From 26fd95f84dce591188d3055001df498cea307ac6 Mon Sep 17 00:00:00 2001 From: Gavin Isgar Date: Sat, 11 Aug 2018 18:56:46 -0400 Subject: [PATCH] Commit v3.1.0 content Commit all v3.1.0 code. --- commands.json | 6 +- main.js | 832 +- main.ts | 896 +- node_modules/.bin/cake | 15 + node_modules/.bin/cake.cmd | 7 + node_modules/.bin/coffee | 15 + node_modules/.bin/coffee.cmd | 7 + node_modules/.bin/pbjs | 15 + node_modules/.bin/pbjs.cmd | 7 + node_modules/.bin/pbts | 15 + node_modules/.bin/pbts.cmd | 7 + node_modules/@protobufjs/aspromise/LICENSE | 26 + node_modules/@protobufjs/aspromise/README.md | 13 + node_modules/@protobufjs/aspromise/index.d.ts | 13 + node_modules/@protobufjs/aspromise/index.js | 52 + .../@protobufjs/aspromise/package.json | 55 + .../@protobufjs/aspromise/tests/index.js | 130 + node_modules/@protobufjs/base64/LICENSE | 26 + node_modules/@protobufjs/base64/README.md | 19 + node_modules/@protobufjs/base64/index.d.ts | 32 + node_modules/@protobufjs/base64/index.js | 139 + node_modules/@protobufjs/base64/package.json | 54 + .../@protobufjs/base64/tests/index.js | 46 + node_modules/@protobufjs/codegen/LICENSE | 26 + node_modules/@protobufjs/codegen/README.md | 49 + node_modules/@protobufjs/codegen/index.d.ts | 31 + node_modules/@protobufjs/codegen/index.js | 99 + node_modules/@protobufjs/codegen/package.json | 46 + .../@protobufjs/codegen/tests/index.js | 13 + node_modules/@protobufjs/eventemitter/LICENSE | 26 + .../@protobufjs/eventemitter/README.md | 22 + .../@protobufjs/eventemitter/index.d.ts | 43 + .../@protobufjs/eventemitter/index.js | 76 + .../@protobufjs/eventemitter/package.json | 54 + .../@protobufjs/eventemitter/tests/index.js | 47 + node_modules/@protobufjs/fetch/LICENSE | 26 + node_modules/@protobufjs/fetch/README.md | 13 + node_modules/@protobufjs/fetch/index.d.ts | 56 + node_modules/@protobufjs/fetch/index.js | 115 + node_modules/@protobufjs/fetch/package.json | 58 + node_modules/@protobufjs/fetch/tests/index.js | 16 + node_modules/@protobufjs/float/LICENSE | 26 + node_modules/@protobufjs/float/README.md | 102 + node_modules/@protobufjs/float/bench/index.js | 87 + node_modules/@protobufjs/float/bench/suite.js | 46 + node_modules/@protobufjs/float/index.d.ts | 83 + node_modules/@protobufjs/float/index.js | 335 + node_modules/@protobufjs/float/package.json | 59 + node_modules/@protobufjs/float/tests/index.js | 100 + node_modules/@protobufjs/inquire/.npmignore | 3 + node_modules/@protobufjs/inquire/LICENSE | 26 + node_modules/@protobufjs/inquire/README.md | 13 + node_modules/@protobufjs/inquire/index.d.ts | 9 + node_modules/@protobufjs/inquire/index.js | 17 + node_modules/@protobufjs/inquire/package.json | 55 + .../@protobufjs/inquire/tests/data/array.js | 1 + .../inquire/tests/data/emptyArray.js | 1 + .../inquire/tests/data/emptyObject.js | 1 + .../@protobufjs/inquire/tests/data/object.js | 1 + .../@protobufjs/inquire/tests/index.js | 20 + node_modules/@protobufjs/path/LICENSE | 26 + node_modules/@protobufjs/path/README.md | 19 + node_modules/@protobufjs/path/index.d.ts | 22 + node_modules/@protobufjs/path/index.js | 65 + node_modules/@protobufjs/path/package.json | 54 + node_modules/@protobufjs/path/tests/index.js | 60 + node_modules/@protobufjs/pool/.npmignore | 3 + node_modules/@protobufjs/pool/LICENSE | 26 + node_modules/@protobufjs/pool/README.md | 13 + node_modules/@protobufjs/pool/index.d.ts | 32 + node_modules/@protobufjs/pool/index.js | 48 + node_modules/@protobufjs/pool/package.json | 54 + node_modules/@protobufjs/pool/tests/index.js | 33 + node_modules/@protobufjs/utf8/.npmignore | 3 + node_modules/@protobufjs/utf8/LICENSE | 26 + node_modules/@protobufjs/utf8/README.md | 20 + node_modules/@protobufjs/utf8/index.d.ts | 24 + node_modules/@protobufjs/utf8/index.js | 105 + node_modules/@protobufjs/utf8/package.json | 54 + .../@protobufjs/utf8/tests/data/utf8.txt | 216 + node_modules/@protobufjs/utf8/tests/index.js | 57 + .../@tensorflow/tfjs-converter/LICENSE | 202 + .../@tensorflow/tfjs-converter/README.md | 255 + .../dist/data/compiled_api.d.ts | 1617 ++ .../tfjs-converter/dist/data/compiled_api.js | 1723 ++ .../tfjs-converter/dist/data/types.d.ts | 16 + .../tfjs-converter/dist/data/types.js | 3 + .../tfjs-converter/dist/docs/doc_gen.d.ts | 1 + .../tfjs-converter/dist/docs/doc_gen.js | 121 + .../dist/executor/execution_context.d.ts | 29 + .../dist/executor/execution_context.js | 104 + .../dist/executor/frozen_model.d.ts | 29 + .../dist/executor/frozen_model.js | 252 + .../dist/executor/graph_executor.d.ts | 26 + .../dist/executor/graph_executor.js | 307 + .../dist/executor/tensor_array.d.ts | 32 + .../dist/executor/tensor_array.js | 171 + .../tfjs-converter/dist/index.d.ts | 2 + .../@tensorflow/tfjs-converter/dist/index.js | 8 + .../executors/arithmetic_executor.d.ts | 3 + .../executors/arithmetic_executor.js | 40 + .../executors/basic_math_executor.d.ts | 3 + .../executors/basic_math_executor.js | 88 + .../executors/control_executor.d.ts | 6 + .../operations/executors/control_executor.js | 152 + .../executors/convolution_executor.d.ts | 3 + .../executors/convolution_executor.js | 54 + .../executors/creation_executor.d.ts | 3 + .../operations/executors/creation_executor.js | 58 + .../executors/dynamic_executor.d.ts | 3 + .../operations/executors/dynamic_executor.js | 67 + .../executors/evaluation_executor.d.ts | 3 + .../executors/evaluation_executor.js | 19 + .../operations/executors/graph_executor.d.ts | 3 + .../operations/executors/graph_executor.js | 45 + .../operations/executors/image_executor.d.ts | 3 + .../operations/executors/image_executor.js | 24 + .../executors/logical_executor.d.ts | 3 + .../operations/executors/logical_executor.js | 42 + .../executors/matrices_executor.d.ts | 3 + .../operations/executors/matrices_executor.js | 16 + .../executors/normalization_executor.d.ts | 3 + .../executors/normalization_executor.js | 21 + .../executors/reduction_executor.d.ts | 3 + .../executors/reduction_executor.js | 50 + .../executors/slice_join_executor.d.ts | 3 + .../executors/slice_join_executor.js | 82 + .../operations/executors/test_helper.d.ts | 10 + .../dist/operations/executors/test_helper.js | 39 + .../executors/transformation_executor.d.ts | 3 + .../executors/transformation_executor.js | 39 + .../dist/operations/executors/types.d.ts | 7 + .../dist/operations/executors/types.js | 3 + .../dist/operations/executors/utils.d.ts | 9 + .../dist/operations/executors/utils.js | 61 + .../dist/operations/op_list/arithmetic.json | 266 + .../dist/operations/op_list/basic_math.json | 646 + .../dist/operations/op_list/control.json | 364 + .../dist/operations/op_list/convolution.json | 288 + .../dist/operations/op_list/creation.json | 285 + .../dist/operations/op_list/dynamic.json | 79 + .../dist/operations/op_list/evaluation.json | 24 + .../dist/operations/op_list/graph.json | 181 + .../dist/operations/op_list/image.json | 117 + .../dist/operations/op_list/logical.json | 232 + .../dist/operations/op_list/matrices.json | 60 + .../operations/op_list/normalization.json | 137 + .../dist/operations/op_list/reduction.json | 168 + .../dist/operations/op_list/slice_join.json | 263 + .../operations/op_list/transformation.json | 161 + .../dist/operations/operation_executor.d.ts | 5 + .../dist/operations/operation_executor.js | 55 + .../dist/operations/operation_mapper.d.ts | 18 + .../dist/operations/operation_mapper.js | 218 + .../tfjs-converter/dist/operations/types.d.ts | 49 + .../tfjs-converter/dist/operations/types.js | 3 + .../dist/operations/typings.d.ts | 21 + .../tfjs-converter/dist/tf-converter.esm.js | 17 + .../tfjs-converter/dist/tf-converter.js | 10787 +++++++++++ .../tfjs-converter/dist/tf-converter.min.js | 17 + .../tfjs-converter/dist/version.d.ts | 2 + .../tfjs-converter/dist/version.js | 5 + .../@tensorflow/tfjs-converter/package.json | 97 + node_modules/@tensorflow/tfjs-core/LICENSE | 202 + node_modules/@tensorflow/tfjs-core/README.md | 45 + .../tfjs-core/dist/browser_util.d.ts | 2 + .../tfjs-core/dist/browser_util.js | 10 + .../tfjs-core/dist/browser_util.js.map | 1 + .../tfjs-core/dist/browser_util_test.d.ts | 1 + .../tfjs-core/dist/browser_util_test.js | 83 + .../tfjs-core/dist/browser_util_test.js.map | 1 + .../tfjs-core/dist/debug_mode_test.d.ts | 1 + .../tfjs-core/dist/debug_mode_test.js | 58 + .../tfjs-core/dist/debug_mode_test.js.map | 1 + .../tfjs-core/dist/device_util.d.ts | 1 + .../@tensorflow/tfjs-core/dist/device_util.js | 11 + .../tfjs-core/dist/device_util.js.map | 1 + .../@tensorflow/tfjs-core/dist/engine.d.ts | 73 + .../@tensorflow/tfjs-core/dist/engine.js | 376 + .../@tensorflow/tfjs-core/dist/engine.js.map | 1 + .../tfjs-core/dist/engine_test.d.ts | 1 + .../@tensorflow/tfjs-core/dist/engine_test.js | 275 + .../tfjs-core/dist/engine_test.js.map | 1 + .../tfjs-core/dist/environment.d.ts | 35 + .../@tensorflow/tfjs-core/dist/environment.js | 233 + .../tfjs-core/dist/environment.js.map | 1 + .../tfjs-core/dist/environment_test.d.ts | 1 + .../tfjs-core/dist/environment_test.js | 219 + .../tfjs-core/dist/environment_test.js.map | 1 + .../tfjs-core/dist/environment_util.d.ts | 36 + .../tfjs-core/dist/environment_util.js | 200 + .../tfjs-core/dist/environment_util.js.map | 1 + .../@tensorflow/tfjs-core/dist/globals.d.ts | 6 + .../@tensorflow/tfjs-core/dist/globals.js | 15 + .../@tensorflow/tfjs-core/dist/globals.js.map | 1 + .../@tensorflow/tfjs-core/dist/gradients.d.ts | 20 + .../@tensorflow/tfjs-core/dist/gradients.js | 112 + .../tfjs-core/dist/gradients.js.map | 1 + .../@tensorflow/tfjs-core/dist/index.d.ts | 38 + .../@tensorflow/tfjs-core/dist/index.js | 63 + .../@tensorflow/tfjs-core/dist/index.js.map | 1 + .../tfjs-core/dist/io/browser_files.d.ts | 14 + .../tfjs-core/dist/io/browser_files.js | 240 + .../tfjs-core/dist/io/browser_files.js.map | 1 + .../tfjs-core/dist/io/browser_files_test.d.ts | 1 + .../tfjs-core/dist/io/browser_files_test.js | 689 + .../dist/io/browser_files_test.js.map | 1 + .../tfjs-core/dist/io/browser_http.d.ts | 13 + .../tfjs-core/dist/io/browser_http.js | 166 + .../tfjs-core/dist/io/browser_http.js.map | 1 + .../tfjs-core/dist/io/browser_http_test.d.ts | 1 + .../tfjs-core/dist/io/browser_http_test.js | 576 + .../dist/io/browser_http_test.js.map | 1 + .../tfjs-core/dist/io/indexed_db.d.ts | 22 + .../tfjs-core/dist/io/indexed_db.js | 309 + .../tfjs-core/dist/io/indexed_db.js.map | 1 + .../tfjs-core/dist/io/indexed_db_test.d.ts | 1 + .../tfjs-core/dist/io/indexed_db_test.js | 313 + .../tfjs-core/dist/io/indexed_db_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/io/io.d.ts | 15 + .../@tensorflow/tfjs-core/dist/io/io.js | 33 + .../@tensorflow/tfjs-core/dist/io/io.js.map | 1 + .../tfjs-core/dist/io/io_utils.d.ts | 15 + .../@tensorflow/tfjs-core/dist/io/io_utils.js | 195 + .../tfjs-core/dist/io/io_utils.js.map | 1 + .../tfjs-core/dist/io/io_utils_test.d.ts | 1 + .../tfjs-core/dist/io/io_utils_test.js | 465 + .../tfjs-core/dist/io/io_utils_test.js.map | 1 + .../tfjs-core/dist/io/local_storage.d.ts | 24 + .../tfjs-core/dist/io/local_storage.js | 246 + .../tfjs-core/dist/io/local_storage.js.map | 1 + .../tfjs-core/dist/io/local_storage_test.d.ts | 1 + .../tfjs-core/dist/io/local_storage_test.js | 379 + .../dist/io/local_storage_test.js.map | 1 + .../tfjs-core/dist/io/model_management.d.ts | 17 + .../tfjs-core/dist/io/model_management.js | 203 + .../tfjs-core/dist/io/model_management.js.map | 1 + .../dist/io/model_management_test.d.ts | 1 + .../dist/io/model_management_test.js | 376 + .../dist/io/model_management_test.js.map | 1 + .../tfjs-core/dist/io/passthrough.d.ts | 3 + .../tfjs-core/dist/io/passthrough.js | 93 + .../tfjs-core/dist/io/passthrough.js.map | 1 + .../tfjs-core/dist/io/passthrough_test.d.ts | 1 + .../tfjs-core/dist/io/passthrough_test.js | 167 + .../tfjs-core/dist/io/passthrough_test.js.map | 1 + .../tfjs-core/dist/io/router_registry.d.ts | 14 + .../tfjs-core/dist/io/router_registry.js | 41 + .../tfjs-core/dist/io/router_registry.js.map | 1 + .../dist/io/router_registry_test.d.ts | 1 + .../tfjs-core/dist/io/router_registry_test.js | 62 + .../dist/io/router_registry_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/io/types.d.ts | 50 + .../@tensorflow/tfjs-core/dist/io/types.js | 10 + .../tfjs-core/dist/io/types.js.map | 1 + .../tfjs-core/dist/io/weights_loader.d.ts | 4 + .../tfjs-core/dist/io/weights_loader.js | 200 + .../tfjs-core/dist/io/weights_loader.js.map | 1 + .../dist/io/weights_loader_test.d.ts | 1 + .../tfjs-core/dist/io/weights_loader_test.js | 531 + .../dist/io/weights_loader_test.js.map | 1 + .../tfjs-core/dist/jasmine_util.d.ts | 14 + .../tfjs-core/dist/jasmine_util.js | 112 + .../tfjs-core/dist/jasmine_util.js.map | 1 + .../tfjs-core/dist/jasmine_util_test.d.ts | 1 + .../tfjs-core/dist/jasmine_util_test.js | 61 + .../tfjs-core/dist/jasmine_util_test.js.map | 1 + .../tfjs-core/dist/kernels/backend.d.ts | 125 + .../tfjs-core/dist/kernels/backend.js | 3 + .../tfjs-core/dist/kernels/backend.js.map | 1 + .../tfjs-core/dist/kernels/backend_cpu.d.ts | 127 + .../tfjs-core/dist/kernels/backend_cpu.js | 1776 ++ .../tfjs-core/dist/kernels/backend_cpu.js.map | 1 + .../tfjs-core/dist/kernels/backend_util.d.ts | 6 + .../tfjs-core/dist/kernels/backend_util.js | 25 + .../dist/kernels/backend_util.js.map | 1 + .../tfjs-core/dist/kernels/backend_webgl.d.ts | 172 + .../tfjs-core/dist/kernels/backend_webgl.js | 1132 ++ .../dist/kernels/backend_webgl.js.map | 1 + .../dist/kernels/backend_webgl_test.d.ts | 1 + .../dist/kernels/backend_webgl_test.js | 176 + .../dist/kernels/backend_webgl_test.js.map | 1 + .../kernels/non_max_suppression_impl.d.ts | 3 + .../dist/kernels/non_max_suppression_impl.js | 57 + .../kernels/non_max_suppression_impl.js.map | 1 + .../tfjs-core/dist/kernels/topk_impl.d.ts | 3 + .../tfjs-core/dist/kernels/topk_impl.js | 34 + .../tfjs-core/dist/kernels/topk_impl.js.map | 1 + .../dist/kernels/webgl/argminmax_gpu.d.ts | 8 + .../dist/kernels/webgl/argminmax_gpu.js | 23 + .../dist/kernels/webgl/argminmax_gpu.js.map | 1 + .../kernels/webgl/avg_pool_backprop_gpu.d.ts | 8 + .../kernels/webgl/avg_pool_backprop_gpu.js | 19 + .../webgl/avg_pool_backprop_gpu.js.map | 1 + .../dist/kernels/webgl/batchnorm_gpu.d.ts | 8 + .../dist/kernels/webgl/batchnorm_gpu.js | 29 + .../dist/kernels/webgl/batchnorm_gpu.js.map | 1 + .../dist/kernels/webgl/binaryop_gpu.d.ts | 31 + .../dist/kernels/webgl/binaryop_gpu.js | 48 + .../dist/kernels/webgl/binaryop_gpu.js.map | 1 + .../dist/kernels/webgl/clip_gpu.d.ts | 7 + .../tfjs-core/dist/kernels/webgl/clip_gpu.js | 14 + .../dist/kernels/webgl/clip_gpu.js.map | 1 + .../dist/kernels/webgl/concat_gpu.d.ts | 7 + .../dist/kernels/webgl/concat_gpu.js | 15 + .../dist/kernels/webgl/concat_gpu.js.map | 1 + .../dist/kernels/webgl/conv_backprop_gpu.d.ts | 14 + .../dist/kernels/webgl/conv_backprop_gpu.js | 31 + .../kernels/webgl/conv_backprop_gpu.js.map | 1 + .../webgl/conv_backprop_gpu_depthwise.d.ts | 14 + .../webgl/conv_backprop_gpu_depthwise.js | 33 + .../webgl/conv_backprop_gpu_depthwise.js.map | 1 + .../dist/kernels/webgl/conv_gpu.d.ts | 8 + .../tfjs-core/dist/kernels/webgl/conv_gpu.js | 22 + .../dist/kernels/webgl/conv_gpu.js.map | 1 + .../kernels/webgl/conv_gpu_depthwise.d.ts | 8 + .../dist/kernels/webgl/conv_gpu_depthwise.js | 23 + .../kernels/webgl/conv_gpu_depthwise.js.map | 1 + .../dist/kernels/webgl/cumsum_gpu.d.ts | 7 + .../dist/kernels/webgl/cumsum_gpu.js | 50 + .../dist/kernels/webgl/cumsum_gpu.js.map | 1 + .../dist/kernels/webgl/encode_float_gpu.d.ts | 7 + .../dist/kernels/webgl/encode_float_gpu.js | 12 + .../kernels/webgl/encode_float_gpu.js.map | 1 + .../dist/kernels/webgl/from_pixels_gpu.d.ts | 7 + .../dist/kernels/webgl/from_pixels_gpu.js | 13 + .../dist/kernels/webgl/from_pixels_gpu.js.map | 1 + .../dist/kernels/webgl/gather_gpu.d.ts | 8 + .../dist/kernels/webgl/gather_gpu.js | 38 + .../dist/kernels/webgl/gather_gpu.js.map | 1 + .../dist/kernels/webgl/gpgpu_context.d.ts | 79 + .../dist/kernels/webgl/gpgpu_context.js | 479 + .../dist/kernels/webgl/gpgpu_context.js.map | 1 + .../kernels/webgl/gpgpu_context_test.d.ts | 1 + .../dist/kernels/webgl/gpgpu_context_test.js | 302 + .../kernels/webgl/gpgpu_context_test.js.map | 1 + .../dist/kernels/webgl/gpgpu_math.d.ts | 29 + .../dist/kernels/webgl/gpgpu_math.js | 113 + .../dist/kernels/webgl/gpgpu_math.js.map | 1 + .../dist/kernels/webgl/gpgpu_util.d.ts | 29 + .../dist/kernels/webgl/gpgpu_util.js | 226 + .../dist/kernels/webgl/gpgpu_util.js.map | 1 + .../dist/kernels/webgl/gpgpu_util_test.d.ts | 1 + .../dist/kernels/webgl/gpgpu_util_test.js | 91 + .../dist/kernels/webgl/gpgpu_util_test.js.map | 1 + .../tfjs-core/dist/kernels/webgl/lrn_gpu.d.ts | 7 + .../tfjs-core/dist/kernels/webgl/lrn_gpu.js | 26 + .../dist/kernels/webgl/lrn_gpu.js.map | 1 + .../dist/kernels/webgl/lrn_grad_gpu.d.ts | 12 + .../dist/kernels/webgl/lrn_grad_gpu.js | 18 + .../dist/kernels/webgl/lrn_grad_gpu.js.map | 1 + .../kernels/webgl/max_pool_backprop_gpu.d.ts | 8 + .../kernels/webgl/max_pool_backprop_gpu.js | 19 + .../webgl/max_pool_backprop_gpu.js.map | 1 + .../dist/kernels/webgl/mulmat_gpu.d.ts | 7 + .../dist/kernels/webgl/mulmat_gpu.js | 27 + .../dist/kernels/webgl/mulmat_gpu.js.map | 1 + .../dist/kernels/webgl/mulmat_packed_gpu.d.ts | 8 + .../dist/kernels/webgl/mulmat_packed_gpu.js | 64 + .../kernels/webgl/mulmat_packed_gpu.js.map | 1 + .../kernels/webgl/mulmat_packed_gpu_test.d.ts | 1 + .../kernels/webgl/mulmat_packed_gpu_test.js | 322 + .../webgl/mulmat_packed_gpu_test.js.map | 1 + .../dist/kernels/webgl/multinomial_gpu.d.ts | 10 + .../dist/kernels/webgl/multinomial_gpu.js | 21 + .../dist/kernels/webgl/multinomial_gpu.js.map | 1 + .../dist/kernels/webgl/onehot_gpu.d.ts | 8 + .../dist/kernels/webgl/onehot_gpu.js | 12 + .../dist/kernels/webgl/onehot_gpu.js.map | 1 + .../tfjs-core/dist/kernels/webgl/pad_gpu.d.ts | 7 + .../tfjs-core/dist/kernels/webgl/pad_gpu.js | 22 + .../dist/kernels/webgl/pad_gpu.js.map | 1 + .../dist/kernels/webgl/pool_gpu.d.ts | 8 + .../tfjs-core/dist/kernels/webgl/pool_gpu.js | 40 + .../dist/kernels/webgl/pool_gpu.js.map | 1 + .../dist/kernels/webgl/reduce_gpu.d.ts | 8 + .../dist/kernels/webgl/reduce_gpu.js | 55 + .../dist/kernels/webgl/reduce_gpu.js.map | 1 + .../webgl/resize_bilinear_backprop_gpu.d.ts | 8 + .../webgl/resize_bilinear_backprop_gpu.js | 29 + .../webgl/resize_bilinear_backprop_gpu.js.map | 1 + .../kernels/webgl/resize_bilinear_gpu.d.ts | 7 + .../dist/kernels/webgl/resize_bilinear_gpu.js | 22 + .../kernels/webgl/resize_bilinear_gpu.js.map | 1 + .../resize_nearest_neighbor_backprop_gpu.d.ts | 8 + .../resize_nearest_neighbor_backprop_gpu.js | 29 + ...esize_nearest_neighbor_backprop_gpu.js.map | 1 + .../webgl/resize_nearest_neighbor_gpu.d.ts | 7 + .../webgl/resize_nearest_neighbor_gpu.js | 23 + .../webgl/resize_nearest_neighbor_gpu.js.map | 1 + .../dist/kernels/webgl/reverse_gpu.d.ts | 7 + .../dist/kernels/webgl/reverse_gpu.js | 29 + .../dist/kernels/webgl/reverse_gpu.js.map | 1 + .../dist/kernels/webgl/segment_gpu.d.ts | 8 + .../dist/kernels/webgl/segment_gpu.js | 30 + .../dist/kernels/webgl/segment_gpu.js.map | 1 + .../dist/kernels/webgl/select_gpu.d.ts | 7 + .../dist/kernels/webgl/select_gpu.js | 36 + .../dist/kernels/webgl/select_gpu.js.map | 1 + .../dist/kernels/webgl/shader_compiler.d.ts | 11 + .../dist/kernels/webgl/shader_compiler.js | 414 + .../dist/kernels/webgl/shader_compiler.js.map | 1 + .../dist/kernels/webgl/slice_gpu.d.ts | 11 + .../tfjs-core/dist/kernels/webgl/slice_gpu.js | 63 + .../dist/kernels/webgl/slice_gpu.js.map | 1 + .../dist/kernels/webgl/strided_slice_gpu.d.ts | 8 + .../dist/kernels/webgl/strided_slice_gpu.js | 24 + .../kernels/webgl/strided_slice_gpu.js.map | 1 + .../dist/kernels/webgl/tex_util.d.ts | 32 + .../tfjs-core/dist/kernels/webgl/tex_util.js | 192 + .../dist/kernels/webgl/tex_util.js.map | 1 + .../dist/kernels/webgl/tex_util_test.d.ts | 1 + .../dist/kernels/webgl/tex_util_test.js | 204 + .../dist/kernels/webgl/tex_util_test.js.map | 1 + .../dist/kernels/webgl/texture_manager.d.ts | 17 + .../dist/kernels/webgl/texture_manager.js | 121 + .../dist/kernels/webgl/texture_manager.js.map | 1 + .../dist/kernels/webgl/tile_gpu.d.ts | 8 + .../tfjs-core/dist/kernels/webgl/tile_gpu.js | 35 + .../dist/kernels/webgl/tile_gpu.js.map | 1 + .../dist/kernels/webgl/transpose_gpu.d.ts | 8 + .../dist/kernels/webgl/transpose_gpu.js | 32 + .../dist/kernels/webgl/transpose_gpu.js.map | 1 + .../dist/kernels/webgl/unaryop_gpu.d.ts | 45 + .../dist/kernels/webgl/unaryop_gpu.js | 66 + .../dist/kernels/webgl/unaryop_gpu.js.map | 1 + .../dist/kernels/webgl/webgl_types.d.ts | 26 + .../dist/kernels/webgl/webgl_types.js | 3 + .../dist/kernels/webgl/webgl_types.js.map | 1 + .../dist/kernels/webgl/webgl_util.d.ts | 31 + .../dist/kernels/webgl/webgl_util.js | 310 + .../dist/kernels/webgl/webgl_util.js.map | 1 + .../dist/kernels/webgl/webgl_util_test.d.ts | 1 + .../dist/kernels/webgl/webgl_util_test.js | 49 + .../dist/kernels/webgl/webgl_util_test.js.map | 1 + .../tfjs-core/dist/kernels/where_impl.d.ts | 3 + .../tfjs-core/dist/kernels/where_impl.js | 21 + .../tfjs-core/dist/kernels/where_impl.js.map | 1 + .../@tensorflow/tfjs-core/dist/log.d.ts | 2 + .../@tensorflow/tfjs-core/dist/log.js | 24 + .../@tensorflow/tfjs-core/dist/log.js.map | 1 + .../tfjs-core/dist/model_types.d.ts | 12 + .../@tensorflow/tfjs-core/dist/model_types.js | 3 + .../tfjs-core/dist/model_types.js.map | 1 + .../tfjs-core/dist/ops/arithmetic_test.d.ts | 1 + .../tfjs-core/dist/ops/arithmetic_test.js | 946 + .../tfjs-core/dist/ops/arithmetic_test.js.map | 1 + .../tfjs-core/dist/ops/array_ops.d.ts | 56 + .../tfjs-core/dist/ops/array_ops.js | 526 + .../tfjs-core/dist/ops/array_ops.js.map | 1 + .../tfjs-core/dist/ops/array_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/array_ops_test.js | 2743 +++ .../tfjs-core/dist/ops/array_ops_test.js.map | 1 + .../tfjs-core/dist/ops/array_ops_util.d.ts | 5 + .../tfjs-core/dist/ops/array_ops_util.js | 97 + .../tfjs-core/dist/ops/array_ops_util.js.map | 1 + .../tfjs-core/dist/ops/axis_util.d.ts | 9 + .../tfjs-core/dist/ops/axis_util.js | 89 + .../tfjs-core/dist/ops/axis_util.js.map | 1 + .../tfjs-core/dist/ops/axis_util_test.d.ts | 1 + .../tfjs-core/dist/ops/axis_util_test.js | 224 + .../tfjs-core/dist/ops/axis_util_test.js.map | 1 + .../tfjs-core/dist/ops/batchnorm.d.ts | 11 + .../tfjs-core/dist/ops/batchnorm.js | 219 + .../tfjs-core/dist/ops/batchnorm.js.map | 1 + .../tfjs-core/dist/ops/batchnorm_test.d.ts | 1 + .../tfjs-core/dist/ops/batchnorm_test.js | 533 + .../tfjs-core/dist/ops/batchnorm_test.js.map | 1 + .../tfjs-core/dist/ops/binary_ops.d.ts | 45 + .../tfjs-core/dist/ops/binary_ops.js | 365 + .../tfjs-core/dist/ops/binary_ops.js.map | 1 + .../tfjs-core/dist/ops/binary_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/binary_ops_test.js | 744 + .../tfjs-core/dist/ops/binary_ops_test.js.map | 1 + .../tfjs-core/dist/ops/broadcast_util.d.ts | 4 + .../tfjs-core/dist/ops/broadcast_util.js | 55 + .../tfjs-core/dist/ops/broadcast_util.js.map | 1 + .../dist/ops/broadcast_util_test.d.ts | 1 + .../tfjs-core/dist/ops/broadcast_util_test.js | 147 + .../dist/ops/broadcast_util_test.js.map | 1 + .../tfjs-core/dist/ops/clone_test.d.ts | 1 + .../tfjs-core/dist/ops/clone_test.js | 20 + .../tfjs-core/dist/ops/clone_test.js.map | 1 + .../tfjs-core/dist/ops/compare.d.ts | 27 + .../@tensorflow/tfjs-core/dist/ops/compare.js | 99 + .../tfjs-core/dist/ops/compare.js.map | 1 + .../tfjs-core/dist/ops/compareop_test.d.ts | 1 + .../tfjs-core/dist/ops/compareop_test.js | 1775 ++ .../tfjs-core/dist/ops/compareop_test.js.map | 1 + .../tfjs-core/dist/ops/concat.d.ts | 13 + .../@tensorflow/tfjs-core/dist/ops/concat.js | 52 + .../tfjs-core/dist/ops/concat.js.map | 1 + .../tfjs-core/dist/ops/concat_test.d.ts | 1 + .../tfjs-core/dist/ops/concat_test.js | 247 + .../tfjs-core/dist/ops/concat_test.js.map | 1 + .../tfjs-core/dist/ops/concat_util.d.ts | 8 + .../tfjs-core/dist/ops/concat_util.js | 33 + .../tfjs-core/dist/ops/concat_util.js.map | 1 + .../tfjs-core/dist/ops/concat_util_test.d.ts | 1 + .../tfjs-core/dist/ops/concat_util_test.js | 63 + .../dist/ops/concat_util_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/conv.d.ts | 13 + .../@tensorflow/tfjs-core/dist/ops/conv.js | 267 + .../tfjs-core/dist/ops/conv.js.map | 1 + .../tfjs-core/dist/ops/conv1d_test.d.ts | 1 + .../tfjs-core/dist/ops/conv1d_test.js | 210 + .../tfjs-core/dist/ops/conv1d_test.js.map | 1 + .../dist/ops/conv2d_depthwise_test.d.ts | 1 + .../dist/ops/conv2d_depthwise_test.js | 377 + .../dist/ops/conv2d_depthwise_test.js.map | 1 + .../dist/ops/conv2d_separable_test.d.ts | 1 + .../dist/ops/conv2d_separable_test.js | 296 + .../dist/ops/conv2d_separable_test.js.map | 1 + .../tfjs-core/dist/ops/conv2d_test.d.ts | 1 + .../tfjs-core/dist/ops/conv2d_test.js | 192 + .../tfjs-core/dist/ops/conv2d_test.js.map | 1 + .../dist/ops/conv2d_transpose_test.d.ts | 1 + .../dist/ops/conv2d_transpose_test.js | 101 + .../dist/ops/conv2d_transpose_test.js.map | 1 + .../tfjs-core/dist/ops/conv_util.d.ts | 30 + .../tfjs-core/dist/ops/conv_util.js | 146 + .../tfjs-core/dist/ops/conv_util.js.map | 1 + .../tfjs-core/dist/ops/conv_util_test.d.ts | 1 + .../tfjs-core/dist/ops/conv_util_test.js | 322 + .../tfjs-core/dist/ops/conv_util_test.js.map | 1 + .../tfjs-core/dist/ops/erf_util.d.ts | 6 + .../tfjs-core/dist/ops/erf_util.js | 9 + .../tfjs-core/dist/ops/erf_util.js.map | 1 + .../tfjs-core/dist/ops/image_ops.d.ts | 11 + .../tfjs-core/dist/ops/image_ops.js | 168 + .../tfjs-core/dist/ops/image_ops.js.map | 1 + .../tfjs-core/dist/ops/image_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/image_ops_test.js | 211 + .../tfjs-core/dist/ops/image_ops_test.js.map | 1 + .../tfjs-core/dist/ops/linalg_ops.d.ts | 6 + .../tfjs-core/dist/ops/linalg_ops.js | 144 + .../tfjs-core/dist/ops/linalg_ops.js.map | 1 + .../tfjs-core/dist/ops/linalg_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/linalg_ops_test.js | 146 + .../tfjs-core/dist/ops/linalg_ops_test.js.map | 1 + .../tfjs-core/dist/ops/logical_ops.d.ts | 15 + .../tfjs-core/dist/ops/logical_ops.js | 116 + .../tfjs-core/dist/ops/logical_ops.js.map | 1 + .../tfjs-core/dist/ops/logicalop_test.d.ts | 1 + .../tfjs-core/dist/ops/logicalop_test.js | 672 + .../tfjs-core/dist/ops/logicalop_test.js.map | 1 + .../tfjs-core/dist/ops/loss_ops.d.ts | 27 + .../tfjs-core/dist/ops/loss_ops.js | 224 + .../tfjs-core/dist/ops/loss_ops.js.map | 1 + .../tfjs-core/dist/ops/loss_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/loss_ops_test.js | 1049 ++ .../tfjs-core/dist/ops/loss_ops_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/lrn.d.ts | 5 + .../@tensorflow/tfjs-core/dist/ops/lrn.js | 36 + .../@tensorflow/tfjs-core/dist/ops/lrn.js.map | 1 + .../tfjs-core/dist/ops/lrn_test.d.ts | 1 + .../tfjs-core/dist/ops/lrn_test.js | 854 + .../tfjs-core/dist/ops/lrn_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/lstm.d.ts | 10 + .../@tensorflow/tfjs-core/dist/ops/lstm.js | 48 + .../tfjs-core/dist/ops/lstm.js.map | 1 + .../tfjs-core/dist/ops/lstm_test.d.ts | 1 + .../tfjs-core/dist/ops/lstm_test.js | 209 + .../tfjs-core/dist/ops/lstm_test.js.map | 1 + .../tfjs-core/dist/ops/matmul.d.ts | 9 + .../@tensorflow/tfjs-core/dist/ops/matmul.js | 80 + .../tfjs-core/dist/ops/matmul.js.map | 1 + .../tfjs-core/dist/ops/matmul_test.d.ts | 1 + .../tfjs-core/dist/ops/matmul_test.js | 362 + .../tfjs-core/dist/ops/matmul_test.js.map | 1 + .../tfjs-core/dist/ops/moving_average.d.ts | 5 + .../tfjs-core/dist/ops/moving_average.js | 27 + .../tfjs-core/dist/ops/moving_average.js.map | 1 + .../dist/ops/moving_average_test.d.ts | 1 + .../tfjs-core/dist/ops/moving_average_test.js | 77 + .../dist/ops/moving_average_test.js.map | 1 + .../tfjs-core/dist/ops/multinomial_test.d.ts | 1 + .../tfjs-core/dist/ops/multinomial_test.js | 93 + .../dist/ops/multinomial_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/norm.d.ts | 5 + .../@tensorflow/tfjs-core/dist/ops/norm.js | 62 + .../tfjs-core/dist/ops/norm.js.map | 1 + .../tfjs-core/dist/ops/operation.d.ts | 3 + .../tfjs-core/dist/ops/operation.js | 39 + .../tfjs-core/dist/ops/operation.js.map | 1 + .../tfjs-core/dist/ops/operation_test.d.ts | 1 + .../tfjs-core/dist/ops/operation_test.js | 25 + .../tfjs-core/dist/ops/operation_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/ops.d.ts | 29 + .../@tensorflow/tfjs-core/dist/ops/ops.js | 38 + .../@tensorflow/tfjs-core/dist/ops/ops.js.map | 1 + .../tfjs-core/dist/ops/pad_test.d.ts | 1 + .../tfjs-core/dist/ops/pad_test.js | 153 + .../tfjs-core/dist/ops/pad_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/pool.d.ts | 7 + .../@tensorflow/tfjs-core/dist/ops/pool.js | 103 + .../tfjs-core/dist/ops/pool.js.map | 1 + .../tfjs-core/dist/ops/pool_test.d.ts | 1 + .../tfjs-core/dist/ops/pool_test.js | 309 + .../tfjs-core/dist/ops/pool_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/rand.d.ts | 21 + .../@tensorflow/tfjs-core/dist/ops/rand.js | 57 + .../tfjs-core/dist/ops/rand.js.map | 1 + .../tfjs-core/dist/ops/rand_test.d.ts | 1 + .../tfjs-core/dist/ops/rand_test.js | 47 + .../tfjs-core/dist/ops/rand_test.js.map | 1 + .../tfjs-core/dist/ops/rand_util.d.ts | 4 + .../tfjs-core/dist/ops/rand_util.js | 79 + .../tfjs-core/dist/ops/rand_util.js.map | 1 + .../tfjs-core/dist/ops/reduce_util.d.ts | 7 + .../tfjs-core/dist/ops/reduce_util.js | 12 + .../tfjs-core/dist/ops/reduce_util.js.map | 1 + .../tfjs-core/dist/ops/reduction_ops.d.ts | 26 + .../tfjs-core/dist/ops/reduction_ops.js | 213 + .../tfjs-core/dist/ops/reduction_ops.js.map | 1 + .../dist/ops/reduction_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/reduction_ops_test.js | 968 + .../dist/ops/reduction_ops_test.js.map | 1 + .../tfjs-core/dist/ops/relu_ops.d.ts | 13 + .../tfjs-core/dist/ops/relu_ops.js | 65 + .../tfjs-core/dist/ops/relu_ops.js.map | 1 + .../dist/ops/resize_bilinear_test.d.ts | 1 + .../dist/ops/resize_bilinear_test.js | 678 + .../dist/ops/resize_bilinear_test.js.map | 1 + .../ops/resize_nearest_neighbor_test.d.ts | 1 + .../dist/ops/resize_nearest_neighbor_test.js | 500 + .../ops/resize_nearest_neighbor_test.js.map | 1 + .../tfjs-core/dist/ops/reverse.d.ts | 13 + .../@tensorflow/tfjs-core/dist/ops/reverse.js | 45 + .../tfjs-core/dist/ops/reverse.js.map | 1 + .../tfjs-core/dist/ops/reverse_test.d.ts | 1 + .../tfjs-core/dist/ops/reverse_test.js | 270 + .../tfjs-core/dist/ops/reverse_test.js.map | 1 + .../tfjs-core/dist/ops/segment_ops.d.ts | 7 + .../tfjs-core/dist/ops/segment_ops.js | 91 + .../tfjs-core/dist/ops/segment_ops.js.map | 1 + .../tfjs-core/dist/ops/segment_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/segment_ops_test.js | 102 + .../dist/ops/segment_ops_test.js.map | 1 + .../tfjs-core/dist/ops/segment_util.d.ts | 8 + .../tfjs-core/dist/ops/segment_util.js | 41 + .../tfjs-core/dist/ops/segment_util.js.map | 1 + .../tfjs-core/dist/ops/selu_util.d.ts | 2 + .../tfjs-core/dist/ops/selu_util.js | 5 + .../tfjs-core/dist/ops/selu_util.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/slice.d.ts | 13 + .../@tensorflow/tfjs-core/dist/ops/slice.js | 81 + .../tfjs-core/dist/ops/slice.js.map | 1 + .../tfjs-core/dist/ops/slice_test.d.ts | 1 + .../tfjs-core/dist/ops/slice_test.js | 172 + .../tfjs-core/dist/ops/slice_test.js.map | 1 + .../tfjs-core/dist/ops/slice_util.d.ts | 5 + .../tfjs-core/dist/ops/slice_util.js | 76 + .../tfjs-core/dist/ops/slice_util.js.map | 1 + .../tfjs-core/dist/ops/softmax.d.ts | 5 + .../@tensorflow/tfjs-core/dist/ops/softmax.js | 31 + .../tfjs-core/dist/ops/softmax.js.map | 1 + .../tfjs-core/dist/ops/softmax_test.d.ts | 1 + .../tfjs-core/dist/ops/softmax_test.js | 91 + .../tfjs-core/dist/ops/softmax_test.js.map | 1 + .../tfjs-core/dist/ops/strided_slice.d.ts | 5 + .../tfjs-core/dist/ops/strided_slice.js | 13 + .../tfjs-core/dist/ops/strided_slice.js.map | 1 + .../dist/ops/strided_slice_test.d.ts | 1 + .../tfjs-core/dist/ops/strided_slice_test.js | 178 + .../dist/ops/strided_slice_test.js.map | 1 + .../tfjs-core/dist/ops/tensor_ops.d.ts | 21 + .../tfjs-core/dist/ops/tensor_ops.js | 208 + .../tfjs-core/dist/ops/tensor_ops.js.map | 1 + .../@tensorflow/tfjs-core/dist/ops/topk.d.ts | 8 + .../@tensorflow/tfjs-core/dist/ops/topk.js | 22 + .../tfjs-core/dist/ops/topk.js.map | 1 + .../tfjs-core/dist/ops/topk_test.d.ts | 1 + .../tfjs-core/dist/ops/topk_test.js | 101 + .../tfjs-core/dist/ops/topk_test.js.map | 1 + .../tfjs-core/dist/ops/transpose.d.ts | 5 + .../tfjs-core/dist/ops/transpose.js | 29 + .../tfjs-core/dist/ops/transpose.js.map | 1 + .../tfjs-core/dist/ops/transpose_test.d.ts | 1 + .../tfjs-core/dist/ops/transpose_test.js | 110 + .../tfjs-core/dist/ops/transpose_test.js.map | 1 + .../tfjs-core/dist/ops/unary_ops.d.ts | 67 + .../tfjs-core/dist/ops/unary_ops.js | 289 + .../tfjs-core/dist/ops/unary_ops.js.map | 1 + .../tfjs-core/dist/ops/unary_ops_test.d.ts | 1 + .../tfjs-core/dist/ops/unary_ops_test.js | 2240 +++ .../tfjs-core/dist/ops/unary_ops_test.js.map | 1 + .../dist/optimizers/adadelta_optimizer.d.ts | 20 + .../dist/optimizers/adadelta_optimizer.js | 107 + .../dist/optimizers/adadelta_optimizer.js.map | 1 + .../optimizers/adadelta_optimizer_test.d.ts | 1 + .../optimizers/adadelta_optimizer_test.js | 33 + .../optimizers/adadelta_optimizer_test.js.map | 1 + .../dist/optimizers/adagrad_optimizer.d.ts | 16 + .../dist/optimizers/adagrad_optimizer.js | 83 + .../dist/optimizers/adagrad_optimizer.js.map | 1 + .../optimizers/adagrad_optimizer_test.d.ts | 1 + .../dist/optimizers/adagrad_optimizer_test.js | 33 + .../optimizers/adagrad_optimizer_test.js.map | 1 + .../dist/optimizers/adam_optimizer.d.ts | 26 + .../dist/optimizers/adam_optimizer.js | 119 + .../dist/optimizers/adam_optimizer.js.map | 1 + .../dist/optimizers/adam_optimizer_test.d.ts | 1 + .../dist/optimizers/adam_optimizer_test.js | 34 + .../optimizers/adam_optimizer_test.js.map | 1 + .../dist/optimizers/adamax_optimizer.d.ts | 27 + .../dist/optimizers/adamax_optimizer.js | 121 + .../dist/optimizers/adamax_optimizer.js.map | 1 + .../optimizers/adamax_optimizer_test.d.ts | 1 + .../dist/optimizers/adamax_optimizer_test.js | 35 + .../optimizers/adamax_optimizer_test.js.map | 1 + .../dist/optimizers/momentum_optimizer.d.ts | 17 + .../dist/optimizers/momentum_optimizer.js | 89 + .../dist/optimizers/momentum_optimizer.js.map | 1 + .../optimizers/momentum_optimizer_test.d.ts | 1 + .../optimizers/momentum_optimizer_test.js | 54 + .../optimizers/momentum_optimizer_test.js.map | 1 + .../tfjs-core/dist/optimizers/optimizer.d.ts | 11 + .../tfjs-core/dist/optimizers/optimizer.js | 40 + .../dist/optimizers/optimizer.js.map | 1 + .../optimizers/optimizer_constructors.d.ts | 16 + .../dist/optimizers/optimizer_constructors.js | 55 + .../optimizers/optimizer_constructors.js.map | 1 + .../dist/optimizers/optimizer_test.d.ts | 1 + .../dist/optimizers/optimizer_test.js | 136 + .../dist/optimizers/optimizer_test.js.map | 1 + .../dist/optimizers/optimizer_utils.d.ts | 1 + .../dist/optimizers/optimizer_utils.js | 13 + .../dist/optimizers/optimizer_utils.js.map | 1 + .../dist/optimizers/rmsprop_optimizer.d.ts | 24 + .../dist/optimizers/rmsprop_optimizer.js | 144 + .../dist/optimizers/rmsprop_optimizer.js.map | 1 + .../optimizers/rmsprop_optimizer_test.d.ts | 1 + .../dist/optimizers/rmsprop_optimizer_test.js | 56 + .../optimizers/rmsprop_optimizer_test.js.map | 1 + .../dist/optimizers/sgd_optimizer.d.ts | 15 + .../dist/optimizers/sgd_optimizer.js | 59 + .../dist/optimizers/sgd_optimizer.js.map | 1 + .../dist/optimizers/sgd_optimizer_test.d.ts | 1 + .../dist/optimizers/sgd_optimizer_test.js | 35 + .../dist/optimizers/sgd_optimizer_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/profiler.d.ts | 12 + .../@tensorflow/tfjs-core/dist/profiler.js | 46 + .../tfjs-core/dist/profiler.js.map | 1 + .../tfjs-core/dist/profiler_test.d.ts | 1 + .../tfjs-core/dist/profiler_test.js | 147 + .../tfjs-core/dist/profiler_test.js.map | 1 + .../tfjs-core/dist/serialization.d.ts | 26 + .../tfjs-core/dist/serialization.js | 33 + .../tfjs-core/dist/serialization.js.map | 1 + .../@tensorflow/tfjs-core/dist/tape.d.ts | 16 + .../@tensorflow/tfjs-core/dist/tape.js | 100 + .../@tensorflow/tfjs-core/dist/tape.js.map | 1 + .../@tensorflow/tfjs-core/dist/tape_test.d.ts | 1 + .../@tensorflow/tfjs-core/dist/tape_test.js | 235 + .../tfjs-core/dist/tape_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/tensor.d.ts | 316 + .../@tensorflow/tfjs-core/dist/tensor.js | 836 + .../@tensorflow/tfjs-core/dist/tensor.js.map | 1 + .../tfjs-core/dist/tensor_format.d.ts | 2 + .../tfjs-core/dist/tensor_format.js | 105 + .../tfjs-core/dist/tensor_format.js.map | 1 + .../tfjs-core/dist/tensor_test.d.ts | 1 + .../@tensorflow/tfjs-core/dist/tensor_test.js | 1057 ++ .../tfjs-core/dist/tensor_test.js.map | 1 + .../tfjs-core/dist/tensor_types.d.ts | 19 + .../tfjs-core/dist/tensor_types.js | 3 + .../tfjs-core/dist/tensor_types.js.map | 1 + .../tfjs-core/dist/tensor_util.d.ts | 7 + .../@tensorflow/tfjs-core/dist/tensor_util.js | 74 + .../tfjs-core/dist/tensor_util.js.map | 1 + .../tfjs-core/dist/tensor_util_env.d.ts | 4 + .../tfjs-core/dist/tensor_util_env.js | 33 + .../tfjs-core/dist/tensor_util_env.js.map | 1 + .../tfjs-core/dist/tensor_util_test.d.ts | 1 + .../tfjs-core/dist/tensor_util_test.js | 159 + .../tfjs-core/dist/tensor_util_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/test_env.d.ts | 2 + .../@tensorflow/tfjs-core/dist/test_env.js | 5 + .../tfjs-core/dist/test_env.js.map | 1 + .../@tensorflow/tfjs-core/dist/test_node.d.ts | 1 + .../@tensorflow/tfjs-core/dist/test_node.js | 11 + .../tfjs-core/dist/test_node.js.map | 1 + .../@tensorflow/tfjs-core/dist/test_util.d.ts | 19 + .../@tensorflow/tfjs-core/dist/test_util.js | 120 + .../tfjs-core/dist/test_util.js.map | 1 + .../@tensorflow/tfjs-core/dist/tf-core.esm.js | 18 + .../tfjs-core/dist/tf-core.esm.js.map | 1 + .../@tensorflow/tfjs-core/dist/tf-core.js | 15500 ++++++++++++++++ .../@tensorflow/tfjs-core/dist/tf-core.js.map | 1 + .../@tensorflow/tfjs-core/dist/tf-core.min.js | 18 + .../tfjs-core/dist/tf-core.min.js.map | 1 + .../tfjs-core/dist/tracking_test.d.ts | 1 + .../tfjs-core/dist/tracking_test.js | 300 + .../tfjs-core/dist/tracking_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/train.d.ts | 10 + .../@tensorflow/tfjs-core/dist/train.js | 22 + .../@tensorflow/tfjs-core/dist/train.js.map | 1 + .../@tensorflow/tfjs-core/dist/types.d.ts | 45 + .../@tensorflow/tfjs-core/dist/types.js | 50 + .../@tensorflow/tfjs-core/dist/types.js.map | 1 + .../@tensorflow/tfjs-core/dist/util.d.ts | 37 + .../@tensorflow/tfjs-core/dist/util.js | 417 + .../@tensorflow/tfjs-core/dist/util.js.map | 1 + .../@tensorflow/tfjs-core/dist/util_test.d.ts | 1 + .../@tensorflow/tfjs-core/dist/util_test.js | 199 + .../tfjs-core/dist/util_test.js.map | 1 + .../tfjs-core/dist/variable_test.d.ts | 1 + .../tfjs-core/dist/variable_test.js | 137 + .../tfjs-core/dist/variable_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/version.d.ts | 2 + .../@tensorflow/tfjs-core/dist/version.js | 5 + .../@tensorflow/tfjs-core/dist/version.js.map | 1 + .../tfjs-core/dist/version_test.d.ts | 1 + .../tfjs-core/dist/version_test.js | 10 + .../tfjs-core/dist/version_test.js.map | 1 + .../@tensorflow/tfjs-core/dist/webgl.d.ts | 5 + .../@tensorflow/tfjs-core/dist/webgl.js | 11 + .../@tensorflow/tfjs-core/dist/webgl.js.map | 1 + .../@tensorflow/tfjs-core/package.json | 90 + node_modules/@tensorflow/tfjs-layers/LICENSE | 249 + .../@tensorflow/tfjs-layers/README.md | 96 + .../tfjs-layers/dist/activations.d.ts | 53 + .../tfjs-layers/dist/activations.js | 200 + .../tfjs-layers/dist/activations.js.map | 1 + .../tfjs-layers/dist/activations_test.js.map | 1 + .../tfjs-layers/dist/backend/common.d.ts | 4 + .../tfjs-layers/dist/backend/common.js | 16 + .../tfjs-layers/dist/backend/common.js.map | 1 + .../tfjs-layers/dist/backend/state.d.ts | 5 + .../tfjs-layers/dist/backend/state.js | 44 + .../tfjs-layers/dist/backend/state.js.map | 1 + .../dist/backend/state_test.js.map | 1 + .../dist/backend/tfjs_backend.d.ts | 31 + .../tfjs-layers/dist/backend/tfjs_backend.js | 396 + .../dist/backend/tfjs_backend.js.map | 1 + .../dist/backend/tfjs_backend_test.js.map | 1 + .../tfjs-layers/dist/base_callbacks.d.ts | 73 + .../tfjs-layers/dist/base_callbacks.js | 570 + .../tfjs-layers/dist/base_callbacks.js.map | 1 + .../dist/base_callbacks_test.js.map | 1 + .../tfjs-layers/dist/callbacks.d.ts | 7 + .../@tensorflow/tfjs-layers/dist/callbacks.js | 31 + .../tfjs-layers/dist/callbacks.js.map | 1 + .../@tensorflow/tfjs-layers/dist/common.d.ts | 13 + .../@tensorflow/tfjs-layers/dist/common.js | 74 + .../tfjs-layers/dist/common.js.map | 1 + .../tfjs-layers/dist/common_test.js.map | 1 + .../tfjs-layers/dist/constraints.d.ts | 61 + .../tfjs-layers/dist/constraints.js | 163 + .../tfjs-layers/dist/constraints.js.map | 1 + .../tfjs-layers/dist/constraints_test.js.map | 1 + .../tfjs-layers/dist/engine/container.d.ts | 53 + .../tfjs-layers/dist/engine/container.js | 895 + .../tfjs-layers/dist/engine/container.js.map | 1 + .../dist/engine/container_test.js.map | 1 + .../tfjs-layers/dist/engine/executor.d.ts | 16 + .../tfjs-layers/dist/engine/executor.js | 133 + .../tfjs-layers/dist/engine/executor.js.map | 1 + .../dist/engine/executor_test.js.map | 1 + .../tfjs-layers/dist/engine/input_layer.d.ts | 26 + .../tfjs-layers/dist/engine/input_layer.js | 120 + .../dist/engine/input_layer.js.map | 1 + .../dist/engine/input_layer_test.js.map | 1 + .../tfjs-layers/dist/engine/topology.d.ts | 139 + .../tfjs-layers/dist/engine/topology.js | 701 + .../tfjs-layers/dist/engine/topology.js.map | 1 + .../dist/engine/topology_test.js.map | 1 + .../tfjs-layers/dist/engine/training.d.ts | 108 + .../tfjs-layers/dist/engine/training.js | 1158 ++ .../tfjs-layers/dist/engine/training.js.map | 1 + .../dist/engine/training_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/errors.d.ts | 18 + .../@tensorflow/tfjs-layers/dist/errors.js | 73 + .../tfjs-layers/dist/errors.js.map | 1 + .../tfjs-layers/dist/errors_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/exports.d.ts | 10 + .../@tensorflow/tfjs-layers/dist/exports.js | 22 + .../tfjs-layers/dist/exports.js.map | 1 + .../tfjs-layers/dist/exports_constraints.d.ts | 5 + .../tfjs-layers/dist/exports_constraints.js | 20 + .../dist/exports_constraints.js.map | 1 + .../dist/exports_initializers.d.ts | 14 + .../tfjs-layers/dist/exports_initializers.js | 56 + .../dist/exports_initializers.js.map | 1 + .../tfjs-layers/dist/exports_layers.d.ts | 68 + .../tfjs-layers/dist/exports_layers.js | 219 + .../tfjs-layers/dist/exports_layers.js.map | 1 + .../tfjs-layers/dist/exports_metrics.d.ts | 13 + .../tfjs-layers/dist/exports_metrics.js | 53 + .../tfjs-layers/dist/exports_metrics.js.map | 1 + .../dist/exports_regularizers.d.ts | 4 + .../tfjs-layers/dist/exports_regularizers.js | 17 + .../dist/exports_regularizers.js.map | 1 + .../@tensorflow/tfjs-layers/dist/index.d.ts | 17 + .../@tensorflow/tfjs-layers/dist/index.js | 35 + .../@tensorflow/tfjs-layers/dist/index.js.map | 1 + .../tfjs-layers/dist/initializers.d.ts | 142 + .../tfjs-layers/dist/initializers.js | 438 + .../tfjs-layers/dist/initializers.js.map | 1 + .../tfjs-layers/dist/initializers_test.js.map | 1 + .../layers/advanced_activation_test.js.map | 1 + .../dist/layers/advanced_activations.d.ts | 53 + .../dist/layers/advanced_activations.js | 142 + .../dist/layers/advanced_activations.js.map | 1 + .../dist/layers/convolutional.d.ts | 144 + .../tfjs-layers/dist/layers/convolutional.js | 696 + .../dist/layers/convolutional.js.map | 1 + .../dist/layers/convolutional_depthwise.d.ts | 28 + .../dist/layers/convolutional_depthwise.js | 132 + .../layers/convolutional_depthwise.js.map | 1 + .../convolutional_depthwise_test.js.map | 1 + .../dist/layers/convolutional_test.js.map | 1 + .../tfjs-layers/dist/layers/core.d.ts | 97 + .../tfjs-layers/dist/layers/core.js | 348 + .../tfjs-layers/dist/layers/core.js.map | 1 + .../tfjs-layers/dist/layers/core_test.js.map | 1 + .../tfjs-layers/dist/layers/embeddings.d.ts | 35 + .../tfjs-layers/dist/layers/embeddings.js | 118 + .../tfjs-layers/dist/layers/embeddings.js.map | 1 + .../dist/layers/embeddings_test.js.map | 1 + .../tfjs-layers/dist/layers/merge.d.ts | 56 + .../tfjs-layers/dist/layers/merge.js | 446 + .../tfjs-layers/dist/layers/merge.js.map | 1 + .../tfjs-layers/dist/layers/merge_test.js.map | 1 + .../dist/layers/normalization.d.ts | 48 + .../tfjs-layers/dist/layers/normalization.js | 202 + .../dist/layers/normalization.js.map | 1 + .../dist/layers/normalization_test.js.map | 1 + .../tfjs-layers/dist/layers/padding.d.ts | 19 + .../tfjs-layers/dist/layers/padding.js | 171 + .../tfjs-layers/dist/layers/padding.js.map | 1 + .../dist/layers/padding_test.js.map | 1 + .../tfjs-layers/dist/layers/pooling.d.ts | 90 + .../tfjs-layers/dist/layers/pooling.js | 380 + .../tfjs-layers/dist/layers/pooling.js.map | 1 + .../dist/layers/pooling_test.js.map | 1 + .../tfjs-layers/dist/layers/recurrent.d.ts | 286 + .../tfjs-layers/dist/layers/recurrent.js | 1628 ++ .../tfjs-layers/dist/layers/recurrent.js.map | 1 + .../dist/layers/recurrent_test.js.map | 1 + .../dist/layers/serialization.d.ts | 2 + .../tfjs-layers/dist/layers/serialization.js | 10 + .../dist/layers/serialization.js.map | 1 + .../dist/layers/serialization_test.js.map | 1 + .../tfjs-layers/dist/layers/wrappers.d.ts | 61 + .../tfjs-layers/dist/layers/wrappers.js | 416 + .../tfjs-layers/dist/layers/wrappers.js.map | 1 + .../dist/layers/wrappers_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/logs.d.ts | 9 + .../@tensorflow/tfjs-layers/dist/logs.js | 85 + .../@tensorflow/tfjs-layers/dist/logs.js.map | 1 + .../@tensorflow/tfjs-layers/dist/losses.d.ts | 30 + .../@tensorflow/tfjs-layers/dist/losses.js | 191 + .../tfjs-layers/dist/losses.js.map | 1 + .../tfjs-layers/dist/losses_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/metrics.d.ts | 19 + .../@tensorflow/tfjs-layers/dist/metrics.js | 72 + .../tfjs-layers/dist/metrics.js.map | 1 + .../tfjs-layers/dist/metrics_test.js.map | 1 + .../tfjs-layers/dist/model_save_test.js.map | 1 + .../dist/model_summary_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/models.d.ts | 47 + .../@tensorflow/tfjs-layers/dist/models.js | 397 + .../tfjs-layers/dist/models.js.map | 1 + .../tfjs-layers/dist/models_test.js.map | 1 + .../tfjs-layers/dist/optimizers.d.ts | 2 + .../tfjs-layers/dist/optimizers.js | 27 + .../tfjs-layers/dist/optimizers.js.map | 1 + .../tfjs-layers/dist/optimizers_test.js.map | 1 + .../tfjs-layers/dist/regularizers.d.ts | 34 + .../tfjs-layers/dist/regularizers.js | 102 + .../tfjs-layers/dist/regularizers.js.map | 1 + .../tfjs-layers/dist/regularizers_test.js.map | 1 + .../tfjs-layers/dist/tf-layers.esm.js | 18 + .../tfjs-layers/dist/tf-layers.esm.js.map | 1 + .../@tensorflow/tfjs-layers/dist/tf-layers.js | 10592 +++++++++++ .../tfjs-layers/dist/tf-layers.js.map | 1 + .../tfjs-layers/dist/tf-layers.min.js | 18 + .../tfjs-layers/dist/tf-layers.min.js.map | 1 + .../@tensorflow/tfjs-layers/dist/types.d.ts | 20 + .../@tensorflow/tfjs-layers/dist/types.js | 3 + .../@tensorflow/tfjs-layers/dist/types.js.map | 1 + .../tfjs-layers/dist/types_test.js.map | 1 + .../tfjs-layers/dist/utils/conv_utils.d.ts | 4 + .../tfjs-layers/dist/utils/conv_utils.js | 59 + .../tfjs-layers/dist/utils/conv_utils.js.map | 1 + .../tfjs-layers/dist/utils/generic_utils.d.ts | 23 + .../tfjs-layers/dist/utils/generic_utils.js | 254 + .../dist/utils/generic_utils.js.map | 1 + .../dist/utils/generic_utils_test.js.map | 1 + .../tfjs-layers/dist/utils/layer_utils.d.ts | 2 + .../tfjs-layers/dist/utils/layer_utils.js | 155 + .../tfjs-layers/dist/utils/layer_utils.js.map | 1 + .../tfjs-layers/dist/utils/math_utils.d.ts | 10 + .../tfjs-layers/dist/utils/math_utils.js | 71 + .../tfjs-layers/dist/utils/math_utils.js.map | 1 + .../dist/utils/math_utils_test.js.map | 1 + .../dist/utils/serialization_utils.d.ts | 4 + .../dist/utils/serialization_utils.js | 93 + .../dist/utils/serialization_utils.js.map | 1 + .../utils/serialization_utils_test.js.map | 1 + .../tfjs-layers/dist/utils/test_utils.d.ts | 7 + .../tfjs-layers/dist/utils/test_utils.js | 64 + .../tfjs-layers/dist/utils/test_utils.js.map | 1 + .../tfjs-layers/dist/utils/types_utils.d.ts | 6 + .../tfjs-layers/dist/utils/types_utils.js | 47 + .../tfjs-layers/dist/utils/types_utils.js.map | 1 + .../dist/utils/types_utils_test.js.map | 1 + .../dist/utils/variable_utils.d.ts | 2 + .../tfjs-layers/dist/utils/variable_utils.js | 17 + .../dist/utils/variable_utils.js.map | 1 + .../dist/utils/variable_utils_test.js.map | 1 + .../tfjs-layers/dist/variables.d.ts | 32 + .../@tensorflow/tfjs-layers/dist/variables.js | 125 + .../tfjs-layers/dist/variables.js.map | 1 + .../tfjs-layers/dist/variables_test.js.map | 1 + .../@tensorflow/tfjs-layers/dist/version.d.ts | 2 + .../@tensorflow/tfjs-layers/dist/version.js | 5 + .../tfjs-layers/dist/version.js.map | 1 + .../tfjs-layers/dist/version_test.js.map | 1 + .../@tensorflow/tfjs-layers/package.json | 76 + .../@tensorflow/tfjs-layers/tsconfig.json | 23 + node_modules/@tensorflow/tfjs/GALLERY.md | 74 + node_modules/@tensorflow/tfjs/LICENSE | 202 + node_modules/@tensorflow/tfjs/README.md | 145 + .../@tensorflow/tfjs/dist-es6/index.d.ts | 9 + .../@tensorflow/tfjs/dist-es6/index.js | 14 + .../@tensorflow/tfjs/dist-es6/index.js.map | 1 + .../@tensorflow/tfjs/dist-es6/index_test.d.ts | 1 + .../@tensorflow/tfjs/dist-es6/index_test.js | 25 + .../tfjs/dist-es6/index_test.js.map | 1 + .../@tensorflow/tfjs/dist-es6/version.d.ts | 2 + .../@tensorflow/tfjs/dist-es6/version.js | 3 + .../@tensorflow/tfjs/dist-es6/version.js.map | 1 + node_modules/@tensorflow/tfjs/dist/index.d.ts | 9 + node_modules/@tensorflow/tfjs/dist/index.js | 19 + .../@tensorflow/tfjs/dist/index.js.map | 1 + .../@tensorflow/tfjs/dist/index_test.js.map | 1 + node_modules/@tensorflow/tfjs/dist/tf.esm.js | 3 + .../@tensorflow/tfjs/dist/tf.esm.js.map | 1 + node_modules/@tensorflow/tfjs/dist/tf.js | 11468 ++++++++++++ node_modules/@tensorflow/tfjs/dist/tf.js.map | 1 + node_modules/@tensorflow/tfjs/dist/tf.min.js | 3 + .../@tensorflow/tfjs/dist/tf.min.js.map | 1 + .../@tensorflow/tfjs/dist/version.d.ts | 2 + node_modules/@tensorflow/tfjs/dist/version.js | 5 + .../@tensorflow/tfjs/dist/version.js.map | 1 + node_modules/@tensorflow/tfjs/package.json | 96 + node_modules/@tensorflow/tfjs/yalc.lock | 4 + node_modules/@types/long/LICENSE | 21 + node_modules/@types/long/README.md | 16 + node_modules/@types/long/index.d.ts | 352 + node_modules/@types/long/package.json | 47 + node_modules/@types/seedrandom/README.md | 18 + node_modules/@types/seedrandom/index.d.ts | 45 + node_modules/@types/seedrandom/package.json | 45 + .../@types/seedrandom/types-metadata.json | 23 + node_modules/@types/webgl-ext/LICENSE | 21 + node_modules/@types/webgl-ext/README.md | 16 + node_modules/@types/webgl-ext/index.d.ts | 214 + node_modules/@types/webgl-ext/package.json | 47 + node_modules/@types/webgl2/LICENSE | 21 + node_modules/@types/webgl2/README.md | 16 + node_modules/@types/webgl2/index.d.ts | 1194 ++ node_modules/@types/webgl2/package.json | 51 + node_modules/coffeescript/LICENSE | 22 + node_modules/coffeescript/README.md | 66 + node_modules/coffeescript/bin/cake | 25 + node_modules/coffeescript/bin/coffee | 25 + node_modules/coffeescript/lib/.DS_Store | Bin 0 -> 6148 bytes .../coffeescript/lib/coffeescript/browser.js | 145 + .../coffeescript/lib/coffeescript/cake.js | 135 + .../lib/coffeescript/coffeescript.js | 438 + .../coffeescript/lib/coffeescript/command.js | 719 + .../coffeescript/lib/coffeescript/grammar.js | 2151 +++ .../coffeescript/lib/coffeescript/helpers.js | 350 + .../coffeescript/lib/coffeescript/index.js | 176 + .../coffeescript/lib/coffeescript/lexer.js | 1710 ++ .../coffeescript/lib/coffeescript/nodes.js | 5868 ++++++ .../coffeescript/lib/coffeescript/optparse.js | 230 + .../coffeescript/lib/coffeescript/parser.js | 1130 ++ .../coffeescript/lib/coffeescript/register.js | 85 + .../coffeescript/lib/coffeescript/repl.js | 296 + .../coffeescript/lib/coffeescript/rewriter.js | 1016 + .../coffeescript/lib/coffeescript/scope.js | 187 + .../lib/coffeescript/sourcemap.js | 211 + node_modules/coffeescript/package.json | 84 + node_modules/coffeescript/register.js | 1 + node_modules/coffeescript/repl.js | 1 + node_modules/protobufjs/CHANGELOG.md | 935 + node_modules/protobufjs/LICENSE | 39 + node_modules/protobufjs/README.md | 879 + node_modules/protobufjs/bin/pbjs | 6 + node_modules/protobufjs/bin/pbts | 6 + node_modules/protobufjs/cli/LICENSE | 33 + node_modules/protobufjs/cli/README.md | 11 + node_modules/protobufjs/cli/bin/pbjs | 6 + node_modules/protobufjs/cli/bin/pbts | 6 + node_modules/protobufjs/cli/index.d.ts | 3 + node_modules/protobufjs/cli/index.js | 3 + .../protobufjs/cli/lib/tsd-jsdoc.json | 18 + .../protobufjs/cli/lib/tsd-jsdoc/LICENSE | 21 + .../protobufjs/cli/lib/tsd-jsdoc/README.md | 23 + .../protobufjs/cli/lib/tsd-jsdoc/plugin.js | 21 + .../protobufjs/cli/lib/tsd-jsdoc/publish.js | 693 + .../cli/node_modules/os-tmpdir/index.js | 25 + .../cli/node_modules/os-tmpdir/license | 21 + .../cli/node_modules/os-tmpdir/readme.md | 32 + .../protobufjs/cli/node_modules/tmp/LICENSE | 21 + .../protobufjs/cli/node_modules/tmp/README.md | 314 + .../cli/node_modules/tmp/lib/tmp.js | 611 + node_modules/protobufjs/cli/package-lock.json | 20 + node_modules/protobufjs/cli/package.json | 1 + .../protobufjs/cli/package.standalone.json | 32 + node_modules/protobufjs/cli/pbjs.d.ts | 9 + node_modules/protobufjs/cli/pbjs.js | 329 + node_modules/protobufjs/cli/pbts.d.ts | 9 + node_modules/protobufjs/cli/pbts.js | 197 + .../protobufjs/cli/targets/json-module.js | 38 + node_modules/protobufjs/cli/targets/json.js | 8 + node_modules/protobufjs/cli/targets/proto.js | 326 + node_modules/protobufjs/cli/targets/proto2.js | 10 + node_modules/protobufjs/cli/targets/proto3.js | 10 + .../protobufjs/cli/targets/static-module.js | 29 + node_modules/protobufjs/cli/targets/static.js | 702 + node_modules/protobufjs/cli/util.js | 183 + node_modules/protobufjs/cli/wrappers/amd.js | 7 + .../protobufjs/cli/wrappers/closure.js | 7 + .../protobufjs/cli/wrappers/commonjs.js | 7 + .../protobufjs/cli/wrappers/default.js | 15 + node_modules/protobufjs/cli/wrappers/es6.js | 5 + node_modules/protobufjs/dist/README.md | 31 + node_modules/protobufjs/dist/light/README.md | 31 + .../protobufjs/dist/light/protobuf.js | 7152 +++++++ .../protobufjs/dist/light/protobuf.js.map | 1 + .../protobufjs/dist/light/protobuf.min.js | 8 + .../protobufjs/dist/light/protobuf.min.js.map | 1 + .../protobufjs/dist/minimal/README.md | 31 + .../protobufjs/dist/minimal/protobuf.js | 2684 +++ .../protobufjs/dist/minimal/protobuf.js.map | 1 + .../protobufjs/dist/minimal/protobuf.min.js | 8 + .../dist/minimal/protobuf.min.js.map | 1 + node_modules/protobufjs/dist/protobuf.js | 8726 +++++++++ node_modules/protobufjs/dist/protobuf.js.map | 1 + node_modules/protobufjs/dist/protobuf.min.js | 8 + .../protobufjs/dist/protobuf.min.js.map | 1 + node_modules/protobufjs/ext/debug/README.md | 4 + node_modules/protobufjs/ext/debug/index.js | 71 + .../protobufjs/ext/descriptor/README.md | 72 + .../protobufjs/ext/descriptor/index.d.ts | 191 + .../protobufjs/ext/descriptor/index.js | 1052 ++ .../protobufjs/ext/descriptor/test.js | 54 + node_modules/protobufjs/google/LICENSE | 27 + node_modules/protobufjs/google/README.md | 1 + .../protobufjs/google/api/annotations.json | 83 + .../protobufjs/google/api/annotations.proto | 11 + node_modules/protobufjs/google/api/http.json | 86 + node_modules/protobufjs/google/api/http.proto | 31 + .../protobufjs/google/protobuf/api.json | 118 + .../protobufjs/google/protobuf/api.proto | 34 + .../google/protobuf/descriptor.json | 739 + .../google/protobuf/descriptor.proto | 286 + .../google/protobuf/source_context.json | 20 + .../google/protobuf/source_context.proto | 7 + .../protobufjs/google/protobuf/type.json | 202 + .../protobufjs/google/protobuf/type.proto | 89 + node_modules/protobufjs/index.d.ts | 2694 +++ node_modules/protobufjs/index.js | 4 + node_modules/protobufjs/light.d.ts | 2 + node_modules/protobufjs/light.js | 4 + node_modules/protobufjs/minimal.d.ts | 2 + node_modules/protobufjs/minimal.js | 4 + .../node_modules/@types/long/LICENSE | 21 + .../node_modules/@types/long/README.md | 16 + .../node_modules/@types/long/index.d.ts | 385 + .../node_modules/@types/long/package.json | 47 + .../node_modules/@types/node/LICENSE | 21 + .../node_modules/@types/node/README.md | 16 + .../node_modules/@types/node/index.d.ts | 8026 ++++++++ .../node_modules/@types/node/inspector.d.ts | 2488 +++ .../node_modules/@types/node/package.json | 155 + node_modules/protobufjs/package-lock.json | 7307 ++++++++ node_modules/protobufjs/package.json | 152 + node_modules/protobufjs/scripts/changelog.js | 150 + .../protobufjs/scripts/postinstall.js | 35 + node_modules/protobufjs/src/common.js | 399 + node_modules/protobufjs/src/converter.js | 293 + node_modules/protobufjs/src/decoder.js | 106 + node_modules/protobufjs/src/encoder.js | 100 + node_modules/protobufjs/src/enum.js | 181 + node_modules/protobufjs/src/field.js | 371 + node_modules/protobufjs/src/index-light.js | 104 + node_modules/protobufjs/src/index-minimal.js | 36 + node_modules/protobufjs/src/index.js | 12 + node_modules/protobufjs/src/mapfield.js | 126 + node_modules/protobufjs/src/message.js | 139 + node_modules/protobufjs/src/method.js | 151 + node_modules/protobufjs/src/namespace.js | 433 + node_modules/protobufjs/src/object.js | 200 + node_modules/protobufjs/src/oneof.js | 203 + node_modules/protobufjs/src/parse.js | 758 + node_modules/protobufjs/src/reader.js | 405 + node_modules/protobufjs/src/reader_buffer.js | 44 + node_modules/protobufjs/src/root.js | 351 + node_modules/protobufjs/src/roots.js | 18 + node_modules/protobufjs/src/rpc.js | 36 + node_modules/protobufjs/src/rpc/service.js | 142 + node_modules/protobufjs/src/service.js | 167 + node_modules/protobufjs/src/tokenize.js | 397 + node_modules/protobufjs/src/type.js | 589 + node_modules/protobufjs/src/types.js | 196 + node_modules/protobufjs/src/typescript.jsdoc | 15 + node_modules/protobufjs/src/util.js | 178 + node_modules/protobufjs/src/util/longbits.js | 200 + node_modules/protobufjs/src/util/minimal.js | 414 + node_modules/protobufjs/src/verifier.js | 177 + node_modules/protobufjs/src/wrappers.js | 83 + node_modules/protobufjs/src/writer.js | 459 + node_modules/protobufjs/src/writer_buffer.js | 81 + node_modules/protobufjs/tsconfig.json | 7 + node_modules/querystring/.History.md.un~ | Bin 0 -> 7960 bytes node_modules/querystring/.Readme.md.un~ | Bin 0 -> 3225 bytes node_modules/querystring/.package.json.un~ | Bin 0 -> 5710 bytes node_modules/querystring/.travis.yml | 4 + node_modules/querystring/History.md | 20 + node_modules/querystring/License.md | 19 + node_modules/querystring/Readme.md | 15 + node_modules/querystring/decode.js | 80 + node_modules/querystring/encode.js | 64 + node_modules/querystring/index.js | 4 + node_modules/querystring/package.json | 100 + node_modules/querystring/test/.index.js.un~ | Bin 0 -> 975 bytes node_modules/querystring/test/common-index.js | 3 + node_modules/querystring/test/index.js | 210 + node_modules/querystring/test/tap-index.js | 3 + node_modules/seedrandom/.coveralls.yml | 1 + node_modules/seedrandom/.npmignore | 2 + node_modules/seedrandom/.nvmrc | 1 + node_modules/seedrandom/.travis.yml | 9 + node_modules/seedrandom/Gruntfile.js | 108 + node_modules/seedrandom/README.md | 298 + node_modules/seedrandom/bower.json | 16 + node_modules/seedrandom/component.json | 10 + node_modules/seedrandom/index.js | 60 + node_modules/seedrandom/lib/alea.js | 114 + node_modules/seedrandom/lib/alea.min.js | 1 + node_modules/seedrandom/lib/crypto.js | 11 + node_modules/seedrandom/lib/tychei.js | 103 + node_modules/seedrandom/lib/tychei.min.js | 1 + node_modules/seedrandom/lib/xor128.js | 81 + node_modules/seedrandom/lib/xor128.min.js | 1 + node_modules/seedrandom/lib/xor4096.js | 146 + node_modules/seedrandom/lib/xor4096.min.js | 1 + node_modules/seedrandom/lib/xorshift7.js | 97 + node_modules/seedrandom/lib/xorshift7.min.js | 1 + node_modules/seedrandom/lib/xorwow.js | 86 + node_modules/seedrandom/lib/xorwow.min.js | 1 + node_modules/seedrandom/package.json | 82 + node_modules/seedrandom/seedrandom.js | 247 + node_modules/seedrandom/seedrandom.min.js | 1 + node_modules/seedrandom/test/altprng.html | 30 + node_modules/seedrandom/test/autoseed.html | 46 + node_modules/seedrandom/test/bitgen.js | 45 + .../seedrandom/test/browserified.html | 23 + node_modules/seedrandom/test/browserified.js | 489 + node_modules/seedrandom/test/cryptotest.js | 57 + node_modules/seedrandom/test/lib/qunit.css | 415 + node_modules/seedrandom/test/lib/qunit.js | 4349 +++++ node_modules/seedrandom/test/lib/require.js | 2142 +++ node_modules/seedrandom/test/newapi.html | 44 + node_modules/seedrandom/test/nodetest.js | 226 + node_modules/seedrandom/test/options.html | 195 + .../seedrandom/test/out/dieharder-report.txt | 125 + node_modules/seedrandom/test/prngtest.js | 122 + node_modules/seedrandom/test/qunitassert.js | 3 + node_modules/seedrandom/test/require.html | 57 + node_modules/seedrandom/test/run_dieharder.sh | 5 + node_modules/seedrandom/test/state.html | 56 + node_modules/url/.npmignore | 1 + node_modules/url/.travis.yml | 7 + node_modules/url/.zuul.yml | 16 + node_modules/url/LICENSE | 21 + node_modules/url/README.md | 108 + .../url/node_modules/punycode/LICENSE-MIT.txt | 20 + .../url/node_modules/punycode/README.md | 176 + .../url/node_modules/punycode/package.json | 80 + .../url/node_modules/punycode/punycode.js | 530 + node_modules/url/package.json | 53 + node_modules/url/test.js | 1599 ++ node_modules/url/url.js | 732 + node_modules/url/util.js | 16 + package-lock.json | 176 +- package.json | 4 +- 1294 files changed, 211441 insertions(+), 747 deletions(-) create mode 100644 node_modules/.bin/cake create mode 100644 node_modules/.bin/cake.cmd create mode 100644 node_modules/.bin/coffee create mode 100644 node_modules/.bin/coffee.cmd create mode 100644 node_modules/.bin/pbjs create mode 100644 node_modules/.bin/pbjs.cmd create mode 100644 node_modules/.bin/pbts create mode 100644 node_modules/.bin/pbts.cmd create mode 100644 node_modules/@protobufjs/aspromise/LICENSE create mode 100644 node_modules/@protobufjs/aspromise/README.md create mode 100644 node_modules/@protobufjs/aspromise/index.d.ts create mode 100644 node_modules/@protobufjs/aspromise/index.js create mode 100644 node_modules/@protobufjs/aspromise/package.json create mode 100644 node_modules/@protobufjs/aspromise/tests/index.js create mode 100644 node_modules/@protobufjs/base64/LICENSE create mode 100644 node_modules/@protobufjs/base64/README.md create mode 100644 node_modules/@protobufjs/base64/index.d.ts create mode 100644 node_modules/@protobufjs/base64/index.js create mode 100644 node_modules/@protobufjs/base64/package.json create mode 100644 node_modules/@protobufjs/base64/tests/index.js create mode 100644 node_modules/@protobufjs/codegen/LICENSE create mode 100644 node_modules/@protobufjs/codegen/README.md create mode 100644 node_modules/@protobufjs/codegen/index.d.ts create mode 100644 node_modules/@protobufjs/codegen/index.js create mode 100644 node_modules/@protobufjs/codegen/package.json create mode 100644 node_modules/@protobufjs/codegen/tests/index.js create mode 100644 node_modules/@protobufjs/eventemitter/LICENSE create mode 100644 node_modules/@protobufjs/eventemitter/README.md create mode 100644 node_modules/@protobufjs/eventemitter/index.d.ts create mode 100644 node_modules/@protobufjs/eventemitter/index.js create mode 100644 node_modules/@protobufjs/eventemitter/package.json create mode 100644 node_modules/@protobufjs/eventemitter/tests/index.js create mode 100644 node_modules/@protobufjs/fetch/LICENSE create mode 100644 node_modules/@protobufjs/fetch/README.md create mode 100644 node_modules/@protobufjs/fetch/index.d.ts create mode 100644 node_modules/@protobufjs/fetch/index.js create mode 100644 node_modules/@protobufjs/fetch/package.json create mode 100644 node_modules/@protobufjs/fetch/tests/index.js create mode 100644 node_modules/@protobufjs/float/LICENSE create mode 100644 node_modules/@protobufjs/float/README.md create mode 100644 node_modules/@protobufjs/float/bench/index.js create mode 100644 node_modules/@protobufjs/float/bench/suite.js create mode 100644 node_modules/@protobufjs/float/index.d.ts create mode 100644 node_modules/@protobufjs/float/index.js create mode 100644 node_modules/@protobufjs/float/package.json create mode 100644 node_modules/@protobufjs/float/tests/index.js create mode 100644 node_modules/@protobufjs/inquire/.npmignore create mode 100644 node_modules/@protobufjs/inquire/LICENSE create mode 100644 node_modules/@protobufjs/inquire/README.md create mode 100644 node_modules/@protobufjs/inquire/index.d.ts create mode 100644 node_modules/@protobufjs/inquire/index.js create mode 100644 node_modules/@protobufjs/inquire/package.json create mode 100644 node_modules/@protobufjs/inquire/tests/data/array.js create mode 100644 node_modules/@protobufjs/inquire/tests/data/emptyArray.js create mode 100644 node_modules/@protobufjs/inquire/tests/data/emptyObject.js create mode 100644 node_modules/@protobufjs/inquire/tests/data/object.js create mode 100644 node_modules/@protobufjs/inquire/tests/index.js create mode 100644 node_modules/@protobufjs/path/LICENSE create mode 100644 node_modules/@protobufjs/path/README.md create mode 100644 node_modules/@protobufjs/path/index.d.ts create mode 100644 node_modules/@protobufjs/path/index.js create mode 100644 node_modules/@protobufjs/path/package.json create mode 100644 node_modules/@protobufjs/path/tests/index.js create mode 100644 node_modules/@protobufjs/pool/.npmignore create mode 100644 node_modules/@protobufjs/pool/LICENSE create mode 100644 node_modules/@protobufjs/pool/README.md create mode 100644 node_modules/@protobufjs/pool/index.d.ts create mode 100644 node_modules/@protobufjs/pool/index.js create mode 100644 node_modules/@protobufjs/pool/package.json create mode 100644 node_modules/@protobufjs/pool/tests/index.js create mode 100644 node_modules/@protobufjs/utf8/.npmignore create mode 100644 node_modules/@protobufjs/utf8/LICENSE create mode 100644 node_modules/@protobufjs/utf8/README.md create mode 100644 node_modules/@protobufjs/utf8/index.d.ts create mode 100644 node_modules/@protobufjs/utf8/index.js create mode 100644 node_modules/@protobufjs/utf8/package.json create mode 100644 node_modules/@protobufjs/utf8/tests/data/utf8.txt create mode 100644 node_modules/@protobufjs/utf8/tests/index.js create mode 100644 node_modules/@tensorflow/tfjs-converter/LICENSE create mode 100644 node_modules/@tensorflow/tfjs-converter/README.md create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/data/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/data/types.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/index.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/index.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/arithmetic.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/basic_math.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/control.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/convolution.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/creation.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/dynamic.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/evaluation.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/graph.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/image.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/logical.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/matrices.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/normalization.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/reduction.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/slice_join.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/transformation.json create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/types.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/operations/typings.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/tf-converter.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/tf-converter.min.js create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/version.d.ts create mode 100644 node_modules/@tensorflow/tfjs-converter/dist/version.js create mode 100644 node_modules/@tensorflow/tfjs-converter/package.json create mode 100644 node_modules/@tensorflow/tfjs-core/LICENSE create mode 100644 node_modules/@tensorflow/tfjs-core/README.md create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/device_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/device_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/device_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/engine_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/environment_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/globals.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/globals.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/globals.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/gradients.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/gradients.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/gradients.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/index.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/index.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/index.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/types.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/types.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/log.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/log.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/log.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/model_types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/model_types.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/model_types.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compare.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compare.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compare.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/norm.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/norm.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/norm.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/profiler_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/serialization.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/serialization.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/serialization.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tape_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_format.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_format.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_format.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_types.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_types.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_env.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_env.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_env.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_node.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_node.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_node.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/test_util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tracking_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tracking_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/tracking_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/train.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/train.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/train.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/types.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/types.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/util_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/variable_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/variable_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/variable_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version_test.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/version_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/dist/webgl.d.ts create mode 100644 node_modules/@tensorflow/tfjs-core/dist/webgl.js create mode 100644 node_modules/@tensorflow/tfjs-core/dist/webgl.js.map create mode 100644 node_modules/@tensorflow/tfjs-core/package.json create mode 100644 node_modules/@tensorflow/tfjs-layers/LICENSE create mode 100644 node_modules/@tensorflow/tfjs-layers/README.md create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/activations.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/activations.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/activations.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/activations_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/common.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/common.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/common.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/state.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/state.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/state.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/state_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/base_callbacks_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/callbacks.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/callbacks.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/callbacks.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/common.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/common.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/common.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/common_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/constraints.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/constraints.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/constraints.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/constraints_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/container.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/container.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/container.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/container_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/executor.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/executor_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/topology.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/topology_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/training.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/training.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/training.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/engine/training_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/errors.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/errors.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/errors.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/errors_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_layers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/index.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/index.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/index.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/initializers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/initializers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/initializers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/initializers_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activation_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/core.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/core.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/core.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/core_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/merge.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/merge_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/normalization_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/padding.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/padding_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/pooling_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/serialization_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/logs.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/logs.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/logs.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/losses.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/losses.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/losses.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/losses_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/metrics.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/metrics.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/metrics.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/metrics_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/model_save_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/model_summary_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/models.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/models.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/models.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/models_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/optimizers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/optimizers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/optimizers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/optimizers_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/regularizers.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/regularizers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/regularizers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/regularizers_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.min.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/tf-layers.min.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/types.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/types.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/types.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/types_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/variables.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/variables.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/variables.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/variables_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/version.d.ts create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/version.js create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/version.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/dist/version_test.js.map create mode 100644 node_modules/@tensorflow/tfjs-layers/package.json create mode 100644 node_modules/@tensorflow/tfjs-layers/tsconfig.json create mode 100644 node_modules/@tensorflow/tfjs/GALLERY.md create mode 100644 node_modules/@tensorflow/tfjs/LICENSE create mode 100644 node_modules/@tensorflow/tfjs/README.md create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index.d.ts create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index.js create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index_test.d.ts create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index_test.js create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/index_test.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/version.d.ts create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/version.js create mode 100644 node_modules/@tensorflow/tfjs/dist-es6/version.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/index.d.ts create mode 100644 node_modules/@tensorflow/tfjs/dist/index.js create mode 100644 node_modules/@tensorflow/tfjs/dist/index.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/index_test.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.esm.js create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.esm.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.js create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.min.js create mode 100644 node_modules/@tensorflow/tfjs/dist/tf.min.js.map create mode 100644 node_modules/@tensorflow/tfjs/dist/version.d.ts create mode 100644 node_modules/@tensorflow/tfjs/dist/version.js create mode 100644 node_modules/@tensorflow/tfjs/dist/version.js.map create mode 100644 node_modules/@tensorflow/tfjs/package.json create mode 100644 node_modules/@tensorflow/tfjs/yalc.lock create mode 100644 node_modules/@types/long/LICENSE create mode 100644 node_modules/@types/long/README.md create mode 100644 node_modules/@types/long/index.d.ts create mode 100644 node_modules/@types/long/package.json create mode 100644 node_modules/@types/seedrandom/README.md create mode 100644 node_modules/@types/seedrandom/index.d.ts create mode 100644 node_modules/@types/seedrandom/package.json create mode 100644 node_modules/@types/seedrandom/types-metadata.json create mode 100644 node_modules/@types/webgl-ext/LICENSE create mode 100644 node_modules/@types/webgl-ext/README.md create mode 100644 node_modules/@types/webgl-ext/index.d.ts create mode 100644 node_modules/@types/webgl-ext/package.json create mode 100644 node_modules/@types/webgl2/LICENSE create mode 100644 node_modules/@types/webgl2/README.md create mode 100644 node_modules/@types/webgl2/index.d.ts create mode 100644 node_modules/@types/webgl2/package.json create mode 100644 node_modules/coffeescript/LICENSE create mode 100644 node_modules/coffeescript/README.md create mode 100644 node_modules/coffeescript/bin/cake create mode 100644 node_modules/coffeescript/bin/coffee create mode 100644 node_modules/coffeescript/lib/.DS_Store create mode 100644 node_modules/coffeescript/lib/coffeescript/browser.js create mode 100644 node_modules/coffeescript/lib/coffeescript/cake.js create mode 100644 node_modules/coffeescript/lib/coffeescript/coffeescript.js create mode 100644 node_modules/coffeescript/lib/coffeescript/command.js create mode 100644 node_modules/coffeescript/lib/coffeescript/grammar.js create mode 100644 node_modules/coffeescript/lib/coffeescript/helpers.js create mode 100644 node_modules/coffeescript/lib/coffeescript/index.js create mode 100644 node_modules/coffeescript/lib/coffeescript/lexer.js create mode 100644 node_modules/coffeescript/lib/coffeescript/nodes.js create mode 100644 node_modules/coffeescript/lib/coffeescript/optparse.js create mode 100644 node_modules/coffeescript/lib/coffeescript/parser.js create mode 100644 node_modules/coffeescript/lib/coffeescript/register.js create mode 100644 node_modules/coffeescript/lib/coffeescript/repl.js create mode 100644 node_modules/coffeescript/lib/coffeescript/rewriter.js create mode 100644 node_modules/coffeescript/lib/coffeescript/scope.js create mode 100644 node_modules/coffeescript/lib/coffeescript/sourcemap.js create mode 100644 node_modules/coffeescript/package.json create mode 100644 node_modules/coffeescript/register.js create mode 100644 node_modules/coffeescript/repl.js create mode 100644 node_modules/protobufjs/CHANGELOG.md create mode 100644 node_modules/protobufjs/LICENSE create mode 100644 node_modules/protobufjs/README.md create mode 100644 node_modules/protobufjs/bin/pbjs create mode 100644 node_modules/protobufjs/bin/pbts create mode 100644 node_modules/protobufjs/cli/LICENSE create mode 100644 node_modules/protobufjs/cli/README.md create mode 100644 node_modules/protobufjs/cli/bin/pbjs create mode 100644 node_modules/protobufjs/cli/bin/pbts create mode 100644 node_modules/protobufjs/cli/index.d.ts create mode 100644 node_modules/protobufjs/cli/index.js create mode 100644 node_modules/protobufjs/cli/lib/tsd-jsdoc.json create mode 100644 node_modules/protobufjs/cli/lib/tsd-jsdoc/LICENSE create mode 100644 node_modules/protobufjs/cli/lib/tsd-jsdoc/README.md create mode 100644 node_modules/protobufjs/cli/lib/tsd-jsdoc/plugin.js create mode 100644 node_modules/protobufjs/cli/lib/tsd-jsdoc/publish.js create mode 100644 node_modules/protobufjs/cli/node_modules/os-tmpdir/index.js create mode 100644 node_modules/protobufjs/cli/node_modules/os-tmpdir/license create mode 100644 node_modules/protobufjs/cli/node_modules/os-tmpdir/readme.md create mode 100644 node_modules/protobufjs/cli/node_modules/tmp/LICENSE create mode 100644 node_modules/protobufjs/cli/node_modules/tmp/README.md create mode 100644 node_modules/protobufjs/cli/node_modules/tmp/lib/tmp.js create mode 100644 node_modules/protobufjs/cli/package-lock.json create mode 100644 node_modules/protobufjs/cli/package.json create mode 100644 node_modules/protobufjs/cli/package.standalone.json create mode 100644 node_modules/protobufjs/cli/pbjs.d.ts create mode 100644 node_modules/protobufjs/cli/pbjs.js create mode 100644 node_modules/protobufjs/cli/pbts.d.ts create mode 100644 node_modules/protobufjs/cli/pbts.js create mode 100644 node_modules/protobufjs/cli/targets/json-module.js create mode 100644 node_modules/protobufjs/cli/targets/json.js create mode 100644 node_modules/protobufjs/cli/targets/proto.js create mode 100644 node_modules/protobufjs/cli/targets/proto2.js create mode 100644 node_modules/protobufjs/cli/targets/proto3.js create mode 100644 node_modules/protobufjs/cli/targets/static-module.js create mode 100644 node_modules/protobufjs/cli/targets/static.js create mode 100644 node_modules/protobufjs/cli/util.js create mode 100644 node_modules/protobufjs/cli/wrappers/amd.js create mode 100644 node_modules/protobufjs/cli/wrappers/closure.js create mode 100644 node_modules/protobufjs/cli/wrappers/commonjs.js create mode 100644 node_modules/protobufjs/cli/wrappers/default.js create mode 100644 node_modules/protobufjs/cli/wrappers/es6.js create mode 100644 node_modules/protobufjs/dist/README.md create mode 100644 node_modules/protobufjs/dist/light/README.md create mode 100644 node_modules/protobufjs/dist/light/protobuf.js create mode 100644 node_modules/protobufjs/dist/light/protobuf.js.map create mode 100644 node_modules/protobufjs/dist/light/protobuf.min.js create mode 100644 node_modules/protobufjs/dist/light/protobuf.min.js.map create mode 100644 node_modules/protobufjs/dist/minimal/README.md create mode 100644 node_modules/protobufjs/dist/minimal/protobuf.js create mode 100644 node_modules/protobufjs/dist/minimal/protobuf.js.map create mode 100644 node_modules/protobufjs/dist/minimal/protobuf.min.js create mode 100644 node_modules/protobufjs/dist/minimal/protobuf.min.js.map create mode 100644 node_modules/protobufjs/dist/protobuf.js create mode 100644 node_modules/protobufjs/dist/protobuf.js.map create mode 100644 node_modules/protobufjs/dist/protobuf.min.js create mode 100644 node_modules/protobufjs/dist/protobuf.min.js.map create mode 100644 node_modules/protobufjs/ext/debug/README.md create mode 100644 node_modules/protobufjs/ext/debug/index.js create mode 100644 node_modules/protobufjs/ext/descriptor/README.md create mode 100644 node_modules/protobufjs/ext/descriptor/index.d.ts create mode 100644 node_modules/protobufjs/ext/descriptor/index.js create mode 100644 node_modules/protobufjs/ext/descriptor/test.js create mode 100644 node_modules/protobufjs/google/LICENSE create mode 100644 node_modules/protobufjs/google/README.md create mode 100644 node_modules/protobufjs/google/api/annotations.json create mode 100644 node_modules/protobufjs/google/api/annotations.proto create mode 100644 node_modules/protobufjs/google/api/http.json create mode 100644 node_modules/protobufjs/google/api/http.proto create mode 100644 node_modules/protobufjs/google/protobuf/api.json create mode 100644 node_modules/protobufjs/google/protobuf/api.proto create mode 100644 node_modules/protobufjs/google/protobuf/descriptor.json create mode 100644 node_modules/protobufjs/google/protobuf/descriptor.proto create mode 100644 node_modules/protobufjs/google/protobuf/source_context.json create mode 100644 node_modules/protobufjs/google/protobuf/source_context.proto create mode 100644 node_modules/protobufjs/google/protobuf/type.json create mode 100644 node_modules/protobufjs/google/protobuf/type.proto create mode 100644 node_modules/protobufjs/index.d.ts create mode 100644 node_modules/protobufjs/index.js create mode 100644 node_modules/protobufjs/light.d.ts create mode 100644 node_modules/protobufjs/light.js create mode 100644 node_modules/protobufjs/minimal.d.ts create mode 100644 node_modules/protobufjs/minimal.js create mode 100644 node_modules/protobufjs/node_modules/@types/long/LICENSE create mode 100644 node_modules/protobufjs/node_modules/@types/long/README.md create mode 100644 node_modules/protobufjs/node_modules/@types/long/index.d.ts create mode 100644 node_modules/protobufjs/node_modules/@types/long/package.json create mode 100644 node_modules/protobufjs/node_modules/@types/node/LICENSE create mode 100644 node_modules/protobufjs/node_modules/@types/node/README.md create mode 100644 node_modules/protobufjs/node_modules/@types/node/index.d.ts create mode 100644 node_modules/protobufjs/node_modules/@types/node/inspector.d.ts create mode 100644 node_modules/protobufjs/node_modules/@types/node/package.json create mode 100644 node_modules/protobufjs/package-lock.json create mode 100644 node_modules/protobufjs/package.json create mode 100644 node_modules/protobufjs/scripts/changelog.js create mode 100644 node_modules/protobufjs/scripts/postinstall.js create mode 100644 node_modules/protobufjs/src/common.js create mode 100644 node_modules/protobufjs/src/converter.js create mode 100644 node_modules/protobufjs/src/decoder.js create mode 100644 node_modules/protobufjs/src/encoder.js create mode 100644 node_modules/protobufjs/src/enum.js create mode 100644 node_modules/protobufjs/src/field.js create mode 100644 node_modules/protobufjs/src/index-light.js create mode 100644 node_modules/protobufjs/src/index-minimal.js create mode 100644 node_modules/protobufjs/src/index.js create mode 100644 node_modules/protobufjs/src/mapfield.js create mode 100644 node_modules/protobufjs/src/message.js create mode 100644 node_modules/protobufjs/src/method.js create mode 100644 node_modules/protobufjs/src/namespace.js create mode 100644 node_modules/protobufjs/src/object.js create mode 100644 node_modules/protobufjs/src/oneof.js create mode 100644 node_modules/protobufjs/src/parse.js create mode 100644 node_modules/protobufjs/src/reader.js create mode 100644 node_modules/protobufjs/src/reader_buffer.js create mode 100644 node_modules/protobufjs/src/root.js create mode 100644 node_modules/protobufjs/src/roots.js create mode 100644 node_modules/protobufjs/src/rpc.js create mode 100644 node_modules/protobufjs/src/rpc/service.js create mode 100644 node_modules/protobufjs/src/service.js create mode 100644 node_modules/protobufjs/src/tokenize.js create mode 100644 node_modules/protobufjs/src/type.js create mode 100644 node_modules/protobufjs/src/types.js create mode 100644 node_modules/protobufjs/src/typescript.jsdoc create mode 100644 node_modules/protobufjs/src/util.js create mode 100644 node_modules/protobufjs/src/util/longbits.js create mode 100644 node_modules/protobufjs/src/util/minimal.js create mode 100644 node_modules/protobufjs/src/verifier.js create mode 100644 node_modules/protobufjs/src/wrappers.js create mode 100644 node_modules/protobufjs/src/writer.js create mode 100644 node_modules/protobufjs/src/writer_buffer.js create mode 100644 node_modules/protobufjs/tsconfig.json create mode 100644 node_modules/querystring/.History.md.un~ create mode 100644 node_modules/querystring/.Readme.md.un~ create mode 100644 node_modules/querystring/.package.json.un~ create mode 100644 node_modules/querystring/.travis.yml create mode 100644 node_modules/querystring/History.md create mode 100644 node_modules/querystring/License.md create mode 100644 node_modules/querystring/Readme.md create mode 100644 node_modules/querystring/decode.js create mode 100644 node_modules/querystring/encode.js create mode 100644 node_modules/querystring/index.js create mode 100644 node_modules/querystring/package.json create mode 100644 node_modules/querystring/test/.index.js.un~ create mode 100644 node_modules/querystring/test/common-index.js create mode 100644 node_modules/querystring/test/index.js create mode 100644 node_modules/querystring/test/tap-index.js create mode 100644 node_modules/seedrandom/.coveralls.yml create mode 100644 node_modules/seedrandom/.npmignore create mode 100644 node_modules/seedrandom/.nvmrc create mode 100644 node_modules/seedrandom/.travis.yml create mode 100644 node_modules/seedrandom/Gruntfile.js create mode 100644 node_modules/seedrandom/README.md create mode 100644 node_modules/seedrandom/bower.json create mode 100644 node_modules/seedrandom/component.json create mode 100644 node_modules/seedrandom/index.js create mode 100644 node_modules/seedrandom/lib/alea.js create mode 100644 node_modules/seedrandom/lib/alea.min.js create mode 100644 node_modules/seedrandom/lib/crypto.js create mode 100644 node_modules/seedrandom/lib/tychei.js create mode 100644 node_modules/seedrandom/lib/tychei.min.js create mode 100644 node_modules/seedrandom/lib/xor128.js create mode 100644 node_modules/seedrandom/lib/xor128.min.js create mode 100644 node_modules/seedrandom/lib/xor4096.js create mode 100644 node_modules/seedrandom/lib/xor4096.min.js create mode 100644 node_modules/seedrandom/lib/xorshift7.js create mode 100644 node_modules/seedrandom/lib/xorshift7.min.js create mode 100644 node_modules/seedrandom/lib/xorwow.js create mode 100644 node_modules/seedrandom/lib/xorwow.min.js create mode 100644 node_modules/seedrandom/package.json create mode 100644 node_modules/seedrandom/seedrandom.js create mode 100644 node_modules/seedrandom/seedrandom.min.js create mode 100644 node_modules/seedrandom/test/altprng.html create mode 100644 node_modules/seedrandom/test/autoseed.html create mode 100644 node_modules/seedrandom/test/bitgen.js create mode 100644 node_modules/seedrandom/test/browserified.html create mode 100644 node_modules/seedrandom/test/browserified.js create mode 100644 node_modules/seedrandom/test/cryptotest.js create mode 100644 node_modules/seedrandom/test/lib/qunit.css create mode 100644 node_modules/seedrandom/test/lib/qunit.js create mode 100644 node_modules/seedrandom/test/lib/require.js create mode 100644 node_modules/seedrandom/test/newapi.html create mode 100644 node_modules/seedrandom/test/nodetest.js create mode 100644 node_modules/seedrandom/test/options.html create mode 100644 node_modules/seedrandom/test/out/dieharder-report.txt create mode 100644 node_modules/seedrandom/test/prngtest.js create mode 100644 node_modules/seedrandom/test/qunitassert.js create mode 100644 node_modules/seedrandom/test/require.html create mode 100644 node_modules/seedrandom/test/run_dieharder.sh create mode 100644 node_modules/seedrandom/test/state.html create mode 100644 node_modules/url/.npmignore create mode 100644 node_modules/url/.travis.yml create mode 100644 node_modules/url/.zuul.yml create mode 100644 node_modules/url/LICENSE create mode 100644 node_modules/url/README.md create mode 100644 node_modules/url/node_modules/punycode/LICENSE-MIT.txt create mode 100644 node_modules/url/node_modules/punycode/README.md create mode 100644 node_modules/url/node_modules/punycode/package.json create mode 100644 node_modules/url/node_modules/punycode/punycode.js create mode 100644 node_modules/url/package.json create mode 100644 node_modules/url/test.js create mode 100644 node_modules/url/url.js create mode 100644 node_modules/url/util.js diff --git a/commands.json b/commands.json index 52ed098..42670ee 100644 --- a/commands.json +++ b/commands.json @@ -14,7 +14,8 @@ "/ratz gituserinfo + GitHub Username", "/ratz gitrepoinfo + {GitHubUsername}/{RepositoryName}", "/ratz showactiveevent", - "/ratz joinactiveevent" + "/ratz joinactiveevent", + "/ratz getremovedmessages [DM-Channel Command]" ], "definitions": [ "Shows all commands for ratzBot", @@ -31,6 +32,7 @@ "Shows information for provided GitHub user", "Show information for provided GitHub repository (which is owned by the provided GitHub username)", "Shows active server event", - "Join active server event" + "Join active server event", + "Gets all removed messages that were created by the user; given by ratzBot in a DM-Channel" ] } \ No newline at end of file diff --git a/main.js b/main.js index 3f2e606..2451616 100644 --- a/main.js +++ b/main.js @@ -1,6 +1,42 @@ // COPYRIGHT (C) GAVIN ISGAR 2017-2018 +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; var Discord = require("discord.js"); var DiscordRPC = require("discord-rpc"); +var tf = require('@tensorflow/tfjs'); var opus = require("opusscript"); var ffmpeg = require("ffmpeg-binaries"); var ytdl = require("ytdl-core"); @@ -12,12 +48,15 @@ var url = require("url"); var path = require("path"); var request = require("request"); var commands = require("./commands.json"); -var tokens = require("./exclude/tokens.json"); +//var tokens = require("./exclude/tokens.json"); +var tokens = require("C:/Users/Gavin/Desktop/tokens.json"); var fs = require("fs"); var readline = require("readline"); -var package = require("./package.json"); +var packagefile = require("./package.json"); var _a = require('electron'), app = _a.app, BrowserWindow = _a.BrowserWindow; var date = new Date(); +var messagedata = require("./exclude/removedauthmessages.json"); +var advertdata = require("./exclude/adverts.json"); //-----SERVER EVENTS----- var activeevent = ""; // --------- @@ -25,409 +64,440 @@ var activeevent = ""; var logChannel = "423939166401855518"; var newcomerChannel = "423937750937501697"; var mainChannel = "443227379712917505"; +var liveChannel = "423938014801166346"; +var selfPromoChannel = "438003121755783199"; // ---------- bot.on('message', function (message) { try { - if (fs.readFileSync("./exclude/bannedusers.ratz").includes(message.author.id.toString()) == true) { - message.channel.send(message.author + ", you are banned from communicating in the server."); - message["delete"](); - } - else { - if (fs.readFileSync("./exclude/users.ratz").includes(message.author.id.toString()) == false) { - if (message.author.username == "GitHub" && message.author.bot == 1) { - // Do nothing - } - else { - if (message.content.toString() == "/ratz slimedog") { - fs.appendFileSync("./exclude/users.ratz", "\r\n" + message.author.id.toString()); - message["delete"](); - message.channel.send(message.author + ", you now have access to type in the server!"); + if (message.channel.type == "dm") { + if (message.author.id == "434154972834299904") { + // Do nothing + } + else { + if (message.content.toString() == "/ratz getremovedmessages") { + if (!messagedata.users[0][message.author.id]) { + message.channel.send("No message data exists for your UserID."); + console.log("Private data requested and failed from " + message.author.username); } else { - fs.appendFileSync("./exclude/removedauthmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); - message["delete"](); - message.channel.send(message.author + ", you have not completely read the rules in order to have access to chat. To get access, re-read the rules and type the secret response message specified."); + message.channel.send(messagedata.users[0][message.author.id]); + console.log("Private data requested and given to " + message.author.username); } } } + } + else { + if (fs.readFileSync("./exclude/bannedusers.ratz").includes(message.author.id.toString()) == true) { + message.channel.send(message.author + ", you are banned from communicating in the server."); + message["delete"](); + } else { - // ---COMMANDS--- - if (message.content.toString().startsWith("/ratz discorduserinfo ")) { - var result = message.content.slice(22); - try { - var user = bot.users.find("id", result); - var embed = new Discord.RichEmbed() - .setTitle("Discord User Information for " + user.username) - .setColor(0xcb00ff) - .setThumbnail(user.avatarURL) - .addField("Username", user.username) - .addField("ID", user.id) - .addField("Tag", user.tag) - .addField("Account Created", user.createdTimestamp) - .addField("Last Message ID", user.lastMessageID); - message.channel.send(embed); - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000008)); - appendError(TYPE.BACKEND, ERROR.RATZx0000008, message.author.id); + if (fs.readFileSync("./exclude/users.ratz").includes(message.author.id.toString()) == false) { + if (message.author.username == "GitHub" && message.author.bot == 1) { + // Do nothing } - } - if (message.content.toString() == "/ratz slimedog") { - message.channel.send(message.author + ", you are already authorized to type in the server!"); - } - if (message.content.toString() == "/ratz showcommands") { - var i; - var embed_1 = new Discord.RichEmbed() - .setTitle("Commands for ratzBot") - .setColor(0xcb00ff) - .setThumbnail(bot.user.avatarURL.toString()); - for (i = 0; commands.names[i]; i++) { - for (i = 0; commands.definitions[i]; i++) { - embed_1.addField(commands.names[i], commands.definitions[i]); + else { + if (message.content.toString() == "/ratz slimedog") { + fs.appendFileSync("./exclude/users.ratz", "\r\n" + message.author.id.toString()); + message["delete"](); + message.channel.send(message.author + ", you now have access to type in the server!"); + } + else { + removeMessage(message.content.toString(), message.author.id); + message["delete"](); + message.channel.send(message.author + ", hello and welcome to the server! You have to read the rules and enter the specified password to access the server (for the sake of spammers \u2661)."); + // Old method + //fs.appendFileSync("./exclude/removedauthmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); + //message["delete"](); + //message.channel.send(message.author + ", hello and welcome to the server! You have to read the rules and enter the specified password to access the server (for the sake of spammers \u2661)."); } } - message.channel.send({ embed: embed_1 }); } - if (message.content.toString() == "/ratz botinfo") { - var embed = new Discord.RichEmbed() - .setTitle("ratzBot Information") - .setThumbnail(bot.user.avatarURL.toString()) - .setColor(0xcb00ff) - .addField("Developer", "Gavin Isgar (https://www.github.com/gisgar3/)") - .addField("Version Number", package.version) - .addField("Source Languages", "JavaScript\nTypeScript") - .addField("GitHub Repository", "https://www.github.com/gisgar3/ratzbot/"); - message.channel.send(embed); - } - if (message.content.startsWith("/ratz steamuserinfo ")) { - var result = message.content.slice(20); - var getSteamProfile = { - method: "GET", - url: "https://api.steampowered.com/ISteamUser/GetPlayerSummaries/v2/?key=" + tokens.steamtoken + "&steamids=" + result - }; - request(getSteamProfile, function (error, response, body) { + else { + // ---COMMANDS--- + if (message.content.toString().startsWith("/ratz discorduserinfo ")) { + var result = message.content.slice(22); try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed_2 = new Discord.RichEmbed() - .setTitle("Steam User Information for " + stats.response.players[0].steamid) - .setURL(stats.response.players[0].profileurl) - .setColor(0xcb00ff) - .setThumbnail(stats.response.players[0].avatarfull) - .addField("Username", stats.response.players[0].personaname) - .addField("Profile State", stats.response.players[0].profilestate) - .addField("Primary Clan", stats.response.players[0].primaryclanid) - .addField("Last Logoff", stats.response.players[0].lastlogoff) - .addField("Account Created", stats.response.players[0].timecreated); - message.channel.send({ embed: embed_2 }); - } - else { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); - appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id); - } + var user = bot.users.find("id", result); + var embed = new Discord.RichEmbed() + .setTitle("Discord User Information for " + user.username) + .setColor(0xcb00ff) + .setThumbnail(user.avatarURL) + .addField("Username", user.username) + .addField("ID", user.id) + .addField("Tag", user.tag) + .addField("Account Created", user.createdTimestamp) + .addField("Last Message ID", user.lastMessageID); + message.channel.send(embed); } catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); - appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id); + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000008)); + appendError(TYPE.BACKEND, ERROR.RATZx0000008, message.author.id, err); } - }); - } - if (message.content.toString() == "/ratz releaseinfo") { - var getReleaseInfo = { - method: "GET", - url: "https://api.github.com/repos/Gisgar3/ratzBot/releases", - headers: { - "User-Agent": "Gisgar3" + } + if (message.content.toString() == "/ratz slimedog") { + message.channel.send(message.author + ", you are already authorized to type in the server!"); + } + if (message.content.toString() == "/ratz showcommands") { + var i; + var embed_1 = new Discord.RichEmbed() + .setTitle("Commands for ratzBot") + .setColor(0xcb00ff) + .setThumbnail(bot.user.avatarURL.toString()); + for (i = 0; commands.names[i]; i++) { + for (i = 0; commands.definitions[i]; i++) { + embed_1.addField(commands.names[i], commands.definitions[i]); + } } - }; - request(getReleaseInfo, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed = new Discord.RichEmbed() - .setTitle("ratzBot GitHub Release Information") - .setThumbnail(bot.user.avatarURL) - .setColor(0xcb00ff) - .setURL(stats[0].html_url) - .addField("Latest Release", "" + stats[0].name) - .addField("Release Branch", "" + stats[0].target_commitish) - .addField("Tag", stats[0].tag_name) - .addField("Changelog", stats[0].body) - .addField("Pre-Release Status", "" + stats[0].prerelease) - .addField("Author", stats[0].author.login); - if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-RC")) { - embed.setFooter("BUILD STAGE: Release Candidate"); + message.channel.send({ embed: embed_1 }); + } + if (message.content.toString() == "/ratz botinfo") { + var embed = new Discord.RichEmbed() + .setTitle("ratzBot Information") + .setThumbnail(bot.user.avatarURL.toString()) + .setColor(0xcb00ff) + .addField("Developer", "Gavin Isgar (https://www.github.com/gisgar3/)") + .addField("Version Number", packagefile.version) + .addField("Source Languages", "JavaScript\nTypeScript") + .addField("GitHub Repository", "https://www.github.com/gisgar3/ratzbot/"); + message.channel.send(embed); + } + if (message.content.startsWith("/ratz steamuserinfo ")) { + var result = message.content.slice(20); + var getSteamProfile = { + method: "GET", + url: "https://api.steampowered.com/ISteamUser/GetPlayerSummaries/v2/?key=" + tokens.steamtoken + "&steamids=" + result + }; + request(getSteamProfile, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_2 = new Discord.RichEmbed() + .setTitle("Steam User Information for " + stats.response.players[0].steamid) + .setURL(stats.response.players[0].profileurl) + .setColor(0xcb00ff) + .setThumbnail(stats.response.players[0].avatarfull) + .addField("Username", stats.response.players[0].personaname) + .addField("Profile State", stats.response.players[0].profilestate) + .addField("Primary Clan", stats.response.players[0].primaryclanid) + .addField("Last Logoff", stats.response.players[0].lastlogoff) + .addField("Account Created", stats.response.players[0].timecreated); + message.channel.send({ embed: embed_2 }); } - else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Beta")) { - embed.setFooter("BUILD STAGE: Beta"); + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); + appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id, error); } - else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Alpha")) { - embed.setFooter("BUILD STAGE: Alpha"); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); + appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id, err); + } + }); + } + if (message.content.toString() == "/ratz releaseinfo") { + var getReleaseInfo = { + method: "GET", + url: "https://api.github.com/repos/Gisgar3/ratzBot/releases", + headers: { + "User-Agent": "Gisgar3" + } + }; + request(getReleaseInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed = new Discord.RichEmbed() + .setTitle("ratzBot GitHub Release Information") + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .setURL(stats[0].html_url) + .addField("Latest Release", "" + stats[0].name) + .addField("Release Branch", "" + stats[0].target_commitish) + .addField("Tag", stats[0].tag_name) + .addField("Changelog", stats[0].body) + .addField("Pre-Release Status", "" + stats[0].prerelease) + .addField("Author", stats[0].author.login); + if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-RC")) { + embed.setFooter("BUILD STAGE: Release Candidate"); + } + else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Beta")) { + embed.setFooter("BUILD STAGE: Beta"); + } + else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Alpha")) { + embed.setFooter("BUILD STAGE: Alpha"); + } + else if ("" + stats[0].prerelease == "false") { + embed.setFooter("BUILD STAGE: General Availability"); + } + message.channel.send(embed); } - else if ("" + stats[0].prerelease == "false") { - embed.setFooter("BUILD STAGE: General Availability"); + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); } - message.channel.send(embed); } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }); - } - if (message.content.startsWith("/ratz gituserinfo ")) { - var result = message.content.slice(18); - var getGitUserInfo = { - method: "GET", - url: "https://api.github.com/users/" + result, - headers: { - "User-Agent": "Gisgar3" - } - }; - request(getGitUserInfo, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed_3 = new Discord.RichEmbed() - .setTitle("GitHub User Information for " + result) - .setURL(stats.html_url) - .setColor(0xcb00ff) - .setThumbnail(stats.avatar_url) - .addField("Name", stats.name) - .addField("Company", "" + stats.company) - .addField("Bio", "" + stats.bio) - .addField("Location", "" + stats.location) - .addField("Email", "" + stats.email) - .addField("Hireable", "" + stats.hireable) - .addField("Public Repositories", stats.public_repos); - message.channel.send(embed_3); + }); + } + if (message.content.startsWith("/ratz gituserinfo ")) { + var result = message.content.slice(18); + var getGitUserInfo = { + method: "GET", + url: "https://api.github.com/users/" + result, + headers: { + "User-Agent": "Gisgar3" + } + }; + request(getGitUserInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_3 = new Discord.RichEmbed() + .setTitle("GitHub User Information for " + result) + .setURL(stats.html_url) + .setColor(0xcb00ff) + .setThumbnail(stats.avatar_url) + .addField("Name", stats.name) + .addField("Company", "" + stats.company) + .addField("Bio", "" + stats.bio) + .addField("Location", "" + stats.location) + .addField("Email", "" + stats.email) + .addField("Hireable", "" + stats.hireable) + .addField("Public Repositories", stats.public_repos); + message.channel.send(embed_3); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }); - } - if (message.content.startsWith("/ratz gitrepoinfo ")) { - var result = message.content.slice(18); - var getGitRepoInfo = { - method: "GET", - url: "https://api.github.com/repos/" + result, - headers: { - 'User-Agent': 'Gisgar3' - } - }; - request(getGitRepoInfo, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed_4 = new Discord.RichEmbed() - .setTitle("GitHub Repository for " + result) - .setURL(stats.html_url) - .setColor(0xcb00ff) - .setThumbnail(stats.owner.avatar_url) - .addField("Name", stats.name) - .addField("Description", stats.description) - .addField("Owner", stats.owner.login) - .addField("Language", stats.language) - .addField("Archive Status", stats.archived); - message.channel.send(embed_4); + }); + } + if (message.content.startsWith("/ratz gitrepoinfo ")) { + var result = message.content.slice(18); + var getGitRepoInfo = { + method: "GET", + url: "https://api.github.com/repos/" + result, + headers: { + 'User-Agent': 'Gisgar3' + } + }; + request(getGitRepoInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_4 = new Discord.RichEmbed() + .setTitle("GitHub Repository for " + result) + .setURL(stats.html_url) + .setColor(0xcb00ff) + .setThumbnail(stats.owner.avatar_url) + .addField("Name", stats.name) + .addField("Description", stats.description) + .addField("Owner", stats.owner.login) + .addField("Language", stats.language) + .addField("Archive Status", stats.archived); + message.channel.send(embed_4); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }); - } - if (message.content.toString() == "/ratz btcinfo") { - var getBTCInfo = { - method: "GET", - url: "https://api.blockchain.info/stats" - }; - request(getBTCInfo, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed_5 = new Discord.RichEmbed() - .setTitle("BTC Information") - .setColor(0xcb00ff) - .setThumbnail(bot.user.avatarURL) - .addField("Market Price (USD)", "$" + stats.market_price_usd) - .addField("BTC Mined", stats.n_btc_mined) - .addField("Blocks Mined", stats.n_blocks_mined) - .addField("Total Blocks", stats.n_blocks_total) - .addField("Total BTC Sent", stats.total_btc_sent); - message.channel.send(embed_5); + }); + } + if (message.content.toString() == "/ratz btcinfo") { + var getBTCInfo = { + method: "GET", + url: "https://api.blockchain.info/stats" + }; + request(getBTCInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_5 = new Discord.RichEmbed() + .setTitle("BTC Information") + .setColor(0xcb00ff) + .setThumbnail(bot.user.avatarURL) + .addField("Market Price (USD)", "$" + stats.market_price_usd) + .addField("BTC Mined", stats.n_btc_mined) + .addField("Blocks Mined", stats.n_blocks_mined) + .addField("Total Blocks", stats.n_blocks_total) + .addField("Total BTC Sent", stats.total_btc_sent); + message.channel.send(embed_5); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); + appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); - appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id, err); } + }); + } + // -----SERVER EVENTS----- + if (message.content.toString() == "/ratz joinactiveevent") { + if (activeevent == "") { + message.channel.send(message.author + ", there is no active event on the server."); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); - appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id); + else { + try { + fs.appendFileSync("./exclude/eventuserlist.ratz", "\r\n" + message.author.id); + message.channel.send(message.author + ", you are now joined into the " + activeevent + "!"); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000004)); + appendError(TYPE.BACKEND, ERROR.RATZx0000004, message.author.id, err); + } } - }); - } - // -----SERVER EVENTS----- - if (message.content.toString() == "/ratz joinactiveevent") { - if (activeevent == "") { - message.channel.send(message.author + ", there is no active event on the server."); } - else { - try { - fs.appendFileSync("./exclude/eventuserlist.ratz", "\r\n" + message.author.id); - message.channel.send(message.author + ", you are now joined into the " + activeevent + "!"); + if (message.content.toString() == "/ratz showactiveevent") { + if (activeevent == "") { + message.channel.send(message.author + ", there is no active event on the server."); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000004)); - appendError(TYPE.BACKEND, ERROR.RATZx0000004, message.author.id); + else { + message.channel.send(message.author + ", the active event on the server is the " + activeevent + "."); } } - } - if (message.content.toString() == "/ratz showactiveevent") { - if (activeevent == "") { - message.channel.send(message.author + ", there is no active event on the server."); - } - else { - message.channel.send(message.author + ", the active event on the server is the " + activeevent + "."); - } - } - // -----STREAMLABS INTEGRATION----- - if (message.content.startsWith("/ratz ratcoininfo ")) { - var result = message.content.slice(18); - var getRTCInfo = { - method: "GET", - url: "https://streamlabs.com/api/v1.0/points?access_token=" + tokens.streamlabstoken + "&username=" + result + "&channel=ratzdoll" - }; - request(getRTCInfo, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - message.channel.send(message.author + ", " + result + " has " + stats.points + " RTC!"); + // -----STREAMLABS INTEGRATION----- + if (message.content.startsWith("/ratz ratcoininfo ")) { + var result = message.content.slice(18); + var getRTCInfo = { + method: "GET", + url: "https://streamlabs.com/api/v1.0/points?access_token=" + tokens.streamlabstoken + "&username=" + result + "&channel=ratzdoll" + }; + request(getRTCInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + message.channel.send(message.author + ", " + result + " has " + stats.points + " RTC!"); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); + appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); - appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); - appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id); - } - }); - } - // -----TWITCH NEW API----- - if (message.content.toString() == "/ratz laststream") { - var getStreamVOD = { - method: 'GET', - url: "https://api.twitch.tv/helix/videos?user_id=157901049&first=1", - headers: { - "Client-ID": "" + tokens.twitchapiclientid - } - }; - request(getStreamVOD, function (error, response, body) { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed_6 = new Discord.RichEmbed() - .setTitle("Last Stream VOD from ratzDoll") - .setThumbnail(bot.user.avatarURL) - .setColor(0xcb00ff) - .setURL(stats.data[0].url) - .addField("Title", "" + stats.data[0].title) - .addField("Published At", "" + stats.data[0].published_at) - .addField("Duration", "" + stats.data[0].duration) - .addField("View Count", stats.data[0].view_count); - message.channel.send(embed_6); + }); + } + // -----TWITCH NEW API----- + if (message.content.toString() == "/ratz laststream") { + var getStreamVOD = { + method: 'GET', + url: "https://api.twitch.tv/helix/videos?user_id=157901049&first=1", + headers: { + "Client-ID": "" + tokens.twitchapiclientid } - else { + }; + request(getStreamVOD, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_6 = new Discord.RichEmbed() + .setTitle("Last Stream VOD from ratzDoll") + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .setURL(stats.data[0].url) + .addField("Title", "" + stats.data[0].title) + .addField("Published At", "" + stats.data[0].published_at) + .addField("Duration", "" + stats.data[0].duration) + .addField("View Count", stats.data[0].view_count); + message.channel.send(embed_6); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); + appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id, error); + } + } + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); - appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id, err); } + }); + } + // -----VOICE CHANNELS----- + if (message.content.startsWith("/ratz play ")) { + var result = message.content.slice(11); + if (message.member.voiceChannel) { + message.member.voiceChannel.join().then(function (connection) { + try { + var stream = ytdl(result, { filter: "audioonly" }); + var dispatcher = connection.playStream(stream); + message.channel.send(message.author + ", your music is now playing."); + dispatcher.on("end", function (end) { + message.channel.send(message.author + ", your music has ended."); + message.member.voiceChannel.leave(); + }); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); + appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id, err); + } + }); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); - appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id); + else { + message.channel.send(message.author + ", you are not in a voice channel. Join a voice channel to play music!"); } - }); - } - // -----VOICE CHANNELS----- - if (message.content.startsWith("/ratz play ")) { - var result = message.content.slice(11); - if (message.member.voiceChannel) { - message.member.voiceChannel.join().then(function (connection) { + } + if (message.content.toString() == "/ratz stop") { + if (message.member.voiceChannel) { try { - var stream = ytdl(result, { filter: "audioonly" }); - var dispatcher = connection.playStream(stream); - message.channel.send(message.author + ", your music is now playing."); - dispatcher.on("end", function (end) { - message.channel.send(message.author + ", your music has ended."); - message.member.voiceChannel.leave(); - }); + message.member.voiceChannel.connection.disconnect(); + message.member.voiceChannel.leave(); } catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); - appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id, err); } - }); - } - else { - message.channel.send(message.author + ", you are not in a voice channel. Join a voice channel to play music!"); - } - } - if (message.content.toString() == "/ratz stop") { - if (message.member.voiceChannel) { - try { - message.member.voiceChannel.connection.disconnect(); - message.member.voiceChannel.leave(); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); - appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id); + else { + message.channel.send(message.author + ", you are not in a voice channel."); } } - else { - message.channel.send(message.author + ", you are not in a voice channel."); - } - } - // -----TOPIC DETECTION AND REVIEW----- - if ((message.content.includes("XXXTentacion") || message.content.includes("xxxtentacion")) && (message.content.includes("death") || message.content.includes("died"))) { - if (fs.readFileSync("./exclude/approvedmessages.ratz").includes(message.content.toString())) { - // Do nothing + // -----TOPIC DETECTION AND REVIEW----- + if ((message.content.includes("XXXTentacion") || message.content.includes("xxxtentacion")) && (message.content.includes("death") || message.content.includes("died"))) { + if (fs.readFileSync("./exclude/approvedmessages.ratz").includes(message.content.toString())) { + // Do nothing + } + else { + fs.appendFileSync("./exclude/bannedmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); + message["delete"](); + removeMessage(message.content.toString(), message.author.id); + message.channel.send(message.author + ", your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator."); + } } - else { + if (message.content.includes("NIGGER") || message.content.includes("nigger") || message.content.includes("NIGGA") || message.content.includes("nigga")) { fs.appendFileSync("./exclude/bannedmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); message["delete"](); + removeMessage(message.content.toString(), message.author.id); message.channel.send(message.author + ", your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator."); } - } - if (message.content.includes("NIGGER") || message.content.includes("nigger") || message.content.includes("NIGGA") || message.content.includes("nigga")) { - fs.appendFileSync("./exclude/bannedmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); - message["delete"](); - message.channel.send(message.author + ", your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator."); + // -------------------------------- + if (message.content.startsWith("/ratz testdetermine")) { + message.channel.send(teachAI()); + } } } } } catch (err) { - appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM"); + appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM", err); } }); bot.on("guildMemberAdd", function (member) { @@ -437,7 +507,7 @@ bot.on("guildMemberRemove", function (member) { bot.channels.get(newcomerChannel).send("**| GOODBYE |** " + member + " has left the server!"); }); bot.on("error", function (error) { - fs.appendFileSync("./exclude/errors.ratz", "\r\nERROR at " + date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds() + " " + date.getMonth() + "/" + date.getDate() + "/" + date.getFullYear() + ": " + error.name + " | " + error.message + "\n"); + appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM", error); }); bot.on("disconnect", function (userconnection) { try { @@ -447,6 +517,9 @@ bot.on("disconnect", function (userconnection) { console.log("**RECON. ERROR**: " + err); } }); +bot.on("ready", function (ready) { + //setInterval(rollAdvert, 7200000); +}); // -----READLINE----- var rl = readline.createInterface({ input: process.stdin, @@ -517,8 +590,81 @@ var TYPE; function sendError(TYPE, ERROR) { this.type = TYPE; this.error = ERROR; - return "An error occured during the process: **| " + TYPE + " | " + ERROR + " |**"; + return "An error occured during the process: **| TYPE: " + TYPE + " | CODE: " + ERROR + " |**"; } -function appendError(TYPE, ERROR, USER) { - fs.appendFileSync("./exclude/errors.ratz", "ERROR CODE: " + ERROR + "\r\nERROR TYPE: " + TYPE + "\r\nUSER: " + USER + "\r\nRECEIVED: " + date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds() + " " + (date.getMonth() + 1) + "/" + date.getDate() + "/" + date.getFullYear() + "\r\n\r\n"); +function appendError(TYPE, ERROR, USER, ERRORDES) { + fs.appendFileSync("./exclude/errors.ratz", "ERROR CODE: " + ERROR + "\r\nERROR TYPE: " + TYPE + "\r\nUSER: " + USER + "\r\nRECEIVED: " + date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds() + " " + (date.getMonth() + 1) + "/" + date.getDate() + "/" + date.getFullYear() + "\r\nERROR DESCRIPTION: " + ERRORDES + "\r\n\r\n"); +} +function removeMessage(content, authorid) { + if (!messagedata.users[0][authorid]) { + messagedata.users[0][authorid] = []; + } + var data = messagedata.users[0][authorid]; + data.push(content); + var txt = JSON.stringify(messagedata); + fs.writeFileSync("./exclude/removedauthmessages.json", txt); +} +//-----ADVERT FUNCTIONS----- +function rollAdvert() { + // Uses the part of a GitHub repo URL to run into the API + var integer; + var random = Math.floor(Math.random() * 2); + var result = advertdata.adverts[random]; + var getAdvertInfo = { + method: "GET", + url: "https://api.github.com/repos/" + result, + headers: { + "User-Agent": "Gisgar3" + } + }; + request(getAdvertInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed = new Discord.RichEmbed() + .setTitle("ADVERTISEMENT") + .setDescription("**" + stats.name + "**") + .setURL(stats.html_url) + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .addField("Owner", "" + stats.owner.login) + .addField("Program Name", "" + stats.name) + .addField("Program Description", "" + stats.description) + .addField("License", "" + stats.license.name); + bot.channels.get(selfPromoChannel).send(embed); + } + else { + appendError(TYPE.BACKEND, ERROR.RATZx0000006, "SYSTEM", error); + } + } + catch (err) { + appendError(TYPE.BACKEND, ERROR.RATZx0000006, "SYSTEM", error); + } + }); +} +// ---------- +function teachAI() { + return __awaiter(this, void 0, void 0, function () { + var model, xs, ys, result; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + model = tf.sequential(); + model.add(tf.layers.dense({ units: 1, inputShape: [1] })); + model.compile({ + loss: 'meanSquaredError', + optimizer: 'sgd' + }); + xs = tf.tensor2d([-1, 0, 1, 2, 3, 4], [6, 1]); + ys = tf.tensor2d([0.10, 1.20, 2.30, 3.40, 4.50, 5.60], [6, 1]); + // Train the model + return [4 /*yield*/, model.fit(xs, ys, { epochs: 500 })]; + case 1: + // Train the model + _b.sent(); + result = model.predict(tf.tensor2d([7], [1, 1])).print(); + return [2 /*return*/]; + } + }); + }); } diff --git a/main.ts b/main.ts index 69f53da..862cb19 100644 --- a/main.ts +++ b/main.ts @@ -1,531 +1,627 @@ // COPYRIGHT (C) GAVIN ISGAR 2017-2018 -const Discord = require("discord.js"); -const DiscordRPC = require("discord-rpc"); -const opus = require("opusscript"); -const ffmpeg = require("ffmpeg-binaries"); -const ytdl = require("ytdl-core"); -const bot = new Discord.Client(); -const msg = new Discord.Message(); +var Discord = require("discord.js"); +var DiscordRPC = require("discord-rpc"); +const tf = require('@tensorflow/tfjs'); +var opus = require("opusscript"); +var ffmpeg = require("ffmpeg-binaries"); +var ytdl = require("ytdl-core"); +var bot = new Discord.Client(); +var msg = new Discord.Message(); var net = require('net'); var http = require("http"); var url = require("url"); var path = require("path"); var request = require("request"); var commands = require("./commands.json"); -var tokens = require("./exclude/tokens.json"); +//var tokens = require("./exclude/tokens.json"); +var tokens = require("C:/Users/Gavin/Desktop/tokens.json"); var fs = require("fs"); -const readline = require("readline"); -const package = require("./package.json"); -const { app, BrowserWindow } = require('electron'); +var readline = require("readline"); +var packagefile = require("./package.json"); +var _a = require('electron'), app = _a.app, BrowserWindow = _a.BrowserWindow; var date = new Date(); - +var messagedata = require("./exclude/removedauthmessages.json"); +var advertdata = require("./exclude/adverts.json"); //-----SERVER EVENTS----- var activeevent = ""; // --------- - // -----CHANNELS----- var logChannel = "423939166401855518"; var newcomerChannel = "423937750937501697"; var mainChannel = "443227379712917505"; +var liveChannel = "423938014801166346"; +var selfPromoChannel = "438003121755783199"; // ---------- - -bot.on('message', (message) => { +bot.on('message', function (message) { try { - if (fs.readFileSync("./exclude/bannedusers.ratz").includes(message.author.id.toString()) == true) { - message.channel.send(`${message.author}, you are banned from communicating in the server.`); - message.delete(); - } - else { - if (fs.readFileSync("./exclude/users.ratz").includes(message.author.id.toString()) == false) { - if (message.author.username == "GitHub" && message.author.bot == 1) { - // Do nothing - } - else { - if (message.content.toString() == "/ratz slimedog") { - fs.appendFileSync("./exclude/users.ratz", `\r\n${message.author.id.toString()}`); - message.delete(); - message.channel.send(`${message.author}, you now have access to type in the server!`); + if (message.channel.type == "dm") { + if (message.author.id == "434154972834299904") { + // Do nothing + } + else { + if (message.content.toString() == "/ratz getremovedmessages") { + if (!messagedata.users[0][message.author.id]) { + message.channel.send("No message data exists for your UserID."); + console.log(`Private data requested and failed from ${message.author.username}`); } else { - fs.appendFileSync("./exclude/removedauthmessages.ratz", `\r\n(${message.author.username} [${message.author.id}], ${message.createdTimestamp}) ${message.content.toString()}`); - message.delete(); - message.channel.send(`${message.author}, you have not completely read the rules in order to have access to chat. To get access, re-read the rules and type the secret response message specified.`) + message.channel.send(messagedata.users[0][message.author.id]); + console.log(`Private data requested and given to ${message.author.username}`); } } } + } + else { + if (fs.readFileSync("./exclude/bannedusers.ratz").includes(message.author.id.toString()) == true) { + message.channel.send(message.author + ", you are banned from communicating in the server."); + message["delete"](); + } else { - // ---COMMANDS--- - if (message.content.toString().startsWith("/ratz discorduserinfo ")) { - var result = message.content.slice(22); - try { - var user = bot.users.find("id", result); - var embed = new Discord.RichEmbed() - .setTitle(`Discord User Information for ${user.username}`) - .setColor(0xcb00ff) - .setThumbnail(user.avatarURL) - .addField(`Username`, user.username) - .addField(`ID`, user.id) - .addField(`Tag`, user.tag) - .addField(`Account Created`, user.createdTimestamp) - .addField(`Last Message ID`, user.lastMessageID) - message.channel.send(embed); - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000008)); - appendError(TYPE.BACKEND, ERROR.RATZx0000008, message.author.id); + if (fs.readFileSync("./exclude/users.ratz").includes(message.author.id.toString()) == false) { + if (message.author.username == "GitHub" && message.author.bot == 1) { + // Do nothing } - } - if (message.content.toString() == "/ratz slimedog") { - message.channel.send(`${message.author}, you are already authorized to type in the server!`); - } - if (message.content.toString() == "/ratz showcommands") { - var i; - const embed = new Discord.RichEmbed() - .setTitle(`Commands for ratzBot`) - .setColor(0xcb00ff) - .setThumbnail(bot.user.avatarURL.toString()) - for (i = 0; commands.names[i]; i++) { - for (i = 0; commands.definitions[i]; i++) { - embed.addField(commands.names[i], commands.definitions[i]); + else { + if (message.content.toString() == "/ratz slimedog") { + fs.appendFileSync("./exclude/users.ratz", "\r\n" + message.author.id.toString()); + message["delete"](); + message.channel.send(message.author + ", you now have access to type in the server!"); + } + else { + removeMessage(message.content.toString(), message.author.id); + message["delete"](); + message.channel.send(message.author + ", hello and welcome to the server! You have to read the rules and enter the specified password to access the server (for the sake of spammers \u2661)."); + // Old method + //fs.appendFileSync("./exclude/removedauthmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); + //message["delete"](); + //message.channel.send(message.author + ", hello and welcome to the server! You have to read the rules and enter the specified password to access the server (for the sake of spammers \u2661)."); } } - message.channel.send({ embed }); } - if (message.content.toString() == "/ratz botinfo") { - var embed = new Discord.RichEmbed() - .setTitle("ratzBot Information") - .setThumbnail(bot.user.avatarURL.toString()) - .setColor(0xcb00ff) - .addField("Developer", "Gavin Isgar (https://www.github.com/gisgar3/)") - .addField("Version Number", package.version) - .addField("Source Languages", "JavaScript\nTypeScript") - .addField("GitHub Repository", "https://www.github.com/gisgar3/ratzbot/") - message.channel.send(embed); - } - if (message.content.startsWith("/ratz steamuserinfo ")) { - var result = message.content.slice(20); - var getSteamProfile = { - method: "GET", - url: `https://api.steampowered.com/ISteamUser/GetPlayerSummaries/v2/?key=${tokens.steamtoken}&steamids=${result}`, - } - request(getSteamProfile, (error, response, body) => { + else { + // ---COMMANDS--- + if (message.content.toString().startsWith("/ratz discorduserinfo ")) { + var result = message.content.slice(22); try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - const embed = new Discord.RichEmbed() - .setTitle(`Steam User Information for ${stats.response.players[0].steamid}`) - .setURL(stats.response.players[0].profileurl) - .setColor(0xcb00ff) - .setThumbnail(stats.response.players[0].avatarfull) - .addField("Username", stats.response.players[0].personaname) - .addField("Profile State", stats.response.players[0].profilestate) - .addField("Primary Clan", stats.response.players[0].primaryclanid) - .addField("Last Logoff", stats.response.players[0].lastlogoff) - .addField("Account Created", stats.response.players[0].timecreated); - message.channel.send({ embed }); - } - else { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); - appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id); - } + var user = bot.users.find("id", result); + var embed = new Discord.RichEmbed() + .setTitle("Discord User Information for " + user.username) + .setColor(0xcb00ff) + .setThumbnail(user.avatarURL) + .addField("Username", user.username) + .addField("ID", user.id) + .addField("Tag", user.tag) + .addField("Account Created", user.createdTimestamp) + .addField("Last Message ID", user.lastMessageID); + message.channel.send(embed); } catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); - appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id); + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000008)); + appendError(TYPE.BACKEND, ERROR.RATZx0000008, message.author.id, err); } - }) - } - if (message.content.toString() == "/ratz releaseinfo") { - var getReleaseInfo = { - method: "GET", - url: `https://api.github.com/repos/Gisgar3/ratzBot/releases`, - headers: { - "User-Agent": "Gisgar3" + } + if (message.content.toString() == "/ratz slimedog") { + message.channel.send(message.author + ", you are already authorized to type in the server!"); + } + if (message.content.toString() == "/ratz showcommands") { + var i; + var embed_1 = new Discord.RichEmbed() + .setTitle("Commands for ratzBot") + .setColor(0xcb00ff) + .setThumbnail(bot.user.avatarURL.toString()); + for (i = 0; commands.names[i]; i++) { + for (i = 0; commands.definitions[i]; i++) { + embed_1.addField(commands.names[i], commands.definitions[i]); + } } + message.channel.send({ embed: embed_1 }); } - request(getReleaseInfo, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - var embed = new Discord.RichEmbed() - .setTitle("ratzBot GitHub Release Information") - .setThumbnail(bot.user.avatarURL) - .setColor(0xcb00ff) - .setURL(stats[0].html_url) - .addField(`Latest Release`, "" + stats[0].name) - .addField(`Release Branch`, "" + stats[0].target_commitish) - .addField(`Tag`, stats[0].tag_name) - .addField(`Changelog`, stats[0].body) - .addField(`Pre-Release Status`, "" + stats[0].prerelease) - .addField(`Author`, stats[0].author.login) - if (`${stats[0].prerelease}` == "true" && `${stats[0].tag_name}`.endsWith("-RC")) { - embed.setFooter("BUILD STAGE: Release Candidate"); + if (message.content.toString() == "/ratz botinfo") { + var embed = new Discord.RichEmbed() + .setTitle("ratzBot Information") + .setThumbnail(bot.user.avatarURL.toString()) + .setColor(0xcb00ff) + .addField("Developer", "Gavin Isgar (https://www.github.com/gisgar3/)") + .addField("Version Number", packagefile.version) + .addField("Source Languages", "JavaScript\nTypeScript") + .addField("GitHub Repository", "https://www.github.com/gisgar3/ratzbot/"); + message.channel.send(embed); + } + if (message.content.startsWith("/ratz steamuserinfo ")) { + var result = message.content.slice(20); + var getSteamProfile = { + method: "GET", + url: "https://api.steampowered.com/ISteamUser/GetPlayerSummaries/v2/?key=" + tokens.steamtoken + "&steamids=" + result + }; + request(getSteamProfile, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_2 = new Discord.RichEmbed() + .setTitle("Steam User Information for " + stats.response.players[0].steamid) + .setURL(stats.response.players[0].profileurl) + .setColor(0xcb00ff) + .setThumbnail(stats.response.players[0].avatarfull) + .addField("Username", stats.response.players[0].personaname) + .addField("Profile State", stats.response.players[0].profilestate) + .addField("Primary Clan", stats.response.players[0].primaryclanid) + .addField("Last Logoff", stats.response.players[0].lastlogoff) + .addField("Account Created", stats.response.players[0].timecreated); + message.channel.send({ embed: embed_2 }); } - else if (`${stats[0].prerelease}` == "true" && `${stats[0].tag_name}`.endsWith("-Beta")) { - embed.setFooter("BUILD STAGE: Beta"); + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); + appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id, error); } - else if (`${stats[0].prerelease}` == "true" && `${stats[0].tag_name}`.endsWith("-Alpha")) { - embed.setFooter("BUILD STAGE: Alpha"); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000007)); + appendError(TYPE.BACKEND, ERROR.RATZx0000007, message.author.id, err); + } + }); + } + if (message.content.toString() == "/ratz releaseinfo") { + var getReleaseInfo = { + method: "GET", + url: "https://api.github.com/repos/Gisgar3/ratzBot/releases", + headers: { + "User-Agent": "Gisgar3" + } + }; + request(getReleaseInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed = new Discord.RichEmbed() + .setTitle("ratzBot GitHub Release Information") + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .setURL(stats[0].html_url) + .addField("Latest Release", "" + stats[0].name) + .addField("Release Branch", "" + stats[0].target_commitish) + .addField("Tag", stats[0].tag_name) + .addField("Changelog", stats[0].body) + .addField("Pre-Release Status", "" + stats[0].prerelease) + .addField("Author", stats[0].author.login); + if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-RC")) { + embed.setFooter("BUILD STAGE: Release Candidate"); + } + else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Beta")) { + embed.setFooter("BUILD STAGE: Beta"); + } + else if ("" + stats[0].prerelease == "true" && ("" + stats[0].tag_name).endsWith("-Alpha")) { + embed.setFooter("BUILD STAGE: Alpha"); + } + else if ("" + stats[0].prerelease == "false") { + embed.setFooter("BUILD STAGE: General Availability"); + } + message.channel.send(embed); } - else if (`${stats[0].prerelease}` == "false") { - embed.setFooter("BUILD STAGE: General Availability"); + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); } - message.channel.send(embed); } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }) - } - if (message.content.startsWith("/ratz gituserinfo ")) { - var result = message.content.slice(18); - var getGitUserInfo = { - method: "GET", - url: `https://api.github.com/users/${result}`, - headers: { - "User-Agent": "Gisgar3" - } + }); } - request(getGitUserInfo, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - const embed = new Discord.RichEmbed() - .setTitle(`GitHub User Information for ${result}`) - .setURL(stats.html_url) - .setColor(0xcb00ff) - .setThumbnail(stats.avatar_url) - .addField("Name", stats.name) - .addField("Company", "" + stats.company) - .addField("Bio", "" + stats.bio) - .addField("Location", "" + stats.location) - .addField("Email", "" + stats.email) - .addField("Hireable", "" + stats.hireable) - .addField("Public Repositories", stats.public_repos) - message.channel.send(embed); + if (message.content.startsWith("/ratz gituserinfo ")) { + var result = message.content.slice(18); + var getGitUserInfo = { + method: "GET", + url: "https://api.github.com/users/" + result, + headers: { + "User-Agent": "Gisgar3" + } + }; + request(getGitUserInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_3 = new Discord.RichEmbed() + .setTitle("GitHub User Information for " + result) + .setURL(stats.html_url) + .setColor(0xcb00ff) + .setThumbnail(stats.avatar_url) + .addField("Name", stats.name) + .addField("Company", "" + stats.company) + .addField("Bio", "" + stats.bio) + .addField("Location", "" + stats.location) + .addField("Email", "" + stats.email) + .addField("Hireable", "" + stats.hireable) + .addField("Public Repositories", stats.public_repos); + message.channel.send(embed_3); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }) - } - if (message.content.startsWith("/ratz gitrepoinfo ")) { - var result = message.content.slice(18); - var getGitRepoInfo = { - method: "GET", - url: `https://api.github.com/repos/${result}`, - headers: { - 'User-Agent': 'Gisgar3' - } + }); } - request(getGitRepoInfo, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - const embed = new Discord.RichEmbed() - .setTitle(`GitHub Repository for ${result}`) - .setURL(stats.html_url) - .setColor(0xcb00ff) - .setThumbnail(stats.owner.avatar_url) - .addField("Name", stats.name) - .addField("Description", stats.description) - .addField("Owner", stats.owner.login) - .addField("Language", stats.language) - .addField("Archive Status", stats.archived) - message.channel.send(embed); + if (message.content.startsWith("/ratz gitrepoinfo ")) { + var result = message.content.slice(18); + var getGitRepoInfo = { + method: "GET", + url: "https://api.github.com/repos/" + result, + headers: { + 'User-Agent': 'Gisgar3' } - else { + }; + request(getGitRepoInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_4 = new Discord.RichEmbed() + .setTitle("GitHub Repository for " + result) + .setURL(stats.html_url) + .setColor(0xcb00ff) + .setThumbnail(stats.owner.avatar_url) + .addField("Name", stats.name) + .addField("Description", stats.description) + .addField("Owner", stats.owner.login) + .addField("Language", stats.language) + .addField("Archive Status", stats.archived); + message.channel.send(embed_4); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, error); + } + } + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000006)); - appendError(TYPE.BACKEND, ERROR.RATZx0000006, message.author.id); - } - }) - } - if (message.content.toString() == "/ratz btcinfo") { - var getBTCInfo = { - method: "GET", - url: "https://api.blockchain.info/stats" + }); } - request(getBTCInfo, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - const embed = new Discord.RichEmbed() - .setTitle("BTC Information") - .setColor(0xcb00ff) - .setThumbnail(bot.user.avatarURL) - .addField("Market Price (USD)", `$${stats.market_price_usd}`) - .addField("BTC Mined", stats.n_btc_mined) - .addField("Blocks Mined", stats.n_blocks_mined) - .addField("Total Blocks", stats.n_blocks_total) - .addField("Total BTC Sent", stats.total_btc_sent) - message.channel.send(embed); + if (message.content.toString() == "/ratz btcinfo") { + var getBTCInfo = { + method: "GET", + url: "https://api.blockchain.info/stats" + }; + request(getBTCInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_5 = new Discord.RichEmbed() + .setTitle("BTC Information") + .setColor(0xcb00ff) + .setThumbnail(bot.user.avatarURL) + .addField("Market Price (USD)", "$" + stats.market_price_usd) + .addField("BTC Mined", stats.n_btc_mined) + .addField("Blocks Mined", stats.n_blocks_mined) + .addField("Total Blocks", stats.n_blocks_total) + .addField("Total BTC Sent", stats.total_btc_sent); + message.channel.send(embed_5); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); + appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); - appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id, err); } + }); + } + // -----SERVER EVENTS----- + if (message.content.toString() == "/ratz joinactiveevent") { + if (activeevent == "") { + message.channel.send(message.author + ", there is no active event on the server."); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000005)); - appendError(TYPE.BACKEND, ERROR.RATZx0000005, message.author.id); + else { + try { + fs.appendFileSync("./exclude/eventuserlist.ratz", "\r\n" + message.author.id); + message.channel.send(message.author + ", you are now joined into the " + activeevent + "!"); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000004)); + appendError(TYPE.BACKEND, ERROR.RATZx0000004, message.author.id, err); + } } - }) - } - // -----SERVER EVENTS----- - if (message.content.toString() == "/ratz joinactiveevent") { - if (activeevent == "") { - message.channel.send(`${message.author}, there is no active event on the server.`); } - else { - try { - fs.appendFileSync("./exclude/eventuserlist.ratz", `\r\n${message.author.id}`); - message.channel.send(`${message.author}, you are now joined into the ${activeevent}!`); + if (message.content.toString() == "/ratz showactiveevent") { + if (activeevent == "") { + message.channel.send(message.author + ", there is no active event on the server."); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000004)); - appendError(TYPE.BACKEND, ERROR.RATZx0000004, message.author.id); + else { + message.channel.send(message.author + ", the active event on the server is the " + activeevent + "."); } } - } - if (message.content.toString() == "/ratz showactiveevent") { - if (activeevent == "") { - message.channel.send(`${message.author}, there is no active event on the server.`); - } - else { - message.channel.send(`${message.author}, the active event on the server is the ${activeevent}.`); - } - } - // -----STREAMLABS INTEGRATION----- - if (message.content.startsWith("/ratz ratcoininfo ")) { - var result = message.content.slice(18); - var getRTCInfo = { - method: "GET", - url: `https://streamlabs.com/api/v1.0/points?access_token=${tokens.streamlabstoken}&username=${result}&channel=ratzdoll` - } - request(getRTCInfo, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - message.channel.send(`${message.author}, ${result} has ${stats.points} RTC!`); + // -----STREAMLABS INTEGRATION----- + if (message.content.startsWith("/ratz ratcoininfo ")) { + var result = message.content.slice(18); + var getRTCInfo = { + method: "GET", + url: "https://streamlabs.com/api/v1.0/points?access_token=" + tokens.streamlabstoken + "&username=" + result + "&channel=ratzdoll" + }; + request(getRTCInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + message.channel.send(message.author + ", " + result + " has " + stats.points + " RTC!"); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); + appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id, error); + } } - else { + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); - appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id, err); } - } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000003)); - appendError(TYPE.BACKEND, ERROR.RATZx0000003, message.author.id); - } - }) - } - // -----TWITCH NEW API----- - if (message.content.toString() == "/ratz laststream") { - var getStreamVOD = { - method: 'GET', - url: `https://api.twitch.tv/helix/videos?user_id=157901049&first=1`, - headers: { - "Client-ID": `${tokens.twitchapiclientid}` - } + }); } - request(getStreamVOD, (error, response, body) => { - try { - if (!error && response.statusCode == 200) { - var stats = JSON.parse(body); - const embed = new Discord.RichEmbed() - .setTitle("Last Stream VOD from ratzDoll") - .setThumbnail(bot.user.avatarURL) - .setColor(0xcb00ff) - .setURL(stats.data[0].url) - .addField("Title", "" + stats.data[0].title) - .addField("Published At", "" + stats.data[0].published_at) - .addField("Duration", "" + stats.data[0].duration) - .addField("View Count", stats.data[0].view_count) - message.channel.send(embed); + // -----TWITCH NEW API----- + if (message.content.toString() == "/ratz laststream") { + var getStreamVOD = { + method: 'GET', + url: "https://api.twitch.tv/helix/videos?user_id=157901049&first=1", + headers: { + "Client-ID": "" + tokens.twitchapiclientid } - else { + }; + request(getStreamVOD, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed_6 = new Discord.RichEmbed() + .setTitle("Last Stream VOD from ratzDoll") + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .setURL(stats.data[0].url) + .addField("Title", "" + stats.data[0].title) + .addField("Published At", "" + stats.data[0].published_at) + .addField("Duration", "" + stats.data[0].duration) + .addField("View Count", stats.data[0].view_count); + message.channel.send(embed_6); + } + else { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); + appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id, error); + } + } + catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); - appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id, err); } + }); + } + // -----VOICE CHANNELS----- + if (message.content.startsWith("/ratz play ")) { + var result = message.content.slice(11); + if (message.member.voiceChannel) { + message.member.voiceChannel.join().then(function (connection) { + try { + var stream = ytdl(result, { filter: "audioonly" }); + var dispatcher = connection.playStream(stream); + message.channel.send(message.author + ", your music is now playing."); + dispatcher.on("end", function (end) { + message.channel.send(message.author + ", your music has ended."); + message.member.voiceChannel.leave(); + }); + } + catch (err) { + message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); + appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id, err); + } + }); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000002)); - appendError(TYPE.BACKEND, ERROR.RATZx0000002, message.author.id); + else { + message.channel.send(message.author + ", you are not in a voice channel. Join a voice channel to play music!"); } - }) - } - // -----VOICE CHANNELS----- - if (message.content.startsWith("/ratz play ")) { - var result = message.content.slice(11); - if (message.member.voiceChannel) { - message.member.voiceChannel.join().then(connection => { + } + if (message.content.toString() == "/ratz stop") { + if (message.member.voiceChannel) { try { - const stream = ytdl(result, { filter: `audioonly` }); - const dispatcher = connection.playStream(stream); - message.channel.send(`${message.author}, your music is now playing.`); - dispatcher.on("end", end => { - message.channel.send(`${message.author}, your music has ended.`); - message.member.voiceChannel.leave(); - }) + message.member.voiceChannel.connection.disconnect(); + message.member.voiceChannel.leave(); } catch (err) { message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); - appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id); + appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id, err); } - }) - } - else { - message.channel.send(`${message.author}, you are not in a voice channel. Join a voice channel to play music!`); - } - } - if (message.content.toString() == "/ratz stop") { - if (message.member.voiceChannel) { - try { - message.member.voiceChannel.connection.disconnect() - message.member.voiceChannel.leave(); } - catch (err) { - message.channel.send(sendError(TYPE.BACKEND, ERROR.RATZx0000001)); - appendError(TYPE.BACKEND, ERROR.RATZx0000001, message.author.id); + else { + message.channel.send(message.author + ", you are not in a voice channel."); } } - else { - message.channel.send(`${message.author}, you are not in a voice channel.`); + // -----TOPIC DETECTION AND REVIEW----- + if ((message.content.includes("XXXTentacion") || message.content.includes("xxxtentacion")) && (message.content.includes("death") || message.content.includes("died"))) { + if (fs.readFileSync("./exclude/approvedmessages.ratz").includes(message.content.toString())) { + // Do nothing + } + else { + fs.appendFileSync("./exclude/bannedmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); + message["delete"](); + removeMessage(message.content.toString(), message.author.id); + message.channel.send(message.author + ", your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator."); + } } - } - // -----TOPIC DETECTION AND REVIEW----- - if ((message.content.includes("XXXTentacion") || message.content.includes("xxxtentacion")) && (message.content.includes("death") || message.content.includes("died"))) { - if (fs.readFileSync("./exclude/approvedmessages.ratz").includes(message.content.toString())) { - // Do nothing + if (message.content.includes("NIGGER") || message.content.includes("nigger") || message.content.includes("NIGGA") || message.content.includes("nigga")) { + fs.appendFileSync("./exclude/bannedmessages.ratz", "\r\n(" + message.author.username + " [" + message.author.id + "], " + message.createdTimestamp + ") " + message.content.toString()); + message["delete"](); + removeMessage(message.content.toString(), message.author.id); + message.channel.send(message.author + ", your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator."); } - else { - fs.appendFileSync("./exclude/bannedmessages.ratz", `\r\n(${message.author.username} [${message.author.id}], ${message.createdTimestamp}) ${message.content.toString()}`); - message.delete(); - message.channel.send(`${message.author}, your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator.`); + // -------------------------------- + if (message.content.startsWith("/ratz testdetermine")) { + message.channel.send(teachAI()); } } - if (message.content.includes("NIGGER") || message.content.includes("nigger") || message.content.includes("NIGGA") || message.content.includes("nigga")) { - fs.appendFileSync("./exclude/bannedmessages.ratz", `\r\n(${message.author.username} [${message.author.id}], ${message.createdTimestamp}) ${message.content.toString()}`); - message.delete(); - message.channel.send(`${message.author}, your message was deleted because it possibly relates to a blocked topic. To appeal the deletion of your message, contact an administrator.`); - } } } } catch (err) { - appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM"); + appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM", err); } -}) - -bot.on("guildMemberAdd", (member) => { - bot.channels.get(newcomerChannel).send(`**| WELCOME |** ${member} has joined the server!`); -}) - -bot.on("guildMemberRemove", (member) => { - bot.channels.get(newcomerChannel).send(`**| GOODBYE |** ${member} has left the server!`); -}) - -bot.on("error", (error) => { - fs.appendFileSync("./exclude/errors.ratz", `\r\nERROR at ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()} ${date.getMonth()}/${date.getDate()}/${date.getFullYear()}: ${error.name} | ${error.message}\n`); -}) - -bot.on("disconnect", (userconnection) => { +}); +bot.on("guildMemberAdd", function (member) { + bot.channels.get(newcomerChannel).send("**| WELCOME |** " + member + " has joined the server!"); +}); +bot.on("guildMemberRemove", function (member) { + bot.channels.get(newcomerChannel).send("**| GOODBYE |** " + member + " has left the server!"); +}); +bot.on("error", function (error) { + appendError(TYPE.BACKEND, ERROR.RATZx0000009, "SYSTEM", error); +}); +bot.on("disconnect", function (userconnection) { try { bot.login(tokens.bottoken); } catch (err) { - console.log(`**RECON. ERROR**: ${err}`); + console.log("**RECON. ERROR**: " + err); } -}) - +}); +bot.on("ready", function (ready) { + //setInterval(rollAdvert, 7200000); +}); // -----READLINE----- -const rl = readline.createInterface({ +var rl = readline.createInterface({ input: process.stdin, output: process.stdout }); - -rl.on("line", (input) => { +rl.on("line", function (input) { if (input.toString().startsWith("/ratz userban ")) { var result = input.slice(14); try { bot.guilds.forEach(function (getGuilds) { if (getGuilds.name == "ratzcord") { getGuilds.members.forEach(function (getMembers) { - if (getMembers.id == `${result}`) { + if (getMembers.id == "" + result) { getMembers.ban("Banned by ratzBot system."); - console.log(`**BAN**: User ${result} was successfully banned.`); + console.log("**BAN**: User " + result + " was successfully banned."); } else { // Do nothing } - }) + }); } else { // Do nothing } - }) + }); } catch (err) { - console.log(`**ERROR**: ${err}`); + console.log("**ERROR**: " + err); } } if (input.toString().startsWith("/ratz writemain ")) { var result = input.slice(16); try { - bot.channels.get(mainChannel).send(`${result}`); + bot.channels.get(mainChannel).send("" + result); } catch (err) { - console.log(`**ERROR**: ${err}`); + console.log("**ERROR**: " + err); } } // -----SERVER EVENTS----- if (input.toString().startsWith("/ratz setevent ")) { var result = input.slice(15); activeevent = result; - console.log(`**EVENT**: Event has been set.`); + console.log("**EVENT**: Event has been set."); } -}) - +}); bot.login(tokens.bottoken); // -----ERROR REPORTING----- -enum ERROR { - RATZx0000001 = "RATZx0000001", - RATZx0000002 = "RATZx0000002", - RATZx0000003 = "RATZx0000003", - RATZx0000004 = "RATZx0000004", - RATZx0000005 = "RATZx0000005", - RATZx0000006 = "RATZx0000006", - RATZx0000007 = "RATZx0000007", - RATZx0000008 = "RATZx0000008", - RATZx0000009 = "RATZx0000009" -}; -enum TYPE { - FRONTEND = "FRONTEND", - BACKEND = "BACKEND" -}; -function sendError(TYPE: TYPE, ERROR: ERROR) { +var ERROR; +(function (ERROR) { + ERROR["RATZx0000001"] = "RATZx0000001"; + ERROR["RATZx0000002"] = "RATZx0000002"; + ERROR["RATZx0000003"] = "RATZx0000003"; + ERROR["RATZx0000004"] = "RATZx0000004"; + ERROR["RATZx0000005"] = "RATZx0000005"; + ERROR["RATZx0000006"] = "RATZx0000006"; + ERROR["RATZx0000007"] = "RATZx0000007"; + ERROR["RATZx0000008"] = "RATZx0000008"; + ERROR["RATZx0000009"] = "RATZx0000009"; +})(ERROR || (ERROR = {})); +; +var TYPE; +(function (TYPE) { + TYPE["FRONTEND"] = "FRONTEND"; + TYPE["BACKEND"] = "BACKEND"; +})(TYPE || (TYPE = {})); +; +function sendError(TYPE, ERROR) { this.type = TYPE; this.error = ERROR; - return `An error occured during the process: **| ${TYPE} | ${ERROR} |**` + return "An error occured during the process: **| TYPE: " + TYPE + " | CODE: " + ERROR + " |**"; +} +function appendError(TYPE, ERROR, USER, ERRORDES) { + fs.appendFileSync("./exclude/errors.ratz", "ERROR CODE: " + ERROR + "\r\nERROR TYPE: " + TYPE + "\r\nUSER: " + USER + "\r\nRECEIVED: " + date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds() + " " + (date.getMonth() + 1) + "/" + date.getDate() + "/" + date.getFullYear() + "\r\nERROR DESCRIPTION: " + ERRORDES + "\r\n\r\n"); +} +function removeMessage(content, authorid) { + if (!messagedata.users[0][authorid]) { + messagedata.users[0][authorid] = []; + } + var data = messagedata.users[0][authorid]; + data.push(content); + var txt = JSON.stringify(messagedata); + fs.writeFileSync("./exclude/removedauthmessages.json", txt); +} + +//-----ADVERT FUNCTIONS----- +function rollAdvert() { + // Uses the part of a GitHub repo URL to run into the API + var integer; + var random = Math.floor(Math.random() * 2); + var result = advertdata.adverts[random]; + var getAdvertInfo = { + method: "GET", + url: `https://api.github.com/repos/${result}`, + headers: { + "User-Agent": "Gisgar3" + } + } + request(getAdvertInfo, function (error, response, body) { + try { + if (!error && response.statusCode == 200) { + var stats = JSON.parse(body); + var embed = new Discord.RichEmbed() + .setTitle("ADVERTISEMENT") + .setDescription(`**${stats.name}**`) + .setURL(stats.html_url) + .setThumbnail(bot.user.avatarURL) + .setColor(0xcb00ff) + .addField("Owner", `` + stats.owner.login) + .addField("Program Name", `` + stats.name) + .addField("Program Description", `` + stats.description) + .addField("License", `` + stats.license.name) + bot.channels.get(selfPromoChannel).send(embed); + } + else { + appendError(TYPE.BACKEND, ERROR.RATZx0000006, "SYSTEM", error); + } + } + catch (err) { + appendError(TYPE.BACKEND, ERROR.RATZx0000006, "SYSTEM", error); + } + }) +} +// ---------- +async function teachAI() { + const model = tf.sequential(); + model.add(tf.layers.dense({units: 1, inputShape: [1]})); + model.compile({ + loss: 'meanSquaredError', + optimizer: 'sgd' + }); + // Shape the output + const xs = tf.tensor2d([-1, 0, 1, 2, 3, 4], [6,1]); + const ys = tf.tensor2d([0.10, 1.20, 2.30, 3.40, 4.50, 5.60], [6,1]); + // Train the model + await model.fit(xs, ys, {epochs: 500}); + // Predict the number + var result = model.predict(tf.tensor2d([7], [1,1])).print(); } -function appendError(TYPE: TYPE, ERROR: ERROR, USER: String) { - fs.appendFileSync("./exclude/errors.ratz", `ERROR CODE: ${ERROR}\r\nERROR TYPE: ${TYPE}\r\nUSER: ${USER}\r\nRECEIVED: ${date.getHours()}:${date.getMinutes()}:${date.getSeconds()} ${date.getMonth() + 1}/${date.getDate()}/${date.getFullYear()}\r\n\r\n`) -} \ No newline at end of file diff --git a/node_modules/.bin/cake b/node_modules/.bin/cake new file mode 100644 index 0000000..8051e8c --- /dev/null +++ b/node_modules/.bin/cake @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../coffeescript/bin/cake" "$@" + ret=$? +else + node "$basedir/../coffeescript/bin/cake" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/cake.cmd b/node_modules/.bin/cake.cmd new file mode 100644 index 0000000..9d857b6 --- /dev/null +++ b/node_modules/.bin/cake.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\coffeescript\bin\cake" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\coffeescript\bin\cake" %* +) \ No newline at end of file diff --git a/node_modules/.bin/coffee b/node_modules/.bin/coffee new file mode 100644 index 0000000..57082f8 --- /dev/null +++ b/node_modules/.bin/coffee @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../coffeescript/bin/coffee" "$@" + ret=$? +else + node "$basedir/../coffeescript/bin/coffee" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/coffee.cmd b/node_modules/.bin/coffee.cmd new file mode 100644 index 0000000..744913a --- /dev/null +++ b/node_modules/.bin/coffee.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\coffeescript\bin\coffee" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\coffeescript\bin\coffee" %* +) \ No newline at end of file diff --git a/node_modules/.bin/pbjs b/node_modules/.bin/pbjs new file mode 100644 index 0000000..a786ae9 --- /dev/null +++ b/node_modules/.bin/pbjs @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../protobufjs/bin/pbjs" "$@" + ret=$? +else + node "$basedir/../protobufjs/bin/pbjs" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/pbjs.cmd b/node_modules/.bin/pbjs.cmd new file mode 100644 index 0000000..6a94ef9 --- /dev/null +++ b/node_modules/.bin/pbjs.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\protobufjs\bin\pbjs" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\protobufjs\bin\pbjs" %* +) \ No newline at end of file diff --git a/node_modules/.bin/pbts b/node_modules/.bin/pbts new file mode 100644 index 0000000..8dd2c44 --- /dev/null +++ b/node_modules/.bin/pbts @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../protobufjs/bin/pbts" "$@" + ret=$? +else + node "$basedir/../protobufjs/bin/pbts" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/pbts.cmd b/node_modules/.bin/pbts.cmd new file mode 100644 index 0000000..d9381f9 --- /dev/null +++ b/node_modules/.bin/pbts.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\protobufjs\bin\pbts" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\protobufjs\bin\pbts" %* +) \ No newline at end of file diff --git a/node_modules/@protobufjs/aspromise/LICENSE b/node_modules/@protobufjs/aspromise/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/aspromise/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/aspromise/README.md b/node_modules/@protobufjs/aspromise/README.md new file mode 100644 index 0000000..c7ae36f --- /dev/null +++ b/node_modules/@protobufjs/aspromise/README.md @@ -0,0 +1,13 @@ +@protobufjs/aspromise +===================== +[![npm](https://img.shields.io/npm/v/@protobufjs/aspromise.svg)](https://www.npmjs.com/package/@protobufjs/aspromise) + +Returns a promise from a node-style callback function. + +API +--- + +* **asPromise(fn: `function`, ctx: `Object`, ...params: `*`): `Promise<*>`**
+ Returns a promise from a node-style callback function. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/aspromise/index.d.ts b/node_modules/@protobufjs/aspromise/index.d.ts new file mode 100644 index 0000000..3db03db --- /dev/null +++ b/node_modules/@protobufjs/aspromise/index.d.ts @@ -0,0 +1,13 @@ +export = asPromise; + +type asPromiseCallback = (error: Error | null, ...params: any[]) => {}; + +/** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ +declare function asPromise(fn: asPromiseCallback, ctx: any, ...params: any[]): Promise; diff --git a/node_modules/@protobufjs/aspromise/index.js b/node_modules/@protobufjs/aspromise/index.js new file mode 100644 index 0000000..d6f642c --- /dev/null +++ b/node_modules/@protobufjs/aspromise/index.js @@ -0,0 +1,52 @@ +"use strict"; +module.exports = asPromise; + +/** + * Callback as used by {@link util.asPromise}. + * @typedef asPromiseCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {...*} params Additional arguments + * @returns {undefined} + */ + +/** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ +function asPromise(fn, ctx/*, varargs */) { + var params = new Array(arguments.length - 1), + offset = 0, + index = 2, + pending = true; + while (index < arguments.length) + params[offset++] = arguments[index++]; + return new Promise(function executor(resolve, reject) { + params[offset] = function callback(err/*, varargs */) { + if (pending) { + pending = false; + if (err) + reject(err); + else { + var params = new Array(arguments.length - 1), + offset = 0; + while (offset < params.length) + params[offset++] = arguments[offset]; + resolve.apply(null, params); + } + } + }; + try { + fn.apply(ctx || null, params); + } catch (err) { + if (pending) { + pending = false; + reject(err); + } + } + }); +} diff --git a/node_modules/@protobufjs/aspromise/package.json b/node_modules/@protobufjs/aspromise/package.json new file mode 100644 index 0000000..911c6ec --- /dev/null +++ b/node_modules/@protobufjs/aspromise/package.json @@ -0,0 +1,55 @@ +{ + "_from": "@protobufjs/aspromise@^1.1.2", + "_id": "@protobufjs/aspromise@1.1.2", + "_inBundle": false, + "_integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=", + "_location": "/@protobufjs/aspromise", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/aspromise@^1.1.2", + "name": "@protobufjs/aspromise", + "escapedName": "@protobufjs%2faspromise", + "scope": "@protobufjs", + "rawSpec": "^1.1.2", + "saveSpec": null, + "fetchSpec": "^1.1.2" + }, + "_requiredBy": [ + "/@protobufjs/fetch", + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", + "_shasum": "9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf", + "_spec": "@protobufjs/aspromise@^1.1.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "Returns a promise from a node-style callback function.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/aspromise", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.2" +} diff --git a/node_modules/@protobufjs/aspromise/tests/index.js b/node_modules/@protobufjs/aspromise/tests/index.js new file mode 100644 index 0000000..cfdb258 --- /dev/null +++ b/node_modules/@protobufjs/aspromise/tests/index.js @@ -0,0 +1,130 @@ +var tape = require("tape"); + +var asPromise = require(".."); + +tape.test("aspromise", function(test) { + + test.test(this.name + " - resolve", function(test) { + + function fn(arg1, arg2, callback) { + test.equal(this, ctx, "function should be called with this = ctx"); + test.equal(arg1, 1, "function should be called with arg1 = 1"); + test.equal(arg2, 2, "function should be called with arg2 = 2"); + callback(null, arg2); + } + + var ctx = {}; + + var promise = asPromise(fn, ctx, 1, 2); + promise.then(function(arg2) { + test.equal(arg2, 2, "promise should be resolved with arg2 = 2"); + test.end(); + }).catch(function(err) { + test.fail("promise should not be rejected (" + err + ")"); + }); + }); + + test.test(this.name + " - reject", function(test) { + + function fn(arg1, arg2, callback) { + test.equal(this, ctx, "function should be called with this = ctx"); + test.equal(arg1, 1, "function should be called with arg1 = 1"); + test.equal(arg2, 2, "function should be called with arg2 = 2"); + callback(arg1); + } + + var ctx = {}; + + var promise = asPromise(fn, ctx, 1, 2); + promise.then(function() { + test.fail("promise should not be resolved"); + }).catch(function(err) { + test.equal(err, 1, "promise should be rejected with err = 1"); + test.end(); + }); + }); + + test.test(this.name + " - resolve twice", function(test) { + + function fn(arg1, arg2, callback) { + test.equal(this, ctx, "function should be called with this = ctx"); + test.equal(arg1, 1, "function should be called with arg1 = 1"); + test.equal(arg2, 2, "function should be called with arg2 = 2"); + callback(null, arg2); + callback(null, arg1); + } + + var ctx = {}; + var count = 0; + + var promise = asPromise(fn, ctx, 1, 2); + promise.then(function(arg2) { + test.equal(arg2, 2, "promise should be resolved with arg2 = 2"); + if (++count > 1) + test.fail("promise should not be resolved twice"); + test.end(); + }).catch(function(err) { + test.fail("promise should not be rejected (" + err + ")"); + }); + }); + + test.test(this.name + " - reject twice", function(test) { + + function fn(arg1, arg2, callback) { + test.equal(this, ctx, "function should be called with this = ctx"); + test.equal(arg1, 1, "function should be called with arg1 = 1"); + test.equal(arg2, 2, "function should be called with arg2 = 2"); + callback(arg1); + callback(arg2); + } + + var ctx = {}; + var count = 0; + + var promise = asPromise(fn, ctx, 1, 2); + promise.then(function() { + test.fail("promise should not be resolved"); + }).catch(function(err) { + test.equal(err, 1, "promise should be rejected with err = 1"); + if (++count > 1) + test.fail("promise should not be rejected twice"); + test.end(); + }); + }); + + test.test(this.name + " - reject error", function(test) { + + function fn(callback) { + test.ok(arguments.length === 1 && typeof callback === "function", "function should be called with just a callback"); + throw 3; + } + + var promise = asPromise(fn, null); + promise.then(function() { + test.fail("promise should not be resolved"); + }).catch(function(err) { + test.equal(err, 3, "promise should be rejected with err = 3"); + test.end(); + }); + }); + + test.test(this.name + " - reject and error", function(test) { + + function fn(callback) { + callback(3); + throw 4; + } + + var count = 0; + + var promise = asPromise(fn, null); + promise.then(function() { + test.fail("promise should not be resolved"); + }).catch(function(err) { + test.equal(err, 3, "promise should be rejected with err = 3"); + if (++count > 1) + test.fail("promise should not be rejected twice"); + test.end(); + }); + }); +}); diff --git a/node_modules/@protobufjs/base64/LICENSE b/node_modules/@protobufjs/base64/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/base64/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/base64/README.md b/node_modules/@protobufjs/base64/README.md new file mode 100644 index 0000000..b06cb0a --- /dev/null +++ b/node_modules/@protobufjs/base64/README.md @@ -0,0 +1,19 @@ +@protobufjs/base64 +================== +[![npm](https://img.shields.io/npm/v/@protobufjs/base64.svg)](https://www.npmjs.com/package/@protobufjs/base64) + +A minimal base64 implementation for number arrays. + +API +--- + +* **base64.length(string: `string`): `number`**
+ Calculates the byte length of a base64 encoded string. + +* **base64.encode(buffer: `Uint8Array`, start: `number`, end: `number`): `string`**
+ Encodes a buffer to a base64 encoded string. + +* **base64.decode(string: `string`, buffer: `Uint8Array`, offset: `number`): `number`**
+ Decodes a base64 encoded string to a buffer. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/base64/index.d.ts b/node_modules/@protobufjs/base64/index.d.ts new file mode 100644 index 0000000..085d0a7 --- /dev/null +++ b/node_modules/@protobufjs/base64/index.d.ts @@ -0,0 +1,32 @@ +/** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ +export function length(string: string): number; + +/** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ +export function encode(buffer: Uint8Array, start: number, end: number): string; + +/** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ +export function decode(string: string, buffer: Uint8Array, offset: number): number; + +/** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if it appears to be base64 encoded, otherwise false + */ +export function test(string: string): boolean; diff --git a/node_modules/@protobufjs/base64/index.js b/node_modules/@protobufjs/base64/index.js new file mode 100644 index 0000000..6146f54 --- /dev/null +++ b/node_modules/@protobufjs/base64/index.js @@ -0,0 +1,139 @@ +"use strict"; + +/** + * A minimal base64 implementation for number arrays. + * @memberof util + * @namespace + */ +var base64 = exports; + +/** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ +base64.length = function length(string) { + var p = string.length; + if (!p) + return 0; + var n = 0; + while (--p % 4 > 1 && string.charAt(p) === "=") + ++n; + return Math.ceil(string.length * 3) / 4 - n; +}; + +// Base64 encoding table +var b64 = new Array(64); + +// Base64 decoding table +var s64 = new Array(123); + +// 65..90, 97..122, 48..57, 43, 47 +for (var i = 0; i < 64;) + s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++; + +/** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ +base64.encode = function encode(buffer, start, end) { + var parts = null, + chunk = []; + var i = 0, // output index + j = 0, // goto index + t; // temporary + while (start < end) { + var b = buffer[start++]; + switch (j) { + case 0: + chunk[i++] = b64[b >> 2]; + t = (b & 3) << 4; + j = 1; + break; + case 1: + chunk[i++] = b64[t | b >> 4]; + t = (b & 15) << 2; + j = 2; + break; + case 2: + chunk[i++] = b64[t | b >> 6]; + chunk[i++] = b64[b & 63]; + j = 0; + break; + } + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (j) { + chunk[i++] = b64[t]; + chunk[i++] = 61; + if (j === 1) + chunk[i++] = 61; + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +var invalidEncoding = "invalid encoding"; + +/** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ +base64.decode = function decode(string, buffer, offset) { + var start = offset; + var j = 0, // goto index + t; // temporary + for (var i = 0; i < string.length;) { + var c = string.charCodeAt(i++); + if (c === 61 && j > 1) + break; + if ((c = s64[c]) === undefined) + throw Error(invalidEncoding); + switch (j) { + case 0: + t = c; + j = 1; + break; + case 1: + buffer[offset++] = t << 2 | (c & 48) >> 4; + t = c; + j = 2; + break; + case 2: + buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2; + t = c; + j = 3; + break; + case 3: + buffer[offset++] = (t & 3) << 6 | c; + j = 0; + break; + } + } + if (j === 1) + throw Error(invalidEncoding); + return offset - start; +}; + +/** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if probably base64 encoded, otherwise false + */ +base64.test = function test(string) { + return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string); +}; diff --git a/node_modules/@protobufjs/base64/package.json b/node_modules/@protobufjs/base64/package.json new file mode 100644 index 0000000..0024a13 --- /dev/null +++ b/node_modules/@protobufjs/base64/package.json @@ -0,0 +1,54 @@ +{ + "_from": "@protobufjs/base64@^1.1.2", + "_id": "@protobufjs/base64@1.1.2", + "_inBundle": false, + "_integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==", + "_location": "/@protobufjs/base64", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/base64@^1.1.2", + "name": "@protobufjs/base64", + "escapedName": "@protobufjs%2fbase64", + "scope": "@protobufjs", + "rawSpec": "^1.1.2", + "saveSpec": null, + "fetchSpec": "^1.1.2" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", + "_shasum": "4c85730e59b9a1f1f349047dbf24296034bb2735", + "_spec": "@protobufjs/base64@^1.1.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A minimal base64 implementation for number arrays.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/base64", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.2" +} diff --git a/node_modules/@protobufjs/base64/tests/index.js b/node_modules/@protobufjs/base64/tests/index.js new file mode 100644 index 0000000..6ede32c --- /dev/null +++ b/node_modules/@protobufjs/base64/tests/index.js @@ -0,0 +1,46 @@ +var tape = require("tape"); + +var base64 = require(".."); + +var strings = { + "": "", + "a": "YQ==", + "ab": "YWI=", + "abcdefg": "YWJjZGVmZw==", + "abcdefgh": "YWJjZGVmZ2g=", + "abcdefghi": "YWJjZGVmZ2hp" +}; + +tape.test("base64", function(test) { + + Object.keys(strings).forEach(function(str) { + var enc = strings[str]; + + test.equal(base64.test(enc), true, "should detect '" + enc + "' to be base64 encoded"); + + var len = base64.length(enc); + test.equal(len, str.length, "should calculate '" + enc + "' as " + str.length + " bytes"); + + var buf = new Array(len); + var len2 = base64.decode(enc, buf, 0); + test.equal(len2, len, "should decode '" + enc + "' to " + len + " bytes"); + + test.equal(String.fromCharCode.apply(String, buf), str, "should decode '" + enc + "' to '" + str + "'"); + + var enc2 = base64.encode(buf, 0, buf.length); + test.equal(enc2, enc, "should encode '" + str + "' to '" + enc + "'"); + + }); + + test.throws(function() { + var buf = new Array(10); + base64.decode("YQ!", buf, 0); + }, Error, "should throw if encoding is invalid"); + + test.throws(function() { + var buf = new Array(10); + base64.decode("Y", buf, 0); + }, Error, "should throw if string is truncated"); + + test.end(); +}); diff --git a/node_modules/@protobufjs/codegen/LICENSE b/node_modules/@protobufjs/codegen/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/codegen/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/codegen/README.md b/node_modules/@protobufjs/codegen/README.md new file mode 100644 index 0000000..577c43e --- /dev/null +++ b/node_modules/@protobufjs/codegen/README.md @@ -0,0 +1,49 @@ +@protobufjs/codegen +=================== +[![npm](https://img.shields.io/npm/v/@protobufjs/codegen.svg)](https://www.npmjs.com/package/@protobufjs/codegen) + +A minimalistic code generation utility. + +API +--- + +* **codegen([functionParams: `string[]`], [functionName: string]): `Codegen`**
+ Begins generating a function. + +* **codegen.verbose = `false`**
+ When set to true, codegen will log generated code to console. Useful for debugging. + +Invoking **codegen** returns an appender function that appends code to the function's body and returns itself: + +* **Codegen(formatString: `string`, [...formatParams: `any`]): Codegen**
+ Appends code to the function's body. The format string can contain placeholders specifying the types of inserted format parameters: + + * `%d`: Number (integer or floating point value) + * `%f`: Floating point value + * `%i`: Integer value + * `%j`: JSON.stringify'ed value + * `%s`: String value + * `%%`: Percent sign
+ +* **Codegen([scope: `Object.`]): `Function`**
+ Finishes the function and returns it. + +* **Codegen.toString([functionNameOverride: `string`]): `string`**
+ Returns the function as a string. + +Example +------- + +```js +var codegen = require("@protobufjs/codegen"); + +var add = codegen(["a", "b"], "add") // A function with parameters "a" and "b" named "add" + ("// awesome comment") // adds the line to the function's body + ("return a + b - c + %d", 1) // replaces %d with 1 and adds the line to the body + ({ c: 1 }); // adds "c" with a value of 1 to the function's scope + +console.log(add.toString()); // function add(a, b) { return a + b - c + 1 } +console.log(add(1, 2)); // calculates 1 + 2 - 1 + 1 = 3 +``` + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/codegen/index.d.ts b/node_modules/@protobufjs/codegen/index.d.ts new file mode 100644 index 0000000..f8ed908 --- /dev/null +++ b/node_modules/@protobufjs/codegen/index.d.ts @@ -0,0 +1,31 @@ +export = codegen; + +/** + * Appends code to the function's body. + * @param [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any + * @param [formatParams] Format parameters + * @returns Itself or the generated function if finished + * @throws {Error} If format parameter counts do not match + */ +type Codegen = (formatStringOrScope?: (string|{ [k: string]: any }), ...formatParams: any[]) => (Codegen|Function); + +/** + * Begins generating a function. + * @param functionParams Function parameter names + * @param [functionName] Function name if not anonymous + * @returns Appender that appends code to the function's body + */ +declare function codegen(functionParams: string[], functionName?: string): Codegen; + +/** + * Begins generating a function. + * @param [functionName] Function name if not anonymous + * @returns Appender that appends code to the function's body + */ +declare function codegen(functionName?: string): Codegen; + +declare namespace codegen { + + /** When set to `true`, codegen will log generated code to console. Useful for debugging. */ + let verbose: boolean; +} diff --git a/node_modules/@protobufjs/codegen/index.js b/node_modules/@protobufjs/codegen/index.js new file mode 100644 index 0000000..af005cb --- /dev/null +++ b/node_modules/@protobufjs/codegen/index.js @@ -0,0 +1,99 @@ +"use strict"; +module.exports = codegen; + +/** + * Begins generating a function. + * @memberof util + * @param {string[]} functionParams Function parameter names + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + */ +function codegen(functionParams, functionName) { + + /* istanbul ignore if */ + if (typeof functionParams === "string") { + functionName = functionParams; + functionParams = undefined; + } + + var body = []; + + /** + * Appends code to the function's body or finishes generation. + * @typedef Codegen + * @type {function} + * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any + * @param {...*} [formatParams] Format parameters + * @returns {Codegen|Function} Itself or the generated function if finished + * @throws {Error} If format parameter counts do not match + */ + + function Codegen(formatStringOrScope) { + // note that explicit array handling below makes this ~50% faster + + // finish the function + if (typeof formatStringOrScope !== "string") { + var source = toString(); + if (codegen.verbose) + console.log("codegen: " + source); // eslint-disable-line no-console + source = "return " + source; + if (formatStringOrScope) { + var scopeKeys = Object.keys(formatStringOrScope), + scopeParams = new Array(scopeKeys.length + 1), + scopeValues = new Array(scopeKeys.length), + scopeOffset = 0; + while (scopeOffset < scopeKeys.length) { + scopeParams[scopeOffset] = scopeKeys[scopeOffset]; + scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]]; + } + scopeParams[scopeOffset] = source; + return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func + } + return Function(source)(); // eslint-disable-line no-new-func + } + + // otherwise append to body + var formatParams = new Array(arguments.length - 1), + formatOffset = 0; + while (formatOffset < formatParams.length) + formatParams[formatOffset] = arguments[++formatOffset]; + formatOffset = 0; + formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) { + var value = formatParams[formatOffset++]; + switch ($1) { + case "d": case "f": return String(Number(value)); + case "i": return String(Math.floor(value)); + case "j": return JSON.stringify(value); + case "s": return String(value); + } + return "%"; + }); + if (formatOffset !== formatParams.length) + throw Error("parameter count mismatch"); + body.push(formatStringOrScope); + return Codegen; + } + + function toString(functionNameOverride) { + return "function " + (functionNameOverride || functionName || "") + "(" + (functionParams && functionParams.join(",") || "") + "){\n " + body.join("\n ") + "\n}"; + } + + Codegen.toString = toString; + return Codegen; +} + +/** + * Begins generating a function. + * @memberof util + * @function codegen + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + * @variation 2 + */ + +/** + * When set to `true`, codegen will log generated code to console. Useful for debugging. + * @name util.codegen.verbose + * @type {boolean} + */ +codegen.verbose = false; diff --git a/node_modules/@protobufjs/codegen/package.json b/node_modules/@protobufjs/codegen/package.json new file mode 100644 index 0000000..6c680d1 --- /dev/null +++ b/node_modules/@protobufjs/codegen/package.json @@ -0,0 +1,46 @@ +{ + "_from": "@protobufjs/codegen@^2.0.4", + "_id": "@protobufjs/codegen@2.0.4", + "_inBundle": false, + "_integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==", + "_location": "/@protobufjs/codegen", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/codegen@^2.0.4", + "name": "@protobufjs/codegen", + "escapedName": "@protobufjs%2fcodegen", + "scope": "@protobufjs", + "rawSpec": "^2.0.4", + "saveSpec": null, + "fetchSpec": "^2.0.4" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", + "_shasum": "7ef37f0d010fb028ad1ad59722e506d9262815cb", + "_spec": "@protobufjs/codegen@^2.0.4", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A minimalistic code generation utility.", + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/codegen", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "types": "index.d.ts", + "version": "2.0.4" +} diff --git a/node_modules/@protobufjs/codegen/tests/index.js b/node_modules/@protobufjs/codegen/tests/index.js new file mode 100644 index 0000000..b189117 --- /dev/null +++ b/node_modules/@protobufjs/codegen/tests/index.js @@ -0,0 +1,13 @@ +var codegen = require(".."); + +// new require("benchmark").Suite().add("add", function() { + +var add = codegen(["a", "b"], "add") + ("// awesome comment") + ("return a + b - c + %d", 1) + ({ c: 1 }); + +if (add(1, 2) !== 3) + throw Error("failed"); + +// }).on("cycle", function(event) { process.stdout.write(String(event.target) + "\n"); }).run(); diff --git a/node_modules/@protobufjs/eventemitter/LICENSE b/node_modules/@protobufjs/eventemitter/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/eventemitter/README.md b/node_modules/@protobufjs/eventemitter/README.md new file mode 100644 index 0000000..528e725 --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/README.md @@ -0,0 +1,22 @@ +@protobufjs/eventemitter +======================== +[![npm](https://img.shields.io/npm/v/@protobufjs/eventemitter.svg)](https://www.npmjs.com/package/@protobufjs/eventemitter) + +A minimal event emitter. + +API +--- + +* **new EventEmitter()**
+ Constructs a new event emitter instance. + +* **EventEmitter#on(evt: `string`, fn: `function`, [ctx: `Object`]): `EventEmitter`**
+ Registers an event listener. + +* **EventEmitter#off([evt: `string`], [fn: `function`]): `EventEmitter`**
+ Removes an event listener or any matching listeners if arguments are omitted. + +* **EventEmitter#emit(evt: `string`, ...args: `*`): `EventEmitter`**
+ Emits an event by calling its listeners with the specified arguments. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/eventemitter/index.d.ts b/node_modules/@protobufjs/eventemitter/index.d.ts new file mode 100644 index 0000000..f177823 --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/index.d.ts @@ -0,0 +1,43 @@ +export = EventEmitter; + +/** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ +declare class EventEmitter { + + /** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ + constructor(); + + /** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ + on(evt: string, fn: () => any, ctx?: any): EventEmitter; + + /** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ + off(evt?: string, fn?: () => any): EventEmitter; + + /** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ + emit(evt: string, ...args: any[]): EventEmitter; +} diff --git a/node_modules/@protobufjs/eventemitter/index.js b/node_modules/@protobufjs/eventemitter/index.js new file mode 100644 index 0000000..f766fd0 --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/index.js @@ -0,0 +1,76 @@ +"use strict"; +module.exports = EventEmitter; + +/** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ +function EventEmitter() { + + /** + * Registered listeners. + * @type {Object.} + * @private + */ + this._listeners = {}; +} + +/** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.on = function on(evt, fn, ctx) { + (this._listeners[evt] || (this._listeners[evt] = [])).push({ + fn : fn, + ctx : ctx || this + }); + return this; +}; + +/** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.off = function off(evt, fn) { + if (evt === undefined) + this._listeners = {}; + else { + if (fn === undefined) + this._listeners[evt] = []; + else { + var listeners = this._listeners[evt]; + for (var i = 0; i < listeners.length;) + if (listeners[i].fn === fn) + listeners.splice(i, 1); + else + ++i; + } + } + return this; +}; + +/** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.emit = function emit(evt) { + var listeners = this._listeners[evt]; + if (listeners) { + var args = [], + i = 1; + for (; i < arguments.length;) + args.push(arguments[i++]); + for (i = 0; i < listeners.length;) + listeners[i].fn.apply(listeners[i++].ctx, args); + } + return this; +}; diff --git a/node_modules/@protobufjs/eventemitter/package.json b/node_modules/@protobufjs/eventemitter/package.json new file mode 100644 index 0000000..98354ed --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/package.json @@ -0,0 +1,54 @@ +{ + "_from": "@protobufjs/eventemitter@^1.1.0", + "_id": "@protobufjs/eventemitter@1.1.0", + "_inBundle": false, + "_integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=", + "_location": "/@protobufjs/eventemitter", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/eventemitter@^1.1.0", + "name": "@protobufjs/eventemitter", + "escapedName": "@protobufjs%2feventemitter", + "scope": "@protobufjs", + "rawSpec": "^1.1.0", + "saveSpec": null, + "fetchSpec": "^1.1.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", + "_shasum": "355cbc98bafad5978f9ed095f397621f1d066b70", + "_spec": "@protobufjs/eventemitter@^1.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A minimal event emitter.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/eventemitter", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.0" +} diff --git a/node_modules/@protobufjs/eventemitter/tests/index.js b/node_modules/@protobufjs/eventemitter/tests/index.js new file mode 100644 index 0000000..390958f --- /dev/null +++ b/node_modules/@protobufjs/eventemitter/tests/index.js @@ -0,0 +1,47 @@ +var tape = require("tape"); + +var EventEmitter = require(".."); + +tape.test("eventemitter", function(test) { + + var ee = new EventEmitter(); + var fn; + var ctx = {}; + + test.doesNotThrow(function() { + ee.emit("a", 1); + ee.off(); + ee.off("a"); + ee.off("a", function() {}); + }, "should not throw if no listeners are registered"); + + test.equal(ee.on("a", function(arg1) { + test.equal(this, ctx, "should be called with this = ctx"); + test.equal(arg1, 1, "should be called with arg1 = 1"); + }, ctx), ee, "should return itself when registering events"); + ee.emit("a", 1); + + ee.off("a"); + test.same(ee._listeners, { a: [] }, "should remove all listeners of the respective event when calling off(evt)"); + + ee.off(); + test.same(ee._listeners, {}, "should remove all listeners when just calling off()"); + + ee.on("a", fn = function(arg1) { + test.equal(this, ctx, "should be called with this = ctx"); + test.equal(arg1, 1, "should be called with arg1 = 1"); + }, ctx).emit("a", 1); + + ee.off("a", fn); + test.same(ee._listeners, { a: [] }, "should remove the exact listener when calling off(evt, fn)"); + + ee.on("a", function() { + test.equal(this, ee, "should be called with this = ee"); + }).emit("a"); + + test.doesNotThrow(function() { + ee.off("a", fn); + }, "should not throw if no such listener is found"); + + test.end(); +}); diff --git a/node_modules/@protobufjs/fetch/LICENSE b/node_modules/@protobufjs/fetch/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/fetch/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/fetch/README.md b/node_modules/@protobufjs/fetch/README.md new file mode 100644 index 0000000..1ebf4d4 --- /dev/null +++ b/node_modules/@protobufjs/fetch/README.md @@ -0,0 +1,13 @@ +@protobufjs/fetch +================= +[![npm](https://img.shields.io/npm/v/@protobufjs/fetch.svg)](https://www.npmjs.com/package/@protobufjs/fetch) + +Fetches the contents of a file accross node and browsers. + +API +--- + +* **fetch(path: `string`, [options: { binary: boolean } ], [callback: `function(error: ?Error, [contents: string])`]): `Promise|undefined`** + Fetches the contents of a file. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/fetch/index.d.ts b/node_modules/@protobufjs/fetch/index.d.ts new file mode 100644 index 0000000..ab0820c --- /dev/null +++ b/node_modules/@protobufjs/fetch/index.d.ts @@ -0,0 +1,56 @@ +export = fetch; + +/** + * Node-style callback as used by {@link util.fetch}. + * @typedef FetchCallback + * @type {function} + * @param {?Error} error Error, if any, otherwise `null` + * @param {string} [contents] File contents, if there hasn't been an error + * @returns {undefined} + */ +type FetchCallback = (error: Error, contents?: string) => void; + +/** + * Options as used by {@link util.fetch}. + * @typedef FetchOptions + * @type {Object} + * @property {boolean} [binary=false] Whether expecting a binary response + * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest + */ + +interface FetchOptions { + binary?: boolean; + xhr?: boolean +} + +/** + * Fetches the contents of a file. + * @memberof util + * @param {string} filename File path or url + * @param {FetchOptions} options Fetch options + * @param {FetchCallback} callback Callback function + * @returns {undefined} + */ +declare function fetch(filename: string, options: FetchOptions, callback: FetchCallback): void; + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ +declare function fetch(path: string, callback: FetchCallback): void; + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchOptions} [options] Fetch options + * @returns {Promise} Promise + * @variation 3 + */ +declare function fetch(path: string, options?: FetchOptions): Promise<(string|Uint8Array)>; diff --git a/node_modules/@protobufjs/fetch/index.js b/node_modules/@protobufjs/fetch/index.js new file mode 100644 index 0000000..d92aa68 --- /dev/null +++ b/node_modules/@protobufjs/fetch/index.js @@ -0,0 +1,115 @@ +"use strict"; +module.exports = fetch; + +var asPromise = require("@protobufjs/aspromise"), + inquire = require("@protobufjs/inquire"); + +var fs = inquire("fs"); + +/** + * Node-style callback as used by {@link util.fetch}. + * @typedef FetchCallback + * @type {function} + * @param {?Error} error Error, if any, otherwise `null` + * @param {string} [contents] File contents, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Options as used by {@link util.fetch}. + * @typedef FetchOptions + * @type {Object} + * @property {boolean} [binary=false] Whether expecting a binary response + * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest + */ + +/** + * Fetches the contents of a file. + * @memberof util + * @param {string} filename File path or url + * @param {FetchOptions} options Fetch options + * @param {FetchCallback} callback Callback function + * @returns {undefined} + */ +function fetch(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = {}; + } else if (!options) + options = {}; + + if (!callback) + return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this + + // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found. + if (!options.xhr && fs && fs.readFile) + return fs.readFile(filename, function fetchReadFileCallback(err, contents) { + return err && typeof XMLHttpRequest !== "undefined" + ? fetch.xhr(filename, options, callback) + : err + ? callback(err) + : callback(null, options.binary ? contents : contents.toString("utf8")); + }); + + // use the XHR version otherwise. + return fetch.xhr(filename, options, callback); +} + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchOptions} [options] Fetch options + * @returns {Promise} Promise + * @variation 3 + */ + +/**/ +fetch.xhr = function fetch_xhr(filename, options, callback) { + var xhr = new XMLHttpRequest(); + xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() { + + if (xhr.readyState !== 4) + return undefined; + + // local cors security errors return status 0 / empty string, too. afaik this cannot be + // reliably distinguished from an actually empty file for security reasons. feel free + // to send a pull request if you are aware of a solution. + if (xhr.status !== 0 && xhr.status !== 200) + return callback(Error("status " + xhr.status)); + + // if binary data is expected, make sure that some sort of array is returned, even if + // ArrayBuffers are not supported. the binary string fallback, however, is unsafe. + if (options.binary) { + var buffer = xhr.response; + if (!buffer) { + buffer = []; + for (var i = 0; i < xhr.responseText.length; ++i) + buffer.push(xhr.responseText.charCodeAt(i) & 255); + } + return callback(null, typeof Uint8Array !== "undefined" ? new Uint8Array(buffer) : buffer); + } + return callback(null, xhr.responseText); + }; + + if (options.binary) { + // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers + if ("overrideMimeType" in xhr) + xhr.overrideMimeType("text/plain; charset=x-user-defined"); + xhr.responseType = "arraybuffer"; + } + + xhr.open("GET", filename); + xhr.send(); +}; diff --git a/node_modules/@protobufjs/fetch/package.json b/node_modules/@protobufjs/fetch/package.json new file mode 100644 index 0000000..781ea6f --- /dev/null +++ b/node_modules/@protobufjs/fetch/package.json @@ -0,0 +1,58 @@ +{ + "_from": "@protobufjs/fetch@^1.1.0", + "_id": "@protobufjs/fetch@1.1.0", + "_inBundle": false, + "_integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", + "_location": "/@protobufjs/fetch", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/fetch@^1.1.0", + "name": "@protobufjs/fetch", + "escapedName": "@protobufjs%2ffetch", + "scope": "@protobufjs", + "rawSpec": "^1.1.0", + "saveSpec": null, + "fetchSpec": "^1.1.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", + "_shasum": "ba99fb598614af65700c1619ff06d454b0d84c45", + "_spec": "@protobufjs/fetch@^1.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "dependencies": { + "@protobufjs/aspromise": "^1.1.1", + "@protobufjs/inquire": "^1.1.0" + }, + "deprecated": false, + "description": "Fetches the contents of a file accross node and browsers.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/fetch", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.0" +} diff --git a/node_modules/@protobufjs/fetch/tests/index.js b/node_modules/@protobufjs/fetch/tests/index.js new file mode 100644 index 0000000..b7fbf81 --- /dev/null +++ b/node_modules/@protobufjs/fetch/tests/index.js @@ -0,0 +1,16 @@ +var tape = require("tape"); + +var fetch = require(".."); + +tape.test("fetch", function(test) { + + if (typeof Promise !== "undefined") { + var promise = fetch("NOTFOUND"); + promise.catch(function() {}); + test.ok(promise instanceof Promise, "should return a promise if callback has been omitted"); + } + + // TODO - some way to test this properly? + + test.end(); +}); diff --git a/node_modules/@protobufjs/float/LICENSE b/node_modules/@protobufjs/float/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/float/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/float/README.md b/node_modules/@protobufjs/float/README.md new file mode 100644 index 0000000..e475fc9 --- /dev/null +++ b/node_modules/@protobufjs/float/README.md @@ -0,0 +1,102 @@ +@protobufjs/float +================= +[![npm](https://img.shields.io/npm/v/@protobufjs/float.svg)](https://www.npmjs.com/package/@protobufjs/float) + +Reads / writes floats / doubles from / to buffers in both modern and ancient browsers. Fast. + +API +--- + +* **writeFloatLE(val: `number`, buf: `Uint8Array`, pos: `number`)**
+ Writes a 32 bit float to a buffer using little endian byte order. + +* **writeFloatBE(val: `number`, buf: `Uint8Array`, pos: `number`)**
+ Writes a 32 bit float to a buffer using big endian byte order. + +* **readFloatLE(buf: `Uint8Array`, pos: `number`): `number`**
+ Reads a 32 bit float from a buffer using little endian byte order. + +* **readFloatBE(buf: `Uint8Array`, pos: `number`): `number`**
+ Reads a 32 bit float from a buffer using big endian byte order. + +* **writeDoubleLE(val: `number`, buf: `Uint8Array`, pos: `number`)**
+ Writes a 64 bit double to a buffer using little endian byte order. + +* **writeDoubleBE(val: `number`, buf: `Uint8Array`, pos: `number`)**
+ Writes a 64 bit double to a buffer using big endian byte order. + +* **readDoubleLE(buf: `Uint8Array`, pos: `number`): `number`**
+ Reads a 64 bit double from a buffer using little endian byte order. + +* **readDoubleBE(buf: `Uint8Array`, pos: `number`): `number`**
+ Reads a 64 bit double from a buffer using big endian byte order. + +Performance +----------- +There is a simple benchmark included comparing raw read/write performance of this library (float), float's fallback for old browsers, the [ieee754](https://www.npmjs.com/package/ieee754) module and node's [buffer](https://nodejs.org/api/buffer.html). On an i7-2600k running node 6.9.1 it yields: + +``` +benchmarking writeFloat performance ... + +float x 42,741,625 ops/sec ±1.75% (81 runs sampled) +float (fallback) x 11,272,532 ops/sec ±1.12% (85 runs sampled) +ieee754 x 8,653,337 ops/sec ±1.18% (84 runs sampled) +buffer x 12,412,414 ops/sec ±1.41% (83 runs sampled) +buffer (noAssert) x 13,471,149 ops/sec ±1.09% (84 runs sampled) + + float was fastest + float (fallback) was 73.5% slower + ieee754 was 79.6% slower + buffer was 70.9% slower + buffer (noAssert) was 68.3% slower + +benchmarking readFloat performance ... + +float x 44,382,729 ops/sec ±1.70% (84 runs sampled) +float (fallback) x 20,925,938 ops/sec ±0.86% (87 runs sampled) +ieee754 x 17,189,009 ops/sec ±1.01% (87 runs sampled) +buffer x 10,518,437 ops/sec ±1.04% (83 runs sampled) +buffer (noAssert) x 11,031,636 ops/sec ±1.15% (87 runs sampled) + + float was fastest + float (fallback) was 52.5% slower + ieee754 was 61.0% slower + buffer was 76.1% slower + buffer (noAssert) was 75.0% slower + +benchmarking writeDouble performance ... + +float x 38,624,906 ops/sec ±0.93% (83 runs sampled) +float (fallback) x 10,457,811 ops/sec ±1.54% (85 runs sampled) +ieee754 x 7,681,130 ops/sec ±1.11% (83 runs sampled) +buffer x 12,657,876 ops/sec ±1.03% (83 runs sampled) +buffer (noAssert) x 13,372,795 ops/sec ±0.84% (85 runs sampled) + + float was fastest + float (fallback) was 73.1% slower + ieee754 was 80.1% slower + buffer was 67.3% slower + buffer (noAssert) was 65.3% slower + +benchmarking readDouble performance ... + +float x 40,527,888 ops/sec ±1.05% (84 runs sampled) +float (fallback) x 18,696,480 ops/sec ±0.84% (86 runs sampled) +ieee754 x 14,074,028 ops/sec ±1.04% (87 runs sampled) +buffer x 10,092,367 ops/sec ±1.15% (84 runs sampled) +buffer (noAssert) x 10,623,793 ops/sec ±0.96% (84 runs sampled) + + float was fastest + float (fallback) was 53.8% slower + ieee754 was 65.3% slower + buffer was 75.1% slower + buffer (noAssert) was 73.8% slower +``` + +To run it yourself: + +``` +$> npm run bench +``` + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/float/bench/index.js b/node_modules/@protobufjs/float/bench/index.js new file mode 100644 index 0000000..911f461 --- /dev/null +++ b/node_modules/@protobufjs/float/bench/index.js @@ -0,0 +1,87 @@ +"use strict"; + +var float = require(".."), + ieee754 = require("ieee754"), + newSuite = require("./suite"); + +var F32 = Float32Array; +var F64 = Float64Array; +delete global.Float32Array; +delete global.Float64Array; +var floatFallback = float({}); +global.Float32Array = F32; +global.Float64Array = F64; + +var buf = new Buffer(8); + +newSuite("writeFloat") +.add("float", function() { + float.writeFloatLE(0.1, buf, 0); +}) +.add("float (fallback)", function() { + floatFallback.writeFloatLE(0.1, buf, 0); +}) +.add("ieee754", function() { + ieee754.write(buf, 0.1, 0, true, 23, 4); +}) +.add("buffer", function() { + buf.writeFloatLE(0.1, 0); +}) +.add("buffer (noAssert)", function() { + buf.writeFloatLE(0.1, 0, true); +}) +.run(); + +newSuite("readFloat") +.add("float", function() { + float.readFloatLE(buf, 0); +}) +.add("float (fallback)", function() { + floatFallback.readFloatLE(buf, 0); +}) +.add("ieee754", function() { + ieee754.read(buf, 0, true, 23, 4); +}) +.add("buffer", function() { + buf.readFloatLE(0); +}) +.add("buffer (noAssert)", function() { + buf.readFloatLE(0, true); +}) +.run(); + +newSuite("writeDouble") +.add("float", function() { + float.writeDoubleLE(0.1, buf, 0); +}) +.add("float (fallback)", function() { + floatFallback.writeDoubleLE(0.1, buf, 0); +}) +.add("ieee754", function() { + ieee754.write(buf, 0.1, 0, true, 52, 8); +}) +.add("buffer", function() { + buf.writeDoubleLE(0.1, 0); +}) +.add("buffer (noAssert)", function() { + buf.writeDoubleLE(0.1, 0, true); +}) +.run(); + +newSuite("readDouble") +.add("float", function() { + float.readDoubleLE(buf, 0); +}) +.add("float (fallback)", function() { + floatFallback.readDoubleLE(buf, 0); +}) +.add("ieee754", function() { + ieee754.read(buf, 0, true, 52, 8); +}) +.add("buffer", function() { + buf.readDoubleLE(0); +}) +.add("buffer (noAssert)", function() { + buf.readDoubleLE(0, true); +}) +.run(); diff --git a/node_modules/@protobufjs/float/bench/suite.js b/node_modules/@protobufjs/float/bench/suite.js new file mode 100644 index 0000000..e8016d2 --- /dev/null +++ b/node_modules/@protobufjs/float/bench/suite.js @@ -0,0 +1,46 @@ +"use strict"; +module.exports = newSuite; + +var benchmark = require("benchmark"), + chalk = require("chalk"); + +var padSize = 27; + +function newSuite(name) { + var benches = []; + return new benchmark.Suite(name) + .on("add", function(event) { + benches.push(event.target); + }) + .on("start", function() { + process.stdout.write("benchmarking " + name + " performance ...\n\n"); + }) + .on("cycle", function(event) { + process.stdout.write(String(event.target) + "\n"); + }) + .on("complete", function() { + if (benches.length > 1) { + var fastest = this.filter("fastest"), // eslint-disable-line no-invalid-this + fastestHz = getHz(fastest[0]); + process.stdout.write("\n" + chalk.white(pad(fastest[0].name, padSize)) + " was " + chalk.green("fastest") + "\n"); + benches.forEach(function(bench) { + if (fastest.indexOf(bench) === 0) + return; + var hz = hz = getHz(bench); + var percent = (1 - hz / fastestHz) * 100; + process.stdout.write(chalk.white(pad(bench.name, padSize)) + " was " + chalk.red(percent.toFixed(1) + "% slower") + "\n"); + }); + } + process.stdout.write("\n"); + }); +} + +function getHz(bench) { + return 1 / (bench.stats.mean + bench.stats.moe); +} + +function pad(str, len, l) { + while (str.length < len) + str = l ? str + " " : " " + str; + return str; +} diff --git a/node_modules/@protobufjs/float/index.d.ts b/node_modules/@protobufjs/float/index.d.ts new file mode 100644 index 0000000..ab05de3 --- /dev/null +++ b/node_modules/@protobufjs/float/index.d.ts @@ -0,0 +1,83 @@ +/** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ +export function writeFloatLE(val: number, buf: Uint8Array, pos: number): void; + +/** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ +export function writeFloatBE(val: number, buf: Uint8Array, pos: number): void; + +/** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ +export function readFloatLE(buf: Uint8Array, pos: number): number; + +/** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ +export function readFloatBE(buf: Uint8Array, pos: number): number; + +/** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ +export function writeDoubleLE(val: number, buf: Uint8Array, pos: number): void; + +/** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ +export function writeDoubleBE(val: number, buf: Uint8Array, pos: number): void; + +/** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ +export function readDoubleLE(buf: Uint8Array, pos: number): number; + +/** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ +export function readDoubleBE(buf: Uint8Array, pos: number): number; diff --git a/node_modules/@protobufjs/float/index.js b/node_modules/@protobufjs/float/index.js new file mode 100644 index 0000000..52ba3aa --- /dev/null +++ b/node_modules/@protobufjs/float/index.js @@ -0,0 +1,335 @@ +"use strict"; + +module.exports = factory(factory); + +/** + * Reads / writes floats / doubles from / to buffers. + * @name util.float + * @namespace + */ + +/** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name util.float.writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name util.float.writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name util.float.readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name util.float.readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name util.float.writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name util.float.writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name util.float.readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name util.float.readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +// Factory function for the purpose of node-based testing in modified global environments +function factory(exports) { + + // float: typed array + if (typeof Float32Array !== "undefined") (function() { + + var f32 = new Float32Array([ -0 ]), + f8b = new Uint8Array(f32.buffer), + le = f8b[3] === 128; + + function writeFloat_f32_cpy(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + } + + function writeFloat_f32_rev(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[3]; + buf[pos + 1] = f8b[2]; + buf[pos + 2] = f8b[1]; + buf[pos + 3] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev; + /* istanbul ignore next */ + exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy; + + function readFloat_f32_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + return f32[0]; + } + + function readFloat_f32_rev(buf, pos) { + f8b[3] = buf[pos ]; + f8b[2] = buf[pos + 1]; + f8b[1] = buf[pos + 2]; + f8b[0] = buf[pos + 3]; + return f32[0]; + } + + /* istanbul ignore next */ + exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev; + /* istanbul ignore next */ + exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy; + + // float: ieee754 + })(); else (function() { + + function writeFloat_ieee754(writeUint, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos); + else if (isNaN(val)) + writeUint(2143289344, buf, pos); + else if (val > 3.4028234663852886e+38) // +-Infinity + writeUint((sign << 31 | 2139095040) >>> 0, buf, pos); + else if (val < 1.1754943508222875e-38) // denormal + writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos); + else { + var exponent = Math.floor(Math.log(val) / Math.LN2), + mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607; + writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos); + } + } + + exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE); + exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE); + + function readFloat_ieee754(readUint, buf, pos) { + var uint = readUint(buf, pos), + sign = (uint >> 31) * 2 + 1, + exponent = uint >>> 23 & 255, + mantissa = uint & 8388607; + return exponent === 255 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 1.401298464324817e-45 * mantissa + : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608); + } + + exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE); + exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE); + + })(); + + // double: typed array + if (typeof Float64Array !== "undefined") (function() { + + var f64 = new Float64Array([-0]), + f8b = new Uint8Array(f64.buffer), + le = f8b[7] === 128; + + function writeDouble_f64_cpy(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + buf[pos + 4] = f8b[4]; + buf[pos + 5] = f8b[5]; + buf[pos + 6] = f8b[6]; + buf[pos + 7] = f8b[7]; + } + + function writeDouble_f64_rev(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[7]; + buf[pos + 1] = f8b[6]; + buf[pos + 2] = f8b[5]; + buf[pos + 3] = f8b[4]; + buf[pos + 4] = f8b[3]; + buf[pos + 5] = f8b[2]; + buf[pos + 6] = f8b[1]; + buf[pos + 7] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev; + /* istanbul ignore next */ + exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy; + + function readDouble_f64_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + f8b[4] = buf[pos + 4]; + f8b[5] = buf[pos + 5]; + f8b[6] = buf[pos + 6]; + f8b[7] = buf[pos + 7]; + return f64[0]; + } + + function readDouble_f64_rev(buf, pos) { + f8b[7] = buf[pos ]; + f8b[6] = buf[pos + 1]; + f8b[5] = buf[pos + 2]; + f8b[4] = buf[pos + 3]; + f8b[3] = buf[pos + 4]; + f8b[2] = buf[pos + 5]; + f8b[1] = buf[pos + 6]; + f8b[0] = buf[pos + 7]; + return f64[0]; + } + + /* istanbul ignore next */ + exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev; + /* istanbul ignore next */ + exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy; + + // double: ieee754 + })(); else (function() { + + function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) { + writeUint(0, buf, pos + off0); + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1); + } else if (isNaN(val)) { + writeUint(0, buf, pos + off0); + writeUint(2146959360, buf, pos + off1); + } else if (val > 1.7976931348623157e+308) { // +-Infinity + writeUint(0, buf, pos + off0); + writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1); + } else { + var mantissa; + if (val < 2.2250738585072014e-308) { // denormal + mantissa = val / 5e-324; + writeUint(mantissa >>> 0, buf, pos + off0); + writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1); + } else { + var exponent = Math.floor(Math.log(val) / Math.LN2); + if (exponent === 1024) + exponent = 1023; + mantissa = val * Math.pow(2, -exponent); + writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0); + writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1); + } + } + } + + exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4); + exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0); + + function readDouble_ieee754(readUint, off0, off1, buf, pos) { + var lo = readUint(buf, pos + off0), + hi = readUint(buf, pos + off1); + var sign = (hi >> 31) * 2 + 1, + exponent = hi >>> 20 & 2047, + mantissa = 4294967296 * (hi & 1048575) + lo; + return exponent === 2047 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 5e-324 * mantissa + : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496); + } + + exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4); + exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0); + + })(); + + return exports; +} + +// uint helpers + +function writeUintLE(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +function writeUintBE(val, buf, pos) { + buf[pos ] = val >>> 24; + buf[pos + 1] = val >>> 16 & 255; + buf[pos + 2] = val >>> 8 & 255; + buf[pos + 3] = val & 255; +} + +function readUintLE(buf, pos) { + return (buf[pos ] + | buf[pos + 1] << 8 + | buf[pos + 2] << 16 + | buf[pos + 3] << 24) >>> 0; +} + +function readUintBE(buf, pos) { + return (buf[pos ] << 24 + | buf[pos + 1] << 16 + | buf[pos + 2] << 8 + | buf[pos + 3]) >>> 0; +} diff --git a/node_modules/@protobufjs/float/package.json b/node_modules/@protobufjs/float/package.json new file mode 100644 index 0000000..4c01526 --- /dev/null +++ b/node_modules/@protobufjs/float/package.json @@ -0,0 +1,59 @@ +{ + "_from": "@protobufjs/float@^1.0.2", + "_id": "@protobufjs/float@1.0.2", + "_inBundle": false, + "_integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=", + "_location": "/@protobufjs/float", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/float@^1.0.2", + "name": "@protobufjs/float", + "escapedName": "@protobufjs%2ffloat", + "scope": "@protobufjs", + "rawSpec": "^1.0.2", + "saveSpec": null, + "fetchSpec": "^1.0.2" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", + "_shasum": "5e9e1abdcb73fc0a7cb8b291df78c8cbd97b87d1", + "_spec": "@protobufjs/float@^1.0.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "dependencies": {}, + "deprecated": false, + "description": "Reads / writes floats / doubles from / to buffers in both modern and ancient browsers.", + "devDependencies": { + "benchmark": "^2.1.4", + "chalk": "^1.1.3", + "ieee754": "^1.1.8", + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/float", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "bench": "node bench", + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.0.2" +} diff --git a/node_modules/@protobufjs/float/tests/index.js b/node_modules/@protobufjs/float/tests/index.js new file mode 100644 index 0000000..62f0827 --- /dev/null +++ b/node_modules/@protobufjs/float/tests/index.js @@ -0,0 +1,100 @@ +var tape = require("tape"); + +var float = require(".."); + +tape.test("float", function(test) { + + // default + test.test(test.name + " - typed array", function(test) { + runTest(float, test); + }); + + // ieee754 + test.test(test.name + " - fallback", function(test) { + var F32 = global.Float32Array, + F64 = global.Float64Array; + delete global.Float32Array; + delete global.Float64Array; + runTest(float({}), test); + global.Float32Array = F32; + global.Float64Array = F64; + }); +}); + +function runTest(float, test) { + + var common = [ + 0, + -0, + Infinity, + -Infinity, + 0.125, + 1024.5, + -4096.5, + NaN + ]; + + test.test(test.name + " - using 32 bits", function(test) { + common.concat([ + 3.4028234663852886e+38, + 1.1754943508222875e-38, + 1.1754946310819804e-39 + ]) + .forEach(function(value) { + var strval = value === 0 && 1 / value < 0 ? "-0" : value.toString(); + test.ok( + checkValue(value, 4, float.readFloatLE, float.writeFloatLE, Buffer.prototype.writeFloatLE), + "should write and read back " + strval + " (32 bit LE)" + ); + test.ok( + checkValue(value, 4, float.readFloatBE, float.writeFloatBE, Buffer.prototype.writeFloatBE), + "should write and read back " + strval + " (32 bit BE)" + ); + }); + test.end(); + }); + + test.test(test.name + " - using 64 bits", function(test) { + common.concat([ + 1.7976931348623157e+308, + 2.2250738585072014e-308, + 2.2250738585072014e-309 + ]) + .forEach(function(value) { + var strval = value === 0 && 1 / value < 0 ? "-0" : value.toString(); + test.ok( + checkValue(value, 8, float.readDoubleLE, float.writeDoubleLE, Buffer.prototype.writeDoubleLE), + "should write and read back " + strval + " (64 bit LE)" + ); + test.ok( + checkValue(value, 8, float.readDoubleBE, float.writeDoubleBE, Buffer.prototype.writeDoubleBE), + "should write and read back " + strval + " (64 bit BE)" + ); + }); + test.end(); + }); + + test.end(); +} + +function checkValue(value, size, read, write, write_comp) { + var buffer = new Buffer(size); + write(value, buffer, 0); + var value_comp = read(buffer, 0); + var strval = value === 0 && 1 / value < 0 ? "-0" : value.toString(); + if (value !== value) { + if (value_comp === value_comp) + return false; + } else if (value_comp !== value) + return false; + + var buffer_comp = new Buffer(size); + write_comp.call(buffer_comp, value, 0); + for (var i = 0; i < size; ++i) + if (buffer[i] !== buffer_comp[i]) { + console.error(">", buffer, buffer_comp); + return false; + } + + return true; +} \ No newline at end of file diff --git a/node_modules/@protobufjs/inquire/.npmignore b/node_modules/@protobufjs/inquire/.npmignore new file mode 100644 index 0000000..c3fc82e --- /dev/null +++ b/node_modules/@protobufjs/inquire/.npmignore @@ -0,0 +1,3 @@ +npm-debug.* +node_modules/ +coverage/ diff --git a/node_modules/@protobufjs/inquire/LICENSE b/node_modules/@protobufjs/inquire/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/inquire/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/inquire/README.md b/node_modules/@protobufjs/inquire/README.md new file mode 100644 index 0000000..3eabd86 --- /dev/null +++ b/node_modules/@protobufjs/inquire/README.md @@ -0,0 +1,13 @@ +@protobufjs/inquire +=================== +[![npm](https://img.shields.io/npm/v/@protobufjs/inquire.svg)](https://www.npmjs.com/package/@protobufjs/inquire) + +Requires a module only if available and hides the require call from bundlers. + +API +--- + +* **inquire(moduleName: `string`): `?Object`**
+ Requires a module only if available. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/inquire/index.d.ts b/node_modules/@protobufjs/inquire/index.d.ts new file mode 100644 index 0000000..1f5a865 --- /dev/null +++ b/node_modules/@protobufjs/inquire/index.d.ts @@ -0,0 +1,9 @@ +export = inquire; + +/** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ +declare function inquire(moduleName: string): Object; diff --git a/node_modules/@protobufjs/inquire/index.js b/node_modules/@protobufjs/inquire/index.js new file mode 100644 index 0000000..1a1f238 --- /dev/null +++ b/node_modules/@protobufjs/inquire/index.js @@ -0,0 +1,17 @@ +"use strict"; +module.exports = inquire; + +/** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ +function inquire(moduleName) { + try { + var mod = eval("quire".replace(/^/,"re"))(moduleName); // eslint-disable-line no-eval + if (mod && (mod.length || Object.keys(mod).length)) + return mod; + } catch (e) {} // eslint-disable-line no-empty + return null; +} diff --git a/node_modules/@protobufjs/inquire/package.json b/node_modules/@protobufjs/inquire/package.json new file mode 100644 index 0000000..2dab709 --- /dev/null +++ b/node_modules/@protobufjs/inquire/package.json @@ -0,0 +1,55 @@ +{ + "_from": "@protobufjs/inquire@^1.1.0", + "_id": "@protobufjs/inquire@1.1.0", + "_inBundle": false, + "_integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=", + "_location": "/@protobufjs/inquire", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/inquire@^1.1.0", + "name": "@protobufjs/inquire", + "escapedName": "@protobufjs%2finquire", + "scope": "@protobufjs", + "rawSpec": "^1.1.0", + "saveSpec": null, + "fetchSpec": "^1.1.0" + }, + "_requiredBy": [ + "/@protobufjs/fetch", + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", + "_shasum": "ff200e3e7cf2429e2dcafc1140828e8cc638f089", + "_spec": "@protobufjs/inquire@^1.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "Requires a module only if available and hides the require call from bundlers.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/inquire", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.0" +} diff --git a/node_modules/@protobufjs/inquire/tests/data/array.js b/node_modules/@protobufjs/inquire/tests/data/array.js new file mode 100644 index 0000000..0847b28 --- /dev/null +++ b/node_modules/@protobufjs/inquire/tests/data/array.js @@ -0,0 +1 @@ +module.exports = [1]; diff --git a/node_modules/@protobufjs/inquire/tests/data/emptyArray.js b/node_modules/@protobufjs/inquire/tests/data/emptyArray.js new file mode 100644 index 0000000..e0a30c5 --- /dev/null +++ b/node_modules/@protobufjs/inquire/tests/data/emptyArray.js @@ -0,0 +1 @@ +module.exports = []; diff --git a/node_modules/@protobufjs/inquire/tests/data/emptyObject.js b/node_modules/@protobufjs/inquire/tests/data/emptyObject.js new file mode 100644 index 0000000..f053ebf --- /dev/null +++ b/node_modules/@protobufjs/inquire/tests/data/emptyObject.js @@ -0,0 +1 @@ +module.exports = {}; diff --git a/node_modules/@protobufjs/inquire/tests/data/object.js b/node_modules/@protobufjs/inquire/tests/data/object.js new file mode 100644 index 0000000..3b75bca --- /dev/null +++ b/node_modules/@protobufjs/inquire/tests/data/object.js @@ -0,0 +1 @@ +module.exports = { a: 1 }; diff --git a/node_modules/@protobufjs/inquire/tests/index.js b/node_modules/@protobufjs/inquire/tests/index.js new file mode 100644 index 0000000..4a555ca --- /dev/null +++ b/node_modules/@protobufjs/inquire/tests/index.js @@ -0,0 +1,20 @@ +var tape = require("tape"); + +var inquire = require(".."); + +tape.test("inquire", function(test) { + + test.equal(inquire("buffer").Buffer, Buffer, "should be able to require \"buffer\""); + + test.equal(inquire("%invalid"), null, "should not be able to require \"%invalid\""); + + test.equal(inquire("./tests/data/emptyObject"), null, "should return null when requiring a module exporting an empty object"); + + test.equal(inquire("./tests/data/emptyArray"), null, "should return null when requiring a module exporting an empty array"); + + test.same(inquire("./tests/data/object"), { a: 1 }, "should return the object if a non-empty object"); + + test.same(inquire("./tests/data/array"), [ 1 ], "should return the module if a non-empty array"); + + test.end(); +}); diff --git a/node_modules/@protobufjs/path/LICENSE b/node_modules/@protobufjs/path/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/path/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/path/README.md b/node_modules/@protobufjs/path/README.md new file mode 100644 index 0000000..1c1a2ba --- /dev/null +++ b/node_modules/@protobufjs/path/README.md @@ -0,0 +1,19 @@ +@protobufjs/path +================ +[![npm](https://img.shields.io/npm/v/@protobufjs/path.svg)](https://www.npmjs.com/package/@protobufjs/path) + +A minimal path module to resolve Unix, Windows and URL paths alike. + +API +--- + +* **path.isAbsolute(path: `string`): `boolean`**
+ Tests if the specified path is absolute. + +* **path.normalize(path: `string`): `string`**
+ Normalizes the specified path. + +* **path.resolve(originPath: `string`, includePath: `string`, [alreadyNormalized=false: `boolean`]): `string`**
+ Resolves the specified include path against the specified origin path. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/path/index.d.ts b/node_modules/@protobufjs/path/index.d.ts new file mode 100644 index 0000000..b664d81 --- /dev/null +++ b/node_modules/@protobufjs/path/index.d.ts @@ -0,0 +1,22 @@ +/** + * Tests if the specified path is absolute. + * @param {string} path Path to test + * @returns {boolean} `true` if path is absolute + */ +export function isAbsolute(path: string): boolean; + +/** + * Normalizes the specified path. + * @param {string} path Path to normalize + * @returns {string} Normalized path + */ +export function normalize(path: string): string; + +/** + * Resolves the specified include path against the specified origin path. + * @param {string} originPath Path to the origin file + * @param {string} includePath Include path relative to origin path + * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized + * @returns {string} Path to the include file + */ +export function resolve(originPath: string, includePath: string, alreadyNormalized?: boolean): string; diff --git a/node_modules/@protobufjs/path/index.js b/node_modules/@protobufjs/path/index.js new file mode 100644 index 0000000..7c7fb72 --- /dev/null +++ b/node_modules/@protobufjs/path/index.js @@ -0,0 +1,65 @@ +"use strict"; + +/** + * A minimal path module to resolve Unix, Windows and URL paths alike. + * @memberof util + * @namespace + */ +var path = exports; + +var isAbsolute = +/** + * Tests if the specified path is absolute. + * @param {string} path Path to test + * @returns {boolean} `true` if path is absolute + */ +path.isAbsolute = function isAbsolute(path) { + return /^(?:\/|\w+:)/.test(path); +}; + +var normalize = +/** + * Normalizes the specified path. + * @param {string} path Path to normalize + * @returns {string} Normalized path + */ +path.normalize = function normalize(path) { + path = path.replace(/\\/g, "/") + .replace(/\/{2,}/g, "/"); + var parts = path.split("/"), + absolute = isAbsolute(path), + prefix = ""; + if (absolute) + prefix = parts.shift() + "/"; + for (var i = 0; i < parts.length;) { + if (parts[i] === "..") { + if (i > 0 && parts[i - 1] !== "..") + parts.splice(--i, 2); + else if (absolute) + parts.splice(i, 1); + else + ++i; + } else if (parts[i] === ".") + parts.splice(i, 1); + else + ++i; + } + return prefix + parts.join("/"); +}; + +/** + * Resolves the specified include path against the specified origin path. + * @param {string} originPath Path to the origin file + * @param {string} includePath Include path relative to origin path + * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized + * @returns {string} Path to the include file + */ +path.resolve = function resolve(originPath, includePath, alreadyNormalized) { + if (!alreadyNormalized) + includePath = normalize(includePath); + if (isAbsolute(includePath)) + return includePath; + if (!alreadyNormalized) + originPath = normalize(originPath); + return (originPath = originPath.replace(/(?:\/|^)[^/]+$/, "")).length ? normalize(originPath + "/" + includePath) : includePath; +}; diff --git a/node_modules/@protobufjs/path/package.json b/node_modules/@protobufjs/path/package.json new file mode 100644 index 0000000..e2d475f --- /dev/null +++ b/node_modules/@protobufjs/path/package.json @@ -0,0 +1,54 @@ +{ + "_from": "@protobufjs/path@^1.1.2", + "_id": "@protobufjs/path@1.1.2", + "_inBundle": false, + "_integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=", + "_location": "/@protobufjs/path", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/path@^1.1.2", + "name": "@protobufjs/path", + "escapedName": "@protobufjs%2fpath", + "scope": "@protobufjs", + "rawSpec": "^1.1.2", + "saveSpec": null, + "fetchSpec": "^1.1.2" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", + "_shasum": "6cc2b20c5c9ad6ad0dccfd21ca7673d8d7fbf68d", + "_spec": "@protobufjs/path@^1.1.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A minimal path module to resolve Unix, Windows and URL paths alike.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/path", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.2" +} diff --git a/node_modules/@protobufjs/path/tests/index.js b/node_modules/@protobufjs/path/tests/index.js new file mode 100644 index 0000000..9c23bc9 --- /dev/null +++ b/node_modules/@protobufjs/path/tests/index.js @@ -0,0 +1,60 @@ +var tape = require("tape"); + +var path = require(".."); + +tape.test("path", function(test) { + + test.ok(path.isAbsolute("X:\\some\\path\\file.js"), "should identify absolute windows paths"); + test.ok(path.isAbsolute("/some/path/file.js"), "should identify absolute unix paths"); + + test.notOk(path.isAbsolute("some\\path\\file.js"), "should identify relative windows paths"); + test.notOk(path.isAbsolute("some/path/file.js"), "should identify relative unix paths"); + + var paths = [ + { + actual: "X:\\some\\..\\.\\path\\\\file.js", + normal: "X:/path/file.js", + resolve: { + origin: "X:/path/origin.js", + expected: "X:/path/file.js" + } + }, { + actual: "some\\..\\.\\path\\\\file.js", + normal: "path/file.js", + resolve: { + origin: "X:/path/origin.js", + expected: "X:/path/path/file.js" + } + }, { + actual: "/some/.././path//file.js", + normal: "/path/file.js", + resolve: { + origin: "/path/origin.js", + expected: "/path/file.js" + } + }, { + actual: "some/.././path//file.js", + normal: "path/file.js", + resolve: { + origin: "", + expected: "path/file.js" + } + }, { + actual: ".././path//file.js", + normal: "../path/file.js" + }, { + actual: "/.././path//file.js", + normal: "/path/file.js" + } + ]; + + paths.forEach(function(p) { + test.equal(path.normalize(p.actual), p.normal, "should normalize " + p.actual); + if (p.resolve) { + test.equal(path.resolve(p.resolve.origin, p.actual), p.resolve.expected, "should resolve " + p.actual); + test.equal(path.resolve(p.resolve.origin, p.normal, true), p.resolve.expected, "should resolve " + p.normal + " (already normalized)"); + } + }); + + test.end(); +}); diff --git a/node_modules/@protobufjs/pool/.npmignore b/node_modules/@protobufjs/pool/.npmignore new file mode 100644 index 0000000..c3fc82e --- /dev/null +++ b/node_modules/@protobufjs/pool/.npmignore @@ -0,0 +1,3 @@ +npm-debug.* +node_modules/ +coverage/ diff --git a/node_modules/@protobufjs/pool/LICENSE b/node_modules/@protobufjs/pool/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/pool/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/pool/README.md b/node_modules/@protobufjs/pool/README.md new file mode 100644 index 0000000..9fb0e97 --- /dev/null +++ b/node_modules/@protobufjs/pool/README.md @@ -0,0 +1,13 @@ +@protobufjs/pool +================ +[![npm](https://img.shields.io/npm/v/@protobufjs/pool.svg)](https://www.npmjs.com/package/@protobufjs/pool) + +A general purpose buffer pool. + +API +--- + +* **pool(alloc: `function(size: number): Uint8Array`, slice: `function(this: Uint8Array, start: number, end: number): Uint8Array`, [size=8192: `number`]): `function(size: number): Uint8Array`**
+ Creates a pooled allocator. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/pool/index.d.ts b/node_modules/@protobufjs/pool/index.d.ts new file mode 100644 index 0000000..23fe38c --- /dev/null +++ b/node_modules/@protobufjs/pool/index.d.ts @@ -0,0 +1,32 @@ +export = pool; + +/** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ +type PoolAllocator = (size: number) => Uint8Array; + +/** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ +type PoolSlicer = (this: Uint8Array, start: number, end: number) => Uint8Array; + +/** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ +declare function pool(alloc: PoolAllocator, slice: PoolSlicer, size?: number): PoolAllocator; diff --git a/node_modules/@protobufjs/pool/index.js b/node_modules/@protobufjs/pool/index.js new file mode 100644 index 0000000..6c666f6 --- /dev/null +++ b/node_modules/@protobufjs/pool/index.js @@ -0,0 +1,48 @@ +"use strict"; +module.exports = pool; + +/** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + +/** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ + +/** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ +function pool(alloc, slice, size) { + var SIZE = size || 8192; + var MAX = SIZE >>> 1; + var slab = null; + var offset = SIZE; + return function pool_alloc(size) { + if (size < 1 || size > MAX) + return alloc(size); + if (offset + size > SIZE) { + slab = alloc(SIZE); + offset = 0; + } + var buf = slice.call(slab, offset, offset += size); + if (offset & 7) // align to 32 bit + offset = (offset | 7) + 1; + return buf; + }; +} diff --git a/node_modules/@protobufjs/pool/package.json b/node_modules/@protobufjs/pool/package.json new file mode 100644 index 0000000..ca261ea --- /dev/null +++ b/node_modules/@protobufjs/pool/package.json @@ -0,0 +1,54 @@ +{ + "_from": "@protobufjs/pool@^1.1.0", + "_id": "@protobufjs/pool@1.1.0", + "_inBundle": false, + "_integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=", + "_location": "/@protobufjs/pool", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/pool@^1.1.0", + "name": "@protobufjs/pool", + "escapedName": "@protobufjs%2fpool", + "scope": "@protobufjs", + "rawSpec": "^1.1.0", + "saveSpec": null, + "fetchSpec": "^1.1.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", + "_shasum": "09fd15f2d6d3abfa9b65bc366506d6ad7846ff54", + "_spec": "@protobufjs/pool@^1.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A general purpose buffer pool.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/pool", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.0" +} diff --git a/node_modules/@protobufjs/pool/tests/index.js b/node_modules/@protobufjs/pool/tests/index.js new file mode 100644 index 0000000..5d1a921 --- /dev/null +++ b/node_modules/@protobufjs/pool/tests/index.js @@ -0,0 +1,33 @@ +var tape = require("tape"); + +var pool = require(".."); + +if (typeof Uint8Array !== "undefined") +tape.test("pool", function(test) { + + var alloc = pool(function(size) { return new Uint8Array(size); }, Uint8Array.prototype.subarray); + + var buf1 = alloc(0); + test.equal(buf1.length, 0, "should allocate a buffer of size 0"); + + var buf2 = alloc(1); + test.equal(buf2.length, 1, "should allocate a buffer of size 1 (initializes slab)"); + + test.notEqual(buf2.buffer, buf1.buffer, "should not reference the same backing buffer if previous buffer had size 0"); + test.equal(buf2.byteOffset, 0, "should allocate at byteOffset 0 when using a new slab"); + + buf1 = alloc(1); + test.equal(buf1.buffer, buf2.buffer, "should reference the same backing buffer when allocating a chunk fitting into the slab"); + test.equal(buf1.byteOffset, 8, "should align slices to 32 bit and this allocate at byteOffset 8"); + + var buf3 = alloc(4097); + test.notEqual(buf3.buffer, buf2.buffer, "should not reference the same backing buffer when allocating a buffer larger than half the backing buffer's size"); + + buf2 = alloc(4096); + test.equal(buf2.buffer, buf1.buffer, "should reference the same backing buffer when allocating a buffer smaller or equal than half the backing buffer's size"); + + buf1 = alloc(4096); + test.notEqual(buf1.buffer, buf2.buffer, "should not reference the same backing buffer when the slab is exhausted (initializes new slab)"); + + test.end(); +}); \ No newline at end of file diff --git a/node_modules/@protobufjs/utf8/.npmignore b/node_modules/@protobufjs/utf8/.npmignore new file mode 100644 index 0000000..c3fc82e --- /dev/null +++ b/node_modules/@protobufjs/utf8/.npmignore @@ -0,0 +1,3 @@ +npm-debug.* +node_modules/ +coverage/ diff --git a/node_modules/@protobufjs/utf8/LICENSE b/node_modules/@protobufjs/utf8/LICENSE new file mode 100644 index 0000000..be2b397 --- /dev/null +++ b/node_modules/@protobufjs/utf8/LICENSE @@ -0,0 +1,26 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/@protobufjs/utf8/README.md b/node_modules/@protobufjs/utf8/README.md new file mode 100644 index 0000000..c936d9b --- /dev/null +++ b/node_modules/@protobufjs/utf8/README.md @@ -0,0 +1,20 @@ +@protobufjs/utf8 +================ +[![npm](https://img.shields.io/npm/v/@protobufjs/utf8.svg)](https://www.npmjs.com/package/@protobufjs/utf8) + +A minimal UTF8 implementation for number arrays. + +API +--- + +* **utf8.length(string: `string`): `number`**
+ Calculates the UTF8 byte length of a string. + +* **utf8.read(buffer: `Uint8Array`, start: `number`, end: `number`): `string`**
+ Reads UTF8 bytes as a string. + +* **utf8.write(string: `string`, buffer: `Uint8Array`, offset: `number`): `number`**
+ Writes a string as UTF8 bytes. + + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/@protobufjs/utf8/index.d.ts b/node_modules/@protobufjs/utf8/index.d.ts new file mode 100644 index 0000000..2f1d0ab --- /dev/null +++ b/node_modules/@protobufjs/utf8/index.d.ts @@ -0,0 +1,24 @@ +/** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ +export function length(string: string): number; + +/** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ +export function read(buffer: Uint8Array, start: number, end: number): string; + +/** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ +export function write(string: string, buffer: Uint8Array, offset: number): number; diff --git a/node_modules/@protobufjs/utf8/index.js b/node_modules/@protobufjs/utf8/index.js new file mode 100644 index 0000000..43c5298 --- /dev/null +++ b/node_modules/@protobufjs/utf8/index.js @@ -0,0 +1,105 @@ +"use strict"; + +/** + * A minimal UTF8 implementation for number arrays. + * @memberof util + * @namespace + */ +var utf8 = exports; + +/** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ +utf8.length = function utf8_length(string) { + var len = 0, + c = 0; + for (var i = 0; i < string.length; ++i) { + c = string.charCodeAt(i); + if (c < 128) + len += 1; + else if (c < 2048) + len += 2; + else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) { + ++i; + len += 4; + } else + len += 3; + } + return len; +}; + +/** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ +utf8.read = function utf8_read(buffer, start, end) { + var len = end - start; + if (len < 1) + return ""; + var parts = null, + chunk = [], + i = 0, // char offset + t; // temporary + while (start < end) { + t = buffer[start++]; + if (t < 128) + chunk[i++] = t; + else if (t > 191 && t < 224) + chunk[i++] = (t & 31) << 6 | buffer[start++] & 63; + else if (t > 239 && t < 365) { + t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000; + chunk[i++] = 0xD800 + (t >> 10); + chunk[i++] = 0xDC00 + (t & 1023); + } else + chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63; + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +/** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ +utf8.write = function utf8_write(string, buffer, offset) { + var start = offset, + c1, // character 1 + c2; // character 2 + for (var i = 0; i < string.length; ++i) { + c1 = string.charCodeAt(i); + if (c1 < 128) { + buffer[offset++] = c1; + } else if (c1 < 2048) { + buffer[offset++] = c1 >> 6 | 192; + buffer[offset++] = c1 & 63 | 128; + } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) { + c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF); + ++i; + buffer[offset++] = c1 >> 18 | 240; + buffer[offset++] = c1 >> 12 & 63 | 128; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } else { + buffer[offset++] = c1 >> 12 | 224; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } + } + return offset - start; +}; diff --git a/node_modules/@protobufjs/utf8/package.json b/node_modules/@protobufjs/utf8/package.json new file mode 100644 index 0000000..81dc758 --- /dev/null +++ b/node_modules/@protobufjs/utf8/package.json @@ -0,0 +1,54 @@ +{ + "_from": "@protobufjs/utf8@^1.1.0", + "_id": "@protobufjs/utf8@1.1.0", + "_inBundle": false, + "_integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=", + "_location": "/@protobufjs/utf8", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@protobufjs/utf8@^1.1.0", + "name": "@protobufjs/utf8", + "escapedName": "@protobufjs%2futf8", + "scope": "@protobufjs", + "rawSpec": "^1.1.0", + "saveSpec": null, + "fetchSpec": "^1.1.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", + "_shasum": "a777360b5b39a1a2e5106f8e858f2fd2d060c570", + "_spec": "@protobufjs/utf8@^1.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "A minimal UTF8 implementation for number arrays.", + "devDependencies": { + "istanbul": "^0.4.5", + "tape": "^4.6.3" + }, + "homepage": "https://github.com/dcodeIO/protobuf.js#readme", + "license": "BSD-3-Clause", + "main": "index.js", + "name": "@protobufjs/utf8", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "coverage": "istanbul cover node_modules/tape/bin/tape tests/*.js", + "test": "tape tests/*.js" + }, + "types": "index.d.ts", + "version": "1.1.0" +} diff --git a/node_modules/@protobufjs/utf8/tests/data/utf8.txt b/node_modules/@protobufjs/utf8/tests/data/utf8.txt new file mode 100644 index 0000000..580b4c4 --- /dev/null +++ b/node_modules/@protobufjs/utf8/tests/data/utf8.txt @@ -0,0 +1,216 @@ +UTF-8 encoded sample plain-text file +‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾ + +Markus Kuhn [ˈmaʳkʊs kuːn] — 2002-07-25 CC BY + + +The ASCII compatible UTF-8 encoding used in this plain-text file +is defined in Unicode, ISO 10646-1, and RFC 2279. + + +Using Unicode/UTF-8, you can write in emails and source code things such as + +Mathematics and sciences: + + ∮ E⋅da = Q, n → ∞, ∑ f(i) = ∏ g(i), ⎧⎡⎛┌─────┐⎞⎤⎫ + ⎪⎢⎜│a²+b³ ⎟⎥⎪ + ∀x∈ℝ: ⌈x⌉ = −⌊−x⌋, α ∧ ¬β = ¬(¬α ∨ β), ⎪⎢⎜│───── ⎟⎥⎪ + ⎪⎢⎜⎷ c₈ ⎟⎥⎪ + ℕ ⊆ ℕ₀ ⊂ ℤ ⊂ ℚ ⊂ ℝ ⊂ ℂ, ⎨⎢⎜ ⎟⎥⎬ + ⎪⎢⎜ ∞ ⎟⎥⎪ + ⊥ < a ≠ b ≡ c ≤ d ≪ ⊤ ⇒ (⟦A⟧ ⇔ ⟪B⟫), ⎪⎢⎜ ⎲ ⎟⎥⎪ + ⎪⎢⎜ ⎳aⁱ-bⁱ⎟⎥⎪ + 2H₂ + O₂ ⇌ 2H₂O, R = 4.7 kΩ, ⌀ 200 mm ⎩⎣⎝i=1 ⎠⎦⎭ + +Linguistics and dictionaries: + + ði ıntəˈnæʃənəl fəˈnɛtık əsoʊsiˈeıʃn + Y [ˈʏpsilɔn], Yen [jɛn], Yoga [ˈjoːgɑ] + +APL: + + ((V⍳V)=⍳⍴V)/V←,V ⌷←⍳→⍴∆∇⊃‾⍎⍕⌈ + +Nicer typography in plain text files: + + ╔══════════════════════════════════════════╗ + ║ ║ + ║ • ‘single’ and “double” quotes ║ + ║ ║ + ║ • Curly apostrophes: “We’ve been here” ║ + ║ ║ + ║ • Latin-1 apostrophe and accents: '´` ║ + ║ ║ + ║ • ‚deutsche‘ „Anführungszeichen“ ║ + ║ ║ + ║ • †, ‡, ‰, •, 3–4, —, −5/+5, ™, … ║ + ║ ║ + ║ • ASCII safety test: 1lI|, 0OD, 8B ║ + ║ ╭─────────╮ ║ + ║ • the euro symbol: │ 14.95 € │ ║ + ║ ╰─────────╯ ║ + ╚══════════════════════════════════════════╝ + +Combining characters: + + STARGΛ̊TE SG-1, a = v̇ = r̈, a⃑ ⊥ b⃑ + +Greek (in Polytonic): + + The Greek anthem: + + Σὲ γνωρίζω ἀπὸ τὴν κόψη + τοῦ σπαθιοῦ τὴν τρομερή, + σὲ γνωρίζω ἀπὸ τὴν ὄψη + ποὺ μὲ βία μετράει τὴ γῆ. + + ᾿Απ᾿ τὰ κόκκαλα βγαλμένη + τῶν ῾Ελλήνων τὰ ἱερά + καὶ σὰν πρῶτα ἀνδρειωμένη + χαῖρε, ὦ χαῖρε, ᾿Ελευθεριά! + + From a speech of Demosthenes in the 4th century BC: + + Οὐχὶ ταὐτὰ παρίσταταί μοι γιγνώσκειν, ὦ ἄνδρες ᾿Αθηναῖοι, + ὅταν τ᾿ εἰς τὰ πράγματα ἀποβλέψω καὶ ὅταν πρὸς τοὺς + λόγους οὓς ἀκούω· τοὺς μὲν γὰρ λόγους περὶ τοῦ + τιμωρήσασθαι Φίλιππον ὁρῶ γιγνομένους, τὰ δὲ πράγματ᾿ + εἰς τοῦτο προήκοντα, ὥσθ᾿ ὅπως μὴ πεισόμεθ᾿ αὐτοὶ + πρότερον κακῶς σκέψασθαι δέον. οὐδέν οὖν ἄλλο μοι δοκοῦσιν + οἱ τὰ τοιαῦτα λέγοντες ἢ τὴν ὑπόθεσιν, περὶ ἧς βουλεύεσθαι, + οὐχὶ τὴν οὖσαν παριστάντες ὑμῖν ἁμαρτάνειν. ἐγὼ δέ, ὅτι μέν + ποτ᾿ ἐξῆν τῇ πόλει καὶ τὰ αὑτῆς ἔχειν ἀσφαλῶς καὶ Φίλιππον + τιμωρήσασθαι, καὶ μάλ᾿ ἀκριβῶς οἶδα· ἐπ᾿ ἐμοῦ γάρ, οὐ πάλαι + γέγονεν ταῦτ᾿ ἀμφότερα· νῦν μέντοι πέπεισμαι τοῦθ᾿ ἱκανὸν + προλαβεῖν ἡμῖν εἶναι τὴν πρώτην, ὅπως τοὺς συμμάχους + σώσομεν. ἐὰν γὰρ τοῦτο βεβαίως ὑπάρξῃ, τότε καὶ περὶ τοῦ + τίνα τιμωρήσεταί τις καὶ ὃν τρόπον ἐξέσται σκοπεῖν· πρὶν δὲ + τὴν ἀρχὴν ὀρθῶς ὑποθέσθαι, μάταιον ἡγοῦμαι περὶ τῆς + τελευτῆς ὁντινοῦν ποιεῖσθαι λόγον. + + Δημοσθένους, Γ´ ᾿Ολυνθιακὸς + +Georgian: + + From a Unicode conference invitation: + + გთხოვთ ახლავე გაიაროთ რეგისტრაცია Unicode-ის მეათე საერთაშორისო + კონფერენციაზე დასასწრებად, რომელიც გაიმართება 10-12 მარტს, + ქ. მაინცში, გერმანიაში. კონფერენცია შეჰკრებს ერთად მსოფლიოს + ექსპერტებს ისეთ დარგებში როგორიცაა ინტერნეტი და Unicode-ი, + ინტერნაციონალიზაცია და ლოკალიზაცია, Unicode-ის გამოყენება + ოპერაციულ სისტემებსა, და გამოყენებით პროგრამებში, შრიფტებში, + ტექსტების დამუშავებასა და მრავალენოვან კომპიუტერულ სისტემებში. + +Russian: + + From a Unicode conference invitation: + + Зарегистрируйтесь сейчас на Десятую Международную Конференцию по + Unicode, которая состоится 10-12 марта 1997 года в Майнце в Германии. + Конференция соберет широкий круг экспертов по вопросам глобального + Интернета и Unicode, локализации и интернационализации, воплощению и + применению Unicode в различных операционных системах и программных + приложениях, шрифтах, верстке и многоязычных компьютерных системах. + +Thai (UCS Level 2): + + Excerpt from a poetry on The Romance of The Three Kingdoms (a Chinese + classic 'San Gua'): + + [----------------------------|------------------------] + ๏ แผ่นดินฮั่นเสื่อมโทรมแสนสังเวช พระปกเกศกองบู๊กู้ขึ้นใหม่ + สิบสองกษัตริย์ก่อนหน้าแลถัดไป สององค์ไซร้โง่เขลาเบาปัญญา + ทรงนับถือขันทีเป็นที่พึ่ง บ้านเมืองจึงวิปริตเป็นนักหนา + โฮจิ๋นเรียกทัพทั่วหัวเมืองมา หมายจะฆ่ามดชั่วตัวสำคัญ + เหมือนขับไสไล่เสือจากเคหา รับหมาป่าเข้ามาเลยอาสัญ + ฝ่ายอ้องอุ้นยุแยกให้แตกกัน ใช้สาวนั้นเป็นชนวนชื่นชวนใจ + พลันลิฉุยกุยกีกลับก่อเหตุ ช่างอาเพศจริงหนาฟ้าร้องไห้ + ต้องรบราฆ่าฟันจนบรรลัย ฤๅหาใครค้ำชูกู้บรรลังก์ ฯ + + (The above is a two-column text. If combining characters are handled + correctly, the lines of the second column should be aligned with the + | character above.) + +Ethiopian: + + Proverbs in the Amharic language: + + ሰማይ አይታረስ ንጉሥ አይከሰስ። + ብላ ካለኝ እንደአባቴ በቆመጠኝ። + ጌጥ ያለቤቱ ቁምጥና ነው። + ደሀ በሕልሙ ቅቤ ባይጠጣ ንጣት በገደለው። + የአፍ ወለምታ በቅቤ አይታሽም። + አይጥ በበላ ዳዋ ተመታ። + ሲተረጉሙ ይደረግሙ። + ቀስ በቀስ፥ ዕንቁላል በእግሩ ይሄዳል። + ድር ቢያብር አንበሳ ያስር። + ሰው እንደቤቱ እንጅ እንደ ጉረቤቱ አይተዳደርም። + እግዜር የከፈተውን ጉሮሮ ሳይዘጋው አይድርም። + የጎረቤት ሌባ፥ ቢያዩት ይስቅ ባያዩት ያጠልቅ። + ሥራ ከመፍታት ልጄን ላፋታት። + ዓባይ ማደሪያ የለው፥ ግንድ ይዞ ይዞራል። + የእስላም አገሩ መካ የአሞራ አገሩ ዋርካ። + ተንጋሎ ቢተፉ ተመልሶ ባፉ። + ወዳጅህ ማር ቢሆን ጨርስህ አትላሰው። + እግርህን በፍራሽህ ልክ ዘርጋ። + +Runes: + + ᚻᛖ ᚳᚹᚫᚦ ᚦᚫᛏ ᚻᛖ ᛒᚢᛞᛖ ᚩᚾ ᚦᚫᛗ ᛚᚪᚾᛞᛖ ᚾᚩᚱᚦᚹᛖᚪᚱᛞᚢᛗ ᚹᛁᚦ ᚦᚪ ᚹᛖᛥᚫ + + (Old English, which transcribed into Latin reads 'He cwaeth that he + bude thaem lande northweardum with tha Westsae.' and means 'He said + that he lived in the northern land near the Western Sea.') + +Braille: + + ⡌⠁⠧⠑ ⠼⠁⠒ ⡍⠜⠇⠑⠹⠰⠎ ⡣⠕⠌ + + ⡍⠜⠇⠑⠹ ⠺⠁⠎ ⠙⠑⠁⠙⠒ ⠞⠕ ⠃⠑⠛⠔ ⠺⠊⠹⠲ ⡹⠻⠑ ⠊⠎ ⠝⠕ ⠙⠳⠃⠞ + ⠱⠁⠞⠑⠧⠻ ⠁⠃⠳⠞ ⠹⠁⠞⠲ ⡹⠑ ⠗⠑⠛⠊⠌⠻ ⠕⠋ ⠙⠊⠎ ⠃⠥⠗⠊⠁⠇ ⠺⠁⠎ + ⠎⠊⠛⠝⠫ ⠃⠹ ⠹⠑ ⠊⠇⠻⠛⠹⠍⠁⠝⠂ ⠹⠑ ⠊⠇⠻⠅⠂ ⠹⠑ ⠥⠝⠙⠻⠞⠁⠅⠻⠂ + ⠁⠝⠙ ⠹⠑ ⠡⠊⠑⠋ ⠍⠳⠗⠝⠻⠲ ⡎⠊⠗⠕⠕⠛⠑ ⠎⠊⠛⠝⠫ ⠊⠞⠲ ⡁⠝⠙ + ⡎⠊⠗⠕⠕⠛⠑⠰⠎ ⠝⠁⠍⠑ ⠺⠁⠎ ⠛⠕⠕⠙ ⠥⠏⠕⠝ ⠰⡡⠁⠝⠛⠑⠂ ⠋⠕⠗ ⠁⠝⠹⠹⠔⠛ ⠙⠑ + ⠡⠕⠎⠑ ⠞⠕ ⠏⠥⠞ ⠙⠊⠎ ⠙⠁⠝⠙ ⠞⠕⠲ + + ⡕⠇⠙ ⡍⠜⠇⠑⠹ ⠺⠁⠎ ⠁⠎ ⠙⠑⠁⠙ ⠁⠎ ⠁ ⠙⠕⠕⠗⠤⠝⠁⠊⠇⠲ + + ⡍⠔⠙⠖ ⡊ ⠙⠕⠝⠰⠞ ⠍⠑⠁⠝ ⠞⠕ ⠎⠁⠹ ⠹⠁⠞ ⡊ ⠅⠝⠪⠂ ⠕⠋ ⠍⠹ + ⠪⠝ ⠅⠝⠪⠇⠫⠛⠑⠂ ⠱⠁⠞ ⠹⠻⠑ ⠊⠎ ⠏⠜⠞⠊⠊⠥⠇⠜⠇⠹ ⠙⠑⠁⠙ ⠁⠃⠳⠞ + ⠁ ⠙⠕⠕⠗⠤⠝⠁⠊⠇⠲ ⡊ ⠍⠊⠣⠞ ⠙⠁⠧⠑ ⠃⠑⠲ ⠔⠊⠇⠔⠫⠂ ⠍⠹⠎⠑⠇⠋⠂ ⠞⠕ + ⠗⠑⠛⠜⠙ ⠁ ⠊⠕⠋⠋⠔⠤⠝⠁⠊⠇ ⠁⠎ ⠹⠑ ⠙⠑⠁⠙⠑⠌ ⠏⠊⠑⠊⠑ ⠕⠋ ⠊⠗⠕⠝⠍⠕⠝⠛⠻⠹ + ⠔ ⠹⠑ ⠞⠗⠁⠙⠑⠲ ⡃⠥⠞ ⠹⠑ ⠺⠊⠎⠙⠕⠍ ⠕⠋ ⠳⠗ ⠁⠝⠊⠑⠌⠕⠗⠎ + ⠊⠎ ⠔ ⠹⠑ ⠎⠊⠍⠊⠇⠑⠆ ⠁⠝⠙ ⠍⠹ ⠥⠝⠙⠁⠇⠇⠪⠫ ⠙⠁⠝⠙⠎ + ⠩⠁⠇⠇ ⠝⠕⠞ ⠙⠊⠌⠥⠗⠃ ⠊⠞⠂ ⠕⠗ ⠹⠑ ⡊⠳⠝⠞⠗⠹⠰⠎ ⠙⠕⠝⠑ ⠋⠕⠗⠲ ⡹⠳ + ⠺⠊⠇⠇ ⠹⠻⠑⠋⠕⠗⠑ ⠏⠻⠍⠊⠞ ⠍⠑ ⠞⠕ ⠗⠑⠏⠑⠁⠞⠂ ⠑⠍⠏⠙⠁⠞⠊⠊⠁⠇⠇⠹⠂ ⠹⠁⠞ + ⡍⠜⠇⠑⠹ ⠺⠁⠎ ⠁⠎ ⠙⠑⠁⠙ ⠁⠎ ⠁ ⠙⠕⠕⠗⠤⠝⠁⠊⠇⠲ + + (The first couple of paragraphs of "A Christmas Carol" by Dickens) + +Compact font selection example text: + + ABCDEFGHIJKLMNOPQRSTUVWXYZ /0123456789 + abcdefghijklmnopqrstuvwxyz £©µÀÆÖÞßéöÿ + –—‘“”„†•…‰™œŠŸž€ ΑΒΓΔΩαβγδω АБВГДабвгд + ∀∂∈ℝ∧∪≡∞ ↑↗↨↻⇣ ┐┼╔╘░►☺♀ fi�⑀₂ἠḂӥẄɐː⍎אԱა + +Greetings in various languages: + + Hello world, Καλημέρα κόσμε, コンニチハ + +Box drawing alignment tests: █ + ▉ + ╔══╦══╗ ┌──┬──┐ ╭──┬──╮ ╭──┬──╮ ┏━━┳━━┓ ┎┒┏┑ ╷ ╻ ┏┯┓ ┌┰┐ ▊ ╱╲╱╲╳╳╳ + ║┌─╨─┐║ │╔═╧═╗│ │╒═╪═╕│ │╓─╁─╖│ ┃┌─╂─┐┃ ┗╃╄┙ ╶┼╴╺╋╸┠┼┨ ┝╋┥ ▋ ╲╱╲╱╳╳╳ + ║│╲ ╱│║ │║ ║│ ││ │ ││ │║ ┃ ║│ ┃│ ╿ │┃ ┍╅╆┓ ╵ ╹ ┗┷┛ └┸┘ ▌ ╱╲╱╲╳╳╳ + ╠╡ ╳ ╞╣ ├╢ ╟┤ ├┼─┼─┼┤ ├╫─╂─╫┤ ┣┿╾┼╼┿┫ ┕┛┖┚ ┌┄┄┐ ╎ ┏┅┅┓ ┋ ▍ ╲╱╲╱╳╳╳ + ║│╱ ╲│║ │║ ║│ ││ │ ││ │║ ┃ ║│ ┃│ ╽ │┃ ░░▒▒▓▓██ ┊ ┆ ╎ ╏ ┇ ┋ ▎ + ║└─╥─┘║ │╚═╤═╝│ │╘═╪═╛│ │╙─╀─╜│ ┃└─╂─┘┃ ░░▒▒▓▓██ ┊ ┆ ╎ ╏ ┇ ┋ ▏ + ╚══╩══╝ └──┴──┘ ╰──┴──╯ ╰──┴──╯ ┗━━┻━━┛ ▗▄▖▛▀▜ └╌╌┘ ╎ ┗╍╍┛ ┋ ▁▂▃▄▅▆▇█ + ▝▀▘▙▄▟ + +Surrogates: + +𠜎 𠜱 𠝹 𠱓 𠱸 𠲖 𠳏 𠳕 𠴕 𠵼 𠵿 𠸎 𠸏 𠹷 𠺝 𠺢 𠻗 𠻹 𠻺 𠼭 𠼮 𠽌 𠾴 𠾼 𠿪 𡁜 𡁯 𡁵 𡁶 𡁻 𡃁 +𡃉 𡇙 𢃇 𢞵 𢫕 𢭃 𢯊 𢱑 𢱕 𢳂 𢴈 𢵌 𢵧 𢺳 𣲷 𤓓 𤶸 𤷪 𥄫 𦉘 𦟌 𦧲 𦧺 𧨾 𨅝 𨈇 𨋢 𨳊 𨳍 𨳒 𩶘 diff --git a/node_modules/@protobufjs/utf8/tests/index.js b/node_modules/@protobufjs/utf8/tests/index.js new file mode 100644 index 0000000..16d169e --- /dev/null +++ b/node_modules/@protobufjs/utf8/tests/index.js @@ -0,0 +1,57 @@ +var tape = require("tape"); + +var utf8 = require(".."); + +var data = require("fs").readFileSync(require.resolve("./data/utf8.txt")), + dataStr = data.toString("utf8"); + +tape.test("utf8", function(test) { + + test.test(test.name + " - length", function(test) { + test.equal(utf8.length(""), 0, "should return a byte length of zero for an empty string"); + + test.equal(utf8.length(dataStr), Buffer.byteLength(dataStr), "should return the same byte length as node buffers"); + + test.end(); + }); + + test.test(test.name + " - read", function(test) { + var comp = utf8.read([], 0, 0); + test.equal(comp, "", "should decode an empty buffer to an empty string"); + + comp = utf8.read(data, 0, data.length); + test.equal(comp, data.toString("utf8"), "should decode to the same byte data as node buffers"); + + var longData = Buffer.concat([data, data, data, data]); + comp = utf8.read(longData, 0, longData.length); + test.equal(comp, longData.toString("utf8"), "should decode to the same byte data as node buffers (long)"); + + var chunkData = new Buffer(data.toString("utf8").substring(0, 8192)); + comp = utf8.read(chunkData, 0, chunkData.length); + test.equal(comp, chunkData.toString("utf8"), "should decode to the same byte data as node buffers (chunk size)"); + + test.end(); + }); + + test.test(test.name + " - write", function(test) { + var buf = new Buffer(0); + test.equal(utf8.write("", buf, 0), 0, "should encode an empty string to an empty buffer"); + + var len = utf8.length(dataStr); + buf = new Buffer(len); + test.equal(utf8.write(dataStr, buf, 0), len, "should encode to exactly " + len + " bytes"); + + test.equal(buf.length, data.length, "should encode to a buffer length equal to that of node buffers"); + + for (var i = 0; i < buf.length; ++i) { + if (buf[i] !== data[i]) { + test.fail("should encode to the same buffer data as node buffers (offset " + i + ")"); + return; + } + } + test.pass("should encode to the same buffer data as node buffers"); + + test.end(); + }); + +}); diff --git a/node_modules/@tensorflow/tfjs-converter/LICENSE b/node_modules/@tensorflow/tfjs-converter/LICENSE new file mode 100644 index 0000000..d645695 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/LICENSE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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. diff --git a/node_modules/@tensorflow/tfjs-converter/README.md b/node_modules/@tensorflow/tfjs-converter/README.md new file mode 100644 index 0000000..bef481f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/README.md @@ -0,0 +1,255 @@ +[![Build Status](https://travis-ci.org/tensorflow/tfjs-converter.svg?branch=master)](https://travis-ci.org/tensorflow/tfjs-converter) + +# Getting started + +**TensorFlow.js converter** is an open source library to load a pretrained +TensorFlow [SavedModel](https://www.tensorflow.org/programmers_guide/saved_model#overview_of_saving_and_restoring_models), [Frozen Model](https://www.tensorflow.org/mobile/prepare_models#how_do_you_get_a_model_you_can_use_on_mobile) or [Session Bundle](https://github.com/tensorflow/tensorflow/blob/master/tensorflow/contrib/session_bundle/README.md) +into the browser and run inference through [TensorFlow.js](https://js.tensorflow.org). + +(Note: TensorFlow has deprecated session bundle format, please switch to SavedModel.) + +A 2-step process to import your model: + +1. A python pip package to convert a TensorFlow SavedModel/Frozen Model/Session Bundle to a web friendly format. If you already have a converted model, or are using an already hosted model (e.g. MobileNet), skip this step. +2. [Javascript API](./src/executor/tf_model.ts), for loading and running inference. + +## Step 1: Converting a [SavedModel](https://github.com/tensorflow/tensorflow/blob/master/tensorflow/python/saved_model/README.md), [Keras h5](https://keras.io/getting-started/faq/#how-can-i-save-a-keras-model), [Session Bundle](https://github.com/tensorflow/tensorflow/blob/master/tensorflow/contrib/session_bundle/README.md), [Frozen Model](https://www.tensorflow.org/mobile/prepare_models#how_do_you_get_a_model_you_can_use_on_mobile) or [Tensorflow Hub module](https://www.tensorflow.org/hub/) to a web-friendly format + +1. Install the TensorFlow.js pip package: + +```bash + $ pip install tensorflowjs +``` + +2. Run the converter script provided by the pip package: + +Usage: + +SavedModel example: + +```bash +$ tensorflowjs_converter \ + --input_format=tf_saved_model \ + --output_node_names='MobilenetV1/Predictions/Reshape_1' \ + --saved_model_tags=serve \ + /mobilenet/saved_model \ + /mobilenet/web_model +``` + +Frozen model example: + +```bash +$ tensorflowjs_converter \ + --input_format=tf_frozen_model \ + --output_node_names='MobilenetV1/Predictions/Reshape_1' \ + --saved_model_tags=serve \ + /mobilenet/frozen_model.pb \ + /mobilenet/web_model +``` + +Session bundle model example: + +```bash +$ tensorflowjs_converter \ + --input_format=tf_session_bundle \ + --output_node_names='MobilenetV1/Predictions/Reshape_1' \ + /mobilenet/session_bundle \ + /mobilenet/web_model +``` + +Tensorflow Hub module example: + +```bash +$ tensorflowjs_converter \ + --input_format=tf_hub \ + 'https://tfhub.dev/google/imagenet/mobilenet_v1_100_224/classification/1' \ + /mobilenet/web_model +``` + +Keras h5 model example: + +```bash +$ tensorflowjs_converter \ + --input_format=keras \ + /tmp/my_keras_model.h5 \ + /tmp/my_tfjs_model +``` + + +|Positional Arguments | Description | +|---|---| +|`input_path` | Full path of the saved model directory, session bundle directory, frozen model file or TensorFlow Hub module handle or path.| +|`output_path` | Path for all output artifacts.| + + +| Options | Description +|---|---| +|`--input_format` | The format of input model, use `tf_saved_model` for SavedModel, `tf_frozen_model` for frozen model, `tf_session_bundle` for session bundle, `tf_hub` for TensorFlow Hub module, `tensorflowjs` for TensorFlow.js JSON format, and `keras` for Keras HDF5. | +|`--output_node_names`| The names of the output nodes, separated by commas.| +|`--output_format`| The desired output format. Must be `tensorflowjs` (the default) or `keras`. Not all pairs of input-output formats are supported. Please file a [github issue](https://github.com/tensorflow/tfjs/issues) if your desired input-output pair is not supported.| +|`--saved_model_tags` | Only applicable to SavedModel conversion. Tags of the MetaGraphDef to load, in comma separated format. Defaults to `serve`.| +|`--signature_name` | Only applicable to TensorFlow Hub module conversion, signature to load. Defaults to `default`. See https://www.tensorflow.org/hub/common_signatures/.| +|`--strip_debug_ops` | Strips out TensorFlow debug operations `Print`, `Assert`, `CheckNumerics`. Defaults to `True`.| + + +### Format conversions support table + +| input format | output `tensorflowjs` | output `keras` | +|---|---|---| +|`keras`| :heavy_check_mark: | :x: | +|`tensorflowjs`| :x: | :heavy_check_mark: | +|`tf_frozen_model`| :heavy_check_mark: | :x: | +|`tf_hub`| :heavy_check_mark: | :x: | +|`tf_saved_model`| :heavy_check_mark: | :x: | +|`tf_session_bundle`| :heavy_check_mark: | :x: | + +### Web-friendly format + +The conversion script above produces 3 types of files: + +* `web_model.pb` (the dataflow graph) +* `weights_manifest.json` (weight manifest file) +* `group1-shard\*of\*` (collection of binary weight files) + +For example, here is the MobileNet model converted and served in +following location: + +```html + https://storage.cloud.google.com/tfjs-models/savedmodel/mobilenet_v1_1.0_224/optimized_model.pb + https://storage.cloud.google.com/tfjs-models/savedmodel/mobilenet_v1_1.0_224/weights_manifest.json + https://storage.cloud.google.com/tfjs-models/savedmodel/mobilenet_v1_1.0_224/group1-shard1of5 + ... + https://storage.cloud.google.com/tfjs-models/savedmodel/mobilenet_v1_1.0_224/group1-shard5of5 +``` + +## Step 2: Loading and running in the browser + +1. Install the tfjs-converter npm package + +`yarn add @tensorflow/tfjs-converter` or `npm install @tensorflow/tfjs-converter` + +2. Instantiate the [FrozenModel class](./src/executor/frozen_model.ts) and run inference. + +```typescript +import * as tf from '@tensorflow/tfjs'; +import {loadFrozenModel} from '@tensorflow/tfjs-converter'; + +const MODEL_URL = 'https://.../mobilenet/web_model.pb'; +const WEIGHTS_URL = 'https://.../mobilenet/weights_manifest.json'; + +const model = await loadFrozenModel(MODEL_URL, WEIGHTS_URL); +const cat = document.getElementById('cat'); +model.execute({input: tf.fromPixels(cat)}); +``` + +Check out our working [MobileNet demo](./demo/mobilenet/README.md). + +If your server requests credentials for accessing the model files, you can provide the optional RequestOption param. + +```typescript +const model = await loadFrozenModel(MODEL_URL, WEIGHTS_URL, + {credentials: 'include'}); +``` + +Please see [fetch() documentation](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch) for details. + +## Supported operations + +Currently TensorFlow.js only supports a limited set of TensorFlow Ops. See the +[full list](./docs/supported_ops.md). +If your model uses an unsupported ops, the `tensorflowjs_converter` script will fail and +produce a list of the unsupported ops in your model. Please file issues to let us +know what ops you need support with. + +## Loading the weights only + +If you prefer to load the weights only, you can use follow code snippet. + +```typescript +import * as tf from '@tensorflow/tfjs'; + +const weightManifestUrl = "https://example.org/model/weights_manifest.json"; + +const manifest = await fetch(weightManifestUrl); +this.weightManifest = await manifest.json(); +const weightMap = await tf.io.loadWeights( + this.weightManifest, "https://example.org/model"); +``` + +## FAQ + +1. What TensorFlow models does the converter currently support? + +Image-based models (MobileNet, SqueezeNet, add more if you tested) are the most supported. Models with control flow ops (e.g. RNNs) are not yet supported. The tensorflowjs_converter script will validate the model you have and show a list of unsupported ops in your model. See [this list](./docs/supported_ops.md) for which ops are currently supported. + +2. Will model with large weights work? + +While the browser supports loading 100-500MB models, the page load time, the inference time and the user experience would not be great. We recommend using models that are designed for edge devices (e.g. phones). These models are usually smaller than 30MB. + +3. Will the model and weight files be cached in the browser? + +Yes, we are splitting the weights into files of 4MB chunks, which enable the browser to cache them automatically. If the model architecture is less than 4MB (most models are), it will also be cached. + +4. Will it support model with quantization? + +Not yet. We are planning to add quantization support soon. + +5. Why is the predict() method for inference so much slower on the first call than the subsequent calls? + +The time of first call also includes the compilation time of WebGL shader programs for the model. After the first call the shader programs are cached, which makes the subsequent calls much faster. You can warm up the cache by calling the predict method with an all zero inputs, right after the completion of the model loading. + +## Development + +To build **TensorFlow.js converter** from source, we need to clone the project and prepare +the dev environment: + +```bash +$ git clone https://github.com/tensorflow/tfjs-converter.git +$ cd tfjs-converter +$ yarn # Installs dependencies. +``` + +We recommend using [Visual Studio Code](https://code.visualstudio.com/) for +development. Make sure to install +[TSLint VSCode extension](https://marketplace.visualstudio.com/items?itemName=eg2.tslint) +and the npm [clang-format](https://github.com/angular/clang-format) `1.2.2` or later +with the +[Clang-Format VSCode extension](https://marketplace.visualstudio.com/items?itemName=xaver.clang-format) +for auto-formatting. + +Before submitting a pull request, make sure the code passes all the tests and is clean of lint errors: + +```bash +$ yarn test +$ yarn lint +``` + +To run a subset of tests and/or on a specific browser: + +```bash +$ yarn test --browsers=Chrome --grep='execute' +  +> ... +> Chrome 64.0.3282 (Linux 0.0.0): Executed 39 of 39 SUCCESS (0.129 secs / 0 secs) +``` + +To run the tests once and exit the karma process (helpful on Windows): + +```bash +$ yarn test --single-run +``` + +To generate the static js file for GraphDef proto, run following steps: + +1. Generate static js file with comment first, in order to generate typescript definition. + +```bash +$ node_modules/protobufjs/bin/pbjs -t static-module -w commonjs -o src/data/compiled_api.js --no-create --no-encode --no-verify --no-convert --no-delimited --no-beautify src/data/api.proto + +$ node_modules/protobufjs/bin/pbts -o src/data/compiled_api.d.ts src/data/compiled_api.js +``` + +2. Replace the static js file with the version without comments. +```bash +$ node_modules/protobufjs/bin/pbjs -t static-module -w commonjs -o src/data/compiled_api.js --no-create --no-encode --no-verify --no-convert --no-delimited --no-beautify --no-comments src/data/api.proto +``` diff --git a/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.d.ts new file mode 100644 index 0000000..5455e2f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.d.ts @@ -0,0 +1,1617 @@ +import * as $protobuf from "protobufjs"; + +/** Namespace tensorflow. */ +export namespace tensorflow { + + /** Properties of an Any. */ + interface IAny { + + /** Any typeUrl */ + typeUrl?: (string|null); + + /** Any value */ + value?: (Uint8Array|null); + } + + /** Represents an Any. */ + class Any implements IAny { + + /** + * Constructs a new Any. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IAny); + + /** Any typeUrl. */ + public typeUrl: string; + + /** Any value. */ + public value: Uint8Array; + + /** + * Decodes an Any message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns Any + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.Any; + } + + /** DataType enum. */ + enum DataType { + DT_INVALID = 0, + DT_FLOAT = 1, + DT_DOUBLE = 2, + DT_INT32 = 3, + DT_UINT8 = 4, + DT_INT16 = 5, + DT_INT8 = 6, + DT_STRING = 7, + DT_COMPLEX64 = 8, + DT_INT64 = 9, + DT_BOOL = 10, + DT_QINT8 = 11, + DT_QUINT8 = 12, + DT_QINT32 = 13, + DT_BFLOAT16 = 14, + DT_FLOAT_REF = 101, + DT_DOUBLE_REF = 102, + DT_INT32_REF = 103, + DT_UINT8_REF = 104, + DT_INT16_REF = 105, + DT_INT8_REF = 106, + DT_STRING_REF = 107, + DT_COMPLEX64_REF = 108, + DT_INT64_REF = 109, + DT_BOOL_REF = 110, + DT_QINT8_REF = 111, + DT_QUINT8_REF = 112, + DT_QINT32_REF = 113, + DT_BFLOAT16_REF = 114 + } + + /** Properties of a TensorShape. */ + interface ITensorShape { + + /** TensorShape dim */ + dim?: (tensorflow.TensorShape.IDim[]|null); + + /** TensorShape unknownRank */ + unknownRank?: (boolean|null); + } + + /** Represents a TensorShape. */ + class TensorShape implements ITensorShape { + + /** + * Constructs a new TensorShape. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ITensorShape); + + /** TensorShape dim. */ + public dim: tensorflow.TensorShape.IDim[]; + + /** TensorShape unknownRank. */ + public unknownRank: boolean; + + /** + * Decodes a TensorShape message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns TensorShape + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.TensorShape; + } + + namespace TensorShape { + + /** Properties of a Dim. */ + interface IDim { + + /** Dim size */ + size?: (number|Long|null); + + /** Dim name */ + name?: (string|null); + } + + /** Represents a Dim. */ + class Dim implements IDim { + + /** + * Constructs a new Dim. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.TensorShape.IDim); + + /** Dim size. */ + public size: (number|Long); + + /** Dim name. */ + public name: string; + + /** + * Decodes a Dim message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns Dim + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.TensorShape.Dim; + } + } + + /** Properties of a Tensor. */ + interface ITensor { + + /** Tensor dtype */ + dtype?: (tensorflow.DataType|null); + + /** Tensor tensorShape */ + tensorShape?: (tensorflow.ITensorShape|null); + + /** Tensor versionNumber */ + versionNumber?: (number|null); + + /** Tensor tensorContent */ + tensorContent?: (Uint8Array|null); + + /** Tensor floatVal */ + floatVal?: (number[]|null); + + /** Tensor doubleVal */ + doubleVal?: (number[]|null); + + /** Tensor intVal */ + intVal?: (number[]|null); + + /** Tensor stringVal */ + stringVal?: (Uint8Array[]|null); + + /** Tensor scomplexVal */ + scomplexVal?: (number[]|null); + + /** Tensor int64Val */ + int64Val?: ((number|Long)[]|null); + + /** Tensor boolVal */ + boolVal?: (boolean[]|null); + + /** Tensor uint32Val */ + uint32Val?: (number[]|null); + + /** Tensor uint64Val */ + uint64Val?: ((number|Long)[]|null); + } + + /** Represents a Tensor. */ + class Tensor implements ITensor { + + /** + * Constructs a new Tensor. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ITensor); + + /** Tensor dtype. */ + public dtype: tensorflow.DataType; + + /** Tensor tensorShape. */ + public tensorShape?: (tensorflow.ITensorShape|null); + + /** Tensor versionNumber. */ + public versionNumber: number; + + /** Tensor tensorContent. */ + public tensorContent: Uint8Array; + + /** Tensor floatVal. */ + public floatVal: number[]; + + /** Tensor doubleVal. */ + public doubleVal: number[]; + + /** Tensor intVal. */ + public intVal: number[]; + + /** Tensor stringVal. */ + public stringVal: Uint8Array[]; + + /** Tensor scomplexVal. */ + public scomplexVal: number[]; + + /** Tensor int64Val. */ + public int64Val: (number|Long)[]; + + /** Tensor boolVal. */ + public boolVal: boolean[]; + + /** Tensor uint32Val. */ + public uint32Val: number[]; + + /** Tensor uint64Val. */ + public uint64Val: (number|Long)[]; + + /** + * Decodes a Tensor message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns Tensor + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.Tensor; + } + + /** Properties of an AttrValue. */ + interface IAttrValue { + + /** AttrValue list */ + list?: (tensorflow.AttrValue.IListValue|null); + + /** AttrValue s */ + s?: (Uint8Array|null); + + /** AttrValue i */ + i?: (number|Long|null); + + /** AttrValue f */ + f?: (number|null); + + /** AttrValue b */ + b?: (boolean|null); + + /** AttrValue type */ + type?: (tensorflow.DataType|null); + + /** AttrValue shape */ + shape?: (tensorflow.ITensorShape|null); + + /** AttrValue tensor */ + tensor?: (tensorflow.ITensor|null); + + /** AttrValue placeholder */ + placeholder?: (string|null); + + /** AttrValue func */ + func?: (tensorflow.INameAttrList|null); + } + + /** Represents an AttrValue. */ + class AttrValue implements IAttrValue { + + /** + * Constructs a new AttrValue. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IAttrValue); + + /** AttrValue list. */ + public list?: (tensorflow.AttrValue.IListValue|null); + + /** AttrValue s. */ + public s: Uint8Array; + + /** AttrValue i. */ + public i: (number|Long); + + /** AttrValue f. */ + public f: number; + + /** AttrValue b. */ + public b: boolean; + + /** AttrValue type. */ + public type: tensorflow.DataType; + + /** AttrValue shape. */ + public shape?: (tensorflow.ITensorShape|null); + + /** AttrValue tensor. */ + public tensor?: (tensorflow.ITensor|null); + + /** AttrValue placeholder. */ + public placeholder: string; + + /** AttrValue func. */ + public func?: (tensorflow.INameAttrList|null); + + /** AttrValue value. */ + public value?: ("list"|"s"|"i"|"f"|"b"|"type"|"shape"|"tensor"|"placeholder"|"func"); + + /** + * Decodes an AttrValue message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns AttrValue + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.AttrValue; + } + + namespace AttrValue { + + /** Properties of a ListValue. */ + interface IListValue { + + /** ListValue s */ + s?: (Uint8Array[]|null); + + /** ListValue i */ + i?: ((number|Long)[]|null); + + /** ListValue f */ + f?: (number[]|null); + + /** ListValue b */ + b?: (boolean[]|null); + + /** ListValue type */ + type?: (tensorflow.DataType[]|null); + + /** ListValue shape */ + shape?: (tensorflow.ITensorShape[]|null); + + /** ListValue tensor */ + tensor?: (tensorflow.ITensor[]|null); + + /** ListValue func */ + func?: (tensorflow.INameAttrList[]|null); + } + + /** Represents a ListValue. */ + class ListValue implements IListValue { + + /** + * Constructs a new ListValue. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.AttrValue.IListValue); + + /** ListValue s. */ + public s: Uint8Array[]; + + /** ListValue i. */ + public i: (number|Long)[]; + + /** ListValue f. */ + public f: number[]; + + /** ListValue b. */ + public b: boolean[]; + + /** ListValue type. */ + public type: tensorflow.DataType[]; + + /** ListValue shape. */ + public shape: tensorflow.ITensorShape[]; + + /** ListValue tensor. */ + public tensor: tensorflow.ITensor[]; + + /** ListValue func. */ + public func: tensorflow.INameAttrList[]; + + /** + * Decodes a ListValue message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns ListValue + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.AttrValue.ListValue; + } + } + + /** Properties of a NameAttrList. */ + interface INameAttrList { + + /** NameAttrList name */ + name?: (string|null); + + /** NameAttrList attr */ + attr?: ({ [k: string]: tensorflow.IAttrValue }|null); + } + + /** Represents a NameAttrList. */ + class NameAttrList implements INameAttrList { + + /** + * Constructs a new NameAttrList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.INameAttrList); + + /** NameAttrList name. */ + public name: string; + + /** NameAttrList attr. */ + public attr: { [k: string]: tensorflow.IAttrValue }; + + /** + * Decodes a NameAttrList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns NameAttrList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.NameAttrList; + } + + /** Properties of a NodeDef. */ + interface INodeDef { + + /** NodeDef name */ + name?: (string|null); + + /** NodeDef op */ + op?: (string|null); + + /** NodeDef input */ + input?: (string[]|null); + + /** NodeDef device */ + device?: (string|null); + + /** NodeDef attr */ + attr?: ({ [k: string]: tensorflow.IAttrValue }|null); + } + + /** Represents a NodeDef. */ + class NodeDef implements INodeDef { + + /** + * Constructs a new NodeDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.INodeDef); + + /** NodeDef name. */ + public name: string; + + /** NodeDef op. */ + public op: string; + + /** NodeDef input. */ + public input: string[]; + + /** NodeDef device. */ + public device: string; + + /** NodeDef attr. */ + public attr: { [k: string]: tensorflow.IAttrValue }; + + /** + * Decodes a NodeDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns NodeDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.NodeDef; + } + + /** Properties of a VersionDef. */ + interface IVersionDef { + + /** VersionDef producer */ + producer?: (number|null); + + /** VersionDef minConsumer */ + minConsumer?: (number|null); + + /** VersionDef badConsumers */ + badConsumers?: (number[]|null); + } + + /** Represents a VersionDef. */ + class VersionDef implements IVersionDef { + + /** + * Constructs a new VersionDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IVersionDef); + + /** VersionDef producer. */ + public producer: number; + + /** VersionDef minConsumer. */ + public minConsumer: number; + + /** VersionDef badConsumers. */ + public badConsumers: number[]; + + /** + * Decodes a VersionDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns VersionDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.VersionDef; + } + + /** Properties of a GraphDef. */ + interface IGraphDef { + + /** GraphDef node */ + node?: (tensorflow.INodeDef[]|null); + + /** GraphDef versions */ + versions?: (tensorflow.IVersionDef|null); + + /** GraphDef library */ + library?: (tensorflow.IFunctionDefLibrary|null); + } + + /** Represents a GraphDef. */ + class GraphDef implements IGraphDef { + + /** + * Constructs a new GraphDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IGraphDef); + + /** GraphDef node. */ + public node: tensorflow.INodeDef[]; + + /** GraphDef versions. */ + public versions?: (tensorflow.IVersionDef|null); + + /** GraphDef library. */ + public library?: (tensorflow.IFunctionDefLibrary|null); + + /** + * Decodes a GraphDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns GraphDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.GraphDef; + } + + /** Properties of a CollectionDef. */ + interface ICollectionDef { + + /** CollectionDef nodeList */ + nodeList?: (tensorflow.CollectionDef.INodeList|null); + + /** CollectionDef bytesList */ + bytesList?: (tensorflow.CollectionDef.IBytesList|null); + + /** CollectionDef int64List */ + int64List?: (tensorflow.CollectionDef.IInt64List|null); + + /** CollectionDef floatList */ + floatList?: (tensorflow.CollectionDef.IFloatList|null); + + /** CollectionDef anyList */ + anyList?: (tensorflow.CollectionDef.IAnyList|null); + } + + /** Represents a CollectionDef. */ + class CollectionDef implements ICollectionDef { + + /** + * Constructs a new CollectionDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ICollectionDef); + + /** CollectionDef nodeList. */ + public nodeList?: (tensorflow.CollectionDef.INodeList|null); + + /** CollectionDef bytesList. */ + public bytesList?: (tensorflow.CollectionDef.IBytesList|null); + + /** CollectionDef int64List. */ + public int64List?: (tensorflow.CollectionDef.IInt64List|null); + + /** CollectionDef floatList. */ + public floatList?: (tensorflow.CollectionDef.IFloatList|null); + + /** CollectionDef anyList. */ + public anyList?: (tensorflow.CollectionDef.IAnyList|null); + + /** CollectionDef kind. */ + public kind?: ("nodeList"|"bytesList"|"int64List"|"floatList"|"anyList"); + + /** + * Decodes a CollectionDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns CollectionDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef; + } + + namespace CollectionDef { + + /** Properties of a NodeList. */ + interface INodeList { + + /** NodeList value */ + value?: (string[]|null); + } + + /** Represents a NodeList. */ + class NodeList implements INodeList { + + /** + * Constructs a new NodeList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.CollectionDef.INodeList); + + /** NodeList value. */ + public value: string[]; + + /** + * Decodes a NodeList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns NodeList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef.NodeList; + } + + /** Properties of a BytesList. */ + interface IBytesList { + + /** BytesList value */ + value?: (Uint8Array[]|null); + } + + /** Represents a BytesList. */ + class BytesList implements IBytesList { + + /** + * Constructs a new BytesList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.CollectionDef.IBytesList); + + /** BytesList value. */ + public value: Uint8Array[]; + + /** + * Decodes a BytesList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns BytesList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef.BytesList; + } + + /** Properties of an Int64List. */ + interface IInt64List { + + /** Int64List value */ + value?: ((number|Long)[]|null); + } + + /** Represents an Int64List. */ + class Int64List implements IInt64List { + + /** + * Constructs a new Int64List. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.CollectionDef.IInt64List); + + /** Int64List value. */ + public value: (number|Long)[]; + + /** + * Decodes an Int64List message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns Int64List + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef.Int64List; + } + + /** Properties of a FloatList. */ + interface IFloatList { + + /** FloatList value */ + value?: (number[]|null); + } + + /** Represents a FloatList. */ + class FloatList implements IFloatList { + + /** + * Constructs a new FloatList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.CollectionDef.IFloatList); + + /** FloatList value. */ + public value: number[]; + + /** + * Decodes a FloatList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns FloatList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef.FloatList; + } + + /** Properties of an AnyList. */ + interface IAnyList { + + /** AnyList value */ + value?: (tensorflow.IAny[]|null); + } + + /** Represents an AnyList. */ + class AnyList implements IAnyList { + + /** + * Constructs a new AnyList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.CollectionDef.IAnyList); + + /** AnyList value. */ + public value: tensorflow.IAny[]; + + /** + * Decodes an AnyList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns AnyList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.CollectionDef.AnyList; + } + } + + /** Properties of a SaverDef. */ + interface ISaverDef { + + /** SaverDef filenameTensorName */ + filenameTensorName?: (string|null); + + /** SaverDef saveTensorName */ + saveTensorName?: (string|null); + + /** SaverDef restoreOpName */ + restoreOpName?: (string|null); + + /** SaverDef maxToKeep */ + maxToKeep?: (number|null); + + /** SaverDef sharded */ + sharded?: (boolean|null); + + /** SaverDef keepCheckpointEveryNHours */ + keepCheckpointEveryNHours?: (number|null); + + /** SaverDef version */ + version?: (tensorflow.SaverDef.CheckpointFormatVersion|null); + } + + /** Represents a SaverDef. */ + class SaverDef implements ISaverDef { + + /** + * Constructs a new SaverDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ISaverDef); + + /** SaverDef filenameTensorName. */ + public filenameTensorName: string; + + /** SaverDef saveTensorName. */ + public saveTensorName: string; + + /** SaverDef restoreOpName. */ + public restoreOpName: string; + + /** SaverDef maxToKeep. */ + public maxToKeep: number; + + /** SaverDef sharded. */ + public sharded: boolean; + + /** SaverDef keepCheckpointEveryNHours. */ + public keepCheckpointEveryNHours: number; + + /** SaverDef version. */ + public version: tensorflow.SaverDef.CheckpointFormatVersion; + + /** + * Decodes a SaverDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns SaverDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.SaverDef; + } + + namespace SaverDef { + + /** CheckpointFormatVersion enum. */ + enum CheckpointFormatVersion { + LEGACY = 0, + V1 = 1, + V2 = 2 + } + } + + /** Properties of a TensorInfo. */ + interface ITensorInfo { + + /** TensorInfo name */ + name?: (string|null); + + /** TensorInfo cooSparse */ + cooSparse?: (tensorflow.TensorInfo.ICooSparse|null); + + /** TensorInfo dtype */ + dtype?: (tensorflow.DataType|null); + + /** TensorInfo tensorShape */ + tensorShape?: (tensorflow.ITensorShape|null); + } + + /** Represents a TensorInfo. */ + class TensorInfo implements ITensorInfo { + + /** + * Constructs a new TensorInfo. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ITensorInfo); + + /** TensorInfo name. */ + public name: string; + + /** TensorInfo cooSparse. */ + public cooSparse?: (tensorflow.TensorInfo.ICooSparse|null); + + /** TensorInfo dtype. */ + public dtype: tensorflow.DataType; + + /** TensorInfo tensorShape. */ + public tensorShape?: (tensorflow.ITensorShape|null); + + /** TensorInfo encoding. */ + public encoding?: ("name"|"cooSparse"); + + /** + * Decodes a TensorInfo message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns TensorInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.TensorInfo; + } + + namespace TensorInfo { + + /** Properties of a CooSparse. */ + interface ICooSparse { + + /** CooSparse valuesTensorName */ + valuesTensorName?: (string|null); + + /** CooSparse indicesTensorName */ + indicesTensorName?: (string|null); + + /** CooSparse denseShapeTensorName */ + denseShapeTensorName?: (string|null); + } + + /** Represents a CooSparse. */ + class CooSparse implements ICooSparse { + + /** + * Constructs a new CooSparse. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.TensorInfo.ICooSparse); + + /** CooSparse valuesTensorName. */ + public valuesTensorName: string; + + /** CooSparse indicesTensorName. */ + public indicesTensorName: string; + + /** CooSparse denseShapeTensorName. */ + public denseShapeTensorName: string; + + /** + * Decodes a CooSparse message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns CooSparse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.TensorInfo.CooSparse; + } + } + + /** Properties of a SignatureDef. */ + interface ISignatureDef { + + /** SignatureDef inputs */ + inputs?: ({ [k: string]: tensorflow.ITensorInfo }|null); + + /** SignatureDef outputs */ + outputs?: ({ [k: string]: tensorflow.ITensorInfo }|null); + + /** SignatureDef methodName */ + methodName?: (string|null); + } + + /** Represents a SignatureDef. */ + class SignatureDef implements ISignatureDef { + + /** + * Constructs a new SignatureDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ISignatureDef); + + /** SignatureDef inputs. */ + public inputs: { [k: string]: tensorflow.ITensorInfo }; + + /** SignatureDef outputs. */ + public outputs: { [k: string]: tensorflow.ITensorInfo }; + + /** SignatureDef methodName. */ + public methodName: string; + + /** + * Decodes a SignatureDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns SignatureDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.SignatureDef; + } + + /** Properties of an AssetFileDef. */ + interface IAssetFileDef { + + /** AssetFileDef tensorInfo */ + tensorInfo?: (tensorflow.ITensorInfo|null); + + /** AssetFileDef filename */ + filename?: (string|null); + } + + /** Represents an AssetFileDef. */ + class AssetFileDef implements IAssetFileDef { + + /** + * Constructs a new AssetFileDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IAssetFileDef); + + /** AssetFileDef tensorInfo. */ + public tensorInfo?: (tensorflow.ITensorInfo|null); + + /** AssetFileDef filename. */ + public filename: string; + + /** + * Decodes an AssetFileDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns AssetFileDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.AssetFileDef; + } + + /** Properties of an OpDef. */ + interface IOpDef { + + /** OpDef name */ + name?: (string|null); + + /** OpDef inputArg */ + inputArg?: (tensorflow.OpDef.IArgDef[]|null); + + /** OpDef outputArg */ + outputArg?: (tensorflow.OpDef.IArgDef[]|null); + + /** OpDef attr */ + attr?: (tensorflow.OpDef.IAttrDef[]|null); + + /** OpDef deprecation */ + deprecation?: (tensorflow.OpDef.IOpDeprecation|null); + + /** OpDef summary */ + summary?: (string|null); + + /** OpDef description */ + description?: (string|null); + + /** OpDef isCommutative */ + isCommutative?: (boolean|null); + + /** OpDef isAggregate */ + isAggregate?: (boolean|null); + + /** OpDef isStateful */ + isStateful?: (boolean|null); + + /** OpDef allowsUninitializedInput */ + allowsUninitializedInput?: (boolean|null); + } + + /** Represents an OpDef. */ + class OpDef implements IOpDef { + + /** + * Constructs a new OpDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IOpDef); + + /** OpDef name. */ + public name: string; + + /** OpDef inputArg. */ + public inputArg: tensorflow.OpDef.IArgDef[]; + + /** OpDef outputArg. */ + public outputArg: tensorflow.OpDef.IArgDef[]; + + /** OpDef attr. */ + public attr: tensorflow.OpDef.IAttrDef[]; + + /** OpDef deprecation. */ + public deprecation?: (tensorflow.OpDef.IOpDeprecation|null); + + /** OpDef summary. */ + public summary: string; + + /** OpDef description. */ + public description: string; + + /** OpDef isCommutative. */ + public isCommutative: boolean; + + /** OpDef isAggregate. */ + public isAggregate: boolean; + + /** OpDef isStateful. */ + public isStateful: boolean; + + /** OpDef allowsUninitializedInput. */ + public allowsUninitializedInput: boolean; + + /** + * Decodes an OpDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns OpDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.OpDef; + } + + namespace OpDef { + + /** Properties of an ArgDef. */ + interface IArgDef { + + /** ArgDef name */ + name?: (string|null); + + /** ArgDef description */ + description?: (string|null); + + /** ArgDef type */ + type?: (tensorflow.DataType|null); + + /** ArgDef typeAttr */ + typeAttr?: (string|null); + + /** ArgDef numberAttr */ + numberAttr?: (string|null); + + /** ArgDef typeListAttr */ + typeListAttr?: (string|null); + + /** ArgDef isRef */ + isRef?: (boolean|null); + } + + /** Represents an ArgDef. */ + class ArgDef implements IArgDef { + + /** + * Constructs a new ArgDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.OpDef.IArgDef); + + /** ArgDef name. */ + public name: string; + + /** ArgDef description. */ + public description: string; + + /** ArgDef type. */ + public type: tensorflow.DataType; + + /** ArgDef typeAttr. */ + public typeAttr: string; + + /** ArgDef numberAttr. */ + public numberAttr: string; + + /** ArgDef typeListAttr. */ + public typeListAttr: string; + + /** ArgDef isRef. */ + public isRef: boolean; + + /** + * Decodes an ArgDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns ArgDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.OpDef.ArgDef; + } + + /** Properties of an AttrDef. */ + interface IAttrDef { + + /** AttrDef name */ + name?: (string|null); + + /** AttrDef type */ + type?: (string|null); + + /** AttrDef defaultValue */ + defaultValue?: (tensorflow.IAttrValue|null); + + /** AttrDef description */ + description?: (string|null); + + /** AttrDef hasMinimum */ + hasMinimum?: (boolean|null); + + /** AttrDef minimum */ + minimum?: (number|Long|null); + + /** AttrDef allowedValues */ + allowedValues?: (tensorflow.IAttrValue|null); + } + + /** Represents an AttrDef. */ + class AttrDef implements IAttrDef { + + /** + * Constructs a new AttrDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.OpDef.IAttrDef); + + /** AttrDef name. */ + public name: string; + + /** AttrDef type. */ + public type: string; + + /** AttrDef defaultValue. */ + public defaultValue?: (tensorflow.IAttrValue|null); + + /** AttrDef description. */ + public description: string; + + /** AttrDef hasMinimum. */ + public hasMinimum: boolean; + + /** AttrDef minimum. */ + public minimum: (number|Long); + + /** AttrDef allowedValues. */ + public allowedValues?: (tensorflow.IAttrValue|null); + + /** + * Decodes an AttrDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns AttrDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.OpDef.AttrDef; + } + + /** Properties of an OpDeprecation. */ + interface IOpDeprecation { + + /** OpDeprecation version */ + version?: (number|null); + + /** OpDeprecation explanation */ + explanation?: (string|null); + } + + /** Represents an OpDeprecation. */ + class OpDeprecation implements IOpDeprecation { + + /** + * Constructs a new OpDeprecation. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.OpDef.IOpDeprecation); + + /** OpDeprecation version. */ + public version: number; + + /** OpDeprecation explanation. */ + public explanation: string; + + /** + * Decodes an OpDeprecation message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns OpDeprecation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.OpDef.OpDeprecation; + } + } + + /** Properties of an OpList. */ + interface IOpList { + + /** OpList op */ + op?: (tensorflow.IOpDef[]|null); + } + + /** Represents an OpList. */ + class OpList implements IOpList { + + /** + * Constructs a new OpList. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IOpList); + + /** OpList op. */ + public op: tensorflow.IOpDef[]; + + /** + * Decodes an OpList message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns OpList + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.OpList; + } + + /** Properties of a MetaGraphDef. */ + interface IMetaGraphDef { + + /** MetaGraphDef metaInfoDef */ + metaInfoDef?: (tensorflow.MetaGraphDef.IMetaInfoDef|null); + + /** MetaGraphDef graphDef */ + graphDef?: (tensorflow.IGraphDef|null); + + /** MetaGraphDef saverDef */ + saverDef?: (tensorflow.ISaverDef|null); + + /** MetaGraphDef collectionDef */ + collectionDef?: ({ [k: string]: tensorflow.ICollectionDef }|null); + + /** MetaGraphDef signatureDef */ + signatureDef?: ({ [k: string]: tensorflow.ISignatureDef }|null); + + /** MetaGraphDef assetFileDef */ + assetFileDef?: (tensorflow.IAssetFileDef[]|null); + } + + /** Represents a MetaGraphDef. */ + class MetaGraphDef implements IMetaGraphDef { + + /** + * Constructs a new MetaGraphDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IMetaGraphDef); + + /** MetaGraphDef metaInfoDef. */ + public metaInfoDef?: (tensorflow.MetaGraphDef.IMetaInfoDef|null); + + /** MetaGraphDef graphDef. */ + public graphDef?: (tensorflow.IGraphDef|null); + + /** MetaGraphDef saverDef. */ + public saverDef?: (tensorflow.ISaverDef|null); + + /** MetaGraphDef collectionDef. */ + public collectionDef: { [k: string]: tensorflow.ICollectionDef }; + + /** MetaGraphDef signatureDef. */ + public signatureDef: { [k: string]: tensorflow.ISignatureDef }; + + /** MetaGraphDef assetFileDef. */ + public assetFileDef: tensorflow.IAssetFileDef[]; + + /** + * Decodes a MetaGraphDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns MetaGraphDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.MetaGraphDef; + } + + namespace MetaGraphDef { + + /** Properties of a MetaInfoDef. */ + interface IMetaInfoDef { + + /** MetaInfoDef metaGraphVersion */ + metaGraphVersion?: (string|null); + + /** MetaInfoDef strippedOpList */ + strippedOpList?: (tensorflow.IOpList|null); + + /** MetaInfoDef anyInfo */ + anyInfo?: (tensorflow.IAny|null); + + /** MetaInfoDef tags */ + tags?: (string[]|null); + + /** MetaInfoDef tensorflowVersion */ + tensorflowVersion?: (string|null); + + /** MetaInfoDef tensorflowGitVersion */ + tensorflowGitVersion?: (string|null); + } + + /** Represents a MetaInfoDef. */ + class MetaInfoDef implements IMetaInfoDef { + + /** + * Constructs a new MetaInfoDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.MetaGraphDef.IMetaInfoDef); + + /** MetaInfoDef metaGraphVersion. */ + public metaGraphVersion: string; + + /** MetaInfoDef strippedOpList. */ + public strippedOpList?: (tensorflow.IOpList|null); + + /** MetaInfoDef anyInfo. */ + public anyInfo?: (tensorflow.IAny|null); + + /** MetaInfoDef tags. */ + public tags: string[]; + + /** MetaInfoDef tensorflowVersion. */ + public tensorflowVersion: string; + + /** MetaInfoDef tensorflowGitVersion. */ + public tensorflowGitVersion: string; + + /** + * Decodes a MetaInfoDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns MetaInfoDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.MetaGraphDef.MetaInfoDef; + } + } + + /** Properties of a SavedModel. */ + interface ISavedModel { + + /** SavedModel savedModelSchemaVersion */ + savedModelSchemaVersion?: (number|Long|null); + + /** SavedModel metaGraphs */ + metaGraphs?: (tensorflow.IMetaGraphDef[]|null); + } + + /** Represents a SavedModel. */ + class SavedModel implements ISavedModel { + + /** + * Constructs a new SavedModel. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.ISavedModel); + + /** SavedModel savedModelSchemaVersion. */ + public savedModelSchemaVersion: (number|Long); + + /** SavedModel metaGraphs. */ + public metaGraphs: tensorflow.IMetaGraphDef[]; + + /** + * Decodes a SavedModel message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns SavedModel + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.SavedModel; + } + + /** Properties of a FunctionDefLibrary. */ + interface IFunctionDefLibrary { + + /** FunctionDefLibrary function */ + "function"?: (tensorflow.IFunctionDef[]|null); + + /** FunctionDefLibrary gradient */ + gradient?: (tensorflow.IGradientDef[]|null); + } + + /** Represents a FunctionDefLibrary. */ + class FunctionDefLibrary implements IFunctionDefLibrary { + + /** + * Constructs a new FunctionDefLibrary. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IFunctionDefLibrary); + + /** FunctionDefLibrary function. */ + public function: tensorflow.IFunctionDef[]; + + /** FunctionDefLibrary gradient. */ + public gradient: tensorflow.IGradientDef[]; + + /** + * Decodes a FunctionDefLibrary message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns FunctionDefLibrary + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.FunctionDefLibrary; + } + + /** Properties of a FunctionDef. */ + interface IFunctionDef { + + /** FunctionDef signature */ + signature?: (tensorflow.IOpDef|null); + + /** FunctionDef attr */ + attr?: ({ [k: string]: tensorflow.IAttrValue }|null); + + /** FunctionDef nodeDef */ + nodeDef?: (tensorflow.INodeDef[]|null); + + /** FunctionDef ret */ + ret?: ({ [k: string]: string }|null); + } + + /** Represents a FunctionDef. */ + class FunctionDef implements IFunctionDef { + + /** + * Constructs a new FunctionDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IFunctionDef); + + /** FunctionDef signature. */ + public signature?: (tensorflow.IOpDef|null); + + /** FunctionDef attr. */ + public attr: { [k: string]: tensorflow.IAttrValue }; + + /** FunctionDef nodeDef. */ + public nodeDef: tensorflow.INodeDef[]; + + /** FunctionDef ret. */ + public ret: { [k: string]: string }; + + /** + * Decodes a FunctionDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns FunctionDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.FunctionDef; + } + + /** Properties of a GradientDef. */ + interface IGradientDef { + + /** GradientDef functionName */ + functionName?: (string|null); + + /** GradientDef gradientFunc */ + gradientFunc?: (string|null); + } + + /** Represents a GradientDef. */ + class GradientDef implements IGradientDef { + + /** + * Constructs a new GradientDef. + * @param [p] Properties to set + */ + constructor(p?: tensorflow.IGradientDef); + + /** GradientDef functionName. */ + public functionName: string; + + /** GradientDef gradientFunc. */ + public gradientFunc: string; + + /** + * Decodes a GradientDef message from the specified reader or buffer. + * @param r Reader or buffer to decode from + * @param [l] Message length if known beforehand + * @returns GradientDef + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(r: ($protobuf.Reader|Uint8Array), l?: number): tensorflow.GradientDef; + } +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.js b/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.js new file mode 100644 index 0000000..89e3c9b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/data/compiled_api.js @@ -0,0 +1,1723 @@ +/*eslint-disable block-scoped-var, no-redeclare, no-control-regex, no-prototype-builtins*/ +"use strict"; + +var $protobuf = require("protobufjs/minimal"); + +var $Reader = $protobuf.Reader, $util = $protobuf.util; + +var $root = $protobuf.roots["default"] || ($protobuf.roots["default"] = {}); + +$root.tensorflow = (function() { + + var tensorflow = {}; + + tensorflow.Any = (function() { + + function Any(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Any.prototype.typeUrl = ""; + Any.prototype.value = $util.newBuffer([]); + + Any.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.Any(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.typeUrl = r.string(); + break; + case 2: + m.value = r.bytes(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Any; + })(); + + tensorflow.DataType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "DT_INVALID"] = 0; + values[valuesById[1] = "DT_FLOAT"] = 1; + values[valuesById[2] = "DT_DOUBLE"] = 2; + values[valuesById[3] = "DT_INT32"] = 3; + values[valuesById[4] = "DT_UINT8"] = 4; + values[valuesById[5] = "DT_INT16"] = 5; + values[valuesById[6] = "DT_INT8"] = 6; + values[valuesById[7] = "DT_STRING"] = 7; + values[valuesById[8] = "DT_COMPLEX64"] = 8; + values[valuesById[9] = "DT_INT64"] = 9; + values[valuesById[10] = "DT_BOOL"] = 10; + values[valuesById[11] = "DT_QINT8"] = 11; + values[valuesById[12] = "DT_QUINT8"] = 12; + values[valuesById[13] = "DT_QINT32"] = 13; + values[valuesById[14] = "DT_BFLOAT16"] = 14; + values[valuesById[101] = "DT_FLOAT_REF"] = 101; + values[valuesById[102] = "DT_DOUBLE_REF"] = 102; + values[valuesById[103] = "DT_INT32_REF"] = 103; + values[valuesById[104] = "DT_UINT8_REF"] = 104; + values[valuesById[105] = "DT_INT16_REF"] = 105; + values[valuesById[106] = "DT_INT8_REF"] = 106; + values[valuesById[107] = "DT_STRING_REF"] = 107; + values[valuesById[108] = "DT_COMPLEX64_REF"] = 108; + values[valuesById[109] = "DT_INT64_REF"] = 109; + values[valuesById[110] = "DT_BOOL_REF"] = 110; + values[valuesById[111] = "DT_QINT8_REF"] = 111; + values[valuesById[112] = "DT_QUINT8_REF"] = 112; + values[valuesById[113] = "DT_QINT32_REF"] = 113; + values[valuesById[114] = "DT_BFLOAT16_REF"] = 114; + return values; + })(); + + tensorflow.TensorShape = (function() { + + function TensorShape(p) { + this.dim = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + TensorShape.prototype.dim = $util.emptyArray; + TensorShape.prototype.unknownRank = false; + + TensorShape.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorShape(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 2: + if (!(m.dim && m.dim.length)) + m.dim = []; + m.dim.push($root.tensorflow.TensorShape.Dim.decode(r, r.uint32())); + break; + case 3: + m.unknownRank = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + TensorShape.Dim = (function() { + + function Dim(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Dim.prototype.size = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + Dim.prototype.name = ""; + + Dim.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorShape.Dim(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.size = r.int64(); + break; + case 2: + m.name = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Dim; + })(); + + return TensorShape; + })(); + + tensorflow.Tensor = (function() { + + function Tensor(p) { + this.floatVal = []; + this.doubleVal = []; + this.intVal = []; + this.stringVal = []; + this.scomplexVal = []; + this.int64Val = []; + this.boolVal = []; + this.uint32Val = []; + this.uint64Val = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Tensor.prototype.dtype = 0; + Tensor.prototype.tensorShape = null; + Tensor.prototype.versionNumber = 0; + Tensor.prototype.tensorContent = $util.newBuffer([]); + Tensor.prototype.floatVal = $util.emptyArray; + Tensor.prototype.doubleVal = $util.emptyArray; + Tensor.prototype.intVal = $util.emptyArray; + Tensor.prototype.stringVal = $util.emptyArray; + Tensor.prototype.scomplexVal = $util.emptyArray; + Tensor.prototype.int64Val = $util.emptyArray; + Tensor.prototype.boolVal = $util.emptyArray; + Tensor.prototype.uint32Val = $util.emptyArray; + Tensor.prototype.uint64Val = $util.emptyArray; + + Tensor.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.Tensor(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.dtype = r.int32(); + break; + case 2: + m.tensorShape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + case 3: + m.versionNumber = r.int32(); + break; + case 4: + m.tensorContent = r.bytes(); + break; + case 5: + if (!(m.floatVal && m.floatVal.length)) + m.floatVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.floatVal.push(r.float()); + } else + m.floatVal.push(r.float()); + break; + case 6: + if (!(m.doubleVal && m.doubleVal.length)) + m.doubleVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.doubleVal.push(r.double()); + } else + m.doubleVal.push(r.double()); + break; + case 7: + if (!(m.intVal && m.intVal.length)) + m.intVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.intVal.push(r.int32()); + } else + m.intVal.push(r.int32()); + break; + case 8: + if (!(m.stringVal && m.stringVal.length)) + m.stringVal = []; + m.stringVal.push(r.bytes()); + break; + case 9: + if (!(m.scomplexVal && m.scomplexVal.length)) + m.scomplexVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.scomplexVal.push(r.float()); + } else + m.scomplexVal.push(r.float()); + break; + case 10: + if (!(m.int64Val && m.int64Val.length)) + m.int64Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.int64Val.push(r.int64()); + } else + m.int64Val.push(r.int64()); + break; + case 11: + if (!(m.boolVal && m.boolVal.length)) + m.boolVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.boolVal.push(r.bool()); + } else + m.boolVal.push(r.bool()); + break; + case 16: + if (!(m.uint32Val && m.uint32Val.length)) + m.uint32Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.uint32Val.push(r.uint32()); + } else + m.uint32Val.push(r.uint32()); + break; + case 17: + if (!(m.uint64Val && m.uint64Val.length)) + m.uint64Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.uint64Val.push(r.uint64()); + } else + m.uint64Val.push(r.uint64()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Tensor; + })(); + + tensorflow.AttrValue = (function() { + + function AttrValue(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AttrValue.prototype.list = null; + AttrValue.prototype.s = $util.newBuffer([]); + AttrValue.prototype.i = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + AttrValue.prototype.f = 0; + AttrValue.prototype.b = false; + AttrValue.prototype.type = 0; + AttrValue.prototype.shape = null; + AttrValue.prototype.tensor = null; + AttrValue.prototype.placeholder = ""; + AttrValue.prototype.func = null; + + var $oneOfFields; + + Object.defineProperty(AttrValue.prototype, "value", { + get: $util.oneOfGetter($oneOfFields = ["list", "s", "i", "f", "b", "type", "shape", "tensor", "placeholder", "func"]), + set: $util.oneOfSetter($oneOfFields) + }); + + AttrValue.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AttrValue(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.list = $root.tensorflow.AttrValue.ListValue.decode(r, r.uint32()); + break; + case 2: + m.s = r.bytes(); + break; + case 3: + m.i = r.int64(); + break; + case 4: + m.f = r.float(); + break; + case 5: + m.b = r.bool(); + break; + case 6: + m.type = r.int32(); + break; + case 7: + m.shape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + case 8: + m.tensor = $root.tensorflow.Tensor.decode(r, r.uint32()); + break; + case 9: + m.placeholder = r.string(); + break; + case 10: + m.func = $root.tensorflow.NameAttrList.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + AttrValue.ListValue = (function() { + + function ListValue(p) { + this.s = []; + this.i = []; + this.f = []; + this.b = []; + this.type = []; + this.shape = []; + this.tensor = []; + this.func = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + ListValue.prototype.s = $util.emptyArray; + ListValue.prototype.i = $util.emptyArray; + ListValue.prototype.f = $util.emptyArray; + ListValue.prototype.b = $util.emptyArray; + ListValue.prototype.type = $util.emptyArray; + ListValue.prototype.shape = $util.emptyArray; + ListValue.prototype.tensor = $util.emptyArray; + ListValue.prototype.func = $util.emptyArray; + + ListValue.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AttrValue.ListValue(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 2: + if (!(m.s && m.s.length)) + m.s = []; + m.s.push(r.bytes()); + break; + case 3: + if (!(m.i && m.i.length)) + m.i = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.i.push(r.int64()); + } else + m.i.push(r.int64()); + break; + case 4: + if (!(m.f && m.f.length)) + m.f = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.f.push(r.float()); + } else + m.f.push(r.float()); + break; + case 5: + if (!(m.b && m.b.length)) + m.b = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.b.push(r.bool()); + } else + m.b.push(r.bool()); + break; + case 6: + if (!(m.type && m.type.length)) + m.type = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.type.push(r.int32()); + } else + m.type.push(r.int32()); + break; + case 7: + if (!(m.shape && m.shape.length)) + m.shape = []; + m.shape.push($root.tensorflow.TensorShape.decode(r, r.uint32())); + break; + case 8: + if (!(m.tensor && m.tensor.length)) + m.tensor = []; + m.tensor.push($root.tensorflow.Tensor.decode(r, r.uint32())); + break; + case 9: + if (!(m.func && m.func.length)) + m.func = []; + m.func.push($root.tensorflow.NameAttrList.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return ListValue; + })(); + + return AttrValue; + })(); + + tensorflow.NameAttrList = (function() { + + function NameAttrList(p) { + this.attr = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NameAttrList.prototype.name = ""; + NameAttrList.prototype.attr = $util.emptyObject; + + NameAttrList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.NameAttrList(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NameAttrList; + })(); + + tensorflow.NodeDef = (function() { + + function NodeDef(p) { + this.input = []; + this.attr = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NodeDef.prototype.name = ""; + NodeDef.prototype.op = ""; + NodeDef.prototype.input = $util.emptyArray; + NodeDef.prototype.device = ""; + NodeDef.prototype.attr = $util.emptyObject; + + NodeDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.NodeDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.op = r.string(); + break; + case 3: + if (!(m.input && m.input.length)) + m.input = []; + m.input.push(r.string()); + break; + case 4: + m.device = r.string(); + break; + case 5: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NodeDef; + })(); + + tensorflow.VersionDef = (function() { + + function VersionDef(p) { + this.badConsumers = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + VersionDef.prototype.producer = 0; + VersionDef.prototype.minConsumer = 0; + VersionDef.prototype.badConsumers = $util.emptyArray; + + VersionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.VersionDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.producer = r.int32(); + break; + case 2: + m.minConsumer = r.int32(); + break; + case 3: + if (!(m.badConsumers && m.badConsumers.length)) + m.badConsumers = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.badConsumers.push(r.int32()); + } else + m.badConsumers.push(r.int32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return VersionDef; + })(); + + tensorflow.GraphDef = (function() { + + function GraphDef(p) { + this.node = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + GraphDef.prototype.node = $util.emptyArray; + GraphDef.prototype.versions = null; + GraphDef.prototype.library = null; + + GraphDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.GraphDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.node && m.node.length)) + m.node = []; + m.node.push($root.tensorflow.NodeDef.decode(r, r.uint32())); + break; + case 4: + m.versions = $root.tensorflow.VersionDef.decode(r, r.uint32()); + break; + case 2: + m.library = $root.tensorflow.FunctionDefLibrary.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return GraphDef; + })(); + + tensorflow.CollectionDef = (function() { + + function CollectionDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + CollectionDef.prototype.nodeList = null; + CollectionDef.prototype.bytesList = null; + CollectionDef.prototype.int64List = null; + CollectionDef.prototype.floatList = null; + CollectionDef.prototype.anyList = null; + + var $oneOfFields; + + Object.defineProperty(CollectionDef.prototype, "kind", { + get: $util.oneOfGetter($oneOfFields = ["nodeList", "bytesList", "int64List", "floatList", "anyList"]), + set: $util.oneOfSetter($oneOfFields) + }); + + CollectionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.nodeList = $root.tensorflow.CollectionDef.NodeList.decode(r, r.uint32()); + break; + case 2: + m.bytesList = $root.tensorflow.CollectionDef.BytesList.decode(r, r.uint32()); + break; + case 3: + m.int64List = $root.tensorflow.CollectionDef.Int64List.decode(r, r.uint32()); + break; + case 4: + m.floatList = $root.tensorflow.CollectionDef.FloatList.decode(r, r.uint32()); + break; + case 5: + m.anyList = $root.tensorflow.CollectionDef.AnyList.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + CollectionDef.NodeList = (function() { + + function NodeList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NodeList.prototype.value = $util.emptyArray; + + NodeList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.NodeList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push(r.string()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NodeList; + })(); + + CollectionDef.BytesList = (function() { + + function BytesList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + BytesList.prototype.value = $util.emptyArray; + + BytesList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.BytesList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push(r.bytes()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return BytesList; + })(); + + CollectionDef.Int64List = (function() { + + function Int64List(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Int64List.prototype.value = $util.emptyArray; + + Int64List.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.Int64List(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.value.push(r.int64()); + } else + m.value.push(r.int64()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Int64List; + })(); + + CollectionDef.FloatList = (function() { + + function FloatList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FloatList.prototype.value = $util.emptyArray; + + FloatList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.FloatList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.value.push(r.float()); + } else + m.value.push(r.float()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FloatList; + })(); + + CollectionDef.AnyList = (function() { + + function AnyList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AnyList.prototype.value = $util.emptyArray; + + AnyList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.AnyList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push($root.tensorflow.Any.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AnyList; + })(); + + return CollectionDef; + })(); + + tensorflow.SaverDef = (function() { + + function SaverDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SaverDef.prototype.filenameTensorName = ""; + SaverDef.prototype.saveTensorName = ""; + SaverDef.prototype.restoreOpName = ""; + SaverDef.prototype.maxToKeep = 0; + SaverDef.prototype.sharded = false; + SaverDef.prototype.keepCheckpointEveryNHours = 0; + SaverDef.prototype.version = 0; + + SaverDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SaverDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.filenameTensorName = r.string(); + break; + case 2: + m.saveTensorName = r.string(); + break; + case 3: + m.restoreOpName = r.string(); + break; + case 4: + m.maxToKeep = r.int32(); + break; + case 5: + m.sharded = r.bool(); + break; + case 6: + m.keepCheckpointEveryNHours = r.float(); + break; + case 7: + m.version = r.int32(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + SaverDef.CheckpointFormatVersion = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "LEGACY"] = 0; + values[valuesById[1] = "V1"] = 1; + values[valuesById[2] = "V2"] = 2; + return values; + })(); + + return SaverDef; + })(); + + tensorflow.TensorInfo = (function() { + + function TensorInfo(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + TensorInfo.prototype.name = ""; + TensorInfo.prototype.cooSparse = null; + TensorInfo.prototype.dtype = 0; + TensorInfo.prototype.tensorShape = null; + + var $oneOfFields; + + Object.defineProperty(TensorInfo.prototype, "encoding", { + get: $util.oneOfGetter($oneOfFields = ["name", "cooSparse"]), + set: $util.oneOfSetter($oneOfFields) + }); + + TensorInfo.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorInfo(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 4: + m.cooSparse = $root.tensorflow.TensorInfo.CooSparse.decode(r, r.uint32()); + break; + case 2: + m.dtype = r.int32(); + break; + case 3: + m.tensorShape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + TensorInfo.CooSparse = (function() { + + function CooSparse(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + CooSparse.prototype.valuesTensorName = ""; + CooSparse.prototype.indicesTensorName = ""; + CooSparse.prototype.denseShapeTensorName = ""; + + CooSparse.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorInfo.CooSparse(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.valuesTensorName = r.string(); + break; + case 2: + m.indicesTensorName = r.string(); + break; + case 3: + m.denseShapeTensorName = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return CooSparse; + })(); + + return TensorInfo; + })(); + + tensorflow.SignatureDef = (function() { + + function SignatureDef(p) { + this.inputs = {}; + this.outputs = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SignatureDef.prototype.inputs = $util.emptyObject; + SignatureDef.prototype.outputs = $util.emptyObject; + SignatureDef.prototype.methodName = ""; + + SignatureDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SignatureDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + r.skip().pos++; + if (m.inputs === $util.emptyObject) + m.inputs = {}; + k = r.string(); + r.pos++; + m.inputs[k] = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 2: + r.skip().pos++; + if (m.outputs === $util.emptyObject) + m.outputs = {}; + k = r.string(); + r.pos++; + m.outputs[k] = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 3: + m.methodName = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return SignatureDef; + })(); + + tensorflow.AssetFileDef = (function() { + + function AssetFileDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AssetFileDef.prototype.tensorInfo = null; + AssetFileDef.prototype.filename = ""; + + AssetFileDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AssetFileDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.tensorInfo = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 2: + m.filename = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AssetFileDef; + })(); + + tensorflow.OpDef = (function() { + + function OpDef(p) { + this.inputArg = []; + this.outputArg = []; + this.attr = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpDef.prototype.name = ""; + OpDef.prototype.inputArg = $util.emptyArray; + OpDef.prototype.outputArg = $util.emptyArray; + OpDef.prototype.attr = $util.emptyArray; + OpDef.prototype.deprecation = null; + OpDef.prototype.summary = ""; + OpDef.prototype.description = ""; + OpDef.prototype.isCommutative = false; + OpDef.prototype.isAggregate = false; + OpDef.prototype.isStateful = false; + OpDef.prototype.allowsUninitializedInput = false; + + OpDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + if (!(m.inputArg && m.inputArg.length)) + m.inputArg = []; + m.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(r, r.uint32())); + break; + case 3: + if (!(m.outputArg && m.outputArg.length)) + m.outputArg = []; + m.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(r, r.uint32())); + break; + case 4: + if (!(m.attr && m.attr.length)) + m.attr = []; + m.attr.push($root.tensorflow.OpDef.AttrDef.decode(r, r.uint32())); + break; + case 8: + m.deprecation = $root.tensorflow.OpDef.OpDeprecation.decode(r, r.uint32()); + break; + case 5: + m.summary = r.string(); + break; + case 6: + m.description = r.string(); + break; + case 18: + m.isCommutative = r.bool(); + break; + case 16: + m.isAggregate = r.bool(); + break; + case 17: + m.isStateful = r.bool(); + break; + case 19: + m.allowsUninitializedInput = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + OpDef.ArgDef = (function() { + + function ArgDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + ArgDef.prototype.name = ""; + ArgDef.prototype.description = ""; + ArgDef.prototype.type = 0; + ArgDef.prototype.typeAttr = ""; + ArgDef.prototype.numberAttr = ""; + ArgDef.prototype.typeListAttr = ""; + ArgDef.prototype.isRef = false; + + ArgDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.ArgDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.description = r.string(); + break; + case 3: + m.type = r.int32(); + break; + case 4: + m.typeAttr = r.string(); + break; + case 5: + m.numberAttr = r.string(); + break; + case 6: + m.typeListAttr = r.string(); + break; + case 16: + m.isRef = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return ArgDef; + })(); + + OpDef.AttrDef = (function() { + + function AttrDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AttrDef.prototype.name = ""; + AttrDef.prototype.type = ""; + AttrDef.prototype.defaultValue = null; + AttrDef.prototype.description = ""; + AttrDef.prototype.hasMinimum = false; + AttrDef.prototype.minimum = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + AttrDef.prototype.allowedValues = null; + + AttrDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.AttrDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.type = r.string(); + break; + case 3: + m.defaultValue = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + case 4: + m.description = r.string(); + break; + case 5: + m.hasMinimum = r.bool(); + break; + case 6: + m.minimum = r.int64(); + break; + case 7: + m.allowedValues = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AttrDef; + })(); + + OpDef.OpDeprecation = (function() { + + function OpDeprecation(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpDeprecation.prototype.version = 0; + OpDeprecation.prototype.explanation = ""; + + OpDeprecation.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.OpDeprecation(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.version = r.int32(); + break; + case 2: + m.explanation = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return OpDeprecation; + })(); + + return OpDef; + })(); + + tensorflow.OpList = (function() { + + function OpList(p) { + this.op = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpList.prototype.op = $util.emptyArray; + + OpList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.op && m.op.length)) + m.op = []; + m.op.push($root.tensorflow.OpDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return OpList; + })(); + + tensorflow.MetaGraphDef = (function() { + + function MetaGraphDef(p) { + this.collectionDef = {}; + this.signatureDef = {}; + this.assetFileDef = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + MetaGraphDef.prototype.metaInfoDef = null; + MetaGraphDef.prototype.graphDef = null; + MetaGraphDef.prototype.saverDef = null; + MetaGraphDef.prototype.collectionDef = $util.emptyObject; + MetaGraphDef.prototype.signatureDef = $util.emptyObject; + MetaGraphDef.prototype.assetFileDef = $util.emptyArray; + + MetaGraphDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.MetaGraphDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.metaInfoDef = $root.tensorflow.MetaGraphDef.MetaInfoDef.decode(r, r.uint32()); + break; + case 2: + m.graphDef = $root.tensorflow.GraphDef.decode(r, r.uint32()); + break; + case 3: + m.saverDef = $root.tensorflow.SaverDef.decode(r, r.uint32()); + break; + case 4: + r.skip().pos++; + if (m.collectionDef === $util.emptyObject) + m.collectionDef = {}; + k = r.string(); + r.pos++; + m.collectionDef[k] = $root.tensorflow.CollectionDef.decode(r, r.uint32()); + break; + case 5: + r.skip().pos++; + if (m.signatureDef === $util.emptyObject) + m.signatureDef = {}; + k = r.string(); + r.pos++; + m.signatureDef[k] = $root.tensorflow.SignatureDef.decode(r, r.uint32()); + break; + case 6: + if (!(m.assetFileDef && m.assetFileDef.length)) + m.assetFileDef = []; + m.assetFileDef.push($root.tensorflow.AssetFileDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + MetaGraphDef.MetaInfoDef = (function() { + + function MetaInfoDef(p) { + this.tags = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + MetaInfoDef.prototype.metaGraphVersion = ""; + MetaInfoDef.prototype.strippedOpList = null; + MetaInfoDef.prototype.anyInfo = null; + MetaInfoDef.prototype.tags = $util.emptyArray; + MetaInfoDef.prototype.tensorflowVersion = ""; + MetaInfoDef.prototype.tensorflowGitVersion = ""; + + MetaInfoDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.MetaGraphDef.MetaInfoDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.metaGraphVersion = r.string(); + break; + case 2: + m.strippedOpList = $root.tensorflow.OpList.decode(r, r.uint32()); + break; + case 3: + m.anyInfo = $root.tensorflow.Any.decode(r, r.uint32()); + break; + case 4: + if (!(m.tags && m.tags.length)) + m.tags = []; + m.tags.push(r.string()); + break; + case 5: + m.tensorflowVersion = r.string(); + break; + case 6: + m.tensorflowGitVersion = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return MetaInfoDef; + })(); + + return MetaGraphDef; + })(); + + tensorflow.SavedModel = (function() { + + function SavedModel(p) { + this.metaGraphs = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SavedModel.prototype.savedModelSchemaVersion = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + SavedModel.prototype.metaGraphs = $util.emptyArray; + + SavedModel.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SavedModel(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.savedModelSchemaVersion = r.int64(); + break; + case 2: + if (!(m.metaGraphs && m.metaGraphs.length)) + m.metaGraphs = []; + m.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return SavedModel; + })(); + + tensorflow.FunctionDefLibrary = (function() { + + function FunctionDefLibrary(p) { + this["function"] = []; + this.gradient = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FunctionDefLibrary.prototype["function"] = $util.emptyArray; + FunctionDefLibrary.prototype.gradient = $util.emptyArray; + + FunctionDefLibrary.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.FunctionDefLibrary(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m["function"] && m["function"].length)) + m["function"] = []; + m["function"].push($root.tensorflow.FunctionDef.decode(r, r.uint32())); + break; + case 2: + if (!(m.gradient && m.gradient.length)) + m.gradient = []; + m.gradient.push($root.tensorflow.GradientDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FunctionDefLibrary; + })(); + + tensorflow.FunctionDef = (function() { + + function FunctionDef(p) { + this.attr = {}; + this.nodeDef = []; + this.ret = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FunctionDef.prototype.signature = null; + FunctionDef.prototype.attr = $util.emptyObject; + FunctionDef.prototype.nodeDef = $util.emptyArray; + FunctionDef.prototype.ret = $util.emptyObject; + + FunctionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.FunctionDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.signature = $root.tensorflow.OpDef.decode(r, r.uint32()); + break; + case 5: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + case 3: + if (!(m.nodeDef && m.nodeDef.length)) + m.nodeDef = []; + m.nodeDef.push($root.tensorflow.NodeDef.decode(r, r.uint32())); + break; + case 4: + r.skip().pos++; + if (m.ret === $util.emptyObject) + m.ret = {}; + k = r.string(); + r.pos++; + m.ret[k] = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FunctionDef; + })(); + + tensorflow.GradientDef = (function() { + + function GradientDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + GradientDef.prototype.functionName = ""; + GradientDef.prototype.gradientFunc = ""; + + GradientDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.GradientDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.functionName = r.string(); + break; + case 2: + m.gradientFunc = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return GradientDef; + })(); + + return tensorflow; +})(); + +module.exports = $root; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/data/types.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/data/types.d.ts new file mode 100644 index 0000000..5a10e54 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/data/types.d.ts @@ -0,0 +1,16 @@ +import { DataType, Tensor } from '@tensorflow/tfjs-core'; +import { TensorArray } from '../executor/tensor_array'; +export declare type NamedTensorMap = { + [key: string]: Tensor; +}; +export declare type NamedTensorsMap = { + [key: string]: Tensor[]; +}; +export declare type TensorArrayMap = { + [key: number]: TensorArray; +}; +export interface TensorInfo { + name: string; + shape?: number[]; + dtype: DataType; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/data/types.js b/node_modules/@tensorflow/tfjs-converter/dist/data/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/data/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.js b/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.js new file mode 100644 index 0000000..322fbc7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/docs/doc_gen.js @@ -0,0 +1,121 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var fs = require("fs"); +var node_fetch_1 = require("node-fetch"); +var arithmetic = require("../operations/op_list/arithmetic.json"); +var basicMath = require("../operations/op_list/basic_math.json"); +var control = require("../operations/op_list/control.json"); +var convolution = require("../operations/op_list/convolution.json"); +var creation = require("../operations/op_list/creation.json"); +var graph = require("../operations/op_list/graph.json"); +var image = require("../operations/op_list/image.json"); +var logical = require("../operations/op_list/logical.json"); +var matrices = require("../operations/op_list/matrices.json"); +var normalization = require("../operations/op_list/normalization.json"); +var reduction = require("../operations/op_list/reduction.json"); +var sliceJoin = require("../operations/op_list/slice_join.json"); +var transformation = require("../operations/op_list/transformation.json"); +var DOC_DIR = './docs/'; +var opMappers = arithmetic.concat(basicMath, control, convolution, creation, logical, image, graph, matrices, normalization, reduction, sliceJoin, transformation); +var GITHUB_URL_PREFIX = 'https://raw.githubusercontent.com/tensorflow/tfjs-website'; +var CORE_API_PREFIX = "/master/source/_data/api/" + tfc.version_core + "/tfjs-core.json"; +function genDoc() { + return __awaiter(this, void 0, void 0, function () { + var response, json, coreApis, output; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, node_fetch_1.default(GITHUB_URL_PREFIX + CORE_API_PREFIX)]; + case 1: + response = _a.sent(); + return [4, response.json()]; + case 2: + json = _a.sent(); + coreApis = json.docs.headings.reduce(function (list, h) { + return h.subheadings ? list.concat(h.subheadings.reduce(function (sublist, sub) { + return sublist.concat(sub.symbols); + }, [])) : + list; + }, []); + output = []; + output.push('# Supported Tensorflow Ops\n\n'); + generateTable('Operations', 'Arithmetic', arithmetic, output, coreApis); + generateTable('Operations', 'Basic math', basicMath, output, coreApis); + generateTable('Operations', 'Control Flow', control, output, coreApis); + generateTable('Operations', 'Convolution', convolution, output, coreApis); + generateTable('Tensors', 'Creation', creation, output, coreApis); + generateTable('Tensorflow', 'Graph', graph, output, coreApis); + generateTable('Operations', 'Logical', logical, output, coreApis); + generateTable('Operations', 'Matrices', matrices, output, coreApis); + generateTable('Operations', 'Normalization', normalization, output, coreApis); + generateTable('Operations', 'Images', image, output, coreApis); + generateTable('Operations', 'Reduction', reduction, output, coreApis); + generateTable('Tensors', 'Slicing and Joining', sliceJoin, output, coreApis); + generateTable('Tensors', 'Transformations', transformation, output, coreApis); + console.log(process.cwd()); + fs.writeFileSync(DOC_DIR + 'supported_ops.md', output.join('')); + console.log("Supported Ops written to " + (DOC_DIR + 'supported_ops.md') + "\n" + + ("Found " + opMappers.length + " ops\n")); + return [2]; + } + }); + }); +} +function findCoreOps(heading, subHeading, coreApis) { + return coreApis.filter(function (op) { return op.docInfo.heading === heading && + op.docInfo.subheading === subHeading; }); +} +function generateTable(heading, subHeading, ops, output, coreApis) { + var coreOps = findCoreOps(heading, subHeading, coreApis); + output.push("## " + heading + " - " + subHeading + "\n\n"); + output.push('|Tensorflow Op Name|Tensorflow.js Op Name|\n'); + output.push('|---|---|\n'); + ops.sort(function (a, b) { return a.tfOpName.localeCompare(b.tfOpName); }).forEach(function (element) { + output.push("|" + element.tfOpName + "|" + element.dlOpName + "|\n"); + }); + coreOps + .sort(function (a, b) { return a.symbolName.localeCompare(b.symbolName); }) + .forEach(function (element) { + if (!ops.find(function (op) { return op.dlOpName === element.symbolName; })) { + output.push("|Not mapped|" + element.symbolName + "|\n"); + } + }); + output.push('\n\n'); +} +genDoc(); +//# sourceMappingURL=doc_gen.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.d.ts new file mode 100644 index 0000000..5c001e0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.d.ts @@ -0,0 +1,29 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { NamedTensorsMap, TensorArrayMap } from '../data/types'; +import { TensorArray } from './tensor_array'; +export interface ExecutionContextInfo { + id: number; + frameName: string; + iterationId: number; +} +export declare class ExecutionContext { + readonly weightMap: NamedTensorsMap; + readonly tensorArrayMap: TensorArrayMap; + private rootContext; + private contexts; + private lastId; + private _currentContextIds; + constructor(weightMap: NamedTensorsMap, tensorArrayMap: TensorArrayMap); + private newFrame(id, frameName); + currentContext: ExecutionContextInfo[]; + readonly currentContextId: string; + readonly currentContextIds: string[]; + private generateCurrentContextIds(); + private contextIdforContexts(contexts); + enterFrame(frameId: string): void; + exitFrame(): void; + nextIteration(): void; + getWeight(name: string): Tensor[]; + addTensorArray(tensorArray: TensorArray): void; + getTensorArray(id: number): TensorArray; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.js b/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.js new file mode 100644 index 0000000..5211aa8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/execution_context.js @@ -0,0 +1,104 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ExecutionContext = (function () { + function ExecutionContext(weightMap, tensorArrayMap) { + this.weightMap = weightMap; + this.tensorArrayMap = tensorArrayMap; + this.rootContext = { id: 0, frameName: '', iterationId: 0 }; + this.contexts = [this.rootContext]; + this.lastId = 0; + this.generateCurrentContextIds(); + } + ExecutionContext.prototype.newFrame = function (id, frameName) { + return { id: id, frameName: frameName, iterationId: 0 }; + }; + Object.defineProperty(ExecutionContext.prototype, "currentContext", { + get: function () { + return this.contexts; + }, + set: function (contexts) { + if (this.contexts !== contexts) { + this.contexts = contexts; + this.generateCurrentContextIds(); + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(ExecutionContext.prototype, "currentContextId", { + get: function () { + return this._currentContextIds[0]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(ExecutionContext.prototype, "currentContextIds", { + get: function () { + return this._currentContextIds; + }, + enumerable: true, + configurable: true + }); + ExecutionContext.prototype.generateCurrentContextIds = function () { + var names = []; + for (var i = 0; i < this.contexts.length - 1; i++) { + var contexts = this.contexts.slice(0, this.contexts.length - i); + names.push(this.contextIdforContexts(contexts)); + } + names.push(''); + this._currentContextIds = names; + }; + ExecutionContext.prototype.contextIdforContexts = function (contexts) { + return contexts ? + contexts + .map(function (context) { return (context.id === 0 && context.iterationId === 0) ? + '' : + context.frameName + "-" + context.iterationId; }) + .join('/') : + ''; + }; + ExecutionContext.prototype.enterFrame = function (frameId) { + if (this.contexts) { + this.lastId++; + this.contexts = this.contexts.slice(); + this.contexts.push(this.newFrame(this.lastId, frameId)); + this._currentContextIds.unshift(this.contextIdforContexts(this.contexts)); + } + }; + ExecutionContext.prototype.exitFrame = function () { + if (this.contexts && this.contexts.length > 1) { + this.contexts = this.contexts.slice(); + this.contexts.splice(-1); + this.currentContextIds.shift(); + } + else { + throw new Error('Cannot exit frame, the context is empty'); + } + }; + ExecutionContext.prototype.nextIteration = function () { + if (this.contexts && this.contexts.length > 0) { + this.contexts = this.contexts.slice(); + this.lastId++; + var context = Object.assign({}, this.contexts[this.contexts.length - 1]); + context.iterationId += 1; + context.id = this.lastId; + this.contexts.splice(-1, 1, context); + this._currentContextIds.splice(0, 1, this.contextIdforContexts(this.contexts)); + } + else { + throw new Error('Cannot increase frame iteration, the context is empty'); + } + }; + ExecutionContext.prototype.getWeight = function (name) { + return this.weightMap[name]; + }; + ExecutionContext.prototype.addTensorArray = function (tensorArray) { + this.tensorArrayMap[tensorArray.id] = tensorArray; + }; + ExecutionContext.prototype.getTensorArray = function (id) { + return this.tensorArrayMap[id]; + }; + return ExecutionContext; +}()); +exports.ExecutionContext = ExecutionContext; +//# sourceMappingURL=execution_context.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.d.ts new file mode 100644 index 0000000..b802d01 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.d.ts @@ -0,0 +1,29 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { NamedTensorsMap, TensorInfo } from '../data/types'; +export declare class FrozenModel implements tfc.InferenceModel { + private modelUrl; + private weightManifestUrl; + private requestOption; + private executor; + private version; + private weightManifest; + private pathPrefix; + readonly modelVersion: string; + readonly inputNodes: string[]; + readonly outputNodes: string[]; + readonly inputs: TensorInfo[]; + readonly outputs: TensorInfo[]; + readonly weights: NamedTensorsMap; + constructor(modelUrl: string, weightManifestUrl: string, requestOption?: RequestInit); + getPathPrefix(): string; + private loadRemoteProtoFile(); + private loadWeightManifest(); + load(): Promise; + predict(inputs: tfc.Tensor | tfc.Tensor[] | tfc.NamedTensorMap, config?: tfc.ModelPredictConfig): tfc.Tensor | tfc.Tensor[] | tfc.NamedTensorMap; + private constructTensorMap(inputs); + execute(inputs: tfc.Tensor | tfc.Tensor[] | tfc.NamedTensorMap, outputs?: string | string[]): tfc.Tensor | tfc.Tensor[]; + executeAsync(inputs: tfc.Tensor | tfc.Tensor[] | tfc.NamedTensorMap, outputs?: string | string[]): Promise; + private convertTensorMapToTensorsMap(map); + dispose(): void; +} +export declare function loadFrozenModel(modelUrl: string, weightsManifestUrl: string, requestOption?: RequestInit): Promise; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.js b/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.js new file mode 100644 index 0000000..6564c4a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/frozen_model.js @@ -0,0 +1,252 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var Url = require("url"); +var compiled_api_1 = require("../data/compiled_api"); +var operation_mapper_1 = require("../operations/operation_mapper"); +var graph_executor_1 = require("./graph_executor"); +var FrozenModel = (function () { + function FrozenModel(modelUrl, weightManifestUrl, requestOption) { + this.modelUrl = modelUrl; + this.weightManifestUrl = weightManifestUrl; + this.requestOption = requestOption; + this.version = 'n/a'; + this.pathPrefix = this.getPathPrefix(); + } + Object.defineProperty(FrozenModel.prototype, "modelVersion", { + get: function () { + return this.version; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "inputNodes", { + get: function () { + return this.executor.inputNodes; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "outputNodes", { + get: function () { + return this.executor.outputNodes; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "inputs", { + get: function () { + return this.executor.inputs; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "outputs", { + get: function () { + return this.executor.outputs; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "weights", { + get: function () { + return this.executor.weightMap; + }, + enumerable: true, + configurable: true + }); + FrozenModel.prototype.getPathPrefix = function () { + var url = Url.parse(this.weightManifestUrl); + var segments = url.pathname.split('/'); + segments.splice(-1); + url.pathname = segments.join('/'); + return Url.format(url) + '/'; + }; + FrozenModel.prototype.loadRemoteProtoFile = function () { + return __awaiter(this, void 0, void 0, function () { + var response, _a, _b, _c, error_1; + return __generator(this, function (_d) { + switch (_d.label) { + case 0: + _d.trys.push([0, 3, , 4]); + return [4, fetch(this.modelUrl, this.requestOption)]; + case 1: + response = _d.sent(); + _b = (_a = compiled_api_1.tensorflow.GraphDef).decode; + _c = Uint8Array.bind; + return [4, response.arrayBuffer()]; + case 2: return [2, _b.apply(_a, [new (_c.apply(Uint8Array, [void 0, _d.sent()]))()])]; + case 3: + error_1 = _d.sent(); + throw new Error(this.modelUrl + " not found. " + error_1); + case 4: return [2]; + } + }); + }); + }; + FrozenModel.prototype.loadWeightManifest = function () { + return __awaiter(this, void 0, void 0, function () { + var manifest, _a, error_2; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _b.trys.push([0, 3, , 4]); + return [4, fetch(this.weightManifestUrl, this.requestOption)]; + case 1: + manifest = _b.sent(); + _a = this; + return [4, manifest.clone().json()]; + case 2: + _a.weightManifest = _b.sent(); + return [3, 4]; + case 3: + error_2 = _b.sent(); + throw new Error(this.weightManifestUrl + " not found. " + error_2); + case 4: return [2]; + } + }); + }); + }; + FrozenModel.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var graphPromise, manifestPromise, graph, weightMap; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + graphPromise = this.loadRemoteProtoFile(); + manifestPromise = this.loadWeightManifest(); + return [4, Promise.all([graphPromise, manifestPromise])]; + case 1: + graph = (_a.sent())[0]; + this.version = graph.versions.producer + "." + graph.versions.minConsumer; + return [4, tfc.io.loadWeights(this.weightManifest, this.pathPrefix, undefined, this.requestOption)]; + case 2: + weightMap = _a.sent(); + this.executor = + new graph_executor_1.GraphExecutor(operation_mapper_1.OperationMapper.Instance.transformGraph(graph)); + this.executor.weightMap = this.convertTensorMapToTensorsMap(weightMap); + return [2, true]; + } + }); + }); + }; + FrozenModel.prototype.predict = function (inputs, config) { + return this.execute(inputs, this.outputNodes); + }; + FrozenModel.prototype.constructTensorMap = function (inputs) { + var inputArray = inputs instanceof tfc.Tensor ? [inputs] : inputs; + if (inputArray.length !== this.inputNodes.length) { + throw new Error('Input tensor count mismatch,' + + ("the frozen model has " + this.inputNodes.length + " placeholders, ") + + ("while there are " + inputArray.length + " input tensors.")); + } + return this.inputNodes.reduce(function (map, inputName, i) { + map[inputName] = inputArray[i]; + return map; + }, {}); + }; + FrozenModel.prototype.execute = function (inputs, outputs) { + outputs = outputs || this.outputNodes; + if (inputs instanceof tfc.Tensor || Array.isArray(inputs)) { + inputs = this.constructTensorMap(inputs); + } + if (this.executor.isControlFlowModel || this.executor.isDynamicShapeModel) { + throw new Error('The model contains control flow or dynamic shape ops, ' + + 'please use executeAsync method'); + } + var result = this.executor.execute(this.convertTensorMapToTensorsMap(inputs), outputs); + var keys = Object.keys(result); + return (Array.isArray(outputs) && outputs.length > 1) ? + outputs.map(function (node) { return result[node]; }) : + result[keys[0]]; + }; + FrozenModel.prototype.executeAsync = function (inputs, outputs) { + return __awaiter(this, void 0, void 0, function () { + var result, keys; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.executor.isControlFlowModel && + this.executor.isDynamicShapeModel)) { + throw new Error('The model does not contain control flow or dynamic shape ops, ' + + 'please use execute method for better performance.'); + } + outputs = outputs || this.outputNodes; + if (inputs instanceof tfc.Tensor || Array.isArray(inputs)) { + inputs = this.constructTensorMap(inputs); + } + return [4, this.executor.executeAsync(this.convertTensorMapToTensorsMap(inputs), outputs)]; + case 1: + result = _a.sent(); + keys = Object.keys(result); + return [2, Array.isArray(outputs) && outputs.length > 1 ? + outputs.map(function (node) { return result[node]; }) : + result[keys[0]]]; + } + }); + }); + }; + FrozenModel.prototype.convertTensorMapToTensorsMap = function (map) { + return Object.keys(map).reduce(function (newMap, key) { + newMap[key] = [map[key]]; + return newMap; + }, {}); + }; + FrozenModel.prototype.dispose = function () { + this.executor.dispose(); + }; + return FrozenModel; +}()); +exports.FrozenModel = FrozenModel; +function loadFrozenModel(modelUrl, weightsManifestUrl, requestOption) { + return __awaiter(this, void 0, void 0, function () { + var model; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + model = new FrozenModel(modelUrl, weightsManifestUrl, requestOption); + return [4, model.load()]; + case 1: + _a.sent(); + return [2, model]; + } + }); + }); +} +exports.loadFrozenModel = loadFrozenModel; +//# sourceMappingURL=frozen_model.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.d.ts new file mode 100644 index 0000000..a6fe4b0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.d.ts @@ -0,0 +1,26 @@ +import { NamedTensorMap, NamedTensorsMap, TensorInfo } from '../data/types'; +import { Graph } from '../operations/types'; +export declare class GraphExecutor { + private graph; + private compiledOrder; + private _weightMap; + private weightIds; + private placeholders; + private _outputs; + weightMap: NamedTensorsMap; + readonly inputs: TensorInfo[]; + readonly outputs: TensorInfo[]; + readonly inputNodes: string[]; + readonly outputNodes: string[]; + constructor(graph: Graph); + readonly isControlFlowModel: boolean; + readonly isDynamicShapeModel: boolean; + private compile(); + execute(inputs: NamedTensorsMap, outputs?: string | string[]): NamedTensorMap; + executeAsync(inputs: NamedTensorsMap, outputs?: string | string[]): Promise; + private executeWithControlFlow(inputs, context); + private findOutputs(tensorMap, context, outputs?); + dispose(): void; + private checkInputShapeAndType(inputs); + private checkInput(inputs); +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.js new file mode 100644 index 0000000..da7faa2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/graph_executor.js @@ -0,0 +1,307 @@ +"use strict"; +var __assign = (this && this.__assign) || Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var utils_1 = require("../operations/executors/utils"); +var operation_executor_1 = require("../operations/operation_executor"); +var execution_context_1 = require("./execution_context"); +var GraphExecutor = (function () { + function GraphExecutor(graph) { + this.graph = graph; + this.compiledOrder = []; + this._weightMap = {}; + this.placeholders = graph.placeholders; + this._outputs = graph.outputs; + this.compile(); + } + Object.defineProperty(GraphExecutor.prototype, "weightMap", { + get: function () { + return this._weightMap; + }, + set: function (weightMap) { + var weightIds = Object.keys(weightMap).map(function (key) { return weightMap[key].map(function (tensor) { return tensor.id; }); }); + this.weightIds = [].concat.apply([], weightIds); + this._weightMap = weightMap; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "inputs", { + get: function () { + return this.placeholders.map(function (node) { + return { + name: node.name, + shape: node.params['shape'] ? node.params['shape'].value : + undefined, + dtype: node.params['dtype'] ? node.params['dtype'].value : + undefined + }; + }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "outputs", { + get: function () { + return this._outputs.map(function (node) { + return { + name: node.name, + shape: node.params['shape'] ? node.params['shape'].value : + undefined, + dtype: node.params['dtype'] ? node.params['dtype'].value : + undefined + }; + }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "inputNodes", { + get: function () { + return this.placeholders.map(function (node) { return node.name; }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "outputNodes", { + get: function () { + return this.outputs.map(function (node) { return node.name; }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "isControlFlowModel", { + get: function () { + return this.graph.withControlFlow; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "isDynamicShapeModel", { + get: function () { + return this.graph.withDynamicShape; + }, + enumerable: true, + configurable: true + }); + GraphExecutor.prototype.compile = function () { + if (this.graph.withControlFlow || this.graph.withDynamicShape) { + return; + } + var stack = this.graph.inputs.slice(); + var visited = {}; + while (stack.length > 0) { + var node = stack.pop(); + visited[node.name] = true; + this.compiledOrder.push(node); + node.children.forEach(function (childNode) { + if (!visited[childNode.name] && childNode.inputNames.every(function (name) { + var nodeName = utils_1.getNodeNameAndIndex(name)[0]; + return visited[nodeName]; + })) { + stack.push(childNode); + } + }); + } + }; + GraphExecutor.prototype.execute = function (inputs, outputs) { + var _this = this; + this.checkInput(inputs); + this.checkInputShapeAndType(inputs); + var tensorArrayMap = {}; + var result = tfjs_core_1.tidy(function () { + var context = new execution_context_1.ExecutionContext(_this._weightMap, tensorArrayMap); + var tensors = _this.compiledOrder.reduce(function (map, node) { + map[node.name] = operation_executor_1.executeOp(node, map, context); + return map; + }, __assign({}, _this.weightMap, inputs)); + return _this.findOutputs(tensors, context, outputs); + }); + return result; + }; + GraphExecutor.prototype.executeAsync = function (inputs, outputs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var tensorArrayMap, context, tensors, results, outputIds, inputIdArray, inputIds; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + this.checkInput(inputs); + this.checkInputShapeAndType(inputs); + tensorArrayMap = {}; + context = new execution_context_1.ExecutionContext(this._weightMap, tensorArrayMap); + return [4, this.executeWithControlFlow(inputs, context)]; + case 1: + tensors = _a.sent(); + results = this.findOutputs(tensors, context, outputs); + outputIds = Object.keys(results).map(function (key) { return results[key].id; }); + inputIdArray = Object.keys(inputs).map(function (key) { return inputs[key].map(function (input) { return input.id; }); }); + inputIds = [].concat.apply([], inputIdArray); + Object.keys(tensors).forEach(function (key) { + var tensorArray = tensors[key]; + tensorArray.forEach(function (tensor) { + if (tensor && outputIds.indexOf(tensor.id) === -1 && + inputIds.indexOf(tensor.id) === -1 && + _this.weightIds.indexOf(tensor.id) === -1) { + tensor.dispose(); + } + }); + }); + return [2, results]; + } + }); + }); + }; + GraphExecutor.prototype.executeWithControlFlow = function (inputs, context) { + return __awaiter(this, void 0, void 0, function () { + var stack, tensorMap, added, item, nodeName, tensors, _a, _b; + return __generator(this, function (_c) { + switch (_c.label) { + case 0: + stack = this.graph.inputs.map(function (node) { + return { node: node, contexts: context.currentContext }; + }); + tensorMap = __assign({}, this.weightMap, inputs); + added = {}; + _c.label = 1; + case 1: + if (!(stack.length > 0)) return [3, 3]; + item = stack.pop(); + context.currentContext = item.contexts; + nodeName = ''; + if (item.node.op === 'enter' && + utils_1.getParamValue('isConstant', item.node, tensorMap, context)) { + nodeName = utils_1.getNodeNameAndIndex(item.node.name, context)[0]; + } + tensors = operation_executor_1.executeOp(item.node, tensorMap, context); + if (!nodeName) { + nodeName = utils_1.getNodeNameAndIndex(item.node.name, context)[0]; + } + _a = tensorMap; + _b = nodeName; + return [4, tensors]; + case 2: + _a[_b] = _c.sent(); + item.node.children.forEach(function (childNode) { + var nodeName = utils_1.getNodeNameAndIndex(childNode.name, context)[0]; + if (!added[nodeName]) { + if (childNode.op === 'merge') { + if (childNode.inputNames.some(function (name) { + return !!utils_1.getTensor(name, tensorMap, context); + })) { + added[nodeName] = true; + stack.push({ contexts: context.currentContext, node: childNode }); + } + } + else if (childNode.inputNames.every(function (name) { + return !!utils_1.getTensor(name, tensorMap, context); + })) { + added[nodeName] = true; + stack.push({ contexts: context.currentContext, node: childNode }); + } + } + }); + return [3, 1]; + case 3: return [2, tensorMap]; + } + }); + }); + }; + GraphExecutor.prototype.findOutputs = function (tensorMap, context, outputs) { + if (outputs && !(outputs instanceof Array)) { + outputs = [outputs]; + } + var requestedOutputs = (outputs || this.graph.outputs.map(function (node) { return node.name; })); + return requestedOutputs.reduce(function (map, name) { + map[name] = utils_1.getTensor(name, tensorMap, context); + return map; + }, {}); + }; + GraphExecutor.prototype.dispose = function () { + var _this = this; + Object.keys(this.weightMap) + .forEach(function (key) { return _this.weightMap[key].forEach(function (tensor) { return tensor.dispose(); }); }); + }; + GraphExecutor.prototype.checkInputShapeAndType = function (inputs) { + this.placeholders.forEach(function (node) { + var input = inputs[node.name][0]; + if (node.params['shape'] && node.params['shape'].value) { + var shape_1 = node.params['shape'].value; + var match = shape_1.length === input.shape.length && + input.shape.every(function (dim, index) { return shape_1[index] === -1 || shape_1[index] === dim; }); + tfjs_core_1.util.assert(match, "The shape of dict['" + node.name + "'] provided in model.execute(dict) must be [" + shape_1 + "], but was [" + input.shape + "]"); + } + if (node.params['dtype'] && node.params['dtype'].value) { + tfjs_core_1.util.assert(input.dtype === node.params['dtype'].value, "The dtype of dict['" + node.name + "'] provided in model.execute(dict) must be " + node.params['dtype'].value + ", but was " + input.dtype); + } + }); + }; + GraphExecutor.prototype.checkInput = function (inputs) { + var _this = this; + var inputKeys = Object.keys(inputs); + var missing = []; + var extra = []; + this.inputNodes.forEach(function (name) { + if (inputKeys.indexOf(name) === -1) + missing.push(name); + }); + inputKeys.forEach(function (name) { + if (_this.inputNodes.indexOf(name) === -1) + extra.push(name); + }); + if (missing.length > 0) { + throw new Error("The dict provided in model.execute(dict) has the keys " + + ("[" + inputKeys + "], but is missing the required keys: [" + missing + "].")); + } + if (extra.length > 0) { + throw new Error("The dict provided in model.execute(dict) has " + + ("unused keys: [" + extra + "]. Please provide only the following keys: ") + + ("[" + this.inputNodes + "].")); + } + }; + return GraphExecutor; +}()); +exports.GraphExecutor = GraphExecutor; +//# sourceMappingURL=graph_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.d.ts new file mode 100644 index 0000000..a1542a2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.d.ts @@ -0,0 +1,32 @@ +import { DataType, Tensor } from '@tensorflow/tfjs-core'; +export interface TensorWithState { + tensor?: Tensor; + written?: boolean; + read?: boolean; + cleared?: boolean; +} +export declare class TensorArray { + readonly name: string; + readonly dtype: DataType; + private maxSize; + private elementShape; + readonly identicalElementShapes: boolean; + readonly dynamicSize: boolean; + readonly clearAfterRead: boolean; + private static nextId; + private tensors; + private closed_; + readonly id: number; + constructor(name: string, dtype: DataType, maxSize: number, elementShape: number[], identicalElementShapes: boolean, dynamicSize: boolean, clearAfterRead: boolean); + readonly closed: boolean; + clearAndClose(): void; + size(): number; + read(index: number): Tensor; + readMany(indices: number[]): Tensor[]; + write(index: number, tensor: Tensor): void; + writeMany(indices: number[], tensors: Tensor[]): void; + gather(indices?: number[], dtype?: DataType): Tensor; + concat(dtype?: DataType): Tensor; + scatter(indices: number[], tensor: Tensor): void; + split(length: number[], tensor: Tensor): void; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.js b/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.js new file mode 100644 index 0000000..8c77d1b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/executor/tensor_array.js @@ -0,0 +1,171 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var TensorArray = (function () { + function TensorArray(name, dtype, maxSize, elementShape, identicalElementShapes, dynamicSize, clearAfterRead) { + this.name = name; + this.dtype = dtype; + this.maxSize = maxSize; + this.elementShape = elementShape; + this.identicalElementShapes = identicalElementShapes; + this.dynamicSize = dynamicSize; + this.clearAfterRead = clearAfterRead; + this.tensors = []; + this.closed_ = false; + this.id = TensorArray.nextId++; + } + Object.defineProperty(TensorArray.prototype, "closed", { + get: function () { + return this.closed_; + }, + enumerable: true, + configurable: true + }); + TensorArray.prototype.clearAndClose = function () { + this.tensors.forEach(function (tensor) { return tensor.tensor.dispose(); }); + this.tensors = []; + this.closed_ = true; + }; + TensorArray.prototype.size = function () { + return this.tensors.length; + }; + TensorArray.prototype.read = function (index) { + if (this.closed_) { + throw new Error("TensorArray " + this.name + " has already been closed."); + } + if (index < 0 || index >= this.tensors.length) { + throw new Error("Tried to read from index " + index + ", but array size is: " + this.tensors.length); + } + var tensorWithState = this.tensors[index]; + if (tensorWithState.cleared) { + throw new Error("TensorArray " + this.name + ": Could not read index " + index + " twice because it was cleared after a previous read " + + "(perhaps try setting clear_after_read = false?)."); + } + if (this.clearAfterRead) { + tensorWithState.cleared = true; + } + tensorWithState.read = true; + return tensorWithState.tensor; + }; + TensorArray.prototype.readMany = function (indices) { + var _this = this; + return indices.map(function (index) { return _this.read(index); }); + }; + TensorArray.prototype.write = function (index, tensor) { + if (this.closed_) { + throw new Error("TensorArray " + this.name + " has already been closed."); + } + if (index < 0 || !this.dynamicSize && index >= this.maxSize) { + throw new Error("Tried to write to index " + index + ", but array is not resizeable and size is: " + this.maxSize); + } + var t = this.tensors[index] || {}; + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ",\n because the value dtype is " + tensor.dtype + ", but TensorArray dtype is " + this.dtype + "."); + } + if (this.size() === 0 && this.elementShape.length === 0) { + this.elementShape = tensor.shape; + } + tfjs_core_1.util.assertShapesMatch(this.elementShape, tensor.shape, "TensorArray " + this.name + ": Could not write to TensorArray index " + index + "."); + if (t && t.read) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ", because it has already been read."); + } + if (t && t.written) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ", because it has already been written."); + } + t.tensor = tensor; + t.written = true; + this.tensors[index] = t; + }; + TensorArray.prototype.writeMany = function (indices, tensors) { + var _this = this; + if (indices.length !== tensors.length) { + throw new Error("TensorArray " + this.name + ": could not write multiple tensors," + + ("because the index size: " + indices.length + " is not the same as tensors size: " + tensors.length + ".")); + } + indices.map(function (i, index) { return _this.write(i, tensors[index]); }); + }; + TensorArray.prototype.gather = function (indices, dtype) { + if (!!dtype && dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but gather requested dtype " + dtype); + } + if (!indices) { + indices = []; + for (var i = 0; i < this.size(); i++) { + indices.push(i); + } + } + if (indices.length === 0) { + return tfjs_core_1.tensor([], [0].concat(this.elementShape)); + } + var tensors = this.readMany(indices); + tfjs_core_1.util.assertShapesMatch(this.elementShape, tensors[0].shape, 'TensorArray shape mismatch: '); + return tfjs_core_1.stack(tensors, 0); + }; + TensorArray.prototype.concat = function (dtype) { + if (!!dtype && dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but concat requested dtype " + dtype); + } + if (this.size() === 0) { + return tfjs_core_1.tensor([], [0].concat(this.elementShape)); + } + var indices = []; + for (var i = 0; i < this.size(); i++) { + indices.push(i); + } + var tensors = this.readMany(indices); + tfjs_core_1.util.assertShapesMatch(this.elementShape, tensors[0].shape, "TensorArray shape mismatch: tensor array shape (" + this.elementShape + ") vs first tensor shape (" + tensors[0].shape + ")"); + return tfjs_core_1.concat(tensors, 0); + }; + TensorArray.prototype.scatter = function (indices, tensor) { + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + tensor.dtype); + } + if (indices.length !== tensor.shape[0]) { + throw new Error("Expected len(indices) == tensor.shape[0], but saw: " + indices.length + " vs. " + tensor.shape[0]); + } + var maxIndex = Math.max.apply(Math, indices); + if (!this.dynamicSize && maxIndex >= this.maxSize) { + throw new Error("Max index must be < array size (" + maxIndex + " vs. " + this.maxSize + ")"); + } + this.writeMany(indices, tfjs_core_1.unstack(tensor, 0)); + }; + TensorArray.prototype.split = function (length, tensor) { + var _this = this; + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + tensor.dtype); + } + var totalLength = 0; + var cumulativeLengths = length.map(function (len) { + totalLength += len; + return totalLength; + }); + if (totalLength !== tensor.shape[0]) { + throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n " + totalLength + ", and tensor's shape is: " + tensor.shape); + } + if (!this.dynamicSize && length.length !== this.maxSize) { + throw new Error("TensorArray's size is not equal to the size of lengths (" + this.maxSize + " vs. " + length.length + "), " + + 'and the TensorArray is not marked as dynamically resizeable'); + } + var elementPerRow = totalLength === 0 ? 0 : tensor.size / totalLength; + var tensors = []; + tfjs_core_1.tidy(function () { + tensor = tensor.reshape([1, totalLength, elementPerRow]); + for (var i = 0; i < length.length; ++i) { + var previousLength = (i === 0) ? 0 : cumulativeLengths[i - 1]; + var indices_1 = [0, previousLength, 0]; + var sizes = [1, length[i], elementPerRow]; + tensors[i] = tfjs_core_1.slice(tensor, indices_1, sizes).reshape(_this.elementShape); + } + return tensors; + }); + var indices = []; + for (var i = 0; i < length.length; i++) { + indices[i] = i; + } + this.writeMany(indices, tensors); + }; + TensorArray.nextId = 0; + return TensorArray; +}()); +exports.TensorArray = TensorArray; +//# sourceMappingURL=tensor_array.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/index.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/index.d.ts new file mode 100644 index 0000000..c61fe79 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/index.d.ts @@ -0,0 +1,2 @@ +export { FrozenModel, loadFrozenModel } from './executor/frozen_model'; +export { version as version_converter } from './version'; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/index.js b/node_modules/@tensorflow/tfjs-converter/dist/index.js new file mode 100644 index 0000000..b450d77 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/index.js @@ -0,0 +1,8 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var frozen_model_1 = require("./executor/frozen_model"); +exports.FrozenModel = frozen_model_1.FrozenModel; +exports.loadFrozenModel = frozen_model_1.loadFrozenModel; +var version_1 = require("./version"); +exports.version_converter = version_1.version; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.d.ts new file mode 100644 index 0000000..ac6fe1d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "arithmetic"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.js new file mode 100644 index 0000000..ac6c113 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/arithmetic_executor.js @@ -0,0 +1,40 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'add': { + return [tfc.add(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'mod': + return [tfc.mod(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + case 'mul': + return [tfc.mul(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + case 'div': { + return [tfc.div(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'floorDiv': { + return [tfc.floorDiv(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'sub': { + return [tfc.sub(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'minimum': { + return [tfc.minimum(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'maximum': { + return [tfc.maximum(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'pow': { + return [tfc.pow(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'squaredDifference': { + return [tfc.squaredDifference(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'arithmetic'; +//# sourceMappingURL=arithmetic_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.d.ts new file mode 100644 index 0000000..60a5196 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "basic_math"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.js new file mode 100644 index 0000000..e4a5511 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/basic_math_executor.js @@ -0,0 +1,88 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'abs': + return [tfc.abs(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'acos': + return [tfc.acos(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'acosh': + return [tfc.acosh(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'asin': + return [tfc.asin(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'asinh': + return [tfc.asinh(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'atan': + return [tfc.atan(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'atanh': + return [tfc.atanh(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'ceil': + return [tfc.ceil(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'cos': + return [tfc.cos(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'cosh': + return [tfc.cosh(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'elu': + return [tfc.elu(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'erf': + return [tfc.erf(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'exp': + return [tfc.exp(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'expm1': { + return [tfc.expm1(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'floor': + return [tfc.floor(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'log': + return [tfc.log(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'log1p': { + return [tfc.log1p(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'neg': + return [tfc.neg(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'reciprocal': { + return [tfc.reciprocal(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'relu': + return [tfc.relu(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'round': { + return [tfc.round(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'selu': + return [tfc.selu(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'sigmoid': + return [tfc.sigmoid(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'sin': + return [tfc.sin(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'sign': { + return [tfc.sign(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'sinh': { + return [tfc.sinh(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'softplus': { + return [tfc.softplus(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'sqrt': { + return [tfc.sqrt(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'square': { + return [tfc.square(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'tanh': { + return [tfc.tanh(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'tan': + return [tfc.tan(utils_1.getParamValue('x', node, tensorMap, context))]; + case 'clipByValue': + return [tfc.clipByValue(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('clipValueMin', node, tensorMap, context), utils_1.getParamValue('clipValueMax', node, tensorMap, context))]; + case 'rsqrt': + return [tfc.div(tfc.scalar(1.0, 'float32'), tfc.sqrt(utils_1.getTensor(node.inputNames[0], tensorMap, context)))]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'basic_math'; +//# sourceMappingURL=basic_math_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.d.ts new file mode 100644 index 0000000..a8187a7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.d.ts @@ -0,0 +1,6 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { NamedTensorsMap } from '../../data/types'; +import { ExecutionContext } from '../../executor/execution_context'; +import { Node } from '../types'; +export declare function executeOp(node: Node, tensorMap: NamedTensorsMap, context: ExecutionContext): Promise; +export declare const CATEGORY = "control"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.js new file mode 100644 index 0000000..5f98652 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/control_executor.js @@ -0,0 +1,152 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var tensor_array_1 = require("../../executor/tensor_array"); +var utils_1 = require("./utils"); +function executeOp(node, tensorMap, context) { + return __awaiter(this, void 0, void 0, function () { + var _a, pred, data_1, inputName, frameId, data, tensor, input, size, dtype, elementShape, dynamicSize, clearAfterRead, identicalElementShapes, name_1, tensorArray, id, index, writeTensor, writeTensorArray, readId, readIndex, readTensorArray, gatherId, gatherIndices, gatherDtype, gatherTensorArray, scatterId, scatterIndices, scatterTensor, scatterTensorArray, concatId, concatTensorArray, concatDtype, splitId, splitTensor, lengths, splitTensorArray, sizeId, sizeTensorArray, closeId, closeTensorArray; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _a = node.op; + switch (_a) { + case 'loopCond': return [3, 1]; + case 'switch': return [3, 2]; + case 'merge': return [3, 4]; + case 'enter': return [3, 5]; + case 'exit': return [3, 6]; + case 'nextIteration': return [3, 7]; + case 'tensorArray': return [3, 8]; + case 'tensorArrayWrite': return [3, 9]; + case 'tensorArrayRead': return [3, 10]; + case 'tensorArrayGather': return [3, 11]; + case 'tensorArrayScatter': return [3, 12]; + case 'tensorArrayConcat': return [3, 13]; + case 'tensorArraySplit': return [3, 14]; + case 'tensorArraySize': return [3, 15]; + case 'tensorArrayClose': return [3, 16]; + } + return [3, 17]; + case 1: return [2, [utils_1.getParamValue('pred', node, tensorMap, context)]]; + case 2: + pred = utils_1.getParamValue('pred', node, tensorMap, context); + data_1 = utils_1.getParamValue('data', node, tensorMap, context); + return [4, pred.data()]; + case 3: return [2, (_b.sent())[0] ? [undefined, data_1] : [data_1, undefined]]; + case 4: + inputName = node.inputNames.find(function (name) { return utils_1.getTensor(name, tensorMap, context) !== undefined; }); + return [2, inputName ? [utils_1.getTensor(inputName, tensorMap, context)] : undefined]; + case 5: + frameId = utils_1.getParamValue('frameName', node, tensorMap, context); + data = utils_1.getParamValue('tensor', node, tensorMap, context); + context.enterFrame(frameId); + return [2, [data]]; + case 6: + tensor = utils_1.getParamValue('tensor', node, tensorMap, context); + context.exitFrame(); + return [2, [tensor]]; + case 7: + input = utils_1.getParamValue('tensor', node, tensorMap, context); + context.nextIteration(); + return [2, [input]]; + case 8: + size = utils_1.getParamValue('size', node, tensorMap, context); + dtype = utils_1.getParamValue('dtype', node, tensorMap, context); + elementShape = utils_1.getParamValue('elementShape', node, tensorMap, context); + dynamicSize = utils_1.getParamValue('dynamicSize', node, tensorMap, context); + clearAfterRead = utils_1.getParamValue('clearAfterRead', node, tensorMap, context); + identicalElementShapes = utils_1.getParamValue('identicalElementShapes', node, tensorMap, context); + name_1 = utils_1.getParamValue('name', node, tensorMap, context); + tensorArray = new tensor_array_1.TensorArray(name_1, dtype, size, elementShape, identicalElementShapes, dynamicSize, clearAfterRead); + context.addTensorArray(tensorArray); + return [2, [tfjs_core_1.scalar(tensorArray.id), tfjs_core_1.scalar(1.0)]]; + case 9: + id = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + index = utils_1.getParamValue('index', node, tensorMap, context); + writeTensor = utils_1.getParamValue('tensor', node, tensorMap, context); + writeTensorArray = context.getTensorArray(id); + writeTensorArray.write(index, writeTensor); + return [2, [tfjs_core_1.scalar(1.0)]]; + case 10: + readId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + readIndex = utils_1.getParamValue('index', node, tensorMap, context); + readTensorArray = context.getTensorArray(readId); + return [2, [readTensorArray.read(readIndex)]]; + case 11: + gatherId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + gatherIndices = utils_1.getParamValue('indices', node, tensorMap, context); + gatherDtype = utils_1.getParamValue('dtype', node, tensorMap, context); + gatherTensorArray = context.getTensorArray(gatherId); + return [2, [gatherTensorArray.gather(gatherIndices, gatherDtype)]]; + case 12: + scatterId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + scatterIndices = utils_1.getParamValue('indices', node, tensorMap, context); + scatterTensor = utils_1.getParamValue('tensor', node, tensorMap, context); + scatterTensorArray = context.getTensorArray(scatterId); + scatterTensorArray.scatter(scatterIndices, scatterTensor); + return [2, [tfjs_core_1.scalar(1.0)]]; + case 13: + concatId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + concatTensorArray = context.getTensorArray(concatId); + concatDtype = utils_1.getParamValue('dtype', node, tensorMap, context); + return [2, [concatTensorArray.concat(concatDtype)]]; + case 14: + splitId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + splitTensor = utils_1.getParamValue('tensor', node, tensorMap, context); + lengths = utils_1.getParamValue('lengths', node, tensorMap, context); + splitTensorArray = context.getTensorArray(splitId); + splitTensorArray.split(lengths, splitTensor); + return [2, [tfjs_core_1.scalar(1.0)]]; + case 15: + sizeId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + sizeTensorArray = context.getTensorArray(sizeId); + return [2, [tfjs_core_1.scalar(sizeTensorArray.size(), 'int32')]]; + case 16: + closeId = utils_1.getParamValue('tensorArrayId', node, tensorMap, context); + closeTensorArray = context.getTensorArray(closeId); + closeTensorArray.clearAndClose(); + return [2, []]; + case 17: throw TypeError("Node type " + node.op + " is not implemented"); + } + }); + }); +} +exports.executeOp = executeOp; +exports.CATEGORY = 'control'; +//# sourceMappingURL=control_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.d.ts new file mode 100644 index 0000000..da0f066 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "convolution"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.js new file mode 100644 index 0000000..e53f465 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/convolution_executor.js @@ -0,0 +1,54 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'conv1d': { + var stride = utils_1.getParamValue('stride', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + var dataFormat = utils_1.getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + var dilation = utils_1.getParamValue('dilation', node, tensorMap, context); + return [tfc.conv1d(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('filter', node, tensorMap, context), stride, pad, dataFormat, dilation)]; + } + case 'conv2d': { + var stride = utils_1.getParamValue('strides', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + var dataFormat = utils_1.getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + var dilations = utils_1.getParamValue('dilations', node, tensorMap, context); + return [tfc.conv2d(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('filter', node, tensorMap, context), [stride[1], stride[2]], pad, dataFormat, [dilations[0], dilations[1]])]; + } + case 'conv2dTranspose': { + var shape = utils_1.getParamValue('outputShape', node, tensorMap, context); + var stride = utils_1.getParamValue('strides', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + return [tfc.conv2dTranspose(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('filter', node, tensorMap, context), shape, [stride[1], stride[2]], pad)]; + } + case 'depthwiseConv2d': { + var stride = utils_1.getParamValue('strides', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + var dilations = utils_1.getParamValue('dilations', node, tensorMap, context); + var dataFormat = utils_1.getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + return [tfc.depthwiseConv2d(utils_1.getParamValue('input', node, tensorMap, context), utils_1.getParamValue('filter', node, tensorMap, context), [stride[1], stride[2]], pad, dataFormat, [dilations[0], dilations[1]])]; + } + case 'avgPool': { + var stride = utils_1.getParamValue('strides', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + var kernelSize = utils_1.getParamValue('kernelSize', node, tensorMap, context); + return [tfc.avgPool(utils_1.getParamValue('x', node, tensorMap, context), [kernelSize[1], kernelSize[2]], [stride[1], stride[2]], pad)]; + } + case 'maxPool': { + var stride = utils_1.getParamValue('strides', node, tensorMap, context); + var pad = utils_1.getParamValue('pad', node, tensorMap, context); + var kernelSize = utils_1.getParamValue('kernelSize', node, tensorMap, context); + return [tfc.maxPool(utils_1.getParamValue('x', node, tensorMap, context), [kernelSize[1], kernelSize[2]], [stride[1], stride[2]], pad)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'convolution'; +//# sourceMappingURL=convolution_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.d.ts new file mode 100644 index 0000000..85d9dc1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "creation"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.js new file mode 100644 index 0000000..c1b13ad --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/creation_executor.js @@ -0,0 +1,58 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'fill': { + var shape = utils_1.getParamValue('shape', node, tensorMap, context); + var value = utils_1.getParamValue('value', node, tensorMap, context); + return [tfc.fill(shape, value)]; + } + case 'linspace': { + var start = utils_1.getParamValue('start', node, tensorMap, context); + var stop_1 = utils_1.getParamValue('stop', node, tensorMap, context); + var num = utils_1.getParamValue('num', node, tensorMap, context); + return [tfc.linspace(start, stop_1, num)]; + } + case 'oneHot': { + var indices = utils_1.getParamValue('indices', node, tensorMap, context); + var depth = utils_1.getParamValue('depth', node, tensorMap, context); + var onValue = utils_1.getParamValue('onValue', node, tensorMap, context); + var offValue = utils_1.getParamValue('offValue', node, tensorMap, context); + return [tfc.oneHot(indices, depth, onValue, offValue)]; + } + case 'ones': { + return [tfc.ones(utils_1.getParamValue('shape', node, tensorMap, context), utils_1.getParamValue('dtype', node, tensorMap, context))]; + } + case 'onesLike': { + return [tfc.onesLike(utils_1.getParamValue('x', node, tensorMap, context))]; + } + case 'randomUniform': { + return [tfc.randomUniform(utils_1.getParamValue('shape', node, tensorMap, context), utils_1.getParamValue('minval', node, tensorMap, context), utils_1.getParamValue('maxval', node, tensorMap, context), utils_1.getParamValue('dtype', node, tensorMap, context))]; + } + case 'range': { + var start = utils_1.getParamValue('start', node, tensorMap, context); + var stop_2 = utils_1.getParamValue('stop', node, tensorMap, context); + var step = utils_1.getParamValue('step', node, tensorMap, context); + return [tfc.range(start, stop_2, step, utils_1.getParamValue('dtype', node, tensorMap, context))]; + } + case 'truncatedNormal': { + var shape = utils_1.getParamValue('shape', node, tensorMap, context); + var mean = utils_1.getParamValue('mean', node, tensorMap, context); + var stdDev = utils_1.getParamValue('stdDev', node, tensorMap, context); + var seed = utils_1.getParamValue('seed', node, tensorMap, context); + return [tfc.truncatedNormal(shape, mean, stdDev, utils_1.getParamValue('dtype', node, tensorMap, context), seed)]; + } + case 'zeros': { + return [tfc.zeros(utils_1.getParamValue('shape', node, tensorMap, context), utils_1.getParamValue('dtype', node, tensorMap, context))]; + } + case 'zerosLike': { + return [tfc.zerosLike(utils_1.getParamValue('x', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'creation'; +//# sourceMappingURL=creation_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.d.ts new file mode 100644 index 0000000..9df5915 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "dynamic"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.js new file mode 100644 index 0000000..627ed98 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/dynamic_executor.js @@ -0,0 +1,67 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { return __awaiter(_this, void 0, void 0, function () { + var _a, boxes, scores, maxOutputSize, iouThreshold, scoreThreshold; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _a = node.op; + switch (_a) { + case 'nonMaxSuppression': return [3, 1]; + case 'whereAsync': return [3, 3]; + } + return [3, 5]; + case 1: + boxes = utils_1.getParamValue('boxes', node, tensorMap, context); + scores = utils_1.getParamValue('scores', node, tensorMap, context); + maxOutputSize = utils_1.getParamValue('maxOutputSize', node, tensorMap, context); + iouThreshold = utils_1.getParamValue('iouThreshold', node, tensorMap, context); + scoreThreshold = utils_1.getParamValue('scoreThreshold', node, tensorMap, context); + return [4, tfc.image.nonMaxSuppressionAsync(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold)]; + case 2: return [2, [_b.sent()]]; + case 3: return [4, tfc.whereAsync(utils_1.getParamValue('condition', node, tensorMap, context))]; + case 4: return [2, [_b.sent()]]; + case 5: throw TypeError("Node type " + node.op + " is not implemented"); + } + }); +}); }; +exports.CATEGORY = 'dynamic'; +//# sourceMappingURL=dynamic_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.d.ts new file mode 100644 index 0000000..673cb68 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "evaluation"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.js new file mode 100644 index 0000000..f844626 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/evaluation_executor.js @@ -0,0 +1,19 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'topK': { + var x = utils_1.getParamValue('x', node, tensorMap, context); + var k = utils_1.getParamValue('k', node, tensorMap, context); + var sorted = utils_1.getParamValue('sorted', node, tensorMap, context); + var result = tfc.topk(x, k, sorted); + return [result.values, result.indices]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'evaluation'; +//# sourceMappingURL=evaluation_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.d.ts new file mode 100644 index 0000000..0714e2d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "graph"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.js new file mode 100644 index 0000000..cdd5bd4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/graph_executor.js @@ -0,0 +1,45 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'const': { + return tensorMap[node.name]; + } + case 'placeholder': + var def = utils_1.getParamValue('default', node, tensorMap, context); + return [utils_1.getTensor(node.name, tensorMap, context) || def]; + case 'identity': + case 'stopGradient': + case 'fakeQuantWithMinMaxVars': + return [utils_1.getParamValue('x', node, tensorMap, context)]; + case 'snapshot': + var snapshot = utils_1.getParamValue('x', node, tensorMap, context); + return [snapshot.clone()]; + case 'shape': + return [tfc.tensor1d(utils_1.getParamValue('x', node, tensorMap, context).shape, 'int32')]; + case 'size': + return [tfc.scalar(utils_1.getParamValue('x', node, tensorMap, context).size, 'int32')]; + case 'rank': + return [tfc.scalar(utils_1.getParamValue('x', node, tensorMap, context).rank, 'int32')]; + case 'noop': + return []; + case 'print': + var input = utils_1.getParamValue('x', node, tensorMap, context); + var data = utils_1.getParamValue('data', node, tensorMap, context); + var message = utils_1.getParamValue('message', node, tensorMap, context); + var summarize = utils_1.getParamValue('summarize', node, tensorMap, context); + console.warn('The graph has a tf.print() operation,' + + 'usually used for debugging, which slows down performance.'); + console.log(message); + for (var i = 0; i < data.length; i++) { + console.log(Array.prototype.slice.call(data[0].dataSync()).slice(0, summarize)); + } + return [input]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'graph'; +//# sourceMappingURL=graph_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.d.ts new file mode 100644 index 0000000..1aa381b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "image"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.js new file mode 100644 index 0000000..edb6249 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/image_executor.js @@ -0,0 +1,24 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'resizeBilinear': { + var images = utils_1.getParamValue('images', node, tensorMap, context); + var size = utils_1.getParamValue('size', node, tensorMap, context); + var alignCorners = utils_1.getParamValue('alignCorners', node, tensorMap, context); + return [tfc.image.resizeBilinear(images, [size[0], size[1]], alignCorners)]; + } + case 'resizeNearestNeighbor': { + var images = utils_1.getParamValue('images', node, tensorMap, context); + var size = utils_1.getParamValue('size', node, tensorMap, context); + var alignCorners = utils_1.getParamValue('alignCorners', node, tensorMap, context); + return [tfc.image.resizeNearestNeighbor(images, [size[0], size[1]], alignCorners)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'image'; +//# sourceMappingURL=image_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.d.ts new file mode 100644 index 0000000..7f07e57 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "logical"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.js new file mode 100644 index 0000000..69e4ce0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/logical_executor.js @@ -0,0 +1,42 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'equal': { + return [tfc.equal(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'notEqual': { + return [tfc.notEqual(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'greater': { + return [tfc.greater(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'greaterEqual': { + return [tfc.greaterEqual(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'less': { + return [tfc.less(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'lessEqual': { + return [tfc.lessEqual(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'logicalAnd': { + return [tfc.logicalAnd(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'logicalNot': { + return [tfc.logicalNot(utils_1.getParamValue('a', node, tensorMap, context))]; + } + case 'logicalOr': { + return [tfc.logicalOr(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + case 'where': { + return [tfc.where(utils_1.getParamValue('condition', node, tensorMap, context), utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'logical'; +//# sourceMappingURL=logical_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.d.ts new file mode 100644 index 0000000..993885d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "matrices"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.js new file mode 100644 index 0000000..e8f2e06 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/matrices_executor.js @@ -0,0 +1,16 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'matMul': + return [tfc.matMul(utils_1.getParamValue('a', node, tensorMap, context), utils_1.getParamValue('b', node, tensorMap, context), utils_1.getParamValue('transposeA', node, tensorMap, context), utils_1.getParamValue('transposeB', node, tensorMap, context))]; + case 'transpose': + return [tfc.transpose(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('perm', node, tensorMap, context))]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'matrices'; +//# sourceMappingURL=matrices_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.d.ts new file mode 100644 index 0000000..eba166f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "normalization"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.js new file mode 100644 index 0000000..756eee8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/normalization_executor.js @@ -0,0 +1,21 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'batchNormalization': { + return [tfc.batchNormalization(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('mean', node, tensorMap, context), utils_1.getParamValue('variance', node, tensorMap, context), utils_1.getParamValue('epsilon', node, tensorMap, context), utils_1.getParamValue('scale', node, tensorMap, context), utils_1.getParamValue('offset', node, tensorMap, context))]; + } + case 'localResponseNormalization': { + return [tfc.localResponseNormalization(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('radius', node, tensorMap, context), utils_1.getParamValue('bias', node, tensorMap, context), utils_1.getParamValue('alpha', node, tensorMap, context), utils_1.getParamValue('beta', node, tensorMap, context))]; + } + case 'softmax': { + return [tfc.softmax(utils_1.getParamValue('x', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'normalization'; +//# sourceMappingURL=normalization_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.d.ts new file mode 100644 index 0000000..b06d437 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "reduction"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.js new file mode 100644 index 0000000..d9cc321 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/reduction_executor.js @@ -0,0 +1,50 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'max': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.max(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'mean': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.mean(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'min': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.min(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'sum': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.sum(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'all': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.all(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'any': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var keepDims = utils_1.getParamValue('keepDims', node, tensorMap, context); + return [tfc.any(utils_1.getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'argMax': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + return [tfc.argMax(utils_1.getParamValue('x', node, tensorMap, context), axis)]; + } + case 'argMin': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + return [tfc.argMin(utils_1.getParamValue('x', node, tensorMap, context), axis)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'reduction'; +//# sourceMappingURL=reduction_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.d.ts new file mode 100644 index 0000000..be1fe03 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "slice_join"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.js new file mode 100644 index 0000000..45f57d2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/slice_join_executor.js @@ -0,0 +1,82 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'concat': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var inputs = utils_1.getParamValue('tensors', node, tensorMap, context); + return [tfc.concat(inputs, axis)]; + } + case 'gather': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var input = utils_1.getParamValue('x', node, tensorMap, context); + var indices = utils_1.getParamValue('indices', node, tensorMap, context); + return [tfc.gather(input, indices, axis)]; + } + case 'reverse': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var input = utils_1.getParamValue('x', node, tensorMap, context); + return [tfc.reverse(input, axis)]; + } + case 'slice': { + var begin = utils_1.getParamValue('begin', node, tensorMap, context); + var size = utils_1.getParamValue('size', node, tensorMap, context); + return [tfc.slice(utils_1.getParamValue('x', node, tensorMap, context), begin, size)]; + } + case 'stridedSlice': { + var begin = utils_1.getParamValue('begin', node, tensorMap, context); + var end = utils_1.getParamValue('end', node, tensorMap, context); + var strides = utils_1.getParamValue('strides', node, tensorMap, context); + var beginMask = utils_1.getParamValue('beginMask', node, tensorMap, context); + var endMask = utils_1.getParamValue('endMask', node, tensorMap, context); + var tensor = utils_1.getParamValue('x', node, tensorMap, context); + if (begin.length === 1 && tensor.shape.length > 1) { + for (var i = 1; i < tensor.shape.length; i++) { + begin.push(0); + end.push(tensor.shape[i]); + strides.push(strides[0]); + } + } + return [tfc.stridedSlice(tensor, begin, end, strides, beginMask, endMask)]; + } + case 'stack': { + return tfc.tidy(function () { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var tensors = utils_1.getParamValue('tensors', node, tensorMap, context); + var shape = tensors[0].shape; + var squeezedShape = tensors[0].squeeze().shape; + var mapped = tensors.map(function (tensor) { + var sameShape = tfc.util.arraysEqual(tensor.shape, shape); + if (!sameShape && + !tfc.util.arraysEqual(tensor.squeeze().shape, squeezedShape)) { + throw new Error('the input tensors shape does not match'); + } + return sameShape ? tensor : tensor.reshape(shape); + }); + return [tfc.stack(mapped, axis)]; + }); + } + case 'unstack': { + return tfc.tidy(function () { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var tensor = utils_1.getParamValue('tensor', node, tensorMap, context); + return tfc.unstack(tensor, axis); + }); + } + case 'tile': { + var reps = utils_1.getParamValue('reps', node, tensorMap, context); + return [tfc.tile(utils_1.getParamValue('x', node, tensorMap, context), reps)]; + } + case 'split': { + var axis = utils_1.getParamValue('axis', node, tensorMap, context); + var numOrSizeSplits = utils_1.getParamValue('numOrSizeSplits', node, tensorMap, context); + return tfc.split(utils_1.getParamValue('x', node, tensorMap, context), numOrSizeSplits, axis); + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'slice_join'; +//# sourceMappingURL=slice_join_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.d.ts new file mode 100644 index 0000000..57f2620 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.d.ts @@ -0,0 +1,10 @@ +import { ParamValue } from '../types'; +export declare function createNumberAttr(value: number): ParamValue; +export declare function createNumberAttrFromIndex(inputIndex: number): ParamValue; +export declare function createStrAttr(str: string): ParamValue; +export declare function createBoolAttr(value: boolean): ParamValue; +export declare function createNumericArrayAttr(value: number[]): ParamValue; +export declare function createNumericArrayAttrFromIndex(inputIndex: number): ParamValue; +export declare function createTensorAttr(index: number): ParamValue; +export declare function createTensorsAttr(index: number, paramLength: number): ParamValue; +export declare function createDtypeAttr(dtype: string): ParamValue; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.js new file mode 100644 index 0000000..3b7039d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/test_helper.js @@ -0,0 +1,39 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function createNumberAttr(value) { + return { value: value, type: 'number' }; +} +exports.createNumberAttr = createNumberAttr; +function createNumberAttrFromIndex(inputIndex) { + return { inputIndex: inputIndex, type: 'number' }; +} +exports.createNumberAttrFromIndex = createNumberAttrFromIndex; +function createStrAttr(str) { + return { value: str, type: 'string' }; +} +exports.createStrAttr = createStrAttr; +function createBoolAttr(value) { + return { value: value, type: 'bool' }; +} +exports.createBoolAttr = createBoolAttr; +function createNumericArrayAttr(value) { + return { value: value, type: 'number[]' }; +} +exports.createNumericArrayAttr = createNumericArrayAttr; +function createNumericArrayAttrFromIndex(inputIndex) { + return { inputIndex: inputIndex, type: 'number[]' }; +} +exports.createNumericArrayAttrFromIndex = createNumericArrayAttrFromIndex; +function createTensorAttr(index) { + return { inputIndex: index, type: 'tensor' }; +} +exports.createTensorAttr = createTensorAttr; +function createTensorsAttr(index, paramLength) { + return { inputIndex: index, inputParamLength: paramLength, type: 'tensors' }; +} +exports.createTensorsAttr = createTensorsAttr; +function createDtypeAttr(dtype) { + return { value: dtype, type: 'dtype' }; +} +exports.createDtypeAttr = createDtypeAttr; +//# sourceMappingURL=test_helper.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.d.ts new file mode 100644 index 0000000..f3a14e1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.d.ts @@ -0,0 +1,3 @@ +import { OpExecutor } from './types'; +export declare let executeOp: OpExecutor; +export declare const CATEGORY = "transformation"; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.js new file mode 100644 index 0000000..e436fd8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/transformation_executor.js @@ -0,0 +1,39 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var utils_1 = require("./utils"); +exports.executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'cast': { + return [tfc.cast(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('dtype', node, tensorMap, context))]; + } + case 'expandDims': { + var axis = node.params['axis'].value; + return [tfc.expandDims(utils_1.getParamValue('x', node, tensorMap, context), axis)]; + } + case 'squeeze': { + var axis = node.params['axis'].value; + return [tfc.squeeze(utils_1.getParamValue('x', node, tensorMap, context), axis)]; + } + case 'reshape': { + return [tfc.reshape(utils_1.getParamValue('x', node, tensorMap, context), utils_1.getParamValue('shape', node, tensorMap, context))]; + } + case 'pad': { + return [tfc.pad(utils_1.getParamValue('x', node, tensorMap, context), utils_1.split(utils_1.getParamValue('padding', node, tensorMap, context), 2), utils_1.getParamValue('constantValue', node, tensorMap, context))]; + } + case 'spaceToBatchND': { + var blockShape = utils_1.getParamValue('blockShape', node, tensorMap, context); + var paddings = utils_1.split(utils_1.getParamValue('paddings', node, tensorMap, context), 2); + return [tfc.spaceToBatchND(utils_1.getParamValue('x', node, tensorMap, context), blockShape, paddings)]; + } + case 'batchToSpaceND': { + var blockShape = utils_1.getParamValue('blockShape', node, tensorMap, context); + var crops = utils_1.split(utils_1.getParamValue('crops', node, tensorMap, context), 2); + return [tfc.batchToSpaceND(utils_1.getParamValue('x', node, tensorMap, context), blockShape, crops)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +}; +exports.CATEGORY = 'transformation'; +//# sourceMappingURL=transformation_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.d.ts new file mode 100644 index 0000000..eeb3e18 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.d.ts @@ -0,0 +1,7 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { NamedTensorsMap } from '../../data/types'; +import { ExecutionContext } from '../../executor/execution_context'; +import { Node } from '../types'; +export interface OpExecutor { + (node: Node, tensorMap: NamedTensorsMap, context: ExecutionContext): tfc.Tensor[] | Promise; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.d.ts new file mode 100644 index 0000000..0d3b3ed --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.d.ts @@ -0,0 +1,9 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { NamedTensorsMap } from '../../data/types'; +import { ExecutionContext } from '../../executor/execution_context'; +import { Node, ValueType } from '../types'; +export declare function getParamValue(paramName: string, node: Node, tensorMap: NamedTensorsMap, context: ExecutionContext): ValueType; +export declare function getTensor(name: string, tensorsMap: NamedTensorsMap, context: ExecutionContext): tfc.Tensor; +export declare function getNodeNameAndIndex(inputName: string, context?: ExecutionContext): [string, number]; +export declare function parseNodeName(name: string): [string, number]; +export declare function split(arr: number[], size: number): number[][]; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.js new file mode 100644 index 0000000..c03fce5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/executors/utils.js @@ -0,0 +1,61 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function getParamValue(paramName, node, tensorMap, context) { + var param = node.params[paramName]; + if (param && param.inputIndex !== undefined) { + if (param.type === 'tensor') { + return getTensor(node.inputNames[param.inputIndex], tensorMap, context); + } + if (param.type === 'tensors') { + var inputs = param.inputIndex === 0 ? + (param.inputParamLength === 0 ? + node.inputNames : + node.inputNames.slice(param.inputIndex, -param.inputParamLength)) : + node.inputNames.splice(param.inputIndex); + return inputs.map(function (name) { return getTensor(name, tensorMap, context); }); + } + var data = Array.prototype.slice.call(getTensor(node.inputNames.slice(param.inputIndex)[0], tensorMap, context) + .dataSync()); + return param.type === 'number' ? data[0] : data; + } + return param && param.value; +} +exports.getParamValue = getParamValue; +function getTensor(name, tensorsMap, context) { + var _a = parseNodeName(name), nodeName = _a[0], index = _a[1]; + var contextId = context.currentContextIds.find(function (contextId) { + return !!tensorsMap[getNodeNameWithContextId(nodeName, contextId)]; + }); + return contextId !== undefined ? + tensorsMap[getNodeNameWithContextId(nodeName, contextId)][index] : + undefined; +} +exports.getTensor = getTensor; +function getNodeNameAndIndex(inputName, context) { + var _a = parseNodeName(inputName), nodeName = _a[0], index = _a[1]; + return [ + getNodeNameWithContextId(nodeName, context && context.currentContextId), + index + ]; +} +exports.getNodeNameAndIndex = getNodeNameAndIndex; +function getNodeNameWithContextId(name, contextId) { + return !!contextId ? name + "-" + contextId : name; +} +function parseNodeName(name) { + var index = name.lastIndexOf(':'); + if (index === -1) + return [name, 0]; + var nodeName = name.substring(0, index); + return [nodeName, Number(name.substring(index + 1))]; +} +exports.parseNodeName = parseNodeName; +function split(arr, size) { + var res = []; + for (var i = 0; i < arr.length; i += size) { + res.push(arr.slice(i, i + size)); + } + return res; +} +exports.split = split; +//# sourceMappingURL=utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/arithmetic.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/arithmetic.json new file mode 100644 index 0000000..a1bde0f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/arithmetic.json @@ -0,0 +1,266 @@ +[ + { + "tfOpName": "Add", + "dlOpName": "add", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "BiasAdd", + "dlOpName": "add", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sub", + "dlOpName": "sub", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "RealDiv", + "dlOpName": "div", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Div", + "dlOpName": "div", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "FloorDiv", + "dlOpName": "floorDiv", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Mul", + "dlOpName": "mul", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Maximum", + "dlOpName": "maximum", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Minimum", + "dlOpName": "minimum", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Pow", + "dlOpName": "pow", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "SquaredDifference", + "dlOpName": "squaredDifference", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Mod", + "dlOpName": "mod", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/basic_math.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/basic_math.json new file mode 100644 index 0000000..8d4c08b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/basic_math.json @@ -0,0 +1,646 @@ +[ + { + "tfOpName": "Abs", + "dlOpName": "abs", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Acos", + "dlOpName": "acos", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Asin", + "dlOpName": "asin", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "atan", + "dlOpName": "atan", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Ceil", + "dlOpName": "ceil", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "ClipByValue", + "dlOpName": "clipByValue", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "clip_value_min", + "dlParamName": "clipValueMin", + "type": "number" + }, + { + "tfParamName": "clip_value_max", + "dlParamName": "clipValueMax", + "type": "number" + } + ] + }, + { + "tfOpName": "Cos", + "dlOpName": "cos", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Cosh", + "dlOpName": "cosh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Elu", + "dlOpName": "elu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Exp", + "dlOpName": "exp", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Floor", + "dlOpName": "floor", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Log", + "dlOpName": "log", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Neg", + "dlOpName": "neg", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Relu", + "dlOpName": "relu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Relu6", + "dlOpName": "clipByValue", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "dlParamName": "clipValueMin", + "type": "number", + "defaultValue": 0 + }, + { + "dlParamName": "clipValueMax", + "type": "number", + "defaultValue": 6 + } + ] + }, + { + "tfOpName": "Selu", + "dlOpName": "selu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sigmoid", + "dlOpName": "sigmoid", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sin", + "dlOpName": "sin", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sinh", + "dlOpName": "sinh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sqrt", + "dlOpName": "sqrt", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Rsqrt", + "dlOpName": "rsqrt", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Square", + "dlOpName": "square", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Tan", + "dlOpName": "tan", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Tanh", + "dlOpName": "tanh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sign", + "dlOpName": "sign", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Round", + "dlOpName": "round", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Expm1", + "dlOpName": "expm1", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Log1p", + "dlOpName": "log1p", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reciprocal", + "dlOpName": "reciprocal", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reciprocal", + "dlOpName": "reciprocal", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Softplus", + "dlOpName": "softplus", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Asinh", + "dlOpName": "asinh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Acosh", + "dlOpName": "acosh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Atanh", + "dlOpName": "atanh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Erf", + "dlOpName": "erf", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/control.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/control.json new file mode 100644 index 0000000..db90232 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/control.json @@ -0,0 +1,364 @@ +[ + { + "tfOpName": "LoopCond", + "dlOpName": "loopCond", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "pred", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Switch", + "dlOpName": "switch", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "data", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "pred", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Merge", + "dlOpName": "merge", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensors", + "type": "tensors" + } + ] + }, + { + "tfOpName": "Enter", + "dlOpName": "enter", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "frame_name", + "dlParamName": "frameName", + "type": "string" + }, + { + "tfParamName": "is_constant", + "dlParamName": "isConstant", + "type": "bool" + } + ] + }, + { + "tfOpName": "Exit", + "dlOpName": "exit", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NextIteration", + "dlOpName": "nextIteration", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayV3", + "dlOpName": "tensorArray", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "size", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape", + "dlParamName": "elementShape", + "type": "shape" + }, + { + "tfParamName": "dynamic_size", + "dlParamName": "dynamicSize", + "type": "bool" + }, + { + "tfParamName": "clear_after_read", + "dlParamName": "clearAfterRead", + "type": "bool" + }, + { + "tfParamName": "identical_element_shapes", + "dlParamName": "identicalElementShapes", + "type": "bool" + }, + { + "tfParamName": "tensor_array_name", + "dlParamName": "name", + "type": "string" + } + ] + }, + { + "tfOpName": "TensorArrayWriteV3", + "dlOpName": "tensorArrayWrite", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "index", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayReadV3", + "dlOpName": "tensorArrayRead", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "index", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayGatherV3", + "dlOpName": "tensorArrayGather", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape", + "dlParamName": "elementShape", + "type": "shape" + } + ] + }, + { + "tfOpName": "TensorArrayScatterV3", + "dlOpName": "tensorArrayScatter", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "tensor", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "TensorArrayConcatV3", + "dlOpName": "tensorArrayConcat", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape_except0", + "dlParamName": "elementShapeExcept0", + "type": "shape", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArraySplitV3", + "dlOpName": "tensorArraySplit", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "lengths", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "TensorArraySizeV3", + "dlOpName": "tensorArraySize", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "flowIn", + "type": "number" + } + ] + }, + { + "tfOpName": "TensorArrayCloseV3", + "dlOpName": "tensorArrayClose", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/convolution.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/convolution.json new file mode 100644 index 0000000..6d84b65 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/convolution.json @@ -0,0 +1,288 @@ +[ + { + "tfOpName": "AvgPool", + "dlOpName": "avgPool", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + }, + { + "tfParamName": "ksize", + "dlParamName": "kernelSize", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "MaxPool", + "dlOpName": "maxPool", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + }, + { + "tfParamName": "ksize", + "dlParamName": "kernelSize", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Conv1D", + "dlOpName": "conv1d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "stride", + "dlParamName": "stride", + "type": "number" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NWC" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "dilation", + "dlParamName": "dilation", + "type": "number", + "defaultValue": 1 + } + ] + }, + { + "tfOpName": "Conv2D", + "dlOpName": "conv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "useCudnnOnGpu", + "dlParamName": "useCudnnOnGpu", + "type": "bool" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Conv2DBackpropInput", + "dlOpName": "conv2dTranspose", + "category": "convolution", + "params": [ + { + "tfInputIndex": 2, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfInputIndex": 0, + "dlParamName": "outputShape", + "type": "number[]" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "DepthwiseConv2d", + "dlOpName": "depthwiseConv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "input", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + }, + { + "tfOpName": "DepthwiseConv2dNative", + "dlOpName": "depthwiseConv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "input", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/creation.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/creation.json new file mode 100644 index 0000000..66f1b58 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/creation.json @@ -0,0 +1,285 @@ +[ + { + "tfOpName": "Fill", + "dlOpName": "fill", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfInputIndex": 1, + "dlParamName": "value", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LinSpace", + "dlOpName": "linspace", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "start", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "stop", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "num", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "OneHot", + "dlOpName": "oneHot", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "depth", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "onValue", + "type": "number", + "defaultValue": 1 + }, + { + "tfInputIndex": 3, + "dlParamName": "offValue", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "notSupported": true + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Ones", + "dlOpName": "ones", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "OnesLike", + "dlOpName": "onesLike", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "RandomUniform", + "dlOpName": "randomUniform", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "minval", + "dlParamName": "minval", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "maxval", + "dlParamName": "maxval", + "type": "number", + "defaultValue": 1 + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "seed", + "dlParamName": "seed", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "seed2", + "dlParamName": "seed2", + "type": "number", + "defaultValue": 0, + "notSupported": true + }, + { + "tfParamName": "T", + "dlParamName": "T", + "type": "number", + "notSupported": true + } + ] + }, + { + "tfOpName": "Range", + "dlOpName": "range", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "start", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "stop", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "step", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "Tidx", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "truncatedNormal", + "dlOpName": "truncatedNormal", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "means", + "dlParamName": "mean", + "type": "number", + "defaultValue": 0.0 + }, + { + "tfParamName": "stddev", + "dlParamName": "stdDev", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "seed", + "dlParamName": "seed", + "type": "number" + }, + { + "tfParamName": "seed2", + "dlParamName": "seed2", + "type": "number", + "defaultValue": 0, + "notSupported": true + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "T", + "dlParamName": "T", + "type": "number", + "notSupported": true + } + ] + }, + { + "tfOpName": "Zeros", + "dlOpName": "zeros", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "ZerosLike", + "dlOpName": "zerosLike", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/dynamic.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/dynamic.json new file mode 100644 index 0000000..5adb5be --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/dynamic.json @@ -0,0 +1,79 @@ +[ + { + "tfOpName": "NonMaxSuppressionV2", + "dlOpName": "nonMaxSuppression", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV3", + "dlOpName": "nonMaxSuppression", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + }, + { + "tfInputIndex": 4, + "dlParamName": "scoreThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "Where", + "dlOpName": "whereAsync", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "condition", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/evaluation.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/evaluation.json new file mode 100644 index 0000000..f72a99d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/evaluation.json @@ -0,0 +1,24 @@ +[ + { + "tfOpName": "TopKV2", + "dlOpName": "topK", + "category": "evaluation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "k", + "type": "number" + }, + { + "tfParamName": "sorted", + "dlParamName": "sorted", + "type": "bool" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/graph.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/graph.json new file mode 100644 index 0000000..8d0295c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/graph.json @@ -0,0 +1,181 @@ +[ + { + "tfOpName": "PlaceholderWithDefault", + "dlOpName": "placeholder", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "default", + "type": "tensor" + }, + { + "tfParamName": "shape", + "dlParamName": "shape", + "type": "shape" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "Placeholder", + "dlOpName": "placeholder", + "category": "graph", + "params": [ + { + "tfParamName": "shape", + "dlParamName": "shape", + "type": "shape" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "Const", + "dlOpName": "const", + "category": "graph" + }, + { + "tfOpName": "Identity", + "dlOpName": "identity", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Snapshot", + "dlOpName": "snapshot", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Rank", + "dlOpName": "rank", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Size", + "dlOpName": "size", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Shape", + "dlOpName": "shape", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Print", + "dlOpName": "print", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "tfInputParamLength": 1, + "dlParamName": "data", + "type": "tensors" + }, + { + "tfParamName": "message", + "dlParamName": "message", + "type": "string" + }, + { + "tfParamName": "first_n", + "dlParamName": "firstN", + "type": "number", + "notSupprted": true + }, + { + "tfParamName": "summarize", + "dlParamName": "summarize", + "type": "number", + "defaultValue": 3 + } + ] + }, + { + "tfOpName": "NoOp", + "dlOpName": "noop", + "category": "graph", + "params": [] + }, + { + "tfOpName": "StopGradient", + "dlOpName": "stopGradient", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "FakeQuantWithMinMaxVars", + "dlOpName": "fakeQuantWithMinMaxVars", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "min", + "dlParamName": "min", + "type": "number" + }, + { + "tfParamName": "max", + "dlParamName": "max", + "type": "number" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/image.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/image.json new file mode 100644 index 0000000..f4d2f73 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/image.json @@ -0,0 +1,117 @@ +[ + { + "tfOpName": "ResizeBilinear", + "dlOpName": "resizeBilinear", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "images", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "size", + "type": "number[]" + }, + { + "tfParamName": "align_corners", + "dlParamName": "alignCorners", + "type": "bool" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "ResizeNearestNeighbor", + "dlOpName": "resizeNearestNeighbor", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "images", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "size", + "type": "number[]" + }, + { + "tfParamName": "align_corners", + "dlParamName": "alignCorners", + "type": "bool" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV2", + "dlOpName": "nonMaxSuppression", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV3", + "dlOpName": "nonMaxSuppression", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + }, + { + "tfInputIndex": 4, + "dlParamName": "scoreThreshold", + "type": "number" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/logical.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/logical.json new file mode 100644 index 0000000..21d2d9a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/logical.json @@ -0,0 +1,232 @@ +[ + { + "tfOpName": "Equal", + "dlOpName": "equal", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NotEqual", + "dlOpName": "notEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Greater", + "dlOpName": "greater", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "GreaterEqual", + "dlOpName": "greaterEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Less", + "dlOpName": "less", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LessEqual", + "dlOpName": "lessEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalAnd", + "dlOpName": "logicalAnd", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalNot", + "dlOpName": "logicalNot", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalOr", + "dlOpName": "logicalOr", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Select", + "dlOpName": "where", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "condition", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/matrices.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/matrices.json new file mode 100644 index 0000000..c9662f5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/matrices.json @@ -0,0 +1,60 @@ +[ + { + "tfOpName": "MatMul", + "dlOpName": "matMul", + "category": "matrices", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "transpose_a", + "dlParamName": "transposeA", + "type": "bool", + "defaultValue": false + }, + { + "tfParamName": "transpose_b", + "dlParamName": "transposeB", + "type": "bool", + "defaultValue": false + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Transpose", + "dlOpName": "transpose", + "category": "matrices", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "perm", + "dlParamName": "perm", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/normalization.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/normalization.json new file mode 100644 index 0000000..a5cb485 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/normalization.json @@ -0,0 +1,137 @@ +[ + { + "tfOpName": "FusedBatchNorm", + "dlOpName": "batchNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scale", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "offset", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "mean", + "type": "tensor" + }, + { + "tfInputIndex": 4, + "dlParamName": "variance", + "type": "tensor" + }, + { + "tfParamName": "epsilon", + "dlParamName": "epsilon", + "type": "number", + "defaultValue": 0.001 + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "FusedBatchNormV2", + "dlOpName": "batchNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scale", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "offset", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "mean", + "type": "tensor" + }, + { + "tfInputIndex": 4, + "dlParamName": "variance", + "type": "tensor" + }, + { + "tfParamName": "epsilon", + "dlParamName": "epsilon", + "type": "number", + "defaultValue": 0.001 + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "LRN", + "dlOpName": "localResponseNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "depth_radius", + "dlParamName": "radius", + "type": "number", + "defaultValue": 5 + }, + { + "tfParamName": "bias", + "dlParamName": "bias", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "alpha", + "dlParamName": "alpha", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "beta", + "dlParamName": "beta", + "type": "number", + "defaultValue": 0.5 + } + ] + }, { + "tfOpName": "Softmax", + "dlOpName": "softmax", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/reduction.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/reduction.json new file mode 100644 index 0000000..9d3fd95 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/reduction.json @@ -0,0 +1,168 @@ +[ + { + "tfOpName": "Max", + "dlOpName": "max", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Mean", + "dlOpName": "mean", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Min", + "dlOpName": "min", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Sum", + "dlOpName": "sum", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "All", + "dlOpName": "all", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Any", + "dlOpName": "any", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "ArgMax", + "dlOpName": "argMax", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "ArgMin", + "dlOpName": "argMin", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/slice_join.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/slice_join.json new file mode 100644 index 0000000..2e4f783 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/slice_join.json @@ -0,0 +1,263 @@ +[ + { + "tfOpName": "ConcatV2", + "dlOpName": "concat", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "tfInputParamLength": 1, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfInputIndex": -1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Concat", + "dlOpName": "concat", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 1, + "tfInputParamLength": 1, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfInputIndex": 0, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "GatherV2", + "dlOpName": "gather", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Gather", + "dlOpName": "gather", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "validate_indices", + "dlParamName": "validateIndices", + "type": "bool", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reverse", + "dlOpName": "reverse", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "ReverseV2", + "dlOpName": "reverse", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Slice", + "dlOpName": "slice", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "begin", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "size", + "type": "number[]" + } + ] + }, + { + "tfOpName": "StridedSlice", + "dlOpName": "stridedSlice", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "begin", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "end", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "begin_mask", + "dlParamName": "beginMask", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "end_mask", + "dlParamName": "endMask", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Pack", + "dlOpName": "stack", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Unpack", + "dlOpName": "unstack", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "num", + "dlParamName": "num", + "type": "number", + "defaultValue": 0, + "notSupported": true + } + ] + }, + { + "tfOpName": "Tile", + "dlOpName": "tile", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "reps", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Split", + "dlOpName": "split", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfInputIndex": 1, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "num_split", + "dlParamName": "numOrSizeSplits", + "type": "number", + "defaultValue": 1 + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/transformation.json b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/transformation.json new file mode 100644 index 0000000..65e091d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/op_list/transformation.json @@ -0,0 +1,161 @@ +[ + { + "tfOpName": "Cast", + "dlOpName": "cast", + "category": "transformation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "SrcT", + "dlParamName": "sdtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "DstT", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "ExpandDims", + "dlOpName": "expandDims", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "tfParamNameDeprecated": "dim", + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Pad", + "dlOpName": "pad", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "padding", + "type": "number[]" + }, + { + "tfParamName": "constant_value", + "dlParamName": "constantValue", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "PadV2", + "dlOpName": "pad", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "padding", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "constantValue", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Reshape", + "dlOpName": "reshape", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "shape", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Squeeze", + "dlOpName": "squeeze", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "axis", + "tfParamNameDeprecated": "squeeze_dims", + "dlParamName": "axis", + "type": "number[]" + } + ] + }, + { + "tfOpName": "SpaceToBatchND", + "dlOpName": "spaceToBatchND", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "blockShape", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "paddings", + "type": "number[]" + } + ] + }, + { + "tfOpName": "BatchToSpaceND", + "dlOpName": "batchToSpaceND", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "blockShape", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "crops", + "type": "number[]" + } + ] + } +] diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.d.ts new file mode 100644 index 0000000..28e0f5e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.d.ts @@ -0,0 +1,5 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { NamedTensorsMap } from '../data/types'; +import { ExecutionContext } from '../executor/execution_context'; +import { Node } from './types'; +export declare function executeOp(node: Node, tensorMap: NamedTensorsMap, context: ExecutionContext): tfc.Tensor[] | Promise; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.js new file mode 100644 index 0000000..bcf91b8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_executor.js @@ -0,0 +1,55 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var arithmetic = require("./executors/arithmetic_executor"); +var basicMath = require("./executors/basic_math_executor"); +var control = require("./executors/control_executor"); +var convolution = require("./executors/convolution_executor"); +var creation = require("./executors/creation_executor"); +var dynamic = require("./executors/dynamic_executor"); +var evaluation = require("./executors/evaluation_executor"); +var graph = require("./executors/graph_executor"); +var image = require("./executors/image_executor"); +var logical = require("./executors/logical_executor"); +var matrices = require("./executors/matrices_executor"); +var normalization = require("./executors/normalization_executor"); +var reduction = require("./executors/reduction_executor"); +var sliceJoin = require("./executors/slice_join_executor"); +var transformation = require("./executors/transformation_executor"); +function executeOp(node, tensorMap, context) { + switch (node.category) { + case 'arithmetic': + return arithmetic.executeOp(node, tensorMap, context); + case 'basic_math': + return basicMath.executeOp(node, tensorMap, context); + case 'control': + return control.executeOp(node, tensorMap, context); + case 'convolution': + return convolution.executeOp(node, tensorMap, context); + case 'creation': + return creation.executeOp(node, tensorMap, context); + case 'dynamic': + return dynamic.executeOp(node, tensorMap, context); + case 'evaluation': + return evaluation.executeOp(node, tensorMap, context); + case 'image': + return image.executeOp(node, tensorMap, context); + case 'graph': + return graph.executeOp(node, tensorMap, context); + case 'logical': + return logical.executeOp(node, tensorMap, context); + case 'matrices': + return matrices.executeOp(node, tensorMap, context); + case 'normalization': + return normalization.executeOp(node, tensorMap, context); + case 'reduction': + return reduction.executeOp(node, tensorMap, context); + case 'slice_join': + return sliceJoin.executeOp(node, tensorMap, context); + case 'transformation': + return transformation.executeOp(node, tensorMap, context); + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } +} +exports.executeOp = executeOp; +//# sourceMappingURL=operation_executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.d.ts new file mode 100644 index 0000000..dd8ef3c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.d.ts @@ -0,0 +1,18 @@ +import { tensorflow } from '../data/compiled_api'; +import { Graph } from './types'; +export declare class OperationMapper { + private static _instance; + private opMappers; + static readonly Instance: OperationMapper; + private constructor(); + private isControlFlow(node); + private isDynamicShape(node); + transformGraph(graph: tensorflow.IGraphDef): Graph; + private mapNode(node); + private getStringParam(attrs, name, def, keepCase?); + private getBoolParam(attrs, name, def); + private getNumberParam(attrs, name, def); + private getDtypeParam(attrs, name, def); + private getTensorShapeParam(attrs, name, def?); + private getNumericArrayParam(attrs, name, def); +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.js new file mode 100644 index 0000000..c8d2752 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/operation_mapper.js @@ -0,0 +1,218 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var compiled_api_1 = require("../data/compiled_api"); +var utils_1 = require("./executors/utils"); +var arithmetic = require("./op_list/arithmetic.json"); +var basicMath = require("./op_list/basic_math.json"); +var control = require("./op_list/control.json"); +var convolution = require("./op_list/convolution.json"); +var creation = require("./op_list/creation.json"); +var dynamic = require("./op_list/dynamic.json"); +var evaluation = require("./op_list/evaluation.json"); +var graph = require("./op_list/graph.json"); +var image = require("./op_list/image.json"); +var logical = require("./op_list/logical.json"); +var matrices = require("./op_list/matrices.json"); +var normalization = require("./op_list/normalization.json"); +var reduction = require("./op_list/reduction.json"); +var sliceJoin = require("./op_list/slice_join.json"); +var transformation = require("./op_list/transformation.json"); +var CONTROL_FLOW_OPS = ['Switch', 'Merge', 'Enter', 'Exit', 'NextIteration']; +var DYNAMIC_SHAPE_OPS = ['NonMaxSuppressionV2', 'NonMaxSuppressionV3', 'Where']; +var OperationMapper = (function () { + function OperationMapper() { + var ops = [ + arithmetic, basicMath, control, convolution, creation, dynamic, + evaluation, logical, image, graph, matrices, normalization, reduction, + sliceJoin, transformation + ]; + var mappersJson = [].concat.apply([], ops.map(function (op) { return op.default ? op.default : op; })); + this.opMappers = mappersJson.reduce(function (map, mapper) { + map[mapper.tfOpName] = mapper; + return map; + }, {}); + } + Object.defineProperty(OperationMapper, "Instance", { + get: function () { + return this._instance || (this._instance = new this()); + }, + enumerable: true, + configurable: true + }); + OperationMapper.prototype.isControlFlow = function (node) { + return CONTROL_FLOW_OPS.some(function (op) { return op === node.op; }); + }; + OperationMapper.prototype.isDynamicShape = function (node) { + return DYNAMIC_SHAPE_OPS.some(function (op) { return op === node.op; }); + }; + OperationMapper.prototype.transformGraph = function (graph) { + var _this = this; + var tfNodes = graph.node; + var withControlFlow = false; + var withDynamicShape = false; + var placeholders = []; + var nodes = tfNodes.reduce(function (map, node) { + map[node.name] = _this.mapNode(node); + if (_this.isControlFlow(node)) + withControlFlow = true; + if (_this.isDynamicShape(node)) + withDynamicShape = true; + if (node.op === 'Placeholder') + placeholders.push(map[node.name]); + return map; + }, {}); + var inputs = []; + var outputs = []; + Object.keys(nodes).forEach(function (key) { + var node = nodes[key]; + node.inputNames.forEach(function (name) { + var nodeName = utils_1.getNodeNameAndIndex(name)[0]; + node.inputs.push(nodes[nodeName]); + nodes[nodeName].children.push(node); + }); + if (node.inputs.length === 0) + inputs.push(node); + }); + Object.keys(nodes).forEach(function (key) { + var node = nodes[key]; + if (node.children.length === 0) + outputs.push(node); + }); + return { + nodes: nodes, + inputs: inputs, + outputs: outputs, + placeholders: placeholders, + withControlFlow: withControlFlow, + withDynamicShape: withDynamicShape + }; + }; + OperationMapper.prototype.mapNode = function (node) { + var _this = this; + var mapper = this.opMappers[node.op]; + if (mapper === undefined) { + throw new Error('Tensorflow Op is not supported: ' + node.op); + } + var newNode = { + name: node.name, + op: mapper.dlOpName, + category: mapper.category, + inputNames: (node.input || + []).map(function (input) { return input.startsWith('^') ? input.substr(1) : input; }), + inputs: [], + children: [], + params: {} + }; + if (!!mapper.params) { + newNode.params = mapper.params.reduce(function (map, param) { + var inputIndex = param.tfInputIndex; + var inputParamLength = param.tfInputParamLength; + var type = param.type; + var value = undefined; + if (inputIndex === undefined) { + switch (param.type) { + case 'string': + value = _this.getStringParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getStringParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'number': + value = _this.getNumberParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getNumberParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'number[]': + value = _this.getNumericArrayParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getNumericArrayParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'bool': + value = _this.getBoolParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getBoolParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'shape': + value = _this.getTensorShapeParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getTensorShapeParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'dtype': + value = _this.getDtypeParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getDtypeParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'tensor': + case 'tensors': + break; + default: + throw new Error("Unsupported param type: " + param.type + " for op: " + node.op); + } + } + map[param.dlParamName] = { value: value, inputIndex: inputIndex, type: type, inputParamLength: inputParamLength }; + return map; + }, {}); + } + return newNode; + }; + OperationMapper.prototype.getStringParam = function (attrs, name, def, keepCase) { + if (keepCase === void 0) { keepCase = false; } + var param = attrs[name]; + if (param !== undefined) { + var value = String.fromCharCode.apply(null, param.s); + return keepCase ? value : value.toLowerCase(); + } + return def; + }; + OperationMapper.prototype.getBoolParam = function (attrs, name, def) { + var param = attrs[name]; + return param ? param.b : def; + }; + OperationMapper.prototype.getNumberParam = function (attrs, name, def) { + var param = attrs[name]; + var value = (param ? ((param.f !== undefined) ? param.f : param.i) : def); + return (typeof value === 'number') ? value : value['toInt'](); + }; + OperationMapper.prototype.getDtypeParam = function (attrs, name, def) { + var param = attrs[name]; + if (param && param.type) { + switch (param.type) { + case compiled_api_1.tensorflow.DataType.DT_FLOAT: + return 'float32'; + case compiled_api_1.tensorflow.DataType.DT_INT32: + return 'int32'; + case compiled_api_1.tensorflow.DataType.DT_BOOL: + return 'bool'; + default: + return def; + } + } + return def; + }; + OperationMapper.prototype.getTensorShapeParam = function (attrs, name, def) { + var param = attrs[name]; + if (param && param.shape) { + return param.shape.dim.map(function (dim) { + return (typeof dim.size === 'number') ? dim.size : dim.size['toInt'](); + }); + } + return def; + }; + OperationMapper.prototype.getNumericArrayParam = function (attrs, name, def) { + var param = attrs[name]; + if (param) { + return ((param.list.f && param.list.f.length ? param.list.f : + param.list.i)) + .map(function (v) { return (typeof v === 'number') ? v : v['toInt'](); }); + } + return def; + }; + return OperationMapper; +}()); +exports.OperationMapper = OperationMapper; +//# sourceMappingURL=operation_mapper.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/types.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/types.d.ts new file mode 100644 index 0000000..c64401d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/types.d.ts @@ -0,0 +1,49 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +export declare type ParamTypes = 'number' | 'string' | 'number[]' | 'bool' | 'shape' | 'tensor' | 'tensors' | 'dtype'; +export declare type Category = 'arithmetic' | 'basic_math' | 'control' | 'convolution' | 'dynamic' | 'evaluation' | 'image' | 'creation' | 'graph' | 'logical' | 'matrices' | 'normalization' | 'reduction' | 'slice_join' | 'transformation'; +export interface ParamMapper { + tfParamName?: string; + tfParamNameDeprecated?: string; + tfInputIndex?: number; + tfInputParamLength?: number; + dlParamName: string; + type: ParamTypes; + converter?: string; + defaultValue?: string | string[] | number | number[] | boolean | boolean[]; + notSupported?: boolean; +} +export interface OpMapper { + tfOpName: string; + dlOpName: string; + category: Category; + params: ParamMapper[]; + unsupportedParams: string[]; +} +export interface Node { + name: string; + op: string; + category: Category; + inputNames: string[]; + inputs: Node[]; + params: { + [key: string]: ParamValue; + }; + children: Node[]; +} +export interface Graph { + nodes: { + [key: string]: Node; + }; + placeholders: Node[]; + inputs: Node[]; + outputs: Node[]; + withControlFlow: boolean; + withDynamicShape: boolean; +} +export declare type ValueType = string | string[] | number | number[] | number[][] | boolean | boolean[] | Tensor | Tensor[]; +export interface ParamValue { + value?: ValueType; + inputIndex?: number; + inputParamLength?: number; + type: ParamTypes; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/types.js b/node_modules/@tensorflow/tfjs-converter/dist/operations/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/dist/operations/typings.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/operations/typings.d.ts new file mode 100644 index 0000000..ef959c2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/operations/typings.d.ts @@ -0,0 +1,21 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ + +declare module '*.json' { + const value: any; + export default value; +} diff --git a/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js new file mode 100644 index 0000000..8dc7b59 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js @@ -0,0 +1,17 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +import{concat,slice,stack,tensor,tidy,unstack,util,io,Tensor,add,mod,mul,div,floorDiv,sub,minimum,maximum,pow,squaredDifference,abs,acos,acosh,asin,asinh,atan,atanh,ceil,cos,cosh,elu,erf,exp,expm1,floor,log,log1p,neg,reciprocal,relu,round,selu,sigmoid,sin,sign,sinh,softplus,sqrt,square,tanh,tan,clipByValue,scalar,conv1d,conv2d,conv2dTranspose,depthwiseConv2d,avgPool,maxPool,fill,linspace,oneHot,ones,onesLike,randomUniform,range,truncatedNormal,zeros,zerosLike,image,whereAsync,topk,tensor1d,equal,notEqual,greater,greaterEqual,less,lessEqual,logicalAnd,logicalNot,logicalOr,where,matMul,transpose,batchNormalization,localResponseNormalization,softmax,max,mean,min,sum,all,any,argMax,argMin,gather,reverse,stridedSlice,tile,split,cast,expandDims,squeeze,reshape,pad,spaceToBatchND,batchToSpaceND}from"@tensorflow/tfjs-core";var __assign=Object.assign||function(e){for(var t,a=1,r=arguments.length;a0&&n[n.length-1])&&(6===o[0]||2===o[0])){s=0;continue}if(3===o[0]&&(!n||o[1]>n[0]&&o[1]= 0x80 (not a basic code point)","invalid-input":"Invalid input"},x=u-m,v=Math.floor,I=String.fromCharCode;function O(e){throw RangeError(b[e])}function w(e,t){for(var a=e.length,r=[];a--;)r[a]=t(e[a]);return r}function V(e,t){var a=e.split("@"),r="";return a.length>1&&(r=a[0]+"@",e=a[1]),r+w((e=e.replace(P,".")).split("."),t).join(".")}function T(e){for(var t,a,r=[],n=0,o=e.length;n=55296&&t<=56319&&n65535&&(t+=I((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+=I(e)}).join("")}function $(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function _(e,t,a){var r=0;for(e=a?v(e/c):e>>1,e+=v(e/t);e>x*l>>1;r+=u)e=v(e/x);return v(r+(x+1)*e/(e+d))}function A(e){var t,a,r,n,o,s,i,d,c,g,N,P=[],b=e.length,x=0,I=h,w=f;for((a=e.lastIndexOf(y))<0&&(a=0),r=0;r=128&&O("not-basic"),P.push(e.charCodeAt(r));for(n=a>0?a+1:0;n=b&&O("invalid-input"),((d=(N=e.charCodeAt(n++))-48<10?N-22:N-65<26?N-65:N-97<26?N-97:u)>=u||d>v((p-x)/s))&&O("overflow"),x+=d*s,!(d<(c=i<=w?m:i>=w+l?l:i-w));i+=u)s>v(p/(g=u-c))&&O("overflow"),s*=g;w=_(x-o,t=P.length+1,0==o),v(x/t)>p-I&&O("overflow"),I+=v(x/t),x%=t,P.splice(x++,0,I)}return k(P)}function S(e){var t,a,r,n,o,s,i,d,c,g,N,P,b,x,w,V=[];for(P=(e=T(e)).length,t=h,a=0,o=f,s=0;s=t&&Nv((p-a)/(b=r+1))&&O("overflow"),a+=(i-t)*b,t=i,s=0;sp&&O("overflow"),N==t){for(d=a,c=u;!(d<(g=c<=o?m:c>=o+l?l:c-o));c+=u)w=d-g,x=u-g,V.push(I($(g+w%x,0))),d=v(w/x);V.push(I($(d,0))),o=_(a,b,r==n),a=0,++r}++a,++t}return V.join("")}if(s={version:"1.3.2",ucs2:{decode:T,encode:k},decode:A,encode:S,toASCII:function(e){return V(e,function(e){return N.test(e)?"xn--"+S(e):e})},toUnicode:function(e){return V(e,function(e){return g.test(e)?A(e.slice(4).toLowerCase()):e})}},r&&n)if(e.exports==r)n.exports=s;else for(i in s)s.hasOwnProperty(i)&&(r[i]=s[i]);else a.punycode=s}(commonjsGlobal)}),util$1={isString:function(e){return"string"==typeof e},isObject:function(e){return"object"==typeof e&&null!==e},isNull:function(e){return null===e},isNullOrUndefined:function(e){return null==e}};function hasOwnProperty(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var decode=function(e,t,a,r){t=t||"&",a=a||"=";var n={};if("string"!=typeof e||0===e.length)return n;var o=/\+/g;e=e.split(t);var s=1e3;r&&"number"==typeof r.maxKeys&&(s=r.maxKeys);var i=e.length;s>0&&i>s&&(i=s);for(var p=0;p=0?(u=c.substr(0,f),m=c.substr(f+1)):(u=c,m=""),l=decodeURIComponent(u),d=decodeURIComponent(m),hasOwnProperty(n,l)?Array.isArray(n[l])?n[l].push(d):n[l]=[n[l],d]:n[l]=d}return n},stringifyPrimitive=function(e){switch(typeof e){case"string":return e;case"boolean":return e?"true":"false";case"number":return isFinite(e)?e:"";default:return""}},encode=function(e,t,a,r){return t=t||"&",a=a||"=",null===e&&(e=void 0),"object"==typeof e?Object.keys(e).map(function(r){var n=encodeURIComponent(stringifyPrimitive(r))+a;return Array.isArray(e[r])?e[r].map(function(e){return n+encodeURIComponent(stringifyPrimitive(e))}).join(t):n+encodeURIComponent(stringifyPrimitive(e[r]))}).join(t):r?encodeURIComponent(stringifyPrimitive(r))+a+encodeURIComponent(stringifyPrimitive(e)):""},querystring=createCommonjsModule(function(e,t){t.decode=t.parse=decode,t.encode=t.stringify=encode}),querystring_1=querystring.decode,querystring_2=querystring.parse,querystring_3=querystring.encode,querystring_4=querystring.stringify,parse=urlParse,format=urlFormat;function Url(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}var protocolPattern=/^([a-z0-9.+-]+:)/i,portPattern=/:[0-9]*$/,simplePathPattern=/^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/,delims=["<",">",'"',"`"," ","\r","\n","\t"],unwise=["{","}","|","\\","^","`"].concat(delims),autoEscape=["'"].concat(unwise),nonHostChars=["%","/","?",";","#"].concat(autoEscape),hostEndingChars=["/","?","#"],hostnameMaxLen=255,hostnamePartPattern=/^[+a-z0-9A-Z_-]{0,63}$/,hostnamePartStart=/^([+a-z0-9A-Z_-]{0,63})(.*)$/,unsafeProtocol={javascript:!0,"javascript:":!0},hostlessProtocol={javascript:!0,"javascript:":!0},slashedProtocol={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,"http:":!0,"https:":!0,"ftp:":!0,"gopher:":!0,"file:":!0};function urlParse(e,t,a){if(e&&util$1.isObject(e)&&e instanceof Url)return e;var r=new Url;return r.parse(e,t,a),r}function urlFormat(e){return util$1.isString(e)&&(e=urlParse(e)),e instanceof Url?e.format():Url.prototype.format.call(e)}Url.prototype.parse=function(e,t,a){if(!util$1.isString(e))throw new TypeError("Parameter 'url' must be a string, not "+typeof e);var r=e.indexOf("?"),n=-1!==r&&r127?b+="x":b+=P[x];if(!b.match(hostnamePartPattern)){var I=g.slice(0,f),O=g.slice(f+1),w=P.match(hostnamePartStart);w&&(I.push(w[1]),O.unshift(w[2])),O.length&&(s="/"+O.join(".")+s),this.hostname=I.join(".");break}}}this.hostname.length>hostnameMaxLen?this.hostname="":this.hostname=this.hostname.toLowerCase(),y||(this.hostname=punycode.toASCII(this.hostname));var V=this.port?":"+this.port:"",T=this.hostname||"";this.host=T+V,this.href+=this.host,y&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),"/"!==s[0]&&(s="/"+s))}if(!unsafeProtocol[u])for(f=0,N=autoEscape.length;f0)&&a.host.split("@"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift());return a.search=e.search,a.query=e.query,util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:"")+(a.search?a.search:"")),a.href=a.format(),a}if(!P.length)return a.pathname=null,a.search?a.path="/"+a.search:a.path=null,a.href=a.format(),a;for(var x=P.slice(-1)[0],v=(a.host||e.host||P.length>1)&&("."===x||".."===x)||""===x,I=0,O=P.length;O>=0;O--)"."===(x=P[O])?P.splice(O,1):".."===x?(P.splice(O,1),I++):I&&(P.splice(O,1),I--);if(!g&&!N)for(;I--;I)P.unshift("..");!g||""===P[0]||P[0]&&"/"===P[0].charAt(0)||P.unshift(""),v&&"/"!==P.join("/").substr(-1)&&P.push("");var w,V=""===P[0]||P[0]&&"/"===P[0].charAt(0);b&&(a.hostname=a.host=V?"":P.length?P.shift():"",(w=!!(a.host&&a.host.indexOf("@")>0)&&a.host.split("@"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift()));return(g=g||a.host&&P.length)&&!V&&P.unshift(""),P.length?a.pathname=P.join("/"):(a.pathname=null,a.path=null),util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:"")+(a.search?a.search:"")),a.auth=e.auth||a.auth,a.slashes=a.slashes||e.slashes,a.href=a.format(),a},Url.prototype.parseHost=function(){var e=this.host,t=portPattern.exec(e);t&&(":"!==(t=t[0])&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)};var aspromise=asPromise;function asPromise(e,t){for(var a=new Array(arguments.length-1),r=0,n=2,o=!0;n1&&"="===e.charAt(t);)++a;return Math.ceil(3*e.length)/4-a};for(var r=new Array(64),n=new Array(123),o=0;o<64;)n[r[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;a.encode=function(e,t,a){for(var n,o=null,s=[],i=0,p=0;t>2],n=(3&u)<<4,p=1;break;case 1:s[i++]=r[n|u>>4],n=(15&u)<<2,p=2;break;case 2:s[i++]=r[n|u>>6],s[i++]=r[63&u],p=0}i>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,s)),i=0)}return p&&(s[i++]=r[n],s[i++]=61,1===p&&(s[i++]=61)),o?(i&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))};a.decode=function(e,t,a){for(var r,o=a,s=0,i=0;i1)break;if(void 0===(p=n[p]))throw Error("invalid encoding");switch(s){case 0:r=p,s=1;break;case 1:t[a++]=r<<2|(48&p)>>4,r=p,s=2;break;case 2:t[a++]=(15&r)<<4|(60&p)>>2,r=p,s=3;break;case 3:t[a++]=(3&r)<<6|p,s=0}}if(1===s)throw Error("invalid encoding");return a-o},a.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}}),eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(e,t,a){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:a||this}),this},EventEmitter.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var a=this._listeners[e],r=0;r0?0:2147483648,a,r);else if(isNaN(t))e(2143289344,a,r);else if(t>3.4028234663852886e38)e((n<<31|2139095040)>>>0,a,r);else if(t<1.1754943508222875e-38)e((n<<31|Math.round(t/1.401298464324817e-45))>>>0,a,r);else{var o=Math.floor(Math.log(t)/Math.LN2);e((n<<31|o+127<<23|8388607&Math.round(t*Math.pow(2,-o)*8388608))>>>0,a,r)}}function a(e,t,a){var r=e(t,a),n=2*(r>>31)+1,o=r>>>23&255,s=8388607&r;return 255===o?s?NaN:n*(1/0):0===o?1.401298464324817e-45*n*s:n*Math.pow(2,o-150)*(s+8388608)}e.writeFloatLE=t.bind(null,writeUintLE),e.writeFloatBE=t.bind(null,writeUintBE),e.readFloatLE=a.bind(null,readUintLE),e.readFloatBE=a.bind(null,readUintBE)}(),"undefined"!=typeof Float64Array?function(){var t=new Float64Array([-0]),a=new Uint8Array(t.buffer),r=128===a[7];function n(e,r,n){t[0]=e,r[n]=a[0],r[n+1]=a[1],r[n+2]=a[2],r[n+3]=a[3],r[n+4]=a[4],r[n+5]=a[5],r[n+6]=a[6],r[n+7]=a[7]}function o(e,r,n){t[0]=e,r[n]=a[7],r[n+1]=a[6],r[n+2]=a[5],r[n+3]=a[4],r[n+4]=a[3],r[n+5]=a[2],r[n+6]=a[1],r[n+7]=a[0]}function s(e,r){return a[0]=e[r],a[1]=e[r+1],a[2]=e[r+2],a[3]=e[r+3],a[4]=e[r+4],a[5]=e[r+5],a[6]=e[r+6],a[7]=e[r+7],t[0]}function i(e,r){return a[7]=e[r],a[6]=e[r+1],a[5]=e[r+2],a[4]=e[r+3],a[3]=e[r+4],a[2]=e[r+5],a[1]=e[r+6],a[0]=e[r+7],t[0]}e.writeDoubleLE=r?n:o,e.writeDoubleBE=r?o:n,e.readDoubleLE=r?s:i,e.readDoubleBE=r?i:s}():function(){function t(e,t,a,r,n,o){var s=r<0?1:0;if(s&&(r=-r),0===r)e(0,n,o+t),e(1/r>0?0:2147483648,n,o+a);else if(isNaN(r))e(0,n,o+t),e(2146959360,n,o+a);else if(r>1.7976931348623157e308)e(0,n,o+t),e((s<<31|2146435072)>>>0,n,o+a);else{var i;if(r<2.2250738585072014e-308)e((i=r/5e-324)>>>0,n,o+t),e((s<<31|i/4294967296)>>>0,n,o+a);else{var p=Math.floor(Math.log(r)/Math.LN2);1024===p&&(p=1023),e(4503599627370496*(i=r*Math.pow(2,-p))>>>0,n,o+t),e((s<<31|p+1023<<20|1048576*i&1048575)>>>0,n,o+a)}}}function a(e,t,a,r,n){var o=e(r,n+t),s=e(r,n+a),i=2*(s>>31)+1,p=s>>>20&2047,u=4294967296*(1048575&s)+o;return 2047===p?u?NaN:i*(1/0):0===p?5e-324*i*u:i*Math.pow(2,p-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,writeUintLE,0,4),e.writeDoubleBE=t.bind(null,writeUintBE,4,0),e.readDoubleLE=a.bind(null,readUintLE,0,4),e.readDoubleBE=a.bind(null,readUintBE,4,0)}(),e}function writeUintLE(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}function writeUintBE(e,t,a){t[a]=e>>>24,t[a+1]=e>>>16&255,t[a+2]=e>>>8&255,t[a+3]=255&e}function readUintLE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function readUintBE(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod$$1=eval("quire".replace(/^/,"re"))(moduleName);if(mod$$1&&(mod$$1.length||Object.keys(mod$$1).length))return mod$$1}catch(e){}return null}var utf8_1=createCommonjsModule(function(e,t){var a=t;a.length=function(e){for(var t=0,a=0,r=0;r191&&r<224?o[s++]=(31&r)<<6|63&e[t++]:r>239&&r<365?(r=((7&r)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,o[s++]=55296+(r>>10),o[s++]=56320+(1023&r)):o[s++]=(15&r)<<12|(63&e[t++])<<6|63&e[t++],s>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,o)),s=0);return n?(s&&n.push(String.fromCharCode.apply(String,o.slice(0,s))),n.join("")):String.fromCharCode.apply(String,o.slice(0,s))},a.write=function(e,t,a){for(var r,n,o=a,s=0;s>6|192,t[a++]=63&r|128):55296==(64512&r)&&56320==(64512&(n=e.charCodeAt(s+1)))?(r=65536+((1023&r)<<10)+(1023&n),++s,t[a++]=r>>18|240,t[a++]=r>>12&63|128,t[a++]=r>>6&63|128,t[a++]=63&r|128):(t[a++]=r>>12|224,t[a++]=r>>6&63|128,t[a++]=63&r|128);return a-o}}),pool_1=pool;function pool(e,t,a){var r=a||8192,n=r>>>1,o=null,s=r;return function(a){if(a<1||a>n)return e(a);s+a>r&&(o=e(r),s=0);var i=t.call(o,s,s+=a);return 7&s&&(s=1+(7|s)),i}}var longbits=LongBits;function LongBits(e,t){this.lo=e>>>0,this.hi=t>>>0}var zero=LongBits.zero=new LongBits(0,0);zero.toNumber=function(){return 0},zero.zzEncode=zero.zzDecode=function(){return this},zero.length=function(){return 1};var zeroHash=LongBits.zeroHash="\0\0\0\0\0\0\0\0";LongBits.fromNumber=function(e){if(0===e)return zero;var t=e<0;t&&(e=-e);var a=e>>>0,r=(e-a)/4294967296>>>0;return t&&(r=~r>>>0,a=~a>>>0,++a>4294967295&&(a=0,++r>4294967295&&(r=0))),new LongBits(a,r)},LongBits.from=function(e){if("number"==typeof e)return LongBits.fromNumber(e);if(minimal.isString(e)){if(!minimal.Long)return LongBits.fromNumber(parseInt(e,10));e=minimal.Long.fromString(e)}return e.low||e.high?new LongBits(e.low>>>0,e.high>>>0):zero},LongBits.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,a=~this.hi>>>0;return t||(a=a+1>>>0),-(t+4294967296*a)}return this.lo+4294967296*this.hi},LongBits.prototype.toLong=function(e){return minimal.Long?new minimal.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var charCodeAt=String.prototype.charCodeAt;LongBits.fromHash=function(e){return e===zeroHash?zero:new LongBits((charCodeAt.call(e,0)|charCodeAt.call(e,1)<<8|charCodeAt.call(e,2)<<16|charCodeAt.call(e,3)<<24)>>>0,(charCodeAt.call(e,4)|charCodeAt.call(e,5)<<8|charCodeAt.call(e,6)<<16|charCodeAt.call(e,7)<<24)>>>0)},LongBits.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},LongBits.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},LongBits.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},LongBits.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,a=this.hi>>>24;return 0===a?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:a<128?9:10};var minimal=createCommonjsModule(function(e,t){var a=t;function r(e,t,a){for(var r=Object.keys(t),n=0;n0)},a.Buffer=function(){try{var e=a.inquire("buffer").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),a._Buffer_from=null,a._Buffer_allocUnsafe=null,a.newBuffer=function(e){return"number"==typeof e?a.Buffer?a._Buffer_allocUnsafe(e):new a.Array(e):a.Buffer?a._Buffer_from(e):"undefined"==typeof Uint8Array?e:new Uint8Array(e)},a.Array="undefined"!=typeof Uint8Array?Uint8Array:Array,a.Long=commonjsGlobal.dcodeIO&&commonjsGlobal.dcodeIO.Long||a.inquire("long"),a.key2Re=/^true|false|0|1$/,a.key32Re=/^-?(?:0|[1-9][0-9]*)$/,a.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,a.longToHash=function(e){return e?a.LongBits.from(e).toHash():a.LongBits.zeroHash},a.longFromHash=function(e,t){var r=a.LongBits.fromHash(e);return a.Long?a.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},a.merge=r,a.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},a.newError=n,a.ProtocolError=n("ProtocolError"),a.oneOfGetter=function(e){for(var t={},a=0;a-1;--a)if(1===t[e[a]]&&void 0!==this[e[a]]&&null!==this[e[a]])return e[a]}},a.oneOfSetter=function(e){return function(t){for(var a=0;a127;)t[a++]=127&e|128,e>>>=7;t[a]=e}function VarintOp(e,t){this.len=e,this.next=void 0,this.val=t}function writeVarint64(e,t,a){for(;e.hi;)t[a++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[a++]=127&e.lo|128,e.lo=e.lo>>>7;t[a++]=e.lo}function writeFixed32(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}Writer.create=minimal.Buffer?function(){return(Writer.create=function(){return new BufferWriter})()}:function(){return new Writer},Writer.alloc=function(e){return new minimal.Array(e)},minimal.Array!==Array&&(Writer.alloc=minimal.pool(Writer.alloc,minimal.Array.prototype.subarray)),Writer.prototype._push=function(e,t,a){return this.tail=this.tail.next=new Op(e,t,a),this.len+=t,this},VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new VarintOp((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},Writer.prototype.int32=function(e){return e<0?this._push(writeVarint64,10,LongBits$1.fromNumber(e)):this.uint32(e)},Writer.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},Writer.prototype.uint64=function(e){var t=LongBits$1.from(e);return this._push(writeVarint64,t.length(),t)},Writer.prototype.int64=Writer.prototype.uint64,Writer.prototype.sint64=function(e){var t=LongBits$1.from(e).zzEncode();return this._push(writeVarint64,t.length(),t)},Writer.prototype.bool=function(e){return this._push(writeByte,1,e?1:0)},Writer.prototype.fixed32=function(e){return this._push(writeFixed32,4,e>>>0)},Writer.prototype.sfixed32=Writer.prototype.fixed32,Writer.prototype.fixed64=function(e){var t=LongBits$1.from(e);return this._push(writeFixed32,4,t.lo)._push(writeFixed32,4,t.hi)},Writer.prototype.sfixed64=Writer.prototype.fixed64,Writer.prototype.float=function(e){return this._push(minimal.float.writeFloatLE,4,e)},Writer.prototype.double=function(e){return this._push(minimal.float.writeDoubleLE,8,e)};var writeBytes=minimal.Array.prototype.set?function(e,t,a){t.set(e,a)}:function(e,t,a){for(var r=0;r>>0;if(!t)return this._push(writeByte,1,0);if(minimal.isString(e)){var a=Writer.alloc(t=base64.length(e));base64.decode(e,a,0),e=a}return this.uint32(t)._push(writeBytes,t,e)},Writer.prototype.string=function(e){var t=utf8.length(e);return t?this.uint32(t)._push(utf8.write,t,e):this._push(writeByte,1,0)},Writer.prototype.fork=function(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer.prototype.ldelim=function(){var e=this.head,t=this.tail,a=this.len;return this.reset().uint32(a),a&&(this.tail.next=e.next,this.tail=t,this.len+=a),this},Writer.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),a=0;e;)e.fn(e.val,t,a),a+=e.len,e=e.next;return t},Writer._configure=function(e){BufferWriter=e};var writer_buffer=BufferWriter$1;(BufferWriter$1.prototype=Object.create(writer.prototype)).constructor=BufferWriter$1;var Buffer=minimal.Buffer;function BufferWriter$1(){writer.call(this)}BufferWriter$1.alloc=function(e){return(BufferWriter$1.alloc=minimal._Buffer_allocUnsafe)(e)};var writeBytesBuffer=Buffer&&Buffer.prototype instanceof Uint8Array&&"set"===Buffer.prototype.set.name?function(e,t,a){t.set(e,a)}:function(e,t,a){if(e.copy)e.copy(t,a,0,e.length);else for(var r=0;r>>0;return this.uint32(t),t&&this._push(writeBytesBuffer,t,e),this},BufferWriter$1.prototype.string=function(e){var t=Buffer.byteLength(e);return this.uint32(t),t&&this._push(writeStringBuffer,t,e),this};var reader=Reader,BufferReader,LongBits$2=minimal.LongBits,utf8$1=minimal.utf8;function indexOutOfRange(e,t){return RangeError("index out of range: "+e.pos+" + "+(t||1)+" > "+e.len)}function Reader(e){this.buf=e,this.pos=0,this.len=e.length}var create_array="undefined"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new Reader(e);throw Error("illegal buffer")}:function(e){if(Array.isArray(e))return new Reader(e);throw Error("illegal buffer")};function readLongVarint(){var e=new LongBits$2(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}function readFixed32_end(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits$2(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader.create=minimal.Buffer?function(e){return(Reader.create=function(e){return minimal.Buffer.isBuffer(e)?new BufferReader(e):create_array(e)})(e)}:create_array,Reader.prototype._slice=minimal.Array.prototype.subarray||minimal.Array.prototype.slice,Reader.prototype.uint32=function(){var e=4294967295;return function(){if(e=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return e;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return e}}(),Reader.prototype.int32=function(){return 0|this.uint32()},Reader.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},Reader.prototype.bool=function(){return 0!==this.uint32()},Reader.prototype.fixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.sfixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return 0|readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.float=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},Reader.prototype.double=function(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},Reader.prototype.bytes=function(){var e=this.uint32(),t=this.pos,a=this.pos+e;if(a>this.len)throw indexOutOfRange(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,a):t===a?new this.buf.constructor(0):this._slice.call(this.buf,t,a)},Reader.prototype.string=function(){var e=this.bytes();return utf8$1.read(e,0,e.length)},Reader.prototype.skip=function(e){if("number"==typeof e){if(this.pos+e>this.len)throw indexOutOfRange(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw indexOutOfRange(this)}while(128&this.buf[this.pos++]);return this},Reader.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;;){if(4==(e=7&this.uint32()))break;this.skipType(e)}break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+e+" at offset "+this.pos)}return this},Reader._configure=function(e){BufferReader=e;var t=minimal.Long?"toLong":"toNumber";minimal.merge(Reader.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader$1;function BufferReader$1(e){reader.call(this,e)}(BufferReader$1.prototype=Object.create(reader.prototype)).constructor=BufferReader$1,minimal.Buffer&&(BufferReader$1.prototype._slice=minimal.Buffer.prototype.slice),BufferReader$1.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len))};var service=Service;function Service(e,t,a){if("function"!=typeof e)throw TypeError("rpcImpl must be a function");minimal.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(a)}(Service.prototype=Object.create(minimal.EventEmitter.prototype)).constructor=Service,Service.prototype.rpcCall=function e(t,a,r,n,o){if(!n)throw TypeError("request must be specified");var s=this;if(!o)return minimal.asPromise(e,s,t,a,r,n);if(s.rpcImpl)try{return s.rpcImpl(t,a[s.requestDelimited?"encodeDelimited":"encode"](n).finish(),function(e,a){if(e)return s.emit("error",e,t),o(e);if(null!==a){if(!(a instanceof r))try{a=r[s.responseDelimited?"decodeDelimited":"decode"](a)}catch(e){return s.emit("error",e,t),o(e)}return s.emit("data",a,t),o(null,a)}s.end(!0)})}catch(e){return s.emit("error",e,t),void setTimeout(function(){o(e)},0)}else setTimeout(function(){o(Error("already ended"))},0)},Service.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this};var rpc_1=createCommonjsModule(function(e,t){t.Service=service}),roots={},indexMinimal=createCommonjsModule(function(e,t){var a=t;function r(){a.Reader._configure(a.BufferReader),a.util._configure()}a.build="minimal",a.Writer=writer,a.BufferWriter=writer_buffer,a.Reader=reader,a.BufferReader=reader_buffer,a.util=minimal,a.rpc=rpc_1,a.roots=roots,a.configure=r,a.Writer._configure(a.BufferWriter),r()}),minimal$1=indexMinimal,minimal_1=minimal$1.roots,minimal_2=minimal$1.Reader,minimal_3=minimal$1.util,$Reader=minimal$1.Reader,$util=minimal$1.util,$root=minimal$1.roots.default||(minimal$1.roots.default={});$root.tensorflow=function(){var e,t,a={};return a.Any=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.typeUrl=e.string();break;case 2:r.value=e.bytes();break;default:e.skipType(7&n)}}return r},e}(),a.DataType=(e={},(t=Object.create(e))[e[0]="DT_INVALID"]=0,t[e[1]="DT_FLOAT"]=1,t[e[2]="DT_DOUBLE"]=2,t[e[3]="DT_INT32"]=3,t[e[4]="DT_UINT8"]=4,t[e[5]="DT_INT16"]=5,t[e[6]="DT_INT8"]=6,t[e[7]="DT_STRING"]=7,t[e[8]="DT_COMPLEX64"]=8,t[e[9]="DT_INT64"]=9,t[e[10]="DT_BOOL"]=10,t[e[11]="DT_QINT8"]=11,t[e[12]="DT_QUINT8"]=12,t[e[13]="DT_QINT32"]=13,t[e[14]="DT_BFLOAT16"]=14,t[e[101]="DT_FLOAT_REF"]=101,t[e[102]="DT_DOUBLE_REF"]=102,t[e[103]="DT_INT32_REF"]=103,t[e[104]="DT_UINT8_REF"]=104,t[e[105]="DT_INT16_REF"]=105,t[e[106]="DT_INT8_REF"]=106,t[e[107]="DT_STRING_REF"]=107,t[e[108]="DT_COMPLEX64_REF"]=108,t[e[109]="DT_INT64_REF"]=109,t[e[110]="DT_BOOL_REF"]=110,t[e[111]="DT_QINT8_REF"]=111,t[e[112]="DT_QUINT8_REF"]=112,t[e[113]="DT_QINT32_REF"]=113,t[e[114]="DT_BFLOAT16_REF"]=114,t),a.TensorShape=function(){function e(e){if(this.dim=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.dim&&r.dim.length||(r.dim=[]),r.dim.push($root.tensorflow.TensorShape.Dim.decode(e,e.uint32()));break;case 3:r.unknownRank=e.bool();break;default:e.skipType(7&n)}}return r},e.Dim=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.size=e.int64();break;case 2:r.name=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.Tensor=function(){function e(e){if(this.floatVal=[],this.doubleVal=[],this.intVal=[],this.stringVal=[],this.scomplexVal=[],this.int64Val=[],this.boolVal=[],this.uint32Val=[],this.uint64Val=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.dtype=e.int32();break;case 2:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 3:r.versionNumber=e.int32();break;case 4:r.tensorContent=e.bytes();break;case 5:if(r.floatVal&&r.floatVal.length||(r.floatVal=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.list=$root.tensorflow.AttrValue.ListValue.decode(e,e.uint32());break;case 2:r.s=e.bytes();break;case 3:r.i=e.int64();break;case 4:r.f=e.float();break;case 5:r.b=e.bool();break;case 6:r.type=e.int32();break;case 7:r.shape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 8:r.tensor=$root.tensorflow.Tensor.decode(e,e.uint32());break;case 9:r.placeholder=e.string();break;case 10:r.func=$root.tensorflow.NameAttrList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.ListValue=function(){function e(e){if(this.s=[],this.i=[],this.f=[],this.b=[],this.type=[],this.shape=[],this.tensor=[],this.func=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.s&&r.s.length||(r.s=[]),r.s.push(e.bytes());break;case 3:if(r.i&&r.i.length||(r.i=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.name=e.string();break;case 2:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.NodeDef=function(){function e(e){if(this.input=[],this.attr={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.name=e.string();break;case 2:n.op=e.string();break;case 3:n.input&&n.input.length||(n.input=[]),n.input.push(e.string());break;case 4:n.device=e.string();break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.VersionDef=function(){function e(e){if(this.badConsumers=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.producer=e.int32();break;case 2:r.minConsumer=e.int32();break;case 3:if(r.badConsumers&&r.badConsumers.length||(r.badConsumers=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.node&&r.node.length||(r.node=[]),r.node.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:r.versions=$root.tensorflow.VersionDef.decode(e,e.uint32());break;case 2:r.library=$root.tensorflow.FunctionDefLibrary.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),a.CollectionDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.nodeList=$root.tensorflow.CollectionDef.NodeList.decode(e,e.uint32());break;case 2:r.bytesList=$root.tensorflow.CollectionDef.BytesList.decode(e,e.uint32());break;case 3:r.int64List=$root.tensorflow.CollectionDef.Int64List.decode(e,e.uint32());break;case 4:r.floatList=$root.tensorflow.CollectionDef.FloatList.decode(e,e.uint32());break;case 5:r.anyList=$root.tensorflow.CollectionDef.AnyList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.NodeList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.string());break;default:e.skipType(7&n)}}return r},e}(),e.BytesList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.bytes());break;default:e.skipType(7&n)}}return r},e}(),e.Int64List=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push($root.tensorflow.Any.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SaverDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.filenameTensorName=e.string();break;case 2:r.saveTensorName=e.string();break;case 3:r.restoreOpName=e.string();break;case 4:r.maxToKeep=e.int32();break;case 5:r.sharded=e.bool();break;case 6:r.keepCheckpointEveryNHours=e.float();break;case 7:r.version=e.int32();break;default:e.skipType(7&n)}}return r},e.CheckpointFormatVersion=(t={},(a=Object.create(t))[t[0]="LEGACY"]=0,a[t[1]="V1"]=1,a[t[2]="V2"]=2,a),e}(),a.TensorInfo=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 4:r.cooSparse=$root.tensorflow.TensorInfo.CooSparse.decode(e,e.uint32());break;case 2:r.dtype=e.int32();break;case 3:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.CooSparse=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.valuesTensorName=e.string();break;case 2:r.indicesTensorName=e.string();break;case 3:r.denseShapeTensorName=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SignatureDef=function(){function e(e){if(this.inputs={},this.outputs={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:e.skip().pos++,n.inputs===$util.emptyObject&&(n.inputs={}),a=e.string(),e.pos++,n.inputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:e.skip().pos++,n.outputs===$util.emptyObject&&(n.outputs={}),a=e.string(),e.pos++,n.outputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 3:n.methodName=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.AssetFileDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.tensorInfo=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:r.filename=e.string();break;default:e.skipType(7&n)}}return r},e}(),a.OpDef=function(){function e(e){if(this.inputArg=[],this.outputArg=[],this.attr=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.inputArg&&r.inputArg.length||(r.inputArg=[]),r.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 3:r.outputArg&&r.outputArg.length||(r.outputArg=[]),r.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 4:r.attr&&r.attr.length||(r.attr=[]),r.attr.push($root.tensorflow.OpDef.AttrDef.decode(e,e.uint32()));break;case 8:r.deprecation=$root.tensorflow.OpDef.OpDeprecation.decode(e,e.uint32());break;case 5:r.summary=e.string();break;case 6:r.description=e.string();break;case 18:r.isCommutative=e.bool();break;case 16:r.isAggregate=e.bool();break;case 17:r.isStateful=e.bool();break;case 19:r.allowsUninitializedInput=e.bool();break;default:e.skipType(7&n)}}return r},e.ArgDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.description=e.string();break;case 3:r.type=e.int32();break;case 4:r.typeAttr=e.string();break;case 5:r.numberAttr=e.string();break;case 6:r.typeListAttr=e.string();break;case 16:r.isRef=e.bool();break;default:e.skipType(7&n)}}return r},e}(),e.AttrDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.type=e.string();break;case 3:r.defaultValue=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 4:r.description=e.string();break;case 5:r.hasMinimum=e.bool();break;case 6:r.minimum=e.int64();break;case 7:r.allowedValues=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),e.OpDeprecation=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.version=e.int32();break;case 2:r.explanation=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.OpList=function(){function e(e){if(this.op=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.op&&r.op.length||(r.op=[]),r.op.push($root.tensorflow.OpDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.MetaGraphDef=function(){function e(e){if(this.collectionDef={},this.signatureDef={},this.assetFileDef=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.metaInfoDef=$root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e,e.uint32());break;case 2:n.graphDef=$root.tensorflow.GraphDef.decode(e,e.uint32());break;case 3:n.saverDef=$root.tensorflow.SaverDef.decode(e,e.uint32());break;case 4:e.skip().pos++,n.collectionDef===$util.emptyObject&&(n.collectionDef={}),a=e.string(),e.pos++,n.collectionDef[a]=$root.tensorflow.CollectionDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.signatureDef===$util.emptyObject&&(n.signatureDef={}),a=e.string(),e.pos++,n.signatureDef[a]=$root.tensorflow.SignatureDef.decode(e,e.uint32());break;case 6:n.assetFileDef&&n.assetFileDef.length||(n.assetFileDef=[]),n.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return n},e.MetaInfoDef=function(){function e(e){if(this.tags=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.metaGraphVersion=e.string();break;case 2:r.strippedOpList=$root.tensorflow.OpList.decode(e,e.uint32());break;case 3:r.anyInfo=$root.tensorflow.Any.decode(e,e.uint32());break;case 4:r.tags&&r.tags.length||(r.tags=[]),r.tags.push(e.string());break;case 5:r.tensorflowVersion=e.string();break;case 6:r.tensorflowGitVersion=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SavedModel=function(){function e(e){if(this.metaGraphs=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.savedModelSchemaVersion=e.int64();break;case 2:r.metaGraphs&&r.metaGraphs.length||(r.metaGraphs=[]),r.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDefLibrary=function(){function e(e){if(this.function=[],this.gradient=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.function&&r.function.length||(r.function=[]),r.function.push($root.tensorflow.FunctionDef.decode(e,e.uint32()));break;case 2:r.gradient&&r.gradient.length||(r.gradient=[]),r.gradient.push($root.tensorflow.GradientDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDef=function(){function e(e){if(this.attr={},this.nodeDef=[],this.ret={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.signature=$root.tensorflow.OpDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 3:n.nodeDef&&n.nodeDef.length||(n.nodeDef=[]),n.nodeDef.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:e.skip().pos++,n.ret===$util.emptyObject&&(n.ret={}),a=e.string(),e.pos++,n.ret[a]=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.GradientDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.functionName=e.string();break;case 2:r.gradientFunc=e.string();break;default:e.skipType(7&n)}}return r},e}(),a}();var compiled_api=$root,compiled_api_1=compiled_api.tensorflow;function getParamValue(e,t,a,r){var n=t.params[e];if(n&&void 0!==n.inputIndex){if("tensor"===n.type)return getTensor(t.inputNames[n.inputIndex],a,r);if("tensors"===n.type)return(0===n.inputIndex?0===n.inputParamLength?t.inputNames:t.inputNames.slice(n.inputIndex,-n.inputParamLength):t.inputNames.splice(n.inputIndex)).map(function(e){return getTensor(e,a,r)});var o=Array.prototype.slice.call(getTensor(t.inputNames.slice(n.inputIndex)[0],a,r).dataSync());return"number"===n.type?o[0]:o}return n&&n.value}function getTensor(e,t,a){var r=parseNodeName(e),n=r[0],o=r[1],s=a.currentContextIds.find(function(e){return!!t[getNodeNameWithContextId(n,e)]});return void 0!==s?t[getNodeNameWithContextId(n,s)][o]:void 0}function getNodeNameAndIndex(e,t){var a=parseNodeName(e),r=a[0],n=a[1];return[getNodeNameWithContextId(r,t&&t.currentContextId),n]}function getNodeNameWithContextId(e,t){return t?e+"-"+t:e}function parseNodeName(e){var t=e.lastIndexOf(":");return-1===t?[e,0]:[e.substring(0,t),Number(e.substring(t+1))]}function split$1(e,t){for(var a=[],r=0;r=this.tensors.length)throw new Error("Tried to read from index "+e+", but array size is: "+this.tensors.length);var t=this.tensors[e];if(t.cleared)throw new Error("TensorArray "+this.name+": Could not read index "+e+" twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).");return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor},e.prototype.readMany=function(e){var t=this;return e.map(function(e){return t.read(e)})},e.prototype.write=function(e,t){if(this.closed_)throw new Error("TensorArray "+this.name+" has already been closed.");if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error("Tried to write to index "+e+", but array is not resizeable and size is: "+this.maxSize);var a=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+",\n because the value dtype is "+t.dtype+", but TensorArray dtype is "+this.dtype+".");if(0===this.size()&&0===this.elementShape.length&&(this.elementShape=t.shape),util.assertShapesMatch(this.elementShape,t.shape,"TensorArray "+this.name+": Could not write to TensorArray index "+e+"."),a&&a.read)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been read.");if(a&&a.written)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been written.");a.tensor=t,a.written=!0,this.tensors[e]=a},e.prototype.writeMany=function(e,t){var a=this;if(e.length!==t.length)throw new Error("TensorArray "+this.name+": could not write multiple tensors,because the index size: "+e.length+" is not the same as tensors size: "+t.length+".");e.map(function(e,r){return a.write(e,t[r])})},e.prototype.gather=function(e,t){if(t&&t!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but gather requested dtype "+t);if(!e){e=[];for(var a=0;a=this.maxSize)throw new Error("Max index must be < array size ("+a+" vs. "+this.maxSize+")");this.writeMany(e,unstack(t,0))},e.prototype.split=function(e,t){var a=this;if(t.dtype!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but tensor has dtype "+t.dtype);var r=0,n=e.map(function(e){return r+=e});if(r!==t.shape[0])throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n "+r+", and tensor's shape is: "+t.shape);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error("TensorArray's size is not equal to the size of lengths ("+this.maxSize+" vs. "+e.length+"), and the TensorArray is not marked as dynamically resizeable");var o=0===r?0:t.size/r,s=[];tidy(function(){t=t.reshape([1,r,o]);for(var i=0;i1)for(var f=1;f1))throw new Error("Cannot exit frame, the context is empty");this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift()},e.prototype.nextIteration=function(){if(!(this.contexts&&this.contexts.length>0))throw new Error("Cannot increase frame iteration, the context is empty");this.contexts=this.contexts.slice(),this.lastId++;var e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))},e.prototype.getWeight=function(e){return this.weightMap[e]},e.prototype.addTensorArray=function(e){this.tensorArrayMap[e.id]=e},e.prototype.getTensorArray=function(e){return this.tensorArrayMap[e]},e}(),GraphExecutor=function(){function e(e){this.graph=e,this.compiledOrder=[],this._weightMap={},this.placeholders=e.placeholders,this._outputs=e.outputs,this.compile()}return Object.defineProperty(e.prototype,"weightMap",{get:function(){return this._weightMap},set:function(e){var t=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})});this.weightIds=[].concat.apply([],t),this._weightMap=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.placeholders.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this._outputs.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.placeholders.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.outputs.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isControlFlowModel",{get:function(){return this.graph.withControlFlow},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isDynamicShapeModel",{get:function(){return this.graph.withDynamicShape},enumerable:!0,configurable:!0}),e.prototype.compile=function(){if(!this.graph.withControlFlow&&!this.graph.withDynamicShape)for(var e=this.graph.inputs.slice(),t={};e.length>0;){var a=e.pop();t[a.name]=!0,this.compiledOrder.push(a),a.children.forEach(function(a){!t[a.name]&&a.inputNames.every(function(e){var a=getNodeNameAndIndex(e)[0];return t[a]})&&e.push(a)})}},e.prototype.execute=function(e,t){var a=this;this.checkInput(e),this.checkInputShapeAndType(e);var r={};return tidy(function(){var n=new ExecutionContext(a._weightMap,r),o=a.compiledOrder.reduce(function(e,t){return e[t.name]=executeOp$15(t,e,n),e},__assign({},a.weightMap,e));return a.findOutputs(o,n,t)})},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u=this;return __generator(this,function(m){switch(m.label){case 0:return this.checkInput(e),this.checkInputShapeAndType(e),a={},r=new ExecutionContext(this._weightMap,a),[4,this.executeWithControlFlow(e,r)];case 1:return n=m.sent(),o=this.findOutputs(n,r,t),s=Object.keys(o).map(function(e){return o[e].id}),i=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})}),p=[].concat.apply([],i),Object.keys(n).forEach(function(e){n[e].forEach(function(e){e&&-1===s.indexOf(e.id)&&-1===p.indexOf(e.id)&&-1===u.weightIds.indexOf(e.id)&&e.dispose()})}),[2,o]}})})},e.prototype.executeWithControlFlow=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u;return __generator(this,function(m){switch(m.label){case 0:a=this.graph.inputs.map(function(e){return{node:e,contexts:t.currentContext}}),r=__assign({},this.weightMap,e),n={},m.label=1;case 1:return a.length>0?(o=a.pop(),t.currentContext=o.contexts,s="","enter"===o.node.op&&getParamValue("isConstant",o.node,r,t)&&(s=getNodeNameAndIndex(o.node.name,t)[0]),i=executeOp$15(o.node,r,t),s||(s=getNodeNameAndIndex(o.node.name,t)[0]),p=r,u=s,[4,i]):[3,3];case 2:return p[u]=m.sent(),o.node.children.forEach(function(e){var o=getNodeNameAndIndex(e.name,t)[0];n[o]||("merge"===e.op?e.inputNames.some(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})):e.inputNames.every(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})))}),[3,1];case 3:return[2,r]}})})},e.prototype.findOutputs=function(e,t,a){return!a||a instanceof Array||(a=[a]),(a||this.graph.outputs.map(function(e){return e.name})).reduce(function(a,r){return a[r]=getTensor(r,e,t),a},{})},e.prototype.dispose=function(){var e=this;Object.keys(this.weightMap).forEach(function(t){return e.weightMap[t].forEach(function(e){return e.dispose()})})},e.prototype.checkInputShapeAndType=function(e){this.placeholders.forEach(function(t){var a=e[t.name][0];if(t.params.shape&&t.params.shape.value){var r=t.params.shape.value,n=r.length===a.shape.length&&a.shape.every(function(e,t){return-1===r[t]||r[t]===e});util.assert(n,"The shape of dict['"+t.name+"'] provided in model.execute(dict) must be ["+r+"], but was ["+a.shape+"]")}t.params.dtype&&t.params.dtype.value&&util.assert(a.dtype===t.params.dtype.value,"The dtype of dict['"+t.name+"'] provided in model.execute(dict) must be "+t.params.dtype.value+", but was "+a.dtype)})},e.prototype.checkInput=function(e){var t=this,a=Object.keys(e),r=[],n=[];if(this.inputNodes.forEach(function(e){-1===a.indexOf(e)&&r.push(e)}),a.forEach(function(e){-1===t.inputNodes.indexOf(e)&&n.push(e)}),r.length>0)throw new Error("The dict provided in model.execute(dict) has the keys ["+a+"], but is missing the required keys: ["+r+"].");if(n.length>0)throw new Error("The dict provided in model.execute(dict) has unused keys: ["+n+"]. Please provide only the following keys: ["+this.inputNodes+"].")},e}(),FrozenModel=function(){function e(e,t,a){this.modelUrl=e,this.weightManifestUrl=t,this.requestOption=a,this.version="n/a",this.pathPrefix=this.getPathPrefix()}return Object.defineProperty(e.prototype,"modelVersion",{get:function(){return this.version},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.executor.inputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.executor.outputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.executor.inputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this.executor.outputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"weights",{get:function(){return this.executor.weightMap},enumerable:!0,configurable:!0}),e.prototype.getPathPrefix=function(){var e=parse(this.weightManifestUrl),t=e.pathname.split("/");return t.splice(-1),e.pathname=t.join("/"),format(e)+"/"},e.prototype.loadRemoteProtoFile=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r,n;return __generator(this,function(o){switch(o.label){case 0:return o.trys.push([0,3,,4]),[4,fetch(this.modelUrl,this.requestOption)];case 1:return e=o.sent(),a=(t=compiled_api_1.GraphDef).decode,r=Uint8Array.bind,[4,e.arrayBuffer()];case 2:return[2,a.apply(t,[new(r.apply(Uint8Array,[void 0,o.sent()]))])];case 3:throw n=o.sent(),new Error(this.modelUrl+" not found. "+n);case 4:return[2]}})})},e.prototype.loadWeightManifest=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a;return __generator(this,function(r){switch(r.label){case 0:return r.trys.push([0,3,,4]),[4,fetch(this.weightManifestUrl,this.requestOption)];case 1:return e=r.sent(),t=this,[4,e.clone().json()];case 2:return t.weightManifest=r.sent(),[3,4];case 3:throw a=r.sent(),new Error(this.weightManifestUrl+" not found. "+a);case 4:return[2]}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r;return __generator(this,function(n){switch(n.label){case 0:return e=this.loadRemoteProtoFile(),t=this.loadWeightManifest(),[4,Promise.all([e,t])];case 1:return a=n.sent()[0],this.version=a.versions.producer+"."+a.versions.minConsumer,[4,io.loadWeights(this.weightManifest,this.pathPrefix,void 0,this.requestOption)];case 2:return r=n.sent(),this.executor=new GraphExecutor(OperationMapper.Instance.transformGraph(a)),this.executor.weightMap=this.convertTensorMapToTensorsMap(r),[2,!0]}})})},e.prototype.predict=function(e,t){return this.execute(e,this.outputNodes)},e.prototype.constructTensorMap=function(e){var t=e instanceof Tensor?[e]:e;if(t.length!==this.inputNodes.length)throw new Error("Input tensor count mismatch,the frozen model has "+this.inputNodes.length+" placeholders, while there are "+t.length+" input tensors.");return this.inputNodes.reduce(function(e,a,r){return e[a]=t[r],e},{})},e.prototype.execute=function(e,t){if(t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),this.executor.isControlFlowModel||this.executor.isDynamicShapeModel)throw new Error("The model contains control flow or dynamic shape ops, please use executeAsync method");var a=this.executor.execute(this.convertTensorMapToTensorsMap(e),t),r=Object.keys(a);return Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r;return __generator(this,function(n){switch(n.label){case 0:if(!this.executor.isControlFlowModel||!this.executor.isDynamicShapeModel)throw new Error("The model does not contain control flow or dynamic shape ops, please use execute method for better performance.");return t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),[4,this.executor.executeAsync(this.convertTensorMapToTensorsMap(e),t)];case 1:return a=n.sent(),r=Object.keys(a),[2,Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]]}})})},e.prototype.convertTensorMapToTensorsMap=function(e){return Object.keys(e).reduce(function(t,a){return t[a]=[e[a]],t},{})},e.prototype.dispose=function(){this.executor.dispose()},e}();function loadFrozenModel(e,t,a){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(n){switch(n.label){case 0:return[4,(r=new FrozenModel(e,t,a)).load()];case 1:return n.sent(),[2,r]}})})}var version="0.5.5";export{FrozenModel,loadFrozenModel,version as version_converter}; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.js b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.js new file mode 100644 index 0000000..b68c9b7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.js @@ -0,0 +1,10787 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@tensorflow/tfjs-core')) : + typeof define === 'function' && define.amd ? define(['exports', '@tensorflow/tfjs-core'], factory) : + (factory((global.tf = global.tf || {}),global.tf)); +}(this, (function (exports,tfc) { 'use strict'; + + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. 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 + + THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED + WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, + MERCHANTABLITY OR NON-INFRINGEMENT. + + See the Apache Version 2.0 License for specific language governing permissions + and limitations under the License. + ***************************************************************************** */ + + var __assign = Object.assign || function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; + + function __awaiter(thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + } + + function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + } + + var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var punycode = createCommonjsModule(function (module, exports) { + (function(root) { + + /** Detect free variables */ + var freeExports = exports && + !exports.nodeType && exports; + var freeModule = module && + !module.nodeType && module; + var freeGlobal = typeof commonjsGlobal == 'object' && commonjsGlobal; + if ( + freeGlobal.global === freeGlobal || + freeGlobal.window === freeGlobal || + freeGlobal.self === freeGlobal + ) { + root = freeGlobal; + } + + /** + * The `punycode` object. + * @name punycode + * @type Object + */ + var punycode, + + /** Highest positive signed 32-bit float value */ + maxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1 + + /** Bootstring parameters */ + base = 36, + tMin = 1, + tMax = 26, + skew = 38, + damp = 700, + initialBias = 72, + initialN = 128, // 0x80 + delimiter = '-', // '\x2D' + + /** Regular expressions */ + regexPunycode = /^xn--/, + regexNonASCII = /[^\x20-\x7E]/, // unprintable ASCII chars + non-ASCII chars + regexSeparators = /[\x2E\u3002\uFF0E\uFF61]/g, // RFC 3490 separators + + /** Error messages */ + errors = { + 'overflow': 'Overflow: input needs wider integers to process', + 'not-basic': 'Illegal input >= 0x80 (not a basic code point)', + 'invalid-input': 'Invalid input' + }, + + /** Convenience shortcuts */ + baseMinusTMin = base - tMin, + floor = Math.floor, + stringFromCharCode = String.fromCharCode, + + /** Temporary variable */ + key; + + /*--------------------------------------------------------------------------*/ + + /** + * A generic error utility function. + * @private + * @param {String} type The error type. + * @returns {Error} Throws a `RangeError` with the applicable error message. + */ + function error(type) { + throw RangeError(errors[type]); + } + + /** + * A generic `Array#map` utility function. + * @private + * @param {Array} array The array to iterate over. + * @param {Function} callback The function that gets called for every array + * item. + * @returns {Array} A new array of values returned by the callback function. + */ + function map(array, fn) { + var length = array.length; + var result = []; + while (length--) { + result[length] = fn(array[length]); + } + return result; + } + + /** + * A simple `Array#map`-like wrapper to work with domain name strings or email + * addresses. + * @private + * @param {String} domain The domain name or email address. + * @param {Function} callback The function that gets called for every + * character. + * @returns {Array} A new string of characters returned by the callback + * function. + */ + function mapDomain(string, fn) { + var parts = string.split('@'); + var result = ''; + if (parts.length > 1) { + // In email addresses, only the domain name should be punycoded. Leave + // the local part (i.e. everything up to `@`) intact. + result = parts[0] + '@'; + string = parts[1]; + } + // Avoid `split(regex)` for IE8 compatibility. See #17. + string = string.replace(regexSeparators, '\x2E'); + var labels = string.split('.'); + var encoded = map(labels, fn).join('.'); + return result + encoded; + } + + /** + * Creates an array containing the numeric code points of each Unicode + * character in the string. While JavaScript uses UCS-2 internally, + * this function will convert a pair of surrogate halves (each of which + * UCS-2 exposes as separate characters) into a single code point, + * matching UTF-16. + * @see `punycode.ucs2.encode` + * @see + * @memberOf punycode.ucs2 + * @name decode + * @param {String} string The Unicode input string (UCS-2). + * @returns {Array} The new array of code points. + */ + function ucs2decode(string) { + var output = [], + counter = 0, + length = string.length, + value, + extra; + while (counter < length) { + value = string.charCodeAt(counter++); + if (value >= 0xD800 && value <= 0xDBFF && counter < length) { + // high surrogate, and there is a next character + extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { // low surrogate + output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); + } else { + // unmatched surrogate; only append this code unit, in case the next + // code unit is the high surrogate of a surrogate pair + output.push(value); + counter--; + } + } else { + output.push(value); + } + } + return output; + } + + /** + * Creates a string based on an array of numeric code points. + * @see `punycode.ucs2.decode` + * @memberOf punycode.ucs2 + * @name encode + * @param {Array} codePoints The array of numeric code points. + * @returns {String} The new Unicode string (UCS-2). + */ + function ucs2encode(array) { + return map(array, function(value) { + var output = ''; + if (value > 0xFFFF) { + value -= 0x10000; + output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800); + value = 0xDC00 | value & 0x3FF; + } + output += stringFromCharCode(value); + return output; + }).join(''); + } + + /** + * Converts a basic code point into a digit/integer. + * @see `digitToBasic()` + * @private + * @param {Number} codePoint The basic numeric code point value. + * @returns {Number} The numeric value of a basic code point (for use in + * representing integers) in the range `0` to `base - 1`, or `base` if + * the code point does not represent a value. + */ + function basicToDigit(codePoint) { + if (codePoint - 48 < 10) { + return codePoint - 22; + } + if (codePoint - 65 < 26) { + return codePoint - 65; + } + if (codePoint - 97 < 26) { + return codePoint - 97; + } + return base; + } + + /** + * Converts a digit/integer into a basic code point. + * @see `basicToDigit()` + * @private + * @param {Number} digit The numeric value of a basic code point. + * @returns {Number} The basic code point whose value (when used for + * representing integers) is `digit`, which needs to be in the range + * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is + * used; else, the lowercase form is used. The behavior is undefined + * if `flag` is non-zero and `digit` has no uppercase form. + */ + function digitToBasic(digit, flag) { + // 0..25 map to ASCII a..z or A..Z + // 26..35 map to ASCII 0..9 + return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5); + } + + /** + * Bias adaptation function as per section 3.4 of RFC 3492. + * http://tools.ietf.org/html/rfc3492#section-3.4 + * @private + */ + function adapt(delta, numPoints, firstTime) { + var k = 0; + delta = firstTime ? floor(delta / damp) : delta >> 1; + delta += floor(delta / numPoints); + for (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) { + delta = floor(delta / baseMinusTMin); + } + return floor(k + (baseMinusTMin + 1) * delta / (delta + skew)); + } + + /** + * Converts a Punycode string of ASCII-only symbols to a string of Unicode + * symbols. + * @memberOf punycode + * @param {String} input The Punycode string of ASCII-only symbols. + * @returns {String} The resulting string of Unicode symbols. + */ + function decode(input) { + // Don't use UCS-2 + var output = [], + inputLength = input.length, + out, + i = 0, + n = initialN, + bias = initialBias, + basic, + j, + index, + oldi, + w, + k, + digit, + t, + /** Cached calculation results */ + baseMinusT; + + // Handle the basic code points: let `basic` be the number of input code + // points before the last delimiter, or `0` if there is none, then copy + // the first basic code points to the output. + + basic = input.lastIndexOf(delimiter); + if (basic < 0) { + basic = 0; + } + + for (j = 0; j < basic; ++j) { + // if it's not a basic code point + if (input.charCodeAt(j) >= 0x80) { + error('not-basic'); + } + output.push(input.charCodeAt(j)); + } + + // Main decoding loop: start just after the last delimiter if any basic code + // points were copied; start at the beginning otherwise. + + for (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) { + + // `index` is the index of the next character to be consumed. + // Decode a generalized variable-length integer into `delta`, + // which gets added to `i`. The overflow checking is easier + // if we increase `i` as we go, then subtract off its starting + // value at the end to obtain `delta`. + for (oldi = i, w = 1, k = base; /* no condition */; k += base) { + + if (index >= inputLength) { + error('invalid-input'); + } + + digit = basicToDigit(input.charCodeAt(index++)); + + if (digit >= base || digit > floor((maxInt - i) / w)) { + error('overflow'); + } + + i += digit * w; + t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); + + if (digit < t) { + break; + } + + baseMinusT = base - t; + if (w > floor(maxInt / baseMinusT)) { + error('overflow'); + } + + w *= baseMinusT; + + } + + out = output.length + 1; + bias = adapt(i - oldi, out, oldi == 0); + + // `i` was supposed to wrap around from `out` to `0`, + // incrementing `n` each time, so we'll fix that now: + if (floor(i / out) > maxInt - n) { + error('overflow'); + } + + n += floor(i / out); + i %= out; + + // Insert `n` at position `i` of the output + output.splice(i++, 0, n); + + } + + return ucs2encode(output); + } + + /** + * Converts a string of Unicode symbols (e.g. a domain name label) to a + * Punycode string of ASCII-only symbols. + * @memberOf punycode + * @param {String} input The string of Unicode symbols. + * @returns {String} The resulting Punycode string of ASCII-only symbols. + */ + function encode(input) { + var n, + delta, + handledCPCount, + basicLength, + bias, + j, + m, + q, + k, + t, + currentValue, + output = [], + /** `inputLength` will hold the number of code points in `input`. */ + inputLength, + /** Cached calculation results */ + handledCPCountPlusOne, + baseMinusT, + qMinusT; + + // Convert the input in UCS-2 to Unicode + input = ucs2decode(input); + + // Cache the length + inputLength = input.length; + + // Initialize the state + n = initialN; + delta = 0; + bias = initialBias; + + // Handle the basic code points + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue < 0x80) { + output.push(stringFromCharCode(currentValue)); + } + } + + handledCPCount = basicLength = output.length; + + // `handledCPCount` is the number of code points that have been handled; + // `basicLength` is the number of basic code points. + + // Finish the basic string - if it is not empty - with a delimiter + if (basicLength) { + output.push(delimiter); + } + + // Main encoding loop: + while (handledCPCount < inputLength) { + + // All non-basic code points < n have been handled already. Find the next + // larger one: + for (m = maxInt, j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue >= n && currentValue < m) { + m = currentValue; + } + } + + // Increase `delta` enough to advance the decoder's state to , + // but guard against overflow + handledCPCountPlusOne = handledCPCount + 1; + if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) { + error('overflow'); + } + + delta += (m - n) * handledCPCountPlusOne; + n = m; + + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + + if (currentValue < n && ++delta > maxInt) { + error('overflow'); + } + + if (currentValue == n) { + // Represent delta as a generalized variable-length integer + for (q = delta, k = base; /* no condition */; k += base) { + t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); + if (q < t) { + break; + } + qMinusT = q - t; + baseMinusT = base - t; + output.push( + stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)) + ); + q = floor(qMinusT / baseMinusT); + } + + output.push(stringFromCharCode(digitToBasic(q, 0))); + bias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength); + delta = 0; + ++handledCPCount; + } + } + + ++delta; + ++n; + + } + return output.join(''); + } + + /** + * Converts a Punycode string representing a domain name or an email address + * to Unicode. Only the Punycoded parts of the input will be converted, i.e. + * it doesn't matter if you call it on a string that has already been + * converted to Unicode. + * @memberOf punycode + * @param {String} input The Punycoded domain name or email address to + * convert to Unicode. + * @returns {String} The Unicode representation of the given Punycode + * string. + */ + function toUnicode(input) { + return mapDomain(input, function(string) { + return regexPunycode.test(string) + ? decode(string.slice(4).toLowerCase()) + : string; + }); + } + + /** + * Converts a Unicode string representing a domain name or an email address to + * Punycode. Only the non-ASCII parts of the domain name will be converted, + * i.e. it doesn't matter if you call it with a domain that's already in + * ASCII. + * @memberOf punycode + * @param {String} input The domain name or email address to convert, as a + * Unicode string. + * @returns {String} The Punycode representation of the given domain name or + * email address. + */ + function toASCII(input) { + return mapDomain(input, function(string) { + return regexNonASCII.test(string) + ? 'xn--' + encode(string) + : string; + }); + } + + /*--------------------------------------------------------------------------*/ + + /** Define the public API */ + punycode = { + /** + * A string representing the current Punycode.js version number. + * @memberOf punycode + * @type String + */ + 'version': '1.3.2', + /** + * An object of methods to convert from JavaScript's internal character + * representation (UCS-2) to Unicode code points, and back. + * @see + * @memberOf punycode + * @type Object + */ + 'ucs2': { + 'decode': ucs2decode, + 'encode': ucs2encode + }, + 'decode': decode, + 'encode': encode, + 'toASCII': toASCII, + 'toUnicode': toUnicode + }; + + /** Expose `punycode` */ + // Some AMD build optimizers, like r.js, check for specific condition patterns + // like the following: + if ( + typeof undefined == 'function' && + typeof undefined.amd == 'object' && + undefined.amd + ) { + undefined('punycode', function() { + return punycode; + }); + } else if (freeExports && freeModule) { + if (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+ + freeModule.exports = punycode; + } else { // in Narwhal or RingoJS v0.7.0- + for (key in punycode) { + punycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]); + } + } + } else { // in Rhino or a web browser + root.punycode = punycode; + } + + }(commonjsGlobal)); + }); + + var util = { + isString: function(arg) { + return typeof(arg) === 'string'; + }, + isObject: function(arg) { + return typeof(arg) === 'object' && arg !== null; + }, + isNull: function(arg) { + return arg === null; + }, + isNullOrUndefined: function(arg) { + return arg == null; + } + }; + + // Copyright Joyent, Inc. and other Node contributors. + + // If obj.hasOwnProperty has been overridden, then calling + // obj.hasOwnProperty(prop) will break. + // See: https://github.com/joyent/node/issues/1707 + function hasOwnProperty(obj, prop) { + return Object.prototype.hasOwnProperty.call(obj, prop); + } + + var decode = function(qs, sep, eq, options) { + sep = sep || '&'; + eq = eq || '='; + var obj = {}; + + if (typeof qs !== 'string' || qs.length === 0) { + return obj; + } + + var regexp = /\+/g; + qs = qs.split(sep); + + var maxKeys = 1000; + if (options && typeof options.maxKeys === 'number') { + maxKeys = options.maxKeys; + } + + var len = qs.length; + // maxKeys <= 0 means that we should not limit keys count + if (maxKeys > 0 && len > maxKeys) { + len = maxKeys; + } + + for (var i = 0; i < len; ++i) { + var x = qs[i].replace(regexp, '%20'), + idx = x.indexOf(eq), + kstr, vstr, k, v; + + if (idx >= 0) { + kstr = x.substr(0, idx); + vstr = x.substr(idx + 1); + } else { + kstr = x; + vstr = ''; + } + + k = decodeURIComponent(kstr); + v = decodeURIComponent(vstr); + + if (!hasOwnProperty(obj, k)) { + obj[k] = v; + } else if (Array.isArray(obj[k])) { + obj[k].push(v); + } else { + obj[k] = [obj[k], v]; + } + } + + return obj; + }; + + // Copyright Joyent, Inc. and other Node contributors. + + var stringifyPrimitive = function(v) { + switch (typeof v) { + case 'string': + return v; + + case 'boolean': + return v ? 'true' : 'false'; + + case 'number': + return isFinite(v) ? v : ''; + + default: + return ''; + } + }; + + var encode = function(obj, sep, eq, name) { + sep = sep || '&'; + eq = eq || '='; + if (obj === null) { + obj = undefined; + } + + if (typeof obj === 'object') { + return Object.keys(obj).map(function(k) { + var ks = encodeURIComponent(stringifyPrimitive(k)) + eq; + if (Array.isArray(obj[k])) { + return obj[k].map(function(v) { + return ks + encodeURIComponent(stringifyPrimitive(v)); + }).join(sep); + } else { + return ks + encodeURIComponent(stringifyPrimitive(obj[k])); + } + }).join(sep); + + } + + if (!name) return ''; + return encodeURIComponent(stringifyPrimitive(name)) + eq + + encodeURIComponent(stringifyPrimitive(obj)); + }; + + var querystring = createCommonjsModule(function (module, exports) { + + exports.decode = exports.parse = decode; + exports.encode = exports.stringify = encode; + }); + var querystring_1 = querystring.decode; + var querystring_2 = querystring.parse; + var querystring_3 = querystring.encode; + var querystring_4 = querystring.stringify; + + var parse = urlParse; + var format = urlFormat; + + function Url() { + this.protocol = null; + this.slashes = null; + this.auth = null; + this.host = null; + this.port = null; + this.hostname = null; + this.hash = null; + this.search = null; + this.query = null; + this.pathname = null; + this.path = null; + this.href = null; + } + + // Reference: RFC 3986, RFC 1808, RFC 2396 + + // define these here so at least they only have to be + // compiled once on the first module load. + var protocolPattern = /^([a-z0-9.+-]+:)/i, + portPattern = /:[0-9]*$/, + + // Special case for a simple path URL + simplePathPattern = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/, + + // RFC 2396: characters reserved for delimiting URLs. + // We actually just auto-escape these. + delims = ['<', '>', '"', '`', ' ', '\r', '\n', '\t'], + + // RFC 2396: characters not allowed for various reasons. + unwise = ['{', '}', '|', '\\', '^', '`'].concat(delims), + + // Allowed by RFCs, but cause of XSS attacks. Always escape these. + autoEscape = ['\''].concat(unwise), + // Characters that are never ever allowed in a hostname. + // Note that any invalid chars are also handled, but these + // are the ones that are *expected* to be seen, so we fast-path + // them. + nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape), + hostEndingChars = ['/', '?', '#'], + hostnameMaxLen = 255, + hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/, + hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/, + // protocols that can allow "unsafe" and "unwise" chars. + unsafeProtocol = { + 'javascript': true, + 'javascript:': true + }, + // protocols that never have a hostname. + hostlessProtocol = { + 'javascript': true, + 'javascript:': true + }, + // protocols that always contain a // bit. + slashedProtocol = { + 'http': true, + 'https': true, + 'ftp': true, + 'gopher': true, + 'file': true, + 'http:': true, + 'https:': true, + 'ftp:': true, + 'gopher:': true, + 'file:': true + }; + + function urlParse(url, parseQueryString, slashesDenoteHost) { + if (url && util.isObject(url) && url instanceof Url) return url; + + var u = new Url; + u.parse(url, parseQueryString, slashesDenoteHost); + return u; + } + + Url.prototype.parse = function(url, parseQueryString, slashesDenoteHost) { + if (!util.isString(url)) { + throw new TypeError("Parameter 'url' must be a string, not " + typeof url); + } + + // Copy chrome, IE, opera backslash-handling behavior. + // Back slashes before the query string get converted to forward slashes + // See: https://code.google.com/p/chromium/issues/detail?id=25916 + var queryIndex = url.indexOf('?'), + splitter = + (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#', + uSplit = url.split(splitter), + slashRegex = /\\/g; + uSplit[0] = uSplit[0].replace(slashRegex, '/'); + url = uSplit.join(splitter); + + var rest = url; + + // trim before proceeding. + // This is to support parse stuff like " http://foo.com \n" + rest = rest.trim(); + + if (!slashesDenoteHost && url.split('#').length === 1) { + // Try fast path regexp + var simplePath = simplePathPattern.exec(rest); + if (simplePath) { + this.path = rest; + this.href = rest; + this.pathname = simplePath[1]; + if (simplePath[2]) { + this.search = simplePath[2]; + if (parseQueryString) { + this.query = querystring.parse(this.search.substr(1)); + } else { + this.query = this.search.substr(1); + } + } else if (parseQueryString) { + this.search = ''; + this.query = {}; + } + return this; + } + } + + var proto = protocolPattern.exec(rest); + if (proto) { + proto = proto[0]; + var lowerProto = proto.toLowerCase(); + this.protocol = lowerProto; + rest = rest.substr(proto.length); + } + + // figure out if it's got a host + // user@server is *always* interpreted as a hostname, and url + // resolution will treat //foo/bar as host=foo,path=bar because that's + // how the browser resolves relative URLs. + if (slashesDenoteHost || proto || rest.match(/^\/\/[^@\/]+@[^@\/]+/)) { + var slashes = rest.substr(0, 2) === '//'; + if (slashes && !(proto && hostlessProtocol[proto])) { + rest = rest.substr(2); + this.slashes = true; + } + } + + if (!hostlessProtocol[proto] && + (slashes || (proto && !slashedProtocol[proto]))) { + + // there's a hostname. + // the first instance of /, ?, ;, or # ends the host. + // + // If there is an @ in the hostname, then non-host chars *are* allowed + // to the left of the last @ sign, unless some host-ending character + // comes *before* the @-sign. + // URLs are obnoxious. + // + // ex: + // http://a@b@c/ => user:a@b host:c + // http://a@b?@c => user:a host:c path:/?@c + + // v0.12 TODO(isaacs): This is not quite how Chrome does things. + // Review our test case against browsers more comprehensively. + + // find the first instance of any hostEndingChars + var hostEnd = -1; + for (var i = 0; i < hostEndingChars.length; i++) { + var hec = rest.indexOf(hostEndingChars[i]); + if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) + hostEnd = hec; + } + + // at this point, either we have an explicit point where the + // auth portion cannot go past, or the last @ char is the decider. + var auth, atSign; + if (hostEnd === -1) { + // atSign can be anywhere. + atSign = rest.lastIndexOf('@'); + } else { + // atSign must be in auth portion. + // http://a@b/c@d => host:b auth:a path:/c@d + atSign = rest.lastIndexOf('@', hostEnd); + } + + // Now we have a portion which is definitely the auth. + // Pull that off. + if (atSign !== -1) { + auth = rest.slice(0, atSign); + rest = rest.slice(atSign + 1); + this.auth = decodeURIComponent(auth); + } + + // the host is the remaining to the left of the first non-host char + hostEnd = -1; + for (var i = 0; i < nonHostChars.length; i++) { + var hec = rest.indexOf(nonHostChars[i]); + if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) + hostEnd = hec; + } + // if we still have not hit it, then the entire thing is a host. + if (hostEnd === -1) + hostEnd = rest.length; + + this.host = rest.slice(0, hostEnd); + rest = rest.slice(hostEnd); + + // pull out port. + this.parseHost(); + + // we've indicated that there is a hostname, + // so even if it's empty, it has to be present. + this.hostname = this.hostname || ''; + + // if hostname begins with [ and ends with ] + // assume that it's an IPv6 address. + var ipv6Hostname = this.hostname[0] === '[' && + this.hostname[this.hostname.length - 1] === ']'; + + // validate a little. + if (!ipv6Hostname) { + var hostparts = this.hostname.split(/\./); + for (var i = 0, l = hostparts.length; i < l; i++) { + var part = hostparts[i]; + if (!part) continue; + if (!part.match(hostnamePartPattern)) { + var newpart = ''; + for (var j = 0, k = part.length; j < k; j++) { + if (part.charCodeAt(j) > 127) { + // we replace non-ASCII char with a temporary placeholder + // we need this to make sure size of hostname is not + // broken by replacing non-ASCII by nothing + newpart += 'x'; + } else { + newpart += part[j]; + } + } + // we test again with ASCII char only + if (!newpart.match(hostnamePartPattern)) { + var validParts = hostparts.slice(0, i); + var notHost = hostparts.slice(i + 1); + var bit = part.match(hostnamePartStart); + if (bit) { + validParts.push(bit[1]); + notHost.unshift(bit[2]); + } + if (notHost.length) { + rest = '/' + notHost.join('.') + rest; + } + this.hostname = validParts.join('.'); + break; + } + } + } + } + + if (this.hostname.length > hostnameMaxLen) { + this.hostname = ''; + } else { + // hostnames are always lower case. + this.hostname = this.hostname.toLowerCase(); + } + + if (!ipv6Hostname) { + // IDNA Support: Returns a punycoded representation of "domain". + // It only converts parts of the domain name that + // have non-ASCII characters, i.e. it doesn't matter if + // you call it with a domain that already is ASCII-only. + this.hostname = punycode.toASCII(this.hostname); + } + + var p = this.port ? ':' + this.port : ''; + var h = this.hostname || ''; + this.host = h + p; + this.href += this.host; + + // strip [ and ] from the hostname + // the host field still retains them, though + if (ipv6Hostname) { + this.hostname = this.hostname.substr(1, this.hostname.length - 2); + if (rest[0] !== '/') { + rest = '/' + rest; + } + } + } + + // now rest is set to the post-host stuff. + // chop off any delim chars. + if (!unsafeProtocol[lowerProto]) { + + // First, make 100% sure that any "autoEscape" chars get + // escaped, even if encodeURIComponent doesn't think they + // need to be. + for (var i = 0, l = autoEscape.length; i < l; i++) { + var ae = autoEscape[i]; + if (rest.indexOf(ae) === -1) + continue; + var esc = encodeURIComponent(ae); + if (esc === ae) { + esc = escape(ae); + } + rest = rest.split(ae).join(esc); + } + } + + + // chop off from the tail first. + var hash = rest.indexOf('#'); + if (hash !== -1) { + // got a fragment string. + this.hash = rest.substr(hash); + rest = rest.slice(0, hash); + } + var qm = rest.indexOf('?'); + if (qm !== -1) { + this.search = rest.substr(qm); + this.query = rest.substr(qm + 1); + if (parseQueryString) { + this.query = querystring.parse(this.query); + } + rest = rest.slice(0, qm); + } else if (parseQueryString) { + // no query string, but parseQueryString still requested + this.search = ''; + this.query = {}; + } + if (rest) this.pathname = rest; + if (slashedProtocol[lowerProto] && + this.hostname && !this.pathname) { + this.pathname = '/'; + } + + //to support http.request + if (this.pathname || this.search) { + var p = this.pathname || ''; + var s = this.search || ''; + this.path = p + s; + } + + // finally, reconstruct the href based on what has been validated. + this.href = this.format(); + return this; + }; + + // format a parsed object into a url string + function urlFormat(obj) { + // ensure it's an object, and not a string url. + // If it's an obj, this is a no-op. + // this way, you can call url_format() on strings + // to clean up potentially wonky urls. + if (util.isString(obj)) obj = urlParse(obj); + if (!(obj instanceof Url)) return Url.prototype.format.call(obj); + return obj.format(); + } + + Url.prototype.format = function() { + var auth = this.auth || ''; + if (auth) { + auth = encodeURIComponent(auth); + auth = auth.replace(/%3A/i, ':'); + auth += '@'; + } + + var protocol = this.protocol || '', + pathname = this.pathname || '', + hash = this.hash || '', + host = false, + query = ''; + + if (this.host) { + host = auth + this.host; + } else if (this.hostname) { + host = auth + (this.hostname.indexOf(':') === -1 ? + this.hostname : + '[' + this.hostname + ']'); + if (this.port) { + host += ':' + this.port; + } + } + + if (this.query && + util.isObject(this.query) && + Object.keys(this.query).length) { + query = querystring.stringify(this.query); + } + + var search = this.search || (query && ('?' + query)) || ''; + + if (protocol && protocol.substr(-1) !== ':') protocol += ':'; + + // only the slashedProtocols get the //. Not mailto:, xmpp:, etc. + // unless they had them to begin with. + if (this.slashes || + (!protocol || slashedProtocol[protocol]) && host !== false) { + host = '//' + (host || ''); + if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname; + } else if (!host) { + host = ''; + } + + if (hash && hash.charAt(0) !== '#') hash = '#' + hash; + if (search && search.charAt(0) !== '?') search = '?' + search; + + pathname = pathname.replace(/[?#]/g, function(match) { + return encodeURIComponent(match); + }); + search = search.replace('#', '%23'); + + return protocol + host + pathname + search + hash; + }; + + Url.prototype.resolve = function(relative) { + return this.resolveObject(urlParse(relative, false, true)).format(); + }; + + Url.prototype.resolveObject = function(relative) { + if (util.isString(relative)) { + var rel = new Url(); + rel.parse(relative, false, true); + relative = rel; + } + + var result = new Url(); + var tkeys = Object.keys(this); + for (var tk = 0; tk < tkeys.length; tk++) { + var tkey = tkeys[tk]; + result[tkey] = this[tkey]; + } + + // hash is always overridden, no matter what. + // even href="" will remove it. + result.hash = relative.hash; + + // if the relative url is empty, then there's nothing left to do here. + if (relative.href === '') { + result.href = result.format(); + return result; + } + + // hrefs like //foo/bar always cut to the protocol. + if (relative.slashes && !relative.protocol) { + // take everything except the protocol from relative + var rkeys = Object.keys(relative); + for (var rk = 0; rk < rkeys.length; rk++) { + var rkey = rkeys[rk]; + if (rkey !== 'protocol') + result[rkey] = relative[rkey]; + } + + //urlParse appends trailing / to urls like http://www.example.com + if (slashedProtocol[result.protocol] && + result.hostname && !result.pathname) { + result.path = result.pathname = '/'; + } + + result.href = result.format(); + return result; + } + + if (relative.protocol && relative.protocol !== result.protocol) { + // if it's a known url protocol, then changing + // the protocol does weird things + // first, if it's not file:, then we MUST have a host, + // and if there was a path + // to begin with, then we MUST have a path. + // if it is file:, then the host is dropped, + // because that's known to be hostless. + // anything else is assumed to be absolute. + if (!slashedProtocol[relative.protocol]) { + var keys = Object.keys(relative); + for (var v = 0; v < keys.length; v++) { + var k = keys[v]; + result[k] = relative[k]; + } + result.href = result.format(); + return result; + } + + result.protocol = relative.protocol; + if (!relative.host && !hostlessProtocol[relative.protocol]) { + var relPath = (relative.pathname || '').split('/'); + while (relPath.length && !(relative.host = relPath.shift())); + if (!relative.host) relative.host = ''; + if (!relative.hostname) relative.hostname = ''; + if (relPath[0] !== '') relPath.unshift(''); + if (relPath.length < 2) relPath.unshift(''); + result.pathname = relPath.join('/'); + } else { + result.pathname = relative.pathname; + } + result.search = relative.search; + result.query = relative.query; + result.host = relative.host || ''; + result.auth = relative.auth; + result.hostname = relative.hostname || relative.host; + result.port = relative.port; + // to support http.request + if (result.pathname || result.search) { + var p = result.pathname || ''; + var s = result.search || ''; + result.path = p + s; + } + result.slashes = result.slashes || relative.slashes; + result.href = result.format(); + return result; + } + + var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'), + isRelAbs = ( + relative.host || + relative.pathname && relative.pathname.charAt(0) === '/' + ), + mustEndAbs = (isRelAbs || isSourceAbs || + (result.host && relative.pathname)), + removeAllDots = mustEndAbs, + srcPath = result.pathname && result.pathname.split('/') || [], + relPath = relative.pathname && relative.pathname.split('/') || [], + psychotic = result.protocol && !slashedProtocol[result.protocol]; + + // if the url is a non-slashed url, then relative + // links like ../.. should be able + // to crawl up to the hostname, as well. This is strange. + // result.protocol has already been set by now. + // Later on, put the first path part into the host field. + if (psychotic) { + result.hostname = ''; + result.port = null; + if (result.host) { + if (srcPath[0] === '') srcPath[0] = result.host; + else srcPath.unshift(result.host); + } + result.host = ''; + if (relative.protocol) { + relative.hostname = null; + relative.port = null; + if (relative.host) { + if (relPath[0] === '') relPath[0] = relative.host; + else relPath.unshift(relative.host); + } + relative.host = null; + } + mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === ''); + } + + if (isRelAbs) { + // it's absolute. + result.host = (relative.host || relative.host === '') ? + relative.host : result.host; + result.hostname = (relative.hostname || relative.hostname === '') ? + relative.hostname : result.hostname; + result.search = relative.search; + result.query = relative.query; + srcPath = relPath; + // fall through to the dot-handling below. + } else if (relPath.length) { + // it's relative + // throw away the existing file, and take the new path instead. + if (!srcPath) srcPath = []; + srcPath.pop(); + srcPath = srcPath.concat(relPath); + result.search = relative.search; + result.query = relative.query; + } else if (!util.isNullOrUndefined(relative.search)) { + // just pull out the search. + // like href='?foo'. + // Put this after the other two cases because it simplifies the booleans + if (psychotic) { + result.hostname = result.host = srcPath.shift(); + //occationaly the auth can get stuck only in host + //this especially happens in cases like + //url.resolveObject('mailto:local1@domain1', 'local2@domain2') + var authInHost = result.host && result.host.indexOf('@') > 0 ? + result.host.split('@') : false; + if (authInHost) { + result.auth = authInHost.shift(); + result.host = result.hostname = authInHost.shift(); + } + } + result.search = relative.search; + result.query = relative.query; + //to support http.request + if (!util.isNull(result.pathname) || !util.isNull(result.search)) { + result.path = (result.pathname ? result.pathname : '') + + (result.search ? result.search : ''); + } + result.href = result.format(); + return result; + } + + if (!srcPath.length) { + // no path at all. easy. + // we've already handled the other stuff above. + result.pathname = null; + //to support http.request + if (result.search) { + result.path = '/' + result.search; + } else { + result.path = null; + } + result.href = result.format(); + return result; + } + + // if a url ENDs in . or .., then it must get a trailing slash. + // however, if it ends in anything else non-slashy, + // then it must NOT get a trailing slash. + var last = srcPath.slice(-1)[0]; + var hasTrailingSlash = ( + (result.host || relative.host || srcPath.length > 1) && + (last === '.' || last === '..') || last === ''); + + // strip single dots, resolve double dots to parent dir + // if the path tries to go above the root, `up` ends up > 0 + var up = 0; + for (var i = srcPath.length; i >= 0; i--) { + last = srcPath[i]; + if (last === '.') { + srcPath.splice(i, 1); + } else if (last === '..') { + srcPath.splice(i, 1); + up++; + } else if (up) { + srcPath.splice(i, 1); + up--; + } + } + + // if the path is allowed to go above the root, restore leading ..s + if (!mustEndAbs && !removeAllDots) { + for (; up--; up) { + srcPath.unshift('..'); + } + } + + if (mustEndAbs && srcPath[0] !== '' && + (!srcPath[0] || srcPath[0].charAt(0) !== '/')) { + srcPath.unshift(''); + } + + if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) { + srcPath.push(''); + } + + var isAbsolute = srcPath[0] === '' || + (srcPath[0] && srcPath[0].charAt(0) === '/'); + + // put the host back + if (psychotic) { + result.hostname = result.host = isAbsolute ? '' : + srcPath.length ? srcPath.shift() : ''; + //occationaly the auth can get stuck only in host + //this especially happens in cases like + //url.resolveObject('mailto:local1@domain1', 'local2@domain2') + var authInHost = result.host && result.host.indexOf('@') > 0 ? + result.host.split('@') : false; + if (authInHost) { + result.auth = authInHost.shift(); + result.host = result.hostname = authInHost.shift(); + } + } + + mustEndAbs = mustEndAbs || (result.host && srcPath.length); + + if (mustEndAbs && !isAbsolute) { + srcPath.unshift(''); + } + + if (!srcPath.length) { + result.pathname = null; + result.path = null; + } else { + result.pathname = srcPath.join('/'); + } + + //to support request.http + if (!util.isNull(result.pathname) || !util.isNull(result.search)) { + result.path = (result.pathname ? result.pathname : '') + + (result.search ? result.search : ''); + } + result.auth = relative.auth || result.auth; + result.slashes = result.slashes || relative.slashes; + result.href = result.format(); + return result; + }; + + Url.prototype.parseHost = function() { + var host = this.host; + var port = portPattern.exec(host); + if (port) { + port = port[0]; + if (port !== ':') { + this.port = port.substr(1); + } + host = host.substr(0, host.length - port.length); + } + if (host) this.hostname = host; + }; + + var aspromise = asPromise; + + /** + * Callback as used by {@link util.asPromise}. + * @typedef asPromiseCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {...*} params Additional arguments + * @returns {undefined} + */ + + /** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ + function asPromise(fn, ctx/*, varargs */) { + var params = new Array(arguments.length - 1), + offset = 0, + index = 2, + pending = true; + while (index < arguments.length) + params[offset++] = arguments[index++]; + return new Promise(function executor(resolve, reject) { + params[offset] = function callback(err/*, varargs */) { + if (pending) { + pending = false; + if (err) + reject(err); + else { + var params = new Array(arguments.length - 1), + offset = 0; + while (offset < params.length) + params[offset++] = arguments[offset]; + resolve.apply(null, params); + } + } + }; + try { + fn.apply(ctx || null, params); + } catch (err) { + if (pending) { + pending = false; + reject(err); + } + } + }); + } + + var base64_1 = createCommonjsModule(function (module, exports) { + + /** + * A minimal base64 implementation for number arrays. + * @memberof util + * @namespace + */ + var base64 = exports; + + /** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ + base64.length = function length(string) { + var p = string.length; + if (!p) + return 0; + var n = 0; + while (--p % 4 > 1 && string.charAt(p) === "=") + ++n; + return Math.ceil(string.length * 3) / 4 - n; + }; + + // Base64 encoding table + var b64 = new Array(64); + + // Base64 decoding table + var s64 = new Array(123); + + // 65..90, 97..122, 48..57, 43, 47 + for (var i = 0; i < 64;) + s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++; + + /** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ + base64.encode = function encode(buffer, start, end) { + var parts = null, + chunk = []; + var i = 0, // output index + j = 0, // goto index + t; // temporary + while (start < end) { + var b = buffer[start++]; + switch (j) { + case 0: + chunk[i++] = b64[b >> 2]; + t = (b & 3) << 4; + j = 1; + break; + case 1: + chunk[i++] = b64[t | b >> 4]; + t = (b & 15) << 2; + j = 2; + break; + case 2: + chunk[i++] = b64[t | b >> 6]; + chunk[i++] = b64[b & 63]; + j = 0; + break; + } + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (j) { + chunk[i++] = b64[t]; + chunk[i++] = 61; + if (j === 1) + chunk[i++] = 61; + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); + }; + + var invalidEncoding = "invalid encoding"; + + /** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ + base64.decode = function decode(string, buffer, offset) { + var start = offset; + var j = 0, // goto index + t; // temporary + for (var i = 0; i < string.length;) { + var c = string.charCodeAt(i++); + if (c === 61 && j > 1) + break; + if ((c = s64[c]) === undefined) + throw Error(invalidEncoding); + switch (j) { + case 0: + t = c; + j = 1; + break; + case 1: + buffer[offset++] = t << 2 | (c & 48) >> 4; + t = c; + j = 2; + break; + case 2: + buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2; + t = c; + j = 3; + break; + case 3: + buffer[offset++] = (t & 3) << 6 | c; + j = 0; + break; + } + } + if (j === 1) + throw Error(invalidEncoding); + return offset - start; + }; + + /** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if probably base64 encoded, otherwise false + */ + base64.test = function test(string) { + return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string); + }; + }); + + var eventemitter = EventEmitter; + + /** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ + function EventEmitter() { + + /** + * Registered listeners. + * @type {Object.} + * @private + */ + this._listeners = {}; + } + + /** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ + EventEmitter.prototype.on = function on(evt, fn, ctx) { + (this._listeners[evt] || (this._listeners[evt] = [])).push({ + fn : fn, + ctx : ctx || this + }); + return this; + }; + + /** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ + EventEmitter.prototype.off = function off(evt, fn) { + if (evt === undefined) + this._listeners = {}; + else { + if (fn === undefined) + this._listeners[evt] = []; + else { + var listeners = this._listeners[evt]; + for (var i = 0; i < listeners.length;) + if (listeners[i].fn === fn) + listeners.splice(i, 1); + else + ++i; + } + } + return this; + }; + + /** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ + EventEmitter.prototype.emit = function emit(evt) { + var listeners = this._listeners[evt]; + if (listeners) { + var args = [], + i = 1; + for (; i < arguments.length;) + args.push(arguments[i++]); + for (i = 0; i < listeners.length;) + listeners[i].fn.apply(listeners[i++].ctx, args); + } + return this; + }; + + var float_1 = factory(factory); + + /** + * Reads / writes floats / doubles from / to buffers. + * @name util.float + * @namespace + */ + + /** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name util.float.writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + + /** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name util.float.writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + + /** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name util.float.readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + + /** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name util.float.readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + + /** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name util.float.writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + + /** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name util.float.writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + + /** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name util.float.readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + + /** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name util.float.readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + + // Factory function for the purpose of node-based testing in modified global environments + function factory(exports) { + + // float: typed array + if (typeof Float32Array !== "undefined") (function() { + + var f32 = new Float32Array([ -0 ]), + f8b = new Uint8Array(f32.buffer), + le = f8b[3] === 128; + + function writeFloat_f32_cpy(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + } + + function writeFloat_f32_rev(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[3]; + buf[pos + 1] = f8b[2]; + buf[pos + 2] = f8b[1]; + buf[pos + 3] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev; + /* istanbul ignore next */ + exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy; + + function readFloat_f32_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + return f32[0]; + } + + function readFloat_f32_rev(buf, pos) { + f8b[3] = buf[pos ]; + f8b[2] = buf[pos + 1]; + f8b[1] = buf[pos + 2]; + f8b[0] = buf[pos + 3]; + return f32[0]; + } + + /* istanbul ignore next */ + exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev; + /* istanbul ignore next */ + exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy; + + // float: ieee754 + })(); else (function() { + + function writeFloat_ieee754(writeUint, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos); + else if (isNaN(val)) + writeUint(2143289344, buf, pos); + else if (val > 3.4028234663852886e+38) // +-Infinity + writeUint((sign << 31 | 2139095040) >>> 0, buf, pos); + else if (val < 1.1754943508222875e-38) // denormal + writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos); + else { + var exponent = Math.floor(Math.log(val) / Math.LN2), + mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607; + writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos); + } + } + + exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE); + exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE); + + function readFloat_ieee754(readUint, buf, pos) { + var uint = readUint(buf, pos), + sign = (uint >> 31) * 2 + 1, + exponent = uint >>> 23 & 255, + mantissa = uint & 8388607; + return exponent === 255 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 1.401298464324817e-45 * mantissa + : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608); + } + + exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE); + exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE); + + })(); + + // double: typed array + if (typeof Float64Array !== "undefined") (function() { + + var f64 = new Float64Array([-0]), + f8b = new Uint8Array(f64.buffer), + le = f8b[7] === 128; + + function writeDouble_f64_cpy(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + buf[pos + 4] = f8b[4]; + buf[pos + 5] = f8b[5]; + buf[pos + 6] = f8b[6]; + buf[pos + 7] = f8b[7]; + } + + function writeDouble_f64_rev(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[7]; + buf[pos + 1] = f8b[6]; + buf[pos + 2] = f8b[5]; + buf[pos + 3] = f8b[4]; + buf[pos + 4] = f8b[3]; + buf[pos + 5] = f8b[2]; + buf[pos + 6] = f8b[1]; + buf[pos + 7] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev; + /* istanbul ignore next */ + exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy; + + function readDouble_f64_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + f8b[4] = buf[pos + 4]; + f8b[5] = buf[pos + 5]; + f8b[6] = buf[pos + 6]; + f8b[7] = buf[pos + 7]; + return f64[0]; + } + + function readDouble_f64_rev(buf, pos) { + f8b[7] = buf[pos ]; + f8b[6] = buf[pos + 1]; + f8b[5] = buf[pos + 2]; + f8b[4] = buf[pos + 3]; + f8b[3] = buf[pos + 4]; + f8b[2] = buf[pos + 5]; + f8b[1] = buf[pos + 6]; + f8b[0] = buf[pos + 7]; + return f64[0]; + } + + /* istanbul ignore next */ + exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev; + /* istanbul ignore next */ + exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy; + + // double: ieee754 + })(); else (function() { + + function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) { + writeUint(0, buf, pos + off0); + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1); + } else if (isNaN(val)) { + writeUint(0, buf, pos + off0); + writeUint(2146959360, buf, pos + off1); + } else if (val > 1.7976931348623157e+308) { // +-Infinity + writeUint(0, buf, pos + off0); + writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1); + } else { + var mantissa; + if (val < 2.2250738585072014e-308) { // denormal + mantissa = val / 5e-324; + writeUint(mantissa >>> 0, buf, pos + off0); + writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1); + } else { + var exponent = Math.floor(Math.log(val) / Math.LN2); + if (exponent === 1024) + exponent = 1023; + mantissa = val * Math.pow(2, -exponent); + writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0); + writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1); + } + } + } + + exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4); + exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0); + + function readDouble_ieee754(readUint, off0, off1, buf, pos) { + var lo = readUint(buf, pos + off0), + hi = readUint(buf, pos + off1); + var sign = (hi >> 31) * 2 + 1, + exponent = hi >>> 20 & 2047, + mantissa = 4294967296 * (hi & 1048575) + lo; + return exponent === 2047 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 5e-324 * mantissa + : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496); + } + + exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4); + exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0); + + })(); + + return exports; + } + + // uint helpers + + function writeUintLE(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; + } + + function writeUintBE(val, buf, pos) { + buf[pos ] = val >>> 24; + buf[pos + 1] = val >>> 16 & 255; + buf[pos + 2] = val >>> 8 & 255; + buf[pos + 3] = val & 255; + } + + function readUintLE(buf, pos) { + return (buf[pos ] + | buf[pos + 1] << 8 + | buf[pos + 2] << 16 + | buf[pos + 3] << 24) >>> 0; + } + + function readUintBE(buf, pos) { + return (buf[pos ] << 24 + | buf[pos + 1] << 16 + | buf[pos + 2] << 8 + | buf[pos + 3]) >>> 0; + } + + var inquire_1 = inquire; + + /** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ + function inquire(moduleName) { + try { + var mod = eval("quire".replace(/^/,"re"))(moduleName); // eslint-disable-line no-eval + if (mod && (mod.length || Object.keys(mod).length)) + return mod; + } catch (e) {} // eslint-disable-line no-empty + return null; + } + + var utf8_1 = createCommonjsModule(function (module, exports) { + + /** + * A minimal UTF8 implementation for number arrays. + * @memberof util + * @namespace + */ + var utf8 = exports; + + /** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ + utf8.length = function utf8_length(string) { + var len = 0, + c = 0; + for (var i = 0; i < string.length; ++i) { + c = string.charCodeAt(i); + if (c < 128) + len += 1; + else if (c < 2048) + len += 2; + else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) { + ++i; + len += 4; + } else + len += 3; + } + return len; + }; + + /** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ + utf8.read = function utf8_read(buffer, start, end) { + var len = end - start; + if (len < 1) + return ""; + var parts = null, + chunk = [], + i = 0, // char offset + t; // temporary + while (start < end) { + t = buffer[start++]; + if (t < 128) + chunk[i++] = t; + else if (t > 191 && t < 224) + chunk[i++] = (t & 31) << 6 | buffer[start++] & 63; + else if (t > 239 && t < 365) { + t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000; + chunk[i++] = 0xD800 + (t >> 10); + chunk[i++] = 0xDC00 + (t & 1023); + } else + chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63; + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); + }; + + /** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ + utf8.write = function utf8_write(string, buffer, offset) { + var start = offset, + c1, // character 1 + c2; // character 2 + for (var i = 0; i < string.length; ++i) { + c1 = string.charCodeAt(i); + if (c1 < 128) { + buffer[offset++] = c1; + } else if (c1 < 2048) { + buffer[offset++] = c1 >> 6 | 192; + buffer[offset++] = c1 & 63 | 128; + } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) { + c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF); + ++i; + buffer[offset++] = c1 >> 18 | 240; + buffer[offset++] = c1 >> 12 & 63 | 128; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } else { + buffer[offset++] = c1 >> 12 | 224; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } + } + return offset - start; + }; + }); + + var pool_1 = pool; + + /** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + + /** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ + + /** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ + function pool(alloc, slice, size) { + var SIZE = size || 8192; + var MAX = SIZE >>> 1; + var slab = null; + var offset = SIZE; + return function pool_alloc(size) { + if (size < 1 || size > MAX) + return alloc(size); + if (offset + size > SIZE) { + slab = alloc(SIZE); + offset = 0; + } + var buf = slice.call(slab, offset, offset += size); + if (offset & 7) // align to 32 bit + offset = (offset | 7) + 1; + return buf; + }; + } + + var longbits = LongBits; + + + + /** + * Constructs new long bits. + * @classdesc Helper class for working with the low and high bits of a 64 bit value. + * @memberof util + * @constructor + * @param {number} lo Low 32 bits, unsigned + * @param {number} hi High 32 bits, unsigned + */ + function LongBits(lo, hi) { + + // note that the casts below are theoretically unnecessary as of today, but older statically + // generated converter code might still call the ctor with signed 32bits. kept for compat. + + /** + * Low bits. + * @type {number} + */ + this.lo = lo >>> 0; + + /** + * High bits. + * @type {number} + */ + this.hi = hi >>> 0; + } + + /** + * Zero bits. + * @memberof util.LongBits + * @type {util.LongBits} + */ + var zero = LongBits.zero = new LongBits(0, 0); + + zero.toNumber = function() { return 0; }; + zero.zzEncode = zero.zzDecode = function() { return this; }; + zero.length = function() { return 1; }; + + /** + * Zero hash. + * @memberof util.LongBits + * @type {string} + */ + var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0"; + + /** + * Constructs new long bits from the specified number. + * @param {number} value Value + * @returns {util.LongBits} Instance + */ + LongBits.fromNumber = function fromNumber(value) { + if (value === 0) + return zero; + var sign = value < 0; + if (sign) + value = -value; + var lo = value >>> 0, + hi = (value - lo) / 4294967296 >>> 0; + if (sign) { + hi = ~hi >>> 0; + lo = ~lo >>> 0; + if (++lo > 4294967295) { + lo = 0; + if (++hi > 4294967295) + hi = 0; + } + } + return new LongBits(lo, hi); + }; + + /** + * Constructs new long bits from a number, long or string. + * @param {Long|number|string} value Value + * @returns {util.LongBits} Instance + */ + LongBits.from = function from(value) { + if (typeof value === "number") + return LongBits.fromNumber(value); + if (minimal.isString(value)) { + /* istanbul ignore else */ + if (minimal.Long) + value = minimal.Long.fromString(value); + else + return LongBits.fromNumber(parseInt(value, 10)); + } + return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero; + }; + + /** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {number} Possibly unsafe number + */ + LongBits.prototype.toNumber = function toNumber(unsigned) { + if (!unsigned && this.hi >>> 31) { + var lo = ~this.lo + 1 >>> 0, + hi = ~this.hi >>> 0; + if (!lo) + hi = hi + 1 >>> 0; + return -(lo + hi * 4294967296); + } + return this.lo + this.hi * 4294967296; + }; + + /** + * Converts this long bits to a long. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long} Long + */ + LongBits.prototype.toLong = function toLong(unsigned) { + return minimal.Long + ? new minimal.Long(this.lo | 0, this.hi | 0, Boolean(unsigned)) + /* istanbul ignore next */ + : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) }; + }; + + var charCodeAt = String.prototype.charCodeAt; + + /** + * Constructs new long bits from the specified 8 characters long hash. + * @param {string} hash Hash + * @returns {util.LongBits} Bits + */ + LongBits.fromHash = function fromHash(hash) { + if (hash === zeroHash) + return zero; + return new LongBits( + ( charCodeAt.call(hash, 0) + | charCodeAt.call(hash, 1) << 8 + | charCodeAt.call(hash, 2) << 16 + | charCodeAt.call(hash, 3) << 24) >>> 0 + , + ( charCodeAt.call(hash, 4) + | charCodeAt.call(hash, 5) << 8 + | charCodeAt.call(hash, 6) << 16 + | charCodeAt.call(hash, 7) << 24) >>> 0 + ); + }; + + /** + * Converts this long bits to a 8 characters long hash. + * @returns {string} Hash + */ + LongBits.prototype.toHash = function toHash() { + return String.fromCharCode( + this.lo & 255, + this.lo >>> 8 & 255, + this.lo >>> 16 & 255, + this.lo >>> 24 , + this.hi & 255, + this.hi >>> 8 & 255, + this.hi >>> 16 & 255, + this.hi >>> 24 + ); + }; + + /** + * Zig-zag encodes this long bits. + * @returns {util.LongBits} `this` + */ + LongBits.prototype.zzEncode = function zzEncode() { + var mask = this.hi >> 31; + this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0; + this.lo = ( this.lo << 1 ^ mask) >>> 0; + return this; + }; + + /** + * Zig-zag decodes this long bits. + * @returns {util.LongBits} `this` + */ + LongBits.prototype.zzDecode = function zzDecode() { + var mask = -(this.lo & 1); + this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0; + this.hi = ( this.hi >>> 1 ^ mask) >>> 0; + return this; + }; + + /** + * Calculates the length of this longbits when encoded as a varint. + * @returns {number} Length + */ + LongBits.prototype.length = function length() { + var part0 = this.lo, + part1 = (this.lo >>> 28 | this.hi << 4) >>> 0, + part2 = this.hi >>> 24; + return part2 === 0 + ? part1 === 0 + ? part0 < 16384 + ? part0 < 128 ? 1 : 2 + : part0 < 2097152 ? 3 : 4 + : part1 < 16384 + ? part1 < 128 ? 5 : 6 + : part1 < 2097152 ? 7 : 8 + : part2 < 128 ? 9 : 10; + }; + + var minimal = createCommonjsModule(function (module, exports) { + var util = exports; + + // used to return a Promise where callback is omitted + util.asPromise = aspromise; + + // converts to / from base64 encoded strings + util.base64 = base64_1; + + // base class of rpc.Service + util.EventEmitter = eventemitter; + + // float handling accross browsers + util.float = float_1; + + // requires modules optionally and hides the call from bundlers + util.inquire = inquire_1; + + // converts to / from utf8 encoded strings + util.utf8 = utf8_1; + + // provides a node-like buffer pool in the browser + util.pool = pool_1; + + // utility to work with the low and high bits of a 64 bit value + util.LongBits = longbits; + + /** + * An immuable empty array. + * @memberof util + * @type {Array.<*>} + * @const + */ + util.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes + + /** + * An immutable empty object. + * @type {Object} + * @const + */ + util.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes + + /** + * Whether running within node or not. + * @memberof util + * @type {boolean} + * @const + */ + util.isNode = Boolean(commonjsGlobal.process && commonjsGlobal.process.versions && commonjsGlobal.process.versions.node); + + /** + * Tests if the specified value is an integer. + * @function + * @param {*} value Value to test + * @returns {boolean} `true` if the value is an integer + */ + util.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) { + return typeof value === "number" && isFinite(value) && Math.floor(value) === value; + }; + + /** + * Tests if the specified value is a string. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a string + */ + util.isString = function isString(value) { + return typeof value === "string" || value instanceof String; + }; + + /** + * Tests if the specified value is a non-null object. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a non-null object + */ + util.isObject = function isObject(value) { + return value && typeof value === "object"; + }; + + /** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @function + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ + util.isset = + + /** + * Checks if a property on a message is considered to be present. + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ + util.isSet = function isSet(obj, prop) { + var value = obj[prop]; + if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins + return typeof value !== "object" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0; + return false; + }; + + /** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + * @interface Buffer + * @extends Uint8Array + */ + + /** + * Node's Buffer class if available. + * @type {Constructor} + */ + util.Buffer = (function() { + try { + var Buffer = util.inquire("buffer").Buffer; + // refuse to use non-node buffers if not explicitly assigned (perf reasons): + return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null; + } catch (e) { + /* istanbul ignore next */ + return null; + } + })(); + + // Internal alias of or polyfull for Buffer.from. + util._Buffer_from = null; + + // Internal alias of or polyfill for Buffer.allocUnsafe. + util._Buffer_allocUnsafe = null; + + /** + * Creates a new buffer of whatever type supported by the environment. + * @param {number|number[]} [sizeOrArray=0] Buffer size or number array + * @returns {Uint8Array|Buffer} Buffer + */ + util.newBuffer = function newBuffer(sizeOrArray) { + /* istanbul ignore next */ + return typeof sizeOrArray === "number" + ? util.Buffer + ? util._Buffer_allocUnsafe(sizeOrArray) + : new util.Array(sizeOrArray) + : util.Buffer + ? util._Buffer_from(sizeOrArray) + : typeof Uint8Array === "undefined" + ? sizeOrArray + : new Uint8Array(sizeOrArray); + }; + + /** + * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. + * @type {Constructor} + */ + util.Array = typeof Uint8Array !== "undefined" ? Uint8Array /* istanbul ignore next */ : Array; + + /** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + * @interface Long + * @property {number} low Low bits + * @property {number} high High bits + * @property {boolean} unsigned Whether unsigned or not + */ + + /** + * Long.js's Long class if available. + * @type {Constructor} + */ + util.Long = /* istanbul ignore next */ commonjsGlobal.dcodeIO && /* istanbul ignore next */ commonjsGlobal.dcodeIO.Long || util.inquire("long"); + + /** + * Regular expression used to verify 2 bit (`bool`) map keys. + * @type {RegExp} + * @const + */ + util.key2Re = /^true|false|0|1$/; + + /** + * Regular expression used to verify 32 bit (`int32` etc.) map keys. + * @type {RegExp} + * @const + */ + util.key32Re = /^-?(?:0|[1-9][0-9]*)$/; + + /** + * Regular expression used to verify 64 bit (`int64` etc.) map keys. + * @type {RegExp} + * @const + */ + util.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/; + + /** + * Converts a number or long to an 8 characters long hash string. + * @param {Long|number} value Value to convert + * @returns {string} Hash + */ + util.longToHash = function longToHash(value) { + return value + ? util.LongBits.from(value).toHash() + : util.LongBits.zeroHash; + }; + + /** + * Converts an 8 characters long hash string to a long or number. + * @param {string} hash Hash + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long|number} Original value + */ + util.longFromHash = function longFromHash(hash, unsigned) { + var bits = util.LongBits.fromHash(hash); + if (util.Long) + return util.Long.fromBits(bits.lo, bits.hi, unsigned); + return bits.toNumber(Boolean(unsigned)); + }; + + /** + * Merges the properties of the source object into the destination object. + * @memberof util + * @param {Object.} dst Destination object + * @param {Object.} src Source object + * @param {boolean} [ifNotSet=false] Merges only if the key is not already set + * @returns {Object.} Destination object + */ + function merge(dst, src, ifNotSet) { // used by converters + for (var keys = Object.keys(src), i = 0; i < keys.length; ++i) + if (dst[keys[i]] === undefined || !ifNotSet) + dst[keys[i]] = src[keys[i]]; + return dst; + } + + util.merge = merge; + + /** + * Converts the first character of a string to lower case. + * @param {string} str String to convert + * @returns {string} Converted string + */ + util.lcFirst = function lcFirst(str) { + return str.charAt(0).toLowerCase() + str.substring(1); + }; + + /** + * Creates a custom error constructor. + * @memberof util + * @param {string} name Error name + * @returns {Constructor} Custom error constructor + */ + function newError(name) { + + function CustomError(message, properties) { + + if (!(this instanceof CustomError)) + return new CustomError(message, properties); + + // Error.call(this, message); + // ^ just returns a new error instance because the ctor can be called as a function + + Object.defineProperty(this, "message", { get: function() { return message; } }); + + /* istanbul ignore next */ + if (Error.captureStackTrace) // node + Error.captureStackTrace(this, CustomError); + else + Object.defineProperty(this, "stack", { value: (new Error()).stack || "" }); + + if (properties) + merge(this, properties); + } + + (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError; + + Object.defineProperty(CustomError.prototype, "name", { get: function() { return name; } }); + + CustomError.prototype.toString = function toString() { + return this.name + ": " + this.message; + }; + + return CustomError; + } + + util.newError = newError; + + /** + * Constructs a new protocol error. + * @classdesc Error subclass indicating a protocol specifc error. + * @memberof util + * @extends Error + * @template T extends Message + * @constructor + * @param {string} message Error message + * @param {Object.} [properties] Additional properties + * @example + * try { + * MyMessage.decode(someBuffer); // throws if required fields are missing + * } catch (e) { + * if (e instanceof ProtocolError && e.instance) + * console.log("decoded so far: " + JSON.stringify(e.instance)); + * } + */ + util.ProtocolError = newError("ProtocolError"); + + /** + * So far decoded message instance. + * @name util.ProtocolError#instance + * @type {Message} + */ + + /** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @typedef OneOfGetter + * @type {function} + * @returns {string|undefined} Set field name, if any + */ + + /** + * Builds a getter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfGetter} Unbound getter + */ + util.oneOfGetter = function getOneOf(fieldNames) { + var fieldMap = {}; + for (var i = 0; i < fieldNames.length; ++i) + fieldMap[fieldNames[i]] = 1; + + /** + * @returns {string|undefined} Set field name, if any + * @this Object + * @ignore + */ + return function() { // eslint-disable-line consistent-return + for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i) + if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null) + return keys[i]; + }; + }; + + /** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @typedef OneOfSetter + * @type {function} + * @param {string|undefined} value Field name + * @returns {undefined} + */ + + /** + * Builds a setter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfSetter} Unbound setter + */ + util.oneOfSetter = function setOneOf(fieldNames) { + + /** + * @param {string} name Field name + * @returns {undefined} + * @this Object + * @ignore + */ + return function(name) { + for (var i = 0; i < fieldNames.length; ++i) + if (fieldNames[i] !== name) + delete this[fieldNames[i]]; + }; + }; + + /** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @type {IConversionOptions} + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ + util.toJSONOptions = { + longs: String, + enums: String, + bytes: String, + json: true + }; + + util._configure = function() { + var Buffer = util.Buffer; + /* istanbul ignore if */ + if (!Buffer) { + util._Buffer_from = util._Buffer_allocUnsafe = null; + return; + } + // because node 4.x buffers are incompatible & immutable + // see: https://github.com/dcodeIO/protobuf.js/pull/665 + util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from || + /* istanbul ignore next */ + function Buffer_from(value, encoding) { + return new Buffer(value, encoding); + }; + util._Buffer_allocUnsafe = Buffer.allocUnsafe || + /* istanbul ignore next */ + function Buffer_allocUnsafe(size) { + return new Buffer(size); + }; + }; + }); + + var writer = Writer; + + + + var BufferWriter; // cyclic + + var LongBits$1 = minimal.LongBits, + base64 = minimal.base64, + utf8 = minimal.utf8; + + /** + * Constructs a new writer operation instance. + * @classdesc Scheduled writer operation. + * @constructor + * @param {function(*, Uint8Array, number)} fn Function to call + * @param {number} len Value byte length + * @param {*} val Value to write + * @ignore + */ + function Op(fn, len, val) { + + /** + * Function to call. + * @type {function(Uint8Array, number, *)} + */ + this.fn = fn; + + /** + * Value byte length. + * @type {number} + */ + this.len = len; + + /** + * Next operation. + * @type {Writer.Op|undefined} + */ + this.next = undefined; + + /** + * Value to write. + * @type {*} + */ + this.val = val; // type varies + } + + /* istanbul ignore next */ + function noop() {} // eslint-disable-line no-empty-function + + /** + * Constructs a new writer state instance. + * @classdesc Copied writer state. + * @memberof Writer + * @constructor + * @param {Writer} writer Writer to copy state from + * @ignore + */ + function State(writer) { + + /** + * Current head. + * @type {Writer.Op} + */ + this.head = writer.head; + + /** + * Current tail. + * @type {Writer.Op} + */ + this.tail = writer.tail; + + /** + * Current buffer length. + * @type {number} + */ + this.len = writer.len; + + /** + * Next state. + * @type {State|null} + */ + this.next = writer.states; + } + + /** + * Constructs a new writer instance. + * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`. + * @constructor + */ + function Writer() { + + /** + * Current length. + * @type {number} + */ + this.len = 0; + + /** + * Operations head. + * @type {Object} + */ + this.head = new Op(noop, 0, 0); + + /** + * Operations tail + * @type {Object} + */ + this.tail = this.head; + + /** + * Linked forked states. + * @type {Object|null} + */ + this.states = null; + + // When a value is written, the writer calculates its byte length and puts it into a linked + // list of operations to perform when finish() is called. This both allows us to allocate + // buffers of the exact required size and reduces the amount of work we have to do compared + // to first calculating over objects and then encoding over objects. In our case, the encoding + // part is just a linked list walk calling operations with already prepared values. + } + + /** + * Creates a new writer. + * @function + * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ + Writer.create = minimal.Buffer + ? function create_buffer_setup() { + return (Writer.create = function create_buffer() { + return new BufferWriter(); + })(); + } + /* istanbul ignore next */ + : function create_array() { + return new Writer(); + }; + + /** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + Writer.alloc = function alloc(size) { + return new minimal.Array(size); + }; + + // Use Uint8Array buffer pool in the browser, just like node does with buffers + /* istanbul ignore else */ + if (minimal.Array !== Array) + Writer.alloc = minimal.pool(Writer.alloc, minimal.Array.prototype.subarray); + + /** + * Pushes a new operation to the queue. + * @param {function(Uint8Array, number, *)} fn Function to call + * @param {number} len Value byte length + * @param {number} val Value to write + * @returns {Writer} `this` + * @private + */ + Writer.prototype._push = function push(fn, len, val) { + this.tail = this.tail.next = new Op(fn, len, val); + this.len += len; + return this; + }; + + function writeByte(val, buf, pos) { + buf[pos] = val & 255; + } + + function writeVarint32(val, buf, pos) { + while (val > 127) { + buf[pos++] = val & 127 | 128; + val >>>= 7; + } + buf[pos] = val; + } + + /** + * Constructs a new varint writer operation instance. + * @classdesc Scheduled varint writer operation. + * @extends Op + * @constructor + * @param {number} len Value byte length + * @param {number} val Value to write + * @ignore + */ + function VarintOp(len, val) { + this.len = len; + this.next = undefined; + this.val = val; + } + + VarintOp.prototype = Object.create(Op.prototype); + VarintOp.prototype.fn = writeVarint32; + + /** + * Writes an unsigned 32 bit value as a varint. + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.uint32 = function write_uint32(value) { + // here, the call to this.push has been inlined and a varint specific Op subclass is used. + // uint32 is by far the most frequently used operation and benefits significantly from this. + this.len += (this.tail = this.tail.next = new VarintOp( + (value = value >>> 0) + < 128 ? 1 + : value < 16384 ? 2 + : value < 2097152 ? 3 + : value < 268435456 ? 4 + : 5, + value)).len; + return this; + }; + + /** + * Writes a signed 32 bit value as a varint. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.int32 = function write_int32(value) { + return value < 0 + ? this._push(writeVarint64, 10, LongBits$1.fromNumber(value)) // 10 bytes per spec + : this.uint32(value); + }; + + /** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.sint32 = function write_sint32(value) { + return this.uint32((value << 1 ^ value >> 31) >>> 0); + }; + + function writeVarint64(val, buf, pos) { + while (val.hi) { + buf[pos++] = val.lo & 127 | 128; + val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0; + val.hi >>>= 7; + } + while (val.lo > 127) { + buf[pos++] = val.lo & 127 | 128; + val.lo = val.lo >>> 7; + } + buf[pos++] = val.lo; + } + + /** + * Writes an unsigned 64 bit value as a varint. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + Writer.prototype.uint64 = function write_uint64(value) { + var bits = LongBits$1.from(value); + return this._push(writeVarint64, bits.length(), bits); + }; + + /** + * Writes a signed 64 bit value as a varint. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + Writer.prototype.int64 = Writer.prototype.uint64; + + /** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + Writer.prototype.sint64 = function write_sint64(value) { + var bits = LongBits$1.from(value).zzEncode(); + return this._push(writeVarint64, bits.length(), bits); + }; + + /** + * Writes a boolish value as a varint. + * @param {boolean} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.bool = function write_bool(value) { + return this._push(writeByte, 1, value ? 1 : 0); + }; + + function writeFixed32(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; + } + + /** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.fixed32 = function write_fixed32(value) { + return this._push(writeFixed32, 4, value >>> 0); + }; + + /** + * Writes a signed 32 bit value as fixed 32 bits. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.sfixed32 = Writer.prototype.fixed32; + + /** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + Writer.prototype.fixed64 = function write_fixed64(value) { + var bits = LongBits$1.from(value); + return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi); + }; + + /** + * Writes a signed 64 bit value as fixed 64 bits. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + Writer.prototype.sfixed64 = Writer.prototype.fixed64; + + /** + * Writes a float (32 bit). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.float = function write_float(value) { + return this._push(minimal.float.writeFloatLE, 4, value); + }; + + /** + * Writes a double (64 bit float). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.double = function write_double(value) { + return this._push(minimal.float.writeDoubleLE, 8, value); + }; + + var writeBytes = minimal.Array.prototype.set + ? function writeBytes_set(val, buf, pos) { + buf.set(val, pos); // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytes_for(val, buf, pos) { + for (var i = 0; i < val.length; ++i) + buf[pos + i] = val[i]; + }; + + /** + * Writes a sequence of bytes. + * @param {Uint8Array|string} value Buffer or base64 encoded string to write + * @returns {Writer} `this` + */ + Writer.prototype.bytes = function write_bytes(value) { + var len = value.length >>> 0; + if (!len) + return this._push(writeByte, 1, 0); + if (minimal.isString(value)) { + var buf = Writer.alloc(len = base64.length(value)); + base64.decode(value, buf, 0); + value = buf; + } + return this.uint32(len)._push(writeBytes, len, value); + }; + + /** + * Writes a string. + * @param {string} value Value to write + * @returns {Writer} `this` + */ + Writer.prototype.string = function write_string(value) { + var len = utf8.length(value); + return len + ? this.uint32(len)._push(utf8.write, len, value) + : this._push(writeByte, 1, 0); + }; + + /** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns {Writer} `this` + */ + Writer.prototype.fork = function fork() { + this.states = new State(this); + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + return this; + }; + + /** + * Resets this instance to the last state. + * @returns {Writer} `this` + */ + Writer.prototype.reset = function reset() { + if (this.states) { + this.head = this.states.head; + this.tail = this.states.tail; + this.len = this.states.len; + this.states = this.states.next; + } else { + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + } + return this; + }; + + /** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns {Writer} `this` + */ + Writer.prototype.ldelim = function ldelim() { + var head = this.head, + tail = this.tail, + len = this.len; + this.reset().uint32(len); + if (len) { + this.tail.next = head.next; // skip noop + this.tail = tail; + this.len += len; + } + return this; + }; + + /** + * Finishes the write operation. + * @returns {Uint8Array} Finished buffer + */ + Writer.prototype.finish = function finish() { + var head = this.head.next, // skip noop + buf = this.constructor.alloc(this.len), + pos = 0; + while (head) { + head.fn(head.val, buf, pos); + pos += head.len; + head = head.next; + } + // this.head = this.tail = null; + return buf; + }; + + Writer._configure = function(BufferWriter_) { + BufferWriter = BufferWriter_; + }; + + var writer_buffer = BufferWriter$1; + + // extends Writer + + (BufferWriter$1.prototype = Object.create(writer.prototype)).constructor = BufferWriter$1; + + + + var Buffer = minimal.Buffer; + + /** + * Constructs a new buffer writer instance. + * @classdesc Wire format writer using node buffers. + * @extends Writer + * @constructor + */ + function BufferWriter$1() { + writer.call(this); + } + + /** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Buffer} Buffer + */ + BufferWriter$1.alloc = function alloc_buffer(size) { + return (BufferWriter$1.alloc = minimal._Buffer_allocUnsafe)(size); + }; + + var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set" + ? function writeBytesBuffer_set(val, buf, pos) { + buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited) + // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytesBuffer_copy(val, buf, pos) { + if (val.copy) // Buffer values + val.copy(buf, pos, 0, val.length); + else for (var i = 0; i < val.length;) // plain array values + buf[pos++] = val[i++]; + }; + + /** + * @override + */ + BufferWriter$1.prototype.bytes = function write_bytes_buffer(value) { + if (minimal.isString(value)) + value = minimal._Buffer_from(value, "base64"); + var len = value.length >>> 0; + this.uint32(len); + if (len) + this._push(writeBytesBuffer, len, value); + return this; + }; + + function writeStringBuffer(val, buf, pos) { + if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions) + minimal.utf8.write(val, buf, pos); + else + buf.utf8Write(val, pos); + } + + /** + * @override + */ + BufferWriter$1.prototype.string = function write_string_buffer(value) { + var len = Buffer.byteLength(value); + this.uint32(len); + if (len) + this._push(writeStringBuffer, len, value); + return this; + }; + + var reader = Reader; + + + + var BufferReader; // cyclic + + var LongBits$2 = minimal.LongBits, + utf8$1 = minimal.utf8; + + /* istanbul ignore next */ + function indexOutOfRange(reader, writeLength) { + return RangeError("index out of range: " + reader.pos + " + " + (writeLength || 1) + " > " + reader.len); + } + + /** + * Constructs a new reader instance using the specified buffer. + * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`. + * @constructor + * @param {Uint8Array} buffer Buffer to read from + */ + function Reader(buffer) { + + /** + * Read buffer. + * @type {Uint8Array} + */ + this.buf = buffer; + + /** + * Read buffer position. + * @type {number} + */ + this.pos = 0; + + /** + * Read buffer length. + * @type {number} + */ + this.len = buffer.length; + } + + var create_array = typeof Uint8Array !== "undefined" + ? function create_typed_array(buffer) { + if (buffer instanceof Uint8Array || Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + } + /* istanbul ignore next */ + : function create_array(buffer) { + if (Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + }; + + /** + * Creates a new reader using the specified buffer. + * @function + * @param {Uint8Array|Buffer} buffer Buffer to read from + * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ + Reader.create = minimal.Buffer + ? function create_buffer_setup(buffer) { + return (Reader.create = function create_buffer(buffer) { + return minimal.Buffer.isBuffer(buffer) + ? new BufferReader(buffer) + /* istanbul ignore next */ + : create_array(buffer); + })(buffer); + } + /* istanbul ignore next */ + : create_array; + + Reader.prototype._slice = minimal.Array.prototype.subarray || /* istanbul ignore next */ minimal.Array.prototype.slice; + + /** + * Reads a varint as an unsigned 32 bit value. + * @function + * @returns {number} Value read + */ + Reader.prototype.uint32 = (function read_uint32_setup() { + var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!) + return function read_uint32() { + value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value; + + /* istanbul ignore if */ + if ((this.pos += 5) > this.len) { + this.pos = this.len; + throw indexOutOfRange(this, 10); + } + return value; + }; + })(); + + /** + * Reads a varint as a signed 32 bit value. + * @returns {number} Value read + */ + Reader.prototype.int32 = function read_int32() { + return this.uint32() | 0; + }; + + /** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns {number} Value read + */ + Reader.prototype.sint32 = function read_sint32() { + var value = this.uint32(); + return value >>> 1 ^ -(value & 1) | 0; + }; + + /* eslint-disable no-invalid-this */ + + function readLongVarint() { + // tends to deopt with local vars for octet etc. + var bits = new LongBits$2(0, 0); + var i = 0; + if (this.len - this.pos > 4) { // fast route (lo) + for (; i < 4; ++i) { + // 1st..4th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 5th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0; + bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + i = 0; + } else { + for (; i < 3; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 1st..3th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 4th + bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0; + return bits; + } + if (this.len - this.pos > 4) { // fast route (hi) + for (; i < 5; ++i) { + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } else { + for (; i < 5; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } + /* istanbul ignore next */ + throw Error("invalid varint encoding"); + } + + /* eslint-enable no-invalid-this */ + + /** + * Reads a varint as a signed 64 bit value. + * @name Reader#int64 + * @function + * @returns {Long} Value read + */ + + /** + * Reads a varint as an unsigned 64 bit value. + * @name Reader#uint64 + * @function + * @returns {Long} Value read + */ + + /** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @name Reader#sint64 + * @function + * @returns {Long} Value read + */ + + /** + * Reads a varint as a boolean. + * @returns {boolean} Value read + */ + Reader.prototype.bool = function read_bool() { + return this.uint32() !== 0; + }; + + function readFixed32_end(buf, end) { // note that this uses `end`, not `pos` + return (buf[end - 4] + | buf[end - 3] << 8 + | buf[end - 2] << 16 + | buf[end - 1] << 24) >>> 0; + } + + /** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns {number} Value read + */ + Reader.prototype.fixed32 = function read_fixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4); + }; + + /** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns {number} Value read + */ + Reader.prototype.sfixed32 = function read_sfixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4) | 0; + }; + + /* eslint-disable no-invalid-this */ + + function readFixed64(/* this: Reader */) { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 8); + + return new LongBits$2(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); + } + + /* eslint-enable no-invalid-this */ + + /** + * Reads fixed 64 bits. + * @name Reader#fixed64 + * @function + * @returns {Long} Value read + */ + + /** + * Reads zig-zag encoded fixed 64 bits. + * @name Reader#sfixed64 + * @function + * @returns {Long} Value read + */ + + /** + * Reads a float (32 bit) as a number. + * @function + * @returns {number} Value read + */ + Reader.prototype.float = function read_float() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + var value = minimal.float.readFloatLE(this.buf, this.pos); + this.pos += 4; + return value; + }; + + /** + * Reads a double (64 bit float) as a number. + * @function + * @returns {number} Value read + */ + Reader.prototype.double = function read_double() { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 4); + + var value = minimal.float.readDoubleLE(this.buf, this.pos); + this.pos += 8; + return value; + }; + + /** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns {Uint8Array} Value read + */ + Reader.prototype.bytes = function read_bytes() { + var length = this.uint32(), + start = this.pos, + end = this.pos + length; + + /* istanbul ignore if */ + if (end > this.len) + throw indexOutOfRange(this, length); + + this.pos += length; + if (Array.isArray(this.buf)) // plain array + return this.buf.slice(start, end); + return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1 + ? new this.buf.constructor(0) + : this._slice.call(this.buf, start, end); + }; + + /** + * Reads a string preceeded by its byte length as a varint. + * @returns {string} Value read + */ + Reader.prototype.string = function read_string() { + var bytes = this.bytes(); + return utf8$1.read(bytes, 0, bytes.length); + }; + + /** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param {number} [length] Length if known, otherwise a varint is assumed + * @returns {Reader} `this` + */ + Reader.prototype.skip = function skip(length) { + if (typeof length === "number") { + /* istanbul ignore if */ + if (this.pos + length > this.len) + throw indexOutOfRange(this, length); + this.pos += length; + } else { + do { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + } while (this.buf[this.pos++] & 128); + } + return this; + }; + + /** + * Skips the next element of the specified wire type. + * @param {number} wireType Wire type received + * @returns {Reader} `this` + */ + Reader.prototype.skipType = function(wireType) { + switch (wireType) { + case 0: + this.skip(); + break; + case 1: + this.skip(8); + break; + case 2: + this.skip(this.uint32()); + break; + case 3: + do { // eslint-disable-line no-constant-condition + if ((wireType = this.uint32() & 7) === 4) + break; + this.skipType(wireType); + } while (true); + break; + case 5: + this.skip(4); + break; + + /* istanbul ignore next */ + default: + throw Error("invalid wire type " + wireType + " at offset " + this.pos); + } + return this; + }; + + Reader._configure = function(BufferReader_) { + BufferReader = BufferReader_; + + var fn = minimal.Long ? "toLong" : /* istanbul ignore next */ "toNumber"; + minimal.merge(Reader.prototype, { + + int64: function read_int64() { + return readLongVarint.call(this)[fn](false); + }, + + uint64: function read_uint64() { + return readLongVarint.call(this)[fn](true); + }, + + sint64: function read_sint64() { + return readLongVarint.call(this).zzDecode()[fn](false); + }, + + fixed64: function read_fixed64() { + return readFixed64.call(this)[fn](true); + }, + + sfixed64: function read_sfixed64() { + return readFixed64.call(this)[fn](false); + } + + }); + }; + + var reader_buffer = BufferReader$1; + + // extends Reader + + (BufferReader$1.prototype = Object.create(reader.prototype)).constructor = BufferReader$1; + + + + /** + * Constructs a new buffer reader instance. + * @classdesc Wire format reader using node buffers. + * @extends Reader + * @constructor + * @param {Buffer} buffer Buffer to read from + */ + function BufferReader$1(buffer) { + reader.call(this, buffer); + + /** + * Read buffer. + * @name BufferReader#buf + * @type {Buffer} + */ + } + + /* istanbul ignore else */ + if (minimal.Buffer) + BufferReader$1.prototype._slice = minimal.Buffer.prototype.slice; + + /** + * @override + */ + BufferReader$1.prototype.string = function read_string_buffer() { + var len = this.uint32(); // modifies pos + return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len)); + }; + + var service = Service; + + + + // Extends EventEmitter + (Service.prototype = Object.create(minimal.EventEmitter.prototype)).constructor = Service; + + /** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @typedef rpc.ServiceMethodCallback + * @template TRes extends Message + * @type {function} + * @param {Error|null} error Error, if any + * @param {TRes} [response] Response message + * @returns {undefined} + */ + + /** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @typedef rpc.ServiceMethod + * @template TReq extends Message + * @template TRes extends Message + * @type {function} + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message + * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined` + */ + + /** + * Constructs a new RPC service instance. + * @classdesc An RPC service as returned by {@link Service#create}. + * @exports rpc.Service + * @extends util.EventEmitter + * @constructor + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ + function Service(rpcImpl, requestDelimited, responseDelimited) { + + if (typeof rpcImpl !== "function") + throw TypeError("rpcImpl must be a function"); + + minimal.EventEmitter.call(this); + + /** + * RPC implementation. Becomes `null` once the service is ended. + * @type {RPCImpl|null} + */ + this.rpcImpl = rpcImpl; + + /** + * Whether requests are length-delimited. + * @type {boolean} + */ + this.requestDelimited = Boolean(requestDelimited); + + /** + * Whether responses are length-delimited. + * @type {boolean} + */ + this.responseDelimited = Boolean(responseDelimited); + } + + /** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param {Method|rpc.ServiceMethod} method Reflected or static method + * @param {Constructor} requestCtor Request constructor + * @param {Constructor} responseCtor Response constructor + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} callback Service callback + * @returns {undefined} + * @template TReq extends Message + * @template TRes extends Message + */ + Service.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) { + + if (!request) + throw TypeError("request must be specified"); + + var self = this; + if (!callback) + return minimal.asPromise(rpcCall, self, method, requestCtor, responseCtor, request); + + if (!self.rpcImpl) { + setTimeout(function() { callback(Error("already ended")); }, 0); + return undefined; + } + + try { + return self.rpcImpl( + method, + requestCtor[self.requestDelimited ? "encodeDelimited" : "encode"](request).finish(), + function rpcCallback(err, response) { + + if (err) { + self.emit("error", err, method); + return callback(err); + } + + if (response === null) { + self.end(/* endedByRPC */ true); + return undefined; + } + + if (!(response instanceof responseCtor)) { + try { + response = responseCtor[self.responseDelimited ? "decodeDelimited" : "decode"](response); + } catch (err) { + self.emit("error", err, method); + return callback(err); + } + } + + self.emit("data", response, method); + return callback(null, response); + } + ); + } catch (err) { + self.emit("error", err, method); + setTimeout(function() { callback(err); }, 0); + return undefined; + } + }; + + /** + * Ends this service and emits the `end` event. + * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns {rpc.Service} `this` + */ + Service.prototype.end = function end(endedByRPC) { + if (this.rpcImpl) { + if (!endedByRPC) // signal end to rpcImpl + this.rpcImpl(null, null, null); + this.rpcImpl = null; + this.emit("end").off(); + } + return this; + }; + + var rpc_1 = createCommonjsModule(function (module, exports) { + + /** + * Streaming RPC helpers. + * @namespace + */ + var rpc = exports; + + /** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @typedef RPCImpl + * @type {function} + * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called + * @param {Uint8Array} requestData Request data + * @param {RPCImplCallback} callback Callback function + * @returns {undefined} + * @example + * function rpcImpl(method, requestData, callback) { + * if (protobuf.util.lcFirst(method.name) !== "myMethod") // compatible with static code + * throw Error("no such method"); + * asynchronouslyObtainAResponse(requestData, function(err, responseData) { + * callback(err, responseData); + * }); + * } + */ + + /** + * Node-style callback as used by {@link RPCImpl}. + * @typedef RPCImplCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error + * @returns {undefined} + */ + + rpc.Service = service; + }); + + var roots = {}; + + var indexMinimal = createCommonjsModule(function (module, exports) { + var protobuf = exports; + + /** + * Build type, one of `"full"`, `"light"` or `"minimal"`. + * @name build + * @type {string} + * @const + */ + protobuf.build = "minimal"; + + // Serialization + protobuf.Writer = writer; + protobuf.BufferWriter = writer_buffer; + protobuf.Reader = reader; + protobuf.BufferReader = reader_buffer; + + // Utility + protobuf.util = minimal; + protobuf.rpc = rpc_1; + protobuf.roots = roots; + protobuf.configure = configure; + + /* istanbul ignore next */ + /** + * Reconfigures the library according to the environment. + * @returns {undefined} + */ + function configure() { + protobuf.Reader._configure(protobuf.BufferReader); + protobuf.util._configure(); + } + + // Configure serialization + protobuf.Writer._configure(protobuf.BufferWriter); + configure(); + }); + + var minimal$1 = indexMinimal; + var minimal_1 = minimal$1.roots; + var minimal_2 = minimal$1.Reader; + var minimal_3 = minimal$1.util; + + var $Reader = minimal$1.Reader, $util = minimal$1.util; + + var $root = minimal$1.roots["default"] || (minimal$1.roots["default"] = {}); + + $root.tensorflow = (function() { + + var tensorflow = {}; + + tensorflow.Any = (function() { + + function Any(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Any.prototype.typeUrl = ""; + Any.prototype.value = $util.newBuffer([]); + + Any.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.Any(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.typeUrl = r.string(); + break; + case 2: + m.value = r.bytes(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Any; + })(); + + tensorflow.DataType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "DT_INVALID"] = 0; + values[valuesById[1] = "DT_FLOAT"] = 1; + values[valuesById[2] = "DT_DOUBLE"] = 2; + values[valuesById[3] = "DT_INT32"] = 3; + values[valuesById[4] = "DT_UINT8"] = 4; + values[valuesById[5] = "DT_INT16"] = 5; + values[valuesById[6] = "DT_INT8"] = 6; + values[valuesById[7] = "DT_STRING"] = 7; + values[valuesById[8] = "DT_COMPLEX64"] = 8; + values[valuesById[9] = "DT_INT64"] = 9; + values[valuesById[10] = "DT_BOOL"] = 10; + values[valuesById[11] = "DT_QINT8"] = 11; + values[valuesById[12] = "DT_QUINT8"] = 12; + values[valuesById[13] = "DT_QINT32"] = 13; + values[valuesById[14] = "DT_BFLOAT16"] = 14; + values[valuesById[101] = "DT_FLOAT_REF"] = 101; + values[valuesById[102] = "DT_DOUBLE_REF"] = 102; + values[valuesById[103] = "DT_INT32_REF"] = 103; + values[valuesById[104] = "DT_UINT8_REF"] = 104; + values[valuesById[105] = "DT_INT16_REF"] = 105; + values[valuesById[106] = "DT_INT8_REF"] = 106; + values[valuesById[107] = "DT_STRING_REF"] = 107; + values[valuesById[108] = "DT_COMPLEX64_REF"] = 108; + values[valuesById[109] = "DT_INT64_REF"] = 109; + values[valuesById[110] = "DT_BOOL_REF"] = 110; + values[valuesById[111] = "DT_QINT8_REF"] = 111; + values[valuesById[112] = "DT_QUINT8_REF"] = 112; + values[valuesById[113] = "DT_QINT32_REF"] = 113; + values[valuesById[114] = "DT_BFLOAT16_REF"] = 114; + return values; + })(); + + tensorflow.TensorShape = (function() { + + function TensorShape(p) { + this.dim = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + TensorShape.prototype.dim = $util.emptyArray; + TensorShape.prototype.unknownRank = false; + + TensorShape.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorShape(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 2: + if (!(m.dim && m.dim.length)) + m.dim = []; + m.dim.push($root.tensorflow.TensorShape.Dim.decode(r, r.uint32())); + break; + case 3: + m.unknownRank = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + TensorShape.Dim = (function() { + + function Dim(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Dim.prototype.size = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + Dim.prototype.name = ""; + + Dim.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorShape.Dim(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.size = r.int64(); + break; + case 2: + m.name = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Dim; + })(); + + return TensorShape; + })(); + + tensorflow.Tensor = (function() { + + function Tensor(p) { + this.floatVal = []; + this.doubleVal = []; + this.intVal = []; + this.stringVal = []; + this.scomplexVal = []; + this.int64Val = []; + this.boolVal = []; + this.uint32Val = []; + this.uint64Val = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Tensor.prototype.dtype = 0; + Tensor.prototype.tensorShape = null; + Tensor.prototype.versionNumber = 0; + Tensor.prototype.tensorContent = $util.newBuffer([]); + Tensor.prototype.floatVal = $util.emptyArray; + Tensor.prototype.doubleVal = $util.emptyArray; + Tensor.prototype.intVal = $util.emptyArray; + Tensor.prototype.stringVal = $util.emptyArray; + Tensor.prototype.scomplexVal = $util.emptyArray; + Tensor.prototype.int64Val = $util.emptyArray; + Tensor.prototype.boolVal = $util.emptyArray; + Tensor.prototype.uint32Val = $util.emptyArray; + Tensor.prototype.uint64Val = $util.emptyArray; + + Tensor.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.Tensor(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.dtype = r.int32(); + break; + case 2: + m.tensorShape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + case 3: + m.versionNumber = r.int32(); + break; + case 4: + m.tensorContent = r.bytes(); + break; + case 5: + if (!(m.floatVal && m.floatVal.length)) + m.floatVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.floatVal.push(r.float()); + } else + m.floatVal.push(r.float()); + break; + case 6: + if (!(m.doubleVal && m.doubleVal.length)) + m.doubleVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.doubleVal.push(r.double()); + } else + m.doubleVal.push(r.double()); + break; + case 7: + if (!(m.intVal && m.intVal.length)) + m.intVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.intVal.push(r.int32()); + } else + m.intVal.push(r.int32()); + break; + case 8: + if (!(m.stringVal && m.stringVal.length)) + m.stringVal = []; + m.stringVal.push(r.bytes()); + break; + case 9: + if (!(m.scomplexVal && m.scomplexVal.length)) + m.scomplexVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.scomplexVal.push(r.float()); + } else + m.scomplexVal.push(r.float()); + break; + case 10: + if (!(m.int64Val && m.int64Val.length)) + m.int64Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.int64Val.push(r.int64()); + } else + m.int64Val.push(r.int64()); + break; + case 11: + if (!(m.boolVal && m.boolVal.length)) + m.boolVal = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.boolVal.push(r.bool()); + } else + m.boolVal.push(r.bool()); + break; + case 16: + if (!(m.uint32Val && m.uint32Val.length)) + m.uint32Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.uint32Val.push(r.uint32()); + } else + m.uint32Val.push(r.uint32()); + break; + case 17: + if (!(m.uint64Val && m.uint64Val.length)) + m.uint64Val = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.uint64Val.push(r.uint64()); + } else + m.uint64Val.push(r.uint64()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Tensor; + })(); + + tensorflow.AttrValue = (function() { + + function AttrValue(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AttrValue.prototype.list = null; + AttrValue.prototype.s = $util.newBuffer([]); + AttrValue.prototype.i = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + AttrValue.prototype.f = 0; + AttrValue.prototype.b = false; + AttrValue.prototype.type = 0; + AttrValue.prototype.shape = null; + AttrValue.prototype.tensor = null; + AttrValue.prototype.placeholder = ""; + AttrValue.prototype.func = null; + + var $oneOfFields; + + Object.defineProperty(AttrValue.prototype, "value", { + get: $util.oneOfGetter($oneOfFields = ["list", "s", "i", "f", "b", "type", "shape", "tensor", "placeholder", "func"]), + set: $util.oneOfSetter($oneOfFields) + }); + + AttrValue.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AttrValue(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.list = $root.tensorflow.AttrValue.ListValue.decode(r, r.uint32()); + break; + case 2: + m.s = r.bytes(); + break; + case 3: + m.i = r.int64(); + break; + case 4: + m.f = r.float(); + break; + case 5: + m.b = r.bool(); + break; + case 6: + m.type = r.int32(); + break; + case 7: + m.shape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + case 8: + m.tensor = $root.tensorflow.Tensor.decode(r, r.uint32()); + break; + case 9: + m.placeholder = r.string(); + break; + case 10: + m.func = $root.tensorflow.NameAttrList.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + AttrValue.ListValue = (function() { + + function ListValue(p) { + this.s = []; + this.i = []; + this.f = []; + this.b = []; + this.type = []; + this.shape = []; + this.tensor = []; + this.func = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + ListValue.prototype.s = $util.emptyArray; + ListValue.prototype.i = $util.emptyArray; + ListValue.prototype.f = $util.emptyArray; + ListValue.prototype.b = $util.emptyArray; + ListValue.prototype.type = $util.emptyArray; + ListValue.prototype.shape = $util.emptyArray; + ListValue.prototype.tensor = $util.emptyArray; + ListValue.prototype.func = $util.emptyArray; + + ListValue.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AttrValue.ListValue(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 2: + if (!(m.s && m.s.length)) + m.s = []; + m.s.push(r.bytes()); + break; + case 3: + if (!(m.i && m.i.length)) + m.i = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.i.push(r.int64()); + } else + m.i.push(r.int64()); + break; + case 4: + if (!(m.f && m.f.length)) + m.f = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.f.push(r.float()); + } else + m.f.push(r.float()); + break; + case 5: + if (!(m.b && m.b.length)) + m.b = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.b.push(r.bool()); + } else + m.b.push(r.bool()); + break; + case 6: + if (!(m.type && m.type.length)) + m.type = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.type.push(r.int32()); + } else + m.type.push(r.int32()); + break; + case 7: + if (!(m.shape && m.shape.length)) + m.shape = []; + m.shape.push($root.tensorflow.TensorShape.decode(r, r.uint32())); + break; + case 8: + if (!(m.tensor && m.tensor.length)) + m.tensor = []; + m.tensor.push($root.tensorflow.Tensor.decode(r, r.uint32())); + break; + case 9: + if (!(m.func && m.func.length)) + m.func = []; + m.func.push($root.tensorflow.NameAttrList.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return ListValue; + })(); + + return AttrValue; + })(); + + tensorflow.NameAttrList = (function() { + + function NameAttrList(p) { + this.attr = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NameAttrList.prototype.name = ""; + NameAttrList.prototype.attr = $util.emptyObject; + + NameAttrList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.NameAttrList(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NameAttrList; + })(); + + tensorflow.NodeDef = (function() { + + function NodeDef(p) { + this.input = []; + this.attr = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NodeDef.prototype.name = ""; + NodeDef.prototype.op = ""; + NodeDef.prototype.input = $util.emptyArray; + NodeDef.prototype.device = ""; + NodeDef.prototype.attr = $util.emptyObject; + + NodeDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.NodeDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.op = r.string(); + break; + case 3: + if (!(m.input && m.input.length)) + m.input = []; + m.input.push(r.string()); + break; + case 4: + m.device = r.string(); + break; + case 5: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NodeDef; + })(); + + tensorflow.VersionDef = (function() { + + function VersionDef(p) { + this.badConsumers = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + VersionDef.prototype.producer = 0; + VersionDef.prototype.minConsumer = 0; + VersionDef.prototype.badConsumers = $util.emptyArray; + + VersionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.VersionDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.producer = r.int32(); + break; + case 2: + m.minConsumer = r.int32(); + break; + case 3: + if (!(m.badConsumers && m.badConsumers.length)) + m.badConsumers = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.badConsumers.push(r.int32()); + } else + m.badConsumers.push(r.int32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return VersionDef; + })(); + + tensorflow.GraphDef = (function() { + + function GraphDef(p) { + this.node = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + GraphDef.prototype.node = $util.emptyArray; + GraphDef.prototype.versions = null; + GraphDef.prototype.library = null; + + GraphDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.GraphDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.node && m.node.length)) + m.node = []; + m.node.push($root.tensorflow.NodeDef.decode(r, r.uint32())); + break; + case 4: + m.versions = $root.tensorflow.VersionDef.decode(r, r.uint32()); + break; + case 2: + m.library = $root.tensorflow.FunctionDefLibrary.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return GraphDef; + })(); + + tensorflow.CollectionDef = (function() { + + function CollectionDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + CollectionDef.prototype.nodeList = null; + CollectionDef.prototype.bytesList = null; + CollectionDef.prototype.int64List = null; + CollectionDef.prototype.floatList = null; + CollectionDef.prototype.anyList = null; + + var $oneOfFields; + + Object.defineProperty(CollectionDef.prototype, "kind", { + get: $util.oneOfGetter($oneOfFields = ["nodeList", "bytesList", "int64List", "floatList", "anyList"]), + set: $util.oneOfSetter($oneOfFields) + }); + + CollectionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.nodeList = $root.tensorflow.CollectionDef.NodeList.decode(r, r.uint32()); + break; + case 2: + m.bytesList = $root.tensorflow.CollectionDef.BytesList.decode(r, r.uint32()); + break; + case 3: + m.int64List = $root.tensorflow.CollectionDef.Int64List.decode(r, r.uint32()); + break; + case 4: + m.floatList = $root.tensorflow.CollectionDef.FloatList.decode(r, r.uint32()); + break; + case 5: + m.anyList = $root.tensorflow.CollectionDef.AnyList.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + CollectionDef.NodeList = (function() { + + function NodeList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + NodeList.prototype.value = $util.emptyArray; + + NodeList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.NodeList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push(r.string()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return NodeList; + })(); + + CollectionDef.BytesList = (function() { + + function BytesList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + BytesList.prototype.value = $util.emptyArray; + + BytesList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.BytesList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push(r.bytes()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return BytesList; + })(); + + CollectionDef.Int64List = (function() { + + function Int64List(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + Int64List.prototype.value = $util.emptyArray; + + Int64List.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.Int64List(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.value.push(r.int64()); + } else + m.value.push(r.int64()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return Int64List; + })(); + + CollectionDef.FloatList = (function() { + + function FloatList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FloatList.prototype.value = $util.emptyArray; + + FloatList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.FloatList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + if ((t & 7) === 2) { + var c2 = r.uint32() + r.pos; + while (r.pos < c2) + m.value.push(r.float()); + } else + m.value.push(r.float()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FloatList; + })(); + + CollectionDef.AnyList = (function() { + + function AnyList(p) { + this.value = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AnyList.prototype.value = $util.emptyArray; + + AnyList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.CollectionDef.AnyList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.value && m.value.length)) + m.value = []; + m.value.push($root.tensorflow.Any.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AnyList; + })(); + + return CollectionDef; + })(); + + tensorflow.SaverDef = (function() { + + function SaverDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SaverDef.prototype.filenameTensorName = ""; + SaverDef.prototype.saveTensorName = ""; + SaverDef.prototype.restoreOpName = ""; + SaverDef.prototype.maxToKeep = 0; + SaverDef.prototype.sharded = false; + SaverDef.prototype.keepCheckpointEveryNHours = 0; + SaverDef.prototype.version = 0; + + SaverDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SaverDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.filenameTensorName = r.string(); + break; + case 2: + m.saveTensorName = r.string(); + break; + case 3: + m.restoreOpName = r.string(); + break; + case 4: + m.maxToKeep = r.int32(); + break; + case 5: + m.sharded = r.bool(); + break; + case 6: + m.keepCheckpointEveryNHours = r.float(); + break; + case 7: + m.version = r.int32(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + SaverDef.CheckpointFormatVersion = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "LEGACY"] = 0; + values[valuesById[1] = "V1"] = 1; + values[valuesById[2] = "V2"] = 2; + return values; + })(); + + return SaverDef; + })(); + + tensorflow.TensorInfo = (function() { + + function TensorInfo(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + TensorInfo.prototype.name = ""; + TensorInfo.prototype.cooSparse = null; + TensorInfo.prototype.dtype = 0; + TensorInfo.prototype.tensorShape = null; + + var $oneOfFields; + + Object.defineProperty(TensorInfo.prototype, "encoding", { + get: $util.oneOfGetter($oneOfFields = ["name", "cooSparse"]), + set: $util.oneOfSetter($oneOfFields) + }); + + TensorInfo.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorInfo(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 4: + m.cooSparse = $root.tensorflow.TensorInfo.CooSparse.decode(r, r.uint32()); + break; + case 2: + m.dtype = r.int32(); + break; + case 3: + m.tensorShape = $root.tensorflow.TensorShape.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + TensorInfo.CooSparse = (function() { + + function CooSparse(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + CooSparse.prototype.valuesTensorName = ""; + CooSparse.prototype.indicesTensorName = ""; + CooSparse.prototype.denseShapeTensorName = ""; + + CooSparse.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.TensorInfo.CooSparse(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.valuesTensorName = r.string(); + break; + case 2: + m.indicesTensorName = r.string(); + break; + case 3: + m.denseShapeTensorName = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return CooSparse; + })(); + + return TensorInfo; + })(); + + tensorflow.SignatureDef = (function() { + + function SignatureDef(p) { + this.inputs = {}; + this.outputs = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SignatureDef.prototype.inputs = $util.emptyObject; + SignatureDef.prototype.outputs = $util.emptyObject; + SignatureDef.prototype.methodName = ""; + + SignatureDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SignatureDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + r.skip().pos++; + if (m.inputs === $util.emptyObject) + m.inputs = {}; + k = r.string(); + r.pos++; + m.inputs[k] = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 2: + r.skip().pos++; + if (m.outputs === $util.emptyObject) + m.outputs = {}; + k = r.string(); + r.pos++; + m.outputs[k] = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 3: + m.methodName = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return SignatureDef; + })(); + + tensorflow.AssetFileDef = (function() { + + function AssetFileDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AssetFileDef.prototype.tensorInfo = null; + AssetFileDef.prototype.filename = ""; + + AssetFileDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.AssetFileDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.tensorInfo = $root.tensorflow.TensorInfo.decode(r, r.uint32()); + break; + case 2: + m.filename = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AssetFileDef; + })(); + + tensorflow.OpDef = (function() { + + function OpDef(p) { + this.inputArg = []; + this.outputArg = []; + this.attr = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpDef.prototype.name = ""; + OpDef.prototype.inputArg = $util.emptyArray; + OpDef.prototype.outputArg = $util.emptyArray; + OpDef.prototype.attr = $util.emptyArray; + OpDef.prototype.deprecation = null; + OpDef.prototype.summary = ""; + OpDef.prototype.description = ""; + OpDef.prototype.isCommutative = false; + OpDef.prototype.isAggregate = false; + OpDef.prototype.isStateful = false; + OpDef.prototype.allowsUninitializedInput = false; + + OpDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + if (!(m.inputArg && m.inputArg.length)) + m.inputArg = []; + m.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(r, r.uint32())); + break; + case 3: + if (!(m.outputArg && m.outputArg.length)) + m.outputArg = []; + m.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(r, r.uint32())); + break; + case 4: + if (!(m.attr && m.attr.length)) + m.attr = []; + m.attr.push($root.tensorflow.OpDef.AttrDef.decode(r, r.uint32())); + break; + case 8: + m.deprecation = $root.tensorflow.OpDef.OpDeprecation.decode(r, r.uint32()); + break; + case 5: + m.summary = r.string(); + break; + case 6: + m.description = r.string(); + break; + case 18: + m.isCommutative = r.bool(); + break; + case 16: + m.isAggregate = r.bool(); + break; + case 17: + m.isStateful = r.bool(); + break; + case 19: + m.allowsUninitializedInput = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + OpDef.ArgDef = (function() { + + function ArgDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + ArgDef.prototype.name = ""; + ArgDef.prototype.description = ""; + ArgDef.prototype.type = 0; + ArgDef.prototype.typeAttr = ""; + ArgDef.prototype.numberAttr = ""; + ArgDef.prototype.typeListAttr = ""; + ArgDef.prototype.isRef = false; + + ArgDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.ArgDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.description = r.string(); + break; + case 3: + m.type = r.int32(); + break; + case 4: + m.typeAttr = r.string(); + break; + case 5: + m.numberAttr = r.string(); + break; + case 6: + m.typeListAttr = r.string(); + break; + case 16: + m.isRef = r.bool(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return ArgDef; + })(); + + OpDef.AttrDef = (function() { + + function AttrDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + AttrDef.prototype.name = ""; + AttrDef.prototype.type = ""; + AttrDef.prototype.defaultValue = null; + AttrDef.prototype.description = ""; + AttrDef.prototype.hasMinimum = false; + AttrDef.prototype.minimum = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + AttrDef.prototype.allowedValues = null; + + AttrDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.AttrDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.name = r.string(); + break; + case 2: + m.type = r.string(); + break; + case 3: + m.defaultValue = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + case 4: + m.description = r.string(); + break; + case 5: + m.hasMinimum = r.bool(); + break; + case 6: + m.minimum = r.int64(); + break; + case 7: + m.allowedValues = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return AttrDef; + })(); + + OpDef.OpDeprecation = (function() { + + function OpDeprecation(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpDeprecation.prototype.version = 0; + OpDeprecation.prototype.explanation = ""; + + OpDeprecation.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpDef.OpDeprecation(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.version = r.int32(); + break; + case 2: + m.explanation = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return OpDeprecation; + })(); + + return OpDef; + })(); + + tensorflow.OpList = (function() { + + function OpList(p) { + this.op = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + OpList.prototype.op = $util.emptyArray; + + OpList.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.OpList(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m.op && m.op.length)) + m.op = []; + m.op.push($root.tensorflow.OpDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return OpList; + })(); + + tensorflow.MetaGraphDef = (function() { + + function MetaGraphDef(p) { + this.collectionDef = {}; + this.signatureDef = {}; + this.assetFileDef = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + MetaGraphDef.prototype.metaInfoDef = null; + MetaGraphDef.prototype.graphDef = null; + MetaGraphDef.prototype.saverDef = null; + MetaGraphDef.prototype.collectionDef = $util.emptyObject; + MetaGraphDef.prototype.signatureDef = $util.emptyObject; + MetaGraphDef.prototype.assetFileDef = $util.emptyArray; + + MetaGraphDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.MetaGraphDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.metaInfoDef = $root.tensorflow.MetaGraphDef.MetaInfoDef.decode(r, r.uint32()); + break; + case 2: + m.graphDef = $root.tensorflow.GraphDef.decode(r, r.uint32()); + break; + case 3: + m.saverDef = $root.tensorflow.SaverDef.decode(r, r.uint32()); + break; + case 4: + r.skip().pos++; + if (m.collectionDef === $util.emptyObject) + m.collectionDef = {}; + k = r.string(); + r.pos++; + m.collectionDef[k] = $root.tensorflow.CollectionDef.decode(r, r.uint32()); + break; + case 5: + r.skip().pos++; + if (m.signatureDef === $util.emptyObject) + m.signatureDef = {}; + k = r.string(); + r.pos++; + m.signatureDef[k] = $root.tensorflow.SignatureDef.decode(r, r.uint32()); + break; + case 6: + if (!(m.assetFileDef && m.assetFileDef.length)) + m.assetFileDef = []; + m.assetFileDef.push($root.tensorflow.AssetFileDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + MetaGraphDef.MetaInfoDef = (function() { + + function MetaInfoDef(p) { + this.tags = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + MetaInfoDef.prototype.metaGraphVersion = ""; + MetaInfoDef.prototype.strippedOpList = null; + MetaInfoDef.prototype.anyInfo = null; + MetaInfoDef.prototype.tags = $util.emptyArray; + MetaInfoDef.prototype.tensorflowVersion = ""; + MetaInfoDef.prototype.tensorflowGitVersion = ""; + + MetaInfoDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.MetaGraphDef.MetaInfoDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.metaGraphVersion = r.string(); + break; + case 2: + m.strippedOpList = $root.tensorflow.OpList.decode(r, r.uint32()); + break; + case 3: + m.anyInfo = $root.tensorflow.Any.decode(r, r.uint32()); + break; + case 4: + if (!(m.tags && m.tags.length)) + m.tags = []; + m.tags.push(r.string()); + break; + case 5: + m.tensorflowVersion = r.string(); + break; + case 6: + m.tensorflowGitVersion = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return MetaInfoDef; + })(); + + return MetaGraphDef; + })(); + + tensorflow.SavedModel = (function() { + + function SavedModel(p) { + this.metaGraphs = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + SavedModel.prototype.savedModelSchemaVersion = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + SavedModel.prototype.metaGraphs = $util.emptyArray; + + SavedModel.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.SavedModel(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.savedModelSchemaVersion = r.int64(); + break; + case 2: + if (!(m.metaGraphs && m.metaGraphs.length)) + m.metaGraphs = []; + m.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return SavedModel; + })(); + + tensorflow.FunctionDefLibrary = (function() { + + function FunctionDefLibrary(p) { + this["function"] = []; + this.gradient = []; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FunctionDefLibrary.prototype["function"] = $util.emptyArray; + FunctionDefLibrary.prototype.gradient = $util.emptyArray; + + FunctionDefLibrary.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.FunctionDefLibrary(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + if (!(m["function"] && m["function"].length)) + m["function"] = []; + m["function"].push($root.tensorflow.FunctionDef.decode(r, r.uint32())); + break; + case 2: + if (!(m.gradient && m.gradient.length)) + m.gradient = []; + m.gradient.push($root.tensorflow.GradientDef.decode(r, r.uint32())); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FunctionDefLibrary; + })(); + + tensorflow.FunctionDef = (function() { + + function FunctionDef(p) { + this.attr = {}; + this.nodeDef = []; + this.ret = {}; + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + FunctionDef.prototype.signature = null; + FunctionDef.prototype.attr = $util.emptyObject; + FunctionDef.prototype.nodeDef = $util.emptyArray; + FunctionDef.prototype.ret = $util.emptyObject; + + FunctionDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.FunctionDef(), k; + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.signature = $root.tensorflow.OpDef.decode(r, r.uint32()); + break; + case 5: + r.skip().pos++; + if (m.attr === $util.emptyObject) + m.attr = {}; + k = r.string(); + r.pos++; + m.attr[k] = $root.tensorflow.AttrValue.decode(r, r.uint32()); + break; + case 3: + if (!(m.nodeDef && m.nodeDef.length)) + m.nodeDef = []; + m.nodeDef.push($root.tensorflow.NodeDef.decode(r, r.uint32())); + break; + case 4: + r.skip().pos++; + if (m.ret === $util.emptyObject) + m.ret = {}; + k = r.string(); + r.pos++; + m.ret[k] = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return FunctionDef; + })(); + + tensorflow.GradientDef = (function() { + + function GradientDef(p) { + if (p) + for (var ks = Object.keys(p), i = 0; i < ks.length; ++i) + if (p[ks[i]] != null) + this[ks[i]] = p[ks[i]]; + } + + GradientDef.prototype.functionName = ""; + GradientDef.prototype.gradientFunc = ""; + + GradientDef.decode = function decode(r, l) { + if (!(r instanceof $Reader)) + r = $Reader.create(r); + var c = l === undefined ? r.len : r.pos + l, m = new $root.tensorflow.GradientDef(); + while (r.pos < c) { + var t = r.uint32(); + switch (t >>> 3) { + case 1: + m.functionName = r.string(); + break; + case 2: + m.gradientFunc = r.string(); + break; + default: + r.skipType(t & 7); + break; + } + } + return m; + }; + + return GradientDef; + })(); + + return tensorflow; + })(); + + var compiled_api = $root; + var compiled_api_1 = compiled_api.tensorflow; + + function getParamValue(paramName, node, tensorMap, context) { + var param = node.params[paramName]; + if (param && param.inputIndex !== undefined) { + if (param.type === 'tensor') { + return getTensor(node.inputNames[param.inputIndex], tensorMap, context); + } + if (param.type === 'tensors') { + var inputs = param.inputIndex === 0 ? + (param.inputParamLength === 0 ? + node.inputNames : + node.inputNames.slice(param.inputIndex, -param.inputParamLength)) : + node.inputNames.splice(param.inputIndex); + return inputs.map(function (name) { return getTensor(name, tensorMap, context); }); + } + var data = Array.prototype.slice.call(getTensor(node.inputNames.slice(param.inputIndex)[0], tensorMap, context) + .dataSync()); + return param.type === 'number' ? data[0] : data; + } + return param && param.value; + } + function getTensor(name, tensorsMap, context) { + var _a = parseNodeName(name), nodeName = _a[0], index = _a[1]; + var contextId = context.currentContextIds.find(function (contextId) { + return !!tensorsMap[getNodeNameWithContextId(nodeName, contextId)]; + }); + return contextId !== undefined ? + tensorsMap[getNodeNameWithContextId(nodeName, contextId)][index] : + undefined; + } + function getNodeNameAndIndex(inputName, context) { + var _a = parseNodeName(inputName), nodeName = _a[0], index = _a[1]; + return [ + getNodeNameWithContextId(nodeName, context && context.currentContextId), + index + ]; + } + function getNodeNameWithContextId(name, contextId) { + return !!contextId ? name + "-" + contextId : name; + } + function parseNodeName(name) { + var index = name.lastIndexOf(':'); + if (index === -1) + return [name, 0]; + var nodeName = name.substring(0, index); + return [nodeName, Number(name.substring(index + 1))]; + } + function split(arr, size) { + var res = []; + for (var i = 0; i < arr.length; i += size) { + res.push(arr.slice(i, i + size)); + } + return res; + } + + var arithmetic = [ + { + "tfOpName": "Add", + "dlOpName": "add", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "BiasAdd", + "dlOpName": "add", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sub", + "dlOpName": "sub", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "RealDiv", + "dlOpName": "div", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Div", + "dlOpName": "div", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "FloorDiv", + "dlOpName": "floorDiv", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Mul", + "dlOpName": "mul", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Maximum", + "dlOpName": "maximum", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Minimum", + "dlOpName": "minimum", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Pow", + "dlOpName": "pow", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "SquaredDifference", + "dlOpName": "squaredDifference", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Mod", + "dlOpName": "mod", + "category": "arithmetic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } + ] + ; + + var arithmetic$1 = /*#__PURE__*/Object.freeze({ + default: arithmetic + }); + + var basic_math = [ + { + "tfOpName": "Abs", + "dlOpName": "abs", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Acos", + "dlOpName": "acos", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Asin", + "dlOpName": "asin", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "atan", + "dlOpName": "atan", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Ceil", + "dlOpName": "ceil", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "ClipByValue", + "dlOpName": "clipByValue", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "clip_value_min", + "dlParamName": "clipValueMin", + "type": "number" + }, + { + "tfParamName": "clip_value_max", + "dlParamName": "clipValueMax", + "type": "number" + } + ] + }, + { + "tfOpName": "Cos", + "dlOpName": "cos", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Cosh", + "dlOpName": "cosh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Elu", + "dlOpName": "elu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Exp", + "dlOpName": "exp", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Floor", + "dlOpName": "floor", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Log", + "dlOpName": "log", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Neg", + "dlOpName": "neg", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Relu", + "dlOpName": "relu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Relu6", + "dlOpName": "clipByValue", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "dlParamName": "clipValueMin", + "type": "number", + "defaultValue": 0 + }, + { + "dlParamName": "clipValueMax", + "type": "number", + "defaultValue": 6 + } + ] + }, + { + "tfOpName": "Selu", + "dlOpName": "selu", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sigmoid", + "dlOpName": "sigmoid", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sin", + "dlOpName": "sin", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sinh", + "dlOpName": "sinh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sqrt", + "dlOpName": "sqrt", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Rsqrt", + "dlOpName": "rsqrt", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Square", + "dlOpName": "square", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Tan", + "dlOpName": "tan", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Tanh", + "dlOpName": "tanh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Sign", + "dlOpName": "sign", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Round", + "dlOpName": "round", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Expm1", + "dlOpName": "expm1", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Log1p", + "dlOpName": "log1p", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reciprocal", + "dlOpName": "reciprocal", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reciprocal", + "dlOpName": "reciprocal", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Softplus", + "dlOpName": "softplus", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Asinh", + "dlOpName": "asinh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Acosh", + "dlOpName": "acosh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Atanh", + "dlOpName": "atanh", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Erf", + "dlOpName": "erf", + "category": "basic_math", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } + ] + ; + + var basicMath = /*#__PURE__*/Object.freeze({ + default: basic_math + }); + + var control = [ + { + "tfOpName": "LoopCond", + "dlOpName": "loopCond", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "pred", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Switch", + "dlOpName": "switch", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "data", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "pred", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Merge", + "dlOpName": "merge", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensors", + "type": "tensors" + } + ] + }, + { + "tfOpName": "Enter", + "dlOpName": "enter", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "frame_name", + "dlParamName": "frameName", + "type": "string" + }, + { + "tfParamName": "is_constant", + "dlParamName": "isConstant", + "type": "bool" + } + ] + }, + { + "tfOpName": "Exit", + "dlOpName": "exit", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NextIteration", + "dlOpName": "nextIteration", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayV3", + "dlOpName": "tensorArray", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "size", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape", + "dlParamName": "elementShape", + "type": "shape" + }, + { + "tfParamName": "dynamic_size", + "dlParamName": "dynamicSize", + "type": "bool" + }, + { + "tfParamName": "clear_after_read", + "dlParamName": "clearAfterRead", + "type": "bool" + }, + { + "tfParamName": "identical_element_shapes", + "dlParamName": "identicalElementShapes", + "type": "bool" + }, + { + "tfParamName": "tensor_array_name", + "dlParamName": "name", + "type": "string" + } + ] + }, + { + "tfOpName": "TensorArrayWriteV3", + "dlOpName": "tensorArrayWrite", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "index", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayReadV3", + "dlOpName": "tensorArrayRead", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "index", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArrayGatherV3", + "dlOpName": "tensorArrayGather", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape", + "dlParamName": "elementShape", + "type": "shape" + } + ] + }, + { + "tfOpName": "TensorArrayScatterV3", + "dlOpName": "tensorArrayScatter", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "tensor", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "TensorArrayConcatV3", + "dlOpName": "tensorArrayConcat", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "element_shape_except0", + "dlParamName": "elementShapeExcept0", + "type": "shape", + "notSupported": true + } + ] + }, + { + "tfOpName": "TensorArraySplitV3", + "dlOpName": "tensorArraySplit", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "lengths", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "flowIn", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "TensorArraySizeV3", + "dlOpName": "tensorArraySize", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "flowIn", + "type": "number" + } + ] + }, + { + "tfOpName": "TensorArrayCloseV3", + "dlOpName": "tensorArrayClose", + "category": "control", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "tensorArrayId", + "type": "number" + } + ] + } + ] + ; + + var control$1 = /*#__PURE__*/Object.freeze({ + default: control + }); + + var convolution = [ + { + "tfOpName": "AvgPool", + "dlOpName": "avgPool", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + }, + { + "tfParamName": "ksize", + "dlParamName": "kernelSize", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "MaxPool", + "dlOpName": "maxPool", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + }, + { + "tfParamName": "ksize", + "dlParamName": "kernelSize", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Conv1D", + "dlOpName": "conv1d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "stride", + "dlParamName": "stride", + "type": "number" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NWC" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "dilation", + "dlParamName": "dilation", + "type": "number", + "defaultValue": 1 + } + ] + }, + { + "tfOpName": "Conv2D", + "dlOpName": "conv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "useCudnnOnGpu", + "dlParamName": "useCudnnOnGpu", + "type": "bool" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Conv2DBackpropInput", + "dlOpName": "conv2dTranspose", + "category": "convolution", + "params": [ + { + "tfInputIndex": 2, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfInputIndex": 0, + "dlParamName": "outputShape", + "type": "number[]" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "DepthwiseConv2d", + "dlOpName": "depthwiseConv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "input", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + }, + { + "tfOpName": "DepthwiseConv2dNative", + "dlOpName": "depthwiseConv2d", + "category": "convolution", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "input", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "filter", + "type": "tensor" + }, + { + "tfParamName": "strides", + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "padding", + "dlParamName": "pad", + "type": "string" + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "defaultValue": "NHWC" + }, + { + "tfParamName": "dilations", + "dlParamName": "dilations", + "type": "number[]" + } + ] + } + ] + ; + + var convolution$1 = /*#__PURE__*/Object.freeze({ + default: convolution + }); + + var creation = [ + { + "tfOpName": "Fill", + "dlOpName": "fill", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfInputIndex": 1, + "dlParamName": "value", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LinSpace", + "dlOpName": "linspace", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "start", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "stop", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "num", + "type": "number" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "OneHot", + "dlOpName": "oneHot", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "depth", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "onValue", + "type": "number", + "defaultValue": 1 + }, + { + "tfInputIndex": 3, + "dlParamName": "offValue", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "notSupported": true + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Ones", + "dlOpName": "ones", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "OnesLike", + "dlOpName": "onesLike", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "RandomUniform", + "dlOpName": "randomUniform", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "minval", + "dlParamName": "minval", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "maxval", + "dlParamName": "maxval", + "type": "number", + "defaultValue": 1 + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "seed", + "dlParamName": "seed", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "seed2", + "dlParamName": "seed2", + "type": "number", + "defaultValue": 0, + "notSupported": true + }, + { + "tfParamName": "T", + "dlParamName": "T", + "type": "number", + "notSupported": true + } + ] + }, + { + "tfOpName": "Range", + "dlOpName": "range", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "start", + "type": "number" + }, + { + "tfInputIndex": 1, + "dlParamName": "stop", + "type": "number" + }, + { + "tfInputIndex": 2, + "dlParamName": "step", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "Tidx", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "truncatedNormal", + "dlOpName": "truncatedNormal", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "means", + "dlParamName": "mean", + "type": "number", + "defaultValue": 0.0 + }, + { + "tfParamName": "stddev", + "dlParamName": "stdDev", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "seed", + "dlParamName": "seed", + "type": "number" + }, + { + "tfParamName": "seed2", + "dlParamName": "seed2", + "type": "number", + "defaultValue": 0, + "notSupported": true + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + }, + { + "tfParamName": "T", + "dlParamName": "T", + "type": "number", + "notSupported": true + } + ] + }, + { + "tfOpName": "Zeros", + "dlOpName": "zeros", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "shape", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "ZerosLike", + "dlOpName": "zerosLike", + "category": "creation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype" + } + ] + } + ] + ; + + var creation$1 = /*#__PURE__*/Object.freeze({ + default: creation + }); + + var dynamic = [ + { + "tfOpName": "NonMaxSuppressionV2", + "dlOpName": "nonMaxSuppression", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV3", + "dlOpName": "nonMaxSuppression", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + }, + { + "tfInputIndex": 4, + "dlParamName": "scoreThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "Where", + "dlOpName": "whereAsync", + "category": "dynamic", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "condition", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } + ] + ; + + var dynamic$1 = /*#__PURE__*/Object.freeze({ + default: dynamic + }); + + var evaluation = [ + { + "tfOpName": "TopKV2", + "dlOpName": "topK", + "category": "evaluation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "k", + "type": "number" + }, + { + "tfParamName": "sorted", + "dlParamName": "sorted", + "type": "bool" + } + ] + } + ] + ; + + var evaluation$1 = /*#__PURE__*/Object.freeze({ + default: evaluation + }); + + var graph = [ + { + "tfOpName": "PlaceholderWithDefault", + "dlOpName": "placeholder", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "default", + "type": "tensor" + }, + { + "tfParamName": "shape", + "dlParamName": "shape", + "type": "shape" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "Placeholder", + "dlOpName": "placeholder", + "category": "graph", + "params": [ + { + "tfParamName": "shape", + "dlParamName": "shape", + "type": "shape" + }, + { + "tfParamName": "dtype", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "Const", + "dlOpName": "const", + "category": "graph" + }, + { + "tfOpName": "Identity", + "dlOpName": "identity", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Snapshot", + "dlOpName": "snapshot", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Rank", + "dlOpName": "rank", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Size", + "dlOpName": "size", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Shape", + "dlOpName": "shape", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "Print", + "dlOpName": "print", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "tfInputParamLength": 1, + "dlParamName": "data", + "type": "tensors" + }, + { + "tfParamName": "message", + "dlParamName": "message", + "type": "string" + }, + { + "tfParamName": "first_n", + "dlParamName": "firstN", + "type": "number", + "notSupprted": true + }, + { + "tfParamName": "summarize", + "dlParamName": "summarize", + "type": "number", + "defaultValue": 3 + } + ] + }, + { + "tfOpName": "NoOp", + "dlOpName": "noop", + "category": "graph", + "params": [] + }, + { + "tfOpName": "StopGradient", + "dlOpName": "stopGradient", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + }, + { + "tfOpName": "FakeQuantWithMinMaxVars", + "dlOpName": "fakeQuantWithMinMaxVars", + "category": "graph", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "min", + "dlParamName": "min", + "type": "number" + }, + { + "tfParamName": "max", + "dlParamName": "max", + "type": "number" + } + ] + } + ] + ; + + var graph$1 = /*#__PURE__*/Object.freeze({ + default: graph + }); + + var image = [ + { + "tfOpName": "ResizeBilinear", + "dlOpName": "resizeBilinear", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "images", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "size", + "type": "number[]" + }, + { + "tfParamName": "align_corners", + "dlParamName": "alignCorners", + "type": "bool" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "ResizeNearestNeighbor", + "dlOpName": "resizeNearestNeighbor", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "images", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "size", + "type": "number[]" + }, + { + "tfParamName": "align_corners", + "dlParamName": "alignCorners", + "type": "bool" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV2", + "dlOpName": "nonMaxSuppression", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + } + ] + }, + { + "tfOpName": "NonMaxSuppressionV3", + "dlOpName": "nonMaxSuppression", + "category": "image", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "boxes", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scores", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "maxOutputSize", + "type": "number" + }, + { + "tfInputIndex": 3, + "dlParamName": "iouThreshold", + "type": "number" + }, + { + "tfInputIndex": 4, + "dlParamName": "scoreThreshold", + "type": "number" + } + ] + } + ] + ; + + var image$1 = /*#__PURE__*/Object.freeze({ + default: image + }); + + var logical = [ + { + "tfOpName": "Equal", + "dlOpName": "equal", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "NotEqual", + "dlOpName": "notEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Greater", + "dlOpName": "greater", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "GreaterEqual", + "dlOpName": "greaterEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Less", + "dlOpName": "less", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LessEqual", + "dlOpName": "lessEqual", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalAnd", + "dlOpName": "logicalAnd", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalNot", + "dlOpName": "logicalNot", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "LogicalOr", + "dlOpName": "logicalOr", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Select", + "dlOpName": "where", + "category": "logical", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "condition", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } + ] + ; + + var logical$1 = /*#__PURE__*/Object.freeze({ + default: logical + }); + + var matrices = [ + { + "tfOpName": "MatMul", + "dlOpName": "matMul", + "category": "matrices", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "a", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "b", + "type": "tensor" + }, + { + "tfParamName": "transpose_a", + "dlParamName": "transposeA", + "type": "bool", + "defaultValue": false + }, + { + "tfParamName": "transpose_b", + "dlParamName": "transposeB", + "type": "bool", + "defaultValue": false + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + }, + { + "tfOpName": "Transpose", + "dlOpName": "transpose", + "category": "matrices", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "perm", + "dlParamName": "perm", + "type": "number[]" + }, + { + "tfParamName": "T", + "dlParamName": "dtype", + "type": "dtype", + "notSupported": true + } + ] + } + ] + ; + + var matrices$1 = /*#__PURE__*/Object.freeze({ + default: matrices + }); + + var normalization = [ + { + "tfOpName": "FusedBatchNorm", + "dlOpName": "batchNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scale", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "offset", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "mean", + "type": "tensor" + }, + { + "tfInputIndex": 4, + "dlParamName": "variance", + "type": "tensor" + }, + { + "tfParamName": "epsilon", + "dlParamName": "epsilon", + "type": "number", + "defaultValue": 0.001 + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "FusedBatchNormV2", + "dlOpName": "batchNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "scale", + "type": "tensor" + }, + { + "tfInputIndex": 2, + "dlParamName": "offset", + "type": "tensor" + }, + { + "tfInputIndex": 3, + "dlParamName": "mean", + "type": "tensor" + }, + { + "tfInputIndex": 4, + "dlParamName": "variance", + "type": "tensor" + }, + { + "tfParamName": "epsilon", + "dlParamName": "epsilon", + "type": "number", + "defaultValue": 0.001 + }, + { + "tfParamName": "data_format", + "dlParamName": "dataFormat", + "type": "string", + "notSupported": true + } + ] + }, + { + "tfOpName": "LRN", + "dlOpName": "localResponseNormalization", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "depth_radius", + "dlParamName": "radius", + "type": "number", + "defaultValue": 5 + }, + { + "tfParamName": "bias", + "dlParamName": "bias", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "alpha", + "dlParamName": "alpha", + "type": "number", + "defaultValue": 1.0 + }, + { + "tfParamName": "beta", + "dlParamName": "beta", + "type": "number", + "defaultValue": 0.5 + } + ] + }, { + "tfOpName": "Softmax", + "dlOpName": "softmax", + "category": "normalization", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + } + ] + } + ] + ; + + var normalization$1 = /*#__PURE__*/Object.freeze({ + default: normalization + }); + + var reduction = [ + { + "tfOpName": "Max", + "dlOpName": "max", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Mean", + "dlOpName": "mean", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Min", + "dlOpName": "min", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Sum", + "dlOpName": "sum", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "All", + "dlOpName": "all", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "Any", + "dlOpName": "any", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number[]" + }, + { + "tfParamName": "keep_dims", + "dlParamName": "keepDims", + "type": "bool" + } + ] + }, + { + "tfOpName": "ArgMax", + "dlOpName": "argMax", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "ArgMin", + "dlOpName": "argMin", + "category": "reduction", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + } + ] + ; + + var reduction$1 = /*#__PURE__*/Object.freeze({ + default: reduction + }); + + var slice_join = [ + { + "tfOpName": "ConcatV2", + "dlOpName": "concat", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "tfInputParamLength": 1, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfInputIndex": -1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Concat", + "dlOpName": "concat", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 1, + "tfInputParamLength": 1, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfInputIndex": 0, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "GatherV2", + "dlOpName": "gather", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Gather", + "dlOpName": "gather", + "category": "slice_join", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "indices", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "validate_indices", + "dlParamName": "validateIndices", + "type": "bool", + "notSupported": true + } + ] + }, + { + "tfOpName": "Reverse", + "dlOpName": "reverse", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "ReverseV2", + "dlOpName": "reverse", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Slice", + "dlOpName": "slice", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "begin", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "size", + "type": "number[]" + } + ] + }, + { + "tfOpName": "StridedSlice", + "dlOpName": "stridedSlice", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "begin", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "end", + "type": "number[]" + }, + { + "tfInputIndex": 3, + "dlParamName": "strides", + "type": "number[]" + }, + { + "tfParamName": "begin_mask", + "dlParamName": "beginMask", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "end_mask", + "dlParamName": "endMask", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Pack", + "dlOpName": "stack", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensors", + "type": "tensors" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Unpack", + "dlOpName": "unstack", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "tfInputParamLength": 0, + "dlParamName": "tensor", + "type": "tensor" + }, + { + "tfParamName": "axis", + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfParamName": "num", + "dlParamName": "num", + "type": "number", + "defaultValue": 0, + "notSupported": true + } + ] + }, + { + "tfOpName": "Tile", + "dlOpName": "tile", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "reps", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Split", + "dlOpName": "split", + "category": "slice_join", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "axis", + "type": "number", + "defaultValue": 0 + }, + { + "tfInputIndex": 1, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "num_split", + "dlParamName": "numOrSizeSplits", + "type": "number", + "defaultValue": 1 + } + ] + } + ] + ; + + var sliceJoin = /*#__PURE__*/Object.freeze({ + default: slice_join + }); + + var transformation = [ + { + "tfOpName": "Cast", + "dlOpName": "cast", + "category": "transformation", + "params": [ + { + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "SrcT", + "dlParamName": "sdtype", + "type": "dtype", + "notSupported": true + }, + { + "tfParamName": "DstT", + "dlParamName": "dtype", + "type": "dtype" + } + ] + }, + { + "tfOpName": "ExpandDims", + "dlOpName": "expandDims", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "tfParamNameDeprecated": "dim", + "dlParamName": "axis", + "type": "number" + } + ] + }, + { + "tfOpName": "Pad", + "dlOpName": "pad", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "padding", + "type": "number[]" + }, + { + "tfParamName": "constant_value", + "dlParamName": "constantValue", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "PadV2", + "dlOpName": "pad", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "padding", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "constantValue", + "type": "number", + "defaultValue": 0 + } + ] + }, + { + "tfOpName": "Reshape", + "dlOpName": "reshape", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "shape", + "type": "number[]" + } + ] + }, + { + "tfOpName": "Squeeze", + "dlOpName": "squeeze", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfParamName": "axis", + "tfParamNameDeprecated": "squeeze_dims", + "dlParamName": "axis", + "type": "number[]" + } + ] + }, + { + "tfOpName": "SpaceToBatchND", + "dlOpName": "spaceToBatchND", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "blockShape", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "paddings", + "type": "number[]" + } + ] + }, + { + "tfOpName": "BatchToSpaceND", + "dlOpName": "batchToSpaceND", + "category": "transformation", + "params": [{ + "tfInputIndex": 0, + "dlParamName": "x", + "type": "tensor" + }, + { + "tfInputIndex": 1, + "dlParamName": "blockShape", + "type": "number[]" + }, + { + "tfInputIndex": 2, + "dlParamName": "crops", + "type": "number[]" + } + ] + } + ] + ; + + var transformation$1 = /*#__PURE__*/Object.freeze({ + default: transformation + }); + + var CONTROL_FLOW_OPS = ['Switch', 'Merge', 'Enter', 'Exit', 'NextIteration']; + var DYNAMIC_SHAPE_OPS = ['NonMaxSuppressionV2', 'NonMaxSuppressionV3', 'Where']; + var OperationMapper = (function () { + function OperationMapper() { + var ops = [ + arithmetic$1, basicMath, control$1, convolution$1, creation$1, dynamic$1, + evaluation$1, logical$1, image$1, graph$1, matrices$1, normalization$1, reduction$1, + sliceJoin, transformation$1 + ]; + var mappersJson = [].concat.apply([], ops.map(function (op) { return op.default ? op.default : op; })); + this.opMappers = mappersJson.reduce(function (map, mapper) { + map[mapper.tfOpName] = mapper; + return map; + }, {}); + } + Object.defineProperty(OperationMapper, "Instance", { + get: function () { + return this._instance || (this._instance = new this()); + }, + enumerable: true, + configurable: true + }); + OperationMapper.prototype.isControlFlow = function (node) { + return CONTROL_FLOW_OPS.some(function (op) { return op === node.op; }); + }; + OperationMapper.prototype.isDynamicShape = function (node) { + return DYNAMIC_SHAPE_OPS.some(function (op) { return op === node.op; }); + }; + OperationMapper.prototype.transformGraph = function (graph$$1) { + var _this = this; + var tfNodes = graph$$1.node; + var withControlFlow = false; + var withDynamicShape = false; + var placeholders = []; + var nodes = tfNodes.reduce(function (map, node) { + map[node.name] = _this.mapNode(node); + if (_this.isControlFlow(node)) + withControlFlow = true; + if (_this.isDynamicShape(node)) + withDynamicShape = true; + if (node.op === 'Placeholder') + placeholders.push(map[node.name]); + return map; + }, {}); + var inputs = []; + var outputs = []; + Object.keys(nodes).forEach(function (key) { + var node = nodes[key]; + node.inputNames.forEach(function (name) { + var nodeName = getNodeNameAndIndex(name)[0]; + node.inputs.push(nodes[nodeName]); + nodes[nodeName].children.push(node); + }); + if (node.inputs.length === 0) + inputs.push(node); + }); + Object.keys(nodes).forEach(function (key) { + var node = nodes[key]; + if (node.children.length === 0) + outputs.push(node); + }); + return { + nodes: nodes, + inputs: inputs, + outputs: outputs, + placeholders: placeholders, + withControlFlow: withControlFlow, + withDynamicShape: withDynamicShape + }; + }; + OperationMapper.prototype.mapNode = function (node) { + var _this = this; + var mapper = this.opMappers[node.op]; + if (mapper === undefined) { + throw new Error('Tensorflow Op is not supported: ' + node.op); + } + var newNode = { + name: node.name, + op: mapper.dlOpName, + category: mapper.category, + inputNames: (node.input || + []).map(function (input) { return input.startsWith('^') ? input.substr(1) : input; }), + inputs: [], + children: [], + params: {} + }; + if (!!mapper.params) { + newNode.params = mapper.params.reduce(function (map, param) { + var inputIndex = param.tfInputIndex; + var inputParamLength = param.tfInputParamLength; + var type = param.type; + var value = undefined; + if (inputIndex === undefined) { + switch (param.type) { + case 'string': + value = _this.getStringParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getStringParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'number': + value = _this.getNumberParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getNumberParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'number[]': + value = _this.getNumericArrayParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getNumericArrayParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'bool': + value = _this.getBoolParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getBoolParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'shape': + value = _this.getTensorShapeParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getTensorShapeParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'dtype': + value = _this.getDtypeParam(node.attr, param.tfParamName, param.defaultValue); + if (value === undefined && !!param.tfParamNameDeprecated) { + value = _this.getDtypeParam(node.attr, param.tfParamNameDeprecated, param.defaultValue); + } + break; + case 'tensor': + case 'tensors': + break; + default: + throw new Error("Unsupported param type: " + param.type + " for op: " + node.op); + } + } + map[param.dlParamName] = { value: value, inputIndex: inputIndex, type: type, inputParamLength: inputParamLength }; + return map; + }, {}); + } + return newNode; + }; + OperationMapper.prototype.getStringParam = function (attrs, name, def, keepCase) { + if (keepCase === void 0) { keepCase = false; } + var param = attrs[name]; + if (param !== undefined) { + var value = String.fromCharCode.apply(null, param.s); + return keepCase ? value : value.toLowerCase(); + } + return def; + }; + OperationMapper.prototype.getBoolParam = function (attrs, name, def) { + var param = attrs[name]; + return param ? param.b : def; + }; + OperationMapper.prototype.getNumberParam = function (attrs, name, def) { + var param = attrs[name]; + var value = (param ? ((param.f !== undefined) ? param.f : param.i) : def); + return (typeof value === 'number') ? value : value['toInt'](); + }; + OperationMapper.prototype.getDtypeParam = function (attrs, name, def) { + var param = attrs[name]; + if (param && param.type) { + switch (param.type) { + case compiled_api_1.DataType.DT_FLOAT: + return 'float32'; + case compiled_api_1.DataType.DT_INT32: + return 'int32'; + case compiled_api_1.DataType.DT_BOOL: + return 'bool'; + default: + return def; + } + } + return def; + }; + OperationMapper.prototype.getTensorShapeParam = function (attrs, name, def) { + var param = attrs[name]; + if (param && param.shape) { + return param.shape.dim.map(function (dim) { + return (typeof dim.size === 'number') ? dim.size : dim.size['toInt'](); + }); + } + return def; + }; + OperationMapper.prototype.getNumericArrayParam = function (attrs, name, def) { + var param = attrs[name]; + if (param) { + return ((param.list.f && param.list.f.length ? param.list.f : + param.list.i)) + .map(function (v) { return (typeof v === 'number') ? v : v['toInt'](); }); + } + return def; + }; + return OperationMapper; + }()); + + var executeOp = function (node, tensorMap, context) { + switch (node.op) { + case 'add': { + return [tfc.add(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'mod': + return [tfc.mod(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + case 'mul': + return [tfc.mul(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + case 'div': { + return [tfc.div(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'floorDiv': { + return [tfc.floorDiv(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'sub': { + return [tfc.sub(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'minimum': { + return [tfc.minimum(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'maximum': { + return [tfc.maximum(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'pow': { + return [tfc.pow(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'squaredDifference': { + return [tfc.squaredDifference(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$1 = function (node, tensorMap, context) { + switch (node.op) { + case 'abs': + return [tfc.abs(getParamValue('x', node, tensorMap, context))]; + case 'acos': + return [tfc.acos(getParamValue('x', node, tensorMap, context))]; + case 'acosh': + return [tfc.acosh(getParamValue('x', node, tensorMap, context))]; + case 'asin': + return [tfc.asin(getParamValue('x', node, tensorMap, context))]; + case 'asinh': + return [tfc.asinh(getParamValue('x', node, tensorMap, context))]; + case 'atan': + return [tfc.atan(getParamValue('x', node, tensorMap, context))]; + case 'atanh': + return [tfc.atanh(getParamValue('x', node, tensorMap, context))]; + case 'ceil': + return [tfc.ceil(getParamValue('x', node, tensorMap, context))]; + case 'cos': + return [tfc.cos(getParamValue('x', node, tensorMap, context))]; + case 'cosh': + return [tfc.cosh(getParamValue('x', node, tensorMap, context))]; + case 'elu': + return [tfc.elu(getParamValue('x', node, tensorMap, context))]; + case 'erf': + return [tfc.erf(getParamValue('x', node, tensorMap, context))]; + case 'exp': + return [tfc.exp(getParamValue('x', node, tensorMap, context))]; + case 'expm1': { + return [tfc.expm1(getParamValue('x', node, tensorMap, context))]; + } + case 'floor': + return [tfc.floor(getParamValue('x', node, tensorMap, context))]; + case 'log': + return [tfc.log(getParamValue('x', node, tensorMap, context))]; + case 'log1p': { + return [tfc.log1p(getParamValue('x', node, tensorMap, context))]; + } + case 'neg': + return [tfc.neg(getParamValue('x', node, tensorMap, context))]; + case 'reciprocal': { + return [tfc.reciprocal(getParamValue('x', node, tensorMap, context))]; + } + case 'relu': + return [tfc.relu(getParamValue('x', node, tensorMap, context))]; + case 'round': { + return [tfc.round(getParamValue('x', node, tensorMap, context))]; + } + case 'selu': + return [tfc.selu(getParamValue('x', node, tensorMap, context))]; + case 'sigmoid': + return [tfc.sigmoid(getParamValue('x', node, tensorMap, context))]; + case 'sin': + return [tfc.sin(getParamValue('x', node, tensorMap, context))]; + case 'sign': { + return [tfc.sign(getParamValue('x', node, tensorMap, context))]; + } + case 'sinh': { + return [tfc.sinh(getParamValue('x', node, tensorMap, context))]; + } + case 'softplus': { + return [tfc.softplus(getParamValue('x', node, tensorMap, context))]; + } + case 'sqrt': { + return [tfc.sqrt(getParamValue('x', node, tensorMap, context))]; + } + case 'square': { + return [tfc.square(getParamValue('x', node, tensorMap, context))]; + } + case 'tanh': { + return [tfc.tanh(getParamValue('x', node, tensorMap, context))]; + } + case 'tan': + return [tfc.tan(getParamValue('x', node, tensorMap, context))]; + case 'clipByValue': + return [tfc.clipByValue(getParamValue('x', node, tensorMap, context), getParamValue('clipValueMin', node, tensorMap, context), getParamValue('clipValueMax', node, tensorMap, context))]; + case 'rsqrt': + return [tfc.div(tfc.scalar(1.0, 'float32'), tfc.sqrt(getTensor(node.inputNames[0], tensorMap, context)))]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var TensorArray = (function () { + function TensorArray(name, dtype, maxSize, elementShape, identicalElementShapes, dynamicSize, clearAfterRead) { + this.name = name; + this.dtype = dtype; + this.maxSize = maxSize; + this.elementShape = elementShape; + this.identicalElementShapes = identicalElementShapes; + this.dynamicSize = dynamicSize; + this.clearAfterRead = clearAfterRead; + this.tensors = []; + this.closed_ = false; + this.id = TensorArray.nextId++; + } + Object.defineProperty(TensorArray.prototype, "closed", { + get: function () { + return this.closed_; + }, + enumerable: true, + configurable: true + }); + TensorArray.prototype.clearAndClose = function () { + this.tensors.forEach(function (tensor) { return tensor.tensor.dispose(); }); + this.tensors = []; + this.closed_ = true; + }; + TensorArray.prototype.size = function () { + return this.tensors.length; + }; + TensorArray.prototype.read = function (index) { + if (this.closed_) { + throw new Error("TensorArray " + this.name + " has already been closed."); + } + if (index < 0 || index >= this.tensors.length) { + throw new Error("Tried to read from index " + index + ", but array size is: " + this.tensors.length); + } + var tensorWithState = this.tensors[index]; + if (tensorWithState.cleared) { + throw new Error("TensorArray " + this.name + ": Could not read index " + index + " twice because it was cleared after a previous read " + + "(perhaps try setting clear_after_read = false?)."); + } + if (this.clearAfterRead) { + tensorWithState.cleared = true; + } + tensorWithState.read = true; + return tensorWithState.tensor; + }; + TensorArray.prototype.readMany = function (indices) { + var _this = this; + return indices.map(function (index) { return _this.read(index); }); + }; + TensorArray.prototype.write = function (index, tensor) { + if (this.closed_) { + throw new Error("TensorArray " + this.name + " has already been closed."); + } + if (index < 0 || !this.dynamicSize && index >= this.maxSize) { + throw new Error("Tried to write to index " + index + ", but array is not resizeable and size is: " + this.maxSize); + } + var t = this.tensors[index] || {}; + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ",\n because the value dtype is " + tensor.dtype + ", but TensorArray dtype is " + this.dtype + "."); + } + if (this.size() === 0 && this.elementShape.length === 0) { + this.elementShape = tensor.shape; + } + tfc.util.assertShapesMatch(this.elementShape, tensor.shape, "TensorArray " + this.name + ": Could not write to TensorArray index " + index + "."); + if (t && t.read) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ", because it has already been read."); + } + if (t && t.written) { + throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + index + ", because it has already been written."); + } + t.tensor = tensor; + t.written = true; + this.tensors[index] = t; + }; + TensorArray.prototype.writeMany = function (indices, tensors) { + var _this = this; + if (indices.length !== tensors.length) { + throw new Error("TensorArray " + this.name + ": could not write multiple tensors," + + ("because the index size: " + indices.length + " is not the same as tensors size: " + tensors.length + ".")); + } + indices.map(function (i, index) { return _this.write(i, tensors[index]); }); + }; + TensorArray.prototype.gather = function (indices, dtype) { + if (!!dtype && dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but gather requested dtype " + dtype); + } + if (!indices) { + indices = []; + for (var i = 0; i < this.size(); i++) { + indices.push(i); + } + } + if (indices.length === 0) { + return tfc.tensor([], [0].concat(this.elementShape)); + } + var tensors = this.readMany(indices); + tfc.util.assertShapesMatch(this.elementShape, tensors[0].shape, 'TensorArray shape mismatch: '); + return tfc.stack(tensors, 0); + }; + TensorArray.prototype.concat = function (dtype) { + if (!!dtype && dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but concat requested dtype " + dtype); + } + if (this.size() === 0) { + return tfc.tensor([], [0].concat(this.elementShape)); + } + var indices = []; + for (var i = 0; i < this.size(); i++) { + indices.push(i); + } + var tensors = this.readMany(indices); + tfc.util.assertShapesMatch(this.elementShape, tensors[0].shape, "TensorArray shape mismatch: tensor array shape (" + this.elementShape + ") vs first tensor shape (" + tensors[0].shape + ")"); + return tfc.concat(tensors, 0); + }; + TensorArray.prototype.scatter = function (indices, tensor) { + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + tensor.dtype); + } + if (indices.length !== tensor.shape[0]) { + throw new Error("Expected len(indices) == tensor.shape[0], but saw: " + indices.length + " vs. " + tensor.shape[0]); + } + var maxIndex = Math.max.apply(Math, indices); + if (!this.dynamicSize && maxIndex >= this.maxSize) { + throw new Error("Max index must be < array size (" + maxIndex + " vs. " + this.maxSize + ")"); + } + this.writeMany(indices, tfc.unstack(tensor, 0)); + }; + TensorArray.prototype.split = function (length, tensor) { + var _this = this; + if (tensor.dtype !== this.dtype) { + throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + tensor.dtype); + } + var totalLength = 0; + var cumulativeLengths = length.map(function (len) { + totalLength += len; + return totalLength; + }); + if (totalLength !== tensor.shape[0]) { + throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n " + totalLength + ", and tensor's shape is: " + tensor.shape); + } + if (!this.dynamicSize && length.length !== this.maxSize) { + throw new Error("TensorArray's size is not equal to the size of lengths (" + this.maxSize + " vs. " + length.length + "), " + + 'and the TensorArray is not marked as dynamically resizeable'); + } + var elementPerRow = totalLength === 0 ? 0 : tensor.size / totalLength; + var tensors = []; + tfc.tidy(function () { + tensor = tensor.reshape([1, totalLength, elementPerRow]); + for (var i = 0; i < length.length; ++i) { + var previousLength = (i === 0) ? 0 : cumulativeLengths[i - 1]; + var indices_1 = [0, previousLength, 0]; + var sizes = [1, length[i], elementPerRow]; + tensors[i] = tfc.slice(tensor, indices_1, sizes).reshape(_this.elementShape); + } + return tensors; + }); + var indices = []; + for (var i = 0; i < length.length; i++) { + indices[i] = i; + } + this.writeMany(indices, tensors); + }; + TensorArray.nextId = 0; + return TensorArray; + }()); + + function executeOp$2(node, tensorMap, context) { + return __awaiter(this, void 0, void 0, function () { + var _a, pred, data_1, inputName, frameId, data, tensor, input, size, dtype, elementShape, dynamicSize, clearAfterRead, identicalElementShapes, name_1, tensorArray, id, index, writeTensor, writeTensorArray, readId, readIndex, readTensorArray, gatherId, gatherIndices, gatherDtype, gatherTensorArray, scatterId, scatterIndices, scatterTensor, scatterTensorArray, concatId, concatTensorArray, concatDtype, splitId, splitTensor, lengths, splitTensorArray, sizeId, sizeTensorArray, closeId, closeTensorArray; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _a = node.op; + switch (_a) { + case 'loopCond': return [3, 1]; + case 'switch': return [3, 2]; + case 'merge': return [3, 4]; + case 'enter': return [3, 5]; + case 'exit': return [3, 6]; + case 'nextIteration': return [3, 7]; + case 'tensorArray': return [3, 8]; + case 'tensorArrayWrite': return [3, 9]; + case 'tensorArrayRead': return [3, 10]; + case 'tensorArrayGather': return [3, 11]; + case 'tensorArrayScatter': return [3, 12]; + case 'tensorArrayConcat': return [3, 13]; + case 'tensorArraySplit': return [3, 14]; + case 'tensorArraySize': return [3, 15]; + case 'tensorArrayClose': return [3, 16]; + } + return [3, 17]; + case 1: return [2, [getParamValue('pred', node, tensorMap, context)]]; + case 2: + pred = getParamValue('pred', node, tensorMap, context); + data_1 = getParamValue('data', node, tensorMap, context); + return [4, pred.data()]; + case 3: return [2, (_b.sent())[0] ? [undefined, data_1] : [data_1, undefined]]; + case 4: + inputName = node.inputNames.find(function (name) { return getTensor(name, tensorMap, context) !== undefined; }); + return [2, inputName ? [getTensor(inputName, tensorMap, context)] : undefined]; + case 5: + frameId = getParamValue('frameName', node, tensorMap, context); + data = getParamValue('tensor', node, tensorMap, context); + context.enterFrame(frameId); + return [2, [data]]; + case 6: + tensor = getParamValue('tensor', node, tensorMap, context); + context.exitFrame(); + return [2, [tensor]]; + case 7: + input = getParamValue('tensor', node, tensorMap, context); + context.nextIteration(); + return [2, [input]]; + case 8: + size = getParamValue('size', node, tensorMap, context); + dtype = getParamValue('dtype', node, tensorMap, context); + elementShape = getParamValue('elementShape', node, tensorMap, context); + dynamicSize = getParamValue('dynamicSize', node, tensorMap, context); + clearAfterRead = getParamValue('clearAfterRead', node, tensorMap, context); + identicalElementShapes = getParamValue('identicalElementShapes', node, tensorMap, context); + name_1 = getParamValue('name', node, tensorMap, context); + tensorArray = new TensorArray(name_1, dtype, size, elementShape, identicalElementShapes, dynamicSize, clearAfterRead); + context.addTensorArray(tensorArray); + return [2, [tfc.scalar(tensorArray.id), tfc.scalar(1.0)]]; + case 9: + id = getParamValue('tensorArrayId', node, tensorMap, context); + index = getParamValue('index', node, tensorMap, context); + writeTensor = getParamValue('tensor', node, tensorMap, context); + writeTensorArray = context.getTensorArray(id); + writeTensorArray.write(index, writeTensor); + return [2, [tfc.scalar(1.0)]]; + case 10: + readId = getParamValue('tensorArrayId', node, tensorMap, context); + readIndex = getParamValue('index', node, tensorMap, context); + readTensorArray = context.getTensorArray(readId); + return [2, [readTensorArray.read(readIndex)]]; + case 11: + gatherId = getParamValue('tensorArrayId', node, tensorMap, context); + gatherIndices = getParamValue('indices', node, tensorMap, context); + gatherDtype = getParamValue('dtype', node, tensorMap, context); + gatherTensorArray = context.getTensorArray(gatherId); + return [2, [gatherTensorArray.gather(gatherIndices, gatherDtype)]]; + case 12: + scatterId = getParamValue('tensorArrayId', node, tensorMap, context); + scatterIndices = getParamValue('indices', node, tensorMap, context); + scatterTensor = getParamValue('tensor', node, tensorMap, context); + scatterTensorArray = context.getTensorArray(scatterId); + scatterTensorArray.scatter(scatterIndices, scatterTensor); + return [2, [tfc.scalar(1.0)]]; + case 13: + concatId = getParamValue('tensorArrayId', node, tensorMap, context); + concatTensorArray = context.getTensorArray(concatId); + concatDtype = getParamValue('dtype', node, tensorMap, context); + return [2, [concatTensorArray.concat(concatDtype)]]; + case 14: + splitId = getParamValue('tensorArrayId', node, tensorMap, context); + splitTensor = getParamValue('tensor', node, tensorMap, context); + lengths = getParamValue('lengths', node, tensorMap, context); + splitTensorArray = context.getTensorArray(splitId); + splitTensorArray.split(lengths, splitTensor); + return [2, [tfc.scalar(1.0)]]; + case 15: + sizeId = getParamValue('tensorArrayId', node, tensorMap, context); + sizeTensorArray = context.getTensorArray(sizeId); + return [2, [tfc.scalar(sizeTensorArray.size(), 'int32')]]; + case 16: + closeId = getParamValue('tensorArrayId', node, tensorMap, context); + closeTensorArray = context.getTensorArray(closeId); + closeTensorArray.clearAndClose(); + return [2, []]; + case 17: throw TypeError("Node type " + node.op + " is not implemented"); + } + }); + }); + } + + var executeOp$3 = function (node, tensorMap, context) { + switch (node.op) { + case 'conv1d': { + var stride = getParamValue('stride', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + var dataFormat = getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + var dilation = getParamValue('dilation', node, tensorMap, context); + return [tfc.conv1d(getParamValue('x', node, tensorMap, context), getParamValue('filter', node, tensorMap, context), stride, pad, dataFormat, dilation)]; + } + case 'conv2d': { + var stride = getParamValue('strides', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + var dataFormat = getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + var dilations = getParamValue('dilations', node, tensorMap, context); + return [tfc.conv2d(getParamValue('x', node, tensorMap, context), getParamValue('filter', node, tensorMap, context), [stride[1], stride[2]], pad, dataFormat, [dilations[0], dilations[1]])]; + } + case 'conv2dTranspose': { + var shape = getParamValue('outputShape', node, tensorMap, context); + var stride = getParamValue('strides', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + return [tfc.conv2dTranspose(getParamValue('x', node, tensorMap, context), getParamValue('filter', node, tensorMap, context), shape, [stride[1], stride[2]], pad)]; + } + case 'depthwiseConv2d': { + var stride = getParamValue('strides', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + var dilations = getParamValue('dilations', node, tensorMap, context); + var dataFormat = getParamValue('dataFormat', node, tensorMap, context) + .toUpperCase(); + return [tfc.depthwiseConv2d(getParamValue('input', node, tensorMap, context), getParamValue('filter', node, tensorMap, context), [stride[1], stride[2]], pad, dataFormat, [dilations[0], dilations[1]])]; + } + case 'avgPool': { + var stride = getParamValue('strides', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + var kernelSize = getParamValue('kernelSize', node, tensorMap, context); + return [tfc.avgPool(getParamValue('x', node, tensorMap, context), [kernelSize[1], kernelSize[2]], [stride[1], stride[2]], pad)]; + } + case 'maxPool': { + var stride = getParamValue('strides', node, tensorMap, context); + var pad = getParamValue('pad', node, tensorMap, context); + var kernelSize = getParamValue('kernelSize', node, tensorMap, context); + return [tfc.maxPool(getParamValue('x', node, tensorMap, context), [kernelSize[1], kernelSize[2]], [stride[1], stride[2]], pad)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$4 = function (node, tensorMap, context) { + switch (node.op) { + case 'fill': { + var shape = getParamValue('shape', node, tensorMap, context); + var value = getParamValue('value', node, tensorMap, context); + return [tfc.fill(shape, value)]; + } + case 'linspace': { + var start = getParamValue('start', node, tensorMap, context); + var stop_1 = getParamValue('stop', node, tensorMap, context); + var num = getParamValue('num', node, tensorMap, context); + return [tfc.linspace(start, stop_1, num)]; + } + case 'oneHot': { + var indices = getParamValue('indices', node, tensorMap, context); + var depth = getParamValue('depth', node, tensorMap, context); + var onValue = getParamValue('onValue', node, tensorMap, context); + var offValue = getParamValue('offValue', node, tensorMap, context); + return [tfc.oneHot(indices, depth, onValue, offValue)]; + } + case 'ones': { + return [tfc.ones(getParamValue('shape', node, tensorMap, context), getParamValue('dtype', node, tensorMap, context))]; + } + case 'onesLike': { + return [tfc.onesLike(getParamValue('x', node, tensorMap, context))]; + } + case 'randomUniform': { + return [tfc.randomUniform(getParamValue('shape', node, tensorMap, context), getParamValue('minval', node, tensorMap, context), getParamValue('maxval', node, tensorMap, context), getParamValue('dtype', node, tensorMap, context))]; + } + case 'range': { + var start = getParamValue('start', node, tensorMap, context); + var stop_2 = getParamValue('stop', node, tensorMap, context); + var step = getParamValue('step', node, tensorMap, context); + return [tfc.range(start, stop_2, step, getParamValue('dtype', node, tensorMap, context))]; + } + case 'truncatedNormal': { + var shape = getParamValue('shape', node, tensorMap, context); + var mean = getParamValue('mean', node, tensorMap, context); + var stdDev = getParamValue('stdDev', node, tensorMap, context); + var seed = getParamValue('seed', node, tensorMap, context); + return [tfc.truncatedNormal(shape, mean, stdDev, getParamValue('dtype', node, tensorMap, context), seed)]; + } + case 'zeros': { + return [tfc.zeros(getParamValue('shape', node, tensorMap, context), getParamValue('dtype', node, tensorMap, context))]; + } + case 'zerosLike': { + return [tfc.zerosLike(getParamValue('x', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var _this = undefined; + var executeOp$5 = function (node, tensorMap, context) { return __awaiter(_this, void 0, void 0, function () { + var _a, boxes, scores, maxOutputSize, iouThreshold, scoreThreshold; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _a = node.op; + switch (_a) { + case 'nonMaxSuppression': return [3, 1]; + case 'whereAsync': return [3, 3]; + } + return [3, 5]; + case 1: + boxes = getParamValue('boxes', node, tensorMap, context); + scores = getParamValue('scores', node, tensorMap, context); + maxOutputSize = getParamValue('maxOutputSize', node, tensorMap, context); + iouThreshold = getParamValue('iouThreshold', node, tensorMap, context); + scoreThreshold = getParamValue('scoreThreshold', node, tensorMap, context); + return [4, tfc.image.nonMaxSuppressionAsync(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold)]; + case 2: return [2, [_b.sent()]]; + case 3: return [4, tfc.whereAsync(getParamValue('condition', node, tensorMap, context))]; + case 4: return [2, [_b.sent()]]; + case 5: throw TypeError("Node type " + node.op + " is not implemented"); + } + }); + }); }; + + var executeOp$6 = function (node, tensorMap, context) { + switch (node.op) { + case 'topK': { + var x = getParamValue('x', node, tensorMap, context); + var k = getParamValue('k', node, tensorMap, context); + var sorted = getParamValue('sorted', node, tensorMap, context); + var result = tfc.topk(x, k, sorted); + return [result.values, result.indices]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$7 = function (node, tensorMap, context) { + switch (node.op) { + case 'const': { + return tensorMap[node.name]; + } + case 'placeholder': + var def = getParamValue('default', node, tensorMap, context); + return [getTensor(node.name, tensorMap, context) || def]; + case 'identity': + case 'stopGradient': + case 'fakeQuantWithMinMaxVars': + return [getParamValue('x', node, tensorMap, context)]; + case 'snapshot': + var snapshot = getParamValue('x', node, tensorMap, context); + return [snapshot.clone()]; + case 'shape': + return [tfc.tensor1d(getParamValue('x', node, tensorMap, context).shape, 'int32')]; + case 'size': + return [tfc.scalar(getParamValue('x', node, tensorMap, context).size, 'int32')]; + case 'rank': + return [tfc.scalar(getParamValue('x', node, tensorMap, context).rank, 'int32')]; + case 'noop': + return []; + case 'print': + var input = getParamValue('x', node, tensorMap, context); + var data = getParamValue('data', node, tensorMap, context); + var message = getParamValue('message', node, tensorMap, context); + var summarize = getParamValue('summarize', node, tensorMap, context); + console.warn('The graph has a tf.print() operation,' + + 'usually used for debugging, which slows down performance.'); + console.log(message); + for (var i = 0; i < data.length; i++) { + console.log(Array.prototype.slice.call(data[0].dataSync()).slice(0, summarize)); + } + return [input]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$8 = function (node, tensorMap, context) { + switch (node.op) { + case 'resizeBilinear': { + var images = getParamValue('images', node, tensorMap, context); + var size = getParamValue('size', node, tensorMap, context); + var alignCorners = getParamValue('alignCorners', node, tensorMap, context); + return [tfc.image.resizeBilinear(images, [size[0], size[1]], alignCorners)]; + } + case 'resizeNearestNeighbor': { + var images = getParamValue('images', node, tensorMap, context); + var size = getParamValue('size', node, tensorMap, context); + var alignCorners = getParamValue('alignCorners', node, tensorMap, context); + return [tfc.image.resizeNearestNeighbor(images, [size[0], size[1]], alignCorners)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$9 = function (node, tensorMap, context) { + switch (node.op) { + case 'equal': { + return [tfc.equal(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'notEqual': { + return [tfc.notEqual(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'greater': { + return [tfc.greater(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'greaterEqual': { + return [tfc.greaterEqual(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'less': { + return [tfc.less(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'lessEqual': { + return [tfc.lessEqual(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'logicalAnd': { + return [tfc.logicalAnd(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'logicalNot': { + return [tfc.logicalNot(getParamValue('a', node, tensorMap, context))]; + } + case 'logicalOr': { + return [tfc.logicalOr(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + case 'where': { + return [tfc.where(getParamValue('condition', node, tensorMap, context), getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$10 = function (node, tensorMap, context) { + switch (node.op) { + case 'matMul': + return [tfc.matMul(getParamValue('a', node, tensorMap, context), getParamValue('b', node, tensorMap, context), getParamValue('transposeA', node, tensorMap, context), getParamValue('transposeB', node, tensorMap, context))]; + case 'transpose': + return [tfc.transpose(getParamValue('x', node, tensorMap, context), getParamValue('perm', node, tensorMap, context))]; + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$11 = function (node, tensorMap, context) { + switch (node.op) { + case 'batchNormalization': { + return [tfc.batchNormalization(getParamValue('x', node, tensorMap, context), getParamValue('mean', node, tensorMap, context), getParamValue('variance', node, tensorMap, context), getParamValue('epsilon', node, tensorMap, context), getParamValue('scale', node, tensorMap, context), getParamValue('offset', node, tensorMap, context))]; + } + case 'localResponseNormalization': { + return [tfc.localResponseNormalization(getParamValue('x', node, tensorMap, context), getParamValue('radius', node, tensorMap, context), getParamValue('bias', node, tensorMap, context), getParamValue('alpha', node, tensorMap, context), getParamValue('beta', node, tensorMap, context))]; + } + case 'softmax': { + return [tfc.softmax(getParamValue('x', node, tensorMap, context))]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$12 = function (node, tensorMap, context) { + switch (node.op) { + case 'max': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.max(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'mean': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.mean(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'min': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.min(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'sum': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.sum(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'all': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.all(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'any': { + var axis = getParamValue('axis', node, tensorMap, context); + var keepDims = getParamValue('keepDims', node, tensorMap, context); + return [tfc.any(getParamValue('x', node, tensorMap, context), axis, keepDims)]; + } + case 'argMax': { + var axis = getParamValue('axis', node, tensorMap, context); + return [tfc.argMax(getParamValue('x', node, tensorMap, context), axis)]; + } + case 'argMin': { + var axis = getParamValue('axis', node, tensorMap, context); + return [tfc.argMin(getParamValue('x', node, tensorMap, context), axis)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$13 = function (node, tensorMap, context) { + switch (node.op) { + case 'concat': { + var axis = getParamValue('axis', node, tensorMap, context); + var inputs = getParamValue('tensors', node, tensorMap, context); + return [tfc.concat(inputs, axis)]; + } + case 'gather': { + var axis = getParamValue('axis', node, tensorMap, context); + var input = getParamValue('x', node, tensorMap, context); + var indices = getParamValue('indices', node, tensorMap, context); + return [tfc.gather(input, indices, axis)]; + } + case 'reverse': { + var axis = getParamValue('axis', node, tensorMap, context); + var input = getParamValue('x', node, tensorMap, context); + return [tfc.reverse(input, axis)]; + } + case 'slice': { + var begin = getParamValue('begin', node, tensorMap, context); + var size = getParamValue('size', node, tensorMap, context); + return [tfc.slice(getParamValue('x', node, tensorMap, context), begin, size)]; + } + case 'stridedSlice': { + var begin = getParamValue('begin', node, tensorMap, context); + var end = getParamValue('end', node, tensorMap, context); + var strides = getParamValue('strides', node, tensorMap, context); + var beginMask = getParamValue('beginMask', node, tensorMap, context); + var endMask = getParamValue('endMask', node, tensorMap, context); + var tensor = getParamValue('x', node, tensorMap, context); + if (begin.length === 1 && tensor.shape.length > 1) { + for (var i = 1; i < tensor.shape.length; i++) { + begin.push(0); + end.push(tensor.shape[i]); + strides.push(strides[0]); + } + } + return [tfc.stridedSlice(tensor, begin, end, strides, beginMask, endMask)]; + } + case 'stack': { + return tfc.tidy(function () { + var axis = getParamValue('axis', node, tensorMap, context); + var tensors = getParamValue('tensors', node, tensorMap, context); + var shape = tensors[0].shape; + var squeezedShape = tensors[0].squeeze().shape; + var mapped = tensors.map(function (tensor) { + var sameShape = tfc.util.arraysEqual(tensor.shape, shape); + if (!sameShape && + !tfc.util.arraysEqual(tensor.squeeze().shape, squeezedShape)) { + throw new Error('the input tensors shape does not match'); + } + return sameShape ? tensor : tensor.reshape(shape); + }); + return [tfc.stack(mapped, axis)]; + }); + } + case 'unstack': { + return tfc.tidy(function () { + var axis = getParamValue('axis', node, tensorMap, context); + var tensor = getParamValue('tensor', node, tensorMap, context); + return tfc.unstack(tensor, axis); + }); + } + case 'tile': { + var reps = getParamValue('reps', node, tensorMap, context); + return [tfc.tile(getParamValue('x', node, tensorMap, context), reps)]; + } + case 'split': { + var axis = getParamValue('axis', node, tensorMap, context); + var numOrSizeSplits = getParamValue('numOrSizeSplits', node, tensorMap, context); + return tfc.split(getParamValue('x', node, tensorMap, context), numOrSizeSplits, axis); + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + var executeOp$14 = function (node, tensorMap, context) { + switch (node.op) { + case 'cast': { + return [tfc.cast(getParamValue('x', node, tensorMap, context), getParamValue('dtype', node, tensorMap, context))]; + } + case 'expandDims': { + var axis = node.params['axis'].value; + return [tfc.expandDims(getParamValue('x', node, tensorMap, context), axis)]; + } + case 'squeeze': { + var axis = node.params['axis'].value; + return [tfc.squeeze(getParamValue('x', node, tensorMap, context), axis)]; + } + case 'reshape': { + return [tfc.reshape(getParamValue('x', node, tensorMap, context), getParamValue('shape', node, tensorMap, context))]; + } + case 'pad': { + return [tfc.pad(getParamValue('x', node, tensorMap, context), split(getParamValue('padding', node, tensorMap, context), 2), getParamValue('constantValue', node, tensorMap, context))]; + } + case 'spaceToBatchND': { + var blockShape = getParamValue('blockShape', node, tensorMap, context); + var paddings = split(getParamValue('paddings', node, tensorMap, context), 2); + return [tfc.spaceToBatchND(getParamValue('x', node, tensorMap, context), blockShape, paddings)]; + } + case 'batchToSpaceND': { + var blockShape = getParamValue('blockShape', node, tensorMap, context); + var crops = split(getParamValue('crops', node, tensorMap, context), 2); + return [tfc.batchToSpaceND(getParamValue('x', node, tensorMap, context), blockShape, crops)]; + } + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + }; + + function executeOp$15(node, tensorMap, context) { + switch (node.category) { + case 'arithmetic': + return executeOp(node, tensorMap, context); + case 'basic_math': + return executeOp$1(node, tensorMap, context); + case 'control': + return executeOp$2(node, tensorMap, context); + case 'convolution': + return executeOp$3(node, tensorMap, context); + case 'creation': + return executeOp$4(node, tensorMap, context); + case 'dynamic': + return executeOp$5(node, tensorMap, context); + case 'evaluation': + return executeOp$6(node, tensorMap, context); + case 'image': + return executeOp$8(node, tensorMap, context); + case 'graph': + return executeOp$7(node, tensorMap, context); + case 'logical': + return executeOp$9(node, tensorMap, context); + case 'matrices': + return executeOp$10(node, tensorMap, context); + case 'normalization': + return executeOp$11(node, tensorMap, context); + case 'reduction': + return executeOp$12(node, tensorMap, context); + case 'slice_join': + return executeOp$13(node, tensorMap, context); + case 'transformation': + return executeOp$14(node, tensorMap, context); + default: + throw TypeError("Node type " + node.op + " is not implemented"); + } + } + + var ExecutionContext = (function () { + function ExecutionContext(weightMap, tensorArrayMap) { + this.weightMap = weightMap; + this.tensorArrayMap = tensorArrayMap; + this.rootContext = { id: 0, frameName: '', iterationId: 0 }; + this.contexts = [this.rootContext]; + this.lastId = 0; + this.generateCurrentContextIds(); + } + ExecutionContext.prototype.newFrame = function (id, frameName) { + return { id: id, frameName: frameName, iterationId: 0 }; + }; + Object.defineProperty(ExecutionContext.prototype, "currentContext", { + get: function () { + return this.contexts; + }, + set: function (contexts) { + if (this.contexts !== contexts) { + this.contexts = contexts; + this.generateCurrentContextIds(); + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(ExecutionContext.prototype, "currentContextId", { + get: function () { + return this._currentContextIds[0]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(ExecutionContext.prototype, "currentContextIds", { + get: function () { + return this._currentContextIds; + }, + enumerable: true, + configurable: true + }); + ExecutionContext.prototype.generateCurrentContextIds = function () { + var names = []; + for (var i = 0; i < this.contexts.length - 1; i++) { + var contexts = this.contexts.slice(0, this.contexts.length - i); + names.push(this.contextIdforContexts(contexts)); + } + names.push(''); + this._currentContextIds = names; + }; + ExecutionContext.prototype.contextIdforContexts = function (contexts) { + return contexts ? + contexts + .map(function (context) { return (context.id === 0 && context.iterationId === 0) ? + '' : + context.frameName + "-" + context.iterationId; }) + .join('/') : + ''; + }; + ExecutionContext.prototype.enterFrame = function (frameId) { + if (this.contexts) { + this.lastId++; + this.contexts = this.contexts.slice(); + this.contexts.push(this.newFrame(this.lastId, frameId)); + this._currentContextIds.unshift(this.contextIdforContexts(this.contexts)); + } + }; + ExecutionContext.prototype.exitFrame = function () { + if (this.contexts && this.contexts.length > 1) { + this.contexts = this.contexts.slice(); + this.contexts.splice(-1); + this.currentContextIds.shift(); + } + else { + throw new Error('Cannot exit frame, the context is empty'); + } + }; + ExecutionContext.prototype.nextIteration = function () { + if (this.contexts && this.contexts.length > 0) { + this.contexts = this.contexts.slice(); + this.lastId++; + var context = Object.assign({}, this.contexts[this.contexts.length - 1]); + context.iterationId += 1; + context.id = this.lastId; + this.contexts.splice(-1, 1, context); + this._currentContextIds.splice(0, 1, this.contextIdforContexts(this.contexts)); + } + else { + throw new Error('Cannot increase frame iteration, the context is empty'); + } + }; + ExecutionContext.prototype.getWeight = function (name) { + return this.weightMap[name]; + }; + ExecutionContext.prototype.addTensorArray = function (tensorArray) { + this.tensorArrayMap[tensorArray.id] = tensorArray; + }; + ExecutionContext.prototype.getTensorArray = function (id) { + return this.tensorArrayMap[id]; + }; + return ExecutionContext; + }()); + + var GraphExecutor = (function () { + function GraphExecutor(graph) { + this.graph = graph; + this.compiledOrder = []; + this._weightMap = {}; + this.placeholders = graph.placeholders; + this._outputs = graph.outputs; + this.compile(); + } + Object.defineProperty(GraphExecutor.prototype, "weightMap", { + get: function () { + return this._weightMap; + }, + set: function (weightMap) { + var weightIds = Object.keys(weightMap).map(function (key) { return weightMap[key].map(function (tensor) { return tensor.id; }); }); + this.weightIds = [].concat.apply([], weightIds); + this._weightMap = weightMap; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "inputs", { + get: function () { + return this.placeholders.map(function (node) { + return { + name: node.name, + shape: node.params['shape'] ? node.params['shape'].value : + undefined, + dtype: node.params['dtype'] ? node.params['dtype'].value : + undefined + }; + }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "outputs", { + get: function () { + return this._outputs.map(function (node) { + return { + name: node.name, + shape: node.params['shape'] ? node.params['shape'].value : + undefined, + dtype: node.params['dtype'] ? node.params['dtype'].value : + undefined + }; + }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "inputNodes", { + get: function () { + return this.placeholders.map(function (node) { return node.name; }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "outputNodes", { + get: function () { + return this.outputs.map(function (node) { return node.name; }); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "isControlFlowModel", { + get: function () { + return this.graph.withControlFlow; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GraphExecutor.prototype, "isDynamicShapeModel", { + get: function () { + return this.graph.withDynamicShape; + }, + enumerable: true, + configurable: true + }); + GraphExecutor.prototype.compile = function () { + if (this.graph.withControlFlow || this.graph.withDynamicShape) { + return; + } + var stack = this.graph.inputs.slice(); + var visited = {}; + while (stack.length > 0) { + var node = stack.pop(); + visited[node.name] = true; + this.compiledOrder.push(node); + node.children.forEach(function (childNode) { + if (!visited[childNode.name] && childNode.inputNames.every(function (name) { + var nodeName = getNodeNameAndIndex(name)[0]; + return visited[nodeName]; + })) { + stack.push(childNode); + } + }); + } + }; + GraphExecutor.prototype.execute = function (inputs, outputs) { + var _this = this; + this.checkInput(inputs); + this.checkInputShapeAndType(inputs); + var tensorArrayMap = {}; + var result = tfc.tidy(function () { + var context = new ExecutionContext(_this._weightMap, tensorArrayMap); + var tensors = _this.compiledOrder.reduce(function (map, node) { + map[node.name] = executeOp$15(node, map, context); + return map; + }, __assign({}, _this.weightMap, inputs)); + return _this.findOutputs(tensors, context, outputs); + }); + return result; + }; + GraphExecutor.prototype.executeAsync = function (inputs, outputs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var tensorArrayMap, context, tensors, results, outputIds, inputIdArray, inputIds; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + this.checkInput(inputs); + this.checkInputShapeAndType(inputs); + tensorArrayMap = {}; + context = new ExecutionContext(this._weightMap, tensorArrayMap); + return [4, this.executeWithControlFlow(inputs, context)]; + case 1: + tensors = _a.sent(); + results = this.findOutputs(tensors, context, outputs); + outputIds = Object.keys(results).map(function (key) { return results[key].id; }); + inputIdArray = Object.keys(inputs).map(function (key) { return inputs[key].map(function (input) { return input.id; }); }); + inputIds = [].concat.apply([], inputIdArray); + Object.keys(tensors).forEach(function (key) { + var tensorArray = tensors[key]; + tensorArray.forEach(function (tensor) { + if (tensor && outputIds.indexOf(tensor.id) === -1 && + inputIds.indexOf(tensor.id) === -1 && + _this.weightIds.indexOf(tensor.id) === -1) { + tensor.dispose(); + } + }); + }); + return [2, results]; + } + }); + }); + }; + GraphExecutor.prototype.executeWithControlFlow = function (inputs, context) { + return __awaiter(this, void 0, void 0, function () { + var stack, tensorMap, added, item, nodeName, tensors, _a, _b; + return __generator(this, function (_c) { + switch (_c.label) { + case 0: + stack = this.graph.inputs.map(function (node) { + return { node: node, contexts: context.currentContext }; + }); + tensorMap = __assign({}, this.weightMap, inputs); + added = {}; + _c.label = 1; + case 1: + if (!(stack.length > 0)) return [3, 3]; + item = stack.pop(); + context.currentContext = item.contexts; + nodeName = ''; + if (item.node.op === 'enter' && + getParamValue('isConstant', item.node, tensorMap, context)) { + nodeName = getNodeNameAndIndex(item.node.name, context)[0]; + } + tensors = executeOp$15(item.node, tensorMap, context); + if (!nodeName) { + nodeName = getNodeNameAndIndex(item.node.name, context)[0]; + } + _a = tensorMap; + _b = nodeName; + return [4, tensors]; + case 2: + _a[_b] = _c.sent(); + item.node.children.forEach(function (childNode) { + var nodeName = getNodeNameAndIndex(childNode.name, context)[0]; + if (!added[nodeName]) { + if (childNode.op === 'merge') { + if (childNode.inputNames.some(function (name) { + return !!getTensor(name, tensorMap, context); + })) { + added[nodeName] = true; + stack.push({ contexts: context.currentContext, node: childNode }); + } + } + else if (childNode.inputNames.every(function (name) { + return !!getTensor(name, tensorMap, context); + })) { + added[nodeName] = true; + stack.push({ contexts: context.currentContext, node: childNode }); + } + } + }); + return [3, 1]; + case 3: return [2, tensorMap]; + } + }); + }); + }; + GraphExecutor.prototype.findOutputs = function (tensorMap, context, outputs) { + if (outputs && !(outputs instanceof Array)) { + outputs = [outputs]; + } + var requestedOutputs = (outputs || this.graph.outputs.map(function (node) { return node.name; })); + return requestedOutputs.reduce(function (map, name) { + map[name] = getTensor(name, tensorMap, context); + return map; + }, {}); + }; + GraphExecutor.prototype.dispose = function () { + var _this = this; + Object.keys(this.weightMap) + .forEach(function (key) { return _this.weightMap[key].forEach(function (tensor) { return tensor.dispose(); }); }); + }; + GraphExecutor.prototype.checkInputShapeAndType = function (inputs) { + this.placeholders.forEach(function (node) { + var input = inputs[node.name][0]; + if (node.params['shape'] && node.params['shape'].value) { + var shape_1 = node.params['shape'].value; + var match = shape_1.length === input.shape.length && + input.shape.every(function (dim, index) { return shape_1[index] === -1 || shape_1[index] === dim; }); + tfc.util.assert(match, "The shape of dict['" + node.name + "'] provided in model.execute(dict) must be [" + shape_1 + "], but was [" + input.shape + "]"); + } + if (node.params['dtype'] && node.params['dtype'].value) { + tfc.util.assert(input.dtype === node.params['dtype'].value, "The dtype of dict['" + node.name + "'] provided in model.execute(dict) must be " + node.params['dtype'].value + ", but was " + input.dtype); + } + }); + }; + GraphExecutor.prototype.checkInput = function (inputs) { + var _this = this; + var inputKeys = Object.keys(inputs); + var missing = []; + var extra = []; + this.inputNodes.forEach(function (name) { + if (inputKeys.indexOf(name) === -1) + missing.push(name); + }); + inputKeys.forEach(function (name) { + if (_this.inputNodes.indexOf(name) === -1) + extra.push(name); + }); + if (missing.length > 0) { + throw new Error("The dict provided in model.execute(dict) has the keys " + + ("[" + inputKeys + "], but is missing the required keys: [" + missing + "].")); + } + if (extra.length > 0) { + throw new Error("The dict provided in model.execute(dict) has " + + ("unused keys: [" + extra + "]. Please provide only the following keys: ") + + ("[" + this.inputNodes + "].")); + } + }; + return GraphExecutor; + }()); + + var FrozenModel = (function () { + function FrozenModel(modelUrl, weightManifestUrl, requestOption) { + this.modelUrl = modelUrl; + this.weightManifestUrl = weightManifestUrl; + this.requestOption = requestOption; + this.version = 'n/a'; + this.pathPrefix = this.getPathPrefix(); + } + Object.defineProperty(FrozenModel.prototype, "modelVersion", { + get: function () { + return this.version; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "inputNodes", { + get: function () { + return this.executor.inputNodes; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "outputNodes", { + get: function () { + return this.executor.outputNodes; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "inputs", { + get: function () { + return this.executor.inputs; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "outputs", { + get: function () { + return this.executor.outputs; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(FrozenModel.prototype, "weights", { + get: function () { + return this.executor.weightMap; + }, + enumerable: true, + configurable: true + }); + FrozenModel.prototype.getPathPrefix = function () { + var url$$1 = parse(this.weightManifestUrl); + var segments = url$$1.pathname.split('/'); + segments.splice(-1); + url$$1.pathname = segments.join('/'); + return format(url$$1) + '/'; + }; + FrozenModel.prototype.loadRemoteProtoFile = function () { + return __awaiter(this, void 0, void 0, function () { + var response, _a, _b, _c, error_1; + return __generator(this, function (_d) { + switch (_d.label) { + case 0: + _d.trys.push([0, 3, , 4]); + return [4, fetch(this.modelUrl, this.requestOption)]; + case 1: + response = _d.sent(); + _b = (_a = compiled_api_1.GraphDef).decode; + _c = Uint8Array.bind; + return [4, response.arrayBuffer()]; + case 2: return [2, _b.apply(_a, [new (_c.apply(Uint8Array, [void 0, _d.sent()]))()])]; + case 3: + error_1 = _d.sent(); + throw new Error(this.modelUrl + " not found. " + error_1); + case 4: return [2]; + } + }); + }); + }; + FrozenModel.prototype.loadWeightManifest = function () { + return __awaiter(this, void 0, void 0, function () { + var manifest, _a, error_2; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _b.trys.push([0, 3, , 4]); + return [4, fetch(this.weightManifestUrl, this.requestOption)]; + case 1: + manifest = _b.sent(); + _a = this; + return [4, manifest.clone().json()]; + case 2: + _a.weightManifest = _b.sent(); + return [3, 4]; + case 3: + error_2 = _b.sent(); + throw new Error(this.weightManifestUrl + " not found. " + error_2); + case 4: return [2]; + } + }); + }); + }; + FrozenModel.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var graphPromise, manifestPromise, graph, weightMap; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + graphPromise = this.loadRemoteProtoFile(); + manifestPromise = this.loadWeightManifest(); + return [4, Promise.all([graphPromise, manifestPromise])]; + case 1: + graph = (_a.sent())[0]; + this.version = graph.versions.producer + "." + graph.versions.minConsumer; + return [4, tfc.io.loadWeights(this.weightManifest, this.pathPrefix, undefined, this.requestOption)]; + case 2: + weightMap = _a.sent(); + this.executor = + new GraphExecutor(OperationMapper.Instance.transformGraph(graph)); + this.executor.weightMap = this.convertTensorMapToTensorsMap(weightMap); + return [2, true]; + } + }); + }); + }; + FrozenModel.prototype.predict = function (inputs, config) { + return this.execute(inputs, this.outputNodes); + }; + FrozenModel.prototype.constructTensorMap = function (inputs) { + var inputArray = inputs instanceof tfc.Tensor ? [inputs] : inputs; + if (inputArray.length !== this.inputNodes.length) { + throw new Error('Input tensor count mismatch,' + + ("the frozen model has " + this.inputNodes.length + " placeholders, ") + + ("while there are " + inputArray.length + " input tensors.")); + } + return this.inputNodes.reduce(function (map, inputName, i) { + map[inputName] = inputArray[i]; + return map; + }, {}); + }; + FrozenModel.prototype.execute = function (inputs, outputs) { + outputs = outputs || this.outputNodes; + if (inputs instanceof tfc.Tensor || Array.isArray(inputs)) { + inputs = this.constructTensorMap(inputs); + } + if (this.executor.isControlFlowModel || this.executor.isDynamicShapeModel) { + throw new Error('The model contains control flow or dynamic shape ops, ' + + 'please use executeAsync method'); + } + var result = this.executor.execute(this.convertTensorMapToTensorsMap(inputs), outputs); + var keys = Object.keys(result); + return (Array.isArray(outputs) && outputs.length > 1) ? + outputs.map(function (node) { return result[node]; }) : + result[keys[0]]; + }; + FrozenModel.prototype.executeAsync = function (inputs, outputs) { + return __awaiter(this, void 0, void 0, function () { + var result, keys; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.executor.isControlFlowModel && + this.executor.isDynamicShapeModel)) { + throw new Error('The model does not contain control flow or dynamic shape ops, ' + + 'please use execute method for better performance.'); + } + outputs = outputs || this.outputNodes; + if (inputs instanceof tfc.Tensor || Array.isArray(inputs)) { + inputs = this.constructTensorMap(inputs); + } + return [4, this.executor.executeAsync(this.convertTensorMapToTensorsMap(inputs), outputs)]; + case 1: + result = _a.sent(); + keys = Object.keys(result); + return [2, Array.isArray(outputs) && outputs.length > 1 ? + outputs.map(function (node) { return result[node]; }) : + result[keys[0]]]; + } + }); + }); + }; + FrozenModel.prototype.convertTensorMapToTensorsMap = function (map) { + return Object.keys(map).reduce(function (newMap, key) { + newMap[key] = [map[key]]; + return newMap; + }, {}); + }; + FrozenModel.prototype.dispose = function () { + this.executor.dispose(); + }; + return FrozenModel; + }()); + function loadFrozenModel(modelUrl, weightsManifestUrl, requestOption) { + return __awaiter(this, void 0, void 0, function () { + var model; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + model = new FrozenModel(modelUrl, weightsManifestUrl, requestOption); + return [4, model.load()]; + case 1: + _a.sent(); + return [2, model]; + } + }); + }); + } + + var version = '0.5.5'; + + exports.FrozenModel = FrozenModel; + exports.loadFrozenModel = loadFrozenModel; + exports.version_converter = version; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); diff --git a/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.min.js b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.min.js new file mode 100644 index 0000000..41e538f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/tf-converter.min.js @@ -0,0 +1,17 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@tensorflow/tfjs-core")):"function"==typeof define&&define.amd?define(["exports","@tensorflow/tfjs-core"],t):t(e.tf=e.tf||{},e.tf)}(this,function(exports,tfc){"use strict";var __assign=Object.assign||function(e){for(var t,a=1,r=arguments.length;a0&&n[n.length-1])&&(6===o[0]||2===o[0])){s=0;continue}if(3===o[0]&&(!n||o[1]>n[0]&&o[1]= 0x80 (not a basic code point)","invalid-input":"Invalid input"},x=u-l,v=Math.floor,I=String.fromCharCode;function O(e){throw RangeError(b[e])}function w(e,t){for(var a=e.length,r=[];a--;)r[a]=t(e[a]);return r}function V(e,t){var a=e.split("@"),r="";return a.length>1&&(r=a[0]+"@",e=a[1]),r+w((e=e.replace(P,".")).split("."),t).join(".")}function T(e){for(var t,a,r=[],n=0,o=e.length;n=55296&&t<=56319&&n65535&&(t+=I((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+=I(e)}).join("")}function _(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function A(e,t,a){var r=0;for(e=a?v(e/f):e>>1,e+=v(e/t);e>x*m>>1;r+=u)e=v(e/x);return v(r+(x+1)*e/(e+d))}function $(e){var t,a,r,n,o,s,i,d,f,g,N,P=[],b=e.length,x=0,I=h,w=c;for((a=e.lastIndexOf(y))<0&&(a=0),r=0;r=128&&O("not-basic"),P.push(e.charCodeAt(r));for(n=a>0?a+1:0;n=b&&O("invalid-input"),((d=(N=e.charCodeAt(n++))-48<10?N-22:N-65<26?N-65:N-97<26?N-97:u)>=u||d>v((p-x)/s))&&O("overflow"),x+=d*s,!(d<(f=i<=w?l:i>=w+m?m:i-w));i+=u)s>v(p/(g=u-f))&&O("overflow"),s*=g;w=A(x-o,t=P.length+1,0==o),v(x/t)>p-I&&O("overflow"),I+=v(x/t),x%=t,P.splice(x++,0,I)}return k(P)}function S(e){var t,a,r,n,o,s,i,d,f,g,N,P,b,x,w,V=[];for(P=(e=T(e)).length,t=h,a=0,o=c,s=0;s=t&&Nv((p-a)/(b=r+1))&&O("overflow"),a+=(i-t)*b,t=i,s=0;sp&&O("overflow"),N==t){for(d=a,f=u;!(d<(g=f<=o?l:f>=o+m?m:f-o));f+=u)w=d-g,x=u-g,V.push(I(_(g+w%x,0))),d=v(w/x);V.push(I(_(d,0))),o=A(a,b,r==n),a=0,++r}++a,++t}return V.join("")}if(s={version:"1.3.2",ucs2:{decode:T,encode:k},decode:$,encode:S,toASCII:function(e){return V(e,function(e){return N.test(e)?"xn--"+S(e):e})},toUnicode:function(e){return V(e,function(e){return g.test(e)?$(e.slice(4).toLowerCase()):e})}},r&&n)if(e.exports==r)n.exports=s;else for(i in s)s.hasOwnProperty(i)&&(r[i]=s[i]);else a.punycode=s}(commonjsGlobal)}),util={isString:function(e){return"string"==typeof e},isObject:function(e){return"object"==typeof e&&null!==e},isNull:function(e){return null===e},isNullOrUndefined:function(e){return null==e}};function hasOwnProperty(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var decode=function(e,t,a,r){t=t||"&",a=a||"=";var n={};if("string"!=typeof e||0===e.length)return n;var o=/\+/g;e=e.split(t);var s=1e3;r&&"number"==typeof r.maxKeys&&(s=r.maxKeys);var i=e.length;s>0&&i>s&&(i=s);for(var p=0;p=0?(u=f.substr(0,c),l=f.substr(c+1)):(u=f,l=""),m=decodeURIComponent(u),d=decodeURIComponent(l),hasOwnProperty(n,m)?Array.isArray(n[m])?n[m].push(d):n[m]=[n[m],d]:n[m]=d}return n},stringifyPrimitive=function(e){switch(typeof e){case"string":return e;case"boolean":return e?"true":"false";case"number":return isFinite(e)?e:"";default:return""}},encode=function(e,t,a,r){return t=t||"&",a=a||"=",null===e&&(e=void 0),"object"==typeof e?Object.keys(e).map(function(r){var n=encodeURIComponent(stringifyPrimitive(r))+a;return Array.isArray(e[r])?e[r].map(function(e){return n+encodeURIComponent(stringifyPrimitive(e))}).join(t):n+encodeURIComponent(stringifyPrimitive(e[r]))}).join(t):r?encodeURIComponent(stringifyPrimitive(r))+a+encodeURIComponent(stringifyPrimitive(e)):""},querystring=createCommonjsModule(function(e,t){t.decode=t.parse=decode,t.encode=t.stringify=encode}),querystring_1=querystring.decode,querystring_2=querystring.parse,querystring_3=querystring.encode,querystring_4=querystring.stringify,parse=urlParse,format=urlFormat;function Url(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}var protocolPattern=/^([a-z0-9.+-]+:)/i,portPattern=/:[0-9]*$/,simplePathPattern=/^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/,delims=["<",">",'"',"`"," ","\r","\n","\t"],unwise=["{","}","|","\\","^","`"].concat(delims),autoEscape=["'"].concat(unwise),nonHostChars=["%","/","?",";","#"].concat(autoEscape),hostEndingChars=["/","?","#"],hostnameMaxLen=255,hostnamePartPattern=/^[+a-z0-9A-Z_-]{0,63}$/,hostnamePartStart=/^([+a-z0-9A-Z_-]{0,63})(.*)$/,unsafeProtocol={javascript:!0,"javascript:":!0},hostlessProtocol={javascript:!0,"javascript:":!0},slashedProtocol={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,"http:":!0,"https:":!0,"ftp:":!0,"gopher:":!0,"file:":!0};function urlParse(e,t,a){if(e&&util.isObject(e)&&e instanceof Url)return e;var r=new Url;return r.parse(e,t,a),r}function urlFormat(e){return util.isString(e)&&(e=urlParse(e)),e instanceof Url?e.format():Url.prototype.format.call(e)}Url.prototype.parse=function(e,t,a){if(!util.isString(e))throw new TypeError("Parameter 'url' must be a string, not "+typeof e);var r=e.indexOf("?"),n=-1!==r&&r127?b+="x":b+=P[x];if(!b.match(hostnamePartPattern)){var I=g.slice(0,c),O=g.slice(c+1),w=P.match(hostnamePartStart);w&&(I.push(w[1]),O.unshift(w[2])),O.length&&(s="/"+O.join(".")+s),this.hostname=I.join(".");break}}}this.hostname.length>hostnameMaxLen?this.hostname="":this.hostname=this.hostname.toLowerCase(),y||(this.hostname=punycode.toASCII(this.hostname));var V=this.port?":"+this.port:"",T=this.hostname||"";this.host=T+V,this.href+=this.host,y&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),"/"!==s[0]&&(s="/"+s))}if(!unsafeProtocol[u])for(c=0,N=autoEscape.length;c0)&&a.host.split("@"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift());return a.search=e.search,a.query=e.query,util.isNull(a.pathname)&&util.isNull(a.search)||(a.path=(a.pathname?a.pathname:"")+(a.search?a.search:"")),a.href=a.format(),a}if(!P.length)return a.pathname=null,a.search?a.path="/"+a.search:a.path=null,a.href=a.format(),a;for(var x=P.slice(-1)[0],v=(a.host||e.host||P.length>1)&&("."===x||".."===x)||""===x,I=0,O=P.length;O>=0;O--)"."===(x=P[O])?P.splice(O,1):".."===x?(P.splice(O,1),I++):I&&(P.splice(O,1),I--);if(!g&&!N)for(;I--;I)P.unshift("..");!g||""===P[0]||P[0]&&"/"===P[0].charAt(0)||P.unshift(""),v&&"/"!==P.join("/").substr(-1)&&P.push("");var w,V=""===P[0]||P[0]&&"/"===P[0].charAt(0);b&&(a.hostname=a.host=V?"":P.length?P.shift():"",(w=!!(a.host&&a.host.indexOf("@")>0)&&a.host.split("@"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift()));return(g=g||a.host&&P.length)&&!V&&P.unshift(""),P.length?a.pathname=P.join("/"):(a.pathname=null,a.path=null),util.isNull(a.pathname)&&util.isNull(a.search)||(a.path=(a.pathname?a.pathname:"")+(a.search?a.search:"")),a.auth=e.auth||a.auth,a.slashes=a.slashes||e.slashes,a.href=a.format(),a},Url.prototype.parseHost=function(){var e=this.host,t=portPattern.exec(e);t&&(":"!==(t=t[0])&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)};var aspromise=asPromise;function asPromise(e,t){for(var a=new Array(arguments.length-1),r=0,n=2,o=!0;n1&&"="===e.charAt(t);)++a;return Math.ceil(3*e.length)/4-a};for(var r=new Array(64),n=new Array(123),o=0;o<64;)n[r[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;a.encode=function(e,t,a){for(var n,o=null,s=[],i=0,p=0;t>2],n=(3&u)<<4,p=1;break;case 1:s[i++]=r[n|u>>4],n=(15&u)<<2,p=2;break;case 2:s[i++]=r[n|u>>6],s[i++]=r[63&u],p=0}i>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,s)),i=0)}return p&&(s[i++]=r[n],s[i++]=61,1===p&&(s[i++]=61)),o?(i&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))};a.decode=function(e,t,a){for(var r,o=a,s=0,i=0;i1)break;if(void 0===(p=n[p]))throw Error("invalid encoding");switch(s){case 0:r=p,s=1;break;case 1:t[a++]=r<<2|(48&p)>>4,r=p,s=2;break;case 2:t[a++]=(15&r)<<4|(60&p)>>2,r=p,s=3;break;case 3:t[a++]=(3&r)<<6|p,s=0}}if(1===s)throw Error("invalid encoding");return a-o},a.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}}),eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(e,t,a){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:a||this}),this},EventEmitter.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var a=this._listeners[e],r=0;r0?0:2147483648,a,r);else if(isNaN(t))e(2143289344,a,r);else if(t>3.4028234663852886e38)e((n<<31|2139095040)>>>0,a,r);else if(t<1.1754943508222875e-38)e((n<<31|Math.round(t/1.401298464324817e-45))>>>0,a,r);else{var o=Math.floor(Math.log(t)/Math.LN2);e((n<<31|o+127<<23|8388607&Math.round(t*Math.pow(2,-o)*8388608))>>>0,a,r)}}function a(e,t,a){var r=e(t,a),n=2*(r>>31)+1,o=r>>>23&255,s=8388607&r;return 255===o?s?NaN:n*(1/0):0===o?1.401298464324817e-45*n*s:n*Math.pow(2,o-150)*(s+8388608)}e.writeFloatLE=t.bind(null,writeUintLE),e.writeFloatBE=t.bind(null,writeUintBE),e.readFloatLE=a.bind(null,readUintLE),e.readFloatBE=a.bind(null,readUintBE)}(),"undefined"!=typeof Float64Array?function(){var t=new Float64Array([-0]),a=new Uint8Array(t.buffer),r=128===a[7];function n(e,r,n){t[0]=e,r[n]=a[0],r[n+1]=a[1],r[n+2]=a[2],r[n+3]=a[3],r[n+4]=a[4],r[n+5]=a[5],r[n+6]=a[6],r[n+7]=a[7]}function o(e,r,n){t[0]=e,r[n]=a[7],r[n+1]=a[6],r[n+2]=a[5],r[n+3]=a[4],r[n+4]=a[3],r[n+5]=a[2],r[n+6]=a[1],r[n+7]=a[0]}function s(e,r){return a[0]=e[r],a[1]=e[r+1],a[2]=e[r+2],a[3]=e[r+3],a[4]=e[r+4],a[5]=e[r+5],a[6]=e[r+6],a[7]=e[r+7],t[0]}function i(e,r){return a[7]=e[r],a[6]=e[r+1],a[5]=e[r+2],a[4]=e[r+3],a[3]=e[r+4],a[2]=e[r+5],a[1]=e[r+6],a[0]=e[r+7],t[0]}e.writeDoubleLE=r?n:o,e.writeDoubleBE=r?o:n,e.readDoubleLE=r?s:i,e.readDoubleBE=r?i:s}():function(){function t(e,t,a,r,n,o){var s=r<0?1:0;if(s&&(r=-r),0===r)e(0,n,o+t),e(1/r>0?0:2147483648,n,o+a);else if(isNaN(r))e(0,n,o+t),e(2146959360,n,o+a);else if(r>1.7976931348623157e308)e(0,n,o+t),e((s<<31|2146435072)>>>0,n,o+a);else{var i;if(r<2.2250738585072014e-308)e((i=r/5e-324)>>>0,n,o+t),e((s<<31|i/4294967296)>>>0,n,o+a);else{var p=Math.floor(Math.log(r)/Math.LN2);1024===p&&(p=1023),e(4503599627370496*(i=r*Math.pow(2,-p))>>>0,n,o+t),e((s<<31|p+1023<<20|1048576*i&1048575)>>>0,n,o+a)}}}function a(e,t,a,r,n){var o=e(r,n+t),s=e(r,n+a),i=2*(s>>31)+1,p=s>>>20&2047,u=4294967296*(1048575&s)+o;return 2047===p?u?NaN:i*(1/0):0===p?5e-324*i*u:i*Math.pow(2,p-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,writeUintLE,0,4),e.writeDoubleBE=t.bind(null,writeUintBE,4,0),e.readDoubleLE=a.bind(null,readUintLE,0,4),e.readDoubleBE=a.bind(null,readUintBE,4,0)}(),e}function writeUintLE(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}function writeUintBE(e,t,a){t[a]=e>>>24,t[a+1]=e>>>16&255,t[a+2]=e>>>8&255,t[a+3]=255&e}function readUintLE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function readUintBE(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(e){}return null}var utf8_1=createCommonjsModule(function(e,t){var a=t;a.length=function(e){for(var t=0,a=0,r=0;r191&&r<224?o[s++]=(31&r)<<6|63&e[t++]:r>239&&r<365?(r=((7&r)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,o[s++]=55296+(r>>10),o[s++]=56320+(1023&r)):o[s++]=(15&r)<<12|(63&e[t++])<<6|63&e[t++],s>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,o)),s=0);return n?(s&&n.push(String.fromCharCode.apply(String,o.slice(0,s))),n.join("")):String.fromCharCode.apply(String,o.slice(0,s))},a.write=function(e,t,a){for(var r,n,o=a,s=0;s>6|192,t[a++]=63&r|128):55296==(64512&r)&&56320==(64512&(n=e.charCodeAt(s+1)))?(r=65536+((1023&r)<<10)+(1023&n),++s,t[a++]=r>>18|240,t[a++]=r>>12&63|128,t[a++]=r>>6&63|128,t[a++]=63&r|128):(t[a++]=r>>12|224,t[a++]=r>>6&63|128,t[a++]=63&r|128);return a-o}}),pool_1=pool;function pool(e,t,a){var r=a||8192,n=r>>>1,o=null,s=r;return function(a){if(a<1||a>n)return e(a);s+a>r&&(o=e(r),s=0);var i=t.call(o,s,s+=a);return 7&s&&(s=1+(7|s)),i}}var longbits=LongBits;function LongBits(e,t){this.lo=e>>>0,this.hi=t>>>0}var zero=LongBits.zero=new LongBits(0,0);zero.toNumber=function(){return 0},zero.zzEncode=zero.zzDecode=function(){return this},zero.length=function(){return 1};var zeroHash=LongBits.zeroHash="\0\0\0\0\0\0\0\0";LongBits.fromNumber=function(e){if(0===e)return zero;var t=e<0;t&&(e=-e);var a=e>>>0,r=(e-a)/4294967296>>>0;return t&&(r=~r>>>0,a=~a>>>0,++a>4294967295&&(a=0,++r>4294967295&&(r=0))),new LongBits(a,r)},LongBits.from=function(e){if("number"==typeof e)return LongBits.fromNumber(e);if(minimal.isString(e)){if(!minimal.Long)return LongBits.fromNumber(parseInt(e,10));e=minimal.Long.fromString(e)}return e.low||e.high?new LongBits(e.low>>>0,e.high>>>0):zero},LongBits.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,a=~this.hi>>>0;return t||(a=a+1>>>0),-(t+4294967296*a)}return this.lo+4294967296*this.hi},LongBits.prototype.toLong=function(e){return minimal.Long?new minimal.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var charCodeAt=String.prototype.charCodeAt;LongBits.fromHash=function(e){return e===zeroHash?zero:new LongBits((charCodeAt.call(e,0)|charCodeAt.call(e,1)<<8|charCodeAt.call(e,2)<<16|charCodeAt.call(e,3)<<24)>>>0,(charCodeAt.call(e,4)|charCodeAt.call(e,5)<<8|charCodeAt.call(e,6)<<16|charCodeAt.call(e,7)<<24)>>>0)},LongBits.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},LongBits.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},LongBits.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},LongBits.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,a=this.hi>>>24;return 0===a?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:a<128?9:10};var minimal=createCommonjsModule(function(e,t){var a=t;function r(e,t,a){for(var r=Object.keys(t),n=0;n0)},a.Buffer=function(){try{var e=a.inquire("buffer").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),a._Buffer_from=null,a._Buffer_allocUnsafe=null,a.newBuffer=function(e){return"number"==typeof e?a.Buffer?a._Buffer_allocUnsafe(e):new a.Array(e):a.Buffer?a._Buffer_from(e):"undefined"==typeof Uint8Array?e:new Uint8Array(e)},a.Array="undefined"!=typeof Uint8Array?Uint8Array:Array,a.Long=commonjsGlobal.dcodeIO&&commonjsGlobal.dcodeIO.Long||a.inquire("long"),a.key2Re=/^true|false|0|1$/,a.key32Re=/^-?(?:0|[1-9][0-9]*)$/,a.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,a.longToHash=function(e){return e?a.LongBits.from(e).toHash():a.LongBits.zeroHash},a.longFromHash=function(e,t){var r=a.LongBits.fromHash(e);return a.Long?a.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},a.merge=r,a.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},a.newError=n,a.ProtocolError=n("ProtocolError"),a.oneOfGetter=function(e){for(var t={},a=0;a-1;--a)if(1===t[e[a]]&&void 0!==this[e[a]]&&null!==this[e[a]])return e[a]}},a.oneOfSetter=function(e){return function(t){for(var a=0;a127;)t[a++]=127&e|128,e>>>=7;t[a]=e}function VarintOp(e,t){this.len=e,this.next=void 0,this.val=t}function writeVarint64(e,t,a){for(;e.hi;)t[a++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[a++]=127&e.lo|128,e.lo=e.lo>>>7;t[a++]=e.lo}function writeFixed32(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}Writer.create=minimal.Buffer?function(){return(Writer.create=function(){return new BufferWriter})()}:function(){return new Writer},Writer.alloc=function(e){return new minimal.Array(e)},minimal.Array!==Array&&(Writer.alloc=minimal.pool(Writer.alloc,minimal.Array.prototype.subarray)),Writer.prototype._push=function(e,t,a){return this.tail=this.tail.next=new Op(e,t,a),this.len+=t,this},VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new VarintOp((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},Writer.prototype.int32=function(e){return e<0?this._push(writeVarint64,10,LongBits$1.fromNumber(e)):this.uint32(e)},Writer.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},Writer.prototype.uint64=function(e){var t=LongBits$1.from(e);return this._push(writeVarint64,t.length(),t)},Writer.prototype.int64=Writer.prototype.uint64,Writer.prototype.sint64=function(e){var t=LongBits$1.from(e).zzEncode();return this._push(writeVarint64,t.length(),t)},Writer.prototype.bool=function(e){return this._push(writeByte,1,e?1:0)},Writer.prototype.fixed32=function(e){return this._push(writeFixed32,4,e>>>0)},Writer.prototype.sfixed32=Writer.prototype.fixed32,Writer.prototype.fixed64=function(e){var t=LongBits$1.from(e);return this._push(writeFixed32,4,t.lo)._push(writeFixed32,4,t.hi)},Writer.prototype.sfixed64=Writer.prototype.fixed64,Writer.prototype.float=function(e){return this._push(minimal.float.writeFloatLE,4,e)},Writer.prototype.double=function(e){return this._push(minimal.float.writeDoubleLE,8,e)};var writeBytes=minimal.Array.prototype.set?function(e,t,a){t.set(e,a)}:function(e,t,a){for(var r=0;r>>0;if(!t)return this._push(writeByte,1,0);if(minimal.isString(e)){var a=Writer.alloc(t=base64.length(e));base64.decode(e,a,0),e=a}return this.uint32(t)._push(writeBytes,t,e)},Writer.prototype.string=function(e){var t=utf8.length(e);return t?this.uint32(t)._push(utf8.write,t,e):this._push(writeByte,1,0)},Writer.prototype.fork=function(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer.prototype.ldelim=function(){var e=this.head,t=this.tail,a=this.len;return this.reset().uint32(a),a&&(this.tail.next=e.next,this.tail=t,this.len+=a),this},Writer.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),a=0;e;)e.fn(e.val,t,a),a+=e.len,e=e.next;return t},Writer._configure=function(e){BufferWriter=e};var writer_buffer=BufferWriter$1;(BufferWriter$1.prototype=Object.create(writer.prototype)).constructor=BufferWriter$1;var Buffer=minimal.Buffer;function BufferWriter$1(){writer.call(this)}BufferWriter$1.alloc=function(e){return(BufferWriter$1.alloc=minimal._Buffer_allocUnsafe)(e)};var writeBytesBuffer=Buffer&&Buffer.prototype instanceof Uint8Array&&"set"===Buffer.prototype.set.name?function(e,t,a){t.set(e,a)}:function(e,t,a){if(e.copy)e.copy(t,a,0,e.length);else for(var r=0;r>>0;return this.uint32(t),t&&this._push(writeBytesBuffer,t,e),this},BufferWriter$1.prototype.string=function(e){var t=Buffer.byteLength(e);return this.uint32(t),t&&this._push(writeStringBuffer,t,e),this};var reader=Reader,BufferReader,LongBits$2=minimal.LongBits,utf8$1=minimal.utf8;function indexOutOfRange(e,t){return RangeError("index out of range: "+e.pos+" + "+(t||1)+" > "+e.len)}function Reader(e){this.buf=e,this.pos=0,this.len=e.length}var create_array="undefined"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new Reader(e);throw Error("illegal buffer")}:function(e){if(Array.isArray(e))return new Reader(e);throw Error("illegal buffer")},value;function readLongVarint(){var e=new LongBits$2(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}function readFixed32_end(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits$2(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader.create=minimal.Buffer?function(e){return(Reader.create=function(e){return minimal.Buffer.isBuffer(e)?new BufferReader(e):create_array(e)})(e)}:create_array,Reader.prototype._slice=minimal.Array.prototype.subarray||minimal.Array.prototype.slice,Reader.prototype.uint32=(value=4294967295,function(){if(value=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return value;if(value=(value|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return value;if(value=(value|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return value;if(value=(value|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return value;if(value=(value|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return value;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return value}),Reader.prototype.int32=function(){return 0|this.uint32()},Reader.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},Reader.prototype.bool=function(){return 0!==this.uint32()},Reader.prototype.fixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.sfixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return 0|readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.float=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},Reader.prototype.double=function(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},Reader.prototype.bytes=function(){var e=this.uint32(),t=this.pos,a=this.pos+e;if(a>this.len)throw indexOutOfRange(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,a):t===a?new this.buf.constructor(0):this._slice.call(this.buf,t,a)},Reader.prototype.string=function(){var e=this.bytes();return utf8$1.read(e,0,e.length)},Reader.prototype.skip=function(e){if("number"==typeof e){if(this.pos+e>this.len)throw indexOutOfRange(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw indexOutOfRange(this)}while(128&this.buf[this.pos++]);return this},Reader.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;;){if(4==(e=7&this.uint32()))break;this.skipType(e)}break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+e+" at offset "+this.pos)}return this},Reader._configure=function(e){BufferReader=e;var t=minimal.Long?"toLong":"toNumber";minimal.merge(Reader.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader$1;function BufferReader$1(e){reader.call(this,e)}(BufferReader$1.prototype=Object.create(reader.prototype)).constructor=BufferReader$1,minimal.Buffer&&(BufferReader$1.prototype._slice=minimal.Buffer.prototype.slice),BufferReader$1.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len))};var service=Service;function Service(e,t,a){if("function"!=typeof e)throw TypeError("rpcImpl must be a function");minimal.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(a)}(Service.prototype=Object.create(minimal.EventEmitter.prototype)).constructor=Service,Service.prototype.rpcCall=function e(t,a,r,n,o){if(!n)throw TypeError("request must be specified");var s=this;if(!o)return minimal.asPromise(e,s,t,a,r,n);if(s.rpcImpl)try{return s.rpcImpl(t,a[s.requestDelimited?"encodeDelimited":"encode"](n).finish(),function(e,a){if(e)return s.emit("error",e,t),o(e);if(null!==a){if(!(a instanceof r))try{a=r[s.responseDelimited?"decodeDelimited":"decode"](a)}catch(e){return s.emit("error",e,t),o(e)}return s.emit("data",a,t),o(null,a)}s.end(!0)})}catch(e){return s.emit("error",e,t),void setTimeout(function(){o(e)},0)}else setTimeout(function(){o(Error("already ended"))},0)},Service.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this};var rpc_1=createCommonjsModule(function(e,t){t.Service=service}),roots={},indexMinimal=createCommonjsModule(function(e,t){var a=t;function r(){a.Reader._configure(a.BufferReader),a.util._configure()}a.build="minimal",a.Writer=writer,a.BufferWriter=writer_buffer,a.Reader=reader,a.BufferReader=reader_buffer,a.util=minimal,a.rpc=rpc_1,a.roots=roots,a.configure=r,a.Writer._configure(a.BufferWriter),r()}),minimal$1=indexMinimal,minimal_1=minimal$1.roots,minimal_2=minimal$1.Reader,minimal_3=minimal$1.util,$Reader=minimal$1.Reader,$util=minimal$1.util,$root=minimal$1.roots.default||(minimal$1.roots.default={}),valuesById,values,tensorflow;$root.tensorflow=(tensorflow={},tensorflow.Any=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.typeUrl=e.string();break;case 2:r.value=e.bytes();break;default:e.skipType(7&n)}}return r},e}(),tensorflow.DataType=(valuesById={},(values=Object.create(valuesById))[valuesById[0]="DT_INVALID"]=0,values[valuesById[1]="DT_FLOAT"]=1,values[valuesById[2]="DT_DOUBLE"]=2,values[valuesById[3]="DT_INT32"]=3,values[valuesById[4]="DT_UINT8"]=4,values[valuesById[5]="DT_INT16"]=5,values[valuesById[6]="DT_INT8"]=6,values[valuesById[7]="DT_STRING"]=7,values[valuesById[8]="DT_COMPLEX64"]=8,values[valuesById[9]="DT_INT64"]=9,values[valuesById[10]="DT_BOOL"]=10,values[valuesById[11]="DT_QINT8"]=11,values[valuesById[12]="DT_QUINT8"]=12,values[valuesById[13]="DT_QINT32"]=13,values[valuesById[14]="DT_BFLOAT16"]=14,values[valuesById[101]="DT_FLOAT_REF"]=101,values[valuesById[102]="DT_DOUBLE_REF"]=102,values[valuesById[103]="DT_INT32_REF"]=103,values[valuesById[104]="DT_UINT8_REF"]=104,values[valuesById[105]="DT_INT16_REF"]=105,values[valuesById[106]="DT_INT8_REF"]=106,values[valuesById[107]="DT_STRING_REF"]=107,values[valuesById[108]="DT_COMPLEX64_REF"]=108,values[valuesById[109]="DT_INT64_REF"]=109,values[valuesById[110]="DT_BOOL_REF"]=110,values[valuesById[111]="DT_QINT8_REF"]=111,values[valuesById[112]="DT_QUINT8_REF"]=112,values[valuesById[113]="DT_QINT32_REF"]=113,values[valuesById[114]="DT_BFLOAT16_REF"]=114,values),tensorflow.TensorShape=function(){function e(e){if(this.dim=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.dim&&r.dim.length||(r.dim=[]),r.dim.push($root.tensorflow.TensorShape.Dim.decode(e,e.uint32()));break;case 3:r.unknownRank=e.bool();break;default:e.skipType(7&n)}}return r},e.Dim=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.size=e.int64();break;case 2:r.name=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),tensorflow.Tensor=function(){function e(e){if(this.floatVal=[],this.doubleVal=[],this.intVal=[],this.stringVal=[],this.scomplexVal=[],this.int64Val=[],this.boolVal=[],this.uint32Val=[],this.uint64Val=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.dtype=e.int32();break;case 2:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 3:r.versionNumber=e.int32();break;case 4:r.tensorContent=e.bytes();break;case 5:if(r.floatVal&&r.floatVal.length||(r.floatVal=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.list=$root.tensorflow.AttrValue.ListValue.decode(e,e.uint32());break;case 2:r.s=e.bytes();break;case 3:r.i=e.int64();break;case 4:r.f=e.float();break;case 5:r.b=e.bool();break;case 6:r.type=e.int32();break;case 7:r.shape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 8:r.tensor=$root.tensorflow.Tensor.decode(e,e.uint32());break;case 9:r.placeholder=e.string();break;case 10:r.func=$root.tensorflow.NameAttrList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.ListValue=function(){function e(e){if(this.s=[],this.i=[],this.f=[],this.b=[],this.type=[],this.shape=[],this.tensor=[],this.func=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.s&&r.s.length||(r.s=[]),r.s.push(e.bytes());break;case 3:if(r.i&&r.i.length||(r.i=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.name=e.string();break;case 2:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),tensorflow.NodeDef=function(){function e(e){if(this.input=[],this.attr={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.name=e.string();break;case 2:n.op=e.string();break;case 3:n.input&&n.input.length||(n.input=[]),n.input.push(e.string());break;case 4:n.device=e.string();break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),tensorflow.VersionDef=function(){function e(e){if(this.badConsumers=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.producer=e.int32();break;case 2:r.minConsumer=e.int32();break;case 3:if(r.badConsumers&&r.badConsumers.length||(r.badConsumers=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.node&&r.node.length||(r.node=[]),r.node.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:r.versions=$root.tensorflow.VersionDef.decode(e,e.uint32());break;case 2:r.library=$root.tensorflow.FunctionDefLibrary.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),tensorflow.CollectionDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.nodeList=$root.tensorflow.CollectionDef.NodeList.decode(e,e.uint32());break;case 2:r.bytesList=$root.tensorflow.CollectionDef.BytesList.decode(e,e.uint32());break;case 3:r.int64List=$root.tensorflow.CollectionDef.Int64List.decode(e,e.uint32());break;case 4:r.floatList=$root.tensorflow.CollectionDef.FloatList.decode(e,e.uint32());break;case 5:r.anyList=$root.tensorflow.CollectionDef.AnyList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.NodeList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.string());break;default:e.skipType(7&n)}}return r},e}(),e.BytesList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.bytes());break;default:e.skipType(7&n)}}return r},e}(),e.Int64List=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push($root.tensorflow.Any.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),e}(),tensorflow.SaverDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.filenameTensorName=e.string();break;case 2:r.saveTensorName=e.string();break;case 3:r.restoreOpName=e.string();break;case 4:r.maxToKeep=e.int32();break;case 5:r.sharded=e.bool();break;case 6:r.keepCheckpointEveryNHours=e.float();break;case 7:r.version=e.int32();break;default:e.skipType(7&n)}}return r},e.CheckpointFormatVersion=(t={},(a=Object.create(t))[t[0]="LEGACY"]=0,a[t[1]="V1"]=1,a[t[2]="V2"]=2,a),e}(),tensorflow.TensorInfo=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 4:r.cooSparse=$root.tensorflow.TensorInfo.CooSparse.decode(e,e.uint32());break;case 2:r.dtype=e.int32();break;case 3:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.CooSparse=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.valuesTensorName=e.string();break;case 2:r.indicesTensorName=e.string();break;case 3:r.denseShapeTensorName=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),tensorflow.SignatureDef=function(){function e(e){if(this.inputs={},this.outputs={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:e.skip().pos++,n.inputs===$util.emptyObject&&(n.inputs={}),a=e.string(),e.pos++,n.inputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:e.skip().pos++,n.outputs===$util.emptyObject&&(n.outputs={}),a=e.string(),e.pos++,n.outputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 3:n.methodName=e.string();break;default:e.skipType(7&o)}}return n},e}(),tensorflow.AssetFileDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.tensorInfo=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:r.filename=e.string();break;default:e.skipType(7&n)}}return r},e}(),tensorflow.OpDef=function(){function e(e){if(this.inputArg=[],this.outputArg=[],this.attr=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.inputArg&&r.inputArg.length||(r.inputArg=[]),r.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 3:r.outputArg&&r.outputArg.length||(r.outputArg=[]),r.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 4:r.attr&&r.attr.length||(r.attr=[]),r.attr.push($root.tensorflow.OpDef.AttrDef.decode(e,e.uint32()));break;case 8:r.deprecation=$root.tensorflow.OpDef.OpDeprecation.decode(e,e.uint32());break;case 5:r.summary=e.string();break;case 6:r.description=e.string();break;case 18:r.isCommutative=e.bool();break;case 16:r.isAggregate=e.bool();break;case 17:r.isStateful=e.bool();break;case 19:r.allowsUninitializedInput=e.bool();break;default:e.skipType(7&n)}}return r},e.ArgDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.description=e.string();break;case 3:r.type=e.int32();break;case 4:r.typeAttr=e.string();break;case 5:r.numberAttr=e.string();break;case 6:r.typeListAttr=e.string();break;case 16:r.isRef=e.bool();break;default:e.skipType(7&n)}}return r},e}(),e.AttrDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.type=e.string();break;case 3:r.defaultValue=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 4:r.description=e.string();break;case 5:r.hasMinimum=e.bool();break;case 6:r.minimum=e.int64();break;case 7:r.allowedValues=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),e.OpDeprecation=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.version=e.int32();break;case 2:r.explanation=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),tensorflow.OpList=function(){function e(e){if(this.op=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.op&&r.op.length||(r.op=[]),r.op.push($root.tensorflow.OpDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),tensorflow.MetaGraphDef=function(){function e(e){if(this.collectionDef={},this.signatureDef={},this.assetFileDef=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.metaInfoDef=$root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e,e.uint32());break;case 2:n.graphDef=$root.tensorflow.GraphDef.decode(e,e.uint32());break;case 3:n.saverDef=$root.tensorflow.SaverDef.decode(e,e.uint32());break;case 4:e.skip().pos++,n.collectionDef===$util.emptyObject&&(n.collectionDef={}),a=e.string(),e.pos++,n.collectionDef[a]=$root.tensorflow.CollectionDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.signatureDef===$util.emptyObject&&(n.signatureDef={}),a=e.string(),e.pos++,n.signatureDef[a]=$root.tensorflow.SignatureDef.decode(e,e.uint32());break;case 6:n.assetFileDef&&n.assetFileDef.length||(n.assetFileDef=[]),n.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return n},e.MetaInfoDef=function(){function e(e){if(this.tags=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.metaGraphVersion=e.string();break;case 2:r.strippedOpList=$root.tensorflow.OpList.decode(e,e.uint32());break;case 3:r.anyInfo=$root.tensorflow.Any.decode(e,e.uint32());break;case 4:r.tags&&r.tags.length||(r.tags=[]),r.tags.push(e.string());break;case 5:r.tensorflowVersion=e.string();break;case 6:r.tensorflowGitVersion=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),tensorflow.SavedModel=function(){function e(e){if(this.metaGraphs=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.savedModelSchemaVersion=e.int64();break;case 2:r.metaGraphs&&r.metaGraphs.length||(r.metaGraphs=[]),r.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),tensorflow.FunctionDefLibrary=function(){function e(e){if(this.function=[],this.gradient=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.function&&r.function.length||(r.function=[]),r.function.push($root.tensorflow.FunctionDef.decode(e,e.uint32()));break;case 2:r.gradient&&r.gradient.length||(r.gradient=[]),r.gradient.push($root.tensorflow.GradientDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),tensorflow.FunctionDef=function(){function e(e){if(this.attr={},this.nodeDef=[],this.ret={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.signature=$root.tensorflow.OpDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 3:n.nodeDef&&n.nodeDef.length||(n.nodeDef=[]),n.nodeDef.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:e.skip().pos++,n.ret===$util.emptyObject&&(n.ret={}),a=e.string(),e.pos++,n.ret[a]=e.string();break;default:e.skipType(7&o)}}return n},e}(),tensorflow.GradientDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.functionName=e.string();break;case 2:r.gradientFunc=e.string();break;default:e.skipType(7&n)}}return r},e}(),tensorflow);var compiled_api=$root,compiled_api_1=compiled_api.tensorflow;function getParamValue(e,t,a,r){var n=t.params[e];if(n&&void 0!==n.inputIndex){if("tensor"===n.type)return getTensor(t.inputNames[n.inputIndex],a,r);if("tensors"===n.type)return(0===n.inputIndex?0===n.inputParamLength?t.inputNames:t.inputNames.slice(n.inputIndex,-n.inputParamLength):t.inputNames.splice(n.inputIndex)).map(function(e){return getTensor(e,a,r)});var o=Array.prototype.slice.call(getTensor(t.inputNames.slice(n.inputIndex)[0],a,r).dataSync());return"number"===n.type?o[0]:o}return n&&n.value}function getTensor(e,t,a){var r=parseNodeName(e),n=r[0],o=r[1],s=a.currentContextIds.find(function(e){return!!t[getNodeNameWithContextId(n,e)]});return void 0!==s?t[getNodeNameWithContextId(n,s)][o]:void 0}function getNodeNameAndIndex(e,t){var a=parseNodeName(e),r=a[0],n=a[1];return[getNodeNameWithContextId(r,t&&t.currentContextId),n]}function getNodeNameWithContextId(e,t){return t?e+"-"+t:e}function parseNodeName(e){var t=e.lastIndexOf(":");return-1===t?[e,0]:[e.substring(0,t),Number(e.substring(t+1))]}function split(e,t){for(var a=[],r=0;r=this.tensors.length)throw new Error("Tried to read from index "+e+", but array size is: "+this.tensors.length);var t=this.tensors[e];if(t.cleared)throw new Error("TensorArray "+this.name+": Could not read index "+e+" twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).");return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor},e.prototype.readMany=function(e){var t=this;return e.map(function(e){return t.read(e)})},e.prototype.write=function(e,t){if(this.closed_)throw new Error("TensorArray "+this.name+" has already been closed.");if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error("Tried to write to index "+e+", but array is not resizeable and size is: "+this.maxSize);var a=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+",\n because the value dtype is "+t.dtype+", but TensorArray dtype is "+this.dtype+".");if(0===this.size()&&0===this.elementShape.length&&(this.elementShape=t.shape),tfc.util.assertShapesMatch(this.elementShape,t.shape,"TensorArray "+this.name+": Could not write to TensorArray index "+e+"."),a&&a.read)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been read.");if(a&&a.written)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been written.");a.tensor=t,a.written=!0,this.tensors[e]=a},e.prototype.writeMany=function(e,t){var a=this;if(e.length!==t.length)throw new Error("TensorArray "+this.name+": could not write multiple tensors,because the index size: "+e.length+" is not the same as tensors size: "+t.length+".");e.map(function(e,r){return a.write(e,t[r])})},e.prototype.gather=function(e,t){if(t&&t!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but gather requested dtype "+t);if(!e){e=[];for(var a=0;a=this.maxSize)throw new Error("Max index must be < array size ("+a+" vs. "+this.maxSize+")");this.writeMany(e,tfc.unstack(t,0))},e.prototype.split=function(e,t){var a=this;if(t.dtype!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but tensor has dtype "+t.dtype);var r=0,n=e.map(function(e){return r+=e});if(r!==t.shape[0])throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n "+r+", and tensor's shape is: "+t.shape);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error("TensorArray's size is not equal to the size of lengths ("+this.maxSize+" vs. "+e.length+"), and the TensorArray is not marked as dynamically resizeable");var o=0===r?0:t.size/r,s=[];tfc.tidy(function(){t=t.reshape([1,r,o]);for(var i=0;i1)for(var c=1;c1))throw new Error("Cannot exit frame, the context is empty");this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift()},e.prototype.nextIteration=function(){if(!(this.contexts&&this.contexts.length>0))throw new Error("Cannot increase frame iteration, the context is empty");this.contexts=this.contexts.slice(),this.lastId++;var e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))},e.prototype.getWeight=function(e){return this.weightMap[e]},e.prototype.addTensorArray=function(e){this.tensorArrayMap[e.id]=e},e.prototype.getTensorArray=function(e){return this.tensorArrayMap[e]},e}(),GraphExecutor=function(){function e(e){this.graph=e,this.compiledOrder=[],this._weightMap={},this.placeholders=e.placeholders,this._outputs=e.outputs,this.compile()}return Object.defineProperty(e.prototype,"weightMap",{get:function(){return this._weightMap},set:function(e){var t=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})});this.weightIds=[].concat.apply([],t),this._weightMap=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.placeholders.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this._outputs.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.placeholders.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.outputs.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isControlFlowModel",{get:function(){return this.graph.withControlFlow},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isDynamicShapeModel",{get:function(){return this.graph.withDynamicShape},enumerable:!0,configurable:!0}),e.prototype.compile=function(){if(!this.graph.withControlFlow&&!this.graph.withDynamicShape)for(var e=this.graph.inputs.slice(),t={};e.length>0;){var a=e.pop();t[a.name]=!0,this.compiledOrder.push(a),a.children.forEach(function(a){!t[a.name]&&a.inputNames.every(function(e){var a=getNodeNameAndIndex(e)[0];return t[a]})&&e.push(a)})}},e.prototype.execute=function(e,t){var a=this;this.checkInput(e),this.checkInputShapeAndType(e);var r={};return tfc.tidy(function(){var n=new ExecutionContext(a._weightMap,r),o=a.compiledOrder.reduce(function(e,t){return e[t.name]=executeOp$15(t,e,n),e},__assign({},a.weightMap,e));return a.findOutputs(o,n,t)})},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u=this;return __generator(this,function(l){switch(l.label){case 0:return this.checkInput(e),this.checkInputShapeAndType(e),a={},r=new ExecutionContext(this._weightMap,a),[4,this.executeWithControlFlow(e,r)];case 1:return n=l.sent(),o=this.findOutputs(n,r,t),s=Object.keys(o).map(function(e){return o[e].id}),i=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})}),p=[].concat.apply([],i),Object.keys(n).forEach(function(e){n[e].forEach(function(e){e&&-1===s.indexOf(e.id)&&-1===p.indexOf(e.id)&&-1===u.weightIds.indexOf(e.id)&&e.dispose()})}),[2,o]}})})},e.prototype.executeWithControlFlow=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u;return __generator(this,function(l){switch(l.label){case 0:a=this.graph.inputs.map(function(e){return{node:e,contexts:t.currentContext}}),r=__assign({},this.weightMap,e),n={},l.label=1;case 1:return a.length>0?(o=a.pop(),t.currentContext=o.contexts,s="","enter"===o.node.op&&getParamValue("isConstant",o.node,r,t)&&(s=getNodeNameAndIndex(o.node.name,t)[0]),i=executeOp$15(o.node,r,t),s||(s=getNodeNameAndIndex(o.node.name,t)[0]),p=r,u=s,[4,i]):[3,3];case 2:return p[u]=l.sent(),o.node.children.forEach(function(e){var o=getNodeNameAndIndex(e.name,t)[0];n[o]||("merge"===e.op?e.inputNames.some(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})):e.inputNames.every(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})))}),[3,1];case 3:return[2,r]}})})},e.prototype.findOutputs=function(e,t,a){return!a||a instanceof Array||(a=[a]),(a||this.graph.outputs.map(function(e){return e.name})).reduce(function(a,r){return a[r]=getTensor(r,e,t),a},{})},e.prototype.dispose=function(){var e=this;Object.keys(this.weightMap).forEach(function(t){return e.weightMap[t].forEach(function(e){return e.dispose()})})},e.prototype.checkInputShapeAndType=function(e){this.placeholders.forEach(function(t){var a=e[t.name][0];if(t.params.shape&&t.params.shape.value){var r=t.params.shape.value,n=r.length===a.shape.length&&a.shape.every(function(e,t){return-1===r[t]||r[t]===e});tfc.util.assert(n,"The shape of dict['"+t.name+"'] provided in model.execute(dict) must be ["+r+"], but was ["+a.shape+"]")}t.params.dtype&&t.params.dtype.value&&tfc.util.assert(a.dtype===t.params.dtype.value,"The dtype of dict['"+t.name+"'] provided in model.execute(dict) must be "+t.params.dtype.value+", but was "+a.dtype)})},e.prototype.checkInput=function(e){var t=this,a=Object.keys(e),r=[],n=[];if(this.inputNodes.forEach(function(e){-1===a.indexOf(e)&&r.push(e)}),a.forEach(function(e){-1===t.inputNodes.indexOf(e)&&n.push(e)}),r.length>0)throw new Error("The dict provided in model.execute(dict) has the keys ["+a+"], but is missing the required keys: ["+r+"].");if(n.length>0)throw new Error("The dict provided in model.execute(dict) has unused keys: ["+n+"]. Please provide only the following keys: ["+this.inputNodes+"].")},e}(),FrozenModel=function(){function e(e,t,a){this.modelUrl=e,this.weightManifestUrl=t,this.requestOption=a,this.version="n/a",this.pathPrefix=this.getPathPrefix()}return Object.defineProperty(e.prototype,"modelVersion",{get:function(){return this.version},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.executor.inputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.executor.outputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.executor.inputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this.executor.outputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"weights",{get:function(){return this.executor.weightMap},enumerable:!0,configurable:!0}),e.prototype.getPathPrefix=function(){var e=parse(this.weightManifestUrl),t=e.pathname.split("/");return t.splice(-1),e.pathname=t.join("/"),format(e)+"/"},e.prototype.loadRemoteProtoFile=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r,n;return __generator(this,function(o){switch(o.label){case 0:return o.trys.push([0,3,,4]),[4,fetch(this.modelUrl,this.requestOption)];case 1:return e=o.sent(),a=(t=compiled_api_1.GraphDef).decode,r=Uint8Array.bind,[4,e.arrayBuffer()];case 2:return[2,a.apply(t,[new(r.apply(Uint8Array,[void 0,o.sent()]))])];case 3:throw n=o.sent(),new Error(this.modelUrl+" not found. "+n);case 4:return[2]}})})},e.prototype.loadWeightManifest=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a;return __generator(this,function(r){switch(r.label){case 0:return r.trys.push([0,3,,4]),[4,fetch(this.weightManifestUrl,this.requestOption)];case 1:return e=r.sent(),t=this,[4,e.clone().json()];case 2:return t.weightManifest=r.sent(),[3,4];case 3:throw a=r.sent(),new Error(this.weightManifestUrl+" not found. "+a);case 4:return[2]}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r;return __generator(this,function(n){switch(n.label){case 0:return e=this.loadRemoteProtoFile(),t=this.loadWeightManifest(),[4,Promise.all([e,t])];case 1:return a=n.sent()[0],this.version=a.versions.producer+"."+a.versions.minConsumer,[4,tfc.io.loadWeights(this.weightManifest,this.pathPrefix,void 0,this.requestOption)];case 2:return r=n.sent(),this.executor=new GraphExecutor(OperationMapper.Instance.transformGraph(a)),this.executor.weightMap=this.convertTensorMapToTensorsMap(r),[2,!0]}})})},e.prototype.predict=function(e,t){return this.execute(e,this.outputNodes)},e.prototype.constructTensorMap=function(e){var t=e instanceof tfc.Tensor?[e]:e;if(t.length!==this.inputNodes.length)throw new Error("Input tensor count mismatch,the frozen model has "+this.inputNodes.length+" placeholders, while there are "+t.length+" input tensors.");return this.inputNodes.reduce(function(e,a,r){return e[a]=t[r],e},{})},e.prototype.execute=function(e,t){if(t=t||this.outputNodes,(e instanceof tfc.Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),this.executor.isControlFlowModel||this.executor.isDynamicShapeModel)throw new Error("The model contains control flow or dynamic shape ops, please use executeAsync method");var a=this.executor.execute(this.convertTensorMapToTensorsMap(e),t),r=Object.keys(a);return Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r;return __generator(this,function(n){switch(n.label){case 0:if(!this.executor.isControlFlowModel||!this.executor.isDynamicShapeModel)throw new Error("The model does not contain control flow or dynamic shape ops, please use execute method for better performance.");return t=t||this.outputNodes,(e instanceof tfc.Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),[4,this.executor.executeAsync(this.convertTensorMapToTensorsMap(e),t)];case 1:return a=n.sent(),r=Object.keys(a),[2,Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]]}})})},e.prototype.convertTensorMapToTensorsMap=function(e){return Object.keys(e).reduce(function(t,a){return t[a]=[e[a]],t},{})},e.prototype.dispose=function(){this.executor.dispose()},e}();function loadFrozenModel(e,t,a){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(n){switch(n.label){case 0:return[4,(r=new FrozenModel(e,t,a)).load()];case 1:return n.sent(),[2,r]}})})}var version="0.5.5";exports.FrozenModel=FrozenModel,exports.loadFrozenModel=loadFrozenModel,exports.version_converter=version,Object.defineProperty(exports,"__esModule",{value:!0})}); diff --git a/node_modules/@tensorflow/tfjs-converter/dist/version.d.ts b/node_modules/@tensorflow/tfjs-converter/dist/version.d.ts new file mode 100644 index 0000000..097c78d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/version.d.ts @@ -0,0 +1,2 @@ +declare const version = "0.5.5"; +export { version }; diff --git a/node_modules/@tensorflow/tfjs-converter/dist/version.js b/node_modules/@tensorflow/tfjs-converter/dist/version.js new file mode 100644 index 0000000..a5b460f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/dist/version.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var version = '0.5.5'; +exports.version = version; +//# sourceMappingURL=version.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-converter/package.json b/node_modules/@tensorflow/tfjs-converter/package.json new file mode 100644 index 0000000..ef48560 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-converter/package.json @@ -0,0 +1,97 @@ +{ + "_from": "@tensorflow/tfjs-converter@0.5.5", + "_id": "@tensorflow/tfjs-converter@0.5.5", + "_inBundle": false, + "_integrity": "sha512-tLIv4u0+BtE61oarjQWJUsL0Ro54YmiDx8XVCbN9QY34V6zZrNFr/VJYZEIZnKcepCQ0MxZ09mggnfBD3EvMrQ==", + "_location": "/@tensorflow/tfjs-converter", + "_phantomChildren": {}, + "_requested": { + "type": "version", + "registry": true, + "raw": "@tensorflow/tfjs-converter@0.5.5", + "name": "@tensorflow/tfjs-converter", + "escapedName": "@tensorflow%2ftfjs-converter", + "scope": "@tensorflow", + "rawSpec": "0.5.5", + "saveSpec": null, + "fetchSpec": "0.5.5" + }, + "_requiredBy": [ + "/@tensorflow/tfjs" + ], + "_resolved": "https://registry.npmjs.org/@tensorflow/tfjs-converter/-/tfjs-converter-0.5.5.tgz", + "_shasum": "0b8ced232d598e70bc52a4a6d95ba69f88af1b8d", + "_spec": "@tensorflow/tfjs-converter@0.5.5", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs", + "bugs": { + "url": "https://github.com/tensorflow/tfjs-converter/issues" + }, + "bundleDependencies": false, + "dependencies": { + "@types/long": "~3.0.32", + "protobufjs": "~6.8.6", + "url": "~0.11.0" + }, + "deprecated": false, + "description": "Tensorflow model converter for javascript", + "devDependencies": { + "@tensorflow/tfjs-core": "~0.12.8", + "@types/jasmine": "~2.8.6", + "@types/node-fetch": "1.6.9", + "ajv": "~6.3.0", + "babel-core": "~6.26.3", + "babel-plugin-external-helpers": "~6.22.0", + "babel-preset-env": "~1.7.0", + "clang-format": "~1.2.2", + "copyfiles": "~1.2.0", + "jasmine-core": "~3.1.0", + "karma": "~2.0.0", + "karma-browserstack-launcher": "~1.3.0", + "karma-chrome-launcher": "~2.2.0", + "karma-firefox-launcher": "~1.0.1", + "karma-jasmine": "~1.1.1", + "karma-typescript": "~3.0.12", + "node-fetch": "~2.1.2", + "opn": "~5.1.0", + "rimraf": "~2.6.2", + "rollup": "~0.58.2", + "rollup-plugin-commonjs": "~9.1.3", + "rollup-plugin-json": "~3.0.0", + "rollup-plugin-node-resolve": "~3.3.0", + "rollup-plugin-typescript2": "~0.13.0", + "rollup-plugin-uglify": "~3.0.0", + "ts-node": "~4.1.0", + "tslint": "~5.8.0", + "tslint-no-circular-imports": "~0.5.0", + "typescript": "~2.7.2", + "yalc": "~1.0.0-pre.21" + }, + "homepage": "https://github.com/tensorflow/tfjs-converter#readme", + "jsdelivr": "dist/tf-converter.min.js", + "jsnext:main": "dist/tf-converter.esm.js", + "license": "Apache-2.0", + "main": "dist/index.js", + "module": "dist/tf-converter.esm.js", + "name": "@tensorflow/tfjs-converter", + "peerDependencies": { + "@tensorflow/tfjs-core": "~0.12.8" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/tensorflow/tfjs-converter.git" + }, + "scripts": { + "build": "tsc && copyfiles -f src/data/compiled_api.* dist/data && copyfiles -f src/operations/op_list/*.json dist/operations/op_list && copyfiles -f src/operations/typings.d.ts dist/operations", + "build-npm": "./scripts/build-npm.sh", + "gen-doc": "ts-node ./src/docs/doc_gen.ts", + "link-local": "yalc link", + "lint": "tslint -p . -t verbose", + "make-version": "sh -c ./scripts/make-version", + "publish-local": "yarn build-npm && yalc push", + "test": "karma start", + "test-travis": "karma start --browsers='bs_firefox_mac,bs_chrome_mac' --singleRun" + }, + "types": "dist/index.d.ts", + "unpkg": "dist/tf-converter.min.js", + "version": "0.5.5" +} diff --git a/node_modules/@tensorflow/tfjs-core/LICENSE b/node_modules/@tensorflow/tfjs-core/LICENSE new file mode 100644 index 0000000..d645695 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/LICENSE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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. diff --git a/node_modules/@tensorflow/tfjs-core/README.md b/node_modules/@tensorflow/tfjs-core/README.md new file mode 100644 index 0000000..1010a37 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/README.md @@ -0,0 +1,45 @@ + + + + +# TensorFlow.js Core API + +A part of the TensorFlow.js ecosystem, this repo hosts `@tensorflow/tfjs-core`, +the TensorFlow.js Core API, which provides low-level, hardware-accelerated +linear algebra operations and an eager API for automatic differentiation. + +Check out [js.tensorflow.org](https://js.tensorflow.org) for more +information about the library, tutorials and API docs. + +To keep track of issues we use the [tensorflow/tfjs](https://github.com/tensorflow/tfjs) Github repo. + +## Importing + +You can install TensorFlow.js via yarn or npm. We recommend using the +[@tensorflow/tfjs](https://www.npmjs.com/package/@tensorflow/tfjs) npm package, +which gives you both this Core API and the higher-level +[Layers API](https://github.com/tensorflow/tfjs-layers): + +```js +import * as tf from '@tensorflow/tfjs'; +// You have the Core API: tf.matMul(), tf.softmax(), ... +// You also have Layers API: tf.model(), tf.layers.dense(), ... +``` + +On the other hand, if you care about the bundle size and you do not use the +Layers API, you can import only the Core API: + +```js +import * as tfc from '@tensorflow/tfjs-core'; +// You have the Core API: tfc.matMul(), tfc.softmax(), ... +// No Layers API. +``` + +For info about development, check out [DEVELOPMENT.md](./DEVELOPMENT.md). + +## For more information + +- [TensorFlow.js API documentation](https://js.tensorflow.org/api/latest/) +- [TensorFlow.js Tutorials](https://js.tensorflow.org/tutorials/) + +Thanks BrowserStack for providing testing support. diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/browser_util.d.ts new file mode 100644 index 0000000..2b112a5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util.d.ts @@ -0,0 +1,2 @@ +declare function nextFrame(): Promise; +export { nextFrame }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util.js b/node_modules/@tensorflow/tfjs-core/dist/browser_util.js new file mode 100644 index 0000000..0f3dcb7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util.js @@ -0,0 +1,10 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var delayCallback = typeof requestAnimationFrame !== 'undefined' ? + requestAnimationFrame : + setImmediate; +function nextFrame() { + return new Promise(function (resolve) { return delayCallback(function () { return resolve(); }); }); +} +exports.nextFrame = nextFrame; +//# sourceMappingURL=browser_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/browser_util.js.map new file mode 100644 index 0000000..b9f4f7f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_util.js","sourceRoot":"","sources":["../src/browser_util.ts"],"names":[],"mappings":";;AAiBA,IAAM,aAAa,GAAG,OAAO,qBAAqB,KAAK,WAAW,CAAC,CAAC;IAChE,qBAAqB,CAAC,CAAC;IACvB,YAAY,CAAC;AAWjB;IACE,OAAO,IAAI,OAAO,CAAO,UAAA,OAAO,IAAI,OAAA,aAAa,CAAC,cAAM,OAAA,OAAO,EAAE,EAAT,CAAS,CAAC,EAA9B,CAA8B,CAAC,CAAC;AACtE,CAAC;AAEO,8BAAS"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js new file mode 100644 index 0000000..0883abf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js @@ -0,0 +1,83 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('nextFrame', test_util_1.ALL_ENVS, function () { + it('basic usage', function () { return __awaiter(_this, void 0, void 0, function () { + var t0, t1; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + t0 = tf.util.now(); + return [4, tf.nextFrame()]; + case 1: + _a.sent(); + t1 = tf.util.now(); + expect(t1 > t0); + return [2]; + } + }); + }); }); + it('does not block timers', function () { return __awaiter(_this, void 0, void 0, function () { + var flag, t0; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + flag = false; + setTimeout(function () { + flag = true; + }, 50); + t0 = tf.util.now(); + expect(flag).toBe(false); + _a.label = 1; + case 1: + if (!(tf.util.now() - t0 < 1000 && !flag)) return [3, 3]; + return [4, tf.nextFrame()]; + case 2: + _a.sent(); + return [3, 1]; + case 3: + expect(flag).toBe(true); + return [2]; + } + }); + }); }); +}); +//# sourceMappingURL=browser_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js.map new file mode 100644 index 0000000..5d035b6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/browser_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_util_test.js","sourceRoot":"","sources":["../src/browser_util_test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBA,iBA0BA;;AA1BA,4BAA8B;AAC9B,+CAAiD;AACjD,yCAAqC;AAErC,gCAAiB,CAAC,WAAW,EAAE,oBAAQ,EAAE;IACvC,EAAE,CAAC,aAAa,EAAE;;;;;oBACV,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;oBACzB,WAAM,EAAE,CAAC,SAAS,EAAE,EAAA;;oBAApB,SAAoB,CAAC;oBACf,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;oBAEzB,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;;;;SACjB,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE;;;;;oBACtB,IAAI,GAAG,KAAK,CAAC;oBACjB,UAAU,CAAC;wBACT,IAAI,GAAG,IAAI,CAAC;oBACd,CAAC,EAAE,EAAE,CAAC,CAAC;oBACD,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;oBACzB,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;;;yBAClB,CAAA,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,CAAC,IAAI,CAAA;oBACvC,WAAM,EAAE,CAAC,SAAS,EAAE,EAAA;;oBAApB,SAAoB,CAAC;;;oBAEvB,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;SACzB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js new file mode 100644 index 0000000..04dd2f4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js @@ -0,0 +1,58 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var tensor_util_env_1 = require("./tensor_util_env"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('debug on', test_util_1.ALL_ENVS, function () { + beforeAll(function () { + tf.ENV.set('DEBUG', true); + }); + afterAll(function () { + tf.ENV.set('DEBUG', false); + }); + it('debug mode does not error when no nans', function () { + var a = tf.tensor1d([2, -1, 0, 3]); + var res = tf.relu(a); + test_util_1.expectArraysClose(res, [2, 0, 0, 3]); + }); + it('debug mode errors when there are nans, float32', function () { + var a = tf.tensor1d([2, NaN]); + var f = function () { return tf.relu(a); }; + expect(f).toThrowError(); + }); + it('debug mode errors when nans in tensor construction, int32', function () { + var a = function () { return tf.tensor1d([2, NaN], 'int32'); }; + expect(a).toThrowError(); + }); + it('debug mode errors when nans in oneHot op (tensorlike), int32', function () { + var f = function () { return tf.oneHot([2, NaN], 3); }; + expect(f).toThrowError(); + }); + it('debug mode errors when nan in convertToTensor, int32', function () { + var a = function () { return tensor_util_env_1.convertToTensor(NaN, 'a', 'test', 'int32'); }; + expect(a).toThrowError(); + }); + it('debug mode errors when nan in convertToTensor array input, int32', function () { + var a = function () { return tensor_util_env_1.convertToTensor([NaN], 'a', 'test', 'int32'); }; + expect(a).toThrowError(); + }); + it('A x B', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([0, 1, -3, 2, 2, 1], [3, 2]); + var c = tf.matMul(a, b); + expect(c.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(c, [0, 8, -3, 20]); + }); +}); +jasmine_util_1.describeWithFlags('debug off', test_util_1.ALL_ENVS, function () { + beforeAll(function () { + tf.ENV.set('DEBUG', false); + }); + it('no errors where there are nans, and debug mode is disabled', function () { + var a = tf.tensor1d([2, NaN]); + var res = tf.relu(a); + test_util_1.expectArraysClose(res, [2, NaN]); + }); +}); +//# sourceMappingURL=debug_mode_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js.map new file mode 100644 index 0000000..b7f084b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/debug_mode_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"debug_mode_test.js","sourceRoot":"","sources":["../src/debug_mode_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/device_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/device_util.d.ts new file mode 100644 index 0000000..c2a6948 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/device_util.d.ts @@ -0,0 +1 @@ +export declare function isMobile(): boolean; diff --git a/node_modules/@tensorflow/tfjs-core/dist/device_util.js b/node_modules/@tensorflow/tfjs-core/dist/device_util.js new file mode 100644 index 0000000..6bf155e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/device_util.js @@ -0,0 +1,11 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function isMobile() { + var a = navigator.userAgent || navigator.vendor || window.opera; + return /(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i + .test(a) || + /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i + .test(a.substr(0, 4)); +} +exports.isMobile = isMobile; +//# sourceMappingURL=device_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/device_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/device_util.js.map new file mode 100644 index 0000000..b6db30c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/device_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"device_util.js","sourceRoot":"","sources":["../src/device_util.ts"],"names":[],"mappings":";;AAiBA;IAEE,IAAM,CAAC,GAAG,SAAS,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,IAAK,MAAc,CAAC,KAAK,CAAC;IAE3E,OAAO,0TAA0T;SACrT,IAAI,CAAC,CAAC,CAAC;QAEf,ykDAAykD;aACpkD,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAChC,CAAC;AATD,4BASC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine.d.ts b/node_modules/@tensorflow/tfjs-core/dist/engine.d.ts new file mode 100644 index 0000000..f804d07 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine.d.ts @@ -0,0 +1,73 @@ +import { BackendTimingInfo, KernelBackend } from './kernels/backend'; +import { DataId, Tensor, Tensor3D, Variable } from './tensor'; +import { NamedTensorMap, NamedVariableMap, TensorContainer } from './tensor_types'; +import { TypedArray } from './types'; +export declare type ForwardFunc = (backend: KernelBackend, save?: (tensor: S) => S) => T; +export declare type CustomGradientFunc = (...args: Tensor[]) => { + value: T; + gradFunc: (dy: T) => Tensor | Tensor[]; +}; +export declare type MemoryInfo = { + numTensors: number; + numDataBuffers: number; + numBytes: number; + unreliable?: boolean; +}; +export interface TimingInfo extends BackendTimingInfo { + wallMs: number; +} +export declare type ScopeFn = () => T; +export interface TensorManager { + registerTensor(a: Tensor): void; + registerVariable(v: Variable): void; + disposeTensor(a: Tensor): void; + memory(): { + numDataBuffers: number; + numBytes: number; + }; +} +export declare class Engine implements TensorManager { + private backend; + safeMode: boolean; + private debugMode; + registeredVariables: NamedVariableMap; + private refCounter; + private nextTapeNodeId; + private numBytes; + private numTensors; + private numDataBuffers; + private activeTape; + private gradientScopeCount; + private customGradientDepth; + private activeScope; + private scopeStack; + private keepTensors; + private profiler; + constructor(backend: KernelBackend, safeMode: boolean, debugMode: () => boolean); + tidy(nameOrFn: string | ScopeFn, fn?: ScopeFn, gradMode?: boolean): T; + private scopedRun; + runKernel(forwardFunc: ForwardFunc, inputs: I, backwardsFunc?: (dy: T, saved: Tensor[]) => { + [P in keyof I]: () => I[P]; + }): T; + registerTensor(a: Tensor | Variable): void; + registerVariable(v: Variable): void; + disposeTensor(a: Tensor): void; + disposeVariables(): void; + memory(): MemoryInfo; + private shouldRecord; + private addTapeNode; + keep(result: T): T; + startScope(name?: string, gradientsMode?: boolean): void; + endScope(result?: TensorContainer, gradientsMode?: boolean): void; + gradients(f: () => T, xs: Tensor[], dy?: T, allowNoGradients?: boolean): { + value: T; + grads: Tensor[]; + }; + customGrad(f: CustomGradientFunc): (...args: Tensor[]) => T; + write(dataId: DataId, values: TypedArray): void; + readSync(dataId: DataId): TypedArray; + read(dataId: DataId): Promise; + fromPixels(pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, numChannels: number): Tensor3D; + time(query: () => void): Promise; + private track; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine.js b/node_modules/@tensorflow/tfjs-core/dist/engine.js new file mode 100644 index 0000000..54adb70 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine.js @@ -0,0 +1,376 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var profiler_1 = require("./profiler"); +var tape_1 = require("./tape"); +var tensor_1 = require("./tensor"); +var tensor_util_1 = require("./tensor_util"); +var util = require("./util"); +var util_1 = require("./util"); +var Engine = (function () { + function Engine(backend, safeMode, debugMode) { + this.backend = backend; + this.safeMode = safeMode; + this.debugMode = debugMode; + this.registeredVariables = {}; + this.refCounter = new WeakMap(); + this.nextTapeNodeId = 0; + this.numBytes = 0; + this.numTensors = 0; + this.numDataBuffers = 0; + this.gradientScopeCount = 0; + this.customGradientDepth = 0; + this.keepTensors = new Set(); + this.activeScope = { track: [], name: 'default scope' }; + this.scopeStack = [this.activeScope]; + this.profiler = new profiler_1.Profiler(backend); + } + Engine.prototype.tidy = function (nameOrFn, fn, gradMode) { + var _this = this; + if (gradMode === void 0) { gradMode = false; } + var name = null; + if (fn == null) { + if (typeof nameOrFn !== 'function') { + throw new Error('Please provide a function to tidy()'); + } + fn = nameOrFn; + } + else { + if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) { + throw new Error('When calling with two arguments, the first argument ' + + 'to tidy() must be a string'); + } + if (typeof fn !== 'function') { + throw new Error('When calling with two arguments, the 2nd argument ' + + 'to tidy() must be a function'); + } + name = nameOrFn; + } + var result; + return this.scopedRun(function () { return _this.startScope(name, gradMode); }, function () { return _this.endScope(result, gradMode); }, function () { + result = fn(); + if (result instanceof Promise) { + console.error('Cannot return a Promise inside of tidy.'); + } + return result; + }); + }; + Engine.prototype.scopedRun = function (start, end, f) { + start(); + try { + var res = f(); + end(); + return res; + } + catch (ex) { + end(); + throw ex; + } + }; + Engine.prototype.runKernel = function (forwardFunc, inputs, backwardsFunc) { + var _this = this; + var result; + var saved = []; + var saveFunc = function (x) { + saved.push(x); + return x; + }; + var scopeName = this.activeScope.name; + this.scopedRun(function () { return _this.customGradientDepth++; }, function () { return _this.customGradientDepth--; }, function () { + if (!_this.debugMode()) { + result = forwardFunc(_this.backend, saveFunc); + } + else { + result = _this.profiler.profileKernel(scopeName, function () { return forwardFunc(_this.backend, saveFunc); }); + } + }); + if (this.shouldRecord()) { + var tapeNode = { + id: this.nextTapeNodeId++, + name: scopeName, + inputs: inputs, + output: Array.isArray(result) ? result[0] : result + }; + if (backwardsFunc != null) { + tapeNode.gradient = + (function (dy) { return backwardsFunc(dy, saved); }); + } + this.activeTape.push(tapeNode); + } + return result; + }; + Engine.prototype.registerTensor = function (a) { + var refCount = this.refCounter.has(a.dataId) ? this.refCounter.get(a.dataId) : 0; + this.numTensors++; + if (refCount === 0) { + this.numDataBuffers++; + this.numBytes += + util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype); + this.backend.register(a.dataId, a.shape, a.dtype); + } + this.refCounter.set(a.dataId, refCount + 1); + if (!(a instanceof tensor_1.Variable)) { + this.track(a); + } + }; + Engine.prototype.registerVariable = function (v) { + if (this.registeredVariables[v.name] != null) { + throw new Error("Variable with name " + v.name + " was already registered"); + } + this.registeredVariables[v.name] = v; + }; + Engine.prototype.disposeTensor = function (a) { + if (!this.refCounter.has(a.dataId)) { + return; + } + if (this.keepTensors.has(a.id)) { + this.keepTensors.delete(a.id); + } + this.numTensors--; + var refCount = this.refCounter.get(a.dataId); + if (refCount <= 1) { + this.refCounter.delete(a.dataId); + this.backend.disposeData(a.dataId); + this.numDataBuffers--; + this.numBytes -= + util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype); + } + else { + this.refCounter.set(a.dataId, refCount - 1); + } + }; + Engine.prototype.disposeVariables = function () { + for (var varName in this.registeredVariables) { + var v = this.registeredVariables[varName]; + this.disposeTensor(v); + delete this.registeredVariables[varName]; + } + }; + Engine.prototype.memory = function () { + var info = this.backend.memory(); + info.numTensors = this.numTensors; + info.numDataBuffers = this.numDataBuffers; + info.numBytes = this.numBytes; + return info; + }; + Engine.prototype.shouldRecord = function () { + return this.activeTape != null && this.customGradientDepth === 0; + }; + Engine.prototype.addTapeNode = function (inputs, result, gradientsFunc) { + var inputsMap = {}; + inputs.forEach(function (input, idx) { + inputsMap[idx] = input; + }); + var gradient = function (dy) { + var res = gradientsFunc(dy); + var resMap = {}; + res.forEach(function (r, idx) { + resMap[idx] = function () { return r; }; + }); + return resMap; + }; + var tapeNode = { + id: this.nextTapeNodeId++, + name: this.activeScope.name, + inputs: inputsMap, + output: result, + gradient: gradient + }; + this.activeTape.push(tapeNode); + }; + Engine.prototype.keep = function (result) { + if (this.scopeStack.length === 1 && this.safeMode) { + throw new Error('Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' + + 'tf.tidy(() => {...}) to avoid memory leaks.'); + } + this.keepTensors.add(result.id); + return result; + }; + Engine.prototype.startScope = function (name, gradientsMode) { + if (gradientsMode === void 0) { gradientsMode = false; } + if (gradientsMode && this.gradientScopeCount === 0) { + this.activeTape = []; + } + if (gradientsMode) { + this.gradientScopeCount++; + } + var scopeInfo = { track: [], name: 'unnamed scope' }; + if (name) { + scopeInfo.name = name; + } + this.scopeStack.push(scopeInfo); + this.activeScope = scopeInfo; + }; + Engine.prototype.endScope = function (result, gradientsMode) { + var _this = this; + if (gradientsMode === void 0) { gradientsMode = false; } + if (gradientsMode) { + this.gradientScopeCount--; + if (this.gradientScopeCount === 0) { + this.activeTape = null; + } + } + var tensorsToKeep = new Set(this.keepTensors); + var tensorsToTrackInParent = tensor_util_1.getTensorsInContainer(result); + tensorsToTrackInParent.forEach(function (tensor) { return tensorsToKeep.add(tensor.id); }); + for (var i = 0; i < this.activeScope.track.length; i++) { + var tensor = this.activeScope.track[i]; + if (tensorsToKeep.has(tensor.id)) { + continue; + } + if (this.activeTape != null) { + tensorsToTrackInParent.push(tensor); + } + else { + tensor.dispose(); + } + } + var oldScope = this.scopeStack.pop(); + this.activeScope = this.scopeStack.length === 0 ? + { track: [], name: 'default scope' } : + this.scopeStack[this.scopeStack.length - 1]; + tensorsToTrackInParent.forEach(function (tensor) { + if (!_this.keepTensors.has(tensor.id) && + tensor_util_1.isTensorInList(tensor, oldScope.track)) { + _this.track(tensor); + } + }); + }; + Engine.prototype.gradients = function (f, xs, dy, allowNoGradients) { + var _this = this; + if (allowNoGradients === void 0) { allowNoGradients = false; } + util.assert(xs.length > 0, 'gradients() received an empty list of xs.'); + return this.tidy('gradients', function () { + var y = f(); + util.assert(y instanceof tensor_1.Tensor, 'The result y returned by f() must be a tensor.'); + var filteredTape = tape_1.getFilteredNodesXToY(_this.activeTape, xs, y); + if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) { + throw new Error('Cannot compute gradient of y=f(x) with respect to x. Make sure ' + + 'that the f you passed encloses all operations that lead from x ' + + 'to y.'); + } + var accumulatedGradientMap = {}; + accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy; + tape_1.backpropagateGradients(accumulatedGradientMap, filteredTape); + var grads = xs.map(function (x) { return accumulatedGradientMap[x.id]; }); + return { value: y, grads: grads }; + }, true); + }; + Engine.prototype.customGrad = function (f) { + var _this = this; + util.assert(util.isFunction(f), 'The f passed in customGrad(f) must be a function.'); + return function () { + var inputs = []; + for (var _i = 0; _i < arguments.length; _i++) { + inputs[_i] = arguments[_i]; + } + util.assert(inputs.every(function (t) { return t instanceof tensor_1.Tensor; }), 'The args passed in customGrad(f)(x1, x2,...) must all be tensors'); + var gradientsFunc; + var result; + _this.scopedRun(function () { return _this.customGradientDepth++; }, function () { return _this.customGradientDepth--; }, function () { + var gradientsMode = true; + result = _this.tidy(f.name, function () { + var _a = f.apply(void 0, inputs), value = _a.value, gradFunc = _a.gradFunc; + util.assert(value instanceof tensor_1.Tensor, 'The function f passed in customGrad(f) must return an ' + + 'object where `obj.value` is a tensor'); + util.assert(util.isFunction(gradFunc), 'The function f passed in customGrad(f) must return an ' + + 'object where `obj.gradFunc` is a function.'); + gradientsFunc = gradFunc; + return value; + }, gradientsMode); + }); + if (_this.shouldRecord()) { + var gradFunc = function (dy) { + var res = gradientsFunc(dy); + var grads = Array.isArray(res) ? res : [res]; + util.assert(grads.length === inputs.length, 'The function f passed in customGrad(f) must return an object ' + + 'where `obj.gradFunc` is a function that returns the same ' + + 'number of tensors as inputs passed to f(...).'); + util.assert(grads.every(function (t) { return t instanceof tensor_1.Tensor; }), 'The function f passed in customGrad(f) must return an object ' + + 'where `obj.gradFunc` is a function that returns a list of ' + + 'only tensors.'); + return grads; + }; + _this.addTapeNode(inputs, result, gradFunc); + } + return result; + }; + }; + Engine.prototype.write = function (dataId, values) { + this.backend.write(dataId, values); + }; + Engine.prototype.readSync = function (dataId) { + return this.backend.readSync(dataId); + }; + Engine.prototype.read = function (dataId) { + return this.backend.read(dataId); + }; + Engine.prototype.fromPixels = function (pixels, numChannels) { + return this.backend.fromPixels(pixels, numChannels); + }; + Engine.prototype.time = function (query) { + return __awaiter(this, void 0, void 0, function () { + var start, timingInfo; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + start = util_1.now(); + return [4, this.backend.time(query)]; + case 1: + timingInfo = _a.sent(); + timingInfo.wallMs = util_1.now() - start; + return [2, timingInfo]; + } + }); + }); + }; + Engine.prototype.track = function (result) { + if (this.scopeStack.length === 1 && this.safeMode) { + throw new Error('Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' + + 'tf.tidy(() => {op();...}); to avoid memory leaks.'); + } + this.activeScope.track.push(result); + return result; + }; + return Engine; +}()); +exports.Engine = Engine; +function ones(shape) { + var values = util_1.makeOnesTypedArray(util_1.sizeFromShape(shape), 'float32'); + return tensor_1.Tensor.make(shape, { values: values }); +} +//# sourceMappingURL=engine.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine.js.map b/node_modules/@tensorflow/tfjs-core/dist/engine.js.map new file mode 100644 index 0000000..f315c3f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine.js.map @@ -0,0 +1 @@ +{"version":3,"file":"engine.js","sourceRoot":"","sources":["../src/engine.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/engine_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine_test.js b/node_modules/@tensorflow/tfjs-core/dist/engine_test.js new file mode 100644 index 0000000..39f0fcc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine_test.js @@ -0,0 +1,275 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('fromPixels + regular math op', test_util_1.WEBGL_ENVS, function () { + it('debug mode does not error when no nans', function () { + var pixels = new ImageData(2, 2); + for (var i = 0; i < 8; i++) { + pixels.data[i] = 100; + } + for (var i = 8; i < 16; i++) { + pixels.data[i] = 250; + } + var a = tf.fromPixels(pixels, 4); + var b = tf.scalar(20, 'int32'); + var res = tf.add(a, b); + test_util_1.expectArraysEqual(res, [ + 120, 120, 120, 120, 120, 120, 120, 120, 270, 270, 270, 270, 270, 270, 270, + 270 + ]); + }); +}); +jasmine_util_1.describeWithFlags('gradients', test_util_1.ALL_ENVS, function () { + it('matmul + relu', function () { + var a = tf.tensor2d([-1, 2, -3, 10, -20, 30], [2, 3]); + var b = tf.tensor2d([2, -3, 4, -1, 2, -3], [3, 2]); + var _a = tf.grads(function (a, b) { + var m = tf.matMul(a, b); + var y = tf.relu(m); + return tf.sum(y); + })([a, b]), da = _a[0], db = _a[1]; + var dedm = tf.step(tf.matMul(a, b)); + expect(da.shape).toEqual(a.shape); + var transposeA = false; + var transposeB = true; + test_util_1.expectArraysClose(da, tf.matMul(dedm, b, transposeA, transposeB)); + expect(db.shape).toEqual(b.shape); + transposeA = true; + transposeB = false; + test_util_1.expectArraysClose(db, tf.matMul(a, dedm, transposeA, transposeB)); + }); + it('grad(f)', function () { + var grad = tf.grad(function (x) { return x.square(); }); + var result = grad(tf.tensor1d([.1, .2])); + test_util_1.expectArraysClose(result, [.2, .4]); + }); + it('calling grad(f) twice works', function () { + var grad = tf.grad(function (x) { return x.square(); }); + var result = grad(tf.tensor1d([.1, .2])); + var result2 = grad(tf.tensor1d([.1, .4])); + test_util_1.expectArraysClose(result, [.2, .4]); + test_util_1.expectArraysClose(result2, [.2, .8]); + }); + it('grads(f)', function () { + var grads = tf.grads(function (x) { return x.square(); }); + var result = grads([tf.tensor1d([.1, .2])]); + test_util_1.expectArraysClose(result[0], [.2, .4]); + }); + it('calling grads(f) twice works', function () { + var grads = tf.grads(function (x) { return x.square(); }); + var result = grads([tf.tensor1d([.1, .2])]); + var result2 = grads([tf.tensor1d([.1, .4])]); + test_util_1.expectArraysClose(result[0], [.2, .4]); + test_util_1.expectArraysClose(result2[0], [.2, .8]); + }); + it('works with reshape', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var exponent = tf.tensor1d([2, 2, 2, 2], 'int32'); + var da = tf.grad(function (a) { + var b = a.flatten(); + var m = tf.pow(b, exponent); + return tf.sum(m); + })(a); + expect(da.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(da, [2, 4, 6, 8]); + }); + it('reshape outside tf.grads() throws error', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var b = a.flatten(); + var exponent = tf.tensor1d([2, 2, 2, 2], 'int32'); + var f = function () { + tf.grads(function (a, b) { + var m = tf.pow(b, exponent); + return tf.sum(m); + })([a, b]); + }; + expect(f).toThrowError(); + }); + it('does not error if irrelevant (pruned) ops are missing grads', function () { + var a = tf.tensor1d([true, true], 'bool'); + var b = tf.tensor1d([false, true], 'bool'); + var da = tf.grad(function (a) { + a.logicalAnd(b); + return a.sum(); + })(a); + test_util_1.expectArraysClose(da, [1, 1]); + }); + it('errors if relevant ops are missing grads', function () { + var a = tf.tensor1d([true, true], 'bool'); + var b = tf.tensor1d([false, true], 'bool'); + var dfda = tf.grad(function (a) { + return a.logicalAnd(b); + }); + expect(function () { return dfda(a); }).toThrowError(); + }); + it('works with asType', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var exponent = tf.tensor2d([2, 2, 2, 2], [2, 2], 'int32'); + var da = tf.grad(function (a) { + var b = a.toFloat(); + var m = tf.pow(b, exponent); + return tf.sum(m); + })(a); + expect(da.shape).toEqual([2, 2]); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [2, 4, 6, 8]); + }); + it('asType outside of tf.grads() throws error', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var b = a.toFloat(); + var exponent = tf.tensor2d([2, 2, 2, 2], [2, 2], 'int32'); + var f = function () { + tf.grad(function (a) { + var m = tf.pow(b, exponent); + return tf.sum(m); + })(a); + }; + expect(f).toThrowError(); + }); +}); +jasmine_util_1.describeWithFlags('valueAndGradients', test_util_1.ALL_ENVS, function () { + it('matmul + relu', function () { + var a = tf.tensor2d([-1, 2, -3, 10, -20, 30], [2, 3]); + var b = tf.tensor2d([2, -3, 4, -1, 2, -3], [3, 2]); + var _a = tf.valueAndGrads(function (a, b) { + var m = tf.matMul(a, b); + var y = tf.relu(m); + return tf.sum(y); + })([a, b]), value = _a.value, grads = _a.grads; + test_util_1.expectNumbersClose(value.get(), 10); + var dedm = tf.step(tf.matMul(a, b)); + var da = grads[0], db = grads[1]; + var transposeA = false; + var transposeB = true; + test_util_1.expectArraysClose(da, tf.matMul(dedm, b, transposeA, transposeB)); + transposeA = true; + transposeB = false; + test_util_1.expectArraysClose(db, tf.matMul(a, dedm, transposeA, transposeB)); + }); + it('matmul + relu + inner tidy', function () { + var a = tf.tensor2d([-1, 2, -3, 10, -20, 30], [2, 3]); + var b = tf.tensor2d([2, -3, 4, -1, 2, -3], [3, 2]); + var _a = tf.valueAndGrads(function (a, b) { + var m = tf.matMul(a, b); + return tf.tidy(function () { + var y = tf.relu(m); + return tf.sum(y); + }); + })([a, b]), value = _a.value, grads = _a.grads; + test_util_1.expectNumbersClose(value.get(), 10); + var dedm = tf.step(tf.matMul(a, b)); + var da = grads[0], db = grads[1]; + var transposeA = false; + var transposeB = true; + test_util_1.expectArraysClose(da, tf.matMul(dedm, b, transposeA, transposeB)); + transposeA = true; + transposeB = false; + test_util_1.expectArraysClose(db, tf.matMul(a, dedm, transposeA, transposeB)); + }); +}); +jasmine_util_1.describeWithFlags('higher-order gradients', test_util_1.ALL_ENVS, function () { + it('grad(grad(f))', function () { + var gradgrad = tf.grad(tf.grad(function (x) { return x.mul(x).mul(x); })); + var result = gradgrad(tf.tensor1d([.1, .2])); + test_util_1.expectArraysClose(result, [.6, 1.2]); + }); + it('grads(grads(f))', function () { + var grads = tf.grads(function (x) { return x.mul(x).mul(x); }); + var gradsgrads = tf.grads(function (x) { return grads([x])[0]; }); + var result = gradsgrads([tf.tensor1d([.1, .2])]); + test_util_1.expectArraysClose(result[0], [.6, 1.2]); + }); +}); +jasmine_util_1.describeWithFlags('customGradient', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.scalar(3); + var b = tf.scalar(2, 'int32'); + var dy = tf.scalar(4); + var customPow = tf.customGrad(function (a) { + var value = tf.pow(a, b); + var gradFunc = function (dy) { return dy.mul(tf.scalar(0.1)); }; + return { value: value, gradFunc: gradFunc }; + }); + var _a = tf.valueAndGrad(function (a) { return customPow(a); })(a, dy), value = _a.value, grad = _a.grad; + expect(value.shape).toEqual(a.shape); + test_util_1.expectArraysClose(value, [9]); + expect(grad.shape).toEqual(a.shape); + test_util_1.expectArraysClose(grad, [.4]); + }); + it('second order derivative through customGradient', function () { + var a = tf.scalar(3); + var b = tf.scalar(2, 'int32'); + var dy = tf.scalar(5); + var customPow = tf.customGrad(function (a) { + var value = tf.pow(a, b); + var gradFunc = function (dy) { return dy.mul(a); }; + return { value: value, gradFunc: gradFunc }; + }); + var dda = tf.grad(tf.grad(function (a) { return customPow(a); }))(a, dy); + expect(dda.shape).toEqual(a.shape); + test_util_1.expectArraysClose(dda, dy); + }); + it('calling gradient of custom op twice works', function () { + var customOp = tf.customGrad(function (x) { + return { value: x.square(), gradFunc: function (dy) { return dy.mul(x.abs()); } }; + }); + var x = tf.tensor1d([-1, -2, 3]); + var grad = tf.grad(function (x) { return customOp(x); }); + test_util_1.expectArraysClose(grad(x), [1, 2, 3]); + test_util_1.expectArraysClose(grad(x), [1, 2, 3]); + }); +}); +jasmine_util_1.describeWithFlags('memory', test_util_1.ALL_ENVS, function () { + it('Sum(float)', function () { + expect(tf.memory().numTensors).toBe(0); + expect(tf.memory().numBytes).toBe(0); + var sum = tf.tidy(function () { + var a = tf.tensor1d([1, 2, 3, 4]); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4 * 4); + return a.sum(); + }); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4); + test_util_1.expectArraysClose(sum, [1 + 2 + 3 + 4]); + }); + it('Sum(bool)', function () { + var sum = tf.tidy(function () { + var a = tf.tensor1d([true, true, false, true], 'bool'); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4); + return a.sum(); + }); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4); + expect(sum.dtype).toBe('int32'); + test_util_1.expectArraysClose(sum, [1 + 1 + 0 + 1]); + }); + it('Sum(int32)', function () { + var sum = tf.tidy(function () { + var a = tf.tensor1d([1, 1, 0, 1], 'int32'); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4 * 4); + return a.sum(); + }); + expect(tf.memory().numTensors).toBe(1); + expect(tf.memory().numBytes).toBe(4); + expect(sum.dtype).toBe('int32'); + test_util_1.expectArraysClose(sum, [1 + 1 + 0 + 1]); + }); +}); +jasmine_util_1.describeWithFlags('disposeVariables', test_util_1.ALL_ENVS, function () { + it('reuse same name variable', function () { + tf.tensor1d([1, 2, 3]).variable(true, 'v1'); + tf.tensor1d([1, 2, 3]).variable(true, 'v2'); + expect(function () { + tf.tensor1d([1, 2, 3]).variable(true, 'v1'); + }).toThrowError(); + tf.disposeVariables(); + tf.tensor1d([1, 2, 3]).variable(true, 'v1'); + tf.tensor1d([1, 2, 3]).variable(true, 'v2'); + }); +}); +//# sourceMappingURL=engine_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/engine_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/engine_test.js.map new file mode 100644 index 0000000..1a2c259 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/engine_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"engine_test.js","sourceRoot":"","sources":["../src/engine_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment.d.ts b/node_modules/@tensorflow/tfjs-core/dist/environment.d.ts new file mode 100644 index 0000000..b7a032a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment.d.ts @@ -0,0 +1,35 @@ +import { Engine, MemoryInfo, ScopeFn, TimingInfo } from './engine'; +import { Features } from './environment_util'; +import { KernelBackend } from './kernels/backend'; +import { Tensor, TensorTracker } from './tensor'; +import { TensorContainer } from './tensor_types'; +export declare class Environment { + private features; + private globalEngine; + private registry; + backendName: string; + backend: KernelBackend; + constructor(features?: Features); + static setBackend(backendName: string, safeMode?: boolean): void; + static getBackend(): string; + static disposeVariables(): void; + static memory(): MemoryInfo; + static tidy(nameOrFn: string | ScopeFn, fn?: ScopeFn, gradMode?: boolean): T; + static dispose(container: TensorContainer): void; + static keep(result: T): T; + static time(f: () => void): Promise; + get(feature: K): Features[K]; + getFeatures(): Features; + set(feature: K, value: Features[K]): void; + private getBestBackendName; + private evaluateFeature; + setFeatures(features: Features): void; + reset(): void; + private initBackend; + findBackend(name: string): KernelBackend; + registerBackend(name: string, factory: () => KernelBackend, priority?: number, setTensorTrackerFn?: (f: () => TensorTracker) => void): boolean; + removeBackend(name: string): void; + readonly engine: Engine; + private initDefaultBackend; +} +export declare let ENV: Environment; diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment.js b/node_modules/@tensorflow/tfjs-core/dist/environment.js new file mode 100644 index 0000000..2f60d1c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment.js @@ -0,0 +1,233 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var device_util = require("./device_util"); +var engine_1 = require("./engine"); +var environment_util_1 = require("./environment_util"); +var tensor_1 = require("./tensor"); +var tensor_util_1 = require("./tensor_util"); +var TEST_EPSILON_FLOAT32_ENABLED = 1e-3; +var TEST_EPSILON_FLOAT32_DISABLED = 1e-1; +var Environment = (function () { + function Environment(features) { + this.features = {}; + this.registry = {}; + if (features != null) { + this.features = features; + } + if (this.get('DEBUG')) { + console.warn('Debugging mode is ON. The output of every math call will ' + + 'be downloaded to CPU and checked for NaNs. ' + + 'This significantly impacts performance.'); + } + } + Environment.setBackend = function (backendName, safeMode) { + if (safeMode === void 0) { safeMode = false; } + if (!(backendName in exports.ENV.registry)) { + throw new Error("Backend name '" + backendName + "' not found in registry"); + } + exports.ENV.initBackend(backendName, safeMode); + }; + Environment.getBackend = function () { + exports.ENV.initDefaultBackend(); + return exports.ENV.backendName; + }; + Environment.disposeVariables = function () { + exports.ENV.engine.disposeVariables(); + }; + Environment.memory = function () { + return exports.ENV.engine.memory(); + }; + Environment.tidy = function (nameOrFn, fn, gradMode) { + if (gradMode === void 0) { gradMode = false; } + return exports.ENV.engine.tidy(nameOrFn, fn, gradMode); + }; + Environment.dispose = function (container) { + var tensors = tensor_util_1.getTensorsInContainer(container); + tensors.forEach(function (tensor) { return tensor.dispose(); }); + }; + Environment.keep = function (result) { + return exports.ENV.engine.keep(result); + }; + Environment.time = function (f) { + return exports.ENV.engine.time(f); + }; + Environment.prototype.get = function (feature) { + if (feature in this.features) { + return this.features[feature]; + } + this.features[feature] = this.evaluateFeature(feature); + return this.features[feature]; + }; + Environment.prototype.getFeatures = function () { + return this.features; + }; + Environment.prototype.set = function (feature, value) { + this.features[feature] = value; + }; + Environment.prototype.getBestBackendName = function () { + var _this = this; + if (Object.keys(this.registry).length === 0) { + throw new Error('No backend found in registry.'); + } + var sortedBackends = Object.keys(this.registry) + .map(function (name) { + return { name: name, entry: _this.registry[name] }; + }) + .sort(function (a, b) { + return b.entry.priority - a.entry.priority; + }); + return sortedBackends[0].name; + }; + Environment.prototype.evaluateFeature = function (feature) { + if (feature === 'DEBUG') { + return false; + } + else if (feature === 'IS_BROWSER') { + return typeof window !== 'undefined'; + } + else if (feature === 'IS_NODE') { + return (typeof process !== 'undefined') && + (typeof process.versions.node !== 'undefined'); + } + else if (feature === 'IS_CHROME') { + return environment_util_1.isChrome(); + } + else if (feature === 'IS_TEST') { + return false; + } + else if (feature === 'BACKEND') { + return this.getBestBackendName(); + } + else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') { + var webGLVersion = this.get('WEBGL_VERSION'); + if (webGLVersion === 0) { + return 0; + } + if (webGLVersion > 0) { + return 0; + } + return environment_util_1.getWebGLDisjointQueryTimerVersion(webGLVersion, this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE') { + return this.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0 && + !device_util.isMobile(); + } + else if (feature === 'HAS_WEBGL') { + return this.get('WEBGL_VERSION') > 0; + } + else if (feature === 'WEBGL_VERSION') { + if (environment_util_1.isWebGLVersionEnabled(2, this.get('IS_BROWSER'))) { + return 2; + } + else if (environment_util_1.isWebGLVersionEnabled(1, this.get('IS_BROWSER'))) { + return 1; + } + return 0; + } + else if (feature === 'WEBGL_RENDER_FLOAT32_ENABLED') { + return environment_util_1.isRenderToFloatTextureEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_DOWNLOAD_FLOAT_ENABLED') { + return environment_util_1.isDownloadFloatTextureEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_FENCE_API_ENABLED') { + return environment_util_1.isWebGLFenceEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'TEST_EPSILON') { + if (this.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + return TEST_EPSILON_FLOAT32_ENABLED; + } + return TEST_EPSILON_FLOAT32_DISABLED; + } + throw new Error("Unknown feature " + feature + "."); + }; + Environment.prototype.setFeatures = function (features) { + this.features = Object.assign({}, features); + }; + Environment.prototype.reset = function () { + this.features = environment_util_1.getFeaturesFromURL(); + if (this.globalEngine != null) { + this.globalEngine = null; + } + }; + Environment.prototype.initBackend = function (backendName, safeMode) { + var _this = this; + if (safeMode === void 0) { safeMode = false; } + this.backendName = backendName; + this.backend = this.findBackend(backendName); + this.globalEngine = + new engine_1.Engine(this.backend, safeMode, function () { return _this.get('DEBUG'); }); + }; + Environment.prototype.findBackend = function (name) { + if (!(name in this.registry)) { + return null; + } + return this.registry[name].backend; + }; + Environment.prototype.registerBackend = function (name, factory, priority, setTensorTrackerFn) { + var _this = this; + if (priority === void 0) { priority = 1; } + if (name in this.registry) { + console.warn(name + " backend was already registered. Reusing existing backend"); + if (setTensorTrackerFn != null) { + setTensorTrackerFn(function () { return _this.engine; }); + } + return false; + } + try { + var backend = factory(); + this.registry[name] = { backend: backend, priority: priority }; + return true; + } + catch (err) { + console.warn("Registration of backend " + name + " failed"); + console.warn(err.stack || err.message); + return false; + } + }; + Environment.prototype.removeBackend = function (name) { + if (!(name in this.registry)) { + throw new Error(name + " backend not found in registry"); + } + this.registry[name].backend.dispose(); + delete this.registry[name]; + }; + Object.defineProperty(Environment.prototype, "engine", { + get: function () { + this.initDefaultBackend(); + return this.globalEngine; + }, + enumerable: true, + configurable: true + }); + Environment.prototype.initDefaultBackend = function () { + if (this.globalEngine == null) { + this.initBackend(this.get('BACKEND'), false); + } + }; + return Environment; +}()); +exports.Environment = Environment; +function getGlobalNamespace() { + var ns; + if (typeof (window) !== 'undefined') { + ns = window; + } + else if (typeof (process) !== 'undefined') { + ns = process; + } + else { + throw new Error('Could not find a global object'); + } + return ns; +} +function getOrMakeEnvironment() { + var ns = getGlobalNamespace(); + if (ns.ENV == null) { + ns.ENV = new Environment(environment_util_1.getFeaturesFromURL()); + tensor_1.setTensorTracker(function () { return ns.ENV.engine; }); + } + return ns.ENV; +} +exports.ENV = getOrMakeEnvironment(); +//# sourceMappingURL=environment.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment.js.map b/node_modules/@tensorflow/tfjs-core/dist/environment.js.map new file mode 100644 index 0000000..6e59cf5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment.js.map @@ -0,0 +1 @@ +{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/environment_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_test.js b/node_modules/@tensorflow/tfjs-core/dist/environment_test.js new file mode 100644 index 0000000..85bdb0f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_test.js @@ -0,0 +1,219 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var device_util = require("./device_util"); +var environment_1 = require("./environment"); +var environment_util_1 = require("./environment_util"); +var jasmine_util_1 = require("./jasmine_util"); +var backend_cpu_1 = require("./kernels/backend_cpu"); +var backend_webgl_1 = require("./kernels/backend_webgl"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('disjoint query timer enabled', test_util_1.WEBGL_ENVS, function () { + afterEach(function () { + environment_1.ENV.reset(); + }); + it('no webgl', function () { + environment_1.ENV.setFeatures({ 'WEBGL_VERSION': 0 }); + expect(environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')).toBe(0); + }); + it('webgl 1', function () { + var features = { 'WEBGL_VERSION': 1 }; + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { + if (context === 'webgl' || context === 'experimental-webgl') { + return { + getExtension: function (extensionName) { + if (extensionName === 'EXT_disjoint_timer_query') { + return {}; + } + else if (extensionName === 'WEBGL_lose_context') { + return { loseContext: function () { } }; + } + return null; + } + }; + } + return null; + } + }); + environment_1.ENV.setFeatures(features); + expect(environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')).toBe(0); + }); + it('webgl 2', function () { + var features = { 'WEBGL_VERSION': 2 }; + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { + if (context === 'webgl2') { + return { + getExtension: function (extensionName) { + if (extensionName === 'EXT_disjoint_timer_query_webgl2') { + return {}; + } + else if (extensionName === 'WEBGL_lose_context') { + return { loseContext: function () { } }; + } + return null; + } + }; + } + return null; + } + }); + environment_1.ENV.setFeatures(features); + expect(environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')).toBe(0); + }); +}); +jasmine_util_1.describeWithFlags('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', test_util_1.WEBGL_ENVS, function () { + afterEach(function () { + environment_1.ENV.reset(); + }); + it('disjoint query timer disabled', function () { + var features = { 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION': 0 }; + var env = new environment_1.Environment(features); + expect(env.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE')) + .toBe(false); + }); + it('disjoint query timer enabled, mobile', function () { + var features = { 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION': 1 }; + spyOn(device_util, 'isMobile').and.returnValue(true); + var env = new environment_1.Environment(features); + expect(env.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE')) + .toBe(false); + }); + it('disjoint query timer enabled, not mobile', function () { + var features = { 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION': 1 }; + spyOn(device_util, 'isMobile').and.returnValue(false); + var env = new environment_1.Environment(features); + expect(env.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE')) + .toBe(true); + }); +}); +jasmine_util_1.describeWithFlags('WEBGL_FENCE_API_ENABLED', test_util_1.WEBGL_ENVS, function () { + afterEach(function () { + environment_1.ENV.reset(); + }); + beforeEach(function () { + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { + if (context === 'webgl2') { + return { + getExtension: function (extensionName) { + if (extensionName === 'WEBGL_get_buffer_sub_data_async') { + return {}; + } + else if (extensionName === 'WEBGL_lose_context') { + return { loseContext: function () { } }; + } + return null; + }, + fenceSync: function () { return 1; } + }; + } + return null; + } + }); + }); + it('WebGL 2 enabled', function () { + var features = { 'WEBGL_VERSION': 2 }; + var env = new environment_1.Environment(features); + expect(env.get('WEBGL_FENCE_API_ENABLED')).toBe(true); + }); + it('WebGL 1 disabled', function () { + var features = { 'WEBGL_VERSION': 1 }; + var env = new environment_1.Environment(features); + expect(env.get('WEBGL_FENCE_API_ENABLED')).toBe(false); + }); +}); +jasmine_util_1.describeWithFlags('WebGL version', test_util_1.WEBGL_ENVS, function () { + afterEach(function () { + environment_1.ENV.reset(); + }); + it('webgl 1', function () { + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { + if (context === 'webgl') { + return { + getExtension: function (a) { + return { loseContext: function () { } }; + } + }; + } + return null; + } + }); + var env = new environment_1.Environment(); + expect(env.get('WEBGL_VERSION')).toBe(1); + }); + it('webgl 2', function () { + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { + if (context === 'webgl2') { + return { + getExtension: function (a) { + return { loseContext: function () { } }; + } + }; + } + return null; + } + }); + var env = new environment_1.Environment(); + expect(env.get('WEBGL_VERSION')).toBe(2); + }); + it('no webgl', function () { + spyOn(document, 'createElement').and.returnValue({ + getContext: function (context) { return null; } + }); + var env = new environment_1.Environment(); + expect(env.get('WEBGL_VERSION')).toBe(0); + }); +}); +describe('Backend', function () { + beforeAll(function () { + spyOn(console, 'warn'); + }); + afterEach(function () { + environment_1.ENV.reset(); + }); + it('custom cpu registration', function () { + var backend; + environment_1.ENV.registerBackend('custom-cpu', function () { + backend = new backend_cpu_1.MathBackendCPU(); + return backend; + }); + expect(environment_1.ENV.findBackend('custom-cpu')).toBe(backend); + environment_1.Environment.setBackend('custom-cpu'); + expect(environment_1.ENV.backend).toBe(backend); + environment_1.ENV.removeBackend('custom-cpu'); + }); + it('webgl not supported, falls back to cpu', function () { + environment_1.ENV.setFeatures({ 'WEBGL_VERSION': 0 }); + var cpuBackend; + environment_1.ENV.registerBackend('custom-cpu', function () { + cpuBackend = new backend_cpu_1.MathBackendCPU(); + return cpuBackend; + }, 103); + var success = environment_1.ENV.registerBackend('custom-webgl', function () { return new backend_webgl_1.MathBackendWebGL(); }, 104); + expect(success).toBe(false); + expect(environment_1.ENV.findBackend('custom-webgl') == null).toBe(true); + expect(environment_1.Environment.getBackend()).toBe('custom-cpu'); + expect(environment_1.ENV.backend).toBe(cpuBackend); + environment_1.ENV.removeBackend('custom-cpu'); + }); + it('default custom background null', function () { + expect(environment_1.ENV.findBackend('custom')).toBeNull(); + }); + it('allow custom backend', function () { + var backend = new backend_cpu_1.MathBackendCPU(); + var success = environment_1.ENV.registerBackend('custom', function () { return backend; }); + expect(success).toBeTruthy(); + expect(environment_1.ENV.findBackend('custom')).toEqual(backend); + environment_1.ENV.removeBackend('custom'); + }); +}); +describe('environment_util.getQueryParams', function () { + it('basic', function () { + expect(environment_util_1.getQueryParams('?a=1&b=hi&f=animal')) + .toEqual({ 'a': '1', 'b': 'hi', 'f': 'animal' }); + }); +}); +//# sourceMappingURL=environment_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/environment_test.js.map new file mode 100644 index 0000000..3f4c815 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"environment_test.js","sourceRoot":"","sources":["../src/environment_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/environment_util.d.ts new file mode 100644 index 0000000..0097622 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_util.d.ts @@ -0,0 +1,36 @@ +export interface Features { + 'DEBUG'?: boolean; + 'IS_BROWSER'?: boolean; + 'IS_NODE'?: boolean; + 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'?: number; + 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE'?: boolean; + 'WEBGL_VERSION'?: number; + 'HAS_WEBGL'?: boolean; + 'WEBGL_RENDER_FLOAT32_ENABLED'?: boolean; + 'WEBGL_DOWNLOAD_FLOAT_ENABLED'?: boolean; + 'WEBGL_FENCE_API_ENABLED'?: boolean; + 'BACKEND'?: string; + 'TEST_EPSILON'?: number; + 'IS_CHROME'?: boolean; + 'IS_TEST'?: boolean; +} +export declare enum Type { + NUMBER = 0, + BOOLEAN = 1, + STRING = 2 +} +export declare const URL_PROPERTIES: URLProperty[]; +export interface URLProperty { + name: keyof Features; + type: Type; +} +export declare function isWebGLVersionEnabled(webGLVersion: 1 | 2, isBrowser: boolean): boolean; +export declare function getWebGLDisjointQueryTimerVersion(webGLVersion: number, isBrowser: boolean): number; +export declare function isRenderToFloatTextureEnabled(webGLVersion: number, isBrowser: boolean): boolean; +export declare function isDownloadFloatTextureEnabled(webGLVersion: number, isBrowser: boolean): boolean; +export declare function isWebGLFenceEnabled(webGLVersion: number, isBrowser: boolean): boolean; +export declare function isChrome(): boolean; +export declare function getFeaturesFromURL(): Features; +export declare function getQueryParams(queryString: string): { + [key: string]: string; +}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_util.js b/node_modules/@tensorflow/tfjs-core/dist/environment_util.js new file mode 100644 index 0000000..73ebb5d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_util.js @@ -0,0 +1,200 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Type; +(function (Type) { + Type[Type["NUMBER"] = 0] = "NUMBER"; + Type[Type["BOOLEAN"] = 1] = "BOOLEAN"; + Type[Type["STRING"] = 2] = "STRING"; +})(Type = exports.Type || (exports.Type = {})); +exports.URL_PROPERTIES = [ + { name: 'DEBUG', type: Type.BOOLEAN }, { name: 'IS_BROWSER', type: Type.BOOLEAN }, + { name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION', type: Type.NUMBER }, + { name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', type: Type.BOOLEAN }, + { name: 'WEBGL_VERSION', type: Type.NUMBER }, + { name: 'WEBGL_RENDER_FLOAT32_ENABLED', type: Type.BOOLEAN }, + { name: 'WEBGL_DOWNLOAD_FLOAT_ENABLED', type: Type.BOOLEAN }, + { name: 'WEBGL_FENCE_API_ENABLED', type: Type.BOOLEAN }, + { name: 'BACKEND', type: Type.STRING } +]; +function isWebGLVersionEnabled(webGLVersion, isBrowser) { + var gl; + try { + gl = getWebGLRenderingContext(webGLVersion, isBrowser); + } + catch (e) { + return false; + } + if (gl != null) { + loseContext(gl); + return true; + } + return false; +} +exports.isWebGLVersionEnabled = isWebGLVersionEnabled; +function getWebGLDisjointQueryTimerVersion(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return 0; + } + var queryTimerVersion; + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (hasExtension(gl, 'EXT_disjoint_timer_query_webgl2') && + webGLVersion === 2) { + queryTimerVersion = 2; + } + else if (hasExtension(gl, 'EXT_disjoint_timer_query')) { + queryTimerVersion = 1; + } + else { + queryTimerVersion = 0; + } + if (gl != null) { + loseContext(gl); + } + return queryTimerVersion; +} +exports.getWebGLDisjointQueryTimerVersion = getWebGLDisjointQueryTimerVersion; +function isRenderToFloatTextureEnabled(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (webGLVersion === 1) { + if (!hasExtension(gl, 'OES_texture_float')) { + return false; + } + } + else { + if (!hasExtension(gl, 'EXT_color_buffer_float')) { + return false; + } + } + createFloatTextureAndBindToFramebuffer(gl, webGLVersion); + var isFrameBufferComplete = gl.checkFramebufferStatus(gl.FRAMEBUFFER) === gl.FRAMEBUFFER_COMPLETE; + loseContext(gl); + return isFrameBufferComplete; +} +exports.isRenderToFloatTextureEnabled = isRenderToFloatTextureEnabled; +function isDownloadFloatTextureEnabled(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (webGLVersion === 1) { + if (!hasExtension(gl, 'OES_texture_float')) { + return false; + } + } + else { + if (!hasExtension(gl, 'EXT_color_buffer_float')) { + return false; + } + } + createFloatTextureAndBindToFramebuffer(gl, webGLVersion); + gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.FLOAT, new Float32Array(4)); + var readPixelsNoError = gl.getError() === gl.NO_ERROR; + loseContext(gl); + return readPixelsNoError; +} +exports.isDownloadFloatTextureEnabled = isDownloadFloatTextureEnabled; +function isWebGLFenceEnabled(webGLVersion, isBrowser) { + if (webGLVersion !== 2) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + var isEnabled = gl.fenceSync != null; + loseContext(gl); + return isEnabled; +} +exports.isWebGLFenceEnabled = isWebGLFenceEnabled; +function isChrome() { + return typeof navigator !== 'undefined' && navigator != null && + navigator.userAgent != null && /Chrome/.test(navigator.userAgent) && + /Google Inc/.test(navigator.vendor); +} +exports.isChrome = isChrome; +var TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags'; +function getFeaturesFromURL() { + var features = {}; + if (typeof window === 'undefined' || typeof window.location === 'undefined') { + return features; + } + var urlParams = getQueryParams(window.location.search); + if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) { + var urlFlags_1 = {}; + var keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(','); + keyValues.forEach(function (keyValue) { + var _a = keyValue.split(':'), key = _a[0], value = _a[1]; + urlFlags_1[key] = value; + }); + exports.URL_PROPERTIES.forEach(function (urlProperty) { + if (urlProperty.name in urlFlags_1) { + console.log("Setting feature override from URL " + urlProperty.name + ": " + + ("" + urlFlags_1[urlProperty.name])); + if (urlProperty.type === Type.NUMBER) { + features[urlProperty.name] = +urlFlags_1[urlProperty.name]; + } + else if (urlProperty.type === Type.BOOLEAN) { + features[urlProperty.name] = urlFlags_1[urlProperty.name] === 'true'; + } + else if (urlProperty.type === Type.STRING) { + features[urlProperty.name] = urlFlags_1[urlProperty.name]; + } + else { + console.warn("Unknown URL param: " + urlProperty.name + "."); + } + } + }); + } + return features; +} +exports.getFeaturesFromURL = getFeaturesFromURL; +function hasExtension(gl, extensionName) { + var ext = gl.getExtension(extensionName); + return ext != null; +} +function getWebGLRenderingContext(webGLVersion, isBrowser) { + if (webGLVersion === 0 || !isBrowser) { + throw new Error('Cannot get WebGL rendering context, WebGL is disabled.'); + } + var tempCanvas = document.createElement('canvas'); + if (webGLVersion === 1) { + return (tempCanvas.getContext('webgl') || + tempCanvas.getContext('experimental-webgl')); + } + return tempCanvas.getContext('webgl2'); +} +function loseContext(gl) { + if (gl != null) { + var loseContextExtension = gl.getExtension('WEBGL_lose_context'); + if (loseContextExtension == null) { + throw new Error('Extension WEBGL_lose_context not supported on this browser.'); + } + loseContextExtension.loseContext(); + } +} +function createFloatTextureAndBindToFramebuffer(gl, webGLVersion) { + var frameBuffer = gl.createFramebuffer(); + var texture = gl.createTexture(); + gl.bindTexture(gl.TEXTURE_2D, texture); + var internalFormat = webGLVersion === 2 ? gl.RGBA32F : gl.RGBA; + gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, 1, 1, 0, gl.RGBA, gl.FLOAT, null); + gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer); + gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0); +} +function getQueryParams(queryString) { + var params = {}; + queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, function (s) { + var t = []; + for (var _i = 1; _i < arguments.length; _i++) { + t[_i - 1] = arguments[_i]; + } + decodeParam(params, t[0], t[1]); + return t.join('='); + }); + return params; +} +exports.getQueryParams = getQueryParams; +function decodeParam(params, name, value) { + params[decodeURIComponent(name)] = decodeURIComponent(value || ''); +} +//# sourceMappingURL=environment_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/environment_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/environment_util.js.map new file mode 100644 index 0000000..032419f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/environment_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"environment_util.js","sourceRoot":"","sources":["../src/environment_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/globals.d.ts b/node_modules/@tensorflow/tfjs-core/dist/globals.d.ts new file mode 100644 index 0000000..a603763 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/globals.d.ts @@ -0,0 +1,6 @@ +import { Environment } from './environment'; +export { customGrad, grad, grads, valueAndGrad, valueAndGrads, variableGrads } from './gradients'; +export declare const tidy: typeof Environment.tidy; +export declare const keep: typeof Environment.keep; +export declare const dispose: typeof Environment.dispose; +export declare const time: typeof Environment.time; diff --git a/node_modules/@tensorflow/tfjs-core/dist/globals.js b/node_modules/@tensorflow/tfjs-core/dist/globals.js new file mode 100644 index 0000000..578bfa2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/globals.js @@ -0,0 +1,15 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +var gradients_1 = require("./gradients"); +exports.customGrad = gradients_1.customGrad; +exports.grad = gradients_1.grad; +exports.grads = gradients_1.grads; +exports.valueAndGrad = gradients_1.valueAndGrad; +exports.valueAndGrads = gradients_1.valueAndGrads; +exports.variableGrads = gradients_1.variableGrads; +exports.tidy = environment_1.Environment.tidy; +exports.keep = environment_1.Environment.keep; +exports.dispose = environment_1.Environment.dispose; +exports.time = environment_1.Environment.time; +//# sourceMappingURL=globals.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/globals.js.map b/node_modules/@tensorflow/tfjs-core/dist/globals.js.map new file mode 100644 index 0000000..55dbd3e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/globals.js.map @@ -0,0 +1 @@ +{"version":3,"file":"globals.js","sourceRoot":"","sources":["../src/globals.ts"],"names":[],"mappings":";;AAiBA,6CAA0C;AAC1C,yCAAgG;AAAxF,iCAAA,UAAU,CAAA;AAAE,2BAAA,IAAI,CAAA;AAAE,4BAAA,KAAK,CAAA;AAAE,mCAAA,YAAY,CAAA;AAAE,oCAAA,aAAa,CAAA;AAAE,oCAAA,aAAa,CAAA;AAE9D,QAAA,IAAI,GAAG,yBAAW,CAAC,IAAI,CAAC;AACxB,QAAA,IAAI,GAAG,yBAAW,CAAC,IAAI,CAAC;AACxB,QAAA,OAAO,GAAG,yBAAW,CAAC,OAAO,CAAC;AAC9B,QAAA,IAAI,GAAG,yBAAW,CAAC,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/gradients.d.ts b/node_modules/@tensorflow/tfjs-core/dist/gradients.d.ts new file mode 100644 index 0000000..9198615 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/gradients.d.ts @@ -0,0 +1,20 @@ +import { CustomGradientFunc, ScopeFn } from './engine'; +import { Scalar, Tensor, Variable } from './tensor'; +import { NamedTensorMap, TensorContainer } from './tensor_types'; +declare function gradScope(nameOrScopeFn: string | ScopeFn, scopeFn?: ScopeFn): T; +declare function grad(f: (x: I) => O): (x: I, dy?: O) => I; +declare function grads(f: (...args: Tensor[]) => O): (args: Tensor[], dy?: O) => Tensor[]; +declare function valueAndGrad(f: (x: I) => O): (x: I, dy?: O) => { + value: O; + grad: I; +}; +declare function valueAndGrads(f: (...args: Tensor[]) => O): (args: Tensor[], dy?: O) => { + grads: Tensor[]; + value: O; +}; +declare function variableGrads(f: () => Scalar, varList?: Variable[]): { + value: Scalar; + grads: NamedTensorMap; +}; +declare function customGrad(f: CustomGradientFunc): (...args: Tensor[]) => T; +export { gradScope, customGrad, variableGrads, valueAndGrad, valueAndGrads, grad, grads, }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/gradients.js b/node_modules/@tensorflow/tfjs-core/dist/gradients.js new file mode 100644 index 0000000..d74545a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/gradients.js @@ -0,0 +1,112 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +var tensor_1 = require("./tensor"); +var util = require("./util"); +function gradScope(nameOrScopeFn, scopeFn) { + return environment_1.ENV.engine.tidy(nameOrScopeFn, scopeFn, true); +} +exports.gradScope = gradScope; +function grad(f) { + util.assert(util.isFunction(f), 'The f passed in grad(f) must be a function'); + return function (x, dy) { + util.assert(x instanceof tensor_1.Tensor, 'The x passed in grad(f)(x) must be a tensor'); + util.assert(dy == null || dy instanceof tensor_1.Tensor, 'The dy passed in grad(f)(x, dy) must be a tensor'); + return environment_1.ENV.engine.tidy(function () { + var _a = environment_1.ENV.engine.gradients(function () { return f(x); }, [x], dy), value = _a.value, grads = _a.grads; + if (dy != null) { + util.assertShapesMatch(value.shape, dy.shape, 'The shape of dy passed in grad(f)(x, dy) must match the shape ' + + 'returned by f(x)'); + } + checkGrads(grads); + return grads[0]; + }); + }; +} +exports.grad = grad; +function grads(f) { + util.assert(util.isFunction(f), 'The f passed in grads(f) must be a function'); + return function (args, dy) { + util.assert(Array.isArray(args) && args.every(function (arg) { return arg instanceof tensor_1.Tensor; }), 'The args passed in grads(f)(args) must be an array of tensors'); + util.assert(dy == null || dy instanceof tensor_1.Tensor, 'The dy passed in grads(f)(args, dy) must be a tensor'); + return environment_1.ENV.engine.tidy(function () { + var _a = environment_1.ENV.engine.gradients(function () { return f.apply(void 0, args); }, args, dy), value = _a.value, grads = _a.grads; + if (dy != null) { + util.assertShapesMatch(value.shape, dy.shape, 'The shape of dy passed in grads(f)([x1,...], dy) must ' + + 'match the shape returned by f([x1,...])'); + } + checkGrads(grads); + return grads; + }); + }; +} +exports.grads = grads; +function valueAndGrad(f) { + util.assert(util.isFunction(f), 'The f passed in valueAndGrad(f) must be a function'); + return function (x, dy) { + util.assert(x instanceof tensor_1.Tensor, 'The x passed in valueAndGrad(f)(x) must be a tensor'); + util.assert(dy == null || dy instanceof tensor_1.Tensor, 'The dy passed in valueAndGrad(f)(x, dy) must be a tensor'); + var _a = environment_1.ENV.engine.gradients(function () { return f(x); }, [x], dy), grads = _a.grads, value = _a.value; + checkGrads(grads); + return { grad: grads[0], value: value }; + }; +} +exports.valueAndGrad = valueAndGrad; +function valueAndGrads(f) { + util.assert(util.isFunction(f), 'The f passed in valueAndGrads(f) must be a function'); + return function (args, dy) { + util.assert(Array.isArray(args) && args.every(function (arg) { return arg instanceof tensor_1.Tensor; }), 'The args passed in valueAndGrads(f)(args) must be array of tensors'); + util.assert(dy == null || dy instanceof tensor_1.Tensor, 'The dy passed in valueAndGrads(f)(args, dy) must be a tensor'); + var res = environment_1.ENV.engine.gradients(function () { return f.apply(void 0, args); }, args, dy); + if (dy != null) { + util.assertShapesMatch(res.value.shape, dy.shape, 'The shape of dy passed in valueAndGrads(f)([x1,...], dy) must ' + + 'match the shape returned by f([x1,...])'); + } + checkGrads(res.grads); + return res; + }; +} +exports.valueAndGrads = valueAndGrads; +function variableGrads(f, varList) { + util.assert(util.isFunction(f), 'The f passed in variableGrads(f) must be a function'); + util.assert(varList == null || + Array.isArray(varList) && varList.every(function (v) { return v instanceof tensor_1.Variable; }), 'The varList passed in variableGrads(f, varList) must be an array ' + + 'of variables'); + if (varList == null) { + varList = []; + for (var varName in environment_1.ENV.engine.registeredVariables) { + varList.push(environment_1.ENV.engine.registeredVariables[varName]); + } + } + var originalVarCount = varList.length; + varList = varList.filter(function (variable) { return variable.trainable; }); + util.assert(varList.length > 0, "variableGrads() expects at least one of the input variables to be " + + ("trainable, but none of the " + originalVarCount + " variables is ") + + "trainable."); + var allowNoGradients = true; + var _a = environment_1.ENV.engine.gradients(f, varList, null, allowNoGradients), value = _a.value, grads = _a.grads; + util.assert(grads.some(function (g) { return g != null; }), 'Cannot find a connection between any variable and the result of the ' + + 'loss function y=f(x). Please make sure the operations that use ' + + 'variables are inside the function f passed to minimize().'); + util.assert(value.rank === 0, "The f passed in variableGrads(f) must return a scalar, but it " + + ("returned a rank-" + value.rank + " tensor")); + var namedGrads = {}; + varList.forEach(function (v, i) { + if (grads[i] != null) { + namedGrads[v.name] = grads[i]; + } + }); + return { value: value, grads: namedGrads }; +} +exports.variableGrads = variableGrads; +function customGrad(f) { + return environment_1.ENV.engine.customGrad(f); +} +exports.customGrad = customGrad; +function checkGrads(grads) { + var numNullGradients = grads.filter(function (g) { return g == null; }).length; + if (numNullGradients > 0) { + throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y."); + } +} +//# sourceMappingURL=gradients.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/gradients.js.map b/node_modules/@tensorflow/tfjs-core/dist/gradients.js.map new file mode 100644 index 0000000..6d35893 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/gradients.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gradients.js","sourceRoot":"","sources":["../src/gradients.ts"],"names":[],"mappings":";;AAkBA,6CAAkC;AAClC,mCAAkD;AAElD,6BAA+B;AAa/B,mBACI,aAAgC,EAAE,OAAoB;IACxD,OAAO,iBAAG,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAiB,CAAC;AACvE,CAAC;AAuUC,8BAAS;AApSX,cAAkD,CAAc;IAE9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,4CAA4C,CAAC,CAAC;IAC9E,OAAO,UAAC,CAAI,EAAE,EAAM;QAClB,IAAI,CAAC,MAAM,CACP,CAAC,YAAY,eAAM,EAAE,6CAA6C,CAAC,CAAC;QACxE,IAAI,CAAC,MAAM,CACP,EAAE,IAAI,IAAI,IAAI,EAAE,YAAY,eAAM,EAClC,kDAAkD,CAAC,CAAC;QACxD,OAAO,iBAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACf,IAAA,8EAA0D,EAAzD,gBAAK,EAAE,gBAAK,CAA8C;YACjE,IAAI,EAAE,IAAI,IAAI,EAAE;gBACd,IAAI,CAAC,iBAAiB,CAClB,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,EACrB,gEAAgE;oBAC5D,kBAAkB,CAAC,CAAC;aAC7B;YACD,UAAU,CAAC,KAAK,CAAC,CAAC;YAClB,OAAO,KAAK,CAAC,CAAC,CAAM,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAoRC,oBAAI;AAtPN,eAAiC,CAA2B;IAE1D,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,6CAA6C,CAAC,CAAC;IACvE,OAAO,UAAC,IAAc,EAAE,EAAM;QAC5B,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAA,GAAG,IAAI,OAAA,GAAG,YAAY,eAAM,EAArB,CAAqB,CAAC,EAC/D,+DAA+D,CAAC,CAAC;QACrE,IAAI,CAAC,MAAM,CACP,EAAE,IAAI,IAAI,IAAI,EAAE,YAAY,eAAM,EAClC,sDAAsD,CAAC,CAAC;QAC5D,OAAO,iBAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACf,IAAA,gGAAiE,EAAhE,gBAAK,EAAE,gBAAK,CAAqD;YACxE,IAAI,EAAE,IAAI,IAAI,EAAE;gBACd,IAAI,CAAC,iBAAiB,CAClB,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,EACrB,wDAAwD;oBACpD,yCAAyC,CAAC,CAAC;aACpD;YACD,UAAU,CAAC,KAAK,CAAC,CAAC;YAClB,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAgOC,sBAAK;AAtMP,sBAA0D,CAAc;IAKtE,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,oDAAoD,CAAC,CAAC;IAC9E,OAAO,UAAC,CAAI,EAAE,EAAM;QAClB,IAAI,CAAC,MAAM,CACP,CAAC,YAAY,eAAM,EACnB,qDAAqD,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,CACP,EAAE,IAAI,IAAI,IAAI,EAAE,YAAY,eAAM,EAClC,0DAA0D,CAAC,CAAC;QAC1D,IAAA,8EAA0D,EAAzD,gBAAK,EAAE,gBAAK,CAA8C;QACjE,UAAU,CAAC,KAAK,CAAC,CAAC;QAClB,OAAO,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAM,EAAE,KAAK,EAAE,KAAU,EAAC,CAAC;IAClD,CAAC,CAAC;AACJ,CAAC;AAiLC,oCAAY;AAjJd,uBAAyC,CAA2B;IAKlE,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAClB,qDAAqD,CAAC,CAAC;IAC3D,OAAO,UAAC,IAAc,EAAE,EAAM;QAC5B,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAA,GAAG,IAAI,OAAA,GAAG,YAAY,eAAM,EAArB,CAAqB,CAAC,EAC/D,oEAAoE,CAAC,CAAC;QAC1E,IAAI,CAAC,MAAM,CACP,EAAE,IAAI,IAAI,IAAI,EAAE,YAAY,eAAM,EAClC,8DAA8D,CAAC,CAAC;QACpE,IAAM,GAAG,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAAC,cAAM,OAAA,CAAC,eAAI,IAAI,GAAT,CAAU,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;QAC7D,IAAI,EAAE,IAAI,IAAI,EAAE;YACd,IAAI,CAAC,iBAAiB,CAClB,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,EACzB,gEAAgE;gBAC5D,yCAAyC,CAAC,CAAC;SACpD;QACD,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;AACJ,CAAC;AAyHC,sCAAa;AAjGf,uBAAuB,CAAe,EAAE,OAAoB;IAE1D,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAClB,qDAAqD,CAAC,CAAC;IAC3D,IAAI,CAAC,MAAM,CACP,OAAO,IAAI,IAAI;QACX,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,YAAY,iBAAQ,EAArB,CAAqB,CAAC,EACvE,mEAAmE;QAC/D,cAAc,CAAC,CAAC;IACxB,IAAI,OAAO,IAAI,IAAI,EAAE;QAEnB,OAAO,GAAG,EAAE,CAAC;QACb,KAAK,IAAM,OAAO,IAAI,iBAAG,CAAC,MAAM,CAAC,mBAAmB,EAAE;YACpD,OAAO,CAAC,IAAI,CAAC,iBAAG,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;SACvD;KACF;IAED,IAAM,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC;IACxC,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,UAAA,QAAQ,IAAI,OAAA,QAAQ,CAAC,SAAS,EAAlB,CAAkB,CAAC,CAAC;IACzD,IAAI,CAAC,MAAM,CACP,OAAO,CAAC,MAAM,GAAG,CAAC,EAClB,oEAAoE;SAChE,gCAA8B,gBAAgB,mBAAgB,CAAA;QAC9D,YAAY,CAAC,CAAC;IAEtB,IAAM,gBAAgB,GAAG,IAAI,CAAC;IACxB,IAAA,2EACsD,EADrD,gBAAK,EAAE,gBAAK,CAC0C;IAE7D,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,IAAI,IAAI,EAAT,CAAS,CAAC,EAC1B,sEAAsE;QAClE,iEAAiE;QACjE,2DAA2D,CAAC,CAAC;IACrE,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,KAAK,CAAC,EAChB,gEAAgE;SAC5D,qBAAmB,KAAK,CAAC,IAAI,YAAS,CAAA,CAAC,CAAC;IAEhD,IAAM,UAAU,GAAmB,EAAE,CAAC;IACtC,OAAO,CAAC,OAAO,CAAC,UAAC,CAAC,EAAE,CAAC;QACnB,IAAI,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;YACpB,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;SAC/B;IACH,CAAC,CAAC,CAAC;IACH,OAAO,EAAC,KAAK,OAAA,EAAE,KAAK,EAAE,UAAU,EAAC,CAAC;AACpC,CAAC;AAgDC,sCAAa;AAjBf,oBAAsC,CAAwB;IAE5D,OAAO,iBAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;AAClC,CAAC;AAaC,gCAAU;AAXZ,oBAAoB,KAAe;IACjC,IAAM,gBAAgB,GAAG,KAAK,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,IAAI,IAAI,EAAT,CAAS,CAAC,CAAC,MAAM,CAAC;IAC7D,IAAI,gBAAgB,GAAG,CAAC,EAAE;QACxB,MAAM,IAAI,KAAK,CACX,0IAC4D,CAAC,CAAC;KACnE;AACH,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/index.d.ts b/node_modules/@tensorflow/tfjs-core/dist/index.d.ts new file mode 100644 index 0000000..cb0ca49 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/index.d.ts @@ -0,0 +1,38 @@ +import './kernels/backend_webgl'; +import './kernels/backend_cpu'; +import { nextFrame } from './browser_util'; +import * as environment from './environment'; +import * as io from './io/io'; +import * as serialization from './serialization'; +import * as test_util from './test_util'; +import * as util from './util'; +import { version } from './version'; +import * as webgl from './webgl'; +export { InferenceModel, ModelPredictConfig } from './model_types'; +export { AdadeltaOptimizer } from './optimizers/adadelta_optimizer'; +export { AdagradOptimizer } from './optimizers/adagrad_optimizer'; +export { AdamOptimizer } from './optimizers/adam_optimizer'; +export { AdamaxOptimizer } from './optimizers/adamax_optimizer'; +export { MomentumOptimizer } from './optimizers/momentum_optimizer'; +export { Optimizer } from './optimizers/optimizer'; +export { RMSPropOptimizer } from './optimizers/rmsprop_optimizer'; +export { SGDOptimizer } from './optimizers/sgd_optimizer'; +export { Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer, variable, Variable } from './tensor'; +export { NamedTensorMap } from './tensor_types'; +export { DataType, Rank, ShapeMap } from './types'; +export * from './ops/ops'; +export { LSTMCellFunc } from './ops/lstm'; +export { Reduction } from './ops/loss_ops'; +export * from './train'; +export * from './globals'; +export { Features } from './environment_util'; +export { TimingInfo } from './engine'; +export { ENV, Environment } from './environment'; +export declare const setBackend: typeof environment.Environment.setBackend; +export declare const getBackend: typeof environment.Environment.getBackend; +export declare const disposeVariables: typeof environment.Environment.disposeVariables; +export declare const memory: typeof environment.Environment.memory; +export { version as version_core }; +export { nextFrame }; +export { environment, io, serialization, test_util, util, webgl }; +export { KernelBackend, BackendTimingInfo } from './kernels/backend'; diff --git a/node_modules/@tensorflow/tfjs-core/dist/index.js b/node_modules/@tensorflow/tfjs-core/dist/index.js new file mode 100644 index 0000000..338637a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/index.js @@ -0,0 +1,63 @@ +"use strict"; +function __export(m) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} +Object.defineProperty(exports, "__esModule", { value: true }); +require("./kernels/backend_webgl"); +require("./kernels/backend_cpu"); +var browser_util_1 = require("./browser_util"); +exports.nextFrame = browser_util_1.nextFrame; +var environment = require("./environment"); +exports.environment = environment; +var environment_1 = require("./environment"); +var io = require("./io/io"); +exports.io = io; +var serialization = require("./serialization"); +exports.serialization = serialization; +var tensor_1 = require("./tensor"); +var test_util = require("./test_util"); +exports.test_util = test_util; +var util = require("./util"); +exports.util = util; +var version_1 = require("./version"); +exports.version_core = version_1.version; +var webgl = require("./webgl"); +exports.webgl = webgl; +var adadelta_optimizer_1 = require("./optimizers/adadelta_optimizer"); +exports.AdadeltaOptimizer = adadelta_optimizer_1.AdadeltaOptimizer; +var adagrad_optimizer_1 = require("./optimizers/adagrad_optimizer"); +exports.AdagradOptimizer = adagrad_optimizer_1.AdagradOptimizer; +var adam_optimizer_1 = require("./optimizers/adam_optimizer"); +exports.AdamOptimizer = adam_optimizer_1.AdamOptimizer; +var adamax_optimizer_1 = require("./optimizers/adamax_optimizer"); +exports.AdamaxOptimizer = adamax_optimizer_1.AdamaxOptimizer; +var momentum_optimizer_1 = require("./optimizers/momentum_optimizer"); +exports.MomentumOptimizer = momentum_optimizer_1.MomentumOptimizer; +var optimizer_1 = require("./optimizers/optimizer"); +exports.Optimizer = optimizer_1.Optimizer; +var rmsprop_optimizer_1 = require("./optimizers/rmsprop_optimizer"); +exports.RMSPropOptimizer = rmsprop_optimizer_1.RMSPropOptimizer; +var sgd_optimizer_1 = require("./optimizers/sgd_optimizer"); +exports.SGDOptimizer = sgd_optimizer_1.SGDOptimizer; +var tensor_2 = require("./tensor"); +exports.Tensor = tensor_2.Tensor; +exports.TensorBuffer = tensor_2.TensorBuffer; +exports.variable = tensor_2.variable; +exports.Variable = tensor_2.Variable; +var types_1 = require("./types"); +exports.Rank = types_1.Rank; +__export(require("./ops/ops")); +var loss_ops_1 = require("./ops/loss_ops"); +exports.Reduction = loss_ops_1.Reduction; +__export(require("./train")); +__export(require("./globals")); +var environment_2 = require("./environment"); +exports.ENV = environment_2.ENV; +exports.Environment = environment_2.Environment; +exports.setBackend = environment_1.Environment.setBackend; +exports.getBackend = environment_1.Environment.getBackend; +exports.disposeVariables = environment_1.Environment.disposeVariables; +exports.memory = environment_1.Environment.memory; +var ops = require("./ops/ops"); +tensor_1.setOpHandler(ops); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/index.js.map b/node_modules/@tensorflow/tfjs-core/dist/index.js.map new file mode 100644 index 0000000..489d543 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAoBA,mCAAiC;AACjC,iCAA+B;AAE/B,+CAAyC;AA6CjC,oBA7CA,wBAAS,CA6CA;AA5CjB,2CAA6C;AA+CrC,kCAAW;AA9CnB,6CAA0C;AAG1C,4BAA8B;AA2CT,gBAAE;AA1CvB,+CAAiD;AA0CxB,sCAAa;AAzCtC,mCAAsC;AACtC,uCAAyC;AAwCD,8BAAS;AAvCjD,6BAA+B;AAuCoB,oBAAI;AAtCvD,qCAAkC;AAiCf,uBAjCX,iBAAO,CAiCgB;AAhC/B,+BAAiC;AAqCwB,sBAAK;AAhC9D,sEAAkE;AAA1D,iDAAA,iBAAiB,CAAA;AACzB,oEAAgE;AAAxD,+CAAA,gBAAgB,CAAA;AACxB,8DAA0D;AAAlD,yCAAA,aAAa,CAAA;AACrB,kEAA8D;AAAtD,6CAAA,eAAe,CAAA;AACvB,sEAAkE;AAA1D,iDAAA,iBAAiB,CAAA;AACzB,oDAAiD;AAAzC,gCAAA,SAAS,CAAA;AACjB,oEAAgE;AAAxD,+CAAA,gBAAgB,CAAA;AACxB,4DAAwD;AAAhD,uCAAA,YAAY,CAAA;AACpB,mCAAkH;AAAlG,0BAAA,MAAM,CAAA;AAA0C,gCAAA,YAAY,CAAA;AAAE,4BAAA,QAAQ,CAAA;AAAE,4BAAA,QAAQ,CAAA;AAEhG,iCAAiD;AAA/B,uBAAA,IAAI,CAAA;AAEtB,+BAA0B;AAE1B,2CAAyC;AAAjC,+BAAA,SAAS,CAAA;AAEjB,6BAAwB;AACxB,+BAA0B;AAI1B,6CAA+C;AAAvC,4BAAA,GAAG,CAAA;AAAE,oCAAA,WAAW,CAAA;AAEX,QAAA,UAAU,GAAG,yBAAW,CAAC,UAAU,CAAC;AACpC,QAAA,UAAU,GAAG,yBAAW,CAAC,UAAU,CAAC;AACpC,QAAA,gBAAgB,GAAG,yBAAW,CAAC,gBAAgB,CAAC;AAChD,QAAA,MAAM,GAAG,yBAAW,CAAC,MAAM,CAAC;AAWzC,+BAAiC;AACjC,qBAAY,CAAC,GAAG,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.d.ts new file mode 100644 index 0000000..384ec0e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.d.ts @@ -0,0 +1,14 @@ +import { IORouter } from './router_registry'; +import { IOHandler, ModelArtifacts, SaveResult } from './types'; +export declare class BrowserDownloads implements IOHandler { + private readonly modelTopologyFileName; + private readonly weightDataFileName; + private readonly jsonAnchor; + private readonly weightDataAnchor; + static readonly URL_SCHEME: string; + constructor(fileNamePrefix?: string); + save(modelArtifacts: ModelArtifacts): Promise; +} +export declare const browserDownloadsRouter: IORouter; +export declare function browserDownloads(fileNamePrefix?: string): IOHandler; +export declare function browserFiles(files: File[]): IOHandler; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js new file mode 100644 index 0000000..3345b4f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js @@ -0,0 +1,240 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var io_utils_1 = require("./io_utils"); +var router_registry_1 = require("./router_registry"); +var DEFAULT_FILE_NAME_PREFIX = 'model'; +var DEFAULT_JSON_EXTENSION_NAME = '.json'; +var DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin'; +var BrowserDownloads = (function () { + function BrowserDownloads(fileNamePrefix) { + if (!environment_1.ENV.get('IS_BROWSER')) { + throw new Error('triggerDownloads() cannot proceed because the current environment ' + + 'is not a browser.'); + } + if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) { + fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length); + } + if (fileNamePrefix == null || fileNamePrefix.length === 0) { + fileNamePrefix = DEFAULT_FILE_NAME_PREFIX; + } + this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME; + this.weightDataFileName = + fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME; + } + BrowserDownloads.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var weightsURL, weightsManifest, modelTopologyAndWeightManifest, modelTopologyAndWeightManifestURL, jsonAnchor, weightDataAnchor; + return __generator(this, function (_a) { + weightsURL = window.URL.createObjectURL(new Blob([modelArtifacts.weightData], { type: 'application/octet-stream' })); + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('DownloadTrigger.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + else { + weightsManifest = [{ + paths: ['./' + this.weightDataFileName], + weights: modelArtifacts.weightSpecs + }]; + modelTopologyAndWeightManifest = { + modelTopology: modelArtifacts.modelTopology, + weightsManifest: weightsManifest + }; + modelTopologyAndWeightManifestURL = window.URL.createObjectURL(new Blob([JSON.stringify(modelTopologyAndWeightManifest)], { type: 'application/json' })); + jsonAnchor = this.jsonAnchor == null ? document.createElement('a') : + this.jsonAnchor; + jsonAnchor.download = this.modelTopologyFileName; + jsonAnchor.href = modelTopologyAndWeightManifestURL; + jsonAnchor.click(); + if (modelArtifacts.weightData != null) { + weightDataAnchor = this.weightDataAnchor == null ? + document.createElement('a') : + this.weightDataAnchor; + weightDataAnchor.download = this.weightDataFileName; + weightDataAnchor.href = weightsURL; + weightDataAnchor.click(); + } + return [2, { modelArtifactsInfo: io_utils_1.getModelArtifactsInfoForJSON(modelArtifacts) }]; + } + return [2]; + }); + }); + }; + BrowserDownloads.URL_SCHEME = 'downloads://'; + return BrowserDownloads; +}()); +exports.BrowserDownloads = BrowserDownloads; +var BrowserFiles = (function () { + function BrowserFiles(files) { + if (files == null || files.length < 1) { + throw new Error("When calling browserFiles, at least 1 file is required, " + + ("but received " + files)); + } + this.files = files; + } + BrowserFiles.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var jsonFile, weightFiles; + var _this = this; + return __generator(this, function (_a) { + jsonFile = this.files[0]; + weightFiles = this.files.slice(1); + return [2, new Promise(function (resolve, reject) { + var jsonReader = new FileReader(); + jsonReader.onload = function (event) { + var modelJSON = JSON.parse(event.target.result); + var modelTopology = modelJSON.modelTopology; + if (modelTopology == null) { + reject(new Error("modelTopology field is missing from file " + jsonFile.name)); + return; + } + if (weightFiles.length === 0) { + resolve({ modelTopology: modelTopology }); + } + var weightsManifest = modelJSON.weightsManifest; + if (weightsManifest == null) { + reject(new Error("weightManifest field is missing from file " + jsonFile.name)); + return; + } + var pathToFile; + try { + pathToFile = + _this.checkManifestAndWeightFiles(weightsManifest, weightFiles); + } + catch (err) { + reject(err); + return; + } + var weightSpecs = []; + var paths = []; + var perFileBuffers = []; + weightsManifest.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + paths.push(path); + perFileBuffers.push(null); + }); + weightSpecs.push.apply(weightSpecs, weightsGroup.weights); + }); + weightsManifest.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + var weightFileReader = new FileReader(); + weightFileReader.onload = function (event) { + var weightData = event.target.result; + var index = paths.indexOf(path); + perFileBuffers[index] = weightData; + if (perFileBuffers.indexOf(null) === -1) { + resolve({ + modelTopology: modelTopology, + weightSpecs: weightSpecs, + weightData: io_utils_1.concatenateArrayBuffers(perFileBuffers), + }); + } + }; + weightFileReader.onerror = function (error) { + reject("Failed to weights data from file of path '" + path + "'."); + return; + }; + weightFileReader.readAsArrayBuffer(pathToFile[path]); + }); + }); + }; + jsonReader.onerror = function (error) { + reject("Failed to read model topology and weights manifest JSON " + + ("from file '" + jsonFile.name + "'. BrowserFiles supports loading ") + + "Keras-style tf.Model artifacts only."); + return; + }; + jsonReader.readAsText(jsonFile); + })]; + }); + }); + }; + BrowserFiles.prototype.checkManifestAndWeightFiles = function (manifest, files) { + var basenames = []; + var fileNames = files.map(function (file) { return io_utils_1.basename(file.name); }); + var pathToFile = {}; + for (var _i = 0, manifest_1 = manifest; _i < manifest_1.length; _i++) { + var group = manifest_1[_i]; + group.paths.forEach(function (path) { + var pathBasename = io_utils_1.basename(path); + if (basenames.indexOf(pathBasename) !== -1) { + throw new Error("Duplicate file basename found in weights manifest: " + + ("'" + pathBasename + "'")); + } + basenames.push(pathBasename); + if (fileNames.indexOf(pathBasename) === -1) { + throw new Error("Weight file with basename '" + pathBasename + "' is not provided."); + } + else { + pathToFile[path] = files[fileNames.indexOf(pathBasename)]; + } + }); + } + if (basenames.length !== files.length) { + throw new Error("Mismatch in the number of files in weights manifest " + + ("(" + basenames.length + ") and the number of weight files provided ") + + ("(" + files.length + ").")); + } + return pathToFile; + }; + return BrowserFiles; +}()); +exports.browserDownloadsRouter = function (url) { + if (!environment_1.ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserDownloads.URL_SCHEME)) { + return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length)); + } + else { + return null; + } + } +}; +router_registry_1.IORouterRegistry.registerSaveRouter(exports.browserDownloadsRouter); +function browserDownloads(fileNamePrefix) { + if (fileNamePrefix === void 0) { fileNamePrefix = 'model'; } + return new BrowserDownloads(fileNamePrefix); +} +exports.browserDownloads = browserDownloads; +function browserFiles(files) { + return new BrowserFiles(files); +} +exports.browserFiles = browserFiles; +//# sourceMappingURL=browser_files.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js.map new file mode 100644 index 0000000..a9d4068 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_files.js","sourceRoot":"","sources":["../../src/io/browser_files.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBA,8CAAmC;AACnC,uCAA2F;AAC3F,qDAA6D;AAG7D,IAAM,wBAAwB,GAAG,OAAO,CAAC;AACzC,IAAM,2BAA2B,GAAG,OAAO,CAAC;AAC5C,IAAM,kCAAkC,GAAG,cAAc,CAAC;AAE1D;IAQE,0BAAY,cAAuB;QACjC,IAAI,CAAC,iBAAG,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YAG1B,MAAM,IAAI,KAAK,CACX,oEAAoE;gBACpE,mBAAmB,CAAC,CAAC;SAC1B;QAED,IAAI,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC,UAAU,CAAC,EAAE;YAC1D,cAAc,GAAG,cAAc,CAAC,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;SAC3E;QACD,IAAI,cAAc,IAAI,IAAI,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE;YACzD,cAAc,GAAG,wBAAwB,CAAC;SAC3C;QAED,IAAI,CAAC,qBAAqB,GAAG,cAAc,GAAG,2BAA2B,CAAC;QAC1E,IAAI,CAAC,kBAAkB;YACnB,cAAc,GAAG,kCAAkC,CAAC;IAC1D,CAAC;IAEK,+BAAI,GAAV,UAAW,cAA8B;;;;gBACjC,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI,CAClD,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC,CAAC;gBAEtE,IAAI,cAAc,CAAC,aAAa,YAAY,WAAW,EAAE;oBACvD,MAAM,IAAI,KAAK,CACX,gEAAgE;wBAChE,wBAAwB,CAAC,CAAC;iBAC/B;qBAAM;oBACC,eAAe,GAA0B,CAAC;4BAC9C,KAAK,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC;4BACvC,OAAO,EAAE,cAAc,CAAC,WAAW;yBACpC,CAAC,CAAC;oBACG,8BAA8B,GAAG;wBACrC,aAAa,EAAE,cAAc,CAAC,aAAa;wBAC3C,eAAe,iBAAA;qBAChB,CAAC;oBACI,iCAAiC,GACnC,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI,CAC/B,CAAC,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,CAAC,EAChD,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC,CAAC;oBAI/B,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;wBAC7B,IAAI,CAAC,UAAU,CAAC;oBAC7D,UAAU,CAAC,QAAQ,GAAG,IAAI,CAAC,qBAAqB,CAAC;oBACjD,UAAU,CAAC,IAAI,GAAG,iCAAiC,CAAC;oBAGpD,UAAU,CAAC,KAAK,EAAE,CAAC;oBAEnB,IAAI,cAAc,CAAC,UAAU,IAAI,IAAI,EAAE;wBAC/B,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,CAAC;4BACpD,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;4BAC7B,IAAI,CAAC,gBAAgB,CAAC;wBAC1B,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC;wBACpD,gBAAgB,CAAC,IAAI,GAAG,UAAU,CAAC;wBACnC,gBAAgB,CAAC,KAAK,EAAE,CAAC;qBAC1B;oBAED,WAAO,EAAC,kBAAkB,EAAE,uCAA4B,CAAC,cAAc,CAAC,EAAC,EAAC;iBAC3E;;;;KACF;IAlEe,2BAAU,GAAG,cAAc,CAAC;IAmE9C,uBAAC;CAAA,AAzED,IAyEC;AAzEY,4CAAgB;AA2E7B;IAGE,sBAAY,KAAa;QACvB,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACrC,MAAM,IAAI,KAAK,CACX,0DAA0D;iBAC1D,kBAAgB,KAAO,CAAA,CAAC,CAAC;SAC9B;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAEK,2BAAI,GAAV;;;;;gBACQ,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACzB,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAExC,WAAO,IAAI,OAAO,CAAiB,UAAC,OAAO,EAAE,MAAM;wBACjD,IAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;wBACpC,UAAU,CAAC,MAAM,GAAG,UAAC,KAAY;4BAE/B,IAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAE,KAAK,CAAC,MAAc,CAAC,MAAM,CAAC,CAAC;4BAC3D,IAAM,aAAa,GAAG,SAAS,CAAC,aAAmB,CAAC;4BACpD,IAAI,aAAa,IAAI,IAAI,EAAE;gCACzB,MAAM,CAAC,IAAI,KAAK,CACZ,8CAA4C,QAAQ,CAAC,IAAM,CAAC,CAAC,CAAC;gCAClE,OAAO;6BACR;4BAED,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;gCAC5B,OAAO,CAAC,EAAC,aAAa,eAAA,EAAC,CAAC,CAAC;6BAC1B;4BAED,IAAM,eAAe,GACjB,SAAS,CAAC,eAAwC,CAAC;4BACvD,IAAI,eAAe,IAAI,IAAI,EAAE;gCAC3B,MAAM,CAAC,IAAI,KAAK,CACZ,+CAA6C,QAAQ,CAAC,IAAM,CAAC,CAAC,CAAC;gCACnE,OAAO;6BACR;4BAED,IAAI,UAAkC,CAAC;4BACvC,IAAI;gCACF,UAAU;oCACN,KAAI,CAAC,2BAA2B,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;6BACpE;4BAAC,OAAO,GAAG,EAAE;gCACZ,MAAM,CAAC,GAAG,CAAC,CAAC;gCACZ,OAAO;6BACR;4BAED,IAAM,WAAW,GAA2B,EAAE,CAAC;4BAC/C,IAAM,KAAK,GAAa,EAAE,CAAC;4BAC3B,IAAM,cAAc,GAAkB,EAAE,CAAC;4BACzC,eAAe,CAAC,OAAO,CAAC,UAAA,YAAY;gCAClC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI;oCAC7B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oCACjB,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gCAC5B,CAAC,CAAC,CAAC;gCACH,WAAW,CAAC,IAAI,OAAhB,WAAW,EAAS,YAAY,CAAC,OAAO,EAAE;4BAC5C,CAAC,CAAC,CAAC;4BAEH,eAAe,CAAC,OAAO,CAAC,UAAA,YAAY;gCAClC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI;oCAC7B,IAAM,gBAAgB,GAAG,IAAI,UAAU,EAAE,CAAC;oCAC1C,gBAAgB,CAAC,MAAM,GAAG,UAAC,KAAY;wCAErC,IAAM,UAAU,GAAI,KAAK,CAAC,MAAc,CAAC,MAAqB,CAAC;wCAC/D,IAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;wCAClC,cAAc,CAAC,KAAK,CAAC,GAAG,UAAU,CAAC;wCACnC,IAAI,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;4CACvC,OAAO,CAAC;gDACN,aAAa,eAAA;gDACb,WAAW,aAAA;gDACX,UAAU,EAAE,kCAAuB,CAAC,cAAc,CAAC;6CACpD,CAAC,CAAC;yCACJ;oCACH,CAAC,CAAC;oCACF,gBAAgB,CAAC,OAAO,GAAG,UAAC,KAA8B;wCACxD,MAAM,CAAC,+CAA6C,IAAI,OAAI,CAAC,CAAC;wCAC9D,OAAO;oCACT,CAAC,CAAC;oCACF,gBAAgB,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;gCACvD,CAAC,CAAC,CAAC;4BACL,CAAC,CAAC,CAAC;wBACL,CAAC,CAAC;wBACF,UAAU,CAAC,OAAO,GAAG,UAAC,KAA8B;4BAClD,MAAM,CACF,0DAA0D;iCAC1D,gBAAc,QAAQ,CAAC,IAAI,sCAAmC,CAAA;gCAC9D,sCAAsC,CAAC,CAAC;4BAC5C,OAAO;wBACT,CAAC,CAAC;wBACF,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;oBAClC,CAAC,CAAC,EAAC;;;KACJ;IAKO,kDAA2B,GAAnC,UACI,QAA+B,EAAE,KAAa;QAChD,IAAM,SAAS,GAAa,EAAE,CAAC;QAC/B,IAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,UAAA,IAAI,IAAI,OAAA,mBAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAnB,CAAmB,CAAC,CAAC;QACzD,IAAM,UAAU,GAA2B,EAAE,CAAC;QAC9C,KAAoB,UAAQ,EAAR,qBAAQ,EAAR,sBAAQ,EAAR,IAAQ,EAAE;YAAzB,IAAM,KAAK,iBAAA;YACd,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI;gBACtB,IAAM,YAAY,GAAG,mBAAQ,CAAC,IAAI,CAAC,CAAC;gBACpC,IAAI,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE;oBAC1C,MAAM,IAAI,KAAK,CACX,qDAAqD;yBACrD,MAAI,YAAY,MAAG,CAAA,CAAC,CAAC;iBAC1B;gBACD,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC7B,IAAI,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE;oBAC1C,MAAM,IAAI,KAAK,CACX,gCAA8B,YAAY,uBAAoB,CAAC,CAAC;iBACrE;qBAAM;oBACL,UAAU,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;iBAC3D;YACH,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,SAAS,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,EAAE;YACrC,MAAM,IAAI,KAAK,CACX,sDAAsD;iBACtD,MAAI,SAAS,CAAC,MAAM,+CAA4C,CAAA;iBAChE,MAAI,KAAK,CAAC,MAAM,OAAI,CAAA,CAAC,CAAC;SAC3B;QACD,OAAO,UAAU,CAAC;IACpB,CAAC;IACH,mBAAC;AAAD,CAAC,AAjID,IAiIC;AAEY,QAAA,sBAAsB,GAAa,UAAC,GAAW;IAC1D,IAAI,CAAC,iBAAG,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;QAC1B,OAAO,IAAI,CAAC;KACb;SAAM;QACL,IAAI,GAAG,CAAC,UAAU,CAAC,gBAAgB,CAAC,UAAU,CAAC,EAAE;YAC/C,OAAO,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;SACxE;aAAM;YACL,OAAO,IAAI,CAAC;SACb;KACF;AACH,CAAC,CAAC;AACF,kCAAgB,CAAC,kBAAkB,CAAC,8BAAsB,CAAC,CAAC;AAkC5D,0BAAiC,cAAwB;IAAxB,+BAAA,EAAA,wBAAwB;IACvD,OAAO,IAAI,gBAAgB,CAAC,cAAc,CAAC,CAAC;AAC9C,CAAC;AAFD,4CAEC;AAmCD,sBAA6B,KAAa;IACxC,OAAO,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC;AACjC,CAAC;AAFD,oCAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js new file mode 100644 index 0000000..d0219ae --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js @@ -0,0 +1,689 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var browser_files_1 = require("./browser_files"); +var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' +}; +var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } +]; +var weightData1 = new ArrayBuffer(16); +var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, +}; +jasmine_util_1.describeWithFlags('browserDownloads', test_util_1.BROWSER_ENVS, function () { + var FakeHTMLAnchorElement = (function () { + function FakeHTMLAnchorElement() { + this.clicked = 0; + } + FakeHTMLAnchorElement.prototype.click = function () { + this.clicked++; + }; + return FakeHTMLAnchorElement; + }()); + var fakeAnchors = []; + var fakeAnchorCount = 0; + beforeEach(function () { + fakeAnchorCount = 0; + fakeAnchors = [new FakeHTMLAnchorElement(), new FakeHTMLAnchorElement()]; + spyOn(document, 'createElement').and.callFake(function (tag) { + return fakeAnchors[fakeAnchorCount++]; + }); + }); + it('Explicit file name prefix, with existing anchors', function (done) { + var testStartDate = new Date(); + var downloadTrigger = tf.io.getSaveHandlers('downloads://test-model')[0]; + downloadTrigger.save(artifacts1) + .then(function (saveResult) { return __awaiter(_this, void 0, void 0, function () { + var artifactsInfo, jsonAnchor, weightDataAnchor, jsonContent, modelTopologyAndWeightsManifest, _a, _b, weightsManifest, weightsContent, fileReader, _c, _d; + return __generator(this, function (_e) { + switch (_e.label) { + case 0: + expect(saveResult.errors).toEqual(undefined); + artifactsInfo = saveResult.modelArtifactsInfo; + expect(artifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(16); + jsonAnchor = fakeAnchors[0]; + weightDataAnchor = fakeAnchors[1]; + expect(jsonAnchor.download).toEqual('test-model.json'); + expect(weightDataAnchor.download).toEqual('test-model.weights.bin'); + return [4, fetch(jsonAnchor.href)]; + case 1: + jsonContent = _e.sent(); + _b = (_a = JSON).parse; + return [4, jsonContent.text()]; + case 2: + modelTopologyAndWeightsManifest = _b.apply(_a, [_e.sent()]); + expect(modelTopologyAndWeightsManifest.modelTopology) + .toEqual(modelTopology1); + weightsManifest = modelTopologyAndWeightsManifest.weightsManifest; + expect(weightsManifest.length).toEqual(1); + expect(weightsManifest[0].paths).toEqual([ + './test-model.weights.bin' + ]); + expect(weightsManifest[0].weights).toEqual(weightSpecs1); + return [4, fetch(weightDataAnchor.href)]; + case 3: + weightsContent = _e.sent(); + fileReader = new FileReader(); + fileReader.onload = function (event) { + var buffer = event.target.result; + expect(buffer).toEqual(weightData1); + done(); + }; + _d = (_c = fileReader).readAsArrayBuffer; + return [4, weightsContent.blob()]; + case 4: + _d.apply(_c, [_e.sent()]); + expect(jsonAnchor.clicked).toEqual(1); + expect(weightDataAnchor.clicked).toEqual(1); + return [2]; + } + }); + }); }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('URL scheme in explicit name gets stripped', function (done) { + var testStartDate = new Date(); + var downloadTrigger = browser_files_1.browserDownloads('downloads://test-model'); + downloadTrigger.save(artifacts1) + .then(function (saveResult) { return __awaiter(_this, void 0, void 0, function () { + var artifactsInfo, jsonAnchor, weightDataAnchor, jsonContent, modelTopologyAndWeightsManifest, _a, _b, weightsManifest, weightsContent, fileReader, _c, _d; + return __generator(this, function (_e) { + switch (_e.label) { + case 0: + expect(saveResult.errors).toEqual(undefined); + artifactsInfo = saveResult.modelArtifactsInfo; + expect(artifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(16); + jsonAnchor = fakeAnchors[0]; + weightDataAnchor = fakeAnchors[1]; + expect(jsonAnchor.download).toEqual('test-model.json'); + expect(weightDataAnchor.download).toEqual('test-model.weights.bin'); + return [4, fetch(jsonAnchor.href)]; + case 1: + jsonContent = _e.sent(); + _b = (_a = JSON).parse; + return [4, jsonContent.text()]; + case 2: + modelTopologyAndWeightsManifest = _b.apply(_a, [_e.sent()]); + expect(modelTopologyAndWeightsManifest.modelTopology) + .toEqual(modelTopology1); + weightsManifest = modelTopologyAndWeightsManifest.weightsManifest; + expect(weightsManifest.length).toEqual(1); + expect(weightsManifest[0].paths).toEqual([ + './test-model.weights.bin' + ]); + expect(weightsManifest[0].weights).toEqual(weightSpecs1); + return [4, fetch(weightDataAnchor.href)]; + case 3: + weightsContent = _e.sent(); + fileReader = new FileReader(); + fileReader.onload = function (event) { + var buffer = event.target.result; + expect(buffer).toEqual(weightData1); + done(); + }; + _d = (_c = fileReader).readAsArrayBuffer; + return [4, weightsContent.blob()]; + case 4: + _d.apply(_c, [_e.sent()]); + expect(jsonAnchor.clicked).toEqual(1); + expect(weightDataAnchor.clicked).toEqual(1); + return [2]; + } + }); + }); }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('No file name provided, with existing anchors', function (done) { + var testStartDate = new Date(); + var downloadTrigger = browser_files_1.browserDownloads(); + downloadTrigger.save(artifacts1) + .then(function (saveResult) { return __awaiter(_this, void 0, void 0, function () { + var artifactsInfo, jsonAnchor, weightDataAnchor, jsonContent, modelTopologyAndWeightsManifest, _a, _b, weightsManifest, weightsContent, fileReader, _c, _d; + return __generator(this, function (_e) { + switch (_e.label) { + case 0: + expect(saveResult.errors).toEqual(undefined); + artifactsInfo = saveResult.modelArtifactsInfo; + expect(artifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(16); + jsonAnchor = fakeAnchors[0]; + weightDataAnchor = fakeAnchors[1]; + expect(jsonAnchor.download).toEqual('model.json'); + expect(weightDataAnchor.download).toEqual('model.weights.bin'); + return [4, fetch(jsonAnchor.href)]; + case 1: + jsonContent = _e.sent(); + _b = (_a = JSON).parse; + return [4, jsonContent.text()]; + case 2: + modelTopologyAndWeightsManifest = _b.apply(_a, [_e.sent()]); + expect(modelTopologyAndWeightsManifest.modelTopology) + .toEqual(modelTopology1); + weightsManifest = modelTopologyAndWeightsManifest.weightsManifest; + expect(weightsManifest.length).toEqual(1); + expect(weightsManifest[0].paths).toEqual(['./model.weights.bin']); + expect(weightsManifest[0].weights).toEqual(weightSpecs1); + return [4, fetch(weightDataAnchor.href)]; + case 3: + weightsContent = _e.sent(); + fileReader = new FileReader(); + fileReader.onload = function (event) { + var buffer = event.target.result; + expect(buffer).toEqual(weightData1); + done(); + }; + _d = (_c = fileReader).readAsArrayBuffer; + return [4, weightsContent.blob()]; + case 4: + _d.apply(_c, [_e.sent()]); + return [2]; + } + }); + }); }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('Download only model topology', function (done) { + var testStartDate = new Date(); + var downloadTrigger = browser_files_1.browserDownloads(); + var modelTopologyOnlyArtifacts = { + modelTopology: modelTopology1, + }; + downloadTrigger.save(modelTopologyOnlyArtifacts) + .then(function (saveResult) { return __awaiter(_this, void 0, void 0, function () { + var artifactsInfo, jsonAnchor, weightDataAnchor, jsonContent, modelTopologyAndWeightsManifest, _a, _b; + return __generator(this, function (_c) { + switch (_c.label) { + case 0: + expect(saveResult.errors).toEqual(undefined); + artifactsInfo = saveResult.modelArtifactsInfo; + expect(artifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes).toEqual(0); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(0); + jsonAnchor = fakeAnchors[0]; + weightDataAnchor = fakeAnchors[1]; + expect(jsonAnchor.download).toEqual('model.json'); + expect(jsonAnchor.clicked).toEqual(1); + expect(weightDataAnchor.download).toEqual(undefined); + expect(weightDataAnchor.clicked).toEqual(0); + return [4, fetch(jsonAnchor.href)]; + case 1: + jsonContent = _c.sent(); + _b = (_a = JSON).parse; + return [4, jsonContent.text()]; + case 2: + modelTopologyAndWeightsManifest = _b.apply(_a, [_c.sent()]); + expect(modelTopologyAndWeightsManifest.modelTopology) + .toEqual(modelTopology1); + done(); + return [2]; + } + }); + }); }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('browserDownloadsRouter', function () { + expect(browser_files_1.browserDownloadsRouter('downloads://foo') instanceof browser_files_1.BrowserDownloads) + .toEqual(true); + expect(browser_files_1.browserDownloadsRouter('invaliddownloads://foo')).toBeNull(); + expect(browser_files_1.browserDownloadsRouter('foo')).toBeNull(); + }); +}); +jasmine_util_1.describeWithFlags('browserFiles', test_util_1.BROWSER_ENVS, function () { + var weightsBlob = new Blob([weightData1], { type: 'application/octet-stream' }); + var weightsFile = new File([weightsBlob], 'model.weights.bin', { type: 'application/octet-stream' }); + it('One group, one path', function (done) { + var weightsManifest = [{ + paths: ['./model.weights.bin'], + weights: weightSpecs1, + }]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile]); + filesHandler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toEqual(weightSpecs1); + expect(new Uint8Array(modelArtifacts.weightData)) + .toEqual(new Uint8Array(weightData1)); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it("One group, two paths", function (done) { + var weightSpecs = [ + { + name: 'foo', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'bar', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightsManifest = [{ + paths: ['./dir1/model.weights.1.bin', './dir2/model.weights.2.bin'], + weights: weightSpecs, + }]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 2, 3, 4]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 20, 30, 40]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.2.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile1, weightsFile2]); + filesHandler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toEqual(weightSpecs); + expect(new Uint8Array(modelArtifacts.weightData)) + .toEqual(new Uint8Array([1, 2, 3, 4, 10, 20, 30, 40])); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it("Two groups, four paths, reverseOrder=false", function (done) { + var weightSpecs1 = [ + { + name: 'foo', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'bar', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightSpecs2 = [ + { + name: 'baz', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'qux', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightsManifest = [ + { + paths: ['./model.weights.1.bin', './model.weights.2.bin'], + weights: weightSpecs1, + }, + { + paths: ['./model.weights.3.bin', './model.weights.4.bin'], + weights: weightSpecs2, + } + ]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 3, 5, 7]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 30, 50, 70]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.2.bin', { type: 'application/octet-stream' }); + var weightsBlob3 = new Blob([new Uint8Array([2, 4, 6, 8]).buffer], { type: 'application/octet-stream' }); + var weightsFile3 = new File([weightsBlob3], 'model.weights.3.bin', { type: 'application/octet-stream' }); + var weightsBlob4 = new Blob([new Uint8Array([20, 40, 60, 80]).buffer], { type: 'application/octet-stream' }); + var weightsFile4 = new File([weightsBlob4], 'model.weights.4.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile1, weightsFile2, weightsFile3, weightsFile4]); + filesHandler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightSpecs1.concat(weightSpecs2)); + expect(new Uint8Array(modelArtifacts.weightData)) + .toEqual(new Uint8Array([1, 3, 5, 7, 10, 30, 50, 70, 2, 4, 6, 8, 20, 40, 60, 80])); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it("Two groups, four paths, reverseOrder=true", function (done) { + var weightSpecs1 = [ + { + name: 'foo', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'bar', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightSpecs2 = [ + { + name: 'baz', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'qux', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightsManifest = [ + { + paths: ['./model.weights.1.bin', './model.weights.2.bin'], + weights: weightSpecs1, + }, + { + paths: ['./model.weights.3.bin', './model.weights.4.bin'], + weights: weightSpecs2, + } + ]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 3, 5, 7]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 30, 50, 70]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.2.bin', { type: 'application/octet-stream' }); + var weightsBlob3 = new Blob([new Uint8Array([2, 4, 6, 8]).buffer], { type: 'application/octet-stream' }); + var weightsFile3 = new File([weightsBlob3], 'model.weights.3.bin', { type: 'application/octet-stream' }); + var weightsBlob4 = new Blob([new Uint8Array([20, 40, 60, 80]).buffer], { type: 'application/octet-stream' }); + var weightsFile4 = new File([weightsBlob4], 'model.weights.4.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile4, weightsFile3, weightsFile2, weightsFile1]); + filesHandler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightSpecs1.concat(weightSpecs2)); + expect(new Uint8Array(modelArtifacts.weightData)) + .toEqual(new Uint8Array([1, 3, 5, 7, 10, 30, 50, 70, 2, 4, 6, 8, 20, 40, 60, 80])); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('Upload model topology only', function (done) { + var weightsManifest = [{ + paths: ['./model.weights.bin'], + weights: weightSpecs1, + }]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile]); + filesHandler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toEqual(undefined); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('Mismatch in number of paths and number of files', function (done) { + var weightsManifest = [{ + paths: ['./model.weights.1.bin'], + weights: weightSpecs1, + }]; + var weightsTopologyAndManifest = { + modelTopology: weightSpecs1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 2, 3, 4]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 20, 30, 40]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.2.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile2, weightsFile1]); + filesHandler.load() + .then(function (modelArtifacts) { + done.fail('Loading with mismatch in number of paths and number of files ' + + 'succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Mismatch in the number of files in weights manifest (1) ' + + 'and the number of weight files provided (2).'); + done(); + }); + }); + it('Mismatch in manifest paths and file names', function (done) { + var weightSpecs = [ + { + name: 'foo', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'bar', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightsManifest = [{ + paths: ['./model.weights.1.bin', './model.weights.2.bin'], + weights: weightSpecs, + }]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 2, 3, 4]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 20, 30, 40]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.3.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile1, weightsFile2]); + filesHandler.load() + .then(function (modelArtifacts) { + done.fail('Loading with mismatching paths and file names ' + + 'succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Weight file with basename \'model.weights.2.bin\' is not ' + + 'provided.'); + done(); + }); + }); + it('Duplicate basenames in paths fails', function (done) { + var weightSpecs = [ + { + name: 'foo', + shape: [1, 1], + dtype: 'float32', + }, + { + name: 'bar', + shape: [1, 1], + dtype: 'float32', + } + ]; + var weightsManifest = [{ + paths: ['./dir1/model.weights.1.bin', './dir2/model.weights.1.bin'], + weights: weightSpecs, + }]; + var weightsTopologyAndManifest = { + modelTopology: modelTopology1, + weightsManifest: weightsManifest, + }; + var weightsBlob1 = new Blob([new Uint8Array([1, 2, 3, 4]).buffer], { type: 'application/octet-stream' }); + var weightsFile1 = new File([weightsBlob1], 'model.weights.1.bin', { type: 'application/octet-stream' }); + var weightsBlob2 = new Blob([new Uint8Array([10, 20, 30, 40]).buffer], { type: 'application/octet-stream' }); + var weightsFile2 = new File([weightsBlob2], 'model.weights.2.bin', { type: 'application/octet-stream' }); + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile1, weightsFile2]); + filesHandler.load() + .then(function (modelArtifacts) { + done.fail('Loading with duplicate basenames in paths ' + + 'succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Duplicate file basename found in weights manifest: ' + + '\'model.weights.1.bin\''); + done(); + }); + }); + it('Missing modelTopology from JSON leads to Error', function (done) { + var weightsManifest = [{ + paths: ['./model.weights.bin'], + weights: weightSpecs1, + }]; + var weightsTopologyAndManifest = { + weightsManifest: weightsManifest, + }; + var jsonBlob = new Blob([JSON.stringify(weightsTopologyAndManifest)], { type: 'application/json' }); + var jsonFile = new File([jsonBlob], 'model.json', { type: 'application/json' }); + var filesHandler = tf.io.browserFiles([jsonFile, weightsFile]); + filesHandler.load() + .then(function (modelArtifacts) { + done.fail('Loading with Files IOHandler with missing modelTopology ' + + 'succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toMatch(/modelTopology field is missing from file model\.json/); + done(); + }); + }); + it('Incorrect number of files leads to Error', function () { + expect(function () { return tf.io.browserFiles(null); }).toThrowError(/at least 1 file/); + expect(function () { return tf.io.browserFiles([]); }).toThrowError(/at least 1 file/); + }); +}); +//# sourceMappingURL=browser_files_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js.map new file mode 100644 index 0000000..8799dee --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_files_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_files_test.js","sourceRoot":"","sources":["../../src/io/browser_files_test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBA,iBA+wBA;;AA/wBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAA0C;AAC1C,iDAA2F;AAG3F,IAAM,cAAc,GAAO;IACzB,YAAY,EAAE,YAAY;IAC1B,eAAe,EAAE,OAAO;IACxB,QAAQ,EAAE,CAAC;YACT,YAAY,EAAE,OAAO;YACrB,QAAQ,EAAE;gBACR,oBAAoB,EAAE;oBACpB,YAAY,EAAE,iBAAiB;oBAC/B,QAAQ,EAAE;wBACR,cAAc,EAAE,SAAS;wBACzB,OAAO,EAAE,GAAG;wBACZ,MAAM,EAAE,IAAI;wBACZ,MAAM,EAAE,SAAS;qBAClB;iBACF;gBACD,MAAM,EAAE,OAAO;gBACf,mBAAmB,EAAE,IAAI;gBACzB,kBAAkB,EAAE,IAAI;gBACxB,iBAAiB,EAAE,IAAI;gBACvB,OAAO,EAAE,SAAS;gBAClB,YAAY,EAAE,QAAQ;gBACtB,WAAW,EAAE,IAAI;gBACjB,oBAAoB,EAAE,IAAI;gBAC1B,kBAAkB,EAAE,EAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAC;gBACzD,OAAO,EAAE,CAAC;gBACV,mBAAmB,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC9B,UAAU,EAAE,IAAI;gBAChB,sBAAsB,EAAE,IAAI;aAC7B;SACF,CAAC;IACF,SAAS,EAAE,YAAY;CACxB,CAAC;AACF,IAAM,YAAY,GAAiC;IACjD;QACE,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QACb,KAAK,EAAE,SAAS;KACjB;IACD;QACE,IAAI,EAAE,YAAY;QAClB,KAAK,EAAE,CAAC,CAAC,CAAC;QACV,KAAK,EAAE,SAAS;KACjB;CACF,CAAC;AACF,IAAM,WAAW,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;AACxC,IAAM,UAAU,GAAyB;IACvC,aAAa,EAAE,cAAc;IAC7B,WAAW,EAAE,YAAY;IACzB,UAAU,EAAE,WAAW;CACxB,CAAC;AAEF,gCAAiB,CAAC,kBAAkB,EAAE,wBAAY,EAAE;IAClD;QAKE;YACE,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACnB,CAAC;QAED,qCAAK,GAAL;YACE,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC;QACH,4BAAC;IAAD,CAAC,AAZD,IAYC;IAED,IAAI,WAAW,GAA4B,EAAE,CAAC;IAC9C,IAAI,eAAe,GAAG,CAAC,CAAC;IAExB,UAAU,CAAC;QACT,eAAe,GAAG,CAAC,CAAC;QACpB,WAAW,GAAG,CAAC,IAAI,qBAAqB,EAAE,EAAE,IAAI,qBAAqB,EAAE,CAAC,CAAC;QACzE,KAAK,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAC,GAAW;YACxD,OAAO,WAAW,CAAC,eAAe,EAAE,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,UAAA,IAAI;QACzD,IAAM,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;QACjC,IAAM,eAAe,GAAG,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;aAC3B,IAAI,CAAC,UAAM,UAAU;;;;;wBACpB,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;wBACvC,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC;wBACpD,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;6BACpC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;wBACrD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,kBAAkB,CAAC;6BACnD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;wBACpD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC;6BACjD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;wBAClD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;wBAE5D,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAC5B,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBACxC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;wBACvD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;wBAGhD,WAAM,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAA1C,WAAW,GAAG,SAA4B;wBAE5C,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,WAAW,CAAC,IAAI,EAAE,EAAA;;wBADjC,+BAA+B,GACjC,cAAW,SAAwB,EAAC;wBACxC,MAAM,CAAC,+BAA+B,CAAC,aAAa,CAAC;6BAChD,OAAO,CAAC,cAAc,CAAC,CAAC;wBACvB,eAAe,GACjB,+BAA+B,CAAC,eACX,CAAC;wBAC1B,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAC1C,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;4BACvC,0BAA0B;yBAC3B,CAAC,CAAC;wBACH,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBAGlC,WAAM,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAA;;wBAAnD,cAAc,GAAG,SAAkC;wBACnD,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;wBAEpC,UAAU,CAAC,MAAM,GAAG,UAAC,KAAU;4BAC7B,IAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAqB,CAAC;4BAClD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;4BACpC,IAAI,EAAE,CAAC;wBACT,CAAC,CAAC;wBACF,KAAA,CAAA,KAAA,UAAU,CAAA,CAAC,iBAAiB,CAAA;wBAAC,WAAM,cAAc,CAAC,IAAI,EAAE,EAAA;;wBAAxD,cAA6B,SAA2B,EAAC,CAAC;wBAG1D,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBACtC,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;;;;aAC7C,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,UAAA,IAAI;QAClD,IAAM,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;QACjC,IAAM,eAAe,GAAG,gCAAgB,CAAC,wBAAwB,CAAC,CAAC;QACnE,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;aAC3B,IAAI,CAAC,UAAM,UAAU;;;;;wBACpB,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;wBACvC,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC;wBACpD,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;6BACpC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;wBACrD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,kBAAkB,CAAC;6BACnD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;wBACpD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC;6BACjD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;wBAClD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;wBAE5D,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAC5B,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBACxC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;wBACvD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;wBAGhD,WAAM,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAA1C,WAAW,GAAG,SAA4B;wBAE5C,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,WAAW,CAAC,IAAI,EAAE,EAAA;;wBADjC,+BAA+B,GACjC,cAAW,SAAwB,EAAC;wBACxC,MAAM,CAAC,+BAA+B,CAAC,aAAa,CAAC;6BAChD,OAAO,CAAC,cAAc,CAAC,CAAC;wBACvB,eAAe,GACjB,+BAA+B,CAAC,eACX,CAAC;wBAC1B,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAC1C,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;4BACvC,0BAA0B;yBAC3B,CAAC,CAAC;wBACH,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBAGlC,WAAM,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAA;;wBAAnD,cAAc,GAAG,SAAkC;wBACnD,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;wBAEpC,UAAU,CAAC,MAAM,GAAG,UAAC,KAAU;4BAC7B,IAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAqB,CAAC;4BAClD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;4BACpC,IAAI,EAAE,CAAC;wBACT,CAAC,CAAC;wBACF,KAAA,CAAA,KAAA,UAAU,CAAA,CAAC,iBAAiB,CAAA;wBAAC,WAAM,cAAc,CAAC,IAAI,EAAE,EAAA;;wBAAxD,cAA6B,SAA2B,EAAC,CAAC;wBAG1D,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBACtC,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;;;;aAC7C,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,UAAA,IAAI;QACrD,IAAM,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;QACjC,IAAM,eAAe,GAAG,gCAAgB,EAAE,CAAC;QAC3C,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;aAC3B,IAAI,CAAC,UAAM,UAAU;;;;;wBACpB,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;wBACvC,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC;wBACpD,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;6BACpC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;wBACrD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,kBAAkB,CAAC;6BACnD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;wBACpD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC;6BACjD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;wBAClD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;wBAE5D,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAC5B,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAGxC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBAClD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;wBAG3C,WAAM,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAA1C,WAAW,GAAG,SAA4B;wBAE5C,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,WAAW,CAAC,IAAI,EAAE,EAAA;;wBADjC,+BAA+B,GACjC,cAAW,SAAwB,EAAC;wBACxC,MAAM,CAAC,+BAA+B,CAAC,aAAa,CAAC;6BAChD,OAAO,CAAC,cAAc,CAAC,CAAC;wBACvB,eAAe,GACjB,+BAA+B,CAAC,eACX,CAAC;wBAC1B,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAC1C,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC;wBAClE,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBAGlC,WAAM,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAA;;wBAAnD,cAAc,GAAG,SAAkC;wBACnD,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;wBAEpC,UAAU,CAAC,MAAM,GAAG,UAAC,KAAU;4BAC7B,IAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAqB,CAAC;4BAClD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;4BACpC,IAAI,EAAE,CAAC;wBACT,CAAC,CAAC;wBACF,KAAA,CAAA,KAAA,UAAU,CAAA,CAAC,iBAAiB,CAAA;wBAAC,WAAM,cAAc,CAAC,IAAI,EAAE,EAAA;;wBAAxD,cAA6B,SAA2B,EAAC,CAAC;;;;aAC3D,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,UAAA,IAAI;QACrC,IAAM,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;QACjC,IAAM,eAAe,GAAG,gCAAgB,EAAE,CAAC;QAC3C,IAAM,0BAA0B,GAAyB;YACvD,aAAa,EAAE,cAAc;SAC9B,CAAC;QACF,eAAe,CAAC,IAAI,CAAC,0BAA0B,CAAC;aAC3C,IAAI,CAAC,UAAM,UAAU;;;;;wBACpB,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;wBACvC,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC;wBACpD,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;6BACpC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;wBACrD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,kBAAkB,CAAC;6BACnD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;wBACpD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAClE,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAE3D,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAC5B,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;wBAGxC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBAClD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAEtC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;wBACrD,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAGxB,WAAM,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA;;wBAA1C,WAAW,GAAG,SAA4B;wBAE5C,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,WAAW,CAAC,IAAI,EAAE,EAAA;;wBADjC,+BAA+B,GACjC,cAAW,SAAwB,EAAC;wBACxC,MAAM,CAAC,+BAA+B,CAAC,aAAa,CAAC;6BAChD,OAAO,CAAC,cAAc,CAAC,CAAC;wBAC7B,IAAI,EAAE,CAAC;;;;aACR,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,MAAM,CACF,sCAAsB,CAAC,iBAAiB,CAAC,YAAY,gCAAgB,CAAC;aACrE,OAAO,CAAC,IAAI,CAAC,CAAC;QACnB,MAAM,CAAC,sCAAsB,CAAC,wBAAwB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACpE,MAAM,CAAC,sCAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,cAAc,EAAE,wBAAY,EAAE;IAC9C,IAAM,WAAW,GACb,IAAI,IAAI,CAAC,CAAC,WAAW,CAAC,EAAE,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;IAChE,IAAM,WAAW,GAAG,IAAI,IAAI,CACxB,CAAC,WAAW,CAAC,EAAE,mBAAmB,EAAE,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;IAE5E,EAAE,CAAC,qBAAqB,EAAE,UAAA,IAAI;QAC5B,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,qBAAqB,CAAC;gBAC9B,OAAO,EAAE,YAAY;aACtB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC;QACjE,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACzD,MAAM,CAAC,IAAI,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;iBAC5C,OAAO,CAAC,IAAI,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;YAC1C,IAAI,EAAE,CAAC;QACT,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE,UAAA,IAAI;QAC7B,IAAM,WAAW,GAA2B;YAC1C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,4BAA4B,EAAE,4BAA4B,CAAC;gBACnE,OAAO,EAAE,WAAW;aACrB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAExC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GACd,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QAC/D,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACxD,MAAM,CAAC,IAAI,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;iBAC5C,OAAO,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YAC3D,IAAI,EAAE,CAAC;QACT,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,UAAA,IAAI;QACnD,IAAM,YAAY,GAA2B;YAC3C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,YAAY,GAA2B;YAC3C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,eAAe,GAA0B;YAC7C;gBACE,KAAK,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;gBACzD,OAAO,EAAE,YAAY;aACtB;YACD;gBACE,KAAK,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;gBACzD,OAAO,EAAE,YAAY;aACtB;SACF,CAAC;QACF,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAExC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,CACnC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QACxE,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC;iBAC7B,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;YAChD,MAAM,CAAC,IAAI,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;iBAC5C,OAAO,CAAC,IAAI,UAAU,CACnB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACnE,IAAI,EAAE,CAAC;QACT,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,UAAA,IAAI;QAClD,IAAM,YAAY,GAA2B;YAC3C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,YAAY,GAA2B;YAC3C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,eAAe,GAA0B;YAC7C;gBACE,KAAK,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;gBACzD,OAAO,EAAE,YAAY;aACtB;YACD;gBACE,KAAK,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;gBACzD,OAAO,EAAE,YAAY;aACtB;SACF,CAAC;QACF,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAExC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,CACnC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QACxE,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC;iBAC7B,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;YAChD,MAAM,CAAC,IAAI,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;iBAC5C,OAAO,CAAC,IAAI,UAAU,CACnB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACnE,IAAI,EAAE,CAAC;QACT,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,UAAA,IAAI;QACnC,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,qBAAqB,CAAC;gBAC9B,OAAO,EAAE,YAAY;aACtB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAGnE,IAAM,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QACpD,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;YAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACtD,IAAI,EAAE,CAAC;QACT,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,UAAA,IAAI;QACxD,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,uBAAuB,CAAC;gBAChC,OAAO,EAAE,YAAY;aACtB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,YAAY;YAC3B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAExC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAInE,IAAM,YAAY,GACd,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QAC/D,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,IAAI,CAAC,IAAI,CACL,+DAA+D;gBAC/D,yBAAyB,CAAC,CAAC;QACjC,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC;iBACd,OAAO,CACJ,0DAA0D;gBAC1D,8CAA8C,CAAC,CAAC;YACxD,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,UAAA,IAAI;QAClD,IAAM,WAAW,GAA2B;YAC1C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QACF,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;gBACzD,OAAO,EAAE,WAAW;aACrB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAGxC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GACd,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QAC/D,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,IAAI,CAAC,IAAI,CACL,gDAAgD;gBAChD,yBAAyB,CAAC,CAAC;QACjC,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC;iBACd,OAAO,CACJ,2DAA2D;gBAC3D,WAAW,CAAC,CAAC;YACrB,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,UAAA,IAAI;QAC3C,IAAM,WAAW,GAA2B;YAC1C;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;gBACb,KAAK,EAAE,SAAS;aACjB;SACF,CAAC;QAGF,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,4BAA4B,EAAE,4BAA4B,CAAC;gBACnE,OAAO,EAAE,WAAW;aACrB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,aAAa,EAAE,cAAc;YAC7B,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,IAAI,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EACzC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QACxC,IAAM,YAAY,GAAG,IAAI,IAAI,CACzB,CAAC,YAAY,CAAC,EAAE,qBAAqB,EACrC,EAAC,IAAI,EAAE,0BAA0B,EAAC,CAAC,CAAC;QAGxC,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GACd,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QAC/D,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,IAAI,CAAC,IAAI,CACL,4CAA4C;gBAC5C,yBAAyB,CAAC,CAAC;QACjC,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC;iBACd,OAAO,CACJ,qDAAqD;gBACrD,yBAAyB,CAAC,CAAC;YACnC,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,UAAA,IAAI;QACvD,IAAM,eAAe,GAA0B,CAAC;gBAC9C,KAAK,EAAE,CAAC,qBAAqB,CAAC;gBAC9B,OAAO,EAAE,YAAY;aACtB,CAAC,CAAC;QACH,IAAM,0BAA0B,GAAG;YACjC,eAAe,iBAAA;SAChB,CAAC;QACF,IAAM,QAAQ,GAAG,IAAI,IAAI,CACrB,CAAC,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,EAC5C,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GACV,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC,CAAC,CAAC;QAEnE,IAAM,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC;QACjE,YAAY,CAAC,IAAI,EAAE;aACd,IAAI,CAAC,UAAA,cAAc;YAClB,IAAI,CAAC,IAAI,CACL,0DAA0D;gBAC1D,yBAAyB,CAAC,CAAC;QACjC,CAAC,CAAC;aACD,KAAK,CAAC,UAAA,GAAG;YACR,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC;iBACd,OAAO,CAAC,sDAAsD,CAAC,CAAC;YACrE,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EAAxB,CAAwB,CAAC,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;QACvE,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,EAAtB,CAAsB,CAAC,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.d.ts new file mode 100644 index 0000000..3c32af5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.d.ts @@ -0,0 +1,13 @@ +import { IORouter } from './router_registry'; +import { IOHandler, ModelArtifacts, SaveResult } from './types'; +export declare class BrowserHTTPRequest implements IOHandler { + protected readonly path: string; + protected readonly requestInit: RequestInit; + readonly DEFAULT_METHOD: string; + static readonly URL_SCHEMES: string[]; + constructor(path: string, requestInit?: RequestInit); + save(modelArtifacts: ModelArtifacts): Promise; + load(): Promise; +} +export declare const httpRequestRouter: IORouter; +export declare function browserHTTPRequest(path: string, requestInit?: RequestInit): IOHandler; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js new file mode 100644 index 0000000..c7c449b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js @@ -0,0 +1,166 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var util_1 = require("../util"); +var io_utils_1 = require("./io_utils"); +var router_registry_1 = require("./router_registry"); +var weights_loader_1 = require("./weights_loader"); +var BrowserHTTPRequest = (function () { + function BrowserHTTPRequest(path, requestInit) { + this.DEFAULT_METHOD = 'POST'; + if (typeof fetch === 'undefined') { + throw new Error('browserHTTPRequest is not supported outside the web browser without a fetch polyfill.'); + } + util_1.assert(path != null && path.length > 0, 'URL path for browserHTTPRequest must not be null, undefined or ' + + 'empty.'); + this.path = path; + if (requestInit != null && requestInit.body != null) { + throw new Error('requestInit is expected to have no pre-existing body, but has one.'); + } + this.requestInit = requestInit || {}; + } + BrowserHTTPRequest.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var init, weightsManifest, modelTopologyAndWeightManifest, response; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserHTTPRequest.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + init = Object.assign({ method: this.DEFAULT_METHOD }, this.requestInit); + init.body = new FormData(); + weightsManifest = [{ + paths: ['./model.weights.bin'], + weights: modelArtifacts.weightSpecs, + }]; + modelTopologyAndWeightManifest = { + modelTopology: modelArtifacts.modelTopology, + weightsManifest: weightsManifest + }; + init.body.append('model.json', new Blob([JSON.stringify(modelTopologyAndWeightManifest)], { type: 'application/json' }), 'model.json'); + if (modelArtifacts.weightData != null) { + init.body.append('model.weights.bin', new Blob([modelArtifacts.weightData], { type: 'application/octet-stream' }), 'model.weights.bin'); + } + return [4, fetch(this.path, init)]; + case 1: + response = _a.sent(); + if (response.status === 200) { + return [2, { + modelArtifactsInfo: io_utils_1.getModelArtifactsInfoForJSON(modelArtifacts), + responses: [response], + }]; + } + else { + throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status " + + (response.status + ".")); + } + return [2]; + } + }); + }); + }; + BrowserHTTPRequest.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var modelConfigRequest, modelConfig, modelTopology, weightsManifest, weightSpecs, weightData, weightsManifest_2, _i, weightsManifest_1, entry, pathPrefix_1, fetchURLs_1, _a; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: return [4, fetch(this.path, this.requestInit)]; + case 1: + modelConfigRequest = _b.sent(); + return [4, modelConfigRequest.json()]; + case 2: + modelConfig = _b.sent(); + modelTopology = modelConfig['modelTopology']; + weightsManifest = modelConfig['weightsManifest']; + if (modelTopology == null && weightsManifest == null) { + throw new Error("The JSON from HTTP path " + this.path + " contains neither model " + + "topology or manifest for weights."); + } + if (!(weightsManifest != null)) return [3, 4]; + weightsManifest_2 = modelConfig['weightsManifest']; + weightSpecs = []; + for (_i = 0, weightsManifest_1 = weightsManifest_2; _i < weightsManifest_1.length; _i++) { + entry = weightsManifest_1[_i]; + weightSpecs.push.apply(weightSpecs, entry.weights); + } + pathPrefix_1 = this.path.substring(0, this.path.lastIndexOf('/')); + if (!pathPrefix_1.endsWith('/')) { + pathPrefix_1 = pathPrefix_1 + '/'; + } + fetchURLs_1 = []; + weightsManifest_2.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + fetchURLs_1.push(pathPrefix_1 + path); + }); + }); + _a = io_utils_1.concatenateArrayBuffers; + return [4, weights_loader_1.loadWeightsAsArrayBuffer(fetchURLs_1, this.requestInit)]; + case 3: + weightData = _a.apply(void 0, [_b.sent()]); + _b.label = 4; + case 4: return [2, { modelTopology: modelTopology, weightSpecs: weightSpecs, weightData: weightData }]; + } + }); + }); + }; + BrowserHTTPRequest.URL_SCHEMES = ['http://', 'https://']; + return BrowserHTTPRequest; +}()); +exports.BrowserHTTPRequest = BrowserHTTPRequest; +exports.httpRequestRouter = function (url) { + if (typeof fetch === 'undefined') { + return null; + } + else { + for (var _i = 0, _a = BrowserHTTPRequest.URL_SCHEMES; _i < _a.length; _i++) { + var scheme = _a[_i]; + if (url.startsWith(scheme)) { + return browserHTTPRequest(url); + } + } + return null; + } +}; +router_registry_1.IORouterRegistry.registerSaveRouter(exports.httpRequestRouter); +router_registry_1.IORouterRegistry.registerLoadRouter(exports.httpRequestRouter); +function browserHTTPRequest(path, requestInit) { + return new BrowserHTTPRequest(path, requestInit); +} +exports.browserHTTPRequest = browserHTTPRequest; +//# sourceMappingURL=browser_http.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js.map new file mode 100644 index 0000000..6a82867 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_http.js","sourceRoot":"","sources":["../../src/io/browser_http.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js new file mode 100644 index 0000000..6a60279 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js @@ -0,0 +1,576 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var browser_http_1 = require("./browser_http"); +var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' +}; +jasmine_util_1.describeWithFlags('browserHTTPRequest-load fetch-polyfill', test_util_1.NODE_ENVS, function () { + var requestInits; + beforeEach(function () { + global.fetch = function () { }; + requestInits = []; + }); + afterAll(function () { + delete global.fetch; + }); + var fakeResponse = function (body) { return ({ + json: function () { + return Promise.resolve(JSON.parse(body)); + }, + arrayBuffer: function () { + var buf = body.buffer ? + body.buffer : + body; + return Promise.resolve(buf); + } + }); }; + var setupFakeWeightFiles = function (fileBufferMap) { + spyOn(global, 'fetch') + .and.callFake(function (path, init) { + requestInits.push(init); + return fakeResponse(fileBufferMap[path]); + }); + }; + it('1 group, 2 weights, 1 path', function (done) { + var weightManifest1 = [{ + paths: ['weightfile0'], + weights: [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [2], + dtype: 'float32', + } + ] + }]; + var floatData = new Float32Array([1, 3, 3, 7, 4]); + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightManifest1 }), + './weightfile0': floatData, + }); + var handler = tf.io.browserHTTPRequest('./model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightManifest1[0].weights); + expect(new Float32Array(modelArtifacts.weightData)) + .toEqual(floatData); + expect(requestInits).toEqual([{}, {}]); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('throw exception if no fetch polyfill', function () { + delete global.fetch; + try { + tf.io.browserHTTPRequest('./model.json'); + } + catch (err) { + expect(err.message) + .toMatch(/not supported outside the web browser without a fetch polyfill/); + } + }); +}); +jasmine_util_1.describeWithFlags('browserHTTPRequest-save', test_util_1.CHROME_ENVS, function () { + var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } + ]; + var weightData1 = new ArrayBuffer(16); + var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, + }; + var requestInits = []; + beforeEach(function () { + requestInits = []; + spyOn(window, 'fetch').and.callFake(function (path, init) { + if (path === 'model-upload-test' || path === 'http://model-upload-test') { + requestInits.push(init); + return new Response(null, { status: 200 }); + } + else { + return new Response(null, { status: 404 }); + } + }); + }); + it('Save topology and weights, default POST method', function (done) { + var testStartDate = new Date(); + var handler = tf.io.getSaveHandlers('http://model-upload-test')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + expect(saveResult.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes) + .toEqual(weightData1.byteLength); + expect(requestInits.length).toEqual(1); + var init = requestInits[0]; + expect(init.method).toEqual('POST'); + var body = init.body; + var jsonFile = body.get('model.json'); + var jsonFileReader = new FileReader(); + jsonFileReader.onload = function (event) { + var modelJSON = JSON.parse(event.target.result); + expect(modelJSON.modelTopology).toEqual(modelTopology1); + expect(modelJSON.weightsManifest.length).toEqual(1); + expect(modelJSON.weightsManifest[0].weights).toEqual(weightSpecs1); + var weightsFile = body.get('model.weights.bin'); + var weightsFileReader = new FileReader(); + weightsFileReader.onload = function (event) { + var weightData = event.target.result; + expect(new Uint8Array(weightData)) + .toEqual(new Uint8Array(weightData1)); + done(); + }; + weightsFileReader.onerror = function (error) { + done.fail(error.target.error.message); + }; + weightsFileReader.readAsArrayBuffer(weightsFile); + }; + jsonFileReader.onerror = function (error) { + done.fail(error.target.error.message); + }; + jsonFileReader.readAsText(jsonFile); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('Save topology only, default POST method', function (done) { + var testStartDate = new Date(); + var handler = tf.io.getSaveHandlers('http://model-upload-test')[0]; + var topologyOnlyArtifacts = { modelTopology: modelTopology1 }; + handler.save(topologyOnlyArtifacts) + .then(function (saveResult) { + expect(saveResult.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes).toEqual(0); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(0); + expect(requestInits.length).toEqual(1); + var init = requestInits[0]; + expect(init.method).toEqual('POST'); + var body = init.body; + var jsonFile = body.get('model.json'); + var jsonFileReader = new FileReader(); + jsonFileReader.onload = function (event) { + var modelJSON = JSON.parse(event.target.result); + expect(modelJSON.modelTopology).toEqual(modelTopology1); + expect(body.get('model.weights.bin')).toEqual(null); + done(); + }; + jsonFileReader.onerror = function (error) { + done.fail(error.target.error.message); + }; + jsonFileReader.readAsText(jsonFile); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('Save topology and weights, PUT method, extra headers', function (done) { + var testStartDate = new Date(); + var handler = tf.io.browserHTTPRequest('model-upload-test', { + method: 'PUT', + headers: { + 'header_key_1': 'header_value_1', + 'header_key_2': 'header_value_2' + } + }); + handler.save(artifacts1) + .then(function (saveResult) { + expect(saveResult.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes) + .toEqual(weightData1.byteLength); + expect(requestInits.length).toEqual(1); + var init = requestInits[0]; + expect(init.method).toEqual('PUT'); + expect(init.headers).toEqual({ + 'header_key_1': 'header_value_1', + 'header_key_2': 'header_value_2' + }); + var body = init.body; + var jsonFile = body.get('model.json'); + var jsonFileReader = new FileReader(); + jsonFileReader.onload = function (event) { + var modelJSON = JSON.parse(event.target.result); + expect(modelJSON.modelTopology).toEqual(modelTopology1); + expect(modelJSON.weightsManifest.length).toEqual(1); + expect(modelJSON.weightsManifest[0].weights).toEqual(weightSpecs1); + var weightsFile = body.get('model.weights.bin'); + var weightsFileReader = new FileReader(); + weightsFileReader.onload = function (event) { + var weightData = event.target.result; + expect(new Uint8Array(weightData)) + .toEqual(new Uint8Array(weightData1)); + done(); + }; + weightsFileReader.onerror = function (error) { + done.fail(error.target.error.message); + }; + weightsFileReader.readAsArrayBuffer(weightsFile); + }; + jsonFileReader.onerror = function (error) { + done.fail(error.target.error.message); + }; + jsonFileReader.readAsText(jsonFile); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + it('404 response causes Error', function (done) { + var handler = tf.io.getSaveHandlers('http://invalid/path')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + done.fail('Calling browserHTTPRequest at invalid URL succeeded ' + + 'unexpectedly'); + }) + .catch(function (err) { + done(); + }); + }); + it('Existing body leads to Error', function () { + expect(function () { return tf.io.browserHTTPRequest('model-upload-test', { + body: 'existing body' + }); }).toThrowError(/requestInit is expected to have no pre-existing body/); + }); + it('Empty, null or undefined URL paths lead to Error', function () { + expect(function () { return tf.io.browserHTTPRequest(null); }) + .toThrowError(/must not be null, undefined or empty/); + expect(function () { return tf.io.browserHTTPRequest(undefined); }) + .toThrowError(/must not be null, undefined or empty/); + expect(function () { return tf.io.browserHTTPRequest(''); }) + .toThrowError(/must not be null, undefined or empty/); + }); + it('router', function () { + expect(browser_http_1.httpRequestRouter('http://bar/foo') instanceof browser_http_1.BrowserHTTPRequest) + .toEqual(true); + expect(browser_http_1.httpRequestRouter('https://localhost:5000/upload') instanceof + browser_http_1.BrowserHTTPRequest) + .toEqual(true); + expect(browser_http_1.httpRequestRouter('localhost://foo')).toBeNull(); + expect(browser_http_1.httpRequestRouter('foo:5000/bar')).toBeNull(); + }); +}); +jasmine_util_1.describeWithFlags('browserHTTPRequest-load', test_util_1.BROWSER_ENVS, function () { + var requestInits; + var setupFakeWeightFiles = function (fileBufferMap) { + spyOn(window, 'fetch').and.callFake(function (path, init) { + requestInits.push(init); + return new Response(fileBufferMap[path]); + }); + }; + beforeEach(function () { + requestInits = []; + }); + it('1 group, 2 weights, 1 path', function (done) { + var weightManifest1 = [{ + paths: ['weightfile0'], + weights: [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [2], + dtype: 'float32', + } + ] + }]; + var floatData = new Float32Array([1, 3, 3, 7, 4]); + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightManifest1 }), + './weightfile0': floatData, + }); + var handler = tf.io.browserHTTPRequest('./model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightManifest1[0].weights); + expect(new Float32Array(modelArtifacts.weightData)) + .toEqual(floatData); + expect(requestInits).toEqual([{}, {}]); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('1 group, 2 weights, 1 path, with requestInit', function (done) { + var weightManifest1 = [{ + paths: ['weightfile0'], + weights: [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [2], + dtype: 'float32', + } + ] + }]; + var floatData = new Float32Array([1, 3, 3, 7, 4]); + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightManifest1 }), + './weightfile0': floatData, + }); + var handler = tf.io.browserHTTPRequest('./model.json', { headers: { 'header_key_1': 'header_value_1' } }); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightManifest1[0].weights); + expect(new Float32Array(modelArtifacts.weightData)) + .toEqual(floatData); + expect(requestInits).toEqual([ + { headers: { 'header_key_1': 'header_value_1' } }, + { headers: { 'header_key_1': 'header_value_1' } } + ]); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('1 group, 2 weight, 2 paths', function (done) { + var weightManifest1 = [{ + paths: ['weightfile0', 'weightfile1'], + weights: [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [2], + dtype: 'float32', + } + ] + }]; + var floatData1 = new Float32Array([1, 3, 3]); + var floatData2 = new Float32Array([7, 4]); + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightManifest1 }), + './weightfile0': floatData1, + './weightfile1': floatData2, + }); + var handler = tf.io.browserHTTPRequest('./model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightManifest1[0].weights); + expect(new Float32Array(modelArtifacts.weightData)) + .toEqual(new Float32Array([1, 3, 3, 7, 4])); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('2 groups, 2 weight, 2 paths', function (done) { + var weightsManifest = [ + { + paths: ['weightfile0'], + weights: [{ + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }] + }, + { + paths: ['weightfile1'], + weights: [{ + name: 'dense/bias', + shape: [2], + dtype: 'float32', + }], + } + ]; + var floatData1 = new Float32Array([1, 3, 3]); + var floatData2 = new Float32Array([7, 4]); + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightsManifest }), + './weightfile0': floatData1, + './weightfile1': floatData2, + }); + var handler = tf.io.browserHTTPRequest('./model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightsManifest[0].weights.concat(weightsManifest[1].weights)); + expect(new Float32Array(modelArtifacts.weightData)) + .toEqual(new Float32Array([1, 3, 3, 7, 4])); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('2 groups, 2 weight, 2 paths, Int32 and Uint8 Data', function (done) { + var weightsManifest = [ + { + paths: ['weightfile0'], + weights: [{ + name: 'fooWeight', + shape: [3, 1], + dtype: 'int32', + }] + }, + { + paths: ['weightfile1'], + weights: [{ + name: 'barWeight', + shape: [2], + dtype: 'bool', + }], + } + ]; + var floatData1 = new Int32Array([1, 3, 3]); + var floatData2 = new Uint8Array([7, 4]); + setupFakeWeightFiles({ + 'path1/model.json': JSON.stringify({ modelTopology: modelTopology1, weightsManifest: weightsManifest }), + 'path1/weightfile0': floatData1, + 'path1/weightfile1': floatData2, + }); + var handler = tf.io.browserHTTPRequest('path1/model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs) + .toEqual(weightsManifest[0].weights.concat(weightsManifest[1].weights)); + expect(new Int32Array(modelArtifacts.weightData.slice(0, 12))) + .toEqual(new Int32Array([1, 3, 3])); + expect(new Uint8Array(modelArtifacts.weightData.slice(12, 14))) + .toEqual(new Uint8Array([7, 4])); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('topology only', function (done) { + setupFakeWeightFiles({ + './model.json': JSON.stringify({ modelTopology: modelTopology1 }), + }); + var handler = tf.io.browserHTTPRequest('./model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toBeUndefined(); + expect(modelArtifacts.weightData).toBeUndefined(); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('weights only', function (done) { + var weightsManifest = [ + { + paths: ['weightfile0'], + weights: [{ + name: 'fooWeight', + shape: [3, 1], + dtype: 'int32', + }] + }, + { + paths: ['weightfile1'], + weights: [{ + name: 'barWeight', + shape: [2], + dtype: 'float32', + }], + } + ]; + var floatData1 = new Int32Array([1, 3, 3]); + var floatData2 = new Float32Array([-7, -4]); + setupFakeWeightFiles({ + 'path1/model.json': JSON.stringify({ weightsManifest: weightsManifest }), + 'path1/weightfile0': floatData1, + 'path1/weightfile1': floatData2, + }); + var handler = tf.io.browserHTTPRequest('path1/model.json'); + handler.load() + .then(function (modelArtifacts) { + expect(modelArtifacts.modelTopology).toBeUndefined(); + expect(modelArtifacts.weightSpecs) + .toEqual(weightsManifest[0].weights.concat(weightsManifest[1].weights)); + expect(new Int32Array(modelArtifacts.weightData.slice(0, 12))) + .toEqual(new Int32Array([1, 3, 3])); + expect(new Float32Array(modelArtifacts.weightData.slice(12, 20))) + .toEqual(new Float32Array([-7, -4])); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Missing modelTopology and weightsManifest leads to error', function (done) { + setupFakeWeightFiles({ 'path1/model.json': JSON.stringify({}) }); + var handler = tf.io.browserHTTPRequest('path1/model.json'); + handler.load() + .then(function (modelTopology1) { + done.fail('Loading from missing modelTopology and weightsManifest ' + + 'succeeded expectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toMatch(/contains neither model topology or manifest/); + done(); + }); + }); +}); +//# sourceMappingURL=browser_http_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js.map new file mode 100644 index 0000000..2e8d614 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/browser_http_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"browser_http_test.js","sourceRoot":"","sources":["../../src/io/browser_http_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.d.ts new file mode 100644 index 0000000..52354fb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.d.ts @@ -0,0 +1,22 @@ +import { IORouter } from './router_registry'; +import { IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult } from './types'; +export declare function deleteDatabase(): Promise; +export declare class BrowserIndexedDB implements IOHandler { + protected readonly indexedDB: IDBFactory; + protected readonly modelPath: string; + static readonly URL_SCHEME: string; + constructor(modelPath: string); + save(modelArtifacts: ModelArtifacts): Promise; + load(): Promise; + private databaseAction; +} +export declare const indexedDBRouter: IORouter; +export declare function browserIndexedDB(modelPath: string): IOHandler; +export declare class BrowserIndexedDBManager implements ModelStoreManager { + private indexedDB; + constructor(); + listModels(): Promise<{ + [path: string]: ModelArtifactsInfo; + }>; + removeModel(path: string): Promise; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js new file mode 100644 index 0000000..ac6936a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js @@ -0,0 +1,309 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var io_utils_1 = require("./io_utils"); +var model_management_1 = require("./model_management"); +var router_registry_1 = require("./router_registry"); +var DATABASE_NAME = 'tensorflowjs'; +var DATABASE_VERSION = 1; +var MODEL_STORE_NAME = 'models_store'; +var INFO_STORE_NAME = 'model_info_store'; +function deleteDatabase() { + return __awaiter(this, void 0, void 0, function () { + var idbFactory; + return __generator(this, function (_a) { + idbFactory = getIndexedDBFactory(); + return [2, new Promise(function (resolve, reject) { + var deleteRequest = idbFactory.deleteDatabase(DATABASE_NAME); + deleteRequest.onsuccess = function () { return resolve(); }; + deleteRequest.onerror = function (error) { return reject(error); }; + })]; + }); + }); +} +exports.deleteDatabase = deleteDatabase; +function getIndexedDBFactory() { + if (!environment_1.ENV.get('IS_BROWSER')) { + throw new Error('Failed to obtain IndexedDB factory because the current environment' + + 'is not a web browser.'); + } + var theWindow = window; + var factory = theWindow.indexedDB || theWindow.mozIndexedDB || + theWindow.webkitIndexedDB || theWindow.msIndexedDB || + theWindow.shimIndexedDB; + if (factory == null) { + throw new Error('The current browser does not appear to support IndexedDB.'); + } + return factory; +} +function setUpDatabase(openRequest) { + var db = openRequest.result; + db.createObjectStore(MODEL_STORE_NAME, { keyPath: 'modelPath' }); + db.createObjectStore(INFO_STORE_NAME, { keyPath: 'modelPath' }); +} +var BrowserIndexedDB = (function () { + function BrowserIndexedDB(modelPath) { + this.indexedDB = getIndexedDBFactory(); + if (modelPath == null || !modelPath) { + throw new Error('For IndexedDB, modelPath must not be null, undefined or empty.'); + } + this.modelPath = modelPath; + } + BrowserIndexedDB.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserLocalStorage.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + return [2, this.databaseAction(this.modelPath, modelArtifacts)]; + }); + }); + }; + BrowserIndexedDB.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.databaseAction(this.modelPath)]; + }); + }); + }; + BrowserIndexedDB.prototype.databaseAction = function (modelPath, modelArtifacts) { + var _this = this; + return new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + if (modelArtifacts == null) { + var modelTx = db.transaction(MODEL_STORE_NAME, 'readonly'); + var modelStore = modelTx.objectStore(MODEL_STORE_NAME); + var getRequest_1 = modelStore.get(_this.modelPath); + getRequest_1.onsuccess = function () { + if (getRequest_1.result == null) { + db.close(); + return reject(new Error("Cannot find model with path '" + _this.modelPath + "' " + + "in IndexedDB.")); + } + else { + resolve(getRequest_1.result.modelArtifacts); + } + }; + getRequest_1.onerror = function (error) { + db.close(); + return reject(getRequest_1.error); + }; + modelTx.oncomplete = function () { return db.close(); }; + } + else { + var modelArtifactsInfo_1 = io_utils_1.getModelArtifactsInfoForJSON(modelArtifacts); + var infoTx_1 = db.transaction(INFO_STORE_NAME, 'readwrite'); + var infoStore_1 = infoTx_1.objectStore(INFO_STORE_NAME); + var putInfoRequest_1 = infoStore_1.put({ modelPath: _this.modelPath, modelArtifactsInfo: modelArtifactsInfo_1 }); + var modelTx_1; + putInfoRequest_1.onsuccess = function () { + modelTx_1 = db.transaction(MODEL_STORE_NAME, 'readwrite'); + var modelStore = modelTx_1.objectStore(MODEL_STORE_NAME); + var putModelRequest = modelStore.put({ + modelPath: _this.modelPath, + modelArtifacts: modelArtifacts, + modelArtifactsInfo: modelArtifactsInfo_1 + }); + putModelRequest.onsuccess = function () { return resolve({ modelArtifactsInfo: modelArtifactsInfo_1 }); }; + putModelRequest.onerror = function (error) { + infoStore_1 = infoTx_1.objectStore(INFO_STORE_NAME); + var deleteInfoRequest = infoStore_1.delete(_this.modelPath); + deleteInfoRequest.onsuccess = function () { + db.close(); + return reject(putModelRequest.error); + }; + deleteInfoRequest.onerror = function (error) { + db.close(); + return reject(putModelRequest.error); + }; + }; + }; + putInfoRequest_1.onerror = function (error) { + db.close(); + return reject(putInfoRequest_1.error); + }; + infoTx_1.oncomplete = function () { + if (modelTx_1 == null) { + db.close(); + } + else { + modelTx_1.oncomplete = function () { return db.close(); }; + } + }; + } + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + }); + }; + BrowserIndexedDB.URL_SCHEME = 'indexeddb://'; + return BrowserIndexedDB; +}()); +exports.BrowserIndexedDB = BrowserIndexedDB; +exports.indexedDBRouter = function (url) { + if (!environment_1.ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserIndexedDB.URL_SCHEME)) { + return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length)); + } + else { + return null; + } + } +}; +router_registry_1.IORouterRegistry.registerSaveRouter(exports.indexedDBRouter); +router_registry_1.IORouterRegistry.registerLoadRouter(exports.indexedDBRouter); +function browserIndexedDB(modelPath) { + return new BrowserIndexedDB(modelPath); +} +exports.browserIndexedDB = browserIndexedDB; +function maybeStripScheme(key) { + return key.startsWith(BrowserIndexedDB.URL_SCHEME) ? + key.slice(BrowserIndexedDB.URL_SCHEME.length) : + key; +} +var BrowserIndexedDBManager = (function () { + function BrowserIndexedDBManager() { + this.indexedDB = getIndexedDBFactory(); + } + BrowserIndexedDBManager.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + return [2, new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + var tx = db.transaction(INFO_STORE_NAME, 'readonly'); + var store = tx.objectStore(INFO_STORE_NAME); + var getAllInfoRequest = store.getAll(); + getAllInfoRequest.onsuccess = function () { + var out = {}; + for (var _i = 0, _a = getAllInfoRequest.result; _i < _a.length; _i++) { + var item = _a[_i]; + out[item.modelPath] = item.modelArtifactsInfo; + } + resolve(out); + }; + getAllInfoRequest.onerror = function (error) { + db.close(); + return reject(getAllInfoRequest.error); + }; + tx.oncomplete = function () { return db.close(); }; + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + })]; + }); + }); + }; + BrowserIndexedDBManager.prototype.removeModel = function (path) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + path = maybeStripScheme(path); + return [2, new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + var infoTx = db.transaction(INFO_STORE_NAME, 'readwrite'); + var infoStore = infoTx.objectStore(INFO_STORE_NAME); + var getInfoRequest = infoStore.get(path); + var modelTx; + getInfoRequest.onsuccess = function () { + if (getInfoRequest.result == null) { + db.close(); + return reject(new Error("Cannot find model with path '" + path + "' " + + "in IndexedDB.")); + } + else { + var deleteInfoRequest = infoStore.delete(path); + var deleteModelData_1 = function () { + modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite'); + var modelStore = modelTx.objectStore(MODEL_STORE_NAME); + var deleteModelRequest = modelStore.delete(path); + deleteModelRequest.onsuccess = function () { + return resolve(getInfoRequest.result.modelArtifactsInfo); + }; + deleteModelRequest.onerror = function (error) { + return reject(getInfoRequest.error); + }; + }; + deleteInfoRequest.onsuccess = deleteModelData_1; + deleteInfoRequest.onerror = function (error) { + deleteModelData_1(); + db.close(); + return reject(getInfoRequest.error); + }; + } + }; + getInfoRequest.onerror = function (error) { + db.close(); + return reject(getInfoRequest.error); + }; + infoTx.oncomplete = function () { + if (modelTx == null) { + db.close(); + } + else { + modelTx.oncomplete = function () { return db.close(); }; + } + }; + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + })]; + }); + }); + }; + return BrowserIndexedDBManager; +}()); +exports.BrowserIndexedDBManager = BrowserIndexedDBManager; +if (environment_1.ENV.get('IS_BROWSER')) { + try { + model_management_1.ModelStoreManagerRegistry.registerManager(BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager()); + } + catch (err) { + } +} +//# sourceMappingURL=indexed_db.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js.map new file mode 100644 index 0000000..f85e11c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db.js.map @@ -0,0 +1 @@ +{"version":3,"file":"indexed_db.js","sourceRoot":"","sources":["../../src/io/indexed_db.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js new file mode 100644 index 0000000..3c19df7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js @@ -0,0 +1,313 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var indexed_db_1 = require("./indexed_db"); +jasmine_util_1.describeWithFlags('IndexedDB', test_util_1.BROWSER_ENVS, function () { + var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' + }; + var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } + ]; + var weightData1 = new ArrayBuffer(16); + var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, + }; + var weightSpecs2 = [ + { + name: 'dense/new_kernel', + shape: [5, 1], + dtype: 'float32', + }, + { + name: 'dense/new_bias', + shape: [1], + dtype: 'float32', + } + ]; + beforeEach(function (done) { + indexed_db_1.deleteDatabase().then(function () { + done(); + }); + }); + afterEach(function (done) { + indexed_db_1.deleteDatabase().then(function () { + done(); + }); + }); + it('Save-load round trip', function (done) { + var testStartDate = new Date(); + var handler = tf.io.getSaveHandlers('indexeddb://FooModel')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + expect(saveResult.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes) + .toEqual(weightData1.byteLength); + handler.load() + .then(function (loadedArtifacts) { + expect(loadedArtifacts.modelTopology).toEqual(modelTopology1); + expect(loadedArtifacts.weightSpecs).toEqual(weightSpecs1); + test_util_1.expectArrayBuffersEqual(loadedArtifacts.weightData, weightData1); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Save two models and load one', function (done) { + var weightData2 = new ArrayBuffer(24); + var artifacts2 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs2, + weightData: weightData2, + }; + var handler1 = tf.io.getSaveHandlers('indexeddb://Model/1')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + expect(saveResult1.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult1.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult1.modelArtifactsInfo.weightDataBytes) + .toEqual(weightData1.byteLength); + var handler2 = tf.io.getSaveHandlers('indexeddb://Model/2')[0]; + handler2.save(artifacts2) + .then(function (saveResult2) { + expect(saveResult2.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(saveResult1.modelArtifactsInfo.dateSaved.getTime()); + expect(saveResult2.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult2.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs2).length); + expect(saveResult2.modelArtifactsInfo.weightDataBytes) + .toEqual(weightData2.byteLength); + handler1.load() + .then(function (loadedArtifacts) { + expect(loadedArtifacts.modelTopology) + .toEqual(modelTopology1); + expect(loadedArtifacts.weightSpecs).toEqual(weightSpecs1); + test_util_1.expectArrayBuffersEqual(loadedArtifacts.weightData, weightData1); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Loading nonexistent model fails', function (done) { + var handler = tf.io.getSaveHandlers('indexeddb://NonexistentModel')[0]; + handler.load() + .then(function (modelArtifacts) { + done.fail('Loading nonexistent model from IndexedDB succeeded unexpectly'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Cannot find model with path \'NonexistentModel\' in ' + + 'IndexedDB.'); + done(); + }); + }); + it('Null, undefined or empty modelPath throws Error', function () { + expect(function () { return indexed_db_1.browserIndexedDB(null); }) + .toThrowError(/IndexedDB, modelPath must not be null, undefined or empty/); + expect(function () { return indexed_db_1.browserIndexedDB(undefined); }) + .toThrowError(/IndexedDB, modelPath must not be null, undefined or empty/); + expect(function () { return indexed_db_1.browserIndexedDB(''); }) + .toThrowError(/IndexedDB, modelPath must not be null, undefined or empty./); + }); + it('router', function () { + expect(indexed_db_1.indexedDBRouter('indexeddb://bar') instanceof indexed_db_1.BrowserIndexedDB) + .toEqual(true); + expect(indexed_db_1.indexedDBRouter('localstorage://bar')).toBeNull(); + expect(indexed_db_1.indexedDBRouter('qux')).toBeNull(); + }); + it('Manager: List models: 0 result', function (done) { + new indexed_db_1.BrowserIndexedDBManager() + .listModels() + .then(function (out) { + expect(out).toEqual({}); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: List models: 1 result', function (done) { + var handler = tf.io.getSaveHandlers('indexeddb://baz/QuxModel')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + new indexed_db_1.BrowserIndexedDBManager() + .listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(1); + expect(out['baz/QuxModel'].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out['baz/QuxModel'].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out['baz/QuxModel'].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out['baz/QuxModel'].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: List models: 2 results', function (done) { + var handler1 = tf.io.getSaveHandlers('indexeddb://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('indexeddb://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + new indexed_db_1.BrowserIndexedDBManager() + .listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(2); + expect(out['QuxModel'].modelTopologyType) + .toEqual(saveResult1.modelArtifactsInfo.modelTopologyType); + expect(out['QuxModel'].modelTopologyBytes) + .toEqual(saveResult1.modelArtifactsInfo + .modelTopologyBytes); + expect(out['QuxModel'].weightSpecsBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightSpecsBytes); + expect(out['QuxModel'].weightDataBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightDataBytes); + expect(out['repeat/QuxModel'].modelTopologyType) + .toEqual(saveResult2.modelArtifactsInfo.modelTopologyType); + expect(out['repeat/QuxModel'].modelTopologyBytes) + .toEqual(saveResult2.modelArtifactsInfo + .modelTopologyBytes); + expect(out['repeat/QuxModel'].weightSpecsBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightSpecsBytes); + expect(out['repeat/QuxModel'].weightDataBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: Successful deleteModel', function (done) { + var handler1 = tf.io.getSaveHandlers('indexeddb://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('indexeddb://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + var manager = new indexed_db_1.BrowserIndexedDBManager(); + manager.removeModel('QuxModel') + .then(function (deletedInfo) { + manager.listModels() + .then(function (out) { + expect(Object.keys(out)).toEqual([ + 'repeat/QuxModel' + ]); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: Successful deleteModel with URL scheme', function (done) { + var handler1 = tf.io.getSaveHandlers('indexeddb://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('indexeddb://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + var manager = new indexed_db_1.BrowserIndexedDBManager(); + manager.removeModel('indexeddb://QuxModel') + .then(function (deletedInfo) { + manager.listModels() + .then(function (out) { + expect(Object.keys(out)).toEqual([ + 'repeat/QuxModel' + ]); + done(); + }) + .catch(function (err) { return done.fail(err); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: Failed deletedModel', function (done) { + new indexed_db_1.BrowserIndexedDBManager() + .removeModel('nonexistent') + .then(function (out) { + done.fail('Deleting nonexistent model succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Cannot find model with path \'nonexistent\' in IndexedDB.'); + done(); + }); + }); +}); +//# sourceMappingURL=indexed_db_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js.map new file mode 100644 index 0000000..2a5eeb0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/indexed_db_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"indexed_db_test.js","sourceRoot":"","sources":["../../src/io/indexed_db_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/io.d.ts new file mode 100644 index 0000000..9c53f97 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io.d.ts @@ -0,0 +1,15 @@ +import './indexed_db'; +import './local_storage'; +import { browserFiles } from './browser_files'; +import { browserHTTPRequest } from './browser_http'; +import { concatenateArrayBuffers, decodeWeights, encodeWeights, getModelArtifactsInfoForJSON } from './io_utils'; +import { fromMemory, withSaveHandler } from './passthrough'; +import { IORouterRegistry } from './router_registry'; +import { IOHandler, LoadHandler, ModelArtifacts, ModelStoreManager, SaveConfig, SaveHandler, SaveResult, WeightsManifestConfig, WeightsManifestEntry } from './types'; +import { loadWeights } from './weights_loader'; +declare const registerSaveRouter: typeof IORouterRegistry.registerSaveRouter; +declare const registerLoadRouter: typeof IORouterRegistry.registerLoadRouter; +declare const getSaveHandlers: typeof IORouterRegistry.getSaveHandlers; +declare const getLoadHandlers: typeof IORouterRegistry.getLoadHandlers; +export { copyModel, listModels, moveModel, removeModel } from './model_management'; +export { browserFiles, browserHTTPRequest, concatenateArrayBuffers, decodeWeights, encodeWeights, fromMemory, getLoadHandlers, getModelArtifactsInfoForJSON, getSaveHandlers, IOHandler, LoadHandler, loadWeights, ModelArtifacts, ModelStoreManager, registerLoadRouter, registerSaveRouter, SaveConfig, SaveHandler, SaveResult, WeightsManifestConfig, WeightsManifestEntry, withSaveHandler }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io.js b/node_modules/@tensorflow/tfjs-core/dist/io/io.js new file mode 100644 index 0000000..07f5b2a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +require("./indexed_db"); +require("./local_storage"); +var browser_files_1 = require("./browser_files"); +exports.browserFiles = browser_files_1.browserFiles; +var browser_http_1 = require("./browser_http"); +exports.browserHTTPRequest = browser_http_1.browserHTTPRequest; +var io_utils_1 = require("./io_utils"); +exports.concatenateArrayBuffers = io_utils_1.concatenateArrayBuffers; +exports.decodeWeights = io_utils_1.decodeWeights; +exports.encodeWeights = io_utils_1.encodeWeights; +exports.getModelArtifactsInfoForJSON = io_utils_1.getModelArtifactsInfoForJSON; +var passthrough_1 = require("./passthrough"); +exports.fromMemory = passthrough_1.fromMemory; +exports.withSaveHandler = passthrough_1.withSaveHandler; +var router_registry_1 = require("./router_registry"); +var weights_loader_1 = require("./weights_loader"); +exports.loadWeights = weights_loader_1.loadWeights; +var registerSaveRouter = router_registry_1.IORouterRegistry.registerSaveRouter; +exports.registerSaveRouter = registerSaveRouter; +var registerLoadRouter = router_registry_1.IORouterRegistry.registerLoadRouter; +exports.registerLoadRouter = registerLoadRouter; +var getSaveHandlers = router_registry_1.IORouterRegistry.getSaveHandlers; +exports.getSaveHandlers = getSaveHandlers; +var getLoadHandlers = router_registry_1.IORouterRegistry.getLoadHandlers; +exports.getLoadHandlers = getLoadHandlers; +var model_management_1 = require("./model_management"); +exports.copyModel = model_management_1.copyModel; +exports.listModels = model_management_1.listModels; +exports.moveModel = model_management_1.moveModel; +exports.removeModel = model_management_1.removeModel; +//# sourceMappingURL=io.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/io.js.map new file mode 100644 index 0000000..fae71e4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io.js.map @@ -0,0 +1 @@ +{"version":3,"file":"io.js","sourceRoot":"","sources":["../../src/io/io.ts"],"names":[],"mappings":";;AAmBA,wBAAsB;AACtB,2BAAyB;AAEzB,iDAA6C;AAgB3C,uBAhBM,4BAAY,CAgBN;AAfd,+CAAkD;AAgBhD,6BAhBM,iCAAkB,CAgBN;AAfpB,uCAA+G;AAgB7G,kCAhBM,kCAAuB,CAgBN;AACvB,wBAjB+B,wBAAa,CAiB/B;AACb,wBAlB8C,wBAAa,CAkB9C;AAGb,uCArB6D,uCAA4B,CAqB7D;AApB9B,6CAA0D;AAkBxD,qBAlBM,wBAAU,CAkBN;AAgBV,0BAlCkB,6BAAe,CAkClB;AAjCjB,qDAAmD;AAEnD,mDAA6C;AAqB3C,sBArBM,4BAAW,CAqBN;AAnBb,IAAM,kBAAkB,GAAG,kCAAgB,CAAC,kBAAkB,CAAC;AAuB7D,gDAAkB;AAtBpB,IAAM,kBAAkB,GAAG,kCAAgB,CAAC,kBAAkB,CAAC;AAqB7D,gDAAkB;AApBpB,IAAM,eAAe,GAAG,kCAAgB,CAAC,eAAe,CAAC;AAcvD,0CAAe;AAbjB,IAAM,eAAe,GAAG,kCAAgB,CAAC,eAAe,CAAC;AAWvD,0CAAe;AATjB,uDAAiF;AAAzE,uCAAA,SAAS,CAAA;AAAE,wCAAA,UAAU,CAAA;AAAE,uCAAA,SAAS,CAAA;AAAE,yCAAA,WAAW,CAAA"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.d.ts new file mode 100644 index 0000000..8c70b11 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.d.ts @@ -0,0 +1,15 @@ +import { NamedTensorMap } from '../tensor_types'; +import { TypedArray } from '../types'; +import { ModelArtifacts, ModelArtifactsInfo, WeightsManifestEntry } from './types'; +export declare function encodeWeights(tensors: NamedTensorMap): Promise<{ + data: ArrayBuffer; + specs: WeightsManifestEntry[]; +}>; +export declare function decodeWeights(buffer: ArrayBuffer, specs: WeightsManifestEntry[]): NamedTensorMap; +export declare function concatenateTypedArrays(xs: TypedArray[]): ArrayBuffer; +export declare function stringByteLength(str: string): number; +export declare function arrayBufferToBase64String(buffer: ArrayBuffer): string; +export declare function base64StringToArrayBuffer(str: string): ArrayBuffer; +export declare function concatenateArrayBuffers(buffers: ArrayBuffer[]): ArrayBuffer; +export declare function basename(path: string): string; +export declare function getModelArtifactsInfoForJSON(modelArtifacts: ModelArtifacts): ModelArtifactsInfo; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js new file mode 100644 index 0000000..0ccd90f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js @@ -0,0 +1,195 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_ops_1 = require("../ops/tensor_ops"); +var util_1 = require("../util"); +var types_1 = require("./types"); +function encodeWeights(tensors) { + return __awaiter(this, void 0, void 0, function () { + var specs, dataPromises, name_1, t, tensorValues; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + specs = []; + dataPromises = []; + for (name_1 in tensors) { + t = tensors[name_1]; + if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool') { + throw new Error("Unsupported dtype in weight '" + name_1 + "': " + t.dtype); + } + specs.push({ name: name_1, shape: t.shape, dtype: t.dtype }); + dataPromises.push(t.data()); + } + return [4, Promise.all(dataPromises)]; + case 1: + tensorValues = _a.sent(); + return [2, { data: concatenateTypedArrays(tensorValues), specs: specs }]; + } + }); + }); +} +exports.encodeWeights = encodeWeights; +function decodeWeights(buffer, specs) { + var out = {}; + var offset = 0; + for (var _i = 0, specs_1 = specs; _i < specs_1.length; _i++) { + var spec = specs_1[_i]; + var name_2 = spec.name; + var dtype = spec.dtype; + var shape = spec.shape; + if (spec.quantization != null) { + throw new Error("decodeWeights does not support quantization yet, but encountered " + + ("weight '" + name_2 + " with quantization.'")); + } + var size = util_1.sizeFromShape(shape); + var value = void 0; + if (dtype === 'float32') { + value = tensor_ops_1.tensor(new Float32Array(buffer, offset, size), shape, 'float32'); + } + else if (dtype === 'int32') { + value = tensor_ops_1.tensor(new Int32Array(buffer, offset, size), shape, 'int32'); + } + else if (dtype === 'bool') { + value = tensor_ops_1.tensor(new Uint8Array(buffer, offset, size), shape, 'bool'); + } + else { + throw new Error("Unsupported dtype in weight '" + name_2 + "': " + dtype); + } + out[name_2] = value; + offset += size * types_1.DTYPE_VALUE_SIZE_MAP[dtype]; + } + return out; +} +exports.decodeWeights = decodeWeights; +function concatenateTypedArrays(xs) { + if (xs === null) { + throw new Error("Invalid input value: " + JSON.stringify(xs)); + } + var totalByteLength = 0; + var normalizedXs = []; + xs.forEach(function (x) { + totalByteLength += x.byteLength; + normalizedXs.push(x.byteLength === x.buffer.byteLength ? x : + new x.constructor(x)); + if (!(x instanceof Float32Array || x instanceof Int32Array || + x instanceof Uint8Array)) { + throw new Error("Unsupported TypedArray subtype: " + x.constructor.name); + } + }); + var y = new Uint8Array(totalByteLength); + var offset = 0; + normalizedXs.forEach(function (x) { + y.set(new Uint8Array(x.buffer), offset); + offset += x.byteLength; + }); + return y.buffer; +} +exports.concatenateTypedArrays = concatenateTypedArrays; +var useNodeBuffer = typeof Buffer !== 'undefined' && + (typeof Blob === 'undefined' || typeof atob === 'undefined' || + typeof btoa === 'undefined'); +function stringByteLength(str) { + if (useNodeBuffer) { + return Buffer.byteLength(str); + } + return new Blob([str]).size; +} +exports.stringByteLength = stringByteLength; +function arrayBufferToBase64String(buffer) { + if (useNodeBuffer) { + return Buffer.from(buffer).toString('base64'); + } + return btoa(String.fromCharCode.apply(null, new Uint8Array(buffer))); +} +exports.arrayBufferToBase64String = arrayBufferToBase64String; +function base64StringToArrayBuffer(str) { + if (useNodeBuffer) { + var buf = Buffer.from(str, 'base64'); + return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength); + } + var s = atob(str); + var buffer = new Uint8Array(s.length); + for (var i = 0; i < s.length; ++i) { + buffer.set([s.charCodeAt(i)], i); + } + return buffer.buffer; +} +exports.base64StringToArrayBuffer = base64StringToArrayBuffer; +function concatenateArrayBuffers(buffers) { + var totalByteLength = 0; + buffers.forEach(function (buffer) { + totalByteLength += buffer.byteLength; + }); + var temp = new Uint8Array(totalByteLength); + var offset = 0; + buffers.forEach(function (buffer) { + temp.set(new Uint8Array(buffer), offset); + offset += buffer.byteLength; + }); + return temp.buffer; +} +exports.concatenateArrayBuffers = concatenateArrayBuffers; +function basename(path) { + var SEPARATOR = '/'; + path = path.trim(); + while (path.endsWith(SEPARATOR)) { + path = path.slice(0, path.length - 1); + } + var items = path.split(SEPARATOR); + return items[items.length - 1]; +} +exports.basename = basename; +function getModelArtifactsInfoForJSON(modelArtifacts) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('Expected JSON model topology, received ArrayBuffer.'); + } + return { + dateSaved: new Date(), + modelTopologyType: 'JSON', + modelTopologyBytes: modelArtifacts.modelTopology == null ? + 0 : + stringByteLength(JSON.stringify(modelArtifacts.modelTopology)), + weightSpecsBytes: modelArtifacts.weightSpecs == null ? + 0 : + stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)), + weightDataBytes: modelArtifacts.weightData == null ? + 0 : + modelArtifacts.weightData.byteLength, + }; +} +exports.getModelArtifactsInfoForJSON = getModelArtifactsInfoForJSON; +//# sourceMappingURL=io_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js.map new file mode 100644 index 0000000..e8e3574 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"io_utils.js","sourceRoot":"","sources":["../../src/io/io_utils.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js new file mode 100644 index 0000000..387305d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js @@ -0,0 +1,465 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var ops_1 = require("../ops/ops"); +var test_util_1 = require("../test_util"); +var io_utils_1 = require("./io_utils"); +describe('concatenateTypedArrays', function () { + it('Single float arrays', function () { + var x = new Float32Array([1.1, 2.2, 3.3]); + var buffer = io_utils_1.concatenateTypedArrays([x]); + expect(buffer.byteLength).toEqual(12); + expect(new Float32Array(buffer, 0, 3)).toEqual(x); + }); + it('Float arrays', function () { + var x = new Float32Array([1.1, 2.2, 3.3]); + var y = new Float32Array([-1.1, -2.2, -3.3]); + var buffer = io_utils_1.concatenateTypedArrays([x, y]); + expect(buffer.byteLength).toEqual(24); + expect(new Float32Array(buffer, 0, 3)).toEqual(x); + expect(new Float32Array(buffer, 12, 3)).toEqual(y); + }); + it('Single int32 arrays', function () { + var x = new Int32Array([11, 22, 33]); + var buffer = io_utils_1.concatenateTypedArrays([x]); + expect(buffer.byteLength).toEqual(12); + expect(new Int32Array(buffer, 0, 3)).toEqual(x); + }); + it('Int32 arrays', function () { + var x = new Int32Array([11, 22, 33]); + var y = new Int32Array([-11, -22, -33]); + var buffer = io_utils_1.concatenateTypedArrays([x, y]); + expect(buffer.byteLength).toEqual(24); + expect(new Int32Array(buffer, 0, 3)).toEqual(x); + expect(new Int32Array(buffer, 12, 3)).toEqual(y); + }); + it('Single uint8 arrays', function () { + var x = new Uint8Array([11, 22, 33]); + var buffer = io_utils_1.concatenateTypedArrays([x]); + expect(buffer.byteLength).toEqual(3); + expect(new Uint8Array(buffer, 0, 3)).toEqual(x); + }); + it('Uint8 arrays', function () { + var x = new Uint8Array([11, 22, 33]); + var y = new Uint8Array([111, 122, 133]); + var buffer = io_utils_1.concatenateTypedArrays([x, y]); + expect(buffer.byteLength).toEqual(6); + expect(new Uint8Array(buffer, 0, 3)).toEqual(x); + expect(new Uint8Array(buffer, 3, 3)).toEqual(y); + }); + it('Mixed Uint8, Int32 and Float32 arrays', function () { + var x = new Uint8Array([0, 1, 1, 0]); + var y = new Int32Array([10, 20, 30, 40]); + var z = new Float32Array([-1.1, -2.2, -3.3, -4.4]); + var buffer = io_utils_1.concatenateTypedArrays([x, y, z]); + expect(buffer.byteLength).toEqual(1 * 4 + 4 * 4 + 4 * 4); + expect(new Uint8Array(buffer, 0, 4)).toEqual(x); + expect(new Int32Array(buffer, 4, 4)).toEqual(y); + expect(new Float32Array(buffer, 20, 4)).toEqual(z); + }); + it('Concatenate Float32Arrays from SubArrays', function () { + var x1 = new Float32Array([1.1, 2.2, 3.3]); + var x2 = new Float32Array([-1.1, -2.2, -3.3]); + var xConcatenated = io_utils_1.concatenateTypedArrays([x1, x2]); + var y1 = new Float32Array(xConcatenated, 0, 3); + var y2 = new Float32Array(xConcatenated, 3 * 4, 3); + expect(y1.buffer.byteLength).toEqual(6 * 4); + expect(y2.buffer.byteLength).toEqual(6 * 4); + var yConcatenated = io_utils_1.concatenateTypedArrays([y1, y2]); + expect(yConcatenated.byteLength).toEqual(6 * 4); + expect(new Float32Array(yConcatenated, 0, 3)).toEqual(x1); + expect(new Float32Array(yConcatenated, 3 * 4, 3)).toEqual(x2); + }); + it('Concatenate Int32Array from SubArrays', function () { + var x1 = new Int32Array([11, 22, 33]); + var x2 = new Int32Array([-11, -22, -33]); + var xConcatenated = io_utils_1.concatenateTypedArrays([x1, x2]); + var y1 = new Int32Array(xConcatenated, 0, 3); + var y2 = new Int32Array(xConcatenated, 3 * 4, 3); + expect(y1.buffer.byteLength).toEqual(6 * 4); + expect(y2.buffer.byteLength).toEqual(6 * 4); + var yConcatenated = io_utils_1.concatenateTypedArrays([y1, y2]); + expect(yConcatenated.byteLength).toEqual(6 * 4); + expect(new Int32Array(yConcatenated, 0, 3)).toEqual(x1); + expect(new Int32Array(yConcatenated, 3 * 4, 3)).toEqual(x2); + }); + it('Concatenate Uint8Array from SubArrays', function () { + var x1 = new Uint8Array([11, 22, 33]); + var x2 = new Uint8Array([44, 55, 66]); + var xConcatenated = io_utils_1.concatenateTypedArrays([x1, x2]); + var y1 = new Uint8Array(xConcatenated, 0, 3); + var y2 = new Uint8Array(xConcatenated, 3, 3); + expect(y1.buffer.byteLength).toEqual(6); + expect(y2.buffer.byteLength).toEqual(6); + var yConcatenated = io_utils_1.concatenateTypedArrays([y1, y2]); + expect(yConcatenated.byteLength).toEqual(6); + expect(new Uint8Array(yConcatenated, 0, 3)).toEqual(x1); + expect(new Uint8Array(yConcatenated, 3, 3)).toEqual(x2); + }); + it('Concatenate mixed TypedArrays from SubArrays', function () { + var x1 = new Uint8Array([11, 22, 33, 44]); + var x2 = new Int32Array([-44, -55, -66]); + var x3 = new Float32Array([1.1, 2.2, 3.3]); + var xConcatenated = io_utils_1.concatenateTypedArrays([x1, x2, x3]); + var y1 = new Uint8Array(xConcatenated, 0, 4); + var y2 = new Int32Array(xConcatenated, 4, 3); + var y3 = new Float32Array(xConcatenated, 4 + 3 * 4, 3); + expect(y1.buffer.byteLength).toEqual(4 + 3 * 4 + 3 * 4); + expect(y2.buffer.byteLength).toEqual(4 + 3 * 4 + 3 * 4); + expect(y3.buffer.byteLength).toEqual(4 + 3 * 4 + 3 * 4); + var yConcatenated = io_utils_1.concatenateTypedArrays([y1, y2, y3]); + expect(yConcatenated.byteLength).toEqual(4 + 3 * 4 + 3 * 4); + expect(new Uint8Array(yConcatenated, 0, 4)).toEqual(x1); + expect(new Int32Array(yConcatenated, 4, 3)).toEqual(x2); + expect(new Float32Array(yConcatenated, 4 + 3 * 4, 3)).toEqual(x3); + }); + it('null and undefined inputs', function () { + expect(function () { return io_utils_1.concatenateTypedArrays(null); }).toThrow(); + expect(function () { return io_utils_1.concatenateTypedArrays(undefined); }).toThrow(); + }); + it('empty input array', function () { + expect(io_utils_1.concatenateTypedArrays([]).byteLength).toEqual(0); + }); + it('Unsupported dtype', function () { + var x = new Int16Array([0, 1, 1, 0]); + expect(function () { return io_utils_1.concatenateTypedArrays([x]); }) + .toThrowError(/Unsupported TypedArray subtype: Int16Array/); + }); +}); +describe('encodeWeights', function () { + it('Float32 tensors', function (done) { return __awaiter(_this, void 0, void 0, function () { + var tensors; + return __generator(this, function (_a) { + tensors = { + x1: ops_1.tensor2d([[10, 20], [30, 40]]), + x2: ops_1.scalar(42), + x3: ops_1.tensor1d([-1.3, -3.7, 1.3, 3.7]), + }; + tf.io.encodeWeights(tensors) + .then(function (dataAndSpecs) { + var data = dataAndSpecs.data; + var specs = dataAndSpecs.specs; + expect(data.byteLength).toEqual(4 * (4 + 1 + 4)); + expect(new Float32Array(data, 0, 4)).toEqual(new Float32Array([ + 10, 20, 30, 40 + ])); + expect(new Float32Array(data, 16, 1)).toEqual(new Float32Array([42])); + expect(new Float32Array(data, 20, 4)).toEqual(new Float32Array([ + -1.3, -3.7, 1.3, 3.7 + ])); + expect(specs).toEqual([ + { + name: 'x1', + dtype: 'float32', + shape: [2, 2], + }, + { + name: 'x2', + dtype: 'float32', + shape: [], + }, + { + name: 'x3', + dtype: 'float32', + shape: [4], + } + ]); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + return [2]; + }); + }); }); + it('Int32 tensors', function (done) { return __awaiter(_this, void 0, void 0, function () { + var tensors; + return __generator(this, function (_a) { + tensors = { + x1: ops_1.tensor2d([[10, 20], [30, 40]], [2, 2], 'int32'), + x2: ops_1.scalar(42, 'int32'), + x3: ops_1.tensor1d([-1, -3, -3, -7], 'int32'), + }; + tf.io.encodeWeights(tensors) + .then(function (dataAndSpecs) { + var data = dataAndSpecs.data; + var specs = dataAndSpecs.specs; + expect(data.byteLength).toEqual(4 * (4 + 1 + 4)); + expect(new Int32Array(data, 0, 4)).toEqual(new Int32Array([ + 10, 20, 30, 40 + ])); + expect(new Int32Array(data, 16, 1)).toEqual(new Int32Array([42])); + expect(new Int32Array(data, 20, 4)).toEqual(new Int32Array([ + -1, -3, -3, -7 + ])); + expect(specs).toEqual([ + { + name: 'x1', + dtype: 'int32', + shape: [2, 2], + }, + { + name: 'x2', + dtype: 'int32', + shape: [], + }, + { + name: 'x3', + dtype: 'int32', + shape: [4], + } + ]); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + return [2]; + }); + }); }); + it('Bool tensors', function (done) { return __awaiter(_this, void 0, void 0, function () { + var tensors; + return __generator(this, function (_a) { + tensors = { + x1: ops_1.tensor2d([[true, false], [false, true]], [2, 2], 'bool'), + x2: ops_1.scalar(false, 'bool'), + x3: ops_1.tensor1d([false, true, true, false], 'bool'), + }; + tf.io.encodeWeights(tensors) + .then(function (dataAndSpecs) { + var data = dataAndSpecs.data; + var specs = dataAndSpecs.specs; + expect(data.byteLength).toEqual(4 + 1 + 4); + expect(new Uint8Array(data, 0, 4)).toEqual(new Uint8Array([ + 1, 0, 0, 1 + ])); + expect(new Uint8Array(data, 4, 1)).toEqual(new Uint8Array([0])); + expect(new Uint8Array(data, 5, 4)).toEqual(new Uint8Array([ + 0, 1, 1, 0 + ])); + expect(specs).toEqual([ + { + name: 'x1', + dtype: 'bool', + shape: [2, 2], + }, + { + name: 'x2', + dtype: 'bool', + shape: [], + }, + { + name: 'x3', + dtype: 'bool', + shape: [4], + } + ]); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + return [2]; + }); + }); }); + it('Mixed dtype tensors', function (done) { return __awaiter(_this, void 0, void 0, function () { + var tensors; + return __generator(this, function (_a) { + tensors = { + x1: ops_1.tensor2d([[10, 20], [30, 40]], [2, 2], 'int32'), + x2: ops_1.scalar(13.37, 'float32'), + x3: ops_1.tensor1d([true, false, false, true], 'bool'), + }; + tf.io.encodeWeights(tensors) + .then(function (dataAndSpecs) { + var data = dataAndSpecs.data; + var specs = dataAndSpecs.specs; + expect(data.byteLength).toEqual(4 * 4 + 4 * 1 + 1 * 4); + expect(new Int32Array(data, 0, 4)).toEqual(new Int32Array([ + 10, 20, 30, 40 + ])); + expect(new Float32Array(data, 16, 1)) + .toEqual(new Float32Array([13.37])); + expect(new Uint8Array(data, 20, 4)).toEqual(new Uint8Array([ + 1, 0, 0, 1 + ])); + expect(specs).toEqual([ + { + name: 'x1', + dtype: 'int32', + shape: [2, 2], + }, + { + name: 'x2', + dtype: 'float32', + shape: [], + }, + { + name: 'x3', + dtype: 'bool', + shape: [4], + } + ]); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + return [2]; + }); + }); }); +}); +describe('decodeWeights', function () { + it('Mixed dtype tensors', function (done) { return __awaiter(_this, void 0, void 0, function () { + var tensors; + return __generator(this, function (_a) { + tensors = { + x1: ops_1.tensor2d([[10, 20], [30, 40]], [2, 2], 'int32'), + x2: ops_1.scalar(13.37, 'float32'), + x3: ops_1.tensor1d([true, false, false, true], 'bool'), + y1: ops_1.tensor2d([-10, -20, -30], [3, 1], 'float32'), + }; + tf.io.encodeWeights(tensors) + .then(function (dataAndSpecs) { + var data = dataAndSpecs.data; + var specs = dataAndSpecs.specs; + expect(data.byteLength).toEqual(4 * 4 + 4 * 1 + 1 * 4 + 4 * 3); + var decoded = tf.io.decodeWeights(data, specs); + expect(Object.keys(decoded).length).toEqual(4); + test_util_1.expectArraysEqual(decoded['x1'], tensors['x1']); + test_util_1.expectArraysEqual(decoded['x2'], tensors['x2']); + test_util_1.expectArraysEqual(decoded['x3'], tensors['x3']); + test_util_1.expectArraysEqual(decoded['y1'], tensors['y1']); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + return [2]; + }); + }); }); + it('Unsupported dtype raises Error', function () { + var buffer = new ArrayBuffer(4); + var specs = [ + { + name: 'x', + dtype: 'int16', + shape: [], + }, + { name: 'y', dtype: 'int16', shape: [] } + ]; + expect(function () { return tf.io.decodeWeights(buffer, specs); }) + .toThrowError(/Unsupported dtype in weight \'x\': int16/); + }); +}); +describe('stringByteLength', function () { + it('ASCII only', function () { + var str = '_Lorem ipsum 1337!'; + expect(io_utils_1.stringByteLength(str)).toEqual(str.length); + }); + it('Mixed narrow and wide chars', function () { + var str = 'aЖ文1'; + expect(io_utils_1.stringByteLength(str.slice(0, 1))).toEqual(1); + expect(io_utils_1.stringByteLength(str.slice(0, 2))).toEqual(3); + expect(io_utils_1.stringByteLength(str.slice(0, 3))).toEqual(6); + expect(io_utils_1.stringByteLength(str.slice(0, 4))).toEqual(7); + }); +}); +describe('arrayBufferToBase64String-base64StringToArrayBuffer', function () { + it('Round trip', function () { + var x = []; + for (var k = 0; k < 2; ++k) { + for (var i = 0; i < 254; ++i) { + x.push(i + k); + } + for (var i = 254; i >= 0; --i) { + x.push(i + k); + } + } + var buffer = Uint8Array.from(x).buffer; + var base64Str = io_utils_1.arrayBufferToBase64String(buffer); + var decoded = Array.from(new Uint8Array(io_utils_1.base64StringToArrayBuffer(base64Str))); + expect(decoded).toEqual(x); + }); +}); +describe('concatenateArrayBuffers', function () { + it('Concatenate 3 non-empty ArrayBuffers', function () { + var buffer1 = new Uint8Array([1, 2, 3]); + var buffer2 = new Uint8Array([11, 22, 33, 44]); + var buffer3 = new Uint8Array([111, 222, 100]); + var out = io_utils_1.concatenateArrayBuffers([buffer1.buffer, buffer2.buffer, buffer3.buffer]); + expect(new Uint8Array(out)).toEqual(new Uint8Array([ + 1, 2, 3, 11, 22, 33, 44, 111, 222, 100 + ])); + }); + it('Concatenate non-empty and empty ArrayBuffers', function () { + var buffer1 = new Uint8Array([1, 2, 3]); + var buffer2 = new Uint8Array([11, 22, 33, 44]); + var buffer3 = new Uint8Array([]); + var buffer4 = new Uint8Array([150, 100, 50]); + var out = io_utils_1.concatenateArrayBuffers([buffer1.buffer, buffer2.buffer, buffer3.buffer, buffer4.buffer]); + expect(new Uint8Array(out)).toEqual(new Uint8Array([ + 1, 2, 3, 11, 22, 33, 44, 150, 100, 50 + ])); + }); + it('A single ArrayBuffer', function () { + var buffer1 = new Uint8Array([1, 3, 3, 7]); + var out = io_utils_1.concatenateArrayBuffers([buffer1.buffer]); + expect(new Uint8Array(out)).toEqual(buffer1); + }); + it('Zero ArrayBuffers', function () { + expect(new Uint8Array(io_utils_1.concatenateArrayBuffers([]))) + .toEqual(new Uint8Array([])); + }); +}); +describe('basename', function () { + it('Paths without slashes', function () { + expect(io_utils_1.basename('foo.txt')).toEqual('foo.txt'); + expect(io_utils_1.basename('bar')).toEqual('bar'); + }); + it('Paths with slashes', function () { + expect(io_utils_1.basename('qux/foo.txt')).toEqual('foo.txt'); + expect(io_utils_1.basename('qux/My Model.json')).toEqual('My Model.json'); + expect(io_utils_1.basename('foo/bar/baz')).toEqual('baz'); + expect(io_utils_1.basename('/foo/bar/baz')).toEqual('baz'); + expect(io_utils_1.basename('foo/bar/baz/')).toEqual('baz'); + expect(io_utils_1.basename('foo/bar/baz//')).toEqual('baz'); + }); +}); +//# sourceMappingURL=io_utils_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js.map new file mode 100644 index 0000000..eebc1ba --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/io_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"io_utils_test.js","sourceRoot":"","sources":["../../src/io/io_utils_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.d.ts new file mode 100644 index 0000000..567e324 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.d.ts @@ -0,0 +1,24 @@ +import { IORouter } from './router_registry'; +import { IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult } from './types'; +export declare function purgeLocalStorageArtifacts(): string[]; +export declare class BrowserLocalStorage implements IOHandler { + protected readonly LS: Storage; + protected readonly modelPath: string; + protected readonly keys: { + [key: string]: string; + }; + static readonly URL_SCHEME: string; + constructor(modelPath: string); + save(modelArtifacts: ModelArtifacts): Promise; + load(): Promise; +} +export declare const localStorageRouter: IORouter; +export declare function browserLocalStorage(modelPath: string): IOHandler; +export declare class BrowserLocalStorageManager implements ModelStoreManager { + private readonly LS; + constructor(); + listModels(): Promise<{ + [path: string]: ModelArtifactsInfo; + }>; + removeModel(path: string): Promise; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js new file mode 100644 index 0000000..c2417d8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js @@ -0,0 +1,246 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var util_1 = require("../util"); +var io_utils_1 = require("./io_utils"); +var model_management_1 = require("./model_management"); +var router_registry_1 = require("./router_registry"); +var PATH_SEPARATOR = '/'; +var PATH_PREFIX = 'tensorflowjs_models'; +var INFO_SUFFIX = 'info'; +var MODEL_TOPOLOGY_SUFFIX = 'model_topology'; +var WEIGHT_SPECS_SUFFIX = 'weight_specs'; +var WEIGHT_DATA_SUFFIX = 'weight_data'; +function purgeLocalStorageArtifacts() { + if (!environment_1.ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') { + throw new Error('purgeLocalStorageModels() cannot proceed because local storage is ' + + 'unavailable in the current environment.'); + } + var LS = window.localStorage; + var purgedModelPaths = []; + for (var i = 0; i < LS.length; ++i) { + var key = LS.key(i); + var prefix = PATH_PREFIX + PATH_SEPARATOR; + if (key.startsWith(prefix) && key.length > prefix.length) { + LS.removeItem(key); + var modelName = getModelPathFromKey(key); + if (purgedModelPaths.indexOf(modelName) === -1) { + purgedModelPaths.push(modelName); + } + } + } + return purgedModelPaths; +} +exports.purgeLocalStorageArtifacts = purgeLocalStorageArtifacts; +function getModelKeys(path) { + return { + info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR), + topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR), + weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR), + weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR) + }; +} +function getModelPathFromKey(key) { + var items = key.split(PATH_SEPARATOR); + if (items.length < 3) { + throw new Error("Invalid key format: " + key); + } + return items.slice(1, items.length - 1).join(PATH_SEPARATOR); +} +function maybeStripScheme(key) { + return key.startsWith(BrowserLocalStorage.URL_SCHEME) ? + key.slice(BrowserLocalStorage.URL_SCHEME.length) : + key; +} +var BrowserLocalStorage = (function () { + function BrowserLocalStorage(modelPath) { + if (!environment_1.ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') { + throw new Error('The current environment does not support local storage.'); + } + this.LS = window.localStorage; + if (modelPath == null || !modelPath) { + throw new Error('For local storage, modelPath must not be null, undefined or empty.'); + } + this.modelPath = modelPath; + this.keys = getModelKeys(this.modelPath); + } + BrowserLocalStorage.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var topology, weightSpecs, modelArtifactsInfo, key; + return __generator(this, function (_a) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserLocalStorage.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + else { + topology = JSON.stringify(modelArtifacts.modelTopology); + weightSpecs = JSON.stringify(modelArtifacts.weightSpecs); + modelArtifactsInfo = io_utils_1.getModelArtifactsInfoForJSON(modelArtifacts); + try { + this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo)); + this.LS.setItem(this.keys.topology, topology); + this.LS.setItem(this.keys.weightSpecs, weightSpecs); + this.LS.setItem(this.keys.weightData, io_utils_1.arrayBufferToBase64String(modelArtifacts.weightData)); + return [2, { modelArtifactsInfo: modelArtifactsInfo }]; + } + catch (err) { + for (key in this.keys) { + this.LS.removeItem(this.keys[key]); + } + throw new Error("Failed to save model '" + this.modelPath + "' to local storage: " + + "size quota being exceeded is a possible cause of this failure: " + + ("modelTopologyBytes=" + modelArtifactsInfo.modelTopologyBytes + ", ") + + ("weightSpecsBytes=" + modelArtifactsInfo.weightSpecsBytes + ", ") + + ("weightDataBytes=" + modelArtifactsInfo.weightDataBytes + ".")); + } + } + return [2]; + }); + }); + }; + BrowserLocalStorage.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var info, out, topology, weightSpecs, weightDataBase64; + return __generator(this, function (_a) { + info = JSON.parse(this.LS.getItem(this.keys.info)); + if (info == null) { + throw new Error("In local storage, there is no model with name '" + this.modelPath + "'"); + } + if (info.modelTopologyType !== 'JSON') { + throw new Error('BrowserLocalStorage does not support loading non-JSON model ' + + 'topology yet.'); + } + out = {}; + topology = JSON.parse(this.LS.getItem(this.keys.topology)); + if (topology == null) { + throw new Error("In local storage, the topology of model '" + this.modelPath + "' " + + "is missing."); + } + out.modelTopology = topology; + weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs)); + if (weightSpecs == null) { + throw new Error("In local storage, the weight specs of model '" + this.modelPath + "' " + + "are missing."); + } + out.weightSpecs = weightSpecs; + weightDataBase64 = this.LS.getItem(this.keys.weightData); + if (weightDataBase64 == null) { + throw new Error("In local storage, the binary weight values of model " + + ("'" + this.modelPath + "' are missing.")); + } + out.weightData = io_utils_1.base64StringToArrayBuffer(weightDataBase64); + return [2, out]; + }); + }); + }; + BrowserLocalStorage.URL_SCHEME = 'localstorage://'; + return BrowserLocalStorage; +}()); +exports.BrowserLocalStorage = BrowserLocalStorage; +exports.localStorageRouter = function (url) { + if (!environment_1.ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserLocalStorage.URL_SCHEME)) { + return browserLocalStorage(url.slice(BrowserLocalStorage.URL_SCHEME.length)); + } + else { + return null; + } + } +}; +router_registry_1.IORouterRegistry.registerSaveRouter(exports.localStorageRouter); +router_registry_1.IORouterRegistry.registerLoadRouter(exports.localStorageRouter); +function browserLocalStorage(modelPath) { + return new BrowserLocalStorage(modelPath); +} +exports.browserLocalStorage = browserLocalStorage; +var BrowserLocalStorageManager = (function () { + function BrowserLocalStorageManager() { + util_1.assert(environment_1.ENV.get('IS_BROWSER'), 'Current environment is not a web browser'); + util_1.assert(typeof window.localStorage !== 'undefined', 'Current browser does not appear to support localStorage'); + this.LS = window.localStorage; + } + BrowserLocalStorageManager.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var out, prefix, suffix, i, key, modelPath; + return __generator(this, function (_a) { + out = {}; + prefix = PATH_PREFIX + PATH_SEPARATOR; + suffix = PATH_SEPARATOR + INFO_SUFFIX; + for (i = 0; i < this.LS.length; ++i) { + key = this.LS.key(i); + if (key.startsWith(prefix) && key.endsWith(suffix)) { + modelPath = getModelPathFromKey(key); + out[modelPath] = JSON.parse(this.LS.getItem(key)); + } + } + return [2, out]; + }); + }); + }; + BrowserLocalStorageManager.prototype.removeModel = function (path) { + return __awaiter(this, void 0, void 0, function () { + var keys, info; + return __generator(this, function (_a) { + path = maybeStripScheme(path); + keys = getModelKeys(path); + if (this.LS.getItem(keys.info) == null) { + throw new Error("Cannot find model at path '" + path + "'"); + } + info = JSON.parse(this.LS.getItem(keys.info)); + this.LS.removeItem(keys.info); + this.LS.removeItem(keys.topology); + this.LS.removeItem(keys.weightSpecs); + this.LS.removeItem(keys.weightData); + return [2, info]; + }); + }); + }; + return BrowserLocalStorageManager; +}()); +exports.BrowserLocalStorageManager = BrowserLocalStorageManager; +if (environment_1.ENV.get('IS_BROWSER')) { + try { + model_management_1.ModelStoreManagerRegistry.registerManager(BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager()); + } + catch (err) { + } +} +//# sourceMappingURL=local_storage.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js.map new file mode 100644 index 0000000..c2a72c8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage.js.map @@ -0,0 +1 @@ +{"version":3,"file":"local_storage.js","sourceRoot":"","sources":["../../src/io/local_storage.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js new file mode 100644 index 0000000..c80e638 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js @@ -0,0 +1,379 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var io_utils_1 = require("./io_utils"); +var local_storage_1 = require("./local_storage"); +jasmine_util_1.describeWithFlags('LocalStorage', test_util_1.BROWSER_ENVS, function () { + var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' + }; + var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } + ]; + var weightData1 = new ArrayBuffer(16); + var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, + }; + function findOverflowingByteSize() { + var LS = window.localStorage; + var probeKey = "tfjs_test_probe_values_" + new Date().getTime() + "_" + Math.random(); + var minKilobytes = 200; + var stepKilobytes = 200; + var maxKilobytes = 40000; + for (var kilobytes = minKilobytes; kilobytes < maxKilobytes; kilobytes += stepKilobytes) { + var bytes = kilobytes * 1024; + var data = new ArrayBuffer(bytes); + try { + var encoded = io_utils_1.arrayBufferToBase64String(data); + LS.setItem(probeKey, encoded); + } + catch (err) { + return bytes; + } + LS.removeItem(probeKey); + } + throw new Error("Unable to determined overflowing byte size up to " + maxKilobytes + " kB."); + } + beforeEach(function () { + local_storage_1.purgeLocalStorageArtifacts(); + }); + afterEach(function () { + local_storage_1.purgeLocalStorageArtifacts(); + }); + it('Save artifacts succeeds', function (done) { + var testStartDate = new Date(); + var handler = tf.io.getSaveHandlers('localstorage://foo/FooModel')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + expect(saveResult.modelArtifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(16); + var LS = window.localStorage; + var info = JSON.parse(LS.getItem('tensorflowjs_models/foo/FooModel/info')); + expect(Date.parse(info.dateSaved)) + .toEqual(saveResult.modelArtifactsInfo.dateSaved.getTime()); + expect(info.modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(info.weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(info.weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + var topologyString = LS.getItem('tensorflowjs_models/foo/FooModel/model_topology'); + expect(JSON.stringify(modelTopology1)).toEqual(topologyString); + var weightSpecsString = LS.getItem('tensorflowjs_models/foo/FooModel/weight_specs'); + expect(JSON.stringify(weightSpecs1)).toEqual(weightSpecsString); + var weightDataBase64String = LS.getItem('tensorflowjs_models/foo/FooModel/weight_data'); + expect(io_utils_1.base64StringToArrayBuffer(weightDataBase64String)) + .toEqual(weightData1); + done(); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Save-load round trip succeeds', function () { return __awaiter(_this, void 0, void 0, function () { + var handler1, handler2, loaded; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + handler1 = tf.io.getSaveHandlers('localstorage://FooModel')[0]; + return [4, handler1.save(artifacts1)]; + case 1: + _a.sent(); + handler2 = tf.io.getLoadHandlers('localstorage://FooModel')[0]; + return [4, handler2.load()]; + case 2: + loaded = _a.sent(); + expect(loaded.modelTopology).toEqual(modelTopology1); + expect(loaded.weightSpecs).toEqual(weightSpecs1); + expect(loaded.weightData).toEqual(weightData1); + return [2]; + } + }); + }); }); + it('Loading nonexistent model fails.', function (done) { + var handler = tf.io.getSaveHandlers('localstorage://NonexistentModel')[0]; + handler.load() + .then(function (aritfacts) { + fail('Loading nonexistent model succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('In local storage, there is no model with name ' + + '\'NonexistentModel\''); + done(); + }); + }); + it('Loading model with missing topology fails.', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://FooModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + window.localStorage.removeItem('tensorflowjs_models/FooModel/model_topology'); + var handler2 = tf.io.getLoadHandlers('localstorage://FooModel')[0]; + handler2.load() + .then(function (aritfacts) { + fail('Loading of model with missing topology succeeded ' + + 'unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('In local storage, the topology of model ' + + '\'FooModel\' is missing.'); + done(); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Loading model with missing weight specs fails.', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://FooModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + window.localStorage.removeItem('tensorflowjs_models/FooModel/weight_specs'); + var handler2 = tf.io.getLoadHandlers('localstorage://FooModel')[0]; + handler2.load() + .then(function (aritfacts) { + fail('Loading of model with missing weight specs succeeded ' + + 'unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('In local storage, the weight specs of model ' + + '\'FooModel\' are missing.'); + done(); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Loading model with missing weight data fails.', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://FooModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + window.localStorage.removeItem('tensorflowjs_models/FooModel/weight_data'); + var handler2 = tf.io.getLoadHandlers('localstorage://FooModel')[0]; + handler2.load() + .then(function (aritfacts) { + fail('Loading of model with missing weight data succeeded ' + + 'unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('In local storage, the binary weight values of model ' + + '\'FooModel\' are missing.'); + done(); + }); + }) + .catch(function (err) { + console.error(err.stack); + }); + }); + it('Data size too large leads to error thrown', function (done) { + var overflowByteSize = findOverflowingByteSize(); + var overflowArtifacts = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: new ArrayBuffer(overflowByteSize), + }; + var handler1 = tf.io.getSaveHandlers('localstorage://FooModel')[0]; + handler1.save(overflowArtifacts) + .then(function (saveResult) { + fail('Saving of model of overflowing-size weight data succeeded ' + + 'unexpectedly.'); + }) + .catch(function (err) { + expect(err.message + .indexOf('Failed to save model \'FooModel\' to local storage')) + .toEqual(0); + done(); + }); + }); + it('Null, undefined or empty modelPath throws Error', function () { + expect(function () { return local_storage_1.browserLocalStorage(null); }) + .toThrowError(/local storage, modelPath must not be null, undefined or empty/); + expect(function () { return local_storage_1.browserLocalStorage(undefined); }) + .toThrowError(/local storage, modelPath must not be null, undefined or empty/); + expect(function () { return local_storage_1.browserLocalStorage(''); }) + .toThrowError(/local storage, modelPath must not be null, undefined or empty./); + }); + it('router', function () { + expect(local_storage_1.localStorageRouter('localstorage://bar') instanceof local_storage_1.BrowserLocalStorage) + .toEqual(true); + expect(local_storage_1.localStorageRouter('indexeddb://bar')).toBeNull(); + expect(local_storage_1.localStorageRouter('qux')).toBeNull(); + }); + it('Manager: List models: 0 result', function (done) { + new local_storage_1.BrowserLocalStorageManager() + .listModels() + .then(function (out) { + expect(out).toEqual({}); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: List models: 1 result', function (done) { + var handler = tf.io.getSaveHandlers('localstorage://baz/QuxModel')[0]; + handler.save(artifacts1) + .then(function (saveResult) { + new local_storage_1.BrowserLocalStorageManager() + .listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(1); + expect(out['baz/QuxModel'].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out['baz/QuxModel'].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out['baz/QuxModel'].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out['baz/QuxModel'].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: List models: 2 results', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('localstorage://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + new local_storage_1.BrowserLocalStorageManager() + .listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(2); + expect(out['QuxModel'].modelTopologyType) + .toEqual(saveResult1.modelArtifactsInfo.modelTopologyType); + expect(out['QuxModel'].modelTopologyBytes) + .toEqual(saveResult1.modelArtifactsInfo + .modelTopologyBytes); + expect(out['QuxModel'].weightSpecsBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightSpecsBytes); + expect(out['QuxModel'].weightDataBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightDataBytes); + expect(out['repeat/QuxModel'].modelTopologyType) + .toEqual(saveResult2.modelArtifactsInfo.modelTopologyType); + expect(out['repeat/QuxModel'].modelTopologyBytes) + .toEqual(saveResult2.modelArtifactsInfo + .modelTopologyBytes); + expect(out['repeat/QuxModel'].weightSpecsBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightSpecsBytes); + expect(out['repeat/QuxModel'].weightDataBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: Successful deleteModel', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('localstorage://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + var manager = new local_storage_1.BrowserLocalStorageManager(); + manager.removeModel('QuxModel') + .then(function (deletedInfo) { + manager.listModels().then(function (out) { + expect(Object.keys(out)).toEqual(['repeat/QuxModel']); + }); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); +}); +//# sourceMappingURL=local_storage_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js.map new file mode 100644 index 0000000..bf5218d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/local_storage_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"local_storage_test.js","sourceRoot":"","sources":["../../src/io/local_storage_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.d.ts new file mode 100644 index 0000000..483b7e3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.d.ts @@ -0,0 +1,17 @@ +import { ModelArtifactsInfo, ModelStoreManager } from './types'; +export declare class ModelStoreManagerRegistry { + private static instance; + private managers; + private constructor(); + private static getInstance; + static registerManager(scheme: string, manager: ModelStoreManager): void; + static getManager(scheme: string): ModelStoreManager; + static getSchemes(): string[]; +} +declare function listModels(): Promise<{ + [url: string]: ModelArtifactsInfo; +}>; +declare function removeModel(url: string): Promise; +declare function copyModel(sourceURL: string, destURL: string): Promise; +declare function moveModel(sourceURL: string, destURL: string): Promise; +export { moveModel, copyModel, removeModel, listModels }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js new file mode 100644 index 0000000..e1c7fa4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js @@ -0,0 +1,203 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var util_1 = require("../util"); +var router_registry_1 = require("./router_registry"); +var URL_SCHEME_SUFFIX = '://'; +var ModelStoreManagerRegistry = (function () { + function ModelStoreManagerRegistry() { + this.managers = {}; + } + ModelStoreManagerRegistry.getInstance = function () { + if (ModelStoreManagerRegistry.instance == null) { + ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry(); + } + return ModelStoreManagerRegistry.instance; + }; + ModelStoreManagerRegistry.registerManager = function (scheme, manager) { + util_1.assert(scheme != null, 'scheme must not be undefined or null.'); + if (scheme.endsWith(URL_SCHEME_SUFFIX)) { + scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX)); + } + util_1.assert(scheme.length > 0, 'scheme must not be an empty string.'); + var registry = ModelStoreManagerRegistry.getInstance(); + util_1.assert(registry.managers[scheme] == null, "A model store manager is already registered for scheme '" + scheme + "'."); + registry.managers[scheme] = manager; + }; + ModelStoreManagerRegistry.getManager = function (scheme) { + var manager = this.getInstance().managers[scheme]; + if (manager == null) { + throw new Error("Cannot find model manager for scheme '" + scheme + "'"); + } + return manager; + }; + ModelStoreManagerRegistry.getSchemes = function () { + return Object.keys(this.getInstance().managers); + }; + return ModelStoreManagerRegistry; +}()); +exports.ModelStoreManagerRegistry = ModelStoreManagerRegistry; +function parseURL(url) { + if (url.indexOf(URL_SCHEME_SUFFIX) === -1) { + throw new Error("The url string provided does not contain a scheme. " + + "Supported schemes are: " + + ("" + ModelStoreManagerRegistry.getSchemes().join(','))); + } + return { + scheme: url.split(URL_SCHEME_SUFFIX)[0], + path: url.split(URL_SCHEME_SUFFIX)[1], + }; +} +function cloneModelInternal(sourceURL, destURL, deleteSource) { + if (deleteSource === void 0) { deleteSource = false; } + return __awaiter(this, void 0, void 0, function () { + var loadHandlers, loadHandler, saveHandlers, saveHandler, sourceScheme, sourcePath, sameMedium, modelArtifacts, saveResult; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + util_1.assert(sourceURL !== destURL, "Old path and new path are the same: '" + sourceURL + "'"); + loadHandlers = router_registry_1.IORouterRegistry.getLoadHandlers(sourceURL); + util_1.assert(loadHandlers.length > 0, "Copying failed because no load handler is found for source URL " + sourceURL + "."); + util_1.assert(loadHandlers.length < 2, "Copying failed because more than one (" + loadHandlers.length + ") " + + ("load handlers for source URL " + sourceURL + ".")); + loadHandler = loadHandlers[0]; + saveHandlers = router_registry_1.IORouterRegistry.getSaveHandlers(destURL); + util_1.assert(saveHandlers.length > 0, "Copying failed because no save handler is found for destination URL " + + (destURL + ".")); + util_1.assert(saveHandlers.length < 2, "Copying failed because more than one (" + loadHandlers.length + ") " + + ("save handlers for destination URL " + destURL + ".")); + saveHandler = saveHandlers[0]; + sourceScheme = parseURL(sourceURL).scheme; + sourcePath = parseURL(sourceURL).path; + sameMedium = sourceScheme === parseURL(sourceURL).scheme; + return [4, loadHandler.load()]; + case 1: + modelArtifacts = _a.sent(); + if (!(deleteSource && sameMedium)) return [3, 3]; + return [4, ModelStoreManagerRegistry.getManager(sourceScheme) + .removeModel(sourcePath)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [4, saveHandler.save(modelArtifacts)]; + case 4: + saveResult = _a.sent(); + if (!(deleteSource && !sameMedium)) return [3, 6]; + return [4, ModelStoreManagerRegistry.getManager(sourceScheme) + .removeModel(sourcePath)]; + case 5: + _a.sent(); + _a.label = 6; + case 6: return [2, saveResult.modelArtifactsInfo]; + } + }); + }); +} +function listModels() { + return __awaiter(this, void 0, void 0, function () { + var schemes, out, _i, schemes_1, scheme, schemeOut, path, url; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + schemes = ModelStoreManagerRegistry.getSchemes(); + out = {}; + _i = 0, schemes_1 = schemes; + _a.label = 1; + case 1: + if (!(_i < schemes_1.length)) return [3, 4]; + scheme = schemes_1[_i]; + return [4, ModelStoreManagerRegistry.getManager(scheme).listModels()]; + case 2: + schemeOut = _a.sent(); + for (path in schemeOut) { + url = scheme + URL_SCHEME_SUFFIX + path; + out[url] = schemeOut[path]; + } + _a.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2, out]; + } + }); + }); +} +exports.listModels = listModels; +function removeModel(url) { + return __awaiter(this, void 0, void 0, function () { + var schemeAndPath, manager; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + schemeAndPath = parseURL(url); + manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme); + return [4, manager.removeModel(schemeAndPath.path)]; + case 1: return [2, _a.sent()]; + } + }); + }); +} +exports.removeModel = removeModel; +function copyModel(sourceURL, destURL) { + return __awaiter(this, void 0, void 0, function () { + var deleteSource; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + deleteSource = false; + return [4, cloneModelInternal(sourceURL, destURL, deleteSource)]; + case 1: return [2, _a.sent()]; + } + }); + }); +} +exports.copyModel = copyModel; +function moveModel(sourceURL, destURL) { + return __awaiter(this, void 0, void 0, function () { + var deleteSource; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + deleteSource = true; + return [4, cloneModelInternal(sourceURL, destURL, deleteSource)]; + case 1: return [2, _a.sent()]; + } + }); + }); +} +exports.moveModel = moveModel; +//# sourceMappingURL=model_management.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js.map new file mode 100644 index 0000000..a45712f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management.js.map @@ -0,0 +1 @@ +{"version":3,"file":"model_management.js","sourceRoot":"","sources":["../../src/io/model_management.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js new file mode 100644 index 0000000..5753160 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js @@ -0,0 +1,376 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var indexed_db_1 = require("./indexed_db"); +var local_storage_1 = require("./local_storage"); +jasmine_util_1.describeWithFlags('ModelManagement', test_util_1.CHROME_ENVS, function () { + var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' + }; + var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } + ]; + var weightData1 = new ArrayBuffer(16); + var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, + }; + beforeEach(function (done) { + local_storage_1.purgeLocalStorageArtifacts(); + indexed_db_1.deleteDatabase().then(function () { + done(); + }); + }); + afterEach(function (done) { + local_storage_1.purgeLocalStorageArtifacts(); + indexed_db_1.deleteDatabase().then(function () { + done(); + }); + }); + it('List models: 0 result', function (done) { + tf.io.listModels() + .then(function (out) { + expect(out).toEqual({}); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('List models: 1 result', function (done) { + var url = 'localstorage://baz/QuxModel'; + var handler = tf.io.getSaveHandlers(url)[0]; + handler.save(artifacts1) + .then(function (saveResult) { + tf.io.listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(1); + expect(out[url].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out[url].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out[url].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out[url].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Manager: List models: 2 results in 2 mediums', function (done) { + var url1 = 'localstorage://QuxModel'; + var url2 = 'indexeddb://QuxModel'; + var handler1 = tf.io.getSaveHandlers(url1)[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers(url2)[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + tf.io.listModels() + .then(function (out) { + expect(Object.keys(out).length).toEqual(2); + expect(out[url1].modelTopologyType) + .toEqual(saveResult1.modelArtifactsInfo.modelTopologyType); + expect(out[url1].modelTopologyBytes) + .toEqual(saveResult1.modelArtifactsInfo + .modelTopologyBytes); + expect(out[url1].weightSpecsBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightSpecsBytes); + expect(out[url1].weightDataBytes) + .toEqual(saveResult1.modelArtifactsInfo.weightDataBytes); + expect(out[url2].modelTopologyType) + .toEqual(saveResult2.modelArtifactsInfo.modelTopologyType); + expect(out[url2].modelTopologyBytes) + .toEqual(saveResult2.modelArtifactsInfo + .modelTopologyBytes); + expect(out[url2].weightSpecsBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightSpecsBytes); + expect(out[url2].weightDataBytes) + .toEqual(saveResult2.modelArtifactsInfo.weightDataBytes); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Successful removeModel', function (done) { + var handler1 = tf.io.getSaveHandlers('localstorage://QuxModel')[0]; + handler1.save(artifacts1) + .then(function (saveResult1) { + var handler2 = tf.io.getSaveHandlers('indexeddb://repeat/QuxModel')[0]; + handler2.save(artifacts1) + .then(function (saveResult2) { + tf.io.removeModel('indexeddb://repeat/QuxModel') + .then(function (deletedInfo) { + tf.io.listModels() + .then(function (out) { + expect(Object.keys(out)).toEqual([ + 'localstorage://QuxModel' + ]); + tf.io.removeModel('localstorage://QuxModel') + .then(function (out) { + tf.io.listModels() + .then(function (out) { + expect(Object.keys(out)).toEqual([]); + done(); + }) + .catch(function (err) { return done.fail(err); }); + }) + .catch(function (err) { return done.fail(err); }); + }) + .catch(function (err) { return done.fail(err); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Successful copyModel between mediums', function (done) { + var url1 = 'localstorage://a1/FooModel'; + var url2 = 'indexeddb://a1/FooModel'; + var handler1 = tf.io.getSaveHandlers(url1)[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + tf.io.copyModel(url1, url2) + .then(function (modelInfo) { + tf.io.listModels().then(function (out) { + expect(Object.keys(out).length).toEqual(2); + expect(out[url1].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out[url1].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out[url1].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out[url1].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + expect(out[url2].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out[url2].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out[url2].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out[url2].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + var handler2 = tf.io.getLoadHandlers(url2)[0]; + handler2.load() + .then(function (loaded) { + expect(loaded.modelTopology).toEqual(modelTopology1); + expect(loaded.weightSpecs).toEqual(weightSpecs1); + expect(new Uint8Array(loaded.weightData)) + .toEqual(new Uint8Array(weightData1)); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Successful moveModel between mediums', function (done) { + var url1 = 'localstorage://a1/FooModel'; + var url2 = 'indexeddb://a1/FooModel'; + var handler1 = tf.io.getSaveHandlers(url1)[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + tf.io.moveModel(url1, url2) + .then(function (modelInfo) { + tf.io.listModels().then(function (out) { + expect(Object.keys(out)).toEqual([url2]); + expect(out[url2].modelTopologyType) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyType); + expect(out[url2].modelTopologyBytes) + .toEqual(saveResult.modelArtifactsInfo.modelTopologyBytes); + expect(out[url2].weightSpecsBytes) + .toEqual(saveResult.modelArtifactsInfo.weightSpecsBytes); + expect(out[url2].weightDataBytes) + .toEqual(saveResult.modelArtifactsInfo.weightDataBytes); + var handler2 = tf.io.getLoadHandlers(url2)[0]; + handler2.load() + .then(function (loaded) { + expect(loaded.modelTopology).toEqual(modelTopology1); + expect(loaded.weightSpecs).toEqual(weightSpecs1); + expect(new Uint8Array(loaded.weightData)) + .toEqual(new Uint8Array(weightData1)); + done(); + }) + .catch(function (err) { + done.fail(err.stack); + }); + }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Failed copyModel to invalid source URL', function (done) { + var url1 = 'invalidurl'; + var url2 = 'localstorage://a1/FooModel'; + tf.io.copyModel(url1, url2) + .then(function (out) { + done.fail('Copying from invalid URL succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Copying failed because no load handler is found for ' + + 'source URL invalidurl.'); + done(); + }); + }); + it('Failed copyModel to invalid destination URL', function (done) { + var url1 = 'localstorage://a1/FooModel'; + var url2 = 'invalidurl'; + var handler1 = tf.io.getSaveHandlers(url1)[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + tf.io.copyModel(url1, url2) + .then(function (out) { + done.fail('Copying to invalid URL succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Copying failed because no save handler is found for ' + + 'destination URL invalidurl.'); + done(); + }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Failed moveModel to invalid destination URL', function (done) { + var url1 = 'localstorage://a1/FooModel'; + var url2 = 'invalidurl'; + var handler1 = tf.io.getSaveHandlers(url1)[0]; + handler1.save(artifacts1) + .then(function (saveResult) { + tf.io.moveModel(url1, url2) + .then(function (out) { + done.fail('Copying to invalid URL succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Copying failed because no save handler is found for ' + + 'destination URL invalidurl.'); + tf.io.listModels() + .then(function (out) { + expect(Object.keys(out)).toEqual([url1]); + done(); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + }) + .catch(function (err) { return done.fail(err.stack); }); + }); + it('Failed deletedModel: Absent scheme', function (done) { + tf.io.removeModel('foo') + .then(function (out) { + done.fail('Removing model with missing scheme succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toMatch(/The url string provided does not contain a scheme/); + expect(err.message.indexOf('localstorage')).toBeGreaterThan(0); + expect(err.message.indexOf('indexeddb')).toBeGreaterThan(0); + done(); + }); + }); + it('Failed deletedModel: Invalid scheme', function (done) { + tf.io.removeModel('invalidscheme://foo') + .then(function (out) { + done.fail('Removing nonexistent model succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Cannot find model manager for scheme \'invalidscheme\''); + done(); + }); + }); + it('Failed deletedModel: Nonexistent model', function (done) { + tf.io.removeModel('indexeddb://nonexistent') + .then(function (out) { + done.fail('Removing nonexistent model succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Cannot find model with path \'nonexistent\' in IndexedDB.'); + done(); + }); + }); + it('Failed copyModel', function (done) { + tf.io.copyModel('indexeddb://nonexistent', 'indexeddb://destination') + .then(function (out) { + done.fail('Copying nonexistent model succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Cannot find model with path \'nonexistent\' in IndexedDB.'); + done(); + }); + }); + it('copyModel: Identical oldPath and newPath leads to Error', function (done) { + tf.io.copyModel('a/1', 'a/1') + .then(function (out) { + done.fail('Copying with identical old & new paths succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Old path and new path are the same: \'a/1\''); + done(); + }); + }); + it('moveModel: Identical oldPath and newPath leads to Error', function (done) { + tf.io.moveModel('a/1', 'a/1') + .then(function (out) { + done.fail('Copying with identical old & new paths succeeded unexpectedly.'); + }) + .catch(function (err) { + expect(err.message) + .toEqual('Old path and new path are the same: \'a/1\''); + done(); + }); + }); +}); +//# sourceMappingURL=model_management_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js.map new file mode 100644 index 0000000..0601d55 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/model_management_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"model_management_test.js","sourceRoot":"","sources":["../../src/io/model_management_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.d.ts new file mode 100644 index 0000000..157be24 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.d.ts @@ -0,0 +1,3 @@ +import { IOHandler, ModelArtifacts, SaveResult, WeightsManifestEntry } from './types'; +export declare function fromMemory(modelTopology: {}, weightSpecs?: WeightsManifestEntry[], weightData?: ArrayBuffer): IOHandler; +export declare function withSaveHandler(saveHandler: (artifacts: ModelArtifacts) => SaveResult): IOHandler; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js new file mode 100644 index 0000000..91b9757 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js @@ -0,0 +1,93 @@ +"use strict"; +var __assign = (this && this.__assign) || Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var PassthroughLoader = (function () { + function PassthroughLoader(modelTopology, weightSpecs, weightData) { + this.modelTopology = modelTopology; + this.weightSpecs = weightSpecs; + this.weightData = weightData; + } + PassthroughLoader.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var result; + return __generator(this, function (_a) { + result = {}; + if (this.modelTopology != null) { + result = __assign({ modelTopology: this.modelTopology }, result); + } + if (this.weightSpecs != null && this.weightSpecs.length > 0) { + result = __assign({ weightSpecs: this.weightSpecs }, result); + } + if (this.weightData != null && this.weightData.byteLength > 0) { + result = __assign({ weightData: this.weightData }, result); + } + return [2, result]; + }); + }); + }; + return PassthroughLoader; +}()); +var PassthroughSaver = (function () { + function PassthroughSaver(saveHandler) { + this.saveHandler = saveHandler; + } + PassthroughSaver.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.saveHandler(modelArtifacts)]; + }); + }); + }; + return PassthroughSaver; +}()); +function fromMemory(modelTopology, weightSpecs, weightData) { + return new PassthroughLoader(modelTopology, weightSpecs, weightData); +} +exports.fromMemory = fromMemory; +function withSaveHandler(saveHandler) { + return new PassthroughSaver(saveHandler); +} +exports.withSaveHandler = withSaveHandler; +//# sourceMappingURL=passthrough.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js.map new file mode 100644 index 0000000..fffdafa --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough.js.map @@ -0,0 +1 @@ +{"version":3,"file":"passthrough.js","sourceRoot":"","sources":["../../src/io/passthrough.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA;IACE,2BACqB,aAA8B,EAC9B,WAAoC,EACpC,UAAwB;QAFxB,kBAAa,GAAb,aAAa,CAAiB;QAC9B,gBAAW,GAAX,WAAW,CAAyB;QACpC,eAAU,GAAV,UAAU,CAAc;IAAG,CAAC;IAE3C,gCAAI,GAAV;;;;gBACM,MAAM,GAAG,EAAE,CAAC;gBAChB,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,EAAE;oBAC9B,MAAM,cAAI,aAAa,EAAE,IAAI,CAAC,aAAa,IAAK,MAAM,CAAC,CAAC;iBACzD;gBACD,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC3D,MAAM,cAAI,WAAW,EAAE,IAAI,CAAC,WAAW,IAAK,MAAM,CAAC,CAAC;iBACrD;gBACD,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,EAAE;oBAC7D,MAAM,cAAI,UAAU,EAAE,IAAI,CAAC,UAAU,IAAK,MAAM,CAAC,CAAC;iBACnD;gBACD,WAAO,MAAM,EAAC;;;KACf;IACH,wBAAC;AAAD,CAAC,AAnBD,IAmBC;AAED;IACE,0BACqB,WAAsD;QAAtD,gBAAW,GAAX,WAAW,CAA2C;IAC3E,CAAC;IAEK,+BAAI,GAAV,UAAW,cAA8B;;;gBACvC,WAAO,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAC;;;KACzC;IACH,uBAAC;AAAD,CAAC,AARD,IAQC;AAsBD,oBACI,aAAiB,EAAE,WAAoC,EACvD,UAAwB;IAC1B,OAAO,IAAI,iBAAiB,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;AACvE,CAAC;AAJD,gCAIC;AAiBD,yBACI,WAAsD;IACxD,OAAO,IAAI,gBAAgB,CAAC,WAAW,CAAC,CAAC;AAC3C,CAAC;AAHD,0CAGC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js new file mode 100644 index 0000000..9420360 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js @@ -0,0 +1,167 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require(".."); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var modelTopology1 = { + 'class_name': 'Sequential', + 'keras_version': '2.1.4', + 'config': [{ + 'class_name': 'Dense', + 'config': { + 'kernel_initializer': { + 'class_name': 'VarianceScaling', + 'config': { + 'distribution': 'uniform', + 'scale': 1.0, + 'seed': null, + 'mode': 'fan_avg' + } + }, + 'name': 'dense', + 'kernel_constraint': null, + 'bias_regularizer': null, + 'bias_constraint': null, + 'dtype': 'float32', + 'activation': 'linear', + 'trainable': true, + 'kernel_regularizer': null, + 'bias_initializer': { 'class_name': 'Zeros', 'config': {} }, + 'units': 1, + 'batch_input_shape': [null, 3], + 'use_bias': true, + 'activity_regularizer': null + } + }], + 'backend': 'tensorflow' +}; +var weightSpecs1 = [ + { + name: 'dense/kernel', + shape: [3, 1], + dtype: 'float32', + }, + { + name: 'dense/bias', + shape: [1], + dtype: 'float32', + } +]; +var weightData1 = new ArrayBuffer(16); +var artifacts1 = { + modelTopology: modelTopology1, + weightSpecs: weightSpecs1, + weightData: weightData1, +}; +jasmine_util_1.describeWithFlags('Passthrough Saver', test_util_1.BROWSER_ENVS, function () { + it('passes provided arguments through on save', function () { return __awaiter(_this, void 0, void 0, function () { + function saveHandler(artifacts) { + savedArtifacts = artifacts; + return { + modelArtifactsInfo: { + dateSaved: testStartDate, + modelTopologyType: 'JSON', + modelTopologyBytes: JSON.stringify(modelTopology1).length, + weightSpecsBytes: JSON.stringify(weightSpecs1).length, + weightDataBytes: weightData1.byteLength, + } + }; + } + var testStartDate, savedArtifacts, saveTrigger, saveResult, artifactsInfo; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + testStartDate = new Date(); + savedArtifacts = null; + saveTrigger = tf.io.withSaveHandler(saveHandler); + return [4, saveTrigger.save(artifacts1)]; + case 1: + saveResult = _a.sent(); + expect(saveResult.errors).toEqual(undefined); + artifactsInfo = saveResult.modelArtifactsInfo; + expect(artifactsInfo.dateSaved.getTime()) + .toBeGreaterThanOrEqual(testStartDate.getTime()); + expect(saveResult.modelArtifactsInfo.modelTopologyBytes) + .toEqual(JSON.stringify(modelTopology1).length); + expect(saveResult.modelArtifactsInfo.weightSpecsBytes) + .toEqual(JSON.stringify(weightSpecs1).length); + expect(saveResult.modelArtifactsInfo.weightDataBytes).toEqual(16); + expect(savedArtifacts.modelTopology).toEqual(modelTopology1); + expect(savedArtifacts.weightSpecs).toEqual(weightSpecs1); + expect(savedArtifacts.weightData).toEqual(weightData1); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('Passthrough Loader', test_util_1.BROWSER_ENVS, function () { + it('load topology and weights', function () { return __awaiter(_this, void 0, void 0, function () { + var passthroughHandler, modelArtifacts; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + passthroughHandler = tf.io.fromMemory(modelTopology1, weightSpecs1, weightData1); + return [4, passthroughHandler.load()]; + case 1: + modelArtifacts = _a.sent(); + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toEqual(weightSpecs1); + expect(modelArtifacts.weightData).toEqual(weightData1); + return [2]; + } + }); + }); }); + it('load model topology only', function () { return __awaiter(_this, void 0, void 0, function () { + var passthroughHandler, modelArtifacts; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + passthroughHandler = tf.io.fromMemory(modelTopology1); + return [4, passthroughHandler.load()]; + case 1: + modelArtifacts = _a.sent(); + expect(modelArtifacts.modelTopology).toEqual(modelTopology1); + expect(modelArtifacts.weightSpecs).toEqual(undefined); + expect(modelArtifacts.weightData).toEqual(undefined); + return [2]; + } + }); + }); }); +}); +//# sourceMappingURL=passthrough_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js.map new file mode 100644 index 0000000..1d01ace --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/passthrough_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"passthrough_test.js","sourceRoot":"","sources":["../../src/io/passthrough_test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBA,iBAgHA;;AAhHA,uBAAyB;AACzB,gDAAkD;AAClD,0CAA0C;AAE1C,IAAM,cAAc,GAAO;IACzB,YAAY,EAAE,YAAY;IAC1B,eAAe,EAAE,OAAO;IACxB,QAAQ,EAAE,CAAC;YACT,YAAY,EAAE,OAAO;YACrB,QAAQ,EAAE;gBACR,oBAAoB,EAAE;oBACpB,YAAY,EAAE,iBAAiB;oBAC/B,QAAQ,EAAE;wBACR,cAAc,EAAE,SAAS;wBACzB,OAAO,EAAE,GAAG;wBACZ,MAAM,EAAE,IAAI;wBACZ,MAAM,EAAE,SAAS;qBAClB;iBACF;gBACD,MAAM,EAAE,OAAO;gBACf,mBAAmB,EAAE,IAAI;gBACzB,kBAAkB,EAAE,IAAI;gBACxB,iBAAiB,EAAE,IAAI;gBACvB,OAAO,EAAE,SAAS;gBAClB,YAAY,EAAE,QAAQ;gBACtB,WAAW,EAAE,IAAI;gBACjB,oBAAoB,EAAE,IAAI;gBAC1B,kBAAkB,EAAE,EAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAC;gBACzD,OAAO,EAAE,CAAC;gBACV,mBAAmB,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC9B,UAAU,EAAE,IAAI;gBAChB,sBAAsB,EAAE,IAAI;aAC7B;SACF,CAAC;IACF,SAAS,EAAE,YAAY;CACxB,CAAC;AAEF,IAAM,YAAY,GAAiC;IACjD;QACE,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QACb,KAAK,EAAE,SAAS;KACjB;IACD;QACE,IAAI,EAAE,YAAY;QAClB,KAAK,EAAE,CAAC,CAAC,CAAC;QACV,KAAK,EAAE,SAAS;KACjB;CACF,CAAC;AAEF,IAAM,WAAW,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;AACxC,IAAM,UAAU,GAAyB;IACvC,aAAa,EAAE,cAAc;IAC7B,WAAW,EAAE,YAAY;IACzB,UAAU,EAAE,WAAW;CACxB,CAAC;AAEF,gCAAiB,CAAC,mBAAmB,EAAE,wBAAY,EAAE;IACnD,EAAE,CAAC,2CAA2C,EAAE;QAI9C,qBAAqB,SAA+B;YAClD,cAAc,GAAG,SAAS,CAAC;YAC3B,OAAO;gBACL,kBAAkB,EAAE;oBAClB,SAAS,EAAE,aAAa;oBACxB,iBAAiB,EAAE,MAAM;oBACzB,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM;oBACzD,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,MAAM;oBACrD,eAAe,EAAE,WAAW,CAAC,UAAU;iBACxC;aACF,CAAC;QACJ,CAAC;;;;;oBAdK,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC;oBAC7B,cAAc,GAAyB,IAAI,CAAC;oBAe1C,WAAW,GAAG,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;oBACpC,WAAM,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,EAAA;;oBAA/C,UAAU,GAAG,SAAkC;oBAErD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;oBACvC,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC;oBACpD,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;yBACpC,sBAAsB,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;oBACrD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,kBAAkB,CAAC;yBACnD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC;oBACpD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC;yBACjD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;oBAClD,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;oBAElE,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;oBAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;oBACzD,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;;;;SACxD,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,oBAAoB,EAAE,wBAAY,EAAE;IACpD,EAAE,CAAC,2BAA2B,EAAE;;;;;oBACxB,kBAAkB,GACpB,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,cAAc,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;oBACzC,WAAM,kBAAkB,CAAC,IAAI,EAAE,EAAA;;oBAAhD,cAAc,GAAG,SAA+B;oBACtD,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;oBAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;oBACzD,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;;;;SACxD,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;;;;;oBACvB,kBAAkB,GAAG,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;oBACrC,WAAM,kBAAkB,CAAC,IAAI,EAAE,EAAA;;oBAAhD,cAAc,GAAG,SAA+B;oBACtD,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;oBAC7D,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;oBACtD,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;;;;SACtD,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.d.ts new file mode 100644 index 0000000..e5cc6bc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.d.ts @@ -0,0 +1,14 @@ +import { IOHandler } from './types'; +export declare type IORouter = (url: string) => IOHandler; +export declare class IORouterRegistry { + private static instance; + private saveRouters; + private loadRouters; + private constructor(); + private static getInstance; + static registerSaveRouter(saveRouter: IORouter): void; + static registerLoadRouter(loadRouter: IORouter): void; + static getSaveHandlers(url: string): IOHandler[]; + static getLoadHandlers(url: string): IOHandler[]; + private static getHandlers; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js new file mode 100644 index 0000000..e57dd46 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js @@ -0,0 +1,41 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var IORouterRegistry = (function () { + function IORouterRegistry() { + this.saveRouters = []; + this.loadRouters = []; + } + IORouterRegistry.getInstance = function () { + if (IORouterRegistry.instance == null) { + IORouterRegistry.instance = new IORouterRegistry(); + } + return IORouterRegistry.instance; + }; + IORouterRegistry.registerSaveRouter = function (saveRouter) { + IORouterRegistry.getInstance().saveRouters.push(saveRouter); + }; + IORouterRegistry.registerLoadRouter = function (loadRouter) { + IORouterRegistry.getInstance().loadRouters.push(loadRouter); + }; + IORouterRegistry.getSaveHandlers = function (url) { + return IORouterRegistry.getHandlers(url, 'save'); + }; + IORouterRegistry.getLoadHandlers = function (url) { + return IORouterRegistry.getHandlers(url, 'load'); + }; + IORouterRegistry.getHandlers = function (url, handlerType) { + var validHandlers = []; + var routers = handlerType === 'load' ? this.getInstance().loadRouters : + this.getInstance().saveRouters; + routers.forEach(function (router) { + var handler = router(url); + if (handler !== null) { + validHandlers.push(handler); + } + }); + return validHandlers; + }; + return IORouterRegistry; +}()); +exports.IORouterRegistry = IORouterRegistry; +//# sourceMappingURL=router_registry.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js.map new file mode 100644 index 0000000..ec91550 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry.js.map @@ -0,0 +1 @@ +{"version":3,"file":"router_registry.js","sourceRoot":"","sources":["../../src/io/router_registry.ts"],"names":[],"mappings":";;AAqBA;IAOE;QACE,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAEc,4BAAW,GAA1B;QACE,IAAI,gBAAgB,CAAC,QAAQ,IAAI,IAAI,EAAE;YACrC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,gBAAgB,EAAE,CAAC;SACpD;QACD,OAAO,gBAAgB,CAAC,QAAQ,CAAC;IACnC,CAAC;IAQM,mCAAkB,GAAzB,UAA0B,UAAoB;QAC5C,gBAAgB,CAAC,WAAW,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;IAQM,mCAAkB,GAAzB,UAA0B,UAAoB;QAC5C,gBAAgB,CAAC,WAAW,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;IAUM,gCAAe,GAAtB,UAAuB,GAAW;QAChC,OAAO,gBAAgB,CAAC,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACnD,CAAC;IASM,gCAAe,GAAtB,UAAuB,GAAW;QAChC,OAAO,gBAAgB,CAAC,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACnD,CAAC;IAEc,4BAAW,GAA1B,UAA2B,GAAW,EAAE,WAA0B;QAEhE,IAAM,aAAa,GAAgB,EAAE,CAAC;QACtC,IAAM,OAAO,GAAG,WAAW,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,WAAW,CAAC,CAAC;YAChC,IAAI,CAAC,WAAW,EAAE,CAAC,WAAW,CAAC;QACxE,OAAO,CAAC,OAAO,CAAC,UAAA,MAAM;YACpB,IAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;YAC5B,IAAI,OAAO,KAAK,IAAI,EAAE;gBACpB,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aAC7B;QACH,CAAC,CAAC,CAAC;QACH,OAAO,aAAa,CAAC;IACvB,CAAC;IACH,uBAAC;AAAD,CAAC,AA3ED,IA2EC;AA3EY,4CAAgB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js new file mode 100644 index 0000000..65ec045 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js @@ -0,0 +1,62 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var indexed_db_1 = require("./indexed_db"); +var local_storage_1 = require("./local_storage"); +var router_registry_1 = require("./router_registry"); +jasmine_util_1.describeWithFlags('IORouterRegistry', test_util_1.BROWSER_ENVS, function () { + var localStorageRouter = function (url) { + var scheme = 'localstorage://'; + if (url.startsWith(scheme)) { + return local_storage_1.browserLocalStorage(url.slice(scheme.length)); + } + else { + return null; + } + }; + var indexedDBRouter = function (url) { + var scheme = 'indexeddb://'; + if (url.startsWith(scheme)) { + return indexed_db_1.browserIndexedDB(url.slice(scheme.length)); + } + else { + return null; + } + }; + var tempRegistryInstance = null; + beforeEach(function () { + tempRegistryInstance = router_registry_1.IORouterRegistry.instance; + router_registry_1.IORouterRegistry.instance = null; + }); + afterEach(function () { + router_registry_1.IORouterRegistry.instance = tempRegistryInstance; + }); + it('getSaveHandler succeeds', function () { + router_registry_1.IORouterRegistry.registerSaveRouter(localStorageRouter); + router_registry_1.IORouterRegistry.registerSaveRouter(indexedDBRouter); + var out1 = tf.io.getSaveHandlers('localstorage://foo-model'); + expect(out1.length).toEqual(1); + expect(out1[0] instanceof local_storage_1.BrowserLocalStorage).toEqual(true); + var out2 = tf.io.getSaveHandlers('indexeddb://foo-model'); + expect(out2.length).toEqual(1); + expect(out2[0] instanceof indexed_db_1.BrowserIndexedDB).toEqual(true); + }); + it('getLoadHandler succeeds', function () { + router_registry_1.IORouterRegistry.registerLoadRouter(localStorageRouter); + router_registry_1.IORouterRegistry.registerLoadRouter(indexedDBRouter); + var out1 = tf.io.getLoadHandlers('localstorage://foo-model'); + expect(out1.length).toEqual(1); + expect(out1[0] instanceof local_storage_1.BrowserLocalStorage).toEqual(true); + var out2 = tf.io.getLoadHandlers('indexeddb://foo-model'); + expect(out2.length).toEqual(1); + expect(out2[0] instanceof indexed_db_1.BrowserIndexedDB).toEqual(true); + }); + it('getSaveHandler fails', function () { + router_registry_1.IORouterRegistry.registerSaveRouter(localStorageRouter); + expect(tf.io.getSaveHandlers('invalidscheme://foo-model')).toEqual([]); + expect(tf.io.getLoadHandlers('localstorage://foo-model')).toEqual([]); + }); +}); +//# sourceMappingURL=router_registry_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js.map new file mode 100644 index 0000000..984f9d3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/router_registry_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"router_registry_test.js","sourceRoot":"","sources":["../../src/io/router_registry_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/types.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/types.d.ts new file mode 100644 index 0000000..979c9d3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/types.d.ts @@ -0,0 +1,50 @@ +export declare const DTYPE_VALUE_SIZE_MAP: { + [dtype: string]: number; +}; +export declare type WeightsManifestConfig = WeightsManifestGroupConfig[]; +export declare interface WeightsManifestGroupConfig { + paths: string[]; + weights: WeightsManifestEntry[]; +} +export declare interface WeightsManifestEntry { + name: string; + shape: number[]; + dtype: 'float32' | 'int32' | 'bool'; + quantization?: { + scale: number; + min: number; + dtype: 'uint16' | 'uint8'; + }; +} +export interface SaveConfig { + trainableOnly?: boolean; +} +export interface SaveResult { + modelArtifactsInfo: ModelArtifactsInfo; + responses?: Response[]; + errors?: Array<{} | string>; +} +export declare interface ModelArtifactsInfo { + dateSaved: Date; + modelTopologyType: 'JSON' | 'GraphDef'; + modelTopologyBytes?: number; + weightSpecsBytes?: number; + weightDataBytes?: number; +} +export declare interface ModelArtifacts { + modelTopology?: {} | ArrayBuffer; + weightSpecs?: WeightsManifestEntry[]; + weightData?: ArrayBuffer; +} +export declare type LoadHandler = () => Promise; +export declare type SaveHandler = (modelArtifact: ModelArtifacts) => Promise; +export interface IOHandler { + save?: SaveHandler; + load?: LoadHandler; +} +export interface ModelStoreManager { + listModels(): Promise<{ + [path: string]: ModelArtifactsInfo; + }>; + removeModel(path: string): Promise; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/types.js b/node_modules/@tensorflow/tfjs-core/dist/io/types.js new file mode 100644 index 0000000..cf52e5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/types.js @@ -0,0 +1,10 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.DTYPE_VALUE_SIZE_MAP = { + 'float32': 4, + 'int32': 4, + 'uint16': 2, + 'uint8': 1, + 'bool': 1, +}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/types.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/types.js.map new file mode 100644 index 0000000..cc5eec8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/io/types.ts"],"names":[],"mappings":";;AAsBa,QAAA,oBAAoB,GAA8B;IAC7D,SAAS,EAAE,CAAC;IACZ,OAAO,EAAE,CAAC;IACV,QAAQ,EAAE,CAAC;IACX,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.d.ts new file mode 100644 index 0000000..aa0a2a2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.d.ts @@ -0,0 +1,4 @@ +import { NamedTensorMap } from '../tensor_types'; +import { WeightsManifestConfig } from './types'; +export declare function loadWeightsAsArrayBuffer(fetchURLs: string[], requestOptions?: RequestInit): Promise; +export declare function loadWeights(manifest: WeightsManifestConfig, filePathPrefix?: string, weightNames?: string[], requestOptions?: RequestInit): Promise; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js new file mode 100644 index 0000000..07d10ab --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js @@ -0,0 +1,200 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var ops_1 = require("../ops/ops"); +var util = require("../util"); +var types_1 = require("./types"); +function loadWeightsAsArrayBuffer(fetchURLs, requestOptions) { + return __awaiter(this, void 0, void 0, function () { + var requests, responses, buffers; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + requests = fetchURLs.map(function (fetchURL) { return fetch(fetchURL, requestOptions); }); + return [4, Promise.all(requests)]; + case 1: + responses = _a.sent(); + return [4, Promise.all(responses.map(function (response) { return response.arrayBuffer(); }))]; + case 2: + buffers = _a.sent(); + return [2, buffers]; + } + }); + }); +} +exports.loadWeightsAsArrayBuffer = loadWeightsAsArrayBuffer; +function loadWeights(manifest, filePathPrefix, weightNames, requestOptions) { + if (filePathPrefix === void 0) { filePathPrefix = ''; } + return __awaiter(this, void 0, void 0, function () { + var groupIndicesToFetchMap, groupWeightsToFetch, weightsFound, allManifestWeightNames, weightsNotFound, groupIndicesToFetch, fetchUrls, buffers, weightsTensorMap, bufferIndexOffset; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + groupIndicesToFetchMap = manifest.map(function () { return false; }); + groupWeightsToFetch = {}; + weightsFound = weightNames != null ? weightNames.map(function () { return false; }) : []; + allManifestWeightNames = []; + manifest.forEach(function (manifestGroupConfig, groupIndex) { + var groupOffset = 0; + manifestGroupConfig.weights.forEach(function (weightsEntry) { + var rawDtype = ('quantization' in weightsEntry) ? + weightsEntry.quantization.dtype : + weightsEntry.dtype; + var weightsBytes = types_1.DTYPE_VALUE_SIZE_MAP[rawDtype] * + util.sizeFromShape(weightsEntry.shape); + var enqueueWeightsForFetchingFn = function () { + groupIndicesToFetchMap[groupIndex] = true; + if (groupWeightsToFetch[groupIndex] == null) { + groupWeightsToFetch[groupIndex] = []; + } + groupWeightsToFetch[groupIndex].push({ + manifestEntry: weightsEntry, + groupOffset: groupOffset, + sizeBytes: weightsBytes + }); + }; + if (weightNames != null) { + weightNames.forEach(function (weightName, weightIndex) { + if (weightName === weightsEntry.name) { + enqueueWeightsForFetchingFn(); + weightsFound[weightIndex] = true; + } + }); + } + else { + enqueueWeightsForFetchingFn(); + } + allManifestWeightNames.push(weightsEntry.name); + groupOffset += weightsBytes; + }); + }); + if (!weightsFound.every(function (found) { return found; })) { + weightsNotFound = weightNames.filter(function (weight, i) { return !weightsFound[i]; }); + throw new Error("Could not find weights in manifest with names: " + + (weightsNotFound.join(', ') + ". \n") + + "Manifest JSON has weights with names: " + + (allManifestWeightNames.join(', ') + ".")); + } + groupIndicesToFetch = groupIndicesToFetchMap.reduce(function (accumulator, shouldFetch, i) { + if (shouldFetch) { + accumulator.push(i); + } + return accumulator; + }, []); + fetchUrls = []; + groupIndicesToFetch.forEach(function (i) { + manifest[i].paths.forEach(function (filepath) { + var fetchUrl = filePathPrefix + + (!filePathPrefix.endsWith('/') ? '/' : '') + filepath; + fetchUrls.push(fetchUrl); + }); + }); + return [4, loadWeightsAsArrayBuffer(fetchUrls, requestOptions)]; + case 1: + buffers = _a.sent(); + weightsTensorMap = {}; + bufferIndexOffset = 0; + groupIndicesToFetch.forEach(function (i) { + var numBuffers = manifest[i].paths.length; + var groupBytes = 0; + for (var i_1 = 0; i_1 < numBuffers; i_1++) { + groupBytes += buffers[bufferIndexOffset + i_1].byteLength; + } + var groupBuffer = new ArrayBuffer(groupBytes); + var groupByteBuffer = new Uint8Array(groupBuffer); + var groupBufferOffset = 0; + for (var i_2 = 0; i_2 < numBuffers; i_2++) { + var buffer = new Uint8Array(buffers[bufferIndexOffset + i_2]); + groupByteBuffer.set(buffer, groupBufferOffset); + groupBufferOffset += buffer.byteLength; + } + var weightsEntries = groupWeightsToFetch[i]; + weightsEntries.forEach(function (weightsEntry) { + var byteBuffer = groupBuffer.slice(weightsEntry.groupOffset, weightsEntry.groupOffset + weightsEntry.sizeBytes); + var typedArray; + var dtype = weightsEntry.manifestEntry.dtype; + if ('quantization' in weightsEntry.manifestEntry) { + var quantization_1 = weightsEntry.manifestEntry.quantization; + if (quantization_1.dtype !== 'uint8' && quantization_1.dtype !== 'uint16') { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has unknown " + + ("quantization dtype " + quantization_1.dtype + ".")); + } + var quantizedArray = (quantization_1.dtype === 'uint8') ? + new Uint8Array(byteBuffer) : + new Uint16Array(byteBuffer); + if (dtype === 'float32') { + typedArray = Float32Array.from(quantizedArray, function (v) { return v * quantization_1.scale + quantization_1.min; }); + } + else if (dtype === 'int32') { + typedArray = Int32Array.from(quantizedArray, function (v) { return Math.round(v * quantization_1.scale + quantization_1.min); }); + } + else { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has a dtype not " + + ("supported by quantization: " + dtype)); + } + } + else { + if (dtype === 'float32') { + typedArray = new Float32Array(byteBuffer); + } + else if (dtype === 'int32') { + typedArray = new Int32Array(byteBuffer); + } + else if (dtype === 'bool') { + typedArray = new Uint8Array(byteBuffer); + } + else { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has unknown dtype " + + (dtype + ".")); + } + } + var weightName = weightsEntry.manifestEntry.name; + if (weightsTensorMap[weightName] != null) { + throw new Error("Duplicate weight with name " + weightName + ". " + + "Please make sure weights names are unique in the manifest JSON."); + } + weightsTensorMap[weightName] = ops_1.tensor(typedArray, weightsEntry.manifestEntry.shape, weightsEntry.manifestEntry.dtype); + }); + bufferIndexOffset += numBuffers; + }); + return [2, weightsTensorMap]; + } + }); + }); +} +exports.loadWeights = loadWeights; +//# sourceMappingURL=weights_loader.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js.map new file mode 100644 index 0000000..f47b706 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader.js.map @@ -0,0 +1 @@ +{"version":3,"file":"weights_loader.js","sourceRoot":"","sources":["../../src/io/weights_loader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBA,kCAAkC;AAGlC,8BAAgC;AAChC,iCAA0F;AAU1F,kCACI,SAAmB,EAAE,cAA4B;;;;;;oBAE7C,QAAQ,GAAG,SAAS,CAAC,GAAG,CAAC,UAAA,QAAQ,IAAI,OAAA,KAAK,CAAC,QAAQ,EAAE,cAAc,CAAC,EAA/B,CAA+B,CAAC,CAAC;oBAC1D,WAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAA;;oBAAvC,SAAS,GAAG,SAA2B;oBAEzC,WAAM,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,UAAA,QAAQ,IAAI,OAAA,QAAQ,CAAC,WAAW,EAAE,EAAtB,CAAsB,CAAC,CAAC,EAAA;;oBADlE,OAAO,GACT,SAAoE;oBACxE,WAAO,OAAO,EAAC;;;;CAChB;AARD,4DAQC;AAWD,qBACI,QAA+B,EAAE,cAAmB,EACpD,WAAsB,EACtB,cAA4B;IAFK,+BAAA,EAAA,mBAAmB;;;;;;oBAWhD,sBAAsB,GAAG,QAAQ,CAAC,GAAG,CAAC,cAAM,OAAA,KAAK,EAAL,CAAK,CAAC,CAAC;oBACnD,mBAAmB,GAKrB,EAAE,CAAC;oBACD,YAAY,GAAG,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,cAAM,OAAA,KAAK,EAAL,CAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBACvE,sBAAsB,GAAa,EAAE,CAAC;oBAC5C,QAAQ,CAAC,OAAO,CAAC,UAAC,mBAAmB,EAAE,UAAU;wBAC/C,IAAI,WAAW,GAAG,CAAC,CAAC;wBACpB,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,UAAA,YAAY;4BAC9C,IAAM,QAAQ,GAAG,CAAC,cAAc,IAAI,YAAY,CAAC,CAAC,CAAC;gCAC/C,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;gCACjC,YAAY,CAAC,KAAK,CAAC;4BAEvB,IAAM,YAAY,GAAG,4BAAoB,CAAC,QAAQ,CAAC;gCAC/C,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;4BAE3C,IAAM,2BAA2B,GAAG;gCAClC,sBAAsB,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC;gCAC1C,IAAI,mBAAmB,CAAC,UAAU,CAAC,IAAI,IAAI,EAAE;oCAC3C,mBAAmB,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;iCACtC;gCAED,mBAAmB,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC;oCACnC,aAAa,EAAE,YAAY;oCAC3B,WAAW,aAAA;oCACX,SAAS,EAAE,YAAY;iCACxB,CAAC,CAAC;4BACL,CAAC,CAAC;4BAEF,IAAI,WAAW,IAAI,IAAI,EAAE;gCACvB,WAAW,CAAC,OAAO,CAAC,UAAC,UAAU,EAAE,WAAW;oCAC1C,IAAI,UAAU,KAAK,YAAY,CAAC,IAAI,EAAE;wCACpC,2BAA2B,EAAE,CAAC;wCAC9B,YAAY,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC;qCAClC;gCACH,CAAC,CAAC,CAAC;6BACJ;iCAAM;gCACL,2BAA2B,EAAE,CAAC;6BAC/B;4BAED,sBAAsB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;4BAC/C,WAAW,IAAI,YAAY,CAAC;wBAC9B,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC,CAAC;oBAEH,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,EAAL,CAAK,CAAC,EAAE;wBACjC,eAAe,GAAG,WAAW,CAAC,MAAM,CAAC,UAAC,MAAM,EAAE,CAAC,IAAK,OAAA,CAAC,YAAY,CAAC,CAAC,CAAC,EAAhB,CAAgB,CAAC,CAAC;wBAC5E,MAAM,IAAI,KAAK,CACX,iDAAiD;6BAC9C,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAM,CAAA;4BACnC,wCAAwC;6BACrC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAG,CAAA,CAAC,CAAC;qBAC9C;oBAIK,mBAAmB,GACrB,sBAAsB,CAAC,MAAM,CAAC,UAAC,WAAW,EAAE,WAAW,EAAE,CAAC;wBACxD,IAAI,WAAW,EAAE;4BACf,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;yBACrB;wBACD,OAAO,WAAW,CAAC;oBACrB,CAAC,EAAE,EAAE,CAAC,CAAC;oBAEL,SAAS,GAAa,EAAE,CAAC;oBAC/B,mBAAmB,CAAC,OAAO,CAAC,UAAA,CAAC;wBAC3B,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,QAAQ;4BAChC,IAAM,QAAQ,GAAG,cAAc;gCAC3B,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC;4BAC1D,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBAC3B,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC,CAAC;oBACa,WAAM,wBAAwB,CAAC,SAAS,EAAE,cAAc,CAAC,EAAA;;oBAAnE,OAAO,GAAG,SAAyD;oBAEnE,gBAAgB,GAAmB,EAAE,CAAC;oBACxC,iBAAiB,GAAG,CAAC,CAAC;oBAC1B,mBAAmB,CAAC,OAAO,CAAC,UAAA,CAAC;wBAC3B,IAAM,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;wBAE5C,IAAI,UAAU,GAAG,CAAC,CAAC;wBACnB,KAAK,IAAI,GAAC,GAAG,CAAC,EAAE,GAAC,GAAG,UAAU,EAAE,GAAC,EAAE,EAAE;4BACnC,UAAU,IAAI,OAAO,CAAC,iBAAiB,GAAG,GAAC,CAAC,CAAC,UAAU,CAAC;yBACzD;wBAGD,IAAM,WAAW,GAAG,IAAI,WAAW,CAAC,UAAU,CAAC,CAAC;wBAChD,IAAM,eAAe,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAC;wBACpD,IAAI,iBAAiB,GAAG,CAAC,CAAC;wBAC1B,KAAK,IAAI,GAAC,GAAG,CAAC,EAAE,GAAC,GAAG,UAAU,EAAE,GAAC,EAAE,EAAE;4BACnC,IAAM,MAAM,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,iBAAiB,GAAG,GAAC,CAAC,CAAC,CAAC;4BAC9D,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;4BAC/C,iBAAiB,IAAI,MAAM,CAAC,UAAU,CAAC;yBACxC;wBAED,IAAM,cAAc,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;wBAE9C,cAAc,CAAC,OAAO,CAAC,UAAA,YAAY;4BACjC,IAAM,UAAU,GAAG,WAAW,CAAC,KAAK,CAChC,YAAY,CAAC,WAAW,EACxB,YAAY,CAAC,WAAW,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;4BAEvD,IAAI,UAAsB,CAAC;4BAE3B,IAAM,KAAK,GAAG,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC;4BAE/C,IAAI,cAAc,IAAI,YAAY,CAAC,aAAa,EAAE;gCAChD,IAAM,cAAY,GAAG,YAAY,CAAC,aAAa,CAAC,YAAY,CAAC;gCAC7D,IAAI,cAAY,CAAC,KAAK,KAAK,OAAO,IAAI,cAAY,CAAC,KAAK,KAAK,QAAQ,EAAE;oCACrE,MAAM,IAAI,KAAK,CACX,YAAU,YAAY,CAAC,aAAa,CAAC,IAAI,kBAAe;yCACxD,wBAAsB,cAAY,CAAC,KAAK,MAAG,CAAA,CAAC,CAAC;iCAClD;gCACD,IAAM,cAAc,GAAG,CAAC,cAAY,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC;oCACrD,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;oCAC5B,IAAI,WAAW,CAAC,UAAU,CAAC,CAAC;gCAChC,IAAI,KAAK,KAAK,SAAS,EAAE;oCACvB,UAAU,GAAG,YAAY,CAAC,IAAI,CAC1B,cAAc,EAAE,UAAA,CAAC,IAAI,OAAA,CAAC,GAAG,cAAY,CAAC,KAAK,GAAG,cAAY,CAAC,GAAG,EAAzC,CAAyC,CAAC,CAAC;iCACrE;qCAAM,IAAI,KAAK,KAAK,OAAO,EAAE;oCAC5B,UAAU,GAAG,UAAU,CAAC,IAAI,CACxB,cAAc,EACd,UAAA,CAAC,IAAI,OAAA,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,cAAY,CAAC,KAAK,GAAG,cAAY,CAAC,GAAG,CAAC,EAArD,CAAqD,CAAC,CAAC;iCACjE;qCAAM;oCACL,MAAM,IAAI,KAAK,CACX,YAAU,YAAY,CAAC,aAAa,CAAC,IAAI,sBAAmB;yCAC5D,gCAA8B,KAAO,CAAA,CAAC,CAAC;iCAC5C;6BACF;iCAAM;gCACL,IAAI,KAAK,KAAK,SAAS,EAAE;oCACvB,UAAU,GAAG,IAAI,YAAY,CAAC,UAAU,CAAC,CAAC;iCAC3C;qCAAM,IAAI,KAAK,KAAK,OAAO,EAAE;oCAC5B,UAAU,GAAG,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC;iCACzC;qCAAM,IAAI,KAAK,KAAK,MAAM,EAAE;oCAC3B,UAAU,GAAG,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC;iCACzC;qCAAM;oCACL,MAAM,IAAI,KAAK,CACX,YAAU,YAAY,CAAC,aAAa,CAAC,IAAI,wBAAqB;yCAC3D,KAAK,MAAG,CAAA,CAAC,CAAC;iCAClB;6BACF;4BAED,IAAM,UAAU,GAAG,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC;4BACnD,IAAI,gBAAgB,CAAC,UAAU,CAAC,IAAI,IAAI,EAAE;gCACxC,MAAM,IAAI,KAAK,CACX,gCAA8B,UAAU,OAAI;oCAC5C,iEAAiE,CAAC,CAAC;6BACxE;4BACD,gBAAgB,CAAC,UAAU,CAAC,GAAG,YAAM,CACjC,UAAU,EAAE,YAAY,CAAC,aAAa,CAAC,KAAK,EAC5C,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;wBACxC,CAAC,CAAC,CAAC;wBAEH,iBAAiB,IAAI,UAAU,CAAC;oBAClC,CAAC,CAAC,CAAC;oBAEH,WAAO,gBAAgB,EAAC;;;;CACzB;AA3KD,kCA2KC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js new file mode 100644 index 0000000..e7ce1de --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js @@ -0,0 +1,531 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('loadWeights', test_util_1.BROWSER_ENVS, function () { + var setupFakeWeightFiles = function (fileBufferMap) { + spyOn(window, 'fetch').and.callFake(function (path) { + return new Response(fileBufferMap[path]); + }); + }; + it('1 group, 1 weight, 1 requested weight', function (done) { + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [{ 'name': 'weight0', 'dtype': 'float32', 'shape': [3] }] + }]; + var weightsNamesToFetch = ['weight0']; + tf.io.loadWeights(manifest, './', weightsNamesToFetch) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(weightsNamesToFetch.length); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2, 3]); + expect(weight0.shape).toEqual([3]); + expect(weight0.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, 2 weights, fetch 1st weight', function (done) { + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3, 4, 5]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }]; + tf.io.loadWeights(manifest, './', ['weight0']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(1); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, 2 weights, fetch 2nd weight', function (done) { + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3, 4, 5]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }]; + tf.io.loadWeights(manifest, './', ['weight1']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(1); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [3, 4, 5]); + expect(weight1.shape).toEqual([3]); + expect(weight1.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, 2 weights, fetch all weights', function (done) { + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3, 4, 5]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight1']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(2); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('float32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [3, 4, 5]); + expect(weight1.shape).toEqual([3]); + expect(weight1.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, multiple weights, different dtypes', function (done) { + var buffer = new ArrayBuffer(5 * 4 + 1); + var view = new DataView(buffer); + view.setInt32(0, 1, true); + view.setInt32(4, 2, true); + view.setUint8(8, 1); + view.setFloat32(9, 3., true); + view.setFloat32(13, 4., true); + view.setFloat32(17, 5., true); + setupFakeWeightFiles({ './weightfile0': buffer }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'int32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'bool', 'shape': [] }, + { 'name': 'weight2', 'dtype': 'float32', 'shape': [3] }, + ] + }]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight1', 'weight2']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(3); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('int32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [1]); + expect(weight1.shape).toEqual([]); + expect(weight1.dtype).toEqual('bool'); + var weight2 = weights['weight2']; + test_util_1.expectArraysClose(weight2, [3, 4, 5]); + expect(weight2.shape).toEqual([3]); + expect(weight2.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, sharded 1 weight across multiple files', function (done) { + var shard0 = new Float32Array([1, 2, 3, 4, 5]); + var shard1 = new Float32Array([1.1, 2.2]); + var shard2 = new Float32Array([10, 20, 30]); + setupFakeWeightFiles({ + './weightfile0': shard0, + './weightsfile1': shard1, + './weightsfile2': shard2 + }); + var manifest = [{ + 'paths': ['weightfile0', 'weightsfile1', 'weightsfile2'], + 'weights': [{ 'name': 'weight0', 'dtype': 'float32', 'shape': [5, 2] }] + }]; + tf.io.loadWeights(manifest, './', ['weight0']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(3); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(1); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2, 3, 4, 5, 1.1, 2.2, 10, 20, 30]); + expect(weight0.shape).toEqual([5, 2]); + expect(weight0.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('1 group, sharded 2 weights across multiple files', function (done) { + var shard0 = new Int32Array([1, 2, 3, 4, 5]); + var shard1 = new ArrayBuffer(5 * 4); + var intBuffer = new Int32Array(shard1, 0, 2); + intBuffer.set([10, 20]); + var floatBuffer = new Float32Array(shard1, intBuffer.byteLength, 3); + floatBuffer.set([3.0, 4.0, 5.0]); + var shard2 = new Float32Array([10, 20, 30]); + setupFakeWeightFiles({ + './weightfile0': shard0, + './weightsfile1': shard1, + './weightsfile2': shard2 + }); + var manifest = [{ + 'paths': ['weightfile0', 'weightsfile1', 'weightsfile2'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'int32', 'shape': [7, 1] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3, 2] } + ] + }]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight1']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(3); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(2); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2, 3, 4, 5, 10, 20]); + expect(weight0.shape).toEqual([7, 1]); + expect(weight0.dtype).toEqual('int32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [3.0, 4.0, 5.0, 10, 20, 30]); + expect(weight1.shape).toEqual([3, 2]); + expect(weight1.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('2 group, 4 weights, fetches one group', function (done) { + setupFakeWeightFiles({ + './weightfile0': new Float32Array([1, 2, 3, 4, 5]), + './weightfile1': new Float32Array([6, 7, 8, 9]) + }); + var manifest = [ + { + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }, + { + 'paths': ['weightfile1'], + 'weights': [ + { 'name': 'weight2', 'dtype': 'float32', 'shape': [3, 1] }, + { 'name': 'weight3', 'dtype': 'float32', 'shape': [] } + ] + } + ]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight1']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(2); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('float32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [3, 4, 5]); + expect(weight1.shape).toEqual([3]); + expect(weight1.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('2 group, 4 weights, one weight from each group', function (done) { + setupFakeWeightFiles({ + './weightfile0': new Float32Array([1, 2, 3, 4, 5]), + './weightfile1': new Float32Array([6, 7, 8, 9]) + }); + var manifest = [ + { + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }, + { + 'paths': ['weightfile1'], + 'weights': [ + { 'name': 'weight2', 'dtype': 'float32', 'shape': [3, 1] }, + { 'name': 'weight3', 'dtype': 'float32', 'shape': [] } + ] + } + ]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight2']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(2); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(2); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('float32'); + var weight2 = weights['weight2']; + test_util_1.expectArraysClose(weight2, [6, 7, 8]); + expect(weight2.shape).toEqual([3, 1]); + expect(weight2.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('2 group, 4 weights, dont specify weights fetchs all', function (done) { + setupFakeWeightFiles({ + './weightfile0': new Float32Array([1, 2, 3, 4, 5]), + './weightfile1': new Float32Array([6, 7, 8, 9]) + }); + var manifest = [ + { + 'paths': ['weightfile0'], + 'weights': [ + { 'name': 'weight0', 'dtype': 'float32', 'shape': [2] }, + { 'name': 'weight1', 'dtype': 'float32', 'shape': [3] } + ] + }, + { + 'paths': ['weightfile1'], + 'weights': [ + { 'name': 'weight2', 'dtype': 'float32', 'shape': [3, 1] }, + { 'name': 'weight3', 'dtype': 'float32', 'shape': [] } + ] + } + ]; + tf.io.loadWeights(manifest, './') + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(2); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(4); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [1, 2]); + expect(weight0.shape).toEqual([2]); + expect(weight0.dtype).toEqual('float32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysClose(weight1, [3, 4, 5]); + expect(weight1.shape).toEqual([3]); + expect(weight1.dtype).toEqual('float32'); + var weight2 = weights['weight2']; + test_util_1.expectArraysClose(weight2, [6, 7, 8]); + expect(weight2.shape).toEqual([3, 1]); + expect(weight2.dtype).toEqual('float32'); + var weight3 = weights['weight3']; + test_util_1.expectArraysClose(weight3, [9]); + expect(weight3.shape).toEqual([]); + expect(weight3.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); + it('throws if requested weight not found', function (done) { return __awaiter(_this, void 0, void 0, function () { + var manifest, weightsNamesToFetch, e_1; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3]) }); + manifest = [{ + 'paths': ['weightfile0'], + 'weights': [{ 'name': 'weight0', 'dtype': 'float32', 'shape': [3] }] + }]; + weightsNamesToFetch = ['doesntexist']; + _a.label = 1; + case 1: + _a.trys.push([1, 3, , 4]); + return [4, tf.io.loadWeights(manifest, './', weightsNamesToFetch)]; + case 2: + _a.sent(); + done.fail(); + return [3, 4]; + case 3: + e_1 = _a.sent(); + done(); + return [3, 4]; + case 4: return [2]; + } + }); + }); }); + it('throws if requested weight has unknown dtype', function (done) { return __awaiter(_this, void 0, void 0, function () { + var manifest, weightsNamesToFetch, e_2; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3]) }); + manifest = [{ + 'paths': ['weightfile0'], + 'weights': [{ + 'name': 'weight0', + 'dtype': 'null', + 'shape': [3] + }] + }]; + weightsNamesToFetch = ['weight0']; + _a.label = 1; + case 1: + _a.trys.push([1, 3, , 4]); + return [4, tf.io.loadWeights(manifest, './', weightsNamesToFetch)]; + case 2: + _a.sent(); + done.fail(); + return [3, 4]; + case 3: + e_2 = _a.sent(); + done(); + return [3, 4]; + case 4: return [2]; + } + }); + }); }); + it('should use request option', function (done) { + setupFakeWeightFiles({ './weightfile0': new Float32Array([1, 2, 3]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [{ 'name': 'weight0', 'dtype': 'float32', 'shape': [3] }] + }]; + var weightsNamesToFetch = ['weight0']; + tf.io + .loadWeights(manifest, './', weightsNamesToFetch, { credentials: 'include' }) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + expect(window.fetch).toHaveBeenCalledWith('./weightfile0', { + credentials: 'include' + }); + }) + .then(done) + .catch(done.fail); + }); + var quantizationTest = function (quantizationDtype, done) { + var arrayType = quantizationDtype === 'uint8' ? Uint8Array : Uint16Array; + setupFakeWeightFiles({ './weightfile0': new arrayType([0, 48, 255, 0, 48, 255]) }); + var manifest = [{ + 'paths': ['weightfile0'], + 'weights': [ + { + 'name': 'weight0', + 'dtype': 'float32', + 'shape': [3], + 'quantization': { 'min': -1, 'scale': 0.1, 'dtype': quantizationDtype } + }, + { + 'name': 'weight1', + 'dtype': 'int32', + 'shape': [3], + 'quantization': { 'min': -1, 'scale': 0.1, 'dtype': quantizationDtype } + } + ] + }]; + var weightsNamesToFetch = ['weight0', 'weight1']; + tf.io.loadWeights(manifest, './', weightsNamesToFetch) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(1); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(weightsNamesToFetch.length); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [-1, 3.8, 24.5]); + expect(weight0.shape).toEqual([3]); + expect(weight0.dtype).toEqual('float32'); + var weight1 = weights['weight1']; + test_util_1.expectArraysEqual(weight1, [-1, 4, 25]); + expect(weight1.shape).toEqual([3]); + expect(weight1.dtype).toEqual('int32'); + }) + .then(done) + .catch(done.fail); + }; + it('quantized weights (uint8)', function (done) { + quantizationTest('uint8', done); + }); + it('quantized weights (uint16)', function (done) { + quantizationTest('uint16', done); + }); + it('2 groups, 1 quantized, 1 unquantized', function (done) { + setupFakeWeightFiles({ + './weightfile0': new Uint8Array([0, 48, 255, 0, 48, 255]), + './weightfile1': new Float32Array([6, 7, 8, 9]) + }); + var manifest = [ + { + 'paths': ['weightfile0'], + 'weights': [ + { + 'name': 'weight0', + 'dtype': 'float32', + 'shape': [3], + 'quantization': { 'min': -1, 'scale': 0.1, 'dtype': 'uint8' } + }, + { + 'name': 'weight1', + 'dtype': 'int32', + 'shape': [3], + 'quantization': { 'min': -1, 'scale': 0.1, 'dtype': 'uint8' } + } + ] + }, + { + 'paths': ['weightfile1'], + 'weights': [ + { 'name': 'weight2', 'dtype': 'float32', 'shape': [3, 1] }, + { 'name': 'weight3', 'dtype': 'float32', 'shape': [] } + ] + } + ]; + tf.io.loadWeights(manifest, './', ['weight0', 'weight2']) + .then(function (weights) { + expect(window.fetch.calls.count()).toBe(2); + var weightNames = Object.keys(weights); + expect(weightNames.length).toEqual(2); + var weight0 = weights['weight0']; + test_util_1.expectArraysClose(weight0, [-1, 3.8, 24.5]); + expect(weight0.shape).toEqual([3]); + expect(weight0.dtype).toEqual('float32'); + var weight2 = weights['weight2']; + test_util_1.expectArraysClose(weight2, [6, 7, 8]); + expect(weight2.shape).toEqual([3, 1]); + expect(weight2.dtype).toEqual('float32'); + }) + .then(done) + .catch(done.fail); + }); +}); +//# sourceMappingURL=weights_loader_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js.map new file mode 100644 index 0000000..4487850 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/io/weights_loader_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"weights_loader_test.js","sourceRoot":"","sources":["../../src/io/weights_loader_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.d.ts new file mode 100644 index 0000000..ecb6501 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.d.ts @@ -0,0 +1,14 @@ +import { Features } from './environment_util'; +import { KernelBackend } from './kernels/backend'; +import { MathBackendCPU } from './kernels/backend_cpu'; +export declare function envSatisfiesConstraints(constraints: Features): boolean; +export declare function parseKarmaFlags(args: string[]): TestEnv; +export declare function describeWithFlags(name: string, constraints: Features, tests: () => void): void; +export interface TestEnv { + name: string; + factory: () => KernelBackend; + features: Features; +} +export declare let TEST_ENVS: TestEnv[]; +export declare const CPU_FACTORY: () => MathBackendCPU; +export declare function setTestEnvs(testEnvs: TestEnv[]): void; diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js new file mode 100644 index 0000000..1642252 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js @@ -0,0 +1,112 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +var backend_cpu_1 = require("./kernels/backend_cpu"); +var backend_webgl_1 = require("./kernels/backend_webgl"); +Error.stackTraceLimit = Infinity; +function envSatisfiesConstraints(constraints) { + for (var key in constraints) { + var value = constraints[key]; + if (environment_1.ENV.get(key) !== value) { + return false; + } + } + return true; +} +exports.envSatisfiesConstraints = envSatisfiesConstraints; +function parseKarmaFlags(args) { + var features; + var backend; + var name = ''; + args.forEach(function (arg, i) { + if (arg === '--features') { + features = JSON.parse(args[i + 1]); + } + else if (arg === '--backend') { + var type = args[i + 1]; + name = type; + if (type.toLowerCase() === 'cpu') { + backend = function () { return new backend_cpu_1.MathBackendCPU(); }; + } + else if (type.toLowerCase() === 'webgl') { + backend = function () { return new backend_webgl_1.MathBackendWebGL(); }; + } + else { + throw new Error("Unknown value " + type + " for flag --backend. " + + "Allowed values are 'cpu' or 'webgl'."); + } + } + }); + if (features == null && backend == null) { + return null; + } + if (features != null && backend == null) { + throw new Error('--backend flag is required when --features is present. ' + + 'Available values are "webgl" or "cpu".'); + } + return { features: features || {}, factory: backend, name: name }; +} +exports.parseKarmaFlags = parseKarmaFlags; +function describeWithFlags(name, constraints, tests) { + exports.TEST_ENVS.forEach(function (testEnv) { + environment_1.ENV.setFeatures(testEnv.features); + if (envSatisfiesConstraints(constraints)) { + var testName = name + ' ' + testEnv.name + ' ' + JSON.stringify(testEnv.features); + executeTests(testName, tests, testEnv); + } + }); +} +exports.describeWithFlags = describeWithFlags; +exports.TEST_ENVS = [ + { + name: 'test-webgl1', + factory: function () { return new backend_webgl_1.MathBackendWebGL(); }, + features: { 'WEBGL_VERSION': 1 } + }, + { + name: 'test-webgl2', + factory: function () { return new backend_webgl_1.MathBackendWebGL(); }, + features: { 'WEBGL_VERSION': 2 } + }, + { + name: 'test-cpu', + factory: function () { return new backend_cpu_1.MathBackendCPU(); }, + features: { 'HAS_WEBGL': false } + } +]; +exports.CPU_FACTORY = function () { return new backend_cpu_1.MathBackendCPU(); }; +if (typeof __karma__ !== 'undefined') { + var testEnv = parseKarmaFlags(__karma__.config.args); + if (testEnv) { + setTestEnvs([testEnv]); + } +} +function setTestEnvs(testEnvs) { + exports.TEST_ENVS = testEnvs; +} +exports.setTestEnvs = setTestEnvs; +function executeTests(testName, tests, testEnv) { + describe(testName, function () { + var backendName = 'test-' + testEnv.name; + beforeAll(function () { + environment_1.ENV.reset(); + environment_1.ENV.setFeatures(testEnv.features); + environment_1.ENV.set('IS_TEST', true); + environment_1.ENV.registerBackend(backendName, testEnv.factory, 1000); + environment_1.Environment.setBackend(backendName); + }); + beforeEach(function () { + environment_1.ENV.engine.startScope(); + }); + afterEach(function () { + environment_1.ENV.engine.endScope(); + environment_1.Environment.disposeVariables(); + }); + afterAll(function () { + environment_1.ENV.removeBackend(backendName); + environment_1.ENV.reset(); + }); + tests(); + }); +} +//# sourceMappingURL=jasmine_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js.map new file mode 100644 index 0000000..83f7141 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"jasmine_util.js","sourceRoot":"","sources":["../src/jasmine_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js new file mode 100644 index 0000000..1fe5341 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js @@ -0,0 +1,61 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var backend_cpu_1 = require("./kernels/backend_cpu"); +var backend_webgl_1 = require("./kernels/backend_webgl"); +var test_util_1 = require("./test_util"); +describe('jasmine_util.envSatisfiesConstraints', function () { + it('ENV satisfies empty constraints', function () { + expect(jasmine_util_1.envSatisfiesConstraints({})).toBe(true); + }); + it('ENV satisfies matching constraints', function () { + var c = { TEST_EPSILON: tf.ENV.get('TEST_EPSILON') }; + expect(jasmine_util_1.envSatisfiesConstraints(c)).toBe(true); + }); + it('ENV does not satisfy mismatching constraints', function () { + var c = { TEST_EPSILON: tf.ENV.get('TEST_EPSILON') + 0.1 }; + expect(jasmine_util_1.envSatisfiesConstraints(c)).toBe(false); + }); +}); +describe('jasmine_util.parseKarmaFlags', function () { + it('parse empty args', function () { + var res = jasmine_util_1.parseKarmaFlags([]); + expect(res).toBeNull(); + }); + it('--backend cpu', function () { + var res = jasmine_util_1.parseKarmaFlags(['--backend', 'cpu']); + expect(res.name).toBe('cpu'); + expect(res.features).toEqual({}); + expect(res.factory() instanceof backend_cpu_1.MathBackendCPU).toBe(true); + }); + it('--backend cpu --features {"IS_NODE": true}', function () { + var res = jasmine_util_1.parseKarmaFlags(['--backend', 'cpu', '--features', '{"IS_NODE": true}']); + expect(res.name).toBe('cpu'); + expect(res.features).toEqual({ IS_NODE: true }); + expect(res.factory() instanceof backend_cpu_1.MathBackendCPU).toBe(true); + }); + it('"--backend unknown" throws error', function () { + expect(function () { return jasmine_util_1.parseKarmaFlags(['--backend', 'unknown']); }).toThrowError(); + }); + it('"--features {}" throws error since --backend is missing', function () { + expect(function () { return jasmine_util_1.parseKarmaFlags(['--features', '{}']); }).toThrowError(); + }); + it('"--backend cpu --features" throws error since features value is missing', function () { + expect(function () { return jasmine_util_1.parseKarmaFlags(['--backend', 'cpu', '--features']); }) + .toThrowError(); + }); + it('"--backend cpu --features notJson" throws error', function () { + expect(function () { return jasmine_util_1.parseKarmaFlags(['--backend', 'cpu', '--features', 'notJson']); }) + .toThrowError(); + }); +}); +jasmine_util_1.describeWithFlags('jasmine_util.envSatisfiesConstraints', test_util_1.WEBGL_ENVS, function () { + it('--backend webgl', function () { + var res = jasmine_util_1.parseKarmaFlags(['--backend', 'webgl']); + expect(res.name).toBe('webgl'); + expect(res.features).toEqual({}); + expect(res.factory() instanceof backend_webgl_1.MathBackendWebGL).toBe(true); + }); +}); +//# sourceMappingURL=jasmine_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js.map new file mode 100644 index 0000000..97e2e82 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/jasmine_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"jasmine_util_test.js","sourceRoot":"","sources":["../src/jasmine_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.d.ts new file mode 100644 index 0000000..86bd06e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.d.ts @@ -0,0 +1,125 @@ +import { Conv2DInfo } from '../ops/conv_util'; +import { DataId, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { DataType, Rank, ShapeMap, TypedArray } from '../types'; +export interface BackendTimingInfo { + kernelMs: number; +} +export interface TensorStorage { + read(dataId: DataId): Promise; + readSync(dataId: DataId): TypedArray; + disposeData(dataId: DataId): void; + write(dataId: DataId, values: TypedArray): void; + fromPixels(pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, numChannels: number): Tensor3D; + register(dataId: DataId, shape: number[], dtype: DataType): void; + memory(): { + unreliable: boolean; + }; +} +export interface BackendTimer { + time(f: () => void): Promise; +} +export interface KernelBackend extends TensorStorage, BackendTimer { + matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean): Tensor2D; + slice(x: T, begin: number[], size: number[]): T; + stridedSlice(x: T, begin: number[], end: number[], strides: number[], beginMask: number, endMask: number): T; + reverse(a: T, axis: number[]): T; + concat(a: Tensor2D, b: Tensor2D): Tensor2D; + neg(a: T): T; + add(a: Tensor, b: Tensor): Tensor; + addN(tensors: T[]): T; + subtract(a: Tensor, b: Tensor): Tensor; + multiply(a: Tensor, b: Tensor): Tensor; + realDivide(a: Tensor, b: Tensor): Tensor; + floorDiv(a: Tensor, b: Tensor): Tensor; + sum(x: Tensor, axes: number[]): Tensor; + unsortedSegmentSum(x: T, segmentIds: Tensor1D, numSegments: number): Tensor; + argMin(x: Tensor, axis: number): Tensor; + argMax(x: Tensor, axis: number): Tensor; + equal(a: Tensor, b: Tensor): Tensor; + notEqual(a: Tensor, b: Tensor): Tensor; + less(a: Tensor, b: Tensor): Tensor; + lessEqual(a: Tensor, b: Tensor): Tensor; + greater(a: Tensor, b: Tensor): Tensor; + greaterEqual(a: Tensor, b: Tensor): Tensor; + logicalNot(a: T): T; + logicalAnd(a: Tensor, b: Tensor): Tensor; + logicalOr(a: Tensor, b: Tensor): Tensor; + where(condition: Tensor): Tensor2D; + select(condition: Tensor, a: Tensor, b: Tensor): Tensor; + topk(x: T, k: number, sorted: boolean): [T, T]; + min(x: Tensor, axes: number[]): Tensor; + minimum(a: Tensor, b: Tensor): Tensor; + mod(a: Tensor, b: Tensor): Tensor; + max(x: Tensor, axes: number[]): Tensor; + maximum(a: Tensor, b: Tensor): Tensor; + all(x: Tensor, axes: number[]): Tensor; + any(x: Tensor, axes: number[]): Tensor; + squaredDifference(a: Tensor, b: Tensor): Tensor; + ceil(x: T): T; + floor(x: T): T; + round(x: T): T; + sign(x: T): T; + pow(a: T, b: Tensor): T; + exp(x: T): T; + expm1(x: T): T; + log(x: T): T; + log1p(x: T): T; + sqrt(x: T): T; + rsqrt(x: T): T; + square(x: T): T; + reciprocal(x: T): T; + relu(x: T): T; + elu(x: T): T; + eluDer(dy: T, y: T): T; + selu(x: T): T; + int(x: T): T; + clip(x: T, min: number, max: number): T; + abs(x: T): T; + sigmoid(x: T): T; + softplus(x: T): T; + sin(x: T): T; + cos(x: T): T; + tan(x: T): T; + asin(x: T): T; + acos(x: T): T; + atan(x: T): T; + atan2(a: T, b: T): T; + sinh(x: T): T; + cosh(x: T): T; + tanh(x: T): T; + asinh(x: T): T; + acosh(x: T): T; + atanh(x: T): T; + erf(x: T): T; + step(x: T, alpha: number): T; + conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerFilter(x: Tensor4D, dY: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2D(input: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerFilter(x: Tensor4D, dY: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + reshape(x: T, shape: ShapeMap[R]): Tensor; + cast(x: T, dtype: DataType): T; + tile(x: T, reps: number[]): T; + pad(x: T, paddings: Array<[number, number]>, constantValue: number): T; + transpose(x: T, perm: number[]): T; + gather(x: T, indices: Tensor1D, axis: number): T; + batchToSpaceND(x: T, blockShape: number[], crops: number[][]): T; + spaceToBatchND(x: T, blockShape: number[], paddings: number[][]): T; + resizeBilinear(x: Tensor4D, newHeight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D; + resizeNearestNeighbor(x: Tensor4D, newHEight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeNearestNeighborBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D; + batchNormalization(x: Tensor4D, mean: Tensor4D | Tensor1D, variance: Tensor4D | Tensor1D, varianceEpsilon: number, scale?: Tensor4D | Tensor1D, offset?: Tensor4D | Tensor1D): Tensor4D; + localResponseNormalization4D(x: Tensor4D, radius: number, bias: number, alpha: number, beta: number): Tensor4D; + LRNGrad(dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D, radius: number, bias: number, alpha: number, beta: number): Tensor4D; + multinomial(logits: Tensor2D, normalized: boolean, numSamples: number, seed: number): Tensor2D; + oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number): Tensor2D; + cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean): Tensor; + nonMaxSuppression(boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number, iouThreshold: number, scoreThreshold?: number): Tensor1D; + dispose(): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js new file mode 100644 index 0000000..702447e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=backend.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js.map new file mode 100644 index 0000000..317978d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend.js.map @@ -0,0 +1 @@ +{"version":3,"file":"backend.js","sourceRoot":"","sources":["../../src/kernels/backend.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.d.ts new file mode 100644 index 0000000..be55eec --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.d.ts @@ -0,0 +1,127 @@ +import { Conv2DInfo } from '../ops/conv_util'; +import { DataId, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { DataType, Rank, ShapeMap, TypedArray } from '../types'; +import { BackendTimingInfo, KernelBackend } from './backend'; +export declare class MathBackendCPU implements KernelBackend { + private data; + private canvas; + private firstUse; + constructor(); + register(dataId: DataId, shape: number[], dtype: DataType): void; + write(dataId: DataId, values: TypedArray): void; + fromPixels(pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, numChannels: number): Tensor3D; + read(dataId: DataId): Promise; + readSync(dataId: DataId): TypedArray; + disposeData(dataId: DataId): void; + time(f: () => void): Promise; + memory(): { + unreliable: boolean; + }; + private throwIfNoData; + slice(x: T, begin: number[], size: number[]): T; + stridedSlice(x: T, begin: number[], end: number[], strides: number[], beginMask: number, endMask: number): T; + reverse(x: T, axis: number[]): T; + concat(a: Tensor2D, b: Tensor2D): Tensor2D; + neg(x: T): T; + add(a: Tensor, b: Tensor): Tensor; + addN(tensors: T[]): T; + subtract(a: Tensor, b: Tensor): Tensor; + pow(a: T, b: Tensor): T; + matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean): Tensor2D; + multiply(a: Tensor, b: Tensor): Tensor; + realDivide(a: Tensor, b: Tensor): Tensor; + floorDiv(a: Tensor, b: Tensor): Tensor; + sum(x: Tensor, axes: number[]): Tensor; + unsortedSegmentSum(x: T, segmentIds: Tensor1D, numSegments: number): Tensor; + argMin(x: Tensor, axis: number): Tensor; + argMax(x: Tensor, axis: number): Tensor; + cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean): Tensor; + equal(a: Tensor, b: Tensor): Tensor; + notEqual(a: Tensor, b: Tensor): Tensor; + less(a: Tensor, b: Tensor): Tensor; + lessEqual(a: Tensor, b: Tensor): Tensor; + greater(a: Tensor, b: Tensor): Tensor; + greaterEqual(a: Tensor, b: Tensor): Tensor; + logicalNot(x: T): T; + logicalAnd(a: Tensor, b: Tensor): Tensor; + logicalOr(a: Tensor, b: Tensor): Tensor; + select(condition: Tensor, a: Tensor, b: Tensor): Tensor; + where(condition: Tensor): Tensor2D; + topk(x: T, k: number, sorted: boolean): [T, T]; + min(x: Tensor, axes: number[]): Tensor; + minimum(a: Tensor, b: Tensor): Tensor; + mod(a: Tensor, b: Tensor): Tensor; + max(x: Tensor, axes: number[]): Tensor; + maximum(a: Tensor, b: Tensor): Tensor; + all(x: Tensor, axes: number[]): Tensor; + any(x: Tensor, axes: number[]): Tensor; + squaredDifference(a: Tensor, b: Tensor): Tensor; + ceil(x: T): T; + floor(x: T): T; + sign(x: T): T; + round(x: T): T; + exp(x: T): T; + expm1(x: T): T; + log(x: T): T; + log1p(x: T): T; + sqrt(x: T): T; + rsqrt(x: T): T; + square(x: T): T; + reciprocal(x: T): T; + relu(x: T): T; + elu(x: T): T; + eluDer(dy: T, y: T): T; + selu(x: T): T; + clip(x: T, min: number, max: number): T; + abs(x: T): T; + int(x: T): T; + sigmoid(x: T): T; + softplus(x: T): T; + sin(x: T): T; + cos(x: T): T; + tan(x: T): T; + asin(x: T): T; + acos(x: T): T; + atan(x: T): T; + atan2(a: T, b: T): T; + sinh(x: T): T; + cosh(x: T): T; + tanh(x: T): T; + asinh(x: T): T; + acosh(x: T): T; + atanh(x: T): T; + erf(x: T): T; + step(x: T, alpha?: number): T; + conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + tile(x: T, reps: number[]): T; + pad(x: T, paddings: Array<[number, number]>, constantValue: number): T; + transpose(x: T, perm: number[]): T; + gather(x: T, indices: Tensor1D, axis: number): T; + batchToSpaceND(x: T, blockShape: number[], crops: number[][]): T; + spaceToBatchND(x: T, blockShape: number[], paddings: Array<[number, number]>): T; + private pool; + maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + private maxPoolPositions; + maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + cast(x: T, dtype: DataType): T; + reshape(x: Tensor, shape: ShapeMap[R]): Tensor; + avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + resizeBilinear(x: Tensor4D, newHeight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor; + resizeNearestNeighbor(x: Tensor4D, newHeight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeNearestNeighborBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor; + batchNormalization(x: Tensor4D, mean: Tensor4D | Tensor1D, variance: Tensor4D | Tensor1D, varianceEpsilon: number, scale?: Tensor4D | Tensor1D, offset?: Tensor4D | Tensor1D): Tensor4D; + localResponseNormalization4D(x: Tensor4D, radius: number, bias: number, alpha: number, beta: number): Tensor4D; + LRNGrad(dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D, depthRadius: number, bias: number, alpha: number, beta: number): Tensor4D; + multinomial(logits: Tensor2D, normalized: boolean, numSamples: number, seed: number): Tensor2D; + oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number): Tensor2D; + nonMaxSuppression(boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number, iouThreshold: number, scoreThreshold: number): Tensor1D; + private broadcastedBinaryOp; + dispose(): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js new file mode 100644 index 0000000..13577c4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js @@ -0,0 +1,1776 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var seedrandom = require("seedrandom"); +var environment_1 = require("../environment"); +var log_1 = require("../log"); +var array_ops_util = require("../ops/array_ops_util"); +var axis_util = require("../ops/axis_util"); +var broadcast_util = require("../ops/broadcast_util"); +var concat_util = require("../ops/concat_util"); +var erf_util = require("../ops/erf_util"); +var ops = require("../ops/ops"); +var ops_1 = require("../ops/ops"); +var selu_util = require("../ops/selu_util"); +var slice_util_1 = require("../ops/slice_util"); +var tensor_1 = require("../tensor"); +var types_1 = require("../types"); +var util = require("../util"); +var util_1 = require("../util"); +var backend_util = require("./backend_util"); +var non_max_suppression_impl_1 = require("./non_max_suppression_impl"); +var topk_impl_1 = require("./topk_impl"); +var where_impl_1 = require("./where_impl"); +var MathBackendCPU = (function () { + function MathBackendCPU() { + this.data = new WeakMap(); + this.firstUse = true; + if (environment_1.ENV.get('IS_BROWSER')) { + this.canvas = document.createElement('canvas'); + } + } + MathBackendCPU.prototype.register = function (dataId, shape, dtype) { + if (this.firstUse) { + this.firstUse = false; + if (environment_1.ENV.get('IS_NODE')) { + log_1.warn('\n============================\n' + + 'Hi there 👋. Looks like you are running TensorFlow.js in ' + + 'Node.js. To speed things up dramatically, install our node ' + + 'backend, which binds to TensorFlow C++, by running ' + + 'npm i @tensorflow/tfjs-node, ' + + 'or npm i @tensorflow/tfjs-node-gpu if you have CUDA. ' + + 'Then call require(\'@tensorflow/tfjs-node\'); (-gpu ' + + 'suffix for CUDA) at the start of your program. ' + + 'Visit https://github.com/tensorflow/tfjs-node for more details.' + + '\n============================\n'); + } + } + if (this.data.has(dataId)) { + throw new Error("Data buffer is already registered"); + } + this.data.set(dataId, null); + }; + MathBackendCPU.prototype.write = function (dataId, values) { + if (values == null) { + throw new Error('MathBackendCPU.write(): values can not be null'); + } + this.throwIfNoData(dataId); + this.data.set(dataId, values); + }; + MathBackendCPU.prototype.fromPixels = function (pixels, numChannels) { + if (pixels == null) { + throw new Error('pixels passed to tf.fromPixels() can not be null'); + } + var vals; + if (environment_1.ENV.get('IS_NODE') && pixels.getContext == null) { + throw new Error('When running in node, pixels must be an HTMLCanvasElement ' + + 'like the one returned by the `canvas` npm package'); + } + if (pixels.getContext != null) { + vals = pixels + .getContext('2d') + .getImageData(0, 0, pixels.width, pixels.height) + .data; + } + else if (pixels instanceof ImageData) { + vals = pixels.data; + } + else if (pixels instanceof HTMLImageElement || + pixels instanceof HTMLVideoElement) { + if (this.canvas == null) { + throw new Error('Can\'t read pixels from HTMLImageElement outside ' + + 'the browser.'); + } + this.canvas.width = pixels.width; + this.canvas.height = pixels.height; + this.canvas.getContext('2d').drawImage(pixels, 0, 0, pixels.width, pixels.height); + vals = this.canvas.getContext('2d') + .getImageData(0, 0, pixels.width, pixels.height) + .data; + } + else { + throw new Error('pixels passed to tf.fromPixels() must be either an ' + + "HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or " + + ("ImageData, but was " + pixels.constructor.name)); + } + var values; + if (numChannels === 4) { + values = new Int32Array(vals); + } + else { + var numPixels = pixels.width * pixels.height; + values = new Int32Array(numPixels * numChannels); + for (var i = 0; i < numPixels; i++) { + for (var channel = 0; channel < numChannels; ++channel) { + values[i * numChannels + channel] = vals[i * 4 + channel]; + } + } + } + var outShape = [pixels.height, pixels.width, numChannels]; + return ops_1.tensor3d(values, outShape, 'int32'); + }; + MathBackendCPU.prototype.read = function (dataId) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.readSync(dataId)]; + }); + }); + }; + MathBackendCPU.prototype.readSync = function (dataId) { + this.throwIfNoData(dataId); + return this.data.get(dataId); + }; + MathBackendCPU.prototype.disposeData = function (dataId) { + if (this.data.has(dataId)) { + this.data.delete(dataId); + } + }; + MathBackendCPU.prototype.time = function (f) { + return __awaiter(this, void 0, void 0, function () { + var start, kernelMs; + return __generator(this, function (_a) { + start = util_1.now(); + f(); + kernelMs = util_1.now() - start; + return [2, { kernelMs: kernelMs }]; + }); + }); + }; + MathBackendCPU.prototype.memory = function () { + return { + unreliable: true + }; + }; + MathBackendCPU.prototype.throwIfNoData = function (dataId) { + if (!this.data.has(dataId)) { + throw new Error("CPU backend: No data found for this tensor. " + + "Did you change your backend in the middle of the program? " + + "New backends can't use Tensors created with previous backends"); + } + }; + MathBackendCPU.prototype.slice = function (x, begin, size) { + var buffer = ops.buffer(size, x.dtype); + for (var i = 0; i < buffer.size; ++i) { + var loc = buffer.indexToLoc(i); + var xLoc = loc.map(function (idx, j) { return idx + begin[j]; }); + buffer.set.apply(buffer, [x.get.apply(x, xLoc)].concat(loc)); + } + return buffer.toTensor(); + }; + MathBackendCPU.prototype.stridedSlice = function (x, begin, end, strides, beginMask, endMask) { + var _a = slice_util_1.getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask), beginIndex = _a[0], size = _a[1]; + if (size.some(function (axis) { return axis === 0; })) { + return ops.tensor([], size); + } + var buffer = ops.buffer(size, x.dtype); + for (var i = 0; i < buffer.size; i++) { + var loc = buffer.indexToLoc(i); + var newLoc = new Array(loc.length); + for (var j = 0; j < newLoc.length; j++) { + newLoc[j] = loc[j] * strides[j] + beginIndex[j]; + } + buffer.set.apply(buffer, [x.get.apply(x, newLoc)].concat(loc)); + } + return buffer.toTensor(); + }; + MathBackendCPU.prototype.reverse = function (x, axis) { + var buffer = ops.buffer(x.shape, x.dtype); + var xBuffer = x.buffer(); + var _loop_1 = function (i) { + var outLoc = buffer.indexToLoc(i); + var inLoc = outLoc.slice(); + axis.forEach(function (ax) { return inLoc[ax] = x.shape[ax] - 1 - inLoc[ax]; }); + buffer.set.apply(buffer, [xBuffer.get.apply(xBuffer, inLoc)].concat(outLoc)); + }; + for (var i = 0; i < buffer.size; i++) { + _loop_1(i); + } + return buffer.toTensor(); + }; + MathBackendCPU.prototype.concat = function (a, b) { + var outShape = concat_util.computeOutShape(a.shape, b.shape, 1); + var buffer = ops.buffer(outShape, a.dtype); + if (a.shape[0] === 1 && b.shape[0] === 1) { + var aVals = a.dataSync(); + var bVals = b.dataSync(); + var vals = buffer.values; + vals.set(aVals, 0); + vals.set(bVals, a.size); + return buffer.toTensor(); + } + for (var i = 0; i < outShape[0]; ++i) { + for (var j = 0; j < a.shape[1]; ++j) { + buffer.set(a.get(i, j), i, j); + } + for (var j = 0; j < b.shape[1]; ++j) { + buffer.set(b.get(i, j), i, j + a.shape[1]); + } + } + return buffer.toTensor(); + }; + MathBackendCPU.prototype.neg = function (x) { + return this.multiply(ops.scalar(-1), x); + }; + MathBackendCPU.prototype.add = function (a, b) { + return this.broadcastedBinaryOp(a, b, types_1.upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue + bValue; }); + }; + MathBackendCPU.prototype.addN = function (tensors) { + var vals = tensors.map(function (t) { return t.dataSync(); }); + var result = ops.buffer(tensors[0].shape, tensors[0].dtype); + var resultVals = result.values; + for (var i = 0; i < tensors.length; i++) { + var currVals = vals[i]; + for (var j = 0; j < resultVals.length; j++) { + resultVals[j] += currVals[j]; + } + } + return result.toTensor(); + }; + MathBackendCPU.prototype.subtract = function (a, b) { + return this.broadcastedBinaryOp(a, b, types_1.upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue - bValue; }); + }; + MathBackendCPU.prototype.pow = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aValue, bValue) { return Math.pow(aValue, bValue); }); + }; + MathBackendCPU.prototype.matMul = function (a, b, transposeA, transposeB) { + var sharedDim = transposeA ? a.shape[0] : a.shape[1]; + var leftDim = transposeA ? a.shape[1] : a.shape[0]; + var rightDim = transposeB ? b.shape[0] : b.shape[1]; + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var _a = transposeA ? [1, a.strides[0]] : [a.strides[0], 1], aOuterStep = _a[0], aInnerStep = _a[1]; + var _b = transposeB ? [b.strides[0], 1] : [1, b.strides[0]], bOuterStep = _b[0], bInnerStep = _b[1]; + var aOuterEnd = leftDim * aOuterStep; + var bOuterEnd = rightDim * bOuterStep; + var result = new Float32Array(leftDim * rightDim); + var resultIndex = 0; + for (var aOuter = 0; aOuter < aOuterEnd; aOuter += aOuterStep) { + for (var bOuter = 0; bOuter < bOuterEnd; bOuter += bOuterStep) { + var aInner = aOuter; + var bInner = bOuter; + var sum = 0; + for (var k = 0; k < sharedDim; ++k) { + sum += aValues[aInner] * bValues[bInner]; + aInner += aInnerStep; + bInner += bInnerStep; + } + result[resultIndex++] = sum; + } + } + return ops.tensor2d(result, [leftDim, rightDim]); + }; + MathBackendCPU.prototype.multiply = function (a, b) { + return this.broadcastedBinaryOp(a, b, types_1.upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue * bValue; }); + }; + MathBackendCPU.prototype.realDivide = function (a, b) { + var op = function (a, b) { return a / b; }; + var outputDtype = 'float32'; + return this.broadcastedBinaryOp(a, b, outputDtype, op); + }; + MathBackendCPU.prototype.floorDiv = function (a, b) { + var op = function (a, b) { return Math.floor(a / b); }; + var outputDtype = 'int32'; + return this.broadcastedBinaryOp(a, b, outputDtype, op); + }; + MathBackendCPU.prototype.sum = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var resultDtype = types_1.upcastType(x.dtype, 'int32'); + var result = ops.zeros(outShape, resultDtype); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var sum = 0; + for (var j = 0; j < reduceSize; ++j) { + sum += aVals[offset + j]; + } + vals[i] = sum; + } + return result; + }; + MathBackendCPU.prototype.unsortedSegmentSum = function (x, segmentIds, numSegments) { + var res = []; + var numIters = x.rank - segmentIds.rank; + for (var i = 0; i < numIters; ++i) { + segmentIds = segmentIds.expandDims(i + 1); + } + for (var i = 0; i < numSegments; ++i) { + var segmentId = ops.scalar(i, 'int32'); + var mask = ops.equal(segmentId, segmentIds).asType('float32'); + var sum = mask.mul(x).sum(0); + res.push(sum); + } + return ops.stack(res); + }; + MathBackendCPU.prototype.argMin = function (x, axis) { + var axes = [axis]; + axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, 'int32'); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var min = aVals[offset]; + var minIndex = 0; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value < min) { + min = value; + minIndex = j; + } + } + vals[i] = minIndex; + } + return result; + }; + MathBackendCPU.prototype.argMax = function (x, axis) { + var axes = [axis]; + axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, 'int32'); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var max = aVals[offset]; + var maxIndex = 0; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value > max) { + max = value; + maxIndex = j; + } + } + vals[i] = maxIndex; + } + return result; + }; + MathBackendCPU.prototype.cumsum = function (x, axis, exclusive, reverse) { + if (axis !== x.rank - 1) { + throw new Error("backend.cumsum in CPU expects an inner-most axis=" + (x.rank - 1) + " " + + ("but got axis=" + axis)); + } + var resultDtype = types_1.upcastType(x.dtype, 'int32'); + var result = ops.zeros(x.shape, resultDtype); + var vals = result.dataSync(); + var aVals = x.dataSync(); + var finalDim = x.shape[x.rank - 1]; + var indexAdjuster = reverse ? + function (i, j) { return i + finalDim - j - 1; } : + function (i, j) { return i + j; }; + for (var i = 0; i < aVals.length; i += finalDim) { + for (var j = 0; j < finalDim; j++) { + var idx = indexAdjuster(i, j); + if (j === 0) { + vals[idx] = exclusive ? 0 : aVals[idx]; + } + else { + var prevIdx = indexAdjuster(i, j - 1); + vals[idx] = exclusive ? aVals[prevIdx] + vals[prevIdx] : + aVals[idx] + vals[prevIdx]; + } + } + } + return result; + }; + MathBackendCPU.prototype.equal = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal === bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.notEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal !== bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.less = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal < bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.lessEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal <= bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.greater = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal > bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.greaterEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal >= bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.logicalNot = function (x) { + var values = x.dataSync(); + var newValues = new Int32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = values[i] ? 0 : 1; + } + return tensor_1.Tensor.make(x.shape, { values: newValues }, 'bool'); + }; + MathBackendCPU.prototype.logicalAnd = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return aVal && bVal; + }); + }; + MathBackendCPU.prototype.logicalOr = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return aVal || bVal; + }); + }; + MathBackendCPU.prototype.select = function (condition, a, b) { + var values = condition.dataSync(); + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var result = ops.zeros(a.shape, types_1.upcastType(a.dtype, b.dtype)); + var newValues = result.dataSync(); + var index = 0; + var offset = condition.rank === 0 || condition.rank > 1 || a.rank === 1 ? + 1 : + a.shape[1]; + for (var i = 0; i < values.length; i++) { + for (var j = 0; j < offset; j++) { + if (values[i] === 1) { + newValues[index++] = aValues[i]; + } + else { + newValues[index++] = bValues[i]; + } + } + } + return result; + }; + MathBackendCPU.prototype.where = function (condition) { + var condVals = condition.dataSync(); + return where_impl_1.whereImpl(condition.shape, condVals); + }; + MathBackendCPU.prototype.topk = function (x, k, sorted) { + var xVals = x.dataSync(); + return topk_impl_1.topkImpl(xVals, x.shape, x.dtype, k, sorted); + }; + MathBackendCPU.prototype.min = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('min', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, x.dtype); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var min = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value < min) { + min = value; + } + } + vals[i] = min; + } + return result; + }; + MathBackendCPU.prototype.minimum = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { return Math.min(aVal, bVal); }); + }; + MathBackendCPU.prototype.mod = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { + var rem = aVal % bVal; + if ((aVal < 0 && bVal < 0) || (aVal >= 0 && bVal >= 0)) { + return rem; + } + else { + return (rem + bVal) % bVal; + } + }); + }; + MathBackendCPU.prototype.max = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('max', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, x.dtype); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var max = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value > max) { + max = value; + } + } + vals[i] = max; + } + return result; + }; + MathBackendCPU.prototype.maximum = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { return Math.max(aVal, bVal); }); + }; + MathBackendCPU.prototype.all = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('all', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, x.dtype); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var all = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + all = all && value; + } + vals[i] = all; + } + return result; + }; + MathBackendCPU.prototype.any = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('any', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = ops.zeros(outShape, x.dtype); + var reduceSize = util.sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var anyVal = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + anyVal = anyVal || value; + } + vals[i] = anyVal; + } + return result; + }; + MathBackendCPU.prototype.squaredDifference = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { + var diff = aVal - bVal; + return diff * diff; + }); + }; + MathBackendCPU.prototype.ceil = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.ceil(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.floor = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.floor(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.sign = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + if (values[i] < 0) { + newValues[i] = -1; + } + else if (values[i] > 0) { + newValues[i] = 1; + } + else { + newValues[i] = 0; + } + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.round = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var base = Math.floor(values[i]); + if (values[i] - base < 0.5) { + newValues[i] = Math.floor(values[i]); + } + else if (values[i] - base > 0.5) { + newValues[i] = Math.ceil(values[i]); + } + else { + if (base % 2.0 === 0.0) { + newValues[i] = base; + } + else { + newValues[i] = base + 1.0; + } + } + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.exp = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.exp(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.expm1 = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.expm1(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.log = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.log(value); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.log1p = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.log1p(value); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.sqrt = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.sqrt(value); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.rsqrt = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = 1 / Math.sqrt(value); + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.square = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = value * value; + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.reciprocal = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = 1 / values[i]; + } + return tensor_1.Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.relu = function (x) { + var res = ops.zeros(x.shape, x.dtype); + var resVals = res.dataSync(); + var inVals = x.dataSync(); + for (var i = 0; i < inVals.length; ++i) { + resVals[i] = Math.max(0, inVals[i]); + } + return res; + }; + MathBackendCPU.prototype.elu = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 0) { + resultValues[i] = v; + } + else { + resultValues[i] = (Math.exp(v) - 1); + } + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.eluDer = function (dy, y) { + var resultValues = new Float32Array(y.size); + var values = y.dataSync(); + var dyValues = dy.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 1) { + resultValues[i] = dyValues[i]; + } + else { + resultValues[i] = dyValues[i] * (v + 1); + } + } + return tensor_1.Tensor.make(y.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.selu = function (x) { + var scaleAlpha = selu_util.SELU_SCALEALPHA; + var scale = selu_util.SELU_SCALE; + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 0) { + resultValues[i] = scale * v; + } + else { + resultValues[i] = scaleAlpha * (Math.exp(v) - 1); + } + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.clip = function (x, min, max) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.min(max, Math.max(min, values[i])); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.abs = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.abs(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.int = function (x) { + var resultValues = new Int32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = values[i]; + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }, 'int32'); + }; + MathBackendCPU.prototype.sigmoid = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = 1 / (1 + Math.exp(-values[i])); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.softplus = function (x) { + var epsilon = 1.1920928955078125e-7; + var threshold = Math.log(epsilon) + 2.0; + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var tooLarge = values[i] > -threshold; + var tooSmall = values[i] < threshold; + var expX = Math.exp(values[i]); + var result = void 0; + if (tooSmall) { + result = expX; + } + else if (tooLarge) { + result = values[i]; + } + else { + result = Math.log(1.0 + expX); + } + resultValues[i] = result; + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.sin = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.sin(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.cos = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.cos(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.tan = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.tan(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.asin = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.asin(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.acos = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.acos(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atan = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.atan(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atan2 = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aValue, bValue) { return Math.atan2(aValue, bValue); }); + }; + MathBackendCPU.prototype.sinh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.sinh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.cosh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.cosh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.tanh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = util.tanh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.asinh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.asinh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.acosh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.acosh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atanh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.atanh(values[i]); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.erf = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + var p = erf_util.ERF_P; + var a1 = erf_util.ERF_A1; + var a2 = erf_util.ERF_A2; + var a3 = erf_util.ERF_A3; + var a4 = erf_util.ERF_A4; + var a5 = erf_util.ERF_A5; + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + var t = 1.0 / (1.0 + p * v); + resultValues[i] = 1.0 - + (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t * + Math.exp(-v * v); + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.step = function (x, alpha) { + if (alpha === void 0) { alpha = 0; } + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + if (isNaN(value)) { + resultValues[i] = NaN; + } + else { + resultValues[i] = value > 0 ? 1 : alpha; + } + } + return tensor_1.Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.conv2d = function (x, filter, convInfo) { + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var padLeft = convInfo.padInfo.left; + var padTop = convInfo.padInfo.top; + var y = ops.buffer(convInfo.outShape, x.dtype); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * convInfo.strideHeight - padLeft; + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * convInfo.strideWidth - padTop; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; wR++) { + var xR = xRCorner + wR * dilationHeight; + if (xR < 0 || xR >= convInfo.inHeight) { + continue; + } + for (var wC = 0; wC < filterWidth; wC++) { + var xC = xCCorner + wC * dilationWidth; + if (xC < 0 || xC >= convInfo.inWidth) { + continue; + } + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + var pixel = x.get(b, xR, xC, d1); + var weight = filter.get(wR, wC, d1, d2); + dotProd += pixel * weight; + } + } + } + y.set(dotProd, b, yR, yC, d2); + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.conv2dDerInput = function (dy, filter, convInfo) { + var dx = ops.buffer(convInfo.inShape, 'float32'); + var dxValues = dx.values; + var _a = dx.strides, dxS0 = _a[0], dxS1 = _a[1], dxS2 = _a[2]; + var dyValues = dy.dataSync(); + var _b = dy.strides, dyS0 = _b[0], dyS1 = _b[1], dyS2 = _b[2]; + var fltValues = filter.dataSync(); + var _c = filter.strides, fltS0 = _c[0], fltS1 = _c[1], fltS2 = _c[2]; + var batchSize = convInfo.batchSize, filterHeight = convInfo.filterHeight, filterWidth = convInfo.filterWidth, inChannels = convInfo.inChannels, inHeight = convInfo.inHeight, inWidth = convInfo.inWidth, outChannels = convInfo.outChannels, outHeight = convInfo.outHeight, outWidth = convInfo.outWidth, strideHeight = convInfo.strideHeight, strideWidth = convInfo.strideWidth; + var topPad = filterHeight - 1 - convInfo.padInfo.top; + var leftPad = filterWidth - 1 - convInfo.padInfo.left; + for (var b = 0; b < batchSize; ++b) { + for (var d1 = 0; d1 < inChannels; ++d1) { + for (var xR = 0; xR < inHeight; ++xR) { + var xRCorner = xR - topPad; + var xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight)); + var yRMax = Math.min(outHeight, (filterHeight + xRCorner) / strideHeight); + for (var xC = 0; xC < inWidth; ++xC) { + var xCCorner = xC - leftPad; + var xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth)); + var yCMax = Math.min(outWidth, (filterWidth + xCCorner) / strideWidth); + var dotProd = 0; + for (var yR = xRMin; yR < yRMax; ++yR) { + var wR = yR * strideHeight - xRCorner; + for (var yC = xCMin; yC < yCMax; ++yC) { + var wC = yC * strideWidth - xCCorner; + var dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC; + var fltOffset = fltS0 * (filterHeight - 1 - wR) + + fltS1 * (filterWidth - 1 - wC) + fltS2 * d1; + for (var d2 = 0; d2 < outChannels; ++d2) { + var pixel = dyValues[dyOffset + d2]; + var weight = fltValues[fltOffset + d2]; + dotProd += pixel * weight; + } + } + } + dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd; + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.conv2dDerFilter = function (x, dy, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dW = ops.buffer(convInfo.filterShape, 'float32'); + var leftPad = convInfo.padInfo.left; + var topPad = convInfo.padInfo.top; + for (var wR = 0; wR < filterHeight; ++wR) { + var yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight)); + var yRMax = Math.min(convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight); + for (var wC = 0; wC < filterWidth; ++wC) { + var yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth)); + var yCMax = Math.min(convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth); + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + var dotProd = 0; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var yR = yRMin; yR < yRMax; ++yR) { + var xR = wR + yR * strideHeight - topPad; + for (var yC = yCMin; yC < yCMax; ++yC) { + var xC = wC + yC * strideWidth - leftPad; + dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2); + } + } + } + dW.set(dotProd, wR, wC, d1, d2); + } + } + } + } + return dW.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2D = function (x, filter, convInfo) { + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var padLeft = convInfo.padInfo.left; + var padTop = convInfo.padInfo.top; + var chMul = convInfo.outChannels / convInfo.inChannels; + var y = ops.buffer(convInfo.outShape, x.dtype); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * convInfo.strideHeight - padLeft; + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * convInfo.strideWidth - padTop; + for (var q = 0; q < chMul; ++q) { + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var xR = xRCorner + wR * dilationHeight; + if (xR < 0 || xR >= convInfo.inHeight) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var xC = xCCorner + wC * dilationWidth; + if (xC < 0 || xC >= convInfo.inWidth) { + continue; + } + var pixel = x.get(b, xR, xC, d1); + var weight = filter.get(wR, wC, d1, q); + dotProd += pixel * weight; + } + } + y.set(dotProd, b, yR, yC, d1 * chMul + q); + } + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2DDerInput = function (dy, filter, convInfo) { + var dx = ops.buffer(convInfo.inShape, 'float32'); + var dxValues = dx.values; + var _a = dx.strides, dxS0 = _a[0], dxS1 = _a[1], dxS2 = _a[2]; + var dyValues = dy.dataSync(); + var _b = dy.strides, dyS0 = _b[0], dyS1 = _b[1], dyS2 = _b[2]; + var fltValues = filter.dataSync(); + var _c = filter.strides, fltS0 = _c[0], fltS1 = _c[1], fltS2 = _c[2]; + var batchSize = convInfo.batchSize, filterHeight = convInfo.filterHeight, filterWidth = convInfo.filterWidth, inChannels = convInfo.inChannels, inHeight = convInfo.inHeight, inWidth = convInfo.inWidth, outChannels = convInfo.outChannels, outHeight = convInfo.outHeight, outWidth = convInfo.outWidth, strideHeight = convInfo.strideHeight, strideWidth = convInfo.strideWidth; + var topPad = filterHeight - 1 - convInfo.padInfo.top; + var leftPad = filterWidth - 1 - convInfo.padInfo.left; + var chMul = outChannels / inChannels; + for (var b = 0; b < batchSize; ++b) { + for (var d1 = 0; d1 < inChannels; ++d1) { + for (var xR = 0; xR < inHeight; ++xR) { + var xRCorner = xR - topPad; + var xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight)); + var yRMax = Math.min(outHeight, (filterHeight + xRCorner) / strideHeight); + for (var xC = 0; xC < inWidth; ++xC) { + var xCCorner = xC - leftPad; + var xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth)); + var yCMax = Math.min(outWidth, (filterWidth + xCCorner) / strideWidth); + var dotProd = 0; + for (var yR = xRMin; yR < yRMax; ++yR) { + var wR = yR * strideHeight - xRCorner; + for (var yC = xCMin; yC < yCMax; ++yC) { + var wC = yC * strideWidth - xCCorner; + var dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC; + var fltOffset = fltS0 * (filterHeight - 1 - wR) + + fltS1 * (filterWidth - 1 - wC) + fltS2 * d1; + for (var dm = 0; dm < chMul; ++dm) { + var d2 = d1 * chMul + dm; + var pixel = dyValues[dyOffset + d2]; + var weight = fltValues[fltOffset + dm]; + dotProd += pixel * weight; + } + } + } + dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd; + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2DDerFilter = function (x, dy, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dW = ops.buffer(convInfo.filterShape, 'float32'); + var leftPad = convInfo.padInfo.left; + var topPad = convInfo.padInfo.top; + var chMul = convInfo.outChannels / convInfo.inChannels; + for (var wR = 0; wR < filterHeight; ++wR) { + var yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight)); + var yRMax = Math.min(convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight); + for (var wC = 0; wC < filterWidth; ++wC) { + var yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth)); + var yCMax = Math.min(convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth); + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + var d1 = Math.trunc(d2 / chMul); + var dm = d2 % chMul; + var dotProd = 0; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var yR = yRMin; yR < yRMax; ++yR) { + var xR = wR + yR * strideHeight - topPad; + for (var yC = yCMin; yC < yCMax; ++yC) { + var xC = wC + yC * strideWidth - leftPad; + dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2); + } + } + } + dW.set(dotProd, wR, wC, d1, dm); + } + } + } + return dW.toTensor(); + }; + MathBackendCPU.prototype.tile = function (x, reps) { + var newShape = new Array(x.rank); + for (var i = 0; i < newShape.length; i++) { + newShape[i] = x.shape[i] * reps[i]; + } + var result = ops.buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < result.values.length; ++i) { + var newLoc = result.indexToLoc(i); + var originalLoc = new Array(x.rank); + for (var i_1 = 0; i_1 < originalLoc.length; i_1++) { + originalLoc[i_1] = newLoc[i_1] % x.shape[i_1]; + } + var originalIndex = xBuf.locToIndex(originalLoc); + result.values[i] = xBuf.values[originalIndex]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.pad = function (x, paddings, constantValue) { + var outShape = paddings.map(function (p, i) { return p[0] + x.shape[i] + p[1]; }); + var start = paddings.map(function (p) { return p[0]; }); + var xBuffer = x.buffer(); + var buffer = ops.buffer(outShape, x.dtype); + if (constantValue !== 0) { + buffer.values.fill(constantValue); + } + for (var i = 0; i < x.size; i++) { + var coords = xBuffer.indexToLoc(i); + var outCoords = coords.map(function (c, i) { return c + start[i]; }); + buffer.set.apply(buffer, [x.get.apply(x, coords)].concat(outCoords)); + } + return buffer.toTensor(); + }; + MathBackendCPU.prototype.transpose = function (x, perm) { + var newShape = new Array(x.rank); + for (var i = 0; i < newShape.length; i++) { + newShape[i] = x.shape[perm[i]]; + } + var values = x.dataSync(); + var result = ops_1.buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < x.size; ++i) { + var loc = xBuf.indexToLoc(i); + var newLoc = new Array(loc.length); + for (var i_2 = 0; i_2 < newLoc.length; i_2++) { + newLoc[i_2] = loc[perm[i_2]]; + } + var newIndex = result.locToIndex(newLoc); + result.values[newIndex] = values[i]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.gather = function (x, indices, axis) { + var newShape = x.shape.slice(); + var indicesValues = indices.dataSync(); + newShape[axis] = indicesValues.length; + var result = ops_1.buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < result.size; ++i) { + var newLoc = result.indexToLoc(i); + var originalLoc = newLoc.slice(); + originalLoc[axis] = indicesValues[newLoc[axis]]; + var originalIndex = xBuf.locToIndex(originalLoc); + result.values[i] = xBuf.values[originalIndex]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.batchToSpaceND = function (x, blockShape, crops) { + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod); + var permuted = array_ops_util.getPermuted(reshaped.length, blockShape.length); + var reshapedPermuted = array_ops_util.getReshapedPermuted(x.shape, blockShape, prod); + var sliceBeginCoords = array_ops_util.getSliceBeginCoords(crops, blockShape.length); + var sliceSize = array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length); + return x.reshape(reshaped) + .transpose(permuted) + .reshape(reshapedPermuted) + .slice(sliceBeginCoords, sliceSize); + }; + MathBackendCPU.prototype.spaceToBatchND = function (x, blockShape, paddings) { + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var completePaddings = [[0, 0]]; + completePaddings.push.apply(completePaddings, paddings); + for (var i = 1 + blockShape.length; i < x.shape.length; ++i) { + completePaddings.push([0, 0]); + } + var paddedX = x.pad(completePaddings); + var reshapedPaddedShape = array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false); + var permutedReshapedPaddedPermutation = array_ops_util.getPermuted(reshapedPaddedShape.length, blockShape.length, false); + var flattenShape = array_ops_util.getReshapedPermuted(paddedX.shape, blockShape, prod, false); + return paddedX.reshape(reshapedPaddedShape) + .transpose(permutedReshapedPaddedPermutation) + .reshape(flattenShape); + }; + MathBackendCPU.prototype.pool = function (x, convInfo, poolType) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var y = ops.buffer(convInfo.outShape, 'float32'); + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * strideHeight - padTop; + var xRMin = Math.max(0, xRCorner); + var xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner); + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * strideWidth - padLeft; + var xCMin = Math.max(0, xCCorner); + var xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner); + var minMaxValue = (poolType === 'max' ? Number.NEGATIVE_INFINITY : + Number.POSITIVE_INFINITY); + var avgValue = 0; + var count = 0; + for (var xR = xRMin; xR < xRMax; ++xR) { + for (var xC = xCMin; xC < xCMax; ++xC) { + var pixel = x.get(b, xR, xC, d); + if ((poolType === 'max' && pixel > minMaxValue)) { + minMaxValue = pixel; + } + else if (poolType === 'avg') { + avgValue += pixel; + count++; + } + } + if (isNaN(minMaxValue)) { + break; + } + } + y.set(poolType === 'avg' ? avgValue / count : minMaxValue, b, yR, yC, d); + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.maxPool = function (x, convInfo) { + return this.pool(x, convInfo, 'max'); + }; + MathBackendCPU.prototype.maxPoolPositions = function (x, convInfo) { + var maxPositions = ops.buffer(convInfo.outShape, 'int32'); + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * strideHeight - padTop; + var xRMin = Math.max(0, xRCorner); + var xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner); + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * strideWidth - padLeft; + var xCMin = Math.max(0, xCCorner); + var xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner); + var maxValue = Number.NEGATIVE_INFINITY; + var maxPosition = -1; + for (var xR = xRMin; xR < xRMax; ++xR) { + var wR = xR - xRCorner; + for (var xC = xCMin; xC < xCMax; ++xC) { + var wC = xC - xCCorner; + var pixel = x.get(b, xR, xC, d); + if (pixel > maxValue) { + maxValue = pixel; + maxPosition = wR * filterWidth + wC; + } + } + } + maxPositions.set(maxPosition, b, yR, yC, d); + } + } + } + } + return maxPositions.toTensor(); + }; + MathBackendCPU.prototype.maxPoolBackprop = function (dy, x, y, convInfo) { + var maxPositions = this.maxPoolPositions(x, convInfo); + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var dx = ops.buffer(x.shape, 'float32'); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var dxR = 0; dxR < convInfo.inHeight; ++dxR) { + for (var dxC = 0; dxC < convInfo.inWidth; ++dxC) { + var dyRCorner = dxR - padTop; + var dyCCorner = dxC - padLeft; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var dyR = (dyRCorner + wR) / strideHeight; + if (dyR < 0 || dyR >= convInfo.outHeight || + Math.floor(dyR) !== dyR) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var dyC = (dyCCorner + wC) / strideWidth; + if (dyC < 0 || dyC >= convInfo.outWidth || + Math.floor(dyC) !== dyC) { + continue; + } + var maxPos = filterHeight * filterWidth - 1 - + maxPositions.get(b, dyR, dyC, d); + var curPos = wR * filterWidth + wC; + var mask = maxPos === curPos ? 1 : 0; + if (mask === 0) { + continue; + } + var pixel = dy.get(b, dyR, dyC, d); + dotProd += pixel * mask; + } + } + dx.set(dotProd, b, dxR, dxC, d); + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.avgPoolBackprop = function (dy, x, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var dx = ops.buffer(x.shape, 'float32'); + var avgMultiplier = 1 / (filterHeight * filterWidth); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var dxR = 0; dxR < convInfo.inHeight; ++dxR) { + for (var dxC = 0; dxC < convInfo.inWidth; ++dxC) { + var dyRCorner = dxR - padTop; + var dyCCorner = dxC - padLeft; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var dyR = (dyRCorner + wR) / strideHeight; + if (dyR < 0 || dyR >= convInfo.outHeight || + Math.floor(dyR) !== dyR) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var dyC = (dyCCorner + wC) / strideWidth; + if (dyC < 0 || dyC >= convInfo.outWidth || + Math.floor(dyC) !== dyC) { + continue; + } + var pixel = dy.get(b, dyR, dyC, d); + dotProd += pixel; + } + } + dx.set(dotProd * avgMultiplier, b, dxR, dxC, d); + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.cast = function (x, dtype) { + return backend_util.castTensor(x, dtype, this); + }; + MathBackendCPU.prototype.reshape = function (x, shape) { + return backend_util.reshapeTensor(x, shape); + }; + MathBackendCPU.prototype.avgPool = function (x, convInfo) { + return this.pool(x, convInfo, 'avg').toFloat(); + }; + MathBackendCPU.prototype.resizeBilinear = function (x, newHeight, newWidth, alignCorners) { + var _a = x.shape, batch = _a[0], oldHeight = _a[1], oldWidth = _a[2], numChannels = _a[3]; + var output = ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype); + var effectiveInputSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutputSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < newHeight; r++) { + for (var c = 0; c < newWidth; c++) { + for (var d = 0; d < numChannels; d++) { + var sourceFracRow = (effectiveInputSize[0]) * r / (effectiveOutputSize[0]); + var sourceFracCol = (effectiveInputSize[1]) * c / (effectiveOutputSize[1]); + var sourceRowFloor = Math.floor(sourceFracRow); + var sourceRowCeil = Math.min(oldHeight - 1, Math.ceil(sourceFracRow)); + var sourceColFloor = Math.floor(sourceFracCol); + var sourceColCeil = Math.min(oldWidth - 1, Math.ceil(sourceFracCol)); + var topLeft = x.get(b, sourceRowFloor, sourceColFloor, d); + var bottomLeft = x.get(b, sourceRowCeil, sourceColFloor, d); + var topRight = x.get(b, sourceRowFloor, sourceColCeil, d); + var bottomRight = x.get(b, sourceRowCeil, sourceColCeil, d); + var rowFrac = sourceFracRow - sourceRowFloor; + var colFrac = sourceFracCol - sourceColFloor; + var top_1 = topLeft + (topRight - topLeft) * colFrac; + var bottom = bottomLeft + (bottomRight - bottomLeft) * colFrac; + var newValue = top_1 + (bottom - top_1) * rowFrac; + output.set(newValue, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeBilinearBackprop = function (dy, x, alignCorners) { + var _a = x.shape, batch = _a[0], xHeight = _a[1], xWidth = _a[2], depth = _a[3]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var output = ops.buffer([batch, xHeight, xWidth, depth], x.dtype); + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < yHeight; r++) { + var dxR = r * heightScale; + var topDxRIndex = Math.floor(dxR); + var bottomDxRIndex = Math.min(Math.ceil(dxR), xHeight - 1); + var dxRLerp = dxR - topDxRIndex; + var inverseDxRLerp = 1.0 - dxRLerp; + for (var c = 0; c < yWidth; c++) { + var dxC = c * widthScale; + var leftDxCIndex = Math.floor(dxC); + var rightDxCIndex = Math.min(Math.ceil(dxC), xWidth - 1); + var dxCLerp = dxC - leftDxCIndex; + var inverseDxCLerp = 1.0 - dxCLerp; + for (var d = 0; d < depth; d++) { + var dyVal = dy.get(b, r, c, d); + var topLeft = output.get(b, topDxRIndex, leftDxCIndex, d); + topLeft += dyVal * inverseDxRLerp * inverseDxCLerp; + output.set(topLeft, b, topDxRIndex, leftDxCIndex, d); + var topRight = output.get(b, topDxRIndex, rightDxCIndex, d); + topRight += dyVal * inverseDxRLerp * dxCLerp; + output.set(topRight, b, topDxRIndex, rightDxCIndex, d); + var bottomLeft = output.get(b, bottomDxRIndex, leftDxCIndex, d); + bottomLeft += dyVal * dxRLerp * inverseDxCLerp; + output.set(bottomLeft, b, bottomDxRIndex, leftDxCIndex, d); + var bottomRight = output.get(b, bottomDxRIndex, rightDxCIndex, d); + bottomRight += dyVal * dxRLerp * dxCLerp; + output.set(bottomRight, b, bottomDxRIndex, rightDxCIndex, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeNearestNeighbor = function (x, newHeight, newWidth, alignCorners) { + var _a = x.shape, batch = _a[0], oldHeight = _a[1], oldWidth = _a[2], numChannels = _a[3]; + var output = ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype); + var effectiveInputSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutputSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < newHeight; r++) { + for (var c = 0; c < newWidth; c++) { + for (var d = 0; d < numChannels; d++) { + var sourceFracRow = (effectiveInputSize[0]) * r / (effectiveOutputSize[0]); + var sourceFracCol = (effectiveInputSize[1]) * c / (effectiveOutputSize[1]); + var sourceNearestRow = Math.min(oldHeight - 1, alignCorners ? Math.round(sourceFracRow) : + Math.floor(sourceFracRow)); + var sourceNearestCol = Math.min(oldWidth - 1, alignCorners ? Math.round(sourceFracCol) : + Math.floor(sourceFracCol)); + var newValue = x.get(b, sourceNearestRow, sourceNearestCol, d); + output.set(newValue, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeNearestNeighborBackprop = function (dy, x, alignCorners) { + var _a = x.shape, batch = _a[0], xHeight = _a[1], xWidth = _a[2], depth = _a[3]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var output = ops.buffer([batch, xHeight, xWidth, depth], x.dtype); + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < xHeight; r++) { + for (var c = 0; c < xWidth; c++) { + var startRLerp = Math.floor(r * invHeightScale); + var startDyR = Math.floor(startRLerp - (winHeight / 2)); + var startCLerp = Math.floor(c * invWidthScale); + var startDyC = Math.floor(startCLerp - (winWidth / 2)); + for (var d = 0; d < depth; d++) { + var accum = 0; + for (var dyROffset = 0; dyROffset < winHeight; dyROffset++) { + var dyR = dyROffset + startDyR; + if (dyR < 0 || dyR >= yHeight) { + continue; + } + for (var dyCOffSet = 0; dyCOffSet < winWidth; dyCOffSet++) { + var dyC = dyCOffSet + startDyC; + if (dyC < 0 || dyC >= yWidth) { + continue; + } + var sourceFracRow = effectiveXSize[0] * (dyR / effectiveYSize[0]); + var sourceFracCol = effectiveXSize[1] * (dyC / effectiveYSize[1]); + var sourceNearestRow = Math.min(xHeight - 1, alignCorners ? Math.round(sourceFracRow) : + Math.floor(sourceFracRow)); + var sourceNearestCol = Math.min(xWidth - 1, alignCorners ? Math.round(sourceFracCol) : + Math.floor(sourceFracCol)); + if (r === sourceNearestRow && c === sourceNearestCol) { + accum += dy.get(b, dyR, dyC, d); + } + } + } + output.set(accum, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.batchNormalization = function (x, mean, variance, varianceEpsilon, scale, offset) { + var xValues = x.dataSync(); + var meanValues = mean.dataSync(); + var varianceValues = variance.dataSync(); + var scaleValues = scale ? scale.dataSync() : new Float32Array([1]); + var offsetValues = offset ? offset.dataSync() : new Float32Array([0]); + var outValues = new Float32Array(xValues.length); + for (var i = 0; i < xValues.length; i++) { + outValues[i] = offsetValues[i % offsetValues.length] + + (xValues[i] - meanValues[i % meanValues.length]) * + scaleValues[i % scaleValues.length] / + Math.sqrt(varianceValues[i % varianceValues.length] + varianceEpsilon); + } + return ops_1.tensor4d(outValues, x.shape); + }; + MathBackendCPU.prototype.localResponseNormalization4D = function (x, radius, bias, alpha, beta) { + var output = ops.buffer(x.shape, 'float32'); + var rad = radius; + var maxD = output.shape[3] - 1; + function sumAcrossChannels(b, r, c, d) { + var sum = 0.0; + for (var j = Math.max(0, d - rad); j <= Math.min(d + rad, maxD); j++) { + var z = x.get(b, r, c, j); + sum += z * z; + } + return sum; + } + for (var b = 0; b < output.shape[0]; b++) { + for (var r = 0; r <= output.shape[1]; r++) { + for (var c = 0; c < output.shape[2]; c++) { + for (var d = 0; d < output.shape[3]; d++) { + var sum = sumAcrossChannels(b, r, c, d); + var val = x.get(b, r, c, d) * Math.pow(bias + alpha * sum, -beta); + output.set(val, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.LRNGrad = function (dy, inputImage, outputImage, depthRadius, bias, alpha, beta) { + var batch = dy.shape[0]; + var rows = dy.shape[1]; + var cols = dy.shape[2]; + var depth = dy.shape[3]; + var output = ops.buffer([batch, rows, cols, depth], 'float32'); + for (var b = 0; b < batch; ++b) { + for (var r = 0; r < rows; ++r) { + for (var c = 0; c < cols; ++c) { + for (var d = 0; d < depth; ++d) { + var depthBegin = Math.max(0, d - depthRadius); + var depthEnd = Math.min(depth, d + depthRadius + 1); + var norm = 0; + for (var k = depthBegin; k < depthEnd; ++k) { + norm += inputImage.get(b, r, c, k) * inputImage.get(b, r, c, k); + } + norm = alpha * norm + bias; + for (var k = depthBegin; k < depthEnd; ++k) { + var dyi = -2 * alpha * beta * inputImage.get(b, r, c, k) * + outputImage.get(b, r, c, d) / norm; + if (d === k) { + dyi += Math.pow(norm, -beta); + } + dyi *= dy.get(b, r, c, d); + output.set(dyi + output.get(b, r, c, k), b, r, c, k); + } + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.multinomial = function (logits, normalized, numSamples, seed) { + var probabilities = normalized ? logits : ops.softmax(logits); + var batchSize = probabilities.shape[0]; + var numEvents = probabilities.shape[1]; + var res = ops.zeros([batchSize, numSamples], 'int32'); + var resVals = res.dataSync(); + var probVals = probabilities.dataSync(); + for (var b = 0; b < batchSize; ++b) { + var offset = b * numEvents; + var cdf = new Float32Array(numEvents - 1); + cdf[0] = probVals[offset]; + for (var event_1 = 1; event_1 < cdf.length; ++event_1) { + cdf[event_1] = cdf[event_1 - 1] + probVals[offset + event_1]; + } + var random = seedrandom.alea(seed.toString()); + var outOffset = b * numSamples; + for (var sampleId = 0; sampleId < numSamples; ++sampleId) { + var r = random(); + resVals[outOffset + sampleId] = cdf.length; + for (var event_2 = 0; event_2 < cdf.length; event_2++) { + if (r < cdf[event_2]) { + resVals[outOffset + sampleId] = event_2; + break; + } + } + } + } + return res; + }; + MathBackendCPU.prototype.oneHot = function (indices, depth, onValue, offValue) { + var res = new Float32Array(indices.size * depth); + res.fill(offValue); + for (var event_3 = 0; event_3 < indices.size; ++event_3) { + if (indices.get(event_3) >= 0 && indices.get(event_3) < depth) { + res[event_3 * depth + indices.get(event_3)] = onValue; + } + } + return ops.tensor2d(res, [indices.size, depth], 'int32'); + }; + MathBackendCPU.prototype.nonMaxSuppression = function (boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + var boxesVals = boxes.dataSync(); + var scoresVals = scores.dataSync(); + return non_max_suppression_impl_1.nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + }; + MathBackendCPU.prototype.broadcastedBinaryOp = function (a, b, dtype, op) { + var newShape = broadcast_util.assertAndGetBroadcastShape(a.shape, b.shape); + var result = ops.buffer(newShape, dtype); + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var aBroadcastDims = broadcast_util.getBroadcastDims(a.shape, newShape); + var bBroadcastDims = broadcast_util.getBroadcastDims(b.shape, newShape); + var aBuf = a.buffer(); + var bBuf = b.buffer(); + var _loop_2 = function (i) { + var loc = result.indexToLoc(i); + var aLoc = loc.slice(-a.rank); + aBroadcastDims.forEach(function (d) { return aLoc[d] = 0; }); + var aIndex = aBuf.locToIndex(aLoc); + var bLoc = loc.slice(-b.rank); + bBroadcastDims.forEach(function (d) { return bLoc[d] = 0; }); + var bIndex = bBuf.locToIndex(bLoc); + result.values[i] = op(aValues[aIndex], bValues[bIndex]); + }; + for (var i = 0; i < result.values.length; ++i) { + _loop_2(i); + } + return result.toTensor(); + }; + MathBackendCPU.prototype.dispose = function () { }; + return MathBackendCPU; +}()); +exports.MathBackendCPU = MathBackendCPU; +environment_1.ENV.registerBackend('cpu', function () { return new MathBackendCPU(); }, 1, tensor_1.setTensorTracker); +//# sourceMappingURL=backend_cpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js.map new file mode 100644 index 0000000..b6dda67 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_cpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"backend_cpu.js","sourceRoot":"","sources":["../../src/kernels/backend_cpu.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.d.ts new file mode 100644 index 0000000..4149084 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.d.ts @@ -0,0 +1,6 @@ +import { Tensor } from '../tensor'; +import { Rank } from '../types'; +import { DataType, ShapeMap } from '../types'; +import { KernelBackend } from './backend'; +export declare function castTensor(x: T, dtype: DataType, backend: KernelBackend): T; +export declare function reshapeTensor(x: T, shape: ShapeMap[R]): Tensor; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js new file mode 100644 index 0000000..f0990fe --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js @@ -0,0 +1,25 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_ops_1 = require("../ops/tensor_ops"); +var tensor_1 = require("../tensor"); +var util_1 = require("../util"); +function castTensor(x, dtype, backend) { + if (!util_1.hasEncodingLoss(x.dtype, dtype)) { + return tensor_1.Tensor.make(x.shape, { dataId: x.dataId }, dtype); + } + if (dtype === 'int32') { + return backend.int(x); + } + else if (dtype === 'bool') { + return backend.notEqual(x, tensor_ops_1.scalar(0, x.dtype)); + } + else { + throw new Error("Error in Cast: unknown dtype argument (" + dtype + ")"); + } +} +exports.castTensor = castTensor; +function reshapeTensor(x, shape) { + return tensor_1.Tensor.make(shape, { dataId: x.dataId }, x.dtype); +} +exports.reshapeTensor = reshapeTensor; +//# sourceMappingURL=backend_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js.map new file mode 100644 index 0000000..dbb10a8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"backend_util.js","sourceRoot":"","sources":["../../src/kernels/backend_util.ts"],"names":[],"mappings":";;AAiBA,gDAAyC;AACzC,oCAAiC;AAGjC,gCAAwC;AAGxC,oBACI,CAAI,EAAE,KAAe,EAAE,OAAsB;IAC/C,IAAI,CAAC,sBAAe,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE;QAGpC,OAAO,eAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAC,EAAE,KAAK,CAAM,CAAC;KAC7D;IACD,IAAI,KAAK,KAAK,OAAO,EAAE;QACrB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;KACvB;SAAM,IAAI,KAAK,KAAK,MAAM,EAAE;QAC3B,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAE,mBAAM,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAM,CAAC;KACrD;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,4CAA0C,KAAK,MAAG,CAAC,CAAC;KACrE;AACH,CAAC;AAdD,gCAcC;AAED,uBACI,CAAI,EAAE,KAAkB;IAC1B,OAAO,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;AACzD,CAAC;AAHD,sCAGC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.d.ts new file mode 100644 index 0000000..1c4f47e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.d.ts @@ -0,0 +1,172 @@ +import { MemoryInfo, TimingInfo } from '../engine'; +import { Conv2DInfo } from '../ops/conv_util'; +import { DataId, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { DataType, Rank, ShapeMap, TypedArray } from '../types'; +import { KernelBackend } from './backend'; +import { GPGPUContext } from './webgl/gpgpu_context'; +import { TextureManager } from './webgl/texture_manager'; +export interface CPUTimerQuery { + startMs: number; + endMs?: number; +} +export interface WebGLMemoryInfo extends MemoryInfo { + numBytesInGPU: number; + unreliable: boolean; +} +export interface WebGLTimingInfo extends TimingInfo { + uploadWaitMs: number; + downloadWaitMs: number; +} +export declare const SIZE_UPLOAD_UNIFORM = 32; +export declare class MathBackendWebGL implements KernelBackend { + private gpgpu?; + private delayedStorage; + private texData; + private pendingRead; + private pendingDisposal; + private lruDataGPU; + private numBytesInGPU; + private NUM_BYTES_BEFORE_PAGING; + private canvas; + private fromPixelsCanvas; + private programTimersStack; + private activeTimers; + private uploadWaitMs; + private downloadWaitMs; + register(dataId: DataId, shape: number[], dtype: DataType): void; + fromPixels(pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, numChannels: number): Tensor3D; + write(dataId: DataId, values: TypedArray): void; + readSync(dataId: DataId): TypedArray; + read(dataId: DataId): Promise; + private getValuesFromTexture; + time(f: () => void): Promise; + memory(): WebGLMemoryInfo; + private startTimer; + private endTimer; + private getQueryTime; + disposeData(dataId: DataId): void; + getTexture(dataId: DataId): WebGLTexture; + private textureManager; + private binaryCache; + private gpgpuCreatedLocally; + constructor(gpgpu?: GPGPUContext, delayedStorage?: boolean); + getGPGPUContext(): GPGPUContext; + getCanvas(): HTMLCanvasElement; + slice(x: T, begin: number[], size: number[]): T; + stridedSlice(x: T, begin: number[], end: number[], strides: number[], beginMask: number, endMask: number): T; + reverse(x: T, axis: number[]): T; + concat(a: Tensor2D, b: Tensor2D): Tensor2D; + neg(x: T): T; + matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean): Tensor2D; + multiply(a: Tensor, b: Tensor): Tensor; + batchNormalization(x: Tensor4D, mean: Tensor4D | Tensor1D, variance: Tensor4D | Tensor1D, varianceEpsilon: number, scale?: Tensor4D | Tensor1D, offset?: Tensor4D | Tensor1D): Tensor4D; + localResponseNormalization4D(x: Tensor4D, radius: number, bias: number, alpha: number, beta: number): Tensor4D; + LRNGrad(dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D, depthRadius: number, bias: number, alpha: number, beta: number): Tensor4D; + tile(x: T, reps: number[]): T; + pad(x: T, paddings: Array<[number, number]>, constantValue: number): T; + transpose(x: T, perm: number[]): T; + gather(x: T, indices: Tensor1D, axis: number): T; + batchToSpaceND(x: T, blockShape: number[], crops: number[][]): T; + spaceToBatchND(x: T, blockShape: number[], paddings: Array<[number, number]>): T; + private reduce; + private argReduce; + sum(x: Tensor, axes: number[]): Tensor; + unsortedSegmentSum(x: T, segmentIds: Tensor1D, numSegments: number): Tensor; + private segOpCompute; + argMin(x: Tensor, axis: number): Tensor; + argMax(x: Tensor, axis: number): Tensor; + cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean): Tensor; + equal(a: Tensor, b: Tensor): Tensor; + notEqual(a: Tensor, b: Tensor): Tensor; + less(a: Tensor, b: Tensor): Tensor; + lessEqual(a: Tensor, b: Tensor): Tensor; + greater(a: Tensor, b: Tensor): Tensor; + greaterEqual(a: Tensor, b: Tensor): Tensor; + logicalNot(x: T): T; + logicalAnd(a: Tensor, b: Tensor): Tensor; + logicalOr(a: Tensor, b: Tensor): Tensor; + select(condition: Tensor, a: Tensor, b: Tensor): Tensor; + where(condition: Tensor): Tensor2D; + topk(x: T, k: number, sorted: boolean): [T, T]; + min(x: Tensor, axes: number[]): Tensor; + minimum(a: Tensor, b: Tensor): Tensor; + mod(a: Tensor, b: Tensor): Tensor; + max(x: Tensor, axes: number[]): Tensor; + maximum(a: Tensor, b: Tensor): Tensor; + all(x: Tensor, axes: number[]): Tensor; + any(x: Tensor, axes: number[]): Tensor; + squaredDifference(a: Tensor, b: Tensor): Tensor; + realDivide(a: Tensor, b: Tensor): Tensor; + floorDiv(a: Tensor, b: Tensor): Tensor; + add(a: Tensor, b: Tensor): Tensor; + addN(tensors: T[]): T; + subtract(a: Tensor, b: Tensor): Tensor; + pow(a: T, b: Tensor): T; + ceil(x: T): T; + floor(x: T): T; + sign(x: T): T; + round(x: T): T; + exp(x: T): T; + expm1(x: T): T; + log(x: T): T; + log1p(x: T): T; + sqrt(x: T): T; + rsqrt(x: T): T; + square(x: T): T; + reciprocal(x: T): T; + relu(x: T): T; + elu(x: T): T; + eluDer(dy: T, y: T): T; + selu(x: T): T; + int(x: T): T; + clip(x: T, min: number, max: number): T; + abs(x: T): T; + sigmoid(x: T): T; + softplus(x: T): T; + sin(x: T): T; + cos(x: T): T; + tan(x: T): T; + asin(x: T): T; + acos(x: T): T; + atan(x: T): T; + atan2(a: T, b: T): T; + sinh(x: T): T; + cosh(x: T): T; + tanh(x: T): T; + asinh(x: T): T; + acosh(x: T): T; + atanh(x: T): T; + erf(x: T): T; + step(x: T, alpha: number): T; + conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D; + cast(x: T, dtype: DataType): T; + reshape(x: Tensor, shape: ShapeMap[R]): Tensor; + resizeBilinear(x: Tensor4D, newHeight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D; + resizeNearestNeighbor(x: Tensor4D, newHeight: number, newWidth: number, alignCorners: boolean): Tensor4D; + resizeNearestNeighborBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D; + multinomial(logits: Tensor2D, normalized: boolean, numSamples: number, seed: number): Tensor2D; + oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number): Tensor2D; + nonMaxSuppression(boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number, iouThreshold: number, scoreThreshold: number): Tensor1D; + private makeOutputArray; + private compileAndRun; + private getAndSaveBinary; + getTextureManager(): TextureManager; + private disposed; + dispose(): void; + private throwIfNoData; + private uploadToGPU; + private cacheOnCPU; + private releaseTexture; + private acquireTexture; + private computeBytes; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js new file mode 100644 index 0000000..29754e2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js @@ -0,0 +1,1132 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var log_1 = require("../log"); +var array_ops_util = require("../ops/array_ops_util"); +var axis_util = require("../ops/axis_util"); +var reduce_util = require("../ops/reduce_util"); +var segment_util = require("../ops/segment_util"); +var slice_util_1 = require("../ops/slice_util"); +var softmax_1 = require("../ops/softmax"); +var tensor_ops_1 = require("../ops/tensor_ops"); +var tensor_1 = require("../tensor"); +var types_1 = require("../types"); +var util = require("../util"); +var backend_util = require("./backend_util"); +var non_max_suppression_impl_1 = require("./non_max_suppression_impl"); +var topk_impl_1 = require("./topk_impl"); +var argminmax_gpu_1 = require("./webgl/argminmax_gpu"); +var avg_pool_backprop_gpu_1 = require("./webgl/avg_pool_backprop_gpu"); +var batchnorm_gpu_1 = require("./webgl/batchnorm_gpu"); +var binaryop_gpu = require("./webgl/binaryop_gpu"); +var binaryop_gpu_1 = require("./webgl/binaryop_gpu"); +var clip_gpu_1 = require("./webgl/clip_gpu"); +var concat_gpu_1 = require("./webgl/concat_gpu"); +var conv_backprop_gpu_1 = require("./webgl/conv_backprop_gpu"); +var conv_backprop_gpu_depthwise_1 = require("./webgl/conv_backprop_gpu_depthwise"); +var conv_gpu_1 = require("./webgl/conv_gpu"); +var conv_gpu_depthwise_1 = require("./webgl/conv_gpu_depthwise"); +var cumsum_gpu_1 = require("./webgl/cumsum_gpu"); +var encode_float_gpu_1 = require("./webgl/encode_float_gpu"); +var from_pixels_gpu_1 = require("./webgl/from_pixels_gpu"); +var gather_gpu_1 = require("./webgl/gather_gpu"); +var gpgpu_context_1 = require("./webgl/gpgpu_context"); +var gpgpu_math = require("./webgl/gpgpu_math"); +var gpgpu_util = require("./webgl/gpgpu_util"); +var lrn_gpu_1 = require("./webgl/lrn_gpu"); +var lrn_grad_gpu_1 = require("./webgl/lrn_grad_gpu"); +var max_pool_backprop_gpu_1 = require("./webgl/max_pool_backprop_gpu"); +var mulmat_gpu_1 = require("./webgl/mulmat_gpu"); +var multinomial_gpu_1 = require("./webgl/multinomial_gpu"); +var onehot_gpu_1 = require("./webgl/onehot_gpu"); +var pad_gpu_1 = require("./webgl/pad_gpu"); +var pool_gpu_1 = require("./webgl/pool_gpu"); +var reduce_gpu_1 = require("./webgl/reduce_gpu"); +var resize_bilinear_backprop_gpu_1 = require("./webgl/resize_bilinear_backprop_gpu"); +var resize_bilinear_gpu_1 = require("./webgl/resize_bilinear_gpu"); +var resize_nearest_neighbor_backprop_gpu_1 = require("./webgl/resize_nearest_neighbor_backprop_gpu"); +var resize_nearest_neighbor_gpu_1 = require("./webgl/resize_nearest_neighbor_gpu"); +var reverse_gpu_1 = require("./webgl/reverse_gpu"); +var segment_gpu_1 = require("./webgl/segment_gpu"); +var select_gpu_1 = require("./webgl/select_gpu"); +var slice_gpu_1 = require("./webgl/slice_gpu"); +var strided_slice_gpu_1 = require("./webgl/strided_slice_gpu"); +var tex_util_1 = require("./webgl/tex_util"); +var texture_manager_1 = require("./webgl/texture_manager"); +var tile_gpu_1 = require("./webgl/tile_gpu"); +var transpose_gpu_1 = require("./webgl/transpose_gpu"); +var unary_op = require("./webgl/unaryop_gpu"); +var unaryop_gpu_1 = require("./webgl/unaryop_gpu"); +var webgl_util = require("./webgl/webgl_util"); +var where_impl_1 = require("./where_impl"); +var BEFORE_PAGING_CONSTANT = 300; +exports.SIZE_UPLOAD_UNIFORM = 32; +var MathBackendWebGL = (function () { + function MathBackendWebGL(gpgpu, delayedStorage) { + if (delayedStorage === void 0) { delayedStorage = true; } + this.gpgpu = gpgpu; + this.delayedStorage = delayedStorage; + this.texData = new WeakMap(); + this.pendingRead = new WeakMap(); + this.pendingDisposal = new WeakSet(); + this.lruDataGPU = []; + this.numBytesInGPU = 0; + this.uploadWaitMs = 0; + this.downloadWaitMs = 0; + this.binaryCache = {}; + this.disposed = false; + if (environment_1.ENV.get('WEBGL_VERSION') < 1) { + throw new Error('WebGL is not supported on this device'); + } + if (environment_1.ENV.get('IS_BROWSER')) { + this.canvas = document.createElement('canvas'); + } + if (gpgpu == null) { + this.gpgpu = new gpgpu_context_1.GPGPUContext(gpgpu_util.createWebGLContext(this.canvas)); + this.gpgpuCreatedLocally = true; + } + else { + this.gpgpuCreatedLocally = false; + } + this.NUM_BYTES_BEFORE_PAGING = + (window.screen.height * window.screen.width * window.devicePixelRatio) * + BEFORE_PAGING_CONSTANT; + this.textureManager = new texture_manager_1.TextureManager(this.gpgpu); + } + MathBackendWebGL.prototype.register = function (dataId, shape, dtype) { + if (this.texData.has(dataId)) { + throw new Error('Data buffer is already registered'); + } + this.texData.set(dataId, { + shape: shape, + dtype: dtype, + values: null, + texture: null, + texShape: null, + usage: tex_util_1.TextureUsage.RENDER + }); + }; + MathBackendWebGL.prototype.fromPixels = function (pixels, numChannels) { + if (pixels == null) { + throw new Error('pixels passed to tf.fromPixels() can not be null'); + } + var texShape = [pixels.height, pixels.width]; + var outShape = [pixels.height, pixels.width, numChannels]; + if (!(pixels instanceof HTMLVideoElement) && + !(pixels instanceof HTMLImageElement) && + !(pixels instanceof HTMLCanvasElement) && + !(pixels instanceof ImageData)) { + throw new Error('pixels passed to tf.fromPixels() must be either an ' + + "HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or " + + ("ImageData, but was " + pixels.constructor.name)); + } + if (pixels instanceof HTMLVideoElement) { + if (this.fromPixelsCanvas == null) { + if (!environment_1.ENV.get('IS_BROWSER')) { + throw new Error('Can\'t read pixels from HTMLImageElement outside the browser.'); + } + if (document.readyState !== 'complete') { + throw new Error('The DOM is not ready yet. Please call tf.fromPixels() ' + + 'once the DOM is ready. One way to do that is to add an event ' + + 'listener for `DOMContentLoaded` on the document object'); + } + this.fromPixelsCanvas = document.createElement('canvas'); + } + this.fromPixelsCanvas.width = pixels.width; + this.fromPixelsCanvas.height = pixels.height; + this.fromPixelsCanvas.getContext('2d').drawImage(pixels, 0, 0, pixels.width, pixels.height); + pixels = this.fromPixelsCanvas; + } + var tempPixelArray = tensor_1.Tensor.make(texShape, {}, 'int32'); + this.texData.get(tempPixelArray.dataId).usage = tex_util_1.TextureUsage.PIXELS; + this.gpgpu.uploadPixelDataToTexture(this.getTexture(tempPixelArray.dataId), pixels); + var program = new from_pixels_gpu_1.FromPixelsProgram(outShape); + var res = this.compileAndRun(program, [tempPixelArray]); + tempPixelArray.dispose(); + return res; + }; + MathBackendWebGL.prototype.write = function (dataId, values) { + if (values == null) { + throw new Error('MathBackendWebGL.write(): values can not be null'); + } + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var texture = texData.texture, texShape = texData.texShape, usage = texData.usage; + if (texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + texData.texture = null; + texData.texShape = null; + } + texData.usage = tex_util_1.TextureUsage.UPLOAD; + texData.values = values; + if (!this.delayedStorage) { + this.uploadToGPU(dataId); + } + }; + MathBackendWebGL.prototype.readSync = function (dataId) { + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var shape = texData.shape, texture = texData.texture, values = texData.values, texShape = texData.texShape, dtype = texData.dtype; + if (values != null) { + this.cacheOnCPU(dataId); + return values; + } + var shouldTimeProgram = this.activeTimers != null; + var start; + if (shouldTimeProgram) { + start = performance.now(); + } + var float32Values = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape); + if (shouldTimeProgram) { + this.downloadWaitMs += performance.now() - start; + } + this.cacheOnCPU(dataId, float32Values); + return texData.values; + }; + MathBackendWebGL.prototype.read = function (dataId) { + return __awaiter(this, void 0, void 0, function () { + var subscribers_1, texData, shape, texture, values, texShape, dtype, bufferOrTexture, vals, subscribers; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (this.pendingRead.has(dataId)) { + subscribers_1 = this.pendingRead.get(dataId); + return [2, new Promise(function (resolve) { return subscribers_1.push(resolve); })]; + } + this.throwIfNoData(dataId); + texData = this.texData.get(dataId); + shape = texData.shape, texture = texData.texture, values = texData.values, texShape = texData.texShape, dtype = texData.dtype; + if (values != null) { + this.cacheOnCPU(dataId); + return [2, values]; + } + this.pendingRead.set(dataId, []); + if (!environment_1.ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED') && + environment_1.ENV.get('WEBGL_VERSION') === 2) { + throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and " + + "WEBGL_VERSION=2 not yet supported."); + } + bufferOrTexture = this.gpgpu.maybeCreateBufferFromTexture(texture, texShape[0], texShape[1]); + return [4, this.gpgpu.createAndWaitForFence()]; + case 1: + _a.sent(); + if (bufferOrTexture instanceof WebGLTexture) { + vals = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape); + } + else { + vals = this.gpgpu.downloadFloat32MatrixFromBuffer(bufferOrTexture, texShape[0], texShape[1]); + } + this.cacheOnCPU(dataId, vals); + subscribers = this.pendingRead.get(dataId); + this.pendingRead.delete(dataId); + subscribers.forEach(function (resolve) { return resolve(vals); }); + if (this.pendingDisposal.has(dataId)) { + this.pendingDisposal.delete(dataId); + this.disposeData(dataId); + } + return [2, vals]; + } + }); + }); + }; + MathBackendWebGL.prototype.getValuesFromTexture = function (texture, dataId, dtype, texShape, shape) { + if (environment_1.ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED')) { + return this.gpgpu.downloadFloat32MatrixFromOutputTexture(texture, texShape[0], texShape[1]); + } + var tmpTarget = tensor_1.Tensor.make(shape, {}); + this.texData.get(tmpTarget.dataId).usage = tex_util_1.TextureUsage.DOWNLOAD; + var tmpInput = tensor_1.Tensor.make(shape, { dataId: dataId }, dtype); + var program = new encode_float_gpu_1.EncodeFloatProgram(shape); + var pageToCpu = false; + this.compileAndRun(program, [tmpInput], tmpTarget, null, pageToCpu); + var tmpData = this.texData.get(tmpTarget.dataId); + var vals = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(tmpData.texture, tmpData.texShape[0], tmpData.texShape[1]); + tmpInput.dispose(); + tmpTarget.dispose(); + return vals; + }; + MathBackendWebGL.prototype.time = function (f) { + return __awaiter(this, void 0, void 0, function () { + var oldActiveTimers, newActiveTimers, outerMostTime, flattenedActiveTimers, kernelMs, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + oldActiveTimers = this.activeTimers; + newActiveTimers = []; + outerMostTime = false; + if (this.programTimersStack == null) { + this.programTimersStack = newActiveTimers; + outerMostTime = true; + } + else { + this.activeTimers.push(newActiveTimers); + } + this.activeTimers = newActiveTimers; + f(); + flattenedActiveTimers = util.flatten(this.activeTimers); + this.activeTimers = oldActiveTimers; + if (outerMostTime) { + this.programTimersStack = null; + } + return [4, Promise.all(flattenedActiveTimers).then(function (results) { + var sum = 0; + results.forEach(function (result) { return sum += result; }); + return sum; + })]; + case 1: + kernelMs = _a.sent(); + res = { + uploadWaitMs: this.uploadWaitMs, + downloadWaitMs: this.downloadWaitMs, + kernelMs: kernelMs, + wallMs: null + }; + this.uploadWaitMs = 0; + this.downloadWaitMs = 0; + return [2, res]; + } + }); + }); + }; + MathBackendWebGL.prototype.memory = function () { + return { unreliable: false, numBytesInGPU: this.numBytesInGPU }; + }; + MathBackendWebGL.prototype.startTimer = function () { + if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + return this.gpgpu.beginQuery(); + } + return { startMs: performance.now(), endMs: null }; + }; + MathBackendWebGL.prototype.endTimer = function (query) { + if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + this.gpgpu.endQuery(); + return query; + } + query.endMs = performance.now(); + return query; + }; + MathBackendWebGL.prototype.getQueryTime = function (query) { + return __awaiter(this, void 0, void 0, function () { + var timerQuery; + return __generator(this, function (_a) { + if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + return [2, this.gpgpu.waitForQueryAndGetTime(query)]; + } + timerQuery = query; + return [2, timerQuery.endMs - timerQuery.startMs]; + }); + }); + }; + MathBackendWebGL.prototype.disposeData = function (dataId) { + if (this.pendingDisposal.has(dataId)) { + return; + } + if (this.pendingRead.has(dataId)) { + this.pendingDisposal.add(dataId); + return; + } + if (this.texData.has(dataId)) { + var _a = this.texData.get(dataId), texture = _a.texture, texShape = _a.texShape, usage = _a.usage; + if (texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + } + this.texData.delete(dataId); + } + }; + MathBackendWebGL.prototype.getTexture = function (dataId) { + this.uploadToGPU(dataId); + return this.texData.get(dataId).texture; + }; + MathBackendWebGL.prototype.getGPGPUContext = function () { + return this.gpgpu; + }; + MathBackendWebGL.prototype.getCanvas = function () { + return this.canvas; + }; + MathBackendWebGL.prototype.slice = function (x, begin, size) { + var program = new slice_gpu_1.SliceProgram(size); + var customSetup = program.getCustomSetupFunc(begin); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.stridedSlice = function (x, begin, end, strides, beginMask, endMask) { + var _a = slice_util_1.getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask), beginIndex = _a[0], size = _a[1]; + if (size.some(function (axis) { return axis === 0; })) { + return tensor_ops_1.tensor([], size); + } + var program = new strided_slice_gpu_1.StridedSliceProgram(beginIndex, strides, size); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.reverse = function (x, axis) { + var program = new reverse_gpu_1.ReverseProgram(x.shape, axis); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.concat = function (a, b) { + var program = new concat_gpu_1.ConcatProgram(a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.neg = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.NEG); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.matMul = function (a, b, transposeA, transposeB) { + var program = new mulmat_gpu_1.MatMulProgram(a.shape, b.shape, transposeA, transposeB); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.multiply = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.MUL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, types_1.upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.batchNormalization = function (x, mean, variance, varianceEpsilon, scale, offset) { + var inputs = [x, mean, variance]; + var offsetShape = null; + if (offset != null) { + offsetShape = offset.shape; + inputs.push(offset); + } + var scaleShape = null; + if (scale != null) { + scaleShape = scale.shape; + inputs.push(scale); + } + var program = new batchnorm_gpu_1.BatchNormProgram(x.shape, mean.shape, variance.shape, offsetShape, scaleShape, varianceEpsilon); + return this.compileAndRun(program, inputs); + }; + MathBackendWebGL.prototype.localResponseNormalization4D = function (x, radius, bias, alpha, beta) { + var program = new lrn_gpu_1.LRNProgram(x.shape, radius, bias, alpha, beta); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.LRNGrad = function (dy, inputImage, outputImage, depthRadius, bias, alpha, beta) { + var program = new lrn_grad_gpu_1.LRNGradProgram(inputImage.shape, depthRadius, bias, alpha, beta); + return this.compileAndRun(program, [inputImage, outputImage, dy]); + }; + MathBackendWebGL.prototype.tile = function (x, reps) { + var program = new tile_gpu_1.TileProgram(x.shape, reps); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.pad = function (x, paddings, constantValue) { + var program = new pad_gpu_1.PadProgram(x.shape, paddings, constantValue); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.transpose = function (x, perm) { + var program = new transpose_gpu_1.TransposeProgram(x.shape, perm); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.gather = function (x, indices, axis) { + var program = new gather_gpu_1.GatherProgram(x.shape, indices.size, axis); + return this.compileAndRun(program, [x, indices]); + }; + MathBackendWebGL.prototype.batchToSpaceND = function (x, blockShape, crops) { + util.assert(x.rank <= 4, 'batchToSpaceND for rank > 4 with a WebGL backend not implemented yet'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod); + var permuted = array_ops_util.getPermuted(reshaped.length, blockShape.length); + var reshapedPermuted = array_ops_util.getReshapedPermuted(x.shape, blockShape, prod); + var sliceBeginCoords = array_ops_util.getSliceBeginCoords(crops, blockShape.length); + var sliceSize = array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length); + return x.reshape(reshaped) + .transpose(permuted) + .reshape(reshapedPermuted) + .slice(sliceBeginCoords, sliceSize); + }; + MathBackendWebGL.prototype.spaceToBatchND = function (x, blockShape, paddings) { + util.assert(x.rank <= 4, 'spaceToBatchND for rank > 4 with a WebGL backend not implemented yet'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var completePaddings = [[0, 0]]; + completePaddings.push.apply(completePaddings, paddings); + for (var i = 1 + blockShape.length; i < x.shape.length; ++i) { + completePaddings.push([0, 0]); + } + var paddedX = x.pad(completePaddings); + var reshapedPaddedShape = array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false); + var permutedReshapedPaddedPermutation = array_ops_util.getPermuted(reshapedPaddedShape.length, blockShape.length, false); + var flattenShape = array_ops_util.getReshapedPermuted(paddedX.shape, blockShape, prod, false); + return paddedX.reshape(reshapedPaddedShape) + .transpose(permutedReshapedPaddedPermutation) + .reshape(flattenShape); + }; + MathBackendWebGL.prototype.reduce = function (x, reduceType, dtype) { + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + var windowSize = reduce_util.computeOptimalWindowSize(inSize); + var reduceInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize }; + var program = new reduce_gpu_1.ReduceProgram(reduceInfo, reduceType); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], dtype); + this.compileAndRun(program, [x], output); + if (output.shape[1] === 1) { + return output; + } + return this.reduce(output, reduceType, dtype); + }; + MathBackendWebGL.prototype.argReduce = function (x, reduceType, bestIndicesA) { + if (bestIndicesA === void 0) { bestIndicesA = null; } + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + if (bestIndicesA != null) { + batchSize = bestIndicesA.shape[0]; + inSize = bestIndicesA.shape[1]; + } + var windowSize = reduce_util.computeOptimalWindowSize(inSize); + var reduceInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize }; + var program = new argminmax_gpu_1.ArgMinMaxProgram(reduceInfo, reduceType, bestIndicesA == null); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], 'int32'); + var inputs = [x]; + if (bestIndicesA != null) { + inputs.push(bestIndicesA); + } + this.compileAndRun(program, inputs, output); + if (output.shape[1] === 1) { + return output; + } + return this.argReduce(x, reduceType, output); + }; + MathBackendWebGL.prototype.sum = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + var outputDType = types_1.sumOutType(x.dtype); + return this.reduce(a2D, 'sum', outputDType).reshape(outShape); + }; + MathBackendWebGL.prototype.unsortedSegmentSum = function (x, segmentIds, numSegments) { + var axis = 0; + var permutation = axis_util.getAxesPermutation([axis], x.rank); + var permutedX = x; + if (permutation != null) { + permutedX = x.transpose(permutation); + axis = axis_util.getInnerMostAxes(1, x.rank)[0]; + } + var outShape = segment_util.computeOutShape(permutedX.shape, axis, numSegments); + var inSize = util.sizeFromShape([permutedX.shape[axis]]); + var a2D = permutedX.as2D(-1, inSize); + var outputDType = types_1.sumOutType(x.dtype); + var result = this.segOpCompute(a2D, 'unsortedSegmentSum', segmentIds, outputDType, numSegments) + .reshape(outShape); + if (permutation != null) { + result = result.transpose(axis_util.getUndoAxesPermutation(permutation)); + } + return result; + }; + MathBackendWebGL.prototype.segOpCompute = function (x, segOpType, segmentIds, dtype, numSegments) { + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + var windowSize = segment_util.segOpComputeOptimalWindowSize(inSize, numSegments); + var segOpInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize, numSegments: numSegments }; + var program = new segment_gpu_1.SegmentOpProgram(segOpInfo, segOpType); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], dtype); + this.compileAndRun(program, [x, segmentIds], output); + if (output.shape[1] === numSegments) { + return output; + } + segmentIds = tensor_ops_1.range(0, numSegments).tile([inSize / windowSize]); + return this.segOpCompute(output, segOpType, segmentIds, dtype, numSegments); + }; + MathBackendWebGL.prototype.argMin = function (x, axis) { + var axes = [axis]; + axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.argReduce(a2D, 'min').reshape(outShape); + }; + MathBackendWebGL.prototype.argMax = function (x, axis) { + var axes = [axis]; + axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.argReduce(a2D, 'max').reshape(outShape); + }; + MathBackendWebGL.prototype.cumsum = function (x, axis, exclusive, reverse) { + if (axis !== x.rank - 1) { + throw new Error("WebGL cumsum shader expects an inner-most axis=" + (x.rank - 1) + " " + + ("but got axis=" + axis)); + } + var program = new cumsum_gpu_1.CumSumProgram(x.shape, exclusive, reverse); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.equal = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.notEqual = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.NOT_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.less = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.LESS, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.lessEqual = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.LESS_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.greater = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.GREATER, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.greaterEqual = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.GREATER_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.logicalNot = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.LOGICAL_NOT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.logicalAnd = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.LOGICAL_AND, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.logicalOr = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.LOGICAL_OR, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.select = function (condition, a, b) { + var program = new select_gpu_1.SelectProgram(condition.rank, a.shape, a.rank); + var output = this.makeOutputArray(program.outputShape, types_1.upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [condition, a, b], output); + }; + MathBackendWebGL.prototype.where = function (condition) { + log_1.warn('tf.where() in webgl locks the UI thread. ' + + 'Call tf.whereAsync() instead'); + var condVals = condition.dataSync(); + return where_impl_1.whereImpl(condition.shape, condVals); + }; + MathBackendWebGL.prototype.topk = function (x, k, sorted) { + var xVals = x.dataSync(); + return topk_impl_1.topkImpl(xVals, x.shape, x.dtype, k, sorted); + }; + MathBackendWebGL.prototype.min = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('min', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'min', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.minimum = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.MIN, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.mod = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.MOD, a.shape, b.shape); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [a, b], null, customSetup); + }; + MathBackendWebGL.prototype.max = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('max', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'max', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.maximum = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.MAX, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.all = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('all', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'all', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.any = function (x, axes) { + axis_util.assertAxesAreInnerMostDims('any', axes, x.rank); + var _a = axis_util.computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = util.sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'any', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.squaredDifference = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.SQUARED_DIFFERENCE, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.realDivide = function (a, b) { + var op = binaryop_gpu.DIV; + var outputDtype = 'float32'; + var program = new binaryop_gpu_1.BinaryOpProgram(op, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, outputDtype); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.floorDiv = function (a, b) { + var op = binaryop_gpu.INT_DIV; + var outputDtype = 'int32'; + var program = new binaryop_gpu_1.BinaryOpProgram(op, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, outputDtype); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.add = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.ADD, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, types_1.upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.addN = function (tensors) { + var res = tensors[0]; + for (var i = 1; i < tensors.length; i++) { + res = this.add(res, tensors[i]); + } + return res; + }; + MathBackendWebGL.prototype.subtract = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.SUB, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, types_1.upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.pow = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.POW, a.shape, b.shape); + var customSetup = program.getCustomSetupFunc(); + var output = this.makeOutputArray(program.outputShape, types_1.upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output, customSetup); + }; + MathBackendWebGL.prototype.ceil = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.CEIL); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.floor = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.FLOOR); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sign = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SIGN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.round = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ROUND); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.exp = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.EXP); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.expm1 = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.EXPM1); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.log = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.LOG); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.log1p = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.LOG1P); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sqrt = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SQRT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.rsqrt = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.RSQRT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.square = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SQUARE); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.reciprocal = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.RECIPROCAL); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.relu = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.RELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.elu = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.eluDer = function (dy, y) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.ELU_DER, dy.shape, y.shape); + return this.compileAndRun(program, [dy, y]); + }; + MathBackendWebGL.prototype.selu = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.int = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.TO_INT); + var output = this.makeOutputArray(program.outputShape, 'int32'); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.clip = function (x, min, max) { + var program = new clip_gpu_1.ClipProgram(x.shape, min, max); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.abs = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ABS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sigmoid = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SIGMOID); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.softplus = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SOFTPLUS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sin = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SIN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.cos = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.COS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.tan = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.TAN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.asin = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ASIN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.acos = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ACOS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.atan = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ATAN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.atan2 = function (a, b) { + var program = new binaryop_gpu_1.BinaryOpProgram(binaryop_gpu.ATAN2, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.sinh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.SINH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.cosh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.COSH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.tanh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.TANH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.asinh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ASINH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.acosh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ACOSH); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.atanh = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ATANH); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.erf = function (x) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.ERF); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.step = function (x, alpha) { + var program = new unaryop_gpu_1.UnaryOpProgram(x.shape, unary_op.STEP(alpha)); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.conv2d = function (x, filter, convInfo) { + var program = new conv_gpu_1.Conv2DProgram(convInfo); + return this.compileAndRun(program, [x, filter]); + }; + MathBackendWebGL.prototype.conv2dDerInput = function (dy, filter, convInfo) { + var program = new conv_backprop_gpu_1.Conv2DDerInputProgram(convInfo); + return this.compileAndRun(program, [dy, filter]); + }; + MathBackendWebGL.prototype.conv2dDerFilter = function (x, dy, convInfo) { + var program = new conv_backprop_gpu_1.Conv2DDerFilterProgram(convInfo); + return this.compileAndRun(program, [x, dy]); + }; + MathBackendWebGL.prototype.depthwiseConv2D = function (x, filter, convInfo) { + var program = new conv_gpu_depthwise_1.DepthwiseConv2DProgram(convInfo); + return this.compileAndRun(program, [x, filter]); + }; + MathBackendWebGL.prototype.depthwiseConv2DDerInput = function (dy, filter, convInfo) { + var program = new conv_backprop_gpu_depthwise_1.DepthwiseConv2DDerInputProgram(convInfo); + return this.compileAndRun(program, [dy, filter]); + }; + MathBackendWebGL.prototype.depthwiseConv2DDerFilter = function (x, dy, convInfo) { + var program = new conv_backprop_gpu_depthwise_1.DepthwiseConv2DDerFilterProgram(convInfo); + return this.compileAndRun(program, [x, dy]); + }; + MathBackendWebGL.prototype.maxPool = function (x, convInfo) { + var program = new pool_gpu_1.Pool2DProgram(convInfo, 'max', false); + var output = this.makeOutputArray(program.outputShape, x.dtype); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.avgPool = function (x, convInfo) { + var program = new pool_gpu_1.Pool2DProgram(convInfo, 'avg', false); + var output = this.makeOutputArray(program.outputShape, 'float32'); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.maxPoolBackprop = function (dy, x, y, convInfo) { + var getPositions = true; + var maxPoolPositionsProgram = new pool_gpu_1.Pool2DProgram(convInfo, 'max', getPositions); + var maxPoolPositions = this.compileAndRun(maxPoolPositionsProgram, [x]); + var maxPoolBackPropProgram = new max_pool_backprop_gpu_1.MaxPool2DBackpropProgram(convInfo); + var output = this.makeOutputArray(maxPoolBackPropProgram.outputShape, x.dtype); + var result = this.compileAndRun(maxPoolBackPropProgram, [dy, maxPoolPositions], output); + maxPoolPositions.dispose(); + return result; + }; + MathBackendWebGL.prototype.avgPoolBackprop = function (dy, x, convInfo) { + var avgPoolBackpropProgram = new avg_pool_backprop_gpu_1.AvgPool2DBackpropProgram(convInfo); + var output = this.makeOutputArray(avgPoolBackpropProgram.outputShape, x.dtype); + return this.compileAndRun(avgPoolBackpropProgram, [dy], output); + }; + MathBackendWebGL.prototype.cast = function (x, dtype) { + return backend_util.castTensor(x, dtype, this); + }; + MathBackendWebGL.prototype.reshape = function (x, shape) { + return backend_util.reshapeTensor(x, shape); + }; + MathBackendWebGL.prototype.resizeBilinear = function (x, newHeight, newWidth, alignCorners) { + var program = new resize_bilinear_gpu_1.ResizeBilinearProgram(x.shape, newHeight, newWidth, alignCorners); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.resizeBilinearBackprop = function (dy, x, alignCorners) { + var program = new resize_bilinear_backprop_gpu_1.ResizeBilinearBackpropProgram(dy, x, alignCorners); + return this.compileAndRun(program, [dy]); + }; + MathBackendWebGL.prototype.resizeNearestNeighbor = function (x, newHeight, newWidth, alignCorners) { + var program = new resize_nearest_neighbor_gpu_1.ResizeNearestNeighborProgram(x.shape, newHeight, newWidth, alignCorners); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.resizeNearestNeighborBackprop = function (dy, x, alignCorners) { + var program = new resize_nearest_neighbor_backprop_gpu_1.ResizeNearestNeigborBackpropProgram(dy, x, alignCorners); + return this.compileAndRun(program, [dy]); + }; + MathBackendWebGL.prototype.multinomial = function (logits, normalized, numSamples, seed) { + var probs = normalized ? logits : softmax_1.softmax(logits); + var batchSize = probs.shape[0]; + var numOutcomes = probs.shape[1]; + var program = new multinomial_gpu_1.MultinomialProgram(batchSize, numOutcomes, numSamples); + var output = this.makeOutputArray(program.outputShape, 'int32'); + var customSetup = program.getCustomSetupFunc(seed); + return this.compileAndRun(program, [probs], output, customSetup); + }; + MathBackendWebGL.prototype.oneHot = function (indices, depth, onValue, offValue) { + var program = new onehot_gpu_1.OneHotProgram(indices.size, depth, onValue, offValue); + return this.compileAndRun(program, [indices]); + }; + MathBackendWebGL.prototype.nonMaxSuppression = function (boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + log_1.warn('tf.nonMaxSuppression() in webgl locks the UI thread. ' + + 'Call tf.nonMaxSuppressionAsync() instead'); + var boxesVals = boxes.dataSync(); + var scoresVals = scores.dataSync(); + return non_max_suppression_impl_1.nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + }; + MathBackendWebGL.prototype.makeOutputArray = function (shape, dtype) { + return tensor_1.Tensor.make(shape, {}, dtype); + }; + MathBackendWebGL.prototype.compileAndRun = function (program, inputs, output, customSetup, pageToCpu) { + var _this = this; + if (pageToCpu === void 0) { pageToCpu = true; } + if (output == null) { + output = this.makeOutputArray(program.outputShape, inputs[0].dtype); + } + var inputsData = inputs.map(function (tensor) { + var texData = _this.texData.get(tensor.dataId); + if (texData.texture == null && tensor.size <= exports.SIZE_UPLOAD_UNIFORM) { + return { tensor: tensor, texData: null, isUniform: true }; + } + _this.uploadToGPU(tensor.dataId); + return { tensor: tensor, texData: texData, isUniform: false }; + }); + this.uploadToGPU(output.dataId); + var outputData = { + tensor: output, + texData: this.texData.get(output.dataId), + isUniform: false + }; + var key = gpgpu_math.makeShaderKey(program, inputsData, outputData); + var binary = this.getAndSaveBinary(key, function () { + return gpgpu_math.compileProgram(_this.gpgpu, program, inputsData, outputData); + }); + var shouldTimeProgram = this.activeTimers != null; + var query; + if (shouldTimeProgram) { + query = this.startTimer(); + } + gpgpu_math.runProgram(binary, inputsData, outputData, customSetup); + if (pageToCpu && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) { + var numBytesToPage = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING; + while (numBytesToPage > 0 && this.lruDataGPU.length > 0) { + var dataId = this.lruDataGPU.shift(); + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + numBytesToPage -= this.computeBytes(shape, dtype); + this.read(dataId); + } + } + if (shouldTimeProgram) { + query = this.endTimer(query); + this.activeTimers.push(this.getQueryTime(query)); + } + return output; + }; + MathBackendWebGL.prototype.getAndSaveBinary = function (key, getBinary) { + if (!(key in this.binaryCache)) { + this.binaryCache[key] = getBinary(); + } + return this.binaryCache[key]; + }; + MathBackendWebGL.prototype.getTextureManager = function () { + return this.textureManager; + }; + MathBackendWebGL.prototype.dispose = function () { + if (this.disposed) { + return; + } + for (var key in this.binaryCache) { + this.gpgpu.deleteProgram(this.binaryCache[key].webGLProgram); + } + this.textureManager.dispose(); + this.canvas.remove(); + if (this.fromPixelsCanvas != null) { + this.fromPixelsCanvas.remove(); + } + if (this.gpgpuCreatedLocally) { + this.gpgpu.dispose(); + } + this.disposed = true; + }; + MathBackendWebGL.prototype.throwIfNoData = function (dataId) { + if (!this.texData.has(dataId)) { + throw new Error("WebGL backend: No data found for this tensor. " + + "Did you change your backend in the middle of the program? " + + "New backends can't use Tensors created with previous backends"); + } + }; + MathBackendWebGL.prototype.uploadToGPU = function (dataId) { + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var shape = texData.shape, values = texData.values, texture = texData.texture, dtype = texData.dtype, usage = texData.usage; + if (texture != null) { + var index = this.lruDataGPU.indexOf(dataId); + if (index >= 0) { + this.lruDataGPU.splice(this.lruDataGPU.indexOf(dataId), 1); + this.lruDataGPU.push(dataId); + } + return; + } + var shouldTimeProgram = this.activeTimers != null; + var start; + if (shouldTimeProgram) { + start = performance.now(); + } + var texShape = webgl_util.getTextureShapeFromLogicalShape(this.gpgpu.gl, shape); + texData.texShape = texShape; + var newTexture = this.acquireTexture(dataId, texShape, usage); + texData.texture = newTexture; + if (values != null) { + this.gpgpu.uploadMatrixToTexture(newTexture, texShape[0], texShape[1], typedArrayToFloat32(values, dtype)); + texData.values = null; + if (shouldTimeProgram) { + this.uploadWaitMs += performance.now() - start; + } + } + }; + MathBackendWebGL.prototype.cacheOnCPU = function (dataId, float32Values) { + var dontKeepCopyOnGPU = this.delayedStorage; + var texData = this.texData.get(dataId); + var texture = texData.texture, texShape = texData.texShape, dtype = texData.dtype, usage = texData.usage; + if (dontKeepCopyOnGPU && texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + texData.texture = null; + texData.texShape = null; + } + if (float32Values != null) { + texData.values = float32ToTypedArray(float32Values, dtype); + } + }; + MathBackendWebGL.prototype.releaseTexture = function (dataId, texture, texShape, texType) { + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + var idx = this.lruDataGPU.indexOf(dataId); + if (idx >= 0) { + this.lruDataGPU.splice(idx, 1); + } + this.numBytesInGPU -= this.computeBytes(shape, dtype); + this.textureManager.releaseTexture(texture, texShape, texType); + }; + MathBackendWebGL.prototype.acquireTexture = function (dataId, texShape, texType) { + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + this.lruDataGPU.push(dataId); + this.numBytesInGPU += this.computeBytes(shape, dtype); + return this.textureManager.acquireTexture(texShape, texType); + }; + MathBackendWebGL.prototype.computeBytes = function (shape, dtype) { + return util.sizeFromShape(shape) * util.bytesPerElement(dtype); + }; + return MathBackendWebGL; +}()); +exports.MathBackendWebGL = MathBackendWebGL; +if (environment_1.ENV.get('IS_BROWSER')) { + environment_1.ENV.registerBackend('webgl', function () { return new MathBackendWebGL(); }, 2, tensor_1.setTensorTracker); +} +function float32ToTypedArray(a, dtype) { + if (dtype === 'float32') { + return a; + } + else if (dtype === 'int32' || dtype === 'bool') { + var result = (dtype === 'int32') ? new Int32Array(a.length) : + new Uint8Array(a.length); + for (var i = 0; i < result.length; ++i) { + result[i] = Math.round(a[i]); + } + return result; + } + else { + throw new Error("Unknown dtype " + dtype); + } +} +function typedArrayToFloat32(a, dtype) { + return (a instanceof Float32Array) ? a : new Float32Array(a); +} +//# sourceMappingURL=backend_webgl.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js.map new file mode 100644 index 0000000..a63171b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"backend_webgl.js","sourceRoot":"","sources":["../../src/kernels/backend_webgl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js new file mode 100644 index 0000000..d3db8bc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js @@ -0,0 +1,176 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var backend_webgl_1 = require("./backend_webgl"); +jasmine_util_1.describeWithFlags('backendWebGL', test_util_1.WEBGL_ENVS, function () { + var prevBackend; + beforeAll(function () { + prevBackend = tf.getBackend(); + }); + afterEach(function () { + tf.setBackend(prevBackend); + tf.ENV.removeBackend('test-storage'); + }); + it('delayed storage, reading', function () { + var delayedStorage = true; + var backend = new backend_webgl_1.MathBackendWebGL(null, delayedStorage); + tf.ENV.registerBackend('test-storage', function () { return backend; }); + tf.setBackend('test-storage'); + var texManager = backend.getTextureManager(); + var t = tf.Tensor.make([3], {}, 'float32'); + backend.write(t.dataId, new Float32Array([1, 2, 3])); + expect(texManager.getNumUsedTextures()).toBe(0); + backend.getTexture(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(1); + test_util_1.expectArraysClose(backend.readSync(t.dataId), new Float32Array([1, 2, 3])); + expect(texManager.getNumUsedTextures()).toBe(0); + backend.getTexture(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(1); + backend.disposeData(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(0); + }); + it('delayed storage, overwriting', function () { + var delayedStorage = true; + var backend = new backend_webgl_1.MathBackendWebGL(null, delayedStorage); + tf.ENV.registerBackend('test-storage', function () { return backend; }); + tf.setBackend('test-storage'); + var texManager = backend.getTextureManager(); + var t = tf.Tensor.make([3], {}, 'float32'); + backend.write(t.dataId, new Float32Array([1, 2, 3])); + backend.getTexture(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(1); + backend.write(t.dataId, new Float32Array([4, 5, 6])); + expect(texManager.getNumUsedTextures()).toBe(0); + test_util_1.expectArraysClose(backend.readSync(t.dataId), new Float32Array([4, 5, 6])); + backend.getTexture(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(1); + test_util_1.expectArraysClose(backend.readSync(t.dataId), new Float32Array([4, 5, 6])); + expect(texManager.getNumUsedTextures()).toBe(0); + }); + it('immediate storage reading', function () { + var delayedStorage = false; + var backend = new backend_webgl_1.MathBackendWebGL(null, delayedStorage); + tf.ENV.registerBackend('test-storage', function () { return backend; }); + tf.setBackend('test-storage'); + var texManager = backend.getTextureManager(); + var t = tf.Tensor.make([3], {}, 'float32'); + backend.write(t.dataId, new Float32Array([1, 2, 3])); + expect(texManager.getNumUsedTextures()).toBe(1); + test_util_1.expectArraysClose(backend.readSync(t.dataId), new Float32Array([1, 2, 3])); + expect(texManager.getNumUsedTextures()).toBe(1); + backend.disposeData(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(0); + }); + it('immediate storage overwriting', function () { + var delayedStorage = false; + var backend = new backend_webgl_1.MathBackendWebGL(null, delayedStorage); + tf.ENV.registerBackend('test-storage', function () { return backend; }); + tf.setBackend('test-storage'); + var texManager = backend.getTextureManager(); + var t = tf.Tensor.make([3], {}, 'float32'); + backend.write(t.dataId, new Float32Array([1, 2, 3])); + expect(texManager.getNumUsedTextures()).toBe(1); + backend.write(t.dataId, new Float32Array([4, 5, 6])); + expect(texManager.getNumUsedTextures()).toBe(1); + test_util_1.expectArraysClose(backend.readSync(t.dataId), new Float32Array([4, 5, 6])); + expect(texManager.getNumUsedTextures()).toBe(1); + backend.disposeData(t.dataId); + expect(texManager.getNumUsedTextures()).toBe(0); + }); + it('disposal of backend disposes all textures', function () { + var delayedStorage = false; + var backend = new backend_webgl_1.MathBackendWebGL(null, delayedStorage); + var texManager = backend.getTextureManager(); + tf.ENV.registerBackend('test-storage', function () { return backend; }); + tf.setBackend('test-storage'); + var t = tf.Tensor.make([3], {}, 'float32'); + backend.write(t.dataId, new Float32Array([1, 2, 3])); + var t2 = tf.Tensor.make([3], {}, 'float32'); + backend.write(t2.dataId, new Float32Array([4, 5, 6])); + expect(texManager.getNumUsedTextures()).toBe(2); + backend.dispose(); + expect(texManager.getNumUsedTextures()).toBe(0); + }); +}); +jasmine_util_1.describeWithFlags('Custom window size', test_util_1.WEBGL_ENVS, function () { + it('Set screen area to be 1x1', function () { return __awaiter(_this, void 0, void 0, function () { + var oldBackend, a; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + spyOnProperty(window, 'screen', 'get') + .and.returnValue({ height: 1, width: 1 }); + oldBackend = tf.getBackend(); + tf.ENV.registerBackend('custom-webgl', function () { return new backend_webgl_1.MathBackendWebGL(); }); + tf.setBackend('custom-webgl'); + a = tf.ones([100, 100]); + expect(tf.memory().numBytesInGPU).toBe(0); + return [4, a.square().data()]; + case 1: + _a.sent(); + expect(tf.memory().numBytesInGPU).toBe(0); + test_util_1.expectArraysEqual(a, new Float32Array(100 * 100).fill(1)); + tf.setBackend(oldBackend); + tf.ENV.removeBackend('custom-webgl'); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('upload tensors as uniforms', test_util_1.WEBGL_ENVS, function () { + it('small tensor gets uploaded as scalar', function () { + var m = tf.memory(); + expect(m.numBytesInGPU).toBe(0); + var a = tf.zeros([backend_webgl_1.SIZE_UPLOAD_UNIFORM - 1]); + a.square(); + m = tf.memory(); + expect(m.numBytesInGPU).toBe(a.size * 4); + }); + it('large tensor gets uploaded to gpu', function () { + var m = tf.memory(); + expect(m.numBytesInGPU).toBe(0); + var a = tf.zeros([backend_webgl_1.SIZE_UPLOAD_UNIFORM + 1]); + a.square(); + m = tf.memory(); + expect(m.numBytesInGPU).toBe(a.size * 4 * 2); + }); +}); +//# sourceMappingURL=backend_webgl_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js.map new file mode 100644 index 0000000..29f68da --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/backend_webgl_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"backend_webgl_test.js","sourceRoot":"","sources":["../../src/kernels/backend_webgl_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.d.ts new file mode 100644 index 0000000..9a623ab --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.d.ts @@ -0,0 +1,3 @@ +import { Tensor1D } from '../tensor'; +import { TypedArray } from '../types'; +export declare function nonMaxSuppressionImpl(boxes: TypedArray, scores: TypedArray, maxOutputSize: number, iouThreshold: number, scoreThreshold: number): Tensor1D; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js new file mode 100644 index 0000000..77c973e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js @@ -0,0 +1,57 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_ops_1 = require("../ops/tensor_ops"); +function nonMaxSuppressionImpl(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + var candidates = Array.from(scores) + .map(function (score, boxIndex) { return ({ score: score, boxIndex: boxIndex }); }) + .filter(function (c) { return c.score > scoreThreshold; }) + .sort(function (c1, c2) { return c2.score - c1.score; }); + var selected = []; + for (var i = 0; i < candidates.length; i++) { + var _a = candidates[i], score = _a.score, boxIndex = _a.boxIndex; + if (score < scoreThreshold) { + break; + } + var ignoreCandidate = false; + for (var j = selected.length - 1; j >= 0; --j) { + var iou = intersectionOverUnion(boxes, boxIndex, selected[j]); + if (iou >= iouThreshold) { + ignoreCandidate = true; + break; + } + } + if (!ignoreCandidate) { + selected.push(boxIndex); + if (selected.length >= maxOutputSize) { + break; + } + } + } + return tensor_ops_1.tensor1d(selected, 'int32'); +} +exports.nonMaxSuppressionImpl = nonMaxSuppressionImpl; +function intersectionOverUnion(boxes, i, j) { + var iCoord = boxes.subarray(i * 4, i * 4 + 4); + var jCoord = boxes.subarray(j * 4, j * 4 + 4); + var yminI = Math.min(iCoord[0], iCoord[2]); + var xminI = Math.min(iCoord[1], iCoord[3]); + var ymaxI = Math.max(iCoord[0], iCoord[2]); + var xmaxI = Math.max(iCoord[1], iCoord[3]); + var yminJ = Math.min(jCoord[0], jCoord[2]); + var xminJ = Math.min(jCoord[1], jCoord[3]); + var ymaxJ = Math.max(jCoord[0], jCoord[2]); + var xmaxJ = Math.max(jCoord[1], jCoord[3]); + var areaI = (ymaxI - yminI) * (xmaxI - xminI); + var areaJ = (ymaxJ - yminJ) * (xmaxJ - xminJ); + if (areaI <= 0 || areaJ <= 0) { + return 0.0; + } + var intersectionYmin = Math.max(yminI, yminJ); + var intersectionXmin = Math.max(xminI, xminJ); + var intersectionYmax = Math.min(ymaxI, ymaxJ); + var intersectionXmax = Math.min(xmaxI, xmaxJ); + var intersectionArea = Math.max(intersectionYmax - intersectionYmin, 0.0) * + Math.max(intersectionXmax - intersectionXmin, 0.0); + return intersectionArea / (areaI + areaJ - intersectionArea); +} +//# sourceMappingURL=non_max_suppression_impl.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js.map new file mode 100644 index 0000000..621675d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/non_max_suppression_impl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"non_max_suppression_impl.js","sourceRoot":"","sources":["../../src/kernels/non_max_suppression_impl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.d.ts new file mode 100644 index 0000000..1004334 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.d.ts @@ -0,0 +1,3 @@ +import { Tensor } from '../tensor'; +import { DataType, TypedArray } from '../types'; +export declare function topkImpl(x: TypedArray, xShape: number[], xDtype: DataType, k: number, sorted: boolean): [T, T]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js new file mode 100644 index 0000000..4036c1f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_ops_1 = require("../ops/tensor_ops"); +var util_1 = require("../util"); +function topkImpl(x, xShape, xDtype, k, sorted) { + var lastDim = xShape[xShape.length - 1]; + var _a = [x.length / lastDim, lastDim], batch = _a[0], size = _a[1]; + var allTopKVals = util_1.getTypedArrayFromDType(xDtype, batch * k); + var allTopKIndices = util_1.getTypedArrayFromDType('int32', batch * k); + for (var b = 0; b < batch; b++) { + var offset = b * size; + var vals = x.subarray(offset, offset + size); + var valAndInd = []; + for (var i = 0; i < vals.length; i++) { + valAndInd.push({ value: vals[i], index: i }); + } + valAndInd.sort(function (a, b) { return b.value - a.value; }); + var outOffset = b * k; + var topKVals = allTopKVals.subarray(outOffset, outOffset + k); + var topKIndices = allTopKIndices.subarray(outOffset, outOffset + k); + for (var i = 0; i < k; i++) { + topKVals[i] = valAndInd[i].value; + topKIndices[i] = valAndInd[i].index; + } + } + var outputShape = xShape.slice(); + outputShape[outputShape.length - 1] = k; + return [ + tensor_ops_1.tensor(allTopKVals, outputShape, xDtype), + tensor_ops_1.tensor(allTopKIndices, outputShape, 'int32') + ]; +} +exports.topkImpl = topkImpl; +//# sourceMappingURL=topk_impl.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js.map new file mode 100644 index 0000000..1bdceec --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/topk_impl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"topk_impl.js","sourceRoot":"","sources":["../../src/kernels/topk_impl.ts"],"names":[],"mappings":";;AAmBA,gDAAyC;AAGzC,gCAA+C;AAE/C,kBACI,CAAa,EAAE,MAAgB,EAAE,MAAgB,EAAE,CAAS,EAC5D,MAAe;IAEjB,IAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACpC,IAAA,kCAA6C,EAA5C,aAAK,EAAE,YAAI,CAAkC;IACpD,IAAM,WAAW,GAAG,6BAAsB,CAAC,MAAM,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;IAC9D,IAAM,cAAc,GAAG,6BAAsB,CAAC,OAAO,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;IAElE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;QAC9B,IAAM,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC;QACxB,IAAM,IAAI,GAAG,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,CAAC;QAC/C,IAAM,SAAS,GAA0C,EAAE,CAAC;QAC5D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpC,SAAS,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;SAC5C;QACD,SAAS,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,EAAjB,CAAiB,CAAC,CAAC;QAE5C,IAAM,SAAS,GAAG,CAAC,GAAG,CAAC,CAAC;QACxB,IAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,SAAS,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;QAChE,IAAM,WAAW,GAAG,cAAc,CAAC,QAAQ,CAAC,SAAS,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;QACtE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1B,QAAQ,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACjC,WAAW,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;SACrC;KACF;IAGD,IAAM,WAAW,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;IACnC,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACxC,OAAO;QACL,mBAAM,CAAC,WAAW,EAAE,WAAW,EAAE,MAAM,CAAM;QAC7C,mBAAM,CAAC,cAAc,EAAE,WAAW,EAAE,OAAO,CAAM;KAClD,CAAC;AACJ,CAAC;AAlCD,4BAkCC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.d.ts new file mode 100644 index 0000000..298d3fc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.d.ts @@ -0,0 +1,8 @@ +import { ReduceInfo } from '../../ops/reduce_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class ArgMinMaxProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(reduceInfo: ReduceInfo, op: 'max' | 'min', firstPass: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js new file mode 100644 index 0000000..1ff477e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js @@ -0,0 +1,23 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ArgMinMaxProgram = (function () { + function ArgMinMaxProgram(reduceInfo, op, firstPass) { + this.variableNames = ['A']; + var windowSize = reduceInfo.windowSize; + var batchSize = reduceInfo.batchSize; + var inSize = reduceInfo.inSize; + var outSize = Math.ceil(inSize / windowSize); + if (!firstPass) { + this.variableNames.push('bestIndicesA'); + } + this.outputShape = [batchSize, outSize]; + var compOp = (op === 'max') ? '>' : '<'; + var indexSnippet = firstPass ? + 'inOffset + i;' : + 'round(getBestIndicesA(batch, inOffset + i));'; + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + windowSize + ";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < " + windowSize + "; i++) {\n int inIdx = " + indexSnippet + ";\n float candidate = getA(batch, inIdx);\n if (candidate " + compOp + " bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "; + } + return ArgMinMaxProgram; +}()); +exports.ArgMinMaxProgram = ArgMinMaxProgram; +//# sourceMappingURL=argminmax_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js.map new file mode 100644 index 0000000..21d8d6a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/argminmax_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"argminmax_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/argminmax_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,0BAAY,UAAsB,EAAE,EAAe,EAAE,SAAkB;QAJvE,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKpB,IAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;QACzC,IAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC;QACvC,IAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;QACjC,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC;QAC/C,IAAI,CAAC,SAAS,EAAE;YACd,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACzC;QACD,IAAI,CAAC,WAAW,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACxC,IAAM,MAAM,GAAG,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAC1C,IAAM,YAAY,GAAG,SAAS,CAAC,CAAC;YAC5B,eAAe,CAAC,CAAC;YACjB,8CAA8C,CAAC;QAEnD,IAAI,CAAC,QAAQ,GAAG,wKAKc,UAAU,yHAKd,UAAU,wCAChB,YAAY,oFAEV,MAAM,mKAO3B,CAAC;IACJ,CAAC;IACH,uBAAC;AAAD,CAAC,AAzCD,IAyCC;AAzCY,4CAAgB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.d.ts new file mode 100644 index 0000000..d419ff6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.d.ts @@ -0,0 +1,8 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class AvgPool2DBackpropProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js new file mode 100644 index 0000000..fa92982 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js @@ -0,0 +1,19 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var AvgPool2DBackpropProgram = (function () { + function AvgPool2DBackpropProgram(convInfo) { + this.variableNames = ['dy']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var avgMultiplier = 1 / (filterHeight * filterWidth); + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n const float avgMultiplier = float(" + avgMultiplier + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return AvgPool2DBackpropProgram; +}()); +exports.AvgPool2DBackpropProgram = AvgPool2DBackpropProgram; +//# sourceMappingURL=avg_pool_backprop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js.map new file mode 100644 index 0000000..b8ce2db --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/avg_pool_backprop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"avg_pool_backprop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/avg_pool_backprop_gpu.ts"],"names":[],"mappings":";;AAqBA;IAKE,kCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,IAAI,CAAC,CAAC;QAKrB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC;QACpC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAEzC,IAAM,MAAM,GAAG,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACvD,IAAM,OAAO,GAAG,WAAW,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QAExD,IAAM,aAAa,GAAG,CAAC,GAAG,CAAC,YAAY,GAAG,WAAW,CAAC,CAAC;QAEvD,IAAI,CAAC,QAAQ,GAAG,sCACa,MAAM,UAAK,OAAO,oDACT,aAAa,sdAcvB,YAAY,iEACI,YAAY,iDAExB,QAAQ,CAAC,SAAS,yIAKpB,WAAW,mEACK,WAAW,mDAEvB,QAAQ,CAAC,QAAQ,wSAalD,CAAC;IACJ,CAAC;IACH,+BAAC;AAAD,CAAC,AA3DD,IA2DC;AA3DY,4DAAwB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.d.ts new file mode 100644 index 0000000..b2de35a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class BatchNormProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + supportsBroadcasting: boolean; + constructor(xShape: number[], meanShape: number[], varianceShape: number[], offsetShape: number[] | null, scaleShape: number[] | null, varianceEpsilon: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js new file mode 100644 index 0000000..576c294 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js @@ -0,0 +1,29 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var broadcast_util = require("../../ops/broadcast_util"); +var BatchNormProgram = (function () { + function BatchNormProgram(xShape, meanShape, varianceShape, offsetShape, scaleShape, varianceEpsilon) { + this.outputShape = []; + this.supportsBroadcasting = true; + this.variableNames = ['x', 'mean', 'variance']; + broadcast_util.assertAndGetBroadcastShape(xShape, meanShape); + broadcast_util.assertAndGetBroadcastShape(xShape, varianceShape); + var offsetSnippet = '0.0'; + if (offsetShape != null) { + broadcast_util.assertAndGetBroadcastShape(xShape, offsetShape); + this.variableNames.push('offset'); + offsetSnippet = 'getOffsetAtOutCoords()'; + } + var scaleSnippet = '1.0'; + if (scaleShape != null) { + broadcast_util.assertAndGetBroadcastShape(xShape, scaleShape); + this.variableNames.push('scale'); + scaleSnippet = 'getScaleAtOutCoords()'; + } + this.outputShape = xShape; + this.userCode = "\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = " + offsetSnippet + ";\n float scale = " + scaleSnippet + ";\n float inv = scale * inversesqrt(variance + float(" + varianceEpsilon + "));\n setOutput((x - mean) * inv + offset);\n }\n "; + } + return BatchNormProgram; +}()); +exports.BatchNormProgram = BatchNormProgram; +//# sourceMappingURL=batchnorm_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js.map new file mode 100644 index 0000000..81f3efe --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/batchnorm_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"batchnorm_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/batchnorm_gpu.ts"],"names":[],"mappings":";;AAiBA,yDAA2D;AAG3D;IAME,0BACI,MAAgB,EAAE,SAAmB,EAAE,aAAuB,EAC9D,WAA0B,EAAE,UAAyB,EACrD,eAAuB;QAP3B,gBAAW,GAAa,EAAE,CAAC;QAE3B,yBAAoB,GAAG,IAAI,CAAC;QAM1B,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC/C,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC7D,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QAEjE,IAAI,aAAa,GAAG,KAAK,CAAC;QAC1B,IAAI,WAAW,IAAI,IAAI,EAAE;YACvB,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;YAC/D,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAClC,aAAa,GAAG,wBAAwB,CAAC;SAC1C;QAED,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;YAC9D,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACjC,YAAY,GAAG,uBAAuB,CAAC;SACxC;QAED,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,yLAKK,aAAa,iCACd,YAAY,oEACuB,eAAe,sEAGrE,CAAC;IACJ,CAAC;IACH,uBAAC;AAAD,CAAC,AAzCD,IAyCC;AAzCY,4CAAgB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.d.ts new file mode 100644 index 0000000..b7b111c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.d.ts @@ -0,0 +1,31 @@ +import { GPGPUContext } from './gpgpu_context'; +import { GPGPUProgram } from './gpgpu_math'; +export declare const ADD = "return a + b;"; +export declare const SUB = "return a - b;"; +export declare const MUL = "return a * b;"; +export declare const DIV = "if (a == b) return 1.0;\n return a / b;"; +export declare const INT_DIV = "\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n"; +export declare const POW = "\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n"; +export declare const SQUARED_DIFFERENCE = "return (a - b) * (a - b);"; +export declare const EQUAL = "return float(a == b);"; +export declare const NOT_EQUAL = "return float(a != b);"; +export declare const LESS = "return float(a < b);"; +export declare const LESS_EQUAL = "return float(a <= b);"; +export declare const GREATER = "return float(a > b);"; +export declare const GREATER_EQUAL = "return float(a >= b);"; +export declare const LOGICAL_AND = "return float(a >= 1.0 && b >= 1.0);"; +export declare const LOGICAL_OR = "return float(a >= 1.0 || b >= 1.0);"; +export declare const MAX: string; +export declare const MIN: string; +export declare const MOD = "if (b == 0.0) return NAN;\n return mod(a, b);"; +export declare const ATAN2: string; +export declare const ELU_DER = "return (b >= 1.0) ? a : a * (b + 1.0);"; +export declare class BinaryOpProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + supportsBroadcasting: boolean; + startLoc: WebGLUniformLocation; + constructor(op: string, aShape: number[], bShape: number[]); + getCustomSetupFunc(): (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js new file mode 100644 index 0000000..fbacce4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js @@ -0,0 +1,48 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var broadcast_util = require("../../ops/broadcast_util"); +var CHECK_NAN_SNIPPET = "\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n"; +exports.ADD = 'return a + b;'; +exports.SUB = 'return a - b;'; +exports.MUL = 'return a * b;'; +exports.DIV = "if (a == b) return 1.0;\n return a / b;"; +exports.INT_DIV = "\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n"; +exports.POW = "\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n"; +exports.SQUARED_DIFFERENCE = 'return (a - b) * (a - b);'; +exports.EQUAL = "return float(a == b);"; +exports.NOT_EQUAL = "return float(a != b);"; +exports.LESS = "return float(a < b);"; +exports.LESS_EQUAL = "return float(a <= b);"; +exports.GREATER = "return float(a > b);"; +exports.GREATER_EQUAL = "return float(a >= b);"; +exports.LOGICAL_AND = "return float(a >= 1.0 && b >= 1.0);"; +exports.LOGICAL_OR = "return float(a >= 1.0 || b >= 1.0);"; +exports.MAX = CHECK_NAN_SNIPPET + "\n return max(a, b);\n"; +exports.MIN = CHECK_NAN_SNIPPET + "\n return min(a, b);\n"; +exports.MOD = "if (b == 0.0) return NAN;\n return mod(a, b);"; +exports.ATAN2 = CHECK_NAN_SNIPPET + "\n return atan(a, b);\n"; +exports.ELU_DER = "return (b >= 1.0) ? a : a * (b + 1.0);"; +var BinaryOpProgram = (function () { + function BinaryOpProgram(op, aShape, bShape) { + this.variableNames = ['A', 'B']; + this.supportsBroadcasting = true; + this.outputShape = + broadcast_util.assertAndGetBroadcastShape(aShape, bShape); + this.userCode = "\n uniform float NAN;\n float binaryOperation(float a, float b) {\n " + op + "\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "; + } + BinaryOpProgram.prototype.getCustomSetupFunc = function () { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN'); + if (_this.startLoc == null) { + return; + } + } + gpgpu.gl.uniform1f(_this.startLoc, NaN); + }; + }; + return BinaryOpProgram; +}()); +exports.BinaryOpProgram = BinaryOpProgram; +//# sourceMappingURL=binaryop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js.map new file mode 100644 index 0000000..63fd68f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/binaryop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"binaryop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/binaryop_gpu.ts"],"names":[],"mappings":";;AAiBA,yDAA2D;AAK3D,IAAM,iBAAiB,GAAG,0DAGzB,CAAC;AAEW,QAAA,GAAG,GAAG,eAAe,CAAC;AACtB,QAAA,GAAG,GAAG,eAAe,CAAC;AACtB,QAAA,GAAG,GAAG,eAAe,CAAC;AACtB,QAAA,GAAG,GAAG,0CACH,CAAC;AAMJ,QAAA,OAAO,GAAG,8OAWtB,CAAC;AAEW,QAAA,GAAG,GAAG,mKAMlB,CAAC;AACW,QAAA,kBAAkB,GAAG,2BAA2B,CAAC;AAEjD,QAAA,KAAK,GAAG,uBAAuB,CAAC;AAEhC,QAAA,SAAS,GAAG,uBAAuB,CAAC;AAEpC,QAAA,IAAI,GAAG,sBAAsB,CAAC;AAE9B,QAAA,UAAU,GAAG,uBAAuB,CAAC;AAErC,QAAA,OAAO,GAAG,sBAAsB,CAAC;AAEjC,QAAA,aAAa,GAAG,uBAAuB,CAAC;AAExC,QAAA,WAAW,GAAG,qCAAqC,CAAC;AAEpD,QAAA,UAAU,GAAG,qCAAqC,CAAC;AAEnD,QAAA,GAAG,GAAG,iBAAiB,GAAG,yBAEtC,CAAC;AACW,QAAA,GAAG,GAAG,iBAAiB,GAAG,yBAEtC,CAAC;AACW,QAAA,GAAG,GAAG,gDACC,CAAC;AAER,QAAA,KAAK,GAAG,iBAAiB,GAAG,0BAExC,CAAC;AAEW,QAAA,OAAO,GAAG,wCAAwC,CAAC;AAEhE;IASE,yBAAY,EAAU,EAAE,MAAgB,EAAE,MAAgB;QAR1D,kBAAa,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAG3B,yBAAoB,GAAG,IAAI,CAAC;QAM1B,IAAI,CAAC,WAAW;YACZ,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,GAAG,0FAGV,EAAE,2KAQP,CAAC;IACJ,CAAC;IAED,4CAAkB,GAAlB;QAAA,iBAYC;QAXC,OAAO,UAAC,KAAmB,EAAE,YAA0B;YACrD,IAAI,KAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;gBACzB,KAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,yBAAyB,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;gBACrE,IAAI,KAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;oBAGzB,OAAO;iBACR;aACF;YACD,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACzC,CAAC,CAAC;IACJ,CAAC;IACH,sBAAC;AAAD,CAAC,AAvCD,IAuCC;AAvCY,0CAAe"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.d.ts new file mode 100644 index 0000000..b1ff28b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class ClipProgram implements GPGPUProgram { + variableNames: string[]; + userCode: string; + outputShape: number[]; + constructor(aShape: number[], min: number, max: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js new file mode 100644 index 0000000..6d8134c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js @@ -0,0 +1,14 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ClipProgram = (function () { + function ClipProgram(aShape, min, max) { + this.variableNames = ['A']; + this.outputShape = aShape; + var minFixed = min.toFixed(20); + var maxFixed = max.toFixed(20); + this.userCode = "\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, " + minFixed + ", " + maxFixed + "));\n }\n "; + } + return ClipProgram; +}()); +exports.ClipProgram = ClipProgram; +//# sourceMappingURL=clip_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js.map new file mode 100644 index 0000000..1586d49 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/clip_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"clip_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/clip_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,qBAAY,MAAgB,EAAE,GAAW,EAAE,GAAW;QAJtD,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKpB,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAC1B,IAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjC,IAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,+LAQa,QAAQ,UAAK,QAAQ,uBAEjD,CAAC;IACJ,CAAC;IACH,kBAAC;AAAD,CAAC,AArBD,IAqBC;AArBY,kCAAW"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.d.ts new file mode 100644 index 0000000..aa8a095 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class ConcatProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(aShape: [number, number], bShape: [number, number]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js new file mode 100644 index 0000000..f75d8c2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js @@ -0,0 +1,15 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var concat_util = require("../../ops/concat_util"); +var ConcatProgram = (function () { + function ConcatProgram(aShape, bShape) { + this.variableNames = ['A', 'B']; + this.outputShape = []; + this.outputShape = + concat_util.computeOutShape(aShape, bShape, 1); + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < " + aShape[1] + ") {\n value = getA(yR, yC);\n } else {\n yC -= " + aShape[1] + ";\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n "; + } + return ConcatProgram; +}()); +exports.ConcatProgram = ConcatProgram; +//# sourceMappingURL=concat_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js.map new file mode 100644 index 0000000..dc99d20 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/concat_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"concat_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/concat_gpu.ts"],"names":[],"mappings":";;AAiBA,mDAAqD;AAGrD;IAME,uBAAY,MAAwB,EAAE,MAAwB;QAL9D,kBAAa,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC3B,gBAAW,GAAa,EAAE,CAAC;QAKzB,IAAI,CAAC,WAAW;YACZ,WAAW,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAY,CAAC;QAE9D,IAAI,CAAC,QAAQ,GAAG,8KAOD,MAAM,CAAC,CAAC,CAAC,gFAGV,MAAM,CAAC,CAAC,CAAC,8FAMtB,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AA5BD,IA4BC;AA5BY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.d.ts new file mode 100644 index 0000000..e2c2c52 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.d.ts @@ -0,0 +1,14 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class Conv2DDerFilterProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} +export declare class Conv2DDerInputProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js new file mode 100644 index 0000000..5d9b4ad --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js @@ -0,0 +1,31 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Conv2DDerFilterProgram = (function () { + function Conv2DDerFilterProgram(convInfo) { + this.variableNames = ['x', 'dy']; + this.outputShape = convInfo.filterShape; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < " + convInfo.batchSize + "; b++) {\n for (int yR = 0; yR < " + convInfo.outHeight + "; yR++) {\n int xR = wR + yR * " + strideHeight + " - " + padTop + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + convInfo.outWidth + "; yC++) {\n int xC = wC + yC * " + strideWidth + " - " + padLeft + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DDerFilterProgram; +}()); +exports.Conv2DDerFilterProgram = Conv2DDerFilterProgram; +var Conv2DDerInputProgram = (function () { + function Conv2DDerInputProgram(convInfo) { + this.variableNames = ['dy', 'W']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + filterHeight + " - 1 - wR;\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + filterWidth + " - 1 - wC;\n\n for (int d2 = 0; d2 < " + convInfo.outChannels + "; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DDerInputProgram; +}()); +exports.Conv2DDerInputProgram = Conv2DDerInputProgram; +//# sourceMappingURL=conv_backprop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js.map new file mode 100644 index 0000000..6509884 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_backprop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/conv_backprop_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,gCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAK1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAExC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QAEtC,IAAI,CAAC,QAAQ,GAAG,yYAYU,QAAQ,CAAC,SAAS,kDACd,QAAQ,CAAC,SAAS,kDACnB,YAAY,WAAM,MAAM,6CAEvB,QAAQ,CAAC,QAAQ,yFAIf,QAAQ,CAAC,QAAQ,oDAClB,WAAW,WAAM,OAAO,+CAEvB,QAAQ,CAAC,OAAO,+RAY/C,CAAC;IACJ,CAAC;IACH,6BAAC;AAAD,CAAC,AAlDD,IAkDC;AAlDY,wDAAsB;AAoDnC;IAKE,+BAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAK1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC;QAEpC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAEzC,IAAM,MAAM,GAAG,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACvD,IAAM,OAAO,GAAG,WAAW,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QAExD,IAAI,CAAC,QAAQ,GAAG,sCACa,MAAM,UAAK,OAAO,ydAcnB,YAAY,iEACI,YAAY,iDAExB,QAAQ,CAAC,SAAS,gIAK7B,YAAY,sDAEH,WAAW,mEACK,WAAW,mDAEvB,QAAQ,CAAC,QAAQ,yJAM5B,WAAW,wDAEF,QAAQ,CAAC,WAAW,oQASnD,CAAC;IACJ,CAAC;IACH,4BAAC;AAAD,CAAC,AA/DD,IA+DC;AA/DY,sDAAqB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.d.ts new file mode 100644 index 0000000..4a0ab6e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.d.ts @@ -0,0 +1,14 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class DepthwiseConv2DDerFilterProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} +export declare class DepthwiseConv2DDerInputProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js new file mode 100644 index 0000000..47cb27e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var DepthwiseConv2DDerFilterProgram = (function () { + function DepthwiseConv2DDerFilterProgram(convInfo) { + this.variableNames = ['x', 'dy']; + this.outputShape = convInfo.filterShape; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * " + channelMul + " + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < " + convInfo.batchSize + "; b++) {\n for (int yR = 0; yR < " + convInfo.outHeight + "; yR++) {\n int xR = wR + yR * " + strideHeight + " - " + padTop + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + convInfo.outWidth + "; yC++) {\n int xC = wC + yC * " + strideWidth + " - " + padLeft + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DDerFilterProgram; +}()); +exports.DepthwiseConv2DDerFilterProgram = DepthwiseConv2DDerFilterProgram; +var DepthwiseConv2DDerInputProgram = (function () { + function DepthwiseConv2DDerInputProgram(convInfo) { + this.variableNames = ['dy', 'W']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + filterHeight + " - 1 - wR;\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + filterWidth + " - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < " + channelMul + "; dm++) {\n int d2 = d1 * " + channelMul + " + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DDerInputProgram; +}()); +exports.DepthwiseConv2DDerInputProgram = DepthwiseConv2DDerInputProgram; +//# sourceMappingURL=conv_backprop_gpu_depthwise.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js.map new file mode 100644 index 0000000..d82a2a9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_backprop_gpu_depthwise.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_backprop_gpu_depthwise.js","sourceRoot":"","sources":["../../../src/kernels/webgl/conv_backprop_gpu_depthwise.ts"],"names":[],"mappings":";;AAoBA;IAKE,yCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAK1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAExC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QACtC,IAAM,UAAU,GAAG,QAAQ,CAAC,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC;QAE9D,IAAI,CAAC,QAAQ,GAAG,6MAOI,UAAU,yHAKJ,QAAQ,CAAC,SAAS,kDACd,QAAQ,CAAC,SAAS,kDACnB,YAAY,WAAM,MAAM,6CAEvB,QAAQ,CAAC,QAAQ,yFAIf,QAAQ,CAAC,QAAQ,oDAClB,WAAW,WAAM,OAAO,+CAEvB,QAAQ,CAAC,OAAO,+RAY/C,CAAC;IACJ,CAAC;IACH,sCAAC;AAAD,CAAC,AAnDD,IAmDC;AAnDY,0EAA+B;AAqD5C;IAKE,wCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAK1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC;QAEpC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAEzC,IAAM,MAAM,GAAG,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACvD,IAAM,OAAO,GAAG,WAAW,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QACxD,IAAM,UAAU,GAAG,QAAQ,CAAC,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC;QAE9D,IAAI,CAAC,QAAQ,GAAG,sCACa,MAAM,UAAK,OAAO,iUAYnB,YAAY,iEACI,YAAY,iDAExB,QAAQ,CAAC,SAAS,gIAK7B,YAAY,sDAEH,WAAW,mEACK,WAAW,mDAEvB,QAAQ,CAAC,QAAQ,yJAM5B,WAAW,uGAGF,UAAU,+CAChB,UAAU,iQASnC,CAAC;IACJ,CAAC;IACH,qCAAC;AAAD,CAAC,AAhED,IAgEC;AAhEY,wEAA8B"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.d.ts new file mode 100644 index 0000000..4e4cbbe --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.d.ts @@ -0,0 +1,8 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class Conv2DProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js new file mode 100644 index 0000000..0ce1246 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Conv2DProgram = (function () { + function Conv2DProgram(convInfo) { + this.variableNames = ['x', 'W']; + this.outputShape = convInfo.outShape; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var inputDepthNearestVec4 = Math.floor(convInfo.inChannels / 4) * 4; + var inputDepthVec4Remainder = convInfo.inChannels % 4; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR * " + dilationHeight + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC * " + dilationWidth + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n for (int d1 = 0; d1 < " + inputDepthNearestVec4 + "; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (" + (inputDepthVec4Remainder === 1) + ") {\n dotProd +=\n getX(batch, xR, xC, " + inputDepthNearestVec4 + ") *\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2);\n } else if (" + (inputDepthVec4Remainder === 2) + ") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, " + inputDepthNearestVec4 + "),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (" + (inputDepthVec4Remainder === 3) + ") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, " + inputDepthNearestVec4 + "),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 1),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 1, d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DProgram; +}()); +exports.Conv2DProgram = Conv2DProgram; +//# sourceMappingURL=conv_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js.map new file mode 100644 index 0000000..35e583f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/conv_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,uBAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAKzB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,QAAQ,CAAC;QACrC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QACtC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC;QAC/C,IAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;QAC7C,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAEzC,IAAM,qBAAqB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QACtE,IAAM,uBAAuB,GAAG,QAAQ,CAAC,UAAU,GAAG,CAAC,CAAC;QAExD,IAAI,CAAC,QAAQ,GAAG,yCACgB,YAAY,UAAK,WAAW,2CAC/B,MAAM,UAAK,OAAO,8dAcnB,YAAY,sDACP,cAAc,2CAEnB,QAAQ,CAAC,QAAQ,mFAIf,WAAW,wDACN,aAAa,6CAElB,QAAQ,CAAC,OAAO,yFAId,qBAAqB,ijBAiBvC,uBAAuB,KAAK,CAAC,4EAET,qBAAqB,0CAC5B,qBAAqB,wCAC3B,uBAAuB,KAAK,CAAC,sFAEhB,qBAAqB,gDACrB,qBAAqB,kGAG5B,qBAAqB,6CACrB,qBAAqB,8GAG3B,uBAAuB,KAAK,CAAC,sFAEhB,qBAAqB,gDACrB,qBAAqB,oDACrB,qBAAqB,kGAG5B,qBAAqB,6CACrB,qBAAqB,iDACrB,qBAAqB,oKAQ/C,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AAnGD,IAmGC;AAnGY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.d.ts new file mode 100644 index 0000000..8efdb62 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.d.ts @@ -0,0 +1,8 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class DepthwiseConv2DProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js new file mode 100644 index 0000000..1ffb6c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js @@ -0,0 +1,23 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var DepthwiseConv2DProgram = (function () { + function DepthwiseConv2DProgram(convInfo) { + this.variableNames = ['x', 'W']; + this.outputShape = convInfo.outShape; + var xNumRows = convInfo.inHeight; + var xNumCols = convInfo.inWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / " + channelMul + ";\n int q = d2 - d1 * " + channelMul + ";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR * " + dilationHeight + ";\n\n if (xR < 0 || xR >= " + xNumRows + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC * " + dilationWidth + ";\n\n if (xC < 0 || xC >= " + xNumCols + ") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DProgram; +}()); +exports.DepthwiseConv2DProgram = DepthwiseConv2DProgram; +//# sourceMappingURL=conv_gpu_depthwise.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js.map new file mode 100644 index 0000000..d63f2f0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/conv_gpu_depthwise.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_gpu_depthwise.js","sourceRoot":"","sources":["../../../src/kernels/webgl/conv_gpu_depthwise.ts"],"names":[],"mappings":";;AAoBA;IAKE,gCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAKzB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,QAAQ,CAAC;QAErC,IAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;QACnC,IAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;QAClC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QACtC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC;QAC/C,IAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;QAC7C,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,UAAU,GAAG,QAAQ,CAAC,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC;QAE9D,IAAI,CAAC,QAAQ,GAAG,yCACgB,YAAY,UAAK,WAAW,2CAC/B,MAAM,UAAK,OAAO,sNAO3B,UAAU,qCACN,UAAU,qXASN,YAAY,sDACP,cAAc,2CAEnB,QAAQ,mFAIN,WAAW,wDACN,aAAa,6CAElB,QAAQ,6PAWrC,CAAC;IACJ,CAAC;IACH,6BAAC;AAAD,CAAC,AA9DD,IA8DC;AA9DY,wDAAsB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.d.ts new file mode 100644 index 0000000..f708f96 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class CumSumProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(shape: number[], exclusive: boolean, reverse: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js new file mode 100644 index 0000000..9ca0f0f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js @@ -0,0 +1,50 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var CumSumProgram = (function () { + function CumSumProgram(shape, exclusive, reverse) { + this.variableNames = ['x']; + this.outputShape = shape; + var rank = shape.length; + var finalDim = shape[shape.length - 1]; + var comparator = reverse ? '<' : '>'; + this.userCode = "\n int getIndex(int i) {\n " + (reverse ? "return " + finalDim + " -i - 1;" : 'return i;') + "\n }\n\n void main() {\n " + shader_compiler_1.getCoordsDataType(rank) + " coords = getOutputCoords();\n int end = " + getFinalCoord(rank, 'coords') + ";\n float val = 0.0;\n for (int i = " + finalDim + " - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx " + comparator + " end) {\n continue;\n }\n if (idx == end && " + exclusive + ") {\n continue;\n }\n " + getFinalCoord(rank, 'coords') + " = idx;\n val += getX(" + getCoords(rank, 'coords') + ");\n }\n setOutput(val);\n }\n "; + } + return CumSumProgram; +}()); +exports.CumSumProgram = CumSumProgram; +function getCoords(rank, name) { + if (rank === 1) { + return "" + name; + } + else if (rank === 2) { + return name + ".x, " + name + ".y"; + } + else if (rank === 3) { + return name + ".x, " + name + ".y, " + name + ".z"; + } + else if (rank === 4) { + return name + ".x, " + name + ".y, " + name + ".z, " + name + ".w"; + } + else { + throw Error("Cumulative sum for rank " + rank + " is not yet supported"); + } +} +function getFinalCoord(rank, name) { + if (rank === 1) { + return "" + name; + } + else if (rank === 2) { + return name + ".y"; + } + else if (rank === 3) { + return name + ".z"; + } + else if (rank === 4) { + return name + ".w"; + } + else { + throw Error("Cumulative sum for rank " + rank + " is not yet supported"); + } +} +//# sourceMappingURL=cumsum_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js.map new file mode 100644 index 0000000..d056393 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/cumsum_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"cumsum_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/cumsum_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAKE,uBAAY,KAAe,EAAE,SAAkB,EAAE,OAAgB;QAJjE,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKpB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC;QAC1B,IAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACzC,IAAM,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAEvC,IAAI,CAAC,QAAQ,GAAG,6CAEV,OAAO,CAAC,CAAC,CAAC,YAAU,QAAQ,aAAU,CAAC,CAAC,CAAC,WAAW,mDAIpD,mCAAiB,CAAC,IAAI,CAAC,wDACb,aAAa,CAAC,IAAI,EAAE,QAAQ,CAAC,0DAE1B,QAAQ,qFAEX,UAAU,iFAGA,SAAS,2DAG3B,aAAa,CAAC,IAAI,EAAE,QAAQ,CAAC,uCACjB,SAAS,CAAC,IAAI,EAAE,QAAQ,CAAC,0DAI5C,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AAnCD,IAmCC;AAnCY,sCAAa;AAqC1B,mBAAmB,IAAY,EAAE,IAAY;IAC3C,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,OAAO,KAAG,IAAM,CAAC;KAClB;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,YAAO,IAAI,OAAI,CAAC;KAC/B;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,YAAO,IAAI,YAAO,IAAI,OAAI,CAAC;KAC1C;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,YAAO,IAAI,YAAO,IAAI,YAAO,IAAI,OAAI,CAAC;KACrD;SAAM;QACL,MAAM,KAAK,CAAC,6BAA2B,IAAI,0BAAuB,CAAC,CAAC;KACrE;AACH,CAAC;AAED,uBAAuB,IAAY,EAAE,IAAY;IAC/C,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,OAAO,KAAG,IAAM,CAAC;KAClB;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,OAAI,CAAC;KACpB;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,OAAI,CAAC;KACpB;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAU,IAAI,OAAI,CAAC;KACpB;SAAM;QACL,MAAM,KAAK,CAAC,6BAA2B,IAAI,0BAAuB,CAAC,CAAC;KACrE;AACH,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.d.ts new file mode 100644 index 0000000..54b72fc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class EncodeFloatProgram implements GPGPUProgram { + variableNames: string[]; + userCode: string; + outputShape: number[]; + constructor(outputShape: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js new file mode 100644 index 0000000..9f724b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js @@ -0,0 +1,12 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var EncodeFloatProgram = (function () { + function EncodeFloatProgram(outputShape) { + this.variableNames = ['A']; + this.outputShape = outputShape; + this.userCode = "\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "; + } + return EncodeFloatProgram; +}()); +exports.EncodeFloatProgram = EncodeFloatProgram; +//# sourceMappingURL=encode_float_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js.map new file mode 100644 index 0000000..0f4b518 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/encode_float_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"encode_float_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/encode_float_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,4BAAY,WAAqB;QAJjC,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKpB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,gqCA4Cf,CAAC;IACJ,CAAC;IACH,yBAAC;AAAD,CAAC,AArDD,IAqDC;AArDY,gDAAkB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.d.ts new file mode 100644 index 0000000..1cfba93 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class FromPixelsProgram implements GPGPUProgram { + variableNames: string[]; + userCode: string; + outputShape: number[]; + constructor(outputShape: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js new file mode 100644 index 0000000..e0c8a20 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js @@ -0,0 +1,13 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var FromPixelsProgram = (function () { + function FromPixelsProgram(outputShape) { + this.variableNames = ['A']; + var height = outputShape[0], width = outputShape[1]; + this.outputShape = outputShape; + this.userCode = "\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + width + ".0, " + height + ".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "; + } + return FromPixelsProgram; +}()); +exports.FromPixelsProgram = FromPixelsProgram; +//# sourceMappingURL=from_pixels_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js.map new file mode 100644 index 0000000..eedb16e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/from_pixels_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"from_pixels_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/from_pixels_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,2BAAY,WAAqB;QAJjC,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKb,IAAA,uBAAM,EAAE,sBAAK,CAAkB;QACtC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,0NAMmC,KAAK,YAAO,MAAM,2YAgBpE,CAAC;IACJ,CAAC;IACH,wBAAC;AAAD,CAAC,AAhCD,IAgCC;AAhCY,8CAAiB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.d.ts new file mode 100644 index 0000000..5ca9d41 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class GatherProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + rank: number; + constructor(aShape: number[], indicesLength: number, axis: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js new file mode 100644 index 0000000..2d70034 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js @@ -0,0 +1,38 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var GatherProgram = (function () { + function GatherProgram(aShape, indicesLength, axis) { + this.variableNames = ['A', 'indices']; + var outputShape = aShape.slice(); + outputShape[axis] = indicesLength; + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = shader_compiler_1.getCoordsDataType(this.rank); + var sourceCoords = getSourceCoords(aShape, axis); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + sourceCoords + "));\n }\n "; + } + return GatherProgram; +}()); +exports.GatherProgram = GatherProgram; +function getSourceCoords(aShape, axis) { + var rank = aShape.length; + if (rank > 4) { + throw Error("Gather for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + return "int(getIndices(resRC))"; + } + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w']; + var sourceCoords = []; + for (var i = 0; i < aShape.length; i++) { + if (i === axis) { + sourceCoords.push("int(getIndices(" + currentCoords[i] + "))"); + } + else { + sourceCoords.push("" + currentCoords[i]); + } + } + return sourceCoords.join(); +} +//# sourceMappingURL=gather_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js.map new file mode 100644 index 0000000..eb5fed5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gather_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gather_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gather_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAME,uBAAY,MAAgB,EAAE,aAAqB,EAAE,IAAY;QALjE,kBAAa,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAM/B,IAAM,WAAW,GAAa,MAAM,CAAC,KAAK,EAAE,CAAC;QAC7C,WAAW,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,MAAM,CAAC;QAC/B,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAM,YAAY,GAAG,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAEnD,IAAI,CAAC,QAAQ,GAAG,oCAEV,KAAK,4DACU,YAAY,uBAEhC,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AArBD,IAqBC;AArBY,sCAAa;AAuB1B,yBAAyB,MAAgB,EAAE,IAAY;IACrD,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,IAAI,IAAI,GAAG,CAAC,EAAE;QACZ,MAAM,KAAK,CAAC,qBAAmB,IAAI,0BAAuB,CAAC,CAAC;KAC7D;IACD,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,OAAO,wBAAwB,CAAC;KACjC;IAED,IAAM,aAAa,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IAEnE,IAAM,YAAY,GAAG,EAAE,CAAC;IACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACtC,IAAI,CAAC,KAAK,IAAI,EAAE;YACd,YAAY,CAAC,IAAI,CAAC,oBAAkB,aAAa,CAAC,CAAC,CAAC,OAAI,CAAC,CAAC;SAC3D;aAAM;YACL,YAAY,CAAC,IAAI,CAAC,KAAG,aAAa,CAAC,CAAC,CAAG,CAAC,CAAC;SAC1C;KACF;IACD,OAAO,YAAY,CAAC,IAAI,EAAE,CAAC;AAC7B,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.d.ts new file mode 100644 index 0000000..a91e221 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.d.ts @@ -0,0 +1,79 @@ +/// +/// +import { WebGL1DisjointQueryTimerExtension, WebGL2DisjointQueryTimerExtension } from './webgl_types'; +export interface FenceContext { + query: WebGLQuery | WebGLSync; + isFencePassed(): boolean; +} +export declare class GPGPUContext { + gl: WebGLRenderingContext; + textureFloatExtension: {}; + textureHalfFloatExtension: {}; + colorBufferFloatExtension: {}; + colorBufferHalfFloatExtension: {}; + getBufferSubDataAsyncExtension: {}; + loseContextExtension: WebGLLoseContext; + disjointQueryTimerExtension: WebGL2DisjointQueryTimerExtension | WebGL1DisjointQueryTimerExtension; + vertexBuffer: WebGLBuffer; + indexBuffer: WebGLBuffer; + framebuffer: WebGLFramebuffer; + outputTexture: WebGLTexture | null; + program: WebGLProgram | null; + private disposed; + private autoDebugValidate; + private disjoint; + private textureConfig; + constructor(gl?: WebGLRenderingContext); + dispose(): void; + enableAutomaticDebugValidation(enabled: boolean): void; + createFloat32MatrixTexture(rows: number, columns: number): WebGLTexture; + createFloat16MatrixTexture(rows: number, columns: number): WebGLTexture; + createUnsignedBytesMatrixTexture(rows: number, columns: number): WebGLTexture; + uploadPixelDataToTexture(texture: WebGLTexture, pixels: ImageData | HTMLImageElement | HTMLCanvasElement): void; + createPackedMatrixTexture(rows: number, columns: number): WebGLTexture; + deleteMatrixTexture(texture: WebGLTexture): void; + uploadMatrixToTexture(texture: WebGLTexture, rows: number, columns: number, matrix: Float32Array): void; + uploadMatrixToPackedTexture(texture: WebGLTexture, rows: number, columns: number, matrix: Float32Array): void; + downloadFloat32MatrixFromOutputTexture(texture: WebGLTexture, rows: number, columns: number): Float32Array; + downloadByteEncodedFloatMatrixFromOutputTexture(texture: WebGLTexture, rows: number, columns: number): Float32Array; + downloadFloat32MatrixFromBuffer(buffer: WebGLBuffer, rows: number, columns: number): Float32Array; + maybeCreateBufferFromTexture(texture: WebGLTexture, rows: number, columns: number): WebGLBuffer | WebGLTexture; + createAndWaitForFence(): Promise; + private createFence; + downloadMatrixFromPackedTexture(texture: WebGLTexture, rows: number, columns: number): Float32Array; + private vertexAttrsAreBound; + createProgram(fragmentShaderSource: string): WebGLProgram; + deleteProgram(program: WebGLProgram): void; + setProgram(program: WebGLProgram | null): void; + getUniformLocation(program: WebGLProgram, uniformName: string, shouldThrow?: boolean): WebGLUniformLocation; + getAttributeLocation(program: WebGLProgram, attribute: string): number; + getUniformLocationNoThrow(program: WebGLProgram, uniformName: string): WebGLUniformLocation; + setInputMatrixTexture(inputMatrixTexture: WebGLTexture, uniformLocation: WebGLUniformLocation, textureUnit: number): void; + setOutputMatrixTexture(outputMatrixTexture: WebGLTexture, rows: number, columns: number): void; + setOutputPackedMatrixTexture(outputPackedMatrixTexture: WebGLTexture, rows: number, columns: number): void; + setOutputMatrixWriteRegion(startRow: number, numRows: number, startColumn: number, numColumns: number): void; + setOutputPackedMatrixWriteRegion(startRow: number, numRows: number, startColumn: number, numColumns: number): void; + debugValidate(): void; + executeProgram(): void; + blockUntilAllProgramsCompleted(): void; + private getQueryTimerExtension; + private getQueryTimerExtensionWebGL2; + private getQueryTimerExtensionWebGL1; + beginQuery(): WebGLQuery; + endQuery(): void; + waitForQueryAndGetTime(query: WebGLQuery): Promise; + private getQueryTime; + private isQueryAvailable; + pollFence(fenceContext: FenceContext): Promise; + private itemsToPoll; + pollItems(): void; + private addItemToPoll; + private bindTextureToFrameBuffer; + private unbindTextureToFrameBuffer; + private downloadMatrixDriver; + private setOutputMatrixTextureDriver; + private setOutputMatrixWriteRegionDriver; + private throwIfDisposed; + private throwIfNoProgram; +} +export declare function binSearchLastTrue(arr: Array<() => boolean>): number; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js new file mode 100644 index 0000000..c02790e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js @@ -0,0 +1,479 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../../environment"); +var util = require("../../util"); +var gpgpu_util = require("./gpgpu_util"); +var tex_util = require("./tex_util"); +var webgl_util = require("./webgl_util"); +var GPGPUContext = (function () { + function GPGPUContext(gl) { + this.outputTexture = null; + this.program = null; + this.disposed = false; + this.autoDebugValidate = false; + this.vertexAttrsAreBound = false; + this.itemsToPoll = []; + if (gl != null) { + this.gl = gl; + } + else { + this.gl = gpgpu_util.createWebGLContext(); + } + if (environment_1.ENV.get('WEBGL_VERSION') === 1) { + this.textureFloatExtension = + webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_float'); + this.colorBufferFloatExtension = + this.gl.getExtension('WEBGL_color_buffer_float'); + if (!environment_1.ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + this.textureHalfFloatExtension = + webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_half_float'); + this.colorBufferHalfFloatExtension = + this.gl.getExtension('EXT_color_buffer_half_float'); + } + } + else { + this.colorBufferFloatExtension = + webgl_util.getExtensionOrThrow(this.gl, 'EXT_color_buffer_float'); + } + this.loseContextExtension = + webgl_util.getExtensionOrThrow(this.gl, 'WEBGL_lose_context'); + this.vertexBuffer = gpgpu_util.createVertexBuffer(this.gl); + this.indexBuffer = gpgpu_util.createIndexBuffer(this.gl); + this.framebuffer = webgl_util.createFramebuffer(this.gl); + this.textureConfig = + gpgpu_util.getTextureConfig(this.gl, this.textureHalfFloatExtension); + } + GPGPUContext.prototype.dispose = function () { + var _this = this; + if (this.disposed) { + return; + } + if (this.program != null) { + console.warn('Disposing a GPGPUContext that still has a bound WebGLProgram.' + + ' This is probably a resource leak, delete the program with ' + + 'GPGPUContext.deleteProgram before disposing.'); + } + if (this.outputTexture != null) { + console.warn('Disposing a GPGPUContext that still has a bound output matrix ' + + 'texture. This is probably a resource leak, delete the output ' + + 'matrix texture with GPGPUContext.deleteMatrixTexture before ' + + 'disposing.'); + } + var gl = this.gl; + webgl_util.callAndCheck(gl, function () { return gl.finish(); }); + webgl_util.callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, null); }); + webgl_util.callAndCheck(gl, function () { return gl.deleteFramebuffer(_this.framebuffer); }); + webgl_util.callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, null); }); + webgl_util.callAndCheck(gl, function () { return gl.deleteBuffer(_this.vertexBuffer); }); + webgl_util.callAndCheck(gl, function () { return gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null); }); + webgl_util.callAndCheck(gl, function () { return gl.deleteBuffer(_this.indexBuffer); }); + this.loseContextExtension.loseContext(); + this.disposed = true; + }; + GPGPUContext.prototype.enableAutomaticDebugValidation = function (enabled) { + this.autoDebugValidate = enabled; + webgl_util.enableDebugWebGLErrorChecking(enabled); + }; + GPGPUContext.prototype.createFloat32MatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return gpgpu_util.createFloat32MatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.createFloat16MatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return gpgpu_util.createFloat16MatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.createUnsignedBytesMatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return gpgpu_util.createUnsignedBytesMatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.uploadPixelDataToTexture = function (texture, pixels) { + this.throwIfDisposed(); + gpgpu_util.uploadPixelDataToTexture(this.gl, texture, pixels); + }; + GPGPUContext.prototype.createPackedMatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return gpgpu_util.createPackedMatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.deleteMatrixTexture = function (texture) { + var _this = this; + this.throwIfDisposed(); + if (this.outputTexture === texture) { + webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer); + this.outputTexture = null; + } + webgl_util.callAndCheck(this.gl, function () { return _this.gl.deleteTexture(texture); }); + }; + GPGPUContext.prototype.uploadMatrixToTexture = function (texture, rows, columns, matrix) { + this.throwIfDisposed(); + var numChannels = webgl_util.getNumChannels(); + return gpgpu_util.uploadMatrixToTexture(this.gl, texture, rows, columns, matrix, numChannels, this.textureConfig); + }; + GPGPUContext.prototype.uploadMatrixToPackedTexture = function (texture, rows, columns, matrix) { + this.throwIfDisposed(); + return gpgpu_util.uploadMatrixToPackedTexture(this.gl, texture, rows, columns, matrix, this.textureConfig); + }; + GPGPUContext.prototype.downloadFloat32MatrixFromOutputTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return gpgpu_util.downloadFloat32MatrixFromOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.downloadByteEncodedFloatMatrixFromOutputTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.downloadFloat32MatrixFromBuffer = function (buffer, rows, columns) { + return gpgpu_util.downloadFloat32MatrixFromBuffer(this.gl, buffer, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.maybeCreateBufferFromTexture = function (texture, rows, columns) { + this.bindTextureToFrameBuffer(texture); + var result = gpgpu_util.maybeCreateBufferFromOutputTexture(this.gl, texture, rows, columns, this.textureConfig); + this.unbindTextureToFrameBuffer(); + return result; + }; + GPGPUContext.prototype.createAndWaitForFence = function () { + var fenceContext = this.createFence(this.gl); + return this.pollFence(fenceContext); + }; + GPGPUContext.prototype.createFence = function (gl) { + var _this = this; + var query; + var isFencePassed; + if (environment_1.ENV.get('WEBGL_FENCE_API_ENABLED')) { + var gl2_1 = gl; + var sync_1 = gl2_1.fenceSync(gl2_1.SYNC_GPU_COMMANDS_COMPLETE, 0); + gl.flush(); + isFencePassed = function () { + var status = gl2_1.clientWaitSync(sync_1, 0, 0); + return status === gl2_1.ALREADY_SIGNALED || + status === gl2_1.CONDITION_SATISFIED; + }; + query = sync_1; + } + else if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + query = this.beginQuery(); + this.endQuery(); + isFencePassed = function () { return _this.isQueryAvailable(query, environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')); }; + } + else { + isFencePassed = function () { return true; }; + } + return { query: query, isFencePassed: isFencePassed }; + }; + GPGPUContext.prototype.downloadMatrixFromPackedTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return gpgpu_util.downloadMatrixFromPackedOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.createProgram = function (fragmentShaderSource) { + this.throwIfDisposed(); + var gl = this.gl; + var fragmentShader = webgl_util.createFragmentShader(gl, fragmentShaderSource); + var vertexShader = gpgpu_util.createVertexShader(gl); + var program = webgl_util.createProgram(gl); + webgl_util.callAndCheck(gl, function () { return gl.attachShader(program, vertexShader); }); + webgl_util.callAndCheck(gl, function () { return gl.attachShader(program, fragmentShader); }); + webgl_util.linkProgram(gl, program); + if (this.autoDebugValidate) { + webgl_util.validateProgram(gl, program); + } + if (!this.vertexAttrsAreBound) { + this.setProgram(program); + this.vertexAttrsAreBound = gpgpu_util.bindVertexProgramAttributeStreams(gl, this.program, this.vertexBuffer); + } + return program; + }; + GPGPUContext.prototype.deleteProgram = function (program) { + var _this = this; + this.throwIfDisposed(); + if (program === this.program) { + this.program = null; + } + if (program != null) { + webgl_util.callAndCheck(this.gl, function () { return _this.gl.deleteProgram(program); }); + } + }; + GPGPUContext.prototype.setProgram = function (program) { + var _this = this; + this.throwIfDisposed(); + this.program = program; + if ((this.program != null) && this.autoDebugValidate) { + webgl_util.validateProgram(this.gl, this.program); + } + webgl_util.callAndCheck(this.gl, function () { return _this.gl.useProgram(program); }); + }; + GPGPUContext.prototype.getUniformLocation = function (program, uniformName, shouldThrow) { + if (shouldThrow === void 0) { shouldThrow = true; } + this.throwIfDisposed(); + if (shouldThrow) { + return webgl_util.getProgramUniformLocationOrThrow(this.gl, program, uniformName); + } + else { + return webgl_util.getProgramUniformLocation(this.gl, program, uniformName); + } + }; + GPGPUContext.prototype.getAttributeLocation = function (program, attribute) { + var _this = this; + this.throwIfDisposed(); + return webgl_util.callAndCheck(this.gl, function () { return _this.gl.getAttribLocation(program, attribute); }); + }; + GPGPUContext.prototype.getUniformLocationNoThrow = function (program, uniformName) { + this.throwIfDisposed(); + return this.gl.getUniformLocation(program, uniformName); + }; + GPGPUContext.prototype.setInputMatrixTexture = function (inputMatrixTexture, uniformLocation, textureUnit) { + this.throwIfDisposed(); + this.throwIfNoProgram(); + webgl_util.bindTextureToProgramUniformSampler(this.gl, this.program, inputMatrixTexture, uniformLocation, textureUnit); + }; + GPGPUContext.prototype.setOutputMatrixTexture = function (outputMatrixTexture, rows, columns) { + this.setOutputMatrixTextureDriver(outputMatrixTexture, columns, rows); + }; + GPGPUContext.prototype.setOutputPackedMatrixTexture = function (outputPackedMatrixTexture, rows, columns) { + this.throwIfDisposed(); + var _a = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + this.setOutputMatrixTextureDriver(outputPackedMatrixTexture, width, height); + }; + GPGPUContext.prototype.setOutputMatrixWriteRegion = function (startRow, numRows, startColumn, numColumns) { + this.setOutputMatrixWriteRegionDriver(startColumn, startRow, numColumns, numRows); + }; + GPGPUContext.prototype.setOutputPackedMatrixWriteRegion = function (startRow, numRows, startColumn, numColumns) { + throw new Error('setOutputPackedMatrixWriteRegion not implemented.'); + }; + GPGPUContext.prototype.debugValidate = function () { + if (this.program != null) { + webgl_util.validateProgram(this.gl, this.program); + } + webgl_util.validateFramebuffer(this.gl); + }; + GPGPUContext.prototype.executeProgram = function () { + this.throwIfDisposed(); + this.throwIfNoProgram(); + var gl = this.gl; + if (this.autoDebugValidate) { + this.debugValidate(); + } + webgl_util.callAndCheck(gl, function () { return gl.drawElements(gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0); }); + }; + GPGPUContext.prototype.blockUntilAllProgramsCompleted = function () { + var _this = this; + this.throwIfDisposed(); + webgl_util.callAndCheck(this.gl, function () { return _this.gl.finish(); }); + }; + GPGPUContext.prototype.getQueryTimerExtension = function () { + if (this.disjointQueryTimerExtension == null) { + this.disjointQueryTimerExtension = + webgl_util.getExtensionOrThrow(this.gl, environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2 ? + 'EXT_disjoint_timer_query_webgl2' : + 'EXT_disjoint_timer_query'); + } + return this.disjointQueryTimerExtension; + }; + GPGPUContext.prototype.getQueryTimerExtensionWebGL2 = function () { + return this.getQueryTimerExtension(); + }; + GPGPUContext.prototype.getQueryTimerExtensionWebGL1 = function () { + return this.getQueryTimerExtension(); + }; + GPGPUContext.prototype.beginQuery = function () { + if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) { + var gl2 = this.gl; + var ext_1 = this.getQueryTimerExtensionWebGL2(); + var query_1 = gl2.createQuery(); + gl2.beginQuery(ext_1.TIME_ELAPSED_EXT, query_1); + return query_1; + } + var ext = this.getQueryTimerExtensionWebGL1(); + var query = ext.createQueryEXT(); + ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, query); + return query; + }; + GPGPUContext.prototype.endQuery = function () { + if (environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) { + var gl2 = this.gl; + var ext_2 = this.getQueryTimerExtensionWebGL2(); + gl2.endQuery(ext_2.TIME_ELAPSED_EXT); + return; + } + var ext = this.getQueryTimerExtensionWebGL1(); + ext.endQueryEXT(ext.TIME_ELAPSED_EXT); + }; + GPGPUContext.prototype.waitForQueryAndGetTime = function (query) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, util.repeatedTry(function () { return _this.isQueryAvailable(query, environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')); })]; + case 1: + _a.sent(); + return [2, this.getQueryTime(query, environment_1.ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'))]; + } + }); + }); + }; + GPGPUContext.prototype.getQueryTime = function (query, queryTimerVersion) { + if (queryTimerVersion === 0) { + return null; + } + if (queryTimerVersion === 2) { + var gl2 = this.gl; + var timeElapsedNanos = gl2.getQueryParameter(query, gl2.QUERY_RESULT); + return timeElapsedNanos / 1000000; + } + else { + var ext = this.getQueryTimerExtensionWebGL1(); + var timeElapsedNanos = ext.getQueryObjectEXT(query, ext.QUERY_RESULT_EXT); + return timeElapsedNanos / 1000000; + } + }; + GPGPUContext.prototype.isQueryAvailable = function (query, queryTimerVersion) { + if (queryTimerVersion === 0) { + return true; + } + if (queryTimerVersion === 2) { + var gl2 = this.gl; + var ext = this.getQueryTimerExtensionWebGL2(); + var available = gl2.getQueryParameter(query, gl2.QUERY_RESULT_AVAILABLE); + if (this.disjoint == null) { + this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT); + } + return available && !this.disjoint; + } + else { + var ext = this.getQueryTimerExtensionWebGL1(); + var available = ext.getQueryObjectEXT(query, ext.QUERY_RESULT_AVAILABLE_EXT); + if (this.disjoint == null) { + this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT); + } + return available && !this.disjoint; + } + }; + GPGPUContext.prototype.pollFence = function (fenceContext) { + var _this = this; + return new Promise(function (resolve) { + _this.addItemToPoll(function () { return fenceContext.isFencePassed(); }, function () { return resolve(); }); + }); + }; + GPGPUContext.prototype.pollItems = function () { + var index = binSearchLastTrue(this.itemsToPoll.map(function (x) { return x.isDoneFn; })); + for (var i = 0; i <= index; ++i) { + var resolveFn = this.itemsToPoll[i].resolveFn; + resolveFn(); + } + this.itemsToPoll = this.itemsToPoll.slice(index + 1); + }; + GPGPUContext.prototype.addItemToPoll = function (isDoneFn, resolveFn) { + var _this = this; + this.itemsToPoll.push({ isDoneFn: isDoneFn, resolveFn: resolveFn }); + if (this.itemsToPoll.length > 1) { + return; + } + util.repeatedTry(function () { + _this.pollItems(); + return _this.itemsToPoll.length === 0; + }); + }; + GPGPUContext.prototype.bindTextureToFrameBuffer = function (texture) { + this.throwIfDisposed(); + webgl_util.bindColorTextureToFramebuffer(this.gl, texture, this.framebuffer); + if (this.autoDebugValidate) { + webgl_util.validateFramebuffer(this.gl); + } + }; + GPGPUContext.prototype.unbindTextureToFrameBuffer = function () { + if (this.outputTexture != null) { + webgl_util.bindColorTextureToFramebuffer(this.gl, this.outputTexture, this.framebuffer); + if (this.autoDebugValidate) { + webgl_util.validateFramebuffer(this.gl); + } + } + else { + webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer); + } + }; + GPGPUContext.prototype.downloadMatrixDriver = function (texture, downloadAndDecode) { + this.bindTextureToFrameBuffer(texture); + var result = downloadAndDecode(); + this.unbindTextureToFrameBuffer(); + return result; + }; + GPGPUContext.prototype.setOutputMatrixTextureDriver = function (outputMatrixTextureMaybePacked, width, height) { + this.throwIfDisposed(); + var gl = this.gl; + webgl_util.bindColorTextureToFramebuffer(gl, outputMatrixTextureMaybePacked, this.framebuffer); + if (this.autoDebugValidate) { + webgl_util.validateFramebuffer(gl); + } + this.outputTexture = outputMatrixTextureMaybePacked; + webgl_util.callAndCheck(gl, function () { return gl.viewport(0, 0, width, height); }); + webgl_util.callAndCheck(gl, function () { return gl.scissor(0, 0, width, height); }); + }; + GPGPUContext.prototype.setOutputMatrixWriteRegionDriver = function (x, y, width, height) { + var _this = this; + this.throwIfDisposed(); + webgl_util.callAndCheck(this.gl, function () { return _this.gl.scissor(x, y, width, height); }); + }; + GPGPUContext.prototype.throwIfDisposed = function () { + if (this.disposed) { + throw new Error('Attempted to use disposed GPGPUContext.'); + } + }; + GPGPUContext.prototype.throwIfNoProgram = function () { + if (this.program == null) { + throw new Error('No GPU program is currently set.'); + } + }; + return GPGPUContext; +}()); +exports.GPGPUContext = GPGPUContext; +function binSearchLastTrue(arr) { + var start = 0; + var end = arr.length - 1; + var best = -1; + while (start <= end) { + var mid = (start + end) >> 1; + var isDone = arr[mid](); + if (isDone) { + best = mid; + start = mid + 1; + } + else { + end = mid - 1; + } + } + return best; +} +exports.binSearchLastTrue = binSearchLastTrue; +//# sourceMappingURL=gpgpu_context.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js.map new file mode 100644 index 0000000..d560de2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gpgpu_context.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gpgpu_context.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js new file mode 100644 index 0000000..5f5b92f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js @@ -0,0 +1,302 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var jasmine_util_1 = require("../../jasmine_util"); +var test_util_1 = require("../../test_util"); +var gpgpu_context_1 = require("./gpgpu_context"); +var tex_util = require("./tex_util"); +var DOWNLOAD_FLOAT_ENVS = { + 'WEBGL_DOWNLOAD_FLOAT_ENABLED': true +}; +jasmine_util_1.describeWithFlags('GPGPUContext downloadMatrixFromTexture', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + var texture; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + texture = gpgpu.createFloat32MatrixTexture(1, 1); + }); + afterEach(function () { + gpgpu.deleteMatrixTexture(texture); + gpgpu.dispose(); + }); + it('returns 1x1 matrix that was uploaded', function () { + gpgpu.uploadMatrixToTexture(texture, 1, 1, new Float32Array([1.234])); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + test_util_1.expectNumbersClose(result[0], 1.234); + }); + it('returns 2x2 matrix that was uploaded', function () { + var texture2 = gpgpu.createFloat32MatrixTexture(2, 2); + gpgpu.uploadMatrixToTexture(texture2, 2, 2, new Float32Array([1.234, 2, 3, 4])); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(texture2, 2, 2); + test_util_1.expectArraysClose(result, new Float32Array([1.234, 2, 3, 4])); + gpgpu.deleteMatrixTexture(texture2); + }); + it('uses texture parameter', function () { + var texture2 = gpgpu.createFloat32MatrixTexture(1, 1); + gpgpu.uploadMatrixToTexture(texture, 1, 1, new Float32Array([1])); + gpgpu.uploadMatrixToTexture(texture2, 1, 1, new Float32Array([2])); + var read1 = gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + var read2 = gpgpu.downloadFloat32MatrixFromOutputTexture(texture2, 1, 1); + test_util_1.expectNumbersClose(read1[0], 1); + test_util_1.expectNumbersClose(read2[0], 2); + gpgpu.deleteMatrixTexture(texture2); + }); +}); +jasmine_util_1.describeWithFlags('GPGPUContext color texture with float', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + var texture; + afterEach(function () { + gpgpu.deleteMatrixTexture(texture); + gpgpu.dispose(); + }); + it('basic', function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + texture = gpgpu.createFloat32MatrixTexture(1, 1); + gpgpu.setOutputMatrixTexture(texture, 1, 1); + gpgpu.gl.clearColor(0.123, 0, 0, 0); + gpgpu.gl.clear(gpgpu.gl.COLOR_BUFFER_BIT); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + test_util_1.expectNumbersClose(result[0], 0.123); + }); +}); +jasmine_util_1.describeWithFlags('GPGPUContext setOutputMatrixTexture', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + var texture; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + texture = gpgpu.createFloat32MatrixTexture(1, 1); + }); + afterEach(function () { + gpgpu.deleteMatrixTexture(texture); + gpgpu.dispose(); + }); + it('sets the output texture property to the output texture', function () { + gpgpu.setOutputMatrixTexture(texture, 1, 1); + expect(gpgpu.outputTexture).toBe(texture); + }); + it('rebinds the output texture to the color buffer target', function () { + var output = gpgpu.createFloat32MatrixTexture(1, 1); + gpgpu.uploadMatrixToTexture(texture, 1, 1, new Float32Array([10])); + gpgpu.setOutputMatrixTexture(output, 1, 1); + var tBeforeClear = gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + test_util_1.expectNumbersClose(tBeforeClear[0], 10); + gpgpu.gl.clearColor(1, 0, 0, 0); + gpgpu.gl.clear(gpgpu.gl.COLOR_BUFFER_BIT); + var tAfterClear = gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + test_util_1.expectNumbersClose(tAfterClear[0], 10); + gpgpu.deleteMatrixTexture(output); + }); + it('resets output texture to null if nothing was previously bound', function () { + expect(gpgpu.outputTexture).toBeNull(); + gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + expect(gpgpu.outputTexture).toBeNull(); + }); + it('sets the gl viewport to the output texture dimensions', function () { + var columns = 456; + var rows = 123; + var output = gpgpu.createFloat32MatrixTexture(rows, columns); + gpgpu.setOutputMatrixTexture(output, rows, columns); + var expected = new Int32Array([0, 0, columns, rows]); + expect(gpgpu.gl.getParameter(gpgpu.gl.VIEWPORT)).toEqual(expected); + gpgpu.deleteMatrixTexture(output); + }); + it('doesn\'t change gl viewport when downloading a non-output tex', function () { + var output = gpgpu.createFloat32MatrixTexture(128, 128); + gpgpu.setOutputMatrixTexture(output, 128, 128); + gpgpu.downloadFloat32MatrixFromOutputTexture(texture, 1, 1); + var expected = new Int32Array([0, 0, 128, 128]); + expect(gpgpu.gl.getParameter(gpgpu.gl.VIEWPORT)).toEqual(expected); + gpgpu.deleteMatrixTexture(output); + }); +}); +jasmine_util_1.describeWithFlags('GPGPUContext setOutputPackedMatrixTexture', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + var texture; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + }); + afterEach(function () { + if (texture != null) { + gpgpu.deleteMatrixTexture(texture); + } + gpgpu.dispose(); + }); + it('sets the output texture property to the output texture', function () { + texture = gpgpu.createPackedMatrixTexture(1, 1); + gpgpu.setOutputPackedMatrixTexture(texture, 1, 1); + expect(gpgpu.outputTexture).toBe(texture); + }); + it('sets the gl viewport to the output packed texture dimensions', function () { + var columns = 456; + var rows = 123; + texture = gpgpu.createPackedMatrixTexture(rows, columns); + gpgpu.setOutputPackedMatrixTexture(texture, rows, columns); + var _a = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + var expected = new Int32Array([0, 0, width, height]); + expect(gpgpu.gl.getParameter(gpgpu.gl.VIEWPORT)).toEqual(expected); + }); +}); +jasmine_util_1.describeWithFlags('GPGPUContext setOutputMatrixWriteRegion', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + var program; + var output; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + var src = 'precision highp float; void main(){gl_FragColor = vec4(2,0,0,0);}'; + program = gpgpu.createProgram(src); + output = gpgpu.createFloat32MatrixTexture(4, 4); + gpgpu.uploadMatrixToTexture(output, 4, 4, new Float32Array(16)); + gpgpu.setOutputMatrixTexture(output, 4, 4); + gpgpu.setProgram(program); + }); + afterEach(function () { + gpgpu.deleteMatrixTexture(output); + gpgpu.deleteProgram(program); + gpgpu.dispose(); + }); + it('writes to all pixels by default', function () { + gpgpu.executeProgram(); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(output, 4, 4); + var expected = new Float32Array(4 * 4); + expected.fill(2); + test_util_1.expectArraysClose(result, expected); + }); + it('sets the scissor box to the requested parameters', function () { + gpgpu.setOutputMatrixWriteRegion(0, 1, 2, 3); + var scissorBox = gpgpu.gl.getParameter(gpgpu.gl.SCISSOR_BOX); + expect(scissorBox[0]).toEqual(2); + expect(scissorBox[1]).toEqual(0); + expect(scissorBox[2]).toEqual(3); + expect(scissorBox[3]).toEqual(1); + }); + it('writes only to center 2x2 region of 4x4 texture', function () { + gpgpu.setOutputMatrixWriteRegion(1, 2, 1, 2); + gpgpu.executeProgram(); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(output, 4, 4); + var expected = new Float32Array([0, 0, 0, 0, 0, 2, 2, 0, 0, 2, 2, 0, 0, 0, 0, 0]); + test_util_1.expectArraysClose(result, expected); + }); + it('preserves data from previous writes outside of write region', function () { + gpgpu.setOutputMatrixWriteRegion(0, 1, 0, 4); + gpgpu.executeProgram(); + gpgpu.setOutputMatrixWriteRegion(3, 1, 0, 4); + gpgpu.executeProgram(); + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(output, 4, 4); + var expected = new Float32Array([2, 2, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 2, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('writes adjacent cells across multiple calls', function () { + for (var row = 0; row < 4; ++row) { + for (var col = 0; col < 4; ++col) { + gpgpu.setOutputMatrixWriteRegion(row, 1, col, 1); + gpgpu.executeProgram(); + } + } + var result = gpgpu.downloadFloat32MatrixFromOutputTexture(output, 4, 4); + var expected = new Float32Array(4 * 4); + expected.fill(2); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('GPGPUContext', DOWNLOAD_FLOAT_ENVS, function () { + var gpgpu; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + gpgpu.enableAutomaticDebugValidation(true); + }); + afterEach(function () { + gpgpu.dispose(); + }); + it('throws an error if used after dispose', function () { + var gpgpuContext = new gpgpu_context_1.GPGPUContext(); + gpgpuContext.dispose(); + expect(gpgpuContext.dispose).toThrowError(); + }); + it('throws an error if validation is on and framebuffer incomplete', function () { + var src = "precision highp float; void main() {}"; + var program = gpgpu.createProgram(src); + var result = gpgpu.createFloat32MatrixTexture(1, 1); + gpgpu.setOutputMatrixTexture(result, 1, 1); + gpgpu.setProgram(program); + gpgpu.deleteMatrixTexture(result); + expect(gpgpu.executeProgram).toThrowError(); + gpgpu.deleteProgram(program); + }); +}); +describe('gpgpu_context binSearchLastTrue', function () { + it('[false]', function () { + var a = [false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(-1); + }); + it('[true]', function () { + var a = [true]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(0); + }); + it('[false, false]', function () { + var a = [false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(-1); + }); + it('[true, false]', function () { + var a = [true, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(0); + }); + it('[true, true]', function () { + var a = [true, true]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(1); + }); + it('[false, false, false]', function () { + var a = [false, false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(-1); + }); + it('[true, false, false]', function () { + var a = [true, false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(0); + }); + it('[true, true, false]', function () { + var a = [true, true, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(1); + }); + it('[true, true, true]', function () { + var a = [true, true, true]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(2); + }); + it('[false, false, false, false]', function () { + var a = [false, false, false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(-1); + }); + it('[true, false, false, false]', function () { + var a = [true, false, false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(0); + }); + it('[true, true, false, false]', function () { + var a = [true, true, false, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(1); + }); + it('[true, true, true, false]', function () { + var a = [true, true, true, false]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(2); + }); + it('[true, true, true, true]', function () { + var a = [true, true, true, true]; + var arr = a.map(function (x) { return function () { return x; }; }); + expect(gpgpu_context_1.binSearchLastTrue(arr)).toBe(3); + }); +}); +//# sourceMappingURL=gpgpu_context_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js.map new file mode 100644 index 0000000..7b4b9a8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_context_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gpgpu_context_test.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gpgpu_context_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.d.ts new file mode 100644 index 0000000..36eafde --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.d.ts @@ -0,0 +1,29 @@ +import { Tensor } from '../../tensor'; +import { GPGPUContext } from './gpgpu_context'; +import { ShapeInfo } from './shader_compiler'; +import { TextureData } from './tex_util'; +export interface GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + supportsBroadcasting?: boolean; +} +export interface GPGPUBinary { + webGLProgram: WebGLProgram; + program: GPGPUProgram; + uniformLocations: { + [name: string]: WebGLUniformLocation; + }; + gpgpu: GPGPUContext; + source: string; + inShapeInfos: ShapeInfo[]; + outShapeInfo: ShapeInfo; +} +export interface TensorData { + tensor: T; + texData: TextureData; + isUniform: boolean; +} +export declare function compileProgram(gpgpu: GPGPUContext, program: GPGPUProgram, inputs: Array>, output: TensorData): GPGPUBinary; +export declare function runProgram(binary: GPGPUBinary, inputs: Array>, output: TensorData, customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void): void; +export declare function makeShaderKey(program: GPGPUProgram, inputs: Array>, output: TensorData): string; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js new file mode 100644 index 0000000..8807a54 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js @@ -0,0 +1,113 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("../../util"); +var shader_compiler = require("./shader_compiler"); +function compileProgram(gpgpu, program, inputs, output) { + var userCode = program.userCode; + var inputInfos = inputs.map(function (input, i) { + var shapeInfo = { + logicalShape: input.tensor.shape, + texShape: input.isUniform ? null : input.texData.texShape, + isUniform: input.isUniform + }; + return { name: program.variableNames[i], shapeInfo: shapeInfo }; + }); + var inShapeInfos = inputInfos.map(function (x) { return x.shapeInfo; }); + var outShapeInfo = { + logicalShape: output.tensor.shape, + texShape: output.texData.texShape, + isUniform: false + }; + var source = shader_compiler.makeShader(inputInfos, outShapeInfo, userCode, program.supportsBroadcasting === true); + var webGLProgram = gpgpu.createProgram(source); + var uniformLocations = {}; + for (var i = 0; i < program.variableNames.length; i++) { + var uniformName = program.variableNames[i]; + var shouldThrow = false; + uniformLocations[uniformName] = + gpgpu.getUniformLocation(webGLProgram, uniformName, shouldThrow); + } + return { + program: program, + source: source, + webGLProgram: webGLProgram, + uniformLocations: uniformLocations, + gpgpu: gpgpu, + inShapeInfos: inShapeInfos, + outShapeInfo: outShapeInfo + }; +} +exports.compileProgram = compileProgram; +function validateBinaryAndProgram(shapeInfos, inputs) { + if (shapeInfos.length !== inputs.length) { + throw Error("Binary was compiled with " + shapeInfos.length + " inputs, but " + + ("was executed with " + inputs.length + " inputs")); + } + shapeInfos.forEach(function (s, i) { + var shapeA = s.logicalShape; + var input = inputs[i]; + var shapeB = input.tensor.shape; + if (!util.arraysEqual(shapeA, shapeB)) { + throw Error("Binary was compiled with different shapes than " + + ("the current args. Shapes " + shapeA + " and " + shapeB + " must match")); + } + if (s.isUniform && input.isUniform) { + return; + } + var texShapeA = s.texShape; + var texShapeB = input.isUniform ? null : input.texData.texShape; + if (!util.arraysEqual(texShapeA, texShapeB)) { + throw Error("Binary was compiled with different texture shapes than the" + + (" current args. Shape " + texShapeA + " and " + texShapeB + " must match")); + } + }); +} +function runProgram(binary, inputs, output, customSetup) { + validateBinaryAndProgram(binary.inShapeInfos, inputs); + validateBinaryAndProgram([binary.outShapeInfo], [output]); + var outTex = output.texData.texture; + var outTexShape = output.texData.texShape; + var gpgpu = binary.gpgpu; + gpgpu.setOutputMatrixTexture(outTex, outTexShape[0], outTexShape[1]); + gpgpu.setProgram(binary.webGLProgram); + inputs.forEach(function (input, i) { + var variableName = binary.program.variableNames[i]; + var variableUniformLocation = binary.uniformLocations[variableName]; + if (variableUniformLocation != null) { + if (input.isUniform) { + if (input.tensor.size === 1) { + gpgpu.gl.uniform1f(variableUniformLocation, input.tensor.dataSync()[0]); + } + else { + var vals = input.tensor.dataSync(); + if (!(vals instanceof Float32Array)) { + vals = new Float32Array(vals); + } + gpgpu.gl.uniform1fv(variableUniformLocation, vals); + } + return; + } + var tex = input.texData.texture; + gpgpu.setInputMatrixTexture(tex, variableUniformLocation, i); + } + }); + if (customSetup != null) { + customSetup(gpgpu, binary.webGLProgram); + } + gpgpu.executeProgram(); +} +exports.runProgram = runProgram; +function makeShaderKey(program, inputs, output) { + var keyInputs = ''; + inputs.concat(output).forEach(function (x) { + keyInputs += + x.tensor.shape + "_" + (x.isUniform ? 'uniform' : x.texData.texShape); + }); + var keyUserCode = program.userCode; + var keyBroadcast = (program.supportsBroadcasting === true).toString(); + var key = program.constructor.name; + key += '_' + keyBroadcast + '_' + keyInputs + '_' + keyUserCode; + return key; +} +exports.makeShaderKey = makeShaderKey; +//# sourceMappingURL=gpgpu_math.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js.map new file mode 100644 index 0000000..e1e4e6b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_math.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gpgpu_math.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gpgpu_math.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.d.ts new file mode 100644 index 0000000..f85a65f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.d.ts @@ -0,0 +1,29 @@ +export declare function getWebGLContextAttributes(): WebGLContextAttributes; +export interface TextureConfig { + internalFormatFloat: number; + textureFormatFloat: number; + internalFormatHalfFloat: number; + internalFormatPackedFloat: number; + downloadTextureFormat: number; + downloadUnpackNumChannels: number; + defaultNumChannels: number; + textureTypeHalfFloat: number; +} +export declare function createWebGLContext(canvas?: HTMLCanvasElement): WebGLRenderingContext; +export declare function createVertexShader(gl: WebGLRenderingContext): WebGLShader; +export declare function createVertexBuffer(gl: WebGLRenderingContext): WebGLBuffer; +export declare function createIndexBuffer(gl: WebGLRenderingContext): WebGLBuffer; +export declare function getTextureConfig(gl: WebGLRenderingContext, textureHalfFloatExtension?: any): TextureConfig; +export declare function createFloat32MatrixTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): WebGLTexture; +export declare function createFloat16MatrixTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): WebGLTexture; +export declare function createUnsignedBytesMatrixTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): WebGLTexture; +export declare function createPackedMatrixTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): WebGLTexture; +export declare function bindVertexProgramAttributeStreams(gl: WebGLRenderingContext, program: WebGLProgram, vertexBuffer: WebGLBuffer): boolean; +export declare function uploadPixelDataToTexture(gl: WebGLRenderingContext, texture: WebGLTexture, pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; +export declare function uploadMatrixToTexture(gl: WebGLRenderingContext, texture: WebGLTexture, rows: number, columns: number, matrix: Float32Array, numChannels: number, textureConfig: TextureConfig): void; +export declare function uploadMatrixToPackedTexture(gl: WebGLRenderingContext, texture: WebGLTexture, rows: number, columns: number, matrix: Float32Array, textureConfig: TextureConfig): void; +export declare function maybeCreateBufferFromOutputTexture(gl: WebGLRenderingContext, texture: WebGLTexture, rows: number, columns: number, textureConfig: TextureConfig): WebGLBuffer | WebGLTexture; +export declare function downloadFloat32MatrixFromBuffer(gl: WebGLRenderingContext, buffer: WebGLBuffer, rows: number, columns: number, textureConfig: TextureConfig): Float32Array; +export declare function downloadFloat32MatrixFromOutputTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): Float32Array; +export declare function downloadByteEncodedFloatMatrixFromOutputTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): Float32Array; +export declare function downloadMatrixFromPackedOutputTexture(gl: WebGLRenderingContext, rows: number, columns: number, textureConfig: TextureConfig): Float32Array; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js new file mode 100644 index 0000000..c2f4a39 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js @@ -0,0 +1,226 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../../environment"); +var tex_util = require("./tex_util"); +var webgl_util = require("./webgl_util"); +function getWebGLContextAttributes() { + return { + alpha: false, + antialias: false, + premultipliedAlpha: false, + preserveDrawingBuffer: false, + depth: false, + stencil: false, + failIfMajorPerformanceCaveat: true + }; +} +exports.getWebGLContextAttributes = getWebGLContextAttributes; +function createWebGLContext(canvas) { + var attributes = getWebGLContextAttributes(); + var gl; + if (canvas != null) { + gl = webgl_util.createWebGLRenderingContextFromCanvas(canvas, attributes); + } + else { + gl = webgl_util.createWebGLRenderingContext(attributes); + } + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.DEPTH_TEST); }); + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.STENCIL_TEST); }); + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.BLEND); }); + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.DITHER); }); + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.POLYGON_OFFSET_FILL); }); + webgl_util.callAndCheck(gl, function () { return gl.disable(gl.SAMPLE_COVERAGE); }); + webgl_util.callAndCheck(gl, function () { return gl.enable(gl.SCISSOR_TEST); }); + webgl_util.callAndCheck(gl, function () { return gl.enable(gl.CULL_FACE); }); + webgl_util.callAndCheck(gl, function () { return gl.cullFace(gl.BACK); }); + return gl; +} +exports.createWebGLContext = createWebGLContext; +function createVertexShader(gl) { + var vertexShaderSource = "\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }"; + return webgl_util.createVertexShader(gl, vertexShaderSource); +} +exports.createVertexShader = createVertexShader; +function createVertexBuffer(gl) { + var vertexArray = new Float32Array([-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]); + return webgl_util.createStaticVertexBuffer(gl, vertexArray); +} +exports.createVertexBuffer = createVertexBuffer; +function createIndexBuffer(gl) { + var triangleVertexIndices = new Uint16Array([0, 1, 2, 2, 1, 3]); + return webgl_util.createStaticIndexBuffer(gl, triangleVertexIndices); +} +exports.createIndexBuffer = createIndexBuffer; +function getTextureConfig(gl, textureHalfFloatExtension) { + var glany = gl; + var internalFormatFloat; + var internalFormatHalfFloat; + var internalFormatPackedFloat; + var textureFormatFloat; + var downloadTextureFormat; + var downloadUnpackNumChannels; + var defaultNumChannels; + var textureTypeHalfFloat; + if (environment_1.ENV.get('WEBGL_VERSION') === 2) { + internalFormatFloat = glany.R32F; + internalFormatHalfFloat = glany.R16F; + internalFormatPackedFloat = glany.RGBA32F; + textureFormatFloat = glany.RED; + downloadUnpackNumChannels = 4; + defaultNumChannels = 1; + textureTypeHalfFloat = glany.HALF_FLOAT; + } + else { + internalFormatFloat = gl.RGBA; + internalFormatHalfFloat = gl.RGBA; + internalFormatPackedFloat = glany.RGBA; + textureFormatFloat = gl.RGBA; + downloadUnpackNumChannels = 4; + defaultNumChannels = 4; + textureTypeHalfFloat = textureHalfFloatExtension != null ? + textureHalfFloatExtension.HALF_FLOAT_OES : + null; + } + downloadTextureFormat = gl.RGBA; + return { + internalFormatFloat: internalFormatFloat, + internalFormatHalfFloat: internalFormatHalfFloat, + internalFormatPackedFloat: internalFormatPackedFloat, + textureFormatFloat: textureFormatFloat, + downloadTextureFormat: downloadTextureFormat, + downloadUnpackNumChannels: downloadUnpackNumChannels, + defaultNumChannels: defaultNumChannels, + textureTypeHalfFloat: textureTypeHalfFloat + }; +} +exports.getTextureConfig = getTextureConfig; +function createAndConfigureTexture(gl, width, height, internalFormat, textureFormat, textureType) { + webgl_util.validateTextureSize(gl, width, height); + var texture = webgl_util.createTexture(gl); + var tex2d = gl.TEXTURE_2D; + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(tex2d, texture); }); + webgl_util.callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE); }); + webgl_util.callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE); }); + webgl_util.callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_MIN_FILTER, gl.NEAREST); }); + webgl_util.callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_MAG_FILTER, gl.NEAREST); }); + webgl_util.callAndCheck(gl, function () { return gl.texImage2D(tex2d, 0, internalFormat, width, height, 0, textureFormat, textureType, null); }); + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); + return texture; +} +function createFloat32MatrixTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatFloat, textureConfig.textureFormatFloat, gl.FLOAT); +} +exports.createFloat32MatrixTexture = createFloat32MatrixTexture; +function createFloat16MatrixTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatFloat, textureConfig.textureFormatFloat, textureConfig.textureTypeHalfFloat); +} +exports.createFloat16MatrixTexture = createFloat16MatrixTexture; +function createUnsignedBytesMatrixTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE); +} +exports.createUnsignedBytesMatrixTexture = createUnsignedBytesMatrixTexture; +function createPackedMatrixTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatPackedFloat, gl.RGBA, gl.FLOAT); +} +exports.createPackedMatrixTexture = createPackedMatrixTexture; +function bindVertexProgramAttributeStreams(gl, program, vertexBuffer) { + var posOffset = 0; + var uvOffset = 3 * 4; + var stride = (3 * 4) + (2 * 4); + webgl_util.callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer); }); + var success = webgl_util.bindVertexBufferToProgramAttribute(gl, program, 'clipSpacePos', vertexBuffer, 3, stride, posOffset); + return success && + webgl_util.bindVertexBufferToProgramAttribute(gl, program, 'uv', vertexBuffer, 2, stride, uvOffset); +} +exports.bindVertexProgramAttributeStreams = bindVertexProgramAttributeStreams; +function uploadPixelDataToTexture(gl, texture, pixels) { + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); + webgl_util.callAndCheck(gl, function () { return gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, pixels); }); + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); +} +exports.uploadPixelDataToTexture = uploadPixelDataToTexture; +function uploadDataToTexture(gl, texture, width, height, data, textureFormat) { + webgl_util.validateTextureSize(gl, width, height); + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); + webgl_util.callAndCheck(gl, function () { return gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, width, height, textureFormat, gl.FLOAT, data); }); + webgl_util.callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); +} +function uploadMatrixToTexture(gl, texture, rows, columns, matrix, numChannels, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var unpackedArray; + if (textureConfig.defaultNumChannels === 1) { + unpackedArray = matrix; + } + else { + unpackedArray = + new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(matrix.length, numChannels)); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedArray, numChannels); + } + uploadDataToTexture(gl, texture, w, h, unpackedArray, textureConfig.textureFormatFloat); +} +exports.uploadMatrixToTexture = uploadMatrixToTexture; +function uploadMatrixToPackedTexture(gl, texture, rows, columns, matrix, textureConfig) { + var _a = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var packedRGBA = new Float32Array(tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns)); + tex_util.encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA); + uploadDataToTexture(gl, texture, w, h, packedRGBA, gl.RGBA); +} +exports.uploadMatrixToPackedTexture = uploadMatrixToPackedTexture; +function maybeCreateBufferFromOutputTexture(gl, texture, rows, columns, textureConfig) { + var bufferOrTexture = texture; + if (environment_1.ENV.get('WEBGL_VERSION') === 2) { + var gl2_1 = gl; + var buffer_1 = gl2_1.createBuffer(); + webgl_util.callAndCheck(gl, function () { return gl.bindBuffer(gl2_1.PIXEL_PACK_BUFFER, buffer_1); }); + var bytesPerFloat = 4; + var bufferSizeBytes_1 = bytesPerFloat * + tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels); + webgl_util.callAndCheck(gl, function () { return gl.bufferData(gl2_1.PIXEL_PACK_BUFFER, bufferSizeBytes_1, gl.STATIC_DRAW); }); + webgl_util.callAndCheck(gl, function () { return gl2_1.readPixels(0, 0, columns, rows, gl.RGBA, gl.FLOAT, 0); }); + webgl_util.callAndCheck(gl, function () { return gl.bindBuffer(gl2_1.PIXEL_PACK_BUFFER, null); }); + bufferOrTexture = buffer_1; + } + return bufferOrTexture; +} +exports.maybeCreateBufferFromOutputTexture = maybeCreateBufferFromOutputTexture; +function downloadFloat32MatrixFromBuffer(gl, buffer, rows, columns, textureConfig) { + var gl2 = gl; + var downloadTarget = new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels)); + gl2.bindBuffer(gl.ARRAY_BUFFER, buffer); + gl2.getBufferSubData(gl.ARRAY_BUFFER, 0, downloadTarget); + gl2.bindBuffer(gl.ARRAY_BUFFER, null); + var matrix = new Float32Array(rows * columns); + tex_util.decodeMatrixFromUnpackedArray(downloadTarget, matrix, textureConfig.downloadUnpackNumChannels); + return matrix; +} +exports.downloadFloat32MatrixFromBuffer = downloadFloat32MatrixFromBuffer; +function downloadFloat32MatrixFromOutputTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var downloadTarget = new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels)); + webgl_util.callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, textureConfig.downloadTextureFormat, gl.FLOAT, downloadTarget); }); + var matrix = new Float32Array(rows * columns); + tex_util.decodeMatrixFromUnpackedArray(downloadTarget, matrix, textureConfig.downloadUnpackNumChannels); + return matrix; +} +exports.downloadFloat32MatrixFromOutputTexture = downloadFloat32MatrixFromOutputTexture; +function downloadByteEncodedFloatMatrixFromOutputTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var numChannels = 4; + var downloadTarget = new Uint8Array(tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, numChannels)); + webgl_util.callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, textureConfig.downloadTextureFormat, gl.UNSIGNED_BYTE, downloadTarget); }); + return new Float32Array(downloadTarget.buffer); +} +exports.downloadByteEncodedFloatMatrixFromOutputTexture = downloadByteEncodedFloatMatrixFromOutputTexture; +function downloadMatrixFromPackedOutputTexture(gl, rows, columns, textureConfig) { + var _a = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var packedRGBA = new Float32Array(tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns)); + webgl_util.callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, gl.RGBA, gl.FLOAT, packedRGBA); }); + var matrix = new Float32Array(rows * columns); + return tex_util.decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix); +} +exports.downloadMatrixFromPackedOutputTexture = downloadMatrixFromPackedOutputTexture; +//# sourceMappingURL=gpgpu_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js.map new file mode 100644 index 0000000..ecd205b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gpgpu_util.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gpgpu_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js new file mode 100644 index 0000000..5bedb26 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js @@ -0,0 +1,91 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var jasmine_util_1 = require("../../jasmine_util"); +var test_util_1 = require("../../test_util"); +var gpgpu_context_1 = require("./gpgpu_context"); +var gpgpu_util = require("./gpgpu_util"); +jasmine_util_1.describeWithFlags('gpgpu_util createWebGLContext', test_util_1.WEBGL_ENVS, function () { + var gpgpu; + beforeEach(function () { + gpgpu = new gpgpu_context_1.GPGPUContext(); + }); + afterEach(function () { + gpgpu.dispose(); + }); + it('disables DEPTH_TEST and STENCIL_TEST', function () { + expect(gpgpu.gl.getParameter(gpgpu.gl.DEPTH_TEST)).toEqual(false); + expect(gpgpu.gl.getParameter(gpgpu.gl.STENCIL_TEST)).toEqual(false); + }); + it('disables BLEND', function () { + expect(gpgpu.gl.getParameter(gpgpu.gl.BLEND)).toEqual(false); + }); + it('disables DITHER, POLYGON_OFFSET_FILL', function () { + expect(gpgpu.gl.getParameter(gpgpu.gl.DITHER)).toEqual(false); + expect(gpgpu.gl.getParameter(gpgpu.gl.POLYGON_OFFSET_FILL)).toEqual(false); + }); + it('enables CULL_FACE with BACK', function () { + expect(gpgpu.gl.getParameter(gpgpu.gl.CULL_FACE)).toEqual(true); + expect(gpgpu.gl.getParameter(gpgpu.gl.CULL_FACE_MODE)) + .toEqual(gpgpu.gl.BACK); + }); + it('enables SCISSOR_TEST', function () { + expect(gpgpu.gl.getParameter(gpgpu.gl.SCISSOR_TEST)).toEqual(true); + }); +}); +jasmine_util_1.describeWithFlags('gpgpu_util createFloat32MatrixTexture', test_util_1.WEBGL_ENVS, function () { + it('sets the TEXTURE_WRAP S+T parameters to CLAMP_TO_EDGE', function () { + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var textureConfig = gpgpu_util.getTextureConfig(gpgpu.gl); + var tex = gpgpu_util.createFloat32MatrixTexture(gpgpu.gl, 32, 32, textureConfig); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, tex); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_WRAP_S)) + .toEqual(gpgpu.gl.CLAMP_TO_EDGE); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_WRAP_T)) + .toEqual(gpgpu.gl.CLAMP_TO_EDGE); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, null); + gpgpu.deleteMatrixTexture(tex); + gpgpu.dispose(); + }); + it('sets the TEXTURE_[MIN|MAG]_FILTER parameters to NEAREST', function () { + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var textureConfig = gpgpu_util.getTextureConfig(gpgpu.gl); + var tex = gpgpu_util.createFloat32MatrixTexture(gpgpu.gl, 32, 32, textureConfig); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, tex); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_MIN_FILTER)) + .toEqual(gpgpu.gl.NEAREST); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_MAG_FILTER)) + .toEqual(gpgpu.gl.NEAREST); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, null); + gpgpu.deleteMatrixTexture(tex); + gpgpu.dispose(); + }); +}); +jasmine_util_1.describeWithFlags('gpgpu_util createPackedMatrixTexture', test_util_1.WEBGL_ENVS, function () { + it('sets the TEXTURE_WRAP S+T parameters to CLAMP_TO_EDGE', function () { + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var textureConfig = gpgpu_util.getTextureConfig(gpgpu.gl); + var tex = gpgpu_util.createPackedMatrixTexture(gpgpu.gl, 32, 32, textureConfig); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, tex); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_WRAP_S)) + .toEqual(gpgpu.gl.CLAMP_TO_EDGE); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_WRAP_T)) + .toEqual(gpgpu.gl.CLAMP_TO_EDGE); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, null); + gpgpu.deleteMatrixTexture(tex); + gpgpu.dispose(); + }); + it('sets the TEXTURE_[MIN|MAG]_FILTER parameters to NEAREST', function () { + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var textureConfig = gpgpu_util.getTextureConfig(gpgpu.gl); + var tex = gpgpu_util.createPackedMatrixTexture(gpgpu.gl, 32, 32, textureConfig); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, tex); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_MIN_FILTER)) + .toEqual(gpgpu.gl.NEAREST); + expect(gpgpu.gl.getTexParameter(gpgpu.gl.TEXTURE_2D, gpgpu.gl.TEXTURE_MAG_FILTER)) + .toEqual(gpgpu.gl.NEAREST); + gpgpu.gl.bindTexture(gpgpu.gl.TEXTURE_2D, null); + gpgpu.deleteMatrixTexture(tex); + gpgpu.dispose(); + }); +}); +//# sourceMappingURL=gpgpu_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js.map new file mode 100644 index 0000000..52205d1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/gpgpu_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gpgpu_util_test.js","sourceRoot":"","sources":["../../../src/kernels/webgl/gpgpu_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.d.ts new file mode 100644 index 0000000..186c911 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class LRNProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(xShape: number[], radius: number, bias: number, alpha: number, beta: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js new file mode 100644 index 0000000..788b819 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js @@ -0,0 +1,26 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var LRNProgram = (function () { + function LRNProgram(xShape, radius, bias, alpha, beta) { + this.variableNames = ['x']; + this.outputShape = []; + var rad = radius; + var maxD = xShape[3] - 1; + this.outputShape = xShape; + var powOperator; + var basis = "float(" + bias + ") + float(" + alpha + ") * sum"; + if (beta === 0.5) { + powOperator = "inversesqrt(" + basis + ")"; + } + else if (beta === 1.0) { + powOperator = "1.0/(" + basis + ")"; + } + else { + powOperator = "exp(log(" + basis + ") * float(-" + beta + "));"; + } + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -" + rad + "; j <= " + rad + "; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= " + maxD + ") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * " + powOperator + ";\n setOutput(val);\n }\n "; + } + return LRNProgram; +}()); +exports.LRNProgram = LRNProgram; +//# sourceMappingURL=lrn_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js.map new file mode 100644 index 0000000..175f38e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lrn_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/lrn_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,oBACI,MAAgB,EAAE,MAAc,EAAE,IAAY,EAAE,KAAa,EAC7D,IAAY;QANhB,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QACtB,gBAAW,GAAa,EAAE,CAAC;QAMzB,IAAM,GAAG,GAAG,MAAM,CAAC;QACnB,IAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAM1B,IAAI,WAAW,CAAC;QAChB,IAAM,KAAK,GAAG,WAAS,IAAI,kBAAa,KAAK,YAAS,CAAC;QACvD,IAAI,IAAI,KAAK,GAAG,EAAE;YAChB,WAAW,GAAG,iBAAe,KAAK,MAAG,CAAC;SACvC;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACvB,WAAW,GAAG,UAAQ,KAAK,MAAG,CAAC;SAChC;aAAM;YACL,WAAW,GAAG,aAAW,KAAK,mBAAc,IAAI,QAAK,CAAC;SACvD;QAED,IAAI,CAAC,QAAQ,GAAG,4QASI,GAAG,eAAU,GAAG,gFAEJ,IAAI,mIAKd,WAAW,8CAGhC,CAAC;IACJ,CAAC;IACH,iBAAC;AAAD,CAAC,AA/CD,IA+CC;AA/CY,gCAAU"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.d.ts new file mode 100644 index 0000000..e77237f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.d.ts @@ -0,0 +1,12 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class LRNGradProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + depthRadius: number; + bias: number; + alpha: number; + beta: number; + depth: number; + constructor(inputShape: number[], depthRadius: number, bias: number, alpha: number, beta: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js new file mode 100644 index 0000000..930b18b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js @@ -0,0 +1,18 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var LRNGradProgram = (function () { + function LRNGradProgram(inputShape, depthRadius, bias, alpha, beta) { + this.variableNames = ['inputImage', 'outputImage', 'dy']; + this.outputShape = []; + this.outputShape = inputShape; + this.depth = inputShape[3]; + this.depthRadius = depthRadius; + this.bias = bias; + this.alpha = alpha; + this.beta = beta; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < " + this.depth + "; ++d) {\n int depthBegin = int(max(0.0, float(d - " + depthRadius + ")));\n int depthEnd = int(min(float(" + this.depth + "),\n float(d + " + depthRadius + " + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = " + this.depth + ";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(" + alpha + ") * norm + float(" + bias + ");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(" + alpha + ")\n * float(" + beta + ")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * " + beta + ");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "; + } + return LRNGradProgram; +}()); +exports.LRNGradProgram = LRNGradProgram; +//# sourceMappingURL=lrn_grad_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js.map new file mode 100644 index 0000000..bbd1a9b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/lrn_grad_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lrn_grad_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/lrn_grad_gpu.ts"],"names":[],"mappings":";;AAEA;IAUE,wBACI,UAAoB,EAAE,WAAmB,EAAE,IAAY,EAAE,KAAa,EACtE,IAAY;QAXhB,kBAAa,GAAG,CAAC,YAAY,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;QACpD,gBAAW,GAAa,EAAE,CAAC;QAWzB,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,sNAQU,IAAI,CAAC,KAAK,oEACY,WAAW,qDACtB,IAAI,CAAC,KAAK,oCACzB,WAAW,kGAGC,IAAI,CAAC,KAAK,4aAevB,KAAK,yBAAoB,IAAI,wPAOb,KAAK,mCACpB,IAAI,mLAIY,IAAI,gSAczC,CAAC;IACJ,CAAC;IACH,qBAAC;AAAD,CAAC,AA5ED,IA4EC;AA5EY,wCAAc"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.d.ts new file mode 100644 index 0000000..5204f82 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.d.ts @@ -0,0 +1,8 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class MaxPool2DBackpropProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js new file mode 100644 index 0000000..8891c71 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js @@ -0,0 +1,19 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var MaxPool2DBackpropProgram = (function () { + function MaxPool2DBackpropProgram(convInfo) { + this.variableNames = ['dy', 'maxPos']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var lastIndex = filterHeight * filterWidth - 1; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = " + lastIndex + " - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * " + filterWidth + " + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return MaxPool2DBackpropProgram; +}()); +exports.MaxPool2DBackpropProgram = MaxPool2DBackpropProgram; +//# sourceMappingURL=max_pool_backprop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js.map new file mode 100644 index 0000000..c6a4290 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/max_pool_backprop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"max_pool_backprop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/max_pool_backprop_gpu.ts"],"names":[],"mappings":";;AAqBA;IAKE,kCAAY,QAAoB;QAJhC,kBAAa,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAK/B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC;QACpC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QAEzC,IAAM,MAAM,GAAG,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACvD,IAAM,OAAO,GAAG,WAAW,GAAG,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QAExD,IAAM,SAAS,GAAG,YAAY,GAAG,WAAW,GAAG,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,sCACa,MAAM,UAAK,OAAO,sdAcnB,YAAY,iEACI,YAAY,iDAExB,QAAQ,CAAC,SAAS,yIAKpB,WAAW,mEACK,WAAW,mDAEvB,QAAQ,CAAC,QAAQ,oNAOvB,SAAS,+LAIJ,WAAW,kMAQ3C,CAAC;IACJ,CAAC;IACH,+BAAC;AAAD,CAAC,AA/DD,IA+DC;AA/DY,4DAAwB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.d.ts new file mode 100644 index 0000000..c87bbc5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class MatMulProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(aShape: [number, number], bShape: [number, number], transposeA?: boolean, transposeB?: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js new file mode 100644 index 0000000..d0228ae --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js @@ -0,0 +1,27 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var MatMulProgram = (function () { + function MatMulProgram(aShape, bShape, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + this.variableNames = ['matrixA', 'matrixB']; + var outerShapeA = transposeA ? aShape[1] : aShape[0]; + var outerShapeB = transposeB ? bShape[0] : bShape[1]; + var sharedDim = transposeA ? aShape[0] : aShape[1]; + this.outputShape = [outerShapeA, outerShapeB]; + var aSnippetFromOffset = function (vec4Offset, indexVar) { + return transposeA ? indexVar + " + " + vec4Offset + ", aRow" : + "aRow, " + indexVar + " + " + vec4Offset; + }; + var bSnippetFromOffset = function (vec4Offset, indexVar) { + return transposeB ? "bCol, " + indexVar + " + " + vec4Offset : + indexVar + " + " + vec4Offset + ", bCol"; + }; + var sharedDimNearestVec4 = Math.floor(sharedDim / 4) * 4; + var sharedDimVec4Remainder = sharedDim % 4; + this.userCode = " float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < " + sharedDimNearestVec4 + "; i += 4) {\n vec4 a = vec4(\n getMatrixA(" + aSnippetFromOffset(0, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(1, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(2, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(3, 'i') + ")\n );\n vec4 b = vec4(\n getMatrixB(" + bSnippetFromOffset(0, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(1, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(2, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(3, 'i') + ")\n );\n\n result += dot(a, b);\n }\n\n if (" + (sharedDimVec4Remainder === 1) + ") {\n result += getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + ") *\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + ");\n } else if (" + (sharedDimVec4Remainder === 2) + ") {\n vec2 a = vec2(\n getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(1, sharedDimNearestVec4) + ")\n );\n vec2 b = vec2(\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(1, sharedDimNearestVec4) + ")\n );\n result += dot(a, b);\n } else if (" + (sharedDimVec4Remainder === 3) + ") {\n vec3 a = vec3(\n getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(1, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(2, sharedDimNearestVec4) + ")\n );\n vec3 b = vec3(\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(1, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(2, sharedDimNearestVec4) + ")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "; + } + return MatMulProgram; +}()); +exports.MatMulProgram = MatMulProgram; +//# sourceMappingURL=mulmat_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js.map new file mode 100644 index 0000000..8e89246 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"mulmat_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/mulmat_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,uBACI,MAAwB,EAAE,MAAwB,EAAE,UAAkB,EACtE,UAAkB;QADkC,2BAAA,EAAA,kBAAkB;QACtE,2BAAA,EAAA,kBAAkB;QANtB,kBAAa,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAOrC,IAAM,WAAW,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvD,IAAM,WAAW,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvD,IAAM,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,WAAW,GAAG,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QAE9C,IAAM,kBAAkB,GAAG,UAAC,UAAkB,EAAE,QAAuB;YACnE,OAAA,UAAU,CAAC,CAAC,CAAI,QAAQ,WAAM,UAAU,WAAQ,CAAC,CAAC;gBACrC,WAAS,QAAQ,WAAM,UAAY;QADhD,CACgD,CAAC;QACrD,IAAM,kBAAkB,GAAG,UAAC,UAAkB,EAAE,QAAuB;YACnE,OAAA,UAAU,CAAC,CAAC,CAAC,WAAS,QAAQ,WAAM,UAAY,CAAC,CAAC;gBAClC,QAAQ,WAAM,UAAU,WAAQ;QADhD,CACgD,CAAC;QAErD,IAAM,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3D,IAAM,sBAAsB,GAAG,SAAS,GAAG,CAAC,CAAC;QAE7C,IAAI,CAAC,QAAQ,GAAG,oGAEQ,oBAAoB,kEAEzB,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,oEAG1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,iCAC1B,kBAAkB,CAAC,CAAC,EAAE,GAAG,CAAC,6EAMrC,sBAAsB,KAAK,CAAC,2CACT,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,kCACnD,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,8BAC/C,sBAAsB,KAAK,CAAC,2DAExB,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,oEAG3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,uEAG/C,sBAAsB,KAAK,CAAC,2DAExB,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,oEAG3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,iCAC3C,kBAAkB,CAAC,CAAC,EAAE,oBAAoB,CAAC,mNAY7D,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AA9ED,IA8EC;AA9EY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.d.ts new file mode 100644 index 0000000..c715fd6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUContext } from './gpgpu_context'; +export declare enum MatrixOrientation { + REGULAR = 0, + TRANSPOSED = 1 +} +export declare function getFragmentShaderSource(sharedDimension: number, aOrientation: MatrixOrientation, bOrientation: MatrixOrientation): string; +export declare function multiplyMatrixPacked(gpgpu: GPGPUContext, multiplyProgram: WebGLProgram, a: WebGLTexture, b: WebGLTexture, result: WebGLTexture, resultShapeRowCol: [number, number]): void; +export declare function uploadMultiplyMatrixPackedDownload(a: Float32Array, aShapeRowCol: [number, number], b: Float32Array, bShapeRowCol: [number, number], aOrientation?: MatrixOrientation, bOrientation?: MatrixOrientation): Float32Array; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js new file mode 100644 index 0000000..9b5061c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js @@ -0,0 +1,64 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var gpgpu_context_1 = require("./gpgpu_context"); +var webgl_util = require("./webgl_util"); +var MatrixOrientation; +(function (MatrixOrientation) { + MatrixOrientation[MatrixOrientation["REGULAR"] = 0] = "REGULAR"; + MatrixOrientation[MatrixOrientation["TRANSPOSED"] = 1] = "TRANSPOSED"; +})(MatrixOrientation = exports.MatrixOrientation || (exports.MatrixOrientation = {})); +function getFragmentShaderSource(sharedDimension, aOrientation, bOrientation) { + var sharedDimensionPacked = Math.ceil(sharedDimension / 2); + var aSample = (aOrientation === MatrixOrientation.REGULAR) ? + 'center, resultUV.t' : + 'resultUV.t, center'; + var bSample = (bOrientation === MatrixOrientation.REGULAR) ? + 'resultUV.s, center' : + 'center, resultUV.s'; + var aSwizzle = (aOrientation === MatrixOrientation.REGULAR) ? ['a.xxzz', 'a.yyww'] : + ['a.xxyy', 'a.zzww']; + var bSwizzle = (bOrientation === MatrixOrientation.REGULAR) ? ['b.xyxy', 'b.zwzw'] : + ['b.xzxz', 'b.ywyw']; + return "\n precision highp float;\n uniform sampler2D matrixA;\n uniform sampler2D matrixB;\n varying vec2 resultUV;\n\n const float sharedDimension = " + sharedDimensionPacked + ".0;\n\n vec4 dot2x2ARowBCol() {\n vec4 result = vec4(0, 0, 0, 0);\n for (int ii = 0; ii < " + sharedDimensionPacked + "; ii++) {\n float i = float(ii);\n float center = (i + 0.5) / sharedDimension;\n vec4 a = texture2D(matrixA, vec2(" + aSample + "));\n vec4 b = texture2D(matrixB, vec2(" + bSample + "));\n result +=\n (" + aSwizzle[0] + " * " + bSwizzle[0] + ") + (" + aSwizzle[1] + " * " + bSwizzle[1] + ");\n }\n return result;\n }\n\n void main() {\n gl_FragColor = dot2x2ARowBCol();\n }"; +} +exports.getFragmentShaderSource = getFragmentShaderSource; +function multiplyMatrixPacked(gpgpu, multiplyProgram, a, b, result, resultShapeRowCol) { + gpgpu.setOutputPackedMatrixTexture(result, resultShapeRowCol[0], resultShapeRowCol[1]); + gpgpu.setProgram(multiplyProgram); + var matrixASamplerLocation = webgl_util.getProgramUniformLocationOrThrow(gpgpu.gl, multiplyProgram, 'matrixA'); + var matrixBSamplerLocation = webgl_util.getProgramUniformLocationOrThrow(gpgpu.gl, multiplyProgram, 'matrixB'); + gpgpu.setInputMatrixTexture(a, matrixASamplerLocation, 0); + gpgpu.setInputMatrixTexture(b, matrixBSamplerLocation, 1); + gpgpu.executeProgram(); +} +exports.multiplyMatrixPacked = multiplyMatrixPacked; +function uploadMultiplyMatrixPackedDownload(a, aShapeRowCol, b, bShapeRowCol, aOrientation, bOrientation) { + if (aOrientation === void 0) { aOrientation = MatrixOrientation.REGULAR; } + if (bOrientation === void 0) { bOrientation = MatrixOrientation.REGULAR; } + var resultNumRows = (aOrientation === MatrixOrientation.REGULAR) ? + aShapeRowCol[0] : + aShapeRowCol[1]; + var resultNumCols = (bOrientation === MatrixOrientation.REGULAR) ? + bShapeRowCol[1] : + bShapeRowCol[0]; + var sharedDimension = (aOrientation === MatrixOrientation.REGULAR) ? + aShapeRowCol[1] : + aShapeRowCol[0]; + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var program = gpgpu.createProgram(getFragmentShaderSource(sharedDimension, aOrientation, bOrientation)); + var aTexture = gpgpu.createPackedMatrixTexture(aShapeRowCol[0], aShapeRowCol[1]); + var bTexture = gpgpu.createPackedMatrixTexture(bShapeRowCol[0], bShapeRowCol[1]); + var resultTexture = gpgpu.createPackedMatrixTexture(resultNumRows, resultNumCols); + gpgpu.uploadMatrixToPackedTexture(aTexture, aShapeRowCol[0], aShapeRowCol[1], a); + gpgpu.uploadMatrixToPackedTexture(bTexture, bShapeRowCol[0], bShapeRowCol[1], b); + multiplyMatrixPacked(gpgpu, program, aTexture, bTexture, resultTexture, [resultNumRows, resultNumCols]); + var result = gpgpu.downloadMatrixFromPackedTexture(resultTexture, resultNumRows, resultNumCols); + gpgpu.deleteMatrixTexture(aTexture); + gpgpu.deleteMatrixTexture(bTexture); + gpgpu.deleteMatrixTexture(resultTexture); + gpgpu.deleteProgram(program); + gpgpu.dispose(); + return result; +} +exports.uploadMultiplyMatrixPackedDownload = uploadMultiplyMatrixPackedDownload; +//# sourceMappingURL=mulmat_packed_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js.map new file mode 100644 index 0000000..66cf40e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"mulmat_packed_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/mulmat_packed_gpu.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js new file mode 100644 index 0000000..b7e1843 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js @@ -0,0 +1,322 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var jasmine_util_1 = require("../../jasmine_util"); +var test_util_1 = require("../../test_util"); +var gpgpu_context_1 = require("./gpgpu_context"); +var mulmat_packed_gpu = require("./mulmat_packed_gpu"); +var mulmat_packed_gpu_1 = require("./mulmat_packed_gpu"); +var DOWNLOAD_FLOAT_ENVS = { + 'WEBGL_DOWNLOAD_FLOAT_ENABLED': true +}; +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (1x1 * 1x1)', DOWNLOAD_FLOAT_ENVS, function () { + it('returns a 1x1 matrix', function () { + var a = new Float32Array([0]); + var b = new Float32Array([0]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result.length).toEqual(1); + }); + it('returns [0] when multiplying [0] by [0]', function () { + var a = new Float32Array([0]); + var b = new Float32Array([0]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result[0]).toEqual(0); + }); + it('returns [1] when multiplying [1] by [1]', function () { + var a = new Float32Array([1]); + var b = new Float32Array([1]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result[0]).toEqual(1); + }); + it('returns [-1] when multiplying [1] by [-1]', function () { + var a = new Float32Array([1]); + var b = new Float32Array([-1]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result[0]).toEqual(-1); + }); + it('returns [4.08] when multiplying [1.2] by [3.4]', function () { + var a = new Float32Array([1.2]); + var b = new Float32Array([3.4]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + test_util_1.expectNumbersClose(result[0], 4.08); + }); + it('returns [356000] when multiplying [356] by [1000]', function () { + var a = new Float32Array([356]); + var b = new Float32Array([1000]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result[0]).toEqual(356000); + }); + it('returns [-31415926] when multiplying [-3.1415926] by [10000000]', function () { + var a = new Float32Array([-3.1415926]); + var b = new Float32Array([10000000]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1]); + expect(result[0]).toEqual(-31415926); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (dot product)', DOWNLOAD_FLOAT_ENVS, function () { + it('returns a 1x1 matrix', function () { + var a = new Float32Array(5); + var b = new Float32Array(5); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, a.length], b, [b.length, 1]); + expect(result.length).toEqual(1); + }); + it('returns zero when one vector is all zeroes', function () { + var a = new Float32Array(5); + var b = new Float32Array([1, 2, 3, 4, 5]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, a.length], b, [b.length, 1]); + expect(result[0]).toEqual(0); + }); + it('returns the sum of b when a is all ones', function () { + var a = new Float32Array([1, 1, 1, 1, 1]); + var b = new Float32Array([0, 1, 2, 3, 100]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, a.length], b, [b.length, 1]); + expect(result[0]).toEqual(106); + }); + it('computes the dot product of a and b', function () { + var a = new Float32Array([10, 20, 30, 40, 50]); + var b = new Float32Array([0.5, 1.1, 12.4, 32.5, -123.98]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, a.length], b, [b.length, 1]); + var expected = cpuDotProduct(a, b); + test_util_1.expectNumbersClose(result[0], expected); + }); + it('computes a dot product on very large vectors', function () { + var a = randomArrayInRange(2048, -1, 1); + var b = randomArrayInRange(2048, -1, 1); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, a.length], b, [b.length, 1]); + var expected = cpuDotProduct(a, b); + test_util_1.expectNumbersClose(result[0], expected); + }); +}); +function cpuMul2x2(a, b) { + if (a.length !== 4 || b.length !== 4) { + throw new Error('a and b must have 4 elements.'); + } + var result = new Float32Array(4); + result[0] = (a[0] * b[0]) + (a[1] * b[2]); + result[1] = (a[0] * b[1]) + (a[1] * b[3]); + result[2] = (a[2] * b[0]) + (a[3] * b[2]); + result[3] = (a[2] * b[1]) + (a[3] * b[3]); + return result; +} +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (2x2 * 2x2)', DOWNLOAD_FLOAT_ENVS, function () { + it('returns a 2x2 matrix', function () { + var a = new Float32Array([0, 0, 0, 0]); + var b = new Float32Array([0, 0, 0, 0]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result.length).toEqual(4); + }); + it('returns the identity when multiplying two identity matrices', function () { + var a = makeIdentity(2); + var b = makeIdentity(2); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(cpuMul2x2(a, b)); + }); + it('returns [0] when A is [0]', function () { + var a = new Float32Array([0, 0, 0, 0]); + var b = new Float32Array([1, 2, 3, 4]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(a); + }); + it('returns [0] when B is [0]', function () { + var a = new Float32Array([1, 2, 3, 4]); + var b = new Float32Array(4); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(b); + }); + it('returns B when A is identity', function () { + var a = makeIdentity(2); + var b = new Float32Array([11, -22, 33.333, -44.44444]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(b); + }); + it('returns A when B is identity', function () { + var a = new Float32Array([11, -22, 33.333, -44.44444]); + var b = makeIdentity(2); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(a); + }); + it('returns the product of A and B when non-identity', function () { + var a = new Float32Array([10000.02, -1.2, 3.14159, -2345.1234]); + var b = new Float32Array([-23.45, 0.01234, 100, 2.5]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2]); + expect(result).toEqual(cpuMul2x2(a, b)); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (different shapes)', DOWNLOAD_FLOAT_ENVS, function () { + it('returns a 4x1 when multiplying a 4x4 with a 4x1', function () { + var a = new Float32Array(16); + var b = new Float32Array(4); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [4, 4], b, [4, 1]); + expect(result.length).toEqual(4); + }); + it('returns B (4x1) when A (4x4) is I', function () { + var a = makeIdentity(4); + var b = new Float32Array([1, 2, 3, 4]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [4, 4], b, [4, 1]); + expect(result).toEqual(b); + }); + it('4x2 * 2x2', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8]); + var b = new Float32Array([9, 10, 11, 12]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [4, 2], b, [2, 2]); + var expected = cpuMultiplyMatrix(a, 4, 2, b, 2, 2); + test_util_1.expectArraysClose(result, expected); + }); + it('multiplies a 4x1 by a non-identity 4x4', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]); + var b = new Float32Array([1, 2, 3, 4]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [4, 4], b, [4, 1]); + expect(result).toEqual(cpuMultiplyMatrix(a, 4, 4, b, 4, 1)); + }); + it('returns a 2x3 when multiplying a 2x4 by a 4x3', function () { + var a = new Float32Array(8); + var b = new Float32Array(12); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 4], b, [4, 3]); + expect(result.length).toEqual(6); + }); + it('multiplies A (2x4) by B(4x3)', function () { + var a = new Float32Array([0.1, 3.2, -4.5, 11.78, -0.234, -2.999, 7, 9]); + var b = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 4], b, [4, 3]); + var expected = cpuMultiplyMatrix(a, 2, 4, b, 4, 3); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (large matrices)', DOWNLOAD_FLOAT_ENVS, function () { + it('returns 128x128 when multiplying 2 128x128s', function () { + var a = new Float32Array(128 * 128); + var b = new Float32Array(128 * 128); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [128, 128], b, [128, 128]); + expect(result.length).toEqual(128 * 128); + }); + it('multiplies 2 128x128s', function () { + var a = randomArrayInRange(128 * 128, -1, 1); + var b = randomArrayInRange(128 * 128, -1, 1); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [128, 128], b, [128, 128]); + var expected = cpuMultiplyMatrix(a, 128, 128, b, 128, 128); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (multiple matrices)', DOWNLOAD_FLOAT_ENVS, function () { + it('4x2 * 2x12 * 12x1 === 4x1', function () { + var aData = new Float32Array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]); + var bData = new Float32Array([ + 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 + ]); + var cData = new Float32Array([ + -0.1, -0.2, -0.3, -0.4, -0.5, -0.6, -0.7, -0.8, -0.9, -1.0, -1.1, -1.2 + ]); + var gpgpu = new gpgpu_context_1.GPGPUContext(); + var axbProgram = gpgpu.createProgram(mulmat_packed_gpu.getFragmentShaderSource(2, mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.REGULAR)); + var abxcProgram = gpgpu.createProgram(mulmat_packed_gpu.getFragmentShaderSource(12, mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.REGULAR)); + var a = gpgpu.createPackedMatrixTexture(4, 2); + var b = gpgpu.createPackedMatrixTexture(2, 12); + var ab = gpgpu.createPackedMatrixTexture(4, 12); + var c = gpgpu.createPackedMatrixTexture(12, 1); + var r = gpgpu.createPackedMatrixTexture(4, 1); + gpgpu.uploadMatrixToPackedTexture(a, 4, 2, aData); + gpgpu.uploadMatrixToPackedTexture(b, 2, 12, bData); + gpgpu.uploadMatrixToPackedTexture(c, 12, 1, cData); + mulmat_packed_gpu.multiplyMatrixPacked(gpgpu, axbProgram, a, b, ab, [4, 12]); + mulmat_packed_gpu.multiplyMatrixPacked(gpgpu, abxcProgram, ab, c, r, [4, 1]); + var result = gpgpu.downloadMatrixFromPackedTexture(r, 4, 1); + var expected = cpuMultiplyMatrix(cpuMultiplyMatrix(aData, 4, 2, bData, 2, 12), 4, 12, cData, 12, 1); + test_util_1.expectArraysClose(result, expected); + gpgpu.deleteMatrixTexture(a); + gpgpu.deleteMatrixTexture(b); + gpgpu.deleteMatrixTexture(ab); + gpgpu.deleteMatrixTexture(c); + gpgpu.deleteMatrixTexture(r); + gpgpu.deleteProgram(axbProgram); + gpgpu.deleteProgram(abxcProgram); + gpgpu.dispose(); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu A * B^t', DOWNLOAD_FLOAT_ENVS, function () { + it('1x1 * 1x1', function () { + var a = new Float32Array([2]); + var b = new Float32Array([3]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [1, 1], b, [1, 1], mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED); + expect(result[0]).toEqual(6); + }); + it('2x2 * 2x2', function () { + var a = new Float32Array([1, 2, 3, 4]); + var b = new Float32Array([5, 6, 7, 8]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 2], b, [2, 2], mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED); + var bt = new Float32Array([b[0], b[2], b[1], b[3]]); + var expected = cpuMultiplyMatrix(a, 2, 2, bt, 2, 2); + test_util_1.expectArraysClose(result, expected); + }); + it('2x4 * 4x2', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8]); + var b = new Float32Array([9, 10, 11, 12, 13, 14, 15, 16]); + var result = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 4], b, [2, 4], mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED); + var bt = new Float32Array([b[0], b[4], b[1], b[5], b[2], b[6], b[3], b[7]]); + var expected = cpuMultiplyMatrix(a, 2, 4, bt, 4, 2); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('mulmat_packed_gpu (transposed versions)', DOWNLOAD_FLOAT_ENVS, function () { + it('A * B^t', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6]); + var b = new Float32Array([1, 0, 2, 4, 3, 0]); + var c = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 3], b, [2, 3], mulmat_packed_gpu_1.MatrixOrientation.REGULAR, mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED); + var expected = new Float32Array([7, 10, 16, 31]); + expect(c).toEqual(expected); + }); + it('A^t * B', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6]); + var b = new Float32Array([1, 0, 2, 4, 3, 0]); + var c = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [2, 3], b, [2, 3], mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED, mulmat_packed_gpu_1.MatrixOrientation.REGULAR); + var expected = new Float32Array([17, 12, 2, 22, 15, 4, 27, 18, 6]); + expect(c).toEqual(expected); + }); + it('A^t * B^t', function () { + var a = new Float32Array([1, 2, 3, 4, 5, 6]); + var b = new Float32Array([1, 0, 2, 4, 3, 0]); + var c = mulmat_packed_gpu.uploadMultiplyMatrixPackedDownload(a, [3, 2], b, [2, 3], mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED, mulmat_packed_gpu_1.MatrixOrientation.TRANSPOSED); + var expected = new Float32Array([11, 13, 14, 20]); + expect(c).toEqual(expected); + }); +}); +function randomArrayInRange(n, minValue, maxValue) { + var v = new Float32Array(n); + var range = maxValue - minValue; + for (var i = 0; i < n; ++i) { + v[i] = (Math.random() * range) + minValue; + } + return v; +} +function makeIdentity(n) { + var i = new Float32Array(n * n); + for (var j = 0; j < n; ++j) { + i[(j * n) + j] = 1; + } + return i; +} +function cpuMultiplyMatrix(a, aRow, aCol, b, bRow, bCol) { + var result = new Float32Array(aRow * bCol); + for (var r = 0; r < aRow; ++r) { + var aOffset = (r * aCol); + var cOffset = (r * bCol); + for (var c = 0; c < bCol; ++c) { + var d = 0; + for (var k = 0; k < aCol; ++k) { + d += a[aOffset + k] * b[(k * bCol) + c]; + } + result[cOffset + c] = d; + } + } + return result; +} +function cpuDotProduct(a, b) { + if (a.length !== b.length) { + throw new Error('cpuDotProduct: incompatible vectors.'); + } + var d = 0; + for (var i = 0; i < a.length; ++i) { + d += a[i] * b[i]; + } + return d; +} +//# sourceMappingURL=mulmat_packed_gpu_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js.map new file mode 100644 index 0000000..f11e701 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/mulmat_packed_gpu_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"mulmat_packed_gpu_test.js","sourceRoot":"","sources":["../../../src/kernels/webgl/mulmat_packed_gpu_test.ts"],"names":[],"mappings":";;AAiBA,mDAAqD;AACrD,6CAAsE;AACtE,iDAA6C;AAC7C,uDAAyD;AACzD,yDAAsD;AAEtD,IAAM,mBAAmB,GAAG;IAC1B,8BAA8B,EAAE,IAAI;CACrC,CAAC;AAEF,gCAAiB,CAAC,+BAA+B,EAAE,mBAAmB,EAAE;IACtE,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE;QAC5C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE;QAC5C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE;QACnD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAClC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAClC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,8BAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE;QACtD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAClC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACnC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;QACpE,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QACzC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QACvC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CACb,iCAAiC,EAAE,mBAAmB,EAAE;IACtD,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5C,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE;QAC5C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;QACxC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACjD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;QAC5D,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,IAAM,QAAQ,GAAG,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrC,8BAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE;QACjD,IAAM,CAAC,GAAiB,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACxD,IAAM,CAAC,GAAiB,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACxD,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,IAAM,QAAQ,GAAG,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrC,8BAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEP,mBAAmB,CAAe,EAAE,CAAe;IACjD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;QACpC,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IASD,IAAM,MAAM,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;IACnC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,gCAAiB,CAAC,+BAA+B,EAAE,mBAAmB,EAAE;IACtE,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE;QAChE,IAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;QACzD,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;QACzD,IAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAClE,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACxD,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CACb,sCAAsC,EAAE,mBAAmB,EAAE;IAC3D,EAAE,CAAC,iDAAiD,EAAE;QACpD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QAC/B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAC5C,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrD,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE;QAC3C,IAAM,CAAC,GAAG,IAAI,YAAY,CACtB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAC7D,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE;QAClD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QAC/B,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,CAAC,GACH,IAAI,YAAY,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACpE,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrD,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEP,gCAAiB,CACb,oCAAoC,EAAE,mBAAmB,EAAE;IACzD,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QACtC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QACtC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,CAAC,GAAG,kBAAkB,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,kBAAkB,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAClC,IAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC7D,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEP,gCAAiB,CACb,uCAAuC,EAAE,mBAAmB,EAAE;IAC5D,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GACP,IAAI,YAAY,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAC/D,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC;YAC7B,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,CAAC,EAAG,EAAE,EAAE,EAAE,EAAE,EAAE;YAC9C,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;SAC/C,CAAC,CAAC;QACH,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC;YAC7B,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG;SACvE,CAAC,CAAC;QAEH,IAAM,KAAK,GAAG,IAAI,4BAAY,EAAE,CAAC;QAEjC,IAAM,UAAU,GACZ,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,uBAAuB,CACzD,CAAC,EAAE,qCAAiB,CAAC,OAAO,EAAE,qCAAiB,CAAC,OAAO,CAAC,CAAC,CAAC;QAClE,IAAM,WAAW,GACb,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,uBAAuB,CACzD,EAAE,EAAE,qCAAiB,CAAC,OAAO,EAAE,qCAAiB,CAAC,OAAO,CAAC,CAAC,CAAC;QAEnE,IAAM,CAAC,GAAiB,KAAK,CAAC,yBAAyB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9D,IAAM,CAAC,GAAiB,KAAK,CAAC,yBAAyB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/D,IAAM,EAAE,GAAiB,KAAK,CAAC,yBAAyB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAChE,IAAM,CAAC,GAAiB,KAAK,CAAC,yBAAyB,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QAC/D,IAAM,CAAC,GAAiB,KAAK,CAAC,yBAAyB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAE9D,KAAK,CAAC,2BAA2B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;QAClD,KAAK,CAAC,2BAA2B,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QACnD,KAAK,CAAC,2BAA2B,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;QAEnD,iBAAiB,CAAC,oBAAoB,CAClC,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1C,iBAAiB,CAAC,oBAAoB,CAClC,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1C,IAAM,MAAM,GAAG,KAAK,CAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9D,IAAM,QAAQ,GAAG,iBAAiB,CAC9B,iBAAiB,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACvE,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAEpC,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC7B,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC7B,KAAK,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;QAC9B,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC7B,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC7B,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAChC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QACjC,KAAK,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEP,gCAAiB,CAAC,2BAA2B,EAAE,mBAAmB,EAAE;IAClE,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,OAAO,EAC/C,qCAAiB,CAAC,UAAU,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,OAAO,EAC/C,qCAAiB,CAAC,UAAU,CAAC,CAAC;QAElC,IAAM,EAAE,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtD,IAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACtD,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QAad,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAC5D,IAAM,MAAM,GAAG,iBAAiB,CAAC,kCAAkC,CAC/D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,OAAO,EAC/C,qCAAiB,CAAC,UAAU,CAAC,CAAC;QAElC,IAAM,EAAE,GACJ,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACvE,IAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACtD,6BAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CACb,yCAAyC,EAAE,mBAAmB,EAAE;IAC9D,EAAE,CAAC,SAAS,EAAE;QACZ,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,iBAAiB,CAAC,kCAAkC,CAC1D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,OAAO,EAC/C,qCAAiB,CAAC,UAAU,CAAC,CAAC;QAClC,IAAM,QAAQ,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QACZ,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,iBAAiB,CAAC,kCAAkC,CAC1D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,UAAU,EAClD,qCAAiB,CAAC,OAAO,CAAC,CAAC;QAC/B,IAAM,QAAQ,GAAG,IAAI,YAAY,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,CAAC,GAAG,iBAAiB,CAAC,kCAAkC,CAC1D,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,qCAAiB,CAAC,UAAU,EAClD,qCAAiB,CAAC,UAAU,CAAC,CAAC;QAClC,IAAM,QAAQ,GAAG,IAAI,YAAY,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACpD,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEP,4BACI,CAAS,EAAE,QAAgB,EAAE,QAAgB;IAC/C,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9B,IAAM,KAAK,GAAG,QAAQ,GAAG,QAAQ,CAAC;IAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;QAC1B,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,GAAG,QAAQ,CAAC;KAC3C;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,sBAAsB,CAAS;IAC7B,IAAM,CAAC,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;QAC1B,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;KACpB;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,2BACI,CAAe,EAAE,IAAY,EAAE,IAAY,EAAE,CAAe,EAAE,IAAY,EAC1E,IAAY;IACd,IAAM,MAAM,GAAG,IAAI,YAAY,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IAC7C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,EAAE;QAC7B,IAAM,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QAC3B,IAAM,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,EAAE;YAC7B,IAAI,CAAC,GAAG,CAAC,CAAC;YACV,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,EAAE;gBAC7B,CAAC,IAAI,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;aACzC;YACD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;SACzB;KACF;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,uBAAuB,CAAe,EAAE,CAAe;IACrD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IACD,IAAI,CAAC,GAAG,CAAC,CAAC;IACV,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;QACjC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;KAClB;IACD,OAAO,CAAC,CAAC;AACX,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.d.ts new file mode 100644 index 0000000..76673d1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.d.ts @@ -0,0 +1,10 @@ +import { GPGPUContext } from './gpgpu_context'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class MultinomialProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + seedLoc: WebGLUniformLocation; + constructor(batchSize: number, numOutcomes: number, numSamples: number); + getCustomSetupFunc(seed: number): (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js new file mode 100644 index 0000000..d26cc7b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js @@ -0,0 +1,21 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var MultinomialProgram = (function () { + function MultinomialProgram(batchSize, numOutcomes, numSamples) { + this.variableNames = ['probs']; + this.outputShape = [batchSize, numSamples]; + this.userCode = "\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < " + (numOutcomes - 1) + "; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(" + (numOutcomes - 1) + "));\n }\n "; + } + MultinomialProgram.prototype.getCustomSetupFunc = function (seed) { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.seedLoc == null) { + _this.seedLoc = gpgpu.getUniformLocation(webGLProgram, 'seed'); + } + gpgpu.gl.uniform1f(_this.seedLoc, seed); + }; + }; + return MultinomialProgram; +}()); +exports.MultinomialProgram = MultinomialProgram; +//# sourceMappingURL=multinomial_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js.map new file mode 100644 index 0000000..74bd948 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/multinomial_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"multinomial_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/multinomial_gpu.ts"],"names":[],"mappings":";;AAoBA;IAQE,4BAAY,SAAiB,EAAE,WAAmB,EAAE,UAAkB;QAPtE,kBAAa,GAAG,CAAC,OAAO,CAAC,CAAC;QAQxB,IAAI,CAAC,WAAW,GAAG,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;QAE3C,IAAI,CAAC,QAAQ,GAAG,gOAUU,WAAW,GAAG,CAAC,4PAUnB,WAAW,GAAG,CAAC,wBAEpC,CAAC;IACJ,CAAC;IAED,+CAAkB,GAAlB,UAAmB,IAAY;QAA/B,iBAOC;QANC,OAAO,UAAC,KAAmB,EAAE,YAA0B;YACrD,IAAI,KAAI,CAAC,OAAO,IAAI,IAAI,EAAE;gBACxB,KAAI,CAAC,OAAO,GAAG,KAAK,CAAC,kBAAkB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;aAC/D;YACD,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACzC,CAAC,CAAC;IACJ,CAAC;IACH,yBAAC;AAAD,CAAC,AA5CD,IA4CC;AA5CY,gDAAkB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.d.ts new file mode 100644 index 0000000..fbcf404 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class OneHotProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + seedLoc: WebGLUniformLocation; + constructor(numIndices: number, depth: number, onValue: number, offValue: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js new file mode 100644 index 0000000..4e0e660 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js @@ -0,0 +1,12 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var OneHotProgram = (function () { + function OneHotProgram(numIndices, depth, onValue, offValue) { + this.variableNames = ['indices']; + this.outputShape = [numIndices, depth]; + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(" + offValue + "), float(" + onValue + "),\n float(index == coords.y)));\n }\n "; + } + return OneHotProgram; +}()); +exports.OneHotProgram = OneHotProgram; +//# sourceMappingURL=onehot_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js.map new file mode 100644 index 0000000..69fa907 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/onehot_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"onehot_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/onehot_gpu.ts"],"names":[],"mappings":";;AAmBA;IAQE,uBACI,UAAkB,EAAE,KAAa,EAAE,OAAe,EAAE,QAAgB;QARxE,kBAAa,GAAG,CAAC,SAAS,CAAC,CAAC;QAS1B,IAAI,CAAC,WAAW,GAAG,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAEvC,IAAI,CAAC,QAAQ,GAAG,qJAIU,QAAQ,iBAAY,OAAO,yEAGpD,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AArBD,IAqBC;AArBY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.d.ts new file mode 100644 index 0000000..04b8862 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class PadProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(xShape: number[], paddings: Array<[number, number]>, constantValue: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js new file mode 100644 index 0000000..8f274b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var PadProgram = (function () { + function PadProgram(xShape, paddings, constantValue) { + this.variableNames = ['x']; + this.outputShape = paddings.map(function (p, i) { return p[0] + xShape[i] + p[1]; }); + var rank = xShape.length; + var type = shader_compiler_1.getCoordsDataType(rank); + var start = paddings.map(function (p) { return p[0]; }).join(','); + var end = paddings.map(function (p, i) { return p[0] + xShape[i]; }).join(','); + var unpackedCoords = ['coords[0]', 'coords[1]', 'coords[2]', 'coords[3]'].slice(0, rank); + if (rank === 1) { + this.userCode = "\n int start = " + start + ";\n int end = " + end + ";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(" + constantValue + "));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "; + return; + } + this.userCode = "\n " + type + " start = " + type + "(" + start + ");\n " + type + " end = " + type + "(" + end + ");\n\n void main() {\n " + type + " outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(" + constantValue + "));\n } else {\n " + type + " coords = outC - start;\n setOutput(getX(" + unpackedCoords + "));\n }\n }\n "; + } + return PadProgram; +}()); +exports.PadProgram = PadProgram; +//# sourceMappingURL=pad_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js.map new file mode 100644 index 0000000..e60edfe --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pad_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pad_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/pad_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAKE,oBACI,MAAgB,EAAE,QAAiC,EACnD,aAAqB;QANzB,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAOpB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,GAAG,CAC3B,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,CAAC,GAAmB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAvC,CAAuC,CAAgB,CAAC;QACtE,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;QAC3B,IAAM,IAAI,GAAG,mCAAiB,CAAC,IAAI,CAAC,CAAC;QAErC,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,CAAC,EAAJ,CAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChD,IAAM,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,EAAhB,CAAgB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAM,cAAc,GACf,CAAC,WAAW,EAAE,WAAW,EAAE,WAAW,EAAC,WAAW,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAExE,IAAI,IAAI,KAAK,CAAC,EAAE;YACd,IAAI,CAAC,QAAQ,GAAG,2BACA,KAAK,6BACP,GAAG,uJAKO,aAAa,wGAKpC,CAAC;YACF,OAAO;SACR;QACD,IAAI,CAAC,QAAQ,GAAG,aACZ,IAAI,iBAAY,IAAI,SAAI,KAAK,kBAC7B,IAAI,eAAU,IAAI,SAAI,GAAG,2CAGvB,IAAI,6IAEc,aAAa,yCAE7B,IAAI,0DACW,cAAc,kCAGpC,CAAC;IACJ,CAAC;IACH,iBAAC;AAAD,CAAC,AAjDD,IAiDC;AAjDY,gCAAU"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.d.ts new file mode 100644 index 0000000..03d06d1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.d.ts @@ -0,0 +1,8 @@ +import { Conv2DInfo } from '../../ops/conv_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class Pool2DProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(convInfo: Conv2DInfo, poolType: 'max' | 'avg', computePositions: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js new file mode 100644 index 0000000..5ff18ed --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js @@ -0,0 +1,40 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Pool2DProgram = (function () { + function Pool2DProgram(convInfo, poolType, computePositions) { + this.variableNames = ['x']; + if (poolType === 'avg' && computePositions) { + throw new Error('Cannot compute positions for average pool.'); + } + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + this.outputShape = convInfo.outShape; + var isAvgPool = poolType === 'avg'; + var initializationValue = '0.0'; + if (!isAvgPool) { + initializationValue = '-1.0 / 0.0'; + } + if (computePositions) { + var compareOp_1 = '>='; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value " + compareOp_1 + " currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * " + filterWidth + " + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n "; + return; + } + var compareOp = 'max'; + var returnValue = poolType + "(" + poolType + "(" + poolType + "(" + + 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])'; + if (poolType === 'avg') { + returnValue = "avgValue / count"; + } + var filterWidthNearestVec4 = Math.floor(filterWidth / 4) * 4; + var filterWidthVec4Remainder = filterWidth % 4; + var updateSnippet = "\n if (" + isAvgPool + ") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = " + compareOp + "(values, minMaxValue);\n }\n "; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n const float initializationValue = " + initializationValue + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(" + initializationValue + ");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidthNearestVec4 + "; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n " + updateSnippet + "\n }\n\n int xC = xCCorner + " + filterWidthNearestVec4 + ";\n if (" + (filterWidthVec4Remainder === 1) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (filterWidthVec4Remainder === 2) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (filterWidthVec4Remainder === 3) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n " + updateSnippet + "\n }\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return Pool2DProgram; +}()); +exports.Pool2DProgram = Pool2DProgram; +//# sourceMappingURL=pool_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js.map new file mode 100644 index 0000000..2616919 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/pool_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pool_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/pool_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,uBACI,QAAoB,EAAE,QAAqB,EAAE,gBAAyB;QAL1E,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAMpB,IAAI,QAAQ,KAAK,KAAK,IAAI,gBAAgB,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;SAC/D;QAED,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC3C,IAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;QACzC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,QAAQ,CAAC;QAErC,IAAM,SAAS,GAAG,QAAQ,KAAK,KAAK,CAAC;QAErC,IAAI,mBAAmB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE;YACd,mBAAmB,GAAG,YAAY,CAAC;SACpC;QAED,IAAI,gBAAgB,EAAE;YACpB,IAAM,WAAS,GAAG,IAAI,CAAC;YAEvB,IAAI,CAAC,QAAQ,GAAG,2CACgB,YAAY,UAAK,WAAW,6CAC/B,MAAM,UAAK,OAAO,yiBAkBnB,YAAY,0FAGZ,QAAQ,CAAC,QAAQ,yFAIf,WAAW,8FAGX,QAAQ,CAAC,OAAO,wWAU1B,WAAS,kJAGK,WAAW,wHAM5C,CAAC;YACF,OAAO;SACR;QAED,IAAM,SAAS,GAAG,KAAK,CAAC;QAExB,IAAI,WAAW,GAAM,QAAQ,SAAI,QAAQ,SAAI,QAAQ,MAAG;YACpD,mEAAmE,CAAC;QACxE,IAAI,QAAQ,KAAK,KAAK,EAAE;YACtB,WAAW,GAAG,kBAAkB,CAAC;SAClC;QAED,IAAM,sBAAsB,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAM,wBAAwB,GAAG,WAAW,GAAG,CAAC,CAAC;QAEjD,IAAM,aAAa,GAAG,iBACd,SAAS,2FAGG,SAAS,0CAE5B,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG,yCACgB,YAAY,UAAK,WAAW,2CAC/B,MAAM,UAAK,OAAO,oDACT,mBAAmB,kLAM/B,QAAQ,CAAC,OAAO,+fAkBZ,mBAAmB,iGAIrB,YAAY,sFAGZ,QAAQ,CAAC,QAAQ,mFAIf,sBAAsB,mTAU1C,aAAa,uDAGK,sBAAsB,0BACtC,wBAAwB,KAAK,CAAC,mOAQhC,aAAa,gCACJ,wBAAwB,KAAK,CAAC,8OAQvC,aAAa,gCACJ,wBAAwB,KAAK,CAAC,yPAQvC,aAAa,oDAGP,WAAW,sBAE1B,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AA1LD,IA0LC;AA1LY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.d.ts new file mode 100644 index 0000000..a85146f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.d.ts @@ -0,0 +1,8 @@ +import { ReduceInfo } from '../../ops/reduce_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class ReduceProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(reduceInfo: ReduceInfo, reduceType: 'all' | 'any' | 'max' | 'min' | 'sum'); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js new file mode 100644 index 0000000..b8f6f83 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js @@ -0,0 +1,55 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ReduceProgram = (function () { + function ReduceProgram(reduceInfo, reduceType) { + this.variableNames = ['x']; + var windowSize = reduceInfo.windowSize; + var batchSize = reduceInfo.batchSize; + var inSize = reduceInfo.inSize; + var outSize = Math.ceil(inSize / windowSize); + this.outputShape = [batchSize, outSize]; + var initializationValue = '0.0'; + var compareOp = ""; + if (reduceType === 'min') { + initializationValue = '1.0 / 0.0'; + compareOp = "min"; + } + else if (reduceType === 'max') { + initializationValue = '-1.0 / 0.0'; + compareOp = "max"; + } + var returnValue = reduceType + "(" + reduceType + "(" + reduceType + "(" + + 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])'; + if (reduceType === 'sum') { + returnValue = "sumValue"; + } + else if (reduceType === 'all') { + returnValue = "allValue"; + } + else if (reduceType === 'any') { + returnValue = "anyValue"; + } + var windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4; + var windowSizeVec4Remainder = windowSize % 4; + var updateSnippet = "\n if (" + (reduceType === 'sum') + ") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = " + compareOp + "(values, minMaxValue);\n }\n "; + var vecType = "vec4"; + if (reduceType === 'all') { + initializationValue = '1.0'; + updateSnippet = "\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n "; + vecType = "bvec4"; + } + else if (reduceType === 'any') { + initializationValue = '0.0'; + updateSnippet = "\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n "; + vecType = "bvec4"; + } + var checkOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return initializationValue;\n }\n "; + } + this.userCode = "\n const float initializationValue = " + initializationValue + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n " + checkOutOfBounds + "\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + windowSize + ";\n\n vec4 minMaxValue = vec4(" + initializationValue + ");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < " + windowSizeNearestVec4 + "; i += 4) {\n int inIdx = inOffset + i;\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n " + updateSnippet + "\n }\n\n int inIdx = inOffset + " + windowSizeNearestVec4 + ";\n if (" + (windowSizeVec4Remainder === 1) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 2) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 3) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n " + updateSnippet + "\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return ReduceProgram; +}()); +exports.ReduceProgram = ReduceProgram; +//# sourceMappingURL=reduce_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js.map new file mode 100644 index 0000000..e2fad8a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reduce_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reduce_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/reduce_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,uBACI,UAAsB,EAAE,UAAyC;QALrE,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAMpB,IAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;QACzC,IAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC;QACvC,IAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;QACjC,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAExC,IAAI,mBAAmB,GAAG,KAAK,CAAC;QAChC,IAAI,SAAS,GAAG,EAAE,CAAC;QAEnB,IAAI,UAAU,KAAK,KAAK,EAAE;YACxB,mBAAmB,GAAG,WAAW,CAAC;YAClC,SAAS,GAAG,KAAK,CAAC;SACnB;aAAM,IAAI,UAAU,KAAK,KAAK,EAAE;YAC/B,mBAAmB,GAAG,YAAY,CAAC;YACnC,SAAS,GAAG,KAAK,CAAC;SACnB;QAED,IAAI,WAAW,GAAM,UAAU,SAAI,UAAU,SAAI,UAAU,MAAG;YAC1D,mEAAmE,CAAC;QAExE,IAAI,UAAU,KAAK,KAAK,EAAE;YACxB,WAAW,GAAG,UAAU,CAAC;SAC1B;aAAM,IAAI,UAAU,KAAK,KAAK,EAAE;YAC/B,WAAW,GAAG,UAAU,CAAC;SAC1B;aAAM,IAAI,UAAU,KAAK,KAAK,EAAE;YAC/B,WAAW,GAAG,UAAU,CAAC;SAC1B;QAED,IAAM,qBAAqB,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAM,uBAAuB,GAAG,UAAU,GAAG,CAAC,CAAC;QAE/C,IAAI,aAAa,GAAG,kBACZ,UAAU,KAAK,KAAK,4FAGR,SAAS,0CAE5B,CAAC;QAEF,IAAI,OAAO,GAAG,MAAM,CAAC;QAErB,IAAI,UAAU,KAAK,KAAK,EAAE;YACxB,mBAAmB,GAAG,KAAK,CAAC;YAC5B,aAAa,GAAG,oMAIf,CAAC;YACF,OAAO,GAAG,OAAO,CAAC;SACnB;aAAM,IAAI,UAAU,KAAK,KAAK,EAAE;YAC/B,mBAAmB,GAAG,KAAK,CAAC;YAC5B,aAAa,GAAG,oMAIf,CAAC;YACF,OAAO,GAAG,OAAO,CAAC;SACnB;QAED,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,MAAM,GAAG,UAAU,GAAG,CAAC,EAAE;YAC3B,gBAAgB,GAAG,yCACW,MAAM,kEAGnC,CAAC;SACH;QACD,IAAI,CAAC,QAAQ,GAAG,+CACsB,mBAAmB,sHAInD,gBAAgB,0NAQQ,UAAU,6CAEV,mBAAmB,uIAKvB,qBAAqB,oEAEvC,OAAO,kBAAa,OAAO,oMAO3B,aAAa,sDAGQ,qBAAqB,wBACxC,uBAAuB,KAAK,CAAC,wBAC/B,OAAO,kBAAa,OAAO,+KAO3B,aAAa,8BACJ,uBAAuB,KAAK,CAAC,wBACtC,OAAO,kBAAa,OAAO,sLAO3B,aAAa,8BACJ,uBAAuB,KAAK,CAAC,wBACtC,OAAO,kBAAa,OAAO,6LAO3B,aAAa,uCAEL,WAAW,sBAE1B,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AA3ID,IA2IC;AA3IY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.d.ts new file mode 100644 index 0000000..69efde0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.d.ts @@ -0,0 +1,8 @@ +import { Tensor4D } from '../../tensor'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class ResizeBilinearBackpropProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js new file mode 100644 index 0000000..0185b3c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js @@ -0,0 +1,29 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ResizeBilinearBackpropProgram = (function () { + function ResizeBilinearBackpropProgram(dy, x, alignCorners) { + this.variableNames = ['dy']; + this.outputShape = []; + this.outputShape = x.shape; + var _a = x.shape, xHeight = _a[1], xWidth = _a[2]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + heightScale + ");\n const float widthScale = float(" + widthScale + ");\n\n const float invHeightScale = float(" + invHeightScale + ");\n const float invWidthScale = float(" + invWidthScale + ");\n\n const int winHeight = int(" + winHeight + ");\n const int winWidth = int(" + winWidth + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + yHeight + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + yWidth + ") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), " + (xHeight - 1) + ".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), " + (xWidth - 1) + ".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + } + return ResizeBilinearBackpropProgram; +}()); +exports.ResizeBilinearBackpropProgram = ResizeBilinearBackpropProgram; +//# sourceMappingURL=resize_bilinear_backprop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js.map new file mode 100644 index 0000000..2f72c70 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_backprop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_bilinear_backprop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/resize_bilinear_backprop_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,uCAAY,EAAY,EAAE,CAAW,EAAE,YAAqB;QAJ5D,kBAAa,GAAG,CAAC,IAAI,CAAC,CAAC;QACvB,gBAAW,GAAa,EAAE,CAAC;QAIzB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,KAAK,CAAC;QACrB,IAAA,YAA+B,EAA5B,eAAO,EAAE,cAAM,CAAc;QAChC,IAAA,aAA8B,EAA3B,eAAO,EAAE,cAAM,CAAa;QAMrC,IAAM,cAAc,GAAqB;YACvC,CAAC,YAAY,IAAI,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO;YACrD,CAAC,YAAY,IAAI,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM;SACnD,CAAC;QAEF,IAAM,cAAc,GAAqB;YACvC,CAAC,YAAY,IAAI,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO;YACrD,CAAC,YAAY,IAAI,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM;SACnD,CAAC;QAEF,IAAM,WAAW,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;QAC1D,IAAM,UAAU,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,cAAc,GAAG,CAAC,GAAG,WAAW,CAAC;QACvC,IAAM,aAAa,GAAG,CAAC,GAAG,UAAU,CAAC;QAIrC,IAAM,SAAS,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QACtD,IAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAEpD,IAAI,CAAC,QAAQ,GAAG,qQAUsB,WAAW,mDACZ,UAAU,yDAEN,cAAc,sDACf,aAAa,gDAErB,SAAS,6CACV,QAAQ,mjBAcT,OAAO,gRAQL,MAAM,+MAMY,OAAO,GAAG,CAAC,mRAMZ,MAAM,GAAG,CAAC,k9BA8B1D,CAAC;IACJ,CAAC;IACH,oCAAC;AAAD,CAAC,AAtHD,IAsHC;AAtHY,sEAA6B"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.d.ts new file mode 100644 index 0000000..286d872 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class ResizeBilinearProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(inputShape: [number, number, number, number], newHeight: number, newWidth: number, alignCorners: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js new file mode 100644 index 0000000..a6d0edc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ResizeBilinearProgram = (function () { + function ResizeBilinearProgram(inputShape, newHeight, newWidth, alignCorners) { + this.variableNames = ['A']; + this.outputShape = []; + var batch = inputShape[0], oldHeight = inputShape[1], oldWidth = inputShape[2], depth = inputShape[3]; + this.outputShape = [batch, newHeight, newWidth, depth]; + var effectiveInSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + effectiveInSize[0] / effectiveOutSize[0] + ",\n " + effectiveInSize[1] / effectiveOutSize[1] + ");\n const vec2 inputShapeRC = vec2(" + oldHeight + ".0, " + oldWidth + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "; + } + return ResizeBilinearProgram; +}()); +exports.ResizeBilinearProgram = ResizeBilinearProgram; +//# sourceMappingURL=resize_bilinear_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js.map new file mode 100644 index 0000000..ba09b6b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_bilinear_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_bilinear_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/resize_bilinear_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,+BACI,UAA4C,EAAE,SAAiB,EAC/D,QAAgB,EAAE,YAAqB;QAN3C,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QACtB,gBAAW,GAAa,EAAE,CAAC;QAMlB,IAAA,qBAAK,EAAE,yBAAS,EAAE,wBAAQ,EAAE,qBAAK,CAAe;QACvD,IAAI,CAAC,WAAW,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;QAEvD,IAAM,eAAe,GAAqB;YACxC,CAAC,YAAY,IAAI,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3D,CAAC,YAAY,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ;SACzD,CAAC;QAEF,IAAM,gBAAgB,GAAqB;YACzC,CAAC,YAAY,IAAI,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3D,CAAC,YAAY,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ;SACzD,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG,2EAER,eAAe,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,qBACxC,eAAe,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,iDACb,SAAS,YAAO,QAAQ,ikCA6B1D,CAAC;IACJ,CAAC;IACH,4BAAC;AAAD,CAAC,AAxDD,IAwDC;AAxDY,sDAAqB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.d.ts new file mode 100644 index 0000000..eb82c6e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.d.ts @@ -0,0 +1,8 @@ +import { Tensor4D } from '../../tensor'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class ResizeNearestNeigborBackpropProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js new file mode 100644 index 0000000..6a9896a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js @@ -0,0 +1,29 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ResizeNearestNeigborBackpropProgram = (function () { + function ResizeNearestNeigborBackpropProgram(dy, x, alignCorners) { + this.variableNames = ['dy']; + this.outputShape = []; + this.outputShape = x.shape; + var _a = x.shape, xHeight = _a[1], xWidth = _a[2]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + heightScale + ");\n const float widthScale = float(" + widthScale + ");\n\n const float invHeightScale = float(" + invHeightScale + ");\n const float invWidthScale = float(" + invWidthScale + ");\n\n const int winHeight = int(" + winHeight + ");\n const int winWidth = int(" + winWidth + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + yHeight + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + yWidth + ") {\n continue;\n }\n\n float sourceFracRow =\n float(" + effectiveXSize[0] + ") *\n (float(dyR) / float(" + effectiveYSize[0] + "));\n\n float sourceFracCol =\n float(" + effectiveXSize[1] + ") *\n (float(dyC) / float(" + effectiveYSize[1] + "));\n\n int sourceNearestRow = int(min(\n float(int(" + xHeight + ") - 1),\n " + alignCorners + " ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(" + xWidth + ") - 1),\n " + alignCorners + " ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + } + return ResizeNearestNeigborBackpropProgram; +}()); +exports.ResizeNearestNeigborBackpropProgram = ResizeNearestNeigborBackpropProgram; +//# sourceMappingURL=resize_nearest_neighbor_backprop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js.map new file mode 100644 index 0000000..52e660d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_backprop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_nearest_neighbor_backprop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/resize_nearest_neighbor_backprop_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,6CAAY,EAAY,EAAE,CAAW,EAAE,YAAqB;QAJ5D,kBAAa,GAAG,CAAC,IAAI,CAAC,CAAC;QACvB,gBAAW,GAAa,EAAE,CAAC;QAIzB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,KAAK,CAAC;QACrB,IAAA,YAA+B,EAA5B,eAAO,EAAE,cAAM,CAAc;QAChC,IAAA,aAA8B,EAA3B,eAAO,EAAE,cAAM,CAAa;QAMrC,IAAM,cAAc,GAAqB;YACvC,CAAC,YAAY,IAAI,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO;YACrD,CAAC,YAAY,IAAI,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM;SACnD,CAAC;QAEF,IAAM,cAAc,GAAqB;YACvC,CAAC,YAAY,IAAI,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO;YACrD,CAAC,YAAY,IAAI,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM;SACnD,CAAC;QAEF,IAAM,WAAW,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;QAC1D,IAAM,UAAU,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,cAAc,GAAG,CAAC,GAAG,WAAW,CAAC;QACvC,IAAM,aAAa,GAAG,CAAC,GAAG,UAAU,CAAC;QAIrC,IAAM,SAAS,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QACtD,IAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAEpD,IAAI,CAAC,QAAQ,GAAG,qQAUsB,WAAW,mDACZ,UAAU,yDAEN,cAAc,sDACf,aAAa,gDAErB,SAAS,6CACV,QAAQ,ikBAcT,OAAO,gRAQL,MAAM,8GAKpB,cAAc,CAAC,CAAC,CAAC,iDACD,cAAc,CAAC,CAAC,CAAC,wEAG/B,cAAc,CAAC,CAAC,CAAC,mDACD,cAAc,CAAC,CAAC,CAAC,sFAG7B,OAAO,iCACjB,YAAY,qLAIF,MAAM,iCAChB,YAAY,uVAYzB,CAAC;IACJ,CAAC;IACH,0CAAC;AAAD,CAAC,AA3GD,IA2GC;AA3GY,kFAAmC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.d.ts new file mode 100644 index 0000000..2b4d227 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class ResizeNearestNeighborProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(inputShape: [number, number, number, number], newHeight: number, newWidth: number, alignCorners: boolean); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js new file mode 100644 index 0000000..66aa7d6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js @@ -0,0 +1,23 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var ResizeNearestNeighborProgram = (function () { + function ResizeNearestNeighborProgram(inputShape, newHeight, newWidth, alignCorners) { + this.variableNames = ['A']; + this.outputShape = []; + var batch = inputShape[0], oldHeight = inputShape[1], oldWidth = inputShape[2], depth = inputShape[3]; + this.outputShape = [batch, newHeight, newWidth, depth]; + var effectiveInSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + var roundBase = alignCorners ? '0.5' : '0.0'; + this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + effectiveInSize[0] / effectiveOutSize[0] + ",\n " + effectiveInSize[1] / effectiveOutSize[1] + ");\n const vec2 inputShapeRC = vec2(" + oldHeight + ".0, " + oldWidth + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + " + roundBase + ")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "; + } + return ResizeNearestNeighborProgram; +}()); +exports.ResizeNearestNeighborProgram = ResizeNearestNeighborProgram; +//# sourceMappingURL=resize_nearest_neighbor_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js.map new file mode 100644 index 0000000..8a22298 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/resize_nearest_neighbor_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_nearest_neighbor_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/resize_nearest_neighbor_gpu.ts"],"names":[],"mappings":";;AAmBA;IAKE,sCACI,UAA4C,EAAE,SAAiB,EAC/D,QAAgB,EAAE,YAAqB;QAN3C,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QACtB,gBAAW,GAAa,EAAE,CAAC;QAMlB,IAAA,qBAAK,EAAE,yBAAS,EAAE,wBAAQ,EAAE,qBAAK,CAAe;QACvD,IAAI,CAAC,WAAW,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;QAEvD,IAAM,eAAe,GAAqB;YACxC,CAAC,YAAY,IAAI,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3D,CAAC,YAAY,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ;SACzD,CAAC;QAEF,IAAM,gBAAgB,GAAqB;YACzC,CAAC,YAAY,IAAI,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3D,CAAC,YAAY,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ;SACzD,CAAC;QAGF,IAAM,SAAS,GAAG,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAE/C,IAAI,CAAC,QAAQ,GAAG,2EAER,eAAe,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,qBACxC,eAAe,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,iDACb,SAAS,YAAO,QAAQ,ocAaD,SAAS,sIAMlE,CAAC;IACJ,CAAC;IACH,mCAAC;AAAD,CAAC,AAjDD,IAiDC;AAjDY,oEAA4B"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.d.ts new file mode 100644 index 0000000..b2465b0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class ReverseProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(xShape: number[], axis: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js new file mode 100644 index 0000000..f3d3663 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js @@ -0,0 +1,29 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var ReverseProgram = (function () { + function ReverseProgram(xShape, axis) { + this.variableNames = ['x']; + var rank = xShape.length; + if (rank > 4) { + throw new Error("WebGL backend: Reverse of rank-" + rank + " tensor is not yet supported"); + } + this.outputShape = xShape; + if (rank === 1) { + this.userCode = "\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(" + xShape[0] + " - coord - 1));\n }\n "; + return; + } + var getInCoord = function (i) { + if (axis.indexOf(i) !== -1 && xShape[i] !== 1) { + return xShape[i] + " - coords[" + i + "] - 1"; + } + return "coords[" + i + "]"; + }; + var inCoords = xShape.map(function (_, i) { return getInCoord(i); }).join(','); + var type = shader_compiler_1.getCoordsDataType(rank); + this.userCode = "\n void main() {\n " + type + " coords = getOutputCoords();\n setOutput(getX(" + inCoords + "));\n }\n "; + } + return ReverseProgram; +}()); +exports.ReverseProgram = ReverseProgram; +//# sourceMappingURL=reverse_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js.map new file mode 100644 index 0000000..bdf4aa8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/reverse_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reverse_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/reverse_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAKE,wBAAY,MAAgB,EAAE,IAAc;QAJ5C,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAKpB,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;QAC3B,IAAI,IAAI,GAAG,CAAC,EAAE;YACZ,MAAM,IAAI,KAAK,CACX,oCAAkC,IAAI,iCAA8B,CAAC,CAAC;SAC3E;QACD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAE1B,IAAI,IAAI,KAAK,CAAC,EAAE;YACd,IAAI,CAAC,QAAQ,GAAG,iGAGK,MAAM,CAAC,CAAC,CAAC,uCAE7B,CAAC;YACF,OAAO;SACR;QACD,IAAM,UAAU,GAAG,UAAC,CAAS;YAC3B,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;gBAC7C,OAAU,MAAM,CAAC,CAAC,CAAC,kBAAa,CAAC,UAAO,CAAC;aAC1C;YACD,OAAO,YAAU,CAAC,MAAG,CAAC;QACxB,CAAC,CAAC;QACF,IAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,UAAU,CAAC,CAAC,CAAC,EAAb,CAAa,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAM,IAAI,GAAG,mCAAiB,CAAC,IAAI,CAAC,CAAC;QAErC,IAAI,CAAC,QAAQ,GAAG,oCAEV,IAAI,6DACW,QAAQ,uBAE5B,CAAC;IACJ,CAAC;IACH,qBAAC;AAAD,CAAC,AAtCD,IAsCC;AAtCY,wCAAc"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.d.ts new file mode 100644 index 0000000..db503c3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.d.ts @@ -0,0 +1,8 @@ +import { SegOpInfo } from '../../ops/segment_util'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class SegmentOpProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(segOpInfo: SegOpInfo, segOpType: 'unsortedSegmentSum'); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js new file mode 100644 index 0000000..ac1c74a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js @@ -0,0 +1,30 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var SegmentOpProgram = (function () { + function SegmentOpProgram(segOpInfo, segOpType) { + this.variableNames = ['x', 'segmentIds']; + var windowSize = segOpInfo.windowSize; + var batchSize = segOpInfo.batchSize; + var inSize = segOpInfo.inSize; + var numSegments = segOpInfo.numSegments; + var outSize = numSegments * Math.ceil(inSize / windowSize); + this.outputShape = [batchSize, outSize]; + var initializationValue = '0.0'; + var returnValue = "sumValue"; + var windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4; + var windowSizeVec4Remainder = windowSize % 4; + var updateSnippet = "\n sumValue += dot(values, filter);\n "; + var checkValueOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkValueOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return initializationValue;\n }\n "; + } + var checkSegmentIdOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkSegmentIdOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return -1.0;\n }\n "; + } + this.userCode = "\n const float initializationValue = " + initializationValue + ";\n\n float getValue(int batch, int inIdx) {\n " + checkValueOutOfBounds + "\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n " + checkSegmentIdOutOfBounds + "\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n " + numSegments + ")) * float(" + windowSize + "));\n int currentSeg = int(mod(float(outIdx), float(" + numSegments + ")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < " + windowSizeNearestVec4 + "; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n " + updateSnippet + "\n }\n\n int inIdx = inOffset + " + windowSizeNearestVec4 + ";\n if (" + (windowSizeVec4Remainder === 1) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 2) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 3) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n " + updateSnippet + "\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return SegmentOpProgram; +}()); +exports.SegmentOpProgram = SegmentOpProgram; +//# sourceMappingURL=segment_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js.map new file mode 100644 index 0000000..94b943b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/segment_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"segment_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/segment_gpu.ts"],"names":[],"mappings":";;AAoBA;IAKE,0BAAY,SAAoB,EAAE,SAA+B;QAJjE,kBAAa,GAAG,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;QAKlC,IAAM,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC;QACxC,IAAM,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC;QACtC,IAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAChC,IAAM,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC;QAC1C,IAAM,OAAO,GAAG,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC;QAC7D,IAAI,CAAC,WAAW,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAExC,IAAM,mBAAmB,GAAG,KAAK,CAAC;QAClC,IAAM,WAAW,GAAG,UAAU,CAAC;QAE/B,IAAM,qBAAqB,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAM,uBAAuB,GAAG,UAAU,GAAG,CAAC,CAAC;QAE/C,IAAM,aAAa,GAAG,kDAErB,CAAC;QAEF,IAAI,qBAAqB,GAAG,EAAE,CAAC;QAC/B,IAAI,MAAM,GAAG,UAAU,GAAG,CAAC,EAAE;YAC3B,qBAAqB,GAAG,yCACM,MAAM,kEAGnC,CAAC;SACH;QAED,IAAI,yBAAyB,GAAG,EAAE,CAAC;QACnC,IAAI,MAAM,GAAG,UAAU,GAAG,CAAC,EAAE;YAC3B,yBAAyB,GAAG,yCACE,MAAM,mDAGnC,CAAC;SACH;QAED,IAAI,CAAC,QAAQ,GAAG,+CACsB,mBAAmB,mEAGnD,qBAAqB,+GAKrB,yBAAyB,+PASvB,WAAW,mBAAc,UAAU,mEACS,WAAW,6EAIrC,qBAAqB,4lBAgBvC,aAAa,sDAGQ,qBAAqB,wBACxC,uBAAuB,KAAK,CAAC,gbAiB/B,aAAa,8BACJ,uBAAuB,KAAK,CAAC,sbAetC,aAAa,8BACJ,uBAAuB,KAAK,CAAC,ifAetC,aAAa,uCAEL,WAAW,sBAE1B,CAAC;IACJ,CAAC;IACH,uBAAC;AAAD,CAAC,AA3ID,IA2IC;AA3IY,4CAAgB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.d.ts new file mode 100644 index 0000000..3cbcd41 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.d.ts @@ -0,0 +1,7 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class SelectProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + constructor(cRank: number, shape: number[], rank: number); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js new file mode 100644 index 0000000..b100f05 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js @@ -0,0 +1,36 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var SelectProgram = (function () { + function SelectProgram(cRank, shape, rank) { + this.variableNames = ['c', 'a', 'b']; + this.outputShape = shape; + var cCoords; + var abCoords; + if (rank > 4) { + throw Error("Where for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + abCoords = "resRC"; + cCoords = "resRC"; + } + else { + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w']; + var cCoordVars = []; + var abCoordVars = []; + for (var i = 0; i < shape.length; i++) { + abCoordVars.push("" + currentCoords[i]); + if (i < cRank) { + cCoordVars.push("" + currentCoords[i]); + } + } + cCoords = cCoordVars.join(); + abCoords = abCoordVars.join(); + } + var dtype = shader_compiler_1.getCoordsDataType(rank); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n float cVal = getC(" + cCoords + ");\n if (cVal >= 1.0) {\n setOutput(getA(" + abCoords + "));\n } else {\n setOutput(getB(" + abCoords + "));\n }\n }\n "; + } + return SelectProgram; +}()); +exports.SelectProgram = SelectProgram; +//# sourceMappingURL=select_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js.map new file mode 100644 index 0000000..304ede0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/select_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"select_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/select_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAKE,uBAAY,KAAa,EAAE,KAAe,EAAE,IAAY;QAJxD,kBAAa,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAK9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,IAAI,OAAO,CAAC;QACZ,IAAI,QAAQ,CAAC;QACb,IAAI,IAAI,GAAG,CAAC,EAAE;YACZ,MAAM,KAAK,CAAC,oBAAkB,IAAI,0BAAuB,CAAC,CAAC;SAC5D;QAED,IAAI,IAAI,KAAK,CAAC,EAAE;YACd,QAAQ,GAAG,OAAO,CAAC;YACnB,OAAO,GAAG,OAAO,CAAC;SACnB;aAAM;YACL,IAAM,aAAa,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;YACnE,IAAM,UAAU,GAAG,EAAE,CAAC;YACtB,IAAM,WAAW,GAAG,EAAE,CAAC;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACrC,WAAW,CAAC,IAAI,CAAC,KAAG,aAAa,CAAC,CAAC,CAAG,CAAC,CAAC;gBACxC,IAAI,CAAC,GAAG,KAAK,EAAE;oBACb,UAAU,CAAC,IAAI,CAAC,KAAG,aAAa,CAAC,CAAC,CAAG,CAAC,CAAC;iBACxC;aACF;YACD,OAAO,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;YAC5B,QAAQ,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;SAC/B;QAED,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,CAAC;QAEtC,IAAI,CAAC,QAAQ,GAAG,oCAEV,KAAK,+DACa,OAAO,iEAER,QAAQ,wDAER,QAAQ,kCAG9B,CAAC;IACJ,CAAC;IACH,oBAAC;AAAD,CAAC,AA7CD,IA6CC;AA7CY,sCAAa"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.d.ts new file mode 100644 index 0000000..62b7065 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.d.ts @@ -0,0 +1,11 @@ +export declare type ShapeInfo = { + logicalShape: number[]; + texShape: [number, number]; + isUniform: boolean; +}; +export declare type InputInfo = { + name: string; + shapeInfo: ShapeInfo; +}; +export declare function makeShader(inputsInfo: InputInfo[], outputShape: ShapeInfo, userCode: string, broadcast: boolean): string; +export declare function getCoordsDataType(rank: number): string; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js new file mode 100644 index 0000000..857df3f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js @@ -0,0 +1,414 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var broadcast_util = require("../../ops/broadcast_util"); +var util = require("../../util"); +function makeShader(inputsInfo, outputShape, userCode, broadcast) { + var inputPrefixSnippet = inputsInfo.map(function (x) { + var size = util.sizeFromShape(x.shapeInfo.logicalShape); + if (x.shapeInfo.isUniform) { + return "uniform float " + x.name + (size > 1 ? "[" + size + "]" : '') + ";"; + } + return "uniform sampler2D " + x.name + ";"; + }); + inputPrefixSnippet = inputPrefixSnippet.join('\n'); + var inputSamplingSnippet = inputsInfo.map(function (x) { return getInputSamplingSnippet(x, outputShape, broadcast); }) + .join('\n'); + var outTexShape = outputShape.texShape; + var outputSamplingSnippet = getOutputSamplingSnippet(outputShape.logicalShape, outTexShape); + var source = [ + SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET, + FLOAT_TEXTURE_SETOUTPUT_SNIPPET, inputPrefixSnippet, outputSamplingSnippet, + inputSamplingSnippet, userCode + ].join('\n'); + return source; +} +exports.makeShader = makeShader; +function getSamplerFromInInfo(inInfo) { + var shape = inInfo.shapeInfo.logicalShape; + switch (shape.length) { + case 0: + return getSamplerScalar(inInfo); + case 1: + return getSampler1D(inInfo); + case 2: + return getSampler2D(inInfo); + case 3: + return getSampler3D(inInfo); + case 4: + return getSampler4D(inInfo); + case 5: + return getSampler5D(inInfo); + case 6: + return getSampler6D(inInfo); + default: + throw new Error(shape.length + "-D input sampling" + + " is not yet supported"); + } +} +function getInputSamplingSnippet(inInfo, outShapeInfo, broadcast) { + var res = getSamplerFlat(inInfo); + res += getSamplerFromInInfo(inInfo); + if (broadcast || + util.arraysEqual(inInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape)) { + res += getSamplerAtOutputCoords(inInfo, outShapeInfo, broadcast); + } + return res; +} +function getOutputSamplingSnippet(outShape, outTexShape) { + switch (outShape.length) { + case 0: + return getOutputScalarCoords(); + case 1: + return getOutput1DCoords(outShape, outTexShape); + case 2: + return getOutput2DCoords(outShape, outTexShape); + case 3: + return getOutput3DCoords(outShape, outTexShape); + case 4: + return getOutput4DCoords(outShape, outTexShape); + case 5: + return getOutput5DCoords(outShape, outTexShape); + case 6: + return getOutput6DCoords(outShape, outTexShape); + default: + throw new Error(outShape.length + "-D output sampling is not yet supported"); + } +} +var SAMPLE_1D_SNIPPET = "\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var SAMPLE_2D_SNIPPET = "\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var SAMPLE_3D_SNIPPET = "\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var SAMPLE_4D_SNIPPET = "\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var SAMPLE_5D_SNIPPET = "\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var SAMPLE_6D_SNIPPET = "\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; +var FLOAT_TEXTURE_SAMPLE_SNIPPET = "\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n"; +var FLOAT_TEXTURE_SETOUTPUT_SNIPPET = "\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n"; +var SHADER_PREFIX = "\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n " + SAMPLE_1D_SNIPPET + "\n " + SAMPLE_2D_SNIPPET + "\n " + SAMPLE_3D_SNIPPET + "\n " + SAMPLE_4D_SNIPPET + "\n " + SAMPLE_5D_SNIPPET + "\n " + SAMPLE_6D_SNIPPET + "\n"; +function getOutputScalarCoords() { + return "\n int getOutputCoords() {\n return 0;\n }\n "; +} +function getOutput1DCoords(shape, texShape) { + if (texShape[0] === 1) { + return "\n int getOutputCoords() {\n return int(resultUV.x * " + texShape[1] + ".0);\n }\n "; + } + if (texShape[1] === 1) { + return "\n int getOutputCoords() {\n return int(resultUV.y * " + texShape[0] + ".0);\n }\n "; + } + return "\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n return resTexRC.x * " + texShape[1] + " + resTexRC.y;\n }\n "; +} +function getOutput3DCoords(shape, texShape) { + var stride0 = shape[1] * shape[2]; + var stride1 = shape[2]; + return "\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n int c = index / " + stride1 + ";\n int d = index - c * " + stride1 + ";\n return ivec3(r, c, d);\n }\n "; +} +function getOutput4DCoords(shape, texShape) { + var stride2 = shape[3]; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n int d2 = index - d * " + stride2 + ";\n\n return ivec4(r, c, d, d2);\n }\n "; +} +function getOutput5DCoords(shape, texShape) { + var stride3 = shape[4]; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(" + texShape[0] + ",\n " + texShape[1] + "));\n\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n index -= d * " + stride2 + ";\n\n int d2 = index / " + stride3 + ";\n int d3 = index - d2 * " + stride3 + ";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "; +} +function getOutput6DCoords(shape, texShape) { + var stride4 = shape[5]; + var stride3 = shape[4] * stride4; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n index -= d * " + stride2 + ";\n\n int d2 = index / " + stride3 + ";\n index -= d2 * " + stride3 + ";\n\n int d3 = index / " + stride4 + ";\n int d4 = index - d3 * " + stride4 + ";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "; +} +function getOutput2DCoords(shape, texShape) { + if (util.arraysEqual(shape, texShape)) { + return "\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(" + texShape[0] + ", " + texShape[1] + "));\n }\n "; + } + if (shape[1] === 1) { + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n return ivec2(index, 0);\n }\n "; + } + if (shape[0] === 1) { + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n return ivec2(0, index);\n }\n "; + } + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n int r = index / " + shape[1] + ";\n int c = index - r * " + shape[1] + ";\n return ivec2(r, c);\n }\n "; +} +function getSamplerScalar(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + if (inputInfo.shapeInfo.isUniform) { + return "float " + funcName + "() {return " + texName + ";}"; + } + return "\n float " + funcName + "() {\n return sampleTexture(" + texName + ", halfCR);\n }\n "; +} +function getSampler1D(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + return "\n float " + funcName + "(int index) {\n return " + funcName + "Flat(index);\n }\n "; +} +function getSampler2D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var texShape = inputInfo.shapeInfo.texShape; + if (texShape != null && util.arraysEqual(shape, texShape)) { + var texNumR_1 = texShape[0]; + var texNumC_1 = texShape[1]; + return "\n float " + funcName + "(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(" + texNumC_1 + ".0, " + texNumR_1 + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + var _a = util.squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + var squeezedShape = newShape; + if (squeezedShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, squeezedShape); + var params = ['row', 'col']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n return " + funcName + "Flat(index);\n }\n "; + } + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === 1) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumR === 1) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n vec2 uv = vec2((float(index) + 0.5) / " + texNumC + ".0, 0.5);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col) {\n vec2 uv = UVfrom2D(" + texNumR + ", " + texNumC + ", " + shape[1] + ", row, col);\n return sampleTexture(" + texName + ", uv);\n }\n"; +} +function getSampler3D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride0 = shape[1] * shape[2]; + var stride1 = shape[2]; + var _a = util.squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + var squeezedShape = newShape; + if (squeezedShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, squeezedShape); + var params = ['row', 'col', 'depth']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int index = row * " + stride0 + " + col * " + stride1 + " + depth;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int texR = row;\n int texC = col * " + stride1 + " + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride1) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int texR = row * " + shape[1] + " + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n " + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ", row, col, depth);\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getSampler4D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride2 = shape[3]; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = util.squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride2) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", row, col, depth, depth2);\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getSampler5D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride3 = shape[4]; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = util.squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2', 'depth3']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2 * " + stride3 + " + depth3;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " +\n depth2 * " + stride3 + " + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride3) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " +\n depth * " + shape[3] + " + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", " + stride3 + ", row, col, depth, depth2, depth3);\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getSampler6D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride4 = shape[5]; + var stride3 = shape[4] * stride4; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = util.squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2 * " + stride3 + " + depth3 * " + stride3 + "\n + depth4\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride4) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", " + stride3 + ", " + stride4 + "\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getSamplerFlat(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1) + 'Flat'; + var inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape); + if (inputInfo.shapeInfo.isUniform) { + if (inSize === 1) { + return "float " + funcName + "(int index) {return " + texName + ";}"; + } + return "\n float " + funcName + "(int index) {\n for (int i = 0; i < " + inSize + "; i++) {\n if (i == index) {\n return " + texName + "[i];\n }\n }\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var tNumR = texShape[0]; + var tNumC = texShape[1]; + if (tNumC === 1 && tNumR === 1) { + return "\n float " + funcName + "(int index) {\n return sampleTexture(" + texName + ", halfCR);\n }\n "; + } + if (tNumC === 1) { + return "\n float " + funcName + "(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + tNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (tNumR === 1) { + return "\n float " + funcName + "(int index) {\n vec2 uv = vec2((float(index) + 0.5) / " + tNumC + ".0, 0.5);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int index) {\n vec2 uv = UVfrom1D(" + tNumR + ", " + tNumC + ", index);\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getBroadcastOutputCoordsSampler(inputInfo, outShapeInfo, texFuncSnippet, funcName) { + var inRank = inputInfo.shapeInfo.logicalShape.length; + var outRank = outShapeInfo.logicalShape.length; + var type = 'int'; + if (outRank === 2) { + type = 'ivec2'; + } + else if (outRank === 3) { + type = 'ivec3'; + } + else if (outRank === 4) { + type = 'ivec4'; + } + var broadcastDims = broadcast_util.getBroadcastDims(inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape); + var rankDiff = outRank - inRank; + var coordsSnippet; + if (inRank === 0) { + coordsSnippet = ''; + } + else if (outRank < 2 && broadcastDims.length >= 1) { + coordsSnippet = 'coords = 0;'; + } + else { + coordsSnippet = + broadcastDims.map(function (d) { return "coords[" + (d + rankDiff) + "] = 0;"; }).join('\n'); + } + var unpackedCoordsSnippet = ''; + if (outRank < 2 && inRank > 0) { + unpackedCoordsSnippet = 'coords'; + } + else { + unpackedCoordsSnippet = inputInfo.shapeInfo.logicalShape + .map(function (s, i) { return "coords[" + (i + rankDiff) + "]"; }) + .join(', '); + } + return "\n float " + funcName + "() {\n " + type + " coords = getOutputCoords();\n " + coordsSnippet + "\n return get" + texFuncSnippet + "(" + unpackedCoordsSnippet + ");\n }\n "; +} +function getSamplerAtOutputCoords(inputInfo, outShapeInfo, supportsBroadcasting) { + var texName = inputInfo.name; + var texFuncSnippet = texName.charAt(0).toUpperCase() + texName.slice(1); + var funcName = 'get' + texFuncSnippet + 'AtOutCoords'; + var broadcastDims = broadcast_util.getBroadcastDims(inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape); + var inRank = inputInfo.shapeInfo.logicalShape.length; + var outRank = outShapeInfo.logicalShape.length; + var doBroadcast = supportsBroadcasting && ((outRank > inRank) || broadcastDims.length > 0); + var broadcastOverOuter = broadcast_util.broadcastDimsAreOuter(broadcastDims); + var isUniform = inputInfo.shapeInfo.isUniform; + if (doBroadcast && !broadcastOverOuter) { + return getBroadcastOutputCoordsSampler(inputInfo, outShapeInfo, texFuncSnippet, funcName); + } + var inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape); + var broadcastSnippet = ''; + if (doBroadcast && broadcastOverOuter) { + broadcastSnippet = "\n int mainPart = index / " + inSize + ";\n index -= mainPart * " + inSize + ";\n "; + } + var outTexShape = outShapeInfo.texShape; + if (isUniform) { + if (inSize === 1) { + return "float " + funcName + "() {return " + texName + ";}"; + } + return "\n float " + funcName + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + outTexShape[0] + ", " + outTexShape[1] + "));\n int index = resTexRC.x * " + outTexShape[1] + " + resTexRC.y;\n " + broadcastSnippet + "\n return get" + texFuncSnippet + "Flat(index);\n }\n "; + } + var inTexShape = inputInfo.shapeInfo.texShape; + if (util.arraysEqual(inTexShape, outTexShape)) { + return "\n float " + funcName + "() {\n return sampleTexture(" + texName + ", resultUV);\n }\n "; + } + return "\n float " + funcName + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + outTexShape[0] + ", " + outTexShape[1] + "));\n int index = resTexRC.x * " + outTexShape[1] + " + resTexRC.y;\n " + broadcastSnippet + "\n int texR = index / " + inTexShape[1] + ";\n int texC = index - texR * " + inTexShape[1] + ";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + inTexShape[1] + ".0, " + inTexShape[0] + ".0);\n\n return sampleTexture(" + texName + ", uv);\n }\n "; +} +function getCoordsDataType(rank) { + if (rank <= 1) { + return 'int'; + } + else if (rank === 2) { + return 'ivec2'; + } + else if (rank === 3) { + return 'ivec3'; + } + else if (rank === 4) { + return 'ivec4'; + } + else if (rank === 5) { + return 'ivec5'; + } + else if (rank === 6) { + return 'ivec6'; + } + else { + throw Error("GPU for rank " + rank + " is not yet supported"); + } +} +exports.getCoordsDataType = getCoordsDataType; +function squeezeInputInfo(inInfo, squeezedShape) { + var newInputInfo = JSON.parse(JSON.stringify(inInfo)); + newInputInfo.shapeInfo.logicalShape = squeezedShape; + return newInputInfo; +} +function getSqueezedParams(params, keptDims) { + return keptDims.map(function (d) { return params[d]; }).join(', '); +} +//# sourceMappingURL=shader_compiler.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js.map new file mode 100644 index 0000000..b9745cb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/shader_compiler.js.map @@ -0,0 +1 @@ +{"version":3,"file":"shader_compiler.js","sourceRoot":"","sources":["../../../src/kernels/webgl/shader_compiler.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.d.ts new file mode 100644 index 0000000..c5e7209 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.d.ts @@ -0,0 +1,11 @@ +import { GPGPUContext } from './gpgpu_context'; +import { GPGPUProgram } from './gpgpu_math'; +export declare class SliceProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + rank: number; + startLoc: WebGLUniformLocation; + constructor(destSize: number[]); + getCustomSetupFunc(start: number[]): (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js new file mode 100644 index 0000000..9fff0aa --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js @@ -0,0 +1,63 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var SliceProgram = (function () { + function SliceProgram(destSize) { + this.variableNames = ['source']; + this.outputShape = destSize; + this.rank = destSize.length; + var dtype = shader_compiler_1.getCoordsDataType(this.rank); + var sourceCoords = getCoords(this.rank); + this.userCode = "\n uniform " + dtype + " start;\n\n void main() {\n " + dtype + " sourceLoc = start + getOutputCoords();\n setOutput(getSource(" + sourceCoords + "));\n }\n "; + } + SliceProgram.prototype.getCustomSetupFunc = function (start) { + var _this = this; + if (start.length !== this.rank) { + throw Error("The rank (" + this.rank + ") of the program must match the " + + ("length of start (" + start.length + ")")); + } + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'start'); + if (_this.startLoc == null) { + return; + } + } + if (_this.rank === 1) { + gpgpu.gl.uniform1i(_this.startLoc, start[0]); + } + else if (_this.rank === 2) { + gpgpu.gl.uniform2i(_this.startLoc, start[0], start[1]); + } + else if (_this.rank === 3) { + gpgpu.gl.uniform3i(_this.startLoc, start[0], start[1], start[2]); + } + else if (_this.rank === 4) { + gpgpu.gl.uniform4i(_this.startLoc, start[0], start[1], start[2], start[3]); + } + else { + throw Error("Slicing for rank " + _this.rank + " is not yet supported"); + } + }; + }; + return SliceProgram; +}()); +exports.SliceProgram = SliceProgram; +function getCoords(rank) { + if (rank === 1) { + return 'sourceLoc'; + } + else if (rank === 2) { + return 'sourceLoc.x, sourceLoc.y'; + } + else if (rank === 3) { + return 'sourceLoc.x, sourceLoc.y, sourceLoc.z'; + } + else if (rank === 4) { + return 'sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w'; + } + else { + throw Error("Slicing for rank " + rank + " is not yet supported"); + } +} +//# sourceMappingURL=slice_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js.map new file mode 100644 index 0000000..f7247f9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/slice_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"slice_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/slice_gpu.ts"],"names":[],"mappings":";;AAmBA,qDAAoD;AAEpD;IASE,sBAAY,QAAkB;QAR9B,kBAAa,GAAG,CAAC,QAAQ,CAAC,CAAC;QASzB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC;QAE5B,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAM,YAAY,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE1C,IAAI,CAAC,QAAQ,GAAG,qBACJ,KAAK,gDAGX,KAAK,6EACe,YAAY,uBAErC,CAAC;IACJ,CAAC;IAED,yCAAkB,GAAlB,UAAmB,KAAe;QAAlC,iBA4BC;QA3BC,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,IAAI,EAAE;YAC9B,MAAM,KAAK,CACP,eAAa,IAAI,CAAC,IAAI,qCAAkC;iBACxD,sBAAoB,KAAK,CAAC,MAAM,MAAG,CAAA,CAAC,CAAC;SAC1C;QACD,OAAO,UAAC,KAAmB,EAAE,YAA0B;YACrD,IAAI,KAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;gBACzB,KAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,yBAAyB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;gBACvE,IAAI,KAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;oBAGzB,OAAO;iBACR;aACF;YACD,IAAI,KAAI,CAAC,IAAI,KAAK,CAAC,EAAE;gBACnB,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aAC7C;iBAAM,IAAI,KAAI,CAAC,IAAI,KAAK,CAAC,EAAE;gBAC1B,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aACvD;iBAAM,IAAI,KAAI,CAAC,IAAI,KAAK,CAAC,EAAE;gBAC1B,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aACjE;iBAAM,IAAI,KAAI,CAAC,IAAI,KAAK,CAAC,EAAE;gBAC1B,KAAK,CAAC,EAAE,CAAC,SAAS,CACd,KAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aAC5D;iBAAM;gBACL,MAAM,KAAK,CAAC,sBAAoB,KAAI,CAAC,IAAI,0BAAuB,CAAC,CAAC;aACnE;QACH,CAAC,CAAC;IACJ,CAAC;IACH,mBAAC;AAAD,CAAC,AAvDD,IAuDC;AAvDY,oCAAY;AAyDzB,mBAAmB,IAAY;IAC7B,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,OAAO,WAAW,CAAC;KACpB;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAO,0BAA0B,CAAC;KACnC;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAO,uCAAuC,CAAC;KAChD;SAAM,IAAI,IAAI,KAAK,CAAC,EAAE;QACrB,OAAO,oDAAoD,CAAC;KAC7D;SAAM;QACL,MAAM,KAAK,CAAC,sBAAoB,IAAI,0BAAuB,CAAC,CAAC;KAC9D;AACH,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.d.ts new file mode 100644 index 0000000..faf6244 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class StridedSliceProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + rank: number; + constructor(begin: number[], strides: number[], shape: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js new file mode 100644 index 0000000..d9147dd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js @@ -0,0 +1,24 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var StridedSliceProgram = (function () { + function StridedSliceProgram(begin, strides, shape) { + this.variableNames = ['x']; + this.outputShape = shape; + this.rank = shape.length; + var dtype = shader_compiler_1.getCoordsDataType(this.rank); + var newCoords = ''; + if (this.rank === 1) { + newCoords = 'coords * strides + begin'; + } + else { + newCoords = + shape.map(function (_, i) { return "coords[" + i + "] * strides[" + i + "] + begin[" + i + "]"; }) + .join(','); + } + this.userCode = "\n " + dtype + " begin = " + dtype + "(" + begin + ");\n " + dtype + " strides = " + dtype + "(" + strides + ");\n\n void main() {\n " + dtype + " coords = getOutputCoords();\n setOutput(getX(" + newCoords + "));\n }\n "; + } + return StridedSliceProgram; +}()); +exports.StridedSliceProgram = StridedSliceProgram; +//# sourceMappingURL=strided_slice_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js.map new file mode 100644 index 0000000..eda7095 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/strided_slice_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"strided_slice_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/strided_slice_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAME,6BAAY,KAAe,EAAE,OAAiB,EAAE,KAAe;QAL/D,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAMpB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC;QACzB,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3C,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;YACnB,SAAS,GAAG,0BAA0B,CAAC;SACxC;aAAM;YACL,SAAS;gBACL,KAAK,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,YAAU,CAAC,oBAAe,CAAC,kBAAa,CAAC,MAAG,EAA5C,CAA4C,CAAC;qBAC5D,IAAI,CAAC,GAAG,CAAC,CAAC;SACpB;QAED,IAAI,CAAC,QAAQ,GAAG,aACZ,KAAK,iBAAY,KAAK,SAAI,KAAK,kBAC/B,KAAK,mBAAc,KAAK,SAAI,OAAO,2CAGjC,KAAK,6DACU,SAAS,uBAE7B,CAAC;IACJ,CAAC;IACH,0BAAC;AAAD,CAAC,AA9BD,IA8BC;AA9BY,kDAAmB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.d.ts new file mode 100644 index 0000000..d2863f1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.d.ts @@ -0,0 +1,32 @@ +import { DataType, DataTypeMap } from '../../types'; +export declare enum TextureUsage { + RENDER = 0, + UPLOAD = 1, + PIXELS = 2, + DOWNLOAD = 3 +} +export declare enum PhysicalTextureType { + FLOAT16 = 0, + FLOAT32 = 1, + UNSIGNED_BYTE = 2 +} +export interface TextureData { + texture: WebGLTexture; + shape: number[]; + texShape: [number, number]; + dtype: DataType; + values: DataTypeMap[DataType]; + usage: TextureUsage; +} +export declare function getUnpackedMatrixTextureShapeWidthHeight(rows: number, columns: number): [number, number]; +export declare function getUnpackedArraySizeFromMatrixSize(matrixSize: number, channelsPerTexture: number): number; +export declare function getColorMatrixTextureShapeWidthHeight(rows: number, columns: number): [number, number]; +export declare function getMatrixSizeFromUnpackedArraySize(unpackedSize: number, channelsPerTexture: number): number; +export declare type TypedArray = Float32Array | Uint8Array; +export declare function encodeMatrixToUnpackedArray(matrix: TypedArray, unpackedArray: TypedArray, channelsPerTexture: number): void; +export declare function decodeMatrixFromUnpackedArray(unpackedArray: Float32Array, matrix: Float32Array, channelsPerTexture: number): void; +export declare function decodeMatrixFromUnpackedColorRGBAArray(unpackedArray: Float32Array, matrix: Float32Array, channels: number): void; +export declare function getPackedMatrixTextureShapeWidthHeight(rows: number, columns: number): [number, number]; +export declare function getPackedRGBAArraySizeFromMatrixShape(rows: number, columns: number): number; +export declare function encodeMatrixToPackedRGBA(matrix: Float32Array, rows: number, columns: number, packedRGBA: Float32Array): Float32Array; +export declare function decodeMatrixFromPackedRGBA(packedRGBA: Float32Array, rows: number, columns: number, matrix: Float32Array): Float32Array; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js new file mode 100644 index 0000000..b100fb1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js @@ -0,0 +1,192 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var TextureUsage; +(function (TextureUsage) { + TextureUsage[TextureUsage["RENDER"] = 0] = "RENDER"; + TextureUsage[TextureUsage["UPLOAD"] = 1] = "UPLOAD"; + TextureUsage[TextureUsage["PIXELS"] = 2] = "PIXELS"; + TextureUsage[TextureUsage["DOWNLOAD"] = 3] = "DOWNLOAD"; +})(TextureUsage = exports.TextureUsage || (exports.TextureUsage = {})); +var PhysicalTextureType; +(function (PhysicalTextureType) { + PhysicalTextureType[PhysicalTextureType["FLOAT16"] = 0] = "FLOAT16"; + PhysicalTextureType[PhysicalTextureType["FLOAT32"] = 1] = "FLOAT32"; + PhysicalTextureType[PhysicalTextureType["UNSIGNED_BYTE"] = 2] = "UNSIGNED_BYTE"; +})(PhysicalTextureType = exports.PhysicalTextureType || (exports.PhysicalTextureType = {})); +function getUnpackedMatrixTextureShapeWidthHeight(rows, columns) { + return [columns, rows]; +} +exports.getUnpackedMatrixTextureShapeWidthHeight = getUnpackedMatrixTextureShapeWidthHeight; +function getUnpackedArraySizeFromMatrixSize(matrixSize, channelsPerTexture) { + return matrixSize * channelsPerTexture; +} +exports.getUnpackedArraySizeFromMatrixSize = getUnpackedArraySizeFromMatrixSize; +function getColorMatrixTextureShapeWidthHeight(rows, columns) { + return [columns * 4, rows]; +} +exports.getColorMatrixTextureShapeWidthHeight = getColorMatrixTextureShapeWidthHeight; +function getMatrixSizeFromUnpackedArraySize(unpackedSize, channelsPerTexture) { + if (unpackedSize % channelsPerTexture !== 0) { + throw new Error("unpackedSize (" + unpackedSize + ") must be a multiple of " + + ("" + channelsPerTexture)); + } + return unpackedSize / channelsPerTexture; +} +exports.getMatrixSizeFromUnpackedArraySize = getMatrixSizeFromUnpackedArraySize; +function encodeMatrixToUnpackedArray(matrix, unpackedArray, channelsPerTexture) { + var requiredSize = getUnpackedArraySizeFromMatrixSize(matrix.length, channelsPerTexture); + if (unpackedArray.length < requiredSize) { + throw new Error("unpackedArray length (" + unpackedArray.length + ") must be >= " + + ("" + requiredSize)); + } + var dst = 0; + for (var src = 0; src < matrix.length; ++src) { + unpackedArray[dst] = matrix[src]; + dst += channelsPerTexture; + } +} +exports.encodeMatrixToUnpackedArray = encodeMatrixToUnpackedArray; +function decodeMatrixFromUnpackedArray(unpackedArray, matrix, channelsPerTexture) { + var requiredSize = getMatrixSizeFromUnpackedArraySize(unpackedArray.length, channelsPerTexture); + if (matrix.length < requiredSize) { + throw new Error("matrix length (" + matrix.length + ") must be >= " + requiredSize); + } + var dst = 0; + for (var src = 0; src < unpackedArray.length; src += channelsPerTexture) { + matrix[dst++] = unpackedArray[src]; + } +} +exports.decodeMatrixFromUnpackedArray = decodeMatrixFromUnpackedArray; +function decodeMatrixFromUnpackedColorRGBAArray(unpackedArray, matrix, channels) { + var requiredSize = unpackedArray.length * channels / 4; + if (matrix.length < requiredSize) { + throw new Error("matrix length (" + matrix.length + ") must be >= " + requiredSize); + } + var dst = 0; + for (var src = 0; src < unpackedArray.length; src += 4) { + for (var c = 0; c < channels; c++) { + matrix[dst++] = unpackedArray[src + c]; + } + } +} +exports.decodeMatrixFromUnpackedColorRGBAArray = decodeMatrixFromUnpackedColorRGBAArray; +function getPackedMatrixTextureShapeWidthHeight(rows, columns) { + return [Math.ceil(columns / 2), Math.ceil(rows / 2)]; +} +exports.getPackedMatrixTextureShapeWidthHeight = getPackedMatrixTextureShapeWidthHeight; +function getPackedRGBAArraySizeFromMatrixShape(rows, columns) { + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + return w * h * 4; +} +exports.getPackedRGBAArraySizeFromMatrixShape = getPackedRGBAArraySizeFromMatrixShape; +function encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA) { + var requiredSize = getPackedRGBAArraySizeFromMatrixShape(rows, columns); + if (packedRGBA.length < requiredSize) { + throw new Error("packedRGBA length (" + packedRGBA.length + ") must be >= " + requiredSize); + } + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), textureWidth = _a[0], textureHeight = _a[1]; + var oddWidth = (columns % 2) === 1; + var oddHeight = (rows % 2) === 1; + var widthInFullBlocks = Math.floor(columns / 2); + var heightInFullBlocks = Math.floor(rows / 2); + { + var dstStride = (oddWidth ? 4 : 0); + var oneRow = columns; + var dst = 0; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + var matrixSrcRow = (blockY * 2 * columns); + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + var matrixSrcCol = blockX * 2; + var src = matrixSrcRow + matrixSrcCol; + packedRGBA[dst] = matrix[src]; + packedRGBA[dst + 1] = matrix[src + 1]; + packedRGBA[dst + 2] = matrix[src + oneRow]; + packedRGBA[dst + 3] = matrix[src + oneRow + 1]; + dst += 4; + } + dst += dstStride; + } + } + if (oddWidth) { + var src = columns - 1; + var dst = (textureWidth - 1) * 4; + var srcStride = 2 * columns; + var dstStride = textureWidth * 4; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + packedRGBA[dst] = matrix[src]; + packedRGBA[dst + 2] = matrix[src + columns]; + src += srcStride; + dst += dstStride; + } + } + if (oddHeight) { + var src = (rows - 1) * columns; + var dst = (textureHeight - 1) * textureWidth * 4; + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + packedRGBA[dst++] = matrix[src++]; + packedRGBA[dst++] = matrix[src++]; + dst += 2; + } + } + if (oddWidth && oddHeight) { + packedRGBA[packedRGBA.length - 4] = matrix[matrix.length - 1]; + } + return packedRGBA; +} +exports.encodeMatrixToPackedRGBA = encodeMatrixToPackedRGBA; +function decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix) { + var requiredSize = rows * columns; + if (requiredSize < matrix.length) { + throw new Error("matrix length (" + matrix.length + ") must be >= " + requiredSize); + } + var oddWidth = (columns % 2) === 1; + var oddHeight = (rows % 2) === 1; + var widthInFullBlocks = Math.floor(columns / 2); + var heightInFullBlocks = Math.floor(rows / 2); + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), textureWidth = _a[0], textureHeight = _a[1]; + { + var srcStride = oddWidth ? 4 : 0; + var dstStride = columns + (oddWidth ? 1 : 0); + var src = 0; + var dstRow1 = 0; + var dstRow2 = columns; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + matrix[dstRow1++] = packedRGBA[src++]; + matrix[dstRow1++] = packedRGBA[src++]; + matrix[dstRow2++] = packedRGBA[src++]; + matrix[dstRow2++] = packedRGBA[src++]; + } + src += srcStride; + dstRow1 += dstStride; + dstRow2 += dstStride; + } + } + if (oddWidth) { + var src = (textureWidth - 1) * 4; + var dst = columns - 1; + var srcStride = textureWidth * 4; + var dstStride = 2 * columns; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + matrix[dst] = packedRGBA[src]; + matrix[dst + columns] = packedRGBA[src + 2]; + src += srcStride; + dst += dstStride; + } + } + if (oddHeight) { + var src = (textureHeight - 1) * textureWidth * 4; + var dst = (rows - 1) * columns; + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + matrix[dst++] = packedRGBA[src++]; + matrix[dst++] = packedRGBA[src++]; + src += 2; + } + } + if (oddWidth && oddHeight) { + matrix[matrix.length - 1] = packedRGBA[packedRGBA.length - 4]; + } + return matrix; +} +exports.decodeMatrixFromPackedRGBA = decodeMatrixFromPackedRGBA; +//# sourceMappingURL=tex_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js.map new file mode 100644 index 0000000..66d8843 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tex_util.js","sourceRoot":"","sources":["../../../src/kernels/webgl/tex_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js new file mode 100644 index 0000000..c4c0d97 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js @@ -0,0 +1,204 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var test_util_1 = require("../../test_util"); +var tex_util = require("./tex_util"); +describe('tex_util getUnpackedMatrixTextureShapeWidthHeight', function () { + it('[1x1] => [1x1]', function () { + expect(tex_util.getUnpackedMatrixTextureShapeWidthHeight(1, 1)).toEqual([ + 1, 1 + ]); + }); + it('[MxN] => [NxM]', function () { + expect(tex_util.getUnpackedMatrixTextureShapeWidthHeight(123, 456)) + .toEqual([456, 123]); + }); +}); +describe('tex_util getPackedMatrixTextureShapeWidthHeight', function () { + it('[1x1] => [1x1]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(1, 1); + expect(shape).toEqual([1, 1]); + }); + it('[1x2] => [1x1]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(1, 2); + expect(shape).toEqual([1, 1]); + }); + it('[2x1] => [1x1]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(2, 1); + expect(shape).toEqual([1, 1]); + }); + it('[2x2] => [1x1]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(2, 2); + expect(shape).toEqual([1, 1]); + }); + it('[3x3] => [2x2]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(3, 3); + expect(shape).toEqual([2, 2]); + }); + it('[4x3] => [2x2]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(4, 3); + expect(shape).toEqual([2, 2]); + }); + it('[3x4] => [2x2]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(3, 4); + expect(shape).toEqual([2, 2]); + }); + it('[4x4] => [2x2]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(4, 4); + expect(shape).toEqual([2, 2]); + }); + it('[1024x1024] => [512x512]', function () { + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(1024, 1024); + expect(shape).toEqual([512, 512]); + }); + it('[MxN] => [ceil(N/2)xceil(M/2)]', function () { + var M = 123; + var N = 5013; + var shape = tex_util.getPackedMatrixTextureShapeWidthHeight(M, N); + expect(shape).toEqual([Math.ceil(N / 2), Math.ceil(M / 2)]); + }); +}); +describe('tex_util encodeMatrixToUnpackedArray, channels = 4', function () { + it('1x1 writes the only matrix array value to the only texel', function () { + var matrix = new Float32Array([1]); + var unpackedRGBA = new Float32Array([0, 0, 0, 0]); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 4); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([1, 0, 0, 0])); + }); + it('1x1 can upload texels with values greater than 1', function () { + var matrix = new Float32Array([100]); + var unpackedRGBA = new Float32Array([0, 0, 0, 0]); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 4); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([100, 0, 0, 0])); + }); + it('1x4 each texel has 4 elements with matrix value in R channel', function () { + var matrix = new Float32Array([1, 2, 3, 4]); + var unpackedRGBA = new Float32Array(16); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 4); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([1, 0, 0, 0, 2, 0, 0, 0, 3, 0, 0, 0, 4, 0, 0, 0])); + }); +}); +describe('tex_util encodeMatrixToUnpackedArray, channels = 1', function () { + it('1x1 writes the only matrix array value to the only texel', function () { + var matrix = new Float32Array([1]); + var unpackedRGBA = new Float32Array([0]); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 1); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([1])); + }); + it('1x1 can upload texels with values greater than 1', function () { + var matrix = new Float32Array([100]); + var unpackedRGBA = new Float32Array([0]); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 1); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([100])); + }); + it('1x4 each texel has 4 elements with matrix value in R channel', function () { + var matrix = new Float32Array([1, 2, 3, 4]); + var unpackedRGBA = new Float32Array(4); + tex_util.encodeMatrixToUnpackedArray(matrix, unpackedRGBA, 1); + test_util_1.expectArraysClose(unpackedRGBA, new Float32Array([1, 2, 3, 4])); + }); +}); +describe('tex_util decodeMatrixFromUnpackedArray', function () { + it('1x1 writes the only matrix array value to the first element', function () { + var unpackedRGBA = new Float32Array([1, 0, 0, 0]); + var matrix = new Float32Array(1); + tex_util.decodeMatrixFromUnpackedArray(unpackedRGBA, matrix, 4); + expect(matrix.length).toEqual(1); + expect(matrix[0]).toEqual(1); + }); + it('1x2 writes the second texel R component to the second element', function () { + var unpackedRGBA = new Float32Array([1, 0, 0, 0, 2, 0, 0, 0]); + var matrix = new Float32Array(2); + tex_util.decodeMatrixFromUnpackedArray(unpackedRGBA, matrix, 4); + expect(matrix.length).toEqual(2); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2])); + }); +}); +describe('tex_util encodeMatrixToPackedRGBA', function () { + it('1x1 loads the element into R and 0\'s into GBA', function () { + var matrix = new Float32Array([1]); + var packedRGBA = new Float32Array(4); + tex_util.encodeMatrixToPackedRGBA(matrix, 1, 1, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 0, 0, 0])); + }); + it('1x2 loads the second element into G and 0\'s into BA', function () { + var matrix = new Float32Array([1, 2]); + var packedRGBA = new Float32Array(4); + tex_util.encodeMatrixToPackedRGBA(matrix, 1, 2, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 2, 0, 0])); + }); + it('2x1 loads the second element into G and 0\'s into BA', function () { + var matrix = new Float32Array([1, 2]); + var packedRGBA = new Float32Array(4); + tex_util.encodeMatrixToPackedRGBA(matrix, 2, 1, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 0, 2, 0])); + }); + it('2x2 exactly fills one texel', function () { + var matrix = new Float32Array([1, 2, 3, 4]); + var packedRGBA = new Float32Array(4); + tex_util.encodeMatrixToPackedRGBA(matrix, 2, 2, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 2, 3, 4])); + }); + it('4x3 pads the final column G and A channels with 0', function () { + var matrix = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + var packedRGBA = new Float32Array(16); + tex_util.encodeMatrixToPackedRGBA(matrix, 4, 3, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 2, 4, 5, 3, 0, 6, 0, 7, 8, 10, 11, 9, 0, 12, 0])); + }); + it('3x4 pads the final row B and A channels with 0', function () { + var matrix = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + var packedRGBA = new Float32Array(16); + tex_util.encodeMatrixToPackedRGBA(matrix, 3, 4, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 2, 5, 6, 3, 4, 7, 8, 9, 10, 0, 0, 11, 12, 0, 0])); + }); + it('3x3 bottom-right texel is R000', function () { + var matrix = new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9]); + var packedRGBA = new Float32Array(16); + tex_util.encodeMatrixToPackedRGBA(matrix, 3, 3, packedRGBA); + test_util_1.expectArraysClose(packedRGBA, new Float32Array([1, 2, 4, 5, 3, 0, 6, 0, 7, 8, 0, 0, 9, 0, 0, 0])); + }); +}); +describe('tex_util decodeMatrixFromPackedRGBA', function () { + it('1x1 matrix only loads R component from only texel', function () { + var packedRGBA = new Float32Array([1, 0, 0, 0]); + var matrix = new Float32Array(1); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 1, 1, matrix); + expect(matrix[0]).toEqual(1); + }); + it('1x2 matrix loads RG from only texel', function () { + var packedRGBA = new Float32Array([1, 2, 0, 0]); + var matrix = new Float32Array(2); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 1, 2, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2])); + }); + it('2x1 matrix loads RB from only texel', function () { + var packedRGBA = new Float32Array([1, 0, 2, 0]); + var matrix = new Float32Array(2); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 2, 1, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2])); + }); + it('2x2 matrix loads RGBA from only texel', function () { + var packedRGBA = new Float32Array([1, 2, 3, 4]); + var matrix = new Float32Array(4); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 2, 2, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2, 3, 4])); + }); + it('4x3 final column only reads RB from edge texels', function () { + var packedRGBA = new Float32Array([1, 2, 4, 5, 3, 0, 6, 0, 7, 8, 10, 11, 9, 0, 12, 0]); + var matrix = new Float32Array(12); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 4, 3, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12])); + }); + it('3x4 final row only reads RG from edge texels', function () { + var packedRGBA = new Float32Array([1, 2, 5, 6, 3, 4, 7, 8, 9, 10, 0, 0, 11, 12, 0, 0]); + var matrix = new Float32Array(12); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 3, 4, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12])); + }); + it('3x3 bottom-right only reads R from corner texel', function () { + var packedRGBA = new Float32Array([1, 2, 4, 5, 3, 0, 6, 0, 7, 8, 0, 0, 9, 0, 0, 0]); + var matrix = new Float32Array(9); + tex_util.decodeMatrixFromPackedRGBA(packedRGBA, 3, 3, matrix); + test_util_1.expectArraysClose(matrix, new Float32Array([1, 2, 3, 4, 5, 6, 7, 8, 9])); + }); +}); +//# sourceMappingURL=tex_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js.map new file mode 100644 index 0000000..097103e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tex_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tex_util_test.js","sourceRoot":"","sources":["../../../src/kernels/webgl/tex_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.d.ts new file mode 100644 index 0000000..7c9e6db --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.d.ts @@ -0,0 +1,17 @@ +import { GPGPUContext } from './gpgpu_context'; +import { TextureUsage } from './tex_util'; +export declare class TextureManager { + private gpgpu; + private numUsedTextures; + private numFreeTextures; + private freeTextures; + private logEnabled; + private usedTextures; + constructor(gpgpu: GPGPUContext); + acquireTexture(shapeRC: [number, number], usage: TextureUsage): WebGLTexture; + releaseTexture(texture: WebGLTexture, shape: [number, number], logicalTexType: TextureUsage): void; + private log; + getNumUsedTextures(): number; + getNumFreeTextures(): number; + dispose(): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js new file mode 100644 index 0000000..9779cb8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js @@ -0,0 +1,121 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../../environment"); +var tex_util_1 = require("./tex_util"); +var TextureManager = (function () { + function TextureManager(gpgpu) { + this.gpgpu = gpgpu; + this.numUsedTextures = 0; + this.numFreeTextures = 0; + this.freeTextures = {}; + this.logEnabled = false; + this.usedTextures = {}; + } + TextureManager.prototype.acquireTexture = function (shapeRC, usage) { + var physicalTexType = getPhysicalFromLogicalTextureType(usage); + var shapeKey = getKeyFromTextureShape(shapeRC, physicalTexType); + if (!(shapeKey in this.freeTextures)) { + this.freeTextures[shapeKey] = []; + } + if (!(shapeKey in this.usedTextures)) { + this.usedTextures[shapeKey] = []; + } + if (this.freeTextures[shapeKey].length > 0) { + this.numFreeTextures--; + this.numUsedTextures++; + this.log(); + var newTexture_1 = this.freeTextures[shapeKey].shift(); + this.usedTextures[shapeKey].push(newTexture_1); + return newTexture_1; + } + this.numUsedTextures++; + this.log(); + var newTexture; + if (physicalTexType === tex_util_1.PhysicalTextureType.FLOAT32) { + newTexture = + this.gpgpu.createFloat32MatrixTexture(shapeRC[0], shapeRC[1]); + } + else if (physicalTexType === tex_util_1.PhysicalTextureType.FLOAT16) { + newTexture = + this.gpgpu.createFloat16MatrixTexture(shapeRC[0], shapeRC[1]); + } + else if (physicalTexType === tex_util_1.PhysicalTextureType.UNSIGNED_BYTE) { + newTexture = + this.gpgpu.createUnsignedBytesMatrixTexture(shapeRC[0], shapeRC[1]); + } + this.usedTextures[shapeKey].push(newTexture); + return newTexture; + }; + TextureManager.prototype.releaseTexture = function (texture, shape, logicalTexType) { + var physicalTexType = getPhysicalFromLogicalTextureType(logicalTexType); + var shapeKey = getKeyFromTextureShape(shape, physicalTexType); + if (!(shapeKey in this.freeTextures)) { + this.freeTextures[shapeKey] = []; + } + this.freeTextures[shapeKey].push(texture); + this.numFreeTextures++; + this.numUsedTextures--; + var texList = this.usedTextures[shapeKey]; + var texIndex = texList.indexOf(texture); + if (texIndex < 0) { + throw new Error('Cannot release a texture that was never provided by this ' + + 'texture manager'); + } + texList.splice(texIndex, 1); + this.log(); + }; + TextureManager.prototype.log = function () { + if (!this.logEnabled) { + return; + } + var total = this.numFreeTextures + this.numUsedTextures; + console.log('Free/Used', this.numFreeTextures + " / " + this.numUsedTextures, "(" + total + ")"); + }; + TextureManager.prototype.getNumUsedTextures = function () { + return this.numUsedTextures; + }; + TextureManager.prototype.getNumFreeTextures = function () { + return this.numFreeTextures; + }; + TextureManager.prototype.dispose = function () { + var _this = this; + if (this.freeTextures == null) { + return; + } + for (var texShape in this.freeTextures) { + this.freeTextures[texShape].forEach(function (tex) { + _this.gpgpu.deleteMatrixTexture(tex); + }); + } + for (var texShape in this.usedTextures) { + this.usedTextures[texShape].forEach(function (tex) { + _this.gpgpu.deleteMatrixTexture(tex); + }); + } + this.freeTextures = null; + this.usedTextures = null; + this.numUsedTextures = 0; + this.numFreeTextures = 0; + }; + return TextureManager; +}()); +exports.TextureManager = TextureManager; +function getPhysicalFromLogicalTextureType(logicalTexType) { + if (logicalTexType === tex_util_1.TextureUsage.DOWNLOAD || + logicalTexType === tex_util_1.TextureUsage.PIXELS) { + return tex_util_1.PhysicalTextureType.UNSIGNED_BYTE; + } + else if (logicalTexType === tex_util_1.TextureUsage.UPLOAD) { + return tex_util_1.PhysicalTextureType.FLOAT32; + } + else if (logicalTexType === tex_util_1.TextureUsage.RENDER) { + return environment_1.ENV.get('WEBGL_RENDER_FLOAT32_ENABLED') ? + tex_util_1.PhysicalTextureType.FLOAT32 : + tex_util_1.PhysicalTextureType.FLOAT16; + } + throw new Error("Unknown logical texture type " + logicalTexType); +} +function getKeyFromTextureShape(shapeRowsCol, physicalTexType) { + return shapeRowsCol[0] + "_" + shapeRowsCol[1] + "_" + physicalTexType; +} +//# sourceMappingURL=texture_manager.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js.map new file mode 100644 index 0000000..45c0610 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/texture_manager.js.map @@ -0,0 +1 @@ +{"version":3,"file":"texture_manager.js","sourceRoot":"","sources":["../../../src/kernels/webgl/texture_manager.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.d.ts new file mode 100644 index 0000000..8476401 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class TileProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + rank: number; + constructor(aShape: number[], reps: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js new file mode 100644 index 0000000..8107e12 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js @@ -0,0 +1,35 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var TileProgram = (function () { + function TileProgram(aShape, reps) { + this.variableNames = ['A']; + var outputShape = new Array(aShape.length); + for (var i = 0; i < outputShape.length; i++) { + outputShape[i] = aShape[i] * reps[i]; + } + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = shader_compiler_1.getCoordsDataType(this.rank); + var sourceCoords = getSourceCoords(aShape); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + sourceCoords + "));\n }\n "; + } + return TileProgram; +}()); +exports.TileProgram = TileProgram; +function getSourceCoords(aShape) { + var rank = aShape.length; + if (rank > 5) { + throw Error("Tile for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + return "imod(resRC, " + aShape[0] + ")"; + } + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u']; + var sourceCoords = []; + for (var i = 0; i < aShape.length; i++) { + sourceCoords.push("imod(" + currentCoords[i] + ", " + aShape[i] + ")"); + } + return sourceCoords.join(); +} +//# sourceMappingURL=tile_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js.map new file mode 100644 index 0000000..8b48e6f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/tile_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tile_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/tile_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAME,qBAAY,MAAgB,EAAE,IAAc;QAL5C,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAMpB,IAAM,WAAW,GAAa,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC3C,WAAW,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;SACtC;QACD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,MAAM,CAAC;QAC/B,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAM,YAAY,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;QAE7C,IAAI,CAAC,QAAQ,GAAG,oCAEV,KAAK,4DACU,YAAY,uBAEhC,CAAC;IACJ,CAAC;IACH,kBAAC;AAAD,CAAC,AAvBD,IAuBC;AAvBY,kCAAW;AAyBxB,yBAAyB,MAAgB;IACvC,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,IAAI,IAAI,GAAG,CAAC,EAAE;QACZ,MAAM,KAAK,CAAC,mBAAiB,IAAI,0BAAuB,CAAC,CAAC;KAC3D;IACD,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,OAAO,iBAAe,MAAM,CAAC,CAAC,CAAC,MAAG,CAAC;KACpC;IAED,IAAM,aAAa,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IAE9E,IAAM,YAAY,GAAG,EAAE,CAAC;IACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACtC,YAAY,CAAC,IAAI,CAAC,UAAQ,aAAa,CAAC,CAAC,CAAC,UAAK,MAAM,CAAC,CAAC,CAAC,MAAG,CAAC,CAAC;KAC9D;IACD,OAAO,YAAY,CAAC,IAAI,EAAE,CAAC;AAC7B,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.d.ts new file mode 100644 index 0000000..982c730 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.d.ts @@ -0,0 +1,8 @@ +import { GPGPUProgram } from './gpgpu_math'; +export declare class TransposeProgram implements GPGPUProgram { + variableNames: string[]; + outputShape: number[]; + userCode: string; + rank: number; + constructor(aShape: number[], newDim: number[]); +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js new file mode 100644 index 0000000..753cc5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js @@ -0,0 +1,32 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var shader_compiler_1 = require("./shader_compiler"); +var TransposeProgram = (function () { + function TransposeProgram(aShape, newDim) { + this.variableNames = ['A']; + var outputShape = new Array(aShape.length); + for (var i = 0; i < outputShape.length; i++) { + outputShape[i] = aShape[newDim[i]]; + } + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = shader_compiler_1.getCoordsDataType(this.rank); + var switched = getSwitchedCoords(newDim); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + switched + "));\n }\n "; + } + return TransposeProgram; +}()); +exports.TransposeProgram = TransposeProgram; +function getSwitchedCoords(newDim) { + var rank = newDim.length; + if (rank > 6) { + throw Error("Transpose for rank " + rank + " is not yet supported"); + } + var originalOrder = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u', 'resRC.v']; + var switchedCoords = new Array(rank); + for (var i = 0; i < newDim.length; i++) { + switchedCoords[newDim[i]] = originalOrder[i]; + } + return switchedCoords.join(); +} +//# sourceMappingURL=transpose_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js.map new file mode 100644 index 0000000..20369f6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/transpose_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"transpose_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/transpose_gpu.ts"],"names":[],"mappings":";;AAkBA,qDAAoD;AAEpD;IAME,0BAAY,MAAgB,EAAE,MAAgB;QAL9C,kBAAa,GAAG,CAAC,GAAG,CAAC,CAAC;QAMpB,IAAM,WAAW,GAAa,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC3C,WAAW,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SACpC;QACD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,MAAM,CAAC;QAC/B,IAAM,KAAK,GAAG,mCAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAM,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE3C,IAAI,CAAC,QAAQ,GAAG,gCAEZ,KAAK,0DACU,QAAQ,qBAE1B,CAAC;IACJ,CAAC;IACH,uBAAC;AAAD,CAAC,AAvBD,IAuBC;AAvBY,4CAAgB;AAyB7B,2BAA2B,MAAgB;IACzC,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,IAAI,IAAI,GAAG,CAAC,EAAE;QACZ,MAAM,KAAK,CAAC,wBAAsB,IAAI,0BAAuB,CAAC,CAAC;KAChE;IACD,IAAM,aAAa,GACf,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IACvE,IAAM,cAAc,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC;IACvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACtC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;KAC9C;IACD,OAAO,cAAc,CAAC,IAAI,EAAE,CAAC;AAC/B,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.d.ts new file mode 100644 index 0000000..bbbe5b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.d.ts @@ -0,0 +1,45 @@ +import { GPGPUProgram } from './gpgpu_math'; +import { GPGPUContext } from './gpgpu_context'; +export declare class UnaryOpProgram implements GPGPUProgram { + variableNames: string[]; + userCode: string; + outputShape: number[]; + startLoc: WebGLUniformLocation; + constructor(aShape: number[], opSnippet: string); + getCustomSetupFunc(): (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void; +} +export declare const ABS = "return abs(x);"; +export declare const RELU: string; +export declare const ELU = "return (x >= 0.0) ? x : (exp(x) - 1.0);"; +export declare const SELU: string; +export declare function STEP(alpha?: number): string; +export declare const NEG = "return -x;"; +export declare const CEIL = "return ceil(x);"; +export declare const FLOOR = "return floor(x);"; +export declare const SIGN = "\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n"; +export declare const ROUND = "\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n"; +export declare const EXP = "return exp(x);"; +export declare const EXPM1 = "return exp(x) - 1.0;"; +export declare const LOG = "if (x < 0.0) return NAN;\n return log(x);"; +export declare const LOG1P = "return log(1.0 + x);"; +export declare const SQRT = "return sqrt(x);"; +export declare const RSQRT = "return inversesqrt(x);"; +export declare const SIGMOID = "return 1.0 / (1.0 + exp(-1.0 * x));"; +export declare const SOFTPLUS = "\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n"; +export declare const SIN: string; +export declare const COS: string; +export declare const TAN = "return tan(x);"; +export declare const ASIN = "return asin(x);"; +export declare const ACOS = "return acos(x);"; +export declare const ATAN: string; +export declare const SINH = "\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n"; +export declare const COSH = "\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n"; +export declare const TANH = "\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n"; +export declare const ASINH = "return log(x + sqrt(x * x + 1.0));"; +export declare const ACOSH: string; +export declare const ATANH: string; +export declare const ERF: string; +export declare const SQUARE = "return x * x;"; +export declare const RECIPROCAL = "return 1.0 / x;"; +export declare const LOGICAL_NOT = "return float(!(x >= 1.0));"; +export declare const TO_INT = "return float(int(x));"; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js new file mode 100644 index 0000000..8160ca9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js @@ -0,0 +1,66 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var erf_util = require("../../ops/erf_util"); +var selu_util = require("../../ops/selu_util"); +var UnaryOpProgram = (function () { + function UnaryOpProgram(aShape, opSnippet) { + this.variableNames = ['A']; + this.outputShape = aShape; + this.userCode = "\n uniform float NAN;\n float unaryOperation(float x) {\n " + opSnippet + "\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n "; + } + UnaryOpProgram.prototype.getCustomSetupFunc = function () { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN'); + if (_this.startLoc == null) { + return; + } + } + gpgpu.gl.uniform1f(_this.startLoc, NaN); + }; + }; + return UnaryOpProgram; +}()); +exports.UnaryOpProgram = UnaryOpProgram; +var CHECK_NAN_SNIPPET = "if (isNaN(x)) return x;"; +exports.ABS = "return abs(x);"; +exports.RELU = CHECK_NAN_SNIPPET + "\n return (x < 0.0) ? 0.0 : x;\n"; +exports.ELU = "return (x >= 0.0) ? x : (exp(x) - 1.0);"; +exports.SELU = "\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = " + selu_util.SELU_SCALEALPHA + ";\n float scale = " + selu_util.SELU_SCALE + ";\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n"; +function STEP(alpha) { + if (alpha === void 0) { alpha = 0.0; } + return CHECK_NAN_SNIPPET + ("\n return x > 0.0 ? 1.0 : float(" + alpha + ");\n "); +} +exports.STEP = STEP; +exports.NEG = "return -x;"; +exports.CEIL = "return ceil(x);"; +exports.FLOOR = "return floor(x);"; +exports.SIGN = "\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n"; +exports.ROUND = "\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n"; +exports.EXP = "return exp(x);"; +exports.EXPM1 = "return exp(x) - 1.0;"; +exports.LOG = "if (x < 0.0) return NAN;\n return log(x);"; +exports.LOG1P = "return log(1.0 + x);"; +exports.SQRT = "return sqrt(x);"; +exports.RSQRT = "return inversesqrt(x);"; +exports.SIGMOID = "return 1.0 / (1.0 + exp(-1.0 * x));"; +exports.SOFTPLUS = "\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n"; +exports.SIN = CHECK_NAN_SNIPPET + "\n return sin(x);\n"; +exports.COS = CHECK_NAN_SNIPPET + "\n return cos(x);\n"; +exports.TAN = "return tan(x);"; +exports.ASIN = "return asin(x);"; +exports.ACOS = "return acos(x);"; +exports.ATAN = CHECK_NAN_SNIPPET + "\n return atan(x);\n"; +exports.SINH = "\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n"; +exports.COSH = "\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n"; +exports.TANH = "\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n"; +exports.ASINH = "return log(x + sqrt(x * x + 1.0));"; +exports.ACOSH = CHECK_NAN_SNIPPET + "\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));"; +exports.ATANH = CHECK_NAN_SNIPPET + "\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;"; +exports.ERF = "\n // Error function is calculated approximately with elementary function.\n // See \"Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\n float p = " + erf_util.ERF_P + ";\n float a1 = " + erf_util.ERF_A1 + ";\n float a2 = " + erf_util.ERF_A2 + ";\n float a3 = " + erf_util.ERF_A3 + ";\n float a4 = " + erf_util.ERF_A4 + ";\n float a5 = " + erf_util.ERF_A5 + ";\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n"; +exports.SQUARE = "return x * x;"; +exports.RECIPROCAL = "return 1.0 / x;"; +exports.LOGICAL_NOT = "return float(!(x >= 1.0));"; +exports.TO_INT = "return float(int(x));"; +//# sourceMappingURL=unaryop_gpu.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js.map new file mode 100644 index 0000000..90e3e52 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/unaryop_gpu.js.map @@ -0,0 +1 @@ +{"version":3,"file":"unaryop_gpu.js","sourceRoot":"","sources":["../../../src/kernels/webgl/unaryop_gpu.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.d.ts new file mode 100644 index 0000000..5cfe4b2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.d.ts @@ -0,0 +1,26 @@ +/// +export interface WebGL2DisjointQueryTimerExtension { + TIME_ELAPSED_EXT: number; + GPU_DISJOINT_EXT: number; +} +export interface WebGL1DisjointQueryTimerExtension { + TIME_ELAPSED_EXT: number; + QUERY_RESULT_AVAILABLE_EXT: number; + GPU_DISJOINT_EXT: number; + QUERY_RESULT_EXT: number; + createQueryEXT: () => {}; + beginQueryEXT: (ext: number, query: WebGLQuery) => void; + endQueryEXT: (ext: number) => void; + deleteQueryEXT: (query: WebGLQuery) => void; + isQueryEXT: (query: WebGLQuery) => boolean; + getQueryObjectEXT: (query: WebGLQuery, queryResultAvailableExt: number) => number; +} +export interface WebGLContextAttributes { + alpha?: boolean; + antialias?: boolean; + premultipliedAlpha?: boolean; + preserveDrawingBuffer?: boolean; + depth?: boolean; + stencil?: boolean; + failIfMajorPerformanceCaveat?: boolean; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js new file mode 100644 index 0000000..2c46246 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=webgl_types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js.map new file mode 100644 index 0000000..e4ce532 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"webgl_types.js","sourceRoot":"","sources":["../../../src/kernels/webgl/webgl_types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.d.ts new file mode 100644 index 0000000..25260ff --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.d.ts @@ -0,0 +1,31 @@ +export declare function createWebGLRenderingContext(attributes: WebGLContextAttributes): WebGLRenderingContext; +export declare function createWebGLRenderingContextFromCanvas(canvas: HTMLCanvasElement, attributes: WebGLContextAttributes): WebGLRenderingContext; +export declare function callAndCheck(gl: WebGLRenderingContext, func: () => T): T; +export declare function enableDebugWebGLErrorChecking(enabled: boolean): void; +export declare function checkWebGLError(gl: WebGLRenderingContext): void; +export declare function getWebGLErrorMessage(gl: WebGLRenderingContext, status: number): string; +export declare function getExtensionOrThrow(gl: WebGLRenderingContext, extensionName: string): {}; +export declare function createVertexShader(gl: WebGLRenderingContext, vertexShaderSource: string): WebGLShader; +export declare function createFragmentShader(gl: WebGLRenderingContext, fragmentShaderSource: string): WebGLShader; +export declare function createProgram(gl: WebGLRenderingContext): WebGLProgram; +export declare function linkProgram(gl: WebGLRenderingContext, program: WebGLProgram): void; +export declare function validateProgram(gl: WebGLRenderingContext, program: WebGLProgram): void; +export declare function createStaticVertexBuffer(gl: WebGLRenderingContext, data: Float32Array): WebGLBuffer; +export declare function createStaticIndexBuffer(gl: WebGLRenderingContext, data: Uint16Array): WebGLBuffer; +export declare function queryMaxTextureSize(gl: WebGLRenderingContext): number; +export declare function getNumChannels(): number; +export declare function createTexture(gl: WebGLRenderingContext): WebGLTexture; +export declare function validateTextureSize(gl: WebGLRenderingContext, width: number, height: number): void; +export declare function createFramebuffer(gl: WebGLRenderingContext): WebGLFramebuffer; +export declare function bindVertexBufferToProgramAttribute(gl: WebGLRenderingContext, program: WebGLProgram, attribute: string, buffer: WebGLBuffer, arrayEntriesPerItem: number, itemStrideInBytes: number, itemOffsetInBytes: number): boolean; +export declare function bindTextureUnit(gl: WebGLRenderingContext, texture: WebGLTexture, textureUnit: number): void; +export declare function unbindTextureUnit(gl: WebGLRenderingContext, textureUnit: number): void; +export declare function getProgramUniformLocationOrThrow(gl: WebGLRenderingContext, program: WebGLProgram, uniformName: string): WebGLUniformLocation; +export declare function getProgramUniformLocation(gl: WebGLRenderingContext, program: WebGLProgram, uniformName: string): WebGLUniformLocation; +export declare function bindTextureToProgramUniformSampler(gl: WebGLRenderingContext, program: WebGLProgram, texture: WebGLTexture, uniformSamplerLocation: WebGLUniformLocation, textureUnit: number): void; +export declare function bindCanvasToFramebuffer(gl: WebGLRenderingContext): void; +export declare function bindColorTextureToFramebuffer(gl: WebGLRenderingContext, texture: WebGLTexture, framebuffer: WebGLFramebuffer): void; +export declare function unbindColorTextureFromFramebuffer(gl: WebGLRenderingContext, framebuffer: WebGLFramebuffer): void; +export declare function validateFramebuffer(gl: WebGLRenderingContext): void; +export declare function getFramebufferErrorMessage(gl: WebGLRenderingContext, status: number): string; +export declare function getTextureShapeFromLogicalShape(gl: WebGLRenderingContext, logShape: number[]): [number, number]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js new file mode 100644 index 0000000..eb31506 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js @@ -0,0 +1,310 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var MAX_TEXTURE_SIZE = null; +var util = require("../../util"); +var environment_1 = require("../../environment"); +function createWebGLRenderingContext(attributes) { + var canvas = document.createElement('canvas'); + canvas.width = 1; + canvas.height = 1; + return createWebGLRenderingContextFromCanvas(canvas, attributes); +} +exports.createWebGLRenderingContext = createWebGLRenderingContext; +function createWebGLRenderingContextFromCanvas(canvas, attributes) { + var gl; + var webglVersion = environment_1.ENV.get('WEBGL_VERSION'); + if (webglVersion === 2) { + gl = canvas.getContext('webgl2', attributes); + } + else if (webglVersion === 1) { + gl = (canvas.getContext('webgl', attributes) || + canvas.getContext('experimental-webgl', attributes)); + } + if (webglVersion === 0 || gl == null) { + throw new Error('This browser does not support WebGL.'); + } + return gl; +} +exports.createWebGLRenderingContextFromCanvas = createWebGLRenderingContextFromCanvas; +function callAndCheck(gl, func) { + var returnValue = func(); + checkWebGLError(gl); + return returnValue; +} +exports.callAndCheck = callAndCheck; +var webGLDebugErrorCheckingEnabled = false; +function enableDebugWebGLErrorChecking(enabled) { + webGLDebugErrorCheckingEnabled = enabled; +} +exports.enableDebugWebGLErrorChecking = enableDebugWebGLErrorChecking; +function checkWebGLError(gl) { + if (webGLDebugErrorCheckingEnabled) { + var error = gl.getError(); + if (error !== gl.NO_ERROR) { + throw new Error('WebGL Error: ' + getWebGLErrorMessage(gl, error)); + } + } +} +exports.checkWebGLError = checkWebGLError; +function getWebGLErrorMessage(gl, status) { + switch (status) { + case gl.NO_ERROR: + return 'NO_ERROR'; + case gl.INVALID_ENUM: + return 'INVALID_ENUM'; + case gl.INVALID_VALUE: + return 'INVALID_VALUE'; + case gl.INVALID_OPERATION: + return 'INVALID_OPERATION'; + case gl.INVALID_FRAMEBUFFER_OPERATION: + return 'INVALID_FRAMEBUFFER_OPERATION'; + case gl.OUT_OF_MEMORY: + return 'OUT_OF_MEMORY'; + case gl.CONTEXT_LOST_WEBGL: + return 'CONTEXT_LOST_WEBGL'; + default: + return "Unknown error code " + status; + } +} +exports.getWebGLErrorMessage = getWebGLErrorMessage; +function getExtensionOrThrow(gl, extensionName) { + return throwIfNull(gl, function () { return gl.getExtension(extensionName); }, 'Extension "' + extensionName + '" not supported on this browser.'); +} +exports.getExtensionOrThrow = getExtensionOrThrow; +function createVertexShader(gl, vertexShaderSource) { + var vertexShader = throwIfNull(gl, function () { return gl.createShader(gl.VERTEX_SHADER); }, 'Unable to create vertex WebGLShader.'); + callAndCheck(gl, function () { return gl.shaderSource(vertexShader, vertexShaderSource); }); + callAndCheck(gl, function () { return gl.compileShader(vertexShader); }); + if (gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS) === false) { + console.log(gl.getShaderInfoLog(vertexShader)); + throw new Error('Failed to compile vertex shader.'); + } + return vertexShader; +} +exports.createVertexShader = createVertexShader; +function createFragmentShader(gl, fragmentShaderSource) { + var fragmentShader = throwIfNull(gl, function () { return gl.createShader(gl.FRAGMENT_SHADER); }, 'Unable to create fragment WebGLShader.'); + callAndCheck(gl, function () { return gl.shaderSource(fragmentShader, fragmentShaderSource); }); + callAndCheck(gl, function () { return gl.compileShader(fragmentShader); }); + if (gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS) === false) { + logShaderSourceAndInfoLog(fragmentShaderSource, gl.getShaderInfoLog(fragmentShader)); + throw new Error('Failed to compile fragment shader.'); + } + return fragmentShader; +} +exports.createFragmentShader = createFragmentShader; +var lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g; +function logShaderSourceAndInfoLog(shaderSource, shaderInfoLog) { + var lineNumberRegexResult = lineNumberRegex.exec(shaderInfoLog); + if (lineNumberRegexResult == null) { + console.log("Couldn't parse line number in error: " + shaderInfoLog); + console.log(shaderSource); + return; + } + var lineNumber = +lineNumberRegexResult[1]; + var shaderLines = shaderSource.split('\n'); + var pad = shaderLines.length.toString().length + 2; + var linesWithLineNumbers = shaderLines.map(function (line, lineNumber) { + return util.rightPad((lineNumber + 1).toString(), pad) + line; + }); + var maxLineLength = 0; + for (var i = 0; i < linesWithLineNumbers.length; i++) { + maxLineLength = Math.max(linesWithLineNumbers[i].length, maxLineLength); + } + var beforeErrorLines = linesWithLineNumbers.slice(0, lineNumber - 1); + var errorLine = linesWithLineNumbers.slice(lineNumber - 1, lineNumber); + var afterErrorLines = linesWithLineNumbers.slice(lineNumber); + console.log(beforeErrorLines.join('\n')); + console.log(shaderInfoLog.split('\n')[0]); + console.log("%c " + util.rightPad(errorLine[0], maxLineLength), 'border:1px solid red; background-color:#e3d2d2; color:#a61717'); + console.log(afterErrorLines.join('\n')); +} +function createProgram(gl) { + return throwIfNull(gl, function () { return gl.createProgram(); }, 'Unable to create WebGLProgram.'); +} +exports.createProgram = createProgram; +function linkProgram(gl, program) { + callAndCheck(gl, function () { return gl.linkProgram(program); }); + if (gl.getProgramParameter(program, gl.LINK_STATUS) === false) { + console.log(gl.getProgramInfoLog(program)); + throw new Error('Failed to link vertex and fragment shaders.'); + } +} +exports.linkProgram = linkProgram; +function validateProgram(gl, program) { + callAndCheck(gl, function () { return gl.validateProgram(program); }); + if (gl.getProgramParameter(program, gl.VALIDATE_STATUS) === false) { + console.log(gl.getProgramInfoLog(program)); + throw new Error('Shader program validation failed.'); + } +} +exports.validateProgram = validateProgram; +function createStaticVertexBuffer(gl, data) { + var buffer = throwIfNull(gl, function () { return gl.createBuffer(); }, 'Unable to create WebGLBuffer'); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW); }); + return buffer; +} +exports.createStaticVertexBuffer = createStaticVertexBuffer; +function createStaticIndexBuffer(gl, data) { + var buffer = throwIfNull(gl, function () { return gl.createBuffer(); }, 'Unable to create WebGLBuffer'); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, data, gl.STATIC_DRAW); }); + return buffer; +} +exports.createStaticIndexBuffer = createStaticIndexBuffer; +function queryMaxTextureSize(gl) { + if (MAX_TEXTURE_SIZE != null) { + return MAX_TEXTURE_SIZE; + } + MAX_TEXTURE_SIZE = + callAndCheck(gl, function () { return gl.getParameter(gl.MAX_TEXTURE_SIZE); }); + return MAX_TEXTURE_SIZE; +} +exports.queryMaxTextureSize = queryMaxTextureSize; +function getNumChannels() { + if (environment_1.ENV.get('WEBGL_VERSION') === 2) { + return 1; + } + return 4; +} +exports.getNumChannels = getNumChannels; +function createTexture(gl) { + return throwIfNull(gl, function () { return gl.createTexture(); }, 'Unable to create WebGLTexture.'); +} +exports.createTexture = createTexture; +function validateTextureSize(gl, width, height) { + var maxTextureSize = queryMaxTextureSize(gl); + if ((width <= 0) || (height <= 0)) { + var requested = "[" + width + "x" + height + "]"; + throw new Error('Requested texture size ' + requested + ' is invalid.'); + } + if ((width > maxTextureSize) || (height > maxTextureSize)) { + var requested = "[" + width + "x" + height + "]"; + var max = "[" + maxTextureSize + "x" + maxTextureSize + "]"; + throw new Error('Requested texture size ' + requested + + ' greater than WebGL maximum on this browser / GPU ' + max + '.'); + } +} +exports.validateTextureSize = validateTextureSize; +function createFramebuffer(gl) { + return throwIfNull(gl, function () { return gl.createFramebuffer(); }, 'Unable to create WebGLFramebuffer.'); +} +exports.createFramebuffer = createFramebuffer; +function bindVertexBufferToProgramAttribute(gl, program, attribute, buffer, arrayEntriesPerItem, itemStrideInBytes, itemOffsetInBytes) { + var loc = gl.getAttribLocation(program, attribute); + if (loc === -1) { + return false; + } + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.vertexAttribPointer(loc, arrayEntriesPerItem, gl.FLOAT, false, itemStrideInBytes, itemOffsetInBytes); }); + callAndCheck(gl, function () { return gl.enableVertexAttribArray(loc); }); + return true; +} +exports.bindVertexBufferToProgramAttribute = bindVertexBufferToProgramAttribute; +function bindTextureUnit(gl, texture, textureUnit) { + validateTextureUnit(gl, textureUnit); + callAndCheck(gl, function () { return gl.activeTexture(gl.TEXTURE0 + textureUnit); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); +} +exports.bindTextureUnit = bindTextureUnit; +function unbindTextureUnit(gl, textureUnit) { + validateTextureUnit(gl, textureUnit); + callAndCheck(gl, function () { return gl.activeTexture(gl.TEXTURE0 + textureUnit); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); +} +exports.unbindTextureUnit = unbindTextureUnit; +function getProgramUniformLocationOrThrow(gl, program, uniformName) { + return throwIfNull(gl, function () { return gl.getUniformLocation(program, uniformName); }, 'uniform "' + uniformName + '" not present in program.'); +} +exports.getProgramUniformLocationOrThrow = getProgramUniformLocationOrThrow; +function getProgramUniformLocation(gl, program, uniformName) { + return gl.getUniformLocation(program, uniformName); +} +exports.getProgramUniformLocation = getProgramUniformLocation; +function bindTextureToProgramUniformSampler(gl, program, texture, uniformSamplerLocation, textureUnit) { + callAndCheck(gl, function () { return bindTextureUnit(gl, texture, textureUnit); }); + callAndCheck(gl, function () { return gl.uniform1i(uniformSamplerLocation, textureUnit); }); +} +exports.bindTextureToProgramUniformSampler = bindTextureToProgramUniformSampler; +function bindCanvasToFramebuffer(gl) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, null); }); + callAndCheck(gl, function () { return gl.viewport(0, 0, gl.canvas.width, gl.canvas.height); }); + callAndCheck(gl, function () { return gl.scissor(0, 0, gl.canvas.width, gl.canvas.height); }); +} +exports.bindCanvasToFramebuffer = bindCanvasToFramebuffer; +function bindColorTextureToFramebuffer(gl, texture, framebuffer) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer); }); + callAndCheck(gl, function () { return gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0); }); +} +exports.bindColorTextureToFramebuffer = bindColorTextureToFramebuffer; +function unbindColorTextureFromFramebuffer(gl, framebuffer) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer); }); + callAndCheck(gl, function () { return gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, null, 0); }); +} +exports.unbindColorTextureFromFramebuffer = unbindColorTextureFromFramebuffer; +function validateFramebuffer(gl) { + var status = gl.checkFramebufferStatus(gl.FRAMEBUFFER); + if (status !== gl.FRAMEBUFFER_COMPLETE) { + throw new Error('Error binding framebuffer: ' + getFramebufferErrorMessage(gl, status)); + } +} +exports.validateFramebuffer = validateFramebuffer; +function getFramebufferErrorMessage(gl, status) { + switch (status) { + case gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT: + return 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT'; + case gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: + return 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT'; + case gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS: + return 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS'; + case gl.FRAMEBUFFER_UNSUPPORTED: + return 'FRAMEBUFFER_UNSUPPORTED'; + default: + return "unknown error " + status; + } +} +exports.getFramebufferErrorMessage = getFramebufferErrorMessage; +function throwIfNull(gl, returnTOrNull, failureMessage) { + var tOrNull = callAndCheck(gl, function () { return returnTOrNull(); }); + if (tOrNull == null) { + throw new Error(failureMessage); + } + return tOrNull; +} +function validateTextureUnit(gl, textureUnit) { + var maxTextureUnit = gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1; + var glTextureUnit = textureUnit + gl.TEXTURE0; + if (glTextureUnit < gl.TEXTURE0 || glTextureUnit > maxTextureUnit) { + var textureUnitRange = "[gl.TEXTURE0, gl.TEXTURE" + maxTextureUnit + "]"; + throw new Error("textureUnit must be in " + textureUnitRange + "."); + } +} +function getTextureShapeFromLogicalShape(gl, logShape) { + if (logShape.length !== 2) { + var squeezeResult = util.squeezeShape(logShape); + logShape = squeezeResult.newShape; + } + var maxTexSize = queryMaxTextureSize(gl); + var size = util.sizeFromShape(logShape); + if (logShape.length <= 1 && size <= maxTexSize) { + return [size, 1]; + } + else if (logShape.length === 2 && logShape[0] <= maxTexSize && + logShape[1] <= maxTexSize) { + return logShape; + } + else if (logShape.length === 3 && logShape[0] <= maxTexSize && + logShape[1] * logShape[2] <= maxTexSize) { + return [logShape[0], logShape[1] * logShape[2]]; + } + else if (logShape.length === 4 && logShape[0] <= maxTexSize && + logShape[1] * logShape[2] * logShape[3] <= maxTexSize) { + return [logShape[0], logShape[1] * logShape[2] * logShape[3]]; + } + else { + return util.sizeToSquarishShape(size); + } +} +exports.getTextureShapeFromLogicalShape = getTextureShapeFromLogicalShape; +//# sourceMappingURL=webgl_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js.map new file mode 100644 index 0000000..33186e1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"webgl_util.js","sourceRoot":"","sources":["../../../src/kernels/webgl/webgl_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js new file mode 100644 index 0000000..e50a0bb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js @@ -0,0 +1,49 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var test_util_1 = require("../../test_util"); +var jasmine_util_1 = require("../../jasmine_util"); +var gpgpu_util = require("./gpgpu_util"); +var webgl_util = require("./webgl_util"); +jasmine_util_1.describeWithFlags('webgl_util getTextureShapeFromLogicalShape', test_util_1.WEBGL_ENVS, function () { + var gl; + beforeEach(function () { + gl = gpgpu_util.createWebGLContext(); + }); + it('scalar', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, []); + expect(texShape).toEqual([1, 1]); + }); + it('1d', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [4]); + expect(texShape).toEqual([4, 1]); + }); + it('2d stays same', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [5, 2]); + expect(texShape).toEqual([5, 2]); + texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [5, 1]); + expect(texShape).toEqual([5, 1]); + texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [1, 5]); + expect(texShape).toEqual([1, 5]); + }); + it('3d 2x3x4', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [2, 3, 4]); + expect(texShape).toEqual([2, 12]); + }); + it('3d 2x1x4 got squeezed', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [2, 1, 4]); + expect(texShape).toEqual([2, 4]); + }); + it('3d 1x8x2 got squeezed', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [1, 8, 2]); + expect(texShape).toEqual([8, 2]); + }); + it('4d 1x8x1x3 got squeezed', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [1, 8, 1, 3]); + expect(texShape).toEqual([8, 3]); + }); + it('4d 1x3x1x8 got squeezed', function () { + var texShape = webgl_util.getTextureShapeFromLogicalShape(gl, [1, 3, 1, 8]); + expect(texShape).toEqual([3, 8]); + }); +}); +//# sourceMappingURL=webgl_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js.map new file mode 100644 index 0000000..6072e7c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/webgl/webgl_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"webgl_util_test.js","sourceRoot":"","sources":["../../../src/kernels/webgl/webgl_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.d.ts b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.d.ts new file mode 100644 index 0000000..9c63507 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.d.ts @@ -0,0 +1,3 @@ +import { Tensor2D } from '../tensor'; +import { TypedArray } from '../types'; +export declare function whereImpl(condShape: number[], condVals: TypedArray): Tensor2D; diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js new file mode 100644 index 0000000..b2a12ca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js @@ -0,0 +1,21 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var array_ops_1 = require("../ops/array_ops"); +function whereImpl(condShape, condVals) { + var indices = []; + for (var i = 0; i < condVals.length; i++) { + if (condVals[i]) { + indices.push(i); + } + } + var inBuffer = array_ops_1.buffer(condShape, 'int32'); + var out = array_ops_1.buffer([indices.length, condShape.length], 'int32'); + for (var i = 0; i < indices.length; i++) { + var loc = inBuffer.indexToLoc(indices[i]); + var offset = i * condShape.length; + out.values.set(loc, offset); + } + return out.toTensor(); +} +exports.whereImpl = whereImpl; +//# sourceMappingURL=where_impl.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js.map b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js.map new file mode 100644 index 0000000..6e108fb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/kernels/where_impl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"where_impl.js","sourceRoot":"","sources":["../../src/kernels/where_impl.ts"],"names":[],"mappings":";;AAmBA,8CAAwC;AAIxC,mBAA0B,SAAmB,EAAE,QAAoB;IACjE,IAAM,OAAO,GAAG,EAAE,CAAC;IACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACxC,IAAI,QAAQ,CAAC,CAAC,CAAC,EAAE;YACf,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACjB;KACF;IAED,IAAM,QAAQ,GAAG,kBAAM,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAE5C,IAAM,GAAG,GAAG,kBAAM,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,CAAC;IAChE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACvC,IAAM,GAAG,GAAG,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,IAAM,MAAM,GAAG,CAAC,GAAG,SAAS,CAAC,MAAM,CAAC;QACpC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;KAC7B;IACD,OAAO,GAAG,CAAC,QAAQ,EAAc,CAAC;AACpC,CAAC;AAjBD,8BAiBC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/log.d.ts b/node_modules/@tensorflow/tfjs-core/dist/log.d.ts new file mode 100644 index 0000000..42a6d73 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/log.d.ts @@ -0,0 +1,2 @@ +export declare function warn(...msg: Array<{}>): void; +export declare function log(...msg: Array<{}>): void; diff --git a/node_modules/@tensorflow/tfjs-core/dist/log.js b/node_modules/@tensorflow/tfjs-core/dist/log.js new file mode 100644 index 0000000..f85c06f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/log.js @@ -0,0 +1,24 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +function warn() { + var msg = []; + for (var _i = 0; _i < arguments.length; _i++) { + msg[_i] = arguments[_i]; + } + if (!environment_1.ENV.get('IS_TEST')) { + console.warn.apply(console, msg); + } +} +exports.warn = warn; +function log() { + var msg = []; + for (var _i = 0; _i < arguments.length; _i++) { + msg[_i] = arguments[_i]; + } + if (!environment_1.ENV.get('IS_TEST')) { + console.log.apply(console, msg); + } +} +exports.log = log; +//# sourceMappingURL=log.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/log.js.map b/node_modules/@tensorflow/tfjs-core/dist/log.js.map new file mode 100644 index 0000000..156cdc8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/log.js.map @@ -0,0 +1 @@ +{"version":3,"file":"log.js","sourceRoot":"","sources":["../src/log.ts"],"names":[],"mappings":";;AAiBA,6CAAkC;AAElC;IAAqB,aAAiB;SAAjB,UAAiB,EAAjB,qBAAiB,EAAjB,IAAiB;QAAjB,wBAAiB;;IACpC,IAAI,CAAC,iBAAG,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;QACvB,OAAO,CAAC,IAAI,OAAZ,OAAO,EAAS,GAAG,EAAE;KACtB;AACH,CAAC;AAJD,oBAIC;AAED;IAAoB,aAAiB;SAAjB,UAAiB,EAAjB,qBAAiB,EAAjB,IAAiB;QAAjB,wBAAiB;;IACnC,IAAI,CAAC,iBAAG,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;QACvB,OAAO,CAAC,GAAG,OAAX,OAAO,EAAQ,GAAG,EAAE;KACrB;AACH,CAAC;AAJD,kBAIC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/model_types.d.ts b/node_modules/@tensorflow/tfjs-core/dist/model_types.d.ts new file mode 100644 index 0000000..e9ae8ca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/model_types.d.ts @@ -0,0 +1,12 @@ +import { Tensor } from './tensor'; +import { NamedTensorMap, TensorInfo } from './tensor_types'; +export interface ModelPredictConfig { + batchSize?: number; + verbose?: boolean; +} +export interface InferenceModel { + readonly inputs: TensorInfo[]; + readonly outputs: TensorInfo[]; + predict(inputs: Tensor | Tensor[] | NamedTensorMap, config: ModelPredictConfig): Tensor | Tensor[] | NamedTensorMap; + execute(inputs: Tensor | Tensor[] | NamedTensorMap, outputs: string | string[]): Tensor | Tensor[]; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/model_types.js b/node_modules/@tensorflow/tfjs-core/dist/model_types.js new file mode 100644 index 0000000..aaad700 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/model_types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=model_types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/model_types.js.map b/node_modules/@tensorflow/tfjs-core/dist/model_types.js.map new file mode 100644 index 0000000..e36142b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/model_types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"model_types.js","sourceRoot":"","sources":["../src/model_types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js new file mode 100644 index 0000000..f605420 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js @@ -0,0 +1,946 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('div', test_util_1.ALL_ENVS, function () { + it('same shape', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var c = tf.tensor2d([1, 2, 3, 4, 2, 5], [2, 3]); + var r = tf.div(a, c); + test_util_1.expectArraysClose(r, [1, 1, 1, 1, 2.5, 6 / 5]); + }); + it('integer division implements floor divide', function () { + var a = tf.tensor1d([-6, -6, -5, -4, -3, -3, 3, 3, 2], 'int32'); + var c = tf.tensor1d([-2, 2, 3, 2, -3, 3, 2, 3, 2], 'int32'); + var r = tf.div(a, c); + expect(r.dtype).toEqual('int32'); + test_util_1.expectArraysClose(r, [3, -3, -2, -2, 1, -1, 1, 1, 1]); + }); + it('integer division broadcasts', function () { + var a = tf.tensor1d([-5, -4, 3, 2], 'int32'); + var c = tf.scalar(2, 'int32'); + var r = tf.div(a, c); + expect(r.dtype).toEqual('int32'); + test_util_1.expectArraysClose(r, [-3, -2, 1, 1]); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([1, 2], [2, 1]); + var c = tf.tensor2d([3, NaN], [2, 1]); + var r = tf.div(a, c); + test_util_1.expectArraysClose(r, [1 / 3, NaN]); + }); + it('broadcasting same rank Tensors different shape', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([2, 3], [2, 1]); + var result = tf.div(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [1 / 2, 1, -1, -4 / 3]; + test_util_1.expectArraysClose(result, expected); + }); + it('broadcast 2D + 1D', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor1d([1, 2]); + var result = tf.div(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [1, 1, -3, -2]; + test_util_1.expectArraysClose(result, expected); + }); + it('throws when passed tensors of different types', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([1, 2, 3, 4, 2, 5], [2, 3], 'int32'); + expect(function () { return tf.div(a, b); }).toThrowError(); + expect(function () { return tf.div(b, a); }).toThrowError(); + }); + it('throws when passed tensors of different shapes', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2]); + expect(function () { return tf.div(a, b); }).toThrowError(); + expect(function () { return tf.div(b, a); }).toThrowError(); + }); + it('scalar divided by array', function () { + var c = tf.scalar(2); + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var r = tf.div(c, a); + test_util_1.expectArraysClose(r, [2 / 1, 2 / 2, 2 / 3, 2 / 4, 2 / 5, 2 / 6]); + }); + it('scalar divided by array propagates NaNs', function () { + var c = tf.scalar(NaN); + var a = tf.tensor2d([1, 2, 3], [1, 3]); + var r = tf.div(c, a); + test_util_1.expectArraysEqual(r, [NaN, NaN, NaN]); + }); + it('array divided by scalar', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var c = tf.scalar(2); + var r = tf.div(a, c); + test_util_1.expectArraysClose(r, [1 / 2, 2 / 2, 3 / 2, 4 / 2, 5 / 2, 6 / 2]); + }); + it('array divided by scalar propagates NaNs', function () { + var a = tf.tensor2d([1, 2, NaN], [1, 3]); + var c = tf.scalar(2); + var r = tf.div(a, c); + test_util_1.expectArraysClose(r, [1 / 2, 2 / 2, NaN]); + }); + it('gradient: Scalar', function () { + var a = tf.scalar(5); + var b = tf.scalar(2); + var dy = tf.scalar(4); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [4 / 2]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-4 * 5 / (2 * 2)]); + }); + it('gradient: Tensor1D', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 / 3, 10 / 4, 20 / 5]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 * 1 / 9, -10 * 2 / 16, -20 * 3 / 25]); + }); + it('gradient: Tensor1D with int32', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var b = tf.tensor1d([3, 4, 5], 'int32'); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 / 3, 10 / 4, 20 / 5]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 * 1 / 9, -10 * 2 / 16, -20 * 3 / 25]); + }); + it('gradient: 1d with 1d ', function () { + var a = tf.tensor1d([true, false, true], 'bool'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var dy = tf.tensor1d([1, 19, 20]); + var grads = tf.grads(function (a, b) { return tf.div(a.toInt(), b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1, 19 / 2, 20 / 3]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 / 1, 0, -20 / 9]); + }); + it('gradient: Tensor2D', function () { + var a = tf.tensor2d([3, 1, 2, 3], [2, 2]); + var b = tf.tensor2d([1, 3, 4, 5], [2, 2]); + var dy = tf.tensor2d([1, 10, 15, 20], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 / 1, 10 / 3, 15 / 4, 20 / 5]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 * 3 / 1, -10 * 1 / 9, -15 * 2 / 16, -20 * 3 / 25]); + }); + it('gradient: scalar / Tensor1D', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([6, 7, 8]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 / 3 + 7 / 4 + 8 / 5]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 2 / 9, -7 * 2 / 16, -8 * 2 / 25]); + }); + it('gradient: Tensor2D / scalar', function () { + var a = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var b = tf.scalar(2); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 / 2, 7 / 2, 8 / 2, 9 / 2]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 2 / 4 + -7 * 3 / 4 + -8 * 4 / 4 + -9 * 5 / 4]); + }); + it('gradient: Tensor2D / Tensor2D w/ broadcast', function () { + var a = tf.tensor2d([3, 4], [2, 1]); + var b = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.div(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 / 2 + 7 / 3, 8 / 4 + 9 / 5]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 3 / 4, -7 * 3 / 9, -8 * 4 / 16, -9 * 4 / 25]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.div({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'div' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.div(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'div' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.div([[1, 2, 3], [4, 5, 6]], 2); + expect(r.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(r, [1 / 2, 2 / 2, 3 / 2, 4 / 2, 5 / 2, 6 / 2]); + }); +}); +jasmine_util_1.describeWithFlags('mul', test_util_1.ALL_ENVS, function () { + it('strict same-shaped tensors', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2]); + var expected = [5, 6, -12, 28]; + var result = tf.mulStrict(a, b); + expect(result.shape).toEqual([2, 2]); + expect(result.dtype).toBe('float32'); + test_util_1.expectArraysClose(result, expected); + }); + it('strict propagates NaNs', function () { + var a = tf.tensor2d([1, 3, 4, 0], [2, 2]); + var b = tf.tensor2d([NaN, 3, NaN, 3], [2, 2]); + var result = tf.mulStrict(a, b); + expect(result.dtype).toBe('float32'); + test_util_1.expectArraysClose(result, [NaN, 9, NaN, 0]); + }); + it('strict throws when passed tensors of different shapes', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2]); + expect(function () { return tf.mulStrict(a, b); }).toThrowError(); + expect(function () { return tf.mulStrict(b, a); }).toThrowError(); + }); + it('strict throws when dtypes do not match', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3], 'float32'); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2], 'int32'); + expect(function () { return tf.mulStrict(a, b); }).toThrowError(); + expect(function () { return tf.mulStrict(b, a); }).toThrowError(); + }); + it('strict int32 * int32', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2], 'int32'); + var b = tf.tensor2d([2, 1, 3, -4], [2, 2], 'int32'); + var res = tf.mulStrict(a, b); + expect(res.dtype).toBe('int32'); + test_util_1.expectArraysClose(res, [2, 2, -9, 16]); + }); + it('same-shaped tensors', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2]); + var expected = [5, 6, -12, 28]; + var result = tf.mul(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('broadcasting tensors', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.scalar(2); + var expected = [2, 4, -6, -8]; + var result = tf.mul(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('broadcasting same rank Tensors different shape', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([2, 3], [2, 1]); + var result = tf.mul(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [2, 4, -9, -12]; + test_util_1.expectArraysClose(result, expected); + }); + it('broadcast 2D + 1D', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor1d([1, 2]); + var result = tf.mul(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [1, 4, -3, -8]; + test_util_1.expectArraysClose(result, expected); + }); + it('gradient: Scalar', function () { + var a = tf.scalar(5); + var b = tf.scalar(2); + var dy = tf.scalar(4); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [b.get() * dy.get()]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [a.get() * dy.get()]); + }); + it('gradient: Tensor1D', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 1, 4 * 10, 5 * 20]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [1 * 1, 2 * 10, 3 * 20]); + }); + it('gradient: Tensor1D with dtype int32', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var b = tf.tensor1d([3, 4, 5], 'int32'); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 1, 4 * 10, 5 * 20]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [1 * 1, 2 * 10, 3 * 20]); + }); + it('gradient: Tensor2D', function () { + var a = tf.tensor2d([3, 1, 2, 3], [2, 2]); + var b = tf.tensor2d([1, 3, 4, 5], [2, 2]); + var dy = tf.tensor2d([1, 10, 15, 20], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 3 * 10, 4 * 15, 5 * 20]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [3 * 1, 1 * 10, 2 * 15, 3 * 20]); + }); + it('gradient: scalar * Tensor1D', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([6, 7, 8]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 6 + 4 * 7 + 5 * 8]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [2 * 6, 2 * 7, 2 * 8]); + }); + it('gradient: Tensor2D * scalar', function () { + var a = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var b = tf.scalar(2); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [2 * 6, 2 * 7, 2 * 8, 2 * 9]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [2 * 6 + 3 * 7 + 4 * 8 + 5 * 9]); + }); + it('gradient: Tensor2D * Tensor2D w/ broadcast', function () { + var a = tf.tensor2d([3, 4], [2, 1]); + var b = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.mul(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [2 * 6 + 3 * 7, 4 * 8 + 5 * 9]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [6 * 3, 7 * 3, 8 * 4, 9 * 4]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.mul({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'mul' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.mul(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'mul' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.mul([[1, 2], [-3, -4]], 2); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [2, 4, -6, -8]); + }); +}); +jasmine_util_1.describeWithFlags('pow', test_util_1.ALL_ENVS, function () { + it('same-shaped tensors', function () { + var a = tf.tensor2d([1, -2, -3, 0, 7, 1], [2, 3]); + var b = tf.tensor2d([5, 3, 4, 5, 2, -3], [2, 3], 'int32'); + var expected = [1, -8, 81, 0, 49, 1]; + var result = tf.pow(a, b); + expect(result.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(result, expected, 0.01); + }); + it('int32^int32 returns int32', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var exp = tf.scalar(2, 'int32'); + var result = tf.pow(a, exp); + expect(result.shape).toEqual([3]); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [1, 4, 9]); + }); + it('different-shaped tensors', function () { + var a = tf.tensor2d([1, -2, -3, 0, 7, 1], [2, 3]); + var b = tf.scalar(2, 'int32'); + var expected = [1, 4, 9, 0, 49, 1]; + var result = tf.pow(a, b); + expect(result.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(result, expected, 0.05); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([NaN, 3, NaN, 0], [2, 2]); + var b = tf.tensor2d([1, 3, 2, 3], [2, 2], 'int32'); + var result = tf.pow(a, b); + test_util_1.expectArraysClose(result, [NaN, 27, NaN, 0], 0.05); + }); + it('handles non int32 exponent param', function () { + var a = tf.tensor1d([2, 4]); + var b = tf.tensor1d([.5, 1.2]); + var result = tf.pow(a, b); + var expected = [Math.pow(2, 0.5), Math.pow(4, 1.2)]; + test_util_1.expectArraysClose(result, expected); + }); + it('broadcasting same rank Tensors different shape', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([2, 1], [2, 1], 'int32'); + var result = tf.pow(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [1, 4, -3, -4]; + test_util_1.expectArraysClose(result, expected); + }); + it('broadcast 2D + 1D', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor1d([1, 2], 'int32'); + var result = tf.pow(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [1, 4, -3, 16]; + test_util_1.expectArraysClose(result, expected); + }); + it('powStrict same-shaped tensors', function () { + var a = tf.tensor2d([1, -2, -3, 0, 7, 1], [2, 3]); + var b = tf.tensor2d([5, 3, 4, 5, 2, -3], [2, 3], 'int32'); + var expected = [1, -8, 81, 0, 49, 1]; + var result = tf.powStrict(a, b); + expect(result.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(result, expected, 0.01); + }); + it('powStrict throws when passed tensors of different shapes', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2], 'int32'); + expect(function () { return tf.powStrict(a, b); }).toThrowError(); + }); + it('powStrict handles non int32 exponent param', function () { + var a = tf.tensor1d([2, 4]); + var b = tf.tensor1d([.5, 1.2]); + var result = tf.powStrict(a, b); + var expected = [Math.pow(2, 0.5), Math.pow(4, 1.2)]; + test_util_1.expectArraysClose(result, expected); + }); + it('gradients: Scalar ^ Scalar', function () { + var a = tf.scalar(5); + var b = tf.scalar(2, 'int32'); + var dy = tf.scalar(3); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [2 * 5 * 3]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [3 * Math.pow(5, 2) * Math.log(5)]); + }); + it('gradients: Scalar ^ Scalar fractional exponent', function () { + var a = tf.scalar(4.0); + var b = tf.scalar(1.5); + var dy = tf.scalar(3.0); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1.5 * Math.pow(4, 0.5) * 3]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [3.0 * Math.pow(4, 1.5) * Math.log(4.0)]); + }); + it('gradients: Tensor ^ Tensor', function () { + var a = tf.tensor1d([-1, .5, 2]); + var b = tf.tensor1d([3, 2, -1], 'int32'); + var dy = tf.tensor1d([1, 5, 10]); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 3 * Math.pow(-1, 2) * 1, 2 * Math.pow(.5, 1) * 5, + -1 * Math.pow(2, -2) * 10 + ], 1e-1); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [ + NaN, 5 * Math.pow(.5, 2) * Math.log(.5), + 10 * Math.pow(2, -1) * Math.log(2) + ]); + }); + it('gradient: scalar / Tensor1D', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([6, 7, 8]); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 6 * 3 * Math.pow(2, 2) + 7 * 4 * Math.pow(2, 3) + 8 * 5 * Math.pow(2, 4) + ]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [ + 6 * Math.pow(2, 3) * Math.log(2), 7 * Math.pow(2, 4) * Math.log(2), + 8 * Math.pow(2, 5) * Math.log(2) + ]); + }); + it('gradient: Tensor2D / scalar', function () { + var a = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var b = tf.scalar(2); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 6 * 2 * Math.pow(2, 1), 7 * 2 * Math.pow(3, 1), 8 * 2 * Math.pow(4, 1), + 9 * 2 * Math.pow(5, 1) + ]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [6 * Math.pow(2, 2) * Math.log(2) + 7 * Math.pow(3, 2) * Math.log(3) + + 8 * Math.pow(4, 2) * Math.log(4) + 9 * Math.pow(5, 2) * Math.log(5)]); + }); + it('gradient: Tensor2D / Tensor2D w/ broadcast', function () { + var a = tf.tensor2d([3, 4], [2, 1]); + var b = tf.tensor2d([[2, 3], [.4, .5]], [2, 2]); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.pow(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 6 * 2 * Math.pow(3, 1) + 7 * 3 * Math.pow(3, 2), + 8 * .4 * Math.pow(4, .4 - 1) + 9 * .5 * Math.pow(4, .5 - 1) + ]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [ + 6 * Math.pow(3, 2) * Math.log(3), 7 * Math.pow(3, 3) * Math.log(3), + 8 * Math.pow(4, .4) * Math.log(4), 9 * Math.pow(4, .5) * Math.log(4) + ]); + }); + it('throws when passed base as a non-tensor', function () { + expect(function () { return tf.pow({}, tf.scalar(1)); }) + .toThrowError(/Argument 'base' passed to 'pow' must be a Tensor/); + }); + it('throws when passed exp as a non-tensor', function () { + expect(function () { return tf.pow(tf.scalar(1), {}); }) + .toThrowError(/Argument 'exp' passed to 'pow' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.pow([1, 2, 3], 2); + expect(result.shape).toEqual([3]); + expect(result.dtype).toBe('float32'); + test_util_1.expectArraysEqual(result, [1, 4, 9]); + }); + it('negative base and whole exponent not NaN', function () { + var a = tf.tensor1d([-2, -3, -4], 'float32'); + var b = tf.tensor1d([2, -3, 4], 'float32'); + var expected = [Math.pow(-2, 2), Math.pow(-3, -3), Math.pow(-4, 4)]; + var result = tf.pow(a, b); + test_util_1.expectArraysClose(result, expected); + }); + it('negative base and fract exponent NaN', function () { + var a = tf.tensor1d([-2, -3, -4], 'float32'); + var b = tf.tensor1d([2.1, -3.01, 4.001], 'float32'); + var expected = [NaN, NaN, NaN]; + var result = tf.pow(a, b); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('add', test_util_1.ALL_ENVS, function () { + it('c + A', function () { + var c = tf.scalar(5); + var a = tf.tensor1d([1, 2, 3]); + var result = tf.add(c, a); + test_util_1.expectArraysClose(result, [6, 7, 8]); + }); + it('c + A propagates NaNs', function () { + var c = tf.scalar(NaN); + var a = tf.tensor1d([1, 2, 3]); + var res = tf.add(c, a); + test_util_1.expectArraysEqual(res, [NaN, NaN, NaN]); + }); + it('A + B broadcasting same rank Tensors different shape', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([2, 3], [2, 1]); + var result = tf.add(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [3, 4, 0, -1]; + test_util_1.expectArraysClose(result, expected); + }); + it('A + B broadcast 2D + 1D', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor1d([1, 2]); + var result = tf.add(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [2, 4, -2, -2]; + test_util_1.expectArraysClose(result, expected); + }); + it('A + B', function () { + var a = tf.tensor1d([2, 5, 1]); + var b = tf.tensor1d([4, 2, -1]); + var result = tf.add(a, b); + var expected = [6, 7, 0]; + test_util_1.expectArraysClose(result, expected); + }); + it('A + B propagates NaNs', function () { + var a = tf.tensor1d([2, 5, NaN]); + var b = tf.tensor1d([4, 2, -1]); + var res = tf.add(a, b); + test_util_1.expectArraysClose(res, [6, 7, NaN]); + }); + it('A + B throws when passed tensors with different shape', function () { + var a = tf.tensor1d([2, 5, 1, 5]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.add(a, b); }).toThrowError(); + expect(function () { return tf.add(b, a); }).toThrowError(); + }); + it('2D+scalar broadcast', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.scalar(2); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [3, 4, 5, 6, 7, 8]); + }); + it('scalar+1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([1, 2, 3, 4, 5, 6]); + var res = tf.add(a, b); + expect(res.shape).toEqual([6]); + test_util_1.expectArraysClose(res, [3, 4, 5, 6, 7, 8]); + }); + it('2D+2D broadcast each with 1 dim', function () { + var a = tf.tensor2d([1, 2, 5], [1, 3]); + var b = tf.tensor2d([7, 3], [2, 1]); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [8, 9, 12, 4, 5, 8]); + }); + it('2D+2D broadcast inner dim of b', function () { + var a = tf.tensor2d([1, 2, 5, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([7, 3], [2, 1]); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [8, 9, 12, 7, 8, 9]); + }); + it('3D+scalar', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1]); + var b = tf.scalar(-1); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 3, 1]); + test_util_1.expectArraysClose(res, [0, 1, 2, 3, 4, 5]); + }); + it('6D+scalar', function () { + var a = tf.range(0, 64).reshape([2, 2, 2, 2, 2, 2]); + var b = tf.scalar(-1); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 2, 2, 2, 2, 2]); + var expectedResult = [ + -1, 0, 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 + ]; + test_util_1.expectArraysClose(res, expectedResult); + }); + it('6D+2D', function () { + var a = tf.range(0, 64).reshape([2, 2, 2, 2, 2, 2]); + var b = tf.tensor2d([11, 13, 17, 19], [2, 2]); + var res = tf.add(a, b); + expect(res.shape).toEqual([2, 2, 2, 2, 2, 2]); + var expectedResult = [ + 11, 14, 19, 22, 15, 18, 23, 26, 19, 22, 27, 30, 23, 26, 31, 34, + 27, 30, 35, 38, 31, 34, 39, 42, 35, 38, 43, 46, 39, 42, 47, 50, + 43, 46, 51, 54, 47, 50, 55, 58, 51, 54, 59, 62, 55, 58, 63, 66, + 59, 62, 67, 70, 63, 66, 71, 74, 67, 70, 75, 78, 71, 74, 79, 82 + ]; + test_util_1.expectArraysClose(res, expectedResult); + }); + it('gradient: scalar + 1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([7, 8, 9]); + var grads = tf.grads(function (a, b) { return tf.add(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [7 + 8 + 9]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [7, 8, 9]); + }); + it('gradient: 2D + 2D broadcast', function () { + var a = tf.tensor2d([2, 3], [2, 1]); + var b = tf.tensor2d([4, 5, 6, 7], [2, 2]); + var dy = tf.tensor2d([5, 4, 3, 2], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.add(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [5 + 4, 3 + 2]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [5, 4, 3, 2]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.add({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'add' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.add(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'add' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.add(5, [1, 2, 3]); + test_util_1.expectArraysClose(result, [6, 7, 8]); + }); +}); +jasmine_util_1.describeWithFlags('addN', test_util_1.ALL_ENVS, function () { + it('a single tensor', function () { + var res = tf.addN([tf.tensor1d([1, 2, 3])]); + test_util_1.expectArraysClose(res, [1, 2, 3]); + }); + it('two tensors, int32', function () { + var res = tf.addN([ + tf.tensor1d([1, 2, -1], 'int32'), + tf.tensor1d([5, 3, 2], 'int32'), + ]); + test_util_1.expectArraysClose(res, [6, 5, 1]); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([3]); + }); + it('three tensors', function () { + var res = tf.addN([ + tf.tensor1d([1, 2]), + tf.tensor1d([5, 3]), + tf.tensor1d([-5, -2]), + ]); + test_util_1.expectArraysClose(res, [1, 3]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([2]); + }); + it('accepts a tensor-like object', function () { + var res = tf.addN([[1, 2], [3, 4]]); + test_util_1.expectArraysClose(res, [4, 6]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([2]); + }); + it('list of numbers gets treated as a list of scalars', function () { + var res = tf.addN([1, 2, 3, 4]); + test_util_1.expectArraysClose(res, [10]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([]); + }); + it('errors if list is empty', function () { + expect(function () { return tf.addN([]); }) + .toThrowError(/Must pass at least one tensor to tf.addN\(\), but got 0/); + }); + it('errors if argument is not an array', function () { + expect(function () { return tf.addN(tf.scalar(3)); }) + .toThrowError(/The param passed to tf.addN\(\) must be a list of tensors/); + }); + it('errors if arguments not of same dtype', function () { + expect(function () { return tf.addN([tf.scalar(1, 'int32'), tf.scalar(2, 'float32')]); }) + .toThrowError(/All tensors passed to tf.addN\(\) must have the same dtype/); + }); + it('errors if arguments not of same shape', function () { + expect(function () { return tf.addN([tf.scalar(1), tf.tensor1d([2])]); }) + .toThrowError(/All tensors passed to tf.addN\(\) must have the same shape/); + }); +}); +jasmine_util_1.describeWithFlags('sub', test_util_1.ALL_ENVS, function () { + it('c - A', function () { + var c = tf.scalar(5); + var a = tf.tensor1d([7, 2, 3]); + var result = tf.sub(c, a); + test_util_1.expectArraysClose(result, [-2, 3, 2]); + }); + it('A - c', function () { + var a = tf.tensor1d([1, 2, -3]); + var c = tf.scalar(5); + var result = tf.sub(a, c); + test_util_1.expectArraysClose(result, [-4, -3, -8]); + }); + it('A - c propagates NaNs', function () { + var a = tf.tensor1d([1, NaN, 3]); + var c = tf.scalar(5); + var res = tf.sub(a, c); + test_util_1.expectArraysClose(res, [-4, NaN, -2]); + }); + it('A - B', function () { + var a = tf.tensor1d([2, 5, 1]); + var b = tf.tensor1d([4, 2, -1]); + var result = tf.sub(a, b); + var expected = [-2, 3, 2]; + test_util_1.expectArraysClose(result, expected); + }); + it('A - B propagates NaNs', function () { + var a = tf.tensor1d([2, 5, 1]); + var b = tf.tensor1d([4, NaN, -1]); + var res = tf.sub(a, b); + test_util_1.expectArraysClose(res, [-2, NaN, 2]); + }); + it('A - B throws when passed tensors with different shape', function () { + var a = tf.tensor1d([2, 5, 1, 5]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.sub(a, b); }).toThrowError(); + expect(function () { return tf.sub(b, a); }).toThrowError(); + }); + it('A - B broadcasting same rank Tensors different shape', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor2d([2, 3], [2, 1]); + var result = tf.sub(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [-1, 0, -6, -7]; + test_util_1.expectArraysClose(result, expected); + }); + it('A - B broadcast 2D + 1D', function () { + var a = tf.tensor2d([1, 2, -3, -4], [2, 2]); + var b = tf.tensor1d([1, 2]); + var result = tf.sub(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [0, 0, -4, -6]; + test_util_1.expectArraysClose(result, expected); + }); + it('2D-scalar broadcast', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.scalar(2); + var res = tf.sub(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [-1, 0, 1, 2, 3, 4]); + }); + it('scalar-1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([1, 2, 3, 4, 5, 6]); + var res = tf.sub(a, b); + expect(res.shape).toEqual([6]); + test_util_1.expectArraysClose(res, [1, 0, -1, -2, -3, -4]); + }); + it('2D-2D broadcast each with 1 dim', function () { + var a = tf.tensor2d([1, 2, 5], [1, 3]); + var b = tf.tensor2d([7, 3], [2, 1]); + var res = tf.sub(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [-6, -5, -2, -2, -1, 2]); + }); + it('2D-2D broadcast inner dim of b', function () { + var a = tf.tensor2d([1, 2, 5, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([7, 3], [2, 1]); + var res = tf.sub(a, b); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [-6, -5, -2, 1, 2, 3]); + }); + it('3D-scalar', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1]); + var b = tf.scalar(-1); + var res = tf.sub(a, b); + expect(res.shape).toEqual([2, 3, 1]); + test_util_1.expectArraysClose(res, [2, 3, 4, 5, 6, 7]); + }); + it('gradients: basic 1D arrays', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([3, 2, 1]); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.sub(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1, 10, 20]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1, -10, -20]); + }); + it('gradients: basic 2D arrays', function () { + var a = tf.tensor2d([0, 1, 2, 3], [2, 2]); + var b = tf.tensor2d([3, 2, 1, 0], [2, 2]); + var dy = tf.tensor2d([1, 10, 15, 20], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.sub(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1, 10, 15, 20]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1, -10, -15, -20]); + }); + it('gradient: 1D - scalar broadcast', function () { + var a = tf.tensor1d([3, 4, 5]); + var b = tf.scalar(2); + var dy = tf.tensor1d([7, 8, 9]); + var grads = tf.grads(function (a, b) { return tf.sub(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [7, 8, 9]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-7 - 8 - 9]); + }); + it('gradient: scalar - 1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([7, 8, 9]); + var grads = tf.grads(function (a, b) { return tf.sub(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [7 + 8 + 9]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-7, -8, -9]); + }); + it('gradient: 2D - 2D broadcast', function () { + var a = tf.tensor2d([4, 5, 6, 7], [2, 2]); + var b = tf.tensor2d([2, 3], [2, 1]); + var dy = tf.tensor2d([5, 4, 3, 2], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.sub(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [5, 4, 3, 2]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-5 - 4, -3 - 2]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.sub({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'sub' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.sub(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'sub' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.sub(5, [7, 2, 3]); + test_util_1.expectArraysClose(result, [-2, 3, 2]); + }); +}); +//# sourceMappingURL=arithmetic_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js.map new file mode 100644 index 0000000..5040563 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/arithmetic_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"arithmetic_test.js","sourceRoot":"","sources":["../../src/ops/arithmetic_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.d.ts new file mode 100644 index 0000000..46a4a34 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.d.ts @@ -0,0 +1,56 @@ +import { Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer } from '../tensor'; +import { DataType, Rank, ShapeMap, TensorLike, TensorLike1D, TypedArray } from '../types'; +declare function clone_(x: T | TensorLike): T; +declare function eye_(numRows: number, numColumns?: number, batchShape?: [number] | [number, number] | [number, number, number] | [number, number, number, number], dtype?: DataType): Tensor2D; +declare function randomNormal_(shape: ShapeMap[R], mean?: number, stdDev?: number, dtype?: 'float32' | 'int32', seed?: number): Tensor; +declare function truncatedNormal_(shape: ShapeMap[R], mean?: number, stdDev?: number, dtype?: 'float32' | 'int32', seed?: number): Tensor; +declare function randomUniform_(shape: ShapeMap[R], minval?: number, maxval?: number, dtype?: DataType): Tensor; +declare function rand_(shape: ShapeMap[R], randFunction: () => number, dtype?: DataType): Tensor; +declare function multinomial_(logits: Tensor1D | Tensor2D | TensorLike, numSamples: number, seed?: number, normalized?: boolean): Tensor1D | Tensor2D; +declare function oneHot_(indices: Tensor1D | TensorLike1D, depth: number, onValue?: number, offValue?: number): Tensor2D; +declare function fromPixels_(pixels: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, numChannels?: number): Tensor3D; +declare function toPixels(img: Tensor2D | Tensor3D | TensorLike, canvas?: HTMLCanvasElement): Promise; +declare function reshape_(x: Tensor | TensorLike, shape: ShapeMap[R2]): Tensor; +declare function squeeze_(x: Tensor | TensorLike, axis?: number[]): T; +declare function cast_(x: T | TensorLike, dtype: DataType): T; +declare function tile_(x: T | TensorLike, reps: number[]): T; +declare function pad1d_(x: Tensor1D | TensorLike, paddings: [number, number], constantValue?: number): Tensor1D; +declare function pad2d_(x: Tensor2D | TensorLike, paddings: [[number, number], [number, number]], constantValue?: number): Tensor2D; +declare function pad3d_(x: Tensor3D | TensorLike, paddings: [[number, number], [number, number], [number, number]], constantValue?: number): Tensor3D; +declare function pad4d_(x: Tensor4D | TensorLike, paddings: [[number, number], [number, number], [number, number], [number, number]], constantValue?: number): Tensor4D; +declare function pad_(x: T | TensorLike, paddings: Array<[number, number]>, constantValue?: number): T; +declare function stack_(tensors: T[] | TensorLike[], axis?: number): Tensor; +declare function batchToSpaceND_(x: T | TensorLike, blockShape: number[], crops: number[][]): T; +declare function spaceToBatchND_(x: T | TensorLike, blockShape: number[], paddings: number[][]): T; +declare function unstack_(x: T | TensorLike, axis?: number): Tensor[]; +declare function split_(x: T | TensorLike, numOrSizeSplits: number[] | number, axis?: number): T[]; +declare function cumsum_(x: Tensor | TensorLike, axis?: number, exclusive?: boolean, reverse?: boolean): T; +declare function expandDims_(x: Tensor | TensorLike, axis?: number): Tensor; +declare function buffer(shape: ShapeMap[R], dtype?: DataType, values?: TypedArray): TensorBuffer; +declare function print(x: T, verbose?: boolean): void; +export { buffer, toPixels, print }; +export declare const cast: typeof cast_; +export declare const clone: typeof clone_; +export declare const cumsum: typeof cumsum_; +export declare const expandDims: typeof expandDims_; +export declare const eye: typeof eye_; +export declare const fromPixels: typeof fromPixels_; +export declare const multinomial: typeof multinomial_; +export declare const oneHot: typeof oneHot_; +export declare const pad: typeof pad_; +export declare const pad1d: typeof pad1d_; +export declare const pad2d: typeof pad2d_; +export declare const pad3d: typeof pad3d_; +export declare const pad4d: typeof pad4d_; +export declare const rand: typeof rand_; +export declare const randomNormal: typeof randomNormal_; +export declare const randomUniform: typeof randomUniform_; +export declare const reshape: typeof reshape_; +export declare const split: typeof split_; +export declare const squeeze: typeof squeeze_; +export declare const stack: typeof stack_; +export declare const tile: typeof tile_; +export declare const truncatedNormal: typeof truncatedNormal_; +export declare const unstack: typeof unstack_; +export declare const batchToSpaceND: typeof batchToSpaceND_; +export declare const spaceToBatchND: typeof spaceToBatchND_; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js new file mode 100644 index 0000000..985d670 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js @@ -0,0 +1,526 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_1 = require("../tensor"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var axis_util_1 = require("./axis_util"); +var concat_1 = require("./concat"); +var operation_1 = require("./operation"); +var rand_1 = require("./rand"); +var tensor_ops_1 = require("./tensor_ops"); +function clone_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'clone'); + var der = function (dy) { + return { $x: function () { return dy.toFloat(); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { + return tensor_1.Tensor.make($x.shape, { dataId: $x.dataId }, $x.dtype); + }, { $x: $x }, der); +} +function eye_(numRows, numColumns, batchShape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (numColumns == null) { + numColumns = numRows; + } + var buff = buffer([numRows, numColumns], dtype); + var n = numRows <= numColumns ? numRows : numColumns; + for (var i = 0; i < n; ++i) { + buff.set(1, i, i); + } + var out = buff.toTensor().as2D(numRows, numColumns); + if (batchShape == null) { + return out; + } + else { + if (batchShape.length === 1) { + return exports.tile(exports.expandDims(out, 0), [batchShape[0], 1, 1]); + } + else if (batchShape.length === 2) { + return exports.tile(exports.expandDims(exports.expandDims(out, 0), 0), [batchShape[0], batchShape[1], 1, 1]); + } + else if (batchShape.length === 3) { + return exports.tile(exports.expandDims(exports.expandDims(exports.expandDims(out, 0), 0), 0), [batchShape[0], batchShape[1], batchShape[2], 1, 1]); + } + else { + throw new Error("eye() currently supports only 1D and 2D " + + ("batchShapes, but received " + batchShape.length + "D.")); + } + } +} +function randomNormal_(shape, mean, stdDev, dtype, seed) { + if (mean === void 0) { mean = 0; } + if (stdDev === void 0) { stdDev = 1; } + if (dtype != null && dtype === 'bool') { + throw new Error("Unsupported data type " + dtype); + } + var randGauss = new rand_1.MPRandGauss(mean, stdDev, dtype, false, seed); + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = randGauss.nextValue(); + } + return res.toTensor(); +} +function truncatedNormal_(shape, mean, stdDev, dtype, seed) { + if (mean === void 0) { mean = 0; } + if (stdDev === void 0) { stdDev = 1; } + if (dtype != null && dtype === 'bool') { + throw new Error("Unsupported data type " + dtype); + } + var randGauss = new rand_1.MPRandGauss(mean, stdDev, dtype, true, seed); + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = randGauss.nextValue(); + } + return res.toTensor(); +} +function randomUniform_(shape, minval, maxval, dtype) { + if (minval === void 0) { minval = 0; } + if (maxval === void 0) { maxval = 1; } + if (dtype === void 0) { dtype = 'float32'; } + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = util.randUniform(minval, maxval); + } + return res.toTensor(); +} +function rand_(shape, randFunction, dtype) { + var size = util.sizeFromShape(shape); + var values = null; + if (dtype == null || dtype === 'float32') { + values = new Float32Array(size); + } + else if (dtype === 'int32') { + values = new Int32Array(size); + } + else if (dtype === 'bool') { + values = new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } + for (var i = 0; i < size; i++) { + values[i] = randFunction(); + } + return tensor_1.Tensor.make(shape, { values: values }, dtype); +} +function multinomial_(logits, numSamples, seed, normalized) { + if (normalized === void 0) { normalized = false; } + var $logits = tensor_util_env_1.convertToTensor(logits, 'logits', 'multinomial'); + var numOutcomes = $logits.size; + var origRank = $logits.rank; + if (numOutcomes < 2) { + throw new Error("Error in multinomial: you need at least 2 outcomes, but got " + + (numOutcomes + ".")); + } + if (origRank > 2) { + throw new Error("Rank of probabilities must be 1 or 2, but is " + origRank); + } + seed = seed || Math.random(); + var logits2D = origRank === 1 ? $logits.as2D(1, -1) : $logits; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.multinomial(logits2D, normalized, numSamples, seed); }, { logits2D: logits2D }); + return origRank === 1 ? res.as1D() : res; +} +function oneHot_(indices, depth, onValue, offValue) { + if (onValue === void 0) { onValue = 1; } + if (offValue === void 0) { offValue = 0; } + var $indices = tensor_util_env_1.convertToTensor(indices, 'indices', 'oneHot', 'int32'); + util.assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`'); + if (depth < 2) { + throw new Error("Error in oneHot: depth must be >=2, but it is " + depth); + } + return environment_1.ENV.engine.runKernel(function (backend) { return backend.oneHot($indices, depth, onValue, offValue); }, { $indices: $indices }); +} +function fromPixels_(pixels, numChannels) { + if (numChannels === void 0) { numChannels = 3; } + if (numChannels > 4) { + throw new Error('Cannot construct Tensor with more than 4 channels from pixels.'); + } + return environment_1.ENV.engine.fromPixels(pixels, numChannels); +} +function toPixels(img, canvas) { + return __awaiter(this, void 0, void 0, function () { + var $img, _a, height, width, depth, minTensor, maxTensor, min, max, data, multiplier, bytes, i, r, g, b, a, j, ctx, imageData; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + $img = tensor_util_env_1.convertToTensor(img, 'img', 'toPixels', 'int32'); + if ($img.rank !== 2 && $img.rank !== 3) { + throw new Error("toPixels only supports rank 2 or 3 tensors, got rank " + $img.rank + "."); + } + _a = $img.shape.slice(0, 2), height = _a[0], width = _a[1]; + depth = $img.rank === 2 ? 1 : $img.shape[2]; + if (depth > 4 || depth === 2) { + throw new Error("toPixels only supports depth of size " + + ("1, 3 or 4 but got " + depth)); + } + minTensor = $img.min(); + maxTensor = $img.max(); + return [4, minTensor.data()]; + case 1: + min = (_b.sent())[0]; + return [4, maxTensor.data()]; + case 2: + max = (_b.sent())[0]; + minTensor.dispose(); + maxTensor.dispose(); + if ($img.dtype === 'float32') { + if (min < 0 || max > 1) { + throw new Error("Tensor values for a float32 Tensor must be in the " + + ("range [0 - 1] but got range [" + min + " - " + max + "].")); + } + } + else if ($img.dtype === 'int32') { + if (min < 0 || max > 255) { + throw new Error("Tensor values for a int32 Tensor must be in the " + + ("range [0 - 255] but got range [" + min + " - " + max + "].")); + } + } + else { + throw new Error("Unsupported type for toPixels: " + $img.dtype + "." + + " Please use float32 or int32 tensors."); + } + return [4, $img.data()]; + case 3: + data = _b.sent(); + multiplier = $img.dtype === 'float32' ? 255 : 1; + bytes = new Uint8ClampedArray(width * height * 4); + for (i = 0; i < height * width; ++i) { + r = void 0, g = void 0, b = void 0, a = void 0; + if (depth === 1) { + r = data[i] * multiplier; + g = data[i] * multiplier; + b = data[i] * multiplier; + a = 255; + } + else if (depth === 3) { + r = data[i * 3] * multiplier; + g = data[i * 3 + 1] * multiplier; + b = data[i * 3 + 2] * multiplier; + a = 255; + } + else if (depth === 4) { + r = data[i * 4] * multiplier; + g = data[i * 4 + 1] * multiplier; + b = data[i * 4 + 2] * multiplier; + a = data[i * 4 + 3] * multiplier; + } + j = i * 4; + bytes[j + 0] = Math.round(r); + bytes[j + 1] = Math.round(g); + bytes[j + 2] = Math.round(b); + bytes[j + 3] = Math.round(a); + } + if (canvas != null) { + canvas.width = width; + canvas.height = height; + ctx = canvas.getContext('2d'); + imageData = new ImageData(bytes, width, height); + ctx.putImageData(imageData, 0, 0); + } + if ($img !== img) { + $img.dispose(); + } + return [2, bytes]; + } + }); + }); +} +exports.toPixels = toPixels; +function reshape_(x, shape) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reshape'); + shape = util.inferFromImplicitShape(shape, $x.size); + util.assert($x.size === util.sizeFromShape(shape), 'new shape and old shape must have the same number of elements.'); + var grad = function (dy) { + return { $x: function () { return dy.reshape($x.shape); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.reshape($x, shape); }, { $x: $x }, grad); +} +function squeeze_(x, axis) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'squeeze'); + return exports.reshape($x, util.squeezeShape($x.shape, axis).newShape); +} +function cast_(x, dtype) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'cast'); + var grad = function (dy) { + return { $x: function () { return dy.clone(); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.cast($x, dtype); }, { $x: $x }, grad); +} +function tile_(x, reps) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'tile'); + util.assert($x.rank === reps.length, "Error in transpose: rank of input " + $x.rank + " " + + ("must match length of reps " + reps + ".")); + var grad = function (dy) { + var derX = function () { + var xGrad = tensor_ops_1.zerosLike($x); + if ($x.rank === 1) { + for (var i = 0; i < reps[0]; ++i) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0]], [$x.shape[0]])); + } + } + else if ($x.rank === 2) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0], j * $x.shape[1]], [$x.shape[0], $x.shape[1]])); + } + } + } + else if ($x.rank === 3) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + for (var k = 0; k < reps[2]; ++k) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0], j * $x.shape[1], k * $x.shape[2]], [$x.shape[0], $x.shape[1], $x.shape[2]])); + } + } + } + } + else if ($x.rank === 4) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + for (var k = 0; k < reps[2]; ++k) { + for (var l = 0; l < reps[3]; ++l) { + xGrad = xGrad.add(dy.slice([ + i * $x.shape[0], j * $x.shape[1], k * $x.shape[2], + l * $x.shape[3] + ], [$x.shape[0], $x.shape[1], $x.shape[2], $x.shape[3]])); + } + } + } + } + } + else { + throw new Error("Gradient for tile operation is not implemented for rank-" + + ($x.rank + " tensors yet.")); + } + return xGrad; + }; + return { $x: derX }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.tile($x, reps); }, { $x: $x }, grad); +} +function pad1d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + util.assert(paddings.length === 2, 'Invalid number of paddings. Must be length of 2.'); + return exports.pad(x, [paddings], constantValue); +} +function pad2d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + util.assert(paddings.length === 2 && paddings[0].length === 2 && + paddings[1].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return exports.pad(x, paddings, constantValue); +} +function pad3d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + util.assert(paddings.length === 3 && paddings[0].length === 2 && + paddings[1].length === 2 && paddings[2].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return exports.pad(x, paddings, constantValue); +} +function pad4d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + util.assert(paddings.length === 4 && paddings[0].length === 2 && + paddings[1].length === 2 && paddings[2].length === 2 && + paddings[3].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return exports.pad(x, paddings, constantValue); +} +function pad_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'pad'); + if ($x.rank === 0) { + throw new Error('pad(scalar) is not defined. Pass non-scalar to pad'); + } + var begin = paddings.map(function (p) { return p[0]; }); + var grad = function (dy) { + return { $x: function () { return dy.slice(begin, $x.shape); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.pad($x, paddings, constantValue); }, { $x: $x }, grad); +} +function stack_(tensors, axis) { + if (axis === void 0) { axis = 0; } + var $tensors = tensor_util_env_1.convertToTensorArray(tensors, 'tensors', 'stack'); + util.assert($tensors.length >= 1, 'Pass at least one tensor to tf.stack'); + if ($tensors.length === 1) { + return $tensors[0].expandDims(axis); + } + var rank = $tensors[0].rank; + var shape = $tensors[0].shape; + var dtype = $tensors[0].dtype; + util.assert(axis <= rank, 'Axis must be <= rank of the tensor'); + $tensors.forEach(function (t) { + util.assertShapesMatch(shape, t.shape, 'All tensors passed to stack must have matching shapes'); + }); + $tensors.forEach(function (t) { + util.assert(dtype === t.dtype, 'All tensors passed to stack must have matching dtypes'); + }); + var expandedTensors = $tensors.map(function (t) { return t.expandDims(axis); }); + return concat_1.concat(expandedTensors, axis); +} +function batchToSpaceND_(x, blockShape, crops) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'batchToSpaceND'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + util.assert($x.rank >= 1 + blockShape.length, "input rank should be > than [blockShape] but got " + $x.rank); + util.assert(crops.length === blockShape.length, "crops.shape[0] must be equal to [blockShape] but got " + crops.length); + util.assert($x.shape[0] % prod === 0, "input tensor batch must be divisible by prod( blockShape )"); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.batchToSpaceND($x, blockShape, crops); }, {}); +} +function spaceToBatchND_(x, blockShape, paddings) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'spaceToBatchND'); + util.assert($x.rank >= 1 + blockShape.length, "input rank should be > than [blockShape] but got " + $x.rank); + util.assert(paddings.length === blockShape.length, "paddings.shape[0] must be equal to [blockShape], got " + paddings.length); + util.assert($x.shape.reduce(function (a, b, i) { + if (i > 0 && i <= blockShape.length) { + return a && (b % blockShape[i - 1] === 0); + } + return a; + }, true), "input spatial dimensions must be divisible by blockShapes"); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.spaceToBatchND($x, blockShape, paddings); }, {}); +} +function unstack_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'unstack'); + var num = $x.shape[axis]; + var outputShape = Array($x.rank - 1).fill(0); + var outIndex = 0; + for (var i = 0; i < $x.rank; i++) { + if (i !== axis) { + outputShape[outIndex] = $x.shape[i]; + outIndex++; + } + } + var splitSizes; + splitSizes = Array(num).fill(1); + var begin = Array($x.rank).fill(0); + var size = $x.shape.slice(); + return splitSizes.map(function (s) { + size[axis] = s; + var slice = $x.slice(begin, size); + begin[axis] += s; + return slice.reshape(outputShape); + }); +} +function split_(x, numOrSizeSplits, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'split'); + axis = axis_util_1.parseAxisParam(axis, $x.shape)[0]; + var splitSizes; + if (typeof (numOrSizeSplits) === 'number') { + util.assert($x.shape[axis] % numOrSizeSplits === 0, 'Number of splits must evenly divide the axis.'); + splitSizes = Array(numOrSizeSplits).fill($x.shape[axis] / numOrSizeSplits); + } + else { + util.assert($x.shape[axis] === numOrSizeSplits.reduce(function (a, b) { return a + b; }), 'The sum of sizes must match the size of the axis dimension.'); + splitSizes = numOrSizeSplits; + } + var begin = Array($x.rank).fill(0); + var size = $x.shape.slice(); + return splitSizes.map(function (s) { + size[axis] = s; + var slice = $x.slice(begin, size); + begin[axis] += s; + return slice; + }); +} +function cumsum_(x, axis, exclusive, reverse) { + if (axis === void 0) { axis = 0; } + if (exclusive === void 0) { exclusive = false; } + if (reverse === void 0) { reverse = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'cumsum'); + axis = axis | 0; + var permutation = axis_util_1.getAxesPermutation([axis], $x.rank); + var permutedX = $x; + if (permutation != null) { + permutedX = $x.transpose(permutation); + } + var permutedAxis = axis_util_1.getInnerMostAxes(1, $x.rank)[0]; + var grad = function (dy) { + return { permutedX: function () { return dy.cumsum(axis, exclusive, !reverse); } }; + }; + var value = environment_1.ENV.engine.runKernel(function (backend) { return backend.cumsum(permutedX, permutedAxis, exclusive, reverse); }, { permutedX: permutedX }, grad); + if (permutation != null) { + value = value.transpose(permutation); + } + return value; +} +function expandDims_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'expandDims'); + util.assert(axis <= $x.rank, 'Axis must be <= rank of the tensor'); + var newShape = $x.shape.slice(); + if (axis < 0) { + util.assert(-($x.rank + 1) <= axis, "Axis must be in the interval [" + -($x.rank + 1) + ", " + $x.rank + "]"); + axis = $x.rank + axis + 1; + } + newShape.splice(axis, 0, 1); + return exports.reshape($x, newShape); +} +function buffer(shape, dtype, values) { + if (dtype === void 0) { dtype = 'float32'; } + return new tensor_1.TensorBuffer(shape, dtype, values); +} +exports.buffer = buffer; +function print(x, verbose) { + if (verbose === void 0) { verbose = false; } + console.log(x.toString(verbose)); +} +exports.print = print; +exports.cast = operation_1.op({ cast_: cast_ }); +exports.clone = operation_1.op({ clone_: clone_ }); +exports.cumsum = operation_1.op({ cumsum_: cumsum_ }); +exports.expandDims = operation_1.op({ expandDims_: expandDims_ }); +exports.eye = operation_1.op({ eye_: eye_ }); +exports.fromPixels = operation_1.op({ fromPixels_: fromPixels_ }); +exports.multinomial = operation_1.op({ multinomial_: multinomial_ }); +exports.oneHot = operation_1.op({ oneHot_: oneHot_ }); +exports.pad = operation_1.op({ pad_: pad_ }); +exports.pad1d = operation_1.op({ pad1d_: pad1d_ }); +exports.pad2d = operation_1.op({ pad2d_: pad2d_ }); +exports.pad3d = operation_1.op({ pad3d_: pad3d_ }); +exports.pad4d = operation_1.op({ pad4d_: pad4d_ }); +exports.rand = operation_1.op({ rand_: rand_ }); +exports.randomNormal = operation_1.op({ randomNormal_: randomNormal_ }); +exports.randomUniform = operation_1.op({ randomUniform_: randomUniform_ }); +exports.reshape = operation_1.op({ reshape_: reshape_ }); +exports.split = operation_1.op({ split_: split_ }); +exports.squeeze = operation_1.op({ squeeze_: squeeze_ }); +exports.stack = operation_1.op({ stack_: stack_ }); +exports.tile = operation_1.op({ tile_: tile_ }); +exports.truncatedNormal = operation_1.op({ truncatedNormal_: truncatedNormal_ }); +exports.unstack = operation_1.op({ unstack_: unstack_ }); +exports.batchToSpaceND = operation_1.op({ batchToSpaceND_: batchToSpaceND_ }); +exports.spaceToBatchND = operation_1.op({ spaceToBatchND_: spaceToBatchND_ }); +//# sourceMappingURL=array_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js.map new file mode 100644 index 0000000..a9f4d7b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"array_ops.js","sourceRoot":"","sources":["../../src/ops/array_ops.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgBA,8CAAmC;AACnC,oCAAuF;AACvF,sDAAyE;AAEzE,8BAAgC;AAChC,yCAAiF;AACjF,mCAAgC;AAChC,yCAA+B;AAC/B,+BAAmC;AACnC,2CAAuC;AAevC,gBAAkC,CAAe;IAC/C,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IAC5C,IAAM,GAAG,GAAG,UAAC,EAAK;QAChB,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,OAAO,EAAE,EAAZ,CAAY,EAAC,CAAC;IAClC,CAAC,CAAC;IAEF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CAChB,UAAA,OAAO;QACH,OAAA,eAAM,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAC,EAAE,EAAE,CAAC,KAAK,CAAM;IAAzD,CAAyD,EAC7D,EAAC,EAAE,IAAA,EAAC,EAAE,GAAG,CAAM,CAAC;AAC7B,CAAC;AAeD,cACI,OAAe,EAAE,UAAmB,EACpC,UAIwE,EACxE,KAA2B;IAA3B,sBAAA,EAAA,iBAA2B;IAC7B,IAAI,UAAU,IAAI,IAAI,EAAE;QACtB,UAAU,GAAG,OAAO,CAAC;KACtB;IACD,IAAM,IAAI,GAAG,MAAM,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,EAAE,KAAK,CAAC,CAAC;IAClD,IAAM,CAAC,GAAG,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC;IACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;QAC1B,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;KACnB;IACD,IAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IACtD,IAAI,UAAU,IAAI,IAAI,EAAE;QACtB,OAAO,GAAG,CAAC;KACZ;SAAM;QACL,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,OAAO,YAAI,CAAC,kBAAU,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SACxD;aAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,OAAO,YAAI,CACP,kBAAU,CAAC,kBAAU,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EACjC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SAC3C;aAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,OAAO,YAAI,CACP,kBAAU,CAAC,kBAAU,CAAC,kBAAU,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAChD,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SAC1D;aAAM;YACL,MAAM,IAAI,KAAK,CACX,0CAA0C;iBAE1C,+BAA8B,UAAkB,CAAC,MAAM,OAAI,CAAA,CAAC,CAAC;SAClE;KACF;AACH,CAAC;AAgBD,uBACI,KAAkB,EAAE,IAAQ,EAAE,MAAU,EAAE,KAAyB,EACnE,IAAa;IADO,qBAAA,EAAA,QAAQ;IAAE,uBAAA,EAAA,UAAU;IAE1C,IAAI,KAAK,IAAI,IAAI,IAAK,KAAkB,KAAK,MAAM,EAAE;QACnD,MAAM,IAAI,KAAK,CAAC,2BAAyB,KAAO,CAAC,CAAC;KACnD;IACD,IAAM,SAAS,GACX,IAAI,kBAAW,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAkB,IAAI,CAAC,CAAC;IACtE,IAAM,GAAG,GAAG,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC;KACvC;IACD,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;AACxB,CAAC;AAqBD,0BACI,KAAkB,EAAE,IAAQ,EAAE,MAAU,EAAE,KAAyB,EACnE,IAAa;IADO,qBAAA,EAAA,QAAQ;IAAE,uBAAA,EAAA,UAAU;IAE1C,IAAI,KAAK,IAAI,IAAI,IAAK,KAAkB,KAAK,MAAM,EAAE;QACnD,MAAM,IAAI,KAAK,CAAC,2BAAyB,KAAO,CAAC,CAAC;KACnD;IACD,IAAM,SAAS,GACX,IAAI,kBAAW,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAkB,IAAI,CAAC,CAAC;IACrE,IAAM,GAAG,GAAG,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC;KACvC;IACD,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;AACxB,CAAC;AAqBD,wBACI,KAAkB,EAAE,MAAU,EAAE,MAAU,EAC1C,KAA2B;IADP,uBAAA,EAAA,UAAU;IAAE,uBAAA,EAAA,UAAU;IAC1C,sBAAA,EAAA,iBAA2B;IAC7B,IAAM,GAAG,GAAG,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KAClD;IACD,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;AACxB,CAAC;AAWD,eACI,KAAkB,EAAE,YAA0B,EAC9C,KAAgB;IAClB,IAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAEvC,IAAI,MAAM,GAAG,IAAI,CAAC;IAClB,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;QACxC,MAAM,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;KACjC;SAAM,IAAI,KAAK,KAAK,OAAO,EAAE;QAC5B,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;KAC/B;SAAM,IAAI,KAAK,KAAK,MAAM,EAAE;QAC3B,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;KAC/B;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,uBAAqB,KAAO,CAAC,CAAC;KAC/C;IAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;QAC7B,MAAM,CAAC,CAAC,CAAC,GAAG,YAAY,EAAE,CAAC;KAC5B;IACD,OAAO,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,MAAM,QAAA,EAAC,EAAE,KAAK,CAAC,CAAC;AAC7C,CAAC;AAqBD,sBACI,MAAoC,EAAE,UAAkB,EAAE,IAAa,EACvE,UAAkB;IAAlB,2BAAA,EAAA,kBAAkB;IACpB,IAAM,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;IACjE,IAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IACjC,IAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAC9B,IAAI,WAAW,GAAG,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CACX,8DAA8D;aAC3D,WAAW,MAAG,CAAA,CAAC,CAAC;KACxB;IACD,IAAI,QAAQ,GAAG,CAAC,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,kDAAgD,QAAU,CAAC,CAAC;KAC7E;IACD,IAAI,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;IAC7B,IAAM,QAAQ,GAAG,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAmB,CAAC;IAC5E,IAAM,GAAG,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAC5B,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,WAAW,CAAC,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,EAA3D,CAA2D,EACtE,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;IAEhB,OAAO,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;AAC3C,CAAC;AAmBD,iBACI,OAA8B,EAAE,KAAa,EAAE,OAAW,EAC1D,QAAY;IADmC,wBAAA,EAAA,WAAW;IAC1D,yBAAA,EAAA,YAAY;IACd,IAAM,QAAQ,GAAG,iCAAe,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IACxE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,KAAK,OAAO,EAAE,kCAAkC,CAAC,CAAC;IAE5E,IAAI,KAAK,GAAG,CAAC,EAAE;QACb,MAAM,IAAI,KAAK,CAAC,mDAAiD,KAAO,CAAC,CAAC;KAC3E;IACD,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CACvB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAlD,CAAkD,EAC7D,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;AAClB,CAAC;AAsBD,qBACI,MAAqE,EACrE,WAAe;IAAf,4BAAA,EAAA,eAAe;IACjB,IAAI,WAAW,GAAG,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CACX,gEAAgE,CAAC,CAAC;KACvE;IACD,OAAO,iBAAG,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AACpD,CAAC;AAoBD,kBACI,GAAiC,EACjC,MAA0B;;;;;;oBACtB,IAAI,GAAG,iCAAe,CAAC,GAAG,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;oBAC9D,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;wBACtC,MAAM,IAAI,KAAK,CACX,0DAAwD,IAAI,CAAC,IAAI,MAAG,CAAC,CAAC;qBAC3E;oBACK,KAAkB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAvC,MAAM,QAAA,EAAE,KAAK,QAAA,CAA2B;oBACzC,KAAK,GAAG,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBAElD,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE;wBAC5B,MAAM,IAAI,KAAK,CACX,uCAAuC;6BACvC,uBAAqB,KAAO,CAAA,CAAC,CAAC;qBACnC;oBAEK,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;oBACvB,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;oBAChB,WAAM,SAAS,CAAC,IAAI,EAAE,EAAA;;oBAA7B,GAAG,GAAG,CAAC,SAAsB,CAAC,CAAC,CAAC,CAAC;oBAC1B,WAAM,SAAS,CAAC,IAAI,EAAE,EAAA;;oBAA7B,GAAG,GAAG,CAAC,SAAsB,CAAC,CAAC,CAAC,CAAC;oBACvC,SAAS,CAAC,OAAO,EAAE,CAAC;oBACpB,SAAS,CAAC,OAAO,EAAE,CAAC;oBACpB,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;wBAC5B,IAAI,GAAG,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,EAAE;4BACtB,MAAM,IAAI,KAAK,CACX,oDAAoD;iCACpD,kCAAgC,GAAG,WAAM,GAAG,OAAI,CAAA,CAAC,CAAC;yBACvD;qBACF;yBAAM,IAAI,IAAI,CAAC,KAAK,KAAK,OAAO,EAAE;wBACjC,IAAI,GAAG,GAAG,CAAC,IAAI,GAAG,GAAG,GAAG,EAAE;4BACxB,MAAM,IAAI,KAAK,CACX,kDAAkD;iCAClD,oCAAkC,GAAG,WAAM,GAAG,OAAI,CAAA,CAAC,CAAC;yBACzD;qBACF;yBAAM;wBACL,MAAM,IAAI,KAAK,CACX,oCAAkC,IAAI,CAAC,KAAK,MAAG;4BAC/C,uCAAuC,CAAC,CAAC;qBAC9C;oBAEY,WAAM,IAAI,CAAC,IAAI,EAAE,EAAA;;oBAAxB,IAAI,GAAG,SAAiB;oBACxB,UAAU,GAAG,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;oBAChD,KAAK,GAAG,IAAI,iBAAiB,CAAC,KAAK,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC;oBAExD,KAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,GAAG,KAAK,EAAE,EAAE,CAAC,EAAE;wBACnC,CAAC,SAAA,EAAE,CAAC,SAAA,EAAE,CAAC,SAAA,EAAE,CAAC,SAAA,CAAC;wBACf,IAAI,KAAK,KAAK,CAAC,EAAE;4BACf,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;4BACzB,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;4BACzB,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;4BACzB,CAAC,GAAG,GAAG,CAAC;yBACT;6BAAM,IAAI,KAAK,KAAK,CAAC,EAAE;4BACtB,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BAC7B,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BACjC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BACjC,CAAC,GAAG,GAAG,CAAC;yBACT;6BAAM,IAAI,KAAK,KAAK,CAAC,EAAE;4BACtB,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BAC7B,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BACjC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;4BACjC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC;yBAClC;wBAEK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;wBAChB,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBAC7B,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBAC7B,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBAC7B,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;qBAC9B;oBAED,IAAI,MAAM,IAAI,IAAI,EAAE;wBAClB,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;wBACrB,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;wBACjB,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;wBAC9B,SAAS,GAAG,IAAI,SAAS,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;wBACtD,GAAG,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;qBACnC;oBACD,IAAI,IAAI,KAAK,GAAG,EAAE;wBAChB,IAAI,CAAC,OAAO,EAAE,CAAC;qBAChB;oBACD,WAAO,KAAK,EAAC;;;;CACd;AAkqBC,4BAAQ;AAvoBV,kBACI,CAAoB,EAAE,KAAmB;IAC3C,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,KAAK,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;IACpD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EACrC,gEAAgE,CAAC,CAAC;IAEtE,IAAM,IAAI,GAAG,UAAC,EAAc;QAC1B,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,EAApB,CAAoB,EAAC,CAAC;IAC1C,CAAC,CAAC;IACF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CACvB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,OAAO,CAAC,EAAE,EAAE,KAAK,CAAC,EAA1B,CAA0B,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,IAAI,CAAC,CAAC;AACzD,CAAC;AAgBD,kBAAoC,CAAoB,EAAE,IAAe;IACvE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,OAAO,eAAO,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAM,CAAC;AACtE,CAAC;AAaD,eAAiC,CAAe,EAAE,KAAe;IAC/D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAE3C,IAAM,IAAI,GAAG,UAAC,EAAK;QACjB,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,KAAK,EAAE,EAAV,CAAU,EAAC,CAAC;IAChC,CAAC,CAAC;IACF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,CAAC,EAAvB,CAAuB,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,IAAI,CACrE,CAAC;AACR,CAAC;AA0BD,eAAiC,CAAe,EAAE,IAAc;IAC9D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAE3C,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EACvB,uCAAqC,EAAE,CAAC,IAAI,MAAG;SAC3C,+BAA6B,IAAI,MAAG,CAAA,CAAC,CAAC;IAC9C,IAAM,IAAI,GAAG,UAAC,EAAK;QACjB,IAAM,IAAI,GAAG;YACX,IAAI,KAAK,GAAG,sBAAS,CAAC,EAAE,CAAC,CAAC;YAG1B,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;gBACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;oBAChC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC/D;aACF;iBAAM,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;gBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;oBAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;wBAChC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CACtB,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAClC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;qBAClC;iBACF;aACF;iBAAM,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;gBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;oBAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;wBAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;4BAChC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CACtB,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EACnD,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;yBAC/C;qBACF;iBACF;aACF;iBAAM,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;gBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;oBAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;wBAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;4BAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE;gCAChC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CACtB;oCACE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;oCACjD,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;iCAChB,EACD,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;6BAC5D;yBACF;qBACF;iBACF;aACF;iBAAM;gBACL,MAAM,IAAI,KAAK,CACX,0DAA0D;qBACvD,EAAE,CAAC,IAAI,kBAAe,CAAA,CAAC,CAAC;aAChC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC;QACF,OAAO,EAAC,EAAE,EAAE,IAAI,EAAC,CAAC;IACpB,CAAC,CAAC;IACF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,EAAtB,CAAsB,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,IAAI,CAAC,CAAC;AAC7E,CAAC;AAKD,gBACI,CAAsB,EAAE,QAA0B,EAClD,aAAiB;IAAjB,8BAAA,EAAA,iBAAiB;IACnB,IAAI,CAAC,MAAM,CACP,QAAQ,CAAC,MAAM,KAAK,CAAC,EACrB,kDAAkD,CAAC,CAAC;IACxD,OAAO,WAAG,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,aAAa,CAAC,CAAC;AAC3C,CAAC;AAKD,gBACI,CAAsB,EAAE,QAA8C,EACtE,aAAiB;IAAjB,8BAAA,EAAA,iBAAiB;IACnB,IAAI,CAAC,MAAM,CACP,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7C,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,EAC5B,uDAAuD,CAAC,CAAC;IAC7D,OAAO,WAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;AACzC,CAAC;AAKD,gBACI,CAAsB,EACtB,QAAgE,EAChE,aAAiB;IAAjB,8BAAA,EAAA,iBAAiB;IACnB,IAAI,CAAC,MAAM,CACP,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7C,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,EACxD,uDAAuD,CAAC,CAAC;IAC7D,OAAO,WAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;AACzC,CAAC;AAKD,gBACI,CAAsB,EACtB,QAIK,EACL,aAAiB;IAAjB,8BAAA,EAAA,iBAAiB;IACnB,IAAI,CAAC,MAAM,CACP,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7C,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC;QACpD,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,EAC5B,uDAAuD,CAAC,CAAC;IAC7D,OAAO,WAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;AACzC,CAAC;AAyBD,cACI,CAAe,EAAE,QAAiC,EAAE,aAAiB;IAAjB,8BAAA,EAAA,iBAAiB;IACvE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;IAE1C,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;KACvE;IAGD,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,CAAC,EAAJ,CAAI,CAAC,CAAC;IACtC,IAAM,IAAI,GAAG,UAAC,EAAK;QACjB,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAzB,CAAyB,EAAC,CAAC;IAC/C,CAAC,CAAC;IACF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CAChB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,EAAE,aAAa,CAAC,EAAxC,CAAwC,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,IAAI,CACrE,CAAC;AACR,CAAC;AAgBD,gBAAkC,OAAyB,EAAE,IAAQ;IAAR,qBAAA,EAAA,QAAQ;IACnE,IAAM,QAAQ,GAAG,sCAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAEnE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE,sCAAsC,CAAC,CAAC;IAC1E,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;QACzB,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;KACrC;IACD,IAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC9B,IAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAChC,IAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAEhC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,EAAE,oCAAoC,CAAC,CAAC;IAEhE,QAAQ,CAAC,OAAO,CAAC,UAAA,CAAC;QAChB,IAAI,CAAC,iBAAiB,CAClB,KAAK,EAAE,CAAC,CAAC,KAAK,EACd,uDAAuD,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,OAAO,CAAC,UAAA,CAAC;QAChB,IAAI,CAAC,MAAM,CACP,KAAK,KAAK,CAAC,CAAC,KAAK,EACjB,uDAAuD,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IACH,IAAM,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,EAAlB,CAAkB,CAAC,CAAC;IAC9D,OAAO,eAAM,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;AACvC,CAAC;AAkDD,yBACI,CAAe,EAAE,UAAoB,EAAE,KAAiB;IAC1D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,gBAAgB,CAAC,CAAC;IACrD,IAAM,IAAI,GAAG,UAAU,CAAC,MAAM,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,GAAG,CAAC,EAAL,CAAK,CAAC,CAAC;IAEhD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAChC,sDAAoD,EAAE,CAAC,IAAM,CAAC,CAAC;IAEnE,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,MAAM,KAAK,UAAU,CAAC,MAAM,EAClC,0DAAwD,KAAK,CAAC,MAAQ,CAAC,CAAC;IAE5E,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,EACxB,4DAA4D,CAAC,CAAC;IAClE,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CACvB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,cAAc,CAAC,EAAE,EAAE,UAAU,EAAE,KAAK,CAAC,EAA7C,CAA6C,EAAE,EAAE,CAAC,CAAC;AACpE,CAAC;AAmDD,yBACI,CAAe,EAAE,UAAoB,EAAE,QAAoB;IAC7D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,gBAAgB,CAAC,CAAC;IAErD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAChC,sDAAoD,EAAE,CAAC,IAAM,CAAC,CAAC;IAEnE,IAAI,CAAC,MAAM,CACP,QAAQ,CAAC,MAAM,KAAK,UAAU,CAAC,MAAM,EACrC,0DACI,QAAQ,CAAC,MAAQ,CAAC,CAAC;IAE3B,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,UAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QAClC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,MAAM,EAAE;YACnC,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SAC3C;QACD,OAAO,CAAC,CAAC;IACX,CAAC,EAAE,IAAI,CAAC,EAAE,2DAA2D,CAAC,CAAC;IACvE,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CACvB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,cAAc,CAAC,EAAE,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAhD,CAAgD,EAAE,EAAE,CAAC,CAAC;AACvE,CAAC;AAeD,kBAAoC,CAAe,EAAE,IAAQ;IAAR,qBAAA,EAAA,QAAQ;IAC3D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,IAAM,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC3B,IAAM,WAAW,GAAa,KAAK,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzD,IAAI,QAAQ,GAAG,CAAC,CAAC;IACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;QAChC,IAAI,CAAC,KAAK,IAAI,EAAE;YACd,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACpC,QAAQ,EAAE,CAAC;SACZ;KACF;IAED,IAAI,UAAoB,CAAC;IACzB,UAAU,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChC,IAAM,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACrC,IAAM,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IAC9B,OAAO,UAAU,CAAC,GAAG,CAAC,UAAA,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACf,IAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,OAAO,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;AACL,CAAC;AAmCD,gBACI,CAAe,EAAE,eAAgC,EAAE,IAAQ;IAAR,qBAAA,EAAA,QAAQ;IAC7D,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IAE5C,IAAI,GAAG,0BAAc,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACzC,IAAI,UAAoB,CAAC;IACzB,IAAI,OAAO,CAAC,eAAe,CAAC,KAAK,QAAQ,EAAE;QACzC,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,eAAe,KAAK,CAAC,EACtC,+CAA+C,CAAC,CAAC;QACrD,UAAU,GAAG,KAAK,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,CAAC;KAC5E;SAAM;QACL,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,eAAe,CAAC,MAAM,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,GAAG,CAAC,EAAL,CAAK,CAAC,EAC1D,6DAA6D,CAAC,CAAC;QACnE,UAAU,GAAG,eAAe,CAAC;KAC9B;IACD,IAAM,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACrC,IAAM,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IAC9B,OAAO,UAAU,CAAC,GAAG,CAAC,UAAA,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACf,IAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,OAAO,KAAK,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC;AAwBD,iBACI,CAAoB,EAAE,IAAQ,EAAE,SAAiB,EAAE,OAAe;IAA5C,qBAAA,EAAA,QAAQ;IAAE,0BAAA,EAAA,iBAAiB;IAAE,wBAAA,EAAA,eAAe;IACpE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;IAE7C,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC;IAChB,IAAM,WAAW,GAAG,8BAAkB,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;IACxD,IAAI,SAAS,GAAG,EAAE,CAAC;IACnB,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,SAAS,GAAG,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;KACvC;IACD,IAAM,YAAY,GAAG,4BAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAErD,IAAM,IAAI,GAAG,UAAC,EAAK;QACjB,OAAO,EAAC,SAAS,EAAE,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,OAAO,CAAC,EAApC,CAAoC,EAAC,CAAC;IACjE,CAAC,CAAC;IACF,IAAI,KAAK,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAChB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,MAAM,CACrB,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,CAAC,EADrC,CACqC,EAChD,EAAC,SAAS,WAAA,EAAC,EAAE,IAAI,CAAM,CAAC;IAExC,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,KAAK,GAAG,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;KACtC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAiBD,qBACI,CAAoB,EAAE,IAAQ;IAAR,qBAAA,EAAA,QAAQ;IAChC,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,YAAY,CAAC,CAAC;IAEjD,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI,EAAE,oCAAoC,CAAC,CAAC;IACnE,IAAM,QAAQ,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IAClC,IAAI,IAAI,GAAG,CAAC,EAAE;QAEZ,IAAI,CAAC,MAAM,CACP,CAAC,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,EACtB,mCAAiC,CAAE,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,UAAK,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;QACrE,IAAI,GAAG,EAAE,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC;KAC3B;IACD,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,OAAO,eAAO,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;AAC/B,CAAC;AA2BD,gBACI,KAAkB,EAAE,KAA2B,EAC/C,MAAmB;IADC,sBAAA,EAAA,iBAA2B;IAEjD,OAAO,IAAI,qBAAY,CAAI,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AACnD,CAAC;AAmBC,wBAAM;AALR,eAAiC,CAAI,EAAE,OAAe;IAAf,wBAAA,EAAA,eAAe;IACpD,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;AACnC,CAAC;AAKC,sBAAK;AAGM,QAAA,IAAI,GAAG,cAAE,CAAC,EAAC,KAAK,OAAA,EAAC,CAAC,CAAC;AACnB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,MAAM,GAAG,cAAE,CAAC,EAAC,OAAO,SAAA,EAAC,CAAC,CAAC;AACvB,QAAA,UAAU,GAAG,cAAE,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;AAC/B,QAAA,GAAG,GAAG,cAAE,CAAC,EAAC,IAAI,MAAA,EAAC,CAAC,CAAC;AACjB,QAAA,UAAU,GAAG,cAAE,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;AAC/B,QAAA,WAAW,GAAG,cAAE,CAAC,EAAC,YAAY,cAAA,EAAC,CAAC,CAAC;AACjC,QAAA,MAAM,GAAG,cAAE,CAAC,EAAC,OAAO,SAAA,EAAC,CAAC,CAAC;AACvB,QAAA,GAAG,GAAG,cAAE,CAAC,EAAC,IAAI,MAAA,EAAC,CAAC,CAAC;AACjB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,IAAI,GAAG,cAAE,CAAC,EAAC,KAAK,OAAA,EAAC,CAAC,CAAC;AACnB,QAAA,YAAY,GAAG,cAAE,CAAC,EAAC,aAAa,eAAA,EAAC,CAAC,CAAC;AACnC,QAAA,aAAa,GAAG,cAAE,CAAC,EAAC,cAAc,gBAAA,EAAC,CAAC,CAAC;AACrC,QAAA,OAAO,GAAG,cAAE,CAAC,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;AACzB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,OAAO,GAAG,cAAE,CAAC,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;AACzB,QAAA,KAAK,GAAG,cAAE,CAAC,EAAC,MAAM,QAAA,EAAC,CAAC,CAAC;AACrB,QAAA,IAAI,GAAG,cAAE,CAAC,EAAC,KAAK,OAAA,EAAC,CAAC,CAAC;AACnB,QAAA,eAAe,GAAG,cAAE,CAAC,EAAC,gBAAgB,kBAAA,EAAC,CAAC,CAAC;AACzC,QAAA,OAAO,GAAG,cAAE,CAAC,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;AACzB,QAAA,cAAc,GAAG,cAAE,CAAC,EAAC,eAAe,iBAAA,EAAC,CAAC,CAAC;AACvC,QAAA,cAAc,GAAG,cAAE,CAAC,EAAC,eAAe,iBAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js new file mode 100644 index 0000000..74309f0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js @@ -0,0 +1,2743 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var util = require("../util"); +var rand_util_1 = require("./rand_util"); +jasmine_util_1.describeWithFlags('zeros', test_util_1.ALL_ENVS, function () { + it('1D default dtype', function () { + var a = tf.zeros([3]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [0, 0, 0]); + }); + it('1D float32 dtype', function () { + var a = tf.zeros([3], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [0, 0, 0]); + }); + it('1D int32 dtype', function () { + var a = tf.zeros([3], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [0, 0, 0]); + }); + it('1D bool dtype', function () { + var a = tf.zeros([3], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [0, 0, 0]); + }); + it('2D default dtype', function () { + var a = tf.zeros([3, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0]); + }); + it('2D float32 dtype', function () { + var a = tf.zeros([3, 2], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0]); + }); + it('2D int32 dtype', function () { + var a = tf.zeros([3, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0]); + }); + it('2D bool dtype', function () { + var a = tf.zeros([3, 2], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0]); + }); + it('3D default dtype', function () { + var a = tf.zeros([2, 2, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0, 0, 0]); + }); + it('3D float32 dtype', function () { + var a = tf.zeros([2, 2, 2], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0, 0, 0]); + }); + it('3D int32 dtype', function () { + var a = tf.zeros([2, 2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0, 0, 0]); + }); + it('3D bool dtype', function () { + var a = tf.zeros([2, 2, 2], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0, 0, 0]); + }); + it('4D default dtype', function () { + var a = tf.zeros([3, 2, 1, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0]); + }); + it('4D float32 dtype', function () { + var a = tf.zeros([3, 2, 1, 1], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysClose(a, [0, 0, 0, 0, 0, 0]); + }); + it('4D int32 dtype', function () { + var a = tf.zeros([3, 2, 1, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0]); + }); + it('4D bool dtype', function () { + var a = tf.zeros([3, 2, 1, 1], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [0, 0, 0, 0, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('ones', test_util_1.ALL_ENVS, function () { + it('1D default dtype', function () { + var a = tf.ones([3]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [1, 1, 1]); + }); + it('1D float32 dtype', function () { + var a = tf.ones([3], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [1, 1, 1]); + }); + it('1D int32 dtype', function () { + var a = tf.ones([3], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [1, 1, 1]); + }); + it('1D bool dtype', function () { + var a = tf.ones([3], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [1, 1, 1]); + }); + it('2D default dtype', function () { + var a = tf.ones([3, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1]); + }); + it('2D float32 dtype', function () { + var a = tf.ones([3, 2], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1]); + }); + it('2D int32 dtype', function () { + var a = tf.ones([3, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1]); + }); + it('2D bool dtype', function () { + var a = tf.ones([3, 2], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1]); + }); + it('3D default dtype', function () { + var a = tf.ones([2, 2, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1, 1, 1]); + }); + it('3D float32 dtype', function () { + var a = tf.ones([2, 2, 2], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1, 1, 1]); + }); + it('3D int32 dtype', function () { + var a = tf.ones([2, 2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1, 1, 1]); + }); + it('3D bool dtype', function () { + var a = tf.ones([2, 2, 2], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1, 1, 1]); + }); + it('4D default dtype', function () { + var a = tf.ones([3, 2, 1, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1]); + }); + it('4D float32 dtype', function () { + var a = tf.ones([3, 2, 1, 1], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysClose(a, [1, 1, 1, 1, 1, 1]); + }); + it('4D int32 dtype', function () { + var a = tf.ones([3, 2, 1, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1]); + }); + it('4D bool dtype', function () { + var a = tf.ones([3, 2, 1, 1], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([3, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [1, 1, 1, 1, 1, 1]); + }); +}); +jasmine_util_1.describeWithFlags('zerosLike', test_util_1.ALL_ENVS, function () { + it('1D default dtype', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [0, 0, 0]); + }); + it('1D float32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [0, 0, 0]); + }); + it('1D int32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [0, 0, 0]); + }); + it('1D bool dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [0, 0, 0]); + }); + it('2D default dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('2D float32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('2D int32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('2D bool dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('3D default dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('3D float32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('3D int32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('3D bool dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('4D float32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('4D int32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('4D bool dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('5D float32 dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('5D int32 dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('5D bool dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('5D default dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('6D float32 dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'float32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1, 1]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('6D int32 dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'int32'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('6D bool dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'bool'); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysEqual(b, [0, 0, 0, 0]); + }); + it('6D default dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1]); + var b = tf.zerosLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysClose(b, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.zerosLike({}); }) + .toThrowError(/Argument 'x' passed to 'zerosLike' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.zerosLike([[1, 2], [3, 4]]); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(res, [0, 0, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('onesLike', test_util_1.ALL_ENVS, function () { + it('1D default dtype', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [1, 1, 1]); + }); + it('1D float32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [1, 1, 1]); + }); + it('1D int32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [1, 1, 1]); + }); + it('1D bool dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [1, 1, 1]); + }); + it('2D default dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('2D float32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('2D int32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('2D bool dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('3D default dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('3D float32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('3D int32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('3D bool dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('4D float32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('4D int32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('4D bool dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('5D float32 dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('5D int32 dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('5D bool dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('5D default dtype', function () { + var a = tf.tensor5d([1, 2, 3, 4], [1, 2, 2, 1, 1]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('6D int32 dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'int32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('6D bool dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'bool'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysEqual(b, [1, 1, 1, 1]); + }); + it('6D default dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1]); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('6D float32 dtype', function () { + var a = tf.tensor6d([1, 2, 3, 4], [1, 2, 2, 1, 1, 1], 'float32'); + var b = tf.onesLike(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual(a.shape); + test_util_1.expectArraysClose(b, [1, 1, 1, 1]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.onesLike({}); }) + .toThrowError(/Argument 'x' passed to 'onesLike' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.onesLike([[1, 2], [3, 4]]); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(res, [1, 1, 1, 1]); + }); +}); +jasmine_util_1.describeWithFlags('rand', test_util_1.ALL_ENVS, function () { + it('should return a random 1D float32 array', function () { + var shape = [10]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2); + result = tf.rand(shape, function () { return util.randUniform(0, 1.5); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 1D int32 array', function () { + var shape = [10]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2); }, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 1D bool array', function () { + var shape = [10]; + var result = tf.rand(shape, function () { return util.randUniform(0, 1); }, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 2D float32 array', function () { + var shape = [3, 4]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2.5); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.rand(shape, function () { return util.randUniform(0, 1.5); }, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 2D int32 array', function () { + var shape = [3, 4]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2); }, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 2D bool array', function () { + var shape = [3, 4]; + var result = tf.rand(shape, function () { return util.randUniform(0, 1); }, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 3D float32 array', function () { + var shape = [3, 4, 5]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2.5); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.rand(shape, function () { return util.randUniform(0, 1.5); }, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 3D int32 array', function () { + var shape = [3, 4, 5]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2); }, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 3D bool array', function () { + var shape = [3, 4, 5]; + var result = tf.rand(shape, function () { return util.randUniform(0, 1); }, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 4D float32 array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2.5); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.rand(shape, function () { return util.randUniform(0, 1.5); }); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 4D int32 array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.rand(shape, function () { return util.randUniform(0, 2); }, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 4D bool array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.rand(shape, function () { return util.randUniform(0, 1); }, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); +}); +jasmine_util_1.describeWithFlags('eye', test_util_1.ALL_ENVS, function () { + it('1x1', function () { + test_util_1.expectArraysClose(tf.eye(1), tf.tensor2d([[1]])); + }); + it('2x2', function () { + test_util_1.expectArraysClose(tf.eye(2), tf.tensor2d([[1, 0], [0, 1]])); + }); + it('3x3', function () { + test_util_1.expectArraysClose(tf.eye(3), tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1]])); + }); + it('3x4', function () { + test_util_1.expectArraysClose(tf.eye(3, 4), tf.tensor2d([[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 1, 0]])); + }); + it('4x3', function () { + test_util_1.expectArraysClose(tf.eye(4, 3), tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1], [0, 0, 0]])); + }); + it('with 1D batchShape', function () { + test_util_1.expectArraysClose(tf.eye(2, 2, [3]), tf.tensor3d([[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]])); + }); + it('with 2D batchShape', function () { + test_util_1.expectArraysClose(tf.eye(2, 2, [2, 3]), tf.tensor4d([ + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]], + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]] + ])); + }); + it('with 3D batchShape', function () { + test_util_1.expectArraysClose(tf.eye(2, 2, [2, 2, 3]), tf.tensor5d([ + [ + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]], + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]] + ], + [ + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]], + [[[1, 0], [0, 1]], [[1, 0], [0, 1]], [[1, 0], [0, 1]]] + ] + ])); + }); + it('3x3, int32', function () { + test_util_1.expectArraysClose(tf.eye(3, 3, null, 'int32'), tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1]], [3, 3], 'int32')); + }); + it('3x3, bool', function () { + test_util_1.expectArraysClose(tf.eye(3, 3, null, 'bool'), tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1]], [3, 3], 'bool')); + }); +}); +jasmine_util_1.describeWithFlags('randomNormal', test_util_1.ALL_ENVS, function () { + var SEED = 2002; + var EPSILON = 0.05; + it('should return a float32 1D of random normal values', function () { + var SAMPLES = 10000; + var result = tf.randomNormal([SAMPLES], 0, 0.5, null, SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual([SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 0.5, EPSILON); + result = tf.randomNormal([SAMPLES], 0, 1.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual([SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 1.5, EPSILON); + }); + it('should return a int32 1D of random normal values', function () { + var SAMPLES = 10000; + var result = tf.randomNormal([SAMPLES], 0, 2, 'int32', SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2, EPSILON); + }); + it('should return a float32 2D of random normal values', function () { + var SAMPLES = 100; + var result = tf.randomNormal([SAMPLES, SAMPLES], 0, 2.5, null, SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual([SAMPLES, SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2.5, EPSILON); + result = tf.randomNormal([SAMPLES, SAMPLES], 0, 3.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual([SAMPLES, SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 3.5, EPSILON); + }); + it('should return a int32 2D of random normal values', function () { + var SAMPLES = 100; + var result = tf.randomNormal([SAMPLES, SAMPLES], 0, 2, 'int32', SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([SAMPLES, SAMPLES]); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2, EPSILON); + }); + it('should return a float32 3D of random normal values', function () { + var SAMPLES_SHAPE = [20, 20, 20]; + var result = tf.randomNormal(SAMPLES_SHAPE, 0, 0.5, null, SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 0.5, EPSILON); + result = tf.randomNormal(SAMPLES_SHAPE, 0, 1.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 1.5, EPSILON); + }); + it('should return a int32 3D of random normal values', function () { + var SAMPLES_SHAPE = [20, 20, 20]; + var result = tf.randomNormal(SAMPLES_SHAPE, 0, 2, 'int32', SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2, EPSILON); + }); + it('should return a float32 4D of random normal values', function () { + var SAMPLES_SHAPE = [10, 10, 10, 10]; + var result = tf.randomNormal(SAMPLES_SHAPE, 0, 0.5, null, SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 0.5, EPSILON); + result = tf.randomNormal(SAMPLES_SHAPE, 0, 1.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 1.5, EPSILON); + }); + it('should return a int32 4D of random normal values', function () { + var SAMPLES_SHAPE = [10, 10, 10, 10]; + var result = tf.randomNormal(SAMPLES_SHAPE, 0, 2, 'int32', SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2, EPSILON); + }); + it('should return a int32 5D of random normal values', function () { + var SAMPLES_SHAPE = [10, 10, 10, 10, 10]; + var result = tf.randomNormal(SAMPLES_SHAPE, 0, 2, 'int32', SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual(SAMPLES_SHAPE); + rand_util_1.jarqueBeraNormalityTest(result); + rand_util_1.expectArrayInMeanStdRange(result, 0, 2, EPSILON); + }); +}); +jasmine_util_1.describeWithFlags('truncatedNormal', test_util_1.ALL_ENVS, function () { + var EPSILON = 0.60; + var SEED = 2002; + function assertTruncatedValues(array, mean, stdv) { + var bounds = mean + stdv * 2; + var values = array.dataSync(); + for (var i = 0; i < values.length; i++) { + expect(Math.abs(values[i])).toBeLessThanOrEqual(bounds); + } + } + it('should return a random 1D float32 array', function () { + var shape = [1000]; + var result = tf.truncatedNormal(shape, 0, 3.5, null, SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 3.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 3.5, EPSILON); + result = tf.truncatedNormal(shape, 0, 4.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 4.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 4.5, EPSILON); + }); + it('should return a randon 1D int32 array', function () { + var shape = [1000]; + var result = tf.truncatedNormal(shape, 0, 5, 'int32', SEED); + expect(result.dtype).toBe('int32'); + assertTruncatedValues(result, 0, 5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 5, EPSILON); + }); + it('should return a 2D float32 array', function () { + var shape = [50, 50]; + var result = tf.truncatedNormal(shape, 0, 3.5, null, SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 3.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 3.5, EPSILON); + result = tf.truncatedNormal(shape, 0, 4.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 4.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 4.5, EPSILON); + }); + it('should return a 2D int32 array', function () { + var shape = [50, 50]; + var result = tf.truncatedNormal(shape, 0, 5, 'int32', SEED); + expect(result.dtype).toBe('int32'); + assertTruncatedValues(result, 0, 5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 5, EPSILON); + }); + it('should return a 3D float32 array', function () { + var shape = [10, 10, 10]; + var result = tf.truncatedNormal(shape, 0, 3.5, null, SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 3.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 3.5, EPSILON); + result = tf.truncatedNormal(shape, 0, 4.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 4.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 4.5, EPSILON); + }); + it('should return a 3D int32 array', function () { + var shape = [10, 10, 10]; + var result = tf.truncatedNormal(shape, 0, 5, 'int32', SEED); + expect(result.dtype).toBe('int32'); + assertTruncatedValues(result, 0, 5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 5, EPSILON); + }); + it('should return a 4D float32 array', function () { + var shape = [5, 5, 5, 5]; + var result = tf.truncatedNormal(shape, 0, 3.5, null, SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 3.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 3.5, EPSILON); + result = tf.truncatedNormal(shape, 0, 4.5, 'float32', SEED); + expect(result.dtype).toBe('float32'); + assertTruncatedValues(result, 0, 4.5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 4.5, EPSILON); + }); + it('should return a 4D int32 array', function () { + var shape = [5, 5, 5, 5]; + var result = tf.truncatedNormal(shape, 0, 5, 'int32', SEED); + expect(result.dtype).toBe('int32'); + assertTruncatedValues(result, 0, 5); + rand_util_1.expectArrayInMeanStdRange(result, 0, 5, EPSILON); + }); +}); +jasmine_util_1.describeWithFlags('randomUniform', test_util_1.ALL_ENVS, function () { + it('should return a random 1D float32 array', function () { + var shape = [10]; + var result = tf.randomUniform(shape, 0, 2.5); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.randomUniform(shape, 0, 1.5, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 1D int32 array', function () { + var shape = [10]; + var result = tf.randomUniform(shape, 0, 2, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 1D bool array', function () { + var shape = [10]; + var result = tf.randomUniform(shape, 0, 1, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 2D float32 array', function () { + var shape = [3, 4]; + var result = tf.randomUniform(shape, 0, 2.5); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.randomUniform(shape, 0, 1.5, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 2D int32 array', function () { + var shape = [3, 4]; + var result = tf.randomUniform(shape, 0, 2, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 2D bool array', function () { + var shape = [3, 4]; + var result = tf.randomUniform(shape, 0, 1, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 3D float32 array', function () { + var shape = [3, 4, 5]; + var result = tf.randomUniform(shape, 0, 2.5); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.randomUniform(shape, 0, 1.5, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 3D int32 array', function () { + var shape = [3, 4, 5]; + var result = tf.randomUniform(shape, 0, 2, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 3D bool array', function () { + var shape = [3, 4, 5]; + var result = tf.randomUniform(shape, 0, 1, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 4D float32 array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 2.5); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.randomUniform(shape, 0, 1.5, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 4D int32 array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 2, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 4D bool array', function () { + var shape = [3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 1, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); + it('should return a random 5D float32 array', function () { + var shape = [2, 3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 2.5); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 2.5); + result = tf.randomUniform(shape, 0, 1.5, 'float32'); + expect(result.dtype).toBe('float32'); + test_util_1.expectValuesInRange(result, 0, 1.5); + }); + it('should return a random 5D int32 array', function () { + var shape = [2, 3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 2, 'int32'); + expect(result.dtype).toBe('int32'); + test_util_1.expectValuesInRange(result, 0, 2); + }); + it('should return a random 5D bool array', function () { + var shape = [2, 3, 4, 5, 6]; + var result = tf.randomUniform(shape, 0, 1, 'bool'); + expect(result.dtype).toBe('bool'); + test_util_1.expectValuesInRange(result, 0, 1); + }); +}); +var MockContext = (function () { + function MockContext() { + } + MockContext.prototype.getImageData = function (x, y, width, height) { + var data = new Uint8ClampedArray(width * height * 4); + for (var i = 0; i < data.length; ++i) { + data[i] = i + 1; + } + return { data: data }; + }; + return MockContext; +}()); +var MockCanvas = (function () { + function MockCanvas(width, height) { + this.width = width; + this.height = height; + } + MockCanvas.prototype.getContext = function (type) { + return new MockContext(); + }; + return MockCanvas; +}()); +jasmine_util_1.describeWithFlags('fromPixels, mock canvas', test_util_1.NODE_ENVS, function () { + it('accepts a canvas-like element', function () { + var c = new MockCanvas(2, 2); + var t = tf.fromPixels(c); + expect(t.dtype).toBe('int32'); + expect(t.shape).toEqual([2, 2, 3]); + tf.test_util.expectArraysEqual(t, [1, 2, 3, 5, 6, 7, 9, 10, 11, 13, 14, 15]); + }); + it('accepts a canvas-like element, numChannels=4', function () { + var c = new MockCanvas(2, 2); + var t = tf.fromPixels(c, 4); + expect(t.dtype).toBe('int32'); + expect(t.shape).toEqual([2, 2, 4]); + tf.test_util.expectArraysEqual(t, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]); + }); + it('errors when passed a non-canvas object', function () { + expect(function () { return tf.fromPixels(5); }).toThrowError(); + }); +}); +jasmine_util_1.describeWithFlags('fromPixels', test_util_1.BROWSER_ENVS, function () { + it('ImageData 1x1x3', function () { + var pixels = new ImageData(1, 1); + pixels.data[0] = 0; + pixels.data[1] = 80; + pixels.data[2] = 160; + pixels.data[3] = 240; + var array = tf.fromPixels(pixels, 3); + test_util_1.expectArraysEqual(array, [0, 80, 160]); + }); + it('ImageData 1x1x4', function () { + var pixels = new ImageData(1, 1); + pixels.data[0] = 0; + pixels.data[1] = 80; + pixels.data[2] = 160; + pixels.data[3] = 240; + var array = tf.fromPixels(pixels, 4); + test_util_1.expectArraysEqual(array, [0, 80, 160, 240]); + }); + it('ImageData 2x2x3', function () { + var pixels = new ImageData(2, 2); + for (var i = 0; i < 8; i++) { + pixels.data[i] = i * 2; + } + for (var i = 8; i < 16; i++) { + pixels.data[i] = i * 2; + } + var array = tf.fromPixels(pixels, 3); + test_util_1.expectArraysEqual(array, [0, 2, 4, 8, 10, 12, 16, 18, 20, 24, 26, 28]); + }); + it('ImageData 2x2x4', function () { + var pixels = new ImageData(2, 2); + for (var i = 0; i < 8; i++) { + pixels.data[i] = i * 2; + } + for (var i = 8; i < 16; i++) { + pixels.data[i] = i * 2; + } + var array = tf.fromPixels(pixels, 4); + test_util_1.expectArraysClose(array, new Int32Array([0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30])); + }); + it('fromPixels, 3 channels', function () { + var pixels = new ImageData(1, 2); + pixels.data[0] = 2; + pixels.data[1] = 3; + pixels.data[2] = 4; + pixels.data[3] = 255; + pixels.data[4] = 5; + pixels.data[5] = 6; + pixels.data[6] = 7; + pixels.data[7] = 255; + var res = tf.fromPixels(pixels, 3); + expect(res.shape).toEqual([2, 1, 3]); + expect(res.dtype).toBe('int32'); + test_util_1.expectArraysClose(res, [2, 3, 4, 5, 6, 7]); + }); + it('fromPixels, reshape, then do tf.add()', function () { + var pixels = new ImageData(1, 1); + pixels.data[0] = 2; + pixels.data[1] = 3; + pixels.data[2] = 4; + pixels.data[3] = 255; + var a = tf.fromPixels(pixels, 3).reshape([1, 1, 1, 3]); + var res = a.add(tf.scalar(2, 'int32')); + expect(res.shape).toEqual([1, 1, 1, 3]); + expect(res.dtype).toBe('int32'); + test_util_1.expectArraysClose(res, [4, 5, 6]); + }); + it('fromPixels + fromPixels', function () { + var pixelsA = new ImageData(1, 1); + pixelsA.data[0] = 255; + pixelsA.data[1] = 3; + pixelsA.data[2] = 4; + pixelsA.data[3] = 255; + var pixelsB = new ImageData(1, 1); + pixelsB.data[0] = 5; + pixelsB.data[1] = 6; + pixelsB.data[2] = 7; + pixelsB.data[3] = 255; + var a = tf.fromPixels(pixelsA, 3).toFloat(); + var b = tf.fromPixels(pixelsB, 3).toFloat(); + var res = a.add(b); + expect(res.shape).toEqual([1, 1, 3]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [260, 9, 11]); + }); + it('throws when passed a primitive number', function () { + expect(function () { return tf.fromPixels(3); }) + .toThrowError(/pixels passed to tf.fromPixels\(\) must be either/); + }); + it('throws when passed a string', function () { + expect(function () { return tf.fromPixels('test'); }) + .toThrowError(/pixels passed to tf.fromPixels\(\) must be either/); + }); +}); +jasmine_util_1.describeWithFlags('toPixels no canvas', test_util_1.ALL_ENVS, function () { + it('draws a rank-2 float32 tensor', function (done) { + var x = tf.tensor2d([.1, .2], [2, 1], 'float32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.1 * 255), Math.round(.1 * 255), Math.round(.1 * 255), 255, + Math.round(.2 * 255), Math.round(.2 * 255), Math.round(.2 * 255), 255 + ]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-2 int32 tensor', function (done) { + var x = tf.tensor2d([10, 20], [2, 1], 'int32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([10, 10, 10, 255, 20, 20, 20, 255]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 1 channel', function (done) { + var x = tf.tensor3d([.1, .2], [2, 1, 1], 'float32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.1 * 255), Math.round(.1 * 255), Math.round(.1 * 255), 255, + Math.round(.2 * 255), Math.round(.2 * 255), Math.round(.2 * 255), 255 + ]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 1 channel', function (done) { + var x = tf.tensor3d([10, 20], [2, 1, 1], 'int32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([10, 10, 10, 255, 20, 20, 20, 255]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 3 channel', function (done) { + var x = tf.tensor3d([.05, .1, .15, .2, .25, .3], [2, 1, 3], 'float32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.05 * 255), Math.round(.1 * 255), Math.round(.15 * 255), 255, + Math.round(.2 * 255), Math.round(.25 * 255), Math.round(.30 * 255), 255 + ]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 3 channel', function (done) { + var x = tf.tensor3d([10, 20, 30, 40, 50, 60], [2, 1, 3], 'int32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([10, 20, 30, 255, 40, 50, 60, 255]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 4 channel', function (done) { + var x = tf.tensor3d([.05, .1, .15, .2, .25, .3, .35, .4], [2, 1, 4], 'float32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.05 * 255), Math.round(.1 * 255), Math.round(.15 * 255), + Math.round(.20 * 255), Math.round(.25 * 255), Math.round(.30 * 255), + Math.round(.35 * 255), Math.round(.4 * 255) + ]); + expect(data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 4 channel', function (done) { + var x = tf.tensor3d([10, 20, 30, 40, 50, 60, 70, 80], [2, 1, 4], 'int32'); + tf.toPixels(x).then(function (data) { + var expected = new Uint8ClampedArray([10, 20, 30, 40, 50, 60, 70, 80]); + expect(data).toEqual(expected); + done(); + }); + }); + it('throws for scalars', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.scalar(1)); }, done); + }); + it('throws for rank-1 tensors', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor1d([1])); }, done); + }); + it('throws for rank-4 tensors', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor4d([1], [1, 1, 1, 1])); }, done); + }); + it('throws for bool dtype', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor2d([1], [1, 1], 'bool')); }, done); + }); + it('throws for rank-3 depth = 2', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor3d([1, 2], [1, 1, 2])); }, done); + }); + it('throws for rank-3 depth = 5', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor3d([1, 2, 3, 4, 5], [1, 1, 5])); }, done); + }); + it('throws for float32 tensor with values not in [0 - 1]', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor2d([-1, .5], [1, 2])); }, done); + }); + it('throws for int32 tensor with values not in [0 - 255]', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels(tf.tensor2d([-1, 100], [1, 2], 'int32')); }, done); + }); + it('throws when passed a non-tensor', function (done) { + test_util_1.expectPromiseToFail(function () { return tf.toPixels({}); }, done); + }); + it('accepts a tensor-like object', function () { return __awaiter(_this, void 0, void 0, function () { + var x, data, expected; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + x = [[10], [20]]; + return [4, tf.toPixels(x)]; + case 1: + data = _a.sent(); + expected = new Uint8ClampedArray([10, 10, 10, 255, 20, 20, 20, 255]); + expect(data).toEqual(expected); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('toPixels', test_util_1.WEBGL_ENVS, function () { + it('draws a rank-2 float32 tensor, canvas', function (done) { + var x = tf.tensor2d([.1, .2], [2, 1], 'float32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.1 * 255), Math.round(.1 * 255), Math.round(.1 * 255), 255, + Math.round(.2 * 255), Math.round(.2 * 255), Math.round(.2 * 255), 255 + ]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-2 int32 tensor, canvas', function (done) { + var x = tf.tensor2d([10, 20], [2, 1], 'int32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([10, 10, 10, 255, 20, 20, 20, 255]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 1 channel, canvas', function (done) { + var x = tf.tensor3d([.1, .2], [2, 1, 1], 'float32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.1 * 255), Math.round(.1 * 255), Math.round(.1 * 255), 255, + Math.round(.2 * 255), Math.round(.2 * 255), Math.round(.2 * 255), 255 + ]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 1 channel, canvas', function (done) { + var x = tf.tensor3d([10, 20], [2, 1, 1], 'int32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([10, 10, 10, 255, 20, 20, 20, 255]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 3 channel, canvas', function (done) { + var x = tf.tensor3d([.05, .1, .15, .20, .25, .30], [2, 1, 3], 'float32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.05 * 255), Math.round(.1 * 255), Math.round(.15 * 255), 255, + Math.round(.2 * 255), Math.round(.25 * 255), Math.round(.3 * 255), 255 + ]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 3 channel, canvas', function (done) { + var x = tf.tensor3d([10, 20, 30, 40, 50, 60], [2, 1, 3], 'int32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([10, 20, 30, 255, 40, 50, 60, 255]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 float32 tensor, 4 channel, canvas', function (done) { + var x = tf.tensor3d([.05, .1, .15, 1, .20, .25, .30, 1], [2, 1, 4], 'float32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([ + Math.round(.05 * 255), Math.round(.1 * 255), Math.round(.15 * 255), 255, + Math.round(.20 * 255), Math.round(.25 * 255), Math.round(.30 * 255), 255 + ]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('draws a rank-3 int32 tensor, 4 channel, canvas', function (done) { + var x = tf.tensor3d([10, 20, 30, 255, 50, 60, 70, 255], [2, 1, 4], 'int32'); + var canvas = document.createElement('canvas'); + tf.toPixels(x, canvas).then(function (data) { + var expected = new Uint8ClampedArray([10, 20, 30, 255, 50, 60, 70, 255]); + expect(data).toEqual(expected); + var ctx = canvas.getContext('2d'); + var imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + done(); + }); + }); + it('accepts a tensor-like object', function () { return __awaiter(_this, void 0, void 0, function () { + var x, canvas, data, expected, ctx, imgData; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + x = [[127], [100]]; + canvas = document.createElement('canvas'); + return [4, tf.toPixels(x, canvas)]; + case 1: + data = _a.sent(); + expected = new Uint8ClampedArray([127, 127, 127, 255, 100, 100, 100, 255]); + expect(data).toEqual(expected); + ctx = canvas.getContext('2d'); + imgData = ctx.getImageData(0, 0, 1, 2); + expect(imgData.data).toEqual(expected); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('clone', test_util_1.ALL_ENVS, function () { + it('1D default dtype', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [1, 2, 3]); + }); + it('1D float32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'float32'); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysClose(b, [1, 2, 3]); + }); + it('1D int32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + var b = tf.clone(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [1, 2, 3]); + }); + it('1D bool dtype', function () { + var a = tf.tensor1d([1, 1, 0], 'bool'); + var b = tf.clone(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([3]); + test_util_1.expectArraysEqual(b, [1, 1, 0]); + }); + it('2D default dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('2D float32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'float32'); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('2D int32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var b = tf.clone(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [1, 2, 3, 4]); + }); + it('2D bool dtype', function () { + var a = tf.tensor2d([1, 1, 1, 0], [2, 2], 'bool'); + var b = tf.clone(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 0]); + }); + it('3D default dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('3D float32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'float32'); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('3D int32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1], 'int32'); + var b = tf.clone(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [1, 2, 3, 4]); + }); + it('3D bool dtype', function () { + var a = tf.tensor3d([1, 1, 1, 0], [2, 2, 1], 'bool'); + var b = tf.clone(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 0]); + }); + it('4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('4D float32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'float32'); + var b = tf.clone(a); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('4D int32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1], 'int32'); + var b = tf.clone(a); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 2, 3, 4]); + }); + it('4D bool dtype', function () { + var a = tf.tensor4d([1, 1, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.clone(a); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(b, [1, 1, 1, 0]); + }); + it('gradient: 1D', function () { + var a = tf.tensor1d([1, 2, 3]); + var dy = tf.tensor1d([4, 5, 6]); + var da = tf.grad(function (x) { return tf.clone(x); })(a, dy); + expect(da.dtype).toBe('float32'); + expect(da.shape).toEqual([3]); + test_util_1.expectArraysClose(da, [4, 5, 6]); + }); + it('gradient: 2D int32', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var dy = tf.tensor2d([5, 6, 7, 8], [2, 2], 'float32'); + var da = tf.grad(function (x) { return tf.clone(x); })(a, dy); + expect(da.dtype).toBe('float32'); + expect(da.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(da, [5, 6, 7, 8]); + }); + it('gradient: 4D bool', function () { + var a = tf.tensor4d([1, 1, 1, 0], [2, 2, 1, 1], 'bool'); + var dy = tf.tensor4d([5, 6, 7, 8], [2, 2, 1, 1], 'float32'); + var da = tf.grad(function (x) { return tf.clone(x); })(a, dy); + expect(da.dtype).toBe('float32'); + expect(da.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(da, [5, 6, 7, 8]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.clone({}); }) + .toThrowError(/Argument 'x' passed to 'clone' must be a Tensor/); + }); +}); +jasmine_util_1.describeWithFlags('tile', test_util_1.ALL_ENVS, function () { + it('1D (tile)', function () { + var t = tf.tensor1d([1, 2, 3]); + var t2 = tf.tile(t, [2]); + expect(t2.shape).toEqual([6]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 1, 2, 3]); + }); + it('2D (tile)', function () { + var t = tf.tensor2d([1, 11, 2, 22], [2, 2]); + var t2 = tf.tile(t, [1, 2]); + expect(t2.shape).toEqual([2, 4]); + test_util_1.expectArraysClose(t2, [1, 11, 1, 11, 2, 22, 2, 22]); + t2 = tf.tile(t, [2, 1]); + expect(t2.shape).toEqual([4, 2]); + test_util_1.expectArraysClose(t2, [1, 11, 2, 22, 1, 11, 2, 22]); + t2 = tf.tile(t, [2, 2]); + expect(t2.shape).toEqual([4, 4]); + test_util_1.expectArraysClose(t2, [1, 11, 1, 11, 2, 22, 2, 22, 1, 11, 1, 11, 2, 22, 2, 22]); + }); + it('3D (tile)', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var t2 = tf.tile(t, [1, 2, 1]); + expect(t2.shape).toEqual([2, 4, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 1, 2, 3, 4, 5, 6, 7, 8, 5, 6, 7, 8]); + }); + it('4D (tile)', function () { + var t = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [1, 2, 2, 2]); + var t2 = tf.tile(t, [1, 2, 1, 1]); + expect(t2.shape).toEqual([1, 4, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 5, 6, 7, 8, 1, 2, 3, 4, 5, 6, 7, 8]); + }); + it('5D (tile)', function () { + var t = tf.tensor5d([1, 2, 3, 4, 5, 6, 7, 8], [1, 1, 2, 2, 2]); + var t2 = tf.tile(t, [1, 2, 1, 1, 1]); + expect(t2.shape).toEqual([1, 2, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 5, 6, 7, 8, 1, 2, 3, 4, 5, 6, 7, 8]); + }); + it('propagates NaNs', function () { + var t = tf.tensor1d([1, 2, NaN]); + var t2 = tf.tile(t, [2]); + expect(t2.shape).toEqual([6]); + test_util_1.expectArraysClose(t2, [1, 2, NaN, 1, 2, NaN]); + }); + it('1D bool (tile)', function () { + var t = tf.tensor1d([true, false, true], 'bool'); + var t2 = tf.tile(t, [2]); + expect(t2.shape).toEqual([6]); + expect(t2.dtype).toBe('bool'); + test_util_1.expectArraysEqual(t2, [1, 0, 1, 1, 0, 1]); + }); + it('2D bool (tile)', function () { + var t = tf.tensor2d([true, false, true, true], [2, 2], 'bool'); + var t2 = tf.tile(t, [1, 2]); + expect(t2.shape).toEqual([2, 4]); + expect(t2.dtype).toBe('bool'); + test_util_1.expectArraysEqual(t2, [1, 0, 1, 0, 1, 1, 1, 1]); + t2 = tf.tile(t, [2, 1]); + expect(t2.shape).toEqual([4, 2]); + expect(t2.dtype).toBe('bool'); + test_util_1.expectArraysEqual(t2, [1, 0, 1, 1, 1, 0, 1, 1]); + t2 = tf.tile(t, [2, 2]); + expect(t2.shape).toEqual([4, 4]); + expect(t2.dtype).toBe('bool'); + test_util_1.expectArraysEqual(t2, [1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 1, 1, 1]); + }); + it('3D bool (tile)', function () { + var t = tf.tensor3d([true, false, true, false, true, false, true, false], [2, 2, 2], 'bool'); + var t2 = tf.tile(t, [1, 2, 1]); + expect(t2.shape).toEqual([2, 4, 2]); + expect(t2.dtype).toBe('bool'); + test_util_1.expectArraysEqual(t2, [1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0]); + }); + it('1D int32 (tile)', function () { + var t = tf.tensor1d([1, 2, 5], 'int32'); + var t2 = tf.tile(t, [2]); + expect(t2.shape).toEqual([6]); + expect(t2.dtype).toBe('int32'); + test_util_1.expectArraysEqual(t2, [1, 2, 5, 1, 2, 5]); + }); + it('2D int32 (tile)', function () { + var t = tf.tensor2d([1, 2, 3, 4], [2, 2], 'int32'); + var t2 = tf.tile(t, [1, 2]); + expect(t2.shape).toEqual([2, 4]); + expect(t2.dtype).toBe('int32'); + test_util_1.expectArraysEqual(t2, [1, 2, 1, 2, 3, 4, 3, 4]); + t2 = tf.tile(t, [2, 1]); + expect(t2.shape).toEqual([4, 2]); + expect(t2.dtype).toBe('int32'); + test_util_1.expectArraysEqual(t2, [1, 2, 3, 4, 1, 2, 3, 4]); + t2 = tf.tile(t, [2, 2]); + expect(t2.shape).toEqual([4, 4]); + expect(t2.dtype).toBe('int32'); + test_util_1.expectArraysEqual(t2, [1, 2, 1, 2, 3, 4, 3, 4, 1, 2, 1, 2, 3, 4, 3, 4]); + }); + it('3D int32 (tile)', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2], 'int32'); + var t2 = tf.tile(t, [1, 2, 1]); + expect(t2.shape).toEqual([2, 4, 2]); + expect(t2.dtype).toBe('int32'); + test_util_1.expectArraysEqual(t2, [1, 2, 3, 4, 1, 2, 3, 4, 5, 6, 7, 8, 5, 6, 7, 8]); + }); + it('1D (tile) gradient', function () { + var x = tf.tensor1d([1, 2, 3]); + var dy = tf.tensor1d([0.1, 0.2, 0.3, 1, 2, 3, 10, 20, 30]); + var gradients = tf.grad(function (x) { return tf.tile(x, [3]); })(x, dy); + test_util_1.expectArraysClose(gradients, tf.tensor1d([11.1, 22.2, 33.3])); + }); + it('2D (tile) gradient', function () { + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var dy = tf.tensor2d([[1, 2, 10, 20], [3, 4, 30, 40]], [2, 4]); + var gradients = tf.grad(function (x) { return tf.tile(x, [1, 2]); })(x, dy); + test_util_1.expectArraysClose(gradients, tf.tensor2d([[11, 22], [33, 44]], [2, 2])); + }); + it('3D (tile) gradient', function () { + var x = tf.tensor3d([[[1], [2]], [[3], [4]]], [2, 2, 1]); + var dy = tf.tensor3d([[[1, 10], [2, 20]], [[3, 30], [4, 40]]], [2, 2, 2]); + var gradients = tf.grad(function (x) { return tf.tile(x, [1, 1, 2]); })(x, dy); + test_util_1.expectArraysClose(gradients, tf.tensor3d([[[11], [22]], [[33], [44]]], [2, 2, 1])); + }); + it('4D (tile) gradient', function () { + var x = tf.tensor4d([[[[1]], [[2]]], [[[3]], [[4]]]], [2, 2, 1, 1]); + var dy = tf.tensor4d([ + [[[.01, .1], [1, 10]], [[.02, .2], [2, 20]]], + [[[.03, .3], [3, 30]], [[.04, .4], [4, 40]]] + ], [2, 2, 2, 2]); + var gradients = tf.grad(function (x) { return tf.tile(x, [1, 1, 2, 2]); })(x, dy); + test_util_1.expectArraysClose(gradients, tf.tensor4d([[[[11.11]], [[22.22]]], [[[33.33]], [[44.44]]]], [2, 2, 1, 1])); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.tile({}, [1]); }) + .toThrowError(/Argument 'x' passed to 'tile' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.tile([1, 2, 3], [2]); + expect(res.shape).toEqual([6]); + test_util_1.expectArraysClose(res, [1, 2, 3, 1, 2, 3]); + }); +}); +jasmine_util_1.describeWithFlags('gather', test_util_1.ALL_ENVS, function () { + it('1D (gather)', function () { + var t = tf.tensor1d([1, 2, 3]); + var t2 = tf.gather(t, tf.tensor1d([0, 2, 0, 1], 'int32'), 0); + expect(t2.shape).toEqual([4]); + test_util_1.expectArraysClose(t2, [1, 3, 1, 2]); + }); + it('2D (gather)', function () { + var t = tf.tensor2d([1, 11, 2, 22], [2, 2]); + var t2 = tf.gather(t, tf.tensor1d([1, 0, 0, 1], 'int32'), 0); + expect(t2.shape).toEqual([4, 2]); + test_util_1.expectArraysClose(t2, [2, 22, 1, 11, 1, 11, 2, 22]); + t2 = tf.gather(t, tf.tensor1d([1, 0, 0, 1], 'int32'), 1); + expect(t2.shape).toEqual([2, 4]); + test_util_1.expectArraysClose(t2, [11, 1, 1, 11, 22, 2, 2, 22]); + }); + it('3D (gather)', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var t2 = tf.gather(t, tf.tensor1d([1, 0, 0, 1], 'int32'), 2); + expect(t2.shape).toEqual([2, 2, 4]); + test_util_1.expectArraysClose(t2, [2, 1, 1, 2, 4, 3, 3, 4, 6, 5, 5, 6, 8, 7, 7, 8]); + }); + it('bool (gather)', function () { + var t = tf.tensor1d([true, false, true], 'bool'); + var t2 = tf.gather(t, tf.tensor1d([0, 2, 0, 1], 'int32'), 0); + expect(t2.shape).toEqual([4]); + expect(t2.dtype).toBe('bool'); + expect(t2.dataSync()).toEqual(new Uint8Array([1, 1, 1, 0])); + }); + it('int32 (gather)', function () { + var t = tf.tensor1d([1, 2, 5], 'int32'); + var t2 = tf.gather(t, tf.tensor1d([0, 2, 0, 1], 'int32'), 0); + expect(t2.shape).toEqual([4]); + expect(t2.dtype).toBe('int32'); + expect(t2.dataSync()).toEqual(new Int32Array([1, 5, 1, 2])); + }); + it('propagates NaNs', function () { + var t = tf.tensor1d([1, 2, NaN]); + var t2 = tf.gather(t, tf.tensor1d([0, 2, 0, 1], 'int32'), 0); + expect(t2.shape).toEqual([4]); + test_util_1.expectArraysClose(t2, [1, NaN, 1, 2]); + }); + it('chaining, axis=1', function () { + var x = tf.zeros([2, 4, 6]); + var indices = tf.range(0, 6, 2, 'int32'); + var axis = 2; + expect(x.gather(indices, axis).shape).toEqual([2, 4, 3]); + }); + it('indices not int32 throws error', function () { + var x = tf.zeros([2, 4, 6]); + var indices = tf.range(0, 6, 2); + var axis = 2; + expect(function () { return x.gather(indices, axis); }).toThrowError(); + }); + it('throws when passed x as a non-tensor', function () { + expect(function () { return tf.gather({}, tf.tensor1d([1])); }) + .toThrowError(/Argument 'x' passed to 'gather' must be a Tensor/); + }); + it('throws when passed indices as a non-tensor', function () { + expect(function () { return tf.gather(tf.tensor1d([1]), {}); }) + .toThrowError(/Argument 'indices' passed to 'gather' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.gather([1, 2, 3], [0, 2, 0, 1], 0); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [1, 3, 1, 2]); + }); + it('gradient 1D (gather)', function () { + var t = tf.tensor1d([1, 2, 3]); + var indices = tf.tensor1d([0, 2, 0, 1], 'int32'); + var dy = tf.tensor([3, 4, 5, 6]); + var gradients = tf.grad(function (t) { return tf.gather(t, indices); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [8, 6, 4]); + }); + it('gradient 2D (gather) axis=0 shape=[2, 2]', function () { + var t = tf.tensor2d([1, 11, 2, 22], [2, 2]); + var indices = tf.tensor1d([1, 0, 0, 1], 'int32'); + var dy = tf.tensor([3, 4, 5, 6, 7, 8, 9, 10], [4, 2]); + var axis = 0; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [12, 14, 12, 14]); + }); + it('gradient 2D (gather) axis=0 shape=[4, 1]', function () { + var t = tf.tensor2d([1, 11, 2, 22], [4, 1]); + var indices = tf.tensor1d([1, 0, 0, 1], 'int32'); + var dy = tf.tensor([23, 7, 19, 13], [4, 1]); + var axis = 0; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [26, 36, 0, 0]); + }); + it('gradient 2D (gather) axis=1 shape=[2, 2]', function () { + var t = tf.tensor2d([1, 11, 2, 22], [2, 2]); + var indices = tf.tensor1d([1, 0, 0, 1], 'int32'); + var dy = tf.tensor([3, 4, 5, 6, 7, 8, 9, 10], [2, 4]); + var axis = 1; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [9, 9, 17, 17]); + }); + it('gradient 2D (gather) axis=1 shape=[4, 1]', function () { + var t = tf.tensor2d([1, 11, 2, 22], [4, 1]); + var indices = tf.tensor1d([0, 0, 0, 0], 'int32'); + var dy = tf.tensor([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18], [4, 4]); + var axis = 1; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [18, 34, 50, 66]); + }); + it('gradient 3D (gather) axis=0 shape=[2, 3, 2]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var indices = tf.tensor1d([1, 0, 0, 1], 'int32'); + var dy = tf.tensor([ + 2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 12, 13, + 4, 15, 12, -7, 18, 19, 2, 21, 6, 23, 24, 25 + ], [4, 3, 2]); + var axis = 0; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [5, 33, 12.01, -7, 30, 32, 4, 18, 10, 38, 30, 25.7]); + }); + it('gradient 3D (gather) axis=0 shape=[1, 4, 4]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], [1, 4, 4]); + var indices = tf.tensor1d([0, 0], 'int32'); + var dy = tf.tensor([ + 2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 12, 13, 4, 15, 12, -7, + 18, 19, 2, 21, 6, 23, 24, 25, 101, 31, 34, 54, 1, 0, -3, -4 + ], [2, 4, 4]); + var axis = 0; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [20, 16, 6, 36, 12, 23.7, 25, 43, 101.01, 31, 46, 67, 5, 15, 9, -11]); + }); + it('gradient 3D (gather) axis=1 shape=[2, 3, 2]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var indices = tf.tensor1d([1, 2, 2, 1], 'int32'); + var dy = tf.tensor([2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 12, 13, 4, 15, 12, -7], [2, 4, 2]); + var axis = 1; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [0, 0, 3, 15, 10, 15.7, 0, 0, 12.01, -7, 16, 28]); + }); + it('gradient 3D (gather) axis=1 shape=[1, 4, 4]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], [1, 4, 4]); + var indices = tf.tensor1d([1, 2, 2, 1], 'int32'); + var dy = tf.tensor([2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 12, 13, 4, 15, 12, -7], [1, 4, 4]); + var axis = 1; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0, 6, 12, 16, 8, 6.01, .7, 13, 31, 0, 0, 0, 0]); + }); + it('gradient 3D (gather) axis=2 shape=[2, 3, 2]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var indices = tf.tensor1d([1, 0, 1, 0], 'int32'); + var dy = tf.tensor([ + 2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 12, 13, + 4, 15, 12, -7, 18, 19, 2, 21, 6, 23, 24, 25 + ], [2, 3, 4]); + var axis = 2; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [12, 6, 18.7, 7, 13, 12.01, 8, 16, 40, 20, 48, 30]); + }); + it('gradient 3D (gather) axis=2 shape=[4, 1, 4]', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], [4, 1, 4]); + var indices = tf.tensor1d([1, 3, 1], 'int32'); + var dy = tf.tensor([2, -3, 4, 15, 6, 0.7, 1, 18, 0.01, 0, 4, 15], [4, 1, 3]); + var axis = 2; + var gradients = tf.grad(function (t) { return tf.gather(t, indices, axis); })(t, dy); + expect(gradients.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradients, [0, 6, 0, -3, 0, 15.7, 0, 6, 0, 1.01, 0, 18, 0, 15, 0, 4]); + }); +}); +jasmine_util_1.describeWithFlags('oneHot', test_util_1.ALL_ENVS, function () { + it('Depth 1 throws error', function () { + var indices = tf.tensor1d([0, 0, 0], 'int32'); + expect(function () { return tf.oneHot(indices, 1); }).toThrowError(); + }); + it('Depth 2, diagonal', function () { + var indices = tf.tensor1d([0, 1], 'int32'); + var res = tf.oneHot(indices, 2); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [1, 0, 0, 1]); + }); + it('Depth 2, transposed diagonal', function () { + var indices = tf.tensor1d([1, 0], 'int32'); + var res = tf.oneHot(indices, 2); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [0, 1, 1, 0]); + }); + it('Depth 3, 4 events', function () { + var indices = tf.tensor1d([2, 1, 2, 0], 'int32'); + var res = tf.oneHot(indices, 3); + expect(res.shape).toEqual([4, 3]); + test_util_1.expectArraysClose(res, [0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0]); + }); + it('Out of range events do not trigger onValue', function () { + var indices = tf.tensor1d([-1, 5, 12345], 'int32'); + var res = tf.oneHot(indices, 5); + expect(res.shape).toEqual([3, 5]); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]); + }); + it('Depth 2 onValue=3, offValue=-2', function () { + var indices = tf.tensor1d([0, 1], 'int32'); + var res = tf.oneHot(indices, 2, 3, -2); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [3, -2, -2, 3]); + }); + it('indices not int32 throws error', function () { + var indices = tf.tensor1d([0, 1], 'float32'); + expect(function () { return tf.oneHot(indices, 2); }).toThrowError(); + }); + it('check output dtype', function () { + var expectedType = 'int32'; + var indices = tf.tensor1d([0, 1], 'int32'); + var res = tf.oneHot(indices, 2); + expect(res.dtype).toEqual(expectedType); + }); + it('oneHot accepts a tensor-like object', function () { + var res = tf.oneHot([0, 1], 2); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [1, 0, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('linspace', test_util_1.ALL_ENVS, function () { + it('start stop', function () { + var a = tf.linspace(1, 10, 10); + test_util_1.expectArraysEqual(a, [1., 2., 3., 4., 5., 6., 7., 8., 9., 10.]); + expect(a.shape).toEqual([10]); + var b = tf.linspace(12, 17, 8); + test_util_1.expectArraysClose(b, [ + 12., 12.71428571, 13.42857143, 14.14285714, 14.85714286, 15.57142857, + 16.28571429, 17. + ]); + expect(b.shape).toEqual([8]); + var c = tf.linspace(9, 0, 6); + test_util_1.expectArraysClose(c, [9., 7.2, 5.4, 3.6, 1.8, 0.]); + expect(c.shape).toEqual([6]); + }); + it('negative start stop', function () { + var a = tf.linspace(-4, 5, 6); + test_util_1.expectArraysClose(a, [-4., -2.2, -0.4, 1.4, 3.2, 5.]); + expect(a.shape).toEqual([6]); + }); + it('start negative stop', function () { + var a = tf.linspace(4, -5, 6); + test_util_1.expectArraysClose(a, [4., 2.2, 0.4, -1.4, -3.2, -5.]); + expect(a.shape).toEqual([6]); + }); + it('negative start negative stop', function () { + var a = tf.linspace(-4, -5, 6); + test_util_1.expectArraysClose(a, [-4., -4.2, -4.4, -4.6, -4.8, -5.]); + expect(a.shape).toEqual([6]); + var b = tf.linspace(-9, -4, 5); + test_util_1.expectArraysClose(b, [-9., -7.75, -6.5, -5.25, -4.]); + expect(b.shape).toEqual([5]); + }); + it('should throw with no samples', function () { + expect(function () { return tf.linspace(2, 10, 0); }).toThrow(); + }); +}); +jasmine_util_1.describeWithFlags('range', test_util_1.ALL_ENVS, function () { + it('start stop', function () { + var a = tf.range(0, 3); + test_util_1.expectArraysEqual(a, [0, 1, 2]); + expect(a.shape).toEqual([3]); + var b = tf.range(3, 8); + test_util_1.expectArraysEqual(b, [3, 4, 5, 6, 7]); + expect(b.shape).toEqual([5]); + }); + it('start stop negative', function () { + var a = tf.range(-2, 3); + test_util_1.expectArraysEqual(a, [-2, -1, 0, 1, 2]); + expect(a.shape).toEqual([5]); + var b = tf.range(4, -2); + test_util_1.expectArraysEqual(b, [4, 3, 2, 1, 0, -1]); + expect(b.shape).toEqual([6]); + }); + it('start stop step', function () { + var a = tf.range(4, 15, 4); + test_util_1.expectArraysEqual(a, [4, 8, 12]); + expect(a.shape).toEqual([3]); + var b = tf.range(4, 11, 4); + test_util_1.expectArraysEqual(b, [4, 8]); + expect(b.shape).toEqual([2]); + var c = tf.range(4, 17, 4); + test_util_1.expectArraysEqual(c, [4, 8, 12, 16]); + expect(c.shape).toEqual([4]); + var d = tf.range(0, 30, 5); + test_util_1.expectArraysEqual(d, [0, 5, 10, 15, 20, 25]); + expect(d.shape).toEqual([6]); + var e = tf.range(-3, 9, 2); + test_util_1.expectArraysEqual(e, [-3, -1, 1, 3, 5, 7]); + expect(e.shape).toEqual([6]); + var f = tf.range(3, 3); + test_util_1.expectArraysEqual(f, new Float32Array(0)); + expect(f.shape).toEqual([0]); + var g = tf.range(3, 3, 1); + test_util_1.expectArraysEqual(g, new Float32Array(0)); + expect(g.shape).toEqual([0]); + var h = tf.range(3, 3, 4); + test_util_1.expectArraysEqual(h, new Float32Array(0)); + expect(h.shape).toEqual([0]); + var i = tf.range(-18, -2, 5); + test_util_1.expectArraysEqual(i, [-18, -13, -8, -3]); + expect(i.shape).toEqual([4]); + }); + it('start stop large step', function () { + var a = tf.range(3, 10, 150); + test_util_1.expectArraysEqual(a, [3]); + expect(a.shape).toEqual([1]); + var b = tf.range(10, 500, 205); + test_util_1.expectArraysEqual(b, [10, 215, 420]); + expect(b.shape).toEqual([3]); + var c = tf.range(3, -10, -150); + test_util_1.expectArraysEqual(c, [3]); + expect(c.shape).toEqual([1]); + var d = tf.range(-10, -500, -205); + test_util_1.expectArraysEqual(d, [-10, -215, -420]); + expect(d.shape).toEqual([3]); + }); + it('start stop negative step', function () { + var a = tf.range(0, -10, -1); + test_util_1.expectArraysEqual(a, [0, -1, -2, -3, -4, -5, -6, -7, -8, -9]); + expect(a.shape).toEqual([10]); + var b = tf.range(0, -10); + test_util_1.expectArraysEqual(b, [0, -1, -2, -3, -4, -5, -6, -7, -8, -9]); + expect(b.shape).toEqual([10]); + var c = tf.range(3, -4, -2); + test_util_1.expectArraysEqual(c, [3, 1, -1, -3]); + expect(c.shape).toEqual([4]); + var d = tf.range(-3, -18, -5); + test_util_1.expectArraysEqual(d, [-3, -8, -13]); + expect(d.shape).toEqual([3]); + }); + it('start stop incompatible step', function () { + var a = tf.range(3, 10, -2); + test_util_1.expectArraysEqual(a, new Float32Array(0)); + expect(a.shape).toEqual([0]); + var b = tf.range(40, 3, 2); + test_util_1.expectArraysEqual(b, new Float32Array(0)); + expect(b.shape).toEqual([0]); + }); + it('zero step', function () { + expect(function () { return tf.range(2, 10, 0); }).toThrow(); + }); + it('should have default dtype', function () { + var a = tf.range(1, 4); + test_util_1.expectArraysEqual(a, [1, 2, 3]); + expect(a.dtype).toEqual('float32'); + expect(a.shape).toEqual([3]); + }); + it('should have float32 dtype', function () { + var a = tf.range(1, 4, undefined, 'float32'); + test_util_1.expectArraysEqual(a, [1, 2, 3]); + expect(a.dtype).toEqual('float32'); + expect(a.shape).toEqual([3]); + }); + it('should have int32 dtype', function () { + var a = tf.range(1, 4, undefined, 'int32'); + test_util_1.expectArraysEqual(a, [1, 2, 3]); + expect(a.dtype).toEqual('int32'); + expect(a.shape).toEqual([3]); + }); +}); +jasmine_util_1.describeWithFlags('fill', test_util_1.ALL_ENVS, function () { + it('1D fill', function () { + var a = tf.fill([3], 2); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [2, 2, 2]); + }); + it('2D fill', function () { + var a = tf.fill([3, 2], 2); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(a, [2, 2, 2, 2, 2, 2]); + }); + it('3D fill', function () { + var a = tf.fill([3, 2, 1], 2); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1]); + test_util_1.expectArraysClose(a, [2, 2, 2, 2, 2, 2]); + }); + it('4D fill', function () { + var a = tf.fill([3, 2, 1, 2], 2); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3, 2, 1, 2]); + test_util_1.expectArraysClose(a, [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2]); + }); + it('5D fill', function () { + var a = tf.fill([2, 1, 2, 1, 2], 2); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 1, 2, 1, 2]); + test_util_1.expectArraysClose(a, [2, 2, 2, 2, 2, 2, 2, 2]); + }); +}); +jasmine_util_1.describeWithFlags('stack', test_util_1.ALL_ENVS, function () { + it('scalars 3, 5 and 7', function () { + var a = tf.scalar(3); + var b = tf.scalar(5); + var c = tf.scalar(7); + var res = tf.stack([a, b, c]); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [3, 5, 7]); + }); + it('scalars 3, 5 and 7 along axis=1 throws error', function () { + var a = tf.scalar(3); + var b = tf.scalar(5); + var c = tf.scalar(7); + var f = function () { return tf.stack([a, b, c], 1); }; + expect(f).toThrowError(); + }); + it('non matching shapes throws error', function () { + var a = tf.scalar(3); + var b = tf.tensor1d([5]); + var f = function () { return tf.stack([a, b]); }; + expect(f).toThrowError(); + }); + it('non matching dtypes throws error', function () { + var a = tf.scalar(3); + var b = tf.scalar(5, 'bool'); + var f = function () { return tf.stack([a, b]); }; + expect(f).toThrowError(); + }); + it('2d but axis=3 throws error', function () { + var a = tf.zeros([2, 2]); + var b = tf.zeros([2, 2]); + var f = function () { return tf.stack([a, b], 3); }; + expect(f).toThrowError(); + }); + it('[1,2], [3,4] and [5,6], axis=0', function () { + var a = tf.tensor1d([1, 2]); + var b = tf.tensor1d([3, 4]); + var c = tf.tensor1d([5, 6]); + var res = tf.stack([a, b, c], 0); + expect(res.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('[1,2], [3,4] and [5,6], axis=1', function () { + var a = tf.tensor1d([1, 2]); + var b = tf.tensor1d([3, 4]); + var c = tf.tensor1d([5, 6]); + var res = tf.stack([a, b, c], 1); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [1, 3, 5, 2, 4, 6]); + }); + it('[[1,2],[3,4]] and [[5, 6], [7, 8]], axis=0', function () { + var a = tf.tensor2d([[1, 2], [3, 4]]); + var b = tf.tensor2d([[5, 6], [7, 8]]); + var res = tf.stack([a, b], 0); + expect(res.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6, 7, 8]); + }); + it('[[1,2],[3,4]] and [[5, 6], [7, 8]], axis=2', function () { + var a = tf.tensor2d([[1, 2], [3, 4]]); + var b = tf.tensor2d([[5, 6], [7, 8]]); + var c = tf.tensor2d([[9, 10], [11, 12]]); + var res = tf.stack([a, b, c], 2); + expect(res.shape).toEqual([2, 2, 3]); + test_util_1.expectArraysClose(res, [1, 5, 9, 2, 6, 10, 3, 7, 11, 4, 8, 12]); + }); + it('single tensor', function () { + var a = tf.tensor2d([[1, 2], [3, 4]]); + var res = tf.stack([a], 2); + expect(res.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.stack([{}]); }) + .toThrowError(/Argument 'tensors\[0\]' passed to 'stack' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[1, 2], [3, 4]]; + var res = tf.stack([a], 2); + expect(res.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); +}); +jasmine_util_1.describeWithFlags('unstack', test_util_1.ALL_ENVS, function () { + it('unstack by default', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var res = tf.unstack(x); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(1); + expect(res[0].shape).toEqual([4]); + test_util_1.expectArraysClose(res[0], [1, 2, 3, 4]); + expect(res[1].rank).toEqual(1); + expect(res[1].shape).toEqual([4]); + test_util_1.expectArraysClose(res[1], [5, 6, 7, 8]); + }); + it('unstack into 3 tensors', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6], [3, 2]); + var res = tf.unstack(x, 0); + expect(res.length).toEqual(3); + expect(res[0].rank).toEqual(1); + expect(res[0].shape).toEqual([2]); + test_util_1.expectArraysClose(res[0], [1, 2]); + expect(res[1].rank).toEqual(1); + expect(res[1].shape).toEqual([2]); + test_util_1.expectArraysClose(res[1], [3, 4]); + expect(res[2].rank).toEqual(1); + expect(res[2].shape).toEqual([2]); + test_util_1.expectArraysClose(res[2], [5, 6]); + }); + it('unstack by axis=1', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var res = tf.unstack(x, 1); + expect(res.length).toEqual(4); + expect(res[0].rank).toEqual(1); + expect(res[0].shape).toEqual([2]); + test_util_1.expectArraysClose(res[0], [1, 5]); + expect(res[1].rank).toEqual(1); + expect(res[1].shape).toEqual([2]); + test_util_1.expectArraysClose(res[1], [2, 6]); + expect(res[2].rank).toEqual(1); + expect(res[2].shape).toEqual([2]); + test_util_1.expectArraysClose(res[2], [3, 7]); + expect(res[3].rank).toEqual(1); + expect(res[3].shape).toEqual([2]); + test_util_1.expectArraysClose(res[3], [4, 8]); + }); + it('unstack rank 3 tensor', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var res = tf.unstack(x); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(2); + expect(res[0].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[0], [1, 2, 3, 4]); + expect(res[1].rank).toEqual(2); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [5, 6, 7, 8]); + }); + it('unstack rank 3 tensor with axis=1', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var res = tf.unstack(x, 1); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(2); + expect(res[0].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[0], [1, 2, 5, 6]); + expect(res[1].rank).toEqual(2); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [3, 4, 7, 8]); + }); + it('unstack rank 3 tensor with axis=2', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var res = tf.unstack(x, 2); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(2); + expect(res[0].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[0], [1, 3, 5, 7]); + expect(res[1].rank).toEqual(2); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [2, 4, 6, 8]); + }); + it('unstack rank 4 tensor', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]); + var res = tf.unstack(x); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(3); + expect(res[0].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[0], [1, 2, 3, 4]); + expect(res[1].rank).toEqual(3); + expect(res[1].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[1], [5, 6, 7, 8]); + }); + it('unstack rank 4 tensor with axis=1', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]); + var res = tf.unstack(x, 1); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(3); + expect(res[0].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[0], [1, 2, 5, 6]); + expect(res[1].rank).toEqual(3); + expect(res[1].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[1], [3, 4, 7, 8]); + }); + it('unstack rank 4 tensor with axis=2', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]); + var res = tf.unstack(x, 2); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(3); + expect(res[0].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[0], [1, 3, 5, 7]); + expect(res[1].rank).toEqual(3); + expect(res[1].shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(res[1], [2, 4, 6, 8]); + }); + it('unstack rank 4 tensor with axis=3', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]); + var res = tf.unstack(x, 3); + expect(res.length).toEqual(1); + expect(res[0].rank).toEqual(3); + expect(res[0].shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(res[0], [1, 2, 3, 4, 5, 6, 7, 8]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.unstack({}); }) + .toThrowError(/Argument 'x' passed to 'unstack' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var x = [[1, 2, 3, 4], [5, 6, 7, 8]]; + var res = tf.unstack(x); + expect(res.length).toEqual(2); + expect(res[0].rank).toEqual(1); + expect(res[0].shape).toEqual([4]); + test_util_1.expectArraysClose(res[0], [1, 2, 3, 4]); + expect(res[1].rank).toEqual(1); + expect(res[1].shape).toEqual([4]); + test_util_1.expectArraysClose(res[1], [5, 6, 7, 8]); + }); +}); +jasmine_util_1.describeWithFlags('split', test_util_1.ALL_ENVS, function () { + it('split by number', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var res = tf.split(x, 2, 1); + expect(res.length).toEqual(2); + expect(res[0].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[0], [1, 2, 5, 6]); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [3, 4, 7, 8]); + }); + it('split by sizes', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var res = tf.split(x, [1, 2, 1], 1); + expect(res.length).toEqual(3); + expect(res[0].shape).toEqual([2, 1]); + test_util_1.expectArraysClose(res[0], [1, 5]); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [2, 3, 6, 7]); + expect(res[2].shape).toEqual([2, 1]); + test_util_1.expectArraysClose(res[2], [4, 8]); + }); + it('sizes to not sum to axis size throws error', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var f = function () { return tf.split(x, [1, 2], 1); }; + expect(f).toThrowError(); + }); + it('number of splits does not evenly divide axis', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]); + var f = function () { return tf.split(x, 3, 1); }; + expect(f).toThrowError(); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.split({}, 1); }) + .toThrowError(/Argument 'x' passed to 'split' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var x = [[1, 2, 3, 4], [5, 6, 7, 8]]; + var res = tf.split(x, 2, 1); + expect(res.length).toEqual(2); + expect(res[0].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[0], [1, 2, 5, 6]); + expect(res[1].shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res[1], [3, 4, 7, 8]); + }); +}); +jasmine_util_1.describeWithFlags('expandDims', test_util_1.ALL_ENVS, function () { + it('scalar, default axis is 0', function () { + var res = tf.scalar(1).expandDims(); + expect(res.shape).toEqual([1]); + test_util_1.expectArraysClose(res, [1]); + }); + it('scalar, axis is out of bounds throws error', function () { + var f = function () { return tf.scalar(1).expandDims(1); }; + expect(f).toThrowError(); + }); + it('1d, axis=-3', function () { + expect(function () { + tf.tensor1d([1, 2, 3]).expandDims(-3); + }).toThrowError('Axis must be in the interval [-2, 1]'); + }); + it('1d, axis=-2', function () { + var res = tf.tensor1d([1, 2, 3]).expandDims(-2); + expect(res.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(res, [1, 2, 3]); + }); + it('1d, axis=-1', function () { + var res = tf.tensor1d([1, 2, 3]).expandDims(-1); + expect(res.shape).toEqual([3, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3]); + }); + it('1d, axis=0', function () { + var res = tf.tensor1d([1, 2, 3]).expandDims(0); + expect(res.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(res, [1, 2, 3]); + }); + it('1d, axis=1', function () { + var res = tf.tensor1d([1, 2, 3]).expandDims(1); + expect(res.shape).toEqual([3, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3]); + }); + it('2d, axis=-4', function () { + expect(function () { + tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(-4); + }).toThrowError('Axis must be in the interval [-3, 2]'); + }); + it('2d, axis=-3', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(-3); + expect(res.shape).toEqual([1, 3, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('2d, axis=-2', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(-2); + expect(res.shape).toEqual([3, 1, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('2d, axis=-1', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(-1); + expect(res.shape).toEqual([3, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('2d, axis=0', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(0); + expect(res.shape).toEqual([1, 3, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('2d, axis=1', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(1); + expect(res.shape).toEqual([3, 1, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('2d, axis=2', function () { + var res = tf.tensor2d([[1, 2], [3, 4], [5, 6]]).expandDims(2); + expect(res.shape).toEqual([3, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('4d, axis=0', function () { + var res = tf.tensor4d([[[[4]]]]).expandDims(); + expect(res.shape).toEqual([1, 1, 1, 1, 1]); + test_util_1.expectArraysClose(res, [4]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.expandDims({}); }) + .toThrowError(/Argument 'x' passed to 'expandDims' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.expandDims(7); + expect(res.shape).toEqual([1]); + test_util_1.expectArraysClose(res, [7]); + }); +}); +jasmine_util_1.describeWithFlags('cumsum', test_util_1.ALL_ENVS, function () { + it('1D standard', function () { + var res = tf.tensor1d([1, 2, 3, 4]).cumsum(); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [1, 3, 6, 10]); + }); + it('1D reverse', function () { + var reverse = true; + var exclusive = false; + var res = tf.tensor1d([1, 2, 3, 4]).cumsum(0, exclusive, reverse); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [10, 9, 7, 4]); + }); + it('1D exclusive', function () { + var exclusive = true; + var res = tf.tensor1d([1, 2, 3, 4]).cumsum(0, exclusive); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [0, 1, 3, 6]); + }); + it('1D exclusive reverse', function () { + var reverse = true; + var exclusive = true; + var res = tf.tensor1d([1, 2, 3, 4]).cumsum(0, exclusive, reverse); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [9, 7, 4, 0]); + }); + it('gradient: 1D', function () { + var a = tf.tensor1d([1, 2, 3]); + var dy = tf.tensor1d([4, 5, 6]); + var da = tf.grad(function (x) { return tf.cumsum(x); })(a, dy); + expect(da.shape).toEqual([3]); + test_util_1.expectArraysClose(da, [15, 11, 6]); + }); + it('2D standard', function () { + var res = tf.tensor2d([[1, 2], [3, 4]]).cumsum(1); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [1, 3, 3, 7]); + }); + it('2D reverse exclusive', function () { + var reverse = true; + var exclusive = true; + var res = tf.tensor2d([[1, 2], [3, 4]]).cumsum(1, exclusive, reverse); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [2, 0, 4, 0]); + }); + it('2D axis=0', function () { + var res = tf.tensor2d([[1, 2], [3, 4]]).cumsum(); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [1, 2, 4, 6]); + }); + it('3D standard', function () { + var res = tf.tensor3d([[[0, 1], [2, 3]], [[4, 5], [6, 7]]]).cumsum(2); + expect(res.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(res, [0, 1, 2, 5, 4, 9, 6, 13]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.cumsum({}); }) + .toThrowError(/Argument 'x' passed to 'cumsum' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var res = tf.cumsum([1, 2, 3, 4]); + expect(res.shape).toEqual([4]); + test_util_1.expectArraysClose(res, [1, 3, 6, 10]); + }); +}); +jasmine_util_1.describeWithFlags('batchToSpaceND', test_util_1.ALL_ENVS, function () { + it('tensor4d, input shape=[4, 1, 1, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([1, 2, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); + it('tensor4d, input shape=[4, 1, 1, 3], blockShape=[2, 2]', function () { + var t = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [4, 1, 1, 3]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([1, 2, 2, 3]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + }); + it('tensor4d, input shape=[1, 4, 4, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([1, 3, 9, 11, 2, 4, 10, 12, 5, 7, 13, 15, 6, 8, 14, 16], [4, 2, 2, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([1, 4, 4, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]); + }); + it('tensor4d, input shape=[8, 1, 3, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([ + 0, 1, 3, 0, 9, 11, 0, 2, 4, 0, 10, 12, + 0, 5, 7, 0, 13, 15, 0, 6, 8, 0, 14, 16 + ], [8, 1, 3, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [2, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([2, 2, 4, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]); + }); + it('tensor2d, blockShape [1]', function () { + var t = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var blockShape = [2]; + var crops = [[0, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([1, 4]); + test_util_1.expectArraysClose(res, [1, 3, 2, 4]); + }); + it('tensor3d, blockSHape [1]', function () { + var t = tf.tensor([ + -61, 37, -68, 72, 31, 62, 0, -13, 28, 54, 96, + 44, -55, -64, -88, -94, 65, -32, -96, -73, -2, -77, + -14, 47, 33, 15, 70, 20, 75, 28, 84, -13 + ], [8, 2, 2]); + var blockShape = [2]; + var crops = [[0, 2]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([4, 2, 2]); + test_util_1.expectArraysClose(res, [-61, 37, 65, -32, 31, 62, -2, -77, 28, 54, 33, 15, -55, -64, 75, 28]); + }); + it('tensor3d, blockShape [2]', function () { + var t = tf.tensor([ + -61, 37, -68, 72, 31, 62, 0, -13, 28, 54, 96, + 44, -55, -64, -88, -94, 65, -32, -96, -73, -2, -77, + -14, 47, 33, 15, 70, 20, 75, 28, 84, -13 + ], [8, 2, 2]); + var blockShape = [2, 2]; + var crops = [[2, 0], [2, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(res, [72, 44, -73, 20, -13, -94, 47, -13]); + }); + it('throws when blockShape equal to input rank', function () { + var t = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]); + var blockShape = [2, 2, 2, 2]; + var crops = [[0, 0], [0, 0], [0, 0], [0, 0]]; + expect(function () { return tf.batchToSpaceND(t, blockShape, crops); }) + .toThrowError('input rank should be > than [blockShape] but got 4'); + }); + it('throws when crops row dimension not equal to blockshape', function () { + var t = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0]]; + expect(function () { return tf.batchToSpaceND(t, blockShape, crops); }) + .toThrowError('crops.shape[0] must be equal to [blockShape] but got 1'); + }); + it('throws when input tensor batch not divisible by prod(blockShape)', function () { + var t = tf.tensor4d([1, 2, 3, 4, 5], [5, 1, 1, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + expect(function () { return tf.batchToSpaceND(t, blockShape, crops); }) + .toThrowError('input tensor batch must be divisible by prod( blockShape )'); + }); + it('accepts a tensor-like object', function () { + var t = [[[[1]]], [[[2]]], [[[3]]], [[[4]]]]; + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var res = tf.batchToSpaceND(t, blockShape, crops); + expect(res.shape).toEqual([1, 2, 2, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); +}); +jasmine_util_1.describeWithFlags('spaceToBatchND', test_util_1.ALL_ENVS, function () { + it('tensor4d, input shape=[1, 2, 2, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([[[[1], [2]], [[3], [4]]]], [1, 2, 2, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([4, 1, 1, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); + it('tensor4d, input shape=[1, 2, 2, 3], blockShape=[2, 2]', function () { + var t = tf.tensor4d([[[[1, 2, 3], [4, 5, 6]], [[7, 8, 9], [10, 11, 12]]]], [1, 2, 2, 3]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([4, 1, 1, 3]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + }); + it('tensor4d, input shape=[1, 4, 4, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([[ + [[1], [2], [3], [4]], [[5], [6], [7], [8]], [[9], [10], [11], [12]], + [[13], [14], [15], [16]] + ]], [1, 4, 4, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([4, 2, 2, 1]); + test_util_1.expectArraysClose(res, [1, 3, 9, 11, 2, 4, 10, 12, 5, 7, 13, 15, 6, 8, 14, 16]); + }); + it('tensor4d, input shape=[2, 6, 6, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([ + 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 + ], [2, 6, 6, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([8, 3, 3, 1]); + test_util_1.expectArraysClose(res, [ + 1, 3, 5, 13, 15, 17, 25, 27, 29, 37, 39, 41, 49, 51, 53, 61, 63, 65, + 2, 4, 6, 14, 16, 18, 26, 28, 30, 38, 40, 42, 50, 52, 54, 62, 64, 66, + 7, 9, 11, 19, 21, 23, 31, 33, 35, 43, 45, 47, 55, 57, 59, 67, 69, 71, + 8, 10, 12, 20, 22, 24, 32, 34, 36, 44, 46, 48, 56, 58, 60, 68, 70, 72 + ]); + }); + it('tensor4d, input shape=[2, 2, 4, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([ + [[[1], [2], [3], [4]], [[5], [6], [7], [8]]], + [[[9], [10], [11], [12]], [[13], [14], [15], [16]]] + ], [2, 2, 4, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [2, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([8, 1, 3, 1]); + test_util_1.expectArraysClose(res, [ + 0, 1, 3, 0, 9, 11, 0, 2, 4, 0, 10, 12, + 0, 5, 7, 0, 13, 15, 0, 6, 8, 0, 14, 16 + ]); + }); + it('tensor2d, blockShape [1]', function () { + var t = tf.tensor2d([1, 3, 2, 4], [1, 4]); + var blockShape = [2]; + var paddings = [[0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); + it('throws when blockShape equal to input rank', function () { + var t = tf.tensor4d([1, 2, 3, 4], [1, 2, 2, 1]); + var blockShape = [2, 2, 2, 2]; + var paddings = [[0, 0], [0, 0], [0, 0], [0, 0]]; + expect(function () { return tf.spaceToBatchND(t, blockShape, paddings); }) + .toThrowError('input rank should be > than [blockShape] but got 4'); + }); + it('throws when paddings row dimension not equal to blockshape', function () { + var t = tf.tensor4d([1, 2, 3, 4], [1, 2, 2, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0]]; + expect(function () { return tf.spaceToBatchND(t, blockShape, paddings); }) + .toThrowError('paddings.shape[0] must be equal to [blockShape], got 1'); + }); + it('throws when input tensor spatial dimension not divisible by \ + blockshapes', function () { + var t = tf.tensor4d([1, 2, 3, 4, 5, 6], [1, 2, 3, 1]); + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + expect(function () { return tf.spaceToBatchND(t, blockShape, paddings); }) + .toThrowError('input spatial dimensions must be divisible by blockShapes'); + }); + it('accepts a tensor-like object', function () { + var t = [[[[1], [2]], [[3], [4]]]]; + var blockShape = [2, 2]; + var paddings = [[0, 0], [0, 0]]; + var res = tf.spaceToBatchND(t, blockShape, paddings); + expect(res.shape).toEqual([4, 1, 1, 1]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4]); + }); +}); +jasmine_util_1.describeWithFlags('batchToSpaceND X spaceToBatchND', test_util_1.ALL_ENVS, function () { + it('tensor4d, input shape=[4, 1, 1, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var paddings = [[0, 0], [0, 0]]; + var b2s = tf.batchToSpaceND(t, blockShape, crops); + expect(b2s.shape).toEqual([1, 2, 2, 1]); + test_util_1.expectArraysClose(b2s, [1, 2, 3, 4]); + var s2b = tf.spaceToBatchND(b2s, blockShape, paddings); + expect(s2b.shape).toEqual([4, 1, 1, 1]); + test_util_1.expectArraysClose(s2b, [1, 2, 3, 4]); + }); + it('tensor4d, input shape=[2, 6, 6, 1], blockShape=[2, 2]', function () { + var t = tf.tensor4d([ + 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 + ], [2, 6, 6, 1]); + var blockShape = [2, 2]; + var crops = [[0, 0], [0, 0]]; + var paddings = [[0, 0], [0, 0]]; + var s2b = tf.spaceToBatchND(t, blockShape, paddings); + expect(s2b.shape).toEqual([8, 3, 3, 1]); + test_util_1.expectArraysClose(s2b, [ + 1, 3, 5, 13, 15, 17, 25, 27, 29, 37, 39, 41, 49, 51, 53, 61, 63, 65, + 2, 4, 6, 14, 16, 18, 26, 28, 30, 38, 40, 42, 50, 52, 54, 62, 64, 66, + 7, 9, 11, 19, 21, 23, 31, 33, 35, 43, 45, 47, 55, 57, 59, 67, 69, 71, + 8, 10, 12, 20, 22, 24, 32, 34, 36, 44, 46, 48, 56, 58, 60, 68, 70, 72 + ]); + var b2s = tf.batchToSpaceND(s2b, blockShape, crops); + expect(b2s.shape).toEqual([2, 6, 6, 1]); + test_util_1.expectArraysClose(b2s, [ + 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 + ]); + }); +}); +//# sourceMappingURL=array_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js.map new file mode 100644 index 0000000..cd52df8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"array_ops_test.js","sourceRoot":"","sources":["../../src/ops/array_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.d.ts new file mode 100644 index 0000000..bd8d7c9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.d.ts @@ -0,0 +1,5 @@ +export declare function getReshaped(inputShape: number[], blockShape: number[], prod: number, batchToSpace?: boolean): number[]; +export declare function getPermuted(reshapedRank: number, blockShapeRank: number, batchToSpace?: boolean): number[]; +export declare function getReshapedPermuted(inputShape: number[], blockShape: number[], prod: number, batchToSpace?: boolean): number[]; +export declare function getSliceBeginCoords(crops: number[][], blockShape: number): number[]; +export declare function getSliceSize(uncroppedShape: number[], crops: number[][], blockShape: number): number[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js new file mode 100644 index 0000000..cd655b9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js @@ -0,0 +1,97 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function getReshaped(inputShape, blockShape, prod, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var reshaped = []; + if (batchToSpace) { + reshaped = reshaped.concat(blockShape.slice(0)); + reshaped.push(inputShape[0] / prod); + reshaped = reshaped.concat(inputShape.slice(1)); + } + else { + reshaped = reshaped.concat(inputShape[0]); + var spatialLength = blockShape.length; + for (var i = 0; i < spatialLength; ++i) { + reshaped = + reshaped.concat([inputShape[i + 1] / blockShape[i], blockShape[i]]); + } + reshaped = reshaped.concat(inputShape.slice(spatialLength + 1)); + } + return reshaped; +} +exports.getReshaped = getReshaped; +function getPermuted(reshapedRank, blockShapeRank, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var permuted = []; + if (batchToSpace) { + permuted.push(blockShapeRank); + for (var i = blockShapeRank + 1; i < reshapedRank; ++i) { + if (i <= 2 * blockShapeRank) { + permuted.push(i); + permuted.push(i - (blockShapeRank + 1)); + } + else { + permuted.push(i); + } + } + } + else { + var permutedBeforeBatch = []; + var permutedAfterBatch = []; + for (var i = 1; i < reshapedRank; ++i) { + if (i >= blockShapeRank * 2 + 1 || i % 2 === 1) { + permutedAfterBatch.push(i); + } + else { + permutedBeforeBatch.push(i); + } + } + permuted.push.apply(permuted, permutedBeforeBatch); + permuted.push(0); + permuted.push.apply(permuted, permutedAfterBatch); + } + return permuted; +} +exports.getPermuted = getPermuted; +function getReshapedPermuted(inputShape, blockShape, prod, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var reshapedPermuted = []; + if (batchToSpace) { + reshapedPermuted.push(inputShape[0] / prod); + } + else { + reshapedPermuted.push(inputShape[0] * prod); + } + for (var i = 1; i < inputShape.length; ++i) { + if (i <= blockShape.length) { + if (batchToSpace) { + reshapedPermuted.push(blockShape[i - 1] * inputShape[i]); + } + else { + reshapedPermuted.push(inputShape[i] / blockShape[i - 1]); + } + } + else { + reshapedPermuted.push(inputShape[i]); + } + } + return reshapedPermuted; +} +exports.getReshapedPermuted = getReshapedPermuted; +function getSliceBeginCoords(crops, blockShape) { + var sliceBeginCoords = [0]; + for (var i = 0; i < blockShape; ++i) { + sliceBeginCoords.push(crops[i][0]); + } + return sliceBeginCoords; +} +exports.getSliceBeginCoords = getSliceBeginCoords; +function getSliceSize(uncroppedShape, crops, blockShape) { + var sliceSize = uncroppedShape.slice(0, 1); + for (var i = 0; i < blockShape; ++i) { + sliceSize.push(uncroppedShape[i + 1] - crops[i][0] - crops[i][1]); + } + return sliceSize; +} +exports.getSliceSize = getSliceSize; +//# sourceMappingURL=array_ops_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js.map new file mode 100644 index 0000000..501debc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/array_ops_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"array_ops_util.js","sourceRoot":"","sources":["../../src/ops/array_ops_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.d.ts new file mode 100644 index 0000000..feae0eb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.d.ts @@ -0,0 +1,9 @@ +export declare function axesAreInnerMostDims(axes: number[], rank: number): boolean; +export declare function combineLocations(outputLoc: number[], reduceLoc: number[], axes: number[]): number[]; +export declare function computeOutAndReduceShapes(aShape: number[], axes: number[]): [number[], number[]]; +export declare function expandShapeToKeepDim(shape: number[], axes: number[]): number[]; +export declare function parseAxisParam(axis: number | number[], shape: number[]): number[]; +export declare function assertAxesAreInnerMostDims(msg: string, axes: number[], rank: number): void; +export declare function getAxesPermutation(axes: number[], rank: number): number[] | null; +export declare function getUndoAxesPermutation(axes: number[]): number[]; +export declare function getInnerMostAxes(numAxes: number, rank: number): number[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js new file mode 100644 index 0000000..9203f74 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js @@ -0,0 +1,89 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("../util"); +function axesAreInnerMostDims(axes, rank) { + for (var i = 0; i < axes.length; ++i) { + if (axes[axes.length - i - 1] !== rank - 1 - i) { + return false; + } + } + return true; +} +exports.axesAreInnerMostDims = axesAreInnerMostDims; +function combineLocations(outputLoc, reduceLoc, axes) { + var rank = outputLoc.length + reduceLoc.length; + var loc = []; + var outIdx = 0; + var reduceIdx = 0; + for (var dim = 0; dim < rank; dim++) { + if (axes.indexOf(dim) === -1) { + loc.push(outputLoc[outIdx++]); + } + else { + loc.push(reduceLoc[reduceIdx++]); + } + } + return loc; +} +exports.combineLocations = combineLocations; +function computeOutAndReduceShapes(aShape, axes) { + var outShape = []; + var rank = aShape.length; + for (var dim = 0; dim < rank; dim++) { + if (axes.indexOf(dim) === -1) { + outShape.push(aShape[dim]); + } + } + var reduceShape = axes.map(function (dim) { return aShape[dim]; }); + return [outShape, reduceShape]; +} +exports.computeOutAndReduceShapes = computeOutAndReduceShapes; +function expandShapeToKeepDim(shape, axes) { + var reduceSubShape = axes.map(function (x) { return 1; }); + return combineLocations(shape, reduceSubShape, axes); +} +exports.expandShapeToKeepDim = expandShapeToKeepDim; +function parseAxisParam(axis, shape) { + var rank = shape.length; + axis = axis == null ? shape.map(function (s, i) { return i; }) : [].concat(axis); + util.assert(axis.every(function (ax) { return ax >= -rank && ax < rank; }), "All values in axis param must be in range [-" + rank + ", " + rank + ") but " + + ("got axis " + axis)); + util.assert(axis.every(function (ax) { return util.isInt(ax); }), "All values in axis param must be integers but " + + ("got axis " + axis)); + return axis.map(function (a) { return a < 0 ? rank + a : a; }); +} +exports.parseAxisParam = parseAxisParam; +function assertAxesAreInnerMostDims(msg, axes, rank) { + util.assert(axesAreInnerMostDims(axes, rank), msg + " supports only inner-most axes for now. " + + ("Got axes " + axes + " and rank-" + rank + " input.")); +} +exports.assertAxesAreInnerMostDims = assertAxesAreInnerMostDims; +function getAxesPermutation(axes, rank) { + if (axesAreInnerMostDims(axes, rank)) { + return null; + } + var result = []; + for (var i = 0; i < rank; ++i) { + if (axes.indexOf(i) === -1) { + result.push(i); + } + } + axes.forEach(function (axis) { return result.push(axis); }); + return result; +} +exports.getAxesPermutation = getAxesPermutation; +function getUndoAxesPermutation(axes) { + return axes.map(function (axis, i) { return [i, axis]; }) + .sort(function (a, b) { return a[1] - b[1]; }) + .map(function (x) { return x[0]; }); +} +exports.getUndoAxesPermutation = getUndoAxesPermutation; +function getInnerMostAxes(numAxes, rank) { + var res = []; + for (var i = rank - numAxes; i < rank; ++i) { + res.push(i); + } + return res; +} +exports.getInnerMostAxes = getInnerMostAxes; +//# sourceMappingURL=axis_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js.map new file mode 100644 index 0000000..2c34c07 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"axis_util.js","sourceRoot":"","sources":["../../src/ops/axis_util.ts"],"names":[],"mappings":";;AAiBA,8BAAgC;AAMhC,8BAAqC,IAAc,EAAE,IAAY;IAC/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;QACpC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,GAAG,CAAC,GAAG,CAAC,EAAE;YAC9C,OAAO,KAAK,CAAC;SACd;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAPD,oDAOC;AAED,0BACI,SAAmB,EAAE,SAAmB,EAAE,IAAc;IAC1D,IAAM,IAAI,GAAG,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;IACjD,IAAM,GAAG,GAAG,EAAE,CAAC;IACf,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,IAAI,SAAS,GAAG,CAAC,CAAC;IAChB,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,EAAE;QACrC,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE;YAC5B,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;SAC/B;aAAM;YACL,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;SAClC;KACF;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAdD,4CAcC;AAED,mCACI,MAAgB,EAAE,IAAc;IAClC,IAAM,QAAQ,GAAG,EAAE,CAAC;IACpB,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,EAAE;QACnC,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE;YAC5B,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;SAC5B;KACF;IACD,IAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,MAAM,CAAC,GAAG,CAAC,EAAX,CAAW,CAAC,CAAC;IACjD,OAAO,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;AACjC,CAAC;AAXD,8DAWC;AAED,8BACI,KAAe,EAAE,IAAc;IACjC,IAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,EAAD,CAAC,CAAC,CAAC;IACxC,OAAO,gBAAgB,CAAC,KAAK,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;AACvD,CAAC;AAJD,oDAIC;AAED,wBACI,IAAqB,EAAE,KAAe;IACxC,IAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC;IAG1B,IAAI,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,EAAD,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAG/D,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,KAAK,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE,GAAG,IAAI,EAAxB,CAAwB,CAAC,EAC1C,iDAA+C,IAAI,UAAK,IAAI,WAAQ;SAChE,cAAY,IAAM,CAAA,CAAC,CAAC;IAG5B,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,KAAK,CAAC,UAAA,EAAE,IAAI,OAAA,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAd,CAAc,CAAC,EAChC,gDAAgD;SAC5C,cAAY,IAAM,CAAA,CAAC,CAAC;IAG5B,OAAO,IAAI,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAApB,CAAoB,CAAC,CAAC;AAC7C,CAAC;AArBD,wCAqBC;AAED,oCACI,GAAW,EAAE,IAAc,EAAE,IAAY;IAC3C,IAAI,CAAC,MAAM,CACP,oBAAoB,CAAC,IAAI,EAAE,IAAI,CAAC,EAC7B,GAAG,6CAA0C;SAC5C,cAAY,IAAI,kBAAa,IAAI,YAAS,CAAA,CAAC,CAAC;AACtD,CAAC;AAND,gEAMC;AAOD,4BAAmC,IAAc,EAAE,IAAY;IAE7D,IAAI,oBAAoB,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE;QACpC,OAAO,IAAI,CAAC;KACb;IACD,IAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,EAAE;QAC7B,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE;YAC1B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAChB;KACF;IACD,IAAI,CAAC,OAAO,CAAC,UAAA,IAAI,IAAI,OAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAjB,CAAiB,CAAC,CAAC;IACxC,OAAO,MAAM,CAAC;AAChB,CAAC;AAbD,gDAaC;AAGD,gCAAuC,IAAc;IACnD,OAAO,IAAI,CAAC,GAAG,CAAC,UAAC,IAAI,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,EAAE,IAAI,CAAC,EAAT,CAAS,CAAC;SAClC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAX,CAAW,CAAC;SAC3B,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,CAAC,EAAJ,CAAI,CAAC,CAAC;AACtB,CAAC;AAJD,wDAIC;AAED,0BAAiC,OAAe,EAAE,IAAY;IAC5D,IAAM,GAAG,GAAa,EAAE,CAAC;IACzB,KAAK,IAAI,CAAC,GAAG,IAAI,GAAG,OAAO,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,EAAE;QAC1C,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KACb;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAND,4CAMC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js new file mode 100644 index 0000000..f07e2f5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js @@ -0,0 +1,224 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var axis_util = require("./axis_util"); +describe('axis_util combineLocations', function () { + it('rank 4, reduce last 2 dims', function () { + var loc = axis_util.combineLocations([4, 1], [3, 7], [2, 3]); + expect(loc).toEqual([4, 1, 3, 7]); + }); + it('rank 4, reduce first two dims', function () { + var loc = axis_util.combineLocations([4, 1], [3, 7], [0, 1]); + expect(loc).toEqual([3, 7, 4, 1]); + }); + it('rank 4, reduce 1st and 3rd dims', function () { + var loc = axis_util.combineLocations([4, 1], [3, 7], [0, 2]); + expect(loc).toEqual([3, 4, 7, 1]); + }); + it('rank 4, reduce 1st and 4th dims', function () { + var loc = axis_util.combineLocations([4, 1], [3, 7], [0, 3]); + expect(loc).toEqual([3, 4, 1, 7]); + }); + it('rank 3, reduce all dims', function () { + var loc = axis_util.combineLocations([], [3, 7, 1], [0, 1, 2]); + expect(loc).toEqual([3, 7, 1]); + }); + it('rank 2, reduce last dim', function () { + var loc = axis_util.combineLocations([3], [5], [1]); + expect(loc).toEqual([3, 5]); + }); + it('rank 2, reduce first dim', function () { + var loc = axis_util.combineLocations([3], [5], [0]); + expect(loc).toEqual([5, 3]); + }); +}); +describe('axis_util computeOutAndReduceShapes', function () { + it('rank 4, reduce all dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2, 4], [0, 1, 2, 3]), out = _a[0], red = _a[1]; + expect(out).toEqual([]); + expect(red).toEqual([3, 7, 2, 4]); + }); + it('rank 4, reduce last 2 dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2, 4], [2, 3]), out = _a[0], red = _a[1]; + expect(out).toEqual([3, 7]); + expect(red).toEqual([2, 4]); + }); + it('rank 4, reduce first 2 dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2, 4], [0, 1]), out = _a[0], red = _a[1]; + expect(out).toEqual([2, 4]); + expect(red).toEqual([3, 7]); + }); + it('rank 4, reduce last 3 dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2, 4], [1, 2, 3]), out = _a[0], red = _a[1]; + expect(out).toEqual([3]); + expect(red).toEqual([7, 2, 4]); + }); + it('rank 4, reduce 1st and 3rd dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2, 4], [0, 2]), out = _a[0], red = _a[1]; + expect(out).toEqual([7, 4]); + expect(red).toEqual([3, 2]); + }); + it('rank 3, reduce all dims', function () { + var _a = axis_util.computeOutAndReduceShapes([3, 7, 2], [0, 1, 2]), out = _a[0], red = _a[1]; + expect(out).toEqual([]); + expect(red).toEqual([3, 7, 2]); + }); +}); +describe('axis_util axesAreInnerMostDims', function () { + it('rank 4, reduce last dim', function () { + var res = axis_util.axesAreInnerMostDims([3], 4); + expect(res).toBe(true); + }); + it('rank 4, reduce last 2 dims', function () { + var res = axis_util.axesAreInnerMostDims([2, 3], 4); + expect(res).toBe(true); + }); + it('rank 4, reduce last 3 dims', function () { + var res = axis_util.axesAreInnerMostDims([1, 2, 3], 4); + expect(res).toBe(true); + }); + it('rank 4, reduce all dims', function () { + var res = axis_util.axesAreInnerMostDims([0, 1, 2, 3], 4); + expect(res).toBe(true); + }); + it('rank 4, reduce all but 2nd', function () { + var res = axis_util.axesAreInnerMostDims([0, 2, 3], 4); + expect(res).toBe(false); + }); + it('rank 4, reduce all but 3rd', function () { + var res = axis_util.axesAreInnerMostDims([0, 1, 3], 4); + expect(res).toBe(false); + }); + it('rank 4, reduce all but last', function () { + var res = axis_util.axesAreInnerMostDims([0, 1, 2], 4); + expect(res).toBe(false); + }); +}); +describe('axis_util expandShapeToKeepDim', function () { + it('2d -> 1d axis=0', function () { + var shape = axis_util.expandShapeToKeepDim([2], [0]); + expect(shape).toEqual([1, 2]); + }); + it('2d -> 1d axis=1', function () { + var shape = axis_util.expandShapeToKeepDim([4], [1]); + expect(shape).toEqual([4, 1]); + }); + it('3d -> 1d axis=1,2', function () { + var shape = axis_util.expandShapeToKeepDim([7], [1, 2]); + expect(shape).toEqual([7, 1, 1]); + }); + it('3d -> 2d axis=1', function () { + var shape = axis_util.expandShapeToKeepDim([7, 3], [1]); + expect(shape).toEqual([7, 1, 3]); + }); +}); +describe('axis_util getPermAxes', function () { + it('all axes, no perm is needed', function () { + var perm = axis_util.getAxesPermutation([0, 1, 2], 3); + expect(perm).toBeNull(); + }); + it('no axes, no perm is needed', function () { + var perm = axis_util.getAxesPermutation([], 3); + expect(perm).toBeNull(); + }); + it('inner most 2 axes, no perm is needed', function () { + var perm = axis_util.getAxesPermutation([2, 3], 4); + expect(perm).toBeNull(); + }); + it('outer most axis, perm is needed', function () { + var perm = axis_util.getAxesPermutation([0], 4); + expect(perm).toEqual([1, 2, 3, 0]); + }); + it('2 outer most axes, perm is needed', function () { + var perm = axis_util.getAxesPermutation([0, 1], 4); + expect(perm).toEqual([2, 3, 0, 1]); + }); +}); +describe('axis_util parseAxisParam', function () { + it('axis=null returns no axes for scalar', function () { + var axis = null; + var shape = []; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([]); + }); + it('axis=null returns 0 axis for Tensor1D', function () { + var axis = null; + var shape = [4]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([0]); + }); + it('axis=null returns all axes for Tensor3D', function () { + var axis = null; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([0, 1, 2]); + }); + it('axis as a single number', function () { + var axis = 1; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([1]); + }); + it('axis as single negative number', function () { + var axis = -1; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([2]); + var axis2 = -2; + expect(axis_util.parseAxisParam(axis2, shape)).toEqual([1]); + var axis3 = -3; + expect(axis_util.parseAxisParam(axis3, shape)).toEqual([0]); + }); + it('axis as list of negative numbers', function () { + var axis = [-1, -3]; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([2, 0]); + }); + it('axis as list of positive numbers', function () { + var axis = [0, 2]; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([0, 2]); + }); + it('axis as combo of positive and negative numbers', function () { + var axis = [0, -1]; + var shape = [3, 1, 2]; + expect(axis_util.parseAxisParam(axis, shape)).toEqual([0, 2]); + }); + it('axis out of range throws error', function () { + var axis = -4; + var shape = [3, 1, 2]; + expect(function () { return axis_util.parseAxisParam(axis, shape); }).toThrowError(); + var axis2 = 4; + expect(function () { return axis_util.parseAxisParam(axis2, shape); }).toThrowError(); + }); + it('axis a list with one number out of range throws error', function () { + var axis = [0, 4]; + var shape = [3, 1, 2]; + expect(function () { return axis_util.parseAxisParam(axis, shape); }).toThrowError(); + }); + it('axis with decimal value throws error', function () { + var axis = 0.5; + var shape = [3, 1, 2]; + expect(function () { return axis_util.parseAxisParam(axis, shape); }).toThrowError(); + }); +}); +jasmine_util_1.describeWithFlags('axis_util getUndoAxesPermutation', test_util_1.ALL_ENVS, function () { + it('4d axes', function () { + var axes = [2, 0, 1, 3]; + expect(axis_util.getUndoAxesPermutation(axes)).toEqual([1, 2, 0, 3]); + }); + it('3d axes, no perm', function () { + var axes = [0, 1, 2]; + expect(axis_util.getUndoAxesPermutation(axes)).toEqual([0, 1, 2]); + }); + it('3d axes, complete flip', function () { + var axes = [2, 1, 0]; + expect(axis_util.getUndoAxesPermutation(axes)).toEqual([2, 1, 0]); + }); + it('4d array with values', function () { + var axes = [2, 0, 1, 3]; + var undoPermutation = axis_util.getUndoAxesPermutation(axes); + var a = tf.randomNormal([2, 3, 4, 5]); + var aT = tf.transpose(a, axes); + var aTT = tf.transpose(aT, undoPermutation); + test_util_1.expectArraysClose(a, aTT); + }); +}); +//# sourceMappingURL=axis_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js.map new file mode 100644 index 0000000..8a2cfcc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/axis_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"axis_util_test.js","sourceRoot":"","sources":["../../src/ops/axis_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.d.ts new file mode 100644 index 0000000..d834e3c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.d.ts @@ -0,0 +1,11 @@ +import { Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { Rank, TensorLike } from '../types'; +declare function batchNormalization2d_(x: Tensor2D | TensorLike, mean: Tensor2D | Tensor1D | TensorLike, variance: Tensor2D | Tensor1D | TensorLike, varianceEpsilon?: number, scale?: Tensor2D | Tensor1D | TensorLike, offset?: Tensor2D | Tensor1D | TensorLike): Tensor2D; +declare function batchNormalization3d_(x: Tensor3D | TensorLike, mean: Tensor3D | Tensor1D | TensorLike, variance: Tensor3D | Tensor1D | TensorLike, varianceEpsilon?: number, scale?: Tensor3D | Tensor1D | TensorLike, offset?: Tensor3D | Tensor1D | TensorLike): Tensor3D; +declare function batchNormalization4d_(x: Tensor4D | TensorLike, mean: Tensor4D | Tensor1D | TensorLike, variance: Tensor4D | Tensor1D | TensorLike, varianceEpsilon?: number, scale?: Tensor4D | Tensor1D | TensorLike, offset?: Tensor4D | Tensor1D | TensorLike): Tensor4D; +declare function batchNormalization_(x: Tensor | Tensor1D | TensorLike, mean: Tensor | Tensor1D | TensorLike, variance: Tensor | Tensor1D | TensorLike, varianceEpsilon?: number, scale?: Tensor | Tensor1D | TensorLike, offset?: Tensor | Tensor1D | TensorLike): Tensor; +export declare const batchNormalization2d: typeof batchNormalization2d_; +export declare const batchNormalization3d: typeof batchNormalization3d_; +export declare const batchNormalization4d: typeof batchNormalization4d_; +export declare const batchNormalization: typeof batchNormalization_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js new file mode 100644 index 0000000..a2d8f54 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js @@ -0,0 +1,219 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var array_ops_1 = require("./array_ops"); +var broadcast_util_1 = require("./broadcast_util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +var unary_ops_1 = require("./unary_ops"); +function batchNormalization2d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'batchNormalization'); + var $mean = tensor_util_env_1.convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = tensor_util_env_1.convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = tensor_util_env_1.convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = tensor_util_env_1.convertToTensor(offset, 'offset', 'batchNormalization'); + } + util.assert($x.rank === 2, "Error in batchNormalization3D: x must be rank 3 but got rank " + + ($x.rank + ".")); + util.assert($mean.rank === 2 || $mean.rank === 1, "Error in batchNormalization2D: mean must be rank 2 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + util.assert($variance.rank === 2 || $variance.rank === 1, "Error in batchNormalization2D: variance must be rank 2 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + util.assert($scale.rank === 2 || $scale.rank === 1, "Error in batchNormalization2D: scale must be rank 2 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + util.assert($offset.rank === 2 || $offset.rank === 1, "Error in batchNormalization2D: offset must be rank 2 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return exports.batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); +} +function batchNormalization3d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'batchNormalization'); + var $mean = tensor_util_env_1.convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = tensor_util_env_1.convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = tensor_util_env_1.convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = tensor_util_env_1.convertToTensor(offset, 'offset', 'batchNormalization'); + } + util.assert($x.rank === 3, "Error in batchNormalization3D: x must be rank 3 but got rank " + + ($x.rank + ".")); + util.assert($mean.rank === 3 || $mean.rank === 1, "Error in batchNormalization3D: mean must be rank 3 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + util.assert($variance.rank === 3 || $variance.rank === 1, "Error in batchNormalization3D: variance must be rank 3 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + util.assert($scale.rank === 3 || $scale.rank === 1, "Error in batchNormalization3D: scale must be rank 3 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + util.assert($offset.rank === 3 || $offset.rank === 1, "Error in batchNormalization3D: offset must be rank 3 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return exports.batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); +} +function batchNormalization4d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'batchNormalization'); + var $mean = tensor_util_env_1.convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = tensor_util_env_1.convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = tensor_util_env_1.convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = tensor_util_env_1.convertToTensor(offset, 'offset', 'batchNormalization'); + } + util.assert($x.rank === 4, "Error in batchNormalization4D: x must be rank 4 but got rank " + + ($x.rank + ".")); + util.assert($mean.rank === 4 || $mean.rank === 1, "Error in batchNormalization4D: mean must be rank 4 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + util.assert($variance.rank === 4 || $variance.rank === 1, "Error in batchNormalization4D: variance must be rank 4 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + util.assert($scale.rank === 4 || $scale.rank === 1, "Error in batchNormalization4D: scale must be rank 4 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + util.assert($offset.rank === 4 || $offset.rank === 1, "Error in batchNormalization4D: offset must be rank 4 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return exports.batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); +} +function batchNormalization_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'batchNormalization'); + var $mean = tensor_util_env_1.convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = tensor_util_env_1.convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = tensor_util_env_1.convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = tensor_util_env_1.convertToTensor(offset, 'offset', 'batchNormalization'); + } + util.assert($mean.rank === $variance.rank, 'Batch normalization gradient requires mean and variance to have ' + + 'equal ranks.'); + util.assert($offset == null || $mean.rank === $offset.rank, 'Batch normalization gradient requires mean and offset to have ' + + 'equal ranks.'); + util.assert($scale == null || $mean.rank === $scale.rank, 'Batch normalization gradient requires mean and scale to have ' + + 'equal ranks.'); + var x4D; + if ($x.rank === 0 || $x.rank === 1) { + x4D = $x.as4D(1, 1, 1, $x.size); + } + else if ($x.rank === 2) { + x4D = $x.as4D(1, 1, $x.shape[0], $x.shape[1]); + } + else if ($x.rank === 3) { + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + else { + x4D = $x; + } + var der = function (dy) { + var scaleValue = $scale == null ? tensor_ops_1.scalar(1) : $scale; + var reductionAxes = broadcast_util_1.getReductionAxes($mean.shape, x4D.shape); + var tileShape = []; + if ($mean.rank === 1) { + for (var i = 0; i < x4D.shape.length - 1; ++i) { + tileShape.push(x4D.shape[i]); + } + tileShape.push(1); + } + var xMinusMean = $x.sub($mean); + var dyTimesScaleValue = dy.mul(scaleValue); + var oneOverSqrtVariance = unary_ops_1.rsqrt($variance.add(tensor_ops_1.scalar(varianceEpsilon))); + var minusHalfRCube = oneOverSqrtVariance.mul(oneOverSqrtVariance) + .mul(oneOverSqrtVariance) + .mul(tensor_ops_1.scalar(-0.5)); + var derX = function () { + if ($mean.rank === 1) { + return dy + .mul(array_ops_1.tile(oneOverSqrtVariance.as4D(1, 1, 1, $mean.shape[0]), tileShape)) + .mul(scaleValue) + .reshape($x.shape); + } + else { + return dy.mul(oneOverSqrtVariance).mul(scaleValue).reshape($x.shape); + } + }; + var derMean = function () { + var meanDer = oneOverSqrtVariance.mul(tensor_ops_1.scalar(-1)).mul(dyTimesScaleValue); + if ($mean.rank === 1) { + meanDer = meanDer.sum(reductionAxes); + } + return meanDer.reshape($mean.shape); + }; + var derVariance = function () { + var varianceDer = minusHalfRCube.mul(xMinusMean).mul(dyTimesScaleValue); + if ($mean.rank === 1) { + varianceDer = varianceDer.sum(reductionAxes); + } + return varianceDer.reshape($mean.shape); + }; + var derScale = function () { + var xMinusMean2TimesRsqrt = xMinusMean.mul(oneOverSqrtVariance); + var scaleDer = dy.mul(xMinusMean2TimesRsqrt); + if ($mean.rank === 1) { + scaleDer = scaleDer.sum(reductionAxes); + } + return scaleDer.reshape($mean.shape); + }; + var derOffset = function () { + var offsetDer = dy; + if ($mean.rank === 1) { + offsetDer = offsetDer.sum(reductionAxes); + } + return offsetDer.reshape($mean.shape); + }; + return { + $x: derX, + $mean: derMean, + $variance: derVariance, + $scale: derScale, + $offset: derOffset + }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.batchNormalization(x4D, batchnormReshape4D($mean), batchnormReshape4D($variance), varianceEpsilon, batchnormReshape4D($scale), batchnormReshape4D($offset)); }, { $x: $x, $mean: $mean, $variance: $variance, $scale: $scale, $offset: $offset }, der); + return res.reshape($x.shape); +} +function batchnormReshape4D(x) { + if (x == null) { + return null; + } + if (x.rank === 0) { + return x.as1D(); + } + else if (x.rank === 1) { + return x; + } + else if (x.rank === 2) { + return x.as4D(1, 1, x.shape[0], x.shape[1]); + } + else if (x.rank === 3) { + return x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + return x; +} +exports.batchNormalization2d = operation_1.op({ batchNormalization2d_: batchNormalization2d_ }); +exports.batchNormalization3d = operation_1.op({ batchNormalization3d_: batchNormalization3d_ }); +exports.batchNormalization4d = operation_1.op({ batchNormalization4d_: batchNormalization4d_ }); +exports.batchNormalization = operation_1.op({ batchNormalization_: batchNormalization_ }); +//# sourceMappingURL=batchnorm.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js.map new file mode 100644 index 0000000..aa4b739 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"batchnorm.js","sourceRoot":"","sources":["../../src/ops/batchnorm.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,8BAAgC;AAEhC,yCAAiC;AACjC,mDAAkD;AAClD,yCAA+B;AAC/B,2CAAoC;AACpC,yCAAkC;AAalC,+BACI,CAAsB,EAAE,IAAkC,EAC1D,QAAsC,EAAE,eAAsB,EAC9D,KAAoC,EACpC,MAAqC;IAFG,gCAAA,EAAA,sBAAsB;IAGhE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,oBAAoB,CAAC,CAAC;IACzD,IAAM,KAAK,GAAG,iCAAe,CAAC,IAAI,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC;IAClE,IAAM,SAAS,GAAG,iCAAe,CAAC,QAAQ,EAAE,UAAU,EAAE,oBAAoB,CAAC,CAAC;IAC9E,IAAI,MAAyB,CAAC;IAC9B,IAAI,KAAK,IAAI,IAAI,EAAE;QACjB,MAAM,GAAG,iCAAe,CAAC,KAAK,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;KAChE;IACD,IAAI,OAA0B,CAAC;IAC/B,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,oBAAoB,CAAC,CAAC;KACnE;IACD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,CAAC,EACb,+DAA+D;SACxD,EAAE,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACvB,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EACpC,mEAAmE;SAC/D,cAAY,KAAK,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACnC,IAAI,CAAC,MAAM,CACP,SAAS,CAAC,IAAI,KAAK,CAAC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAC5C,mEAAmE;SAC/D,kBAAgB,SAAS,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IAC3C,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,IAAI,CAAC,MAAM,CACP,MAAM,CAAC,IAAI,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EACtC,gEAAgE;aAC5D,kBAAgB,MAAM,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KACzC;IACD,IAAI,OAAO,IAAI,IAAI,EAAE;QACnB,IAAI,CAAC,MAAM,CACP,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,KAAK,CAAC,EACxC,iEAAiE;aAC7D,kBAAgB,OAAO,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KAC1C;IAED,OAAO,0BAAkB,CACrB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC;AAaD,+BACI,CAAsB,EAAE,IAAkC,EAC1D,QAAsC,EAAE,eAAsB,EAC9D,KAAoC,EACpC,MAAqC;IAFG,gCAAA,EAAA,sBAAsB;IAGhE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,oBAAoB,CAAC,CAAC;IACzD,IAAM,KAAK,GAAG,iCAAe,CAAC,IAAI,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC;IAClE,IAAM,SAAS,GAAG,iCAAe,CAAC,QAAQ,EAAE,UAAU,EAAE,oBAAoB,CAAC,CAAC;IAC9E,IAAI,MAAyB,CAAC;IAC9B,IAAI,KAAK,IAAI,IAAI,EAAE;QACjB,MAAM,GAAG,iCAAe,CAAC,KAAK,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;KAChE;IACD,IAAI,OAA0B,CAAC;IAC/B,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,oBAAoB,CAAC,CAAC;KACnE;IACD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,CAAC,EACb,+DAA+D;SACxD,EAAE,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACvB,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EACpC,mEAAmE;SAC/D,cAAY,KAAK,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACnC,IAAI,CAAC,MAAM,CACP,SAAS,CAAC,IAAI,KAAK,CAAC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAC5C,mEAAmE;SAC/D,kBAAgB,SAAS,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IAC3C,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,IAAI,CAAC,MAAM,CACP,MAAM,CAAC,IAAI,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EACtC,gEAAgE;aAC5D,kBAAgB,MAAM,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KACzC;IACD,IAAI,OAAO,IAAI,IAAI,EAAE;QACnB,IAAI,CAAC,MAAM,CACP,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,KAAK,CAAC,EACxC,iEAAiE;aAC7D,kBAAgB,OAAO,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KAC1C;IAED,OAAO,0BAAkB,CACrB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC;AAaD,+BACI,CAAsB,EAAE,IAAkC,EAC1D,QAAsC,EAAE,eAAsB,EAC9D,KAAoC,EACpC,MAAqC;IAFG,gCAAA,EAAA,sBAAsB;IAGhE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,oBAAoB,CAAC,CAAC;IACzD,IAAM,KAAK,GAAG,iCAAe,CAAC,IAAI,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC;IAClE,IAAM,SAAS,GAAG,iCAAe,CAAC,QAAQ,EAAE,UAAU,EAAE,oBAAoB,CAAC,CAAC;IAC9E,IAAI,MAAyB,CAAC;IAC9B,IAAI,KAAK,IAAI,IAAI,EAAE;QACjB,MAAM,GAAG,iCAAe,CAAC,KAAK,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;KAChE;IACD,IAAI,OAA0B,CAAC;IAC/B,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,oBAAoB,CAAC,CAAC;KACnE;IACD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,CAAC,EACb,+DAA+D;SACxD,EAAE,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACvB,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EACpC,mEAAmE;SAC/D,cAAY,KAAK,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IACnC,IAAI,CAAC,MAAM,CACP,SAAS,CAAC,IAAI,KAAK,CAAC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAC5C,mEAAmE;SAC/D,kBAAgB,SAAS,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;IAC3C,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,IAAI,CAAC,MAAM,CACP,MAAM,CAAC,IAAI,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EACtC,gEAAgE;aAC5D,kBAAgB,MAAM,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KACzC;IACD,IAAI,OAAO,IAAI,IAAI,EAAE;QACnB,IAAI,CAAC,MAAM,CACP,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,KAAK,CAAC,EACxC,iEAAiE;aAC7D,kBAAgB,OAAO,CAAC,IAAI,MAAG,CAAA,CAAC,CAAC;KAC1C;IACD,OAAO,0BAAkB,CACrB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC;AA4BD,6BACI,CAAgC,EAAE,IAAmC,EACrE,QAAuC,EAAE,eAAsB,EAC/D,KAAqC,EACrC,MAAsC;IAFG,gCAAA,EAAA,sBAAsB;IAGjE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,oBAAoB,CAAC,CAAC;IACzD,IAAM,KAAK,GAAG,iCAAe,CAAC,IAAI,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC;IAClE,IAAM,SAAS,GAAG,iCAAe,CAAC,QAAQ,EAAE,UAAU,EAAE,oBAAoB,CAAC,CAAC;IAC9E,IAAI,MAA0B,CAAC;IAC/B,IAAI,KAAK,IAAI,IAAI,EAAE;QACjB,MAAM,GAAG,iCAAe,CAAC,KAAK,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;KAChE;IACD,IAAI,OAA2B,CAAC;IAChC,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,oBAAoB,CAAC,CAAC;KACnE;IAED,IAAI,CAAC,MAAM,CACP,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,EAC7B,kEAAkE;QAC9D,cAAc,CAAC,CAAC;IACxB,IAAI,CAAC,MAAM,CACP,OAAO,IAAI,IAAI,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,EAC9C,gEAAgE;QAC5D,cAAc,CAAC,CAAC;IACxB,IAAI,CAAC,MAAM,CACP,MAAM,IAAI,IAAI,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,EAC5C,+DAA+D;QAC3D,cAAc,CAAC,CAAC;IAExB,IAAI,GAAa,CAAC;IAClB,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QAClC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;KACjC;SAAM,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACxB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC/C;SAAM,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACxB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAa,CAAC;KACrE;SAAM;QACL,GAAG,GAAG,EAAc,CAAC;KACtB;IAED,IAAM,GAAG,GAAG,UAAC,EAAU;QACrB,IAAM,UAAU,GAAG,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,mBAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QACvD,IAAM,aAAa,GAAG,iCAAgB,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/D,IAAM,SAAS,GAAa,EAAE,CAAC;QAC/B,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;YACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;gBAC7C,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aAC9B;YACD,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACnB;QAED,IAAM,UAAU,GAAG,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,IAAM,iBAAiB,GAAG,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAC7C,IAAM,mBAAmB,GAAG,iBAAK,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,cAAc,GAAG,mBAAmB,CAAC,GAAG,CAAC,mBAAmB,CAAC;aACvC,GAAG,CAAC,mBAAmB,CAAC;aACxB,GAAG,CAAC,mBAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAM,IAAI,GAAG;YACX,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpB,OAAO,EAAE;qBACJ,GAAG,CAAC,gBAAI,CACL,mBAAmB,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;qBACjE,GAAG,CAAC,UAAU,CAAC;qBACf,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;aACxB;iBAAM;gBACL,OAAO,EAAE,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;aACtE;QACH,CAAC,CAAC;QACF,IAAM,OAAO,GAAG;YACd,IAAI,OAAO,GAAG,mBAAmB,CAAC,GAAG,CAAC,mBAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YACzE,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpB,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aACtC;YACD,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC;QACF,IAAM,WAAW,GAAG;YAClB,IAAI,WAAW,GAAG,cAAc,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YACxE,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpB,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aAC9C;YACD,OAAO,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC,CAAC;QACF,IAAM,QAAQ,GAAG;YACf,IAAM,qBAAqB,GAAG,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;YAClE,IAAI,QAAQ,GAAG,EAAE,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;YAC7C,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpB,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aACxC;YACD,OAAO,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC,CAAC;QACF,IAAM,SAAS,GAAG;YAChB,IAAI,SAAS,GAAG,EAAE,CAAC;YACnB,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpB,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aAC1C;YACD,OAAO,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC,CAAC;QACF,OAAO;YACL,EAAE,EAAE,IAAI;YACR,KAAK,EAAE,OAAO;YACd,SAAS,EAAE,WAAW;YACtB,MAAM,EAAE,QAAQ;YAChB,OAAO,EAAE,SAAS;SACnB,CAAC;IACJ,CAAC,CAAC;IAEF,IAAM,GAAG,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAC5B,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,kBAAkB,CACjC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAAE,kBAAkB,CAAC,SAAS,CAAC,EAC7D,eAAe,EAAE,kBAAkB,CAAC,MAAM,CAAC,EAC3C,kBAAkB,CAAC,OAAO,CAAC,CAAC,EAHrB,CAGqB,EAChC,EAAC,EAAE,IAAA,EAAE,KAAK,OAAA,EAAE,SAAS,WAAA,EAAE,MAAM,QAAA,EAAE,OAAO,SAAA,EAAC,EAAE,GAAG,CAAC,CAAC;IAClD,OAAO,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;AAC/B,CAAC;AAED,4BAA4B,CAAS;IACnC,IAAI,CAAC,IAAI,IAAI,EAAE;QACb,OAAO,IAAI,CAAC;KACb;IACD,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QAChB,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;KACjB;SAAM,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QACvB,OAAO,CAAa,CAAC;KACtB;SAAM,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC7C;SAAM,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KACtD;IACD,OAAO,CAAa,CAAC;AACvB,CAAC;AAEY,QAAA,oBAAoB,GAAG,cAAE,CAAC,EAAC,qBAAqB,uBAAA,EAAC,CAAC,CAAC;AACnD,QAAA,oBAAoB,GAAG,cAAE,CAAC,EAAC,qBAAqB,uBAAA,EAAC,CAAC,CAAC;AACnD,QAAA,oBAAoB,GAAG,cAAE,CAAC,EAAC,qBAAqB,uBAAA,EAAC,CAAC,CAAC;AACnD,QAAA,kBAAkB,GAAG,cAAE,CAAC,EAAC,mBAAmB,qBAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js new file mode 100644 index 0000000..32e3c03 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js @@ -0,0 +1,533 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('batchNormalization4D', test_util_1.ALL_ENVS, function () { + it('simple batchnorm4D, no offset or scale, 2x1x1x2', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var varianceEpsilon = .001; + var result = tf.batchNormalization4d(x, mean, variance, varianceEpsilon, undefined, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm4D, no offset, 2x1x1x2', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm4D, no scale, 2x1x1x2', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization4d(x, mean, variance, varianceEpsilon, undefined, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm4D, 2x1x1x2', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('accepts a tensor-like object', function () { + var x = [[[[2, 4]]], [[[9, 23]]]]; + var mean = [1, 2]; + var variance = [2, 3]; + var offset = [3, 4]; + var scale = [4, 5]; + var varianceEpsilon = .001; + var result = tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset[0] + + (x[0][0][0][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[0][0][0][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon), + offset[0] + + (x[1][0][0][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[1][0][0][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon) + ]); + }); + it('simple batchnorm4D gradients, 2x1x1x2', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([2, 5]); + var varianceEpsilon = .001; + var dy = tf.tensor4d([-1, -1, -1, -1], [2, 1, 1, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor4d([-1.414, -2.887, -1.414, -2.887], [2, 1, 1, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor1d([2.828, 5.773])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor1d([3.180, 11.060])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, dy.sum([0, 1, 2])); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor1d([-6.362, -13.277])); + }); + it('batchnorm4D gradients, same shapes in x, mean and variance', function () { + var x = tf.tensor4d([10, 20, 30, 40], [2, 1, 1, 2]); + var mean = tf.tensor4d([0, 5, 10, 15], [2, 1, 1, 2]); + var variance = tf.tensor4d([2, 4, 6, 8], [2, 1, 1, 2]); + var scale = tf.tensor4d([2, 5, 2, 5], [2, 1, 1, 2]); + var offset = tf.tensor4d([0, 0, 0, 0], [2, 1, 1, 2]); + var varianceEpsilon = .001; + var dy = tf.tensor4d([-1, -1, -1, -1], [2, 1, 1, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor4d([-1.414, -2.500, -0.816, -1.768], [2, 1, 1, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor4d([1.414, 2.500, 0.816, 1.768], [2, 1, 1, 2])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor4d([3.533, 4.686, 1.360, 2.762], [2, 1, 1, 2])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, dy); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization4d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor4d([-7.069, -7.499, -8.164, -8.838], [2, 1, 1, 2])); + }); +}); +jasmine_util_1.describeWithFlags('batchNormalization3D', test_util_1.ALL_ENVS, function () { + it('simple batchnorm3D, no offset or scale, 2x1x2', function () { + var x = tf.tensor3d([2, 4, 9, 23], [2, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, undefined, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm3D, no offset, 2x1x2', function () { + var x = tf.tensor3d([2, 4, 9, 23], [2, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm3D, no scale, 2x1x2', function () { + var x = tf.tensor3d([2, 4, 9, 23], [2, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, undefined, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm3D, 2x1x2', function () { + var x = tf.tensor3d([2, 4, 9, 23], [2, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('accepts a tensor-like object', function () { + var x = [[[2, 4]], [[9, 23]]]; + var mean = [1, 2]; + var variance = [2, 3]; + var offset = [3, 4]; + var scale = [4, 5]; + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset[0] + + (x[0][0][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[0][0][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon), + offset[0] + + (x[1][0][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[1][0][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon) + ]); + }); + it('batchnorm3D, x,mean,var,offset,scale are all 3D', function () { + var shape = [2, 1, 2]; + var x = tf.tensor3d([2, 4, 9, 23], shape); + var mean = tf.tensor3d([1, 2, 3, 4], shape); + var variance = tf.tensor3d([2, 3, 4, 5], shape); + var offset = tf.tensor3d([3, 4, 5, 6], shape); + var scale = tf.tensor3d([4, 5, 6, 7], shape); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0, 0, 0) + + (x.get(0, 0, 0) - mean.get(0, 0, 0)) * scale.get(0, 0, 0) / + Math.sqrt(variance.get(0, 0, 0) + varianceEpsilon), + offset.get(0, 0, 1) + + (x.get(0, 0, 1) - mean.get(0, 0, 1)) * scale.get(0, 0, 1) / + Math.sqrt(variance.get(0, 0, 1) + varianceEpsilon), + offset.get(1, 0, 0) + + (x.get(1, 0, 0) - mean.get(1, 0, 0)) * scale.get(1, 0, 0) / + Math.sqrt(variance.get(1, 0, 0) + varianceEpsilon), + offset.get(1, 0, 1) + + (x.get(1, 0, 1) - mean.get(1, 0, 1)) * scale.get(1, 0, 1) / + Math.sqrt(variance.get(1, 0, 1) + varianceEpsilon) + ]); + }); + it('simple batchnorm3D gradients, 2x1x2', function () { + var x = tf.tensor3d([2, 4, 9, 23], [2, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([2, 5]); + var varianceEpsilon = .001; + var dy = tf.tensor3d([1, 1, 1, 1], [2, 1, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor3d([1.414, 2.887, 1.414, 2.887], [2, 1, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor1d([-2.828, -5.773])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor1d([-3.180, -11.060])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, tf.onesLike(offset).mul(tf.scalar(2))); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor1d([6.362, 13.277])); + }); + it('batchnorm3D gradients, same shapes in x, mean and variance', function () { + var x = tf.tensor3d([10, 20, 30, 40], [2, 1, 2]); + var mean = tf.tensor3d([0, 5, 10, 15], [2, 1, 2]); + var variance = tf.tensor3d([2, 4, 6, 8], [2, 1, 2]); + var scale = tf.tensor3d([2, 5, 2, 5], [2, 1, 2]); + var offset = tf.tensor3d([0, 0, 0, 0], [2, 1, 2]); + var varianceEpsilon = .001; + var dy = tf.tensor3d([1, 1, 1, 1], [2, 1, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor3d([1.414, 2.500, 0.816, 1.768], [2, 1, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor3d([-1.414, -2.500, -0.816, -1.768], [2, 1, 2])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor3d([-3.533, -4.686, -1.360, -2.762], [2, 1, 2])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, tf.onesLike(offset)); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor3d([7.069, 7.499, 8.164, 8.838], [2, 1, 2])); + }); + it('batchnorm matches tensorflow, 2x3x3', function () { + var x = tf.tensor3d([ + 0.49955603, 0.04158615, -1.09440524, 2.03854165, -0.61578344, + 2.87533573, 1.18105987, 0.807462, 1.87888837, 2.26563962, -0.37040935, + 1.35848753, -0.75347094, 0.15683117, 0.91925946, 0.34121279, + 0.92717143, 1.89683965 + ], [2, 3, 3]); + var mean = tf.tensor1d([0.39745062, -0.48062894, 0.4847822]); + var variance = tf.tensor1d([0.32375343, 0.67117643, 1.08334653]); + var offset = tf.tensor1d([0.69398749, -1.29056387, 0.9429723]); + var scale = tf.tensor1d([-0.5607271, 0.9878457, 0.25181573]); + var varianceEpsilon = .001; + var result = tf.batchNormalization3d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + 0.59352049, -0.66135202, 0.5610874, -0.92077015, -1.45341019, 1.52106473, + -0.07704776, 0.26144429, 1.28010017, -1.14422404, -1.15776136, 1.15425493, + 1.82644104, -0.52249442, 1.04803919, 0.74932291, 0.40568101, 1.2844412 + ]); + }); +}); +jasmine_util_1.describeWithFlags('batchNormalization2D', test_util_1.ALL_ENVS, function () { + it('simple batchnorm2D, no offset or scale, 2x2', function () { + var x = tf.tensor2d([2, 4, 9, 23], [2, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, undefined, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm2D, no offset, 2x2', function () { + var x = tf.tensor2d([2, 4, 9, 23], [2, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, undefined); + test_util_1.expectArraysClose(result, [ + (x.get(0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + (x.get(1, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + (x.get(1, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm2D, no scale, 2x2', function () { + var x = tf.tensor2d([2, 4, 9, 23], [2, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, undefined, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0) - mean.get(0)) * 1 / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 1) - mean.get(1)) * 1 / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm2D, 2x2', function () { + var x = tf.tensor2d([2, 4, 9, 23], [2, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([4, 5]); + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset.get(0) + + (x.get(0, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(0, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon), + offset.get(0) + + (x.get(1, 0) - mean.get(0)) * scale.get(0) / + Math.sqrt(variance.get(0) + varianceEpsilon), + offset.get(1) + + (x.get(1, 1) - mean.get(1)) * scale.get(1) / + Math.sqrt(variance.get(1) + varianceEpsilon) + ]); + }); + it('simple batchnorm2D gradients, 2x2', function () { + var x = tf.tensor2d([2, 4, 9, 23], [2, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var offset = tf.tensor1d([3, 4]); + var scale = tf.tensor1d([2, 5]); + var varianceEpsilon = .001; + var dy = tf.tensor2d([1, 1, 1, 1], [2, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor2d([1.414, 2.887, 1.414, 2.887], [2, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor1d([-2.828, -5.773])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor1d([-3.180, -11.060])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, tf.onesLike(offset).mul(tf.scalar(2))); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor1d([6.362, 13.277])); + }); + it('batchnorm2D gradients, same shapes in x, mean and variance', function () { + var x = tf.tensor2d([10, 20, 30, 40], [2, 2]); + var mean = tf.tensor2d([0, 5, 10, 15], [2, 2]); + var variance = tf.tensor2d([2, 4, 6, 8], [2, 2]); + var scale = tf.tensor2d([2, 5, 2, 5], [2, 2]); + var offset = tf.tensor2d([0, 0, 0, 0], [2, 2]); + var varianceEpsilon = .001; + var dy = tf.tensor2d([1, 1, 1, 1], [2, 2]); + var gradX = tf.grad(function (x) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(x, dy); + test_util_1.expectArraysClose(gradX, tf.tensor2d([1.414, 2.500, 0.816, 1.768], [2, 2])); + var gradMean = tf.grad(function (mean) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(mean, dy); + test_util_1.expectArraysClose(gradMean, tf.tensor2d([-1.414, -2.500, -0.816, -1.768], [2, 2])); + var gradVariance = tf.grad(function (variance) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(variance, dy); + test_util_1.expectArraysClose(gradVariance, tf.tensor2d([-3.533, -4.686, -1.360, -2.762], [2, 2])); + var gradOffset = tf.grad(function (offset) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(offset, dy); + test_util_1.expectArraysClose(gradOffset, tf.onesLike(offset)); + var gradScale = tf.grad(function (scale) { return tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); })(scale, dy); + test_util_1.expectArraysClose(gradScale, tf.tensor2d([7.069, 7.499, 8.164, 8.838], [2, 2])); + }); + it('batchnorm2D matches tensorflow, 3x3', function () { + var x = tf.tensor2d([ + 0.3136892, 0.92389025, 0.594782, 0.05021042, 0.67545404, 0.93910035, + 0.13277993, 0.96474269, 0.88608916 + ], [3, 3]); + var mean = tf.tensor1d([0.19526312, 0.74857256, 0.45166398]); + var variance = tf.tensor1d([0.22963001, 0.61521992, 0.46623685]); + var offset = tf.tensor1d([0.43098484, 0.77712237, 0.47916298]); + var scale = tf.tensor1d([0.62186907, 0.85673736, 0.19201061]); + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + 0.58433646, 0.96846228, 0.51936529, 0.24315402, 0.69732157, 0.61608542, + 0.35007446, 1.01304821, 0.60119441 + ]); + }); + it('throws when passed x as a non-tensor', function () { + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + expect(function () { return tf.batchNormalization({}, mean, variance); }) + .toThrowError(/Argument 'x' passed to 'batchNormalization' must be a Tensor/); + }); + it('throws when passed mean as a non-tensor', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var variance = tf.tensor1d([2, 3]); + expect(function () { return tf.batchNormalization(x, {}, variance); }) + .toThrowError(/Argument 'mean' passed to 'batchNormalization' must be a Tensor/); + }); + it('throws when passed variance as a non-tensor', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var e = /Argument 'variance' passed to 'batchNormalization' must be a Tensor/; + expect(function () { return tf.batchNormalization(x, mean, {}); }) + .toThrowError(e); + }); + it('throws when passed scale as a non-tensor', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var epsilon = .001; + expect(function () { + return tf.batchNormalization(x, mean, variance, epsilon, {}); + }) + .toThrowError(/Argument 'scale' passed to 'batchNormalization' must be a Tensor/); + }); + it('throws when passed offset as a non-tensor', function () { + var x = tf.tensor4d([2, 4, 9, 23], [2, 1, 1, 2]); + var mean = tf.tensor1d([1, 2]); + var variance = tf.tensor1d([2, 3]); + var epsilon = .001; + var scale = tf.tensor1d([0.62186907, 0.85673736, 0.19201061]); + var e = /Argument 'offset' passed to 'batchNormalization' must be a Tensor/; + expect(function () { return tf.batchNormalization(x, mean, variance, epsilon, scale, {}); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var x = [[2, 4], [9, 23]]; + var mean = [1, 2]; + var variance = [2, 3]; + var offset = [3, 4]; + var scale = [4, 5]; + var varianceEpsilon = .001; + var result = tf.batchNormalization2d(x, mean, variance, varianceEpsilon, scale, offset); + test_util_1.expectArraysClose(result, [ + offset[0] + + (x[0][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[0][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon), + offset[0] + + (x[1][0] - mean[0]) * scale[0] / + Math.sqrt(variance[0] + varianceEpsilon), + offset[1] + + (x[1][1] - mean[1]) * scale[1] / + Math.sqrt(variance[1] + varianceEpsilon) + ]); + }); +}); +//# sourceMappingURL=batchnorm_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js.map new file mode 100644 index 0000000..30b94a6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/batchnorm_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"batchnorm_test.js","sourceRoot":"","sources":["../../src/ops/batchnorm_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.d.ts new file mode 100644 index 0000000..8d8dc5e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.d.ts @@ -0,0 +1,45 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function add_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function addN_(tensors: Array): T; +declare function addStrict_(a: T, b: T): T; +declare function sub_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function subStrict_(a: T, b: T): T; +declare function pow_(base: T | TensorLike, exp: Tensor | TensorLike): T; +declare function powStrict_(base: T, exp: Tensor): T; +declare function mul_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function mulStrict_(a: T, b: T): T; +declare function div_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function floorDiv_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function divStrict_(a: T, b: T): T; +declare function mod_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function modStrict_(a: T, b: T): T; +declare function minimum_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function minimumStrict_(a: T, b: T): T; +declare function maximum_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function maximumStrict_(a: T, b: T): T; +declare function squaredDifference_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function squaredDifferenceStrict_(a: T, b: T): T; +declare function atan2_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +export declare const add: typeof add_; +export declare const addN: typeof addN_; +export declare const addStrict: typeof addStrict_; +export declare const atan2: typeof atan2_; +export declare const div: typeof div_; +export declare const divStrict: typeof divStrict_; +export declare const floorDiv: typeof floorDiv_; +export declare const maximum: typeof maximum_; +export declare const maximumStrict: typeof maximumStrict_; +export declare const minimum: typeof minimum_; +export declare const minimumStrict: typeof minimumStrict_; +export declare const mod: typeof mod_; +export declare const modStrict: typeof modStrict_; +export declare const mul: typeof mul_; +export declare const mulStrict: typeof mulStrict_; +export declare const pow: typeof pow_; +export declare const powStrict: typeof powStrict_; +export declare const squaredDifference: typeof squaredDifference_; +export declare const squaredDifferenceStrict: typeof squaredDifferenceStrict_; +export declare const sub: typeof sub_; +export declare const subStrict: typeof subStrict_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js new file mode 100644 index 0000000..5e32035 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js @@ -0,0 +1,365 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_1 = require("../tensor_util"); +var tensor_util_env_1 = require("../tensor_util_env"); +var types_1 = require("../types"); +var util = require("../util"); +var broadcast_util = require("./broadcast_util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +var unary_ops_1 = require("./unary_ops"); +function add_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'add'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'add'); + tensor_util_1.assertTypesMatch($a, $b); + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy; + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var res = dy; + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.add($a, $b); }, { $a: $a, $b: $b }, der); +} +function addN_(tensors) { + util.assert(Array.isArray(tensors), function () { return 'The param passed to tf.addN() must be a list of tensors'; }); + util.assert(tensors.length >= 1, function () { return "Must pass at least one tensor to tf.addN(), but got " + + ("" + tensors.length); }); + var $tensors = tensors.map(function (t, i) { return tensor_util_env_1.convertToTensor(t, "tensors" + i, 'addN'); }); + var firstTensor = $tensors[0]; + $tensors.forEach(function (t) { + if (t.dtype !== firstTensor.dtype) { + throw new Error('All tensors passed to tf.addN() must have the same dtype'); + } + }); + $tensors.forEach(function (t) { + if (!util.arraysEqual(t.shape, firstTensor.shape)) { + throw new Error('All tensors passed to tf.addN() must have the same shape'); + } + }); + var der = function (dy) { + var ders = {}; + $tensors.forEach(function (t, i) { + ders[i] = function () { return dy.clone(); }; + }); + return ders; + }; + var inputs = $tensors; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.addN($tensors); }, inputs, der); +} +function addStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in addStrict: '); + return a.add(b); +} +function sub_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'sub'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'sub'); + tensor_util_1.assertTypesMatch($a, $b); + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy; + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var res = dy; + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.neg().reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.subtract($a, $b); }, { $a: $a, $b: $b }, der); +} +function subStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in subStrict: '); + return a.sub(b); +} +function pow_(base, exp) { + var $base = tensor_util_env_1.convertToTensor(base, 'base', 'pow'); + var $exp = tensor_util_env_1.convertToTensor(exp, 'exp', 'pow'); + var outShape = broadcast_util.assertAndGetBroadcastShape($base.shape, $exp.shape); + base = $base.cast(types_1.upcastType($base.dtype, $exp.dtype)); + exp = $exp.cast(types_1.upcastType($base.dtype, $exp.dtype)); + var grad = function (dy, saved) { + var y = saved[0]; + var derBase = function () { + var res = dy.mul($exp.toFloat().mul(y.div($base))); + var reduceAxes = broadcast_util.getReductionAxes($base.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($base.shape); + }; + var derExp = function () { + var res = dy.mul(y.mul($base.log()).toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($exp.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($exp.shape); + }; + return { $base: derBase, $exp: derExp }; + }; + return environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.pow($base, $exp)); }, { $base: $base, $exp: $exp }, grad); +} +function powStrict_(base, exp) { + util.assertShapesMatch(base.shape, exp.shape, 'Error in powStrict: '); + return base.pow(exp); +} +function mul_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'mul'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'mul'); + tensor_util_1.assertTypesMatch($a, $b); + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.mul($b.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($b.shape); + } + return res; + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.multiply($a, $b); }, { $a: $a, $b: $b }, der); +} +function mulStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in multiplyStrict: '); + return a.mul(b); +} +function div_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'div'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'div'); + tensor_util_1.assertTypesMatch($a, $b); + var forwardFunc; + if ($a.dtype === 'int32' && $b.dtype === 'int32') { + return exports.floorDiv($a, $b); + } + else { + forwardFunc = function (backend) { return backend.realDivide($a, $b); }; + } + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.div($b.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes).reshape($b.shape); + } + var tmp = $b.square(); + return res.div(tmp.toFloat()).neg(); + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(forwardFunc, { $a: $a, $b: $b }, der); +} +function floorDiv_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'floorDiv'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'floorDiv'); + tensor_util_1.assertTypesMatch($a, $b); + var forwardFunc = function (backend) { return backend.floorDiv($a, $b); }; + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.div($b.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes).reshape($b.shape); + } + var tmp = $b.square(); + return res.div(tmp.toFloat()).neg(); + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(forwardFunc, { $a: $a, $b: $b }, der); +} +function divStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in divideStrict: '); + return a.div(b); +} +function mod_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'mod'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'mod'); + tensor_util_1.assertTypesMatch($a, $b); + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return dy.sum(reduceAxes).reshape($a.shape); + } + return dy; + }; + var derB = function () { + var res = dy.mul($a.div($b).floor().neg()); + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($b.shape); + } + return res; + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.mod($a, $b); }, { $a: $a, $b: $b }, der); +} +function modStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in modStrict: '); + return a.mod(b); +} +function minimum_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'minimum'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'minimum'); + tensor_util_1.assertTypesMatch($a, $b); + if ($a.dtype === 'bool') { + $a = $a.toInt(); + } + if ($b.dtype === 'bool') { + $b = $b.toInt(); + } + broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { return dy.mul($a.lessEqual($b).toFloat()); }; + var derB = function () { return dy.mul($a.greater($b).toFloat()); }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.minimum($a, $b); }, { $a: $a, $b: $b }, der); +} +function minimumStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: '); + return a.minimum(b); +} +function maximum_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'maximum'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'maximum'); + tensor_util_1.assertTypesMatch($a, $b); + if ($a.dtype === 'bool') { + $a = $a.toInt(); + } + if ($b.dtype === 'bool') { + $b = $b.toInt(); + } + broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { return dy.mul($a.greaterEqual($b).toFloat()); }; + var derB = function () { return dy.mul($a.less($b).toFloat()); }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.maximum($a, $b); }, { $a: $a, $b: $b }, der); +} +function maximumStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: '); + return a.maximum(b); +} +function squaredDifference_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'squaredDifference'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'squaredDifference'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var two = tensor_ops_1.scalar(2); + var derA = function () { return dy.mul($a.sub($b).mul(two)); }; + var derB = function () { return dy.mul($b.sub($a).mul(two)); }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.squaredDifference($a, $b); }, { $a: $a, $b: $b }, der); +} +function squaredDifferenceStrict_(a, b) { + util.assertShapesMatch(a.shape, b.shape, 'Error in squaredDifferenceStrict: '); + return a.squaredDifference(b); +} +function atan2_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'atan2'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'atan2'); + tensor_util_1.assertTypesMatch($a, $b); + var outShape = broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var d = exports.add($a.square(), $b.square()); + var res = dy.mul($b.div(d)); + var reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var d = exports.add($a.square(), $b.square()); + var res = unary_ops_1.neg(dy.mul($a.div(d))); + var reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.atan2($a, $b); }, { $a: $a, $b: $b }, der); +} +exports.add = operation_1.op({ add_: add_ }); +exports.addN = operation_1.op({ addN_: addN_ }); +exports.addStrict = operation_1.op({ addStrict_: addStrict_ }); +exports.atan2 = operation_1.op({ atan2_: atan2_ }); +exports.div = operation_1.op({ div_: div_ }); +exports.divStrict = operation_1.op({ divStrict_: divStrict_ }); +exports.floorDiv = operation_1.op({ floorDiv_: floorDiv_ }); +exports.maximum = operation_1.op({ maximum_: maximum_ }); +exports.maximumStrict = operation_1.op({ maximumStrict_: maximumStrict_ }); +exports.minimum = operation_1.op({ minimum_: minimum_ }); +exports.minimumStrict = operation_1.op({ minimumStrict_: minimumStrict_ }); +exports.mod = operation_1.op({ mod_: mod_ }); +exports.modStrict = operation_1.op({ modStrict_: modStrict_ }); +exports.mul = operation_1.op({ mul_: mul_ }); +exports.mulStrict = operation_1.op({ mulStrict_: mulStrict_ }); +exports.pow = operation_1.op({ pow_: pow_ }); +exports.powStrict = operation_1.op({ powStrict_: powStrict_ }); +exports.squaredDifference = operation_1.op({ squaredDifference_: squaredDifference_ }); +exports.squaredDifferenceStrict = operation_1.op({ squaredDifferenceStrict_: squaredDifferenceStrict_ }); +exports.sub = operation_1.op({ sub_: sub_ }); +exports.subStrict = operation_1.op({ subStrict_: subStrict_ }); +//# sourceMappingURL=binary_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js.map new file mode 100644 index 0000000..d071ff6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"binary_ops.js","sourceRoot":"","sources":["../../src/ops/binary_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js new file mode 100644 index 0000000..09e528c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js @@ -0,0 +1,744 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('prelu', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var x = tf.tensor1d([0, 1, -2, -4]); + var a = tf.tensor1d([0.15, 0.2, 0.25, 0.15]); + var result = tf.prelu(x, a); + expect(result.shape).toEqual(x.shape); + test_util_1.expectArraysClose(result, [0, 1, -0.5, -0.6]); + }); + it('derivative', function () { + var x = tf.tensor1d([0.5, 3, -0.1, -4]); + var a = tf.tensor1d([0.2, 0.4, 0.25, 0.15]); + var dy = tf.tensor1d([1, 1, 1, 1]); + var dx = tf.grad(function (x) { return tf.prelu(x, a); })(x, dy); + expect(dx.shape).toEqual(x.shape); + expect(dx.dtype).toEqual('float32'); + test_util_1.expectArraysClose(dx, [1, 1, 0.25, 0.15]); + }); + it('throws when passed x as a non-tensor', function () { + expect(function () { return tf.prelu({}, tf.scalar(1)); }) + .toThrowError(/Argument 'x' passed to 'prelu' must be a Tensor/); + }); + it('throws when passed alpha as a non-tensor', function () { + expect(function () { return tf.prelu(tf.scalar(1), {}); }) + .toThrowError(/Argument 'alpha' passed to 'prelu' must be a Tensor/); + }); +}); +jasmine_util_1.describeWithFlags('maximum', test_util_1.ALL_ENVS, function () { + it('float32 and float32', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.tensor1d([0.2, 0.4, 0.25, 0.15]); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.5, 3, 0.25, 0.15]); + }); + it('int32 and int32', function () { + var a = tf.tensor1d([1, 5, 2, 3], 'int32'); + var b = tf.tensor1d([2, 3, 1, 4], 'int32'); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [2, 5, 2, 4]); + }); + it('bool and bool', function () { + var a = tf.tensor1d([true, false, false, true], 'bool'); + var b = tf.tensor1d([false, false, true, true], 'bool'); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [1, 0, 1, 1]); + }); + it('different dtypes throws error', function () { + var a = tf.tensor1d([true, false, false, true], 'float32'); + var b = tf.tensor1d([false, false, true, true], 'int32'); + expect(function () { return tf.maximum(a, b); }).toThrowError(); + }); + it('propagates NaN', function () { + var a = tf.tensor1d([0.5, -0.1, NaN]); + var b = tf.tensor1d([0.2, 0.3, 0.25]); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.5, 0.3, NaN]); + }); + it('broadcasts Tensor1D and scalar', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.scalar(0.6); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.6, 3, 0.6, 0.6]); + }); + it('broadcasts scalar and Tensor1D', function () { + var a = tf.scalar(0.6); + var b = tf.tensor1d([0.5, 3, -0.1, -4]); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.6, 3, 0.6, 0.6]); + }); + it('broadcasts Tensor1D and Tensor2D', function () { + var a = tf.tensor1d([0.5, 0.3]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.5, 0.4, 0.6, 0.3]); + }); + it('broadcasts 2x1 Tensor2D and 2x2 Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3], [2, 1]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.maximum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.5, 0.5, 0.6, 0.3]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var b = tf.scalar(0.6); + var dy = tf.scalar(3); + var grads = tf.grads(function (a, b) { return tf.maximum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 1]); + test_util_1.expectArraysClose(db, [3 * 0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1.1, 2.6, 3, 5.9]); + var b = tf.tensor1d([1.0, 2.7, 3, 5.8]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var grads = tf.grads(function (a, b) { return tf.maximum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * 0, 3 * 1, 4 * 1]); + test_util_1.expectArraysClose(db, [1 * 0, 2 * 1, 3 * 0, 4 * 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3, 0.7, 0.9], [2, 2]); + var b = tf.tensor2d([0.2, 0.4, 0.7, 0.15], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.maximum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * 0, 3 * 1, 4 * 1]); + test_util_1.expectArraysClose(db, [1 * 0, 2 * 1, 3 * 0, 4 * 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.maximum({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'maximum' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.maximum(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'maximum' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[0.5, 3], [-0.1, -4]]; + var b = [[0.2, 0.4], [0.25, 0.15]]; + var result = tf.maximum(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [0.5, 3, 0.25, 0.15]); + }); +}); +jasmine_util_1.describeWithFlags('squaredDifference', test_util_1.ALL_ENVS, function () { + it('float32 and float32', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.tensor1d([0.2, 0.4, 0.25, 0.15]); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [ + Math.pow(0.5 - 0.2, 2), Math.pow(3 - 0.4, 2), Math.pow(-0.1 - 0.25, 2), + Math.pow(-4 - 0.15, 2) + ]); + }); + it('int32 and int32', function () { + var a = tf.tensor1d([1, 5, 2, 3], 'int32'); + var b = tf.tensor1d([2, 3, 1, 4], 'int32'); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [ + Math.pow(1 - 2, 2), Math.pow(5 - 3, 2), Math.pow(2 - 1, 2), + Math.pow(3 - 4, 2) + ]); + }); + it('different dtypes throws error', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4], 'float32'); + var b = tf.tensor1d([2, 3, 1, 4], 'int32'); + expect(function () { return tf.squaredDifference(a, b); }).toThrowError(); + }); + it('propagates NaN', function () { + var a = tf.tensor1d([0.5, -0.1, NaN]); + var b = tf.tensor1d([0.2, 0.3, 0.25]); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [Math.pow(0.5 - 0.2, 2), Math.pow(-0.1 - 0.3, 2), NaN]); + }); + it('broadcasts Tensor1D and scalar', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.scalar(0.6); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [ + Math.pow(0.5 - 0.6, 2), Math.pow(3 - 0.6, 2), Math.pow(-0.1 - 0.6, 2), + Math.pow(-4 - 0.6, 2) + ]); + }); + it('broadcasts scalar and Tensor1D', function () { + var a = tf.scalar(0.6); + var b = tf.tensor1d([0.5, 3, -0.1, -4]); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [ + Math.pow(0.6 - 0.5, 2), Math.pow(0.6 - 3, 2), Math.pow(0.6 - (-0.1), 2), + Math.pow(0.6 - (-4), 2) + ]); + }); + it('broadcasts Tensor1D and Tensor2D', function () { + var a = tf.tensor1d([0.5, 0.3]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [ + Math.pow(0.5 - 0.2, 2), Math.pow(0.3 - 0.4, 2), Math.pow(0.5 - 0.6, 2), + Math.pow(0.3 - 0.15, 2) + ]); + }); + it('broadcasts 2x1 Tensor2D and 2x2 Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3], [2, 1]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [ + Math.pow(0.5 - 0.2, 2), Math.pow(0.5 - 0.4, 2), Math.pow(0.3 - 0.6, 2), + Math.pow(0.3 - 0.15, 2) + ]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var b = tf.scalar(0.6); + var dy = tf.scalar(3); + var grads = tf.grads(function (a, b) { return tf.squaredDifference(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 2 * (5.2 - 0.6)]); + test_util_1.expectArraysClose(db, [3 * 2 * (0.6 - 5.2)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1.1, 2.6, 3, 5.9]); + var b = tf.tensor1d([1.0, 2.7, 3, 5.8]); + var dy = tf.tensor1d([1, 2, 3, 1]); + var grads = tf.grads(function (a, b) { return tf.squaredDifference(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 1 * 2 * (1.1 - 1.0), 2 * 2 * (2.6 - 2.7), 3 * 2 * (3 - 3), + 1 * 2 * (5.9 - 5.8) + ]); + test_util_1.expectArraysClose(db, [ + 1 * 2 * (1.0 - 1.1), 2 * 2 * (2.7 - 2.6), 3 * 2 * (3 - 3), + 1 * 2 * (5.8 - 5.9) + ]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3, 0.7, 0.9], [2, 2]); + var b = tf.tensor2d([0.2, 0.4, 0.7, 0.15], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.squaredDifference(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [ + 1 * 2 * (0.5 - 0.2), 2 * 2 * (0.3 - 0.4), 3 * 2 * (0.7 - 0.7), + 4 * 2 * (0.9 - 0.15) + ]); + test_util_1.expectArraysClose(db, [ + 1 * 2 * (0.2 - 0.5), 2 * 2 * (0.4 - 0.3), 3 * 2 * (0.7 - 0.7), + 4 * 2 * (0.15 - 0.9) + ]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.squaredDifference({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'squaredDifference' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.squaredDifference(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'squaredDifference' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[0.5, 3], [-0.1, -4]]; + var b = 0.6; + var result = tf.squaredDifference(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [ + Math.pow(0.5 - 0.6, 2), Math.pow(3 - 0.6, 2), Math.pow(-0.1 - 0.6, 2), + Math.pow(-4 - 0.6, 2) + ]); + }); +}); +jasmine_util_1.describeWithFlags('minimum', test_util_1.ALL_ENVS, function () { + it('float32 and float32', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.tensor1d([0.2, 0.4, 0.25, 0.15]); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.2, 0.4, -0.1, -4]); + }); + it('int32 and int32', function () { + var a = tf.tensor1d([1, 5, 2, 3], 'int32'); + var b = tf.tensor1d([2, 3, 1, 4], 'int32'); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [1, 3, 1, 3]); + }); + it('bool and bool', function () { + var a = tf.tensor1d([true, false, false, true], 'bool'); + var b = tf.tensor1d([false, false, true, true], 'bool'); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [0, 0, 0, 1]); + }); + it('different dtypes throws error', function () { + var a = tf.tensor1d([true, false, false, true], 'float32'); + var b = tf.tensor1d([false, false, true, true], 'int32'); + expect(function () { return tf.minimum(a, b); }).toThrowError(); + }); + it('propagates NaN', function () { + var a = tf.tensor1d([0.5, -0.1, NaN]); + var b = tf.tensor1d([0.2, 0.3, 0.25]); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.2, -0.1, NaN]); + }); + it('broadcasts Tensor1D and scalar', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.scalar(0.6); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.5, 0.6, -0.1, -4]); + }); + it('broadcasts scalar and Tensor1D', function () { + var a = tf.scalar(0.6); + var b = tf.tensor1d([0.5, 3, -0.1, -4]); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.5, 0.6, -0.1, -4]); + }); + it('broadcasts Tensor1D and Tensor2D', function () { + var a = tf.tensor1d([0.5, 0.3]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.2, 0.3, 0.5, 0.15]); + }); + it('broadcasts 2x1 Tensor2D and 2x2 Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3], [2, 1]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.minimum(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.2, 0.4, 0.3, 0.15]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var b = tf.scalar(0.6); + var dy = tf.scalar(3); + var grads = tf.grads(function (a, b) { return tf.minimum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3 * 0]); + test_util_1.expectArraysClose(db, [3 * 1]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1.1, 2.6, 3, 5.9]); + var b = tf.tensor1d([1.0, 2.7, 3, 5.8]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var grads = tf.grads(function (a, b) { return tf.minimum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 0, 2 * 1, 3 * 1, 4 * 0]); + test_util_1.expectArraysClose(db, [1 * 1, 2 * 0, 3 * 0, 4 * 1]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3, 0.7, 0.9], [2, 2]); + var b = tf.tensor2d([0.2, 0.4, 0.7, 0.15], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.minimum(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 0, 2 * 1, 3 * 1, 4 * 0]); + test_util_1.expectArraysClose(db, [1 * 1, 2 * 0, 3 * 0, 4 * 1]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.minimum({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'minimum' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.minimum(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'minimum' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[0.5, 3], [-0.1, -4]]; + var b = [[0.2, 0.4], [0.25, 0.15]]; + var result = tf.minimum(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [0.2, 0.4, -0.1, -4]); + }); +}); +jasmine_util_1.describeWithFlags('mod', test_util_1.ALL_ENVS, function () { + it('float32 and float32', function () { + var a = tf.tensor1d([0.5, 3, -0.1, -4]); + var b = tf.tensor1d([0.2, 0.4, 0.25, 0.15]); + var result = tf.mod(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.1, 0.2, 0.15, 0.05]); + }); + it('int32 and int32', function () { + var a = tf.tensor1d([1, 5, 2, 3], 'int32'); + var b = tf.tensor1d([2, 3, 1, 4], 'int32'); + var result = tf.mod(a, b); + expect(result.shape).toEqual(a.shape); + expect(result.dtype).toBe('int32'); + test_util_1.expectArraysEqual(result, [1, 2, 0, 3]); + }); + it('different dtypes throws error', function () { + var a = tf.tensor1d([1.1, 2.2, 3.3, 4.4], 'float32'); + var b = tf.tensor1d([1, 2, 3, 4], 'int32'); + expect(function () { return tf.mod(a, b); }).toThrowError(); + }); + it('propagates NaN', function () { + var a = tf.tensor1d([5, -1, NaN]); + var b = tf.tensor1d([2, 3, 0.25]); + var result = tf.mod(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1, 2, NaN]); + }); + it('broadcasts Tensor1D and scalar', function () { + var a = tf.tensor1d([0.5, 2.5, -0.1, -4], 'float32'); + var b = tf.scalar(0.6); + var result = tf.mod(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0.5, 0.1, 0.5, 0.2]); + }); + it('broadcasts scalar and Tensor1D', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 3, -1, -4]); + var result = tf.mod(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [2, 2, 0, -2]); + }); + it('broadcasts Tensor1D and Tensor2D', function () { + var a = tf.tensor1d([0.5, 0.3]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.mod(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.1, 0.3, 0.5, 0.0]); + }); + it('broadcasts 2x1 Tensor2D and 2x2 Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3], [2, 1]); + var b = tf.tensor2d([0.2, 0.4, 0.6, 0.15], [2, 2]); + var result = tf.mod(a, b); + expect(result.shape).toEqual(b.shape); + test_util_1.expectArraysClose(result, [0.1, 0.1, 0.3, 0.0]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var b = tf.scalar(0.6); + var dy = tf.scalar(3); + var grads = tf.grads(function (a, b) { return tf.mod(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [3]); + test_util_1.expectArraysClose(db, [3 * -1 * Math.floor(5.2 / 0.6)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1.1, 2.6, 3, 5.9]); + var b = tf.tensor1d([1.0, 2.7, 3, 5.8]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var grads = tf.grads(function (a, b) { return tf.mod(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * 1, 3 * 1, 4 * 1]); + test_util_1.expectArraysClose(db, [ + 1 * -1 * Math.floor(1.1 / 1.0), 2 * -1 * Math.floor(2.6 / 2.7), + 3 * -1 * Math.floor(3 / 3), 4 * -1 * Math.floor(5.9 / 5.8) + ]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([0.5, 0.3, 0.7, 0.91], [2, 2]); + var b = tf.tensor2d([0.2, 0.4, 0.7, 0.15], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.mod(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * 1, 3 * 1, 4 * 1]); + test_util_1.expectArraysClose(db, [ + 1 * -1 * Math.floor(0.5 / 0.2), 2 * -1 * Math.floor(0.3 / 0.4), + 3 * -1 * Math.floor(0.7 / 0.7), 4 * -1 * Math.floor(0.91 / 0.15) + ]); + }); + it('gradients: broadcasts scalar and Tensor1D', function () { + var a = tf.scalar(0.7); + var b = tf.tensor1d([0.2, 0.3, 0.4, 0.5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var grads = tf.grads(function (a, b) { return tf.mod(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 + 2 + 3 + 4]); + test_util_1.expectArraysClose(db, [ + 1 * -1 * Math.floor(0.7 / 0.2), 2 * -1 * Math.floor(0.7 / 0.3), + 3 * -1 * Math.floor(0.7 / 0.4), 4 * -1 * Math.floor(0.7 / 0.5) + ]); + }); + it('broadcasts Tensor1D and Tensor2D', function () { + var a = tf.tensor1d([0.5, 0.3]); + var b = tf.tensor2d([0.2, 0.4, 0.7, 0.15], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.mod(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + expect(da.dtype).toEqual('float32'); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1 + 3 * 1, 2 * 1 + 4 * 1]); + test_util_1.expectArraysClose(db, [ + 1 * -1 * Math.floor(0.5 / 0.2), 2 * -1 * Math.floor(0.3 / 0.4), + 3 * -1 * Math.floor(0.5 / 0.7), 4 * -1 * Math.floor(0.3 / 0.15) + ]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.mod({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'mod' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.mod(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'mod' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[0.5, 3], [-0.1, -4]]; + var b = [[0.2, 0.4], [0.25, 0.15]]; + var result = tf.mod(a, b); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [0.1, 0.2, 0.15, 0.05]); + }); +}); +jasmine_util_1.describeWithFlags('atan2', test_util_1.ALL_ENVS, function () { + it('same shape', function () { + var aValues = [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]; + var bValues = [1.0, 2.5, 3.5, 4.5, 2.0, 5.0]; + var a = tf.tensor2d(aValues, [2, 3]); + var c = tf.tensor2d(bValues, [2, 3]); + var r = tf.atan2(a, c); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.atan2(aValues[i], bValues[i]); + } + test_util_1.expectArraysClose(r, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([1.0, 2.0], [2, 1]); + var c = tf.tensor2d([3.0, NaN], [2, 1]); + var r = tf.atan2(a, c); + test_util_1.expectArraysClose(r, [Math.atan2(1.0, 3.0), NaN]); + }); + it('broadcasting same rank Tensors different shape', function () { + var aValues = [1.0, 2.0, -3.0, -4.0]; + var bValues = [2.0, 3.0]; + var a = tf.tensor2d(aValues, [2, 2]); + var b = tf.tensor2d(bValues, [2, 1]); + var result = tf.atan2(a, b); + expect(result.shape).toEqual([2, 2]); + var expected = [ + Math.atan2(1.0, 2.0), Math.atan2(2.0, 2.0), Math.atan2(-3.0, 3.0), + Math.atan2(-4.0, 3.0) + ]; + test_util_1.expectArraysClose(result, expected); + }); + it('throws when passed tensors of different shapes', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3]); + var b = tf.tensor2d([5, 3, 4, -7], [2, 2]); + expect(function () { return tf.atan2(a, b); }).toThrowError(); + expect(function () { return tf.atan2(b, a); }).toThrowError(); + }); + it('throws when passed tensors of different types', function () { + var a = tf.tensor2d([1, 2, -3, -4, 5, 6], [2, 3]); + var b = tf.tensor2d([5.0, 3.0, 4.0, -7.0], [2, 2]); + expect(function () { return tf.atan2(a, b); }).toThrowError(); + expect(function () { return tf.atan2(b, a); }).toThrowError(); + }); + it('atan2 of scalar and array propagates NaNs', function () { + var c = tf.scalar(NaN); + var a = tf.tensor2d([1, 2, 3], [1, 3]); + var r = tf.atan2(c, a); + test_util_1.expectArraysEqual(r, [NaN, NaN, NaN]); + }); + it('atan2 of scalar and array', function () { + var aValues = [1, 2, 3, 4, 5, 6]; + var a = tf.tensor2d(aValues, [2, 3]); + var c = tf.scalar(2); + var r = tf.atan2(a, c); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.atan2(aValues[i], 2); + } + test_util_1.expectArraysClose(r, expected); + }); + it('gradient: Scalar', function () { + var a = tf.scalar(5); + var b = tf.scalar(2); + var dy = tf.scalar(4); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [4 * 2 / 29]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [4 * -5 / 29]); + }); + it('gradient: Tensor1D', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([1, 10, 20]); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 3 / 10, 10 * 4 / 20, 20 * 5 / 34]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 * 1 / 10, -10 * 2 / 20, -20 * 3 / 34]); + }); + it('gradient: Tensor2D', function () { + var a = tf.tensor2d([3, 1, 2, 3], [2, 2]); + var b = tf.tensor2d([1, 3, 4, 5], [2, 2]); + var dy = tf.tensor2d([1, 10, 15, 20], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1 / 10, 10 * 3 / 10, 15 * 4 / 20, 20 * 5 / 34]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-1 * 3 / 10, -10 * 1 / 10, -15 * 2 / 20, -20 * 3 / 34]); + }); + it('gradient: scalar / Tensor1D', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([3, 4, 5]); + var dy = tf.tensor1d([6, 7, 8]); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 * 3 / 13 + 7 * 4 / 20 + 8 * 5 / 29]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 2 / 13, -7 * 2 / 20, -8 * 2 / 29]); + }); + it('gradient: Tensor2D / scalar', function () { + var a = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var b = tf.scalar(2); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 * 2 / 8, 7 * 2 / 13, 8 * 2 / 20, 9 * 2 / 29]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 2 / 8 + -7 * 3 / 13 + -8 * 4 / 20 + -9 * 5 / 29]); + }); + it('gradient: Tensor2D / Tensor2D w/ broadcast', function () { + var a = tf.tensor2d([3, 4], [2, 1]); + var b = tf.tensor2d([[2, 3], [4, 5]], [2, 2]); + var dy = tf.tensor2d([[6, 7], [8, 9]], [2, 2]); + var grads = tf.grads(function (a, b) { return tf.atan2(a, b); }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [6 * 2 / 13 + 7 * 3 / 18, 8 * 4 / 32 + 9 * 5 / 41]); + expect(db.shape).toEqual(b.shape); + expect(db.dtype).toEqual('float32'); + test_util_1.expectArraysClose(db, [-6 * 3 / 13, -7 * 3 / 18, -8 * 4 / 32, -9 * 4 / 41]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.atan2({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'atan2' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.atan2(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'atan2' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[1, 2, 3], [4, 5, 6]]; + var c = 2; + var r = tf.atan2(a, c); + var expected = []; + for (var i = 0; i < 6; i++) { + expected[i] = Math.atan2(i + 1, 2); + } + test_util_1.expectArraysClose(r, expected); + }); +}); +jasmine_util_1.describeWithFlags('div', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([0, 1, -2, -4, 4, -4]); + var b = tf.tensor1d([0.15, 0.2, 0.25, 0.5, 0.7, 1.2]); + var result = tf.div(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0, 5.0, -8.0, -8.0, 5.714285850524902, -3.3333332538604736]); + }); + it('floored internally', function () { + var a = tf.tensor1d([10, 20, -20, -40], 'int32'); + var b = tf.tensor1d([10, 12, 8, 5], 'int32'); + var result = tf.div(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1, 1, -3, -8]); + }); + it('floorDiv', function () { + var a = tf.tensor1d([10, 20, -20, -40], 'int32'); + var b = tf.tensor1d([10, 12, 8, 5], 'int32'); + var result = tf.floorDiv(a, b); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1, 1, -3, -8]); + }); +}); +//# sourceMappingURL=binary_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js.map new file mode 100644 index 0000000..7ca3680 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/binary_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"binary_ops_test.js","sourceRoot":"","sources":["../../src/ops/binary_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.d.ts new file mode 100644 index 0000000..2abadb8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.d.ts @@ -0,0 +1,4 @@ +export declare function getBroadcastDims(inShape: number[], outShape: number[]): number[]; +export declare function getReductionAxes(inShape: number[], outShape: number[]): number[]; +export declare function broadcastDimsAreOuter(dims: number[]): boolean; +export declare function assertAndGetBroadcastShape(shapeA: number[], shapeB: number[]): number[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js new file mode 100644 index 0000000..3c0f3b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js @@ -0,0 +1,55 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function getBroadcastDims(inShape, outShape) { + var inRank = inShape.length; + var dims = []; + for (var i = 0; i < inRank; i++) { + var dim = inRank - 1 - i; + var a = inShape[dim] || 1; + var b = outShape[outShape.length - 1 - i] || 1; + if (b > 1 && a === 1) { + dims.unshift(dim); + } + } + return dims; +} +exports.getBroadcastDims = getBroadcastDims; +function getReductionAxes(inShape, outShape) { + var result = []; + for (var i = 0; i < outShape.length; i++) { + var inDim = inShape[inShape.length - i - 1]; + var outAxis = outShape.length - i - 1; + var outDim = outShape[outAxis]; + if (inDim == null || (inDim === 1 && outDim > 1)) { + result.unshift(outAxis); + } + } + return result; +} +exports.getReductionAxes = getReductionAxes; +function broadcastDimsAreOuter(dims) { + for (var i = 0; i < dims.length; i++) { + if (dims[i] !== i) { + return false; + } + } + return true; +} +exports.broadcastDimsAreOuter = broadcastDimsAreOuter; +function assertAndGetBroadcastShape(shapeA, shapeB) { + var result = []; + var errMsg = "Operands could not be broadcast together with shapes " + + (shapeA + " and " + shapeB + "."); + var l = Math.max(shapeA.length, shapeB.length); + for (var i = 0; i < l; i++) { + var a = shapeA[shapeA.length - i - 1] || 1; + var b = shapeB[shapeB.length - i - 1] || 1; + if (a > 1 && b > 1 && a !== b) { + throw Error(errMsg); + } + result.unshift(Math.max(a, b)); + } + return result; +} +exports.assertAndGetBroadcastShape = assertAndGetBroadcastShape; +//# sourceMappingURL=broadcast_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js.map new file mode 100644 index 0000000..db35be2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"broadcast_util.js","sourceRoot":"","sources":["../../src/ops/broadcast_util.ts"],"names":[],"mappings":";;AA0BA,0BACI,OAAiB,EAAE,QAAkB;IACvC,IAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAC9B,IAAM,IAAI,GAAa,EAAE,CAAC;IAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE;QAC/B,IAAM,GAAG,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAM,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAM,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;QACjD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACpB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SACnB;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAbD,4CAaC;AAMD,0BACI,OAAiB,EAAE,QAAkB;IACvC,IAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACxC,IAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;QACxC,IAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;QACjC,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,MAAM,GAAG,CAAC,CAAC,EAAE;YAChD,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;SACzB;KACF;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAZD,4CAYC;AAMD,+BAAsC,IAAc;IAClD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACpC,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;YACjB,OAAO,KAAK,CAAC;SACd;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAPD,sDAOC;AAED,oCACI,MAAgB,EAAE,MAAgB;IACpC,IAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,IAAM,MAAM,GAAG,uDAAuD;SAC/D,MAAM,aAAQ,MAAM,MAAG,CAAA,CAAC;IAC/B,IAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAEjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1B,IAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC7B,MAAM,KAAK,CAAC,MAAM,CAAC,CAAC;SACrB;QACD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KAChC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAhBD,gEAgBC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js new file mode 100644 index 0000000..e4e3b58 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js @@ -0,0 +1,147 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var broadcast_util = require("./broadcast_util"); +describe('broadcast_util.getBroadcastShape', function () { + it('two scalars', function () { + var res = broadcast_util.assertAndGetBroadcastShape([], []); + expect(res).toEqual([]); + }); + it('scalar and 1d', function () { + var res = broadcast_util.assertAndGetBroadcastShape([6], []); + expect(res).toEqual([6]); + }); + it('scalar and 2d', function () { + var res = broadcast_util.assertAndGetBroadcastShape([2, 6], []); + expect(res).toEqual([2, 6]); + }); + it('1d and 2d', function () { + var res = broadcast_util.assertAndGetBroadcastShape([6], [2, 6]); + expect(res).toEqual([2, 6]); + }); + it('2d and 3d', function () { + var res = broadcast_util.assertAndGetBroadcastShape([2, 6], [7, 2, 6]); + expect(res).toEqual([7, 2, 6]); + }); + it('3d and 3d', function () { + var res = broadcast_util.assertAndGetBroadcastShape([1, 1, 6], [7, 2, 6]); + expect(res).toEqual([7, 2, 6]); + }); + it('incompatible inner shape', function () { + var f = function () { + return broadcast_util.assertAndGetBroadcastShape([7, 2, 5], [7, 2, 6]); + }; + expect(f).toThrowError(); + }); + it('incompatible middle shape', function () { + var f = function () { + return broadcast_util.assertAndGetBroadcastShape([7, 3, 6], [7, 2, 6]); + }; + expect(f).toThrowError(); + }); + it('compatible with broadcasting support', function () { + var res = broadcast_util.assertAndGetBroadcastShape([7, 1, 1], [7, 1, 1]); + expect(res).toEqual([7, 1, 1]); + }); + it('3d and 3d, each gets broadcasted', function () { + var res = broadcast_util.assertAndGetBroadcastShape([4, 1, 7], [1, 3, 1]); + expect(res).toEqual([4, 3, 7]); + }); +}); +describe('broadcast_util.getBroadcastDims', function () { + it('[] => []', function () { + var dims = broadcast_util.getBroadcastDims([], []); + expect(dims.length).toBe(0); + }); + it('[] => [5, 4]', function () { + var dims = broadcast_util.getBroadcastDims([], [5, 4]); + expect(dims.length).toBe(0); + }); + it('[1] => [5]', function () { + var dims = broadcast_util.getBroadcastDims([1], [5]); + expect(dims).toEqual([0]); + }); + it('[5, 1] => [5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([5, 1], [5, 3]); + expect(dims).toEqual([1]); + }); + it('[1, 3] => [5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([1, 3], [5, 3]); + expect(dims).toEqual([0]); + }); + it('[1, 1] => [5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([1, 1], [5, 3]); + expect(dims).toEqual([0, 1]); + }); + it('[4, 1, 3] => [4, 5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([4, 1, 3], [4, 5, 3]); + expect(dims).toEqual([1]); + }); +}); +describe('broadcast_util.getReductionAxes', function () { + it('[] => []', function () { + var axes = broadcast_util.getReductionAxes([], []); + expect(axes).toEqual([]); + }); + it('[] => [5, 4]', function () { + var axes = broadcast_util.getReductionAxes([], [5, 4]); + expect(axes).toEqual([0, 1]); + }); + it('[1] => [5]', function () { + var axes = broadcast_util.getReductionAxes([1], [5]); + expect(axes).toEqual([0]); + }); + it('[5, 1] => [5, 3]', function () { + var axes = broadcast_util.getReductionAxes([5, 1], [5, 3]); + expect(axes).toEqual([1]); + }); + it('[1, 3] => [5, 3]', function () { + var axes = broadcast_util.getReductionAxes([1, 3], [5, 3]); + expect(axes).toEqual([0]); + }); + it('[1, 1] => [5, 3]', function () { + var axes = broadcast_util.getReductionAxes([1, 1], [5, 3]); + expect(axes).toEqual([0, 1]); + }); + it('[4, 1, 3] => [4, 5, 3]', function () { + var axes = broadcast_util.getReductionAxes([4, 1, 3], [4, 5, 3]); + expect(axes).toEqual([1]); + }); +}); +describe('broadcast_util.broadcastDimsAreOuter', function () { + it('[] => []', function () { + var dims = broadcast_util.getBroadcastDims([], []); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(true); + }); + it('[] => [5, 4]', function () { + var dims = broadcast_util.getBroadcastDims([], [5, 4]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(true); + }); + it('[1] => [5]', function () { + var dims = broadcast_util.getBroadcastDims([1], [5]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(true); + }); + it('[5, 1] => [5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([5, 1], [5, 3]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(false); + }); + it('[1, 1] => [5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([1, 1], [5, 3]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(true); + }); + it('[4, 1, 3] => [4, 5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([4, 1, 3], [4, 5, 3]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(false); + }); + it('[1, 1, 3] => [4, 5, 3]', function () { + var dims = broadcast_util.getBroadcastDims([1, 1, 3], [4, 5, 3]); + var areOuter = broadcast_util.broadcastDimsAreOuter(dims); + expect(areOuter).toBe(true); + }); +}); +//# sourceMappingURL=broadcast_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js.map new file mode 100644 index 0000000..1d7d8a6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/broadcast_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"broadcast_util_test.js","sourceRoot":"","sources":["../../src/ops/broadcast_util_test.ts"],"names":[],"mappings":";;AAiBA,iDAAmD;AAEnD,QAAQ,CAAC,kCAAkC,EAAE;IAC3C,EAAE,CAAC,aAAa,EAAE;QAChB,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAC9D,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE;QAClB,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/D,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE;QAClB,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAClE,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzE,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,CAAC,GAAG;YACN,OAAA,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAA/D,CAA+D,CAAC;QACpE,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,CAAC,GAAG;YACN,OAAA,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAA/D,CAA+D,CAAC;QACpE,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE;QACzC,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,GAAG,GAAG,cAAc,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,iCAAiC,EAAE;IAC1C,EAAE,CAAC,UAAU,EAAE;QACb,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,iCAAiC,EAAE;IAC1C,EAAE,CAAC,UAAU,EAAE;QACb,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,sCAAsC,EAAE;IAC/C,EAAE,CAAC,UAAU,EAAE;QACb,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACvD,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,IAAI,GAAG,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAM,QAAQ,GAAG,cAAc,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js new file mode 100644 index 0000000..7b72a24 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js @@ -0,0 +1,20 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('clone', test_util_1.ALL_ENVS, function () { + it('returns a tensor with the same shape and value', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9], [3, 3]); + var aPrime = tf.clone(a); + expect(aPrime.shape).toEqual(a.shape); + test_util_1.expectArraysClose(aPrime, a); + }); + it('accepts a tensor-like object', function () { + var res = tf.clone([[1, 2, 3], [4, 5, 6]]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); +}); +//# sourceMappingURL=clone_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js.map new file mode 100644 index 0000000..e0fc2fa --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/clone_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"clone_test.js","sourceRoot":"","sources":["../../src/ops/clone_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,OAAO,EAAE,oBAAQ,EAAE;IACnC,EAAE,CAAC,gDAAgD,EAAE;QACnD,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,IAAM,MAAM,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACtC,6BAAiB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,6BAAiB,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compare.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.d.ts new file mode 100644 index 0000000..f77a110 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.d.ts @@ -0,0 +1,27 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function notEqual_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function notEqualStrict_(a: T | TensorLike, b: T | TensorLike): T; +declare function less_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function lessStrict_(a: T | TensorLike, b: T | TensorLike): T; +declare function equal_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function equalStrict_(a: T | TensorLike, b: T | TensorLike): T; +declare function lessEqual_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function lessEqualStrict_(a: T | TensorLike, b: T | TensorLike): T; +declare function greater_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function greaterStrict_(a: T | TensorLike, b: T | TensorLike): T; +declare function greaterEqual_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function greaterEqualStrict_(a: T | TensorLike, b: T | TensorLike): T; +export declare const equal: typeof equal_; +export declare const equalStrict: typeof equalStrict_; +export declare const greater: typeof greater_; +export declare const greaterEqual: typeof greaterEqual_; +export declare const greaterEqualStrict: typeof greaterEqualStrict_; +export declare const greaterStrict: typeof greaterStrict_; +export declare const less: typeof less_; +export declare const lessEqual: typeof lessEqual_; +export declare const lessEqualStrict: typeof lessEqualStrict_; +export declare const lessStrict: typeof lessStrict_; +export declare const notEqual: typeof notEqual_; +export declare const notEqualStrict: typeof notEqualStrict_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js new file mode 100644 index 0000000..d4ea914 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js @@ -0,0 +1,99 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_1 = require("../tensor_util"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var broadcast_util_1 = require("./broadcast_util"); +var operation_1 = require("./operation"); +function notEqual_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'notEqual'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'notEqual'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.notEqual($a, $b); }, { $a: $a, $b: $b }); +} +function notEqualStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'notEqualStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'notEqualStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in notEqualStrict: '); + return $a.notEqual($b); +} +function less_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'less'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'less'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.less($a, $b); }, { $a: $a, $b: $b }); +} +function lessStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'lessStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'lessStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in lessStrict: '); + return $a.less($b); +} +function equal_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'equal'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'equal'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.equal($a, $b); }, { $a: $a, $b: $b }); +} +function equalStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'equalStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'equalStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in equalStrict: '); + return $a.equal($b); +} +function lessEqual_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'lessEqual'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'lessEqual'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.lessEqual($a, $b); }, { $a: $a, $b: $b }); +} +function lessEqualStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'lessEqualStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'lessEqualStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in lessEqualStrict: '); + return $a.lessEqual($b); +} +function greater_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'greater'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'greater'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.greater($a, $b); }, { $a: $a, $b: $b }); +} +function greaterStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'greaterStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'greaterStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in greaterStrict: '); + return $a.greater($b); +} +function greaterEqual_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'greaterEqual'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'greaterEqual'); + tensor_util_1.assertTypesMatch($a, $b); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.greaterEqual($a, $b); }, { $a: $a, $b: $b }); +} +function greaterEqualStrict_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'greaterEqualStrict'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'greaterEqualStrict'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in greaterEqualStrict: '); + return $a.greaterEqual($b); +} +exports.equal = operation_1.op({ equal_: equal_ }); +exports.equalStrict = operation_1.op({ equalStrict_: equalStrict_ }); +exports.greater = operation_1.op({ greater_: greater_ }); +exports.greaterEqual = operation_1.op({ greaterEqual_: greaterEqual_ }); +exports.greaterEqualStrict = operation_1.op({ greaterEqualStrict_: greaterEqualStrict_ }); +exports.greaterStrict = operation_1.op({ greaterStrict_: greaterStrict_ }); +exports.less = operation_1.op({ less_: less_ }); +exports.lessEqual = operation_1.op({ lessEqual_: lessEqual_ }); +exports.lessEqualStrict = operation_1.op({ lessEqualStrict_: lessEqualStrict_ }); +exports.lessStrict = operation_1.op({ lessStrict_: lessStrict_ }); +exports.notEqual = operation_1.op({ notEqual_: notEqual_ }); +exports.notEqualStrict = operation_1.op({ notEqualStrict_: notEqualStrict_ }); +//# sourceMappingURL=compare.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js.map new file mode 100644 index 0000000..826f987 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compare.js.map @@ -0,0 +1 @@ +{"version":3,"file":"compare.js","sourceRoot":"","sources":["../../src/ops/compare.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js new file mode 100644 index 0000000..199e98f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js @@ -0,0 +1,1775 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var test_util_1 = require("../test_util"); +var jasmine_util_1 = require("../jasmine_util"); +jasmine_util_1.describeWithFlags('equal', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.equal(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.equal(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0]); + }); + it('scalar and 1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([1, 2, 3, 4, 5, 2]); + var res = tf.equal(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([6]); + test_util_1.expectArraysEqual(res, [0, 1, 0, 0, 0, 1]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 0, 0, 0]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 4.1, 5.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 1, 1, 0, 0, 0]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 1, 0, 1, 0, 0]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 1, 0, 1, 0, 0]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1, 0]); + }); + it('2D and 2D broadcast each with 1 dim', function () { + var a = tf.tensor2d([1, 2, 5], [1, 3]); + var b = tf.tensor2d([5, 1], [2, 1]); + var res = tf.equal(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysEqual(res, [0, 0, 1, 1, 0, 0]); + }); + it('2D and scalar broadcast', function () { + var a = tf.tensor2d([1, 2, 3, 2, 5, 6], [2, 3]); + var b = tf.scalar(2); + var res = tf.equal(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysEqual(res, [0, 1, 0, 1, 0, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [12]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 0, 0, 1]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1, 1, 1]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [12.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 0, 0, 1]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1, 1, 1]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0]); + }); + it('broadcasting Tensor3D shapes - float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1, 0, 1, 0]); + }); + it('3D and scalar', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, -1], [2, 3, 1]); + var b = tf.scalar(-1); + var res = tf.equal(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3, 1]); + test_util_1.expectArraysEqual(res, [0, 0, 0, 0, 0, 1]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 8], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 1]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 0]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 8.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 1]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 1, 1, 1]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 0, 0]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 0, 0, 0, 1, 0, 0, 0]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [1, 0, 0, 0, 1, 0, 0, 0]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 1.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.equal({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'equal' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.equal(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'equal' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + test_util_1.expectArraysClose(tf.equal(a, b), [0, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('equalStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 0, 0, 0]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 4.1, 5.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 1, 1, 0, 0, 0]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1]); + }); + it('mismatch Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [12]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 0, 0, 1]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1, 1, 1]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [12.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 0, 0, 1]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1, 1, 1]); + }); + it('mismatch Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor3D shapes - float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1, 0, 1, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 8], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 1]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 0]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 8.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 1]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [1, 1, 1, 1]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 0, 0]); + }); + it('mismatch Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var f = function () { + tf.equalStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 1.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1, 0]); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + test_util_1.expectArraysClose(tf.equalStrict(a, b), [0, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('notEqual', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.notEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.notEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1]); + }); + it('works with NaNs', function () { + var a = tf.tensor1d([2, 5, NaN]); + var b = tf.tensor1d([4, 5, -1]); + var res = tf.notEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysEqual(res, [1, 0, 1]); + }); + it('scalar and 1D broadcast', function () { + var a = tf.scalar(2); + var b = tf.tensor1d([1, 2, 3, 4, 5, 2]); + var res = tf.notEqual(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([6]); + test_util_1.expectArraysEqual(res, [1, 0, 1, 1, 1, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 1, 1, 1]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 4.1, 5.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 0, 0, 1, 1, 1]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 0, 1, 0, 1, 1]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 0, 1, 0, 1, 1]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0, 1]); + }); + it('2D and scalar broadcast', function () { + var a = tf.tensor2d([1, 2, 3, 2, 5, 6], [2, 3]); + var b = tf.scalar(2); + var res = tf.notEqual(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysEqual(res, [1, 0, 1, 0, 1, 1]); + }); + it('2D and 2D broadcast each with 1 dim', function () { + var a = tf.tensor2d([1, 2, 5], [1, 3]); + var b = tf.tensor2d([5, 1], [2, 1]); + var res = tf.notEqual(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3]); + test_util_1.expectArraysEqual(res, [1, 1, 0, 0, 1, 1]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [12]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 1, 1, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [12.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 1, 1, 0]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 1, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1]); + }); + it('broadcasting Tensor3D shapes - float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 1, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0, 1, 0, 1]); + }); + it('3D and scalar', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, -1], [2, 3, 1]); + var b = tf.scalar(-1); + var res = tf.notEqual(a, b); + expect(res.dtype).toBe('bool'); + expect(res.shape).toEqual([2, 3, 1]); + test_util_1.expectArraysEqual(res, [1, 1, 1, 1, 1, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 8], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 0]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 1]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 8.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 0]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 1, 1, 1, 0, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [0, 1, 1, 1, 0, 1, 1, 1]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 1.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0, 1]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.notEqual({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'notEqual' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.notEqual(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'notEqual' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + test_util_1.expectArraysClose(tf.notEqual(a, b), [1, 1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('notEqualStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1]); + }); + it('strict version throws when x and y are different shape', function () { + var a = tf.tensor1d([2]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.notEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.notEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 1, 1, 1]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 4.1, 5.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 0, 0, 1, 1, 1]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0]); + }); + it('mismatch Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0, 1]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [12]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 1, 1, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [12.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 1, 1, 0]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('mismatch Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor3D shapes - float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0, 1, 0, 1]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 8], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 0]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 1]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 8.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 0]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 1, 1]); + }); + it('mismatch Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatch Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var f = function () { + tf.notEqualStrict(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 1.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0, 1]); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + test_util_1.expectArraysClose(tf.notEqualStrict(a, b), [1, 1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('less', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.less(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.less(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 3.1, 6.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0, 1, 1]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0, 1, 1]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [0.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [11]]], [2, 3, 1], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 0]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [11.1]]], [2, 3, 1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.0]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 1]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0]); + }); + it('broadcasting Tensor3D float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 1, 0, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 7], [2, 2, 1, 1], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 7.1], [2, 2, 1, 1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1, 1, 0, 1, 0, 0]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1, 1, 0, 1, 0, 0]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.less({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'less' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.less(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'less' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.less(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('lessStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - strict version throws when a and b are different shape', function () { + var a = tf.tensor1d([2]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.lessStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessStrict(b, a); }).toThrowError(); + }); + it('Tensor2D - strict version throws when a and b are different shape', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + expect(function () { return tf.lessStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessStrict(b, a); }).toThrowError(); + }); + it('Tensor3D - strict version throws when a and b are different shape', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + expect(function () { return tf.lessStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessStrict(b, a); }).toThrowError(); + }); + it('Tensor4D - strict version throws when a and b are different shape', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + expect(function () { return tf.lessStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessStrict(b, a); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.lessStrict(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('lessEqual', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.lessEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.lessEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 3.1, 6.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1, 1, 1, 1]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [0.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [11]]], [2, 3, 1], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 1]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [11.1]]], [2, 3, 1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.2]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 0]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0]); + }); + it('broadcasting Tensor3D float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 1, 1, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 7], [2, 2, 1, 1], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 7.1], [2, 2, 1, 1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 1, 0, 0]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 1, 0, 0]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 1, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.lessEqual({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'lessEqual' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.lessEqual(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'lessEqual' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.lessEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('lessEqualStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - strict version throws when a and b are different shape', function () { + var a = tf.tensor1d([2]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.lessEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor2D - strict version throws when a and b are different shape', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + expect(function () { return tf.lessEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor3D - strict version throws when a and b are different shape', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + expect(function () { return tf.lessEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor4D - strict version throws when a and b are different shape', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + expect(function () { return tf.lessEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.lessEqualStrict(b, a); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.lessEqualStrict(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('greater', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + a = tf.tensor1d([3, 3], 'int32'); + b = tf.tensor1d([0, 0], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + a = tf.tensor1d([3.123, 3.321], 'float32'); + b = tf.tensor1d([0.45, 0.123], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.greater(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.greater(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 11]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 0]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 11.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 3.1, 6.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 0]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0, 0, 0]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0, 0, 0]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [0.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [11]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [11]]], [2, 3, 1], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 0]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [11.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [11.1]]], [2, 3, 1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 0]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.2]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 1]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1]); + }); + it('broadcasting Tensor3D float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0, 0, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 8], [2, 2, 1, 1], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 0]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + a = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 8.1], [2, 2, 1, 1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 0]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + a = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 0, 1, 1]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 0, 0, 1, 1]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.greater({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'greater' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.greater(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'greater' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.greater(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('greaterStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - strict version throws when a and b are different shape', function () { + var a = tf.tensor1d([2]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.greaterStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterStrict(b, a); }).toThrowError(); + }); + it('Tensor2D - strict version throws when a and b are different shape', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + expect(function () { return tf.greaterStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterStrict(b, a); }).toThrowError(); + }); + it('Tensor3D - strict version throws when a and b are different shape', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + expect(function () { return tf.greaterStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterStrict(b, a); }).toThrowError(); + }); + it('Tensor4D - strict version throws when a and b are different shape', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + expect(function () { return tf.greaterStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterStrict(b, a); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.greaterStrict(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('greaterEqual', test_util_1.ALL_ENVS, function () { + it('Tensor1D - int32', function () { + var a = tf.tensor1d([1, 4, 5], 'int32'); + var b = tf.tensor1d([2, 3, 5], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1]); + a = tf.tensor1d([2, 2, 2], 'int32'); + b = tf.tensor1d([2, 2, 2], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1]); + a = tf.tensor1d([0, 0], 'int32'); + b = tf.tensor1d([3, 3], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0]); + }); + it('Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, 4.1, 5.1], 'float32'); + var b = tf.tensor1d([2.2, 3.2, 5.1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1]); + a = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + b = tf.tensor1d([2.31, 2.31, 2.31], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1]); + a = tf.tensor1d([0.45, 0.123], 'float32'); + b = tf.tensor1d([3.123, 3.321], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0]); + }); + it('mismatched Tensor1D shapes - int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + var b = tf.tensor1d([1, 2, 3], 'int32'); + var f = function () { + tf.greaterEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('mismatched Tensor1D shapes - float32', function () { + var a = tf.tensor1d([1.1, 2.1], 'float32'); + var b = tf.tensor1d([1.1, 2.1, 3.1], 'float32'); + var f = function () { + tf.greaterEqual(a, b); + }; + expect(f).toThrowError(); + }); + it('NaNs in Tensor1D - float32', function () { + var a = tf.tensor1d([1.1, NaN, 2.1], 'float32'); + var b = tf.tensor1d([2.1, 3.1, NaN], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0]); + }); + it('Tensor2D - int32', function () { + var a = tf.tensor2d([[1, 4, 5], [8, 9, 12]], [2, 3], 'int32'); + var b = tf.tensor2d([[2, 3, 6], [7, 10, 11]], [2, 3], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 1]); + a = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + b = tf.tensor2d([[0, 0], [1, 1]], [2, 2], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, 4.1, 5.1], [8.1, 9.1, 12.1]], [2, 3], 'float32'); + var b = tf.tensor2d([[2.1, 3.1, 6.1], [7.1, 10.1, 11.1]], [2, 3], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 1]); + a = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + b = tf.tensor2d([[0.2, 0.2], [1.2, 1.2]], [2, 2], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes - int32', function () { + var a = tf.tensor2d([[3], [7]], [2, 1], 'int32'); + var b = tf.tensor2d([[2, 3, 4], [7, 8, 9]], [2, 3], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 0, 1, 0, 0]); + }); + it('broadcasting Tensor2D shapes - float32', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 0, 1, 0, 0]); + }); + it('NaNs in Tensor2D - float32', function () { + var a = tf.tensor2d([[1.1, NaN], [0.1, NaN]], [2, 2], 'float32'); + var b = tf.tensor2d([[0.1, NaN], [1.1, NaN]], [2, 2], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0]); + }); + it('Tensor3D - int32', function () { + var a = tf.tensor3d([[[1], [4], [5]], [[8], [9], [12]]], [2, 3, 1], 'int32'); + var b = tf.tensor3d([[[2], [3], [6]], [[7], [10], [11]]], [2, 3, 1], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 1]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 1]); + }); + it('Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [4.1], [5.1]], [[8.1], [9.1], [12.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[2.1], [3.1], [6.1]], [[7.1], [10.1], [11.1]]], [2, 3, 1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1, 0, 1]); + a = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.2]]], [2, 3, 1], 'float32'); + b = tf.tensor3d([[[0.1], [0.1], [0.1]], [[1.1], [1.1], [1.1]]], [2, 3, 1], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1, 1, 1]); + }); + it('broadcasting Tensor3D shapes - int32', function () { + var a = tf.tensor3d([[[1, 0], [2, 3], [4, 5]], [[6, 7], [9, 8], [10, 11]]], [2, 3, 2], 'int32'); + var b = tf.tensor3d([[[1], [2], [3]], [[7], [10], [9]]], [2, 3, 1], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 1]); + }); + it('broadcasting Tensor3D float32', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 1]); + }); + it('NaNs in Tensor3D - float32', function () { + var a = tf.tensor3d([[[1.1], [NaN], [1.1]], [[0.1], [0.1], [0.1]]], [2, 3, 1], 'float32'); + var b = tf.tensor3d([[[0.1], [0.1], [1.1]], [[1.1], [0.1], [NaN]]], [2, 3, 1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 1, 0, 1, 0]); + }); + it('Tensor4D - int32', function () { + var a = tf.tensor4d([1, 4, 5, 8], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([2, 3, 6, 7], [2, 2, 1, 1], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1]); + a = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([0, 1, 2, 3], [2, 2, 1, 1], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'int32'); + b = tf.tensor4d([2, 2, 2, 2], [2, 2, 1, 1], 'int32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, 4.1, 5.1, 8.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([2.1, 3.1, 6.1, 7.1], [2, 2, 1, 1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 0, 1]); + a = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([0.1, 1.1, 2.2, 3.3], [2, 2, 1, 1], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 1, 1, 1]); + a = tf.tensor4d([0.1, 0.1, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + b = tf.tensor4d([1.1, 1.1, 1.1, 1.1], [2, 2, 1, 1], 'float32'); + res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 0, 0, 0]); + }); + it('broadcasting Tensor4D shapes - int32', function () { + var a = tf.tensor4d([1, 2, 5, 9], [2, 2, 1, 1], 'int32'); + var b = tf.tensor4d([[[[1, 2]], [[3, 4]]], [[[5, 6]], [[7, 8]]]], [2, 2, 1, 2], 'int32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0, 1, 0, 1, 1]); + }); + it('broadcasting Tensor4D shapes - float32', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0, 1, 0, 1, 1]); + }); + it('NaNs in Tensor4D - float32', function () { + var a = tf.tensor4d([1.1, NaN, 0.1, 0.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([0.1, 1.1, 1.1, NaN], [2, 2, 1, 1], 'float32'); + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [1, 0, 0, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.greaterEqual({}, tf.scalar(1)); }) + .toThrowError(/Argument 'a' passed to 'greaterEqual' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.greaterEqual(tf.scalar(1), {}); }) + .toThrowError(/Argument 'b' passed to 'greaterEqual' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.greaterEqual(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1]); + }); +}); +jasmine_util_1.describeWithFlags('greaterEqualStrict', test_util_1.ALL_ENVS, function () { + it('Tensor1D - strict version throws when a and b are different shape', function () { + var a = tf.tensor1d([2]); + var b = tf.tensor1d([4, 2, -1]); + expect(function () { return tf.greaterEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor2D - strict version throws when a and b are different shape', function () { + var a = tf.tensor2d([[1.1], [7.1]], [2, 1], 'float32'); + var b = tf.tensor2d([[0.1, 1.1, 2.1], [7.1, 8.1, 9.1]], [2, 3], 'float32'); + expect(function () { return tf.greaterEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor3D - strict version throws when a and b are different shape', function () { + var a = tf.tensor3d([ + [[1.1, 0.1], [2.1, 3.1], [4.1, 5.1]], + [[6.1, 7.1], [9.1, 8.1], [10.1, 11.1]] + ], [2, 3, 2], 'float32'); + var b = tf.tensor3d([[[1.1], [2.1], [3.1]], [[7.1], [10.1], [9.1]]], [2, 3, 1], 'float32'); + expect(function () { return tf.greaterEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterEqualStrict(b, a); }).toThrowError(); + }); + it('Tensor4D - strict version throws when a and b are different shape', function () { + var a = tf.tensor4d([1.1, 2.1, 5.1, 9.1], [2, 2, 1, 1], 'float32'); + var b = tf.tensor4d([[[[1.1, 2.1]], [[3.1, 4.1]]], [[[5.1, 6.1]], [[7.1, 8.1]]]], [2, 2, 1, 2], 'float32'); + expect(function () { return tf.greaterEqualStrict(a, b); }).toThrowError(); + expect(function () { return tf.greaterEqualStrict(b, a); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var a = [1, 4, 5]; + var b = [2, 3, 5]; + var res = tf.greaterEqualStrict(a, b); + expect(res.dtype).toBe('bool'); + test_util_1.expectArraysClose(res, [0, 1, 1]); + }); +}); +//# sourceMappingURL=compareop_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js.map new file mode 100644 index 0000000..c99f12f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/compareop_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"compareop_test.js","sourceRoot":"","sources":["../../src/ops/compareop_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.d.ts new file mode 100644 index 0000000..db35d7b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.d.ts @@ -0,0 +1,13 @@ +import { Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function concat1d_(tensors: Tensor1D[] | TensorLike[]): Tensor1D; +declare function concat2d_(tensors: Tensor2D[] | TensorLike[], axis: number): Tensor2D; +declare function concat3d_(tensors: Tensor3D[] | TensorLike[], axis: number): Tensor3D; +declare function concat4d_(tensors: Tensor4D[] | TensorLike[], axis: number): Tensor4D; +declare function concat_(tensors: T[] | TensorLike[], axis?: number): T; +export declare const concat: typeof concat_; +export declare const concat1d: typeof concat1d_; +export declare const concat2d: typeof concat2d_; +export declare const concat3d: typeof concat3d_; +export declare const concat4d: typeof concat4d_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js new file mode 100644 index 0000000..093da74 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js @@ -0,0 +1,52 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var axis_util_1 = require("./axis_util"); +var concat_util = require("./concat_util"); +var operation_1 = require("./operation"); +function concat1d_(tensors) { + return exports.concat(tensors, 0); +} +function concat2d_(tensors, axis) { + return exports.concat(tensors, axis); +} +function concat3d_(tensors, axis) { + return exports.concat(tensors, axis); +} +function concat4d_(tensors, axis) { + return exports.concat(tensors, axis); +} +function concat_(tensors, axis) { + if (axis === void 0) { axis = 0; } + util_1.assert(tensors.length >= 1, 'Pass at least one tensor to concat'); + var $tensors = tensor_util_env_1.convertToTensorArray(tensors, 'tensors', 'concat'); + var result = $tensors[0]; + if ($tensors.length === 1) { + return result; + } + var axes = axis_util_1.parseAxisParam(axis, result.shape); + for (var i = 1; i < $tensors.length; ++i) { + result = concat2Tensors(result, $tensors[i], axes[0]); + } + return result; +} +function concat2Tensors(a, b, axis) { + concat_util.assertParams(a.shape, b.shape, axis); + var outShape = concat_util.computeOutShape(a.shape, b.shape, axis); + var a2D = a.as2D(-1, util_1.sizeFromShape(a.shape.slice(axis))); + var b2D = b.as2D(-1, util_1.sizeFromShape(b.shape.slice(axis))); + var _a = concat_util.computeGradientSliceShapes(a2D.shape, b2D.shape), aBegin = _a.aBegin, aSize = _a.aSize, bBegin = _a.bBegin, bSize = _a.bSize; + var der = function (dy) { + return { a: function () { return dy.slice(aBegin, aSize); }, b: function () { return dy.slice(bBegin, bSize); } }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.concat(a2D, b2D); }, { a: a2D, b: b2D }, der); + return res.reshape(outShape); +} +exports.concat = operation_1.op({ concat_: concat_ }); +exports.concat1d = operation_1.op({ concat1d_: concat1d_ }); +exports.concat2d = operation_1.op({ concat2d_: concat2d_ }); +exports.concat3d = operation_1.op({ concat3d_: concat3d_ }); +exports.concat4d = operation_1.op({ concat4d_: concat4d_ }); +//# sourceMappingURL=concat.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js.map new file mode 100644 index 0000000..0deb8e1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat.js.map @@ -0,0 +1 @@ +{"version":3,"file":"concat.js","sourceRoot":"","sources":["../../src/ops/concat.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAwD;AAExD,gCAA8C;AAC9C,yCAA2C;AAC3C,2CAA6C;AAC7C,yCAA+B;AAa/B,mBAAmB,OAAgC;IACjD,OAAO,cAAM,CAAC,OAAO,EAAE,CAAC,CAAY,CAAC;AACvC,CAAC;AA6BD,mBAAmB,OAAgC,EAAE,IAAY;IAC/D,OAAO,cAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAC/B,CAAC;AAgCD,mBAAmB,OAAgC,EAAE,IAAY;IAC/D,OAAO,cAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAC/B,CAAC;AASD,mBAAmB,OAAgC,EAAE,IAAY;IAC/D,OAAO,cAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAC/B,CAAC;AAyCD,iBAAmC,OAAyB,EAAE,IAAQ;IAAR,qBAAA,EAAA,QAAQ;IACpE,aAAM,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE,oCAAoC,CAAC,CAAC;IAClE,IAAM,QAAQ,GAAG,sCAAoB,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;IAEpE,IAAI,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAM,CAAC;IAC9B,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;QACzB,OAAO,MAAM,CAAC;KACf;IACD,IAAM,IAAI,GAAG,0BAAc,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;IAEhD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;QACxC,MAAM,GAAG,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAM,CAAC;KAC5D;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,wBAA0C,CAAI,EAAE,CAAI,EAAE,IAAY;IAChE,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACjD,IAAM,QAAQ,GAAG,WAAW,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAGrE,IAAM,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,oBAAa,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3D,IAAM,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,oBAAa,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAErD,IAAA,iEAC0D,EADzD,kBAAM,EAAE,gBAAK,EAAE,kBAAM,EAAE,gBAAK,CAC8B;IACjE,IAAM,GAAG,GAAG,UAAC,EAAY;QACvB,OAAO,EAAC,CAAC,EAAE,cAAM,OAAA,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAvB,CAAuB,EAAE,CAAC,EAAE,cAAM,OAAA,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAvB,CAAuB,EAAC,CAAC;IAC9E,CAAC,CAAC;IACF,IAAM,GAAG,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAC5B,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,EAAxB,CAAwB,EAAE,EAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAC,EAAE,GAAG,CAAC,CAAC;IAChE,OAAO,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAM,CAAC;AACpC,CAAC;AAEY,QAAA,MAAM,GAAG,cAAE,CAAC,EAAC,OAAO,SAAA,EAAC,CAAC,CAAC;AACvB,QAAA,QAAQ,GAAG,cAAE,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC;AAC3B,QAAA,QAAQ,GAAG,cAAE,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC;AAC3B,QAAA,QAAQ,GAAG,cAAE,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC;AAC3B,QAAA,QAAQ,GAAG,cAAE,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js new file mode 100644 index 0000000..0c8b20f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js @@ -0,0 +1,247 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('concat1d', test_util_1.ALL_ENVS, function () { + it('3 + 5', function () { + var a = tf.tensor1d([3]); + var b = tf.tensor1d([5]); + var result = tf.concat1d([a, b]); + var expected = [3, 5]; + test_util_1.expectArraysClose(result, expected); + }); + it('3 + [5,7]', function () { + var a = tf.tensor1d([3]); + var b = tf.tensor1d([5, 7]); + var result = tf.concat1d([a, b]); + var expected = [3, 5, 7]; + test_util_1.expectArraysClose(result, expected); + }); + it('[3,5] + 7', function () { + var a = tf.tensor1d([3, 5]); + var b = tf.tensor1d([7]); + var result = tf.concat1d([a, b]); + var expected = [3, 5, 7]; + test_util_1.expectArraysClose(result, expected); + }); + it('3 + 5 + 7 + 9', function () { + var a = tf.tensor1d([3]); + var b = tf.tensor1d([5]); + var c = tf.tensor1d([7]); + var d = tf.tensor1d([9]); + var result = tf.concat1d([a, b, c, d]); + test_util_1.expectArraysClose(result, [3, 5, 7, 9]); + }); + it('single tensor', function () { + var a = tf.tensor1d([3]); + var result = tf.concat1d([a]); + test_util_1.expectArraysClose(result, [3]); + }); + it('accepts a tensor-like object', function () { + var a = [3]; + var b = [5]; + var result = tf.concat1d([a, b]); + var expected = [3, 5]; + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('concat2d', test_util_1.ALL_ENVS, function () { + it('[[3]] + [[5]], axis=0', function () { + var axis = 0; + var a = tf.tensor2d([3], [1, 1]); + var b = tf.tensor2d([5], [1, 1]); + var result = tf.concat2d([a, b], axis); + var expected = [3, 5]; + expect(result.shape).toEqual([2, 1]); + test_util_1.expectArraysClose(result, expected); + }); + it('[[3]] + [[5]], axis=1', function () { + var axis = 1; + var a = tf.tensor2d([3], [1, 1]); + var b = tf.tensor2d([5], [1, 1]); + var result = tf.concat2d([a, b], axis); + var expected = [3, 5]; + expect(result.shape).toEqual([1, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('[[1, 2], [3, 4]] + [[5, 6]], axis=0', function () { + var axis = 0; + var a = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var b = tf.tensor2d([[5, 6]], [1, 2]); + var result = tf.concat2d([a, b], axis); + var expected = [1, 2, 3, 4, 5, 6]; + expect(result.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('[[1, 2],[3, 4]] + [[5, 6]] + [[7, 8]], axis=0', function () { + var axis = 0; + var a = tf.tensor2d([[1, 2], [3, 4]]); + var b = tf.tensor2d([[5, 6]]); + var c = tf.tensor2d([[7, 8]]); + var result = tf.concat2d([a, b, c], axis); + var expected = [1, 2, 3, 4, 5, 6, 7, 8]; + expect(result.shape).toEqual([4, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('[[1, 2], [3, 4]] + [[5, 6]], axis=1 throws error', function () { + var axis = 1; + var a = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var b = tf.tensor2d([[5, 6]], [1, 2]); + expect(function () { return tf.concat2d([a, b], axis); }).toThrowError(); + }); + it('[[1, 2], [3, 4]] + [[5, 6], [7, 8]], axis=1', function () { + var axis = 1; + var a = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var b = tf.tensor2d([[5, 6], [7, 8]], [2, 2]); + var result = tf.concat2d([a, b], axis); + var expected = [1, 2, 5, 6, 3, 4, 7, 8]; + expect(result.shape).toEqual([2, 4]); + test_util_1.expectArraysClose(result, expected); + }); + it('[[1, 2],[3, 4]] + [[5, 6],[7, 8]] + [[9, 10],[11, 12]], axis=1', function () { + var axis = 1; + var a = tf.tensor2d([[1, 2], [3, 4]]); + var b = tf.tensor2d([[5, 6], [7, 8]]); + var c = tf.tensor2d([[9, 10], [11, 12]]); + var result = tf.concat2d([a, b, c], axis); + var expected = [1, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11, 12]; + expect(result.shape).toEqual([2, 6]); + test_util_1.expectArraysClose(result, expected); + }); + it('accepts a tensor-like object', function () { + var axis = 0; + var a = [[3]]; + var b = [[5]]; + var result = tf.concat2d([a, b], axis); + var expected = [3, 5]; + expect(result.shape).toEqual([2, 1]); + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('concat3d', test_util_1.ALL_ENVS, function () { + it('shapes correct concat axis=0', function () { + var tensor1 = tf.tensor3d([1, 2, 3], [1, 1, 3]); + var tensor2 = tf.tensor3d([4, 5, 6], [1, 1, 3]); + var values = tf.concat3d([tensor1, tensor2], 0); + expect(values.shape).toEqual([2, 1, 3]); + test_util_1.expectArraysClose(values, [1, 2, 3, 4, 5, 6]); + }); + it('concat axis=0', function () { + var tensor1 = tf.tensor3d([1, 11, 111, 2, 22, 222], [1, 2, 3]); + var tensor2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + var values = tf.concat3d([tensor1, tensor2], 0); + expect(values.shape).toEqual([3, 2, 3]); + test_util_1.expectArraysClose(values, [ + 1, 11, 111, 2, 22, 222, 5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888 + ]); + }); + it('shapes correct concat axis=1', function () { + var tensor1 = tf.tensor3d([1, 2, 3], [1, 1, 3]); + var tensor2 = tf.tensor3d([4, 5, 6], [1, 1, 3]); + var values = tf.concat3d([tensor1, tensor2], 1); + expect(values.shape).toEqual([1, 2, 3]); + test_util_1.expectArraysClose(values, [1, 2, 3, 4, 5, 6]); + }); + it('concat axis=1', function () { + var tensor1 = tf.tensor3d([1, 11, 111, 3, 33, 333], [2, 1, 3]); + var tensor2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + var values = tf.concat3d([tensor1, tensor2], 1); + expect(values.shape).toEqual([2, 3, 3]); + test_util_1.expectArraysClose(values, [ + 1, 11, 111, 5, 55, 555, 6, 66, 666, 3, 33, 333, 7, 77, 777, 8, 88, 888 + ]); + }); + it('shapes correct concat axis=2', function () { + var tensor1 = tf.tensor3d([1, 2, 3], [1, 1, 3]); + var tensor2 = tf.tensor3d([4, 5, 6], [1, 1, 3]); + var values = tf.concat3d([tensor1, tensor2], 2); + expect(values.shape).toEqual([1, 1, 6]); + test_util_1.expectArraysClose(values, [1, 2, 3, 4, 5, 6]); + }); + it('concat axis=2', function () { + var tensor1 = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var tensor2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + var values = tf.concat3d([tensor1, tensor2], 2); + expect(values.shape).toEqual([2, 2, 5]); + test_util_1.expectArraysClose(values, [ + 1, 11, 5, 55, 555, 2, 22, 6, 66, 666, + 3, 33, 7, 77, 777, 4, 44, 8, 88, 888 + ]); + }); + it('concat throws when invalid non-axis shapes, axis=0', function () { + var axis = 0; + var x1 = tf.tensor3d([1, 11, 111], [1, 1, 3]); + var x2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + expect(function () { return tf.concat3d([x1, x2], axis); }).toThrowError(); + }); + it('concat throws when invalid non-axis shapes, axis=1', function () { + var axis = 1; + var x1 = tf.tensor3d([1, 11, 111], [1, 1, 3]); + var x2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + expect(function () { return tf.concat3d([x1, x2], axis); }).toThrowError(); + }); + it('concat throws when invalid non-axis shapes, axis=2', function () { + var axis = 2; + var x1 = tf.tensor3d([1, 11, 2, 22], [1, 2, 2]); + var x2 = tf.tensor3d([5, 55, 555, 6, 66, 666, 7, 77, 777, 8, 88, 888], [2, 2, 3]); + expect(function () { return tf.concat3d([x1, x2], axis); }).toThrowError(); + }); + it('gradient concat axis=0', function () { + var x1 = tf.tensor3d([1, 11, 2, 22], [1, 2, 2]); + var x2 = tf.tensor3d([5, 55, 6, 66, 7, 77, 8, 88], [2, 2, 2]); + var dy = tf.tensor3d([66, 6, 55, 5, 44, 4, 33, 3, 22, 2, 11, 1], [3, 2, 2]); + var axis = 0; + var grads = tf.grads(function (x1, x2) { return tf.concat3d([x1, x2], axis); }); + var _a = grads([x1, x2], dy), dx1 = _a[0], dx2 = _a[1]; + expect(dx1.shape).toEqual(x1.shape); + test_util_1.expectArraysClose(dx1, [66, 6, 55, 5]); + expect(dx2.shape).toEqual(x2.shape); + test_util_1.expectArraysClose(dx2, [44, 4, 33, 3, 22, 2, 11, 1]); + }); + it('gradient concat axis=1', function () { + var x1 = tf.tensor3d([1, 11, 2, 22], [2, 1, 2]); + var x2 = tf.tensor3d([3, 33, 4, 44, 5, 55, 6, 66], [2, 2, 2]); + var dy = tf.tensor3d([66, 6, 55, 5, 44, 4, 33, 3, 22, 2, 11, 1], [2, 3, 2]); + var axis = 1; + var grads = tf.grads(function (x1, x2) { return tf.concat3d([x1, x2], axis); }); + var _a = grads([x1, x2], dy), dx1 = _a[0], dx2 = _a[1]; + expect(dx1.shape).toEqual(x1.shape); + test_util_1.expectArraysClose(dx1, [66, 6, 33, 3]); + expect(dx2.shape).toEqual(x2.shape); + test_util_1.expectArraysClose(dx2, [55, 5, 44, 4, 22, 2, 11, 1]); + }); + it('gradient concat axis=2', function () { + var x1 = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x2 = tf.tensor3d([5, 55, 6, 66, 7, 77, 8, 88], [2, 2, 2]); + var dy = tf.tensor3d([4, 40, 400, 3, 30, 300, 2, 20, 200, 1, 10, 100], [2, 2, 3]); + var axis = 2; + var grads = tf.grads(function (x1, x2) { return tf.concat3d([x1, x2], axis); }); + var _a = grads([x1, x2], dy), dx1 = _a[0], dx2 = _a[1]; + expect(dx1.shape).toEqual(x1.shape); + test_util_1.expectArraysClose(dx1, [4, 3, 2, 1]); + expect(dx2.shape).toEqual(x2.shape); + test_util_1.expectArraysClose(dx2, [40, 400, 30, 300, 20, 200, 10, 100]); + }); + it('accepts a tensor-like object', function () { + var tensor1 = [[[1, 2, 3]]]; + var tensor2 = [[[4, 5, 6]]]; + var values = tf.concat3d([tensor1, tensor2], 0); + expect(values.shape).toEqual([2, 1, 3]); + test_util_1.expectArraysClose(values, [1, 2, 3, 4, 5, 6]); + }); +}); +jasmine_util_1.describeWithFlags('concat throws for non-tensors', test_util_1.ALL_ENVS, function () { + it('throws when passed a non-tensor', function () { + expect(function () { return tf.concat([{}]); }) + .toThrowError(/Argument 'tensors\[0\]' passed to 'concat' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var tensor1 = [[[1, 2, 3, 4]]]; + var tensor2 = [[[4, 5, 6, 7]]]; + var values = tf.concat([tensor1, tensor2], 0); + expect(values.shape).toEqual([2, 1, 4]); + test_util_1.expectArraysClose(values, [1, 2, 3, 4, 4, 5, 6, 7]); + }); +}); +//# sourceMappingURL=concat_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js.map new file mode 100644 index 0000000..b2258ca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"concat_test.js","sourceRoot":"","sources":["../../src/ops/concat_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.d.ts new file mode 100644 index 0000000..0b27c74 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.d.ts @@ -0,0 +1,8 @@ +export declare function assertParams(aShape: number[], bShape: number[], axis: number): void; +export declare function computeOutShape(x1Shape: number[], x2Shape: number[], axis: number): number[]; +export declare function computeGradientSliceShapes(aShape: [number, number], bShape: [number, number]): { + aBegin: [number, number]; + aSize: [number, number]; + bBegin: [number, number]; + bSize: [number, number]; +}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js new file mode 100644 index 0000000..4bccbb0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("../util"); +function assertParams(aShape, bShape, axis) { + var aRank = aShape.length; + var bRank = bShape.length; + util.assert(aShape.length === bShape.length, "Error in concat" + aRank + "D: rank of x1 (" + aRank + ") and x2 (" + bRank + ") " + + "must be the same."); + util.assert(axis >= 0 && axis < aRank, "Error in concat" + aRank + "D: axis must be " + + ("between 0 and " + (aRank - 1) + ".")); + for (var i = 0; i < aRank; i++) { + util.assert((i === axis) || (aShape[i] === bShape[i]), "Error in concat" + aRank + "D: Shape (" + aShape + ") does not match " + + ("(" + bShape + ") along the non-concatenated axis " + i + ".")); + } +} +exports.assertParams = assertParams; +function computeOutShape(x1Shape, x2Shape, axis) { + util.assert(x1Shape.length === x2Shape.length, 'x1 and x2 should have the same rank.'); + var outputShape = x1Shape.slice(); + outputShape[axis] += x2Shape[axis]; + return outputShape; +} +exports.computeOutShape = computeOutShape; +function computeGradientSliceShapes(aShape, bShape) { + return { + aBegin: [0, 0], + aSize: aShape, + bBegin: [0, aShape[1]], + bSize: bShape + }; +} +exports.computeGradientSliceShapes = computeGradientSliceShapes; +//# sourceMappingURL=concat_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js.map new file mode 100644 index 0000000..89b39af --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"concat_util.js","sourceRoot":"","sources":["../../src/ops/concat_util.ts"],"names":[],"mappings":";;AAiBA,8BAAgC;AAEhC,sBAA6B,MAAgB,EAAE,MAAgB,EAAE,IAAY;IAC3E,IAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;IAC5B,IAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;IAC5B,IAAI,CAAC,MAAM,CACP,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,EAC/B,oBAAkB,KAAK,uBAAkB,KAAK,kBAAa,KAAK,OAAI;QAChE,mBAAmB,CAAC,CAAC;IAE7B,IAAI,CAAC,MAAM,CACP,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,KAAK,EACzB,oBAAkB,KAAK,qBAAkB;SACrC,oBAAiB,KAAK,GAAG,CAAC,OAAG,CAAA,CAAC,CAAC;IAEvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;QAC9B,IAAI,CAAC,MAAM,CACP,CAAC,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,EACzC,oBAAkB,KAAK,kBAAa,MAAM,sBAAmB;aACzD,MAAI,MAAM,0CAAqC,CAAC,MAAG,CAAA,CAAC,CAAC;KAC9D;AACH,CAAC;AAnBD,oCAmBC;AAED,yBACI,OAAiB,EAAE,OAAiB,EAAE,IAAY;IACpD,IAAI,CAAC,MAAM,CACP,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,EACjC,sCAAsC,CAAC,CAAC;IAC5C,IAAM,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IACpC,WAAW,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACnC,OAAO,WAAW,CAAC;AACrB,CAAC;AARD,0CAQC;AAED,oCACI,MAAwB,EAAE,MAAwB;IACpD,OAAO;QACL,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAqB;QAClC,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAqB;QAC1C,KAAK,EAAE,MAAM;KACd,CAAC;AACJ,CAAC;AARD,gEAQC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js new file mode 100644 index 0000000..f4fa713 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js @@ -0,0 +1,63 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var concat_util = require("./concat_util"); +describe('concat_util.assertConcatShapesMatch rank=3D', function () { + it('Non-3D tensor x1', function () { + var assertFn = function () { + concat_util.assertParams([1], [1, 2, 3], 1); + }; + expect(assertFn).toThrow(); + }); + it('Non-3D tensor x2', function () { + var assertFn = function () { + concat_util.assertParams([1, 2, 3], [2, 3], 1); + }; + expect(assertFn).toThrow(); + }); + it('axis out of bound', function () { + var assertFn = function () { + concat_util.assertParams([1, 2, 3], [1, 2, 3], 4); + }; + expect(assertFn).toThrow(); + }); + it('non-axis shape mismatch', function () { + var assertFn = function () { + concat_util.assertParams([2, 3, 3], [2, 2, 4], 2); + }; + expect(assertFn).toThrow(); + }); + it('shapes line up', function () { + var assertFn = function () { + concat_util.assertParams([2, 3, 3], [2, 3, 4], 2); + }; + expect(assertFn).not.toThrow(); + }); +}); +describe('concat_util.computeConcatOutputShape', function () { + it('compute output shape, axis=0', function () { + expect(concat_util.computeOutShape([2, 2, 3], [1, 2, 3], 0)).toEqual([ + 3, 2, 3 + ]); + }); +}); +describe('concat_util.computeBackpropSizes', function () { + it('compute backprop sizes of 2D tensors, original axis=0', function () { + var a = [1, 6]; + var b = [1, 8]; + var _a = concat_util.computeGradientSliceShapes(a, b), aBegin = _a.aBegin, aSize = _a.aSize, bBegin = _a.bBegin, bSize = _a.bSize; + expect(aBegin).toEqual([0, 0]); + expect(aSize).toEqual([1, 6]); + expect(bBegin).toEqual([0, 6]); + expect(bSize).toEqual([1, 8]); + }); + it('compute backprop sizes of 2D tensors, original axis=1', function () { + var a = [3, 2]; + var b = [3, 7]; + var _a = concat_util.computeGradientSliceShapes(a, b), aBegin = _a.aBegin, aSize = _a.aSize, bBegin = _a.bBegin, bSize = _a.bSize; + expect(aBegin).toEqual([0, 0]); + expect(aSize).toEqual([3, 2]); + expect(bBegin).toEqual([0, 2]); + expect(bSize).toEqual([3, 7]); + }); +}); +//# sourceMappingURL=concat_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js.map new file mode 100644 index 0000000..fde2ad6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/concat_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"concat_util_test.js","sourceRoot":"","sources":["../../src/ops/concat_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.d.ts new file mode 100644 index 0000000..43ee4eb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.d.ts @@ -0,0 +1,13 @@ +import { Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function conv1d_(x: T | TensorLike, filter: Tensor3D | TensorLike, stride: number, pad: 'valid' | 'same' | number, dataFormat?: 'NWC' | 'NCW', dilation?: number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +declare function conv2d_(x: T | TensorLike, filter: Tensor4D | TensorLike, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat?: 'NHWC' | 'NCHW', dilations?: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +declare function conv2dTranspose_(x: T | TensorLike, filter: Tensor4D | TensorLike, outputShape: [number, number, number, number] | [number, number, number], strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +declare function depthwiseConv2d_(x: T | TensorLike, filter: Tensor4D | TensorLike, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat?: 'NHWC' | 'NCHW', dilations?: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +declare function separableConv2d_(x: T | TensorLike, depthwiseFilter: Tensor4D | TensorLike, pointwiseFilter: Tensor4D | TensorLike, strides: [number, number] | number, pad: 'valid' | 'same', dilation?: [number, number] | number, dataFormat?: 'NHWC' | 'NCHW'): T; +export declare const conv1d: typeof conv1d_; +export declare const conv2d: typeof conv2d_; +export declare const depthwiseConv2d: typeof depthwiseConv2d_; +export declare const separableConv2d: typeof separableConv2d_; +export declare const conv2dTranspose: typeof conv2dTranspose_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js new file mode 100644 index 0000000..7aa3951 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js @@ -0,0 +1,267 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var conv_util = require("./conv_util"); +var operation_1 = require("./operation"); +function conv1d_(x, filter, stride, pad, dataFormat, dilation, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NWC'; } + if (dilation === void 0) { dilation = 1; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'conv1d'); + var $filter = tensor_util_env_1.convertToTensor(filter, 'filter', 'conv1d'); + var x3D = $x; + var reshapedTo3D = false; + if ($x.rank === 2) { + reshapedTo3D = true; + x3D = $x.as3D(1, $x.shape[0], $x.shape[1]); + } + util.assert(x3D.rank === 3, "Error in conv1d: input must be rank 3, but got rank " + x3D.rank + "."); + util.assert($filter.rank === 3, "Error in conv1d: filter must be rank 3, but got rank " + + ($filter.rank + ".")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in conv1d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + util.assert(x3D.shape[2] === $filter.shape[1], "Error in conv1d: depth of input (" + x3D.shape[2] + ") must match " + + ("input depth for filter " + $filter.shape[1] + ".")); + util.assert(eitherStridesOrDilationsAreOne(stride, dilation), 'Error in conv1D: Either stride or dilation must be 1. ' + + ("Got stride " + stride + " and dilation '" + dilation + "'")); + util.assert(dataFormat === 'NWC', "Error in conv1d: got dataFormat of " + dataFormat + " but only NWC is currently supported."); + var filter4D = $filter.as4D(1, $filter.shape[0], $filter.shape[1], $filter.shape[2]); + var input4D = x3D.as4D(x3D.shape[0], 1, x3D.shape[1], x3D.shape[2]); + var strides = [1, stride]; + var dilations = [1, dilation]; + var conv2dDataFormat = 'NHWC'; + var res = exports.conv2d(input4D, filter4D, strides, pad, conv2dDataFormat, dilations, dimRoundingMode); + if (reshapedTo3D) { + return res.as2D(res.shape[2], res.shape[3]); + } + return res.as3D(res.shape[0], res.shape[2], res.shape[3]); +} +function conv2d_(x, filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'conv2d'); + var $filter = tensor_util_env_1.convertToTensor(filter, 'filter', 'conv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + util.assert(x4D.rank === 4, "Error in conv2d: input must be rank 4, but got rank " + x4D.rank + "."); + util.assert($filter.rank === 4, "Error in conv2d: filter must be rank 4, but got rank " + + ($filter.rank + ".")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in conv2d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + util.assert(x4D.shape[3] === $filter.shape[2], "Error in conv2d: depth of input (" + x4D.shape[3] + ") must match " + + ("input depth for filter " + $filter.shape[2] + ".")); + util.assert(eitherStridesOrDilationsAreOne(strides, dilations), 'Error in conv2D: Either strides or dilations must be 1. ' + + ("Got strides " + strides + " and dilations '" + dilations + "'")); + util.assert(dataFormat === 'NHWC', "Error in conv2d: got dataFormat of " + dataFormat + " but only NHWC is currently supported."); + var convInfo = conv_util.computeConv2DInfo(x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode); + var grad = function (dy) { + util.assert(tupleValuesAreOne(dilations), 'Error in gradient of conv2D: dilation rates greater than 1 are not' + + ("yet supported in gradients. Got dilations '" + dilations + "'")); + return { + x: function () { return conv2dDerInput_(x4D.shape, dy, $filter, strides, pad); }, + $filter: function () { return conv2dDerFilter_(x4D, dy, $filter.shape, strides, pad); } + }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.conv2d(x4D, $filter, convInfo); }, { x: x4D, $filter: $filter }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function conv2dDerInput_(xShape, dy, filter, strides, pad, dimRoundingMode) { + util.assert(xShape.length === dy.rank, "Length of inShape " + + ("(" + xShape.length + ") and rank of dy (" + dy.rank + ") must match")); + var xShape4D = xShape; + var dy4D = dy; + var reshapedTo4D = false; + if (dy.rank === 3) { + reshapedTo4D = true; + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + xShape4D = [1, xShape[0], xShape[1], xShape[2]]; + } + var inDepth = xShape4D[3]; + var outDepth = dy4D.shape[3]; + util.assert(xShape4D.length === 4, "Error in conv2dDerInput: inShape must be length 4, but got length " + + (xShape4D.length + ".")); + util.assert(dy4D.rank === 4, "Error in conv2dDerInput: dy must be rank 4, but got " + + ("rank " + dy4D.rank)); + util.assert(filter.rank === 4, "Error in conv2dDerInput: filter must be rank 4, but got " + + ("rank " + filter.rank)); + util.assert(inDepth === filter.shape[2], "Error in conv2dDerInput: depth of input (" + inDepth + ") must " + + ("match input depth for filter " + filter.shape[2] + ".")); + util.assert(outDepth === filter.shape[3], "Error in conv2dDerInput: depth of output (" + outDepth + ") must " + + ("match output depth for filter " + filter.shape[3] + ".")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in conv2dDerInput: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var dilations = 1; + var convInfo = conv_util.computeConv2DInfo(xShape4D, filter.shape, strides, dilations, pad, dimRoundingMode); + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.conv2dDerInput(dy4D, filter, convInfo); }, { dy4D: dy4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function conv2dDerFilter_(x, dy, filterShape, strides, pad, dimRoundingMode) { + var x4D = x; + if (x.rank === 3) { + x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + var dy4D = dy; + if (dy4D.rank === 3) { + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + util.assert(x4D.rank === 4, "Error in conv2dDerFilter: input must be rank 4, but got shape " + + (x4D.shape + ".")); + util.assert(dy4D.rank === 4, "Error in conv2dDerFilter: dy must be rank 4, but got shape " + + (dy4D.shape + ".")); + util.assert(filterShape.length === 4, "Error in conv2dDerFilter: filterShape must be length 4, but got " + + (filterShape + ".")); + util.assert(x4D.shape[3] === filterShape[2], "Error in conv2dDerFilter: depth of input " + x4D.shape[3] + ") must " + + ("match input depth in filter (" + filterShape[2] + ".")); + util.assert(dy4D.shape[3] === filterShape[3], "Error in conv2dDerFilter: depth of dy (" + dy4D.shape[3] + ") must " + + ("match output depth for filter (" + filterShape[3] + ").")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in conv2dDerFilter: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var dilations = 1; + var convInfo = conv_util.computeConv2DInfo(x4D.shape, filterShape, strides, dilations, pad, dimRoundingMode); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.conv2dDerFilter(x4D, dy4D, convInfo); }, { x4D: x4D, dy4D: dy4D }); +} +function conv2dTranspose_(x, filter, outputShape, strides, pad, dimRoundingMode) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'conv2dTranspose'); + var $filter = tensor_util_env_1.convertToTensor(filter, 'filter', 'conv2dTranspose'); + return conv2dDerInput_(outputShape, $x, $filter, strides, pad, dimRoundingMode); +} +function depthwiseConv2d_(x, filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'depthwiseConv2d'); + var $filter = tensor_util_env_1.convertToTensor(filter, 'filter', 'depthwiseConv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + util.assert(x4D.rank === 4, "Error in depthwiseConv2d: input must be rank 4, but got " + + ("rank " + x4D.rank + ".")); + util.assert($filter.rank === 4, "Error in depthwiseConv2d: filter must be rank 4, but got rank " + + ($filter.rank + ".")); + util.assert(x4D.shape[3] === $filter.shape[2], "Error in depthwiseConv2d: number of input channels " + + ("(" + x4D.shape[3] + ") must match the inChannels dimension in ") + + ("filter " + $filter.shape[2] + ".")); + if (dilations == null) { + dilations = [1, 1]; + } + util.assert(eitherStridesOrDilationsAreOne(strides, dilations), 'Error in depthwiseConv2d: Either strides or dilations must be 1. ' + + ("Got strides " + strides + " and dilations '" + dilations + "'")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in depthwiseConv2d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = conv_util.computeConv2DInfo(x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode, true); + var grad = function (dy) { + util.assert(tupleValuesAreOne(dilations), 'Error in gradient of depthwiseConv2d: dilation rates greater than ' + + ("1 are not yet supported. Got dilations '" + dilations + "'")); + return { + x: function () { return depthwiseConv2dDerInput(x4D.shape, dy, $filter, convInfo); }, + $filter: function () { return depthwiseConv2dDerFilter(x4D, dy, $filter.shape, convInfo); }, + }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2D(x4D, $filter, convInfo); }, { x: x4D, $filter: $filter }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function separableConv2d_(x, depthwiseFilter, pointwiseFilter, strides, pad, dilation, dataFormat) { + if (dilation === void 0) { dilation = [1, 1]; } + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'separableConv2d'); + var $depthwiseFilter = tensor_util_env_1.convertToTensor(depthwiseFilter, 'depthwiseFilter', 'separableConv2d'); + var $pointwiseFilter = tensor_util_env_1.convertToTensor(pointwiseFilter, 'pointwiseFilter', 'separableConv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + if (dataFormat === 'NCHW') { + throw new Error('separableConv2d currently does not support dataFormat NCHW; only ' + + 'NHWC is supported'); + } + util.assert(x4D.rank === 4, "Error in separableConv2d: input must be rank 4, but got " + + ("rank " + x4D.rank + ".")); + util.assert($depthwiseFilter.rank === 4, "Error in separableConv2d: depthwise filter must be rank 4, but got " + + ("rank " + $depthwiseFilter.rank + ".")); + util.assert($pointwiseFilter.rank === 4, "Error in separableConv2d: pointwise filter must be rank 4, but got " + + ("rank " + $depthwiseFilter.rank + ".")); + util.assert($pointwiseFilter.shape[0] === 1, "Error in separableConv2d: the first dimension of pointwise filter " + + (" must be 1, but got " + $pointwiseFilter.shape[0] + ".")); + util.assert($pointwiseFilter.shape[1] === 1, "Error in separableConv2d: the second dimension of pointwise filter " + + (" must be 1, but got " + $pointwiseFilter.shape[1] + ".")); + var inChannels = $depthwiseFilter.shape[2]; + var channelMultiplier = $depthwiseFilter.shape[3]; + util.assert($pointwiseFilter.shape[2] === inChannels * channelMultiplier, "Error in separableConv2d: the third dimension of pointwise filter " + + ("must be " + inChannels * channelMultiplier + ", ") + + ("but got " + $pointwiseFilter.shape[2] + ".")); + var depthwise = exports.depthwiseConv2d(x4D, $depthwiseFilter, strides, pad, dataFormat, dilation); + var pointwiseStride = 1; + var res = exports.conv2d(depthwise, $pointwiseFilter, pointwiseStride, 'valid', dataFormat); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function parseTupleParam(param) { + return typeof param === 'number' ? [param, param] : param; +} +function tupleValuesAreOne(param) { + var _a = parseTupleParam(param), dimA = _a[0], dimB = _a[1]; + return dimA === 1 && dimB === 1; +} +function eitherStridesOrDilationsAreOne(strides, dilations) { + return tupleValuesAreOne(strides) || tupleValuesAreOne(dilations); +} +function depthwiseConv2dDerInput(xShape, dy, filter, convInfo) { + var dy4D = dy; + var reshapedTo4D = false; + if (dy.rank === 3) { + reshapedTo4D = true; + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2DDerInput(dy4D, filter, convInfo); }, { dy4D: dy4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function depthwiseConv2dDerFilter(x, dy, filterShape, convInfo) { + var x4D = x; + if (x.rank === 3) { + x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + var dy4D = dy; + if (dy4D.rank === 3) { + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + return environment_1.ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2DDerFilter(x4D, dy4D, convInfo); }, { x4D: x4D, dy4D: dy4D }); +} +exports.conv1d = operation_1.op({ conv1d_: conv1d_ }); +exports.conv2d = operation_1.op({ conv2d_: conv2d_ }); +exports.depthwiseConv2d = operation_1.op({ depthwiseConv2d_: depthwiseConv2d_ }); +exports.separableConv2d = operation_1.op({ separableConv2d_: separableConv2d_ }); +exports.conv2dTranspose = operation_1.op({ conv2dTranspose_: conv2dTranspose_ }); +//# sourceMappingURL=conv.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js.map new file mode 100644 index 0000000..0a62f80 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv.js","sourceRoot":"","sources":["../../src/ops/conv.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js new file mode 100644 index 0000000..d57d10d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js @@ -0,0 +1,210 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('conv1d', test_util_1.ALL_ENVS, function () { + it('conv1d input=2x2x1,d2=1,f=1,s=1,d=1,p=same', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 1; + var pad = 'same'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([3], [fSize, inputDepth, outputDepth]); + var result = tf.conv1d(x, w, stride, pad, dataFormat, dilation); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [3, 6, 9, 12]); + }); + it('conv1d input=4x1,d2=1,f=2x1x1,s=1,d=1,p=valid', function () { + var inputDepth = 1; + var inputShape = [4, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor2d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([2, 1], [fSize, inputDepth, outputDepth]); + var result = tf.conv1d(x, w, stride, pad, dataFormat, dilation); + expect(result.shape).toEqual([3, 1]); + test_util_1.expectArraysClose(result, [4, 7, 10]); + }); + it('conv1d input=4x1,d2=1,f=2x1x1,s=1,d=2,p=valid', function () { + var inputDepth = 1; + var inputShape = [4, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var fSizeDilated = 3; + var pad = 'valid'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 2; + var dilationWEffective = 1; + var x = tf.tensor2d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([2, 1], [fSize, inputDepth, outputDepth]); + var wDilated = tf.tensor3d([2, 0, 1], [fSizeDilated, inputDepth, outputDepth]); + var result = tf.conv1d(x, w, stride, pad, dataFormat, dilation); + var expectedResult = tf.conv1d(x, wDilated, stride, pad, dataFormat, dilationWEffective); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('conv1d input=14x1,d2=1,f=3x1x1,s=1,d=3,p=valid', function () { + var inputDepth = 1; + var inputShape = [14, inputDepth]; + var outputDepth = 1; + var fSize = 3; + var fSizeDilated = 7; + var pad = 'valid'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 3; + var dilationWEffective = 1; + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14], inputShape); + var w = tf.tensor3d([3, 2, 1], [fSize, inputDepth, outputDepth]); + var wDilated = tf.tensor3d([3, 0, 0, 2, 0, 0, 1], [fSizeDilated, inputDepth, outputDepth]); + var result = tf.conv1d(x, w, stride, pad, dataFormat, dilation); + var expectedResult = tf.conv1d(x, wDilated, stride, pad, dataFormat, dilationWEffective); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('throws when x is not rank 3', function () { + var inputDepth = 1; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var w = tf.tensor3d([3, 1], [fSize, inputDepth, outputDepth]); + expect(function () { return tf.conv1d(x, w, stride, pad, dataFormat, dilation); }) + .toThrowError(); + }); + it('throws when weights is not rank 3', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var pad = 0; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor4d([3, 1, 5, 0], [2, 2, 1, 1]); + expect(function () { return tf.conv1d(x, w, stride, pad, dataFormat, dilation); }) + .toThrowError(); + }); + it('throws when x depth does not match weight depth', function () { + var inputDepth = 1; + var wrongInputDepth = 5; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.randomNormal([fSize, wrongInputDepth, outputDepth]); + expect(function () { return tf.conv1d(x, w, stride, pad, dataFormat, dilation); }) + .toThrowError(); + }); + it('throws when both stride and dilation are greater than 1', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 1; + var pad = 'same'; + var stride = 2; + var dataFormat = 'NWC'; + var dilation = 2; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([3], [fSize, inputDepth, outputDepth]); + expect(function () { return tf.conv1d(x, w, stride, pad, dataFormat, dilation); }) + .toThrowError(); + }); + it('throws when passed x as a non-tensor', function () { + var inputDepth = 1; + var outputDepth = 1; + var fSize = 1; + var pad = 'same'; + var stride = 2; + var dataFormat = 'NWC'; + var dilation = 2; + var w = tf.tensor3d([3], [fSize, inputDepth, outputDepth]); + expect(function () { + return tf.conv1d({}, w, stride, pad, dataFormat, dilation); + }) + .toThrowError(/Argument 'x' passed to 'conv1d' must be a Tensor/); + }); + it('throws when passed filter as a non-tensor', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var pad = 'same'; + var stride = 2; + var dataFormat = 'NWC'; + var dilation = 2; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + expect(function () { + return tf.conv1d(x, {}, stride, pad, dataFormat, dilation); + }) + .toThrowError(/Argument 'filter' passed to 'conv1d' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var pad = 'same'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = [[[1], [2]], [[3], [4]]]; + var w = [[[3]]]; + var result = tf.conv1d(x, w, stride, pad, dataFormat, dilation); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [3, 6, 9, 12]); + }); + it('conv1d gradients, input=2x2x1,d2=1,f=1,s=1,d=1,p=same', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 1; + var filterShape = [fSize, inputDepth, outputDepth]; + var pad = 'same'; + var stride = 1; + var dataFormat = 'NWC'; + var dilation = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([3], filterShape); + var dy = tf.tensor3d([3, 2, 1, 0], inputShape); + var grads = tf.grads(function (x, w) { + return tf.conv1d(x, w, stride, pad, dataFormat, dilation); + }); + var _a = grads([x, w], dy), dx = _a[0], dw = _a[1]; + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [9, 6, 3, 0]); + expect(dw.shape).toEqual(w.shape); + test_util_1.expectArraysClose(dw, [10]); + }); + it('conv1d gradients input=14x1,d2=1,f=3x1x1,s=1,p=valid', function () { + var inputDepth = 1; + var inputShape = [14, inputDepth]; + var outputDepth = 1; + var fSize = 3; + var pad = 'valid'; + var stride = 1; + var dataFormat = 'NWC'; + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14], inputShape); + var w = tf.tensor3d([3, 2, 1], [fSize, inputDepth, outputDepth]); + var dy = tf.tensor2d([3, 2, 1, 0, 3, 2, 1, 0, 3, 2, 1, 0], [12, inputDepth]); + var grads = tf.grads(function (x, w) { + return tf.conv1d(x, w, stride, pad, dataFormat); + }); + var _a = grads([x, w], dy), dx = _a[0], dw = _a[1]; + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [9, 12, 10, 4, 10, 12, 10, 4, 10, 12, 10, 4, 1, 0]); + expect(dw.shape).toEqual(w.shape); + test_util_1.expectArraysClose(dw, [102, 120, 138]); + }); +}); +//# sourceMappingURL=conv1d_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js.map new file mode 100644 index 0000000..01b1f12 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv1d_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv1d_test.js","sourceRoot":"","sources":["../../src/ops/conv1d_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js new file mode 100644 index 0000000..8d0dd93 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js @@ -0,0 +1,377 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('depthwiseConv2D', test_util_1.ALL_ENVS, function () { + it('input=1x3x3x1,f=2,s=1,d=1,p=valid,chMul=1', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var x = tf.tensor4d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [1, 3, 3, inDepth]); + var w = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([1, 2, 2, 1]); + var expected = [1.07022, 1.03167, 0.67041, 0.778863]; + test_util_1.expectArraysClose(result, expected); + }); + it('input=1x3x3x1,f=2,s=1,d=2,p=valid,chMul=1', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var dilation = 2; + var chMul = 1; + var inDepth = 1; + var x = tf.tensor4d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [1, 3, 3, inDepth]); + var w = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var fSizeDilated = fSize + (fSize - 1) * (dilation - 1); + var wDilated = tf.tensor4d([0.303873, 0, 0.229223, 0, 0, 0, 0.144333, 0, 0.803373], [fSizeDilated, fSizeDilated, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad, 'NHWC', dilation); + var expectedResult = tf.depthwiseConv2d(x, wDilated, stride, pad); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('input=1x3x3x2,f=2,s=1,d=1,p=same,chMul=1', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 1; + var inDepth = 2; + var x = tf.tensor4d([ + 0.111057, 0.661818, 0.701979, 0.424362, 0.992854, 0.417599, 0.423036, + 0.500499, 0.368484, 0.714135, 0.456693, 0.531058, 0.636636, 0.345024, + 0.0506303, 0.789682, 0.177473, 0.793569 + ], [1, 3, 3, inDepth]); + var w = tf.tensor4d([ + 0.614293, 0.0648011, 0.101113, 0.452887, 0.0582746, 0.426481, + 0.872743, 0.765767 + ], [fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([1, 3, 3, 2]); + var expected = [ + 0.485445, 0.995389, 0.95166, 0.927856, 0.636516, 0.253547, 0.378414, + 1.10771, 0.430373, 1.23126, 0.290885, 0.372855, 0.3962, 0.379995, + 0.0490466, 0.410569, 0.10902, 0.0514242 + ]; + test_util_1.expectArraysClose(result, expected); + }); + it('input=1x3x3x2,f=2,s=1,d=2,p=same,chMul=1', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var dilation = 2; + var inDepth = 2; + var x = tf.tensor4d([ + 0.111057, 0.661818, 0.701979, 0.424362, 0.992854, 0.417599, 0.423036, + 0.500499, 0.368484, 0.714135, 0.456693, 0.531058, 0.636636, 0.345024, + 0.0506303, 0.789682, 0.177473, 0.793569 + ], [1, 3, 3, inDepth]); + var w = tf.stack([ + tf.tensor2d([0.614293, 0.0648011, 0.101113, 0.452887], [fSize, fSize]), + tf.tensor2d([0.0582746, 0.426481, 0.872743, 0.765767], [fSize, fSize]) + ], 2) + .expandDims(3); + var fSizeDilated = fSize + (fSize - 1) * (dilation - 1); + var wDilated = tf.stack([ + tf.tensor2d([0.614293, 0, 0.0648011, 0, 0, 0, 0.101113, 0, 0.452887], [fSizeDilated, fSizeDilated]), + tf.tensor2d([0.0582746, 0, 0.426481, 0, 0, 0, 0.872743, 0, 0.765767], [fSizeDilated, fSizeDilated]) + ], 2) + .expandDims(3); + expect(wDilated.shape).toEqual([fSizeDilated, fSizeDilated, inDepth, 1]); + var result = tf.depthwiseConv2d(x, w, stride, pad, 'NHWC', dilation); + var expectedResult = tf.depthwiseConv2d(x, wDilated, stride, pad); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('input=1x3x3x2,f=2,s=1,p=same,chMul=2', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 2; + var inDepth = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, 0.804231, + 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, 0.133869, 0.650827, + 0.047613, 0.554795, 0.653365, 0.442196 + ], [1, 3, 3, inDepth]); + var w = tf.tensor4d([ + 0.347154, 0.386692, 0.327191, 0.483784, 0.591807, 0.24263, 0.95182, + 0.174353, 0.592136, 0.623469, 0.988244, 0.660731, 0.946534, 0.0801365, + 0.864889, 0.874602 + ], [fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([1, 3, 3, 4]); + var expected = [ + 1.83059, 0.937125, 2.1218, 1.39024, 0.990167, 0.803472, + 1.31405, 1.14959, 0.182147, 0.196385, 0.241141, 0.188081, + 0.950656, 0.622581, 1.92451, 1.20179, 1.07422, 0.483268, + 1.36948, 1.14256, 0.449444, 0.477042, 0.505857, 0.393989, + 0.0746509, 0.0633184, 0.74101, 0.41159, 0.403195, 0.176938, + 0.602415, 0.345499, 0.226819, 0.252651, 0.144682, 0.213927 + ]; + test_util_1.expectArraysClose(result, expected); + }); + it('input=2x3x3x2,f=2,s=1,p=same,chMul=2', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 2; + var inDepth = 2; + var x = tf.tensor4d([ + 0.261945, 0.0528113, 0.656698, 0.127345, 0.610039, 0.169131, + 0.458647, 0.0988288, 0.966109, 0.0421747, 0.82035, 0.274711, + 0.359377, 0.512113, 0.689682, 0.941571, 0.31961, 0.743826, + 0.858147, 0.984766, 0.926973, 0.579597, 0.444104, 0.505969, + 0.241437, 0.937999, 0.0957074, 0.773611, 0.46023, 0.469379, + 0.363789, 0.269745, 0.486136, 0.894215, 0.794299, 0.724615 + ], [2, 3, 3, inDepth]); + var w = tf.tensor4d([ + 0.240347, 0.906352, 0.478657, 0.825918, 0.380769, 0.184705, 0.238241, + 0.201907, 0.294087, 0.181165, 0.191303, 0.7225, 0.430064, 0.900622, + 0.670338, 0.33478 + ], [fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([2, 3, 3, 4]); + var expected = [ + 0.863379, 1.3119, 0.102795, 0.154853, 1.02704, 1.62173, 0.293466, + 0.261764, 0.387876, 0.701529, 0.133508, 0.338167, 0.880395, 1.28039, + 0.786492, 0.775361, 0.884845, 1.43995, 0.764374, 1.0196, 0.291162, + 0.801428, 0.273788, 0.764303, 0.348985, 0.45311, 0.469447, 0.613073, + 0.287461, 0.684128, 0.627899, 0.927844, 0.0768174, 0.28968, 0.356037, + 0.614339, 0.67138, 1.07894, 1.30747, 1.86705, 0.617971, 1.35402, + 0.860607, 1.29693, 0.242087, 0.485892, 0.331979, 0.757015, 0.410527, + 0.740235, 1.28431, 1.42516, 0.68281, 0.975185, 1.13892, 1.62237, + 0.344208, 0.561029, 0.363292, 0.911203, 0.272541, 0.419513, 0.342154, + 0.403335, 0.419286, 0.587321, 0.600655, 0.884853, 0.190907, 0.719914, + 0.346842, 0.598472 + ]; + test_util_1.expectArraysClose(result, expected); + }); + it('input=2x3x3x2,f=2,s=1,d=2,p=same,chMul=2', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var inDepth = 2; + var dilation = 2; + var noDilation = 1; + var x = tf.tensor4d([ + 0.261945, 0.0528113, 0.656698, 0.127345, 0.610039, 0.169131, + 0.458647, 0.0988288, 0.966109, 0.0421747, 0.82035, 0.274711, + 0.359377, 0.512113, 0.689682, 0.941571, 0.31961, 0.743826, + 0.858147, 0.984766, 0.926973, 0.579597, 0.444104, 0.505969, + 0.241437, 0.937999, 0.0957074, 0.773611, 0.46023, 0.469379, + 0.363789, 0.269745, 0.486136, 0.894215, 0.794299, 0.724615 + ], [2, 3, 3, inDepth]); + var w = tf.stack([ + tf.stack([ + tf.tensor2d([0.240347, 0.906352, 0.478657, 0.825918], [fSize, fSize]), + tf.tensor2d([0.380769, 0.184705, 0.238241, 0.201907], [fSize, fSize]) + ], 2), + tf.stack([ + tf.tensor2d([0.294087, 0.181165, 0.191303, 0.7225], [fSize, fSize]), + tf.tensor2d([0.430064, 0.900622, 0.670338, 0.33478], [fSize, fSize]) + ], 2) + ], 3); + var fSizeDilated = fSize + (fSize - 1) * (dilation - 1); + var wDilated = tf.stack([ + tf.stack([ + tf.tensor2d([0.240347, 0, 0.906352, 0, 0, 0, 0.478657, 0, 0.825918], [fSizeDilated, fSizeDilated]), + tf.tensor2d([0.380769, 0, 0.184705, 0, 0, 0, 0.238241, 0, 0.201907], [fSizeDilated, fSizeDilated]) + ], 2), + tf.stack([ + tf.tensor2d([0.294087, 0, 0.181165, 0, 0, 0, 0.191303, 0, 0.7225], [fSizeDilated, fSizeDilated]), + tf.tensor2d([0.430064, 0, 0.900622, 0, 0, 0, 0.670338, 0, 0.33478], [fSizeDilated, fSizeDilated]) + ], 2) + ], 3); + var result = tf.depthwiseConv2d(x, w, stride, pad, 'NHWC', dilation); + var expectedResult = tf.depthwiseConv2d(x, wDilated, stride, pad, 'NHWC', noDilation); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('Tensor3D is allowed', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 3; + var inDepth = 2; + var x = tf.zeros([3, 3, inDepth]); + var w = tf.zeros([fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([3, 3, inDepth * chMul]); + }); + it('Pass null for dilations, which defaults to [1, 1]', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 3; + var inDepth = 2; + var dilations = null; + var x = tf.zeros([3, 3, inDepth]); + var w = tf.zeros([fSize, fSize, inDepth, chMul]); + var result = tf.depthwiseConv2d(x, w, stride, pad, 'NHWC', dilations); + expect(result.shape).toEqual([3, 3, inDepth * chMul]); + }); + it('throws when passed x as a non-tensor', function () { + var inputDepth = 1; + var outputDepth = 1; + var fSize = 1; + var pad = 'same'; + var stride = 2; + var dataFormat = 'NHWC'; + var dilation = 2; + var w = tf.tensor4d([3], [fSize, fSize, inputDepth, outputDepth]); + var e = /Argument 'x' passed to 'depthwiseConv2d' must be a Tensor/; + expect(function () { return tf.depthwiseConv2d({}, w, stride, pad, dataFormat, dilation); }) + .toThrowError(e); + }); + it('throws when passed filter as a non-tensor', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var pad = 'same'; + var stride = 2; + var dataFormat = 'NHWC'; + var dilation = 2; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var e = /Argument 'filter' passed to 'depthwiseConv2d' must be a Tensor/; + expect(function () { return tf.depthwiseConv2d(x, {}, stride, pad, dataFormat, dilation); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var pad = 'valid'; + var stride = 1; + var x = [[ + [[0.230664], [0.987388], [0.0685208]], + [[0.419224], [0.887861], [0.731641]], + [[0.0741907], [0.409265], [0.351377]] + ]]; + var w = [[[[0.303873]], [[0.229223]]], [[[0.144333]], [[0.803373]]]]; + var result = tf.depthwiseConv2d(x, w, stride, pad); + expect(result.shape).toEqual([1, 2, 2, 1]); + var expected = [1.07022, 1.03167, 0.67041, 0.778863]; + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('depthwiseConv2d gradients', test_util_1.ALL_ENVS, function () { + var images; + var filter; + var result; + var stride = 1; + var pad = 'same'; + beforeEach(function () { + images = tf.tensor4d([ + [[[2, 3, 1], [3, 0, 2]], [[0, 4, 1], [3, 1, 3]]], + [[[2, 1, 0], [0, 3, 3]], [[4, 0, 1], [1, 4, 1]]] + ]); + filter = tf.tensor4d([ + [[[1, 1], [1, 1], [0, 0]], [[0, 1], [1, 1], [1, 1]]], + [[[1, 0], [1, 1], [0, 0]], [[0, 1], [1, 0], [0, 0]]] + ]); + result = tf.tensor4d([ + [ + [[2, 8, 8, 7, 2, 2], [6, 3, 1, 1, 0, 0]], + [[0, 3, 5, 5, 3, 3], [3, 3, 1, 1, 0, 0]] + ], + [ + [[6, 3, 8, 4, 3, 3], [1, 0, 7, 7, 0, 0]], + [[4, 5, 4, 4, 1, 1], [1, 1, 4, 4, 0, 0]] + ] + ]); + }); + it('wrt input', function () { + var _a = tf.valueAndGrad(function (x) { return tf.depthwiseConv2d(x, filter, stride, pad); })(images), value = _a.value, grad = _a.grad; + test_util_1.expectArraysClose(value, result); + var expectedGrad = tf.tensor4d([ + [[[2., 2., 0.], [3., 4., 2.]], [[3., 4., 0.], [5., 7., 2.]]], + [[[2., 2., 0.], [3., 4., 2.]], [[3., 4., 0.], [5., 7., 2.]]] + ]); + test_util_1.expectArraysClose(grad, expectedGrad); + }); + it('wrt input, squared output', function () { + var grad = tf.grad(function (x) { + return tf.square(tf.depthwiseConv2d(x, filter, stride, pad)); + })(images); + var expectedGrad = tf.tensor4d([ + [[[20., 30., 0.], [34., 34., 8.]], [[10., 50., 0.], [46., 44., 12.]]], + [[[18., 24., 0.], [8., 52., 12.]], [[30., 40., 0.], [22., 76., 4.]]] + ]); + test_util_1.expectArraysClose(grad, expectedGrad); + }); + it('wrt filter', function () { + var _a = tf.valueAndGrad(function (f) { return tf.depthwiseConv2d(images, f, stride, pad); })(filter), value = _a.value, grad = _a.grad; + test_util_1.expectArraysClose(value, result); + var expectedGrad = tf.tensor4d([ + [[[15., 15.], [16., 16.], [12., 12.]], [[7., 7.], [8., 8.], [9., 9.]]], + [[[8., 8.], [9., 9.], [6., 6.]], [[4., 4.], [5., 5.], [4., 4.]]] + ]); + test_util_1.expectArraysClose(grad, expectedGrad); + }); + it('wrt filter, squared output', function () { + var grad = tf.grad(function (f) { + return tf.square(tf.depthwiseConv2d(images, f, stride, pad)); + })(filter); + var expectedGrad = tf.tensor4d([ + [ + [[120., 122.], [180., 166.], [12., 12.]], + [[20., 76.], [90., 66.], [46., 46.]] + ], + [ + [[86., 42.], [122., 114.], [10., 10.]], + [[24., 54.], [80., 46.], [18., 18.]] + ] + ]); + test_util_1.expectArraysClose(grad, expectedGrad); + }); + it('throws error on dilations > 1', function () { + var grad = tf.grad(function (x) { + return tf.depthwiseConv2d(x, filter, stride, pad, 'NHWC', 2); + }); + expect(function () { return grad(images); }) + .toThrowError(/dilation rates greater than 1 are not yet supported/); + }); + it('wrt input, stride=2, pad=valid', function () { + var dx = tf.grad(function (x) { return tf.depthwiseConv2d(x, filter, 2, 'valid'); })(images); + test_util_1.expectArraysClose(dx, tf.tensor4d([ + [[[2., 2., 0.], [1., 2., 2.]], [[1., 2., 0.], [1., 1., 0.]]], + [[[2., 2., 0.], [1., 2., 2.]], [[1., 2., 0.], [1., 1., 0.]]] + ])); + }); + it('wrt filter, stride=2, pad=valid', function () { + var df = tf.grad(function (f) { return tf.depthwiseConv2d(images, f, 2, 'valid'); })(filter); + test_util_1.expectArraysClose(df, tf.tensor4d([ + [[[4., 4.], [4., 4.], [1., 1.]], [[3., 3.], [3., 3.], [5., 5.]]], + [[[4., 4.], [4., 4.], [2., 2.]], [[4., 4.], [5., 5.], [4., 4.]]] + ])); + }); + it('wrt input and filter, 1x3x3x1 and 2x2x1x1', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var x = tf.tensor4d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [1, 3, 3, inDepth]); + var f = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var _a = tf.grads(function (x, f) { + return tf.depthwiseConv2d(x, f, stride, pad); + })([x, f]), dx = _a[0], df = _a[1]; + test_util_1.expectArraysClose(dx, tf.tensor4d([[ + [[0.303873], [0.533096], [0.229223]], + [[0.448206], [1.480802], [1.032596]], + [[0.144333], [0.947706], [0.803373]] + ]])); + test_util_1.expectArraysClose(df, tf.tensor4d([ + [[[2.525137]], [[2.6754108]]], [[[1.7905407]], [[2.380144]]] + ])); + }); +}); +//# sourceMappingURL=conv2d_depthwise_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js.map new file mode 100644 index 0000000..dfe2b91 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_depthwise_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv2d_depthwise_test.js","sourceRoot":"","sources":["../../src/ops/conv2d_depthwise_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js new file mode 100644 index 0000000..fee453e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js @@ -0,0 +1,296 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('separableConv2d', test_util_1.ALL_ENVS, function () { + it('input=1x3x3x1,f=2,s=1,d=1,p=valid,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.tensor4d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [1, 3, 3, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.10702161, -0.21404321, 0.10316753, -0.20633507, 0.06704096, + -0.13408193, 0.07788632, -0.15577264 + ], [1, 2, 2, outDepth])); + }); + it('input=1x3x3x1,f=2,s=1,d=1,p=valid,chMul=2,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 2; + var inDepth = 1; + var outDepth = 3; + var x = tf.tensor4d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [1, 3, 3, inDepth]); + var depthwiseFilter = tf.tensor4d([ + 0.303873, 0.229223, 0.144333, 0.803373, -0.303873, -0.229223, + -0.144333, -0.803373 + ], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2, -0.1, 0.2, 0.15, 0.15], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.00305368, 0.0140969, 0.00980358, -0.10853045, -0.06339455, + -0.0699412, 0.11010849, 0.0347524, 0.05214475, 0.10307151, + 0.02221644, 0.04224815 + ], [1, 2, 2, outDepth])); + }); + it('input=1x3x3x1,f=2,s=1,d=1,p=valid,chMul=1,outDepth=2,3D input', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.tensor3d([ + 0.230664, 0.987388, 0.0685208, 0.419224, 0.887861, 0.731641, + 0.0741907, 0.409265, 0.351377 + ], [3, 3, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor3d([ + 0.10702161, -0.21404321, 0.10316753, -0.20633507, 0.06704096, + -0.13408193, 0.07788632, -0.15577264 + ], [2, 2, outDepth])); + }); + it('input=1x4x4x1,f=2,s=2,d=1,p=valid,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = [2, 2]; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, 0.804231, + 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, 0.133869, 0.650827, + 0.047613, 0.554795 + ], [1, 4, 4, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.04919822, -0.09839644, 0.07275512, -0.14551024, 0.09901544, + -0.19803089, 0.05555845, -0.11111691 + ], [1, 2, 2, outDepth])); + }); + it('input=2x4x4x1,f=2,s=2,d=1,p=valid,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = [2, 2]; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, + 0.804231, 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, + 0.133869, 0.650827, 0.047613, 0.554795, -0.675707, -0.758567, + -0.413529, -0.963967, -0.217291, -0.101335, -0.804231, -0.329673, + -0.924503, -0.728742, -0.180217, -0.210459, -0.133869, -0.650827, + -0.047613, -0.554795 + ], [2, 4, 4, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.04919822, -0.09839644, 0.07275512, -0.14551024, 0.09901544, + -0.19803089, 0.05555845, -0.11111691, -0.04919822, 0.09839644, + -0.07275512, 0.14551024, -0.09901544, 0.19803089, -0.05555845, + 0.11111691 + ], [2, 2, 2, outDepth])); + }); + it('input=1x4x4x2,f=2,s=2,d=1,p=valid,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = [2, 2]; + var chMul = 1; + var inDepth = 2; + var outDepth = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, + 0.804231, 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, + 0.133869, 0.650827, 0.047613, 0.554795, -0.675707, -0.758567, + -0.413529, -0.963967, -0.217291, -0.101335, -0.804231, -0.329673, + -0.924503, -0.728742, -0.180217, -0.210459, -0.133869, -0.650827, + -0.047613, -0.554795 + ], [1, 4, 4, inDepth]); + var depthwiseFilter = tf.tensor4d([ + 0.303873, 0.229223, 0.144333, 0.803373, 0.98976838, 0.56597068, + 0.42654137, 0.66445535 + ], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2, 0.05, -0.05], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.20072255, -0.32641545, 0.08474462, -0.11823604, -0.20072255, + 0.32641545, -0.08474462, 0.11823604 + ], [1, 2, 2, outDepth])); + }); + it('input=1x4x4x1,f=2,s=1,d=2,p=valid,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var dilationRate = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, 0.804231, + 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, 0.133869, 0.650827, + 0.047613, 0.554795 + ], [1, 4, 4, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad, dilationRate); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.05783373, -0.11566745, 0.07257301, -0.14514601, 0.03079498, + -0.06158997, 0.06460048, -0.12920095 + ], [1, 2, 2, outDepth])); + }); + it('input=1x4x4x1,f=2,s=1,d=1,p=same,chMul=1,outDepth=2', function () { + var fSize = 2; + var pad = 'same'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.tensor4d([ + 0.675707, 0.758567, 0.413529, 0.963967, 0.217291, 0.101335, 0.804231, + 0.329673, 0.924503, 0.728742, 0.180217, 0.210459, 0.133869, 0.650827, + 0.047613, 0.554795 + ], [1, 4, 4, inDepth]); + var depthwiseFilter = tf.tensor4d([0.303873, 0.229223, 0.144333, 0.803373], [fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.tensor4d([0.1, -0.2], [1, 1, inDepth * chMul, outDepth]); + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor4d([ + 0.04919822, -0.09839644, 0.09860218, -0.19720435, 0.07275512, + -0.14551024, 0.03405062, -0.06810125, 0.08081452, -0.16162904, + 0.04651042, -0.09302084, 0.05150411, -0.10300821, 0.01305549, + -0.02611098, 0.09901544, -0.19803089, 0.03949417, -0.07898834, + 0.05555845, -0.11111691, 0.0144028, -0.02880561, 0.01898637, + -0.03797274, 0.02086828, -0.04173655, 0.01416401, -0.02832802, + 0.01685872, -0.03371745 + ], [1, 4, 4, outDepth])); + }); + it('Incorrect input rank raises error', function () { + var x = tf.zeros([4, 4]); + var depthwiseFilter = tf.zeros([2, 2, 1, 3]); + var pointwiseFilter = tf.zeros([1, 1, 2, 4]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/rank 4/); + }); + it('Incorrect depthwise filter rank raises error', function () { + var x = tf.zeros([1, 4, 4, 1]); + var depthwiseFilter = tf.zeros([2, 2, 1]); + var pointwiseFilter = tf.zeros([1, 1, 2, 4]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/rank 4/); + }); + it('Incorrect depthwise filter rank raises error', function () { + var x = tf.zeros([1, 4, 4, 1]); + var depthwiseFilter = tf.zeros([2, 2, 1, 3]); + var pointwiseFilter = tf.zeros([1, 1, 2]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/rank 4/); + }); + it('Incorrect point filter 1st dimension raises error', function () { + var x = tf.zeros([1, 4, 4, 1]); + var depthwiseFilter = tf.zeros([2, 2, 1, 3]); + var pointwiseFilter = tf.zeros([2, 1, 3, 6]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/must be 1, but got 2/); + }); + it('Incorrect point filter 2nd dimension raises error', function () { + var x = tf.zeros([1, 4, 4, 1]); + var depthwiseFilter = tf.zeros([2, 2, 1, 3]); + var pointwiseFilter = tf.zeros([1, 5, 3, 6]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/must be 1, but got 5/); + }); + it('Incorrect pointwise filter 3rd dimension raises error', function () { + var x = tf.zeros([1, 4, 4, 1]); + var depthwiseFilter = tf.zeros([2, 2, 1, 3]); + var pointwiseFilter = tf.zeros([1, 1, 4, 6]); + expect(function () { + return tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, 1, 'valid'); + }) + .toThrowError(/must be 3, but got 4/); + }); + it('throws when passed x as a non-tensor', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var depthwiseFilter = tf.zeros([fSize, fSize, inDepth, chMul]); + var pointwiseFilter = tf.zeros([1, 1, inDepth * chMul, outDepth]); + var e = /Argument 'x' passed to 'separableConv2d' must be a Tensor/; + expect(function () { return tf.separableConv2d({}, depthwiseFilter, pointwiseFilter, stride, pad); }) + .toThrowError(e); + }); + it('throws when passed depthwiseFilter as a non-tensor', function () { + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var outDepth = 2; + var x = tf.zeros([1, 3, 3, inDepth]); + var pointwiseFilter = tf.zeros([1, 1, inDepth * chMul, outDepth]); + var e = new RegExp('Argument \'depthwiseFilter\' passed to \'separableConv2d\'' + + ' must be a Tensor'); + expect(function () { return tf.separableConv2d(x, {}, pointwiseFilter, stride, pad); }) + .toThrowError(e); + }); + it('throws when passed pointwiseFilter as a non-tensor', function () { + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var chMul = 1; + var inDepth = 1; + var x = tf.zeros([1, 3, 3, inDepth]); + var depthwiseFilter = tf.zeros([fSize, fSize, inDepth, chMul]); + var e = new RegExp('Argument \'pointwiseFilter\' passed to \'separableConv2d\'' + + ' must be a Tensor'); + expect(function () { return tf.separableConv2d(x, depthwiseFilter, {}, stride, pad); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var pad = 'valid'; + var stride = 1; + var outDepth = 2; + var x = [ + [[0.230664], [0.987388], [0.0685208]], + [[0.419224], [0.887861], [0.731641]], + [[0.0741907], [0.409265], [0.351377]] + ]; + var depthwiseFilter = [[[[0.303873]], [[0.229223]]], [[[0.144333]], [[0.803373]]]]; + var pointwiseFilter = [[[[0.1, -0.2]]]]; + var result = tf.separableConv2d(x, depthwiseFilter, pointwiseFilter, stride, pad); + test_util_1.expectArraysClose(result, tf.tensor3d([ + 0.10702161, -0.21404321, 0.10316753, -0.20633507, 0.06704096, + -0.13408193, 0.07788632, -0.15577264 + ], [2, 2, outDepth])); + }); +}); +//# sourceMappingURL=conv2d_separable_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js.map new file mode 100644 index 0000000..fd818d3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_separable_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv2d_separable_test.js","sourceRoot":"","sources":["../../src/ops/conv2d_separable_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js new file mode 100644 index 0000000..9de0333 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js @@ -0,0 +1,192 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('conv2d', test_util_1.ALL_ENVS, function () { + it('x=[2,2,1] f=[1,1,1,2] s=1 d=1 p=0', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 1; + var pad = 0; + var stride = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor4d([2], [fSize, fSize, inputDepth, outputDepth]); + var result = tf.conv2d(x, w, stride, pad); + test_util_1.expectArraysClose(result, [2, 4, 6, 8]); + }); + it('x=[2,2,2,1] f=[1,1,1,1] s=1 d=1 p=0', function () { + var inputDepth = 1; + var inShape = [2, 2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 1; + var pad = 0; + var stride = 1; + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], inShape); + var w = tf.tensor4d([2], [fSize, fSize, inputDepth, outputDepth]); + var result = tf.conv2d(x, w, stride, pad); + expect(result.shape).toEqual([2, 2, 2, 1]); + var expected = [2, 4, 6, 8, 10, 12, 14, 16]; + test_util_1.expectArraysClose(result, expected); + }); + it('x=[2,2,1] f=[2,2,1,1] s=1 d=1 p=0', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = 1; + var dataFormat = 'NHWC'; + var dilation = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, inputDepth, outputDepth]); + var result = tf.conv2d(x, w, stride, pad, dataFormat, dilation); + test_util_1.expectArraysClose(result, [20]); + }); + it('x=[4,4,1] f=[2,2,1,1] s=1 d=2 p=0', function () { + var inputDepth = 1; + var inputShape = [4, 4, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var fSizeDilated = 3; + var pad = 0; + var stride = 1; + var dataFormat = 'NHWC'; + var dilation = 2; + var noDilation = 1; + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], inputShape); + var w = tf.tensor4d([3, 1, 5, 2], [fSize, fSize, inputDepth, outputDepth]); + var wDilated = tf.tensor4d([3, 0, 1, 0, 0, 0, 5, 0, 2], [fSizeDilated, fSizeDilated, inputDepth, outputDepth]); + var result = tf.conv2d(x, w, stride, pad, dataFormat, dilation); + var expectedResult = tf.conv2d(x, wDilated, stride, pad, dataFormat, noDilation); + expect(result.shape).toEqual(expectedResult.shape); + test_util_1.expectArraysClose(result, expectedResult); + }); + it('throws when x is not rank 3', function () { + var inputDepth = 1; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = 1; + var x = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, inputDepth, outputDepth]); + expect(function () { return tf.conv2d(x, w, stride, pad); }).toThrowError(); + }); + it('throws when weights is not rank 4', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var pad = 0; + var stride = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor3d([3, 1, 5, 0], [2, 2, 1]); + expect(function () { return tf.conv2d(x, w, stride, pad); }).toThrowError(); + }); + it('throws when x depth does not match weight depth', function () { + var inputDepth = 1; + var wrongInputDepth = 5; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.randomNormal([fSize, fSize, wrongInputDepth, outputDepth]); + expect(function () { return tf.conv2d(x, w, stride, pad); }).toThrowError(); + }); + it('throws when dimRoundingMode is set and pad is not a number', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 'valid'; + var stride = 1; + var dataFormat = 'NHWC'; + var dilation = 1; + var dimRoundingMode = 'round'; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.randomNormal([fSize, fSize, inputDepth, outputDepth]); + expect(function () { + return tf.conv2d(x, w, stride, pad, dataFormat, dilation, dimRoundingMode); + }) + .toThrowError(); + }); + it('throws when both stride and dilation are greater than 1', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var outputDepth = 1; + var fSize = 2; + var pad = 0; + var stride = [2, 1]; + var dataFormat = 'NHWC'; + var dilation = [1, 2]; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, inputDepth, outputDepth]); + expect(function () { return tf.conv2d(x, w, stride, pad, dataFormat, dilation); }) + .toThrowError(); + }); + it('gradient input=[3,3,1] f=[2,2,1,1] s=1 p=0', function () { + var inputDepth = 1; + var outputDepth = 1; + var inputShape = [3, 3, inputDepth]; + var filterSize = 2; + var stride = 1; + var pad = 0; + var filterShape = [filterSize, filterSize, inputDepth, outputDepth]; + var filter = tf.ones(filterShape); + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9], inputShape); + var dy = tf.tensor3d([3, 1, 2, 0], [2, 2, 1]); + var grads = tf.grads(function (x, filter) { return x.conv2d(filter, stride, pad); }); + var _a = grads([x, filter], dy), dx = _a[0], dfilter = _a[1]; + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [3, 4, 1, 5, 6, 1, 2, 2, 0]); + expect(dfilter.shape).toEqual(filterShape); + test_util_1.expectArraysClose(dfilter, [13, 19, 31, 37]); + }); + it('gradient x=[2,3,3,1] f=[2,2,1,1] s=1 p=0', function () { + var inputDepth = 1; + var outputDepth = 1; + var inputShape = [2, 3, 3, inputDepth]; + var filterSize = 2; + var stride = 1; + var pad = 0; + var filterShape = [filterSize, filterSize, inputDepth, outputDepth]; + var filter = tf.ones(filterShape); + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7, 8, 9], inputShape); + var dy = tf.tensor4d([3, 1, 2, 0, 3, 1, 2, 0], [2, 2, 2, 1]); + var grads = tf.grads(function (x, filter) { return x.conv2d(filter, stride, pad); }); + var _a = grads([x, filter], dy), dx = _a[0], dfilter = _a[1]; + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [3, 4, 1, 5, 6, 1, 2, 2, 0, 3, 4, 1, 5, 6, 1, 2, 2, 0]); + expect(dfilter.shape).toEqual(filterShape); + test_util_1.expectArraysClose(dfilter, [13 * 2, 19 * 2, 31 * 2, 37 * 2]); + }); + it('throws when passed x as a non-tensor', function () { + var inputDepth = 1; + var outputDepth = 1; + var fSize = 1; + var pad = 0; + var stride = 1; + var w = tf.tensor4d([2], [fSize, fSize, inputDepth, outputDepth]); + expect(function () { return tf.conv2d({}, w, stride, pad); }) + .toThrowError(/Argument 'x' passed to 'conv2d' must be a Tensor/); + }); + it('throws when passed filter as a non-tensor', function () { + var inputDepth = 1; + var inputShape = [2, 2, inputDepth]; + var pad = 0; + var stride = 1; + var x = tf.tensor3d([1, 2, 3, 4], inputShape); + expect(function () { return tf.conv2d(x, {}, stride, pad); }) + .toThrowError(/Argument 'filter' passed to 'conv2d' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var pad = 0; + var stride = 1; + var x = [[[1], [2]], [[3], [4]]]; + var w = [[[[2]]]]; + var result = tf.conv2d(x, w, stride, pad); + test_util_1.expectArraysClose(result, [2, 4, 6, 8]); + }); +}); +//# sourceMappingURL=conv2d_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js.map new file mode 100644 index 0000000..a34c5e3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv2d_test.js","sourceRoot":"","sources":["../../src/ops/conv2d_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js new file mode 100644 index 0000000..dddaf02 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js @@ -0,0 +1,101 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('conv2dTranspose', test_util_1.ALL_ENVS, function () { + it('input=2x2x1,d2=1,f=2,s=1,p=0', function () { + var origInputDepth = 1; + var origOutputDepth = 1; + var inputShape = [1, 1, origOutputDepth]; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var x = tf.tensor3d([2], inputShape); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, origInputDepth, origOutputDepth]); + var result = tf.conv2dTranspose(x, w, [2, 2, 1], origStride, origPad); + var expected = [6, 2, 10, 0]; + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, expected); + }); + it('input=2x2x1,d2=1,f=2,s=1,p=0, batch=2', function () { + var origInputDepth = 1; + var origOutputDepth = 1; + var inputShape = [2, 1, 1, origOutputDepth]; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var x = tf.tensor4d([2, 3], inputShape); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, origInputDepth, origOutputDepth]); + var result = tf.conv2dTranspose(x, w, [2, 2, 2, 1], origStride, origPad); + var expected = [6, 2, 10, 0, 9, 3, 15, 0]; + expect(result.shape).toEqual([2, 2, 2, 1]); + test_util_1.expectArraysClose(result, expected); + }); + it('throws when x is not rank 3', function () { + var origInputDepth = 1; + var origOutputDepth = 1; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var x = tf.tensor2d([2, 2], [2, 1]); + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, origInputDepth, origOutputDepth]); + expect(function () { return tf.conv2dTranspose(x, w, [2, 2, 1], origStride, origPad); }) + .toThrowError(); + }); + it('throws when weights is not rank 4', function () { + var origInputDepth = 1; + var origOutputDepth = 1; + var inputShape = [1, 1, origOutputDepth]; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var x = tf.tensor3d([2], inputShape); + var w = tf.tensor3d([3, 1, 5, 0], [fSize, fSize, origInputDepth]); + expect(function () { return tf.conv2dTranspose(x, w, [2, 2, 1], origStride, origPad); }) + .toThrowError(); + }); + it('throws when x depth does not match weights original output depth', function () { + var origInputDepth = 1; + var origOutputDepth = 2; + var wrongOrigOutputDepth = 3; + var inputShape = [1, 1, origOutputDepth]; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var x = tf.tensor3d([2, 2], inputShape); + var w = tf.randomNormal([fSize, fSize, origInputDepth, wrongOrigOutputDepth]); + expect(function () { return tf.conv2dTranspose(x, w, [2, 2, 2], origStride, origPad); }) + .toThrowError(); + }); + it('throws when passed x as a non-tensor', function () { + var origInputDepth = 1; + var origOutputDepth = 1; + var fSize = 2; + var origPad = 0; + var origStride = 1; + var w = tf.tensor4d([3, 1, 5, 0], [fSize, fSize, origInputDepth, origOutputDepth]); + expect(function () { return tf.conv2dTranspose({}, w, [2, 2, 1], origStride, origPad); }) + .toThrowError(/Argument 'x' passed to 'conv2dTranspose' must be a Tensor/); + }); + it('throws when passed filter as a non-tensor', function () { + var origOutputDepth = 1; + var inputShape = [1, 1, origOutputDepth]; + var origPad = 0; + var origStride = 1; + var x = tf.tensor3d([2], inputShape); + expect(function () { return tf.conv2dTranspose(x, {}, [2, 2, 1], origStride, origPad); }) + .toThrowError(/Argument 'filter' passed to 'conv2dTranspose' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var origPad = 0; + var origStride = 1; + var x = [[[2]]]; + var w = [[[[3]], [[1]]], [[[5]], [[0]]]]; + var result = tf.conv2dTranspose(x, w, [2, 2, 1], origStride, origPad); + var expected = [6, 2, 10, 0]; + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, expected); + }); +}); +//# sourceMappingURL=conv2d_transpose_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js.map new file mode 100644 index 0000000..05c4dd1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv2d_transpose_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv2d_transpose_test.js","sourceRoot":"","sources":["../../src/ops/conv2d_transpose_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.d.ts new file mode 100644 index 0000000..846670b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.d.ts @@ -0,0 +1,30 @@ +export declare type PadInfo = { + top: number; + left: number; + right: number; + bottom: number; + type: string; +}; +export declare type Conv2DInfo = { + batchSize: number; + inHeight: number; + inWidth: number; + inChannels: number; + outHeight: number; + outWidth: number; + outChannels: number; + dataFormat: 'channelsFirst' | 'channelsLast'; + strideHeight: number; + strideWidth: number; + dilationHeight: number; + dilationWidth: number; + filterHeight: number; + filterWidth: number; + padInfo: PadInfo; + inShape: [number, number, number, number]; + outShape: [number, number, number, number]; + filterShape: [number, number, number, number]; +}; +export declare function computePool2DInfo(inShape: [number, number, number, number], filterSize: [number, number] | number, strides: number | [number, number], pad: 'same' | 'valid' | number, roundingMode?: 'floor' | 'round' | 'ceil', dataFormat?: 'channelsFirst' | 'channelsLast'): Conv2DInfo; +export declare function computeConv2DInfo(inShape: [number, number, number, number], filterShape: [number, number, number, number], strides: number | [number, number], dilations: number | [number, number], pad: 'same' | 'valid' | number, roundingMode?: 'floor' | 'round' | 'ceil', depthwise?: boolean, dataFormat?: 'channelsFirst' | 'channelsLast'): Conv2DInfo; +export declare function computeDefaultPad(inputShape: [number, number, number], fieldSize: number, stride: number, dilation?: number): number; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js new file mode 100644 index 0000000..fc6721c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js @@ -0,0 +1,146 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("../util"); +function computePool2DInfo(inShape, filterSize, strides, pad, roundingMode, dataFormat) { + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var _a = parseTupleParam(filterSize), filterHeight = _a[0], filterWidth = _a[1]; + var filterShape; + if (dataFormat === 'channelsLast') { + filterShape = [filterHeight, filterWidth, inShape[3], inShape[3]]; + } + else if (dataFormat === 'channelsFirst') { + filterShape = [filterHeight, filterWidth, inShape[1], inShape[1]]; + } + else { + throw new Error("Unknown dataFormat " + dataFormat); + } + var dilations = 1; + return computeConv2DInfo(inShape, filterShape, strides, dilations, pad, roundingMode, false, dataFormat); +} +exports.computePool2DInfo = computePool2DInfo; +function computeConv2DInfo(inShape, filterShape, strides, dilations, pad, roundingMode, depthwise, dataFormat) { + if (depthwise === void 0) { depthwise = false; } + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var _a = [-1, -1, -1, -1], batchSize = _a[0], inHeight = _a[1], inWidth = _a[2], inChannels = _a[3]; + if (dataFormat === 'channelsLast') { + batchSize = inShape[0], inHeight = inShape[1], inWidth = inShape[2], inChannels = inShape[3]; + } + else if (dataFormat === 'channelsFirst') { + batchSize = inShape[0], inChannels = inShape[1], inHeight = inShape[2], inWidth = inShape[3]; + } + else { + throw new Error("Unknown dataFormat " + dataFormat); + } + var filterHeight = filterShape[0], filterWidth = filterShape[1], filterChannels = filterShape[3]; + var _b = parseTupleParam(strides), strideHeight = _b[0], strideWidth = _b[1]; + var _c = parseTupleParam(dilations), dilationHeight = _c[0], dilationWidth = _c[1]; + var effectiveFilterHeight = getEffectiveFilterSize(filterHeight, dilationHeight); + var effectiveFilterWidth = getEffectiveFilterSize(filterWidth, dilationWidth); + var _d = getPadAndOutInfo(pad, inHeight, inWidth, strideHeight, strideWidth, effectiveFilterHeight, effectiveFilterWidth, roundingMode), padInfo = _d.padInfo, outHeight = _d.outHeight, outWidth = _d.outWidth; + var outChannels = depthwise ? filterChannels * inChannels : filterChannels; + var outShape; + if (dataFormat === 'channelsFirst') { + outShape = [batchSize, outChannels, outHeight, outWidth]; + } + else if (dataFormat === 'channelsLast') { + outShape = [batchSize, outHeight, outWidth, outChannels]; + } + return { + batchSize: batchSize, + dataFormat: dataFormat, + inHeight: inHeight, + inWidth: inWidth, + inChannels: inChannels, + outHeight: outHeight, + outWidth: outWidth, + outChannels: outChannels, + padInfo: padInfo, + strideHeight: strideHeight, + strideWidth: strideWidth, + filterHeight: filterHeight, + filterWidth: filterWidth, + dilationHeight: dilationHeight, + dilationWidth: dilationWidth, + inShape: inShape, + outShape: outShape, + filterShape: filterShape + }; +} +exports.computeConv2DInfo = computeConv2DInfo; +function computeOutputShape3D(inShape, fieldSize, outDepth, stride, zeroPad, roundingMode) { + if (zeroPad == null) { + zeroPad = computeDefaultPad(inShape, fieldSize, stride); + } + var inputRows = inShape[0]; + var inputCols = inShape[1]; + var outputRows = conditionalRound((inputRows - fieldSize + 2 * zeroPad) / stride + 1, roundingMode); + util.assert(util.isInt(outputRows), "The output # of rows (" + outputRows + ") must be an integer. Change the " + + "stride and/or zero pad parameters"); + var outputCols = conditionalRound((inputCols - fieldSize + 2 * zeroPad) / stride + 1, roundingMode); + util.assert(util.isInt(outputCols), "The output # of columns (" + outputCols + ") must be an integer. Change " + + "the stride and/or zero pad parameters"); + return [outputRows, outputCols, outDepth]; +} +function computeDefaultPad(inputShape, fieldSize, stride, dilation) { + if (dilation === void 0) { dilation = 1; } + var effectiveFieldSize = getEffectiveFilterSize(fieldSize, dilation); + return Math.floor((inputShape[0] * (stride - 1) - stride + effectiveFieldSize) / 2); +} +exports.computeDefaultPad = computeDefaultPad; +function parseTupleParam(param) { + return typeof param === 'number' ? [param, param] : param; +} +function getEffectiveFilterSize(filterSize, dilation) { + if (dilation <= 1) { + return filterSize; + } + return filterSize + (filterSize - 1) * (dilation - 1); +} +function getPadAndOutInfo(pad, inHeight, inWidth, strideHeight, strideWidth, filterHeight, filterWidth, roundingMode) { + var padInfo; + var outHeight; + var outWidth; + if (typeof pad === 'number') { + var padType = (pad === 0) ? 'VALID' : 'NUMBER'; + padInfo = { top: pad, bottom: pad, left: pad, right: pad, type: padType }; + var outShape = computeOutputShape3D([inHeight, inWidth, 1], filterHeight, 1, strideHeight, pad, roundingMode); + outHeight = outShape[0]; + outWidth = outShape[1]; + } + else if (pad === 'same') { + outHeight = Math.ceil(inHeight / strideHeight); + outWidth = Math.ceil(inWidth / strideWidth); + var padAlongHeight = (outHeight - 1) * strideHeight + filterHeight - inHeight; + var padAlongWidth = (outWidth - 1) * strideWidth + filterWidth - inWidth; + var top_1 = Math.floor(padAlongHeight / 2); + var bottom = padAlongHeight - top_1; + var left = Math.floor(padAlongWidth / 2); + var right = padAlongWidth - left; + padInfo = { top: top_1, bottom: bottom, left: left, right: right, type: 'SAME' }; + } + else if (pad === 'valid') { + padInfo = { top: 0, bottom: 0, left: 0, right: 0, type: 'VALID' }; + outHeight = Math.ceil((inHeight - filterHeight + 1) / strideHeight); + outWidth = Math.ceil((inWidth - filterWidth + 1) / strideWidth); + } + else { + throw Error("Unknown padding parameter: " + pad); + } + return { padInfo: padInfo, outHeight: outHeight, outWidth: outWidth }; +} +function conditionalRound(value, roundingMode) { + if (!roundingMode) { + return value; + } + switch (roundingMode) { + case 'round': + return Math.round(value); + case 'ceil': + return Math.ceil(value); + case 'floor': + return Math.floor(value); + default: + throw new Error("Unknown roundingMode " + roundingMode); + } +} +//# sourceMappingURL=conv_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js.map new file mode 100644 index 0000000..22d8626 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_util.js","sourceRoot":"","sources":["../../src/ops/conv_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js new file mode 100644 index 0000000..a7e39b2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js @@ -0,0 +1,322 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var conv_util = require("./conv_util"); +describe('conv_util computeConvInfo', function () { + it('1x1 conv over 1x1 array with same pad', function () { + var inShape = [1, 1, 1, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [1, 1, 1, 1], stride, dilation, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(1); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 conv over 3x3 array with same pad', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilation, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + expect(convInfo.padInfo.left).toBe(0); + expect(convInfo.padInfo.right).toBe(1); + expect(convInfo.padInfo.top).toBe(0); + expect(convInfo.padInfo.bottom).toBe(1); + }); + it('2x2 conv over 3x3 array with same pad', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilation, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 conv over 3x3 array with valid pad', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(2); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(1); + }); + it('3x3 conv over 5x5 array with same pad with stride 2', function () { + var inShape = [1, 5, 5, 1]; + var stride = 2; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [3, 3, 1, 1], stride, dilation, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + expect(convInfo.padInfo.left).toBe(1); + expect(convInfo.padInfo.right).toBe(1); + expect(convInfo.padInfo.top).toBe(1); + expect(convInfo.padInfo.bottom).toBe(1); + }); + it('2x2 conv over 3x3 array with valid pad with stride 2', function () { + var inShape = [1, 3, 3, 1]; + var stride = 2; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(1); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x1 conv over 3x3 array with valid pad with stride 1', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 1, 1, 1], stride, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(2); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x1 conv over 3x3 array with valid pad with strides h=2, w=1', function () { + var inShape = [1, 3, 3, 1]; + var strides = [2, 1]; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 1, 1, 1], strides, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + }); + it('1x2 conv over 3x3 array with valid pad with stride 1', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [1, 2, 1, 1], stride, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(1); + }); + it('1x2 conv over 3x3 array with valid pad with stride 1, batch=5', function () { + var inShape = [5, 3, 3, 1]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [1, 2, 1, 1], stride, dilation, 'valid'); + expect(convInfo.batchSize).toEqual(5); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 conv over 3x3 array with same pad with dilations 2', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilations = 2; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilations, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + expect(convInfo.padInfo.left).toBe(1); + expect(convInfo.padInfo.right).toBe(1); + expect(convInfo.padInfo.top).toBe(1); + expect(convInfo.padInfo.bottom).toBe(1); + }); + it('2x1 conv over 3x3 array with same pad with dilations 2', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilations = 2; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 1, 1, 1], stride, dilations, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + expect(convInfo.padInfo.left).toBe(0); + expect(convInfo.padInfo.right).toBe(0); + expect(convInfo.padInfo.top).toBe(1); + expect(convInfo.padInfo.bottom).toBe(1); + }); + it('3x4 conv over 8x8 array with same pad with dilations h=4 w=3', function () { + var inShape = [1, 8, 8, 1]; + var stride = 1; + var dilations = [4, 3]; + var convInfo = conv_util.computeConv2DInfo(inShape, [3, 4, 1, 1], stride, dilations, 'same'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(8); + expect(convInfo.outWidth).toEqual(8); + expect(convInfo.outChannels).toEqual(1); + expect(convInfo.padInfo.left).toBe(4); + expect(convInfo.padInfo.right).toBe(5); + expect(convInfo.padInfo.top).toBe(4); + expect(convInfo.padInfo.bottom).toBe(4); + }); + it('2x1 conv over 3x3 array with valid pad with dilations 2', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilations = 2; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 1, 1, 1], stride, dilations, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 conv over 3x3 array with valid pad with dilations 2', function () { + var inShape = [1, 3, 3, 1]; + var stride = 1; + var dilations = 2; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilations, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(1); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 conv over 4x4 array with valid pad with dilations 2', function () { + var inShape = [1, 4, 4, 1]; + var stride = 1; + var dilations = 2; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, 1, 1], stride, dilations, 'valid'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(2); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(1); + }); +}); +describe('conv_util computeConv2DInfo with depthwise=true', function () { + it('1x1 filter over 1x1 array with same pad', function () { + var inChannels = 1; + var inShape = [1, 1, 1, inChannels]; + var fSize = 1; + var chMul = 1; + var stride = 1; + var dilation = 1; + var pad = 'same'; + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, null, true); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(1); + expect(convInfo.outWidth).toEqual(1); + expect(convInfo.outChannels).toEqual(1); + }); + it('2x2 filter over 3x3 array with same pad, chMul=3, depth=2', function () { + var inChannels = 2; + var batchSize = 1; + var inSize = 3; + var inShape = [batchSize, inSize, inSize, inChannels]; + var fSize = 2; + var chMul = 3; + var stride = 1; + var dilation = 1; + var pad = 'same'; + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, null, true); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(6); + }); + it('2x2 filter over 3x3 array with valid pad, chMul=3, depth=2', function () { + var inChannels = 2; + var batchSize = 1; + var inSize = 3; + var inShape = [batchSize, inSize, inSize, inChannels]; + var fSize = 2; + var chMul = 3; + var stride = 1; + var dilation = 1; + var pad = 'valid'; + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, null, true); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(2); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(6); + }); +}); +describe('conv_util computeConvInfo channelsFirst', function () { + it('2x2 conv over 3x3 array with same pad', function () { + var inDepth = 2; + var outDepth = 4; + var inShape = [1, inDepth, 3, 3]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, inDepth, outDepth], stride, dilation, 'same', null, false, 'channelsFirst'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(3); + expect(convInfo.outWidth).toEqual(3); + expect(convInfo.outChannels).toEqual(4); + expect(convInfo.outShape).toEqual([1, 4, 3, 3]); + expect(convInfo.padInfo.left).toBe(0); + expect(convInfo.padInfo.right).toBe(1); + expect(convInfo.padInfo.top).toBe(0); + expect(convInfo.padInfo.bottom).toBe(1); + }); + it('2x2 conv over 3x3 array with valid pad', function () { + var inDepth = 6; + var outDepth = 16; + var inShape = [1, inDepth, 3, 3]; + var stride = 1; + var dilation = 1; + var convInfo = conv_util.computeConv2DInfo(inShape, [2, 2, inDepth, outDepth], stride, dilation, 'valid', null, false, 'channelsFirst'); + expect(convInfo.batchSize).toEqual(1); + expect(convInfo.outHeight).toEqual(2); + expect(convInfo.outWidth).toEqual(2); + expect(convInfo.outChannels).toEqual(16); + expect(convInfo.outShape).toEqual([1, 16, 2, 2]); + expect(convInfo.padInfo.left).toBe(0); + expect(convInfo.padInfo.right).toBe(0); + expect(convInfo.padInfo.top).toBe(0); + expect(convInfo.padInfo.bottom).toBe(0); + }); +}); +describe('conv_util computeConvInfo roundingMode', function () { + var inChannels = 6; + var batchSize = 1; + var inSize = 5; + var inShape = [batchSize, inSize, inSize, inChannels]; + var fSize = 2; + var chMul = 12; + var stride = 2; + var dilation = 1; + var pad = 1; + it('should fail computing the output dimension of Conv Layer', function () { + expect(function () { return conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad); }) + .toThrowError(); + }); + it('Floor the output dimension of Conv Layer', function () { + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, 'floor'); + expect(convInfo.outShape).toEqual([batchSize, 3, 3, chMul]); + }); + it('Round the output dimension of Conv Layer', function () { + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, 'round'); + expect(convInfo.outShape).toEqual([batchSize, 4, 4, chMul]); + }); + it('Ceil the output dimension of Conv Layer', function () { + var convInfo = conv_util.computeConv2DInfo(inShape, [fSize, fSize, inChannels, chMul], stride, dilation, pad, 'ceil'); + expect(convInfo.outShape).toEqual([batchSize, 4, 4, chMul]); + }); +}); +describe('conv_util computePoolInfo roundingMode', function () { + var inChannels = 6; + var batchSize = 1; + var inSize = 5; + var inShape = [batchSize, inSize, inSize, inChannels]; + var fSize = 2; + var stride = 2; + var pad = 1; + it('should fail computing the output dimension of Pool Layer', function () { + expect(function () { return conv_util.computePool2DInfo(inShape, [fSize, fSize], stride, pad); }) + .toThrowError(); + }); + it('Floor the output dimension of Pool Layer', function () { + var poolInfo = conv_util.computePool2DInfo(inShape, [fSize, fSize], stride, pad, 'floor'); + expect(poolInfo.outShape).toEqual([batchSize, 3, 3, inChannels]); + }); + it('Round the output dimension of Pool Layer', function () { + var poolInfo = conv_util.computePool2DInfo(inShape, [fSize, fSize], stride, pad, 'round'); + expect(poolInfo.outShape).toEqual([batchSize, 4, 4, inChannels]); + }); + it('Ceil the output dimension of Pool Layer', function () { + var poolInfo = conv_util.computePool2DInfo(inShape, [fSize, fSize], stride, pad, 'ceil'); + expect(poolInfo.outShape).toEqual([batchSize, 4, 4, inChannels]); + }); +}); +//# sourceMappingURL=conv_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js.map new file mode 100644 index 0000000..784d7d5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/conv_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_util_test.js","sourceRoot":"","sources":["../../src/ops/conv_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.d.ts new file mode 100644 index 0000000..04a64d4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.d.ts @@ -0,0 +1,6 @@ +export declare const ERF_P = 0.3275911; +export declare const ERF_A1 = 0.254829592; +export declare const ERF_A2 = -0.284496736; +export declare const ERF_A3 = 1.421413741; +export declare const ERF_A4 = -1.453152027; +export declare const ERF_A5 = 1.061405429; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js new file mode 100644 index 0000000..0987a81 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js @@ -0,0 +1,9 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.ERF_P = 0.3275911; +exports.ERF_A1 = 0.254829592; +exports.ERF_A2 = -0.284496736; +exports.ERF_A3 = 1.421413741; +exports.ERF_A4 = -1.453152027; +exports.ERF_A5 = 1.061405429; +//# sourceMappingURL=erf_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js.map new file mode 100644 index 0000000..d67cb7d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/erf_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"erf_util.js","sourceRoot":"","sources":["../../src/ops/erf_util.ts"],"names":[],"mappings":";;AAiBa,QAAA,KAAK,GAAG,SAAS,CAAC;AAClB,QAAA,MAAM,GAAG,WAAW,CAAC;AACrB,QAAA,MAAM,GAAG,CAAC,WAAW,CAAC;AACtB,QAAA,MAAM,GAAG,WAAW,CAAC;AACrB,QAAA,MAAM,GAAG,CAAC,WAAW,CAAC;AACtB,QAAA,MAAM,GAAG,WAAW,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.d.ts new file mode 100644 index 0000000..7e88df3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.d.ts @@ -0,0 +1,11 @@ +import { Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function resizeBilinear_(images: T | TensorLike, size: [number, number], alignCorners?: boolean): T; +declare function resizeNearestNeighbor_(images: T | TensorLike, size: [number, number], alignCorners?: boolean): T; +declare function nonMaxSuppression_(boxes: Tensor2D | TensorLike, scores: Tensor1D | TensorLike, maxOutputSize: number, iouThreshold?: number, scoreThreshold?: number): Tensor1D; +declare function nonMaxSuppressionAsync_(boxes: Tensor2D | TensorLike, scores: Tensor1D | TensorLike, maxOutputSize: number, iouThreshold?: number, scoreThreshold?: number): Promise; +export declare const resizeBilinear: typeof resizeBilinear_; +export declare const resizeNearestNeighbor: typeof resizeNearestNeighbor_; +export declare const nonMaxSuppression: typeof nonMaxSuppression_; +export declare const nonMaxSuppressionAsync: typeof nonMaxSuppressionAsync_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js new file mode 100644 index 0000000..1c78459 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js @@ -0,0 +1,168 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var non_max_suppression_impl_1 = require("../kernels/non_max_suppression_impl"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var operation_1 = require("./operation"); +function resizeBilinear_(images, size, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + var $images = tensor_util_env_1.convertToTensor(images, 'images', 'resizeBilinear'); + util.assert($images.rank === 3 || $images.rank === 4, "Error in resizeBilinear: x must be rank 3 or 4, but got " + + ("rank " + $images.rank + ".")); + util.assert(size.length === 2, "Error in resizeBilinear: new shape must 2D, but got shape " + + (size + ".")); + var batchImages = $images; + var reshapedTo4D = false; + if ($images.rank === 3) { + reshapedTo4D = true; + batchImages = + $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]); + } + var newHeight = size[0], newWidth = size[1]; + var forward = function (backend, save) { + return backend.resizeBilinear(batchImages, newHeight, newWidth, alignCorners); + }; + var backward = function (dy, saved) { + return { + batchImages: function () { return environment_1.ENV.engine.runKernel(function (backend) { + return backend.resizeBilinearBackprop(dy, batchImages, alignCorners); + }, {}); } + }; + }; + var res = environment_1.ENV.engine.runKernel(forward, { batchImages: batchImages }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function resizeNearestNeighbor_(images, size, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + var $images = tensor_util_env_1.convertToTensor(images, 'images', 'resizeNearestNeighbor'); + util.assert($images.rank === 3 || $images.rank === 4, "Error in resizeNearestNeighbor: x must be rank 3 or 4, but got " + + ("rank " + $images.rank + ".")); + util.assert(size.length === 2, "Error in resizeNearestNeighbor: new shape must 2D, but got shape " + + (size + ".")); + util.assert($images.dtype === 'float32' || $images.dtype === 'int32', '`images` must have `int32` or `float32` as dtype'); + var batchImages = $images; + var reshapedTo4D = false; + if ($images.rank === 3) { + reshapedTo4D = true; + batchImages = + $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]); + } + var newHeight = size[0], newWidth = size[1]; + var forward = function (backend, save) { + return backend.resizeNearestNeighbor(batchImages, newHeight, newWidth, alignCorners); + }; + var backward = function (dy, saved) { + return { + batchImages: function () { return environment_1.ENV.engine.runKernel(function (backend) { return backend.resizeNearestNeighborBackprop(dy, batchImages, alignCorners); }, {}); } + }; + }; + var res = environment_1.ENV.engine.runKernel(forward, { batchImages: batchImages }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function nonMaxSuppression_(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold === void 0) { iouThreshold = 0.5; } + if (scoreThreshold === void 0) { scoreThreshold = Number.NEGATIVE_INFINITY; } + var $boxes = tensor_util_env_1.convertToTensor(boxes, 'boxes', 'nonMaxSuppression'); + var $scores = tensor_util_env_1.convertToTensor(scores, 'scores', 'nonMaxSuppression'); + var inputs = nonMaxSuppSanityCheck($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); + maxOutputSize = inputs.maxOutputSize; + iouThreshold = inputs.iouThreshold; + scoreThreshold = inputs.scoreThreshold; + return environment_1.ENV.engine.runKernel(function (b) { return b.nonMaxSuppression($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); }, { $boxes: $boxes }); +} +function nonMaxSuppressionAsync_(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold === void 0) { iouThreshold = 0.5; } + if (scoreThreshold === void 0) { scoreThreshold = Number.NEGATIVE_INFINITY; } + return __awaiter(this, void 0, void 0, function () { + var $boxes, $scores, inputs, boxesVals, scoresVals, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + $boxes = tensor_util_env_1.convertToTensor(boxes, 'boxes', 'nonMaxSuppressionAsync'); + $scores = tensor_util_env_1.convertToTensor(scores, 'scores', 'nonMaxSuppressionAsync'); + inputs = nonMaxSuppSanityCheck($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); + maxOutputSize = inputs.maxOutputSize; + iouThreshold = inputs.iouThreshold; + scoreThreshold = inputs.scoreThreshold; + return [4, $boxes.data()]; + case 1: + boxesVals = _a.sent(); + return [4, $scores.data()]; + case 2: + scoresVals = _a.sent(); + res = non_max_suppression_impl_1.nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + if ($boxes !== boxes) { + $boxes.dispose(); + } + if ($scores !== scores) { + $scores.dispose(); + } + return [2, res]; + } + }); + }); +} +function nonMaxSuppSanityCheck(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold == null) { + iouThreshold = 0.5; + } + if (scoreThreshold == null) { + scoreThreshold = Number.NEGATIVE_INFINITY; + } + var numBoxes = boxes.shape[0]; + maxOutputSize = Math.min(maxOutputSize, numBoxes); + util.assert(0 <= iouThreshold && iouThreshold <= 1, "iouThreshold must be in [0, 1], but was '" + iouThreshold + "'"); + util.assert(boxes.rank === 2, "boxes must be a 2D tensor, but was of rank '" + boxes.rank + "'"); + util.assert(boxes.shape[1] === 4, "boxes must have 4 columns, but 2nd dimension was " + boxes.shape[1]); + util.assert(scores.rank === 1, 'scores must be a 1D tensor'); + util.assert(scores.shape[0] === numBoxes, "scores has incompatible shape with boxes. Expected " + numBoxes + ", " + + ("but was " + scores.shape[0])); + return { maxOutputSize: maxOutputSize, iouThreshold: iouThreshold, scoreThreshold: scoreThreshold }; +} +exports.resizeBilinear = operation_1.op({ resizeBilinear_: resizeBilinear_ }); +exports.resizeNearestNeighbor = operation_1.op({ resizeNearestNeighbor_: resizeNearestNeighbor_ }); +exports.nonMaxSuppression = operation_1.op({ nonMaxSuppression_: nonMaxSuppression_ }); +exports.nonMaxSuppressionAsync = nonMaxSuppressionAsync_; +//# sourceMappingURL=image_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js.map new file mode 100644 index 0000000..4d626c2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"image_ops.js","sourceRoot":"","sources":["../../src/ops/image_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js new file mode 100644 index 0000000..13e895c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js @@ -0,0 +1,211 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('nonMaxSuppression', test_util_1.ALL_ENVS, function () { + it('select from three clusters', function () { + var boxes = tf.tensor2d([ + 0, 0, 1, 1, 0, 0.1, 1, 1.1, 0, -0.1, 1, 0.9, + 0, 10, 1, 11, 0, 10.1, 1, 11.1, 0, 100, 1, 101 + ], [6, 4]); + var scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5, 0.3]); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([3]); + test_util_1.expectArraysEqual(indices, [3, 0, 5]); + }); + it('select from three clusters flipped coordinates', function () { + var boxes = tf.tensor2d([ + 1, 1, 0, 0, 0, 0.1, 1, 1.1, 0, .9, 1, -0.1, + 0, 10, 1, 11, 1, 10.1, 0, 11.1, 1, 101, 0, 100 + ], [6, 4]); + var scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5, 0.3]); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([3]); + test_util_1.expectArraysEqual(indices, [3, 0, 5]); + }); + it('select at most two boxes from three clusters', function () { + var boxes = tf.tensor2d([ + 0, 0, 1, 1, 0, 0.1, 1, 1.1, 0, -0.1, 1, 0.9, + 0, 10, 1, 11, 0, 10.1, 1, 11.1, 0, 100, 1, 101 + ], [6, 4]); + var scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5, 0.3]); + var maxOutputSize = 2; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([2]); + test_util_1.expectArraysEqual(indices, [3, 0]); + }); + it('select at most thirty boxes from three clusters', function () { + var boxes = tf.tensor2d([ + 0, 0, 1, 1, 0, 0.1, 1, 1.1, 0, -0.1, 1, 0.9, + 0, 10, 1, 11, 0, 10.1, 1, 11.1, 0, 100, 1, 101 + ], [6, 4]); + var scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5, 0.3]); + var maxOutputSize = 30; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([3]); + test_util_1.expectArraysEqual(indices, [3, 0, 5]); + }); + it('select single box', function () { + var boxes = tf.tensor2d([0, 0, 1, 1], [1, 4]); + var scores = tf.tensor1d([0.9]); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([1]); + test_util_1.expectArraysEqual(indices, [0]); + }); + it('select from ten identical boxes', function () { + var boxes = tf.tensor2d([0, 0, 1, 1], [1, 4]); + var scores = tf.tensor1d([0.9]); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([1]); + test_util_1.expectArraysEqual(indices, [0]); + }); + it('select from ten identical boxes', function () { + var numBoxes = 10; + var corners = Array(numBoxes) + .fill(0) + .map(function (_) { return [0, 0, 1, 1]; }) + .reduce(function (arr, curr) { return arr.concat(curr); }); + var boxes = tf.tensor2d(corners, [numBoxes, 4]); + var scores = tf.tensor1d(Array(numBoxes).fill(0.9)); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([1]); + test_util_1.expectArraysEqual(indices, [0]); + }); + it('inconsistent box and score shapes', function () { + var boxes = tf.tensor2d([ + 0, 0, 1, 1, 0, 0.1, 1, 1.1, 0, -0.1, 1, 0.9, + 0, 10, 1, 11, 0, 10.1, 1, 11.1, 0, 100, 1, 101 + ], [6, 4]); + var scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5]); + var maxOutputSize = 30; + var iouThreshold = 0.5; + var scoreThreshold = 0; + expect(function () { return tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); }) + .toThrowError(/scores has incompatible shape with boxes/); + }); + it('invalid iou threshold', function () { + var boxes = tf.tensor2d([0, 0, 1, 1], [1, 4]); + var scores = tf.tensor1d([0.9]); + var maxOutputSize = 3; + var iouThreshold = 1.2; + var scoreThreshold = 0; + expect(function () { return tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); }) + .toThrowError(/iouThreshold must be in \[0, 1\]/); + }); + it('empty input', function () { + var boxes = tf.tensor2d([], [0, 4]); + var scores = tf.tensor1d([]); + var maxOutputSize = 3; + var iouThreshold = 0.5; + var scoreThreshold = 0; + var indices = tf.image.nonMaxSuppression(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold); + expect(indices.shape).toEqual([0]); + test_util_1.expectArraysEqual(indices, []); + }); + it('accepts a tensor-like object', function () { + var boxes = [[0, 0, 1, 1], [0, 1, 1, 2]]; + var scores = [1, 2]; + var indices = tf.image.nonMaxSuppression(boxes, scores, 10); + expect(indices.shape).toEqual([2]); + expect(indices.dtype).toEqual('int32'); + test_util_1.expectArraysEqual(indices, [1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('nonMaxSuppressionAsync', test_util_1.ALL_ENVS, function () { + it('select from three clusters', function () { return __awaiter(_this, void 0, void 0, function () { + var boxes, scores, maxOutputSize, iouThreshold, scoreThreshold, indices; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + boxes = tf.tensor2d([ + 0, 0, 1, 1, 0, 0.1, 1, 1.1, 0, -0.1, 1, 0.9, + 0, 10, 1, 11, 0, 10.1, 1, 11.1, 0, 100, 1, 101 + ], [6, 4]); + scores = tf.tensor1d([0.9, 0.75, 0.6, 0.95, 0.5, 0.3]); + maxOutputSize = 3; + iouThreshold = 0.5; + scoreThreshold = 0; + return [4, tf.image.nonMaxSuppressionAsync(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold)]; + case 1: + indices = _a.sent(); + expect(indices.shape).toEqual([3]); + test_util_1.expectArraysEqual(indices, [3, 0, 5]); + return [2]; + } + }); + }); }); + it('accepts a tensor-like object', function () { return __awaiter(_this, void 0, void 0, function () { + var boxes, scores, indices; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + boxes = [[0, 0, 1, 1], [0, 1, 1, 2]]; + scores = [1, 2]; + return [4, tf.image.nonMaxSuppressionAsync(boxes, scores, 10)]; + case 1: + indices = _a.sent(); + expect(indices.shape).toEqual([2]); + expect(indices.dtype).toEqual('int32'); + test_util_1.expectArraysEqual(indices, [1, 0]); + return [2]; + } + }); + }); }); +}); +//# sourceMappingURL=image_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js.map new file mode 100644 index 0000000..013048a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/image_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"image_ops_test.js","sourceRoot":"","sources":["../../src/ops/image_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.d.ts new file mode 100644 index 0000000..5405f88 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.d.ts @@ -0,0 +1,6 @@ +import { Tensor, Tensor1D, Tensor2D } from '../tensor'; +declare function gramSchmidt_(xs: Tensor1D[] | Tensor2D): Tensor1D[] | Tensor2D; +declare function qr_(x: Tensor, fullMatrices?: boolean): [Tensor, Tensor]; +export declare const gramSchmidt: typeof gramSchmidt_; +export declare const qr: typeof qr_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js new file mode 100644 index 0000000..00fcc48 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js @@ -0,0 +1,144 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var util_1 = require("../util"); +var array_ops_1 = require("./array_ops"); +var norm_1 = require("./norm"); +var operation_1 = require("./operation"); +var reduction_ops_1 = require("./reduction_ops"); +var tensor_ops_1 = require("./tensor_ops"); +function gramSchmidt_(xs) { + var inputIsTensor2D; + if (Array.isArray(xs)) { + inputIsTensor2D = false; + util_1.assert(xs != null && xs.length > 0, 'Gram-Schmidt process: input must not be null, undefined, or empty'); + var dim = xs[0].shape[0]; + for (var i = 1; i < xs.length; ++i) { + util_1.assert(xs[i].shape[0] === dim, 'Gram-Schmidt: Non-unique lengths found in the input vectors: ' + + ("(" + xs[i].shape[0] + " vs. " + dim + ")")); + } + } + else { + inputIsTensor2D = true; + xs = array_ops_1.split(xs, xs.shape[0], 0).map(function (x) { return array_ops_1.squeeze(x, [0]); }); + } + util_1.assert(xs.length <= xs[0].shape[0], "Gram-Schmidt: Number of vectors (" + xs.length + ") exceeds " + + ("number of dimensions (" + xs[0].shape[0] + ").")); + var ys = []; + var xs1d = xs; + var _loop_1 = function (i) { + ys.push(environment_1.ENV.engine.tidy(function () { + var x = xs1d[i]; + if (i > 0) { + for (var j = 0; j < i; ++j) { + var proj = reduction_ops_1.sum(ys[j].mulStrict(x)).mul(ys[j]); + x = x.sub(proj); + } + } + return x.div(norm_1.norm(x, 'euclidean')); + })); + }; + for (var i = 0; i < xs.length; ++i) { + _loop_1(i); + } + if (inputIsTensor2D) { + return array_ops_1.stack(ys, 0); + } + else { + return ys; + } +} +function qr_(x, fullMatrices) { + if (fullMatrices === void 0) { fullMatrices = false; } + if (x.rank < 2) { + throw new Error("qr() requires input tensor to have a rank >= 2, but got rank " + x.rank); + } + else if (x.rank === 2) { + return qr2d(x, fullMatrices); + } + else { + var outerDimsProd = x.shape.slice(0, x.shape.length - 2) + .reduce(function (value, prev) { return value * prev; }); + var x2ds = array_ops_1.unstack(x.reshape([ + outerDimsProd, x.shape[x.shape.length - 2], + x.shape[x.shape.length - 1] + ]), 0); + var q2ds_1 = []; + var r2ds_1 = []; + x2ds.forEach(function (x2d) { + var _a = qr2d(x2d, fullMatrices), q2d = _a[0], r2d = _a[1]; + q2ds_1.push(q2d); + r2ds_1.push(r2d); + }); + var q = array_ops_1.stack(q2ds_1, 0).reshape(x.shape); + var r = array_ops_1.stack(r2ds_1, 0).reshape(x.shape); + return [q, r]; + } +} +function qr2d(x, fullMatrices) { + if (fullMatrices === void 0) { fullMatrices = false; } + return environment_1.ENV.engine.tidy(function () { + if (x.shape.length !== 2) { + throw new Error("qr2d() requires a 2D Tensor, but got a " + x.shape.length + "D Tensor."); + } + var m = x.shape[0]; + var n = x.shape[1]; + var q = array_ops_1.eye(m); + var r = x.clone(); + var one2D = tensor_ops_1.tensor2d([[1]], [1, 1]); + var w = one2D.clone(); + var iters = m >= n ? n : m; + var _loop_2 = function (j) { + var _a; + var rTemp = r; + var wTemp = w; + var qTemp = q; + _a = environment_1.ENV.engine.tidy(function () { + var rjEnd1 = r.slice([j, j], [m - j, 1]); + var normX = rjEnd1.norm(); + var rjj = r.slice([j, j], [1, 1]); + var s = rjj.sign().neg(); + var u1 = rjj.sub(s.mul(normX)); + var wPre = rjEnd1.div(u1); + if (wPre.shape[0] === 1) { + w = one2D.clone(); + } + else { + w = one2D.concat(wPre.slice([1, 0], [wPre.shape[0] - 1, wPre.shape[1]]), 0); + } + var tau = s.matMul(u1).div(normX).neg(); + var rjEndAll = r.slice([j, 0], [m - j, n]); + var tauTimesW = tau.mul(w); + if (j === 0) { + r = rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll))); + } + else { + r = r.slice([0, 0], [j, n]) + .concat(rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll))), 0); + } + var qAllJEnd = q.slice([0, j], [m, q.shape[1] - j]); + if (j === 0) { + q = qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose())); + } + else { + q = q.slice([0, 0], [m, j]) + .concat(qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose())), 1); + } + return [w, r, q]; + }), w = _a[0], r = _a[1], q = _a[2]; + globals_1.dispose([rTemp, wTemp, qTemp]); + }; + for (var j = 0; j < iters; ++j) { + _loop_2(j); + } + if (!fullMatrices && m > n) { + q = q.slice([0, 0], [m, n]); + r = r.slice([0, 0], [n, n]); + } + return [q, r]; + }); +} +exports.gramSchmidt = operation_1.op({ gramSchmidt_: gramSchmidt_ }); +exports.qr = operation_1.op({ qr_: qr_ }); +//# sourceMappingURL=linalg_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js.map new file mode 100644 index 0000000..15ca31a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"linalg_ops.js","sourceRoot":"","sources":["../../src/ops/linalg_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js new file mode 100644 index 0000000..b3a555e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js @@ -0,0 +1,146 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var ops_1 = require("./ops"); +jasmine_util_1.describeWithFlags('gramSchmidt-tiny', test_util_1.ALL_ENVS, function () { + it('2x2, Array of Tensor1D', function () { + var xs = [ + tf.randomNormal([2], 0, 1, 'float32', 1), + tf.randomNormal([2], 0, 1, 'float32', 2) + ]; + var ys = tf.linalg.gramSchmidt(xs); + var y = tf.stack(ys); + test_util_1.expectArraysClose(y.transpose().matMul(y), tf.eye(2)); + test_util_1.expectArraysClose(tf.sum(xs[0].mul(ys[0])), tf.norm(xs[0]).mul(tf.norm(ys[0]))); + }); + it('3x3, Array of Tensor1D', function () { + var xs = [ + tf.randomNormal([3], 0, 1, 'float32', 1), + tf.randomNormal([3], 0, 1, 'float32', 2), + tf.randomNormal([3], 0, 1, 'float32', 3) + ]; + var ys = tf.linalg.gramSchmidt(xs); + var y = tf.stack(ys); + test_util_1.expectArraysClose(y.transpose().matMul(y), tf.eye(3)); + test_util_1.expectArraysClose(tf.sum(xs[0].mul(ys[0])), tf.norm(xs[0]).mul(tf.norm(ys[0]))); + }); + it('3x3, Matrix', function () { + var xs = tf.randomNormal([3, 3], 0, 1, 'float32', 1); + var y = tf.linalg.gramSchmidt(xs); + test_util_1.expectArraysClose(y.transpose().matMul(y), tf.eye(3)); + }); + it('2x3, Matrix', function () { + var xs = tf.randomNormal([2, 3], 0, 1, 'float32', 1); + var y = tf.linalg.gramSchmidt(xs); + test_util_1.expectArraysClose(y.matMul(y.transpose()), tf.eye(2)); + }); + it('3x2 Matrix throws Error', function () { + var xs = tf.tensor2d([[1, 2], [3, -1], [5, 1]]); + expect(function () { return tf.linalg.gramSchmidt(xs); }) + .toThrowError(/Number of vectors \(3\) exceeds number of dimensions \(2\)/); + }); + it('Mismatching dimensions input throws Error', function () { + var xs = [tf.tensor1d([1, 2, 3]), tf.tensor1d([-1, 5, 1]), tf.tensor1d([0, 0])]; + expect(function () { return tf.linalg.gramSchmidt(xs); }).toThrowError(/Non-unique/); + }); + it('Empty input throws Error', function () { + expect(function () { return tf.linalg.gramSchmidt([]); }).toThrowError(/empty/); + }); +}); +jasmine_util_1.describeWithFlags('gramSchmidt-non-tiny', test_util_1.WEBGL_ENVS, function () { + it('32x512', function () { + var xs = tf.randomUniform([32, 512]); + var y = tf.linalg.gramSchmidt(xs); + test_util_1.expectArraysClose(y.matMul(y.transpose()), tf.eye(32)); + }); +}); +jasmine_util_1.describeWithFlags('qr', test_util_1.ALL_ENVS, function () { + it('1x1', function () { + var x = ops_1.tensor2d([[10]], [1, 1]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([[-1]], [1, 1])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-10]], [1, 1])); + }); + it('2x2', function () { + var x = ops_1.tensor2d([[1, 3], [-2, -4]], [2, 2]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([[-0.4472, -0.8944], [0.8944, -0.4472]], [2, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-2.2361, -4.9193], [0, -0.8944]], [2, 2])); + }); + it('2x2x2', function () { + var x = ops_1.tensor3d([[[-1, -3], [2, 4]], [[1, 3], [-2, -4]]], [2, 2, 2]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor3d([ + [[-0.4472, -0.8944], [0.8944, -0.4472]], + [[-0.4472, -0.8944], [0.8944, -0.4472]] + ], [2, 2, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor3d([ + [[2.2361, 4.9193], [0, 0.8944]], + [[-2.2361, -4.9193], [0, -0.8944]] + ], [2, 2, 2])); + }); + it('2x1x2x2', function () { + var x = ops_1.tensor4d([[[[-1, -3], [2, 4]]], [[[1, 3], [-2, -4]]]], [2, 1, 2, 2]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor4d([ + [[[-0.4472, -0.8944], [0.8944, -0.4472]]], + [[[-0.4472, -0.8944], [0.8944, -0.4472]]], + ], [2, 1, 2, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor4d([ + [[[2.2361, 4.9193], [0, 0.8944]]], + [[[-2.2361, -4.9193], [0, -0.8944]]] + ], [2, 1, 2, 2])); + }); + it('3x3', function () { + var x = ops_1.tensor2d([[1, 3, 2], [-2, 0, 7], [8, -9, 4]], [3, 3]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([ + [-0.1204, 0.8729, 0.4729], [0.2408, -0.4364, 0.8669], + [-0.9631, -0.2182, 0.1576] + ], [3, 3])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-8.3066, 8.3066, -2.4077], [0, 4.5826, -2.1822], [0, 0, 7.6447]], [3, 3])); + }); + it('3x2, fullMatrices = default false', function () { + var x = ops_1.tensor2d([[1, 2], [3, -3], [-2, 1]], [3, 2]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([[-0.2673, 0.9221], [-0.8018, -0.3738], [0.5345, -0.0997]], [3, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-3.7417, 2.4054], [0, 2.8661]], [2, 2])); + }); + it('3x2, fullMatrices = true', function () { + var x = ops_1.tensor2d([[1, 2], [3, -3], [-2, 1]], [3, 2]); + var _a = tf.linalg.qr(x, true), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([ + [-0.2673, 0.9221, 0.2798], [-0.8018, -0.3738, 0.4663], + [0.5345, -0.0997, 0.8393] + ], [3, 3])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-3.7417, 2.4054], [0, 2.8661], [0, 0]], [3, 2])); + }); + it('2x3, fullMatrices = default false', function () { + var x = ops_1.tensor2d([[1, 2, 3], [-3, -2, 1]], [2, 3]); + var _a = tf.linalg.qr(x), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([[-0.3162278, -0.9486833], [0.9486833, -0.31622773]], [2, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-3.162, -2.5298, -2.3842e-07], [0, -1.2649, -3.162]], [2, 3])); + }); + it('2x3, fullMatrices = true', function () { + var x = ops_1.tensor2d([[1, 2, 3], [-3, -2, 1]], [2, 3]); + var _a = tf.linalg.qr(x, true), q = _a[0], r = _a[1]; + test_util_1.expectArraysClose(q, ops_1.tensor2d([[-0.3162278, -0.9486833], [0.9486833, -0.31622773]], [2, 2])); + test_util_1.expectArraysClose(r, ops_1.tensor2d([[-3.162, -2.5298, -2.3842e-07], [0, -1.2649, -3.162]], [2, 3])); + }); + it('Does not leak memory', function () { + var x = ops_1.tensor2d([[1, 3], [-2, -4]], [2, 2]); + tf.linalg.qr(x); + var numTensors = tf.memory().numTensors; + tf.linalg.qr(x); + expect(tf.memory().numTensors).toEqual(numTensors + 2); + }); + it('Insuffient input tensor rank leads to error', function () { + var x1 = ops_1.scalar(12); + expect(function () { return tf.linalg.qr(x1); }).toThrowError(/rank >= 2.*got rank 0/); + var x2 = ops_1.tensor1d([12]); + expect(function () { return tf.linalg.qr(x2); }).toThrowError(/rank >= 2.*got rank 1/); + }); +}); +//# sourceMappingURL=linalg_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js.map new file mode 100644 index 0000000..d9bc3f8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/linalg_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"linalg_ops_test.js","sourceRoot":"","sources":["../../src/ops/linalg_ops_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAElD,0CAAqE;AAErE,6BAAqE;AAErE,gCAAiB,CAAC,kBAAkB,EAAE,oBAAQ,EAAE;IAC9C,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,EAAE,GAAe;YACrB,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;YACxC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;SACzC,CAAC;QACF,IAAM,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAe,CAAC;QACnD,IAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,CAAa,CAAC;QAEnC,6BAAiB,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAGtD,6BAAiB,CACb,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,EAAE,GAAe;YACrB,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;YACxC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;YACxC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;SACzC,CAAC;QACF,IAAM,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAe,CAAC;QACnD,IAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,CAAa,CAAC;QACnC,6BAAiB,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACtD,6BAAiB,CACb,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,aAAa,EAAE;QAChB,IAAM,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAa,CAAC;QACnE,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAa,CAAC;QAChD,6BAAiB,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,aAAa,EAAE;QAChB,IAAM,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAa,CAAC;QACnE,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAa,CAAC;QAChD,6BAAiB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;QAC5B,IAAM,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,EAAzB,CAAyB,CAAC;aAClC,YAAY,CACT,4DAA4D,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,EAAE,GACJ,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3E,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,EAAzB,CAAyB,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,EAAzB,CAAyB,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAIH,gCAAiB,CAAC,sBAAsB,EAAE,sBAAU,EAAE;IACpD,EAAE,CAAC,QAAQ,EAAE;QAGX,IAAM,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAa,CAAC;QACnD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAa,CAAC;QAChD,6BAAiB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,IAAI,EAAE,oBAAQ,EAAE;IAChC,EAAE,CAAC,KAAK,EAAE;QACR,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CAAC,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,6BAAiB,CAAC,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,KAAK,EAAE;QACR,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAClE,6BAAiB,CAAC,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClE,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;SACxC,EACD,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACpB,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;YAC/B,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;SACnC,EACD,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QACZ,IAAM,CAAC,GACH,cAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;YACzC,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;SAC1C,EACD,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;SACrC,EACD,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,KAAK,EAAE;QACR,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1D,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;YACpD,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;SAC3B,EACD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACjB,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,EAC1D,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACjB,6BAAiB,CAAC,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAA,0BAA8B,EAA7B,SAAC,EAAE,SAAC,CAA0B;QACrC,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ;YACE,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;YACrD,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;SAC1B,EACD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACjB,6BAAiB,CACb,CAAC,EAAE,cAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAA,oBAAwB,EAAvB,SAAC,EAAE,SAAC,CAAoB;QAC/B,6BAAiB,CACb,CAAC,EACD,cAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5E,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CACtE,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAA,0BAA8B,EAA7B,SAAC,EAAE,SAAC,CAA0B;QACrC,6BAAiB,CACb,CAAC,EACD,cAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5E,6BAAiB,CACb,CAAC,EACD,cAAQ,CACJ,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CACtE,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,CAAC,GAAG,cAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAG/C,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEhB,IAAM,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAC1C,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,EAAE,GAAG,YAAM,CAAC,EAAE,CAAC,CAAC;QACtB,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAhB,CAAgB,CAAC,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC;QACrE,IAAM,EAAE,GAAG,cAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAhB,CAAgB,CAAC,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.d.ts new file mode 100644 index 0000000..0ccf986 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.d.ts @@ -0,0 +1,15 @@ +import { Tensor, Tensor2D } from '../tensor'; +import { TensorLike } from '../types'; +declare function logicalNot_(x: T | TensorLike): T; +declare function logicalAnd_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function logicalOr_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function logicalXor_(a: Tensor | TensorLike, b: Tensor | TensorLike): T; +declare function where_(condition: Tensor | TensorLike, a: T | TensorLike, b: T | TensorLike): T; +declare function whereAsync_(condition: Tensor | TensorLike): Promise; +export declare const logicalAnd: typeof logicalAnd_; +export declare const logicalNot: typeof logicalNot_; +export declare const logicalOr: typeof logicalOr_; +export declare const logicalXor: typeof logicalXor_; +export declare const where: typeof where_; +export declare const whereAsync: typeof whereAsync_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js new file mode 100644 index 0000000..d10b3b2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js @@ -0,0 +1,116 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var where_impl_1 = require("../kernels/where_impl"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var broadcast_util_1 = require("./broadcast_util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function logicalNot_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'logicalNot', 'bool'); + util_1.assert($x.dtype === 'bool', 'Error Array must be of type bool.'); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.logicalNot($x); }, { $x: $x }); +} +function logicalAnd_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'logicalAnd', 'bool'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'logicalAnd', 'bool'); + util_1.assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.logicalAnd($a, $b); }, { $a: $a, $b: $b }); +} +function logicalOr_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'logicalOr', 'bool'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'logicalOr', 'bool'); + util_1.assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.logicalOr($a, $b); }, { $a: $a, $b: $b }); +} +function logicalXor_(a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'logicalXor', 'bool'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'logicalXor', 'bool'); + util_1.assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + broadcast_util_1.assertAndGetBroadcastShape($a.shape, $b.shape); + return exports.logicalOr(a, b).logicalAnd(exports.logicalAnd(a, b).logicalNot()); +} +function where_(condition, a, b) { + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'where'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'where'); + var $condition = tensor_util_env_1.convertToTensor(condition, 'condition', 'where', 'bool'); + util_1.assert($condition.dtype === 'bool', 'Error Condition must be of type bool.'); + util_1.assertShapesMatch($a.shape, $b.shape, 'Error in where: '); + if ($condition.rank === 1) { + util_1.assert($condition.shape[0] === $a.shape[0], 'The first dimension of `a` must match the size of `condition`.'); + } + else { + util_1.assertShapesMatch($condition.shape, $b.shape, 'Error in where: '); + } + var grad = function (dy) { return ({ + $condition: function () { return tensor_ops_1.zerosLike($condition); }, + $a: function () { return dy.mul($condition.cast($a.dtype)); }, + $b: function () { return dy.mul($condition.logicalNot().cast($b.dtype)); } + }); }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.select($condition, $a, $b); }, { $condition: $condition, $a: $a, $b: $b }, grad); +} +function whereAsync_(condition) { + return __awaiter(this, void 0, void 0, function () { + var $condition, vals, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + $condition = tensor_util_env_1.convertToTensor(condition, 'condition', 'where', 'bool'); + util_1.assert($condition.dtype === 'bool', 'Condition must be of type bool.'); + return [4, $condition.data()]; + case 1: + vals = _a.sent(); + res = where_impl_1.whereImpl($condition.shape, vals); + if (condition !== $condition) { + $condition.dispose(); + } + return [2, res]; + } + }); + }); +} +exports.logicalAnd = operation_1.op({ logicalAnd_: logicalAnd_ }); +exports.logicalNot = operation_1.op({ logicalNot_: logicalNot_ }); +exports.logicalOr = operation_1.op({ logicalOr_: logicalOr_ }); +exports.logicalXor = operation_1.op({ logicalXor_: logicalXor_ }); +exports.where = operation_1.op({ where_: where_ }); +exports.whereAsync = whereAsync_; +//# sourceMappingURL=logical_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js.map new file mode 100644 index 0000000..c7ece2f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logical_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"logical_ops.js","sourceRoot":"","sources":["../../src/ops/logical_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js new file mode 100644 index 0000000..d344b8c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js @@ -0,0 +1,672 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('logicalNot', test_util_1.ALL_ENVS, function () { + it('Tensor1D.', function () { + var a = tf.tensor1d([1, 0, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 1]); + a = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [1, 1, 1]); + a = tf.tensor1d([1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 0]); + }); + it('Tests chaining in Tensor1D', function () { + var a = tf.tensor1d([1, 0, 0], 'bool'); + test_util_1.expectArraysClose(a.logicalNot(), [0, 1, 1]); + a = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectArraysClose(a.logicalNot(), [1, 1, 1]); + a = tf.tensor1d([1, 1], 'bool'); + test_util_1.expectArraysClose(a.logicalNot(), [0, 0]); + }); + it('Tensor2D', function () { + var a = tf.tensor2d([[1, 0, 1], [0, 0, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 0, 1, 1, 1]); + a = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [1, 1, 1, 0, 0, 0]); + }); + it('Tensor3D', function () { + var a = tf.tensor3d([[[1], [0], [1]], [[0], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 0, 1, 1, 1]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [1, 1, 1, 0, 0, 0]); + }); + it('Tensor4D', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 0, 1]); + a = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [1, 1, 1, 1]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 0, 0, 0]); + }); + it('Tensor6D', function () { + var a = tf.tensor6d([1, 0, 1, 0], [2, 2, 1, 1, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 0, 1]); + a = tf.zeros([2, 2, 2, 2, 2, 2]).cast('bool'); + var expectedResult = new Int32Array(64); + expectedResult = expectedResult.fill(1); + test_util_1.expectArraysClose(tf.logicalNot(a), expectedResult); + a = tf.ones([2, 2, 2, 2, 2, 2]).cast('bool'); + expectedResult = expectedResult.fill(0); + test_util_1.expectArraysClose(tf.logicalNot(a), expectedResult); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.logicalNot({}); }) + .toThrowError(/Argument 'x' passed to 'logicalNot' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 0, 0]; + test_util_1.expectArraysClose(tf.logicalNot(a), [0, 1, 1]); + }); +}); +jasmine_util_1.describeWithFlags('logicalAnd', test_util_1.ALL_ENVS, function () { + it('Tensor1D.', function () { + var a = tf.tensor1d([1, 0, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0]); + a = tf.tensor1d([0, 0, 0], 'bool'); + b = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0]); + a = tf.tensor1d([1, 1], 'bool'); + b = tf.tensor1d([1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [1, 1]); + }); + it('mismatched Tensor1D shapes', function () { + var a = tf.tensor1d([1, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + var f = function () { + tf.logicalAnd(a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D', function () { + var a = tf.tensor2d([[1, 0, 1], [0, 0, 0]], [2, 3], 'bool'); + var b = tf.tensor2d([[0, 0, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 0, 0, 0]); + a = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + b = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes', function () { + var a = tf.tensor2d([[1], [0]], [2, 1], 'bool'); + var b = tf.tensor2d([[0, 1, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 1, 0, 0, 0, 0]); + }); + it('Tensor3D', function () { + var a = tf.tensor3d([[[1], [0], [1]], [[0], [0], [1]]], [2, 3, 1], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 1, 0, 0, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 1, 1, 1]); + }); + it('broadcasting Tensor3D shapes', function () { + var a = tf.tensor3d([[[1, 0], [0, 0], [1, 1]], [[0, 0], [0, 1], [0, 0]]], [2, 3, 2], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0]); + }); + it('Tensor4D', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([0, 1, 1, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 1, 0]); + a = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([[[[1, 0]], [[0, 0]]], [[[0, 0]], [[1, 1]]]], [2, 2, 1, 2], 'bool'); + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [1, 0, 0, 0, 0, 0, 0, 0]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.logicalAnd({}, tf.scalar(1, 'bool')); }) + .toThrowError(/Argument 'a' passed to 'logicalAnd' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.logicalAnd(tf.scalar(1, 'bool'), {}); }) + .toThrowError(/Argument 'b' passed to 'logicalAnd' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 0, 0, 1]; + var b = [0, 1, 0, 1]; + test_util_1.expectArraysClose(tf.logicalAnd(a, b), [0, 0, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('logicalOr', test_util_1.ALL_ENVS, function () { + it('Tensor1D.', function () { + var a = tf.tensor1d([1, 0, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 0]); + a = tf.tensor1d([0, 0, 0], 'bool'); + b = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [0, 0, 0]); + a = tf.tensor1d([1, 1], 'bool'); + b = tf.tensor1d([1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1]); + }); + it('mismatched Tensor1D shapes', function () { + var a = tf.tensor1d([1, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + var f = function () { + tf.logicalOr(a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D', function () { + var a = tf.tensor2d([[1, 0, 1], [0, 0, 0]], [2, 3], 'bool'); + var b = tf.tensor2d([[0, 0, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + b = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [0, 0, 0, 1, 1, 1]); + }); + it('broadcasting Tensor2D shapes', function () { + var a = tf.tensor2d([[1], [0]], [2, 1], 'bool'); + var b = tf.tensor2d([[0, 0, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 1, 0, 1, 0]); + }); + it('Tensor3D', function () { + var a = tf.tensor3d([[[1], [0], [1]], [[0], [0], [0]]], [2, 3, 1], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 0, 1, 1, 0, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [0, 0, 0, 1, 1, 1]); + }); + it('broadcasting Tensor3D shapes', function () { + var a = tf.tensor3d([[[1, 0], [0, 0], [1, 1]], [[0, 0], [0, 1], [0, 0]]], [2, 3, 2], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0]); + }); + it('Tensor4D', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([0, 1, 0, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 1, 0]); + a = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 1, 1]); + }); + it('broadcasting Tensor4D shapes', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([[[[1, 0]], [[0, 0]]], [[[0, 0]], [[1, 1]]]], [2, 2, 1, 2], 'bool'); + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 0, 0, 1, 1, 1, 1]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.logicalOr({}, tf.scalar(1, 'bool')); }) + .toThrowError(/Argument 'a' passed to 'logicalOr' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.logicalOr(tf.scalar(1, 'bool'), {}); }) + .toThrowError(/Argument 'b' passed to 'logicalOr' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 0, 0, 1]; + var b = [0, 1, 0, 1]; + test_util_1.expectArraysClose(tf.logicalOr(a, b), [1, 1, 0, 1]); + }); +}); +jasmine_util_1.describeWithFlags('logicalXor', test_util_1.ALL_ENVS, function () { + it('Tensor1D.', function () { + var a = tf.tensor1d([1, 0, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 1, 0]); + a = tf.tensor1d([0, 0, 0], 'bool'); + b = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0, 0]); + a = tf.tensor1d([1, 1], 'bool'); + b = tf.tensor1d([1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0]); + }); + it('mismatched Tensor1D shapes', function () { + var a = tf.tensor1d([1, 0], 'bool'); + var b = tf.tensor1d([0, 1, 0], 'bool'); + var f = function () { + tf.logicalXor(a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D', function () { + var a = tf.tensor2d([[1, 0, 1], [0, 0, 0]], [2, 3], 'bool'); + var b = tf.tensor2d([[0, 0, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 0, 1, 0, 1, 0]); + a = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + b = tf.tensor2d([[0, 0, 0], [1, 1, 1]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('broadcasting Tensor2D shapes', function () { + var a = tf.tensor2d([[1], [0]], [2, 1], 'bool'); + var b = tf.tensor2d([[0, 0, 0], [0, 1, 0]], [2, 3], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 1, 1, 0, 1, 0]); + }); + it('Tensor3D', function () { + var a = tf.tensor3d([[[1], [0], [1]], [[0], [0], [0]]], [2, 3, 1], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 0, 0, 1, 0, 0]); + a = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + b = tf.tensor3d([[[0], [0], [0]], [[1], [1], [1]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0, 0, 0, 0, 0]); + }); + it('broadcasting Tensor3D shapes', function () { + var a = tf.tensor3d([[[1, 0], [0, 0], [1, 1]], [[0, 0], [0, 1], [0, 0]]], [2, 3, 2], 'bool'); + var b = tf.tensor3d([[[0], [0], [1]], [[1], [0], [0]]], [2, 3, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0]); + }); + it('Tensor4D', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([0, 1, 1, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 1, 0, 0]); + a = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([0, 0, 0, 0], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0, 0, 0]); + a = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + b = tf.tensor4d([1, 1, 1, 1], [2, 2, 1, 1], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 0, 0, 0]); + }); + it('broadcasting Tensor4D shapes', function () { + var a = tf.tensor4d([1, 0, 1, 0], [2, 2, 1, 1], 'bool'); + var b = tf.tensor4d([[[[1, 0]], [[0, 0]]], [[[0, 0]], [[1, 1]]]], [2, 2, 1, 2], 'bool'); + test_util_1.expectArraysClose(tf.logicalXor(a, b), [0, 1, 0, 0, 1, 1, 1, 1]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.logicalXor({}, tf.scalar(1, 'bool')); }) + .toThrowError(/Argument 'a' passed to 'logicalXor' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.logicalXor(tf.scalar(1, 'bool'), {}); }) + .toThrowError(/Argument 'b' passed to 'logicalXor' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [1, 0, 0, 1]; + var b = [0, 1, 0, 1]; + test_util_1.expectArraysClose(tf.logicalXor(a, b), [1, 1, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('where', test_util_1.ALL_ENVS, function () { + it('Scalars.', function () { + var a = tf.scalar(10); + var b = tf.scalar(20); + var c = tf.scalar(1, 'bool'); + test_util_1.expectArraysClose(tf.where(c, a, b), [10]); + }); + it('Invalid condition type', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'int32'); + var a = tf.tensor1d([10, 10, 10, 10], 'bool'); + var b = tf.tensor1d([20, 20, 20, 20], 'bool'); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor1D', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor1d([10, 10, 10, 10]); + var b = tf.tensor1d([20, 20, 20, 20]); + test_util_1.expectArraysClose(tf.where(c, a, b), [10, 20, 10, 20]); + }); + it('Tensor1D different a/b shapes', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor1d([10, 10, 10]); + var b = tf.tensor1d([20, 20, 20, 20]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + c = tf.tensor1d([1, 0, 1, 0], 'bool'); + a = tf.tensor1d([10, 10, 10, 10]); + b = tf.tensor1d([20, 20, 20]); + f = function () { + tf.where(c, a, b); + }; + }); + it('Tensor1D different condition/a shapes', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor1d([10, 10, 10]); + var b = tf.tensor1d([20, 20, 20]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D', function () { + var c = tf.tensor2d([[1, 0], [0, 1]], [2, 2], 'bool'); + var a = tf.tensor2d([[10, 10], [10, 10]], [2, 2]); + var b = tf.tensor2d([[5, 5], [5, 5]], [2, 2]); + test_util_1.expectArraysClose(tf.where(c, a, b), [10, 5, 5, 10]); + }); + it('Tensor2D different a/b shapes', function () { + var c = tf.tensor2d([[1, 1], [0, 0]], [2, 2], 'bool'); + var a = tf.tensor2d([[5, 5, 5], [5, 5, 5]], [2, 3]); + var b = tf.tensor2d([[4, 4], [4, 4]], [2, 2]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + c = tf.tensor2d([[1, 1], [0, 0]], [2, 2], 'bool'); + a = tf.tensor2d([[5, 5], [5, 5]], [2, 2]); + b = tf.tensor2d([[4, 4, 4], [4, 4, 4]], [2, 3]); + f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D different condition/a shapes', function () { + var c = tf.tensor2d([[1, 0], [0, 1]], [2, 2], 'bool'); + var a = tf.tensor2d([[10, 10, 10], [10, 10, 10]], [2, 3]); + var b = tf.tensor2d([[5, 5, 5], [5, 5, 5]], [2, 3]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor2D different `a` dimension w/ condition rank=1', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor2d([[10, 10], [10, 10]], [2, 2]); + var b = tf.tensor2d([[5, 5], [5, 5]], [2, 2]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + a = tf.tensor2d([[10], [10], [10], [10]], [4, 1]); + b = tf.tensor2d([[5], [5], [5], [5]], [4, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [10, 5, 10, 5]); + a = tf.tensor2d([[10, 10], [10, 10], [10, 10], [10, 10]], [4, 2]); + b = tf.tensor2d([[5, 5], [5, 5], [5, 5], [5, 5]], [4, 2]); + test_util_1.expectArraysClose(tf.where(c, a, b), [10, 10, 5, 5, 10, 10, 5, 5]); + }); + it('Tensor3D', function () { + var c = tf.tensor3d([[[1], [0], [1]], [[0], [0], [0]]], [2, 3, 1], 'bool'); + var a = tf.tensor3d([[[5], [5], [5]], [[5], [5], [5]]], [2, 3, 1]); + var b = tf.tensor3d([[[3], [3], [3]], [[3], [3], [3]]], [2, 3, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [5, 3, 5, 3, 3, 3]); + }); + it('Tensor3D different a/b shapes', function () { + var c = tf.tensor3d([[[1], [0], [1]], [[0], [0], [0]]], [2, 3, 1], 'bool'); + var a = tf.tensor3d([[[5], [5]], [[5], [5]]], [2, 2, 1]); + var b = tf.tensor3d([[[3], [3], [3]], [[3], [3], [3]]], [2, 3, 1]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + a = tf.tensor3d([[[5], [5], [5]], [[5], [5], [5]]], [2, 3, 1]); + b = tf.tensor3d([[[3], [3]], [[3], [3]]], [2, 2, 1]); + f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor3D different condition/a shapes', function () { + var c = tf.tensor3d([[[1], [0]], [[0], [0]]], [2, 2, 1], 'bool'); + var a = tf.tensor3d([[[5], [5], [5]], [[5], [5], [5]]], [2, 3, 1]); + var b = tf.tensor3d([[[3], [3], [3]], [[3], [3], [3]]], [2, 3, 1]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor3D different `a` dimension w/ condition rank=1', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor3d([[[9, 9], [9, 9]], [[9, 9], [9, 9]]], [2, 2, 2]); + var b = tf.tensor3d([[[8, 8], [8, 8]], [[8, 8], [8, 8]]], [2, 2, 2]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + a = tf.tensor3d([[[9]], [[9]], [[9]], [[9]]], [4, 1, 1]); + b = tf.tensor3d([[[8]], [[8]], [[8]], [[8]]], [4, 1, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [9, 8, 9, 8]); + a = tf.tensor3d([[[9], [9]], [[9], [9]], [[9], [9]], [[9], [9]]], [4, 2, 1]); + b = tf.tensor3d([[[8], [8]], [[8], [8]], [[8], [8]], [[8], [8]]], [4, 2, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [9, 9, 8, 8, 9, 9, 8, 8]); + }); + it('Tensor4D', function () { + var c = tf.tensor4d([1, 0, 1, 1], [2, 2, 1, 1], 'bool'); + var a = tf.tensor4d([7, 7, 7, 7], [2, 2, 1, 1]); + var b = tf.tensor4d([3, 3, 3, 3], [2, 2, 1, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [7, 3, 7, 7]); + }); + it('Tensor4D different a/b shapes', function () { + var c = tf.tensor4d([1, 0, 1, 1], [2, 2, 1, 1], 'bool'); + var a = tf.tensor4d([7, 7, 7, 7, 7, 7, 7, 7], [2, 2, 2, 1]); + var b = tf.tensor4d([3, 3, 3, 3], [2, 2, 1, 1]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + a = tf.tensor4d([7, 7, 7, 7], [2, 2, 1, 1]); + b = tf.tensor4d([3, 3, 3, 3, 3, 3, 3, 3], [2, 2, 2, 1]); + f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor4D different condition/a shapes', function () { + var c = tf.tensor4d([1, 0, 1, 1, 1, 0, 1, 1], [2, 2, 2, 1], 'bool'); + var a = tf.tensor4d([7, 7, 7, 7], [2, 2, 1, 1]); + var b = tf.tensor4d([3, 3, 3, 3], [2, 2, 1, 1]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + }); + it('Tensor4D different `a` dimension w/ condition rank=1', function () { + var c = tf.tensor1d([1, 0, 1, 0], 'bool'); + var a = tf.tensor4d([7, 7, 7, 7, 7, 7, 7, 7], [2, 2, 2, 1]); + var b = tf.tensor4d([3, 3, 3, 3, 3, 3, 3, 3], [2, 2, 2, 1]); + var f = function () { + tf.where(c, a, b); + }; + expect(f).toThrowError(); + a = tf.tensor4d([7, 7, 7, 7], [4, 1, 1, 1]); + b = tf.tensor4d([3, 3, 3, 3], [4, 1, 1, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [7, 3, 7, 3]); + a = tf.tensor4d([7, 7, 7, 7, 7, 7, 7, 7], [4, 2, 1, 1]); + b = tf.tensor4d([3, 3, 3, 3, 3, 3, 3, 3], [4, 2, 1, 1]); + test_util_1.expectArraysClose(tf.where(c, a, b), [7, 7, 3, 3, 7, 7, 3, 3]); + }); + it('throws when passed condition as a non-tensor', function () { + expect(function () { return tf.where({}, tf.scalar(1, 'bool'), tf.scalar(1, 'bool')); }) + .toThrowError(/Argument 'condition' passed to 'where' must be a Tensor/); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.where(tf.scalar(1, 'bool'), {}, tf.scalar(1, 'bool')); }) + .toThrowError(/Argument 'a' passed to 'where' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.where(tf.scalar(1, 'bool'), tf.scalar(1, 'bool'), {}); }) + .toThrowError(/Argument 'b' passed to 'where' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = 10; + var b = 20; + var c = 1; + test_util_1.expectArraysClose(tf.where(c, a, b), [10]); + }); + it('1D gradient', function () { + var c = tf.tensor1d([1, 0, 1], 'bool'); + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([4, 5, 6]); + var dy = tf.tensor1d([1, 2, 3]); + var grads = tf.grads(function (c, a, b) { return tf.where(c, a, b); }); + var _a = grads([c, a, b], dy), dc = _a[0], da = _a[1], db = _a[2]; + test_util_1.expectArraysClose(dc, [0, 0, 0]); + test_util_1.expectArraysClose(da, [1, 0, 3]); + test_util_1.expectArraysClose(db, [0, 2, 0]); + expect(dc.shape).toEqual(c.shape); + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + }); + it('2D gradient', function () { + var c = tf.tensor2d([1, 0, 1, 1, 1, 0], [2, 3], 'bool'); + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([7, 8, 9, 10, 11, 12], [2, 3]); + var dy = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var grads = tf.grads(function (c, a, b) { return tf.where(c, a, b); }); + var _a = grads([c, a, b], dy), dc = _a[0], da = _a[1], db = _a[2]; + test_util_1.expectArraysClose(dc, [0, 0, 0, 0, 0, 0]); + test_util_1.expectArraysClose(da, [1, 0, 3, 4, 5, 0]); + test_util_1.expectArraysClose(db, [0, 2, 0, 0, 0, 6]); + expect(dc.shape).toEqual(c.shape); + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + }); + it('3D gradient', function () { + var c = tf.tensor3d([1, 1, 0, 1, 1, 0], [2, 3, 1], 'bool'); + var a = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1]); + var b = tf.tensor3d([7, 8, 9, 10, 11, 12], [2, 3, 1]); + var dy = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1]); + var grads = tf.grads(function (c, a, b) { return tf.where(c, a, b); }); + var _a = grads([c, a, b], dy), dc = _a[0], da = _a[1], db = _a[2]; + test_util_1.expectArraysClose(dc, [0, 0, 0, 0, 0, 0]); + test_util_1.expectArraysClose(da, [1, 2, 0, 4, 5, 0]); + test_util_1.expectArraysClose(db, [0, 0, 3, 0, 0, 6]); + expect(dc.shape).toEqual(c.shape); + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + }); + it('4D gradient', function () { + var c = tf.tensor4d([1, 1, 0, 1], [2, 2, 1, 1], 'bool'); + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var b = tf.tensor4d([5, 6, 7, 8], [2, 2, 1, 1]); + var dy = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + var grads = tf.grads(function (c, a, b) { return tf.where(c, a, b); }); + var _a = grads([c, a, b], dy), dc = _a[0], da = _a[1], db = _a[2]; + test_util_1.expectArraysClose(dc, [0, 0, 0, 0]); + test_util_1.expectArraysClose(da, [1, 2, 0, 4]); + test_util_1.expectArraysClose(db, [0, 0, 3, 0]); + expect(dc.shape).toEqual(c.shape); + expect(da.shape).toEqual(a.shape); + expect(db.shape).toEqual(b.shape); + }); +}); +jasmine_util_1.describeWithFlags('whereAsync', test_util_1.ALL_ENVS, function () { + it('1d tensor', function () { return __awaiter(_this, void 0, void 0, function () { + var condition, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + condition = tf.tensor1d([true, false, true, true], 'bool'); + return [4, tf.whereAsync(condition)]; + case 1: + res = _a.sent(); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([3, 1]); + test_util_1.expectArraysClose(res, [0, 2, 3]); + return [2]; + } + }); + }); }); + it('2d tensor', function () { return __awaiter(_this, void 0, void 0, function () { + var condition, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + condition = tf.tensor2d([[true, false, false], [false, true, true]], [2, 3], 'bool'); + return [4, tf.whereAsync(condition)]; + case 1: + res = _a.sent(); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(res, [0, 0, 1, 1, 1, 2]); + return [2]; + } + }); + }); }); + it('3d tensor', function () { return __awaiter(_this, void 0, void 0, function () { + var condition, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + condition = tf.tensor3d([[[true, false, false], [false, true, true]], + [[false, false, false], [true, true, false]]], [2, 2, 3], 'bool'); + return [4, tf.whereAsync(condition)]; + case 1: + res = _a.sent(); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([5, 3]); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 1, 1, 0, 1, 2, 1, 1, 0, 1, 1, 1]); + return [2]; + } + }); + }); }); + it('accepts a tensor-like object', function () { return __awaiter(_this, void 0, void 0, function () { + var condition, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + condition = [true, false, true]; + return [4, tf.whereAsync(condition)]; + case 1: + res = _a.sent(); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([2, 1]); + test_util_1.expectArraysClose(res, [0, 2]); + return [2]; + } + }); + }); }); + it('throws error if condition is not of type bool', function () { return __awaiter(_this, void 0, void 0, function () { + var condition, ex_1; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + condition = tf.tensor1d([1, 0, 1]); + _a.label = 1; + case 1: + _a.trys.push([1, 3, , 4]); + return [4, tf.whereAsync(condition)]; + case 2: + _a.sent(); + throw new Error('The line above should have thrown an error'); + case 3: + ex_1 = _a.sent(); + expect(ex_1.message).toBe('Condition must be of type bool.'); + return [3, 4]; + case 4: return [2]; + } + }); + }); }); +}); +//# sourceMappingURL=logicalop_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js.map new file mode 100644 index 0000000..214a10e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/logicalop_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"logicalop_test.js","sourceRoot":"","sources":["../../src/ops/logicalop_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.d.ts new file mode 100644 index 0000000..37d8f4d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.d.ts @@ -0,0 +1,27 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +export declare enum Reduction { + NONE = 0, + MEAN = 1, + SUM = 2, + SUM_BY_NONZERO_WEIGHTS = 3 +} +declare function computeWeightedLoss_(losses: T | TensorLike, weights?: Tensor | TensorLike, reduction?: Reduction): O; +declare function absoluteDifference_(labels: T | TensorLike, predictions: T | TensorLike, weights?: Tensor | TensorLike, reduction?: Reduction): O; +declare function meanSquaredError_(labels: T | TensorLike, predictions: T | TensorLike, weights?: Tensor | TensorLike, reduction?: Reduction): O; +declare function cosineDistance_(labels: T | TensorLike, predictions: T | TensorLike, axis: number, weights?: Tensor | TensorLike, reduction?: Reduction): O; +declare function hingeLoss_(labels: T | TensorLike, predictions: T | TensorLike, weights?: Tensor | TensorLike, reduction?: Reduction): O; +declare function logLoss_(labels: T | TensorLike, predictions: T | TensorLike, weights?: Tensor | TensorLike, epsilon?: number, reduction?: Reduction): O; +declare function sigmoidCrossEntropy_(multiClassLabels: T | TensorLike, logits: T | TensorLike, weights?: Tensor | TensorLike, labelSmoothing?: number, reduction?: Reduction): O; +declare function huberLoss_(labels: T | TensorLike, predictions: T | TensorLike, weights?: Tensor | TensorLike, delta?: number, reduction?: Reduction): O; +declare function softmaxCrossEntropy_(onehotLabels: T | TensorLike, logits: T | TensorLike, weights?: Tensor | TensorLike, labelSmoothing?: number, reduction?: Reduction): O; +export declare const absoluteDifference: typeof absoluteDifference_; +export declare const computeWeightedLoss: typeof computeWeightedLoss_; +export declare const cosineDistance: typeof cosineDistance_; +export declare const hingeLoss: typeof hingeLoss_; +export declare const huberLoss: typeof huberLoss_; +export declare const logLoss: typeof logLoss_; +export declare const meanSquaredError: typeof meanSquaredError_; +export declare const sigmoidCrossEntropy: typeof sigmoidCrossEntropy_; +export declare const softmaxCrossEntropy: typeof softmaxCrossEntropy_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js new file mode 100644 index 0000000..f17f8e0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js @@ -0,0 +1,224 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var globals_1 = require("../globals"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var axis_util_1 = require("./axis_util"); +var binary_ops_1 = require("./binary_ops"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +var Reduction; +(function (Reduction) { + Reduction[Reduction["NONE"] = 0] = "NONE"; + Reduction[Reduction["MEAN"] = 1] = "MEAN"; + Reduction[Reduction["SUM"] = 2] = "SUM"; + Reduction[Reduction["SUM_BY_NONZERO_WEIGHTS"] = 3] = "SUM_BY_NONZERO_WEIGHTS"; +})(Reduction = exports.Reduction || (exports.Reduction = {})); +function computeWeightedLoss_(losses, weights, reduction) { + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $losses = tensor_util_env_1.convertToTensor(losses, 'losses', 'computeWeightedLoss'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'computeWeightedLoss'); + } + var weightedLoss = ($weights == null) ? $losses : $losses.mul($weights); + if (reduction === Reduction.NONE) { + return weightedLoss; + } + if (reduction === Reduction.SUM) { + return weightedLoss.sum(); + } + if (reduction === Reduction.MEAN) { + if ($weights == null) { + return weightedLoss.mean(); + } + else { + var broadcastFactor = util_1.sizeFromShape($losses.shape) / util_1.sizeFromShape($weights.shape); + var result = weightedLoss.sum().div($weights.sum()); + return broadcastFactor > 1 ? result.div(tensor_ops_1.scalar(broadcastFactor)) : + result; + } + } + if (reduction === Reduction.SUM_BY_NONZERO_WEIGHTS) { + if ($weights == null) { + return weightedLoss.sum().div(tensor_ops_1.scalar($losses.size)); + } + else { + var broadcastedWeights = $weights.mul(tensor_ops_1.ones($losses.shape)); + var numNonZeros = broadcastedWeights.notEqual(tensor_ops_1.scalar(0)).sum().toFloat(); + return weightedLoss.sum().div(numNonZeros); + } + } + throw Error("Unknown reduction: " + reduction); +} +function absoluteDifference_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'absoluteDifference'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'absoluteDifference'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'absoluteDifference'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in absoluteDifference: '); + var losses = $labels.sub($predictions).abs(); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function meanSquaredError_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'meanSquaredError'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'meanSquaredError'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'meanSquaredError'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in meanSquaredError: '); + var losses = $labels.squaredDifference($predictions); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function cosineDistance_(labels, predictions, axis, weights, reduction) { + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'cosineDistance'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'cosineDistance'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'cosineDistance'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in cosineDistance: '); + var one = tensor_ops_1.scalar(1); + var losses = one.sub($labels.mul($predictions).sum(axis, true)); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function hingeLoss_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'hingeLoss'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'hingeLoss'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'hingeLoss'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in hingeLoss: '); + var one = tensor_ops_1.scalar(1); + $labels = tensor_ops_1.scalar(2).mul($labels).sub(one); + var losses = one.sub($labels.mul($predictions)).relu(); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function logLoss_(labels, predictions, weights, epsilon, reduction) { + if (epsilon === void 0) { epsilon = 1e-7; } + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'logLoss'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'logLoss'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'logLoss'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in logLoss: '); + var one = tensor_ops_1.scalar(1); + var epsilonScalar = tensor_ops_1.scalar(epsilon); + var losses = $labels.mul($predictions.add(epsilonScalar).log()) + .neg() + .sub(one.sub($labels).mul(one.sub($predictions).add(epsilonScalar).log())); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function sigmoidCrossEntropyWithLogits_(labels, logits) { + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'sigmoidCrossEntropyWithLogits'); + var $logits = tensor_util_env_1.convertToTensor(logits, 'logits', 'sigmoidCrossEntropyWithLogits'); + util_1.assertShapesMatch($labels.shape, $logits.shape, 'Error in sigmoidCrossEntropyWithLogits: '); + var maxOutput = $logits.relu(); + var outputXTarget = $logits.mul($labels); + var sigmoidOutput = $logits.abs().neg().exp().log1p(); + return maxOutput.sub(outputXTarget).add(sigmoidOutput); +} +function sigmoidCrossEntropy_(multiClassLabels, logits, weights, labelSmoothing, reduction) { + if (labelSmoothing === void 0) { labelSmoothing = 0; } + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $multiClassLabels = tensor_util_env_1.convertToTensor(multiClassLabels, 'multiClassLabels', 'sigmoidCrossEntropy'); + var $logits = tensor_util_env_1.convertToTensor(logits, 'logits', 'sigmoidCrossEntropy'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'sigmoidCrossEntropy'); + } + util_1.assertShapesMatch($multiClassLabels.shape, $logits.shape, 'Error in sigmoidCrossEntropy: '); + if (labelSmoothing > 0) { + var labelSmoothingScalar = tensor_ops_1.scalar(labelSmoothing); + var one = tensor_ops_1.scalar(1); + var half = tensor_ops_1.scalar(0.5); + $multiClassLabels = $multiClassLabels.mul(one.sub(labelSmoothingScalar)) + .add(half.mul(labelSmoothingScalar)); + } + var losses = sigmoidCrossEntropyWithLogits_($multiClassLabels, $logits); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function huberLoss_(labels, predictions, weights, delta, reduction) { + if (delta === void 0) { delta = 1.0; } + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = tensor_util_env_1.convertToTensor(labels, 'labels', 'huberLoss'); + var $predictions = tensor_util_env_1.convertToTensor(predictions, 'predictions', 'huberLoss'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'huberLoss'); + } + util_1.assertShapesMatch($labels.shape, $predictions.shape, 'Error in huberLoss: '); + var deltaScalar = tensor_ops_1.scalar(delta); + var error = $predictions.sub($labels).abs(); + var quadratic = binary_ops_1.minimum(error, deltaScalar); + var linear = error.sub(quadratic); + var losses = tensor_ops_1.scalar(0.5).mul(quadratic.square()).add(deltaScalar.mul(linear)); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +function softmaxCrossEntropyWithLogits_(labels, logits, dim) { + if (dim === void 0) { dim = -1; } + if (dim === -1) { + dim = logits.rank - 1; + } + if (dim !== logits.rank - 1) { + throw Error("Softmax cross entropy along a non-last dimension is not yet " + + ("supported. Labels / logits was rank " + logits.rank + " ") + + ("and dim was " + dim)); + } + var customOp = globals_1.customGrad(function (labels, logits) { + var keepDims = true; + var lse = logits.logSumExp([dim], keepDims); + var logResult = logits.toFloat().sub(lse); + var costVector = logResult.mul(labels).neg(); + var value = costVector.sum([dim]); + var gradFunc = function (dy) { + var dyShape = axis_util_1.expandShapeToKeepDim(dy.shape, [dim]); + return [ + dy.reshape(dyShape).mul(labels.toFloat().sub(logResult.exp())), + dy.reshape(dyShape).mul(logResult.exp().sub(labels.toFloat())), + ]; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp(labels, logits); +} +function softmaxCrossEntropy_(onehotLabels, logits, weights, labelSmoothing, reduction) { + if (labelSmoothing === void 0) { labelSmoothing = 0; } + if (reduction === void 0) { reduction = Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $onehotLabels = tensor_util_env_1.convertToTensor(onehotLabels, 'onehotLabels', 'softmaxCrossEntropy'); + var $logits = tensor_util_env_1.convertToTensor(logits, 'logits', 'softmaxCrossEntropy'); + var $weights = null; + if (weights != null) { + $weights = tensor_util_env_1.convertToTensor(weights, 'weights', 'softmaxCrossEntropy'); + } + util_1.assertShapesMatch($onehotLabels.shape, $logits.shape, 'Error in softmaxCrossEntropy: '); + if (labelSmoothing > 0) { + var labelSmoothingScalar = tensor_ops_1.scalar(labelSmoothing); + var one = tensor_ops_1.scalar(1); + var numClasses = tensor_ops_1.scalar($onehotLabels.shape[1]); + $onehotLabels = $onehotLabels.mul(one.sub(labelSmoothingScalar)) + .add(labelSmoothingScalar.div(numClasses)); + } + var losses = softmaxCrossEntropyWithLogits_($onehotLabels, $logits); + return exports.computeWeightedLoss(losses, $weights, reduction); +} +exports.absoluteDifference = operation_1.op({ absoluteDifference_: absoluteDifference_ }); +exports.computeWeightedLoss = operation_1.op({ computeWeightedLoss_: computeWeightedLoss_ }); +exports.cosineDistance = operation_1.op({ cosineDistance_: cosineDistance_ }); +exports.hingeLoss = operation_1.op({ hingeLoss_: hingeLoss_ }); +exports.huberLoss = operation_1.op({ huberLoss_: huberLoss_ }); +exports.logLoss = operation_1.op({ logLoss_: logLoss_ }); +exports.meanSquaredError = operation_1.op({ meanSquaredError_: meanSquaredError_ }); +exports.sigmoidCrossEntropy = operation_1.op({ sigmoidCrossEntropy_: sigmoidCrossEntropy_ }); +exports.softmaxCrossEntropy = operation_1.op({ softmaxCrossEntropy_: softmaxCrossEntropy_ }); +//# sourceMappingURL=loss_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js.map new file mode 100644 index 0000000..50300be --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"loss_ops.js","sourceRoot":"","sources":["../../src/ops/loss_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js new file mode 100644 index 0000000..646d289 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js @@ -0,0 +1,1049 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('computeWeightedLoss', test_util_1.ALL_ENVS, function () { + it('1D - no weights', function () { + var losses = tf.tensor1d([1, 2, 3]); + var y = tf.losses.computeWeightedLoss(losses); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 + 2 + 3) / 3); + }); + it('1D - no weights - Reduction.NONE', function () { + var losses = tf.tensor1d([1, 2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [1, 2, 3]); + }); + it('1D - no weights - Reduction.MEAN', function () { + var losses = tf.tensor1d([1, 2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 + 2 + 3) / 3); + }); + it('1D - no weights - Reduction.SUM', function () { + var losses = tf.tensor1d([1, 2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.SUM); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 + 2 + 3)); + }); + it('1D - weights', function () { + var losses = tf.tensor1d([1, 2, 3]); + var weights = tf.tensor1d([0.1, 0, 0.3]); + var y = tf.losses.computeWeightedLoss(losses, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 * 0.1 + 2 * 0 + 3 * 0.3) / 2); + }); + it('2D - weights - broadcast', function () { + var losses = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var y = tf.losses.computeWeightedLoss(losses, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.06666667); + }); + it('1D - weights - Reduction.NONE', function () { + var losses = tf.tensor1d([1, 2, 3]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [1 * 0.1, 2 * 0.2, 3 * 0.3]); + }); + it('1D - weights - Reduction.MEAN', function () { + var losses = tf.tensor1d([1, 2, 3]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 * 0.1 + 2 * 0.2 + 3 * 0.3) / 0.6); + }); + it('1D - weights - Reduction.SUM', function () { + var losses = tf.tensor1d([1, 2, 3]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.SUM); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 * 0.1 + 2 * 0.2 + 3 * 0.3)); + }); + it('2D - no weights', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 + 8 + 12 + 8 + 1 + 3) / 6); + }); + it('2D - weights', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([1, 0, 2, -5, 0, 6], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 * 1 + 8 * 0 + 12 * 2 + (8 * -5) + 1 * 0 + 3 * 6) / 4); + }); + it('2D - no weights - Reduction.MEAN', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 + 8 + 12 + 8 + 1 + 3) / 6); + }); + it('2D - weights - Reduction.MEAN', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([1, 0, 2, -5, 0, 6], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 * 1 + 8 * 0 + 12 * 2 + (8 * -5) + 1 * 0 + 3 * 6) / 4); + }); + it('2D - weights - broadcast - MEAN', function () { + var losses = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (0.3 + 0.1 + 0.2) / (3 * 0.6)); + }); + it('2D - no weights - Reduction.SUM', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.SUM); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 + 8 + 12 + 8 + 1 + 3)); + }); + it('2D - weights - Reduction.SUM', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([1, 0, 2, -5, 0, 6], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.SUM); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (4 * 1 + 8 * 0 + 12 * 2 + (8 * -5) + 1 * 0 + 3 * 6)); + }); + it('2D - no weights - Reduction.NONE', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [4, 8, 12, 8, 1, 3]); + }); + it('2D - weights - Reduction.NONE', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([1, 0, 2, -5, 0, 6], [2, 3]); + var y = tf.losses.computeWeightedLoss(losses, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [4 * 1, 8 * 0, 12 * 2, (8 * -5), 1 * 0, 3 * 6]); + }); + it('throws when passed losses as a non-tensor', function () { + var weights = tf.tensor2d([1, 0, 2, -5, 0, 6], [2, 3]); + var e = /Argument 'losses' passed to 'computeWeightedLoss' must be a Tensor/; + expect(function () { return tf.losses.computeWeightedLoss({}, weights, tf.Reduction.NONE); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var losses = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var e = /Argument 'weights' passed to 'computeWeightedLoss' must be a Tensor/; + expect(function () { return tf.losses.computeWeightedLoss(losses, {}, tf.Reduction.NONE); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var losses = [1, 2, 3]; + var weights = [0.1, 0, 0.3]; + var y = tf.losses.computeWeightedLoss(losses, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 * 0.1 + 2 * 0 + 3 * 0.3) / 2); + }); +}); +jasmine_util_1.describeWithFlags('absoluteDifference', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.absoluteDifference(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(1 - 0.3) + Math.abs(2 - (-0.6)) + Math.abs(3 - (-0.1))) / 3); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.absoluteDifference(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(1 - 0.3) * 0.1 + Math.abs(2 - (-0.6)) * 0.2 + + Math.abs(3 - (-0.1)) * 0.3) / + 3); + }); + it('1D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.absoluteDifference(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [ + Math.abs(1 - 0.3) * 0.1, Math.abs(2 - (-0.6)) * 0.2, + Math.abs(3 - (-0.1)) * 0.3 + ]); + }); + it('1D - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.absoluteDifference(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(1 - 0.3) + Math.abs(2 - (-0.6)) + Math.abs(3 - (-0.1))) / 3); + }); + it('1D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.absoluteDifference(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((Math.abs(1 - 0.3) * 0.1) + (Math.abs(2 - (-0.6)) * 0.2) + + (Math.abs(3 - (-0.1)) * 0.3)) / + 0.6); + }); + it('2D', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.absoluteDifference(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(4 - 1) + Math.abs(8 - 9) + Math.abs(12 - 2) + + Math.abs(8 - (-5)) + Math.abs(1 - (-2)) + Math.abs(3 - 6)) / + 6); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.absoluteDifference(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(4 - 1) * 3 + Math.abs(8 - 9) * 0 + Math.abs(12 - 2) * 5 + + Math.abs(8 - (-5)) * 0 + Math.abs(1 - (-2)) * 4 + + Math.abs(3 - 6) * 2) / + 4); + }); + it('2D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.absoluteDifference(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [ + Math.abs(4 - 1) * 3, Math.abs(8 - 9) * 6, Math.abs(12 - 2) * 5, + Math.abs(8 - (-5)) * 0, Math.abs(1 - (-2)) * 4, Math.abs(3 - 6) * 2 + ]); + }); + it('2D - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.absoluteDifference(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(4 - 1) + Math.abs(8 - 9) + Math.abs(12 - 2) + + Math.abs(8 - (-5)) + Math.abs(1 - (-2)) + Math.abs(3 - 6)) / + 6); + }); + it('2D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.absoluteDifference(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (Math.abs(4 - 1) * 3 + Math.abs(8 - 9) * 6 + Math.abs(12 - 2) * 5 + + Math.abs(8 - (-5)) * 0 + Math.abs(1 - (-2)) * 4 + + Math.abs(3 - 6) * 2) / + 20); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = /Argument 'labels' passed to 'absoluteDifference' must be a Tensor/; + expect(function () { return tf.losses.absoluteDifference({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'absoluteDifference\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.absoluteDifference(label, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var e = /Argument 'weights' passed to 'absoluteDifference' must be a Tensor/; + expect(function () { return tf.losses.absoluteDifference(label, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var predictions = [1, 2, 3]; + var label = [0.3, -0.6, -0.1]; + var weights = [0.1, 0.2, 0.3]; + var y = tf.losses.absoluteDifference(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [ + Math.abs(1 - 0.3) * 0.1, Math.abs(2 - (-0.6)) * 0.2, + Math.abs(3 - (-0.1)) * 0.3 + ]); + }); +}); +jasmine_util_1.describeWithFlags('meanSquaredError', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.meanSquaredError(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - 0.3) * (1 - 0.3) + (2 - (-0.6)) * (2 - (-0.6)) + + (3 - (-0.1)) * (3 - (-0.1))) / + 3); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.meanSquaredError(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - 0.3) * (1 - 0.3) * 0.1 + (2 - (-0.6)) * (2 - (-0.6)) * 0.2 + + (3 - (-0.1)) * (3 - (-0.1)) * 0.3) / + 3); + }); + it('1D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.meanSquaredError(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [ + (1 - 0.3) * (1 - 0.3) * 0.1, (2 - (-0.6)) * (2 - (-0.6)) * 0.2, + (3 - (-0.1)) * (3 - (-0.1)) * 0.3 + ]); + }); + it('1D - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.meanSquaredError(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - 0.3) * (1 - 0.3) + (2 - (-0.6)) * (2 - (-0.6)) + + (3 - (-0.1)) * (3 - (-0.1))) / + 3); + }); + it('1D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.meanSquaredError(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (((1 - 0.3) * (1 - 0.3) * 0.1) + ((2 - (-0.6)) * (2 - (-0.6)) * 0.2) + + ((3 - (-0.1)) * (3 - (-0.1)) * 0.3)) / + 0.6); + }); + it('2D', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.meanSquaredError(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((4 - 1) * (4 - 1) + (8 - 9) * (8 - 9) + (12 - 2) * (12 - 2) + + (8 - (-5)) * (8 - (-5)) + (1 - (-2)) * (1 - (-2)) + + (3 - 6) * (3 - 6)) / + 6); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.meanSquaredError(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((4 - 1) * (4 - 1) * 3 + (8 - 9) * (8 - 9) * 0 + + (12 - 2) * (12 - 2) * 5 + (8 - (-5)) * (8 - (-5)) * 0 + + (1 - (-2)) * (1 - (-2)) * 4 + (3 - 6) * (3 - 6) * 2) / + 4); + }); + it('2D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.meanSquaredError(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [ + (4 - 1) * (4 - 1) * 3, (8 - 9) * (8 - 9) * 6, (12 - 2) * (12 - 2) * 5, + (8 - (-5)) * (8 - (-5)) * 0, (1 - (-2)) * (1 - (-2)) * 4, + (3 - 6) * (3 - 6) * 2 + ]); + }); + it('2D - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.meanSquaredError(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((4 - 1) * (4 - 1) + (8 - 9) * (8 - 9) + (12 - 2) * (12 - 2) + + (8 - (-5)) * (8 - (-5)) + (1 - (-2)) * (1 - (-2)) + + (3 - 6) * (3 - 6)) / + 6); + }); + it('2D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.meanSquaredError(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((4 - 1) * (4 - 1) * 3 + (8 - 9) * (8 - 9) * 6 + + (12 - 2) * (12 - 2) * 5 + (8 - (-5)) * (8 - (-5)) * 0 + + (1 - (-2)) * (1 - (-2)) * 4 + (3 - 6) * (3 - 6) * 2) / + 20); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = /Argument 'labels' passed to 'meanSquaredError' must be a Tensor/; + expect(function () { return tf.losses.meanSquaredError({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'meanSquaredError\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.meanSquaredError(label, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var e = /Argument 'weights' passed to 'meanSquaredError' must be a Tensor/; + expect(function () { return tf.losses.meanSquaredError(label, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var predictions = [1, 2, 3]; + var label = [0.3, -0.6, -0.1]; + var weights = [0.1, 0.2, 0.3]; + var y = tf.losses.meanSquaredError(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [ + (1 - 0.3) * (1 - 0.3) * 0.1, (2 - (-0.6)) * (2 - (-0.6)) * 0.2, + (3 - (-0.1)) * (3 - (-0.1)) * 0.3 + ]); + }); +}); +jasmine_util_1.describeWithFlags('cosineDistance', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.cosineDistance(label, predictions, 0); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1)); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.scalar(0.1); + var y = tf.losses.cosineDistance(label, predictions, 0, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1)) * 0.1); + }); + it('1D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.scalar(0.1); + var y = tf.losses.cosineDistance(label, predictions, 0, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([1]); + test_util_1.expectArraysClose(y, [(1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1)) * 0.1]); + }); + it('1D - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.cosineDistance(label, predictions, 0, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), (1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1))); + }); + it('1D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor1d([1, 2, 3]); + var label = tf.tensor1d([0.3, -0.6, -0.1]); + var weights = tf.scalar(0.1); + var y = tf.losses.cosineDistance(label, predictions, 0, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1)) * 0.1) / 0.1); + }); + it('2D', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.cosineDistance(label, predictions, 1); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - (4 * 1 + 8 * 9 + 12 * 2)) + (1 - (8 * -5 + 1 * -2 + 3 * 6))) / 2); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 0], [2, 1]); + var y = tf.losses.cosineDistance(label, predictions, 1, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - (4 * 1 + 8 * 9 + 12 * 2)) * 3 + + (1 - (8 * -5 + 1 * -2 + 3 * 6)) * 0) / + 1); + }); + it('2D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 0], [2, 1]); + var y = tf.losses.cosineDistance(label, predictions, 1, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 1]); + test_util_1.expectArraysClose(y, [ + (1 - (4 * 1 + 8 * 9 + 12 * 2)) * 3, (1 - (8 * -5 + 1 * -2 + 3 * 6)) * 0 + ]); + }); + it('2D - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var y = tf.losses.cosineDistance(label, predictions, 1, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - (4 * 1 + 8 * 9 + 12 * 2)) + (1 - (8 * -5 + 1 * -2 + 3 * 6))) / 2); + }); + it('2D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 0], [2, 1]); + var y = tf.losses.cosineDistance(label, predictions, 1, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), ((1 - (4 * 1 + 8 * 9 + 12 * 2)) * 3 + + (1 - (8 * -5 + 1 * -2 + 3 * 6)) * 0) / + 3); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = /Argument 'labels' passed to 'cosineDistance' must be a Tensor/; + expect(function () { return tf.losses.cosineDistance({}, predictions, 0, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'cosineDistance\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.cosineDistance(label, {}, 0, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var predictions = tf.tensor2d([4, 8, 12, 8, 1, 3], [2, 3]); + var label = tf.tensor2d([1, 9, 2, -5, -2, 6], [2, 3]); + var e = /Argument 'weights' passed to 'cosineDistance' must be a Tensor/; + expect(function () { return tf.losses.cosineDistance(label, predictions, 0, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var predictions = [1, 2, 3]; + var label = [0.3, -0.6, -0.1]; + var weights = 0.1; + var y = tf.losses.cosineDistance(label, predictions, 0, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([1]); + test_util_1.expectArraysClose(y, [(1 - (1 * 0.3 + 2 * -0.6 + 3 * -0.1)) * 0.1]); + }); +}); +jasmine_util_1.describeWithFlags('hingeLoss', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var predictions = tf.tensor1d([0, 0, 1, 1]); + var label = tf.tensor1d([0, 1, 0, 1]); + var y = tf.losses.hingeLoss(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.0); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor1d([0, 0, 1, 1]); + var label = tf.tensor1d([0, 1, 0, 1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3, 0.4]); + var y = tf.losses.hingeLoss(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.225); + }); + it('1D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor1d([0, 0, 1, 1]); + var label = tf.tensor1d([0, 1, 0, 1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3, 0.4]); + var y = tf.losses.hingeLoss(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([4]); + test_util_1.expectArraysClose(y, [0.1, 0.2, 0.6, 0.0]); + }); + it('1D - Reduction.MEAN', function () { + var predictions = tf.tensor1d([0, 0, 1, 1]); + var label = tf.tensor1d([0, 1, 0, 1]); + var y = tf.losses.hingeLoss(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.0); + }); + it('1D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor1d([0, 0, 1, 1]); + var label = tf.tensor1d([0, 1, 0, 1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3, 0.4]); + var y = tf.losses.hingeLoss(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.9); + }); + it('2D', function () { + var predictions = tf.tensor2d([0, 0, 0, 1, 1, 1], [2, 3]); + var label = tf.tensor2d([0, 1, 0, 1, 0, 1], [2, 3]); + var y = tf.losses.hingeLoss(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.8333333); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var predictions = tf.tensor2d([0, 0, 0, 1, 1, 1], [2, 3]); + var label = tf.tensor2d([0, 1, 0, 1, 0, 1], [2, 3]); + var weights = tf.tensor2d([0.1, 0.2, 0.3, 0.4, 0.5, 0.6], [2, 3]); + var y = tf.losses.hingeLoss(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.26666668); + }); + it('2D - weighted - Reduction.NONE', function () { + var predictions = tf.tensor2d([0, 0, 0, 1, 1, 1], [2, 3]); + var label = tf.tensor2d([0, 1, 0, 1, 0, 1], [2, 3]); + var weights = tf.tensor2d([0.1, 0.2, 0.3, 0.4, 0.5, 0.6], [2, 3]); + var y = tf.losses.hingeLoss(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [0.1, 0.2, 0.3, 0, 1, 0]); + }); + it('2D - Reduction.MEAN', function () { + var predictions = tf.tensor2d([0, 0, 0, 1, 1, 1], [2, 3]); + var label = tf.tensor2d([0, 1, 0, 1, 0, 1], [2, 3]); + var y = tf.losses.hingeLoss(label, predictions, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.8333333); + }); + it('2D - weighted - Reduction.MEAN', function () { + var predictions = tf.tensor2d([0, 0, 0, 1, 1, 1], [2, 3]); + var label = tf.tensor2d([0, 1, 0, 1, 0, 1], [2, 3]); + var weights = tf.tensor2d([0.1, 0.2, 0.3, 0.4, 0.5, 0.6], [2, 3]); + var y = tf.losses.hingeLoss(label, predictions, weights, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.76190484); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var weights = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var e = /Argument 'labels' passed to 'hingeLoss' must be a Tensor/; + expect(function () { return tf.losses.hingeLoss({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var label = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var weights = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'hingeLoss\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.hingeLoss(label, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var predictions = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var label = tf.tensor2d([1, 0, 1, 0, 1, 0], [2, 3]); + var e = /Argument 'weights' passed to 'hingeLoss' must be a Tensor/; + expect(function () { return tf.losses.hingeLoss(label, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var predictions = [0, 0, 1, 1]; + var label = [0, 1, 0, 1]; + var weights = [0.1, 0.2, 0.3, 0.4]; + var y = tf.losses.hingeLoss(label, predictions, weights, tf.Reduction.NONE); + expect(y.shape).toEqual([4]); + test_util_1.expectArraysClose(y, [0.1, 0.2, 0.6, 0.0]); + }); +}); +jasmine_util_1.describeWithFlags('logLoss', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var y = tf.losses.logLoss(labels, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 2.668788); + }); + it('1D - Check for negative values', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, -0.6, -0.1]); + var y = tf.losses.logLoss(labels, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), NaN); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.logLoss(labels, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.7168596); + }); + it('1D - weighted - Reduction.NONE', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.logLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [0.12039725, 0.02107204, 2.0091095]); + }); + it('1D - Reduction.MEAN', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var y = tf.losses.logLoss(labels, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 2.668788); + }); + it('1D - weighted - Reduction.MEAN', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.logLoss(labels, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 3.5842977); + }); + it('2D', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var y = tf.losses.logLoss(labels, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.60019904); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.logLoss(labels, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.8866577); + }); + it('2D - weighted - Reduction.NONE', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.logLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [2.9527497, 0., 1.8451363, 0., 1.3829476, 1.3657978]); + }); + it('2D - Reduction.MEAN', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var y = tf.losses.logLoss(labels, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.60019904); + }); + it('2D - weighted - Reduction.MEAN', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.logLoss(labels, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.53904504); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = /Argument 'labels' passed to 'logLoss' must be a Tensor/; + expect(function () { return tf.losses.logLoss({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'logLoss\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.logLoss(labels, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var e = /Argument 'weights' passed to 'logLoss' must be a Tensor/; + expect(function () { return tf.losses.logLoss(labels, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var labels = [1, 2, 3]; + var predictions = [0.3, 0.6, 0.1]; + var weights = [0.1, 0.2, 0.3]; + var y = tf.losses.logLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [0.12039725, 0.02107204, 2.0091095]); + }); +}); +jasmine_util_1.describeWithFlags('huberLoss', test_util_1.ALL_ENVS, function () { + it('1D', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var y = tf.losses.huberLoss(labels, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.1816667); + }); + it('1D - delta', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var delta = 0.4; + var y = tf.losses.huberLoss(labels, predictions, undefined, delta); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.58666664); + }); + it('1D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.huberLoss(labels, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.30816665); + }); + it('1D - weighted - Reduction.NONE', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.huberLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [0.0245, 0.17999999, 0.72]); + }); + it('1D - Reduction.MEAN', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var y = tf.losses.huberLoss(labels, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.1816667); + }); + it('1D - weighted - Reduction.MEAN', function () { + var labels = tf.tensor1d([1, 2, 3]); + var predictions = tf.tensor1d([0.3, 0.6, 0.1]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.huberLoss(labels, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.5408332); + }); + it('2D', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var y = tf.losses.huberLoss(labels, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.01795); + }); + it('2D - weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.huberLoss(labels, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.040875003); + }); + it('2D - weighted - Reduction.NONE', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.huberLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(y, [0.135, 0., 0.001, 0., 0.005, 0.0225]); + }); + it('2D - Reduction.MEAN', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var y = tf.losses.huberLoss(labels, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.01795); + }); + it('2D - weighted - Reduction.MEAN', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 0, 5, 0, 4, 2], [2, 3]); + var y = tf.losses.huberLoss(labels, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0.011678572); + }); + it('throws when passed label as a non-tensor', function () { + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = /Argument 'labels' passed to 'huberLoss' must be a Tensor/; + expect(function () { return tf.losses.huberLoss({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed label as a non-tensor', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var weights = tf.tensor2d([3, 6, 5, 0, 4, 2], [2, 3]); + var e = new RegExp('Argument \'predictions\' passed to \'huberLoss\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.huberLoss(labels, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var labels = tf.tensor2d([0.4, 0.8, 0.12, 0.8, 0.1, 0.3], [2, 3]); + var predictions = tf.tensor2d([0.1, 0.7, 0.1, 0.5, 0.05, 0.15], [2, 3]); + var e = /Argument 'weights' passed to 'huberLoss' must be a Tensor/; + expect(function () { return tf.losses.huberLoss(labels, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var labels = [1, 2, 3]; + var predictions = [0.3, 0.6, 0.1]; + var weights = [0.1, 0.2, 0.3]; + var y = tf.losses.huberLoss(labels, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [0.0245, 0.17999999, 0.72]); + }); +}); +jasmine_util_1.describeWithFlags('sigmoidCrossEntropy', test_util_1.ALL_ENVS, function () { + it('All wrong', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 6.6667123); + }); + it('All right', function () { + var label = tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0); + }); + it('Weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 1.3333424); + }); + it('Weighted - Reduction.NONE', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3, 3]); + test_util_1.expectArraysClose(y, [ + 1.0000046, 9.0797803e-06, 3.0000138e+00, 1.0000046e+00, 2.0000093e+00, + 1.3619671e-05, 4.5398901e-06, 2.0000093e+00, 3.0000138e+00 + ]); + }); + it('Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 6.6667123); + }); + it('Weighted - Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var y = tf.losses.sigmoidCrossEntropy(label, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 6.666712284088135); + }); + it('Label Smoothing - Weighted - Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var labelSmoothing = 0.3; + var y = tf.losses.sigmoidCrossEntropy(label, predictions, weights, labelSmoothing, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 6.1667128); + }); + it('throws when multiClassLabels and logits are of different shapes', function () { + var multiClassLabels = tf.tensor2d([10, 10, 10, 10, 10, 10, 10, 10, 10], [3, 3]); + var logits = tf.tensor2d([10, 10, 10, 10, 10, 10], [2, 3]); + var e = new RegExp('Error in sigmoidCrossEntropy: Shapes 3,3 and 2,3 must match'); + expect(function () { return tf.losses.sigmoidCrossEntropy(multiClassLabels, logits); }) + .toThrowError(e); + }); + it('throws when passed multiClassLabels as a non-tensor', function () { + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var e = new RegExp('Argument \'multiClassLabels\' passed to \'sigmoidCrossEntropy\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.sigmoidCrossEntropy({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed logits as a non-tensor', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var e = new RegExp('Argument \'logits\' passed to \'sigmoidCrossEntropy\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.sigmoidCrossEntropy(label, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var e = /Argument 'weights' passed to 'sigmoidCrossEntropy' must be a Tensor/; + expect(function () { return tf.losses.sigmoidCrossEntropy(label, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); +}); +jasmine_util_1.describeWithFlags('softmaxCrossEntropy', test_util_1.ALL_ENVS, function () { + it('All wrong', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.softmaxCrossEntropy(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 20); + }); + it('All right', function () { + var label = tf.tensor2d([[1, 0, 0], [0, 1, 0], [0, 0, 1]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.softmaxCrossEntropy(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 0); + }); + it('Weighted - Reduction.SUM_BY_NONZERO_WEIGHTS', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3], [0.1, 0.2, 0.3], [0.1, 0.2, 0.3]]); + var y = tf.losses.softmaxCrossEntropy(label, predictions, weights); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 4); + }); + it('Weighted - Reduction.NONE', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.softmaxCrossEntropy(label, predictions, weights, undefined, tf.Reduction.NONE); + expect(y.shape).toEqual([3]); + test_util_1.expectArraysClose(y, [2, 4, 6]); + }); + it('Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var y = tf.losses.softmaxCrossEntropy(label, predictions, undefined, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 20); + }); + it('Weighted - Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor1d([0.1, 0.2, 0.3]); + var y = tf.losses.softmaxCrossEntropy(label, predictions, weights, undefined, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 20); + }); + it('Label Smoothing - Weighted - Reduction.MEAN', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var labelSmoothing = 0.3; + var y = tf.losses.softmaxCrossEntropy(label, predictions, weights, labelSmoothing, tf.Reduction.MEAN); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 18); + }); + it('throws when multiClassLabels and logits are of different shapes', function () { + var multiClassLabels = tf.tensor2d([10, 10, 10, 10, 10, 10, 10, 10, 10], [3, 3]); + var logits = tf.tensor2d([10, 10, 10, 10, 10, 10], [2, 3]); + var e = new RegExp('Error in softmaxCrossEntropy: Shapes 3,3 and 2,3 must match'); + expect(function () { return tf.losses.softmaxCrossEntropy(multiClassLabels, logits); }) + .toThrowError(e); + }); + it('throws when passed multiClassLabels as a non-tensor', function () { + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var e = new RegExp('Argument \'onehotLabels\' passed to \'softmaxCrossEntropy\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.softmaxCrossEntropy({}, predictions, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed logits as a non-tensor', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var weights = tf.tensor2d([[0.1, 0.2, 0.3]]); + var e = new RegExp('Argument \'logits\' passed to \'softmaxCrossEntropy\' ' + + 'must be a Tensor'); + expect(function () { return tf.losses.softmaxCrossEntropy(label, {}, weights, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('throws when passed weights as a non-tensor', function () { + var label = tf.tensor2d([[0, 0, 1], [1, 0, 0], [0, 1, 0]], [3, 3]); + var predictions = tf.tensor2d([[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]], [3, 3]); + var e = /Argument 'weights' passed to 'softmaxCrossEntropy' must be a Tensor/; + expect(function () { return tf.losses.softmaxCrossEntropy(label, predictions, {}, tf.Reduction.MEAN); }) + .toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var label = [[0, 0, 1], [1, 0, 0], [0, 1, 0]]; + var predictions = [[10.0, -10.0, -10.0], [-10.0, 10.0, -10.0], [-10.0, -10.0, 10.0]]; + var y = tf.losses.softmaxCrossEntropy(label, predictions); + expect(y.shape).toEqual([]); + test_util_1.expectNumbersClose(y.get(), 20); + }); +}); +//# sourceMappingURL=loss_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js.map new file mode 100644 index 0000000..5171c75 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/loss_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"loss_ops_test.js","sourceRoot":"","sources":["../../src/ops/loss_ops_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAA6E;AAE7E,gCAAiB,CAAC,qBAAqB,EAAE,oBAAQ,EAAE;IACjD,EAAE,CAAC,iBAAiB,EAAE;QACpB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAEhD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtC,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtC,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE;QACpC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtC,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAEvE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QAE3C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE5E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE5E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAE3E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iBAAiB,EAAE;QACpB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAEhD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE5E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE;QACpC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE5E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE;QACpC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAEvE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAE3E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE5E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAM,CAAC,GACH,oEAAoE,CAAC;QACzE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAD1C,CAC0C,CAAC;aAChD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,qEAAqE,CAAC;QAC1E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,MAAM,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADzC,CACyC,CAAC;aAC/C,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACzB,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;QAC9B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,oBAAoB,EAAE,oBAAQ,EAAE;IAChD,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE3D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAEpE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YACpD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;YACxB,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE;YACnB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YACnD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;SAC3B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEtD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;YACxD,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;YAC1B,GAAG,CAAC,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE3D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YACpD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACvD,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAEpE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC;YAChE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YAC/C,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACjB,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE;YACnB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC;YAC9D,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;SACpE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEtD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YACpD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACvD,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC;YAChE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YAC/C,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACjB,EAAE,CAAC,CAAC;IACd,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,mEAAmE,CAAC;QACxE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAC9B,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,4DAA4D;YAC5D,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAC9B,KAAK,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADjD,CACiD,CAAC;aACvD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,oEAAoE,CAAC;QACzE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAC9B,KAAK,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADrD,CACqD,CAAC;aAC3D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9B,IAAM,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAChC,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAEhC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAClC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE;YACnB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YACnD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;SAC3B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,kBAAkB,EAAE,oBAAQ,EAAE;IAC9C,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACnD,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YAC/D,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;YAC/B,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE;YACnB,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YAC9D,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;SAClC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEtD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACnD,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;YACnE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;YACjC,GAAG,CAAC,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YAC3D,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;YAC7C,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YACrD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE;YACnB,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC;YACrE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YACxD,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;SACtB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEtD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YAC3D,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC;YAC7C,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YACrD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACjD,EAAE,CAAC,CAAC;IACd,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,iEAAiE,CAAC;QAC5E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAC5B,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,0DAA0D;YAC1D,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAC5B,KAAK,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADjD,CACiD,CAAC;aACvD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GACH,kEAAkE,CAAC;QACvE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAC5B,KAAK,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADrD,CACqD,CAAC;aAC3D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9B,IAAM,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAChC,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAEhC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAChC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE;YACnB,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;YAC9D,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG;SAClC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,gBAAgB,EAAE,oBAAQ,EAAE;IAC5C,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QAE1D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QAEnE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC7C,IAAM,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QAE1D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE5C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QAEnE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAClC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE5C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE;YACnB,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;SACxE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEzD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE5C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAClC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,+DAA+D,CAAC;QAC1E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,cAAc,CAC1B,EAAe,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAD1D,CAC0D,CAAC;aAChE,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,wDAAwD;YACxD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,cAAc,CAC1B,KAAK,EAAE,EAAe,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADpD,CACoD,CAAC;aAC1D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,gEAAgE,CAAC;QAC3E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,cAAc,CAC1B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADxD,CACwD,CAAC;aAC9D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9B,IAAM,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAChC,IAAM,OAAO,GAAG,GAAG,CAAC;QAEpB,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAC9B,KAAK,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,WAAW,EAAE,oBAAQ,EAAE;IACvC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAElD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAElD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE3D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAElD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExC,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE1E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAElD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAElD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEpE,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE3D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEpE,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtD,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE1E,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEpE,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,0DAA0D,CAAC;QACrE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,mDAAmD;YACnD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,KAAK,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADjD,CACiD,CAAC;aACvD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEtD,IAAM,CAAC,GAAG,2DAA2D,CAAC;QACtE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,KAAK,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADrD,CACqD,CAAC;aAC3D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACjC,IAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3B,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAErC,IAAM,CAAC,GACH,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAExE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,SAAS,EAAE,oBAAQ,EAAE;IACrC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAEjD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAEnD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAEjD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE1D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAEjD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE1D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE,CAAC,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,wDAAwD,CAAC;QACnE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,OAAO,CACnB,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,iDAAiD;YACjD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,OAAO,CACnB,MAAM,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADlD,CACkD,CAAC;aACxD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,yDAAyD,CAAC;QACpE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,OAAO,CACnB,MAAM,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADtD,CACsD,CAAC;aAC5D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACzB,IAAM,WAAW,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACpC,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAEhC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CACvB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,WAAW,EAAE,oBAAQ,EAAE;IACvC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAEnD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,KAAK,GAAG,GAAG,CAAC;QAElB,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QAErE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtC,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAEnD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;QACxB,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAElE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,0DAA0D,CAAC;QACrE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAExD,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,mDAAmD;YACnD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,MAAM,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADlD,CACkD,CAAC;aACxD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,2DAA2D,CAAC;QACtE,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,SAAS,CACrB,MAAM,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADtD,CACsD,CAAC;aAC5D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACzB,IAAM,WAAW,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACpC,IAAM,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAEhC,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CACzB,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,qBAAqB,EAAE,oBAAQ,EAAE;IACjD,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAErE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE/D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,6BAAiB,CAAC,CAAC,EAAE;YACnB,SAAS,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa;YACrE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa;SAC3D,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gBAAgB,EAAE;QACnB,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEjE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE/D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,iBAAiB,CACpB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,cAAc,GAAG,GAAG,CAAC;QAE3B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;QACpE,IAAM,gBAAgB,GAClB,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE7D,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,8DAA8D,CAAC,CAAC;QACpE,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,MAAM,CAAC,EAAvD,CAAuD,CAAC;aAChE,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE;QACxD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,kEAAkE;YAClE,kBAAkB,CAAC,CAAC;QAExB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,wDAAwD;YACxD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,KAAK,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADjD,CACiD,CAAC;aACvD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GACH,qEAAqE,CAAC;QAC1E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,KAAK,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADrD,CACqD,CAAC;aAC3D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gCAAiB,CAAC,qBAAqB,EAAE,oBAAQ,EAAE;IACjD,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,OAAO,GACT,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAErE,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAErE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE/D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,6BAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gBAAgB,EAAE;QACnB,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEjE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE/D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CACd,CAAC,CAAC,GAAG,EAAE,EACP,EAAE,CACL,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,cAAc,GAAG,GAAG,CAAC;QAE3B,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CACnC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;QACpE,IAAM,gBAAgB,GAClB,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAM,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE7D,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,8DAA8D,CAAC,CAAC;QACpE,MAAM,CAAC,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,MAAM,CAAC,EAAvD,CAAuD,CAAC;aAChE,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE;QACxD,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,8DAA8D;YAC9D,kBAAkB,CAAC,CAAC;QAExB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,EAAe,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADvD,CACuD,CAAC;aAC7D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAM,CAAC,GAAG,IAAI,MAAM,CAChB,wDAAwD;YACxD,kBAAkB,CAAC,CAAC;QACxB,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,KAAK,EAAE,EAAe,EAAE,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADjD,CACiD,CAAC;aACvD,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GAAG,EAAE,CAAC,QAAQ,CAC3B,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEZ,IAAM,CAAC,GACH,qEAAqE,CAAC;QAC1E,MAAM,CACF,cAAM,OAAA,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAC/B,KAAK,EAAE,WAAW,EAAE,EAAe,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EADrD,CACqD,CAAC;aAC3D,YAAY,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,IAAM,WAAW,GACb,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAEvE,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAE5D,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5B,8BAAkB,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.d.ts new file mode 100644 index 0000000..e15821e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.d.ts @@ -0,0 +1,5 @@ +import { Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function localResponseNormalization_(x: T | TensorLike, depthRadius?: number, bias?: number, alpha?: number, beta?: number): T; +export declare const localResponseNormalization: typeof localResponseNormalization_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js new file mode 100644 index 0000000..40c3403 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js @@ -0,0 +1,36 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var operation_1 = require("./operation"); +function localResponseNormalization_(x, depthRadius, bias, alpha, beta) { + if (depthRadius === void 0) { depthRadius = 5; } + if (bias === void 0) { bias = 1; } + if (alpha === void 0) { alpha = 1; } + if (beta === void 0) { beta = 0.5; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'localResponseNormalization'); + util.assert($x.rank === 4 || $x.rank === 3, "Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank " + $x.rank + "."); + util.assert(util.isInt(depthRadius), "Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius " + depthRadius + "."); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + var backward = function (dy, saved) { + var outputImage = saved[0]; + return { + x4D: function () { return environment_1.ENV.engine.runKernel(function (backend) { return backend.LRNGrad(dy, x4D, outputImage, depthRadius, bias, alpha, beta); }, {}); } + }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.localResponseNormalization4D(x4D, depthRadius, bias, alpha, beta)); }, { x4D: x4D }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + else { + return res; + } +} +exports.localResponseNormalization = operation_1.op({ localResponseNormalization_: localResponseNormalization_ }); +//# sourceMappingURL=lrn.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js.map new file mode 100644 index 0000000..4736bbf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lrn.js","sourceRoot":"","sources":["../../src/ops/lrn.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,8BAAgC;AAChC,yCAA+B;AAgB/B,qCACI,CAAe,EAAE,WAAe,EAAE,IAAQ,EAAE,KAAS,EAAE,IAAU;IAAhD,4BAAA,EAAA,eAAe;IAAE,qBAAA,EAAA,QAAQ;IAAE,sBAAA,EAAA,SAAS;IAAE,qBAAA,EAAA,UAAU;IACnE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,4BAA4B,CAAC,CAAC;IACjE,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAC9B,6FACgB,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;IAChC,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,EACvB,mHACqC,WAAW,MAAG,CAAC,CAAC;IAEzD,IAAI,GAAG,GAAG,EAAc,CAAC;IACzB,IAAI,YAAY,GAAG,KAAK,CAAC;IACzB,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACjB,YAAY,GAAG,IAAI,CAAC;QACpB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KACzD;IACD,IAAM,QAAQ,GAAG,UAAC,EAAY,EAAE,KAAe;QACtC,IAAA,sBAAW,CAAU;QAC5B,OAAO;YACL,GAAG,EAAE,cAAM,OAAA,iBAAG,CAAC,MAAM,CAAC,SAAS,CAC3B,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,OAAO,CACtB,EAAE,EAAE,GAAG,EAAE,WAAuB,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,EAD1D,CAC0D,EACrE,EAAE,CAAC,EAHI,CAGJ;SACR,CAAC;IACJ,CAAC,CAAC;IACF,IAAM,GAAG,GAAG,iBAAG,CAAC,MAAM,CAAC,SAAS,CAC5B,UAAC,OAAO,EAAE,IAAI,IAAK,OAAA,IAAI,CAAC,OAAO,CAAC,4BAA4B,CACxD,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,EADtB,CACsB,EACzC,EAAC,GAAG,KAAA,EAAC,EAAE,QAAQ,CAAC,CAAC;IACrB,IAAI,YAAY,EAAE;QAChB,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAM,CAAC;KAChE;SAAM;QACL,OAAO,GAAQ,CAAC;KACjB;AACH,CAAC;AAEY,QAAA,0BAA0B,GAAG,cAAE,CAAC,EAAC,2BAA2B,6BAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js new file mode 100644 index 0000000..b52eda9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js @@ -0,0 +1,854 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var sqArr = function (arr) { return arr.map(function (d) { return d * d; }); }; +var sumArr = function (arr) { return arr.reduce(function (prev, curr) { return prev + curr; }, 0); }; +var flatten = function (arr) { + return arr.reduce(function (prev, curr) { + return prev.concat(Array.isArray(curr) ? flatten(curr) : curr); + }, []); +}; +jasmine_util_1.describeWithFlags('localResponseNormalization with Tensor3D', test_util_1.ALL_ENVS, function () { + it('throws error with invalid input', function () { + var x = tf.tensor2d([1, 20, 300, 4], [1, 4]); + var radius = 3; + expect(function () { return x.localResponseNormalization(radius); }).toThrowError(); + }); + it('throws error with invalid radius', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + var radius = 0.5; + expect(function () { return x.localResponseNormalization(radius); }).toThrowError(); + }); + it('computes simple normalization across channels', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.5; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + test_util_1.expectArraysClose(result, [ + x.get(0, 0, 0) * f(x.get(0, 0, 0), x.get(0, 0, 1)), + x.get(0, 0, 1) * f(x.get(0, 0, 0), x.get(0, 0, 1), x.get(0, 0, 2)), + x.get(0, 0, 2) * f(x.get(0, 0, 1), x.get(0, 0, 2), x.get(0, 0, 3)), + x.get(0, 0, 3) * f(x.get(0, 0, 2), x.get(0, 0, 3)), + ]); + }); + it('uses beta = 1.0 to test GPU optimization', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 1.0; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + test_util_1.expectArraysClose(result, [ + x.get(0, 0, 0) * f(x.get(0, 0, 0), x.get(0, 0, 1)), + x.get(0, 0, 1) * f(x.get(0, 0, 0), x.get(0, 0, 1), x.get(0, 0, 2)), + x.get(0, 0, 2) * f(x.get(0, 0, 1), x.get(0, 0, 2), x.get(0, 0, 3)), + x.get(0, 0, 3) * f(x.get(0, 0, 2), x.get(0, 0, 3)), + ]); + }); + it('uses beta = 0.75 to test GPU optimization', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.75; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + test_util_1.expectArraysClose(result, [ + x.get(0, 0, 0) * f(x.get(0, 0, 0), x.get(0, 0, 1)), + x.get(0, 0, 1) * f(x.get(0, 0, 0), x.get(0, 0, 1), x.get(0, 0, 2)), + x.get(0, 0, 2) * f(x.get(0, 0, 1), x.get(0, 0, 2), x.get(0, 0, 3)), + x.get(0, 0, 3) * f(x.get(0, 0, 2), x.get(0, 0, 3)), + ]); + }); + it('computes complex normalization across channels', function () { + var x = tf.tensor3d([1, 20, 300, 4, 5, 15, 24, 200, 1, 20, 300, 4, 5, 15, 24, 200], [2, 2, 4]); + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.5; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + test_util_1.expectArraysClose(result, [ + x.get(0, 0, 0) * f(x.get(0, 0, 0), x.get(0, 0, 1)), + x.get(0, 0, 1) * f(x.get(0, 0, 0), x.get(0, 0, 1), x.get(0, 0, 2)), + x.get(0, 0, 2) * f(x.get(0, 0, 1), x.get(0, 0, 2), x.get(0, 0, 3)), + x.get(0, 0, 3) * f(x.get(0, 0, 2), x.get(0, 0, 3)), + x.get(0, 1, 0) * f(x.get(0, 1, 0), x.get(0, 1, 1)), + x.get(0, 1, 1) * f(x.get(0, 1, 0), x.get(0, 1, 1), x.get(0, 1, 2)), + x.get(0, 1, 2) * f(x.get(0, 1, 1), x.get(0, 1, 2), x.get(0, 1, 3)), + x.get(0, 1, 3) * f(x.get(0, 1, 2), x.get(0, 1, 3)), + x.get(1, 0, 0) * f(x.get(1, 0, 0), x.get(1, 0, 1)), + x.get(1, 0, 1) * f(x.get(1, 0, 0), x.get(1, 0, 1), x.get(1, 0, 2)), + x.get(1, 0, 2) * f(x.get(1, 0, 1), x.get(1, 0, 2), x.get(1, 0, 3)), + x.get(1, 0, 3) * f(x.get(1, 0, 2), x.get(1, 0, 3)), + x.get(1, 1, 0) * f(x.get(1, 1, 0), x.get(1, 1, 1)), + x.get(1, 1, 1) * f(x.get(1, 1, 0), x.get(1, 1, 1), x.get(1, 1, 2)), + x.get(1, 1, 2) * f(x.get(1, 1, 1), x.get(1, 1, 2), x.get(1, 1, 3)), + x.get(1, 1, 3) * f(x.get(1, 1, 2), x.get(1, 1, 3)), + ]); + }); + it('yields same result as tensorflow', function () { + var input = [ + [ + [ + 0.95782757, 0.12892687, 0.63624668, 0.70160735, 0.77376258, + 0.54166114, 0.71172535, 0.65087497 + ], + [ + 0.91872108, 0.38846886, 0.37847793, 0.50477624, 0.42154622, + 0.43310916, 0.36253822, 0.07576156 + ], + [ + 0.48662257, 0.4154036, 0.81704032, 0.91660416, 0.87671542, 0.64215934, + 0.29933751, 0.90671134 + ] + ], + [ + [ + 0.6208992, 0.60847163, 0.41475761, 0.2127713, 0.65306914, 0.13923979, + 0.32003641, 0.28183973 + ], + [ + 0.04751575, 0.26870155, 0.45150304, 0.58678186, 0.99118924, + 0.58878231, 0.30913198, 0.18836617 + ], + [ + 0.16166461, 0.56322742, 0.67908955, 0.2269547, 0.38491273, 0.97113752, + 0.51210916, 0.69430435 + ] + ], + [ + [ + 0.06625497, 0.13011181, 0.59202921, 0.88871598, 0.6366322, 0.47911358, + 0.96530843, 0.74259472 + ], + [ + 0.62660718, 0.0445286, 0.18430257, 0.76863647, 0.87511849, 0.53588808, + 0.27980685, 0.30281997 + ], + [ + 0.73987067, 0.91034842, 0.26241004, 0.72832751, 0.78974342, + 0.50751543, 0.05434644, 0.8231523 + ] + ] + ]; + var expected = [ + [ + [ + 0.62630326, 0.07662392, 0.34354961, 0.41885775, 0.42621866, + 0.29751951, 0.42365381, 0.4364861 + ], + [ + 0.62828875, 0.251122, 0.23605582, 0.36483878, 0.30624411, 0.32672295, + 0.29576892, 0.06582346 + ], + [ + 0.3376624, 0.24321821, 0.42558169, 0.46646208, 0.45103404, 0.32380751, + 0.17021206, 0.59476018 + ] + ], + [ + [ + 0.44719055, 0.43318295, 0.26775005, 0.14921051, 0.49148726, + 0.10764983, 0.25084552, 0.25714993 + ], + [ + 0.04202608, 0.21094096, 0.27973703, 0.34166718, 0.57487047, + 0.35158369, 0.19708875, 0.15495601 + ], + [ + 0.12034657, 0.41341963, 0.47968671, 0.13278878, 0.22735766, + 0.57154536, 0.30411762, 0.42352781 + ] + ], + [ + [ + 0.05656794, 0.08849642, 0.36951816, 0.53186077, 0.33065733, + 0.24236222, 0.54666328, 0.45085984 + ], + [ + 0.52425432, 0.03133496, 0.11043368, 0.46954039, 0.5271349, 0.31946796, + 0.1876673, 0.25085902 + ], + [ + 0.47316891, 0.5277527, 0.13831842, 0.40036613, 0.50113004, 0.28860986, + 0.03395459, 0.59127772 + ] + ] + ]; + var x = tf.tensor3d(flatten(input), [3, 3, 8]); + var radius = 2; + var bias = 1; + var alpha = 1; + var beta = 0.5; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + test_util_1.expectArraysClose(result, flatten(expected)); + }); + it('accepts a tensor-like object', function () { + var x = [[[1, 20, 300, 4]]]; + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.5; + var result = tf.localResponseNormalization(x, radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + test_util_1.expectArraysClose(result, [ + x[0][0][0] * f(x[0][0][0], x[0][0][1]), + x[0][0][1] * f(x[0][0][0], x[0][0][1], x[0][0][2]), + x[0][0][2] * f(x[0][0][1], x[0][0][2], x[0][0][3]), + x[0][0][3] * f(x[0][0][2], x[0][0][3]), + ]); + }); +}); +jasmine_util_1.describeWithFlags('localResponseNormalization with Tensor4D', test_util_1.ALL_ENVS, function () { + it('throws error with invalid input', function () { + var x = tf.tensor2d([1, 20, 300, 4], [1, 4]); + var radius = 3; + expect(function () { return x.localResponseNormalization(radius); }).toThrowError(); + }); + it('throws error with invalid radius', function () { + var x = tf.tensor4d([1, 20, 300, 4], [1, 1, 1, 4]); + var radius = 0.5; + expect(function () { return x.localResponseNormalization(radius); }).toThrowError(); + }); + it('computes simple normalization across channels', function () { + var x = tf.tensor4d([1, 20, 300, 4, 1, 20, 300, 4], [2, 1, 1, 4]); + var radius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.5; + var result = x.localResponseNormalization(radius, bias, alpha, beta); + var f = function () { + var vals = []; + for (var _i = 0; _i < arguments.length; _i++) { + vals[_i] = arguments[_i]; + } + return Math.pow(bias + alpha * sumArr(sqArr(vals)), -beta); + }; + var b0 = 0; + var b1 = 1; + test_util_1.expectArraysClose(result, [ + x.get(b0, 0, 0, 0) * f(x.get(b0, 0, 0, 0), x.get(b0, 0, 0, 1)), + x.get(b0, 0, 0, 1) * + f(x.get(b0, 0, 0, 0), x.get(b0, 0, 0, 1), x.get(b0, 0, 0, 2)), + x.get(b0, 0, 0, 2) * + f(x.get(b0, 0, 0, 1), x.get(b0, 0, 0, 2), x.get(b0, 0, 0, 3)), + x.get(b0, 0, 0, 3) * f(x.get(b0, 0, 0, 2), x.get(b0, 0, 0, 3)), + x.get(b1, 0, 0, 0) * f(x.get(b1, 0, 0, 0), x.get(b1, 0, 0, 1)), + x.get(b1, 0, 0, 1) * + f(x.get(b1, 0, 0, 0), x.get(b1, 0, 0, 1), x.get(b1, 0, 0, 2)), + x.get(b1, 0, 0, 2) * + f(x.get(b1, 0, 0, 1), x.get(b1, 0, 0, 2), x.get(b1, 0, 0, 3)), + x.get(b1, 0, 0, 3) * f(x.get(b1, 0, 0, 2), x.get(b1, 0, 0, 3)), + ]); + }); + it('yields same result as tensorflow', function () { + var input = [ + [ + [ + [ + 0.5659827, 0.57000327, 0.75555623, 0.89843333, 0.55120194, + 0.53531718, 0.56402838, 0.95481384 + ], + [ + 0.57334661, 0.65172958, 0.75794137, 0.80764937, 0.376616, + 0.92726362, 0.36422753, 0.60535395 + ], + [ + 0.82404268, 0.01054764, 0.4649173, 0.91637003, 0.82287347, 0.043468, + 0.44953859, 0.92056584 + ] + ], + [ + [ + 0.68583369, 0.52534163, 0.53325927, 0.39608097, 0.9337523, + 0.37397444, 0.81212556, 0.5697 + ], + [ + 0.34278774, 0.57656682, 0.2356832, 0.02636456, 0.49111438, + 0.17981696, 0.65398049, 0.70132935 + ], + [ + 0.14241767, 0.68376505, 0.65419888, 0.69369483, 0.21489143, + 0.46235347, 0.0559243, 0.60612857 + ] + ], + [ + [ + 0.59678483, 0.09368539, 0.3017447, 0.36870825, 0.68145788, + 0.52048779, 0.46136606, 0.94114387 + ], + [ + 0.3156569, 0.75275254, 0.31970251, 0.3154043, 0.61088014, + 0.13359487, 0.99048364, 0.33625424 + ], + [ + 0.82103574, 0.52066624, 0.63629258, 0.42294252, 0.93214262, + 0.57041013, 0.66087878, 0.7019999 + ] + ] + ], + [ + [ + [ + 0.21894431, 0.43085241, 0.79883206, 0.19462204, 0.68623316, + 0.08703053, 0.82380795, 0.85634673 + ], + [ + 0.45011401, 0.70312083, 0.86319792, 0.83205295, 0.67109787, + 0.82081223, 0.46556532, 0.46408331 + ], + [ + 0.07028461, 0.0038743, 0.44619524, 0.0611403, 0.96373355, + 0.80561554, 0.42428243, 0.46897113 + ] + ], + [ + [ + 0.21006894, 0.48764861, 0.36842632, 0.23030031, 0.69685507, + 0.31707478, 0.68662715, 0.0639503 + ], + [ + 0.53940296, 0.50777435, 0.12625301, 0.12324154, 0.89205229, + 0.69380629, 0.33191144, 0.81000078 + ], + [ + 0.52650976, 0.71220326, 0.07246161, 0.08874547, 0.42528927, + 0.36320579, 0.54055619, 0.79342318 + ] + ], + [ + [ + 0.75916636, 0.74499428, 0.76877356, 0.87210917, 0.93040991, + 0.49491942, 0.70801985, 0.14901721 + ], + [ + 0.27037835, 0.89302075, 0.69147241, 0.23044991, 0.98916364, + 0.60161841, 0.63691151, 0.56759977 + ], + [ + 0.56307781, 0.92782414, 0.25880754, 0.98518133, 0.04097319, + 0.24640906, 0.54566145, 0.99261606 + ] + ] + ] + ]; + var expected = [ + [ + [ + [ + 0.38019636, 0.32782161, 0.414222, 0.49507114, 0.3040463, 0.28107059, + 0.33586296, 0.60191077 + ], + [ + 0.37577698, 0.37752095, 0.42895618, 0.4225589, 0.2054275, + 0.52219951, 0.23032214, 0.39414096 + ], + [ + 0.59856331, 0.00637784, 0.25168711, 0.5541048, 0.48015645, + 0.02301128, 0.27214608, 0.6427291 + ] + ], + [ + [ + 0.48127589, 0.35518789, 0.30486941, 0.23976389, 0.52926594, + 0.21061926, 0.46920502, 0.39090639 + ], + [ + 0.27937523, 0.46979892, 0.17829391, 0.02044933, 0.37045884, + 0.12140442, 0.44160855, 0.50198948 + ], + [ + 0.10289387, 0.44164398, 0.41853485, 0.42720893, 0.14580171, + 0.31817055, 0.043797, 0.48155668 + ] + ], + [ + [ + 0.49458414, 0.07425242, 0.21042404, 0.26262277, 0.46205613, + 0.30202535, 0.27406475, 0.61140078 + ], + [ + 0.23736385, 0.55076694, 0.2135559, 0.21463785, 0.38077739, + 0.08309806, 0.62830603, 0.23137885 + ], + [ + 0.5355776, 0.32740855, 0.3451882, 0.24221195, 0.51988536, + 0.31387195, 0.37391993, 0.46748781 + ] + ] + ], + [ + [ + [ + 0.16003507, 0.31178808, 0.51775187, 0.12722474, 0.40769571, + 0.05085804, 0.48455271, 0.5505302 + ], + [ + 0.2880325, 0.39714804, 0.45591024, 0.4131493, 0.34525412, 0.4554069, + 0.29119283, 0.31980222 + ], + [ + 0.0640529, 0.00352532, 0.3052578, 0.03666528, 0.56009793, + 0.46656418, 0.24587312, 0.32762629 + ] + ], + [ + [ + 0.17643087, 0.40210918, 0.2634095, 0.16233148, 0.4649446, + 0.21803913, 0.47819966, 0.05093931 + ], + [ + 0.43121469, 0.403974, 0.08191212, 0.07693455, 0.57362044, + 0.39671475, 0.19025819, 0.54028469 + ], + [ + 0.39356521, 0.53120333, 0.05151648, 0.06554616, 0.33433318, + 0.2425479, 0.36161765, 0.5536595 + ] + ], + [ + [ + 0.46011236, 0.39919043, 0.36865807, 0.43511948, 0.46734285, + 0.26861796, 0.43624333, 0.11205748 + ], + [ + 0.17642327, 0.57622254, 0.37609601, 0.12030836, 0.54640025, + 0.34052721, 0.36361033, 0.3926385 + ], + [ + 0.37581176, 0.51741964, 0.14429154, 0.57254595, 0.02646073, + 0.13531584, 0.35629693, 0.64837402 + ] + ] + ] + ]; + var x = tf.tensor4d(flatten(input), [2, 3, 3, 8]); + var radius = 2; + var result = x.localResponseNormalization(radius); + test_util_1.expectArraysClose(result, flatten(expected)); + }); + it('throws when passed a non-tensor', function () { + var e = /Argument 'x' passed to 'localResponseNormalization' must be a Tensor/; + expect(function () { return tf.localResponseNormalization({}); }) + .toThrowError(e); + }); + it('gradient with 3D input', function () { + var input = [ + [ + [ + 0.95782757, 0.12892687, 0.63624668, 0.70160735, 0.77376258, + 0.54166114, 0.71172535, 0.65087497 + ], + [ + 0.91872108, 0.38846886, 0.37847793, 0.50477624, 0.42154622, + 0.43310916, 0.36253822, 0.07576156 + ], + [ + 0.48662257, 0.4154036, 0.81704032, 0.91660416, 0.87671542, 0.64215934, + 0.29933751, 0.90671134 + ] + ], + [ + [ + 0.6208992, 0.60847163, 0.41475761, 0.2127713, 0.65306914, 0.13923979, + 0.32003641, 0.28183973 + ], + [ + 0.04751575, 0.26870155, 0.45150304, 0.58678186, 0.99118924, + 0.58878231, 0.30913198, 0.18836617 + ], + [ + 0.16166461, 0.56322742, 0.67908955, 0.2269547, 0.38491273, 0.97113752, + 0.51210916, 0.69430435 + ] + ], + [ + [ + 0.06625497, 0.13011181, 0.59202921, 0.88871598, 0.6366322, 0.47911358, + 0.96530843, 0.74259472 + ], + [ + 0.62660718, 0.0445286, 0.18430257, 0.76863647, 0.87511849, 0.53588808, + 0.27980685, 0.30281997 + ], + [ + 0.73987067, 0.91034842, 0.26241004, 0.72832751, 0.78974342, + 0.50751543, 0.05434644, 0.8231523 + ] + ] + ]; + var expected = [[ + [ + [ + 0.27552658, 0.52414668, 0.11137494, 0.24928074, 0.07215497, + 0.16210511, 0.19277242, 0.38672262 + ], + [ + 0.23314378, 0.38181645, 0.30470729, 0.35180706, 0.37793165, + 0.41450983, 0.60044503, 0.83605933 + ], + [ + 0.51801264, 0.38517883, 0.02934788, 0.03102355, 0.08222333, + 0.09746625, 0.4151727, 0.29936206 + ] + ], + [ + [ + 0.37059873, 0.32463685, 0.26611608, 0.54228389, 0.30733055, + 0.66392428, 0.55629295, 0.79049641 + ], + [ + 0.87162501, 0.68129337, 0.35793597, 0.18797961, -0.03660985, + 0.23235559, 0.48184156, 0.76417446 + ], + [ + 0.65893668, 0.41059417, 0.26254228, 0.40696776, 0.3330358, 0.01789692, + 0.3162199, 0.28867012 + ] + ], + [ + [ + 0.83880937, 0.62594998, 0.324698, 0.13046435, 0.09858654, 0.17851587, + 0.09067203, 0.30748016 + ], + [ + 0.57213897, 0.67710453, 0.45385274, 0.19951296, 0.07371041, + 0.20141563, 0.51362634, 0.7163325 + ], + [ + 0.33668244, 0.09696329, 0.33500126, 0.08948036, 0.26512182, + 0.19593786, 0.59144169, 0.379444 + ] + ] + ]]; + var radius = 2.0; + var bias = 1.0; + var alpha = 1.0; + var beta = 0.5; + var t = tf.tensor3d(input); + var dy = tf.onesLike(t); + var gradients = tf.grad(function (t) { + return tf.localResponseNormalization(t, radius, bias, alpha, beta); + })(t, dy); + test_util_1.expectArraysEqual(gradients.shape, t.shape); + test_util_1.expectArraysClose(gradients, flatten(expected)); + }); + it('gradient with 4D input', function () { + var input = [ + [ + [ + [ + 0.5659827, 0.57000327, 0.75555623, 0.89843333, 0.55120194, + 0.53531718, 0.56402838, 0.95481384 + ], + [ + 0.57334661, 0.65172958, 0.75794137, 0.80764937, 0.376616, + 0.92726362, 0.36422753, 0.60535395 + ], + [ + 0.82404268, 0.01054764, 0.4649173, 0.91637003, 0.82287347, 0.043468, + 0.44953859, 0.92056584 + ] + ], + [ + [ + 0.68583369, 0.52534163, 0.53325927, 0.39608097, 0.9337523, + 0.37397444, 0.81212556, 0.5697 + ], + [ + 0.34278774, 0.57656682, 0.2356832, 0.02636456, 0.49111438, + 0.17981696, 0.65398049, 0.70132935 + ], + [ + 0.14241767, 0.68376505, 0.65419888, 0.69369483, 0.21489143, + 0.46235347, 0.0559243, 0.60612857 + ] + ], + [ + [ + 0.59678483, 0.09368539, 0.3017447, 0.36870825, 0.68145788, + 0.52048779, 0.46136606, 0.94114387 + ], + [ + 0.3156569, 0.75275254, 0.31970251, 0.3154043, 0.61088014, + 0.13359487, 0.99048364, 0.33625424 + ], + [ + 0.82103574, 0.52066624, 0.63629258, 0.42294252, 0.93214262, + 0.57041013, 0.66087878, 0.7019999 + ] + ] + ], + [ + [ + [ + 0.21894431, 0.43085241, 0.79883206, 0.19462204, 0.68623316, + 0.08703053, 0.82380795, 0.85634673 + ], + [ + 0.45011401, 0.70312083, 0.86319792, 0.83205295, 0.67109787, + 0.82081223, 0.46556532, 0.46408331 + ], + [ + 0.07028461, 0.0038743, 0.44619524, 0.0611403, 0.96373355, + 0.80561554, 0.42428243, 0.46897113 + ] + ], + [ + [ + 0.21006894, 0.48764861, 0.36842632, 0.23030031, 0.69685507, + 0.31707478, 0.68662715, 0.0639503 + ], + [ + 0.53940296, 0.50777435, 0.12625301, 0.12324154, 0.89205229, + 0.69380629, 0.33191144, 0.81000078 + ], + [ + 0.52650976, 0.71220326, 0.07246161, 0.08874547, 0.42528927, + 0.36320579, 0.54055619, 0.79342318 + ] + ], + [ + [ + 0.75916636, 0.74499428, 0.76877356, 0.87210917, 0.93040991, + 0.49491942, 0.70801985, 0.14901721 + ], + [ + 0.27037835, 0.89302075, 0.69147241, 0.23044991, 0.98916364, + 0.60161841, 0.63691151, 0.56759977 + ], + [ + 0.56307781, 0.92782414, 0.25880754, 0.98518133, 0.04097319, + 0.24640906, 0.54566145, 0.99261606 + ] + ] + ] + ]; + var dyVals = [ + [ + [ + [ + 1.40394282, -1.68962789, -0.21134049, 1.15015793, 1.51244378, + 0.42844626, -2.70123291, 0.06449971 + ], + [ + -0.29038581, 0.67567694, 0.95617437, -1.07383668, 0.20920482, + 0.39050213, -0.81124371, 2.42158198 + ], + [ + -1.01235235, -0.63514435, -1.49017262, -0.01205151, 0.78492945, + -0.20330679, -2.31419802, -0.31220308 + ] + ], + [ + [ + 0.07061944, -0.46716127, 0.91232526, -1.30444264, -0.07080109, + 0.13207501, 0.26701283, -0.48946589 + ], + [ + -0.74995744, -0.79466617, -1.03790498, -0.32234526, 1.33345711, + 0.11863081, 1.93010819, 0.47857195 + ], + [ + 0.37702683, -0.7804451, 0.45868117, 1.06967258, -0.65336537, + 0.3594887, 0.62512684, 0.77009726 + ] + ], + [ + [ + 0.76865023, 1.00893021, -0.24408816, -0.3943336, 0.47094285, + -2.61926222, 1.52929449, 0.7862013 + ], + [ + -1.20878386, -0.26222935, -0.9076528, 0.03079577, -0.01467486, + -0.06949636, 0.05466342, 1.44880533 + ], + [ + 0.05611863, 0.15142779, 0.7802065, -1.2623471, 0.09119794, + -0.20110528, 0.17715968, -0.48476508 + ] + ] + ], + [ + [ + [ + 0.1549256, 0.94472402, -0.70033115, -1.05752802, -0.63035947, + -1.35643113, -0.27211693, 2.33576941 + ], + [ + 0.81070906, -0.58353454, -0.3253817, 2.53953528, -1.40062141, + 1.7728076, -0.59849483, 1.49650824 + ], + [ + -0.00610052, -2.29434419, -1.77995121, -0.66354084, -0.70676774, + -0.81570011, -1.30821037, 0.40997007 + ] + ], + [ + [ + -1.02013469, -0.74198806, -0.82677251, -0.00890179, -1.62196338, + -0.5095427, 1.26501179, 0.12931485 + ], + [ + -1.14763546, 0.11011696, -0.23312508, 0.29730096, -0.49138394, + -0.27012363, -0.15987533, -1.84277928 + ], + [ + -0.03816459, -0.73517877, -2.00476885, 0.47192496, -0.27395752, + 0.99806124, 1.54439747, -1.02016675 + ] + ], + [ + [ + -1.27831209, -0.6961385, -0.73713994, -1.97954738, 0.39108652, + -0.46152538, 1.8255372, 2.18119025 + ], + [ + 0.56322283, -1.59858179, 1.54127491, -0.57665956, -1.0098567, + 0.93239671, 0.25231698, -0.7346009 + ], + [ + 0.41614994, -1.20103085, 0.4330301, -1.23348403, -0.46117213, + -0.3780126, 0.35449561, -0.60129249 + ] + ] + ] + ]; + var depthRadius = 1; + var bias = 1; + var alpha = 1; + var beta = 0.75; + var expected = [ + [ + [ + [ + 0.88732064, -0.98597342, -0.00569269, 0.09561057, 0.42255375, + 0.30286378, -1.17104781, 0.44769961 + ], + [ + -0.22329885, 0.19271846, 0.41454071, -0.50674957, 0.14660946, + 0.1591837, -0.83707076, 1.19177234 + ], + [ + -0.26728818, -0.3847312, -0.72818488, 0.09040837, 0.24023688, + -0.11545581, -1.09341288, 0.33930668 + ] + ], + [ + [ + 0.10079086, -0.38184536, 0.60918945, -0.7267822, 0.13867335, + 0.03526202, 0.17270499, -0.2705338 + ], + [ + -0.38344458, -0.15589149, -0.68160093, -0.27644777, 0.79392856, + -0.14384332, 0.67121017, -0.23130262 + ], + [ + 0.31069142, -0.39895257, 0.11755499, 0.39481708, -0.5234766, + 0.2511853, 0.40955079, 0.3492966 + ] + ], + [ + [ + 0.32660595, 0.7240563, -0.18117335, -0.2649861, 0.67781603, + -1.46250272, 0.8465963, -0.05466701 + ], + [ + -0.71582067, 0.20831716, -0.50778204, 0.07256755, -0.00893679, + -0.03798783, -0.18604305, 0.75747406 + ], + [ + -0.00540833, -0.07677216, 0.41930205, -0.69235319, 0.20631291, + -0.11946303, 0.19601521, -0.21237698 + ] + ] + ], + [ + [ + [ + 0.0800111, 0.60922205, -0.31155977, -0.46448132, -0.15912701, + -0.72455585, -0.5727275, 0.71780092 + ], + [ + 0.50568235, -0.31544152, -0.40618286, 0.97909468, -1.15286613, + 0.8145386, -0.77758539, 0.93794745 + ], + [ + -0.00535599, -1.99269259, -1.15343952, -0.31053686, 0.01680636, + 0.10109296, -0.66026396, 0.35474917 + ] + ], + [ + [ + -0.74113333, -0.20625943, -0.4339568, 0.21517368, -0.5734458, + -0.23481363, 0.53855389, 0.05860626 + ], + [ + -0.61435795, 0.29290834, -0.19639145, 0.20930134, -0.08880179, + 0.02209887, 0.21427482, -0.51696646 + ], + [ + 0.13036536, -0.19079237, -1.43941545, 0.42789665, -0.29732707, + 0.52354813, 0.78893, -0.59992862 + ] + ], + [ + [ + -0.328383, 0.15830949, 0.13110149, -0.492423, 0.46827313, + -0.58950633, 0.56422544, 1.44929576 + ], + [ + 0.46141064, -0.80682266, 0.92562175, -0.28897452, -0.30567497, + 0.50646484, 0.16439518, -0.38878182 + ], + [ + 0.41004074, -0.38593128, 0.42881966, -0.22443436, -0.24573228, + -0.2941249, 0.31119603, -0.17903978 + ] + ] + ] + ]; + var t = tf.tensor(input); + var dy = tf.tensor(dyVals); + var gradients = tf.grad(function (t) { return tf.localResponseNormalization(t, depthRadius, bias, alpha, beta); })(t, dy); + test_util_1.expectArraysClose(gradients, flatten(expected)); + }); +}); +//# sourceMappingURL=lrn_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js.map new file mode 100644 index 0000000..6680bf8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lrn_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lrn_test.js","sourceRoot":"","sources":["../../src/ops/lrn_test.ts"],"names":[],"mappings":"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E,CAAC,EAAE,CAAC,CAAC,CAAC;YAGlD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAGlD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAGlD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClD,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,C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G,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YACjE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAE9D,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9D,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;gBACd,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YACjE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;gBACd,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YACjE,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,E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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.d.ts new file mode 100644 index 0000000..96cdc6c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.d.ts @@ -0,0 +1,10 @@ +import { Scalar, Tensor1D, Tensor2D } from '../tensor'; +import { TensorLike } from '../types'; +export declare type LSTMCellFunc = { + (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D]; +}; +declare function multiRNNCell_(lstmCells: LSTMCellFunc[], data: Tensor2D | TensorLike, c: Tensor2D[] | TensorLike[], h: Tensor2D[] | TensorLike[]): [Tensor2D[], Tensor2D[]]; +declare function basicLSTMCell_(forgetBias: Scalar | TensorLike, lstmKernel: Tensor2D | TensorLike, lstmBias: Tensor1D | TensorLike, data: Tensor2D | TensorLike, c: Tensor2D | TensorLike, h: Tensor2D | TensorLike): [Tensor2D, Tensor2D]; +export declare const basicLSTMCell: typeof basicLSTMCell_; +export declare const multiRNNCell: typeof multiRNNCell_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js new file mode 100644 index 0000000..3dcc92d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js @@ -0,0 +1,48 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_util_env_1 = require("../tensor_util_env"); +var operation_1 = require("./operation"); +function multiRNNCell_(lstmCells, data, c, h) { + var $data = tensor_util_env_1.convertToTensor(data, 'data', 'multiRNNCell'); + var $c = tensor_util_env_1.convertToTensorArray(c, 'c', 'multiRNNCell'); + var $h = tensor_util_env_1.convertToTensorArray(h, 'h', 'multiRNNCell'); + var input = $data; + var newStates = []; + for (var i = 0; i < lstmCells.length; i++) { + var output = lstmCells[i](input, $c[i], $h[i]); + newStates.push(output[0]); + newStates.push(output[1]); + input = output[1]; + } + var newC = []; + var newH = []; + for (var i = 0; i < newStates.length; i += 2) { + newC.push(newStates[i]); + newH.push(newStates[i + 1]); + } + return [newC, newH]; +} +function basicLSTMCell_(forgetBias, lstmKernel, lstmBias, data, c, h) { + var $forgetBias = tensor_util_env_1.convertToTensor(forgetBias, 'forgetBias', 'basicLSTMCell'); + var $lstmKernel = tensor_util_env_1.convertToTensor(lstmKernel, 'lstmKernel', 'basicLSTMCell'); + var $lstmBias = tensor_util_env_1.convertToTensor(lstmBias, 'lstmBias', 'basicLSTMCell'); + var $data = tensor_util_env_1.convertToTensor(data, 'data', 'basicLSTMCell'); + var $c = tensor_util_env_1.convertToTensor(c, 'c', 'basicLSTMCell'); + var $h = tensor_util_env_1.convertToTensor(h, 'h', 'basicLSTMCell'); + var combined = $data.concat($h, 1); + var weighted = combined.matMul($lstmKernel); + var res = weighted.add($lstmBias); + var batchSize = res.shape[0]; + var sliceCols = res.shape[1] / 4; + var sliceSize = [batchSize, sliceCols]; + var i = res.slice([0, 0], sliceSize); + var j = res.slice([0, sliceCols], sliceSize); + var f = res.slice([0, sliceCols * 2], sliceSize); + var o = res.slice([0, sliceCols * 3], sliceSize); + var newC = i.sigmoid().mulStrict(j.tanh()).addStrict($c.mulStrict($forgetBias.add(f).sigmoid())); + var newH = newC.tanh().mulStrict(o.sigmoid()); + return [newC, newH]; +} +exports.basicLSTMCell = operation_1.op({ basicLSTMCell_: basicLSTMCell_ }); +exports.multiRNNCell = operation_1.op({ multiRNNCell_: multiRNNCell_ }); +//# sourceMappingURL=lstm.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js.map new file mode 100644 index 0000000..f3bec61 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lstm.js","sourceRoot":"","sources":["../../src/ops/lstm.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js new file mode 100644 index 0000000..1d7e5b6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js @@ -0,0 +1,209 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('lstm', test_util_1.ALL_ENVS, function () { + it('MultiRNNCell with 2 BasicLSTMCells', function () { + var lstmKernel1 = tf.tensor2d([ + 0.26242125034332275, -0.8787832260131836, 0.781475305557251, + 1.337337851524353, 0.6180247068405151, -0.2760246992111206, + -0.11299663782119751, -0.46332040429115295, -0.1765323281288147, + 0.6807947158813477, -0.8326982855796814, 0.6732975244522095 + ], [3, 4]); + var lstmBias1 = tf.tensor1d([1.090713620185852, -0.8282332420349121, 0, 1.0889357328414917]); + var lstmKernel2 = tf.tensor2d([ + -1.893059492111206, -1.0185645818710327, -0.6270437240600586, + -2.1829540729522705, -0.4583775997161865, -0.5454602241516113, + -0.3114445209503174, 0.8450229167938232 + ], [2, 4]); + var lstmBias2 = tf.tensor1d([0.9906240105628967, 0.6248329877853394, 0, 1.0224634408950806]); + var forgetBias = tf.scalar(1.0); + var lstm1 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel1, lstmBias1, data, c, h); + }; + var lstm2 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel2, lstmBias2, data, c, h); + }; + var c = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + var h = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + var onehot = tf.buffer([1, 2], 'float32'); + onehot.set(1.0, 0, 0); + var output = tf.multiRNNCell([lstm1, lstm2], onehot.toTensor(), c, h); + test_util_1.expectArraysClose(output[0][0], [-0.7440074682235718]); + test_util_1.expectArraysClose(output[0][1], [0.7460772395133972]); + test_util_1.expectArraysClose(output[1][0], [-0.5802832245826721]); + test_util_1.expectArraysClose(output[1][1], [0.5745711922645569]); + }); + it('basicLSTMCell with batch=2', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = tf.randomNormal([4]); + var forgetBias = tf.scalar(1.0); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + var _a = tf.basicLSTMCell(forgetBias, lstmKernel, lstmBias, batchedData, batchedC, batchedH), newC = _a[0], newH = _a[1]; + expect(newC.get(0, 0)).toEqual(newC.get(1, 0)); + expect(newH.get(0, 0)).toEqual(newH.get(1, 0)); + }); + it('basicLSTMCell accepts a tensor-like object', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = [0, 0, 0, 0]; + var forgetBias = 1; + var data = [[0, 0]]; + var batchedData = tf.concat2d([data, data], 0); + var c = [[0]]; + var batchedC = tf.concat2d([c, c], 0); + var h = [[0]]; + var batchedH = tf.concat2d([h, h], 0); + var _a = tf.basicLSTMCell(forgetBias, lstmKernel, lstmBias, batchedData, batchedC, batchedH), newC = _a[0], newH = _a[1]; + expect(newC.get(0, 0)).toEqual(newC.get(1, 0)); + expect(newH.get(0, 0)).toEqual(newH.get(1, 0)); + }); +}); +jasmine_util_1.describeWithFlags('multiRNN throws when passed non-tensor', test_util_1.ALL_ENVS, function () { + it('input: data', function () { + var lstmKernel1 = tf.zeros([3, 4]); + var lstmBias1 = tf.zeros([4]); + var lstmKernel2 = tf.zeros([2, 4]); + var lstmBias2 = tf.zeros([4]); + var forgetBias = tf.scalar(1.0); + var lstm1 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel1, lstmBias1, data, c, h); + }; + var lstm2 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel2, lstmBias2, data, c, h); + }; + var c = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + var h = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + expect(function () { return tf.multiRNNCell([lstm1, lstm2], {}, c, h); }) + .toThrowError(/Argument 'data' passed to 'multiRNNCell' must be a Tensor/); + }); + it('input: c', function () { + var lstmKernel1 = tf.zeros([3, 4]); + var lstmBias1 = tf.zeros([4]); + var lstmKernel2 = tf.zeros([2, 4]); + var lstmBias2 = tf.zeros([4]); + var forgetBias = tf.scalar(1.0); + var lstm1 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel1, lstmBias1, data, c, h); + }; + var lstm2 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel2, lstmBias2, data, c, h); + }; + var h = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + var data = tf.zeros([1, 2]); + expect(function () { return tf.multiRNNCell([lstm1, lstm2], data, [{}], h); }) + .toThrowError(/Argument 'c\[0\]' passed to 'multiRNNCell' must be a Tensor/); + }); + it('input: h', function () { + var lstmKernel1 = tf.zeros([3, 4]); + var lstmBias1 = tf.zeros([4]); + var lstmKernel2 = tf.zeros([2, 4]); + var lstmBias2 = tf.zeros([4]); + var forgetBias = tf.scalar(1.0); + var lstm1 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel1, lstmBias1, data, c, h); + }; + var lstm2 = function (data, c, h) { + return tf.basicLSTMCell(forgetBias, lstmKernel2, lstmBias2, data, c, h); + }; + var c = [ + tf.zeros([1, lstmBias1.shape[0] / 4]), + tf.zeros([1, lstmBias2.shape[0] / 4]) + ]; + var data = tf.zeros([1, 2]); + expect(function () { return tf.multiRNNCell([lstm1, lstm2], data, c, [{}]); }) + .toThrowError(/Argument 'h\[0\]' passed to 'multiRNNCell' must be a Tensor/); + }); +}); +jasmine_util_1.describeWithFlags('basicLSTMCell throws with non-tensor', test_util_1.ALL_ENVS, function () { + it('input: forgetBias', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = tf.randomNormal([4]); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + expect(function () { return tf.basicLSTMCell({}, lstmKernel, lstmBias, batchedData, batchedC, batchedH); }) + .toThrowError(/Argument 'forgetBias' passed to 'basicLSTMCell' must be a Tensor/); + }); + it('input: lstmKernel', function () { + var lstmBias = tf.randomNormal([4]); + var forgetBias = tf.scalar(1.0); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + expect(function () { return tf.basicLSTMCell(forgetBias, {}, lstmBias, batchedData, batchedC, batchedH); }) + .toThrowError(/Argument 'lstmKernel' passed to 'basicLSTMCell' must be a Tensor/); + }); + it('input: lstmBias', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var forgetBias = tf.scalar(1.0); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + expect(function () { return tf.basicLSTMCell(forgetBias, lstmKernel, {}, batchedData, batchedC, batchedH); }) + .toThrowError(/Argument 'lstmBias' passed to 'basicLSTMCell' must be a Tensor/); + }); + it('input: data', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = tf.randomNormal([4]); + var forgetBias = tf.scalar(1.0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + expect(function () { return tf.basicLSTMCell(forgetBias, lstmKernel, lstmBias, {}, batchedC, batchedH); }) + .toThrowError(/Argument 'data' passed to 'basicLSTMCell' must be a Tensor/); + }); + it('input: c', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = tf.randomNormal([4]); + var forgetBias = tf.scalar(1.0); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var h = tf.randomNormal([1, 1]); + var batchedH = tf.concat2d([h, h], 0); + expect(function () { return tf.basicLSTMCell(forgetBias, lstmKernel, lstmBias, batchedData, {}, batchedH); }) + .toThrowError(/Argument 'c' passed to 'basicLSTMCell' must be a Tensor/); + }); + it('input: h', function () { + var lstmKernel = tf.randomNormal([3, 4]); + var lstmBias = tf.randomNormal([4]); + var forgetBias = tf.scalar(1.0); + var data = tf.randomNormal([1, 2]); + var batchedData = tf.concat2d([data, data], 0); + var c = tf.randomNormal([1, 1]); + var batchedC = tf.concat2d([c, c], 0); + expect(function () { return tf.basicLSTMCell(forgetBias, lstmKernel, lstmBias, batchedData, batchedC, {}); }) + .toThrowError(/Argument 'h' passed to 'basicLSTMCell' must be a Tensor/); + }); +}); +//# sourceMappingURL=lstm_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js.map new file mode 100644 index 0000000..6a997a1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/lstm_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"lstm_test.js","sourceRoot":"","sources":["../../src/ops/lstm_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.d.ts new file mode 100644 index 0000000..380803d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.d.ts @@ -0,0 +1,9 @@ +import { Tensor, Tensor1D, Tensor2D } from '../tensor'; +import { TensorLike } from '../types'; +declare function matMul_(a: Tensor2D | TensorLike, b: Tensor2D | TensorLike, transposeA?: boolean, transposeB?: boolean): Tensor2D; +declare function outerProduct_(v1: Tensor1D | TensorLike, v2: Tensor1D | TensorLike): Tensor2D; +declare function dot_(t1: Tensor | TensorLike, t2: Tensor | TensorLike): Tensor; +export declare const matMul: typeof matMul_; +export declare const dot: typeof dot_; +export declare const outerProduct: typeof outerProduct_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js new file mode 100644 index 0000000..89c8f04 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js @@ -0,0 +1,80 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var operation_1 = require("./operation"); +function matMul_(a, b, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + var $a = tensor_util_env_1.convertToTensor(a, 'a', 'matMul'); + var $b = tensor_util_env_1.convertToTensor(b, 'b', 'matMul'); + var innerShapeA = transposeA ? $a.shape[0] : $a.shape[1]; + var innerShapeB = transposeB ? $b.shape[1] : $b.shape[0]; + util.assert($a.rank === 2 && $b.rank === 2, "Error in matMul: inputs must be rank 2, got ranks " + $a.rank + + (" and " + $b.rank + ".")); + util.assert(innerShapeA === innerShapeB, "Error in matMul: inner shapes (" + innerShapeA + ") and (" + + (innerShapeB + ") of Tensors with shapes " + $a.shape + " and ") + + ($b.shape + " and transposeA=" + transposeA) + + (" and transposeB=" + transposeB + " must match.")); + var grad = function (dy) { + if (!transposeA && !transposeB) { + return { + $a: function () { return dy.matMul($b.toFloat(), false, true); }, + $b: function () { return $a.toFloat().matMul(dy, true, false); } + }; + } + else if (!transposeA && transposeB) { + return { + $a: function () { return dy.matMul($b.toFloat(), false, false); }, + $b: function () { return dy.matMul($a.toFloat(), true, false); } + }; + } + else if (transposeA && !transposeB) { + return { + $a: function () { return $b.toFloat().matMul(dy, false, true); }, + $b: function () { return $a.toFloat().matMul(dy, false, false); } + }; + } + else { + return { + $a: function () { return $b.toFloat().matMul(dy, true, true); }, + $b: function () { return dy.matMul($a.toFloat(), true, true); } + }; + } + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.matMul($a, $b, transposeA, transposeB); }, { $a: $a, $b: $b }, grad); +} +function outerProduct_(v1, v2) { + var $v1 = tensor_util_env_1.convertToTensor(v1, 'v1', 'outerProduct'); + var $v2 = tensor_util_env_1.convertToTensor(v2, 'v2', 'outerProduct'); + util.assert($v1.rank === 1 && $v2.rank === 1, "Error in outerProduct: inputs must be rank 1, but got ranks " + + ($v1.rank + " and " + $v2.rank + ".")); + return $v1.as2D(-1, 1).matMul($v2.as2D(1, -1)); +} +function dot_(t1, t2) { + var $t1 = tensor_util_env_1.convertToTensor(t1, 't1', 'dot'); + var $t2 = tensor_util_env_1.convertToTensor(t2, 't2', 'dot'); + util.assert(($t1.rank === 1 || $t1.rank === 2) && ($t2.rank === 1 || $t2.rank === 2), "Error in dot: inputs must all be rank 1 or 2, but got ranks " + + ($t1.rank + " and " + $t2.rank + ".")); + var t1Inner = ($t1.rank === 1 ? $t1.size : $t1.shape[1]); + var t2Inner = ($t2.rank === 1 ? $t2.size : $t2.shape[0]); + util.assert(t1Inner === t2Inner, "Error in dot: inner dimensions of inputs must match, but got " + + (t1Inner + " and " + t2Inner + ".")); + if ($t1.rank === 1 && $t2.rank === 1) { + return $t1.as2D(1, -1).matMul($t2.as2D(-1, 1)).asScalar(); + } + else if ($t1.rank === 1 && $t2.rank === 2) { + return $t1.as2D(1, -1).matMul($t2.as2D($t2.shape[0], $t2.shape[1])).as1D(); + } + else if ($t1.rank === 2 && $t2.rank === 1) { + return $t1.matMul($t2.as2D(-1, 1)).as1D(); + } + else { + return $t1.matMul($t2.as2D($t2.shape[0], $t2.shape[1])); + } +} +exports.matMul = operation_1.op({ matMul_: matMul_ }); +exports.dot = operation_1.op({ dot_: dot_ }); +exports.outerProduct = operation_1.op({ outerProduct_: outerProduct_ }); +//# sourceMappingURL=matmul.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js.map new file mode 100644 index 0000000..f1e3fe6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul.js.map @@ -0,0 +1 @@ +{"version":3,"file":"matmul.js","sourceRoot":"","sources":["../../src/ops/matmul.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js new file mode 100644 index 0000000..2788bdd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js @@ -0,0 +1,362 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('matmul', test_util_1.ALL_ENVS, function () { + it('A x B', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([0, 1, -3, 2, 2, 1], [3, 2]); + var c = tf.matMul(a, b); + expect(c.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(c, [0, 8, -3, 20]); + }); + it('A x B^t', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([1, 0, 2, 4, 3, 0], [2, 3]); + var transposeA = false; + var transposeB = true; + var c = tf.matMul(a, b, transposeA, transposeB); + var expected = [7, 10, 16, 31]; + test_util_1.expectArraysClose(c, expected); + }); + it('A^t x B', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([1, 0, 2, 4, 3, 0], [2, 3]); + var transposeA = true; + var transposeB = false; + var c = tf.matMul(a, b, transposeA, transposeB); + var expected = [17, 12, 2, 22, 15, 4, 27, 18, 6]; + test_util_1.expectArraysClose(c, expected); + }); + it('A^t x B^t', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [3, 2]); + var b = tf.tensor2d([1, 0, 2, 4, 3, 0], [2, 3]); + var transposeA = true; + var transposeB = true; + var c = tf.matMul(a, b, transposeA, transposeB); + var expected = [11, 13, 14, 20]; + test_util_1.expectArraysClose(c, expected); + }); + it('A x B^t shapes do not match', function () { + var a = tf.zeros([2, 3]); + var b = tf.zeros([3, 2]); + var f = function () { + var transposeA = false; + var transposeB = true; + tf.matMul(a, b, transposeA, transposeB); + }; + expect(f).toThrowError(); + }); + it('A^t x B shapes do not match', function () { + var a = tf.zeros([2, 3]); + var b = tf.zeros([3, 2]); + var f = function () { + var transposeA = true; + var transposeB = false; + tf.matMul(a, b, transposeA, transposeB); + }; + expect(f).toThrowError(); + }); + it('A^t x B^t shapes do not match', function () { + var a = tf.zeros([3, 2]); + var b = tf.zeros([3, 2]); + var f = function () { + var transposeA = true; + var transposeB = true; + tf.matMul(a, b, transposeA, transposeB); + }; + expect(f).toThrowError(); + }); + it('matmul throws when inner dimensions dont match', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = tf.tensor2d([0, 1, -3, 2, 2, 1, 2, 2], [4, 2]); + expect(function () { return tf.matMul(a, b); }).toThrowError(); + }); + it('matmul throws when passed non matrices', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var b = tf.tensor2d([0, 1, -3, 2, 2, 1, 2, 2], [4, 2]); + expect(function () { return tf.matMul(a, b); }).toThrowError(); + expect(function () { return tf.matMul(b, a); }).toThrowError(); + }); + it('Vector times matrix', function () { + var v = tf.tensor1d([2, 3]); + var matrix = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var result = tf.dot(v, matrix); + var expected = [11, 16]; + test_util_1.expectArraysClose(result, expected); + }); + it('Vector times matrix with implicit reshape', function () { + var v = tf.tensor1d([2, 3]); + var matrix = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var result = tf.dot(v, matrix); + var expected = [11, 16]; + test_util_1.expectArraysClose(result, expected); + }); + it('Matrix times vector', function () { + var matrix = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var v = tf.tensor1d([2, 3]); + var result = tf.dot(matrix, v); + var expected = [8, 18]; + test_util_1.expectArraysClose(result, expected); + }); + it('Matrix * vector propagates NaNs', function () { + var matrix = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var v = tf.tensor1d([2, NaN]); + var result = tf.dot(matrix, v); + var expected = [NaN, NaN]; + test_util_1.expectArraysClose(result, expected); + }); + it('matrix times vector throws when not passed a matrix', function () { + var v = tf.tensor1d([2, 3]); + var matrix = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + expect(function () { return tf.dot(matrix, v); }).toThrowError(); + }); + it('Dot product', function () { + var v1 = tf.tensor1d([2, 3]); + var v2 = tf.tensor1d([2, 1]); + var result = tf.dot(v1, v2); + test_util_1.expectNumbersClose(result.get(), 7); + }); + it('Dot product propagates NaNs', function () { + var v1 = tf.tensor1d([2, NaN]); + var v2 = tf.tensor1d([2, 1]); + var result = tf.dot(v1, v2); + expect(result.get()).toEqual(NaN); + }); + it('Dot product throws when vectors are different size', function () { + var v1 = tf.tensor1d([2, 3, 3]); + var v2 = tf.tensor1d([2, 1]); + expect(function () { return tf.dot(v1, v2); }).toThrowError(); + expect(function () { return tf.dot(v2, v1); }).toThrowError(); + }); + it('Outer product', function () { + var v1 = tf.tensor1d([2, 3]); + var v2 = tf.tensor1d([2, 1]); + var result = tf.outerProduct(v1, v2); + var expected = [4, 2, 6, 3]; + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('outer product accepts a tensor-like object', function () { + var v1 = [2, 3]; + var v2 = [2, 1]; + var result = tf.outerProduct(v1, v2); + var expected = [4, 2, 6, 3]; + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, expected); + }); + it('gradients: A * B', function () { + var a = tf.tensor2d([1, 2, 3, 10, 20, 30], [2, 3]); + var b = tf.tensor2d([2, 3, 4, 1, 2, 3], [3, 2]); + var dy = tf.tensor2d([1, 10, 20, 30], [2, 2]); + var transposeA = false; + var transposeB = false; + var grads = tf.grads(function (a, b) { + return tf.matMul(a, b, transposeA, transposeB); + }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + test_util_1.expectArraysClose(da, [ + dy.get(0, 0) * b.get(0, 0) + dy.get(0, 1) * b.get(0, 1), + dy.get(0, 0) * b.get(1, 0) + dy.get(0, 1) * b.get(1, 1), + dy.get(0, 0) * b.get(2, 0) + dy.get(0, 1) * b.get(2, 1), + dy.get(1, 0) * b.get(0, 0) + dy.get(1, 1) * b.get(0, 1), + dy.get(1, 0) * b.get(1, 0) + dy.get(1, 1) * b.get(1, 1), + dy.get(1, 0) * b.get(2, 0) + dy.get(1, 1) * b.get(2, 1) + ], 1e-1); + expect(db.shape).toEqual(b.shape); + test_util_1.expectArraysClose(db, [ + a.get(0, 0) * dy.get(0, 0) + a.get(1, 0) * dy.get(1, 0), + a.get(0, 0) * dy.get(0, 1) + a.get(1, 0) * dy.get(1, 1), + a.get(0, 1) * dy.get(0, 0) + a.get(1, 1) * dy.get(1, 0), + a.get(0, 1) * dy.get(0, 1) + a.get(1, 1) * dy.get(1, 1), + a.get(0, 2) * dy.get(0, 0) + a.get(1, 2) * dy.get(1, 0), + a.get(0, 2) * dy.get(0, 1) + a.get(1, 2) * dy.get(1, 1) + ]); + }); + it('gradients: a * bT', function () { + var a = tf.tensor2d([1, 2, 3, 10, 20, 30], [3, 2]); + var b = tf.tensor2d([2, 3, 4, 1, 2, 3], [3, 2]); + var dy = tf.tensor2d([1, 10, 20, 30, 40, 50, 60, 70, 80], [3, 3]); + var transposeA = false; + var transposeB = true; + var grads = tf.grads(function (a, b) { + return tf.matMul(a, b, transposeA, transposeB); + }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + test_util_1.expectArraysClose(da, [ + dy.get(0, 0) * b.get(0, 0) + dy.get(0, 1) * b.get(1, 0) + + dy.get(0, 2) * b.get(2, 0), + dy.get(0, 0) * b.get(0, 1) + dy.get(0, 1) * b.get(1, 1) + + dy.get(0, 2) * b.get(2, 1), + dy.get(1, 0) * b.get(0, 0) + dy.get(1, 1) * b.get(1, 0) + + dy.get(1, 2) * b.get(2, 0), + dy.get(1, 0) * b.get(0, 1) + dy.get(1, 1) * b.get(1, 1) + + dy.get(1, 2) * b.get(2, 1), + dy.get(2, 0) * b.get(0, 0) + dy.get(2, 1) * b.get(1, 0) + + dy.get(2, 2) * b.get(2, 0), + dy.get(2, 0) * b.get(0, 1) + dy.get(2, 1) * b.get(1, 1) + + dy.get(2, 2) * b.get(2, 1) + ]); + expect(db.shape).toEqual(b.shape); + test_util_1.expectArraysClose(db, [ + dy.get(0, 0) * a.get(0, 0) + dy.get(1, 0) * a.get(1, 0) + + dy.get(2, 0) * a.get(2, 0), + dy.get(0, 0) * a.get(0, 1) + dy.get(1, 0) * a.get(1, 1) + + dy.get(2, 0) * a.get(2, 1), + dy.get(0, 1) * a.get(0, 0) + dy.get(1, 1) * a.get(1, 0) + + dy.get(2, 1) * a.get(2, 0), + dy.get(0, 1) * a.get(0, 1) + dy.get(1, 1) * a.get(1, 1) + + dy.get(2, 1) * a.get(2, 1), + dy.get(0, 2) * a.get(0, 0) + dy.get(1, 2) * a.get(1, 0) + + dy.get(2, 2) * a.get(2, 0), + dy.get(0, 2) * a.get(0, 1) + dy.get(1, 2) * a.get(1, 1) + + dy.get(2, 2) * a.get(2, 1) + ]); + }); + it('gradients: aT * b', function () { + var a = tf.tensor2d([1, 2, 3, 10, 20, 30], [3, 2]); + var b = tf.tensor2d([2, 3, 4, 1, 2, 3], [3, 2]); + var dy = tf.tensor2d([1, 10, 20, 30], [2, 2]); + var transposeA = true; + var transposeB = false; + var grads = tf.grads(function (a, b) { + return tf.matMul(a, b, transposeA, transposeB); + }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + test_util_1.expectArraysClose(da, [ + dy.get(0, 0) * b.get(0, 0) + dy.get(0, 1) * b.get(0, 1), + dy.get(1, 0) * b.get(0, 0) + dy.get(1, 1) * b.get(0, 1), + dy.get(0, 0) * b.get(1, 0) + dy.get(0, 1) * b.get(1, 1), + dy.get(1, 0) * b.get(1, 0) + dy.get(1, 1) * b.get(1, 1), + dy.get(0, 0) * b.get(2, 0) + dy.get(0, 1) * b.get(2, 1), + dy.get(1, 0) * b.get(2, 0) + dy.get(1, 1) * b.get(2, 1) + ]); + expect(db.shape).toEqual(b.shape); + test_util_1.expectArraysClose(db, [ + dy.get(0, 0) * a.get(0, 0) + dy.get(1, 0) * a.get(0, 1), + dy.get(0, 1) * a.get(0, 0) + dy.get(1, 1) * a.get(0, 1), + dy.get(0, 0) * a.get(1, 0) + dy.get(1, 0) * a.get(1, 1), + dy.get(0, 1) * a.get(1, 0) + dy.get(1, 1) * a.get(1, 1), + dy.get(0, 0) * a.get(2, 0) + dy.get(1, 0) * a.get(2, 1), + dy.get(0, 1) * a.get(2, 0) + dy.get(1, 1) * a.get(2, 1) + ]); + }); + it('gradients: aT * bT', function () { + var a = tf.tensor2d([1, 2, 3, 10, 20, 30], [3, 2]); + var b = tf.tensor2d([2, 3, 4, 1, 2, 3], [2, 3]); + var dy = tf.tensor2d([1, 10, 20, 30], [2, 2]); + var transposeA = true; + var transposeB = true; + var grads = tf.grads(function (a, b) { + return tf.matMul(a, b, transposeA, transposeB); + }); + var _a = grads([a, b], dy), da = _a[0], db = _a[1]; + expect(da.shape).toEqual(a.shape); + test_util_1.expectArraysClose(da, [ + dy.get(0, 0) * b.get(0, 0) + dy.get(0, 1) * b.get(1, 0), + dy.get(1, 0) * b.get(0, 0) + dy.get(1, 1) * b.get(1, 0), + dy.get(0, 0) * b.get(0, 1) + dy.get(0, 1) * b.get(1, 1), + dy.get(1, 0) * b.get(0, 1) + dy.get(1, 1) * b.get(1, 1), + dy.get(0, 0) * b.get(0, 2) + dy.get(0, 1) * b.get(1, 2), + dy.get(1, 0) * b.get(0, 2) + dy.get(1, 1) * b.get(1, 2) + ]); + expect(db.shape).toEqual(b.shape); + test_util_1.expectArraysClose(db, [ + dy.get(0, 0) * a.get(0, 0) + dy.get(1, 0) * a.get(0, 1), + dy.get(0, 0) * a.get(1, 0) + dy.get(1, 0) * a.get(1, 1), + dy.get(0, 0) * a.get(2, 0) + dy.get(1, 0) * a.get(2, 1), + dy.get(0, 1) * a.get(0, 0) + dy.get(1, 1) * a.get(0, 1), + dy.get(0, 1) * a.get(1, 0) + dy.get(1, 1) * a.get(1, 1), + dy.get(0, 1) * a.get(2, 0) + dy.get(1, 1) * a.get(2, 1) + ]); + }); + it('throws when passed a as a non-tensor', function () { + expect(function () { return tf.matMul({}, tf.tensor2d([2], [1, 1])); }) + .toThrowError(/Argument 'a' passed to 'matMul' must be a Tensor/); + }); + it('throws when passed b as a non-tensor', function () { + expect(function () { return tf.matMul(tf.tensor2d([2], [1, 1]), {}); }) + .toThrowError(/Argument 'b' passed to 'matMul' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[1, 2, 3], [4, 5, 6]]; + var b = [[0, 1], [-3, 2], [2, 1]]; + var c = tf.matMul(a, b); + expect(c.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(c, [0, 8, -3, 20]); + }); +}); +jasmine_util_1.describeWithFlags('matmul webgl-only', test_util_1.WEBGL_ENVS, function () { + it('Matrix times vector, large matrix', function () { + var maxTexSize = 16000; + var sharedDim = maxTexSize + 4; + var matrix = tf.buffer([2, sharedDim], 'float32'); + matrix.set(1, 0, sharedDim - 3); + matrix.set(1, 0, sharedDim - 2); + var v = tf.buffer([sharedDim], 'float32'); + v.set(1, sharedDim - 3); + v.set(1, sharedDim - 2); + var result = tf.dot(matrix.toTensor(), v.toTensor()); + var expected = [2, 0]; + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('dot', test_util_1.ALL_ENVS, function () { + var a; + var b; + var c; + var d; + var e; + beforeEach(function () { + a = tf.tensor1d([1, 2]); + b = tf.tensor2d([[1, 2], [3, 4]]); + c = tf.tensor2d([[1, 2, 3], [4, 5, 6]]); + d = tf.tensor3d([1, 2], [1, 1, 2]); + e = tf.scalar(1); + }); + it('vector-vector', function () { + var aa = tf.dot(a, a); + test_util_1.expectArraysClose(aa, [5]); + expect(aa.shape).toEqual([]); + }); + it('vector-matrix', function () { + var ab = tf.dot(a, b); + var ac = tf.dot(a, c); + expect(ab.shape).toEqual([2]); + expect(ac.shape).toEqual([3]); + test_util_1.expectArraysClose(ab, [7, 10]); + test_util_1.expectArraysClose(ac, [9, 12, 15]); + }); + it('matrix-vector', function () { + var ba = b.dot(a); + expect(ba.shape).toEqual([2]); + test_util_1.expectArraysClose(ba, [5, 11]); + }); + it('matrix-matrix', function () { + var bb = tf.dot(b, b); + var bc = tf.dot(b, c); + expect(bb.shape).toEqual([2, 2]); + expect(bc.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(bb, [7, 10, 15, 22]); + test_util_1.expectArraysClose(bc, [9, 12, 15, 19, 26, 33]); + }); + it('throws error on incompatible dimensions', function () { + expect(function () { return tf.dot(c, a); }).toThrowError(); + expect(function () { return tf.dot(c, b); }).toThrowError(); + }); + it('throws error when inputs are not rank 1 or 2', function () { + expect(function () { return tf.dot(a, d); }).toThrowError(); + expect(function () { return tf.dot(a, e); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var a = [1, 2, 3]; + var res = tf.dot(a, a); + test_util_1.expectArraysClose(res, [14]); + expect(res.shape).toEqual([]); + }); +}); +//# sourceMappingURL=matmul_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js.map new file mode 100644 index 0000000..024461c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/matmul_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"matmul_test.js","sourceRoot":"","sources":["../../src/ops/matmul_test.ts"],"names":[],"mappings":"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,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;gBACnD,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC9B,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;gBACnD,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC9B,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;gBACnD,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC9B,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;gBACnD,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC9B,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CA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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.d.ts new file mode 100644 index 0000000..6683208 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.d.ts @@ -0,0 +1,5 @@ +import { Scalar, Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function movingAverage_(v: T | TensorLike, x: T | TensorLike, decay: number | Scalar, step?: number | Scalar, zeroDebias?: boolean): T; +export declare const movingAverage: typeof movingAverage_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js new file mode 100644 index 0000000..4ea2c06 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js @@ -0,0 +1,27 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_util_1 = require("../tensor_util"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var binary_ops_1 = require("./binary_ops"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function movingAverage_(v, x, decay, step, zeroDebias) { + if (zeroDebias === void 0) { zeroDebias = true; } + var $v = tensor_util_env_1.convertToTensor(v, 'v', 'movingAverage'); + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'movingAverage'); + var $decay = tensor_util_env_1.convertToTensor(decay, 'decay', 'movingAverage'); + tensor_util_1.assertTypesMatch($v, $x); + util.assert(util.arraysEqual($v.shape, $x.shape), 'Shape mismatch in v and x'); + var one = tensor_ops_1.scalar(1); + var oneMinusDecay = one.sub($decay); + var update = $x.sub($v).mul(oneMinusDecay); + if (zeroDebias) { + util.assert(step != null, 'When using zeroDebias: true, step is required.'); + var $step = tensor_util_env_1.convertToTensor(step, 'step', 'movingAverage'); + update = update.div(one.sub(binary_ops_1.pow($decay, $step))); + } + return $v.add(update); +} +exports.movingAverage = operation_1.op({ movingAverage_: movingAverage_ }); +//# sourceMappingURL=moving_average.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js.map new file mode 100644 index 0000000..1681b29 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average.js.map @@ -0,0 +1 @@ +{"version":3,"file":"moving_average.js","sourceRoot":"","sources":["../../src/ops/moving_average.ts"],"names":[],"mappings":";;AAkBA,8CAAgD;AAChD,sDAAmD;AAEnD,8BAAgC;AAChC,2CAAiC;AACjC,yCAA+B;AAC/B,2CAAoC;AA6BpC,wBACI,CAAe,EAAE,CAAe,EAAE,KAAoB,EACtD,IAAoB,EAAE,UAAiB;IAAjB,2BAAA,EAAA,iBAAiB;IACzC,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;IACpD,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;IACpD,IAAM,MAAM,GAAG,iCAAe,CAAC,KAAK,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;IAEhE,8BAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IACzB,IAAI,CAAC,MAAM,CACP,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,2BAA2B,CAAC,CAAC;IAEvE,IAAM,GAAG,GAAG,mBAAM,CAAC,CAAC,CAAC,CAAC;IACtB,IAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAEtC,IAAI,MAAM,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAC3C,IAAI,UAAU,EAAE;QACd,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,EAAE,gDAAgD,CAAC,CAAC;QAC5E,IAAM,KAAK,GAAG,iCAAe,CAAC,IAAI,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC;QAC7D,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,gBAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;KAClD;IACD,OAAO,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;AACxB,CAAC;AAEY,QAAA,aAAa,GAAG,cAAE,CAAC,EAAC,cAAc,gBAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js new file mode 100644 index 0000000..85df968 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js @@ -0,0 +1,77 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('movingAverage', test_util_1.ALL_ENVS, function () { + it('zeroDebias=true, decay and step are numbers', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var decay = 0.6; + var v1 = tf.movingAverage(v0, x, decay, 1); + test_util_1.expectArraysClose(v1, tf.tensor2d([[1, 2], [3, 4]], [2, 2])); + var y = tf.tensor2d([[11, 12], [13, 14]], [2, 2]); + var v2 = tf.movingAverage(v1, y, decay, 2); + test_util_1.expectArraysClose(v2, tf.tensor2d([[7.25, 8.25], [9.25, 10.25]], [2, 2])); + }); + it('zeroDebias=true, decay and step are scalars', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var decay = tf.scalar(0.6); + var v1 = tf.movingAverage(v0, x, decay, tf.scalar(1)); + test_util_1.expectArraysClose(v1, tf.tensor2d([[1, 2], [3, 4]], [2, 2])); + var y = tf.tensor2d([[11, 12], [13, 14]], [2, 2]); + var v2 = tf.movingAverage(v1, y, decay, tf.scalar(2)); + test_util_1.expectArraysClose(v2, tf.tensor2d([[7.25, 8.25], [9.25, 10.25]], [2, 2])); + }); + it('zeroDebias=false, decay and step are numbers', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var decay = 0.6; + var v1 = tf.movingAverage(v0, x, decay, null, false); + test_util_1.expectArraysClose(v1, tf.tensor2d([[0.4, 0.8], [1.2, 1.6]], [2, 2])); + var y = tf.tensor2d([[11, 12], [13, 14]], [2, 2]); + var v2 = tf.movingAverage(v1, y, decay, null, false); + test_util_1.expectArraysClose(v2, tf.tensor2d([[4.64, 5.28], [5.92, 6.56]], [2, 2])); + }); + it('zeroDebias=false, decay is scalar', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var decay = tf.scalar(0.6); + var v1 = tf.movingAverage(v0, x, decay, null, false); + test_util_1.expectArraysClose(v1, tf.tensor2d([[0.4, 0.8], [1.2, 1.6]], [2, 2])); + var y = tf.tensor2d([[11, 12], [13, 14]], [2, 2]); + var v2 = tf.movingAverage(v1, y, decay, null, false); + test_util_1.expectArraysClose(v2, tf.tensor2d([[4.64, 5.28], [5.92, 6.56]], [2, 2])); + }); + it('zeroDebias=true, no step throws error', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + var decay = tf.scalar(0.6); + expect(function () { return tf.movingAverage(v0, x, decay, null); }).toThrowError(); + }); + it('shape mismatch in v and x throws error', function () { + var v0 = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + var x = tf.tensor2d([[1, 2]], [1, 2]); + var decay = tf.scalar(0.6); + expect(function () { return tf.movingAverage(v0, x, decay, null); }).toThrowError(); + }); + it('throws when passed v as a non-tensor', function () { + var x = tf.tensor2d([[1, 2], [3, 4]], [2, 2]); + expect(function () { return tf.movingAverage({}, x, 1); }) + .toThrowError(/Argument 'v' passed to 'movingAverage' must be a Tensor/); + }); + it('throws when passed v as a non-tensor', function () { + var v = tf.tensor2d([[0, 0], [0, 0]], [2, 2]); + expect(function () { return tf.movingAverage(v, {}, 1); }) + .toThrowError(/Argument 'x' passed to 'movingAverage' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var v0 = [[0, 0], [0, 0]]; + var x = [[1, 2], [3, 4]]; + var decay = 0.6; + var v1 = tf.movingAverage(v0, x, decay, 1); + test_util_1.expectArraysClose(v1, tf.tensor2d([[1, 2], [3, 4]], [2, 2])); + }); +}); +//# sourceMappingURL=moving_average_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js.map new file mode 100644 index 0000000..96e95e7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/moving_average_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"moving_average_test.js","sourceRoot":"","sources":["../../src/ops/moving_average_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js new file mode 100644 index 0000000..2700b6b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js @@ -0,0 +1,93 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('multinomial', test_util_1.ALL_ENVS, function () { + var NUM_SAMPLES = 1000; + var EPSILON = 0.05; + var SEED = 3.14; + it('Flip a fair coin and check bounds', function () { + var probs = tf.tensor1d([1, 1]); + var result = tf.multinomial(probs, NUM_SAMPLES, SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([NUM_SAMPLES]); + var outcomeProbs = computeProbs(result.dataSync(), 2); + test_util_1.expectArraysClose(outcomeProbs, [0.5, 0.5], EPSILON); + }); + it('Flip a two-sided coin with 100% of heads', function () { + var logits = tf.tensor1d([1, -100]); + var result = tf.multinomial(logits, NUM_SAMPLES, SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([NUM_SAMPLES]); + var outcomeProbs = computeProbs(result.dataSync(), 2); + test_util_1.expectArraysClose(outcomeProbs, [1, 0], EPSILON); + }); + it('Flip a two-sided coin with 100% of tails', function () { + var logits = tf.tensor1d([-100, 1]); + var result = tf.multinomial(logits, NUM_SAMPLES, SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([NUM_SAMPLES]); + var outcomeProbs = computeProbs(result.dataSync(), 2); + test_util_1.expectArraysClose(outcomeProbs, [0, 1], EPSILON); + }); + it('Flip a single-sided coin throws error', function () { + var probs = tf.tensor1d([1]); + expect(function () { return tf.multinomial(probs, NUM_SAMPLES, SEED); }).toThrowError(); + }); + it('Flip a ten-sided coin and check bounds', function () { + var numOutcomes = 10; + var logits = tf.fill([numOutcomes], 1).as1D(); + var result = tf.multinomial(logits, NUM_SAMPLES, SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([NUM_SAMPLES]); + var outcomeProbs = computeProbs(result.dataSync(), numOutcomes); + expect(outcomeProbs.length).toBeLessThanOrEqual(numOutcomes); + }); + it('Flip 3 three-sided coins, each coin is 100% biases', function () { + var numOutcomes = 3; + var logits = tf.tensor2d([[-100, -100, 1], [-100, 1, -100], [1, -100, -100]], [3, numOutcomes]); + var result = tf.multinomial(logits, NUM_SAMPLES, SEED); + expect(result.dtype).toBe('int32'); + expect(result.shape).toEqual([3, NUM_SAMPLES]); + var outcomeProbs = computeProbs(result.dataSync().slice(0, NUM_SAMPLES), numOutcomes); + test_util_1.expectArraysClose(outcomeProbs, [0, 0, 1], EPSILON); + outcomeProbs = computeProbs(result.dataSync().slice(NUM_SAMPLES, 2 * NUM_SAMPLES), numOutcomes); + test_util_1.expectArraysClose(outcomeProbs, [0, 1, 0], EPSILON); + outcomeProbs = + computeProbs(result.dataSync().slice(2 * NUM_SAMPLES), numOutcomes); + test_util_1.expectArraysClose(outcomeProbs, [1, 0, 0], EPSILON); + }); + it('passing Tensor3D throws error', function () { + var probs = tf.zeros([3, 2, 2]); + var normalized = true; + expect(function () { return tf.multinomial(probs, 3, SEED, normalized); }) + .toThrowError(); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.multinomial({}, NUM_SAMPLES, SEED); }) + .toThrowError(/Argument 'logits' passed to 'multinomial' must be a Tensor/); + }); + it('accepts a tensor-like object for logits (biased coin)', function () { + var res = tf.multinomial([-100, 1], NUM_SAMPLES, SEED); + expect(res.dtype).toBe('int32'); + expect(res.shape).toEqual([NUM_SAMPLES]); + var outcomeProbs = computeProbs(res.dataSync(), 2); + test_util_1.expectArraysClose(outcomeProbs, [0, 1], EPSILON); + }); + function computeProbs(events, numOutcomes) { + var counts = []; + for (var i = 0; i < numOutcomes; ++i) { + counts[i] = 0; + } + var numSamples = events.length; + for (var i = 0; i < events.length; ++i) { + counts[events[i]]++; + } + for (var i = 0; i < counts.length; i++) { + counts[i] /= numSamples; + } + return counts; + } +}); +//# sourceMappingURL=multinomial_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js.map new file mode 100644 index 0000000..5d54a66 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/multinomial_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"multinomial_test.js","sourceRoot":"","sources":["../../src/ops/multinomial_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/norm.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.d.ts new file mode 100644 index 0000000..8369c33 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.d.ts @@ -0,0 +1,5 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function norm_(x: Tensor | TensorLike, ord?: number | 'euclidean' | 'fro', axis?: number | number[], keepDims?: boolean): Tensor; +export declare const norm: typeof norm_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js new file mode 100644 index 0000000..230a84a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js @@ -0,0 +1,62 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_util_env_1 = require("../tensor_util_env"); +var axis_util = require("./axis_util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function norm_(x, ord, axis, keepDims) { + if (ord === void 0) { ord = 'euclidean'; } + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + x = tensor_util_env_1.convertToTensor(x, 'x', 'norm'); + var norm = normImpl(x, ord, axis); + var keepDimsShape = norm.shape; + if (keepDims) { + var axes = axis_util.parseAxisParam(axis, x.shape); + keepDimsShape = axis_util.expandShapeToKeepDim(norm.shape, axes); + } + return norm.reshape(keepDimsShape); +} +function normImpl(x, p, axis) { + if (axis === void 0) { axis = null; } + if (x.rank === 0) { + return x.abs(); + } + if (x.rank !== 1 && axis === null) { + return normImpl(x.reshape([-1]), p, axis); + } + if (x.rank === 1 || typeof axis === 'number' || + axis instanceof Array && axis.length === 1) { + if (p === 1) { + return x.abs().sum(axis); + } + if (p === Infinity) { + return x.abs().max(axis); + } + if (p === -Infinity) { + return x.abs().min(axis); + } + if (p === 'euclidean' || p === 2) { + return x.abs().pow(tensor_ops_1.scalar(2, 'int32')).sum(axis).sqrt(); + } + throw new Error("Error in norm: invalid ord value: " + p); + } + if (axis instanceof Array && axis.length === 2) { + if (p === 1) { + return x.abs().sum(axis[0]).max(axis[1] - 1); + } + if (p === Infinity) { + return x.abs().sum(axis[1]).max(axis[0]); + } + if (p === -Infinity) { + return x.abs().sum(axis[1]).min(axis[0]); + } + if (p === 'fro' || p === 'euclidean') { + return x.square().sum(axis).sqrt(); + } + throw new Error("Error in norm: invalid ord value: " + p); + } + throw new Error("Error in norm: invalid axis: " + axis); +} +exports.norm = operation_1.op({ norm_: norm_ }); +//# sourceMappingURL=norm.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js.map new file mode 100644 index 0000000..d9d23e7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/norm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"norm.js","sourceRoot":"","sources":["../../src/ops/norm.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.d.ts new file mode 100644 index 0000000..6beba1c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.d.ts @@ -0,0 +1,3 @@ +export declare function op(f: { + [name: string]: T; +}): T; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js new file mode 100644 index 0000000..67d3472 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js @@ -0,0 +1,39 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +function op(f) { + var keys = Object.keys(f); + if (keys.length !== 1) { + throw new Error("Please provide an object with a single key " + + "(operation name) mapping to a function. Got an object with " + + (keys.length + " keys.")); + } + var opName = keys[0]; + var fn = f[opName]; + if (opName.endsWith('_')) { + opName = opName.substring(0, opName.length - 1); + } + var f2 = function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + environment_1.ENV.engine.startScope(opName); + try { + var result = fn.apply(void 0, args); + if (result instanceof Promise) { + console.error('Cannot return a Promise inside of tidy.'); + } + environment_1.ENV.engine.endScope(result); + return result; + } + catch (ex) { + environment_1.ENV.engine.endScope(null); + throw ex; + } + }; + Object.defineProperty(f2, 'name', { value: opName, configurable: true }); + return f2; +} +exports.op = op; +//# sourceMappingURL=operation.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js.map new file mode 100644 index 0000000..0e020d6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation.js.map @@ -0,0 +1 @@ +{"version":3,"file":"operation.js","sourceRoot":"","sources":["../../src/ops/operation.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAOnC,YAAuC,CAAsB;IAC3D,IAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;QACrB,MAAM,IAAI,KAAK,CACX,6CAA6C;YAC7C,6DAA6D;aAC1D,IAAI,CAAC,MAAM,WAAQ,CAAA,CAAC,CAAC;KAC7B;IAED,IAAI,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;IACrB,IAAM,EAAE,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;IAGrB,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;QACxB,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;KACjD;IAGD,IAAM,EAAE,GAAG;QAAC,cAAc;aAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;YAAd,yBAAc;;QACxB,iBAAG,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI;YACF,IAAM,MAAM,GAAG,EAAE,eAAI,IAAI,CAAC,CAAC;YAC3B,IAAI,MAAM,YAAY,OAAO,EAAE;gBAC7B,OAAO,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;aAC1D;YACD,iBAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC5B,OAAO,MAAM,CAAC;SACf;QAAC,OAAO,EAAE,EAAE;YACX,iBAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC1B,MAAM,EAAE,CAAC;SACV;IACH,CAAC,CAAC;IACF,MAAM,CAAC,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAC,CAAC,CAAC;IAGvE,OAAO,EAAc,CAAC;AACxB,CAAC;AApCD,gBAoCC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js new file mode 100644 index 0000000..95f9f30 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js @@ -0,0 +1,25 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var operation_1 = require("./operation"); +jasmine_util_1.describeWithFlags('operation', test_util_1.ALL_ENVS, function () { + it('executes and preserves function name', function () { + var f = function () { return 2; }; + var opfn = operation_1.op({ 'opName': f }); + expect(opfn.name).toBe('opName'); + expect(opfn()).toBe(2); + }); + it('executes, preserves function name, strips underscore', function () { + var f = function () { return 2; }; + var opfn = operation_1.op({ 'opName_': f }); + expect(opfn.name).toBe('opName'); + expect(opfn()).toBe(2); + }); + it('throws when passing an object with multiple keys', function () { + var f = function () { return 2; }; + expect(function () { return operation_1.op({ 'opName_': f, 'opName2_': f }); }) + .toThrowError(/Please provide an object with a single key/); + }); +}); +//# sourceMappingURL=operation_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js.map new file mode 100644 index 0000000..34a26af --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/operation_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"operation_test.js","sourceRoot":"","sources":["../../src/ops/operation_test.ts"],"names":[],"mappings":";;AAgBA,gDAAkD;AAClD,0CAAsC;AACtC,yCAA+B;AAE/B,gCAAiB,CAAC,WAAW,EAAE,oBAAQ,EAAE;IACvC,EAAE,CAAC,sCAAsC,EAAE;QACzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,EAAD,CAAC,CAAC;QAClB,IAAM,IAAI,GAAG,cAAE,CAAC,EAAC,QAAQ,EAAE,CAAC,EAAC,CAAC,CAAC;QAE/B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sDAAsD,EAAE;QACzD,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,EAAD,CAAC,CAAC;QAClB,IAAM,IAAI,GAAG,cAAE,CAAC,EAAC,SAAS,EAAE,CAAC,EAAC,CAAC,CAAC;QAEhC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,EAAD,CAAC,CAAC;QAClB,MAAM,CAAC,cAAM,OAAA,cAAE,CAAC,EAAC,SAAS,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAC,CAAC,EAAjC,CAAiC,CAAC;aAC1C,YAAY,CAAC,4CAA4C,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.d.ts new file mode 100644 index 0000000..dbf26a7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.d.ts @@ -0,0 +1,29 @@ +export * from './batchnorm'; +export * from './concat'; +export * from './conv'; +export * from './matmul'; +export * from './reverse'; +export * from './pool'; +export * from './slice'; +export * from './unary_ops'; +export * from './reduction_ops'; +export * from './compare'; +export * from './binary_ops'; +export * from './relu_ops'; +export * from './logical_ops'; +export * from './array_ops'; +export * from './tensor_ops'; +export * from './transpose'; +export * from './softmax'; +export * from './lrn'; +export * from './norm'; +export * from './segment_ops'; +export * from './lstm'; +export * from './moving_average'; +export * from './strided_slice'; +export * from './topk'; +export { op } from './operation'; +import * as losses from './loss_ops'; +import * as linalg from './linalg_ops'; +import * as image from './image_ops'; +export { image, linalg, losses }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js new file mode 100644 index 0000000..83e086b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js @@ -0,0 +1,38 @@ +"use strict"; +function __export(m) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} +Object.defineProperty(exports, "__esModule", { value: true }); +__export(require("./batchnorm")); +__export(require("./concat")); +__export(require("./conv")); +__export(require("./matmul")); +__export(require("./reverse")); +__export(require("./pool")); +__export(require("./slice")); +__export(require("./unary_ops")); +__export(require("./reduction_ops")); +__export(require("./compare")); +__export(require("./binary_ops")); +__export(require("./relu_ops")); +__export(require("./logical_ops")); +__export(require("./array_ops")); +__export(require("./tensor_ops")); +__export(require("./transpose")); +__export(require("./softmax")); +__export(require("./lrn")); +__export(require("./norm")); +__export(require("./segment_ops")); +__export(require("./lstm")); +__export(require("./moving_average")); +__export(require("./strided_slice")); +__export(require("./topk")); +var operation_1 = require("./operation"); +exports.op = operation_1.op; +var losses = require("./loss_ops"); +exports.losses = losses; +var linalg = require("./linalg_ops"); +exports.linalg = linalg; +var image = require("./image_ops"); +exports.image = image; +//# sourceMappingURL=ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js.map new file mode 100644 index 0000000..bc3056e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"ops.js","sourceRoot":"","sources":["../../src/ops/ops.ts"],"names":[],"mappings":";;;;;AAiBA,iCAA4B;AAC5B,8BAAyB;AACzB,4BAAuB;AACvB,8BAAyB;AACzB,+BAA0B;AAC1B,4BAAuB;AACvB,6BAAwB;AACxB,iCAA4B;AAC5B,qCAAgC;AAChC,+BAA0B;AAC1B,kCAA6B;AAC7B,gCAA2B;AAC3B,mCAA8B;AAC9B,iCAA4B;AAC5B,kCAA6B;AAC7B,iCAA4B;AAC5B,+BAA0B;AAC1B,2BAAsB;AACtB,4BAAuB;AACvB,mCAA8B;AAC9B,4BAAuB;AACvB,sCAAiC;AACjC,qCAAgC;AAChC,4BAAuB;AAEvB,yCAA+B;AAAvB,yBAAA,EAAE,CAAA;AAGV,mCAAqC;AAGd,wBAAM;AAF7B,qCAAuC;AAExB,wBAAM;AADrB,mCAAqC;AAC7B,sBAAK"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js new file mode 100644 index 0000000..8e5a46d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js @@ -0,0 +1,153 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('pad1d', test_util_1.ALL_ENVS, function () { + it('Should pad 1D arrays', function () { + var a = tf.tensor1d([1, 2, 3, 4, 5, 6], 'int32'); + var b = tf.pad1d(a, [2, 3]); + test_util_1.expectArraysClose(b, [0, 0, 1, 2, 3, 4, 5, 6, 0, 0, 0]); + }); + it('Should not pad 1D arrays with 0s', function () { + var a = tf.tensor1d([1, 2, 3, 4], 'int32'); + var b = tf.pad1d(a, [0, 0]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4]); + }); + it('Should handle padding with custom value', function () { + var a = tf.tensor1d([1, 2, 3, 4], 'int32'); + var b = tf.pad1d(a, [2, 3], 9); + test_util_1.expectArraysClose(b, [9, 9, 1, 2, 3, 4, 9, 9, 9]); + a = tf.tensor1d([1, 2, 3, 4]); + b = tf.pad1d(a, [2, 1], 1.1); + test_util_1.expectArraysClose(b, [1.1, 1.1, 1, 2, 3, 4, 1.1]); + a = tf.tensor1d([1, 2, 3, 4]); + b = tf.pad1d(a, [2, 1], 1); + test_util_1.expectArraysClose(b, [1, 1, 1, 2, 3, 4, 1]); + }); + it('Should handle NaNs with 1D arrays', function () { + var a = tf.tensor1d([1, NaN, 2, NaN]); + var b = tf.pad1d(a, [1, 1]); + test_util_1.expectArraysClose(b, [0, 1, NaN, 2, NaN, 0]); + }); + it('Should handle invalid paddings', function () { + var a = tf.tensor1d([1, 2, 3, 4], 'int32'); + var f = function () { + tf.pad1d(a, [2, 2, 2]); + }; + expect(f).toThrowError(); + }); + it('grad', function () { + var a = tf.tensor1d([1, 2, 3]); + var dy = tf.tensor1d([10, 20, 30, 40, 50, 60]); + var da = tf.grad(function (a) { return tf.pad1d(a, [2, 1]); })(a, dy); + expect(da.shape).toEqual([3]); + test_util_1.expectArraysClose(da, [30, 40, 50]); + }); + it('accepts a tensor-like object', function () { + var a = [1, 2, 3, 4, 5, 6]; + var b = tf.pad1d(a, [2, 3]); + test_util_1.expectArraysClose(b, [0, 0, 1, 2, 3, 4, 5, 6, 0, 0, 0]); + }); +}); +jasmine_util_1.describeWithFlags('pad2d', test_util_1.ALL_ENVS, function () { + it('Should pad 2D arrays', function () { + var a = tf.tensor2d([[1], [2]], [2, 1], 'int32'); + var b = tf.pad2d(a, [[1, 1], [1, 1]]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0]); + a = tf.tensor2d([[1, 2, 3], [4, 5, 6]], [2, 3], 'int32'); + b = tf.pad2d(a, [[2, 2], [1, 1]]); + test_util_1.expectArraysClose(b, [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 0, + 0, 4, 5, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 + ]); + }); + it('Should not pad 2D arrays with 0s', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]], [2, 3], 'int32'); + var b = tf.pad2d(a, [[0, 0], [0, 0]]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4, 5, 6]); + }); + it('Should handle padding with custom value', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]], [2, 3], 'int32'); + var b = tf.pad2d(a, [[1, 1], [1, 1]], 10); + test_util_1.expectArraysClose(b, [ + 10, 10, 10, 10, 10, 10, 1, 2, 3, 10, + 10, 4, 5, 6, 10, 10, 10, 10, 10, 10 + ]); + a = tf.tensor2d([[1], [1]], [2, 1]); + b = tf.pad2d(a, [[1, 1], [1, 1]], -2.1); + test_util_1.expectArraysClose(b, [-2.1, -2.1, -2.1, -2.1, 1, -2.1, -2.1, 1, -2.1, -2.1, -2.1, -2.1]); + a = tf.tensor2d([[1], [1]], [2, 1]); + b = tf.pad2d(a, [[1, 1], [1, 1]], -2); + test_util_1.expectArraysClose(b, [-2, -2, -2, -2, 1, -2, -2, 1, -2, -2, -2, -2]); + }); + it('Should handle NaNs with 2D arrays', function () { + var a = tf.tensor2d([[1, NaN], [1, NaN]], [2, 2]); + var b = tf.pad2d(a, [[1, 1], [1, 1]]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0, 0, 1, NaN, 0, 0, 1, NaN, 0, 0, 0, 0, 0]); + }); + it('Should handle invalid paddings', function () { + var a = tf.tensor2d([[1], [2]], [2, 1], 'int32'); + var f = function () { + tf.pad2d(a, [[2, 2, 2], [1, 1, 1]]); + }; + expect(f).toThrowError(); + }); + it('grad', function () { + var a = tf.tensor2d([[1, 2], [3, 4]]); + var dy = tf.tensor2d([[0, 0, 0], [10, 20, 0], [30, 40, 0]], [3, 3]); + var da = tf.grad(function (a) { return tf.pad2d(a, [[1, 0], [0, 1]]); })(a, dy); + expect(da.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(da, [10, 20, 30, 40]); + }); + it('accepts a tensor-like object', function () { + var a = [[1, 2, 3], [4, 5, 6]]; + var b = tf.pad2d(a, [[0, 0], [0, 0]]); + test_util_1.expectArraysClose(b, [1, 2, 3, 4, 5, 6]); + }); +}); +jasmine_util_1.describeWithFlags('pad4d', test_util_1.ALL_ENVS, function () { + it('Should pad 4D arrays', function () { + var a = tf.tensor4d([[[[9]]]], [1, 1, 1, 1], 'int32'); + var b = tf.pad4d(a, [[0, 0], [1, 1], [1, 1], [0, 0]]); + var expected = tf.tensor4d([[[[0], [0], [0]], [[0], [9], [0]], [[0], [0], [0]]]], [1, 3, 3, 1], 'int32'); + test_util_1.expectArraysClose(b, expected); + }); + it('does not leak memory', function () { + var a = tf.tensor4d([[[[9]]]], [1, 1, 1, 1], 'int32'); + tf.pad4d(a, [[0, 0], [1, 1], [1, 1], [0, 0]]); + var numTensors = environment_1.Environment.memory().numTensors; + tf.pad4d(a, [[0, 0], [1, 1], [1, 1], [0, 0]]); + expect(environment_1.Environment.memory().numTensors).toEqual(numTensors + 1); + }); + it('accepts a tensor-like object', function () { + var a = [[[[9]]]]; + var b = tf.pad4d(a, [[0, 0], [1, 1], [1, 1], [0, 0]]); + var expected = tf.tensor4d([[[[0], [0], [0]], [[0], [9], [0]], [[0], [0], [0]]]], [1, 3, 3, 1], 'float32'); + test_util_1.expectArraysClose(b, expected); + }); +}); +jasmine_util_1.describeWithFlags('pad', test_util_1.ALL_ENVS, function () { + it('Pad tensor2d', function () { + var a = tf.tensor2d([[1], [2]], [2, 1], 'int32'); + var b = tf.pad(a, [[1, 1], [1, 1]]); + test_util_1.expectArraysClose(b, [0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0]); + a = tf.tensor2d([[1, 2, 3], [4, 5, 6]], [2, 3], 'int32'); + b = tf.pad(a, [[2, 2], [1, 1]]); + test_util_1.expectArraysClose(b, [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 0, + 0, 4, 5, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 + ]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.pad({}, [[0, 0]]); }) + .toThrowError(/Argument 'x' passed to 'pad' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var x = [[1], [2]]; + var res = tf.pad(x, [[1, 1], [1, 1]]); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0]); + }); +}); +//# sourceMappingURL=pad_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js.map new file mode 100644 index 0000000..60b21fc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pad_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pad_test.js","sourceRoot":"","sources":["../../src/ops/pad_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.d.ts new file mode 100644 index 0000000..c5396f3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.d.ts @@ -0,0 +1,7 @@ +import { Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function maxPool_(x: T | TensorLike, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +declare function avgPool_(x: T | TensorLike, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; +export declare const maxPool: typeof maxPool_; +export declare const avgPool: typeof avgPool_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js new file mode 100644 index 0000000..e1c7527 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js @@ -0,0 +1,103 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var conv_util = require("./conv_util"); +var operation_1 = require("./operation"); +function maxPool_(x, filterSize, strides, pad, dimRoundingMode) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'maxPool'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + util.assert(x4D.rank === 4, "Error in maxPool: input must be rank 4 but got rank " + x4D.rank + "."); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in maxPool: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = conv_util.computePool2DInfo(x4D.shape, filterSize, strides, pad, dimRoundingMode); + var grad = function (dy, saved) { + var y4D = saved[0]; + return { + x: function () { + return maxPoolBackprop(dy, x4D, y4D, filterSize, strides, pad); + } + }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.maxPool(x4D, convInfo)); }, { x: x4D }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function avgPool_(x, filterSize, strides, pad, dimRoundingMode) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'avgPool'); + util.assert($x.dtype === 'float32', 'The input dtype to avgPool must be float32'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + util.assert(x4D.rank === 4, "Error in avgPool: x must be rank 4 but got rank " + x4D.rank + "."); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in avgPool: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = conv_util.computePool2DInfo(x4D.shape, filterSize, strides, pad); + var grad = function (dy) { + return { x: function () { return avgPoolBackprop(dy, x4D, filterSize, strides, pad); } }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.avgPool(x4D, convInfo); }, { x: x4D }, grad); + res = res.cast($x.dtype); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +function maxPoolBackprop(dy, input, output, filterSize, strides, pad, dimRoundingMode) { + var $dy = tensor_util_env_1.convertToTensor(dy, 'dy', 'maxPoolBackprop'); + var $input = tensor_util_env_1.convertToTensor(input, 'input', 'maxPoolBackprop'); + var $output = tensor_util_env_1.convertToTensor(output, 'output', 'maxPoolBackprop'); + util.assert($input.rank === $dy.rank, "Rank of input (" + $input.rank + ") does not match rank of dy (" + $dy.rank + ")"); + util.assert($dy.rank === 4, "Error in maxPoolBackprop: dy must be rank 4 but got rank " + + ($dy.rank + ".")); + util.assert($input.rank === 4, "Error in maxPoolBackprop: input must be rank 4 but got rank " + + ($input.rank + ".")); + if (dimRoundingMode != null) { + util.assert(util.isInt(pad), "Error in maxPoolBackprop: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = conv_util.computePool2DInfo($input.shape, filterSize, strides, pad, dimRoundingMode); + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.maxPoolBackprop($dy, $input, $output, convInfo); }, { $dy: $dy, $input: $input }); + return res; +} +function avgPoolBackprop(dy, input, filterSize, strides, pad) { + var $dy = tensor_util_env_1.convertToTensor(dy, 'dy', 'avgPoolBackprop'); + var $input = tensor_util_env_1.convertToTensor(input, 'input', 'avgPoolBackprop'); + util.assert($input.rank === $dy.rank, "Rank of input (" + $input.rank + ") does not match rank of dy (" + $dy.rank + ")"); + var input4D = $input; + var dy4D = $dy; + var reshapedTo4D = false; + if ($input.rank === 3) { + reshapedTo4D = true; + input4D = $input.as4D(1, $input.shape[0], $input.shape[1], $input.shape[2]); + dy4D = $dy.as4D(1, $dy.shape[0], $dy.shape[1], $dy.shape[2]); + } + util.assert(dy4D.rank === 4, "Error in avgPoolBackprop: dy must be rank 4 but got rank " + + (dy4D.rank + ".")); + util.assert(input4D.rank === 4, "Error in avgPoolBackprop: input must be rank 4 but got rank " + + (input4D.rank + ".")); + var convInfo = conv_util.computePool2DInfo(input4D.shape, filterSize, strides, pad); + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.avgPoolBackprop(dy4D, input4D, convInfo); }, { dy4D: dy4D, input4D: input4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; +} +exports.maxPool = operation_1.op({ maxPool_: maxPool_ }); +exports.avgPool = operation_1.op({ avgPool_: avgPool_ }); +//# sourceMappingURL=pool.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js.map new file mode 100644 index 0000000..c08eca6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../src/ops/pool.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js new file mode 100644 index 0000000..abf3f1a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js @@ -0,0 +1,309 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('maxPool', test_util_1.ALL_ENVS, function () { + it('x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () { + var x = tf.tensor3d([0], [1, 1, 1]); + var result = tf.maxPool(x, 1, 1, 0); + test_util_1.expectArraysClose(result, [0]); + }); + it('x=[3,3,1] f=[2,2] s=1', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]); + var result = tf.maxPool(x, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [5, 6, 9, 9]); + }); + it('x=[2,3,3,1] f=[2,2] s=1', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]); + var result = tf.maxPool(x, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 2, 1]); + test_util_1.expectArraysClose(result, [5, 6, 9, 9, 5, 6, 8, 9]); + }); + it('[x=[3,3,1] f=[2,2] s=1 ignores NaNs', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, NaN, 9], [3, 3, 1]); + var result = tf.maxPool(x, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [5, 6, 7, 9]); + }); + it('x=[3,3,2] f=[2,2] s=1', function () { + var x = tf.tensor3d([1, 99, 2, 88, 3, 77, 4, 66, 5, 55, 6, 44, 7, 33, 9, 22, 8, 11], [3, 3, 2]); + var result = tf.maxPool(x, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(result, [5, 99, 6, 88, 9, 66, 9, 55]); + }); + it('x=[4,4,1] f=[2,2] s=2', function () { + var x = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]); + var result = tf.maxPool(x, 2, 2, 0); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [5, 7, 13, 15]); + }); + it('x=[2,2,1] f=[2,2] s=1 p=same', function () { + var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var fSize = 2; + var strides = 1; + var result = tf.maxPool(x, fSize, strides, 'same'); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [4, 4, 4, 4]); + }); + it('throws when x is not rank 3', function () { + var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9], [3, 3]); + expect(function () { return tf.maxPool(x, 2, 1, 0); }).toThrowError(); + }); + it('throws when dimRoundingMode is set and pad is not a number', function () { + var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var pad = 'valid'; + var dimRoundingMode = 'round'; + expect(function () { return tf.maxPool(x, 2, 1, pad, dimRoundingMode); }).toThrowError(); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.maxPool({}, 2, 1, 'valid'); }) + .toThrowError(/Argument 'x' passed to 'maxPool' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var x = [[[0]]]; + var result = tf.maxPool(x, 1, 1, 0); + test_util_1.expectArraysClose(result, [0]); + }); +}); +jasmine_util_1.describeWithFlags('maxPoolBackprop', test_util_1.ALL_ENVS, function () { + it('gradients x=[3,3,1] f=[2,2] s=1 no dup max value, test #1', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9], [3, 3, 1]); + var expected = [0, 0, 0, 0, 1, 2, 0, 3, 4]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradients x=[3,3,1] f=[2,2] s=1 no dup max value, test #2', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([9, 5, 6, 6, 8, 4, 9, 5, 10], [3, 3, 1]); + var expected = [1, 0, 0, 0, 2, 0, 3, 0, 4]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradients x=[2,3,3,1] f=[2,2] s=1 no duplicate max value', function () { + var dy = tf.tensor4d([1, 2, 3, 4, 1, 2, 3, 4], [2, 2, 2, 1]); + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 9, 5, 6, 6, 8, 4, 9, 5, 10], [2, 3, 3, 1]); + var expected = [0, 0, 0, 0, 1, 2, 0, 3, 4, 1, 0, 0, 0, 2, 0, 3, 0, 4]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[3,3,1] f=[2,2] s=1 dup max value, test 1', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([0, 0, 0, 0, 5, 0, 0, 0, 0], [3, 3, 1]); + var expected = [0, 0, 0, 0, 10, 0, 0, 0, 0]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[3,3,1] f=[2,2] s=1 dup max value, test 2', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([1, 3, 2, 1, 2, 1, 1, 1, 5], [3, 3, 1]); + var expected = [0, 3, 0, 0, 3, 0, 0, 0, 4]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[2,3,3,1] f=[2,2] s=1 dup max value in 2nd input', function () { + var dy = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]); + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7, 9, 8], [2, 3, 3, 1]); + var expected = new Float32Array([0, 0, 0, 0, 1, 2, 0, 3, 4, 0, 0, 0, 0, 5, 6, 0, 15, 0]); + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[4,4,1] f=[2,2] s=2 test #1', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]); + var expected = [0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 3, 0, 4]; + var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[4,4,1] f=[2,2] s=2 test #2', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 1], [4, 4, 1]); + var expected = [0, 1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0]; + var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[5,5,1] f=[3,3] s=2 no duplicate max value', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([ + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 + ], [5, 5, 1]); + var expected = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, + 0, 2, 0, 0, 0, 0, 0, 0, 0, 3, 0, 4 + ]; + var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[5,5,1] f=[3,3] s=2 duplicate max value', function () { + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var x = tf.tensor3d([ + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 24, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 12 + ], [5, 5, 1]); + var expected = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 + ]; + var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[3,3,2] f=[2,2] s=1, no duplicate max value', function () { + var dy = tf.tensor3d([1, 44, 2, 33, 3, 22, 4, 11], [2, 2, 2]); + var x = tf.tensor3d([1, 99, 2, 55, 3, 66, 4, 66, 5, 88, 6, 44, 7, 99, 8, 55, 9, 100], [3, 3, 2]); + var expected = [0, 44, 0, 0, 0, 0, 0, 0, 1, 33, 2, 0, 0, 22, 3, 0, 4, 11]; + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[3,3,2] f=[2,2] s=1 duplicate max value', function () { + var dy = tf.tensor3d([1, 44, 2, 33, 3, 22, 4, 11], [2, 2, 2]); + var x = tf.tensor3d([0, 1, 0, 3, 0, 2, 0, 1, 5, 2, 0, 1, 0, 1, 0, 1, 0, 5], [3, 3, 2]); + var expected = new Float32Array([0, 0, 0, 77, 0, 0, 0, 0, 10, 22, 0, 0, 0, 0, 0, 0, 0, 11]); + var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=[4,4,2] f=[2,2] s=1', function () { + var dy = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var x = tf.tensor3d([ + 0, 1, 1, 2, 2, 2, 3, 1, 4, 1, 5, 1, 6, 1, 7, 1, + 8, 1, 9, 1, 10, 1, 11, 1, 12, 1, 13, 2, 14, 2, 15, 1 + ], [4, 4, 2]); + var expected = [ + 0, 0, 0, 11, 0, 22, 0, 0, 0, 0, 1, 0, 0, 0, 2, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 33, 0, 44, 4, 0 + ]; + var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); + it('gradient x=5x5x2, f=3, s=2 no duplicate max value', function () { + var dy = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var x = tf.tensor3d([ + 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, + 8, 9, 9, 10, 10, 11, 11, 12, 24, 13, 13, 14, 14, 15, 15, 16, 16, + 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 12 + ], [5, 5, 2]); + var expected = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1, 110, 0, 0, 2, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 4, 0 + ]; + var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, expected); + }); +}); +jasmine_util_1.describeWithFlags('avgPool', test_util_1.ALL_ENVS, function () { + it('x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () { + var a = tf.tensor3d([0], [1, 1, 1]); + var result = tf.avgPool(a, 1, 1, 0); + test_util_1.expectArraysClose(result, [0]); + }); + it('x=[3,3,1] f=[2,2] s=1', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]); + var result = tf.avgPool(a, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 1]); + expect(result.dtype).toBe('float32'); + test_util_1.expectArraysClose(result, [3, 4, 6.25, 7]); + }); + it('input int32 throws error', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1], 'int32'); + expect(function () { return tf.avgPool(a, 2, 1, 0); }).toThrowError(); + }); + it('x=[2,3,3,1] f=[2,2], s=1', function () { + var a = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]); + var result = tf.avgPool(a, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 2, 1]); + test_util_1.expectArraysClose(result, [3, 4, 6.25, 7, 3, 4, 6, 7]); + }); + it('x=[3,3,1] f=[2,2] s=1 propagates NaNs', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, NaN, 8], [3, 3, 1]); + var result = tf.avgPool(a, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [3, 4, NaN, NaN]); + }); + it('x=[3,3,2] f=[2,2] s=1', function () { + var a = tf.tensor3d([1, 99, 2, 88, 3, 77, 4, 66, 5, 55, 6, 44, 7, 33, 9, 22, 8, 11], [3, 3, 2]); + var result = tf.avgPool(a, 2, 1, 0); + expect(result.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(result, [3, 77, 4, 66, 6.25, 44, 7, 33]); + }); + it('x=[4,4,1] f=[2,2] s=2', function () { + var a = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]); + var result = tf.avgPool(a, 2, 2, 0); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [2.5, 4.5, 10.5, 12.5]); + }); + it('x=[2,2,1] f=[2,2] s=1 p=same', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var fSize = 2; + var strides = 1; + var result = tf.avgPool(a, fSize, strides, 'same'); + expect(result.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(result, [2.5, 3, 3.5, 4]); + }); + it('gradient x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () { + var x = tf.tensor3d([0], [1, 1, 1]); + var dy = tf.tensor3d([0], [1, 1, 1]); + var dx = tf.grad(function (x) { return x.avgPool(1, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [0]); + }); + it('gradient x=[3,3,1] f=[2,2] s=1', function () { + var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]); + var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var avgMultiplier = 1 / (2 * 2); + var dx = tf.grad(function (x) { return x.avgPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [ + 1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier, + 4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier, + 3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier + ]); + }); + it('gradient x=[2,3,3,1] f=[2,2], s=1', function () { + var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]); + var dy = tf.tensor4d([1, 2, 3, 4, 1, 2, 3, 4], [2, 2, 2, 1]); + var avgMultiplier = 1 / (2 * 2); + var dx = tf.grad(function (x) { return x.avgPool(2, 1, 0); })(x, dy); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [ + 1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier, + 4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier, + 3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier, + 1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier, + 4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier, + 3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier + ]); + }); + it('throws when dimRoundingMode is set and pad is not a number', function () { + var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + var pad = 'valid'; + var dimRoundingMode = 'round'; + expect(function () { return tf.avgPool(x, 2, 1, pad, dimRoundingMode); }).toThrowError(); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.avgPool({}, 2, 1, 'valid'); }) + .toThrowError(/Argument 'x' passed to 'avgPool' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[[0]]]; + var result = tf.avgPool(a, 1, 1, 0); + test_util_1.expectArraysClose(result, [0]); + }); +}); +//# sourceMappingURL=pool_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js.map new file mode 100644 index 0000000..325e76c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/pool_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pool_test.js","sourceRoot":"","sources":["../../src/ops/pool_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.d.ts new file mode 100644 index 0000000..57c13b0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.d.ts @@ -0,0 +1,21 @@ +export interface RandGauss { + nextValue(): number; +} +export interface RandNormalDataTypes { + float32: Float32Array; + int32: Int32Array; +} +export declare class MPRandGauss implements RandGauss { + private mean; + private stdDev; + private nextVal; + private dtype?; + private truncated?; + private upper?; + private lower?; + private random; + constructor(mean: number, stdDeviation: number, dtype?: keyof RandNormalDataTypes, truncated?: boolean, seed?: number); + nextValue(): number; + private convertValue; + private isValidTruncated; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js new file mode 100644 index 0000000..defaee1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js @@ -0,0 +1,57 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var seedrandom = require("seedrandom"); +var MPRandGauss = (function () { + function MPRandGauss(mean, stdDeviation, dtype, truncated, seed) { + this.mean = mean; + this.stdDev = stdDeviation; + this.dtype = dtype; + this.nextVal = NaN; + this.truncated = truncated; + if (this.truncated) { + this.upper = this.mean + this.stdDev * 2; + this.lower = this.mean - this.stdDev * 2; + } + var seedValue = seed ? seed : Math.random(); + this.random = seedrandom.alea(seedValue.toString()); + } + MPRandGauss.prototype.nextValue = function () { + if (!isNaN(this.nextVal)) { + var value = this.nextVal; + this.nextVal = NaN; + return value; + } + var resultX, resultY; + var isValid = false; + while (!isValid) { + var v1 = void 0, v2 = void 0, s = void 0; + do { + v1 = 2 * this.random() - 1; + v2 = 2 * this.random() - 1; + s = v1 * v1 + v2 * v2; + } while (s >= 1 || s === 0); + var mul = Math.sqrt(-2.0 * Math.log(s) / s); + resultX = this.mean + this.stdDev * v1 * mul; + resultY = this.mean + this.stdDev * v2 * mul; + if (!this.truncated || this.isValidTruncated(resultX)) { + isValid = true; + } + } + if (!this.truncated || this.isValidTruncated(resultY)) { + this.nextVal = this.convertValue(resultY); + } + return this.convertValue(resultX); + }; + MPRandGauss.prototype.convertValue = function (value) { + if (this.dtype == null || this.dtype === 'float32') { + return value; + } + return Math.round(value); + }; + MPRandGauss.prototype.isValidTruncated = function (value) { + return value <= this.upper && value >= this.lower; + }; + return MPRandGauss; +}()); +exports.MPRandGauss = MPRandGauss; +//# sourceMappingURL=rand.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js.map new file mode 100644 index 0000000..163c61e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand.js.map @@ -0,0 +1 @@ +{"version":3,"file":"rand.js","sourceRoot":"","sources":["../../src/ops/rand.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js new file mode 100644 index 0000000..b08eb75 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js @@ -0,0 +1,47 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var rand_1 = require("./rand"); +var rand_util_1 = require("./rand_util"); +function isFloat(n) { + return Number(n) === n && n % 1 !== 0; +} +describe('MPRandGauss', function () { + var EPSILON = 0.05; + var SEED = 2002; + it('should default to float32 numbers', function () { + var rand = new rand_1.MPRandGauss(0, 1.5); + expect(isFloat(rand.nextValue())).toBe(true); + }); + it('should handle create a mean/stdv of float32 numbers', function () { + var rand = new rand_1.MPRandGauss(0, 1.5, 'float32', false, SEED); + var values = []; + var size = 10000; + for (var i = 0; i < size; i++) { + values.push(rand.nextValue()); + } + rand_util_1.expectArrayInMeanStdRange(values, 0, 1.5, EPSILON); + rand_util_1.jarqueBeraNormalityTest(values); + }); + it('should handle int32 numbers', function () { + var rand = new rand_1.MPRandGauss(0, 1, 'int32'); + expect(isFloat(rand.nextValue())).toBe(false); + }); + it('should handle create a mean/stdv of int32 numbers', function () { + var rand = new rand_1.MPRandGauss(0, 2, 'int32', false, SEED); + var values = []; + var size = 10000; + for (var i = 0; i < size; i++) { + values.push(rand.nextValue()); + } + rand_util_1.expectArrayInMeanStdRange(values, 0, 2, EPSILON); + rand_util_1.jarqueBeraNormalityTest(values); + }); + it('Should not have a more than 2x std-d from mean for truncated values', function () { + var stdv = 1.5; + var rand = new rand_1.MPRandGauss(0, stdv, 'float32', true); + for (var i = 0; i < 1000; i++) { + expect(Math.abs(rand.nextValue())).toBeLessThan(stdv * 2); + } + }); +}); +//# sourceMappingURL=rand_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js.map new file mode 100644 index 0000000..47539fb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"rand_test.js","sourceRoot":"","sources":["../../src/ops/rand_test.ts"],"names":[],"mappings":";;AAiBA,+BAAmC;AACnC,yCAA+E;AAE/E,iBAAiB,CAAS;IACxB,OAAO,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACxC,CAAC;AAED,QAAQ,CAAC,aAAa,EAAE;IACtB,IAAM,OAAO,GAAG,IAAI,CAAC;IACrB,IAAM,IAAI,GAAG,IAAI,CAAC;IAElB,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,IAAI,GAAG,IAAI,kBAAW,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACrC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE;QACxD,IAAM,IAAI,GACN,IAAI,kBAAW,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,KAAK,EAAkB,IAAI,CAAC,CAAC;QACpE,IAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAM,IAAI,GAAG,KAAK,CAAC;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC7B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;SAC/B;QACD,qCAAyB,CAAC,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;QACnD,mCAAuB,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE;QAChC,IAAM,IAAI,GAAG,IAAI,kBAAW,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE;QACtD,IAAM,IAAI,GAAG,IAAI,kBAAW,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAkB,IAAI,CAAC,CAAC;QACzE,IAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAM,IAAI,GAAG,KAAK,CAAC;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC7B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;SAC/B;QACD,qCAAyB,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QACjD,mCAAuB,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qEAAqE,EACrE;QACE,IAAM,IAAI,GAAG,GAAG,CAAC;QACjB,IAAM,IAAI,GAAG,IAAI,kBAAW,CAAC,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAiB,CAAC;QACvE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC7B,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;SAC3D;IACH,CAAC,CAAC,CAAC;AACR,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.d.ts new file mode 100644 index 0000000..0b09be1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.d.ts @@ -0,0 +1,4 @@ +import { Tensor } from '../tensor'; +import { TypedArray } from '../types'; +export declare function jarqueBeraNormalityTest(a: Tensor | TypedArray | number[]): void; +export declare function expectArrayInMeanStdRange(actual: Tensor | TypedArray | number[], expectedMean: number, expectedStdDev: number, epsilon?: number): void; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js new file mode 100644 index 0000000..bc8315c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js @@ -0,0 +1,79 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_1 = require("../tensor"); +var test_util_1 = require("../test_util"); +function jarqueBeraNormalityTest(a) { + var values; + if (a instanceof tensor_1.Tensor) { + values = a.dataSync(); + } + else { + values = a; + } + var n = values.length; + var s = skewness(values); + var k = kurtosis(values); + var jb = n / 6 * (Math.pow(s, 2) + 0.25 * Math.pow(k - 3, 2)); + var CHI_SQUARE_2DEG = 5.991; + if (jb > CHI_SQUARE_2DEG) { + throw new Error("Invalid p-value for JB: " + jb); + } +} +exports.jarqueBeraNormalityTest = jarqueBeraNormalityTest; +function expectArrayInMeanStdRange(actual, expectedMean, expectedStdDev, epsilon) { + if (epsilon == null) { + epsilon = environment_1.ENV.get('TEST_EPSILON'); + } + var actualValues; + if (actual instanceof tensor_1.Tensor) { + actualValues = actual.dataSync(); + } + else { + actualValues = actual; + } + var actualMean = mean(actualValues); + test_util_1.expectNumbersClose(actualMean, expectedMean, epsilon); + test_util_1.expectNumbersClose(standardDeviation(actualValues, actualMean), expectedStdDev, epsilon); +} +exports.expectArrayInMeanStdRange = expectArrayInMeanStdRange; +function mean(values) { + var sum = 0; + for (var i = 0; i < values.length; i++) { + sum += values[i]; + } + return sum / values.length; +} +function standardDeviation(values, mean) { + var squareDiffSum = 0; + for (var i = 0; i < values.length; i++) { + var diff = values[i] - mean; + squareDiffSum += diff * diff; + } + return Math.sqrt(squareDiffSum / values.length); +} +function kurtosis(values) { + var valuesMean = mean(values); + var n = values.length; + var sum2 = 0; + var sum4 = 0; + for (var i = 0; i < n; i++) { + var v = values[i] - valuesMean; + sum2 += Math.pow(v, 2); + sum4 += Math.pow(v, 4); + } + return (1 / n) * sum4 / Math.pow((1 / n) * sum2, 2); +} +function skewness(values) { + var valuesMean = mean(values); + var n = values.length; + var sum2 = 0; + var sum3 = 0; + for (var i = 0; i < n; i++) { + var v = values[i] - valuesMean; + sum2 += Math.pow(v, 2); + sum3 += Math.pow(v, 3); + } + return (1 / n) * sum3 / Math.pow((1 / (n - 1)) * sum2, 3 / 2); +} +//# sourceMappingURL=rand_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js.map new file mode 100644 index 0000000..0ee864e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/rand_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"rand_util.js","sourceRoot":"","sources":["../../src/ops/rand_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.d.ts new file mode 100644 index 0000000..ba4acd4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.d.ts @@ -0,0 +1,7 @@ +export declare const PARALLELIZE_THRESHOLD = 30; +export interface ReduceInfo { + windowSize: number; + batchSize: number; + inSize: number; +} +export declare function computeOptimalWindowSize(inSize: number): number; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js new file mode 100644 index 0000000..cfbd2be --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js @@ -0,0 +1,12 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util_1 = require("../util"); +exports.PARALLELIZE_THRESHOLD = 30; +function computeOptimalWindowSize(inSize) { + if (inSize <= exports.PARALLELIZE_THRESHOLD) { + return inSize; + } + return util_1.nearestDivisor(inSize, Math.floor(Math.sqrt(inSize))); +} +exports.computeOptimalWindowSize = computeOptimalWindowSize; +//# sourceMappingURL=reduce_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js.map new file mode 100644 index 0000000..9654271 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduce_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reduce_util.js","sourceRoot":"","sources":["../../src/ops/reduce_util.ts"],"names":[],"mappings":";;AAqBA,gCAAuC;AAE1B,QAAA,qBAAqB,GAAG,EAAE,CAAC;AAQxC,kCAAyC,MAAc;IACrD,IAAI,MAAM,IAAI,6BAAqB,EAAE;QACnC,OAAO,MAAM,CAAC;KACf;IACD,OAAO,qBAAc,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AAC/D,CAAC;AALD,4DAKC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.d.ts new file mode 100644 index 0000000..6cc692c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.d.ts @@ -0,0 +1,26 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function logSumExp_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function sum_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function mean_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function min_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function max_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function argMin_(x: Tensor | TensorLike, axis?: number): T; +declare function argMax_(x: Tensor | TensorLike, axis?: number): T; +declare function all_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function any_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): T; +declare function moments_(x: Tensor | TensorLike, axis?: number | number[], keepDims?: boolean): { + mean: Tensor; + variance: Tensor; +}; +export declare const all: typeof all_; +export declare const any: typeof any_; +export declare const argMax: typeof argMax_; +export declare const argMin: typeof argMin_; +export declare const logSumExp: typeof logSumExp_; +export declare const max: typeof max_; +export declare const mean: typeof mean_; +export declare const min: typeof min_; +export declare const moments: typeof moments_; +export declare const sum: typeof sum_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js new file mode 100644 index 0000000..06c4b9d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js @@ -0,0 +1,213 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var axis_util = require("./axis_util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function logSumExp_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'logSumExp'); + var axes = axis_util.parseAxisParam(axis, $x.shape); + var xMax = $x.max(axes, true); + var a = $x.sub(xMax); + var b = a.exp(); + var c = b.sum(axes); + var d = c.log(); + var res = xMax.reshape(d.shape).add(d); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(res.shape, axes); + return res.reshape(newShape); + } + return res; +} +function sum_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sum'); + if ($x.dtype === 'bool') { + $x = $x.toInt(); + } + var axes = axis_util.parseAxisParam(axis, $x.shape); + var customOp = globals_1.customGrad(function (x) { + var permutation = axis_util.getAxesPermutation(axes, x.rank); + var reductionAxes = axes; + var permutedX = x; + if (permutation != null) { + permutedX = x.transpose(permutation); + reductionAxes = axis_util.getInnerMostAxes(reductionAxes.length, x.rank); + } + var value = environment_1.ENV.engine.runKernel(function (backend) { return backend.sum(permutedX, reductionAxes); }, { permutedX: permutedX }); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(value.shape, axes); + value = value.reshape(newShape); + } + var gradFunc = function (dy) { + var expandedDyShape = x.shape.slice(); + axes.forEach(function (axis) { + expandedDyShape[axis] = 1; + }); + var expandedDy = dy.reshape(expandedDyShape); + var derX = expandedDy.mul(tensor_ops_1.ones(x.shape, 'float32')); + return derX; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp($x); +} +function mean_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'mean'); + var axes = axis_util.parseAxisParam(axis, $x.shape); + var shapes = axis_util.computeOutAndReduceShapes($x.shape, axes); + var reduceShape = shapes[1]; + var reduceSize = util.sizeFromShape(reduceShape); + var customOp = globals_1.customGrad(function (x) { + var reduceSizeScalar = tensor_ops_1.scalar(reduceSize); + var xReduce = reduceSizeScalar.dtype === x.dtype ? x : x.cast(reduceSizeScalar.dtype); + var res = xReduce.div(reduceSizeScalar); + var value = res.sum(axis, keepDims); + var gradFunc = function (dy) { + var expandedDyShape = x.shape.slice(); + axes.forEach(function (axis) { + expandedDyShape[axis] = 1; + }); + var expandedDy = dy.reshape(expandedDyShape); + var derX = expandedDy.mul(tensor_ops_1.ones(x.shape, 'float32')).div(reduceSizeScalar); + return derX; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp($x); +} +function min_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'min'); + var origAxes = axis_util.parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.min($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; +} +function max_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'max'); + var origAxes = axis_util.parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.max($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; +} +function argMin_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'argMin'); + if (axis == null) { + axis = 0; + } + var axes = axis_util.parseAxisParam(axis, $x.shape); + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + return environment_1.ENV.engine.runKernel(function (backend) { return backend.argMin($x, axes[0]); }, { $x: $x }); +} +function argMax_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'argMax'); + if (axis == null) { + axis = 0; + } + var axes = axis_util.parseAxisParam(axis, $x.shape); + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + return environment_1.ENV.engine.runKernel(function (backend) { return backend.argMax($x, axes[0]); }, { $x: $x }); +} +function all_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'all', 'bool'); + util.assert($x.dtype === 'bool', "Error Tensor must be of type bool. Got: " + $x.dtype); + var origAxes = axis_util.parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.all($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; +} +function any_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'any', 'bool'); + util.assert($x.dtype === 'bool', "Error Tensor must be of type bool. Got: " + $x.dtype); + var origAxes = axis_util.parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = axis_util.getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = axis_util.getInnerMostAxes(axes.length, $x.rank); + } + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.any($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; +} +function moments_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + x = tensor_util_env_1.convertToTensor(x, 'x', 'moments'); + var axes = axis_util.parseAxisParam(axis, x.shape); + var mean = x.mean(axes, keepDims); + var keepDimsShape = mean.shape; + if (!keepDims) { + keepDimsShape = axis_util.expandShapeToKeepDim(mean.shape, axes); + } + var devSquared = x.toFloat().sub(mean.reshape(keepDimsShape)).square(); + var variance = devSquared.mean(axes, keepDims); + return { mean: mean, variance: variance }; +} +exports.all = operation_1.op({ all_: all_ }); +exports.any = operation_1.op({ any_: any_ }); +exports.argMax = operation_1.op({ argMax_: argMax_ }); +exports.argMin = operation_1.op({ argMin_: argMin_ }); +exports.logSumExp = operation_1.op({ logSumExp_: logSumExp_ }); +exports.max = operation_1.op({ max_: max_ }); +exports.mean = operation_1.op({ mean_: mean_ }); +exports.min = operation_1.op({ min_: min_ }); +exports.moments = operation_1.op({ moments_: moments_ }); +exports.sum = operation_1.op({ sum_: sum_ }); +//# sourceMappingURL=reduction_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js.map new file mode 100644 index 0000000..0106e42 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reduction_ops.js","sourceRoot":"","sources":["../../src/ops/reduction_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js new file mode 100644 index 0000000..66f10fd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js @@ -0,0 +1,968 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var reduce_util = require("./reduce_util"); +jasmine_util_1.describeWithFlags('Reduction: min', test_util_1.ALL_ENVS, function () { + it('Tensor1D', function () { + var a = tf.tensor1d([3, -1, 0, 100, -7, 2]); + test_util_1.expectNumbersClose(tf.min(a).get(), -7); + }); + it('ignores NaNs', function () { + var a = tf.tensor1d([3, NaN, 2]); + expect(tf.min(a).get()).toEqual(2); + }); + it('2D', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectNumbersClose(tf.min(a).get(), -7); + }); + it('2D axis=[0,1]', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectNumbersClose(tf.min(a, [0, 1]).get(), -7); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.min(a, 0); + expect(r.shape).toEqual([3]); + test_util_1.expectArraysClose(r, [3, -7, 0]); + }); + it('2D, axis=0, keepDims', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.min(a, 0, true); + expect(r.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(r, [3, -7, 0]); + }); + it('2D, axis=1 provided as a number', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.min(a, 1); + test_util_1.expectArraysClose(r, [2, -7]); + }); + it('2D, axis = -1 provided as a number', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.min(a, -1); + test_util_1.expectArraysClose(r, [2, -7]); + }); + it('2D, axis=[1]', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.min(a, [1]); + test_util_1.expectArraysClose(r, [2, -7]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.min({}); }) + .toThrowError(/Argument 'x' passed to 'min' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + test_util_1.expectNumbersClose(tf.min([3, -1, 0, 100, -7, 2]).get(), -7); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: max', test_util_1.ALL_ENVS, function () { + it('with one element dominating', function () { + var a = tf.tensor1d([3, -1, 0, 100, -7, 2]); + var r = tf.max(a); + test_util_1.expectNumbersClose(r.get(), 100); + }); + it('with all elements being the same', function () { + var a = tf.tensor1d([3, 3, 3]); + var r = tf.max(a); + test_util_1.expectNumbersClose(r.get(), 3); + }); + it('ignores NaNs', function () { + test_util_1.expectNumbersClose(tf.max(tf.tensor1d([3, NaN, 2])).get(), 3); + }); + it('2D', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectNumbersClose(tf.max(a).get(), 100); + }); + it('2D axis=[0,1]', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectNumbersClose(tf.max(a, [0, 1]).get(), 100); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.max(a, [0]); + expect(r.shape).toEqual([3]); + test_util_1.expectArraysClose(r, [100, -1, 2]); + }); + it('2D, axis=0, keepDims', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.max(a, [0], true); + expect(r.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(r, [100, -1, 2]); + }); + it('2D, axis=1 provided as a number', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.max(a, 1); + test_util_1.expectArraysClose(r, [5, 100]); + }); + it('2D, axis = -1 provided as a number', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.max(a, -1); + test_util_1.expectArraysClose(r, [5, 100]); + }); + it('2D, axis=[1]', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.max(a, [1]); + test_util_1.expectArraysClose(r, [5, 100]); + }); + it('6D, axis=[5]', function () { + var a = tf.range(0, 64).reshape([2, 2, 2, 2, 2, 2]); + var r = tf.max(a, [5]); + var expectedResult = [ + 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, + 33, 35, 37, 39, 41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61, 63 + ]; + test_util_1.expectArraysClose(r, expectedResult); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.max({}); }) + .toThrowError(/Argument 'x' passed to 'max' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.max([3, -1, 0, 100, -7, 2]); + test_util_1.expectNumbersClose(r.get(), 100); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: argmax', test_util_1.ALL_ENVS, function () { + it('Tensor1D', function () { + var a = tf.tensor1d([1, 0, 3, 2]); + var result = tf.argMax(a); + expect(result.dtype).toBe('int32'); + expect(result.get()).toBe(2); + }); + it('one value', function () { + var a = tf.tensor1d([10]); + var result = tf.argMax(a); + expect(result.dtype).toBe('int32'); + expect(result.get()).toBe(0); + }); + it('N > than parallelization threshold', function () { + var n = reduce_util.PARALLELIZE_THRESHOLD * 2; + var values = new Float32Array(n); + for (var i = 0; i < n; i++) { + values[i] = i; + } + var a = tf.tensor1d(values); + var result = tf.argMax(a); + expect(result.dtype).toBe('int32'); + expect(result.get()).toBe(n - 1); + }); + it('ignores NaNs', function () { + var a = tf.tensor1d([0, 3, 5, NaN, 3]); + var res = tf.argMax(a); + expect(res.dtype).toBe('int32'); + expect(res.get()).toBe(2); + }); + it('2D, no axis specified', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectArraysEqual(tf.argMax(a), [1, 0, 1]); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.argMax(a, 0); + expect(r.shape).toEqual([3]); + expect(r.dtype).toBe('int32'); + test_util_1.expectArraysEqual(r, [1, 0, 1]); + }); + it('2D, axis=1', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.argMax(a, 1); + expect(r.dtype).toBe('int32'); + test_util_1.expectArraysEqual(r, [2, 0]); + }); + it('2D, axis = -1', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, 2], [2, 3]); + var r = tf.argMax(a, -1); + expect(r.dtype).toBe('int32'); + test_util_1.expectArraysEqual(r, [2, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.argMax({}); }) + .toThrowError(/Argument 'x' passed to 'argMax' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.argMax([1, 0, 3, 2]); + expect(result.dtype).toBe('int32'); + expect(result.get()).toBe(2); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: argmin', test_util_1.ALL_ENVS, function () { + it('Tensor1D', function () { + var a = tf.tensor1d([1, 0, 3, 2]); + var result = tf.argMin(a); + expect(result.get()).toBe(1); + }); + it('one value', function () { + var a = tf.tensor1d([10]); + var result = tf.argMin(a); + expect(result.get()).toBe(0); + }); + it('N > than parallelization threshold', function () { + var n = reduce_util.PARALLELIZE_THRESHOLD * 2; + var values = new Float32Array(n); + for (var i = 0; i < n; i++) { + values[i] = n - i; + } + var a = tf.tensor1d(values); + var result = tf.argMin(a); + expect(result.dtype).toBe('int32'); + expect(result.get()).toBe(n - 1); + }); + it('ignores NaNs', function () { + var a = tf.tensor1d([5, 0, NaN, -1, 3]); + var res = tf.argMin(a); + expect(res.get()).toBe(3); + }); + it('2D, no axis specified', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + test_util_1.expectArraysEqual(tf.argMin(a), [0, 1, 0]); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([3, -1, 0, 100, -7, 2], [2, 3]); + var r = tf.argMin(a, 0); + expect(r.shape).toEqual([3]); + expect(r.dtype).toBe('int32'); + test_util_1.expectArraysEqual(r, [0, 1, 0]); + }); + it('2D, axis=1', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, -8], [2, 3]); + var r = tf.argMin(a, 1); + test_util_1.expectArraysEqual(r, [1, 2]); + }); + it('2D, axis = -1', function () { + var a = tf.tensor2d([3, 2, 5, 100, -7, -8], [2, 3]); + var r = tf.argMin(a, -1); + test_util_1.expectArraysEqual(r, [1, 2]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.argMin({}); }) + .toThrowError(/Argument 'x' passed to 'argMin' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.argMin([1, 0, 3, 2]); + expect(result.get()).toBe(1); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: logSumExp', test_util_1.ALL_ENVS, function () { + it('0', function () { + var a = tf.scalar(0); + var result = tf.logSumExp(a); + test_util_1.expectNumbersClose(result.get(), 0); + }); + it('basic', function () { + var a = tf.tensor1d([1, 2, -3]); + var result = tf.logSumExp(a); + test_util_1.expectNumbersClose(result.get(), Math.log(Math.exp(1) + Math.exp(2) + Math.exp(-3))); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1, 2, NaN]); + var result = tf.logSumExp(a); + expect(result.get()).toEqual(NaN); + }); + it('axes=0 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var r = tf.logSumExp(a, [0]); + expect(r.shape).toEqual([2]); + var expected = [ + Math.log(Math.exp(1) + Math.exp(3) + Math.exp(0)), + Math.log(Math.exp(2) + Math.exp(0) + Math.exp(1)) + ]; + test_util_1.expectArraysClose(r, expected); + }); + it('axes=0 in 2D array, keepDims', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var r = tf.logSumExp(a, [0], true); + expect(r.shape).toEqual([1, 2]); + var expected = [ + Math.log(Math.exp(1) + Math.exp(3) + Math.exp(0)), + Math.log(Math.exp(2) + Math.exp(0) + Math.exp(1)) + ]; + test_util_1.expectArraysClose(r, expected); + }); + it('axes=1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.logSumExp(a, [1]); + expect(res.shape).toEqual([3]); + var expected = [ + Math.log(Math.exp(1) + Math.exp(2)), + Math.log(Math.exp(3) + Math.exp(0)), + Math.log(Math.exp(0) + Math.exp(1)), + ]; + test_util_1.expectArraysClose(res, expected); + }); + it('axes = -1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.logSumExp(a, -1); + expect(res.shape).toEqual([3]); + var expected = [ + Math.log(Math.exp(1) + Math.exp(2)), + Math.log(Math.exp(3) + Math.exp(0)), + Math.log(Math.exp(0) + Math.exp(1)), + ]; + test_util_1.expectArraysClose(res, expected); + }); + it('2D, axes=1 provided as a single digit', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var res = tf.logSumExp(a, 1); + expect(res.shape).toEqual([2]); + var expected = [ + Math.log(Math.exp(1) + Math.exp(2) + Math.exp(3)), + Math.log(Math.exp(0) + Math.exp(0) + Math.exp(1)) + ]; + test_util_1.expectArraysClose(res, expected); + }); + it('axes=0,1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.logSumExp(a, [0, 1]); + expect(res.shape).toEqual([]); + var expected = [Math.log(Math.exp(1) + Math.exp(2) + Math.exp(3) + Math.exp(0) + Math.exp(0) + + Math.exp(1))]; + test_util_1.expectArraysClose(res, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.logSumExp({}); }) + .toThrowError(/Argument 'x' passed to 'logSumExp' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.logSumExp([1, 2, -3]); + test_util_1.expectNumbersClose(result.get(), Math.log(Math.exp(1) + Math.exp(2) + Math.exp(-3))); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: sum', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var result = tf.sum(a); + test_util_1.expectNumbersClose(result.get(), 7); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([1, 2, 3, NaN, 0, 1], [3, 2]); + expect(tf.sum(a).get()).toEqual(NaN); + }); + it('sum over dtype int32', function () { + var a = tf.tensor1d([1, 5, 7, 3], 'int32'); + var sum = tf.sum(a); + expect(sum.get()).toBe(16); + }); + it('sum over dtype bool', function () { + var a = tf.tensor1d([true, false, false, true, true], 'bool'); + var sum = tf.sum(a); + expect(sum.get()).toBe(3); + }); + it('sums all values in 2D array with keep dim', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, null, true); + expect(res.shape).toEqual([1, 1]); + test_util_1.expectArraysClose(res, [7]); + }); + it('sums across axis=0 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, [0]); + expect(res.shape).toEqual([2]); + test_util_1.expectArraysClose(res, [4, 3]); + }); + it('sums across axis=0 in 2D array, keepDims', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, [0], true); + expect(res.shape).toEqual([1, 2]); + test_util_1.expectArraysClose(res, [4, 3]); + }); + it('sums across axis=1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, [1]); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [3, 3, 1]); + }); + it('2D, axis=1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var res = tf.sum(a, 1); + expect(res.shape).toEqual([2]); + test_util_1.expectArraysClose(res, [6, 1]); + }); + it('2D, axis = -1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var res = tf.sum(a, -1); + expect(res.shape).toEqual([2]); + test_util_1.expectArraysClose(res, [6, 1]); + }); + it('sums across axis=0,1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, [0, 1]); + expect(res.shape).toEqual([]); + test_util_1.expectArraysClose(res, [7]); + }); + it('2D, axis=[-1,-2] in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.sum(a, [-1, -2]); + expect(res.shape).toEqual([]); + test_util_1.expectArraysClose(res, [7]); + }); + it('gradients: sum(2d)', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var dy = tf.scalar(10); + var gradients = tf.grad(function (a) { return a.sum(); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [10, 10, 10, 10, 10, 10]); + }); + it('gradients: sum(2d, axis=0)', function () { + var a = tf.tensor2d([[1, 2], [3, 0], [0, 1]], [3, 2]); + var dy = tf.tensor1d([10, 20]); + var axis = 0; + var gradients = tf.grad(function (a) { return a.sum(axis); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [10, 20, 10, 20, 10, 20]); + }); + it('gradients: sum(2d, axis=1)', function () { + var a = tf.tensor2d([[1, 2], [3, 0], [0, 1]], [3, 2]); + var dy = tf.tensor1d([10, 20, 30]); + var axis = 1; + var gradients = tf.grad(function (a) { return a.sum(axis); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [10, 10, 20, 20, 30, 30]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sum({}); }) + .toThrowError(/Argument 'x' passed to 'sum' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.sum([[1, 2], [3, 0], [0, 1]]); + test_util_1.expectNumbersClose(result.get(), 7); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: mean', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var r = tf.mean(a); + expect(r.dtype).toBe('float32'); + test_util_1.expectNumbersClose(r.get(), 7 / 6); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([1, 2, 3, NaN, 0, 1], [3, 2]); + var r = tf.mean(a); + expect(r.dtype).toBe('float32'); + expect(r.get()).toEqual(NaN); + }); + it('mean(int32) => float32', function () { + var a = tf.tensor1d([1, 5, 7, 3], 'int32'); + var r = tf.mean(a); + expect(r.dtype).toBe('float32'); + test_util_1.expectNumbersClose(r.get(), 4); + }); + it('mean(bool) => float32', function () { + var a = tf.tensor1d([true, false, false, true, true], 'bool'); + var r = tf.mean(a); + expect(r.dtype).toBe('float32'); + test_util_1.expectNumbersClose(r.get(), 3 / 5); + }); + it('2D array with keep dim', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, null, true); + expect(res.shape).toEqual([1, 1]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [7 / 6]); + }); + it('axis=0 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, [0]); + expect(res.shape).toEqual([2]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [4 / 3, 1]); + }); + it('axis=0 in 2D array, keepDims', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, [0], true); + expect(res.shape).toEqual([1, 2]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [4 / 3, 1]); + }); + it('axis=1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, [1]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [1.5, 1.5, 0.5]); + }); + it('axis = -1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, [-1]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [1.5, 1.5, 0.5]); + }); + it('2D, axis=1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var res = tf.mean(a, 1); + expect(res.shape).toEqual([2]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [2, 1 / 3]); + }); + it('axis=0,1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var res = tf.mean(a, [0, 1]); + expect(res.shape).toEqual([]); + expect(res.dtype).toBe('float32'); + test_util_1.expectArraysClose(res, [7 / 6]); + }); + it('gradients', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var dy = tf.scalar(1.5); + var da = tf.grad(function (a) { return a.mean(); })(a, dy); + expect(da.shape).toEqual(a.shape); + test_util_1.expectArraysClose(da, [ + dy.get() / a.size, dy.get() / a.size, dy.get() / a.size, + dy.get() / a.size, dy.get() / a.size, dy.get() / a.size + ]); + }); + it('gradients throws for defined axis', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var dy = tf.scalar(1.5); + expect(function () { return tf.grad(function (a) { return a.mean(1); })(a, dy); }).toThrowError(); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.mean({}); }) + .toThrowError(/Argument 'x' passed to 'mean' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.mean([[1, 2, 3], [0, 0, 1]]); + expect(r.dtype).toBe('float32'); + test_util_1.expectNumbersClose(r.get(), 7 / 6); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: moments', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var _a = tf.moments(a), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(variance.dtype).toBe('float32'); + test_util_1.expectNumbersClose(mean.get(), 7 / 6); + test_util_1.expectNumbersClose(variance.get(), 1.1389); + }); + it('propagates NaNs', function () { + var a = tf.tensor2d([1, 2, 3, NaN, 0, 1], [3, 2]); + var _a = tf.moments(a), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(variance.dtype).toBe('float32'); + expect(mean.get()).toEqual(NaN); + expect(variance.get()).toEqual(NaN); + }); + it('moments(int32) => float32', function () { + var a = tf.tensor1d([1, 5, 7, 3], 'int32'); + var _a = tf.moments(a), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(variance.dtype).toBe('float32'); + test_util_1.expectNumbersClose(mean.get(), 4); + test_util_1.expectNumbersClose(variance.get(), 5); + }); + it('moments(bool) => float32', function () { + var a = tf.tensor1d([true, false, false, true, true], 'bool'); + var _a = tf.moments(a), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(variance.dtype).toBe('float32'); + test_util_1.expectNumbersClose(mean.get(), 3 / 5); + test_util_1.expectNumbersClose(variance.get(), 0.23999998); + }); + it('2D array with keep dim', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var _a = tf.moments(a, null, true), mean = _a.mean, variance = _a.variance; + expect(mean.shape).toEqual([1, 1]); + expect(mean.dtype).toBe('float32'); + expect(variance.shape).toEqual([1, 1]); + expect(variance.dtype).toBe('float32'); + test_util_1.expectArraysClose(mean, [7 / 6]); + test_util_1.expectArraysClose(variance, [1.138889]); + }); + it('axis=0 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var _a = tf.moments(a, [0]), mean = _a.mean, variance = _a.variance; + expect(mean.shape).toEqual([2]); + expect(mean.dtype).toBe('float32'); + expect(variance.shape).toEqual([2]); + expect(variance.dtype).toBe('float32'); + test_util_1.expectArraysClose(mean, [4 / 3, 1]); + test_util_1.expectArraysClose(variance, [1.556, 2 / 3]); + }); + it('axis=1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var _a = tf.moments(a, [1]), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(mean.shape).toEqual([3]); + expect(variance.dtype).toBe('float32'); + expect(variance.shape).toEqual([3]); + test_util_1.expectArraysClose(mean, [1.5, 1.5, 0.5]); + test_util_1.expectArraysClose(variance, [0.25, 2.25, 0.25]); + }); + it('2D, axis=1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var _a = tf.moments(a, 1), mean = _a.mean, variance = _a.variance; + expect(mean.shape).toEqual([2]); + expect(mean.dtype).toBe('float32'); + expect(variance.shape).toEqual([2]); + expect(variance.dtype).toBe('float32'); + test_util_1.expectArraysClose(mean, [2, 1 / 3]); + test_util_1.expectArraysClose(variance, [2 / 3, 0.222]); + }); + it('2D, axis=-1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var _a = tf.moments(a, -1), mean = _a.mean, variance = _a.variance; + expect(mean.shape).toEqual([2]); + expect(mean.dtype).toBe('float32'); + expect(variance.shape).toEqual([2]); + expect(variance.dtype).toBe('float32'); + test_util_1.expectArraysClose(mean, [2, 1 / 3]); + test_util_1.expectArraysClose(variance, [2 / 3, 0.222]); + }); + it('axis=0,1 in 2D array', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var _a = tf.moments(a, [0, 1]), mean = _a.mean, variance = _a.variance; + expect(mean.shape).toEqual([]); + expect(mean.dtype).toBe('float32'); + expect(variance.shape).toEqual([]); + expect(variance.dtype).toBe('float32'); + test_util_1.expectArraysClose(mean, [7 / 6]); + test_util_1.expectArraysClose(variance, [1.1389]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.moments({}); }) + .toThrowError(/Argument 'x' passed to 'moments' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var _a = tf.moments([1, 2, 3, 0, 0, 1]), mean = _a.mean, variance = _a.variance; + expect(mean.dtype).toBe('float32'); + expect(variance.dtype).toBe('float32'); + test_util_1.expectNumbersClose(mean.get(), 7 / 6); + test_util_1.expectNumbersClose(variance.get(), 1.1389); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: norm', test_util_1.ALL_ENVS, function () { + it('scalar norm', function () { + var a = tf.scalar(-22.0); + var norm = tf.norm(a); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 22); + }); + it('vector inf norm', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + var norm = tf.norm(a, Infinity); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 4); + }); + it('vector -inf norm', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + var norm = tf.norm(a, -Infinity); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 1); + }); + it('vector 1 norm', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + var norm = tf.norm(a, 1); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 10); + }); + it('vector euclidean norm', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + var norm = tf.norm(a, 'euclidean'); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 5.4772); + }); + it('vector 2-norm', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + var norm = tf.norm(a, 2); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 5.4772); + }); + it('vector >2-norm to throw error', function () { + var a = tf.tensor1d([1, -2, 3, -4]); + expect(function () { return tf.norm(a, 3); }).toThrowError(); + }); + it('matrix inf norm', function () { + var a = tf.tensor2d([1, 2, -3, 1, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [0, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 4); + }); + it('matrix -inf norm', function () { + var a = tf.tensor2d([1, 2, -3, 1, 0, 1], [3, 2]); + var norm = tf.norm(a, -Infinity, [0, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 1); + }); + it('matrix 1 norm', function () { + var a = tf.tensor2d([1, 2, -3, 1, 1, 1], [3, 2]); + var norm = tf.norm(a, 1, [0, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 5); + }); + it('matrix euclidean norm', function () { + var a = tf.tensor2d([1, 2, -3, 1, 1, 1], [3, 2]); + var norm = tf.norm(a, 'euclidean', [0, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 4.123); + }); + it('matrix fro norm', function () { + var a = tf.tensor2d([1, 2, -3, 1, 1, 1], [3, 2]); + var norm = tf.norm(a, 'fro', [0, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 4.123); + }); + it('matrix other norm to throw error', function () { + var a = tf.tensor2d([1, 2, -3, 1, 1, 1], [3, 2]); + expect(function () { return tf.norm(a, 2, [0, 1]); }).toThrowError(); + }); + it('propagates NaNs for norm', function () { + var a = tf.tensor2d([1, 2, 3, NaN, 0, 1], [3, 2]); + var norm = tf.norm(a); + expect(norm.dtype).toBe('float32'); + expect(norm.get()).toEqual(NaN); + }); + it('axis=null in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity); + expect(norm.shape).toEqual([]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('2D array norm with keep dim', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, null, true); + expect(norm.shape).toEqual([1, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('axis=0 in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [0]); + expect(norm.shape).toEqual([2]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3, 2]); + }); + it('axis=1 in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [1]); + expect(norm.dtype).toBe('float32'); + expect(norm.shape).toEqual([3]); + test_util_1.expectArraysClose(norm, [2, 3, 1]); + }); + it('axis=1 keepDims in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [1], true); + expect(norm.dtype).toBe('float32'); + expect(norm.shape).toEqual([3, 1]); + test_util_1.expectArraysClose(norm, [2, 3, 1]); + }); + it('2D norm with axis=1 provided as number', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [2, 3]); + var norm = tf.norm(a, Infinity, 1); + expect(norm.shape).toEqual([2]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3, 1]); + }); + it('axis=0,1 in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [0, 1]); + expect(norm.shape).toEqual([]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('axis=0,1 keepDims in 2D array norm', function () { + var a = tf.tensor2d([1, 2, 3, 0, 0, 1], [3, 2]); + var norm = tf.norm(a, Infinity, [0, 1], true); + expect(norm.shape).toEqual([1, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('3D norm axis=0,1, matrix inf norm', function () { + var a = tf.tensor3d([1, 2, -3, 1, 0, 1], [3, 2, 1]); + var norm = tf.norm(a, Infinity, [0, 1]); + expect(norm.shape).toEqual([1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [4]); + }); + it('axis=0,1 keepDims in 3D array norm', function () { + var a = tf.tensor3d([1, 2, 3, 0, 0, 1], [3, 2, 1]); + var norm = tf.norm(a, Infinity, [0, 1], true); + expect(norm.shape).toEqual([1, 1, 1]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('axis=0,1 keepDims in 3D array norm', function () { + var a = tf.tensor3d([1, 2, 3, 0, 0, 1, 1, 2, 3, 0, 0, 1], [3, 2, 2]); + var norm = tf.norm(a, Infinity, [0, 1], true); + expect(norm.shape).toEqual([1, 1, 2]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [4, 3]); + }); + it('axis=null in 3D array norm', function () { + var a = tf.tensor3d([1, 2, 3, 0, 0, 1], [3, 2, 1]); + var norm = tf.norm(a, Infinity); + expect(norm.shape).toEqual([]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('axis=null in 4D array norm', function () { + var a = tf.tensor4d([1, 2, 3, 0, 0, 1], [3, 2, 1, 1]); + var norm = tf.norm(a, Infinity); + expect(norm.shape).toEqual([]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [3]); + }); + it('axis=0,1 in 4D array norm', function () { + var a = tf.tensor4d([ + 1, 2, 3, 0, 0, 1, 1, 2, 3, 0, 0, 1, + 1, 2, 3, 0, 0, 1, 1, 2, 3, 0, 0, 1 + ], [3, 2, 2, 2]); + var norm = tf.norm(a, Infinity, [0, 1]); + expect(norm.shape).toEqual([2, 2]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [4, 3, 4, 3]); + }); + it('axis=0,1 in 4D array norm', function () { + var a = tf.tensor4d([ + 1, 2, 3, 0, 0, 1, 1, 2, 3, 0, 0, 1, + 1, 2, 3, 0, 0, 1, 1, 2, 3, 0, 0, 1 + ], [3, 2, 2, 2]); + var norm = tf.norm(a, Infinity, [0, 1], true); + expect(norm.shape).toEqual([1, 1, 2, 2]); + expect(norm.dtype).toBe('float32'); + test_util_1.expectArraysClose(norm, [4, 3, 4, 3]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.norm({}); }) + .toThrowError(/Argument 'x' passed to 'norm' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var norm = tf.norm([1, -2, 3, -4], 1); + expect(norm.dtype).toBe('float32'); + test_util_1.expectNumbersClose(norm.get(), 10); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: all', test_util_1.ALL_ENVS, function () { + it('Tensor1D', function () { + var a = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectNumbersClose(tf.all(a).get(), 0); + a = tf.tensor1d([1, 0, 1], 'bool'); + test_util_1.expectNumbersClose(tf.all(a).get(), 0); + a = tf.tensor1d([1, 1, 1], 'bool'); + test_util_1.expectNumbersClose(tf.all(a).get(), 1); + }); + it('ignores NaNs', function () { + var a = tf.tensor1d([1, NaN, 1], 'bool'); + expect(tf.all(a).get()).toEqual(1); + }); + it('2D', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool'); + test_util_1.expectNumbersClose(tf.all(a).get(), 0); + }); + it('2D axis=[0,1]', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + test_util_1.expectNumbersClose(tf.all(a, [0, 1]).get(), 0); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool'); + var r = tf.all(a, 0); + expect(r.shape).toEqual([2]); + test_util_1.expectArraysClose(r, [0, 0]); + r = tf.all(a, 1); + expect(r.shape).toEqual([2]); + test_util_1.expectArraysClose(r, [1, 0]); + }); + it('2D, axis=0, keepDims', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = a.all(0, true); + expect(r.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(r, [0, 1, 0]); + }); + it('2D, axis=1 provided as a number', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.all(a, 1); + test_util_1.expectArraysClose(r, [0, 0]); + }); + it('2D, axis = -1 provided as a number', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.all(a, -1); + test_util_1.expectArraysClose(r, [0, 0]); + }); + it('2D, axis=[1]', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.all(a, [1]); + test_util_1.expectArraysClose(r, [0, 0]); + }); + it('throws when dtype is not boolean', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2]); + expect(function () { return tf.all(a); }).toThrowError(/Error Tensor must be of type bool/); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.all({}); }) + .toThrowError(/Argument 'x' passed to 'all' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [0, 0, 0]; + test_util_1.expectNumbersClose(tf.all(a).get(), 0); + }); +}); +jasmine_util_1.describeWithFlags('Reduction: any', test_util_1.ALL_ENVS, function () { + it('Tensor1D', function () { + var a = tf.tensor1d([0, 0, 0], 'bool'); + test_util_1.expectNumbersClose(tf.any(a).get(), 0); + a = tf.tensor1d([1, 0, 1], 'bool'); + test_util_1.expectNumbersClose(tf.any(a).get(), 1); + a = tf.tensor1d([1, 1, 1], 'bool'); + test_util_1.expectNumbersClose(tf.any(a).get(), 1); + }); + it('ignores NaNs', function () { + var a = tf.tensor1d([1, NaN, 0], 'bool'); + expect(tf.any(a).get()).toEqual(1); + }); + it('2D', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool'); + test_util_1.expectNumbersClose(tf.any(a).get(), 1); + }); + it('2D axis=[0,1]', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + test_util_1.expectNumbersClose(tf.any(a, [0, 1]).get(), 1); + }); + it('2D, axis=0', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool'); + var r = tf.any(a, 0); + expect(r.shape).toEqual([2]); + test_util_1.expectArraysClose(r, [1, 1]); + r = tf.any(a, 1); + expect(r.shape).toEqual([2]); + test_util_1.expectArraysClose(r, [1, 0]); + }); + it('2D, axis=0, keepDims', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = a.any(0, true); + expect(r.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(r, [1, 1, 0]); + }); + it('2D, axis=1 provided as a number', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.any(a, 1); + test_util_1.expectArraysClose(r, [1, 1]); + }); + it('2D, axis = -1 provided as a number', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.any(a, -1); + test_util_1.expectArraysClose(r, [1, 1]); + }); + it('2D, axis=[1]', function () { + var a = tf.tensor2d([1, 1, 0, 0, 1, 0], [2, 3], 'bool'); + var r = tf.any(a, [1]); + test_util_1.expectArraysClose(r, [1, 1]); + }); + it('throws when dtype is not boolean', function () { + var a = tf.tensor2d([1, 1, 0, 0], [2, 2]); + expect(function () { return tf.any(a); }).toThrowError(/Error Tensor must be of type bool/); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.any({}); }) + .toThrowError(/Argument 'x' passed to 'any' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [0, 0, 0]; + test_util_1.expectNumbersClose(tf.any(a).get(), 0); + }); +}); +//# sourceMappingURL=reduction_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js.map new file mode 100644 index 0000000..39242a2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reduction_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reduction_ops_test.js","sourceRoot":"","sources":["../../src/ops/reduction_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.d.ts new file mode 100644 index 0000000..4abc49f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.d.ts @@ -0,0 +1,13 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function relu_(x: T | TensorLike): T; +declare function elu_(x: T | TensorLike): T; +declare function selu_(x: T | TensorLike): T; +declare function leakyRelu_(x: T | TensorLike, alpha?: number): T; +declare function prelu_(x: T | TensorLike, alpha: T | TensorLike): T; +export declare const elu: typeof elu_; +export declare const leakyRelu: typeof leakyRelu_; +export declare const prelu: typeof prelu_; +export declare const relu: typeof relu_; +export declare const selu: typeof selu_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js new file mode 100644 index 0000000..d33deef --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js @@ -0,0 +1,65 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var binary_ops_1 = require("./binary_ops"); +var logical_ops_1 = require("./logical_ops"); +var operation_1 = require("./operation"); +var selu_util_1 = require("./selu_util"); +var tensor_ops_1 = require("./tensor_ops"); +function relu_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'relu'); + if ($x.dtype === 'bool') { + return $x.toInt(); + } + var grad = function (dy) { + var stepRes = $x.step(); + return { $x: function () { return dy.mulStrict(stepRes.toFloat()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.relu($x); }, { $x: $x }, grad); +} +function elu_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'elu'); + var grad = function (dy, saved) { + var y = saved[0]; + return { + $x: function () { + return environment_1.ENV.engine.runKernel(function (backend) { return backend.eluDer(dy, y); }, { dy: dy, y: y }); + } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.elu($x)); }, { $x: $x }, grad); +} +function selu_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'selu'); + var grad = function (dy) { + return { + $x: function () { + var mask = $x.greater(tensor_ops_1.scalar(0)); + var scaleAlpha = tensor_ops_1.scalar(selu_util_1.SELU_SCALEALPHA); + var scale = tensor_ops_1.scalar(selu_util_1.SELU_SCALE); + var greaterThanZeroDer = dy.mul(scale); + var lessEqualZeroDer = dy.mul(scaleAlpha).mul($x.toFloat().exp()); + return logical_ops_1.where(mask, greaterThanZeroDer, lessEqualZeroDer); + } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.selu($x); }, { $x: $x }, grad); +} +function leakyRelu_(x, alpha) { + if (alpha === void 0) { alpha = 0.2; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'leakyRelu'); + return binary_ops_1.maximum(tensor_ops_1.scalar(alpha).mul($x), $x); +} +function prelu_(x, alpha) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'prelu'); + var $alpha = tensor_util_env_1.convertToTensor(alpha, 'alpha', 'prelu'); + var zero = tensor_ops_1.scalar(0); + return binary_ops_1.maximum(zero, $x).add($alpha.mul(binary_ops_1.minimum(zero, $x))); +} +exports.elu = operation_1.op({ elu_: elu_ }); +exports.leakyRelu = operation_1.op({ leakyRelu_: leakyRelu_ }); +exports.prelu = operation_1.op({ prelu_: prelu_ }); +exports.relu = operation_1.op({ relu_: relu_ }); +exports.selu = operation_1.op({ selu_: selu_ }); +//# sourceMappingURL=relu_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js.map new file mode 100644 index 0000000..4041d22 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/relu_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"relu_ops.js","sourceRoot":"","sources":["../../src/ops/relu_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js new file mode 100644 index 0000000..440ac9d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js @@ -0,0 +1,678 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('resizeBilinear', test_util_1.ALL_ENVS, function () { + it('simple alignCorners=false', function () { + var input = tf.tensor3d([2, 2, 4, 4], [2, 2, 1]); + var output = input.resizeBilinear([3, 3], false); + test_util_1.expectArraysClose(output, [2, 2, 2, 10 / 3, 10 / 3, 10 / 3, 4, 4, 4]); + }); + it('simple alignCorners=true', function () { + var input = tf.tensor3d([2, 2, 4, 4], [2, 2, 1]); + var output = input.resizeBilinear([3, 3], true); + test_util_1.expectArraysClose(output, [2, 2, 2, 3, 3, 3, 4, 4, 4]); + }); + it('matches tensorflow w/ random numbers alignCorners=false', function () { + var input = tf.tensor3d([ + 1.19074044, 0.91373104, 2.01611669, -0.52270832, 0.38725395, + 1.30809779, 0.61835143, 3.49600659, 2.09230986, 0.56473997, + 0.03823943, 1.19864896 + ], [2, 3, 2]); + var output = input.resizeBilinear([4, 5], false); + test_util_1.expectArraysClose(output, [ + 1.19074047, 0.91373104, 1.68596613, 0.05186744, 1.69034398, -0.15654698, + 0.7130264, 0.94193673, 0.38725394, 1.30809784, 0.9045459, 2.20486879, + 1.59434628, 0.89455694, 1.68591988, 0.26748738, 0.58103991, 1.00690198, + 0.21274668, 1.25337338, 0.6183514, 3.49600649, 1.50272655, 1.73724651, + 1.68149579, 0.69152176, 0.44905344, 1.07186723, 0.03823943, 1.19864893, + 0.6183514, 3.49600649, 1.50272655, 1.73724651, 1.68149579, 0.69152176, + 0.44905344, 1.07186723, 0.03823943, 1.19864893 + ]); + }); + it('matches tensorflow w/ random numbers alignCorners=true', function () { + var input = tf.tensor3d([ + 1.56324531, 2.13817752, 1.44398421, 1.07632684, 0.59306785, + -0.36970865, 1.62451879, 1.8367334, 1.13944798, 2.01993218, + 2.01919952, 2.67524054 + ], [2, 3, 2]); + var output = input.resizeBilinear([4, 5], true); + test_util_1.expectArraysClose(output, [ + 1.5632453, 2.13817763, 1.50361478, 1.60725224, 1.44398427, 1.07632685, + 1.01852608, 0.35330909, 0.59306782, -0.36970866, 1.58366978, 2.03769612, + 1.46307099, 1.71427906, 1.3424722, 1.39086199, 1.20545864, 1.01806819, + 1.06844509, 0.6452744, 1.60409427, 1.93721485, 1.42252707, 1.82130599, + 1.24096, 1.70539713, 1.3923912, 1.68282723, 1.54382229, 1.66025746, + 1.62451875, 1.83673346, 1.38198328, 1.92833281, 1.13944793, 2.01993227, + 1.57932377, 2.34758639, 2.01919961, 2.67524052 + ]); + }); + it('batch of 2, simple, alignCorners=true', function () { + var input = tf.tensor4d([2, 2, 4, 4, 3, 3, 5, 5], [2, 2, 2, 1]); + var output = input.resizeBilinear([3, 3], true); + test_util_1.expectArraysClose(output, [2, 2, 2, 3, 3, 3, 4, 4, 4, 3, 3, 3, 4, 4, 4, 5, 5, 5]); + }); + it('target width = 1, alignCorners=true', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var output = input.resizeBilinear([3, 1], true); + var expected = tf.tensor3d([ + [[120.68857, 134.51639, 83.03671]], + [[111.243576, 106.04915, 111.55249]], + [[104.87508, 134.01892, 111.026276]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('target height = 1, alignCorners=true', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var output = input.resizeBilinear([1, 3], true); + var expected = tf.tensor3d([[ + [120.68857, 134.51639, 83.03671], + [100.481895, 107.57982, 120.4335], + [96.31679, 111.77168, 83.7351] + ]]); + test_util_1.expectArraysClose(output, expected); + }); + it('throws when passed a non-tensor', function () { + var e = /Argument 'images' passed to 'resizeBilinear' must be a Tensor/; + expect(function () { return tf.image.resizeBilinear({}, [ + 1, 1 + ]); }).toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var input = [[[2], [2]], [[4], [4]]]; + var output = tf.image.resizeBilinear(input, [3, 3], false); + test_util_1.expectArraysClose(output, [2, 2, 2, 10 / 3, 10 / 3, 10 / 3, 4, 4, 4]); + }); +}); +jasmine_util_1.describeWithFlags('resizeBilinear gradients', test_util_1.ALL_ENVS, function () { + it('greyscale: upscale, same aspect ratio', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]] + ]); + var size = [4, 4]; + var alignCorners = false; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([[[6.0], [17.0]], [[38.0], [75.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, same aspect ratio, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]] + ]); + var size = [4, 4]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[17.333330154418945], [23.999998092651367]], + [[44.0], [50.66666793823242]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, taller than wider', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]], + [[17.0], [18.0], [19.0], [20.0]], [[21.0], [22.0], [23.0], [24.0]], + [[25.0], [26.0], [27.0], [28.0]], [[29.0], [30.0], [31.0], [32.0]], + [[33.0], [34.0], [35.0], [36.0]] + ]); + var size = [9, 4]; + var alignCorners = false; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[25.55555534362793], [55.5555534362793]], + [[208.44444274902344], [376.4444274902344]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, taller than wider, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]], + [[17.0], [18.0], [19.0], [20.0]], [[21.0], [22.0], [23.0], [24.0]], + [[25.0], [26.0], [27.0], [28.0]], [[29.0], [30.0], [31.0], [32.0]], + [[33.0], [34.0], [35.0], [36.0]] + ]); + var size = [9, 4]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[99.0], [114.0]], [[219.00001525878906], [233.99998474121094]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, wider than taller', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0], [7.0]], + [[8.0], [9.0], [10.0], [11.0], [12.0], [13.0], [14.0]], + [[15.0], [16.0], [17.0], [18.0], [19.0], [20.0], [21.0]], + [[22.0], [23.0], [24.0], [25.0], [26.0], [27.0], [28.0]] + ]); + var size = [4, 7]; + var alignCorners = false; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[14.428570747375488], [52.07142639160156]], + [[98.71427917480469], [240.78573608398438]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, wider than taller, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0], [7.0]], + [[8.0], [9.0], [10.0], [11.0], [12.0], [13.0], [14.0]], + [[15.0], [16.0], [17.0], [18.0], [19.0], [20.0], [21.0]], + [[22.0], [23.0], [24.0], [25.0], [26.0], [27.0], [28.0]] + ]); + var size = [4, 7]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([[[51.33332824707031], [70.0]], [[133.0], [151.66668701171875]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same aspect ratio', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [2.0], [0.0]], [[0.0], [0.0], [0.0], [0.0]], + [[3.0], [0.0], [4.0], [0.0]], [[0.0], [0.0], [0.0], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same aspect ratio, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [0.0], [2.0]], [[0.0], [0.0], [0.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]], [[3.0], [0.0], [0.0], [4.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]], [[5.0], [6.0]]]); + var size = [3, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [2.0], [0.0]], + [[1.9999998807907104], [0.0], [2.6666665077209473], [0.0]], + [[2.6666665077209473], [0.0], [3.3333330154418945], [0.0]], + [[3.333333730697632], [0.0], [4.000000476837158], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]], [[5.0], [6.0]]]); + var size = [3, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [0.0], [2.0]], [[1.5], [0.0], [0.0], [2.0]], + [[1.5], [0.0], [0.0], [2.0]], [[5.0], [0.0], [0.0], [6.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, wider than taller', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0], [3.0]], [[4.0], [5.0], [6.0]]]); + var size = [2, 3]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [1.3333332538604736], [1.6666665077209473], [2.000000238418579]], + [[0.0], [0.0], [0.0], [0.0]], + [[4.0], [3.3333330154418945], [3.6666665077209473], [4.000000476837158]], + [[0.0], [0.0], [0.0], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, wider than taller, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0], [3.0]], [[4.0], [5.0], [6.0]]]); + var size = [2, 3]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [1.0], [1.0], [3.0]], [[0.0], [0.0], [0.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]], [[4.0], [2.5], [2.5], [6.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: same size', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: same size, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: upscale, wider than taller', function () { + var input = tf.tensor3d([ + [ + [115.11029815673828, 111.90936279296875, 66.87433624267578], + [72.03849029541016, 81.86637878417969, 119.53585815429688] + ], + [ + [68.555419921875, 97.49642181396484, 116.90741729736328], + [128.69467163085938, 86.78314208984375, 104.3116683959961] + ] + ]); + var dy = tf.tensor3d([ + [ + [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0], [10.0, 11.0, 12.0], + [13.0, 14.0, 15.0] + ], + [ + [16.0, 17.0, 18.0], [19.0, 20.0, 21.0], [22.0, 23.0, 24.0], + [25.0, 26.0, 27.0], [28.0, 29.0, 30.0] + ], + [ + [31.0, 32.0, 33.0], [34.0, 35.0, 36.0], [37.0, 38.0, 39.0], + [40.0, 41.0, 42.0], [43.0, 44.0, 45.0] + ] + ]); + var size = [3, 5]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [ + [15.399999618530273, 17.799999237060547, 20.19999885559082], + [56.26666259765625, 60.533329010009766, 64.79999542236328] + ], + [ + [80.00000762939453, 83.0, 86.0], + [178.33334350585938, 183.66668701171875, 189.00001525878906] + ] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: upscale, wider than taller, align corners', function () { + var input = tf.tensor3d([ + [ + [115.11029815673828, 111.90936279296875, 66.87433624267578], + [72.03849029541016, 81.86637878417969, 119.53585815429688] + ], + [ + [68.555419921875, 97.49642181396484, 116.90741729736328], + [128.69467163085938, 86.78314208984375, 104.3116683959961] + ] + ]); + var dy = tf.tensor3d([ + [ + [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0], [10.0, 11.0, 12.0], + [13.0, 14.0, 15.0] + ], + [ + [16.0, 17.0, 18.0], [19.0, 20.0, 21.0], [22.0, 23.0, 24.0], + [25.0, 26.0, 27.0], [28.0, 29.0, 30.0] + ], + [ + [31.0, 32.0, 33.0], [34.0, 35.0, 36.0], [37.0, 38.0, 39.0], + [40.0, 41.0, 42.0], [43.0, 44.0, 45.0] + ] + ]); + var size = [3, 5]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[33.75, 37.5, 41.25], [56.25, 60.0, 63.75]], + [[108.75, 112.5, 116.25], [131.25, 135.0, 138.75]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, taller than wider', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var dy = tf.tensor3d([[[1.0, 2.0, 3.0]], [[4.0, 5.0, 6.0]], [[7.0, 8.0, 9.0]]]); + var size = [3, 1]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [ + [2.6666665077209473, 3.3333330154418945, 3.999999761581421], + [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0] + ], + [ + [3.666666269302368, 4.3333330154418945, 4.999999523162842], + [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0] + ], + [ + [4.6666669845581055, 5.333333969116211, 6.000000953674316], + [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0] + ] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, width = 1, align corners', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var dy = tf.tensor3d([[[1.0, 2.0, 3.0]], [[4.0, 5.0, 6.0]], [[7.0, 8.0, 9.0]]]); + var size = [3, 1]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[2.0, 2.5, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[2.0, 2.5, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[7.0, 8.0, 9.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, height = 1, align corners', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var dy = tf.tensor3d([[[1., 2., 3.], [4., 5., 6.], [7., 8., 9.]]]); + var size = [1, 3]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1., 2., 3.], [2., 2.5, 3.], [2., 2.5, 3.], [7., 8., 9.]], + [[0., 0., 0.], [0., 0., 0.], [0., 0., 0.], [0., 0., 0.]], + [[0., 0., 0.], [0., 0., 0.], [0., 0., 0.], [0., 0., 0.]], + [[0., 0., 0.], [0., 0., 0.], [0., 0., 0.], [0., 0., 0.]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, taller than wider, align corners', function () { + var input = tf.tensor3d([ + [ + [120.68856811523438, 134.51638793945312, 83.03671264648438], + [121.58008575439453, 113.28836059570312, 136.3172149658203], + [79.38370513916016, 101.87127685546875, 104.54979705810547], + [96.31678771972656, 111.77168273925781, 83.73509979248047] + ], + [ + [119.45088195800781, 88.98846435546875, 97.47553253173828], + [117.5562973022461, 108.26356506347656, 99.62212371826172], + [136.62701416015625, 94.10433197021484, 80.97366333007812], + [83.61205291748047, 90.60148620605469, 81.82512664794922] + ], + [ + [103.0362777709961, 123.1098403930664, 125.62944030761719], + [92.2915267944336, 103.15729522705078, 119.18060302734375], + [102.93293762207031, 117.821044921875, 99.40152740478516], + [96.32952117919922, 105.80963134765625, 104.8491439819336] + ], + [ + [104.87507629394531, 134.0189208984375, 111.02627563476562], + [85.4534683227539, 107.68426513671875, 103.03722381591797], + [89.70533752441406, 98.25298309326172, 78.42916870117188], + [113.6744613647461, 95.8189697265625, 122.75005340576172] + ] + ]); + var dy = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]], + [[13.0, 14.0, 15.0], [16.0, 17.0, 18.0]] + ]); + var size = [3, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { return tf.image.resizeBilinear(i, size, alignCorners); }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [4.0, 5.0, 6.0]], + [[3.5, 4.0, 4.5], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [5.0, 5.5, 6.0]], + [[3.5, 4.0, 4.5], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [5.0, 5.5, 6.0]], + [ + [13.0, 14.0, 15.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], + [16.0, 17.0, 18.0] + ] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: same size', function () { + var input = tf.tensor3d([ + [ + [115.11029815673828, 111.90936279296875, 66.87433624267578], + [72.03849029541016, 81.86637878417969, 119.53585815429688] + ], + [ + [68.555419921875, 97.49642181396484, 116.90741729736328], + [128.69467163085938, 86.78314208984375, 104.3116683959961] + ] + ]); + var dy = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: same size, align corners', function () { + var input = tf.tensor3d([ + [ + [115.11029815673828, 111.90936279296875, 66.87433624267578], + [72.03849029541016, 81.86637878417969, 119.53585815429688] + ], + [ + [68.555419921875, 97.49642181396484, 116.90741729736328], + [128.69467163085938, 86.78314208984375, 104.3116683959961] + ] + ]); + var dy = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + var size = [2, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeBilinear(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); +}); +//# sourceMappingURL=resize_bilinear_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js.map new file mode 100644 index 0000000..50acb86 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_bilinear_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_bilinear_test.js","sourceRoot":"","sources":["../../src/ops/resize_bilinear_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js new file mode 100644 index 0000000..8b3f4d2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js @@ -0,0 +1,500 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('resizeNearestNeighbor', test_util_1.ALL_ENVS, function () { + it('simple alignCorners=false', function () { + var input = tf.tensor3d([2, 2, 4, 4], [2, 2, 1]); + var output = input.resizeNearestNeighbor([3, 3], false); + test_util_1.expectArraysClose(output, [2, 2, 2, 2, 2, 2, 4, 4, 4]); + }); + it('simple alignCorners=true', function () { + var input = tf.tensor3d([2, 2, 4, 4], [2, 2, 1]); + var output = input.resizeNearestNeighbor([3, 3], true); + test_util_1.expectArraysClose(output, [2, 2, 2, 4, 4, 4, 4, 4, 4]); + }); + it('matches tensorflow w/ random numbers alignCorners=false', function () { + var input = tf.tensor3d([ + 1.19074044, 0.91373104, 2.01611669, -0.52270832, 0.38725395, + 1.30809779, 0.61835143, 3.49600659, 2.09230986, 0.56473997, + 0.03823943, 1.19864896 + ], [2, 3, 2]); + var output = input.resizeNearestNeighbor([4, 5], false); + test_util_1.expectArraysClose(output, [ + 1.19074047, 0.913731039, 1.19074047, 0.913731039, 2.01611662, + -0.522708297, 2.01611662, -0.522708297, 0.38725394, 1.30809784, + 1.19074047, 0.913731039, 1.19074047, 0.913731039, 2.01611662, + -0.522708297, 2.01611662, -0.522708297, 0.38725394, 1.30809784, + 0.61835146, 3.49600649, 0.61835146, 3.49600649, 2.09230995, + 0.564739943, 2.09230995, 0.564739943, 0.0382394306, 1.19864893, + 0.61835146, 3.49600649, 0.61835146, 3.49600649, 2.09230995, + 0.564739943, 2.09230995, 0.564739943, 0.0382394306, 1.19864893 + ]); + }); + it('matches tensorflow w/ random numbers alignCorners=true', function () { + var input = tf.tensor3d([ + 1.19074044, 0.91373104, 2.01611669, -0.52270832, 0.38725395, + 1.30809779, 0.61835143, 3.49600659, 2.09230986, 0.56473997, + 0.03823943, 1.19864896 + ], [2, 3, 2]); + var output = input.resizeNearestNeighbor([4, 5], true); + test_util_1.expectArraysClose(output, [ + 1.19074044, 0.91373104, 2.01611669, -0.52270832, 2.01611669, -0.52270832, + 0.38725395, 1.30809779, 0.38725395, 1.30809779, 1.19074044, 0.91373104, + 2.01611669, -0.52270832, 2.01611669, -0.52270832, 0.38725395, 1.30809779, + 0.38725395, 1.30809779, 0.61835143, 3.49600659, 2.09230986, 0.56473997, + 2.09230986, 0.56473997, 0.03823943, 1.19864896, 0.03823943, 1.19864896, + 0.61835143, 3.49600659, 2.09230986, 0.56473997, 2.09230986, 0.56473997, + 0.03823943, 1.19864896, 0.03823943, 1.19864896 + ]); + }); + it('batch of 2, simple, alignCorners=true', function () { + var input = tf.tensor4d([2, 2, 4, 4, 3, 3, 5, 5], [2, 2, 2, 1]); + var output = input.resizeNearestNeighbor([3, 3], true); + test_util_1.expectArraysClose(output, [2, 2, 2, 4, 4, 4, 4, 4, 4, 3, 3, 3, 5, 5, 5, 5, 5, 5]); + }); + it('throws when passed a non-tensor', function () { + var e = /Argument 'images' passed to 'resizeNearestNeighbor' must be a Tensor/; + expect(function () { return tf.image.resizeNearestNeighbor({}, [ + 1, 1 + ]); }).toThrowError(e); + }); + it('accepts a tensor-like object', function () { + var input = [[[2], [2]], [[4], [4]]]; + var output = tf.image.resizeNearestNeighbor(input, [3, 3], false); + test_util_1.expectArraysClose(output, [2, 2, 2, 2, 2, 2, 4, 4, 4]); + }); + it('does not throw when some output dim is 1 and alignCorners=true', function () { + var input = tf.tensor3d([2, 2, 4, 4], [2, 2, 1]); + expect(function () { return input.resizeNearestNeighbor([1, 3], true); }).not.toThrow(); + }); +}); +jasmine_util_1.describeWithFlags('resizeNearestNeighbor gradients', test_util_1.ALL_ENVS, function () { + it('greyscale: upscale, same aspect ratio', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]] + ]); + var size = [4, 4]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[14.0], [22.0]], [[46.0], [54.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, same aspect ratio, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]] + ]); + var size = [4, 4]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[14.0], [22.0]], [[46.0], [54.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, taller than wider', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]], + [[17.0], [18.0], [19.0], [20.0]], [[21.0], [22.0], [23.0], [24.0]], + [[25.0], [26.0], [27.0], [28.0]], [[29.0], [30.0], [31.0], [32.0]], + [[33.0], [34.0], [35.0], [36.0]] + ]); + var size = [9, 4]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[95.0], [115.0]], [[220.0], [236.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, taller than wider, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0]], [[5.0], [6.0], [7.0], [8.0]], + [[9.0], [10.0], [11.0], [12.0]], [[13.0], [14.0], [15.0], [16.0]], + [[17.0], [18.0], [19.0], [20.0]], [[21.0], [22.0], [23.0], [24.0]], + [[25.0], [26.0], [27.0], [28.0]], [[29.0], [30.0], [31.0], [32.0]], + [[33.0], [34.0], [35.0], [36.0]] + ]); + var size = [9, 4]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[60.0], [76.0]], [[255.0], [275.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, wider than taller', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0], [7.0]], + [[8.0], [9.0], [10.0], [11.0], [12.0], [13.0], [14.0]], + [[15.0], [16.0], [17.0], [18.0], [19.0], [20.0], [21.0]], + [[22.0], [23.0], [24.0], [25.0], [26.0], [27.0], [28.0]] + ]); + var size = [4, 7]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[48.0], [57.0]], [[160.0], [141.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: upscale, wider than taller, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([ + [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0], [7.0]], + [[8.0], [9.0], [10.0], [11.0], [12.0], [13.0], [14.0]], + [[15.0], [16.0], [17.0], [18.0], [19.0], [20.0], [21.0]], + [[22.0], [23.0], [24.0], [25.0], [26.0], [27.0], [28.0]] + ]); + var size = [4, 7]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[33.0], [72.0]], [[117.0], [184.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same aspect ratio', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [2.0], [0.0]], [[0.0], [0.0], [0.0], [0.0]], + [[3.0], [0.0], [4.0], [0.0]], [[0.0], [0.0], [0.0], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same aspect ratio, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [0.0], [2.0]], [[0.0], [0.0], [0.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]], [[3.0], [0.0], [0.0], [4.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]], [[5.0], [6.0]]]); + var size = [3, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [2.0], [0.0]], + [[3.0], [0.0], [4.0], [0.0]], + [[5.0], [0.0], [6.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]], [[5.0], [6.0]]]); + var size = [3, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [0.0], [2.0]], + [[0.0], [0.0], [0.0], [0.0]], + [[3.0], [0.0], [0.0], [4.0]], + [[5.0], [0.0], [0.0], [6.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0], [3.0]], [[4.0], [5.0], [6.0]]]); + var size = [2, 3]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [2.0], [3.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]], + [[4.0], [5.0], [6.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, taller than wider, align corners', function () { + var input = tf.tensor3d([ + [[100.0], [50.0], [25.0], [10.0]], [[60.0], [20.0], [80.0], [20.0]], + [[40.0], [15.0], [200.0], [203.0]], [[40.0], [10.0], [230.0], [200.0]] + ]); + var dy = tf.tensor3d([[[1.0], [2.0], [3.0]], [[4.0], [5.0], [6.0]]]); + var size = [2, 3]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0], [0.0], [2.0], [3.0]], + [[0.0], [0.0], [0.0], [0.0]], + [[0.0], [0.0], [0.0], [0.0]], + [[4.0], [0.0], [5.0], [6.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same size', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('greyscale: downscale, same size, align corners', function () { + var input = tf.tensor3d([[[100.0], [50.0]], [[60.0], [20.0]]]); + var dy = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + var size = [2, 2]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([[[1.0], [2.0]], [[3.0], [4.0]]]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: upscale, wider than taller', function () { + var input = tf.tensor3d([ + [ + [100.26818084716797, 74.61857604980469, 81.62117767333984], + [127.86964416503906, 85.0583267211914, 102.95439147949219] + ], + [ + [104.3798828125, 96.70733642578125, 92.60601043701172], + [77.63021850585938, 68.55794525146484, 96.17212677001953] + ] + ]); + var dy = tf.tensor3d([ + [ + [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0], [10.0, 11.0, 12.0], + [13.0, 14.0, 15.0] + ], + [ + [16.0, 17.0, 18.0], [19.0, 20.0, 21.0], [22.0, 23.0, 24.0], + [25.0, 26.0, 27.0], [28.0, 29.0, 30.0] + ], + [ + [31.0, 32.0, 33.0], [34.0, 35.0, 36.0], [37.0, 38.0, 39.0], + [40.0, 41.0, 42.0], [43.0, 44.0, 45.0] + ] + ]); + var size = [3, 5]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[69.0, 75.0, 81.0], [76.0, 80.0, 84.0]], + [[102.0, 105.0, 108.0], [83.0, 85.0, 87.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: upscale, wider than taller, align corners', function () { + var input = tf.tensor3d([ + [ + [100.26818084716797, 74.61857604980469, 81.62117767333984], + [127.86964416503906, 85.0583267211914, 102.95439147949219] + ], + [ + [104.3798828125, 96.70733642578125, 92.60601043701172], + [77.63021850585938, 68.55794525146484, 96.17212677001953] + ] + ]); + var dy = tf.tensor3d([ + [ + [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0], [10.0, 11.0, 12.0], + [13.0, 14.0, 15.0] + ], + [ + [16.0, 17.0, 18.0], [19.0, 20.0, 21.0], [22.0, 23.0, 24.0], + [25.0, 26.0, 27.0], [28.0, 29.0, 30.0] + ], + [ + [31.0, 32.0, 33.0], [34.0, 35.0, 36.0], [37.0, 38.0, 39.0], + [40.0, 41.0, 42.0], [43.0, 44.0, 45.0] + ] + ]); + var size = [3, 5]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[5.0, 7.0, 9.0], [30.0, 33.0, 36.0]], + [[100.0, 104.0, 108.0], [195.0, 201.0, 207.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, taller than wider', function () { + var input = tf.tensor3d([ + [ + [97.98934936523438, 77.24969482421875, 113.70111846923828], + [111.34081268310547, 113.15758514404297, 157.90521240234375], + [105.77980041503906, 85.75989532470703, 69.62374114990234], + [125.94231414794922, 73.11385345458984, 87.03099822998047] + ], + [ + [62.25117111206055, 90.23927307128906, 119.1966552734375], + [93.55166625976562, 95.9106674194336, 115.56237030029297], + [102.98121643066406, 98.1983413696289, 97.55982971191406], + [86.47753143310547, 97.04051208496094, 121.50492095947266] + ], + [ + [92.4140853881836, 118.45619201660156, 108.0341796875], + [126.43061065673828, 123.28077697753906, 121.03379821777344], + [128.6694793701172, 98.47042846679688, 114.47464752197266], + [93.31566619873047, 95.2713623046875, 102.51188659667969] + ], + [ + [101.55884552001953, 83.31947326660156, 119.08016204833984], + [128.28546142578125, 92.56212615966797, 74.85054779052734], + [88.9786148071289, 119.43685913085938, 73.06110382080078], + [98.17908477783203, 105.54570007324219, 93.45832061767578] + ] + ]); + var dy = tf.tensor3d([[[1.0, 2.0, 3.0]], [[4.0, 5.0, 6.0]], [[7.0, 8.0, 9.0]]]); + var size = [3, 1]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[4.0, 5.0, 6.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[7.0, 8.0, 9.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: downscale, taller than wider, align corners', function () { + var input = tf.tensor3d([ + [ + [97.98934936523438, 77.24969482421875, 113.70111846923828], + [111.34081268310547, 113.15758514404297, 157.90521240234375], + [105.77980041503906, 85.75989532470703, 69.62374114990234], + [125.94231414794922, 73.11385345458984, 87.03099822998047] + ], + [ + [62.25117111206055, 90.23927307128906, 119.1966552734375], + [93.55166625976562, 95.9106674194336, 115.56237030029297], + [102.98121643066406, 98.1983413696289, 97.55982971191406], + [86.47753143310547, 97.04051208496094, 121.50492095947266] + ], + [ + [92.4140853881836, 118.45619201660156, 108.0341796875], + [126.43061065673828, 123.28077697753906, 121.03379821777344], + [128.6694793701172, 98.47042846679688, 114.47464752197266], + [93.31566619873047, 95.2713623046875, 102.51188659667969] + ], + [ + [101.55884552001953, 83.31947326660156, 119.08016204833984], + [128.28546142578125, 92.56212615966797, 74.85054779052734], + [88.9786148071289, 119.43685913085938, 73.06110382080078], + [98.17908477783203, 105.54570007324219, 93.45832061767578] + ] + ]); + var dy = tf.tensor3d([[[1.0, 2.0, 3.0]], [[4.0, 5.0, 6.0]], [[7.0, 8.0, 9.0]]]); + var size = [3, 1]; + var alignCorners = true; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[4.0, 5.0, 6.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], + [[7.0, 8.0, 9.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); + it('color: same size', function () { + var input = tf.tensor3d([ + [ + [100.26818084716797, 74.61857604980469, 81.62117767333984], + [127.86964416503906, 85.0583267211914, 102.95439147949219] + ], + [ + [104.3798828125, 96.70733642578125, 92.60601043701172], + [77.63021850585938, 68.55794525146484, 96.17212677001953] + ] + ]); + var dy = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + var size = [2, 2]; + var alignCorners = false; + var g = tf.grad(function (i) { + return tf.image.resizeNearestNeighbor(i, size, alignCorners); + }); + var output = g(input, dy); + var expected = tf.tensor3d([ + [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0]], + [[7.0, 8.0, 9.0], [10.0, 11.0, 12.0]] + ]); + test_util_1.expectArraysClose(output, expected); + }); +}); +//# sourceMappingURL=resize_nearest_neighbor_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js.map new file mode 100644 index 0000000..c9bba8a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/resize_nearest_neighbor_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"resize_nearest_neighbor_test.js","sourceRoot":"","sources":["../../src/ops/resize_nearest_neighbor_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.d.ts new file mode 100644 index 0000000..9af4911 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.d.ts @@ -0,0 +1,13 @@ +import { Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { TensorLike } from '../types'; +declare function reverse1d_(x: Tensor1D | TensorLike): Tensor1D; +declare function reverse2d_(x: Tensor2D | TensorLike, axis?: number | number[]): Tensor2D; +declare function reverse3d_(x: Tensor3D | TensorLike, axis?: number | number[]): Tensor3D; +declare function reverse4d_(x: Tensor4D | TensorLike, axis?: number | number[]): Tensor4D; +declare function reverse_(x: T | TensorLike, axis?: number | number[]): T; +export declare const reverse: typeof reverse_; +export declare const reverse1d: typeof reverse1d_; +export declare const reverse2d: typeof reverse2d_; +export declare const reverse3d: typeof reverse3d_; +export declare const reverse4d: typeof reverse4d_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js new file mode 100644 index 0000000..097c5b4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js @@ -0,0 +1,45 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var axis_util_1 = require("./axis_util"); +var operation_1 = require("./operation"); +function reverse1d_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reverse'); + util.assert($x.rank === 1, "Error in reverse1D: x must be rank 1 but got\n rank " + $x.rank + "."); + return exports.reverse($x, 0); +} +function reverse2d_(x, axis) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reverse'); + util.assert($x.rank === 2, "Error in reverse2D: x must be rank 2 but got\n rank " + $x.rank + "."); + return exports.reverse($x, axis); +} +function reverse3d_(x, axis) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reverse'); + util.assert($x.rank === 3, "Error in reverse3D: x must be rank 3 but got\n rank " + $x.rank + "."); + return exports.reverse($x, axis); +} +function reverse4d_(x, axis) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reverse'); + util.assert($x.rank === 4, "Error in reverse4D: x must be rank 4 but got\n rank " + $x.rank + "."); + return exports.reverse($x, axis); +} +function reverse_(x, axis) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reverse'); + if ($x.rank === 0) { + return $x.clone(); + } + var axes = axis_util_1.parseAxisParam(axis, $x.shape); + var grad = function (dy) { + return { $x: function () { return dy.reverse(axes); } }; + }; + var res = environment_1.ENV.engine.runKernel(function (backend) { return backend.reverse($x, axes); }, { $x: $x }, grad); + return res.reshapeAs($x); +} +exports.reverse = operation_1.op({ reverse_: reverse_ }); +exports.reverse1d = operation_1.op({ reverse1d_: reverse1d_ }); +exports.reverse2d = operation_1.op({ reverse2d_: reverse2d_ }); +exports.reverse3d = operation_1.op({ reverse3d_: reverse3d_ }); +exports.reverse4d = operation_1.op({ reverse4d_: reverse4d_ }); +//# sourceMappingURL=reverse.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js.map new file mode 100644 index 0000000..6193294 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reverse.js","sourceRoot":"","sources":["../../src/ops/reverse.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,8BAAgC;AAChC,yCAA2C;AAC3C,yCAA+B;AAO/B,oBAAoB,CAAsB;IACxC,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE,qEACT,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;IAC9B,OAAO,eAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;AACxB,CAAC;AASD,oBAAoB,CAAsB,EAAE,IAAsB;IAChE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE,qEACT,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;IAC9B,OAAO,eAAO,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AAC3B,CAAC;AASD,oBAAoB,CAAsB,EAAE,IAAsB;IAChE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE,qEACT,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;IAC9B,OAAO,eAAO,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AAC3B,CAAC;AASD,oBAAoB,CAAsB,EAAE,IAAsB;IAChE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAC9C,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE,qEACT,EAAE,CAAC,IAAI,MAAG,CAAC,CAAC;IAC9B,OAAO,eAAO,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AAC3B,CAAC;AAgCD,kBACI,CAAe,EAAE,IAAsB;IACzC,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;IAE9C,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACjB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;KACnB;IACD,IAAM,IAAI,GAAG,0BAAc,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;IAC5C,IAAM,IAAI,GAAG,UAAC,EAAK;QACjB,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAhB,CAAgB,EAAC,CAAC;IACtC,CAAC,CAAC;IACF,IAAM,GAAG,GACL,iBAAG,CAAC,MAAM,CAAC,SAAS,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,EAAzB,CAAyB,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,IAAI,CAAC,CAAC;IAC3E,OAAO,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;AAC3B,CAAC;AAEY,QAAA,OAAO,GAAG,cAAE,CAAC,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC;AACzB,QAAA,SAAS,GAAG,cAAE,CAAC,EAAC,UAAU,YAAA,EAAC,CAAC,CAAC;AAC7B,QAAA,SAAS,GAAG,cAAE,CAAC,EAAC,UAAU,YAAA,EAAC,CAAC,CAAC;AAC7B,QAAA,SAAS,GAAG,cAAE,CAAC,EAAC,UAAU,YAAA,EAAC,CAAC,CAAC;AAC7B,QAAA,SAAS,GAAG,cAAE,CAAC,EAAC,UAAU,YAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js new file mode 100644 index 0000000..4d201fd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js @@ -0,0 +1,270 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('reverse1d', test_util_1.ALL_ENVS, function () { + it('reverse a 1D array', function () { + var input = tf.tensor1d([1, 2, 3, 4, 5]); + var result = tf.reverse1d(input); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [5, 4, 3, 2, 1]); + }); + it('grad', function () { + var a = tf.tensor1d([1, 2, 3]); + var dy = tf.tensor1d([10, 20, 30]); + var da = tf.grad(function (a) { return tf.reverse1d(a); })(a, dy); + expect(da.shape).toEqual([3]); + test_util_1.expectArraysClose(da, [30, 20, 10]); + }); + it('accepts a tensor-like object', function () { + var input = [1, 2, 3, 4, 5]; + var result = tf.reverse1d(input); + expect(result.shape).toEqual([5]); + test_util_1.expectArraysClose(result, [5, 4, 3, 2, 1]); + }); +}); +jasmine_util_1.describeWithFlags('reverse2d', test_util_1.ALL_ENVS, function () { + it('reverse a 2D array at axis [0]', function () { + var axis = [0]; + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var result = tf.reverse2d(a, axis); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [4, 5, 6, 1, 2, 3]); + }); + it('reverse a 2D array at axis [1]', function () { + var axis = [1]; + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var result = tf.reverse2d(a, axis); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [3, 2, 1, 6, 5, 4]); + }); + it('throws error with invalid input', function () { + var x = tf.tensor1d([1, 20, 300, 4]); + expect(function () { return tf.reverse2d(x, [0]); }).toThrowError(); + }); + it('throws error with invalid axis param', function () { + var x = tf.tensor2d([1, 20, 300, 4], [1, 4]); + expect(function () { return tf.reverse2d(x, [2]); }).toThrowError(); + expect(function () { return tf.reverse2d(x, [-3]); }).toThrowError(); + }); + it('throws error with non integer axis param', function () { + var x = tf.tensor2d([1, 20, 300, 4], [1, 4]); + expect(function () { return tf.reverse2d(x, [0.5]); }).toThrowError(); + }); + it('grad', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]]); + var dy = tf.tensor2d([[10, 20, 30], [40, 50, 60]]); + var da = tf.grad(function (a) { return tf.reverse2d(a); })(a, dy); + expect(da.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(da, [60, 50, 40, 30, 20, 10]); + }); + it('grad with reverse(axis=0)', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]]); + var dy = tf.tensor2d([[10, 20, 30], [40, 50, 60]]); + var da = tf.grad(function (a) { return tf.reverse2d(a, 0); })(a, dy); + expect(da.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(da, [40, 50, 60, 10, 20, 30]); + }); + it('grad with reverse(axis=1)', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]]); + var dy = tf.tensor2d([[10, 20, 30], [40, 50, 60]]); + var da = tf.grad(function (a) { return tf.reverse2d(a, 1); })(a, dy); + expect(da.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(da, [30, 20, 10, 60, 50, 40]); + }); + it('accepts a tensor-like object', function () { + var axis = [0]; + var a = [[1, 2, 3], [4, 5, 6]]; + var result = tf.reverse2d(a, axis); + expect(result.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(result, [4, 5, 6, 1, 2, 3]); + }); +}); +jasmine_util_1.describeWithFlags('reverse3d', test_util_1.ALL_ENVS, function () { + var shape = [2, 3, 4]; + var data = [ + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, + 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23 + ]; + it('reverse a 3D array at axis [0]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [0]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 + ]); + }); + it('reverse a 3D array at axis [1]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [1]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 8, 9, 10, 11, 4, 5, 6, 7, 0, 1, 2, 3, + 20, 21, 22, 23, 16, 17, 18, 19, 12, 13, 14, 15 + ]); + }); + it('reverse a 3D array at axis [2]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [2]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 3, 2, 1, 0, 7, 6, 5, 4, 11, 10, 9, 8, + 15, 14, 13, 12, 19, 18, 17, 16, 23, 22, 21, 20 + ]); + }); + it('reverse a 3D array at axis [0, 1]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [0, 1]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 20, 21, 22, 23, 16, 17, 18, 19, 12, 13, 14, 15, + 8, 9, 10, 11, 4, 5, 6, 7, 0, 1, 2, 3 + ]); + }); + it('reverse a 3D array at axis [0, 2]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [0, 2]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 15, 14, 13, 12, 19, 18, 17, 16, 23, 22, 21, 20, + 3, 2, 1, 0, 7, 6, 5, 4, 11, 10, 9, 8 + ]); + }); + it('reverse a 3D array at axis [1, 2]', function () { + var input = tf.tensor3d(data, shape); + var result = tf.reverse3d(input, [1, 2]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, + 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12 + ]); + }); + it('throws error with invalid input', function () { + var x = tf.tensor2d([1, 20, 300, 4], [1, 4]); + expect(function () { return tf.reverse3d(x, [1]); }).toThrowError(); + }); + it('throws error with invalid axis param', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + expect(function () { return tf.reverse3d(x, [3]); }).toThrowError(); + expect(function () { return tf.reverse3d(x, [-4]); }).toThrowError(); + }); + it('throws error with non integer axis param', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + expect(function () { return tf.reverse3d(x, [0.5]); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var input = [[[1], [2], [3]], [[4], [5], [6]]]; + var result = tf.reverse3d(input, [0]); + expect(result.shape).toEqual([2, 3, 1]); + test_util_1.expectArraysClose(result, [4, 5, 6, 1, 2, 3]); + }); +}); +jasmine_util_1.describeWithFlags('reverse4d', test_util_1.ALL_ENVS, function () { + var shape = [3, 2, 3, 4]; + var data = [ + 0, 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 + ]; + it('reverse a 4D array at axis [0]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [0]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, + 66, 67, 68, 69, 70, 71, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, + 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 0, 1, 2, 3, 4, 5, + 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23 + ]); + }); + it('reverse a 4D array at axis [1]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [1]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 0, 1, 2, 3, 4, 5, + 6, 7, 8, 9, 10, 11, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 60, 61, 62, 63, 64, 65, + 66, 67, 68, 69, 70, 71, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59 + ]); + }); + it('reverse a 4D array at axis [2]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [2]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 8, 9, 10, 11, 4, 5, 6, 7, 0, 1, 2, 3, 20, 21, 22, 23, 16, 17, + 18, 19, 12, 13, 14, 15, 32, 33, 34, 35, 28, 29, 30, 31, 24, 25, 26, 27, + 44, 45, 46, 47, 40, 41, 42, 43, 36, 37, 38, 39, 56, 57, 58, 59, 52, 53, + 54, 55, 48, 49, 50, 51, 68, 69, 70, 71, 64, 65, 66, 67, 60, 61, 62, 63 + ]); + }); + it('reverse a 4D array at axis [3]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [3]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 3, 2, 1, 0, 7, 6, 5, 4, 11, 10, 9, 8, 15, 14, 13, 12, 19, 18, + 17, 16, 23, 22, 21, 20, 27, 26, 25, 24, 31, 30, 29, 28, 35, 34, 33, 32, + 39, 38, 37, 36, 43, 42, 41, 40, 47, 46, 45, 44, 51, 50, 49, 48, 55, 54, + 53, 52, 59, 58, 57, 56, 63, 62, 61, 60, 67, 66, 65, 64, 71, 70, 69, 68 + ]); + }); + it('reverse a 4D array at axis [0, 2]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [0, 2]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 56, 57, 58, 59, 52, 53, 54, 55, 48, 49, 50, 51, 68, 69, 70, 71, 64, 65, + 66, 67, 60, 61, 62, 63, 32, 33, 34, 35, 28, 29, 30, 31, 24, 25, 26, 27, + 44, 45, 46, 47, 40, 41, 42, 43, 36, 37, 38, 39, 8, 9, 10, 11, 4, 5, + 6, 7, 0, 1, 2, 3, 20, 21, 22, 23, 16, 17, 18, 19, 12, 13, 14, 15 + ]); + }); + it('reverse a 4D array at axis [1, 3]', function () { + var input = tf.tensor4d(data, shape); + var result = tf.reverse4d(input, [1, 3]); + expect(result.shape).toEqual(input.shape); + test_util_1.expectArraysClose(result, [ + 15, 14, 13, 12, 19, 18, 17, 16, 23, 22, 21, 20, 3, 2, 1, 0, 7, 6, + 5, 4, 11, 10, 9, 8, 39, 38, 37, 36, 43, 42, 41, 40, 47, 46, 45, 44, + 27, 26, 25, 24, 31, 30, 29, 28, 35, 34, 33, 32, 63, 62, 61, 60, 67, 66, + 65, 64, 71, 70, 69, 68, 51, 50, 49, 48, 55, 54, 53, 52, 59, 58, 57, 56 + ]); + }); + it('throws error with invalid input', function () { + var x = tf.tensor3d([1, 20, 300, 4], [1, 1, 4]); + expect(function () { return tf.reverse4d(x, [1]); }).toThrowError(); + }); + it('throws error with invalid axis param', function () { + var x = tf.tensor4d([1, 20, 300, 4], [1, 1, 1, 4]); + expect(function () { return tf.reverse4d(x, [4]); }).toThrowError(); + expect(function () { return tf.reverse4d(x, [-5]); }).toThrowError(); + }); + it('throws error with non integer axis param', function () { + var x = tf.tensor4d([1, 20, 300, 4], [1, 1, 1, 4]); + expect(function () { return tf.reverse4d(x, [0.5]); }).toThrowError(); + }); + it('accepts a tensor-like object', function () { + var input = [[[[1]], [[2]], [[3]]], [[[4]], [[5]], [[6]]]]; + var result = tf.reverse4d(input, [0]); + expect(result.shape).toEqual([2, 3, 1, 1]); + test_util_1.expectArraysClose(result, [4, 5, 6, 1, 2, 3]); + }); +}); +jasmine_util_1.describeWithFlags('reverse', test_util_1.ALL_ENVS, function () { + it('throws when passed a non-tensor', function () { + expect(function () { return tf.reverse({}); }) + .toThrowError(/Argument 'x' passed to 'reverse' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var input = [1, 2, 3]; + var result = tf.reverse(input); + expect(result.shape).toEqual([3]); + test_util_1.expectArraysClose(result, [3, 2, 1]); + }); +}); +//# sourceMappingURL=reverse_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js.map new file mode 100644 index 0000000..988fcd3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/reverse_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reverse_test.js","sourceRoot":"","sources":["../../src/ops/reverse_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.d.ts new file mode 100644 index 0000000..3e6bd50 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.d.ts @@ -0,0 +1,7 @@ +import { Tensor, Tensor1D } from '../tensor'; +import { TensorLike } from '../types'; +declare function unsortedSegmentSum_(x: T | TensorLike, segmentIds: Tensor1D | TensorLike, numSegments: number): T; +declare function gather_(x: T | TensorLike, indices: Tensor1D | TensorLike, axis?: number): T; +export declare const gather: typeof gather_; +export declare const unsortedSegmentSum: typeof unsortedSegmentSum_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js new file mode 100644 index 0000000..0d1f853 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js @@ -0,0 +1,91 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var array_ops_1 = require("./array_ops"); +var axis_util_1 = require("./axis_util"); +var binary_ops_1 = require("./binary_ops"); +var compare_1 = require("./compare"); +var logical_ops_1 = require("./logical_ops"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function unsortedSegmentSum_(x, segmentIds, numSegments) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'unsortedSegmentSum'); + var $segmentIds = tensor_util_env_1.convertToTensor(segmentIds, 'segmentIds', 'unsortedSegmentSum', 'int32'); + util_1.assert($segmentIds.dtype === 'int32', 'segmentIds must be of dtype `int32`'); + util_1.assert(util_1.isInt(numSegments), 'numSegments must be of dtype int'); + var gradFunc = function (dy) { + var derX = function () { + return gatherDropNegatives(dy, $segmentIds); + }; + return { $x: derX }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { + return backend.unsortedSegmentSum($x, $segmentIds, numSegments); + }, { $x: $x }, gradFunc); +} +function gather_(x, indices, axis) { + if (axis === void 0) { axis = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'gather'); + var $indices = tensor_util_env_1.convertToTensor(indices, 'indices', 'gather', 'int32'); + util_1.assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`'); + axis = axis_util_1.parseAxisParam(axis, $x.shape)[0]; + var grad = function (dy) { + var derX = function () { + if (axis === 0) { + return exports.unsortedSegmentSum(dy, $indices, $x.shape[axis]); + } + var paramsShape = $x.shape; + var indicesSize = $indices.size; + var outerShape = paramsShape.slice(0, axis); + var outerDims = outerShape.length; + var innerShape = paramsShape.slice(axis, paramsShape.length).slice(1); + var innerDims = innerShape.length; + var outerAxesIndices = arrayRange(0, outerDims); + var innerAxesIndices = arrayRange(outerDims + 1, outerDims + 1 + innerDims); + var valuesShape = arrayConcat([outerShape, [indicesSize], innerShape]); + var values = dy.reshape(valuesShape); + var reshapedIndices = $indices.reshape([indicesSize]); + var transposeDims = arrayConcat([[outerDims], outerAxesIndices, innerAxesIndices]); + var valuesTranspose = values.transpose(transposeDims); + var paramsGrad = exports.unsortedSegmentSum(valuesTranspose, reshapedIndices, $x.shape[axis]); + var invertTransposeDims = axis_util_1.getUndoAxesPermutation(transposeDims); + paramsGrad = paramsGrad.transpose(invertTransposeDims); + return paramsGrad; + }; + return { $x: derX }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.gather($x, $indices, axis); }, { $x: $x }, grad); +} +function arrayRange(start, stop) { + var result = []; + for (var i = start; i < stop; ++i) { + result.push(i); + } + return result; +} +function arrayConcat(arrays) { + var result = []; + for (var i = 0; i < arrays.length; ++i) { + for (var j = 0; j < arrays[i].length; ++j) { + result.push(arrays[i][j]); + } + } + return result; +} +function gatherDropNegatives(x, indices) { + var zeroClippedIndices = binary_ops_1.maximum(indices, tensor_ops_1.zerosLike(indices)); + var gathered = exports.gather(x, zeroClippedIndices); + var isPositive = compare_1.greaterEqual(indices, tensor_ops_1.scalar(0, 'int32')); + var numIters = gathered.rank - isPositive.rank; + for (var i = 0; i < numIters; ++i) { + isPositive = array_ops_1.expandDims(isPositive, i + 1); + } + isPositive = logical_ops_1.logicalAnd(isPositive, tensor_ops_1.ones(gathered.shape, 'bool')); + var zeroSlice = tensor_ops_1.zerosLike(gathered); + return logical_ops_1.where(isPositive, gathered, zeroSlice); +} +exports.gather = operation_1.op({ gather_: gather_ }); +exports.unsortedSegmentSum = operation_1.op({ unsortedSegmentSum_: unsortedSegmentSum_ }); +//# sourceMappingURL=segment_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js.map new file mode 100644 index 0000000..2028355 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"segment_ops.js","sourceRoot":"","sources":["../../src/ops/segment_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js new file mode 100644 index 0000000..2506f17 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js @@ -0,0 +1,102 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var reduce_util_1 = require("./reduce_util"); +jasmine_util_1.describeWithFlags('unsortedSegmentSum', test_util_1.ALL_ENVS, function () { + it('tensor1D', function () { + var t = tf.tensor1d([1, 2, 3, 4]); + var segmentIds = tf.tensor1d([0, 2, 0, 1], 'int32'); + var numSegments = 3; + var res = tf.unsortedSegmentSum(t, segmentIds, numSegments); + expect(res.shape).toEqual([numSegments]); + test_util_1.expectArraysClose(res, [4, 4, 2]); + }); + it('tensor2D', function () { + var t = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var segmentIds = tf.tensor1d([0, 0], 'int32'); + var numSegments = 2; + var res = tf.unsortedSegmentSum(t, segmentIds, numSegments); + expect(res.shape).toEqual([numSegments, 2]); + test_util_1.expectArraysClose(res, [4, 6, 0, 0]); + }); + it('tensor3D', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [3, 2, 2]); + var segmentIds = tf.tensor1d([2, 1, 2], 'int32'); + var numSegments = 3; + var res = tf.unsortedSegmentSum(t, segmentIds, numSegments); + expect(res.shape).toEqual([numSegments, 2, 2]); + test_util_1.expectArraysClose(res, [0, 0, 0, 0, 5, 6, 7, 8, 10, 12, 14, 16]); + }); + it('N > than parallelization threshold, tensor1D', function () { + var n = reduce_util_1.PARALLELIZE_THRESHOLD * 2; + var values = new Float32Array(n); + var numSegments = 5; + var segmentIdValues = new Float32Array(n); + var vals = new Float32Array(numSegments); + for (var i = 0; i < n; i++) { + values[i] = i; + segmentIdValues[i] = i % numSegments; + vals[i % numSegments] += i; + } + var t = tf.tensor1d(values); + var segmentIds = tf.tensor1d(segmentIdValues, 'int32'); + var res = tf.unsortedSegmentSum(t, segmentIds, numSegments); + expect(res.shape).toEqual([numSegments]); + test_util_1.expectArraysClose(res, vals); + }); + it('ignores negative segmentIds', function () { + var t = tf.tensor1d([1, 2, 3, 4]); + var segmentIds = tf.tensor1d([0, 2, -1, 1], 'int32'); + var numSegments = 3; + var res = tf.unsortedSegmentSum(t, segmentIds, numSegments); + expect(res.shape).toEqual([numSegments]); + test_util_1.expectArraysClose(res, [1, 4, 2]); + }); + it('gradient ignores negative segmentIds', function () { + var t = tf.tensor1d([1, 2, 3, 4]); + var segmentIds = tf.tensor1d([0, 2, -1, 1], 'int32'); + var numSegments = 3; + var dy = tf.tensor1d([11, 2, 7]); + var gradient = tf.grad(function (a) { return tf.unsortedSegmentSum(a, segmentIds, numSegments); })(t, dy); + expect(gradient.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradient, [11, 7, 0, 2]); + }); + it('tensor1D gradient', function () { + var t = tf.tensor1d([1, 2, 3, 4]); + var segmentIds = tf.tensor1d([0, 2, 0, 1], 'int32'); + var numSegments = 3; + var dy = tf.tensor1d([11, 2, 7]); + var gradient = tf.grad(function (a) { return tf.unsortedSegmentSum(a, segmentIds, numSegments); })(t, dy); + expect(gradient.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradient, [11, 7, 11, 2]); + }); + it('tensor2D gradient', function () { + var t = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var segmentIds = tf.tensor1d([0, 0], 'int32'); + var numSegments = 2; + var dy = tf.tensor2d([11, 2, 4, 5], [2, 2]); + var gradient = tf.grad(function (a) { return tf.unsortedSegmentSum(a, segmentIds, numSegments); })(t, dy); + expect(gradient.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradient, [11, 2, 11, 2]); + }); + it('tensor3D gradient', function () { + var t = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [3, 2, 2]); + var segmentIds = tf.tensor1d([2, 1, 2], 'int32'); + var numSegments = 3; + var dy = tf.tensor3d([11, 2, 4, 5, 17, 31, 1, 0, -1, 14, 3, 28], [3, 2, 2]); + var gradient = tf.grad(function (a) { return tf.unsortedSegmentSum(a, segmentIds, numSegments); })(t, dy); + expect(gradient.shape).toEqual(t.shape); + test_util_1.expectArraysClose(gradient, [-1, 14, 3, 28, 17, 31, 1, 0, -1, 14, 3, 28]); + }); + it('accepts a tensor-like object', function () { + var x = [1, 2, 3, 4]; + var segmentIds = [0, 2, 0, 1]; + var numSegments = 3; + var res = tf.unsortedSegmentSum(x, segmentIds, numSegments); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [4, 4, 2]); + }); +}); +//# sourceMappingURL=segment_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js.map new file mode 100644 index 0000000..2c37f5a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"segment_ops_test.js","sourceRoot":"","sources":["../../src/ops/segment_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.d.ts new file mode 100644 index 0000000..c1ed265 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.d.ts @@ -0,0 +1,8 @@ +export interface SegOpInfo { + windowSize: number; + batchSize: number; + inSize: number; + numSegments: number; +} +export declare function segOpComputeOptimalWindowSize(inSize: number, numSegments: number): number; +export declare function computeOutShape(aShape: number[], axis: number, numSegments: number): number[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js new file mode 100644 index 0000000..fd67cab --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js @@ -0,0 +1,41 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util_1 = require("../util"); +var reduce_util_1 = require("./reduce_util"); +function segOpComputeOptimalWindowSize(inSize, numSegments) { + var done = false; + var res; + if (inSize <= reduce_util_1.PARALLELIZE_THRESHOLD) { + res = inSize; + done = true; + } + else { + res = util_1.nearestDivisor(inSize, Math.floor(Math.sqrt(inSize))); + } + while (!done) { + if (res > numSegments || res === inSize) { + done = true; + break; + } + else { + res = util_1.nearestDivisor(inSize, res + 1); + } + } + return res; +} +exports.segOpComputeOptimalWindowSize = segOpComputeOptimalWindowSize; +function computeOutShape(aShape, axis, numSegments) { + var outShape = []; + var rank = aShape.length; + for (var dim = 0; dim < rank; dim++) { + if (dim !== axis) { + outShape.push(aShape[dim]); + } + else { + outShape.push(numSegments); + } + } + return outShape; +} +exports.computeOutShape = computeOutShape; +//# sourceMappingURL=segment_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js.map new file mode 100644 index 0000000..7755ad4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/segment_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"segment_util.js","sourceRoot":"","sources":["../../src/ops/segment_util.ts"],"names":[],"mappings":";;AAiBA,gCAAuC;AACvC,6CAAoD;AASpD,uCACI,MAAc,EAAE,WAAmB;IACrC,IAAI,IAAI,GAAG,KAAK,CAAC;IACjB,IAAI,GAAG,CAAC;IAER,IAAI,MAAM,IAAI,mCAAqB,EAAE;QACnC,GAAG,GAAG,MAAM,CAAC;QACb,IAAI,GAAG,IAAI,CAAC;KACb;SAAM;QACL,GAAG,GAAG,qBAAc,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;KAC7D;IAED,OAAO,CAAC,IAAI,EAAE;QACZ,IAAI,GAAG,GAAG,WAAW,IAAI,GAAG,KAAK,MAAM,EAAE;YACvC,IAAI,GAAG,IAAI,CAAC;YACZ,MAAM;SACP;aAAM;YACL,GAAG,GAAG,qBAAc,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC;SACvC;KACF;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AArBD,sEAqBC;AAED,yBACI,MAAgB,EAAE,IAAY,EAAE,WAAmB;IACrD,IAAM,QAAQ,GAAG,EAAE,CAAC;IACpB,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,EAAE;QACnC,IAAI,GAAG,KAAK,IAAI,EAAE;YAChB,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;SAC5B;aAAM;YACL,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC5B;KACF;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAZD,0CAYC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.d.ts new file mode 100644 index 0000000..1360106 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.d.ts @@ -0,0 +1,2 @@ +export declare const SELU_SCALEALPHA = 1.7580993408473768; +export declare const SELU_SCALE = 1.0507009873554805; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js new file mode 100644 index 0000000..356c45c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.SELU_SCALEALPHA = 1.7580993408473768599402175208123; +exports.SELU_SCALE = 1.0507009873554804934193349852946; +//# sourceMappingURL=selu_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js.map new file mode 100644 index 0000000..d9acdcf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/selu_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"selu_util.js","sourceRoot":"","sources":["../../src/ops/selu_util.ts"],"names":[],"mappings":";;AAiBa,QAAA,eAAe,GAAG,iCAAiC,CAAC;AACpD,QAAA,UAAU,GAAG,iCAAiC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.d.ts new file mode 100644 index 0000000..3c1038a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.d.ts @@ -0,0 +1,13 @@ +import { Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D } from '../tensor'; +import { Rank, TensorLike } from '../types'; +declare function slice1d_(x: Tensor1D | TensorLike, begin: number, size: number): Tensor1D; +declare function slice2d_(x: Tensor2D | TensorLike, begin: [number, number], size: [number, number]): Tensor2D; +declare function slice3d_(x: Tensor3D | TensorLike, begin: [number, number, number], size: [number, number, number]): Tensor3D; +declare function slice4d_(x: Tensor4D | TensorLike, begin: [number, number, number, number], size: [number, number, number, number]): Tensor4D; +declare function slice_>(x: T | TensorLike, begin: number | number[], size?: number | number[]): T; +export declare const slice: typeof slice_; +export declare const slice1d: typeof slice1d_; +export declare const slice2d: typeof slice2d_; +export declare const slice3d: typeof slice3d_; +export declare const slice4d: typeof slice4d_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js new file mode 100644 index 0000000..81854bf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js @@ -0,0 +1,81 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var operation_1 = require("./operation"); +var slice_util = require("./slice_util"); +function slice1d_(x, begin, size) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'slice1d'); + util.assert($x.rank === 1, "slice1d expects a rank-1 tensor, but got a rank-" + $x.rank + " tensor"); + return exports.slice($x, [begin], [size]); +} +function slice2d_(x, begin, size) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'slice2d'); + util.assert($x.rank === 2, "slice1d expects a rank-2 tensor, but got a rank-" + $x.rank + " tensor"); + return exports.slice($x, begin, size); +} +function slice3d_(x, begin, size) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'slice3d'); + util.assert($x.rank === 3, "slice1d expects a rank-3 tensor, but got a rank-" + $x.rank + " tensor"); + return exports.slice($x, begin, size); +} +function slice4d_(x, begin, size) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'slice4d'); + util.assert($x.rank === 4, "slice1d expects a rank-4 tensor, but got a rank-" + $x.rank + " tensor"); + return exports.slice($x, begin, size); +} +function slice_(x, begin, size) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'slice'); + if ($x.rank === 0) { + throw new Error('Slicing scalar is not possible'); + } + var begin_; + if (typeof begin === 'number') { + begin_ = [begin].concat(new Array($x.rank - 1).fill(0)); + } + else if (begin.length < $x.rank) { + begin_ = begin.concat(new Array($x.rank - begin.length).fill(0)); + } + else { + begin_ = begin; + } + var size_; + if (size == null) { + size_ = new Array($x.rank).fill(-1); + } + else if (typeof size === 'number') { + size_ = [size].concat(new Array($x.rank - 1).fill(-1)); + } + else if (size.length < $x.rank) { + size_ = size.concat(new Array($x.rank - size.length).fill(-1)); + } + else { + size_ = size; + } + size_ = size_.map(function (d, i) { + if (d >= 0) { + return d; + } + else { + util.assert(d === -1, 'Bad value in size'); + return $x.shape[i] - begin_[i]; + } + }); + slice_util.assertParamsValid($x, begin_, size_); + var inputShape = $x.shape; + var grad = function (dy) { + var paddings = []; + for (var i = 0; i < dy.rank; i++) { + paddings.push([begin_[i], inputShape[i] - begin_[i] - size_[i]]); + } + return { $x: function () { return dy.pad(paddings); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.slice($x, begin_, size_); }, { $x: $x }, grad); +} +exports.slice = operation_1.op({ slice_: slice_ }); +exports.slice1d = operation_1.op({ slice1d_: slice1d_ }); +exports.slice2d = operation_1.op({ slice2d_: slice2d_ }); +exports.slice3d = operation_1.op({ slice3d_: slice3d_ }); +exports.slice4d = operation_1.op({ slice4d_: slice4d_ }); +//# sourceMappingURL=slice.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js.map new file mode 100644 index 0000000..d65c6ec --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice.js.map @@ -0,0 +1 @@ +{"version":3,"file":"slice.js","sourceRoot":"","sources":["../../src/ops/slice.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js new file mode 100644 index 0000000..12fbba8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js @@ -0,0 +1,172 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('slice1d', test_util_1.ALL_ENVS, function () { + it('slices 1x1 into 1x1 (effectively a copy)', function () { + var a = tf.tensor1d([5]); + var result = tf.slice1d(a, 0, 1); + expect(result.shape).toEqual([1]); + test_util_1.expectNumbersClose(result.get(0), 5); + }); + it('slices 5x1 into shape 2x1 starting at 3', function () { + var a = tf.tensor1d([1, 2, 3, 4, 5]); + var result = tf.slice1d(a, 3, 2); + expect(result.shape).toEqual([2]); + test_util_1.expectArraysClose(result, [4, 5]); + }); + it('slices 5x1 into shape 3x1 starting at 1', function () { + var a = tf.tensor1d([1, 2, 3, 4, 5]); + var result = tf.slice1d(a, 1, 3); + expect(result.shape).toEqual([3]); + test_util_1.expectArraysClose(result, [2, 3, 4]); + }); + it('grad', function () { + var a = tf.tensor1d([1, 2, 3, 4, 5]); + var dy = tf.tensor1d([10, 100]); + var da = tf.grad(function (x) { return tf.slice1d(a, 1, 2); })(a, dy); + expect(da.shape).toEqual([5]); + test_util_1.expectArraysClose(da, [0, 10, 100, 0, 0]); + }); + it('accepts a tensor-like object', function () { + var a = [5]; + var result = tf.slice1d(a, 0, 1); + expect(result.shape).toEqual([1]); + test_util_1.expectNumbersClose(result.get(0), 5); + }); +}); +jasmine_util_1.describeWithFlags('slice2d', test_util_1.ALL_ENVS, function () { + it('slicing a 1x1 from a 1x1 returns a 1x1', function () { + var a = tf.tensor2d([0], [1, 1]); + var b = tf.slice2d(a, [0, 0], [1, 1]); + expect(b.shape).toEqual([1, 1]); + }); + it('returns a tensor of slice size', function () { + var a = tf.zeros([100, 100]); + var b = tf.slice2d(a, [0, 0], [12, 34]); + expect(b.shape).toEqual([12, 34]); + }); + it('returns the upper-left submatrix when begin is [0, 0]', function () { + var a = tf.randomUniform([10, 10], -1, 1); + var b = tf.slice2d(a, [0, 0], [2, 2]); + var aValues = a.dataSync(); + test_util_1.expectArraysClose(b, [aValues[0], aValues[1], aValues[10], aValues[11]]); + }); + it('returns the rectangle specified', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [4, 3]); + var b = tf.slice2d(a, [1, 1], [3, 2]); + test_util_1.expectArraysClose(b, [5, 6, 8, 9, 11, 12]); + }); + it('throws when requesting out of bounds slice', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [4, 3]); + expect(function () { return tf.slice2d(a, [1, 1], [10, 10]); }).toThrowError(); + }); + it('grad', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]]); + var dy = tf.tensor2d([[20], [50]]); + var da = tf.grad(function (x) { return tf.slice2d(a, [0, 1], [2, 1]); })(a, dy); + expect(da.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(da, [0, 20, 0, 0, 50, 0]); + }); + it('accepts a tensor-like object', function () { + var a = [[0]]; + var b = tf.slice2d(a, [0, 0], [1, 1]); + expect(b.shape).toEqual([1, 1]); + }); +}); +jasmine_util_1.describeWithFlags('slice3d', test_util_1.ALL_ENVS, function () { + it('slices 1x1x1 into shape 1x1x1 (effectively a copy)', function () { + var a = tf.tensor3d([[[5]]], [1, 1, 1]); + var result = tf.slice3d(a, [0, 0, 0], [1, 1, 1]); + expect(result.shape).toEqual([1, 1, 1]); + test_util_1.expectArraysClose(result, [5]); + }); + it('slices 2x2x2 array into 1x2x2 starting at [1, 0, 0]', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = tf.slice3d(a, [1, 0, 0], [1, 2, 2]); + expect(result.shape).toEqual([1, 2, 2]); + test_util_1.expectArraysClose(result, [5, 6, 7, 8]); + }); + it('slices 2x2x2 array into 2x1x1 starting at [0, 1, 1]', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = tf.slice3d(a, [0, 1, 1], [2, 1, 1]); + expect(result.shape).toEqual([2, 1, 1]); + test_util_1.expectArraysClose(result, [4, 8]); + }); + it('accepts a tensor-like object', function () { + var a = [[[5]]]; + var result = tf.slice3d(a, [0, 0, 0], [1, 1, 1]); + expect(result.shape).toEqual([1, 1, 1]); + test_util_1.expectArraysClose(result, [5]); + }); +}); +jasmine_util_1.describeWithFlags('slice4d', test_util_1.ALL_ENVS, function () { + it('slices 1x1x1x1 into shape 1x1x1x1 (effectively a copy)', function () { + var a = tf.tensor4d([[[[5]]]], [1, 1, 1, 1]); + var result = tf.slice4d(a, [0, 0, 0, 0], [1, 1, 1, 1]); + expect(result.shape).toEqual([1, 1, 1, 1]); + test_util_1.expectArraysClose(result, [5]); + }); + it('slices 2x2x2x2 array into 1x2x2x2 starting at [1, 0, 0, 0]', function () { + var a = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 11, 22, 33, 44, 55, 66, 77, 88], [2, 2, 2, 2]); + var result = tf.slice4d(a, [1, 0, 0, 0], [1, 2, 2, 2]); + expect(result.shape).toEqual([1, 2, 2, 2]); + test_util_1.expectArraysClose(result, [11, 22, 33, 44, 55, 66, 77, 88]); + }); + it('slices 2x2x2x2 array into 2x1x1x1 starting at [0, 1, 1, 1]', function () { + var a = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 11, 22, 33, 44, 55, 66, 77, 88], [2, 2, 2, 2]); + var result = tf.slice4d(a, [0, 1, 1, 1], [2, 1, 1, 1]); + expect(result.shape).toEqual([2, 1, 1, 1]); + test_util_1.expectArraysClose(result, [8, 88]); + }); + it('accepts a tensor-like object', function () { + var a = [[[[5]]]]; + var result = tf.slice4d(a, [0, 0, 0, 0], [1, 1, 1, 1]); + expect(result.shape).toEqual([1, 1, 1, 1]); + test_util_1.expectArraysClose(result, [5]); + }); +}); +jasmine_util_1.describeWithFlags('slice ergonomics', test_util_1.ALL_ENVS, function () { + it('slices 2x2x2 array into 2x1x1 no size', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = a.slice([0, 1, 1]); + expect(result.shape).toEqual([2, 1, 1]); + test_util_1.expectArraysClose(result, [4, 8]); + }); + it('slices 2x2x2 array into 1x2x2 with scalar begin no size', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = a.slice(1); + expect(result.shape).toEqual([1, 2, 2]); + test_util_1.expectArraysClose(result, [5, 6, 7, 8]); + }); + it('slices 2x2x2 array using 2d size and 2d size', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = a.slice([0, 1]); + expect(result.shape).toEqual([2, 1, 2]); + test_util_1.expectArraysClose(result, [3, 4, 7, 8]); + }); + it('slices 2x2x2 array using negative size', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = a.slice([0, 1], [-1, 1]); + expect(result.shape).toEqual([2, 1, 2]); + test_util_1.expectArraysClose(result, [3, 4, 7, 8]); + }); + it('slices 2x2x2 array using 1d size', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2]); + var result = a.slice(0, 1); + expect(result.shape).toEqual([1, 2, 2]); + test_util_1.expectArraysClose(result, [1, 2, 3, 4]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.slice({}, 0, 0); }) + .toThrowError(/Argument 'x' passed to 'slice' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var a = [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]; + var result = tf.slice(a, [0, 1, 1]); + expect(result.shape).toEqual([2, 1, 1]); + test_util_1.expectArraysClose(result, [4, 8]); + }); +}); +//# sourceMappingURL=slice_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js.map new file mode 100644 index 0000000..dcc9999 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"slice_test.js","sourceRoot":"","sources":["../../src/ops/slice_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.d.ts new file mode 100644 index 0000000..c9ed72a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.d.ts @@ -0,0 +1,5 @@ +import { Tensor } from '../tensor'; +export declare function assertParamsValid(input: Tensor, begin: number[], size: number[]): void; +export declare function getStridedSlicedInfo(shape: number[], begin: number[], end: number[], strides: number[], beginMask?: number, endMask?: number): [number[], number[]]; +export declare function startForAxis(beginMask: number, startIndices: number[], strides: number[], inputShape: number[], axis: number): number; +export declare function stopForAxis(endMask: number, stopIndices: number[], strides: number[], inputShape: number[], axis: number): number; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js new file mode 100644 index 0000000..f82c4eb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js @@ -0,0 +1,76 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("../util"); +function assertParamsValid(input, begin, size) { + util.assert(input.rank === begin.length, "Error in slice" + input.rank + "D: Length of begin " + begin + " must " + + ("match the rank of the array (" + input.rank + ").")); + util.assert(input.rank === size.length, "Error in slice" + input.rank + "D: Length of size " + size + " must " + + ("match the rank of the array (" + input.rank + ").")); + for (var i = 0; i < input.rank; ++i) { + util.assert(begin[i] + size[i] <= input.shape[i], "Error in slice" + input.rank + "D: begin[" + i + "] + size[" + i + "] " + + ("(" + (begin[i] + size[i]) + ") would overflow input.shape[" + i + "] (" + input.shape[i] + ")")); + } +} +exports.assertParamsValid = assertParamsValid; +function getStridedSlicedInfo(shape, begin, end, strides, beginMask, endMask) { + if (beginMask === void 0) { beginMask = 0; } + if (endMask === void 0) { endMask = 0; } + var startIndex = []; + var endIndex = []; + for (var i = 0; i < shape.length; i++) { + startIndex[i] = startForAxis(beginMask, begin, strides, shape, i); + endIndex[i] = stopForAxis(endMask, end, strides, shape, i); + } + var size = new Array(shape.length).fill(0); + size = size.map(function (d, i) { + var count = 0; + for (var start = startIndex[i]; !(strides[i] > 0 ? start >= endIndex[i] : start <= endIndex[i]); start += strides[i]) { + count += 1; + } + return count; + }); + return [startIndex, size]; +} +exports.getStridedSlicedInfo = getStridedSlicedInfo; +function startForAxis(beginMask, startIndices, strides, inputShape, axis) { + var start = startIndices[axis]; + if (beginMask & 1 << axis) { + if (strides[axis] > 0) { + start = Number.MIN_SAFE_INTEGER; + } + else { + start = Number.MAX_SAFE_INTEGER; + } + } + var axisSize = inputShape[axis]; + if (start < 0) { + start += axisSize; + } + start = util.clamp(0, start, axisSize - 1); + return start; +} +exports.startForAxis = startForAxis; +function stopForAxis(endMask, stopIndices, strides, inputShape, axis) { + var stop = stopIndices[axis]; + if (endMask & (1 << axis)) { + if (strides[axis] > 0) { + stop = Number.MAX_SAFE_INTEGER; + } + else { + stop = Number.MIN_SAFE_INTEGER; + } + } + var axisSize = inputShape[axis]; + if (stop < 0) { + stop += axisSize; + } + if (strides[axis] > 0) { + stop = util.clamp(0, stop, axisSize); + } + else { + stop = util.clamp(-1, stop, axisSize - 1); + } + return stop; +} +exports.stopForAxis = stopForAxis; +//# sourceMappingURL=slice_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js.map new file mode 100644 index 0000000..3df6d63 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/slice_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"slice_util.js","sourceRoot":"","sources":["../../src/ops/slice_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.d.ts new file mode 100644 index 0000000..772901e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.d.ts @@ -0,0 +1,5 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function softmax_(logits: T | TensorLike, dim?: number): T; +export declare const softmax: typeof softmax_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js new file mode 100644 index 0000000..5e6bb5e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js @@ -0,0 +1,31 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var gradients_1 = require("../gradients"); +var tensor_util_env_1 = require("../tensor_util_env"); +var operation_1 = require("./operation"); +function softmax_(logits, dim) { + if (dim === void 0) { dim = -1; } + var $logits = tensor_util_env_1.convertToTensor(logits, 'logits', 'softmax'); + if (dim === -1) { + dim = $logits.rank - 1; + } + if (dim !== $logits.rank - 1) { + throw Error('Softmax along a non-last dimension is not yet supported. ' + + ("Logits was rank " + $logits.rank + " and dim was " + dim)); + } + var customOp = gradients_1.customGrad(function (logits) { + var keepDims = true; + var lse = logits.logSumExp([dim], keepDims); + var logResult = logits.toFloat().sub(lse); + var y = logResult.exp(); + var gradFunc = function (dy) { + var dyTimesY = dy.mul(y); + var keepDims = true; + return dyTimesY.sub(dyTimesY.sum([dim], keepDims).mul(y)); + }; + return { value: y, gradFunc: gradFunc }; + }); + return customOp($logits); +} +exports.softmax = operation_1.op({ softmax_: softmax_ }); +//# sourceMappingURL=softmax.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js.map new file mode 100644 index 0000000..b65d508 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax.js.map @@ -0,0 +1 @@ +{"version":3,"file":"softmax.js","sourceRoot":"","sources":["../../src/ops/softmax.ts"],"names":[],"mappings":";;AAiBA,0CAAwC;AAExC,sDAAmD;AAEnD,yCAA+B;AAsB/B,kBAAoC,MAAoB,EAAE,GAAQ;IAAR,oBAAA,EAAA,OAAO,CAAC;IAChE,IAAM,OAAO,GAAG,iCAAe,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IAE7D,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE;QACd,GAAG,GAAG,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC;KACxB;IACD,IAAI,GAAG,KAAK,OAAO,CAAC,IAAI,GAAG,CAAC,EAAE;QAC5B,MAAM,KAAK,CACP,2DAA2D;aAC3D,qBAAmB,OAAO,CAAC,IAAI,qBAAgB,GAAK,CAAA,CAAC,CAAC;KAC3D;IAED,IAAM,QAAQ,GAAG,sBAAU,CAAC,UAAA,MAAM;QAGhC,IAAM,QAAQ,GAAG,IAAI,CAAC;QACtB,IAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAC;QAC9C,IAAM,SAAS,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAM,CAAC,GAAG,SAAS,CAAC,GAAG,EAAO,CAAC;QAE/B,IAAM,QAAQ,GAAG,UAAC,EAAK;YACrB,IAAM,QAAQ,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3B,IAAM,QAAQ,GAAG,IAAI,CAAC;YACtB,OAAO,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,CAAC,CAAC;QAEF,OAAO,EAAC,KAAK,EAAE,CAAC,EAAE,QAAQ,UAAA,EAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC;AAC3B,CAAC;AAEY,QAAA,OAAO,GAAG,cAAE,CAAC,EAAC,QAAQ,UAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js new file mode 100644 index 0000000..001925a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js @@ -0,0 +1,91 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('softmax', test_util_1.ALL_ENVS, function () { + it('regular test', function () { + var y = tf.softmax(tf.tensor1d([2, 1, 3])); + test_util_1.expectArraysClose(y, [0.24472847, 0.09003057, 0.66524095]); + test_util_1.expectNumbersClose(y.get(0) + y.get(1) + y.get(2), 1); + }); + it('overflow', function () { + var y = tf.softmax(tf.tensor1d([100, 100])); + test_util_1.expectArraysClose(y, [0.5, 0.5]); + }); + it('underflow', function () { + var y = tf.softmax(tf.tensor1d([-100, -100])); + test_util_1.expectArraysClose(y, [0.5, 0.5]); + }); + it('Huge difference between probabilities', function () { + var y = tf.softmax(tf.tensor1d([-1000, +1000])); + test_util_1.expectArraysClose(y, [0, 1]); + }); + it('Propagates NaNs', function () { + var a = tf.tensor1d([2, 1, NaN]); + var y = tf.softmax(a); + test_util_1.expectArraysClose(y, [NaN, NaN, NaN]); + }); + it('2D, dim=1', function () { + var y = tf.softmax(tf.tensor2d([[2, 1, 3], [1, 3, 2]], [2, 3]), 1); + var expected = [ + 0.24472847, 0.09003057, 0.66524095, 0.09003057, 0.66524095, 0.24472847 + ]; + expect(y.rank).toBe(2); + test_util_1.expectArraysClose(y, expected); + }); + it('2D, implicit dim=1', function () { + var y = tf.softmax(tf.tensor2d([[2, 1, 3], [1, 3, 2]], [2, 3])); + var expected = [ + 0.24472847, 0.09003057, 0.66524095, 0.09003057, 0.66524095, 0.24472847 + ]; + expect(y.rank).toBe(2); + test_util_1.expectArraysClose(y, expected); + }); + it('2D, dim=0 throws error', function () { + var f = function () { + tf.softmax(tf.tensor2d([[2, 1, 3], [1, 3, 2]], [2, 3]), 0); + }; + expect(f).toThrowError(); + }); + it('1D gradient', function () { + var x = tf.tensor1d([10, 0, -1]); + var y = tf.softmax(x); + var dy = tf.tensor1d([1, 2, 3]); + var dx = tf.grad(function (x) { return x.softmax(); })(x, dy); + var totalSum = tf.sum(tf.mul(dy, y)); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [ + (dy.get(0) - totalSum.get()) * y.get(0), + (dy.get(1) - totalSum.get()) * y.get(1), + (dy.get(2) - totalSum.get()) * y.get(2) + ]); + }); + it('2D gradient', function () { + var x = tf.tensor2d([10, 0, -1, 5, 4, 3], [2, 3]); + var y = tf.softmax(x); + var dy = tf.tensor2d([3, 2, 1, 1, 2, 3], [2, 3]); + var dx = tf.grad(function (x) { return x.softmax(); })(x, dy); + var axis = -1; + var totalSum = tf.sum(tf.mulStrict(dy, y), axis); + expect(dx.shape).toEqual(x.shape); + test_util_1.expectArraysClose(dx, [ + (dy.get(0, 0) - totalSum.get(0)) * y.get(0, 0), + (dy.get(0, 1) - totalSum.get(0)) * y.get(0, 1), + (dy.get(0, 2) - totalSum.get(0)) * y.get(0, 2), + (dy.get(1, 0) - totalSum.get(1)) * y.get(1, 0), + (dy.get(1, 1) - totalSum.get(1)) * y.get(1, 1), + (dy.get(1, 2) - totalSum.get(1)) * y.get(1, 2) + ]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.softmax({}); }) + .toThrowError(/Argument 'logits' passed to 'softmax' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var y = tf.softmax([2, 1, 3]); + test_util_1.expectArraysClose(y, [0.24472847, 0.09003057, 0.66524095]); + test_util_1.expectNumbersClose(y.get(0) + y.get(1) + y.get(2), 1); + }); +}); +//# sourceMappingURL=softmax_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js.map new file mode 100644 index 0000000..2a5ca82 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/softmax_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"softmax_test.js","sourceRoot":"","sources":["../../src/ops/softmax_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.d.ts new file mode 100644 index 0000000..a2e2bf3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.d.ts @@ -0,0 +1,5 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function stridedSlice_(x: T | TensorLike, begin: number[], end: number[], strides: number[], beginMask?: number, endMask?: number): T; +export declare const stridedSlice: typeof stridedSlice_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js new file mode 100644 index 0000000..e27cbcf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js @@ -0,0 +1,13 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var operation_1 = require("./operation"); +function stridedSlice_(x, begin, end, strides, beginMask, endMask) { + if (beginMask === void 0) { beginMask = 0; } + if (endMask === void 0) { endMask = 0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'stridedSlice'); + return environment_1.ENV.engine.runKernel(function (backend) { return backend.stridedSlice($x, begin, end, strides, beginMask, endMask); }, { $x: $x }); +} +exports.stridedSlice = operation_1.op({ stridedSlice_: stridedSlice_ }); +//# sourceMappingURL=strided_slice.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js.map new file mode 100644 index 0000000..b2fe414 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice.js.map @@ -0,0 +1 @@ +{"version":3,"file":"strided_slice.js","sourceRoot":"","sources":["../../src/ops/strided_slice.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,yCAA+B;AA+B/B,uBACI,CAAe,EAAE,KAAe,EAAE,GAAa,EAAE,OAAiB,EAClE,SAAa,EAAE,OAAW;IAA1B,0BAAA,EAAA,aAAa;IAAE,wBAAA,EAAA,WAAW;IAC5B,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;IACnD,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CAChB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,YAAY,CAC3B,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,EADrC,CACqC,EAChD,EAAC,EAAE,IAAA,EAAC,CAAM,CAAC;AACxB,CAAC;AAEY,QAAA,YAAY,GAAG,cAAE,CAAC,EAAC,aAAa,eAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js new file mode 100644 index 0000000..6d10b15 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js @@ -0,0 +1,178 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('stridedSlice', test_util_1.ALL_ENVS, function () { + it('stridedSlice should suport 1d tensor', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [0], [3], [2]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [0, 2]); + }); + it('stridedSlice should suport 1d tensor empty result', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [10], [3], [2]); + expect(output.shape).toEqual([0]); + test_util_1.expectArraysClose(output, []); + }); + it('stridedSlice should suport 1d tensor negative begin', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-3], [3], [1]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [1, 2]); + }); + it('stridedSlice should suport 1d tensor out of range begin', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-5], [3], [1]); + expect(output.shape).toEqual([3]); + test_util_1.expectArraysClose(output, [0, 1, 2]); + }); + it('stridedSlice should suport 1d tensor negative end', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [1], [-2], [1]); + expect(output.shape).toEqual([1]); + test_util_1.expectArraysClose(output, [1]); + }); + it('stridedSlice should suport 1d tensor out of range end', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-3], [5], [1]); + expect(output.shape).toEqual([3]); + test_util_1.expectArraysClose(output, [1, 2, 3]); + }); + it('stridedSlice should suport 1d tensor begin mask', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [1], [3], [1], 1); + expect(output.shape).toEqual([3]); + test_util_1.expectArraysClose(output, [0, 1, 2]); + }); + it('stridedSlice should suport 1d tensor nagtive begin and stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-2], [-3], [-1]); + expect(output.shape).toEqual([1]); + test_util_1.expectArraysClose(output, [2]); + }); + it('stridedSlice should suport 1d tensor' + + ' out of range begin and negative stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [5], [-2], [-1]); + expect(output.shape).toEqual([1]); + test_util_1.expectArraysClose(output, [3]); + }); + it('stridedSlice should suport 1d tensor nagtive end and stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [2], [-4], [-1]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [2, 1]); + }); + it('stridedSlice should suport 1d tensor' + + ' out of range end and negative stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-3], [-5], [-1]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [1, 0]); + }); + it('stridedSlice should suport 1d tensor end mask', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [1], [3], [1], 0, 1); + expect(output.shape).toEqual([3]); + test_util_1.expectArraysClose(output, [1, 2, 3]); + }); + it('stridedSlice should suport 1d tensor negative stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [-1], [-4], [-1]); + expect(output.shape).toEqual([3]); + test_util_1.expectArraysClose(output, [3, 2, 1]); + }); + it('stridedSlice should suport 1d tensor even length stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [0], [2], [2]); + expect(output.shape).toEqual([1]); + test_util_1.expectArraysClose(output, [0]); + }); + it('stridedSlice should suport 1d tensor odd length stride', function () { + var tensor = tf.tensor1d([0, 1, 2, 3]); + var output = tf.stridedSlice(tensor, [0], [3], [2]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [0, 2]); + }); + it('stridedSlice should suport 2d tensor identity', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [0, 0], [2, 3], [1, 1]); + expect(output.shape).toEqual([2, 3]); + test_util_1.expectArraysClose(output, [1, 2, 3, 4, 5, 6]); + }); + it('stridedSlice should suport 2d tensor', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, 0], [2, 2], [1, 1]); + expect(output.shape).toEqual([1, 2]); + test_util_1.expectArraysClose(output, [4, 5]); + }); + it('stridedSlice should suport 2d tensor strides', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [0, 0], [2, 3], [2, 2]); + expect(output.shape).toEqual([1, 2]); + test_util_1.expectArraysClose(output, [1, 3]); + }); + it('stridedSlice should suport 2d tensor negative strides', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, -1], [2, -4], [2, -1]); + expect(output.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(output, [6, 5, 4]); + }); + it('stridedSlice should suport 2d tensor begin mask', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, 0], [2, 2], [1, 1], 1); + expect(output.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(output, [1, 2, 4, 5]); + }); + it('stridedSlice should suport 2d tensor end mask', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, 0], [2, 2], [1, 1], 0, 2); + expect(output.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(output, [4, 5, 6]); + }); + it('stridedSlice should suport 2d tensor' + + ' negative strides and begin mask', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, -2], [2, -4], [1, -1], 2); + expect(output.shape).toEqual([1, 3]); + test_util_1.expectArraysClose(output, [6, 5, 4]); + }); + it('stridedSlice should suport 2d tensor' + + ' negative strides and end mask', function () { + var tensor = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var output = tf.stridedSlice(tensor, [1, -2], [2, -3], [1, -1], 0, 2); + expect(output.shape).toEqual([1, 2]); + test_util_1.expectArraysClose(output, [5, 4]); + }); + it('stridedSlice should suport 3d tensor identity', function () { + var tensor = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var output = tf.stridedSlice(tensor, [0, 0, 0], [2, 3, 2], [1, 1, 1]); + expect(output.shape).toEqual([2, 3, 2]); + test_util_1.expectArraysClose(output, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]); + }); + it('stridedSlice should suport 3d tensor negative stride', function () { + var tensor = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var output = tf.stridedSlice(tensor, [-1, -1, -1], [-3, -4, -3], [-1, -1, -1]); + expect(output.shape).toEqual([2, 3, 2]); + test_util_1.expectArraysClose(output, [12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1]); + }); + it('stridedSlice should suport 3d tensor strided 2', function () { + var tensor = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], [2, 3, 2]); + var output = tf.stridedSlice(tensor, [0, 0, 0], [2, 3, 2], [2, 2, 2]); + expect(output.shape).toEqual([1, 2, 1]); + test_util_1.expectArraysClose(output, [1, 5]); + }); + it('stridedSlice should throw when passed a non-tensor', function () { + expect(function () { return tf.stridedSlice({}, [0], [0], [1]); }) + .toThrowError(/Argument 'x' passed to 'stridedSlice' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var tensor = [0, 1, 2, 3]; + var output = tf.stridedSlice(tensor, [0], [3], [2]); + expect(output.shape).toEqual([2]); + test_util_1.expectArraysClose(output, [0, 2]); + }); +}); +//# sourceMappingURL=strided_slice_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js.map new file mode 100644 index 0000000..1e9b919 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/strided_slice_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"strided_slice_test.js","sourceRoot":"","sources":["../../src/ops/strided_slice_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.d.ts new file mode 100644 index 0000000..f477095 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.d.ts @@ -0,0 +1,21 @@ +import { Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, Tensor5D, Tensor6D } from '../tensor'; +import { TensorLike, TensorLike1D, TensorLike2D, TensorLike3D, TensorLike4D, TensorLike5D, TensorLike6D } from '../types'; +import { DataType, Rank, ShapeMap } from '../types'; +declare function tensor(values: TensorLike, shape?: ShapeMap[R], dtype?: DataType): Tensor; +declare function scalar(value: number | boolean, dtype?: DataType): Scalar; +declare function tensor1d(values: TensorLike1D, dtype?: DataType): Tensor1D; +declare function tensor2d(values: TensorLike2D, shape?: [number, number], dtype?: DataType): Tensor2D; +declare function tensor3d(values: TensorLike3D, shape?: [number, number, number], dtype?: DataType): Tensor3D; +declare function tensor4d(values: TensorLike4D, shape?: [number, number, number, number], dtype?: DataType): Tensor4D; +declare function tensor5d(values: TensorLike5D, shape?: [number, number, number, number, number], dtype?: DataType): Tensor5D; +declare function tensor6d(values: TensorLike6D, shape?: [number, number, number, number, number, number], dtype?: DataType): Tensor6D; +declare function ones(shape: ShapeMap[R], dtype?: DataType): Tensor; +declare function zeros(shape: ShapeMap[R], dtype?: DataType): Tensor; +declare function fill(shape: ShapeMap[R], value: number, dtype?: DataType): Tensor; +declare function onesLike_(x: T | TensorLike): T; +declare function zerosLike_(x: T | TensorLike): T; +declare function linspace(start: number, stop: number, num: number): Tensor1D; +declare function range(start: number, stop: number, step?: number, dtype?: 'float32' | 'int32'): Tensor1D; +export { fill, linspace, ones, range, scalar, tensor, tensor1d, tensor2d, tensor3d, tensor4d, tensor5d, tensor6d, zeros }; +export declare const onesLike: typeof onesLike_; +export declare const zerosLike: typeof zerosLike_; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js new file mode 100644 index 0000000..8f2d8b2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js @@ -0,0 +1,208 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_1 = require("../tensor"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util_1 = require("../util"); +var operation_1 = require("./operation"); +function tensor(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (!util_1.isTypedArray(values) && !Array.isArray(values) && + typeof values !== 'number' && typeof values !== 'boolean') { + throw new Error('values passed to tensor(values) must be an ' + + 'array of numbers or booleans, or a TypedArray'); + } + var inferredShape = util_1.inferShape(values); + if (shape != null && inferredShape.length !== 1) { + util_1.assertShapesMatch(shape, inferredShape, "Error creating a new Tensor. " + + ("Inferred shape (" + inferredShape + ") does not match the ") + + ("provided shape (" + shape + "). ")); + } + if (!util_1.isTypedArray(values) && !Array.isArray(values)) { + values = [values]; + } + shape = shape || inferredShape; + return tensor_1.Tensor.make(shape, { + values: util_1.toTypedArray(values, dtype, environment_1.ENV.get('DEBUG')) + }, dtype); +} +exports.tensor = tensor; +function scalar(value, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (util_1.isTypedArray(value) || Array.isArray(value)) { + throw new Error('Error creating a new Scalar: value must be a primitive ' + + '(number|boolean)'); + } + return tensor(value, [], dtype); +} +exports.scalar = scalar; +function tensor1d(values, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 1) { + throw new Error('tensor1d() requires values to be a flat/TypedArray'); + } + return tensor(values, inferredShape, dtype); +} +exports.tensor1d = tensor1d; +function tensor2d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + if (shape != null && shape.length !== 2) { + throw new Error('tensor2d() requires shape to have two numbers'); + } + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 2 && inferredShape.length !== 1) { + throw new Error('tensor2d() requires values to be number[][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor2d() requires shape to be provided when `values` ' + + 'are a flat/TypedArray'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); +} +exports.tensor2d = tensor2d; +function tensor3d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + if (shape != null && shape.length !== 3) { + throw new Error('tensor3d() requires shape to have three numbers'); + } + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 3 && inferredShape.length !== 1) { + throw new Error('tensor3d() requires values to be number[][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor3d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); +} +exports.tensor3d = tensor3d; +function tensor4d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + if (shape != null && shape.length !== 4) { + throw new Error('tensor4d() requires shape to have four numbers'); + } + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 4 && inferredShape.length !== 1) { + throw new Error('tensor4d() requires values to be number[][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor4d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); +} +exports.tensor4d = tensor4d; +function tensor5d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + if (shape != null && shape.length !== 5) { + throw new Error('tensor5d() requires shape to have five numbers'); + } + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 5 && inferredShape.length !== 1) { + throw new Error('tensor5d() requires values to be ' + + 'number[][][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor5d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); +} +exports.tensor5d = tensor5d; +function tensor6d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + util_1.assertNonNull(values); + if (shape != null && shape.length !== 6) { + throw new Error('tensor6d() requires shape to have six numbers'); + } + var inferredShape = util_1.inferShape(values); + if (inferredShape.length !== 6 && inferredShape.length !== 1) { + throw new Error('tensor6d() requires values to be number[][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor6d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || + inferredShape; + return tensor(values, shape, dtype); +} +exports.tensor6d = tensor6d; +function ones(shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = util_1.makeOnesTypedArray(util_1.sizeFromShape(shape), dtype); + return tensor_1.Tensor.make(shape, { values: values }, dtype); +} +exports.ones = ones; +function zeros(shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = util_1.makeZerosTypedArray(util_1.sizeFromShape(shape), dtype); + return tensor_1.Tensor.make(shape, { values: values }, dtype); +} +exports.zeros = zeros; +function fill(shape, value, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = util_1.getTypedArrayFromDType(dtype, util_1.sizeFromShape(shape)); + values.fill(value); + return tensor_1.Tensor.make(shape, { values: values }, dtype); +} +exports.fill = fill; +function onesLike_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'onesLike'); + return ones($x.shape, $x.dtype); +} +function zerosLike_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'zerosLike'); + return zeros($x.shape, $x.dtype); +} +function linspace(start, stop, num) { + if (num === 0) { + throw new Error('Cannot request zero samples'); + } + var step = (stop - start) / (num - 1); + var values = util_1.makeZerosTypedArray(num, 'float32'); + values[0] = start; + for (var i = 1; i < values.length; i++) { + values[i] = values[i - 1] + step; + } + return tensor1d(values, 'float32'); +} +exports.linspace = linspace; +function range(start, stop, step, dtype) { + if (step === void 0) { step = 1; } + if (dtype === void 0) { dtype = 'float32'; } + if (step === 0) { + throw new Error('Cannot have a step of zero'); + } + var sameStartStop = start === stop; + var increasingRangeNegativeStep = start < stop && step < 0; + var decreasingRangePositiveStep = stop < start && step > 1; + if (sameStartStop || increasingRangeNegativeStep || + decreasingRangePositiveStep) { + return zeros([0], dtype); + } + var numElements = Math.abs(Math.ceil((stop - start) / step)); + var values = util_1.makeZerosTypedArray(numElements, dtype); + if (stop < start && step === 1) { + step = -1; + } + values[0] = start; + for (var i = 1; i < values.length; i++) { + values[i] = values[i - 1] + step; + } + return tensor1d(values, dtype); +} +exports.range = range; +exports.onesLike = operation_1.op({ onesLike_: onesLike_ }); +exports.zerosLike = operation_1.op({ zerosLike_: zerosLike_ }); +//# sourceMappingURL=tensor_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js.map new file mode 100644 index 0000000..eedde9b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/tensor_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_ops.js","sourceRoot":"","sources":["../../src/ops/tensor_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.d.ts new file mode 100644 index 0000000..62c3248 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.d.ts @@ -0,0 +1,8 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function topk_(x: T | TensorLike, k?: number, sorted?: boolean): { + values: T; + indices: T; +}; +export declare const topk: typeof topk_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js new file mode 100644 index 0000000..20f3fde --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var operation_1 = require("./operation"); +function topk_(x, k, sorted) { + if (k === void 0) { k = 1; } + if (sorted === void 0) { sorted = true; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'topk'); + if ($x.rank === 0) { + throw new Error('topk() expects the input to be of rank 1 or higher'); + } + var lastDim = $x.shape[$x.shape.length - 1]; + if (k > lastDim) { + throw new Error("'k' passed to topk() must be <= the last dimension (" + lastDim + ") " + + ("but got " + k)); + } + var _a = environment_1.ENV.engine.runKernel(function (b) { return b.topk($x, k, sorted); }, { $x: $x }), values = _a[0], indices = _a[1]; + return { values: values, indices: indices }; +} +exports.topk = operation_1.op({ topk_: topk_ }); +//# sourceMappingURL=topk.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js.map new file mode 100644 index 0000000..c08644b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk.js.map @@ -0,0 +1 @@ +{"version":3,"file":"topk.js","sourceRoot":"","sources":["../../src/ops/topk.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,yCAA+B;AAyB/B,eACI,CAAe,EAAE,CAAK,EAAE,MAAa;IAApB,kBAAA,EAAA,KAAK;IAAE,uBAAA,EAAA,aAAa;IACvC,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAC3C,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,EAAE;QACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;KACvE;IACD,IAAM,OAAO,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC9C,IAAI,CAAC,GAAG,OAAO,EAAE;QACf,MAAM,IAAI,KAAK,CACX,yDAAuD,OAAO,OAAI;aAClE,aAAW,CAAG,CAAA,CAAC,CAAC;KACrB;IAEK,IAAA,mGACoD,EADnD,cAAM,EAAE,eAAO,CACqC;IAC3D,OAAO,EAAC,MAAM,QAAA,EAAE,OAAO,SAAA,EAAC,CAAC;AAC3B,CAAC;AAEY,QAAA,IAAI,GAAG,cAAE,CAAC,EAAC,KAAK,OAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js new file mode 100644 index 0000000..cb25f83 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js @@ -0,0 +1,101 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var tensor_ops_1 = require("./tensor_ops"); +jasmine_util_1.describeWithFlags('topk', test_util_1.ALL_ENVS, function () { + it('1d array with default k', function () { + var a = tensor_ops_1.tensor1d([20, 10, 40, 30]); + var _a = tf.topk(a), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([1]); + expect(indices.shape).toEqual([1]); + expect(values.dtype).toBe('float32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [40]); + test_util_1.expectArraysClose(indices, [2]); + }); + it('2d array with default k', function () { + var a = tensor_ops_1.tensor2d([[10, 50], [40, 30]]); + var _a = tf.topk(a), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([2, 1]); + expect(indices.shape).toEqual([2, 1]); + expect(values.dtype).toBe('float32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [50, 40]); + test_util_1.expectArraysClose(indices, [1, 0]); + }); + it('2d array with k=2', function () { + var a = tensor_ops_1.tensor2d([ + [1, 5, 2], + [4, 3, 6], + [3, 2, 1], + [1, 2, 3], + ]); + var k = 2; + var _a = tf.topk(a, k), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([4, 2]); + expect(indices.shape).toEqual([4, 2]); + expect(values.dtype).toBe('float32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [5, 2, 6, 4, 3, 2, 3, 2]); + test_util_1.expectArraysClose(indices, [1, 2, 2, 0, 0, 1, 2, 1]); + }); + it('3d array with k=3', function () { + var a = tensor_ops_1.tensor3d([ + [[1, 5, 2], [4, 3, 6]], + [[3, 2, 1], [1, 2, 3]], + ]); + var k = 3; + var _a = tf.topk(a, k), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([2, 2, 3]); + expect(indices.shape).toEqual([2, 2, 3]); + expect(values.dtype).toBe('float32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [5, 2, 1, 6, 4, 3, 3, 2, 1, 3, 2, 1]); + test_util_1.expectArraysClose(indices, [1, 2, 0, 2, 0, 1, 0, 1, 2, 2, 1, 0]); + }); + it('topk(int32) propagates int32 dtype', function () { + var a = tensor_ops_1.tensor1d([2, 3, 1, 4], 'int32'); + var _a = tf.topk(a), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([1]); + expect(indices.shape).toEqual([1]); + expect(values.dtype).toBe('int32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [4]); + test_util_1.expectArraysClose(indices, [3]); + }); + it('lower-index element appears first, k=4', function () { + var a = tensor_ops_1.tensor1d([1, 2, 2, 1], 'int32'); + var k = 4; + var _a = tf.topk(a, k), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([4]); + expect(indices.shape).toEqual([4]); + expect(values.dtype).toBe('int32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [2, 2, 1, 1]); + test_util_1.expectArraysClose(indices, [1, 2, 0, 3]); + }); + it('throws when k > size of array', function () { + var a = tensor_ops_1.tensor2d([[10, 50], [40, 30]]); + expect(function () { return tf.topk(a, 3); }) + .toThrowError(/'k' passed to topk\(\) must be <= the last dimension/); + }); + it('throws when passed a scalar', function () { + var a = tensor_ops_1.scalar(2); + expect(function () { return tf.topk(a); }) + .toThrowError(/topk\(\) expects the input to be of rank 1 or higher/); + }); + it('accepts a tensor-like object, k=2', function () { + var a = [20, 10, 40, 30]; + var k = 2; + var _a = tf.topk(a, k), values = _a.values, indices = _a.indices; + expect(values.shape).toEqual([2]); + expect(indices.shape).toEqual([2]); + expect(values.dtype).toBe('float32'); + expect(indices.dtype).toBe('int32'); + test_util_1.expectArraysClose(values, [40, 30]); + test_util_1.expectArraysClose(indices, [2, 3]); + }); +}); +//# sourceMappingURL=topk_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js.map new file mode 100644 index 0000000..92a8785 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/topk_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"topk_test.js","sourceRoot":"","sources":["../../src/ops/topk_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.d.ts new file mode 100644 index 0000000..43395b0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.d.ts @@ -0,0 +1,5 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function transpose_(x: T | TensorLike, perm?: number[]): T; +export declare const transpose: typeof transpose_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js new file mode 100644 index 0000000..09d49f6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js @@ -0,0 +1,29 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var axis_util = require("./axis_util"); +var operation_1 = require("./operation"); +function transpose_(x, perm) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'transpose'); + if (perm == null) { + perm = $x.shape.map(function (s, i) { return i; }).reverse(); + } + util.assert($x.rank === perm.length, "Error in transpose: rank of input " + $x.rank + " " + + ("must match length of perm " + perm + ".")); + perm.forEach(function (axis) { + util.assert(axis >= 0 && axis < $x.rank, "All entries in 'perm' must be between 0 and " + ($x.rank - 1) + + (" but got " + perm)); + }); + if ($x.rank <= 1) { + return $x.clone(); + } + var der = function (dy) { + var undoPerm = axis_util.getUndoAxesPermutation(perm); + return { $x: function () { return dy.transpose(undoPerm); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.transpose($x, perm); }, { $x: $x }, der); +} +exports.transpose = operation_1.op({ transpose_: transpose_ }); +//# sourceMappingURL=transpose.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js.map new file mode 100644 index 0000000..4bbc5f9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose.js.map @@ -0,0 +1 @@ +{"version":3,"file":"transpose.js","sourceRoot":"","sources":["../../src/ops/transpose.ts"],"names":[],"mappings":";;AAiBA,8CAAmC;AAEnC,sDAAmD;AAEnD,8BAAgC;AAChC,uCAAyC;AACzC,yCAA+B;AAoB/B,oBAAsC,CAAe,EAAE,IAAe;IACpE,IAAM,EAAE,GAAG,iCAAe,CAAC,CAAC,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC;IAEhD,IAAI,IAAI,IAAI,IAAI,EAAE;QAChB,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,EAAD,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;KAC5C;IACD,IAAI,CAAC,MAAM,CACP,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EACvB,uCAAqC,EAAE,CAAC,IAAI,MAAG;SAC3C,+BAA6B,IAAI,MAAG,CAAA,CAAC,CAAC;IAC9C,IAAI,CAAC,OAAO,CAAC,UAAA,IAAI;QACf,IAAI,CAAC,MAAM,CACP,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC,IAAI,EAC3B,kDAA+C,EAAE,CAAC,IAAI,GAAG,CAAC,CAAE;aACxD,cAAY,IAAM,CAAA,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,IAAI,EAAE,CAAC,IAAI,IAAI,CAAC,EAAE;QAChB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;KACnB;IAED,IAAM,GAAG,GAAG,UAAC,EAAK;QAChB,IAAM,QAAQ,GAAG,SAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC;QACxD,OAAO,EAAC,EAAE,EAAE,cAAM,OAAA,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAtB,CAAsB,EAAC,CAAC;IAC5C,CAAC,CAAC;IACF,OAAO,iBAAG,CAAC,MAAM,CAAC,SAAS,CACvB,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,EAA3B,CAA2B,EAAE,EAAC,EAAE,IAAA,EAAC,EAAE,GAAG,CAAC,CAAC;AACzD,CAAC;AAEY,QAAA,SAAS,GAAG,cAAE,CAAC,EAAC,UAAU,YAAA,EAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js new file mode 100644 index 0000000..544d572 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js @@ -0,0 +1,110 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('transpose', test_util_1.ALL_ENVS, function () { + it('of scalar is no-op', function () { + var a = tf.scalar(3); + test_util_1.expectArraysClose(tf.transpose(a), [3]); + }); + it('of 1D is no-op', function () { + var a = tf.tensor1d([1, 2, 3]); + test_util_1.expectArraysClose(tf.transpose(a), [1, 2, 3]); + }); + it('of scalar with perm of incorrect rank throws error', function () { + var a = tf.scalar(3); + var perm = [0]; + expect(function () { return tf.transpose(a, perm); }).toThrowError(); + }); + it('of 1d with perm out of bounds throws error', function () { + var a = tf.tensor1d([1, 2, 3]); + var perm = [1]; + expect(function () { return tf.transpose(a, perm); }).toThrowError(); + }); + it('of 1d with perm incorrect rank throws error', function () { + var a = tf.tensor1d([1, 2, 3]); + var perm = [0, 0]; + expect(function () { return tf.transpose(a, perm); }).toThrowError(); + }); + it('2D (no change)', function () { + var t = tf.tensor2d([1, 11, 2, 22, 3, 33, 4, 44], [2, 4]); + var t2 = tf.transpose(t, [0, 1]); + expect(t2.shape).toEqual(t.shape); + test_util_1.expectArraysClose(t2, t); + }); + it('2D (transpose)', function () { + var t = tf.tensor2d([1, 11, 2, 22, 3, 33, 4, 44], [2, 4]); + var t2 = tf.transpose(t, [1, 0]); + expect(t2.shape).toEqual([4, 2]); + test_util_1.expectArraysClose(t2, [1, 3, 11, 33, 2, 4, 22, 44]); + }); + it('3D [r, c, d] => [d, r, c]', function () { + var t = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var t2 = tf.transpose(t, [2, 0, 1]); + expect(t2.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 11, 22, 33, 44]); + }); + it('3D [r, c, d] => [d, c, r]', function () { + var t = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var t2 = tf.transpose(t, [2, 1, 0]); + expect(t2.shape).toEqual([2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 3, 2, 4, 11, 33, 22, 44]); + }); + it('5D [r, c, d, e, f] => [r, c, f, e, d]', function () { + var t = tf.tensor5d([1, 11, 2, 22, 3, 33, 4, 44], [1, 1, 2, 2, 2]); + var t2 = tf.transpose(t, [0, 1, 4, 3, 2]); + expect(t2.shape).toEqual([1, 1, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 3, 2, 4, 11, 33, 22, 44]); + }); + it('5D [r, c, d, e, f] => [r, c, d, f, e]', function () { + var t = tf.tensor5d([1, 11, 2, 22, 3, 33, 4, 44], [1, 1, 2, 2, 2]); + var t2 = tf.transpose(t, [0, 1, 4, 2, 3]); + expect(t2.shape).toEqual([1, 1, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 11, 22, 33, 44]); + }); + it('5D [r, c, d, e, f] => [c, r, d, e, f]', function () { + var t = tf.tensor5d([1, 11, 2, 22, 3, 33, 4, 44], [1, 1, 2, 2, 2]); + var t2 = tf.transpose(t, [1, 0, 2, 3, 4]); + expect(t2.shape).toEqual([1, 1, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 11, 2, 22, 3, 33, 4, 44]); + }); + it('6D [r, c, d, e, f, g] => [g, c, f, e, d, r]', function () { + var t = tf.tensor6d([1, 11, 2, 22, 3, 33, 4, 44, 1, 12, 3, 23, 4, 34, 5, 45], [1, 1, 2, 2, 2, 2]); + var t2 = tf.transpose(t, [5, 1, 4, 3, 2, 0]); + expect(t2.shape).toEqual([2, 1, 2, 2, 2, 1]); + test_util_1.expectArraysClose(t2, [1, 1, 3, 4, 2, 3, 4, 5, 11, 12, 33, 34, 22, 23, 44, 45]); + }); + it('6D [r, c, d, e, f, g] => [r, c, d, f, g, e]', function () { + var t = tf.tensor6d([1, 11, 2, 22, 3, 33, 4, 44, 1, 12, 3, 23, 4, 34, 5, 45], [1, 1, 2, 2, 2, 2]); + var t2 = tf.transpose(t, [0, 1, 5, 2, 3, 4]); + expect(t2.shape).toEqual([1, 1, 2, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 2, 3, 4, 1, 3, 4, 5, 11, 22, 33, 44, 12, 23, 34, 45]); + }); + it('6D [r, c, d, e, f, g] => [c, r, g, e, f, d]', function () { + var t = tf.tensor6d([1, 11, 2, 22, 3, 33, 4, 44, 1, 12, 3, 23, 4, 34, 5, 45], [1, 1, 2, 2, 2, 2]); + var t2 = tf.transpose(t, [1, 0, 5, 3, 4, 2]); + expect(t2.shape).toEqual([1, 1, 2, 2, 2, 2]); + test_util_1.expectArraysClose(t2, [1, 1, 2, 3, 3, 4, 4, 5, 11, 12, 22, 23, 33, 34, 44, 45]); + }); + it('gradient 3D [r, c, d] => [d, c, r]', function () { + var t = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]); + var perm = [2, 1, 0]; + var dy = tf.tensor3d([111, 211, 121, 221, 112, 212, 122, 222], [2, 2, 2]); + var dt = tf.grad(function (t) { return t.transpose(perm); })(t, dy); + expect(dt.shape).toEqual(t.shape); + expect(dt.dtype).toEqual('float32'); + test_util_1.expectArraysClose(dt, [111, 112, 121, 122, 211, 212, 221, 222]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.transpose({}); }) + .toThrowError(/Argument 'x' passed to 'transpose' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var t = [[1, 11, 2, 22], [3, 33, 4, 44]]; + var res = tf.transpose(t, [1, 0]); + expect(res.shape).toEqual([4, 2]); + test_util_1.expectArraysClose(res, [1, 3, 11, 33, 2, 4, 22, 44]); + }); +}); +//# sourceMappingURL=transpose_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js.map new file mode 100644 index 0000000..591a9c4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/transpose_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"transpose_test.js","sourceRoot":"","sources":["../../src/ops/transpose_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.d.ts new file mode 100644 index 0000000..49a73e1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.d.ts @@ -0,0 +1,67 @@ +import { Tensor } from '../tensor'; +import { TensorLike } from '../types'; +declare function neg_(x: T | TensorLike): T; +declare function ceil_(x: T | TensorLike): T; +declare function floor_(x: T | TensorLike): T; +declare function sign_(x: T | TensorLike): T; +declare function round_(x: T | TensorLike): T; +declare function exp_(x: T | TensorLike): T; +declare function expm1_(x: T | TensorLike): T; +declare function log_(x: T | TensorLike): T; +declare function log1p_(x: T | TensorLike): T; +declare function sqrt_(x: T | TensorLike): T; +declare function rsqrt_(x: T | TensorLike): T; +declare function square_(x: T | TensorLike): T; +declare function reciprocal_(x: T | TensorLike): T; +declare function abs_(x: T | TensorLike): T; +declare function clipByValue_(x: T | TensorLike, clipValueMin: number, clipValueMax: number): T; +declare function sigmoid_(x: T | TensorLike): T; +declare function logSigmoid_(x: T | TensorLike): T; +declare function softplus_(x: T | TensorLike): T; +declare function sin_(x: T | TensorLike): T; +declare function cos_(x: T | TensorLike): T; +declare function tan_(x: T | TensorLike): T; +declare function asin_(x: T | TensorLike): T; +declare function acos_(x: T | TensorLike): T; +declare function atan_(x: T | TensorLike): T; +declare function sinh_(x: T | TensorLike): T; +declare function cosh_(x: T | TensorLike): T; +declare function tanh_(x: T | TensorLike): T; +declare function asinh_(x: T | TensorLike): T; +declare function acosh_(x: T | TensorLike): T; +declare function atanh_(x: T | TensorLike): T; +declare function erf_(x: T | TensorLike): T; +declare function step_(x: T | TensorLike, alpha?: number): T; +export declare const abs: typeof abs_; +export declare const acos: typeof acos_; +export declare const acosh: typeof acosh_; +export declare const asin: typeof asin_; +export declare const asinh: typeof asinh_; +export declare const atan: typeof atan_; +export declare const atanh: typeof atanh_; +export declare const ceil: typeof ceil_; +export declare const clipByValue: typeof clipByValue_; +export declare const cos: typeof cos_; +export declare const cosh: typeof cosh_; +export declare const erf: typeof erf_; +export declare const exp: typeof exp_; +export declare const expm1: typeof expm1_; +export declare const floor: typeof floor_; +export declare const log: typeof log_; +export declare const log1p: typeof log1p_; +export declare const logSigmoid: typeof logSigmoid_; +export declare const neg: typeof neg_; +export declare const reciprocal: typeof reciprocal_; +export declare const round: typeof round_; +export declare const rsqrt: typeof rsqrt_; +export declare const sigmoid: typeof sigmoid_; +export declare const sign: typeof sign_; +export declare const sin: typeof sin_; +export declare const sinh: typeof sinh_; +export declare const softplus: typeof softplus_; +export declare const sqrt: typeof sqrt_; +export declare const square: typeof square_; +export declare const step: typeof step_; +export declare const tan: typeof tan_; +export declare const tanh: typeof tanh_; +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js new file mode 100644 index 0000000..f3ae7d3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js @@ -0,0 +1,289 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var tensor_util_env_1 = require("../tensor_util_env"); +var util = require("../util"); +var operation_1 = require("./operation"); +var tensor_ops_1 = require("./tensor_ops"); +function neg_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'neg'); + var grad = function (dy) { + return { $x: function () { return dy.neg(); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.neg($x); }, { $x: $x }, grad); +} +function ceil_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'ceil'); + var grad = function (dy) { + return { $x: function () { return tensor_ops_1.zerosLike(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.ceil($x); }, { $x: $x }, grad); +} +function floor_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'floor'); + var grad = function (dy) { + return { $x: function () { return tensor_ops_1.zerosLike(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.floor($x); }, { $x: $x }, grad); +} +function sign_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sign'); + var grad = function (dy) { + return { $x: function () { return tensor_ops_1.zerosLike(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.sign($x); }, { $x: $x }, grad); +} +function round_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'round'); + var grad = function (dy) { + return { $x: function () { return tensor_ops_1.zerosLike(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.round($x); }, { $x: $x }, grad); +} +function exp_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'exp'); + var bck = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return dy.mulStrict(y); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.exp($x)); }, { $x: $x }, bck); +} +function expm1_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'expm1'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.exp()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.expm1($x); }, { $x: $x }, grad); +} +function log_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'log'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.toFloat()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.log($x); }, { $x: $x }, grad); +} +function log1p_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'log1p'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.add(tensor_ops_1.scalar(1))); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.log1p($x); }, { $x: $x }, grad); +} +function sqrt_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sqrt'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.toFloat().sqrt().mul(tensor_ops_1.scalar(2))); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.sqrt($x); }, { $x: $x }, grad); +} +function rsqrt_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'rsqrt'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.pow(tensor_ops_1.scalar(1.5)).mul(tensor_ops_1.scalar(2))).neg(); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.rsqrt($x); }, { $x: $x }, grad); +} +function square_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'square'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.toFloat().mul(tensor_ops_1.scalar(2))); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.square($x); }, { $x: $x }, grad); +} +function reciprocal_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'reciprocal'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.square().neg()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.reciprocal($x); }, { $x: $x }, grad); +} +function abs_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'abs'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.toFloat().step(-1)); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.abs($x); }, { $x: $x }, grad); +} +function clipByValue_(x, clipValueMin, clipValueMax) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'clipByValue'); + util.assert((clipValueMin <= clipValueMax), "Error in clip: min (" + clipValueMin + ") must be " + + ("less than or equal to max (" + clipValueMax + ").")); + var grad = function (dy) { + return { + $x: function () { return dy.where($x.greaterEqual(tensor_ops_1.scalar(clipValueMin)) + .logicalAnd($x.lessEqual(tensor_ops_1.scalar(clipValueMax))), tensor_ops_1.zerosLike(dy)); }, + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.clip($x, clipValueMin, clipValueMax); }, { $x: $x }, grad); +} +function sigmoid_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sigmoid'); + var grad = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return dy.mulStrict(y.mul(tensor_ops_1.scalar(1).sub(y))); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.sigmoid($x)); }, { $x: $x }, grad); +} +function logSigmoid_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'logSigmoid'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.neg().sigmoid()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.softplus($x.neg()).neg(); }, { $x: $x }, grad); +} +function softplus_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'softplus'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.sigmoid()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.softplus($x); }, { $x: $x }, grad); +} +function sin_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sin'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().cos().mulStrict(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.sin($x); }, { $x: $x }, grad); +} +function cos_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'cos'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().sin().neg().mulStrict(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.cos($x); }, { $x: $x }, grad); +} +function tan_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'tan'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.cos().square()); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.tan($x); }, { $x: $x }, grad); +} +function asin_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'asin'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict(tensor_ops_1.scalar(1).sub($x.toFloat().square()).sqrt()); } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.asin($x); }, { $x: $x }, grad); +} +function acos_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'acos'); + var grad = function (dy) { + return { + $x: function () { + return dy.divStrict(tensor_ops_1.scalar(1).sub($x.toFloat().square()).sqrt()).neg(); + } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.acos($x); }, { $x: $x }, grad); +} +function atan_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'atan'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict(tensor_ops_1.scalar(1).add($x.toFloat().square())); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.atan($x); }, { $x: $x }, grad); +} +function sinh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'sinh'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().cosh().mulStrict(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.sinh($x); }, { $x: $x }, grad); +} +function cosh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'cosh'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().sinh().mulStrict(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.cosh($x); }, { $x: $x }, grad); +} +function tanh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'tanh'); + var grad = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return tensor_ops_1.scalar(1).sub(y.square()).mulStrict(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend, save) { return save(backend.tanh($x)); }, { $x: $x }, grad); +} +function asinh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'asinh'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict(tensor_ops_1.scalar(1).add($x.toFloat().square()).sqrt()); } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.asinh($x); }, { $x: $x }, grad); +} +function acosh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'acosh'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict($x.toFloat().square().sub(tensor_ops_1.scalar(1)).sqrt()); } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.acosh($x); }, { $x: $x }, grad); +} +function atanh_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'atanh'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict(tensor_ops_1.scalar(1).sub($x.toFloat().square())); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.atanh($x); }, { $x: $x }, grad); +} +function erf_(x) { + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'erf'); + util.assert($x.dtype === 'int32' || $x.dtype === 'float32', 'Input dtype must be `int32` or `float32`.'); + if ($x.dtype === 'int32') { + $x = $x.toFloat(); + } + var grad = function (dy) { + return { + $x: function () { return dy.mulStrict(tensor_ops_1.scalar(2 / Math.sqrt(Math.PI)).mul($x.square().neg().exp())); } + }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.erf($x); }, { $x: $x }, grad); +} +function step_(x, alpha) { + if (alpha === void 0) { alpha = 0.0; } + var $x = tensor_util_env_1.convertToTensor(x, 'x', 'step'); + var grad = function (dy) { + return { $x: function () { return tensor_ops_1.zerosLike(dy); } }; + }; + return environment_1.ENV.engine.runKernel(function (backend) { return backend.step($x, alpha); }, { $x: $x }, grad); +} +exports.abs = operation_1.op({ abs_: abs_ }); +exports.acos = operation_1.op({ acos_: acos_ }); +exports.acosh = operation_1.op({ acosh_: acosh_ }); +exports.asin = operation_1.op({ asin_: asin_ }); +exports.asinh = operation_1.op({ asinh_: asinh_ }); +exports.atan = operation_1.op({ atan_: atan_ }); +exports.atanh = operation_1.op({ atanh_: atanh_ }); +exports.ceil = operation_1.op({ ceil_: ceil_ }); +exports.clipByValue = operation_1.op({ clipByValue_: clipByValue_ }); +exports.cos = operation_1.op({ cos_: cos_ }); +exports.cosh = operation_1.op({ cosh_: cosh_ }); +exports.erf = operation_1.op({ erf_: erf_ }); +exports.exp = operation_1.op({ exp_: exp_ }); +exports.expm1 = operation_1.op({ expm1_: expm1_ }); +exports.floor = operation_1.op({ floor_: floor_ }); +exports.log = operation_1.op({ log_: log_ }); +exports.log1p = operation_1.op({ log1p_: log1p_ }); +exports.logSigmoid = operation_1.op({ logSigmoid_: logSigmoid_ }); +exports.neg = operation_1.op({ neg_: neg_ }); +exports.reciprocal = operation_1.op({ reciprocal_: reciprocal_ }); +exports.round = operation_1.op({ round_: round_ }); +exports.rsqrt = operation_1.op({ rsqrt_: rsqrt_ }); +exports.sigmoid = operation_1.op({ sigmoid_: sigmoid_ }); +exports.sign = operation_1.op({ sign_: sign_ }); +exports.sin = operation_1.op({ sin_: sin_ }); +exports.sinh = operation_1.op({ sinh_: sinh_ }); +exports.softplus = operation_1.op({ softplus_: softplus_ }); +exports.sqrt = operation_1.op({ sqrt_: sqrt_ }); +exports.square = operation_1.op({ square_: square_ }); +exports.step = operation_1.op({ step_: step_ }); +exports.tan = operation_1.op({ tan_: tan_ }); +exports.tanh = operation_1.op({ tanh_: tanh_ }); +//# sourceMappingURL=unary_ops.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js.map new file mode 100644 index 0000000..7f6cf8d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops.js.map @@ -0,0 +1 @@ +{"version":3,"file":"unary_ops.js","sourceRoot":"","sources":["../../src/ops/unary_ops.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js new file mode 100644 index 0000000..3230785 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js @@ -0,0 +1,2240 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var util = require("../util"); +var selu_util = require("./selu_util"); +jasmine_util_1.describeWithFlags('relu', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1, -2, 0, 3, -0.1]); + var result = tf.relu(a); + test_util_1.expectArraysClose(result, [1, 0, 0, 3, 0]); + }); + it('5D', function () { + var a = tf.tensor5d([1, -2, 5, -3], [1, 2, 2, 1, 1]); + var result = tf.relu(a); + test_util_1.expectArraysClose(result, [1, 0, 5, 0]); + }); + it('6D', function () { + var a = tf.tensor6d([1, -2, 5, -3, -1, 4, 7, 8], [1, 2, 2, 2, 1, 1]); + var result = tf.relu(a); + test_util_1.expectArraysClose(result, [1, 0, 5, 0, 0, 4, 7, 8]); + }); + it('does nothing to positive values', function () { + var a = tf.scalar(1); + var result = tf.relu(a); + test_util_1.expectNumbersClose(result.get(), 1); + }); + it('sets negative values to 0', function () { + var a = tf.scalar(-1); + var result = tf.relu(a); + test_util_1.expectNumbersClose(result.get(), 0); + }); + it('preserves zero values', function () { + var a = tf.scalar(0); + var result = tf.relu(a); + test_util_1.expectNumbersClose(result.get(), 0); + }); + it('propagates NaNs, float32', function () { + var a = tf.tensor1d([1, -2, 0, 3, -0.1, NaN]); + var result = tf.relu(a); + expect(result.dtype).toBe('float32'); + test_util_1.expectArraysClose(result, [1, 0, 0, 3, 0, NaN]); + }); + it('gradients: positive scalar', function () { + var a = tf.scalar(3); + var dy = tf.scalar(5); + var grad = tf.grad(function (a) { return tf.relu(a); }); + var da = grad(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [5]); + }); + it('gradients: negative scalar', function () { + var a = tf.scalar(-3); + var dy = tf.scalar(5); + var grad = tf.grad(function (a) { return tf.relu(a); }); + var da = grad(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [0]); + }); + it('gradients: array', function () { + var a = tf.tensor2d([1, -1, 0, .1], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var grad = tf.grad(function (a) { return tf.relu(a); }); + var da = grad(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1, 0, 0, 4]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.relu({}); }) + .toThrowError(/Argument 'x' passed to 'relu' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.relu([1, -2, 0, 3, -0.1]); + test_util_1.expectArraysClose(result, [1, 0, 0, 3, 0]); + }); +}); +jasmine_util_1.describeWithFlags('abs', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1, -2, 0, 3, -0.1]); + var result = tf.abs(a); + test_util_1.expectArraysClose(result, [1, 2, 0, 3, 0.1]); + }); + it('5D', function () { + var a = tf.tensor5d([1, -2, 0, -3], [1, 2, 2, 1, 1]); + var result = tf.abs(a); + test_util_1.expectArraysClose(result, [1, 2, 0, 3]); + }); + it('6D', function () { + var a = tf.tensor6d([1, -2, 5, -3, -1, 4, 7, 8], [1, 2, 2, 2, 1, 1]); + var result = tf.abs(a); + test_util_1.expectArraysClose(result, [1, 2, 5, 3, 1, 4, 7, 8]); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1, -2, 0, 3, -0.1, NaN]); + var result = tf.abs(a); + test_util_1.expectArraysClose(result, [1, 2, 0, 3, 0.1, NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(4); + var dy = tf.scalar(8); + var da = tf.grad(function (a) { return tf.abs(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [8 * 1]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var da = tf.grad(function (a) { return tf.abs(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * 1, 3 * -1, 4 * 1]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([3, -1, -2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var da = tf.grad(function (a) { return tf.abs(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * 1, 2 * -1, 3 * -1, 4 * 1]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.abs({}); }) + .toThrowError(/Argument 'x' passed to 'abs' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.abs([1, -2, 0, 3, -0.1]); + test_util_1.expectArraysClose(result, [1, 2, 0, 3, 0.1]); + }); +}); +jasmine_util_1.describeWithFlags('step', test_util_1.ALL_ENVS, function () { + it('with 1d tensor', function () { + var a = tf.tensor1d([1, -2, -.01, 3, -0.1]); + var result = tf.step(a); + test_util_1.expectArraysClose(result, [1, 0, 0, 1, 0]); + }); + it('with 1d tensor and alpha', function () { + var a = tf.tensor1d([1, -2, -.01, 3, NaN]); + var result = tf.step(a, 0.1); + test_util_1.expectArraysClose(result, [1, 0.1, 0.1, 1, NaN]); + }); + it('with 2d tensor', function () { + var a = tf.tensor2d([1, -5, -3, 4], [2, 2]); + var result = tf.step(a); + expect(result.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(result, [1, 0, 0, 1]); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1, -2, -.01, 3, NaN]); + var result = tf.step(a); + test_util_1.expectArraysClose(result, [1, 0, 0, 1, NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(-4); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.step(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.step(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([3, -1, -2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.step(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.step({}); }) + .toThrowError(/Argument 'x' passed to 'step' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.step([1, -2, -.01, 3, -0.1]); + test_util_1.expectArraysClose(result, [1, 0, 0, 1, 0]); + }); +}); +jasmine_util_1.describeWithFlags('neg', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1, -3, 2, 7, -4]); + var result = tf.neg(a); + test_util_1.expectArraysClose(result, [-1, 3, -2, -7, 4]); + }); + it('propagate NaNs', function () { + var a = tf.tensor1d([1, -3, 2, 7, NaN]); + var result = tf.neg(a); + var expected = [-1, 3, -2, -7, NaN]; + test_util_1.expectArraysClose(result, expected); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(4); + var dy = tf.scalar(8); + var da = tf.grad(function (a) { return tf.neg(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [8 * -1]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var da = tf.grad(function (a) { return tf.neg(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * -1, 2 * -1, 3 * -1, 4 * -1]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([3, -1, -2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var da = tf.grad(function (a) { return tf.neg(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [1 * -1, 2 * -1, 3 * -1, 4 * -1]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.neg({}); }) + .toThrowError(/Argument 'x' passed to 'neg' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.neg([1, -3, 2, 7, -4]); + test_util_1.expectArraysClose(result, [-1, 3, -2, -7, 4]); + }); +}); +jasmine_util_1.describeWithFlags('sigmoid', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.sigmoid(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = 1 / (1 + Math.exp(-values[i])); + } + test_util_1.expectArraysClose(result, expected); + }); + it('6D', function () { + var a = tf.ones([2, 2, 2, 2, 2, 2]); + var result = tf.sigmoid(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = 1 / (1 + Math.exp(-1.0)); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([3, NaN]); + var res = tf.sigmoid(a); + test_util_1.expectArraysClose(res, [1 / (1 + Math.exp(-3)), NaN]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var da = tf.grad(function (a) { return tf.sigmoid(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + var y = 1 / (1 + Math.exp(-a.get(i))); + expected[i] = dy.get(i) * y * (1 - y); + } + test_util_1.expectArraysClose(da, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sigmoid({}); }) + .toThrowError(/Argument 'x' passed to 'sigmoid' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.sigmoid(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = 1 / (1 + Math.exp(-values[i])); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('logSigmoid', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.logSigmoid(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.log(1 / (1 + Math.exp(-values[i]))); + } + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var a = tf.scalar(-2); + var result = tf.logSigmoid(a); + var expected = [Math.log(1 / (1 + Math.exp(2)))]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2D', function () { + var values = [1, 2, -3, 5]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.logSigmoid(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.log(1 / (1 + Math.exp(-values[i]))); + } + test_util_1.expectArraysClose(result, expected); + }); + it('larger magnitude negative inputs', function () { + var values = [-100, -200, -3000]; + var a = tf.tensor1d(values); + var result = tf.logSigmoid(a); + var expected = [-100, -200, -3000]; + test_util_1.expectArraysClose(result, expected); + }); + it('larger magnitude positive inputs', function () { + var values = [100, 200, 3000, 50000]; + var a = tf.tensor1d(values); + var result = tf.logSigmoid(a); + var expected = [0, 0, 0, 0]; + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([3, NaN]); + var res = tf.logSigmoid(a); + test_util_1.expectArraysClose(res, [Math.log(1 / (1 + Math.exp(-3))), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(3); + var dy = tf.scalar(4); + var da = tf.grad(function (a) { return tf.logSigmoid(a); })(a, dy).get(); + var y = 1 / (1 + Math.exp(a.get())); + test_util_1.expectNumbersClose(da, dy.get() * y); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var da = tf.grad(function (a) { return tf.logSigmoid(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + var y = 1 / (1 + Math.exp(a.get(i))); + expected[i] = dy.get(i) * y; + } + test_util_1.expectArraysClose(da, expected); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([1, 2, -3, 5], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var da = tf.grad(function (a) { return tf.logSigmoid(a); })(a, dy); + var expected = []; + var aVals = a.dataSync(); + var dyVals = dy.dataSync(); + for (var i = 0; i < a.size; i++) { + var y = 1 / (1 + Math.exp(aVals[i])); + expected[i] = dyVals[i] * y; + } + test_util_1.expectArraysClose(da, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.logSigmoid({}); }) + .toThrowError(/Argument 'x' passed to 'logSigmoid' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.logSigmoid(-2); + var expected = [Math.log(1 / (1 + Math.exp(2)))]; + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('softplus', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.softplus(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.log((1 + Math.exp(values[i]))); + } + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var a = tf.scalar(-2); + var result = tf.softplus(a); + var expected = [Math.log((1 + Math.exp(-2)))]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2D', function () { + var values = [1, 2, -3, 5]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.softplus(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.log((1 + Math.exp(values[i]))); + } + test_util_1.expectArraysClose(result, expected); + }); + it('larger magnitude negative inputs', function () { + var values = [-100, -200, -3000, -50000]; + var a = tf.tensor1d(values); + var result = tf.softplus(a); + var expected = [0, 0, 0, 0]; + test_util_1.expectArraysClose(result, expected); + }); + it('larger magnitude positive inputs', function () { + var values = [100, 200, 3000]; + var a = tf.tensor1d(values); + var result = tf.softplus(a); + var expected = [100, 200, 3000]; + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([3, NaN]); + var res = tf.softplus(a); + test_util_1.expectArraysClose(res, [Math.log((1 + Math.exp(3))), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(3); + var dy = tf.scalar(4); + var da = tf.grad(function (a) { return tf.softplus(a); })(a, dy); + var y = 1 / (1 + Math.exp(-a.get())); + test_util_1.expectNumbersClose(da.get(), dy.get() * y); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, -3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var da = tf.grad(function (a) { return tf.softplus(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + var y = 1 / (1 + Math.exp(-a.get(i))); + expected[i] = dy.get(i) * y; + } + test_util_1.expectArraysClose(da, expected); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([1, 2, -3, 5], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var da = tf.grad(function (a) { return tf.softplus(a); })(a, dy); + var expected = []; + var aVals = a.dataSync(); + var dyVals = dy.dataSync(); + for (var i = 0; i < a.size; i++) { + var y = 1 / (1 + Math.exp(-aVals[i])); + expected[i] = dyVals[i] * y; + } + test_util_1.expectArraysClose(da, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.softplus({}); }) + .toThrowError(/Argument 'x' passed to 'softplus' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.softplus(-2); + var expected = [Math.log((1 + Math.exp(-2)))]; + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('sqrt', test_util_1.ALL_ENVS, function () { + it('sqrt', function () { + var a = tf.tensor1d([2, 4]); + var r = tf.sqrt(a); + test_util_1.expectNumbersClose(r.get(0), Math.sqrt(2)); + test_util_1.expectNumbersClose(r.get(1), Math.sqrt(4)); + }); + it('sqrt propagates NaNs', function () { + var a = tf.tensor1d([1, NaN]); + var r = tf.sqrt(a); + test_util_1.expectArraysClose(r, [Math.sqrt(1), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(4); + var dy = tf.scalar(8); + var da = tf.grad(function (a) { return tf.sqrt(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [8 / (2 * Math.sqrt(4))]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, 3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.sqrt(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + 1 / (2 * Math.sqrt(1)), 2 / (2 * Math.sqrt(2)), + 3 / (2 * Math.sqrt(3)), 4 / (2 * Math.sqrt(5)) + ], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.sqrt(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + 1 / (2 * Math.sqrt(3)), 2 / (2 * Math.sqrt(1)), + 3 / (2 * Math.sqrt(2)), 4 / (2 * Math.sqrt(3)) + ], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sqrt({}); }) + .toThrowError(/Argument 'x' passed to 'sqrt' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.sqrt([2, 4]); + test_util_1.expectNumbersClose(r.get(0), Math.sqrt(2)); + test_util_1.expectNumbersClose(r.get(1), Math.sqrt(4)); + }); +}); +jasmine_util_1.describeWithFlags('rsqrt', test_util_1.ALL_ENVS, function () { + it('rsqrt', function () { + var a = tf.tensor1d([2, 4]); + var r = tf.rsqrt(a); + test_util_1.expectNumbersClose(r.get(0), 1 / Math.sqrt(2)); + test_util_1.expectNumbersClose(r.get(1), 1 / Math.sqrt(4)); + }); + it('rsqrt propagates NaNs', function () { + var a = tf.tensor1d([1, NaN]); + var r = tf.rsqrt(a); + test_util_1.expectArraysClose(r, [1 / Math.sqrt(1), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(4); + var dy = tf.scalar(8); + var da = tf.grad(function (a) { return tf.rsqrt(a); })(a, dy); + expect(da.shape).toEqual(a.shape); + expect(da.dtype).toEqual('float32'); + test_util_1.expectArraysClose(da, [(-1 * 8) / (2 * Math.pow(4, 1.5))]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([1, 2, 3, 5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.rsqrt(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + -1 * 1 / (2 * Math.pow(1, 1.5)), -1 * 2 / (2 * Math.pow(2, 1.5)), + -1 * 3 / (2 * Math.pow(3, 1.5)), -1 * 4 / (2 * Math.pow(5, 1.5)) + ], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.rsqrt(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + -1 * 1 / (2 * Math.pow(3, 1.5)), -1 * 2 / (2 * Math.pow(1, 1.5)), + -1 * 3 / (2 * Math.pow(2, 1.5)), -1 * 4 / (2 * Math.pow(3, 1.5)) + ], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.rsqrt({}); }) + .toThrowError(/Argument 'x' passed to 'rsqrt' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.rsqrt([2, 4]); + test_util_1.expectNumbersClose(r.get(0), 1 / Math.sqrt(2)); + test_util_1.expectNumbersClose(r.get(1), 1 / Math.sqrt(4)); + }); +}); +jasmine_util_1.describeWithFlags('square', test_util_1.ALL_ENVS, function () { + it('1D array', function () { + var a = tf.tensor1d([2, 4, Math.sqrt(2)]); + var r = tf.square(a); + test_util_1.expectArraysClose(r, [4, 16, 2]); + }); + it('2D array', function () { + var a = tf.tensor2d([1, 2, Math.sqrt(2), Math.sqrt(3)], [2, 2]); + var r = tf.square(a); + expect(r.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(r, [1, 4, 2, 3]); + }); + it('5D array', function () { + var a = tf.tensor5d([1, 2, Math.sqrt(2), Math.sqrt(3)], [1, 1, 2, 2, 1]); + var r = tf.square(a); + expect(r.shape).toEqual([1, 1, 2, 2, 1]); + test_util_1.expectArraysClose(r, [1, 4, 2, 3]); + }); + it('6D array', function () { + var a = tf.tensor6d([1, 2, Math.sqrt(2), Math.sqrt(3), 3, 4, Math.sqrt(7), Math.sqrt(13)], [1, 1, 2, 2, 2, 1]); + var r = tf.square(a); + expect(r.shape).toEqual(a.shape); + test_util_1.expectArraysClose(r, [1, 4, 2, 3, 9, 16, 7, 13]); + }); + it('square propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN]); + var r = tf.square(a); + test_util_1.expectArraysClose(r, [2.25, NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.square(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [2 * 5 * 8]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.square(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [-2, 4 * 2, 6 * 3, -10 * 4]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.square(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [-6 * 1, 2 * 2, 4 * 3, 6 * 4]); + }); + it('gradients: Tensor5D', function () { + var a = tf.tensor5d([-3, 1, 2, 3], [1, 1, 1, 2, 2]); + var dy = tf.tensor5d([1, 2, 3, 4], [1, 1, 1, 2, 2]); + var gradients = tf.grad(function (a) { return tf.square(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [-6 * 1, 2 * 2, 4 * 3, 6 * 4]); + }); + it('gradients: Tensor6D', function () { + var a = tf.tensor6d([-3, 1, 2, 3, -4, 5, 12, 3], [1, 1, 1, 2, 2, 2]); + var dy = tf.tensor6d([1, 2, 3, 4, 5, 6, 7, 8], [1, 1, 1, 2, 2, 2]); + var gradients = tf.grad(function (a) { return tf.square(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [-6 * 1, 2 * 2, 4 * 3, 6 * 4, -8 * 5, 10 * 6, 24 * 7, 6 * 8]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.square({}); }) + .toThrowError(/Argument 'x' passed to 'square' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.square([2, 4, Math.sqrt(2)]); + test_util_1.expectArraysClose(r, [4, 16, 2]); + }); +}); +jasmine_util_1.describeWithFlags('reciprocal', test_util_1.ALL_ENVS, function () { + it('1D array', function () { + var a = tf.tensor1d([2, 3, 0, NaN]); + var r = tf.reciprocal(a); + test_util_1.expectArraysClose(r, [1 / 2, 1 / 3, Infinity, NaN]); + }); + it('2D array', function () { + var a = tf.tensor2d([1, Infinity, 0, NaN], [2, 2]); + var r = tf.reciprocal(a); + expect(r.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(r, [1 / 1, 0, Infinity, NaN]); + }); + it('reciprocal propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN]); + var r = tf.reciprocal(a); + test_util_1.expectArraysClose(r, [1 / 1.5, NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.reciprocal(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [-1 * 8 * (1 / (5 * 5))]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.reciprocal(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + -1 * 1 * (1 / (-1 * -1)), -1 * 2 * (1 / (2 * 2)), -1 * 3 * (1 / (3 * 3)), + -1 * 4 * (1 / (-5 * -5)) + ]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-1, 2, 3, -5], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.reciprocal(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + -1 * 1 * (1 / (-1 * -1)), -1 * 2 * (1 / (2 * 2)), -1 * 3 * (1 / (3 * 3)), + -1 * 4 * (1 / (-5 * -5)) + ]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.reciprocal({}); }) + .toThrowError(/Argument 'x' passed to 'reciprocal' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.reciprocal([2, 3, 0, NaN]); + test_util_1.expectArraysClose(r, [1 / 2, 1 / 3, Infinity, NaN]); + }); +}); +jasmine_util_1.describeWithFlags('log', test_util_1.ALL_ENVS, function () { + it('log', function () { + var a = tf.tensor1d([1, 2]); + var r = tf.log(a); + test_util_1.expectNumbersClose(r.get(0), Math.log(1)); + test_util_1.expectNumbersClose(r.get(1), Math.log(2)); + }); + it('log 6D', function () { + var a = tf.range(1, 65).reshape([2, 2, 2, 2, 2, 2]); + var r = tf.log(a); + var expectedResult = []; + for (var i = 1; i < 65; i++) { + expectedResult[i - 1] = Math.log(i); + } + test_util_1.expectArraysClose(r, expectedResult); + }); + it('log propagates NaNs', function () { + var a = tf.tensor1d([1, NaN]); + var r = tf.log(a); + test_util_1.expectArraysClose(r, [Math.log(1), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.log(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [3 / 5]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.log(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 / -1, 2 / 2, 3 / 3, 4 / -5]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.log(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 / -3, 2 / 1, 3 / 2, 4 / 3]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.log({}); }) + .toThrowError(/Argument 'x' passed to 'log' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.log([1, 2]); + test_util_1.expectNumbersClose(r.get(0), Math.log(1)); + test_util_1.expectNumbersClose(r.get(1), Math.log(2)); + }); +}); +jasmine_util_1.describeWithFlags('log1p', test_util_1.ALL_ENVS, function () { + it('log1p', function () { + var a = tf.tensor1d([1, 2]); + var r = tf.log1p(a); + test_util_1.expectNumbersClose(r.get(0), Math.log1p(1)); + test_util_1.expectNumbersClose(r.get(1), Math.log1p(2)); + }); + it('log1p propagates NaNs', function () { + var a = tf.tensor1d([1, NaN]); + var r = tf.log1p(a); + test_util_1.expectArraysClose(r, [Math.log1p(1), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.log1p(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [3 / (1 + 5)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.log1p(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [Infinity, 2 / (1 + 2), 3 / (1 + 3), 4 / (1 + -5)]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.log1p(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 / (1 + -3), 2 / (1 + 1), 3 / (1 + 2), 4 / (1 + 3)]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.log1p({}); }) + .toThrowError(/Argument 'x' passed to 'log1p' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.log1p([1, 2]); + test_util_1.expectNumbersClose(r.get(0), Math.log1p(1)); + test_util_1.expectNumbersClose(r.get(1), Math.log1p(2)); + }); +}); +jasmine_util_1.describeWithFlags('ceil', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1.5, 2.1, -1.4]); + var r = tf.ceil(a); + test_util_1.expectNumbersClose(r.get(0), 2); + test_util_1.expectNumbersClose(r.get(1), 3); + test_util_1.expectNumbersClose(r.get(2), -1); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN, -1.4]); + var r = tf.ceil(a); + test_util_1.expectArraysClose(r, [2, NaN, -1]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.ceil(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1.1, 2.6, 3, -5.9]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.ceil(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2.2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.ceil(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.ceil({}); }) + .toThrowError(/Argument 'x' passed to 'ceil' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.ceil([1.5, 2.1, -1.4]); + test_util_1.expectNumbersClose(r.get(0), 2); + test_util_1.expectNumbersClose(r.get(1), 3); + test_util_1.expectNumbersClose(r.get(2), -1); + }); +}); +jasmine_util_1.describeWithFlags('floor', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1.5, 2.1, -1.4]); + var r = tf.floor(a); + test_util_1.expectNumbersClose(r.get(0), 1); + test_util_1.expectNumbersClose(r.get(1), 2); + test_util_1.expectNumbersClose(r.get(2), -2); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN, -1.4]); + var r = tf.floor(a); + test_util_1.expectArraysClose(r, [1, NaN, -2]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.floor(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1.1, 2.6, 3, -5.9]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.floor(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2.2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.floor(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.floor({}); }) + .toThrowError(/Argument 'x' passed to 'floor' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.floor([1.5, 2.1, -1.4]); + test_util_1.expectNumbersClose(r.get(0), 1); + test_util_1.expectNumbersClose(r.get(1), 2); + test_util_1.expectNumbersClose(r.get(2), -2); + }); +}); +jasmine_util_1.describeWithFlags('sign', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([1.5, 0, NaN, -1.4]); + var r = tf.sign(a); + test_util_1.expectNumbersClose(r.get(0), 1); + test_util_1.expectNumbersClose(r.get(1), 0); + test_util_1.expectNumbersClose(r.get(2), 0); + test_util_1.expectNumbersClose(r.get(3), -1); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN, -1.4]); + var r = tf.sign(a); + test_util_1.expectArraysClose(r, [1, 0, -1]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.sign(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1.1, 2.6, 3, -5.9]); + var dy = tf.tensor1d([-1, 1, 1, -1]); + var gradients = tf.grad(function (a) { return tf.sign(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2.2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.sign(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sign({}); }) + .toThrowError(/Argument 'x' passed to 'sign' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.sign([1.5, 0, NaN, -1.4]); + test_util_1.expectNumbersClose(r.get(0), 1); + test_util_1.expectNumbersClose(r.get(1), 0); + test_util_1.expectNumbersClose(r.get(2), 0); + test_util_1.expectNumbersClose(r.get(3), -1); + }); +}); +jasmine_util_1.describeWithFlags('exp', test_util_1.ALL_ENVS, function () { + it('exp', function () { + var a = tf.tensor1d([1, 2, 0]); + var r = tf.exp(a); + test_util_1.expectNumbersClose(r.get(0), Math.exp(1)); + test_util_1.expectNumbersClose(r.get(1), Math.exp(2)); + test_util_1.expectNumbersClose(r.get(2), 1); + }); + it('exp propagates NaNs', function () { + var a = tf.tensor1d([1, NaN, 0]); + var r = tf.exp(a); + test_util_1.expectArraysClose(r, [Math.exp(1), NaN, 1]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.exp(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [3 * Math.exp(0.5)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.exp(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.exp(-1), 2 * Math.exp(2), 3 * Math.exp(3), 4 * Math.exp(-5)], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.exp(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.exp(-3), 2 * Math.exp(1), 3 * Math.exp(2), 4 * Math.exp(3)], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.exp({}); }) + .toThrowError(/Argument 'x' passed to 'exp' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.exp([1, 2, 0]); + test_util_1.expectNumbersClose(r.get(0), Math.exp(1)); + test_util_1.expectNumbersClose(r.get(1), Math.exp(2)); + test_util_1.expectNumbersClose(r.get(2), 1); + }); +}); +jasmine_util_1.describeWithFlags('expm1', test_util_1.ALL_ENVS, function () { + it('expm1', function () { + var a = tf.tensor1d([1, 2, 0]); + var r = tf.expm1(a); + test_util_1.expectNumbersClose(r.get(0), Math.expm1(1)); + test_util_1.expectNumbersClose(r.get(1), Math.expm1(2)); + test_util_1.expectNumbersClose(r.get(2), Math.expm1(0)); + }); + it('expm1 propagates NaNs', function () { + var a = tf.tensor1d([1, NaN, 0]); + var r = tf.expm1(a); + test_util_1.expectArraysClose(r, [Math.expm1(1), NaN, Math.expm1(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.expm1(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [3 * Math.exp(0.5)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.expm1(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.exp(-1), 2 * Math.exp(2), 3 * Math.exp(3), 4 * Math.exp(-5)], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.expm1(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.exp(-3), 2 * Math.exp(1), 3 * Math.exp(2), 4 * Math.exp(3)], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.expm1({}); }) + .toThrowError(/Argument 'x' passed to 'expm1' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.expm1([1, 2, 0]); + test_util_1.expectNumbersClose(r.get(0), Math.expm1(1)); + test_util_1.expectNumbersClose(r.get(1), Math.expm1(2)); + test_util_1.expectNumbersClose(r.get(2), Math.expm1(0)); + }); +}); +jasmine_util_1.describeWithFlags('sin', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.sin(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.sin(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.sin(a); + test_util_1.expectArraysClose(res, [Math.sin(4), NaN, Math.sin(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.sin(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * Math.cos(5)]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.sin(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.cos(-1), 2 * Math.cos(2), 3 * Math.cos(3), 4 * Math.cos(-5)], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.sin(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1 * Math.cos(-3), 2 * Math.cos(1), 3 * Math.cos(2), 4 * Math.cos(3)], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sin({}); }) + .toThrowError(/Argument 'x' passed to 'sin' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.sin(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.sin(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('cos', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.cos(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.cos(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.cos(a); + test_util_1.expectArraysClose(res, [Math.cos(4), NaN, Math.cos(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.cos(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * Math.sin(5) * -1]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1, 2, 3, -5]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.cos(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + 1 * Math.sin(-1) * -1, 2 * Math.sin(2) * -1, 3 * Math.sin(3) * -1, + 4 * Math.sin(-5) * -1 + ], 1e-1); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.cos(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [ + 1 * Math.sin(-3) * -1, 2 * Math.sin(1) * -1, 3 * Math.sin(2) * -1, + 4 * Math.sin(3) * -1 + ], 1e-1); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.cos({}); }) + .toThrowError(/Argument 'x' passed to 'cos' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.cos(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.cos(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('tan', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.tan(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.tan(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.tan(a); + test_util_1.expectArraysClose(res, [Math.tan(4), NaN, Math.tan(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.tan(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 / (Math.cos(0.5) * Math.cos(0.5))]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-1, 2, 3, -5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.tan(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (Math.cos(aValues[i]) * Math.cos(aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-3, 1, 2, 3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.tan(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (Math.cos(aValues[i]) * Math.cos(aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.tan({}); }) + .toThrowError(/Argument 'x' passed to 'tan' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.tan(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.tan(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('asin', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [.1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.asin(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.asin(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.asin(a); + test_util_1.expectArraysClose(res, [Math.asin(4), NaN, Math.asin(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.asin(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 / Math.sqrt(1 - (0.5 * 0.5))]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-0.1, 0.2, 0.3, -0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.asin(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(1 - (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-0.3, 0.1, 0.2, 0.3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.asin(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(1 - (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.asin({}); }) + .toThrowError(/Argument 'x' passed to 'asin' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [.1, -3, 2, 7, -4]; + var result = tf.asin(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.asin(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('acos', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [.1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.acos(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.acos(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.acos(a); + test_util_1.expectArraysClose(res, [Math.acos(4), NaN, Math.acos(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.acos(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [(-1 * 8) / Math.sqrt(1 - (0.5 * 0.5))]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-0.1, 0.2, 0.3, -0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.acos(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = + (-1 * dyValues[i]) / Math.sqrt(1 - (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-0.3, 0.1, 0.2, 0.3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.acos(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = + (-1 * dyValues[i]) / Math.sqrt(1 - (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.acos({}); }) + .toThrowError(/Argument 'x' passed to 'acos' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [.1, -3, 2, 7, -4]; + var result = tf.acos(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.acos(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('atan', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.atan(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.atan(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('6D atan', function () { + var a = tf.range(1, 65).reshape([2, 2, 2, 2, 2, 2]); + var result = tf.atan(a); + var expected = []; + for (var i = 1; i < 65; ++i) { + expected[i - 1] = Math.atan(i); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.atan(a); + test_util_1.expectArraysClose(res, [Math.atan(4), NaN, Math.atan(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.atan(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 / (1 + (0.5 * 0.5))]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-0.1, 0.2, 0.3, -0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.atan(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (1 + (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-0.3, 0.1, 0.2, 0.3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.atan(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (1 + (aValues[i] * aValues[i])); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.atan({}); }) + .toThrowError(/Argument 'x' passed to 'atan' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.atan(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.atan(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('sinh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, -1, -4]; + var a = tf.tensor1d(values); + var result = tf.sinh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.sinh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.sinh(a); + test_util_1.expectArraysClose(res, [Math.sinh(4), NaN, Math.sinh(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.sinh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * Math.cosh(0.5)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-1, 2, 3, -5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.sinh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * Math.cosh(aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-3, 1, 2, 3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.sinh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * Math.cosh(aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.sinh({}); }) + .toThrowError(/Argument 'x' passed to 'sinh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, -1, -4]; + var result = tf.sinh(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.sinh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('cosh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, -1, -4]; + var a = tf.tensor1d(values); + var result = tf.cosh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.cosh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.cosh(a); + test_util_1.expectArraysClose(res, [Math.cosh(4), NaN, Math.cosh(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.cosh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * Math.sinh(0.5)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-1, 2, 3, -5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.cosh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * Math.sinh(aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-3, 1, 2, 3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.cosh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * Math.sinh(aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.cosh({}); }) + .toThrowError(/Argument 'x' passed to 'cosh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, -1, -4]; + var result = tf.cosh(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.cosh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('tanh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.tanh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = util.tanh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.tanh(a); + test_util_1.expectArraysClose(res, [util.tanh(4), NaN, util.tanh(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.tanh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * (1 - (Math.tanh(0.5) * Math.tanh(0.5)))]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-1, 2, 3, -5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.tanh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = + dyValues[i] * (1 - (Math.tanh(aValues[i]) * Math.tanh(aValues[i]))); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-3, 1, 2, 3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.tanh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = + dyValues[i] * (1 - (Math.tanh(aValues[i]) * Math.tanh(aValues[i]))); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.tanh({}); }) + .toThrowError(/Argument 'x' passed to 'tanh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.tanh(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = util.tanh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('leakyRelu', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([0, 1, -2]); + var result = tf.leakyRelu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0, 1, -0.4]); + }); + it('propagates NaN', function () { + var a = tf.tensor1d([0, 1, NaN]); + var result = tf.leakyRelu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [0, 1, NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(-4); + var dy = tf.scalar(8); + var alpha = 0.1; + var gradients = tf.grad(function (a) { return tf.leakyRelu(a, alpha); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * alpha]); + }); + it('gradients: Tensor1D', function () { + var aValues = [1, -1, 0.1]; + var dyValues = [1, 2, 3]; + var alpha = 0.1; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.leakyRelu(a, alpha); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1, 2 * alpha, 3]); + }); + it('gradients: Tensor2D', function () { + var aValues = [1, -1, 0.1, 0.5]; + var dyValues = [1, 2, 3, 4]; + var alpha = 0.1; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.leakyRelu(a, alpha); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1, 2 * alpha, 3, 4]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.leakyRelu({}); }) + .toThrowError(/Argument 'x' passed to 'leakyRelu' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.leakyRelu([0, 1, -2]); + expect(result.shape).toEqual([3]); + test_util_1.expectArraysClose(result, [0, 1, -0.4]); + }); +}); +jasmine_util_1.describeWithFlags('elu', test_util_1.ALL_ENVS, function () { + it('calculate elu', function () { + var a = tf.tensor1d([1, -1, 0]); + var result = tf.elu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1, -0.6321, 0]); + }); + it('elu propagates NaN', function () { + var a = tf.tensor1d([1, NaN]); + var result = tf.elu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1, NaN]); + }); + it('derivative', function () { + var x = tf.tensor1d([1, 3, -2]); + var dy = tf.tensor1d([5, 50, 500]); + var gradients = tf.grad(function (a) { return tf.elu(a); })(x, dy); + expect(gradients.shape).toEqual(x.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [5, 50, 500 * Math.exp(-2)]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.elu({}); }) + .toThrowError(/Argument 'x' passed to 'elu' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.elu([1, -1, 0]); + expect(result.shape).toEqual(result.shape); + test_util_1.expectArraysClose(result, [1, -0.6321, 0]); + }); +}); +jasmine_util_1.describeWithFlags('selu', test_util_1.ALL_ENVS, function () { + var scaleAlpha = selu_util.SELU_SCALEALPHA; + var scale = selu_util.SELU_SCALE; + it('calculate selu', function () { + var a = tf.tensor1d([1, -1, 0]); + var result = tf.selu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1.0507, -1.1113, 0]); + }); + it('selu propagates NaN', function () { + var a = tf.tensor1d([1, NaN]); + var result = tf.selu(a); + expect(result.shape).toEqual(a.shape); + test_util_1.expectArraysClose(result, [1.0507, NaN]); + }); + it('gradients: Scalar', function () { + var aValue = 1; + var dyValue = 1; + var a = tf.scalar(aValue); + var dy = tf.scalar(dyValue); + var gradients = tf.grad(function (a) { return tf.selu(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [dyValue * scale]); + aValue = -1; + dyValue = 2; + a = tf.scalar(aValue); + dy = tf.scalar(dyValue); + gradients = tf.grad(function (a) { return tf.selu(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [dyValue * scaleAlpha * Math.exp(aValue)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [1, -1, 0]; + var dyValues = [1, 2, 3]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.selu(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + if (aValues[i] > 0) { + expected[i] = dyValues[i] * scale; + } + else { + expected[i] = dyValues[i] * scaleAlpha * Math.exp(aValues[i]); + } + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [1, -1, 0, 0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.selu(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + if (aValues[i] > 0) { + expected[i] = dyValues[i] * scale; + } + else { + expected[i] = dyValues[i] * scaleAlpha * Math.exp(aValues[i]); + } + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.selu({}); }) + .toThrowError(/Argument 'x' passed to 'selu' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.selu([1, -1, 0]); + expect(result.shape).toEqual([3]); + test_util_1.expectArraysClose(result, [1.0507, -1.1113, 0]); + }); +}); +jasmine_util_1.describeWithFlags('clip', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([3, -1, 0, 100, -7, 2]); + var min = -1; + var max = 50; + var result = tf.clipByValue(a, min, max); + test_util_1.expectArraysClose(result, [3, -1, 0, 50, -1, 2]); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([3, -1, 0, 100, -7, 2, NaN]); + var min = -1; + var max = 50; + var result = tf.clipByValue(a, min, max); + test_util_1.expectArraysClose(result, [3, -1, 0, 50, -1, 2, NaN]); + }); + it('min greater than max', function () { + var a = tf.tensor1d([3, -1, 0, 100, -7, 2]); + var min = 1; + var max = -1; + var f = function () { + tf.clipByValue(a, min, max); + }; + expect(f).toThrowError(); + }); + it('derivative: 1D tensor', function () { + var min = -1; + var max = 2; + var x = tf.tensor1d([3, -2, 1]); + var dy = tf.tensor1d([5, 50, 500]); + var gradients = tf.grad(function (x) { return x.clipByValue(min, max); })(x, dy); + expect(gradients.shape).toEqual(x.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 500]); + }); + it('derivative: 1D tensor with max or min value', function () { + var min = -1; + var max = 2; + var x = tf.tensor1d([-1, 1, 2, 3]); + var dy = tf.tensor1d([1, 10, 100, 1000]); + var gradients = tf.grad(function (x) { return x.clipByValue(min, max); })(x, dy); + expect(gradients.shape).toEqual(x.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [1, 10, 100, 0]); + }); + it('derivative: scalar', function () { + var min = -1; + var max = 2; + var x = tf.scalar(-10); + var dy = tf.scalar(5); + var gradients = tf.grad(function (x) { return x.clipByValue(min, max); })(x, dy); + expect(gradients.shape).toEqual(x.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.clipByValue({}, 0, 1); }) + .toThrowError(/Argument 'x' passed to 'clipByValue' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var min = -1; + var max = 50; + var result = tf.clipByValue([3, -1, 0, 100, -7, 2], min, max); + test_util_1.expectArraysClose(result, [3, -1, 0, 50, -1, 2]); + }); +}); +jasmine_util_1.describeWithFlags('round', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var a = tf.tensor1d([0.9, 2.5, 2.3, 1.5, -4.5]); + var r = a.round(); + test_util_1.expectNumbersClose(r.get(0), 1.0); + test_util_1.expectNumbersClose(r.get(1), 2.0); + test_util_1.expectNumbersClose(r.get(2), 2.0); + test_util_1.expectNumbersClose(r.get(3), 2.0); + test_util_1.expectNumbersClose(r.get(4), -4.0); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([1.5, NaN, -1.4]); + var r = tf.round(a); + test_util_1.expectArraysClose(r, [2, NaN, -1]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(5.2); + var dy = tf.scalar(3); + var gradients = tf.grad(function (a) { return tf.round(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0]); + }); + it('gradients: Tensor1D', function () { + var a = tf.tensor1d([-1.1, 2.6, 3, -5.9]); + var dy = tf.tensor1d([1, 2, 3, 4]); + var gradients = tf.grad(function (a) { return tf.round(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('gradients: Tensor2D', function () { + var a = tf.tensor2d([-3, 1, 2.2, 3], [2, 2]); + var dy = tf.tensor2d([1, 2, 3, 4], [2, 2]); + var gradients = tf.grad(function (a) { return tf.round(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [0, 0, 0, 0]); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.round({}); }) + .toThrowError(/Argument 'x' passed to 'round' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var r = tf.round([0.9, 2.5, 2.3, 1.5, -4.5]); + test_util_1.expectArraysClose(r, [1, 2, 2, 2, -4]); + }); +}); +jasmine_util_1.describeWithFlags('asinh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [1, -3, 2, 7, -4]; + var a = tf.tensor1d(values); + var result = tf.asinh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.asinh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var a = tf.scalar(1); + var result = tf.asinh(a); + var expected = [Math.asinh(1)]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2D', function () { + var values = [1, -3, 2, 7]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.asinh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.asinh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 0]); + var res = tf.asinh(a); + test_util_1.expectArraysClose(res, [Math.asinh(4), NaN, Math.asinh(0)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.asinh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 / Math.sqrt(1.0 + 0.5 * 0.5)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-1, 2, 3, -5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.asinh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(1 + aValues[i] * aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-3, 1, 2, 3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.asinh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(1 + aValues[i] * aValues[i]); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.asinh({}); }) + .toThrowError(/Argument 'x' passed to 'asinh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [1, -3, 2, 7, -4]; + var result = tf.asinh(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.asinh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('acosh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [2, 3, 4, 5, 6]; + var a = tf.tensor1d(values); + var result = tf.acosh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.acosh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var value = 2; + var a = tf.scalar(value); + var result = tf.acosh(a); + var expected = [Math.acosh(value)]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2d', function () { + var values = [2, 3, 4, 5]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.acosh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.acosh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([4, NaN, 2]); + var res = tf.acosh(a); + test_util_1.expectArraysClose(res, [Math.acosh(4), NaN, Math.acosh(2)]); + }); + it('NaN outside function domain', function () { + var a = tf.tensor1d([4, -1, 2]); + var res = tf.acosh(a); + test_util_1.expectArraysClose(res, [Math.acosh(4), NaN, Math.acosh(2)]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(1.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.acosh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8.0 / Math.sqrt(1.5 * 1.5 - 1.0)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [2, 3, 5, 10]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.acosh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(Math.pow(aValues[i], 2) - 1.0); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [2, 3, 5, 7]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.acosh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / Math.sqrt(Math.pow(aValues[i], 2) - 1.0); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.acosh({}); }) + .toThrowError(/Argument 'x' passed to 'acosh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var values = [2, 3, 4, 5, 6]; + var result = tf.acosh(values); + var expected = []; + for (var i = 0; i < values.length; i++) { + expected[i] = Math.acosh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); +}); +jasmine_util_1.describeWithFlags('atanh', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [-0.25, 0.25, 0.5, .75, -0.4]; + var a = tf.tensor1d(values); + var result = tf.atanh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.atanh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var value = 0.2; + var a = tf.scalar(value); + var result = tf.atanh(a); + var expected = [Math.atanh(value)]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2d', function () { + var values = [0.2, 0.3, 0.4, 0.5]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.atanh(a); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = Math.atanh(values[i]); + } + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([0.5, NaN, 0]); + var res = tf.atanh(a); + test_util_1.expectArraysClose(res, [Math.atanh(0.5), NaN, Math.atanh(0)]); + }); + it('NaN outside function domain', function () { + var a = tf.tensor1d([-2, 0, 2]); + var res = tf.atanh(a); + test_util_1.expectArraysClose(res, [NaN, Math.atanh(0), NaN]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.atanh(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 / (1 - 0.5 * 0.5)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-0.1, 0.2, 0.3, -0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.atanh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (1 - Math.pow(aValues[i], 2)); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-0.3, 0.1, 0.2, 0.3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.atanh(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] / (1 - Math.pow(aValues[i], 2)); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.atanh({}); }) + .toThrowError(/Argument 'x' passed to 'atanh' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.atanh(0.2); + test_util_1.expectNumbersClose(result.get(), Math.atanh(0.2)); + }); +}); +jasmine_util_1.describeWithFlags('erf', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var values = [-0.25, 0.25, 0.5, .75, -0.4]; + var a = tf.tensor1d(values); + var result = tf.erf(a); + var expected = [-0.2763264, 0.2763264, 0.5204999, 0.7111556, -0.4283924]; + test_util_1.expectArraysClose(result, expected); + }); + it('scalar', function () { + var a = tf.scalar(1); + var result = tf.erf(a); + var expected = [0.8427008]; + test_util_1.expectArraysClose(result, expected); + }); + it('scalar in int32', function () { + var a = tf.scalar(1, 'int32'); + var result = tf.erf(a); + var expected = [0.8427008]; + test_util_1.expectArraysClose(result, expected); + }); + it('tensor2d', function () { + var values = [0.2, 0.3, 0.4, 0.5]; + var a = tf.tensor2d(values, [2, 2]); + var result = tf.erf(a); + var expected = [0.2227026, 0.32862678, 0.42839235, 0.5204999]; + test_util_1.expectArraysClose(result, expected); + }); + it('propagates NaNs', function () { + var a = tf.tensor1d([0.5, NaN, 0]); + var res = tf.erf(a); + test_util_1.expectArraysClose(res, [0.5204999, NaN, 0.0]); + }); + it('gradients: Scalar', function () { + var a = tf.scalar(0.5); + var dy = tf.scalar(8); + var gradients = tf.grad(function (a) { return tf.erf(a); })(a, dy); + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, [8 * 2 * Math.exp(-0.5 * 0.5) / Math.sqrt(Math.PI)]); + }); + it('gradients: Tensor1D', function () { + var aValues = [-0.1, 0.2, 0.3, -0.5]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor1d(aValues); + var dy = tf.tensor1d(dyValues); + var gradients = tf.grad(function (a) { return tf.erf(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * 2 * Math.exp(-aValues[i] * aValues[i]) / + Math.sqrt(Math.PI); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('gradients: Tensor2D', function () { + var aValues = [-0.3, 0.1, 0.2, 0.3]; + var dyValues = [1, 2, 3, 4]; + var a = tf.tensor2d(aValues, [2, 2]); + var dy = tf.tensor2d(dyValues, [2, 2]); + var gradients = tf.grad(function (a) { return tf.erf(a); })(a, dy); + var expected = []; + for (var i = 0; i < a.size; i++) { + expected[i] = dyValues[i] * 2 * Math.exp(-aValues[i] * aValues[i]) / + Math.sqrt(Math.PI); + } + expect(gradients.shape).toEqual(a.shape); + expect(gradients.dtype).toEqual('float32'); + test_util_1.expectArraysClose(gradients, expected); + }); + it('throws when passed a non-tensor', function () { + expect(function () { return tf.erf({}); }) + .toThrowError(/Argument 'x' passed to 'erf' must be a Tensor/); + }); + it('accepts a tensor-like object', function () { + var result = tf.erf(1); + test_util_1.expectNumbersClose(result.get(), 0.8427008); + }); +}); +//# sourceMappingURL=unary_ops_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js.map new file mode 100644 index 0000000..55648ee --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/ops/unary_ops_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"unary_ops_test.js","sourceRoot":"","sources":["../../src/ops/unary_ops_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.d.ts new file mode 100644 index 0000000..ffe845b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.d.ts @@ -0,0 +1,20 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class AdadeltaOptimizer extends Optimizer { + protected learningRate: number; + protected rho: number; + protected epsilon: number; + static className: string; + private c; + private epsilonScalar; + private rhoScalar; + private oneMinusRho; + private accumulatedGrads; + private accumulatedUpdates; + constructor(learningRate: number, rho: number, epsilon?: number); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js new file mode 100644 index 0000000..c15f914 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js @@ -0,0 +1,107 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var optimizer_utils = require("./optimizer_utils"); +var AdadeltaOptimizer = (function (_super) { + __extends(AdadeltaOptimizer, _super); + function AdadeltaOptimizer(learningRate, rho, epsilon) { + if (epsilon === void 0) { epsilon = null; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.rho = rho; + _this.epsilon = epsilon; + _this.accumulatedGrads = {}; + _this.accumulatedUpdates = {}; + _this.c = globals_1.keep(ops_1.scalar(-learningRate)); + _this.rhoScalar = globals_1.keep(ops_1.scalar(rho)); + _this.oneMinusRho = globals_1.keep(ops_1.scalar(1 - rho)); + if (epsilon === null) { + epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue(); + } + _this.epsilonScalar = globals_1.keep(ops_1.scalar(epsilon)); + return _this; + } + AdadeltaOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedGrads[variableName] == null) { + var trainable_1 = false; + globals_1.tidy(function () { + _this.accumulatedGrads[variableName] = + ops_1.zerosLike(value).variable(trainable_1); + }); + } + if (this_1.accumulatedUpdates[variableName] == null) { + var trainable_2 = false; + globals_1.tidy(function () { + _this.accumulatedUpdates[variableName] = + ops_1.zerosLike(value).variable(trainable_2); + }); + } + var gradient = variableGradients[variableName]; + var accumulatedGrad = this_1.accumulatedGrads[variableName]; + var accumulatedUpdate = this_1.accumulatedUpdates[variableName]; + globals_1.tidy(function () { + var newAccumulatedGrad = _this.rhoScalar.mul(accumulatedGrad) + .add(_this.oneMinusRho.mul(gradient.square())); + var updates = accumulatedUpdate.add(_this.epsilonScalar) + .sqrt() + .div(accumulatedGrad.add(_this.epsilonScalar).sqrt()) + .mul(gradient); + var newAccumulatedUpdate = _this.rhoScalar.mul(accumulatedUpdate) + .add(_this.oneMinusRho.mul(updates.square())); + _this.accumulatedGrads[variableName].assign(newAccumulatedGrad); + _this.accumulatedUpdates[variableName].assign(newAccumulatedUpdate); + var newValue = _this.c.mul(updates).add(value); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + AdadeltaOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsilonScalar.dispose(); + this.rhoScalar.dispose(); + this.oneMinusRho.dispose(); + if (this.accumulatedUpdates != null) { + Object.keys(this.accumulatedUpdates) + .forEach(function (name) { return _this.accumulatedUpdates[name].dispose(); }); + Object.keys(this.accumulatedGrads) + .forEach(function (name) { return _this.accumulatedGrads[name].dispose(); }); + } + }; + AdadeltaOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + rho: this.rho, + epsilon: this.epsilon + }; + }; + AdadeltaOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.rho, config.epsilon); + }; + AdadeltaOptimizer.className = 'AdadeltaOptimizer'; + return AdadeltaOptimizer; +}(optimizer_1.Optimizer)); +exports.AdadeltaOptimizer = AdadeltaOptimizer; +serialization_1.SerializationMap.register(AdadeltaOptimizer); +//# sourceMappingURL=adadelta_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js.map new file mode 100644 index 0000000..f478fe4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adadelta_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/adadelta_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js new file mode 100644 index 0000000..3afad4c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('AdadeltaOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var rho = .95; + var optimizer = tf.train.adadelta(learningRate, rho); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 3); + test_util_1.expectArraysClose(x, [0.8, 1.6]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.64, 1.28]); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.adadelta(0.1, 0.2, 2e-8); + var reserialized = tf.AdadeltaOptimizer.fromConfig(tf.AdadeltaOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=adadelta_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js.map new file mode 100644 index 0000000..29749f7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adadelta_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adadelta_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/adadelta_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,mBAAmB,EAAE,oBAAQ,EAAE;IAC/C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,GAAG,GAAG,GAAG,CAAC;QAChB,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;QAEvD,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAepD,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAQrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAGnC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACtD,IAAM,YAAY,GAAG,EAAE,CAAC,iBAAiB,CAAC,UAAU,CAChD,EAAE,CAAC,iBAAiB,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QACnD,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.d.ts new file mode 100644 index 0000000..353dd2e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.d.ts @@ -0,0 +1,16 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class AdagradOptimizer extends Optimizer { + protected learningRate: number; + private initialAccumulatorValue; + static className: string; + private c; + private epsilon; + private accumulatedGrads; + constructor(learningRate: number, initialAccumulatorValue?: number); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js new file mode 100644 index 0000000..e98c3c3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js @@ -0,0 +1,83 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var optimizer_utils = require("./optimizer_utils"); +var AdagradOptimizer = (function (_super) { + __extends(AdagradOptimizer, _super); + function AdagradOptimizer(learningRate, initialAccumulatorValue) { + if (initialAccumulatorValue === void 0) { initialAccumulatorValue = 0.1; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.initialAccumulatorValue = initialAccumulatorValue; + _this.accumulatedGrads = {}; + _this.c = globals_1.keep(ops_1.scalar(-learningRate)); + var epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue(); + _this.epsilon = globals_1.keep(ops_1.scalar(epsilon)); + return _this; + } + AdagradOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedGrads[variableName] == null) { + var trainable_1 = false; + globals_1.tidy(function () { + _this.accumulatedGrads[variableName] = + ops_1.fill(value.shape, _this.initialAccumulatorValue) + .variable(trainable_1); + }); + } + var gradient = variableGradients[variableName]; + var accumulatedGrad = this_1.accumulatedGrads[variableName]; + globals_1.tidy(function () { + var newAccumulatedGrad = accumulatedGrad.add(gradient.square()); + _this.accumulatedGrads[variableName].assign(newAccumulatedGrad); + var newValue = _this.c + .mul(gradient.div(newAccumulatedGrad.add(_this.epsilon).sqrt())) + .add(value); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + AdagradOptimizer.prototype.dispose = function () { + var _this = this; + this.epsilon.dispose(); + this.c.dispose(); + if (this.accumulatedGrads != null) { + Object.keys(this.accumulatedGrads) + .forEach(function (name) { return _this.accumulatedGrads[name].dispose(); }); + } + }; + AdagradOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + initialAccumulatorValue: this.initialAccumulatorValue, + }; + }; + AdagradOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.initialAccumulatorValue); + }; + AdagradOptimizer.className = 'AdagradOptimizer'; + return AdagradOptimizer; +}(optimizer_1.Optimizer)); +exports.AdagradOptimizer = AdagradOptimizer; +serialization_1.SerializationMap.register(AdagradOptimizer); +//# sourceMappingURL=adagrad_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js.map new file mode 100644 index 0000000..9775ff9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adagrad_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/adagrad_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js new file mode 100644 index 0000000..86c4491 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('AdagradOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var initialAccumulatorValue = .1; + var optimizer = tf.train.adagrad(learningRate, initialAccumulatorValue); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 2); + test_util_1.expectArraysClose(x, [0.9012270405, 1.9003110428]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.8347372764, 1.83015597828], 1e-2); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.adagrad(0.1, 0.2); + var reserialized = tf.AdagradOptimizer.fromConfig(tf.AdagradOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=adagrad_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js.map new file mode 100644 index 0000000..83d25c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adagrad_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adagrad_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/adagrad_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,kBAAkB,EAAE,oBAAQ,EAAE;IAC9C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,uBAAuB,GAAG,EAAE,CAAC;QACnC,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,uBAAuB,CAAC,CAAC;QAE1E,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QASpD,6BAAiB,CAAC,CAAC,EAAE,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC;QAEnD,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAQrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,YAAY,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC;QAG1D,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/C,IAAM,YAAY,GAAG,EAAE,CAAC,gBAAgB,CAAC,UAAU,CAC/C,EAAE,CAAC,gBAAgB,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QAClD,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.d.ts new file mode 100644 index 0000000..55ce06b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.d.ts @@ -0,0 +1,26 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class AdamOptimizer extends Optimizer { + protected learningRate: number; + protected beta1: number; + protected beta2: number; + protected epsilon: number; + static className: string; + private c; + private epsScalar; + private beta1Scalar; + private beta2Scalar; + private accBeta1; + private accBeta2; + private oneMinusBeta1; + private oneMinusBeta2; + private one; + private accumulatedFirstMoment; + private accumulatedSecondMoment; + constructor(learningRate: number, beta1: number, beta2: number, epsilon?: number); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js new file mode 100644 index 0000000..76e270f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js @@ -0,0 +1,119 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var optimizer_utils = require("./optimizer_utils"); +var AdamOptimizer = (function (_super) { + __extends(AdamOptimizer, _super); + function AdamOptimizer(learningRate, beta1, beta2, epsilon) { + if (epsilon === void 0) { epsilon = null; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.beta1 = beta1; + _this.beta2 = beta2; + _this.epsilon = epsilon; + _this.accumulatedFirstMoment = {}; + _this.accumulatedSecondMoment = {}; + _this.c = globals_1.keep(ops_1.scalar(-learningRate)); + _this.beta1Scalar = globals_1.keep(ops_1.scalar(beta1)); + _this.beta2Scalar = globals_1.keep(ops_1.scalar(beta2)); + globals_1.tidy(function () { + _this.accBeta1 = ops_1.scalar(beta1).variable(); + _this.accBeta2 = ops_1.scalar(beta2).variable(); + }); + _this.oneMinusBeta1 = globals_1.keep(ops_1.scalar(1 - beta1)); + _this.oneMinusBeta2 = globals_1.keep(ops_1.scalar(1 - beta2)); + _this.one = globals_1.keep(ops_1.scalar(1)); + if (epsilon === null) { + epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue(); + } + _this.epsScalar = globals_1.keep(ops_1.scalar(epsilon)); + return _this; + } + AdamOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + globals_1.tidy(function () { + var oneMinusAccBeta1 = _this.one.sub(_this.accBeta1); + var oneMinusAccBeta2 = _this.one.sub(_this.accBeta2); + for (var variableName in variableGradients) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (_this.accumulatedFirstMoment[variableName] == null) { + var trainable = false; + _this.accumulatedFirstMoment[variableName] = + ops_1.zerosLike(value).variable(trainable); + } + if (_this.accumulatedSecondMoment[variableName] == null) { + var trainable = false; + _this.accumulatedSecondMoment[variableName] = + ops_1.zerosLike(value).variable(trainable); + } + var gradient = variableGradients[variableName]; + var firstMoment = _this.accumulatedFirstMoment[variableName]; + var secondMoment = _this.accumulatedSecondMoment[variableName]; + var newFirstMoment = _this.beta1Scalar.mul(firstMoment) + .add(_this.oneMinusBeta1.mul(gradient)); + var newSecondMoment = _this.beta2Scalar.mul(secondMoment) + .add(_this.oneMinusBeta2.mul(gradient.square())); + var biasCorrectedFirstMoment = newFirstMoment.div(oneMinusAccBeta1); + var biasCorrectedSecondMoment = newSecondMoment.div(oneMinusAccBeta2); + _this.accumulatedFirstMoment[variableName].assign(newFirstMoment); + _this.accumulatedSecondMoment[variableName].assign(newSecondMoment); + var newValue = _this.c + .mul(biasCorrectedFirstMoment.div(_this.epsScalar.add(biasCorrectedSecondMoment.sqrt()))) + .add(value); + value.assign(newValue); + } + _this.accBeta1.assign(_this.accBeta1.mul(_this.beta1Scalar)); + _this.accBeta2.assign(_this.accBeta2.mul(_this.beta2Scalar)); + }); + }; + AdamOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsScalar.dispose(); + this.beta1Scalar.dispose(); + this.beta2Scalar.dispose(); + this.accBeta1.dispose(); + this.accBeta2.dispose(); + this.oneMinusBeta1.dispose(); + this.oneMinusBeta2.dispose(); + this.one.dispose(); + if (this.accumulatedFirstMoment != null) { + Object.keys(this.accumulatedFirstMoment) + .forEach(function (name) { return _this.accumulatedFirstMoment[name].dispose(); }); + } + if (this.accumulatedSecondMoment != null) { + Object.keys(this.accumulatedSecondMoment) + .forEach(function (name) { return _this.accumulatedSecondMoment[name].dispose(); }); + } + }; + AdamOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + beta1: this.beta1, + beta2: this.beta2, + epsilon: this.epsilon, + }; + }; + AdamOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.beta1, config.beta2, config.epsilon); + }; + AdamOptimizer.className = 'AdamOptimizer'; + return AdamOptimizer; +}(optimizer_1.Optimizer)); +exports.AdamOptimizer = AdamOptimizer; +serialization_1.SerializationMap.register(AdamOptimizer); +//# sourceMappingURL=adam_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js.map new file mode 100644 index 0000000..393f28e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adam_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/adam_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js new file mode 100644 index 0000000..dd884b2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('AdamOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var beta1 = .8; + var beta2 = .9; + var optimizer = tf.train.adam(learningRate, beta1, beta2); + var x = tf.tensor1d([2, 4]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 3); + test_util_1.expectArraysClose(x, [1.9, 3.9]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [1.8000001, 3.8002]); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.adam(0.1, 0.2, 0.3, 2e-8); + var reserialized = tf.AdamOptimizer.fromConfig(tf.AdamOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=adam_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js.map new file mode 100644 index 0000000..91ab4ee --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adam_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adam_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/adam_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,eAAe,EAAE,oBAAQ,EAAE;IAC3C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,KAAK,GAAG,EAAE,CAAC;QACjB,IAAM,KAAK,GAAG,EAAE,CAAC;QACjB,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5D,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAapD,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAcrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;QAE1C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACvD,IAAM,YAAY,GACd,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC,aAAa,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QAC3E,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.d.ts new file mode 100644 index 0000000..1a60bfd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.d.ts @@ -0,0 +1,27 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class AdamaxOptimizer extends Optimizer { + protected learningRate: number; + protected beta1: number; + protected beta2: number; + protected epsilon: number; + protected decay: number; + static className: string; + private c; + private epsScalar; + private accBeta1; + private beta1Scalar; + private beta2Scalar; + private decayScalar; + private oneMinusBeta1; + private one; + private iteration; + private accumulatedFirstMoment; + private accumulatedWeightedInfNorm; + constructor(learningRate: number, beta1: number, beta2: number, epsilon?: number, decay?: number); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js new file mode 100644 index 0000000..0e07b96 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js @@ -0,0 +1,121 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var optimizer_utils = require("./optimizer_utils"); +var AdamaxOptimizer = (function (_super) { + __extends(AdamaxOptimizer, _super); + function AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay) { + if (epsilon === void 0) { epsilon = null; } + if (decay === void 0) { decay = 0.0; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.beta1 = beta1; + _this.beta2 = beta2; + _this.epsilon = epsilon; + _this.decay = decay; + _this.accumulatedFirstMoment = {}; + _this.accumulatedWeightedInfNorm = {}; + _this.c = globals_1.keep(ops_1.scalar(-learningRate)); + _this.beta1Scalar = globals_1.keep(ops_1.scalar(beta1)); + _this.beta2Scalar = globals_1.keep(ops_1.scalar(beta2)); + _this.decayScalar = globals_1.keep(ops_1.scalar(decay)); + globals_1.tidy(function () { + _this.iteration = ops_1.scalar(0).variable(); + _this.accBeta1 = ops_1.scalar(beta1).variable(); + }); + _this.oneMinusBeta1 = globals_1.keep(ops_1.scalar(1 - beta1)); + _this.one = globals_1.keep(ops_1.scalar(1)); + if (epsilon === null) { + epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue(); + } + _this.epsScalar = globals_1.keep(ops_1.scalar(epsilon)); + return _this; + } + AdamaxOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + globals_1.tidy(function () { + var oneMinusAccBeta1 = _this.one.sub(_this.accBeta1); + var lr = _this.c.div(_this.one.add(_this.decayScalar.mul(_this.iteration))); + for (var variableName in variableGradients) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (_this.accumulatedFirstMoment[variableName] == null) { + var trainable = false; + _this.accumulatedFirstMoment[variableName] = + ops_1.zerosLike(value).variable(trainable); + } + if (_this.accumulatedWeightedInfNorm[variableName] == null) { + var trainable = false; + _this.accumulatedWeightedInfNorm[variableName] = + ops_1.zerosLike(value).variable(trainable); + } + var gradient = variableGradients[variableName]; + var firstMoment = _this.accumulatedFirstMoment[variableName]; + var weightedInfNorm = _this.accumulatedWeightedInfNorm[variableName]; + var newFirstMoment = _this.beta1Scalar.mul(firstMoment) + .add(_this.oneMinusBeta1.mul(gradient)); + var ut0 = _this.beta2Scalar.mul(weightedInfNorm); + var ut1 = gradient.abs(); + var newWeightedInfNorm = ut0.maximum(ut1); + _this.accumulatedFirstMoment[variableName].assign(newFirstMoment); + _this.accumulatedWeightedInfNorm[variableName].assign(newWeightedInfNorm); + var newValue = lr.div(oneMinusAccBeta1) + .mul(newFirstMoment.div(_this.epsScalar.add(newWeightedInfNorm))) + .add(value); + value.assign(newValue); + } + _this.iteration.assign(_this.iteration.add(_this.one)); + _this.accBeta1.assign(_this.accBeta1.mul(_this.beta1Scalar)); + }); + }; + AdamaxOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsScalar.dispose(); + this.accBeta1.dispose(); + this.beta1Scalar.dispose(); + this.beta2Scalar.dispose(); + this.oneMinusBeta1.dispose(); + this.decayScalar.dispose(); + this.iteration.dispose(); + this.one.dispose(); + if (this.accumulatedFirstMoment != null) { + Object.keys(this.accumulatedFirstMoment) + .forEach(function (name) { return _this.accumulatedFirstMoment[name].dispose(); }); + } + if (this.accumulatedWeightedInfNorm != null) { + Object.keys(this.accumulatedWeightedInfNorm) + .forEach(function (name) { return _this.accumulatedWeightedInfNorm[name].dispose(); }); + } + }; + AdamaxOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + beta1: this.beta1, + beta2: this.beta2, + epsilon: this.epsilon, + decay: this.decay + }; + }; + AdamaxOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.beta1, config.beta2, config.epsilon, config.decay); + }; + AdamaxOptimizer.className = 'AdamaxOptimizer'; + return AdamaxOptimizer; +}(optimizer_1.Optimizer)); +exports.AdamaxOptimizer = AdamaxOptimizer; +serialization_1.SerializationMap.register(AdamaxOptimizer); +//# sourceMappingURL=adamax_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js.map new file mode 100644 index 0000000..25461c8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adamax_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/adamax_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js new file mode 100644 index 0000000..9b7270f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js @@ -0,0 +1,35 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('AdamaxOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = 0.1; + var beta1 = 0.8; + var beta2 = 0.9; + var decay = 0.1; + var optimizer = tf.train.adamax(learningRate, beta1, beta2, undefined, decay); + var x = tf.tensor1d([2, 4]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 3); + test_util_1.expectArraysClose(x, [1.9, 3.9]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [1.80697, 3.8086]); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.adamax(0.1, 0.2, 0.3, 2e-8, 0.1); + var reserialized = tf.AdamaxOptimizer.fromConfig(tf.AdamaxOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=adamax_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js.map new file mode 100644 index 0000000..1408fe6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/adamax_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"adamax_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/adamax_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,iBAAiB,EAAE,oBAAQ,EAAE;IAC7C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,GAAG,CAAC;QACzB,IAAM,KAAK,GAAG,GAAG,CAAC;QAClB,IAAM,KAAK,GAAG,GAAG,CAAC;QAClB,IAAM,KAAK,GAAG,GAAG,CAAC;QAClB,IAAM,SAAS,GACX,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QAElE,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAuBpD,6BAAiB,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEjC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAiCrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;QAExC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;QAC9D,IAAM,YAAY,GAAG,EAAE,CAAC,eAAe,CAAC,UAAU,CAC9C,EAAE,CAAC,eAAe,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QACjD,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.d.ts new file mode 100644 index 0000000..474f9a3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.d.ts @@ -0,0 +1,17 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { SGDOptimizer } from './sgd_optimizer'; +export declare class MomentumOptimizer extends SGDOptimizer { + protected learningRate: number; + private momentum; + private useNesterov; + static className: string; + private m; + private accumulations; + constructor(learningRate: number, momentum: number, useNesterov?: boolean); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + setMomentum(momentum: number): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js new file mode 100644 index 0000000..4c0c494 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js @@ -0,0 +1,89 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var sgd_optimizer_1 = require("./sgd_optimizer"); +var MomentumOptimizer = (function (_super) { + __extends(MomentumOptimizer, _super); + function MomentumOptimizer(learningRate, momentum, useNesterov) { + if (useNesterov === void 0) { useNesterov = false; } + var _this = _super.call(this, learningRate) || this; + _this.learningRate = learningRate; + _this.momentum = momentum; + _this.useNesterov = useNesterov; + _this.m = ops_1.scalar(_this.momentum); + _this.accumulations = {}; + return _this; + } + MomentumOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (this_1.accumulations[variableName] == null) { + var trainable_1 = false; + globals_1.tidy(function () { + _this.accumulations[variableName] = + ops_1.zerosLike(value).variable(trainable_1); + }); + } + var accumulation = this_1.accumulations[variableName]; + var gradient = variableGradients[variableName]; + globals_1.tidy(function () { + var newValue; + var newAccumulation = _this.m.mul(accumulation).add(gradient); + if (_this.useNesterov) { + newValue = + _this.c.mul(gradient.add(newAccumulation.mul(_this.m))).add(value); + } + else { + newValue = _this.c.mul(newAccumulation).add(value); + } + _this.accumulations[variableName].assign(newAccumulation); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + MomentumOptimizer.prototype.dispose = function () { + _super.prototype.dispose.call(this); + this.m.dispose(); + if (this.accumulations != null) { + for (var variableName in this.accumulations) { + this.accumulations[variableName].dispose(); + } + } + }; + MomentumOptimizer.prototype.setMomentum = function (momentum) { + this.momentum = momentum; + }; + MomentumOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + momentum: this.momentum, + useNesterov: this.useNesterov + }; + }; + MomentumOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.momentum, config.useNesterov); + }; + MomentumOptimizer.className = 'MomentumOptimizer'; + return MomentumOptimizer; +}(sgd_optimizer_1.SGDOptimizer)); +exports.MomentumOptimizer = MomentumOptimizer; +serialization_1.SerializationMap.register(MomentumOptimizer); +//# sourceMappingURL=momentum_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js.map new file mode 100644 index 0000000..c938628 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"momentum_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/momentum_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js new file mode 100644 index 0000000..6364dea --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js @@ -0,0 +1,54 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('MomentumOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var momentum = .5; + var optimizer = tf.train.momentum(learningRate, momentum); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 2); + test_util_1.expectArraysClose(x, [.8, 1.6]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.54, 1.08]); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('basic - with Nesterov', function () { + var learningRate = .1; + var momentum = .5; + var useNesterov = true; + var optimizer = tf.train.momentum(learningRate, momentum, useNesterov); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 2); + test_util_1.expectArraysClose(x, [.7, 1.4]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.44, 0.88]); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.momentum(0.1, 0.2, true); + var reserialized = tf.MomentumOptimizer.fromConfig(tf.MomentumOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=momentum_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js.map new file mode 100644 index 0000000..e492c00 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/momentum_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"momentum_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/momentum_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,mBAAmB,EAAE,oBAAQ,EAAE;IAC/C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAE5D,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAQpD,6BAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC;QAEhC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAMrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAGnC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,IAAM,WAAW,GAAG,IAAI,CAAC;QACzB,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;QAEzE,IAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzC,IAAM,CAAC,GAAG,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAe,EAA7B,CAA6B,CAAC;QAE9C,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,IAAI,CAAC,CAAC;QAGxD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAUpD,6BAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC;QAEhC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAmB,KAAK,CAAC,CAAC;QAOrD,6BAAiB,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAGnC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,CAAC,CAAC,OAAO,EAAE,CAAC;QACZ,SAAS,CAAC,OAAO,EAAE,CAAC;QAGpB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACtD,IAAM,YAAY,GAAG,EAAE,CAAC,iBAAiB,CAAC,UAAU,CAChD,EAAE,CAAC,iBAAiB,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QACnD,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.d.ts new file mode 100644 index 0000000..f6d375a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.d.ts @@ -0,0 +1,11 @@ +import { Serializable } from '../serialization'; +import { Scalar, Variable } from '../tensor'; +import { NamedTensorMap } from '../tensor_types'; +export declare abstract class Optimizer extends Serializable { + minimize(f: () => Scalar, returnCost?: boolean, varList?: Variable[]): Scalar | null; + computeGradients(f: () => Scalar, varList?: Variable[]): { + value: Scalar; + grads: NamedTensorMap; + }; + abstract applyGradients(variableGradients: NamedTensorMap): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js new file mode 100644 index 0000000..c96a875 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js @@ -0,0 +1,40 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var globals_1 = require("../globals"); +var serialization_1 = require("../serialization"); +var Optimizer = (function (_super) { + __extends(Optimizer, _super); + function Optimizer() { + return _super !== null && _super.apply(this, arguments) || this; + } + Optimizer.prototype.minimize = function (f, returnCost, varList) { + if (returnCost === void 0) { returnCost = false; } + var _a = this.computeGradients(f, varList), value = _a.value, grads = _a.grads; + this.applyGradients(grads); + var varNames = Object.keys(grads); + varNames.forEach(function (varName) { return grads[varName].dispose(); }); + if (returnCost) { + return value; + } + else { + value.dispose(); + return null; + } + }; + Optimizer.prototype.computeGradients = function (f, varList) { + return globals_1.variableGrads(f, varList); + }; + return Optimizer; +}(serialization_1.Serializable)); +exports.Optimizer = Optimizer; +//# sourceMappingURL=optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js.map new file mode 100644 index 0000000..98625c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizer.js","sourceRoot":"","sources":["../../src/optimizers/optimizer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAiBA,sCAAyC;AACzC,kDAA8C;AAK9C;IAAwC,6BAAY;IAApD;;IAmDA,CAAC;IAtCC,4BAAQ,GAAR,UAAS,CAAe,EAAE,UAAkB,EAAE,OAAoB;QAAxC,2BAAA,EAAA,kBAAkB;QAEpC,IAAA,sCAAkD,EAAjD,gBAAK,EAAE,gBAAK,CAAsC;QAEzD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAG3B,IAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,QAAQ,CAAC,OAAO,CAAC,UAAA,OAAO,IAAI,OAAA,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAxB,CAAwB,CAAC,CAAC;QAEtD,IAAI,UAAU,EAAE;YACd,OAAO,KAAe,CAAC;SACxB;aAAM;YACL,KAAK,CAAC,OAAO,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAYD,oCAAgB,GAAhB,UAAiB,CAAe,EAAE,OAAoB;QAEpD,OAAO,uBAAa,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IACnC,CAAC;IAOH,gBAAC;AAAD,CAAC,AAnDD,CAAwC,4BAAY,GAmDnD;AAnDqB,8BAAS"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.d.ts new file mode 100644 index 0000000..39ed799 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.d.ts @@ -0,0 +1,16 @@ +import { AdadeltaOptimizer } from './adadelta_optimizer'; +import { AdagradOptimizer } from './adagrad_optimizer'; +import { AdamOptimizer } from './adam_optimizer'; +import { AdamaxOptimizer } from './adamax_optimizer'; +import { MomentumOptimizer } from './momentum_optimizer'; +import { RMSPropOptimizer } from './rmsprop_optimizer'; +import { SGDOptimizer } from './sgd_optimizer'; +export declare class OptimizerConstructors { + static sgd(learningRate: number): SGDOptimizer; + static momentum(learningRate: number, momentum: number, useNesterov?: boolean): MomentumOptimizer; + static rmsprop(learningRate: number, decay?: number, momentum?: number, epsilon?: number, centered?: boolean): RMSPropOptimizer; + static adam(learningRate?: number, beta1?: number, beta2?: number, epsilon?: number): AdamOptimizer; + static adadelta(learningRate?: number, rho?: number, epsilon?: number): AdadeltaOptimizer; + static adamax(learningRate?: number, beta1?: number, beta2?: number, epsilon?: number, decay?: number): AdamaxOptimizer; + static adagrad(learningRate: number, initialAccumulatorValue?: number): AdagradOptimizer; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js new file mode 100644 index 0000000..37d3b07 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js @@ -0,0 +1,55 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var adadelta_optimizer_1 = require("./adadelta_optimizer"); +var adagrad_optimizer_1 = require("./adagrad_optimizer"); +var adam_optimizer_1 = require("./adam_optimizer"); +var adamax_optimizer_1 = require("./adamax_optimizer"); +var momentum_optimizer_1 = require("./momentum_optimizer"); +var rmsprop_optimizer_1 = require("./rmsprop_optimizer"); +var sgd_optimizer_1 = require("./sgd_optimizer"); +var OptimizerConstructors = (function () { + function OptimizerConstructors() { + } + OptimizerConstructors.sgd = function (learningRate) { + return new sgd_optimizer_1.SGDOptimizer(learningRate); + }; + OptimizerConstructors.momentum = function (learningRate, momentum, useNesterov) { + if (useNesterov === void 0) { useNesterov = false; } + return new momentum_optimizer_1.MomentumOptimizer(learningRate, momentum, useNesterov); + }; + OptimizerConstructors.rmsprop = function (learningRate, decay, momentum, epsilon, centered) { + if (decay === void 0) { decay = .9; } + if (momentum === void 0) { momentum = 0.0; } + if (epsilon === void 0) { epsilon = null; } + if (centered === void 0) { centered = false; } + return new rmsprop_optimizer_1.RMSPropOptimizer(learningRate, decay, momentum, epsilon, centered); + }; + OptimizerConstructors.adam = function (learningRate, beta1, beta2, epsilon) { + if (learningRate === void 0) { learningRate = 0.001; } + if (beta1 === void 0) { beta1 = 0.9; } + if (beta2 === void 0) { beta2 = 0.999; } + if (epsilon === void 0) { epsilon = null; } + return new adam_optimizer_1.AdamOptimizer(learningRate, beta1, beta2, epsilon); + }; + OptimizerConstructors.adadelta = function (learningRate, rho, epsilon) { + if (learningRate === void 0) { learningRate = .001; } + if (rho === void 0) { rho = .95; } + if (epsilon === void 0) { epsilon = null; } + return new adadelta_optimizer_1.AdadeltaOptimizer(learningRate, rho, epsilon); + }; + OptimizerConstructors.adamax = function (learningRate, beta1, beta2, epsilon, decay) { + if (learningRate === void 0) { learningRate = 0.002; } + if (beta1 === void 0) { beta1 = 0.9; } + if (beta2 === void 0) { beta2 = 0.999; } + if (epsilon === void 0) { epsilon = null; } + if (decay === void 0) { decay = 0.0; } + return new adamax_optimizer_1.AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay); + }; + OptimizerConstructors.adagrad = function (learningRate, initialAccumulatorValue) { + if (initialAccumulatorValue === void 0) { initialAccumulatorValue = 0.1; } + return new adagrad_optimizer_1.AdagradOptimizer(learningRate, initialAccumulatorValue); + }; + return OptimizerConstructors; +}()); +exports.OptimizerConstructors = OptimizerConstructors; +//# sourceMappingURL=optimizer_constructors.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js.map new file mode 100644 index 0000000..50300fd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_constructors.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizer_constructors.js","sourceRoot":"","sources":["../../src/optimizers/optimizer_constructors.ts"],"names":[],"mappings":";;AAiBA,2DAAuD;AACvD,yDAAqD;AACrD,mDAA+C;AAC/C,uDAAmD;AACnD,2DAAuD;AACvD,yDAAqD;AACrD,iDAA6C;AAE7C;IAAA;IA0KA,CAAC;IAnIQ,yBAAG,GAAV,UAAW,YAAoB;QAC7B,OAAO,IAAI,4BAAY,CAAC,YAAY,CAAC,CAAC;IACxC,CAAC;IAkBM,8BAAQ,GAAf,UAAgB,YAAoB,EAAE,QAAgB,EAAE,WAAmB;QAAnB,4BAAA,EAAA,mBAAmB;QAEzE,OAAO,IAAI,sCAAiB,CAAC,YAAY,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;IACpE,CAAC;IAuBM,6BAAO,GAAd,UACI,YAAoB,EAAE,KAAU,EAAE,QAAc,EAAE,OAAsB,EACxE,QAAgB;QADM,sBAAA,EAAA,UAAU;QAAE,yBAAA,EAAA,cAAc;QAAE,wBAAA,EAAA,cAAsB;QACxE,yBAAA,EAAA,gBAAgB;QAClB,OAAO,IAAI,oCAAgB,CACvB,YAAY,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IACxD,CAAC;IAeM,0BAAI,GAAX,UACI,YAAoB,EAAE,KAAW,EAAE,KAAa,EAChD,OAAsB;QADtB,6BAAA,EAAA,oBAAoB;QAAE,sBAAA,EAAA,WAAW;QAAE,sBAAA,EAAA,aAAa;QAChD,wBAAA,EAAA,cAAsB;QACxB,OAAO,IAAI,8BAAa,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;IAeM,8BAAQ,GAAf,UAAgB,YAAmB,EAAE,GAAS,EAAE,OAAsB;QAAtD,6BAAA,EAAA,mBAAmB;QAAE,oBAAA,EAAA,SAAS;QAAE,wBAAA,EAAA,cAAsB;QAEpE,OAAO,IAAI,sCAAiB,CAAC,YAAY,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAgBM,4BAAM,GAAb,UACI,YAAoB,EAAE,KAAW,EAAE,KAAa,EAAE,OAAsB,EACxE,KAAW;QADX,6BAAA,EAAA,oBAAoB;QAAE,sBAAA,EAAA,WAAW;QAAE,sBAAA,EAAA,aAAa;QAAE,wBAAA,EAAA,cAAsB;QACxE,sBAAA,EAAA,WAAW;QACb,OAAO,IAAI,kCAAe,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAmBM,6BAAO,GAAd,UAAe,YAAoB,EAAE,uBAA6B;QAA7B,wCAAA,EAAA,6BAA6B;QAEhE,OAAO,IAAI,oCAAgB,CAAC,YAAY,EAAE,uBAAuB,CAAC,CAAC;IACrE,CAAC;IACH,4BAAC;AAAD,CAAC,AA1KD,IA0KC;AA1KY,sDAAqB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js new file mode 100644 index 0000000..bca539d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js @@ -0,0 +1,136 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require(".."); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +var sgd_optimizer_1 = require("./sgd_optimizer"); +jasmine_util_1.describeWithFlags('optimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var optimizer = tf.train.sgd(learningRate); + var x = tf.scalar(4).variable(); + var bias = tf.scalar(1).variable(); + var strayVariable = tf.scalar(-1).variable(); + var numTensors = tf.memory().numTensors; + var f = function () { return x.square().addStrict(bias); }; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 1); + var expectedX1 = -2 * 4 * learningRate + 4; + var expectedBias1 = -1 * learningRate + 1; + test_util_1.expectArraysClose(x, [expectedX1]); + test_util_1.expectArraysClose(bias, [expectedBias1]); + test_util_1.expectArraysClose(cost, [Math.pow(4, 2) + 1]); + test_util_1.expectArraysClose(strayVariable, [-1]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + expect(tf.memory().numTensors).toBe(numTensors); + var expectedX2 = -2 * expectedX1 * learningRate + expectedX1; + var expectedBias2 = -learningRate + expectedBias1; + test_util_1.expectArraysClose(x, [expectedX2]); + test_util_1.expectArraysClose(bias, [expectedBias2]); + expect(cost).toBe(null); + test_util_1.expectArraysClose(strayVariable, [-1]); + optimizer.dispose(); + x.dispose(); + bias.dispose(); + strayVariable.dispose(); + expect(tf.memory().numTensors).toBe(3); + }); + it('varList array of all variables', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var x = tf.scalar(4).variable(); + var bias = tf.scalar(1).variable(); + var strayVariable = tf.scalar(-1).variable(); + var varList = [x, bias]; + var f = function () { return x.square().addStrict(bias); }; + var cost = optimizer.minimize(f, true, varList); + var expectedX1 = -2 * 4 * learningRate + 4; + var expectedBias1 = -1 * learningRate + 1; + test_util_1.expectArraysClose(x, [expectedX1]); + test_util_1.expectArraysClose(bias, [expectedBias1]); + test_util_1.expectArraysClose(cost, [Math.pow(4, 2) + 1]); + test_util_1.expectArraysClose(strayVariable, [-1]); + cost = optimizer.minimize(f, false, varList); + var expectedX2 = -2 * expectedX1 * learningRate + expectedX1; + var expectedBias2 = -learningRate + expectedBias1; + test_util_1.expectArraysClose(x, [expectedX2]); + test_util_1.expectArraysClose(bias, [expectedBias2]); + test_util_1.expectArraysClose(strayVariable, [-1]); + expect(cost).toBe(null); + }); + it('varList empty array of variables throws error', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var x = tf.scalar(4).variable(); + var bias = tf.scalar(1).variable(); + tf.scalar(-1).variable(); + var varList = []; + var f = function () { return x.square().addStrict(bias); }; + expect(function () { return optimizer.minimize(f, true, varList); }) + .toThrowError(); + }); + it('varList subset of variables update', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var x = tf.scalar(4).variable(); + var bias = tf.scalar(1).variable(); + var strayVariable = tf.scalar(-1).variable(); + var varList = [x]; + var f = function () { return x.square().addStrict(bias); }; + var cost = optimizer.minimize(f, true, varList); + var expectedValue1 = -2 * 4 * learningRate + 4; + test_util_1.expectArraysClose(x, [expectedValue1]); + test_util_1.expectArraysClose(bias, [1]); + test_util_1.expectArraysClose(cost, [Math.pow(4, 2) + 1]); + test_util_1.expectArraysClose(strayVariable, [-1]); + cost = optimizer.minimize(f, false, varList); + var expectedValue2 = -2 * expectedValue1 * learningRate + expectedValue1; + test_util_1.expectArraysClose(x, [expectedValue2]); + test_util_1.expectArraysClose(bias, [1]); + expect(cost).toBe(null); + test_util_1.expectArraysClose(strayVariable, [-1]); + }); + it('only bias trainable', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var trainable = false; + var x = tf.scalar(4).variable(trainable); + var bias = tf.scalar(1).variable(); + var strayVariable = tf.scalar(-1).variable(); + var f = function () { return x.square().addStrict(bias); }; + var cost = optimizer.minimize(f, true); + test_util_1.expectArraysClose(x, [4]); + var expectedBias1 = -1 * learningRate + 1; + test_util_1.expectArraysClose(bias, [expectedBias1]); + test_util_1.expectArraysClose(cost, [Math.pow(4, 2) + 1]); + test_util_1.expectArraysClose(strayVariable, [-1]); + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [4]); + var expectedBias2 = -learningRate + expectedBias1; + test_util_1.expectArraysClose(bias, [expectedBias2]); + expect(cost).toBe(null); + test_util_1.expectArraysClose(strayVariable, [-1]); + }); + it('only bias trainable, only x in varList throws error', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var trainable = false; + var x = tf.scalar(4).variable(trainable); + var bias = tf.scalar(1).variable(); + tf.scalar(-1).variable(); + var varList = [x]; + var f = function () { return x.square().addStrict(bias); }; + expect(function () { return optimizer.minimize(f, true, varList); }) + .toThrowError(); + }); + it('throws error when f returns a non-scalar', function () { + var learningRate = .1; + var optimizer = new sgd_optimizer_1.SGDOptimizer(learningRate); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square(); }; + expect(function () { return optimizer.minimize(f); }).toThrowError(); + }); +}); +//# sourceMappingURL=optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js.map new file mode 100644 index 0000000..f623e26 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/optimizer_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.d.ts new file mode 100644 index 0000000..634983b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.d.ts @@ -0,0 +1 @@ +export declare function getOptimizerDefaultEpsilonValue(): 1e-8 | 0.0001; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js new file mode 100644 index 0000000..013dc44 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js @@ -0,0 +1,13 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var DEFAULT_FLOAT32_EPSILON = 1e-8; +var DEFAULT_FLOAT16_EPSILON = 1e-4; +function getOptimizerDefaultEpsilonValue() { + if (environment_1.ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + return DEFAULT_FLOAT32_EPSILON; + } + return DEFAULT_FLOAT16_EPSILON; +} +exports.getOptimizerDefaultEpsilonValue = getOptimizerDefaultEpsilonValue; +//# sourceMappingURL=optimizer_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js.map new file mode 100644 index 0000000..00b86fe --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/optimizer_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizer_utils.js","sourceRoot":"","sources":["../../src/optimizers/optimizer_utils.ts"],"names":[],"mappings":";;AAgBA,8CAAmC;AAEnC,IAAM,uBAAuB,GAAG,IAAI,CAAC;AACrC,IAAM,uBAAuB,GAAG,IAAI,CAAC;AAErC;IACE,IAAI,iBAAG,CAAC,GAAG,CAAC,8BAA8B,CAAC,EAAE;QAC3C,OAAO,uBAAuB,CAAC;KAChC;IAED,OAAO,uBAAuB,CAAC;AACjC,CAAC;AAND,0EAMC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.d.ts new file mode 100644 index 0000000..6dbcfc4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.d.ts @@ -0,0 +1,24 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { NamedVariableMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class RMSPropOptimizer extends Optimizer { + protected learningRate: number; + protected decay: number; + protected momentum: number; + protected epsilon: number; + static className: string; + private c; + private epsilonScalar; + private decayScalar; + private momentumScalar; + private oneMinusDecay; + private centered; + private accumulatedMeanSquares; + private accumulatedMeanGrads; + private accumulatedMoments; + constructor(learningRate: number, decay?: number, momentum?: number, epsilon?: number, centered?: boolean); + applyGradients(variableGradients: NamedVariableMap): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js new file mode 100644 index 0000000..393cbdf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js @@ -0,0 +1,144 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var optimizer_utils = require("./optimizer_utils"); +var RMSPropOptimizer = (function (_super) { + __extends(RMSPropOptimizer, _super); + function RMSPropOptimizer(learningRate, decay, momentum, epsilon, centered) { + if (decay === void 0) { decay = 0.9; } + if (momentum === void 0) { momentum = 0.0; } + if (epsilon === void 0) { epsilon = null; } + if (centered === void 0) { centered = false; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.decay = decay; + _this.momentum = momentum; + _this.epsilon = epsilon; + _this.accumulatedMeanSquares = {}; + _this.accumulatedMeanGrads = {}; + _this.accumulatedMoments = {}; + _this.c = globals_1.keep(ops_1.scalar(learningRate)); + _this.decayScalar = globals_1.keep(ops_1.scalar(decay)); + _this.momentumScalar = globals_1.keep(ops_1.scalar(momentum)); + _this.oneMinusDecay = globals_1.keep(ops_1.scalar(1 - decay)); + _this.centered = centered; + if (epsilon === null) { + epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue(); + } + _this.epsilonScalar = globals_1.keep(ops_1.scalar(epsilon)); + return _this; + } + RMSPropOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = environment_1.ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedMeanSquares[variableName] == null) { + var trainable_1 = false; + globals_1.tidy(function () { + _this.accumulatedMeanSquares[variableName] = + ops_1.zerosLike(value).variable(trainable_1); + }); + } + if (this_1.accumulatedMeanGrads[variableName] == null && this_1.centered) { + var trainable_2 = false; + globals_1.tidy(function () { + _this.accumulatedMeanGrads[variableName] = + ops_1.zerosLike(value).variable(trainable_2); + }); + } + if (this_1.accumulatedMoments[variableName] == null) { + var trainable_3 = false; + globals_1.tidy(function () { + _this.accumulatedMoments[variableName] = + ops_1.zerosLike(value).variable(trainable_3); + }); + } + var accumulatedMeanSquare = this_1.accumulatedMeanSquares[variableName]; + var accumulatedMeanGrad = this_1.accumulatedMeanGrads[variableName]; + var accumulatedMoments = this_1.accumulatedMoments[variableName]; + var gradient = variableGradients[variableName]; + globals_1.tidy(function () { + var newAccumulatedMeanSquare = _this.decayScalar.mul(accumulatedMeanSquare) + .add(_this.oneMinusDecay.mul(gradient.square())); + if (_this.centered) { + var newAccumulatedMeanGrad = _this.decayScalar.mul(accumulatedMeanGrad) + .add(_this.oneMinusDecay.mul(gradient)); + var newAccumulatedMoments = _this.momentumScalar.mul(accumulatedMoments) + .add(_this.c.mul(gradient).div(newAccumulatedMeanSquare + .sub(newAccumulatedMeanGrad.square().add(_this.epsilonScalar)) + .sqrt())); + _this.accumulatedMeanSquares[variableName].assign(newAccumulatedMeanSquare); + _this.accumulatedMeanGrads[variableName].assign(newAccumulatedMeanGrad); + _this.accumulatedMoments[variableName].assign(newAccumulatedMoments); + var newValue = value.sub(newAccumulatedMoments); + value.assign(newValue); + } + else { + var newAccumulatedMeanSquare_1 = _this.decayScalar.mul(accumulatedMeanSquare) + .add(_this.oneMinusDecay.mul(gradient.square())); + var newAccumulatedMoments = _this.momentumScalar.mul(accumulatedMoments) + .add(_this.c.mul(gradient).div(newAccumulatedMeanSquare_1.add(_this.epsilonScalar).sqrt())); + _this.accumulatedMeanSquares[variableName].assign(newAccumulatedMeanSquare_1); + _this.accumulatedMoments[variableName].assign(newAccumulatedMoments); + var newValue = value.sub(newAccumulatedMoments); + value.assign(newValue); + } + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + RMSPropOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsilonScalar.dispose(); + this.decayScalar.dispose(); + this.momentumScalar.dispose(); + this.oneMinusDecay.dispose(); + if (this.accumulatedMeanSquares != null) { + Object.keys(this.accumulatedMeanSquares) + .forEach(function (name) { return _this.accumulatedMeanSquares[name].dispose(); }); + } + if (this.accumulatedMeanGrads != null && this.centered) { + Object.keys(this.accumulatedMeanGrads) + .forEach(function (name) { return _this.accumulatedMeanGrads[name].dispose(); }); + } + if (this.accumulatedMoments != null) { + Object.keys(this.accumulatedMoments) + .forEach(function (name) { return _this.accumulatedMoments[name].dispose(); }); + } + }; + RMSPropOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + decay: this.decay, + momentum: this.momentum, + epsilon: this.epsilon, + centered: this.centered + }; + }; + RMSPropOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.decay, config.momentum, config.epsilon, config.centered); + }; + RMSPropOptimizer.className = 'RMSPropOptimizer'; + return RMSPropOptimizer; +}(optimizer_1.Optimizer)); +exports.RMSPropOptimizer = RMSPropOptimizer; +serialization_1.SerializationMap.register(RMSPropOptimizer); +//# sourceMappingURL=rmsprop_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js.map new file mode 100644 index 0000000..7284b8c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"rmsprop_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/rmsprop_optimizer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js new file mode 100644 index 0000000..eef2b44 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js @@ -0,0 +1,56 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('RMSPropOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = 0.1; + var moment = 0.1; + var rho = 0.95; + var optimizer = tf.train.rmsprop(learningRate, rho, moment); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 3); + test_util_1.expectArraysClose(x, [0.55279, 1.55279]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.28745, 1.222943], 1e-2); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('gradient with centered momentum', function () { + var learningRate = 0.1; + var moment = 0.1; + var rho = 0.95; + var eps = 1e-8; + var optimizer = tf.train.rmsprop(learningRate, rho, moment, eps, true); + var x = tf.tensor1d([1, 2]).variable(); + var f = function () { return x.square().sum(); }; + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(f, true); + expect(tf.memory().numTensors).toBe(numTensors + 4); + test_util_1.expectArraysClose(x, [0.54117, 1.541169]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(f, false); + test_util_1.expectArraysClose(x, [0.267785, 1.2035924], 1e-2); + expect(tf.memory().numTensors).toBe(numTensors); + expect(cost).toBe(null); + x.dispose(); + optimizer.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var originalOpt = tf.train.rmsprop(0.1, 0.5, 0.1, 1e-7, true); + var reserialized = tf.RMSPropOptimizer.fromConfig(tf.RMSPropOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=rmsprop_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js.map new file mode 100644 index 0000000..0f92610 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/rmsprop_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"rmsprop_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/rmsprop_optimizer_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.d.ts new file mode 100644 index 0000000..169eb89 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.d.ts @@ -0,0 +1,15 @@ +import { ConfigDict, Serializable, SerializableConstructor } from '../serialization'; +import { Scalar } from '../tensor'; +import { NamedTensorMap } from '../tensor_types'; +import { Optimizer } from './optimizer'; +export declare class SGDOptimizer extends Optimizer { + protected learningRate: number; + static className: string; + protected c: Scalar; + constructor(learningRate: number); + applyGradients(variableGradients: NamedTensorMap): void; + setLearningRate(learningRate: number): void; + dispose(): void; + getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js new file mode 100644 index 0000000..6f82fd5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js @@ -0,0 +1,59 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("../environment"); +var globals_1 = require("../globals"); +var ops_1 = require("../ops/ops"); +var serialization_1 = require("../serialization"); +var optimizer_1 = require("./optimizer"); +var SGDOptimizer = (function (_super) { + __extends(SGDOptimizer, _super); + function SGDOptimizer(learningRate) { + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.setLearningRate(learningRate); + return _this; + } + SGDOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var varNames = Object.keys(variableGradients); + varNames.forEach(function (varName) { + var gradient = variableGradients[varName]; + var value = environment_1.ENV.engine.registeredVariables[varName]; + globals_1.tidy(function () { + var newValue = _this.c.mul(gradient).add(value); + value.assign(newValue); + }); + }); + }; + SGDOptimizer.prototype.setLearningRate = function (learningRate) { + this.learningRate = learningRate; + if (this.c != null) { + this.c.dispose(); + } + this.c = globals_1.keep(ops_1.scalar(-learningRate)); + }; + SGDOptimizer.prototype.dispose = function () { + this.c.dispose(); + }; + SGDOptimizer.prototype.getConfig = function () { + return { learningRate: this.learningRate }; + }; + SGDOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate); + }; + SGDOptimizer.className = 'SGDOptimizer'; + return SGDOptimizer; +}(optimizer_1.Optimizer)); +exports.SGDOptimizer = SGDOptimizer; +serialization_1.SerializationMap.register(SGDOptimizer); +//# sourceMappingURL=sgd_optimizer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js.map new file mode 100644 index 0000000..7701fa4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"sgd_optimizer.js","sourceRoot":"","sources":["../../src/optimizers/sgd_optimizer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAiBA,8CAAmC;AACnC,sCAAsC;AACtC,kCAAkC;AAClC,kDAAqG;AAGrG,yCAAsC;AAGtC;IAAkC,gCAAS;IAIzC,sBAAsB,YAAoB;QAA1C,YACE,iBAAO,SAER;QAHqB,kBAAY,GAAZ,YAAY,CAAQ;QAExC,KAAI,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;;IACrC,CAAC;IAED,qCAAc,GAAd,UAAe,iBAAiC;QAAhD,iBAWC;QAVC,IAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAChD,QAAQ,CAAC,OAAO,CAAC,UAAA,OAAO;YACtB,IAAM,QAAQ,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;YAC5C,IAAM,KAAK,GAAG,iBAAG,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;YAEtD,cAAI,CAAC;gBACH,IAAM,QAAQ,GAAG,KAAI,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACjD,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAKD,sCAAe,GAAf,UAAgB,YAAoB;QAClC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,IAAI,CAAC,CAAC,IAAI,IAAI,EAAE;YAClB,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,CAAC,GAAG,cAAI,CAAC,YAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;IACvC,CAAC;IAED,8BAAO,GAAP;QACE,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,gCAAS,GAAT;QACE,OAAO,EAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAC,CAAC;IAC3C,CAAC;IACM,uBAAU,GAAjB,UACI,GAA+B,EAAE,MAAkB;QACrD,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;IA1CM,sBAAS,GAAG,cAAc,CAAC;IA2CpC,mBAAC;CAAA,AA5CD,CAAkC,qBAAS,GA4C1C;AA5CY,oCAAY;AA6CzB,gCAAgB,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js new file mode 100644 index 0000000..b7fcb69 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js @@ -0,0 +1,35 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("../index"); +var jasmine_util_1 = require("../jasmine_util"); +var test_util_1 = require("../test_util"); +jasmine_util_1.describeWithFlags('SGDOptimizer', test_util_1.ALL_ENVS, function () { + it('basic', function () { + var learningRate = .1; + var optimizer = tf.train.sgd(learningRate); + var x = tf.scalar(4).variable(); + var numTensors = tf.memory().numTensors; + var cost = optimizer.minimize(function () { return x.square(); }, true); + expect(tf.memory().numTensors).toBe(numTensors + 1); + var expectedValue1 = -2 * 4 * learningRate + 4; + test_util_1.expectArraysClose(x, [expectedValue1]); + test_util_1.expectArraysClose(cost, [Math.pow(4, 2)]); + cost.dispose(); + numTensors = tf.memory().numTensors; + cost = optimizer.minimize(function () { return x.square(); }, false); + expect(tf.memory().numTensors).toBe(numTensors); + var expectedValue2 = -2 * expectedValue1 * learningRate + expectedValue1; + test_util_1.expectArraysClose(x, [expectedValue2]); + expect(cost).toBe(null); + optimizer.dispose(); + x.dispose(); + expect(tf.memory().numTensors).toBe(1); + }); + it('serialization round-trip', function () { + var learningRate = .1; + var originalOpt = tf.train.sgd(learningRate); + var reserialized = tf.SGDOptimizer.fromConfig(tf.SGDOptimizer, originalOpt.getConfig()); + expect(reserialized.getConfig()).toEqual(originalOpt.getConfig()); + }); +}); +//# sourceMappingURL=sgd_optimizer_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js.map new file mode 100644 index 0000000..0d768c1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/optimizers/sgd_optimizer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"sgd_optimizer_test.js","sourceRoot":"","sources":["../../src/optimizers/sgd_optimizer_test.ts"],"names":[],"mappings":";;AAiBA,6BAA+B;AAC/B,gDAAkD;AAClD,0CAAyD;AAEzD,gCAAiB,CAAC,cAAc,EAAE,oBAAQ,EAAE;IAC1C,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAE7C,IAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElC,IAAI,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAExC,IAAI,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,EAAV,CAAU,EAAmB,IAAI,CAAC,CAAC;QAGvE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QAGpD,IAAM,cAAc,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,YAAY,GAAG,CAAC,CAAC;QACjD,6BAAiB,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;QACvC,6BAAiB,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1C,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,UAAU,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QAEpC,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,cAAM,OAAA,CAAC,CAAC,MAAM,EAAE,EAAV,CAAU,EAAmB,KAAK,CAAC,CAAC;QAEpE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhD,IAAM,cAAc,GAAG,CAAC,CAAC,GAAG,cAAc,GAAG,YAAY,GAAG,cAAc,CAAC;QAC3E,6BAAiB,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,SAAS,CAAC,OAAO,EAAE,CAAC;QACpB,CAAC,CAAC,OAAO,EAAE,CAAC;QAEZ,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAM,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC/C,IAAM,YAAY,GACd,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC,YAAY,EAAE,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;QACzE,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler.d.ts b/node_modules/@tensorflow/tfjs-core/dist/profiler.d.ts new file mode 100644 index 0000000..0634986 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler.d.ts @@ -0,0 +1,12 @@ +import { BackendTimer } from './kernels/backend'; +import { Tensor } from './tensor'; +import { TypedArray } from './types'; +export declare class Profiler { + private backendTimer; + private logger?; + constructor(backendTimer: BackendTimer, logger?: Logger); + profileKernel(name: string, f: () => T | Tensor[]): T; +} +export declare class Logger { + logKernelProfile(name: string, result: Tensor, vals: TypedArray, timeMs: number): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler.js b/node_modules/@tensorflow/tfjs-core/dist/profiler.js new file mode 100644 index 0000000..88e6322 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler.js @@ -0,0 +1,46 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("./util"); +var Profiler = (function () { + function Profiler(backendTimer, logger) { + this.backendTimer = backendTimer; + this.logger = logger; + if (logger == null) { + this.logger = new Logger(); + } + } + Profiler.prototype.profileKernel = function (name, f) { + var _this = this; + var result; + var holdResultWrapperFn = function () { + result = f(); + }; + var timer = this.backendTimer.time(holdResultWrapperFn); + var results = Array.isArray(result) ? result : [result]; + results.forEach(function (r) { + var vals = r.dataSync(); + util.checkComputationForNaN(vals, r.dtype, name); + timer.then(function (timing) { + _this.logger.logKernelProfile(name, r, vals, timing.kernelMs); + }); + }); + return result; + }; + return Profiler; +}()); +exports.Profiler = Profiler; +var Logger = (function () { + function Logger() { + } + Logger.prototype.logKernelProfile = function (name, result, vals, timeMs) { + var time = util.rightPad(timeMs + "ms", 9); + var paddedName = util.rightPad(name, 25); + var rank = result.rank; + var size = result.size; + var shape = util.rightPad(result.shape.toString(), 14); + console.log("%c" + paddedName + "\t%c" + time + "\t%c" + rank + "D " + shape + "\t%c" + size, 'font-weight:bold', 'color:red', 'color:blue', 'color: orange'); + }; + return Logger; +}()); +exports.Logger = Logger; +//# sourceMappingURL=profiler.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler.js.map b/node_modules/@tensorflow/tfjs-core/dist/profiler.js.map new file mode 100644 index 0000000..cc23cd2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler.js.map @@ -0,0 +1 @@ +{"version":3,"file":"profiler.js","sourceRoot":"","sources":["../src/profiler.ts"],"names":[],"mappings":";;AAoBA,6BAA+B;AAE/B;IACE,kBAAoB,YAA0B,EAAU,MAAe;QAAnD,iBAAY,GAAZ,YAAY,CAAc;QAAU,WAAM,GAAN,MAAM,CAAS;QACrE,IAAI,MAAM,IAAI,IAAI,EAAE;YAClB,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,gCAAa,GAAb,UAAyC,IAAY,EAAE,CAAqB;QAA5E,iBAoBC;QAlBC,IAAI,MAAkB,CAAC;QACvB,IAAM,mBAAmB,GAAG;YAC1B,MAAM,GAAG,CAAC,EAAE,CAAC;QACf,CAAC,CAAC;QACF,IAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAE1D,IAAM,OAAO,GACT,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAa,CAAC;QAC1D,OAAO,CAAC,OAAO,CAAC,UAAA,CAAC;YACf,IAAM,IAAI,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAEjD,KAAK,CAAC,IAAI,CAAC,UAAA,MAAM;gBACf,KAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC/D,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,MAAW,CAAC;IACrB,CAAC;IACH,eAAC;AAAD,CAAC,AA5BD,IA4BC;AA5BY,4BAAQ;AA8BrB;IAAA;IAYA,CAAC;IAXC,iCAAgB,GAAhB,UACI,IAAY,EAAE,MAAc,EAAE,IAAgB,EAAE,MAAc;QAChE,IAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAI,MAAM,OAAI,EAAE,CAAC,CAAC,CAAC;QAC7C,IAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC3C,IAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,IAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,IAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CACP,OAAK,UAAU,YAAO,IAAI,YAAO,IAAI,UAAK,KAAK,YAAO,IAAM,EAC5D,kBAAkB,EAAE,WAAW,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;IACtE,CAAC;IACH,aAAC;AAAD,CAAC,AAZD,IAYC;AAZY,wBAAM"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js new file mode 100644 index 0000000..0e776c0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js @@ -0,0 +1,147 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var profiler_1 = require("./profiler"); +var TestBackendTimer = (function () { + function TestBackendTimer(delayMs, queryTimeMs) { + this.delayMs = delayMs; + this.queryTimeMs = queryTimeMs; + this.counter = 1; + } + TestBackendTimer.prototype.time = function (query) { + return __awaiter(this, void 0, void 0, function () { + var kernelMs; + var _this = this; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + query(); + return [4, new Promise(function (resolve) { return setTimeout(resolve(_this.queryTimeMs * _this.counter++), _this.delayMs); })]; + case 1: + kernelMs = _a.sent(); + return [2, { kernelMs: kernelMs }]; + } + }); + }); + }; + return TestBackendTimer; +}()); +var TestLogger = (function (_super) { + __extends(TestLogger, _super); + function TestLogger() { + return _super !== null && _super.apply(this, arguments) || this; + } + TestLogger.prototype.logKernelProfile = function (name, result, vals, timeMs) { }; + return TestLogger; +}(profiler_1.Logger)); +describe('profiler.Profiler', function () { + it('profiles simple function', function (doneFn) { + var delayMs = 5; + var queryTimeMs = 10; + var timer = new TestBackendTimer(delayMs, queryTimeMs); + var logger = new TestLogger(); + var profiler = new profiler_1.Profiler(timer, logger); + spyOn(timer, 'time').and.callThrough(); + spyOn(logger, 'logKernelProfile').and.callThrough(); + var timeSpy = timer.time; + var logKernelProfileSpy = logger.logKernelProfile; + var kernelCalled = false; + var result = 1; + var resultScalar = tf.scalar(result); + profiler.profileKernel('MatMul', function () { + kernelCalled = true; + return resultScalar; + }); + setTimeout(function () { + expect(timeSpy.calls.count()).toBe(1); + expect(logKernelProfileSpy.calls.count()).toBe(1); + expect(logKernelProfileSpy.calls.first().args).toEqual([ + 'MatMul', resultScalar, new Float32Array([result]), queryTimeMs + ]); + expect(kernelCalled).toBe(true); + doneFn(); + }, delayMs * 2); + }); + it('profiles nested kernel', function (doneFn) { + var delayMs = 5; + var queryTimeMs = 10; + var timer = new TestBackendTimer(delayMs, queryTimeMs); + var logger = new TestLogger(); + var profiler = new profiler_1.Profiler(timer, logger); + spyOn(timer, 'time').and.callThrough(); + spyOn(logger, 'logKernelProfile').and.callThrough(); + var timeSpy = timer.time; + var logKernelProfileSpy = logger.logKernelProfile; + var matmulKernelCalled = false; + var maxKernelCalled = false; + var result = 1; + var resultScalar = tf.scalar(result); + profiler.profileKernel('MatMul', function () { + var result = profiler.profileKernel('Max', function () { + maxKernelCalled = true; + return resultScalar; + }); + matmulKernelCalled = true; + return result; + }); + setTimeout(function () { + expect(timeSpy.calls.count()).toBe(2); + expect(logKernelProfileSpy.calls.count()).toBe(2); + expect(logKernelProfileSpy.calls.first().args).toEqual([ + 'Max', resultScalar, new Float32Array([result]), queryTimeMs + ]); + expect(logKernelProfileSpy.calls.argsFor(1)).toEqual([ + 'MatMul', resultScalar, new Float32Array([result]), queryTimeMs * 2 + ]); + expect(matmulKernelCalled).toBe(true); + expect(maxKernelCalled).toBe(true); + doneFn(); + }, delayMs * 2); + }); +}); +//# sourceMappingURL=profiler_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js.map new file mode 100644 index 0000000..66c0153 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/profiler_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"profiler_test.js","sourceRoot":"","sources":["../src/profiler_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/serialization.d.ts b/node_modules/@tensorflow/tfjs-core/dist/serialization.d.ts new file mode 100644 index 0000000..27c6d8a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/serialization.d.ts @@ -0,0 +1,26 @@ +export declare type ConfigDictValue = boolean | number | string | null | ConfigDictArray | ConfigDict; +export interface ConfigDict { + [key: string]: ConfigDictValue; +} +export interface ConfigDictArray extends Array { +} +export declare type SerializableConstructor = { + new (...args: any[]): T; + className: string; + fromConfig: FromConfigMethod; +}; +export declare type FromConfigMethod = (cls: SerializableConstructor, config: ConfigDict) => T; +export declare abstract class Serializable { + getClassName(): string; + abstract getConfig(): ConfigDict; + static fromConfig(cls: SerializableConstructor, config: ConfigDict): T; +} +export declare class SerializationMap { + private static instance; + classNameMap: { + [className: string]: [SerializableConstructor, FromConfigMethod]; + }; + private constructor(); + static getMap(): SerializationMap; + static register(cls: SerializableConstructor): void; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/serialization.js b/node_modules/@tensorflow/tfjs-core/dist/serialization.js new file mode 100644 index 0000000..956b836 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/serialization.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Serializable = (function () { + function Serializable() { + } + Serializable.prototype.getClassName = function () { + return this.constructor + .className; + }; + Serializable.fromConfig = function (cls, config) { + return new cls(config); + }; + return Serializable; +}()); +exports.Serializable = Serializable; +var SerializationMap = (function () { + function SerializationMap() { + this.classNameMap = {}; + } + SerializationMap.getMap = function () { + if (SerializationMap.instance == null) { + SerializationMap.instance = new SerializationMap(); + } + return SerializationMap.instance; + }; + SerializationMap.register = function (cls) { + SerializationMap.getMap().classNameMap[cls.className] = + [cls, cls.fromConfig]; + }; + return SerializationMap; +}()); +exports.SerializationMap = SerializationMap; +//# sourceMappingURL=serialization.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/serialization.js.map b/node_modules/@tensorflow/tfjs-core/dist/serialization.js.map new file mode 100644 index 0000000..3ea6247 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/serialization.js.map @@ -0,0 +1 @@ +{"version":3,"file":"serialization.js","sourceRoot":"","sources":["../src/serialization.ts"],"names":[],"mappings":";;AA4DA;IAAA;IAkCA,CAAC;IAtBC,mCAAY,GAAZ;QACE,OAAQ,IAAI,CAAC,WAAqD;aAC7D,SAAS,CAAC;IACjB,CAAC;IAeM,uBAAU,GAAjB,UACI,GAA+B,EAAE,MAAkB;QACrD,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IACH,mBAAC;AAAD,CAAC,AAlCD,IAkCC;AAlCqB,oCAAY;AA2ClC;IASE;QACE,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAKM,uBAAM,GAAb;QACE,IAAI,gBAAgB,CAAC,QAAQ,IAAI,IAAI,EAAE;YACrC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,gBAAgB,EAAE,CAAC;SACpD;QACD,OAAO,gBAAgB,CAAC,QAAQ,CAAC;IACnC,CAAC;IAKM,yBAAQ,GAAf,UAAwC,GAA+B;QACrE,gBAAgB,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC;YACjD,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;IAC5B,CAAC;IACH,uBAAC;AAAD,CAAC,AA9BD,IA8BC;AA9BY,4CAAgB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tape.d.ts new file mode 100644 index 0000000..65b11c1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape.d.ts @@ -0,0 +1,16 @@ +import { Tensor } from './tensor'; +import { NamedTensorMap } from './tensor_types'; +export interface TapeNode { + id: number; + name: string; + output: Tensor; + inputs: NamedTensorMap; + gradient?: (dy: Tensor | NamedTensorMap) => NamedGradientMap; +} +export declare type NamedGradientMap = { + [inputName: string]: () => Tensor; +}; +export declare function getFilteredNodesXToY(tape: TapeNode[], xs: Tensor[], y: Tensor): TapeNode[]; +export declare function backpropagateGradients(tensorAccumulatedGradientMap: { + [tensorId: number]: Tensor; +}, filteredTape: TapeNode[]): void; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape.js b/node_modules/@tensorflow/tfjs-core/dist/tape.js new file mode 100644 index 0000000..04619fb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape.js @@ -0,0 +1,100 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("./util"); +function getFilteredNodesXToY(tape, xs, y) { + var tensorsFromX = {}; + var nodesFromX = {}; + for (var i = 0; i < xs.length; i++) { + tensorsFromX[xs[i].id] = true; + } + for (var i = 0; i < tape.length; i++) { + var node = tape[i]; + var nodeInputs = node.inputs; + for (var inputName in nodeInputs) { + var input = nodeInputs[inputName]; + var anyInputFromX = false; + for (var j = 0; j < xs.length; j++) { + if (tensorsFromX[input.id]) { + tensorsFromX[node.output.id] = true; + anyInputFromX = true; + nodesFromX[node.id] = true; + break; + } + } + if (anyInputFromX) { + break; + } + } + } + var tensorsLeadToY = {}; + tensorsLeadToY[y.id] = true; + var nodesToY = {}; + for (var i = tape.length - 1; i >= 0; i--) { + var node = tape[i]; + var nodeInputs = node.inputs; + var outputs = []; + outputs.push(node.output); + for (var j = 0; j < outputs.length; j++) { + if (tensorsLeadToY[outputs[j].id]) { + for (var inputName in nodeInputs) { + tensorsLeadToY[nodeInputs[inputName].id] = true; + nodesToY[node.id] = true; + } + break; + } + } + } + var filteredTape = []; + for (var i = 0; i < tape.length; i++) { + var node = tape[i]; + if (nodesFromX[node.id] && nodesToY[node.id]) { + var prunedInputs = {}; + for (var inputName in node.inputs) { + var nodeInput = node.inputs[inputName]; + if (tensorsFromX[nodeInput.id]) { + prunedInputs[inputName] = nodeInput; + } + } + var prunedNode = Object.assign({}, node); + prunedNode.inputs = prunedInputs; + prunedNode.output = node.output; + filteredTape.push(prunedNode); + } + } + return filteredTape; +} +exports.getFilteredNodesXToY = getFilteredNodesXToY; +function backpropagateGradients(tensorAccumulatedGradientMap, filteredTape) { + for (var i = filteredTape.length - 1; i >= 0; i--) { + var node = filteredTape[i]; + var dy = tensorAccumulatedGradientMap[node.output.id]; + if (node.gradient == null) { + throw new Error("Cannot compute gradient: gradient function not found " + + ("for " + node.name + ".")); + } + var inputGradients = node.gradient(dy); + for (var inputName in node.inputs) { + if (!(inputName in inputGradients)) { + throw new Error("Cannot backprop through input " + inputName + ". " + + ("Available gradients found: " + Object.keys(inputGradients) + ".")); + } + var dx = inputGradients[inputName](); + var x = node.inputs[inputName]; + if (!util.arraysEqual(dx.shape, x.shape)) { + throw new Error("Error in gradient for op " + node.name + ". The gradient of input " + + ("'" + inputName + "' has shape '" + dx.shape + "', which does not match ") + + ("the shape of the input '" + x.shape + "'")); + } + if (tensorAccumulatedGradientMap[x.id] == null) { + tensorAccumulatedGradientMap[x.id] = dx; + } + else { + var curGradient = tensorAccumulatedGradientMap[x.id]; + tensorAccumulatedGradientMap[x.id] = curGradient.add(dx); + curGradient.dispose(); + } + } + } +} +exports.backpropagateGradients = backpropagateGradients; +//# sourceMappingURL=tape.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape.js.map b/node_modules/@tensorflow/tfjs-core/dist/tape.js.map new file mode 100644 index 0000000..41b8978 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tape.js","sourceRoot":"","sources":["../src/tape.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tape_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape_test.js b/node_modules/@tensorflow/tfjs-core/dist/tape_test.js new file mode 100644 index 0000000..ea89200 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape_test.js @@ -0,0 +1,235 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var tape_util = require("./tape"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('getFilteredNodesXToY', test_util_1.ALL_ENVS, function () { + it('getFilteredNodesXToY no paths from x to y', function () { + var x = tf.scalar(1); + var intermediate1 = tf.scalar(0); + var intermediate2 = tf.scalar(0); + var y = tf.scalar(2); + var tape = [ + { + id: 0, + name: 'node0', + inputs: { x: x }, + output: intermediate1, + gradient: null + }, + { + id: 1, + name: 'node1', + inputs: { intermediate2: intermediate2 }, + output: y, + gradient: null + } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x], y); + expect(filteredTapeNodes.length).toBe(0); + expect(filteredTapeNodes).toEqual([]); + }); + it('getFilteredNodesXToY one operation x => y', function () { + var x = tf.scalar(1); + var y = tf.scalar(2); + var tape = [{ id: 0, name: 'node0', inputs: { x: x }, output: y, gradient: null }]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x], y); + expect(filteredTapeNodes.length).toBe(1); + expect(filteredTapeNodes).toEqual(tape); + }); + it('getFilteredNodesXToY 1 operation [x0, x1] => y, all input paths', function () { + var x0 = tf.scalar(0); + var x1 = tf.scalar(1); + var y = tf.scalar(2); + var tape = [{ id: 0, name: 'node0', inputs: { x0: x0, x1: x1 }, output: y, gradient: null }]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x0, x1], y); + expect(filteredTapeNodes.length).toBe(1); + expect(filteredTapeNodes).toEqual(tape); + }); + it('getFilteredNodesXToY one operation [x0, x1] => y, one input paths', function () { + var x0 = tf.scalar(0); + var x1 = tf.scalar(1); + var y = tf.scalar(2); + var tape = [ + { id: 0, name: 'node0', inputs: { x0: x0, x1: x1 }, output: y, gradient: null } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x0], y); + expect(filteredTapeNodes.length).toBe(1); + expect(filteredTapeNodes[0]) + .toEqual({ id: 0, name: 'node0', inputs: { x0: x0 }, output: y, gradient: null }); + }); + it('getFilteredNodesXToY two operations x => intermediate => y', function () { + var x = tf.scalar(1); + var intermediate = tf.scalar(0); + var y = tf.scalar(2); + var tape = [ + { id: 0, name: 'node0', inputs: { x: x }, output: intermediate, gradient: null }, + { + id: 1, + name: 'node1', + inputs: { intermediate: intermediate }, + output: y, + gradient: null + } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x], y); + expect(filteredTapeNodes.length).toBe(2); + expect(filteredTapeNodes).toEqual(tape); + }); + it('getFilteredNodesXToY two operations [x0, x1], [x2] => ' + + 'intermediate => y', function () { + var x0 = tf.scalar(1); + var x1 = tf.scalar(2); + var x2 = tf.scalar(3); + var intermediate = tf.scalar(4); + var y = tf.scalar(2); + var tape = [ + { + id: 0, + name: 'node0', + inputs: { x0: x0, x1: x1 }, + output: intermediate, + gradient: null + }, + { + id: 1, + name: 'node1', + inputs: { x2: x2, intermediate: intermediate }, + output: y, + gradient: null + } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x0, x1, x2], y); + expect(filteredTapeNodes.length).toBe(2); + expect(filteredTapeNodes).toEqual(tape); + }); + it('getFilteredNodesXToY x => y and x => orphan', function () { + var x = tf.scalar(1); + var orphan = tf.scalar(0); + var y = tf.scalar(2); + var tape = [ + { id: 0, name: 'node0', inputs: { x: x }, output: orphan, gradient: null }, + { id: 1, name: 'node1', inputs: { x: x }, output: y, gradient: null } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x], y); + expect(filteredTapeNodes.length).toBe(1); + expect(filteredTapeNodes[0]).toEqual(tape[1]); + }); + it('getFilteredNodesXToY x => y and orphan => y', function () { + var x = tf.scalar(1); + var orphan = tf.scalar(0); + var y = tf.scalar(2); + var tape = [ + { id: 0, name: 'node0', inputs: { x: x, orphan: orphan }, output: y, gradient: null } + ]; + var filteredTapeNodes = tape_util.getFilteredNodesXToY(tape, [x], y); + expect(filteredTapeNodes.length).toBe(1); + expect(filteredTapeNodes[0]) + .toEqual({ id: 0, name: 'node0', inputs: { x: x }, output: y, gradient: null }); + }); +}); +jasmine_util_1.describeWithFlags('backpropagateGradients', test_util_1.ALL_ENVS, function () { + it('Throws if gradient is not defined', function () { + var x = tf.scalar(0); + var y = tf.scalar(1); + var dy = tf.scalar(1); + var accumulatedGradientsMap = {}; + accumulatedGradientsMap[y.id] = dy; + var tape = [{ id: 0, name: 'node0', inputs: { x: x }, output: y, gradient: null }]; + expect(function () { return tape_util.backpropagateGradients(accumulatedGradientsMap, tape); }) + .toThrowError(); + }); + it('basic backprop with 1 node', function () { + var x = tf.scalar(0); + var y = tf.scalar(1); + var dy = tf.scalar(1); + var accumulatedGradientsMap = {}; + accumulatedGradientsMap[y.id] = dy; + var tape = [{ + id: 0, + name: 'node0', + inputs: { x: x }, + output: y, + gradient: function (dy) { + return { x: function () { return dy.add(tf.scalar(1)); } }; + } + }]; + tape_util.backpropagateGradients(accumulatedGradientsMap, tape); + test_util_1.expectArraysClose(accumulatedGradientsMap[x.id], [2]); + }); + it('basic backprop with 2 nodes', function () { + var x = tf.scalar(0); + var intermediate = tf.scalar(1); + var y = tf.scalar(2); + var dy = tf.scalar(1); + var accumulatedGradientsMap = {}; + accumulatedGradientsMap[y.id] = dy; + var tape = [ + { + id: 0, + name: 'node0', + inputs: { x: x }, + output: intermediate, + gradient: function (dy) { + return { x: function () { return dy.add(tf.scalar(1)); } }; + } + }, + { + id: 1, + name: 'node1', + inputs: { intermediate: intermediate }, + output: y, + gradient: function (dy) { + return { intermediate: function () { return dy.add(tf.scalar(1)); } }; + } + } + ]; + tape_util.backpropagateGradients(accumulatedGradientsMap, tape); + test_util_1.expectArraysClose(accumulatedGradientsMap[x.id], [3]); + }); + it('basic backprop with a split node accumulates gradients', function () { + var x = tf.scalar(0); + var intermediate1 = tf.scalar(1); + var intermediate2 = tf.scalar(2); + var y = tf.scalar(3); + var dy = tf.scalar(1); + var accumulatedGradientsMap = {}; + accumulatedGradientsMap[y.id] = dy; + var tape = [ + { + id: 0, + name: 'node0', + inputs: { x: x }, + output: intermediate1, + gradient: function (dy) { + return { x: function () { return dy.add(tf.scalar(1)); } }; + } + }, + { + id: 1, + name: 'node1', + inputs: { x: x }, + output: intermediate2, + gradient: function (dy) { + return { x: function () { return dy.add(tf.scalar(1)); } }; + } + }, + { + id: 2, + name: 'node2', + inputs: { intermediate1: intermediate1, intermediate2: intermediate2 }, + output: y, + gradient: function (dy) { + return { + intermediate1: function () { return dy.add(tf.scalar(1)); }, + intermediate2: function () { return dy.add(tf.scalar(1)); } + }; + } + } + ]; + tape_util.backpropagateGradients(accumulatedGradientsMap, tape); + test_util_1.expectArraysClose(accumulatedGradientsMap[x.id], [dy.dataSync()[0] + 5]); + }); +}); +//# sourceMappingURL=tape_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tape_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/tape_test.js.map new file mode 100644 index 0000000..119553d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tape_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tape_test.js","sourceRoot":"","sources":["../src/tape_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor.d.ts new file mode 100644 index 0000000..3f10d89 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor.d.ts @@ -0,0 +1,316 @@ +import { DataType, Rank, ShapeMap, TypedArray } from './types'; +export interface TensorData { + dataId?: DataId; + values?: TypedArray; +} +export declare class TensorBuffer { + dtype: DataType; + size: number; + shape: ShapeMap[R]; + strides: number[]; + values: TypedArray; + constructor(shape: ShapeMap[R], dtype: DataType, values: TypedArray); + set(value: number, ...locs: number[]): void; + get(...locs: number[]): number; + locToIndex(locs: number[]): number; + indexToLoc(index: number): number[]; + readonly rank: number; + toTensor(): Tensor; +} +export interface TensorTracker { + registerTensor(t: Tensor): void; + disposeTensor(t: Tensor): void; + write(dataId: DataId, values: TypedArray): void; + read(dataId: DataId): Promise; + readSync(dataId: DataId): TypedArray; + registerVariable(v: Variable): void; +} +export interface OpHandler { + cast(x: T, dtype: DataType): T; + buffer(shape: ShapeMap[R], dtype: DataType, values?: TypedArray): TensorBuffer; + print(x: T, verbose: boolean): void; + reshape(x: Tensor, shape: ShapeMap[R2]): Tensor; + expandDims(x: Tensor, axis: number): Tensor; + cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean): T; + squeeze(x: Tensor, axis?: number[]): T; + clone(x: T): T; + tile(x: T, reps: number[]): T; + gather(x: T, indices: Tensor1D, axis: number): T; + matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean): Tensor2D; + dot(t1: Tensor, t2: Tensor): Tensor; + norm(x: Tensor, ord: number | 'euclidean' | 'fro', axis: number | number[], keepDims: boolean): Tensor; + slice>(x: T, begin: number | number[], size?: number | number[]): T; + reverse(x: T, axis?: number | number[]): T; + concat(tensors: T[], axis: number): T; + stack(tensors: T[], axis: number): Tensor; + unstack(value: T, axis: number): Tensor[]; + pad(x: T, paddings: Array<[number, number]>, constantValue: number): T; + batchNormalization(x: Tensor, mean: Tensor | Tensor1D, variance: Tensor | Tensor1D, varianceEpsilon: number, scale?: Tensor | Tensor1D, offset?: Tensor | Tensor1D): Tensor; + all(x: Tensor, axis: number | number[], keepDims: boolean): T; + any(x: Tensor, axis: number | number[], keepDims: boolean): T; + logSumExp(x: Tensor, axis: number | number[], keepDims: boolean): T; + sum(x: Tensor, axis: number | number[], keepDims: boolean): T; + mean(x: Tensor, axis: number | number[], keepDims: boolean): T; + min(x: Tensor, axis: number | number[], keepDims: boolean): T; + max(x: Tensor, axis: number | number[], keepDims: boolean): T; + argMin(x: Tensor, axis: number): T; + argMax(x: Tensor, axis: number): T; + add(a: Tensor, b: Tensor): T; + addStrict(a: T, b: T): T; + sub(a: Tensor, b: Tensor): T; + subStrict(a: T, b: T): T; + pow(base: T, exp: Tensor): T; + powStrict(base: T, exp: Tensor): T; + mul(a: Tensor, b: Tensor): T; + mulStrict(a: T, b: T): T; + div(a: Tensor, b: Tensor): T; + floorDiv(a: Tensor, b: Tensor): T; + divStrict(a: T, b: T): T; + mod(a: Tensor, b: Tensor): T; + modStrict(a: T, b: T): T; + minimum(a: Tensor, b: Tensor): T; + minimumStrict(a: T, b: T): T; + maximum(a: Tensor, b: Tensor): T; + maximumStrict(a: T, b: T): T; + squaredDifference(a: Tensor, b: Tensor): T; + squaredDifferenceStrict(a: T, b: T): T; + transpose(x: T, perm?: number[]): T; + logicalNot(x: T): T; + logicalAnd(a: Tensor, b: Tensor): T; + logicalOr(a: Tensor, b: Tensor): T; + logicalXor(a: Tensor, b: Tensor): T; + where(condition: Tensor, a: T, b: T): T; + notEqual(a: Tensor, b: Tensor): T; + notEqualStrict(a: T, b: T): T; + less(a: Tensor, b: Tensor): T; + lessStrict(a: T, b: T): T; + equal(a: Tensor, b: Tensor): T; + equalStrict(a: T, b: T): T; + lessEqual(a: Tensor, b: Tensor): T; + lessEqualStrict(a: T, b: T): T; + greater(a: Tensor, b: Tensor): T; + greaterStrict(a: T, b: T): T; + greaterEqual(a: Tensor, b: Tensor): T; + greaterEqualStrict(a: T, b: T): T; + neg(x: T): T; + ceil(x: T): T; + floor(x: T): T; + sign(x: T): T; + round(x: T): T; + exp(x: T): T; + expm1(x: T): T; + log(x: T): T; + log1p(x: T): T; + sqrt(x: T): T; + rsqrt(x: T): T; + square(x: T): T; + reciprocal(x: T): T; + abs(x: T): T; + clipByValue(x: T, clipValueMin: number, clipValueMax: number): T; + sigmoid(x: T): T; + logSigmoid(x: T): T; + softplus(x: T): T; + sin(x: T): T; + cos(x: T): T; + tan(x: T): T; + asin(x: T): T; + acos(x: T): T; + atan(x: T): T; + sinh(x: T): T; + cosh(x: T): T; + tanh(x: T): T; + asinh(x: T): T; + acosh(x: T): T; + atanh(x: T): T; + erf(x: T): T; + step(x: T, alpha: number): T; + relu(x: T): T; + elu(x: T): T; + selu(x: T): T; + leakyRelu(x: T, alpha: number): T; + prelu(x: T, alpha: T): T; + softmax(logits: T, dim: number): T; + image: { + resizeBilinear(images: T, size: [number, number], alignCorners: boolean): T; + resizeNearestNeighbor(images: T, size: [number, number], alignCorners: boolean): T; + }; + conv1d(x: T, filter: Tensor3D, stride: number, pad: 'valid' | 'same' | number, dataFormat: 'NWC' | 'NCW', dilation: number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + conv2d(x: T, filter: Tensor4D, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat: 'NHWC' | 'NCHW', dilations: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + conv2dTranspose(x: T, filter: Tensor4D, outputShape: [number, number, number, number] | [number, number, number], strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + depthwiseConv2d(x: T, filter: Tensor4D, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat: 'NHWC' | 'NCHW', dilations: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + maxPool(x: T, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + avgPool(x: T, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + localResponseNormalization(x: T, depthRadius: number, bias: number, alpha: number, beta: number): T; + unsortedSegmentSum(x: T, segmentIds: Tensor1D, numSegments: number): T; + batchToSpaceND(x: T, blockShape: number[], crops: number[][]): T; + spaceToBatchND(x: T, blockShape: number[], paddings: number[][]): T; +} +export declare function setTensorTracker(fn: () => TensorTracker): void; +export declare function setOpHandler(handler: OpHandler): void; +export declare type DataId = object; +export declare class Tensor { + private static nextId; + readonly id: number; + dataId: DataId; + readonly shape: ShapeMap[R]; + readonly size: number; + readonly dtype: DataType; + readonly rankType: R; + readonly strides: number[]; + protected constructor(shape: ShapeMap[R], dtype: DataType, values?: TypedArray, dataId?: DataId); + static make, D extends DataType = 'float32', R extends Rank = Rank>(shape: ShapeMap[R], data: TensorData, dtype?: D): T; + flatten(): Tensor1D; + asScalar(): Scalar; + as1D(): Tensor1D; + as2D(rows: number, columns: number): Tensor2D; + as3D(rows: number, columns: number, depth: number): Tensor3D; + as4D(rows: number, columns: number, depth: number, depth2: number): Tensor4D; + asType(this: T, dtype: DataType): T; + readonly rank: number; + get(...locs: number[]): number; + buffer(): TensorBuffer; + data(): Promise; + dataSync(): TypedArray; + dispose(): void; + private isDisposedInternal; + readonly isDisposed: boolean; + private throwIfDisposed; + toFloat(this: T): T; + toInt(): this; + toBool(): this; + print(verbose?: boolean): void; + reshape(newShape: ShapeMap[R2]): Tensor; + reshapeAs(x: T): T; + expandDims(axis?: number): Tensor; + cumsum(axis?: number, exclusive?: boolean, reverse?: boolean): T; + squeeze(axis?: number[]): T; + clone(this: T): T; + toString(verbose?: boolean): string; + tile(this: T, reps: number[]): T; + gather(this: T, indices: Tensor1D, axis?: number): T; + matMul(b: Tensor2D, transposeA?: boolean, transposeB?: boolean): Tensor2D; + dot(b: Tensor): Tensor; + norm(ord?: number | 'euclidean' | 'fro', axis?: number | number[], keepDims?: boolean): Tensor; + slice>(this: T, begin: number | number[], size?: number | number[]): T; + reverse(this: T, axis?: number | number[]): T; + concat(this: T, x: T, axis?: number): T; + stack(x: Tensor, axis?: number): Tensor; + unstack(x: Tensor, axis?: number): Tensor[]; + pad(this: T, paddings: Array<[number, number]>, constantValue?: number): T; + batchNormalization(mean: Tensor | Tensor1D, variance: Tensor | Tensor1D, varianceEpsilon?: number, scale?: Tensor | Tensor1D, offset?: Tensor | Tensor1D): Tensor; + all(axis?: number | number[], keepDims?: boolean): T; + any(axis?: number | number[], keepDims?: boolean): T; + logSumExp(axis?: number | number[], keepDims?: boolean): T; + sum(axis?: number | number[], keepDims?: boolean): T; + mean(axis?: number | number[], keepDims?: boolean): T; + min(axis?: number | number[], keepDims?: boolean): T; + max(axis?: number | number[], keepDims?: boolean): T; + argMin(axis?: number): T; + argMax(axis?: number): T; + cast(dtype: DataType): T; + add(x: Tensor): T; + addStrict(this: T, x: T): T; + sub(x: Tensor): T; + subStrict(this: T, x: T): T; + pow(this: T, exp: Tensor): T; + powStrict(exp: Tensor): Tensor; + mul(x: Tensor): T; + mulStrict(this: T, x: T): T; + div(x: Tensor): T; + floorDiv(x: Tensor): T; + divStrict(this: T, x: T): T; + minimum(x: Tensor): T; + minimumStrict(this: T, x: T): T; + maximum(x: Tensor): T; + maximumStrict(this: T, x: T): T; + mod(x: Tensor): T; + modStrict(this: T, x: T): T; + squaredDifference(x: Tensor): T; + squaredDifferenceStrict(this: T, x: T): T; + transpose(this: T, perm?: number[]): T; + notEqual(x: Tensor): T; + notEqualStrict(this: T, x: T): T; + less(x: Tensor): T; + lessStrict(this: T, x: T): T; + equal(x: Tensor): T; + equalStrict(this: T, x: T): T; + lessEqual(x: Tensor): T; + lessEqualStrict(this: T, x: T): T; + greater(x: Tensor): T; + greaterStrict(this: T, x: T): T; + greaterEqual(x: Tensor): T; + greaterEqualStrict(this: T, x: T): T; + logicalAnd(x: Tensor): Tensor; + logicalOr(x: Tensor): Tensor; + logicalNot(this: T): T; + logicalXor(x: Tensor): Tensor; + where(condition: Tensor, x: Tensor): Tensor; + neg(this: T): T; + ceil(this: T): T; + floor(this: T): T; + sign(this: T): T; + exp(this: T): T; + expm1(this: T): T; + log(this: T): T; + log1p(this: T): T; + sqrt(this: T): T; + rsqrt(this: T): T; + square(this: T): T; + reciprocal(this: T): T; + abs(this: T): T; + clipByValue(min: number, max: number): Tensor; + relu(this: T): T; + elu(this: T): T; + selu(this: T): T; + leakyRelu(alpha?: number): Tensor; + prelu(alpha: Tensor): Tensor; + sigmoid(this: T): T; + logSigmoid(this: T): T; + softplus(this: T): T; + sin(this: T): T; + cos(this: T): T; + tan(this: T): T; + asin(this: T): T; + acos(this: T): T; + atan(this: T): T; + sinh(this: T): T; + cosh(this: T): T; + tanh(this: T): T; + asinh(this: T): T; + acosh(this: T): T; + atanh(this: T): T; + erf(this: T): T; + round(this: T): T; + step(this: T, alpha?: number): T; + softmax(this: T, dim?: number): T; + resizeBilinear(this: T, newShape2D: [number, number], alignCorners?: boolean): T; + resizeNearestNeighbor(this: T, newShape2D: [number, number], alignCorners?: boolean): T; + conv1d(this: T, filter: Tensor3D, stride: number, pad: 'valid' | 'same' | number, dataFormat?: 'NWC' | 'NCW', dilation?: number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + conv2d(this: T, filter: Tensor4D, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat?: 'NHWC' | 'NCHW', dilations?: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + conv2dTranspose(this: T, filter: Tensor4D, outputShape: [number, number, number, number] | [number, number, number], strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + depthwiseConv2D(this: T, filter: Tensor4D, strides: [number, number] | number, pad: 'valid' | 'same' | number, dataFormat?: 'NHWC' | 'NCHW', dilations?: [number, number] | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + avgPool(this: T, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + maxPool(this: T, filterSize: [number, number] | number, strides: [number, number] | number, pad: 'valid' | 'same' | number, dimRoundingMode?: 'floor' | 'round' | 'ceil'): T; + localResponseNormalization(this: T, radius?: number, bias?: number, alpha?: number, beta?: number): T; + variable(trainable?: boolean, name?: string, dtype?: DataType): Variable; + unsortedSegmentSum(this: T, segmentIds: Tensor1D, numSegments: number): T; + batchToSpaceND(this: T, blockShape: number[], crops: number[][]): T; + spaceToBatchND(this: T, blockShape: number[], paddings: number[][]): T; +} +export declare type Scalar = Tensor; +export declare type Tensor1D = Tensor; +export declare type Tensor2D = Tensor; +export declare type Tensor3D = Tensor; +export declare type Tensor4D = Tensor; +export declare type Tensor5D = Tensor; +export declare type Tensor6D = Tensor; +export declare class Variable extends Tensor { + trainable: boolean; + private static nextVarId; + name: string; + private constructor(); + static variable(initialValue: Tensor, trainable?: boolean, name?: string, dtype?: DataType): Variable; + assign(newValue: Tensor): void; +} +declare const variable: typeof Variable.variable; +export { variable }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor.js b/node_modules/@tensorflow/tfjs-core/dist/tensor.js new file mode 100644 index 0000000..208a7bb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor.js @@ -0,0 +1,836 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_format_1 = require("./tensor_format"); +var util = require("./util"); +var util_1 = require("./util"); +var TensorBuffer = (function () { + function TensorBuffer(shape, dtype, values) { + this.dtype = dtype; + if (values != null) { + var n = values.length; + var size = util.sizeFromShape(shape); + util.assert(n === size, "Length of values '" + n + "' does not match the size " + + ("inferred by the shape '" + size + "'")); + } + this.shape = shape.slice(); + this.values = + values || util.getTypedArrayFromDType(dtype, util.sizeFromShape(shape)); + this.strides = util_1.computeStrides(shape); + this.size = util.sizeFromShape(shape); + } + TensorBuffer.prototype.set = function (value) { + var locs = []; + for (var _i = 1; _i < arguments.length; _i++) { + locs[_i - 1] = arguments[_i]; + } + if (locs.length === 0) { + locs = [0]; + } + util.assert(locs.length === this.rank, "The number of provided coordinates (" + locs.length + ") must " + + ("match the rank (" + this.rank + ")")); + var index = this.locToIndex(locs); + this.values[index] = value; + }; + TensorBuffer.prototype.get = function () { + var locs = []; + for (var _i = 0; _i < arguments.length; _i++) { + locs[_i] = arguments[_i]; + } + if (locs.length === 0) { + locs = [0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return this.values[index]; + }; + TensorBuffer.prototype.locToIndex = function (locs) { + if (this.rank === 0) { + return 0; + } + else if (this.rank === 1) { + return locs[0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return index; + }; + TensorBuffer.prototype.indexToLoc = function (index) { + if (this.rank === 0) { + return []; + } + else if (this.rank === 1) { + return [index]; + } + var locs = new Array(this.shape.length); + for (var i = 0; i < locs.length - 1; ++i) { + locs[i] = Math.floor(index / this.strides[i]); + index -= locs[i] * this.strides[i]; + } + locs[locs.length - 1] = index; + return locs; + }; + Object.defineProperty(TensorBuffer.prototype, "rank", { + get: function () { + return this.shape.length; + }, + enumerable: true, + configurable: true + }); + TensorBuffer.prototype.toTensor = function () { + return Tensor.make(this.shape, { values: this.values }, this.dtype); + }; + return TensorBuffer; +}()); +exports.TensorBuffer = TensorBuffer; +var trackerFn = null; +var opHandler = null; +function setTensorTracker(fn) { + trackerFn = fn; +} +exports.setTensorTracker = setTensorTracker; +function setOpHandler(handler) { + opHandler = handler; +} +exports.setOpHandler = setOpHandler; +var Tensor = (function () { + function Tensor(shape, dtype, values, dataId) { + this.isDisposedInternal = false; + this.size = util.sizeFromShape(shape); + if (values != null) { + util.assert(this.size === values.length, "Constructing tensor of shape (" + this.size + ") should match the " + + ("length of values (" + values.length + ")")); + } + this.shape = shape.slice(); + this.dtype = dtype || 'float32'; + this.strides = util_1.computeStrides(shape); + this.dataId = dataId != null ? dataId : {}; + this.id = Tensor.nextId++; + this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher'); + trackerFn().registerTensor(this); + if (values != null) { + trackerFn().write(this.dataId, values); + } + } + Tensor.make = function (shape, data, dtype) { + return new Tensor(shape, dtype, data.values, data.dataId); + }; + Tensor.prototype.flatten = function () { + this.throwIfDisposed(); + return this.as1D(); + }; + Tensor.prototype.asScalar = function () { + this.throwIfDisposed(); + util.assert(this.size === 1, 'The array must have only 1 element.'); + return this.reshape([]); + }; + Tensor.prototype.as1D = function () { + this.throwIfDisposed(); + return this.reshape([this.size]); + }; + Tensor.prototype.as2D = function (rows, columns) { + this.throwIfDisposed(); + return this.reshape([rows, columns]); + }; + Tensor.prototype.as3D = function (rows, columns, depth) { + this.throwIfDisposed(); + return this.reshape([rows, columns, depth]); + }; + Tensor.prototype.as4D = function (rows, columns, depth, depth2) { + this.throwIfDisposed(); + return this.reshape([rows, columns, depth, depth2]); + }; + Tensor.prototype.asType = function (dtype) { + this.throwIfDisposed(); + return opHandler.cast(this, dtype); + }; + Object.defineProperty(Tensor.prototype, "rank", { + get: function () { + return this.shape.length; + }, + enumerable: true, + configurable: true + }); + Tensor.prototype.get = function () { + var locs = []; + for (var _i = 0; _i < arguments.length; _i++) { + locs[_i] = arguments[_i]; + } + util.assert(locs.length === this.rank, 'Number of coordinates in get() must match the rank of the tensor'); + this.throwIfDisposed(); + if (locs.length === 0) { + locs = [0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return this.dataSync()[index]; + }; + Tensor.prototype.buffer = function () { + return opHandler.buffer(this.shape, this.dtype, this.dataSync()); + }; + Tensor.prototype.data = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.throwIfDisposed(); + return [2, trackerFn().read(this.dataId)]; + }); + }); + }; + Tensor.prototype.dataSync = function () { + this.throwIfDisposed(); + return trackerFn().readSync(this.dataId); + }; + Tensor.prototype.dispose = function () { + if (this.isDisposed) { + return; + } + trackerFn().disposeTensor(this); + this.isDisposedInternal = true; + }; + Object.defineProperty(Tensor.prototype, "isDisposed", { + get: function () { + return this.isDisposedInternal; + }, + enumerable: true, + configurable: true + }); + Tensor.prototype.throwIfDisposed = function () { + if (this.isDisposed) { + throw new Error("Tensor is disposed."); + } + }; + Tensor.prototype.toFloat = function () { + return this.asType('float32'); + }; + Tensor.prototype.toInt = function () { + return this.asType('int32'); + }; + Tensor.prototype.toBool = function () { + return this.asType('bool'); + }; + Tensor.prototype.print = function (verbose) { + if (verbose === void 0) { verbose = false; } + return opHandler.print(this, verbose); + }; + Tensor.prototype.reshape = function (newShape) { + this.throwIfDisposed(); + return opHandler.reshape(this, newShape); + }; + Tensor.prototype.reshapeAs = function (x) { + this.throwIfDisposed(); + return this.reshape(x.shape); + }; + Tensor.prototype.expandDims = function (axis) { + if (axis === void 0) { axis = 0; } + return opHandler.expandDims(this, axis); + }; + Tensor.prototype.cumsum = function (axis, exclusive, reverse) { + if (axis === void 0) { axis = 0; } + if (exclusive === void 0) { exclusive = false; } + if (reverse === void 0) { reverse = false; } + return opHandler.cumsum(this, axis, exclusive, reverse); + }; + Tensor.prototype.squeeze = function (axis) { + this.throwIfDisposed(); + return opHandler.squeeze(this, axis); + }; + Tensor.prototype.clone = function () { + this.throwIfDisposed(); + return opHandler.clone(this); + }; + Tensor.prototype.toString = function (verbose) { + if (verbose === void 0) { verbose = false; } + var vals = this.dataSync(); + return tensor_format_1.tensorToString(vals, this.shape, this.dtype, verbose); + }; + Tensor.prototype.tile = function (reps) { + this.throwIfDisposed(); + return opHandler.tile(this, reps); + }; + Tensor.prototype.gather = function (indices, axis) { + if (axis === void 0) { axis = 0; } + this.throwIfDisposed(); + return opHandler.gather(this, indices, axis); + }; + Tensor.prototype.matMul = function (b, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + this.throwIfDisposed(); + return opHandler.matMul(this, b, transposeA, transposeB); + }; + Tensor.prototype.dot = function (b) { + this.throwIfDisposed(); + return opHandler.dot(this, b); + }; + Tensor.prototype.norm = function (ord, axis, keepDims) { + if (ord === void 0) { ord = 'euclidean'; } + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.norm(this, ord, axis, keepDims); + }; + Tensor.prototype.slice = function (begin, size) { + this.throwIfDisposed(); + return opHandler.slice(this, begin, size); + }; + Tensor.prototype.reverse = function (axis) { + this.throwIfDisposed(); + return opHandler.reverse(this, axis); + }; + Tensor.prototype.concat = function (x, axis) { + if (axis === void 0) { axis = 0; } + this.throwIfDisposed(); + return opHandler.concat([this, x], axis); + }; + Tensor.prototype.stack = function (x, axis) { + if (axis === void 0) { axis = 0; } + return opHandler.stack([this, x], axis); + }; + Tensor.prototype.unstack = function (x, axis) { + if (axis === void 0) { axis = 0; } + return opHandler.unstack(this, axis); + }; + Tensor.prototype.pad = function (paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + return opHandler.pad(this, paddings, constantValue); + }; + Tensor.prototype.batchNormalization = function (mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + this.throwIfDisposed(); + return opHandler.batchNormalization(this, mean, variance, varianceEpsilon, scale, offset); + }; + Tensor.prototype.all = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.all(this, axis, keepDims); + }; + Tensor.prototype.any = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.any(this, axis, keepDims); + }; + Tensor.prototype.logSumExp = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.logSumExp(this, axis, keepDims); + }; + Tensor.prototype.sum = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.sum(this, axis, keepDims); + }; + Tensor.prototype.mean = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.mean(this, axis, keepDims); + }; + Tensor.prototype.min = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.min(this, axis, keepDims); + }; + Tensor.prototype.max = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.max(this, axis, keepDims); + }; + Tensor.prototype.argMin = function (axis) { + if (axis === void 0) { axis = null; } + this.throwIfDisposed(); + return opHandler.argMin(this, axis); + }; + Tensor.prototype.argMax = function (axis) { + if (axis === void 0) { axis = null; } + this.throwIfDisposed(); + return opHandler.argMax(this, axis); + }; + Tensor.prototype.cast = function (dtype) { + this.throwIfDisposed(); + return opHandler.cast(this, dtype); + }; + Tensor.prototype.add = function (x) { + this.throwIfDisposed(); + return opHandler.add(this, x); + }; + Tensor.prototype.addStrict = function (x) { + this.throwIfDisposed(); + return opHandler.addStrict(this, x); + }; + Tensor.prototype.sub = function (x) { + this.throwIfDisposed(); + return opHandler.sub(this, x); + }; + Tensor.prototype.subStrict = function (x) { + this.throwIfDisposed(); + return opHandler.subStrict(this, x); + }; + Tensor.prototype.pow = function (exp) { + this.throwIfDisposed(); + return opHandler.pow(this, exp); + }; + Tensor.prototype.powStrict = function (exp) { + this.throwIfDisposed(); + return opHandler.powStrict(this, exp); + }; + Tensor.prototype.mul = function (x) { + this.throwIfDisposed(); + return opHandler.mul(this, x); + }; + Tensor.prototype.mulStrict = function (x) { + this.throwIfDisposed(); + return opHandler.mulStrict(this, x); + }; + Tensor.prototype.div = function (x) { + this.throwIfDisposed(); + return opHandler.div(this, x); + }; + Tensor.prototype.floorDiv = function (x) { + this.throwIfDisposed(); + return opHandler.floorDiv(this, x); + }; + Tensor.prototype.divStrict = function (x) { + this.throwIfDisposed(); + return opHandler.divStrict(this, x); + }; + Tensor.prototype.minimum = function (x) { + this.throwIfDisposed(); + return opHandler.minimum(this, x); + }; + Tensor.prototype.minimumStrict = function (x) { + this.throwIfDisposed(); + return opHandler.minimumStrict(this, x); + }; + Tensor.prototype.maximum = function (x) { + this.throwIfDisposed(); + return opHandler.maximum(this, x); + }; + Tensor.prototype.maximumStrict = function (x) { + this.throwIfDisposed(); + return opHandler.maximumStrict(this, x); + }; + Tensor.prototype.mod = function (x) { + this.throwIfDisposed(); + return opHandler.mod(this, x); + }; + Tensor.prototype.modStrict = function (x) { + this.throwIfDisposed(); + return opHandler.modStrict(this, x); + }; + Tensor.prototype.squaredDifference = function (x) { + this.throwIfDisposed(); + return opHandler.squaredDifference(this, x); + }; + Tensor.prototype.squaredDifferenceStrict = function (x) { + this.throwIfDisposed(); + return opHandler.squaredDifferenceStrict(this, x); + }; + Tensor.prototype.transpose = function (perm) { + this.throwIfDisposed(); + return opHandler.transpose(this, perm); + }; + Tensor.prototype.notEqual = function (x) { + this.throwIfDisposed(); + return opHandler.notEqual(this, x); + }; + Tensor.prototype.notEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.notEqualStrict(this, x); + }; + Tensor.prototype.less = function (x) { + this.throwIfDisposed(); + return opHandler.less(this, x); + }; + Tensor.prototype.lessStrict = function (x) { + this.throwIfDisposed(); + return opHandler.lessStrict(this, x); + }; + Tensor.prototype.equal = function (x) { + this.throwIfDisposed(); + return opHandler.equal(this, x); + }; + Tensor.prototype.equalStrict = function (x) { + this.throwIfDisposed(); + return opHandler.equalStrict(this, x); + }; + Tensor.prototype.lessEqual = function (x) { + this.throwIfDisposed(); + return opHandler.lessEqual(this, x); + }; + Tensor.prototype.lessEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.lessEqualStrict(this, x); + }; + Tensor.prototype.greater = function (x) { + this.throwIfDisposed(); + return opHandler.greater(this, x); + }; + Tensor.prototype.greaterStrict = function (x) { + this.throwIfDisposed(); + return opHandler.greaterStrict(this, x); + }; + Tensor.prototype.greaterEqual = function (x) { + this.throwIfDisposed(); + return opHandler.greaterEqual(this, x); + }; + Tensor.prototype.greaterEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.greaterEqualStrict(this, x); + }; + Tensor.prototype.logicalAnd = function (x) { + this.throwIfDisposed(); + return opHandler.logicalAnd(this, x); + }; + Tensor.prototype.logicalOr = function (x) { + this.throwIfDisposed(); + return opHandler.logicalOr(this, x); + }; + Tensor.prototype.logicalNot = function () { + this.throwIfDisposed(); + return opHandler.logicalNot(this); + }; + Tensor.prototype.logicalXor = function (x) { + this.throwIfDisposed(); + return opHandler.logicalXor(this, x); + }; + Tensor.prototype.where = function (condition, x) { + this.throwIfDisposed(); + return opHandler.where(condition, this, x); + }; + Tensor.prototype.neg = function () { + this.throwIfDisposed(); + return opHandler.neg(this); + }; + Tensor.prototype.ceil = function () { + this.throwIfDisposed(); + return opHandler.ceil(this); + }; + Tensor.prototype.floor = function () { + this.throwIfDisposed(); + return opHandler.floor(this); + }; + Tensor.prototype.sign = function () { + this.throwIfDisposed(); + return opHandler.sign(this); + }; + Tensor.prototype.exp = function () { + this.throwIfDisposed(); + return opHandler.exp(this); + }; + Tensor.prototype.expm1 = function () { + this.throwIfDisposed(); + return opHandler.expm1(this); + }; + Tensor.prototype.log = function () { + this.throwIfDisposed(); + return opHandler.log(this); + }; + Tensor.prototype.log1p = function () { + this.throwIfDisposed(); + return opHandler.log1p(this); + }; + Tensor.prototype.sqrt = function () { + this.throwIfDisposed(); + return opHandler.sqrt(this); + }; + Tensor.prototype.rsqrt = function () { + this.throwIfDisposed(); + return opHandler.rsqrt(this); + }; + Tensor.prototype.square = function () { + this.throwIfDisposed(); + return opHandler.square(this); + }; + Tensor.prototype.reciprocal = function () { + this.throwIfDisposed(); + return opHandler.reciprocal(this); + }; + Tensor.prototype.abs = function () { + this.throwIfDisposed(); + return opHandler.abs(this); + }; + Tensor.prototype.clipByValue = function (min, max) { + this.throwIfDisposed(); + return opHandler.clipByValue(this, min, max); + }; + Tensor.prototype.relu = function () { + this.throwIfDisposed(); + return opHandler.relu(this); + }; + Tensor.prototype.elu = function () { + this.throwIfDisposed(); + return opHandler.elu(this); + }; + Tensor.prototype.selu = function () { + this.throwIfDisposed(); + return opHandler.selu(this); + }; + Tensor.prototype.leakyRelu = function (alpha) { + if (alpha === void 0) { alpha = 0.2; } + this.throwIfDisposed(); + return opHandler.leakyRelu(this, alpha); + }; + Tensor.prototype.prelu = function (alpha) { + this.throwIfDisposed(); + return opHandler.prelu(this, alpha); + }; + Tensor.prototype.sigmoid = function () { + this.throwIfDisposed(); + return opHandler.sigmoid(this); + }; + Tensor.prototype.logSigmoid = function () { + this.throwIfDisposed(); + return opHandler.logSigmoid(this); + }; + Tensor.prototype.softplus = function () { + this.throwIfDisposed(); + return opHandler.softplus(this); + }; + Tensor.prototype.sin = function () { + this.throwIfDisposed(); + return opHandler.sin(this); + }; + Tensor.prototype.cos = function () { + this.throwIfDisposed(); + return opHandler.cos(this); + }; + Tensor.prototype.tan = function () { + this.throwIfDisposed(); + return opHandler.tan(this); + }; + Tensor.prototype.asin = function () { + this.throwIfDisposed(); + return opHandler.asin(this); + }; + Tensor.prototype.acos = function () { + this.throwIfDisposed(); + return opHandler.acos(this); + }; + Tensor.prototype.atan = function () { + this.throwIfDisposed(); + return opHandler.atan(this); + }; + Tensor.prototype.sinh = function () { + this.throwIfDisposed(); + return opHandler.sinh(this); + }; + Tensor.prototype.cosh = function () { + this.throwIfDisposed(); + return opHandler.cosh(this); + }; + Tensor.prototype.tanh = function () { + this.throwIfDisposed(); + return opHandler.tanh(this); + }; + Tensor.prototype.asinh = function () { + this.throwIfDisposed(); + return opHandler.asinh(this); + }; + Tensor.prototype.acosh = function () { + this.throwIfDisposed(); + return opHandler.acosh(this); + }; + Tensor.prototype.atanh = function () { + this.throwIfDisposed(); + return opHandler.atanh(this); + }; + Tensor.prototype.erf = function () { + this.throwIfDisposed(); + return opHandler.erf(this); + }; + Tensor.prototype.round = function () { + this.throwIfDisposed(); + return opHandler.round(this); + }; + Tensor.prototype.step = function (alpha) { + if (alpha === void 0) { alpha = 0.0; } + this.throwIfDisposed(); + return opHandler.step(this, alpha); + }; + Tensor.prototype.softmax = function (dim) { + if (dim === void 0) { dim = -1; } + this.throwIfDisposed(); + return opHandler.softmax(this, dim); + }; + Tensor.prototype.resizeBilinear = function (newShape2D, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + this.throwIfDisposed(); + return opHandler.image.resizeBilinear(this, newShape2D, alignCorners); + }; + Tensor.prototype.resizeNearestNeighbor = function (newShape2D, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + this.throwIfDisposed(); + return opHandler.image.resizeNearestNeighbor(this, newShape2D, alignCorners); + }; + Tensor.prototype.conv1d = function (filter, stride, pad, dataFormat, dilation, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NWC'; } + if (dilation === void 0) { dilation = 1; } + this.throwIfDisposed(); + return opHandler.conv1d(this, filter, stride, pad, dataFormat, dilation, dimRoundingMode); + }; + Tensor.prototype.conv2d = function (filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + this.throwIfDisposed(); + return opHandler.conv2d(this, filter, strides, pad, dataFormat, dilations, dimRoundingMode); + }; + Tensor.prototype.conv2dTranspose = function (filter, outputShape, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.conv2dTranspose(this, filter, outputShape, strides, pad, dimRoundingMode); + }; + Tensor.prototype.depthwiseConv2D = function (filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + this.throwIfDisposed(); + return opHandler.depthwiseConv2d(this, filter, strides, pad, dataFormat, dilations, dimRoundingMode); + }; + Tensor.prototype.avgPool = function (filterSize, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.avgPool(this, filterSize, strides, pad, dimRoundingMode); + }; + Tensor.prototype.maxPool = function (filterSize, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.maxPool(this, filterSize, strides, pad, dimRoundingMode); + }; + Tensor.prototype.localResponseNormalization = function (radius, bias, alpha, beta) { + if (radius === void 0) { radius = 5; } + if (bias === void 0) { bias = 1; } + if (alpha === void 0) { alpha = 1; } + if (beta === void 0) { beta = 0.5; } + return opHandler.localResponseNormalization(this, radius, bias, alpha, beta); + }; + Tensor.prototype.variable = function (trainable, name, dtype) { + if (trainable === void 0) { trainable = true; } + this.throwIfDisposed(); + return Variable.variable(this, trainable, name, dtype); + }; + Tensor.prototype.unsortedSegmentSum = function (segmentIds, numSegments) { + this.throwIfDisposed(); + return opHandler.unsortedSegmentSum(this, segmentIds, numSegments); + }; + Tensor.prototype.batchToSpaceND = function (blockShape, crops) { + this.throwIfDisposed(); + return opHandler.batchToSpaceND(this, blockShape, crops); + }; + Tensor.prototype.spaceToBatchND = function (blockShape, paddings) { + this.throwIfDisposed(); + return opHandler.spaceToBatchND(this, blockShape, paddings); + }; + Tensor.nextId = 0; + return Tensor; +}()); +exports.Tensor = Tensor; +Object.defineProperty(Tensor, Symbol.hasInstance, { + value: function (instance) { + return !!instance && instance.shape != null && instance.dtype != null; + } +}); +var Variable = (function (_super) { + __extends(Variable, _super); + function Variable(initialValue, trainable, name) { + if (trainable === void 0) { trainable = true; } + var _this = _super.call(this, initialValue.shape, initialValue.dtype, null, initialValue.dataId) || this; + _this.trainable = trainable; + _this.name = name; + if (_this.name == null) { + _this.name = Variable.nextVarId.toString(); + Variable.nextVarId++; + } + try { + trackerFn().registerVariable(_this); + } + catch (ex) { + trackerFn().disposeTensor(_this); + throw ex; + } + return _this; + } + Variable.variable = function (initialValue, trainable, name, dtype) { + if (trainable === void 0) { trainable = true; } + if (dtype != null && dtype !== initialValue.dtype) { + initialValue = initialValue.asType(dtype); + } + return new Variable(initialValue, trainable, name); + }; + Variable.prototype.assign = function (newValue) { + if (newValue.dtype !== this.dtype) { + throw new Error("dtype of the new value (" + newValue.dtype + ") and " + + ("previous value (" + this.dtype + ") must match")); + } + if (!util.arraysEqual(newValue.shape, this.shape)) { + throw new Error("shape of the new value (" + newValue.shape + ") and " + + ("previous value (" + this.shape + ") must match")); + } + trackerFn().disposeTensor(this); + this.dataId = newValue.dataId; + trackerFn().registerTensor(this); + }; + Variable.nextVarId = 0; + return Variable; +}(Tensor)); +exports.Variable = Variable; +Object.defineProperty(Variable, Symbol.hasInstance, { + value: function (instance) { + return instance instanceof Tensor && instance.assign != null && + instance.assign instanceof Function; + } +}); +var variable = Variable.variable; +exports.variable = variable; +//# sourceMappingURL=tensor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor.js.map new file mode 100644 index 0000000..2790bd0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor.js","sourceRoot":"","sources":["../src/tensor.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_format.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.d.ts new file mode 100644 index 0000000..eb21384 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.d.ts @@ -0,0 +1,2 @@ +import { DataType, TypedArray } from './types'; +export declare function tensorToString(vals: TypedArray, shape: number[], dtype: DataType, verbose: boolean): string; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js new file mode 100644 index 0000000..4ac35f5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js @@ -0,0 +1,105 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util_1 = require("./util"); +var FORMAT_LIMIT_NUM_VALS = 20; +var FORMAT_NUM_FIRST_LAST_VALS = 3; +var FORMAT_NUM_SIG_DIGITS = 7; +function tensorToString(vals, shape, dtype, verbose) { + var strides = util_1.computeStrides(shape); + var padPerCol = computeMaxSizePerColumn(vals, shape, strides); + var rank = shape.length; + var valsLines = subTensorToString(vals, shape, strides, padPerCol); + var lines = ['Tensor']; + if (verbose) { + lines.push(" dtype: " + dtype); + lines.push(" rank: " + rank); + lines.push(" shape: [" + shape + "]"); + lines.push(" values:"); + } + lines.push(valsLines.map(function (l) { return ' ' + l; }).join('\n')); + return lines.join('\n'); +} +exports.tensorToString = tensorToString; +function computeMaxSizePerColumn(vals, shape, strides) { + var n = util_1.sizeFromShape(shape); + var numCols = strides[strides.length - 1]; + var padPerCol = new Array(numCols).fill(0); + var rank = shape.length; + if (rank > 1) { + for (var row = 0; row < n / numCols; row++) { + var offset = row * numCols; + for (var j = 0; j < numCols; j++) { + padPerCol[j] = + Math.max(padPerCol[j], valToString(vals[offset + j], 0).length); + } + } + } + return padPerCol; +} +function valToString(val, pad) { + return util_1.rightPad(parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), pad); +} +function subTensorToString(vals, shape, strides, padPerCol, isLast) { + if (isLast === void 0) { isLast = true; } + var size = shape[0]; + var rank = shape.length; + if (rank === 0) { + return [vals[0].toString()]; + } + if (rank === 1) { + if (size > FORMAT_LIMIT_NUM_VALS) { + var firstVals = Array.from(vals.subarray(0, FORMAT_NUM_FIRST_LAST_VALS)); + var lastVals = Array.from(vals.subarray(size - FORMAT_NUM_FIRST_LAST_VALS, size)); + return [ + '[' + firstVals.map(function (x, i) { return valToString(x, padPerCol[i]); }).join(', ') + + ', ..., ' + + lastVals + .map(function (x, i) { return valToString(x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i]); }) + .join(', ') + + ']' + ]; + } + return [ + '[' + + Array.from(vals).map(function (x, i) { return valToString(x, padPerCol[i]); }).join(', ') + + ']' + ]; + } + var subshape = shape.slice(1); + var substrides = strides.slice(1); + var stride = strides[0]; + var lines = []; + if (size > FORMAT_LIMIT_NUM_VALS) { + for (var i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, false)); + } + lines.push('...'); + for (var i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, i === size - 1)); + } + } + else { + for (var i = 0; i < size; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, i === size - 1)); + } + } + var sep = rank === 2 ? ',' : ''; + lines[0] = '[' + lines[0] + sep; + for (var i = 1; i < lines.length - 1; i++) { + lines[i] = ' ' + lines[i] + sep; + } + var newLineSep = ',\n'; + for (var i = 2; i < rank; i++) { + newLineSep += '\n'; + } + lines[lines.length - 1] = + ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep); + return lines; +} +//# sourceMappingURL=tensor_format.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js.map new file mode 100644 index 0000000..e75ab92 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_format.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_format.js","sourceRoot":"","sources":["../src/tensor_format.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js new file mode 100644 index 0000000..f77d820 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js @@ -0,0 +1,1057 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var tensor_1 = require("./tensor"); +var test_util_1 = require("./test_util"); +var types_1 = require("./types"); +jasmine_util_1.describeWithFlags('tensor', test_util_1.ALL_ENVS, function () { + it('Tensors of arbitrary size', function () { + var t = tf.tensor1d([1, 2, 3]); + expect(t.rank).toBe(1); + expect(t.size).toBe(3); + test_util_1.expectArraysClose(t, [1, 2, 3]); + expect(t.get(4)).toBeUndefined(); + t = tf.tensor2d([1, 2, 3], [1, 3]); + expect(t.rank).toBe(2); + expect(t.size).toBe(3); + test_util_1.expectArraysClose(t, [1, 2, 3]); + expect(t.get(0, 4)).toBeUndefined(); + t = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + expect(t.rank).toBe(2); + expect(t.size).toBe(6); + test_util_1.expectArraysClose(t, [1, 2, 3, 4, 5, 6]); + expect(t.get(5, 3)).toBeUndefined(); + expect(function () { return tf.tensor2d([1], [1, 2]); }).toThrowError(); + }); + it('Tensors of explicit size', function () { + var t = tf.tensor1d([5, 3, 2]); + expect(t.rank).toBe(1); + expect(t.shape).toEqual([3]); + test_util_1.expectNumbersClose(t.get(1), 3); + expect(function () { return tf.tensor3d([1, 2], [1, 2, 3, 5]); }).toThrowError(); + var t4 = tf.tensor4d([1, 2, 3, 4], [1, 2, 1, 2]); + test_util_1.expectNumbersClose(t4.get(0, 0, 0, 0), 1); + test_util_1.expectNumbersClose(t4.get(0, 0, 0, 1), 2); + test_util_1.expectNumbersClose(t4.get(0, 1, 0, 0), 3); + test_util_1.expectNumbersClose(t4.get(0, 1, 0, 1), 4); + var x = tf.ones([3, 4, 2]); + expect(x.rank).toBe(3); + expect(x.size).toBe(24); + for (var i = 0; i < 3; i++) { + for (var j = 0; j < 4; j++) { + for (var k = 0; k < 2; k++) { + test_util_1.expectNumbersClose(x.get(i, j, k), 1); + } + } + } + var z = tf.zeros([3, 4, 2]); + expect(z.rank).toBe(3); + expect(z.size).toBe(24); + for (var i = 0; i < 3; i++) { + for (var j = 0; j < 4; j++) { + for (var k = 0; k < 2; k++) { + test_util_1.expectNumbersClose(z.get(i, j, k), 0); + } + } + } + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + test_util_1.expectNumbersClose(a.get(1, 2), 6); + }); + it('Tensor dataSync CPU --> GPU', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [3, 2]); + test_util_1.expectArraysClose(a.dataSync(), new Float32Array([1, 2, 3, 4, 5, 6])); + }); + it('Tensor.data() CPU --> GPU', function () { return __awaiter(_this, void 0, void 0, function () { + var a, _a; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + a = tf.tensor2d([1, 2, 3, 4, 5, 6], [3, 2]); + _a = test_util_1.expectArraysClose; + return [4, a.data()]; + case 1: + _a.apply(void 0, [_b.sent(), new Float32Array([1, 2, 3, 4, 5, 6])]); + return [2]; + } + }); + }); }); + it('Scalar basic methods', function () { + var a = tf.scalar(5); + test_util_1.expectNumbersClose(a.get(), 5); + test_util_1.expectArraysClose(a, [5]); + expect(a.rank).toBe(0); + expect(a.size).toBe(1); + expect(a.shape).toEqual([]); + }); + it('indexToLoc Scalar', function () { + var a = tf.scalar(0).buffer(); + expect(a.indexToLoc(0)).toEqual([]); + var b = tf.zeros([]).buffer(); + expect(b.indexToLoc(0)).toEqual([]); + }); + it('indexToLoc Tensor1D', function () { + var a = tf.zeros([3]).buffer(); + expect(a.indexToLoc(0)).toEqual([0]); + expect(a.indexToLoc(1)).toEqual([1]); + expect(a.indexToLoc(2)).toEqual([2]); + var b = tf.zeros([3]).buffer(); + expect(b.indexToLoc(0)).toEqual([0]); + expect(b.indexToLoc(1)).toEqual([1]); + expect(b.indexToLoc(2)).toEqual([2]); + }); + it('indexToLoc Tensor2D', function () { + var a = tf.zeros([3, 2]).buffer(); + expect(a.indexToLoc(0)).toEqual([0, 0]); + expect(a.indexToLoc(1)).toEqual([0, 1]); + expect(a.indexToLoc(2)).toEqual([1, 0]); + expect(a.indexToLoc(3)).toEqual([1, 1]); + expect(a.indexToLoc(4)).toEqual([2, 0]); + expect(a.indexToLoc(5)).toEqual([2, 1]); + var b = tf.zeros([3, 2]).buffer(); + expect(b.indexToLoc(0)).toEqual([0, 0]); + expect(b.indexToLoc(1)).toEqual([0, 1]); + expect(b.indexToLoc(2)).toEqual([1, 0]); + expect(b.indexToLoc(3)).toEqual([1, 1]); + expect(b.indexToLoc(4)).toEqual([2, 0]); + expect(b.indexToLoc(5)).toEqual([2, 1]); + }); + it('indexToLoc Tensor3D', function () { + var a = tf.zeros([3, 2, 2]).buffer(); + expect(a.indexToLoc(0)).toEqual([0, 0, 0]); + expect(a.indexToLoc(1)).toEqual([0, 0, 1]); + expect(a.indexToLoc(2)).toEqual([0, 1, 0]); + expect(a.indexToLoc(3)).toEqual([0, 1, 1]); + expect(a.indexToLoc(4)).toEqual([1, 0, 0]); + expect(a.indexToLoc(5)).toEqual([1, 0, 1]); + expect(a.indexToLoc(11)).toEqual([2, 1, 1]); + var b = tf.zeros([3, 2, 2]).buffer(); + expect(b.indexToLoc(0)).toEqual([0, 0, 0]); + expect(b.indexToLoc(1)).toEqual([0, 0, 1]); + expect(b.indexToLoc(2)).toEqual([0, 1, 0]); + expect(b.indexToLoc(3)).toEqual([0, 1, 1]); + expect(b.indexToLoc(4)).toEqual([1, 0, 0]); + expect(b.indexToLoc(5)).toEqual([1, 0, 1]); + expect(b.indexToLoc(11)).toEqual([2, 1, 1]); + }); + it('indexToLoc Tensor 5D', function () { + var values = new Float32Array([1, 2, 3, 4]); + var a = tensor_1.Tensor.make([2, 1, 1, 1, 2], { values: values }).buffer(); + expect(a.indexToLoc(0)).toEqual([0, 0, 0, 0, 0]); + expect(a.indexToLoc(1)).toEqual([0, 0, 0, 0, 1]); + expect(a.indexToLoc(2)).toEqual([1, 0, 0, 0, 0]); + expect(a.indexToLoc(3)).toEqual([1, 0, 0, 0, 1]); + }); + it('locToIndex Scalar', function () { + var a = tf.scalar(0).buffer(); + expect(a.locToIndex([])).toEqual(0); + var b = tf.zeros([]).buffer(); + expect(b.locToIndex([])).toEqual(0); + }); + it('locToIndex Tensor1D', function () { + var a = tf.zeros([3]).buffer(); + expect(a.locToIndex([0])).toEqual(0); + expect(a.locToIndex([1])).toEqual(1); + expect(a.locToIndex([2])).toEqual(2); + var b = tf.zeros([3]).buffer(); + expect(b.locToIndex([0])).toEqual(0); + expect(b.locToIndex([1])).toEqual(1); + expect(b.locToIndex([2])).toEqual(2); + }); + it('locToIndex Tensor2D', function () { + var a = tf.zeros([3, 2]).buffer(); + expect(a.locToIndex([0, 0])).toEqual(0); + expect(a.locToIndex([0, 1])).toEqual(1); + expect(a.locToIndex([1, 0])).toEqual(2); + expect(a.locToIndex([1, 1])).toEqual(3); + expect(a.locToIndex([2, 0])).toEqual(4); + expect(a.locToIndex([2, 1])).toEqual(5); + var b = tf.zeros([3, 2]).buffer(); + expect(b.locToIndex([0, 0])).toEqual(0); + expect(b.locToIndex([0, 1])).toEqual(1); + expect(b.locToIndex([1, 0])).toEqual(2); + expect(b.locToIndex([1, 1])).toEqual(3); + expect(b.locToIndex([2, 0])).toEqual(4); + expect(b.locToIndex([2, 1])).toEqual(5); + }); + it('locToIndex Tensor3D', function () { + var a = tf.zeros([3, 2, 2]).buffer(); + expect(a.locToIndex([0, 0, 0])).toEqual(0); + expect(a.locToIndex([0, 0, 1])).toEqual(1); + expect(a.locToIndex([0, 1, 0])).toEqual(2); + expect(a.locToIndex([0, 1, 1])).toEqual(3); + expect(a.locToIndex([1, 0, 0])).toEqual(4); + expect(a.locToIndex([1, 0, 1])).toEqual(5); + expect(a.locToIndex([2, 1, 1])).toEqual(11); + var b = tf.zeros([3, 2, 2]).buffer(); + expect(b.locToIndex([0, 0, 0])).toEqual(0); + expect(b.locToIndex([0, 0, 1])).toEqual(1); + expect(b.locToIndex([0, 1, 0])).toEqual(2); + expect(b.locToIndex([0, 1, 1])).toEqual(3); + expect(b.locToIndex([1, 0, 0])).toEqual(4); + expect(b.locToIndex([1, 0, 1])).toEqual(5); + expect(b.locToIndex([2, 1, 1])).toEqual(11); + }); + it('Tensor assignability (asserts compiler)', function () { + var a = null; + var b = a; + expect(b).toBeNull(); + var a1 = null; + var b1 = a1; + expect(b1).toBeNull(); + var a2 = null; + var b2 = a2; + expect(b2).toBeNull(); + var a3 = null; + var b3 = a3; + expect(b3).toBeNull(); + var a4 = null; + var b4 = a4; + expect(b4).toBeNull(); + }); + it('tf.tensor1d() from number[]', function () { + var a = tf.tensor1d([1, 2, 3]); + test_util_1.expectArraysClose(a, [1, 2, 3]); + }); + it('tf.tensor1d() throw error with null input value', function () { + expect(function () { return tf.tensor1d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('tf.tensor1d() from number[][], shape mismatch', function () { + expect(function () { return tf.tensor1d([[1], [2], [3]]); }).toThrowError(); + }); + it('tf.tensor2d() from number[][]', function () { + var a = tf.tensor2d([[1, 2, 3], [4, 5, 6]], [2, 3]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4, 5, 6]); + }); + it('tf.tensor2d() requires shape to be of length 2', function () { + var shape = [4]; + expect(function () { return tf.tensor2d([1, 2, 3, 4], shape); }).toThrowError(); + }); + it('tf.tensor2d() from number[][], but shape does not match', function () { + expect(function () { return tf.tensor2d([[1, 2, 3], [4, 5, 6]], [3, 2]); }).toThrowError(); + }); + it('tf.tensor2d() from number[], but no shape throws error', function () { + expect(function () { return tf.tensor2d([1, 2, 3, 4]); }).toThrowError(); + }); + it('tf.tensor2d() throw error with null input value', function () { + expect(function () { return tf.tensor2d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('tensor3d() from number[][][]', function () { + var a = tf.tensor3d([[[1], [2], [3]], [[4], [5], [6]]], [2, 3, 1]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4, 5, 6]); + }); + it('tensor3d() from number[][][], but shape does not match', function () { + var values = [[[1], [2], [3]], [[4], [5], [6]]]; + expect(function () { return tf.tensor3d(values, [3, 2, 1]); }).toThrowError(); + }); + it('tf.tensor3d() from number[], but no shape throws error', function () { + expect(function () { return tf.tensor3d([1, 2, 3, 4]); }).toThrowError(); + }); + it('tf.tensor3d() requires shape to be of length 3', function () { + var shape = [4, 1]; + expect(function () { return tf.tensor3d([1, 2, 3, 4], shape); }).toThrowError(); + }); + it('tf.tensor3d() throw error with null input value', function () { + expect(function () { return tf.tensor3d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('tensor4d() from number[][][][]', function () { + var a = tf.tensor4d([[[[1]], [[2]]], [[[4]], [[5]]]], [2, 2, 1, 1]); + test_util_1.expectArraysClose(a, [1, 2, 4, 5]); + }); + it('tensor4d() from number[][][][], but shape does not match', function () { + var f = function () { + tf.tensor4d([[[[1]], [[2]]], [[[4]], [[5]]]], [2, 1, 2, 1]); + }; + expect(f).toThrowError(); + }); + it('tf.tensor4d() from number[], but no shape throws error', function () { + expect(function () { return tf.tensor4d([1, 2, 3, 4]); }).toThrowError(); + }); + it('tf.tensor4d() requires shape to be of length 4', function () { + var shape = [4, 1]; + expect(function () { return tf.tensor4d([1, 2, 3, 4], shape); }).toThrowError(); + }); + it('tf.tensor4d() throw error with null input value', function () { + expect(function () { return tf.tensor4d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('tf.tensor5d() throw error with null input value', function () { + expect(function () { return tf.tensor5d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('tf.tensor6d() throw error with null input value', function () { + expect(function () { return tf.tensor6d(null); }) + .toThrowError('The input to the tensor constructor ' + + 'must be a non-null value.'); + }); + it('default dtype', function () { + var a = tf.scalar(3); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [3]); + }); + it('float32 dtype', function () { + var a = tf.scalar(3, 'float32'); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [3]); + }); + it('int32 dtype', function () { + var a = tf.scalar(3, 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [3]); + }); + it('int32 dtype, 3.9 => 3, like numpy', function () { + var a = tf.scalar(3.9, 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [3]); + }); + it('int32 dtype, -3.9 => -3, like numpy', function () { + var a = tf.scalar(-3.9, 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [-3]); + }); + it('bool dtype, 3 => true, like numpy', function () { + var a = tf.scalar(3, 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.get()).toBe(1); + }); + it('bool dtype, -2 => true, like numpy', function () { + var a = tf.scalar(-2, 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.get()).toBe(1); + }); + it('bool dtype, 0 => false, like numpy', function () { + var a = tf.scalar(0, 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.get()).toBe(0); + }); + it('bool dtype from boolean', function () { + var a = tf.scalar(false, 'bool'); + expect(a.get()).toBe(0); + expect(a.dtype).toBe('bool'); + var b = tf.scalar(true, 'bool'); + expect(b.get()).toBe(1); + expect(b.dtype).toBe('bool'); + }); + it('int32 dtype from boolean', function () { + var a = tf.scalar(true, 'int32'); + expect(a.get()).toBe(1); + expect(a.dtype).toBe('int32'); + }); + it('default dtype from boolean', function () { + var a = tf.scalar(false); + test_util_1.expectNumbersClose(a.get(), 0); + expect(a.dtype).toBe('float32'); + }); + it('default dtype', function () { + var a = tf.tensor1d([1, 2, 3]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [1, 2, 3]); + }); + it('float32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'float32'); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [1, 2, 3]); + }); + it('int32 dtype', function () { + var a = tf.tensor1d([1, 2, 3], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [1, 2, 3]); + }); + it('int32 dtype, non-ints get floored, like numpy', function () { + var a = tf.tensor1d([1.1, 2.5, 3.9], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [1, 2, 3]); + }); + it('int32 dtype, negative non-ints get ceiled, like numpy', function () { + var a = tf.tensor1d([-1.1, -2.5, -3.9], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysEqual(a, [-1, -2, -3]); + }); + it('bool dtype, !=0 is truthy, 0 is falsy, like numpy', function () { + var a = tf.tensor1d([1, -2, 0, 3], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([4]); + expect(a.get(0)).toBe(1); + expect(a.get(1)).toBe(1); + expect(a.get(2)).toBe(0); + expect(a.get(3)).toBe(1); + }); + it('default dtype from boolean[]', function () { + var a = tf.tensor1d([false, false, true]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [0, 0, 1]); + }); + it('int32 dtype from boolean[]', function () { + var a = tf.tensor1d([false, false, true], 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [0, 0, 1]); + }); + it('bool dtype from boolean[]', function () { + var a = tf.tensor1d([false, false, true], 'bool'); + expect(a.dtype).toBe('bool'); + test_util_1.expectArraysEqual(a, [0, 0, 1]); + }); + it('default dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('float32 dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4], [2, 2]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('int32 dtype', function () { + var a = tf.tensor2d([[1, 2], [3, 4]], [2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, non-ints get floored, like numpy', function () { + var a = tf.tensor2d([1.1, 2.5, 3.9, 4.0], [2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, negative non-ints get ceiled, like numpy', function () { + var a = tf.tensor2d([-1.1, -2.5, -3.9, -4.0], [2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2]); + test_util_1.expectArraysEqual(a, [-1, -2, -3, -4]); + }); + it('bool dtype, !=0 is truthy, 0 is falsy, like numpy', function () { + var a = tf.tensor2d([1, -2, 0, 3], [2, 2], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([2, 2]); + expect(a.get(0, 0)).toBe(1); + expect(a.get(0, 1)).toBe(1); + expect(a.get(1, 0)).toBe(0); + expect(a.get(1, 1)).toBe(1); + }); + it('default dtype from boolean[]', function () { + var a = tf.tensor2d([[false, false], [true, false]], [2, 2]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [0, 0, 1, 0]); + }); + it('int32 dtype from boolean[]', function () { + var a = tf.tensor2d([[false, false], [true, false]], [2, 2], 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('bool dtype from boolean[]', function () { + var a = tf.tensor2d([[false, false], [true, false]], [2, 2], 'bool'); + expect(a.dtype).toBe('bool'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('default dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('float32 dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('int32 dtype', function () { + var a = tf.tensor3d([[[1], [2]], [[3], [4]]], [2, 2, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, non-ints get floored, like numpy', function () { + var a = tf.tensor3d([1.1, 2.5, 3.9, 4.0], [2, 2, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, negative non-ints get ceiled, like numpy', function () { + var a = tf.tensor3d([-1.1, -2.5, -3.9, -4.0], [2, 2, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1]); + test_util_1.expectArraysEqual(a, [-1, -2, -3, -4]); + }); + it('bool dtype, !=0 is truthy, 0 is falsy, like numpy', function () { + var a = tf.tensor3d([1, -2, 0, 3], [2, 2, 1], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([2, 2, 1]); + expect(a.get(0, 0, 0)).toBe(1); + expect(a.get(0, 1, 0)).toBe(1); + expect(a.get(1, 0, 0)).toBe(0); + expect(a.get(1, 1, 0)).toBe(1); + }); + it('default dtype from boolean[]', function () { + var a = tf.tensor3d([[[false], [false]], [[true], [false]]], [2, 2, 1]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [0, 0, 1, 0]); + }); + it('int32 dtype from boolean[]', function () { + var a = tf.tensor3d([[[false], [false]], [[true], [false]]], [2, 2, 1], 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('bool dtype from boolean[]', function () { + var a = tf.tensor3d([[[false], [false]], [[true], [false]]], [2, 2, 1], 'bool'); + expect(a.dtype).toBe('bool'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('float32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4], [2, 2, 1, 1]); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('int32 dtype', function () { + var a = tf.tensor4d([[[[1]], [[2]]], [[[3]], [[4]]]], [2, 2, 1, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, non-ints get floored, like numpy', function () { + var a = tf.tensor4d([1.1, 2.5, 3.9, 4.0], [2, 2, 1, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [1, 2, 3, 4]); + }); + it('int32 dtype, negative non-ints get ceiled, like numpy', function () { + var a = tf.tensor4d([-1.1, -2.5, -3.9, -4.0], [2, 2, 1, 1], 'int32'); + expect(a.dtype).toBe('int32'); + expect(a.shape).toEqual([2, 2, 1, 1]); + test_util_1.expectArraysEqual(a, [-1, -2, -3, -4]); + }); + it('bool dtype, !=0 is truthy, 0 is falsy, like numpy', function () { + var a = tf.tensor4d([1, -2, 0, 3], [2, 2, 1, 1], 'bool'); + expect(a.dtype).toBe('bool'); + expect(a.shape).toEqual([2, 2, 1, 1]); + expect(a.get(0, 0, 0, 0)).toBe(1); + expect(a.get(0, 1, 0, 0)).toBe(1); + expect(a.get(1, 0, 0, 0)).toBe(0); + expect(a.get(1, 1, 0, 0)).toBe(1); + }); + it('default dtype from boolean[]', function () { + var a = tf.tensor4d([[[[false], [false]], [[true], [false]]]], [1, 2, 2, 1]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [0, 0, 1, 0]); + }); + it('int32 dtype from boolean[]', function () { + var a = tf.tensor4d([[[[false], [false]], [[true], [false]]]], [1, 2, 2, 1], 'int32'); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('bool dtype from boolean[]', function () { + var a = tf.tensor4d([[[[false], [false]], [[true], [false]]]], [1, 2, 2, 1], 'bool'); + expect(a.dtype).toBe('bool'); + test_util_1.expectArraysEqual(a, [0, 0, 1, 0]); + }); + it('Scalar default dtype', function () { + var a = tf.scalar(4); + var b = a.reshape([1, 1]); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 1]); + }); + it('Scalar bool dtype', function () { + var a = tf.scalar(4, 'bool'); + var b = a.reshape([1, 1, 1]); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([1, 1, 1]); + }); + it('Tensor1D default dtype', function () { + var a = tf.tensor1d([1, 2, 3, 4]); + var b = a.reshape([2, 2]); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + }); + it('Tensor1D int32 dtype', function () { + var a = tf.tensor1d([1, 2, 3, 4], 'int32'); + var b = a.reshape([2, 2]); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([2, 2]); + }); + it('Tensor2D default dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]); + var b = a.reshape([6]); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([6]); + }); + it('Tensor2D bool dtype', function () { + var a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3], 'bool'); + var b = a.reshape([6]); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([6]); + }); + it('Tensor3D default dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1]); + var b = a.reshape([6]); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([6]); + }); + it('Tensor3D bool dtype', function () { + var a = tf.tensor3d([1, 2, 3, 4, 5, 6], [2, 3, 1], 'bool'); + var b = a.reshape([6]); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([6]); + }); + it('Tensor4D default dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4, 5, 6], [2, 3, 1, 1]); + var b = a.reshape([2, 3]); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 3]); + }); + it('Tensor4D int32 dtype', function () { + var a = tf.tensor4d([1, 2, 3, 4, 5, 6], [2, 3, 1, 1], 'int32'); + var b = a.reshape([3, 2]); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([3, 2]); + }); + it('reshape is functional', function () { + var a = tf.scalar(2.4); + var b = a.reshape([]); + expect(a.id).not.toBe(b.id); + b.dispose(); + test_util_1.expectArraysClose(a, [2.4]); + }); + it('reshape throws when passed a non-tensor', function () { + expect(function () { return tf.reshape({}, []); }) + .toThrowError(/Argument 'x' passed to 'reshape' must be a Tensor/); + }); + it('reshape accepts a tensor-like object', function () { + var res = tf.reshape([[1, 2, 3], [4, 5, 6]], [3, 2]); + expect(res.dtype).toBe('float32'); + expect(res.shape).toEqual([3, 2]); + test_util_1.expectArraysClose(res, [1, 2, 3, 4, 5, 6]); + }); + it('cast bool -> bool', function () { + var a = tf.tensor1d([1, 0], 'bool'); + expect(a.cast('bool').dtype).toEqual('bool'); + }); + it('cast bool -> int32', function () { + var a = tf.tensor1d([1, 0], 'bool'); + expect(a.cast('int32').dtype).toEqual('int32'); + }); + it('cast bool -> float32', function () { + var a = tf.tensor1d([1, 0], 'bool'); + expect(a.cast('float32').dtype).toEqual('float32'); + }); + it('cast int32 -> bool', function () { + var a = tf.tensor1d([1, 0], 'int32'); + expect(a.cast('bool').dtype).toEqual('bool'); + }); + it('cast int32 -> int32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + expect(a.cast('int32').dtype).toEqual('int32'); + }); + it('cast int32 -> float32', function () { + var a = tf.tensor1d([1, 2], 'int32'); + expect(a.cast('float32').dtype).toEqual('float32'); + }); + it('cast float32 -> bool', function () { + var a = tf.tensor1d([1.0, 0.0]); + expect(a.cast('bool').dtype).toEqual('bool'); + }); + it('cast float32 -> int32', function () { + var a = tf.tensor1d([1.0, 2.0]); + expect(a.cast('int32').dtype).toEqual('int32'); + }); + it('cast float32 -> float32', function () { + var a = tf.tensor1d([1.0, 2.0]); + expect(a.cast('float32').dtype).toEqual('float32'); + }); + it('cast throws when passed a non-tensor', function () { + expect(function () { return tf.cast({}, 'float32'); }) + .toThrowError(/Argument 'x' passed to 'cast' must be a Tensor/); + }); + it('cast accepts a tensor-like object', function () { + var a = [1.0, 2.0]; + var res = tf.cast(a, 'int32'); + expect(res.dtype).toEqual('int32'); + test_util_1.expectArraysClose(res, [1, 2]); + }); + it('scalar bool -> int32', function () { + var a = tf.scalar(true, 'bool').toInt(); + expect(a.dtype).toBe('int32'); + expect(a.get()).toBe(1); + }); + it('Tensor1D float32 -> int32', function () { + var a = tf.tensor1d([1.1, 3.9, -2.9, 0]).toInt(); + expect(a.dtype).toBe('int32'); + test_util_1.expectArraysEqual(a, [1, 3, -2, 0]); + }); + it('Tensor2D float32 -> bool', function () { + var a = tf.tensor2d([1.1, 3.9, -2.9, 0], [2, 2]).asType(types_1.DType.bool); + expect(a.dtype).toBe('bool'); + expect(a.get(0, 0)).toBe(1); + expect(a.get(0, 1)).toBe(1); + expect(a.get(1, 0)).toBe(1); + expect(a.get(1, 1)).toBe(0); + }); + it('Tensor2D int32 -> bool', function () { + var a = tf.tensor2d([1, 3, 0, -1], [2, 2], 'int32').toBool(); + expect(a.dtype).toBe('bool'); + expect(a.get(0, 0)).toBe(1); + expect(a.get(0, 1)).toBe(1); + expect(a.get(1, 0)).toBe(0); + expect(a.get(1, 1)).toBe(1); + }); + it('Tensor3D bool -> float32', function () { + var a = tf.tensor3d([true, false, false, true], [2, 2, 1], 'bool').toFloat(); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [1, 0, 0, 1]); + }); + it('bool CPU -> GPU -> CPU', function () { + var a = tf.tensor1d([1, 2, 0, 0, 5], 'bool'); + test_util_1.expectArraysEqual(a, [1, 1, 0, 0, 1]); + }); + it('int32 CPU -> GPU -> CPU', function () { + var a = tf.tensor1d([1, 2, 0, 0, 5], 'int32'); + test_util_1.expectArraysEqual(a, [1, 2, 0, 0, 5]); + }); + it('asType is functional', function () { + var a = tf.scalar(2.4, 'float32'); + var b = a.toFloat(); + expect(a.id).not.toBe(b.id); + b.dispose(); + test_util_1.expectArraysClose(a, [2.4]); + }); + it('squeeze no axis', function () { + var a = tf.tensor2d([4, 2, 1], [3, 1], 'bool'); + var b = a.squeeze(); + expect(b.shape).toEqual([3]); + }); + it('squeeze with axis', function () { + var a = tf.tensor3d([4, 2, 1], [3, 1, 1], 'bool'); + var b = a.squeeze([1]); + expect(b.shape).toEqual([3, 1]); + }); + it('squeeze wrong axis', function () { + var a = tf.tensor3d([4, 2, 1], [3, 1, 1], 'bool'); + expect(function () { return a.squeeze([0, 1]); }).toThrowError(); + }); + it('squeeze throws when passed a non-tensor', function () { + expect(function () { return tf.squeeze({}); }) + .toThrowError(/Argument 'x' passed to 'squeeze' must be a Tensor/); + }); + it('squeeze accepts a tensor-like object', function () { + var res = tf.squeeze([[[4]], [[2]], [[1]]]); + expect(res.shape).toEqual([3]); + test_util_1.expectArraysClose(res, [4, 2, 1]); + }); + it('scalar -> 2d', function () { + var a = tf.scalar(4, 'int32'); + var b = a.as2D(1, 1); + expect(b.dtype).toBe('int32'); + expect(b.shape).toEqual([1, 1]); + }); + it('1d -> 2d', function () { + var a = tf.tensor1d([4, 2, 1], 'bool'); + var b = a.as2D(3, 1); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([3, 1]); + }); + it('2d -> 4d', function () { + var a = tf.tensor2d([4, 2, 1, 3], [2, 2]); + var b = a.as4D(1, 1, 2, 2); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([1, 1, 2, 2]); + }); + it('3d -> 2d', function () { + var a = tf.tensor3d([4, 2, 1, 3], [2, 2, 1], 'float32'); + var b = a.as2D(2, 2); + expect(b.dtype).toBe('float32'); + expect(b.shape).toEqual([2, 2]); + }); + it('4d -> 1d', function () { + var a = tf.tensor4d([4, 2, 1, 3], [2, 2, 1, 1], 'bool'); + var b = a.as1D(); + expect(b.dtype).toBe('bool'); + expect(b.shape).toEqual([4]); + }); +}); +describe('tensor.toString', function () { + it('scalar verbose', function () { + var verbose = true; + var str = tf.scalar(5).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 0\n' + + ' shape: []\n' + + ' values:\n' + + ' 5'); + }); + it('1d tensor verbose', function () { + var verbose = true; + var str = tf.zeros([4]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 1\n' + + ' shape: [4]\n' + + ' values:\n' + + ' [0, 0, 0, 0]'); + }); + it('2d tensor verbose', function () { + var verbose = true; + var str = tf.zeros([3, 3]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 2\n' + + ' shape: [3,3]\n' + + ' values:\n' + + ' [[0, 0, 0],\n' + + ' [0, 0, 0],\n' + + ' [0, 0, 0]]'); + }); + it('3d tensor verbose', function () { + var verbose = true; + var str = tf.zeros([3, 3, 2]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 3\n' + + ' shape: [3,3,2]\n' + + ' values:\n' + + ' [[[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]],\n\n' + + ' [[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]],\n\n' + + ' [[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]]]'); + }); + it('1d long tensor verbose', function () { + var verbose = true; + var str = tf.zeros([100]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 1\n' + + ' shape: [100]\n' + + ' values:\n' + + ' [0, 0, 0, ..., 0, 0, 0]'); + }); + it('2d long tensor verbose', function () { + var verbose = true; + var str = tf.zeros([100, 100]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 2\n' + + ' shape: [100,100]\n' + + ' values:\n' + + ' [[0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' ...,\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0]]'); + }); + it('2d with padding to align columns verbose', function () { + var verbose = true; + var str = tf.tensor([ + [0.8597712, 3, 0.2740789], [0.6696132, 0.4825962, 2.75], + [1.991, 0.0640865, 0.2983858] + ]).toString(verbose); + expect(str).toEqual('Tensor\n' + + ' dtype: float32\n' + + ' rank: 2\n' + + ' shape: [3,3]\n' + + ' values:\n' + + ' [[0.8597712, 3 , 0.2740789],\n' + + ' [0.6696132, 0.4825962, 2.75 ],\n' + + ' [1.9910001, 0.0640865, 0.2983858]]'); + }); + it('scalar', function () { + var str = tf.scalar(5).toString(); + expect(str).toEqual('Tensor\n' + + ' 5'); + }); + it('1d tensor', function () { + var str = tf.zeros([4]).toString(); + expect(str).toEqual('Tensor\n' + + ' [0, 0, 0, 0]'); + }); + it('2d tensor', function () { + var str = tf.zeros([3, 3]).toString(); + expect(str).toEqual('Tensor\n' + + ' [[0, 0, 0],\n' + + ' [0, 0, 0],\n' + + ' [0, 0, 0]]'); + }); + it('3d tensor', function () { + var str = tf.zeros([3, 3, 2]).toString(); + expect(str).toEqual('Tensor\n' + + ' [[[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]],\n\n' + + ' [[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]],\n\n' + + ' [[0, 0],\n' + + ' [0, 0],\n' + + ' [0, 0]]]'); + }); + it('1d long tensor', function () { + var str = tf.zeros([100]).toString(); + expect(str).toEqual('Tensor\n' + + ' [0, 0, 0, ..., 0, 0, 0]'); + }); + it('2d long tensor', function () { + var str = tf.zeros([100, 100]).toString(); + expect(str).toEqual('Tensor\n' + + ' [[0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' ...,\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0],\n' + + ' [0, 0, 0, ..., 0, 0, 0]]'); + }); + it('2d with padding to align columns', function () { + var str = tf.tensor([ + [0.8597712, 3, 0.2740789], [0.6696132, 0.4825962, 2.75], + [1.991, 0.0640865, 0.2983858] + ]).toString(); + expect(str).toEqual('Tensor\n' + + ' [[0.8597712, 3 , 0.2740789],\n' + + ' [0.6696132, 0.4825962, 2.75 ],\n' + + ' [1.9910001, 0.0640865, 0.2983858]]'); + }); +}); +jasmine_util_1.describeWithFlags('tensor grad', test_util_1.ALL_ENVS, function () { + it('grad with second derivative', function () { + var f = function (x) { return x.pow(tf.scalar(3, 'int32')); }; + var g = tf.grad(f); + var gg = tf.grad(g); + var x = tf.tensor1d([2, 3]); + var data = gg(x); + test_util_1.expectArraysClose(data, [12, 18]); + }); +}); +jasmine_util_1.describeWithFlags('tensor.data', test_util_1.ALL_ENVS, function () { + it('interleaving .data() and .dataSync()', function () { return __awaiter(_this, void 0, void 0, function () { + var a, b, ra, rb, _a, _b, _c; + return __generator(this, function (_d) { + switch (_d.label) { + case 0: + a = tf.tensor1d([1, 2, 3]); + b = tf.tensor1d([4, 5, 6]); + ra = a.square().data(); + rb = b.square().dataSync(); + test_util_1.expectArraysClose(a, [1, 2, 3]); + test_util_1.expectArraysClose(b, [4, 5, 6]); + test_util_1.expectArraysClose(Array.from(rb), [16, 25, 36]); + _a = test_util_1.expectArraysClose; + _c = (_b = Array).from; + return [4, ra]; + case 1: + _a.apply(void 0, [_c.apply(_b, [_d.sent()]), [1, 4, 9]]); + return [2]; + } + }); + }); }); + it('.data() postpones disposal of tensor', function (done) { + expect(tf.memory().numTensors).toBe(0); + tf.tidy(function () { + var a = tf.scalar(5); + expect(tf.memory().numTensors).toBe(1); + a.square(); + a.data().then(function (vals) { + test_util_1.expectNumbersClose(vals[0], 5); + }); + }); + setTimeout(function () { + expect(tf.memory().numTensors).toBe(0); + done(); + }); + }); + it('calling .data() twice works (2 subscribers to a single read)', function (done) { + tf.tidy(function () { + var a = tf.scalar(5); + a.square(); + a.data().then(function (vals) { + test_util_1.expectNumbersClose(vals[0], 5); + }); + a.data() + .then(function (vals) { + test_util_1.expectNumbersClose(vals[0], 5); + }) + .then(done); + }); + }); +}); +jasmine_util_1.describeWithFlags('x instanceof Tensor', test_util_1.ALL_ENVS, function () { + it('x: Tensor', function () { + var t = tf.scalar(1); + expect(t instanceof tensor_1.Tensor).toBe(true); + }); + it('x: Tensor-like', function () { + var t = { shape: [2], dtype: 'float32' }; + expect(t instanceof tensor_1.Tensor).toBe(true); + }); + it('x: other object, fails', function () { + var t = { something: 'else' }; + expect(t instanceof tensor_1.Tensor).toBe(false); + }); + it('x: undefined or null, fails', function () { + expect(undefined instanceof tensor_1.Tensor).toBe(false); + expect(null instanceof tensor_1.Tensor).toBe(false); + }); +}); +//# sourceMappingURL=tensor_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js.map new file mode 100644 index 0000000..11d13d1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_test.js","sourceRoot":"","sources":["../src/tensor_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_types.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.d.ts new file mode 100644 index 0000000..56070b9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.d.ts @@ -0,0 +1,19 @@ +import { Tensor, Variable } from './tensor'; +import { DataType } from './types'; +export declare type NamedTensorMap = { + [name: string]: Tensor; +}; +export declare type NamedVariableMap = { + [name: string]: Variable; +}; +export declare type TensorContainer = void | Tensor | string | number | boolean | TensorContainerObject | TensorContainerArray; +export interface TensorContainerObject { + [x: string]: TensorContainer; +} +export interface TensorContainerArray extends Array { +} +export interface TensorInfo { + name: string; + shape?: number[]; + dtype: DataType; +} diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js new file mode 100644 index 0000000..6c7dba7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=tensor_types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js.map new file mode 100644 index 0000000..f832df6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_types.js","sourceRoot":"","sources":["../src/tensor_types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.d.ts new file mode 100644 index 0000000..301c2cb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.d.ts @@ -0,0 +1,7 @@ +import { Tensor } from './tensor'; +import { NamedTensorMap, TensorContainer } from './tensor_types'; +export declare function assertTypesMatch(a: Tensor, b: Tensor): void; +export declare function isTensorInList(tensor: Tensor, tensorList: Tensor[]): boolean; +export declare function flattenNameArrayMap(nameArrayMap: Tensor | NamedTensorMap, keys?: string[]): Tensor[]; +export declare function unflattenToNameArrayMap(keys: string[], flatArrays: Tensor[]): NamedTensorMap; +export declare function getTensorsInContainer(result: TensorContainer): Tensor[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js new file mode 100644 index 0000000..2941b92 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js @@ -0,0 +1,74 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tensor_1 = require("./tensor"); +var util_1 = require("./util"); +function assertTypesMatch(a, b) { + util_1.assert(a.dtype === b.dtype, " The dtypes of the first(" + a.dtype + ") and" + + (" second(" + b.dtype + ") input must match")); +} +exports.assertTypesMatch = assertTypesMatch; +function isTensorInList(tensor, tensorList) { + for (var i = 0; i < tensorList.length; i++) { + if (tensorList[i].id === tensor.id) { + return true; + } + } + return false; +} +exports.isTensorInList = isTensorInList; +function flattenNameArrayMap(nameArrayMap, keys) { + var xs = []; + if (nameArrayMap instanceof tensor_1.Tensor) { + xs.push(nameArrayMap); + } + else { + var xMap = nameArrayMap; + for (var i = 0; i < keys.length; i++) { + xs.push(xMap[keys[i]]); + } + } + return xs; +} +exports.flattenNameArrayMap = flattenNameArrayMap; +function unflattenToNameArrayMap(keys, flatArrays) { + if (keys.length !== flatArrays.length) { + throw new Error("Cannot unflatten Tensor[], keys and arrays are not of same length."); + } + var result = {}; + for (var i = 0; i < keys.length; i++) { + result[keys[i]] = flatArrays[i]; + } + return result; +} +exports.unflattenToNameArrayMap = unflattenToNameArrayMap; +function getTensorsInContainer(result) { + var list = []; + var seen = new Set(); + walkTensorContainer(result, list, seen); + return list; +} +exports.getTensorsInContainer = getTensorsInContainer; +function walkTensorContainer(container, list, seen) { + if (container == null) { + return; + } + if (container instanceof tensor_1.Tensor) { + list.push(container); + return; + } + if (!isIterable(container)) { + return; + } + var iterable = container; + for (var k in iterable) { + var val = iterable[k]; + if (!seen.has(val)) { + seen.add(val); + walkTensorContainer(val, list, seen); + } + } +} +function isIterable(obj) { + return Array.isArray(obj) || typeof obj === 'object'; +} +//# sourceMappingURL=tensor_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js.map new file mode 100644 index 0000000..de5ef6f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_util.js","sourceRoot":"","sources":["../src/tensor_util.ts"],"names":[],"mappings":";;AAiBA,mCAAgC;AAEhC,+BAA8B;AAE9B,0BAAiC,CAAS,EAAE,CAAS;IACnD,aAAM,CACF,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK,EACnB,8BAA4B,CAAC,CAAC,KAAK,UAAO;SACtC,aAAW,CAAC,CAAC,KAAK,uBAAoB,CAAA,CAAC,CAAC;AAClD,CAAC;AALD,4CAKC;AAED,wBAA+B,MAAc,EAAE,UAAoB;IACjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,EAAE,EAAE;YAClC,OAAO,IAAI,CAAC;SACb;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAPD,wCAOC;AAED,6BACI,YAAmC,EAAE,IAAe;IACtD,IAAM,EAAE,GAAa,EAAE,CAAC;IACxB,IAAI,YAAY,YAAY,eAAM,EAAE;QAClC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;KACvB;SAAM;QACL,IAAM,IAAI,GAAG,YAAyC,CAAC;QACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACxB;KACF;IACD,OAAO,EAAE,CAAC;AACZ,CAAC;AAZD,kDAYC;AAED,iCACI,IAAc,EAAE,UAAoB;IACtC,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,MAAM,EAAE;QACrC,MAAM,IAAI,KAAK,CACX,oEAAoE,CAAC,CAAC;KAC3E;IACD,IAAM,MAAM,GAAmB,EAAE,CAAC;IAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACpC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;KACjC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAXD,0DAWC;AAcD,+BAAsC,MAAuB;IAC3D,IAAM,IAAI,GAAa,EAAE,CAAC;IAC1B,IAAM,IAAI,GAAG,IAAI,GAAG,EAAW,CAAC;IAChC,mBAAmB,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACxC,OAAO,IAAI,CAAC;AACd,CAAC;AALD,sDAKC;AAED,6BACI,SAA0B,EAAE,IAAc,EAAE,IAAkB;IAChE,IAAI,SAAS,IAAI,IAAI,EAAE;QACrB,OAAO;KACR;IACD,IAAI,SAAS,YAAY,eAAM,EAAE;QAC/B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACrB,OAAO;KACR;IACD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;QAC1B,OAAO;KACR;IAED,IAAM,QAAQ,GAAG,SAAiC,CAAC;IACnD,KAAK,IAAM,CAAC,IAAI,QAAQ,EAAE;QACxB,IAAM,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACd,mBAAmB,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;SACtC;KACF;AACH,CAAC;AAGD,oBAAoB,GAAQ;IAC1B,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,OAAO,GAAG,KAAK,QAAQ,CAAC;AACvD,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.d.ts new file mode 100644 index 0000000..8bfc6bd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.d.ts @@ -0,0 +1,4 @@ +import { Tensor } from './tensor'; +import { DataType, TensorLike } from './types'; +export declare function convertToTensor(x: T | TensorLike, argName: string, functionName: string, dtype?: DataType): T; +export declare function convertToTensorArray(arg: T[] | TensorLike[], argName: string, functionName: string): T[]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js new file mode 100644 index 0000000..cdad643 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js @@ -0,0 +1,33 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +var tensor_1 = require("./tensor"); +var util_1 = require("./util"); +function convertToTensor(x, argName, functionName, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + dtype = dtype || 'float32'; + if (x instanceof tensor_1.Tensor) { + return x; + } + if (!util_1.isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' && + typeof x !== 'boolean') { + throw new Error("Argument '" + argName + "' passed to '" + functionName + "' must be a " + + ("Tensor or TensorLike, but got " + x.constructor.name)); + } + var inferredShape = util_1.inferShape(x); + if (!util_1.isTypedArray(x) && !Array.isArray(x)) { + x = [x]; + } + return tensor_1.Tensor.make(inferredShape, { values: util_1.toTypedArray(x, dtype, environment_1.ENV.get('DEBUG')) }, dtype); +} +exports.convertToTensor = convertToTensor; +function convertToTensorArray(arg, argName, functionName) { + if (!Array.isArray(arg)) { + throw new Error("Argument " + argName + " passed to " + functionName + " must be a " + + '`Tensor[]` or `TensorLike[]`'); + } + var tensors = arg; + return tensors.map(function (t, i) { return convertToTensor(t, argName + "[" + i + "]", functionName); }); +} +exports.convertToTensorArray = convertToTensorArray; +//# sourceMappingURL=tensor_util_env.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js.map new file mode 100644 index 0000000..b13580c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_env.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_util_env.js","sourceRoot":"","sources":["../src/tensor_util_env.ts"],"names":[],"mappings":";;AAiBA,6CAAkC;AAClC,mCAAgC;AAEhC,+BAA8D;AAE9D,yBACI,CAAe,EAAE,OAAe,EAAE,YAAoB,EACtD,KAA2B;IAA3B,sBAAA,EAAA,iBAA2B;IAC7B,KAAK,GAAG,KAAK,IAAI,SAAS,CAAC;IAC3B,IAAI,CAAC,YAAY,eAAM,EAAE;QACvB,OAAO,CAAC,CAAC;KACV;IACD,IAAI,CAAC,mBAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ;QAC9D,OAAO,CAAC,KAAK,SAAS,EAAE;QAC1B,MAAM,IAAI,KAAK,CACX,eAAa,OAAO,qBAAgB,YAAY,iBAAc;aAC9D,mCAAiC,CAAC,CAAC,WAAW,CAAC,IAAM,CAAA,CAAC,CAAC;KAC5D;IACD,IAAM,aAAa,GAAG,iBAAU,CAAC,CAAC,CAAC,CAAC;IACpC,IAAI,CAAC,mBAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;QACzC,CAAC,GAAG,CAAC,CAAC,CAAa,CAAC;KACrB;IACD,OAAO,eAAM,CAAC,IAAI,CACd,aAAa,EACb,EAAC,MAAM,EAAE,mBAAY,CAAC,CAAwB,EAAE,KAAK,EAAE,iBAAG,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,EAAC,EACzE,KAAK,CAAC,CAAC;AACb,CAAC;AArBD,0CAqBC;AAED,8BACI,GAAqB,EAAE,OAAe,EAAE,YAAoB;IAC9D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACvB,MAAM,IAAI,KAAK,CACX,cAAY,OAAO,mBAAc,YAAY,gBAAa;YAC1D,8BAA8B,CAAC,CAAC;KACrC;IACD,IAAM,OAAO,GAAG,GAAU,CAAC;IAC3B,OAAO,OAAO,CAAC,GAAG,CACd,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,eAAe,CAAC,CAAC,EAAK,OAAO,SAAI,CAAC,MAAG,EAAE,YAAY,CAAC,EAApD,CAAoD,CAAC,CAAC;AACtE,CAAC;AAVD,oDAUC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js new file mode 100644 index 0000000..0bd2034 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js @@ -0,0 +1,159 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var tensor_util_1 = require("./tensor_util"); +var tensor_util_env_1 = require("./tensor_util_env"); +var test_util_1 = require("./test_util"); +describe('tensor_util.isTensorInList', function () { + it('not in list', function () { + var a = tf.scalar(1); + var list = [tf.scalar(1), tf.tensor1d([1, 2, 3])]; + expect(tensor_util_1.isTensorInList(a, list)).toBe(false); + }); + it('in list', function () { + var a = tf.scalar(1); + var list = [tf.scalar(2), tf.tensor1d([1, 2, 3]), a]; + expect(tensor_util_1.isTensorInList(a, list)).toBe(true); + }); +}); +describe('tensor_util.flattenNameArrayMap', function () { + it('basic', function () { + var a = tf.scalar(1); + var b = tf.scalar(3); + var c = tf.tensor1d([1, 2, 3]); + var map = { a: a, b: b, c: c }; + expect(tensor_util_1.flattenNameArrayMap(map, Object.keys(map))).toEqual([a, b, c]); + }); +}); +describe('tensor_util.unflattenToNameArrayMap', function () { + it('basic', function () { + var a = tf.scalar(1); + var b = tf.scalar(3); + var c = tf.tensor1d([1, 2, 3]); + expect(tensor_util_1.unflattenToNameArrayMap(['a', 'b', 'c'], [ + a, b, c + ])).toEqual({ a: a, b: b, c: c }); + }); +}); +describe('getTensorsInContainer', function () { + it('null input returns empty tensor', function () { + var results = tensor_util_1.getTensorsInContainer(null); + expect(results).toEqual([]); + }); + it('tensor input returns one element tensor', function () { + var x = tf.scalar(1); + var results = tensor_util_1.getTensorsInContainer(x); + expect(results).toEqual([x]); + }); + it('name tensor map returns flattened tensor', function () { + var x1 = tf.scalar(1); + var x2 = tf.scalar(3); + var x3 = tf.scalar(4); + var results = tensor_util_1.getTensorsInContainer({ x1: x1, x2: x2, x3: x3 }); + expect(results).toEqual([x1, x2, x3]); + }); + it('can extract from arbitrary depth', function () { + var container = [ + { x: tf.scalar(1), y: tf.scalar(2) }, + [[[tf.scalar(3)]], { z: tf.scalar(4) }] + ]; + var results = tensor_util_1.getTensorsInContainer(container); + expect(results.length).toBe(4); + }); + it('works with loops in container', function () { + var container = [tf.scalar(1), tf.scalar(2), [tf.scalar(3)]]; + var innerContainer = [container]; + container.push(innerContainer); + var results = tensor_util_1.getTensorsInContainer(container); + expect(results.length).toBe(3); + }); +}); +jasmine_util_1.describeWithFlags('convertToTensor', test_util_1.ALL_ENVS, function () { + it('primitive integer, NaN converts to zero, no error thrown', function () { + var a = function () { return tensor_util_env_1.convertToTensor(NaN, 'a', 'test', 'int32'); }; + expect(a).not.toThrowError(); + var b = tensor_util_env_1.convertToTensor(NaN, 'b', 'test', 'int32'); + expect(b.rank).toBe(0); + expect(b.dtype).toBe('int32'); + test_util_1.expectNumbersClose(b.get(), 0); + }); + it('primitive number', function () { + var a = tensor_util_env_1.convertToTensor(3, 'a', 'test'); + expect(a.rank).toBe(0); + expect(a.dtype).toBe('float32'); + test_util_1.expectNumbersClose(a.get(), 3); + }); + it('primitive integer, NaN converts to zero', function () { + var a = tensor_util_env_1.convertToTensor(NaN, 'a', 'test', 'int32'); + expect(a.rank).toBe(0); + expect(a.dtype).toBe('int32'); + test_util_1.expectNumbersClose(a.get(), 0); + }); + it('primitive boolean, parsed as float', function () { + var a = tensor_util_env_1.convertToTensor(true, 'a', 'test'); + expect(a.rank).toBe(0); + expect(a.dtype).toBe('float32'); + test_util_1.expectNumbersClose(a.get(), 1); + }); + it('primitive boolean, parsed as bool', function () { + var a = tensor_util_env_1.convertToTensor(true, 'a', 'test', 'bool'); + expect(a.rank).toBe(0); + expect(a.dtype).toBe('bool'); + expect(a.get()).toBe(1); + }); + it('array1d', function () { + var a = tensor_util_env_1.convertToTensor([1, 2, 3], 'a', 'test'); + expect(a.rank).toBe(1); + expect(a.dtype).toBe('float32'); + expect(a.shape).toEqual([3]); + test_util_1.expectArraysClose(a, [1, 2, 3]); + }); + it('array2d', function () { + var a = tensor_util_env_1.convertToTensor([[1], [2], [3]], 'a', 'test'); + expect(a.rank).toBe(2); + expect(a.shape).toEqual([3, 1]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [1, 2, 3]); + }); + it('array3d', function () { + var a = tensor_util_env_1.convertToTensor([[[1], [2]], [[3], [4]]], 'a', 'test'); + expect(a.rank).toBe(3); + expect(a.shape).toEqual([2, 2, 1]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('array4d', function () { + var a = tensor_util_env_1.convertToTensor([[[[1]], [[2]]], [[[3]], [[4]]]], 'a', 'test'); + expect(a.rank).toBe(4); + expect(a.shape).toEqual([2, 2, 1, 1]); + expect(a.dtype).toBe('float32'); + test_util_1.expectArraysClose(a, [1, 2, 3, 4]); + }); + it('passing a tensor returns the tensor itself', function () { + var s = tf.scalar(3); + var res = tensor_util_env_1.convertToTensor(s, 'a', 'test'); + expect(res).toBe(s); + }); + it('passing a tensor with casting returns the tensor itself', function () { + var s = tf.scalar(3); + var res = tensor_util_env_1.convertToTensor(s, 'a', 'test', 'bool'); + expect(res).toBe(s); + }); + it('fails to convert a dict to tensor', function () { + expect(function () { return tensor_util_env_1.convertToTensor({}, 'a', 'test'); }) + .toThrowError('Argument \'a\' passed to \'test\' must be a Tensor ' + + 'or TensorLike, but got Object'); + }); + it('fails to convert a string to tensor', function () { + expect(function () { return tensor_util_env_1.convertToTensor('asdf', 'a', 'test'); }) + .toThrowError('Argument \'a\' passed to \'test\' must be a Tensor ' + + 'or TensorLike, but got String'); + }); + it('fails to convert a non-valid shape array to tensor', function () { + var a = [[1, 2], [3], [4, 5, 6]]; + expect(function () { return tensor_util_env_1.convertToTensor(a, 'a', 'test'); }) + .toThrowError('Element arr[1] should have 2 elements, but has 1 elements'); + }); +}); +//# sourceMappingURL=tensor_util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js.map new file mode 100644 index 0000000..095cbb1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tensor_util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tensor_util_test.js","sourceRoot":"","sources":["../src/tensor_util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_env.d.ts b/node_modules/@tensorflow/tfjs-core/dist/test_env.d.ts new file mode 100644 index 0000000..5ff8814 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_env.d.ts @@ -0,0 +1,2 @@ +import './kernels/backend_cpu'; +import './kernels/backend_webgl'; diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_env.js b/node_modules/@tensorflow/tfjs-core/dist/test_env.js new file mode 100644 index 0000000..f9cf81f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_env.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +require("./kernels/backend_cpu"); +require("./kernels/backend_webgl"); +//# sourceMappingURL=test_env.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_env.js.map b/node_modules/@tensorflow/tfjs-core/dist/test_env.js.map new file mode 100644 index 0000000..ba69991 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_env.js.map @@ -0,0 +1 @@ +{"version":3,"file":"test_env.js","sourceRoot":"","sources":["../src/test_env.ts"],"names":[],"mappings":";;AAiBA,iCAA+B;AAC/B,mCAAiC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_node.d.ts b/node_modules/@tensorflow/tfjs-core/dist/test_node.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_node.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_node.js b/node_modules/@tensorflow/tfjs-core/dist/test_node.js new file mode 100644 index 0000000..2c47718 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_node.js @@ -0,0 +1,11 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var jasmine_util_1 = require("./jasmine_util"); +var backend_cpu_1 = require("./kernels/backend_cpu"); +var jasmine = require('jasmine'); +process.on('unhandledRejection', function (e) { throw e; }); +jasmine_util_1.setTestEnvs([{ name: 'node', factory: function () { return new backend_cpu_1.MathBackendCPU(); }, features: {} }]); +var runner = new jasmine(); +runner.loadConfig({ spec_files: ['src/**/*_test.ts'], random: false }); +runner.execute(); +//# sourceMappingURL=test_node.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_node.js.map b/node_modules/@tensorflow/tfjs-core/dist/test_node.js.map new file mode 100644 index 0000000..9519092 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_node.js.map @@ -0,0 +1 @@ +{"version":3,"file":"test_node.js","sourceRoot":"","sources":["../src/test_node.ts"],"names":[],"mappings":";;AAiBA,+CAA2C;AAC3C,qDAAqD;AAErD,IAAM,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;AAEnC,OAAO,CAAC,EAAE,CAAC,oBAAoB,EAAE,UAAA,CAAC,IAAM,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAEpD,0BAAW,CACP,CAAC,EAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,cAAM,OAAA,IAAI,4BAAc,EAAE,EAApB,CAAoB,EAAE,QAAQ,EAAE,EAAE,EAAC,CAAC,CAAC,CAAC;AAEzE,IAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,MAAM,CAAC,UAAU,CAAC,EAAC,UAAU,EAAE,CAAC,kBAAkB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAC,CAAC,CAAC;AACrE,MAAM,CAAC,OAAO,EAAE,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/test_util.d.ts new file mode 100644 index 0000000..a12428c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_util.d.ts @@ -0,0 +1,19 @@ +import { Features } from './environment_util'; +import { Tensor } from './tensor'; +import { TypedArray } from './types'; +export declare const WEBGL_ENVS: Features; +export declare const NODE_ENVS: Features; +export declare const CHROME_ENVS: Features; +export declare const BROWSER_ENVS: Features; +export declare const CPU_ENVS: Features; +export declare const ALL_ENVS: Features; +export declare function expectArraysClose(actual: Tensor | TypedArray | number[], expected: Tensor | TypedArray | number[] | boolean[], epsilon?: number): void; +export interface DoneFn { + (): void; + fail: (message?: Error | string) => void; +} +export declare function expectPromiseToFail(fn: () => Promise<{}>, done: DoneFn): void; +export declare function expectArraysEqual(actual: Tensor | TypedArray | number[], expected: Tensor | TypedArray | number[] | boolean[]): void; +export declare function expectNumbersClose(a: number, e: number, epsilon?: number): void; +export declare function expectValuesInRange(actual: Tensor | TypedArray | number[], low: number, high: number): void; +export declare function expectArrayBuffersEqual(actual: ArrayBuffer, expected: ArrayBuffer): void; diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_util.js b/node_modules/@tensorflow/tfjs-core/dist/test_util.js new file mode 100644 index 0000000..69c5983 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_util.js @@ -0,0 +1,120 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var environment_1 = require("./environment"); +var tensor_1 = require("./tensor"); +var util = require("./util"); +exports.WEBGL_ENVS = { + 'HAS_WEBGL': true +}; +exports.NODE_ENVS = { + 'IS_NODE': true +}; +exports.CHROME_ENVS = { + 'IS_CHROME': true +}; +exports.BROWSER_ENVS = { + 'IS_BROWSER': true +}; +exports.CPU_ENVS = { + 'HAS_WEBGL': false +}; +exports.ALL_ENVS = {}; +function expectArraysClose(actual, expected, epsilon) { + if (epsilon == null) { + epsilon = environment_1.ENV.get('TEST_EPSILON'); + } + if (!(actual instanceof tensor_1.Tensor) && !(expected instanceof tensor_1.Tensor)) { + var aType = actual.constructor.name; + var bType = expected.constructor.name; + if (aType !== bType) { + throw new Error("Arrays are of different type actual: " + aType + " " + + ("vs expected: " + bType)); + } + } + else if (actual instanceof tensor_1.Tensor && expected instanceof tensor_1.Tensor) { + if (actual.dtype !== expected.dtype) { + throw new Error("Arrays are of different type actual: " + actual.dtype + " " + + ("vs expected: " + expected.dtype + ".")); + } + if (!util.arraysEqual(actual.shape, expected.shape)) { + throw new Error("Arrays are of different shape actual: " + actual.shape + " " + + ("vs expected: " + expected.shape + ".")); + } + } + var actualValues; + var expectedValues; + if (actual instanceof tensor_1.Tensor) { + actualValues = actual.dataSync(); + } + else { + actualValues = actual; + } + if (expected instanceof tensor_1.Tensor) { + expectedValues = expected.dataSync(); + } + else { + expectedValues = expected; + } + if (actualValues.length !== expectedValues.length) { + throw new Error("Arrays have different lengths actual: " + actualValues.length + " vs " + + ("expected: " + expectedValues.length + ".\n") + + ("Actual: " + actualValues + ".\n") + + ("Expected: " + expectedValues + ".")); + } + for (var i = 0; i < expectedValues.length; ++i) { + var a = actualValues[i]; + var e = expectedValues[i]; + if (!areClose(a, Number(e), epsilon)) { + throw new Error("Arrays differ: actual[" + i + "] = " + a + ", expected[" + i + "] = " + e + ".\n" + + ("Actual: " + actualValues + ".\n") + + ("Expected: " + expectedValues + ".")); + } + } +} +exports.expectArraysClose = expectArraysClose; +function expectPromiseToFail(fn, done) { + fn().then(function () { return done.fail(); }, function () { return done(); }); +} +exports.expectPromiseToFail = expectPromiseToFail; +function expectArraysEqual(actual, expected) { + return expectArraysClose(actual, expected, 0); +} +exports.expectArraysEqual = expectArraysEqual; +function expectNumbersClose(a, e, epsilon) { + if (epsilon == null) { + epsilon = environment_1.ENV.get('TEST_EPSILON'); + } + if (!areClose(a, e, epsilon)) { + throw new Error("Numbers differ: actual === " + a + ", expected === " + e); + } +} +exports.expectNumbersClose = expectNumbersClose; +function areClose(a, e, epsilon) { + if (isNaN(a) && isNaN(e)) { + return true; + } + if (isNaN(a) || isNaN(e) || Math.abs(a - e) > epsilon) { + return false; + } + return true; +} +function expectValuesInRange(actual, low, high) { + var actualVals; + if (actual instanceof tensor_1.Tensor) { + actualVals = actual.dataSync(); + } + else { + actualVals = actual; + } + for (var i = 0; i < actualVals.length; i++) { + if (actualVals[i] < low || actualVals[i] > high) { + throw new Error("Value out of range:" + actualVals[i] + " low: " + low + ", high: " + high); + } + } +} +exports.expectValuesInRange = expectValuesInRange; +function expectArrayBuffersEqual(actual, expected) { + expect(new Float32Array(actual)).toEqual(new Float32Array(expected)); +} +exports.expectArrayBuffersEqual = expectArrayBuffersEqual; +//# sourceMappingURL=test_util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/test_util.js.map b/node_modules/@tensorflow/tfjs-core/dist/test_util.js.map new file mode 100644 index 0000000..0cc4e11 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/test_util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"test_util.js","sourceRoot":"","sources":["../src/test_util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js b/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js new file mode 100644 index 0000000..39e54ef --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js @@ -0,0 +1,18 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])&&(6===a[0]||2===a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]0;)r=Math.random()*t|0,n=e[--t],e[t]=e[r],e[r]=n}function clamp(e,t,n){return Math.max(e,Math.min(t,n))}function randUniform(e,t){return Math.random()*(t-e)+e}function distSquared(e,t){for(var n=0,r=0;r0,function(){return"Element arr["+n.join("][")+"] should be a primitive, but is an array of "+e.length+" elements"}),assert(e.length===t[0],function(){return"Element arr["+n.join("][")+"] should have "+t[0]+" elements, but has "+e.length+" elements"});for(var r=t.slice(1),o=0;o1;--t)if(e%t==0)return[t,e/t];return[1,e]}function createShuffledIndices(e){for(var t=new Uint32Array(e),n=0;n=n?o():setTimeout(i,s)}};i()})}function inferFromImplicitShape(e,t){for(var n=1,r=-1,o=0;o0)n*=e[o];else if(-1===e[o]){if(-1!==r)throw Error("Shapes can only have 1 implicit size. Found - 1 at dim "+r+" and dim "+o);r=o}else if(e[o]<=0)throw Error("Shapes can not be <= 0. Found "+e[o]+" at dim "+o);if(-1===r){if(t>0&&t!==n)throw Error("Size("+t+") must match the product of shape "+e);return e}if(t%n!=0)throw Error("The implicit shape can't be a fractional number. Got "+t+" / "+n);var a=e.slice();return a[r]=t/n,a}function squeezeShape(e,t){for(var n=[],r=[],o=0,a=0;a1)throw new Error("Can't squeeze axis "+a+" since its dim '"+e[a]+"' is not 1");(null==t[o]||t[o]>a)&&1===e[a]&&(n.push(e[a]),r.push(a)),t[o]<=a&&o++}e[a]>1&&(n.push(e[a]),r.push(a))}return{newShape:n,keptDims:r}}function getTypedArrayFromDType(e,t){var n=null;if(null==e||"float32"===e)n=new Float32Array(t);else if("int32"===e)n=new Int32Array(t);else{if("bool"!==e)throw new Error("Unknown data type "+e);n=new Uint8Array(t)}return n}function checkComputationForNaN(e,t,n){if("float32"===t)for(var r=0;r=0;--r)n[r]=n[r+1]*e[r+1];return n}function toTypedArray(e,t,n){return noConversionNeeded(e,t)?e:(Array.isArray(e)&&(e=flatten(e)),copyTypedArray(e,t,n))}function noConversionNeeded(e,t){return e instanceof Float32Array&&"float32"===t||e instanceof Int32Array&&"int32"===t||e instanceof Uint8Array&&"bool"===t}function makeOnesTypedArray(e,t){for(var n=makeZerosTypedArray(e,t),r=0;r=0;a--){i=(m=e[a]).inputs;var h=[];h.push(m.output);for(c=0;c=0;n--){var r=t[n],o=e[r.output.id];if(null==r.gradient)throw new Error("Cannot compute gradient: gradient function not found for "+r.name+".");var a=r.gradient(o);for(var i in r.inputs){if(!(i in a))throw new Error("Cannot backprop through input "+i+". Available gradients found: "+Object.keys(a)+".");var s=a[i](),u=r.inputs[i];if(!arraysEqual(s.shape,u.shape))throw new Error("Error in gradient for op "+r.name+". The gradient of input '"+i+"' has shape '"+s.shape+"', which does not match the shape of the input '"+u.shape+"'");if(null==e[u.id])e[u.id]=s;else{var l=e[u.id];e[u.id]=l.add(s),l.dispose()}}}}var FORMAT_LIMIT_NUM_VALS=20,FORMAT_NUM_FIRST_LAST_VALS=3,FORMAT_NUM_SIG_DIGITS=7;function tensorToString(e,t,n,r){var o=computeStrides(t),a=computeMaxSizePerColumn(e,t,o),i=t.length,s=subTensorToString(e,t,o,a),u=["Tensor"];return r&&(u.push(" dtype: "+n),u.push(" rank: "+i),u.push(" shape: ["+t+"]"),u.push(" values:")),u.push(s.map(function(e){return" "+e}).join("\n")),u.join("\n")}function computeMaxSizePerColumn(e,t,n){var r=sizeFromShape(t),o=n[n.length-1],a=new Array(o).fill(0);if(t.length>1)for(var i=0;iFORMAT_LIMIT_NUM_VALS){var s=Array.from(e.subarray(0,FORMAT_NUM_FIRST_LAST_VALS)),u=Array.from(e.subarray(a-FORMAT_NUM_FIRST_LAST_VALS,a));return["["+s.map(function(e,t){return valToString(e,r[t])}).join(", ")+", ..., "+u.map(function(e,t){return valToString(e,r[a-FORMAT_NUM_FIRST_LAST_VALS+t])}).join(", ")+"]"]}return["["+Array.from(e).map(function(e,t){return valToString(e,r[t])}).join(", ")+"]"]}var l=t.slice(1),c=n.slice(1),p=n[0],d=[];if(a>FORMAT_LIMIT_NUM_VALS){for(var h=0;h {...}) to avoid memory leaks.");return this.keepTensors.add(e.id),e},e.prototype.startScope=function(e,t){void 0===t&&(t=!1),t&&0===this.gradientScopeCount&&(this.activeTape=[]),t&&this.gradientScopeCount++;var n={track:[],name:"unnamed scope"};e&&(n.name=e),this.scopeStack.push(n),this.activeScope=n},e.prototype.endScope=function(e,t){var n=this;void 0===t&&(t=!1),t&&(this.gradientScopeCount--,0===this.gradientScopeCount&&(this.activeTape=null));var r=new Set(this.keepTensors),o=getTensorsInContainer(e);o.forEach(function(e){return r.add(e.id)});for(var a=0;a0,"gradients() received an empty list of xs."),this.tidy("gradients",function(){var a=e();assert(a instanceof Tensor,"The result y returned by f() must be a tensor.");var i=getFilteredNodesXToY(o.activeTape,t,a);if(!r&&0===i.length&&t.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");var s={};return s[a.id]=null==n?ones(a.shape):n,backpropagateGradients(s,i),{value:a,grads:t.map(function(e){return s[e.id]})}},!0)},e.prototype.customGrad=function(e){var t=this;return assert(isFunction(e),"The f passed in customGrad(f) must be a function."),function(){for(var n,r,o=[],a=0;a {op();...}); to avoid memory leaks.");return this.activeScope.track.push(e),e},e}();function ones(e){var t=makeOnesTypedArray(sizeFromShape(e),"float32");return Tensor.make(e,{values:t})}!function(e){e[e.NUMBER=0]="NUMBER",e[e.BOOLEAN=1]="BOOLEAN",e[e.STRING=2]="STRING"}(Type||(Type={}));var URL_PROPERTIES=[{name:"DEBUG",type:Type.BOOLEAN},{name:"IS_BROWSER",type:Type.BOOLEAN},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",type:Type.NUMBER},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",type:Type.BOOLEAN},{name:"WEBGL_VERSION",type:Type.NUMBER},{name:"WEBGL_RENDER_FLOAT32_ENABLED",type:Type.BOOLEAN},{name:"WEBGL_DOWNLOAD_FLOAT_ENABLED",type:Type.BOOLEAN},{name:"WEBGL_FENCE_API_ENABLED",type:Type.BOOLEAN},{name:"BACKEND",type:Type.STRING}];function isWebGLVersionEnabled(e,t){var n;try{n=getWebGLRenderingContext(e,t)}catch(e){return!1}return null!=n&&(loseContext(n),!0)}function getWebGLDisjointQueryTimerVersion(e,t){if(0===e)return 0;var n,r=getWebGLRenderingContext(e,t);return n=hasExtension(r,"EXT_disjoint_timer_query_webgl2")&&2===e?2:hasExtension(r,"EXT_disjoint_timer_query")?1:0,null!=r&&loseContext(r),n}function isRenderToFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,"OES_texture_float"))return!1}else if(!hasExtension(n,"EXT_color_buffer_float"))return!1;createFloatTextureAndBindToFramebuffer(n,e);var r=n.checkFramebufferStatus(n.FRAMEBUFFER)===n.FRAMEBUFFER_COMPLETE;return loseContext(n),r}function isDownloadFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,"OES_texture_float"))return!1}else if(!hasExtension(n,"EXT_color_buffer_float"))return!1;createFloatTextureAndBindToFramebuffer(n,e),n.readPixels(0,0,1,1,n.RGBA,n.FLOAT,new Float32Array(4));var r=n.getError()===n.NO_ERROR;return loseContext(n),r}function isWebGLFenceEnabled(e,t){if(2!==e)return!1;var n=getWebGLRenderingContext(e,t),r=null!=n.fenceSync;return loseContext(n),r}function isChrome(){return"undefined"!=typeof navigator&&null!=navigator&&null!=navigator.userAgent&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}var TENSORFLOWJS_FLAGS_PREFIX="tfjsflags";function getFeaturesFromURL(){var e={};if("undefined"==typeof window||void 0===window.location)return e;var t=getQueryParams(window.location.search);if(TENSORFLOWJS_FLAGS_PREFIX in t){var n={};t[TENSORFLOWJS_FLAGS_PREFIX].split(",").forEach(function(e){var t=e.split(":"),r=t[0],o=t[1];n[r]=o}),URL_PROPERTIES.forEach(function(t){t.name in n&&(console.log("Setting feature override from URL "+t.name+": "+n[t.name]),t.type===Type.NUMBER?e[t.name]=+n[t.name]:t.type===Type.BOOLEAN?e[t.name]="true"===n[t.name]:t.type===Type.STRING?e[t.name]=n[t.name]:console.warn("Unknown URL param: "+t.name+"."))})}return e}function hasExtension(e,t){return null!=e.getExtension(t)}function getWebGLRenderingContext(e,t){if(0===e||!t)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");var n=document.createElement("canvas");return 1===e?n.getContext("webgl")||n.getContext("experimental-webgl"):n.getContext("webgl2")}function loseContext(e){if(null!=e){var t=e.getExtension("WEBGL_lose_context");if(null==t)throw new Error("Extension WEBGL_lose_context not supported on this browser.");t.loseContext()}}function createFloatTextureAndBindToFramebuffer(e,t){var n=e.createFramebuffer(),r=e.createTexture();e.bindTexture(e.TEXTURE_2D,r);var o=2===t?e.RGBA32F:e.RGBA;e.texImage2D(e.TEXTURE_2D,0,o,1,1,0,e.RGBA,e.FLOAT,null),e.bindFramebuffer(e.FRAMEBUFFER,n),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,r,0)}function getQueryParams(e){var t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,function(e){for(var n=[],r=1;r0?0:getWebGLDisjointQueryTimerVersion(t,this.get("IS_BROWSER"))}if("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE"===e)return this.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!isMobile();if("HAS_WEBGL"===e)return this.get("WEBGL_VERSION")>0;if("WEBGL_VERSION"===e)return isWebGLVersionEnabled(2,this.get("IS_BROWSER"))?2:isWebGLVersionEnabled(1,this.get("IS_BROWSER"))?1:0;if("WEBGL_RENDER_FLOAT32_ENABLED"===e)return isRenderToFloatTextureEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_DOWNLOAD_FLOAT_ENABLED"===e)return isDownloadFloatTextureEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_FENCE_API_ENABLED"===e)return isWebGLFenceEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("TEST_EPSILON"===e)return this.get("WEBGL_RENDER_FLOAT32_ENABLED")?TEST_EPSILON_FLOAT32_ENABLED:TEST_EPSILON_FLOAT32_DISABLED;throw new Error("Unknown feature "+e+".")},e.prototype.setFeatures=function(e){this.features=Object.assign({},e)},e.prototype.reset=function(){this.features=getFeaturesFromURL(),null!=this.globalEngine&&(this.globalEngine=null)},e.prototype.initBackend=function(e,t){var n=this;void 0===t&&(t=!1),this.backendName=e,this.backend=this.findBackend(e),this.globalEngine=new Engine(this.backend,t,function(){return n.get("DEBUG")})},e.prototype.findBackend=function(e){return e in this.registry?this.registry[e].backend:null},e.prototype.registerBackend=function(e,t,n,r){var o=this;if(void 0===n&&(n=1),e in this.registry)return console.warn(e+" backend was already registered. Reusing existing backend"),null!=r&&r(function(){return o.engine}),!1;try{var a=t();return this.registry[e]={backend:a,priority:n},!0}catch(t){return console.warn("Registration of backend "+e+" failed"),console.warn(t.stack||t.message),!1}},e.prototype.removeBackend=function(e){if(!(e in this.registry))throw new Error(e+" backend not found in registry");this.registry[e].backend.dispose(),delete this.registry[e]},Object.defineProperty(e.prototype,"engine",{get:function(){return this.initDefaultBackend(),this.globalEngine},enumerable:!0,configurable:!0}),e.prototype.initDefaultBackend=function(){null==this.globalEngine&&this.initBackend(this.get("BACKEND"),!1)},e}();function getGlobalNamespace(){var e;if("undefined"!=typeof window)e=window;else{if("undefined"==typeof process)throw new Error("Could not find a global object");e=process}return e}function getOrMakeEnvironment(){var e=getGlobalNamespace();return null==e.ENV&&(e.ENV=new Environment(getFeaturesFromURL()),setTensorTracker(function(){return e.ENV.engine})),e.ENV}var ENV=getOrMakeEnvironment(),environment=Object.freeze({Environment:Environment,ENV:ENV});function warn(){for(var e=[],t=0;t=2*t+1||o%2==1?i.push(o):a.push(o);r.push.apply(r,a),r.push(0),r.push.apply(r,i)}return r}function getReshapedPermuted(e,t,n,r){void 0===r&&(r=!0);var o=[];r?o.push(e[0]/n):o.push(e[0]*n);for(var a=1;a=-n&&et||n===e){r=!0;break}n=nearestDivisor(e,n+1)}return n}function computeOutShape(e,t,n){for(var r=[],o=e.length,a=0;a0?o>=s[t]:o<=s[t]);o+=r[t])n+=1;return n}),[i,l]}function startForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MIN_SAFE_INTEGER:Number.MAX_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=clamp(0,a,i-1)}function stopForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MAX_SAFE_INTEGER:Number.MIN_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=n[o]>0?clamp(0,a,i):clamp(-1,a,i-1)}function grad(e){return assert(isFunction(e),"The f passed in grad(f) must be a function"),function(t,n){return assert(t instanceof Tensor,"The x passed in grad(f)(x) must be a tensor"),assert(null==n||n instanceof Tensor,"The dy passed in grad(f)(x, dy) must be a tensor"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"),checkGrads(a),a[0]})}}function grads(e){return assert(isFunction(e),"The f passed in grads(f) must be a function"),function(t,n){return assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),"The args passed in grads(f)(args) must be an array of tensors"),assert(null==n||n instanceof Tensor,"The dy passed in grads(f)(args, dy) must be a tensor"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),checkGrads(a),a})}}function valueAndGrad(e){return assert(isFunction(e),"The f passed in valueAndGrad(f) must be a function"),function(t,n){assert(t instanceof Tensor,"The x passed in valueAndGrad(f)(x) must be a tensor"),assert(null==n||n instanceof Tensor,"The dy passed in valueAndGrad(f)(x, dy) must be a tensor");var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.grads,a=r.value;return checkGrads(o),{grad:o[0],value:a}}}function valueAndGrads(e){return assert(isFunction(e),"The f passed in valueAndGrads(f) must be a function"),function(t,n){assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),"The args passed in valueAndGrads(f)(args) must be array of tensors"),assert(null==n||n instanceof Tensor,"The dy passed in valueAndGrads(f)(args, dy) must be a tensor");var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n);return null!=n&&assertShapesMatch(r.value.shape,n.shape,"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),checkGrads(r.grads),r}}function variableGrads(e,t){if(assert(isFunction(e),"The f passed in variableGrads(f) must be a function"),assert(null==t||Array.isArray(t)&&t.every(function(e){return e instanceof Variable}),"The varList passed in variableGrads(f, varList) must be an array of variables"),null==t)for(var n in t=[],ENV.engine.registeredVariables)t.push(ENV.engine.registeredVariables[n]);var r=t.length;assert((t=t.filter(function(e){return e.trainable})).length>0,"variableGrads() expects at least one of the input variables to be trainable, but none of the "+r+" variables is trainable.");var o=ENV.engine.gradients(e,t,null,!0),a=o.value,i=o.grads;assert(i.some(function(e){return null!=e}),"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),assert(0===a.rank,"The f passed in variableGrads(f) must return a scalar, but it returned a rank-"+a.rank+" tensor");var s={};return t.forEach(function(e,t){null!=i[t]&&(s[e.name]=i[t])}),{value:a,grads:s}}function customGrad(e){return ENV.engine.customGrad(e)}function checkGrads(e){if(e.filter(function(e){return null==e}).length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.")}function convertToTensor(e,t,n,r){if(void 0===r&&(r="float32"),r=r||"float32",e instanceof Tensor)return e;if(!isTypedArray(e)&&!Array.isArray(e)&&"number"!=typeof e&&"boolean"!=typeof e)throw new Error("Argument '"+t+"' passed to '"+n+"' must be a Tensor or TensorLike, but got "+e.constructor.name);var o=inferShape(e);return isTypedArray(e)||Array.isArray(e)||(e=[e]),Tensor.make(o,{values:toTypedArray(e,r,ENV.get("DEBUG"))},r)}function convertToTensorArray(e,t,n){if(!Array.isArray(e))throw new Error("Argument "+t+" passed to "+n+" must be a `Tensor[]` or `TensorLike[]`");return e.map(function(e,r){return convertToTensor(e,t+"["+r+"]",n)})}function op(e){var t=Object.keys(e);if(1!==t.length)throw new Error("Please provide an object with a single key (operation name) mapping to a function. Got an object with "+t.length+" keys.");var n=t[0],r=e[n];n.endsWith("_")&&(n=n.substring(0,n.length-1));var o=function(){for(var e=[],t=0;t1)return zeros([0],r);var o=makeZerosTypedArray(Math.abs(Math.ceil((t-e)/n)),r);to}).sort(function(e,t){return t.score-e.score}),i=[],s=0;s=0;--d){if(intersectionOverUnion(e,c,i[d])>=r){p=!0;break}}if(!p&&(i.push(c),i.length>=n))break}return tensor1d(i,"int32")}function intersectionOverUnion(e,t,n){var r=e.subarray(4*t,4*t+4),o=e.subarray(4*n,4*n+4),a=Math.min(r[0],r[2]),i=Math.min(r[1],r[3]),s=Math.max(r[0],r[2]),u=Math.max(r[1],r[3]),l=Math.min(o[0],o[2]),c=Math.min(o[1],o[3]),p=Math.max(o[0],o[2]),d=Math.max(o[1],o[3]),h=(s-a)*(u-i),f=(p-l)*(d-c);if(h<=0||f<=0)return 0;var m=Math.max(a,l),g=Math.max(i,c),v=Math.min(s,p),y=Math.min(u,d),x=Math.max(v-m,0)*Math.max(y-g,0);return x/(h+f-x)}function topkImpl(e,t,n,r,o){for(var a=t[t.length-1],i=[e.length/a,a],s=i[0],u=i[1],l=getTypedArrayFromDType(n,s*r),c=getTypedArrayFromDType("int32",s*r),p=0;p":"<",u=n?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+r+";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < "+r+"; i++) {\n int inIdx = "+u+";\n float candidate = getA(batch, inIdx);\n if (candidate "+s+" bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "}}(),AvgPool2DBackpropProgram=function(){return function(e){this.variableNames=["dy"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=1/(t*n);this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n const float avgMultiplier = float("+s+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "}}();function getBroadcastDims(e,t){for(var n=e.length,r=[],o=0;o1&&1===i&&r.unshift(a)}return r}function getReductionAxes(e,t){for(var n=[],r=0;r1)&&n.unshift(a)}return n}function broadcastDimsAreOuter(e){for(var t=0;t1&&s>1&&i!==s)throw Error(r);n.unshift(Math.max(i,s))}return n}var BatchNormProgram=function(){return function(e,t,n,r,o,a){this.outputShape=[],this.supportsBroadcasting=!0,this.variableNames=["x","mean","variance"],assertAndGetBroadcastShape(e,t),assertAndGetBroadcastShape(e,n);var i="0.0";null!=r&&(assertAndGetBroadcastShape(e,r),this.variableNames.push("offset"),i="getOffsetAtOutCoords()");var s="1.0";null!=o&&(assertAndGetBroadcastShape(e,o),this.variableNames.push("scale"),s="getScaleAtOutCoords()"),this.outputShape=e,this.userCode="\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = "+i+";\n float scale = "+s+";\n float inv = scale * inversesqrt(variance + float("+a+"));\n setOutput((x - mean) * inv + offset);\n }\n "}}(),CHECK_NAN_SNIPPET="\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n",ADD="return a + b;",SUB="return a - b;",MUL="return a * b;",DIV="if (a == b) return 1.0;\n return a / b;",INT_DIV="\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n",POW="\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n",SQUARED_DIFFERENCE="return (a - b) * (a - b);",EQUAL="return float(a == b);",NOT_EQUAL="return float(a != b);",LESS="return float(a < b);",LESS_EQUAL="return float(a <= b);",GREATER="return float(a > b);",GREATER_EQUAL="return float(a >= b);",LOGICAL_AND="return float(a >= 1.0 && b >= 1.0);",LOGICAL_OR="return float(a >= 1.0 || b >= 1.0);",MAX=CHECK_NAN_SNIPPET+"\n return max(a, b);\n",MIN=CHECK_NAN_SNIPPET+"\n return min(a, b);\n",MOD="if (b == 0.0) return NAN;\n return mod(a, b);",ATAN2=CHECK_NAN_SNIPPET+"\n return atan(a, b);\n",ELU_DER="return (b >= 1.0) ? a : a * (b + 1.0);",BinaryOpProgram=function(){function e(e,t,n){this.variableNames=["A","B"],this.supportsBroadcasting=!0,this.outputShape=assertAndGetBroadcastShape(t,n),this.userCode="\n uniform float NAN;\n float binaryOperation(float a, float b) {\n "+e+"\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "}return e.prototype.getCustomSetupFunc=function(){var e=this;return function(t,n){null==e.startLoc&&(e.startLoc=t.getUniformLocationNoThrow(n,"NAN"),null==e.startLoc)||t.gl.uniform1f(e.startLoc,NaN)}},e}(),ClipProgram=function(){return function(e,t,n){this.variableNames=["A"],this.outputShape=e;var r=t.toFixed(20),o=n.toFixed(20);this.userCode="\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, "+r+", "+o+"));\n }\n "}}();function assertParams(e,t,n){var r=e.length,o=t.length;assert(e.length===t.length,"Error in concat"+r+"D: rank of x1 ("+r+") and x2 ("+o+") must be the same."),assert(n>=0&&n= "+e.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+e.outWidth+"; yC++) {\n int xC = wC + yC * "+n+" - "+o+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Conv2DDerInputProgram=function(){return function(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+t+" - 1 - wR;\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+n+" - 1 - wC;\n\n for (int d2 = 0; d2 < "+e.outChannels+"; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),DepthwiseConv2DDerFilterProgram=function(){return function(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;var t=e.strideHeight,n=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.outChannels/e.inChannels;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * "+a+" + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < "+e.batchSize+"; b++) {\n for (int yR = 0; yR < "+e.outHeight+"; yR++) {\n int xR = wR + yR * "+t+" - "+r+";\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+e.outWidth+"; yC++) {\n int xC = wC + yC * "+n+" - "+o+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),DepthwiseConv2DDerInputProgram=function(){return function(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+t+" - 1 - wR;\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+n+" - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < "+s+"; dm++) {\n int d2 = d1 * "+s+" + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Conv2DProgram=function(){return function(e){this.variableNames=["x","W"],this.outputShape=e.outShape;var t=e.padInfo.top,n=e.padInfo.left,r=e.strideHeight,o=e.strideWidth,a=e.dilationHeight,i=e.dilationWidth,s=e.filterHeight,u=e.filterWidth,l=4*Math.floor(e.inChannels/4),c=e.inChannels%4;this.userCode="\n const ivec2 strides = ivec2("+r+", "+o+");\n const ivec2 pads = ivec2("+t+", "+n+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+s+"; wR++) {\n int xR = xRCorner + wR * "+a+";\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+u+"; wC++) {\n int xC = xCCorner + wC * "+i+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n for (int d1 = 0; d1 < "+l+"; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if ("+(1===c)+") {\n dotProd +=\n getX(batch, xR, xC, "+l+") *\n getW(wR, wC, "+l+", d2);\n } else if ("+(2===c)+") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if ("+(3===c)+") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1),\n getX(batch, xR, xC, "+l+" + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2),\n getW(wR, wC, "+l+" + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),DepthwiseConv2DProgram=function(){return function(e){this.variableNames=["x","W"],this.outputShape=e.outShape;var t=e.inHeight,n=e.inWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.strideHeight,i=e.strideWidth,s=e.dilationHeight,u=e.dilationWidth,l=e.filterHeight,c=e.filterWidth,p=e.outChannels/e.inChannels;this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+r+", "+o+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / "+p+";\n int q = d2 - d1 * "+p+";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < "+l+"; wR++) {\n int xR = xRCorner + wR * "+s+";\n\n if (xR < 0 || xR >= "+t+") {\n continue;\n }\n\n for (int wC = 0; wC < "+c+"; wC++) {\n int xC = xCCorner + wC * "+u+";\n\n if (xC < 0 || xC >= "+n+") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "}}();function makeShader(e,t,n,r){var o=e.map(function(e){var t=sizeFromShape(e.shapeInfo.logicalShape);return e.shapeInfo.isUniform?"uniform float "+e.name+(t>1?"["+t+"]":"")+";":"uniform sampler2D "+e.name+";"});o=o.join("\n");var a=e.map(function(e){return getInputSamplingSnippet(e,t,r)}).join("\n"),i=t.texShape,s=getOutputSamplingSnippet(t.logicalShape,i);return[SHADER_PREFIX,FLOAT_TEXTURE_SAMPLE_SNIPPET,FLOAT_TEXTURE_SETOUTPUT_SNIPPET,o,s,a,n].join("\n")}function getSamplerFromInInfo(e){var t=e.shapeInfo.logicalShape;switch(t.length){case 0:return getSamplerScalar(e);case 1:return getSampler1D(e);case 2:return getSampler2D(e);case 3:return getSampler3D(e);case 4:return getSampler4D(e);case 5:return getSampler5D(e);case 6:return getSampler6D(e);default:throw new Error(t.length+"-D input sampling is not yet supported")}}function getInputSamplingSnippet(e,t,n){var r=getSamplerFlat(e);return r+=getSamplerFromInInfo(e),(n||arraysEqual(e.shapeInfo.logicalShape,t.logicalShape))&&(r+=getSamplerAtOutputCoords(e,t,n)),r}function getOutputSamplingSnippet(e,t){switch(e.length){case 0:return getOutputScalarCoords();case 1:return getOutput1DCoords(e,t);case 2:return getOutput2DCoords(e,t);case 3:return getOutput3DCoords(e,t);case 4:return getOutput4DCoords(e,t);case 5:return getOutput5DCoords(e,t);case 6:return getOutput6DCoords(e,t);default:throw new Error(e.length+"-D output sampling is not yet supported")}}var SAMPLE_1D_SNIPPET="\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_2D_SNIPPET="\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_3D_SNIPPET="\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_4D_SNIPPET="\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_5D_SNIPPET="\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_6D_SNIPPET="\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",FLOAT_TEXTURE_SAMPLE_SNIPPET="\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n",FLOAT_TEXTURE_SETOUTPUT_SNIPPET="\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n",SHADER_PREFIX="\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n "+SAMPLE_1D_SNIPPET+"\n "+SAMPLE_2D_SNIPPET+"\n "+SAMPLE_3D_SNIPPET+"\n "+SAMPLE_4D_SNIPPET+"\n "+SAMPLE_5D_SNIPPET+"\n "+SAMPLE_6D_SNIPPET+"\n";function getOutputScalarCoords(){return"\n int getOutputCoords() {\n return 0;\n }\n "}function getOutput1DCoords(e,t){return 1===t[0]?"\n int getOutputCoords() {\n return int(resultUV.x * "+t[1]+".0);\n }\n ":1===t[1]?"\n int getOutputCoords() {\n return int(resultUV.y * "+t[0]+".0);\n }\n ":"\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n return resTexRC.x * "+t[1]+" + resTexRC.y;\n }\n "}function getOutput3DCoords(e,t){var n=e[1]*e[2],r=e[2];return"\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n int r = index / "+n+";\n index -= r * "+n+";\n int c = index / "+r+";\n int d = index - c * "+r+";\n return ivec3(r, c, d);\n }\n "}function getOutput4DCoords(e,t){var n=e[3],r=e[2]*n,o=e[1]*r;return"\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+o+";\n index -= r * "+o+";\n\n int c = index / "+r+";\n index -= c * "+r+";\n\n int d = index / "+n+";\n int d2 = index - d * "+n+";\n\n return ivec4(r, c, d, d2);\n }\n "}function getOutput5DCoords(e,t){var n=e[4],r=e[3]*n,o=e[2]*r,a=e[1]*o;return"\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2("+t[0]+",\n "+t[1]+"));\n\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+a+";\n index -= r * "+a+";\n\n int c = index / "+o+";\n index -= c * "+o+";\n\n int d = index / "+r+";\n index -= d * "+r+";\n\n int d2 = index / "+n+";\n int d3 = index - d2 * "+n+";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "}function getOutput6DCoords(e,t){var n=e[5],r=e[4]*n,o=e[3]*r,a=e[2]*o,i=e[1]*a;return"\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+i+";\n index -= r * "+i+";\n\n int c = index / "+a+";\n index -= c * "+a+";\n\n int d = index / "+o+";\n index -= d * "+o+";\n\n int d2 = index / "+r+";\n index -= d2 * "+r+";\n\n int d3 = index / "+n+";\n int d4 = index - d3 * "+n+";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "}function getOutput2DCoords(e,t){return arraysEqual(e,t)?"\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2("+t[0]+", "+t[1]+"));\n }\n ":1===e[1]?"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n return ivec2(index, 0);\n }\n ":1===e[0]?"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n return ivec2(0, index);\n }\n ":"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n int r = index / "+e[1]+";\n int c = index - r * "+e[1]+";\n return ivec2(r, c);\n }\n "}function getSamplerScalar(e){var t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1);return e.shapeInfo.isUniform?"float "+n+"() {return "+t+";}":"\n float "+n+"() {\n return sampleTexture("+t+", halfCR);\n }\n "}function getSampler1D(e){var t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1);return"\n float "+n+"(int index) {\n return "+n+"Flat(index);\n }\n "}function getSampler2D(e){var t=e.shapeInfo.logicalShape,n=e.name,r="get"+n.charAt(0).toUpperCase()+n.slice(1),o=e.shapeInfo.texShape;if(null!=o&&arraysEqual(t,o)){var a=o[0];return"\n float "+r+"(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2("+o[1]+".0, "+a+".0);\n return sampleTexture("+n+", uv);\n }\n "}var i=squeezeShape(t),s=i.newShape,u=i.keptDims,l=s;if(l.length=1?"coords = 0;":s.map(function(e){return"coords["+(e+u)+"] = 0;"}).join("\n"))+"\n return get"+n+"("+(a<2&&o>0?"coords":e.shapeInfo.logicalShape.map(function(e,t){return"coords["+(t+u)+"]"}).join(", "))+");\n }\n "}function getSamplerAtOutputCoords(e,t,n){var r=e.name,o=r.charAt(0).toUpperCase()+r.slice(1),a="get"+o+"AtOutCoords",i=getBroadcastDims(e.shapeInfo.logicalShape,t.logicalShape),s=e.shapeInfo.logicalShape.length,u=t.logicalShape.length,l=n&&(u>s||i.length>0),c=broadcastDimsAreOuter(i),p=e.shapeInfo.isUniform;if(l&&!c)return getBroadcastOutputCoordsSampler(e,t,o,a);var d=sizeFromShape(e.shapeInfo.logicalShape),h="";l&&c&&(h="\n int mainPart = index / "+d+";\n index -= mainPart * "+d+";\n ");var f=t.texShape;if(p)return 1===d?"float "+a+"() {return "+r+";}":"\n float "+a+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+f[0]+", "+f[1]+"));\n int index = resTexRC.x * "+f[1]+" + resTexRC.y;\n "+h+"\n return get"+o+"Flat(index);\n }\n ";var m=e.shapeInfo.texShape;return arraysEqual(m,f)?"\n float "+a+"() {\n return sampleTexture("+r+", resultUV);\n }\n ":"\n float "+a+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+f[0]+", "+f[1]+"));\n int index = resTexRC.x * "+f[1]+" + resTexRC.y;\n "+h+"\n int texR = index / "+m[1]+";\n int texC = index - texR * "+m[1]+";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2("+m[1]+".0, "+m[0]+".0);\n\n return sampleTexture("+r+", uv);\n }\n "}function getCoordsDataType(e){if(e<=1)return"int";if(2===e)return"ivec2";if(3===e)return"ivec3";if(4===e)return"ivec4";if(5===e)return"ivec5";if(6===e)return"ivec6";throw Error("GPU for rank "+e+" is not yet supported")}function squeezeInputInfo(e,t){var n=JSON.parse(JSON.stringify(e));return n.shapeInfo.logicalShape=t,n}function getSqueezedParams(e,t){return t.map(function(t){return e[t]}).join(", ")}var CumSumProgram=function(){return function(e,t,n){this.variableNames=["x"],this.outputShape=e;var r=e.length,o=e[e.length-1],a=n?"<":">";this.userCode="\n int getIndex(int i) {\n "+(n?"return "+o+" -i - 1;":"return i;")+"\n }\n\n void main() {\n "+getCoordsDataType(r)+" coords = getOutputCoords();\n int end = "+getFinalCoord(r,"coords")+";\n float val = 0.0;\n for (int i = "+o+" - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx "+a+" end) {\n continue;\n }\n if (idx == end && "+t+") {\n continue;\n }\n "+getFinalCoord(r,"coords")+" = idx;\n val += getX("+getCoords(r,"coords")+");\n }\n setOutput(val);\n }\n "}}();function getCoords(e,t){if(1===e)return""+t;if(2===e)return t+".x, "+t+".y";if(3===e)return t+".x, "+t+".y, "+t+".z";if(4===e)return t+".x, "+t+".y, "+t+".z, "+t+".w";throw Error("Cumulative sum for rank "+e+" is not yet supported")}function getFinalCoord(e,t){if(1===e)return""+t;if(2===e)return t+".y";if(3===e)return t+".z";if(4===e)return t+".w";throw Error("Cumulative sum for rank "+e+" is not yet supported")}var TextureUsage,PhysicalTextureType,EncodeFloatProgram=function(){return function(e){this.variableNames=["A"],this.outputShape=e,this.userCode="\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "}}(),FromPixelsProgram=function(){return function(e){this.variableNames=["A"];var t=e[0],n=e[1];this.outputShape=e,this.userCode="\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2("+n+".0, "+t+".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "}}(),GatherProgram=function(){return function(e,t,n){this.variableNames=["A","indices"];var r=e.slice();r[n]=t,this.outputShape=r,this.rank=r.length;var o=getCoordsDataType(this.rank),a=getSourceCoords(e,n);this.userCode="\n void main() {\n "+o+" resRC = getOutputCoords();\n setOutput(getA("+a+"));\n }\n "}}();function getSourceCoords(e,t){var n=e.length;if(n>4)throw Error("Gather for rank "+n+" is not yet supported");if(1===n)return"int(getIndices(resRC))";for(var r=["resRC.x","resRC.y","resRC.z","resRC.w"],o=[],a=0;a= "+r);for(var o=0,a=0;a= "+r);for(var o=0,a=0;a= "+o);for(var a=getPackedMatrixTextureShapeWidthHeight(t,n),i=a[0],s=a[1],u=n%2==1,l=t%2==1,c=Math.floor(n/2),p=Math.floor(t/2),d=u?4:0,h=n,f=0,m=0;m= "+o);for(var a=n%2==1,i=t%2==1,s=Math.floor(n/2),u=Math.floor(t/2),l=getPackedMatrixTextureShapeWidthHeight(t,n),c=l[0],p=l[1],d=a?4:0,h=n+(a?1:0),f=0,m=0,g=n,v=0;vr||n>r){o="["+t+"x"+n+"]";throw new Error("Requested texture size "+o+" greater than WebGL maximum on this browser / GPU "+("["+r+"x"+r+"]")+".")}}function createFramebuffer(e){return throwIfNull(e,function(){return e.createFramebuffer()},"Unable to create WebGLFramebuffer.")}function bindVertexBufferToProgramAttribute(e,t,n,r,o,a,i){var s=e.getAttribLocation(t,n);return-1!==s&&(callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,r)}),callAndCheck(e,function(){return e.vertexAttribPointer(s,o,e.FLOAT,!1,a,i)}),callAndCheck(e,function(){return e.enableVertexAttribArray(s)}),!0)}function bindTextureUnit(e,t,n){validateTextureUnit(e,n),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)})}function unbindTextureUnit(e,t){validateTextureUnit(e,t),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+t)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function getProgramUniformLocationOrThrow(e,t,n){return throwIfNull(e,function(){return e.getUniformLocation(t,n)},'uniform "'+n+'" not present in program.')}function getProgramUniformLocation(e,t,n){return e.getUniformLocation(t,n)}function bindTextureToProgramUniformSampler(e,t,n,r,o){callAndCheck(e,function(){return bindTextureUnit(e,n,o)}),callAndCheck(e,function(){return e.uniform1i(r,o)})}function bindCanvasToFramebuffer(e){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,null)}),callAndCheck(e,function(){return e.viewport(0,0,e.canvas.width,e.canvas.height)}),callAndCheck(e,function(){return e.scissor(0,0,e.canvas.width,e.canvas.height)})}function bindColorTextureToFramebuffer(e,t,n){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,n)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0)})}function unbindColorTextureFromFramebuffer(e,t){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,t)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0)})}function validateFramebuffer(e){var t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+getFramebufferErrorMessage(e,t))}function getFramebufferErrorMessage(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case e.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return"unknown error "+t}}function throwIfNull(e,t,n){var r=callAndCheck(e,function(){return t()});if(null==r)throw new Error(n);return r}function validateTextureUnit(e,t){var n=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,r=t+e.TEXTURE0;if(rn)throw new Error("textureUnit must be in "+("[gl.TEXTURE0, gl.TEXTURE"+n+"]")+".")}function getTextureShapeFromLogicalShape(e,t){2!==t.length&&(t=squeezeShape(t).newShape);var n=queryMaxTextureSize(e),r=sizeFromShape(t);return t.length<=1&&r<=n?[r,1]:2===t.length&&t[0]<=n&&t[1]<=n?t:3===t.length&&t[0]<=n&&t[1]*t[2]<=n?[t[0],t[1]*t[2]]:4===t.length&&t[0]<=n&&t[1]*t[2]*t[3]<=n?[t[0],t[1]*t[2]*t[3]]:sizeToSquarishShape(r)}var webgl_util=Object.freeze({createWebGLRenderingContext:createWebGLRenderingContext,createWebGLRenderingContextFromCanvas:createWebGLRenderingContextFromCanvas,callAndCheck:callAndCheck,enableDebugWebGLErrorChecking:enableDebugWebGLErrorChecking,checkWebGLError:checkWebGLError,getWebGLErrorMessage:getWebGLErrorMessage,getExtensionOrThrow:getExtensionOrThrow,createVertexShader:createVertexShader,createFragmentShader:createFragmentShader,createProgram:createProgram,linkProgram:linkProgram,validateProgram:validateProgram,createStaticVertexBuffer:createStaticVertexBuffer,createStaticIndexBuffer:createStaticIndexBuffer,queryMaxTextureSize:queryMaxTextureSize,getNumChannels:getNumChannels,createTexture:createTexture,validateTextureSize:validateTextureSize,createFramebuffer:createFramebuffer,bindVertexBufferToProgramAttribute:bindVertexBufferToProgramAttribute,bindTextureUnit:bindTextureUnit,unbindTextureUnit:unbindTextureUnit,getProgramUniformLocationOrThrow:getProgramUniformLocationOrThrow,getProgramUniformLocation:getProgramUniformLocation,bindTextureToProgramUniformSampler:bindTextureToProgramUniformSampler,bindCanvasToFramebuffer:bindCanvasToFramebuffer,bindColorTextureToFramebuffer:bindColorTextureToFramebuffer,unbindColorTextureFromFramebuffer:unbindColorTextureFromFramebuffer,validateFramebuffer:validateFramebuffer,getFramebufferErrorMessage:getFramebufferErrorMessage,getTextureShapeFromLogicalShape:getTextureShapeFromLogicalShape});function getWebGLContextAttributes(){return{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0}}function createWebGLContext(e){var t,n=getWebGLContextAttributes();return callAndCheck(t=null!=e?createWebGLRenderingContextFromCanvas(e,n):createWebGLRenderingContext(n),function(){return t.disable(t.DEPTH_TEST)}),callAndCheck(t,function(){return t.disable(t.STENCIL_TEST)}),callAndCheck(t,function(){return t.disable(t.BLEND)}),callAndCheck(t,function(){return t.disable(t.DITHER)}),callAndCheck(t,function(){return t.disable(t.POLYGON_OFFSET_FILL)}),callAndCheck(t,function(){return t.disable(t.SAMPLE_COVERAGE)}),callAndCheck(t,function(){return t.enable(t.SCISSOR_TEST)}),callAndCheck(t,function(){return t.enable(t.CULL_FACE)}),callAndCheck(t,function(){return t.cullFace(t.BACK)}),t}function createVertexShader$1(e){return createVertexShader(e,"\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }")}function createVertexBuffer(e){return createStaticVertexBuffer(e,new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]))}function createIndexBuffer(e){return createStaticIndexBuffer(e,new Uint16Array([0,1,2,2,1,3]))}function getTextureConfig(e,t){var n,r,o,a,i,s,u,l=e;return 2===ENV.get("WEBGL_VERSION")?(n=l.R32F,r=l.R16F,o=l.RGBA32F,a=l.RED,i=4,s=1,u=l.HALF_FLOAT):(n=e.RGBA,r=e.RGBA,o=l.RGBA,a=e.RGBA,i=4,s=4,u=null!=t?t.HALF_FLOAT_OES:null),{internalFormatFloat:n,internalFormatHalfFloat:r,internalFormatPackedFloat:o,textureFormatFloat:a,downloadTextureFormat:e.RGBA,downloadUnpackNumChannels:i,defaultNumChannels:s,textureTypeHalfFloat:u}}function createAndConfigureTexture(e,t,n,r,o,a){validateTextureSize(e,t,n);var i=createTexture(e),s=e.TEXTURE_2D;return callAndCheck(e,function(){return e.bindTexture(s,i)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MIN_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MAG_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texImage2D(s,0,r,t,n,0,o,a,null)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)}),i}function createFloat32MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,e.FLOAT)}function createFloat16MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,r.textureTypeHalfFloat)}function createUnsignedBytesMatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],e.RGBA,e.RGBA,e.UNSIGNED_BYTE)}function createPackedMatrixTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatPackedFloat,e.RGBA,e.FLOAT)}function bindVertexProgramAttributeStreams(e,t,n){return callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,n)}),bindVertexBufferToProgramAttribute(e,t,"clipSpacePos",n,3,20,0)&&bindVertexBufferToProgramAttribute(e,t,"uv",n,2,20,12)}function uploadPixelDataToTexture(e,t,n){callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadDataToTexture(e,t,n,r,o,a){validateTextureSize(e,n,r),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texSubImage2D(e.TEXTURE_2D,0,0,0,n,r,a,e.FLOAT,o)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadMatrixToTexture(e,t,n,r,o,a,i){var s,u=getUnpackedMatrixTextureShapeWidthHeight(n,r),l=u[0],c=u[1];1===i.defaultNumChannels?s=o:encodeMatrixToUnpackedArray(o,s=new Float32Array(getUnpackedArraySizeFromMatrixSize(o.length,a)),a),uploadDataToTexture(e,t,l,c,s,i.textureFormatFloat)}function uploadMatrixToPackedTexture(e,t,n,r,o,a){var i=getPackedMatrixTextureShapeWidthHeight(n,r),s=i[0],u=i[1],l=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(n,r));encodeMatrixToPackedRGBA(o,n,r,l),uploadDataToTexture(e,t,s,u,l,e.RGBA)}function maybeCreateBufferFromOutputTexture(e,t,n,r,o){var a=t;if(2===ENV.get("WEBGL_VERSION")){var i=e,s=i.createBuffer();callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,s)});var u=4*getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels);callAndCheck(e,function(){return e.bufferData(i.PIXEL_PACK_BUFFER,u,e.STATIC_DRAW)}),callAndCheck(e,function(){return i.readPixels(0,0,r,n,e.RGBA,e.FLOAT,0)}),callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,null)}),a=s}return a}function downloadFloat32MatrixFromBuffer(e,t,n,r,o){var a=e,i=new Float32Array(getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels));a.bindBuffer(e.ARRAY_BUFFER,t),a.getBufferSubData(e.ARRAY_BUFFER,0,i),a.bindBuffer(e.ARRAY_BUFFER,null);var s=new Float32Array(n*r);return decodeMatrixFromUnpackedArray(i,s,o.downloadUnpackNumChannels),s}function downloadFloat32MatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getUnpackedArraySizeFromMatrixSize(t*n,r.downloadUnpackNumChannels));callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromUnpackedArray(s,u,r.downloadUnpackNumChannels),u}function downloadByteEncodedFloatMatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Uint8Array(getUnpackedArraySizeFromMatrixSize(t*n,4));return callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.UNSIGNED_BYTE,s)}),new Float32Array(s.buffer)}function downloadMatrixFromPackedOutputTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(t,n));callAndCheck(e,function(){return e.readPixels(0,0,a,i,e.RGBA,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromPackedRGBA(s,t,n,u)}var gpgpu_util=Object.freeze({getWebGLContextAttributes:getWebGLContextAttributes,createWebGLContext:createWebGLContext,createVertexShader:createVertexShader$1,createVertexBuffer:createVertexBuffer,createIndexBuffer:createIndexBuffer,getTextureConfig:getTextureConfig,createFloat32MatrixTexture:createFloat32MatrixTexture,createFloat16MatrixTexture:createFloat16MatrixTexture,createUnsignedBytesMatrixTexture:createUnsignedBytesMatrixTexture,createPackedMatrixTexture:createPackedMatrixTexture,bindVertexProgramAttributeStreams:bindVertexProgramAttributeStreams,uploadPixelDataToTexture:uploadPixelDataToTexture,uploadMatrixToTexture:uploadMatrixToTexture,uploadMatrixToPackedTexture:uploadMatrixToPackedTexture,maybeCreateBufferFromOutputTexture:maybeCreateBufferFromOutputTexture,downloadFloat32MatrixFromBuffer:downloadFloat32MatrixFromBuffer,downloadFloat32MatrixFromOutputTexture:downloadFloat32MatrixFromOutputTexture,downloadByteEncodedFloatMatrixFromOutputTexture:downloadByteEncodedFloatMatrixFromOutputTexture,downloadMatrixFromPackedOutputTexture:downloadMatrixFromPackedOutputTexture}),GPGPUContext=function(){function e(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.autoDebugValidate=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[],this.gl=null!=e?e:createWebGLContext(),1===ENV.get("WEBGL_VERSION")?(this.textureFloatExtension=getExtensionOrThrow(this.gl,"OES_texture_float"),this.colorBufferFloatExtension=this.gl.getExtension("WEBGL_color_buffer_float"),ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")||(this.textureHalfFloatExtension=getExtensionOrThrow(this.gl,"OES_texture_half_float"),this.colorBufferHalfFloatExtension=this.gl.getExtension("EXT_color_buffer_half_float"))):this.colorBufferFloatExtension=getExtensionOrThrow(this.gl,"EXT_color_buffer_float"),this.loseContextExtension=getExtensionOrThrow(this.gl,"WEBGL_lose_context"),this.vertexBuffer=createVertexBuffer(this.gl),this.indexBuffer=createIndexBuffer(this.gl),this.framebuffer=createFramebuffer(this.gl),this.textureConfig=getTextureConfig(this.gl,this.textureHalfFloatExtension)}return e.prototype.dispose=function(){var e=this;if(!this.disposed){null!=this.program&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),null!=this.outputTexture&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");var t=this.gl;callAndCheck(t,function(){return t.finish()}),callAndCheck(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,null)}),callAndCheck(t,function(){return t.deleteFramebuffer(e.framebuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.vertexBuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.indexBuffer)}),this.loseContextExtension.loseContext(),this.disposed=!0}},e.prototype.enableAutomaticDebugValidation=function(e){this.autoDebugValidate=e,enableDebugWebGLErrorChecking(e)},e.prototype.createFloat32MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat32MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createFloat16MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat16MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createUnsignedBytesMatrixTexture=function(e,t){return this.throwIfDisposed(),createUnsignedBytesMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.uploadPixelDataToTexture=function(e,t){this.throwIfDisposed(),uploadPixelDataToTexture(this.gl,e,t)},e.prototype.createPackedMatrixTexture=function(e,t){return this.throwIfDisposed(),createPackedMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.deleteMatrixTexture=function(e){var t=this;this.throwIfDisposed(),this.outputTexture===e&&(unbindColorTextureFromFramebuffer(this.gl,this.framebuffer),this.outputTexture=null),callAndCheck(this.gl,function(){return t.gl.deleteTexture(e)})},e.prototype.uploadMatrixToTexture=function(e,t,n,r){this.throwIfDisposed();var o=getNumChannels();return uploadMatrixToTexture(this.gl,e,t,n,r,o,this.textureConfig)},e.prototype.uploadMatrixToPackedTexture=function(e,t,n,r){return this.throwIfDisposed(),uploadMatrixToPackedTexture(this.gl,e,t,n,r,this.textureConfig)},e.prototype.downloadFloat32MatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadFloat32MatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadByteEncodedFloatMatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadByteEncodedFloatMatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadFloat32MatrixFromBuffer=function(e,t,n){return downloadFloat32MatrixFromBuffer(this.gl,e,t,n,this.textureConfig)},e.prototype.maybeCreateBufferFromTexture=function(e,t,n){this.bindTextureToFrameBuffer(e);var r=maybeCreateBufferFromOutputTexture(this.gl,e,t,n,this.textureConfig);return this.unbindTextureToFrameBuffer(),r},e.prototype.createAndWaitForFence=function(){var e=this.createFence(this.gl);return this.pollFence(e)},e.prototype.createFence=function(e){var t,n,r=this;if(ENV.get("WEBGL_FENCE_API_ENABLED")){var o=e,a=o.fenceSync(o.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),n=function(){var e=o.clientWaitSync(a,0,0);return e===o.ALREADY_SIGNALED||e===o.CONDITION_SATISFIED},t=a}else ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(t=this.beginQuery(),this.endQuery(),n=function(){return r.isQueryAvailable(t,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}):n=function(){return!0};return{query:t,isFencePassed:n}},e.prototype.downloadMatrixFromPackedTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadMatrixFromPackedOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.createProgram=function(e){this.throwIfDisposed();var t=this.gl,n=createFragmentShader(t,e),r=createVertexShader$1(t),o=createProgram(t);return callAndCheck(t,function(){return t.attachShader(o,r)}),callAndCheck(t,function(){return t.attachShader(o,n)}),linkProgram(t,o),this.autoDebugValidate&&validateProgram(t,o),this.vertexAttrsAreBound||(this.setProgram(o),this.vertexAttrsAreBound=bindVertexProgramAttributeStreams(t,this.program,this.vertexBuffer)),o},e.prototype.deleteProgram=function(e){var t=this;this.throwIfDisposed(),e===this.program&&(this.program=null),null!=e&&callAndCheck(this.gl,function(){return t.gl.deleteProgram(e)})},e.prototype.setProgram=function(e){var t=this;this.throwIfDisposed(),this.program=e,null!=this.program&&this.autoDebugValidate&&validateProgram(this.gl,this.program),callAndCheck(this.gl,function(){return t.gl.useProgram(e)})},e.prototype.getUniformLocation=function(e,t,n){return void 0===n&&(n=!0),this.throwIfDisposed(),n?getProgramUniformLocationOrThrow(this.gl,e,t):getProgramUniformLocation(this.gl,e,t)},e.prototype.getAttributeLocation=function(e,t){var n=this;return this.throwIfDisposed(),callAndCheck(this.gl,function(){return n.gl.getAttribLocation(e,t)})},e.prototype.getUniformLocationNoThrow=function(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)},e.prototype.setInputMatrixTexture=function(e,t,n){this.throwIfDisposed(),this.throwIfNoProgram(),bindTextureToProgramUniformSampler(this.gl,this.program,e,t,n)},e.prototype.setOutputMatrixTexture=function(e,t,n){this.setOutputMatrixTextureDriver(e,n,t)},e.prototype.setOutputPackedMatrixTexture=function(e,t,n){this.throwIfDisposed();var r=getPackedMatrixTextureShapeWidthHeight(t,n),o=r[0],a=r[1];this.setOutputMatrixTextureDriver(e,o,a)},e.prototype.setOutputMatrixWriteRegion=function(e,t,n,r){this.setOutputMatrixWriteRegionDriver(n,e,r,t)},e.prototype.setOutputPackedMatrixWriteRegion=function(e,t,n,r){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")},e.prototype.debugValidate=function(){null!=this.program&&validateProgram(this.gl,this.program),validateFramebuffer(this.gl)},e.prototype.executeProgram=function(){this.throwIfDisposed(),this.throwIfNoProgram();var e=this.gl;this.autoDebugValidate&&this.debugValidate(),callAndCheck(e,function(){return e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)})},e.prototype.blockUntilAllProgramsCompleted=function(){var e=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return e.gl.finish()})},e.prototype.getQueryTimerExtension=function(){return null==this.disjointQueryTimerExtension&&(this.disjointQueryTimerExtension=getExtensionOrThrow(this.gl,2===ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension},e.prototype.getQueryTimerExtensionWebGL2=function(){return this.getQueryTimerExtension()},e.prototype.getQueryTimerExtensionWebGL1=function(){return this.getQueryTimerExtension()},e.prototype.beginQuery=function(){if(2===ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var e=this.gl,t=this.getQueryTimerExtensionWebGL2(),n=e.createQuery();return e.beginQuery(t.TIME_ELAPSED_EXT,n),n}var r=this.getQueryTimerExtensionWebGL1(),o=r.createQueryEXT();return r.beginQueryEXT(r.TIME_ELAPSED_EXT,o),o},e.prototype.endQuery=function(){if(2!==ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}else{var t=this.gl,n=this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT)}},e.prototype.waitForQueryAndGetTime=function(e){return __awaiter(this,void 0,void 0,function(){var t=this;return __generator(this,function(n){switch(n.label){case 0:return[4,repeatedTry(function(){return t.isQueryAvailable(e,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))})];case 1:return n.sent(),[2,this.getQueryTime(e,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))]}})})},e.prototype.getQueryTime=function(e,t){if(0===t)return null;if(2===t){var n=this.gl;return n.getQueryParameter(e,n.QUERY_RESULT)/1e6}var r=this.getQueryTimerExtensionWebGL1();return r.getQueryObjectEXT(e,r.QUERY_RESULT_EXT)/1e6},e.prototype.isQueryAvailable=function(e,t){if(0===t)return!0;if(2===t){var n=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=n.getQueryParameter(e,n.QUERY_RESULT_AVAILABLE);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}o=(r=this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(e,r.QUERY_RESULT_AVAILABLE_EXT);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint},e.prototype.pollFence=function(e){var t=this;return new Promise(function(n){t.addItemToPoll(function(){return e.isFencePassed()},function(){return n()})})},e.prototype.pollItems=function(){for(var e=binSearchLastTrue(this.itemsToPoll.map(function(e){return e.isDoneFn})),t=0;t<=e;++t){(0,this.itemsToPoll[t].resolveFn)()}this.itemsToPoll=this.itemsToPoll.slice(e+1)},e.prototype.addItemToPoll=function(e,t){var n=this;this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),this.itemsToPoll.length>1||repeatedTry(function(){return n.pollItems(),0===n.itemsToPoll.length})},e.prototype.bindTextureToFrameBuffer=function(e){this.throwIfDisposed(),bindColorTextureToFramebuffer(this.gl,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)},e.prototype.unbindTextureToFrameBuffer=function(){null!=this.outputTexture?(bindColorTextureToFramebuffer(this.gl,this.outputTexture,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)):unbindColorTextureFromFramebuffer(this.gl,this.framebuffer)},e.prototype.downloadMatrixDriver=function(e,t){this.bindTextureToFrameBuffer(e);var n=t();return this.unbindTextureToFrameBuffer(),n},e.prototype.setOutputMatrixTextureDriver=function(e,t,n){this.throwIfDisposed();var r=this.gl;bindColorTextureToFramebuffer(r,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(r),this.outputTexture=e,callAndCheck(r,function(){return r.viewport(0,0,t,n)}),callAndCheck(r,function(){return r.scissor(0,0,t,n)})},e.prototype.setOutputMatrixWriteRegionDriver=function(e,t,n,r){var o=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return o.gl.scissor(e,t,n,r)})},e.prototype.throwIfDisposed=function(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")},e.prototype.throwIfNoProgram=function(){if(null==this.program)throw new Error("No GPU program is currently set.")},e}();function binSearchLastTrue(e){for(var t=0,n=e.length-1,r=-1;t<=n;){var o=t+n>>1;e[o]()?(r=o,t=o+1):n=o-1}return r}function compileProgram(e,t,n,r){for(var o=t.userCode,a=n.map(function(e,n){var r={logicalShape:e.tensor.shape,texShape:e.isUniform?null:e.texData.texShape,isUniform:e.isUniform};return{name:t.variableNames[n],shapeInfo:r}}),i=a.map(function(e){return e.shapeInfo}),s={logicalShape:r.tensor.shape,texShape:r.texData.texShape,isUniform:!1},u=makeShader(a,s,o,!0===t.supportsBroadcasting),l=e.createProgram(u),c={},p=0;p= 0 && idx <= "+s+") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * "+a+";\n setOutput(val);\n }\n "}}(),LRNGradProgram=function(){return function(e,t,n,r,o){this.variableNames=["inputImage","outputImage","dy"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=t,this.bias=n,this.alpha=r,this.beta=o,this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < "+this.depth+"; ++d) {\n int depthBegin = int(max(0.0, float(d - "+t+")));\n int depthEnd = int(min(float("+this.depth+"),\n float(d + "+t+" + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = "+this.depth+";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float("+r+") * norm + float("+n+");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float("+r+")\n * float("+o+")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * "+o+");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "}}(),MaxPool2DBackpropProgram=function(){return function(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=t*n-1;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = "+s+" - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * "+n+" + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "}}(),MatMulProgram=function(){return function(e,t,n,r){void 0===n&&(n=!1),void 0===r&&(r=!1),this.variableNames=["matrixA","matrixB"];var o=n?e[1]:e[0],a=r?t[0]:t[1],i=n?e[0]:e[1];this.outputShape=[o,a];var s=function(e,t){return n?t+" + "+e+", aRow":"aRow, "+t+" + "+e},u=function(e,t){return r?"bCol, "+t+" + "+e:t+" + "+e+", bCol"},l=4*Math.floor(i/4),c=i%4;this.userCode=" float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < "+l+"; i += 4) {\n vec4 a = vec4(\n getMatrixA("+s(0,"i")+"),\n getMatrixA("+s(1,"i")+"),\n getMatrixA("+s(2,"i")+"),\n getMatrixA("+s(3,"i")+")\n );\n vec4 b = vec4(\n getMatrixB("+u(0,"i")+"),\n getMatrixB("+u(1,"i")+"),\n getMatrixB("+u(2,"i")+"),\n getMatrixB("+u(3,"i")+")\n );\n\n result += dot(a, b);\n }\n\n if ("+(1===c)+") {\n result += getMatrixA("+s(0,l)+") *\n getMatrixB("+u(0,l)+");\n } else if ("+(2===c)+") {\n vec2 a = vec2(\n getMatrixA("+s(0,l)+"),\n getMatrixA("+s(1,l)+")\n );\n vec2 b = vec2(\n getMatrixB("+u(0,l)+"),\n getMatrixB("+u(1,l)+")\n );\n result += dot(a, b);\n } else if ("+(3===c)+") {\n vec3 a = vec3(\n getMatrixA("+s(0,l)+"),\n getMatrixA("+s(1,l)+"),\n getMatrixA("+s(2,l)+")\n );\n vec3 b = vec3(\n getMatrixB("+u(0,l)+"),\n getMatrixB("+u(1,l)+"),\n getMatrixB("+u(2,l)+")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "}}(),MultinomialProgram=function(){function e(e,t,n){this.variableNames=["probs"],this.outputShape=[e,n],this.userCode="\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < "+(t-1)+"; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float("+(t-1)+"));\n }\n "}return e.prototype.getCustomSetupFunc=function(e){var t=this;return function(n,r){null==t.seedLoc&&(t.seedLoc=n.getUniformLocation(r,"seed")),n.gl.uniform1f(t.seedLoc,e)}},e}(),OneHotProgram=function(){return function(e,t,n,r){this.variableNames=["indices"],this.outputShape=[e,t],this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float("+r+"), float("+n+"),\n float(index == coords.y)));\n }\n "}}(),PadProgram=function(){return function(e,t,n){this.variableNames=["x"],this.outputShape=t.map(function(t,n){return t[0]+e[n]+t[1]});var r=e.length,o=getCoordsDataType(r),a=t.map(function(e){return e[0]}).join(","),i=t.map(function(t,n){return t[0]+e[n]}).join(","),s=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r);this.userCode=1!==r?"\n "+o+" start = "+o+"("+a+");\n "+o+" end = "+o+"("+i+");\n\n void main() {\n "+o+" outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float("+n+"));\n } else {\n "+o+" coords = outC - start;\n setOutput(getX("+s+"));\n }\n }\n ":"\n int start = "+a+";\n int end = "+i+";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float("+n+"));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "}}(),Pool2DProgram=function(){return function(e,t,n){if(this.variableNames=["x"],"avg"===t&&n)throw new Error("Cannot compute positions for average pool.");var r=e.filterHeight,o=e.filterWidth,a=e.strideHeight,i=e.strideWidth,s=e.padInfo.top,u=e.padInfo.left;this.outputShape=e.outShape;var l="avg"===t,c="0.0";if(l||(c="-1.0 / 0.0"),n)this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+s+", "+u+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < "+r+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+o+"; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value >= currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * "+o+" + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n ";else{var p=t+"("+t+"("+t+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"avg"===t&&(p="avgValue / count");var d=4*Math.floor(o/4),h=o%4,f="\n if ("+l+") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = max(values, minMaxValue);\n }\n ";this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+s+", "+u+");\n const float initializationValue = "+c+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= "+e.inWidth+") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4("+c+");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < "+r+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+d+"; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n "+f+"\n }\n\n int xC = xCCorner + "+d+";\n if ("+(1===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+f+"\n } else if ("+(2===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n "+f+"\n } else if ("+(3===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n "+f+"\n }\n }\n setOutput("+p+");\n }\n "}}}(),ReduceProgram=function(){return function(e,t){this.variableNames=["x"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=Math.ceil(o/n);this.outputShape=[r,a];var i="0.0",s="";"min"===t?(i="1.0 / 0.0",s="min"):"max"===t&&(i="-1.0 / 0.0",s="max");var u=t+"("+t+"("+t+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"sum"===t?u="sumValue":"all"===t?u="allValue":"any"===t&&(u="anyValue");var l=4*Math.floor(n/4),c=n%4,p="\n if ("+("sum"===t)+") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = "+s+"(values, minMaxValue);\n }\n ",d="vec4";"all"===t?(i="1.0",p="\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n ",d="bvec4"):"any"===t&&(i="0.0",p="\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n ",d="bvec4");var h="";o%n>0&&(h="\n if (inIdx < 0 || inIdx >= "+o+") {\n return initializationValue;\n }\n "),this.userCode="\n const float initializationValue = "+i+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n "+h+"\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+n+";\n\n vec4 minMaxValue = vec4("+i+");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < "+l+"; i += 4) {\n int inIdx = inOffset + i;\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n "+p+"\n }\n\n int inIdx = inOffset + "+l+";\n if ("+(1===c)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+p+"\n } else if ("+(2===c)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n "+p+"\n } else if ("+(3===c)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n "+p+"\n }\n setOutput("+u+");\n }\n "}}(),ResizeBilinearBackpropProgram=function(){return function(e,t,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+p+");\n const float widthScale = float("+d+");\n\n const float invHeightScale = float("+h+");\n const float invWidthScale = float("+f+");\n\n const int winHeight = int("+m+");\n const int winWidth = int("+g+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+s+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+u+") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), "+(o-1)+".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), "+(a-1)+".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "}}(),ResizeBilinearProgram=function(){return function(e,t,n,r){this.variableNames=["A"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n];this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+u[0]/l[0]+",\n "+u[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+a+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "}}(),ResizeNearestNeigborBackpropProgram=function(){return function(e,t,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+p+");\n const float widthScale = float("+d+");\n\n const float invHeightScale = float("+h+");\n const float invWidthScale = float("+f+");\n\n const int winHeight = int("+m+");\n const int winWidth = int("+g+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+s+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+u+") {\n continue;\n }\n\n float sourceFracRow =\n float("+l[0]+") *\n (float(dyR) / float("+c[0]+"));\n\n float sourceFracCol =\n float("+l[1]+") *\n (float(dyC) / float("+c[1]+"));\n\n int sourceNearestRow = int(min(\n float(int("+o+") - 1),\n "+n+" ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int("+a+") - 1),\n "+n+" ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "}}(),ResizeNearestNeighborProgram=function(){return function(e,t,n,r){this.variableNames=["A"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n],c=r?"0.5":"0.0";this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+u[0]/l[0]+",\n "+u[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+a+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + "+c+")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "}}(),ReverseProgram=function(){return function(e,t){this.variableNames=["x"];var n=e.length;if(n>4)throw new Error("WebGL backend: Reverse of rank-"+n+" tensor is not yet supported");if(this.outputShape=e,1!==n){var r=e.map(function(n,r){return function(n){return-1!==t.indexOf(n)&&1!==e[n]?e[n]+" - coords["+n+"] - 1":"coords["+n+"]"}(r)}).join(","),o=getCoordsDataType(n);this.userCode="\n void main() {\n "+o+" coords = getOutputCoords();\n setOutput(getX("+r+"));\n }\n "}else this.userCode="\n void main() {\n int coord = getOutputCoords();\n setOutput(getX("+e[0]+" - coord - 1));\n }\n "}}(),SegmentOpProgram=function(){return function(e,t){this.variableNames=["x","segmentIds"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=e.numSegments,i=a*Math.ceil(o/n);this.outputShape=[r,i];var s=4*Math.floor(n/4),u=n%4,l="\n sumValue += dot(values, filter);\n ",c="";o%n>0&&(c="\n if (inIdx < 0 || inIdx >= "+o+") {\n return initializationValue;\n }\n ");var p="";o%n>0&&(p="\n if (inIdx < 0 || inIdx >= "+o+") {\n return -1.0;\n }\n "),this.userCode="\n const float initializationValue = 0.0;\n\n float getValue(int batch, int inIdx) {\n "+c+"\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n "+p+"\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n "+a+")) * float("+n+"));\n int currentSeg = int(mod(float(outIdx), float("+a+")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < "+s+"; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n "+l+"\n }\n\n int inIdx = inOffset + "+s+";\n if ("+(1===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(2===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(3===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n "+l+"\n }\n setOutput(sumValue);\n }\n "}}(),SelectProgram=function(){return function(e,t,n){var r,o;if(this.variableNames=["c","a","b"],this.outputShape=t,n>4)throw Error("Where for rank "+n+" is not yet supported");if(1===n)o="resRC",r="resRC";else{for(var a=["resRC.x","resRC.y","resRC.z","resRC.w"],i=[],s=[],u=0;u= 1.0) {\n setOutput(getA("+o+"));\n } else {\n setOutput(getB("+o+"));\n }\n }\n "}}(),SliceProgram=function(){function e(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;var t=getCoordsDataType(this.rank),n=getCoords$1(this.rank);this.userCode="\n uniform "+t+" start;\n\n void main() {\n "+t+" sourceLoc = start + getOutputCoords();\n setOutput(getSource("+n+"));\n }\n "}return e.prototype.getCustomSetupFunc=function(e){var t=this;if(e.length!==this.rank)throw Error("The rank ("+this.rank+") of the program must match the length of start ("+e.length+")");return function(n,r){if(null!=t.startLoc||(t.startLoc=n.getUniformLocationNoThrow(r,"start"),null!=t.startLoc))if(1===t.rank)n.gl.uniform1i(t.startLoc,e[0]);else if(2===t.rank)n.gl.uniform2i(t.startLoc,e[0],e[1]);else if(3===t.rank)n.gl.uniform3i(t.startLoc,e[0],e[1],e[2]);else{if(4!==t.rank)throw Error("Slicing for rank "+t.rank+" is not yet supported");n.gl.uniform4i(t.startLoc,e[0],e[1],e[2],e[3])}}},e}();function getCoords$1(e){if(1===e)return"sourceLoc";if(2===e)return"sourceLoc.x, sourceLoc.y";if(3===e)return"sourceLoc.x, sourceLoc.y, sourceLoc.z";if(4===e)return"sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w";throw Error("Slicing for rank "+e+" is not yet supported")}var StridedSliceProgram=function(){return function(e,t,n){this.variableNames=["x"],this.outputShape=n,this.rank=n.length;var r=getCoordsDataType(this.rank),o="";o=1===this.rank?"coords * strides + begin":n.map(function(e,t){return"coords["+t+"] * strides["+t+"] + begin["+t+"]"}).join(","),this.userCode="\n "+r+" begin = "+r+"("+e+");\n "+r+" strides = "+r+"("+t+");\n\n void main() {\n "+r+" coords = getOutputCoords();\n setOutput(getX("+o+"));\n }\n "}}(),TextureManager=function(){function e(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}return e.prototype.acquireTexture=function(e,t){var n,r=getPhysicalFromLogicalTextureType(t),o=getKeyFromTextureShape(e,r);if(o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]),this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this.log();var a=this.freeTextures[o].shift();return this.usedTextures[o].push(a),a}return this.numUsedTextures++,this.log(),r===PhysicalTextureType.FLOAT32?n=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):r===PhysicalTextureType.FLOAT16?n=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):r===PhysicalTextureType.UNSIGNED_BYTE&&(n=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[o].push(n),n},e.prototype.releaseTexture=function(e,t,n){var r=getKeyFromTextureShape(t,getPhysicalFromLogicalTextureType(n));r in this.freeTextures||(this.freeTextures[r]=[]),this.freeTextures[r].push(e),this.numFreeTextures++,this.numUsedTextures--;var o=this.usedTextures[r],a=o.indexOf(e);if(a<0)throw new Error("Cannot release a texture that was never provided by this texture manager");o.splice(a,1),this.log()},e.prototype.log=function(){if(this.logEnabled){var e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",this.numFreeTextures+" / "+this.numUsedTextures,"("+e+")")}},e.prototype.getNumUsedTextures=function(){return this.numUsedTextures},e.prototype.getNumFreeTextures=function(){return this.numFreeTextures},e.prototype.dispose=function(){var e=this;if(null!=this.freeTextures){for(var t in this.freeTextures)this.freeTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});for(var t in this.usedTextures)this.usedTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0}},e}();function getPhysicalFromLogicalTextureType(e){if(e===TextureUsage.DOWNLOAD||e===TextureUsage.PIXELS)return PhysicalTextureType.UNSIGNED_BYTE;if(e===TextureUsage.UPLOAD)return PhysicalTextureType.FLOAT32;if(e===TextureUsage.RENDER)return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")?PhysicalTextureType.FLOAT32:PhysicalTextureType.FLOAT16;throw new Error("Unknown logical texture type "+e)}function getKeyFromTextureShape(e,t){return e[0]+"_"+e[1]+"_"+t}var TileProgram=function(){return function(e,t){this.variableNames=["A"];for(var n=new Array(e.length),r=0;r5)throw Error("Tile for rank "+t+" is not yet supported");if(1===t)return"imod(resRC, "+e[0]+")";for(var n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],r=[],o=0;o6)throw Error("Transpose for rank "+t+" is not yet supported");for(var n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u","resRC.v"],r=new Array(t),o=0;o= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n";function STEP(e){return void 0===e&&(e=0),CHECK_NAN_SNIPPET$1+"\n return x > 0.0 ? 1.0 : float("+e+");\n "}var NEG="return -x;",CEIL="return ceil(x);",FLOOR="return floor(x);",SIGN="\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n",ROUND="\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n",EXP="return exp(x);",EXPM1="return exp(x) - 1.0;",LOG="if (x < 0.0) return NAN;\n return log(x);",LOG1P="return log(1.0 + x);",SQRT="return sqrt(x);",RSQRT="return inversesqrt(x);",SIGMOID="return 1.0 / (1.0 + exp(-1.0 * x));",SOFTPLUS="\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n",SIN=CHECK_NAN_SNIPPET$1+"\n return sin(x);\n",COS=CHECK_NAN_SNIPPET$1+"\n return cos(x);\n",TAN="return tan(x);",ASIN="return asin(x);",ACOS="return acos(x);",ATAN=CHECK_NAN_SNIPPET$1+"\n return atan(x);\n",SINH="\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n",COSH="\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n",TANH="\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n",ASINH="return log(x + sqrt(x * x + 1.0));",ACOSH=CHECK_NAN_SNIPPET$1+"\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));",ATANH=CHECK_NAN_SNIPPET$1+"\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;",ERF='\n // Error function is calculated approximately with elementary function.\n // See "Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables", Abramowitz and Stegun.\n float p = '+ERF_P+";\n float a1 = "+ERF_A1+";\n float a2 = "+ERF_A2+";\n float a3 = "+ERF_A3+";\n float a4 = "+ERF_A4+";\n float a5 = "+ERF_A5+";\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n",SQUARE="return x * x;",RECIPROCAL="return 1.0 / x;",LOGICAL_NOT="return float(!(x >= 1.0));",TO_INT="return float(int(x));";function concat1d_(e){return concat(e,0)}function concat2d_(e,t){return concat(e,t)}function concat3d_(e,t){return concat(e,t)}function concat4d_(e,t){return concat(e,t)}function concat_(e,t){void 0===t&&(t=0),assert(e.length>=1,"Pass at least one tensor to concat");var n=convertToTensorArray(e,"tensors","concat"),r=n[0];if(1===n.length)return r;for(var o=parseAxisParam(t,r.shape),a=1;a>>0,t=(r*=t)>>>0,t+=4294967296*(r-=t)}return 2.3283064365386963e-10*(t>>>0)});n.next=function(){var e=2091639*n.s0+2.3283064365386963e-10*n.c;return n.s0=n.s1,n.s1=n.s2,n.s2=e-(n.c=0|e)},n.c=1,n.s0=r(" "),n.s1=r(" "),n.s2=r(" "),n.s0-=r(e),n.s0<0&&(n.s0+=1),n.s1-=r(e),n.s1<0&&(n.s1+=1),n.s2-=r(e),n.s2<0&&(n.s2+=1),r=null}(e),o=t&&t.state,a=n.next;return a.int32=function(){return 4294967296*n.next()|0},a.double=function(){return a()+1.1102230246251565e-16*(2097152*a()|0)},a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.alea=o}(0,e,!1)}),xor128=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t}function o(e,t){var n=new function(e){var t=this,n="";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor128=o}(0,e,!1)}),xorwow=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n="";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,t.v=0,e===(0|e)?t.x=e:n+=e;for(var r=0;r>>4),t.next()}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorwow=o}(0,e,!1)}),xorshift7=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x.slice(),t.i=e.i,t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.x,o=t.i;return e=r[o],n=(e^=e>>>7)^e<<24,n^=(e=r[o+1&7])^e>>>10,n^=(e=r[o+3&7])^e>>>3,n^=(e=r[o+4&7])^e<<7,e=r[o+7&7],n^=(e^=e<<13)^e<<9,r[o]=n,t.i=o+1&7,n},function(e,t){var n,r=[];if(t===(0|t))r[0]=t;else for(t=""+t,n=0;n0;--n)e.next()}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.x&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorshift7=o}(0,e,!1)}),xor4096=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.w,o=t.X,a=t.i;return t.w=r=r+1640531527|0,n=o[a+34&127],e=o[a=a+1&127],n^=n<<13,e^=e<<17,n^=n>>>15,e^=e>>>12,n=o[a]=n^e,t.i=a,n+(r^r>>>16)|0},function(e,t){var n,r,o,a,i,s=[],u=128;for(t===(0|t)?(r=t,t=null):(t+="\0",r=0,u=Math.max(u,t.length)),o=0,a=-32;a>>15,r^=r<<4,r^=r>>>13,a>=0&&(i=i+1640531527|0,o=0==(n=s[127&a]^=r+i)?o+1:0);for(o>=128&&(s[127&(t&&t.length||0)]=-1),o=127,a=512;a>0;--a)r=s[o+34&127],n=s[o=o+1&127],r^=r<<13,n^=n<<17,r^=r>>>15,n^=n>>>12,s[o]=r^n;e.w=i,e.X=s,e.i=o}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.X&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor4096=o}(0,e,!1)}),tychei=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n="";t.next=function(){var e=t.b,n=t.c,r=t.d,o=t.a;return e=e<<25^e>>>7^n,n=n-r|0,r=r<<24^r>>>8^o,o=o-e|0,t.b=e=e<<20^e>>>12^n,t.c=n=n-r|0,t.d=r<<16^n>>>16^o,t.a=o-e|0},t.a=0,t.b=0,t.c=-1640531527,t.d=1367130551,e===Math.floor(e)?(t.a=e/4294967296|0,t.b=0|e):n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.tychei=o}(0,e,!1)}),seedrandom=createCommonjsModule(function(e){!function(t,n){var r,o=this,a=256,i=6,s="random",u=n.pow(a,i),l=n.pow(2,52),c=2*l,p=a-1;function d(e,d,g){var v=[],y=f(function e(t,n){var r,o=[],a=typeof t;if(n&&"object"==a)for(r in t)try{o.push(e(t[r],n-1))}catch(e){}return o.length?o:"string"==a?t:t+"\0"}((d=1==d?{entropy:!0}:d||{}).entropy?[e,m(t)]:null==e?function(){try{var e;return r&&(e=r.randomBytes)?e=e(a):(e=new Uint8Array(a),(o.crypto||o.msCrypto).getRandomValues(e)),m(e)}catch(e){var n=o.navigator,i=n&&n.plugins;return[+new Date,o,i,o.screen,m(t)]}}():e,3),v),x=new function(e){var t,n=e.length,r=this,o=0,i=r.i=r.j=0,s=r.S=[];n||(e=[n++]);for(;o=c;)e/=2,t/=2,n>>>=1;return(e+n)/t};return T.int32=function(){return 0|x.g(4)},T.quick=function(){return x.g(4)/4294967296},T.double=T,f(m(x.S),t),(d.pass||g||function(e,t,r,o){return o&&(o.S&&h(o,x),e.state=function(){return h(x,{})}),r?(n[s]=e,t):e})(T,y,"global"in d?d.global:this==n,d.state)}function h(e,t){return t.i=e.i,t.j=e.j,t.S=e.S.slice(),t}function f(e,t){for(var n,r=e+"",o=0;o=1||0===i);var s=Math.sqrt(-2*Math.log(i)/i);t=this.mean+this.stdDev*o*s,n=this.mean+this.stdDev*a*s,this.truncated&&!this.isValidTruncated(t)||(r=!0)}return this.truncated&&!this.isValidTruncated(n)||(this.nextVal=this.convertValue(n)),this.convertValue(t)},e.prototype.convertValue=function(e){return null==this.dtype||"float32"===this.dtype?e:Math.round(e)},e.prototype.isValidTruncated=function(e){return e<=this.upper&&e>=this.lower},e}();function clone_(e){var t=convertToTensor(e,"x","clone");return ENV.engine.runKernel(function(e){return Tensor.make(t.shape,{dataId:t.dataId},t.dtype)},{$x:t},function(e){return{$x:function(){return e.toFloat()}}})}function eye_(e,t,n,r){void 0===r&&(r="float32"),null==t&&(t=e);for(var o=buffer([e,t],r),a=e<=t?e:t,i=0;i2)throw new Error("Rank of probabilities must be 1 or 2, but is "+i);n=n||Math.random();var s=1===i?o.as2D(1,-1):o,u=ENV.engine.runKernel(function(e){return e.multinomial(s,r,t,n)},{logits2D:s});return 1===i?u.as1D():u}function oneHot_(e,t,n,r){void 0===n&&(n=1),void 0===r&&(r=0);var o=convertToTensor(e,"indices","oneHot","int32");if(assert("int32"===o.dtype,"Indices must be of dtype `int32`"),t<2)throw new Error("Error in oneHot: depth must be >=2, but it is "+t);return ENV.engine.runKernel(function(e){return e.oneHot(o,t,n,r)},{$indices:o})}function fromPixels_(e,t){if(void 0===t&&(t=3),t>4)throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");return ENV.engine.fromPixels(e,t)}function toPixels(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,o,a,i,s,u,l,c,p,d,h,f,m,g,v,y,x,T,S;return __generator(this,function(b){switch(b.label){case 0:if(2!==(n=convertToTensor(e,"img","toPixels","int32")).rank&&3!==n.rank)throw new Error("toPixels only supports rank 2 or 3 tensors, got rank "+n.rank+".");if(r=n.shape.slice(0,2),o=r[0],a=r[1],(i=2===n.rank?1:n.shape[2])>4||2===i)throw new Error("toPixels only supports depth of size 1, 3 or 4 but got "+i);return s=n.min(),u=n.max(),[4,s.data()];case 1:return l=b.sent()[0],[4,u.data()];case 2:if(c=b.sent()[0],s.dispose(),u.dispose(),"float32"===n.dtype){if(l<0||c>1)throw new Error("Tensor values for a float32 Tensor must be in the range [0 - 1] but got range ["+l+" - "+c+"].")}else{if("int32"!==n.dtype)throw new Error("Unsupported type for toPixels: "+n.dtype+". Please use float32 or int32 tensors.");if(l<0||c>255)throw new Error("Tensor values for a int32 Tensor must be in the range [0 - 255] but got range ["+l+" - "+c+"].")}return[4,n.data()];case 3:for(p=b.sent(),d="float32"===n.dtype?255:1,h=new Uint8ClampedArray(a*o*4),f=0;f=1,"Pass at least one tensor to tf.stack"),1===n.length)return n[0].expandDims(t);var r=n[0].rank,o=n[0].shape,a=n[0].dtype;assert(t<=r,"Axis must be <= rank of the tensor"),n.forEach(function(e){assertShapesMatch(o,e.shape,"All tensors passed to stack must have matching shapes")}),n.forEach(function(e){assert(a===e.dtype,"All tensors passed to stack must have matching dtypes")});var i=n.map(function(e){return e.expandDims(t)});return concat(i,t)}function batchToSpaceND_(e,t,n){var r=convertToTensor(e,"x","batchToSpaceND"),o=t.reduce(function(e,t){return e*t});return assert(r.rank>=1+t.length,"input rank should be > than [blockShape] but got "+r.rank),assert(n.length===t.length,"crops.shape[0] must be equal to [blockShape] but got "+n.length),assert(r.shape[0]%o==0,"input tensor batch must be divisible by prod( blockShape )"),ENV.engine.runKernel(function(e){return e.batchToSpaceND(r,t,n)},{})}function spaceToBatchND_(e,t,n){var r=convertToTensor(e,"x","spaceToBatchND");return assert(r.rank>=1+t.length,"input rank should be > than [blockShape] but got "+r.rank),assert(n.length===t.length,"paddings.shape[0] must be equal to [blockShape], got "+n.length),assert(r.shape.reduce(function(e,n,r){return r>0&&r<=t.length?e&&n%t[r-1]==0:e},!0),"input spatial dimensions must be divisible by blockShapes"),ENV.engine.runKernel(function(e){return e.spaceToBatchND(r,t,n)},{})}function unstack_(e,t){void 0===t&&(t=0);for(var n,r=convertToTensor(e,"x","unstack"),o=r.shape[t],a=Array(r.rank-1).fill(0),i=0,s=0;s0?this.gpgpu.beginQuery():{startMs:performance.now(),endMs:null}},e.prototype.endTimer=function(e){return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(this.gpgpu.endQuery(),e):(e.endMs=performance.now(),e)},e.prototype.getQueryTime=function(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?[2,this.gpgpu.waitForQueryAndGetTime(e)]:[2,(t=e).endMs-t.startMs]})})},e.prototype.disposeData=function(e){if(!this.pendingDisposal.has(e))if(this.pendingRead.has(e))this.pendingDisposal.add(e);else if(this.texData.has(e)){var t=this.texData.get(e),n=t.texture,r=t.texShape,o=t.usage;null!=n&&this.releaseTexture(e,n,r,o),this.texData.delete(e)}},e.prototype.getTexture=function(e){return this.uploadToGPU(e),this.texData.get(e).texture},e.prototype.getGPGPUContext=function(){return this.gpgpu},e.prototype.getCanvas=function(){return this.canvas},e.prototype.slice=function(e,t,n){var r=new SliceProgram(n),o=r.getCustomSetupFunc(t);return this.compileAndRun(r,[e],null,o)},e.prototype.stridedSlice=function(e,t,n,r,o,a){var i=getStridedSlicedInfo(e.shape,t,n,r,o,a),s=i[0],u=i[1];if(u.some(function(e){return 0===e}))return tensor([],u);var l=new StridedSliceProgram(s,r,u);return this.compileAndRun(l,[e])},e.prototype.reverse=function(e,t){var n=new ReverseProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.concat=function(e,t){var n=new ConcatProgram(e.shape,t.shape);return this.compileAndRun(n,[e,t])},e.prototype.neg=function(e){var t=new UnaryOpProgram(e.shape,NEG);return this.compileAndRun(t,[e])},e.prototype.matMul=function(e,t,n,r){var o=new MatMulProgram(e.shape,t.shape,n,r);return this.compileAndRun(o,[e,t])},e.prototype.multiply=function(e,t){var n=new BinaryOpProgram(MUL,e.shape,t.shape),r=this.makeOutputArray(n.outputShape,upcastType(e.dtype,t.dtype));return this.compileAndRun(n,[e,t],r)},e.prototype.batchNormalization=function(e,t,n,r,o,a){var i=[e,t,n],s=null;null!=a&&(s=a.shape,i.push(a));var u=null;null!=o&&(u=o.shape,i.push(o));var l=new BatchNormProgram(e.shape,t.shape,n.shape,s,u,r);return this.compileAndRun(l,i)},e.prototype.localResponseNormalization4D=function(e,t,n,r,o){var a=new LRNProgram(e.shape,t,n,r,o);return this.compileAndRun(a,[e])},e.prototype.LRNGrad=function(e,t,n,r,o,a,i){var s=new LRNGradProgram(t.shape,r,o,a,i);return this.compileAndRun(s,[t,n,e])},e.prototype.tile=function(e,t){var n=new TileProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.pad=function(e,t,n){var r=new PadProgram(e.shape,t,n);return this.compileAndRun(r,[e])},e.prototype.transpose=function(e,t){var n=new TransposeProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.gather=function(e,t,n){var r=new GatherProgram(e.shape,t.size,n);return this.compileAndRun(r,[e,t])},e.prototype.batchToSpaceND=function(e,t,n){assert(e.rank<=4,"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");var r=t.reduce(function(e,t){return e*t}),o=getReshaped(e.shape,t,r),a=getPermuted(o.length,t.length),i=getReshapedPermuted(e.shape,t,r),s=getSliceBeginCoords(n,t.length),u=getSliceSize(i,n,t.length);return e.reshape(o).transpose(a).reshape(i).slice(s,u)},e.prototype.spaceToBatchND=function(e,t,n){assert(e.rank<=4,"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");var r=t.reduce(function(e,t){return e*t}),o=[[0,0]];o.push.apply(o,n);for(var a=1+t.length;athis.NUM_BYTES_BEFORE_PAGING)for(var d=this.numBytesInGPU-this.NUM_BYTES_BEFORE_PAGING;d>0&&this.lruDataGPU.length>0;){var h=this.lruDataGPU.shift(),f=this.texData.get(h),m=f.shape,g=f.dtype;d-=this.computeBytes(m,g),this.read(h)}return p&&(s=this.endTimer(s),this.activeTimers.push(this.getQueryTime(s))),n},e.prototype.getAndSaveBinary=function(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]},e.prototype.getTextureManager=function(){return this.textureManager},e.prototype.dispose=function(){if(!this.disposed){for(var e in this.binaryCache)this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram);this.textureManager.dispose(),this.canvas.remove(),null!=this.fromPixelsCanvas&&this.fromPixelsCanvas.remove(),this.gpgpuCreatedLocally&&this.gpgpu.dispose(),this.disposed=!0}},e.prototype.throwIfNoData=function(e){if(!this.texData.has(e))throw new Error("WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends")},e.prototype.uploadToGPU=function(e){this.throwIfNoData(e);var t=this.texData.get(e),n=t.shape,r=t.values,o=t.texture,a=t.dtype,i=t.usage;if(null==o){var s,u=null!=this.activeTimers;u&&(s=performance.now());var l=getTextureShapeFromLogicalShape(this.gpgpu.gl,n);t.texShape=l;var c=this.acquireTexture(e,l,i);t.texture=c,null!=r&&(this.gpgpu.uploadMatrixToTexture(c,l[0],l[1],typedArrayToFloat32(r,a)),t.values=null,u&&(this.uploadWaitMs+=performance.now()-s))}else{this.lruDataGPU.indexOf(e)>=0&&(this.lruDataGPU.splice(this.lruDataGPU.indexOf(e),1),this.lruDataGPU.push(e))}},e.prototype.cacheOnCPU=function(e,t){var n=this.delayedStorage,r=this.texData.get(e),o=r.texture,a=r.texShape,i=r.dtype,s=r.usage;n&&null!=o&&(this.releaseTexture(e,o,a,s),r.texture=null,r.texShape=null),null!=t&&(r.values=float32ToTypedArray(t,i))},e.prototype.releaseTexture=function(e,t,n,r){var o=this.texData.get(e),a=o.shape,i=o.dtype,s=this.lruDataGPU.indexOf(e);s>=0&&this.lruDataGPU.splice(s,1),this.numBytesInGPU-=this.computeBytes(a,i),this.textureManager.releaseTexture(t,n,r)},e.prototype.acquireTexture=function(e,t,n){var r=this.texData.get(e),o=r.shape,a=r.dtype;return this.lruDataGPU.push(e),this.numBytesInGPU+=this.computeBytes(o,a),this.textureManager.acquireTexture(t,n)},e.prototype.computeBytes=function(e,t){return sizeFromShape(e)*bytesPerElement(t)},e}();function float32ToTypedArray(e,t){if("float32"===t)return e;if("int32"===t||"bool"===t){for(var n="int32"===t?new Int32Array(e.length):new Uint8Array(e.length),r=0;r=0?e:(assert(-1===e,"Bad value in size"),a.shape[t]-r[t])}),assertParamsValid(a,r,o);var i=a.shape;return ENV.engine.runKernel(function(e){return e.slice(a,r,o)},{$x:a},function(e){for(var t=[],n=0;n0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.reshape(r.shape)}}})}function addN_(e){assert(Array.isArray(e),function(){return"The param passed to tf.addN() must be a list of tensors"}),assert(e.length>=1,function(){return"Must pass at least one tensor to tf.addN(), but got "+e.length});var t=e.map(function(e,t){return convertToTensor(e,"tensors"+t,"addN")}),n=t[0];t.forEach(function(e){if(e.dtype!==n.dtype)throw new Error("All tensors passed to tf.addN() must have the same dtype")}),t.forEach(function(e){if(!arraysEqual(e.shape,n.shape))throw new Error("All tensors passed to tf.addN() must have the same shape")});var r=t;return ENV.engine.runKernel(function(e){return e.addN(t)},r,function(e){var n={};return t.forEach(function(t,r){n[r]=function(){return e.clone()}}),n})}function addStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in addStrict: "),e.add(t)}function sub_(e,t){var n=convertToTensor(e,"a","sub"),r=convertToTensor(t,"b","sub");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.subtract(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e,r=getReductionAxes(n.shape,o);return r.length>0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.neg().reshape(r.shape)}}})}function subStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in subStrict: "),e.sub(t)}function pow_(e,t){var n=convertToTensor(e,"base","pow"),r=convertToTensor(t,"exp","pow"),o=assertAndGetBroadcastShape(n.shape,r.shape);e=n.cast(upcastType(n.dtype,r.dtype)),t=r.cast(upcastType(n.dtype,r.dtype));return ENV.engine.runKernel(function(e,t){return t(e.pow(n,r))},{$base:n,$exp:r},function(e,t){var a=t[0];return{$base:function(){var t=e.mul(r.toFloat().mul(a.div(n))),i=getReductionAxes(n.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(n.shape)},$exp:function(){var t=e.mul(a.mul(n.log()).toFloat()),i=getReductionAxes(r.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(r.shape)}}})}function powStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in powStrict: "),e.pow(t)}function mul_(e,t){var n=convertToTensor(e,"a","mul"),r=convertToTensor(t,"b","mul");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.multiply(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.mul(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function mulStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in multiplyStrict: "),e.mul(t)}function div_(e,t){var n,r=convertToTensor(e,"a","div"),o=convertToTensor(t,"b","div");if(assertTypesMatch(r,o),"int32"===r.dtype&&"int32"===o.dtype)return floorDiv(r,o);n=function(e){return e.realDivide(r,o)};var a=assertAndGetBroadcastShape(r.shape,o.shape);return ENV.engine.runKernel(n,{$a:r,$b:o},function(e){return{$a:function(){var t=e.div(o.toFloat()),n=getReductionAxes(r.shape,a);return n.length>0?t.sum(n).reshape(r.shape):t},$b:function(){var t=e.mul(r.toFloat()),n=getReductionAxes(o.shape,a);n.length>0&&(t=t.sum(n).reshape(o.shape));var i=o.square();return t.div(i.toFloat()).neg()}}})}function floorDiv_(e,t){var n=convertToTensor(e,"a","floorDiv"),r=convertToTensor(t,"b","floorDiv");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.floorDiv(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.div(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);a.length>0&&(t=t.sum(a).reshape(r.shape));var i=r.square();return t.div(i.toFloat()).neg()}}})}function divStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in divideStrict: "),e.div(t)}function mod_(e,t){var n=convertToTensor(e,"a","mod"),r=convertToTensor(t,"b","mod");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.mod(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=getReductionAxes(n.shape,o);return t.length>0?e.sum(t).reshape(n.shape):e},$b:function(){var t=e.mul(n.div(r).floor().neg()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function modStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in modStrict: "),e.mod(t)}function minimum_(e,t){var n=convertToTensor(e,"a","minimum"),r=convertToTensor(t,"b","minimum");assertTypesMatch(n,r),"bool"===n.dtype&&(n=n.toInt()),"bool"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.minimum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.lessEqual(r).toFloat())},$b:function(){return e.mul(n.greater(r).toFloat())}}})}function minimumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in minimumStrict: "),e.minimum(t)}function maximum_(e,t){var n=convertToTensor(e,"a","maximum"),r=convertToTensor(t,"b","maximum");assertTypesMatch(n,r),"bool"===n.dtype&&(n=n.toInt()),"bool"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.maximum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.greaterEqual(r).toFloat())},$b:function(){return e.mul(n.less(r).toFloat())}}})}function maximumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in minimumStrict: "),e.maximum(t)}function squaredDifference_(e,t){var n=convertToTensor(e,"a","squaredDifference"),r=convertToTensor(t,"b","squaredDifference");assertTypesMatch(n,r),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.squaredDifference(n,r)},{$a:n,$b:r},function(e){var t=scalar(2);return{$a:function(){return e.mul(n.sub(r).mul(t))},$b:function(){return e.mul(r.sub(n).mul(t))}}})}function squaredDifferenceStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in squaredDifferenceStrict: "),e.squaredDifference(t)}function atan2_(e,t){var n=convertToTensor(e,"a","atan2"),r=convertToTensor(t,"b","atan2");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.atan2(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=add(n.square(),r.square()),a=e.mul(r.div(t)),i=getReductionAxes(n.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(n.shape)},$b:function(){var t=add(n.square(),r.square()),a=neg(e.mul(n.div(t))),i=getReductionAxes(r.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(r.shape)}}})}var add=op({add_:add_}),addN=op({addN_:addN_}),addStrict=op({addStrict_:addStrict_}),atan2=op({atan2_:atan2_}),div=op({div_:div_}),divStrict=op({divStrict_:divStrict_}),floorDiv=op({floorDiv_:floorDiv_}),maximum=op({maximum_:maximum_}),maximumStrict=op({maximumStrict_:maximumStrict_}),minimum=op({minimum_:minimum_}),minimumStrict=op({minimumStrict_:minimumStrict_}),mod=op({mod_:mod_}),modStrict=op({modStrict_:modStrict_}),mul=op({mul_:mul_}),mulStrict=op({mulStrict_:mulStrict_}),pow=op({pow_:pow_}),powStrict=op({powStrict_:powStrict_}),squaredDifference=op({squaredDifference_:squaredDifference_}),squaredDifferenceStrict=op({squaredDifferenceStrict_:squaredDifferenceStrict_}),sub=op({sub_:sub_}),subStrict=op({subStrict_:subStrict_});function logicalNot_(e){var t=convertToTensor(e,"x","logicalNot","bool");return assert("bool"===t.dtype,"Error Array must be of type bool."),ENV.engine.runKernel(function(e){return e.logicalNot(t)},{$x:t})}function logicalAnd_(e,t){var n=convertToTensor(e,"a","logicalAnd","bool"),r=convertToTensor(t,"b","logicalAnd","bool");return assert("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalAnd(n,r)},{$a:n,$b:r})}function logicalOr_(e,t){var n=convertToTensor(e,"a","logicalOr","bool"),r=convertToTensor(t,"b","logicalOr","bool");return assert("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalOr(n,r)},{$a:n,$b:r})}function logicalXor_(e,t){var n=convertToTensor(e,"a","logicalXor","bool"),r=convertToTensor(t,"b","logicalXor","bool");return assert("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(n.shape,r.shape),logicalOr(e,t).logicalAnd(logicalAnd(e,t).logicalNot())}function where_(e,t,n){var r=convertToTensor(t,"a","where"),o=convertToTensor(n,"b","where"),a=convertToTensor(e,"condition","where","bool");assert("bool"===a.dtype,"Error Condition must be of type bool."),assertShapesMatch(r.shape,o.shape,"Error in where: "),1===a.rank?assert(a.shape[0]===r.shape[0],"The first dimension of `a` must match the size of `condition`."):assertShapesMatch(a.shape,o.shape,"Error in where: ");return ENV.engine.runKernel(function(e){return e.select(a,r,o)},{$condition:a,$a:r,$b:o},function(e){return{$condition:function(){return zerosLike(a)},$a:function(){return e.mul(a.cast(r.dtype))},$b:function(){return e.mul(a.logicalNot().cast(o.dtype))}}})}function whereAsync_(e){return __awaiter(this,void 0,void 0,function(){var t,n,r;return __generator(this,function(o){switch(o.label){case 0:return assert("bool"===(t=convertToTensor(e,"condition","where","bool")).dtype,"Condition must be of type bool."),[4,t.data()];case 1:return n=o.sent(),r=whereImpl(t.shape,n),e!==t&&t.dispose(),[2,r]}})})}var logicalAnd=op({logicalAnd_:logicalAnd_}),logicalNot=op({logicalNot_:logicalNot_}),logicalOr=op({logicalOr_:logicalOr_}),logicalXor=op({logicalXor_:logicalXor_}),where=op({where_:where_}),whereAsync=whereAsync_;function relu_(e){var t=convertToTensor(e,"x","relu");if("bool"===t.dtype)return t.toInt();return ENV.engine.runKernel(function(e){return e.relu(t)},{$x:t},function(e){var n=t.step();return{$x:function(){return e.mulStrict(n.toFloat())}}})}function elu_(e){var t=convertToTensor(e,"x","elu");return ENV.engine.runKernel(function(e,n){return n(e.elu(t))},{$x:t},function(e,t){var n=t[0];return{$x:function(){return ENV.engine.runKernel(function(t){return t.eluDer(e,n)},{dy:e,y:n})}}})}function selu_(e){var t=convertToTensor(e,"x","selu");return ENV.engine.runKernel(function(e){return e.selu(t)},{$x:t},function(e){return{$x:function(){var n=t.greater(scalar(0)),r=scalar(SELU_SCALEALPHA),o=scalar(SELU_SCALE),a=e.mul(o),i=e.mul(r).mul(t.toFloat().exp());return where(n,a,i)}}})}function leakyRelu_(e,t){void 0===t&&(t=.2);var n=convertToTensor(e,"x","leakyRelu");return maximum(scalar(t).mul(n),n)}function prelu_(e,t){var n=convertToTensor(e,"x","prelu"),r=convertToTensor(t,"alpha","prelu"),o=scalar(0);return maximum(o,n).add(r.mul(minimum(o,n)))}var elu=op({elu_:elu_}),leakyRelu=op({leakyRelu_:leakyRelu_}),prelu=op({prelu_:prelu_}),relu=op({relu_:relu_}),selu=op({selu_:selu_});function transpose_(e,t){var n=convertToTensor(e,"x","transpose");if(null==t&&(t=n.shape.map(function(e,t){return t}).reverse()),assert(n.rank===t.length,"Error in transpose: rank of input "+n.rank+" must match length of perm "+t+"."),t.forEach(function(e){assert(e>=0&&eo)throw new Error("'k' passed to topk() must be <= the last dimension ("+o+") but got "+t);var a=ENV.engine.runKernel(function(e){return e.topk(r,t,n)},{$x:r});return{values:a[0],indices:a[1]}}var Reduction,topk=op({topk_:topk_});function computeWeightedLoss_(e,t,n){void 0===n&&(n=Reduction.SUM_BY_NONZERO_WEIGHTS);var r=convertToTensor(e,"losses","computeWeightedLoss"),o=null;null!=t&&(o=convertToTensor(t,"weights","computeWeightedLoss"));var a=null==o?r:r.mul(o);if(n===Reduction.NONE)return a;if(n===Reduction.SUM)return a.sum();if(n===Reduction.MEAN){if(null==o)return a.mean();var i=sizeFromShape(r.shape)/sizeFromShape(o.shape),s=a.sum().div(o.sum());return i>1?s.div(scalar(i)):s}if(n===Reduction.SUM_BY_NONZERO_WEIGHTS){if(null==o)return a.sum().div(scalar(r.size));var u=o.mul(ones$1(r.shape)).notEqual(scalar(0)).sum().toFloat();return a.sum().div(u)}throw Error("Unknown reduction: "+n)}function absoluteDifference_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","absoluteDifference"),a=convertToTensor(t,"predictions","absoluteDifference"),i=null;null!=n&&(i=convertToTensor(n,"weights","absoluteDifference")),assertShapesMatch(o.shape,a.shape,"Error in absoluteDifference: ");var s=o.sub(a).abs();return computeWeightedLoss(s,i,r)}function meanSquaredError_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","meanSquaredError"),a=convertToTensor(t,"predictions","meanSquaredError"),i=null;null!=n&&(i=convertToTensor(n,"weights","meanSquaredError")),assertShapesMatch(o.shape,a.shape,"Error in meanSquaredError: ");var s=o.squaredDifference(a);return computeWeightedLoss(s,i,r)}function cosineDistance_(e,t,n,r,o){void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","cosineDistance"),i=convertToTensor(t,"predictions","cosineDistance"),s=null;null!=r&&(s=convertToTensor(r,"weights","cosineDistance")),assertShapesMatch(a.shape,i.shape,"Error in cosineDistance: ");var u=scalar(1).sub(a.mul(i).sum(n,!0));return computeWeightedLoss(u,s,o)}function hingeLoss_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","hingeLoss"),a=convertToTensor(t,"predictions","hingeLoss"),i=null;null!=n&&(i=convertToTensor(n,"weights","hingeLoss")),assertShapesMatch(o.shape,a.shape,"Error in hingeLoss: ");var s=scalar(1);o=scalar(2).mul(o).sub(s);var u=s.sub(o.mul(a)).relu();return computeWeightedLoss(u,i,r)}function logLoss_(e,t,n,r,o){void 0===r&&(r=1e-7),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","logLoss"),i=convertToTensor(t,"predictions","logLoss"),s=null;null!=n&&(s=convertToTensor(n,"weights","logLoss")),assertShapesMatch(a.shape,i.shape,"Error in logLoss: ");var u=scalar(1),l=scalar(r),c=a.mul(i.add(l).log()).neg().sub(u.sub(a).mul(u.sub(i).add(l).log()));return computeWeightedLoss(c,s,o)}function sigmoidCrossEntropyWithLogits_(e,t){var n=convertToTensor(e,"labels","sigmoidCrossEntropyWithLogits"),r=convertToTensor(t,"logits","sigmoidCrossEntropyWithLogits");assertShapesMatch(n.shape,r.shape,"Error in sigmoidCrossEntropyWithLogits: ");var o=r.relu(),a=r.mul(n),i=r.abs().neg().exp().log1p();return o.sub(a).add(i)}function sigmoidCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"multiClassLabels","sigmoidCrossEntropy"),i=convertToTensor(t,"logits","sigmoidCrossEntropy"),s=null;if(null!=n&&(s=convertToTensor(n,"weights","sigmoidCrossEntropy")),assertShapesMatch(a.shape,i.shape,"Error in sigmoidCrossEntropy: "),r>0){var u=scalar(r),l=scalar(1),c=scalar(.5);a=a.mul(l.sub(u)).add(c.mul(u))}var p=sigmoidCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}function huberLoss_(e,t,n,r,o){void 0===r&&(r=1),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","huberLoss"),i=convertToTensor(t,"predictions","huberLoss"),s=null;null!=n&&(s=convertToTensor(n,"weights","huberLoss")),assertShapesMatch(a.shape,i.shape,"Error in huberLoss: ");var u=scalar(r),l=i.sub(a).abs(),c=minimum(l,u),p=l.sub(c),d=scalar(.5).mul(c.square()).add(u.mul(p));return computeWeightedLoss(d,s,o)}function softmaxCrossEntropyWithLogits_(e,t,n){if(void 0===n&&(n=-1),-1===n&&(n=t.rank-1),n!==t.rank-1)throw Error("Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank "+t.rank+" and dim was "+n);return customGrad(function(e,t){var r=t.logSumExp([n],!0),o=t.toFloat().sub(r);return{value:o.mul(e).neg().sum([n]),gradFunc:function(t){var r=expandShapeToKeepDim(t.shape,[n]);return[t.reshape(r).mul(e.toFloat().sub(o.exp())),t.reshape(r).mul(o.exp().sub(e.toFloat()))]}}})(e,t)}function softmaxCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"onehotLabels","softmaxCrossEntropy"),i=convertToTensor(t,"logits","softmaxCrossEntropy"),s=null;if(null!=n&&(s=convertToTensor(n,"weights","softmaxCrossEntropy")),assertShapesMatch(a.shape,i.shape,"Error in softmaxCrossEntropy: "),r>0){var u=scalar(r),l=scalar(1),c=scalar(a.shape[1]);a=a.mul(l.sub(u)).add(u.div(c))}var p=softmaxCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}!function(e){e[e.NONE=0]="NONE",e[e.MEAN=1]="MEAN",e[e.SUM=2]="SUM",e[e.SUM_BY_NONZERO_WEIGHTS=3]="SUM_BY_NONZERO_WEIGHTS"}(Reduction||(Reduction={}));var absoluteDifference=op({absoluteDifference_:absoluteDifference_}),computeWeightedLoss=op({computeWeightedLoss_:computeWeightedLoss_}),cosineDistance=op({cosineDistance_:cosineDistance_}),hingeLoss=op({hingeLoss_:hingeLoss_}),huberLoss=op({huberLoss_:huberLoss_}),logLoss=op({logLoss_:logLoss_}),meanSquaredError=op({meanSquaredError_:meanSquaredError_}),sigmoidCrossEntropy=op({sigmoidCrossEntropy_:sigmoidCrossEntropy_}),softmaxCrossEntropy=op({softmaxCrossEntropy_:softmaxCrossEntropy_}),loss_ops=Object.freeze({get Reduction(){return Reduction},absoluteDifference:absoluteDifference,computeWeightedLoss:computeWeightedLoss,cosineDistance:cosineDistance,hingeLoss:hingeLoss,huberLoss:huberLoss,logLoss:logLoss,meanSquaredError:meanSquaredError,sigmoidCrossEntropy:sigmoidCrossEntropy,softmaxCrossEntropy:softmaxCrossEntropy});function gramSchmidt_(e){var t;if(Array.isArray(e)){t=!1,assert(null!=e&&e.length>0,"Gram-Schmidt process: input must not be null, undefined, or empty");for(var n=e[0].shape[0],r=1;r0)for(var n=0;n= 2, but got rank "+e.rank);if(2===e.rank)return qr2d(e,t);var n=e.shape.slice(0,e.shape.length-2).reduce(function(e,t){return e*t}),r=[],o=[];return unstack(e.reshape([n,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0).forEach(function(e){var n=qr2d(e,t),a=n[0],i=n[1];r.push(a),o.push(i)}),[stack(r,0).reshape(e.shape),stack(o,0).reshape(e.shape)]}function qr2d(e,t){return void 0===t&&(t=!1),ENV.engine.tidy(function(){if(2!==e.shape.length)throw new Error("qr2d() requires a 2D Tensor, but got a "+e.shape.length+"D Tensor.");for(var n=e.shape[0],r=e.shape[1],o=eye(n),a=e.clone(),i=tensor2d([[1]],[1,1]),s=i.clone(),u=n>=r?r:n,l=function(e){var t,u=a,l=s,c=o;t=ENV.engine.tidy(function(){var t=a.slice([e,e],[n-e,1]),u=t.norm(),l=a.slice([e,e],[1,1]),c=l.sign().neg(),p=l.sub(c.mul(u)),d=t.div(p);s=1===d.shape[0]?i.clone():i.concat(d.slice([1,0],[d.shape[0]-1,d.shape[1]]),0);var h=c.matMul(p).div(u).neg(),f=a.slice([e,0],[n-e,r]),m=h.mul(s);a=0===e?f.sub(m.matMul(s.transpose().matMul(f))):a.slice([0,0],[e,r]).concat(f.sub(m.matMul(s.transpose().matMul(f))),0);var g=o.slice([0,e],[n,o.shape[1]-e]);return o=0===e?g.sub(g.matMul(s).matMul(m.transpose())):o.slice([0,0],[n,e]).concat(g.sub(g.matMul(s).matMul(m.transpose())),1),[s,a,o]}),s=t[0],a=t[1],o=t[2],dispose([u,l,c])},c=0;cr&&(o=o.slice([0,0],[n,r]),a=a.slice([0,0],[r,r])),[o,a]})}var gramSchmidt=op({gramSchmidt_:gramSchmidt_}),qr=op({qr_:qr_}),linalg_ops=Object.freeze({gramSchmidt:gramSchmidt,qr:qr});function resizeBilinear_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,"images","resizeBilinear");assert(3===r.rank||4===r.rank,"Error in resizeBilinear: x must be rank 3 or 4, but got rank "+r.rank+"."),assert(2===t.length,"Error in resizeBilinear: new shape must 2D, but got shape "+t+".");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeBilinear(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeBilinearBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function resizeNearestNeighbor_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,"images","resizeNearestNeighbor");assert(3===r.rank||4===r.rank,"Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank "+r.rank+"."),assert(2===t.length,"Error in resizeNearestNeighbor: new shape must 2D, but got shape "+t+"."),assert("float32"===r.dtype||"int32"===r.dtype,"`images` must have `int32` or `float32` as dtype");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeNearestNeighbor(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeNearestNeighborBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function nonMaxSuppression_(e,t,n,r,o){void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY);var a=convertToTensor(e,"boxes","nonMaxSuppression"),i=convertToTensor(t,"scores","nonMaxSuppression"),s=nonMaxSuppSanityCheck(a,i,n,r,o);return n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,ENV.engine.runKernel(function(e){return e.nonMaxSuppression(a,i,n,r,o)},{$boxes:a})}function nonMaxSuppressionAsync_(e,t,n,r,o){return void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY),__awaiter(this,void 0,void 0,function(){var a,i,s,u,l,c;return __generator(this,function(p){switch(p.label){case 0:return a=convertToTensor(e,"boxes","nonMaxSuppressionAsync"),i=convertToTensor(t,"scores","nonMaxSuppressionAsync"),s=nonMaxSuppSanityCheck(a,i,n,r,o),n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,[4,a.data()];case 1:return u=p.sent(),[4,i.data()];case 2:return l=p.sent(),c=nonMaxSuppressionImpl(u,l,n,r,o),a!==e&&a.dispose(),i!==t&&i.dispose(),[2,c]}})})}function nonMaxSuppSanityCheck(e,t,n,r,o){null==r&&(r=.5),null==o&&(o=Number.NEGATIVE_INFINITY);var a=e.shape[0];return n=Math.min(n,a),assert(0<=r&&r<=1,"iouThreshold must be in [0, 1], but was '"+r+"'"),assert(2===e.rank,"boxes must be a 2D tensor, but was of rank '"+e.rank+"'"),assert(4===e.shape[1],"boxes must have 4 columns, but 2nd dimension was "+e.shape[1]),assert(1===t.rank,"scores must be a 1D tensor"),assert(t.shape[0]===a,"scores has incompatible shape with boxes. Expected "+a+", but was "+t.shape[0]),{maxOutputSize:n,iouThreshold:r,scoreThreshold:o}}var resizeBilinear=op({resizeBilinear_:resizeBilinear_}),resizeNearestNeighbor=op({resizeNearestNeighbor_:resizeNearestNeighbor_}),nonMaxSuppression=op({nonMaxSuppression_:nonMaxSuppression_}),nonMaxSuppressionAsync=nonMaxSuppressionAsync_,image_ops=Object.freeze({resizeBilinear:resizeBilinear,resizeNearestNeighbor:resizeNearestNeighbor,nonMaxSuppression:nonMaxSuppression,nonMaxSuppressionAsync:nonMaxSuppressionAsync}),ops=Object.freeze({image:image_ops,linalg:linalg_ops,losses:loss_ops,op:op,batchNormalization2d:batchNormalization2d,batchNormalization3d:batchNormalization3d,batchNormalization4d:batchNormalization4d,batchNormalization:batchNormalization,concat:concat,concat1d:concat1d,concat2d:concat2d,concat3d:concat3d,concat4d:concat4d,conv1d:conv1d,conv2d:conv2d,depthwiseConv2d:depthwiseConv2d,separableConv2d:separableConv2d,conv2dTranspose:conv2dTranspose,matMul:matMul,dot:dot,outerProduct:outerProduct,reverse:reverse,reverse1d:reverse1d,reverse2d:reverse2d,reverse3d:reverse3d,reverse4d:reverse4d,maxPool:maxPool,avgPool:avgPool,slice:slice,slice1d:slice1d,slice2d:slice2d,slice3d:slice3d,slice4d:slice4d,abs:abs,acos:acos,acosh:acosh,asin:asin,asinh:asinh,atan:atan,atanh:atanh,ceil:ceil,clipByValue:clipByValue,cos:cos,cosh:cosh,erf:erf,exp:exp,expm1:expm1,floor:floor,log:log$1,log1p:log1p,logSigmoid:logSigmoid,neg:neg,reciprocal:reciprocal,round:round,rsqrt:rsqrt,sigmoid:sigmoid,sign:sign,sin:sin,sinh:sinh,softplus:softplus,sqrt:sqrt,square:square,step:step,tan:tan,tanh:tanh$1,all:all,any:any,argMax:argMax,argMin:argMin,logSumExp:logSumExp,max:max,mean:mean,min:min,moments:moments,sum:sum,equal:equal,equalStrict:equalStrict,greater:greater,greaterEqual:greaterEqual,greaterEqualStrict:greaterEqualStrict,greaterStrict:greaterStrict,less:less,lessEqual:lessEqual,lessEqualStrict:lessEqualStrict,lessStrict:lessStrict,notEqual:notEqual,notEqualStrict:notEqualStrict,add:add,addN:addN,addStrict:addStrict,atan2:atan2,div:div,divStrict:divStrict,floorDiv:floorDiv,maximum:maximum,maximumStrict:maximumStrict,minimum:minimum,minimumStrict:minimumStrict,mod:mod,modStrict:modStrict,mul:mul,mulStrict:mulStrict,pow:pow,powStrict:powStrict,squaredDifference:squaredDifference,squaredDifferenceStrict:squaredDifferenceStrict,sub:sub,subStrict:subStrict,elu:elu,leakyRelu:leakyRelu,prelu:prelu,relu:relu,selu:selu,logicalAnd:logicalAnd,logicalNot:logicalNot,logicalOr:logicalOr,logicalXor:logicalXor,where:where,whereAsync:whereAsync,buffer:buffer,toPixels:toPixels,print:print,cast:cast,clone:clone,cumsum:cumsum,expandDims:expandDims,eye:eye,fromPixels:fromPixels,multinomial:multinomial,oneHot:oneHot,pad:pad,pad1d:pad1d,pad2d:pad2d,pad3d:pad3d,pad4d:pad4d,rand:rand,randomNormal:randomNormal,randomUniform:randomUniform,reshape:reshape,split:split,squeeze:squeeze,stack:stack,tile:tile,truncatedNormal:truncatedNormal,unstack:unstack,batchToSpaceND:batchToSpaceND,spaceToBatchND:spaceToBatchND,fill:fill,linspace:linspace,ones:ones$1,range:range,scalar:scalar,tensor:tensor,tensor1d:tensor1d,tensor2d:tensor2d,tensor3d:tensor3d,tensor4d:tensor4d,tensor5d:tensor5d,tensor6d:tensor6d,zeros:zeros,onesLike:onesLike,zerosLike:zerosLike,transpose:transpose,softmax:softmax,localResponseNormalization:localResponseNormalization,norm:norm,gather:gather,unsortedSegmentSum:unsortedSegmentSum,basicLSTMCell:basicLSTMCell,multiRNNCell:multiRNNCell,movingAverage:movingAverage,stridedSlice:stridedSlice,topk:topk}),MathBackendCPU=function(){function e(){this.data=new WeakMap,this.firstUse=!0,ENV.get("IS_BROWSER")&&(this.canvas=document.createElement("canvas"))}return e.prototype.register=function(e,t,n){if(this.firstUse&&(this.firstUse=!1,ENV.get("IS_NODE")&&warn("\n============================\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\n============================\n")),this.data.has(e))throw new Error("Data buffer is already registered");this.data.set(e,null)},e.prototype.write=function(e,t){if(null==t)throw new Error("MathBackendCPU.write(): values can not be null");this.throwIfNoData(e),this.data.set(e,t)},e.prototype.fromPixels=function(e,t){if(null==e)throw new Error("pixels passed to tf.fromPixels() can not be null");var n,r;if(ENV.get("IS_NODE")&&null==e.getContext)throw new Error("When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package");if(null!=e.getContext)n=e.getContext("2d").getImageData(0,0,e.width,e.height).data;else if(e instanceof ImageData)n=e.data;else{if(!(e instanceof HTMLImageElement||e instanceof HTMLVideoElement))throw new Error("pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was "+e.constructor.name);if(null==this.canvas)throw new Error("Can't read pixels from HTMLImageElement outside the browser.");this.canvas.width=e.width,this.canvas.height=e.height,this.canvas.getContext("2d").drawImage(e,0,0,e.width,e.height),n=this.canvas.getContext("2d").getImageData(0,0,e.width,e.height).data}if(4===t)r=new Int32Array(n);else{var o=e.width*e.height;r=new Int32Array(o*t);for(var a=0;ad&&(d=m,h=f)}u[c]=h}return i},e.prototype.cumsum=function(e,t,n,r){if(t!==e.rank-1)throw new Error("backend.cumsum in CPU expects an inner-most axis="+(e.rank-1)+" but got axis="+t);for(var o=upcastType(e.dtype,"int32"),a=zeros(e.shape,o),i=a.dataSync(),s=e.dataSync(),u=e.shape[e.rank-1],l=r?function(e,t){return e+u-t-1}:function(e,t){return e+t},c=0;ct?1:0})},e.prototype.greaterEqual=function(e,t){return this.broadcastedBinaryOp(e,t,"bool",function(e,t){return e>=t?1:0})},e.prototype.logicalNot=function(e){for(var t=e.dataSync(),n=new Int32Array(t.length),r=0;r1||1===t.rank?1:t.shape[1],c=0;c=0&&t>=0?n:(n+t)%t})},e.prototype.max=function(e,t){assertAxesAreInnerMostDims("max",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;lp&&(p=h)}s[l]=p}return a},e.prototype.maximum=function(e,t){return this.broadcastedBinaryOp(e,t,e.dtype,function(e,t){return Math.max(e,t)})},e.prototype.all=function(e,t){assertAxesAreInnerMostDims("all",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;l0?n[r]=1:n[r]=0;return Tensor.make(e.shape,{values:n})},e.prototype.round=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r.5?n[r]=Math.ceil(t[r]):n[r]=o%2==0?o:o+1}return Tensor.make(e.shape,{values:n})},e.prototype.exp=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r=0?o:Math.exp(o)-1}return Tensor.make(e.shape,{values:t})},e.prototype.eluDer=function(e,t){for(var n=new Float32Array(t.size),r=t.dataSync(),o=e.dataSync(),a=0;a=1?o[a]:o[a]*(i+1)}return Tensor.make(t.shape,{values:n})},e.prototype.selu=function(e){for(var t=SELU_SCALEALPHA,n=SELU_SCALE,r=new Float32Array(e.size),o=e.dataSync(),a=0;a=0?n*i:t*(Math.exp(i)-1)}return Tensor.make(e.shape,{values:r})},e.prototype.clip=function(e,t,n){for(var r=new Float32Array(e.size),o=e.dataSync(),a=0;a-t,i=r[o]0?1:t}return Tensor.make(e.shape,{values:n})},e.prototype.conv2d=function(e,t,n){for(var r=n.filterHeight,o=n.filterWidth,a=n.dilationHeight,i=n.dilationWidth,s=n.padInfo.left,u=n.padInfo.top,l=buffer(n.outShape,e.dtype),c=0;c=n.inHeight))for(var x=0;x=n.inWidth))for(var S=0;S=n.inHeight))for(var S=0;S=n.inWidth))y+=e.get(p,T,b,d)*t.get(x,S,d,v)}}c.set(y,p,h,m,d*l+v)}return c.toTensor()},e.prototype.depthwiseConv2DDerInput=function(e,t,n){for(var r=buffer(n.inShape,"float32"),o=r.values,a=r.strides,i=a[0],s=a[1],u=a[2],l=e.dataSync(),c=e.strides,p=c[0],d=c[1],h=c[2],f=t.dataSync(),m=t.strides,g=m[0],v=m[1],y=m[2],x=n.batchSize,T=n.filterHeight,S=n.filterWidth,b=n.inChannels,E=n.inHeight,w=n.inWidth,_=n.outChannels,A=n.outHeight,R=n.outWidth,C=n.strideHeight,N=n.strideWidth,k=T-1-n.padInfo.top,I=S-1-n.padInfo.left,D=_/b,M=0;MT?T=_:"avg"===n&&(S+=_,b++)}if(isNaN(T))break}s.set("avg"===n?S/b:T,c,d,g,p)}return s.toTensor()},e.prototype.maxPool=function(e,t){return this.pool(e,t,"max")},e.prototype.maxPoolPositions=function(e,t){for(var n=buffer(t.outShape,"int32"),r=t.strideHeight,o=t.strideWidth,a=t.filterHeight,i=t.filterWidth,s=t.padInfo.top,u=t.padInfo.left,l=0;lx&&(x=_,T=b*i+w)}n.set(T,l,p,m,c)}return n.toTensor()},e.prototype.maxPoolBackprop=function(e,t,n,r){for(var o=this.maxPoolPositions(t,r),a=r.strideHeight,i=r.strideWidth,s=r.filterHeight,u=r.filterWidth,l=u-1-r.padInfo.left,c=s-1-r.padInfo.top,p=buffer(t.shape,"float32"),d=0;d=r.outHeight||Math.floor(T)!==T))for(var S=0;S=r.outWidth||Math.floor(b)!==b)){var E=s*u-1-o.get(d,T,b,h)===x*u+S?1:0;if(0!==E)y+=e.get(d,T,b,h)*E}}}p.set(y,d,f,m,h)}return p.toTensor()},e.prototype.avgPoolBackprop=function(e,t,n){for(var r=n.strideHeight,o=n.strideWidth,a=n.filterHeight,i=n.filterWidth,s=i-1-n.padInfo.left,u=a-1-n.padInfo.top,l=buffer(t.shape,"float32"),c=1/(a*i),p=0;p=n.outHeight||Math.floor(x)!==x))for(var T=0;T=n.outWidth||Math.floor(S)!==S))v+=e.get(p,x,S,d)}}l.set(v*c,p,h,f,d)}return l.toTensor()},e.prototype.cast=function(e,t){return castTensor(e,t,this)},e.prototype.reshape=function(e,t){return reshapeTensor(e,t)},e.prototype.avgPool=function(e,t){return this.pool(e,t,"avg").toFloat()},e.prototype.resizeBilinear=function(e,t,n,r){for(var o=e.shape,a=o[0],i=o[1],s=o[2],u=o[3],l=buffer([a,t,n,u],e.dtype),c=[r&&t>1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=d[0]/h[0],m=d[1]/h[1],g=0;g1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=1/(d[0]/h[0]),m=1/(d[1]/h[1]),g=2*Math.ceil(f)+2,v=2*Math.ceil(m)+2,y=0;y=l))for(var N=0;N=c)){var I=d[0]*(C/h[0]),D=d[1]*(k/h[1]),M=Math.min(a-1,n?Math.round(I):Math.floor(I)),O=Math.min(i-1,n?Math.round(D):Math.floor(D));x===M&&T===O&&(A+=e.get(y,C,k,_))}}}p.set(A,y,x,T,_)}return p.toTensor()},e.prototype.batchNormalization=function(e,t,n,r,o,a){for(var i=e.dataSync(),s=t.dataSync(),u=n.dataSync(),l=o?o.dataSync():new Float32Array([1]),c=a?a.dataSync():new Float32Array([0]),p=new Float32Array(i.length),d=0;d=0&&e.get(a)0,"scheme must not be an empty string.");var r=e.getInstance();assert(null==r.managers[t],"A model store manager is already registered for scheme '"+t+"'."),r.managers[t]=n},e.getManager=function(e){var t=this.getInstance().managers[e];if(null==t)throw new Error("Cannot find model manager for scheme '"+e+"'");return t},e.getSchemes=function(){return Object.keys(this.getInstance().managers)},e}();function parseURL(e){if(-1===e.indexOf(URL_SCHEME_SUFFIX))throw new Error("The url string provided does not contain a scheme. Supported schemes are: "+ModelStoreManagerRegistry.getSchemes().join(","));return{scheme:e.split(URL_SCHEME_SUFFIX)[0],path:e.split(URL_SCHEME_SUFFIX)[1]}}function cloneModelInternal(e,t,n){return void 0===n&&(n=!1),__awaiter(this,void 0,void 0,function(){var r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return assert(e!==t,"Old path and new path are the same: '"+e+"'"),assert((r=IORouterRegistry.getLoadHandlers(e)).length>0,"Copying failed because no load handler is found for source URL "+e+"."),assert(r.length<2,"Copying failed because more than one ("+r.length+") load handlers for source URL "+e+"."),o=r[0],assert((a=IORouterRegistry.getSaveHandlers(t)).length>0,"Copying failed because no save handler is found for destination URL "+t+"."),assert(a.length<2,"Copying failed because more than one ("+r.length+") save handlers for destination URL "+t+"."),i=a[0],s=parseURL(e).scheme,u=parseURL(e).path,l=s===parseURL(e).scheme,[4,o.load()];case 1:return c=d.sent(),n&&l?[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)]:[3,3];case 2:d.sent(),d.label=3;case 3:return[4,i.save(c)];case 4:return p=d.sent(),!n||l?[3,6]:[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)];case 5:d.sent(),d.label=6;case 6:return[2,p.modelArtifactsInfo]}})})}function listModels(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i;return __generator(this,function(s){switch(s.label){case 0:e=ModelStoreManagerRegistry.getSchemes(),t={},n=0,r=e,s.label=1;case 1:return n0,"URL path for browserHTTPRequest must not be null, undefined or empty."),this.path=e,null!=t&&null!=t.body)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=t||{}}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){var t,n,r,o;return __generator(this,function(a){switch(a.label){case 0:if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");return(t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit)).body=new FormData,n=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],r={modelTopology:e.modelTopology,weightsManifest:n},t.body.append("model.json",new Blob([JSON.stringify(r)],{type:"application/json"}),"model.json"),null!=e.weightData&&t.body.append("model.weights.bin",new Blob([e.weightData],{type:"application/octet-stream"}),"model.weights.bin"),[4,fetch(this.path,t)];case 1:if(200===(o=a.sent()).status)return[2,{modelArtifactsInfo:getModelArtifactsInfoForJSON(e),responses:[o]}];throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status "+o.status+".")}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return[4,fetch(this.path,this.requestInit)];case 1:return[4,d.sent().json()];case 2:if(e=d.sent(),t=e.modelTopology,n=e.weightsManifest,null==t&&null==n)throw new Error("The JSON from HTTP path "+this.path+" contains neither model topology or manifest for weights.");if(null==n)return[3,4];for(a=e.weightsManifest,r=[],i=0,s=a;i0&&(e=__assign({weightSpecs:this.weightSpecs},e)),null!=this.weightData&&this.weightData.byteLength>0&&(e=__assign({weightData:this.weightData},e)),[2,e]})})},e}(),PassthroughSaver=function(){function e(e){this.saveHandler=e}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(t){return[2,this.saveHandler(e)]})})},e}();function fromMemory(e,t,n){return new PassthroughLoader(e,t,n)}function withSaveHandler(e){return new PassthroughSaver(e)}var registerSaveRouter=IORouterRegistry.registerSaveRouter,registerLoadRouter=IORouterRegistry.registerLoadRouter,getSaveHandlers=IORouterRegistry.getSaveHandlers,getLoadHandlers=IORouterRegistry.getLoadHandlers,io=Object.freeze({browserFiles:browserFiles,browserHTTPRequest:browserHTTPRequest,concatenateArrayBuffers:concatenateArrayBuffers,decodeWeights:decodeWeights,encodeWeights:encodeWeights,fromMemory:fromMemory,getLoadHandlers:getLoadHandlers,getModelArtifactsInfoForJSON:getModelArtifactsInfoForJSON,getSaveHandlers:getSaveHandlers,loadWeights:loadWeights,registerLoadRouter:registerLoadRouter,registerSaveRouter:registerSaveRouter,withSaveHandler:withSaveHandler,copyModel:copyModel,listModels:listModels,moveModel:moveModel,removeModel:removeModel}),Serializable=function(){function e(){}return e.prototype.getClassName=function(){return this.constructor.className},e.fromConfig=function(e,t){return new e(t)},e}(),SerializationMap=function(){function e(){this.classNameMap={}}return e.getMap=function(){return null==e.instance&&(e.instance=new e),e.instance},e.register=function(t){e.getMap().classNameMap[t.className]=[t,t.fromConfig]},e}(),serialization=Object.freeze({Serializable:Serializable,SerializationMap:SerializationMap}),WEBGL_ENVS={HAS_WEBGL:!0},NODE_ENVS={IS_NODE:!0},CHROME_ENVS={IS_CHROME:!0},BROWSER_ENVS={IS_BROWSER:!0},CPU_ENVS={HAS_WEBGL:!1},ALL_ENVS={};function expectArraysClose(e,t,n){if(null==n&&(n=ENV.get("TEST_EPSILON")),e instanceof Tensor||t instanceof Tensor){if(e instanceof Tensor&&t instanceof Tensor){if(e.dtype!==t.dtype)throw new Error("Arrays are of different type actual: "+e.dtype+" vs expected: "+t.dtype+".");if(!arraysEqual(e.shape,t.shape))throw new Error("Arrays are of different shape actual: "+e.shape+" vs expected: "+t.shape+".")}}else{var r=e.constructor.name,o=t.constructor.name;if(r!==o)throw new Error("Arrays are of different type actual: "+r+" vs expected: "+o)}var a,i;if(a=e instanceof Tensor?e.dataSync():e,i=t instanceof Tensor?t.dataSync():t,a.length!==i.length)throw new Error("Arrays have different lengths actual: "+a.length+" vs expected: "+i.length+".\nActual: "+a+".\nExpected: "+i+".");for(var s=0;sn)}function expectValuesInRange(e,t,n){var r;r=e instanceof Tensor?e.dataSync():e;for(var o=0;on)throw new Error("Value out of range:"+r[o]+" low: "+t+", high: "+n)}function expectArrayBuffersEqual(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}var test_util=Object.freeze({WEBGL_ENVS:WEBGL_ENVS,NODE_ENVS:NODE_ENVS,CHROME_ENVS:CHROME_ENVS,BROWSER_ENVS:BROWSER_ENVS,CPU_ENVS:CPU_ENVS,ALL_ENVS:ALL_ENVS,expectArraysClose:expectArraysClose,expectPromiseToFail:expectPromiseToFail,expectArraysEqual:expectArraysEqual,expectNumbersClose:expectNumbersClose,expectValuesInRange:expectValuesInRange,expectArrayBuffersEqual:expectArrayBuffersEqual}),version="0.12.8",webgl=Object.freeze({gpgpu_util:gpgpu_util,webgl_util:webgl_util,MathBackendWebGL:MathBackendWebGL,GPGPUContext:GPGPUContext}),Optimizer=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.minimize=function(e,t,n){void 0===t&&(t=!1);var r=this.computeGradients(e,n),o=r.value,a=r.grads;return this.applyGradients(a),Object.keys(a).forEach(function(e){return a[e].dispose()}),t?o:(o.dispose(),null)},t.prototype.computeGradients=function(e,t){return variableGrads(e,t)},t}(Serializable),DEFAULT_FLOAT32_EPSILON=1e-8,DEFAULT_FLOAT16_EPSILON=1e-4;function getOptimizerDefaultEpsilonValue(){return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")?DEFAULT_FLOAT32_EPSILON:DEFAULT_FLOAT16_EPSILON}var AdadeltaOptimizer=function(e){function t(t,n,r){void 0===r&&(r=null);var o=e.call(this)||this;return o.learningRate=t,o.rho=n,o.epsilon=r,o.accumulatedGrads={},o.accumulatedUpdates={},o.c=keep(scalar(-t)),o.rhoScalar=keep(scalar(n)),o.oneMinusRho=keep(scalar(1-n)),null===r&&(r=getOptimizerDefaultEpsilonValue()),o.epsilonScalar=keep(scalar(r)),o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedUpdates[n]){tidy(function(){t.accumulatedUpdates[n]=zerosLike(o).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n],s=r.accumulatedUpdates[n];tidy(function(){var e=t.rhoScalar.mul(i).add(t.oneMinusRho.mul(a.square())),r=s.add(t.epsilonScalar).sqrt().div(i.add(t.epsilonScalar).sqrt()).mul(a),u=t.rhoScalar.mul(s).add(t.oneMinusRho.mul(r.square()));t.accumulatedGrads[n].assign(e),t.accumulatedUpdates[n].assign(u);var l=t.c.mul(r).add(o);o.assign(l)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.rhoScalar.dispose(),this.oneMinusRho.dispose(),null!=this.accumulatedUpdates&&(Object.keys(this.accumulatedUpdates).forEach(function(t){return e.accumulatedUpdates[t].dispose()}),Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()}))},t.prototype.getConfig=function(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.rho,t.epsilon)},t.className="AdadeltaOptimizer",t}(Optimizer);SerializationMap.register(AdadeltaOptimizer);var AdagradOptimizer=function(e){function t(t,n){void 0===n&&(n=.1);var r=e.call(this)||this;r.learningRate=t,r.initialAccumulatorValue=n,r.accumulatedGrads={},r.c=keep(scalar(-t));var o=getOptimizerDefaultEpsilonValue();return r.epsilon=keep(scalar(o)),r}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=fill(o.shape,t.initialAccumulatorValue).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n];tidy(function(){var e=i.add(a.square());t.accumulatedGrads[n].assign(e);var r=t.c.mul(a.div(e.add(t.epsilon).sqrt())).add(o);o.assign(r)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.epsilon.dispose(),this.c.dispose(),null!=this.accumulatedGrads&&Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}},t.fromConfig=function(e,t){return new e(t.learningRate,t.initialAccumulatorValue)},t.className="AdagradOptimizer",t}(Optimizer);SerializationMap.register(AdagradOptimizer);var AdamOptimizer=function(e){function t(t,n,r,o){void 0===o&&(o=null);var a=e.call(this)||this;return a.learningRate=t,a.beta1=n,a.beta2=r,a.epsilon=o,a.accumulatedFirstMoment={},a.accumulatedSecondMoment={},a.c=keep(scalar(-t)),a.beta1Scalar=keep(scalar(n)),a.beta2Scalar=keep(scalar(r)),tidy(function(){a.accBeta1=scalar(n).variable(),a.accBeta2=scalar(r).variable()}),a.oneMinusBeta1=keep(scalar(1-n)),a.oneMinusBeta2=keep(scalar(1-r)),a.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),a.epsScalar=keep(scalar(o)),a}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.one.sub(t.accBeta2);for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedSecondMoment[o]){i=!1;t.accumulatedSecondMoment[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedSecondMoment[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l).add(t.oneMinusBeta2.mul(s.square())),d=c.div(n),h=p.div(r);t.accumulatedFirstMoment[o].assign(c),t.accumulatedSecondMoment[o].assign(p);var f=t.c.mul(d.div(t.epsScalar.add(h.sqrt()))).add(a);a.assign(f)}t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)),t.accBeta2.assign(t.accBeta2.mul(t.beta2Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.accBeta1.dispose(),this.accBeta2.dispose(),this.oneMinusBeta1.dispose(),this.oneMinusBeta2.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedSecondMoment&&Object.keys(this.accumulatedSecondMoment).forEach(function(t){return e.accumulatedSecondMoment[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)},t.className="AdamOptimizer",t}(Optimizer);SerializationMap.register(AdamOptimizer);var AdamaxOptimizer=function(e){function t(t,n,r,o,a){void 0===o&&(o=null),void 0===a&&(a=0);var i=e.call(this)||this;return i.learningRate=t,i.beta1=n,i.beta2=r,i.epsilon=o,i.decay=a,i.accumulatedFirstMoment={},i.accumulatedWeightedInfNorm={},i.c=keep(scalar(-t)),i.beta1Scalar=keep(scalar(n)),i.beta2Scalar=keep(scalar(r)),i.decayScalar=keep(scalar(a)),tidy(function(){i.iteration=scalar(0).variable(),i.accBeta1=scalar(n).variable()}),i.oneMinusBeta1=keep(scalar(1-n)),i.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.c.div(t.one.add(t.decayScalar.mul(t.iteration)));for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedWeightedInfNorm[o]){i=!1;t.accumulatedWeightedInfNorm[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedWeightedInfNorm[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l),d=s.abs(),h=p.maximum(d);t.accumulatedFirstMoment[o].assign(c),t.accumulatedWeightedInfNorm[o].assign(h);var f=r.div(n).mul(c.div(t.epsScalar.add(h))).add(a);a.assign(f)}t.iteration.assign(t.iteration.add(t.one)),t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.accBeta1.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.oneMinusBeta1.dispose(),this.decayScalar.dispose(),this.iteration.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedWeightedInfNorm&&Object.keys(this.accumulatedWeightedInfNorm).forEach(function(t){return e.accumulatedWeightedInfNorm[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)},t.className="AdamaxOptimizer",t}(Optimizer);SerializationMap.register(AdamaxOptimizer);var SGDOptimizer=function(e){function t(t){var n=e.call(this)||this;return n.learningRate=t,n.setLearningRate(t),n}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;Object.keys(e).forEach(function(n){var r=e[n],o=ENV.engine.registeredVariables[n];tidy(function(){var e=t.c.mul(r).add(o);o.assign(e)})})},t.prototype.setLearningRate=function(e){this.learningRate=e,null!=this.c&&this.c.dispose(),this.c=keep(scalar(-e))},t.prototype.dispose=function(){this.c.dispose()},t.prototype.getConfig=function(){return{learningRate:this.learningRate}},t.fromConfig=function(e,t){return new e(t.learningRate)},t.className="SGDOptimizer",t}(Optimizer);SerializationMap.register(SGDOptimizer);var MomentumOptimizer=function(e){function t(t,n,r){void 0===r&&(r=!1);var o=e.call(this,t)||this;return o.learningRate=t,o.momentum=n,o.useNesterov=r,o.m=scalar(o.momentum),o.accumulations={},o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulations[n]){tidy(function(){t.accumulations[n]=zerosLike(o).variable(!1)})}var a=r.accumulations[n],i=e[n];tidy(function(){var e,r=t.m.mul(a).add(i);e=t.useNesterov?t.c.mul(i.add(r.mul(t.m))).add(o):t.c.mul(r).add(o),t.accumulations[n].assign(r),o.assign(e)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){if(e.prototype.dispose.call(this),this.m.dispose(),null!=this.accumulations)for(var t in this.accumulations)this.accumulations[t].dispose()},t.prototype.setMomentum=function(e){this.momentum=e},t.prototype.getConfig=function(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}},t.fromConfig=function(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)},t.className="MomentumOptimizer",t}(SGDOptimizer);SerializationMap.register(MomentumOptimizer);var RMSPropOptimizer=function(e){function t(t,n,r,o,a){void 0===n&&(n=.9),void 0===r&&(r=0),void 0===o&&(o=null),void 0===a&&(a=!1);var i=e.call(this)||this;return i.learningRate=t,i.decay=n,i.momentum=r,i.epsilon=o,i.accumulatedMeanSquares={},i.accumulatedMeanGrads={},i.accumulatedMoments={},i.c=keep(scalar(t)),i.decayScalar=keep(scalar(n)),i.momentumScalar=keep(scalar(r)),i.oneMinusDecay=keep(scalar(1-n)),i.centered=a,null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsilonScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedMeanSquares[n]){tidy(function(){t.accumulatedMeanSquares[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMeanGrads[n]&&r.centered){tidy(function(){t.accumulatedMeanGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMoments[n]){tidy(function(){t.accumulatedMoments[n]=zerosLike(o).variable(!1)})}var a=r.accumulatedMeanSquares[n],i=r.accumulatedMeanGrads[n],s=r.accumulatedMoments[n],u=e[n];tidy(function(){var e=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));if(t.centered){var r=t.decayScalar.mul(i).add(t.oneMinusDecay.mul(u)),l=t.momentumScalar.mul(s).add(t.c.mul(u).div(e.sub(r.square().add(t.epsilonScalar)).sqrt()));t.accumulatedMeanSquares[n].assign(e),t.accumulatedMeanGrads[n].assign(r),t.accumulatedMoments[n].assign(l);var c=o.sub(l);o.assign(c)}else{var p=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));l=t.momentumScalar.mul(s).add(t.c.mul(u).div(p.add(t.epsilonScalar).sqrt()));t.accumulatedMeanSquares[n].assign(p),t.accumulatedMoments[n].assign(l);c=o.sub(l);o.assign(c)}})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.decayScalar.dispose(),this.momentumScalar.dispose(),this.oneMinusDecay.dispose(),null!=this.accumulatedMeanSquares&&Object.keys(this.accumulatedMeanSquares).forEach(function(t){return e.accumulatedMeanSquares[t].dispose()}),null!=this.accumulatedMeanGrads&&this.centered&&Object.keys(this.accumulatedMeanGrads).forEach(function(t){return e.accumulatedMeanGrads[t].dispose()}),null!=this.accumulatedMoments&&Object.keys(this.accumulatedMoments).forEach(function(t){return e.accumulatedMoments[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}},t.fromConfig=function(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)},t.className="RMSPropOptimizer",t}(Optimizer);SerializationMap.register(RMSPropOptimizer);var OptimizerConstructors=function(){function e(){}return e.sgd=function(e){return new SGDOptimizer(e)},e.momentum=function(e,t,n){return void 0===n&&(n=!1),new MomentumOptimizer(e,t,n)},e.rmsprop=function(e,t,n,r,o){return void 0===t&&(t=.9),void 0===n&&(n=0),void 0===r&&(r=null),void 0===o&&(o=!1),new RMSPropOptimizer(e,t,n,r,o)},e.adam=function(e,t,n,r){return void 0===e&&(e=.001),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),new AdamOptimizer(e,t,n,r)},e.adadelta=function(e,t,n){return void 0===e&&(e=.001),void 0===t&&(t=.95),void 0===n&&(n=null),new AdadeltaOptimizer(e,t,n)},e.adamax=function(e,t,n,r,o){return void 0===e&&(e=.002),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),void 0===o&&(o=0),new AdamaxOptimizer(e,t,n,r,o)},e.adagrad=function(e,t){return void 0===t&&(t=.1),new AdagradOptimizer(e,t)},e}(),train={sgd:OptimizerConstructors.sgd,momentum:OptimizerConstructors.momentum,adadelta:OptimizerConstructors.adadelta,adagrad:OptimizerConstructors.adagrad,rmsprop:OptimizerConstructors.rmsprop,adamax:OptimizerConstructors.adamax,adam:OptimizerConstructors.adam},setBackend=Environment.setBackend,getBackend=Environment.getBackend,disposeVariables=Environment.disposeVariables,memory=Environment.memory;setOpHandler(ops);export{setBackend,getBackend,disposeVariables,memory,version as version_core,nextFrame,environment,io,serialization,test_util,util,webgl,AdadeltaOptimizer,AdagradOptimizer,AdamOptimizer,AdamaxOptimizer,MomentumOptimizer,Optimizer,RMSPropOptimizer,SGDOptimizer,Tensor,TensorBuffer,variable,Variable,Rank,Reduction,ENV,Environment,image_ops as image,linalg_ops as linalg,loss_ops as losses,op,batchNormalization2d,batchNormalization3d,batchNormalization4d,batchNormalization,concat,concat1d,concat2d,concat3d,concat4d,conv1d,conv2d,depthwiseConv2d,separableConv2d,conv2dTranspose,matMul,dot,outerProduct,reverse,reverse1d,reverse2d,reverse3d,reverse4d,maxPool,avgPool,slice,slice1d,slice2d,slice3d,slice4d,abs,acos,acosh,asin,asinh,atan,atanh,ceil,clipByValue,cos,cosh,erf,exp,expm1,floor,log$1 as log,log1p,logSigmoid,neg,reciprocal,round,rsqrt,sigmoid,sign,sin,sinh,softplus,sqrt,square,step,tan,tanh$1 as tanh,all,any,argMax,argMin,logSumExp,max,mean,min,moments,sum,equal,equalStrict,greater,greaterEqual,greaterEqualStrict,greaterStrict,less,lessEqual,lessEqualStrict,lessStrict,notEqual,notEqualStrict,add,addN,addStrict,atan2,div,divStrict,floorDiv,maximum,maximumStrict,minimum,minimumStrict,mod,modStrict,mul,mulStrict,pow,powStrict,squaredDifference,squaredDifferenceStrict,sub,subStrict,elu,leakyRelu,prelu,relu,selu,logicalAnd,logicalNot,logicalOr,logicalXor,where,whereAsync,buffer,toPixels,print,cast,clone,cumsum,expandDims,eye,fromPixels,multinomial,oneHot,pad,pad1d,pad2d,pad3d,pad4d,rand,randomNormal,randomUniform,reshape,split,squeeze,stack,tile,truncatedNormal,unstack,batchToSpaceND,spaceToBatchND,fill,linspace,ones$1 as ones,range,scalar,tensor,tensor1d,tensor2d,tensor3d,tensor4d,tensor5d,tensor6d,zeros,onesLike,zerosLike,transpose,softmax,localResponseNormalization,norm,gather,unsortedSegmentSum,basicLSTMCell,multiRNNCell,movingAverage,stridedSlice,topk,train,tidy,keep,dispose,time,customGrad,grad,grads,valueAndGrad,valueAndGrads,variableGrads}; +//# sourceMappingURL=tf-core.esm.js.map diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js.map b/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js.map new file mode 100644 index 0000000..55df755 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf-core.esm.js","sources":["../src/device_util.ts","../src/util.ts","../src/profiler.ts","../src/tape.ts","../src/tensor_format.ts","../src/tensor.ts","../src/tensor_util.ts","../src/engine.ts","../src/environment_util.ts","../src/environment.ts","../src/log.ts","../src/ops/array_ops_util.ts","../src/ops/axis_util.ts","../src/ops/reduce_util.ts","../src/ops/segment_util.ts","../src/ops/slice_util.ts","../src/gradients.ts","../src/tensor_util_env.ts","../src/ops/operation.ts","../src/ops/softmax.ts","../src/ops/tensor_ops.ts","../src/types.ts","../src/kernels/backend_util.ts","../src/kernels/non_max_suppression_impl.ts","../src/kernels/topk_impl.ts","../src/kernels/webgl/argminmax_gpu.ts","../src/kernels/webgl/avg_pool_backprop_gpu.ts","../src/ops/broadcast_util.ts","../src/kernels/webgl/batchnorm_gpu.ts","../src/kernels/webgl/binaryop_gpu.ts","../src/kernels/webgl/clip_gpu.ts","../src/ops/concat_util.ts","../src/kernels/webgl/concat_gpu.ts","../src/kernels/webgl/conv_backprop_gpu.ts","../src/kernels/webgl/conv_backprop_gpu_depthwise.ts","../src/kernels/webgl/conv_gpu.ts","../src/kernels/webgl/conv_gpu_depthwise.ts","../src/kernels/webgl/shader_compiler.ts","../src/kernels/webgl/cumsum_gpu.ts","../src/kernels/webgl/encode_float_gpu.ts","../src/kernels/webgl/tex_util.ts","../src/kernels/webgl/from_pixels_gpu.ts","../src/kernels/webgl/gather_gpu.ts","../src/kernels/webgl/webgl_util.ts","../src/kernels/webgl/gpgpu_util.ts","../src/kernels/webgl/gpgpu_context.ts","../src/kernels/webgl/gpgpu_math.ts","../src/kernels/webgl/lrn_gpu.ts","../src/kernels/webgl/lrn_grad_gpu.ts","../src/kernels/webgl/max_pool_backprop_gpu.ts","../src/kernels/webgl/mulmat_gpu.ts","../src/kernels/webgl/multinomial_gpu.ts","../src/kernels/webgl/onehot_gpu.ts","../src/kernels/webgl/pad_gpu.ts","../src/kernels/webgl/pool_gpu.ts","../src/kernels/webgl/reduce_gpu.ts","../src/kernels/webgl/resize_bilinear_backprop_gpu.ts","../src/kernels/webgl/resize_bilinear_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_backprop_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_gpu.ts","../src/kernels/webgl/reverse_gpu.ts","../src/kernels/webgl/segment_gpu.ts","../src/kernels/webgl/select_gpu.ts","../src/kernels/webgl/slice_gpu.ts","../src/kernels/webgl/strided_slice_gpu.ts","../src/kernels/webgl/texture_manager.ts","../src/kernels/webgl/tile_gpu.ts","../src/kernels/webgl/transpose_gpu.ts","../src/ops/erf_util.ts","../src/ops/selu_util.ts","../src/kernels/webgl/unaryop_gpu.ts","../src/ops/concat.ts","../node_modules/seedrandom/lib/alea.js","../node_modules/seedrandom/lib/xor128.js","../node_modules/seedrandom/lib/xorwow.js","../node_modules/seedrandom/lib/xorshift7.js","../node_modules/seedrandom/lib/xor4096.js","../node_modules/seedrandom/lib/tychei.js","../node_modules/seedrandom/seedrandom.js","../node_modules/seedrandom/index.js","../src/ops/rand.ts","../src/ops/array_ops.ts","../src/kernels/where_impl.ts","../src/kernels/backend_webgl.ts","../src/ops/unary_ops.ts","../src/ops/batchnorm.ts","../src/ops/conv_util.ts","../src/ops/conv.ts","../src/ops/matmul.ts","../src/ops/reverse.ts","../src/ops/pool.ts","../src/ops/slice.ts","../src/globals.ts","../src/ops/reduction_ops.ts","../src/ops/compare.ts","../src/ops/binary_ops.ts","../src/ops/logical_ops.ts","../src/ops/relu_ops.ts","../src/ops/transpose.ts","../src/ops/lrn.ts","../src/ops/norm.ts","../src/ops/segment_ops.ts","../src/ops/lstm.ts","../src/ops/moving_average.ts","../src/ops/strided_slice.ts","../src/ops/topk.ts","../src/ops/loss_ops.ts","../src/ops/linalg_ops.ts","../src/ops/image_ops.ts","../src/kernels/backend_cpu.ts","../src/browser_util.ts","../src/io/types.ts","../src/io/io_utils.ts","../src/io/router_registry.ts","../src/io/model_management.ts","../src/io/indexed_db.ts","../src/io/local_storage.ts","../src/io/browser_files.ts","../src/io/weights_loader.ts","../src/io/browser_http.ts","../src/io/passthrough.ts","../src/io/io.ts","../src/serialization.ts","../src/test_util.ts","../src/version.ts","../src/optimizers/optimizer.ts","../src/optimizers/optimizer_utils.ts","../src/optimizers/adadelta_optimizer.ts","../src/optimizers/adagrad_optimizer.ts","../src/optimizers/adam_optimizer.ts","../src/optimizers/adamax_optimizer.ts","../src/optimizers/sgd_optimizer.ts","../src/optimizers/momentum_optimizer.ts","../src/optimizers/rmsprop_optimizer.ts","../src/optimizers/optimizer_constructors.ts","../src/train.ts","../src/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport function isMobile(): boolean {\n // tslint:disable-next-line:no-any\n const a = navigator.userAgent || navigator.vendor || (window as any).opera;\n // tslint:disable-next-line:max-line-length\n return /(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i\n .test(a) ||\n // tslint:disable-next-line:max-line-length\n /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i\n .test(a.substr(0, 4));\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ArrayData, DataType, DataTypeMap, FlatVector, RecursiveArray, RegularArray, TensorLike, TypedArray} from './types';\n\n/** Shuffles the array using Fisher-Yates algorithm. */\n// tslint:disable-next-line:no-any\nexport function shuffle(array: any[]|Uint32Array|Int32Array|\n Float32Array): void {\n let counter = array.length;\n let temp = 0;\n let index = 0;\n // While there are elements in the array\n while (counter > 0) {\n // Pick a random index\n index = (Math.random() * counter) | 0;\n // Decrease counter by 1\n counter--;\n // And swap the last element with it\n temp = array[counter];\n array[counter] = array[index];\n array[index] = temp;\n }\n}\n\n/** Clamps a value to a specified range. */\nexport function clamp(min: number, x: number, max: number): number {\n return Math.max(min, Math.min(x, max));\n}\n\n/** Returns a sample from a uniform [a, b] distribution. */\nexport function randUniform(a: number, b: number) {\n return Math.random() * (b - a) + a;\n}\n\n/** Returns squared eucledian distance between two vectors. */\nexport function distSquared(a: FlatVector, b: FlatVector): number {\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n const diff = Number(a[i]) - Number(b[i]);\n result += diff * diff;\n }\n return result;\n}\n\nexport function assert(expr: boolean, msg: string|(() => string)) {\n if (!expr) {\n throw new Error(typeof msg === 'string' ? msg : msg());\n }\n}\n\nexport function assertShapesMatch(\n shapeA: number[], shapeB: number[], errorMessagePrefix = ''): void {\n assert(\n arraysEqual(shapeA, shapeB),\n errorMessagePrefix + ` Shapes ${shapeA} and ${shapeB} must match`);\n}\n\nexport function assertNonNull(a: TensorLike): void {\n assert(\n a != null,\n `The input to the tensor constructor must be a non-null value.`);\n}\n\n// NOTE: We explicitly type out what T extends instead of any so that\n// util.flatten on a nested array of number doesn't try to infer T as a\n// number[][], causing us to explicitly type util.flatten().\nexport function flatten>(\n arr: T|RecursiveArray, ret: T[] = []): T[] {\n if (Array.isArray(arr)) {\n for (let i = 0; i < arr.length; ++i) {\n flatten(arr[i], ret);\n }\n } else {\n ret.push(arr as T);\n }\n return ret;\n}\n\nexport function inferShape(val: TypedArray|number|boolean|RegularArray|\n RegularArray): number[] {\n let firstElem: typeof val = val;\n\n if (isTypedArray(val)) {\n return [(val as TypedArray).length];\n }\n if (!Array.isArray(val)) {\n return []; // Scalar.\n }\n const shape: number[] = [];\n\n while (firstElem instanceof Array) {\n shape.push(firstElem.length);\n firstElem = firstElem[0];\n }\n if (val instanceof Array) {\n deepAssertShapeConsistency(val, shape, []);\n }\n return shape;\n}\n\nfunction deepAssertShapeConsistency(\n val: number|boolean|RegularArray|RegularArray,\n shape: number[], indices?: number[]) {\n indices = indices || [];\n if (!(val instanceof Array)) {\n assert(\n shape.length === 0,\n () => `Element arr[${indices.join('][')}] is a primitive, ` +\n `but should be an array of ${shape[0]} elements`);\n return;\n }\n assert(\n shape.length > 0,\n () => `Element arr[${indices.join('][')}] should be a primitive, ` +\n `but is an array of ${val.length} elements`);\n assert(\n val.length === shape[0],\n () => `Element arr[${indices.join('][')}] should have ${shape[0]} ` +\n `elements, but has ${val.length} elements`);\n const subShape = shape.slice(1);\n for (let i = 0; i < val.length; ++i) {\n deepAssertShapeConsistency(val[i], subShape, indices.concat(i));\n }\n}\n\nexport function sizeFromShape(shape: number[]): number {\n if (shape.length === 0) {\n // Scalar.\n return 1;\n }\n let size = shape[0];\n for (let i = 1; i < shape.length; i++) {\n size *= shape[i];\n }\n return size;\n}\n\nexport function isScalarShape(shape: number[]): boolean {\n return shape.length === 0;\n}\n\nexport function arraysEqual(n1: FlatVector, n2: FlatVector) {\n if (n1.length !== n2.length) {\n return false;\n }\n for (let i = 0; i < n1.length; i++) {\n if (n1[i] !== n2[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function isInt(a: number): boolean {\n return a % 1 === 0;\n}\n\nexport function tanh(x: number): number {\n // tslint:disable-next-line:no-any\n if ((Math as any).tanh != null) {\n // tslint:disable-next-line:no-any\n return (Math as any).tanh(x);\n }\n if (x === Infinity) {\n return 1;\n } else if (x === -Infinity) {\n return -1;\n } else {\n const e2x = Math.exp(2 * x);\n return (e2x - 1) / (e2x + 1);\n }\n}\n\nexport function sizeToSquarishShape(size: number): [number, number] {\n for (let a = Math.floor(Math.sqrt(size)); a > 1; --a) {\n if (size % a === 0) {\n return [a, size / a];\n }\n }\n return [1, size];\n}\n\nexport function createShuffledIndices(n: number): Uint32Array {\n const shuffledIndices = new Uint32Array(n);\n for (let i = 0; i < n; ++i) {\n shuffledIndices[i] = i;\n }\n shuffle(shuffledIndices);\n return shuffledIndices;\n}\n\nexport function rightPad(a: string, size: number): string {\n if (size <= a.length) {\n return a;\n }\n return a + ' '.repeat(size - a.length);\n}\n\nexport function repeatedTry(\n checkFn: () => boolean, delayFn = (counter: number) => 0,\n maxCounter?: number): Promise {\n return new Promise((resolve, reject) => {\n let tryCount = 0;\n\n const tryFn = () => {\n if (checkFn()) {\n resolve();\n return;\n }\n\n tryCount++;\n\n const nextBackoff = delayFn(tryCount);\n\n if (maxCounter != null && tryCount >= maxCounter) {\n reject();\n return;\n }\n setTimeout(tryFn, nextBackoff);\n };\n\n tryFn();\n });\n}\n\n/**\n * Given the full size of the array and a shape that may contain -1 as the\n * implicit dimension, returns the inferred shape where -1 is replaced.\n * E.g. For shape=[2, -1, 3] and size=24, it will return [2, 4, 3].\n *\n * @param shape The shape, which may contain -1 in some dimension.\n * @param size The full size (number of elements) of the array.\n * @return The inferred shape where -1 is replaced with the inferred size.\n */\nexport function inferFromImplicitShape(\n shape: number[], size: number): number[] {\n let shapeProd = 1;\n let implicitIdx = -1;\n\n for (let i = 0; i < shape.length; ++i) {\n if (shape[i] > 0) {\n shapeProd *= shape[i];\n } else if (shape[i] === -1) {\n if (implicitIdx !== -1) {\n throw Error(\n `Shapes can only have 1 implicit size. ` +\n `Found - 1 at dim ${implicitIdx} and dim ${i}`);\n }\n implicitIdx = i;\n } else if (shape[i] <= 0) {\n throw Error(`Shapes can not be <= 0. Found ${shape[i]} at dim ${i}`);\n }\n }\n\n if (implicitIdx === -1) {\n if (size > 0 && size !== shapeProd) {\n throw Error(`Size(${size}) must match the product of shape ${shape}`);\n }\n return shape;\n }\n\n if (size % shapeProd !== 0) {\n throw Error(\n `The implicit shape can't be a fractional number. ` +\n `Got ${size} / ${shapeProd}`);\n }\n\n const newShape = shape.slice();\n newShape[implicitIdx] = size / shapeProd;\n return newShape;\n}\n\n/** Reduces the shape by removing all dimensions of shape 1. */\nexport function squeezeShape(shape: number[], axis?: number[]):\n {newShape: number[], keptDims: number[]} {\n const newShape: number[] = [];\n const keptDims: number[] = [];\n let j = 0;\n for (let i = 0; i < shape.length; ++i) {\n if (axis != null) {\n if (axis[j] === i && shape[i] > 1) {\n throw new Error(\n `Can't squeeze axis ${i} since its dim '${shape[i]}' is not 1`);\n }\n if ((axis[j] == null || axis[j] > i) && shape[i] === 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n if (axis[j] <= i) {\n j++;\n }\n }\n if (shape[i] > 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n }\n return {newShape, keptDims};\n}\n\nexport function getTypedArrayFromDType(\n dtype: D, size: number): DataTypeMap[D] {\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n return values;\n}\n\nexport function checkComputationForNaN(\n vals: DataTypeMap[D], dtype: D, name: string): void {\n if (dtype !== 'float32') {\n // Only floating point computations will generate NaN values\n return;\n }\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`The result of the '${name}' has NaNs.`);\n }\n }\n}\n\nexport function checkConversionForNaN(\n vals: DataTypeMap[D]|number[], dtype: D): void {\n if (dtype === 'float32') {\n // NaN is valid for floating point conversions\n return;\n }\n\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`NaN is not a valid value for dtype: '${dtype}'.`);\n }\n }\n}\n\n/**\n * Returns true if the new type can't encode the old type without loss of\n * precision.\n */\nexport function hasEncodingLoss(oldType: DataType, newType: DataType): boolean {\n if (newType === 'float32') {\n return false;\n }\n if (newType === 'int32' && oldType !== 'float32') {\n return false;\n }\n if (newType === 'bool' && oldType === 'bool') {\n return false;\n }\n return true;\n}\n\nfunction copyTypedArray(\n array: DataTypeMap[D]|number[]|boolean[], dtype: D,\n debugMode: boolean): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(array as number[]);\n } else if (dtype === 'int32') {\n if (debugMode) {\n checkConversionForNaN(array as number[], dtype);\n }\n return new Int32Array(array as number[]);\n } else if (dtype === 'bool') {\n const bool = new Uint8Array(array.length);\n for (let i = 0; i < bool.length; ++i) {\n if (Math.round(array[i] as number) !== 0) {\n bool[i] = 1;\n }\n }\n return bool;\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\nexport function isTypedArray(a: TypedArray|number|boolean|RegularArray|\n RegularArray): boolean {\n return a instanceof Float32Array || a instanceof Int32Array ||\n a instanceof Uint8Array;\n}\n\nexport function bytesPerElement(dtype: DataType): number {\n if (dtype === 'float32' || dtype === 'int32') {\n return 4;\n } else if (dtype === 'bool') {\n return 1;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nexport function isFunction(f: Function) {\n return !!(f && f.constructor && f.call && f.apply);\n}\n\nexport function nearestDivisor(size: number, start: number): number {\n for (let i = start; i < size; ++i) {\n if (size % i === 0) {\n return i;\n }\n }\n return size;\n}\n\nexport function computeStrides(shape: number[]): number[] {\n const rank = shape.length;\n if (rank < 2) {\n return [];\n }\n\n // Last dimension has implicit stride of 1, thus having D-1 (instead of D)\n // strides.\n const strides = new Array(rank - 1);\n strides[rank - 2] = shape[rank - 1];\n for (let i = rank - 3; i >= 0; --i) {\n strides[i] = strides[i + 1] * shape[i + 1];\n }\n return strides;\n}\n\nexport function toTypedArray(\n a: ArrayData, dtype: D, debugMode: boolean): DataTypeMap[D] {\n if (noConversionNeeded(a, dtype)) {\n return a as DataTypeMap[D];\n }\n if (Array.isArray(a)) {\n a = flatten(a as number[]);\n }\n return copyTypedArray(a, dtype, debugMode);\n}\n\nfunction noConversionNeeded(\n a: ArrayData, dtype: D): boolean {\n return (a instanceof Float32Array && dtype === 'float32') ||\n (a instanceof Int32Array && dtype === 'int32') ||\n (a instanceof Uint8Array && dtype === 'bool');\n}\n\nexport function makeOnesTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n const array = makeZerosTypedArray(size, dtype);\n for (let i = 0; i < array.length; i++) {\n array[i] = 1;\n }\n return array;\n}\n\nexport function makeZerosTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(size);\n } else if (dtype === 'int32') {\n return new Int32Array(size);\n } else if (dtype === 'bool') {\n return new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\n/**\n * Returns the current high-resolution real time in milliseconds. It is\n * relative to an arbitrary time in the past.\n */\nexport function now(): number {\n if (typeof performance !== 'undefined') {\n return performance.now();\n } else if (typeof process !== 'undefined') {\n const time = process.hrtime();\n return time[0] * 1000 + time[1] / 1000000;\n } else {\n throw new Error(\n 'Can not measure time in this environment. You should run tf.js ' +\n 'in the browser or in Node.js');\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimer} from './kernels/backend';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\nexport class Profiler {\n constructor(private backendTimer: BackendTimer, private logger?: Logger) {\n if (logger == null) {\n this.logger = new Logger();\n }\n }\n\n profileKernel(name: string, f: () => T | Tensor[]):\n T {\n let result: T|Tensor[];\n const holdResultWrapperFn = () => {\n result = f();\n };\n const timer = this.backendTimer.time(holdResultWrapperFn);\n\n const results: Tensor[] =\n Array.isArray(result) ? result : [result] as Tensor[];\n results.forEach(r => {\n const vals = r.dataSync();\n util.checkComputationForNaN(vals, r.dtype, name);\n\n timer.then(timing => {\n this.logger.logKernelProfile(name, r, vals, timing.kernelMs);\n });\n });\n\n return result as T;\n }\n}\n\nexport class Logger {\n logKernelProfile(\n name: string, result: Tensor, vals: TypedArray, timeMs: number) {\n const time = util.rightPad(`${timeMs}ms`, 9);\n const paddedName = util.rightPad(name, 25);\n const rank = result.rank;\n const size = result.size;\n const shape = util.rightPad(result.shape.toString(), 14);\n console.log(\n `%c${paddedName}\\t%c${time}\\t%c${rank}D ${shape}\\t%c${size}`,\n 'font-weight:bold', 'color:red', 'color:blue', 'color: orange');\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap} from './tensor_types';\nimport * as util from './util';\n\nexport interface TapeNode {\n id: number;\n name: string;\n output: Tensor;\n inputs: NamedTensorMap;\n // Optional params, defined only for ops with gradient impl.\n gradient?: (dy: Tensor|NamedTensorMap) => NamedGradientMap;\n}\n\nexport type NamedGradientMap = {\n [inputName: string]: () => Tensor;\n};\n\n/**\n * Computes a list of TapeNodes that connect x to y, filtering everything else\n * out and preserving the order of the original tape elements.\n * @param tape The tape elements to filter.\n * @param xs The input Tensors.\n * @param y The output Tensor.\n */\nexport function getFilteredNodesXToY(\n tape: TapeNode[], xs: Tensor[], y: Tensor): TapeNode[] {\n // Forward pass to compute all the nodes and Tensors that are transitively a\n // function of x.\n const tensorsFromX: {[tensorId: number]: boolean} = {};\n const nodesFromX: {[nodeId: number]: boolean} = {};\n for (let i = 0; i < xs.length; i++) {\n tensorsFromX[xs[i].id] = true;\n }\n\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n for (const inputName in nodeInputs) {\n const input = nodeInputs[inputName];\n\n let anyInputFromX = false;\n for (let j = 0; j < xs.length; j++) {\n if (tensorsFromX[input.id]) {\n tensorsFromX[node.output.id] = true;\n anyInputFromX = true;\n nodesFromX[node.id] = true;\n break;\n }\n }\n\n if (anyInputFromX) {\n break;\n }\n }\n }\n\n // Backwards pass to find all of the nodes and Tensors that lead to y.\n const tensorsLeadToY: {[tensorId: number]: boolean} = {};\n tensorsLeadToY[y.id] = true;\n const nodesToY: {[nodeId: number]: boolean} = {};\n\n for (let i = tape.length - 1; i >= 0; i--) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n\n const outputs: Tensor[] = [];\n outputs.push(node.output);\n\n // If any of the outputs lead to y, mark all of the inputs as leading to y.\n for (let j = 0; j < outputs.length; j++) {\n if (tensorsLeadToY[outputs[j].id]) {\n for (const inputName in nodeInputs) {\n tensorsLeadToY[nodeInputs[inputName].id] = true;\n nodesToY[node.id] = true;\n }\n break;\n }\n }\n }\n\n // Return the paths that come from x and lead to y.\n const filteredTape: TapeNode[] = [];\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n\n if (nodesFromX[node.id] && nodesToY[node.id]) {\n // Prune the inputs from the node that aren't a function of x.\n const prunedInputs: {[inputName: string]: Tensor} = {};\n for (const inputName in node.inputs) {\n const nodeInput = node.inputs[inputName];\n if (tensorsFromX[nodeInput.id]) {\n prunedInputs[inputName] = nodeInput;\n }\n }\n\n // Copy the node and overwrite inputsAndArgs to the pruned version.\n const prunedNode = Object.assign({}, node) as TapeNode;\n prunedNode.inputs = prunedInputs;\n prunedNode.output = node.output;\n\n filteredTape.push(prunedNode);\n }\n }\n\n return filteredTape;\n}\n\n/**\n * Backpropagate gradients through the filtered TapeNodes.\n * @param tensorAccumulatedGradientMap A map of Tensor to its gradient. This map\n * is mutated by this method.\n * @param filteredTape The filtered TapeNodes to backprop through.\n */\nexport function backpropagateGradients(\n tensorAccumulatedGradientMap: {[tensorId: number]: Tensor},\n filteredTape: TapeNode[]) {\n // Walk the tape backwards and keep a map of Tensor to its gradient.\n for (let i = filteredTape.length - 1; i >= 0; i--) {\n const node = filteredTape[i];\n\n const dy = tensorAccumulatedGradientMap[node.output.id];\n\n if (node.gradient == null) {\n throw new Error(\n `Cannot compute gradient: gradient function not found ` +\n `for ${node.name}.`);\n }\n\n // Backprop dy through this node and accumulate gradients over the inputs.\n const inputGradients = node.gradient(dy);\n for (const inputName in node.inputs) {\n if (!(inputName in inputGradients)) {\n throw new Error(\n `Cannot backprop through input ${inputName}. ` +\n `Available gradients found: ${Object.keys(inputGradients)}.`);\n }\n\n // Call the gradient function.\n const dx = inputGradients[inputName]();\n const x = node.inputs[inputName];\n if (!util.arraysEqual(dx.shape, x.shape)) {\n throw new Error(\n `Error in gradient for op ${node.name}. The gradient of input ` +\n `'${inputName}' has shape '${dx.shape}', which does not match ` +\n `the shape of the input '${x.shape}'`);\n }\n\n if (tensorAccumulatedGradientMap[x.id] == null) {\n tensorAccumulatedGradientMap[x.id] = dx;\n } else {\n const curGradient = tensorAccumulatedGradientMap[x.id];\n tensorAccumulatedGradientMap[x.id] = curGradient.add(dx);\n curGradient.dispose();\n }\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, TypedArray} from './types';\nimport {computeStrides, rightPad, sizeFromShape} from './util';\n\n// Maximum number of values before we decide to show ellipsis.\nconst FORMAT_LIMIT_NUM_VALS = 20;\n// Number of first and last values to show when displaying a, b,...,y, z.\nconst FORMAT_NUM_FIRST_LAST_VALS = 3;\n// Number of significant digits to show.\nconst FORMAT_NUM_SIG_DIGITS = 7;\n\nexport function tensorToString(\n vals: TypedArray, shape: number[], dtype: DataType, verbose: boolean) {\n const strides = computeStrides(shape);\n const padPerCol = computeMaxSizePerColumn(vals, shape, strides);\n const rank = shape.length;\n const valsLines = subTensorToString(vals, shape, strides, padPerCol);\n const lines = ['Tensor'];\n if (verbose) {\n lines.push(` dtype: ${dtype}`);\n lines.push(` rank: ${rank}`);\n lines.push(` shape: [${shape}]`);\n lines.push(` values:`);\n }\n lines.push(valsLines.map(l => ' ' + l).join('\\n'));\n return lines.join('\\n');\n}\n\nfunction computeMaxSizePerColumn(\n vals: TypedArray, shape: number[], strides: number[]): number[] {\n const n = sizeFromShape(shape);\n const numCols = strides[strides.length - 1];\n const padPerCol = new Array(numCols).fill(0);\n const rank = shape.length;\n if (rank > 1) {\n for (let row = 0; row < n / numCols; row++) {\n const offset = row * numCols;\n for (let j = 0; j < numCols; j++) {\n padPerCol[j] =\n Math.max(padPerCol[j], valToString(vals[offset + j], 0).length);\n }\n }\n }\n return padPerCol;\n}\n\nfunction valToString(val: number, pad: number) {\n return rightPad(\n parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), pad);\n}\n\nfunction subTensorToString(\n vals: TypedArray, shape: number[], strides: number[], padPerCol: number[],\n isLast = true): string[] {\n const size = shape[0];\n const rank = shape.length;\n if (rank === 0) {\n return [vals[0].toString()];\n }\n\n if (rank === 1) {\n if (size > FORMAT_LIMIT_NUM_VALS) {\n const firstVals =\n Array.from(vals.subarray(0, FORMAT_NUM_FIRST_LAST_VALS));\n const lastVals =\n Array.from(vals.subarray(size - FORMAT_NUM_FIRST_LAST_VALS, size));\n return [\n '[' + firstVals.map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ', ..., ' +\n lastVals\n .map(\n (x, i) => valToString(\n x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i]))\n .join(', ') +\n ']'\n ];\n }\n return [\n '[' +\n Array.from(vals).map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ']'\n ];\n }\n\n // The array is rank 2 or more.\n const subshape = shape.slice(1);\n const substrides = strides.slice(1);\n const stride = strides[0];\n const lines: string[] = [];\n if (size > FORMAT_LIMIT_NUM_VALS) {\n for (let i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n false /* isLast */));\n }\n lines.push('...');\n for (let i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n } else {\n for (let i = 0; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n }\n const sep = rank === 2 ? ',' : '';\n lines[0] = '[' + lines[0] + sep;\n for (let i = 1; i < lines.length - 1; i++) {\n lines[i] = ' ' + lines[i] + sep;\n }\n let newLineSep = ',\\n';\n for (let i = 2; i < rank; i++) {\n newLineSep += '\\n';\n }\n lines[lines.length - 1] =\n ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep);\n return lines;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensorToString} from './tensor_format';\nimport {DataType, Rank, ShapeMap, TypedArray} from './types';\nimport * as util from './util';\nimport {computeStrides} from './util';\n\n/** @hidden */\nexport interface TensorData {\n dataId?: DataId;\n values?: TypedArray;\n}\n\n/**\n * A mutable object, similar to `Tensor`, that allows users to set values\n * at locations before converting to an immutable `Tensor`.\n *\n * See `buffer` for creating a tensor buffer.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class TensorBuffer {\n size: number;\n shape: ShapeMap[R];\n strides: number[];\n values: TypedArray;\n\n constructor(shape: ShapeMap[R], public dtype: DataType, values: TypedArray) {\n if (values != null) {\n const n = values.length;\n const size = util.sizeFromShape(shape);\n util.assert(\n n === size,\n `Length of values '${n}' does not match the size ` +\n `inferred by the shape '${size}'`);\n }\n this.shape = shape.slice();\n this.values =\n values || util.getTypedArrayFromDType(dtype, util.sizeFromShape(shape));\n this.strides = computeStrides(shape);\n this.size = util.sizeFromShape(shape);\n }\n\n /**\n * Sets a value in the buffer at a given location.\n *\n * @param value The value to set.\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n set(value: number, ...locs: number[]) {\n if (locs.length === 0) {\n locs = [0];\n }\n util.assert(\n locs.length === this.rank,\n `The number of provided coordinates (${locs.length}) must ` +\n `match the rank (${this.rank})`);\n const index = this.locToIndex(locs);\n this.values[index] = value;\n }\n\n /**\n * Returns the value in the buffer at the provided location.\n *\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n get(...locs: number[]): number {\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.values[index];\n }\n\n locToIndex(locs: number[]): number {\n if (this.rank === 0) {\n return 0;\n } else if (this.rank === 1) {\n return locs[0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return index;\n }\n\n indexToLoc(index: number): number[] {\n if (this.rank === 0) {\n return [];\n } else if (this.rank === 1) {\n return [index];\n }\n const locs: number[] = new Array(this.shape.length);\n for (let i = 0; i < locs.length - 1; ++i) {\n locs[i] = Math.floor(index / this.strides[i]);\n index -= locs[i] * this.strides[i];\n }\n locs[locs.length - 1] = index;\n return locs;\n }\n\n get rank() {\n return this.shape.length;\n }\n\n /**\n * Creates an immutable `Tensor` object from the buffer.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n toTensor(): Tensor {\n return Tensor.make(this.shape, {values: this.values}, this.dtype);\n }\n}\n\nexport interface TensorTracker {\n registerTensor(t: Tensor): void;\n disposeTensor(t: Tensor): void;\n write(dataId: DataId, values: TypedArray): void;\n read(dataId: DataId): Promise;\n readSync(dataId: DataId): TypedArray;\n registerVariable(v: Variable): void;\n}\n\n/**\n * The Tensor class calls into this handler to delegate chaining operations.\n */\nexport interface OpHandler {\n cast(x: T, dtype: DataType): T;\n buffer(\n shape: ShapeMap[R], dtype: DataType,\n values?: TypedArray): TensorBuffer;\n print(x: T, verbose: boolean): void;\n reshape(x: Tensor, shape: ShapeMap[R2]): Tensor;\n expandDims(x: Tensor, axis: number): Tensor;\n cumsum(\n x: Tensor, axis: number, exclusive: boolean, reverse: boolean): T;\n squeeze(x: Tensor, axis?: number[]): T;\n clone(x: T): T;\n tile(x: T, reps: number[]): T;\n gather(x: T, indices: Tensor1D, axis: number): T;\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D;\n dot(t1: Tensor, t2: Tensor): Tensor;\n norm(\n x: Tensor, ord: number|'euclidean'|'fro', axis: number|number[],\n keepDims: boolean): Tensor;\n slice>(\n x: T, begin: number|number[], size?: number|number[]): T;\n reverse(x: T, axis?: number|number[]): T;\n concat(tensors: T[], axis: number): T;\n stack(tensors: T[], axis: number): Tensor;\n unstack(value: T, axis: number): Tensor[];\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T;\n batchNormalization(\n x: Tensor, mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon: number, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor;\n all(x: Tensor, axis: number|number[], keepDims: boolean): T;\n any(x: Tensor, axis: number|number[], keepDims: boolean): T;\n logSumExp(\n x: Tensor, axis: number|number[], keepDims: boolean): T;\n sum(x: Tensor, axis: number|number[], keepDims: boolean): T;\n mean(x: Tensor, axis: number|number[], keepDims: boolean):\n T;\n min(x: Tensor, axis: number|number[], keepDims: boolean): T;\n max(x: Tensor, axis: number|number[], keepDims: boolean): T;\n argMin(x: Tensor, axis: number): T;\n argMax(x: Tensor, axis: number): T;\n add(a: Tensor, b: Tensor): T;\n addStrict(a: T, b: T): T;\n sub(a: Tensor, b: Tensor): T;\n subStrict(a: T, b: T): T;\n pow(base: T, exp: Tensor): T;\n powStrict(base: T, exp: Tensor): T;\n mul(a: Tensor, b: Tensor): T;\n mulStrict(a: T, b: T): T;\n div(a: Tensor, b: Tensor): T;\n floorDiv(a: Tensor, b: Tensor): T;\n divStrict(a: T, b: T): T;\n mod(a: Tensor, b: Tensor): T;\n modStrict(a: T, b: T): T;\n minimum(a: Tensor, b: Tensor): T;\n minimumStrict(a: T, b: T): T;\n maximum(a: Tensor, b: Tensor): T;\n maximumStrict(a: T, b: T): T;\n squaredDifference(a: Tensor, b: Tensor): T;\n squaredDifferenceStrict(a: T, b: T): T;\n transpose(x: T, perm?: number[]): T;\n logicalNot(x: T): T;\n logicalAnd(a: Tensor, b: Tensor): T;\n logicalOr(a: Tensor, b: Tensor): T;\n logicalXor(a: Tensor, b: Tensor): T;\n where(condition: Tensor, a: T, b: T): T;\n notEqual(a: Tensor, b: Tensor): T;\n notEqualStrict(a: T, b: T): T;\n less(a: Tensor, b: Tensor): T;\n lessStrict(a: T, b: T): T;\n equal(a: Tensor, b: Tensor): T;\n equalStrict(a: T, b: T): T;\n lessEqual(a: Tensor, b: Tensor): T;\n lessEqualStrict(a: T, b: T): T;\n greater(a: Tensor, b: Tensor): T;\n greaterStrict(a: T, b: T): T;\n greaterEqual(a: Tensor, b: Tensor): T;\n greaterEqualStrict(a: T, b: T): T;\n neg(x: T): T;\n ceil(x: T): T;\n floor(x: T): T;\n sign(x: T): T;\n round(x: T): T;\n exp(x: T): T;\n expm1(x: T): T;\n log(x: T): T;\n log1p(x: T): T;\n sqrt(x: T): T;\n rsqrt(x: T): T;\n square(x: T): T;\n reciprocal(x: T): T;\n abs(x: T): T;\n clipByValue(\n x: T, clipValueMin: number, clipValueMax: number): T;\n sigmoid(x: T): T;\n logSigmoid(x: T): T;\n softplus(x: T): T;\n sin(x: T): T;\n cos(x: T): T;\n tan(x: T): T;\n asin(x: T): T;\n acos(x: T): T;\n atan(x: T): T;\n sinh(x: T): T;\n cosh(x: T): T;\n tanh(x: T): T;\n asinh(x: T): T;\n acosh(x: T): T;\n atanh(x: T): T;\n erf(x: T): T;\n step(x: T, alpha: number): T;\n relu(x: T): T;\n elu(x: T): T;\n selu(x: T): T;\n leakyRelu(x: T, alpha: number): T;\n prelu(x: T, alpha: T): T;\n softmax(logits: T, dim: number): T;\n image: {\n resizeBilinear(\n images: T, size: [number, number], alignCorners: boolean): T;\n resizeNearestNeighbor(\n images: T, size: [number, number], alignCorners: boolean): T;\n };\n conv1d(\n x: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW', dilation: number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2dTranspose(\n x: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n depthwiseConv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n maxPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n avgPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n localResponseNormalization(\n x: T, depthRadius: number, bias: number, alpha: number, beta: number): T;\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): T;\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T;\n spaceToBatchND(\n x: T, blockShape: number[], paddings: number[][]): T;\n}\n\n// For tracking tensor creation and disposal.\nlet trackerFn: () => TensorTracker = null;\n// Used by chaining methods to call into ops.\nlet opHandler: OpHandler = null;\n\n/**\n * An external consumer can register itself as the tensor tracker. This way\n * the Tensor class can notify the tracker for every tensor created and\n * disposed.\n */\nexport function setTensorTracker(fn: () => TensorTracker) {\n trackerFn = fn;\n}\n\n/**\n * An external consumer can register itself as the op handler. This way the\n * Tensor class can have chaining methods that call into ops via the op handler.\n */\nexport function setOpHandler(handler: OpHandler) {\n opHandler = handler;\n}\n\n/**\n * We wrap data id since we use weak map to avoid memory leaks.\n * Since we have our own memory management, we have a reference counter\n * mapping a tensor to its data, so there is always a pointer (even if that\n * data is otherwise garbage collectable).\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/\n * Global_Objects/WeakMap\n */\nexport type DataId = object; // object instead of {} to force non-primitive.\n\n/**\n * A `Tensor` object represents an immutable, multidimensional array of numbers\n * that has a shape and a data type.\n *\n * See `tensor` for details on how to create a `Tensor`.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Tensor {\n private static nextId = 0;\n\n /** Unique id of this tensor. */\n readonly id: number;\n /**\n * Id of the bucket holding the data for this tensor. Multiple arrays can\n * point to the same bucket (e.g. when calling array.reshape()).\n */\n dataId: DataId;\n /** The shape of the tensor. */\n readonly shape: ShapeMap[R];\n /** Number of elements in the tensor. */\n readonly size: number;\n /** The data type for the array. */\n readonly dtype: DataType;\n /** The rank type for the array (see `Rank` enum). */\n readonly rankType: R;\n\n /**\n * Number of elements to skip in each dimension when indexing. See\n * https://docs.scipy.org/doc/numpy/reference/generated/\\\n * numpy.ndarray.strides.html\n */\n readonly strides: number[];\n\n protected constructor(\n shape: ShapeMap[R], dtype: DataType, values?: TypedArray,\n dataId?: DataId) {\n this.size = util.sizeFromShape(shape);\n if (values != null) {\n util.assert(\n this.size === values.length,\n `Constructing tensor of shape (${this.size}) should match the ` +\n `length of values (${values.length})`);\n }\n this.shape = shape.slice();\n this.dtype = dtype || 'float32';\n this.strides = computeStrides(shape);\n this.dataId = dataId != null ? dataId : {};\n this.id = Tensor.nextId++;\n this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher') as R;\n trackerFn().registerTensor(this);\n if (values != null) {\n trackerFn().write(this.dataId, values);\n }\n }\n\n /**\n * Makes a new tensor with the provided shape and values. Values should be in\n * a flat array.\n */\n static make, D extends DataType = 'float32',\n R extends Rank = Rank>(\n shape: ShapeMap[R], data: TensorData, dtype?: D): T {\n return new Tensor(shape, dtype, data.values, data.dataId) as T;\n }\n\n /** Flatten a Tensor to a 1D array. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n flatten(): Tensor1D {\n this.throwIfDisposed();\n return this.as1D();\n }\n\n /** Converts a size-1 `Tensor` to a `Scalar`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asScalar(): Scalar {\n this.throwIfDisposed();\n util.assert(this.size === 1, 'The array must have only 1 element.');\n return this.reshape([]);\n }\n\n /** Converts a `Tensor` to a `Tensor1D`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as1D(): Tensor1D {\n this.throwIfDisposed();\n return this.reshape([this.size]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor2D`.\n *\n * @param rows Number of rows in `Tensor2D`.\n * @param columns Number of columns in `Tensor2D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as2D(rows: number, columns: number): Tensor2D {\n this.throwIfDisposed();\n return this.reshape([rows, columns]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor3D`.\n *\n * @param rows Number of rows in `Tensor3D`.\n * @param columns Number of columns in `Tensor3D`.\n * @param depth Depth of `Tensor3D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as3D(rows: number, columns: number, depth: number): Tensor3D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor4D`.\n *\n * @param rows Number of rows in `Tensor4D`.\n * @param columns Number of columns in `Tensor4D`.\n * @param depth Depth of `Tensor4D`.\n * @param depth2 4th dimension of `Tensor4D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as4D(rows: number, columns: number, depth: number, depth2: number): Tensor4D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth, depth2]);\n }\n\n /**\n * Casts a `Tensor` to a specified dtype.\n *\n * @param dtype Data-type to cast the tensor to.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asType(this: T, dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this, dtype) as T;\n }\n\n get rank(): number {\n return this.shape.length;\n }\n\n /**\n * Returns the value in the tensor at the provided location.\n * If using WebGL backend, this is a blocking call.\n * Prefer calling the `async data()[flatIndex]` method instead.\n *\n * @param locs The location indices.\n */\n get(...locs: number[]) {\n util.assert(\n locs.length === this.rank,\n 'Number of coordinates in get() must match the rank of the tensor');\n this.throwIfDisposed();\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.dataSync()[index];\n }\n\n /** Returns a `TensorBuffer` that holds the underlying data. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n buffer(): TensorBuffer {\n return opHandler.buffer(this.shape, this.dtype, this.dataSync());\n }\n\n /**\n * Asynchronously downloads the values from the `Tensor`. Returns a promise of\n * `TypedArray` that resolves when the computation has finished.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n async data(): Promise {\n this.throwIfDisposed();\n return trackerFn().read(this.dataId);\n }\n\n /**\n * Synchronously downloads the values from the `Tensor`. This blocks the UI\n * thread until the values are ready, which can cause performance issues.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dataSync(): TypedArray {\n this.throwIfDisposed();\n return trackerFn().readSync(this.dataId);\n }\n\n /**\n * Disposes `Tensor` from memory.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n trackerFn().disposeTensor(this);\n this.isDisposedInternal = true;\n }\n\n private isDisposedInternal = false;\n get isDisposed(): boolean {\n return this.isDisposedInternal;\n }\n\n private throwIfDisposed() {\n if (this.isDisposed) {\n throw new Error(`Tensor is disposed.`);\n }\n }\n\n /** Casts the array to type `float32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toFloat(this: T): T {\n return this.asType('float32');\n }\n\n /** Casts the array to type `int32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toInt() {\n return this.asType('int32');\n }\n\n /** Casts the array to type `bool` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toBool() {\n return this.asType('bool');\n }\n\n /**\n * Prints the `Tensor`. See `print` for details.\n *\n * @param verbose Whether to print verbose information about the tensor,\n * including dtype and size.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n print(verbose = false): void {\n return opHandler.print(this, verbose);\n }\n\n /**\n * Reshapes the tensor into the provided shape.\n * See `reshape` for more details.\n *\n * @param newShape An array of integers defining the output tensor shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshape(newShape: ShapeMap[R2]): Tensor {\n this.throwIfDisposed();\n return opHandler.reshape(this, newShape);\n }\n\n /**\n * Reshapes the tensor into the shape of the provided tensor.\n *\n * @param x The tensor of required shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshapeAs(x: T): T {\n this.throwIfDisposed();\n return this.reshape(x.shape) as T;\n }\n\n /**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape. See `expandDims` for details.\n *\n * @param axis The dimension index at which to insert shape of 1. Defaults to\n * 0 (the first dimension).\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n expandDims(axis = 0): Tensor {\n return opHandler.expandDims(this, axis);\n }\n\n /**\n * Returns the cumulative sum of the `Tensor` along `axis`.\n *\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Defaults to\n * false. If set to true then the sum of each tensor entry does not include\n * its own value, but only the values previous to it along the specified\n * axis.\n * @param reverse Whether to sum in the opposite direction. Defaults to\n * false.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n cumsum(axis = 0, exclusive = false, reverse = false): T {\n return opHandler.cumsum(this, axis, exclusive, reverse);\n }\n\n /**\n * Returns a `Tensor` with dimensions of size 1 removed from the shape.\n * See `squeeze` for more details.\n *\n * @param axis A list of numbers. If specified, only squeezes the\n * dimensions listed. The dimension index starts at 0. It is an error to\n * squeeze a dimension that is not 1.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n squeeze(axis?: number[]): T {\n this.throwIfDisposed();\n return opHandler.squeeze(this, axis);\n }\n\n /** Returns a copy of the tensor. See `clone` for details. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n clone(this: T): T {\n this.throwIfDisposed();\n return opHandler.clone(this);\n }\n\n /** Returns a human-readable description of the tensor. Useful for logging. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toString(verbose = false): string {\n const vals = this.dataSync();\n return tensorToString(vals, this.shape, this.dtype, verbose);\n }\n\n // Below is chain API that is not exposed to docs to avoid repetition. To\n // expose a method, move it above this comment and add @doc and jsdoc.\n\n tile(this: T, reps: number[]): T {\n this.throwIfDisposed();\n return opHandler.tile(this, reps) as T;\n }\n\n gather(this: T, indices: Tensor1D, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.gather(this, indices, axis) as T;\n }\n\n matMul(b: Tensor2D, transposeA = false, transposeB = false): Tensor2D {\n this.throwIfDisposed();\n return opHandler.matMul(this as Tensor2D, b, transposeA, transposeB);\n }\n dot(b: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.dot(this, b);\n }\n norm(\n ord: number|'euclidean'|'fro' = 'euclidean', axis: number|number[] = null,\n keepDims = false): Tensor {\n this.throwIfDisposed();\n return opHandler.norm(this, ord, axis, keepDims);\n }\n slice>(\n this: T, begin: number|number[], size?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.slice(this, begin, size);\n }\n reverse(this: T, axis?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.reverse(this, axis);\n }\n concat(this: T, x: T, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.concat([this, x], axis);\n }\n stack(x: Tensor, axis = 0): Tensor {\n return opHandler.stack([this, x], axis);\n }\n unstack(x: Tensor, axis = 0): Tensor[] {\n return opHandler.unstack(this, axis);\n }\n pad(\n this: T, paddings: Array<[number, number]>, constantValue = 0): T {\n return opHandler.pad(this, paddings, constantValue);\n }\n batchNormalization(\n mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon = .001, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor {\n this.throwIfDisposed();\n return opHandler.batchNormalization(\n this, mean, variance, varianceEpsilon, scale, offset);\n }\n\n // Reduction ops.\n all(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.all(this, axis, keepDims);\n }\n any(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.any(this, axis, keepDims);\n }\n logSumExp(axis: number|number[] = null, keepDims = false):\n T {\n this.throwIfDisposed();\n return opHandler.logSumExp(this, axis, keepDims);\n }\n sum(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.sum(this, axis, keepDims);\n }\n mean(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.mean(this, axis, keepDims);\n }\n min(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.min(this, axis, keepDims);\n }\n max(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.max(this, axis, keepDims);\n }\n argMin(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMin(this, axis);\n }\n argMax(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMax(this, axis);\n }\n\n // Transformations\n cast(dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this as T, dtype) as T;\n }\n\n // Binary ops.\n\n add(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.add(this, x);\n }\n addStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.addStrict(this, x) as T;\n }\n sub(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.sub(this, x);\n }\n subStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.subStrict(this, x) as T;\n }\n pow(this: T, exp: Tensor): T {\n this.throwIfDisposed();\n return opHandler.pow(this, exp);\n }\n powStrict(exp: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.powStrict(this, exp);\n }\n mul(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mul(this, x);\n }\n mulStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.mulStrict(this, x) as T;\n }\n div(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.div(this, x);\n }\n floorDiv(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.floorDiv(this, x);\n }\n divStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.divStrict(this, x) as T;\n }\n minimum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.minimum(this, x);\n }\n minimumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.minimumStrict(this, x) as T;\n }\n maximum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.maximum(this, x);\n }\n maximumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.maximumStrict(this, x) as T;\n }\n mod(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mod(this, x);\n }\n modStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.modStrict(this, x) as T;\n }\n squaredDifference(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.squaredDifference(this, x);\n }\n squaredDifferenceStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.squaredDifferenceStrict(this, x) as T;\n }\n transpose(this: T, perm?: number[]): T {\n this.throwIfDisposed();\n return opHandler.transpose(this, perm);\n }\n\n // Compare ops.\n\n notEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.notEqual(this, x);\n }\n notEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.notEqualStrict(this, x) as T;\n }\n less(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.less(this, x);\n }\n lessStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessStrict(this, x) as T;\n }\n equal(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.equal(this, x);\n }\n equalStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.equalStrict(this, x) as T;\n }\n lessEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.lessEqual(this, x);\n }\n lessEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessEqualStrict(this, x) as T;\n }\n greater(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greater(this, x);\n }\n greaterStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterStrict(this, x) as T;\n }\n greaterEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greaterEqual(this, x);\n }\n greaterEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterEqualStrict(this, x) as T;\n }\n\n // Compare ops.\n logicalAnd(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalAnd(this, x);\n }\n logicalOr(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalOr(this, x);\n }\n logicalNot(this: T): T {\n this.throwIfDisposed();\n return opHandler.logicalNot(this);\n }\n logicalXor(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalXor(this, x);\n }\n where(condition: Tensor, x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.where(condition, this, x);\n }\n\n // Unary ops.\n neg(this: T): T {\n this.throwIfDisposed();\n return opHandler.neg(this);\n }\n ceil(this: T): T {\n this.throwIfDisposed();\n return opHandler.ceil(this);\n }\n floor(this: T): T {\n this.throwIfDisposed();\n return opHandler.floor(this);\n }\n sign(this: T): T {\n this.throwIfDisposed();\n return opHandler.sign(this);\n }\n exp(this: T): T {\n this.throwIfDisposed();\n return opHandler.exp(this);\n }\n expm1(this: T): T {\n this.throwIfDisposed();\n return opHandler.expm1(this);\n }\n log(this: T): T {\n this.throwIfDisposed();\n return opHandler.log(this);\n }\n log1p(this: T): T {\n this.throwIfDisposed();\n return opHandler.log1p(this);\n }\n sqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.sqrt(this);\n }\n rsqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.rsqrt(this);\n }\n square(this: T): T {\n this.throwIfDisposed();\n return opHandler.square(this);\n }\n reciprocal(this: T): T {\n this.throwIfDisposed();\n return opHandler.reciprocal(this);\n }\n abs(this: T): T {\n this.throwIfDisposed();\n return opHandler.abs(this);\n }\n clipByValue(min: number, max: number): Tensor {\n this.throwIfDisposed();\n return opHandler.clipByValue(this, min, max);\n }\n relu(this: T): T {\n this.throwIfDisposed();\n return opHandler.relu(this);\n }\n elu(this: T): T {\n this.throwIfDisposed();\n return opHandler.elu(this);\n }\n selu(this: T): T {\n this.throwIfDisposed();\n return opHandler.selu(this);\n }\n leakyRelu(alpha = 0.2): Tensor {\n this.throwIfDisposed();\n return opHandler.leakyRelu(this, alpha);\n }\n prelu(alpha: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.prelu(this, alpha);\n }\n sigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.sigmoid(this);\n }\n logSigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.logSigmoid(this);\n }\n softplus(this: T): T {\n this.throwIfDisposed();\n return opHandler.softplus(this);\n }\n sin(this: T): T {\n this.throwIfDisposed();\n return opHandler.sin(this);\n }\n cos(this: T): T {\n this.throwIfDisposed();\n return opHandler.cos(this);\n }\n tan(this: T): T {\n this.throwIfDisposed();\n return opHandler.tan(this);\n }\n asin(this: T): T {\n this.throwIfDisposed();\n return opHandler.asin(this);\n }\n acos(this: T): T {\n this.throwIfDisposed();\n return opHandler.acos(this);\n }\n atan(this: T): T {\n this.throwIfDisposed();\n return opHandler.atan(this);\n }\n sinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.sinh(this);\n }\n cosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.cosh(this);\n }\n tanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.tanh(this);\n }\n asinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.asinh(this);\n }\n acosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.acosh(this);\n }\n atanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.atanh(this);\n }\n erf(this: T): T {\n this.throwIfDisposed();\n return opHandler.erf(this);\n }\n round(this: T): T {\n this.throwIfDisposed();\n return opHandler.round(this);\n }\n step(this: T, alpha = 0.0): T {\n this.throwIfDisposed();\n return opHandler.step(this, alpha);\n }\n softmax(this: T, dim = -1): T {\n this.throwIfDisposed();\n return opHandler.softmax(this, dim) as T;\n }\n\n // Image ops.\n resizeBilinear(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeBilinear(this, newShape2D, alignCorners);\n }\n\n resizeNearestNeighbor(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeNearestNeighbor(\n this, newShape2D, alignCorners);\n }\n\n // Convolutions.\n conv1d(\n this: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv1d(\n this, filter, stride, pad, dataFormat, dilation, dimRoundingMode);\n }\n conv2d(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n conv2dTranspose(\n this: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2dTranspose(\n this, filter, outputShape, strides, pad, dimRoundingMode);\n }\n depthwiseConv2D(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.depthwiseConv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n\n // Pooling.\n avgPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.avgPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n maxPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.maxPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n localResponseNormalization(\n this: T, radius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n return opHandler.localResponseNormalization(\n this, radius, bias, alpha, beta);\n }\n\n variable(trainable = true, name?: string, dtype?: DataType): Variable {\n this.throwIfDisposed();\n return Variable.variable(this, trainable, name, dtype);\n }\n\n unsortedSegmentSum(\n this: T, segmentIds: Tensor1D, numSegments: number): T {\n this.throwIfDisposed();\n return opHandler.unsortedSegmentSum(this, segmentIds, numSegments);\n }\n\n batchToSpaceND(\n this: T, blockShape: number[], crops: number[][]): T {\n this.throwIfDisposed();\n return opHandler.batchToSpaceND(this, blockShape, crops);\n }\n\n spaceToBatchND(\n this: T, blockShape: number[], paddings: number[][]): T {\n this.throwIfDisposed();\n return opHandler.spaceToBatchND(this, blockShape, paddings);\n }\n}\nObject.defineProperty(Tensor, Symbol.hasInstance, {\n value: (instance: Tensor) => {\n return !!instance && instance.shape != null && instance.dtype != null;\n }\n});\n\n/** @doclink Tensor */\nexport type Scalar = Tensor;\n/** @doclink Tensor */\nexport type Tensor1D = Tensor;\n/** @doclink Tensor */\nexport type Tensor2D = Tensor;\n/** @doclink Tensor */\nexport type Tensor3D = Tensor;\n/** @doclink Tensor */\nexport type Tensor4D = Tensor;\n/** @doclink Tensor */\nexport type Tensor5D = Tensor;\n/** @doclink Tensor */\nexport type Tensor6D = Tensor;\n\n/**\n * A mutable `Tensor`, useful for persisting state, e.g. for training.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Variable extends Tensor {\n private static nextVarId = 0;\n name: string;\n\n /**\n * Private constructor since we can not add logic before calling `super()`.\n * Instead, we expose static `Variable.variable` method below, which will be\n * added to global namespace.\n */\n private constructor(\n initialValue: Tensor, public trainable = true, name?: string) {\n super(\n initialValue.shape, initialValue.dtype, null /* values */,\n initialValue.dataId);\n this.name = name;\n if (this.name == null) {\n this.name = Variable.nextVarId.toString();\n Variable.nextVarId++;\n }\n try {\n trackerFn().registerVariable(this);\n } catch (ex) {\n trackerFn().disposeTensor(this);\n throw ex;\n }\n }\n\n /**\n * Creates a new variable with the provided initial value.\n * ```js\n * const x = tf.variable(tf.tensor([1, 2, 3]));\n * x.assign(tf.tensor([4, 5, 6]));\n *\n * x.print();\n * ```\n *\n * @param initialValue Initial value for the tensor.\n * @param trainable If true, optimizers are allowed to update it.\n * @param name Name of the variable. Defaults to a unique id.\n * @param dtype If set, initialValue will be converted to the given type.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n static variable(\n initialValue: Tensor, trainable = true, name?: string,\n dtype?: DataType): Variable {\n if (dtype != null && dtype !== initialValue.dtype) {\n initialValue = initialValue.asType(dtype) as Tensor;\n }\n return new Variable(initialValue, trainable, name);\n }\n\n /**\n * Assign a new `Tensor` to this variable. The new `Tensor` must have the\n * same shape and dtype as the old `Tensor`.\n *\n * @param newValue New tensor to be assigned to this variable.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n assign(newValue: Tensor): void {\n if (newValue.dtype !== this.dtype) {\n throw new Error(\n `dtype of the new value (${newValue.dtype}) and ` +\n `previous value (${this.dtype}) must match`);\n }\n if (!util.arraysEqual(newValue.shape, this.shape)) {\n throw new Error(\n `shape of the new value (${newValue.shape}) and ` +\n `previous value (${this.shape}) must match`);\n }\n trackerFn().disposeTensor(this);\n this.dataId = newValue.dataId;\n trackerFn().registerTensor(this);\n }\n}\nObject.defineProperty(Variable, Symbol.hasInstance, {\n value: (instance: Variable) => {\n return instance instanceof Tensor && instance.assign != null &&\n instance.assign instanceof Function;\n }\n});\n\nconst variable = Variable.variable;\nexport {variable};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap, TensorContainer, TensorContainerArray} from './tensor_types';\nimport {assert} from './util';\n\nexport function assertTypesMatch(a: Tensor, b: Tensor): void {\n assert(\n a.dtype === b.dtype,\n ` The dtypes of the first(${a.dtype}) and` +\n ` second(${b.dtype}) input must match`);\n}\n\nexport function isTensorInList(tensor: Tensor, tensorList: Tensor[]): boolean {\n for (let i = 0; i < tensorList.length; i++) {\n if (tensorList[i].id === tensor.id) {\n return true;\n }\n }\n return false;\n}\n\nexport function flattenNameArrayMap(\n nameArrayMap: Tensor|NamedTensorMap, keys?: string[]): Tensor[] {\n const xs: Tensor[] = [];\n if (nameArrayMap instanceof Tensor) {\n xs.push(nameArrayMap);\n } else {\n const xMap = nameArrayMap as {[xName: string]: Tensor};\n for (let i = 0; i < keys.length; i++) {\n xs.push(xMap[keys[i]]);\n }\n }\n return xs;\n}\n\nexport function unflattenToNameArrayMap(\n keys: string[], flatArrays: Tensor[]): NamedTensorMap {\n if (keys.length !== flatArrays.length) {\n throw new Error(\n `Cannot unflatten Tensor[], keys and arrays are not of same length.`);\n }\n const result: NamedTensorMap = {};\n for (let i = 0; i < keys.length; i++) {\n result[keys[i]] = flatArrays[i];\n }\n return result;\n}\n\n/**\n * Extracts any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. In general it\n * is safe to pass any object here, except that `Promise`s are not\n * supported.\n * @returns An array of `Tensors` found within the passed object. If the\n * argument is simply a `Tensor', a list containing that `Tensor` is\n * returned. If the object is not a `Tensor` or does not\n * contain `Tensors`, an empty list is returned.\n */\nexport function getTensorsInContainer(result: TensorContainer): Tensor[] {\n const list: Tensor[] = [];\n const seen = new Set<{}|void>();\n walkTensorContainer(result, list, seen);\n return list;\n}\n\nfunction walkTensorContainer(\n container: TensorContainer, list: Tensor[], seen: Set<{}|void>): void {\n if (container == null) {\n return;\n }\n if (container instanceof Tensor) {\n list.push(container);\n return;\n }\n if (!isIterable(container)) {\n return;\n }\n // Iteration over keys works also for arrays.\n const iterable = container as TensorContainerArray;\n for (const k in iterable) {\n const val = iterable[k];\n if (!seen.has(val)) {\n seen.add(val);\n walkTensorContainer(val, list, seen);\n }\n }\n}\n\n// tslint:disable-next-line:no-any\nfunction isIterable(obj: any): boolean {\n return Array.isArray(obj) || typeof obj === 'object';\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimingInfo, KernelBackend} from './kernels/backend';\nimport {Profiler} from './profiler';\nimport {backpropagateGradients, getFilteredNodesXToY, NamedGradientMap, TapeNode} from './tape';\nimport {DataId, Tensor, Tensor3D, Variable} from './tensor';\nimport {NamedTensorMap, NamedVariableMap, TensorContainer} from './tensor_types';\nimport {getTensorsInContainer, isTensorInList} from './tensor_util';\nimport {TypedArray} from './types';\nimport * as util from './util';\nimport {makeOnesTypedArray, now, sizeFromShape} from './util';\n\n/**\n * A function that computes an output. The save function is for saving tensors\n * computed in the forward pass, that we need in the backwards pass.\n */\nexport type ForwardFunc =\n (backend: KernelBackend, save?: (tensor: S) => S) => T;\n\n/**\n * @docalias (a: Tensor, b: Tensor,...) => {\n * value: Tensor, * gradFunc: (dy: Tensor) => Tensor | Tensor[] * }\n */\nexport type CustomGradientFunc = (...args: Tensor[]) => {\n value: T, gradFunc: (dy: T) => Tensor | Tensor[];\n};\n\nexport type MemoryInfo = {\n numTensors: number; numDataBuffers: number; numBytes: number;\n unreliable?: boolean;\n};\n\nexport interface TimingInfo extends BackendTimingInfo {\n wallMs: number;\n}\n\n/** @docalias Function */\nexport type ScopeFn = () => T;\n\nexport interface TensorManager {\n registerTensor(a: Tensor): void;\n registerVariable(v: Variable): void;\n disposeTensor(a: Tensor): void;\n memory(): {numDataBuffers: number; numBytes: number;};\n}\n\ninterface ScopeState {\n track: Tensor[];\n name: string;\n}\n\nexport class Engine implements TensorManager {\n // Public since optimizers will use it.\n registeredVariables: NamedVariableMap = {};\n\n private refCounter = new WeakMap();\n private nextTapeNodeId = 0;\n private numBytes = 0;\n private numTensors = 0;\n private numDataBuffers = 0;\n\n private activeTape: TapeNode[];\n private gradientScopeCount = 0;\n private customGradientDepth = 0;\n\n // Keep Tensors that parallel the tapes.\n private activeScope: ScopeState;\n private scopeStack: ScopeState[];\n private keepTensors: Set = new Set();\n private profiler: Profiler;\n\n constructor(\n private backend: KernelBackend, public safeMode: boolean,\n private debugMode: () => boolean) {\n // Create a default outer scope.\n this.activeScope = {track: [], name: 'default scope'};\n this.scopeStack = [this.activeScope];\n this.profiler = new Profiler(backend);\n }\n\n tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n // gradMode Primarily for internal use during backprop\n // If true, will start a tape if it is the outermost tidy.\n\n let name: string = null;\n if (fn == null) {\n // Called with only 1 argument.\n if (typeof nameOrFn !== 'function') {\n throw new Error('Please provide a function to tidy()');\n }\n fn = nameOrFn;\n } else {\n // Called with 2 arguments.\n if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) {\n throw new Error(\n 'When calling with two arguments, the first argument ' +\n 'to tidy() must be a string');\n }\n if (typeof fn !== 'function') {\n throw new Error(\n 'When calling with two arguments, the 2nd argument ' +\n 'to tidy() must be a function');\n }\n name = nameOrFn as string;\n // TODO(nsthorat,smilkov): Do operation logging and performance\n // profiling.\n }\n let result: T;\n return this.scopedRun(\n () => this.startScope(name, gradMode),\n () => this.endScope(result, gradMode), () => {\n result = fn();\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n return result;\n });\n }\n\n private scopedRun(start: () => void, end: () => void, f: () => T): T {\n start();\n try {\n const res = f();\n end();\n return res;\n } catch (ex) {\n end();\n throw ex;\n }\n }\n\n runKernel(\n forwardFunc: ForwardFunc,\n inputs: I,\n backwardsFunc?: (dy: T, saved: Tensor[]) => {[P in keyof I]: () => I[P]},\n ): T {\n let result: T;\n const saved: Tensor[] = [];\n const saveFunc = (x: T): T => {\n saved.push(x);\n return x;\n };\n const scopeName = this.activeScope.name;\n\n // Stop recording to a tape when running a kernel.\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n if (!this.debugMode()) {\n result = forwardFunc(this.backend, saveFunc);\n } else {\n result = this.profiler.profileKernel(\n scopeName, () => forwardFunc(this.backend, saveFunc));\n }\n });\n\n if (this.shouldRecord()) {\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: scopeName,\n inputs,\n // Keep gradient records only for the first output.\n output: Array.isArray(result) ? result[0] : result\n };\n if (backwardsFunc != null) {\n tapeNode.gradient =\n ((dy: T) => backwardsFunc(dy, saved)) as (dy: Tensor) =>\n NamedGradientMap;\n }\n this.activeTape.push(tapeNode);\n }\n return result;\n }\n\n // TensorManager implementation.\n\n registerTensor(a: Tensor|Variable): void {\n const refCount =\n this.refCounter.has(a.dataId) ? this.refCounter.get(a.dataId) : 0;\n this.numTensors++;\n if (refCount === 0) {\n this.numDataBuffers++;\n this.numBytes +=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n this.backend.register(a.dataId, a.shape, a.dtype);\n }\n this.refCounter.set(a.dataId, refCount + 1);\n if (!(a instanceof Variable)) {\n this.track(a);\n }\n }\n\n registerVariable(v: Variable) {\n if (this.registeredVariables[v.name] != null) {\n throw new Error(`Variable with name ${v.name} was already registered`);\n }\n this.registeredVariables[v.name] = v;\n }\n\n disposeTensor(a: Tensor): void {\n if (!this.refCounter.has(a.dataId)) {\n return;\n }\n if (this.keepTensors.has(a.id)) {\n this.keepTensors.delete(a.id);\n }\n this.numTensors--;\n const refCount = this.refCounter.get(a.dataId);\n if (refCount <= 1) {\n this.refCounter.delete(a.dataId);\n this.backend.disposeData(a.dataId);\n this.numDataBuffers--;\n this.numBytes -=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n } else {\n this.refCounter.set(a.dataId, refCount - 1);\n }\n // TODO(nsthorat): Construct an error and save the stack trace for\n // debugging when in debug mode. Creating a stack trace is too expensive\n // to do unconditionally.\n }\n\n disposeVariables(): void {\n for (const varName in this.registeredVariables) {\n const v = this.registeredVariables[varName];\n this.disposeTensor(v);\n delete this.registeredVariables[varName];\n }\n }\n\n memory(): MemoryInfo {\n const info = this.backend.memory() as MemoryInfo;\n info.numTensors = this.numTensors;\n info.numDataBuffers = this.numDataBuffers;\n info.numBytes = this.numBytes;\n return info;\n }\n\n private shouldRecord(): boolean {\n return this.activeTape != null && this.customGradientDepth === 0;\n }\n\n private addTapeNode(\n inputs: Tensor[], result: Tensor,\n gradientsFunc: (dy: Tensor) => Tensor[]): void {\n const inputsMap: NamedTensorMap = {};\n inputs.forEach((input, idx) => {\n inputsMap[idx] = input;\n });\n\n const gradient = (dy: Tensor) => {\n const res = gradientsFunc(dy);\n const resMap: NamedGradientMap = {};\n res.forEach((r, idx) => {\n resMap[idx] = () => r;\n });\n return resMap;\n };\n\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: this.activeScope.name,\n inputs: inputsMap,\n output: result,\n gradient\n };\n this.activeTape.push(tapeNode);\n }\n\n keep(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {...}) to avoid memory leaks.');\n }\n this.keepTensors.add(result.id);\n return result;\n }\n\n /**\n * Start a scope. Use this with endScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n startScope(name?: string, gradientsMode = false) {\n if (gradientsMode && this.gradientScopeCount === 0) {\n this.activeTape = [];\n }\n if (gradientsMode) {\n this.gradientScopeCount++;\n }\n\n const scopeInfo: ScopeState = {track: [], name: 'unnamed scope'};\n if (name) {\n scopeInfo.name = name;\n }\n this.scopeStack.push(scopeInfo);\n this.activeScope = scopeInfo;\n }\n\n /**\n * End a scope. Use this with startScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n endScope(result?: TensorContainer, gradientsMode = false) {\n if (gradientsMode) {\n this.gradientScopeCount--;\n if (this.gradientScopeCount === 0) {\n this.activeTape = null;\n }\n }\n\n const tensorsToKeep = new Set(this.keepTensors);\n\n const tensorsToTrackInParent = getTensorsInContainer(result);\n tensorsToTrackInParent.forEach(tensor => tensorsToKeep.add(tensor.id));\n\n // Dispose the arrays tracked in this scope.\n for (let i = 0; i < this.activeScope.track.length; i++) {\n const tensor = this.activeScope.track[i];\n if (tensorsToKeep.has(tensor.id)) {\n continue;\n }\n\n if (this.activeTape != null) {\n tensorsToTrackInParent.push(tensor);\n } else {\n tensor.dispose();\n }\n }\n\n const oldScope = this.scopeStack.pop();\n this.activeScope = this.scopeStack.length === 0 ?\n {track: [], name: 'default scope'} :\n this.scopeStack[this.scopeStack.length - 1];\n\n // Track the current result in the parent scope.\n tensorsToTrackInParent.forEach(tensor => {\n // Only track the tensor if was allocated in the inner scope and is not\n // globally kept.\n if (!this.keepTensors.has(tensor.id) &&\n isTensorInList(tensor, oldScope.track)) {\n this.track(tensor);\n }\n });\n }\n\n /**\n * Returns gradients of `f` with respect to each of the `xs`. The gradients\n * returned are of the same length as `xs`, but some might be null if `f` was\n * not a function of that `x`. It also takes optional dy to multiply the\n * gradient, which defaults to `1`.\n */\n gradients(\n f: () => T, xs: Tensor[], dy?: T,\n allowNoGradients = false): {value: T, grads: Tensor[]} {\n util.assert(xs.length > 0, 'gradients() received an empty list of xs.');\n\n return this.tidy('gradients', () => {\n const y = f();\n util.assert(\n y instanceof Tensor,\n 'The result y returned by f() must be a tensor.');\n // Filter out the nodes that don't connect x => y.\n const filteredTape = getFilteredNodesXToY(this.activeTape, xs, y);\n if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) {\n throw new Error(\n 'Cannot compute gradient of y=f(x) with respect to x. Make sure ' +\n 'that the f you passed encloses all operations that lead from x ' +\n 'to y.');\n }\n\n const accumulatedGradientMap: {[tensorId: number]: Tensor} = {};\n accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy;\n\n // Backprop gradients through the filtered nodes.\n backpropagateGradients(accumulatedGradientMap, filteredTape);\n\n const grads = xs.map(x => accumulatedGradientMap[x.id]);\n return {value: y, grads};\n }, true /* gradientsMode */);\n }\n\n customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n util.assert(\n util.isFunction(f),\n 'The f passed in customGrad(f) must be a function.');\n return (...inputs: Tensor[]): T => {\n util.assert(\n inputs.every(t => t instanceof Tensor),\n 'The args passed in customGrad(f)(x1, x2,...) must all be tensors');\n\n let gradientsFunc: (dy: T) => Tensor | Tensor[];\n let result: T;\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n const gradientsMode = true;\n result = this.tidy(f.name, () => {\n const {value, gradFunc} = f(...inputs);\n util.assert(\n value instanceof Tensor,\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.value` is a tensor');\n util.assert(\n util.isFunction(gradFunc),\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function.');\n gradientsFunc = gradFunc;\n return value;\n }, gradientsMode);\n });\n\n if (this.shouldRecord()) {\n const gradFunc = (dy: T): Tensor[] => {\n const res = gradientsFunc(dy);\n const grads: Tensor[] = Array.isArray(res) ? res : [res];\n util.assert(\n grads.length === inputs.length,\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns the same ' +\n 'number of tensors as inputs passed to f(...).');\n util.assert(\n grads.every(t => t instanceof Tensor),\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns a list of ' +\n 'only tensors.');\n return grads;\n };\n this.addTapeNode(inputs, result, gradFunc);\n }\n return result;\n };\n }\n\n // Forwarding to backend.\n write(dataId: DataId, values: TypedArray): void {\n this.backend.write(dataId, values);\n }\n readSync(dataId: DataId): TypedArray {\n return this.backend.readSync(dataId);\n }\n read(dataId: DataId): Promise {\n return this.backend.read(dataId);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n return this.backend.fromPixels(pixels, numChannels);\n }\n async time(query: () => void): Promise {\n const start = now();\n const timingInfo = await this.backend.time(query) as TimingInfo;\n timingInfo.wallMs = now() - start;\n return timingInfo;\n }\n\n /**\n * Tracks a Tensor in the current scope to be automatically cleaned up\n * when the current scope ends, and returns the value.\n *\n * @param result The Tensor to track in the current scope.\n */\n private track(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {op();...}); to avoid memory leaks.');\n }\n this.activeScope.track.push(result);\n return result;\n }\n}\n\nfunction ones(shape: number[]): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), 'float32');\n return Tensor.make(shape, {values});\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport interface Features {\n // Whether to enable debug mode.\n 'DEBUG'?: boolean;\n // Whether we are in a browser (as versus, say, node.js) environment.\n 'IS_BROWSER'?: boolean;\n // Whether we are in the Node.js environment.\n 'IS_NODE'?: boolean;\n // The disjoint_query_timer extension version.\n // 0: disabled, 1: EXT_disjoint_timer_query, 2:\n // EXT_disjoint_timer_query_webgl2.\n // In Firefox with WebGL 2.0,\n // EXT_disjoint_timer_query_webgl2 is not available, so we must use the\n // WebGL 1.0 extension.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'?: number;\n // Whether the timer object from the disjoint_query_timer extension gives\n // timing information that is reliable.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE'?: boolean;\n // 0: No WebGL, 1: WebGL 1.0, 2: WebGL 2.0.\n 'WEBGL_VERSION'?: number;\n // True if WebGL is supported.\n 'HAS_WEBGL'?: boolean;\n // Whether rendering to float32 textures is enabled. If disabled, renders to\n // float16 textures.\n 'WEBGL_RENDER_FLOAT32_ENABLED'?: boolean;\n // Whether downloading float textures is enabled. If disabled, uses IEEE 754\n // encoding of the float32 values to 4 uint8 when downloading.\n 'WEBGL_DOWNLOAD_FLOAT_ENABLED'?: boolean;\n // Whether the fence API is available.\n 'WEBGL_FENCE_API_ENABLED'?: boolean;\n 'BACKEND'?: string;\n // Test precision for unit tests. This is decreased when we can't render\n // float32 textures.\n 'TEST_EPSILON'?: number;\n 'IS_CHROME'?: boolean;\n // True if running unit tests.\n 'IS_TEST'?: boolean;\n}\n\nexport enum Type {\n NUMBER,\n BOOLEAN,\n STRING\n}\n\nexport const URL_PROPERTIES: URLProperty[] = [\n {name: 'DEBUG', type: Type.BOOLEAN}, {name: 'IS_BROWSER', type: Type.BOOLEAN},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', type: Type.BOOLEAN},\n {name: 'WEBGL_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_RENDER_FLOAT32_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_DOWNLOAD_FLOAT_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_FENCE_API_ENABLED', type: Type.BOOLEAN},\n {name: 'BACKEND', type: Type.STRING}\n];\n\nexport interface URLProperty {\n name: keyof Features;\n type: Type;\n}\n\nexport function isWebGLVersionEnabled(webGLVersion: 1|2, isBrowser: boolean) {\n let gl;\n try {\n gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n } catch (e) {\n return false;\n }\n\n if (gl != null) {\n loseContext(gl);\n return true;\n }\n return false;\n}\n\nexport function getWebGLDisjointQueryTimerVersion(\n webGLVersion: number, isBrowser: boolean): number {\n if (webGLVersion === 0) {\n return 0;\n }\n\n let queryTimerVersion: number;\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (hasExtension(gl, 'EXT_disjoint_timer_query_webgl2') &&\n webGLVersion === 2) {\n queryTimerVersion = 2;\n } else if (hasExtension(gl, 'EXT_disjoint_timer_query')) {\n queryTimerVersion = 1;\n } else {\n queryTimerVersion = 0;\n }\n\n if (gl != null) {\n loseContext(gl);\n }\n return queryTimerVersion;\n}\n\nexport function isRenderToFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n\n const isFrameBufferComplete =\n gl.checkFramebufferStatus(gl.FRAMEBUFFER) === gl.FRAMEBUFFER_COMPLETE;\n\n loseContext(gl);\n return isFrameBufferComplete;\n}\n\nexport function isDownloadFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.FLOAT, new Float32Array(4));\n\n const readPixelsNoError = gl.getError() === gl.NO_ERROR;\n\n loseContext(gl);\n\n return readPixelsNoError;\n}\n\nexport function isWebGLFenceEnabled(webGLVersion: number, isBrowser: boolean) {\n if (webGLVersion !== 2) {\n return false;\n }\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n // tslint:disable-next-line:no-any\n const isEnabled = (gl as any).fenceSync != null;\n loseContext(gl);\n return isEnabled;\n}\n\nexport function isChrome() {\n return typeof navigator !== 'undefined' && navigator != null &&\n navigator.userAgent != null && /Chrome/.test(navigator.userAgent) &&\n /Google Inc/.test(navigator.vendor);\n}\n\n// Expects flags from URL in the format ?tfjsflags=FLAG1:1,FLAG2:true.\nconst TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags';\nexport function getFeaturesFromURL(): Features {\n const features: Features = {};\n\n if (typeof window === 'undefined' || typeof window.location === 'undefined') {\n return features;\n }\n\n const urlParams = getQueryParams(window.location.search);\n if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) {\n const urlFlags: {[key: string]: string} = {};\n\n const keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(',');\n keyValues.forEach(keyValue => {\n const [key, value] = keyValue.split(':') as [string, string];\n urlFlags[key] = value;\n });\n\n URL_PROPERTIES.forEach(urlProperty => {\n if (urlProperty.name in urlFlags) {\n console.log(\n `Setting feature override from URL ${urlProperty.name}: ` +\n `${urlFlags[urlProperty.name]}`);\n if (urlProperty.type === Type.NUMBER) {\n features[urlProperty.name] = +urlFlags[urlProperty.name];\n } else if (urlProperty.type === Type.BOOLEAN) {\n features[urlProperty.name] = urlFlags[urlProperty.name] === 'true';\n } else if (urlProperty.type === Type.STRING) {\n // tslint:disable-next-line:no-any\n features[urlProperty.name] = urlFlags[urlProperty.name] as any;\n } else {\n console.warn(`Unknown URL param: ${urlProperty.name}.`);\n }\n }\n });\n }\n\n return features;\n}\n\nfunction hasExtension(gl: WebGLRenderingContext, extensionName: string) {\n const ext = gl.getExtension(extensionName);\n return ext != null;\n}\n\nfunction getWebGLRenderingContext(\n webGLVersion: number, isBrowser: boolean): WebGLRenderingContext {\n if (webGLVersion === 0 || !isBrowser) {\n throw new Error('Cannot get WebGL rendering context, WebGL is disabled.');\n }\n\n const tempCanvas = document.createElement('canvas');\n\n if (webGLVersion === 1) {\n return (tempCanvas.getContext('webgl') ||\n tempCanvas.getContext('experimental-webgl')) as\n WebGLRenderingContext;\n }\n return tempCanvas.getContext('webgl2') as WebGLRenderingContext;\n}\n\nfunction loseContext(gl: WebGLRenderingContext) {\n if (gl != null) {\n const loseContextExtension = gl.getExtension('WEBGL_lose_context');\n if (loseContextExtension == null) {\n throw new Error(\n 'Extension WEBGL_lose_context not supported on this browser.');\n }\n loseContextExtension.loseContext();\n }\n}\n\nfunction createFloatTextureAndBindToFramebuffer(\n gl: WebGLRenderingContext, webGLVersion: number) {\n const frameBuffer = gl.createFramebuffer();\n const texture = gl.createTexture();\n\n gl.bindTexture(gl.TEXTURE_2D, texture);\n\n // tslint:disable-next-line:no-any\n const internalFormat = webGLVersion === 2 ? (gl as any).RGBA32F : gl.RGBA;\n gl.texImage2D(\n gl.TEXTURE_2D, 0, internalFormat, 1, 1, 0, gl.RGBA, gl.FLOAT, null);\n\n gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer);\n gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n}\n\nexport function getQueryParams(queryString: string): {[key: string]: string} {\n const params = {};\n queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (s, ...t) => {\n decodeParam(params, t[0], t[1]);\n return t.join('=');\n });\n return params;\n}\n\nfunction decodeParam(\n params: {[key: string]: string}, name: string, value?: string) {\n params[decodeURIComponent(name)] = decodeURIComponent(value || '');\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as device_util from './device_util';\nimport {Engine, MemoryInfo, ScopeFn, TimingInfo} from './engine';\nimport {Features, getFeaturesFromURL, getWebGLDisjointQueryTimerVersion, isChrome, isDownloadFloatTextureEnabled, isRenderToFloatTextureEnabled, isWebGLFenceEnabled, isWebGLVersionEnabled} from './environment_util';\nimport {KernelBackend} from './kernels/backend';\nimport {setTensorTracker, Tensor, TensorTracker} from './tensor';\nimport {TensorContainer} from './tensor_types';\nimport {getTensorsInContainer} from './tensor_util';\n\nconst TEST_EPSILON_FLOAT32_ENABLED = 1e-3;\nconst TEST_EPSILON_FLOAT32_DISABLED = 1e-1;\n\nexport class Environment {\n private features: Features = {};\n private globalEngine: Engine;\n private registry:\n {[id: string]: {backend: KernelBackend, priority: number}} = {};\n backendName: string;\n backend: KernelBackend;\n\n constructor(features?: Features) {\n if (features != null) {\n this.features = features;\n }\n\n if (this.get('DEBUG')) {\n console.warn(\n 'Debugging mode is ON. The output of every math call will ' +\n 'be downloaded to CPU and checked for NaNs. ' +\n 'This significantly impacts performance.');\n }\n }\n\n /**\n * Sets the backend (cpu, webgl, etc) responsible for creating tensors and\n * executing operations on those tensors.\n *\n * Note this disposes the current backend, if any, as well as any tensors\n * associated with it. A new backend is initialized, even if it is of the\n * same type as the previous one.\n *\n * @param backendName The name of the backend. Currently supports\n * `'webgl'|'cpu'` in the browser, and `'tensorflow'` under node.js\n * (requires tfjs-node).\n * @param safeMode Defaults to false. In safe mode, you are forced to\n * construct tensors and call math operations inside a `tidy()` which\n * will automatically clean up intermediate tensors.\n */\n /** @doc {heading: 'Environment'} */\n static setBackend(backendName: string, safeMode = false) {\n if (!(backendName in ENV.registry)) {\n throw new Error(`Backend name '${backendName}' not found in registry`);\n }\n ENV.initBackend(backendName, safeMode);\n }\n\n /**\n * Returns the current backend name (cpu, webgl, etc). The backend is\n * responsible for creating tensors and executing operations on those tensors.\n */\n /** @doc {heading: 'Environment'} */\n static getBackend(): string {\n ENV.initDefaultBackend();\n return ENV.backendName;\n }\n\n /**\n * Dispose all variables kept in backend engine.\n */\n /** @doc {heading: 'Environment'} */\n static disposeVariables(): void {\n ENV.engine.disposeVariables();\n }\n\n /**\n * Returns memory info at the current time in the program. The result is an\n * object with the following properties:\n *\n * - `numBytes`: Number of bytes allocated (undisposed) at this time.\n * - `numTensors`: Number of unique tensors allocated.\n * - `numDataBuffers`: Number of unique data buffers allocated\n * (undisposed) at this time, which is ≤ the number of tensors\n * (e.g. `a.reshape(newShape)` makes a new Tensor that shares the same\n * data buffer with `a`).\n * - `unreliable`: `Optional` `boolean`:\n * - On WebGL, not present (always reliable).\n * - On CPU, true. Due to automatic garbage collection, these numbers\n * represent undisposed tensors, i.e. not wrapped in `tidy()`, or\n * lacking a call to `tensor.dispose()`.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static memory(): MemoryInfo {\n return ENV.engine.memory();\n }\n\n /**\n * Executes the provided function `fn` and after it is executed, cleans up all\n * intermediate tensors allocated by `fn` except those returned by `fn`.\n * `f` must not return a Promise (async functions not allowed).\n * The returned result can be a complex object, however tidy only walks the\n * top-level properties (depth 1) of that object to search for tensors, or\n * lists of tensors that need to be tracked in the parent scope.\n *\n * Using this method helps avoid memory leaks. In general, wrap calls to\n * operations in `tidy` for automatic memory cleanup.\n *\n * When in safe mode, you must enclose all `Tensor` creation and ops\n * inside a `tidy` to prevent memory leaks.\n *\n * ```js\n * // y = 2 ^ 2 + 1\n * const y = tf.tidy(() => {\n * // a, b, and one will be cleaned up when the tidy ends.\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n * const b = a.square();\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * y.print();\n * ```\n *\n * @param nameOrFn The name of the closure, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If debug mode is on, the timing and the memory usage of the function\n * will be tracked and displayed on the console using the provided name.\n * @param fn The function to execute.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n return ENV.engine.tidy(nameOrFn, fn, gradMode);\n }\n\n /**\n * Disposes any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. If the\n * object is not a `Tensor` or does not contain `Tensors`, nothing\n * happens. In general it is safe to pass any object here, except that\n * `Promise`s are not supported.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static dispose(container: TensorContainer) {\n const tensors = getTensorsInContainer(container);\n tensors.forEach(tensor => tensor.dispose());\n }\n\n /**\n * Keeps a `Tensor` generated inside a `tidy` from being disposed\n * automatically.\n *\n * ```js\n * let b;\n * const y = tf.tidy(() => {\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n *\n * // b will not be cleaned up by the tidy. a and one will be cleaned up\n * // when the tidy ends.\n * b = tf.keep(a.square());\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * console.log('y:');\n * y.print();\n * console.log('b:');\n * b.print();\n * ```\n *\n * @param result The tensor to keep from being disposed.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static keep(result: T): T {\n return ENV.engine.keep(result);\n }\n\n /**\n * Executes `f()` and returns a promise that resolves with timing\n * information.\n *\n * The result is an object with the following properties:\n *\n * - `wallMs`: Wall execution time.\n * - `kernelMs`: Kernel execution time, ignoring data transfer.\n * - On `WebGL` The following additional properties exist:\n * - `uploadWaitMs`: CPU blocking time on texture uploads.\n * - `downloadWaitMs`: CPU blocking time on texture downloads (readPixels).\n *\n * ```js\n * const x = tf.randomNormal([20, 20]);\n * const time = await tf.time(() => x.matMul(x));\n *\n * console.log(`kernelMs: ${time.kernelMs}, wallTimeMs: ${time.wallMs}`);\n * ```\n *\n * @param f The function to execute and time.\n */\n /** @doc {heading: 'Performance', subheading: 'Timing'} */\n static time(f: () => void): Promise {\n return ENV.engine.time(f);\n }\n\n get(feature: K): Features[K] {\n if (feature in this.features) {\n return this.features[feature];\n }\n\n this.features[feature] = this.evaluateFeature(feature);\n\n return this.features[feature];\n }\n\n getFeatures(): Features {\n return this.features;\n }\n\n set(feature: K, value: Features[K]): void {\n this.features[feature] = value;\n }\n\n private getBestBackendName(): string {\n if (Object.keys(this.registry).length === 0) {\n throw new Error('No backend found in registry.');\n }\n const sortedBackends = Object.keys(this.registry)\n .map(name => {\n return {name, entry: this.registry[name]};\n })\n .sort((a, b) => {\n // Highest priority comes first.\n return b.entry.priority - a.entry.priority;\n });\n return sortedBackends[0].name;\n }\n\n private evaluateFeature(feature: K): Features[K] {\n if (feature === 'DEBUG') {\n return false;\n } else if (feature === 'IS_BROWSER') {\n return typeof window !== 'undefined';\n } else if (feature === 'IS_NODE') {\n return (typeof process !== 'undefined') &&\n (typeof process.versions.node !== 'undefined');\n } else if (feature === 'IS_CHROME') {\n return isChrome();\n } else if (feature === 'IS_TEST') {\n return false;\n } else if (feature === 'BACKEND') {\n return this.getBestBackendName();\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') {\n const webGLVersion = this.get('WEBGL_VERSION');\n\n if (webGLVersion === 0) {\n return 0;\n }\n // Remove this and reenable this extension when the\n // EXT_disjoint_query_timer extension is reenabled in chrome.\n // https://github.com/tensorflow/tfjs/issues/544\n if (webGLVersion > 0) {\n return 0;\n }\n return getWebGLDisjointQueryTimerVersion(\n webGLVersion, this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE') {\n return this.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0 &&\n !device_util.isMobile();\n } else if (feature === 'HAS_WEBGL') {\n return this.get('WEBGL_VERSION') > 0;\n } else if (feature === 'WEBGL_VERSION') {\n if (isWebGLVersionEnabled(2, this.get('IS_BROWSER'))) {\n return 2;\n } else if (isWebGLVersionEnabled(1, this.get('IS_BROWSER'))) {\n return 1;\n }\n return 0;\n } else if (feature === 'WEBGL_RENDER_FLOAT32_ENABLED') {\n return isRenderToFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DOWNLOAD_FLOAT_ENABLED') {\n return isDownloadFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_FENCE_API_ENABLED') {\n return isWebGLFenceEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'TEST_EPSILON') {\n if (this.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return TEST_EPSILON_FLOAT32_ENABLED;\n }\n return TEST_EPSILON_FLOAT32_DISABLED;\n }\n throw new Error(`Unknown feature ${feature}.`);\n }\n\n setFeatures(features: Features) {\n this.features = Object.assign({}, features);\n }\n\n reset() {\n this.features = getFeaturesFromURL();\n if (this.globalEngine != null) {\n this.globalEngine = null;\n }\n }\n\n private initBackend(backendName?: string, safeMode = false) {\n this.backendName = backendName;\n this.backend = this.findBackend(backendName);\n this.globalEngine =\n new Engine(this.backend, safeMode, () => this.get('DEBUG'));\n }\n\n findBackend(name: string): KernelBackend {\n if (!(name in this.registry)) {\n return null;\n }\n return this.registry[name].backend;\n }\n\n /**\n * Registers a global backend. The registration should happen when importing\n * a module file (e.g. when importing `backend_webgl.ts`), and is used for\n * modular builds (e.g. custom tfjs bundle with only webgl support).\n *\n * @param factory: The backend factory function. When called, it should\n * return an instance of the backend.\n * @param priority The priority of the backend (higher = more important).\n * In case multiple backends are registered, the priority is used to find\n * the best backend. Defaults to 1.\n * @return False if the creation/registration failed. True otherwise.\n */\n registerBackend(\n name: string, factory: () => KernelBackend, priority = 1,\n setTensorTrackerFn?: (f: () => TensorTracker) => void): boolean {\n if (name in this.registry) {\n console.warn(\n `${name} backend was already registered. Reusing existing backend`);\n if (setTensorTrackerFn != null) {\n setTensorTrackerFn(() => this.engine);\n }\n return false;\n }\n try {\n const backend = factory();\n this.registry[name] = {backend, priority};\n return true;\n } catch (err) {\n console.warn(`Registration of backend ${name} failed`);\n console.warn(err.stack || err.message);\n return false;\n }\n }\n\n removeBackend(name: string): void {\n if (!(name in this.registry)) {\n throw new Error(`${name} backend not found in registry`);\n }\n this.registry[name].backend.dispose();\n delete this.registry[name];\n }\n\n get engine(): Engine {\n this.initDefaultBackend();\n return this.globalEngine;\n }\n\n private initDefaultBackend() {\n if (this.globalEngine == null) {\n this.initBackend(this.get('BACKEND'), false /* safeMode */);\n }\n }\n}\n\nfunction getGlobalNamespace(): {ENV: Environment} {\n // tslint:disable-next-line:no-any\n let ns: any;\n if (typeof (window) !== 'undefined') {\n ns = window;\n } else if (typeof (process) !== 'undefined') {\n ns = process;\n } else {\n throw new Error('Could not find a global object');\n }\n return ns;\n}\n\nfunction getOrMakeEnvironment(): Environment {\n const ns = getGlobalNamespace();\n if (ns.ENV == null) {\n ns.ENV = new Environment(getFeaturesFromURL());\n setTensorTracker(() => ns.ENV.engine);\n }\n return ns.ENV;\n}\n\nexport let ENV = getOrMakeEnvironment();\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\n\nexport function warn(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.warn(...msg);\n }\n}\n\nexport function log(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.log(...msg);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Gets the new shape of the input Tensor after it's been reshaped\n * to :\n * [blockShape[0], ..., blockShape[M-1], batch / prod(blockShape),\n * inputShape[1], ..., inputShape[N-1]]\n *\n * See step 1: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshaped(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n let reshaped: number[] = [];\n if (batchToSpace) {\n reshaped = reshaped.concat(blockShape.slice(0));\n reshaped.push(inputShape[0] / prod);\n reshaped = reshaped.concat(inputShape.slice(1));\n } else {\n reshaped = reshaped.concat(inputShape[0]);\n const spatialLength = blockShape.length;\n for (let i = 0; i < spatialLength; ++i) {\n reshaped =\n reshaped.concat([inputShape[i + 1] / blockShape[i], blockShape[i]]);\n }\n reshaped = reshaped.concat(inputShape.slice(spatialLength + 1));\n }\n return reshaped;\n}\n\n/**\n * Gets the permutation that will transpose the dimensions of the\n * reshaped tensor to shape:\n *\n * [batch / prod(block_shape),inputShape[1], blockShape[0], ...,\n * inputShape[M], blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * see step 2: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getPermuted(\n reshapedRank: number, blockShapeRank: number,\n batchToSpace = true): number[] {\n const permuted = [];\n if (batchToSpace) {\n permuted.push(blockShapeRank);\n for (let i = blockShapeRank + 1; i < reshapedRank; ++i) {\n if (i <= 2 * blockShapeRank) {\n permuted.push(i);\n permuted.push(i - (blockShapeRank + 1));\n } else {\n permuted.push(i);\n }\n }\n } else {\n const permutedBeforeBatch = [];\n const permutedAfterBatch = [];\n for (let i = 1; i < reshapedRank; ++i) {\n if (i >= blockShapeRank * 2 + 1 || i % 2 === 1) {\n permutedAfterBatch.push(i);\n } else {\n permutedBeforeBatch.push(i);\n }\n }\n permuted.push(...permutedBeforeBatch);\n permuted.push(0);\n permuted.push(...permutedAfterBatch);\n }\n return permuted;\n}\n\n/**\n * Gets the shape of the reshaped and permuted input Tensor before any cropping\n * is applied. The new shape will be:\n *\n * [batch / prod(blockShape),inputShape[1] * blockShape[0], ...,\n * inputShape[M] * blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 3: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshapedPermuted(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n const reshapedPermuted = [];\n\n if (batchToSpace) {\n reshapedPermuted.push(inputShape[0] / prod);\n } else {\n reshapedPermuted.push(inputShape[0] * prod);\n }\n\n for (let i = 1; i < inputShape.length; ++i) {\n if (i <= blockShape.length) {\n if (batchToSpace) {\n reshapedPermuted.push(blockShape[i - 1] * inputShape[i]);\n } else {\n reshapedPermuted.push(inputShape[i] / blockShape[i - 1]);\n }\n } else {\n reshapedPermuted.push(inputShape[i]);\n }\n }\n\n return reshapedPermuted;\n}\n\n/**\n * Converts the crops argument into the beginning coordinates of a slice\n * operation\n */\nexport function getSliceBeginCoords(\n crops: number[][], blockShape: number): number[] {\n const sliceBeginCoords = [0];\n for (let i = 0; i < blockShape; ++i) {\n sliceBeginCoords.push(crops[i][0]);\n }\n return sliceBeginCoords;\n}\n\n/**\n * converts the crops argument into the size of a slice operation. When\n * combined with getSliceBeginCoords this function allows the reshaped and\n * permuted Tensor to be cropped to its final output shape of:\n *\n * inputShape[1] * blockShape[0] - crops[0,0] - crops[0,1], ...,\n * inputShape[M] * blockShape[M-1] -crops[M-1,0] -\n * crops[M-1,1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 4: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getSliceSize(\n uncroppedShape: number[], crops: number[][], blockShape: number): number[] {\n const sliceSize = uncroppedShape.slice(0, 1);\n for (let i = 0; i < blockShape; ++i) {\n sliceSize.push(uncroppedShape[i + 1] - crops[i][0] - crops[i][1]);\n }\n\n return sliceSize;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\n/**\n * Returns true if the axis specifies the inner most dimensions of the\n * array.\n */\nexport function axesAreInnerMostDims(axes: number[], rank: number): boolean {\n for (let i = 0; i < axes.length; ++i) {\n if (axes[axes.length - i - 1] !== rank - 1 - i) {\n return false;\n }\n }\n return true;\n}\n\nexport function combineLocations(\n outputLoc: number[], reduceLoc: number[], axes: number[]): number[] {\n const rank = outputLoc.length + reduceLoc.length;\n const loc = [];\n let outIdx = 0;\n let reduceIdx = 0;\n   for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n loc.push(outputLoc[outIdx++]);\n } else {\n loc.push(reduceLoc[reduceIdx++]);\n }\n }\n return loc;\n}\n\nexport function computeOutAndReduceShapes(\n aShape: number[], axes: number[]): [number[], number[]] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n outShape.push(aShape[dim]);\n }\n }\n const reduceShape = axes.map(dim => aShape[dim]);\n return [outShape, reduceShape];\n}\n\nexport function expandShapeToKeepDim(\n shape: number[], axes: number[]): number[] {\n const reduceSubShape = axes.map(x => 1);\n return combineLocations(shape, reduceSubShape, axes);\n}\n\nexport function parseAxisParam(\n axis: number|number[], shape: number[]): number[] {\n const rank = shape.length;\n\n // Normalize input\n axis = axis == null ? shape.map((s, i) => i) : [].concat(axis);\n\n // Check for valid range\n util.assert(\n axis.every(ax => ax >= -rank && ax < rank),\n `All values in axis param must be in range [-${rank}, ${rank}) but ` +\n `got axis ${axis}`);\n\n // Check for only integers\n util.assert(\n axis.every(ax => util.isInt(ax)),\n `All values in axis param must be integers but ` +\n `got axis ${axis}`);\n\n // Handle negative axis.\n return axis.map(a => a < 0 ? rank + a : a);\n}\n\nexport function assertAxesAreInnerMostDims(\n msg: string, axes: number[], rank: number): void {\n util.assert(\n axesAreInnerMostDims(axes, rank),\n `${msg} supports only inner-most axes for now. ` +\n `Got axes ${axes} and rank-${rank} input.`);\n}\n\n/**\n * Returns the axes permutation to be used with `tf.transpose`, if such\n * permutation is neccesary. Otherwise it returns null. This method is used by\n * operations that operate only on inner-most axes.\n */\nexport function getAxesPermutation(axes: number[], rank: number): number[]|\n null {\n if (axesAreInnerMostDims(axes, rank)) {\n return null;\n }\n const result: number[] = [];\n for (let i = 0; i < rank; ++i) {\n if (axes.indexOf(i) === -1) {\n result.push(i);\n }\n }\n axes.forEach(axis => result.push(axis));\n return result;\n}\n\n/** Returns the axes permutation that undoes the original permutation. */\nexport function getUndoAxesPermutation(axes: number[]): number[] {\n return axes.map((axis, i) => [i, axis])\n .sort((a, b) => a[1] - b[1])\n .map(x => x[0]);\n}\n\nexport function getInnerMostAxes(numAxes: number, rank: number): number[] {\n const res: number[] = [];\n for (let i = rank - numAxes; i < rank; ++i) {\n res.push(i);\n }\n return res;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Inputs of size above this threshold will be parallelized by calling multiple\n * shader programs.\n */\nimport {nearestDivisor} from '../util';\n\nexport const PARALLELIZE_THRESHOLD = 30;\n\nexport interface ReduceInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n}\n\nexport function computeOptimalWindowSize(inSize: number): number {\n if (inSize <= PARALLELIZE_THRESHOLD) {\n return inSize;\n }\n return nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {nearestDivisor} from '../util';\nimport {PARALLELIZE_THRESHOLD} from './reduce_util';\n\nexport interface SegOpInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n numSegments: number;\n}\n\nexport function segOpComputeOptimalWindowSize(\n inSize: number, numSegments: number): number {\n let done = false;\n let res;\n\n if (inSize <= PARALLELIZE_THRESHOLD) {\n res = inSize;\n done = true;\n } else {\n res = nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n }\n\n while (!done) {\n if (res > numSegments || res === inSize) {\n done = true;\n break;\n } else {\n res = nearestDivisor(inSize, res + 1);\n }\n }\n return res;\n}\n\nexport function computeOutShape(\n aShape: number[], axis: number, numSegments: number): number[] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (dim !== axis) {\n outShape.push(aShape[dim]);\n } else {\n outShape.push(numSegments);\n }\n }\n return outShape;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport * as util from '../util';\n\nexport function assertParamsValid(\n input: Tensor, begin: number[], size: number[]): void {\n util.assert(\n input.rank === begin.length,\n `Error in slice${input.rank}D: Length of begin ${begin} must ` +\n `match the rank of the array (${input.rank}).`);\n util.assert(\n input.rank === size.length,\n `Error in slice${input.rank}D: Length of size ${size} must ` +\n `match the rank of the array (${input.rank}).`);\n\n for (let i = 0; i < input.rank; ++i) {\n util.assert(\n begin[i] + size[i] <= input.shape[i],\n `Error in slice${input.rank}D: begin[${i}] + size[${i}] ` +\n `(${begin[i] + size[i]}) would overflow input.shape[${i}] (${\n input.shape[i]})`);\n }\n}\n\n/**\n * Calculate the start index and output tensor shape for strided slice op.\n */\nexport function getStridedSlicedInfo(\n shape: number[], begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): [number[], number[]] {\n // Note that the axis orders are reversed for runtime ops, so the indices,\n // strides and masks must be as well too.\n const startIndex: number[] = [];\n const endIndex: number[] = [];\n for (let i = 0; i < shape.length; i++) {\n startIndex[i] = startForAxis(beginMask, begin, strides, shape, i);\n endIndex[i] = stopForAxis(endMask, end, strides, shape, i);\n }\n\n let size = new Array(shape.length).fill(0);\n size = size.map((d, i) => {\n let count = 0;\n for (let start = startIndex[i];\n !(strides[i] > 0 ? start >= endIndex[i] : start <= endIndex[i]);\n start += strides[i]) {\n count += 1;\n }\n return count;\n });\n return [startIndex, size];\n}\n\nexport function startForAxis(\n beginMask: number, startIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let start = startIndices[axis];\n\n // Check the axis bit from right of beginMask\n if (beginMask & 1 << axis) {\n if (strides[axis] > 0) {\n // Forward iteration - use the first element. These values will get\n // clamped below (Note: We could have set them to 0 and axis_size-1, but\n // use lowest() and max() to maintain symmetry with StopForAxis())\n start = Number.MIN_SAFE_INTEGER;\n } else {\n // Backward iteration - use the last element.\n start = Number.MAX_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (start < 0) {\n start += axisSize;\n }\n\n // Clamping\n start = util.clamp(0, start, axisSize - 1);\n\n return start;\n}\n\nexport function stopForAxis(\n endMask: number, stopIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let stop = stopIndices[axis];\n\n // Check the axis bit from right of endMask\n if (endMask & (1 << axis)) {\n if (strides[axis] > 0) {\n // Forward iteration - use the last element. These values will get\n // clamped below\n stop = Number.MAX_SAFE_INTEGER;\n } else {\n // Backward iteration - use the first element.\n stop = Number.MIN_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (stop < 0) {\n stop += axisSize;\n }\n\n // Clamping\n // Because the end index points one past the last element, we need slightly\n // different clamping ranges depending on the direction.\n if (strides[axis] > 0) {\n // Forward iteration\n stop = util.clamp(0, stop, axisSize);\n } else {\n // Backward iteration\n stop = util.clamp(-1, stop, axisSize - 1);\n }\n\n return stop;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {CustomGradientFunc, ScopeFn} from './engine';\nimport {ENV} from './environment';\nimport {Scalar, Tensor, Variable} from './tensor';\nimport {NamedTensorMap, TensorContainer} from './tensor_types';\nimport * as util from './util';\n\n/**\n * Create a new gradient scope. Similar to scope, but forces all inner scopes\n * to not clean up so that gradient operations can be used inside of this\n * scope.\n * @param nameOrScopeFn The name of the scope, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If a name is provided, and debug mode is on, the timing and the memory\n * usage of the function will be tracked and displayed on the console\n * using the provided name.\n * @param scopeFn The function to execute.\n */\nfunction gradScope(\n nameOrScopeFn: string|ScopeFn, scopeFn?: ScopeFn): T {\n return ENV.engine.tidy(nameOrScopeFn, scopeFn, true /* gradScope */);\n}\n\n/**\n * Provided `f(x)`, returns another function `g(x, dy?)`, which gives the\n * gradient of `f(x)` with respect to `x`.\n *\n * If `dy` is provided, the gradient of `f(x).mul(dy).sum()` with respect to\n * `x` is computed instead. `f(x)` must take a single tensor `x` and return a\n * single tensor `y`. If `f()` takes multiple inputs, use `grads` instead.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.grad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * g(x).print();\n * ```\n *\n * ```js\n * // f(x) = x ^ 3\n * const f = x => x.pow(tf.scalar(3, 'int32'));\n * // f'(x) = 3x ^ 2\n * const g = tf.grad(f);\n * // f''(x) = 6x\n * const gg = tf.grad(g);\n *\n * const x = tf.tensor1d([2, 3]);\n * gg(x).print();\n * ```\n *\n * @param f The function f(x), to compute gradient for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grad(f: (x: I) => O): (\n x: I, dy?: O) => I {\n util.assert(util.isFunction(f), 'The f passed in grad(f) must be a function');\n return (x: I, dy?: O): I => {\n util.assert(\n x instanceof Tensor, 'The x passed in grad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grad(f)(x, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(x), [x], dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grad(f)(x, dy) must match the shape ' +\n 'returned by f(x)');\n }\n checkGrads(grads);\n return grads[0] as I;\n });\n };\n}\n\n/**\n * Provided `f(x1, x2,...)`, returns another function `g([x1, x2,...], dy?)`,\n * which gives an array of gradients of `f()` with respect to each input\n * [`x1`,`x2`,...].\n *\n * If `dy` is passed when calling `g()`, the gradient of\n * `f(x1,...).mul(dy).sum()` with respect to each input is computed instead.\n * The provided `f` must take one or more tensors and return a single tensor\n * `y`. If `f()` takes a single input, we recommend using `grad` instead.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df / da = b, df / db = a\n * const g = tf.grads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const [da, db] = g([a, b]);\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n *\n * @param f The function `f(x1, x2,...)` to compute gradients for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => Tensor[] {\n util.assert(\n util.isFunction(f), 'The f passed in grads(f) must be a function');\n return (args: Tensor[], dy?: O): Tensor[] => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in grads(f)(args) must be an array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grads(f)(args, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(grads);\n return grads;\n });\n };\n}\n\n/**\n * Like `grad`, but also returns the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grad: The gradient of `f(x)` w.r.t `x` (result of `grad`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.valueAndGrad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * const {value, grad} = g(x);\n *\n * console.log('value');\n * value.print();\n * console.log('grad');\n * grad.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrad(f: (x: I) => O): (\n x: I, dy?: O) => {\n value: O;\n grad: I;\n} {\n util.assert(\n util.isFunction(f), 'The f passed in valueAndGrad(f) must be a function');\n return (x: I, dy?: O) => {\n util.assert(\n x instanceof Tensor,\n 'The x passed in valueAndGrad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrad(f)(x, dy) must be a tensor');\n const {grads, value} = ENV.engine.gradients(() => f(x), [x], dy);\n checkGrads(grads);\n return {grad: grads[0] as I, value: value as O};\n };\n}\n\n/**\n * Like `grads`, but returns also the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grads: The gradients of `f()` w.r.t each input (result of `grads`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df/da = b, df/db = a\n * const g = tf.valueAndGrads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const {value, grads} = g([a, b]);\n *\n * const [da, db] = grads;\n *\n * console.log('value');\n * value.print();\n *\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => {\n grads: Tensor[];\n value: O;\n} {\n util.assert(\n util.isFunction(f),\n 'The f passed in valueAndGrads(f) must be a function');\n return (args: Tensor[], dy?: O) => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in valueAndGrads(f)(args) must be array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrads(f)(args, dy) must be a tensor');\n const res = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n res.value.shape, dy.shape,\n 'The shape of dy passed in valueAndGrads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(res.grads);\n return res;\n };\n}\n\n/**\n * Computes and returns the gradient of f(x) with respect to the list of\n * trainable variables provided by `varList`. If no list is provided, it\n * defaults to all trainable variables.\n *\n * ```js\n * const a = tf.variable(tf.tensor1d([3, 4]));\n * const b = tf.variable(tf.tensor1d([5, 6]));\n * const x = tf.tensor1d([1, 2]);\n *\n * // f(a, b) = a * x ^ 2 + b * x\n * const f = () => a.mul(x.square()).add(b.mul(x)).sum();\n * // df/da = x ^ 2, df/db = x\n * const {value, grads} = tf.variableGrads(f);\n *\n * Object.keys(grads).forEach(varName => grads[varName].print());\n * ```\n *\n * @param f The function to execute. f() should return a scalar.\n * @param varList The list of trainable variables. Defaults to all variables.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction variableGrads(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n util.assert(\n util.isFunction(f),\n 'The f passed in variableGrads(f) must be a function');\n util.assert(\n varList == null ||\n Array.isArray(varList) && varList.every(v => v instanceof Variable),\n 'The varList passed in variableGrads(f, varList) must be an array ' +\n 'of variables');\n if (varList == null) {\n // Get all of the trainable variables.\n varList = [];\n for (const varName in ENV.engine.registeredVariables) {\n varList.push(ENV.engine.registeredVariables[varName]);\n }\n }\n // Prune non-trainable variables.\n const originalVarCount = varList.length;\n varList = varList.filter(variable => variable.trainable);\n util.assert(\n varList.length > 0,\n `variableGrads() expects at least one of the input variables to be ` +\n `trainable, but none of the ${originalVarCount} variables is ` +\n `trainable.`);\n\n const allowNoGradients = true;\n const {value, grads} =\n ENV.engine.gradients(f, varList, null, allowNoGradients);\n\n util.assert(\n grads.some(g => g != null),\n 'Cannot find a connection between any variable and the result of the ' +\n 'loss function y=f(x). Please make sure the operations that use ' +\n 'variables are inside the function f passed to minimize().');\n util.assert(\n value.rank === 0,\n `The f passed in variableGrads(f) must return a scalar, but it ` +\n `returned a rank-${value.rank} tensor`);\n\n const namedGrads: NamedTensorMap = {};\n varList.forEach((v, i) => {\n if (grads[i] != null) {\n namedGrads[v.name] = grads[i];\n }\n });\n return {value, grads: namedGrads};\n}\n\n/**\n * Overrides the gradient computation of a function `f`.\n *\n * Takes a function\n * `f(...inputs) => {value: Tensor, gradFunc: dy => Tensor[]}` and returns\n * another function `g(...inputs)` which takes the same inputs as `f`. When\n * called, `g` returns `f().value`. In backward mode, custom gradients with\n * respect to each input of `f` are computed using `f().gradFunc`.\n *\n * ```js\n * const customOp = tf.customGrad(x => {\n * // Override gradient of our custom x ^ 2 op to be dy * abs(x);\n * return {value: x.square(), gradFunc: dy => [dy.mul(x.abs())]};\n * });\n *\n * const x = tf.tensor1d([-1, -2, 3]);\n * const dx = tf.grad(x => customOp(x));\n *\n * console.log(`f(x):`);\n * customOp(x).print();\n * console.log(`f'(x):`);\n * dx(x).print();\n * ```\n *\n * @param f The function to evaluate in forward mode, which should return\n * `{value: Tensor, gradFunc: (dy) => Tensor[]}`, where `gradFunc` returns\n * the custom gradients of `f` with respect to its inputs.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n return ENV.engine.customGrad(f);\n}\n\nfunction checkGrads(grads: Tensor[]) {\n const numNullGradients = grads.filter(g => g == null).length;\n if (numNullGradients > 0) {\n throw new Error(\n `Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.`);\n }\n}\n\nexport {\n gradScope,\n customGrad,\n variableGrads,\n valueAndGrad,\n valueAndGrads,\n grad,\n grads,\n};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Tensor} from './tensor';\nimport {ArrayData, DataType, TensorLike} from './types';\nimport {inferShape, isTypedArray, toTypedArray} from './util';\n\nexport function convertToTensor(\n x: T|TensorLike, argName: string, functionName: string,\n dtype: DataType = 'float32'): T {\n dtype = dtype || 'float32';\n if (x instanceof Tensor) {\n return x;\n }\n if (!isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' &&\n typeof x !== 'boolean') {\n throw new Error(\n `Argument '${argName}' passed to '${functionName}' must be a ` +\n `Tensor or TensorLike, but got ${x.constructor.name}`);\n }\n const inferredShape = inferShape(x);\n if (!isTypedArray(x) && !Array.isArray(x)) {\n x = [x] as number[];\n }\n return Tensor.make(\n inferredShape,\n {values: toTypedArray(x as ArrayData, dtype, ENV.get('DEBUG'))},\n dtype);\n}\n\nexport function convertToTensorArray(\n arg: T[]|TensorLike[], argName: string, functionName: string): T[] {\n if (!Array.isArray(arg)) {\n throw new Error(\n `Argument ${argName} passed to ${functionName} must be a ` +\n '`Tensor[]` or `TensorLike[]`');\n }\n const tensors = arg as T[];\n return tensors.map(\n (t, i) => convertToTensor(t, `${argName}[${i}]`, functionName));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\n\n/**\n * Used for wrapping functions that perform math operations on\n * Tensors. The function will be wrapped in a named scope that cleans all\n * memory usage after the function is done.\n */\nexport function op(f: {[name: string]: T}): T {\n const keys = Object.keys(f);\n if (keys.length !== 1) {\n throw new Error(\n `Please provide an object with a single key ` +\n `(operation name) mapping to a function. Got an object with ` +\n `${keys.length} keys.`);\n }\n\n let opName = keys[0];\n const fn = f[opName];\n\n // Strip the underscore from the end of the function name.\n if (opName.endsWith('_')) {\n opName = opName.substring(0, opName.length - 1);\n }\n\n // tslint:disable-next-line:no-any\n const f2 = (...args: any[]) => {\n ENV.engine.startScope(opName);\n try {\n const result = fn(...args);\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n ENV.engine.endScope(result);\n return result;\n } catch (ex) {\n ENV.engine.endScope(null);\n throw ex;\n }\n };\n Object.defineProperty(f2, 'name', {value: opName, configurable: true});\n\n // tslint:disable-next-line:no-any\n return f2 as any as T;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../gradients';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Computes the softmax normalized vector given the logits.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * ```js\n * const a = tf.tensor2d([2, 4, 6, 1, 2, 3], [2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction softmax_(logits: T|TensorLike, dim = -1): T {\n const $logits = convertToTensor(logits, 'logits', 'softmax');\n\n if (dim === -1) {\n dim = $logits.rank - 1;\n }\n if (dim !== $logits.rank - 1) {\n throw Error(\n 'Softmax along a non-last dimension is not yet supported. ' +\n `Logits was rank ${$logits.rank} and dim was ${dim}`);\n }\n\n const customOp = customGrad(logits => {\n // Do it in log space for numerical stability.\n // exp(X - logSumExp(X))\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n const logResult = logits.toFloat().sub(lse);\n const y = logResult.exp() as T;\n\n const gradFunc = (dy: T) => {\n const dyTimesY = dy.mul(y);\n const keepDims = true;\n return dyTimesY.sub(dyTimesY.sum([dim], keepDims).mul(y));\n };\n\n return {value: y, gradFunc};\n });\n\n return customOp($logits);\n}\n\nexport const softmax = op({softmax_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, Tensor5D, Tensor6D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, TensorLike1D, TensorLike2D, TensorLike3D, TensorLike4D, TensorLike5D, TensorLike6D} from '../types';\nimport {ArrayData, DataType, Rank, ShapeMap} from '../types';\nimport {assertNonNull, assertShapesMatch, getTypedArrayFromDType, inferShape, isTypedArray, makeOnesTypedArray, makeZerosTypedArray, sizeFromShape, toTypedArray} from '../util';\nimport {op} from './operation';\n\n/**\n * Creates a `Tensor` with the provided values, shape and dtype.\n *\n * ```js\n * // Pass an array of values to create a vector.\n * tf.tensor([1, 2, 3, 4]).print();\n * ```\n *\n * ```js\n * // Pass a nested array of values to make a matrix or a higher\n * // dimensional tensor.\n * tf.tensor([[1, 2], [3, 4]]).print();\n * ```\n *\n * ```js\n * // Pass a flat array and specify a shape yourself.\n * tf.tensor([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor(\n values: TensorLike, shape?: ShapeMap[R],\n dtype: DataType = 'float32'): Tensor {\n if (!isTypedArray(values) && !Array.isArray(values) &&\n typeof values !== 'number' && typeof values !== 'boolean') {\n throw new Error(\n 'values passed to tensor(values) must be an ' +\n 'array of numbers or booleans, or a TypedArray');\n }\n const inferredShape = inferShape(values);\n if (shape != null && inferredShape.length !== 1) {\n assertShapesMatch(\n shape, inferredShape,\n `Error creating a new Tensor. ` +\n `Inferred shape (${inferredShape}) does not match the ` +\n `provided shape (${shape}). `);\n }\n if (!isTypedArray(values) && !Array.isArray(values)) {\n values = [values] as number[];\n }\n shape = shape || inferredShape;\n return Tensor.make(\n shape, {\n values:\n toTypedArray(values as ArrayData, dtype, ENV.get('DEBUG'))\n },\n dtype);\n}\n\n/**\n * Creates rank-0 `Tensor` (scalar) with the provided value and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `scalar` as it makes the code more readable.\n *\n * ```js\n * tf.scalar(3.14).print();\n * ```\n *\n * @param value The value of the scalar.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction scalar(value: number|boolean, dtype: DataType = 'float32'): Scalar {\n if (isTypedArray(value) || Array.isArray(value)) {\n throw new Error(\n 'Error creating a new Scalar: value must be a primitive ' +\n '(number|boolean)');\n }\n return tensor(value, [], dtype);\n}\n\n/**\n * Creates rank-1 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor1d` as it makes the code more readable.\n *\n * ```js\n * tf.tensor1d([1, 2, 3]).print();\n * ```\n *\n * @param values The values of the tensor. Can be array of numbers,\n * or a `TypedArray`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor1d(values: TensorLike1D, dtype: DataType = 'float32'): Tensor1D {\n assertNonNull(values);\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 1) {\n throw new Error('tensor1d() requires values to be a flat/TypedArray');\n }\n return tensor(values, inferredShape as [number], dtype);\n}\n\n/**\n * Creates rank-2 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor2d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor2d([[1, 2], [3, 4]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor2d(\n values: TensorLike2D, shape?: [number, number],\n dtype: DataType = 'float32'): Tensor2D {\n assertNonNull(values);\n if (shape != null && shape.length !== 2) {\n throw new Error('tensor2d() requires shape to have two numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 2 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor2d() requires values to be number[][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor2d() requires shape to be provided when `values` ' +\n 'are a flat/TypedArray');\n }\n shape = shape || inferredShape as [number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-3 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor3d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor3d([[[1], [2]], [[3], [4]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor3d([1, 2, 3, 4], [2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor3d(\n values: TensorLike3D, shape?: [number, number, number],\n dtype: DataType = 'float32'): Tensor3D {\n assertNonNull(values);\n if (shape != null && shape.length !== 3) {\n throw new Error('tensor3d() requires shape to have three numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 3 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor3d() requires values to be number[][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor3d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-4 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor4d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor4d([[[[1], [2]], [[3], [4]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor4d([1, 2, 3, 4], [1, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor4d(\n values: TensorLike4D, shape?: [number, number, number, number],\n dtype: DataType = 'float32'): Tensor4D {\n assertNonNull(values);\n if (shape != null && shape.length !== 4) {\n throw new Error('tensor4d() requires shape to have four numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 4 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor4d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor4d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-5 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor5d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor5d([[[[[1], [2]], [[3], [4]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor5d([1, 2, 3, 4, 5, 6, 7, 8], [1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor5d(\n values: TensorLike5D, shape?: [number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor5D {\n assertNonNull(values);\n if (shape != null && shape.length !== 5) {\n throw new Error('tensor5d() requires shape to have five numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 5 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor5d() requires values to be ' +\n 'number[][][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor5d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-6 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor6d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor6d([[[[[[1],[2]],[[3],[4]]],[[[5],[6]],[[7],[8]]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor6d([1, 2, 3, 4, 5, 6, 7, 8], [1, 1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor6d(\n values: TensorLike6D,\n shape?: [number, number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor6D {\n assertNonNull(values);\n if (shape != null && shape.length !== 6) {\n throw new Error('tensor6d() requires shape to have six numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 6 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor6d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor6d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape ||\n inferredShape as [number, number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1.\n *\n * ```js\n * tf.ones([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction ones(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0.\n *\n * ```js\n * tf.zeros([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Can\n * be 'float32', 'int32' or 'bool'. Defaults to 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zeros(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeZerosTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` filled with a scalar value.\n *\n * ```js\n * tf.fill([2, 2], 4).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param value The scalar value to fill the tensor with.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fill(\n shape: ShapeMap[R], value: number, dtype: DataType = 'float32'): Tensor {\n const values = getTypedArrayFromDType(dtype, sizeFromShape(shape));\n values.fill(value);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.onesLike(x).print();\n * ```\n * @param x A tensor.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction onesLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'onesLike');\n return ones($x.shape, $x.dtype) as T;\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.zerosLike(x).print();\n * ```\n *\n * @param x The tensor of required shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zerosLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'zerosLike');\n return zeros($x.shape, $x.dtype) as T;\n}\n\n/**\n * Return an evenly spaced sequence of numbers over the given interval.\n *\n * ```js\n * tf.linspace(0, 9, 10).print();\n * ```\n * @param start The start value of the sequence.\n * @param stop The end value of the sequence.\n * @param num The number of values to generate.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction linspace(start: number, stop: number, num: number): Tensor1D {\n if (num === 0) {\n throw new Error('Cannot request zero samples');\n }\n\n const step = (stop - start) / (num - 1);\n\n const values = makeZerosTypedArray(num, 'float32');\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, 'float32');\n}\n\n/**\n * Creates a new `Tensor1D` filled with the numbers in the range provided.\n *\n * The tensor is a is half-open interval meaning it includes start, but\n * excludes stop. Decrementing ranges and negative step values are also\n * supported.\n *\n * ```js\n * tf.range(0, 9, 2).print();\n * ```\n *\n * @param start An integer start value\n * @param stop An integer stop value\n * @param step An integer increment (will default to 1 or -1)\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction range(\n start: number, stop: number, step = 1,\n dtype: 'float32'|'int32' = 'float32'): Tensor1D {\n if (step === 0) {\n throw new Error('Cannot have a step of zero');\n }\n\n const sameStartStop = start === stop;\n const increasingRangeNegativeStep = start < stop && step < 0;\n const decreasingRangePositiveStep = stop < start && step > 1;\n\n if (sameStartStop || increasingRangeNegativeStep ||\n decreasingRangePositiveStep) {\n return zeros([0], dtype);\n }\n\n const numElements = Math.abs(Math.ceil((stop - start) / step));\n const values = makeZerosTypedArray(numElements, dtype);\n\n if (stop < start && step === 1) {\n // Auto adjust the step's sign if it hasn't been set\n // (or was set to 1)\n step = -1;\n }\n\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, dtype);\n}\n\nexport {\n fill,\n linspace,\n ones,\n range,\n scalar,\n tensor,\n tensor1d,\n tensor2d,\n tensor3d,\n tensor4d,\n tensor5d,\n tensor6d,\n zeros\n};\n\nexport const onesLike = op({onesLike_});\nexport const zerosLike = op({zerosLike_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport enum DType {\n float32 = 'float32',\n int32 = 'int32',\n bool = 'bool'\n}\n\n/** @docalias number[] */\nexport interface ShapeMap {\n R0: number[];\n R1: [number];\n R2: [number, number];\n R3: [number, number, number];\n R4: [number, number, number, number];\n R5: [number, number, number, number, number];\n R6: [number, number, number, number, number, number];\n}\n\n/** @hidden */\nexport interface DataTypeMap {\n float32: Float32Array;\n int32: Int32Array;\n bool: Uint8Array;\n}\n/** @docalias 'float32'|'int32'|'bool' */\nexport type DataType = keyof DataTypeMap;\nexport type TypedArray = DataTypeMap[DataType];\n\nexport enum Rank {\n R0 = 'R0',\n R1 = 'R1',\n R2 = 'R2',\n R3 = 'R3',\n R4 = 'R4',\n R5 = 'R5',\n R6 = 'R6'\n}\n\nexport type FlatVector = boolean[]|number[]|TypedArray;\nexport type RegularArray =\n T[]|T[][]|T[][][]|T[][][][]|T[][][][][]|T[][][][][][];\nexport type ArrayData =\n DataTypeMap[D]|RegularArray|RegularArray;\n\n// tslint:disable-next-line:no-any\nexport interface RecursiveArray {\n [index: number]: T|RecursiveArray;\n}\n\nenum UpcastInt32AndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'int32'\n}\n\nenum UpcastBoolAndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'bool'\n}\n\nenum UpcastFloat32AndMap {\n 'float32' = 'float32',\n 'int32' = 'float32',\n 'bool' = 'float32'\n}\n\nconst upcastTypeMap = {\n 'float32': UpcastFloat32AndMap,\n 'int32': UpcastInt32AndMap,\n 'bool': UpcastBoolAndMap\n};\n\nexport function upcastType(typeA: DataType, typeB: DataType): DataType {\n return upcastTypeMap[typeA][typeB];\n}\n\n/** Returns the output type after summation. */\nexport function sumOutType(type: DataType) {\n return upcastType(type, 'int32');\n}\n\n/** @docalias TypedArray|Array */\nexport type TensorLike =\n TypedArray|number|boolean|number[]|number[][]|number[][][]|number[][][][]|\n number[][][][][]|number[][][][][][]|boolean[]|boolean[][]|boolean[][][]|\n boolean[][][][]|boolean[][][][][]|boolean[][][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike1D = TypedArray|number[]|boolean[];\n/** @docalias TypedArray|Array */\nexport type TensorLike2D = TypedArray|number[]|number[][]|boolean[]|boolean[][];\n/** @docalias TypedArray|Array */\nexport type TensorLike3D =\n TypedArray|number[]|number[][][]|boolean[]|boolean[][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike4D =\n TypedArray|number[]|number[][][][]|boolean[]|boolean[][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike5D =\n TypedArray|number[]|number[][][][][]|boolean[]|boolean[][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike6D =\n TypedArray|number[]|number[][][][][][]|boolean[]|boolean[][][][][][];\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {scalar} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {Rank} from '../types';\nimport {DataType, ShapeMap} from '../types';\nimport {hasEncodingLoss} from '../util';\nimport {KernelBackend} from './backend';\n\nexport function castTensor(\n x: T, dtype: DataType, backend: KernelBackend): T {\n if (!hasEncodingLoss(x.dtype, dtype)) {\n // We don't change the underlying data, since we cast to higher\n // precision.\n return Tensor.make(x.shape, {dataId: x.dataId}, dtype) as T;\n }\n if (dtype === 'int32') {\n return backend.int(x);\n } else if (dtype === 'bool') {\n return backend.notEqual(x, scalar(0, x.dtype)) as T;\n } else {\n throw new Error(`Error in Cast: unknown dtype argument (${dtype})`);\n }\n}\n\nexport function reshapeTensor(\n x: T, shape: ShapeMap[R]): Tensor {\n return Tensor.make(shape, {dataId: x.dataId}, x.dtype);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Implementation of the NonMaxSuppression kernel shared between webgl and cpu.\n */\n\nimport {tensor1d} from '../ops/tensor_ops';\nimport {Tensor1D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function nonMaxSuppressionImpl(\n boxes: TypedArray, scores: TypedArray, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const candidates = Array.from(scores)\n .map((score, boxIndex) => ({score, boxIndex}))\n .filter(c => c.score > scoreThreshold)\n .sort((c1, c2) => c2.score - c1.score);\n\n const selected: number[] = [];\n\n for (let i = 0; i < candidates.length; i++) {\n const {score, boxIndex} = candidates[i];\n if (score < scoreThreshold) {\n break;\n }\n\n let ignoreCandidate = false;\n for (let j = selected.length - 1; j >= 0; --j) {\n const iou = intersectionOverUnion(boxes, boxIndex, selected[j]);\n if (iou >= iouThreshold) {\n ignoreCandidate = true;\n break;\n }\n }\n\n if (!ignoreCandidate) {\n selected.push(boxIndex);\n if (selected.length >= maxOutputSize) {\n break;\n }\n }\n }\n\n return tensor1d(selected, 'int32');\n}\n\nfunction intersectionOverUnion(boxes: TypedArray, i: number, j: number) {\n const iCoord = boxes.subarray(i * 4, i * 4 + 4);\n const jCoord = boxes.subarray(j * 4, j * 4 + 4);\n const yminI = Math.min(iCoord[0], iCoord[2]);\n const xminI = Math.min(iCoord[1], iCoord[3]);\n const ymaxI = Math.max(iCoord[0], iCoord[2]);\n const xmaxI = Math.max(iCoord[1], iCoord[3]);\n const yminJ = Math.min(jCoord[0], jCoord[2]);\n const xminJ = Math.min(jCoord[1], jCoord[3]);\n const ymaxJ = Math.max(jCoord[0], jCoord[2]);\n const xmaxJ = Math.max(jCoord[1], jCoord[3]);\n const areaI = (ymaxI - yminI) * (xmaxI - xminI);\n const areaJ = (ymaxJ - yminJ) * (xmaxJ - xminJ);\n if (areaI <= 0 || areaJ <= 0) {\n return 0.0;\n }\n const intersectionYmin = Math.max(yminI, yminJ);\n const intersectionXmin = Math.max(xminI, xminJ);\n const intersectionYmax = Math.min(ymaxI, ymaxJ);\n const intersectionXmax = Math.min(xmaxI, xmaxJ);\n const intersectionArea = Math.max(intersectionYmax - intersectionYmin, 0.0) *\n Math.max(intersectionXmax - intersectionXmin, 0.0);\n return intersectionArea / (areaI + areaJ - intersectionArea);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the TopK kernel shared between webgl and cpu. */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {DataType, TypedArray} from '../types';\nimport {getTypedArrayFromDType} from '../util';\n\nexport function topkImpl(\n x: TypedArray, xShape: number[], xDtype: DataType, k: number,\n sorted: boolean): [T, T] {\n // Reshape into a 2d tensor [batch, lastDim] and compute topk along lastDim.\n const lastDim = xShape[xShape.length - 1];\n const [batch, size] = [x.length / lastDim, lastDim];\n const allTopKVals = getTypedArrayFromDType(xDtype, batch * k);\n const allTopKIndices = getTypedArrayFromDType('int32', batch * k);\n\n for (let b = 0; b < batch; b++) {\n const offset = b * size;\n const vals = x.subarray(offset, offset + size);\n const valAndInd: Array<{value: number, index: number}> = [];\n for (let i = 0; i < vals.length; i++) {\n valAndInd.push({value: vals[i], index: i});\n }\n valAndInd.sort((a, b) => b.value - a.value);\n\n const outOffset = b * k;\n const topKVals = allTopKVals.subarray(outOffset, outOffset + k);\n const topKIndices = allTopKIndices.subarray(outOffset, outOffset + k);\n for (let i = 0; i < k; i++) {\n topKVals[i] = valAndInd[i].value;\n topKIndices[i] = valAndInd[i].index;\n }\n }\n // Reshape back to the original input shape, except that the last\n // dimension is k.\n const outputShape = xShape.slice();\n outputShape[outputShape.length - 1] = k;\n return [\n tensor(allTopKVals, outputShape, xDtype) as T,\n tensor(allTopKIndices, outputShape, 'int32') as T\n ];\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ArgMinMaxProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n\n constructor(reduceInfo: ReduceInfo, op: 'max'|'min', firstPass: boolean) {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n if (!firstPass) {\n this.variableNames.push('bestIndicesA');\n }\n this.outputShape = [batchSize, outSize];\n const compOp = (op === 'max') ? '>' : '<';\n const indexSnippet = firstPass ?\n 'inOffset + i;' :\n 'round(getBestIndicesA(batch, inOffset + i));';\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < ${windowSize}; i++) {\n int inIdx = ${indexSnippet};\n float candidate = getA(batch, inIdx);\n if (candidate ${compOp} bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class AvgPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float avgMultiplier = float(${avgMultiplier});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Returns the dimensions in the input shape that are broadcasted to\n * produce the provided output shape.\n *\n * The returned dimensions are 0-indexed and sorted. An example:\n * inShape = [4, 1, 3]\n * outShape = [5, 4, 3, 3]\n * result = [1]. Dimension 1 (2nd dimension of input) gets broadcasted 1 => 3.\n */\nexport function getBroadcastDims(\n inShape: number[], outShape: number[]): number[] {\n const inRank = inShape.length;\n const dims: number[] = [];\n for (let i = 0; i < inRank; i++) {\n const dim = inRank - 1 - i;\n const a = inShape[dim] || 1;\n const b = outShape[outShape.length - 1 - i] || 1;\n if (b > 1 && a === 1) {\n dims.unshift(dim);\n }\n }\n return dims;\n}\n\n/**\n * Returns the axes in the output space that should be reduced to produce\n * the input space.\n */\nexport function getReductionAxes(\n inShape: number[], outShape: number[]): number[] {\n const result: number[] = [];\n for (let i = 0; i < outShape.length; i++) {\n const inDim = inShape[inShape.length - i - 1];\n const outAxis = outShape.length - i - 1;\n const outDim = outShape[outAxis];\n if (inDim == null || (inDim === 1 && outDim > 1)) {\n result.unshift(outAxis);\n }\n }\n return result;\n}\n\n/**\n * Given the output of `getBroadcastDims()`, returns true if the broadcasting\n * is along the outer-most dimensions of the input.\n */\nexport function broadcastDimsAreOuter(dims: number[]): boolean {\n for (let i = 0; i < dims.length; i++) {\n if (dims[i] !== i) {\n return false;\n }\n }\n return true;\n}\n\nexport function assertAndGetBroadcastShape(\n shapeA: number[], shapeB: number[]): number[] {\n const result: number[] = [];\n const errMsg = `Operands could not be broadcast together with shapes ` +\n `${shapeA} and ${shapeB}.`;\n const l = Math.max(shapeA.length, shapeB.length);\n\n for (let i = 0; i < l; i++) {\n const a = shapeA[shapeA.length - i - 1] || 1;\n const b = shapeB[shapeB.length - i - 1] || 1;\n if (a > 1 && b > 1 && a !== b) {\n throw Error(errMsg);\n }\n result.unshift(Math.max(a, b));\n }\n return result;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class BatchNormProgram implements GPGPUProgram {\n variableNames: string[];\n outputShape: number[] = [];\n userCode: string;\n supportsBroadcasting = true;\n\n constructor(\n xShape: number[], meanShape: number[], varianceShape: number[],\n offsetShape: number[]|null, scaleShape: number[]|null,\n varianceEpsilon: number) {\n this.variableNames = ['x', 'mean', 'variance'];\n broadcast_util.assertAndGetBroadcastShape(xShape, meanShape);\n broadcast_util.assertAndGetBroadcastShape(xShape, varianceShape);\n\n let offsetSnippet = '0.0';\n if (offsetShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, offsetShape);\n this.variableNames.push('offset');\n offsetSnippet = 'getOffsetAtOutCoords()';\n }\n\n let scaleSnippet = '1.0';\n if (scaleShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, scaleShape);\n this.variableNames.push('scale');\n scaleSnippet = 'getScaleAtOutCoords()';\n }\n\n this.outputShape = xShape;\n this.userCode = `\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = ${offsetSnippet};\n float scale = ${scaleSnippet};\n float inv = scale * inversesqrt(variance + float(${varianceEpsilon}));\n setOutput((x - mean) * inv + offset);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nconst CHECK_NAN_SNIPPET = `\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n`;\n\nexport const ADD = 'return a + b;';\nexport const SUB = 'return a - b;';\nexport const MUL = 'return a * b;';\nexport const DIV = `if (a == b) return 1.0;\n return a / b;`;\n\n// We use native integer division to deal with floating point imprecision. Since\n// we implement floor division and glsl implements truncated division, we\n// correct for this by subtracting 1 from result when the result is negative and\n// there is a remainder.\nexport const INT_DIV = `\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n`;\n\nexport const POW = `\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n`;\nexport const SQUARED_DIFFERENCE = 'return (a - b) * (a - b);';\n\nexport const EQUAL = `return float(a == b);`;\n\nexport const NOT_EQUAL = `return float(a != b);`;\n\nexport const LESS = `return float(a < b);`;\n\nexport const LESS_EQUAL = `return float(a <= b);`;\n\nexport const GREATER = `return float(a > b);`;\n\nexport const GREATER_EQUAL = `return float(a >= b);`;\n\nexport const LOGICAL_AND = `return float(a >= 1.0 && b >= 1.0);`;\n\nexport const LOGICAL_OR = `return float(a >= 1.0 || b >= 1.0);`;\n\nexport const MAX = CHECK_NAN_SNIPPET + `\n return max(a, b);\n`;\nexport const MIN = CHECK_NAN_SNIPPET + `\n return min(a, b);\n`;\nexport const MOD = `if (b == 0.0) return NAN;\n return mod(a, b);`;\n\nexport const ATAN2 = CHECK_NAN_SNIPPET + `\n return atan(a, b);\n`;\n\nexport const ELU_DER = `return (b >= 1.0) ? a : a * (b + 1.0);`;\n\nexport class BinaryOpProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting = true;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(op: string, aShape: number[], bShape: number[]) {\n this.outputShape =\n broadcast_util.assertAndGetBroadcastShape(aShape, bShape);\n this.userCode = `\n uniform float NAN;\n float binaryOperation(float a, float b) {\n ${op}\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ClipProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(aShape: number[], min: number, max: number) {\n this.outputShape = aShape;\n const minFixed = min.toFixed(20);\n const maxFixed = max.toFixed(20);\n this.userCode = `\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, ${minFixed}, ${maxFixed}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport function assertParams(aShape: number[], bShape: number[], axis: number) {\n const aRank = aShape.length;\n const bRank = bShape.length;\n util.assert(\n aShape.length === bShape.length,\n `Error in concat${aRank}D: rank of x1 (${aRank}) and x2 (${bRank}) ` +\n `must be the same.`);\n\n util.assert(\n axis >= 0 && axis < aRank,\n `Error in concat${aRank}D: axis must be ` +\n `between 0 and ${aRank - 1}.`);\n\n for (let i = 0; i < aRank; i++) {\n util.assert(\n (i === axis) || (aShape[i] === bShape[i]),\n `Error in concat${aRank}D: Shape (${aShape}) does not match ` +\n `(${bShape}) along the non-concatenated axis ${i}.`);\n }\n}\n\nexport function computeOutShape(\n x1Shape: number[], x2Shape: number[], axis: number): number[] {\n util.assert(\n x1Shape.length === x2Shape.length,\n 'x1 and x2 should have the same rank.');\n const outputShape = x1Shape.slice();\n outputShape[axis] += x2Shape[axis];\n return outputShape;\n}\n\nexport function computeGradientSliceShapes(\n aShape: [number, number], bShape: [number, number]) {\n return {\n aBegin: [0, 0] as [number, number],\n aSize: aShape,\n bBegin: [0, aShape[1]] as [number, number],\n bSize: bShape\n };\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as concat_util from '../../ops/concat_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ConcatProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[] = [];\n userCode: string;\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n constructor(aShape: [number, number], bShape: [number, number]) {\n this.outputShape =\n concat_util.computeOutShape(aShape, bShape, 1 /* axis */);\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < ${aShape[1]}) {\n value = getA(yR, yC);\n } else {\n yC -= ${aShape[1]};\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class Conv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n for (int d2 = 0; d2 < ${convInfo.outChannels}; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * ${channelMul} + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class DepthwiseConv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < ${channelMul}; dm++) {\n int d2 = d1 * ${channelMul} + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n\n const inputDepthNearestVec4 = Math.floor(convInfo.inChannels / 4) * 4;\n const inputDepthVec4Remainder = convInfo.inChannels % 4;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n for (int d1 = 0; d1 < ${inputDepthNearestVec4}; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (${inputDepthVec4Remainder === 1}) {\n dotProd +=\n getX(batch, xR, xC, ${inputDepthNearestVec4}) *\n getW(wR, wC, ${inputDepthNearestVec4}, d2);\n } else if (${inputDepthVec4Remainder === 2}) {\n vec2 xValues = vec2(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (${inputDepthVec4Remainder === 3}) {\n vec3 xValues = vec3(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n\n const xNumRows = convInfo.inHeight;\n const xNumCols = convInfo.inWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / ${channelMul};\n int q = d2 - d1 * ${channelMul};\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${xNumRows}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${xNumCols}) {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport * as util from '../../util';\n\nexport type ShapeInfo = {\n logicalShape: number[],\n texShape: [number, number],\n isUniform: boolean\n};\n\nexport type InputInfo = {\n name: string,\n shapeInfo: ShapeInfo\n};\n\nexport function makeShader(\n inputsInfo: InputInfo[], outputShape: ShapeInfo, userCode: string,\n broadcast: boolean): string {\n let inputPrefixSnippet: string[]|string = inputsInfo.map(x => {\n const size = util.sizeFromShape(x.shapeInfo.logicalShape);\n if (x.shapeInfo.isUniform) {\n return `uniform float ${x.name}${size > 1 ? `[${size}]` : ''};`;\n }\n return `uniform sampler2D ${x.name};`;\n });\n inputPrefixSnippet = inputPrefixSnippet.join('\\n');\n const inputSamplingSnippet =\n inputsInfo.map(x => getInputSamplingSnippet(x, outputShape, broadcast))\n .join('\\n');\n const outTexShape = outputShape.texShape;\n const outputSamplingSnippet =\n getOutputSamplingSnippet(outputShape.logicalShape, outTexShape);\n const source = [\n SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET,\n FLOAT_TEXTURE_SETOUTPUT_SNIPPET, inputPrefixSnippet, outputSamplingSnippet,\n inputSamplingSnippet, userCode\n ].join('\\n');\n return source;\n}\n\nfunction getSamplerFromInInfo(inInfo: InputInfo): string {\n const shape = inInfo.shapeInfo.logicalShape;\n switch (shape.length) {\n case 0:\n return getSamplerScalar(inInfo);\n case 1:\n return getSampler1D(inInfo);\n case 2:\n return getSampler2D(inInfo);\n case 3:\n return getSampler3D(inInfo);\n case 4:\n return getSampler4D(inInfo);\n case 5:\n return getSampler5D(inInfo);\n case 6:\n return getSampler6D(inInfo);\n default:\n throw new Error(\n `${shape.length}-D input sampling` +\n ` is not yet supported`);\n }\n}\n\nfunction getInputSamplingSnippet(\n inInfo: InputInfo, outShapeInfo: ShapeInfo, broadcast: boolean): string {\n let res = getSamplerFlat(inInfo);\n res += getSamplerFromInInfo(inInfo);\n\n // If input and output have matching logical shapes, add\n // getTexNameAtOutCoord() method that samples the input\n // textureSampler using the output coordinates.\n if (broadcast ||\n util.arraysEqual(\n inInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape)) {\n res += getSamplerAtOutputCoords(inInfo, outShapeInfo, broadcast);\n }\n return res;\n}\n\nfunction getOutputSamplingSnippet(\n outShape: number[], outTexShape: [number, number]): string {\n switch (outShape.length) {\n case 0:\n return getOutputScalarCoords();\n case 1:\n return getOutput1DCoords(outShape as [number], outTexShape);\n case 2:\n return getOutput2DCoords(outShape as [number, number], outTexShape);\n case 3:\n return getOutput3DCoords(\n outShape as [number, number, number], outTexShape);\n case 4:\n return getOutput4DCoords(\n outShape as [number, number, number, number], outTexShape);\n case 5:\n return getOutput5DCoords(\n outShape as [number, number, number, number, number], outTexShape);\n case 6:\n return getOutput6DCoords(\n outShape as [number, number, number, number, number, number],\n outTexShape);\n default:\n throw new Error(\n `${outShape.length}-D output sampling is not yet supported`);\n }\n}\n\nconst SAMPLE_1D_SNIPPET = `\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_2D_SNIPPET = `\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_3D_SNIPPET = `\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_4D_SNIPPET = `\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_5D_SNIPPET = `\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_6D_SNIPPET = `\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst FLOAT_TEXTURE_SAMPLE_SNIPPET = `\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n`;\n\nconst FLOAT_TEXTURE_SETOUTPUT_SNIPPET = `\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n`;\n\nconst SHADER_PREFIX = `\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n ${SAMPLE_1D_SNIPPET}\n ${SAMPLE_2D_SNIPPET}\n ${SAMPLE_3D_SNIPPET}\n ${SAMPLE_4D_SNIPPET}\n ${SAMPLE_5D_SNIPPET}\n ${SAMPLE_6D_SNIPPET}\n`;\n\nfunction getOutputScalarCoords() {\n return `\n int getOutputCoords() {\n return 0;\n }\n `;\n}\n\nfunction getOutput1DCoords(\n shape: [number], texShape: [number, number]): string {\n if (texShape[0] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.x * ${texShape[1]}.0);\n }\n `;\n }\n if (texShape[1] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.y * ${texShape[0]}.0);\n }\n `;\n }\n return `\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n return resTexRC.x * ${texShape[1]} + resTexRC.y;\n }\n `;\n}\n\nfunction getOutput3DCoords(\n shape: [number, number, number], texShape: [number, number]): string {\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n return `\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${stride0};\n index -= r * ${stride0};\n int c = index / ${stride1};\n int d = index - c * ${stride1};\n return ivec3(r, c, d);\n }\n `;\n}\n\nfunction getOutput4DCoords(\n shape: [number, number, number, number],\n texShape: [number, number]): string {\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n int d2 = index - d * ${stride2};\n\n return ivec4(r, c, d, d2);\n }\n `;\n}\n\nfunction getOutput5DCoords(\n shape: [number, number, number, number, number],\n texShape: [number, number]): string {\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(${texShape[0]},\n ${texShape[1]}));\n\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n int d3 = index - d2 * ${stride3};\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n `;\n}\n\nfunction getOutput6DCoords(\n shape: [number, number, number, number, number, number],\n texShape: [number, number]): string {\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n return `\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n index -= d2 * ${stride3};\n\n int d3 = index / ${stride4};\n int d4 = index - d3 * ${stride4};\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n `;\n}\n\nfunction getOutput2DCoords(\n shape: [number, number], texShape: [number, number]): string {\n if (util.arraysEqual(shape, texShape)) {\n return `\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(${texShape[0]}, ${texShape[1]}));\n }\n `;\n }\n if (shape[1] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(index, 0);\n }\n `;\n }\n if (shape[0] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(0, index);\n }\n `;\n }\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${shape[1]};\n int c = index - r * ${shape[1]};\n return ivec2(r, c);\n }\n `;\n}\n\nfunction getSamplerScalar(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n if (inputInfo.shapeInfo.isUniform) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n}\n\nfunction getSampler1D(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n return `\n float ${funcName}(int index) {\n return ${funcName}Flat(index);\n }\n `;\n}\n\nfunction getSampler2D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n const texShape = inputInfo.shapeInfo.texShape;\n if (texShape != null && util.arraysEqual(shape, texShape)) {\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumR === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2((float(index) + 0.5) / ${texNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = UVfrom2D(${texNumR}, ${texNumC}, ${shape[1]}, row, col);\n return sampleTexture(${texName}, uv);\n }\n`;\n}\n\nfunction getSampler3D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col', 'depth'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int index = row * ${stride0} + col * ${stride1} + depth;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row;\n int texC = col * ${stride1} + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride1) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row * ${shape[1]} + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n ${texNumR}, ${texNumC}, ${stride0}, ${stride1}, row, col, depth);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler4D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride2) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, row, col, depth, depth2);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler5D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} +\n depth2 * ${stride3} + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride3) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} +\n depth * ${shape[3]} + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, row, col, depth, depth2, depth3);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler6D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3 * ${stride3}\n + depth4\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride4) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, ${stride4}\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSamplerFlat(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName =\n 'get' + texName.charAt(0).toUpperCase() + texName.slice(1) + 'Flat';\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n\n if (inputInfo.shapeInfo.isUniform) {\n if (inSize === 1) {\n return `float ${funcName}(int index) {return ${texName};}`;\n }\n return `\n float ${funcName}(int index) {\n for (int i = 0; i < ${inSize}; i++) {\n if (i == index) {\n return ${texName}[i];\n }\n }\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const tNumR = texShape[0];\n const tNumC = texShape[1];\n if (tNumC === 1 && tNumR === 1) {\n return `\n float ${funcName}(int index) {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n }\n if (tNumC === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${tNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (tNumR === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2((float(index) + 0.5) / ${tNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int index) {\n vec2 uv = UVfrom1D(${tNumR}, ${tNumC}, index);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getBroadcastOutputCoordsSampler(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo, texFuncSnippet: string,\n funcName: string): string {\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n\n let type = 'int';\n if (outRank === 2) {\n type = 'ivec2';\n } else if (outRank === 3) {\n type = 'ivec3';\n } else if (outRank === 4) {\n type = 'ivec4';\n }\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const rankDiff = outRank - inRank;\n let coordsSnippet: string;\n if (inRank === 0) {\n coordsSnippet = '';\n } else if (outRank < 2 && broadcastDims.length >= 1) {\n coordsSnippet = 'coords = 0;';\n } else {\n coordsSnippet =\n broadcastDims.map(d => `coords[${d + rankDiff}] = 0;`).join('\\n');\n }\n let unpackedCoordsSnippet = '';\n if (outRank < 2 && inRank > 0) {\n unpackedCoordsSnippet = 'coords';\n } else {\n unpackedCoordsSnippet = inputInfo.shapeInfo.logicalShape\n .map((s, i) => `coords[${i + rankDiff}]`)\n .join(', ');\n }\n return `\n float ${funcName}() {\n ${type} coords = getOutputCoords();\n ${coordsSnippet}\n return get${texFuncSnippet}(${unpackedCoordsSnippet});\n }\n `;\n}\n\nfunction getSamplerAtOutputCoords(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo,\n supportsBroadcasting: boolean) {\n const texName = inputInfo.name;\n const texFuncSnippet = texName.charAt(0).toUpperCase() + texName.slice(1);\n const funcName = 'get' + texFuncSnippet + 'AtOutCoords';\n\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n const doBroadcast =\n supportsBroadcasting && ((outRank > inRank) || broadcastDims.length > 0);\n const broadcastOverOuter =\n broadcast_util.broadcastDimsAreOuter(broadcastDims);\n const isUniform = inputInfo.shapeInfo.isUniform;\n\n if (doBroadcast && !broadcastOverOuter) {\n return getBroadcastOutputCoordsSampler(\n inputInfo, outShapeInfo, texFuncSnippet, funcName);\n }\n\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n let broadcastSnippet = '';\n if (doBroadcast && broadcastOverOuter) {\n broadcastSnippet = `\n int mainPart = index / ${inSize};\n index -= mainPart * ${inSize};\n `;\n }\n\n const outTexShape = outShapeInfo.texShape;\n if (isUniform) {\n if (inSize === 1) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n return get${texFuncSnippet}Flat(index);\n }\n `;\n }\n\n // At this point, the input is not a uniform.\n const inTexShape = inputInfo.shapeInfo.texShape;\n if (util.arraysEqual(inTexShape, outTexShape)) {\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, resultUV);\n }\n `;\n }\n\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n int texR = index / ${inTexShape[1]};\n int texC = index - texR * ${inTexShape[1]};\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${inTexShape[1]}.0, ${inTexShape[0]}.0);\n\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nexport function getCoordsDataType(rank: number): string {\n if (rank <= 1) {\n return 'int';\n } else if (rank === 2) {\n return 'ivec2';\n } else if (rank === 3) {\n return 'ivec3';\n } else if (rank === 4) {\n return 'ivec4';\n } else if (rank === 5) {\n return 'ivec5';\n } else if (rank === 6) {\n return 'ivec6';\n } else {\n throw Error(`GPU for rank ${rank} is not yet supported`);\n }\n}\n\n/** Returns a new input info (a copy) that has a squeezed logical shape. */\nfunction squeezeInputInfo(\n inInfo: InputInfo, squeezedShape: number[]): InputInfo {\n // Deep copy.\n const newInputInfo: InputInfo = JSON.parse(JSON.stringify(inInfo));\n newInputInfo.shapeInfo.logicalShape = squeezedShape;\n return newInputInfo;\n}\n\nfunction getSqueezedParams(params: string[], keptDims: number[]): string {\n return keptDims.map(d => params[d]).join(', ');\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class CumSumProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(shape: number[], exclusive: boolean, reverse: boolean) {\n this.outputShape = shape;\n const rank = shape.length;\n const finalDim = shape[shape.length - 1];\n const comparator = reverse ? '<' : '>';\n\n this.userCode = `\n int getIndex(int i) {\n ${reverse ? `return ${finalDim} -i - 1;` : 'return i;'}\n }\n\n void main() {\n ${getCoordsDataType(rank)} coords = getOutputCoords();\n int end = ${getFinalCoord(rank, 'coords')};\n float val = 0.0;\n for (int i = ${finalDim} - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx ${comparator} end) {\n continue;\n }\n if (idx == end && ${exclusive}) {\n continue;\n }\n ${getFinalCoord(rank, 'coords')} = idx;\n val += getX(${getCoords(rank, 'coords')});\n }\n setOutput(val);\n }\n `;\n }\n}\n\nfunction getCoords(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.x, ${name}.y`;\n } else if (rank === 3) {\n return `${name}.x, ${name}.y, ${name}.z`;\n } else if (rank === 4) {\n return `${name}.x, ${name}.y, ${name}.z, ${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n\nfunction getFinalCoord(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.y`;\n } else if (rank === 3) {\n return `${name}.z`;\n } else if (rank === 4) {\n return `${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class EncodeFloatProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n this.outputShape = outputShape;\n this.userCode = `\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, DataTypeMap} from '../../types';\n\nexport enum TextureUsage {\n RENDER,\n UPLOAD,\n PIXELS,\n DOWNLOAD\n}\n\nexport enum PhysicalTextureType {\n FLOAT16,\n FLOAT32,\n UNSIGNED_BYTE\n}\n\nexport interface TextureData {\n texture: WebGLTexture;\n shape: number[];\n /** [rows, columns] shape of the texture. */\n texShape: [number, number];\n dtype: DataType;\n values: DataTypeMap[DataType];\n usage: TextureUsage;\n}\n\nexport function getUnpackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns, rows];\n}\n\nexport function getUnpackedArraySizeFromMatrixSize(\n matrixSize: number, channelsPerTexture: number): number {\n return matrixSize * channelsPerTexture;\n}\n\nexport function getColorMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns * 4, rows];\n}\n\nexport function getMatrixSizeFromUnpackedArraySize(\n unpackedSize: number, channelsPerTexture: number): number {\n if (unpackedSize % channelsPerTexture !== 0) {\n throw new Error(\n `unpackedSize (${unpackedSize}) must be a multiple of ` +\n `${channelsPerTexture}`);\n }\n return unpackedSize / channelsPerTexture;\n}\n\nexport type TypedArray = Float32Array|Uint8Array;\n\nexport function encodeMatrixToUnpackedArray(\n matrix: TypedArray, unpackedArray: TypedArray, channelsPerTexture: number) {\n const requiredSize =\n getUnpackedArraySizeFromMatrixSize(matrix.length, channelsPerTexture);\n if (unpackedArray.length < requiredSize) {\n throw new Error(\n `unpackedArray length (${unpackedArray.length}) must be >= ` +\n `${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < matrix.length; ++src) {\n unpackedArray[dst] = matrix[src];\n dst += channelsPerTexture;\n }\n}\n\nexport function decodeMatrixFromUnpackedArray(\n unpackedArray: Float32Array, matrix: Float32Array,\n channelsPerTexture: number) {\n const requiredSize = getMatrixSizeFromUnpackedArraySize(\n unpackedArray.length, channelsPerTexture);\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += channelsPerTexture) {\n matrix[dst++] = unpackedArray[src];\n }\n}\n\nexport function decodeMatrixFromUnpackedColorRGBAArray(\n unpackedArray: Float32Array, matrix: Float32Array, channels: number) {\n const requiredSize = unpackedArray.length * channels / 4;\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += 4) {\n for (let c = 0; c < channels; c++) {\n matrix[dst++] = unpackedArray[src + c];\n }\n }\n}\n\nexport function getPackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [Math.ceil(columns / 2), Math.ceil(rows / 2)];\n}\n\nexport function getPackedRGBAArraySizeFromMatrixShape(\n rows: number, columns: number): number {\n const [w, h] = getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return w * h * 4;\n}\n\nexport function encodeMatrixToPackedRGBA(\n matrix: Float32Array, rows: number, columns: number,\n packedRGBA: Float32Array) {\n const requiredSize = getPackedRGBAArraySizeFromMatrixShape(rows, columns);\n if (packedRGBA.length < requiredSize) {\n throw new Error(\n `packedRGBA length (${packedRGBA.length}) must be >= ${requiredSize}`);\n }\n /*\n Unpacked matrix, row-major order in Float32Array[16]: A B C D\n E F G H\n I J K L\n M N O P\n\n Packed matrix, 2x2 RGBA32 texture (memory view): ABEF CDGH IJMN KLOP\n\n Packed matrix, 2x2 RGBA32 texture (matrix view): AB|CD\n EF|GH\n --+--\n IJ|KL\n MN|OP\n */\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n\n // loop over full 2x2 blocks\n {\n const dstStride = (oddWidth ? 4 : 0);\n const oneRow = columns;\n let dst = 0;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n const matrixSrcRow = (blockY * 2 * columns);\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n const matrixSrcCol = blockX * 2;\n const src = matrixSrcRow + matrixSrcCol;\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 1] = matrix[src + 1];\n packedRGBA[dst + 2] = matrix[src + oneRow];\n packedRGBA[dst + 3] = matrix[src + oneRow + 1];\n dst += 4;\n }\n dst += dstStride;\n }\n }\n\n // loop down final odd column\n if (oddWidth) {\n let src = columns - 1;\n let dst = (textureWidth - 1) * 4;\n const srcStride = 2 * columns;\n const dstStride = textureWidth * 4;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 2] = matrix[src + columns];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (rows - 1) * columns;\n let dst = (textureHeight - 1) * textureWidth * 4;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n packedRGBA[dst++] = matrix[src++];\n packedRGBA[dst++] = matrix[src++];\n dst += 2;\n }\n }\n\n // fill in bottom-right texel\n if (oddWidth && oddHeight) {\n packedRGBA[packedRGBA.length - 4] = matrix[matrix.length - 1];\n }\n\n return packedRGBA;\n}\n\nexport function decodeMatrixFromPackedRGBA(\n packedRGBA: Float32Array, rows: number, columns: number,\n matrix: Float32Array): Float32Array {\n const requiredSize = rows * columns;\n if (requiredSize < matrix.length) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n\n // loop over full 2x2 blocks\n {\n const srcStride = oddWidth ? 4 : 0;\n const dstStride = columns + (oddWidth ? 1 : 0);\n let src = 0;\n let dstRow1 = 0;\n let dstRow2 = columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n }\n src += srcStride;\n dstRow1 += dstStride;\n dstRow2 += dstStride;\n }\n }\n\n // loop down final column\n if (oddWidth) {\n let src = (textureWidth - 1) * 4;\n let dst = columns - 1;\n const srcStride = textureWidth * 4;\n const dstStride = 2 * columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n matrix[dst] = packedRGBA[src];\n matrix[dst + columns] = packedRGBA[src + 2];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (textureHeight - 1) * textureWidth * 4;\n let dst = (rows - 1) * columns;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dst++] = packedRGBA[src++];\n matrix[dst++] = packedRGBA[src++];\n src += 2;\n }\n }\n\n // fill in bottom-right cell\n if (oddWidth && oddHeight) {\n matrix[matrix.length - 1] = packedRGBA[packedRGBA.length - 4];\n }\n\n return matrix;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class FromPixelsProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n const [height, width, ] = outputShape;\n this.outputShape = outputShape;\n this.userCode = `\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${width}.0, ${height}.0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class GatherProgram implements GPGPUProgram {\n variableNames = ['A', 'indices'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], indicesLength: number, axis: number) {\n const outputShape: number[] = aShape.slice();\n outputShape[axis] = indicesLength;\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape, axis);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[], axis: number): string {\n const rank = aShape.length;\n if (rank > 4) {\n throw Error(`Gather for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `int(getIndices(resRC))`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n if (i === axis) {\n sourceCoords.push(`int(getIndices(${currentCoords[i]}))`);\n } else {\n sourceCoords.push(`${currentCoords[i]}`);\n }\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nlet MAX_TEXTURE_SIZE: number = null;\n\nimport * as util from '../../util';\nimport {ENV} from '../../environment';\n\nexport function createWebGLRenderingContext(attributes: WebGLContextAttributes):\n WebGLRenderingContext {\n const canvas = document.createElement('canvas');\n canvas.width = 1;\n canvas.height = 1;\n return createWebGLRenderingContextFromCanvas(canvas, attributes);\n}\n\nexport function createWebGLRenderingContextFromCanvas(\n canvas: HTMLCanvasElement,\n attributes: WebGLContextAttributes): WebGLRenderingContext {\n let gl: WebGLRenderingContext;\n\n const webglVersion = ENV.get('WEBGL_VERSION');\n if (webglVersion === 2) {\n gl = canvas.getContext('webgl2', attributes) as WebGLRenderingContext;\n } else if (webglVersion === 1) {\n gl = (canvas.getContext('webgl', attributes) ||\n canvas.getContext('experimental-webgl', attributes)) as\n WebGLRenderingContext;\n }\n\n if (webglVersion === 0 || gl == null) {\n throw new Error('This browser does not support WebGL.');\n }\n return gl;\n}\n\nexport function callAndCheck(gl: WebGLRenderingContext, func: () => T): T {\n const returnValue = func();\n checkWebGLError(gl);\n return returnValue;\n}\n\nlet webGLDebugErrorCheckingEnabled = false;\n\nexport function enableDebugWebGLErrorChecking(enabled: boolean) {\n webGLDebugErrorCheckingEnabled = enabled;\n}\n\nexport function checkWebGLError(gl: WebGLRenderingContext) {\n if (webGLDebugErrorCheckingEnabled) {\n const error = gl.getError();\n if (error !== gl.NO_ERROR) {\n throw new Error('WebGL Error: ' + getWebGLErrorMessage(gl, error));\n }\n }\n}\n\nexport function getWebGLErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.NO_ERROR:\n return 'NO_ERROR';\n case gl.INVALID_ENUM:\n return 'INVALID_ENUM';\n case gl.INVALID_VALUE:\n return 'INVALID_VALUE';\n case gl.INVALID_OPERATION:\n return 'INVALID_OPERATION';\n case gl.INVALID_FRAMEBUFFER_OPERATION:\n return 'INVALID_FRAMEBUFFER_OPERATION';\n case gl.OUT_OF_MEMORY:\n return 'OUT_OF_MEMORY';\n case gl.CONTEXT_LOST_WEBGL:\n return 'CONTEXT_LOST_WEBGL';\n default:\n return `Unknown error code ${status}`;\n }\n}\n\nexport function getExtensionOrThrow(\n gl: WebGLRenderingContext, extensionName: string): {} {\n return throwIfNull<{}>(\n gl, () => gl.getExtension(extensionName),\n 'Extension \"' + extensionName + '\" not supported on this browser.');\n}\n\nexport function createVertexShader(\n gl: WebGLRenderingContext, vertexShaderSource: string): WebGLShader {\n const vertexShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.VERTEX_SHADER),\n 'Unable to create vertex WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(vertexShader, vertexShaderSource));\n callAndCheck(gl, () => gl.compileShader(vertexShader));\n if (gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS) === false) {\n console.log(gl.getShaderInfoLog(vertexShader));\n throw new Error('Failed to compile vertex shader.');\n }\n return vertexShader;\n}\n\nexport function createFragmentShader(\n gl: WebGLRenderingContext, fragmentShaderSource: string): WebGLShader {\n const fragmentShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.FRAGMENT_SHADER),\n 'Unable to create fragment WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(fragmentShader, fragmentShaderSource));\n callAndCheck(gl, () => gl.compileShader(fragmentShader));\n if (gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS) === false) {\n logShaderSourceAndInfoLog(\n fragmentShaderSource, gl.getShaderInfoLog(fragmentShader));\n throw new Error('Failed to compile fragment shader.');\n }\n return fragmentShader;\n}\n\nconst lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g;\nfunction logShaderSourceAndInfoLog(\n shaderSource: string, shaderInfoLog: string) {\n const lineNumberRegexResult = lineNumberRegex.exec(shaderInfoLog);\n if (lineNumberRegexResult == null) {\n console.log(`Couldn't parse line number in error: ${shaderInfoLog}`);\n console.log(shaderSource);\n return;\n }\n\n const lineNumber = +lineNumberRegexResult[1];\n\n const shaderLines = shaderSource.split('\\n');\n const pad = shaderLines.length.toString().length + 2;\n const linesWithLineNumbers = shaderLines.map(\n (line, lineNumber) =>\n util.rightPad((lineNumber + 1).toString(), pad) + line);\n let maxLineLength = 0;\n for (let i = 0; i < linesWithLineNumbers.length; i++) {\n maxLineLength = Math.max(linesWithLineNumbers[i].length, maxLineLength);\n }\n\n const beforeErrorLines = linesWithLineNumbers.slice(0, lineNumber - 1);\n const errorLine = linesWithLineNumbers.slice(lineNumber - 1, lineNumber);\n const afterErrorLines = linesWithLineNumbers.slice(lineNumber);\n\n console.log(beforeErrorLines.join('\\n'));\n console.log(shaderInfoLog.split('\\n')[0]);\n console.log(\n `%c ${util.rightPad(errorLine[0], maxLineLength)}`,\n 'border:1px solid red; background-color:#e3d2d2; color:#a61717');\n console.log(afterErrorLines.join('\\n'));\n}\n\nexport function createProgram(gl: WebGLRenderingContext): WebGLProgram {\n return throwIfNull(\n gl, () => gl.createProgram(), 'Unable to create WebGLProgram.');\n}\n\nexport function linkProgram(gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.linkProgram(program));\n if (gl.getProgramParameter(program, gl.LINK_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Failed to link vertex and fragment shaders.');\n }\n}\n\nexport function validateProgram(\n gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.validateProgram(program));\n if (gl.getProgramParameter(program, gl.VALIDATE_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Shader program validation failed.');\n }\n}\n\nexport function createStaticVertexBuffer(\n gl: WebGLRenderingContext, data: Float32Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(gl, () => gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function createStaticIndexBuffer(\n gl: WebGLRenderingContext, data: Uint16Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, buffer));\n callAndCheck(\n gl, () => gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function queryMaxTextureSize(gl: WebGLRenderingContext): number {\n if (MAX_TEXTURE_SIZE != null) {\n return MAX_TEXTURE_SIZE;\n }\n MAX_TEXTURE_SIZE =\n callAndCheck(gl, () => gl.getParameter(gl.MAX_TEXTURE_SIZE));\n return MAX_TEXTURE_SIZE;\n}\n\nexport function getNumChannels(): number {\n if (ENV.get('WEBGL_VERSION') === 2) {\n return 1;\n }\n return 4;\n}\n\nexport function createTexture(gl: WebGLRenderingContext): WebGLTexture {\n return throwIfNull(\n gl, () => gl.createTexture(), 'Unable to create WebGLTexture.');\n}\n\nexport function validateTextureSize(\n gl: WebGLRenderingContext, width: number, height: number) {\n const maxTextureSize: number = queryMaxTextureSize(gl);\n if ((width <= 0) || (height <= 0)) {\n const requested = `[${width}x${height}]`;\n throw new Error('Requested texture size ' + requested + ' is invalid.');\n }\n if ((width > maxTextureSize) || (height > maxTextureSize)) {\n const requested = `[${width}x${height}]`;\n const max = `[${maxTextureSize}x${maxTextureSize}]`;\n throw new Error(\n 'Requested texture size ' + requested +\n ' greater than WebGL maximum on this browser / GPU ' + max + '.');\n }\n}\n\nexport function createFramebuffer(gl: WebGLRenderingContext): WebGLFramebuffer {\n return throwIfNull(\n gl, () => gl.createFramebuffer(), 'Unable to create WebGLFramebuffer.');\n}\n\nexport function bindVertexBufferToProgramAttribute(\n gl: WebGLRenderingContext, program: WebGLProgram, attribute: string,\n buffer: WebGLBuffer, arrayEntriesPerItem: number, itemStrideInBytes: number,\n itemOffsetInBytes: number): boolean {\n const loc = gl.getAttribLocation(program, attribute);\n if (loc === -1) {\n // The GPU compiler decided to strip out this attribute because it's unused,\n // thus no need to bind.\n return false;\n }\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(\n gl,\n () => gl.vertexAttribPointer(\n loc, arrayEntriesPerItem, gl.FLOAT, false, itemStrideInBytes,\n itemOffsetInBytes));\n callAndCheck(gl, () => gl.enableVertexAttribArray(loc));\n return true;\n}\n\nexport function bindTextureUnit(\n gl: WebGLRenderingContext, texture: WebGLTexture, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n}\n\nexport function unbindTextureUnit(\n gl: WebGLRenderingContext, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function getProgramUniformLocationOrThrow(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return throwIfNull(\n gl, () => gl.getUniformLocation(program, uniformName),\n 'uniform \"' + uniformName + '\" not present in program.');\n}\n\nexport function getProgramUniformLocation(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return gl.getUniformLocation(program, uniformName);\n}\n\nexport function bindTextureToProgramUniformSampler(\n gl: WebGLRenderingContext, program: WebGLProgram, texture: WebGLTexture,\n uniformSamplerLocation: WebGLUniformLocation, textureUnit: number) {\n callAndCheck(gl, () => bindTextureUnit(gl, texture, textureUnit));\n callAndCheck(gl, () => gl.uniform1i(uniformSamplerLocation, textureUnit));\n}\n\nexport function bindCanvasToFramebuffer(gl: WebGLRenderingContext) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n callAndCheck(gl, () => gl.viewport(0, 0, gl.canvas.width, gl.canvas.height));\n callAndCheck(gl, () => gl.scissor(0, 0, gl.canvas.width, gl.canvas.height));\n}\n\nexport function bindColorTextureToFramebuffer(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0));\n}\n\nexport function unbindColorTextureFromFramebuffer(\n gl: WebGLRenderingContext, framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, null, 0));\n}\n\nexport function validateFramebuffer(gl: WebGLRenderingContext) {\n const status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n if (status !== gl.FRAMEBUFFER_COMPLETE) {\n throw new Error(\n 'Error binding framebuffer: ' + getFramebufferErrorMessage(gl, status));\n }\n}\n\nexport function getFramebufferErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:\n return 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS';\n case gl.FRAMEBUFFER_UNSUPPORTED:\n return 'FRAMEBUFFER_UNSUPPORTED';\n default:\n return `unknown error ${status}`;\n }\n}\n\nfunction throwIfNull(\n gl: WebGLRenderingContext, returnTOrNull: () => T | null,\n failureMessage: string): T {\n const tOrNull: T|null = callAndCheck(gl, () => returnTOrNull());\n if (tOrNull == null) {\n throw new Error(failureMessage);\n }\n return tOrNull as T;\n}\n\nfunction validateTextureUnit(gl: WebGLRenderingContext, textureUnit: number) {\n const maxTextureUnit = gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1;\n const glTextureUnit = textureUnit + gl.TEXTURE0;\n if (glTextureUnit < gl.TEXTURE0 || glTextureUnit > maxTextureUnit) {\n const textureUnitRange = `[gl.TEXTURE0, gl.TEXTURE${maxTextureUnit}]`;\n throw new Error(`textureUnit must be in ${textureUnitRange}.`);\n }\n}\n\nexport function getTextureShapeFromLogicalShape(\n gl: WebGLRenderingContext, logShape: number[]): [number, number] {\n // If logical shape is 2, we don't squeeze, since we want to match physical.\n if (logShape.length !== 2) {\n const squeezeResult = util.squeezeShape(logShape);\n logShape = squeezeResult.newShape;\n }\n\n const maxTexSize = queryMaxTextureSize(gl);\n const size = util.sizeFromShape(logShape);\n if (logShape.length <= 1 && size <= maxTexSize) {\n return [size, 1];\n } else if (\n logShape.length === 2 && logShape[0] <= maxTexSize &&\n logShape[1] <= maxTexSize) {\n return logShape as [number, number];\n } else if (\n logShape.length === 3 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2]];\n } else if (\n logShape.length === 4 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] * logShape[3] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2] * logShape[3]];\n } else {\n return util.sizeToSquarishShape(size);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport * as tex_util from './tex_util';\nimport * as webgl_util from './webgl_util';\n\nexport function getWebGLContextAttributes(): WebGLContextAttributes {\n return {\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: true\n };\n}\n\nexport interface TextureConfig {\n internalFormatFloat: number;\n textureFormatFloat: number;\n internalFormatHalfFloat: number;\n internalFormatPackedFloat: number;\n\n // The format to use during a gl.readPixels call.\n downloadTextureFormat: number;\n // How many channels need to be unpacked after a gl.readPixels call.\n downloadUnpackNumChannels: number;\n\n defaultNumChannels: number;\n textureTypeHalfFloat: number;\n}\n\nexport function createWebGLContext(canvas?: HTMLCanvasElement) {\n const attributes = getWebGLContextAttributes();\n let gl: WebGLRenderingContext;\n if (canvas != null) {\n gl = webgl_util.createWebGLRenderingContextFromCanvas(canvas, attributes);\n } else {\n gl = webgl_util.createWebGLRenderingContext(attributes);\n }\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DEPTH_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.STENCIL_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.BLEND));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DITHER));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.POLYGON_OFFSET_FILL));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.SAMPLE_COVERAGE));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.SCISSOR_TEST));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.CULL_FACE));\n webgl_util.callAndCheck(gl, () => gl.cullFace(gl.BACK));\n\n return gl;\n}\n\nexport function createVertexShader(gl: WebGLRenderingContext): WebGLShader {\n const vertexShaderSource = `\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }`;\n return webgl_util.createVertexShader(gl, vertexShaderSource);\n}\n\nexport function createVertexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // [x y z u v] * [upper-left, lower-left, upper-right, lower-right]\n const vertexArray = new Float32Array(\n [-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]);\n return webgl_util.createStaticVertexBuffer(gl, vertexArray);\n}\n\nexport function createIndexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // OpenGL (and WebGL) have \"CCW == front\" winding\n const triangleVertexIndices = new Uint16Array([0, 1, 2, 2, 1, 3]);\n return webgl_util.createStaticIndexBuffer(gl, triangleVertexIndices);\n}\n\nexport function getTextureConfig(\n // tslint:disable-next-line:no-any\n gl: WebGLRenderingContext, textureHalfFloatExtension?: any): TextureConfig {\n // tslint:disable-next-line:no-any\n const glany = gl as any;\n\n let internalFormatFloat: number;\n let internalFormatHalfFloat: number;\n let internalFormatPackedFloat: number;\n let textureFormatFloat: number;\n\n let downloadTextureFormat: number;\n let downloadUnpackNumChannels: number;\n\n let defaultNumChannels: number;\n let textureTypeHalfFloat: number;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n internalFormatFloat = glany.R32F;\n internalFormatHalfFloat = glany.R16F;\n internalFormatPackedFloat = glany.RGBA32F;\n textureFormatFloat = glany.RED;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 1;\n textureTypeHalfFloat = glany.HALF_FLOAT;\n } else {\n internalFormatFloat = gl.RGBA;\n internalFormatHalfFloat = gl.RGBA;\n internalFormatPackedFloat = glany.RGBA;\n textureFormatFloat = gl.RGBA;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 4;\n textureTypeHalfFloat = textureHalfFloatExtension != null ?\n textureHalfFloatExtension.HALF_FLOAT_OES :\n null;\n }\n downloadTextureFormat = gl.RGBA;\n\n return {\n internalFormatFloat,\n internalFormatHalfFloat,\n internalFormatPackedFloat,\n textureFormatFloat,\n downloadTextureFormat,\n downloadUnpackNumChannels,\n defaultNumChannels,\n textureTypeHalfFloat\n };\n}\n\nfunction createAndConfigureTexture(\n gl: WebGLRenderingContext, width: number, height: number,\n internalFormat: number, textureFormat: number,\n textureType: number): WebGLTexture {\n webgl_util.validateTextureSize(gl, width, height);\n const texture = webgl_util.createTexture(gl);\n\n const tex2d = gl.TEXTURE_2D;\n webgl_util.callAndCheck(gl, () => gl.bindTexture(tex2d, texture));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MIN_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MAG_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n tex2d, 0, internalFormat, width, height, 0, textureFormat,\n textureType, null));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n return texture;\n}\n\nexport function createFloat32MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, gl.FLOAT);\n}\n\nexport function createFloat16MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, textureConfig.textureTypeHalfFloat);\n}\n\nexport function createUnsignedBytesMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE);\n}\n\nexport function createPackedMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatPackedFloat, gl.RGBA,\n gl.FLOAT);\n}\n\nexport function bindVertexProgramAttributeStreams(\n gl: WebGLRenderingContext, program: WebGLProgram,\n vertexBuffer: WebGLBuffer): boolean {\n const posOffset = 0; // x is the first buffer element\n const uvOffset = 3 * 4; // uv comes after [x y z]\n const stride = (3 * 4) + (2 * 4); // xyz + uv, each entry is 4-byte float.\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer));\n const success = webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'clipSpacePos', vertexBuffer, 3, stride, posOffset);\n return success &&\n webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'uv', vertexBuffer, 2, stride, uvOffset);\n}\n\nexport function uploadPixelDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement) {\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, pixels));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nfunction uploadDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, width: number,\n height: number, data: Float32Array, textureFormat: number) {\n webgl_util.validateTextureSize(gl, width, height);\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texSubImage2D(\n gl.TEXTURE_2D, 0, 0, 0, width, height, textureFormat, gl.FLOAT,\n data));\n\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function uploadMatrixToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, numChannels: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n let unpackedArray: Float32Array;\n if (textureConfig.defaultNumChannels === 1) {\n // No need to allocate a temporary array.\n unpackedArray = matrix;\n } else {\n unpackedArray =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n matrix.length, numChannels));\n tex_util.encodeMatrixToUnpackedArray(matrix, unpackedArray, numChannels);\n }\n\n uploadDataToTexture(\n gl, texture, w, h, unpackedArray, textureConfig.textureFormatFloat);\n}\n\nexport function uploadMatrixToPackedTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, textureConfig: TextureConfig) {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n tex_util.encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA);\n uploadDataToTexture(gl, texture, w, h, packedRGBA, gl.RGBA);\n}\n\nexport function maybeCreateBufferFromOutputTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, textureConfig: TextureConfig): WebGLBuffer|WebGLTexture {\n let bufferOrTexture: WebGLBuffer|WebGLTexture = texture;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n const gl2 = gl as WebGL2RenderingContext;\n\n // Create and bind the buffer.\n const buffer = gl2.createBuffer();\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, buffer));\n\n // Initialize the buffer to the size of the texture in bytes.\n const bytesPerFloat = 4;\n const bufferSizeBytes = bytesPerFloat *\n tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels);\n\n webgl_util.callAndCheck(\n gl,\n () => gl.bufferData(\n gl2.PIXEL_PACK_BUFFER, bufferSizeBytes, gl.STATIC_DRAW));\n\n // Enqueue a command on the GPU command queue to copy of texture into the\n // buffer.\n webgl_util.callAndCheck(\n gl, () => gl2.readPixels(0, 0, columns, rows, gl.RGBA, gl.FLOAT, 0));\n\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, null));\n\n bufferOrTexture = buffer;\n }\n\n return bufferOrTexture;\n}\n\nexport function downloadFloat32MatrixFromBuffer(\n gl: WebGLRenderingContext, buffer: WebGLBuffer, rows: number,\n columns: number, textureConfig: TextureConfig): Float32Array {\n const gl2 = gl as WebGL2RenderingContext;\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n gl2.bindBuffer(gl.ARRAY_BUFFER, buffer);\n gl2.getBufferSubData(gl.ARRAY_BUFFER, 0, downloadTarget);\n gl2.bindBuffer(gl.ARRAY_BUFFER, null);\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n\n return matrix;\n}\n\nexport function downloadFloat32MatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.FLOAT,\n downloadTarget));\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n return matrix;\n}\n\nexport function downloadByteEncodedFloatMatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const numChannels = 4;\n const downloadTarget = new Uint8Array(\n tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, numChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.UNSIGNED_BYTE,\n downloadTarget));\n\n // By wrapping the buffer in a Float32Array, we use native browser IEEE 754\n // decoding of the 4 bytes that back each 32 bit float.\n return new Float32Array(downloadTarget.buffer);\n}\n\nexport function downloadMatrixFromPackedOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n webgl_util.callAndCheck(\n gl, () => gl.readPixels(0, 0, w, h, gl.RGBA, gl.FLOAT, packedRGBA));\n const matrix = new Float32Array(rows * columns);\n return tex_util.decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix);\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\nimport * as util from '../../util';\nimport * as gpgpu_util from './gpgpu_util';\nimport {TextureConfig} from './gpgpu_util';\nimport * as tex_util from './tex_util';\nimport {WebGL1DisjointQueryTimerExtension, WebGL2DisjointQueryTimerExtension} from './webgl_types';\nimport * as webgl_util from './webgl_util';\n\nexport interface FenceContext {\n query: WebGLQuery|WebGLSync;\n isFencePassed(): boolean;\n}\n\nexport class GPGPUContext {\n gl: WebGLRenderingContext;\n textureFloatExtension: {};\n textureHalfFloatExtension: {};\n colorBufferFloatExtension: {};\n colorBufferHalfFloatExtension: {};\n getBufferSubDataAsyncExtension: {};\n loseContextExtension: WebGLLoseContext;\n disjointQueryTimerExtension: WebGL2DisjointQueryTimerExtension|\n WebGL1DisjointQueryTimerExtension;\n vertexBuffer: WebGLBuffer;\n indexBuffer: WebGLBuffer;\n framebuffer: WebGLFramebuffer;\n outputTexture: WebGLTexture|null = null;\n program: WebGLProgram|null = null;\n private disposed = false;\n private autoDebugValidate = false;\n private disjoint: boolean;\n\n private textureConfig: TextureConfig;\n\n constructor(gl?: WebGLRenderingContext) {\n if (gl != null) {\n this.gl = gl;\n } else {\n this.gl = gpgpu_util.createWebGLContext();\n }\n // WebGL 2.0 enables texture floats without an extension.\n if (ENV.get('WEBGL_VERSION') === 1) {\n this.textureFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_float');\n this.colorBufferFloatExtension =\n this.gl.getExtension('WEBGL_color_buffer_float');\n\n if (!ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n this.textureHalfFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_half_float');\n this.colorBufferHalfFloatExtension =\n this.gl.getExtension('EXT_color_buffer_half_float');\n }\n } else {\n this.colorBufferFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'EXT_color_buffer_float');\n }\n\n this.loseContextExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'WEBGL_lose_context') as\n WebGLLoseContext;\n\n this.vertexBuffer = gpgpu_util.createVertexBuffer(this.gl);\n this.indexBuffer = gpgpu_util.createIndexBuffer(this.gl);\n this.framebuffer = webgl_util.createFramebuffer(this.gl);\n\n this.textureConfig =\n gpgpu_util.getTextureConfig(this.gl, this.textureHalfFloatExtension);\n }\n\n public dispose() {\n if (this.disposed) {\n return;\n }\n if (this.program != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound WebGLProgram.' +\n ' This is probably a resource leak, delete the program with ' +\n 'GPGPUContext.deleteProgram before disposing.');\n }\n if (this.outputTexture != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound output matrix ' +\n 'texture. This is probably a resource leak, delete the output ' +\n 'matrix texture with GPGPUContext.deleteMatrixTexture before ' +\n 'disposing.');\n }\n const gl = this.gl;\n webgl_util.callAndCheck(gl, () => gl.finish());\n webgl_util.callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteFramebuffer(this.framebuffer));\n webgl_util.callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.vertexBuffer));\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.indexBuffer));\n this.loseContextExtension.loseContext();\n this.disposed = true;\n }\n\n public enableAutomaticDebugValidation(enabled: boolean) {\n this.autoDebugValidate = enabled;\n webgl_util.enableDebugWebGLErrorChecking(enabled);\n }\n\n public createFloat32MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat32MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createFloat16MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat16MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createUnsignedBytesMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createUnsignedBytesMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public uploadPixelDataToTexture(\n texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement) {\n this.throwIfDisposed();\n gpgpu_util.uploadPixelDataToTexture(this.gl, texture, pixels);\n }\n\n public createPackedMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createPackedMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public deleteMatrixTexture(texture: WebGLTexture) {\n this.throwIfDisposed();\n if (this.outputTexture === texture) {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n this.outputTexture = null;\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteTexture(texture));\n }\n\n public uploadMatrixToTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n const numChannels = webgl_util.getNumChannels();\n return gpgpu_util.uploadMatrixToTexture(\n this.gl, texture, rows, columns, matrix, numChannels,\n this.textureConfig);\n }\n\n public uploadMatrixToPackedTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n return gpgpu_util.uploadMatrixToPackedTexture(\n this.gl, texture, rows, columns, matrix, this.textureConfig);\n }\n\n public downloadFloat32MatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadFloat32MatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadByteEncodedFloatMatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadFloat32MatrixFromBuffer(\n buffer: WebGLBuffer, rows: number, columns: number): Float32Array {\n return gpgpu_util.downloadFloat32MatrixFromBuffer(\n this.gl, buffer, rows, columns, this.textureConfig);\n }\n\n public maybeCreateBufferFromTexture(\n texture: WebGLTexture, rows: number, columns: number): WebGLBuffer\n |WebGLTexture {\n this.bindTextureToFrameBuffer(texture);\n const result = gpgpu_util.maybeCreateBufferFromOutputTexture(\n this.gl, texture, rows, columns, this.textureConfig);\n this.unbindTextureToFrameBuffer();\n return result;\n }\n\n public createAndWaitForFence(): Promise {\n const fenceContext = this.createFence(this.gl);\n return this.pollFence(fenceContext);\n }\n\n private createFence(gl: WebGLRenderingContext): FenceContext {\n let query: WebGLQuery|WebGLSync;\n let isFencePassed: () => boolean;\n\n if (ENV.get('WEBGL_FENCE_API_ENABLED')) {\n const gl2 = gl as WebGL2RenderingContext;\n\n const sync = gl2.fenceSync(gl2.SYNC_GPU_COMMANDS_COMPLETE, 0);\n gl.flush();\n\n isFencePassed = () => {\n const status = gl2.clientWaitSync(sync, 0, 0);\n return status === gl2.ALREADY_SIGNALED ||\n status === gl2.CONDITION_SATISFIED;\n };\n\n query = sync;\n } else if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n query = this.beginQuery();\n this.endQuery();\n isFencePassed = () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n } else {\n // If we have no way to fence, return true immediately. This will fire in\n // WebGL 1.0 when there is no disjoint query timer. In this case, because\n // the fence passes immediately, we'll immediately ask for a download of\n // the texture, which will cause the UI thread to hang.\n isFencePassed = () => true;\n }\n\n return {query, isFencePassed};\n }\n\n public downloadMatrixFromPackedTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadMatrixFromPackedOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n private vertexAttrsAreBound = false;\n\n public createProgram(fragmentShaderSource: string): WebGLProgram {\n this.throwIfDisposed();\n const gl = this.gl;\n const fragmentShader: WebGLShader =\n webgl_util.createFragmentShader(gl, fragmentShaderSource);\n const vertexShader: WebGLShader = gpgpu_util.createVertexShader(gl);\n const program: WebGLProgram = webgl_util.createProgram(gl);\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, vertexShader));\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, fragmentShader));\n webgl_util.linkProgram(gl, program);\n if (this.autoDebugValidate) {\n webgl_util.validateProgram(gl, program);\n }\n if (!this.vertexAttrsAreBound) {\n this.setProgram(program);\n this.vertexAttrsAreBound = gpgpu_util.bindVertexProgramAttributeStreams(\n gl, this.program, this.vertexBuffer);\n }\n return program;\n }\n\n public deleteProgram(program: WebGLProgram) {\n this.throwIfDisposed();\n if (program === this.program) {\n this.program = null;\n }\n if (program != null) {\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteProgram(program));\n }\n }\n\n public setProgram(program: WebGLProgram|null) {\n this.throwIfDisposed();\n this.program = program;\n if ((this.program != null) && this.autoDebugValidate) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.useProgram(program));\n }\n\n public getUniformLocation(\n program: WebGLProgram, uniformName: string,\n shouldThrow = true): WebGLUniformLocation {\n this.throwIfDisposed();\n if (shouldThrow) {\n return webgl_util.getProgramUniformLocationOrThrow(\n this.gl, program, uniformName);\n } else {\n return webgl_util.getProgramUniformLocation(\n this.gl, program, uniformName);\n }\n }\n\n public getAttributeLocation(program: WebGLProgram, attribute: string):\n number {\n this.throwIfDisposed();\n return webgl_util.callAndCheck(\n this.gl, () => this.gl.getAttribLocation(program, attribute));\n }\n\n public getUniformLocationNoThrow(program: WebGLProgram, uniformName: string):\n WebGLUniformLocation {\n this.throwIfDisposed();\n return this.gl.getUniformLocation(program, uniformName);\n }\n\n public setInputMatrixTexture(\n inputMatrixTexture: WebGLTexture, uniformLocation: WebGLUniformLocation,\n textureUnit: number) {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n webgl_util.bindTextureToProgramUniformSampler(\n this.gl, this.program, inputMatrixTexture, uniformLocation,\n textureUnit);\n }\n\n public setOutputMatrixTexture(\n outputMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.setOutputMatrixTextureDriver(outputMatrixTexture, columns, rows);\n }\n\n public setOutputPackedMatrixTexture(\n outputPackedMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.throwIfDisposed();\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n this.setOutputMatrixTextureDriver(outputPackedMatrixTexture, width, height);\n }\n\n public setOutputMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n this.setOutputMatrixWriteRegionDriver(\n startColumn, startRow, numColumns, numRows);\n }\n\n public setOutputPackedMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n throw new Error('setOutputPackedMatrixWriteRegion not implemented.');\n }\n\n public debugValidate() {\n if (this.program != null) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.validateFramebuffer(this.gl);\n }\n\n public executeProgram() {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n const gl = this.gl;\n if (this.autoDebugValidate) {\n this.debugValidate();\n }\n webgl_util.callAndCheck(\n gl, () => gl.drawElements(gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0));\n }\n\n public blockUntilAllProgramsCompleted() {\n this.throwIfDisposed();\n webgl_util.callAndCheck(this.gl, () => this.gl.finish());\n }\n\n private getQueryTimerExtension(): WebGL1DisjointQueryTimerExtension\n |WebGL2DisjointQueryTimerExtension {\n if (this.disjointQueryTimerExtension == null) {\n this.disjointQueryTimerExtension =\n webgl_util.getExtensionOrThrow(\n this.gl,\n ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2 ?\n 'EXT_disjoint_timer_query_webgl2' :\n 'EXT_disjoint_timer_query') as\n WebGL1DisjointQueryTimerExtension |\n WebGL2DisjointQueryTimerExtension;\n }\n return this.disjointQueryTimerExtension;\n }\n\n private getQueryTimerExtensionWebGL2(): WebGL2DisjointQueryTimerExtension {\n return this.getQueryTimerExtension();\n }\n\n private getQueryTimerExtensionWebGL1(): WebGL1DisjointQueryTimerExtension {\n return this.getQueryTimerExtension() as WebGL1DisjointQueryTimerExtension;\n }\n\n beginQuery(): WebGLQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const query = gl2.createQuery();\n gl2.beginQuery(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n const query = ext.createQueryEXT();\n ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n\n endQuery() {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n gl2.endQuery(ext.TIME_ELAPSED_EXT);\n return;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n ext.endQueryEXT(ext.TIME_ELAPSED_EXT);\n }\n\n public async waitForQueryAndGetTime(query: WebGLQuery): Promise {\n await util.repeatedTry(\n () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')));\n return this.getQueryTime(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n }\n\n private getQueryTime(query: WebGLQuery, queryTimerVersion: number): number {\n if (queryTimerVersion === 0) {\n return null;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n\n const timeElapsedNanos = gl2.getQueryParameter(query, gl2.QUERY_RESULT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const timeElapsedNanos =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_EXT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n }\n }\n\n private isQueryAvailable(query: WebGLQuery, queryTimerVersion: number):\n boolean {\n if (queryTimerVersion === 0) {\n return true;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const available =\n gl2.getQueryParameter(query, gl2.QUERY_RESULT_AVAILABLE);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const available =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_AVAILABLE_EXT);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n }\n }\n\n pollFence(fenceContext: FenceContext) {\n return new Promise(resolve => {\n this.addItemToPoll(() => fenceContext.isFencePassed(), () => resolve());\n });\n }\n\n private itemsToPoll: PollItem[] = [];\n\n pollItems(): void {\n // Find the last query that has finished using binary search.\n // All other queries before it are also done.\n const index = binSearchLastTrue(this.itemsToPoll.map(x => x.isDoneFn));\n for (let i = 0; i <= index; ++i) {\n const {resolveFn} = this.itemsToPoll[i];\n resolveFn();\n }\n this.itemsToPoll = this.itemsToPoll.slice(index + 1);\n }\n\n private addItemToPoll(isDoneFn: () => boolean, resolveFn: () => void) {\n this.itemsToPoll.push({isDoneFn, resolveFn});\n if (this.itemsToPoll.length > 1) {\n // We already have a running loop that polls.\n return;\n }\n // Start a new loop that polls.\n util.repeatedTry(() => {\n this.pollItems();\n // End the loop if no more items to poll.\n return this.itemsToPoll.length === 0;\n });\n }\n private bindTextureToFrameBuffer(texture: WebGLTexture) {\n this.throwIfDisposed();\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, texture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n }\n\n private unbindTextureToFrameBuffer() {\n if (this.outputTexture != null) {\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, this.outputTexture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n } else {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n }\n }\n\n private downloadMatrixDriver(\n texture: WebGLTexture,\n downloadAndDecode: () => Float32Array): Float32Array {\n this.bindTextureToFrameBuffer(texture);\n const result = downloadAndDecode();\n this.unbindTextureToFrameBuffer();\n\n return result;\n }\n\n private setOutputMatrixTextureDriver(\n outputMatrixTextureMaybePacked: WebGLTexture, width: number,\n height: number) {\n this.throwIfDisposed();\n const gl = this.gl;\n webgl_util.bindColorTextureToFramebuffer(\n gl, outputMatrixTextureMaybePacked, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(gl);\n }\n this.outputTexture = outputMatrixTextureMaybePacked;\n webgl_util.callAndCheck(gl, () => gl.viewport(0, 0, width, height));\n webgl_util.callAndCheck(gl, () => gl.scissor(0, 0, width, height));\n }\n\n private setOutputMatrixWriteRegionDriver(\n x: number, y: number, width: number, height: number) {\n this.throwIfDisposed();\n webgl_util.callAndCheck(\n this.gl, () => this.gl.scissor(x, y, width, height));\n }\n\n private throwIfDisposed() {\n if (this.disposed) {\n throw new Error('Attempted to use disposed GPGPUContext.');\n }\n }\n\n private throwIfNoProgram() {\n if (this.program == null) {\n throw new Error('No GPU program is currently set.');\n }\n }\n}\n\ntype PollItem = {\n isDoneFn: () => boolean,\n resolveFn: () => void\n};\n\n/**\n * Finds the index of the last true element using binary search where\n * evaluation of an entry is expensive.\n */\nexport function binSearchLastTrue(arr: Array<() => boolean>): number {\n let start = 0;\n let end = arr.length - 1;\n let best = -1;\n while (start <= end) {\n const mid = (start + end) >> 1;\n const isDone = arr[mid]();\n if (isDone) {\n best = mid;\n start = mid + 1;\n } else {\n end = mid - 1;\n }\n }\n return best;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../../tensor';\nimport * as util from '../../util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport * as shader_compiler from './shader_compiler';\nimport {InputInfo, ShapeInfo} from './shader_compiler';\nimport {TextureData} from './tex_util';\n\nexport interface GPGPUProgram {\n variableNames: string[];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting?: boolean;\n}\n\nexport interface GPGPUBinary {\n webGLProgram: WebGLProgram;\n program: GPGPUProgram;\n uniformLocations: {[name: string]: WebGLUniformLocation};\n gpgpu: GPGPUContext;\n source: string;\n inShapeInfos: ShapeInfo[];\n outShapeInfo: ShapeInfo;\n}\n\nexport interface TensorData {\n tensor: T;\n texData: TextureData;\n isUniform: boolean;\n}\n\nexport function compileProgram(\n gpgpu: GPGPUContext, program: GPGPUProgram, inputs: Array>,\n output: TensorData): GPGPUBinary {\n const userCode = program.userCode;\n const inputInfos: InputInfo[] = inputs.map((input, i) => {\n const shapeInfo = {\n logicalShape: input.tensor.shape,\n texShape: input.isUniform ? null : input.texData.texShape,\n isUniform: input.isUniform\n };\n return {name: program.variableNames[i], shapeInfo};\n });\n const inShapeInfos = inputInfos.map(x => x.shapeInfo);\n const outShapeInfo = {\n logicalShape: output.tensor.shape,\n texShape: output.texData.texShape,\n isUniform: false\n };\n const source = shader_compiler.makeShader(\n inputInfos, outShapeInfo, userCode,\n program.supportsBroadcasting === true);\n\n const webGLProgram = gpgpu.createProgram(source);\n\n const uniformLocations: {[name: string]: WebGLUniformLocation} = {};\n for (let i = 0; i < program.variableNames.length; i++) {\n const uniformName = program.variableNames[i];\n const shouldThrow = false;\n uniformLocations[uniformName] =\n gpgpu.getUniformLocation(webGLProgram, uniformName, shouldThrow);\n }\n\n return {\n program,\n source,\n webGLProgram,\n uniformLocations,\n gpgpu,\n inShapeInfos,\n outShapeInfo\n };\n}\n\nfunction validateBinaryAndProgram(\n shapeInfos: ShapeInfo[], inputs: Array>) {\n if (shapeInfos.length !== inputs.length) {\n throw Error(\n `Binary was compiled with ${shapeInfos.length} inputs, but ` +\n `was executed with ${inputs.length} inputs`);\n }\n\n shapeInfos.forEach((s, i) => {\n const shapeA = s.logicalShape;\n const input = inputs[i];\n const shapeB = input.tensor.shape;\n\n if (!util.arraysEqual(shapeA, shapeB)) {\n throw Error(\n `Binary was compiled with different shapes than ` +\n `the current args. Shapes ${shapeA} and ${shapeB} must match`);\n }\n // The input is uploaded as uniform.\n if (s.isUniform && input.isUniform) {\n return;\n }\n\n const texShapeA = s.texShape;\n const texShapeB = input.isUniform ? null : input.texData.texShape;\n if (!util.arraysEqual(texShapeA, texShapeB)) {\n throw Error(\n `Binary was compiled with different texture shapes than the` +\n ` current args. Shape ${texShapeA} and ${texShapeB} must match`);\n }\n });\n}\n\nexport function runProgram(\n binary: GPGPUBinary, inputs: Array>, output: TensorData,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) =>\n void): void {\n validateBinaryAndProgram(binary.inShapeInfos, inputs);\n validateBinaryAndProgram([binary.outShapeInfo], [output]);\n\n const outTex = output.texData.texture;\n const outTexShape = output.texData.texShape;\n const gpgpu = binary.gpgpu;\n gpgpu.setOutputMatrixTexture(outTex, outTexShape[0], outTexShape[1]);\n gpgpu.setProgram(binary.webGLProgram);\n inputs.forEach((input, i) => {\n const variableName = binary.program.variableNames[i];\n const variableUniformLocation = binary.uniformLocations[variableName];\n if (variableUniformLocation != null) {\n if (input.isUniform) {\n if (input.tensor.size === 1) {\n gpgpu.gl.uniform1f(\n variableUniformLocation, input.tensor.dataSync()[0]);\n } else {\n let vals = input.tensor.dataSync();\n if (!(vals instanceof Float32Array)) {\n vals = new Float32Array(vals);\n }\n gpgpu.gl.uniform1fv(variableUniformLocation, vals);\n }\n return;\n }\n const tex = input.texData.texture;\n gpgpu.setInputMatrixTexture(tex, variableUniformLocation, i);\n }\n });\n\n if (customSetup != null) {\n customSetup(gpgpu, binary.webGLProgram);\n }\n gpgpu.executeProgram();\n}\n\nexport function makeShaderKey(\n program: GPGPUProgram, inputs: Array>,\n output: TensorData): string {\n let keyInputs = '';\n inputs.concat(output).forEach(x => {\n keyInputs +=\n `${x.tensor.shape}_${x.isUniform ? 'uniform' : x.texData.texShape}`;\n });\n const keyUserCode = program.userCode;\n const keyBroadcast = (program.supportsBroadcasting === true).toString();\n let key = program.constructor.name;\n // Fast string concat. See https://jsperf.com/string-concatenation/14.\n key += '_' + keyBroadcast + '_' + keyInputs + '_' + keyUserCode;\n return key;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n xShape: number[], radius: number, bias: number, alpha: number,\n beta: number) {\n const rad = radius;\n const maxD = xShape[3] - 1;\n this.outputShape = xShape;\n\n // optimize pow(bias + alpha * sum, -beta)\n // src: https://github.com/tensorflow/tensorflow/..\n // blob/26033a1644a9c4a5fbe3170ab2e864b6a4ccd4ca/..\n // tensorflow/core/kernels/mkl_lrn_op.cc#L320\n let powOperator;\n const basis = `float(${bias}) + float(${alpha}) * sum`;\n if (beta === 0.5) {\n powOperator = `inversesqrt(${basis})`;\n } else if (beta === 1.0) {\n powOperator = `1.0/(${basis})`;\n } else {\n powOperator = `exp(log(${basis}) * float(-${beta}));`;\n }\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -${rad}; j <= ${rad}; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= ${maxD}) {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * ${powOperator};\n setOutput(val);\n }\n `;\n }\n}\n","import {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNGradProgram implements GPGPUProgram {\n variableNames = ['inputImage', 'outputImage', 'dy'];\n outputShape: number[] = [];\n userCode: string;\n depthRadius: number;\n bias: number;\n alpha: number;\n beta: number;\n depth: number;\n\n constructor(\n inputShape: number[], depthRadius: number, bias: number, alpha: number,\n beta: number) {\n this.outputShape = inputShape;\n this.depth = inputShape[3];\n this.depthRadius = depthRadius;\n this.bias = bias;\n this.alpha = alpha;\n this.beta = beta;\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < ${this.depth}; ++d) {\n int depthBegin = int(max(0.0, float(d - ${depthRadius})));\n int depthEnd = int(min(float(${this.depth}),\n float(d + ${depthRadius} + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = ${this.depth};\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(${alpha}) * norm + float(${bias});\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(${alpha})\n * float(${beta})\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * ${beta});\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MaxPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy', 'maxPos'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const lastIndex = filterHeight * filterWidth - 1;\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = ${lastIndex} - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * ${filterWidth} + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MatMulProgram implements GPGPUProgram {\n variableNames = ['matrixA', 'matrixB'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n aShape: [number, number], bShape: [number, number], transposeA = false,\n transposeB = false) {\n const outerShapeA = transposeA ? aShape[1] : aShape[0];\n const outerShapeB = transposeB ? bShape[0] : bShape[1];\n const sharedDim = transposeA ? aShape[0] : aShape[1];\n this.outputShape = [outerShapeA, outerShapeB];\n\n const aSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeA ? `${indexVar} + ${vec4Offset}, aRow` :\n `aRow, ${indexVar} + ${vec4Offset}`;\n const bSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeB ? `bCol, ${indexVar} + ${vec4Offset}` :\n `${indexVar} + ${vec4Offset}, bCol`;\n\n const sharedDimNearestVec4 = Math.floor(sharedDim / 4) * 4;\n const sharedDimVec4Remainder = sharedDim % 4;\n\n this.userCode = ` float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < ${sharedDimNearestVec4}; i += 4) {\n vec4 a = vec4(\n getMatrixA(${aSnippetFromOffset(0, 'i')}),\n getMatrixA(${aSnippetFromOffset(1, 'i')}),\n getMatrixA(${aSnippetFromOffset(2, 'i')}),\n getMatrixA(${aSnippetFromOffset(3, 'i')})\n );\n vec4 b = vec4(\n getMatrixB(${bSnippetFromOffset(0, 'i')}),\n getMatrixB(${bSnippetFromOffset(1, 'i')}),\n getMatrixB(${bSnippetFromOffset(2, 'i')}),\n getMatrixB(${bSnippetFromOffset(3, 'i')})\n );\n\n result += dot(a, b);\n }\n\n if (${sharedDimVec4Remainder === 1}) {\n result += getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}) *\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)});\n } else if (${sharedDimVec4Remainder === 2}) {\n vec2 a = vec2(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n vec2 b = vec2(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n } else if (${sharedDimVec4Remainder === 3}) {\n vec3 a = vec3(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n vec3 b = vec3(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MultinomialProgram implements GPGPUProgram {\n variableNames = ['probs'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(batchSize: number, numOutcomes: number, numSamples: number) {\n this.outputShape = [batchSize, numSamples];\n\n this.userCode = `\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < ${numOutcomes - 1}; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(${numOutcomes - 1}));\n }\n `;\n }\n\n getCustomSetupFunc(seed: number) {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.seedLoc == null) {\n this.seedLoc = gpgpu.getUniformLocation(webGLProgram, 'seed');\n }\n gpgpu.gl.uniform1f(this.seedLoc, seed);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class OneHotProgram implements GPGPUProgram {\n variableNames = ['indices'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(\n numIndices: number, depth: number, onValue: number, offValue: number) {\n this.outputShape = [numIndices, depth];\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(${offValue}), float(${onValue}),\n float(index == coords.y)));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class PadProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n xShape: number[], paddings: Array<[number, number]>,\n constantValue: number) {\n this.outputShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + xShape[i] + p[1] /* afterPad */);\n const rank = xShape.length;\n const type = getCoordsDataType(rank);\n\n const start = paddings.map(p => p[0]).join(',');\n const end = paddings.map((p, i) => p[0] + xShape[i]).join(',');\n const unpackedCoords =\n ['coords[0]', 'coords[1]', 'coords[2]','coords[3]'].slice(0, rank);\n\n if (rank === 1) {\n this.userCode = `\n int start = ${start};\n int end = ${end};\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(${constantValue}));\n } else {\n setOutput(getX(outC - start));\n }\n }\n `;\n return;\n }\n this.userCode = `\n ${type} start = ${type}(${start});\n ${type} end = ${type}(${end});\n\n void main() {\n ${type} outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(${constantValue}));\n } else {\n ${type} coords = outC - start;\n setOutput(getX(${unpackedCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Pool2DProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n convInfo: Conv2DInfo, poolType: 'max'|'avg', computePositions: boolean) {\n if (poolType === 'avg' && computePositions) {\n throw new Error('Cannot compute positions for average pool.');\n }\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n this.outputShape = convInfo.outShape;\n\n const isAvgPool = poolType === 'avg';\n\n let initializationValue = '0.0';\n if (!isAvgPool) {\n initializationValue = '-1.0 / 0.0';\n }\n\n if (computePositions) {\n const compareOp = '>=';\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value ${compareOp} currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * ${filterWidth} + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n `;\n return;\n }\n\n const compareOp = 'max';\n\n let returnValue = `${poolType}(${poolType}(${poolType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n if (poolType === 'avg') {\n returnValue = `avgValue / count`;\n }\n\n const filterWidthNearestVec4 = Math.floor(filterWidth / 4) * 4;\n const filterWidthVec4Remainder = filterWidth % 4;\n\n const updateSnippet = `\n if (${isAvgPool}) {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(${initializationValue});\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidthNearestVec4}; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n ${updateSnippet}\n }\n\n int xC = xCCorner + ${filterWidthNearestVec4};\n if (${filterWidthVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n ${updateSnippet}\n }\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ReduceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n reduceInfo: ReduceInfo, reduceType: 'all'|'any'|'max'|'min'|'sum') {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n let initializationValue = '0.0';\n let compareOp = ``;\n\n if (reduceType === 'min') {\n initializationValue = '1.0 / 0.0';\n compareOp = `min`;\n } else if (reduceType === 'max') {\n initializationValue = '-1.0 / 0.0';\n compareOp = `max`;\n }\n\n let returnValue = `${reduceType}(${reduceType}(${reduceType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n\n if (reduceType === 'sum') {\n returnValue = `sumValue`;\n } else if (reduceType === 'all') {\n returnValue = `allValue`;\n } else if (reduceType === 'any') {\n returnValue = `anyValue`;\n }\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n let updateSnippet = `\n if (${reduceType === 'sum'}) {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n let vecType = `vec4`;\n\n if (reduceType === 'all') {\n initializationValue = '1.0';\n updateSnippet = `\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n `;\n vecType = `bvec4`;\n } else if (reduceType === 'any') {\n initializationValue = '0.0';\n updateSnippet = `\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n `;\n vecType = `bvec4`;\n }\n\n let checkOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n this.userCode = `\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n ${checkOutOfBounds}\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n vec4 minMaxValue = vec4(${initializationValue});\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), ${xHeight - 1}.0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), ${xWidth - 1}.0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeigborBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float sourceFracRow =\n float(${effectiveXSize[0]}) *\n (float(dyR) / float(${effectiveYSize[0]}));\n\n float sourceFracCol =\n float(${effectiveXSize[1]}) *\n (float(dyC) / float(${effectiveYSize[1]}));\n\n int sourceNearestRow = int(min(\n float(int(${xHeight}) - 1),\n ${alignCorners} ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(${xWidth}) - 1),\n ${alignCorners} ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeighborProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n // When align corners is false, we rounds the value with floor.\n const roundBase = alignCorners ? '0.5' : '0.0';\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${roundBase})));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class ReverseProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(xShape: number[], axis: number[]) {\n const rank = xShape.length;\n if (rank > 4) {\n throw new Error(\n `WebGL backend: Reverse of rank-${rank} tensor is not yet supported`);\n }\n this.outputShape = xShape;\n\n if (rank === 1) {\n this.userCode = `\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(${xShape[0]} - coord - 1));\n }\n `;\n return;\n }\n const getInCoord = (i: number) => {\n if (axis.indexOf(i) !== -1 && xShape[i] !== 1) {\n return `${xShape[i]} - coords[${i}] - 1`;\n }\n return `coords[${i}]`;\n };\n const inCoords = xShape.map((_, i) => getInCoord(i)).join(',');\n const type = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${type} coords = getOutputCoords();\n setOutput(getX(${inCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {SegOpInfo} from '../../ops/segment_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class SegmentOpProgram implements GPGPUProgram {\n variableNames = ['x', 'segmentIds'];\n outputShape: number[];\n userCode: string;\n\n constructor(segOpInfo: SegOpInfo, segOpType: 'unsortedSegmentSum') {\n const windowSize = segOpInfo.windowSize;\n const batchSize = segOpInfo.batchSize;\n const inSize = segOpInfo.inSize;\n const numSegments = segOpInfo.numSegments;\n const outSize = numSegments * Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n const initializationValue = '0.0';\n const returnValue = `sumValue`;\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n const updateSnippet = `\n sumValue += dot(values, filter);\n `;\n\n let checkValueOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkValueOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n\n let checkSegmentIdOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkSegmentIdOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return -1.0;\n }\n `;\n }\n\n this.userCode = `\n const float initializationValue = ${initializationValue};\n\n float getValue(int batch, int inIdx) {\n ${checkValueOutOfBounds}\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n ${checkSegmentIdOutOfBounds}\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n ${numSegments})) * float(${windowSize}));\n int currentSeg = int(mod(float(outIdx), float(${numSegments})));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SelectProgram implements GPGPUProgram {\n variableNames = ['c', 'a', 'b'];\n outputShape: number[];\n userCode: string;\n\n constructor(cRank: number, shape: number[], rank: number) {\n this.outputShape = shape;\n\n let cCoords;\n let abCoords;\n if (rank > 4) {\n throw Error(`Where for rank ${rank} is not yet supported`);\n }\n\n if (rank === 1) {\n abCoords = `resRC`;\n cCoords = `resRC`;\n } else {\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n const cCoordVars = [];\n const abCoordVars = [];\n for (let i = 0; i < shape.length; i++) {\n abCoordVars.push(`${currentCoords[i]}`);\n if (i < cRank) {\n cCoordVars.push(`${currentCoords[i]}`);\n }\n }\n cCoords = cCoordVars.join();\n abCoords = abCoordVars.join();\n }\n\n const dtype = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n float cVal = getC(${cCoords});\n if (cVal >= 1.0) {\n setOutput(getA(${abCoords}));\n } else {\n setOutput(getB(${abCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SliceProgram implements GPGPUProgram {\n variableNames = ['source'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(destSize: number[]) {\n this.outputShape = destSize;\n this.rank = destSize.length;\n\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getCoords(this.rank);\n\n this.userCode = `\n uniform ${dtype} start;\n\n void main() {\n ${dtype} sourceLoc = start + getOutputCoords();\n setOutput(getSource(${sourceCoords}));\n }\n `;\n }\n\n getCustomSetupFunc(start: number[]) {\n if (start.length !== this.rank) {\n throw Error(\n `The rank (${this.rank}) of the program must match the ` +\n `length of start (${start.length})`);\n }\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'start');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n if (this.rank === 1) {\n gpgpu.gl.uniform1i(this.startLoc, start[0]);\n } else if (this.rank === 2) {\n gpgpu.gl.uniform2i(this.startLoc, start[0], start[1]);\n } else if (this.rank === 3) {\n gpgpu.gl.uniform3i(this.startLoc, start[0], start[1], start[2]);\n } else if (this.rank === 4) {\n gpgpu.gl.uniform4i(\n this.startLoc, start[0], start[1], start[2], start[3]);\n } else {\n throw Error(`Slicing for rank ${this.rank} is not yet supported`);\n }\n };\n }\n}\n\nfunction getCoords(rank: number): string {\n if (rank === 1) {\n return 'sourceLoc';\n } else if (rank === 2) {\n return 'sourceLoc.x, sourceLoc.y';\n } else if (rank === 3) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z';\n } else if (rank === 4) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w';\n } else {\n throw Error(`Slicing for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class StridedSliceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(begin: number[], strides: number[], shape: number[]) {\n this.outputShape = shape;\n this.rank = shape.length;\n const dtype = getCoordsDataType(this.rank);\n\n let newCoords = '';\n if (this.rank === 1) {\n newCoords = 'coords * strides + begin';\n } else {\n newCoords =\n shape.map((_, i) => `coords[${i}] * strides[${i}] + begin[${i}]`)\n .join(',');\n }\n\n this.userCode = `\n ${dtype} begin = ${dtype}(${begin});\n ${dtype} strides = ${dtype}(${strides});\n\n void main() {\n ${dtype} coords = getOutputCoords();\n setOutput(getX(${newCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {PhysicalTextureType, TextureUsage} from './tex_util';\n\nexport class TextureManager {\n private numUsedTextures = 0;\n private numFreeTextures = 0;\n private freeTextures: {[shape: string]: WebGLTexture[]} = {};\n private logEnabled = false;\n private usedTextures: {[shape: string]: WebGLTexture[]} = {};\n\n constructor(private gpgpu: GPGPUContext) {}\n\n acquireTexture(shapeRC: [number, number], usage: TextureUsage): WebGLTexture {\n const physicalTexType = getPhysicalFromLogicalTextureType(usage);\n\n const shapeKey = getKeyFromTextureShape(shapeRC, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n if (!(shapeKey in this.usedTextures)) {\n this.usedTextures[shapeKey] = [];\n }\n\n if (this.freeTextures[shapeKey].length > 0) {\n this.numFreeTextures--;\n this.numUsedTextures++;\n this.log();\n const newTexture = this.freeTextures[shapeKey].shift();\n this.usedTextures[shapeKey].push(newTexture);\n return newTexture;\n }\n this.numUsedTextures++;\n this.log();\n\n let newTexture: WebGLTexture;\n if (physicalTexType === PhysicalTextureType.FLOAT32) {\n newTexture =\n this.gpgpu.createFloat32MatrixTexture(shapeRC[0], shapeRC[1]);\n } else if (physicalTexType === PhysicalTextureType.FLOAT16) {\n newTexture =\n this.gpgpu.createFloat16MatrixTexture(shapeRC[0], shapeRC[1]);\n\n } else if (physicalTexType === PhysicalTextureType.UNSIGNED_BYTE) {\n newTexture =\n this.gpgpu.createUnsignedBytesMatrixTexture(shapeRC[0], shapeRC[1]);\n }\n this.usedTextures[shapeKey].push(newTexture);\n\n return newTexture;\n }\n\n releaseTexture(\n texture: WebGLTexture, shape: [number, number],\n logicalTexType: TextureUsage): void {\n const physicalTexType = getPhysicalFromLogicalTextureType(logicalTexType);\n const shapeKey = getKeyFromTextureShape(shape, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n this.freeTextures[shapeKey].push(texture);\n this.numFreeTextures++;\n this.numUsedTextures--;\n const texList = this.usedTextures[shapeKey];\n const texIndex = texList.indexOf(texture);\n if (texIndex < 0) {\n throw new Error(\n 'Cannot release a texture that was never provided by this ' +\n 'texture manager');\n }\n texList.splice(texIndex, 1);\n this.log();\n }\n\n private log() {\n if (!this.logEnabled) {\n return;\n }\n const total = this.numFreeTextures + this.numUsedTextures;\n console.log(\n 'Free/Used', `${this.numFreeTextures} / ${this.numUsedTextures}`,\n `(${total})`);\n }\n\n getNumUsedTextures(): number {\n return this.numUsedTextures;\n }\n\n getNumFreeTextures(): number {\n return this.numFreeTextures;\n }\n\n dispose() {\n if (this.freeTextures == null) {\n // Already disposed.\n return;\n }\n for (const texShape in this.freeTextures) {\n this.freeTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n for (const texShape in this.usedTextures) {\n this.usedTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n this.freeTextures = null;\n this.usedTextures = null;\n this.numUsedTextures = 0;\n this.numFreeTextures = 0;\n }\n}\n\nfunction getPhysicalFromLogicalTextureType(logicalTexType: TextureUsage):\n PhysicalTextureType {\n if (logicalTexType === TextureUsage.DOWNLOAD ||\n logicalTexType === TextureUsage.PIXELS) {\n return PhysicalTextureType.UNSIGNED_BYTE;\n } else if (logicalTexType === TextureUsage.UPLOAD) {\n return PhysicalTextureType.FLOAT32;\n } else if (logicalTexType === TextureUsage.RENDER) {\n return ENV.get('WEBGL_RENDER_FLOAT32_ENABLED') ?\n PhysicalTextureType.FLOAT32 :\n PhysicalTextureType.FLOAT16;\n }\n throw new Error(`Unknown logical texture type ${logicalTexType}`);\n}\n\nfunction getKeyFromTextureShape(\n shapeRowsCol: [number, number],\n physicalTexType: PhysicalTextureType): string {\n return `${shapeRowsCol[0]}_${shapeRowsCol[1]}_${physicalTexType}`;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TileProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], reps: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[i] * reps[i];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[]): string {\n const rank = aShape.length;\n if (rank > 5) {\n throw Error(`Tile for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `imod(resRC, ${aShape[0]})`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n sourceCoords.push(`imod(${currentCoords[i]}, ${aShape[i]})`);\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TransposeProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], newDim: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[newDim[i]];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const switched = getSwitchedCoords(newDim);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${switched}));\n }\n `;\n }\n}\n\nfunction getSwitchedCoords(newDim: number[]): string {\n const rank = newDim.length;\n if (rank > 6) {\n throw Error(`Transpose for rank ${rank} is not yet supported`);\n }\n const originalOrder =\n ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u', 'resRC.v'];\n const switchedCoords = new Array(rank);\n for (let i = 0; i < newDim.length; i++) {\n switchedCoords[newDim[i]] = originalOrder[i];\n }\n return switchedCoords.join();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const ERF_P = 0.3275911;\nexport const ERF_A1 = 0.254829592;\nexport const ERF_A2 = -0.284496736;\nexport const ERF_A3 = 1.421413741;\nexport const ERF_A4 = -1.453152027;\nexport const ERF_A5 = 1.061405429;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const SELU_SCALEALPHA = 1.7580993408473768599402175208123;\nexport const SELU_SCALE = 1.0507009873554804934193349852946;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as erf_util from '../../ops/erf_util';\nimport * as selu_util from '../../ops/selu_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {GPGPUContext} from './gpgpu_context';\n\nexport class UnaryOpProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(aShape: number[], opSnippet: string) {\n this.outputShape = aShape;\n this.userCode = `\n uniform float NAN;\n float unaryOperation(float x) {\n ${opSnippet}\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n\nconst CHECK_NAN_SNIPPET = `if (isNaN(x)) return x;`;\n\nexport const ABS = `return abs(x);`;\n\nexport const RELU = CHECK_NAN_SNIPPET + `\n return (x < 0.0) ? 0.0 : x;\n`;\n\nexport const ELU = `return (x >= 0.0) ? x : (exp(x) - 1.0);`;\n\nexport const SELU = `\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = ${selu_util.SELU_SCALEALPHA};\n float scale = ${selu_util.SELU_SCALE};\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n`;\n\nexport function STEP(alpha = 0.0) {\n return CHECK_NAN_SNIPPET + `\n return x > 0.0 ? 1.0 : float(${alpha});\n `;\n}\n\nexport const NEG = `return -x;`;\n\nexport const CEIL = `return ceil(x);`;\n\nexport const FLOOR = `return floor(x);`;\n\nexport const SIGN = `\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n`;\n\nexport const ROUND = `\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n`;\n\nexport const EXP = `return exp(x);`;\n\nexport const EXPM1 = `return exp(x) - 1.0;`;\n\nexport const LOG = `if (x < 0.0) return NAN;\n return log(x);`;\n\nexport const LOG1P = `return log(1.0 + x);`;\n\nexport const SQRT = `return sqrt(x);`;\n\nexport const RSQRT = `return inversesqrt(x);`;\n\nexport const SIGMOID = `return 1.0 / (1.0 + exp(-1.0 * x));`;\n\n/**\n * mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n *\n * epsilon is the difference between 1.0 and the next representable\n * float. For a single precision 32 bit float this should be 2^-23, see:\n * https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n *\n * too_large = (x > -threshold) is value above which exp(x) may overflow\n * but softplus(x) == x is within machine epsilon\n *\n * too_small = (x < threshold) is value below which exp(x) may underflow,\n * but softplus(x) == exp(x) is within machine epsilon.\n */\nexport const SOFTPLUS = `\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n`;\n\nexport const SIN = CHECK_NAN_SNIPPET + `\n return sin(x);\n`;\n\nexport const COS = CHECK_NAN_SNIPPET + `\n return cos(x);\n`;\n\nexport const TAN = `return tan(x);`;\n\nexport const ASIN = `return asin(x);`;\n\nexport const ACOS = `return acos(x);`;\n\nexport const ATAN = CHECK_NAN_SNIPPET + `\n return atan(x);\n`;\n\nexport const SINH = `\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n`;\n\nexport const COSH = `\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n`;\n\nexport const TANH = `\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n`;\n\nexport const ASINH = `return log(x + sqrt(x * x + 1.0));`;\n\nexport const ACOSH = CHECK_NAN_SNIPPET + `\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));`;\n\nexport const ATANH = CHECK_NAN_SNIPPET + `\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;`;\n\nexport const ERF = `\n // Error function is calculated approximately with elementary function.\n // See \"Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\n float p = ${erf_util.ERF_P};\n float a1 = ${erf_util.ERF_A1};\n float a2 = ${erf_util.ERF_A2};\n float a3 = ${erf_util.ERF_A3};\n float a4 = ${erf_util.ERF_A4};\n float a5 = ${erf_util.ERF_A5};\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n`;\n\nexport const SQUARE = `return x * x;`;\n\nexport const RECIPROCAL = `return 1.0 / x;`;\n\nexport const LOGICAL_NOT = `return float(!(x >= 1.0));`;\n\nexport const TO_INT = `return float(int(x));`;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, sizeFromShape} from '../util';\nimport {parseAxisParam} from './axis_util';\nimport * as concat_util from './concat_util';\nimport {op} from './operation';\n\n/**\n * Concatenates a list of `Tensor1D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(3) = |r1, g1, b1|\n * B: shape(2) = |r2, g2|\n * C = tf.concat1d([A, B]) == |r1, g1, b1, r2, g2|\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @return The concatenated array.\n */\nfunction concat1d_(tensors: Tensor1D[]|TensorLike[]): Tensor1D {\n return concat(tensors, 0 /* axis */);\n}\n\n/**\n * Concatenates a list of `Tensor2D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat2d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C = shape(2, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concatenate along.\n * @return The concatenated array.\n */\nfunction concat2d_(tensors: Tensor2D[]|TensorLike[], axis: number): Tensor2D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor3D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 1, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat3d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C: shape(2, 2, 3) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * if axis = 2:\n * C = shape(2, 1, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat3d_(tensors: Tensor3D[]|TensorLike[], axis: number): Tensor3D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor4D`s along an axis. See `concat` for details.\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat4d_(tensors: Tensor4D[]|TensorLike[], axis: number): Tensor4D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor`s along a given axis.\n *\n * The tensors ranks and types must match, and their sizes must match in all\n * dimensions except `axis`.\n *\n * Also available are stricter rank-specific methods that assert that\n * `tensors` are of the given rank:\n * - `tf.concat1d`\n * - `tf.concat2d`\n * - `tf.concat3d`\n * - `tf.concat4d`\n *\n * Except `tf.concat1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * a.concat(b).print(); // or a.concat(b)\n * ```\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.concat([a, b, c]).print();\n * ```\n *\n * ```js\n * const a = tf.tensor2d([[1, 2], [10, 20]]);\n * const b = tf.tensor2d([[3, 4], [30, 40]]);\n * const axis = 1;\n * tf.concat([a, b], axis).print();\n * ```\n * @param tensors A list of tensors to concatenate.\n * @param axis The axis to concate along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction concat_(tensors: T[]|TensorLike[], axis = 0): T {\n assert(tensors.length >= 1, 'Pass at least one tensor to concat');\n const $tensors = convertToTensorArray(tensors, 'tensors', 'concat');\n\n let result = $tensors[0] as T;\n if ($tensors.length === 1) {\n return result;\n }\n const axes = parseAxisParam(axis, result.shape);\n\n for (let i = 1; i < $tensors.length; ++i) {\n result = concat2Tensors(result, $tensors[i], axes[0]) as T;\n }\n return result;\n}\n\nfunction concat2Tensors(a: T, b: T, axis: number): T {\n concat_util.assertParams(a.shape, b.shape, axis);\n const outShape = concat_util.computeOutShape(a.shape, b.shape, axis);\n\n // Do the reshape.\n const a2D = a.as2D(-1, sizeFromShape(a.shape.slice(axis)));\n const b2D = b.as2D(-1, sizeFromShape(b.shape.slice(axis)));\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n const {aBegin, aSize, bBegin, bSize} =\n concat_util.computeGradientSliceShapes(a2D.shape, b2D.shape);\n const der = (dy: Tensor2D) => {\n return {a: () => dy.slice(aBegin, aSize), b: () => dy.slice(bBegin, bSize)};\n };\n const res = ENV.engine.runKernel(\n backend => backend.concat(a2D, b2D), {a: a2D, b: b2D}, der);\n return res.reshape(outShape) as T;\n}\n\nexport const concat = op({concat_});\nexport const concat1d = op({concat1d_});\nexport const concat2d = op({concat2d_});\nexport const concat3d = op({concat3d_});\nexport const concat4d = op({concat4d_});\n","// A port of an algorithm by Johannes Baagøe , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baagøe \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n// \n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n// \n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = data.toString();\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorshift7\" algorithm by\n// François Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n","// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n","// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","/*\nCopyright 2014 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\nvar global = this,\n width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\nmath['seed' + rngname] = seedrandom;\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n}\n\n// End anonymous scope, and pass initial values.\n})(\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n","// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by François Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\n\nexport interface RandGauss {\n nextValue(): number;\n}\n\nexport interface RandNormalDataTypes {\n float32: Float32Array;\n int32: Int32Array;\n}\n\n// https://en.wikipedia.org/wiki/Marsaglia_polar_method\nexport class MPRandGauss implements RandGauss {\n private mean: number;\n private stdDev: number;\n private nextVal: number;\n private dtype?: keyof RandNormalDataTypes;\n private truncated?: boolean;\n private upper?: number;\n private lower?: number;\n private random: seedrandom.prng;\n\n constructor(\n mean: number, stdDeviation: number, dtype?: keyof RandNormalDataTypes,\n truncated?: boolean, seed?: number) {\n this.mean = mean;\n this.stdDev = stdDeviation;\n this.dtype = dtype;\n this.nextVal = NaN;\n this.truncated = truncated;\n if (this.truncated) {\n this.upper = this.mean + this.stdDev * 2;\n this.lower = this.mean - this.stdDev * 2;\n }\n const seedValue = seed ? seed : Math.random();\n this.random = seedrandom.alea(seedValue.toString());\n }\n\n /** Returns next sample from a gaussian distribution. */\n public nextValue(): number {\n if (!isNaN(this.nextVal)) {\n const value = this.nextVal;\n this.nextVal = NaN;\n return value;\n }\n\n let resultX: number, resultY: number;\n let isValid = false;\n while (!isValid) {\n let v1: number, v2: number, s: number;\n do {\n v1 = 2 * this.random() - 1;\n v2 = 2 * this.random() - 1;\n s = v1 * v1 + v2 * v2;\n } while (s >= 1 || s === 0);\n\n const mul = Math.sqrt(-2.0 * Math.log(s) / s);\n resultX = this.mean + this.stdDev * v1 * mul;\n resultY = this.mean + this.stdDev * v2 * mul;\n\n if (!this.truncated || this.isValidTruncated(resultX)) {\n isValid = true;\n }\n }\n\n if (!this.truncated || this.isValidTruncated(resultY)) {\n this.nextVal = this.convertValue(resultY);\n }\n return this.convertValue(resultX);\n }\n\n /** Handles proper rounding for non floating point numbers. */\n private convertValue(value: number): number {\n if (this.dtype == null || this.dtype === 'float32') {\n return value;\n }\n return Math.round(value);\n }\n\n /** Returns true if less than 2-standard-deviations from the mean. */\n private isValidTruncated(value: number): boolean {\n return value <= this.upper && value >= this.lower;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {DataType, Rank, ShapeMap, TensorLike, TensorLike1D, TypedArray} from '../types';\nimport * as util from '../util';\nimport {getAxesPermutation, getInnerMostAxes, parseAxisParam} from './axis_util';\nimport {concat} from './concat';\nimport {op} from './operation';\nimport {MPRandGauss} from './rand';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Creates a new tensor with the same values and shape as the specified\n * tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n *\n * x.clone().print();\n * ```\n *\n * @param x The tensor to clone.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction clone_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'clone');\n const der = (dy: T) => {\n return {$x: () => dy.toFloat()};\n };\n\n return ENV.engine.runKernel(\n backend =>\n Tensor.make($x.shape, {dataId: $x.dataId}, $x.dtype) as T,\n {$x}, der) as T;\n}\n\n/**\n * Create an identity matrix.\n *\n * @param numRows Number of rows.\n * @param numColumns Number of columns. Defaults to `numRows`.\n * @param batchShape If provided, will add the batch shape to the beginning\n * of the shape of the returned `Tensor` by repeating the identity\n * matrix.\n * @param dtype Data type.\n * @returns Identity matrix of the specified size and data type, possibly\n * with batch repetition if `batchShape` is specified.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction eye_(\n numRows: number, numColumns?: number,\n batchShape?:\n [\n number\n ]|[number,\n number]|[number, number, number]|[number, number, number, number],\n dtype: DataType = 'float32'): Tensor2D {\n if (numColumns == null) {\n numColumns = numRows;\n }\n const buff = buffer([numRows, numColumns], dtype);\n const n = numRows <= numColumns ? numRows : numColumns;\n for (let i = 0; i < n; ++i) {\n buff.set(1, i, i);\n }\n const out = buff.toTensor().as2D(numRows, numColumns);\n if (batchShape == null) {\n return out;\n } else {\n if (batchShape.length === 1) {\n return tile(expandDims(out, 0), [batchShape[0], 1, 1]);\n } else if (batchShape.length === 2) {\n return tile(\n expandDims(expandDims(out, 0), 0),\n [batchShape[0], batchShape[1], 1, 1]);\n } else if (batchShape.length === 3) {\n return tile(\n expandDims(expandDims(expandDims(out, 0), 0), 0),\n [batchShape[0], batchShape[1], batchShape[2], 1, 1]);\n } else {\n throw new Error(\n `eye() currently supports only 1D and 2D ` +\n // tslint:disable-next-line:no-any\n `batchShapes, but received ${(batchShape as any).length}D.`);\n }\n }\n}\n\n/**\n * Creates a `Tensor` with values sampled from a normal distribution.\n *\n * ```js\n * tf.randomNormal([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, false /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a truncated normal\n * distribution.\n *\n * ```js\n * tf.truncatedNormal([2, 2]).print();\n * ```\n *\n * The generated values follow a normal distribution with specified mean and\n * standard deviation, except that values whose magnitude is more than 2\n * standard deviations from the mean are dropped and re-picked.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output tensor.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction truncatedNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, true /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a uniform distribution.\n *\n * The generated values follow a uniform distribution in the range [minval,\n * maxval). The lower bound minval is included in the range, while the upper\n * bound maxval is excluded.\n *\n * ```js\n * tf.randomUniform([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param minval The lower bound on the range of random values to generate.\n * Defaults to 0.\n * @param maxval The upper bound on the range of random values to generate.\n * Defaults to 1.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomUniform_(\n shape: ShapeMap[R], minval = 0, maxval = 1,\n dtype: DataType = 'float32'): Tensor {\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = util.randUniform(minval, maxval);\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a random number generator\n * function defined by the user.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param randFunction A random number generator function which is called\n * for each element in the output tensor.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\nfunction rand_(\n shape: ShapeMap[R], randFunction: () => number,\n dtype?: DataType): Tensor {\n const size = util.sizeFromShape(shape);\n\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n\n for (let i = 0; i < size; i++) {\n values[i] = randFunction();\n }\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with values drawn from a multinomial distribution.\n *\n * ```js\n * const probs = tf.tensor([.75, .25]);\n * tf.multinomial(probs, 3).print();\n * ```\n *\n * @param logits 1D array with unnormalized log-probabilities, or\n * 2D array of shape `[batchSize, numOutcomes]`. See the `normalized`\n * parameter.\n * @param numSamples Number of samples to draw for each row slice.\n * @param seed The seed number.\n * @param normalized Whether the provided `logits` are normalized true\n * probabilities (sum to 1). Defaults to false.\n * @return 1D array of shape `[numSamples]`, or 2D array of shape\n * `[batchSize, numSamples]`, depending on the rank of the input.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction multinomial_(\n logits: Tensor1D|Tensor2D|TensorLike, numSamples: number, seed?: number,\n normalized = false): Tensor1D|Tensor2D {\n const $logits = convertToTensor(logits, 'logits', 'multinomial');\n const numOutcomes = $logits.size;\n const origRank = $logits.rank;\n if (numOutcomes < 2) {\n throw new Error(\n `Error in multinomial: you need at least 2 outcomes, but got ` +\n `${numOutcomes}.`);\n }\n if (origRank > 2) {\n throw new Error(`Rank of probabilities must be 1 or 2, but is ${origRank}`);\n }\n seed = seed || Math.random();\n const logits2D = origRank === 1 ? $logits.as2D(1, -1) : $logits as Tensor2D;\n const res = ENV.engine.runKernel(\n backend => backend.multinomial(logits2D, normalized, numSamples, seed),\n {logits2D});\n\n return origRank === 1 ? res.as1D() : res;\n}\n\n/**\n * Creates a one-hot `Tensor`. The locations represented by `indices` take\n * value `onValue` (defaults to 1), while all other locations take value\n * `offValue` (defaults to 0).\n *\n * ```js\n * tf.oneHot(tf.tensor1d([0, 1], 'int32'), 3).print();\n * ```\n *\n * @param indices `Tensor1D` of indices with dtype `int32`.\n * @param depth The depth of the one hot dimension.\n * @param onValue A number used to fill in output when the index matches\n * the location.\n * @param offValue A number used to fill in the output when the index does\n * not match the location.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction oneHot_(\n indices: Tensor1D|TensorLike1D, depth: number, onValue = 1,\n offValue = 0): Tensor2D {\n const $indices = convertToTensor(indices, 'indices', 'oneHot', 'int32');\n util.assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n\n if (depth < 2) {\n throw new Error(`Error in oneHot: depth must be >=2, but it is ${depth}`);\n }\n return ENV.engine.runKernel(\n backend => backend.oneHot($indices, depth, onValue, offValue),\n {$indices});\n}\n\n/**\n * Creates a `Tensor` from an image.\n *\n * ```js\n * const image = new ImageData(1, 1);\n * image.data[0] = 100;\n * image.data[1] = 150;\n * image.data[2] = 200;\n * image.data[3] = 255;\n *\n * tf.fromPixels(image).print();\n * ```\n *\n * @param pixels The input image to construct the tensor from. The\n * supported image types are all 4-channel.\n * @param numChannels The number of channels of the output tensor. A\n * numChannels value less than 4 allows you to ignore channels. Defaults to\n * 3 (ignores alpha channel of input image).\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fromPixels_(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels = 3): Tensor3D {\n if (numChannels > 4) {\n throw new Error(\n 'Cannot construct Tensor with more than 4 channels from pixels.');\n }\n return ENV.engine.fromPixels(pixels, numChannels);\n}\n\n/**\n * Draws a `Tensor` of pixel values to a byte array or optionally a\n * canvas.\n *\n * When the dtype of the input is 'float32', we assume values in the range\n * [0-1]. Otherwise, when input is 'int32', we assume values in the range\n * [0-255].\n *\n * Returns a promise that resolves when the canvas has been drawn to.\n *\n * @param img A rank-2 or rank-3 tensor. If rank-2, draws grayscale. If\n * rank-3, must have depth of 1, 3 or 4. When depth of 1, draws\n * grayscale. When depth of 3, we draw with the first three components of\n * the depth dimension corresponding to r, g, b and alpha = 1. When depth of\n * 4, all four components of the depth dimension correspond to r, g, b, a.\n * @param canvas The canvas to draw to.\n */\n/** @doc {heading: 'Visualization'} */\nasync function toPixels(\n img: Tensor2D|Tensor3D|TensorLike,\n canvas?: HTMLCanvasElement): Promise {\n const $img = convertToTensor(img, 'img', 'toPixels', 'int32');\n if ($img.rank !== 2 && $img.rank !== 3) {\n throw new Error(\n `toPixels only supports rank 2 or 3 tensors, got rank ${$img.rank}.`);\n }\n const [height, width] = $img.shape.slice(0, 2);\n const depth = $img.rank === 2 ? 1 : $img.shape[2];\n\n if (depth > 4 || depth === 2) {\n throw new Error(\n `toPixels only supports depth of size ` +\n `1, 3 or 4 but got ${depth}`);\n }\n\n const minTensor = $img.min();\n const maxTensor = $img.max();\n const min = (await minTensor.data())[0];\n const max = (await maxTensor.data())[0];\n minTensor.dispose();\n maxTensor.dispose();\n if ($img.dtype === 'float32') {\n if (min < 0 || max > 1) {\n throw new Error(\n `Tensor values for a float32 Tensor must be in the ` +\n `range [0 - 1] but got range [${min} - ${max}].`);\n }\n } else if ($img.dtype === 'int32') {\n if (min < 0 || max > 255) {\n throw new Error(\n `Tensor values for a int32 Tensor must be in the ` +\n `range [0 - 255] but got range [${min} - ${max}].`);\n }\n } else {\n throw new Error(\n `Unsupported type for toPixels: ${$img.dtype}.` +\n ` Please use float32 or int32 tensors.`);\n }\n\n const data = await $img.data();\n const multiplier = $img.dtype === 'float32' ? 255 : 1;\n const bytes = new Uint8ClampedArray(width * height * 4);\n\n for (let i = 0; i < height * width; ++i) {\n let r, g, b, a;\n if (depth === 1) {\n r = data[i] * multiplier;\n g = data[i] * multiplier;\n b = data[i] * multiplier;\n a = 255;\n } else if (depth === 3) {\n r = data[i * 3] * multiplier;\n g = data[i * 3 + 1] * multiplier;\n b = data[i * 3 + 2] * multiplier;\n a = 255;\n } else if (depth === 4) {\n r = data[i * 4] * multiplier;\n g = data[i * 4 + 1] * multiplier;\n b = data[i * 4 + 2] * multiplier;\n a = data[i * 4 + 3] * multiplier;\n }\n\n const j = i * 4;\n bytes[j + 0] = Math.round(r);\n bytes[j + 1] = Math.round(g);\n bytes[j + 2] = Math.round(b);\n bytes[j + 3] = Math.round(a);\n }\n\n if (canvas != null) {\n canvas.width = width;\n canvas.height = height;\n const ctx = canvas.getContext('2d');\n const imageData = new ImageData(bytes, width, height);\n ctx.putImageData(imageData, 0, 0);\n }\n if ($img !== img) {\n $img.dispose();\n }\n return bytes;\n}\n\n/**\n * Reshapes a `Tensor` to a given shape.\n *\n * Given a input tensor, returns a new tensor with the same values as the\n * input tensor with shape `shape`.\n *\n * If one component of shape is the special value -1, the size of that\n * dimension is computed so that the total size remains constant. In\n * particular, a shape of [-1] flattens into 1-D. At most one component of\n * shape can be -1.\n *\n * If shape is 1-D or higher, then the operation returns a tensor with shape\n * shape filled with the values of tensor. In this case, the number of\n * elements implied by shape must be the same as the number of elements in\n * tensor.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.reshape([2, 2]).print();\n * ```\n *\n * @param x The input tensor to be reshaped.\n * @param shape An array of integers defining the output tensor shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction reshape_(\n x: Tensor|TensorLike, shape: ShapeMap[R2]): Tensor {\n const $x = convertToTensor(x, 'x', 'reshape');\n shape = util.inferFromImplicitShape(shape, $x.size);\n util.assert(\n $x.size === util.sizeFromShape(shape),\n 'new shape and old shape must have the same number of elements.');\n\n const grad = (dy: Tensor) => {\n return {$x: () => dy.reshape($x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.reshape($x, shape), {$x}, grad);\n}\n\n/**\n * Removes dimensions of size 1 from the shape of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4], [1, 1, 4]);\n * x.squeeze().print();\n * ```\n *\n * @param x The input tensor to be squeezed.\n * @param axis An optional list of numbers. If specified, only\n * squeezes the dimensions listed. The dimension index starts at 0. It\n * is an error to squeeze a dimension that is not 1.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction squeeze_(x: Tensor|TensorLike, axis?: number[]): T {\n const $x = convertToTensor(x, 'x', 'squeeze');\n return reshape($x, util.squeezeShape($x.shape, axis).newShape) as T;\n}\n\n/**\n * Casts a `Tensor` to a new dtype.\n *\n * ```js\n * const x = tf.tensor1d([1.5, 2.5, 3]);\n * tf.cast(x, 'int32').print();\n * ```\n * @param x The input tensor to be casted.\n * @param dtype The dtype to cast the input tensor to.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction cast_(x: T|TensorLike, dtype: DataType): T {\n const $x = convertToTensor(x, 'x', 'cast');\n\n const grad = (dy: T) => {\n return {$x: () => dy.clone()};\n };\n return ENV.engine.runKernel(backend => backend.cast($x, dtype), {$x}, grad) as\n T;\n}\n\n/**\n * Construct an tensor by repeating it the number of times given by reps.\n *\n * This operation creates a new tensor by replicating `input` `reps`\n * times. The output tensor's i'th dimension has `input.shape[i] *\n * reps[i]` elements, and the values of `input` are replicated\n * `reps[i]` times along the i'th dimension. For example, tiling\n * `[a, b, c, d]` by `[2]` produces `[a, b, c, d, a, b, c, d]`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n *\n * a.tile([2]).print(); // or a.tile([2])\n * ```\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.tile([1, 2]).print(); // or a.tile([1, 2])\n * ```\n * @param x The tensor to tile.\n * @param reps Determines the number of replications per dimension.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction tile_(x: T|TensorLike, reps: number[]): T {\n const $x = convertToTensor(x, 'x', 'tile');\n\n util.assert(\n $x.rank === reps.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of reps ${reps}.`);\n const grad = (dy: T) => {\n const derX = () => {\n let xGrad = zerosLike($x);\n // TODO(cais): Maybe reduce memory footprint by avoiding repeated\n // slicing.\n if ($x.rank === 1) {\n for (let i = 0; i < reps[0]; ++i) {\n xGrad = xGrad.add(dy.slice([i * $x.shape[0]], [$x.shape[0]]));\n }\n } else if ($x.rank === 2) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1]],\n [$x.shape[0], $x.shape[1]]));\n }\n }\n } else if ($x.rank === 3) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1], k * $x.shape[2]],\n [$x.shape[0], $x.shape[1], $x.shape[2]]));\n }\n }\n }\n } else if ($x.rank === 4) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n for (let l = 0; l < reps[3]; ++l) {\n xGrad = xGrad.add(dy.slice(\n [\n i * $x.shape[0], j * $x.shape[1], k * $x.shape[2],\n l * $x.shape[3]\n ],\n [$x.shape[0], $x.shape[1], $x.shape[2], $x.shape[3]]));\n }\n }\n }\n }\n } else {\n throw new Error(\n `Gradient for tile operation is not implemented for rank-` +\n `${$x.rank} tensors yet.`);\n }\n return xGrad;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(backend => backend.tile($x, reps), {$x}, grad);\n}\n\n/**\n * Pads a `Tensor1D` with a given value and paddings. See `pad` for details.\n */\nfunction pad1d_(\n x: Tensor1D|TensorLike, paddings: [number, number],\n constantValue = 0): Tensor1D {\n util.assert(\n paddings.length === 2,\n 'Invalid number of paddings. Must be length of 2.');\n return pad(x, [paddings], constantValue);\n}\n\n/**\n * Pads a `Tensor2D` with a given value and paddings. See `pad` for details.\n */\nfunction pad2d_(\n x: Tensor2D|TensorLike, paddings: [[number, number], [number, number]],\n constantValue = 0): Tensor2D {\n util.assert(\n paddings.length === 2 && paddings[0].length === 2 &&\n paddings[1].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor3D` with a given value and paddings. See `pad` for details.\n */\nfunction pad3d_(\n x: Tensor3D|TensorLike,\n paddings: [[number, number], [number, number], [number, number]],\n constantValue = 0): Tensor3D {\n util.assert(\n paddings.length === 3 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor4D` with a given value and paddings. See `pad` for details.\n */\nfunction pad4d_(\n x: Tensor4D|TensorLike,\n paddings:\n [\n [number, number], [number, number], [number, number],\n [number, number]\n ],\n constantValue = 0): Tensor4D {\n util.assert(\n paddings.length === 4 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2 &&\n paddings[3].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor` with a given value and paddings.\n *\n * This operation currently only implements the `CONSTANT` mode.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `paddings` is of given length.\n * - `tf.pad1d`\n * - `tf.pad2d`\n * - `tf.pad3d`\n * - `tf.pad4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.pad([[1, 2]]).print();\n * ```\n * @param x The tensor to pad.\n * @param paddings An array of length `R` (the rank of the tensor), where\n * each element is a length-2 tuple of ints `[padBefore, padAfter]`,\n * specifying how much to pad along each dimension of the tensor.\n * @param constantValue The pad value to use. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction pad_(\n x: T|TensorLike, paddings: Array<[number, number]>, constantValue = 0): T {\n const $x = convertToTensor(x, 'x', 'pad');\n\n if ($x.rank === 0) {\n throw new Error('pad(scalar) is not defined. Pass non-scalar to pad');\n }\n // Pad introduces values around the original tensor, so the gradient\n // slices the original shape out of the gradient.\n const begin = paddings.map(p => p[0]);\n const grad = (dy: T) => {\n return {$x: () => dy.slice(begin, $x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.pad($x, paddings, constantValue), {$x}, grad) as\n T;\n}\n\n/**\n * Stacks a list of rank-`R` `Tensor`s into one rank-`(R+1)` `Tensor`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.stack([a, b, c]).print();\n * ```\n *\n * @param tensors A list of tensor objects with the same shape and dtype.\n * @param axis The axis to stack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction stack_(tensors: T[]|TensorLike[], axis = 0): Tensor {\n const $tensors = convertToTensorArray(tensors, 'tensors', 'stack');\n\n util.assert($tensors.length >= 1, 'Pass at least one tensor to tf.stack');\n if ($tensors.length === 1) {\n return $tensors[0].expandDims(axis);\n }\n const rank = $tensors[0].rank;\n const shape = $tensors[0].shape;\n const dtype = $tensors[0].dtype;\n\n util.assert(axis <= rank, 'Axis must be <= rank of the tensor');\n\n $tensors.forEach(t => {\n util.assertShapesMatch(\n shape, t.shape,\n 'All tensors passed to stack must have matching shapes');\n });\n\n $tensors.forEach(t => {\n util.assert(\n dtype === t.dtype,\n 'All tensors passed to stack must have matching dtypes');\n });\n const expandedTensors = $tensors.map(t => t.expandDims(axis));\n return concat(expandedTensors, axis);\n}\n\n/**\n * This operation reshapes the \"batch\" dimension 0 into `M + 1` dimensions of\n * shape `blockShape + [batch]`, interleaves these blocks back into the grid\n * defined by the spatial dimensions `[1, ..., M]`, to obtain a result with\n * the same rank as the input. The spatial dimensions of this intermediate\n * result are then optionally cropped according to `crops` to produce the\n * output. This is the reverse of `spaceToBatchND`. See below for a precise\n * description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const crops = [[0, 0], [0, 0]];\n *\n * x.batchToSpaceND(blockShape, crops).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param crops A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `crops[i] =\n * [cropStart, cropEnd]` specifies the amount to crop from input dimension `i\n * + 1`, which corresponds to spatial dimension `i`. It is required that\n * `cropStart[i] + cropEnd[i] <= blockShape[i] * inputShape[i + 1]`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Reshape `x` to `reshaped` of shape: `[blockShape[0], ...,\n * blockShape[M-1], batch / prod(blockShape), x.shape[1], ...,\n * x.shape[N-1]]`\n *\n * 2. Permute dimensions of `reshaped`to produce `permuted` of shape `[batch /\n * prod(blockShape),x.shape[1], blockShape[0], ..., x.shape[M],\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 3. Reshape `permuted` to produce `reshapedPermuted` of shape `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0], ..., x.shape[M] *\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 4. Crop the start and end of dimensions `[1, ..., M]` of `reshapedPermuted`\n * according to `crops` to produce the output of shape: `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0] - crops[0,0] - crops[0,1],\n * ..., x.shape[M] * blockShape[M-1] - crops[M-1,0] -\n * crops[M-1,1],x.shape[M+1], ..., x.shape[N-1]]`\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction batchToSpaceND_(\n x: T|TensorLike, blockShape: number[], crops: number[][]): T {\n const $x = convertToTensor(x, 'x', 'batchToSpaceND');\n const prod = blockShape.reduce((a, b) => a * b);\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n crops.length === blockShape.length,\n `crops.shape[0] must be equal to [blockShape] but got ${crops.length}`);\n\n util.assert(\n $x.shape[0] % prod === 0,\n `input tensor batch must be divisible by prod( blockShape )`);\n return ENV.engine.runKernel(\n backend => backend.batchToSpaceND($x, blockShape, crops), {});\n}\n\n/**\n * This operation divides \"spatial\" dimensions [1, ..., M] of the input into\n * a grid of blocks of shape block_shape, and interleaves these blocks with\n * the \"batch\" dimension (0) such that in the output, the spatial\n * dimensions [1, ..., M] correspond to the position within the grid,\n * and the batch dimension combines both the position within a spatial block\n * and the original batch position. Prior to division into blocks,\n * the spatial dimensions of the input are optionally zero padded\n * according to paddings. See below for a precise description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const paddings = [[0, 0], [0, 0]];\n *\n * x.spaceToBatchND(blockShape, paddings).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param paddings A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `paddings[i] =\n * [padStart, padEnd]` specifies the amount to zero-pad from input dimension\n * `i + 1`, which corresponds to spatial dimension `i`.\n * It is required that\n * `(inputShape[i + 1] + padStart + padEnd) % blockShape[i] === 0`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Zero-pad the start and end of dimensions [1, ..., M] of the input\n * according to paddings to produce padded of shape padded_shape.\n *\n * 2. Reshape padded to reshaped_padded of shape:\n * [batch] + [padded_shape[1] / block_shape[0], block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1], block_shape[M-1]] + remaining_shape\n *\n * 3. Permute dimensions of reshaped_padded to produce permuted_\n * reshaped_padded of shape:\n * block_shape + [batch] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n *\n * 4. Reshape permuted_reshaped_padded to flatten block_shape into the\n * batch dimension, producing an output tensor of shape:\n * [batch * prod(block_shape)] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction spaceToBatchND_(\n x: T|TensorLike, blockShape: number[], paddings: number[][]): T {\n const $x = convertToTensor(x, 'x', 'spaceToBatchND');\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n paddings.length === blockShape.length,\n `paddings.shape[0] must be equal to [blockShape], got ${\n paddings.length}`);\n\n util.assert($x.shape.reduce((a, b, i) => {\n if (i > 0 && i <= blockShape.length) {\n return a && (b % blockShape[i - 1] === 0);\n }\n return a;\n }, true), `input spatial dimensions must be divisible by blockShapes`);\n return ENV.engine.runKernel(\n backend => backend.spaceToBatchND($x, blockShape, paddings), {});\n}\n\n/**\n * Unstacks a `Tensor` of rank-`R` into a list of rank-`(R-1)` `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * tf.unstack(a).forEach(tensor => tensor.print());\n * ```\n *\n * @param x A tensor object.\n * @param axis The axis to unstack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction unstack_(x: T|TensorLike, axis = 0): Tensor[] {\n const $x = convertToTensor(x, 'x', 'unstack');\n const num = $x.shape[axis];\n const outputShape: number[] = Array($x.rank - 1).fill(0);\n let outIndex = 0;\n for (let i = 0; i < $x.rank; i++) {\n if (i !== axis) {\n outputShape[outIndex] = $x.shape[i];\n outIndex++;\n }\n }\n\n let splitSizes: number[];\n splitSizes = Array(num).fill(1);\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice.reshape(outputShape);\n });\n}\n\n/**\n * Splits a `Tensor` into sub tensors.\n *\n * If `numOrSizeSplits` is a number, splits `x` along dimension `axis`\n * into `numOrSizeSplits` smaller tensors.\n * Requires that `numOrSizeSplits` evenly divides `x.shape[axis]`.\n *\n * If `numOrSizeSplits` is a number array, splits `x` into\n * `(numOrSizeSplits.length` pieces. The shape of the `i`-th piece has the\n * same size as `x` except along dimension `axis` where the size is\n * `numOrSizeSplits[i]`.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]);\n * const [a, b] = tf.split(x, 2, 1);\n * a.print();\n * b.print();\n *\n * const [c, d, e] = tf.split(x, [1, 2, 1], 1);\n * c.print();\n * d.print();\n * e.print();\n * ```\n *\n * @param x The input tensor to split.\n * @param numOrSizeSplits Either an integer indicating the number of\n * splits along the axis or an array of integers containing the sizes of\n * each output tensor along the axis. If a number then it must evenly divide\n * `x.shape[axis]`; otherwise the sum of sizes must match `x.shape[axis]`.\n * @param axis The dimension along which to split. Defaults to 0 (the first\n * dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction split_(\n x: T|TensorLike, numOrSizeSplits: number[]|number, axis = 0): T[] {\n const $x = convertToTensor(x, 'x', 'split');\n\n axis = parseAxisParam(axis, $x.shape)[0];\n let splitSizes: number[];\n if (typeof (numOrSizeSplits) === 'number') {\n util.assert(\n $x.shape[axis] % numOrSizeSplits === 0,\n 'Number of splits must evenly divide the axis.');\n splitSizes = Array(numOrSizeSplits).fill($x.shape[axis] / numOrSizeSplits);\n } else {\n util.assert(\n $x.shape[axis] === numOrSizeSplits.reduce((a, b) => a + b),\n 'The sum of sizes must match the size of the axis dimension.');\n splitSizes = numOrSizeSplits;\n }\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice;\n });\n}\n\n/**\n * Computes the cumulative sum of a `Tensor` along `axis`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4]);\n * x.cumsum().print();\n * ```\n * ```js\n * const x = tf.tensor([[1, 2], [3, 4]]);\n * x.cumsum().print();\n * ```\n *\n * @param x The input tensor to be summed.\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Optional.\n * Defaults to false. If set to true then the sum of each tensor entry\n * does not include its own value, but only the values previous to it\n * along the specified axis.\n * @param reverse Whether to sum in the opposite direction. Optional.\n * Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Scan'} */\nfunction cumsum_(\n x: Tensor|TensorLike, axis = 0, exclusive = false, reverse = false): T {\n const $x = convertToTensor(x, 'x', 'cumsum');\n\n axis = axis | 0;\n const permutation = getAxesPermutation([axis], $x.rank);\n let permutedX = $x;\n if (permutation != null) {\n permutedX = $x.transpose(permutation);\n }\n const permutedAxis = getInnerMostAxes(1, $x.rank)[0];\n\n const grad = (dy: T) => {\n return {permutedX: () => dy.cumsum(axis, exclusive, !reverse)};\n };\n let value = ENV.engine.runKernel(\n backend => backend.cumsum(\n permutedX, permutedAxis, exclusive, reverse),\n {permutedX}, grad) as T;\n\n if (permutation != null) {\n value = value.transpose(permutation);\n }\n return value;\n}\n\n/**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const axis = 1;\n * x.expandDims(axis).print();\n * ```\n *\n * @param x The input tensor whose dimensions to be expanded.\n * @param axis The dimension index at which to insert shape of `1`. Defaults\n * to 0 (the first dimension).\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction expandDims_(\n x: Tensor|TensorLike, axis = 0): Tensor {\n const $x = convertToTensor(x, 'x', 'expandDims');\n\n util.assert(axis <= $x.rank, 'Axis must be <= rank of the tensor');\n const newShape = $x.shape.slice();\n if (axis < 0) {\n // Negative value is counted from the tail of rank.\n util.assert(\n -($x.rank + 1) <= axis,\n `Axis must be in the interval [${- ($x.rank + 1)}, ${$x.rank}]`);\n axis = $x.rank + axis + 1;\n }\n newShape.splice(axis, 0, 1);\n return reshape($x, newShape);\n}\n\n/**\n * Creates an empty `TensorBuffer` with the specified `shape` and `dtype`.\n *\n * The values are stored in cpu as `TypedArray`. Fill the buffer using\n * `buffer.set()`, or by modifying directly `buffer.values`.\n *\n * When done, call `buffer.toTensor()` to get an immutable `Tensor` with\n * those values.\n *\n * ```js\n * // Create a buffer and set values at particular indices.\n * const buffer = tf.buffer([2, 2]);\n * buffer.set(3, 0, 0);\n * buffer.set(5, 1, 0);\n *\n * // Convert the buffer back to a tensor.\n * buffer.toTensor().print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The dtype of the buffer. Defaults to 'float32'.\n * @param values The values of the buffer as `TypedArray`. Defaults to\n * zeros.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction buffer(\n shape: ShapeMap[R], dtype: DataType = 'float32',\n values?: TypedArray): TensorBuffer {\n return new TensorBuffer(shape, dtype, values);\n}\n\n/**\n * Prints information about the `Tensor` including its data.\n *\n * ```js\n * const verbose = true;\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print(verbose);\n * ```\n * @param x The tensor to be printed.\n * @param verbose Whether to print verbose information about the ` Tensor`,\n * including dtype and size.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction print(x: T, verbose = false): void {\n console.log(x.toString(verbose));\n}\n\nexport {\n buffer, // Not wrapped in op() since no tensors.\n toPixels, // Not wrapped in op() since async.\n print // Not wrapped in op() since no need to increase stack trace.\n};\n\nexport const cast = op({cast_});\nexport const clone = op({clone_});\nexport const cumsum = op({cumsum_});\nexport const expandDims = op({expandDims_});\nexport const eye = op({eye_});\nexport const fromPixels = op({fromPixels_});\nexport const multinomial = op({multinomial_});\nexport const oneHot = op({oneHot_});\nexport const pad = op({pad_});\nexport const pad1d = op({pad1d_});\nexport const pad2d = op({pad2d_});\nexport const pad3d = op({pad3d_});\nexport const pad4d = op({pad4d_});\nexport const rand = op({rand_});\nexport const randomNormal = op({randomNormal_});\nexport const randomUniform = op({randomUniform_});\nexport const reshape = op({reshape_});\nexport const split = op({split_});\nexport const squeeze = op({squeeze_});\nexport const stack = op({stack_});\nexport const tile = op({tile_});\nexport const truncatedNormal = op({truncatedNormal_});\nexport const unstack = op({unstack_});\nexport const batchToSpaceND = op({batchToSpaceND_});\nexport const spaceToBatchND = op({spaceToBatchND_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the Where kernel shared between cpu and webgl */\n\nimport {buffer} from '../ops/array_ops';\nimport {Tensor2D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function whereImpl(condShape: number[], condVals: TypedArray): Tensor2D {\n const indices = [];\n for (let i = 0; i < condVals.length; i++) {\n if (condVals[i]) {\n indices.push(i);\n }\n }\n\n const inBuffer = buffer(condShape, 'int32');\n\n const out = buffer([indices.length, condShape.length], 'int32');\n for (let i = 0; i < indices.length; i++) {\n const loc = inBuffer.indexToLoc(indices[i]);\n const offset = i * condShape.length;\n out.values.set(loc, offset);\n }\n return out.toTensor() as Tensor2D;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {MemoryInfo, TimingInfo} from '../engine';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as reduce_util from '../ops/reduce_util';\nimport * as segment_util from '../ops/segment_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {softmax} from '../ops/softmax';\nimport {range, tensor} from '../ops/tensor_ops';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, RecursiveArray, ShapeMap, sumOutType, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\n\nimport {KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {ArgMinMaxProgram} from './webgl/argminmax_gpu';\nimport {AvgPool2DBackpropProgram} from './webgl/avg_pool_backprop_gpu';\nimport {BatchNormProgram} from './webgl/batchnorm_gpu';\nimport * as binaryop_gpu from './webgl/binaryop_gpu';\nimport {BinaryOpProgram} from './webgl/binaryop_gpu';\nimport {ClipProgram} from './webgl/clip_gpu';\nimport {ConcatProgram} from './webgl/concat_gpu';\nimport {Conv2DDerFilterProgram, Conv2DDerInputProgram} from './webgl/conv_backprop_gpu';\nimport {DepthwiseConv2DDerFilterProgram, DepthwiseConv2DDerInputProgram} from './webgl/conv_backprop_gpu_depthwise';\nimport {Conv2DProgram} from './webgl/conv_gpu';\nimport {DepthwiseConv2DProgram} from './webgl/conv_gpu_depthwise';\nimport {CumSumProgram} from './webgl/cumsum_gpu';\nimport {EncodeFloatProgram} from './webgl/encode_float_gpu';\nimport {FromPixelsProgram} from './webgl/from_pixels_gpu';\nimport {GatherProgram} from './webgl/gather_gpu';\nimport {GPGPUContext} from './webgl/gpgpu_context';\nimport * as gpgpu_math from './webgl/gpgpu_math';\nimport {GPGPUBinary, GPGPUProgram, TensorData} from './webgl/gpgpu_math';\nimport * as gpgpu_util from './webgl/gpgpu_util';\nimport {LRNProgram} from './webgl/lrn_gpu';\nimport {LRNGradProgram} from './webgl/lrn_grad_gpu';\nimport {MaxPool2DBackpropProgram} from './webgl/max_pool_backprop_gpu';\nimport {MatMulProgram} from './webgl/mulmat_gpu';\nimport {MultinomialProgram} from './webgl/multinomial_gpu';\nimport {OneHotProgram} from './webgl/onehot_gpu';\nimport {PadProgram} from './webgl/pad_gpu';\nimport {Pool2DProgram} from './webgl/pool_gpu';\nimport {ReduceProgram} from './webgl/reduce_gpu';\nimport {ResizeBilinearBackpropProgram} from './webgl/resize_bilinear_backprop_gpu';\nimport {ResizeBilinearProgram} from './webgl/resize_bilinear_gpu';\nimport {ResizeNearestNeigborBackpropProgram} from './webgl/resize_nearest_neighbor_backprop_gpu';\nimport {ResizeNearestNeighborProgram} from './webgl/resize_nearest_neighbor_gpu';\nimport {ReverseProgram} from './webgl/reverse_gpu';\nimport {SegmentOpProgram} from './webgl/segment_gpu';\nimport {SelectProgram} from './webgl/select_gpu';\nimport {SliceProgram} from './webgl/slice_gpu';\nimport {StridedSliceProgram} from './webgl/strided_slice_gpu';\nimport {TextureData, TextureUsage} from './webgl/tex_util';\nimport {TextureManager} from './webgl/texture_manager';\nimport {TileProgram} from './webgl/tile_gpu';\nimport {TransposeProgram} from './webgl/transpose_gpu';\nimport * as unary_op from './webgl/unaryop_gpu';\nimport {UnaryOpProgram} from './webgl/unaryop_gpu';\nimport * as webgl_util from './webgl/webgl_util';\nimport {whereImpl} from './where_impl';\n\ntype TimerNode = RecursiveArray>|Promise;\nexport interface CPUTimerQuery {\n startMs: number;\n endMs?: number;\n}\n\nexport interface WebGLMemoryInfo extends MemoryInfo {\n numBytesInGPU: number;\n unreliable: boolean;\n}\n\nexport interface WebGLTimingInfo extends TimingInfo {\n uploadWaitMs: number;\n downloadWaitMs: number;\n}\n\n// Empirically determined constant used to decide the number of bytes on GPU\n// before we start paging. The bytes are this constant * screen area * dpi.\nconst BEFORE_PAGING_CONSTANT = 300;\n// Tensors with size <= than this will be uploaded as uniforms, not textures.\nexport const SIZE_UPLOAD_UNIFORM = 32;\n\nexport class MathBackendWebGL implements KernelBackend {\n private texData = new WeakMap();\n // Maps data ids that have a pending read operation, to list of subscribers.\n private pendingRead = new WeakMap void>>();\n // List of data ids that are scheduled for disposal, but are waiting on a\n // pending read operation.\n private pendingDisposal = new WeakSet();\n // List of data ids that are currently residing on gpu memory. Sorted with\n // least recently used being first.\n private lruDataGPU: DataId[] = [];\n private numBytesInGPU = 0;\n /**\n * Number of bytes allocated on the GPU before we start moving data to cpu.\n * Moving avoids gpu memory leaks and relies on JS's garbage collector.\n */\n private NUM_BYTES_BEFORE_PAGING: number;\n\n private canvas: HTMLCanvasElement;\n private fromPixelsCanvas: HTMLCanvasElement;\n\n private programTimersStack: TimerNode[];\n private activeTimers: TimerNode[];\n // Accumulated time spent (including blocking) in uploading data to webgl.\n private uploadWaitMs = 0;\n // Accumulated time spent (including blocking in downloading data from webgl.\n private downloadWaitMs = 0;\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.texData.has(dataId)) {\n throw new Error('Data buffer is already registered');\n }\n this.texData.set(dataId, {\n shape,\n dtype,\n values: null,\n texture: null,\n texShape: null,\n usage: TextureUsage.RENDER\n });\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n const texShape: [number, number] = [pixels.height, pixels.width];\n const outShape = [pixels.height, pixels.width, numChannels];\n\n if (!(pixels instanceof HTMLVideoElement) &&\n !(pixels instanceof HTMLImageElement) &&\n !(pixels instanceof HTMLCanvasElement) &&\n !(pixels instanceof ImageData)) {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n if (pixels instanceof HTMLVideoElement) {\n if (this.fromPixelsCanvas == null) {\n if (!ENV.get('IS_BROWSER')) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside the browser.');\n }\n if (document.readyState !== 'complete') {\n throw new Error(\n 'The DOM is not ready yet. Please call tf.fromPixels() ' +\n 'once the DOM is ready. One way to do that is to add an event ' +\n 'listener for `DOMContentLoaded` on the document object');\n }\n this.fromPixelsCanvas = document.createElement('canvas');\n }\n this.fromPixelsCanvas.width = pixels.width;\n this.fromPixelsCanvas.height = pixels.height;\n this.fromPixelsCanvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n pixels = this.fromPixelsCanvas;\n }\n const tempPixelArray = Tensor.make(texShape, {}, 'int32');\n\n // This is a byte texture with pixels.\n this.texData.get(tempPixelArray.dataId).usage = TextureUsage.PIXELS;\n this.gpgpu.uploadPixelDataToTexture(\n this.getTexture(tempPixelArray.dataId), pixels);\n const program = new FromPixelsProgram(outShape);\n const res = this.compileAndRun(program, [tempPixelArray]);\n\n tempPixelArray.dispose();\n\n return res as Tensor3D;\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendWebGL.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n\n const texData = this.texData.get(dataId);\n const {texture, texShape, usage} = texData;\n if (texture != null) {\n // Release the old texture.\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n texData.usage = TextureUsage.UPLOAD;\n texData.values = values;\n\n if (!this.delayedStorage) {\n this.uploadToGPU(dataId);\n }\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n\n const float32Values =\n this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n\n if (shouldTimeProgram) {\n this.downloadWaitMs += performance.now() - start;\n }\n this.cacheOnCPU(dataId, float32Values);\n return texData.values;\n }\n\n async read(dataId: DataId): Promise {\n if (this.pendingRead.has(dataId)) {\n const subscribers = this.pendingRead.get(dataId);\n return new Promise(resolve => subscribers.push(resolve));\n }\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n\n this.pendingRead.set(dataId, []);\n\n if (!ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED') &&\n ENV.get('WEBGL_VERSION') === 2) {\n throw new Error(\n `tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and ` +\n `WEBGL_VERSION=2 not yet supported.`);\n }\n\n // Possibly copy the texture into a buffer before inserting a fence.\n const bufferOrTexture = this.gpgpu.maybeCreateBufferFromTexture(\n texture, texShape[0], texShape[1]);\n\n // Create a fence and wait for it to resolve.\n await this.gpgpu.createAndWaitForFence();\n\n // Download the values from the GPU.\n let vals: Float32Array;\n if (bufferOrTexture instanceof WebGLTexture) {\n vals = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n } else {\n vals = this.gpgpu.downloadFloat32MatrixFromBuffer(\n bufferOrTexture, texShape[0], texShape[1]);\n }\n this.cacheOnCPU(dataId, vals);\n\n const subscribers = this.pendingRead.get(dataId);\n this.pendingRead.delete(dataId);\n\n // Notify all pending reads.\n subscribers.forEach(resolve => resolve(vals));\n if (this.pendingDisposal.has(dataId)) {\n this.pendingDisposal.delete(dataId);\n this.disposeData(dataId);\n }\n return vals;\n }\n\n private getValuesFromTexture(\n texture: WebGLTexture, dataId: DataId, dtype: DataType,\n texShape: [number, number], shape: number[]): Float32Array {\n if (ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED')) {\n return this.gpgpu.downloadFloat32MatrixFromOutputTexture(\n texture, texShape[0], texShape[1]);\n }\n\n const tmpTarget = Tensor.make(shape, {});\n this.texData.get(tmpTarget.dataId).usage = TextureUsage.DOWNLOAD;\n\n const tmpInput = Tensor.make(shape, {dataId}, dtype);\n const program = new EncodeFloatProgram(shape);\n const pageToCpu = false;\n this.compileAndRun(program, [tmpInput], tmpTarget, null, pageToCpu);\n const tmpData = this.texData.get(tmpTarget.dataId);\n const vals = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(\n tmpData.texture, tmpData.texShape[0], tmpData.texShape[1]);\n\n tmpInput.dispose();\n tmpTarget.dispose();\n\n return vals;\n }\n\n async time(f: () => void): Promise {\n const oldActiveTimers = this.activeTimers;\n const newActiveTimers: TimerNode[] = [];\n\n let outerMostTime = false;\n if (this.programTimersStack == null) {\n this.programTimersStack = newActiveTimers;\n outerMostTime = true;\n } else {\n this.activeTimers.push(newActiveTimers);\n }\n this.activeTimers = newActiveTimers;\n\n f();\n\n const flattenedActiveTimers = util.flatten(this.activeTimers);\n this.activeTimers = oldActiveTimers;\n\n if (outerMostTime) {\n this.programTimersStack = null;\n }\n\n const kernelMs = await Promise.all(flattenedActiveTimers).then(results => {\n let sum = 0;\n results.forEach(result => sum += result);\n return sum;\n });\n const res: WebGLTimingInfo = {\n uploadWaitMs: this.uploadWaitMs,\n downloadWaitMs: this.downloadWaitMs,\n kernelMs,\n wallMs: null // will be filled by the engine\n };\n this.uploadWaitMs = 0;\n this.downloadWaitMs = 0;\n return res;\n }\n memory(): WebGLMemoryInfo {\n return {unreliable: false, numBytesInGPU: this.numBytesInGPU} as\n WebGLMemoryInfo;\n }\n\n private startTimer(): WebGLQuery|CPUTimerQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.beginQuery();\n }\n return {startMs: performance.now(), endMs: null};\n }\n\n private endTimer(query: WebGLQuery|CPUTimerQuery): WebGLQuery|\n {startMs: number, endMs: number} {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n this.gpgpu.endQuery();\n return query;\n }\n (query as CPUTimerQuery).endMs = performance.now();\n return query;\n }\n\n private async getQueryTime(query: WebGLQuery|CPUTimerQuery): Promise {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.waitForQueryAndGetTime(query);\n }\n const timerQuery = query as CPUTimerQuery;\n return timerQuery.endMs - timerQuery.startMs;\n }\n\n disposeData(dataId: DataId): void {\n if (this.pendingDisposal.has(dataId)) {\n return;\n }\n if (this.pendingRead.has(dataId)) {\n this.pendingDisposal.add(dataId);\n return;\n }\n if (this.texData.has(dataId)) {\n const {texture, texShape, usage} = this.texData.get(dataId);\n if (texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n }\n this.texData.delete(dataId);\n }\n }\n\n getTexture(dataId: DataId): WebGLTexture {\n this.uploadToGPU(dataId);\n return this.texData.get(dataId).texture;\n }\n\n private textureManager: TextureManager;\n private binaryCache: {[key: string]: GPGPUBinary} = {};\n private gpgpuCreatedLocally: boolean;\n\n constructor(private gpgpu?: GPGPUContext, private delayedStorage = true) {\n if (ENV.get('WEBGL_VERSION') < 1) {\n throw new Error('WebGL is not supported on this device');\n }\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n if (gpgpu == null) {\n this.gpgpu = new GPGPUContext(gpgpu_util.createWebGLContext(this.canvas));\n this.gpgpuCreatedLocally = true;\n } else {\n this.gpgpuCreatedLocally = false;\n }\n // Use the device screen's resolution as a heuristic to decide on the\n // maximum memory allocated on the GPU before starting to page.\n this.NUM_BYTES_BEFORE_PAGING =\n (window.screen.height * window.screen.width * window.devicePixelRatio) *\n BEFORE_PAGING_CONSTANT;\n this.textureManager = new TextureManager(this.gpgpu);\n }\n\n getGPGPUContext(): GPGPUContext {\n return this.gpgpu;\n }\n getCanvas(): HTMLCanvasElement {\n return this.canvas;\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const program = new SliceProgram(size);\n const customSetup = program.getCustomSetupFunc(begin);\n return this.compileAndRun(program, [x], null, customSetup);\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return tensor([], size) as T;\n }\n\n const program = new StridedSliceProgram(beginIndex, strides, size);\n return this.compileAndRun(program, [x]);\n }\n\n reverse(x: T, axis: number[]): T {\n const program = new ReverseProgram(x.shape, axis);\n return this.compileAndRun(program, [x]);\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const program = new ConcatProgram(a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n neg(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.NEG);\n return this.compileAndRun(program, [x]) as T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const program = new MatMulProgram(a.shape, b.shape, transposeA, transposeB);\n return this.compileAndRun(program, [a, b]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MUL, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output) as Tensor;\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const inputs = [x, mean, variance];\n\n let offsetShape = null;\n if (offset != null) {\n offsetShape = offset.shape;\n inputs.push(offset);\n }\n\n let scaleShape = null;\n if (scale != null) {\n scaleShape = scale.shape;\n inputs.push(scale);\n }\n\n const program = new BatchNormProgram(\n x.shape, mean.shape, variance.shape, offsetShape, scaleShape,\n varianceEpsilon);\n return this.compileAndRun(program, inputs);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program = new LRNProgram(x.shape, radius, bias, alpha, beta);\n return this.compileAndRun(program, [x]);\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program =\n new LRNGradProgram(inputImage.shape, depthRadius, bias, alpha, beta);\n return this.compileAndRun(program, [inputImage, outputImage, dy]);\n }\n\n tile(x: T, reps: number[]): T {\n const program = new TileProgram(x.shape, reps);\n return this.compileAndRun(program, [x]);\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const program = new PadProgram(x.shape, paddings, constantValue);\n return this.compileAndRun(program, [x]);\n }\n\n transpose(x: T, perm: number[]): T {\n const program = new TransposeProgram(x.shape, perm);\n return this.compileAndRun(program, [x]);\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const program = new GatherProgram(x.shape, indices.size, axis);\n return this.compileAndRun(program, [x, indices]);\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n util.assert(\n x.rank <= 4,\n 'batchToSpaceND for rank > 4 with a WebGL backend not implemented yet');\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n util.assert(\n x.rank <= 4,\n 'spaceToBatchND for rank > 4 with a WebGL backend not implemented yet');\n\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private reduce(\n x: Tensor2D, reduceType: 'all'|'any'|'max'|'min'|'sum',\n dtype: DataType): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program = new ReduceProgram(reduceInfo, reduceType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.reduce(output, reduceType, dtype);\n }\n\n private argReduce(\n x: Tensor2D, reduceType: 'max'|'min',\n bestIndicesA: Tensor2D = null): Tensor2D {\n let batchSize = x.shape[0];\n let inSize = x.shape[1];\n if (bestIndicesA != null) {\n batchSize = bestIndicesA.shape[0];\n inSize = bestIndicesA.shape[1];\n }\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program =\n new ArgMinMaxProgram(reduceInfo, reduceType, bestIndicesA == null);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], 'int32');\n const inputs = [x];\n if (bestIndicesA != null) {\n inputs.push(bestIndicesA);\n }\n this.compileAndRun(program, inputs, output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.argReduce(x, reduceType, output);\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n return this.reduce(a2D, 'sum', outputDType).reshape(outShape);\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n let axis = 0;\n const permutation = axis_util.getAxesPermutation([axis], x.rank);\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n axis = axis_util.getInnerMostAxes(1, x.rank)[0];\n }\n\n const outShape =\n segment_util.computeOutShape(permutedX.shape, axis, numSegments);\n const inSize = util.sizeFromShape([permutedX.shape[axis]]);\n const a2D = permutedX.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n let result =\n this.segOpCompute(\n a2D, 'unsortedSegmentSum', segmentIds, outputDType, numSegments)\n .reshape(outShape);\n if (permutation != null) {\n result = result.transpose(axis_util.getUndoAxesPermutation(permutation));\n }\n return result;\n }\n\n private segOpCompute(\n x: Tensor2D, segOpType: 'unsortedSegmentSum', segmentIds: Tensor1D,\n dtype: DataType, numSegments: number): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize =\n segment_util.segOpComputeOptimalWindowSize(inSize, numSegments);\n const segOpInfo = {windowSize, inSize, batchSize, numSegments};\n const program = new SegmentOpProgram(segOpInfo, segOpType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x, segmentIds], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === numSegments) {\n return output;\n }\n segmentIds = range(0, numSegments).tile([inSize / windowSize]);\n return this.segOpCompute(output, segOpType, segmentIds, dtype, numSegments);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'min').reshape(outShape);\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'max').reshape(outShape);\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `WebGL cumsum shader expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const program = new CumSumProgram(x.shape, exclusive, reverse);\n return this.compileAndRun(program, [x]);\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.NOT_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.LESS, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LESS_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.GREATER, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.GREATER_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalNot(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOGICAL_NOT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_AND, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_OR, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const program = new SelectProgram(condition.rank, a.shape, a.rank);\n const output =\n this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype));\n return this.compileAndRun(program, [condition, a, b], output);\n }\n\n where(condition: Tensor): Tensor2D {\n warn(\n 'tf.where() in webgl locks the UI thread. ' +\n 'Call tf.whereAsync() instead');\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'min', a2D.dtype).reshape(outShape);\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MIN, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MOD, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [a, b], null, customSetup);\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'max', a2D.dtype).reshape(outShape);\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MAX, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'all', a2D.dtype).reshape(outShape);\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'any', a2D.dtype).reshape(outShape);\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.SQUARED_DIFFERENCE, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.DIV;\n const outputDtype = 'float32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.INT_DIV;\n const outputDtype = 'int32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.ADD, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n addN(tensors: T[]): T {\n let res = tensors[0];\n for (let i = 1; i < tensors.length; i++) {\n res = this.add(res, tensors[i]) as T;\n }\n return res;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.SUB, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n pow(a: T, b: Tensor): T {\n const program = new BinaryOpProgram(binaryop_gpu.POW, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n const output = this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as T;\n return this.compileAndRun(program, [a, b], output, customSetup);\n }\n\n ceil(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.CEIL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n floor(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.FLOOR);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sign(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n round(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ROUND);\n return this.compileAndRun(program, [x]) as T;\n }\n\n exp(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXP);\n return this.compileAndRun(program, [x]) as T;\n }\n\n expm1(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXPM1);\n return this.compileAndRun(program, [x]) as T;\n }\n\n log(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n log1p(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG1P);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n rsqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RSQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n square(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQUARE);\n return this.compileAndRun(program, [x]) as T;\n }\n\n reciprocal(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RECIPROCAL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n relu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n elu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const program =\n new BinaryOpProgram(binaryop_gpu.ELU_DER, dy.shape, y.shape);\n return this.compileAndRun(program, [dy, y]) as T;\n }\n\n selu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n int(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TO_INT);\n const output = this.makeOutputArray(program.outputShape, 'int32');\n return this.compileAndRun(program, [x], output) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const program = new ClipProgram(x.shape, min, max);\n return this.compileAndRun(program, [x]) as T;\n }\n\n abs(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ABS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sigmoid(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGMOID);\n return this.compileAndRun(program, [x]) as T;\n }\n\n softplus(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SOFTPLUS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan2(a: T, b: T): T {\n const program = new BinaryOpProgram(binaryop_gpu.ATAN2, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]) as T;\n }\n\n sinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COSH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TANH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOSH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n atanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATANH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n erf(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ERF);\n return this.compileAndRun(program, [x]) as T;\n }\n\n step(x: T, alpha: number): T {\n const program = new UnaryOpProgram(x.shape, unary_op.STEP(alpha));\n return this.compileAndRun(program, [x]) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new Conv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'max', false);\n const output =\n this.makeOutputArray(program.outputShape, x.dtype) as Tensor4D;\n return this.compileAndRun(program, [x], output);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'avg', false);\n const output = this.makeOutputArray(program.outputShape, 'float32');\n return this.compileAndRun(program, [x], output) as Tensor4D;\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const getPositions = true;\n const maxPoolPositionsProgram =\n new Pool2DProgram(convInfo, 'max', getPositions);\n const maxPoolPositions: Tensor4D =\n this.compileAndRun(maxPoolPositionsProgram, [x]);\n\n const maxPoolBackPropProgram = new MaxPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(maxPoolBackPropProgram.outputShape, x.dtype);\n const result = this.compileAndRun(\n maxPoolBackPropProgram, [dy, maxPoolPositions], output);\n maxPoolPositions.dispose();\n return result as Tensor4D;\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const avgPoolBackpropProgram = new AvgPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(avgPoolBackpropProgram.outputShape, x.dtype);\n return this.compileAndRun(avgPoolBackpropProgram, [dy], output) as Tensor4D;\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program =\n new ResizeBilinearProgram(x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean):\n Tensor4D {\n const program = new ResizeBilinearBackpropProgram(dy, x, alignCorners);\n\n return this.compileAndRun(program, [dy]);\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program = new ResizeNearestNeighborProgram(\n x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D {\n const program =\n new ResizeNearestNeigborBackpropProgram(dy, x, alignCorners);\n return this.compileAndRun(program, [dy]);\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probs = normalized ? logits : softmax(logits);\n const batchSize = probs.shape[0];\n const numOutcomes = probs.shape[1];\n const program = new MultinomialProgram(batchSize, numOutcomes, numSamples);\n const output =\n this.makeOutputArray(program.outputShape, 'int32') as Tensor2D;\n const customSetup = program.getCustomSetupFunc(seed);\n return this.compileAndRun(program, [probs], output, customSetup);\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const program = new OneHotProgram(indices.size, depth, onValue, offValue);\n return this.compileAndRun(program, [indices]);\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n warn(\n 'tf.nonMaxSuppression() in webgl locks the UI thread. ' +\n 'Call tf.nonMaxSuppressionAsync() instead');\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private makeOutputArray(shape: number[], dtype: DataType):\n T {\n return Tensor.make(shape, {}, dtype) as T;\n }\n\n private compileAndRun(\n program: GPGPUProgram, inputs: T[], output?: K,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void,\n pageToCpu = true): K {\n if (output == null) {\n output = this.makeOutputArray(program.outputShape, inputs[0].dtype);\n }\n const inputsData: Array> = inputs.map(tensor => {\n const texData = this.texData.get(tensor.dataId);\n // Upload small tensors that live on the CPU as uniforms, not as\n // textures.\n if (texData.texture == null && tensor.size <= SIZE_UPLOAD_UNIFORM) {\n return {tensor, texData: null, isUniform: true};\n }\n this.uploadToGPU(tensor.dataId);\n return {tensor, texData, isUniform: false};\n });\n this.uploadToGPU(output.dataId);\n const outputData = {\n tensor: output,\n texData: this.texData.get(output.dataId),\n isUniform: false\n };\n const key = gpgpu_math.makeShaderKey(program, inputsData, outputData);\n const binary = this.getAndSaveBinary(key, () => {\n return gpgpu_math.compileProgram(\n this.gpgpu, program, inputsData, outputData);\n });\n const shouldTimeProgram = this.activeTimers != null;\n let query: WebGLQuery|CPUTimerQuery;\n if (shouldTimeProgram) {\n query = this.startTimer();\n }\n\n gpgpu_math.runProgram(binary, inputsData, outputData, customSetup);\n\n if (pageToCpu && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) {\n let numBytesToPage = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING;\n while (numBytesToPage > 0 && this.lruDataGPU.length > 0) {\n const dataId = this.lruDataGPU.shift();\n const {shape, dtype} = this.texData.get(dataId);\n numBytesToPage -= this.computeBytes(shape, dtype);\n this.read(dataId);\n }\n }\n\n if (shouldTimeProgram) {\n query = this.endTimer(query);\n this.activeTimers.push(this.getQueryTime(query));\n }\n return output;\n }\n\n private getAndSaveBinary(key: string, getBinary: () => GPGPUBinary):\n GPGPUBinary {\n if (!(key in this.binaryCache)) {\n this.binaryCache[key] = getBinary();\n }\n return this.binaryCache[key];\n }\n\n getTextureManager(): TextureManager {\n return this.textureManager;\n }\n\n private disposed = false;\n\n dispose() {\n if (this.disposed) {\n return;\n }\n for (const key in this.binaryCache) {\n this.gpgpu.deleteProgram(this.binaryCache[key].webGLProgram);\n }\n this.textureManager.dispose();\n this.canvas.remove();\n if (this.fromPixelsCanvas != null) {\n this.fromPixelsCanvas.remove();\n }\n if (this.gpgpuCreatedLocally) {\n this.gpgpu.dispose();\n }\n this.disposed = true;\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.texData.has(dataId)) {\n throw new Error(\n `WebGL backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n private uploadToGPU(dataId: DataId): void {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, values, texture, dtype, usage} = texData;\n if (texture != null) {\n // Array is already on GPU. No-op.\n // Touching the texture.\n const index = this.lruDataGPU.indexOf(dataId);\n if (index >= 0) {\n this.lruDataGPU.splice(this.lruDataGPU.indexOf(dataId), 1);\n this.lruDataGPU.push(dataId);\n }\n return;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n const texShape =\n webgl_util.getTextureShapeFromLogicalShape(this.gpgpu.gl, shape);\n texData.texShape = texShape;\n const newTexture = this.acquireTexture(dataId, texShape, usage);\n texData.texture = newTexture;\n if (values != null) {\n this.gpgpu.uploadMatrixToTexture(\n newTexture, texShape[0],\n // TODO(smilkov): Propagate the original typed array to gpgpu.\n texShape[1], typedArrayToFloat32(values, dtype));\n // Once uploaded, don't store the values on cpu.\n texData.values = null;\n if (shouldTimeProgram) {\n this.uploadWaitMs += performance.now() - start;\n }\n }\n }\n\n private cacheOnCPU(dataId: DataId, float32Values?: Float32Array) {\n // In delayed storage mode, when the user reads data, we don't keep a\n // copy on the gpu, to minimize likelihood of memory leak. We re-upload\n // to gpu the next time a gpgpu program needs the texture.\n const dontKeepCopyOnGPU = this.delayedStorage;\n const texData = this.texData.get(dataId);\n const {texture, texShape, dtype, usage} = texData;\n if (dontKeepCopyOnGPU && texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n if (float32Values != null) {\n texData.values = float32ToTypedArray(float32Values, dtype);\n }\n }\n\n private releaseTexture(\n dataId: DataId, texture: WebGLTexture, texShape: [number, number],\n texType: TextureUsage) {\n const {shape, dtype} = this.texData.get(dataId);\n const idx = this.lruDataGPU.indexOf(dataId);\n if (idx >= 0) {\n this.lruDataGPU.splice(idx, 1);\n }\n this.numBytesInGPU -= this.computeBytes(shape, dtype);\n this.textureManager.releaseTexture(texture, texShape, texType);\n }\n\n private acquireTexture(\n dataId: DataId, texShape: [number, number],\n texType: TextureUsage): WebGLTexture {\n const {shape, dtype} = this.texData.get(dataId);\n this.lruDataGPU.push(dataId);\n this.numBytesInGPU += this.computeBytes(shape, dtype);\n return this.textureManager.acquireTexture(texShape, texType);\n }\n\n private computeBytes(shape: number[], dtype: DataType) {\n return util.sizeFromShape(shape) * util.bytesPerElement(dtype);\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n ENV.registerBackend(\n 'webgl', () => new MathBackendWebGL(), 2 /* priority */,\n setTensorTracker);\n}\n\nfunction float32ToTypedArray(\n a: Float32Array, dtype: D): DataTypeMap[D] {\n if (dtype === 'float32') {\n return a;\n } else if (dtype === 'int32' || dtype === 'bool') {\n const result = (dtype === 'int32') ? new Int32Array(a.length) :\n new Uint8Array(a.length);\n for (let i = 0; i < result.length; ++i) {\n result[i] = Math.round(a[i]);\n }\n return result;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nfunction typedArrayToFloat32(\n a: DataTypeMap[D], dtype: D): Float32Array {\n return (a instanceof Float32Array) ? a : new Float32Array(a);\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\nimport {scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes `-1 * x` element-wise.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, -2, 0], [2, 2]);\n *\n * x.neg().print(); // or tf.neg(x)\n * ```\n *\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction neg_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'neg');\n\n const grad = (dy: T) => {\n return {$x: () => dy.neg()};\n };\n return ENV.engine.runKernel(backend => backend.neg($x), {$x}, grad);\n}\n\n/**\n * Computes ceiling of input `Tensor` element-wise: `ceil(x)`\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.ceil().print(); // or tf.ceil(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction ceil_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'ceil');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.ceil($x), {$x}, grad);\n}\n\n/**\n * Computes floor of input `Tensor` element-wise: `floor(x)`.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.floor().print(); // or tf.floor(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction floor_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'floor');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.floor($x), {$x}, grad);\n}\n\n/**\n * Returns an element-wise indication of the sign of a number.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3, NaN, 0]);\n *\n * x.sign().print(); // or tf.sign(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sign_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sign');\n\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sign($x), {$x}, grad);\n}\n\n/**\n * Computes round of input `Tensor` element-wise: `round(x)`.\n * It implements banker's rounding.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.round().print(); // or tf.round(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction round_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'round');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.round($x), {$x}, grad);\n}\n\n/**\n * Computes exponential of the input `Tensor` element-wise. `e ^ x`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.exp().print(); // or tf.exp(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction exp_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'exp');\n\n const bck = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y as T)};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.exp($x)), {$x}, bck);\n}\n\n/**\n * Computes exponential of the input `Tensor` minus one element-wise.\n * `e ^ x - 1`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.expm1().print(); // or tf.expm1(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction expm1_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'expm1');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.exp())};\n };\n return ENV.engine.runKernel(backend => backend.expm1($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` element-wise: `ln(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E]);\n *\n * x.log().print(); // or tf.log(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.log($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` plus one\n * element-wise: `ln(1 + x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E - 1]);\n *\n * x.log1p().print(); // or tf.log1p(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log1p_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log1p');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.add(scalar(1)))};\n };\n return ENV.engine.runKernel(backend => backend.log1p($x), {$x}, grad);\n}\n\n/**\n * Computes square root of the input `Tensor` element-wise: `y = sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.sqrt().print(); // or tf.sqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat().sqrt().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.sqrt($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of square root of the input `Tensor` element-wise:\n * `y = 1 / sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.rsqrt().print(); // or tf.rsqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction rsqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'rsqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.pow(scalar(1.5)).mul(scalar(2))).neg()};\n };\n return ENV.engine.runKernel(backend => backend.rsqrt($x), {$x}, grad);\n}\n\n/**\n * Computes square of `x` element-wise: `x ^ 2`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.sqrt(2), -1]);\n *\n * x.square().print(); // or tf.square(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction square_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'square');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.square($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of x element-wise: `1 / x`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, 2]);\n *\n * x.reciprocal().print(); // or tf.reciprocal(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction reciprocal_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'reciprocal');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.square().neg())};\n };\n return ENV.engine.runKernel(backend => backend.reciprocal($x), {$x}, grad);\n}\n\n/**\n * Computes absolute value element-wise: `abs(x)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.abs().print(); // or tf.abs(x)\n * ```\n * @param x The input `Tensor`.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction abs_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'abs');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().step(-1))};\n };\n return ENV.engine.runKernel(backend => backend.abs($x), {$x}, grad);\n}\n\n/**\n * Clips values element-wise. `max(min(x, clipValueMax), clipValueMin)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.clipByValue(-2, 3).print(); // or tf.clipByValue(x, -2, 3)\n * ```\n * @param x The input tensor.\n * @param clipValueMin Lower-bound of range to be clipped to.\n * @param clipValueMax Upper-bound of range to be clipped to.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction clipByValue_(\n x: T|TensorLike, clipValueMin: number, clipValueMax: number): T {\n const $x = convertToTensor(x, 'x', 'clipByValue');\n util.assert(\n (clipValueMin <= clipValueMax),\n `Error in clip: min (${clipValueMin}) must be ` +\n `less than or equal to max (${clipValueMax}).`);\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.where(\n $x.greaterEqual(scalar(clipValueMin))\n .logicalAnd($x.lessEqual(scalar(clipValueMax))),\n zerosLike(dy)) as T,\n };\n };\n return ENV.engine.runKernel(\n backend => backend.clip($x, clipValueMin, clipValueMax), {$x}, grad);\n}\n\n/**\n * Computes sigmoid element-wise, `1 / (1 + exp(-x))`\n *\n * ```js\n * const x = tf.tensor1d([0, -1, 2, -3]);\n *\n * x.sigmoid().print(); // or tf.sigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sigmoid');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y.mul(scalar(1).sub(y)))};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.sigmoid($x)), {$x}, grad);\n}\n\n/**\n * Computes log sigmoid of the input `Tensor` element-wise:\n * `logSigmoid(x)`. For numerical stability, we use `-tf.softplus(-x)`.\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.logSigmoid().print(); // or tf.logSigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction logSigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logSigmoid');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.neg().sigmoid())};\n };\n return ENV.engine.runKernel(\n backend => backend.softplus($x.neg()).neg(), {$x}, grad);\n}\n\n/**\n * Computes softplus of the input `Tensor` element-wise: `log(exp(x) + 1)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.softplus().print(); // or tf.softplus(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction softplus_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'softplus');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.sigmoid())};\n };\n return ENV.engine.runKernel(backend => backend.softplus($x), {$x}, grad);\n}\n\n/**\n * Computes sin of the input Tensor element-wise: `sin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.sin().print(); // or tf.sin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sin');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cos().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sin($x), {$x}, grad);\n}\n\n/**\n * Computes cos of the input `Tensor` element-wise: `cos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.cos().print(); // or tf.cos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cos');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sin().neg().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cos($x), {$x}, grad);\n}\n\n/**\n * Computes tan of the input `Tensor` element-wise, `tan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.tan().print(); // or tf.tan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.cos().square())};\n };\n return ENV.engine.runKernel(backend => backend.tan($x), {$x}, grad);\n}\n\n/**\n * Computes asin of the input `Tensor` element-wise: `asin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asin().print(); // or tf.asin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asin');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asin($x), {$x}, grad);\n}\n\n/**\n * Computes acos of the input `Tensor` element-wise: `acos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.acos().print(); // or tf.acos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acos');\n\n const grad = (dy: T) => {\n return {\n $x: () =>\n dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T).neg()\n };\n };\n return ENV.engine.runKernel(backend => backend.acos($x), {$x}, grad);\n}\n\n/**\n * Computes atan of the input `Tensor` element-wise: `atan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.atan().print(); // or tf.atan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).add($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atan($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic sin of the input `Tensor` element-wise: `sinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.sinh().print(); // or tf.sinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sinh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cosh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sinh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic cos of the input `Tensor` element-wise: `cosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.cosh().print(); // or tf.cosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cosh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sinh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cosh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic tangent of the input `Tensor` element-wise: `tanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, 70]);\n *\n * x.tanh().print(); // or tf.tanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tanh');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => scalar(1).sub(y.square()).mulStrict(dy) as T};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.tanh($x)), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic sin of the input `Tensor` element-wise:\n * `asinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asinh().print(); // or tf.asinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asinh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).add($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asinh($x), {$x}, grad);\n}\n\n/**\n * Computes the inverse hyperbolic cos of the input `Tensor` element-wise:\n * `acosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([10, 1, 3, 5.7]);\n *\n * x.acosh().print(); // or tf.acosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acosh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict($x.toFloat().square().sub(scalar(1)).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.acosh($x), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic tan of the input `Tensor` element-wise:\n * `atanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.atanh().print(); // or tf.atanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atanh');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atanh($x), {$x}, grad);\n}\n\n/**\n * Computes gause error function of the input `Tensor` element-wise:\n * `erf(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.erf().print(); // or tf.erf(x);\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction erf_(x: T|TensorLike): T {\n let $x = convertToTensor(x, 'x', 'erf');\n util.assert(\n $x.dtype === 'int32' || $x.dtype === 'float32',\n 'Input dtype must be `int32` or `float32`.');\n\n if ($x.dtype === 'int32') {\n $x = $x.toFloat();\n }\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.mulStrict(\n scalar(2 / Math.sqrt(Math.PI)).mul($x.square().neg().exp()))\n };\n };\n return ENV.engine.runKernel(backend => backend.erf($x), {$x}, grad);\n}\n\n/**\n * Computes step of the input `Tensor` element-wise: `x > 0 ? 1 : alpha * x`\n *\n * ```js\n * const x = tf.tensor1d([0, 2, -1, -3]);\n *\n * x.step(.5).print(); // or tf.step(x, .5)\n * ```\n * @param x The input tensor.\n * @param alpha The gradient when input is negative.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction step_(x: T|TensorLike, alpha = 0.0): T {\n const $x = convertToTensor(x, 'x', 'step');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports\n // it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.step($x, alpha), {$x}, grad);\n}\n\nexport const abs = op({abs_});\nexport const acos = op({acos_});\nexport const acosh = op({acosh_});\nexport const asin = op({asin_});\nexport const asinh = op({asinh_});\nexport const atan = op({atan_});\nexport const atanh = op({atanh_});\nexport const ceil = op({ceil_});\nexport const clipByValue = op({clipByValue_});\nexport const cos = op({cos_});\nexport const cosh = op({cosh_});\nexport const erf = op({erf_});\nexport const exp = op({exp_});\nexport const expm1 = op({expm1_});\nexport const floor = op({floor_});\nexport const log = op({log_});\nexport const log1p = op({log1p_});\nexport const logSigmoid = op({logSigmoid_});\nexport const neg = op({neg_});\nexport const reciprocal = op({reciprocal_});\nexport const round = op({round_});\nexport const rsqrt = op({rsqrt_});\nexport const sigmoid = op({sigmoid_});\nexport const sign = op({sign_});\nexport const sin = op({sin_});\nexport const sinh = op({sinh_});\nexport const softplus = op({softplus_});\nexport const sqrt = op({sqrt_});\nexport const square = op({square_});\nexport const step = op({step_});\nexport const tan = op({tan_});\nexport const tanh = op({tanh_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {tile} from './array_ops';\nimport {getReductionAxes} from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {rsqrt} from './unary_ops';\n\n/**\n * Batch normalization, strictly for 2D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization2d_(\n x: Tensor2D|TensorLike, mean: Tensor2D|Tensor1D|TensorLike,\n variance: Tensor2D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor2D|Tensor1D|TensorLike,\n offset?: Tensor2D|Tensor1D|TensorLike): Tensor2D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor2D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor2D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 2,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 2 || $mean.rank === 1,\n `Error in batchNormalization2D: mean must be rank 2 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 2 || $variance.rank === 1,\n `Error in batchNormalization2D: variance must be rank 2 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 2 || $scale.rank === 1,\n `Error in batchNormalization2D: scale must be rank 2 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 2 || $offset.rank === 1,\n `Error in batchNormalization2D: offset must be rank 2 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 3D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization3d_(\n x: Tensor3D|TensorLike, mean: Tensor3D|Tensor1D|TensorLike,\n variance: Tensor3D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor3D|Tensor1D|TensorLike,\n offset?: Tensor3D|Tensor1D|TensorLike): Tensor3D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor3D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor3D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 3,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 3 || $mean.rank === 1,\n `Error in batchNormalization3D: mean must be rank 3 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 3 || $variance.rank === 1,\n `Error in batchNormalization3D: variance must be rank 3 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 3 || $scale.rank === 1,\n `Error in batchNormalization3D: scale must be rank 3 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 3 || $offset.rank === 1,\n `Error in batchNormalization3D: offset must be rank 3 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 4D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization4d_(\n x: Tensor4D|TensorLike, mean: Tensor4D|Tensor1D|TensorLike,\n variance: Tensor4D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor4D|Tensor1D|TensorLike,\n offset?: Tensor4D|Tensor1D|TensorLike): Tensor4D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor4D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor4D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 4,\n `Error in batchNormalization4D: x must be rank 4 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 4 || $mean.rank === 1,\n `Error in batchNormalization4D: mean must be rank 4 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 4 || $variance.rank === 1,\n `Error in batchNormalization4D: variance must be rank 4 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 4 || $scale.rank === 1,\n `Error in batchNormalization4D: scale must be rank 4 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 4 || $offset.rank === 1,\n `Error in batchNormalization4D: offset must be rank 4 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization.\n *\n * As described in\n * [http://arxiv.org/abs/1502.03167](http://arxiv.org/abs/1502.03167).\n *\n * Mean, variance, scale, and offset can be of two\n * shapes:\n * - The same shape as the input.\n * - In the common case, the depth dimension is the last dimension of x, so\n * the values would be an `Tensor1D` of shape [depth].\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that parameters passed are of given rank\n * - `tf.batchNormalization2d`\n * - `tf.batchNormalization3d`\n * - `tf.batchNormalization4d`\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction batchNormalization_(\n x: Tensor|Tensor1D|TensorLike, mean: Tensor|Tensor1D|TensorLike,\n variance: Tensor|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor|Tensor1D|TensorLike,\n offset?: Tensor|Tensor1D|TensorLike): Tensor {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n\n util.assert(\n $mean.rank === $variance.rank,\n 'Batch normalization gradient requires mean and variance to have ' +\n 'equal ranks.');\n util.assert(\n $offset == null || $mean.rank === $offset.rank,\n 'Batch normalization gradient requires mean and offset to have ' +\n 'equal ranks.');\n util.assert(\n $scale == null || $mean.rank === $scale.rank,\n 'Batch normalization gradient requires mean and scale to have ' +\n 'equal ranks.');\n\n let x4D: Tensor4D;\n if ($x.rank === 0 || $x.rank === 1) {\n x4D = $x.as4D(1, 1, 1, $x.size);\n } else if ($x.rank === 2) {\n x4D = $x.as4D(1, 1, $x.shape[0], $x.shape[1]);\n } else if ($x.rank === 3) {\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]) as Tensor4D;\n } else {\n x4D = $x as Tensor4D;\n }\n\n const der = (dy: Tensor) => {\n const scaleValue = $scale == null ? scalar(1) : $scale;\n const reductionAxes = getReductionAxes($mean.shape, x4D.shape);\n const tileShape: number[] = [];\n if ($mean.rank === 1) {\n for (let i = 0; i < x4D.shape.length - 1; ++i) {\n tileShape.push(x4D.shape[i]);\n }\n tileShape.push(1);\n }\n\n const xMinusMean = $x.sub($mean);\n const dyTimesScaleValue = dy.mul(scaleValue);\n const oneOverSqrtVariance = rsqrt($variance.add(scalar(varianceEpsilon)));\n const minusHalfRCube = oneOverSqrtVariance.mul(oneOverSqrtVariance)\n .mul(oneOverSqrtVariance)\n .mul(scalar(-0.5));\n const derX = () => {\n if ($mean.rank === 1) {\n return dy\n .mul(tile(\n oneOverSqrtVariance.as4D(1, 1, 1, $mean.shape[0]), tileShape))\n .mul(scaleValue)\n .reshape($x.shape);\n } else {\n return dy.mul(oneOverSqrtVariance).mul(scaleValue).reshape($x.shape);\n }\n };\n const derMean = () => {\n let meanDer = oneOverSqrtVariance.mul(scalar(-1)).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n meanDer = meanDer.sum(reductionAxes);\n }\n return meanDer.reshape($mean.shape);\n };\n const derVariance = () => {\n let varianceDer = minusHalfRCube.mul(xMinusMean).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n varianceDer = varianceDer.sum(reductionAxes);\n }\n return varianceDer.reshape($mean.shape);\n };\n const derScale = () => {\n const xMinusMean2TimesRsqrt = xMinusMean.mul(oneOverSqrtVariance);\n let scaleDer = dy.mul(xMinusMean2TimesRsqrt);\n if ($mean.rank === 1) {\n scaleDer = scaleDer.sum(reductionAxes);\n }\n return scaleDer.reshape($mean.shape);\n };\n const derOffset = () => {\n let offsetDer = dy;\n if ($mean.rank === 1) {\n offsetDer = offsetDer.sum(reductionAxes);\n }\n return offsetDer.reshape($mean.shape);\n };\n return {\n $x: derX,\n $mean: derMean,\n $variance: derVariance,\n $scale: derScale,\n $offset: derOffset\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.batchNormalization(\n x4D, batchnormReshape4D($mean), batchnormReshape4D($variance),\n varianceEpsilon, batchnormReshape4D($scale),\n batchnormReshape4D($offset)),\n {$x, $mean, $variance, $scale, $offset}, der);\n return res.reshape($x.shape);\n}\n\nfunction batchnormReshape4D(x: Tensor): Tensor4D|Tensor1D {\n if (x == null) {\n return null;\n }\n if (x.rank === 0) {\n return x.as1D();\n } else if (x.rank === 1) {\n return x as Tensor1D;\n } else if (x.rank === 2) {\n return x.as4D(1, 1, x.shape[0], x.shape[1]);\n } else if (x.rank === 3) {\n return x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n return x as Tensor4D;\n}\n\nexport const batchNormalization2d = op({batchNormalization2d_});\nexport const batchNormalization3d = op({batchNormalization3d_});\nexport const batchNormalization4d = op({batchNormalization4d_});\nexport const batchNormalization = op({batchNormalization_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport type PadInfo = {\n top: number,\n left: number,\n right: number,\n bottom: number,\n type: string\n};\n\n/**\n * Information about the forward pass of a convolution/pooling operation.\n * It includes input and output shape, strides, filter size and padding\n * information.\n */\nexport type Conv2DInfo = {\n batchSize: number,\n inHeight: number,\n inWidth: number,\n inChannels: number,\n outHeight: number,\n outWidth: number,\n outChannels: number,\n dataFormat: 'channelsFirst'|'channelsLast',\n strideHeight: number,\n strideWidth: number,\n dilationHeight: number,\n dilationWidth: number,\n filterHeight: number,\n filterWidth: number,\n padInfo: PadInfo,\n inShape: [number, number, number, number],\n outShape: [number, number, number, number],\n filterShape: [number, number, number, number]\n};\n\nexport function computePool2DInfo(\n inShape: [number, number, number, number],\n filterSize: [number, number]|number, strides: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n const [filterHeight, filterWidth] = parseTupleParam(filterSize);\n\n let filterShape: [number, number, number, number];\n if (dataFormat === 'channelsLast') {\n filterShape = [filterHeight, filterWidth, inShape[3], inShape[3]];\n } else if (dataFormat === 'channelsFirst') {\n filterShape = [filterHeight, filterWidth, inShape[1], inShape[1]];\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n const dilations = 1;\n\n return computeConv2DInfo(\n inShape, filterShape, strides, dilations, pad, roundingMode, false,\n dataFormat);\n}\n\n/**\n * Computes the information for a forward pass of a convolution/pooling\n * operation.\n */\nexport function computeConv2DInfo(\n inShape: [number, number, number, number],\n filterShape: [number, number, number, number],\n strides: number|[number, number], dilations: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n depthwise = false,\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n let [batchSize, inHeight, inWidth, inChannels] = [-1, -1, -1, -1];\n if (dataFormat === 'channelsLast') {\n [batchSize, inHeight, inWidth, inChannels] = inShape;\n } else if (dataFormat === 'channelsFirst') {\n [batchSize, inChannels, inHeight, inWidth] = inShape;\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n\n const [filterHeight, filterWidth, , filterChannels] = filterShape;\n const [strideHeight, strideWidth] = parseTupleParam(strides);\n const [dilationHeight, dilationWidth] = parseTupleParam(dilations);\n\n const effectiveFilterHeight =\n getEffectiveFilterSize(filterHeight, dilationHeight);\n const effectiveFilterWidth =\n getEffectiveFilterSize(filterWidth, dilationWidth);\n const {padInfo, outHeight, outWidth} = getPadAndOutInfo(\n pad, inHeight, inWidth, strideHeight, strideWidth, effectiveFilterHeight,\n effectiveFilterWidth, roundingMode);\n\n const outChannels = depthwise ? filterChannels * inChannels : filterChannels;\n\n let outShape: [number, number, number, number];\n if (dataFormat === 'channelsFirst') {\n outShape = [batchSize, outChannels, outHeight, outWidth];\n } else if (dataFormat === 'channelsLast') {\n outShape = [batchSize, outHeight, outWidth, outChannels];\n }\n\n return {\n batchSize,\n dataFormat,\n inHeight,\n inWidth,\n inChannels,\n outHeight,\n outWidth,\n outChannels,\n padInfo,\n strideHeight,\n strideWidth,\n filterHeight,\n filterWidth,\n dilationHeight,\n dilationWidth,\n inShape,\n outShape,\n filterShape\n };\n}\n\nfunction computeOutputShape3D(\n inShape: [number, number, number], fieldSize: number, outDepth: number,\n stride: number, zeroPad?: number,\n roundingMode?: 'floor'|'round'|'ceil'): [number, number, number] {\n if (zeroPad == null) {\n zeroPad = computeDefaultPad(inShape, fieldSize, stride);\n }\n const inputRows = inShape[0];\n const inputCols = inShape[1];\n\n const outputRows = conditionalRound(\n (inputRows - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputRows),\n `The output # of rows (${outputRows}) must be an integer. Change the ` +\n `stride and/or zero pad parameters`);\n\n const outputCols = conditionalRound(\n (inputCols - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputCols),\n `The output # of columns (${outputCols}) must be an integer. Change ` +\n `the stride and/or zero pad parameters`);\n\n return [outputRows, outputCols, outDepth];\n}\n\nexport function computeDefaultPad(\n inputShape: [number, number, number], fieldSize: number, stride: number,\n dilation = 1): number {\n const effectiveFieldSize = getEffectiveFilterSize(fieldSize, dilation);\n return Math.floor(\n (inputShape[0] * (stride - 1) - stride + effectiveFieldSize) / 2);\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\n/* See https://www.tensorflow.org/api_docs/python/tf/nn/atrous_conv2d\n * Atrous convolution is equivalent to standard convolution with upsampled\n * filters with effective_filter_height =\n * filter_height + (filter_height - 1) * (dilation - 1)\n * and effective_filter_width =\n * filter_width + (filter_width - 1) * (dilation - 1),\n * produced by inserting dilation - 1 zeros along consecutive elements across\n * the filters' spatial dimensions.\n * When there is a dilation, this converts a filter dimension to the\n * effective filter dimension, so it can be used in a standard convolution.\n */\nfunction getEffectiveFilterSize(filterSize: number, dilation: number) {\n if (dilation <= 1) {\n return filterSize;\n }\n\n return filterSize + (filterSize - 1) * (dilation - 1);\n}\n\nfunction getPadAndOutInfo(\n pad: 'same'|'valid'|number, inHeight: number, inWidth: number,\n strideHeight: number, strideWidth: number, filterHeight: number,\n filterWidth: number, roundingMode?: 'floor'|'round'|'ceil'):\n {padInfo: PadInfo, outHeight: number, outWidth: number} {\n let padInfo: PadInfo;\n let outHeight: number;\n let outWidth: number;\n\n if (typeof pad === 'number') {\n const padType = (pad === 0) ? 'VALID' : 'NUMBER';\n padInfo = {top: pad, bottom: pad, left: pad, right: pad, type: padType};\n const outShape = computeOutputShape3D(\n [inHeight, inWidth, 1], filterHeight, 1, strideHeight, pad,\n roundingMode);\n outHeight = outShape[0];\n outWidth = outShape[1];\n } else if (pad === 'same') {\n outHeight = Math.ceil(inHeight / strideHeight);\n outWidth = Math.ceil(inWidth / strideWidth);\n const padAlongHeight =\n (outHeight - 1) * strideHeight + filterHeight - inHeight;\n const padAlongWidth = (outWidth - 1) * strideWidth + filterWidth - inWidth;\n const top = Math.floor(padAlongHeight / 2);\n const bottom = padAlongHeight - top;\n const left = Math.floor(padAlongWidth / 2);\n const right = padAlongWidth - left;\n padInfo = {top, bottom, left, right, type: 'SAME'};\n } else if (pad === 'valid') {\n padInfo = {top: 0, bottom: 0, left: 0, right: 0, type: 'VALID'};\n outHeight = Math.ceil((inHeight - filterHeight + 1) / strideHeight);\n outWidth = Math.ceil((inWidth - filterWidth + 1) / strideWidth);\n } else {\n throw Error(`Unknown padding parameter: ${pad}`);\n }\n return {padInfo, outHeight, outWidth};\n}\n\n/**\n * Rounds a value depending on the rounding mode\n * @param value\n * @param roundingMode\n */\nfunction conditionalRound(\n value: number, roundingMode?: 'floor'|'round'|'ceil') {\n if (!roundingMode) {\n return value;\n }\n switch (roundingMode) {\n case 'round':\n // used for Caffe Conv\n return Math.round(value);\n case 'ceil':\n // used for Caffe Pool\n return Math.ceil(value);\n case 'floor':\n return Math.floor(value);\n default:\n throw new Error(`Unknown roundingMode ${roundingMode}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes a 1D convolution over the input x.\n *\n * @param x The input tensor, of rank 3 or rank 2, of shape\n * `[batch, width, inChannels]`. If rank 2, batch of 1 is assumed.\n * @param filter The filter, rank 3, of shape\n * `[filterWidth, inDepth, outDepth]`.\n * @param stride The number of entries by which the filter is moved right at\n * each step.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat An optional string from \"NWC\", \"NCW\". Defaults to \"NWC\",\n * the data is stored in the order of [batch, in_width, in_channels]. Only\n * \"NWC\" is currently supported.\n * @param dilation The dilation rate in which we sample input values in\n * atrous convolution. Defaults to `1`. If it is greater than 1, then\n * stride must be `1`.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv1d_(\n x: T|TensorLike, filter: Tensor3D|TensorLike, stride: number,\n pad: 'valid'|'same'|number, dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv1d');\n const $filter = convertToTensor(filter, 'filter', 'conv1d');\n\n let x3D = $x as Tensor3D;\n let reshapedTo3D = false;\n if ($x.rank === 2) {\n reshapedTo3D = true;\n x3D = $x.as3D(1, $x.shape[0], $x.shape[1]);\n }\n\n util.assert(\n x3D.rank === 3,\n `Error in conv1d: input must be rank 3, but got rank ${x3D.rank}.`);\n util.assert(\n $filter.rank === 3,\n `Error in conv1d: filter must be rank 3, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv1d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x3D.shape[2] === $filter.shape[1],\n `Error in conv1d: depth of input (${x3D.shape[2]}) must match ` +\n `input depth for filter ${$filter.shape[1]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(stride, dilation),\n 'Error in conv1D: Either stride or dilation must be 1. ' +\n `Got stride ${stride} and dilation '${dilation}'`);\n util.assert(\n dataFormat === 'NWC',\n `Error in conv1d: got dataFormat of ${\n dataFormat} but only NWC is currently supported.`);\n\n const filter4D =\n $filter.as4D(1, $filter.shape[0], $filter.shape[1], $filter.shape[2]);\n const input4D = x3D.as4D(x3D.shape[0], 1, x3D.shape[1], x3D.shape[2]);\n const strides: [number, number] = [1, stride];\n const dilations: [number, number] = [1, dilation];\n\n const conv2dDataFormat = 'NHWC';\n\n const res = conv2d(\n input4D, filter4D, strides, pad, conv2dDataFormat, dilations,\n dimRoundingMode);\n\n if (reshapedTo3D) {\n return res.as2D(res.shape[2], res.shape[3]) as T;\n }\n return res.as3D(res.shape[0], res.shape[2], res.shape[3]) as T;\n}\n\n/**\n * Computes a 2D convolution over the input x.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `dilations` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2d');\n const $filter = convertToTensor(filter, 'filter', 'conv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2d: input must be rank 4, but got rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in conv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in conv2d: depth of input (${x4D.shape[3]}) must match ` +\n `input depth for filter ${$filter.shape[2]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in conv2D: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n util.assert(\n dataFormat === 'NHWC',\n `Error in conv2d: got dataFormat of ${\n dataFormat} but only NHWC is currently supported.`);\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of conv2D: dilation rates greater than 1 are not' +\n `yet supported in gradients. Got dilations '${dilations}'`);\n\n return {\n x: () => conv2dDerInput_(x4D.shape, dy, $filter, strides, pad),\n $filter: () => conv2dDerFilter_(x4D, dy, $filter.shape, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.conv2d(x4D, $filter, convInfo), {x: x4D, $filter},\n grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the input of a 2D convolution.\n *\n * @param xShape The shape of the input: [batch, height, width, inDepth].\n * If length of 3, batch of 1 is assumed.\n * @param dy The derivative of the output, of rank 4 or rank 3 of shape\n * `[batch, outHeight, outWidth, outDepth]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm used:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\nfunction conv2dDerInput_(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n util.assert(\n xShape.length === dy.rank,\n `Length of inShape ` +\n `(${xShape.length}) and rank of dy (${dy.rank}) must match`);\n\n let xShape4D = xShape as [number, number, number, number];\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n xShape4D = [1, xShape[0], xShape[1], xShape[2]];\n }\n\n const inDepth = xShape4D[3];\n const outDepth = dy4D.shape[3];\n util.assert(\n xShape4D.length === 4,\n `Error in conv2dDerInput: inShape must be length 4, but got length ` +\n `${xShape4D.length}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerInput: dy must be rank 4, but got ` +\n `rank ${dy4D.rank}`);\n util.assert(\n filter.rank === 4,\n `Error in conv2dDerInput: filter must be rank 4, but got ` +\n `rank ${filter.rank}`);\n util.assert(\n inDepth === filter.shape[2],\n `Error in conv2dDerInput: depth of input (${inDepth}) must ` +\n `match input depth for filter ${filter.shape[2]}.`);\n util.assert(\n outDepth === filter.shape[3],\n `Error in conv2dDerInput: depth of output (${outDepth}) must ` +\n `match output depth for filter ${filter.shape[3]}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerInput: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n xShape4D, filter.shape, strides, dilations, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.conv2dDerInput(dy4D, filter, convInfo), {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the filter of a 2D convolution.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * [batch, height, width, inChannels]. If rank 3, batch of 1 is assumed.\n * @param dy The dy image, of rank 4 or rank 3, of shape\n * [batch, height, width, outDepth]. If rank 3, batch of 1 is assumed.\n * @param filterShape The shape of the filter, length 4,\n * [filterHeight, filterWidth, inDepth, outDepth].\n * @param strides The strides of the convolution: [strideHeight,\n * strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction conv2dDerFilter_(\n x: T, dy: T, filterShape: [number, number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2dDerFilter: input must be rank 4, but got shape ` +\n `${x4D.shape}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerFilter: dy must be rank 4, but got shape ` +\n `${dy4D.shape}.`);\n util.assert(\n filterShape.length === 4,\n `Error in conv2dDerFilter: filterShape must be length 4, but got ` +\n `${filterShape}.`);\n util.assert(\n x4D.shape[3] === filterShape[2],\n `Error in conv2dDerFilter: depth of input ${x4D.shape[3]}) must ` +\n `match input depth in filter (${filterShape[2]}.`);\n util.assert(\n dy4D.shape[3] === filterShape[3],\n `Error in conv2dDerFilter: depth of dy (${dy4D.shape[3]}) must ` +\n `match output depth for filter (${filterShape[3]}).`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerFilter: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, filterShape, strides, dilations, pad, dimRoundingMode);\n return ENV.engine.runKernel(\n backend => backend.conv2dDerFilter(x4D, dy4D, convInfo), {x4D, dy4D});\n}\n\n/**\n * Computes the transposed 2D convolution of an image, also known as a\n * deconvolution.\n *\n * @param x The input image, of rank 4 or rank 3, of shape\n * `[batch, height, width, inDepth]`. If rank 3, batch of 1 is assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, outDepth, inDepth]`.\n * `inDepth` must match `inDepth` in `x`.\n * @param outputShape Output shape, of rank 4 or rank 3:\n * `[batch, height, width, outDepth]`. If rank 3, batch of 1 is assumed.\n * @param strides The strides of the original convolution:\n * `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm used in the non-transpose version\n * of the op.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2dTranspose_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2dTranspose');\n const $filter = convertToTensor(filter, 'filter', 'conv2dTranspose');\n\n return conv2dDerInput_(\n outputShape, $x, $filter, strides, pad, dimRoundingMode);\n}\n\n/**\n * Depthwise 2D convolution.\n *\n * Given a 4D `input` array and a `filter` array of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]` containing\n * `inChannels` convolutional filters of depth 1, this op applies a\n * different filter to each input channel (expanding from 1 channel to\n * `channelMultiplier` channels for each), then concatenates the results\n * together. The output has `inChannels * channelMultiplier` channels.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction depthwiseConv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'depthwiseConv2d');\n const $filter = convertToTensor(filter, 'filter', 'depthwiseConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in depthwiseConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in depthwiseConv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in depthwiseConv2d: number of input channels ` +\n `(${x4D.shape[3]}) must match the inChannels dimension in ` +\n `filter ${$filter.shape[2]}.`);\n if (dilations == null) {\n dilations = [1, 1];\n }\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in depthwiseConv2d: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in depthwiseConv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode,\n true /* depthwise */);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of depthwiseConv2d: dilation rates greater than ' +\n `1 are not yet supported. Got dilations '${dilations}'`);\n return {\n x: () => depthwiseConv2dDerInput(x4D.shape, dy, $filter, convInfo),\n $filter: () => depthwiseConv2dDerFilter(x4D, dy, $filter.shape, convInfo),\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2D(x4D, $filter, convInfo),\n {x: x4D, $filter}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * 2-D convolution with separable filters.\n *\n * Performs a depthwise convolution that acts separately on channels followed\n * by a pointwise convolution that mixes channels. Note that this is\n * separability between dimensions [1, 2] and 3, not spatial separability\n * between dimensions 1 and 2.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param depthwiseFilter The depthwise filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`. This is\n * the filter used in the first step.\n * @param pointwiseFilter The pointwise filter tensor, rank 4, of shape\n * `[1, 1, inChannels * channelMultiplier, outChannels]`. This is\n * the filter used in the second step.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction separableConv2d_(\n x: T|TensorLike, depthwiseFilter: Tensor4D|TensorLike,\n pointwiseFilter: Tensor4D|TensorLike, strides: [number, number]|number,\n pad: 'valid'|'same', dilation: [number, number]|number = [1, 1],\n dataFormat: 'NHWC'|'NCHW' = 'NHWC'): T {\n const $x = convertToTensor(x, 'x', 'separableConv2d');\n const $depthwiseFilter =\n convertToTensor(depthwiseFilter, 'depthwiseFilter', 'separableConv2d');\n const $pointwiseFilter =\n convertToTensor(pointwiseFilter, 'pointwiseFilter', 'separableConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n\n if (dataFormat === 'NCHW') {\n throw new Error(\n 'separableConv2d currently does not support dataFormat NCHW; only ' +\n 'NHWC is supported');\n }\n\n util.assert(\n x4D.rank === 4,\n `Error in separableConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $depthwiseFilter.rank === 4,\n `Error in separableConv2d: depthwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.rank === 4,\n `Error in separableConv2d: pointwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.shape[0] === 1,\n `Error in separableConv2d: the first dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[0]}.`);\n util.assert(\n $pointwiseFilter.shape[1] === 1,\n `Error in separableConv2d: the second dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[1]}.`);\n\n const inChannels = $depthwiseFilter.shape[2];\n const channelMultiplier = $depthwiseFilter.shape[3];\n util.assert(\n $pointwiseFilter.shape[2] === inChannels * channelMultiplier,\n `Error in separableConv2d: the third dimension of pointwise filter ` +\n `must be ${inChannels * channelMultiplier}, ` +\n `but got ${$pointwiseFilter.shape[2]}.`);\n\n const depthwise = depthwiseConv2d(\n x4D, $depthwiseFilter, strides, pad, dataFormat, dilation);\n const pointwiseStride = 1;\n const res =\n conv2d(depthwise, $pointwiseFilter, pointwiseStride, 'valid', dataFormat);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\nfunction tupleValuesAreOne(param: number|[number, number]): boolean {\n const [dimA, dimB] = parseTupleParam(param);\n return dimA === 1 && dimB === 1;\n}\n\nfunction eitherStridesOrDilationsAreOne(\n strides: number|[number, number],\n dilations: number|[number, number]): boolean {\n return tupleValuesAreOne(strides) || tupleValuesAreOne(dilations);\n}\n\nfunction depthwiseConv2dDerInput(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, convInfo: conv_util.Conv2DInfo): T {\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerInput(dy4D, filter, convInfo),\n {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction depthwiseConv2dDerFilter(\n x: T, dy: T, filterShape: [number, number, number, number],\n convInfo: conv_util.Conv2DInfo): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n return ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerFilter(x4D, dy4D, convInfo),\n {x4D, dy4D});\n}\n\nexport const conv1d = op({conv1d_});\nexport const conv2d = op({conv2d_});\nexport const depthwiseConv2d = op({depthwiseConv2d_});\nexport const separableConv2d = op({separableConv2d_});\nexport const conv2dTranspose = op({conv2dTranspose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Computes the dot product of two matrices, A * B. These must be matrices.\n *\n * ```js\n * const a = tf.tensor2d([1, 2], [1, 2]);\n * const b = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.matMul(b).print(); // or tf.matMul(a, b)\n * ```\n * @param a First matrix in dot product operation.\n * @param b Second matrix in dot product operation.\n * @param transposeA If true, `a` is transposed before multiplication.\n * @param transposeB If true, `b` is transposed before multiplication.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction matMul_(\n a: Tensor2D|TensorLike, b: Tensor2D|TensorLike, transposeA = false,\n transposeB = false): Tensor2D {\n const $a = convertToTensor(a, 'a', 'matMul');\n const $b = convertToTensor(b, 'b', 'matMul');\n\n const innerShapeA = transposeA ? $a.shape[0] : $a.shape[1];\n const innerShapeB = transposeB ? $b.shape[1] : $b.shape[0];\n\n util.assert(\n $a.rank === 2 && $b.rank === 2,\n `Error in matMul: inputs must be rank 2, got ranks ${$a.rank}` +\n ` and ${$b.rank}.`);\n\n util.assert(\n innerShapeA === innerShapeB,\n `Error in matMul: inner shapes (${innerShapeA}) and (` +\n `${innerShapeB}) of Tensors with shapes ${$a.shape} and ` +\n `${$b.shape} and transposeA=${transposeA}` +\n ` and transposeB=${transposeB} must match.`);\n\n const grad = (dy: Tensor2D) => {\n if (!transposeA && !transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, true),\n $b: () => $a.toFloat().matMul(dy, true, false)\n };\n } else if (!transposeA && transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, false),\n $b: () => dy.matMul($a.toFloat(), true, false)\n };\n } else if (transposeA && !transposeB) {\n return {\n $a: () => $b.toFloat().matMul(dy, false, true),\n $b: () => $a.toFloat().matMul(dy, false, false)\n };\n } else {\n return {\n $a: () => $b.toFloat().matMul(dy, true, true),\n $b: () => dy.matMul($a.toFloat(), true, true)\n };\n }\n };\n return ENV.engine.runKernel(\n backend => backend.matMul($a, $b, transposeA, transposeB), {$a, $b},\n grad);\n}\n\n/**\n * Computes the outer product of two vectors, v1 and v2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([3, 4, 5]);\n *\n * tf.outerProduct(a, b).print();\n * ```\n * @param v1 The first vector in the outer product operation.\n * @param v2 The second vector in the dot product operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction outerProduct_(\n v1: Tensor1D|TensorLike, v2: Tensor1D|TensorLike): Tensor2D {\n const $v1 = convertToTensor(v1, 'v1', 'outerProduct');\n const $v2 = convertToTensor(v2, 'v2', 'outerProduct');\n\n util.assert(\n $v1.rank === 1 && $v2.rank === 1,\n `Error in outerProduct: inputs must be rank 1, but got ranks ` +\n `${$v1.rank} and ${$v2.rank}.`);\n\n return $v1.as2D(-1, 1).matMul($v2.as2D(1, -1));\n}\n\n/**\n * Computes the dot product of two matrices and/or vectors, t1 and t2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor2d([[1, 2], [3, 4]]);\n * const c = tf.tensor2d([[1, 2, 3], [4, 5, 6]]);\n *\n * a.dot(b).print(); // or tf.dot(a, b)\n * b.dot(a).print();\n * b.dot(c).print();\n * ```\n * @param t1 The first tensor in the dot operation.\n * @param t2 The second tensor in the dot operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction dot_(t1: Tensor|TensorLike, t2: Tensor|TensorLike): Tensor {\n const $t1 = convertToTensor(t1, 't1', 'dot');\n const $t2 = convertToTensor(t2, 't2', 'dot');\n util.assert(\n ($t1.rank === 1 || $t1.rank === 2) && ($t2.rank === 1 || $t2.rank === 2),\n `Error in dot: inputs must all be rank 1 or 2, but got ranks ` +\n `${$t1.rank} and ${$t2.rank}.`);\n\n const t1Inner = ($t1.rank === 1 ? $t1.size : $t1.shape[1]);\n const t2Inner = ($t2.rank === 1 ? $t2.size : $t2.shape[0]);\n\n util.assert(\n t1Inner === t2Inner,\n `Error in dot: inner dimensions of inputs must match, but got ` +\n `${t1Inner} and ${t2Inner}.`);\n\n if ($t1.rank === 1 && $t2.rank === 1) {\n return $t1.as2D(1, -1).matMul($t2.as2D(-1, 1)).asScalar();\n } else if ($t1.rank === 1 && $t2.rank === 2) {\n return $t1.as2D(1, -1).matMul($t2.as2D($t2.shape[0], $t2.shape[1])).as1D();\n } else if ($t1.rank === 2 && $t2.rank === 1) {\n return $t1.matMul($t2.as2D(-1, 1)).as1D();\n } else {\n return $t1.matMul($t2.as2D($t2.shape[0], $t2.shape[1]));\n }\n}\n\nexport const matMul = op({matMul_});\nexport const dot = op({dot_});\nexport const outerProduct = op({outerProduct_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {parseAxisParam} from './axis_util';\nimport {op} from './operation';\n\n/**\n * Reverses a `Tensor1D`.\n *\n * @param x The input tensor.\n */\nfunction reverse1d_(x: Tensor1D|TensorLike): Tensor1D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 1, `Error in reverse1D: x must be rank 1 but got\n rank ${$x.rank}.`);\n return reverse($x, 0);\n}\n\n/**\n * Reverses a `Tensor2D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse2d_(x: Tensor2D|TensorLike, axis?: number|number[]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 2, `Error in reverse2D: x must be rank 2 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor3D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse3d_(x: Tensor3D|TensorLike, axis?: number|number[]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 3, `Error in reverse3D: x must be rank 3 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor4D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse4d_(x: Tensor4D|TensorLike, axis?: number|number[]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 4, `Error in reverse4D: x must be rank 4 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor` along a specified axis.\n *\n * Also available are stricter rank-specific methods that assert that `x` is\n * of the given rank:\n * - `tf.reverse1d`\n * - `tf.reverse2d`\n * - `tf.reverse3d`\n * - `tf.reverse4d`\n *\n * Except `tf.reverse1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.reverse().print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.reverse(axis).print();\n * ```\n * @param x The input tensor to be reversed.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction reverse_(\n x: T|TensorLike, axis?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'reverse');\n\n if ($x.rank === 0) {\n return $x.clone();\n }\n const axes = parseAxisParam(axis, $x.shape);\n const grad = (dy: T) => {\n return {$x: () => dy.reverse(axes)};\n };\n const res =\n ENV.engine.runKernel(backend => backend.reverse($x, axes), {$x}, grad);\n return res.reshapeAs($x);\n}\n\nexport const reverse = op({reverse_});\nexport const reverse1d = op({reverse1d_});\nexport const reverse2d = op({reverse2d_});\nexport const reverse3d = op({reverse3d_});\nexport const reverse4d = op({reverse4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes the 2D max pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction maxPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'maxPool');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in maxPool: input must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n const convInfo = conv_util.computePool2DInfo(\n x4D.shape, filterSize, strides, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D, saved: Tensor[]) => {\n const [y4D] = saved;\n return {\n x: () =>\n maxPoolBackprop(dy, x4D, y4D as Tensor4D, filterSize, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.maxPool(x4D, convInfo)), {x: x4D}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the 2D average pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction avgPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'avgPool');\n util.assert(\n $x.dtype === 'float32', 'The input dtype to avgPool must be float32');\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in avgPool: x must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in avgPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo =\n conv_util.computePool2DInfo(x4D.shape, filterSize, strides, pad);\n\n const grad = (dy: Tensor4D) => {\n return {x: () => avgPoolBackprop(dy, x4D, filterSize, strides, pad)};\n };\n let res = ENV.engine.runKernel(\n backend => backend.avgPool(x4D, convInfo), {x: x4D}, grad);\n res = res.cast($x.dtype);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the backprop of a max pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The original input image, of rank 4, of shape\n * [batchSize, height, width, channels].\n * @param output The original output image, of rank 4, of shape\n * [batchSize, outHeight, outWidth, channels].\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction maxPoolBackprop(\n dy: Tensor4D|TensorLike, input: Tensor4D|TensorLike,\n output: Tensor4D|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n const $dy = convertToTensor(dy, 'dy', 'maxPoolBackprop');\n const $input = convertToTensor(input, 'input', 'maxPoolBackprop');\n const $output = convertToTensor(output, 'output', 'maxPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n util.assert(\n $dy.rank === 4,\n `Error in maxPoolBackprop: dy must be rank 4 but got rank ` +\n `${$dy.rank}.`);\n util.assert(\n $input.rank === 4,\n `Error in maxPoolBackprop: input must be rank 4 but got rank ` +\n `${$input.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPoolBackprop: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computePool2DInfo(\n $input.shape, filterSize, strides, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.maxPoolBackprop($dy, $input, $output, convInfo),\n {$dy, $input});\n return res;\n}\n\n/**\n * Computes the backprop of an avg pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The input image, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n */\nfunction avgPoolBackprop(\n dy: T|TensorLike, input: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number): T {\n const $dy = convertToTensor(dy, 'dy', 'avgPoolBackprop');\n const $input = convertToTensor(input, 'input', 'avgPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n let input4D = $input as Tensor4D;\n let dy4D = $dy as Tensor4D;\n let reshapedTo4D = false;\n if ($input.rank === 3) {\n reshapedTo4D = true;\n input4D = $input.as4D(1, $input.shape[0], $input.shape[1], $input.shape[2]);\n dy4D = $dy.as4D(1, $dy.shape[0], $dy.shape[1], $dy.shape[2]);\n }\n\n util.assert(\n dy4D.rank === 4,\n `Error in avgPoolBackprop: dy must be rank 4 but got rank ` +\n `${dy4D.rank}.`);\n util.assert(\n input4D.rank === 4,\n `Error in avgPoolBackprop: input must be rank 4 but got rank ` +\n `${input4D.rank}.`);\n\n const convInfo =\n conv_util.computePool2DInfo(input4D.shape, filterSize, strides, pad);\n const res = ENV.engine.runKernel(\n backend => backend.avgPoolBackprop(dy4D, input4D, convInfo),\n {dy4D, input4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nexport const maxPool = op({maxPool_});\nexport const avgPool = op({avgPool_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\nimport * as slice_util from './slice_util';\n\n/**\n * Extracts a 1D slice from 1D array starting at coordinates `begin` and is\n * of length `size`. See `slice` for details.\n */\nfunction slice1d_(\n x: Tensor1D|TensorLike, begin: number, size: number): Tensor1D {\n const $x = convertToTensor(x, 'x', 'slice1d');\n util.assert(\n $x.rank === 1,\n `slice1d expects a rank-1 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, [begin], [size]);\n}\n\n/**\n * Extracts a 2D slice from a 2D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice2d_(\n x: Tensor2D|TensorLike, begin: [number, number],\n size: [number, number]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'slice2d');\n util.assert(\n $x.rank === 2,\n `slice1d expects a rank-2 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 3D slice from a 3D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice3d_(\n x: Tensor3D|TensorLike, begin: [number, number, number],\n size: [number, number, number]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'slice3d');\n util.assert(\n $x.rank === 3,\n `slice1d expects a rank-3 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 4D slice from a 4D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice4d_(\n x: Tensor4D|TensorLike, begin: [number, number, number, number],\n size: [number, number, number, number]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'slice4d');\n util.assert(\n $x.rank === 4,\n `slice1d expects a rank-4 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a slice from a `Tensor` starting at coordinates `begin`\n * and is of size `size`.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `x` is of the given rank:\n * - `tf.slice1d`\n * - `tf.slice2d`\n * - `tf.slice3d`\n * - `tf.slice4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.slice([1], [2]).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * x.slice([1, 0], [1, 2]).print();\n * ```\n * @param x The input `Tensor` to slice from.\n * @param begin The coordinates to start the slice from. The length can be\n * less than the rank of x - the rest of the axes will have implicit 0 as\n * start. Can also be a single number, in which case it specifies the\n * first axis.\n * @param size The size of the slice. The length can be less than the rank of\n * x - the rest of the axes will have implicit -1. A value of -1 requests\n * the rest of the dimensions in the axis. Can also be a single number,\n * in which case it specifies the size of the first axis.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction slice_>(\n x: T|TensorLike, begin: number|number[], size?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'slice');\n\n if ($x.rank === 0) {\n throw new Error('Slicing scalar is not possible');\n }\n // The following logic allows for more ergonomic calls.\n let begin_: number[];\n if (typeof begin === 'number') {\n begin_ = [begin, ...new Array($x.rank - 1).fill(0)];\n } else if (begin.length < $x.rank) {\n begin_ = begin.concat(new Array($x.rank - begin.length).fill(0));\n } else {\n begin_ = begin;\n }\n let size_: number[];\n if (size == null) {\n size_ = new Array($x.rank).fill(-1);\n } else if (typeof size === 'number') {\n size_ = [size, ...new Array($x.rank - 1).fill(-1)];\n } else if (size.length < $x.rank) {\n size_ = size.concat(new Array($x.rank - size.length).fill(-1));\n } else {\n size_ = size;\n }\n size_ = size_.map((d, i) => {\n if (d >= 0) {\n return d;\n } else {\n util.assert(d === -1, 'Bad value in size');\n return $x.shape[i] - begin_[i];\n }\n });\n slice_util.assertParamsValid($x, begin_, size_);\n const inputShape = $x.shape;\n const grad = (dy: T) => {\n // Create an Nx2 padding where the first column represents how many\n // zeros are prepended (at start) for each dimension, and the second\n // column indicates how many zeros are appended (at end).\n\n // The number of zeros to append is the shape of the input\n // elementwise-subtracted by both the begin vector and sizes vector.\n const paddings: Array<[number, number]> = [];\n for (let i = 0; i < dy.rank; i++) {\n paddings.push([begin_[i], inputShape[i] - begin_[i] - size_[i]]);\n }\n return {$x: () => dy.pad(paddings)};\n };\n return ENV.engine.runKernel(\n backend => backend.slice($x, begin_, size_), {$x}, grad) as T;\n}\n\nexport const slice = op({slice_});\nexport const slice1d = op({slice1d_});\nexport const slice2d = op({slice2d_});\nexport const slice3d = op({slice3d_});\nexport const slice4d = op({slice4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Environment} from './environment';\nexport {customGrad, grad, grads, valueAndGrad, valueAndGrads, variableGrads} from './gradients';\n\nexport const tidy = Environment.tidy;\nexport const keep = Environment.keep;\nexport const dispose = Environment.dispose;\nexport const time = Environment.time;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\n/**\n * Computes the log(sum(exp(elements across the reduction dimensions)).\n *\n * Reduces the input along the dimensions given in `axis`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.logSumExp().print(); // or tf.logSumExp(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.logSumExp(axis).print(); // or tf.logSumExp(a, axis)\n * ```\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. If null (the default),\n * reduces all dimensions.\n * @param keepDims If true, retains reduced dimensions with length\n * of 1. Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction logSumExp_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'logSumExp');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const xMax = $x.max(axes, true /* keepDims */);\n const a = $x.sub(xMax);\n const b = a.exp();\n const c = b.sum(axes);\n const d = c.log();\n const res = xMax.reshape(d.shape).add(d);\n\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, axes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the sum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If axes has no entries, all dimensions are reduced, and a `Tensor` with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.sum().print(); // or tf.sum(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.sum(axis).print(); // or tf.sum(x, axis)\n * ```\n *\n * @param x The input tensor to compute the sum over. If the dtype is `bool`\n * it will be converted to `int32` and the output dtype will be `int32`.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction sum_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'sum');\n\n if ($x.dtype === 'bool') {\n $x = $x.toInt();\n }\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n\n // Use a custom gradient to bypass 2 gradient backprops since sum is used\n // extremely often.\n const customOp = customGrad(x => {\n const permutation = axis_util.getAxesPermutation(axes, x.rank);\n let reductionAxes = axes;\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n reductionAxes = axis_util.getInnerMostAxes(reductionAxes.length, x.rank);\n }\n let value = ENV.engine.runKernel(\n backend => backend.sum(permutedX, reductionAxes), {permutedX});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(value.shape, axes);\n value = value.reshape(newShape);\n }\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX = expandedDy.mul(ones(x.shape, 'float32'));\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the mean of elements across dimensions of a `Tensor`.\n *\n * Reduces `x` along the dimensions given in `axis`. Unless `keepDims` is\n * true, the rank of the `Tensor` is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and a `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.mean().print(); // or tf.mean(a)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.mean(axis).print(); // or tf.mean(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction mean_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'mean');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const shapes = axis_util.computeOutAndReduceShapes($x.shape, axes);\n const reduceShape = shapes[1];\n const reduceSize = util.sizeFromShape(reduceShape);\n\n // Use a custom gradient to bypass 2 gradient backprops since mean is used\n // extremely often.\n const customOp = customGrad(x => {\n const reduceSizeScalar = scalar(reduceSize);\n // Cast if needed.\n const xReduce =\n reduceSizeScalar.dtype === x.dtype ? x : x.cast(reduceSizeScalar.dtype);\n const res = xReduce.div(reduceSizeScalar);\n const value = res.sum(axis, keepDims);\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX =\n expandedDy.mul(ones(x.shape, 'float32')).div(reduceSizeScalar);\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the minimum value from the input.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.min().print(); // or tf.min(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.min(axis).print(); // or tf.min(x, axis)\n * ```\n *\n * @param x The input Tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction min_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'min');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.min($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the maximum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.max().print(); // or tf.max(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.max(axis).print(); // or tf.max(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction max_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'max');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.max($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Returns the indices of the minimum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMin().print(); // or tf.argMin(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMin(axis).print(); // or tf.argMin(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMin_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMin');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMin($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Returns the indices of the maximum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMax().print(); // or tf.argMax(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMax(axis).print(); // or tf.argMax(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMax_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMax');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMax($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Computes the logical and of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.all().print(); // or tf.all(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.all(axis).print(); // or tf.all(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction all_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'all', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.all($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the logical or of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.any().print(); // or tf.any(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.any(axis).print(); // or tf.any(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction any_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'any', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.any($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Calculates the mean and variance of `x`. The mean and variance are\n * calculated by aggregating the contents of `x` across `axes`. If `x` is\n * 1-D and `axes = [0]` this is just the mean and variance of a vector.\n *\n * @param x The input tensor.\n * @param axis The dimension(s) along with to compute mean and\n * variance. By default it reduces all dimensions.\n * @param keepDims If true, the moments have the same dimensionality as the\n * input.\n * @return An object with two keys: `mean` and `variance`.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction moments_(\n x: Tensor|TensorLike, axis: number|number[] = null,\n keepDims = false): {mean: Tensor, variance: Tensor} {\n x = convertToTensor(x, 'x', 'moments');\n const axes = axis_util.parseAxisParam(axis, x.shape);\n const mean = x.mean(axes, keepDims);\n let keepDimsShape = mean.shape;\n if (!keepDims) {\n keepDimsShape = axis_util.expandShapeToKeepDim(mean.shape, axes);\n }\n const devSquared = x.toFloat().sub(mean.reshape(keepDimsShape)).square();\n const variance = devSquared.mean(axes, keepDims);\n return {mean, variance};\n}\n\nexport const all = op({all_});\n// tslint:disable-next-line:variable-name\nexport const any = op({any_});\nexport const argMax = op({argMax_});\nexport const argMin = op({argMin_});\nexport const logSumExp = op({logSumExp_});\nexport const max = op({max_});\nexport const mean = op({mean_});\nexport const min = op({min_});\nexport const moments = op({moments_});\nexport const sum = op({sum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\n\n/**\n * Returns the truth value of (a != b) element-wise. Supports broadcasting.\n *\n * We also expose `notEqualStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([0, 2, 3]);\n *\n * a.notEqual(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction notEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqual');\n const $b = convertToTensor(b, 'b', 'notEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n return ENV.engine.runKernel(backend => backend.notEqual($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Strict version of `notEqual` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction notEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqualStrict');\n const $b = convertToTensor(b, 'b', 'notEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in notEqualStrict: ');\n return $a.notEqual($b);\n}\n\n/**\n * Returns the truth value of (a < b) element-wise. Supports broadcasting.\n *\n * We also expose `lessStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.less(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction less_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'less');\n const $b = convertToTensor(b, 'b', 'less');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.less($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Strict version of `less` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction lessStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessStrict');\n const $b = convertToTensor(b, 'b', 'lessStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessStrict: ');\n return $a.less($b);\n}\n\n/**\n * Returns the truth value of (a == b) element-wise. Supports broadcasting.\n *\n * We also expose `equalStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.equal(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction equal_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equal');\n const $b = convertToTensor(b, 'b', 'equal');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.equal($a, $b), {$a, $b}) as T;\n}\n\nfunction equalStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equalStrict');\n const $b = convertToTensor(b, 'b', 'equalStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in equalStrict: ');\n return $a.equal($b);\n}\n\n/**\n * Returns the truth value of (a <= b) element-wise. Supports broadcasting.\n *\n * We also expose `lessEqualStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.lessEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction lessEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqual');\n const $b = convertToTensor(b, 'b', 'lessEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.lessEqual($a, $b), {$a, $b}) as\n T;\n}\n\nfunction lessEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqualStrict');\n const $b = convertToTensor(b, 'b', 'lessEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessEqualStrict: ');\n return $a.lessEqual($b);\n}\n\n/**\n * Returns the truth value of (a > b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greater(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greater_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greater');\n const $b = convertToTensor(b, 'b', 'greater');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.greater($a, $b), {$a, $b}) as\n T;\n}\n\nfunction greaterStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterStrict');\n const $b = convertToTensor(b, 'b', 'greaterStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterStrict: ');\n return $a.greater($b);\n}\n\n/**\n * Returns the truth value of (a >= b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterEqualStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greaterEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greaterEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqual');\n const $b = convertToTensor(b, 'b', 'greaterEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.greaterEqual($a, $b), {$a, $b}) as T;\n}\n\nfunction greaterEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqualStrict');\n const $b = convertToTensor(b, 'b', 'greaterEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterEqualStrict: ');\n return $a.greaterEqual($b);\n}\n\nexport const equal = op({equal_});\nexport const equalStrict = op({equalStrict_});\nexport const greater = op({greater_});\nexport const greaterEqual = op({greaterEqual_});\nexport const greaterEqualStrict = op({greaterEqualStrict_});\nexport const greaterStrict = op({greaterStrict_});\nexport const less = op({less_});\nexport const lessEqual = op({lessEqual_});\nexport const lessEqualStrict = op({lessEqualStrict_});\nexport const lessStrict = op({lessStrict_});\nexport const notEqual = op({notEqual_});\nexport const notEqualStrict = op({notEqualStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {KernelBackend} from '../kernels/backend';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, upcastType} from '../types';\nimport * as util from '../util';\nimport * as broadcast_util from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {neg} from './unary_ops';\n\n/**\n * Adds two `Tensor`s element-wise, A + B. Supports broadcasting.\n *\n * We also expose `addStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n *\n * ```js\n * // Broadcast add a with b.\n * const a = tf.scalar(5);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n * @param a The first `Tensor` to add.\n * @param b The second `Tensor` to add. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction add_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'add');\n const $b = convertToTensor(b, 'b', 'add');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.add($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Adds a list of `Tensor`s element-wise, each with the same shape and dtype.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n *\n * tf.addN([a, b, c]).print();\n * ```\n * @param tensors A list of tensors with the same shape and dtype.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction addN_(tensors: Array): T {\n util.assert(\n Array.isArray(tensors),\n () => 'The param passed to tf.addN() must be a list of tensors');\n util.assert(\n tensors.length >= 1,\n () => `Must pass at least one tensor to tf.addN(), but got ` +\n `${tensors.length}`);\n const $tensors =\n tensors.map((t, i) => convertToTensor(t, `tensors${i}`, 'addN'));\n const firstTensor = $tensors[0];\n $tensors.forEach(t => {\n if (t.dtype !== firstTensor.dtype) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same dtype');\n }\n });\n $tensors.forEach(t => {\n if (!util.arraysEqual(t.shape, firstTensor.shape)) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same shape');\n }\n });\n\n const der = (dy: T) => {\n const ders: {[key: string]: () => Tensor} = {};\n $tensors.forEach((t, i) => {\n ders[i] = () => dy.clone();\n });\n return ders;\n };\n const inputs: NamedTensorMap = $tensors as {} as NamedTensorMap;\n return ENV.engine.runKernel(backend => backend.addN($tensors), inputs, der);\n}\n\n/**\n * Adds two `Tensor`s element-wise, A + B.\n *\n * Inputs must be the same shape. For broadcasting support, use add() instead.\n *\n * @param a The first Tensor to add element-wise.\n * @param b The second Tensor to add element-wise.\n */\nfunction addStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in addStrict: ');\n return a.add(b);\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Supports broadcasting.\n *\n * We also expose `subStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n *\n * ```js\n * // Broadcast subtract a with b.\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.scalar(5);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n * @param a The first `Tensor` to subtract from.\n * @param b The second `Tensor` to be subtracted. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction sub_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'sub');\n const $b = convertToTensor(b, 'b', 'sub');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.neg().reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.subtract($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use sub() instead.\n *\n * @param a The first Tensor to subtract element-wise.\n * @param b The second Tensor to subtract element-wise.\n */\nfunction subStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in subStrict: ');\n return a.sub(b);\n}\n\n/**\n * Computes the power of one `Tensor` to another. Supports broadcasting.\n *\n * Given a `Tensor` x and a `Tensor` y, this operation computes x^y for\n * corresponding elements in x and y. The result's dtype will be the upcasted\n * type of the `base` and `exp` dtypes.\n *\n * ```js\n * const a = tf.tensor([[2, 3], [4, 5]])\n * const b = tf.tensor([[1, 2], [3, 0]]).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n *\n * ```js\n * const a = tf.tensor([[1, 2], [3, 4]])\n * const b = tf.tensor(2).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n * We also expose `powStrict` which has the same signature as this op and\n * asserts that `base` and `exp` are the same shape (does not broadcast).\n *\n * @param base The base `Tensor` to pow element-wise.\n * @param exp The exponent `Tensor` to pow element-wise.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction pow_(base: T|TensorLike, exp: Tensor|TensorLike): T {\n const $base = convertToTensor(base, 'base', 'pow');\n const $exp = convertToTensor(exp, 'exp', 'pow');\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($base.shape, $exp.shape);\n base = $base.cast(upcastType($base.dtype, $exp.dtype));\n exp = $exp.cast(upcastType($base.dtype, $exp.dtype));\n const grad = (dy: Tensor, saved: Tensor[]) => {\n const [y] = saved;\n const derBase = () => {\n let res = dy.mul($exp.toFloat().mul(y.div($base)));\n const reduceAxes = broadcast_util.getReductionAxes($base.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($base.shape) as T;\n };\n const derExp = () => {\n let res = dy.mul(y.mul($base.log()).toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($exp.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($exp.shape);\n };\n return {$base: derBase, $exp: derExp};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.pow($base, $exp)), {$base, $exp},\n grad) as T;\n}\n\n/**\n * Computes the power of one `Tensor` to another. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use pow() instead.\n *\n * @param base The base tensor to pow element-wise.\n * @param exp The exponent tensor to pow element-wise.\n */\nfunction powStrict_(base: T, exp: Tensor): T {\n util.assertShapesMatch(base.shape, exp.shape, 'Error in powStrict: ');\n return base.pow(exp);\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B. Supports broadcasting.\n *\n * We also expose `mulStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([2, 3, 4, 5]);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n *\n * ```js\n * // Broadcast mul a with b.\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.scalar(5);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n * @param a The first tensor to multiply.\n * @param b The second tensor to multiply. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mul_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mul');\n const $b = convertToTensor(b, 'b', 'mul');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.mul($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n const res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.multiply($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B.\n *\n * Inputs must be the same shape. For broadcasting support, use mul().\n *\n * @param a The first tensor to multiply.\n * @param b The first tensor to multiply. Must have the same\n * dtype as `a`.\n */\nfunction mulStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in multiplyStrict: ');\n return a.mul(b) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n *\n * We also expose `divStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction div_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'div');\n const $b = convertToTensor(b, 'b', 'div');\n assertTypesMatch($a, $b);\n\n let forwardFunc: (backend: KernelBackend) => Tensor;\n if ($a.dtype === 'int32' && $b.dtype === 'int32') {\n return floorDiv($a, $b);\n } else {\n forwardFunc = (backend: KernelBackend) => backend.realDivide($a, $b);\n }\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n * The result is rounded with floor function.\n *\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.floorDiv(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.floorDiv(b).print(); // or tf.floorDiv(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction floorDiv_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'floorDiv');\n const $b = convertToTensor(b, 'b', 'floorDiv');\n assertTypesMatch($a, $b);\n\n const forwardFunc = (backend: KernelBackend) => backend.floorDiv($a, $b);\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Inputs must\n * be the same shape.\n *\n * @param a The first tensor as the numerator for element-wise division.\n * @param b The second tensor as the denominator for element-wise division.\n */\nfunction divStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in divideStrict: ');\n return a.div(b) as T;\n}\n\n/**\n * Returns the mod of a and b element-wise.\n * `floor(x / y) * y + mod(x, y) = x`\n * Supports broadcasting.\n *\n * We also expose `modStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * ```js\n * // Broadcast a mod b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mod_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mod');\n const $b = convertToTensor(b, 'b', 'mod');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return dy.sum(reduceAxes).reshape($a.shape);\n }\n return dy;\n };\n const derB = () => {\n const res = dy.mul($a.div($b).floor().neg());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.mod($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Returns the mod of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use mod().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction modStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in modStrict: ');\n return a.mod(b);\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `minimumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * ```js\n * // Broadcast minimum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction minimum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'minimum');\n let $b = convertToTensor(b, 'b', 'minimum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.lessEqual($b).toFloat());\n const derB = () => dy.mul($a.greater($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.minimum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use minimum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction minimumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.minimum(b);\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `maximumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * ```js\n * // Broadcast maximum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction maximum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'maximum');\n let $b = convertToTensor(b, 'b', 'maximum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.greaterEqual($b).toFloat());\n const derB = () => dy.mul($a.less($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.maximum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use maximum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction maximumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.maximum(b);\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n * Supports broadcasting.\n *\n * We also expose `squaredDifferenceStrict` which has the same signature as\n * this op and asserts that `a` and `b` are the same shape (does not\n * broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * ```js\n * // Broadcast squared difference a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction squaredDifference_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'squaredDifference');\n const $b = convertToTensor(b, 'b', 'squaredDifference');\n assertTypesMatch($a, $b);\n\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const two = scalar(2);\n const derA = () => dy.mul($a.sub($b).mul(two));\n const derB = () => dy.mul($b.sub($a).mul(two));\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.squaredDifference($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n *\n * Inputs must be the same shape. For broadcasting support, use\n * squaredDifference() instead.\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\nfunction squaredDifferenceStrict_(a: T, b: T): T {\n util.assertShapesMatch(\n a.shape, b.shape, 'Error in squaredDifferenceStrict: ');\n return a.squaredDifference(b);\n}\n\n/**\n * Computes arctangent of `Tensor`s a / b element-wise: `atan2(a, b)`.\n * Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([1.0, 1.0, -1.0, .7]);\n * const b = tf.tensor1d([2.0, 13.0, 3.5, .21]);\n *\n * tf.atan2(a, b).print()\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan2_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'atan2');\n const $b = convertToTensor(b, 'b', 'atan2');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const d = add($a.square(), $b.square());\n let res = dy.mul($b.div(d));\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n const d = add($a.square(), $b.square()) as T;\n let res = neg(dy.mul($a.div(d)));\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.atan2($a, $b), {$a, $b}, der) as T;\n}\n\nexport const add = op({add_});\nexport const addN = op({addN_});\nexport const addStrict = op({addStrict_});\nexport const atan2 = op({atan2_});\nexport const div = op({div_});\nexport const divStrict = op({divStrict_});\nexport const floorDiv = op({floorDiv_});\nexport const maximum = op({maximum_});\nexport const maximumStrict = op({maximumStrict_});\nexport const minimum = op({minimum_});\nexport const minimumStrict = op({minimumStrict_});\nexport const mod = op({mod_});\nexport const modStrict = op({modStrict_});\nexport const mul = op({mul_});\nexport const mulStrict = op({mulStrict_});\nexport const pow = op({pow_});\nexport const powStrict = op({powStrict_});\nexport const squaredDifference = op({squaredDifference_});\nexport const squaredDifferenceStrict = op({squaredDifferenceStrict_});\nexport const sub = op({sub_});\nexport const subStrict = op({subStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {whereImpl} from '../kernels/where_impl';\nimport {Tensor, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Returns the truth value of `NOT x` element-wise.\n *\n * ```js\n * const a = tf.tensor1d([false, true], 'bool');\n *\n * a.logicalNot().print();\n * ```\n *\n * @param x The input tensor. Must be of dtype 'bool'.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalNot_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logicalNot', 'bool');\n assert($x.dtype === 'bool', 'Error Array must be of type bool.');\n\n return ENV.engine.runKernel(backend => backend.logicalNot($x), {$x});\n}\n\n/**\n * Returns the truth value of a AND b element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalAnd(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalAnd_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalAnd', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalAnd', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.logicalAnd($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Returns the truth value of `a OR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalOr(b).print();\n * ```\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalOr_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalOr', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalOr', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.logicalOr($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Returns the truth value of `a XOR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalXor(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalXor_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalXor', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalXor', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n // x ^ y = (x | y) & ~(x & y)\n return logicalOr(a, b).logicalAnd(logicalAnd(a, b).logicalNot()) as T;\n}\n\n/**\n * Returns the elements, either `a` or `b` depending on the `condition`.\n *\n * If the condition is true, select from `a`, otherwise select from `b`.\n *\n * ```js\n * const cond = tf.tensor1d([false, false, true], 'bool');\n * const a = tf.tensor1d([1 , 2, 3]);\n * const b = tf.tensor1d([-1, -2, -3]);\n *\n * a.where(cond, b).print();\n * ```\n *\n * @param condition The input condition. Must be of dtype bool.\n * @param a If `condition` is rank 1, `a` may have a higher rank but\n * its first dimension must match the size of `condition`.\n * @param b A tensor with the same shape and type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction where_(\n condition: Tensor|TensorLike, a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'where');\n const $b = convertToTensor(b, 'b', 'where');\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n\n assert($condition.dtype === 'bool', 'Error Condition must be of type bool.');\n assertShapesMatch($a.shape, $b.shape, 'Error in where: ');\n\n if ($condition.rank === 1) {\n // If condition rank is 1, then the first dimension must match the size of\n // condition.\n assert(\n $condition.shape[0] === $a.shape[0],\n 'The first dimension of `a` must match the size of `condition`.');\n } else {\n // A must have the same shape as condition.\n assertShapesMatch($condition.shape, $b.shape, 'Error in where: ');\n }\n\n // TODO(julianoks): Return null for condition gradient\n // when backprop supports it.\n const grad = (dy: T) => ({\n $condition: () => zerosLike($condition),\n $a: () => dy.mul($condition.cast($a.dtype)) as T,\n $b: () => dy.mul($condition.logicalNot().cast($b.dtype)) as T\n });\n\n return ENV.engine.runKernel(\n backend => backend.select($condition, $a, $b),\n {$condition, $a, $b}, grad) as T;\n}\n\n/**\n * Returns the coordinates of true elements of condition.\n *\n * The coordinates are returned in a 2-D tensor where the first dimension (rows)\n * represents the number of true elements, and the second dimension (columns)\n * represents the coordinates of the true elements. Keep in mind, the shape of\n * the output tensor can vary depending on how many true values there are in\n * input. Indices are output in row-major order. The resulting tensor has the\n * shape `[numTrueElems, condition.rank]`.\n */\nasync function whereAsync_(condition: Tensor|TensorLike): Promise {\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n assert($condition.dtype === 'bool', 'Condition must be of type bool.');\n const vals = await $condition.data();\n const res = whereImpl($condition.shape, vals);\n if (condition !== $condition) {\n $condition.dispose();\n }\n return res;\n}\n\nexport const logicalAnd = op({logicalAnd_});\nexport const logicalNot = op({logicalNot_});\nexport const logicalOr = op({logicalOr_});\nexport const logicalXor = op({logicalXor_});\nexport const where = op({where_});\nexport const whereAsync = whereAsync_;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {maximum, minimum} from './binary_ops';\nimport {where} from './logical_ops';\nimport {op} from './operation';\nimport {SELU_SCALE, SELU_SCALEALPHA} from './selu_util';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes rectified linear element-wise: `max(x, 0)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.relu().print(); // or tf.relu(x)\n * ```\n * @param x The input tensor. If the dtype is `bool`, the output dtype will be\n * `int32'.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction relu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'relu');\n\n if ($x.dtype === 'bool') {\n return $x.toInt();\n }\n const grad = (dy: T) => {\n const stepRes = $x.step();\n return {$x: () => dy.mulStrict(stepRes.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.relu($x), {$x}, grad);\n}\n\n/**\n * Computes exponential linear element-wise, `x > 0 ? e ^ x - 1 : 0`\n *\n * ```js\n * const x = tf.tensor1d([-1, 1, -3, 2]);\n *\n * x.elu().print(); // or tf.elu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction elu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'elu');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {\n $x: () =>\n ENV.engine.runKernel(backend => backend.eluDer(dy, y), {dy, y}) as T\n };\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.elu($x)), {$x}, grad);\n}\n\n/**\n * Computes scaled exponential linear element-wise.\n *\n * `x < 0 ? scale * alpha * (exp(x) - 1) : x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.selu().print(); // or tf.selu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction selu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'selu');\n\n const grad = (dy: T) => {\n return {\n $x: () => {\n const mask = $x.greater(scalar(0));\n\n const scaleAlpha = scalar(SELU_SCALEALPHA);\n const scale = scalar(SELU_SCALE);\n\n const greaterThanZeroDer = dy.mul(scale);\n const lessEqualZeroDer = dy.mul(scaleAlpha).mul($x.toFloat().exp());\n\n return where(mask, greaterThanZeroDer, lessEqualZeroDer) as T;\n }\n };\n };\n return ENV.engine.runKernel(backend => backend.selu($x), {$x}, grad);\n}\n\n/**\n * Computes leaky rectified linear element-wise.\n *\n * See\n * [http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf](\n * http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf)\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.leakyRelu(0.1).print(); // or tf.leakyRelu(x, 0.1)\n * ```\n * @param x The input tensor.\n * @param alpha The scaling factor for negative values, defaults to 0.2.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction leakyRelu_(x: T|TensorLike, alpha = 0.2): T {\n const $x = convertToTensor(x, 'x', 'leakyRelu');\n return maximum(scalar(alpha).mul($x), $x);\n}\n\n/**\n * Computes leaky rectified linear element-wise with parametric alphas.\n *\n * `x < 0 ? alpha * x : f(x) = x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n * const alpha = tf.scalar(0.1);\n *\n * x.prelu(alpha).print(); // or tf.prelu(x, alpha)\n * ```\n * @param x The input tensor.\n * @param alpha Scaling factor for negative values.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction prelu_(x: T|TensorLike, alpha: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'prelu');\n const $alpha = convertToTensor(alpha, 'alpha', 'prelu');\n\n const zero = scalar(0);\n return maximum(zero, $x).add($alpha.mul(minimum(zero, $x)));\n}\n\nexport const elu = op({elu_});\nexport const leakyRelu = op({leakyRelu_});\nexport const prelu = op({prelu_});\nexport const relu = op({relu_});\nexport const selu = op({selu_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\n\n/**\n * Transposes the `Tensor`. Permutes the dimensions according to `perm`.\n *\n * The returned `Tensor`'s dimension `i` will correspond to the input\n * dimension `perm[i]`. If `perm` is not given, it is set to `[n-1...0]`,\n * where `n` is the rank of the input `Tensor`. Hence by default, this\n * operation performs a regular matrix transpose on 2-D input `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]);\n *\n * a.transpose().print(); // or tf.transpose(a)\n * ```\n *\n * @param x The tensor to transpose.\n * @param perm The permutation of the dimensions of a.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction transpose_(x: T|TensorLike, perm?: number[]): T {\n const $x = convertToTensor(x, 'x', 'transpose');\n\n if (perm == null) {\n perm = $x.shape.map((s, i) => i).reverse();\n }\n util.assert(\n $x.rank === perm.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of perm ${perm}.`);\n perm.forEach(axis => {\n util.assert(\n axis >= 0 && axis < $x.rank,\n `All entries in 'perm' must be between 0 and ${$x.rank - 1}` +\n ` but got ${perm}`);\n });\n\n if ($x.rank <= 1) {\n return $x.clone();\n }\n\n const der = (dy: T) => {\n const undoPerm = axis_util.getUndoAxesPermutation(perm);\n return {$x: () => dy.transpose(undoPerm)};\n };\n return ENV.engine.runKernel(\n backend => backend.transpose($x, perm), {$x}, der);\n}\n\nexport const transpose = op({transpose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Normalizes the activation of a local neighborhood across or within\n * channels.\n *\n * @param x The input tensor. The 4-D input tensor is treated as a 3-D array\n * of 1D vectors (along the last dimension), and each vector is\n * normalized independently.\n * @param depthRadius The number of adjacent channels in the 1D normalization\n * window.\n * @param bias A constant bias term for the basis.\n * @param alpha A scale factor, usually positive.\n * @param beta An exponent.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction localResponseNormalization_(\n x: T|TensorLike, depthRadius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n const $x = convertToTensor(x, 'x', 'localResponseNormalization');\n util.assert(\n $x.rank === 4 || $x.rank === 3,\n `Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank ${$x.rank}.`);\n util.assert(\n util.isInt(depthRadius),\n `Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius ${depthRadius}.`);\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n const [outputImage] = saved;\n return {\n x4D: () => ENV.engine.runKernel(\n backend => backend.LRNGrad(\n dy, x4D, outputImage as Tensor4D, depthRadius, bias, alpha, beta),\n {})\n };\n };\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.localResponseNormalization4D(\n x4D, depthRadius, bias, alpha, beta)),\n {x4D}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n } else {\n return res as T;\n }\n}\n\nexport const localResponseNormalization = op({localResponseNormalization_});","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes the norm of scalar, vectors, and matrices.\n * This function can compute several different vector norms (the 1-norm, the\n * Euclidean or 2-norm, the inf-norm, and in general the p-norm for p > 0)\n * and matrix norms (Frobenius, 1-norm, and inf-norm).\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.norm().print(); // or tf.norm(x)\n * ```\n *\n * @param x The input array.\n * @param ord Optional. Order of the norm. Supported norm types are\n * following:\n *\n * | ord | norm for matrices | norm for vectors\n * |------------|---------------------------|---------------------\n * |'euclidean' |Frobenius norm |2-norm\n * |'fro' |Frobenius norm\t |\n * |Infinity |max(sum(abs(x), axis=1)) |max(abs(x))\n * |-Infinity |min(sum(abs(x), axis=1)) |min(abs(x))\n * |1 |max(sum(abs(x), axis=0)) |sum(abs(x))\n * |2 | |sum(abs(x)^2)^1/2*\n *\n * @param axis Optional. If axis is null (the default), the input is\n * considered a vector and a single vector norm is computed over the entire\n * set of values in the Tensor, i.e. norm(x, ord) is equivalent\n * to norm(x.reshape([-1]), ord). If axis is a integer, the input\n * is considered a batch of vectors, and axis determines the axis in x\n * over which to compute vector norms. If axis is a 2-tuple of integer it is\n * considered a batch of matrices and axis determines the axes in NDArray\n * over which to compute a matrix norm.\n * @param keepDims Optional. If true, the norm have the same dimensionality\n * as the input.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction norm_(\n x: Tensor|TensorLike, ord: number|'euclidean'|'fro' = 'euclidean',\n axis: number|number[] = null, keepDims = false): Tensor {\n x = convertToTensor(x, 'x', 'norm');\n\n const norm = normImpl(x, ord, axis);\n let keepDimsShape = norm.shape;\n if (keepDims) {\n const axes = axis_util.parseAxisParam(axis, x.shape);\n keepDimsShape = axis_util.expandShapeToKeepDim(norm.shape, axes);\n }\n return norm.reshape(keepDimsShape);\n}\n\nfunction normImpl(\n x: Tensor, p: number|string, axis: number|number[] = null): Tensor {\n if (x.rank === 0) {\n return x.abs();\n }\n\n // consider vector when no axis is specified\n if (x.rank !== 1 && axis === null) {\n return normImpl(x.reshape([-1]), p, axis);\n }\n\n // vector\n if (x.rank === 1 || typeof axis === 'number' ||\n axis instanceof Array && axis.length === 1) {\n if (p === 1) {\n return x.abs().sum(axis);\n }\n if (p === Infinity) {\n return x.abs().max(axis);\n }\n if (p === -Infinity) {\n return x.abs().min(axis);\n }\n if (p === 'euclidean' || p === 2) {\n // norm(x, 2) = sum(abs(xi) ^ 2) ^ 1/2\n return x.abs().pow(scalar(2, 'int32')).sum(axis).sqrt() as Tensor;\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n // matrix (assumption axis[0] < axis[1])\n if (axis instanceof Array && axis.length === 2) {\n if (p === 1) {\n return x.abs().sum(axis[0]).max(axis[1] - 1);\n }\n if (p === Infinity) {\n return x.abs().sum(axis[1]).max(axis[0]);\n }\n if (p === -Infinity) {\n return x.abs().sum(axis[1]).min(axis[0]);\n }\n if (p === 'fro' || p === 'euclidean') {\n // norm(x) = sqrt(sum(pow(x, 2)))\n return x.square().sum(axis).sqrt();\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n throw new Error(`Error in norm: invalid axis: ${axis}`);\n}\n\nexport const norm = op({norm_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, isInt} from '../util';\nimport {expandDims} from './array_ops';\nimport {getUndoAxesPermutation, parseAxisParam} from './axis_util';\nimport {maximum} from './binary_ops';\nimport {greaterEqual} from './compare';\nimport {logicalAnd, where} from './logical_ops';\nimport {op} from './operation';\nimport {ones, scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes the sum along segments of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const segmentIds = tf.tensor1d([1, 2, 0, 1], 'int32');\n * const numSegments = 3;\n *\n * x.unsortedSegmentSum(segmentIds, numSegments).print()\n * //or tf.unsortedSegmentSum(x, segmentIds, numSegments)\n * ```\n * @param x The `Tensor` that will be summed along its segments\n * @param segmentIds A `Tensor1D` whose rank is equal to the rank of `x`'s\n * dimension along the `axis`. Maps each element of `x` to a segment.\n * @param numSegments The number of distinct `segmentIds`\n */\n/** @doc {heading: 'Operations', subheading: 'Segment'} */\nfunction unsortedSegmentSum_(\n x: T|TensorLike, segmentIds: Tensor1D|TensorLike, numSegments: number): T {\n const $x = convertToTensor(x, 'x', 'unsortedSegmentSum');\n const $segmentIds =\n convertToTensor(segmentIds, 'segmentIds', 'unsortedSegmentSum', 'int32');\n assert($segmentIds.dtype === 'int32', 'segmentIds must be of dtype `int32`');\n assert(isInt(numSegments), 'numSegments must be of dtype int');\n\n const gradFunc = (dy: T) => {\n const derX = () => {\n return gatherDropNegatives(dy, $segmentIds);\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend =>\n backend.unsortedSegmentSum($x, $segmentIds, numSegments),\n {$x}, gradFunc) as T;\n}\n\n/**\n * Gather slices from tensor `x`'s axis `axis` according to `indices`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const indices = tf.tensor1d([1, 3, 3], 'int32');\n *\n * x.gather(indices).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const indices = tf.tensor1d([1, 1, 0], 'int32');\n *\n * x.gather(indices).print();\n * ```\n * @param x The input tensor whose slices to be gathered.\n * @param indices The indices of the values to extract.\n * @param axis The axis over which to select values. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction gather_(\n x: T|TensorLike, indices: Tensor1D|TensorLike, axis = 0): T {\n const $x = convertToTensor(x, 'x', 'gather');\n const $indices = convertToTensor(indices, 'indices', 'gather', 'int32');\n\n assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n axis = parseAxisParam(axis, $x.shape)[0];\n const grad = (dy: T) => {\n const derX = () => {\n if (axis === 0) {\n return unsortedSegmentSum(dy, $indices, $x.shape[axis]);\n }\n const paramsShape = $x.shape;\n const indicesSize = $indices.size;\n\n const outerShape = paramsShape.slice(0, axis);\n const outerDims = outerShape.length;\n const innerShape = paramsShape.slice(axis, paramsShape.length).slice(1);\n const innerDims = innerShape.length;\n\n const outerAxesIndices = arrayRange(0, outerDims);\n const innerAxesIndices =\n arrayRange(outerDims + 1, outerDims + 1 + innerDims);\n\n const valuesShape = arrayConcat([outerShape, [indicesSize], innerShape]);\n\n const values = dy.reshape(valuesShape);\n const reshapedIndices = $indices.reshape([indicesSize]);\n\n const transposeDims =\n arrayConcat([[outerDims], outerAxesIndices, innerAxesIndices]);\n const valuesTranspose = values.transpose(transposeDims);\n\n let paramsGrad = unsortedSegmentSum(\n valuesTranspose, reshapedIndices as Tensor1D, $x.shape[axis]);\n\n const invertTransposeDims = getUndoAxesPermutation(transposeDims);\n paramsGrad = paramsGrad.transpose(invertTransposeDims);\n\n return paramsGrad as T;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend => backend.gather($x, $indices as Tensor1D, axis), {$x},\n grad) as T;\n}\n\nfunction arrayRange(start: number, stop: number): number[] {\n const result = [];\n for (let i = start; i < stop; ++i) {\n result.push(i);\n }\n return result;\n}\n\nfunction arrayConcat(arrays: number[][]): number[] {\n const result = [];\n for (let i = 0; i < arrays.length; ++i) {\n for (let j = 0; j < arrays[i].length; ++j) {\n result.push(arrays[i][j]);\n }\n }\n return result;\n}\n\nfunction gatherDropNegatives(x: T, indices: Tensor1D) {\n // Helper function for unsorted segment ops. Gathers params for\n // positive segment ids and gathers 0 for inputs with negative segment id.\n // Mirrors _GatherDropNegatives from tensorflow/python/ops/math_grad.py\n const zeroClippedIndices = maximum(indices, zerosLike(indices));\n const gathered = gather(x, zeroClippedIndices as Tensor1D);\n let isPositive = greaterEqual(indices, scalar(0, 'int32'));\n const numIters = gathered.rank - isPositive.rank;\n for (let i = 0; i < numIters; ++i) {\n isPositive = expandDims(isPositive, i + 1);\n }\n isPositive = logicalAnd(isPositive, ones(gathered.shape, 'bool'));\n const zeroSlice = zerosLike(gathered);\n return where(isPositive, gathered, zeroSlice);\n}\n\nexport const gather = op({gather_});\nexport const unsortedSegmentSum = op({unsortedSegmentSum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * @docalias (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D]\n */\nexport type LSTMCellFunc = {\n (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D];\n};\n\n/**\n * Computes the next states and outputs of a stack of LSTMCells.\n *\n * Each cell output is used as input to the next cell.\n *\n * Returns `[cellState, cellOutput]`.\n *\n * Derived from tf.contrib.rn.MultiRNNCell.\n *\n * @param lstmCells Array of LSTMCell functions.\n * @param data The input to the cell.\n * @param c Array of previous cell states.\n * @param h Array of previous cell outputs.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction multiRNNCell_(\n lstmCells: LSTMCellFunc[], data: Tensor2D|TensorLike,\n c: Tensor2D[]|TensorLike[],\n h: Tensor2D[]|TensorLike[]): [Tensor2D[], Tensor2D[]] {\n const $data = convertToTensor(data, 'data', 'multiRNNCell');\n const $c = convertToTensorArray(c, 'c', 'multiRNNCell');\n const $h = convertToTensorArray(h, 'h', 'multiRNNCell');\n\n let input = $data;\n const newStates = [];\n for (let i = 0; i < lstmCells.length; i++) {\n const output = lstmCells[i](input, $c[i], $h[i]);\n newStates.push(output[0]);\n newStates.push(output[1]);\n input = output[1];\n }\n const newC: Tensor2D[] = [];\n const newH: Tensor2D[] = [];\n for (let i = 0; i < newStates.length; i += 2) {\n newC.push(newStates[i]);\n newH.push(newStates[i + 1]);\n }\n return [newC, newH];\n}\n\n/**\n * Computes the next state and output of a BasicLSTMCell.\n *\n * Returns `[newC, newH]`.\n *\n * Derived from tf.contrib.rnn.BasicLSTMCell.\n *\n * @param forgetBias Forget bias for the cell.\n * @param lstmKernel The weights for the cell.\n * @param lstmBias The bias for the cell.\n * @param data The input to the cell.\n * @param c Previous cell state.\n * @param h Previous cell output.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction basicLSTMCell_(\n forgetBias: Scalar|TensorLike, lstmKernel: Tensor2D|TensorLike,\n lstmBias: Tensor1D|TensorLike, data: Tensor2D|TensorLike,\n c: Tensor2D|TensorLike, h: Tensor2D|TensorLike): [Tensor2D, Tensor2D] {\n const $forgetBias =\n convertToTensor(forgetBias, 'forgetBias', 'basicLSTMCell');\n const $lstmKernel =\n convertToTensor(lstmKernel, 'lstmKernel', 'basicLSTMCell');\n const $lstmBias = convertToTensor(lstmBias, 'lstmBias', 'basicLSTMCell');\n const $data = convertToTensor(data, 'data', 'basicLSTMCell');\n const $c = convertToTensor(c, 'c', 'basicLSTMCell');\n const $h = convertToTensor(h, 'h', 'basicLSTMCell');\n\n const combined = $data.concat($h, 1);\n const weighted = combined.matMul($lstmKernel);\n const res = weighted.add($lstmBias) as Tensor2D;\n\n // i = input_gate, j = new_input, f = forget_gate, o = output_gate\n const batchSize = res.shape[0];\n const sliceCols = res.shape[1] / 4;\n const sliceSize: [number, number] = [batchSize, sliceCols];\n const i = res.slice([0, 0], sliceSize);\n const j = res.slice([0, sliceCols], sliceSize);\n const f = res.slice([0, sliceCols * 2], sliceSize);\n const o = res.slice([0, sliceCols * 3], sliceSize);\n\n const newC = i.sigmoid().mulStrict(j.tanh()).addStrict(\n $c.mulStrict($forgetBias.add(f).sigmoid() as Tensor2D));\n const newH = newC.tanh().mulStrict(o.sigmoid());\n return [newC, newH];\n}\n\nexport const basicLSTMCell = op({basicLSTMCell_});\nexport const multiRNNCell = op({multiRNNCell_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {pow} from './binary_ops';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Compute the moving average of a variable.\n *\n * Without zeroDebias, the moving average operation is defined by:\n * `v += delta`\n * where\n * `delta = (1 - decay) * (x - v)`\n *\n * With zeroDebias (default), the `delta` term is scaled to debias the\n * effect of the (assumed) zero-initialization of `v`.\n * `delta /= (1 - decay ^ step)`\n *\n * For more details on the zero-debiasing algorithm, see:\n * https://arxiv.org/abs/1412.6980\n *\n * Note that this function is completely stateless and does not keep track of\n * step count. The step count needs to be maintained by the caller and passed\n * in as `step`.\n *\n * @param v The current moving average value.\n * @param x New input value, must have the same shape and dtype as `v`.\n * @param decay The decay factor. Typical values are 0.95 and 0.99.\n * @param step Step count.\n * @param zeroDebias: Whether zeroDebias is to be performed (default: `true`).\n * @returns The new moving average value.\n */\n/** @doc {heading: 'Operations', subheading: 'Moving Average'} */\nfunction movingAverage_(\n v: T|TensorLike, x: T|TensorLike, decay: number|Scalar,\n step?: number|Scalar, zeroDebias = true): T {\n const $v = convertToTensor(v, 'v', 'movingAverage');\n const $x = convertToTensor(x, 'x', 'movingAverage');\n const $decay = convertToTensor(decay, 'decay', 'movingAverage');\n\n assertTypesMatch($v, $x);\n util.assert(\n util.arraysEqual($v.shape, $x.shape), 'Shape mismatch in v and x');\n\n const one = scalar(1);\n const oneMinusDecay = one.sub($decay);\n\n let update = $x.sub($v).mul(oneMinusDecay);\n if (zeroDebias) {\n util.assert(step != null, 'When using zeroDebias: true, step is required.');\n const $step = convertToTensor(step, 'step', 'movingAverage');\n update = update.div(one.sub(pow($decay, $step)));\n }\n return $v.add(update);\n}\n\nexport const movingAverage = op({movingAverage_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Extracts a strided slice of a tensor.\n *\n * Roughly speaking, this op extracts a slice of size (end-begin)/stride from\n * the given input_ tensor. Starting at the location specified by begin the\n * slice continues by adding stride to the index until all dimensions are not\n * less than end. Note that a stride can be negative, which causes a reverse\n * slice.\n *\n * ```js\n * t = tf.tensor3d([1, 1, 1 ,2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6],\n * [3, 2, 3]);\n * t.stridedSlice([1, 0, 0], [2, 1, 3], [1, 1, 1]).print() // [[[3, 3, 3]]]\n * t.stridedSlice([1, 0, 0], [2, 2, 3], [1, 1, 1]).print() // [[[3, 3, 3],\n * // [4, 4, 4]]]\n * t.stridedSlice([1, -1, 0], [2, -3, 3], [1, -1, 1]).print() // [[[4, 4, 4],\n * // [3, 3, 3]]]\n * ```\n *\n * @param x The tensor to stride slice.\n * @param begin The coordinates to start the slice from.\n * @param end: The coordinates to end the slice at.\n * @param strides: The size of the slice.\n * @param beginMask: If the ith bit of begin_mask is set, begin[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n * @param endMask: If the ith bit of end_mask is set, end[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n */\n/** @doc {heading: 'Operations', subheading: 'Slicing and Joining'} */\nfunction stridedSlice_(\n x: T|TensorLike, begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): T {\n const $x = convertToTensor(x, 'x', 'stridedSlice');\n return ENV.engine.runKernel(\n backend => backend.stridedSlice(\n $x, begin, end, strides, beginMask, endMask),\n {$x}) as T;\n}\n\nexport const stridedSlice = op({stridedSlice_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Finds the values and indices of the `k` largest entries along the last\n * dimension.\n *\n * If the input is a vector (rank=1), finds the k largest entries in the vector\n * and outputs their values and indices as vectors. Thus values[j] is the j-th\n * largest entry in input, and its index is indices[j].\n * For higher rank inputs, computes the top k entries along the last dimension.\n *\n * If two elements are equal, the lower-index element appears first.\n *\n * ```js\n * const a = tensor2d([[1, 5], [4, 3]]);\n * const {values, indices} = tf.topk(a);\n * values.print();\n * indices.print();\n * ```\n * @param x 1-D or higher `Tensor` with last dimension being at least `k`.\n * @param k Number of top elements to look for along the last dimension.\n * @param sorted If true, the resulting `k` elements will be sorted by the\n * values in descending order.\n */\n/** @doc {heading: 'Operations', subheading: 'Evaluation'} */\nfunction topk_(\n x: T|TensorLike, k = 1, sorted = true): {values: T, indices: T} {\n const $x = convertToTensor(x, 'x', 'topk');\n if ($x.rank === 0) {\n throw new Error('topk() expects the input to be of rank 1 or higher');\n }\n const lastDim = $x.shape[$x.shape.length - 1];\n if (k > lastDim) {\n throw new Error(\n `'k' passed to topk() must be <= the last dimension (${lastDim}) ` +\n `but got ${k}`);\n }\n\n const [values, indices] =\n ENV.engine.runKernel(b => b.topk($x, k, sorted), {$x});\n return {values, indices};\n}\n\nexport const topk = op({topk_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch, sizeFromShape} from '../util';\n\nimport {expandShapeToKeepDim} from './axis_util';\n\nimport {minimum} from './binary_ops';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\nexport enum Reduction {\n NONE,\n MEAN,\n SUM,\n SUM_BY_NONZERO_WEIGHTS\n}\n\n/**\n * Computes the weighted loss between two tensors.\n *\n * @param losses Tensor of shape `[batch_size, d1, ... dN]`.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `losses`, and must be broadcastable to `losses` (i.e., all\n * dimensions must be either `1`, or the same as the corresponding\n * `losses` dimension).\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction computeWeightedLoss_(\n losses: T|TensorLike, weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $losses = convertToTensor(losses, 'losses', 'computeWeightedLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'computeWeightedLoss');\n }\n\n const weightedLoss = ($weights == null) ? $losses : $losses.mul($weights);\n\n if (reduction === Reduction.NONE) {\n return weightedLoss as O;\n }\n if (reduction === Reduction.SUM) {\n return weightedLoss.sum();\n }\n if (reduction === Reduction.MEAN) {\n if ($weights == null) {\n return weightedLoss.mean();\n } else {\n const broadcastFactor =\n sizeFromShape($losses.shape) / sizeFromShape($weights.shape);\n const result = weightedLoss.sum().div($weights.sum());\n return broadcastFactor > 1 ? result.div(scalar(broadcastFactor)) :\n result as O;\n }\n }\n if (reduction === Reduction.SUM_BY_NONZERO_WEIGHTS) {\n if ($weights == null) {\n return weightedLoss.sum().div(scalar($losses.size));\n } else {\n const broadcastedWeights = $weights.mul(ones($losses.shape));\n\n const numNonZeros =\n broadcastedWeights.notEqual(scalar(0)).sum().toFloat();\n return weightedLoss.sum().div(numNonZeros);\n }\n }\n\n throw Error(`Unknown reduction: ${reduction}`);\n}\n\n/**\n * Computes the absolute difference loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction absoluteDifference_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'absoluteDifference');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'absoluteDifference');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'absoluteDifference');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in absoluteDifference: ');\n\n const losses = $labels.sub($predictions).abs();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the mean squared error between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction meanSquaredError_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'meanSquaredError');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'meanSquaredError');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'meanSquaredError');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in meanSquaredError: ');\n\n const losses = $labels.squaredDifference($predictions);\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the cosine distance loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param axis The dimension along which the cosine distance is computed.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction cosineDistance_(\n labels: T|TensorLike, predictions: T|TensorLike, axis: number,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'cosineDistance');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'cosineDistance');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'cosineDistance');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in cosineDistance: ');\n\n const one = scalar(1);\n const losses = one.sub($labels.mul($predictions).sum(axis, true));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the Hinge loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction hingeLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $labels = convertToTensor(labels, 'labels', 'hingeLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'hingeLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'hingeLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in hingeLoss: ');\n\n const one = scalar(1);\n // Convert binary labels to (-1, 1)\n $labels = scalar(2).mul($labels).sub(one);\n const losses = one.sub($labels.mul($predictions)).relu();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the log loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param epsilon A small increment to avoid taking log of zero\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction logLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, epsilon = 1e-7,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'logLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'logLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'logLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in logLoss: ');\n\n const one = scalar(1);\n const epsilonScalar = scalar(epsilon);\n const losses = $labels.mul($predictions.add(epsilonScalar).log())\n .neg()\n .sub(one.sub($labels).mul(\n one.sub($predictions).add(epsilonScalar).log()));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nfunction sigmoidCrossEntropyWithLogits_(\n labels: T|TensorLike, logits: T|TensorLike): O {\n const $labels =\n convertToTensor(labels, 'labels', 'sigmoidCrossEntropyWithLogits');\n const $logits =\n convertToTensor(logits, 'logits', 'sigmoidCrossEntropyWithLogits');\n assertShapesMatch(\n $labels.shape, $logits.shape, 'Error in sigmoidCrossEntropyWithLogits: ');\n\n /**\n * Implementation Details:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n *\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n *\n * Hence, to ensure stability and avoid overflow, the implementation uses\n * this equivalent formulation:\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n */\n const maxOutput = $logits.relu();\n const outputXTarget = $logits.mul($labels);\n const sigmoidOutput = $logits.abs().neg().exp().log1p();\n\n return maxOutput.sub(outputXTarget).add(sigmoidOutput);\n}\n\n/**\n * Computes the sigmoid cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newMulticlassLabels = multiclassLabels * (1 - labelSmoothing)\n * + 0.5 * labelSmoothing\n *\n * @param multiClassLabels The ground truth output tensor of shape\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction sigmoidCrossEntropy_(\n multiClassLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $multiClassLabels = convertToTensor(\n multiClassLabels, 'multiClassLabels', 'sigmoidCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'sigmoidCrossEntropy');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'sigmoidCrossEntropy');\n }\n assertShapesMatch(\n $multiClassLabels.shape, $logits.shape, 'Error in sigmoidCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const half = scalar(0.5);\n\n $multiClassLabels = $multiClassLabels.mul(one.sub(labelSmoothingScalar))\n .add(half.mul(labelSmoothingScalar));\n }\n const losses = sigmoidCrossEntropyWithLogits_($multiClassLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the huber loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param delta Point where huber loss changes from quadratic to linear.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`.\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction huberLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, delta = 1.0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'huberLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'huberLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'huberLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in huberLoss: ');\n\n const deltaScalar = scalar(delta);\n const error = $predictions.sub($labels).abs();\n const quadratic = minimum(error, deltaScalar);\n const linear = error.sub(quadratic);\n\n const losses =\n scalar(0.5).mul(quadratic.square()).add(deltaScalar.mul(linear));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes softmax cross entropy between logits and labels.\n *\n * Measures the probability error in discrete classification tasks in which\n * the classes are mutually exclusive (each entry is in exactly one class).\n * For example, each CIFAR-10 image is labeled with one and only one label: an\n * image can be a dog or a truck, but not both.\n *\n * `NOTE`: While the classes are mutually exclusive, their probabilities need\n * not be. All that is required is that each row of labels is a valid\n * probability distribution. If they are not, the computation of the gradient\n * will be incorrect.\n *\n * `WARNING`: This op expects unscaled logits, since it performs a softmax on\n * logits internally for efficiency. Do not call this op with the output of\n * softmax, as it will produce incorrect results.\n *\n * logits and labels must have the same shape, e.g. [batch_size, num_classes]\n * and the same dtype.\n * @param labels The labels array.\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\nfunction softmaxCrossEntropyWithLogits_(\n labels: T, logits: T, dim = -1): O {\n if (dim === -1) {\n dim = logits.rank - 1;\n }\n\n if (dim !== logits.rank - 1) {\n throw Error(\n `Softmax cross entropy along a non-last dimension is not yet ` +\n `supported. Labels / logits was rank ${logits.rank} ` +\n `and dim was ${dim}`);\n }\n // Use a custom gradient for numerical stability.\n const customOp = customGrad((labels, logits) => {\n // Reference:\n // 1. http://cs231n.github.io/linear-classify/#softmax\n // 2. https://blog.feedly.com/tricks-of-the-trade-logsumexp/\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n\n const logResult = logits.toFloat().sub(lse);\n const costVector = logResult.mul(labels).neg();\n\n const value = costVector.sum([dim]) as O;\n\n const gradFunc = (dy: O) => {\n const dyShape = expandShapeToKeepDim(dy.shape, [dim]);\n return [\n dy.reshape(dyShape).mul(labels.toFloat().sub(logResult.exp())),\n dy.reshape(dyShape).mul(logResult.exp().sub(labels.toFloat())),\n ];\n };\n return {value, gradFunc};\n });\n\n return customOp(labels, logits);\n}\n\n/**\n * Computes the softmax cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newOnehotLabels = onehotLabels * (1 - labelSmoothing)\n * + labelSmoothing / numClasses\n *\n * @param onehotLabels One hot encoded labels\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or 1, and must be\n * broadcastable to `loss` of shape [batch_size]\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction softmaxCrossEntropy_(\n onehotLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $onehotLabels =\n convertToTensor(onehotLabels, 'onehotLabels', 'softmaxCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'softmaxCrossEntropy');\n let $weights: Tensor = null;\n\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'softmaxCrossEntropy');\n }\n\n assertShapesMatch(\n $onehotLabels.shape, $logits.shape, 'Error in softmaxCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const numClasses = scalar($onehotLabels.shape[1]);\n\n $onehotLabels = $onehotLabels.mul(one.sub(labelSmoothingScalar))\n .add(labelSmoothingScalar.div(numClasses));\n }\n\n const losses = softmaxCrossEntropyWithLogits_($onehotLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nexport const absoluteDifference = op({absoluteDifference_});\nexport const computeWeightedLoss = op({computeWeightedLoss_});\nexport const cosineDistance = op({cosineDistance_});\nexport const hingeLoss = op({hingeLoss_});\nexport const huberLoss = op({huberLoss_});\nexport const logLoss = op({logLoss_});\nexport const meanSquaredError = op({meanSquaredError_});\nexport const sigmoidCrossEntropy = op({sigmoidCrossEntropy_});\nexport const softmaxCrossEntropy = op({softmaxCrossEntropy_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Linear algebra ops.\n */\n\nimport {ENV} from '../environment';\nimport {dispose} from '../globals';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {assert} from '../util';\nimport {eye, split, squeeze, stack, unstack} from './array_ops';\nimport {norm} from './norm';\nimport {op} from './operation';\nimport {sum} from './reduction_ops';\nimport {tensor2d} from './tensor_ops';\n\n/**\n * Gram-Schmidt orthogonalization.\n *\n * @param xs The vectors to be orthogonalized, in one of the two following\n * formats:\n * - An Array of `Tensor1D`.\n * - A `Tensor2D`, i.e., a matrix, in which case the vectors are the rows\n * of `xs`.\n * In each case, all the vectors must have the same length and the length\n * must be greater than or equal to the number of vectors.\n * @returns The orthogonalized and normalized vectors or matrix.\n * Orthogonalization means that the vectors or the rows of the matrix\n * are orthogonal (zero inner products). Normalization means that each\n * vector or each row of the matrix has an L2 norm that equals `1`.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction gramSchmidt_(xs: Tensor1D[]|Tensor2D): Tensor1D[]|Tensor2D {\n let inputIsTensor2D: boolean;\n if (Array.isArray(xs)) {\n inputIsTensor2D = false;\n assert(\n xs != null && xs.length > 0,\n 'Gram-Schmidt process: input must not be null, undefined, or empty');\n const dim = xs[0].shape[0];\n for (let i = 1; i < xs.length; ++i) {\n assert(\n xs[i].shape[0] === dim,\n 'Gram-Schmidt: Non-unique lengths found in the input vectors: ' +\n `(${xs[i].shape[0]} vs. ${dim})`);\n }\n } else {\n inputIsTensor2D = true;\n xs = split(xs, xs.shape[0], 0).map(x => squeeze(x, [0]));\n }\n\n assert(\n xs.length <= xs[0].shape[0],\n `Gram-Schmidt: Number of vectors (${xs.length}) exceeds ` +\n `number of dimensions (${xs[0].shape[0]}).`);\n\n const ys: Tensor1D[] = [];\n const xs1d = xs as Tensor1D[];\n for (let i = 0; i < xs.length; ++i) {\n ys.push(ENV.engine.tidy(() => {\n let x = xs1d[i];\n if (i > 0) {\n for (let j = 0; j < i; ++j) {\n const proj = sum(ys[j].mulStrict(x)).mul(ys[j]);\n x = x.sub(proj);\n }\n }\n return x.div(norm(x, 'euclidean'));\n }));\n }\n\n if (inputIsTensor2D) {\n return stack(ys, 0) as Tensor2D;\n } else {\n return ys;\n }\n}\n\n/**\n * Compute QR decomposition of m-by-n matrix using Householder transformation.\n *\n * Implementation based on\n * [http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf]\n * (http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf)\n *\n * @param x The `Tensor` to be QR-decomposed. Must have rank >= 2. Suppose\n * it has the shape `[..., M, N]`.\n * @param fullMatrices An optional boolean parameter. Defaults to `false`.\n * If `true`, compute full-sized `Q`. If `false` (the default),\n * compute only the leading N columns of `Q` and `R`.\n * @return An `Array` of two `Tensor`s: `[Q, R]`. `Q` is a unitary matrix,\n * i.e., its columns all have unit norm and are mutually orthogonal.\n * If `M >= N`,\n * If `fullMatrices` is `false` (default),\n * - `Q` has a shape of `[..., M, N]`,\n * - `R` has a shape of `[..., N, N]`.\n * If `fullMatrices` is `true` (default),\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * If `M < N`,\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * @throws If the rank of `x` is less than 2.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction qr_(x: Tensor, fullMatrices = false): [Tensor, Tensor] {\n if (x.rank < 2) {\n throw new Error(\n `qr() requires input tensor to have a rank >= 2, but got rank ${\n x.rank}`);\n } else if (x.rank === 2) {\n return qr2d(x as Tensor2D, fullMatrices);\n } else {\n // Rank > 2.\n // TODO(cais): Below we split the input into individual 2D tensors,\n // perform QR decomposition on them and then stack the results back\n // together. We should explore whether this can be parallelized.\n const outerDimsProd = x.shape.slice(0, x.shape.length - 2)\n .reduce((value, prev) => value * prev);\n const x2ds = unstack(\n x.reshape([\n outerDimsProd, x.shape[x.shape.length - 2],\n x.shape[x.shape.length - 1]\n ]),\n 0);\n const q2ds: Tensor2D[] = [];\n const r2ds: Tensor2D[] = [];\n x2ds.forEach(x2d => {\n const [q2d, r2d] = qr2d(x2d as Tensor2D, fullMatrices);\n q2ds.push(q2d);\n r2ds.push(r2d);\n });\n const q = stack(q2ds, 0).reshape(x.shape);\n const r = stack(r2ds, 0).reshape(x.shape);\n return [q, r];\n }\n}\n\nfunction qr2d(x: Tensor2D, fullMatrices = false): [Tensor2D, Tensor2D] {\n return ENV.engine.tidy(() => {\n if (x.shape.length !== 2) {\n throw new Error(\n `qr2d() requires a 2D Tensor, but got a ${x.shape.length}D Tensor.`);\n }\n\n const m = x.shape[0];\n const n = x.shape[1];\n\n let q = eye(m) as Tensor2D; // Orthogonal transform so far.\n let r = x.clone(); // Transformed matrix so far.\n\n const one2D = tensor2d([[1]], [1, 1]);\n let w: Tensor2D = one2D.clone();\n\n const iters = m >= n ? n : m;\n for (let j = 0; j < iters; ++j) {\n // This tidy within the for-loop ensures we clean up temporary\n // tensors as soon as they are no longer needed.\n const rTemp = r;\n const wTemp = w;\n const qTemp = q;\n [w, r, q] = ENV.engine.tidy((): [Tensor2D, Tensor2D, Tensor2D] => {\n // Find H = I - tau * w * w', to put zeros below R(j, j).\n const rjEnd1 = r.slice([j, j], [m - j, 1]);\n const normX = rjEnd1.norm();\n const rjj = r.slice([j, j], [1, 1]);\n const s = rjj.sign().neg() as Tensor2D;\n const u1 = rjj.sub(s.mul(normX)) as Tensor2D;\n const wPre = rjEnd1.div(u1);\n if (wPre.shape[0] === 1) {\n w = one2D.clone();\n } else {\n w = one2D.concat(\n wPre.slice([1, 0], [wPre.shape[0] - 1, wPre.shape[1]]), 0) as\n Tensor2D;\n }\n const tau = s.matMul(u1).div(normX).neg() as Tensor2D;\n\n // -- R := HR, Q := QH.\n const rjEndAll = r.slice([j, 0], [m - j, n]);\n const tauTimesW = tau.mul(w) as Tensor2D;\n if (j === 0) {\n r = rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll)));\n } else {\n r = r.slice([0, 0], [j, n])\n .concat(\n rjEndAll.sub(\n tauTimesW.matMul(w.transpose().matMul(rjEndAll))),\n 0) as Tensor2D;\n }\n const qAllJEnd = q.slice([0, j], [m, q.shape[1] - j]);\n if (j === 0) {\n q = qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose()));\n } else {\n q = q.slice([0, 0], [m, j])\n .concat(\n qAllJEnd.sub(\n qAllJEnd.matMul(w).matMul(tauTimesW.transpose())),\n 1) as Tensor2D;\n }\n return [w, r, q];\n });\n dispose([rTemp, wTemp, qTemp]);\n }\n\n if (!fullMatrices && m > n) {\n q = q.slice([0, 0], [m, n]);\n r = r.slice([0, 0], [n, n]);\n }\n\n return [q, r];\n }) as [Tensor2D, Tensor2D];\n}\n\nexport const gramSchmidt = op({gramSchmidt_});\nexport const qr = op({qr_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ForwardFunc} from '../engine';\nimport {ENV} from '../environment';\nimport {nonMaxSuppressionImpl} from '../kernels/non_max_suppression_impl';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Bilinear resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeBilinear_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeBilinear');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeBilinear: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeBilinear: new shape must 2D, but got shape ` +\n `${size}.`);\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n\n const [newHeight, newWidth] = size;\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeBilinear(batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend =>\n backend.resizeBilinearBackprop(dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * NearestNeighbor resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeNearestNeighbor_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeNearestNeighbor');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeNearestNeighbor: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeNearestNeighbor: new shape must 2D, but got shape ` +\n `${size}.`);\n util.assert(\n $images.dtype === 'float32' || $images.dtype === 'int32',\n '`images` must have `int32` or `float32` as dtype');\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n const [newHeight, newWidth] = size;\n\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeNearestNeighbor(\n batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend => backend.resizeNearestNeighborBackprop(\n dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Performs non maximum suppression of bounding boxes based on\n * iou (intersection over union)\n *\n * @param boxes a 2d tensor of shape `[numBoxes, 4]`. Each entry is\n * `[y1, x1, y2, x2]`, where `(y1, x1)` and `(y2, x2)` are the corners of\n * the bounding box.\n * @param scores a 1d tensor providing the box scores of shape `[numBoxes]`.\n * @param maxOutputSize The maximum number of boxes to be selected.\n * @param iouThreshold A float representing the threshold for deciding whether\n * boxes overlap too much with respect to IOU. Must be betwen [0, 1].\n * Defaults to 0.5 (50% box overlap).\n * @param scoreThreshold A threshold for deciding when to remove boxes based\n * on score. Defaults to -inf, which means any score is accepted.\n * @return A 1D tensor with the selected box indices.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction nonMaxSuppression_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Tensor1D {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppression');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppression');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n return ENV.engine.runKernel(\n b => b.nonMaxSuppression(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold),\n {$boxes});\n}\n\n/** This is the async version of `nonMaxSuppression` */\nasync function nonMaxSuppressionAsync_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Promise {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppressionAsync');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppressionAsync');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n const boxesVals = await $boxes.data();\n const scoresVals = await $scores.data();\n const res = nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n if ($boxes !== boxes) {\n $boxes.dispose();\n }\n if ($scores !== scores) {\n $scores.dispose();\n }\n return res;\n}\n\nfunction nonMaxSuppSanityCheck(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number):\n {maxOutputSize: number, iouThreshold: number, scoreThreshold: number} {\n if (iouThreshold == null) {\n iouThreshold = 0.5;\n }\n if (scoreThreshold == null) {\n scoreThreshold = Number.NEGATIVE_INFINITY;\n }\n const numBoxes = boxes.shape[0];\n maxOutputSize = Math.min(maxOutputSize, numBoxes);\n\n util.assert(\n 0 <= iouThreshold && iouThreshold <= 1,\n `iouThreshold must be in [0, 1], but was '${iouThreshold}'`);\n util.assert(\n boxes.rank === 2,\n `boxes must be a 2D tensor, but was of rank '${boxes.rank}'`);\n util.assert(\n boxes.shape[1] === 4,\n `boxes must have 4 columns, but 2nd dimension was ${boxes.shape[1]}`);\n util.assert(scores.rank === 1, 'scores must be a 1D tensor');\n util.assert(\n scores.shape[0] === numBoxes,\n `scores has incompatible shape with boxes. Expected ${numBoxes}, ` +\n `but was ${scores.shape[0]}`);\n return {maxOutputSize, iouThreshold, scoreThreshold};\n}\n\nexport const resizeBilinear = op({resizeBilinear_});\nexport const resizeNearestNeighbor = op({resizeNearestNeighbor_});\nexport const nonMaxSuppression = op({nonMaxSuppression_});\nexport const nonMaxSuppressionAsync = nonMaxSuppressionAsync_;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport * as broadcast_util from '../ops/broadcast_util';\nimport * as concat_util from '../ops/concat_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as erf_util from '../ops/erf_util';\nimport * as ops from '../ops/ops';\nimport {buffer, tensor3d, tensor4d} from '../ops/ops';\nimport * as selu_util from '../ops/selu_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, ShapeMap, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\nimport {now} from '../util';\nimport {BackendTimingInfo, KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {whereImpl} from './where_impl';\n\nexport class MathBackendCPU implements KernelBackend {\n private data = new WeakMap();\n private canvas: HTMLCanvasElement;\n private firstUse = true;\n\n constructor() {\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n }\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.firstUse) {\n this.firstUse = false;\n if (ENV.get('IS_NODE')) {\n warn(\n '\\n============================\\n' +\n 'Hi there 👋. Looks like you are running TensorFlow.js in ' +\n 'Node.js. To speed things up dramatically, install our node ' +\n 'backend, which binds to TensorFlow C++, by running ' +\n 'npm i @tensorflow/tfjs-node, ' +\n 'or npm i @tensorflow/tfjs-node-gpu if you have CUDA. ' +\n 'Then call require(\\'@tensorflow/tfjs-node\\'); (-gpu ' +\n 'suffix for CUDA) at the start of your program. ' +\n 'Visit https://github.com/tensorflow/tfjs-node for more details.' +\n '\\n============================\\n');\n }\n }\n if (this.data.has(dataId)) {\n throw new Error(`Data buffer is already registered`);\n }\n this.data.set(dataId, null);\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendCPU.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n this.data.set(dataId, values);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n let vals: Uint8ClampedArray;\n // tslint:disable-next-line:no-any\n if (ENV.get('IS_NODE') && (pixels as any).getContext == null) {\n throw new Error(\n 'When running in node, pixels must be an HTMLCanvasElement ' +\n 'like the one returned by the `canvas` npm package');\n }\n // tslint:disable-next-line:no-any\n if ((pixels as any).getContext != null) {\n // tslint:disable-next-line:no-any\n vals = (pixels as any)\n .getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else if (pixels instanceof ImageData) {\n vals = pixels.data;\n } else if (\n pixels instanceof HTMLImageElement ||\n pixels instanceof HTMLVideoElement) {\n if (this.canvas == null) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside ' +\n 'the browser.');\n }\n this.canvas.width = pixels.width;\n this.canvas.height = pixels.height;\n this.canvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n vals = this.canvas.getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n let values: Int32Array;\n if (numChannels === 4) {\n values = new Int32Array(vals);\n } else {\n const numPixels = pixels.width * pixels.height;\n values = new Int32Array(numPixels * numChannels);\n for (let i = 0; i < numPixels; i++) {\n for (let channel = 0; channel < numChannels; ++channel) {\n values[i * numChannels + channel] = vals[i * 4 + channel];\n }\n }\n }\n const outShape: [number, number, number] =\n [pixels.height, pixels.width, numChannels];\n return tensor3d(values, outShape, 'int32');\n }\n async read(dataId: DataId): Promise {\n return this.readSync(dataId);\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n return this.data.get(dataId);\n }\n\n disposeData(dataId: DataId): void {\n if (this.data.has(dataId)) {\n this.data.delete(dataId);\n }\n }\n\n async time(f: () => void): Promise {\n const start = now();\n f();\n const kernelMs = now() - start;\n return {kernelMs};\n }\n memory() {\n return {\n // Unreliable due to automatic gc. The numbers above are cumulative.\n unreliable: true\n };\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.data.has(dataId)) {\n throw new Error(\n `CPU backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; ++i) {\n const loc = buffer.indexToLoc(i);\n const xLoc = loc.map((idx, j) => idx + begin[j]);\n buffer.set(x.get(...xLoc), ...loc);\n }\n return buffer.toTensor() as T;\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return ops.tensor([], size) as T;\n }\n\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; i++) {\n const loc = buffer.indexToLoc(i);\n\n const newLoc: number[] = new Array(loc.length);\n for (let j = 0; j < newLoc.length; j++) {\n newLoc[j] = loc[j] * strides[j] + beginIndex[j];\n }\n buffer.set(x.get(...newLoc), ...loc);\n }\n\n return buffer.toTensor() as T;\n }\n\n reverse(x: T, axis: number[]): T {\n const buffer = ops.buffer(x.shape, x.dtype);\n const xBuffer = x.buffer();\n\n for (let i = 0; i < buffer.size; i++) {\n const outLoc = buffer.indexToLoc(i);\n const inLoc = outLoc.slice();\n axis.forEach(ax => inLoc[ax] = x.shape[ax] - 1 - inLoc[ax]);\n buffer.set(xBuffer.get(...inLoc), ...outLoc);\n }\n\n return buffer.toTensor() as T;\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const outShape = concat_util.computeOutShape(\n a.shape, b.shape, 1 /* axis */) as [number, number];\n const buffer = ops.buffer(outShape, a.dtype);\n\n if (a.shape[0] === 1 && b.shape[0] === 1) {\n // Use built-in TypedArray.set() method for speed.\n const aVals = a.dataSync();\n const bVals = b.dataSync();\n const vals = buffer.values;\n vals.set(aVals, 0);\n vals.set(bVals, a.size);\n return buffer.toTensor();\n }\n\n for (let i = 0; i < outShape[0]; ++i) {\n for (let j = 0; j < a.shape[1]; ++j) {\n buffer.set(a.get(i, j), i, j);\n }\n for (let j = 0; j < b.shape[1]; ++j) {\n buffer.set(b.get(i, j), i, j + a.shape[1]);\n }\n }\n return buffer.toTensor();\n }\n\n neg(x: T): T {\n return this.multiply(ops.scalar(-1), x) as T;\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue + bValue) as Tensor;\n }\n\n addN(tensors: T[]): T {\n const vals = tensors.map(t => t.dataSync());\n const result = ops.buffer(tensors[0].shape, tensors[0].dtype);\n const resultVals = result.values;\n for (let i = 0; i < tensors.length; i++) {\n const currVals = vals[i];\n for (let j = 0; j < resultVals.length; j++) {\n resultVals[j] += currVals[j];\n }\n }\n return result.toTensor() as T;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue - bValue) as Tensor;\n }\n\n pow(a: T, b: Tensor): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.pow(aValue, bValue)) as\n T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const sharedDim = transposeA ? a.shape[0] : a.shape[1];\n const leftDim = transposeA ? a.shape[1] : a.shape[0];\n const rightDim = transposeB ? b.shape[0] : b.shape[1];\n\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const [aOuterStep, aInnerStep] =\n transposeA ? [1, a.strides[0]] : [a.strides[0], 1];\n const [bOuterStep, bInnerStep] =\n transposeB ? [b.strides[0], 1] : [1, b.strides[0]];\n\n const aOuterEnd = leftDim * aOuterStep;\n const bOuterEnd = rightDim * bOuterStep;\n\n const result = new Float32Array(leftDim * rightDim);\n let resultIndex = 0;\n\n for (let aOuter = 0; aOuter < aOuterEnd; aOuter += aOuterStep) {\n for (let bOuter = 0; bOuter < bOuterEnd; bOuter += bOuterStep) {\n let aInner = aOuter;\n let bInner = bOuter;\n let sum = 0;\n for (let k = 0; k < sharedDim; ++k) {\n sum += aValues[aInner] * bValues[bInner];\n aInner += aInnerStep;\n bInner += bInnerStep;\n }\n result[resultIndex++] = sum;\n }\n }\n return ops.tensor2d(result, [leftDim, rightDim]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue * bValue) as Tensor;\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => a / b;\n const outputDtype = 'float32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => Math.floor(a / b);\n const outputDtype = 'int32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(outShape, resultDtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let sum = 0;\n for (let j = 0; j < reduceSize; ++j) {\n sum += aVals[offset + j];\n }\n vals[i] = sum;\n }\n return result;\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n const res = [];\n\n // Reshape the segment id's so that they can be broadcast with\n // x. The new shape should be [segmentIds.shape, 1, ..., 1]\n const numIters = x.rank - segmentIds.rank;\n for (let i = 0; i < numIters; ++i) {\n segmentIds = segmentIds.expandDims(i + 1);\n }\n\n for (let i = 0; i < numSegments; ++i) {\n const segmentId = ops.scalar(i, 'int32');\n const mask = ops.equal(segmentId, segmentIds).asType('float32');\n const sum = mask.mul(x).sum(0);\n res.push(sum);\n }\n\n return ops.stack(res);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n let minIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n minIndex = j;\n }\n }\n vals[i] = minIndex;\n }\n return result;\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n let maxIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n maxIndex = j;\n }\n }\n vals[i] = maxIndex;\n }\n return result;\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `backend.cumsum in CPU expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(x.shape, resultDtype);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n const finalDim = x.shape[x.rank - 1];\n const indexAdjuster = reverse ?\n (i: number, j: number) => i + finalDim - j - 1 :\n (i: number, j: number) => i + j;\n for (let i = 0; i < aVals.length; i += finalDim) {\n for (let j = 0; j < finalDim; j++) {\n const idx = indexAdjuster(i, j);\n if (j === 0) {\n vals[idx] = exclusive ? 0 : aVals[idx];\n } else {\n const prevIdx = indexAdjuster(i, j - 1);\n vals[idx] = exclusive ? aVals[prevIdx] + vals[prevIdx] :\n aVals[idx] + vals[prevIdx];\n }\n }\n }\n return result;\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal === bVal) ? 1 : 0;\n });\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal !== bVal) ? 1 : 0;\n });\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal < bVal) ? 1 : 0;\n });\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal <= bVal) ? 1 : 0;\n });\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal > bVal) ? 1 : 0;\n });\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal >= bVal) ? 1 : 0;\n });\n }\n\n logicalNot(x: T): T {\n const values = x.dataSync();\n const newValues = new Int32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = values[i] ? 0 : 1;\n }\n return Tensor.make(x.shape, {values: newValues}, 'bool') as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal && bVal;\n });\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal || bVal;\n });\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const values = condition.dataSync();\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n const result = ops.zeros(a.shape, upcastType(a.dtype, b.dtype));\n const newValues = result.dataSync();\n let index = 0;\n const offset = condition.rank === 0 || condition.rank > 1 || a.rank === 1 ?\n 1 :\n a.shape[1];\n\n for (let i = 0; i < values.length; i++) {\n for (let j = 0; j < offset; j++) {\n if (values[i] === 1) {\n newValues[index++] = aValues[i];\n } else {\n newValues[index++] = bValues[i];\n }\n }\n }\n return result;\n }\n\n where(condition: Tensor): Tensor2D {\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n }\n }\n vals[i] = min;\n }\n return result;\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.min(aVal, bVal));\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const rem = aVal % bVal;\n if ((aVal < 0 && bVal < 0) || (aVal >= 0 && bVal >= 0)) {\n return rem;\n } else {\n return (rem + bVal) % bVal;\n }\n });\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n }\n }\n vals[i] = max;\n }\n return result;\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.max(aVal, bVal));\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let all = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n all = all && value;\n }\n vals[i] = all;\n }\n return result;\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let anyVal = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n anyVal = anyVal || value;\n }\n vals[i] = anyVal;\n }\n return result;\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const diff = aVal - bVal;\n return diff * diff;\n });\n }\n\n ceil(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.ceil(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n floor(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.floor(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sign(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n if (values[i] < 0) {\n newValues[i] = -1;\n } else if (values[i] > 0) {\n newValues[i] = 1;\n } else {\n newValues[i] = 0;\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n round(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n // The algorithm is based on banker's rounding.\n const base = Math.floor(values[i]);\n if (values[i] - base < 0.5) {\n newValues[i] = Math.floor(values[i]);\n } else if (values[i] - base > 0.5) {\n newValues[i] = Math.ceil(values[i]);\n } else {\n if (base % 2.0 === 0.0) {\n newValues[i] = base;\n } else {\n newValues[i] = base + 1.0;\n }\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n exp(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.exp(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n expm1(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.expm1(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log1p(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log1p(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n rsqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = 1 / Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n square(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = value * value;\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n reciprocal(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = 1 / values[i];\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n relu(x: T): T {\n const res = ops.zeros(x.shape, x.dtype);\n const resVals = res.dataSync();\n const inVals = x.dataSync();\n for (let i = 0; i < inVals.length; ++i) {\n resVals[i] = Math.max(0, inVals[i]);\n }\n return res as T;\n }\n\n elu(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = v;\n } else {\n resultValues[i] = (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const resultValues = new Float32Array(y.size);\n const values = y.dataSync();\n const dyValues = dy.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 1) {\n resultValues[i] = dyValues[i];\n } else {\n resultValues[i] = dyValues[i] * (v + 1);\n }\n }\n return Tensor.make(y.shape, {values: resultValues}) as T;\n }\n\n selu(x: T): T {\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n const scaleAlpha = selu_util.SELU_SCALEALPHA;\n const scale = selu_util.SELU_SCALE;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = scale * v;\n } else {\n resultValues[i] = scaleAlpha * (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.min(max, Math.max(min, values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n abs(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.abs(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n int(x: T): T {\n const resultValues = new Int32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = values[i];\n }\n return Tensor.make(x.shape, {values: resultValues}, 'int32');\n }\n\n sigmoid(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = 1 / (1 + Math.exp(-values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n softplus(x: T): T {\n // mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n\n // epsilon is the difference between 1.0 and the next representable float.\n // For a single precision 32 bit float this should be 2^-23, see:\n // https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n const epsilon = 1.1920928955078125e-7;\n const threshold = Math.log(epsilon) + 2.0;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n\n for (let i = 0; i < values.length; ++i) {\n // Value above which exp(x) may overflow, but softplus(x) == x\n // is within machine epsilon.\n const tooLarge = values[i] > -threshold;\n\n // Value below which exp(x) may underflow, but softplus(x) == exp(x)\n // is within machine epsilon.\n const tooSmall = values[i] < threshold;\n\n const expX = Math.exp(values[i]);\n let result;\n\n if (tooSmall) {\n result = expX;\n } else if (tooLarge) {\n result = values[i];\n } else {\n result = Math.log(1.0 + expX);\n }\n resultValues[i] = result;\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n sin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.tan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan2(a: T, b: T): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.atan2(aValue, bValue)) as\n T;\n }\n\n sinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = util.tanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n erf(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n const p = erf_util.ERF_P;\n const a1 = erf_util.ERF_A1;\n const a2 = erf_util.ERF_A2;\n const a3 = erf_util.ERF_A3;\n const a4 = erf_util.ERF_A4;\n const a5 = erf_util.ERF_A5;\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n const t = 1.0 / (1.0 + p * v);\n resultValues[i] = 1.0 -\n (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t *\n Math.exp(-v * v);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n step(x: T, alpha = 0): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n if (isNaN(value)) {\n resultValues[i] = NaN;\n } else {\n resultValues[i] = value > 0 ? 1 : alpha;\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; wR++) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; wC++) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, d2);\n dotProd += pixel * weight;\n }\n }\n }\n y.set(dotProd, b, yR, yC, d2);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let d2 = 0; d2 < outChannels; ++d2) {\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + d2];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n // Need to convolve.\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, d2);\n }\n }\n }\n }\n return dW.toTensor();\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n for (let q = 0; q < chMul; ++q) {\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, q);\n dotProd += pixel * weight;\n }\n }\n y.set(dotProd, b, yR, yC, d1 * chMul + q);\n }\n }\n }\n }\n }\n\n return y.toTensor();\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n const chMul = outChannels / inChannels;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let dm = 0; dm < chMul; ++dm) {\n const d2 = d1 * chMul + dm;\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + dm];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n const d1 = Math.trunc(d2 / chMul);\n const dm = d2 % chMul;\n\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, dm);\n }\n }\n }\n return dW.toTensor();\n }\n\n tile(x: T, reps: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[i] * reps[i];\n }\n const result = ops.buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = new Array(x.rank);\n for (let i = 0; i < originalLoc.length; i++) {\n originalLoc[i] = newLoc[i] % x.shape[i];\n }\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const outShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + x.shape[i] + p[1] /* afterPad */);\n const start = paddings.map(p => p[0]);\n const xBuffer = x.buffer();\n const buffer = ops.buffer(outShape, x.dtype);\n if (constantValue !== 0) {\n buffer.values.fill(constantValue);\n }\n\n for (let i = 0; i < x.size; i++) {\n const coords = xBuffer.indexToLoc(i);\n const outCoords = coords.map((c, i) => c + start[i]);\n buffer.set(x.get(...coords), ...outCoords);\n }\n return buffer.toTensor() as T;\n }\n\n transpose(x: T, perm: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[perm[i]];\n }\n const values = x.dataSync();\n const result = buffer(newShape, x.dtype);\n\n const xBuf = x.buffer();\n for (let i = 0; i < x.size; ++i) {\n const loc = xBuf.indexToLoc(i);\n\n // Permute location.\n const newLoc: number[] = new Array(loc.length);\n for (let i = 0; i < newLoc.length; i++) {\n newLoc[i] = loc[perm[i]];\n }\n\n const newIndex = result.locToIndex(newLoc);\n result.values[newIndex] = values[i];\n }\n return result.toTensor() as T;\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const newShape: number[] = x.shape.slice();\n const indicesValues = indices.dataSync();\n newShape[axis] = indicesValues.length;\n const result = buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n\n for (let i = 0; i < result.size; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = newLoc.slice();\n originalLoc[axis] = indicesValues[newLoc[axis]];\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private pool(x: Tensor4D, convInfo: Conv2DInfo, poolType: 'max'|'avg'):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const y = ops.buffer(convInfo.outShape, 'float32');\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n\n let minMaxValue =\n (poolType === 'max' ? Number.NEGATIVE_INFINITY :\n Number.POSITIVE_INFINITY);\n let avgValue = 0;\n let count = 0;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const pixel = x.get(b, xR, xC, d);\n if ((poolType === 'max' && pixel > minMaxValue)) {\n minMaxValue = pixel;\n } else if (poolType === 'avg') {\n avgValue += pixel;\n count++;\n }\n }\n if (isNaN(minMaxValue)) {\n break;\n }\n }\n y.set(\n poolType === 'avg' ? avgValue / count : minMaxValue, b, yR, yC,\n d);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'max');\n }\n\n private maxPoolPositions(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const maxPositions = ops.buffer(convInfo.outShape, 'int32');\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n let maxValue = Number.NEGATIVE_INFINITY;\n let maxPosition = -1;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n const wR = xR - xRCorner;\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const wC = xC - xCCorner;\n const pixel = x.get(b, xR, xC, d);\n if (pixel > maxValue) {\n maxValue = pixel;\n maxPosition = wR * filterWidth + wC;\n }\n }\n }\n maxPositions.set(maxPosition, b, yR, yC, d);\n }\n }\n }\n }\n return maxPositions.toTensor();\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const maxPositions = this.maxPoolPositions(x, convInfo);\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n const maxPos = filterHeight * filterWidth - 1 -\n maxPositions.get(b, dyR, dyC, d);\n const curPos = wR * filterWidth + wC;\n\n const mask = maxPos === curPos ? 1 : 0;\n if (mask === 0) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel * mask;\n }\n }\n dx.set(dotProd, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel;\n }\n }\n dx.set(dotProd * avgMultiplier, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'avg').toFloat();\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n\n const sourceRowFloor = Math.floor(sourceFracRow);\n const sourceRowCeil =\n Math.min(oldHeight - 1, Math.ceil(sourceFracRow));\n const sourceColFloor = Math.floor(sourceFracCol);\n const sourceColCeil =\n Math.min(oldWidth - 1, Math.ceil(sourceFracCol));\n\n const topLeft = x.get(b, sourceRowFloor, sourceColFloor, d);\n const bottomLeft = x.get(b, sourceRowCeil, sourceColFloor, d);\n const topRight = x.get(b, sourceRowFloor, sourceColCeil, d);\n const bottomRight = x.get(b, sourceRowCeil, sourceColCeil, d);\n\n const rowFrac = sourceFracRow - sourceRowFloor;\n const colFrac = sourceFracCol - sourceColFloor;\n\n const top = topLeft + (topRight - topLeft) * colFrac;\n const bottom = bottomLeft + (bottomRight - bottomLeft) * colFrac;\n const newValue = top + (bottom - top) * rowFrac;\n\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n // Reference implementation\n // tslint:disable-next-line:max-line-length\n // https://github.com/tensorflow/tensorflow/blob/3039375c86a5bbc9610c7725dcaa95d635f87ba2/tensorflow/core/kernels/resize_bilinear_op.cc#L275\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < yHeight; r++) {\n const dxR = r * heightScale;\n const topDxRIndex = Math.floor(dxR);\n const bottomDxRIndex = Math.min(Math.ceil(dxR), xHeight - 1);\n const dxRLerp = dxR - topDxRIndex;\n const inverseDxRLerp = 1.0 - dxRLerp;\n\n for (let c = 0; c < yWidth; c++) {\n const dxC = c * widthScale;\n const leftDxCIndex = Math.floor(dxC);\n const rightDxCIndex = Math.min(Math.ceil(dxC), xWidth - 1);\n const dxCLerp = dxC - leftDxCIndex;\n const inverseDxCLerp = 1.0 - dxCLerp;\n\n for (let d = 0; d < depth; d++) {\n const dyVal = dy.get(b, r, c, d);\n\n let topLeft = output.get(b, topDxRIndex, leftDxCIndex, d);\n topLeft += dyVal * inverseDxRLerp * inverseDxCLerp;\n output.set(topLeft, b, topDxRIndex, leftDxCIndex, d);\n\n let topRight = output.get(b, topDxRIndex, rightDxCIndex, d);\n topRight += dyVal * inverseDxRLerp * dxCLerp;\n output.set(topRight, b, topDxRIndex, rightDxCIndex, d);\n\n let bottomLeft = output.get(b, bottomDxRIndex, leftDxCIndex, d);\n bottomLeft += dyVal * dxRLerp * inverseDxCLerp;\n output.set(bottomLeft, b, bottomDxRIndex, leftDxCIndex, d);\n\n let bottomRight = output.get(b, bottomDxRIndex, rightDxCIndex, d);\n bottomRight += dyVal * dxRLerp * dxCLerp;\n output.set(bottomRight, b, bottomDxRIndex, rightDxCIndex, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n const sourceNearestRow = Math.min(\n oldHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n const sourceNearestCol = Math.min(\n oldWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n const newValue = x.get(b, sourceNearestRow, sourceNearestCol, d);\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n // Loop over the output space.\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < xHeight; r++) {\n for (let c = 0; c < xWidth; c++) {\n // Compute bounds for where in dy we will look\n const startRLerp = Math.floor(r * invHeightScale);\n const startDyR = Math.floor(startRLerp - (winHeight / 2));\n\n const startCLerp = Math.floor(c * invWidthScale);\n const startDyC = Math.floor(startCLerp - (winWidth / 2));\n\n for (let d = 0; d < depth; d++) {\n let accum = 0;\n // loop over dy\n\n for (let dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n const dyR = dyROffset + startDyR;\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= yHeight) {\n continue;\n }\n\n for (let dyCOffSet = 0; dyCOffSet < winWidth; dyCOffSet++) {\n const dyC = dyCOffSet + startDyC;\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= yWidth) {\n continue;\n }\n\n const sourceFracRow =\n effectiveXSize[0] * (dyR / effectiveYSize[0]);\n const sourceFracCol =\n effectiveXSize[1] * (dyC / effectiveYSize[1]);\n\n const sourceNearestRow = Math.min(\n xHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n\n const sourceNearestCol = Math.min(\n xWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n\n if (r === sourceNearestRow && c === sourceNearestCol) {\n accum += dy.get(b, dyR, dyC, d);\n }\n }\n }\n\n output.set(accum, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const xValues = x.dataSync();\n const meanValues = mean.dataSync();\n const varianceValues = variance.dataSync();\n const scaleValues = scale ? scale.dataSync() : new Float32Array([1]);\n const offsetValues = offset ? offset.dataSync() : new Float32Array([0]);\n const outValues = new Float32Array(xValues.length);\n\n for (let i = 0; i < xValues.length; i++) {\n outValues[i] = offsetValues[i % offsetValues.length] +\n (xValues[i] - meanValues[i % meanValues.length]) *\n scaleValues[i % scaleValues.length] /\n Math.sqrt(\n varianceValues[i % varianceValues.length] + varianceEpsilon);\n }\n return tensor4d(outValues, x.shape);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const output = ops.buffer(x.shape, 'float32');\n const rad = radius;\n const maxD = output.shape[3] - 1;\n\n function sumAcrossChannels(\n b: number, r: number, c: number, d: number): number {\n let sum = 0.0;\n for (let j = Math.max(0, d - rad); j <= Math.min(d + rad, maxD); j++) {\n const z = x.get(b, r, c, j);\n sum += z * z;\n }\n return sum;\n }\n\n for (let b = 0; b < output.shape[0]; b++) {\n for (let r = 0; r <= output.shape[1]; r++) {\n for (let c = 0; c < output.shape[2]; c++) {\n for (let d = 0; d < output.shape[3]; d++) {\n const sum = sumAcrossChannels(b, r, c, d);\n const val = x.get(b, r, c, d) * Math.pow(bias + alpha * sum, -beta);\n output.set(val, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const batch = dy.shape[0];\n const rows = dy.shape[1];\n const cols = dy.shape[2];\n const depth = dy.shape[3];\n const output = ops.buffer([batch, rows, cols, depth], 'float32');\n\n for (let b = 0; b < batch; ++b) {\n for (let r = 0; r < rows; ++r) {\n for (let c = 0; c < cols; ++c) {\n for (let d = 0; d < depth; ++d) {\n const depthBegin = Math.max(0, d - depthRadius);\n const depthEnd = Math.min(depth, d + depthRadius + 1);\n\n let norm = 0;\n for (let k = depthBegin; k < depthEnd; ++k) {\n norm += inputImage.get(b, r, c, k) * inputImage.get(b, r, c, k);\n }\n norm = alpha * norm + bias;\n for (let k = depthBegin; k < depthEnd; ++k) {\n let dyi = -2 * alpha * beta * inputImage.get(b, r, c, k) *\n outputImage.get(b, r, c, d) / norm;\n if (d === k) {\n dyi += Math.pow(norm, -beta);\n }\n dyi *= dy.get(b, r, c, d);\n output.set(dyi + output.get(b, r, c, k), b, r, c, k);\n }\n }\n }\n }\n }\n return output.toTensor();\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probabilities = normalized ? logits : ops.softmax(logits);\n const batchSize = probabilities.shape[0];\n const numEvents = probabilities.shape[1];\n const res = ops.zeros([batchSize, numSamples], 'int32');\n const resVals = res.dataSync();\n const probVals = probabilities.dataSync();\n\n for (let b = 0; b < batchSize; ++b) {\n const offset = b * numEvents;\n // The cdf won't include the last event. It will be implicit if no other\n // event happened.\n const cdf = new Float32Array(numEvents - 1);\n cdf[0] = probVals[offset];\n for (let event = 1; event < cdf.length; ++event) {\n cdf[event] = cdf[event - 1] + probVals[offset + event];\n }\n\n const random = seedrandom.alea(seed.toString());\n const outOffset = b * numSamples;\n for (let sampleId = 0; sampleId < numSamples; ++sampleId) {\n const r = random();\n\n // Assume last event happened by default.\n resVals[outOffset + sampleId] = cdf.length;\n\n for (let event = 0; event < cdf.length; event++) {\n if (r < cdf[event]) {\n resVals[outOffset + sampleId] = event;\n break;\n }\n }\n }\n }\n return res;\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const res = new Float32Array(indices.size * depth);\n res.fill(offValue);\n\n for (let event = 0; event < indices.size; ++event) {\n if (indices.get(event) >= 0 && indices.get(event) < depth) {\n res[event * depth + indices.get(event)] = onValue;\n }\n }\n return ops.tensor2d(res, [indices.size, depth], 'int32');\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private broadcastedBinaryOp(\n a: Tensor, b: Tensor, dtype: DataType,\n op: (a: number, b: number) => number): Tensor {\n const newShape =\n broadcast_util.assertAndGetBroadcastShape(a.shape, b.shape);\n const result = ops.buffer(newShape, dtype);\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const aBroadcastDims = broadcast_util.getBroadcastDims(a.shape, newShape);\n const bBroadcastDims = broadcast_util.getBroadcastDims(b.shape, newShape);\n\n const aBuf = a.buffer();\n const bBuf = b.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const loc = result.indexToLoc(i);\n\n const aLoc = loc.slice(-a.rank);\n aBroadcastDims.forEach(d => aLoc[d] = 0);\n const aIndex = aBuf.locToIndex(aLoc);\n\n const bLoc = loc.slice(-b.rank);\n bBroadcastDims.forEach(d => bLoc[d] = 0);\n const bIndex = bBuf.locToIndex(bLoc);\n\n result.values[i] = op(aValues[aIndex], bValues[bIndex]);\n }\n return result.toTensor();\n }\n dispose() {}\n}\n\nENV.registerBackend(\n 'cpu', () => new MathBackendCPU(), 1 /* priority */, setTensorTracker);\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nconst delayCallback = typeof requestAnimationFrame !== 'undefined' ?\n requestAnimationFrame : // Browsers\n setImmediate; // Node.js\n\n/**\n * Returns a promise that resolve when a requestAnimationFrame has completed.\n *\n * On Node.js this uses setImmediate instead of requestAnimationFrame.\n *\n * This is simply a sugar method so that users can do the following:\n * `await tf.nextFrame();`\n */\n/** @doc {heading: 'Performance', subheading: 'Timing'} */\nfunction nextFrame(): Promise {\n return new Promise(resolve => delayCallback(() => resolve()));\n}\n\nexport {nextFrame};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/* Type definitions for exporting and importing of models. */\n\n/**\n * A map from Tensor dtype to number of bytes per element of the Tensor.\n */\nexport const DTYPE_VALUE_SIZE_MAP: {[dtype: string]: number} = {\n 'float32': 4,\n 'int32': 4,\n 'uint16': 2,\n 'uint8': 1,\n 'bool': 1,\n};\n\n/**\n * A weight manifest.\n *\n * The weight manifest consists of an ordered list of weight-manifest groups.\n * Each weight-manifest group (\"group\" for short hereafter) consists of a\n * number of weight values stored in a number of paths.\n * See the documentation of `WeightManifestGroupConfig` below for more details.\n */\nexport declare type WeightsManifestConfig = WeightsManifestGroupConfig[];\n\n/**\n * A weight-manifest group.\n *\n * Consists of an ordered list of weight values encoded in binary format,\n * stored in an ordered list of paths.\n */\nexport declare interface WeightsManifestGroupConfig {\n /**\n * An ordered list of paths.\n *\n * Paths are intentionally abstract in order to be general. For example, they\n * can be relative URL paths or relative paths on the file system.\n */\n paths: string[];\n\n /**\n * Specifications of the weights stored in the paths.\n */\n weights: WeightsManifestEntry[];\n}\n\n/**\n * An entry in the weight manifest.\n *\n * The entry contains specification of a weight.\n */\nexport declare interface WeightsManifestEntry {\n /**\n * Name of the weight, e.g., 'Dense_1/bias'\n */\n name: string;\n\n /**\n * Shape of the weight.\n */\n shape: number[];\n\n /**\n * Data type of the weight.\n */\n dtype: 'float32'|'int32'|'bool';\n\n /**\n * Information for dequantization of the weight.\n */\n quantization?: {\n scale: number, // The scaling constant to multiply by.\n min: number, // The (possibly nudged) minimum weight to add.\n dtype: 'uint16'|'uint8' // The dtype of the quantized weights.\n };\n}\n\n/**\n * Options for saving a model.\n */\nexport interface SaveConfig {\n /**\n * Whether to save only the trainable weights of the model, ignoring the\n * untrainable ones.\n */\n trainableOnly?: boolean;\n}\n\n/**\n * Result of a saving operation.\n */\nexport interface SaveResult {\n /**\n * Information about the model artifacts saved.\n */\n modelArtifactsInfo: ModelArtifactsInfo;\n\n /**\n * HTTP responses from the server that handled the model-saving request (if\n * any). This is applicable only to server-based saving routes.\n */\n responses?: Response[];\n\n /**\n * Error messages and related data (if any).\n */\n errors?: Array<{}|string>;\n}\n\nexport declare interface ModelArtifactsInfo {\n /**\n * Timestamp for when the model is saved.\n */\n dateSaved: Date;\n\n /**\n * Type of the model topology\n *\n * Possible values:\n * - JSON: JSON config (human-readable, e.g., Keras JSON).\n * - GraphDef: TensorFlow\n * [GraphDef](https://www.tensorflow.org/extend/tool_developers/#graphdef)\n * protocal buffer (binary).\n */\n modelTopologyType: 'JSON'|'GraphDef';\n\n /**\n * Size of model topology (Keras JSON or GraphDef), in bytes.\n */\n modelTopologyBytes?: number;\n\n /**\n * Size of weight specification or manifest, in bytes.\n */\n weightSpecsBytes?: number;\n\n /**\n * Size of weight value data, in bytes.\n */\n weightDataBytes?: number;\n}\n\n/**\n * The serialized artifacts of a model, including topology and weights.\n *\n * The `modelTopology`, `weightSpecs` and `weightData` fields of this interface\n * are optional, in order to support topology- or weights-only saving and\n * loading.\n */\nexport declare interface ModelArtifacts {\n /**\n * Model topology.\n *\n * For Keras-style `tf.Model`s, this is a JSON object.\n * For TensorFlow-style models (e.g., `FrozenModel`), this is a binary buffer\n * carrying the `GraphDef` protocol buffer.\n */\n modelTopology?: {}|ArrayBuffer;\n\n /**\n * Weight specifications.\n *\n * This corresponds to the weightsData below.\n */\n weightSpecs?: WeightsManifestEntry[];\n\n /**\n * Binary buffer for all weight values concatenated in the order specified\n * by `weightSpecs`.\n */\n weightData?: ArrayBuffer;\n}\n\n/**\n * Type definition for handlers of loading operations.\n */\nexport type LoadHandler = () => Promise;\n\n/**\n * Type definition for handlers of saving operations.\n */\nexport type SaveHandler = (modelArtifact: ModelArtifacts) =>\n Promise;\n\n/**\n * Interface for a model import/export handler.\n *\n * The `save` and `load` handlers are both optional, in order to allow handlers\n * that support only saving or loading.\n */\n// tslint:disable-next-line:interface-name\nexport interface IOHandler {\n save?: SaveHandler;\n load?: LoadHandler;\n}\n\n/**\n * An interface for the manager of a model store.\n *\n * A model store is defined as a storage medium on which multiple models can\n * be stored. Each stored model has a unique `path` as its identifier.\n * A `ModelStoreManager` for the store allows actions including\n *\n * - Listing the models stored in the store.\n * - Deleting a model from the store.\n */\nexport interface ModelStoreManager {\n /**\n * List all models in the model store.\n *\n * @returns A dictionary mapping paths of existing models to their\n * model artifacts info. Model artifacts info include type of the model's\n * topology, byte sizes of the topology, weights, etc.\n */\n listModels(): Promise<{[path: string]: ModelArtifactsInfo}>;\n\n /**\n * Remove a model specified by `path`.\n *\n * @param path\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n removeModel(path: string): Promise;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport {sizeFromShape} from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, ModelArtifacts, ModelArtifactsInfo, WeightsManifestEntry} from './types';\n\n/**\n * Encode a map from names to weight values as an ArrayBuffer, along with an\n * `Array` of `WeightsManifestEntry` as specification of the encoded weights.\n *\n * This function does not perform sharding.\n *\n * This function is the reverse of `decodeWeights`.\n *\n * @param tensors A map (\"dict\") from names to tensors.\n * @returns A `Promise` of\n * - A flat `ArrayBuffer` with all the binary values of the `Tensor`s\n * concatenated.\n * - An `Array` of `WeightManifestEntry`s, carrying information including\n * tensor names, `dtype`s and shapes.\n * @throws Error: on unsupported tensor `dtype`.\n */\nexport async function encodeWeights(tensors: NamedTensorMap):\n Promise<{data: ArrayBuffer, specs: WeightsManifestEntry[]}> {\n // TODO(adarob, cais): Support quantization.\n const specs: WeightsManifestEntry[] = [];\n const dataPromises: Array> = [];\n for (const name in tensors) {\n const t = tensors[name];\n\n if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool') {\n throw new Error(`Unsupported dtype in weight '${name}': ${t.dtype}`);\n }\n specs.push({name, shape: t.shape, dtype: t.dtype});\n dataPromises.push(t.data());\n }\n const tensorValues = await Promise.all(dataPromises);\n return {data: concatenateTypedArrays(tensorValues), specs};\n}\n\n/**\n * Decode flat ArrayBuffer as weights.\n *\n * This function does not handle sharding.\n *\n * This function is the reverse of `encodeWeights`.\n *\n * @param buffer A flat ArrayBuffer carrying the binary values of the tensors\n * concatenated in the order specified in `specs`.\n * @param specs Specifications of the names, dtypes and shapes of the tensors\n * whose value are encoded by `buffer`.\n * @return A map from tensor name to tensor value, with the names corresponding\n * to names in `specs`.\n * @throws Error, if any of the tensors has unsupported dtype.\n */\nexport function decodeWeights(\n buffer: ArrayBuffer, specs: WeightsManifestEntry[]): NamedTensorMap {\n // TODO(adarob, cais): Support quantization.\n const out: NamedTensorMap = {};\n let offset = 0;\n for (const spec of specs) {\n const name = spec.name;\n const dtype = spec.dtype;\n const shape = spec.shape;\n\n if (spec.quantization != null) {\n throw new Error(\n `decodeWeights does not support quantization yet, but encountered ` +\n `weight '${name} with quantization.'`);\n }\n\n const size = sizeFromShape(shape);\n let value: Tensor;\n if (dtype === 'float32') {\n value = tensor(new Float32Array(buffer, offset, size), shape, 'float32');\n } else if (dtype === 'int32') {\n value = tensor(new Int32Array(buffer, offset, size), shape, 'int32');\n } else if (dtype === 'bool') {\n value = tensor(new Uint8Array(buffer, offset, size), shape, 'bool');\n } else {\n throw new Error(`Unsupported dtype in weight '${name}': ${dtype}`);\n }\n out[name] = value;\n\n offset += size * DTYPE_VALUE_SIZE_MAP[dtype];\n }\n return out;\n}\n\n/**\n * Concatenate TypedArrays into an ArrayBuffer.\n */\nexport function concatenateTypedArrays(xs: TypedArray[]): ArrayBuffer {\n // TODO(adarob, cais): Support quantization.\n if (xs === null) {\n throw new Error(`Invalid input value: ${JSON.stringify(xs)}`);\n }\n\n let totalByteLength = 0;\n\n // `normalizedXs` is here for this reason: a `TypedArray`'s `buffer'\n // can have a different byte length from that of the `TypedArray` itself,\n // for example, when the `TypedArray` is created from an offset in an\n // `ArrayBuffer`. `normliazedXs` holds `TypedArray`s whose `buffer`s match\n // the `TypedArray` in byte length. If an element of `xs` does not show\n // this property, a new `TypedArray` that satisfy this property will be\n // constructed and pushed into `normalizedXs`.\n const normalizedXs: TypedArray[] = [];\n xs.forEach((x: TypedArray) => {\n totalByteLength += x.byteLength;\n // tslint:disable:no-any\n normalizedXs.push(\n x.byteLength === x.buffer.byteLength ? x :\n new (x.constructor as any)(x));\n if (!(x as any instanceof Float32Array || x as any instanceof Int32Array ||\n x as any instanceof Uint8Array)) {\n throw new Error(`Unsupported TypedArray subtype: ${x.constructor.name}`);\n }\n // tslint:enable:no-any\n });\n\n const y = new Uint8Array(totalByteLength);\n let offset = 0;\n normalizedXs.forEach((x: TypedArray) => {\n y.set(new Uint8Array(x.buffer), offset);\n offset += x.byteLength;\n });\n\n return y.buffer;\n}\n\n// Use Buffer on Node.js instead of Blob/atob/btoa\nconst useNodeBuffer = typeof Buffer !== 'undefined' &&\n (typeof Blob === 'undefined' || typeof atob === 'undefined' ||\n typeof btoa === 'undefined');\n\n/**\n * Calculate the byte length of a JavaScript string.\n *\n * Note that a JavaScript string can contain wide characters, therefore the\n * length of the string is not necessarily equal to the byte length.\n *\n * @param str Input string.\n * @returns Byte length.\n */\nexport function stringByteLength(str: string): number {\n if (useNodeBuffer) {\n return Buffer.byteLength(str);\n }\n return new Blob([str]).size;\n}\n\n/**\n * Encode an ArrayBuffer as a base64 encoded string.\n *\n * @param buffer `ArrayBuffer` to be converted.\n * @returns A string that base64-encodes `buffer`.\n */\nexport function arrayBufferToBase64String(buffer: ArrayBuffer): string {\n if (useNodeBuffer) {\n return Buffer.from(buffer).toString('base64');\n }\n return btoa(String.fromCharCode.apply(null, new Uint8Array(buffer)));\n}\n\n/**\n * Decode a base64 string as an ArrayBuffer.\n *\n * @param str Base64 string.\n * @returns Decoded `ArrayBuffer`.\n */\nexport function base64StringToArrayBuffer(str: string): ArrayBuffer {\n if (useNodeBuffer) {\n const buf = Buffer.from(str, 'base64');\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);\n }\n const s = atob(str);\n const buffer = new Uint8Array(s.length);\n for (let i = 0; i < s.length; ++i) {\n buffer.set([s.charCodeAt(i)], i);\n }\n return buffer.buffer;\n}\n\n/**\n * Concatenate a number of ArrayBuffers into one.\n *\n * @param buffers A number of array buffers to concatenate.\n * @returns Result of concatenating `buffers` in order.\n */\nexport function concatenateArrayBuffers(buffers: ArrayBuffer[]): ArrayBuffer {\n let totalByteLength = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n totalByteLength += buffer.byteLength;\n });\n\n const temp = new Uint8Array(totalByteLength);\n let offset = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n temp.set(new Uint8Array(buffer), offset);\n offset += buffer.byteLength;\n });\n return temp.buffer;\n}\n\n/**\n * Get the basename of a path.\n *\n * Behaves in a way analogous to Linux's basename command.\n *\n * @param path\n */\nexport function basename(path: string): string {\n const SEPARATOR = '/';\n path = path.trim();\n while (path.endsWith(SEPARATOR)) {\n path = path.slice(0, path.length - 1);\n }\n const items = path.split(SEPARATOR);\n return items[items.length - 1];\n}\n\n/**\n * Populate ModelArtifactsInfo fields for a model with JSON topology.\n * @param modelArtifacts\n * @returns A ModelArtifactsInfo object.\n */\nexport function getModelArtifactsInfoForJSON(modelArtifacts: ModelArtifacts):\n ModelArtifactsInfo {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error('Expected JSON model topology, received ArrayBuffer.');\n }\n\n return {\n dateSaved: new Date(),\n modelTopologyType: 'JSON',\n modelTopologyBytes: modelArtifacts.modelTopology == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.modelTopology)),\n weightSpecsBytes: modelArtifacts.weightSpecs == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)),\n weightDataBytes: modelArtifacts.weightData == null ?\n 0 :\n modelArtifacts.weightData.byteLength,\n };\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {IOHandler} from './types';\n\nexport type IORouter = (url: string) => IOHandler;\n\nexport class IORouterRegistry {\n // Singleton instance.\n private static instance: IORouterRegistry;\n\n private saveRouters: IORouter[];\n private loadRouters: IORouter[];\n\n private constructor() {\n this.saveRouters = [];\n this.loadRouters = [];\n }\n\n private static getInstance(): IORouterRegistry {\n if (IORouterRegistry.instance == null) {\n IORouterRegistry.instance = new IORouterRegistry();\n }\n return IORouterRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerSaveRouter(saveRouter: IORouter) {\n IORouterRegistry.getInstance().saveRouters.push(saveRouter);\n }\n\n /**\n * Register a load-handler router.\n *\n * @param loadRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `load` method defined or `null`.\n */\n static registerLoadRouter(loadRouter: IORouter) {\n IORouterRegistry.getInstance().loadRouters.push(loadRouter);\n }\n\n /**\n * Look up IOHandler for saving, given a URL-like string.\n *\n * @param url\n * @returns If only one match is found, an instance of IOHandler with the\n * `save` method defined. If no match is found, `null`.\n * @throws Error, if more than one match is found.\n */\n static getSaveHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'save');\n }\n\n /**\n * Look up IOHandler for loading, given a URL-like string.\n *\n * @param url\n * @returns All valid handlers for `url`, given the currently registered\n * handler routers.\n */\n static getLoadHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'load');\n }\n\n private static getHandlers(url: string, handlerType: 'save'|'load'):\n IOHandler[] {\n const validHandlers: IOHandler[] = [];\n const routers = handlerType === 'load' ? this.getInstance().loadRouters :\n this.getInstance().saveRouters;\n routers.forEach(router => {\n const handler = router(url);\n if (handler !== null) {\n validHandlers.push(handler);\n }\n });\n return validHandlers;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Classes and functions for model management across multiple storage mediums.\n *\n * Supported client actions:\n * - Listing models on all registered storage mediums.\n * - Remove model by URL from any registered storage mediums, by using URL\n * string.\n * - Moving or copying model from one path to another in the same medium or from\n * one medium to another, by using URL strings.\n */\n\nimport {assert} from '../util';\n\nimport {IORouterRegistry} from './router_registry';\nimport {ModelArtifactsInfo, ModelStoreManager} from './types';\n\nconst URL_SCHEME_SUFFIX = '://';\n\nexport class ModelStoreManagerRegistry {\n // Singleton instance.\n private static instance: ModelStoreManagerRegistry;\n\n private managers: {[scheme: string]: ModelStoreManager};\n\n private constructor() {\n this.managers = {};\n }\n\n private static getInstance(): ModelStoreManagerRegistry {\n if (ModelStoreManagerRegistry.instance == null) {\n ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry();\n }\n return ModelStoreManagerRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerManager(scheme: string, manager: ModelStoreManager) {\n assert(scheme != null, 'scheme must not be undefined or null.');\n if (scheme.endsWith(URL_SCHEME_SUFFIX)) {\n scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX));\n }\n assert(scheme.length > 0, 'scheme must not be an empty string.');\n const registry = ModelStoreManagerRegistry.getInstance();\n assert(\n registry.managers[scheme] == null,\n `A model store manager is already registered for scheme '${scheme}'.`);\n registry.managers[scheme] = manager;\n }\n\n static getManager(scheme: string): ModelStoreManager {\n const manager = this.getInstance().managers[scheme];\n if (manager == null) {\n throw new Error(`Cannot find model manager for scheme '${scheme}'`);\n }\n return manager;\n }\n\n static getSchemes(): string[] {\n return Object.keys(this.getInstance().managers);\n }\n}\n\n/**\n * Helper method for parsing a URL string into a scheme and a path.\n *\n * @param url E.g., 'localstorage://my-model'\n * @returns A dictionary with two fields: scheme and path.\n * Scheme: e.g., 'localstorage' in the example above.\n * Path: e.g., 'my-model' in the example above.\n */\nfunction parseURL(url: string): {scheme: string, path: string} {\n if (url.indexOf(URL_SCHEME_SUFFIX) === -1) {\n throw new Error(\n `The url string provided does not contain a scheme. ` +\n `Supported schemes are: ` +\n `${ModelStoreManagerRegistry.getSchemes().join(',')}`);\n }\n return {\n scheme: url.split(URL_SCHEME_SUFFIX)[0],\n path: url.split(URL_SCHEME_SUFFIX)[1],\n };\n}\n\nasync function cloneModelInternal(\n sourceURL: string, destURL: string,\n deleteSource = false): Promise {\n assert(\n sourceURL !== destURL,\n `Old path and new path are the same: '${sourceURL}'`);\n\n const loadHandlers = IORouterRegistry.getLoadHandlers(sourceURL);\n assert(\n loadHandlers.length > 0,\n `Copying failed because no load handler is found for source URL ${\n sourceURL}.`);\n assert(\n loadHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `load handlers for source URL ${sourceURL}.`);\n const loadHandler = loadHandlers[0];\n\n const saveHandlers = IORouterRegistry.getSaveHandlers(destURL);\n assert(\n saveHandlers.length > 0,\n `Copying failed because no save handler is found for destination URL ` +\n `${destURL}.`);\n assert(\n saveHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `save handlers for destination URL ${destURL}.`);\n const saveHandler = saveHandlers[0];\n\n const sourceScheme = parseURL(sourceURL).scheme;\n const sourcePath = parseURL(sourceURL).path;\n const sameMedium = sourceScheme === parseURL(sourceURL).scheme;\n\n const modelArtifacts = await loadHandler.load();\n\n // If moving within the same storage medium, remove the old model as soon as\n // the loading is done. Without doing this, it is possible that the combined\n // size of the two models will cause the cloning to fail.\n if (deleteSource && sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n const saveResult = await saveHandler.save(modelArtifacts);\n\n // If moving between mediums, the deletion is done after the save succeeds.\n // This guards against the case in which saving to the destination medium\n // fails.\n if (deleteSource && !sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n return saveResult.modelArtifactsInfo;\n}\n\n/**\n * List all models stored in registered storage mediums.\n *\n * For a web browser environment, the registered mediums are Local Storage and\n * IndexedDB.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @returns A `Promise` of a dictionary mapping URLs of existing models to\n * their model artifacts info. URLs include medium-specific schemes, e.g.,\n * 'indexeddb://my/model/1'. Model artifacts info include type of the\n * model's topology, byte sizes of the topology, weights, etc.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function listModels(): Promise<{[url: string]: ModelArtifactsInfo}> {\n const schemes = ModelStoreManagerRegistry.getSchemes();\n const out: {[url: string]: ModelArtifactsInfo} = {};\n for (const scheme of schemes) {\n const schemeOut =\n await ModelStoreManagerRegistry.getManager(scheme).listModels();\n for (const path in schemeOut) {\n const url = scheme + URL_SCHEME_SUFFIX + path;\n out[url] = schemeOut[path];\n }\n }\n return out;\n}\n\n/**\n * Remove a model specified by URL from a reigstered storage medium.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @param url A URL to a stored model, with a scheme prefix, e.g.,\n * 'localstorage://my-model-1', 'indexeddb://my/model/2'.\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function removeModel(url: string): Promise {\n const schemeAndPath = parseURL(url);\n const manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme);\n return await manager.removeModel(schemeAndPath.path);\n}\n\n/**\n * Copy a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Copying within a storage medium, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Copying between two storage mediums, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Copy the model, from Local Storage to IndexedDB.\n * await tf.io.copyModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove both models.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of copying.\n * @param destURL Destination URL of copying.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if copying fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function copyModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = false;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\n/**\n * Move a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Moving within a storage medium, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Moving between two storage mediums, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Move the model, from Local Storage to IndexedDB.\n * await tf.io.moveModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove the moved model.\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of moving.\n * @param destURL Destination URL of moving.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if moving fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function moveModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = true;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\nexport {moveModel, copyModel, removeModel, listModels};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst DATABASE_NAME = 'tensorflowjs';\nconst DATABASE_VERSION = 1;\n\n// Model data and ModelArtifactsInfo (metadata) are stored in two separate\n// stores for efficient access of the list of stored models and their metadata.\n// 1. The object store for model data: topology, weights and weight manifests.\nconst MODEL_STORE_NAME = 'models_store';\n// 2. The object store for ModelArtifactsInfo, including meta-information such\n// as the type of topology (JSON vs binary), byte size of the topology, byte\n// size of the weights, etc.\nconst INFO_STORE_NAME = 'model_info_store';\n\n/**\n * Delete the entire database for tensorflow.js, including the models store.\n */\nexport async function deleteDatabase(): Promise {\n const idbFactory = getIndexedDBFactory();\n\n return new Promise((resolve, reject) => {\n const deleteRequest = idbFactory.deleteDatabase(DATABASE_NAME);\n deleteRequest.onsuccess = () => resolve();\n deleteRequest.onerror = error => reject(error);\n });\n}\n\nfunction getIndexedDBFactory(): IDBFactory {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Add more info about what IOHandler subtypes are available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'Failed to obtain IndexedDB factory because the current environment' +\n 'is not a web browser.');\n }\n // tslint:disable-next-line:no-any\n const theWindow: any = window;\n const factory = theWindow.indexedDB || theWindow.mozIndexedDB ||\n theWindow.webkitIndexedDB || theWindow.msIndexedDB ||\n theWindow.shimIndexedDB;\n if (factory == null) {\n throw new Error(\n 'The current browser does not appear to support IndexedDB.');\n }\n return factory;\n}\n\nfunction setUpDatabase(openRequest: IDBRequest) {\n const db = openRequest.result as IDBDatabase;\n db.createObjectStore(MODEL_STORE_NAME, {keyPath: 'modelPath'});\n db.createObjectStore(INFO_STORE_NAME, {keyPath: 'modelPath'});\n}\n\n/**\n * IOHandler subclass: Browser IndexedDB.\n *\n * See the doc string of `browserIndexedDB` for more details.\n */\nexport class BrowserIndexedDB implements IOHandler {\n protected readonly indexedDB: IDBFactory;\n protected readonly modelPath: string;\n\n static readonly URL_SCHEME = 'indexeddb://';\n\n constructor(modelPath: string) {\n this.indexedDB = getIndexedDBFactory();\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For IndexedDB, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n // TODO(cais): Support saving GraphDef models.\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n return this.databaseAction(this.modelPath, modelArtifacts) as\n Promise;\n }\n\n async load(): Promise {\n return this.databaseAction(this.modelPath) as Promise;\n }\n\n /**\n * Perform database action to put model artifacts into or read model artifacts\n * from IndexedDB object store.\n *\n * Whether the action is put or get depends on whether `modelArtifacts` is\n * specified. If it is specified, the action will be put; otherwise the action\n * will be get.\n *\n * @param modelPath A unique string path for the model.\n * @param modelArtifacts If specified, it will be the model artifacts to be\n * stored in IndexedDB.\n * @returns A `Promise` of `SaveResult`, if the action is put, or a `Promise`\n * of `ModelArtifacts`, if the action is get.\n */\n private databaseAction(modelPath: string, modelArtifacts?: ModelArtifacts):\n Promise {\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n\n if (modelArtifacts == null) {\n // Read model out from object store.\n const modelTx = db.transaction(MODEL_STORE_NAME, 'readonly');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const getRequest = modelStore.get(this.modelPath);\n getRequest.onsuccess = () => {\n if (getRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${this.modelPath}' ` +\n `in IndexedDB.`));\n } else {\n resolve(getRequest.result.modelArtifacts);\n }\n };\n getRequest.onerror = error => {\n db.close();\n return reject(getRequest.error);\n };\n modelTx.oncomplete = () => db.close();\n } else {\n // Put model into object store.\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n // First, put ModelArtifactsInfo into info store.\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n let infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const putInfoRequest =\n infoStore.put({modelPath: this.modelPath, modelArtifactsInfo});\n let modelTx: IDBTransaction;\n putInfoRequest.onsuccess = () => {\n // Second, put model data into model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const putModelRequest = modelStore.put({\n modelPath: this.modelPath,\n modelArtifacts,\n modelArtifactsInfo\n });\n putModelRequest.onsuccess = () => resolve({modelArtifactsInfo});\n putModelRequest.onerror = error => {\n // If the put-model request fails, roll back the info entry as\n // well.\n infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const deleteInfoRequest = infoStore.delete(this.modelPath);\n deleteInfoRequest.onsuccess = () => {\n db.close();\n return reject(putModelRequest.error);\n };\n deleteInfoRequest.onerror = error => {\n db.close();\n return reject(putModelRequest.error);\n };\n };\n };\n putInfoRequest.onerror = error => {\n db.close();\n return reject(putInfoRequest.error);\n };\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n }\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nexport const indexedDBRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserIndexedDB.URL_SCHEME)) {\n return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(indexedDBRouter);\nIORouterRegistry.registerLoadRouter(indexedDBRouter);\n\n/**\n * Creates a browser IndexedDB IOHandler for saving and loading models.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save('indexeddb://MyModel'));\n * console.log(saveResult);\n * ```\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `BrowserIndexedDB` (sublcass of `IOHandler`),\n * which can be used with, e.g., `tf.Model.save`.\n */\nexport function browserIndexedDB(modelPath: string): IOHandler {\n return new BrowserIndexedDB(modelPath);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserIndexedDB.URL_SCHEME) ?\n key.slice(BrowserIndexedDB.URL_SCHEME.length) :\n key;\n}\n\nexport class BrowserIndexedDBManager implements ModelStoreManager {\n private indexedDB: IDBFactory;\n\n constructor() {\n this.indexedDB = getIndexedDBFactory();\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n return new Promise<{[path: string]: ModelArtifactsInfo}>(\n (resolve, reject) => {\n const openRequest =\n this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const tx = db.transaction(INFO_STORE_NAME, 'readonly');\n const store = tx.objectStore(INFO_STORE_NAME);\n // tslint:disable:max-line-length\n // Need to cast `store` as `any` here because TypeScript's DOM\n // library does not have the `getAll()` method even though the\n // method is supported in the latest version of most mainstream\n // browsers:\n // https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/getAll\n // tslint:enable:max-line-length\n // tslint:disable-next-line:no-any\n const getAllInfoRequest = (store as any).getAll() as IDBRequest;\n getAllInfoRequest.onsuccess = () => {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n for (const item of getAllInfoRequest.result) {\n out[item.modelPath] = item.modelArtifactsInfo;\n }\n resolve(out);\n };\n getAllInfoRequest.onerror = error => {\n db.close();\n return reject(getAllInfoRequest.error);\n };\n tx.oncomplete = () => db.close();\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n const infoStore = infoTx.objectStore(INFO_STORE_NAME);\n\n const getInfoRequest = infoStore.get(path);\n let modelTx: IDBTransaction;\n getInfoRequest.onsuccess = () => {\n if (getInfoRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${path}' ` +\n `in IndexedDB.`));\n } else {\n // First, delete the entry in the info store.\n const deleteInfoRequest = infoStore.delete(path);\n const deleteModelData = () => {\n // Second, delete the entry in the model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const deleteModelRequest = modelStore.delete(path);\n deleteModelRequest.onsuccess = () =>\n resolve(getInfoRequest.result.modelArtifactsInfo);\n deleteModelRequest.onerror = error =>\n reject(getInfoRequest.error);\n };\n // Proceed with deleting model data regardless of whether deletion\n // of info data succeeds or not.\n deleteInfoRequest.onsuccess = deleteModelData;\n deleteInfoRequest.onerror = error => {\n deleteModelData();\n db.close();\n return reject(getInfoRequest.error);\n };\n }\n };\n getInfoRequest.onerror = error => {\n db.close();\n return reject(getInfoRequest.error);\n };\n\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {assert} from '../util';\nimport {arrayBufferToBase64String, base64StringToArrayBuffer, getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst PATH_SEPARATOR = '/';\nconst PATH_PREFIX = 'tensorflowjs_models';\nconst INFO_SUFFIX = 'info';\nconst MODEL_TOPOLOGY_SUFFIX = 'model_topology';\nconst WEIGHT_SPECS_SUFFIX = 'weight_specs';\nconst WEIGHT_DATA_SUFFIX = 'weight_data';\n\n/**\n * Purge all tensorflow.js-saved model artifacts from local storage.\n *\n * @returns Paths of the models purged.\n */\nexport function purgeLocalStorageArtifacts(): string[] {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n throw new Error(\n 'purgeLocalStorageModels() cannot proceed because local storage is ' +\n 'unavailable in the current environment.');\n }\n const LS = window.localStorage;\n const purgedModelPaths: string[] = [];\n for (let i = 0; i < LS.length; ++i) {\n const key = LS.key(i);\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n if (key.startsWith(prefix) && key.length > prefix.length) {\n LS.removeItem(key);\n const modelName = getModelPathFromKey(key);\n if (purgedModelPaths.indexOf(modelName) === -1) {\n purgedModelPaths.push(modelName);\n }\n }\n }\n return purgedModelPaths;\n}\n\nfunction getModelKeys(path: string):\n {info: string, topology: string, weightSpecs: string, weightData: string} {\n return {\n info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR),\n topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR),\n weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR),\n weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR)\n };\n}\n\n/**\n * Get model path from a local-storage key.\n *\n * E.g., 'tensorflowjs_models/my/model/1/info' --> 'my/model/1'\n *\n * @param key\n */\nfunction getModelPathFromKey(key: string) {\n const items = key.split(PATH_SEPARATOR);\n if (items.length < 3) {\n throw new Error(`Invalid key format: ${key}`);\n }\n return items.slice(1, items.length - 1).join(PATH_SEPARATOR);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserLocalStorage.URL_SCHEME) ?\n key.slice(BrowserLocalStorage.URL_SCHEME.length) :\n key;\n}\n\n/**\n * IOHandler subclass: Browser Local Storage.\n *\n * See the doc string to `browserLocalStorage` for more details.\n */\nexport class BrowserLocalStorage implements IOHandler {\n protected readonly LS: Storage;\n protected readonly modelPath: string;\n protected readonly keys: {[key: string]: string};\n\n static readonly URL_SCHEME = 'localstorage://';\n\n constructor(modelPath: string) {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n // TODO(cais): Add more info about what IOHandler subtypes are\n // available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'The current environment does not support local storage.');\n }\n this.LS = window.localStorage;\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For local storage, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n this.keys = getModelKeys(this.modelPath);\n }\n\n /**\n * Save model artifacts to browser local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @param modelArtifacts The model artifacts to be stored.\n * @returns An instance of SaveResult.\n */\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const topology = JSON.stringify(modelArtifacts.modelTopology);\n const weightSpecs = JSON.stringify(modelArtifacts.weightSpecs);\n\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n\n try {\n this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo));\n this.LS.setItem(this.keys.topology, topology);\n this.LS.setItem(this.keys.weightSpecs, weightSpecs);\n this.LS.setItem(\n this.keys.weightData,\n arrayBufferToBase64String(modelArtifacts.weightData));\n\n return {modelArtifactsInfo};\n } catch (err) {\n // If saving failed, clean up all items saved so far.\n for (const key in this.keys) {\n this.LS.removeItem(this.keys[key]);\n }\n\n throw new Error(\n `Failed to save model '${this.modelPath}' to local storage: ` +\n `size quota being exceeded is a possible cause of this failure: ` +\n `modelTopologyBytes=${modelArtifactsInfo.modelTopologyBytes}, ` +\n `weightSpecsBytes=${modelArtifactsInfo.weightSpecsBytes}, ` +\n `weightDataBytes=${modelArtifactsInfo.weightDataBytes}.`);\n }\n }\n }\n\n /**\n * Load a model from local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @returns The loaded model (if loading succeeds).\n */\n async load(): Promise {\n const info =\n JSON.parse(this.LS.getItem(this.keys.info)) as ModelArtifactsInfo;\n if (info == null) {\n throw new Error(\n `In local storage, there is no model with name '${this.modelPath}'`);\n }\n\n if (info.modelTopologyType !== 'JSON') {\n throw new Error(\n 'BrowserLocalStorage does not support loading non-JSON model ' +\n 'topology yet.');\n }\n\n const out: ModelArtifacts = {};\n\n // Load topology.\n const topology = JSON.parse(this.LS.getItem(this.keys.topology));\n if (topology == null) {\n throw new Error(\n `In local storage, the topology of model '${this.modelPath}' ` +\n `is missing.`);\n }\n out.modelTopology = topology;\n\n // Load weight specs.\n const weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs));\n if (weightSpecs == null) {\n throw new Error(\n `In local storage, the weight specs of model '${this.modelPath}' ` +\n `are missing.`);\n }\n out.weightSpecs = weightSpecs;\n\n // Load weight data.\n const weightDataBase64 = this.LS.getItem(this.keys.weightData);\n if (weightDataBase64 == null) {\n throw new Error(\n `In local storage, the binary weight values of model ` +\n `'${this.modelPath}' are missing.`);\n }\n out.weightData = base64StringToArrayBuffer(weightDataBase64);\n\n return out;\n }\n}\n\nexport const localStorageRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserLocalStorage.URL_SCHEME)) {\n return browserLocalStorage(\n url.slice(BrowserLocalStorage.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(localStorageRouter);\nIORouterRegistry.registerLoadRouter(localStorageRouter);\n\n/**\n * Factory function for local storage IOHandler.\n *\n * This `IOHandler` supports both `save` and `load`.\n *\n * For each model's saved artifacts, four items are saved to local storage.\n * - `${PATH_SEPARATOR}/${modelPath}/info`: Contains meta-info about the\n * model, such as date saved, type of the topology, size in bytes, etc.\n * - `${PATH_SEPARATOR}/${modelPath}/topology`: Model topology. For Keras-\n * style models, this is a stringized JSON.\n * - `${PATH_SEPARATOR}/${modelPath}/weight_specs`: Weight specs of the\n * model, can be used to decode the saved binary weight values (see\n * item below).\n * - `${PATH_SEPARATOR}/${modelPath}/weight_data`: Concatenated binary\n * weight values, stored as a base64-encoded string.\n *\n * Saving may throw an `Error` if the total size of the artifacts exceed the\n * browser-specific quota.\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `IOHandler`, which can be used with, e.g.,\n * `tf.Model.save`.\n */\nexport function browserLocalStorage(modelPath: string): IOHandler {\n return new BrowserLocalStorage(modelPath);\n}\n\nexport class BrowserLocalStorageManager implements ModelStoreManager {\n private readonly LS: Storage;\n\n constructor() {\n assert(ENV.get('IS_BROWSER'), 'Current environment is not a web browser');\n assert(\n typeof window.localStorage !== 'undefined',\n 'Current browser does not appear to support localStorage');\n this.LS = window.localStorage;\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n const suffix = PATH_SEPARATOR + INFO_SUFFIX;\n for (let i = 0; i < this.LS.length; ++i) {\n const key = this.LS.key(i);\n if (key.startsWith(prefix) && key.endsWith(suffix)) {\n const modelPath = getModelPathFromKey(key);\n out[modelPath] = JSON.parse(this.LS.getItem(key)) as ModelArtifactsInfo;\n }\n }\n return out;\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n const keys = getModelKeys(path);\n if (this.LS.getItem(keys.info) == null) {\n throw new Error(`Cannot find model at path '${path}'`);\n }\n const info = JSON.parse(this.LS.getItem(keys.info)) as ModelArtifactsInfo;\n\n this.LS.removeItem(keys.info);\n this.LS.removeItem(keys.topology);\n this.LS.removeItem(keys.weightSpecs);\n this.LS.removeItem(keys.weightData);\n return info;\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers related to files, such as browser-triggered file downloads,\n * user-selected files in browser.\n */\n\nimport {ENV} from '../environment';\nimport {basename, concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\nconst DEFAULT_FILE_NAME_PREFIX = 'model';\nconst DEFAULT_JSON_EXTENSION_NAME = '.json';\nconst DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin';\n\nexport class BrowserDownloads implements IOHandler {\n private readonly modelTopologyFileName: string;\n private readonly weightDataFileName: string;\n private readonly jsonAnchor: HTMLAnchorElement;\n private readonly weightDataAnchor: HTMLAnchorElement;\n\n static readonly URL_SCHEME = 'downloads://';\n\n constructor(fileNamePrefix?: string) {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Provide info on what IOHandlers are available under the\n // current environment.\n throw new Error(\n 'triggerDownloads() cannot proceed because the current environment ' +\n 'is not a browser.');\n }\n\n if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) {\n fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length);\n }\n if (fileNamePrefix == null || fileNamePrefix.length === 0) {\n fileNamePrefix = DEFAULT_FILE_NAME_PREFIX;\n }\n\n this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME;\n this.weightDataFileName =\n fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n const weightsURL = window.URL.createObjectURL(new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}));\n\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'DownloadTrigger.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./' + this.weightDataFileName],\n weights: modelArtifacts.weightSpecs\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n const modelTopologyAndWeightManifestURL =\n window.URL.createObjectURL(new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}));\n\n // If anchor elements are not provided, create them without attaching them\n // to parents, so that the downloaded file names can be controlled.\n const jsonAnchor = this.jsonAnchor == null ? document.createElement('a') :\n this.jsonAnchor;\n jsonAnchor.download = this.modelTopologyFileName;\n jsonAnchor.href = modelTopologyAndWeightManifestURL;\n // Trigger downloads by calling the `click` methods on the download\n // anchors.\n jsonAnchor.click();\n\n if (modelArtifacts.weightData != null) {\n const weightDataAnchor = this.weightDataAnchor == null ?\n document.createElement('a') :\n this.weightDataAnchor;\n weightDataAnchor.download = this.weightDataFileName;\n weightDataAnchor.href = weightsURL;\n weightDataAnchor.click();\n }\n\n return {modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts)};\n }\n }\n}\n\nclass BrowserFiles implements IOHandler {\n private readonly files: File[];\n\n constructor(files: File[]) {\n if (files == null || files.length < 1) {\n throw new Error(\n `When calling browserFiles, at least 1 file is required, ` +\n `but received ${files}`);\n }\n this.files = files;\n }\n\n async load(): Promise {\n const jsonFile = this.files[0];\n const weightFiles = this.files.slice(1);\n\n return new Promise((resolve, reject) => {\n const jsonReader = new FileReader();\n jsonReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const modelJSON = JSON.parse((event.target as any).result);\n const modelTopology = modelJSON.modelTopology as {};\n if (modelTopology == null) {\n reject(new Error(\n `modelTopology field is missing from file ${jsonFile.name}`));\n return;\n }\n\n if (weightFiles.length === 0) {\n resolve({modelTopology});\n }\n\n const weightsManifest =\n modelJSON.weightsManifest as WeightsManifestConfig;\n if (weightsManifest == null) {\n reject(new Error(\n `weightManifest field is missing from file ${jsonFile.name}`));\n return;\n }\n\n let pathToFile: {[path: string]: File};\n try {\n pathToFile =\n this.checkManifestAndWeightFiles(weightsManifest, weightFiles);\n } catch (err) {\n reject(err);\n return;\n }\n\n const weightSpecs: WeightsManifestEntry[] = [];\n const paths: string[] = [];\n const perFileBuffers: ArrayBuffer[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n paths.push(path);\n perFileBuffers.push(null);\n });\n weightSpecs.push(...weightsGroup.weights);\n });\n\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n const weightFileReader = new FileReader();\n weightFileReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const weightData = (event.target as any).result as ArrayBuffer;\n const index = paths.indexOf(path);\n perFileBuffers[index] = weightData;\n if (perFileBuffers.indexOf(null) === -1) {\n resolve({\n modelTopology,\n weightSpecs,\n weightData: concatenateArrayBuffers(perFileBuffers),\n });\n }\n };\n weightFileReader.onerror = (error: FileReaderProgressEvent) => {\n reject(`Failed to weights data from file of path '${path}'.`);\n return;\n };\n weightFileReader.readAsArrayBuffer(pathToFile[path]);\n });\n });\n };\n jsonReader.onerror = (error: FileReaderProgressEvent) => {\n reject(\n `Failed to read model topology and weights manifest JSON ` +\n `from file '${jsonFile.name}'. BrowserFiles supports loading ` +\n `Keras-style tf.Model artifacts only.`);\n return;\n };\n jsonReader.readAsText(jsonFile);\n });\n }\n\n /**\n * Check the compatibility between weights manifest and weight files.\n */\n private checkManifestAndWeightFiles(\n manifest: WeightsManifestConfig, files: File[]): {[path: string]: File} {\n const basenames: string[] = [];\n const fileNames = files.map(file => basename(file.name));\n const pathToFile: {[path: string]: File} = {};\n for (const group of manifest) {\n group.paths.forEach(path => {\n const pathBasename = basename(path);\n if (basenames.indexOf(pathBasename) !== -1) {\n throw new Error(\n `Duplicate file basename found in weights manifest: ` +\n `'${pathBasename}'`);\n }\n basenames.push(pathBasename);\n if (fileNames.indexOf(pathBasename) === -1) {\n throw new Error(\n `Weight file with basename '${pathBasename}' is not provided.`);\n } else {\n pathToFile[path] = files[fileNames.indexOf(pathBasename)];\n }\n });\n }\n\n if (basenames.length !== files.length) {\n throw new Error(\n `Mismatch in the number of files in weights manifest ` +\n `(${basenames.length}) and the number of weight files provided ` +\n `(${files.length}).`);\n }\n return pathToFile;\n }\n}\n\nexport const browserDownloadsRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserDownloads.URL_SCHEME)) {\n return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(browserDownloadsRouter);\n\n/**\n * Creates an IOHandler that triggers file downloads from the browser.\n *\n * The returned `IOHandler` instance can be used as model exporting methods such\n * as `tf.Model.save` and supports only saving.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * const saveResult = await model.save('downloads://mymodel'));\n * // This will trigger downloading of two files:\n * // 'mymodel.json' and 'mymodel.weights.bin'.\n * console.log(saveResult);\n * ```\n *\n * @param fileNamePrefix Prefix name of the files to be downloaded. For use with\n * `tf.Model`, `fileNamePrefix` should follow either of the following two\n * formats:\n * 1. `null` or `undefined`, in which case the default file\n * names will be used:\n * - 'model.json' for the JSON file containing the model topology and\n * weights manifest.\n * - 'model.weights.bin' for the binary file containing the binary weight\n * values.\n * 2. A single string or an Array of a single string, as the file name prefix.\n * For example, if `'foo'` is provided, the downloaded JSON\n * file and binary weights file will be named 'foo.json' and\n * 'foo.weights.bin', respectively.\n * @param config Additional configuration for triggering downloads.\n * @returns An instance of `DownloadTrigger` `IOHandler`.\n */\nexport function browserDownloads(fileNamePrefix = 'model'): IOHandler {\n return new BrowserDownloads(fileNamePrefix);\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from user-selected files.\n *\n * This method can be used for loading from files such as user-selected files\n * in the browser.\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * // Note: This code snippet won't run properly without the actual file input\n * // elements in the HTML DOM.\n *\n * // Suppose there are two HTML file input (``)\n * // elements.\n * const uploadJSONInput = document.getElementById('upload-json');\n * const uploadWeightsInput = document.getElementById('upload-weights');\n * const model = await tfl.loadModel(tf.io.browserFiles(\n * [uploadJSONInput.files[0], uploadWeightsInput.files[0]]));\n * ```\n *\n * @param files `File`s to load from. Currently, this function supports only\n * loading from files that contain Keras-style models (i.e., `tf.Model`s), for\n * which an `Array` of `File`s is expected (in that order):\n * - A JSON file containing the model topology and weight manifest.\n * - Optionally, One or more binary files containing the binary weights.\n * These files must have names that match the paths in the `weightsManifest`\n * contained by the aforementioned JSON file, or errors will be thrown\n * during loading. These weights files have the same format as the ones\n * generated by `tensorflowjs_converter` that comes with the `tensorflowjs`\n * Python PIP package. If no weights files are provided, only the model\n * topology will be loaded from the JSON file above.\n * @returns An instance of `Files` `IOHandler`.\n */\nexport function browserFiles(files: File[]): IOHandler {\n return new BrowserFiles(files);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/ops';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport * as util from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\n/**\n * Reads binary weights data from a number of URLs.\n *\n * @param fetchURLs URLs to send the HTTP requests at, using `fetch` calls.\n * @param requestOptions RequestInit (options) for the HTTP requests.\n * @returns A `Promise` of an Array of `ArrayBuffer`. The Array has the same\n * length as `fetchURLs`.\n */\nexport async function loadWeightsAsArrayBuffer(\n fetchURLs: string[], requestOptions?: RequestInit): Promise {\n // Create the requests for all of the weights in parallel.\n const requests = fetchURLs.map(fetchURL => fetch(fetchURL, requestOptions));\n const responses = await Promise.all(requests);\n const buffers =\n await Promise.all(responses.map(response => response.arrayBuffer()));\n return buffers;\n}\n\n/**\n * Reads a weights manifest JSON configuration, fetches the weights and\n * returns them as `Tensor`s.\n *\n * @param manifest The weights manifest JSON.\n * @param filePathPrefix The path prefix for filenames given in the manifest.\n * Defaults to the empty string.\n * @param weightNames The names of the weights to be fetched.\n */\nexport async function loadWeights(\n manifest: WeightsManifestConfig, filePathPrefix = '',\n weightNames?: string[],\n requestOptions?: RequestInit): Promise {\n // TODO(nsthorat): Groups are currently fetched atomically. If you need a\n // single weight from a group, the whole group will be fetched. At a future\n // date, we should support fetching only the individual shards within a\n // group that are needed to reconstruct the requested weight.\n // TODO(cais): Use `decodeWeights` for implementation.\n\n // Collect all the groups, weights, and their relative offsets to be\n // fetched.\n const groupIndicesToFetchMap = manifest.map(() => false);\n const groupWeightsToFetch: {\n [group: number]: Array<{\n manifestEntry: WeightsManifestEntry; groupOffset: number;\n sizeBytes: number;\n }>\n } = {};\n const weightsFound = weightNames != null ? weightNames.map(() => false) : [];\n const allManifestWeightNames: string[] = [];\n manifest.forEach((manifestGroupConfig, groupIndex) => {\n let groupOffset = 0;\n manifestGroupConfig.weights.forEach(weightsEntry => {\n const rawDtype = ('quantization' in weightsEntry) ?\n weightsEntry.quantization.dtype :\n weightsEntry.dtype;\n\n const weightsBytes = DTYPE_VALUE_SIZE_MAP[rawDtype] *\n util.sizeFromShape(weightsEntry.shape);\n\n const enqueueWeightsForFetchingFn = () => {\n groupIndicesToFetchMap[groupIndex] = true;\n if (groupWeightsToFetch[groupIndex] == null) {\n groupWeightsToFetch[groupIndex] = [];\n }\n\n groupWeightsToFetch[groupIndex].push({\n manifestEntry: weightsEntry,\n groupOffset,\n sizeBytes: weightsBytes\n });\n };\n\n if (weightNames != null) {\n weightNames.forEach((weightName, weightIndex) => {\n if (weightName === weightsEntry.name) {\n enqueueWeightsForFetchingFn();\n weightsFound[weightIndex] = true;\n }\n });\n } else {\n enqueueWeightsForFetchingFn();\n }\n\n allManifestWeightNames.push(weightsEntry.name);\n groupOffset += weightsBytes;\n });\n });\n\n if (!weightsFound.every(found => found)) {\n const weightsNotFound = weightNames.filter((weight, i) => !weightsFound[i]);\n throw new Error(\n `Could not find weights in manifest with names: ` +\n `${weightsNotFound.join(', ')}. \\n` +\n `Manifest JSON has weights with names: ` +\n `${allManifestWeightNames.join(', ')}.`);\n }\n\n // Convert the one-hot boolean groupId => shouldFetch map to a list of group\n // IDs.\n const groupIndicesToFetch =\n groupIndicesToFetchMap.reduce((accumulator, shouldFetch, i) => {\n if (shouldFetch) {\n accumulator.push(i);\n }\n return accumulator;\n }, []);\n\n const fetchUrls: string[] = [];\n groupIndicesToFetch.forEach(i => {\n manifest[i].paths.forEach(filepath => {\n const fetchUrl = filePathPrefix +\n (!filePathPrefix.endsWith('/') ? '/' : '') + filepath;\n fetchUrls.push(fetchUrl);\n });\n });\n const buffers = await loadWeightsAsArrayBuffer(fetchUrls, requestOptions);\n\n const weightsTensorMap: NamedTensorMap = {};\n let bufferIndexOffset = 0;\n groupIndicesToFetch.forEach(i => {\n const numBuffers = manifest[i].paths.length;\n\n let groupBytes = 0;\n for (let i = 0; i < numBuffers; i++) {\n groupBytes += buffers[bufferIndexOffset + i].byteLength;\n }\n\n // Create a buffer for the whole group.\n const groupBuffer = new ArrayBuffer(groupBytes);\n const groupByteBuffer = new Uint8Array(groupBuffer);\n let groupBufferOffset = 0;\n for (let i = 0; i < numBuffers; i++) {\n const buffer = new Uint8Array(buffers[bufferIndexOffset + i]);\n groupByteBuffer.set(buffer, groupBufferOffset);\n groupBufferOffset += buffer.byteLength;\n }\n\n const weightsEntries = groupWeightsToFetch[i];\n\n weightsEntries.forEach(weightsEntry => {\n const byteBuffer = groupBuffer.slice(\n weightsEntry.groupOffset,\n weightsEntry.groupOffset + weightsEntry.sizeBytes);\n\n let typedArray: TypedArray;\n\n const dtype = weightsEntry.manifestEntry.dtype;\n\n if ('quantization' in weightsEntry.manifestEntry) {\n const quantization = weightsEntry.manifestEntry.quantization;\n if (quantization.dtype !== 'uint8' && quantization.dtype !== 'uint16') {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown ` +\n `quantization dtype ${quantization.dtype}.`);\n }\n const quantizedArray = (quantization.dtype === 'uint8') ?\n new Uint8Array(byteBuffer) :\n new Uint16Array(byteBuffer);\n if (dtype === 'float32') {\n typedArray = Float32Array.from(\n quantizedArray, v => v * quantization.scale + quantization.min);\n } else if (dtype === 'int32') {\n typedArray = Int32Array.from(\n quantizedArray,\n v => Math.round(v * quantization.scale + quantization.min));\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has a dtype not ` +\n `supported by quantization: ${dtype}`);\n }\n } else {\n if (dtype === 'float32') {\n typedArray = new Float32Array(byteBuffer);\n } else if (dtype === 'int32') {\n typedArray = new Int32Array(byteBuffer);\n } else if (dtype === 'bool') {\n typedArray = new Uint8Array(byteBuffer);\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown dtype ` +\n `${dtype}.`);\n }\n }\n\n const weightName = weightsEntry.manifestEntry.name;\n if (weightsTensorMap[weightName] != null) {\n throw new Error(\n `Duplicate weight with name ${weightName}. ` +\n `Please make sure weights names are unique in the manifest JSON.`);\n }\n weightsTensorMap[weightName] = tensor(\n typedArray, weightsEntry.manifestEntry.shape,\n weightsEntry.manifestEntry.dtype);\n });\n\n bufferIndexOffset += numBuffers;\n });\n\n return weightsTensorMap;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandler implementations based on HTTP requests in the web browser.\n *\n * Uses [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).\n */\n\nimport {assert} from '../util';\nimport {concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeightsAsArrayBuffer} from './weights_loader';\n\nexport class BrowserHTTPRequest implements IOHandler {\n protected readonly path: string;\n protected readonly requestInit: RequestInit;\n\n readonly DEFAULT_METHOD = 'POST';\n\n static readonly URL_SCHEMES = ['http://', 'https://'];\n\n constructor(path: string, requestInit?: RequestInit) {\n if (typeof fetch === 'undefined') {\n throw new Error(\n // tslint:disable-next-line:max-line-length\n 'browserHTTPRequest is not supported outside the web browser without a fetch polyfill.');\n }\n\n assert(\n path != null && path.length > 0,\n 'URL path for browserHTTPRequest must not be null, undefined or ' +\n 'empty.');\n this.path = path;\n\n if (requestInit != null && requestInit.body != null) {\n throw new Error(\n 'requestInit is expected to have no pre-existing body, but has one.');\n }\n this.requestInit = requestInit || {};\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserHTTPRequest.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n const init = Object.assign({method: this.DEFAULT_METHOD}, this.requestInit);\n init.body = new FormData();\n\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./model.weights.bin'],\n weights: modelArtifacts.weightSpecs,\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n\n init.body.append(\n 'model.json',\n new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}),\n 'model.json');\n\n if (modelArtifacts.weightData != null) {\n init.body.append(\n 'model.weights.bin',\n new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}),\n 'model.weights.bin');\n }\n\n const response = await fetch(this.path, init);\n\n if (response.status === 200) {\n return {\n modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts),\n responses: [response],\n };\n } else {\n throw new Error(\n `BrowserHTTPRequest.save() failed due to HTTP response status ` +\n `${response.status}.`);\n }\n }\n\n /**\n * Load model artifacts via HTTP request(s).\n *\n * See the documentation to `browserHTTPRequest` for details on the saved\n * artifacts.\n *\n * @returns The loaded model artifacts (if loading succeeds).\n */\n async load(): Promise {\n const modelConfigRequest = await fetch(this.path, this.requestInit);\n const modelConfig = await modelConfigRequest.json();\n const modelTopology = modelConfig['modelTopology'];\n const weightsManifest = modelConfig['weightsManifest'];\n\n // We do not allow both modelTopology and weightsManifest to be missing.\n if (modelTopology == null && weightsManifest == null) {\n throw new Error(\n `The JSON from HTTP path ${this.path} contains neither model ` +\n `topology or manifest for weights.`);\n }\n\n let weightSpecs: WeightsManifestEntry[];\n let weightData: ArrayBuffer;\n if (weightsManifest != null) {\n const weightsManifest =\n modelConfig['weightsManifest'] as WeightsManifestConfig;\n weightSpecs = [];\n for (const entry of weightsManifest) {\n weightSpecs.push(...entry.weights);\n }\n\n let pathPrefix = this.path.substring(0, this.path.lastIndexOf('/'));\n if (!pathPrefix.endsWith('/')) {\n pathPrefix = pathPrefix + '/';\n }\n\n const fetchURLs: string[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n fetchURLs.push(pathPrefix + path);\n });\n });\n weightData = concatenateArrayBuffers(\n await loadWeightsAsArrayBuffer(fetchURLs, this.requestInit));\n }\n\n return {modelTopology, weightSpecs, weightData};\n }\n}\n\nexport const httpRequestRouter: IORouter = (url: string) => {\n if (typeof fetch === 'undefined') {\n // browserHTTPRequest uses `fetch`, if one wants to use it in node.js\n // they have to setup a global fetch polyfill.\n return null;\n } else {\n for (const scheme of BrowserHTTPRequest.URL_SCHEMES) {\n if (url.startsWith(scheme)) {\n return browserHTTPRequest(url);\n }\n }\n return null;\n }\n};\nIORouterRegistry.registerSaveRouter(httpRequestRouter);\nIORouterRegistry.registerLoadRouter(httpRequestRouter);\n\n/**\n * Creates an IOHandler subtype that sends model artifacts to HTTP server.\n *\n * An HTTP request of the `multipart/form-data` mime type will be sent to the\n * `path` URL. The form data includes artifacts that represent the topology\n * and/or weights of the model. In the case of Keras-style `tf.Model`, two\n * blobs (files) exist in form-data:\n * - A JSON file consisting of `modelTopology` and `weightsManifest`.\n * - A binary weights file consisting of the concatenated weight values.\n * These files are in the same format as the one generated by\n * [tfjs_converter](https://js.tensorflow.org/tutorials/import-keras.html).\n *\n * The following code snippet exemplifies the client-side code that uses this\n * function:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save(tf.io.browserHTTPRequest(\n * 'http://model-server:5000/upload', {method: 'PUT'}));\n * console.log(saveResult);\n * ```\n *\n * If the default `POST` method is to be used, without any custom parameters\n * such as headers, you can simply pass an HTTP or HTTPS URL to `model.save`:\n *\n * ```js\n * const saveResult = await model.save('http://model-server:5000/upload');\n * ```\n *\n * The following Python code snippet based on the\n * [flask](https://github.com/pallets/flask) server framework implements a\n * server that can receive the request. Upon receiving the model artifacts\n * via the requst, this particular server reconsistutes instances of\n * [Keras Models](https://keras.io/models/model/) in memory.\n *\n * ```python\n * # pip install -U flask flask-cors tensorflow tensorflowjs\n *\n * from __future__ import absolute_import\n * from __future__ import division\n * from __future__ import print_function\n *\n * import io\n *\n * from flask import Flask, Response, request\n * from flask_cors import CORS, cross_origin\n * import tensorflow as tf\n * import tensorflowjs as tfjs\n * import werkzeug.formparser\n *\n *\n * class ModelReceiver(object):\n *\n * def __init__(self):\n * self._model = None\n * self._model_json_bytes = None\n * self._model_json_writer = None\n * self._weight_bytes = None\n * self._weight_writer = None\n *\n * @property\n * def model(self):\n * self._model_json_writer.flush()\n * self._weight_writer.flush()\n * self._model_json_writer.seek(0)\n * self._weight_writer.seek(0)\n *\n * json_content = self._model_json_bytes.read()\n * weights_content = self._weight_bytes.read()\n * return tfjs.converters.deserialize_keras_model(\n * json_content,\n * weight_data=[weights_content],\n * use_unique_name_scope=True)\n *\n * def stream_factory(self,\n * total_content_length,\n * content_type,\n * filename,\n * content_length=None):\n * # Note: this example code is *not* thread-safe.\n * if filename == 'model.json':\n * self._model_json_bytes = io.BytesIO()\n * self._model_json_writer = io.BufferedWriter(self._model_json_bytes)\n * return self._model_json_writer\n * elif filename == 'model.weights.bin':\n * self._weight_bytes = io.BytesIO()\n * self._weight_writer = io.BufferedWriter(self._weight_bytes)\n * return self._weight_writer\n *\n *\n * def main():\n * app = Flask('model-server')\n * CORS(app)\n * app.config['CORS_HEADER'] = 'Content-Type'\n *\n * model_receiver = ModelReceiver()\n *\n * @app.route('/upload', methods=['POST'])\n * @cross_origin()\n * def upload():\n * print('Handling request...')\n * werkzeug.formparser.parse_form_data(\n * request.environ, stream_factory=model_receiver.stream_factory)\n * print('Received model:')\n * with tf.Graph().as_default(), tf.Session():\n * model = model_receiver.model\n * model.summary()\n * # You can perform `model.predict()`, `model.fit()`,\n * # `model.evaluate()` etc. here.\n * return Response(status=200)\n *\n * app.run('localhost', 5000)\n *\n *\n * if __name__ == '__main__':\n * main()\n * ```\n *\n * @param path URL path. Can be an absolute HTTP path (e.g.,\n * 'http://localhost:8000/model-upload)') or a relative path (e.g.,\n * './model-upload').\n * @param requestInit Request configurations to be used when sending\n * HTTP request to server using `fetch`. It can contain fields such as\n * `method`, `credentials`, `headers`, `mode`, etc. See\n * https://developer.mozilla.org/en-US/docs/Web/API/Request/Request\n * for more information. `requestInit` must not have a body, because the body\n * will be set by TensorFlow.js. File blobs representing\n * the model topology (filename: 'model.json') and the weights of the\n * model (filename: 'model.weights.bin') will be appended to the body.\n * If `requestInit` has a `body`, an Error will be thrown.\n * @returns An instance of `IOHandler`.\n */\nexport function browserHTTPRequest(\n path: string, requestInit?: RequestInit): IOHandler {\n return new BrowserHTTPRequest(path, requestInit);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers that pass through the in-memory ModelArtifacts format.\n */\n\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestEntry} from './types';\n\nclass PassthroughLoader implements IOHandler {\n constructor(\n private readonly modelTopology?: {}|ArrayBuffer,\n private readonly weightSpecs?: WeightsManifestEntry[],\n private readonly weightData?: ArrayBuffer) {}\n\n async load(): Promise {\n let result = {};\n if (this.modelTopology != null) {\n result = {modelTopology: this.modelTopology, ...result};\n }\n if (this.weightSpecs != null && this.weightSpecs.length > 0) {\n result = {weightSpecs: this.weightSpecs, ...result};\n }\n if (this.weightData != null && this.weightData.byteLength > 0) {\n result = {weightData: this.weightData, ...result};\n }\n return result;\n }\n}\n\nclass PassthroughSaver implements IOHandler {\n constructor(\n private readonly saveHandler: (artifacts: ModelArtifacts) => SaveResult) {\n }\n\n async save(modelArtifacts: ModelArtifacts) {\n return this.saveHandler(modelArtifacts);\n }\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from memory.\n *\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * const model = await tf.loadModel(tf.io.fromMemory(\n * modelTopology, weightSpecs, weightData));\n * ```\n *\n * @param modelTopology a object containing model topology (i.e., parsed from\n * the JSON format).\n * @param weightSpecs An array of `WeightsManifestEntry` objects describing the\n * names, shapes, types, and quantization of the weight data.\n * @param weightData A single `ArrayBuffer` containing the weight data,\n * concatenated in the order described by the weightSpecs.\n *\n * @returns A passthrough `IOHandler` that simply loads the provided data.\n */\nexport function fromMemory(\n modelTopology: {}, weightSpecs?: WeightsManifestEntry[],\n weightData?: ArrayBuffer): IOHandler {\n return new PassthroughLoader(modelTopology, weightSpecs, weightData);\n}\n\n/**\n * Creates an IOHandler that passes saved model artifacts to a callback.\n *\n * ```js\n * function handleSave(artifacts) {\n * // ... do something with the artifacts ...\n * return {modelArtifactsInfo: {...}, ...};\n * }\n *\n * const saveResult = model.save(tf.io.withSaveHandler(handleSave));\n * ```\n *\n * @param saveHandler A function that accepts a `ModelArtifacts` and returns a\n * `SaveResult`.\n */\nexport function withSaveHandler(\n saveHandler: (artifacts: ModelArtifacts) => SaveResult): IOHandler {\n return new PassthroughSaver(saveHandler);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Importing local_storage and indexed_db is necessary for the routers to be\n// registered.\nimport './indexed_db';\nimport './local_storage';\n\nimport {browserFiles} from './browser_files';\nimport {browserHTTPRequest} from './browser_http';\nimport {concatenateArrayBuffers, decodeWeights, encodeWeights, getModelArtifactsInfoForJSON} from './io_utils';\nimport {fromMemory, withSaveHandler} from './passthrough';\nimport {IORouterRegistry} from './router_registry';\nimport {IOHandler, LoadHandler, ModelArtifacts, ModelStoreManager, SaveConfig, SaveHandler, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeights} from './weights_loader';\n\nconst registerSaveRouter = IORouterRegistry.registerSaveRouter;\nconst registerLoadRouter = IORouterRegistry.registerLoadRouter;\nconst getSaveHandlers = IORouterRegistry.getSaveHandlers;\nconst getLoadHandlers = IORouterRegistry.getLoadHandlers;\n\nexport {copyModel, listModels, moveModel, removeModel} from './model_management';\n\nexport {\n browserFiles,\n browserHTTPRequest,\n concatenateArrayBuffers,\n decodeWeights,\n encodeWeights,\n fromMemory,\n getLoadHandlers,\n getModelArtifactsInfoForJSON,\n getSaveHandlers,\n IOHandler,\n LoadHandler,\n loadWeights,\n ModelArtifacts,\n ModelStoreManager,\n registerLoadRouter,\n registerSaveRouter,\n SaveConfig,\n SaveHandler,\n SaveResult,\n WeightsManifestConfig,\n WeightsManifestEntry,\n withSaveHandler\n};\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Types to support JSON-esque data structures internally.\n *\n * Internally ConfigDict's use camelCase keys and values where the\n * values are class names to be instantiated. On the python side, these\n * will be snake_case. Internally we allow Enums into the values for better\n * type safety, but these need to be converted to raw primitives (usually\n * strings) for round-tripping with python.\n *\n * toConfig returns the TS-friendly representation. model.toJSON() returns\n * the pythonic version as that's the portable format. If you need to\n * python-ify a non-model level toConfig output, you'll need to use a\n * convertTsToPythonic from serialization_utils in -Layers.\n *\n */\nexport type ConfigDictValue =\n boolean|number|string|null|ConfigDictArray|ConfigDict;\nexport interface ConfigDict {\n [key: string]: ConfigDictValue;\n}\nexport interface ConfigDictArray extends Array {}\n\n/**\n * Type to represent the class-type of Serializable objects.\n *\n * Ie the class prototype with access to the constructor and any\n * static members/methods. Instance methods are not listed here.\n *\n * Source for this idea: https://stackoverflow.com/a/43607255\n */\nexport type SerializableConstructor = {\n // tslint:disable-next-line:no-any\n new (...args: any[]): T; className: string; fromConfig: FromConfigMethod;\n};\nexport type FromConfigMethod =\n (cls: SerializableConstructor, config: ConfigDict) => T;\n\n/**\n * Serializable defines the serialization contract.\n *\n * TFJS requires serializable classes to return their className when asked\n * to avoid issues with minification.\n */\nexport abstract class Serializable {\n /**\n * Return the class name for this class to use in serialization contexts.\n *\n * Generally speaking this will be the same thing that constructor.name\n * would have returned. However, the class name needs to be robust\n * against minification for serialization/deserialazation to work properly.\n *\n * There's also places such as initializers.VarianceScaling, where\n * implementation details between different languages led to different\n * class hierarchies and a non-leaf node is used for serialization purposes.\n */\n getClassName(): string {\n return (this.constructor as SerializableConstructor)\n .className;\n }\n\n /**\n * Return all the non-weight state needed to serialize this object.\n */\n abstract getConfig(): ConfigDict;\n\n /**\n * Creates an instance of T from a ConfigDict.\n *\n * This works for most descendants of serializable. A few need to\n * provide special handling.\n * @param cls A Constructor for the class to instantiate.\n * @param config The Configuration for the object.\n */\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config);\n }\n}\n\n/**\n * Maps string keys to class constructors.\n *\n * Used during (de)serialization from the cross-language JSON format, which\n * requires the class name in the serialization format matches the class\n * names as used in Python, should it exist.\n */\nexport class SerializationMap {\n private static instance: SerializationMap;\n classNameMap: {\n [className: string]:\n [\n SerializableConstructor, FromConfigMethod\n ]\n };\n\n private constructor() {\n this.classNameMap = {};\n }\n\n /**\n * Returns the singleton instance of the map.\n */\n static getMap(): SerializationMap {\n if (SerializationMap.instance == null) {\n SerializationMap.instance = new SerializationMap();\n }\n return SerializationMap.instance;\n }\n\n /**\n * Registers the class as serializable.\n */\n static register(cls: SerializableConstructor) {\n SerializationMap.getMap().classNameMap[cls.className] =\n [cls, cls.fromConfig];\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Features} from './environment_util';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\n// TODO(smilkov): Move these constants to jasmine_util.\nexport const WEBGL_ENVS: Features = {\n 'HAS_WEBGL': true\n};\nexport const NODE_ENVS: Features = {\n 'IS_NODE': true\n};\nexport const CHROME_ENVS: Features = {\n 'IS_CHROME': true\n};\nexport const BROWSER_ENVS: Features = {\n 'IS_BROWSER': true\n};\nexport const CPU_ENVS: Features = {\n 'HAS_WEBGL': false\n};\nexport const ALL_ENVS: Features = {};\n\nexport function expectArraysClose(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[], epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!(actual instanceof Tensor) && !(expected instanceof Tensor)) {\n const aType = actual.constructor.name;\n const bType = expected.constructor.name;\n\n if (aType !== bType) {\n throw new Error(\n `Arrays are of different type actual: ${aType} ` +\n `vs expected: ${bType}`);\n }\n } else if (actual instanceof Tensor && expected instanceof Tensor) {\n if (actual.dtype !== expected.dtype) {\n throw new Error(\n `Arrays are of different type actual: ${actual.dtype} ` +\n `vs expected: ${expected.dtype}.`);\n }\n if (!util.arraysEqual(actual.shape, expected.shape)) {\n throw new Error(\n `Arrays are of different shape actual: ${actual.shape} ` +\n `vs expected: ${expected.shape}.`);\n }\n }\n\n let actualValues: TypedArray|number[];\n let expectedValues: TypedArray|number[]|boolean[];\n if (actual instanceof Tensor) {\n actualValues = actual.dataSync();\n } else {\n actualValues = actual;\n }\n if (expected instanceof Tensor) {\n expectedValues = expected.dataSync();\n } else {\n expectedValues = expected;\n }\n\n if (actualValues.length !== expectedValues.length) {\n throw new Error(\n `Arrays have different lengths actual: ${actualValues.length} vs ` +\n `expected: ${expectedValues.length}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n for (let i = 0; i < expectedValues.length; ++i) {\n const a = actualValues[i];\n const e = expectedValues[i];\n\n if (!areClose(a, Number(e), epsilon)) {\n throw new Error(\n `Arrays differ: actual[${i}] = ${a}, expected[${i}] = ${e}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n }\n}\n\nexport interface DoneFn {\n (): void;\n fail: (message?: Error|string) => void;\n}\n\nexport function expectPromiseToFail(fn: () => Promise<{}>, done: DoneFn): void {\n fn().then(() => done.fail(), () => done());\n}\n\nexport function expectArraysEqual(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[]) {\n return expectArraysClose(actual, expected, 0);\n}\n\nexport function expectNumbersClose(a: number, e: number, epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!areClose(a, e, epsilon)) {\n throw new Error(`Numbers differ: actual === ${a}, expected === ${e}`);\n }\n}\n\nfunction areClose(a: number, e: number, epsilon: number): boolean {\n if (isNaN(a) && isNaN(e)) {\n return true;\n }\n if (isNaN(a) || isNaN(e) || Math.abs(a - e) > epsilon) {\n return false;\n }\n return true;\n}\n\nexport function expectValuesInRange(\n actual: Tensor|TypedArray|number[], low: number, high: number) {\n let actualVals: TypedArray|number[];\n if (actual instanceof Tensor) {\n actualVals = actual.dataSync();\n } else {\n actualVals = actual;\n }\n for (let i = 0; i < actualVals.length; i++) {\n if (actualVals[i] < low || actualVals[i] > high) {\n throw new Error(\n `Value out of range:${actualVals[i]} low: ${low}, high: ${high}`);\n }\n }\n}\n\nexport function expectArrayBuffersEqual(\n actual: ArrayBuffer, expected: ArrayBuffer) {\n // Safari & Jasmine dont like comparing ArrayBuffers directly. Wrapping in\n // a Float32Array solves this issue.\n expect(new Float32Array(actual)).toEqual(new Float32Array(expected));\n}\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.8';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {variableGrads} from '../globals';\nimport {Serializable} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\n\n/** @doc {heading: 'Training', subheading: 'Classes', namespace: 'train'} */\nexport abstract class Optimizer extends Serializable {\n /**\n * Executes `f()` and minimizes the scalar output of `f()` by computing\n * gradients of y with respect to the list of trainable variables provided by\n * `varList`. If no list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to minimize.\n * @param returnCost Whether to return the scalar cost value produced by\n * executing `f()`.\n * @param varList An optional list of variables to update. If specified, only\n * the trainable variables in varList will be updated by minimize. Defaults to\n * all trainable variables.\n */\n /** @doc {heading: 'Training', subheading: 'Optimizers'} */\n minimize(f: () => Scalar, returnCost = false, varList?: Variable[]): Scalar\n |null {\n const {value, grads} = this.computeGradients(f, varList);\n\n this.applyGradients(grads);\n\n // Dispose gradients.\n const varNames = Object.keys(grads);\n varNames.forEach(varName => grads[varName].dispose());\n\n if (returnCost) {\n return value as Scalar;\n } else {\n value.dispose();\n return null;\n }\n }\n\n /**\n * Executes f() and computes the gradient of the scalar output of f() with\n * respect to the list of trainable variables provided by `varList`. If no\n * list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to use for computing\n * gradients with respect to variables.\n * @param varList An optional list of variables to compute gradients with\n * respect to. If specified, only the trainable variables in varList will have\n * gradients computed with respect to. Defaults to all trainable variables.\n */\n computeGradients(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n return variableGrads(f, varList);\n }\n\n /**\n * Updates variables by using the computed gradients.\n * @param variableGradients A mapping of variable name to its gradient value.\n */\n abstract applyGradients(variableGradients: NamedTensorMap): void;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\n\nconst DEFAULT_FLOAT32_EPSILON = 1e-8;\nconst DEFAULT_FLOAT16_EPSILON = 1e-4;\n\nexport function getOptimizerDefaultEpsilonValue() {\n if (ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return DEFAULT_FLOAT32_EPSILON;\n }\n\n return DEFAULT_FLOAT16_EPSILON;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdadeltaOptimizer extends Optimizer {\n static className = 'AdadeltaOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private rhoScalar: Scalar;\n private oneMinusRho: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n private accumulatedUpdates: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected rho: number,\n protected epsilon: number = null) {\n super();\n\n this.c = keep(scalar(-learningRate));\n this.rhoScalar = keep(scalar(rho));\n this.oneMinusRho = keep(scalar(1 - rho));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedUpdates[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedUpdates[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n const accumulatedUpdate = this.accumulatedUpdates[variableName];\n\n tidy(() => {\n const newAccumulatedGrad =\n this.rhoScalar.mul(accumulatedGrad)\n .add(this.oneMinusRho.mul(gradient.square()));\n\n const updates = accumulatedUpdate.add(this.epsilonScalar)\n .sqrt()\n .div(accumulatedGrad.add(this.epsilonScalar).sqrt())\n .mul(gradient);\n\n const newAccumulatedUpdate =\n this.rhoScalar.mul(accumulatedUpdate)\n .add(this.oneMinusRho.mul(updates.square()));\n\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n this.accumulatedUpdates[variableName].assign(newAccumulatedUpdate);\n\n const newValue = this.c.mul(updates).add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.rhoScalar.dispose();\n this.oneMinusRho.dispose();\n if (this.accumulatedUpdates != null) {\n Object.keys(this.accumulatedUpdates)\n .forEach(name => this.accumulatedUpdates[name].dispose());\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n rho: this.rho,\n epsilon: this.epsilon\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.rho, config.epsilon);\n }\n}\nSerializationMap.register(AdadeltaOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {fill, scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdagradOptimizer extends Optimizer {\n static className = 'AdagradOptimizer';\n private c: Scalar;\n private epsilon: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, private initialAccumulatorValue = 0.1) {\n super();\n this.c = keep(scalar(-learningRate));\n\n const epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n this.epsilon = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n fill(value.shape, this.initialAccumulatorValue)\n .variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n\n tidy(() => {\n const newAccumulatedGrad = accumulatedGrad.add(gradient.square());\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n\n const newValue =\n this.c\n .mul(gradient.div(newAccumulatedGrad.add(this.epsilon).sqrt()))\n .add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.epsilon.dispose();\n this.c.dispose();\n if (this.accumulatedGrads != null) {\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n initialAccumulatorValue: this.initialAccumulatorValue,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.initialAccumulatorValue);\n }\n}\nSerializationMap.register(AdagradOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamOptimizer extends Optimizer {\n static className = 'AdamOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private accBeta1: Variable;\n private accBeta2: Variable;\n private oneMinusBeta1: Scalar;\n private oneMinusBeta2: Scalar;\n private one: Scalar;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedSecondMoment: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null) {\n super();\n this.c = keep(scalar(-learningRate));\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n tidy(() => {\n // accB* will be updated by batch.\n this.accBeta1 = scalar(beta1).variable();\n this.accBeta2 = scalar(beta2).variable();\n });\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.oneMinusBeta2 = keep(scalar(1 - beta2));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const oneMinusAccBeta2 = this.one.sub(this.accBeta2);\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedSecondMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedSecondMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const secondMoment = this.accumulatedSecondMoment[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n const newSecondMoment =\n this.beta2Scalar.mul(secondMoment)\n .add(this.oneMinusBeta2.mul(gradient.square()));\n\n const biasCorrectedFirstMoment = newFirstMoment.div(oneMinusAccBeta1);\n const biasCorrectedSecondMoment = newSecondMoment.div(oneMinusAccBeta2);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedSecondMoment[variableName].assign(newSecondMoment);\n\n const newValue =\n this.c\n .mul(biasCorrectedFirstMoment.div(\n this.epsScalar.add(biasCorrectedSecondMoment.sqrt())))\n .add(value);\n value.assign(newValue);\n }\n\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n this.accBeta2.assign(this.accBeta2.mul(this.beta2Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.accBeta1.dispose();\n this.accBeta2.dispose();\n this.oneMinusBeta1.dispose();\n this.oneMinusBeta2.dispose();\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedSecondMoment != null) {\n Object.keys(this.accumulatedSecondMoment)\n .forEach(name => this.accumulatedSecondMoment[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon);\n }\n}\nSerializationMap.register(AdamOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamaxOptimizer extends Optimizer {\n static className = 'AdamaxOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private accBeta1: Variable;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private decayScalar: Scalar;\n private oneMinusBeta1: Scalar;\n private one: Scalar;\n private iteration: Variable;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedWeightedInfNorm: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null,\n protected decay = 0.0) {\n super();\n this.c = keep(scalar(-learningRate));\n\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n\n this.decayScalar = keep(scalar(decay));\n\n tidy(() => {\n this.iteration = scalar(0).variable();\n this.accBeta1 = scalar(beta1).variable();\n });\n\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const lr = this.c.div(this.one.add(this.decayScalar.mul(this.iteration)));\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedWeightedInfNorm[variableName] == null) {\n const trainable = false;\n this.accumulatedWeightedInfNorm[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const weightedInfNorm = this.accumulatedWeightedInfNorm[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n\n const ut0 = this.beta2Scalar.mul(weightedInfNorm);\n const ut1 = gradient.abs();\n\n const newWeightedInfNorm = ut0.maximum(ut1);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedWeightedInfNorm[variableName].assign(\n newWeightedInfNorm);\n\n const newValue =\n lr.div(oneMinusAccBeta1)\n .mul(newFirstMoment.div(this.epsScalar.add(newWeightedInfNorm)))\n .add(value);\n\n value.assign(newValue);\n }\n\n this.iteration.assign(this.iteration.add(this.one));\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.accBeta1.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.oneMinusBeta1.dispose();\n\n this.decayScalar.dispose();\n this.iteration.dispose();\n\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedWeightedInfNorm != null) {\n Object.keys(this.accumulatedWeightedInfNorm)\n .forEach(name => this.accumulatedWeightedInfNorm[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n decay: this.decay\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon,\n config.decay);\n }\n}\nSerializationMap.register(AdamaxOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\n\n/** @doclink Optimizer */\nexport class SGDOptimizer extends Optimizer {\n static className = 'SGDOptimizer';\n protected c: Scalar;\n\n constructor(protected learningRate: number) {\n super();\n this.setLearningRate(learningRate);\n }\n\n applyGradients(variableGradients: NamedTensorMap) {\n const varNames = Object.keys(variableGradients);\n varNames.forEach(varName => {\n const gradient = variableGradients[varName];\n const value = ENV.engine.registeredVariables[varName];\n\n tidy(() => {\n const newValue = this.c.mul(gradient).add(value);\n value.assign(newValue);\n });\n });\n }\n\n /**\n * Sets the learning rate of the optimizer.\n */\n setLearningRate(learningRate: number) {\n this.learningRate = learningRate;\n if (this.c != null) {\n this.c.dispose();\n }\n this.c = keep(scalar(-learningRate));\n }\n\n dispose() {\n this.c.dispose();\n }\n\n getConfig(): ConfigDict {\n return {learningRate: this.learningRate};\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate);\n }\n}\nSerializationMap.register(SGDOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Tensor} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {SGDOptimizer} from './sgd_optimizer';\n\n/** @doclink Optimizer */\nexport class MomentumOptimizer extends SGDOptimizer {\n static className = 'MomentumOptimizer';\n private m: Scalar;\n private accumulations: NamedVariableMap;\n\n constructor(\n protected learningRate: number, private momentum: number,\n private useNesterov = false) {\n super(learningRate);\n this.m = scalar(this.momentum);\n this.accumulations = {};\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulations[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulations[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulation = this.accumulations[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n let newValue: Tensor;\n const newAccumulation = this.m.mul(accumulation).add(gradient);\n if (this.useNesterov) {\n newValue =\n this.c.mul(gradient.add(newAccumulation.mul(this.m))).add(value);\n } else {\n newValue = this.c.mul(newAccumulation).add(value);\n }\n this.accumulations[variableName].assign(newAccumulation);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n super.dispose();\n this.m.dispose();\n if (this.accumulations != null) {\n for (const variableName in this.accumulations) {\n this.accumulations[variableName].dispose();\n }\n }\n }\n\n /**\n * Sets the momentum of the optimizer.\n *\n * @param momentum\n */\n setMomentum(momentum: number) {\n this.momentum = momentum;\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n momentum: this.momentum,\n useNesterov: this.useNesterov\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.momentum, config.useNesterov);\n }\n}\nSerializationMap.register(MomentumOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class RMSPropOptimizer extends Optimizer {\n static className = 'RMSPropOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private decayScalar: Scalar;\n private momentumScalar: Scalar;\n private oneMinusDecay: Scalar;\n private centered: boolean;\n\n private accumulatedMeanSquares: NamedVariableMap = {};\n private accumulatedMeanGrads: NamedVariableMap = {};\n private accumulatedMoments: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected decay = 0.9,\n protected momentum = 0.0, protected epsilon: number = null,\n centered = false) {\n super();\n\n this.c = keep(scalar(learningRate));\n this.decayScalar = keep(scalar(decay));\n this.momentumScalar = keep(scalar(momentum));\n this.oneMinusDecay = keep(scalar(1 - decay));\n this.centered = centered;\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedMeanSquares[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanSquares[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMeanGrads[variableName] == null && this.centered) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMoments[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMoments[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulatedMeanSquare = this.accumulatedMeanSquares[variableName];\n const accumulatedMeanGrad = this.accumulatedMeanGrads[variableName];\n const accumulatedMoments = this.accumulatedMoments[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n if (this.centered) {\n // Centered gradient\n const newAccumulatedMeanGrad =\n this.decayScalar.mul(accumulatedMeanGrad)\n .add(this.oneMinusDecay.mul(gradient));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare\n .sub(newAccumulatedMeanGrad.square().add(\n this.epsilonScalar))\n .sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMeanGrads[variableName].assign(\n newAccumulatedMeanGrad);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n } else {\n // Plain gradient\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare.add(this.epsilonScalar).sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n }\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.decayScalar.dispose();\n this.momentumScalar.dispose();\n this.oneMinusDecay.dispose();\n if (this.accumulatedMeanSquares != null) {\n Object.keys(this.accumulatedMeanSquares)\n .forEach(name => this.accumulatedMeanSquares[name].dispose());\n }\n if (this.accumulatedMeanGrads != null && this.centered) {\n Object.keys(this.accumulatedMeanGrads)\n .forEach(name => this.accumulatedMeanGrads[name].dispose());\n }\n if (this.accumulatedMoments != null) {\n Object.keys(this.accumulatedMoments)\n .forEach(name => this.accumulatedMoments[name].dispose());\n }\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n decay: this.decay,\n momentum: this.momentum,\n epsilon: this.epsilon,\n centered: this.centered\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.decay, config.momentum, config.epsilon,\n config.centered);\n }\n}\nSerializationMap.register(RMSPropOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {AdadeltaOptimizer} from './adadelta_optimizer';\nimport {AdagradOptimizer} from './adagrad_optimizer';\nimport {AdamOptimizer} from './adam_optimizer';\nimport {AdamaxOptimizer} from './adamax_optimizer';\nimport {MomentumOptimizer} from './momentum_optimizer';\nimport {RMSPropOptimizer} from './rmsprop_optimizer';\nimport {SGDOptimizer} from './sgd_optimizer';\n\nexport class OptimizerConstructors {\n /**\n * Constructs a `SGDOptimizer` that uses stochastic gradient descent.\n *\n * ```js\n * // Fit a quadratic function by learning the coefficients a, b, c.\n * const xs = tf.tensor1d([0, 1, 2, 3]);\n * const ys = tf.tensor1d([1.1, 5.9, 16.8, 33.9]);\n *\n * const a = tf.scalar(Math.random()).variable();\n * const b = tf.scalar(Math.random()).variable();\n * const c = tf.scalar(Math.random()).variable();\n *\n * // y = a * x^2 + b * x + c.\n * const f = x => a.mul(x.square()).add(b.mul(x)).add(c);\n * const loss = (pred, label) => pred.sub(label).square().mean();\n *\n * const learningRate = 0.01;\n * const optimizer = tf.train.sgd(learningRate);\n *\n * // Train the model.\n * for (let i = 0; i < 10; i++) {\n * optimizer.minimize(() => loss(f(xs), ys));\n * }\n *\n * // Make predictions.\n * console.log(\n * `a: ${a.dataSync()}, b: ${b.dataSync()}, c: ${c.dataSync()}`);\n * const preds = f(xs).dataSync();\n * preds.forEach((pred, i) => {\n * console.log(`x: ${i}, pred: ${pred}`);\n * });\n * ```\n *\n * @param learningRate The learning rate to use for the SGD algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static sgd(learningRate: number): SGDOptimizer {\n return new SGDOptimizer(learningRate);\n }\n\n /**\n * Constructs a `MomentumOptimizer` that uses momentum gradient\n * descent.\n *\n * See\n * [http://proceedings.mlr.press/v28/sutskever13.pdf](\n * http://proceedings.mlr.press/v28/sutskever13.pdf)\n *\n * @param learningRate The learning rate to use for the Momentum gradient\n * descent algorithm.\n * @param momentum The momentum to use for the momentum gradient descent\n * algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static momentum(learningRate: number, momentum: number, useNesterov = false):\n MomentumOptimizer {\n return new MomentumOptimizer(learningRate, momentum, useNesterov);\n }\n\n /**\n * Constructs a `RMSPropOptimizer` that uses RMSProp gradient\n * descent. This implementation uses plain momentum and is not centered\n * version of RMSProp.\n *\n * See\n * [http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf](\n * http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf)\n *\n * @param learningRate The learning rate to use for the RMSProp gradient\n * descent algorithm.\n * @param decay The discounting factor for the history/coming gradient.\n * @param momentum The momentum to use for the RMSProp gradient descent\n * algorithm.\n * @param epsilon Small value to avoid zero denominator.\n * @param centered If true, gradients are normalized by the estimated\n * variance of the gradient.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static rmsprop(\n learningRate: number, decay = .9, momentum = 0.0, epsilon: number = null,\n centered = false): RMSPropOptimizer {\n return new RMSPropOptimizer(\n learningRate, decay, momentum, epsilon, centered);\n }\n\n /**\n * Constructs a `AdamOptimizer` that uses the Adam algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adam gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adam(\n learningRate = 0.001, beta1 = 0.9, beta2 = 0.999,\n epsilon: number = null): AdamOptimizer {\n return new AdamOptimizer(learningRate, beta1, beta2, epsilon);\n }\n\n /**\n * Constructs a `AdadeltaOptimizer` that uses the Adadelta algorithm.\n * See [https://arxiv.org/abs/1212.5701](https://arxiv.org/abs/1212.5701)\n *\n * @param learningRate The learning rate to use for the Adadelta gradient\n * descent algorithm.\n * @param rho The learning rate decay over each update.\n * @param epsilon A constant epsilon used to better condition the grad\n * update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adadelta(learningRate = .001, rho = .95, epsilon: number = null):\n AdadeltaOptimizer {\n return new AdadeltaOptimizer(learningRate, rho, epsilon);\n }\n\n /**\n * Constructs a `AdamaxOptimizer` that uses the Adamax algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adamax gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n * @param decay The learning rate decay over each update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adamax(\n learningRate = 0.002, beta1 = 0.9, beta2 = 0.999, epsilon: number = null,\n decay = 0.0): AdamaxOptimizer {\n return new AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay);\n }\n\n /**\n * Constructs a `AdagradOptimizer` that uses the Adagrad algorithm.\n * See\n * [http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf](\n * http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf)\n * or\n * [http://ruder.io/optimizing-gradient-descent/index.html#adagrad](\n * http://ruder.io/optimizing-gradient-descent/index.html#adagrad)\n *\n * @param learningRate The learning rate to use for the Adagrad gradient\n * descent algorithm.\n * @param initialAccumulatorValue Starting value for the accumulators, must be\n * positive.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adagrad(learningRate: number, initialAccumulatorValue = 0.1):\n AdagradOptimizer {\n return new AdagradOptimizer(learningRate, initialAccumulatorValue);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// So typings can propagate.\nimport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nimport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nimport {AdamOptimizer} from './optimizers/adam_optimizer';\nimport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nimport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nimport {OptimizerConstructors} from './optimizers/optimizer_constructors';\nimport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nimport {SGDOptimizer} from './optimizers/sgd_optimizer';\n\n// tslint:disable-next-line:no-unused-expression\n[MomentumOptimizer, SGDOptimizer, AdadeltaOptimizer, AdagradOptimizer,\n RMSPropOptimizer, AdamaxOptimizer, AdamOptimizer];\n\nexport const train = {\n sgd: OptimizerConstructors.sgd,\n momentum: OptimizerConstructors.momentum,\n adadelta: OptimizerConstructors.adadelta,\n adagrad: OptimizerConstructors.adagrad,\n rmsprop: OptimizerConstructors.rmsprop,\n adamax: OptimizerConstructors.adamax,\n adam: OptimizerConstructors.adam\n};\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// backend_cpu.ts and backend_webgl.ts are standalone files and should be\n// explicily included here. Below, there is an export from backend_webgl, but\n// that doesn't count since it's exporting a Typescript interface.\nimport './kernels/backend_webgl';\nimport './kernels/backend_cpu';\n\nimport {nextFrame} from './browser_util';\nimport * as environment from './environment';\nimport {Environment} from './environment';\n\n// Serialization.\nimport * as io from './io/io';\nimport * as serialization from './serialization';\nimport {setOpHandler} from './tensor';\nimport * as test_util from './test_util';\nimport * as util from './util';\nimport {version} from './version';\nimport * as webgl from './webgl';\n\nexport {InferenceModel, ModelPredictConfig} from './model_types';\n\n// Optimizers.\nexport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nexport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nexport {AdamOptimizer} from './optimizers/adam_optimizer';\nexport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nexport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nexport {Optimizer} from './optimizers/optimizer';\nexport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nexport {SGDOptimizer} from './optimizers/sgd_optimizer';\nexport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer, variable, Variable} from './tensor';\nexport {NamedTensorMap} from './tensor_types';\nexport {DataType, Rank, ShapeMap} from './types';\n\nexport * from './ops/ops';\nexport {LSTMCellFunc} from './ops/lstm';\nexport {Reduction} from './ops/loss_ops';\n\nexport * from './train';\nexport * from './globals';\n\nexport {Features} from './environment_util';\nexport {TimingInfo} from './engine';\nexport {ENV, Environment} from './environment';\n\nexport const setBackend = Environment.setBackend;\nexport const getBackend = Environment.getBackend;\nexport const disposeVariables = Environment.disposeVariables;\nexport const memory = Environment.memory;\nexport {version as version_core};\n\nexport {nextFrame};\n\n// Second level exports.\nexport {environment, io, serialization, test_util, util, webgl};\n\n// Backend specific.\nexport {KernelBackend, BackendTimingInfo} from './kernels/backend';\n\nimport * as ops from './ops/ops';\nsetOpHandler(ops);\n"],"names":["a","navigator","userAgent","vendor","window","opera","test","substr","array","counter","length","temp","index","Math","random","min","x","max","b","result","i","diff","Number","expr","msg","Error","shapeA","shapeB","errorMessagePrefix","assert","arraysEqual","arr","ret","Array","isArray","flatten","push","val","firstElem","isTypedArray","shape","deepAssertShapeConsistency","indices","join","subShape","slice","concat","size","n1","n2","tanh","Infinity","e2x","exp","floor","sqrt","n","shuffledIndices","Uint32Array","shuffle","repeat","checkFn","delayFn","maxCounter","Promise","resolve","reject","tryCount","tryFn","nextBackoff","setTimeout","shapeProd","implicitIdx","newShape","axis","keptDims","j","dtype","values","Float32Array","Int32Array","Uint8Array","vals","name","isNaN","oldType","newType","debugMode","checkConversionForNaN","bool","round","f","constructor","call","apply","start","rank","strides","noConversionNeeded","copyTypedArray","makeZerosTypedArray","performance","now","process","time","hrtime","backendTimer","logger","this","Logger","Profiler","timer","forEach","r","dataSync","util.checkComputationForNaN","then","timing","_this","logKernelProfile","kernelMs","timeMs","util.rightPad","paddedName","toString","console","log","tape","xs","y","tensorsFromX","nodesFromX","id","nodeInputs","node","inputs","inputName","input","anyInputFromX","output","tensorsLeadToY","nodesToY","outputs","filteredTape","prunedInputs","nodeInput","prunedNode","Object","assign","tensorAccumulatedGradientMap","dy","gradient","inputGradients","keys","dx","util.arraysEqual","curGradient","add","dispose","FORMAT_LIMIT_NUM_VALS","FORMAT_NUM_FIRST_LAST_VALS","FORMAT_NUM_SIG_DIGITS","verbose","computeStrides","padPerCol","computeMaxSizePerColumn","valsLines","subTensorToString","lines","map","l","sizeFromShape","numCols","fill","row","offset","valToString","pad","rightPad","parseFloat","toFixed","isLast","firstVals","from","subarray","lastVals","subshape","substrides","stride","end","sep","newLineSep","util.sizeFromShape","util.assert","util.getTypedArrayFromDType","TensorBuffer","value","_i","locs","locToIndex","Tensor","make","trackerFn","opHandler","fn","handler","dataId","nextId","rankType","registerTensor","write","data","throwIfDisposed","as1D","reshape","rows","columns","depth","depth2","cast","buffer","read","readSync","isDisposed","disposeTensor","isDisposedInternal","asType","print","expandDims","exclusive","reverse","cumsum","squeeze","clone","tensorToString","reps","tile","gather","transposeA","transposeB","matMul","dot","ord","keepDims","norm","begin","stack","unstack","paddings","constantValue","mean","variance","varianceEpsilon","scale","batchNormalization","all","any","logSumExp","sum","argMin","argMax","addStrict","sub","subStrict","pow","powStrict","mul","mulStrict","div","floorDiv","divStrict","minimum","minimumStrict","maximum","maximumStrict","mod","modStrict","squaredDifference","squaredDifferenceStrict","perm","transpose","notEqual","notEqualStrict","less","lessStrict","equal","equalStrict","lessEqual","lessEqualStrict","greater","greaterStrict","greaterEqual","greaterEqualStrict","logicalAnd","logicalOr","logicalNot","logicalXor","condition","where","neg","ceil","sign","expm1","log1p","rsqrt","square","reciprocal","abs","clipByValue","relu","elu","selu","alpha","leakyRelu","prelu","sigmoid","logSigmoid","softplus","sin","cos","tan","asin","acos","atan","sinh","cosh","asinh","acosh","atanh","erf","step","dim","softmax","newShape2D","alignCorners","image","resizeBilinear","resizeNearestNeighbor","filter","dataFormat","dilation","dimRoundingMode","conv1d","dilations","conv2d","outputShape","conv2dTranspose","depthwiseConv2d","filterSize","avgPool","maxPool","radius","bias","beta","localResponseNormalization","trainable","Variable","variable","segmentIds","numSegments","unsortedSegmentSum","blockShape","crops","batchToSpaceND","spaceToBatchND","defineProperty","Symbol","hasInstance","instance","initialValue","_super","nextVarId","registerVariable","ex","tslib_1.__extends","newValue","Function","tensor","tensorList","list","walkTensorContainer","Set","container","seen","isIterable","iterable","k","has","obj","Type","backend","safeMode","WeakMap","activeScope","track","scopeStack","profiler","Engine","nameOrFn","gradMode","String","scopedRun","startScope","endScope","error","res","forwardFunc","backwardsFunc","saved","saveFunc","scopeName","customGradientDepth","profileKernel","shouldRecord","tapeNode","nextTapeNodeId","activeTape","refCount","refCounter","get","numTensors","numDataBuffers","numBytes","util.bytesPerElement","register","set","v","registeredVariables","keepTensors","delete","disposeData","varName","info","memory","gradientsFunc","inputsMap","idx","resMap","gradientsMode","gradientScopeCount","scopeInfo","tensorsToKeep","tensorsToTrackInParent","getTensorsInContainer","oldScope","pop","isTensorInList","allowNoGradients","tidy","getFilteredNodesXToY","accumulatedGradientMap","ones","backpropagateGradients","grads","util.isFunction","every","t","_a","gradFunc","addTapeNode","pixels","numChannels","fromPixels","query","timingInfo","wallMs","makeOnesTypedArray","URL_PROPERTIES","type","BOOLEAN","NUMBER","STRING","webGLVersion","isBrowser","gl","getWebGLRenderingContext","e","loseContext","queryTimerVersion","hasExtension","createFloatTextureAndBindToFramebuffer","isFrameBufferComplete","checkFramebufferStatus","FRAMEBUFFER","FRAMEBUFFER_COMPLETE","readPixels","RGBA","FLOAT","readPixelsNoError","getError","NO_ERROR","isEnabled","fenceSync","TENSORFLOWJS_FLAGS_PREFIX","features","location","urlParams","getQueryParams","search","urlFlags_1","split","keyValue","key","urlProperty","warn","extensionName","getExtension","tempCanvas","document","createElement","getContext","loseContextExtension","frameBuffer","createFramebuffer","texture","createTexture","bindTexture","TEXTURE_2D","internalFormat","RGBA32F","texImage2D","bindFramebuffer","framebufferTexture2D","COLOR_ATTACHMENT0","queryString","params","replace","s","decodeParam","decodeURIComponent","TEST_EPSILON_FLOAT32_ENABLED","TEST_EPSILON_FLOAT32_DISABLED","Environment","backendName","ENV","registry","initBackend","initDefaultBackend","engine","disposeVariables","keep","feature","evaluateFeature","entry","sort","priority","versions","isChrome","getBestBackendName","getWebGLDisjointQueryTimerVersion","device_util.isMobile","isWebGLVersionEnabled","isRenderToFloatTextureEnabled","isDownloadFloatTextureEnabled","isWebGLFenceEnabled","getFeaturesFromURL","globalEngine","findBackend","factory","setTensorTrackerFn","err","message","ns","getGlobalNamespace","setTensorTracker","getOrMakeEnvironment","inputShape","prod","batchToSpace","reshaped","spatialLength","reshapedRank","blockShapeRank","permuted","permutedBeforeBatch","permutedAfterBatch","reshapedPermuted","sliceBeginCoords","uncroppedShape","sliceSize","axes","outputLoc","reduceLoc","loc","outIdx","reduceIdx","indexOf","aShape","outShape","combineLocations","ax","util.isInt","axesAreInnerMostDims","numAxes","PARALLELIZE_THRESHOLD","inSize","nearestDivisor","done","beginMask","endMask","startIndex","endIndex","startForAxis","stopForAxis","d","count","startIndices","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","axisSize","util.clamp","stopIndices","stop","util.assertShapesMatch","checkGrads","args","arg","grad","gradients","varList","originalVarCount","some","g","namedGrads","customGrad","argName","functionName","inferredShape","inferShape","toTypedArray","convertToTensor","opName","endsWith","substring","f2","configurable","logits","$logits","lse","toFloat","dyTimesY","customOp","op","softmax_","assertShapesMatch","assertNonNull","getTypedArrayFromDType","$x","zeros","num","tensor1d","DType","Rank","UpcastInt32AndMap","UpcastBoolAndMap","UpcastFloat32AndMap","onesLike","onesLike_","zerosLike","zerosLike_","upcastTypeMap","float32","int32","typeA","typeB","upcastType","hasEncodingLoss","int","scalar","boxes","scores","maxOutputSize","iouThreshold","scoreThreshold","candidates","score","boxIndex","c","c1","c2","selected","ignoreCandidate","intersectionOverUnion","iCoord","jCoord","yminI","xminI","ymaxI","xmaxI","yminJ","xminJ","ymaxJ","xmaxJ","areaI","areaJ","intersectionYmin","intersectionXmin","intersectionYmax","intersectionXmax","intersectionArea","xShape","xDtype","sorted","lastDim","batch","allTopKVals","allTopKIndices","valAndInd","outOffset","topKVals","topKIndices","reduceInfo","firstPass","windowSize","batchSize","outSize","variableNames","compOp","indexSnippet","userCode","convInfo","inShape","filterHeight","filterWidth","strideHeight","strideWidth","padTop","padInfo","top","padLeft","left","avgMultiplier","outHeight","outWidth","inRank","dims","unshift","inDim","outAxis","outDim","errMsg","meanShape","varianceShape","offsetShape","scaleShape","broadcast_util.assertAndGetBroadcastShape","offsetSnippet","scaleSnippet","CHECK_NAN_SNIPPET","ADD","SUB","MUL","DIV","INT_DIV","POW","SQUARED_DIFFERENCE","EQUAL","NOT_EQUAL","LESS","LESS_EQUAL","GREATER","GREATER_EQUAL","LOGICAL_AND","LOGICAL_OR","MAX","MIN","MOD","ATAN2","ELU_DER","bShape","BinaryOpProgram","gpgpu","webGLProgram","startLoc","getUniformLocationNoThrow","uniform1f","NaN","minFixed","maxFixed","aRank","bRank","x1Shape","x2Shape","aBegin","aSize","bBegin","bSize","concat_util.computeOutShape","filterShape","inHeight","inWidth","outChannels","channelMul","inChannels","dilationHeight","dilationWidth","inputDepthNearestVec4","inputDepthVec4Remainder","xNumRows","xNumCols","inputsInfo","broadcast","inputPrefixSnippet","shapeInfo","logicalShape","isUniform","inputSamplingSnippet","getInputSamplingSnippet","outTexShape","texShape","outputSamplingSnippet","getOutputSamplingSnippet","SHADER_PREFIX","FLOAT_TEXTURE_SAMPLE_SNIPPET","FLOAT_TEXTURE_SETOUTPUT_SNIPPET","inInfo","getSamplerScalar","getSampler1D","getSampler2D","getSampler3D","getSampler4D","getSampler5D","getSampler6D","outShapeInfo","getSamplerFlat","getSamplerFromInInfo","getSamplerAtOutputCoords","getOutputScalarCoords","getOutput1DCoords","getOutput2DCoords","getOutput3DCoords","getOutput4DCoords","getOutput5DCoords","getOutput6DCoords","SAMPLE_1D_SNIPPET","SAMPLE_2D_SNIPPET","SAMPLE_3D_SNIPPET","SAMPLE_4D_SNIPPET","SAMPLE_5D_SNIPPET","SAMPLE_6D_SNIPPET","stride0","stride1","stride2","stride3","stride4","inputInfo","texName","funcName","charAt","toUpperCase","texNumR_1","squeezedShape","squeezeInputInfo","getSqueezedParams","texNumR","texNumC","tNumR","tNumC","texFuncSnippet","outRank","broadcastDims","broadcast_util.getBroadcastDims","rankDiff","supportsBroadcasting","doBroadcast","broadcastOverOuter","broadcast_util.broadcastDimsAreOuter","getBroadcastOutputCoordsSampler","broadcastSnippet","inTexShape","newInputInfo","JSON","parse","stringify","finalDim","comparator","getCoordsDataType","getFinalCoord","getCoords","TextureUsage","PhysicalTextureType","height","width","indicesLength","sourceCoords","getSourceCoords","currentCoords","matrixSize","channelsPerTexture","unpackedSize","matrix","unpackedArray","requiredSize","getUnpackedArraySizeFromMatrixSize","dst","src","getMatrixSizeFromUnpackedArraySize","packedRGBA","getPackedRGBAArraySizeFromMatrixShape","textureWidth","textureHeight","oddWidth","oddHeight","widthInFullBlocks","heightInFullBlocks","dstStride","oneRow","blockY","matrixSrcRow","blockX","srcStride","dstRow1","dstRow2","MAX_TEXTURE_SIZE","attributes","canvas","createWebGLRenderingContextFromCanvas","webglVersion","func","returnValue","checkWebGLError","webGLDebugErrorCheckingEnabled","enabled","getWebGLErrorMessage","status","INVALID_ENUM","INVALID_VALUE","INVALID_OPERATION","INVALID_FRAMEBUFFER_OPERATION","OUT_OF_MEMORY","CONTEXT_LOST_WEBGL","throwIfNull","vertexShaderSource","vertexShader","createShader","VERTEX_SHADER","callAndCheck","shaderSource","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","fragmentShaderSource","fragmentShader","FRAGMENT_SHADER","logShaderSourceAndInfoLog","lineNumberRegex","shaderInfoLog","lineNumberRegexResult","exec","lineNumber","shaderLines","linesWithLineNumbers","line","maxLineLength","beforeErrorLines","errorLine","afterErrorLines","createProgram","program","linkProgram","getProgramParameter","LINK_STATUS","getProgramInfoLog","validateProgram","VALIDATE_STATUS","createBuffer","bindBuffer","ARRAY_BUFFER","bufferData","STATIC_DRAW","ELEMENT_ARRAY_BUFFER","getParameter","maxTextureSize","queryMaxTextureSize","requested","attribute","arrayEntriesPerItem","itemStrideInBytes","itemOffsetInBytes","getAttribLocation","vertexAttribPointer","enableVertexAttribArray","textureUnit","validateTextureUnit","activeTexture","TEXTURE0","uniformName","getUniformLocation","uniformSamplerLocation","bindTextureUnit","uniform1i","viewport","scissor","framebuffer","getFramebufferErrorMessage","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_UNSUPPORTED","returnTOrNull","failureMessage","tOrNull","maxTextureUnit","MAX_COMBINED_TEXTURE_IMAGE_UNITS","glTextureUnit","logShape","util.squeezeShape","maxTexSize","util.sizeToSquarishShape","antialias","premultipliedAlpha","preserveDrawingBuffer","stencil","failIfMajorPerformanceCaveat","getWebGLContextAttributes","webgl_util.callAndCheck","webgl_util.createWebGLRenderingContextFromCanvas","webgl_util.createWebGLRenderingContext","disable","DEPTH_TEST","STENCIL_TEST","BLEND","DITHER","POLYGON_OFFSET_FILL","SAMPLE_COVERAGE","enable","SCISSOR_TEST","CULL_FACE","cullFace","BACK","webgl_util.createVertexShader","webgl_util.createStaticVertexBuffer","webgl_util.createStaticIndexBuffer","Uint16Array","textureHalfFloatExtension","internalFormatFloat","internalFormatHalfFloat","internalFormatPackedFloat","textureFormatFloat","downloadUnpackNumChannels","defaultNumChannels","textureTypeHalfFloat","glany","R32F","R16F","RED","HALF_FLOAT","HALF_FLOAT_OES","downloadTextureFormat","textureFormat","textureType","webgl_util.validateTextureSize","webgl_util.createTexture","tex2d","texParameteri","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","textureConfig","createAndConfigureTexture","UNSIGNED_BYTE","vertexBuffer","webgl_util.bindVertexBufferToProgramAttribute","texSubImage2D","w","h","tex_util.encodeMatrixToUnpackedArray","tex_util.getUnpackedArraySizeFromMatrixSize","uploadDataToTexture","tex_util.getPackedRGBAArraySizeFromMatrixShape","tex_util.encodeMatrixToPackedRGBA","bufferOrTexture","gl2_1","buffer_1","PIXEL_PACK_BUFFER","bufferSizeBytes_1","gl2","downloadTarget","getBufferSubData","tex_util.decodeMatrixFromUnpackedArray","tex_util.decodeMatrixFromPackedRGBA","gpgpu_util.createWebGLContext","textureFloatExtension","webgl_util.getExtensionOrThrow","colorBufferFloatExtension","colorBufferHalfFloatExtension","gpgpu_util.createVertexBuffer","indexBuffer","gpgpu_util.createIndexBuffer","webgl_util.createFramebuffer","gpgpu_util.getTextureConfig","GPGPUContext","disposed","outputTexture","finish","deleteFramebuffer","deleteBuffer","autoDebugValidate","webgl_util.enableDebugWebGLErrorChecking","gpgpu_util.createFloat32MatrixTexture","gpgpu_util.createFloat16MatrixTexture","gpgpu_util.createUnsignedBytesMatrixTexture","gpgpu_util.uploadPixelDataToTexture","gpgpu_util.createPackedMatrixTexture","webgl_util.unbindColorTextureFromFramebuffer","deleteTexture","webgl_util.getNumChannels","gpgpu_util.uploadMatrixToTexture","gpgpu_util.uploadMatrixToPackedTexture","downloadMatrixDriver","gpgpu_util.downloadFloat32MatrixFromOutputTexture","gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture","gpgpu_util.downloadFloat32MatrixFromBuffer","bindTextureToFrameBuffer","gpgpu_util.maybeCreateBufferFromOutputTexture","unbindTextureToFrameBuffer","fenceContext","createFence","pollFence","isFencePassed","sync_1","SYNC_GPU_COMMANDS_COMPLETE","flush","clientWaitSync","ALREADY_SIGNALED","CONDITION_SATISFIED","beginQuery","endQuery","isQueryAvailable","gpgpu_util.downloadMatrixFromPackedOutputTexture","webgl_util.createFragmentShader","gpgpu_util.createVertexShader","webgl_util.createProgram","attachShader","webgl_util.linkProgram","webgl_util.validateProgram","vertexAttrsAreBound","setProgram","gpgpu_util.bindVertexProgramAttributeStreams","deleteProgram","useProgram","shouldThrow","webgl_util.getProgramUniformLocationOrThrow","webgl_util.getProgramUniformLocation","inputMatrixTexture","uniformLocation","throwIfNoProgram","webgl_util.bindTextureToProgramUniformSampler","outputMatrixTexture","setOutputMatrixTextureDriver","outputPackedMatrixTexture","startRow","numRows","startColumn","numColumns","setOutputMatrixWriteRegionDriver","webgl_util.validateFramebuffer","debugValidate","drawElements","TRIANGLES","UNSIGNED_SHORT","disjointQueryTimerExtension","getQueryTimerExtension","ext_1","getQueryTimerExtensionWebGL2","query_1","createQuery","TIME_ELAPSED_EXT","ext","getQueryTimerExtensionWebGL1","createQueryEXT","beginQueryEXT","endQueryEXT","ext_2","util.repeatedTry","getQueryTime","getQueryParameter","QUERY_RESULT","getQueryObjectEXT","QUERY_RESULT_EXT","available","QUERY_RESULT_AVAILABLE","disjoint","GPU_DISJOINT_EXT","QUERY_RESULT_AVAILABLE_EXT","addItemToPoll","binSearchLastTrue","itemsToPoll","isDoneFn","resolveFn","pollItems","webgl_util.bindColorTextureToFramebuffer","downloadAndDecode","outputMatrixTextureMaybePacked","best","mid","inputInfos","texData","inShapeInfos","source","shader_compiler.makeShader","uniformLocations","shapeInfos","texShapeA","texShapeB","binary","customSetup","validateBinaryAndProgram","outTex","setOutputMatrixTexture","variableName","variableUniformLocation","uniform1fv","tex","setInputMatrixTexture","executeProgram","keyInputs","keyUserCode","keyBroadcast","powOperator","rad","maxD","basis","depthRadius","lastIndex","outerShapeA","outerShapeB","sharedDim","aSnippetFromOffset","vec4Offset","indexVar","bSnippetFromOffset","sharedDimNearestVec4","sharedDimVec4Remainder","numOutcomes","numSamples","MultinomialProgram","seed","seedLoc","numIndices","onValue","offValue","p","unpackedCoords","poolType","computePositions","isAvgPool","initializationValue","filterWidthNearestVec4","filterWidthVec4Remainder","updateSnippet","reduceType","compareOp","windowSizeNearestVec4","windowSizeVec4Remainder","vecType","checkOutOfBounds","xHeight","xWidth","_b","yHeight","yWidth","effectiveXSize","effectiveYSize","heightScale","widthScale","invHeightScale","invWidthScale","winHeight","winWidth","newHeight","newWidth","oldHeight","oldWidth","effectiveInSize","effectiveOutSize","roundBase","inCoords","_","getInCoord","segOpInfo","segOpType","checkValueOutOfBounds","checkSegmentIdOutOfBounds","cRank","cCoords","abCoords","cCoordVars","abCoordVars","destSize","SliceProgram","uniform2i","uniform3i","uniform4i","newCoords","TextureManager","shapeRC","usage","newTexture","physicalTexType","getPhysicalFromLogicalTextureType","shapeKey","getKeyFromTextureShape","freeTextures","usedTextures","numFreeTextures","numUsedTextures","newTexture_1","shift","FLOAT32","createFloat32MatrixTexture","FLOAT16","createFloat16MatrixTexture","createUnsignedBytesMatrixTexture","logicalTexType","texList","texIndex","splice","logEnabled","total","deleteMatrixTexture","DOWNLOAD","PIXELS","UPLOAD","RENDER","shapeRowsCol","newDim","switched","getSwitchedCoords","originalOrder","switchedCoords","ERF_P","ERF_A1","ERF_A2","ERF_A3","ERF_A4","ERF_A5","SELU_SCALEALPHA","SELU_SCALE","opSnippet","UnaryOpProgram","ABS","RELU","ELU","SELU","selu_util.SELU_SCALEALPHA","selu_util.SELU_SCALE","NEG","CEIL","FLOOR","SIGN","ROUND","EXP","EXPM1","LOG","LOG1P","SQRT","RSQRT","SIGMOID","SOFTPLUS","SIN","COS","TAN","ASIN","ACOS","ATAN","SINH","COSH","TANH","ASINH","ACOSH","ATANH","ERF","erf_util.ERF_P","erf_util.ERF_A1","erf_util.ERF_A2","erf_util.ERF_A3","erf_util.ERF_A4","erf_util.ERF_A5","SQUARE","RECIPROCAL","LOGICAL_NOT","TO_INT","tensors","$tensors","convertToTensorArray","parseAxisParam","concat2Tensors","concat_util.assertParams","a2D","as2D","b2D","runKernel","concat_","concat1d","concat1d_","concat2d","concat2d_","concat3d","concat3d_","concat4d","concat4d_","global","module","define","copy","s0","s1","s2","impl","opts","xg","me","mash","charCodeAt","next","state","prng","double","quick","exports","amd","alea","z","strseed","xor128","xorwow","Date","X","init","xorshift7","limit","xor4096","tychei","pool","math","nodecrypto","chunks","rngname","startdenom","significance","overflow","mask","seedrandom","options","callback","shortseed","mixkey","prop","typ","entropy","tostring","out","randomBytes","crypto","msCrypto","getRandomValues","browser","plugins","screen","autoseed","arc4","keylen","S","pass","is_math_call","smear","stringseed","fromCharCode","require","sr","stdDeviation","truncated","stdDev","nextVal","upper","lower","seedValue","seedrandom.alea","MPRandGauss","resultX","resultY","isValid","v1","v2","isValidTruncated","convertValue","batchShape","buff","toTensor","randGauss","nextValue","minval","maxval","util.randUniform","randFunction","normalized","origRank","logits2D","multinomial","$indices","oneHot","img","$img","minTensor","maxTensor","multiplier","bytes","Uint8ClampedArray","ctx","imageData","ImageData","putImageData","util.inferFromImplicitShape","xGrad","expandedTensors","reduce","splitSizes","outIndex","numOrSizeSplits","permutation","getAxesPermutation","permutedX","permutedAxis","getInnerMostAxes","cast_","clone_","cumsum_","expandDims_","eye","eye_","fromPixels_","multinomial_","oneHot_","pad_","pad1d","pad1d_","pad2d","pad2d_","pad3d","pad3d_","pad4d","pad4d_","rand","rand_","randomNormal","randomNormal_","randomUniform","randomUniform_","reshape_","split_","squeeze_","stack_","tile_","truncatedNormal","truncatedNormal_","unstack_","batchToSpaceND_","spaceToBatchND_","condShape","condVals","inBuffer","indexToLoc","BEFORE_PAGING_CONSTANT","SIZE_UPLOAD_UNIFORM","delayedStorage","WeakSet","gpgpuCreatedLocally","NUM_BYTES_BEFORE_PAGING","devicePixelRatio","textureManager","MathBackendWebGL","HTMLVideoElement","HTMLImageElement","HTMLCanvasElement","fromPixelsCanvas","readyState","drawImage","tempPixelArray","uploadPixelDataToTexture","getTexture","FromPixelsProgram","compileAndRun","throwIfNoData","releaseTexture","uploadToGPU","cacheOnCPU","shouldTimeProgram","activeTimers","float32Values","getValuesFromTexture","downloadWaitMs","pendingRead","subscribers_1","maybeCreateBufferFromTexture","createAndWaitForFence","WebGLTexture","downloadFloat32MatrixFromBuffer","subscribers","pendingDisposal","downloadFloat32MatrixFromOutputTexture","tmpTarget","tmpInput","EncodeFloatProgram","tmpData","downloadByteEncodedFloatMatrixFromOutputTexture","oldActiveTimers","newActiveTimers","outerMostTime","programTimersStack","flattenedActiveTimers","util.flatten","results","uploadWaitMs","unreliable","numBytesInGPU","startMs","endMs","waitForQueryAndGetTime","timerQuery","getCustomSetupFunc","beginIndex","StridedSliceProgram","ReverseProgram","ConcatProgram","unary_op.NEG","MatMulProgram","binaryop_gpu.MUL","makeOutputArray","BatchNormProgram","LRNProgram","inputImage","outputImage","LRNGradProgram","TileProgram","PadProgram","TransposeProgram","GatherProgram","array_ops_util.getReshaped","array_ops_util.getPermuted","array_ops_util.getReshapedPermuted","array_ops_util.getSliceBeginCoords","array_ops_util.getSliceSize","completePaddings","paddedX","reshapedPaddedShape","permutedReshapedPaddedPermutation","flattenShape","reduce_util.computeOptimalWindowSize","ReduceProgram","cols","bestIndicesA","ArgMinMaxProgram","argReduce","axis_util.assertAxesAreInnerMostDims","outputDType","sumOutType","axis_util.getAxesPermutation","axis_util.getInnerMostAxes","segment_util.computeOutShape","segOpCompute","axis_util.getUndoAxesPermutation","segment_util.segOpComputeOptimalWindowSize","SegmentOpProgram","range","CumSumProgram","binaryop_gpu.EQUAL","binaryop_gpu.NOT_EQUAL","binaryop_gpu.LESS","binaryop_gpu.LESS_EQUAL","binaryop_gpu.GREATER","binaryop_gpu.GREATER_EQUAL","unary_op.LOGICAL_NOT","binaryop_gpu.LOGICAL_AND","binaryop_gpu.LOGICAL_OR","SelectProgram","whereImpl","topkImpl","binaryop_gpu.MIN","binaryop_gpu.MOD","binaryop_gpu.MAX","binaryop_gpu.SQUARED_DIFFERENCE","binaryop_gpu.DIV","binaryop_gpu.INT_DIV","binaryop_gpu.ADD","binaryop_gpu.SUB","binaryop_gpu.POW","unary_op.CEIL","unary_op.FLOOR","unary_op.SIGN","unary_op.ROUND","unary_op.EXP","unary_op.EXPM1","unary_op.LOG","unary_op.LOG1P","unary_op.SQRT","unary_op.RSQRT","unary_op.SQUARE","unary_op.RECIPROCAL","unary_op.RELU","unary_op.ELU","binaryop_gpu.ELU_DER","unary_op.SELU","unary_op.TO_INT","ClipProgram","unary_op.ABS","unary_op.SIGMOID","unary_op.SOFTPLUS","unary_op.SIN","unary_op.COS","unary_op.TAN","unary_op.ASIN","unary_op.ACOS","unary_op.ATAN","binaryop_gpu.ATAN2","unary_op.SINH","unary_op.COSH","unary_op.TANH","unary_op.ASINH","unary_op.ACOSH","unary_op.ATANH","unary_op.ERF","unary_op.STEP","Conv2DProgram","Conv2DDerInputProgram","Conv2DDerFilterProgram","DepthwiseConv2DProgram","DepthwiseConv2DDerInputProgram","DepthwiseConv2DDerFilterProgram","Pool2DProgram","maxPoolPositionsProgram","maxPoolPositions","maxPoolBackPropProgram","MaxPool2DBackpropProgram","avgPoolBackpropProgram","AvgPool2DBackpropProgram","backend_util.castTensor","backend_util.reshapeTensor","ResizeBilinearProgram","ResizeBilinearBackpropProgram","ResizeNearestNeighborProgram","ResizeNearestNeigborBackpropProgram","probs","OneHotProgram","nonMaxSuppressionImpl","pageToCpu","inputsData","outputData","gpgpu_math.makeShaderKey","getAndSaveBinary","gpgpu_math.compileProgram","startTimer","gpgpu_math.runProgram","numBytesToPage","lruDataGPU","computeBytes","endTimer","getBinary","binaryCache","remove","webgl_util.getTextureShapeFromLogicalShape","acquireTexture","uploadMatrixToTexture","typedArrayToFloat32","dontKeepCopyOnGPU","float32ToTypedArray","texType","save","clipValueMin","clipValueMax","clip","PI","registerBackend","abs_","acos_","acosh_","asin_","asinh_","atan_","atanh_","ceil_","clipByValue_","cos_","cosh_","erf_","exp_","expm1_","floor_","log_","log1p_","logSigmoid_","neg_","reciprocal_","round_","rsqrt_","sigmoid_","sign_","sin_","sinh_","softplus_","sqrt_","square_","step_","tan_","tanh_","$scale","$offset","$mean","$variance","x4D","as4D","batchnormReshape4D","scaleValue","reductionAxes","getReductionAxes","tileShape","xMinusMean","dyTimesScaleValue","oneOverSqrtVariance","minusHalfRCube","meanDer","varianceDer","xMinusMean2TimesRsqrt","scaleDer","offsetDer","batchNormalization2d","batchNormalization2d_","batchNormalization3d","batchNormalization3d_","batchNormalization4d","batchNormalization4d_","batchNormalization_","roundingMode","computeConv2DInfo","depthwise","filterChannels","_c","_d","getEffectiveFilterSize","fieldSize","outDepth","zeroPad","computeDefaultPad","inputRows","inputCols","outputRows","conditionalRound","outputCols","effectiveFieldSize","param","bottom","right","computeOutputShape3D","padAlongHeight","padAlongWidth","top_1","$filter","x3D","reshapedTo3D","as3D","eitherStridesOrDilationsAreOne","filter4D","input4D","reshapedTo4D","conv_util.computeConv2DInfo","tupleValuesAreOne","conv2dDerInput_","conv2dDerFilter_","xShape4D","dy4D","inDepth","conv2dDerInput","conv2dDerFilter","depthwiseConv2D","depthwiseConv2dDerInput","depthwiseConv2dDerFilter","depthwiseFilter","pointwiseFilter","$depthwiseFilter","$pointwiseFilter","channelMultiplier","dimA","dimB","depthwiseConv2DDerInput","depthwiseConv2DDerFilter","conv1d_","conv2d_","depthwiseConv2d_","separableConv2d","separableConv2d_","conv2dTranspose_","$a","$b","innerShapeA","innerShapeB","$v1","$v2","t1","t2","$t1","$t2","t1Inner","t2Inner","asScalar","matMul_","dot_","outerProduct","outerProduct_","reshapeAs","reverse_","reverse1d","reverse1d_","reverse2d","reverse2d_","reverse3d","reverse3d_","reverse4d","reverse4d_","conv_util.computePool2DInfo","y4D","maxPoolBackprop","avgPoolBackprop","$dy","$input","$output","maxPool_","avgPool_","begin_","size_","slice_util.assertParamsValid","slice_","slice1d","slice1d_","slice2d","slice2d_","slice3d","slice3d_","slice4d","slice4d_","axis_util.parseAxisParam","xMax","axis_util.expandShapeToKeepDim","toInt","expandedDyShape","reduceSize","axis_util.computeOutAndReduceShapes","reduceSizeScalar","origAxes","permutedAxes","keepDimsShape","all_","any_","argMax_","argMin_","logSumExp_","max_","mean_","min_","moments","moments_","sum_","assertTypesMatch","assertAndGetBroadcastShape","equal_","equalStrict_","greater_","greaterEqual_","greaterEqualStrict_","greaterStrict_","less_","lessEqual_","lessEqualStrict_","lessStrict_","notEqual_","notEqualStrict_","reduceAxes","broadcast_util.getReductionAxes","firstTensor","addN","ders","subtract","base","$base","$exp","multiply","realDivide","tmp","two","atan2","add_","addN_","addStrict_","atan2_","div_","divStrict_","floorDiv_","maximum_","maximumStrict_","minimum_","minimumStrict_","mod_","modStrict_","mul_","mulStrict_","pow_","powStrict_","squaredDifference_","squaredDifferenceStrict_","sub_","subStrict_","$condition","select","logicalAnd_","logicalNot_","logicalOr_","logicalXor_","where_","whereAsync","whereAsync_","stepRes","eluDer","scaleAlpha","greaterThanZeroDer","lessEqualZeroDer","$alpha","zero","elu_","leakyRelu_","prelu_","relu_","selu_","undoPerm","transpose_","localResponseNormalization4D","LRNGrad","localResponseNormalization_","normImpl","norm_","$segmentIds","isInt","gatherDropNegatives","paramsShape","indicesSize","outerShape","outerDims","innerShape","innerDims","outerAxesIndices","arrayRange","innerAxesIndices","valuesShape","arrayConcat","reshapedIndices","transposeDims","valuesTranspose","paramsGrad","invertTransposeDims","getUndoAxesPermutation","arrays","zeroClippedIndices","gathered","isPositive","numIters","zeroSlice","gather_","unsortedSegmentSum_","lstmCells","$data","$c","$h","newStates","newC","newH","forgetBias","lstmKernel","lstmBias","$forgetBias","$lstmKernel","$lstmBias","sliceCols","o","basicLSTMCell","basicLSTMCell_","multiRNNCell","multiRNNCell_","decay","zeroDebias","$v","$decay","one","oneMinusDecay","update","$step","movingAverage","movingAverage_","stridedSlice","stridedSlice_","Reduction","topk","topk_","losses","weights","reduction","SUM_BY_NONZERO_WEIGHTS","$losses","$weights","weightedLoss","NONE","SUM","MEAN","broadcastFactor","numNonZeros","labels","predictions","$labels","$predictions","computeWeightedLoss","epsilon","epsilonScalar","maxOutput","outputXTarget","sigmoidOutput","multiClassLabels","labelSmoothing","$multiClassLabels","labelSmoothingScalar","half","sigmoidCrossEntropyWithLogits_","delta","deltaScalar","quadratic","linear","logResult","dyShape","expandShapeToKeepDim","onehotLabels","$onehotLabels","numClasses","softmaxCrossEntropyWithLogits_","absoluteDifference","absoluteDifference_","computeWeightedLoss_","cosineDistance","cosineDistance_","hingeLoss","hingeLoss_","huberLoss","huberLoss_","logLoss","logLoss_","meanSquaredError","meanSquaredError_","sigmoidCrossEntropy","sigmoidCrossEntropy_","softmaxCrossEntropy","softmaxCrossEntropy_","inputIsTensor2D","ys","xs1d","proj","fullMatrices","qr2d","outerDimsProd","prev","q2ds_1","r2ds_1","x2d","q2d","r2d","m","q","one2D","tensor2d","iters","rTemp","wTemp","qTemp","gramSchmidt","gramSchmidt_","qr","qr_","images","$images","batchImages","resizeBilinearBackprop","resizeNearestNeighborBackprop","NEGATIVE_INFINITY","$boxes","$scores","nonMaxSuppSanityCheck","nonMaxSuppression","boxesVals","scoresVals","numBoxes","resizeBilinear_","resizeNearestNeighbor_","nonMaxSuppression_","nonMaxSuppressionAsync","nonMaxSuppressionAsync_","MathBackendCPU","firstUse","getImageData","numPixels","channel","tensor3d","ops.buffer","xLoc","ops.tensor","newLoc","xBuffer","outLoc","inLoc","aVals","bVals","ops.scalar","broadcastedBinaryOp","aValue","bValue","resultVals","currVals","leftDim","rightDim","aValues","bValues","aOuterStep","aInnerStep","bOuterStep","bInnerStep","aOuterEnd","bOuterEnd","resultIndex","aOuter","bOuter","aInner","bInner","ops.tensor2d","reduceShape","ops.zeros","segmentId","ops.equal","ops.stack","minIndex","maxIndex","resultDtype","indexAdjuster","prevIdx","aVal","bVal","newValues","rem","anyVal","resVals","inVals","resultValues","dyValues","threshold","tooLarge","tooSmall","expX","util.tanh","a1","a2","a3","a4","a5","d2","yR","xRCorner","yC","xCCorner","dotProd","wR","xR","wC","xC","d1","dxValues","dxS0","dxS1","dxS2","dyS0","dyS1","dyS2","fltValues","fltS0","fltS1","fltS2","topPad","leftPad","xRMin","yRMax","xCMin","yCMax","dyOffset","fltOffset","dW","yRMin","yCMin","chMul","dm","trunc","xBuf","originalLoc","i_1","originalIndex","coords","outCoords","i_2","newIndex","indicesValues","xRMax","xCMax","minMaxValue","POSITIVE_INFINITY","avgValue","pixel","maxPositions","maxValue","maxPosition","dxR","dxC","dyRCorner","dyCCorner","dyR","dyC","effectiveInputSize","effectiveOutputSize","sourceFracRow","sourceFracCol","sourceRowFloor","sourceRowCeil","sourceColFloor","sourceColCeil","topLeft","bottomLeft","colFrac","topDxRIndex","bottomDxRIndex","dxRLerp","inverseDxRLerp","leftDxCIndex","rightDxCIndex","dxCLerp","inverseDxCLerp","dyVal","topRight","bottomRight","sourceNearestRow","sourceNearestCol","startRLerp","startDyR","startCLerp","startDyC","accum","dyROffset","dyCOffSet","xValues","meanValues","varianceValues","scaleValues","offsetValues","outValues","tensor4d","sumAcrossChannels","depthBegin","depthEnd","dyi","probabilities","ops.softmax","numEvents","probVals","cdf","event_1","sampleId","event_2","event_3","aBroadcastDims","bBroadcastDims","aBuf","bBuf","aLoc","aIndex","bLoc","bIndex","delayCallback","requestAnimationFrame","setImmediate","DTYPE_VALUE_SIZE_MAP","uint16","uint8","name_1","specs","dataPromises","concatenateTypedArrays","specs_1","spec","name_2","quantization","totalByteLength","normalizedXs","byteLength","useNodeBuffer","Buffer","Blob","atob","btoa","str","buf","byteOffset","buffers","path","trim","items","modelArtifacts","modelTopology","ArrayBuffer","dateSaved","modelTopologyType","modelTopologyBytes","stringByteLength","weightSpecsBytes","weightSpecs","weightDataBytes","weightData","saveRouters","loadRouters","IORouterRegistry","saveRouter","getInstance","loadRouter","url","getHandlers","handlerType","validHandlers","router","URL_SCHEME_SUFFIX","managers","ModelStoreManagerRegistry","scheme","manager","getSchemes","sourceURL","destURL","deleteSource","loadHandlers","getLoadHandlers","loadHandler","saveHandlers","getSaveHandlers","saveHandler","sourceScheme","parseURL","sourcePath","sameMedium","load","getManager","removeModel","saveResult","modelArtifactsInfo","schemes","schemes_1","listModels","schemeOut","schemeAndPath","cloneModelInternal","DATABASE_NAME","DATABASE_VERSION","MODEL_STORE_NAME","INFO_STORE_NAME","theWindow","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","shimIndexedDB","openRequest","db","createObjectStore","keyPath","modelPath","getIndexedDBFactory","BrowserIndexedDB","databaseAction","open","onupgradeneeded","setUpDatabase","onsuccess","modelTx","transaction","getRequest_1","objectStore","close","onerror","oncomplete","modelTx_1","modelArtifactsInfo_1","getModelArtifactsInfoForJSON","infoTx_1","infoStore_1","putInfoRequest_1","put","putModelRequest","deleteInfoRequest","indexedDBRouter","startsWith","URL_SCHEME","browserIndexedDB","registerSaveRouter","registerLoadRouter","BrowserIndexedDBManager","tx","getAllInfoRequest","getAll","item","maybeStripScheme","infoTx","infoStore","getInfoRequest","deleteModelData_1","deleteModelRequest","registerManager","PATH_SEPARATOR","PATH_PREFIX","INFO_SUFFIX","MODEL_TOPOLOGY_SUFFIX","WEIGHT_SPECS_SUFFIX","WEIGHT_DATA_SUFFIX","topology","BrowserLocalStorage","localStorage","LS","getModelKeys","setItem","arrayBufferToBase64String","removeItem","getItem","weightDataBase64","base64StringToArrayBuffer","localStorageRouter","browserLocalStorage","BrowserLocalStorageManager","prefix","suffix","getModelPathFromKey","DEFAULT_FILE_NAME_PREFIX","DEFAULT_JSON_EXTENSION_NAME","DEFAULT_WEIGHT_DATA_EXTENSION_NAME","fileNamePrefix","BrowserDownloads","modelTopologyFileName","weightDataFileName","weightsURL","URL","createObjectURL","weightsManifest","paths","modelTopologyAndWeightManifest","modelTopologyAndWeightManifestURL","jsonAnchor","download","href","click","weightDataAnchor","files","BrowserFiles","jsonFile","weightFiles","jsonReader","FileReader","onload","event","modelJSON","target","pathToFile","checkManifestAndWeightFiles","perFileBuffers","weightsGroup","weightFileReader","concatenateArrayBuffers","readAsArrayBuffer","readAsText","manifest","basenames","fileNames","file","basename","manifest_1","pathBasename","browserDownloadsRouter","browserDownloads","fetchURLs","requestOptions","requests","fetchURL","fetch","responses","response","arrayBuffer","filePathPrefix","weightNames","groupIndicesToFetchMap","groupWeightsToFetch","weightsFound","allManifestWeightNames","manifestGroupConfig","groupIndex","groupOffset","weightsEntry","rawDtype","weightsBytes","enqueueWeightsForFetchingFn","manifestEntry","sizeBytes","weightName","weightIndex","found","weightsNotFound","weight","groupIndicesToFetch","accumulator","shouldFetch","fetchUrls","filepath","fetchUrl","loadWeightsAsArrayBuffer","weightsTensorMap","bufferIndexOffset","numBuffers","groupBytes","groupBuffer","groupByteBuffer","groupBufferOffset","typedArray","byteBuffer","quantization_1","quantizedArray","requestInit","body","BrowserHTTPRequest","method","DEFAULT_METHOD","FormData","append","json","modelConfig","weightsManifest_2","weightsManifest_1","pathPrefix_1","lastIndexOf","fetchURLs_1","httpRequestRouter","URL_SCHEMES","browserHTTPRequest","PassthroughLoader","PassthroughSaver","Serializable","className","cls","config","classNameMap","SerializationMap","getMap","fromConfig","WEBGL_ENVS","HAS_WEBGL","NODE_ENVS","IS_NODE","CHROME_ENVS","IS_CHROME","BROWSER_ENVS","IS_BROWSER","CPU_ENVS","ALL_ENVS","actual","expected","aType","bType","actualValues","expectedValues","areClose","fail","expectArraysClose","low","high","actualVals","expect","toEqual","version","Optimizer","returnCost","applyGradients","variableGrads","DEFAULT_FLOAT32_EPSILON","DEFAULT_FLOAT16_EPSILON","learningRate","rho","rhoScalar","oneMinusRho","optimizer_utils.getOptimizerDefaultEpsilonValue","AdadeltaOptimizer","variableGradients","this_1","accumulatedGrads","accumulatedUpdates","accumulatedGrad","accumulatedUpdate","newAccumulatedGrad","updates","newAccumulatedUpdate","initialAccumulatorValue","AdagradOptimizer","beta1","beta2","beta1Scalar","beta2Scalar","accBeta1","accBeta2","oneMinusBeta1","oneMinusBeta2","epsScalar","AdamOptimizer","oneMinusAccBeta1","oneMinusAccBeta2","accumulatedFirstMoment","accumulatedSecondMoment","firstMoment","secondMoment","newFirstMoment","newSecondMoment","biasCorrectedFirstMoment","biasCorrectedSecondMoment","decayScalar","iteration","AdamaxOptimizer","lr","accumulatedWeightedInfNorm","weightedInfNorm","ut0","ut1","newWeightedInfNorm","setLearningRate","SGDOptimizer","momentum","useNesterov","accumulations","MomentumOptimizer","accumulation","newAccumulation","centered","momentumScalar","RMSPropOptimizer","accumulatedMeanSquares","accumulatedMeanGrads","accumulatedMoments","accumulatedMeanSquare","accumulatedMeanGrad","newAccumulatedMeanSquare","newAccumulatedMeanGrad","newAccumulatedMoments","newAccumulatedMeanSquare_1","OptimizerConstructors","train","sgd","adadelta","adagrad","rmsprop","adamax","adam","setBackend","getBackend","setOpHandler","ops"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.js b/node_modules/@tensorflow/tfjs-core/dist/tf-core.js new file mode 100644 index 0000000..e8d193c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.js @@ -0,0 +1,15500 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (factory((global.tf = global.tf || {}))); +}(this, (function (exports) { 'use strict'; + + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. 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 + + THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED + WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, + MERCHANTABLITY OR NON-INFRINGEMENT. + + See the Apache Version 2.0 License for specific language governing permissions + and limitations under the License. + ***************************************************************************** */ + /* global Reflect, Promise */ + + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + + function __extends(d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + } + + var __assign = Object.assign || function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; + + function __awaiter(thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + } + + function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + } + + function isMobile() { + var a = navigator.userAgent || navigator.vendor || window.opera; + return /(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i + .test(a) || + /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i + .test(a.substr(0, 4)); + } + + function shuffle(array) { + var counter = array.length; + var temp = 0; + var index = 0; + while (counter > 0) { + index = (Math.random() * counter) | 0; + counter--; + temp = array[counter]; + array[counter] = array[index]; + array[index] = temp; + } + } + function clamp(min, x, max) { + return Math.max(min, Math.min(x, max)); + } + function randUniform(a, b) { + return Math.random() * (b - a) + a; + } + function distSquared(a, b) { + var result = 0; + for (var i = 0; i < a.length; i++) { + var diff = Number(a[i]) - Number(b[i]); + result += diff * diff; + } + return result; + } + function assert(expr, msg) { + if (!expr) { + throw new Error(typeof msg === 'string' ? msg : msg()); + } + } + function assertShapesMatch(shapeA, shapeB, errorMessagePrefix) { + if (errorMessagePrefix === void 0) { errorMessagePrefix = ''; } + assert(arraysEqual(shapeA, shapeB), errorMessagePrefix + (" Shapes " + shapeA + " and " + shapeB + " must match")); + } + function assertNonNull(a) { + assert(a != null, "The input to the tensor constructor must be a non-null value."); + } + function flatten(arr, ret) { + if (ret === void 0) { ret = []; } + if (Array.isArray(arr)) { + for (var i = 0; i < arr.length; ++i) { + flatten(arr[i], ret); + } + } + else { + ret.push(arr); + } + return ret; + } + function inferShape(val) { + var firstElem = val; + if (isTypedArray(val)) { + return [val.length]; + } + if (!Array.isArray(val)) { + return []; + } + var shape = []; + while (firstElem instanceof Array) { + shape.push(firstElem.length); + firstElem = firstElem[0]; + } + if (val instanceof Array) { + deepAssertShapeConsistency(val, shape, []); + } + return shape; + } + function deepAssertShapeConsistency(val, shape, indices) { + indices = indices || []; + if (!(val instanceof Array)) { + assert(shape.length === 0, function () { return "Element arr[" + indices.join('][') + "] is a primitive, " + + ("but should be an array of " + shape[0] + " elements"); }); + return; + } + assert(shape.length > 0, function () { return "Element arr[" + indices.join('][') + "] should be a primitive, " + + ("but is an array of " + val.length + " elements"); }); + assert(val.length === shape[0], function () { return "Element arr[" + indices.join('][') + "] should have " + shape[0] + " " + + ("elements, but has " + val.length + " elements"); }); + var subShape = shape.slice(1); + for (var i = 0; i < val.length; ++i) { + deepAssertShapeConsistency(val[i], subShape, indices.concat(i)); + } + } + function sizeFromShape(shape) { + if (shape.length === 0) { + return 1; + } + var size = shape[0]; + for (var i = 1; i < shape.length; i++) { + size *= shape[i]; + } + return size; + } + function isScalarShape(shape) { + return shape.length === 0; + } + function arraysEqual(n1, n2) { + if (n1.length !== n2.length) { + return false; + } + for (var i = 0; i < n1.length; i++) { + if (n1[i] !== n2[i]) { + return false; + } + } + return true; + } + function isInt(a) { + return a % 1 === 0; + } + function tanh(x) { + if (Math.tanh != null) { + return Math.tanh(x); + } + if (x === Infinity) { + return 1; + } + else if (x === -Infinity) { + return -1; + } + else { + var e2x = Math.exp(2 * x); + return (e2x - 1) / (e2x + 1); + } + } + function sizeToSquarishShape(size) { + for (var a = Math.floor(Math.sqrt(size)); a > 1; --a) { + if (size % a === 0) { + return [a, size / a]; + } + } + return [1, size]; + } + function createShuffledIndices(n) { + var shuffledIndices = new Uint32Array(n); + for (var i = 0; i < n; ++i) { + shuffledIndices[i] = i; + } + shuffle(shuffledIndices); + return shuffledIndices; + } + function rightPad(a, size) { + if (size <= a.length) { + return a; + } + return a + ' '.repeat(size - a.length); + } + function repeatedTry(checkFn, delayFn, maxCounter) { + if (delayFn === void 0) { delayFn = function (counter) { return 0; }; } + return new Promise(function (resolve, reject) { + var tryCount = 0; + var tryFn = function () { + if (checkFn()) { + resolve(); + return; + } + tryCount++; + var nextBackoff = delayFn(tryCount); + if (maxCounter != null && tryCount >= maxCounter) { + reject(); + return; + } + setTimeout(tryFn, nextBackoff); + }; + tryFn(); + }); + } + function inferFromImplicitShape(shape, size) { + var shapeProd = 1; + var implicitIdx = -1; + for (var i = 0; i < shape.length; ++i) { + if (shape[i] > 0) { + shapeProd *= shape[i]; + } + else if (shape[i] === -1) { + if (implicitIdx !== -1) { + throw Error("Shapes can only have 1 implicit size. " + + ("Found - 1 at dim " + implicitIdx + " and dim " + i)); + } + implicitIdx = i; + } + else if (shape[i] <= 0) { + throw Error("Shapes can not be <= 0. Found " + shape[i] + " at dim " + i); + } + } + if (implicitIdx === -1) { + if (size > 0 && size !== shapeProd) { + throw Error("Size(" + size + ") must match the product of shape " + shape); + } + return shape; + } + if (size % shapeProd !== 0) { + throw Error("The implicit shape can't be a fractional number. " + + ("Got " + size + " / " + shapeProd)); + } + var newShape = shape.slice(); + newShape[implicitIdx] = size / shapeProd; + return newShape; + } + function squeezeShape(shape, axis) { + var newShape = []; + var keptDims = []; + var j = 0; + for (var i = 0; i < shape.length; ++i) { + if (axis != null) { + if (axis[j] === i && shape[i] > 1) { + throw new Error("Can't squeeze axis " + i + " since its dim '" + shape[i] + "' is not 1"); + } + if ((axis[j] == null || axis[j] > i) && shape[i] === 1) { + newShape.push(shape[i]); + keptDims.push(i); + } + if (axis[j] <= i) { + j++; + } + } + if (shape[i] > 1) { + newShape.push(shape[i]); + keptDims.push(i); + } + } + return { newShape: newShape, keptDims: keptDims }; + } + function getTypedArrayFromDType(dtype, size) { + var values = null; + if (dtype == null || dtype === 'float32') { + values = new Float32Array(size); + } + else if (dtype === 'int32') { + values = new Int32Array(size); + } + else if (dtype === 'bool') { + values = new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } + return values; + } + function checkComputationForNaN(vals, dtype, name) { + if (dtype !== 'float32') { + return; + } + for (var i = 0; i < vals.length; i++) { + if (isNaN(vals[i])) { + throw Error("The result of the '" + name + "' has NaNs."); + } + } + } + function checkConversionForNaN(vals, dtype) { + if (dtype === 'float32') { + return; + } + for (var i = 0; i < vals.length; i++) { + if (isNaN(vals[i])) { + throw Error("NaN is not a valid value for dtype: '" + dtype + "'."); + } + } + } + function hasEncodingLoss(oldType, newType) { + if (newType === 'float32') { + return false; + } + if (newType === 'int32' && oldType !== 'float32') { + return false; + } + if (newType === 'bool' && oldType === 'bool') { + return false; + } + return true; + } + function copyTypedArray(array, dtype, debugMode) { + if (dtype == null || dtype === 'float32') { + return new Float32Array(array); + } + else if (dtype === 'int32') { + if (debugMode) { + checkConversionForNaN(array, dtype); + } + return new Int32Array(array); + } + else if (dtype === 'bool') { + var bool = new Uint8Array(array.length); + for (var i = 0; i < bool.length; ++i) { + if (Math.round(array[i]) !== 0) { + bool[i] = 1; + } + } + return bool; + } + else { + throw new Error("Unknown data type " + dtype); + } + } + function isTypedArray(a) { + return a instanceof Float32Array || a instanceof Int32Array || + a instanceof Uint8Array; + } + function bytesPerElement(dtype) { + if (dtype === 'float32' || dtype === 'int32') { + return 4; + } + else if (dtype === 'bool') { + return 1; + } + else { + throw new Error("Unknown dtype " + dtype); + } + } + function isFunction(f) { + return !!(f && f.constructor && f.call && f.apply); + } + function nearestDivisor(size, start) { + for (var i = start; i < size; ++i) { + if (size % i === 0) { + return i; + } + } + return size; + } + function computeStrides(shape) { + var rank = shape.length; + if (rank < 2) { + return []; + } + var strides = new Array(rank - 1); + strides[rank - 2] = shape[rank - 1]; + for (var i = rank - 3; i >= 0; --i) { + strides[i] = strides[i + 1] * shape[i + 1]; + } + return strides; + } + function toTypedArray(a, dtype, debugMode) { + if (noConversionNeeded(a, dtype)) { + return a; + } + if (Array.isArray(a)) { + a = flatten(a); + } + return copyTypedArray(a, dtype, debugMode); + } + function noConversionNeeded(a, dtype) { + return (a instanceof Float32Array && dtype === 'float32') || + (a instanceof Int32Array && dtype === 'int32') || + (a instanceof Uint8Array && dtype === 'bool'); + } + function makeOnesTypedArray(size, dtype) { + var array = makeZerosTypedArray(size, dtype); + for (var i = 0; i < array.length; i++) { + array[i] = 1; + } + return array; + } + function makeZerosTypedArray(size, dtype) { + if (dtype == null || dtype === 'float32') { + return new Float32Array(size); + } + else if (dtype === 'int32') { + return new Int32Array(size); + } + else if (dtype === 'bool') { + return new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } + } + function now() { + if (typeof performance !== 'undefined') { + return performance.now(); + } + else if (typeof process !== 'undefined') { + var time = process.hrtime(); + return time[0] * 1000 + time[1] / 1000000; + } + else { + throw new Error('Can not measure time in this environment. You should run tf.js ' + + 'in the browser or in Node.js'); + } + } + + var util = /*#__PURE__*/Object.freeze({ + shuffle: shuffle, + clamp: clamp, + randUniform: randUniform, + distSquared: distSquared, + assert: assert, + assertShapesMatch: assertShapesMatch, + assertNonNull: assertNonNull, + flatten: flatten, + inferShape: inferShape, + sizeFromShape: sizeFromShape, + isScalarShape: isScalarShape, + arraysEqual: arraysEqual, + isInt: isInt, + tanh: tanh, + sizeToSquarishShape: sizeToSquarishShape, + createShuffledIndices: createShuffledIndices, + rightPad: rightPad, + repeatedTry: repeatedTry, + inferFromImplicitShape: inferFromImplicitShape, + squeezeShape: squeezeShape, + getTypedArrayFromDType: getTypedArrayFromDType, + checkComputationForNaN: checkComputationForNaN, + checkConversionForNaN: checkConversionForNaN, + hasEncodingLoss: hasEncodingLoss, + isTypedArray: isTypedArray, + bytesPerElement: bytesPerElement, + isFunction: isFunction, + nearestDivisor: nearestDivisor, + computeStrides: computeStrides, + toTypedArray: toTypedArray, + makeOnesTypedArray: makeOnesTypedArray, + makeZerosTypedArray: makeZerosTypedArray, + now: now + }); + + var Profiler = (function () { + function Profiler(backendTimer, logger) { + this.backendTimer = backendTimer; + this.logger = logger; + if (logger == null) { + this.logger = new Logger(); + } + } + Profiler.prototype.profileKernel = function (name, f) { + var _this = this; + var result; + var holdResultWrapperFn = function () { + result = f(); + }; + var timer = this.backendTimer.time(holdResultWrapperFn); + var results = Array.isArray(result) ? result : [result]; + results.forEach(function (r) { + var vals = r.dataSync(); + checkComputationForNaN(vals, r.dtype, name); + timer.then(function (timing) { + _this.logger.logKernelProfile(name, r, vals, timing.kernelMs); + }); + }); + return result; + }; + return Profiler; + }()); + var Logger = (function () { + function Logger() { + } + Logger.prototype.logKernelProfile = function (name, result, vals, timeMs) { + var time = rightPad(timeMs + "ms", 9); + var paddedName = rightPad(name, 25); + var rank = result.rank; + var size = result.size; + var shape = rightPad(result.shape.toString(), 14); + console.log("%c" + paddedName + "\t%c" + time + "\t%c" + rank + "D " + shape + "\t%c" + size, 'font-weight:bold', 'color:red', 'color:blue', 'color: orange'); + }; + return Logger; + }()); + + function getFilteredNodesXToY(tape, xs, y) { + var tensorsFromX = {}; + var nodesFromX = {}; + for (var i = 0; i < xs.length; i++) { + tensorsFromX[xs[i].id] = true; + } + for (var i = 0; i < tape.length; i++) { + var node = tape[i]; + var nodeInputs = node.inputs; + for (var inputName in nodeInputs) { + var input = nodeInputs[inputName]; + var anyInputFromX = false; + for (var j = 0; j < xs.length; j++) { + if (tensorsFromX[input.id]) { + tensorsFromX[node.output.id] = true; + anyInputFromX = true; + nodesFromX[node.id] = true; + break; + } + } + if (anyInputFromX) { + break; + } + } + } + var tensorsLeadToY = {}; + tensorsLeadToY[y.id] = true; + var nodesToY = {}; + for (var i = tape.length - 1; i >= 0; i--) { + var node = tape[i]; + var nodeInputs = node.inputs; + var outputs = []; + outputs.push(node.output); + for (var j = 0; j < outputs.length; j++) { + if (tensorsLeadToY[outputs[j].id]) { + for (var inputName in nodeInputs) { + tensorsLeadToY[nodeInputs[inputName].id] = true; + nodesToY[node.id] = true; + } + break; + } + } + } + var filteredTape = []; + for (var i = 0; i < tape.length; i++) { + var node = tape[i]; + if (nodesFromX[node.id] && nodesToY[node.id]) { + var prunedInputs = {}; + for (var inputName in node.inputs) { + var nodeInput = node.inputs[inputName]; + if (tensorsFromX[nodeInput.id]) { + prunedInputs[inputName] = nodeInput; + } + } + var prunedNode = Object.assign({}, node); + prunedNode.inputs = prunedInputs; + prunedNode.output = node.output; + filteredTape.push(prunedNode); + } + } + return filteredTape; + } + function backpropagateGradients(tensorAccumulatedGradientMap, filteredTape) { + for (var i = filteredTape.length - 1; i >= 0; i--) { + var node = filteredTape[i]; + var dy = tensorAccumulatedGradientMap[node.output.id]; + if (node.gradient == null) { + throw new Error("Cannot compute gradient: gradient function not found " + + ("for " + node.name + ".")); + } + var inputGradients = node.gradient(dy); + for (var inputName in node.inputs) { + if (!(inputName in inputGradients)) { + throw new Error("Cannot backprop through input " + inputName + ". " + + ("Available gradients found: " + Object.keys(inputGradients) + ".")); + } + var dx = inputGradients[inputName](); + var x = node.inputs[inputName]; + if (!arraysEqual(dx.shape, x.shape)) { + throw new Error("Error in gradient for op " + node.name + ". The gradient of input " + + ("'" + inputName + "' has shape '" + dx.shape + "', which does not match ") + + ("the shape of the input '" + x.shape + "'")); + } + if (tensorAccumulatedGradientMap[x.id] == null) { + tensorAccumulatedGradientMap[x.id] = dx; + } + else { + var curGradient = tensorAccumulatedGradientMap[x.id]; + tensorAccumulatedGradientMap[x.id] = curGradient.add(dx); + curGradient.dispose(); + } + } + } + } + + var FORMAT_LIMIT_NUM_VALS = 20; + var FORMAT_NUM_FIRST_LAST_VALS = 3; + var FORMAT_NUM_SIG_DIGITS = 7; + function tensorToString(vals, shape, dtype, verbose) { + var strides = computeStrides(shape); + var padPerCol = computeMaxSizePerColumn(vals, shape, strides); + var rank = shape.length; + var valsLines = subTensorToString(vals, shape, strides, padPerCol); + var lines = ['Tensor']; + if (verbose) { + lines.push(" dtype: " + dtype); + lines.push(" rank: " + rank); + lines.push(" shape: [" + shape + "]"); + lines.push(" values:"); + } + lines.push(valsLines.map(function (l) { return ' ' + l; }).join('\n')); + return lines.join('\n'); + } + function computeMaxSizePerColumn(vals, shape, strides) { + var n = sizeFromShape(shape); + var numCols = strides[strides.length - 1]; + var padPerCol = new Array(numCols).fill(0); + var rank = shape.length; + if (rank > 1) { + for (var row = 0; row < n / numCols; row++) { + var offset = row * numCols; + for (var j = 0; j < numCols; j++) { + padPerCol[j] = + Math.max(padPerCol[j], valToString(vals[offset + j], 0).length); + } + } + } + return padPerCol; + } + function valToString(val, pad) { + return rightPad(parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), pad); + } + function subTensorToString(vals, shape, strides, padPerCol, isLast) { + if (isLast === void 0) { isLast = true; } + var size = shape[0]; + var rank = shape.length; + if (rank === 0) { + return [vals[0].toString()]; + } + if (rank === 1) { + if (size > FORMAT_LIMIT_NUM_VALS) { + var firstVals = Array.from(vals.subarray(0, FORMAT_NUM_FIRST_LAST_VALS)); + var lastVals = Array.from(vals.subarray(size - FORMAT_NUM_FIRST_LAST_VALS, size)); + return [ + '[' + firstVals.map(function (x, i) { return valToString(x, padPerCol[i]); }).join(', ') + + ', ..., ' + + lastVals + .map(function (x, i) { return valToString(x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i]); }) + .join(', ') + + ']' + ]; + } + return [ + '[' + + Array.from(vals).map(function (x, i) { return valToString(x, padPerCol[i]); }).join(', ') + + ']' + ]; + } + var subshape = shape.slice(1); + var substrides = strides.slice(1); + var stride = strides[0]; + var lines = []; + if (size > FORMAT_LIMIT_NUM_VALS) { + for (var i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, false)); + } + lines.push('...'); + for (var i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, i === size - 1)); + } + } + else { + for (var i = 0; i < size; i++) { + var start = i * stride; + var end = start + stride; + lines.push.apply(lines, subTensorToString(vals.subarray(start, end), subshape, substrides, padPerCol, i === size - 1)); + } + } + var sep = rank === 2 ? ',' : ''; + lines[0] = '[' + lines[0] + sep; + for (var i = 1; i < lines.length - 1; i++) { + lines[i] = ' ' + lines[i] + sep; + } + var newLineSep = ',\n'; + for (var i = 2; i < rank; i++) { + newLineSep += '\n'; + } + lines[lines.length - 1] = + ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep); + return lines; + } + + var TensorBuffer = (function () { + function TensorBuffer(shape, dtype, values) { + this.dtype = dtype; + if (values != null) { + var n = values.length; + var size = sizeFromShape(shape); + assert(n === size, "Length of values '" + n + "' does not match the size " + + ("inferred by the shape '" + size + "'")); + } + this.shape = shape.slice(); + this.values = + values || getTypedArrayFromDType(dtype, sizeFromShape(shape)); + this.strides = computeStrides(shape); + this.size = sizeFromShape(shape); + } + TensorBuffer.prototype.set = function (value) { + var locs = []; + for (var _i = 1; _i < arguments.length; _i++) { + locs[_i - 1] = arguments[_i]; + } + if (locs.length === 0) { + locs = [0]; + } + assert(locs.length === this.rank, "The number of provided coordinates (" + locs.length + ") must " + + ("match the rank (" + this.rank + ")")); + var index = this.locToIndex(locs); + this.values[index] = value; + }; + TensorBuffer.prototype.get = function () { + var locs = []; + for (var _i = 0; _i < arguments.length; _i++) { + locs[_i] = arguments[_i]; + } + if (locs.length === 0) { + locs = [0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return this.values[index]; + }; + TensorBuffer.prototype.locToIndex = function (locs) { + if (this.rank === 0) { + return 0; + } + else if (this.rank === 1) { + return locs[0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return index; + }; + TensorBuffer.prototype.indexToLoc = function (index) { + if (this.rank === 0) { + return []; + } + else if (this.rank === 1) { + return [index]; + } + var locs = new Array(this.shape.length); + for (var i = 0; i < locs.length - 1; ++i) { + locs[i] = Math.floor(index / this.strides[i]); + index -= locs[i] * this.strides[i]; + } + locs[locs.length - 1] = index; + return locs; + }; + Object.defineProperty(TensorBuffer.prototype, "rank", { + get: function () { + return this.shape.length; + }, + enumerable: true, + configurable: true + }); + TensorBuffer.prototype.toTensor = function () { + return Tensor.make(this.shape, { values: this.values }, this.dtype); + }; + return TensorBuffer; + }()); + var trackerFn = null; + var opHandler = null; + function setTensorTracker(fn) { + trackerFn = fn; + } + function setOpHandler(handler) { + opHandler = handler; + } + var Tensor = (function () { + function Tensor(shape, dtype, values, dataId) { + this.isDisposedInternal = false; + this.size = sizeFromShape(shape); + if (values != null) { + assert(this.size === values.length, "Constructing tensor of shape (" + this.size + ") should match the " + + ("length of values (" + values.length + ")")); + } + this.shape = shape.slice(); + this.dtype = dtype || 'float32'; + this.strides = computeStrides(shape); + this.dataId = dataId != null ? dataId : {}; + this.id = Tensor.nextId++; + this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher'); + trackerFn().registerTensor(this); + if (values != null) { + trackerFn().write(this.dataId, values); + } + } + Tensor.make = function (shape, data, dtype) { + return new Tensor(shape, dtype, data.values, data.dataId); + }; + Tensor.prototype.flatten = function () { + this.throwIfDisposed(); + return this.as1D(); + }; + Tensor.prototype.asScalar = function () { + this.throwIfDisposed(); + assert(this.size === 1, 'The array must have only 1 element.'); + return this.reshape([]); + }; + Tensor.prototype.as1D = function () { + this.throwIfDisposed(); + return this.reshape([this.size]); + }; + Tensor.prototype.as2D = function (rows, columns) { + this.throwIfDisposed(); + return this.reshape([rows, columns]); + }; + Tensor.prototype.as3D = function (rows, columns, depth) { + this.throwIfDisposed(); + return this.reshape([rows, columns, depth]); + }; + Tensor.prototype.as4D = function (rows, columns, depth, depth2) { + this.throwIfDisposed(); + return this.reshape([rows, columns, depth, depth2]); + }; + Tensor.prototype.asType = function (dtype) { + this.throwIfDisposed(); + return opHandler.cast(this, dtype); + }; + Object.defineProperty(Tensor.prototype, "rank", { + get: function () { + return this.shape.length; + }, + enumerable: true, + configurable: true + }); + Tensor.prototype.get = function () { + var locs = []; + for (var _i = 0; _i < arguments.length; _i++) { + locs[_i] = arguments[_i]; + } + assert(locs.length === this.rank, 'Number of coordinates in get() must match the rank of the tensor'); + this.throwIfDisposed(); + if (locs.length === 0) { + locs = [0]; + } + var index = locs[locs.length - 1]; + for (var i = 0; i < locs.length - 1; ++i) { + index += this.strides[i] * locs[i]; + } + return this.dataSync()[index]; + }; + Tensor.prototype.buffer = function () { + return opHandler.buffer(this.shape, this.dtype, this.dataSync()); + }; + Tensor.prototype.data = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.throwIfDisposed(); + return [2, trackerFn().read(this.dataId)]; + }); + }); + }; + Tensor.prototype.dataSync = function () { + this.throwIfDisposed(); + return trackerFn().readSync(this.dataId); + }; + Tensor.prototype.dispose = function () { + if (this.isDisposed) { + return; + } + trackerFn().disposeTensor(this); + this.isDisposedInternal = true; + }; + Object.defineProperty(Tensor.prototype, "isDisposed", { + get: function () { + return this.isDisposedInternal; + }, + enumerable: true, + configurable: true + }); + Tensor.prototype.throwIfDisposed = function () { + if (this.isDisposed) { + throw new Error("Tensor is disposed."); + } + }; + Tensor.prototype.toFloat = function () { + return this.asType('float32'); + }; + Tensor.prototype.toInt = function () { + return this.asType('int32'); + }; + Tensor.prototype.toBool = function () { + return this.asType('bool'); + }; + Tensor.prototype.print = function (verbose) { + if (verbose === void 0) { verbose = false; } + return opHandler.print(this, verbose); + }; + Tensor.prototype.reshape = function (newShape) { + this.throwIfDisposed(); + return opHandler.reshape(this, newShape); + }; + Tensor.prototype.reshapeAs = function (x) { + this.throwIfDisposed(); + return this.reshape(x.shape); + }; + Tensor.prototype.expandDims = function (axis) { + if (axis === void 0) { axis = 0; } + return opHandler.expandDims(this, axis); + }; + Tensor.prototype.cumsum = function (axis, exclusive, reverse) { + if (axis === void 0) { axis = 0; } + if (exclusive === void 0) { exclusive = false; } + if (reverse === void 0) { reverse = false; } + return opHandler.cumsum(this, axis, exclusive, reverse); + }; + Tensor.prototype.squeeze = function (axis) { + this.throwIfDisposed(); + return opHandler.squeeze(this, axis); + }; + Tensor.prototype.clone = function () { + this.throwIfDisposed(); + return opHandler.clone(this); + }; + Tensor.prototype.toString = function (verbose) { + if (verbose === void 0) { verbose = false; } + var vals = this.dataSync(); + return tensorToString(vals, this.shape, this.dtype, verbose); + }; + Tensor.prototype.tile = function (reps) { + this.throwIfDisposed(); + return opHandler.tile(this, reps); + }; + Tensor.prototype.gather = function (indices, axis) { + if (axis === void 0) { axis = 0; } + this.throwIfDisposed(); + return opHandler.gather(this, indices, axis); + }; + Tensor.prototype.matMul = function (b, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + this.throwIfDisposed(); + return opHandler.matMul(this, b, transposeA, transposeB); + }; + Tensor.prototype.dot = function (b) { + this.throwIfDisposed(); + return opHandler.dot(this, b); + }; + Tensor.prototype.norm = function (ord, axis, keepDims) { + if (ord === void 0) { ord = 'euclidean'; } + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.norm(this, ord, axis, keepDims); + }; + Tensor.prototype.slice = function (begin, size) { + this.throwIfDisposed(); + return opHandler.slice(this, begin, size); + }; + Tensor.prototype.reverse = function (axis) { + this.throwIfDisposed(); + return opHandler.reverse(this, axis); + }; + Tensor.prototype.concat = function (x, axis) { + if (axis === void 0) { axis = 0; } + this.throwIfDisposed(); + return opHandler.concat([this, x], axis); + }; + Tensor.prototype.stack = function (x, axis) { + if (axis === void 0) { axis = 0; } + return opHandler.stack([this, x], axis); + }; + Tensor.prototype.unstack = function (x, axis) { + if (axis === void 0) { axis = 0; } + return opHandler.unstack(this, axis); + }; + Tensor.prototype.pad = function (paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + return opHandler.pad(this, paddings, constantValue); + }; + Tensor.prototype.batchNormalization = function (mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + this.throwIfDisposed(); + return opHandler.batchNormalization(this, mean, variance, varianceEpsilon, scale, offset); + }; + Tensor.prototype.all = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.all(this, axis, keepDims); + }; + Tensor.prototype.any = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.any(this, axis, keepDims); + }; + Tensor.prototype.logSumExp = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.logSumExp(this, axis, keepDims); + }; + Tensor.prototype.sum = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.sum(this, axis, keepDims); + }; + Tensor.prototype.mean = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.mean(this, axis, keepDims); + }; + Tensor.prototype.min = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.min(this, axis, keepDims); + }; + Tensor.prototype.max = function (axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + this.throwIfDisposed(); + return opHandler.max(this, axis, keepDims); + }; + Tensor.prototype.argMin = function (axis) { + if (axis === void 0) { axis = null; } + this.throwIfDisposed(); + return opHandler.argMin(this, axis); + }; + Tensor.prototype.argMax = function (axis) { + if (axis === void 0) { axis = null; } + this.throwIfDisposed(); + return opHandler.argMax(this, axis); + }; + Tensor.prototype.cast = function (dtype) { + this.throwIfDisposed(); + return opHandler.cast(this, dtype); + }; + Tensor.prototype.add = function (x) { + this.throwIfDisposed(); + return opHandler.add(this, x); + }; + Tensor.prototype.addStrict = function (x) { + this.throwIfDisposed(); + return opHandler.addStrict(this, x); + }; + Tensor.prototype.sub = function (x) { + this.throwIfDisposed(); + return opHandler.sub(this, x); + }; + Tensor.prototype.subStrict = function (x) { + this.throwIfDisposed(); + return opHandler.subStrict(this, x); + }; + Tensor.prototype.pow = function (exp) { + this.throwIfDisposed(); + return opHandler.pow(this, exp); + }; + Tensor.prototype.powStrict = function (exp) { + this.throwIfDisposed(); + return opHandler.powStrict(this, exp); + }; + Tensor.prototype.mul = function (x) { + this.throwIfDisposed(); + return opHandler.mul(this, x); + }; + Tensor.prototype.mulStrict = function (x) { + this.throwIfDisposed(); + return opHandler.mulStrict(this, x); + }; + Tensor.prototype.div = function (x) { + this.throwIfDisposed(); + return opHandler.div(this, x); + }; + Tensor.prototype.floorDiv = function (x) { + this.throwIfDisposed(); + return opHandler.floorDiv(this, x); + }; + Tensor.prototype.divStrict = function (x) { + this.throwIfDisposed(); + return opHandler.divStrict(this, x); + }; + Tensor.prototype.minimum = function (x) { + this.throwIfDisposed(); + return opHandler.minimum(this, x); + }; + Tensor.prototype.minimumStrict = function (x) { + this.throwIfDisposed(); + return opHandler.minimumStrict(this, x); + }; + Tensor.prototype.maximum = function (x) { + this.throwIfDisposed(); + return opHandler.maximum(this, x); + }; + Tensor.prototype.maximumStrict = function (x) { + this.throwIfDisposed(); + return opHandler.maximumStrict(this, x); + }; + Tensor.prototype.mod = function (x) { + this.throwIfDisposed(); + return opHandler.mod(this, x); + }; + Tensor.prototype.modStrict = function (x) { + this.throwIfDisposed(); + return opHandler.modStrict(this, x); + }; + Tensor.prototype.squaredDifference = function (x) { + this.throwIfDisposed(); + return opHandler.squaredDifference(this, x); + }; + Tensor.prototype.squaredDifferenceStrict = function (x) { + this.throwIfDisposed(); + return opHandler.squaredDifferenceStrict(this, x); + }; + Tensor.prototype.transpose = function (perm) { + this.throwIfDisposed(); + return opHandler.transpose(this, perm); + }; + Tensor.prototype.notEqual = function (x) { + this.throwIfDisposed(); + return opHandler.notEqual(this, x); + }; + Tensor.prototype.notEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.notEqualStrict(this, x); + }; + Tensor.prototype.less = function (x) { + this.throwIfDisposed(); + return opHandler.less(this, x); + }; + Tensor.prototype.lessStrict = function (x) { + this.throwIfDisposed(); + return opHandler.lessStrict(this, x); + }; + Tensor.prototype.equal = function (x) { + this.throwIfDisposed(); + return opHandler.equal(this, x); + }; + Tensor.prototype.equalStrict = function (x) { + this.throwIfDisposed(); + return opHandler.equalStrict(this, x); + }; + Tensor.prototype.lessEqual = function (x) { + this.throwIfDisposed(); + return opHandler.lessEqual(this, x); + }; + Tensor.prototype.lessEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.lessEqualStrict(this, x); + }; + Tensor.prototype.greater = function (x) { + this.throwIfDisposed(); + return opHandler.greater(this, x); + }; + Tensor.prototype.greaterStrict = function (x) { + this.throwIfDisposed(); + return opHandler.greaterStrict(this, x); + }; + Tensor.prototype.greaterEqual = function (x) { + this.throwIfDisposed(); + return opHandler.greaterEqual(this, x); + }; + Tensor.prototype.greaterEqualStrict = function (x) { + this.throwIfDisposed(); + return opHandler.greaterEqualStrict(this, x); + }; + Tensor.prototype.logicalAnd = function (x) { + this.throwIfDisposed(); + return opHandler.logicalAnd(this, x); + }; + Tensor.prototype.logicalOr = function (x) { + this.throwIfDisposed(); + return opHandler.logicalOr(this, x); + }; + Tensor.prototype.logicalNot = function () { + this.throwIfDisposed(); + return opHandler.logicalNot(this); + }; + Tensor.prototype.logicalXor = function (x) { + this.throwIfDisposed(); + return opHandler.logicalXor(this, x); + }; + Tensor.prototype.where = function (condition, x) { + this.throwIfDisposed(); + return opHandler.where(condition, this, x); + }; + Tensor.prototype.neg = function () { + this.throwIfDisposed(); + return opHandler.neg(this); + }; + Tensor.prototype.ceil = function () { + this.throwIfDisposed(); + return opHandler.ceil(this); + }; + Tensor.prototype.floor = function () { + this.throwIfDisposed(); + return opHandler.floor(this); + }; + Tensor.prototype.sign = function () { + this.throwIfDisposed(); + return opHandler.sign(this); + }; + Tensor.prototype.exp = function () { + this.throwIfDisposed(); + return opHandler.exp(this); + }; + Tensor.prototype.expm1 = function () { + this.throwIfDisposed(); + return opHandler.expm1(this); + }; + Tensor.prototype.log = function () { + this.throwIfDisposed(); + return opHandler.log(this); + }; + Tensor.prototype.log1p = function () { + this.throwIfDisposed(); + return opHandler.log1p(this); + }; + Tensor.prototype.sqrt = function () { + this.throwIfDisposed(); + return opHandler.sqrt(this); + }; + Tensor.prototype.rsqrt = function () { + this.throwIfDisposed(); + return opHandler.rsqrt(this); + }; + Tensor.prototype.square = function () { + this.throwIfDisposed(); + return opHandler.square(this); + }; + Tensor.prototype.reciprocal = function () { + this.throwIfDisposed(); + return opHandler.reciprocal(this); + }; + Tensor.prototype.abs = function () { + this.throwIfDisposed(); + return opHandler.abs(this); + }; + Tensor.prototype.clipByValue = function (min, max) { + this.throwIfDisposed(); + return opHandler.clipByValue(this, min, max); + }; + Tensor.prototype.relu = function () { + this.throwIfDisposed(); + return opHandler.relu(this); + }; + Tensor.prototype.elu = function () { + this.throwIfDisposed(); + return opHandler.elu(this); + }; + Tensor.prototype.selu = function () { + this.throwIfDisposed(); + return opHandler.selu(this); + }; + Tensor.prototype.leakyRelu = function (alpha) { + if (alpha === void 0) { alpha = 0.2; } + this.throwIfDisposed(); + return opHandler.leakyRelu(this, alpha); + }; + Tensor.prototype.prelu = function (alpha) { + this.throwIfDisposed(); + return opHandler.prelu(this, alpha); + }; + Tensor.prototype.sigmoid = function () { + this.throwIfDisposed(); + return opHandler.sigmoid(this); + }; + Tensor.prototype.logSigmoid = function () { + this.throwIfDisposed(); + return opHandler.logSigmoid(this); + }; + Tensor.prototype.softplus = function () { + this.throwIfDisposed(); + return opHandler.softplus(this); + }; + Tensor.prototype.sin = function () { + this.throwIfDisposed(); + return opHandler.sin(this); + }; + Tensor.prototype.cos = function () { + this.throwIfDisposed(); + return opHandler.cos(this); + }; + Tensor.prototype.tan = function () { + this.throwIfDisposed(); + return opHandler.tan(this); + }; + Tensor.prototype.asin = function () { + this.throwIfDisposed(); + return opHandler.asin(this); + }; + Tensor.prototype.acos = function () { + this.throwIfDisposed(); + return opHandler.acos(this); + }; + Tensor.prototype.atan = function () { + this.throwIfDisposed(); + return opHandler.atan(this); + }; + Tensor.prototype.sinh = function () { + this.throwIfDisposed(); + return opHandler.sinh(this); + }; + Tensor.prototype.cosh = function () { + this.throwIfDisposed(); + return opHandler.cosh(this); + }; + Tensor.prototype.tanh = function () { + this.throwIfDisposed(); + return opHandler.tanh(this); + }; + Tensor.prototype.asinh = function () { + this.throwIfDisposed(); + return opHandler.asinh(this); + }; + Tensor.prototype.acosh = function () { + this.throwIfDisposed(); + return opHandler.acosh(this); + }; + Tensor.prototype.atanh = function () { + this.throwIfDisposed(); + return opHandler.atanh(this); + }; + Tensor.prototype.erf = function () { + this.throwIfDisposed(); + return opHandler.erf(this); + }; + Tensor.prototype.round = function () { + this.throwIfDisposed(); + return opHandler.round(this); + }; + Tensor.prototype.step = function (alpha) { + if (alpha === void 0) { alpha = 0.0; } + this.throwIfDisposed(); + return opHandler.step(this, alpha); + }; + Tensor.prototype.softmax = function (dim) { + if (dim === void 0) { dim = -1; } + this.throwIfDisposed(); + return opHandler.softmax(this, dim); + }; + Tensor.prototype.resizeBilinear = function (newShape2D, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + this.throwIfDisposed(); + return opHandler.image.resizeBilinear(this, newShape2D, alignCorners); + }; + Tensor.prototype.resizeNearestNeighbor = function (newShape2D, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + this.throwIfDisposed(); + return opHandler.image.resizeNearestNeighbor(this, newShape2D, alignCorners); + }; + Tensor.prototype.conv1d = function (filter, stride, pad, dataFormat, dilation, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NWC'; } + if (dilation === void 0) { dilation = 1; } + this.throwIfDisposed(); + return opHandler.conv1d(this, filter, stride, pad, dataFormat, dilation, dimRoundingMode); + }; + Tensor.prototype.conv2d = function (filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + this.throwIfDisposed(); + return opHandler.conv2d(this, filter, strides, pad, dataFormat, dilations, dimRoundingMode); + }; + Tensor.prototype.conv2dTranspose = function (filter, outputShape, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.conv2dTranspose(this, filter, outputShape, strides, pad, dimRoundingMode); + }; + Tensor.prototype.depthwiseConv2D = function (filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + this.throwIfDisposed(); + return opHandler.depthwiseConv2d(this, filter, strides, pad, dataFormat, dilations, dimRoundingMode); + }; + Tensor.prototype.avgPool = function (filterSize, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.avgPool(this, filterSize, strides, pad, dimRoundingMode); + }; + Tensor.prototype.maxPool = function (filterSize, strides, pad, dimRoundingMode) { + this.throwIfDisposed(); + return opHandler.maxPool(this, filterSize, strides, pad, dimRoundingMode); + }; + Tensor.prototype.localResponseNormalization = function (radius, bias, alpha, beta) { + if (radius === void 0) { radius = 5; } + if (bias === void 0) { bias = 1; } + if (alpha === void 0) { alpha = 1; } + if (beta === void 0) { beta = 0.5; } + return opHandler.localResponseNormalization(this, radius, bias, alpha, beta); + }; + Tensor.prototype.variable = function (trainable, name, dtype) { + if (trainable === void 0) { trainable = true; } + this.throwIfDisposed(); + return Variable.variable(this, trainable, name, dtype); + }; + Tensor.prototype.unsortedSegmentSum = function (segmentIds, numSegments) { + this.throwIfDisposed(); + return opHandler.unsortedSegmentSum(this, segmentIds, numSegments); + }; + Tensor.prototype.batchToSpaceND = function (blockShape, crops) { + this.throwIfDisposed(); + return opHandler.batchToSpaceND(this, blockShape, crops); + }; + Tensor.prototype.spaceToBatchND = function (blockShape, paddings) { + this.throwIfDisposed(); + return opHandler.spaceToBatchND(this, blockShape, paddings); + }; + Tensor.nextId = 0; + return Tensor; + }()); + Object.defineProperty(Tensor, Symbol.hasInstance, { + value: function (instance) { + return !!instance && instance.shape != null && instance.dtype != null; + } + }); + var Variable = (function (_super) { + __extends(Variable, _super); + function Variable(initialValue, trainable, name) { + if (trainable === void 0) { trainable = true; } + var _this = _super.call(this, initialValue.shape, initialValue.dtype, null, initialValue.dataId) || this; + _this.trainable = trainable; + _this.name = name; + if (_this.name == null) { + _this.name = Variable.nextVarId.toString(); + Variable.nextVarId++; + } + try { + trackerFn().registerVariable(_this); + } + catch (ex) { + trackerFn().disposeTensor(_this); + throw ex; + } + return _this; + } + Variable.variable = function (initialValue, trainable, name, dtype) { + if (trainable === void 0) { trainable = true; } + if (dtype != null && dtype !== initialValue.dtype) { + initialValue = initialValue.asType(dtype); + } + return new Variable(initialValue, trainable, name); + }; + Variable.prototype.assign = function (newValue) { + if (newValue.dtype !== this.dtype) { + throw new Error("dtype of the new value (" + newValue.dtype + ") and " + + ("previous value (" + this.dtype + ") must match")); + } + if (!arraysEqual(newValue.shape, this.shape)) { + throw new Error("shape of the new value (" + newValue.shape + ") and " + + ("previous value (" + this.shape + ") must match")); + } + trackerFn().disposeTensor(this); + this.dataId = newValue.dataId; + trackerFn().registerTensor(this); + }; + Variable.nextVarId = 0; + return Variable; + }(Tensor)); + Object.defineProperty(Variable, Symbol.hasInstance, { + value: function (instance) { + return instance instanceof Tensor && instance.assign != null && + instance.assign instanceof Function; + } + }); + var variable = Variable.variable; + + function assertTypesMatch(a, b) { + assert(a.dtype === b.dtype, " The dtypes of the first(" + a.dtype + ") and" + + (" second(" + b.dtype + ") input must match")); + } + function isTensorInList(tensor, tensorList) { + for (var i = 0; i < tensorList.length; i++) { + if (tensorList[i].id === tensor.id) { + return true; + } + } + return false; + } + function getTensorsInContainer(result) { + var list = []; + var seen = new Set(); + walkTensorContainer(result, list, seen); + return list; + } + function walkTensorContainer(container, list, seen) { + if (container == null) { + return; + } + if (container instanceof Tensor) { + list.push(container); + return; + } + if (!isIterable(container)) { + return; + } + var iterable = container; + for (var k in iterable) { + var val = iterable[k]; + if (!seen.has(val)) { + seen.add(val); + walkTensorContainer(val, list, seen); + } + } + } + function isIterable(obj) { + return Array.isArray(obj) || typeof obj === 'object'; + } + + var Engine = (function () { + function Engine(backend, safeMode, debugMode) { + this.backend = backend; + this.safeMode = safeMode; + this.debugMode = debugMode; + this.registeredVariables = {}; + this.refCounter = new WeakMap(); + this.nextTapeNodeId = 0; + this.numBytes = 0; + this.numTensors = 0; + this.numDataBuffers = 0; + this.gradientScopeCount = 0; + this.customGradientDepth = 0; + this.keepTensors = new Set(); + this.activeScope = { track: [], name: 'default scope' }; + this.scopeStack = [this.activeScope]; + this.profiler = new Profiler(backend); + } + Engine.prototype.tidy = function (nameOrFn, fn, gradMode) { + var _this = this; + if (gradMode === void 0) { gradMode = false; } + var name = null; + if (fn == null) { + if (typeof nameOrFn !== 'function') { + throw new Error('Please provide a function to tidy()'); + } + fn = nameOrFn; + } + else { + if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) { + throw new Error('When calling with two arguments, the first argument ' + + 'to tidy() must be a string'); + } + if (typeof fn !== 'function') { + throw new Error('When calling with two arguments, the 2nd argument ' + + 'to tidy() must be a function'); + } + name = nameOrFn; + } + var result; + return this.scopedRun(function () { return _this.startScope(name, gradMode); }, function () { return _this.endScope(result, gradMode); }, function () { + result = fn(); + if (result instanceof Promise) { + console.error('Cannot return a Promise inside of tidy.'); + } + return result; + }); + }; + Engine.prototype.scopedRun = function (start, end, f) { + start(); + try { + var res = f(); + end(); + return res; + } + catch (ex) { + end(); + throw ex; + } + }; + Engine.prototype.runKernel = function (forwardFunc, inputs, backwardsFunc) { + var _this = this; + var result; + var saved = []; + var saveFunc = function (x) { + saved.push(x); + return x; + }; + var scopeName = this.activeScope.name; + this.scopedRun(function () { return _this.customGradientDepth++; }, function () { return _this.customGradientDepth--; }, function () { + if (!_this.debugMode()) { + result = forwardFunc(_this.backend, saveFunc); + } + else { + result = _this.profiler.profileKernel(scopeName, function () { return forwardFunc(_this.backend, saveFunc); }); + } + }); + if (this.shouldRecord()) { + var tapeNode = { + id: this.nextTapeNodeId++, + name: scopeName, + inputs: inputs, + output: Array.isArray(result) ? result[0] : result + }; + if (backwardsFunc != null) { + tapeNode.gradient = + (function (dy) { return backwardsFunc(dy, saved); }); + } + this.activeTape.push(tapeNode); + } + return result; + }; + Engine.prototype.registerTensor = function (a) { + var refCount = this.refCounter.has(a.dataId) ? this.refCounter.get(a.dataId) : 0; + this.numTensors++; + if (refCount === 0) { + this.numDataBuffers++; + this.numBytes += + sizeFromShape(a.shape) * bytesPerElement(a.dtype); + this.backend.register(a.dataId, a.shape, a.dtype); + } + this.refCounter.set(a.dataId, refCount + 1); + if (!(a instanceof Variable)) { + this.track(a); + } + }; + Engine.prototype.registerVariable = function (v) { + if (this.registeredVariables[v.name] != null) { + throw new Error("Variable with name " + v.name + " was already registered"); + } + this.registeredVariables[v.name] = v; + }; + Engine.prototype.disposeTensor = function (a) { + if (!this.refCounter.has(a.dataId)) { + return; + } + if (this.keepTensors.has(a.id)) { + this.keepTensors.delete(a.id); + } + this.numTensors--; + var refCount = this.refCounter.get(a.dataId); + if (refCount <= 1) { + this.refCounter.delete(a.dataId); + this.backend.disposeData(a.dataId); + this.numDataBuffers--; + this.numBytes -= + sizeFromShape(a.shape) * bytesPerElement(a.dtype); + } + else { + this.refCounter.set(a.dataId, refCount - 1); + } + }; + Engine.prototype.disposeVariables = function () { + for (var varName in this.registeredVariables) { + var v = this.registeredVariables[varName]; + this.disposeTensor(v); + delete this.registeredVariables[varName]; + } + }; + Engine.prototype.memory = function () { + var info = this.backend.memory(); + info.numTensors = this.numTensors; + info.numDataBuffers = this.numDataBuffers; + info.numBytes = this.numBytes; + return info; + }; + Engine.prototype.shouldRecord = function () { + return this.activeTape != null && this.customGradientDepth === 0; + }; + Engine.prototype.addTapeNode = function (inputs, result, gradientsFunc) { + var inputsMap = {}; + inputs.forEach(function (input, idx) { + inputsMap[idx] = input; + }); + var gradient = function (dy) { + var res = gradientsFunc(dy); + var resMap = {}; + res.forEach(function (r, idx) { + resMap[idx] = function () { return r; }; + }); + return resMap; + }; + var tapeNode = { + id: this.nextTapeNodeId++, + name: this.activeScope.name, + inputs: inputsMap, + output: result, + gradient: gradient + }; + this.activeTape.push(tapeNode); + }; + Engine.prototype.keep = function (result) { + if (this.scopeStack.length === 1 && this.safeMode) { + throw new Error('Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' + + 'tf.tidy(() => {...}) to avoid memory leaks.'); + } + this.keepTensors.add(result.id); + return result; + }; + Engine.prototype.startScope = function (name, gradientsMode) { + if (gradientsMode === void 0) { gradientsMode = false; } + if (gradientsMode && this.gradientScopeCount === 0) { + this.activeTape = []; + } + if (gradientsMode) { + this.gradientScopeCount++; + } + var scopeInfo = { track: [], name: 'unnamed scope' }; + if (name) { + scopeInfo.name = name; + } + this.scopeStack.push(scopeInfo); + this.activeScope = scopeInfo; + }; + Engine.prototype.endScope = function (result, gradientsMode) { + var _this = this; + if (gradientsMode === void 0) { gradientsMode = false; } + if (gradientsMode) { + this.gradientScopeCount--; + if (this.gradientScopeCount === 0) { + this.activeTape = null; + } + } + var tensorsToKeep = new Set(this.keepTensors); + var tensorsToTrackInParent = getTensorsInContainer(result); + tensorsToTrackInParent.forEach(function (tensor) { return tensorsToKeep.add(tensor.id); }); + for (var i = 0; i < this.activeScope.track.length; i++) { + var tensor = this.activeScope.track[i]; + if (tensorsToKeep.has(tensor.id)) { + continue; + } + if (this.activeTape != null) { + tensorsToTrackInParent.push(tensor); + } + else { + tensor.dispose(); + } + } + var oldScope = this.scopeStack.pop(); + this.activeScope = this.scopeStack.length === 0 ? + { track: [], name: 'default scope' } : + this.scopeStack[this.scopeStack.length - 1]; + tensorsToTrackInParent.forEach(function (tensor) { + if (!_this.keepTensors.has(tensor.id) && + isTensorInList(tensor, oldScope.track)) { + _this.track(tensor); + } + }); + }; + Engine.prototype.gradients = function (f, xs, dy, allowNoGradients) { + var _this = this; + if (allowNoGradients === void 0) { allowNoGradients = false; } + assert(xs.length > 0, 'gradients() received an empty list of xs.'); + return this.tidy('gradients', function () { + var y = f(); + assert(y instanceof Tensor, 'The result y returned by f() must be a tensor.'); + var filteredTape = getFilteredNodesXToY(_this.activeTape, xs, y); + if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) { + throw new Error('Cannot compute gradient of y=f(x) with respect to x. Make sure ' + + 'that the f you passed encloses all operations that lead from x ' + + 'to y.'); + } + var accumulatedGradientMap = {}; + accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy; + backpropagateGradients(accumulatedGradientMap, filteredTape); + var grads = xs.map(function (x) { return accumulatedGradientMap[x.id]; }); + return { value: y, grads: grads }; + }, true); + }; + Engine.prototype.customGrad = function (f) { + var _this = this; + assert(isFunction(f), 'The f passed in customGrad(f) must be a function.'); + return function () { + var inputs = []; + for (var _i = 0; _i < arguments.length; _i++) { + inputs[_i] = arguments[_i]; + } + assert(inputs.every(function (t) { return t instanceof Tensor; }), 'The args passed in customGrad(f)(x1, x2,...) must all be tensors'); + var gradientsFunc; + var result; + _this.scopedRun(function () { return _this.customGradientDepth++; }, function () { return _this.customGradientDepth--; }, function () { + var gradientsMode = true; + result = _this.tidy(f.name, function () { + var _a = f.apply(void 0, inputs), value = _a.value, gradFunc = _a.gradFunc; + assert(value instanceof Tensor, 'The function f passed in customGrad(f) must return an ' + + 'object where `obj.value` is a tensor'); + assert(isFunction(gradFunc), 'The function f passed in customGrad(f) must return an ' + + 'object where `obj.gradFunc` is a function.'); + gradientsFunc = gradFunc; + return value; + }, gradientsMode); + }); + if (_this.shouldRecord()) { + var gradFunc = function (dy) { + var res = gradientsFunc(dy); + var grads = Array.isArray(res) ? res : [res]; + assert(grads.length === inputs.length, 'The function f passed in customGrad(f) must return an object ' + + 'where `obj.gradFunc` is a function that returns the same ' + + 'number of tensors as inputs passed to f(...).'); + assert(grads.every(function (t) { return t instanceof Tensor; }), 'The function f passed in customGrad(f) must return an object ' + + 'where `obj.gradFunc` is a function that returns a list of ' + + 'only tensors.'); + return grads; + }; + _this.addTapeNode(inputs, result, gradFunc); + } + return result; + }; + }; + Engine.prototype.write = function (dataId, values) { + this.backend.write(dataId, values); + }; + Engine.prototype.readSync = function (dataId) { + return this.backend.readSync(dataId); + }; + Engine.prototype.read = function (dataId) { + return this.backend.read(dataId); + }; + Engine.prototype.fromPixels = function (pixels, numChannels) { + return this.backend.fromPixels(pixels, numChannels); + }; + Engine.prototype.time = function (query) { + return __awaiter(this, void 0, void 0, function () { + var start, timingInfo; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + start = now(); + return [4, this.backend.time(query)]; + case 1: + timingInfo = _a.sent(); + timingInfo.wallMs = now() - start; + return [2, timingInfo]; + } + }); + }); + }; + Engine.prototype.track = function (result) { + if (this.scopeStack.length === 1 && this.safeMode) { + throw new Error('Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' + + 'tf.tidy(() => {op();...}); to avoid memory leaks.'); + } + this.activeScope.track.push(result); + return result; + }; + return Engine; + }()); + function ones(shape) { + var values = makeOnesTypedArray(sizeFromShape(shape), 'float32'); + return Tensor.make(shape, { values: values }); + } + + var Type; + (function (Type) { + Type[Type["NUMBER"] = 0] = "NUMBER"; + Type[Type["BOOLEAN"] = 1] = "BOOLEAN"; + Type[Type["STRING"] = 2] = "STRING"; + })(Type || (Type = {})); + var URL_PROPERTIES = [ + { name: 'DEBUG', type: Type.BOOLEAN }, { name: 'IS_BROWSER', type: Type.BOOLEAN }, + { name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION', type: Type.NUMBER }, + { name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', type: Type.BOOLEAN }, + { name: 'WEBGL_VERSION', type: Type.NUMBER }, + { name: 'WEBGL_RENDER_FLOAT32_ENABLED', type: Type.BOOLEAN }, + { name: 'WEBGL_DOWNLOAD_FLOAT_ENABLED', type: Type.BOOLEAN }, + { name: 'WEBGL_FENCE_API_ENABLED', type: Type.BOOLEAN }, + { name: 'BACKEND', type: Type.STRING } + ]; + function isWebGLVersionEnabled(webGLVersion, isBrowser) { + var gl; + try { + gl = getWebGLRenderingContext(webGLVersion, isBrowser); + } + catch (e) { + return false; + } + if (gl != null) { + loseContext(gl); + return true; + } + return false; + } + function getWebGLDisjointQueryTimerVersion(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return 0; + } + var queryTimerVersion; + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (hasExtension(gl, 'EXT_disjoint_timer_query_webgl2') && + webGLVersion === 2) { + queryTimerVersion = 2; + } + else if (hasExtension(gl, 'EXT_disjoint_timer_query')) { + queryTimerVersion = 1; + } + else { + queryTimerVersion = 0; + } + if (gl != null) { + loseContext(gl); + } + return queryTimerVersion; + } + function isRenderToFloatTextureEnabled(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (webGLVersion === 1) { + if (!hasExtension(gl, 'OES_texture_float')) { + return false; + } + } + else { + if (!hasExtension(gl, 'EXT_color_buffer_float')) { + return false; + } + } + createFloatTextureAndBindToFramebuffer(gl, webGLVersion); + var isFrameBufferComplete = gl.checkFramebufferStatus(gl.FRAMEBUFFER) === gl.FRAMEBUFFER_COMPLETE; + loseContext(gl); + return isFrameBufferComplete; + } + function isDownloadFloatTextureEnabled(webGLVersion, isBrowser) { + if (webGLVersion === 0) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + if (webGLVersion === 1) { + if (!hasExtension(gl, 'OES_texture_float')) { + return false; + } + } + else { + if (!hasExtension(gl, 'EXT_color_buffer_float')) { + return false; + } + } + createFloatTextureAndBindToFramebuffer(gl, webGLVersion); + gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.FLOAT, new Float32Array(4)); + var readPixelsNoError = gl.getError() === gl.NO_ERROR; + loseContext(gl); + return readPixelsNoError; + } + function isWebGLFenceEnabled(webGLVersion, isBrowser) { + if (webGLVersion !== 2) { + return false; + } + var gl = getWebGLRenderingContext(webGLVersion, isBrowser); + var isEnabled = gl.fenceSync != null; + loseContext(gl); + return isEnabled; + } + function isChrome() { + return typeof navigator !== 'undefined' && navigator != null && + navigator.userAgent != null && /Chrome/.test(navigator.userAgent) && + /Google Inc/.test(navigator.vendor); + } + var TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags'; + function getFeaturesFromURL() { + var features = {}; + if (typeof window === 'undefined' || typeof window.location === 'undefined') { + return features; + } + var urlParams = getQueryParams(window.location.search); + if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) { + var urlFlags_1 = {}; + var keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(','); + keyValues.forEach(function (keyValue) { + var _a = keyValue.split(':'), key = _a[0], value = _a[1]; + urlFlags_1[key] = value; + }); + URL_PROPERTIES.forEach(function (urlProperty) { + if (urlProperty.name in urlFlags_1) { + console.log("Setting feature override from URL " + urlProperty.name + ": " + + ("" + urlFlags_1[urlProperty.name])); + if (urlProperty.type === Type.NUMBER) { + features[urlProperty.name] = +urlFlags_1[urlProperty.name]; + } + else if (urlProperty.type === Type.BOOLEAN) { + features[urlProperty.name] = urlFlags_1[urlProperty.name] === 'true'; + } + else if (urlProperty.type === Type.STRING) { + features[urlProperty.name] = urlFlags_1[urlProperty.name]; + } + else { + console.warn("Unknown URL param: " + urlProperty.name + "."); + } + } + }); + } + return features; + } + function hasExtension(gl, extensionName) { + var ext = gl.getExtension(extensionName); + return ext != null; + } + function getWebGLRenderingContext(webGLVersion, isBrowser) { + if (webGLVersion === 0 || !isBrowser) { + throw new Error('Cannot get WebGL rendering context, WebGL is disabled.'); + } + var tempCanvas = document.createElement('canvas'); + if (webGLVersion === 1) { + return (tempCanvas.getContext('webgl') || + tempCanvas.getContext('experimental-webgl')); + } + return tempCanvas.getContext('webgl2'); + } + function loseContext(gl) { + if (gl != null) { + var loseContextExtension = gl.getExtension('WEBGL_lose_context'); + if (loseContextExtension == null) { + throw new Error('Extension WEBGL_lose_context not supported on this browser.'); + } + loseContextExtension.loseContext(); + } + } + function createFloatTextureAndBindToFramebuffer(gl, webGLVersion) { + var frameBuffer = gl.createFramebuffer(); + var texture = gl.createTexture(); + gl.bindTexture(gl.TEXTURE_2D, texture); + var internalFormat = webGLVersion === 2 ? gl.RGBA32F : gl.RGBA; + gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, 1, 1, 0, gl.RGBA, gl.FLOAT, null); + gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer); + gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0); + } + function getQueryParams(queryString) { + var params = {}; + queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, function (s) { + var t = []; + for (var _i = 1; _i < arguments.length; _i++) { + t[_i - 1] = arguments[_i]; + } + decodeParam(params, t[0], t[1]); + return t.join('='); + }); + return params; + } + function decodeParam(params, name, value) { + params[decodeURIComponent(name)] = decodeURIComponent(value || ''); + } + + var TEST_EPSILON_FLOAT32_ENABLED = 1e-3; + var TEST_EPSILON_FLOAT32_DISABLED = 1e-1; + var Environment = (function () { + function Environment(features) { + this.features = {}; + this.registry = {}; + if (features != null) { + this.features = features; + } + if (this.get('DEBUG')) { + console.warn('Debugging mode is ON. The output of every math call will ' + + 'be downloaded to CPU and checked for NaNs. ' + + 'This significantly impacts performance.'); + } + } + Environment.setBackend = function (backendName, safeMode) { + if (safeMode === void 0) { safeMode = false; } + if (!(backendName in ENV.registry)) { + throw new Error("Backend name '" + backendName + "' not found in registry"); + } + ENV.initBackend(backendName, safeMode); + }; + Environment.getBackend = function () { + ENV.initDefaultBackend(); + return ENV.backendName; + }; + Environment.disposeVariables = function () { + ENV.engine.disposeVariables(); + }; + Environment.memory = function () { + return ENV.engine.memory(); + }; + Environment.tidy = function (nameOrFn, fn, gradMode) { + if (gradMode === void 0) { gradMode = false; } + return ENV.engine.tidy(nameOrFn, fn, gradMode); + }; + Environment.dispose = function (container) { + var tensors = getTensorsInContainer(container); + tensors.forEach(function (tensor) { return tensor.dispose(); }); + }; + Environment.keep = function (result) { + return ENV.engine.keep(result); + }; + Environment.time = function (f) { + return ENV.engine.time(f); + }; + Environment.prototype.get = function (feature) { + if (feature in this.features) { + return this.features[feature]; + } + this.features[feature] = this.evaluateFeature(feature); + return this.features[feature]; + }; + Environment.prototype.getFeatures = function () { + return this.features; + }; + Environment.prototype.set = function (feature, value) { + this.features[feature] = value; + }; + Environment.prototype.getBestBackendName = function () { + var _this = this; + if (Object.keys(this.registry).length === 0) { + throw new Error('No backend found in registry.'); + } + var sortedBackends = Object.keys(this.registry) + .map(function (name) { + return { name: name, entry: _this.registry[name] }; + }) + .sort(function (a, b) { + return b.entry.priority - a.entry.priority; + }); + return sortedBackends[0].name; + }; + Environment.prototype.evaluateFeature = function (feature) { + if (feature === 'DEBUG') { + return false; + } + else if (feature === 'IS_BROWSER') { + return typeof window !== 'undefined'; + } + else if (feature === 'IS_NODE') { + return (typeof process !== 'undefined') && + (typeof process.versions.node !== 'undefined'); + } + else if (feature === 'IS_CHROME') { + return isChrome(); + } + else if (feature === 'IS_TEST') { + return false; + } + else if (feature === 'BACKEND') { + return this.getBestBackendName(); + } + else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') { + var webGLVersion = this.get('WEBGL_VERSION'); + if (webGLVersion === 0) { + return 0; + } + if (webGLVersion > 0) { + return 0; + } + return getWebGLDisjointQueryTimerVersion(webGLVersion, this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE') { + return this.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0 && + !isMobile(); + } + else if (feature === 'HAS_WEBGL') { + return this.get('WEBGL_VERSION') > 0; + } + else if (feature === 'WEBGL_VERSION') { + if (isWebGLVersionEnabled(2, this.get('IS_BROWSER'))) { + return 2; + } + else if (isWebGLVersionEnabled(1, this.get('IS_BROWSER'))) { + return 1; + } + return 0; + } + else if (feature === 'WEBGL_RENDER_FLOAT32_ENABLED') { + return isRenderToFloatTextureEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_DOWNLOAD_FLOAT_ENABLED') { + return isDownloadFloatTextureEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'WEBGL_FENCE_API_ENABLED') { + return isWebGLFenceEnabled(this.get('WEBGL_VERSION'), this.get('IS_BROWSER')); + } + else if (feature === 'TEST_EPSILON') { + if (this.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + return TEST_EPSILON_FLOAT32_ENABLED; + } + return TEST_EPSILON_FLOAT32_DISABLED; + } + throw new Error("Unknown feature " + feature + "."); + }; + Environment.prototype.setFeatures = function (features) { + this.features = Object.assign({}, features); + }; + Environment.prototype.reset = function () { + this.features = getFeaturesFromURL(); + if (this.globalEngine != null) { + this.globalEngine = null; + } + }; + Environment.prototype.initBackend = function (backendName, safeMode) { + var _this = this; + if (safeMode === void 0) { safeMode = false; } + this.backendName = backendName; + this.backend = this.findBackend(backendName); + this.globalEngine = + new Engine(this.backend, safeMode, function () { return _this.get('DEBUG'); }); + }; + Environment.prototype.findBackend = function (name) { + if (!(name in this.registry)) { + return null; + } + return this.registry[name].backend; + }; + Environment.prototype.registerBackend = function (name, factory, priority, setTensorTrackerFn) { + var _this = this; + if (priority === void 0) { priority = 1; } + if (name in this.registry) { + console.warn(name + " backend was already registered. Reusing existing backend"); + if (setTensorTrackerFn != null) { + setTensorTrackerFn(function () { return _this.engine; }); + } + return false; + } + try { + var backend = factory(); + this.registry[name] = { backend: backend, priority: priority }; + return true; + } + catch (err) { + console.warn("Registration of backend " + name + " failed"); + console.warn(err.stack || err.message); + return false; + } + }; + Environment.prototype.removeBackend = function (name) { + if (!(name in this.registry)) { + throw new Error(name + " backend not found in registry"); + } + this.registry[name].backend.dispose(); + delete this.registry[name]; + }; + Object.defineProperty(Environment.prototype, "engine", { + get: function () { + this.initDefaultBackend(); + return this.globalEngine; + }, + enumerable: true, + configurable: true + }); + Environment.prototype.initDefaultBackend = function () { + if (this.globalEngine == null) { + this.initBackend(this.get('BACKEND'), false); + } + }; + return Environment; + }()); + function getGlobalNamespace() { + var ns; + if (typeof (window) !== 'undefined') { + ns = window; + } + else if (typeof (process) !== 'undefined') { + ns = process; + } + else { + throw new Error('Could not find a global object'); + } + return ns; + } + function getOrMakeEnvironment() { + var ns = getGlobalNamespace(); + if (ns.ENV == null) { + ns.ENV = new Environment(getFeaturesFromURL()); + setTensorTracker(function () { return ns.ENV.engine; }); + } + return ns.ENV; + } + var ENV = getOrMakeEnvironment(); + + var environment = /*#__PURE__*/Object.freeze({ + Environment: Environment, + ENV: ENV + }); + + function warn() { + var msg = []; + for (var _i = 0; _i < arguments.length; _i++) { + msg[_i] = arguments[_i]; + } + if (!ENV.get('IS_TEST')) { + console.warn.apply(console, msg); + } + } + + function getReshaped(inputShape, blockShape, prod, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var reshaped = []; + if (batchToSpace) { + reshaped = reshaped.concat(blockShape.slice(0)); + reshaped.push(inputShape[0] / prod); + reshaped = reshaped.concat(inputShape.slice(1)); + } + else { + reshaped = reshaped.concat(inputShape[0]); + var spatialLength = blockShape.length; + for (var i = 0; i < spatialLength; ++i) { + reshaped = + reshaped.concat([inputShape[i + 1] / blockShape[i], blockShape[i]]); + } + reshaped = reshaped.concat(inputShape.slice(spatialLength + 1)); + } + return reshaped; + } + function getPermuted(reshapedRank, blockShapeRank, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var permuted = []; + if (batchToSpace) { + permuted.push(blockShapeRank); + for (var i = blockShapeRank + 1; i < reshapedRank; ++i) { + if (i <= 2 * blockShapeRank) { + permuted.push(i); + permuted.push(i - (blockShapeRank + 1)); + } + else { + permuted.push(i); + } + } + } + else { + var permutedBeforeBatch = []; + var permutedAfterBatch = []; + for (var i = 1; i < reshapedRank; ++i) { + if (i >= blockShapeRank * 2 + 1 || i % 2 === 1) { + permutedAfterBatch.push(i); + } + else { + permutedBeforeBatch.push(i); + } + } + permuted.push.apply(permuted, permutedBeforeBatch); + permuted.push(0); + permuted.push.apply(permuted, permutedAfterBatch); + } + return permuted; + } + function getReshapedPermuted(inputShape, blockShape, prod, batchToSpace) { + if (batchToSpace === void 0) { batchToSpace = true; } + var reshapedPermuted = []; + if (batchToSpace) { + reshapedPermuted.push(inputShape[0] / prod); + } + else { + reshapedPermuted.push(inputShape[0] * prod); + } + for (var i = 1; i < inputShape.length; ++i) { + if (i <= blockShape.length) { + if (batchToSpace) { + reshapedPermuted.push(blockShape[i - 1] * inputShape[i]); + } + else { + reshapedPermuted.push(inputShape[i] / blockShape[i - 1]); + } + } + else { + reshapedPermuted.push(inputShape[i]); + } + } + return reshapedPermuted; + } + function getSliceBeginCoords(crops, blockShape) { + var sliceBeginCoords = [0]; + for (var i = 0; i < blockShape; ++i) { + sliceBeginCoords.push(crops[i][0]); + } + return sliceBeginCoords; + } + function getSliceSize(uncroppedShape, crops, blockShape) { + var sliceSize = uncroppedShape.slice(0, 1); + for (var i = 0; i < blockShape; ++i) { + sliceSize.push(uncroppedShape[i + 1] - crops[i][0] - crops[i][1]); + } + return sliceSize; + } + + function axesAreInnerMostDims(axes, rank) { + for (var i = 0; i < axes.length; ++i) { + if (axes[axes.length - i - 1] !== rank - 1 - i) { + return false; + } + } + return true; + } + function combineLocations(outputLoc, reduceLoc, axes) { + var rank = outputLoc.length + reduceLoc.length; + var loc = []; + var outIdx = 0; + var reduceIdx = 0; + for (var dim = 0; dim < rank; dim++) { + if (axes.indexOf(dim) === -1) { + loc.push(outputLoc[outIdx++]); + } + else { + loc.push(reduceLoc[reduceIdx++]); + } + } + return loc; + } + function computeOutAndReduceShapes(aShape, axes) { + var outShape = []; + var rank = aShape.length; + for (var dim = 0; dim < rank; dim++) { + if (axes.indexOf(dim) === -1) { + outShape.push(aShape[dim]); + } + } + var reduceShape = axes.map(function (dim) { return aShape[dim]; }); + return [outShape, reduceShape]; + } + function expandShapeToKeepDim(shape, axes) { + var reduceSubShape = axes.map(function (x) { return 1; }); + return combineLocations(shape, reduceSubShape, axes); + } + function parseAxisParam(axis, shape) { + var rank = shape.length; + axis = axis == null ? shape.map(function (s, i) { return i; }) : [].concat(axis); + assert(axis.every(function (ax) { return ax >= -rank && ax < rank; }), "All values in axis param must be in range [-" + rank + ", " + rank + ") but " + + ("got axis " + axis)); + assert(axis.every(function (ax) { return isInt(ax); }), "All values in axis param must be integers but " + + ("got axis " + axis)); + return axis.map(function (a) { return a < 0 ? rank + a : a; }); + } + function assertAxesAreInnerMostDims(msg, axes, rank) { + assert(axesAreInnerMostDims(axes, rank), msg + " supports only inner-most axes for now. " + + ("Got axes " + axes + " and rank-" + rank + " input.")); + } + function getAxesPermutation(axes, rank) { + if (axesAreInnerMostDims(axes, rank)) { + return null; + } + var result = []; + for (var i = 0; i < rank; ++i) { + if (axes.indexOf(i) === -1) { + result.push(i); + } + } + axes.forEach(function (axis) { return result.push(axis); }); + return result; + } + function getUndoAxesPermutation(axes) { + return axes.map(function (axis, i) { return [i, axis]; }) + .sort(function (a, b) { return a[1] - b[1]; }) + .map(function (x) { return x[0]; }); + } + function getInnerMostAxes(numAxes, rank) { + var res = []; + for (var i = rank - numAxes; i < rank; ++i) { + res.push(i); + } + return res; + } + + var PARALLELIZE_THRESHOLD = 30; + function computeOptimalWindowSize(inSize) { + if (inSize <= PARALLELIZE_THRESHOLD) { + return inSize; + } + return nearestDivisor(inSize, Math.floor(Math.sqrt(inSize))); + } + + function segOpComputeOptimalWindowSize(inSize, numSegments) { + var done = false; + var res; + if (inSize <= PARALLELIZE_THRESHOLD) { + res = inSize; + done = true; + } + else { + res = nearestDivisor(inSize, Math.floor(Math.sqrt(inSize))); + } + while (!done) { + if (res > numSegments || res === inSize) { + done = true; + break; + } + else { + res = nearestDivisor(inSize, res + 1); + } + } + return res; + } + function computeOutShape(aShape, axis, numSegments) { + var outShape = []; + var rank = aShape.length; + for (var dim = 0; dim < rank; dim++) { + if (dim !== axis) { + outShape.push(aShape[dim]); + } + else { + outShape.push(numSegments); + } + } + return outShape; + } + + function assertParamsValid(input, begin, size) { + assert(input.rank === begin.length, "Error in slice" + input.rank + "D: Length of begin " + begin + " must " + + ("match the rank of the array (" + input.rank + ").")); + assert(input.rank === size.length, "Error in slice" + input.rank + "D: Length of size " + size + " must " + + ("match the rank of the array (" + input.rank + ").")); + for (var i = 0; i < input.rank; ++i) { + assert(begin[i] + size[i] <= input.shape[i], "Error in slice" + input.rank + "D: begin[" + i + "] + size[" + i + "] " + + ("(" + (begin[i] + size[i]) + ") would overflow input.shape[" + i + "] (" + input.shape[i] + ")")); + } + } + function getStridedSlicedInfo(shape, begin, end, strides, beginMask, endMask) { + if (beginMask === void 0) { beginMask = 0; } + if (endMask === void 0) { endMask = 0; } + var startIndex = []; + var endIndex = []; + for (var i = 0; i < shape.length; i++) { + startIndex[i] = startForAxis(beginMask, begin, strides, shape, i); + endIndex[i] = stopForAxis(endMask, end, strides, shape, i); + } + var size = new Array(shape.length).fill(0); + size = size.map(function (d, i) { + var count = 0; + for (var start = startIndex[i]; !(strides[i] > 0 ? start >= endIndex[i] : start <= endIndex[i]); start += strides[i]) { + count += 1; + } + return count; + }); + return [startIndex, size]; + } + function startForAxis(beginMask, startIndices, strides, inputShape, axis) { + var start = startIndices[axis]; + if (beginMask & 1 << axis) { + if (strides[axis] > 0) { + start = Number.MIN_SAFE_INTEGER; + } + else { + start = Number.MAX_SAFE_INTEGER; + } + } + var axisSize = inputShape[axis]; + if (start < 0) { + start += axisSize; + } + start = clamp(0, start, axisSize - 1); + return start; + } + function stopForAxis(endMask, stopIndices, strides, inputShape, axis) { + var stop = stopIndices[axis]; + if (endMask & (1 << axis)) { + if (strides[axis] > 0) { + stop = Number.MAX_SAFE_INTEGER; + } + else { + stop = Number.MIN_SAFE_INTEGER; + } + } + var axisSize = inputShape[axis]; + if (stop < 0) { + stop += axisSize; + } + if (strides[axis] > 0) { + stop = clamp(0, stop, axisSize); + } + else { + stop = clamp(-1, stop, axisSize - 1); + } + return stop; + } + + function grad(f) { + assert(isFunction(f), 'The f passed in grad(f) must be a function'); + return function (x, dy) { + assert(x instanceof Tensor, 'The x passed in grad(f)(x) must be a tensor'); + assert(dy == null || dy instanceof Tensor, 'The dy passed in grad(f)(x, dy) must be a tensor'); + return ENV.engine.tidy(function () { + var _a = ENV.engine.gradients(function () { return f(x); }, [x], dy), value = _a.value, grads = _a.grads; + if (dy != null) { + assertShapesMatch(value.shape, dy.shape, 'The shape of dy passed in grad(f)(x, dy) must match the shape ' + + 'returned by f(x)'); + } + checkGrads(grads); + return grads[0]; + }); + }; + } + function grads(f) { + assert(isFunction(f), 'The f passed in grads(f) must be a function'); + return function (args, dy) { + assert(Array.isArray(args) && args.every(function (arg) { return arg instanceof Tensor; }), 'The args passed in grads(f)(args) must be an array of tensors'); + assert(dy == null || dy instanceof Tensor, 'The dy passed in grads(f)(args, dy) must be a tensor'); + return ENV.engine.tidy(function () { + var _a = ENV.engine.gradients(function () { return f.apply(void 0, args); }, args, dy), value = _a.value, grads = _a.grads; + if (dy != null) { + assertShapesMatch(value.shape, dy.shape, 'The shape of dy passed in grads(f)([x1,...], dy) must ' + + 'match the shape returned by f([x1,...])'); + } + checkGrads(grads); + return grads; + }); + }; + } + function valueAndGrad(f) { + assert(isFunction(f), 'The f passed in valueAndGrad(f) must be a function'); + return function (x, dy) { + assert(x instanceof Tensor, 'The x passed in valueAndGrad(f)(x) must be a tensor'); + assert(dy == null || dy instanceof Tensor, 'The dy passed in valueAndGrad(f)(x, dy) must be a tensor'); + var _a = ENV.engine.gradients(function () { return f(x); }, [x], dy), grads = _a.grads, value = _a.value; + checkGrads(grads); + return { grad: grads[0], value: value }; + }; + } + function valueAndGrads(f) { + assert(isFunction(f), 'The f passed in valueAndGrads(f) must be a function'); + return function (args, dy) { + assert(Array.isArray(args) && args.every(function (arg) { return arg instanceof Tensor; }), 'The args passed in valueAndGrads(f)(args) must be array of tensors'); + assert(dy == null || dy instanceof Tensor, 'The dy passed in valueAndGrads(f)(args, dy) must be a tensor'); + var res = ENV.engine.gradients(function () { return f.apply(void 0, args); }, args, dy); + if (dy != null) { + assertShapesMatch(res.value.shape, dy.shape, 'The shape of dy passed in valueAndGrads(f)([x1,...], dy) must ' + + 'match the shape returned by f([x1,...])'); + } + checkGrads(res.grads); + return res; + }; + } + function variableGrads(f, varList) { + assert(isFunction(f), 'The f passed in variableGrads(f) must be a function'); + assert(varList == null || + Array.isArray(varList) && varList.every(function (v) { return v instanceof Variable; }), 'The varList passed in variableGrads(f, varList) must be an array ' + + 'of variables'); + if (varList == null) { + varList = []; + for (var varName in ENV.engine.registeredVariables) { + varList.push(ENV.engine.registeredVariables[varName]); + } + } + var originalVarCount = varList.length; + varList = varList.filter(function (variable$$1) { return variable$$1.trainable; }); + assert(varList.length > 0, "variableGrads() expects at least one of the input variables to be " + + ("trainable, but none of the " + originalVarCount + " variables is ") + + "trainable."); + var allowNoGradients = true; + var _a = ENV.engine.gradients(f, varList, null, allowNoGradients), value = _a.value, grads = _a.grads; + assert(grads.some(function (g) { return g != null; }), 'Cannot find a connection between any variable and the result of the ' + + 'loss function y=f(x). Please make sure the operations that use ' + + 'variables are inside the function f passed to minimize().'); + assert(value.rank === 0, "The f passed in variableGrads(f) must return a scalar, but it " + + ("returned a rank-" + value.rank + " tensor")); + var namedGrads = {}; + varList.forEach(function (v, i) { + if (grads[i] != null) { + namedGrads[v.name] = grads[i]; + } + }); + return { value: value, grads: namedGrads }; + } + function customGrad(f) { + return ENV.engine.customGrad(f); + } + function checkGrads(grads) { + var numNullGradients = grads.filter(function (g) { return g == null; }).length; + if (numNullGradients > 0) { + throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y."); + } + } + + function convertToTensor(x, argName, functionName, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + dtype = dtype || 'float32'; + if (x instanceof Tensor) { + return x; + } + if (!isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' && + typeof x !== 'boolean') { + throw new Error("Argument '" + argName + "' passed to '" + functionName + "' must be a " + + ("Tensor or TensorLike, but got " + x.constructor.name)); + } + var inferredShape = inferShape(x); + if (!isTypedArray(x) && !Array.isArray(x)) { + x = [x]; + } + return Tensor.make(inferredShape, { values: toTypedArray(x, dtype, ENV.get('DEBUG')) }, dtype); + } + function convertToTensorArray(arg, argName, functionName) { + if (!Array.isArray(arg)) { + throw new Error("Argument " + argName + " passed to " + functionName + " must be a " + + '`Tensor[]` or `TensorLike[]`'); + } + var tensors = arg; + return tensors.map(function (t, i) { return convertToTensor(t, argName + "[" + i + "]", functionName); }); + } + + function op(f) { + var keys = Object.keys(f); + if (keys.length !== 1) { + throw new Error("Please provide an object with a single key " + + "(operation name) mapping to a function. Got an object with " + + (keys.length + " keys.")); + } + var opName = keys[0]; + var fn = f[opName]; + if (opName.endsWith('_')) { + opName = opName.substring(0, opName.length - 1); + } + var f2 = function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + ENV.engine.startScope(opName); + try { + var result = fn.apply(void 0, args); + if (result instanceof Promise) { + console.error('Cannot return a Promise inside of tidy.'); + } + ENV.engine.endScope(result); + return result; + } + catch (ex) { + ENV.engine.endScope(null); + throw ex; + } + }; + Object.defineProperty(f2, 'name', { value: opName, configurable: true }); + return f2; + } + + function softmax_(logits, dim) { + if (dim === void 0) { dim = -1; } + var $logits = convertToTensor(logits, 'logits', 'softmax'); + if (dim === -1) { + dim = $logits.rank - 1; + } + if (dim !== $logits.rank - 1) { + throw Error('Softmax along a non-last dimension is not yet supported. ' + + ("Logits was rank " + $logits.rank + " and dim was " + dim)); + } + var customOp = customGrad(function (logits) { + var keepDims = true; + var lse = logits.logSumExp([dim], keepDims); + var logResult = logits.toFloat().sub(lse); + var y = logResult.exp(); + var gradFunc = function (dy) { + var dyTimesY = dy.mul(y); + var keepDims = true; + return dyTimesY.sub(dyTimesY.sum([dim], keepDims).mul(y)); + }; + return { value: y, gradFunc: gradFunc }; + }); + return customOp($logits); + } + var softmax = op({ softmax_: softmax_ }); + + function tensor(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (!isTypedArray(values) && !Array.isArray(values) && + typeof values !== 'number' && typeof values !== 'boolean') { + throw new Error('values passed to tensor(values) must be an ' + + 'array of numbers or booleans, or a TypedArray'); + } + var inferredShape = inferShape(values); + if (shape != null && inferredShape.length !== 1) { + assertShapesMatch(shape, inferredShape, "Error creating a new Tensor. " + + ("Inferred shape (" + inferredShape + ") does not match the ") + + ("provided shape (" + shape + "). ")); + } + if (!isTypedArray(values) && !Array.isArray(values)) { + values = [values]; + } + shape = shape || inferredShape; + return Tensor.make(shape, { + values: toTypedArray(values, dtype, ENV.get('DEBUG')) + }, dtype); + } + function scalar(value, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (isTypedArray(value) || Array.isArray(value)) { + throw new Error('Error creating a new Scalar: value must be a primitive ' + + '(number|boolean)'); + } + return tensor(value, [], dtype); + } + function tensor1d(values, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + var inferredShape = inferShape(values); + if (inferredShape.length !== 1) { + throw new Error('tensor1d() requires values to be a flat/TypedArray'); + } + return tensor(values, inferredShape, dtype); + } + function tensor2d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + if (shape != null && shape.length !== 2) { + throw new Error('tensor2d() requires shape to have two numbers'); + } + var inferredShape = inferShape(values); + if (inferredShape.length !== 2 && inferredShape.length !== 1) { + throw new Error('tensor2d() requires values to be number[][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor2d() requires shape to be provided when `values` ' + + 'are a flat/TypedArray'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); + } + function tensor3d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + if (shape != null && shape.length !== 3) { + throw new Error('tensor3d() requires shape to have three numbers'); + } + var inferredShape = inferShape(values); + if (inferredShape.length !== 3 && inferredShape.length !== 1) { + throw new Error('tensor3d() requires values to be number[][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor3d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); + } + function tensor4d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + if (shape != null && shape.length !== 4) { + throw new Error('tensor4d() requires shape to have four numbers'); + } + var inferredShape = inferShape(values); + if (inferredShape.length !== 4 && inferredShape.length !== 1) { + throw new Error('tensor4d() requires values to be number[][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor4d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); + } + function tensor5d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + if (shape != null && shape.length !== 5) { + throw new Error('tensor5d() requires shape to have five numbers'); + } + var inferredShape = inferShape(values); + if (inferredShape.length !== 5 && inferredShape.length !== 1) { + throw new Error('tensor5d() requires values to be ' + + 'number[][][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor5d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || inferredShape; + return tensor(values, shape, dtype); + } + function tensor6d(values, shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + assertNonNull(values); + if (shape != null && shape.length !== 6) { + throw new Error('tensor6d() requires shape to have six numbers'); + } + var inferredShape = inferShape(values); + if (inferredShape.length !== 6 && inferredShape.length !== 1) { + throw new Error('tensor6d() requires values to be number[][][][] or flat/TypedArray'); + } + if (inferredShape.length === 1 && shape == null) { + throw new Error('tensor6d() requires shape to be provided when `values` ' + + 'are a flat array'); + } + shape = shape || + inferredShape; + return tensor(values, shape, dtype); + } + function ones$1(shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = makeOnesTypedArray(sizeFromShape(shape), dtype); + return Tensor.make(shape, { values: values }, dtype); + } + function zeros(shape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = makeZerosTypedArray(sizeFromShape(shape), dtype); + return Tensor.make(shape, { values: values }, dtype); + } + function fill(shape, value, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + var values = getTypedArrayFromDType(dtype, sizeFromShape(shape)); + values.fill(value); + return Tensor.make(shape, { values: values }, dtype); + } + function onesLike_(x) { + var $x = convertToTensor(x, 'x', 'onesLike'); + return ones$1($x.shape, $x.dtype); + } + function zerosLike_(x) { + var $x = convertToTensor(x, 'x', 'zerosLike'); + return zeros($x.shape, $x.dtype); + } + function linspace(start, stop, num) { + if (num === 0) { + throw new Error('Cannot request zero samples'); + } + var step = (stop - start) / (num - 1); + var values = makeZerosTypedArray(num, 'float32'); + values[0] = start; + for (var i = 1; i < values.length; i++) { + values[i] = values[i - 1] + step; + } + return tensor1d(values, 'float32'); + } + function range(start, stop, step, dtype) { + if (step === void 0) { step = 1; } + if (dtype === void 0) { dtype = 'float32'; } + if (step === 0) { + throw new Error('Cannot have a step of zero'); + } + var sameStartStop = start === stop; + var increasingRangeNegativeStep = start < stop && step < 0; + var decreasingRangePositiveStep = stop < start && step > 1; + if (sameStartStop || increasingRangeNegativeStep || + decreasingRangePositiveStep) { + return zeros([0], dtype); + } + var numElements = Math.abs(Math.ceil((stop - start) / step)); + var values = makeZerosTypedArray(numElements, dtype); + if (stop < start && step === 1) { + step = -1; + } + values[0] = start; + for (var i = 1; i < values.length; i++) { + values[i] = values[i - 1] + step; + } + return tensor1d(values, dtype); + } + var onesLike = op({ onesLike_: onesLike_ }); + var zerosLike = op({ zerosLike_: zerosLike_ }); + + var DType; + (function (DType) { + DType["float32"] = "float32"; + DType["int32"] = "int32"; + DType["bool"] = "bool"; + })(DType || (DType = {})); + (function (Rank) { + Rank["R0"] = "R0"; + Rank["R1"] = "R1"; + Rank["R2"] = "R2"; + Rank["R3"] = "R3"; + Rank["R4"] = "R4"; + Rank["R5"] = "R5"; + Rank["R6"] = "R6"; + })(exports.Rank || (exports.Rank = {})); + var UpcastInt32AndMap; + (function (UpcastInt32AndMap) { + UpcastInt32AndMap["float32"] = "float32"; + UpcastInt32AndMap["int32"] = "int32"; + UpcastInt32AndMap["bool"] = "int32"; + })(UpcastInt32AndMap || (UpcastInt32AndMap = {})); + var UpcastBoolAndMap; + (function (UpcastBoolAndMap) { + UpcastBoolAndMap["float32"] = "float32"; + UpcastBoolAndMap["int32"] = "int32"; + UpcastBoolAndMap["bool"] = "bool"; + })(UpcastBoolAndMap || (UpcastBoolAndMap = {})); + var UpcastFloat32AndMap; + (function (UpcastFloat32AndMap) { + UpcastFloat32AndMap["float32"] = "float32"; + UpcastFloat32AndMap["int32"] = "float32"; + UpcastFloat32AndMap["bool"] = "float32"; + })(UpcastFloat32AndMap || (UpcastFloat32AndMap = {})); + var upcastTypeMap = { + 'float32': UpcastFloat32AndMap, + 'int32': UpcastInt32AndMap, + 'bool': UpcastBoolAndMap + }; + function upcastType(typeA, typeB) { + return upcastTypeMap[typeA][typeB]; + } + function sumOutType(type) { + return upcastType(type, 'int32'); + } + + function castTensor(x, dtype, backend) { + if (!hasEncodingLoss(x.dtype, dtype)) { + return Tensor.make(x.shape, { dataId: x.dataId }, dtype); + } + if (dtype === 'int32') { + return backend.int(x); + } + else if (dtype === 'bool') { + return backend.notEqual(x, scalar(0, x.dtype)); + } + else { + throw new Error("Error in Cast: unknown dtype argument (" + dtype + ")"); + } + } + function reshapeTensor(x, shape) { + return Tensor.make(shape, { dataId: x.dataId }, x.dtype); + } + + function nonMaxSuppressionImpl(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + var candidates = Array.from(scores) + .map(function (score, boxIndex) { return ({ score: score, boxIndex: boxIndex }); }) + .filter(function (c) { return c.score > scoreThreshold; }) + .sort(function (c1, c2) { return c2.score - c1.score; }); + var selected = []; + for (var i = 0; i < candidates.length; i++) { + var _a = candidates[i], score = _a.score, boxIndex = _a.boxIndex; + if (score < scoreThreshold) { + break; + } + var ignoreCandidate = false; + for (var j = selected.length - 1; j >= 0; --j) { + var iou = intersectionOverUnion(boxes, boxIndex, selected[j]); + if (iou >= iouThreshold) { + ignoreCandidate = true; + break; + } + } + if (!ignoreCandidate) { + selected.push(boxIndex); + if (selected.length >= maxOutputSize) { + break; + } + } + } + return tensor1d(selected, 'int32'); + } + function intersectionOverUnion(boxes, i, j) { + var iCoord = boxes.subarray(i * 4, i * 4 + 4); + var jCoord = boxes.subarray(j * 4, j * 4 + 4); + var yminI = Math.min(iCoord[0], iCoord[2]); + var xminI = Math.min(iCoord[1], iCoord[3]); + var ymaxI = Math.max(iCoord[0], iCoord[2]); + var xmaxI = Math.max(iCoord[1], iCoord[3]); + var yminJ = Math.min(jCoord[0], jCoord[2]); + var xminJ = Math.min(jCoord[1], jCoord[3]); + var ymaxJ = Math.max(jCoord[0], jCoord[2]); + var xmaxJ = Math.max(jCoord[1], jCoord[3]); + var areaI = (ymaxI - yminI) * (xmaxI - xminI); + var areaJ = (ymaxJ - yminJ) * (xmaxJ - xminJ); + if (areaI <= 0 || areaJ <= 0) { + return 0.0; + } + var intersectionYmin = Math.max(yminI, yminJ); + var intersectionXmin = Math.max(xminI, xminJ); + var intersectionYmax = Math.min(ymaxI, ymaxJ); + var intersectionXmax = Math.min(xmaxI, xmaxJ); + var intersectionArea = Math.max(intersectionYmax - intersectionYmin, 0.0) * + Math.max(intersectionXmax - intersectionXmin, 0.0); + return intersectionArea / (areaI + areaJ - intersectionArea); + } + + function topkImpl(x, xShape, xDtype, k, sorted) { + var lastDim = xShape[xShape.length - 1]; + var _a = [x.length / lastDim, lastDim], batch = _a[0], size = _a[1]; + var allTopKVals = getTypedArrayFromDType(xDtype, batch * k); + var allTopKIndices = getTypedArrayFromDType('int32', batch * k); + for (var b = 0; b < batch; b++) { + var offset = b * size; + var vals = x.subarray(offset, offset + size); + var valAndInd = []; + for (var i = 0; i < vals.length; i++) { + valAndInd.push({ value: vals[i], index: i }); + } + valAndInd.sort(function (a, b) { return b.value - a.value; }); + var outOffset = b * k; + var topKVals = allTopKVals.subarray(outOffset, outOffset + k); + var topKIndices = allTopKIndices.subarray(outOffset, outOffset + k); + for (var i = 0; i < k; i++) { + topKVals[i] = valAndInd[i].value; + topKIndices[i] = valAndInd[i].index; + } + } + var outputShape = xShape.slice(); + outputShape[outputShape.length - 1] = k; + return [ + tensor(allTopKVals, outputShape, xDtype), + tensor(allTopKIndices, outputShape, 'int32') + ]; + } + + var ArgMinMaxProgram = (function () { + function ArgMinMaxProgram(reduceInfo, op, firstPass) { + this.variableNames = ['A']; + var windowSize = reduceInfo.windowSize; + var batchSize = reduceInfo.batchSize; + var inSize = reduceInfo.inSize; + var outSize = Math.ceil(inSize / windowSize); + if (!firstPass) { + this.variableNames.push('bestIndicesA'); + } + this.outputShape = [batchSize, outSize]; + var compOp = (op === 'max') ? '>' : '<'; + var indexSnippet = firstPass ? + 'inOffset + i;' : + 'round(getBestIndicesA(batch, inOffset + i));'; + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + windowSize + ";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < " + windowSize + "; i++) {\n int inIdx = " + indexSnippet + ";\n float candidate = getA(batch, inIdx);\n if (candidate " + compOp + " bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "; + } + return ArgMinMaxProgram; + }()); + + var AvgPool2DBackpropProgram = (function () { + function AvgPool2DBackpropProgram(convInfo) { + this.variableNames = ['dy']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var avgMultiplier = 1 / (filterHeight * filterWidth); + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n const float avgMultiplier = float(" + avgMultiplier + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return AvgPool2DBackpropProgram; + }()); + + function getBroadcastDims(inShape, outShape) { + var inRank = inShape.length; + var dims = []; + for (var i = 0; i < inRank; i++) { + var dim = inRank - 1 - i; + var a = inShape[dim] || 1; + var b = outShape[outShape.length - 1 - i] || 1; + if (b > 1 && a === 1) { + dims.unshift(dim); + } + } + return dims; + } + function getReductionAxes(inShape, outShape) { + var result = []; + for (var i = 0; i < outShape.length; i++) { + var inDim = inShape[inShape.length - i - 1]; + var outAxis = outShape.length - i - 1; + var outDim = outShape[outAxis]; + if (inDim == null || (inDim === 1 && outDim > 1)) { + result.unshift(outAxis); + } + } + return result; + } + function broadcastDimsAreOuter(dims) { + for (var i = 0; i < dims.length; i++) { + if (dims[i] !== i) { + return false; + } + } + return true; + } + function assertAndGetBroadcastShape(shapeA, shapeB) { + var result = []; + var errMsg = "Operands could not be broadcast together with shapes " + + (shapeA + " and " + shapeB + "."); + var l = Math.max(shapeA.length, shapeB.length); + for (var i = 0; i < l; i++) { + var a = shapeA[shapeA.length - i - 1] || 1; + var b = shapeB[shapeB.length - i - 1] || 1; + if (a > 1 && b > 1 && a !== b) { + throw Error(errMsg); + } + result.unshift(Math.max(a, b)); + } + return result; + } + + var BatchNormProgram = (function () { + function BatchNormProgram(xShape, meanShape, varianceShape, offsetShape, scaleShape, varianceEpsilon) { + this.outputShape = []; + this.supportsBroadcasting = true; + this.variableNames = ['x', 'mean', 'variance']; + assertAndGetBroadcastShape(xShape, meanShape); + assertAndGetBroadcastShape(xShape, varianceShape); + var offsetSnippet = '0.0'; + if (offsetShape != null) { + assertAndGetBroadcastShape(xShape, offsetShape); + this.variableNames.push('offset'); + offsetSnippet = 'getOffsetAtOutCoords()'; + } + var scaleSnippet = '1.0'; + if (scaleShape != null) { + assertAndGetBroadcastShape(xShape, scaleShape); + this.variableNames.push('scale'); + scaleSnippet = 'getScaleAtOutCoords()'; + } + this.outputShape = xShape; + this.userCode = "\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = " + offsetSnippet + ";\n float scale = " + scaleSnippet + ";\n float inv = scale * inversesqrt(variance + float(" + varianceEpsilon + "));\n setOutput((x - mean) * inv + offset);\n }\n "; + } + return BatchNormProgram; + }()); + + var CHECK_NAN_SNIPPET = "\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n"; + var ADD = 'return a + b;'; + var SUB = 'return a - b;'; + var MUL = 'return a * b;'; + var DIV = "if (a == b) return 1.0;\n return a / b;"; + var INT_DIV = "\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n"; + var POW = "\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n"; + var SQUARED_DIFFERENCE = 'return (a - b) * (a - b);'; + var EQUAL = "return float(a == b);"; + var NOT_EQUAL = "return float(a != b);"; + var LESS = "return float(a < b);"; + var LESS_EQUAL = "return float(a <= b);"; + var GREATER = "return float(a > b);"; + var GREATER_EQUAL = "return float(a >= b);"; + var LOGICAL_AND = "return float(a >= 1.0 && b >= 1.0);"; + var LOGICAL_OR = "return float(a >= 1.0 || b >= 1.0);"; + var MAX = CHECK_NAN_SNIPPET + "\n return max(a, b);\n"; + var MIN = CHECK_NAN_SNIPPET + "\n return min(a, b);\n"; + var MOD = "if (b == 0.0) return NAN;\n return mod(a, b);"; + var ATAN2 = CHECK_NAN_SNIPPET + "\n return atan(a, b);\n"; + var ELU_DER = "return (b >= 1.0) ? a : a * (b + 1.0);"; + var BinaryOpProgram = (function () { + function BinaryOpProgram(op, aShape, bShape) { + this.variableNames = ['A', 'B']; + this.supportsBroadcasting = true; + this.outputShape = + assertAndGetBroadcastShape(aShape, bShape); + this.userCode = "\n uniform float NAN;\n float binaryOperation(float a, float b) {\n " + op + "\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "; + } + BinaryOpProgram.prototype.getCustomSetupFunc = function () { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN'); + if (_this.startLoc == null) { + return; + } + } + gpgpu.gl.uniform1f(_this.startLoc, NaN); + }; + }; + return BinaryOpProgram; + }()); + + var ClipProgram = (function () { + function ClipProgram(aShape, min, max) { + this.variableNames = ['A']; + this.outputShape = aShape; + var minFixed = min.toFixed(20); + var maxFixed = max.toFixed(20); + this.userCode = "\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, " + minFixed + ", " + maxFixed + "));\n }\n "; + } + return ClipProgram; + }()); + + function assertParams(aShape, bShape, axis) { + var aRank = aShape.length; + var bRank = bShape.length; + assert(aShape.length === bShape.length, "Error in concat" + aRank + "D: rank of x1 (" + aRank + ") and x2 (" + bRank + ") " + + "must be the same."); + assert(axis >= 0 && axis < aRank, "Error in concat" + aRank + "D: axis must be " + + ("between 0 and " + (aRank - 1) + ".")); + for (var i = 0; i < aRank; i++) { + assert((i === axis) || (aShape[i] === bShape[i]), "Error in concat" + aRank + "D: Shape (" + aShape + ") does not match " + + ("(" + bShape + ") along the non-concatenated axis " + i + ".")); + } + } + function computeOutShape$1(x1Shape, x2Shape, axis) { + assert(x1Shape.length === x2Shape.length, 'x1 and x2 should have the same rank.'); + var outputShape = x1Shape.slice(); + outputShape[axis] += x2Shape[axis]; + return outputShape; + } + function computeGradientSliceShapes(aShape, bShape) { + return { + aBegin: [0, 0], + aSize: aShape, + bBegin: [0, aShape[1]], + bSize: bShape + }; + } + + var ConcatProgram = (function () { + function ConcatProgram(aShape, bShape) { + this.variableNames = ['A', 'B']; + this.outputShape = []; + this.outputShape = + computeOutShape$1(aShape, bShape, 1); + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < " + aShape[1] + ") {\n value = getA(yR, yC);\n } else {\n yC -= " + aShape[1] + ";\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n "; + } + return ConcatProgram; + }()); + + var Conv2DDerFilterProgram = (function () { + function Conv2DDerFilterProgram(convInfo) { + this.variableNames = ['x', 'dy']; + this.outputShape = convInfo.filterShape; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < " + convInfo.batchSize + "; b++) {\n for (int yR = 0; yR < " + convInfo.outHeight + "; yR++) {\n int xR = wR + yR * " + strideHeight + " - " + padTop + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + convInfo.outWidth + "; yC++) {\n int xC = wC + yC * " + strideWidth + " - " + padLeft + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DDerFilterProgram; + }()); + var Conv2DDerInputProgram = (function () { + function Conv2DDerInputProgram(convInfo) { + this.variableNames = ['dy', 'W']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + filterHeight + " - 1 - wR;\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + filterWidth + " - 1 - wC;\n\n for (int d2 = 0; d2 < " + convInfo.outChannels + "; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DDerInputProgram; + }()); + + var DepthwiseConv2DDerFilterProgram = (function () { + function DepthwiseConv2DDerFilterProgram(convInfo) { + this.variableNames = ['x', 'dy']; + this.outputShape = convInfo.filterShape; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * " + channelMul + " + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < " + convInfo.batchSize + "; b++) {\n for (int yR = 0; yR < " + convInfo.outHeight + "; yR++) {\n int xR = wR + yR * " + strideHeight + " - " + padTop + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + convInfo.outWidth + "; yC++) {\n int xC = wC + yC * " + strideWidth + " - " + padLeft + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DDerFilterProgram; + }()); + var DepthwiseConv2DDerInputProgram = (function () { + function DepthwiseConv2DDerInputProgram(convInfo) { + this.variableNames = ['dy', 'W']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + filterHeight + " - 1 - wR;\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + filterWidth + " - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < " + channelMul + "; dm++) {\n int d2 = d1 * " + channelMul + " + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DDerInputProgram; + }()); + + var Conv2DProgram = (function () { + function Conv2DProgram(convInfo) { + this.variableNames = ['x', 'W']; + this.outputShape = convInfo.outShape; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var inputDepthNearestVec4 = Math.floor(convInfo.inChannels / 4) * 4; + var inputDepthVec4Remainder = convInfo.inChannels % 4; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR * " + dilationHeight + ";\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC * " + dilationWidth + ";\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n for (int d1 = 0; d1 < " + inputDepthNearestVec4 + "; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (" + (inputDepthVec4Remainder === 1) + ") {\n dotProd +=\n getX(batch, xR, xC, " + inputDepthNearestVec4 + ") *\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2);\n } else if (" + (inputDepthVec4Remainder === 2) + ") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, " + inputDepthNearestVec4 + "),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (" + (inputDepthVec4Remainder === 3) + ") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, " + inputDepthNearestVec4 + "),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 1),\n getX(batch, xR, xC, " + inputDepthNearestVec4 + " + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, " + inputDepthNearestVec4 + ", d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 1, d2),\n getW(wR, wC, " + inputDepthNearestVec4 + " + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + } + return Conv2DProgram; + }()); + + var DepthwiseConv2DProgram = (function () { + function DepthwiseConv2DProgram(convInfo) { + this.variableNames = ['x', 'W']; + this.outputShape = convInfo.outShape; + var xNumRows = convInfo.inHeight; + var xNumCols = convInfo.inWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var channelMul = convInfo.outChannels / convInfo.inChannels; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / " + channelMul + ";\n int q = d2 - d1 * " + channelMul + ";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR * " + dilationHeight + ";\n\n if (xR < 0 || xR >= " + xNumRows + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC * " + dilationWidth + ";\n\n if (xC < 0 || xC >= " + xNumCols + ") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return DepthwiseConv2DProgram; + }()); + + function makeShader(inputsInfo, outputShape, userCode, broadcast) { + var inputPrefixSnippet = inputsInfo.map(function (x) { + var size = sizeFromShape(x.shapeInfo.logicalShape); + if (x.shapeInfo.isUniform) { + return "uniform float " + x.name + (size > 1 ? "[" + size + "]" : '') + ";"; + } + return "uniform sampler2D " + x.name + ";"; + }); + inputPrefixSnippet = inputPrefixSnippet.join('\n'); + var inputSamplingSnippet = inputsInfo.map(function (x) { return getInputSamplingSnippet(x, outputShape, broadcast); }) + .join('\n'); + var outTexShape = outputShape.texShape; + var outputSamplingSnippet = getOutputSamplingSnippet(outputShape.logicalShape, outTexShape); + var source = [ + SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET, + FLOAT_TEXTURE_SETOUTPUT_SNIPPET, inputPrefixSnippet, outputSamplingSnippet, + inputSamplingSnippet, userCode + ].join('\n'); + return source; + } + function getSamplerFromInInfo(inInfo) { + var shape = inInfo.shapeInfo.logicalShape; + switch (shape.length) { + case 0: + return getSamplerScalar(inInfo); + case 1: + return getSampler1D(inInfo); + case 2: + return getSampler2D(inInfo); + case 3: + return getSampler3D(inInfo); + case 4: + return getSampler4D(inInfo); + case 5: + return getSampler5D(inInfo); + case 6: + return getSampler6D(inInfo); + default: + throw new Error(shape.length + "-D input sampling" + + " is not yet supported"); + } + } + function getInputSamplingSnippet(inInfo, outShapeInfo, broadcast) { + var res = getSamplerFlat(inInfo); + res += getSamplerFromInInfo(inInfo); + if (broadcast || + arraysEqual(inInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape)) { + res += getSamplerAtOutputCoords(inInfo, outShapeInfo, broadcast); + } + return res; + } + function getOutputSamplingSnippet(outShape, outTexShape) { + switch (outShape.length) { + case 0: + return getOutputScalarCoords(); + case 1: + return getOutput1DCoords(outShape, outTexShape); + case 2: + return getOutput2DCoords(outShape, outTexShape); + case 3: + return getOutput3DCoords(outShape, outTexShape); + case 4: + return getOutput4DCoords(outShape, outTexShape); + case 5: + return getOutput5DCoords(outShape, outTexShape); + case 6: + return getOutput6DCoords(outShape, outTexShape); + default: + throw new Error(outShape.length + "-D output sampling is not yet supported"); + } + } + var SAMPLE_1D_SNIPPET = "\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var SAMPLE_2D_SNIPPET = "\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var SAMPLE_3D_SNIPPET = "\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var SAMPLE_4D_SNIPPET = "\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var SAMPLE_5D_SNIPPET = "\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var SAMPLE_6D_SNIPPET = "\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n"; + var FLOAT_TEXTURE_SAMPLE_SNIPPET = "\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n"; + var FLOAT_TEXTURE_SETOUTPUT_SNIPPET = "\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n"; + var SHADER_PREFIX = "\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n " + SAMPLE_1D_SNIPPET + "\n " + SAMPLE_2D_SNIPPET + "\n " + SAMPLE_3D_SNIPPET + "\n " + SAMPLE_4D_SNIPPET + "\n " + SAMPLE_5D_SNIPPET + "\n " + SAMPLE_6D_SNIPPET + "\n"; + function getOutputScalarCoords() { + return "\n int getOutputCoords() {\n return 0;\n }\n "; + } + function getOutput1DCoords(shape, texShape) { + if (texShape[0] === 1) { + return "\n int getOutputCoords() {\n return int(resultUV.x * " + texShape[1] + ".0);\n }\n "; + } + if (texShape[1] === 1) { + return "\n int getOutputCoords() {\n return int(resultUV.y * " + texShape[0] + ".0);\n }\n "; + } + return "\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n return resTexRC.x * " + texShape[1] + " + resTexRC.y;\n }\n "; + } + function getOutput3DCoords(shape, texShape) { + var stride0 = shape[1] * shape[2]; + var stride1 = shape[2]; + return "\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n int c = index / " + stride1 + ";\n int d = index - c * " + stride1 + ";\n return ivec3(r, c, d);\n }\n "; + } + function getOutput4DCoords(shape, texShape) { + var stride2 = shape[3]; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n int d2 = index - d * " + stride2 + ";\n\n return ivec4(r, c, d, d2);\n }\n "; + } + function getOutput5DCoords(shape, texShape) { + var stride3 = shape[4]; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(" + texShape[0] + ",\n " + texShape[1] + "));\n\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n index -= d * " + stride2 + ";\n\n int d2 = index / " + stride3 + ";\n int d3 = index - d2 * " + stride3 + ";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "; + } + function getOutput6DCoords(shape, texShape) { + var stride4 = shape[5]; + var stride3 = shape[4] * stride4; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + return "\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n\n int r = index / " + stride0 + ";\n index -= r * " + stride0 + ";\n\n int c = index / " + stride1 + ";\n index -= c * " + stride1 + ";\n\n int d = index / " + stride2 + ";\n index -= d * " + stride2 + ";\n\n int d2 = index / " + stride3 + ";\n index -= d2 * " + stride3 + ";\n\n int d3 = index / " + stride4 + ";\n int d4 = index - d3 * " + stride4 + ";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "; + } + function getOutput2DCoords(shape, texShape) { + if (arraysEqual(shape, texShape)) { + return "\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(" + texShape[0] + ", " + texShape[1] + "));\n }\n "; + } + if (shape[1] === 1) { + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n return ivec2(index, 0);\n }\n "; + } + if (shape[0] === 1) { + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n return ivec2(0, index);\n }\n "; + } + return "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + texShape[0] + ", " + texShape[1] + "));\n int index = resTexRC.x * " + texShape[1] + " + resTexRC.y;\n int r = index / " + shape[1] + ";\n int c = index - r * " + shape[1] + ";\n return ivec2(r, c);\n }\n "; + } + function getSamplerScalar(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + if (inputInfo.shapeInfo.isUniform) { + return "float " + funcName + "() {return " + texName + ";}"; + } + return "\n float " + funcName + "() {\n return sampleTexture(" + texName + ", halfCR);\n }\n "; + } + function getSampler1D(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + return "\n float " + funcName + "(int index) {\n return " + funcName + "Flat(index);\n }\n "; + } + function getSampler2D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var texShape = inputInfo.shapeInfo.texShape; + if (texShape != null && arraysEqual(shape, texShape)) { + var texNumR_1 = texShape[0]; + var texNumC_1 = texShape[1]; + return "\n float " + funcName + "(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(" + texNumC_1 + ".0, " + texNumR_1 + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + var _a = squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + var squeezedShape = newShape; + if (squeezedShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, squeezedShape); + var params = ['row', 'col']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n return " + funcName + "Flat(index);\n }\n "; + } + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === 1) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumR === 1) { + return "\n float " + funcName + "(int row, int col) {\n int index = row * " + shape[1] + " + col;\n vec2 uv = vec2((float(index) + 0.5) / " + texNumC + ".0, 0.5);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col) {\n vec2 uv = UVfrom2D(" + texNumR + ", " + texNumC + ", " + shape[1] + ", row, col);\n return sampleTexture(" + texName + ", uv);\n }\n"; + } + function getSampler3D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride0 = shape[1] * shape[2]; + var stride1 = shape[2]; + var _a = squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + var squeezedShape = newShape; + if (squeezedShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, squeezedShape); + var params = ['row', 'col', 'depth']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int index = row * " + stride0 + " + col * " + stride1 + " + depth;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int texR = row;\n int texC = col * " + stride1 + " + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride1) { + return "\n float " + funcName + "(int row, int col, int depth) {\n int texR = row * " + shape[1] + " + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n " + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ", row, col, depth);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getSampler4D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride2 = shape[3]; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride2) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", row, col, depth, depth2);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getSampler5D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride3 = shape[4]; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2', 'depth3']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2 * " + stride3 + " + depth3;\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " +\n depth2 * " + stride3 + " + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride3) { + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " +\n depth * " + shape[3] + " + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", " + stride3 + ", row, col, depth, depth2, depth3);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getSampler6D(inputInfo) { + var shape = inputInfo.shapeInfo.logicalShape; + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1); + var stride4 = shape[5]; + var stride3 = shape[4] * stride4; + var stride2 = shape[3] * stride3; + var stride1 = shape[2] * stride2; + var stride0 = shape[1] * stride1; + var _a = squeezeShape(shape), newShape = _a.newShape, keptDims = _a.keptDims; + if (newShape.length < shape.length) { + var newInputInfo = squeezeInputInfo(inputInfo, newShape); + var params = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4']; + return "\n " + getSamplerFromInInfo(newInputInfo) + "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return " + funcName + "(" + getSqueezedParams(params, keptDims) + ");\n }\n "; + } + if (inputInfo.shapeInfo.isUniform) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * " + stride0 + " + col * " + stride1 + " +\n depth * " + stride2 + " + depth2 * " + stride3 + " + depth3 * " + stride3 + "\n + depth4\n return " + funcName + "Flat(index);\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var texNumR = texShape[0]; + var texNumC = texShape[1]; + if (texNumC === stride0) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * " + stride1 + " + depth * " + stride2 + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (texNumC === stride4) { + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * " + shape[1] * shape[2] + " + col * " + shape[2] + " + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + texNumC + ".0, " + texNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(" + texNumR + ", " + texNumC + ", " + stride0 + ", " + stride1 + ",\n " + stride2 + ", " + stride3 + ", " + stride4 + "\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getSamplerFlat(inputInfo) { + var texName = inputInfo.name; + var funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1) + 'Flat'; + var inSize = sizeFromShape(inputInfo.shapeInfo.logicalShape); + if (inputInfo.shapeInfo.isUniform) { + if (inSize === 1) { + return "float " + funcName + "(int index) {return " + texName + ";}"; + } + return "\n float " + funcName + "(int index) {\n for (int i = 0; i < " + inSize + "; i++) {\n if (i == index) {\n return " + texName + "[i];\n }\n }\n }\n "; + } + var texShape = inputInfo.shapeInfo.texShape; + var tNumR = texShape[0]; + var tNumC = texShape[1]; + if (tNumC === 1 && tNumR === 1) { + return "\n float " + funcName + "(int index) {\n return sampleTexture(" + texName + ", halfCR);\n }\n "; + } + if (tNumC === 1) { + return "\n float " + funcName + "(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + tNumR + ".0);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + if (tNumR === 1) { + return "\n float " + funcName + "(int index) {\n vec2 uv = vec2((float(index) + 0.5) / " + tNumC + ".0, 0.5);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + return "\n float " + funcName + "(int index) {\n vec2 uv = UVfrom1D(" + tNumR + ", " + tNumC + ", index);\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getBroadcastOutputCoordsSampler(inputInfo, outShapeInfo, texFuncSnippet, funcName) { + var inRank = inputInfo.shapeInfo.logicalShape.length; + var outRank = outShapeInfo.logicalShape.length; + var type = 'int'; + if (outRank === 2) { + type = 'ivec2'; + } + else if (outRank === 3) { + type = 'ivec3'; + } + else if (outRank === 4) { + type = 'ivec4'; + } + var broadcastDims = getBroadcastDims(inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape); + var rankDiff = outRank - inRank; + var coordsSnippet; + if (inRank === 0) { + coordsSnippet = ''; + } + else if (outRank < 2 && broadcastDims.length >= 1) { + coordsSnippet = 'coords = 0;'; + } + else { + coordsSnippet = + broadcastDims.map(function (d) { return "coords[" + (d + rankDiff) + "] = 0;"; }).join('\n'); + } + var unpackedCoordsSnippet = ''; + if (outRank < 2 && inRank > 0) { + unpackedCoordsSnippet = 'coords'; + } + else { + unpackedCoordsSnippet = inputInfo.shapeInfo.logicalShape + .map(function (s, i) { return "coords[" + (i + rankDiff) + "]"; }) + .join(', '); + } + return "\n float " + funcName + "() {\n " + type + " coords = getOutputCoords();\n " + coordsSnippet + "\n return get" + texFuncSnippet + "(" + unpackedCoordsSnippet + ");\n }\n "; + } + function getSamplerAtOutputCoords(inputInfo, outShapeInfo, supportsBroadcasting) { + var texName = inputInfo.name; + var texFuncSnippet = texName.charAt(0).toUpperCase() + texName.slice(1); + var funcName = 'get' + texFuncSnippet + 'AtOutCoords'; + var broadcastDims = getBroadcastDims(inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape); + var inRank = inputInfo.shapeInfo.logicalShape.length; + var outRank = outShapeInfo.logicalShape.length; + var doBroadcast = supportsBroadcasting && ((outRank > inRank) || broadcastDims.length > 0); + var broadcastOverOuter = broadcastDimsAreOuter(broadcastDims); + var isUniform = inputInfo.shapeInfo.isUniform; + if (doBroadcast && !broadcastOverOuter) { + return getBroadcastOutputCoordsSampler(inputInfo, outShapeInfo, texFuncSnippet, funcName); + } + var inSize = sizeFromShape(inputInfo.shapeInfo.logicalShape); + var broadcastSnippet = ''; + if (doBroadcast && broadcastOverOuter) { + broadcastSnippet = "\n int mainPart = index / " + inSize + ";\n index -= mainPart * " + inSize + ";\n "; + } + var outTexShape = outShapeInfo.texShape; + if (isUniform) { + if (inSize === 1) { + return "float " + funcName + "() {return " + texName + ";}"; + } + return "\n float " + funcName + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + outTexShape[0] + ", " + outTexShape[1] + "));\n int index = resTexRC.x * " + outTexShape[1] + " + resTexRC.y;\n " + broadcastSnippet + "\n return get" + texFuncSnippet + "Flat(index);\n }\n "; + } + var inTexShape = inputInfo.shapeInfo.texShape; + if (arraysEqual(inTexShape, outTexShape)) { + return "\n float " + funcName + "() {\n return sampleTexture(" + texName + ", resultUV);\n }\n "; + } + return "\n float " + funcName + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + outTexShape[0] + ", " + outTexShape[1] + "));\n int index = resTexRC.x * " + outTexShape[1] + " + resTexRC.y;\n " + broadcastSnippet + "\n int texR = index / " + inTexShape[1] + ";\n int texC = index - texR * " + inTexShape[1] + ";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + inTexShape[1] + ".0, " + inTexShape[0] + ".0);\n\n return sampleTexture(" + texName + ", uv);\n }\n "; + } + function getCoordsDataType(rank) { + if (rank <= 1) { + return 'int'; + } + else if (rank === 2) { + return 'ivec2'; + } + else if (rank === 3) { + return 'ivec3'; + } + else if (rank === 4) { + return 'ivec4'; + } + else if (rank === 5) { + return 'ivec5'; + } + else if (rank === 6) { + return 'ivec6'; + } + else { + throw Error("GPU for rank " + rank + " is not yet supported"); + } + } + function squeezeInputInfo(inInfo, squeezedShape) { + var newInputInfo = JSON.parse(JSON.stringify(inInfo)); + newInputInfo.shapeInfo.logicalShape = squeezedShape; + return newInputInfo; + } + function getSqueezedParams(params, keptDims) { + return keptDims.map(function (d) { return params[d]; }).join(', '); + } + + var CumSumProgram = (function () { + function CumSumProgram(shape, exclusive, reverse) { + this.variableNames = ['x']; + this.outputShape = shape; + var rank = shape.length; + var finalDim = shape[shape.length - 1]; + var comparator = reverse ? '<' : '>'; + this.userCode = "\n int getIndex(int i) {\n " + (reverse ? "return " + finalDim + " -i - 1;" : 'return i;') + "\n }\n\n void main() {\n " + getCoordsDataType(rank) + " coords = getOutputCoords();\n int end = " + getFinalCoord(rank, 'coords') + ";\n float val = 0.0;\n for (int i = " + finalDim + " - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx " + comparator + " end) {\n continue;\n }\n if (idx == end && " + exclusive + ") {\n continue;\n }\n " + getFinalCoord(rank, 'coords') + " = idx;\n val += getX(" + getCoords(rank, 'coords') + ");\n }\n setOutput(val);\n }\n "; + } + return CumSumProgram; + }()); + function getCoords(rank, name) { + if (rank === 1) { + return "" + name; + } + else if (rank === 2) { + return name + ".x, " + name + ".y"; + } + else if (rank === 3) { + return name + ".x, " + name + ".y, " + name + ".z"; + } + else if (rank === 4) { + return name + ".x, " + name + ".y, " + name + ".z, " + name + ".w"; + } + else { + throw Error("Cumulative sum for rank " + rank + " is not yet supported"); + } + } + function getFinalCoord(rank, name) { + if (rank === 1) { + return "" + name; + } + else if (rank === 2) { + return name + ".y"; + } + else if (rank === 3) { + return name + ".z"; + } + else if (rank === 4) { + return name + ".w"; + } + else { + throw Error("Cumulative sum for rank " + rank + " is not yet supported"); + } + } + + var EncodeFloatProgram = (function () { + function EncodeFloatProgram(outputShape) { + this.variableNames = ['A']; + this.outputShape = outputShape; + this.userCode = "\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "; + } + return EncodeFloatProgram; + }()); + + var FromPixelsProgram = (function () { + function FromPixelsProgram(outputShape) { + this.variableNames = ['A']; + var height = outputShape[0], width = outputShape[1]; + this.outputShape = outputShape; + this.userCode = "\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + width + ".0, " + height + ".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "; + } + return FromPixelsProgram; + }()); + + var GatherProgram = (function () { + function GatherProgram(aShape, indicesLength, axis) { + this.variableNames = ['A', 'indices']; + var outputShape = aShape.slice(); + outputShape[axis] = indicesLength; + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = getCoordsDataType(this.rank); + var sourceCoords = getSourceCoords(aShape, axis); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + sourceCoords + "));\n }\n "; + } + return GatherProgram; + }()); + function getSourceCoords(aShape, axis) { + var rank = aShape.length; + if (rank > 4) { + throw Error("Gather for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + return "int(getIndices(resRC))"; + } + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w']; + var sourceCoords = []; + for (var i = 0; i < aShape.length; i++) { + if (i === axis) { + sourceCoords.push("int(getIndices(" + currentCoords[i] + "))"); + } + else { + sourceCoords.push("" + currentCoords[i]); + } + } + return sourceCoords.join(); + } + + var TextureUsage; + (function (TextureUsage) { + TextureUsage[TextureUsage["RENDER"] = 0] = "RENDER"; + TextureUsage[TextureUsage["UPLOAD"] = 1] = "UPLOAD"; + TextureUsage[TextureUsage["PIXELS"] = 2] = "PIXELS"; + TextureUsage[TextureUsage["DOWNLOAD"] = 3] = "DOWNLOAD"; + })(TextureUsage || (TextureUsage = {})); + var PhysicalTextureType; + (function (PhysicalTextureType) { + PhysicalTextureType[PhysicalTextureType["FLOAT16"] = 0] = "FLOAT16"; + PhysicalTextureType[PhysicalTextureType["FLOAT32"] = 1] = "FLOAT32"; + PhysicalTextureType[PhysicalTextureType["UNSIGNED_BYTE"] = 2] = "UNSIGNED_BYTE"; + })(PhysicalTextureType || (PhysicalTextureType = {})); + function getUnpackedMatrixTextureShapeWidthHeight(rows, columns) { + return [columns, rows]; + } + function getUnpackedArraySizeFromMatrixSize(matrixSize, channelsPerTexture) { + return matrixSize * channelsPerTexture; + } + function getMatrixSizeFromUnpackedArraySize(unpackedSize, channelsPerTexture) { + if (unpackedSize % channelsPerTexture !== 0) { + throw new Error("unpackedSize (" + unpackedSize + ") must be a multiple of " + + ("" + channelsPerTexture)); + } + return unpackedSize / channelsPerTexture; + } + function encodeMatrixToUnpackedArray(matrix, unpackedArray, channelsPerTexture) { + var requiredSize = getUnpackedArraySizeFromMatrixSize(matrix.length, channelsPerTexture); + if (unpackedArray.length < requiredSize) { + throw new Error("unpackedArray length (" + unpackedArray.length + ") must be >= " + + ("" + requiredSize)); + } + var dst = 0; + for (var src = 0; src < matrix.length; ++src) { + unpackedArray[dst] = matrix[src]; + dst += channelsPerTexture; + } + } + function decodeMatrixFromUnpackedArray(unpackedArray, matrix, channelsPerTexture) { + var requiredSize = getMatrixSizeFromUnpackedArraySize(unpackedArray.length, channelsPerTexture); + if (matrix.length < requiredSize) { + throw new Error("matrix length (" + matrix.length + ") must be >= " + requiredSize); + } + var dst = 0; + for (var src = 0; src < unpackedArray.length; src += channelsPerTexture) { + matrix[dst++] = unpackedArray[src]; + } + } + function getPackedMatrixTextureShapeWidthHeight(rows, columns) { + return [Math.ceil(columns / 2), Math.ceil(rows / 2)]; + } + function getPackedRGBAArraySizeFromMatrixShape(rows, columns) { + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + return w * h * 4; + } + function encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA) { + var requiredSize = getPackedRGBAArraySizeFromMatrixShape(rows, columns); + if (packedRGBA.length < requiredSize) { + throw new Error("packedRGBA length (" + packedRGBA.length + ") must be >= " + requiredSize); + } + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), textureWidth = _a[0], textureHeight = _a[1]; + var oddWidth = (columns % 2) === 1; + var oddHeight = (rows % 2) === 1; + var widthInFullBlocks = Math.floor(columns / 2); + var heightInFullBlocks = Math.floor(rows / 2); + { + var dstStride = (oddWidth ? 4 : 0); + var oneRow = columns; + var dst = 0; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + var matrixSrcRow = (blockY * 2 * columns); + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + var matrixSrcCol = blockX * 2; + var src = matrixSrcRow + matrixSrcCol; + packedRGBA[dst] = matrix[src]; + packedRGBA[dst + 1] = matrix[src + 1]; + packedRGBA[dst + 2] = matrix[src + oneRow]; + packedRGBA[dst + 3] = matrix[src + oneRow + 1]; + dst += 4; + } + dst += dstStride; + } + } + if (oddWidth) { + var src = columns - 1; + var dst = (textureWidth - 1) * 4; + var srcStride = 2 * columns; + var dstStride = textureWidth * 4; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + packedRGBA[dst] = matrix[src]; + packedRGBA[dst + 2] = matrix[src + columns]; + src += srcStride; + dst += dstStride; + } + } + if (oddHeight) { + var src = (rows - 1) * columns; + var dst = (textureHeight - 1) * textureWidth * 4; + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + packedRGBA[dst++] = matrix[src++]; + packedRGBA[dst++] = matrix[src++]; + dst += 2; + } + } + if (oddWidth && oddHeight) { + packedRGBA[packedRGBA.length - 4] = matrix[matrix.length - 1]; + } + return packedRGBA; + } + function decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix) { + var requiredSize = rows * columns; + if (requiredSize < matrix.length) { + throw new Error("matrix length (" + matrix.length + ") must be >= " + requiredSize); + } + var oddWidth = (columns % 2) === 1; + var oddHeight = (rows % 2) === 1; + var widthInFullBlocks = Math.floor(columns / 2); + var heightInFullBlocks = Math.floor(rows / 2); + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), textureWidth = _a[0], textureHeight = _a[1]; + { + var srcStride = oddWidth ? 4 : 0; + var dstStride = columns + (oddWidth ? 1 : 0); + var src = 0; + var dstRow1 = 0; + var dstRow2 = columns; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + matrix[dstRow1++] = packedRGBA[src++]; + matrix[dstRow1++] = packedRGBA[src++]; + matrix[dstRow2++] = packedRGBA[src++]; + matrix[dstRow2++] = packedRGBA[src++]; + } + src += srcStride; + dstRow1 += dstStride; + dstRow2 += dstStride; + } + } + if (oddWidth) { + var src = (textureWidth - 1) * 4; + var dst = columns - 1; + var srcStride = textureWidth * 4; + var dstStride = 2 * columns; + for (var blockY = 0; blockY < heightInFullBlocks; ++blockY) { + matrix[dst] = packedRGBA[src]; + matrix[dst + columns] = packedRGBA[src + 2]; + src += srcStride; + dst += dstStride; + } + } + if (oddHeight) { + var src = (textureHeight - 1) * textureWidth * 4; + var dst = (rows - 1) * columns; + for (var blockX = 0; blockX < widthInFullBlocks; ++blockX) { + matrix[dst++] = packedRGBA[src++]; + matrix[dst++] = packedRGBA[src++]; + src += 2; + } + } + if (oddWidth && oddHeight) { + matrix[matrix.length - 1] = packedRGBA[packedRGBA.length - 4]; + } + return matrix; + } + + var MAX_TEXTURE_SIZE = null; + function createWebGLRenderingContext(attributes) { + var canvas = document.createElement('canvas'); + canvas.width = 1; + canvas.height = 1; + return createWebGLRenderingContextFromCanvas(canvas, attributes); + } + function createWebGLRenderingContextFromCanvas(canvas, attributes) { + var gl; + var webglVersion = ENV.get('WEBGL_VERSION'); + if (webglVersion === 2) { + gl = canvas.getContext('webgl2', attributes); + } + else if (webglVersion === 1) { + gl = (canvas.getContext('webgl', attributes) || + canvas.getContext('experimental-webgl', attributes)); + } + if (webglVersion === 0 || gl == null) { + throw new Error('This browser does not support WebGL.'); + } + return gl; + } + function callAndCheck(gl, func) { + var returnValue = func(); + checkWebGLError(gl); + return returnValue; + } + var webGLDebugErrorCheckingEnabled = false; + function enableDebugWebGLErrorChecking(enabled) { + webGLDebugErrorCheckingEnabled = enabled; + } + function checkWebGLError(gl) { + if (webGLDebugErrorCheckingEnabled) { + var error = gl.getError(); + if (error !== gl.NO_ERROR) { + throw new Error('WebGL Error: ' + getWebGLErrorMessage(gl, error)); + } + } + } + function getWebGLErrorMessage(gl, status) { + switch (status) { + case gl.NO_ERROR: + return 'NO_ERROR'; + case gl.INVALID_ENUM: + return 'INVALID_ENUM'; + case gl.INVALID_VALUE: + return 'INVALID_VALUE'; + case gl.INVALID_OPERATION: + return 'INVALID_OPERATION'; + case gl.INVALID_FRAMEBUFFER_OPERATION: + return 'INVALID_FRAMEBUFFER_OPERATION'; + case gl.OUT_OF_MEMORY: + return 'OUT_OF_MEMORY'; + case gl.CONTEXT_LOST_WEBGL: + return 'CONTEXT_LOST_WEBGL'; + default: + return "Unknown error code " + status; + } + } + function getExtensionOrThrow(gl, extensionName) { + return throwIfNull(gl, function () { return gl.getExtension(extensionName); }, 'Extension "' + extensionName + '" not supported on this browser.'); + } + function createVertexShader(gl, vertexShaderSource) { + var vertexShader = throwIfNull(gl, function () { return gl.createShader(gl.VERTEX_SHADER); }, 'Unable to create vertex WebGLShader.'); + callAndCheck(gl, function () { return gl.shaderSource(vertexShader, vertexShaderSource); }); + callAndCheck(gl, function () { return gl.compileShader(vertexShader); }); + if (gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS) === false) { + console.log(gl.getShaderInfoLog(vertexShader)); + throw new Error('Failed to compile vertex shader.'); + } + return vertexShader; + } + function createFragmentShader(gl, fragmentShaderSource) { + var fragmentShader = throwIfNull(gl, function () { return gl.createShader(gl.FRAGMENT_SHADER); }, 'Unable to create fragment WebGLShader.'); + callAndCheck(gl, function () { return gl.shaderSource(fragmentShader, fragmentShaderSource); }); + callAndCheck(gl, function () { return gl.compileShader(fragmentShader); }); + if (gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS) === false) { + logShaderSourceAndInfoLog(fragmentShaderSource, gl.getShaderInfoLog(fragmentShader)); + throw new Error('Failed to compile fragment shader.'); + } + return fragmentShader; + } + var lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g; + function logShaderSourceAndInfoLog(shaderSource, shaderInfoLog) { + var lineNumberRegexResult = lineNumberRegex.exec(shaderInfoLog); + if (lineNumberRegexResult == null) { + console.log("Couldn't parse line number in error: " + shaderInfoLog); + console.log(shaderSource); + return; + } + var lineNumber = +lineNumberRegexResult[1]; + var shaderLines = shaderSource.split('\n'); + var pad = shaderLines.length.toString().length + 2; + var linesWithLineNumbers = shaderLines.map(function (line, lineNumber) { + return rightPad((lineNumber + 1).toString(), pad) + line; + }); + var maxLineLength = 0; + for (var i = 0; i < linesWithLineNumbers.length; i++) { + maxLineLength = Math.max(linesWithLineNumbers[i].length, maxLineLength); + } + var beforeErrorLines = linesWithLineNumbers.slice(0, lineNumber - 1); + var errorLine = linesWithLineNumbers.slice(lineNumber - 1, lineNumber); + var afterErrorLines = linesWithLineNumbers.slice(lineNumber); + console.log(beforeErrorLines.join('\n')); + console.log(shaderInfoLog.split('\n')[0]); + console.log("%c " + rightPad(errorLine[0], maxLineLength), 'border:1px solid red; background-color:#e3d2d2; color:#a61717'); + console.log(afterErrorLines.join('\n')); + } + function createProgram(gl) { + return throwIfNull(gl, function () { return gl.createProgram(); }, 'Unable to create WebGLProgram.'); + } + function linkProgram(gl, program) { + callAndCheck(gl, function () { return gl.linkProgram(program); }); + if (gl.getProgramParameter(program, gl.LINK_STATUS) === false) { + console.log(gl.getProgramInfoLog(program)); + throw new Error('Failed to link vertex and fragment shaders.'); + } + } + function validateProgram(gl, program) { + callAndCheck(gl, function () { return gl.validateProgram(program); }); + if (gl.getProgramParameter(program, gl.VALIDATE_STATUS) === false) { + console.log(gl.getProgramInfoLog(program)); + throw new Error('Shader program validation failed.'); + } + } + function createStaticVertexBuffer(gl, data) { + var buffer = throwIfNull(gl, function () { return gl.createBuffer(); }, 'Unable to create WebGLBuffer'); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW); }); + return buffer; + } + function createStaticIndexBuffer(gl, data) { + var buffer = throwIfNull(gl, function () { return gl.createBuffer(); }, 'Unable to create WebGLBuffer'); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, data, gl.STATIC_DRAW); }); + return buffer; + } + function queryMaxTextureSize(gl) { + if (MAX_TEXTURE_SIZE != null) { + return MAX_TEXTURE_SIZE; + } + MAX_TEXTURE_SIZE = + callAndCheck(gl, function () { return gl.getParameter(gl.MAX_TEXTURE_SIZE); }); + return MAX_TEXTURE_SIZE; + } + function getNumChannels() { + if (ENV.get('WEBGL_VERSION') === 2) { + return 1; + } + return 4; + } + function createTexture(gl) { + return throwIfNull(gl, function () { return gl.createTexture(); }, 'Unable to create WebGLTexture.'); + } + function validateTextureSize(gl, width, height) { + var maxTextureSize = queryMaxTextureSize(gl); + if ((width <= 0) || (height <= 0)) { + var requested = "[" + width + "x" + height + "]"; + throw new Error('Requested texture size ' + requested + ' is invalid.'); + } + if ((width > maxTextureSize) || (height > maxTextureSize)) { + var requested = "[" + width + "x" + height + "]"; + var max = "[" + maxTextureSize + "x" + maxTextureSize + "]"; + throw new Error('Requested texture size ' + requested + + ' greater than WebGL maximum on this browser / GPU ' + max + '.'); + } + } + function createFramebuffer(gl) { + return throwIfNull(gl, function () { return gl.createFramebuffer(); }, 'Unable to create WebGLFramebuffer.'); + } + function bindVertexBufferToProgramAttribute(gl, program, attribute, buffer, arrayEntriesPerItem, itemStrideInBytes, itemOffsetInBytes) { + var loc = gl.getAttribLocation(program, attribute); + if (loc === -1) { + return false; + } + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, buffer); }); + callAndCheck(gl, function () { return gl.vertexAttribPointer(loc, arrayEntriesPerItem, gl.FLOAT, false, itemStrideInBytes, itemOffsetInBytes); }); + callAndCheck(gl, function () { return gl.enableVertexAttribArray(loc); }); + return true; + } + function bindTextureUnit(gl, texture, textureUnit) { + validateTextureUnit(gl, textureUnit); + callAndCheck(gl, function () { return gl.activeTexture(gl.TEXTURE0 + textureUnit); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); + } + function unbindTextureUnit(gl, textureUnit) { + validateTextureUnit(gl, textureUnit); + callAndCheck(gl, function () { return gl.activeTexture(gl.TEXTURE0 + textureUnit); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); + } + function getProgramUniformLocationOrThrow(gl, program, uniformName) { + return throwIfNull(gl, function () { return gl.getUniformLocation(program, uniformName); }, 'uniform "' + uniformName + '" not present in program.'); + } + function getProgramUniformLocation(gl, program, uniformName) { + return gl.getUniformLocation(program, uniformName); + } + function bindTextureToProgramUniformSampler(gl, program, texture, uniformSamplerLocation, textureUnit) { + callAndCheck(gl, function () { return bindTextureUnit(gl, texture, textureUnit); }); + callAndCheck(gl, function () { return gl.uniform1i(uniformSamplerLocation, textureUnit); }); + } + function bindCanvasToFramebuffer(gl) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, null); }); + callAndCheck(gl, function () { return gl.viewport(0, 0, gl.canvas.width, gl.canvas.height); }); + callAndCheck(gl, function () { return gl.scissor(0, 0, gl.canvas.width, gl.canvas.height); }); + } + function bindColorTextureToFramebuffer(gl, texture, framebuffer) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer); }); + callAndCheck(gl, function () { return gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0); }); + } + function unbindColorTextureFromFramebuffer(gl, framebuffer) { + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer); }); + callAndCheck(gl, function () { return gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, null, 0); }); + } + function validateFramebuffer(gl) { + var status = gl.checkFramebufferStatus(gl.FRAMEBUFFER); + if (status !== gl.FRAMEBUFFER_COMPLETE) { + throw new Error('Error binding framebuffer: ' + getFramebufferErrorMessage(gl, status)); + } + } + function getFramebufferErrorMessage(gl, status) { + switch (status) { + case gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT: + return 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT'; + case gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: + return 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT'; + case gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS: + return 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS'; + case gl.FRAMEBUFFER_UNSUPPORTED: + return 'FRAMEBUFFER_UNSUPPORTED'; + default: + return "unknown error " + status; + } + } + function throwIfNull(gl, returnTOrNull, failureMessage) { + var tOrNull = callAndCheck(gl, function () { return returnTOrNull(); }); + if (tOrNull == null) { + throw new Error(failureMessage); + } + return tOrNull; + } + function validateTextureUnit(gl, textureUnit) { + var maxTextureUnit = gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1; + var glTextureUnit = textureUnit + gl.TEXTURE0; + if (glTextureUnit < gl.TEXTURE0 || glTextureUnit > maxTextureUnit) { + var textureUnitRange = "[gl.TEXTURE0, gl.TEXTURE" + maxTextureUnit + "]"; + throw new Error("textureUnit must be in " + textureUnitRange + "."); + } + } + function getTextureShapeFromLogicalShape(gl, logShape) { + if (logShape.length !== 2) { + var squeezeResult = squeezeShape(logShape); + logShape = squeezeResult.newShape; + } + var maxTexSize = queryMaxTextureSize(gl); + var size = sizeFromShape(logShape); + if (logShape.length <= 1 && size <= maxTexSize) { + return [size, 1]; + } + else if (logShape.length === 2 && logShape[0] <= maxTexSize && + logShape[1] <= maxTexSize) { + return logShape; + } + else if (logShape.length === 3 && logShape[0] <= maxTexSize && + logShape[1] * logShape[2] <= maxTexSize) { + return [logShape[0], logShape[1] * logShape[2]]; + } + else if (logShape.length === 4 && logShape[0] <= maxTexSize && + logShape[1] * logShape[2] * logShape[3] <= maxTexSize) { + return [logShape[0], logShape[1] * logShape[2] * logShape[3]]; + } + else { + return sizeToSquarishShape(size); + } + } + + var webgl_util = /*#__PURE__*/Object.freeze({ + createWebGLRenderingContext: createWebGLRenderingContext, + createWebGLRenderingContextFromCanvas: createWebGLRenderingContextFromCanvas, + callAndCheck: callAndCheck, + enableDebugWebGLErrorChecking: enableDebugWebGLErrorChecking, + checkWebGLError: checkWebGLError, + getWebGLErrorMessage: getWebGLErrorMessage, + getExtensionOrThrow: getExtensionOrThrow, + createVertexShader: createVertexShader, + createFragmentShader: createFragmentShader, + createProgram: createProgram, + linkProgram: linkProgram, + validateProgram: validateProgram, + createStaticVertexBuffer: createStaticVertexBuffer, + createStaticIndexBuffer: createStaticIndexBuffer, + queryMaxTextureSize: queryMaxTextureSize, + getNumChannels: getNumChannels, + createTexture: createTexture, + validateTextureSize: validateTextureSize, + createFramebuffer: createFramebuffer, + bindVertexBufferToProgramAttribute: bindVertexBufferToProgramAttribute, + bindTextureUnit: bindTextureUnit, + unbindTextureUnit: unbindTextureUnit, + getProgramUniformLocationOrThrow: getProgramUniformLocationOrThrow, + getProgramUniformLocation: getProgramUniformLocation, + bindTextureToProgramUniformSampler: bindTextureToProgramUniformSampler, + bindCanvasToFramebuffer: bindCanvasToFramebuffer, + bindColorTextureToFramebuffer: bindColorTextureToFramebuffer, + unbindColorTextureFromFramebuffer: unbindColorTextureFromFramebuffer, + validateFramebuffer: validateFramebuffer, + getFramebufferErrorMessage: getFramebufferErrorMessage, + getTextureShapeFromLogicalShape: getTextureShapeFromLogicalShape + }); + + function getWebGLContextAttributes() { + return { + alpha: false, + antialias: false, + premultipliedAlpha: false, + preserveDrawingBuffer: false, + depth: false, + stencil: false, + failIfMajorPerformanceCaveat: true + }; + } + function createWebGLContext(canvas) { + var attributes = getWebGLContextAttributes(); + var gl; + if (canvas != null) { + gl = createWebGLRenderingContextFromCanvas(canvas, attributes); + } + else { + gl = createWebGLRenderingContext(attributes); + } + callAndCheck(gl, function () { return gl.disable(gl.DEPTH_TEST); }); + callAndCheck(gl, function () { return gl.disable(gl.STENCIL_TEST); }); + callAndCheck(gl, function () { return gl.disable(gl.BLEND); }); + callAndCheck(gl, function () { return gl.disable(gl.DITHER); }); + callAndCheck(gl, function () { return gl.disable(gl.POLYGON_OFFSET_FILL); }); + callAndCheck(gl, function () { return gl.disable(gl.SAMPLE_COVERAGE); }); + callAndCheck(gl, function () { return gl.enable(gl.SCISSOR_TEST); }); + callAndCheck(gl, function () { return gl.enable(gl.CULL_FACE); }); + callAndCheck(gl, function () { return gl.cullFace(gl.BACK); }); + return gl; + } + function createVertexShader$1(gl) { + var vertexShaderSource = "\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }"; + return createVertexShader(gl, vertexShaderSource); + } + function createVertexBuffer(gl) { + var vertexArray = new Float32Array([-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]); + return createStaticVertexBuffer(gl, vertexArray); + } + function createIndexBuffer(gl) { + var triangleVertexIndices = new Uint16Array([0, 1, 2, 2, 1, 3]); + return createStaticIndexBuffer(gl, triangleVertexIndices); + } + function getTextureConfig(gl, textureHalfFloatExtension) { + var glany = gl; + var internalFormatFloat; + var internalFormatHalfFloat; + var internalFormatPackedFloat; + var textureFormatFloat; + var downloadTextureFormat; + var downloadUnpackNumChannels; + var defaultNumChannels; + var textureTypeHalfFloat; + if (ENV.get('WEBGL_VERSION') === 2) { + internalFormatFloat = glany.R32F; + internalFormatHalfFloat = glany.R16F; + internalFormatPackedFloat = glany.RGBA32F; + textureFormatFloat = glany.RED; + downloadUnpackNumChannels = 4; + defaultNumChannels = 1; + textureTypeHalfFloat = glany.HALF_FLOAT; + } + else { + internalFormatFloat = gl.RGBA; + internalFormatHalfFloat = gl.RGBA; + internalFormatPackedFloat = glany.RGBA; + textureFormatFloat = gl.RGBA; + downloadUnpackNumChannels = 4; + defaultNumChannels = 4; + textureTypeHalfFloat = textureHalfFloatExtension != null ? + textureHalfFloatExtension.HALF_FLOAT_OES : + null; + } + downloadTextureFormat = gl.RGBA; + return { + internalFormatFloat: internalFormatFloat, + internalFormatHalfFloat: internalFormatHalfFloat, + internalFormatPackedFloat: internalFormatPackedFloat, + textureFormatFloat: textureFormatFloat, + downloadTextureFormat: downloadTextureFormat, + downloadUnpackNumChannels: downloadUnpackNumChannels, + defaultNumChannels: defaultNumChannels, + textureTypeHalfFloat: textureTypeHalfFloat + }; + } + function createAndConfigureTexture(gl, width, height, internalFormat, textureFormat, textureType) { + validateTextureSize(gl, width, height); + var texture = createTexture(gl); + var tex2d = gl.TEXTURE_2D; + callAndCheck(gl, function () { return gl.bindTexture(tex2d, texture); }); + callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE); }); + callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE); }); + callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_MIN_FILTER, gl.NEAREST); }); + callAndCheck(gl, function () { return gl.texParameteri(tex2d, gl.TEXTURE_MAG_FILTER, gl.NEAREST); }); + callAndCheck(gl, function () { return gl.texImage2D(tex2d, 0, internalFormat, width, height, 0, textureFormat, textureType, null); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); + return texture; + } + function createFloat32MatrixTexture(gl, rows, columns, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatFloat, textureConfig.textureFormatFloat, gl.FLOAT); + } + function createFloat16MatrixTexture(gl, rows, columns, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatFloat, textureConfig.textureFormatFloat, textureConfig.textureTypeHalfFloat); + } + function createUnsignedBytesMatrixTexture(gl, rows, columns, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE); + } + function createPackedMatrixTexture(gl, rows, columns, textureConfig) { + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + return createAndConfigureTexture(gl, width, height, textureConfig.internalFormatPackedFloat, gl.RGBA, gl.FLOAT); + } + function bindVertexProgramAttributeStreams(gl, program, vertexBuffer) { + var posOffset = 0; + var uvOffset = 3 * 4; + var stride = (3 * 4) + (2 * 4); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer); }); + var success = bindVertexBufferToProgramAttribute(gl, program, 'clipSpacePos', vertexBuffer, 3, stride, posOffset); + return success && + bindVertexBufferToProgramAttribute(gl, program, 'uv', vertexBuffer, 2, stride, uvOffset); + } + function uploadPixelDataToTexture(gl, texture, pixels) { + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); + callAndCheck(gl, function () { return gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, pixels); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); + } + function uploadDataToTexture(gl, texture, width, height, data, textureFormat) { + validateTextureSize(gl, width, height); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, texture); }); + callAndCheck(gl, function () { return gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, width, height, textureFormat, gl.FLOAT, data); }); + callAndCheck(gl, function () { return gl.bindTexture(gl.TEXTURE_2D, null); }); + } + function uploadMatrixToTexture(gl, texture, rows, columns, matrix, numChannels, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var unpackedArray; + if (textureConfig.defaultNumChannels === 1) { + unpackedArray = matrix; + } + else { + unpackedArray = + new Float32Array(getUnpackedArraySizeFromMatrixSize(matrix.length, numChannels)); + encodeMatrixToUnpackedArray(matrix, unpackedArray, numChannels); + } + uploadDataToTexture(gl, texture, w, h, unpackedArray, textureConfig.textureFormatFloat); + } + function uploadMatrixToPackedTexture(gl, texture, rows, columns, matrix, textureConfig) { + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var packedRGBA = new Float32Array(getPackedRGBAArraySizeFromMatrixShape(rows, columns)); + encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA); + uploadDataToTexture(gl, texture, w, h, packedRGBA, gl.RGBA); + } + function maybeCreateBufferFromOutputTexture(gl, texture, rows, columns, textureConfig) { + var bufferOrTexture = texture; + if (ENV.get('WEBGL_VERSION') === 2) { + var gl2_1 = gl; + var buffer_1 = gl2_1.createBuffer(); + callAndCheck(gl, function () { return gl.bindBuffer(gl2_1.PIXEL_PACK_BUFFER, buffer_1); }); + var bytesPerFloat = 4; + var bufferSizeBytes_1 = bytesPerFloat * + getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels); + callAndCheck(gl, function () { return gl.bufferData(gl2_1.PIXEL_PACK_BUFFER, bufferSizeBytes_1, gl.STATIC_DRAW); }); + callAndCheck(gl, function () { return gl2_1.readPixels(0, 0, columns, rows, gl.RGBA, gl.FLOAT, 0); }); + callAndCheck(gl, function () { return gl.bindBuffer(gl2_1.PIXEL_PACK_BUFFER, null); }); + bufferOrTexture = buffer_1; + } + return bufferOrTexture; + } + function downloadFloat32MatrixFromBuffer(gl, buffer, rows, columns, textureConfig) { + var gl2 = gl; + var downloadTarget = new Float32Array(getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels)); + gl2.bindBuffer(gl.ARRAY_BUFFER, buffer); + gl2.getBufferSubData(gl.ARRAY_BUFFER, 0, downloadTarget); + gl2.bindBuffer(gl.ARRAY_BUFFER, null); + var matrix = new Float32Array(rows * columns); + decodeMatrixFromUnpackedArray(downloadTarget, matrix, textureConfig.downloadUnpackNumChannels); + return matrix; + } + function downloadFloat32MatrixFromOutputTexture(gl, rows, columns, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var downloadTarget = new Float32Array(getUnpackedArraySizeFromMatrixSize(rows * columns, textureConfig.downloadUnpackNumChannels)); + callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, textureConfig.downloadTextureFormat, gl.FLOAT, downloadTarget); }); + var matrix = new Float32Array(rows * columns); + decodeMatrixFromUnpackedArray(downloadTarget, matrix, textureConfig.downloadUnpackNumChannels); + return matrix; + } + function downloadByteEncodedFloatMatrixFromOutputTexture(gl, rows, columns, textureConfig) { + var _a = getUnpackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var numChannels = 4; + var downloadTarget = new Uint8Array(getUnpackedArraySizeFromMatrixSize(rows * columns, numChannels)); + callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, textureConfig.downloadTextureFormat, gl.UNSIGNED_BYTE, downloadTarget); }); + return new Float32Array(downloadTarget.buffer); + } + function downloadMatrixFromPackedOutputTexture(gl, rows, columns, textureConfig) { + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), w = _a[0], h = _a[1]; + var packedRGBA = new Float32Array(getPackedRGBAArraySizeFromMatrixShape(rows, columns)); + callAndCheck(gl, function () { return gl.readPixels(0, 0, w, h, gl.RGBA, gl.FLOAT, packedRGBA); }); + var matrix = new Float32Array(rows * columns); + return decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix); + } + + var gpgpu_util = /*#__PURE__*/Object.freeze({ + getWebGLContextAttributes: getWebGLContextAttributes, + createWebGLContext: createWebGLContext, + createVertexShader: createVertexShader$1, + createVertexBuffer: createVertexBuffer, + createIndexBuffer: createIndexBuffer, + getTextureConfig: getTextureConfig, + createFloat32MatrixTexture: createFloat32MatrixTexture, + createFloat16MatrixTexture: createFloat16MatrixTexture, + createUnsignedBytesMatrixTexture: createUnsignedBytesMatrixTexture, + createPackedMatrixTexture: createPackedMatrixTexture, + bindVertexProgramAttributeStreams: bindVertexProgramAttributeStreams, + uploadPixelDataToTexture: uploadPixelDataToTexture, + uploadMatrixToTexture: uploadMatrixToTexture, + uploadMatrixToPackedTexture: uploadMatrixToPackedTexture, + maybeCreateBufferFromOutputTexture: maybeCreateBufferFromOutputTexture, + downloadFloat32MatrixFromBuffer: downloadFloat32MatrixFromBuffer, + downloadFloat32MatrixFromOutputTexture: downloadFloat32MatrixFromOutputTexture, + downloadByteEncodedFloatMatrixFromOutputTexture: downloadByteEncodedFloatMatrixFromOutputTexture, + downloadMatrixFromPackedOutputTexture: downloadMatrixFromPackedOutputTexture + }); + + var GPGPUContext = (function () { + function GPGPUContext(gl) { + this.outputTexture = null; + this.program = null; + this.disposed = false; + this.autoDebugValidate = false; + this.vertexAttrsAreBound = false; + this.itemsToPoll = []; + if (gl != null) { + this.gl = gl; + } + else { + this.gl = createWebGLContext(); + } + if (ENV.get('WEBGL_VERSION') === 1) { + this.textureFloatExtension = + getExtensionOrThrow(this.gl, 'OES_texture_float'); + this.colorBufferFloatExtension = + this.gl.getExtension('WEBGL_color_buffer_float'); + if (!ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + this.textureHalfFloatExtension = + getExtensionOrThrow(this.gl, 'OES_texture_half_float'); + this.colorBufferHalfFloatExtension = + this.gl.getExtension('EXT_color_buffer_half_float'); + } + } + else { + this.colorBufferFloatExtension = + getExtensionOrThrow(this.gl, 'EXT_color_buffer_float'); + } + this.loseContextExtension = + getExtensionOrThrow(this.gl, 'WEBGL_lose_context'); + this.vertexBuffer = createVertexBuffer(this.gl); + this.indexBuffer = createIndexBuffer(this.gl); + this.framebuffer = createFramebuffer(this.gl); + this.textureConfig = + getTextureConfig(this.gl, this.textureHalfFloatExtension); + } + GPGPUContext.prototype.dispose = function () { + var _this = this; + if (this.disposed) { + return; + } + if (this.program != null) { + console.warn('Disposing a GPGPUContext that still has a bound WebGLProgram.' + + ' This is probably a resource leak, delete the program with ' + + 'GPGPUContext.deleteProgram before disposing.'); + } + if (this.outputTexture != null) { + console.warn('Disposing a GPGPUContext that still has a bound output matrix ' + + 'texture. This is probably a resource leak, delete the output ' + + 'matrix texture with GPGPUContext.deleteMatrixTexture before ' + + 'disposing.'); + } + var gl = this.gl; + callAndCheck(gl, function () { return gl.finish(); }); + callAndCheck(gl, function () { return gl.bindFramebuffer(gl.FRAMEBUFFER, null); }); + callAndCheck(gl, function () { return gl.deleteFramebuffer(_this.framebuffer); }); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ARRAY_BUFFER, null); }); + callAndCheck(gl, function () { return gl.deleteBuffer(_this.vertexBuffer); }); + callAndCheck(gl, function () { return gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null); }); + callAndCheck(gl, function () { return gl.deleteBuffer(_this.indexBuffer); }); + this.loseContextExtension.loseContext(); + this.disposed = true; + }; + GPGPUContext.prototype.enableAutomaticDebugValidation = function (enabled) { + this.autoDebugValidate = enabled; + enableDebugWebGLErrorChecking(enabled); + }; + GPGPUContext.prototype.createFloat32MatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return createFloat32MatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.createFloat16MatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return createFloat16MatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.createUnsignedBytesMatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return createUnsignedBytesMatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.uploadPixelDataToTexture = function (texture, pixels) { + this.throwIfDisposed(); + uploadPixelDataToTexture(this.gl, texture, pixels); + }; + GPGPUContext.prototype.createPackedMatrixTexture = function (rows, columns) { + this.throwIfDisposed(); + return createPackedMatrixTexture(this.gl, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.deleteMatrixTexture = function (texture) { + var _this = this; + this.throwIfDisposed(); + if (this.outputTexture === texture) { + unbindColorTextureFromFramebuffer(this.gl, this.framebuffer); + this.outputTexture = null; + } + callAndCheck(this.gl, function () { return _this.gl.deleteTexture(texture); }); + }; + GPGPUContext.prototype.uploadMatrixToTexture = function (texture, rows, columns, matrix) { + this.throwIfDisposed(); + var numChannels = getNumChannels(); + return uploadMatrixToTexture(this.gl, texture, rows, columns, matrix, numChannels, this.textureConfig); + }; + GPGPUContext.prototype.uploadMatrixToPackedTexture = function (texture, rows, columns, matrix) { + this.throwIfDisposed(); + return uploadMatrixToPackedTexture(this.gl, texture, rows, columns, matrix, this.textureConfig); + }; + GPGPUContext.prototype.downloadFloat32MatrixFromOutputTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return downloadFloat32MatrixFromOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.downloadByteEncodedFloatMatrixFromOutputTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return downloadByteEncodedFloatMatrixFromOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.downloadFloat32MatrixFromBuffer = function (buffer, rows, columns) { + return downloadFloat32MatrixFromBuffer(this.gl, buffer, rows, columns, this.textureConfig); + }; + GPGPUContext.prototype.maybeCreateBufferFromTexture = function (texture, rows, columns) { + this.bindTextureToFrameBuffer(texture); + var result = maybeCreateBufferFromOutputTexture(this.gl, texture, rows, columns, this.textureConfig); + this.unbindTextureToFrameBuffer(); + return result; + }; + GPGPUContext.prototype.createAndWaitForFence = function () { + var fenceContext = this.createFence(this.gl); + return this.pollFence(fenceContext); + }; + GPGPUContext.prototype.createFence = function (gl) { + var _this = this; + var query; + var isFencePassed; + if (ENV.get('WEBGL_FENCE_API_ENABLED')) { + var gl2_1 = gl; + var sync_1 = gl2_1.fenceSync(gl2_1.SYNC_GPU_COMMANDS_COMPLETE, 0); + gl.flush(); + isFencePassed = function () { + var status = gl2_1.clientWaitSync(sync_1, 0, 0); + return status === gl2_1.ALREADY_SIGNALED || + status === gl2_1.CONDITION_SATISFIED; + }; + query = sync_1; + } + else if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + query = this.beginQuery(); + this.endQuery(); + isFencePassed = function () { return _this.isQueryAvailable(query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')); }; + } + else { + isFencePassed = function () { return true; }; + } + return { query: query, isFencePassed: isFencePassed }; + }; + GPGPUContext.prototype.downloadMatrixFromPackedTexture = function (texture, rows, columns) { + var _this = this; + return this.downloadMatrixDriver(texture, function () { return downloadMatrixFromPackedOutputTexture(_this.gl, rows, columns, _this.textureConfig); }); + }; + GPGPUContext.prototype.createProgram = function (fragmentShaderSource) { + this.throwIfDisposed(); + var gl = this.gl; + var fragmentShader = createFragmentShader(gl, fragmentShaderSource); + var vertexShader = createVertexShader$1(gl); + var program = createProgram(gl); + callAndCheck(gl, function () { return gl.attachShader(program, vertexShader); }); + callAndCheck(gl, function () { return gl.attachShader(program, fragmentShader); }); + linkProgram(gl, program); + if (this.autoDebugValidate) { + validateProgram(gl, program); + } + if (!this.vertexAttrsAreBound) { + this.setProgram(program); + this.vertexAttrsAreBound = bindVertexProgramAttributeStreams(gl, this.program, this.vertexBuffer); + } + return program; + }; + GPGPUContext.prototype.deleteProgram = function (program) { + var _this = this; + this.throwIfDisposed(); + if (program === this.program) { + this.program = null; + } + if (program != null) { + callAndCheck(this.gl, function () { return _this.gl.deleteProgram(program); }); + } + }; + GPGPUContext.prototype.setProgram = function (program) { + var _this = this; + this.throwIfDisposed(); + this.program = program; + if ((this.program != null) && this.autoDebugValidate) { + validateProgram(this.gl, this.program); + } + callAndCheck(this.gl, function () { return _this.gl.useProgram(program); }); + }; + GPGPUContext.prototype.getUniformLocation = function (program, uniformName, shouldThrow) { + if (shouldThrow === void 0) { shouldThrow = true; } + this.throwIfDisposed(); + if (shouldThrow) { + return getProgramUniformLocationOrThrow(this.gl, program, uniformName); + } + else { + return getProgramUniformLocation(this.gl, program, uniformName); + } + }; + GPGPUContext.prototype.getAttributeLocation = function (program, attribute) { + var _this = this; + this.throwIfDisposed(); + return callAndCheck(this.gl, function () { return _this.gl.getAttribLocation(program, attribute); }); + }; + GPGPUContext.prototype.getUniformLocationNoThrow = function (program, uniformName) { + this.throwIfDisposed(); + return this.gl.getUniformLocation(program, uniformName); + }; + GPGPUContext.prototype.setInputMatrixTexture = function (inputMatrixTexture, uniformLocation, textureUnit) { + this.throwIfDisposed(); + this.throwIfNoProgram(); + bindTextureToProgramUniformSampler(this.gl, this.program, inputMatrixTexture, uniformLocation, textureUnit); + }; + GPGPUContext.prototype.setOutputMatrixTexture = function (outputMatrixTexture, rows, columns) { + this.setOutputMatrixTextureDriver(outputMatrixTexture, columns, rows); + }; + GPGPUContext.prototype.setOutputPackedMatrixTexture = function (outputPackedMatrixTexture, rows, columns) { + this.throwIfDisposed(); + var _a = getPackedMatrixTextureShapeWidthHeight(rows, columns), width = _a[0], height = _a[1]; + this.setOutputMatrixTextureDriver(outputPackedMatrixTexture, width, height); + }; + GPGPUContext.prototype.setOutputMatrixWriteRegion = function (startRow, numRows, startColumn, numColumns) { + this.setOutputMatrixWriteRegionDriver(startColumn, startRow, numColumns, numRows); + }; + GPGPUContext.prototype.setOutputPackedMatrixWriteRegion = function (startRow, numRows, startColumn, numColumns) { + throw new Error('setOutputPackedMatrixWriteRegion not implemented.'); + }; + GPGPUContext.prototype.debugValidate = function () { + if (this.program != null) { + validateProgram(this.gl, this.program); + } + validateFramebuffer(this.gl); + }; + GPGPUContext.prototype.executeProgram = function () { + this.throwIfDisposed(); + this.throwIfNoProgram(); + var gl = this.gl; + if (this.autoDebugValidate) { + this.debugValidate(); + } + callAndCheck(gl, function () { return gl.drawElements(gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0); }); + }; + GPGPUContext.prototype.blockUntilAllProgramsCompleted = function () { + var _this = this; + this.throwIfDisposed(); + callAndCheck(this.gl, function () { return _this.gl.finish(); }); + }; + GPGPUContext.prototype.getQueryTimerExtension = function () { + if (this.disjointQueryTimerExtension == null) { + this.disjointQueryTimerExtension = + getExtensionOrThrow(this.gl, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2 ? + 'EXT_disjoint_timer_query_webgl2' : + 'EXT_disjoint_timer_query'); + } + return this.disjointQueryTimerExtension; + }; + GPGPUContext.prototype.getQueryTimerExtensionWebGL2 = function () { + return this.getQueryTimerExtension(); + }; + GPGPUContext.prototype.getQueryTimerExtensionWebGL1 = function () { + return this.getQueryTimerExtension(); + }; + GPGPUContext.prototype.beginQuery = function () { + if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) { + var gl2 = this.gl; + var ext_1 = this.getQueryTimerExtensionWebGL2(); + var query_1 = gl2.createQuery(); + gl2.beginQuery(ext_1.TIME_ELAPSED_EXT, query_1); + return query_1; + } + var ext = this.getQueryTimerExtensionWebGL1(); + var query = ext.createQueryEXT(); + ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, query); + return query; + }; + GPGPUContext.prototype.endQuery = function () { + if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) { + var gl2 = this.gl; + var ext_2 = this.getQueryTimerExtensionWebGL2(); + gl2.endQuery(ext_2.TIME_ELAPSED_EXT); + return; + } + var ext = this.getQueryTimerExtensionWebGL1(); + ext.endQueryEXT(ext.TIME_ELAPSED_EXT); + }; + GPGPUContext.prototype.waitForQueryAndGetTime = function (query) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, repeatedTry(function () { return _this.isQueryAvailable(query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')); })]; + case 1: + _a.sent(); + return [2, this.getQueryTime(query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'))]; + } + }); + }); + }; + GPGPUContext.prototype.getQueryTime = function (query, queryTimerVersion) { + if (queryTimerVersion === 0) { + return null; + } + if (queryTimerVersion === 2) { + var gl2 = this.gl; + var timeElapsedNanos = gl2.getQueryParameter(query, gl2.QUERY_RESULT); + return timeElapsedNanos / 1000000; + } + else { + var ext = this.getQueryTimerExtensionWebGL1(); + var timeElapsedNanos = ext.getQueryObjectEXT(query, ext.QUERY_RESULT_EXT); + return timeElapsedNanos / 1000000; + } + }; + GPGPUContext.prototype.isQueryAvailable = function (query, queryTimerVersion) { + if (queryTimerVersion === 0) { + return true; + } + if (queryTimerVersion === 2) { + var gl2 = this.gl; + var ext = this.getQueryTimerExtensionWebGL2(); + var available = gl2.getQueryParameter(query, gl2.QUERY_RESULT_AVAILABLE); + if (this.disjoint == null) { + this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT); + } + return available && !this.disjoint; + } + else { + var ext = this.getQueryTimerExtensionWebGL1(); + var available = ext.getQueryObjectEXT(query, ext.QUERY_RESULT_AVAILABLE_EXT); + if (this.disjoint == null) { + this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT); + } + return available && !this.disjoint; + } + }; + GPGPUContext.prototype.pollFence = function (fenceContext) { + var _this = this; + return new Promise(function (resolve) { + _this.addItemToPoll(function () { return fenceContext.isFencePassed(); }, function () { return resolve(); }); + }); + }; + GPGPUContext.prototype.pollItems = function () { + var index = binSearchLastTrue(this.itemsToPoll.map(function (x) { return x.isDoneFn; })); + for (var i = 0; i <= index; ++i) { + var resolveFn = this.itemsToPoll[i].resolveFn; + resolveFn(); + } + this.itemsToPoll = this.itemsToPoll.slice(index + 1); + }; + GPGPUContext.prototype.addItemToPoll = function (isDoneFn, resolveFn) { + var _this = this; + this.itemsToPoll.push({ isDoneFn: isDoneFn, resolveFn: resolveFn }); + if (this.itemsToPoll.length > 1) { + return; + } + repeatedTry(function () { + _this.pollItems(); + return _this.itemsToPoll.length === 0; + }); + }; + GPGPUContext.prototype.bindTextureToFrameBuffer = function (texture) { + this.throwIfDisposed(); + bindColorTextureToFramebuffer(this.gl, texture, this.framebuffer); + if (this.autoDebugValidate) { + validateFramebuffer(this.gl); + } + }; + GPGPUContext.prototype.unbindTextureToFrameBuffer = function () { + if (this.outputTexture != null) { + bindColorTextureToFramebuffer(this.gl, this.outputTexture, this.framebuffer); + if (this.autoDebugValidate) { + validateFramebuffer(this.gl); + } + } + else { + unbindColorTextureFromFramebuffer(this.gl, this.framebuffer); + } + }; + GPGPUContext.prototype.downloadMatrixDriver = function (texture, downloadAndDecode) { + this.bindTextureToFrameBuffer(texture); + var result = downloadAndDecode(); + this.unbindTextureToFrameBuffer(); + return result; + }; + GPGPUContext.prototype.setOutputMatrixTextureDriver = function (outputMatrixTextureMaybePacked, width, height) { + this.throwIfDisposed(); + var gl = this.gl; + bindColorTextureToFramebuffer(gl, outputMatrixTextureMaybePacked, this.framebuffer); + if (this.autoDebugValidate) { + validateFramebuffer(gl); + } + this.outputTexture = outputMatrixTextureMaybePacked; + callAndCheck(gl, function () { return gl.viewport(0, 0, width, height); }); + callAndCheck(gl, function () { return gl.scissor(0, 0, width, height); }); + }; + GPGPUContext.prototype.setOutputMatrixWriteRegionDriver = function (x, y, width, height) { + var _this = this; + this.throwIfDisposed(); + callAndCheck(this.gl, function () { return _this.gl.scissor(x, y, width, height); }); + }; + GPGPUContext.prototype.throwIfDisposed = function () { + if (this.disposed) { + throw new Error('Attempted to use disposed GPGPUContext.'); + } + }; + GPGPUContext.prototype.throwIfNoProgram = function () { + if (this.program == null) { + throw new Error('No GPU program is currently set.'); + } + }; + return GPGPUContext; + }()); + function binSearchLastTrue(arr) { + var start = 0; + var end = arr.length - 1; + var best = -1; + while (start <= end) { + var mid = (start + end) >> 1; + var isDone = arr[mid](); + if (isDone) { + best = mid; + start = mid + 1; + } + else { + end = mid - 1; + } + } + return best; + } + + function compileProgram(gpgpu, program, inputs, output) { + var userCode = program.userCode; + var inputInfos = inputs.map(function (input, i) { + var shapeInfo = { + logicalShape: input.tensor.shape, + texShape: input.isUniform ? null : input.texData.texShape, + isUniform: input.isUniform + }; + return { name: program.variableNames[i], shapeInfo: shapeInfo }; + }); + var inShapeInfos = inputInfos.map(function (x) { return x.shapeInfo; }); + var outShapeInfo = { + logicalShape: output.tensor.shape, + texShape: output.texData.texShape, + isUniform: false + }; + var source = makeShader(inputInfos, outShapeInfo, userCode, program.supportsBroadcasting === true); + var webGLProgram = gpgpu.createProgram(source); + var uniformLocations = {}; + for (var i = 0; i < program.variableNames.length; i++) { + var uniformName = program.variableNames[i]; + var shouldThrow = false; + uniformLocations[uniformName] = + gpgpu.getUniformLocation(webGLProgram, uniformName, shouldThrow); + } + return { + program: program, + source: source, + webGLProgram: webGLProgram, + uniformLocations: uniformLocations, + gpgpu: gpgpu, + inShapeInfos: inShapeInfos, + outShapeInfo: outShapeInfo + }; + } + function validateBinaryAndProgram(shapeInfos, inputs) { + if (shapeInfos.length !== inputs.length) { + throw Error("Binary was compiled with " + shapeInfos.length + " inputs, but " + + ("was executed with " + inputs.length + " inputs")); + } + shapeInfos.forEach(function (s, i) { + var shapeA = s.logicalShape; + var input = inputs[i]; + var shapeB = input.tensor.shape; + if (!arraysEqual(shapeA, shapeB)) { + throw Error("Binary was compiled with different shapes than " + + ("the current args. Shapes " + shapeA + " and " + shapeB + " must match")); + } + if (s.isUniform && input.isUniform) { + return; + } + var texShapeA = s.texShape; + var texShapeB = input.isUniform ? null : input.texData.texShape; + if (!arraysEqual(texShapeA, texShapeB)) { + throw Error("Binary was compiled with different texture shapes than the" + + (" current args. Shape " + texShapeA + " and " + texShapeB + " must match")); + } + }); + } + function runProgram(binary, inputs, output, customSetup) { + validateBinaryAndProgram(binary.inShapeInfos, inputs); + validateBinaryAndProgram([binary.outShapeInfo], [output]); + var outTex = output.texData.texture; + var outTexShape = output.texData.texShape; + var gpgpu = binary.gpgpu; + gpgpu.setOutputMatrixTexture(outTex, outTexShape[0], outTexShape[1]); + gpgpu.setProgram(binary.webGLProgram); + inputs.forEach(function (input, i) { + var variableName = binary.program.variableNames[i]; + var variableUniformLocation = binary.uniformLocations[variableName]; + if (variableUniformLocation != null) { + if (input.isUniform) { + if (input.tensor.size === 1) { + gpgpu.gl.uniform1f(variableUniformLocation, input.tensor.dataSync()[0]); + } + else { + var vals = input.tensor.dataSync(); + if (!(vals instanceof Float32Array)) { + vals = new Float32Array(vals); + } + gpgpu.gl.uniform1fv(variableUniformLocation, vals); + } + return; + } + var tex = input.texData.texture; + gpgpu.setInputMatrixTexture(tex, variableUniformLocation, i); + } + }); + if (customSetup != null) { + customSetup(gpgpu, binary.webGLProgram); + } + gpgpu.executeProgram(); + } + function makeShaderKey(program, inputs, output) { + var keyInputs = ''; + inputs.concat(output).forEach(function (x) { + keyInputs += + x.tensor.shape + "_" + (x.isUniform ? 'uniform' : x.texData.texShape); + }); + var keyUserCode = program.userCode; + var keyBroadcast = (program.supportsBroadcasting === true).toString(); + var key = program.constructor.name; + key += '_' + keyBroadcast + '_' + keyInputs + '_' + keyUserCode; + return key; + } + + var LRNProgram = (function () { + function LRNProgram(xShape, radius, bias, alpha, beta) { + this.variableNames = ['x']; + this.outputShape = []; + var rad = radius; + var maxD = xShape[3] - 1; + this.outputShape = xShape; + var powOperator; + var basis = "float(" + bias + ") + float(" + alpha + ") * sum"; + if (beta === 0.5) { + powOperator = "inversesqrt(" + basis + ")"; + } + else if (beta === 1.0) { + powOperator = "1.0/(" + basis + ")"; + } + else { + powOperator = "exp(log(" + basis + ") * float(-" + beta + "));"; + } + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -" + rad + "; j <= " + rad + "; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= " + maxD + ") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * " + powOperator + ";\n setOutput(val);\n }\n "; + } + return LRNProgram; + }()); + + var LRNGradProgram = (function () { + function LRNGradProgram(inputShape, depthRadius, bias, alpha, beta) { + this.variableNames = ['inputImage', 'outputImage', 'dy']; + this.outputShape = []; + this.outputShape = inputShape; + this.depth = inputShape[3]; + this.depthRadius = depthRadius; + this.bias = bias; + this.alpha = alpha; + this.beta = beta; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < " + this.depth + "; ++d) {\n int depthBegin = int(max(0.0, float(d - " + depthRadius + ")));\n int depthEnd = int(min(float(" + this.depth + "),\n float(d + " + depthRadius + " + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = " + this.depth + ";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(" + alpha + ") * norm + float(" + bias + ");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(" + alpha + ")\n * float(" + beta + ")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * " + beta + ");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "; + } + return LRNGradProgram; + }()); + + var MaxPool2DBackpropProgram = (function () { + function MaxPool2DBackpropProgram(convInfo) { + this.variableNames = ['dy', 'maxPos']; + this.outputShape = convInfo.inShape; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var lastIndex = filterHeight * filterWidth - 1; + this.userCode = "\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + strideHeight + ".0;\n\n if (dyR < 0.0 || dyR >= " + convInfo.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + strideWidth + ".0;\n\n if (dyC < 0.0 || dyC >= " + convInfo.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = " + lastIndex + " - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * " + filterWidth + " + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "; + } + return MaxPool2DBackpropProgram; + }()); + + var MatMulProgram = (function () { + function MatMulProgram(aShape, bShape, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + this.variableNames = ['matrixA', 'matrixB']; + var outerShapeA = transposeA ? aShape[1] : aShape[0]; + var outerShapeB = transposeB ? bShape[0] : bShape[1]; + var sharedDim = transposeA ? aShape[0] : aShape[1]; + this.outputShape = [outerShapeA, outerShapeB]; + var aSnippetFromOffset = function (vec4Offset, indexVar) { + return transposeA ? indexVar + " + " + vec4Offset + ", aRow" : + "aRow, " + indexVar + " + " + vec4Offset; + }; + var bSnippetFromOffset = function (vec4Offset, indexVar) { + return transposeB ? "bCol, " + indexVar + " + " + vec4Offset : + indexVar + " + " + vec4Offset + ", bCol"; + }; + var sharedDimNearestVec4 = Math.floor(sharedDim / 4) * 4; + var sharedDimVec4Remainder = sharedDim % 4; + this.userCode = " float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < " + sharedDimNearestVec4 + "; i += 4) {\n vec4 a = vec4(\n getMatrixA(" + aSnippetFromOffset(0, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(1, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(2, 'i') + "),\n getMatrixA(" + aSnippetFromOffset(3, 'i') + ")\n );\n vec4 b = vec4(\n getMatrixB(" + bSnippetFromOffset(0, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(1, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(2, 'i') + "),\n getMatrixB(" + bSnippetFromOffset(3, 'i') + ")\n );\n\n result += dot(a, b);\n }\n\n if (" + (sharedDimVec4Remainder === 1) + ") {\n result += getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + ") *\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + ");\n } else if (" + (sharedDimVec4Remainder === 2) + ") {\n vec2 a = vec2(\n getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(1, sharedDimNearestVec4) + ")\n );\n vec2 b = vec2(\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(1, sharedDimNearestVec4) + ")\n );\n result += dot(a, b);\n } else if (" + (sharedDimVec4Remainder === 3) + ") {\n vec3 a = vec3(\n getMatrixA(" + aSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(1, sharedDimNearestVec4) + "),\n getMatrixA(" + aSnippetFromOffset(2, sharedDimNearestVec4) + ")\n );\n vec3 b = vec3(\n getMatrixB(" + bSnippetFromOffset(0, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(1, sharedDimNearestVec4) + "),\n getMatrixB(" + bSnippetFromOffset(2, sharedDimNearestVec4) + ")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "; + } + return MatMulProgram; + }()); + + var MultinomialProgram = (function () { + function MultinomialProgram(batchSize, numOutcomes, numSamples) { + this.variableNames = ['probs']; + this.outputShape = [batchSize, numSamples]; + this.userCode = "\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < " + (numOutcomes - 1) + "; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(" + (numOutcomes - 1) + "));\n }\n "; + } + MultinomialProgram.prototype.getCustomSetupFunc = function (seed) { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.seedLoc == null) { + _this.seedLoc = gpgpu.getUniformLocation(webGLProgram, 'seed'); + } + gpgpu.gl.uniform1f(_this.seedLoc, seed); + }; + }; + return MultinomialProgram; + }()); + + var OneHotProgram = (function () { + function OneHotProgram(numIndices, depth, onValue, offValue) { + this.variableNames = ['indices']; + this.outputShape = [numIndices, depth]; + this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(" + offValue + "), float(" + onValue + "),\n float(index == coords.y)));\n }\n "; + } + return OneHotProgram; + }()); + + var PadProgram = (function () { + function PadProgram(xShape, paddings, constantValue) { + this.variableNames = ['x']; + this.outputShape = paddings.map(function (p, i) { return p[0] + xShape[i] + p[1]; }); + var rank = xShape.length; + var type = getCoordsDataType(rank); + var start = paddings.map(function (p) { return p[0]; }).join(','); + var end = paddings.map(function (p, i) { return p[0] + xShape[i]; }).join(','); + var unpackedCoords = ['coords[0]', 'coords[1]', 'coords[2]', 'coords[3]'].slice(0, rank); + if (rank === 1) { + this.userCode = "\n int start = " + start + ";\n int end = " + end + ";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(" + constantValue + "));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "; + return; + } + this.userCode = "\n " + type + " start = " + type + "(" + start + ");\n " + type + " end = " + type + "(" + end + ");\n\n void main() {\n " + type + " outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(" + constantValue + "));\n } else {\n " + type + " coords = outC - start;\n setOutput(getX(" + unpackedCoords + "));\n }\n }\n "; + } + return PadProgram; + }()); + + var Pool2DProgram = (function () { + function Pool2DProgram(convInfo, poolType, computePositions) { + this.variableNames = ['x']; + if (poolType === 'avg' && computePositions) { + throw new Error('Cannot compute positions for average pool.'); + } + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + this.outputShape = convInfo.outShape; + var isAvgPool = poolType === 'avg'; + var initializationValue = '0.0'; + if (!isAvgPool) { + initializationValue = '-1.0 / 0.0'; + } + if (computePositions) { + var compareOp_1 = '>='; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidth + "; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value " + compareOp_1 + " currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * " + filterWidth + " + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n "; + return; + } + var compareOp = 'max'; + var returnValue = poolType + "(" + poolType + "(" + poolType + "(" + + 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])'; + if (poolType === 'avg') { + returnValue = "avgValue / count"; + } + var filterWidthNearestVec4 = Math.floor(filterWidth / 4) * 4; + var filterWidthVec4Remainder = filterWidth % 4; + var updateSnippet = "\n if (" + isAvgPool + ") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = " + compareOp + "(values, minMaxValue);\n }\n "; + this.userCode = "\n const ivec2 strides = ivec2(" + strideHeight + ", " + strideWidth + ");\n const ivec2 pads = ivec2(" + padTop + ", " + padLeft + ");\n const float initializationValue = " + initializationValue + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= " + convInfo.inWidth + ") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(" + initializationValue + ");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < " + filterHeight + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + convInfo.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + filterWidthNearestVec4 + "; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n " + updateSnippet + "\n }\n\n int xC = xCCorner + " + filterWidthNearestVec4 + ";\n if (" + (filterWidthVec4Remainder === 1) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (filterWidthVec4Remainder === 2) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (filterWidthVec4Remainder === 3) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n " + updateSnippet + "\n }\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return Pool2DProgram; + }()); + + var ReduceProgram = (function () { + function ReduceProgram(reduceInfo, reduceType) { + this.variableNames = ['x']; + var windowSize = reduceInfo.windowSize; + var batchSize = reduceInfo.batchSize; + var inSize = reduceInfo.inSize; + var outSize = Math.ceil(inSize / windowSize); + this.outputShape = [batchSize, outSize]; + var initializationValue = '0.0'; + var compareOp = ""; + if (reduceType === 'min') { + initializationValue = '1.0 / 0.0'; + compareOp = "min"; + } + else if (reduceType === 'max') { + initializationValue = '-1.0 / 0.0'; + compareOp = "max"; + } + var returnValue = reduceType + "(" + reduceType + "(" + reduceType + "(" + + 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])'; + if (reduceType === 'sum') { + returnValue = "sumValue"; + } + else if (reduceType === 'all') { + returnValue = "allValue"; + } + else if (reduceType === 'any') { + returnValue = "anyValue"; + } + var windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4; + var windowSizeVec4Remainder = windowSize % 4; + var updateSnippet = "\n if (" + (reduceType === 'sum') + ") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = " + compareOp + "(values, minMaxValue);\n }\n "; + var vecType = "vec4"; + if (reduceType === 'all') { + initializationValue = '1.0'; + updateSnippet = "\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n "; + vecType = "bvec4"; + } + else if (reduceType === 'any') { + initializationValue = '0.0'; + updateSnippet = "\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n "; + vecType = "bvec4"; + } + var checkOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return initializationValue;\n }\n "; + } + this.userCode = "\n const float initializationValue = " + initializationValue + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n " + checkOutOfBounds + "\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + windowSize + ";\n\n vec4 minMaxValue = vec4(" + initializationValue + ");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < " + windowSizeNearestVec4 + "; i += 4) {\n int inIdx = inOffset + i;\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n " + updateSnippet + "\n }\n\n int inIdx = inOffset + " + windowSizeNearestVec4 + ";\n if (" + (windowSizeVec4Remainder === 1) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 2) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 3) + ") {\n " + vecType + " values = " + vecType + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n " + updateSnippet + "\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return ReduceProgram; + }()); + + var ResizeBilinearBackpropProgram = (function () { + function ResizeBilinearBackpropProgram(dy, x, alignCorners) { + this.variableNames = ['dy']; + this.outputShape = []; + this.outputShape = x.shape; + var _a = x.shape, xHeight = _a[1], xWidth = _a[2]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + heightScale + ");\n const float widthScale = float(" + widthScale + ");\n\n const float invHeightScale = float(" + invHeightScale + ");\n const float invWidthScale = float(" + invWidthScale + ");\n\n const int winHeight = int(" + winHeight + ");\n const int winWidth = int(" + winWidth + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + yHeight + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + yWidth + ") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), " + (xHeight - 1) + ".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), " + (xWidth - 1) + ".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + } + return ResizeBilinearBackpropProgram; + }()); + + var ResizeBilinearProgram = (function () { + function ResizeBilinearProgram(inputShape, newHeight, newWidth, alignCorners) { + this.variableNames = ['A']; + this.outputShape = []; + var batch = inputShape[0], oldHeight = inputShape[1], oldWidth = inputShape[2], depth = inputShape[3]; + this.outputShape = [batch, newHeight, newWidth, depth]; + var effectiveInSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + effectiveInSize[0] / effectiveOutSize[0] + ",\n " + effectiveInSize[1] / effectiveOutSize[1] + ");\n const vec2 inputShapeRC = vec2(" + oldHeight + ".0, " + oldWidth + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "; + } + return ResizeBilinearProgram; + }()); + + var ResizeNearestNeigborBackpropProgram = (function () { + function ResizeNearestNeigborBackpropProgram(dy, x, alignCorners) { + this.variableNames = ['dy']; + this.outputShape = []; + this.outputShape = x.shape; + var _a = x.shape, xHeight = _a[1], xWidth = _a[2]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + heightScale + ");\n const float widthScale = float(" + widthScale + ");\n\n const float invHeightScale = float(" + invHeightScale + ");\n const float invWidthScale = float(" + invWidthScale + ");\n\n const int winHeight = int(" + winHeight + ");\n const int winWidth = int(" + winWidth + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + yHeight + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + yWidth + ") {\n continue;\n }\n\n float sourceFracRow =\n float(" + effectiveXSize[0] + ") *\n (float(dyR) / float(" + effectiveYSize[0] + "));\n\n float sourceFracCol =\n float(" + effectiveXSize[1] + ") *\n (float(dyC) / float(" + effectiveYSize[1] + "));\n\n int sourceNearestRow = int(min(\n float(int(" + xHeight + ") - 1),\n " + alignCorners + " ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(" + xWidth + ") - 1),\n " + alignCorners + " ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + } + return ResizeNearestNeigborBackpropProgram; + }()); + + var ResizeNearestNeighborProgram = (function () { + function ResizeNearestNeighborProgram(inputShape, newHeight, newWidth, alignCorners) { + this.variableNames = ['A']; + this.outputShape = []; + var batch = inputShape[0], oldHeight = inputShape[1], oldWidth = inputShape[2], depth = inputShape[3]; + this.outputShape = [batch, newHeight, newWidth, depth]; + var effectiveInSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + var roundBase = alignCorners ? '0.5' : '0.0'; + this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + effectiveInSize[0] / effectiveOutSize[0] + ",\n " + effectiveInSize[1] / effectiveOutSize[1] + ");\n const vec2 inputShapeRC = vec2(" + oldHeight + ".0, " + oldWidth + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + " + roundBase + ")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "; + } + return ResizeNearestNeighborProgram; + }()); + + var ReverseProgram = (function () { + function ReverseProgram(xShape, axis) { + this.variableNames = ['x']; + var rank = xShape.length; + if (rank > 4) { + throw new Error("WebGL backend: Reverse of rank-" + rank + " tensor is not yet supported"); + } + this.outputShape = xShape; + if (rank === 1) { + this.userCode = "\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(" + xShape[0] + " - coord - 1));\n }\n "; + return; + } + var getInCoord = function (i) { + if (axis.indexOf(i) !== -1 && xShape[i] !== 1) { + return xShape[i] + " - coords[" + i + "] - 1"; + } + return "coords[" + i + "]"; + }; + var inCoords = xShape.map(function (_, i) { return getInCoord(i); }).join(','); + var type = getCoordsDataType(rank); + this.userCode = "\n void main() {\n " + type + " coords = getOutputCoords();\n setOutput(getX(" + inCoords + "));\n }\n "; + } + return ReverseProgram; + }()); + + var SegmentOpProgram = (function () { + function SegmentOpProgram(segOpInfo, segOpType) { + this.variableNames = ['x', 'segmentIds']; + var windowSize = segOpInfo.windowSize; + var batchSize = segOpInfo.batchSize; + var inSize = segOpInfo.inSize; + var numSegments = segOpInfo.numSegments; + var outSize = numSegments * Math.ceil(inSize / windowSize); + this.outputShape = [batchSize, outSize]; + var initializationValue = '0.0'; + var returnValue = "sumValue"; + var windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4; + var windowSizeVec4Remainder = windowSize % 4; + var updateSnippet = "\n sumValue += dot(values, filter);\n "; + var checkValueOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkValueOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return initializationValue;\n }\n "; + } + var checkSegmentIdOutOfBounds = ''; + if (inSize % windowSize > 0) { + checkSegmentIdOutOfBounds = "\n if (inIdx < 0 || inIdx >= " + inSize + ") {\n return -1.0;\n }\n "; + } + this.userCode = "\n const float initializationValue = " + initializationValue + ";\n\n float getValue(int batch, int inIdx) {\n " + checkValueOutOfBounds + "\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n " + checkSegmentIdOutOfBounds + "\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n " + numSegments + ")) * float(" + windowSize + "));\n int currentSeg = int(mod(float(outIdx), float(" + numSegments + ")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < " + windowSizeNearestVec4 + "; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n " + updateSnippet + "\n }\n\n int inIdx = inOffset + " + windowSizeNearestVec4 + ";\n if (" + (windowSizeVec4Remainder === 1) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 2) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n " + updateSnippet + "\n } else if (" + (windowSizeVec4Remainder === 3) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n " + updateSnippet + "\n }\n setOutput(" + returnValue + ");\n }\n "; + } + return SegmentOpProgram; + }()); + + var SelectProgram = (function () { + function SelectProgram(cRank, shape, rank) { + this.variableNames = ['c', 'a', 'b']; + this.outputShape = shape; + var cCoords; + var abCoords; + if (rank > 4) { + throw Error("Where for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + abCoords = "resRC"; + cCoords = "resRC"; + } + else { + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w']; + var cCoordVars = []; + var abCoordVars = []; + for (var i = 0; i < shape.length; i++) { + abCoordVars.push("" + currentCoords[i]); + if (i < cRank) { + cCoordVars.push("" + currentCoords[i]); + } + } + cCoords = cCoordVars.join(); + abCoords = abCoordVars.join(); + } + var dtype = getCoordsDataType(rank); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n float cVal = getC(" + cCoords + ");\n if (cVal >= 1.0) {\n setOutput(getA(" + abCoords + "));\n } else {\n setOutput(getB(" + abCoords + "));\n }\n }\n "; + } + return SelectProgram; + }()); + + var SliceProgram = (function () { + function SliceProgram(destSize) { + this.variableNames = ['source']; + this.outputShape = destSize; + this.rank = destSize.length; + var dtype = getCoordsDataType(this.rank); + var sourceCoords = getCoords$1(this.rank); + this.userCode = "\n uniform " + dtype + " start;\n\n void main() {\n " + dtype + " sourceLoc = start + getOutputCoords();\n setOutput(getSource(" + sourceCoords + "));\n }\n "; + } + SliceProgram.prototype.getCustomSetupFunc = function (start) { + var _this = this; + if (start.length !== this.rank) { + throw Error("The rank (" + this.rank + ") of the program must match the " + + ("length of start (" + start.length + ")")); + } + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'start'); + if (_this.startLoc == null) { + return; + } + } + if (_this.rank === 1) { + gpgpu.gl.uniform1i(_this.startLoc, start[0]); + } + else if (_this.rank === 2) { + gpgpu.gl.uniform2i(_this.startLoc, start[0], start[1]); + } + else if (_this.rank === 3) { + gpgpu.gl.uniform3i(_this.startLoc, start[0], start[1], start[2]); + } + else if (_this.rank === 4) { + gpgpu.gl.uniform4i(_this.startLoc, start[0], start[1], start[2], start[3]); + } + else { + throw Error("Slicing for rank " + _this.rank + " is not yet supported"); + } + }; + }; + return SliceProgram; + }()); + function getCoords$1(rank) { + if (rank === 1) { + return 'sourceLoc'; + } + else if (rank === 2) { + return 'sourceLoc.x, sourceLoc.y'; + } + else if (rank === 3) { + return 'sourceLoc.x, sourceLoc.y, sourceLoc.z'; + } + else if (rank === 4) { + return 'sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w'; + } + else { + throw Error("Slicing for rank " + rank + " is not yet supported"); + } + } + + var StridedSliceProgram = (function () { + function StridedSliceProgram(begin, strides, shape) { + this.variableNames = ['x']; + this.outputShape = shape; + this.rank = shape.length; + var dtype = getCoordsDataType(this.rank); + var newCoords = ''; + if (this.rank === 1) { + newCoords = 'coords * strides + begin'; + } + else { + newCoords = + shape.map(function (_, i) { return "coords[" + i + "] * strides[" + i + "] + begin[" + i + "]"; }) + .join(','); + } + this.userCode = "\n " + dtype + " begin = " + dtype + "(" + begin + ");\n " + dtype + " strides = " + dtype + "(" + strides + ");\n\n void main() {\n " + dtype + " coords = getOutputCoords();\n setOutput(getX(" + newCoords + "));\n }\n "; + } + return StridedSliceProgram; + }()); + + var TextureManager = (function () { + function TextureManager(gpgpu) { + this.gpgpu = gpgpu; + this.numUsedTextures = 0; + this.numFreeTextures = 0; + this.freeTextures = {}; + this.logEnabled = false; + this.usedTextures = {}; + } + TextureManager.prototype.acquireTexture = function (shapeRC, usage) { + var physicalTexType = getPhysicalFromLogicalTextureType(usage); + var shapeKey = getKeyFromTextureShape(shapeRC, physicalTexType); + if (!(shapeKey in this.freeTextures)) { + this.freeTextures[shapeKey] = []; + } + if (!(shapeKey in this.usedTextures)) { + this.usedTextures[shapeKey] = []; + } + if (this.freeTextures[shapeKey].length > 0) { + this.numFreeTextures--; + this.numUsedTextures++; + this.log(); + var newTexture_1 = this.freeTextures[shapeKey].shift(); + this.usedTextures[shapeKey].push(newTexture_1); + return newTexture_1; + } + this.numUsedTextures++; + this.log(); + var newTexture; + if (physicalTexType === PhysicalTextureType.FLOAT32) { + newTexture = + this.gpgpu.createFloat32MatrixTexture(shapeRC[0], shapeRC[1]); + } + else if (physicalTexType === PhysicalTextureType.FLOAT16) { + newTexture = + this.gpgpu.createFloat16MatrixTexture(shapeRC[0], shapeRC[1]); + } + else if (physicalTexType === PhysicalTextureType.UNSIGNED_BYTE) { + newTexture = + this.gpgpu.createUnsignedBytesMatrixTexture(shapeRC[0], shapeRC[1]); + } + this.usedTextures[shapeKey].push(newTexture); + return newTexture; + }; + TextureManager.prototype.releaseTexture = function (texture, shape, logicalTexType) { + var physicalTexType = getPhysicalFromLogicalTextureType(logicalTexType); + var shapeKey = getKeyFromTextureShape(shape, physicalTexType); + if (!(shapeKey in this.freeTextures)) { + this.freeTextures[shapeKey] = []; + } + this.freeTextures[shapeKey].push(texture); + this.numFreeTextures++; + this.numUsedTextures--; + var texList = this.usedTextures[shapeKey]; + var texIndex = texList.indexOf(texture); + if (texIndex < 0) { + throw new Error('Cannot release a texture that was never provided by this ' + + 'texture manager'); + } + texList.splice(texIndex, 1); + this.log(); + }; + TextureManager.prototype.log = function () { + if (!this.logEnabled) { + return; + } + var total = this.numFreeTextures + this.numUsedTextures; + console.log('Free/Used', this.numFreeTextures + " / " + this.numUsedTextures, "(" + total + ")"); + }; + TextureManager.prototype.getNumUsedTextures = function () { + return this.numUsedTextures; + }; + TextureManager.prototype.getNumFreeTextures = function () { + return this.numFreeTextures; + }; + TextureManager.prototype.dispose = function () { + var _this = this; + if (this.freeTextures == null) { + return; + } + for (var texShape in this.freeTextures) { + this.freeTextures[texShape].forEach(function (tex) { + _this.gpgpu.deleteMatrixTexture(tex); + }); + } + for (var texShape in this.usedTextures) { + this.usedTextures[texShape].forEach(function (tex) { + _this.gpgpu.deleteMatrixTexture(tex); + }); + } + this.freeTextures = null; + this.usedTextures = null; + this.numUsedTextures = 0; + this.numFreeTextures = 0; + }; + return TextureManager; + }()); + function getPhysicalFromLogicalTextureType(logicalTexType) { + if (logicalTexType === TextureUsage.DOWNLOAD || + logicalTexType === TextureUsage.PIXELS) { + return PhysicalTextureType.UNSIGNED_BYTE; + } + else if (logicalTexType === TextureUsage.UPLOAD) { + return PhysicalTextureType.FLOAT32; + } + else if (logicalTexType === TextureUsage.RENDER) { + return ENV.get('WEBGL_RENDER_FLOAT32_ENABLED') ? + PhysicalTextureType.FLOAT32 : + PhysicalTextureType.FLOAT16; + } + throw new Error("Unknown logical texture type " + logicalTexType); + } + function getKeyFromTextureShape(shapeRowsCol, physicalTexType) { + return shapeRowsCol[0] + "_" + shapeRowsCol[1] + "_" + physicalTexType; + } + + var TileProgram = (function () { + function TileProgram(aShape, reps) { + this.variableNames = ['A']; + var outputShape = new Array(aShape.length); + for (var i = 0; i < outputShape.length; i++) { + outputShape[i] = aShape[i] * reps[i]; + } + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = getCoordsDataType(this.rank); + var sourceCoords = getSourceCoords$1(aShape); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + sourceCoords + "));\n }\n "; + } + return TileProgram; + }()); + function getSourceCoords$1(aShape) { + var rank = aShape.length; + if (rank > 5) { + throw Error("Tile for rank " + rank + " is not yet supported"); + } + if (rank === 1) { + return "imod(resRC, " + aShape[0] + ")"; + } + var currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u']; + var sourceCoords = []; + for (var i = 0; i < aShape.length; i++) { + sourceCoords.push("imod(" + currentCoords[i] + ", " + aShape[i] + ")"); + } + return sourceCoords.join(); + } + + var TransposeProgram = (function () { + function TransposeProgram(aShape, newDim) { + this.variableNames = ['A']; + var outputShape = new Array(aShape.length); + for (var i = 0; i < outputShape.length; i++) { + outputShape[i] = aShape[newDim[i]]; + } + this.outputShape = outputShape; + this.rank = outputShape.length; + var dtype = getCoordsDataType(this.rank); + var switched = getSwitchedCoords(newDim); + this.userCode = "\n void main() {\n " + dtype + " resRC = getOutputCoords();\n setOutput(getA(" + switched + "));\n }\n "; + } + return TransposeProgram; + }()); + function getSwitchedCoords(newDim) { + var rank = newDim.length; + if (rank > 6) { + throw Error("Transpose for rank " + rank + " is not yet supported"); + } + var originalOrder = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u', 'resRC.v']; + var switchedCoords = new Array(rank); + for (var i = 0; i < newDim.length; i++) { + switchedCoords[newDim[i]] = originalOrder[i]; + } + return switchedCoords.join(); + } + + var ERF_P = 0.3275911; + var ERF_A1 = 0.254829592; + var ERF_A2 = -0.284496736; + var ERF_A3 = 1.421413741; + var ERF_A4 = -1.453152027; + var ERF_A5 = 1.061405429; + + var SELU_SCALEALPHA = 1.7580993408473768599402175208123; + var SELU_SCALE = 1.0507009873554804934193349852946; + + var UnaryOpProgram = (function () { + function UnaryOpProgram(aShape, opSnippet) { + this.variableNames = ['A']; + this.outputShape = aShape; + this.userCode = "\n uniform float NAN;\n float unaryOperation(float x) {\n " + opSnippet + "\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n "; + } + UnaryOpProgram.prototype.getCustomSetupFunc = function () { + var _this = this; + return function (gpgpu, webGLProgram) { + if (_this.startLoc == null) { + _this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN'); + if (_this.startLoc == null) { + return; + } + } + gpgpu.gl.uniform1f(_this.startLoc, NaN); + }; + }; + return UnaryOpProgram; + }()); + var CHECK_NAN_SNIPPET$1 = "if (isNaN(x)) return x;"; + var ABS = "return abs(x);"; + var RELU = CHECK_NAN_SNIPPET$1 + "\n return (x < 0.0) ? 0.0 : x;\n"; + var ELU = "return (x >= 0.0) ? x : (exp(x) - 1.0);"; + var SELU = "\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = " + SELU_SCALEALPHA + ";\n float scale = " + SELU_SCALE + ";\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n"; + function STEP(alpha) { + if (alpha === void 0) { alpha = 0.0; } + return CHECK_NAN_SNIPPET$1 + ("\n return x > 0.0 ? 1.0 : float(" + alpha + ");\n "); + } + var NEG = "return -x;"; + var CEIL = "return ceil(x);"; + var FLOOR = "return floor(x);"; + var SIGN = "\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n"; + var ROUND = "\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n"; + var EXP = "return exp(x);"; + var EXPM1 = "return exp(x) - 1.0;"; + var LOG = "if (x < 0.0) return NAN;\n return log(x);"; + var LOG1P = "return log(1.0 + x);"; + var SQRT = "return sqrt(x);"; + var RSQRT = "return inversesqrt(x);"; + var SIGMOID = "return 1.0 / (1.0 + exp(-1.0 * x));"; + var SOFTPLUS = "\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n"; + var SIN = CHECK_NAN_SNIPPET$1 + "\n return sin(x);\n"; + var COS = CHECK_NAN_SNIPPET$1 + "\n return cos(x);\n"; + var TAN = "return tan(x);"; + var ASIN = "return asin(x);"; + var ACOS = "return acos(x);"; + var ATAN = CHECK_NAN_SNIPPET$1 + "\n return atan(x);\n"; + var SINH = "\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n"; + var COSH = "\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n"; + var TANH = "\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n"; + var ASINH = "return log(x + sqrt(x * x + 1.0));"; + var ACOSH = CHECK_NAN_SNIPPET$1 + "\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));"; + var ATANH = CHECK_NAN_SNIPPET$1 + "\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;"; + var ERF = "\n // Error function is calculated approximately with elementary function.\n // See \"Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\n float p = " + ERF_P + ";\n float a1 = " + ERF_A1 + ";\n float a2 = " + ERF_A2 + ";\n float a3 = " + ERF_A3 + ";\n float a4 = " + ERF_A4 + ";\n float a5 = " + ERF_A5 + ";\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n"; + var SQUARE = "return x * x;"; + var RECIPROCAL = "return 1.0 / x;"; + var LOGICAL_NOT = "return float(!(x >= 1.0));"; + var TO_INT = "return float(int(x));"; + + function concat1d_(tensors) { + return concat(tensors, 0); + } + function concat2d_(tensors, axis) { + return concat(tensors, axis); + } + function concat3d_(tensors, axis) { + return concat(tensors, axis); + } + function concat4d_(tensors, axis) { + return concat(tensors, axis); + } + function concat_(tensors, axis) { + if (axis === void 0) { axis = 0; } + assert(tensors.length >= 1, 'Pass at least one tensor to concat'); + var $tensors = convertToTensorArray(tensors, 'tensors', 'concat'); + var result = $tensors[0]; + if ($tensors.length === 1) { + return result; + } + var axes = parseAxisParam(axis, result.shape); + for (var i = 1; i < $tensors.length; ++i) { + result = concat2Tensors(result, $tensors[i], axes[0]); + } + return result; + } + function concat2Tensors(a, b, axis) { + assertParams(a.shape, b.shape, axis); + var outShape = computeOutShape$1(a.shape, b.shape, axis); + var a2D = a.as2D(-1, sizeFromShape(a.shape.slice(axis))); + var b2D = b.as2D(-1, sizeFromShape(b.shape.slice(axis))); + var _a = computeGradientSliceShapes(a2D.shape, b2D.shape), aBegin = _a.aBegin, aSize = _a.aSize, bBegin = _a.bBegin, bSize = _a.bSize; + var der = function (dy) { + return { a: function () { return dy.slice(aBegin, aSize); }, b: function () { return dy.slice(bBegin, bSize); } }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.concat(a2D, b2D); }, { a: a2D, b: b2D }, der); + return res.reshape(outShape); + } + var concat = op({ concat_: concat_ }); + var concat1d = op({ concat1d_: concat1d_ }); + var concat2d = op({ concat2d_: concat2d_ }); + var concat3d = op({ concat3d_: concat3d_ }); + var concat4d = op({ concat4d_: concat4d_ }); + + var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var alea = createCommonjsModule(function (module) { + // A port of an algorithm by Johannes Baagøe , 2010 + // http://baagoe.com/en/RandomMusings/javascript/ + // https://github.com/nquinlan/better-random-numbers-for-javascript-mirror + // Original work is under MIT license - + + // Copyright (C) 2010 by Johannes Baagøe + // + // Permission is hereby granted, free of charge, to any person obtaining a copy + // of this software and associated documentation files (the "Software"), to deal + // in the Software without restriction, including without limitation the rights + // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + // copies of the Software, and to permit persons to whom the Software is + // furnished to do so, subject to the following conditions: + // + // The above copyright notice and this permission notice shall be included in + // all copies or substantial portions of the Software. + // + // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + // THE SOFTWARE. + + + + (function(global, module, define) { + + function Alea(seed) { + var me = this, mash = Mash(); + + me.next = function() { + var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32 + me.s0 = me.s1; + me.s1 = me.s2; + return me.s2 = t - (me.c = t | 0); + }; + + // Apply the seeding algorithm from Baagoe. + me.c = 1; + me.s0 = mash(' '); + me.s1 = mash(' '); + me.s2 = mash(' '); + me.s0 -= mash(seed); + if (me.s0 < 0) { me.s0 += 1; } + me.s1 -= mash(seed); + if (me.s1 < 0) { me.s1 += 1; } + me.s2 -= mash(seed); + if (me.s2 < 0) { me.s2 += 1; } + mash = null; + } + + function copy(f, t) { + t.c = f.c; + t.s0 = f.s0; + t.s1 = f.s1; + t.s2 = f.s2; + return t; + } + + function impl(seed, opts) { + var xg = new Alea(seed), + state = opts && opts.state, + prng = xg.next; + prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }; + prng.double = function() { + return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53 + }; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + function Mash() { + var n = 0xefc8249d; + + var mash = function(data) { + data = data.toString(); + for (var i = 0; i < data.length; i++) { + n += data.charCodeAt(i); + var h = 0.02519603282416938 * n; + n = h >>> 0; + h -= n; + h *= n; + n = h >>> 0; + h -= n; + n += h * 0x100000000; // 2^32 + } + return (n >>> 0) * 2.3283064365386963e-10; // 2^-32 + }; + + return mash; + } + + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.alea = impl; + } + + })( + commonjsGlobal, + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var xor128 = createCommonjsModule(function (module) { + // A Javascript implementaion of the "xor128" prng algorithm by + // George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + + (function(global, module, define) { + + function XorGen(seed) { + var me = this, strseed = ''; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + + // Set up generator function. + me.next = function() { + var t = me.x ^ (me.x << 11); + me.x = me.y; + me.y = me.z; + me.z = me.w; + return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8); + }; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + me.next(); + } + } + + function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + return t; + } + + function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.xor128 = impl; + } + + })( + commonjsGlobal, + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var xorwow = createCommonjsModule(function (module) { + // A Javascript implementaion of the "xorwow" prng algorithm by + // George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + + (function(global, module, define) { + + function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var t = (me.x ^ (me.x >>> 2)); + me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v; + return (me.d = (me.d + 362437 | 0)) + + (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0; + }; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + me.v = 0; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + if (k == strseed.length) { + me.d = me.x << 10 ^ me.x >>> 4; + } + me.next(); + } + } + + function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + t.v = f.v; + t.d = f.d; + return t; + } + + function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.xorwow = impl; + } + + })( + commonjsGlobal, + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var xorshift7 = createCommonjsModule(function (module) { + // A Javascript implementaion of the "xorshift7" algorithm by + // François Panneton and Pierre L'ecuyer: + // "On the Xorgshift Random Number Generators" + // http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf + + (function(global, module, define) { + + function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + // Update xor generator. + var X = me.x, i = me.i, t, v; + t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24); + t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10); + t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3); + t = X[(i + 4) & 7]; v ^= t ^ (t << 7); + t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9); + X[i] = v; + me.i = (i + 1) & 7; + return v; + }; + + function init(me, seed) { + var j, w, X = []; + + if (seed === (seed | 0)) { + // Seed state array using a 32-bit integer. + w = X[0] = seed; + } else { + // Seed state using a string. + seed = '' + seed; + for (j = 0; j < seed.length; ++j) { + X[j & 7] = (X[j & 7] << 15) ^ + (seed.charCodeAt(j) + X[(j + 1) & 7] << 13); + } + } + // Enforce an array length of 8, not all zeroes. + while (X.length < 8) X.push(0); + for (j = 0; j < 8 && X[j] === 0; ++j); + if (j == 8) w = X[7] = -1; else w = X[j]; + + me.x = X; + me.i = 0; + + // Discard an initial 256 values. + for (j = 256; j > 0; --j) { + me.next(); + } + } + + init(me, seed); + } + + function copy(f, t) { + t.x = f.x.slice(); + t.i = f.i; + return t; + } + + function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.x) copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.xorshift7 = impl; + } + + })( + commonjsGlobal, + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var xor4096 = createCommonjsModule(function (module) { + // A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm. + // + // This fast non-cryptographic random number generator is designed for + // use in Monte-Carlo algorithms. It combines a long-period xorshift + // generator with a Weyl generator, and it passes all common batteries + // of stasticial tests for randomness while consuming only a few nanoseconds + // for each prng generated. For background on the generator, see Brent's + // paper: "Some long-period random number generators using shifts and xors." + // http://arxiv.org/pdf/1004.3115v1.pdf + // + // Usage: + // + // var xor4096 = require('xor4096'); + // random = xor4096(1); // Seed with int32 or string. + // assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits. + // assert.equal(random.int32(), 1806534897); // signed int32, 32 bits. + // + // For nonzero numeric keys, this impelementation provides a sequence + // identical to that by Brent's xorgens 3 implementaion in C. This + // implementation also provides for initalizing the generator with + // string seeds, or for saving and restoring the state of the generator. + // + // On Chrome, this prng benchmarks about 2.1 times slower than + // Javascript's built-in Math.random(). + + (function(global, module, define) { + + function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + var w = me.w, + X = me.X, i = me.i, t, v; + // Update Weyl generator. + me.w = w = (w + 0x61c88647) | 0; + // Update xor generator. + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + // Update Xor generator array state. + v = X[i] = v ^ t; + me.i = i; + // Result is the combination. + return (v + (w ^ (w >>> 16))) | 0; + }; + + function init(me, seed) { + var t, v, i, j, w, X = [], limit = 128; + if (seed === (seed | 0)) { + // Numeric seeds initialize v, which is used to generates X. + v = seed; + seed = null; + } else { + // String seeds are mixed into v and X one character at a time. + seed = seed + '\0'; + v = 0; + limit = Math.max(limit, seed.length); + } + // Initialize circular array and weyl value. + for (i = 0, j = -32; j < limit; ++j) { + // Put the unicode characters into the array, and shuffle them. + if (seed) v ^= seed.charCodeAt((j + 32) % seed.length); + // After 32 shuffles, take v as the starting w value. + if (j === 0) w = v; + v ^= v << 10; + v ^= v >>> 15; + v ^= v << 4; + v ^= v >>> 13; + if (j >= 0) { + w = (w + 0x61c88647) | 0; // Weyl. + t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array. + i = (0 == t) ? i + 1 : 0; // Count zeroes. + } + } + // We have detected all zeroes; make the key nonzero. + if (i >= 128) { + X[(seed && seed.length || 0) & 127] = -1; + } + // Run the generator 512 times to further mix the state before using it. + // Factoring this as a function slows the main generator, so it is just + // unrolled here. The weyl generator is not advanced while warming up. + i = 127; + for (j = 4 * 128; j > 0; --j) { + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + X[i] = v ^ t; + } + // Storing state as object members is faster than using closure variables. + me.w = w; + me.X = X; + me.i = i; + } + + init(me, seed); + } + + function copy(f, t) { + t.i = f.i; + t.w = f.w; + t.X = f.X.slice(); + return t; + } + function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.X) copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.xor4096 = impl; + } + + })( + commonjsGlobal, // window object or global + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var tychei = createCommonjsModule(function (module) { + // A Javascript implementaion of the "Tyche-i" prng algorithm by + // Samuel Neves and Filipe Araujo. + // See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf + + (function(global, module, define) { + + function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var b = me.b, c = me.c, d = me.d, a = me.a; + b = (b << 25) ^ (b >>> 7) ^ c; + c = (c - d) | 0; + d = (d << 24) ^ (d >>> 8) ^ a; + a = (a - b) | 0; + me.b = b = (b << 20) ^ (b >>> 12) ^ c; + me.c = c = (c - d) | 0; + me.d = (d << 16) ^ (c >>> 16) ^ a; + return me.a = (a - b) | 0; + }; + + /* The following is non-inverted tyche, which has better internal + * bit diffusion, but which is about 25% slower than tyche-i in JS. + me.next = function() { + var a = me.a, b = me.b, c = me.c, d = me.d; + a = (me.a + me.b | 0) >>> 0; + d = me.d ^ a; d = d << 16 ^ d >>> 16; + c = me.c + d | 0; + b = me.b ^ c; b = b << 12 ^ d >>> 20; + me.a = a = a + b | 0; + d = d ^ a; me.d = d = d << 8 ^ d >>> 24; + me.c = c = c + d | 0; + b = b ^ c; + return me.b = (b << 7 ^ b >>> 25); + } + */ + + me.a = 0; + me.b = 0; + me.c = 2654435769 | 0; + me.d = 1367130551; + + if (seed === Math.floor(seed)) { + // Integer seed. + me.a = (seed / 0x100000000) | 0; + me.b = seed | 0; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 20; k++) { + me.b ^= strseed.charCodeAt(k) | 0; + me.next(); + } + } + + function copy(f, t) { + t.a = f.a; + t.b = f.b; + t.c = f.c; + t.d = f.d; + return t; + } + function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); }; + } + return prng; + } + + if (module && module.exports) { + module.exports = impl; + } else if (define && define.amd) { + define(function() { return impl; }); + } else { + this.tychei = impl; + } + + })( + commonjsGlobal, + module, // present in node.js + (typeof undefined) == 'function' && undefined // present with an AMD loader + ); + }); + + var seedrandom = createCommonjsModule(function (module) { + /* + Copyright 2014 David Bau. + + Permission is hereby granted, free of charge, to any person obtaining + a copy of this software and associated documentation files (the + "Software"), to deal in the Software without restriction, including + without limitation the rights to use, copy, modify, merge, publish, + distribute, sublicense, and/or sell copies of the Software, and to + permit persons to whom the Software is furnished to do so, subject to + the following conditions: + + The above copyright notice and this permission notice shall be + included in all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. + IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY + CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, + TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE + SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + */ + + (function (pool, math) { + // + // The following constants are related to IEEE 754 limits. + // + var global = this, + width = 256, // each RC4 output is 0 <= x < 256 + chunks = 6, // at least six RC4 outputs for each double + digits = 52, // there are 52 significant digits in a double + rngname = 'random', // rngname: name for Math.random and Math.seedrandom + startdenom = math.pow(width, chunks), + significance = math.pow(2, digits), + overflow = significance * 2, + mask = width - 1, + nodecrypto; // node.js crypto module, initialized at the bottom. + + // + // seedrandom() + // This is the seedrandom function described above. + // + function seedrandom(seed, options, callback) { + var key = []; + options = (options == true) ? { entropy: true } : (options || {}); + + // Flatten the seed string or build one from local entropy if needed. + var shortseed = mixkey(flatten( + options.entropy ? [seed, tostring(pool)] : + (seed == null) ? autoseed() : seed, 3), key); + + // Use the seed to initialize an ARC4 generator. + var arc4 = new ARC4(key); + + // This function returns a random double in [0, 1) that contains + // randomness in every bit of the mantissa of the IEEE 754 value. + var prng = function() { + var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48 + d = startdenom, // and denominator d = 2 ^ 48. + x = 0; // and no 'extra last byte'. + while (n < significance) { // Fill up all significant digits by + n = (n + x) * width; // shifting numerator and + d *= width; // denominator and generating a + x = arc4.g(1); // new least-significant-byte. + } + while (n >= overflow) { // To avoid rounding up, before adding + n /= 2; // last byte, shift everything + d /= 2; // right using integer math until + x >>>= 1; // we have exactly the desired bits. + } + return (n + x) / d; // Form the number within [0, 1). + }; + + prng.int32 = function() { return arc4.g(4) | 0; }; + prng.quick = function() { return arc4.g(4) / 0x100000000; }; + prng.double = prng; + + // Mix the randomness into accumulated entropy. + mixkey(tostring(arc4.S), pool); + + // Calling convention: what to return as a function of prng, seed, is_math. + return (options.pass || callback || + function(prng, seed, is_math_call, state) { + if (state) { + // Load the arc4 state from the given state if it has an S array. + if (state.S) { copy(state, arc4); } + // Only provide the .state method if requested via options.state. + prng.state = function() { return copy(arc4, {}); }; + } + + // If called as a method of Math (Math.seedrandom()), mutate + // Math.random because that is how seedrandom.js has worked since v1.0. + if (is_math_call) { math[rngname] = prng; return seed; } + + // Otherwise, it is a newer calling convention, so return the + // prng directly. + else return prng; + })( + prng, + shortseed, + 'global' in options ? options.global : (this == math), + options.state); + } + math['seed' + rngname] = seedrandom; + + // + // ARC4 + // + // An ARC4 implementation. The constructor takes a key in the form of + // an array of at most (width) integers that should be 0 <= x < (width). + // + // The g(count) method returns a pseudorandom integer that concatenates + // the next (count) outputs from ARC4. Its return value is a number x + // that is in the range 0 <= x < (width ^ count). + // + function ARC4(key) { + var t, keylen = key.length, + me = this, i = 0, j = me.i = me.j = 0, s = me.S = []; + + // The empty key [] is treated as [0]. + if (!keylen) { key = [keylen++]; } + + // Set up S using the standard key scheduling algorithm. + while (i < width) { + s[i] = i++; + } + for (i = 0; i < width; i++) { + s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))]; + s[j] = t; + } + + // The "g" method returns the next (count) outputs as one number. + (me.g = function(count) { + // Using instance members instead of closure state nearly doubles speed. + var t, r = 0, + i = me.i, j = me.j, s = me.S; + while (count--) { + t = s[i = mask & (i + 1)]; + r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))]; + } + me.i = i; me.j = j; + return r; + // For robust unpredictability, the function call below automatically + // discards an initial batch of values. This is called RC4-drop[256]. + // See http://google.com/search?q=rsa+fluhrer+response&btnI + })(width); + } + + // + // copy() + // Copies internal state of ARC4 to or from a plain object. + // + function copy(f, t) { + t.i = f.i; + t.j = f.j; + t.S = f.S.slice(); + return t; + } + // + // flatten() + // Converts an object tree to nested arrays of strings. + // + function flatten(obj, depth) { + var result = [], typ = (typeof obj), prop; + if (depth && typ == 'object') { + for (prop in obj) { + try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {} + } + } + return (result.length ? result : typ == 'string' ? obj : obj + '\0'); + } + + // + // mixkey() + // Mixes a string seed into a key that is an array of integers, and + // returns a shortened string seed that is equivalent to the result key. + // + function mixkey(seed, key) { + var stringseed = seed + '', smear, j = 0; + while (j < stringseed.length) { + key[mask & j] = + mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++)); + } + return tostring(key); + } + + // + // autoseed() + // Returns an object for autoseeding, using window.crypto and Node crypto + // module if available. + // + function autoseed() { + try { + var out; + if (nodecrypto && (out = nodecrypto.randomBytes)) { + // The use of 'out' to remember randomBytes makes tight minified code. + out = out(width); + } else { + out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + } + return tostring(out); + } catch (e) { + var browser = global.navigator, + plugins = browser && browser.plugins; + return [+new Date, global, plugins, global.screen, tostring(pool)]; + } + } + + // + // tostring() + // Converts an array of charcodes to a string + // + function tostring(a) { + return String.fromCharCode.apply(0, a); + } + + // + // When seedrandom.js is loaded, we immediately mix a few bits + // from the built-in RNG into the entropy pool. Because we do + // not want to interfere with deterministic PRNG state later, + // seedrandom will not call math.random on its own again after + // initialization. + // + mixkey(math.random(), pool); + + // + // Nodejs and AMD support: export the implementation as a module using + // either convention. + // + if (module.exports) { + module.exports = seedrandom; + // When in node.js, try using crypto package for autoseeding. + try { + nodecrypto = require('crypto'); + } catch (ex) {} + } else if ((typeof undefined) == 'function' && undefined.amd) { + undefined(function() { return seedrandom; }); + } + + // End anonymous scope, and pass initial values. + })( + [], // pool: entropy pool starts empty + Math // math: package containing random, pow, and seedrandom + ); + }); + + // A library of seedable RNGs implemented in Javascript. + // + // Usage: + // + // var seedrandom = require('seedrandom'); + // var random = seedrandom(1); // or any seed. + // var x = random(); // 0 <= x < 1. Every bit is random. + // var x = random.quick(); // 0 <= x < 1. 32 bits of randomness. + + // alea, a 53-bit multiply-with-carry generator by Johannes Baagøe. + // Period: ~2^116 + // Reported to pass all BigCrush tests. + + + // xor128, a pure xor-shift generator by George Marsaglia. + // Period: 2^128-1. + // Reported to fail: MatrixRank and LinearComp. + + + // xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl. + // Period: 2^192-2^32 + // Reported to fail: CollisionOver, SimpPoker, and LinearComp. + + + // xorshift7, by François Panneton and Pierre L'ecuyer, takes + // a different approach: it adds robustness by allowing more shifts + // than Marsaglia's original three. It is a 7-shift generator + // with 256 bits, that passes BigCrush with no systmatic failures. + // Period 2^256-1. + // No systematic BigCrush failures reported. + + + // xor4096, by Richard Brent, is a 4096-bit xor-shift with a + // very long period that also adds a Weyl generator. It also passes + // BigCrush with no systematic failures. Its long period may + // be useful if you have many generators and need to avoid + // collisions. + // Period: 2^4128-2^32. + // No systematic BigCrush failures reported. + + + // Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random + // number generator derived from ChaCha, a modern stream cipher. + // https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf + // Period: ~2^127 + // No systematic BigCrush failures reported. + + + // The original ARC4-based prng included in this library. + // Period: ~2^1600 + + + seedrandom.alea = alea; + seedrandom.xor128 = xor128; + seedrandom.xorwow = xorwow; + seedrandom.xorshift7 = xorshift7; + seedrandom.xor4096 = xor4096; + seedrandom.tychei = tychei; + + var seedrandom$1 = seedrandom; + var seedrandom_1 = seedrandom$1.alea; + + var MPRandGauss = (function () { + function MPRandGauss(mean, stdDeviation, dtype, truncated, seed) { + this.mean = mean; + this.stdDev = stdDeviation; + this.dtype = dtype; + this.nextVal = NaN; + this.truncated = truncated; + if (this.truncated) { + this.upper = this.mean + this.stdDev * 2; + this.lower = this.mean - this.stdDev * 2; + } + var seedValue = seed ? seed : Math.random(); + this.random = seedrandom_1(seedValue.toString()); + } + MPRandGauss.prototype.nextValue = function () { + if (!isNaN(this.nextVal)) { + var value = this.nextVal; + this.nextVal = NaN; + return value; + } + var resultX, resultY; + var isValid = false; + while (!isValid) { + var v1 = void 0, v2 = void 0, s = void 0; + do { + v1 = 2 * this.random() - 1; + v2 = 2 * this.random() - 1; + s = v1 * v1 + v2 * v2; + } while (s >= 1 || s === 0); + var mul = Math.sqrt(-2.0 * Math.log(s) / s); + resultX = this.mean + this.stdDev * v1 * mul; + resultY = this.mean + this.stdDev * v2 * mul; + if (!this.truncated || this.isValidTruncated(resultX)) { + isValid = true; + } + } + if (!this.truncated || this.isValidTruncated(resultY)) { + this.nextVal = this.convertValue(resultY); + } + return this.convertValue(resultX); + }; + MPRandGauss.prototype.convertValue = function (value) { + if (this.dtype == null || this.dtype === 'float32') { + return value; + } + return Math.round(value); + }; + MPRandGauss.prototype.isValidTruncated = function (value) { + return value <= this.upper && value >= this.lower; + }; + return MPRandGauss; + }()); + + function clone_(x) { + var $x = convertToTensor(x, 'x', 'clone'); + var der = function (dy) { + return { $x: function () { return dy.toFloat(); } }; + }; + return ENV.engine.runKernel(function (backend) { + return Tensor.make($x.shape, { dataId: $x.dataId }, $x.dtype); + }, { $x: $x }, der); + } + function eye_(numRows, numColumns, batchShape, dtype) { + if (dtype === void 0) { dtype = 'float32'; } + if (numColumns == null) { + numColumns = numRows; + } + var buff = buffer([numRows, numColumns], dtype); + var n = numRows <= numColumns ? numRows : numColumns; + for (var i = 0; i < n; ++i) { + buff.set(1, i, i); + } + var out = buff.toTensor().as2D(numRows, numColumns); + if (batchShape == null) { + return out; + } + else { + if (batchShape.length === 1) { + return tile(expandDims(out, 0), [batchShape[0], 1, 1]); + } + else if (batchShape.length === 2) { + return tile(expandDims(expandDims(out, 0), 0), [batchShape[0], batchShape[1], 1, 1]); + } + else if (batchShape.length === 3) { + return tile(expandDims(expandDims(expandDims(out, 0), 0), 0), [batchShape[0], batchShape[1], batchShape[2], 1, 1]); + } + else { + throw new Error("eye() currently supports only 1D and 2D " + + ("batchShapes, but received " + batchShape.length + "D.")); + } + } + } + function randomNormal_(shape, mean, stdDev, dtype, seed) { + if (mean === void 0) { mean = 0; } + if (stdDev === void 0) { stdDev = 1; } + if (dtype != null && dtype === 'bool') { + throw new Error("Unsupported data type " + dtype); + } + var randGauss = new MPRandGauss(mean, stdDev, dtype, false, seed); + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = randGauss.nextValue(); + } + return res.toTensor(); + } + function truncatedNormal_(shape, mean, stdDev, dtype, seed) { + if (mean === void 0) { mean = 0; } + if (stdDev === void 0) { stdDev = 1; } + if (dtype != null && dtype === 'bool') { + throw new Error("Unsupported data type " + dtype); + } + var randGauss = new MPRandGauss(mean, stdDev, dtype, true, seed); + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = randGauss.nextValue(); + } + return res.toTensor(); + } + function randomUniform_(shape, minval, maxval, dtype) { + if (minval === void 0) { minval = 0; } + if (maxval === void 0) { maxval = 1; } + if (dtype === void 0) { dtype = 'float32'; } + var res = buffer(shape, dtype); + for (var i = 0; i < res.values.length; i++) { + res.values[i] = randUniform(minval, maxval); + } + return res.toTensor(); + } + function rand_(shape, randFunction, dtype) { + var size = sizeFromShape(shape); + var values = null; + if (dtype == null || dtype === 'float32') { + values = new Float32Array(size); + } + else if (dtype === 'int32') { + values = new Int32Array(size); + } + else if (dtype === 'bool') { + values = new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } + for (var i = 0; i < size; i++) { + values[i] = randFunction(); + } + return Tensor.make(shape, { values: values }, dtype); + } + function multinomial_(logits, numSamples, seed, normalized) { + if (normalized === void 0) { normalized = false; } + var $logits = convertToTensor(logits, 'logits', 'multinomial'); + var numOutcomes = $logits.size; + var origRank = $logits.rank; + if (numOutcomes < 2) { + throw new Error("Error in multinomial: you need at least 2 outcomes, but got " + + (numOutcomes + ".")); + } + if (origRank > 2) { + throw new Error("Rank of probabilities must be 1 or 2, but is " + origRank); + } + seed = seed || Math.random(); + var logits2D = origRank === 1 ? $logits.as2D(1, -1) : $logits; + var res = ENV.engine.runKernel(function (backend) { return backend.multinomial(logits2D, normalized, numSamples, seed); }, { logits2D: logits2D }); + return origRank === 1 ? res.as1D() : res; + } + function oneHot_(indices, depth, onValue, offValue) { + if (onValue === void 0) { onValue = 1; } + if (offValue === void 0) { offValue = 0; } + var $indices = convertToTensor(indices, 'indices', 'oneHot', 'int32'); + assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`'); + if (depth < 2) { + throw new Error("Error in oneHot: depth must be >=2, but it is " + depth); + } + return ENV.engine.runKernel(function (backend) { return backend.oneHot($indices, depth, onValue, offValue); }, { $indices: $indices }); + } + function fromPixels_(pixels, numChannels) { + if (numChannels === void 0) { numChannels = 3; } + if (numChannels > 4) { + throw new Error('Cannot construct Tensor with more than 4 channels from pixels.'); + } + return ENV.engine.fromPixels(pixels, numChannels); + } + function toPixels(img, canvas) { + return __awaiter(this, void 0, void 0, function () { + var $img, _a, height, width, depth, minTensor, maxTensor, min, max, data, multiplier, bytes, i, r, g, b, a, j, ctx, imageData; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + $img = convertToTensor(img, 'img', 'toPixels', 'int32'); + if ($img.rank !== 2 && $img.rank !== 3) { + throw new Error("toPixels only supports rank 2 or 3 tensors, got rank " + $img.rank + "."); + } + _a = $img.shape.slice(0, 2), height = _a[0], width = _a[1]; + depth = $img.rank === 2 ? 1 : $img.shape[2]; + if (depth > 4 || depth === 2) { + throw new Error("toPixels only supports depth of size " + + ("1, 3 or 4 but got " + depth)); + } + minTensor = $img.min(); + maxTensor = $img.max(); + return [4, minTensor.data()]; + case 1: + min = (_b.sent())[0]; + return [4, maxTensor.data()]; + case 2: + max = (_b.sent())[0]; + minTensor.dispose(); + maxTensor.dispose(); + if ($img.dtype === 'float32') { + if (min < 0 || max > 1) { + throw new Error("Tensor values for a float32 Tensor must be in the " + + ("range [0 - 1] but got range [" + min + " - " + max + "].")); + } + } + else if ($img.dtype === 'int32') { + if (min < 0 || max > 255) { + throw new Error("Tensor values for a int32 Tensor must be in the " + + ("range [0 - 255] but got range [" + min + " - " + max + "].")); + } + } + else { + throw new Error("Unsupported type for toPixels: " + $img.dtype + "." + + " Please use float32 or int32 tensors."); + } + return [4, $img.data()]; + case 3: + data = _b.sent(); + multiplier = $img.dtype === 'float32' ? 255 : 1; + bytes = new Uint8ClampedArray(width * height * 4); + for (i = 0; i < height * width; ++i) { + r = void 0, g = void 0, b = void 0, a = void 0; + if (depth === 1) { + r = data[i] * multiplier; + g = data[i] * multiplier; + b = data[i] * multiplier; + a = 255; + } + else if (depth === 3) { + r = data[i * 3] * multiplier; + g = data[i * 3 + 1] * multiplier; + b = data[i * 3 + 2] * multiplier; + a = 255; + } + else if (depth === 4) { + r = data[i * 4] * multiplier; + g = data[i * 4 + 1] * multiplier; + b = data[i * 4 + 2] * multiplier; + a = data[i * 4 + 3] * multiplier; + } + j = i * 4; + bytes[j + 0] = Math.round(r); + bytes[j + 1] = Math.round(g); + bytes[j + 2] = Math.round(b); + bytes[j + 3] = Math.round(a); + } + if (canvas != null) { + canvas.width = width; + canvas.height = height; + ctx = canvas.getContext('2d'); + imageData = new ImageData(bytes, width, height); + ctx.putImageData(imageData, 0, 0); + } + if ($img !== img) { + $img.dispose(); + } + return [2, bytes]; + } + }); + }); + } + function reshape_(x, shape) { + var $x = convertToTensor(x, 'x', 'reshape'); + shape = inferFromImplicitShape(shape, $x.size); + assert($x.size === sizeFromShape(shape), 'new shape and old shape must have the same number of elements.'); + var grad = function (dy) { + return { $x: function () { return dy.reshape($x.shape); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.reshape($x, shape); }, { $x: $x }, grad); + } + function squeeze_(x, axis) { + var $x = convertToTensor(x, 'x', 'squeeze'); + return reshape($x, squeezeShape($x.shape, axis).newShape); + } + function cast_(x, dtype) { + var $x = convertToTensor(x, 'x', 'cast'); + var grad = function (dy) { + return { $x: function () { return dy.clone(); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.cast($x, dtype); }, { $x: $x }, grad); + } + function tile_(x, reps) { + var $x = convertToTensor(x, 'x', 'tile'); + assert($x.rank === reps.length, "Error in transpose: rank of input " + $x.rank + " " + + ("must match length of reps " + reps + ".")); + var grad = function (dy) { + var derX = function () { + var xGrad = zerosLike($x); + if ($x.rank === 1) { + for (var i = 0; i < reps[0]; ++i) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0]], [$x.shape[0]])); + } + } + else if ($x.rank === 2) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0], j * $x.shape[1]], [$x.shape[0], $x.shape[1]])); + } + } + } + else if ($x.rank === 3) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + for (var k = 0; k < reps[2]; ++k) { + xGrad = xGrad.add(dy.slice([i * $x.shape[0], j * $x.shape[1], k * $x.shape[2]], [$x.shape[0], $x.shape[1], $x.shape[2]])); + } + } + } + } + else if ($x.rank === 4) { + for (var i = 0; i < reps[0]; ++i) { + for (var j = 0; j < reps[1]; ++j) { + for (var k = 0; k < reps[2]; ++k) { + for (var l = 0; l < reps[3]; ++l) { + xGrad = xGrad.add(dy.slice([ + i * $x.shape[0], j * $x.shape[1], k * $x.shape[2], + l * $x.shape[3] + ], [$x.shape[0], $x.shape[1], $x.shape[2], $x.shape[3]])); + } + } + } + } + } + else { + throw new Error("Gradient for tile operation is not implemented for rank-" + + ($x.rank + " tensors yet.")); + } + return xGrad; + }; + return { $x: derX }; + }; + return ENV.engine.runKernel(function (backend) { return backend.tile($x, reps); }, { $x: $x }, grad); + } + function pad1d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + assert(paddings.length === 2, 'Invalid number of paddings. Must be length of 2.'); + return pad(x, [paddings], constantValue); + } + function pad2d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + assert(paddings.length === 2 && paddings[0].length === 2 && + paddings[1].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return pad(x, paddings, constantValue); + } + function pad3d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + assert(paddings.length === 3 && paddings[0].length === 2 && + paddings[1].length === 2 && paddings[2].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return pad(x, paddings, constantValue); + } + function pad4d_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + assert(paddings.length === 4 && paddings[0].length === 2 && + paddings[1].length === 2 && paddings[2].length === 2 && + paddings[3].length === 2, 'Invalid number of paddings. Must be length of 2 each.'); + return pad(x, paddings, constantValue); + } + function pad_(x, paddings, constantValue) { + if (constantValue === void 0) { constantValue = 0; } + var $x = convertToTensor(x, 'x', 'pad'); + if ($x.rank === 0) { + throw new Error('pad(scalar) is not defined. Pass non-scalar to pad'); + } + var begin = paddings.map(function (p) { return p[0]; }); + var grad = function (dy) { + return { $x: function () { return dy.slice(begin, $x.shape); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.pad($x, paddings, constantValue); }, { $x: $x }, grad); + } + function stack_(tensors, axis) { + if (axis === void 0) { axis = 0; } + var $tensors = convertToTensorArray(tensors, 'tensors', 'stack'); + assert($tensors.length >= 1, 'Pass at least one tensor to tf.stack'); + if ($tensors.length === 1) { + return $tensors[0].expandDims(axis); + } + var rank = $tensors[0].rank; + var shape = $tensors[0].shape; + var dtype = $tensors[0].dtype; + assert(axis <= rank, 'Axis must be <= rank of the tensor'); + $tensors.forEach(function (t) { + assertShapesMatch(shape, t.shape, 'All tensors passed to stack must have matching shapes'); + }); + $tensors.forEach(function (t) { + assert(dtype === t.dtype, 'All tensors passed to stack must have matching dtypes'); + }); + var expandedTensors = $tensors.map(function (t) { return t.expandDims(axis); }); + return concat(expandedTensors, axis); + } + function batchToSpaceND_(x, blockShape, crops) { + var $x = convertToTensor(x, 'x', 'batchToSpaceND'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + assert($x.rank >= 1 + blockShape.length, "input rank should be > than [blockShape] but got " + $x.rank); + assert(crops.length === blockShape.length, "crops.shape[0] must be equal to [blockShape] but got " + crops.length); + assert($x.shape[0] % prod === 0, "input tensor batch must be divisible by prod( blockShape )"); + return ENV.engine.runKernel(function (backend) { return backend.batchToSpaceND($x, blockShape, crops); }, {}); + } + function spaceToBatchND_(x, blockShape, paddings) { + var $x = convertToTensor(x, 'x', 'spaceToBatchND'); + assert($x.rank >= 1 + blockShape.length, "input rank should be > than [blockShape] but got " + $x.rank); + assert(paddings.length === blockShape.length, "paddings.shape[0] must be equal to [blockShape], got " + paddings.length); + assert($x.shape.reduce(function (a, b, i) { + if (i > 0 && i <= blockShape.length) { + return a && (b % blockShape[i - 1] === 0); + } + return a; + }, true), "input spatial dimensions must be divisible by blockShapes"); + return ENV.engine.runKernel(function (backend) { return backend.spaceToBatchND($x, blockShape, paddings); }, {}); + } + function unstack_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'unstack'); + var num = $x.shape[axis]; + var outputShape = Array($x.rank - 1).fill(0); + var outIndex = 0; + for (var i = 0; i < $x.rank; i++) { + if (i !== axis) { + outputShape[outIndex] = $x.shape[i]; + outIndex++; + } + } + var splitSizes; + splitSizes = Array(num).fill(1); + var begin = Array($x.rank).fill(0); + var size = $x.shape.slice(); + return splitSizes.map(function (s) { + size[axis] = s; + var slice = $x.slice(begin, size); + begin[axis] += s; + return slice.reshape(outputShape); + }); + } + function split_(x, numOrSizeSplits, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'split'); + axis = parseAxisParam(axis, $x.shape)[0]; + var splitSizes; + if (typeof (numOrSizeSplits) === 'number') { + assert($x.shape[axis] % numOrSizeSplits === 0, 'Number of splits must evenly divide the axis.'); + splitSizes = Array(numOrSizeSplits).fill($x.shape[axis] / numOrSizeSplits); + } + else { + assert($x.shape[axis] === numOrSizeSplits.reduce(function (a, b) { return a + b; }), 'The sum of sizes must match the size of the axis dimension.'); + splitSizes = numOrSizeSplits; + } + var begin = Array($x.rank).fill(0); + var size = $x.shape.slice(); + return splitSizes.map(function (s) { + size[axis] = s; + var slice = $x.slice(begin, size); + begin[axis] += s; + return slice; + }); + } + function cumsum_(x, axis, exclusive, reverse) { + if (axis === void 0) { axis = 0; } + if (exclusive === void 0) { exclusive = false; } + if (reverse === void 0) { reverse = false; } + var $x = convertToTensor(x, 'x', 'cumsum'); + axis = axis | 0; + var permutation = getAxesPermutation([axis], $x.rank); + var permutedX = $x; + if (permutation != null) { + permutedX = $x.transpose(permutation); + } + var permutedAxis = getInnerMostAxes(1, $x.rank)[0]; + var grad = function (dy) { + return { permutedX: function () { return dy.cumsum(axis, exclusive, !reverse); } }; + }; + var value = ENV.engine.runKernel(function (backend) { return backend.cumsum(permutedX, permutedAxis, exclusive, reverse); }, { permutedX: permutedX }, grad); + if (permutation != null) { + value = value.transpose(permutation); + } + return value; + } + function expandDims_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'expandDims'); + assert(axis <= $x.rank, 'Axis must be <= rank of the tensor'); + var newShape = $x.shape.slice(); + if (axis < 0) { + assert(-($x.rank + 1) <= axis, "Axis must be in the interval [" + -($x.rank + 1) + ", " + $x.rank + "]"); + axis = $x.rank + axis + 1; + } + newShape.splice(axis, 0, 1); + return reshape($x, newShape); + } + function buffer(shape, dtype, values) { + if (dtype === void 0) { dtype = 'float32'; } + return new TensorBuffer(shape, dtype, values); + } + function print(x, verbose) { + if (verbose === void 0) { verbose = false; } + console.log(x.toString(verbose)); + } + var cast = op({ cast_: cast_ }); + var clone = op({ clone_: clone_ }); + var cumsum = op({ cumsum_: cumsum_ }); + var expandDims = op({ expandDims_: expandDims_ }); + var eye = op({ eye_: eye_ }); + var fromPixels = op({ fromPixels_: fromPixels_ }); + var multinomial = op({ multinomial_: multinomial_ }); + var oneHot = op({ oneHot_: oneHot_ }); + var pad = op({ pad_: pad_ }); + var pad1d = op({ pad1d_: pad1d_ }); + var pad2d = op({ pad2d_: pad2d_ }); + var pad3d = op({ pad3d_: pad3d_ }); + var pad4d = op({ pad4d_: pad4d_ }); + var rand = op({ rand_: rand_ }); + var randomNormal = op({ randomNormal_: randomNormal_ }); + var randomUniform = op({ randomUniform_: randomUniform_ }); + var reshape = op({ reshape_: reshape_ }); + var split = op({ split_: split_ }); + var squeeze = op({ squeeze_: squeeze_ }); + var stack = op({ stack_: stack_ }); + var tile = op({ tile_: tile_ }); + var truncatedNormal = op({ truncatedNormal_: truncatedNormal_ }); + var unstack = op({ unstack_: unstack_ }); + var batchToSpaceND = op({ batchToSpaceND_: batchToSpaceND_ }); + var spaceToBatchND = op({ spaceToBatchND_: spaceToBatchND_ }); + + function whereImpl(condShape, condVals) { + var indices = []; + for (var i = 0; i < condVals.length; i++) { + if (condVals[i]) { + indices.push(i); + } + } + var inBuffer = buffer(condShape, 'int32'); + var out = buffer([indices.length, condShape.length], 'int32'); + for (var i = 0; i < indices.length; i++) { + var loc = inBuffer.indexToLoc(indices[i]); + var offset = i * condShape.length; + out.values.set(loc, offset); + } + return out.toTensor(); + } + + var BEFORE_PAGING_CONSTANT = 300; + var SIZE_UPLOAD_UNIFORM = 32; + var MathBackendWebGL = (function () { + function MathBackendWebGL(gpgpu, delayedStorage) { + if (delayedStorage === void 0) { delayedStorage = true; } + this.gpgpu = gpgpu; + this.delayedStorage = delayedStorage; + this.texData = new WeakMap(); + this.pendingRead = new WeakMap(); + this.pendingDisposal = new WeakSet(); + this.lruDataGPU = []; + this.numBytesInGPU = 0; + this.uploadWaitMs = 0; + this.downloadWaitMs = 0; + this.binaryCache = {}; + this.disposed = false; + if (ENV.get('WEBGL_VERSION') < 1) { + throw new Error('WebGL is not supported on this device'); + } + if (ENV.get('IS_BROWSER')) { + this.canvas = document.createElement('canvas'); + } + if (gpgpu == null) { + this.gpgpu = new GPGPUContext(createWebGLContext(this.canvas)); + this.gpgpuCreatedLocally = true; + } + else { + this.gpgpuCreatedLocally = false; + } + this.NUM_BYTES_BEFORE_PAGING = + (window.screen.height * window.screen.width * window.devicePixelRatio) * + BEFORE_PAGING_CONSTANT; + this.textureManager = new TextureManager(this.gpgpu); + } + MathBackendWebGL.prototype.register = function (dataId, shape, dtype) { + if (this.texData.has(dataId)) { + throw new Error('Data buffer is already registered'); + } + this.texData.set(dataId, { + shape: shape, + dtype: dtype, + values: null, + texture: null, + texShape: null, + usage: TextureUsage.RENDER + }); + }; + MathBackendWebGL.prototype.fromPixels = function (pixels, numChannels) { + if (pixels == null) { + throw new Error('pixels passed to tf.fromPixels() can not be null'); + } + var texShape = [pixels.height, pixels.width]; + var outShape = [pixels.height, pixels.width, numChannels]; + if (!(pixels instanceof HTMLVideoElement) && + !(pixels instanceof HTMLImageElement) && + !(pixels instanceof HTMLCanvasElement) && + !(pixels instanceof ImageData)) { + throw new Error('pixels passed to tf.fromPixels() must be either an ' + + "HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or " + + ("ImageData, but was " + pixels.constructor.name)); + } + if (pixels instanceof HTMLVideoElement) { + if (this.fromPixelsCanvas == null) { + if (!ENV.get('IS_BROWSER')) { + throw new Error('Can\'t read pixels from HTMLImageElement outside the browser.'); + } + if (document.readyState !== 'complete') { + throw new Error('The DOM is not ready yet. Please call tf.fromPixels() ' + + 'once the DOM is ready. One way to do that is to add an event ' + + 'listener for `DOMContentLoaded` on the document object'); + } + this.fromPixelsCanvas = document.createElement('canvas'); + } + this.fromPixelsCanvas.width = pixels.width; + this.fromPixelsCanvas.height = pixels.height; + this.fromPixelsCanvas.getContext('2d').drawImage(pixels, 0, 0, pixels.width, pixels.height); + pixels = this.fromPixelsCanvas; + } + var tempPixelArray = Tensor.make(texShape, {}, 'int32'); + this.texData.get(tempPixelArray.dataId).usage = TextureUsage.PIXELS; + this.gpgpu.uploadPixelDataToTexture(this.getTexture(tempPixelArray.dataId), pixels); + var program = new FromPixelsProgram(outShape); + var res = this.compileAndRun(program, [tempPixelArray]); + tempPixelArray.dispose(); + return res; + }; + MathBackendWebGL.prototype.write = function (dataId, values) { + if (values == null) { + throw new Error('MathBackendWebGL.write(): values can not be null'); + } + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var texture = texData.texture, texShape = texData.texShape, usage = texData.usage; + if (texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + texData.texture = null; + texData.texShape = null; + } + texData.usage = TextureUsage.UPLOAD; + texData.values = values; + if (!this.delayedStorage) { + this.uploadToGPU(dataId); + } + }; + MathBackendWebGL.prototype.readSync = function (dataId) { + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var shape = texData.shape, texture = texData.texture, values = texData.values, texShape = texData.texShape, dtype = texData.dtype; + if (values != null) { + this.cacheOnCPU(dataId); + return values; + } + var shouldTimeProgram = this.activeTimers != null; + var start; + if (shouldTimeProgram) { + start = performance.now(); + } + var float32Values = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape); + if (shouldTimeProgram) { + this.downloadWaitMs += performance.now() - start; + } + this.cacheOnCPU(dataId, float32Values); + return texData.values; + }; + MathBackendWebGL.prototype.read = function (dataId) { + return __awaiter(this, void 0, void 0, function () { + var subscribers_1, texData, shape, texture, values, texShape, dtype, bufferOrTexture, vals, subscribers; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (this.pendingRead.has(dataId)) { + subscribers_1 = this.pendingRead.get(dataId); + return [2, new Promise(function (resolve) { return subscribers_1.push(resolve); })]; + } + this.throwIfNoData(dataId); + texData = this.texData.get(dataId); + shape = texData.shape, texture = texData.texture, values = texData.values, texShape = texData.texShape, dtype = texData.dtype; + if (values != null) { + this.cacheOnCPU(dataId); + return [2, values]; + } + this.pendingRead.set(dataId, []); + if (!ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED') && + ENV.get('WEBGL_VERSION') === 2) { + throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and " + + "WEBGL_VERSION=2 not yet supported."); + } + bufferOrTexture = this.gpgpu.maybeCreateBufferFromTexture(texture, texShape[0], texShape[1]); + return [4, this.gpgpu.createAndWaitForFence()]; + case 1: + _a.sent(); + if (bufferOrTexture instanceof WebGLTexture) { + vals = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape); + } + else { + vals = this.gpgpu.downloadFloat32MatrixFromBuffer(bufferOrTexture, texShape[0], texShape[1]); + } + this.cacheOnCPU(dataId, vals); + subscribers = this.pendingRead.get(dataId); + this.pendingRead.delete(dataId); + subscribers.forEach(function (resolve) { return resolve(vals); }); + if (this.pendingDisposal.has(dataId)) { + this.pendingDisposal.delete(dataId); + this.disposeData(dataId); + } + return [2, vals]; + } + }); + }); + }; + MathBackendWebGL.prototype.getValuesFromTexture = function (texture, dataId, dtype, texShape, shape) { + if (ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED')) { + return this.gpgpu.downloadFloat32MatrixFromOutputTexture(texture, texShape[0], texShape[1]); + } + var tmpTarget = Tensor.make(shape, {}); + this.texData.get(tmpTarget.dataId).usage = TextureUsage.DOWNLOAD; + var tmpInput = Tensor.make(shape, { dataId: dataId }, dtype); + var program = new EncodeFloatProgram(shape); + var pageToCpu = false; + this.compileAndRun(program, [tmpInput], tmpTarget, null, pageToCpu); + var tmpData = this.texData.get(tmpTarget.dataId); + var vals = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(tmpData.texture, tmpData.texShape[0], tmpData.texShape[1]); + tmpInput.dispose(); + tmpTarget.dispose(); + return vals; + }; + MathBackendWebGL.prototype.time = function (f) { + return __awaiter(this, void 0, void 0, function () { + var oldActiveTimers, newActiveTimers, outerMostTime, flattenedActiveTimers, kernelMs, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + oldActiveTimers = this.activeTimers; + newActiveTimers = []; + outerMostTime = false; + if (this.programTimersStack == null) { + this.programTimersStack = newActiveTimers; + outerMostTime = true; + } + else { + this.activeTimers.push(newActiveTimers); + } + this.activeTimers = newActiveTimers; + f(); + flattenedActiveTimers = flatten(this.activeTimers); + this.activeTimers = oldActiveTimers; + if (outerMostTime) { + this.programTimersStack = null; + } + return [4, Promise.all(flattenedActiveTimers).then(function (results) { + var sum = 0; + results.forEach(function (result) { return sum += result; }); + return sum; + })]; + case 1: + kernelMs = _a.sent(); + res = { + uploadWaitMs: this.uploadWaitMs, + downloadWaitMs: this.downloadWaitMs, + kernelMs: kernelMs, + wallMs: null + }; + this.uploadWaitMs = 0; + this.downloadWaitMs = 0; + return [2, res]; + } + }); + }); + }; + MathBackendWebGL.prototype.memory = function () { + return { unreliable: false, numBytesInGPU: this.numBytesInGPU }; + }; + MathBackendWebGL.prototype.startTimer = function () { + if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + return this.gpgpu.beginQuery(); + } + return { startMs: performance.now(), endMs: null }; + }; + MathBackendWebGL.prototype.endTimer = function (query) { + if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + this.gpgpu.endQuery(); + return query; + } + query.endMs = performance.now(); + return query; + }; + MathBackendWebGL.prototype.getQueryTime = function (query) { + return __awaiter(this, void 0, void 0, function () { + var timerQuery; + return __generator(this, function (_a) { + if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) { + return [2, this.gpgpu.waitForQueryAndGetTime(query)]; + } + timerQuery = query; + return [2, timerQuery.endMs - timerQuery.startMs]; + }); + }); + }; + MathBackendWebGL.prototype.disposeData = function (dataId) { + if (this.pendingDisposal.has(dataId)) { + return; + } + if (this.pendingRead.has(dataId)) { + this.pendingDisposal.add(dataId); + return; + } + if (this.texData.has(dataId)) { + var _a = this.texData.get(dataId), texture = _a.texture, texShape = _a.texShape, usage = _a.usage; + if (texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + } + this.texData.delete(dataId); + } + }; + MathBackendWebGL.prototype.getTexture = function (dataId) { + this.uploadToGPU(dataId); + return this.texData.get(dataId).texture; + }; + MathBackendWebGL.prototype.getGPGPUContext = function () { + return this.gpgpu; + }; + MathBackendWebGL.prototype.getCanvas = function () { + return this.canvas; + }; + MathBackendWebGL.prototype.slice = function (x, begin, size) { + var program = new SliceProgram(size); + var customSetup = program.getCustomSetupFunc(begin); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.stridedSlice = function (x, begin, end, strides, beginMask, endMask) { + var _a = getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask), beginIndex = _a[0], size = _a[1]; + if (size.some(function (axis) { return axis === 0; })) { + return tensor([], size); + } + var program = new StridedSliceProgram(beginIndex, strides, size); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.reverse = function (x, axis) { + var program = new ReverseProgram(x.shape, axis); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.concat = function (a, b) { + var program = new ConcatProgram(a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.neg = function (x) { + var program = new UnaryOpProgram(x.shape, NEG); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.matMul = function (a, b, transposeA, transposeB) { + var program = new MatMulProgram(a.shape, b.shape, transposeA, transposeB); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.multiply = function (a, b) { + var program = new BinaryOpProgram(MUL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.batchNormalization = function (x, mean, variance, varianceEpsilon, scale, offset) { + var inputs = [x, mean, variance]; + var offsetShape = null; + if (offset != null) { + offsetShape = offset.shape; + inputs.push(offset); + } + var scaleShape = null; + if (scale != null) { + scaleShape = scale.shape; + inputs.push(scale); + } + var program = new BatchNormProgram(x.shape, mean.shape, variance.shape, offsetShape, scaleShape, varianceEpsilon); + return this.compileAndRun(program, inputs); + }; + MathBackendWebGL.prototype.localResponseNormalization4D = function (x, radius, bias, alpha, beta) { + var program = new LRNProgram(x.shape, radius, bias, alpha, beta); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.LRNGrad = function (dy, inputImage, outputImage, depthRadius, bias, alpha, beta) { + var program = new LRNGradProgram(inputImage.shape, depthRadius, bias, alpha, beta); + return this.compileAndRun(program, [inputImage, outputImage, dy]); + }; + MathBackendWebGL.prototype.tile = function (x, reps) { + var program = new TileProgram(x.shape, reps); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.pad = function (x, paddings, constantValue) { + var program = new PadProgram(x.shape, paddings, constantValue); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.transpose = function (x, perm) { + var program = new TransposeProgram(x.shape, perm); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.gather = function (x, indices, axis) { + var program = new GatherProgram(x.shape, indices.size, axis); + return this.compileAndRun(program, [x, indices]); + }; + MathBackendWebGL.prototype.batchToSpaceND = function (x, blockShape, crops) { + assert(x.rank <= 4, 'batchToSpaceND for rank > 4 with a WebGL backend not implemented yet'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var reshaped = getReshaped(x.shape, blockShape, prod); + var permuted = getPermuted(reshaped.length, blockShape.length); + var reshapedPermuted = getReshapedPermuted(x.shape, blockShape, prod); + var sliceBeginCoords = getSliceBeginCoords(crops, blockShape.length); + var sliceSize = getSliceSize(reshapedPermuted, crops, blockShape.length); + return x.reshape(reshaped) + .transpose(permuted) + .reshape(reshapedPermuted) + .slice(sliceBeginCoords, sliceSize); + }; + MathBackendWebGL.prototype.spaceToBatchND = function (x, blockShape, paddings) { + assert(x.rank <= 4, 'spaceToBatchND for rank > 4 with a WebGL backend not implemented yet'); + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var completePaddings = [[0, 0]]; + completePaddings.push.apply(completePaddings, paddings); + for (var i = 1 + blockShape.length; i < x.shape.length; ++i) { + completePaddings.push([0, 0]); + } + var paddedX = x.pad(completePaddings); + var reshapedPaddedShape = getReshaped(paddedX.shape, blockShape, prod, false); + var permutedReshapedPaddedPermutation = getPermuted(reshapedPaddedShape.length, blockShape.length, false); + var flattenShape = getReshapedPermuted(paddedX.shape, blockShape, prod, false); + return paddedX.reshape(reshapedPaddedShape) + .transpose(permutedReshapedPaddedPermutation) + .reshape(flattenShape); + }; + MathBackendWebGL.prototype.reduce = function (x, reduceType, dtype) { + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + var windowSize = computeOptimalWindowSize(inSize); + var reduceInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize }; + var program = new ReduceProgram(reduceInfo, reduceType); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], dtype); + this.compileAndRun(program, [x], output); + if (output.shape[1] === 1) { + return output; + } + return this.reduce(output, reduceType, dtype); + }; + MathBackendWebGL.prototype.argReduce = function (x, reduceType, bestIndicesA) { + if (bestIndicesA === void 0) { bestIndicesA = null; } + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + if (bestIndicesA != null) { + batchSize = bestIndicesA.shape[0]; + inSize = bestIndicesA.shape[1]; + } + var windowSize = computeOptimalWindowSize(inSize); + var reduceInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize }; + var program = new ArgMinMaxProgram(reduceInfo, reduceType, bestIndicesA == null); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], 'int32'); + var inputs = [x]; + if (bestIndicesA != null) { + inputs.push(bestIndicesA); + } + this.compileAndRun(program, inputs, output); + if (output.shape[1] === 1) { + return output; + } + return this.argReduce(x, reduceType, output); + }; + MathBackendWebGL.prototype.sum = function (x, axes) { + assertAxesAreInnerMostDims('sum', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + var outputDType = sumOutType(x.dtype); + return this.reduce(a2D, 'sum', outputDType).reshape(outShape); + }; + MathBackendWebGL.prototype.unsortedSegmentSum = function (x, segmentIds, numSegments) { + var axis = 0; + var permutation = getAxesPermutation([axis], x.rank); + var permutedX = x; + if (permutation != null) { + permutedX = x.transpose(permutation); + axis = getInnerMostAxes(1, x.rank)[0]; + } + var outShape = computeOutShape(permutedX.shape, axis, numSegments); + var inSize = sizeFromShape([permutedX.shape[axis]]); + var a2D = permutedX.as2D(-1, inSize); + var outputDType = sumOutType(x.dtype); + var result = this.segOpCompute(a2D, 'unsortedSegmentSum', segmentIds, outputDType, numSegments) + .reshape(outShape); + if (permutation != null) { + result = result.transpose(getUndoAxesPermutation(permutation)); + } + return result; + }; + MathBackendWebGL.prototype.segOpCompute = function (x, segOpType, segmentIds, dtype, numSegments) { + var batchSize = x.shape[0]; + var inSize = x.shape[1]; + var windowSize = segOpComputeOptimalWindowSize(inSize, numSegments); + var segOpInfo = { windowSize: windowSize, inSize: inSize, batchSize: batchSize, numSegments: numSegments }; + var program = new SegmentOpProgram(segOpInfo, segOpType); + var _a = program.outputShape, rows = _a[0], cols = _a[1]; + var output = this.makeOutputArray([rows, cols], dtype); + this.compileAndRun(program, [x, segmentIds], output); + if (output.shape[1] === numSegments) { + return output; + } + segmentIds = range(0, numSegments).tile([inSize / windowSize]); + return this.segOpCompute(output, segOpType, segmentIds, dtype, numSegments); + }; + MathBackendWebGL.prototype.argMin = function (x, axis) { + var axes = [axis]; + assertAxesAreInnerMostDims('argMin', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.argReduce(a2D, 'min').reshape(outShape); + }; + MathBackendWebGL.prototype.argMax = function (x, axis) { + var axes = [axis]; + assertAxesAreInnerMostDims('argMax', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.argReduce(a2D, 'max').reshape(outShape); + }; + MathBackendWebGL.prototype.cumsum = function (x, axis, exclusive, reverse) { + if (axis !== x.rank - 1) { + throw new Error("WebGL cumsum shader expects an inner-most axis=" + (x.rank - 1) + " " + + ("but got axis=" + axis)); + } + var program = new CumSumProgram(x.shape, exclusive, reverse); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.equal = function (a, b) { + var program = new BinaryOpProgram(EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.notEqual = function (a, b) { + var program = new BinaryOpProgram(NOT_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.less = function (a, b) { + var program = new BinaryOpProgram(LESS, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.lessEqual = function (a, b) { + var program = new BinaryOpProgram(LESS_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.greater = function (a, b) { + var program = new BinaryOpProgram(GREATER, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.greaterEqual = function (a, b) { + var program = new BinaryOpProgram(GREATER_EQUAL, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.logicalNot = function (x) { + var program = new UnaryOpProgram(x.shape, LOGICAL_NOT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.logicalAnd = function (a, b) { + var program = new BinaryOpProgram(LOGICAL_AND, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.logicalOr = function (a, b) { + var program = new BinaryOpProgram(LOGICAL_OR, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, 'bool'); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.select = function (condition, a, b) { + var program = new SelectProgram(condition.rank, a.shape, a.rank); + var output = this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [condition, a, b], output); + }; + MathBackendWebGL.prototype.where = function (condition) { + warn('tf.where() in webgl locks the UI thread. ' + + 'Call tf.whereAsync() instead'); + var condVals = condition.dataSync(); + return whereImpl(condition.shape, condVals); + }; + MathBackendWebGL.prototype.topk = function (x, k, sorted) { + var xVals = x.dataSync(); + return topkImpl(xVals, x.shape, x.dtype, k, sorted); + }; + MathBackendWebGL.prototype.min = function (x, axes) { + assertAxesAreInnerMostDims('min', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'min', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.minimum = function (a, b) { + var program = new BinaryOpProgram(MIN, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.mod = function (a, b) { + var program = new BinaryOpProgram(MOD, a.shape, b.shape); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [a, b], null, customSetup); + }; + MathBackendWebGL.prototype.max = function (x, axes) { + assertAxesAreInnerMostDims('max', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'max', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.maximum = function (a, b) { + var program = new BinaryOpProgram(MAX, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.all = function (x, axes) { + assertAxesAreInnerMostDims('all', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'all', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.any = function (x, axes) { + assertAxesAreInnerMostDims('any', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var inSize = sizeFromShape(reduceShape); + var a2D = x.as2D(-1, inSize); + return this.reduce(a2D, 'any', a2D.dtype).reshape(outShape); + }; + MathBackendWebGL.prototype.squaredDifference = function (a, b) { + var program = new BinaryOpProgram(SQUARED_DIFFERENCE, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.realDivide = function (a, b) { + var op = DIV; + var outputDtype = 'float32'; + var program = new BinaryOpProgram(op, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, outputDtype); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.floorDiv = function (a, b) { + var op = INT_DIV; + var outputDtype = 'int32'; + var program = new BinaryOpProgram(op, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, outputDtype); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.add = function (a, b) { + var program = new BinaryOpProgram(ADD, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.addN = function (tensors) { + var res = tensors[0]; + for (var i = 1; i < tensors.length; i++) { + res = this.add(res, tensors[i]); + } + return res; + }; + MathBackendWebGL.prototype.subtract = function (a, b) { + var program = new BinaryOpProgram(SUB, a.shape, b.shape); + var output = this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output); + }; + MathBackendWebGL.prototype.pow = function (a, b) { + var program = new BinaryOpProgram(POW, a.shape, b.shape); + var customSetup = program.getCustomSetupFunc(); + var output = this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype)); + return this.compileAndRun(program, [a, b], output, customSetup); + }; + MathBackendWebGL.prototype.ceil = function (x) { + var program = new UnaryOpProgram(x.shape, CEIL); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.floor = function (x) { + var program = new UnaryOpProgram(x.shape, FLOOR); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sign = function (x) { + var program = new UnaryOpProgram(x.shape, SIGN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.round = function (x) { + var program = new UnaryOpProgram(x.shape, ROUND); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.exp = function (x) { + var program = new UnaryOpProgram(x.shape, EXP); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.expm1 = function (x) { + var program = new UnaryOpProgram(x.shape, EXPM1); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.log = function (x) { + var program = new UnaryOpProgram(x.shape, LOG); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.log1p = function (x) { + var program = new UnaryOpProgram(x.shape, LOG1P); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sqrt = function (x) { + var program = new UnaryOpProgram(x.shape, SQRT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.rsqrt = function (x) { + var program = new UnaryOpProgram(x.shape, RSQRT); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.square = function (x) { + var program = new UnaryOpProgram(x.shape, SQUARE); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.reciprocal = function (x) { + var program = new UnaryOpProgram(x.shape, RECIPROCAL); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.relu = function (x) { + var program = new UnaryOpProgram(x.shape, RELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.elu = function (x) { + var program = new UnaryOpProgram(x.shape, ELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.eluDer = function (dy, y) { + var program = new BinaryOpProgram(ELU_DER, dy.shape, y.shape); + return this.compileAndRun(program, [dy, y]); + }; + MathBackendWebGL.prototype.selu = function (x) { + var program = new UnaryOpProgram(x.shape, SELU); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.int = function (x) { + var program = new UnaryOpProgram(x.shape, TO_INT); + var output = this.makeOutputArray(program.outputShape, 'int32'); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.clip = function (x, min, max) { + var program = new ClipProgram(x.shape, min, max); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.abs = function (x) { + var program = new UnaryOpProgram(x.shape, ABS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sigmoid = function (x) { + var program = new UnaryOpProgram(x.shape, SIGMOID); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.softplus = function (x) { + var program = new UnaryOpProgram(x.shape, SOFTPLUS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.sin = function (x) { + var program = new UnaryOpProgram(x.shape, SIN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.cos = function (x) { + var program = new UnaryOpProgram(x.shape, COS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.tan = function (x) { + var program = new UnaryOpProgram(x.shape, TAN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.asin = function (x) { + var program = new UnaryOpProgram(x.shape, ASIN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.acos = function (x) { + var program = new UnaryOpProgram(x.shape, ACOS); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.atan = function (x) { + var program = new UnaryOpProgram(x.shape, ATAN); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.atan2 = function (a, b) { + var program = new BinaryOpProgram(ATAN2, a.shape, b.shape); + return this.compileAndRun(program, [a, b]); + }; + MathBackendWebGL.prototype.sinh = function (x) { + var program = new UnaryOpProgram(x.shape, SINH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.cosh = function (x) { + var program = new UnaryOpProgram(x.shape, COSH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.tanh = function (x) { + var program = new UnaryOpProgram(x.shape, TANH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.asinh = function (x) { + var program = new UnaryOpProgram(x.shape, ASINH); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.acosh = function (x) { + var program = new UnaryOpProgram(x.shape, ACOSH); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.atanh = function (x) { + var program = new UnaryOpProgram(x.shape, ATANH); + var customSetup = program.getCustomSetupFunc(); + return this.compileAndRun(program, [x], null, customSetup); + }; + MathBackendWebGL.prototype.erf = function (x) { + var program = new UnaryOpProgram(x.shape, ERF); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.step = function (x, alpha) { + var program = new UnaryOpProgram(x.shape, STEP(alpha)); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.conv2d = function (x, filter, convInfo) { + var program = new Conv2DProgram(convInfo); + return this.compileAndRun(program, [x, filter]); + }; + MathBackendWebGL.prototype.conv2dDerInput = function (dy, filter, convInfo) { + var program = new Conv2DDerInputProgram(convInfo); + return this.compileAndRun(program, [dy, filter]); + }; + MathBackendWebGL.prototype.conv2dDerFilter = function (x, dy, convInfo) { + var program = new Conv2DDerFilterProgram(convInfo); + return this.compileAndRun(program, [x, dy]); + }; + MathBackendWebGL.prototype.depthwiseConv2D = function (x, filter, convInfo) { + var program = new DepthwiseConv2DProgram(convInfo); + return this.compileAndRun(program, [x, filter]); + }; + MathBackendWebGL.prototype.depthwiseConv2DDerInput = function (dy, filter, convInfo) { + var program = new DepthwiseConv2DDerInputProgram(convInfo); + return this.compileAndRun(program, [dy, filter]); + }; + MathBackendWebGL.prototype.depthwiseConv2DDerFilter = function (x, dy, convInfo) { + var program = new DepthwiseConv2DDerFilterProgram(convInfo); + return this.compileAndRun(program, [x, dy]); + }; + MathBackendWebGL.prototype.maxPool = function (x, convInfo) { + var program = new Pool2DProgram(convInfo, 'max', false); + var output = this.makeOutputArray(program.outputShape, x.dtype); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.avgPool = function (x, convInfo) { + var program = new Pool2DProgram(convInfo, 'avg', false); + var output = this.makeOutputArray(program.outputShape, 'float32'); + return this.compileAndRun(program, [x], output); + }; + MathBackendWebGL.prototype.maxPoolBackprop = function (dy, x, y, convInfo) { + var getPositions = true; + var maxPoolPositionsProgram = new Pool2DProgram(convInfo, 'max', getPositions); + var maxPoolPositions = this.compileAndRun(maxPoolPositionsProgram, [x]); + var maxPoolBackPropProgram = new MaxPool2DBackpropProgram(convInfo); + var output = this.makeOutputArray(maxPoolBackPropProgram.outputShape, x.dtype); + var result = this.compileAndRun(maxPoolBackPropProgram, [dy, maxPoolPositions], output); + maxPoolPositions.dispose(); + return result; + }; + MathBackendWebGL.prototype.avgPoolBackprop = function (dy, x, convInfo) { + var avgPoolBackpropProgram = new AvgPool2DBackpropProgram(convInfo); + var output = this.makeOutputArray(avgPoolBackpropProgram.outputShape, x.dtype); + return this.compileAndRun(avgPoolBackpropProgram, [dy], output); + }; + MathBackendWebGL.prototype.cast = function (x, dtype) { + return castTensor(x, dtype, this); + }; + MathBackendWebGL.prototype.reshape = function (x, shape) { + return reshapeTensor(x, shape); + }; + MathBackendWebGL.prototype.resizeBilinear = function (x, newHeight, newWidth, alignCorners) { + var program = new ResizeBilinearProgram(x.shape, newHeight, newWidth, alignCorners); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.resizeBilinearBackprop = function (dy, x, alignCorners) { + var program = new ResizeBilinearBackpropProgram(dy, x, alignCorners); + return this.compileAndRun(program, [dy]); + }; + MathBackendWebGL.prototype.resizeNearestNeighbor = function (x, newHeight, newWidth, alignCorners) { + var program = new ResizeNearestNeighborProgram(x.shape, newHeight, newWidth, alignCorners); + return this.compileAndRun(program, [x]); + }; + MathBackendWebGL.prototype.resizeNearestNeighborBackprop = function (dy, x, alignCorners) { + var program = new ResizeNearestNeigborBackpropProgram(dy, x, alignCorners); + return this.compileAndRun(program, [dy]); + }; + MathBackendWebGL.prototype.multinomial = function (logits, normalized, numSamples, seed) { + var probs = normalized ? logits : softmax(logits); + var batchSize = probs.shape[0]; + var numOutcomes = probs.shape[1]; + var program = new MultinomialProgram(batchSize, numOutcomes, numSamples); + var output = this.makeOutputArray(program.outputShape, 'int32'); + var customSetup = program.getCustomSetupFunc(seed); + return this.compileAndRun(program, [probs], output, customSetup); + }; + MathBackendWebGL.prototype.oneHot = function (indices, depth, onValue, offValue) { + var program = new OneHotProgram(indices.size, depth, onValue, offValue); + return this.compileAndRun(program, [indices]); + }; + MathBackendWebGL.prototype.nonMaxSuppression = function (boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + warn('tf.nonMaxSuppression() in webgl locks the UI thread. ' + + 'Call tf.nonMaxSuppressionAsync() instead'); + var boxesVals = boxes.dataSync(); + var scoresVals = scores.dataSync(); + return nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + }; + MathBackendWebGL.prototype.makeOutputArray = function (shape, dtype) { + return Tensor.make(shape, {}, dtype); + }; + MathBackendWebGL.prototype.compileAndRun = function (program, inputs, output, customSetup, pageToCpu) { + var _this = this; + if (pageToCpu === void 0) { pageToCpu = true; } + if (output == null) { + output = this.makeOutputArray(program.outputShape, inputs[0].dtype); + } + var inputsData = inputs.map(function (tensor$$1) { + var texData = _this.texData.get(tensor$$1.dataId); + if (texData.texture == null && tensor$$1.size <= SIZE_UPLOAD_UNIFORM) { + return { tensor: tensor$$1, texData: null, isUniform: true }; + } + _this.uploadToGPU(tensor$$1.dataId); + return { tensor: tensor$$1, texData: texData, isUniform: false }; + }); + this.uploadToGPU(output.dataId); + var outputData = { + tensor: output, + texData: this.texData.get(output.dataId), + isUniform: false + }; + var key = makeShaderKey(program, inputsData, outputData); + var binary = this.getAndSaveBinary(key, function () { + return compileProgram(_this.gpgpu, program, inputsData, outputData); + }); + var shouldTimeProgram = this.activeTimers != null; + var query; + if (shouldTimeProgram) { + query = this.startTimer(); + } + runProgram(binary, inputsData, outputData, customSetup); + if (pageToCpu && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) { + var numBytesToPage = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING; + while (numBytesToPage > 0 && this.lruDataGPU.length > 0) { + var dataId = this.lruDataGPU.shift(); + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + numBytesToPage -= this.computeBytes(shape, dtype); + this.read(dataId); + } + } + if (shouldTimeProgram) { + query = this.endTimer(query); + this.activeTimers.push(this.getQueryTime(query)); + } + return output; + }; + MathBackendWebGL.prototype.getAndSaveBinary = function (key, getBinary) { + if (!(key in this.binaryCache)) { + this.binaryCache[key] = getBinary(); + } + return this.binaryCache[key]; + }; + MathBackendWebGL.prototype.getTextureManager = function () { + return this.textureManager; + }; + MathBackendWebGL.prototype.dispose = function () { + if (this.disposed) { + return; + } + for (var key in this.binaryCache) { + this.gpgpu.deleteProgram(this.binaryCache[key].webGLProgram); + } + this.textureManager.dispose(); + this.canvas.remove(); + if (this.fromPixelsCanvas != null) { + this.fromPixelsCanvas.remove(); + } + if (this.gpgpuCreatedLocally) { + this.gpgpu.dispose(); + } + this.disposed = true; + }; + MathBackendWebGL.prototype.throwIfNoData = function (dataId) { + if (!this.texData.has(dataId)) { + throw new Error("WebGL backend: No data found for this tensor. " + + "Did you change your backend in the middle of the program? " + + "New backends can't use Tensors created with previous backends"); + } + }; + MathBackendWebGL.prototype.uploadToGPU = function (dataId) { + this.throwIfNoData(dataId); + var texData = this.texData.get(dataId); + var shape = texData.shape, values = texData.values, texture = texData.texture, dtype = texData.dtype, usage = texData.usage; + if (texture != null) { + var index = this.lruDataGPU.indexOf(dataId); + if (index >= 0) { + this.lruDataGPU.splice(this.lruDataGPU.indexOf(dataId), 1); + this.lruDataGPU.push(dataId); + } + return; + } + var shouldTimeProgram = this.activeTimers != null; + var start; + if (shouldTimeProgram) { + start = performance.now(); + } + var texShape = getTextureShapeFromLogicalShape(this.gpgpu.gl, shape); + texData.texShape = texShape; + var newTexture = this.acquireTexture(dataId, texShape, usage); + texData.texture = newTexture; + if (values != null) { + this.gpgpu.uploadMatrixToTexture(newTexture, texShape[0], texShape[1], typedArrayToFloat32(values, dtype)); + texData.values = null; + if (shouldTimeProgram) { + this.uploadWaitMs += performance.now() - start; + } + } + }; + MathBackendWebGL.prototype.cacheOnCPU = function (dataId, float32Values) { + var dontKeepCopyOnGPU = this.delayedStorage; + var texData = this.texData.get(dataId); + var texture = texData.texture, texShape = texData.texShape, dtype = texData.dtype, usage = texData.usage; + if (dontKeepCopyOnGPU && texture != null) { + this.releaseTexture(dataId, texture, texShape, usage); + texData.texture = null; + texData.texShape = null; + } + if (float32Values != null) { + texData.values = float32ToTypedArray(float32Values, dtype); + } + }; + MathBackendWebGL.prototype.releaseTexture = function (dataId, texture, texShape, texType) { + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + var idx = this.lruDataGPU.indexOf(dataId); + if (idx >= 0) { + this.lruDataGPU.splice(idx, 1); + } + this.numBytesInGPU -= this.computeBytes(shape, dtype); + this.textureManager.releaseTexture(texture, texShape, texType); + }; + MathBackendWebGL.prototype.acquireTexture = function (dataId, texShape, texType) { + var _a = this.texData.get(dataId), shape = _a.shape, dtype = _a.dtype; + this.lruDataGPU.push(dataId); + this.numBytesInGPU += this.computeBytes(shape, dtype); + return this.textureManager.acquireTexture(texShape, texType); + }; + MathBackendWebGL.prototype.computeBytes = function (shape, dtype) { + return sizeFromShape(shape) * bytesPerElement(dtype); + }; + return MathBackendWebGL; + }()); + if (ENV.get('IS_BROWSER')) { + ENV.registerBackend('webgl', function () { return new MathBackendWebGL(); }, 2, setTensorTracker); + } + function float32ToTypedArray(a, dtype) { + if (dtype === 'float32') { + return a; + } + else if (dtype === 'int32' || dtype === 'bool') { + var result = (dtype === 'int32') ? new Int32Array(a.length) : + new Uint8Array(a.length); + for (var i = 0; i < result.length; ++i) { + result[i] = Math.round(a[i]); + } + return result; + } + else { + throw new Error("Unknown dtype " + dtype); + } + } + function typedArrayToFloat32(a, dtype) { + return (a instanceof Float32Array) ? a : new Float32Array(a); + } + + function neg_(x) { + var $x = convertToTensor(x, 'x', 'neg'); + var grad = function (dy) { + return { $x: function () { return dy.neg(); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.neg($x); }, { $x: $x }, grad); + } + function ceil_(x) { + var $x = convertToTensor(x, 'x', 'ceil'); + var grad = function (dy) { + return { $x: function () { return zerosLike(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.ceil($x); }, { $x: $x }, grad); + } + function floor_(x) { + var $x = convertToTensor(x, 'x', 'floor'); + var grad = function (dy) { + return { $x: function () { return zerosLike(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.floor($x); }, { $x: $x }, grad); + } + function sign_(x) { + var $x = convertToTensor(x, 'x', 'sign'); + var grad = function (dy) { + return { $x: function () { return zerosLike(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.sign($x); }, { $x: $x }, grad); + } + function round_(x) { + var $x = convertToTensor(x, 'x', 'round'); + var grad = function (dy) { + return { $x: function () { return zerosLike(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.round($x); }, { $x: $x }, grad); + } + function exp_(x) { + var $x = convertToTensor(x, 'x', 'exp'); + var bck = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return dy.mulStrict(y); } }; + }; + return ENV.engine.runKernel(function (backend, save) { return save(backend.exp($x)); }, { $x: $x }, bck); + } + function expm1_(x) { + var $x = convertToTensor(x, 'x', 'expm1'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.exp()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.expm1($x); }, { $x: $x }, grad); + } + function log_(x) { + var $x = convertToTensor(x, 'x', 'log'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.toFloat()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.log($x); }, { $x: $x }, grad); + } + function log1p_(x) { + var $x = convertToTensor(x, 'x', 'log1p'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.add(scalar(1))); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.log1p($x); }, { $x: $x }, grad); + } + function sqrt_(x) { + var $x = convertToTensor(x, 'x', 'sqrt'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.toFloat().sqrt().mul(scalar(2))); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.sqrt($x); }, { $x: $x }, grad); + } + function rsqrt_(x) { + var $x = convertToTensor(x, 'x', 'rsqrt'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.pow(scalar(1.5)).mul(scalar(2))).neg(); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.rsqrt($x); }, { $x: $x }, grad); + } + function square_(x) { + var $x = convertToTensor(x, 'x', 'square'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.toFloat().mul(scalar(2))); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.square($x); }, { $x: $x }, grad); + } + function reciprocal_(x) { + var $x = convertToTensor(x, 'x', 'reciprocal'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.square().neg()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.reciprocal($x); }, { $x: $x }, grad); + } + function abs_(x) { + var $x = convertToTensor(x, 'x', 'abs'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.toFloat().step(-1)); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.abs($x); }, { $x: $x }, grad); + } + function clipByValue_(x, clipValueMin, clipValueMax) { + var $x = convertToTensor(x, 'x', 'clipByValue'); + assert((clipValueMin <= clipValueMax), "Error in clip: min (" + clipValueMin + ") must be " + + ("less than or equal to max (" + clipValueMax + ").")); + var grad = function (dy) { + return { + $x: function () { return dy.where($x.greaterEqual(scalar(clipValueMin)) + .logicalAnd($x.lessEqual(scalar(clipValueMax))), zerosLike(dy)); }, + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.clip($x, clipValueMin, clipValueMax); }, { $x: $x }, grad); + } + function sigmoid_(x) { + var $x = convertToTensor(x, 'x', 'sigmoid'); + var grad = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return dy.mulStrict(y.mul(scalar(1).sub(y))); } }; + }; + return ENV.engine.runKernel(function (backend, save) { return save(backend.sigmoid($x)); }, { $x: $x }, grad); + } + function logSigmoid_(x) { + var $x = convertToTensor(x, 'x', 'logSigmoid'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.neg().sigmoid()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.softplus($x.neg()).neg(); }, { $x: $x }, grad); + } + function softplus_(x) { + var $x = convertToTensor(x, 'x', 'softplus'); + var grad = function (dy) { + return { $x: function () { return dy.mulStrict($x.sigmoid()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.softplus($x); }, { $x: $x }, grad); + } + function sin_(x) { + var $x = convertToTensor(x, 'x', 'sin'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().cos().mulStrict(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.sin($x); }, { $x: $x }, grad); + } + function cos_(x) { + var $x = convertToTensor(x, 'x', 'cos'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().sin().neg().mulStrict(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.cos($x); }, { $x: $x }, grad); + } + function tan_(x) { + var $x = convertToTensor(x, 'x', 'tan'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict($x.cos().square()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.tan($x); }, { $x: $x }, grad); + } + function asin_(x) { + var $x = convertToTensor(x, 'x', 'asin'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt()); } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.asin($x); }, { $x: $x }, grad); + } + function acos_(x) { + var $x = convertToTensor(x, 'x', 'acos'); + var grad = function (dy) { + return { + $x: function () { + return dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt()).neg(); + } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.acos($x); }, { $x: $x }, grad); + } + function atan_(x) { + var $x = convertToTensor(x, 'x', 'atan'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict(scalar(1).add($x.toFloat().square())); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.atan($x); }, { $x: $x }, grad); + } + function sinh_(x) { + var $x = convertToTensor(x, 'x', 'sinh'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().cosh().mulStrict(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.sinh($x); }, { $x: $x }, grad); + } + function cosh_(x) { + var $x = convertToTensor(x, 'x', 'cosh'); + var grad = function (dy) { + return { $x: function () { return $x.toFloat().sinh().mulStrict(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.cosh($x); }, { $x: $x }, grad); + } + function tanh_(x) { + var $x = convertToTensor(x, 'x', 'tanh'); + var grad = function (dy, saved) { + var y = saved[0]; + return { $x: function () { return scalar(1).sub(y.square()).mulStrict(dy); } }; + }; + return ENV.engine.runKernel(function (backend, save) { return save(backend.tanh($x)); }, { $x: $x }, grad); + } + function asinh_(x) { + var $x = convertToTensor(x, 'x', 'asinh'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict(scalar(1).add($x.toFloat().square()).sqrt()); } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.asinh($x); }, { $x: $x }, grad); + } + function acosh_(x) { + var $x = convertToTensor(x, 'x', 'acosh'); + var grad = function (dy) { + return { + $x: function () { return dy.divStrict($x.toFloat().square().sub(scalar(1)).sqrt()); } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.acosh($x); }, { $x: $x }, grad); + } + function atanh_(x) { + var $x = convertToTensor(x, 'x', 'atanh'); + var grad = function (dy) { + return { $x: function () { return dy.divStrict(scalar(1).sub($x.toFloat().square())); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.atanh($x); }, { $x: $x }, grad); + } + function erf_(x) { + var $x = convertToTensor(x, 'x', 'erf'); + assert($x.dtype === 'int32' || $x.dtype === 'float32', 'Input dtype must be `int32` or `float32`.'); + if ($x.dtype === 'int32') { + $x = $x.toFloat(); + } + var grad = function (dy) { + return { + $x: function () { return dy.mulStrict(scalar(2 / Math.sqrt(Math.PI)).mul($x.square().neg().exp())); } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.erf($x); }, { $x: $x }, grad); + } + function step_(x, alpha) { + if (alpha === void 0) { alpha = 0.0; } + var $x = convertToTensor(x, 'x', 'step'); + var grad = function (dy) { + return { $x: function () { return zerosLike(dy); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.step($x, alpha); }, { $x: $x }, grad); + } + var abs = op({ abs_: abs_ }); + var acos = op({ acos_: acos_ }); + var acosh = op({ acosh_: acosh_ }); + var asin = op({ asin_: asin_ }); + var asinh = op({ asinh_: asinh_ }); + var atan = op({ atan_: atan_ }); + var atanh = op({ atanh_: atanh_ }); + var ceil = op({ ceil_: ceil_ }); + var clipByValue = op({ clipByValue_: clipByValue_ }); + var cos = op({ cos_: cos_ }); + var cosh = op({ cosh_: cosh_ }); + var erf = op({ erf_: erf_ }); + var exp = op({ exp_: exp_ }); + var expm1 = op({ expm1_: expm1_ }); + var floor = op({ floor_: floor_ }); + var log$1 = op({ log_: log_ }); + var log1p = op({ log1p_: log1p_ }); + var logSigmoid = op({ logSigmoid_: logSigmoid_ }); + var neg = op({ neg_: neg_ }); + var reciprocal = op({ reciprocal_: reciprocal_ }); + var round = op({ round_: round_ }); + var rsqrt = op({ rsqrt_: rsqrt_ }); + var sigmoid = op({ sigmoid_: sigmoid_ }); + var sign = op({ sign_: sign_ }); + var sin = op({ sin_: sin_ }); + var sinh = op({ sinh_: sinh_ }); + var softplus = op({ softplus_: softplus_ }); + var sqrt = op({ sqrt_: sqrt_ }); + var square = op({ square_: square_ }); + var step = op({ step_: step_ }); + var tan = op({ tan_: tan_ }); + var tanh$1 = op({ tanh_: tanh_ }); + + function batchNormalization2d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = convertToTensor(x, 'x', 'batchNormalization'); + var $mean = convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = convertToTensor(offset, 'offset', 'batchNormalization'); + } + assert($x.rank === 2, "Error in batchNormalization3D: x must be rank 3 but got rank " + + ($x.rank + ".")); + assert($mean.rank === 2 || $mean.rank === 1, "Error in batchNormalization2D: mean must be rank 2 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + assert($variance.rank === 2 || $variance.rank === 1, "Error in batchNormalization2D: variance must be rank 2 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + assert($scale.rank === 2 || $scale.rank === 1, "Error in batchNormalization2D: scale must be rank 2 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + assert($offset.rank === 2 || $offset.rank === 1, "Error in batchNormalization2D: offset must be rank 2 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); + } + function batchNormalization3d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = convertToTensor(x, 'x', 'batchNormalization'); + var $mean = convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = convertToTensor(offset, 'offset', 'batchNormalization'); + } + assert($x.rank === 3, "Error in batchNormalization3D: x must be rank 3 but got rank " + + ($x.rank + ".")); + assert($mean.rank === 3 || $mean.rank === 1, "Error in batchNormalization3D: mean must be rank 3 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + assert($variance.rank === 3 || $variance.rank === 1, "Error in batchNormalization3D: variance must be rank 3 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + assert($scale.rank === 3 || $scale.rank === 1, "Error in batchNormalization3D: scale must be rank 3 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + assert($offset.rank === 3 || $offset.rank === 1, "Error in batchNormalization3D: offset must be rank 3 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); + } + function batchNormalization4d_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = convertToTensor(x, 'x', 'batchNormalization'); + var $mean = convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = convertToTensor(offset, 'offset', 'batchNormalization'); + } + assert($x.rank === 4, "Error in batchNormalization4D: x must be rank 4 but got rank " + + ($x.rank + ".")); + assert($mean.rank === 4 || $mean.rank === 1, "Error in batchNormalization4D: mean must be rank 4 or rank 1 but " + + ("got rank " + $mean.rank + ".")); + assert($variance.rank === 4 || $variance.rank === 1, "Error in batchNormalization4D: variance must be rank 4 or rank 1 " + + ("but got rank " + $variance.rank + ".")); + if ($scale != null) { + assert($scale.rank === 4 || $scale.rank === 1, "Error in batchNormalization4D: scale must be rank 4 or rank 1 " + + ("but got rank " + $scale.rank + ".")); + } + if ($offset != null) { + assert($offset.rank === 4 || $offset.rank === 1, "Error in batchNormalization4D: offset must be rank 4 or rank 1 " + + ("but got rank " + $offset.rank + ".")); + } + return batchNormalization($x, $mean, $variance, varianceEpsilon, $scale, $offset); + } + function batchNormalization_(x, mean, variance, varianceEpsilon, scale, offset) { + if (varianceEpsilon === void 0) { varianceEpsilon = .001; } + var $x = convertToTensor(x, 'x', 'batchNormalization'); + var $mean = convertToTensor(mean, 'mean', 'batchNormalization'); + var $variance = convertToTensor(variance, 'variance', 'batchNormalization'); + var $scale; + if (scale != null) { + $scale = convertToTensor(scale, 'scale', 'batchNormalization'); + } + var $offset; + if (offset != null) { + $offset = convertToTensor(offset, 'offset', 'batchNormalization'); + } + assert($mean.rank === $variance.rank, 'Batch normalization gradient requires mean and variance to have ' + + 'equal ranks.'); + assert($offset == null || $mean.rank === $offset.rank, 'Batch normalization gradient requires mean and offset to have ' + + 'equal ranks.'); + assert($scale == null || $mean.rank === $scale.rank, 'Batch normalization gradient requires mean and scale to have ' + + 'equal ranks.'); + var x4D; + if ($x.rank === 0 || $x.rank === 1) { + x4D = $x.as4D(1, 1, 1, $x.size); + } + else if ($x.rank === 2) { + x4D = $x.as4D(1, 1, $x.shape[0], $x.shape[1]); + } + else if ($x.rank === 3) { + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + else { + x4D = $x; + } + var der = function (dy) { + var scaleValue = $scale == null ? scalar(1) : $scale; + var reductionAxes = getReductionAxes($mean.shape, x4D.shape); + var tileShape = []; + if ($mean.rank === 1) { + for (var i = 0; i < x4D.shape.length - 1; ++i) { + tileShape.push(x4D.shape[i]); + } + tileShape.push(1); + } + var xMinusMean = $x.sub($mean); + var dyTimesScaleValue = dy.mul(scaleValue); + var oneOverSqrtVariance = rsqrt($variance.add(scalar(varianceEpsilon))); + var minusHalfRCube = oneOverSqrtVariance.mul(oneOverSqrtVariance) + .mul(oneOverSqrtVariance) + .mul(scalar(-0.5)); + var derX = function () { + if ($mean.rank === 1) { + return dy + .mul(tile(oneOverSqrtVariance.as4D(1, 1, 1, $mean.shape[0]), tileShape)) + .mul(scaleValue) + .reshape($x.shape); + } + else { + return dy.mul(oneOverSqrtVariance).mul(scaleValue).reshape($x.shape); + } + }; + var derMean = function () { + var meanDer = oneOverSqrtVariance.mul(scalar(-1)).mul(dyTimesScaleValue); + if ($mean.rank === 1) { + meanDer = meanDer.sum(reductionAxes); + } + return meanDer.reshape($mean.shape); + }; + var derVariance = function () { + var varianceDer = minusHalfRCube.mul(xMinusMean).mul(dyTimesScaleValue); + if ($mean.rank === 1) { + varianceDer = varianceDer.sum(reductionAxes); + } + return varianceDer.reshape($mean.shape); + }; + var derScale = function () { + var xMinusMean2TimesRsqrt = xMinusMean.mul(oneOverSqrtVariance); + var scaleDer = dy.mul(xMinusMean2TimesRsqrt); + if ($mean.rank === 1) { + scaleDer = scaleDer.sum(reductionAxes); + } + return scaleDer.reshape($mean.shape); + }; + var derOffset = function () { + var offsetDer = dy; + if ($mean.rank === 1) { + offsetDer = offsetDer.sum(reductionAxes); + } + return offsetDer.reshape($mean.shape); + }; + return { + $x: derX, + $mean: derMean, + $variance: derVariance, + $scale: derScale, + $offset: derOffset + }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.batchNormalization(x4D, batchnormReshape4D($mean), batchnormReshape4D($variance), varianceEpsilon, batchnormReshape4D($scale), batchnormReshape4D($offset)); }, { $x: $x, $mean: $mean, $variance: $variance, $scale: $scale, $offset: $offset }, der); + return res.reshape($x.shape); + } + function batchnormReshape4D(x) { + if (x == null) { + return null; + } + if (x.rank === 0) { + return x.as1D(); + } + else if (x.rank === 1) { + return x; + } + else if (x.rank === 2) { + return x.as4D(1, 1, x.shape[0], x.shape[1]); + } + else if (x.rank === 3) { + return x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + return x; + } + var batchNormalization2d = op({ batchNormalization2d_: batchNormalization2d_ }); + var batchNormalization3d = op({ batchNormalization3d_: batchNormalization3d_ }); + var batchNormalization4d = op({ batchNormalization4d_: batchNormalization4d_ }); + var batchNormalization = op({ batchNormalization_: batchNormalization_ }); + + function computePool2DInfo(inShape, filterSize, strides, pad, roundingMode, dataFormat) { + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var _a = parseTupleParam(filterSize), filterHeight = _a[0], filterWidth = _a[1]; + var filterShape; + if (dataFormat === 'channelsLast') { + filterShape = [filterHeight, filterWidth, inShape[3], inShape[3]]; + } + else if (dataFormat === 'channelsFirst') { + filterShape = [filterHeight, filterWidth, inShape[1], inShape[1]]; + } + else { + throw new Error("Unknown dataFormat " + dataFormat); + } + var dilations = 1; + return computeConv2DInfo(inShape, filterShape, strides, dilations, pad, roundingMode, false, dataFormat); + } + function computeConv2DInfo(inShape, filterShape, strides, dilations, pad, roundingMode, depthwise, dataFormat) { + if (depthwise === void 0) { depthwise = false; } + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var _a = [-1, -1, -1, -1], batchSize = _a[0], inHeight = _a[1], inWidth = _a[2], inChannels = _a[3]; + if (dataFormat === 'channelsLast') { + batchSize = inShape[0], inHeight = inShape[1], inWidth = inShape[2], inChannels = inShape[3]; + } + else if (dataFormat === 'channelsFirst') { + batchSize = inShape[0], inChannels = inShape[1], inHeight = inShape[2], inWidth = inShape[3]; + } + else { + throw new Error("Unknown dataFormat " + dataFormat); + } + var filterHeight = filterShape[0], filterWidth = filterShape[1], filterChannels = filterShape[3]; + var _b = parseTupleParam(strides), strideHeight = _b[0], strideWidth = _b[1]; + var _c = parseTupleParam(dilations), dilationHeight = _c[0], dilationWidth = _c[1]; + var effectiveFilterHeight = getEffectiveFilterSize(filterHeight, dilationHeight); + var effectiveFilterWidth = getEffectiveFilterSize(filterWidth, dilationWidth); + var _d = getPadAndOutInfo(pad, inHeight, inWidth, strideHeight, strideWidth, effectiveFilterHeight, effectiveFilterWidth, roundingMode), padInfo = _d.padInfo, outHeight = _d.outHeight, outWidth = _d.outWidth; + var outChannels = depthwise ? filterChannels * inChannels : filterChannels; + var outShape; + if (dataFormat === 'channelsFirst') { + outShape = [batchSize, outChannels, outHeight, outWidth]; + } + else if (dataFormat === 'channelsLast') { + outShape = [batchSize, outHeight, outWidth, outChannels]; + } + return { + batchSize: batchSize, + dataFormat: dataFormat, + inHeight: inHeight, + inWidth: inWidth, + inChannels: inChannels, + outHeight: outHeight, + outWidth: outWidth, + outChannels: outChannels, + padInfo: padInfo, + strideHeight: strideHeight, + strideWidth: strideWidth, + filterHeight: filterHeight, + filterWidth: filterWidth, + dilationHeight: dilationHeight, + dilationWidth: dilationWidth, + inShape: inShape, + outShape: outShape, + filterShape: filterShape + }; + } + function computeOutputShape3D(inShape, fieldSize, outDepth, stride, zeroPad, roundingMode) { + if (zeroPad == null) { + zeroPad = computeDefaultPad(inShape, fieldSize, stride); + } + var inputRows = inShape[0]; + var inputCols = inShape[1]; + var outputRows = conditionalRound((inputRows - fieldSize + 2 * zeroPad) / stride + 1, roundingMode); + assert(isInt(outputRows), "The output # of rows (" + outputRows + ") must be an integer. Change the " + + "stride and/or zero pad parameters"); + var outputCols = conditionalRound((inputCols - fieldSize + 2 * zeroPad) / stride + 1, roundingMode); + assert(isInt(outputCols), "The output # of columns (" + outputCols + ") must be an integer. Change " + + "the stride and/or zero pad parameters"); + return [outputRows, outputCols, outDepth]; + } + function computeDefaultPad(inputShape, fieldSize, stride, dilation) { + if (dilation === void 0) { dilation = 1; } + var effectiveFieldSize = getEffectiveFilterSize(fieldSize, dilation); + return Math.floor((inputShape[0] * (stride - 1) - stride + effectiveFieldSize) / 2); + } + function parseTupleParam(param) { + return typeof param === 'number' ? [param, param] : param; + } + function getEffectiveFilterSize(filterSize, dilation) { + if (dilation <= 1) { + return filterSize; + } + return filterSize + (filterSize - 1) * (dilation - 1); + } + function getPadAndOutInfo(pad, inHeight, inWidth, strideHeight, strideWidth, filterHeight, filterWidth, roundingMode) { + var padInfo; + var outHeight; + var outWidth; + if (typeof pad === 'number') { + var padType = (pad === 0) ? 'VALID' : 'NUMBER'; + padInfo = { top: pad, bottom: pad, left: pad, right: pad, type: padType }; + var outShape = computeOutputShape3D([inHeight, inWidth, 1], filterHeight, 1, strideHeight, pad, roundingMode); + outHeight = outShape[0]; + outWidth = outShape[1]; + } + else if (pad === 'same') { + outHeight = Math.ceil(inHeight / strideHeight); + outWidth = Math.ceil(inWidth / strideWidth); + var padAlongHeight = (outHeight - 1) * strideHeight + filterHeight - inHeight; + var padAlongWidth = (outWidth - 1) * strideWidth + filterWidth - inWidth; + var top_1 = Math.floor(padAlongHeight / 2); + var bottom = padAlongHeight - top_1; + var left = Math.floor(padAlongWidth / 2); + var right = padAlongWidth - left; + padInfo = { top: top_1, bottom: bottom, left: left, right: right, type: 'SAME' }; + } + else if (pad === 'valid') { + padInfo = { top: 0, bottom: 0, left: 0, right: 0, type: 'VALID' }; + outHeight = Math.ceil((inHeight - filterHeight + 1) / strideHeight); + outWidth = Math.ceil((inWidth - filterWidth + 1) / strideWidth); + } + else { + throw Error("Unknown padding parameter: " + pad); + } + return { padInfo: padInfo, outHeight: outHeight, outWidth: outWidth }; + } + function conditionalRound(value, roundingMode) { + if (!roundingMode) { + return value; + } + switch (roundingMode) { + case 'round': + return Math.round(value); + case 'ceil': + return Math.ceil(value); + case 'floor': + return Math.floor(value); + default: + throw new Error("Unknown roundingMode " + roundingMode); + } + } + + function conv1d_(x, filter, stride, pad, dataFormat, dilation, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NWC'; } + if (dilation === void 0) { dilation = 1; } + var $x = convertToTensor(x, 'x', 'conv1d'); + var $filter = convertToTensor(filter, 'filter', 'conv1d'); + var x3D = $x; + var reshapedTo3D = false; + if ($x.rank === 2) { + reshapedTo3D = true; + x3D = $x.as3D(1, $x.shape[0], $x.shape[1]); + } + assert(x3D.rank === 3, "Error in conv1d: input must be rank 3, but got rank " + x3D.rank + "."); + assert($filter.rank === 3, "Error in conv1d: filter must be rank 3, but got rank " + + ($filter.rank + ".")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in conv1d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + assert(x3D.shape[2] === $filter.shape[1], "Error in conv1d: depth of input (" + x3D.shape[2] + ") must match " + + ("input depth for filter " + $filter.shape[1] + ".")); + assert(eitherStridesOrDilationsAreOne(stride, dilation), 'Error in conv1D: Either stride or dilation must be 1. ' + + ("Got stride " + stride + " and dilation '" + dilation + "'")); + assert(dataFormat === 'NWC', "Error in conv1d: got dataFormat of " + dataFormat + " but only NWC is currently supported."); + var filter4D = $filter.as4D(1, $filter.shape[0], $filter.shape[1], $filter.shape[2]); + var input4D = x3D.as4D(x3D.shape[0], 1, x3D.shape[1], x3D.shape[2]); + var strides = [1, stride]; + var dilations = [1, dilation]; + var conv2dDataFormat = 'NHWC'; + var res = conv2d(input4D, filter4D, strides, pad, conv2dDataFormat, dilations, dimRoundingMode); + if (reshapedTo3D) { + return res.as2D(res.shape[2], res.shape[3]); + } + return res.as3D(res.shape[0], res.shape[2], res.shape[3]); + } + function conv2d_(x, filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + var $x = convertToTensor(x, 'x', 'conv2d'); + var $filter = convertToTensor(filter, 'filter', 'conv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + assert(x4D.rank === 4, "Error in conv2d: input must be rank 4, but got rank " + x4D.rank + "."); + assert($filter.rank === 4, "Error in conv2d: filter must be rank 4, but got rank " + + ($filter.rank + ".")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in conv2d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + assert(x4D.shape[3] === $filter.shape[2], "Error in conv2d: depth of input (" + x4D.shape[3] + ") must match " + + ("input depth for filter " + $filter.shape[2] + ".")); + assert(eitherStridesOrDilationsAreOne(strides, dilations), 'Error in conv2D: Either strides or dilations must be 1. ' + + ("Got strides " + strides + " and dilations '" + dilations + "'")); + assert(dataFormat === 'NHWC', "Error in conv2d: got dataFormat of " + dataFormat + " but only NHWC is currently supported."); + var convInfo = computeConv2DInfo(x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode); + var grad = function (dy) { + assert(tupleValuesAreOne(dilations), 'Error in gradient of conv2D: dilation rates greater than 1 are not' + + ("yet supported in gradients. Got dilations '" + dilations + "'")); + return { + x: function () { return conv2dDerInput_(x4D.shape, dy, $filter, strides, pad); }, + $filter: function () { return conv2dDerFilter_(x4D, dy, $filter.shape, strides, pad); } + }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.conv2d(x4D, $filter, convInfo); }, { x: x4D, $filter: $filter }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function conv2dDerInput_(xShape, dy, filter, strides, pad, dimRoundingMode) { + assert(xShape.length === dy.rank, "Length of inShape " + + ("(" + xShape.length + ") and rank of dy (" + dy.rank + ") must match")); + var xShape4D = xShape; + var dy4D = dy; + var reshapedTo4D = false; + if (dy.rank === 3) { + reshapedTo4D = true; + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + xShape4D = [1, xShape[0], xShape[1], xShape[2]]; + } + var inDepth = xShape4D[3]; + var outDepth = dy4D.shape[3]; + assert(xShape4D.length === 4, "Error in conv2dDerInput: inShape must be length 4, but got length " + + (xShape4D.length + ".")); + assert(dy4D.rank === 4, "Error in conv2dDerInput: dy must be rank 4, but got " + + ("rank " + dy4D.rank)); + assert(filter.rank === 4, "Error in conv2dDerInput: filter must be rank 4, but got " + + ("rank " + filter.rank)); + assert(inDepth === filter.shape[2], "Error in conv2dDerInput: depth of input (" + inDepth + ") must " + + ("match input depth for filter " + filter.shape[2] + ".")); + assert(outDepth === filter.shape[3], "Error in conv2dDerInput: depth of output (" + outDepth + ") must " + + ("match output depth for filter " + filter.shape[3] + ".")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in conv2dDerInput: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var dilations = 1; + var convInfo = computeConv2DInfo(xShape4D, filter.shape, strides, dilations, pad, dimRoundingMode); + var res = ENV.engine.runKernel(function (backend) { return backend.conv2dDerInput(dy4D, filter, convInfo); }, { dy4D: dy4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function conv2dDerFilter_(x, dy, filterShape, strides, pad, dimRoundingMode) { + var x4D = x; + if (x.rank === 3) { + x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + var dy4D = dy; + if (dy4D.rank === 3) { + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + assert(x4D.rank === 4, "Error in conv2dDerFilter: input must be rank 4, but got shape " + + (x4D.shape + ".")); + assert(dy4D.rank === 4, "Error in conv2dDerFilter: dy must be rank 4, but got shape " + + (dy4D.shape + ".")); + assert(filterShape.length === 4, "Error in conv2dDerFilter: filterShape must be length 4, but got " + + (filterShape + ".")); + assert(x4D.shape[3] === filterShape[2], "Error in conv2dDerFilter: depth of input " + x4D.shape[3] + ") must " + + ("match input depth in filter (" + filterShape[2] + ".")); + assert(dy4D.shape[3] === filterShape[3], "Error in conv2dDerFilter: depth of dy (" + dy4D.shape[3] + ") must " + + ("match output depth for filter (" + filterShape[3] + ").")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in conv2dDerFilter: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var dilations = 1; + var convInfo = computeConv2DInfo(x4D.shape, filterShape, strides, dilations, pad, dimRoundingMode); + return ENV.engine.runKernel(function (backend) { return backend.conv2dDerFilter(x4D, dy4D, convInfo); }, { x4D: x4D, dy4D: dy4D }); + } + function conv2dTranspose_(x, filter, outputShape, strides, pad, dimRoundingMode) { + var $x = convertToTensor(x, 'x', 'conv2dTranspose'); + var $filter = convertToTensor(filter, 'filter', 'conv2dTranspose'); + return conv2dDerInput_(outputShape, $x, $filter, strides, pad, dimRoundingMode); + } + function depthwiseConv2d_(x, filter, strides, pad, dataFormat, dilations, dimRoundingMode) { + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + if (dilations === void 0) { dilations = [1, 1]; } + var $x = convertToTensor(x, 'x', 'depthwiseConv2d'); + var $filter = convertToTensor(filter, 'filter', 'depthwiseConv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + assert(x4D.rank === 4, "Error in depthwiseConv2d: input must be rank 4, but got " + + ("rank " + x4D.rank + ".")); + assert($filter.rank === 4, "Error in depthwiseConv2d: filter must be rank 4, but got rank " + + ($filter.rank + ".")); + assert(x4D.shape[3] === $filter.shape[2], "Error in depthwiseConv2d: number of input channels " + + ("(" + x4D.shape[3] + ") must match the inChannels dimension in ") + + ("filter " + $filter.shape[2] + ".")); + if (dilations == null) { + dilations = [1, 1]; + } + assert(eitherStridesOrDilationsAreOne(strides, dilations), 'Error in depthwiseConv2d: Either strides or dilations must be 1. ' + + ("Got strides " + strides + " and dilations '" + dilations + "'")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in depthwiseConv2d: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = computeConv2DInfo(x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode, true); + var grad = function (dy) { + assert(tupleValuesAreOne(dilations), 'Error in gradient of depthwiseConv2d: dilation rates greater than ' + + ("1 are not yet supported. Got dilations '" + dilations + "'")); + return { + x: function () { return depthwiseConv2dDerInput(x4D.shape, dy, $filter, convInfo); }, + $filter: function () { return depthwiseConv2dDerFilter(x4D, dy, $filter.shape, convInfo); }, + }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2D(x4D, $filter, convInfo); }, { x: x4D, $filter: $filter }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function separableConv2d_(x, depthwiseFilter, pointwiseFilter, strides, pad, dilation, dataFormat) { + if (dilation === void 0) { dilation = [1, 1]; } + if (dataFormat === void 0) { dataFormat = 'NHWC'; } + var $x = convertToTensor(x, 'x', 'separableConv2d'); + var $depthwiseFilter = convertToTensor(depthwiseFilter, 'depthwiseFilter', 'separableConv2d'); + var $pointwiseFilter = convertToTensor(pointwiseFilter, 'pointwiseFilter', 'separableConv2d'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + if (dataFormat === 'NCHW') { + throw new Error('separableConv2d currently does not support dataFormat NCHW; only ' + + 'NHWC is supported'); + } + assert(x4D.rank === 4, "Error in separableConv2d: input must be rank 4, but got " + + ("rank " + x4D.rank + ".")); + assert($depthwiseFilter.rank === 4, "Error in separableConv2d: depthwise filter must be rank 4, but got " + + ("rank " + $depthwiseFilter.rank + ".")); + assert($pointwiseFilter.rank === 4, "Error in separableConv2d: pointwise filter must be rank 4, but got " + + ("rank " + $depthwiseFilter.rank + ".")); + assert($pointwiseFilter.shape[0] === 1, "Error in separableConv2d: the first dimension of pointwise filter " + + (" must be 1, but got " + $pointwiseFilter.shape[0] + ".")); + assert($pointwiseFilter.shape[1] === 1, "Error in separableConv2d: the second dimension of pointwise filter " + + (" must be 1, but got " + $pointwiseFilter.shape[1] + ".")); + var inChannels = $depthwiseFilter.shape[2]; + var channelMultiplier = $depthwiseFilter.shape[3]; + assert($pointwiseFilter.shape[2] === inChannels * channelMultiplier, "Error in separableConv2d: the third dimension of pointwise filter " + + ("must be " + inChannels * channelMultiplier + ", ") + + ("but got " + $pointwiseFilter.shape[2] + ".")); + var depthwise = depthwiseConv2d(x4D, $depthwiseFilter, strides, pad, dataFormat, dilation); + var pointwiseStride = 1; + var res = conv2d(depthwise, $pointwiseFilter, pointwiseStride, 'valid', dataFormat); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function parseTupleParam$1(param) { + return typeof param === 'number' ? [param, param] : param; + } + function tupleValuesAreOne(param) { + var _a = parseTupleParam$1(param), dimA = _a[0], dimB = _a[1]; + return dimA === 1 && dimB === 1; + } + function eitherStridesOrDilationsAreOne(strides, dilations) { + return tupleValuesAreOne(strides) || tupleValuesAreOne(dilations); + } + function depthwiseConv2dDerInput(xShape, dy, filter, convInfo) { + var dy4D = dy; + var reshapedTo4D = false; + if (dy.rank === 3) { + reshapedTo4D = true; + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + var res = ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2DDerInput(dy4D, filter, convInfo); }, { dy4D: dy4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function depthwiseConv2dDerFilter(x, dy, filterShape, convInfo) { + var x4D = x; + if (x.rank === 3) { + x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]); + } + var dy4D = dy; + if (dy4D.rank === 3) { + dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]); + } + return ENV.engine.runKernel(function (backend) { return backend.depthwiseConv2DDerFilter(x4D, dy4D, convInfo); }, { x4D: x4D, dy4D: dy4D }); + } + var conv1d = op({ conv1d_: conv1d_ }); + var conv2d = op({ conv2d_: conv2d_ }); + var depthwiseConv2d = op({ depthwiseConv2d_: depthwiseConv2d_ }); + var separableConv2d = op({ separableConv2d_: separableConv2d_ }); + var conv2dTranspose = op({ conv2dTranspose_: conv2dTranspose_ }); + + function matMul_(a, b, transposeA, transposeB) { + if (transposeA === void 0) { transposeA = false; } + if (transposeB === void 0) { transposeB = false; } + var $a = convertToTensor(a, 'a', 'matMul'); + var $b = convertToTensor(b, 'b', 'matMul'); + var innerShapeA = transposeA ? $a.shape[0] : $a.shape[1]; + var innerShapeB = transposeB ? $b.shape[1] : $b.shape[0]; + assert($a.rank === 2 && $b.rank === 2, "Error in matMul: inputs must be rank 2, got ranks " + $a.rank + + (" and " + $b.rank + ".")); + assert(innerShapeA === innerShapeB, "Error in matMul: inner shapes (" + innerShapeA + ") and (" + + (innerShapeB + ") of Tensors with shapes " + $a.shape + " and ") + + ($b.shape + " and transposeA=" + transposeA) + + (" and transposeB=" + transposeB + " must match.")); + var grad = function (dy) { + if (!transposeA && !transposeB) { + return { + $a: function () { return dy.matMul($b.toFloat(), false, true); }, + $b: function () { return $a.toFloat().matMul(dy, true, false); } + }; + } + else if (!transposeA && transposeB) { + return { + $a: function () { return dy.matMul($b.toFloat(), false, false); }, + $b: function () { return dy.matMul($a.toFloat(), true, false); } + }; + } + else if (transposeA && !transposeB) { + return { + $a: function () { return $b.toFloat().matMul(dy, false, true); }, + $b: function () { return $a.toFloat().matMul(dy, false, false); } + }; + } + else { + return { + $a: function () { return $b.toFloat().matMul(dy, true, true); }, + $b: function () { return dy.matMul($a.toFloat(), true, true); } + }; + } + }; + return ENV.engine.runKernel(function (backend) { return backend.matMul($a, $b, transposeA, transposeB); }, { $a: $a, $b: $b }, grad); + } + function outerProduct_(v1, v2) { + var $v1 = convertToTensor(v1, 'v1', 'outerProduct'); + var $v2 = convertToTensor(v2, 'v2', 'outerProduct'); + assert($v1.rank === 1 && $v2.rank === 1, "Error in outerProduct: inputs must be rank 1, but got ranks " + + ($v1.rank + " and " + $v2.rank + ".")); + return $v1.as2D(-1, 1).matMul($v2.as2D(1, -1)); + } + function dot_(t1, t2) { + var $t1 = convertToTensor(t1, 't1', 'dot'); + var $t2 = convertToTensor(t2, 't2', 'dot'); + assert(($t1.rank === 1 || $t1.rank === 2) && ($t2.rank === 1 || $t2.rank === 2), "Error in dot: inputs must all be rank 1 or 2, but got ranks " + + ($t1.rank + " and " + $t2.rank + ".")); + var t1Inner = ($t1.rank === 1 ? $t1.size : $t1.shape[1]); + var t2Inner = ($t2.rank === 1 ? $t2.size : $t2.shape[0]); + assert(t1Inner === t2Inner, "Error in dot: inner dimensions of inputs must match, but got " + + (t1Inner + " and " + t2Inner + ".")); + if ($t1.rank === 1 && $t2.rank === 1) { + return $t1.as2D(1, -1).matMul($t2.as2D(-1, 1)).asScalar(); + } + else if ($t1.rank === 1 && $t2.rank === 2) { + return $t1.as2D(1, -1).matMul($t2.as2D($t2.shape[0], $t2.shape[1])).as1D(); + } + else if ($t1.rank === 2 && $t2.rank === 1) { + return $t1.matMul($t2.as2D(-1, 1)).as1D(); + } + else { + return $t1.matMul($t2.as2D($t2.shape[0], $t2.shape[1])); + } + } + var matMul = op({ matMul_: matMul_ }); + var dot = op({ dot_: dot_ }); + var outerProduct = op({ outerProduct_: outerProduct_ }); + + function reverse1d_(x) { + var $x = convertToTensor(x, 'x', 'reverse'); + assert($x.rank === 1, "Error in reverse1D: x must be rank 1 but got\n rank " + $x.rank + "."); + return reverse($x, 0); + } + function reverse2d_(x, axis) { + var $x = convertToTensor(x, 'x', 'reverse'); + assert($x.rank === 2, "Error in reverse2D: x must be rank 2 but got\n rank " + $x.rank + "."); + return reverse($x, axis); + } + function reverse3d_(x, axis) { + var $x = convertToTensor(x, 'x', 'reverse'); + assert($x.rank === 3, "Error in reverse3D: x must be rank 3 but got\n rank " + $x.rank + "."); + return reverse($x, axis); + } + function reverse4d_(x, axis) { + var $x = convertToTensor(x, 'x', 'reverse'); + assert($x.rank === 4, "Error in reverse4D: x must be rank 4 but got\n rank " + $x.rank + "."); + return reverse($x, axis); + } + function reverse_(x, axis) { + var $x = convertToTensor(x, 'x', 'reverse'); + if ($x.rank === 0) { + return $x.clone(); + } + var axes = parseAxisParam(axis, $x.shape); + var grad = function (dy) { + return { $x: function () { return dy.reverse(axes); } }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.reverse($x, axes); }, { $x: $x }, grad); + return res.reshapeAs($x); + } + var reverse = op({ reverse_: reverse_ }); + var reverse1d = op({ reverse1d_: reverse1d_ }); + var reverse2d = op({ reverse2d_: reverse2d_ }); + var reverse3d = op({ reverse3d_: reverse3d_ }); + var reverse4d = op({ reverse4d_: reverse4d_ }); + + function maxPool_(x, filterSize, strides, pad, dimRoundingMode) { + var $x = convertToTensor(x, 'x', 'maxPool'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + assert(x4D.rank === 4, "Error in maxPool: input must be rank 4 but got rank " + x4D.rank + "."); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in maxPool: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = computePool2DInfo(x4D.shape, filterSize, strides, pad, dimRoundingMode); + var grad = function (dy, saved) { + var y4D = saved[0]; + return { + x: function () { + return maxPoolBackprop(dy, x4D, y4D, filterSize, strides, pad); + } + }; + }; + var res = ENV.engine.runKernel(function (backend, save) { return save(backend.maxPool(x4D, convInfo)); }, { x: x4D }, grad); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function avgPool_(x, filterSize, strides, pad, dimRoundingMode) { + var $x = convertToTensor(x, 'x', 'avgPool'); + assert($x.dtype === 'float32', 'The input dtype to avgPool must be float32'); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + assert(x4D.rank === 4, "Error in avgPool: x must be rank 4 but got rank " + x4D.rank + "."); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in avgPool: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = computePool2DInfo(x4D.shape, filterSize, strides, pad); + var grad = function (dy) { + return { x: function () { return avgPoolBackprop(dy, x4D, filterSize, strides, pad); } }; + }; + var res = ENV.engine.runKernel(function (backend) { return backend.avgPool(x4D, convInfo); }, { x: x4D }, grad); + res = res.cast($x.dtype); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function maxPoolBackprop(dy, input, output, filterSize, strides, pad, dimRoundingMode) { + var $dy = convertToTensor(dy, 'dy', 'maxPoolBackprop'); + var $input = convertToTensor(input, 'input', 'maxPoolBackprop'); + var $output = convertToTensor(output, 'output', 'maxPoolBackprop'); + assert($input.rank === $dy.rank, "Rank of input (" + $input.rank + ") does not match rank of dy (" + $dy.rank + ")"); + assert($dy.rank === 4, "Error in maxPoolBackprop: dy must be rank 4 but got rank " + + ($dy.rank + ".")); + assert($input.rank === 4, "Error in maxPoolBackprop: input must be rank 4 but got rank " + + ($input.rank + ".")); + if (dimRoundingMode != null) { + assert(isInt(pad), "Error in maxPoolBackprop: pad must be an integer when using, " + + ("dimRoundingMode " + dimRoundingMode + " but got pad " + pad + ".")); + } + var convInfo = computePool2DInfo($input.shape, filterSize, strides, pad, dimRoundingMode); + var res = ENV.engine.runKernel(function (backend) { return backend.maxPoolBackprop($dy, $input, $output, convInfo); }, { $dy: $dy, $input: $input }); + return res; + } + function avgPoolBackprop(dy, input, filterSize, strides, pad) { + var $dy = convertToTensor(dy, 'dy', 'avgPoolBackprop'); + var $input = convertToTensor(input, 'input', 'avgPoolBackprop'); + assert($input.rank === $dy.rank, "Rank of input (" + $input.rank + ") does not match rank of dy (" + $dy.rank + ")"); + var input4D = $input; + var dy4D = $dy; + var reshapedTo4D = false; + if ($input.rank === 3) { + reshapedTo4D = true; + input4D = $input.as4D(1, $input.shape[0], $input.shape[1], $input.shape[2]); + dy4D = $dy.as4D(1, $dy.shape[0], $dy.shape[1], $dy.shape[2]); + } + assert(dy4D.rank === 4, "Error in avgPoolBackprop: dy must be rank 4 but got rank " + + (dy4D.rank + ".")); + assert(input4D.rank === 4, "Error in avgPoolBackprop: input must be rank 4 but got rank " + + (input4D.rank + ".")); + var convInfo = computePool2DInfo(input4D.shape, filterSize, strides, pad); + var res = ENV.engine.runKernel(function (backend) { return backend.avgPoolBackprop(dy4D, input4D, convInfo); }, { dy4D: dy4D, input4D: input4D }); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + var maxPool = op({ maxPool_: maxPool_ }); + var avgPool = op({ avgPool_: avgPool_ }); + + function slice1d_(x, begin, size) { + var $x = convertToTensor(x, 'x', 'slice1d'); + assert($x.rank === 1, "slice1d expects a rank-1 tensor, but got a rank-" + $x.rank + " tensor"); + return slice($x, [begin], [size]); + } + function slice2d_(x, begin, size) { + var $x = convertToTensor(x, 'x', 'slice2d'); + assert($x.rank === 2, "slice1d expects a rank-2 tensor, but got a rank-" + $x.rank + " tensor"); + return slice($x, begin, size); + } + function slice3d_(x, begin, size) { + var $x = convertToTensor(x, 'x', 'slice3d'); + assert($x.rank === 3, "slice1d expects a rank-3 tensor, but got a rank-" + $x.rank + " tensor"); + return slice($x, begin, size); + } + function slice4d_(x, begin, size) { + var $x = convertToTensor(x, 'x', 'slice4d'); + assert($x.rank === 4, "slice1d expects a rank-4 tensor, but got a rank-" + $x.rank + " tensor"); + return slice($x, begin, size); + } + function slice_(x, begin, size) { + var $x = convertToTensor(x, 'x', 'slice'); + if ($x.rank === 0) { + throw new Error('Slicing scalar is not possible'); + } + var begin_; + if (typeof begin === 'number') { + begin_ = [begin].concat(new Array($x.rank - 1).fill(0)); + } + else if (begin.length < $x.rank) { + begin_ = begin.concat(new Array($x.rank - begin.length).fill(0)); + } + else { + begin_ = begin; + } + var size_; + if (size == null) { + size_ = new Array($x.rank).fill(-1); + } + else if (typeof size === 'number') { + size_ = [size].concat(new Array($x.rank - 1).fill(-1)); + } + else if (size.length < $x.rank) { + size_ = size.concat(new Array($x.rank - size.length).fill(-1)); + } + else { + size_ = size; + } + size_ = size_.map(function (d, i) { + if (d >= 0) { + return d; + } + else { + assert(d === -1, 'Bad value in size'); + return $x.shape[i] - begin_[i]; + } + }); + assertParamsValid($x, begin_, size_); + var inputShape = $x.shape; + var grad = function (dy) { + var paddings = []; + for (var i = 0; i < dy.rank; i++) { + paddings.push([begin_[i], inputShape[i] - begin_[i] - size_[i]]); + } + return { $x: function () { return dy.pad(paddings); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.slice($x, begin_, size_); }, { $x: $x }, grad); + } + var slice = op({ slice_: slice_ }); + var slice1d = op({ slice1d_: slice1d_ }); + var slice2d = op({ slice2d_: slice2d_ }); + var slice3d = op({ slice3d_: slice3d_ }); + var slice4d = op({ slice4d_: slice4d_ }); + + var tidy = Environment.tidy; + var keep = Environment.keep; + var dispose = Environment.dispose; + var time = Environment.time; + + function logSumExp_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'logSumExp'); + var axes = parseAxisParam(axis, $x.shape); + var xMax = $x.max(axes, true); + var a = $x.sub(xMax); + var b = a.exp(); + var c = b.sum(axes); + var d = c.log(); + var res = xMax.reshape(d.shape).add(d); + if (keepDims) { + var newShape = expandShapeToKeepDim(res.shape, axes); + return res.reshape(newShape); + } + return res; + } + function sum_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'sum'); + if ($x.dtype === 'bool') { + $x = $x.toInt(); + } + var axes = parseAxisParam(axis, $x.shape); + var customOp = customGrad(function (x) { + var permutation = getAxesPermutation(axes, x.rank); + var reductionAxes = axes; + var permutedX = x; + if (permutation != null) { + permutedX = x.transpose(permutation); + reductionAxes = getInnerMostAxes(reductionAxes.length, x.rank); + } + var value = ENV.engine.runKernel(function (backend) { return backend.sum(permutedX, reductionAxes); }, { permutedX: permutedX }); + if (keepDims) { + var newShape = expandShapeToKeepDim(value.shape, axes); + value = value.reshape(newShape); + } + var gradFunc = function (dy) { + var expandedDyShape = x.shape.slice(); + axes.forEach(function (axis) { + expandedDyShape[axis] = 1; + }); + var expandedDy = dy.reshape(expandedDyShape); + var derX = expandedDy.mul(ones$1(x.shape, 'float32')); + return derX; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp($x); + } + function mean_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'mean'); + var axes = parseAxisParam(axis, $x.shape); + var shapes = computeOutAndReduceShapes($x.shape, axes); + var reduceShape = shapes[1]; + var reduceSize = sizeFromShape(reduceShape); + var customOp = customGrad(function (x) { + var reduceSizeScalar = scalar(reduceSize); + var xReduce = reduceSizeScalar.dtype === x.dtype ? x : x.cast(reduceSizeScalar.dtype); + var res = xReduce.div(reduceSizeScalar); + var value = res.sum(axis, keepDims); + var gradFunc = function (dy) { + var expandedDyShape = x.shape.slice(); + axes.forEach(function (axis) { + expandedDyShape[axis] = 1; + }); + var expandedDy = dy.reshape(expandedDyShape); + var derX = expandedDy.mul(ones$1(x.shape, 'float32')).div(reduceSizeScalar); + return derX; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp($x); + } + function min_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'min'); + var origAxes = parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + var res = ENV.engine.runKernel(function (backend) { return backend.min($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; + } + function max_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'max'); + var origAxes = parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + var res = ENV.engine.runKernel(function (backend) { return backend.max($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; + } + function argMin_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'argMin'); + if (axis == null) { + axis = 0; + } + var axes = parseAxisParam(axis, $x.shape); + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + return ENV.engine.runKernel(function (backend) { return backend.argMin($x, axes[0]); }, { $x: $x }); + } + function argMax_(x, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'argMax'); + if (axis == null) { + axis = 0; + } + var axes = parseAxisParam(axis, $x.shape); + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + return ENV.engine.runKernel(function (backend) { return backend.argMax($x, axes[0]); }, { $x: $x }); + } + function all_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'all', 'bool'); + assert($x.dtype === 'bool', "Error Tensor must be of type bool. Got: " + $x.dtype); + var origAxes = parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + var res = ENV.engine.runKernel(function (backend) { return backend.all($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; + } + function any_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + var $x = convertToTensor(x, 'x', 'any', 'bool'); + assert($x.dtype === 'bool', "Error Tensor must be of type bool. Got: " + $x.dtype); + var origAxes = parseAxisParam(axis, $x.shape); + var axes = origAxes; + var permutedAxes = getAxesPermutation(axes, $x.rank); + if (permutedAxes != null) { + $x = $x.transpose(permutedAxes); + axes = getInnerMostAxes(axes.length, $x.rank); + } + var res = ENV.engine.runKernel(function (backend) { return backend.any($x, axes); }, { $x: $x }); + if (keepDims) { + var newShape = expandShapeToKeepDim(res.shape, origAxes); + return res.reshape(newShape); + } + return res; + } + function moments_(x, axis, keepDims) { + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + x = convertToTensor(x, 'x', 'moments'); + var axes = parseAxisParam(axis, x.shape); + var mean = x.mean(axes, keepDims); + var keepDimsShape = mean.shape; + if (!keepDims) { + keepDimsShape = expandShapeToKeepDim(mean.shape, axes); + } + var devSquared = x.toFloat().sub(mean.reshape(keepDimsShape)).square(); + var variance = devSquared.mean(axes, keepDims); + return { mean: mean, variance: variance }; + } + var all = op({ all_: all_ }); + var any = op({ any_: any_ }); + var argMax = op({ argMax_: argMax_ }); + var argMin = op({ argMin_: argMin_ }); + var logSumExp = op({ logSumExp_: logSumExp_ }); + var max = op({ max_: max_ }); + var mean = op({ mean_: mean_ }); + var min = op({ min_: min_ }); + var moments = op({ moments_: moments_ }); + var sum = op({ sum_: sum_ }); + + function notEqual_(a, b) { + var $a = convertToTensor(a, 'a', 'notEqual'); + var $b = convertToTensor(b, 'b', 'notEqual'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.notEqual($a, $b); }, { $a: $a, $b: $b }); + } + function notEqualStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'notEqualStrict'); + var $b = convertToTensor(b, 'b', 'notEqualStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in notEqualStrict: '); + return $a.notEqual($b); + } + function less_(a, b) { + var $a = convertToTensor(a, 'a', 'less'); + var $b = convertToTensor(b, 'b', 'less'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.less($a, $b); }, { $a: $a, $b: $b }); + } + function lessStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'lessStrict'); + var $b = convertToTensor(b, 'b', 'lessStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in lessStrict: '); + return $a.less($b); + } + function equal_(a, b) { + var $a = convertToTensor(a, 'a', 'equal'); + var $b = convertToTensor(b, 'b', 'equal'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.equal($a, $b); }, { $a: $a, $b: $b }); + } + function equalStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'equalStrict'); + var $b = convertToTensor(b, 'b', 'equalStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in equalStrict: '); + return $a.equal($b); + } + function lessEqual_(a, b) { + var $a = convertToTensor(a, 'a', 'lessEqual'); + var $b = convertToTensor(b, 'b', 'lessEqual'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.lessEqual($a, $b); }, { $a: $a, $b: $b }); + } + function lessEqualStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'lessEqualStrict'); + var $b = convertToTensor(b, 'b', 'lessEqualStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in lessEqualStrict: '); + return $a.lessEqual($b); + } + function greater_(a, b) { + var $a = convertToTensor(a, 'a', 'greater'); + var $b = convertToTensor(b, 'b', 'greater'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.greater($a, $b); }, { $a: $a, $b: $b }); + } + function greaterStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'greaterStrict'); + var $b = convertToTensor(b, 'b', 'greaterStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in greaterStrict: '); + return $a.greater($b); + } + function greaterEqual_(a, b) { + var $a = convertToTensor(a, 'a', 'greaterEqual'); + var $b = convertToTensor(b, 'b', 'greaterEqual'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.greaterEqual($a, $b); }, { $a: $a, $b: $b }); + } + function greaterEqualStrict_(a, b) { + var $a = convertToTensor(a, 'a', 'greaterEqualStrict'); + var $b = convertToTensor(b, 'b', 'greaterEqualStrict'); + assertShapesMatch($a.shape, $b.shape, 'Error in greaterEqualStrict: '); + return $a.greaterEqual($b); + } + var equal = op({ equal_: equal_ }); + var equalStrict = op({ equalStrict_: equalStrict_ }); + var greater = op({ greater_: greater_ }); + var greaterEqual = op({ greaterEqual_: greaterEqual_ }); + var greaterEqualStrict = op({ greaterEqualStrict_: greaterEqualStrict_ }); + var greaterStrict = op({ greaterStrict_: greaterStrict_ }); + var less = op({ less_: less_ }); + var lessEqual = op({ lessEqual_: lessEqual_ }); + var lessEqualStrict = op({ lessEqualStrict_: lessEqualStrict_ }); + var lessStrict = op({ lessStrict_: lessStrict_ }); + var notEqual = op({ notEqual_: notEqual_ }); + var notEqualStrict = op({ notEqualStrict_: notEqualStrict_ }); + + function add_(a, b) { + var $a = convertToTensor(a, 'a', 'add'); + var $b = convertToTensor(b, 'b', 'add'); + assertTypesMatch($a, $b); + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy; + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var res = dy; + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.add($a, $b); }, { $a: $a, $b: $b }, der); + } + function addN_(tensors) { + assert(Array.isArray(tensors), function () { return 'The param passed to tf.addN() must be a list of tensors'; }); + assert(tensors.length >= 1, function () { return "Must pass at least one tensor to tf.addN(), but got " + + ("" + tensors.length); }); + var $tensors = tensors.map(function (t, i) { return convertToTensor(t, "tensors" + i, 'addN'); }); + var firstTensor = $tensors[0]; + $tensors.forEach(function (t) { + if (t.dtype !== firstTensor.dtype) { + throw new Error('All tensors passed to tf.addN() must have the same dtype'); + } + }); + $tensors.forEach(function (t) { + if (!arraysEqual(t.shape, firstTensor.shape)) { + throw new Error('All tensors passed to tf.addN() must have the same shape'); + } + }); + var der = function (dy) { + var ders = {}; + $tensors.forEach(function (t, i) { + ders[i] = function () { return dy.clone(); }; + }); + return ders; + }; + var inputs = $tensors; + return ENV.engine.runKernel(function (backend) { return backend.addN($tensors); }, inputs, der); + } + function addStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in addStrict: '); + return a.add(b); + } + function sub_(a, b) { + var $a = convertToTensor(a, 'a', 'sub'); + var $b = convertToTensor(b, 'b', 'sub'); + assertTypesMatch($a, $b); + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy; + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var res = dy; + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.neg().reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.subtract($a, $b); }, { $a: $a, $b: $b }, der); + } + function subStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in subStrict: '); + return a.sub(b); + } + function pow_(base, exp$$1) { + var $base = convertToTensor(base, 'base', 'pow'); + var $exp = convertToTensor(exp$$1, 'exp', 'pow'); + var outShape = assertAndGetBroadcastShape($base.shape, $exp.shape); + base = $base.cast(upcastType($base.dtype, $exp.dtype)); + exp$$1 = $exp.cast(upcastType($base.dtype, $exp.dtype)); + var grad = function (dy, saved) { + var y = saved[0]; + var derBase = function () { + var res = dy.mul($exp.toFloat().mul(y.div($base))); + var reduceAxes = getReductionAxes($base.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($base.shape); + }; + var derExp = function () { + var res = dy.mul(y.mul($base.log()).toFloat()); + var reduceAxes = getReductionAxes($exp.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($exp.shape); + }; + return { $base: derBase, $exp: derExp }; + }; + return ENV.engine.runKernel(function (backend, save) { return save(backend.pow($base, $exp)); }, { $base: $base, $exp: $exp }, grad); + } + function powStrict_(base, exp$$1) { + assertShapesMatch(base.shape, exp$$1.shape, 'Error in powStrict: '); + return base.pow(exp$$1); + } + function mul_(a, b) { + var $a = convertToTensor(a, 'a', 'mul'); + var $b = convertToTensor(b, 'b', 'mul'); + assertTypesMatch($a, $b); + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.mul($b.toFloat()); + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($b.shape); + } + return res; + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.multiply($a, $b); }, { $a: $a, $b: $b }, der); + } + function mulStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in multiplyStrict: '); + return a.mul(b); + } + function div_(a, b) { + var $a = convertToTensor(a, 'a', 'div'); + var $b = convertToTensor(b, 'b', 'div'); + assertTypesMatch($a, $b); + var forwardFunc; + if ($a.dtype === 'int32' && $b.dtype === 'int32') { + return floorDiv($a, $b); + } + else { + forwardFunc = function (backend) { return backend.realDivide($a, $b); }; + } + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.div($b.toFloat()); + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes).reshape($b.shape); + } + var tmp = $b.square(); + return res.div(tmp.toFloat()).neg(); + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(forwardFunc, { $a: $a, $b: $b }, der); + } + function floorDiv_(a, b) { + var $a = convertToTensor(a, 'a', 'floorDiv'); + var $b = convertToTensor(b, 'b', 'floorDiv'); + assertTypesMatch($a, $b); + var forwardFunc = function (backend) { return backend.floorDiv($a, $b); }; + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var res = dy.div($b.toFloat()); + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($a.shape); + } + return res; + }; + var derB = function () { + var res = dy.mul($a.toFloat()); + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes).reshape($b.shape); + } + var tmp = $b.square(); + return res.div(tmp.toFloat()).neg(); + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(forwardFunc, { $a: $a, $b: $b }, der); + } + function divStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in divideStrict: '); + return a.div(b); + } + function mod_(a, b) { + var $a = convertToTensor(a, 'a', 'mod'); + var $b = convertToTensor(b, 'b', 'mod'); + assertTypesMatch($a, $b); + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + return dy.sum(reduceAxes).reshape($a.shape); + } + return dy; + }; + var derB = function () { + var res = dy.mul($a.div($b).floor().neg()); + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + return res.sum(reduceAxes).reshape($b.shape); + } + return res; + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.mod($a, $b); }, { $a: $a, $b: $b }, der); + } + function modStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in modStrict: '); + return a.mod(b); + } + function minimum_(a, b) { + var $a = convertToTensor(a, 'a', 'minimum'); + var $b = convertToTensor(b, 'b', 'minimum'); + assertTypesMatch($a, $b); + if ($a.dtype === 'bool') { + $a = $a.toInt(); + } + if ($b.dtype === 'bool') { + $b = $b.toInt(); + } + assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { return dy.mul($a.lessEqual($b).toFloat()); }; + var derB = function () { return dy.mul($a.greater($b).toFloat()); }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.minimum($a, $b); }, { $a: $a, $b: $b }, der); + } + function minimumStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: '); + return a.minimum(b); + } + function maximum_(a, b) { + var $a = convertToTensor(a, 'a', 'maximum'); + var $b = convertToTensor(b, 'b', 'maximum'); + assertTypesMatch($a, $b); + if ($a.dtype === 'bool') { + $a = $a.toInt(); + } + if ($b.dtype === 'bool') { + $b = $b.toInt(); + } + assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { return dy.mul($a.greaterEqual($b).toFloat()); }; + var derB = function () { return dy.mul($a.less($b).toFloat()); }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.maximum($a, $b); }, { $a: $a, $b: $b }, der); + } + function maximumStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: '); + return a.maximum(b); + } + function squaredDifference_(a, b) { + var $a = convertToTensor(a, 'a', 'squaredDifference'); + var $b = convertToTensor(b, 'b', 'squaredDifference'); + assertTypesMatch($a, $b); + assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var two = scalar(2); + var derA = function () { return dy.mul($a.sub($b).mul(two)); }; + var derB = function () { return dy.mul($b.sub($a).mul(two)); }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.squaredDifference($a, $b); }, { $a: $a, $b: $b }, der); + } + function squaredDifferenceStrict_(a, b) { + assertShapesMatch(a.shape, b.shape, 'Error in squaredDifferenceStrict: '); + return a.squaredDifference(b); + } + function atan2_(a, b) { + var $a = convertToTensor(a, 'a', 'atan2'); + var $b = convertToTensor(b, 'b', 'atan2'); + assertTypesMatch($a, $b); + var outShape = assertAndGetBroadcastShape($a.shape, $b.shape); + var der = function (dy) { + var derA = function () { + var d = add($a.square(), $b.square()); + var res = dy.mul($b.div(d)); + var reduceAxes = getReductionAxes($a.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($a.shape); + }; + var derB = function () { + var d = add($a.square(), $b.square()); + var res = neg(dy.mul($a.div(d))); + var reduceAxes = getReductionAxes($b.shape, outShape); + if (reduceAxes.length > 0) { + res = res.sum(reduceAxes); + } + return res.reshape($b.shape); + }; + return { $a: derA, $b: derB }; + }; + return ENV.engine.runKernel(function (backend) { return backend.atan2($a, $b); }, { $a: $a, $b: $b }, der); + } + var add = op({ add_: add_ }); + var addN = op({ addN_: addN_ }); + var addStrict = op({ addStrict_: addStrict_ }); + var atan2 = op({ atan2_: atan2_ }); + var div = op({ div_: div_ }); + var divStrict = op({ divStrict_: divStrict_ }); + var floorDiv = op({ floorDiv_: floorDiv_ }); + var maximum = op({ maximum_: maximum_ }); + var maximumStrict = op({ maximumStrict_: maximumStrict_ }); + var minimum = op({ minimum_: minimum_ }); + var minimumStrict = op({ minimumStrict_: minimumStrict_ }); + var mod = op({ mod_: mod_ }); + var modStrict = op({ modStrict_: modStrict_ }); + var mul = op({ mul_: mul_ }); + var mulStrict = op({ mulStrict_: mulStrict_ }); + var pow = op({ pow_: pow_ }); + var powStrict = op({ powStrict_: powStrict_ }); + var squaredDifference = op({ squaredDifference_: squaredDifference_ }); + var squaredDifferenceStrict = op({ squaredDifferenceStrict_: squaredDifferenceStrict_ }); + var sub = op({ sub_: sub_ }); + var subStrict = op({ subStrict_: subStrict_ }); + + function logicalNot_(x) { + var $x = convertToTensor(x, 'x', 'logicalNot', 'bool'); + assert($x.dtype === 'bool', 'Error Array must be of type bool.'); + return ENV.engine.runKernel(function (backend) { return backend.logicalNot($x); }, { $x: $x }); + } + function logicalAnd_(a, b) { + var $a = convertToTensor(a, 'a', 'logicalAnd', 'bool'); + var $b = convertToTensor(b, 'b', 'logicalAnd', 'bool'); + assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.logicalAnd($a, $b); }, { $a: $a, $b: $b }); + } + function logicalOr_(a, b) { + var $a = convertToTensor(a, 'a', 'logicalOr', 'bool'); + var $b = convertToTensor(b, 'b', 'logicalOr', 'bool'); + assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + assertAndGetBroadcastShape($a.shape, $b.shape); + return ENV.engine.runKernel(function (backend) { return backend.logicalOr($a, $b); }, { $a: $a, $b: $b }); + } + function logicalXor_(a, b) { + var $a = convertToTensor(a, 'a', 'logicalXor', 'bool'); + var $b = convertToTensor(b, 'b', 'logicalXor', 'bool'); + assert($a.dtype === 'bool' && $b.dtype === 'bool', 'Error Array must be of type bool.'); + assertAndGetBroadcastShape($a.shape, $b.shape); + return logicalOr(a, b).logicalAnd(logicalAnd(a, b).logicalNot()); + } + function where_(condition, a, b) { + var $a = convertToTensor(a, 'a', 'where'); + var $b = convertToTensor(b, 'b', 'where'); + var $condition = convertToTensor(condition, 'condition', 'where', 'bool'); + assert($condition.dtype === 'bool', 'Error Condition must be of type bool.'); + assertShapesMatch($a.shape, $b.shape, 'Error in where: '); + if ($condition.rank === 1) { + assert($condition.shape[0] === $a.shape[0], 'The first dimension of `a` must match the size of `condition`.'); + } + else { + assertShapesMatch($condition.shape, $b.shape, 'Error in where: '); + } + var grad = function (dy) { return ({ + $condition: function () { return zerosLike($condition); }, + $a: function () { return dy.mul($condition.cast($a.dtype)); }, + $b: function () { return dy.mul($condition.logicalNot().cast($b.dtype)); } + }); }; + return ENV.engine.runKernel(function (backend) { return backend.select($condition, $a, $b); }, { $condition: $condition, $a: $a, $b: $b }, grad); + } + function whereAsync_(condition) { + return __awaiter(this, void 0, void 0, function () { + var $condition, vals, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + $condition = convertToTensor(condition, 'condition', 'where', 'bool'); + assert($condition.dtype === 'bool', 'Condition must be of type bool.'); + return [4, $condition.data()]; + case 1: + vals = _a.sent(); + res = whereImpl($condition.shape, vals); + if (condition !== $condition) { + $condition.dispose(); + } + return [2, res]; + } + }); + }); + } + var logicalAnd = op({ logicalAnd_: logicalAnd_ }); + var logicalNot = op({ logicalNot_: logicalNot_ }); + var logicalOr = op({ logicalOr_: logicalOr_ }); + var logicalXor = op({ logicalXor_: logicalXor_ }); + var where = op({ where_: where_ }); + var whereAsync = whereAsync_; + + function relu_(x) { + var $x = convertToTensor(x, 'x', 'relu'); + if ($x.dtype === 'bool') { + return $x.toInt(); + } + var grad = function (dy) { + var stepRes = $x.step(); + return { $x: function () { return dy.mulStrict(stepRes.toFloat()); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.relu($x); }, { $x: $x }, grad); + } + function elu_(x) { + var $x = convertToTensor(x, 'x', 'elu'); + var grad = function (dy, saved) { + var y = saved[0]; + return { + $x: function () { + return ENV.engine.runKernel(function (backend) { return backend.eluDer(dy, y); }, { dy: dy, y: y }); + } + }; + }; + return ENV.engine.runKernel(function (backend, save) { return save(backend.elu($x)); }, { $x: $x }, grad); + } + function selu_(x) { + var $x = convertToTensor(x, 'x', 'selu'); + var grad = function (dy) { + return { + $x: function () { + var mask = $x.greater(scalar(0)); + var scaleAlpha = scalar(SELU_SCALEALPHA); + var scale = scalar(SELU_SCALE); + var greaterThanZeroDer = dy.mul(scale); + var lessEqualZeroDer = dy.mul(scaleAlpha).mul($x.toFloat().exp()); + return where(mask, greaterThanZeroDer, lessEqualZeroDer); + } + }; + }; + return ENV.engine.runKernel(function (backend) { return backend.selu($x); }, { $x: $x }, grad); + } + function leakyRelu_(x, alpha) { + if (alpha === void 0) { alpha = 0.2; } + var $x = convertToTensor(x, 'x', 'leakyRelu'); + return maximum(scalar(alpha).mul($x), $x); + } + function prelu_(x, alpha) { + var $x = convertToTensor(x, 'x', 'prelu'); + var $alpha = convertToTensor(alpha, 'alpha', 'prelu'); + var zero = scalar(0); + return maximum(zero, $x).add($alpha.mul(minimum(zero, $x))); + } + var elu = op({ elu_: elu_ }); + var leakyRelu = op({ leakyRelu_: leakyRelu_ }); + var prelu = op({ prelu_: prelu_ }); + var relu = op({ relu_: relu_ }); + var selu = op({ selu_: selu_ }); + + function transpose_(x, perm) { + var $x = convertToTensor(x, 'x', 'transpose'); + if (perm == null) { + perm = $x.shape.map(function (s, i) { return i; }).reverse(); + } + assert($x.rank === perm.length, "Error in transpose: rank of input " + $x.rank + " " + + ("must match length of perm " + perm + ".")); + perm.forEach(function (axis) { + assert(axis >= 0 && axis < $x.rank, "All entries in 'perm' must be between 0 and " + ($x.rank - 1) + + (" but got " + perm)); + }); + if ($x.rank <= 1) { + return $x.clone(); + } + var der = function (dy) { + var undoPerm = getUndoAxesPermutation(perm); + return { $x: function () { return dy.transpose(undoPerm); } }; + }; + return ENV.engine.runKernel(function (backend) { return backend.transpose($x, perm); }, { $x: $x }, der); + } + var transpose = op({ transpose_: transpose_ }); + + function localResponseNormalization_(x, depthRadius, bias, alpha, beta) { + if (depthRadius === void 0) { depthRadius = 5; } + if (bias === void 0) { bias = 1; } + if (alpha === void 0) { alpha = 1; } + if (beta === void 0) { beta = 0.5; } + var $x = convertToTensor(x, 'x', 'localResponseNormalization'); + assert($x.rank === 4 || $x.rank === 3, "Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank " + $x.rank + "."); + assert(isInt(depthRadius), "Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius " + depthRadius + "."); + var x4D = $x; + var reshapedTo4D = false; + if ($x.rank === 3) { + reshapedTo4D = true; + x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]); + } + var backward = function (dy, saved) { + var outputImage = saved[0]; + return { + x4D: function () { return ENV.engine.runKernel(function (backend) { return backend.LRNGrad(dy, x4D, outputImage, depthRadius, bias, alpha, beta); }, {}); } + }; + }; + var res = ENV.engine.runKernel(function (backend, save) { return save(backend.localResponseNormalization4D(x4D, depthRadius, bias, alpha, beta)); }, { x4D: x4D }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + else { + return res; + } + } + var localResponseNormalization = op({ localResponseNormalization_: localResponseNormalization_ }); + + function norm_(x, ord, axis, keepDims) { + if (ord === void 0) { ord = 'euclidean'; } + if (axis === void 0) { axis = null; } + if (keepDims === void 0) { keepDims = false; } + x = convertToTensor(x, 'x', 'norm'); + var norm = normImpl(x, ord, axis); + var keepDimsShape = norm.shape; + if (keepDims) { + var axes = parseAxisParam(axis, x.shape); + keepDimsShape = expandShapeToKeepDim(norm.shape, axes); + } + return norm.reshape(keepDimsShape); + } + function normImpl(x, p, axis) { + if (axis === void 0) { axis = null; } + if (x.rank === 0) { + return x.abs(); + } + if (x.rank !== 1 && axis === null) { + return normImpl(x.reshape([-1]), p, axis); + } + if (x.rank === 1 || typeof axis === 'number' || + axis instanceof Array && axis.length === 1) { + if (p === 1) { + return x.abs().sum(axis); + } + if (p === Infinity) { + return x.abs().max(axis); + } + if (p === -Infinity) { + return x.abs().min(axis); + } + if (p === 'euclidean' || p === 2) { + return x.abs().pow(scalar(2, 'int32')).sum(axis).sqrt(); + } + throw new Error("Error in norm: invalid ord value: " + p); + } + if (axis instanceof Array && axis.length === 2) { + if (p === 1) { + return x.abs().sum(axis[0]).max(axis[1] - 1); + } + if (p === Infinity) { + return x.abs().sum(axis[1]).max(axis[0]); + } + if (p === -Infinity) { + return x.abs().sum(axis[1]).min(axis[0]); + } + if (p === 'fro' || p === 'euclidean') { + return x.square().sum(axis).sqrt(); + } + throw new Error("Error in norm: invalid ord value: " + p); + } + throw new Error("Error in norm: invalid axis: " + axis); + } + var norm = op({ norm_: norm_ }); + + function unsortedSegmentSum_(x, segmentIds, numSegments) { + var $x = convertToTensor(x, 'x', 'unsortedSegmentSum'); + var $segmentIds = convertToTensor(segmentIds, 'segmentIds', 'unsortedSegmentSum', 'int32'); + assert($segmentIds.dtype === 'int32', 'segmentIds must be of dtype `int32`'); + assert(isInt(numSegments), 'numSegments must be of dtype int'); + var gradFunc = function (dy) { + var derX = function () { + return gatherDropNegatives(dy, $segmentIds); + }; + return { $x: derX }; + }; + return ENV.engine.runKernel(function (backend) { + return backend.unsortedSegmentSum($x, $segmentIds, numSegments); + }, { $x: $x }, gradFunc); + } + function gather_(x, indices, axis) { + if (axis === void 0) { axis = 0; } + var $x = convertToTensor(x, 'x', 'gather'); + var $indices = convertToTensor(indices, 'indices', 'gather', 'int32'); + assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`'); + axis = parseAxisParam(axis, $x.shape)[0]; + var grad = function (dy) { + var derX = function () { + if (axis === 0) { + return unsortedSegmentSum(dy, $indices, $x.shape[axis]); + } + var paramsShape = $x.shape; + var indicesSize = $indices.size; + var outerShape = paramsShape.slice(0, axis); + var outerDims = outerShape.length; + var innerShape = paramsShape.slice(axis, paramsShape.length).slice(1); + var innerDims = innerShape.length; + var outerAxesIndices = arrayRange(0, outerDims); + var innerAxesIndices = arrayRange(outerDims + 1, outerDims + 1 + innerDims); + var valuesShape = arrayConcat([outerShape, [indicesSize], innerShape]); + var values = dy.reshape(valuesShape); + var reshapedIndices = $indices.reshape([indicesSize]); + var transposeDims = arrayConcat([[outerDims], outerAxesIndices, innerAxesIndices]); + var valuesTranspose = values.transpose(transposeDims); + var paramsGrad = unsortedSegmentSum(valuesTranspose, reshapedIndices, $x.shape[axis]); + var invertTransposeDims = getUndoAxesPermutation(transposeDims); + paramsGrad = paramsGrad.transpose(invertTransposeDims); + return paramsGrad; + }; + return { $x: derX }; + }; + return ENV.engine.runKernel(function (backend) { return backend.gather($x, $indices, axis); }, { $x: $x }, grad); + } + function arrayRange(start, stop) { + var result = []; + for (var i = start; i < stop; ++i) { + result.push(i); + } + return result; + } + function arrayConcat(arrays) { + var result = []; + for (var i = 0; i < arrays.length; ++i) { + for (var j = 0; j < arrays[i].length; ++j) { + result.push(arrays[i][j]); + } + } + return result; + } + function gatherDropNegatives(x, indices) { + var zeroClippedIndices = maximum(indices, zerosLike(indices)); + var gathered = gather(x, zeroClippedIndices); + var isPositive = greaterEqual(indices, scalar(0, 'int32')); + var numIters = gathered.rank - isPositive.rank; + for (var i = 0; i < numIters; ++i) { + isPositive = expandDims(isPositive, i + 1); + } + isPositive = logicalAnd(isPositive, ones$1(gathered.shape, 'bool')); + var zeroSlice = zerosLike(gathered); + return where(isPositive, gathered, zeroSlice); + } + var gather = op({ gather_: gather_ }); + var unsortedSegmentSum = op({ unsortedSegmentSum_: unsortedSegmentSum_ }); + + function multiRNNCell_(lstmCells, data, c, h) { + var $data = convertToTensor(data, 'data', 'multiRNNCell'); + var $c = convertToTensorArray(c, 'c', 'multiRNNCell'); + var $h = convertToTensorArray(h, 'h', 'multiRNNCell'); + var input = $data; + var newStates = []; + for (var i = 0; i < lstmCells.length; i++) { + var output = lstmCells[i](input, $c[i], $h[i]); + newStates.push(output[0]); + newStates.push(output[1]); + input = output[1]; + } + var newC = []; + var newH = []; + for (var i = 0; i < newStates.length; i += 2) { + newC.push(newStates[i]); + newH.push(newStates[i + 1]); + } + return [newC, newH]; + } + function basicLSTMCell_(forgetBias, lstmKernel, lstmBias, data, c, h) { + var $forgetBias = convertToTensor(forgetBias, 'forgetBias', 'basicLSTMCell'); + var $lstmKernel = convertToTensor(lstmKernel, 'lstmKernel', 'basicLSTMCell'); + var $lstmBias = convertToTensor(lstmBias, 'lstmBias', 'basicLSTMCell'); + var $data = convertToTensor(data, 'data', 'basicLSTMCell'); + var $c = convertToTensor(c, 'c', 'basicLSTMCell'); + var $h = convertToTensor(h, 'h', 'basicLSTMCell'); + var combined = $data.concat($h, 1); + var weighted = combined.matMul($lstmKernel); + var res = weighted.add($lstmBias); + var batchSize = res.shape[0]; + var sliceCols = res.shape[1] / 4; + var sliceSize = [batchSize, sliceCols]; + var i = res.slice([0, 0], sliceSize); + var j = res.slice([0, sliceCols], sliceSize); + var f = res.slice([0, sliceCols * 2], sliceSize); + var o = res.slice([0, sliceCols * 3], sliceSize); + var newC = i.sigmoid().mulStrict(j.tanh()).addStrict($c.mulStrict($forgetBias.add(f).sigmoid())); + var newH = newC.tanh().mulStrict(o.sigmoid()); + return [newC, newH]; + } + var basicLSTMCell = op({ basicLSTMCell_: basicLSTMCell_ }); + var multiRNNCell = op({ multiRNNCell_: multiRNNCell_ }); + + function movingAverage_(v, x, decay, step, zeroDebias) { + if (zeroDebias === void 0) { zeroDebias = true; } + var $v = convertToTensor(v, 'v', 'movingAverage'); + var $x = convertToTensor(x, 'x', 'movingAverage'); + var $decay = convertToTensor(decay, 'decay', 'movingAverage'); + assertTypesMatch($v, $x); + assert(arraysEqual($v.shape, $x.shape), 'Shape mismatch in v and x'); + var one = scalar(1); + var oneMinusDecay = one.sub($decay); + var update = $x.sub($v).mul(oneMinusDecay); + if (zeroDebias) { + assert(step != null, 'When using zeroDebias: true, step is required.'); + var $step = convertToTensor(step, 'step', 'movingAverage'); + update = update.div(one.sub(pow($decay, $step))); + } + return $v.add(update); + } + var movingAverage = op({ movingAverage_: movingAverage_ }); + + function stridedSlice_(x, begin, end, strides, beginMask, endMask) { + if (beginMask === void 0) { beginMask = 0; } + if (endMask === void 0) { endMask = 0; } + var $x = convertToTensor(x, 'x', 'stridedSlice'); + return ENV.engine.runKernel(function (backend) { return backend.stridedSlice($x, begin, end, strides, beginMask, endMask); }, { $x: $x }); + } + var stridedSlice = op({ stridedSlice_: stridedSlice_ }); + + function topk_(x, k, sorted) { + if (k === void 0) { k = 1; } + if (sorted === void 0) { sorted = true; } + var $x = convertToTensor(x, 'x', 'topk'); + if ($x.rank === 0) { + throw new Error('topk() expects the input to be of rank 1 or higher'); + } + var lastDim = $x.shape[$x.shape.length - 1]; + if (k > lastDim) { + throw new Error("'k' passed to topk() must be <= the last dimension (" + lastDim + ") " + + ("but got " + k)); + } + var _a = ENV.engine.runKernel(function (b) { return b.topk($x, k, sorted); }, { $x: $x }), values = _a[0], indices = _a[1]; + return { values: values, indices: indices }; + } + var topk = op({ topk_: topk_ }); + + (function (Reduction) { + Reduction[Reduction["NONE"] = 0] = "NONE"; + Reduction[Reduction["MEAN"] = 1] = "MEAN"; + Reduction[Reduction["SUM"] = 2] = "SUM"; + Reduction[Reduction["SUM_BY_NONZERO_WEIGHTS"] = 3] = "SUM_BY_NONZERO_WEIGHTS"; + })(exports.Reduction || (exports.Reduction = {})); + function computeWeightedLoss_(losses, weights, reduction) { + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $losses = convertToTensor(losses, 'losses', 'computeWeightedLoss'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'computeWeightedLoss'); + } + var weightedLoss = ($weights == null) ? $losses : $losses.mul($weights); + if (reduction === exports.Reduction.NONE) { + return weightedLoss; + } + if (reduction === exports.Reduction.SUM) { + return weightedLoss.sum(); + } + if (reduction === exports.Reduction.MEAN) { + if ($weights == null) { + return weightedLoss.mean(); + } + else { + var broadcastFactor = sizeFromShape($losses.shape) / sizeFromShape($weights.shape); + var result = weightedLoss.sum().div($weights.sum()); + return broadcastFactor > 1 ? result.div(scalar(broadcastFactor)) : + result; + } + } + if (reduction === exports.Reduction.SUM_BY_NONZERO_WEIGHTS) { + if ($weights == null) { + return weightedLoss.sum().div(scalar($losses.size)); + } + else { + var broadcastedWeights = $weights.mul(ones$1($losses.shape)); + var numNonZeros = broadcastedWeights.notEqual(scalar(0)).sum().toFloat(); + return weightedLoss.sum().div(numNonZeros); + } + } + throw Error("Unknown reduction: " + reduction); + } + function absoluteDifference_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'absoluteDifference'); + var $predictions = convertToTensor(predictions, 'predictions', 'absoluteDifference'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'absoluteDifference'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in absoluteDifference: '); + var losses = $labels.sub($predictions).abs(); + return computeWeightedLoss(losses, $weights, reduction); + } + function meanSquaredError_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'meanSquaredError'); + var $predictions = convertToTensor(predictions, 'predictions', 'meanSquaredError'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'meanSquaredError'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in meanSquaredError: '); + var losses = $labels.squaredDifference($predictions); + return computeWeightedLoss(losses, $weights, reduction); + } + function cosineDistance_(labels, predictions, axis, weights, reduction) { + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'cosineDistance'); + var $predictions = convertToTensor(predictions, 'predictions', 'cosineDistance'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'cosineDistance'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in cosineDistance: '); + var one = scalar(1); + var losses = one.sub($labels.mul($predictions).sum(axis, true)); + return computeWeightedLoss(losses, $weights, reduction); + } + function hingeLoss_(labels, predictions, weights, reduction) { + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'hingeLoss'); + var $predictions = convertToTensor(predictions, 'predictions', 'hingeLoss'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'hingeLoss'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in hingeLoss: '); + var one = scalar(1); + $labels = scalar(2).mul($labels).sub(one); + var losses = one.sub($labels.mul($predictions)).relu(); + return computeWeightedLoss(losses, $weights, reduction); + } + function logLoss_(labels, predictions, weights, epsilon, reduction) { + if (epsilon === void 0) { epsilon = 1e-7; } + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'logLoss'); + var $predictions = convertToTensor(predictions, 'predictions', 'logLoss'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'logLoss'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in logLoss: '); + var one = scalar(1); + var epsilonScalar = scalar(epsilon); + var losses = $labels.mul($predictions.add(epsilonScalar).log()) + .neg() + .sub(one.sub($labels).mul(one.sub($predictions).add(epsilonScalar).log())); + return computeWeightedLoss(losses, $weights, reduction); + } + function sigmoidCrossEntropyWithLogits_(labels, logits) { + var $labels = convertToTensor(labels, 'labels', 'sigmoidCrossEntropyWithLogits'); + var $logits = convertToTensor(logits, 'logits', 'sigmoidCrossEntropyWithLogits'); + assertShapesMatch($labels.shape, $logits.shape, 'Error in sigmoidCrossEntropyWithLogits: '); + var maxOutput = $logits.relu(); + var outputXTarget = $logits.mul($labels); + var sigmoidOutput = $logits.abs().neg().exp().log1p(); + return maxOutput.sub(outputXTarget).add(sigmoidOutput); + } + function sigmoidCrossEntropy_(multiClassLabels, logits, weights, labelSmoothing, reduction) { + if (labelSmoothing === void 0) { labelSmoothing = 0; } + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $multiClassLabels = convertToTensor(multiClassLabels, 'multiClassLabels', 'sigmoidCrossEntropy'); + var $logits = convertToTensor(logits, 'logits', 'sigmoidCrossEntropy'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'sigmoidCrossEntropy'); + } + assertShapesMatch($multiClassLabels.shape, $logits.shape, 'Error in sigmoidCrossEntropy: '); + if (labelSmoothing > 0) { + var labelSmoothingScalar = scalar(labelSmoothing); + var one = scalar(1); + var half = scalar(0.5); + $multiClassLabels = $multiClassLabels.mul(one.sub(labelSmoothingScalar)) + .add(half.mul(labelSmoothingScalar)); + } + var losses = sigmoidCrossEntropyWithLogits_($multiClassLabels, $logits); + return computeWeightedLoss(losses, $weights, reduction); + } + function huberLoss_(labels, predictions, weights, delta, reduction) { + if (delta === void 0) { delta = 1.0; } + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $labels = convertToTensor(labels, 'labels', 'huberLoss'); + var $predictions = convertToTensor(predictions, 'predictions', 'huberLoss'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'huberLoss'); + } + assertShapesMatch($labels.shape, $predictions.shape, 'Error in huberLoss: '); + var deltaScalar = scalar(delta); + var error = $predictions.sub($labels).abs(); + var quadratic = minimum(error, deltaScalar); + var linear = error.sub(quadratic); + var losses = scalar(0.5).mul(quadratic.square()).add(deltaScalar.mul(linear)); + return computeWeightedLoss(losses, $weights, reduction); + } + function softmaxCrossEntropyWithLogits_(labels, logits, dim) { + if (dim === void 0) { dim = -1; } + if (dim === -1) { + dim = logits.rank - 1; + } + if (dim !== logits.rank - 1) { + throw Error("Softmax cross entropy along a non-last dimension is not yet " + + ("supported. Labels / logits was rank " + logits.rank + " ") + + ("and dim was " + dim)); + } + var customOp = customGrad(function (labels, logits) { + var keepDims = true; + var lse = logits.logSumExp([dim], keepDims); + var logResult = logits.toFloat().sub(lse); + var costVector = logResult.mul(labels).neg(); + var value = costVector.sum([dim]); + var gradFunc = function (dy) { + var dyShape = expandShapeToKeepDim(dy.shape, [dim]); + return [ + dy.reshape(dyShape).mul(labels.toFloat().sub(logResult.exp())), + dy.reshape(dyShape).mul(logResult.exp().sub(labels.toFloat())), + ]; + }; + return { value: value, gradFunc: gradFunc }; + }); + return customOp(labels, logits); + } + function softmaxCrossEntropy_(onehotLabels, logits, weights, labelSmoothing, reduction) { + if (labelSmoothing === void 0) { labelSmoothing = 0; } + if (reduction === void 0) { reduction = exports.Reduction.SUM_BY_NONZERO_WEIGHTS; } + var $onehotLabels = convertToTensor(onehotLabels, 'onehotLabels', 'softmaxCrossEntropy'); + var $logits = convertToTensor(logits, 'logits', 'softmaxCrossEntropy'); + var $weights = null; + if (weights != null) { + $weights = convertToTensor(weights, 'weights', 'softmaxCrossEntropy'); + } + assertShapesMatch($onehotLabels.shape, $logits.shape, 'Error in softmaxCrossEntropy: '); + if (labelSmoothing > 0) { + var labelSmoothingScalar = scalar(labelSmoothing); + var one = scalar(1); + var numClasses = scalar($onehotLabels.shape[1]); + $onehotLabels = $onehotLabels.mul(one.sub(labelSmoothingScalar)) + .add(labelSmoothingScalar.div(numClasses)); + } + var losses = softmaxCrossEntropyWithLogits_($onehotLabels, $logits); + return computeWeightedLoss(losses, $weights, reduction); + } + var absoluteDifference = op({ absoluteDifference_: absoluteDifference_ }); + var computeWeightedLoss = op({ computeWeightedLoss_: computeWeightedLoss_ }); + var cosineDistance = op({ cosineDistance_: cosineDistance_ }); + var hingeLoss = op({ hingeLoss_: hingeLoss_ }); + var huberLoss = op({ huberLoss_: huberLoss_ }); + var logLoss = op({ logLoss_: logLoss_ }); + var meanSquaredError = op({ meanSquaredError_: meanSquaredError_ }); + var sigmoidCrossEntropy = op({ sigmoidCrossEntropy_: sigmoidCrossEntropy_ }); + var softmaxCrossEntropy = op({ softmaxCrossEntropy_: softmaxCrossEntropy_ }); + + var loss_ops = /*#__PURE__*/Object.freeze({ + get Reduction () { return exports.Reduction; }, + absoluteDifference: absoluteDifference, + computeWeightedLoss: computeWeightedLoss, + cosineDistance: cosineDistance, + hingeLoss: hingeLoss, + huberLoss: huberLoss, + logLoss: logLoss, + meanSquaredError: meanSquaredError, + sigmoidCrossEntropy: sigmoidCrossEntropy, + softmaxCrossEntropy: softmaxCrossEntropy + }); + + function gramSchmidt_(xs) { + var inputIsTensor2D; + if (Array.isArray(xs)) { + inputIsTensor2D = false; + assert(xs != null && xs.length > 0, 'Gram-Schmidt process: input must not be null, undefined, or empty'); + var dim = xs[0].shape[0]; + for (var i = 1; i < xs.length; ++i) { + assert(xs[i].shape[0] === dim, 'Gram-Schmidt: Non-unique lengths found in the input vectors: ' + + ("(" + xs[i].shape[0] + " vs. " + dim + ")")); + } + } + else { + inputIsTensor2D = true; + xs = split(xs, xs.shape[0], 0).map(function (x) { return squeeze(x, [0]); }); + } + assert(xs.length <= xs[0].shape[0], "Gram-Schmidt: Number of vectors (" + xs.length + ") exceeds " + + ("number of dimensions (" + xs[0].shape[0] + ").")); + var ys = []; + var xs1d = xs; + var _loop_1 = function (i) { + ys.push(ENV.engine.tidy(function () { + var x = xs1d[i]; + if (i > 0) { + for (var j = 0; j < i; ++j) { + var proj = sum(ys[j].mulStrict(x)).mul(ys[j]); + x = x.sub(proj); + } + } + return x.div(norm(x, 'euclidean')); + })); + }; + for (var i = 0; i < xs.length; ++i) { + _loop_1(i); + } + if (inputIsTensor2D) { + return stack(ys, 0); + } + else { + return ys; + } + } + function qr_(x, fullMatrices) { + if (fullMatrices === void 0) { fullMatrices = false; } + if (x.rank < 2) { + throw new Error("qr() requires input tensor to have a rank >= 2, but got rank " + x.rank); + } + else if (x.rank === 2) { + return qr2d(x, fullMatrices); + } + else { + var outerDimsProd = x.shape.slice(0, x.shape.length - 2) + .reduce(function (value, prev) { return value * prev; }); + var x2ds = unstack(x.reshape([ + outerDimsProd, x.shape[x.shape.length - 2], + x.shape[x.shape.length - 1] + ]), 0); + var q2ds_1 = []; + var r2ds_1 = []; + x2ds.forEach(function (x2d) { + var _a = qr2d(x2d, fullMatrices), q2d = _a[0], r2d = _a[1]; + q2ds_1.push(q2d); + r2ds_1.push(r2d); + }); + var q = stack(q2ds_1, 0).reshape(x.shape); + var r = stack(r2ds_1, 0).reshape(x.shape); + return [q, r]; + } + } + function qr2d(x, fullMatrices) { + if (fullMatrices === void 0) { fullMatrices = false; } + return ENV.engine.tidy(function () { + if (x.shape.length !== 2) { + throw new Error("qr2d() requires a 2D Tensor, but got a " + x.shape.length + "D Tensor."); + } + var m = x.shape[0]; + var n = x.shape[1]; + var q = eye(m); + var r = x.clone(); + var one2D = tensor2d([[1]], [1, 1]); + var w = one2D.clone(); + var iters = m >= n ? n : m; + var _loop_2 = function (j) { + var _a; + var rTemp = r; + var wTemp = w; + var qTemp = q; + _a = ENV.engine.tidy(function () { + var rjEnd1 = r.slice([j, j], [m - j, 1]); + var normX = rjEnd1.norm(); + var rjj = r.slice([j, j], [1, 1]); + var s = rjj.sign().neg(); + var u1 = rjj.sub(s.mul(normX)); + var wPre = rjEnd1.div(u1); + if (wPre.shape[0] === 1) { + w = one2D.clone(); + } + else { + w = one2D.concat(wPre.slice([1, 0], [wPre.shape[0] - 1, wPre.shape[1]]), 0); + } + var tau = s.matMul(u1).div(normX).neg(); + var rjEndAll = r.slice([j, 0], [m - j, n]); + var tauTimesW = tau.mul(w); + if (j === 0) { + r = rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll))); + } + else { + r = r.slice([0, 0], [j, n]) + .concat(rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll))), 0); + } + var qAllJEnd = q.slice([0, j], [m, q.shape[1] - j]); + if (j === 0) { + q = qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose())); + } + else { + q = q.slice([0, 0], [m, j]) + .concat(qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose())), 1); + } + return [w, r, q]; + }), w = _a[0], r = _a[1], q = _a[2]; + dispose([rTemp, wTemp, qTemp]); + }; + for (var j = 0; j < iters; ++j) { + _loop_2(j); + } + if (!fullMatrices && m > n) { + q = q.slice([0, 0], [m, n]); + r = r.slice([0, 0], [n, n]); + } + return [q, r]; + }); + } + var gramSchmidt = op({ gramSchmidt_: gramSchmidt_ }); + var qr = op({ qr_: qr_ }); + + var linalg_ops = /*#__PURE__*/Object.freeze({ + gramSchmidt: gramSchmidt, + qr: qr + }); + + function resizeBilinear_(images, size, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + var $images = convertToTensor(images, 'images', 'resizeBilinear'); + assert($images.rank === 3 || $images.rank === 4, "Error in resizeBilinear: x must be rank 3 or 4, but got " + + ("rank " + $images.rank + ".")); + assert(size.length === 2, "Error in resizeBilinear: new shape must 2D, but got shape " + + (size + ".")); + var batchImages = $images; + var reshapedTo4D = false; + if ($images.rank === 3) { + reshapedTo4D = true; + batchImages = + $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]); + } + var newHeight = size[0], newWidth = size[1]; + var forward = function (backend, save) { + return backend.resizeBilinear(batchImages, newHeight, newWidth, alignCorners); + }; + var backward = function (dy, saved) { + return { + batchImages: function () { return ENV.engine.runKernel(function (backend) { + return backend.resizeBilinearBackprop(dy, batchImages, alignCorners); + }, {}); } + }; + }; + var res = ENV.engine.runKernel(forward, { batchImages: batchImages }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function resizeNearestNeighbor_(images, size, alignCorners) { + if (alignCorners === void 0) { alignCorners = false; } + var $images = convertToTensor(images, 'images', 'resizeNearestNeighbor'); + assert($images.rank === 3 || $images.rank === 4, "Error in resizeNearestNeighbor: x must be rank 3 or 4, but got " + + ("rank " + $images.rank + ".")); + assert(size.length === 2, "Error in resizeNearestNeighbor: new shape must 2D, but got shape " + + (size + ".")); + assert($images.dtype === 'float32' || $images.dtype === 'int32', '`images` must have `int32` or `float32` as dtype'); + var batchImages = $images; + var reshapedTo4D = false; + if ($images.rank === 3) { + reshapedTo4D = true; + batchImages = + $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]); + } + var newHeight = size[0], newWidth = size[1]; + var forward = function (backend, save) { + return backend.resizeNearestNeighbor(batchImages, newHeight, newWidth, alignCorners); + }; + var backward = function (dy, saved) { + return { + batchImages: function () { return ENV.engine.runKernel(function (backend) { return backend.resizeNearestNeighborBackprop(dy, batchImages, alignCorners); }, {}); } + }; + }; + var res = ENV.engine.runKernel(forward, { batchImages: batchImages }, backward); + if (reshapedTo4D) { + return res.as3D(res.shape[1], res.shape[2], res.shape[3]); + } + return res; + } + function nonMaxSuppression_(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold === void 0) { iouThreshold = 0.5; } + if (scoreThreshold === void 0) { scoreThreshold = Number.NEGATIVE_INFINITY; } + var $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppression'); + var $scores = convertToTensor(scores, 'scores', 'nonMaxSuppression'); + var inputs = nonMaxSuppSanityCheck($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); + maxOutputSize = inputs.maxOutputSize; + iouThreshold = inputs.iouThreshold; + scoreThreshold = inputs.scoreThreshold; + return ENV.engine.runKernel(function (b) { return b.nonMaxSuppression($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); }, { $boxes: $boxes }); + } + function nonMaxSuppressionAsync_(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold === void 0) { iouThreshold = 0.5; } + if (scoreThreshold === void 0) { scoreThreshold = Number.NEGATIVE_INFINITY; } + return __awaiter(this, void 0, void 0, function () { + var $boxes, $scores, inputs, boxesVals, scoresVals, res; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppressionAsync'); + $scores = convertToTensor(scores, 'scores', 'nonMaxSuppressionAsync'); + inputs = nonMaxSuppSanityCheck($boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold); + maxOutputSize = inputs.maxOutputSize; + iouThreshold = inputs.iouThreshold; + scoreThreshold = inputs.scoreThreshold; + return [4, $boxes.data()]; + case 1: + boxesVals = _a.sent(); + return [4, $scores.data()]; + case 2: + scoresVals = _a.sent(); + res = nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + if ($boxes !== boxes) { + $boxes.dispose(); + } + if ($scores !== scores) { + $scores.dispose(); + } + return [2, res]; + } + }); + }); + } + function nonMaxSuppSanityCheck(boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + if (iouThreshold == null) { + iouThreshold = 0.5; + } + if (scoreThreshold == null) { + scoreThreshold = Number.NEGATIVE_INFINITY; + } + var numBoxes = boxes.shape[0]; + maxOutputSize = Math.min(maxOutputSize, numBoxes); + assert(0 <= iouThreshold && iouThreshold <= 1, "iouThreshold must be in [0, 1], but was '" + iouThreshold + "'"); + assert(boxes.rank === 2, "boxes must be a 2D tensor, but was of rank '" + boxes.rank + "'"); + assert(boxes.shape[1] === 4, "boxes must have 4 columns, but 2nd dimension was " + boxes.shape[1]); + assert(scores.rank === 1, 'scores must be a 1D tensor'); + assert(scores.shape[0] === numBoxes, "scores has incompatible shape with boxes. Expected " + numBoxes + ", " + + ("but was " + scores.shape[0])); + return { maxOutputSize: maxOutputSize, iouThreshold: iouThreshold, scoreThreshold: scoreThreshold }; + } + var resizeBilinear = op({ resizeBilinear_: resizeBilinear_ }); + var resizeNearestNeighbor = op({ resizeNearestNeighbor_: resizeNearestNeighbor_ }); + var nonMaxSuppression = op({ nonMaxSuppression_: nonMaxSuppression_ }); + var nonMaxSuppressionAsync = nonMaxSuppressionAsync_; + + var image_ops = /*#__PURE__*/Object.freeze({ + resizeBilinear: resizeBilinear, + resizeNearestNeighbor: resizeNearestNeighbor, + nonMaxSuppression: nonMaxSuppression, + nonMaxSuppressionAsync: nonMaxSuppressionAsync + }); + + + + var ops = /*#__PURE__*/Object.freeze({ + image: image_ops, + linalg: linalg_ops, + losses: loss_ops, + op: op, + batchNormalization2d: batchNormalization2d, + batchNormalization3d: batchNormalization3d, + batchNormalization4d: batchNormalization4d, + batchNormalization: batchNormalization, + concat: concat, + concat1d: concat1d, + concat2d: concat2d, + concat3d: concat3d, + concat4d: concat4d, + conv1d: conv1d, + conv2d: conv2d, + depthwiseConv2d: depthwiseConv2d, + separableConv2d: separableConv2d, + conv2dTranspose: conv2dTranspose, + matMul: matMul, + dot: dot, + outerProduct: outerProduct, + reverse: reverse, + reverse1d: reverse1d, + reverse2d: reverse2d, + reverse3d: reverse3d, + reverse4d: reverse4d, + maxPool: maxPool, + avgPool: avgPool, + slice: slice, + slice1d: slice1d, + slice2d: slice2d, + slice3d: slice3d, + slice4d: slice4d, + abs: abs, + acos: acos, + acosh: acosh, + asin: asin, + asinh: asinh, + atan: atan, + atanh: atanh, + ceil: ceil, + clipByValue: clipByValue, + cos: cos, + cosh: cosh, + erf: erf, + exp: exp, + expm1: expm1, + floor: floor, + log: log$1, + log1p: log1p, + logSigmoid: logSigmoid, + neg: neg, + reciprocal: reciprocal, + round: round, + rsqrt: rsqrt, + sigmoid: sigmoid, + sign: sign, + sin: sin, + sinh: sinh, + softplus: softplus, + sqrt: sqrt, + square: square, + step: step, + tan: tan, + tanh: tanh$1, + all: all, + any: any, + argMax: argMax, + argMin: argMin, + logSumExp: logSumExp, + max: max, + mean: mean, + min: min, + moments: moments, + sum: sum, + equal: equal, + equalStrict: equalStrict, + greater: greater, + greaterEqual: greaterEqual, + greaterEqualStrict: greaterEqualStrict, + greaterStrict: greaterStrict, + less: less, + lessEqual: lessEqual, + lessEqualStrict: lessEqualStrict, + lessStrict: lessStrict, + notEqual: notEqual, + notEqualStrict: notEqualStrict, + add: add, + addN: addN, + addStrict: addStrict, + atan2: atan2, + div: div, + divStrict: divStrict, + floorDiv: floorDiv, + maximum: maximum, + maximumStrict: maximumStrict, + minimum: minimum, + minimumStrict: minimumStrict, + mod: mod, + modStrict: modStrict, + mul: mul, + mulStrict: mulStrict, + pow: pow, + powStrict: powStrict, + squaredDifference: squaredDifference, + squaredDifferenceStrict: squaredDifferenceStrict, + sub: sub, + subStrict: subStrict, + elu: elu, + leakyRelu: leakyRelu, + prelu: prelu, + relu: relu, + selu: selu, + logicalAnd: logicalAnd, + logicalNot: logicalNot, + logicalOr: logicalOr, + logicalXor: logicalXor, + where: where, + whereAsync: whereAsync, + buffer: buffer, + toPixels: toPixels, + print: print, + cast: cast, + clone: clone, + cumsum: cumsum, + expandDims: expandDims, + eye: eye, + fromPixels: fromPixels, + multinomial: multinomial, + oneHot: oneHot, + pad: pad, + pad1d: pad1d, + pad2d: pad2d, + pad3d: pad3d, + pad4d: pad4d, + rand: rand, + randomNormal: randomNormal, + randomUniform: randomUniform, + reshape: reshape, + split: split, + squeeze: squeeze, + stack: stack, + tile: tile, + truncatedNormal: truncatedNormal, + unstack: unstack, + batchToSpaceND: batchToSpaceND, + spaceToBatchND: spaceToBatchND, + fill: fill, + linspace: linspace, + ones: ones$1, + range: range, + scalar: scalar, + tensor: tensor, + tensor1d: tensor1d, + tensor2d: tensor2d, + tensor3d: tensor3d, + tensor4d: tensor4d, + tensor5d: tensor5d, + tensor6d: tensor6d, + zeros: zeros, + onesLike: onesLike, + zerosLike: zerosLike, + transpose: transpose, + softmax: softmax, + localResponseNormalization: localResponseNormalization, + norm: norm, + gather: gather, + unsortedSegmentSum: unsortedSegmentSum, + basicLSTMCell: basicLSTMCell, + multiRNNCell: multiRNNCell, + movingAverage: movingAverage, + stridedSlice: stridedSlice, + topk: topk + }); + + var MathBackendCPU = (function () { + function MathBackendCPU() { + this.data = new WeakMap(); + this.firstUse = true; + if (ENV.get('IS_BROWSER')) { + this.canvas = document.createElement('canvas'); + } + } + MathBackendCPU.prototype.register = function (dataId, shape, dtype) { + if (this.firstUse) { + this.firstUse = false; + if (ENV.get('IS_NODE')) { + warn('\n============================\n' + + 'Hi there 👋. Looks like you are running TensorFlow.js in ' + + 'Node.js. To speed things up dramatically, install our node ' + + 'backend, which binds to TensorFlow C++, by running ' + + 'npm i @tensorflow/tfjs-node, ' + + 'or npm i @tensorflow/tfjs-node-gpu if you have CUDA. ' + + 'Then call require(\'@tensorflow/tfjs-node\'); (-gpu ' + + 'suffix for CUDA) at the start of your program. ' + + 'Visit https://github.com/tensorflow/tfjs-node for more details.' + + '\n============================\n'); + } + } + if (this.data.has(dataId)) { + throw new Error("Data buffer is already registered"); + } + this.data.set(dataId, null); + }; + MathBackendCPU.prototype.write = function (dataId, values) { + if (values == null) { + throw new Error('MathBackendCPU.write(): values can not be null'); + } + this.throwIfNoData(dataId); + this.data.set(dataId, values); + }; + MathBackendCPU.prototype.fromPixels = function (pixels, numChannels) { + if (pixels == null) { + throw new Error('pixels passed to tf.fromPixels() can not be null'); + } + var vals; + if (ENV.get('IS_NODE') && pixels.getContext == null) { + throw new Error('When running in node, pixels must be an HTMLCanvasElement ' + + 'like the one returned by the `canvas` npm package'); + } + if (pixels.getContext != null) { + vals = pixels + .getContext('2d') + .getImageData(0, 0, pixels.width, pixels.height) + .data; + } + else if (pixels instanceof ImageData) { + vals = pixels.data; + } + else if (pixels instanceof HTMLImageElement || + pixels instanceof HTMLVideoElement) { + if (this.canvas == null) { + throw new Error('Can\'t read pixels from HTMLImageElement outside ' + + 'the browser.'); + } + this.canvas.width = pixels.width; + this.canvas.height = pixels.height; + this.canvas.getContext('2d').drawImage(pixels, 0, 0, pixels.width, pixels.height); + vals = this.canvas.getContext('2d') + .getImageData(0, 0, pixels.width, pixels.height) + .data; + } + else { + throw new Error('pixels passed to tf.fromPixels() must be either an ' + + "HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or " + + ("ImageData, but was " + pixels.constructor.name)); + } + var values; + if (numChannels === 4) { + values = new Int32Array(vals); + } + else { + var numPixels = pixels.width * pixels.height; + values = new Int32Array(numPixels * numChannels); + for (var i = 0; i < numPixels; i++) { + for (var channel = 0; channel < numChannels; ++channel) { + values[i * numChannels + channel] = vals[i * 4 + channel]; + } + } + } + var outShape = [pixels.height, pixels.width, numChannels]; + return tensor3d(values, outShape, 'int32'); + }; + MathBackendCPU.prototype.read = function (dataId) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.readSync(dataId)]; + }); + }); + }; + MathBackendCPU.prototype.readSync = function (dataId) { + this.throwIfNoData(dataId); + return this.data.get(dataId); + }; + MathBackendCPU.prototype.disposeData = function (dataId) { + if (this.data.has(dataId)) { + this.data.delete(dataId); + } + }; + MathBackendCPU.prototype.time = function (f) { + return __awaiter(this, void 0, void 0, function () { + var start, kernelMs; + return __generator(this, function (_a) { + start = now(); + f(); + kernelMs = now() - start; + return [2, { kernelMs: kernelMs }]; + }); + }); + }; + MathBackendCPU.prototype.memory = function () { + return { + unreliable: true + }; + }; + MathBackendCPU.prototype.throwIfNoData = function (dataId) { + if (!this.data.has(dataId)) { + throw new Error("CPU backend: No data found for this tensor. " + + "Did you change your backend in the middle of the program? " + + "New backends can't use Tensors created with previous backends"); + } + }; + MathBackendCPU.prototype.slice = function (x, begin, size) { + var buffer$$1 = buffer(size, x.dtype); + for (var i = 0; i < buffer$$1.size; ++i) { + var loc = buffer$$1.indexToLoc(i); + var xLoc = loc.map(function (idx, j) { return idx + begin[j]; }); + buffer$$1.set.apply(buffer$$1, [x.get.apply(x, xLoc)].concat(loc)); + } + return buffer$$1.toTensor(); + }; + MathBackendCPU.prototype.stridedSlice = function (x, begin, end, strides, beginMask, endMask) { + var _a = getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask), beginIndex = _a[0], size = _a[1]; + if (size.some(function (axis) { return axis === 0; })) { + return tensor([], size); + } + var buffer$$1 = buffer(size, x.dtype); + for (var i = 0; i < buffer$$1.size; i++) { + var loc = buffer$$1.indexToLoc(i); + var newLoc = new Array(loc.length); + for (var j = 0; j < newLoc.length; j++) { + newLoc[j] = loc[j] * strides[j] + beginIndex[j]; + } + buffer$$1.set.apply(buffer$$1, [x.get.apply(x, newLoc)].concat(loc)); + } + return buffer$$1.toTensor(); + }; + MathBackendCPU.prototype.reverse = function (x, axis) { + var buffer$$1 = buffer(x.shape, x.dtype); + var xBuffer = x.buffer(); + var _loop_1 = function (i) { + var outLoc = buffer$$1.indexToLoc(i); + var inLoc = outLoc.slice(); + axis.forEach(function (ax) { return inLoc[ax] = x.shape[ax] - 1 - inLoc[ax]; }); + buffer$$1.set.apply(buffer$$1, [xBuffer.get.apply(xBuffer, inLoc)].concat(outLoc)); + }; + for (var i = 0; i < buffer$$1.size; i++) { + _loop_1(i); + } + return buffer$$1.toTensor(); + }; + MathBackendCPU.prototype.concat = function (a, b) { + var outShape = computeOutShape$1(a.shape, b.shape, 1); + var buffer$$1 = buffer(outShape, a.dtype); + if (a.shape[0] === 1 && b.shape[0] === 1) { + var aVals = a.dataSync(); + var bVals = b.dataSync(); + var vals = buffer$$1.values; + vals.set(aVals, 0); + vals.set(bVals, a.size); + return buffer$$1.toTensor(); + } + for (var i = 0; i < outShape[0]; ++i) { + for (var j = 0; j < a.shape[1]; ++j) { + buffer$$1.set(a.get(i, j), i, j); + } + for (var j = 0; j < b.shape[1]; ++j) { + buffer$$1.set(b.get(i, j), i, j + a.shape[1]); + } + } + return buffer$$1.toTensor(); + }; + MathBackendCPU.prototype.neg = function (x) { + return this.multiply(scalar(-1), x); + }; + MathBackendCPU.prototype.add = function (a, b) { + return this.broadcastedBinaryOp(a, b, upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue + bValue; }); + }; + MathBackendCPU.prototype.addN = function (tensors) { + var vals = tensors.map(function (t) { return t.dataSync(); }); + var result = buffer(tensors[0].shape, tensors[0].dtype); + var resultVals = result.values; + for (var i = 0; i < tensors.length; i++) { + var currVals = vals[i]; + for (var j = 0; j < resultVals.length; j++) { + resultVals[j] += currVals[j]; + } + } + return result.toTensor(); + }; + MathBackendCPU.prototype.subtract = function (a, b) { + return this.broadcastedBinaryOp(a, b, upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue - bValue; }); + }; + MathBackendCPU.prototype.pow = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aValue, bValue) { return Math.pow(aValue, bValue); }); + }; + MathBackendCPU.prototype.matMul = function (a, b, transposeA, transposeB) { + var sharedDim = transposeA ? a.shape[0] : a.shape[1]; + var leftDim = transposeA ? a.shape[1] : a.shape[0]; + var rightDim = transposeB ? b.shape[0] : b.shape[1]; + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var _a = transposeA ? [1, a.strides[0]] : [a.strides[0], 1], aOuterStep = _a[0], aInnerStep = _a[1]; + var _b = transposeB ? [b.strides[0], 1] : [1, b.strides[0]], bOuterStep = _b[0], bInnerStep = _b[1]; + var aOuterEnd = leftDim * aOuterStep; + var bOuterEnd = rightDim * bOuterStep; + var result = new Float32Array(leftDim * rightDim); + var resultIndex = 0; + for (var aOuter = 0; aOuter < aOuterEnd; aOuter += aOuterStep) { + for (var bOuter = 0; bOuter < bOuterEnd; bOuter += bOuterStep) { + var aInner = aOuter; + var bInner = bOuter; + var sum$$1 = 0; + for (var k = 0; k < sharedDim; ++k) { + sum$$1 += aValues[aInner] * bValues[bInner]; + aInner += aInnerStep; + bInner += bInnerStep; + } + result[resultIndex++] = sum$$1; + } + } + return tensor2d(result, [leftDim, rightDim]); + }; + MathBackendCPU.prototype.multiply = function (a, b) { + return this.broadcastedBinaryOp(a, b, upcastType(a.dtype, b.dtype), function (aValue, bValue) { return aValue * bValue; }); + }; + MathBackendCPU.prototype.realDivide = function (a, b) { + var op$$1 = function (a, b) { return a / b; }; + var outputDtype = 'float32'; + return this.broadcastedBinaryOp(a, b, outputDtype, op$$1); + }; + MathBackendCPU.prototype.floorDiv = function (a, b) { + var op$$1 = function (a, b) { return Math.floor(a / b); }; + var outputDtype = 'int32'; + return this.broadcastedBinaryOp(a, b, outputDtype, op$$1); + }; + MathBackendCPU.prototype.sum = function (x, axes) { + assertAxesAreInnerMostDims('sum', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var resultDtype = upcastType(x.dtype, 'int32'); + var result = zeros(outShape, resultDtype); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var sum$$1 = 0; + for (var j = 0; j < reduceSize; ++j) { + sum$$1 += aVals[offset + j]; + } + vals[i] = sum$$1; + } + return result; + }; + MathBackendCPU.prototype.unsortedSegmentSum = function (x, segmentIds, numSegments) { + var res = []; + var numIters = x.rank - segmentIds.rank; + for (var i = 0; i < numIters; ++i) { + segmentIds = segmentIds.expandDims(i + 1); + } + for (var i = 0; i < numSegments; ++i) { + var segmentId = scalar(i, 'int32'); + var mask = equal(segmentId, segmentIds).asType('float32'); + var sum$$1 = mask.mul(x).sum(0); + res.push(sum$$1); + } + return stack(res); + }; + MathBackendCPU.prototype.argMin = function (x, axis) { + var axes = [axis]; + assertAxesAreInnerMostDims('argMin', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, 'int32'); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var min$$1 = aVals[offset]; + var minIndex = 0; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value < min$$1) { + min$$1 = value; + minIndex = j; + } + } + vals[i] = minIndex; + } + return result; + }; + MathBackendCPU.prototype.argMax = function (x, axis) { + var axes = [axis]; + assertAxesAreInnerMostDims('argMax', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, 'int32'); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var max$$1 = aVals[offset]; + var maxIndex = 0; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value > max$$1) { + max$$1 = value; + maxIndex = j; + } + } + vals[i] = maxIndex; + } + return result; + }; + MathBackendCPU.prototype.cumsum = function (x, axis, exclusive, reverse$$1) { + if (axis !== x.rank - 1) { + throw new Error("backend.cumsum in CPU expects an inner-most axis=" + (x.rank - 1) + " " + + ("but got axis=" + axis)); + } + var resultDtype = upcastType(x.dtype, 'int32'); + var result = zeros(x.shape, resultDtype); + var vals = result.dataSync(); + var aVals = x.dataSync(); + var finalDim = x.shape[x.rank - 1]; + var indexAdjuster = reverse$$1 ? + function (i, j) { return i + finalDim - j - 1; } : + function (i, j) { return i + j; }; + for (var i = 0; i < aVals.length; i += finalDim) { + for (var j = 0; j < finalDim; j++) { + var idx = indexAdjuster(i, j); + if (j === 0) { + vals[idx] = exclusive ? 0 : aVals[idx]; + } + else { + var prevIdx = indexAdjuster(i, j - 1); + vals[idx] = exclusive ? aVals[prevIdx] + vals[prevIdx] : + aVals[idx] + vals[prevIdx]; + } + } + } + return result; + }; + MathBackendCPU.prototype.equal = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal === bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.notEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal !== bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.less = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal < bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.lessEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal <= bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.greater = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal > bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.greaterEqual = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return (aVal >= bVal) ? 1 : 0; + }); + }; + MathBackendCPU.prototype.logicalNot = function (x) { + var values = x.dataSync(); + var newValues = new Int32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = values[i] ? 0 : 1; + } + return Tensor.make(x.shape, { values: newValues }, 'bool'); + }; + MathBackendCPU.prototype.logicalAnd = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return aVal && bVal; + }); + }; + MathBackendCPU.prototype.logicalOr = function (a, b) { + return this.broadcastedBinaryOp(a, b, 'bool', function (aVal, bVal) { + return aVal || bVal; + }); + }; + MathBackendCPU.prototype.select = function (condition, a, b) { + var values = condition.dataSync(); + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var result = zeros(a.shape, upcastType(a.dtype, b.dtype)); + var newValues = result.dataSync(); + var index = 0; + var offset = condition.rank === 0 || condition.rank > 1 || a.rank === 1 ? + 1 : + a.shape[1]; + for (var i = 0; i < values.length; i++) { + for (var j = 0; j < offset; j++) { + if (values[i] === 1) { + newValues[index++] = aValues[i]; + } + else { + newValues[index++] = bValues[i]; + } + } + } + return result; + }; + MathBackendCPU.prototype.where = function (condition) { + var condVals = condition.dataSync(); + return whereImpl(condition.shape, condVals); + }; + MathBackendCPU.prototype.topk = function (x, k, sorted) { + var xVals = x.dataSync(); + return topkImpl(xVals, x.shape, x.dtype, k, sorted); + }; + MathBackendCPU.prototype.min = function (x, axes) { + assertAxesAreInnerMostDims('min', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, x.dtype); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var min$$1 = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value < min$$1) { + min$$1 = value; + } + } + vals[i] = min$$1; + } + return result; + }; + MathBackendCPU.prototype.minimum = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { return Math.min(aVal, bVal); }); + }; + MathBackendCPU.prototype.mod = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { + var rem = aVal % bVal; + if ((aVal < 0 && bVal < 0) || (aVal >= 0 && bVal >= 0)) { + return rem; + } + else { + return (rem + bVal) % bVal; + } + }); + }; + MathBackendCPU.prototype.max = function (x, axes) { + assertAxesAreInnerMostDims('max', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, x.dtype); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var max$$1 = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + if (value > max$$1) { + max$$1 = value; + } + } + vals[i] = max$$1; + } + return result; + }; + MathBackendCPU.prototype.maximum = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { return Math.max(aVal, bVal); }); + }; + MathBackendCPU.prototype.all = function (x, axes) { + assertAxesAreInnerMostDims('all', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, x.dtype); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var all$$1 = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + all$$1 = all$$1 && value; + } + vals[i] = all$$1; + } + return result; + }; + MathBackendCPU.prototype.any = function (x, axes) { + assertAxesAreInnerMostDims('any', axes, x.rank); + var _a = computeOutAndReduceShapes(x.shape, axes), outShape = _a[0], reduceShape = _a[1]; + var result = zeros(outShape, x.dtype); + var reduceSize = sizeFromShape(reduceShape); + var vals = result.dataSync(); + var aVals = x.dataSync(); + for (var i = 0; i < vals.length; ++i) { + var offset = i * reduceSize; + var anyVal = aVals[offset]; + for (var j = 0; j < reduceSize; ++j) { + var value = aVals[offset + j]; + anyVal = anyVal || value; + } + vals[i] = anyVal; + } + return result; + }; + MathBackendCPU.prototype.squaredDifference = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aVal, bVal) { + var diff = aVal - bVal; + return diff * diff; + }); + }; + MathBackendCPU.prototype.ceil = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.ceil(values[i]); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.floor = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.floor(values[i]); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.sign = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + if (values[i] < 0) { + newValues[i] = -1; + } + else if (values[i] > 0) { + newValues[i] = 1; + } + else { + newValues[i] = 0; + } + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.round = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var base = Math.floor(values[i]); + if (values[i] - base < 0.5) { + newValues[i] = Math.floor(values[i]); + } + else if (values[i] - base > 0.5) { + newValues[i] = Math.ceil(values[i]); + } + else { + if (base % 2.0 === 0.0) { + newValues[i] = base; + } + else { + newValues[i] = base + 1.0; + } + } + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.exp = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.exp(values[i]); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.expm1 = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = Math.expm1(values[i]); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.log = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.log(value); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.log1p = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.log1p(value); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.sqrt = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = Math.sqrt(value); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.rsqrt = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = 1 / Math.sqrt(value); + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.square = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + newValues[i] = value * value; + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.reciprocal = function (x) { + var values = x.dataSync(); + var newValues = new Float32Array(values.length); + for (var i = 0; i < values.length; ++i) { + newValues[i] = 1 / values[i]; + } + return Tensor.make(x.shape, { values: newValues }); + }; + MathBackendCPU.prototype.relu = function (x) { + var res = zeros(x.shape, x.dtype); + var resVals = res.dataSync(); + var inVals = x.dataSync(); + for (var i = 0; i < inVals.length; ++i) { + resVals[i] = Math.max(0, inVals[i]); + } + return res; + }; + MathBackendCPU.prototype.elu = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 0) { + resultValues[i] = v; + } + else { + resultValues[i] = (Math.exp(v) - 1); + } + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.eluDer = function (dy, y) { + var resultValues = new Float32Array(y.size); + var values = y.dataSync(); + var dyValues = dy.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 1) { + resultValues[i] = dyValues[i]; + } + else { + resultValues[i] = dyValues[i] * (v + 1); + } + } + return Tensor.make(y.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.selu = function (x) { + var scaleAlpha = SELU_SCALEALPHA; + var scale = SELU_SCALE; + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + if (v >= 0) { + resultValues[i] = scale * v; + } + else { + resultValues[i] = scaleAlpha * (Math.exp(v) - 1); + } + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.clip = function (x, min$$1, max$$1) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.min(max$$1, Math.max(min$$1, values[i])); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.abs = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.abs(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.int = function (x) { + var resultValues = new Int32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = values[i]; + } + return Tensor.make(x.shape, { values: resultValues }, 'int32'); + }; + MathBackendCPU.prototype.sigmoid = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = 1 / (1 + Math.exp(-values[i])); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.softplus = function (x) { + var epsilon = 1.1920928955078125e-7; + var threshold = Math.log(epsilon) + 2.0; + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var tooLarge = values[i] > -threshold; + var tooSmall = values[i] < threshold; + var expX = Math.exp(values[i]); + var result = void 0; + if (tooSmall) { + result = expX; + } + else if (tooLarge) { + result = values[i]; + } + else { + result = Math.log(1.0 + expX); + } + resultValues[i] = result; + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.sin = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.sin(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.cos = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.cos(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.tan = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.tan(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.asin = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.asin(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.acos = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.acos(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atan = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.atan(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atan2 = function (a, b) { + return this.broadcastedBinaryOp(a, b, a.dtype, function (aValue, bValue) { return Math.atan2(aValue, bValue); }); + }; + MathBackendCPU.prototype.sinh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.sinh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.cosh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.cosh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.tanh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = tanh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.asinh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.asinh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.acosh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.acosh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.atanh = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + resultValues[i] = Math.atanh(values[i]); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.erf = function (x) { + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + var p = ERF_P; + var a1 = ERF_A1; + var a2 = ERF_A2; + var a3 = ERF_A3; + var a4 = ERF_A4; + var a5 = ERF_A5; + for (var i = 0; i < values.length; ++i) { + var v = values[i]; + var t = 1.0 / (1.0 + p * v); + resultValues[i] = 1.0 - + (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t * + Math.exp(-v * v); + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.step = function (x, alpha) { + if (alpha === void 0) { alpha = 0; } + var resultValues = new Float32Array(x.size); + var values = x.dataSync(); + for (var i = 0; i < values.length; ++i) { + var value = values[i]; + if (isNaN(value)) { + resultValues[i] = NaN; + } + else { + resultValues[i] = value > 0 ? 1 : alpha; + } + } + return Tensor.make(x.shape, { values: resultValues }); + }; + MathBackendCPU.prototype.conv2d = function (x, filter, convInfo) { + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var padLeft = convInfo.padInfo.left; + var padTop = convInfo.padInfo.top; + var y = buffer(convInfo.outShape, x.dtype); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * convInfo.strideHeight - padLeft; + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * convInfo.strideWidth - padTop; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; wR++) { + var xR = xRCorner + wR * dilationHeight; + if (xR < 0 || xR >= convInfo.inHeight) { + continue; + } + for (var wC = 0; wC < filterWidth; wC++) { + var xC = xCCorner + wC * dilationWidth; + if (xC < 0 || xC >= convInfo.inWidth) { + continue; + } + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + var pixel = x.get(b, xR, xC, d1); + var weight = filter.get(wR, wC, d1, d2); + dotProd += pixel * weight; + } + } + } + y.set(dotProd, b, yR, yC, d2); + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.conv2dDerInput = function (dy, filter, convInfo) { + var dx = buffer(convInfo.inShape, 'float32'); + var dxValues = dx.values; + var _a = dx.strides, dxS0 = _a[0], dxS1 = _a[1], dxS2 = _a[2]; + var dyValues = dy.dataSync(); + var _b = dy.strides, dyS0 = _b[0], dyS1 = _b[1], dyS2 = _b[2]; + var fltValues = filter.dataSync(); + var _c = filter.strides, fltS0 = _c[0], fltS1 = _c[1], fltS2 = _c[2]; + var batchSize = convInfo.batchSize, filterHeight = convInfo.filterHeight, filterWidth = convInfo.filterWidth, inChannels = convInfo.inChannels, inHeight = convInfo.inHeight, inWidth = convInfo.inWidth, outChannels = convInfo.outChannels, outHeight = convInfo.outHeight, outWidth = convInfo.outWidth, strideHeight = convInfo.strideHeight, strideWidth = convInfo.strideWidth; + var topPad = filterHeight - 1 - convInfo.padInfo.top; + var leftPad = filterWidth - 1 - convInfo.padInfo.left; + for (var b = 0; b < batchSize; ++b) { + for (var d1 = 0; d1 < inChannels; ++d1) { + for (var xR = 0; xR < inHeight; ++xR) { + var xRCorner = xR - topPad; + var xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight)); + var yRMax = Math.min(outHeight, (filterHeight + xRCorner) / strideHeight); + for (var xC = 0; xC < inWidth; ++xC) { + var xCCorner = xC - leftPad; + var xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth)); + var yCMax = Math.min(outWidth, (filterWidth + xCCorner) / strideWidth); + var dotProd = 0; + for (var yR = xRMin; yR < yRMax; ++yR) { + var wR = yR * strideHeight - xRCorner; + for (var yC = xCMin; yC < yCMax; ++yC) { + var wC = yC * strideWidth - xCCorner; + var dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC; + var fltOffset = fltS0 * (filterHeight - 1 - wR) + + fltS1 * (filterWidth - 1 - wC) + fltS2 * d1; + for (var d2 = 0; d2 < outChannels; ++d2) { + var pixel = dyValues[dyOffset + d2]; + var weight = fltValues[fltOffset + d2]; + dotProd += pixel * weight; + } + } + } + dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd; + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.conv2dDerFilter = function (x, dy, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dW = buffer(convInfo.filterShape, 'float32'); + var leftPad = convInfo.padInfo.left; + var topPad = convInfo.padInfo.top; + for (var wR = 0; wR < filterHeight; ++wR) { + var yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight)); + var yRMax = Math.min(convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight); + for (var wC = 0; wC < filterWidth; ++wC) { + var yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth)); + var yCMax = Math.min(convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth); + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + var dotProd = 0; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var yR = yRMin; yR < yRMax; ++yR) { + var xR = wR + yR * strideHeight - topPad; + for (var yC = yCMin; yC < yCMax; ++yC) { + var xC = wC + yC * strideWidth - leftPad; + dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2); + } + } + } + dW.set(dotProd, wR, wC, d1, d2); + } + } + } + } + return dW.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2D = function (x, filter, convInfo) { + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dilationHeight = convInfo.dilationHeight; + var dilationWidth = convInfo.dilationWidth; + var padLeft = convInfo.padInfo.left; + var padTop = convInfo.padInfo.top; + var chMul = convInfo.outChannels / convInfo.inChannels; + var y = buffer(convInfo.outShape, x.dtype); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d1 = 0; d1 < convInfo.inChannels; ++d1) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * convInfo.strideHeight - padLeft; + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * convInfo.strideWidth - padTop; + for (var q = 0; q < chMul; ++q) { + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var xR = xRCorner + wR * dilationHeight; + if (xR < 0 || xR >= convInfo.inHeight) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var xC = xCCorner + wC * dilationWidth; + if (xC < 0 || xC >= convInfo.inWidth) { + continue; + } + var pixel = x.get(b, xR, xC, d1); + var weight = filter.get(wR, wC, d1, q); + dotProd += pixel * weight; + } + } + y.set(dotProd, b, yR, yC, d1 * chMul + q); + } + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2DDerInput = function (dy, filter, convInfo) { + var dx = buffer(convInfo.inShape, 'float32'); + var dxValues = dx.values; + var _a = dx.strides, dxS0 = _a[0], dxS1 = _a[1], dxS2 = _a[2]; + var dyValues = dy.dataSync(); + var _b = dy.strides, dyS0 = _b[0], dyS1 = _b[1], dyS2 = _b[2]; + var fltValues = filter.dataSync(); + var _c = filter.strides, fltS0 = _c[0], fltS1 = _c[1], fltS2 = _c[2]; + var batchSize = convInfo.batchSize, filterHeight = convInfo.filterHeight, filterWidth = convInfo.filterWidth, inChannels = convInfo.inChannels, inHeight = convInfo.inHeight, inWidth = convInfo.inWidth, outChannels = convInfo.outChannels, outHeight = convInfo.outHeight, outWidth = convInfo.outWidth, strideHeight = convInfo.strideHeight, strideWidth = convInfo.strideWidth; + var topPad = filterHeight - 1 - convInfo.padInfo.top; + var leftPad = filterWidth - 1 - convInfo.padInfo.left; + var chMul = outChannels / inChannels; + for (var b = 0; b < batchSize; ++b) { + for (var d1 = 0; d1 < inChannels; ++d1) { + for (var xR = 0; xR < inHeight; ++xR) { + var xRCorner = xR - topPad; + var xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight)); + var yRMax = Math.min(outHeight, (filterHeight + xRCorner) / strideHeight); + for (var xC = 0; xC < inWidth; ++xC) { + var xCCorner = xC - leftPad; + var xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth)); + var yCMax = Math.min(outWidth, (filterWidth + xCCorner) / strideWidth); + var dotProd = 0; + for (var yR = xRMin; yR < yRMax; ++yR) { + var wR = yR * strideHeight - xRCorner; + for (var yC = xCMin; yC < yCMax; ++yC) { + var wC = yC * strideWidth - xCCorner; + var dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC; + var fltOffset = fltS0 * (filterHeight - 1 - wR) + + fltS1 * (filterWidth - 1 - wC) + fltS2 * d1; + for (var dm = 0; dm < chMul; ++dm) { + var d2 = d1 * chMul + dm; + var pixel = dyValues[dyOffset + d2]; + var weight = fltValues[fltOffset + dm]; + dotProd += pixel * weight; + } + } + } + dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd; + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.depthwiseConv2DDerFilter = function (x, dy, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var dW = buffer(convInfo.filterShape, 'float32'); + var leftPad = convInfo.padInfo.left; + var topPad = convInfo.padInfo.top; + var chMul = convInfo.outChannels / convInfo.inChannels; + for (var wR = 0; wR < filterHeight; ++wR) { + var yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight)); + var yRMax = Math.min(convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight); + for (var wC = 0; wC < filterWidth; ++wC) { + var yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth)); + var yCMax = Math.min(convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth); + for (var d2 = 0; d2 < convInfo.outChannels; ++d2) { + var d1 = Math.trunc(d2 / chMul); + var dm = d2 % chMul; + var dotProd = 0; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var yR = yRMin; yR < yRMax; ++yR) { + var xR = wR + yR * strideHeight - topPad; + for (var yC = yCMin; yC < yCMax; ++yC) { + var xC = wC + yC * strideWidth - leftPad; + dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2); + } + } + } + dW.set(dotProd, wR, wC, d1, dm); + } + } + } + return dW.toTensor(); + }; + MathBackendCPU.prototype.tile = function (x, reps) { + var newShape = new Array(x.rank); + for (var i = 0; i < newShape.length; i++) { + newShape[i] = x.shape[i] * reps[i]; + } + var result = buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < result.values.length; ++i) { + var newLoc = result.indexToLoc(i); + var originalLoc = new Array(x.rank); + for (var i_1 = 0; i_1 < originalLoc.length; i_1++) { + originalLoc[i_1] = newLoc[i_1] % x.shape[i_1]; + } + var originalIndex = xBuf.locToIndex(originalLoc); + result.values[i] = xBuf.values[originalIndex]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.pad = function (x, paddings, constantValue) { + var outShape = paddings.map(function (p, i) { return p[0] + x.shape[i] + p[1]; }); + var start = paddings.map(function (p) { return p[0]; }); + var xBuffer = x.buffer(); + var buffer$$1 = buffer(outShape, x.dtype); + if (constantValue !== 0) { + buffer$$1.values.fill(constantValue); + } + for (var i = 0; i < x.size; i++) { + var coords = xBuffer.indexToLoc(i); + var outCoords = coords.map(function (c, i) { return c + start[i]; }); + buffer$$1.set.apply(buffer$$1, [x.get.apply(x, coords)].concat(outCoords)); + } + return buffer$$1.toTensor(); + }; + MathBackendCPU.prototype.transpose = function (x, perm) { + var newShape = new Array(x.rank); + for (var i = 0; i < newShape.length; i++) { + newShape[i] = x.shape[perm[i]]; + } + var values = x.dataSync(); + var result = buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < x.size; ++i) { + var loc = xBuf.indexToLoc(i); + var newLoc = new Array(loc.length); + for (var i_2 = 0; i_2 < newLoc.length; i_2++) { + newLoc[i_2] = loc[perm[i_2]]; + } + var newIndex = result.locToIndex(newLoc); + result.values[newIndex] = values[i]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.gather = function (x, indices, axis) { + var newShape = x.shape.slice(); + var indicesValues = indices.dataSync(); + newShape[axis] = indicesValues.length; + var result = buffer(newShape, x.dtype); + var xBuf = x.buffer(); + for (var i = 0; i < result.size; ++i) { + var newLoc = result.indexToLoc(i); + var originalLoc = newLoc.slice(); + originalLoc[axis] = indicesValues[newLoc[axis]]; + var originalIndex = xBuf.locToIndex(originalLoc); + result.values[i] = xBuf.values[originalIndex]; + } + return result.toTensor(); + }; + MathBackendCPU.prototype.batchToSpaceND = function (x, blockShape, crops) { + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var reshaped = getReshaped(x.shape, blockShape, prod); + var permuted = getPermuted(reshaped.length, blockShape.length); + var reshapedPermuted = getReshapedPermuted(x.shape, blockShape, prod); + var sliceBeginCoords = getSliceBeginCoords(crops, blockShape.length); + var sliceSize = getSliceSize(reshapedPermuted, crops, blockShape.length); + return x.reshape(reshaped) + .transpose(permuted) + .reshape(reshapedPermuted) + .slice(sliceBeginCoords, sliceSize); + }; + MathBackendCPU.prototype.spaceToBatchND = function (x, blockShape, paddings) { + var prod = blockShape.reduce(function (a, b) { return a * b; }); + var completePaddings = [[0, 0]]; + completePaddings.push.apply(completePaddings, paddings); + for (var i = 1 + blockShape.length; i < x.shape.length; ++i) { + completePaddings.push([0, 0]); + } + var paddedX = x.pad(completePaddings); + var reshapedPaddedShape = getReshaped(paddedX.shape, blockShape, prod, false); + var permutedReshapedPaddedPermutation = getPermuted(reshapedPaddedShape.length, blockShape.length, false); + var flattenShape = getReshapedPermuted(paddedX.shape, blockShape, prod, false); + return paddedX.reshape(reshapedPaddedShape) + .transpose(permutedReshapedPaddedPermutation) + .reshape(flattenShape); + }; + MathBackendCPU.prototype.pool = function (x, convInfo, poolType) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var y = buffer(convInfo.outShape, 'float32'); + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * strideHeight - padTop; + var xRMin = Math.max(0, xRCorner); + var xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner); + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * strideWidth - padLeft; + var xCMin = Math.max(0, xCCorner); + var xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner); + var minMaxValue = (poolType === 'max' ? Number.NEGATIVE_INFINITY : + Number.POSITIVE_INFINITY); + var avgValue = 0; + var count = 0; + for (var xR = xRMin; xR < xRMax; ++xR) { + for (var xC = xCMin; xC < xCMax; ++xC) { + var pixel = x.get(b, xR, xC, d); + if ((poolType === 'max' && pixel > minMaxValue)) { + minMaxValue = pixel; + } + else if (poolType === 'avg') { + avgValue += pixel; + count++; + } + } + if (isNaN(minMaxValue)) { + break; + } + } + y.set(poolType === 'avg' ? avgValue / count : minMaxValue, b, yR, yC, d); + } + } + } + } + return y.toTensor(); + }; + MathBackendCPU.prototype.maxPool = function (x, convInfo) { + return this.pool(x, convInfo, 'max'); + }; + MathBackendCPU.prototype.maxPoolPositions = function (x, convInfo) { + var maxPositions = buffer(convInfo.outShape, 'int32'); + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padTop = convInfo.padInfo.top; + var padLeft = convInfo.padInfo.left; + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var yR = 0; yR < convInfo.outHeight; ++yR) { + var xRCorner = yR * strideHeight - padTop; + var xRMin = Math.max(0, xRCorner); + var xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner); + for (var yC = 0; yC < convInfo.outWidth; ++yC) { + var xCCorner = yC * strideWidth - padLeft; + var xCMin = Math.max(0, xCCorner); + var xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner); + var maxValue = Number.NEGATIVE_INFINITY; + var maxPosition = -1; + for (var xR = xRMin; xR < xRMax; ++xR) { + var wR = xR - xRCorner; + for (var xC = xCMin; xC < xCMax; ++xC) { + var wC = xC - xCCorner; + var pixel = x.get(b, xR, xC, d); + if (pixel > maxValue) { + maxValue = pixel; + maxPosition = wR * filterWidth + wC; + } + } + } + maxPositions.set(maxPosition, b, yR, yC, d); + } + } + } + } + return maxPositions.toTensor(); + }; + MathBackendCPU.prototype.maxPoolBackprop = function (dy, x, y, convInfo) { + var maxPositions = this.maxPoolPositions(x, convInfo); + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var dx = buffer(x.shape, 'float32'); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var dxR = 0; dxR < convInfo.inHeight; ++dxR) { + for (var dxC = 0; dxC < convInfo.inWidth; ++dxC) { + var dyRCorner = dxR - padTop; + var dyCCorner = dxC - padLeft; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var dyR = (dyRCorner + wR) / strideHeight; + if (dyR < 0 || dyR >= convInfo.outHeight || + Math.floor(dyR) !== dyR) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var dyC = (dyCCorner + wC) / strideWidth; + if (dyC < 0 || dyC >= convInfo.outWidth || + Math.floor(dyC) !== dyC) { + continue; + } + var maxPos = filterHeight * filterWidth - 1 - + maxPositions.get(b, dyR, dyC, d); + var curPos = wR * filterWidth + wC; + var mask = maxPos === curPos ? 1 : 0; + if (mask === 0) { + continue; + } + var pixel = dy.get(b, dyR, dyC, d); + dotProd += pixel * mask; + } + } + dx.set(dotProd, b, dxR, dxC, d); + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.avgPoolBackprop = function (dy, x, convInfo) { + var strideHeight = convInfo.strideHeight; + var strideWidth = convInfo.strideWidth; + var filterHeight = convInfo.filterHeight; + var filterWidth = convInfo.filterWidth; + var padLeft = filterWidth - 1 - convInfo.padInfo.left; + var padTop = filterHeight - 1 - convInfo.padInfo.top; + var dx = buffer(x.shape, 'float32'); + var avgMultiplier = 1 / (filterHeight * filterWidth); + for (var b = 0; b < convInfo.batchSize; ++b) { + for (var d = 0; d < convInfo.inChannels; ++d) { + for (var dxR = 0; dxR < convInfo.inHeight; ++dxR) { + for (var dxC = 0; dxC < convInfo.inWidth; ++dxC) { + var dyRCorner = dxR - padTop; + var dyCCorner = dxC - padLeft; + var dotProd = 0; + for (var wR = 0; wR < filterHeight; ++wR) { + var dyR = (dyRCorner + wR) / strideHeight; + if (dyR < 0 || dyR >= convInfo.outHeight || + Math.floor(dyR) !== dyR) { + continue; + } + for (var wC = 0; wC < filterWidth; ++wC) { + var dyC = (dyCCorner + wC) / strideWidth; + if (dyC < 0 || dyC >= convInfo.outWidth || + Math.floor(dyC) !== dyC) { + continue; + } + var pixel = dy.get(b, dyR, dyC, d); + dotProd += pixel; + } + } + dx.set(dotProd * avgMultiplier, b, dxR, dxC, d); + } + } + } + } + return dx.toTensor(); + }; + MathBackendCPU.prototype.cast = function (x, dtype) { + return castTensor(x, dtype, this); + }; + MathBackendCPU.prototype.reshape = function (x, shape) { + return reshapeTensor(x, shape); + }; + MathBackendCPU.prototype.avgPool = function (x, convInfo) { + return this.pool(x, convInfo, 'avg').toFloat(); + }; + MathBackendCPU.prototype.resizeBilinear = function (x, newHeight, newWidth, alignCorners) { + var _a = x.shape, batch = _a[0], oldHeight = _a[1], oldWidth = _a[2], numChannels = _a[3]; + var output = buffer([batch, newHeight, newWidth, numChannels], x.dtype); + var effectiveInputSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutputSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < newHeight; r++) { + for (var c = 0; c < newWidth; c++) { + for (var d = 0; d < numChannels; d++) { + var sourceFracRow = (effectiveInputSize[0]) * r / (effectiveOutputSize[0]); + var sourceFracCol = (effectiveInputSize[1]) * c / (effectiveOutputSize[1]); + var sourceRowFloor = Math.floor(sourceFracRow); + var sourceRowCeil = Math.min(oldHeight - 1, Math.ceil(sourceFracRow)); + var sourceColFloor = Math.floor(sourceFracCol); + var sourceColCeil = Math.min(oldWidth - 1, Math.ceil(sourceFracCol)); + var topLeft = x.get(b, sourceRowFloor, sourceColFloor, d); + var bottomLeft = x.get(b, sourceRowCeil, sourceColFloor, d); + var topRight = x.get(b, sourceRowFloor, sourceColCeil, d); + var bottomRight = x.get(b, sourceRowCeil, sourceColCeil, d); + var rowFrac = sourceFracRow - sourceRowFloor; + var colFrac = sourceFracCol - sourceColFloor; + var top_1 = topLeft + (topRight - topLeft) * colFrac; + var bottom = bottomLeft + (bottomRight - bottomLeft) * colFrac; + var newValue = top_1 + (bottom - top_1) * rowFrac; + output.set(newValue, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeBilinearBackprop = function (dy, x, alignCorners) { + var _a = x.shape, batch = _a[0], xHeight = _a[1], xWidth = _a[2], depth = _a[3]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var output = buffer([batch, xHeight, xWidth, depth], x.dtype); + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < yHeight; r++) { + var dxR = r * heightScale; + var topDxRIndex = Math.floor(dxR); + var bottomDxRIndex = Math.min(Math.ceil(dxR), xHeight - 1); + var dxRLerp = dxR - topDxRIndex; + var inverseDxRLerp = 1.0 - dxRLerp; + for (var c = 0; c < yWidth; c++) { + var dxC = c * widthScale; + var leftDxCIndex = Math.floor(dxC); + var rightDxCIndex = Math.min(Math.ceil(dxC), xWidth - 1); + var dxCLerp = dxC - leftDxCIndex; + var inverseDxCLerp = 1.0 - dxCLerp; + for (var d = 0; d < depth; d++) { + var dyVal = dy.get(b, r, c, d); + var topLeft = output.get(b, topDxRIndex, leftDxCIndex, d); + topLeft += dyVal * inverseDxRLerp * inverseDxCLerp; + output.set(topLeft, b, topDxRIndex, leftDxCIndex, d); + var topRight = output.get(b, topDxRIndex, rightDxCIndex, d); + topRight += dyVal * inverseDxRLerp * dxCLerp; + output.set(topRight, b, topDxRIndex, rightDxCIndex, d); + var bottomLeft = output.get(b, bottomDxRIndex, leftDxCIndex, d); + bottomLeft += dyVal * dxRLerp * inverseDxCLerp; + output.set(bottomLeft, b, bottomDxRIndex, leftDxCIndex, d); + var bottomRight = output.get(b, bottomDxRIndex, rightDxCIndex, d); + bottomRight += dyVal * dxRLerp * dxCLerp; + output.set(bottomRight, b, bottomDxRIndex, rightDxCIndex, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeNearestNeighbor = function (x, newHeight, newWidth, alignCorners) { + var _a = x.shape, batch = _a[0], oldHeight = _a[1], oldWidth = _a[2], numChannels = _a[3]; + var output = buffer([batch, newHeight, newWidth, numChannels], x.dtype); + var effectiveInputSize = [ + (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight, + (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth + ]; + var effectiveOutputSize = [ + (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight, + (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth + ]; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < newHeight; r++) { + for (var c = 0; c < newWidth; c++) { + for (var d = 0; d < numChannels; d++) { + var sourceFracRow = (effectiveInputSize[0]) * r / (effectiveOutputSize[0]); + var sourceFracCol = (effectiveInputSize[1]) * c / (effectiveOutputSize[1]); + var sourceNearestRow = Math.min(oldHeight - 1, alignCorners ? Math.round(sourceFracRow) : + Math.floor(sourceFracRow)); + var sourceNearestCol = Math.min(oldWidth - 1, alignCorners ? Math.round(sourceFracCol) : + Math.floor(sourceFracCol)); + var newValue = x.get(b, sourceNearestRow, sourceNearestCol, d); + output.set(newValue, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.resizeNearestNeighborBackprop = function (dy, x, alignCorners) { + var _a = x.shape, batch = _a[0], xHeight = _a[1], xWidth = _a[2], depth = _a[3]; + var _b = dy.shape, yHeight = _b[1], yWidth = _b[2]; + var output = buffer([batch, xHeight, xWidth, depth], x.dtype); + var effectiveXSize = [ + (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight, + (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth + ]; + var effectiveYSize = [ + (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight, + (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth + ]; + var heightScale = effectiveXSize[0] / effectiveYSize[0]; + var widthScale = effectiveXSize[1] / effectiveYSize[1]; + var invHeightScale = 1 / heightScale; + var invWidthScale = 1 / widthScale; + var winHeight = (Math.ceil(invHeightScale) * 2) + 2; + var winWidth = (Math.ceil(invWidthScale) * 2) + 2; + for (var b = 0; b < batch; b++) { + for (var r = 0; r < xHeight; r++) { + for (var c = 0; c < xWidth; c++) { + var startRLerp = Math.floor(r * invHeightScale); + var startDyR = Math.floor(startRLerp - (winHeight / 2)); + var startCLerp = Math.floor(c * invWidthScale); + var startDyC = Math.floor(startCLerp - (winWidth / 2)); + for (var d = 0; d < depth; d++) { + var accum = 0; + for (var dyROffset = 0; dyROffset < winHeight; dyROffset++) { + var dyR = dyROffset + startDyR; + if (dyR < 0 || dyR >= yHeight) { + continue; + } + for (var dyCOffSet = 0; dyCOffSet < winWidth; dyCOffSet++) { + var dyC = dyCOffSet + startDyC; + if (dyC < 0 || dyC >= yWidth) { + continue; + } + var sourceFracRow = effectiveXSize[0] * (dyR / effectiveYSize[0]); + var sourceFracCol = effectiveXSize[1] * (dyC / effectiveYSize[1]); + var sourceNearestRow = Math.min(xHeight - 1, alignCorners ? Math.round(sourceFracRow) : + Math.floor(sourceFracRow)); + var sourceNearestCol = Math.min(xWidth - 1, alignCorners ? Math.round(sourceFracCol) : + Math.floor(sourceFracCol)); + if (r === sourceNearestRow && c === sourceNearestCol) { + accum += dy.get(b, dyR, dyC, d); + } + } + } + output.set(accum, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.batchNormalization = function (x, mean$$1, variance, varianceEpsilon, scale, offset) { + var xValues = x.dataSync(); + var meanValues = mean$$1.dataSync(); + var varianceValues = variance.dataSync(); + var scaleValues = scale ? scale.dataSync() : new Float32Array([1]); + var offsetValues = offset ? offset.dataSync() : new Float32Array([0]); + var outValues = new Float32Array(xValues.length); + for (var i = 0; i < xValues.length; i++) { + outValues[i] = offsetValues[i % offsetValues.length] + + (xValues[i] - meanValues[i % meanValues.length]) * + scaleValues[i % scaleValues.length] / + Math.sqrt(varianceValues[i % varianceValues.length] + varianceEpsilon); + } + return tensor4d(outValues, x.shape); + }; + MathBackendCPU.prototype.localResponseNormalization4D = function (x, radius, bias, alpha, beta) { + var output = buffer(x.shape, 'float32'); + var rad = radius; + var maxD = output.shape[3] - 1; + function sumAcrossChannels(b, r, c, d) { + var sum$$1 = 0.0; + for (var j = Math.max(0, d - rad); j <= Math.min(d + rad, maxD); j++) { + var z = x.get(b, r, c, j); + sum$$1 += z * z; + } + return sum$$1; + } + for (var b = 0; b < output.shape[0]; b++) { + for (var r = 0; r <= output.shape[1]; r++) { + for (var c = 0; c < output.shape[2]; c++) { + for (var d = 0; d < output.shape[3]; d++) { + var sum$$1 = sumAcrossChannels(b, r, c, d); + var val = x.get(b, r, c, d) * Math.pow(bias + alpha * sum$$1, -beta); + output.set(val, b, r, c, d); + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.LRNGrad = function (dy, inputImage, outputImage, depthRadius, bias, alpha, beta) { + var batch = dy.shape[0]; + var rows = dy.shape[1]; + var cols = dy.shape[2]; + var depth = dy.shape[3]; + var output = buffer([batch, rows, cols, depth], 'float32'); + for (var b = 0; b < batch; ++b) { + for (var r = 0; r < rows; ++r) { + for (var c = 0; c < cols; ++c) { + for (var d = 0; d < depth; ++d) { + var depthBegin = Math.max(0, d - depthRadius); + var depthEnd = Math.min(depth, d + depthRadius + 1); + var norm$$1 = 0; + for (var k = depthBegin; k < depthEnd; ++k) { + norm$$1 += inputImage.get(b, r, c, k) * inputImage.get(b, r, c, k); + } + norm$$1 = alpha * norm$$1 + bias; + for (var k = depthBegin; k < depthEnd; ++k) { + var dyi = -2 * alpha * beta * inputImage.get(b, r, c, k) * + outputImage.get(b, r, c, d) / norm$$1; + if (d === k) { + dyi += Math.pow(norm$$1, -beta); + } + dyi *= dy.get(b, r, c, d); + output.set(dyi + output.get(b, r, c, k), b, r, c, k); + } + } + } + } + } + return output.toTensor(); + }; + MathBackendCPU.prototype.multinomial = function (logits, normalized, numSamples, seed) { + var probabilities = normalized ? logits : softmax(logits); + var batchSize = probabilities.shape[0]; + var numEvents = probabilities.shape[1]; + var res = zeros([batchSize, numSamples], 'int32'); + var resVals = res.dataSync(); + var probVals = probabilities.dataSync(); + for (var b = 0; b < batchSize; ++b) { + var offset = b * numEvents; + var cdf = new Float32Array(numEvents - 1); + cdf[0] = probVals[offset]; + for (var event_1 = 1; event_1 < cdf.length; ++event_1) { + cdf[event_1] = cdf[event_1 - 1] + probVals[offset + event_1]; + } + var random = seedrandom_1(seed.toString()); + var outOffset = b * numSamples; + for (var sampleId = 0; sampleId < numSamples; ++sampleId) { + var r = random(); + resVals[outOffset + sampleId] = cdf.length; + for (var event_2 = 0; event_2 < cdf.length; event_2++) { + if (r < cdf[event_2]) { + resVals[outOffset + sampleId] = event_2; + break; + } + } + } + } + return res; + }; + MathBackendCPU.prototype.oneHot = function (indices, depth, onValue, offValue) { + var res = new Float32Array(indices.size * depth); + res.fill(offValue); + for (var event_3 = 0; event_3 < indices.size; ++event_3) { + if (indices.get(event_3) >= 0 && indices.get(event_3) < depth) { + res[event_3 * depth + indices.get(event_3)] = onValue; + } + } + return tensor2d(res, [indices.size, depth], 'int32'); + }; + MathBackendCPU.prototype.nonMaxSuppression = function (boxes, scores, maxOutputSize, iouThreshold, scoreThreshold) { + var boxesVals = boxes.dataSync(); + var scoresVals = scores.dataSync(); + return nonMaxSuppressionImpl(boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold); + }; + MathBackendCPU.prototype.broadcastedBinaryOp = function (a, b, dtype, op$$1) { + var newShape = assertAndGetBroadcastShape(a.shape, b.shape); + var result = buffer(newShape, dtype); + var aValues = a.dataSync(); + var bValues = b.dataSync(); + var aBroadcastDims = getBroadcastDims(a.shape, newShape); + var bBroadcastDims = getBroadcastDims(b.shape, newShape); + var aBuf = a.buffer(); + var bBuf = b.buffer(); + var _loop_2 = function (i) { + var loc = result.indexToLoc(i); + var aLoc = loc.slice(-a.rank); + aBroadcastDims.forEach(function (d) { return aLoc[d] = 0; }); + var aIndex = aBuf.locToIndex(aLoc); + var bLoc = loc.slice(-b.rank); + bBroadcastDims.forEach(function (d) { return bLoc[d] = 0; }); + var bIndex = bBuf.locToIndex(bLoc); + result.values[i] = op$$1(aValues[aIndex], bValues[bIndex]); + }; + for (var i = 0; i < result.values.length; ++i) { + _loop_2(i); + } + return result.toTensor(); + }; + MathBackendCPU.prototype.dispose = function () { }; + return MathBackendCPU; + }()); + ENV.registerBackend('cpu', function () { return new MathBackendCPU(); }, 1, setTensorTracker); + + var delayCallback = typeof requestAnimationFrame !== 'undefined' ? + requestAnimationFrame : + setImmediate; + function nextFrame() { + return new Promise(function (resolve) { return delayCallback(function () { return resolve(); }); }); + } + + var DTYPE_VALUE_SIZE_MAP = { + 'float32': 4, + 'int32': 4, + 'uint16': 2, + 'uint8': 1, + 'bool': 1, + }; + + function encodeWeights(tensors) { + return __awaiter(this, void 0, void 0, function () { + var specs, dataPromises, name_1, t, tensorValues; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + specs = []; + dataPromises = []; + for (name_1 in tensors) { + t = tensors[name_1]; + if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool') { + throw new Error("Unsupported dtype in weight '" + name_1 + "': " + t.dtype); + } + specs.push({ name: name_1, shape: t.shape, dtype: t.dtype }); + dataPromises.push(t.data()); + } + return [4, Promise.all(dataPromises)]; + case 1: + tensorValues = _a.sent(); + return [2, { data: concatenateTypedArrays(tensorValues), specs: specs }]; + } + }); + }); + } + function decodeWeights(buffer, specs) { + var out = {}; + var offset = 0; + for (var _i = 0, specs_1 = specs; _i < specs_1.length; _i++) { + var spec = specs_1[_i]; + var name_2 = spec.name; + var dtype = spec.dtype; + var shape = spec.shape; + if (spec.quantization != null) { + throw new Error("decodeWeights does not support quantization yet, but encountered " + + ("weight '" + name_2 + " with quantization.'")); + } + var size = sizeFromShape(shape); + var value = void 0; + if (dtype === 'float32') { + value = tensor(new Float32Array(buffer, offset, size), shape, 'float32'); + } + else if (dtype === 'int32') { + value = tensor(new Int32Array(buffer, offset, size), shape, 'int32'); + } + else if (dtype === 'bool') { + value = tensor(new Uint8Array(buffer, offset, size), shape, 'bool'); + } + else { + throw new Error("Unsupported dtype in weight '" + name_2 + "': " + dtype); + } + out[name_2] = value; + offset += size * DTYPE_VALUE_SIZE_MAP[dtype]; + } + return out; + } + function concatenateTypedArrays(xs) { + if (xs === null) { + throw new Error("Invalid input value: " + JSON.stringify(xs)); + } + var totalByteLength = 0; + var normalizedXs = []; + xs.forEach(function (x) { + totalByteLength += x.byteLength; + normalizedXs.push(x.byteLength === x.buffer.byteLength ? x : + new x.constructor(x)); + if (!(x instanceof Float32Array || x instanceof Int32Array || + x instanceof Uint8Array)) { + throw new Error("Unsupported TypedArray subtype: " + x.constructor.name); + } + }); + var y = new Uint8Array(totalByteLength); + var offset = 0; + normalizedXs.forEach(function (x) { + y.set(new Uint8Array(x.buffer), offset); + offset += x.byteLength; + }); + return y.buffer; + } + var useNodeBuffer = typeof Buffer !== 'undefined' && + (typeof Blob === 'undefined' || typeof atob === 'undefined' || + typeof btoa === 'undefined'); + function stringByteLength(str) { + if (useNodeBuffer) { + return Buffer.byteLength(str); + } + return new Blob([str]).size; + } + function arrayBufferToBase64String(buffer) { + if (useNodeBuffer) { + return Buffer.from(buffer).toString('base64'); + } + return btoa(String.fromCharCode.apply(null, new Uint8Array(buffer))); + } + function base64StringToArrayBuffer(str) { + if (useNodeBuffer) { + var buf = Buffer.from(str, 'base64'); + return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength); + } + var s = atob(str); + var buffer = new Uint8Array(s.length); + for (var i = 0; i < s.length; ++i) { + buffer.set([s.charCodeAt(i)], i); + } + return buffer.buffer; + } + function concatenateArrayBuffers(buffers) { + var totalByteLength = 0; + buffers.forEach(function (buffer) { + totalByteLength += buffer.byteLength; + }); + var temp = new Uint8Array(totalByteLength); + var offset = 0; + buffers.forEach(function (buffer) { + temp.set(new Uint8Array(buffer), offset); + offset += buffer.byteLength; + }); + return temp.buffer; + } + function basename(path) { + var SEPARATOR = '/'; + path = path.trim(); + while (path.endsWith(SEPARATOR)) { + path = path.slice(0, path.length - 1); + } + var items = path.split(SEPARATOR); + return items[items.length - 1]; + } + function getModelArtifactsInfoForJSON(modelArtifacts) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('Expected JSON model topology, received ArrayBuffer.'); + } + return { + dateSaved: new Date(), + modelTopologyType: 'JSON', + modelTopologyBytes: modelArtifacts.modelTopology == null ? + 0 : + stringByteLength(JSON.stringify(modelArtifacts.modelTopology)), + weightSpecsBytes: modelArtifacts.weightSpecs == null ? + 0 : + stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)), + weightDataBytes: modelArtifacts.weightData == null ? + 0 : + modelArtifacts.weightData.byteLength, + }; + } + + var IORouterRegistry = (function () { + function IORouterRegistry() { + this.saveRouters = []; + this.loadRouters = []; + } + IORouterRegistry.getInstance = function () { + if (IORouterRegistry.instance == null) { + IORouterRegistry.instance = new IORouterRegistry(); + } + return IORouterRegistry.instance; + }; + IORouterRegistry.registerSaveRouter = function (saveRouter) { + IORouterRegistry.getInstance().saveRouters.push(saveRouter); + }; + IORouterRegistry.registerLoadRouter = function (loadRouter) { + IORouterRegistry.getInstance().loadRouters.push(loadRouter); + }; + IORouterRegistry.getSaveHandlers = function (url) { + return IORouterRegistry.getHandlers(url, 'save'); + }; + IORouterRegistry.getLoadHandlers = function (url) { + return IORouterRegistry.getHandlers(url, 'load'); + }; + IORouterRegistry.getHandlers = function (url, handlerType) { + var validHandlers = []; + var routers = handlerType === 'load' ? this.getInstance().loadRouters : + this.getInstance().saveRouters; + routers.forEach(function (router) { + var handler = router(url); + if (handler !== null) { + validHandlers.push(handler); + } + }); + return validHandlers; + }; + return IORouterRegistry; + }()); + + var URL_SCHEME_SUFFIX = '://'; + var ModelStoreManagerRegistry = (function () { + function ModelStoreManagerRegistry() { + this.managers = {}; + } + ModelStoreManagerRegistry.getInstance = function () { + if (ModelStoreManagerRegistry.instance == null) { + ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry(); + } + return ModelStoreManagerRegistry.instance; + }; + ModelStoreManagerRegistry.registerManager = function (scheme, manager) { + assert(scheme != null, 'scheme must not be undefined or null.'); + if (scheme.endsWith(URL_SCHEME_SUFFIX)) { + scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX)); + } + assert(scheme.length > 0, 'scheme must not be an empty string.'); + var registry = ModelStoreManagerRegistry.getInstance(); + assert(registry.managers[scheme] == null, "A model store manager is already registered for scheme '" + scheme + "'."); + registry.managers[scheme] = manager; + }; + ModelStoreManagerRegistry.getManager = function (scheme) { + var manager = this.getInstance().managers[scheme]; + if (manager == null) { + throw new Error("Cannot find model manager for scheme '" + scheme + "'"); + } + return manager; + }; + ModelStoreManagerRegistry.getSchemes = function () { + return Object.keys(this.getInstance().managers); + }; + return ModelStoreManagerRegistry; + }()); + function parseURL(url) { + if (url.indexOf(URL_SCHEME_SUFFIX) === -1) { + throw new Error("The url string provided does not contain a scheme. " + + "Supported schemes are: " + + ("" + ModelStoreManagerRegistry.getSchemes().join(','))); + } + return { + scheme: url.split(URL_SCHEME_SUFFIX)[0], + path: url.split(URL_SCHEME_SUFFIX)[1], + }; + } + function cloneModelInternal(sourceURL, destURL, deleteSource) { + if (deleteSource === void 0) { deleteSource = false; } + return __awaiter(this, void 0, void 0, function () { + var loadHandlers, loadHandler, saveHandlers, saveHandler, sourceScheme, sourcePath, sameMedium, modelArtifacts, saveResult; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + assert(sourceURL !== destURL, "Old path and new path are the same: '" + sourceURL + "'"); + loadHandlers = IORouterRegistry.getLoadHandlers(sourceURL); + assert(loadHandlers.length > 0, "Copying failed because no load handler is found for source URL " + sourceURL + "."); + assert(loadHandlers.length < 2, "Copying failed because more than one (" + loadHandlers.length + ") " + + ("load handlers for source URL " + sourceURL + ".")); + loadHandler = loadHandlers[0]; + saveHandlers = IORouterRegistry.getSaveHandlers(destURL); + assert(saveHandlers.length > 0, "Copying failed because no save handler is found for destination URL " + + (destURL + ".")); + assert(saveHandlers.length < 2, "Copying failed because more than one (" + loadHandlers.length + ") " + + ("save handlers for destination URL " + destURL + ".")); + saveHandler = saveHandlers[0]; + sourceScheme = parseURL(sourceURL).scheme; + sourcePath = parseURL(sourceURL).path; + sameMedium = sourceScheme === parseURL(sourceURL).scheme; + return [4, loadHandler.load()]; + case 1: + modelArtifacts = _a.sent(); + if (!(deleteSource && sameMedium)) return [3, 3]; + return [4, ModelStoreManagerRegistry.getManager(sourceScheme) + .removeModel(sourcePath)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [4, saveHandler.save(modelArtifacts)]; + case 4: + saveResult = _a.sent(); + if (!(deleteSource && !sameMedium)) return [3, 6]; + return [4, ModelStoreManagerRegistry.getManager(sourceScheme) + .removeModel(sourcePath)]; + case 5: + _a.sent(); + _a.label = 6; + case 6: return [2, saveResult.modelArtifactsInfo]; + } + }); + }); + } + function listModels() { + return __awaiter(this, void 0, void 0, function () { + var schemes, out, _i, schemes_1, scheme, schemeOut, path, url; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + schemes = ModelStoreManagerRegistry.getSchemes(); + out = {}; + _i = 0, schemes_1 = schemes; + _a.label = 1; + case 1: + if (!(_i < schemes_1.length)) return [3, 4]; + scheme = schemes_1[_i]; + return [4, ModelStoreManagerRegistry.getManager(scheme).listModels()]; + case 2: + schemeOut = _a.sent(); + for (path in schemeOut) { + url = scheme + URL_SCHEME_SUFFIX + path; + out[url] = schemeOut[path]; + } + _a.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2, out]; + } + }); + }); + } + function removeModel(url) { + return __awaiter(this, void 0, void 0, function () { + var schemeAndPath, manager; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + schemeAndPath = parseURL(url); + manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme); + return [4, manager.removeModel(schemeAndPath.path)]; + case 1: return [2, _a.sent()]; + } + }); + }); + } + function copyModel(sourceURL, destURL) { + return __awaiter(this, void 0, void 0, function () { + var deleteSource; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + deleteSource = false; + return [4, cloneModelInternal(sourceURL, destURL, deleteSource)]; + case 1: return [2, _a.sent()]; + } + }); + }); + } + function moveModel(sourceURL, destURL) { + return __awaiter(this, void 0, void 0, function () { + var deleteSource; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + deleteSource = true; + return [4, cloneModelInternal(sourceURL, destURL, deleteSource)]; + case 1: return [2, _a.sent()]; + } + }); + }); + } + + var DATABASE_NAME = 'tensorflowjs'; + var DATABASE_VERSION = 1; + var MODEL_STORE_NAME = 'models_store'; + var INFO_STORE_NAME = 'model_info_store'; + function getIndexedDBFactory() { + if (!ENV.get('IS_BROWSER')) { + throw new Error('Failed to obtain IndexedDB factory because the current environment' + + 'is not a web browser.'); + } + var theWindow = window; + var factory = theWindow.indexedDB || theWindow.mozIndexedDB || + theWindow.webkitIndexedDB || theWindow.msIndexedDB || + theWindow.shimIndexedDB; + if (factory == null) { + throw new Error('The current browser does not appear to support IndexedDB.'); + } + return factory; + } + function setUpDatabase(openRequest) { + var db = openRequest.result; + db.createObjectStore(MODEL_STORE_NAME, { keyPath: 'modelPath' }); + db.createObjectStore(INFO_STORE_NAME, { keyPath: 'modelPath' }); + } + var BrowserIndexedDB = (function () { + function BrowserIndexedDB(modelPath) { + this.indexedDB = getIndexedDBFactory(); + if (modelPath == null || !modelPath) { + throw new Error('For IndexedDB, modelPath must not be null, undefined or empty.'); + } + this.modelPath = modelPath; + } + BrowserIndexedDB.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserLocalStorage.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + return [2, this.databaseAction(this.modelPath, modelArtifacts)]; + }); + }); + }; + BrowserIndexedDB.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.databaseAction(this.modelPath)]; + }); + }); + }; + BrowserIndexedDB.prototype.databaseAction = function (modelPath, modelArtifacts) { + var _this = this; + return new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + if (modelArtifacts == null) { + var modelTx = db.transaction(MODEL_STORE_NAME, 'readonly'); + var modelStore = modelTx.objectStore(MODEL_STORE_NAME); + var getRequest_1 = modelStore.get(_this.modelPath); + getRequest_1.onsuccess = function () { + if (getRequest_1.result == null) { + db.close(); + return reject(new Error("Cannot find model with path '" + _this.modelPath + "' " + + "in IndexedDB.")); + } + else { + resolve(getRequest_1.result.modelArtifacts); + } + }; + getRequest_1.onerror = function (error) { + db.close(); + return reject(getRequest_1.error); + }; + modelTx.oncomplete = function () { return db.close(); }; + } + else { + var modelArtifactsInfo_1 = getModelArtifactsInfoForJSON(modelArtifacts); + var infoTx_1 = db.transaction(INFO_STORE_NAME, 'readwrite'); + var infoStore_1 = infoTx_1.objectStore(INFO_STORE_NAME); + var putInfoRequest_1 = infoStore_1.put({ modelPath: _this.modelPath, modelArtifactsInfo: modelArtifactsInfo_1 }); + var modelTx_1; + putInfoRequest_1.onsuccess = function () { + modelTx_1 = db.transaction(MODEL_STORE_NAME, 'readwrite'); + var modelStore = modelTx_1.objectStore(MODEL_STORE_NAME); + var putModelRequest = modelStore.put({ + modelPath: _this.modelPath, + modelArtifacts: modelArtifacts, + modelArtifactsInfo: modelArtifactsInfo_1 + }); + putModelRequest.onsuccess = function () { return resolve({ modelArtifactsInfo: modelArtifactsInfo_1 }); }; + putModelRequest.onerror = function (error) { + infoStore_1 = infoTx_1.objectStore(INFO_STORE_NAME); + var deleteInfoRequest = infoStore_1.delete(_this.modelPath); + deleteInfoRequest.onsuccess = function () { + db.close(); + return reject(putModelRequest.error); + }; + deleteInfoRequest.onerror = function (error) { + db.close(); + return reject(putModelRequest.error); + }; + }; + }; + putInfoRequest_1.onerror = function (error) { + db.close(); + return reject(putInfoRequest_1.error); + }; + infoTx_1.oncomplete = function () { + if (modelTx_1 == null) { + db.close(); + } + else { + modelTx_1.oncomplete = function () { return db.close(); }; + } + }; + } + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + }); + }; + BrowserIndexedDB.URL_SCHEME = 'indexeddb://'; + return BrowserIndexedDB; + }()); + var indexedDBRouter = function (url) { + if (!ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserIndexedDB.URL_SCHEME)) { + return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length)); + } + else { + return null; + } + } + }; + IORouterRegistry.registerSaveRouter(indexedDBRouter); + IORouterRegistry.registerLoadRouter(indexedDBRouter); + function browserIndexedDB(modelPath) { + return new BrowserIndexedDB(modelPath); + } + function maybeStripScheme(key) { + return key.startsWith(BrowserIndexedDB.URL_SCHEME) ? + key.slice(BrowserIndexedDB.URL_SCHEME.length) : + key; + } + var BrowserIndexedDBManager = (function () { + function BrowserIndexedDBManager() { + this.indexedDB = getIndexedDBFactory(); + } + BrowserIndexedDBManager.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + return [2, new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + var tx = db.transaction(INFO_STORE_NAME, 'readonly'); + var store = tx.objectStore(INFO_STORE_NAME); + var getAllInfoRequest = store.getAll(); + getAllInfoRequest.onsuccess = function () { + var out = {}; + for (var _i = 0, _a = getAllInfoRequest.result; _i < _a.length; _i++) { + var item = _a[_i]; + out[item.modelPath] = item.modelArtifactsInfo; + } + resolve(out); + }; + getAllInfoRequest.onerror = function (error) { + db.close(); + return reject(getAllInfoRequest.error); + }; + tx.oncomplete = function () { return db.close(); }; + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + })]; + }); + }); + }; + BrowserIndexedDBManager.prototype.removeModel = function (path) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + return __generator(this, function (_a) { + path = maybeStripScheme(path); + return [2, new Promise(function (resolve, reject) { + var openRequest = _this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION); + openRequest.onupgradeneeded = function () { return setUpDatabase(openRequest); }; + openRequest.onsuccess = function () { + var db = openRequest.result; + var infoTx = db.transaction(INFO_STORE_NAME, 'readwrite'); + var infoStore = infoTx.objectStore(INFO_STORE_NAME); + var getInfoRequest = infoStore.get(path); + var modelTx; + getInfoRequest.onsuccess = function () { + if (getInfoRequest.result == null) { + db.close(); + return reject(new Error("Cannot find model with path '" + path + "' " + + "in IndexedDB.")); + } + else { + var deleteInfoRequest = infoStore.delete(path); + var deleteModelData_1 = function () { + modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite'); + var modelStore = modelTx.objectStore(MODEL_STORE_NAME); + var deleteModelRequest = modelStore.delete(path); + deleteModelRequest.onsuccess = function () { + return resolve(getInfoRequest.result.modelArtifactsInfo); + }; + deleteModelRequest.onerror = function (error) { + return reject(getInfoRequest.error); + }; + }; + deleteInfoRequest.onsuccess = deleteModelData_1; + deleteInfoRequest.onerror = function (error) { + deleteModelData_1(); + db.close(); + return reject(getInfoRequest.error); + }; + } + }; + getInfoRequest.onerror = function (error) { + db.close(); + return reject(getInfoRequest.error); + }; + infoTx.oncomplete = function () { + if (modelTx == null) { + db.close(); + } + else { + modelTx.oncomplete = function () { return db.close(); }; + } + }; + }; + openRequest.onerror = function (error) { return reject(openRequest.error); }; + })]; + }); + }); + }; + return BrowserIndexedDBManager; + }()); + if (ENV.get('IS_BROWSER')) { + try { + ModelStoreManagerRegistry.registerManager(BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager()); + } + catch (err) { + } + } + + var PATH_SEPARATOR = '/'; + var PATH_PREFIX = 'tensorflowjs_models'; + var INFO_SUFFIX = 'info'; + var MODEL_TOPOLOGY_SUFFIX = 'model_topology'; + var WEIGHT_SPECS_SUFFIX = 'weight_specs'; + var WEIGHT_DATA_SUFFIX = 'weight_data'; + function getModelKeys(path) { + return { + info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR), + topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR), + weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR), + weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR) + }; + } + function getModelPathFromKey(key) { + var items = key.split(PATH_SEPARATOR); + if (items.length < 3) { + throw new Error("Invalid key format: " + key); + } + return items.slice(1, items.length - 1).join(PATH_SEPARATOR); + } + function maybeStripScheme$1(key) { + return key.startsWith(BrowserLocalStorage.URL_SCHEME) ? + key.slice(BrowserLocalStorage.URL_SCHEME.length) : + key; + } + var BrowserLocalStorage = (function () { + function BrowserLocalStorage(modelPath) { + if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') { + throw new Error('The current environment does not support local storage.'); + } + this.LS = window.localStorage; + if (modelPath == null || !modelPath) { + throw new Error('For local storage, modelPath must not be null, undefined or empty.'); + } + this.modelPath = modelPath; + this.keys = getModelKeys(this.modelPath); + } + BrowserLocalStorage.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var topology, weightSpecs, modelArtifactsInfo, key; + return __generator(this, function (_a) { + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserLocalStorage.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + else { + topology = JSON.stringify(modelArtifacts.modelTopology); + weightSpecs = JSON.stringify(modelArtifacts.weightSpecs); + modelArtifactsInfo = getModelArtifactsInfoForJSON(modelArtifacts); + try { + this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo)); + this.LS.setItem(this.keys.topology, topology); + this.LS.setItem(this.keys.weightSpecs, weightSpecs); + this.LS.setItem(this.keys.weightData, arrayBufferToBase64String(modelArtifacts.weightData)); + return [2, { modelArtifactsInfo: modelArtifactsInfo }]; + } + catch (err) { + for (key in this.keys) { + this.LS.removeItem(this.keys[key]); + } + throw new Error("Failed to save model '" + this.modelPath + "' to local storage: " + + "size quota being exceeded is a possible cause of this failure: " + + ("modelTopologyBytes=" + modelArtifactsInfo.modelTopologyBytes + ", ") + + ("weightSpecsBytes=" + modelArtifactsInfo.weightSpecsBytes + ", ") + + ("weightDataBytes=" + modelArtifactsInfo.weightDataBytes + ".")); + } + } + return [2]; + }); + }); + }; + BrowserLocalStorage.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var info, out, topology, weightSpecs, weightDataBase64; + return __generator(this, function (_a) { + info = JSON.parse(this.LS.getItem(this.keys.info)); + if (info == null) { + throw new Error("In local storage, there is no model with name '" + this.modelPath + "'"); + } + if (info.modelTopologyType !== 'JSON') { + throw new Error('BrowserLocalStorage does not support loading non-JSON model ' + + 'topology yet.'); + } + out = {}; + topology = JSON.parse(this.LS.getItem(this.keys.topology)); + if (topology == null) { + throw new Error("In local storage, the topology of model '" + this.modelPath + "' " + + "is missing."); + } + out.modelTopology = topology; + weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs)); + if (weightSpecs == null) { + throw new Error("In local storage, the weight specs of model '" + this.modelPath + "' " + + "are missing."); + } + out.weightSpecs = weightSpecs; + weightDataBase64 = this.LS.getItem(this.keys.weightData); + if (weightDataBase64 == null) { + throw new Error("In local storage, the binary weight values of model " + + ("'" + this.modelPath + "' are missing.")); + } + out.weightData = base64StringToArrayBuffer(weightDataBase64); + return [2, out]; + }); + }); + }; + BrowserLocalStorage.URL_SCHEME = 'localstorage://'; + return BrowserLocalStorage; + }()); + var localStorageRouter = function (url) { + if (!ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserLocalStorage.URL_SCHEME)) { + return browserLocalStorage(url.slice(BrowserLocalStorage.URL_SCHEME.length)); + } + else { + return null; + } + } + }; + IORouterRegistry.registerSaveRouter(localStorageRouter); + IORouterRegistry.registerLoadRouter(localStorageRouter); + function browserLocalStorage(modelPath) { + return new BrowserLocalStorage(modelPath); + } + var BrowserLocalStorageManager = (function () { + function BrowserLocalStorageManager() { + assert(ENV.get('IS_BROWSER'), 'Current environment is not a web browser'); + assert(typeof window.localStorage !== 'undefined', 'Current browser does not appear to support localStorage'); + this.LS = window.localStorage; + } + BrowserLocalStorageManager.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var out, prefix, suffix, i, key, modelPath; + return __generator(this, function (_a) { + out = {}; + prefix = PATH_PREFIX + PATH_SEPARATOR; + suffix = PATH_SEPARATOR + INFO_SUFFIX; + for (i = 0; i < this.LS.length; ++i) { + key = this.LS.key(i); + if (key.startsWith(prefix) && key.endsWith(suffix)) { + modelPath = getModelPathFromKey(key); + out[modelPath] = JSON.parse(this.LS.getItem(key)); + } + } + return [2, out]; + }); + }); + }; + BrowserLocalStorageManager.prototype.removeModel = function (path) { + return __awaiter(this, void 0, void 0, function () { + var keys, info; + return __generator(this, function (_a) { + path = maybeStripScheme$1(path); + keys = getModelKeys(path); + if (this.LS.getItem(keys.info) == null) { + throw new Error("Cannot find model at path '" + path + "'"); + } + info = JSON.parse(this.LS.getItem(keys.info)); + this.LS.removeItem(keys.info); + this.LS.removeItem(keys.topology); + this.LS.removeItem(keys.weightSpecs); + this.LS.removeItem(keys.weightData); + return [2, info]; + }); + }); + }; + return BrowserLocalStorageManager; + }()); + if (ENV.get('IS_BROWSER')) { + try { + ModelStoreManagerRegistry.registerManager(BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager()); + } + catch (err) { + } + } + + var DEFAULT_FILE_NAME_PREFIX = 'model'; + var DEFAULT_JSON_EXTENSION_NAME = '.json'; + var DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin'; + var BrowserDownloads = (function () { + function BrowserDownloads(fileNamePrefix) { + if (!ENV.get('IS_BROWSER')) { + throw new Error('triggerDownloads() cannot proceed because the current environment ' + + 'is not a browser.'); + } + if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) { + fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length); + } + if (fileNamePrefix == null || fileNamePrefix.length === 0) { + fileNamePrefix = DEFAULT_FILE_NAME_PREFIX; + } + this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME; + this.weightDataFileName = + fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME; + } + BrowserDownloads.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var weightsURL, weightsManifest, modelTopologyAndWeightManifest, modelTopologyAndWeightManifestURL, jsonAnchor, weightDataAnchor; + return __generator(this, function (_a) { + weightsURL = window.URL.createObjectURL(new Blob([modelArtifacts.weightData], { type: 'application/octet-stream' })); + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('DownloadTrigger.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + else { + weightsManifest = [{ + paths: ['./' + this.weightDataFileName], + weights: modelArtifacts.weightSpecs + }]; + modelTopologyAndWeightManifest = { + modelTopology: modelArtifacts.modelTopology, + weightsManifest: weightsManifest + }; + modelTopologyAndWeightManifestURL = window.URL.createObjectURL(new Blob([JSON.stringify(modelTopologyAndWeightManifest)], { type: 'application/json' })); + jsonAnchor = this.jsonAnchor == null ? document.createElement('a') : + this.jsonAnchor; + jsonAnchor.download = this.modelTopologyFileName; + jsonAnchor.href = modelTopologyAndWeightManifestURL; + jsonAnchor.click(); + if (modelArtifacts.weightData != null) { + weightDataAnchor = this.weightDataAnchor == null ? + document.createElement('a') : + this.weightDataAnchor; + weightDataAnchor.download = this.weightDataFileName; + weightDataAnchor.href = weightsURL; + weightDataAnchor.click(); + } + return [2, { modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts) }]; + } + return [2]; + }); + }); + }; + BrowserDownloads.URL_SCHEME = 'downloads://'; + return BrowserDownloads; + }()); + var BrowserFiles = (function () { + function BrowserFiles(files) { + if (files == null || files.length < 1) { + throw new Error("When calling browserFiles, at least 1 file is required, " + + ("but received " + files)); + } + this.files = files; + } + BrowserFiles.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var jsonFile, weightFiles; + var _this = this; + return __generator(this, function (_a) { + jsonFile = this.files[0]; + weightFiles = this.files.slice(1); + return [2, new Promise(function (resolve, reject) { + var jsonReader = new FileReader(); + jsonReader.onload = function (event) { + var modelJSON = JSON.parse(event.target.result); + var modelTopology = modelJSON.modelTopology; + if (modelTopology == null) { + reject(new Error("modelTopology field is missing from file " + jsonFile.name)); + return; + } + if (weightFiles.length === 0) { + resolve({ modelTopology: modelTopology }); + } + var weightsManifest = modelJSON.weightsManifest; + if (weightsManifest == null) { + reject(new Error("weightManifest field is missing from file " + jsonFile.name)); + return; + } + var pathToFile; + try { + pathToFile = + _this.checkManifestAndWeightFiles(weightsManifest, weightFiles); + } + catch (err) { + reject(err); + return; + } + var weightSpecs = []; + var paths = []; + var perFileBuffers = []; + weightsManifest.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + paths.push(path); + perFileBuffers.push(null); + }); + weightSpecs.push.apply(weightSpecs, weightsGroup.weights); + }); + weightsManifest.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + var weightFileReader = new FileReader(); + weightFileReader.onload = function (event) { + var weightData = event.target.result; + var index = paths.indexOf(path); + perFileBuffers[index] = weightData; + if (perFileBuffers.indexOf(null) === -1) { + resolve({ + modelTopology: modelTopology, + weightSpecs: weightSpecs, + weightData: concatenateArrayBuffers(perFileBuffers), + }); + } + }; + weightFileReader.onerror = function (error) { + reject("Failed to weights data from file of path '" + path + "'."); + return; + }; + weightFileReader.readAsArrayBuffer(pathToFile[path]); + }); + }); + }; + jsonReader.onerror = function (error) { + reject("Failed to read model topology and weights manifest JSON " + + ("from file '" + jsonFile.name + "'. BrowserFiles supports loading ") + + "Keras-style tf.Model artifacts only."); + return; + }; + jsonReader.readAsText(jsonFile); + })]; + }); + }); + }; + BrowserFiles.prototype.checkManifestAndWeightFiles = function (manifest, files) { + var basenames = []; + var fileNames = files.map(function (file) { return basename(file.name); }); + var pathToFile = {}; + for (var _i = 0, manifest_1 = manifest; _i < manifest_1.length; _i++) { + var group = manifest_1[_i]; + group.paths.forEach(function (path) { + var pathBasename = basename(path); + if (basenames.indexOf(pathBasename) !== -1) { + throw new Error("Duplicate file basename found in weights manifest: " + + ("'" + pathBasename + "'")); + } + basenames.push(pathBasename); + if (fileNames.indexOf(pathBasename) === -1) { + throw new Error("Weight file with basename '" + pathBasename + "' is not provided."); + } + else { + pathToFile[path] = files[fileNames.indexOf(pathBasename)]; + } + }); + } + if (basenames.length !== files.length) { + throw new Error("Mismatch in the number of files in weights manifest " + + ("(" + basenames.length + ") and the number of weight files provided ") + + ("(" + files.length + ").")); + } + return pathToFile; + }; + return BrowserFiles; + }()); + var browserDownloadsRouter = function (url) { + if (!ENV.get('IS_BROWSER')) { + return null; + } + else { + if (url.startsWith(BrowserDownloads.URL_SCHEME)) { + return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length)); + } + else { + return null; + } + } + }; + IORouterRegistry.registerSaveRouter(browserDownloadsRouter); + function browserDownloads(fileNamePrefix) { + if (fileNamePrefix === void 0) { fileNamePrefix = 'model'; } + return new BrowserDownloads(fileNamePrefix); + } + function browserFiles(files) { + return new BrowserFiles(files); + } + + function loadWeightsAsArrayBuffer(fetchURLs, requestOptions) { + return __awaiter(this, void 0, void 0, function () { + var requests, responses, buffers; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + requests = fetchURLs.map(function (fetchURL) { return fetch(fetchURL, requestOptions); }); + return [4, Promise.all(requests)]; + case 1: + responses = _a.sent(); + return [4, Promise.all(responses.map(function (response) { return response.arrayBuffer(); }))]; + case 2: + buffers = _a.sent(); + return [2, buffers]; + } + }); + }); + } + function loadWeights(manifest, filePathPrefix, weightNames, requestOptions) { + if (filePathPrefix === void 0) { filePathPrefix = ''; } + return __awaiter(this, void 0, void 0, function () { + var groupIndicesToFetchMap, groupWeightsToFetch, weightsFound, allManifestWeightNames, weightsNotFound, groupIndicesToFetch, fetchUrls, buffers, weightsTensorMap, bufferIndexOffset; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + groupIndicesToFetchMap = manifest.map(function () { return false; }); + groupWeightsToFetch = {}; + weightsFound = weightNames != null ? weightNames.map(function () { return false; }) : []; + allManifestWeightNames = []; + manifest.forEach(function (manifestGroupConfig, groupIndex) { + var groupOffset = 0; + manifestGroupConfig.weights.forEach(function (weightsEntry) { + var rawDtype = ('quantization' in weightsEntry) ? + weightsEntry.quantization.dtype : + weightsEntry.dtype; + var weightsBytes = DTYPE_VALUE_SIZE_MAP[rawDtype] * + sizeFromShape(weightsEntry.shape); + var enqueueWeightsForFetchingFn = function () { + groupIndicesToFetchMap[groupIndex] = true; + if (groupWeightsToFetch[groupIndex] == null) { + groupWeightsToFetch[groupIndex] = []; + } + groupWeightsToFetch[groupIndex].push({ + manifestEntry: weightsEntry, + groupOffset: groupOffset, + sizeBytes: weightsBytes + }); + }; + if (weightNames != null) { + weightNames.forEach(function (weightName, weightIndex) { + if (weightName === weightsEntry.name) { + enqueueWeightsForFetchingFn(); + weightsFound[weightIndex] = true; + } + }); + } + else { + enqueueWeightsForFetchingFn(); + } + allManifestWeightNames.push(weightsEntry.name); + groupOffset += weightsBytes; + }); + }); + if (!weightsFound.every(function (found) { return found; })) { + weightsNotFound = weightNames.filter(function (weight, i) { return !weightsFound[i]; }); + throw new Error("Could not find weights in manifest with names: " + + (weightsNotFound.join(', ') + ". \n") + + "Manifest JSON has weights with names: " + + (allManifestWeightNames.join(', ') + ".")); + } + groupIndicesToFetch = groupIndicesToFetchMap.reduce(function (accumulator, shouldFetch, i) { + if (shouldFetch) { + accumulator.push(i); + } + return accumulator; + }, []); + fetchUrls = []; + groupIndicesToFetch.forEach(function (i) { + manifest[i].paths.forEach(function (filepath) { + var fetchUrl = filePathPrefix + + (!filePathPrefix.endsWith('/') ? '/' : '') + filepath; + fetchUrls.push(fetchUrl); + }); + }); + return [4, loadWeightsAsArrayBuffer(fetchUrls, requestOptions)]; + case 1: + buffers = _a.sent(); + weightsTensorMap = {}; + bufferIndexOffset = 0; + groupIndicesToFetch.forEach(function (i) { + var numBuffers = manifest[i].paths.length; + var groupBytes = 0; + for (var i_1 = 0; i_1 < numBuffers; i_1++) { + groupBytes += buffers[bufferIndexOffset + i_1].byteLength; + } + var groupBuffer = new ArrayBuffer(groupBytes); + var groupByteBuffer = new Uint8Array(groupBuffer); + var groupBufferOffset = 0; + for (var i_2 = 0; i_2 < numBuffers; i_2++) { + var buffer$$1 = new Uint8Array(buffers[bufferIndexOffset + i_2]); + groupByteBuffer.set(buffer$$1, groupBufferOffset); + groupBufferOffset += buffer$$1.byteLength; + } + var weightsEntries = groupWeightsToFetch[i]; + weightsEntries.forEach(function (weightsEntry) { + var byteBuffer = groupBuffer.slice(weightsEntry.groupOffset, weightsEntry.groupOffset + weightsEntry.sizeBytes); + var typedArray; + var dtype = weightsEntry.manifestEntry.dtype; + if ('quantization' in weightsEntry.manifestEntry) { + var quantization_1 = weightsEntry.manifestEntry.quantization; + if (quantization_1.dtype !== 'uint8' && quantization_1.dtype !== 'uint16') { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has unknown " + + ("quantization dtype " + quantization_1.dtype + ".")); + } + var quantizedArray = (quantization_1.dtype === 'uint8') ? + new Uint8Array(byteBuffer) : + new Uint16Array(byteBuffer); + if (dtype === 'float32') { + typedArray = Float32Array.from(quantizedArray, function (v) { return v * quantization_1.scale + quantization_1.min; }); + } + else if (dtype === 'int32') { + typedArray = Int32Array.from(quantizedArray, function (v) { return Math.round(v * quantization_1.scale + quantization_1.min); }); + } + else { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has a dtype not " + + ("supported by quantization: " + dtype)); + } + } + else { + if (dtype === 'float32') { + typedArray = new Float32Array(byteBuffer); + } + else if (dtype === 'int32') { + typedArray = new Int32Array(byteBuffer); + } + else if (dtype === 'bool') { + typedArray = new Uint8Array(byteBuffer); + } + else { + throw new Error("Weight " + weightsEntry.manifestEntry.name + " has unknown dtype " + + (dtype + ".")); + } + } + var weightName = weightsEntry.manifestEntry.name; + if (weightsTensorMap[weightName] != null) { + throw new Error("Duplicate weight with name " + weightName + ". " + + "Please make sure weights names are unique in the manifest JSON."); + } + weightsTensorMap[weightName] = tensor(typedArray, weightsEntry.manifestEntry.shape, weightsEntry.manifestEntry.dtype); + }); + bufferIndexOffset += numBuffers; + }); + return [2, weightsTensorMap]; + } + }); + }); + } + + var BrowserHTTPRequest = (function () { + function BrowserHTTPRequest(path, requestInit) { + this.DEFAULT_METHOD = 'POST'; + if (typeof fetch === 'undefined') { + throw new Error('browserHTTPRequest is not supported outside the web browser without a fetch polyfill.'); + } + assert(path != null && path.length > 0, 'URL path for browserHTTPRequest must not be null, undefined or ' + + 'empty.'); + this.path = path; + if (requestInit != null && requestInit.body != null) { + throw new Error('requestInit is expected to have no pre-existing body, but has one.'); + } + this.requestInit = requestInit || {}; + } + BrowserHTTPRequest.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + var init, weightsManifest, modelTopologyAndWeightManifest, response; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (modelArtifacts.modelTopology instanceof ArrayBuffer) { + throw new Error('BrowserHTTPRequest.save() does not support saving model topology ' + + 'in binary formats yet.'); + } + init = Object.assign({ method: this.DEFAULT_METHOD }, this.requestInit); + init.body = new FormData(); + weightsManifest = [{ + paths: ['./model.weights.bin'], + weights: modelArtifacts.weightSpecs, + }]; + modelTopologyAndWeightManifest = { + modelTopology: modelArtifacts.modelTopology, + weightsManifest: weightsManifest + }; + init.body.append('model.json', new Blob([JSON.stringify(modelTopologyAndWeightManifest)], { type: 'application/json' }), 'model.json'); + if (modelArtifacts.weightData != null) { + init.body.append('model.weights.bin', new Blob([modelArtifacts.weightData], { type: 'application/octet-stream' }), 'model.weights.bin'); + } + return [4, fetch(this.path, init)]; + case 1: + response = _a.sent(); + if (response.status === 200) { + return [2, { + modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts), + responses: [response], + }]; + } + else { + throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status " + + (response.status + ".")); + } + return [2]; + } + }); + }); + }; + BrowserHTTPRequest.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var modelConfigRequest, modelConfig, modelTopology, weightsManifest, weightSpecs, weightData, weightsManifest_2, _i, weightsManifest_1, entry, pathPrefix_1, fetchURLs_1, _a; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: return [4, fetch(this.path, this.requestInit)]; + case 1: + modelConfigRequest = _b.sent(); + return [4, modelConfigRequest.json()]; + case 2: + modelConfig = _b.sent(); + modelTopology = modelConfig['modelTopology']; + weightsManifest = modelConfig['weightsManifest']; + if (modelTopology == null && weightsManifest == null) { + throw new Error("The JSON from HTTP path " + this.path + " contains neither model " + + "topology or manifest for weights."); + } + if (!(weightsManifest != null)) return [3, 4]; + weightsManifest_2 = modelConfig['weightsManifest']; + weightSpecs = []; + for (_i = 0, weightsManifest_1 = weightsManifest_2; _i < weightsManifest_1.length; _i++) { + entry = weightsManifest_1[_i]; + weightSpecs.push.apply(weightSpecs, entry.weights); + } + pathPrefix_1 = this.path.substring(0, this.path.lastIndexOf('/')); + if (!pathPrefix_1.endsWith('/')) { + pathPrefix_1 = pathPrefix_1 + '/'; + } + fetchURLs_1 = []; + weightsManifest_2.forEach(function (weightsGroup) { + weightsGroup.paths.forEach(function (path) { + fetchURLs_1.push(pathPrefix_1 + path); + }); + }); + _a = concatenateArrayBuffers; + return [4, loadWeightsAsArrayBuffer(fetchURLs_1, this.requestInit)]; + case 3: + weightData = _a.apply(void 0, [_b.sent()]); + _b.label = 4; + case 4: return [2, { modelTopology: modelTopology, weightSpecs: weightSpecs, weightData: weightData }]; + } + }); + }); + }; + BrowserHTTPRequest.URL_SCHEMES = ['http://', 'https://']; + return BrowserHTTPRequest; + }()); + var httpRequestRouter = function (url) { + if (typeof fetch === 'undefined') { + return null; + } + else { + for (var _i = 0, _a = BrowserHTTPRequest.URL_SCHEMES; _i < _a.length; _i++) { + var scheme = _a[_i]; + if (url.startsWith(scheme)) { + return browserHTTPRequest(url); + } + } + return null; + } + }; + IORouterRegistry.registerSaveRouter(httpRequestRouter); + IORouterRegistry.registerLoadRouter(httpRequestRouter); + function browserHTTPRequest(path, requestInit) { + return new BrowserHTTPRequest(path, requestInit); + } + + var PassthroughLoader = (function () { + function PassthroughLoader(modelTopology, weightSpecs, weightData) { + this.modelTopology = modelTopology; + this.weightSpecs = weightSpecs; + this.weightData = weightData; + } + PassthroughLoader.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var result; + return __generator(this, function (_a) { + result = {}; + if (this.modelTopology != null) { + result = __assign({ modelTopology: this.modelTopology }, result); + } + if (this.weightSpecs != null && this.weightSpecs.length > 0) { + result = __assign({ weightSpecs: this.weightSpecs }, result); + } + if (this.weightData != null && this.weightData.byteLength > 0) { + result = __assign({ weightData: this.weightData }, result); + } + return [2, result]; + }); + }); + }; + return PassthroughLoader; + }()); + var PassthroughSaver = (function () { + function PassthroughSaver(saveHandler) { + this.saveHandler = saveHandler; + } + PassthroughSaver.prototype.save = function (modelArtifacts) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2, this.saveHandler(modelArtifacts)]; + }); + }); + }; + return PassthroughSaver; + }()); + function fromMemory(modelTopology, weightSpecs, weightData) { + return new PassthroughLoader(modelTopology, weightSpecs, weightData); + } + function withSaveHandler(saveHandler) { + return new PassthroughSaver(saveHandler); + } + + var registerSaveRouter = IORouterRegistry.registerSaveRouter; + var registerLoadRouter = IORouterRegistry.registerLoadRouter; + var getSaveHandlers = IORouterRegistry.getSaveHandlers; + var getLoadHandlers = IORouterRegistry.getLoadHandlers; + + var io = /*#__PURE__*/Object.freeze({ + browserFiles: browserFiles, + browserHTTPRequest: browserHTTPRequest, + concatenateArrayBuffers: concatenateArrayBuffers, + decodeWeights: decodeWeights, + encodeWeights: encodeWeights, + fromMemory: fromMemory, + getLoadHandlers: getLoadHandlers, + getModelArtifactsInfoForJSON: getModelArtifactsInfoForJSON, + getSaveHandlers: getSaveHandlers, + loadWeights: loadWeights, + registerLoadRouter: registerLoadRouter, + registerSaveRouter: registerSaveRouter, + withSaveHandler: withSaveHandler, + copyModel: copyModel, + listModels: listModels, + moveModel: moveModel, + removeModel: removeModel + }); + + var Serializable = (function () { + function Serializable() { + } + Serializable.prototype.getClassName = function () { + return this.constructor + .className; + }; + Serializable.fromConfig = function (cls, config) { + return new cls(config); + }; + return Serializable; + }()); + var SerializationMap = (function () { + function SerializationMap() { + this.classNameMap = {}; + } + SerializationMap.getMap = function () { + if (SerializationMap.instance == null) { + SerializationMap.instance = new SerializationMap(); + } + return SerializationMap.instance; + }; + SerializationMap.register = function (cls) { + SerializationMap.getMap().classNameMap[cls.className] = + [cls, cls.fromConfig]; + }; + return SerializationMap; + }()); + + var serialization = /*#__PURE__*/Object.freeze({ + Serializable: Serializable, + SerializationMap: SerializationMap + }); + + var WEBGL_ENVS = { + 'HAS_WEBGL': true + }; + var NODE_ENVS = { + 'IS_NODE': true + }; + var CHROME_ENVS = { + 'IS_CHROME': true + }; + var BROWSER_ENVS = { + 'IS_BROWSER': true + }; + var CPU_ENVS = { + 'HAS_WEBGL': false + }; + var ALL_ENVS = {}; + function expectArraysClose(actual, expected, epsilon) { + if (epsilon == null) { + epsilon = ENV.get('TEST_EPSILON'); + } + if (!(actual instanceof Tensor) && !(expected instanceof Tensor)) { + var aType = actual.constructor.name; + var bType = expected.constructor.name; + if (aType !== bType) { + throw new Error("Arrays are of different type actual: " + aType + " " + + ("vs expected: " + bType)); + } + } + else if (actual instanceof Tensor && expected instanceof Tensor) { + if (actual.dtype !== expected.dtype) { + throw new Error("Arrays are of different type actual: " + actual.dtype + " " + + ("vs expected: " + expected.dtype + ".")); + } + if (!arraysEqual(actual.shape, expected.shape)) { + throw new Error("Arrays are of different shape actual: " + actual.shape + " " + + ("vs expected: " + expected.shape + ".")); + } + } + var actualValues; + var expectedValues; + if (actual instanceof Tensor) { + actualValues = actual.dataSync(); + } + else { + actualValues = actual; + } + if (expected instanceof Tensor) { + expectedValues = expected.dataSync(); + } + else { + expectedValues = expected; + } + if (actualValues.length !== expectedValues.length) { + throw new Error("Arrays have different lengths actual: " + actualValues.length + " vs " + + ("expected: " + expectedValues.length + ".\n") + + ("Actual: " + actualValues + ".\n") + + ("Expected: " + expectedValues + ".")); + } + for (var i = 0; i < expectedValues.length; ++i) { + var a = actualValues[i]; + var e = expectedValues[i]; + if (!areClose(a, Number(e), epsilon)) { + throw new Error("Arrays differ: actual[" + i + "] = " + a + ", expected[" + i + "] = " + e + ".\n" + + ("Actual: " + actualValues + ".\n") + + ("Expected: " + expectedValues + ".")); + } + } + } + function expectPromiseToFail(fn, done) { + fn().then(function () { return done.fail(); }, function () { return done(); }); + } + function expectArraysEqual(actual, expected) { + return expectArraysClose(actual, expected, 0); + } + function expectNumbersClose(a, e, epsilon) { + if (epsilon == null) { + epsilon = ENV.get('TEST_EPSILON'); + } + if (!areClose(a, e, epsilon)) { + throw new Error("Numbers differ: actual === " + a + ", expected === " + e); + } + } + function areClose(a, e, epsilon) { + if (isNaN(a) && isNaN(e)) { + return true; + } + if (isNaN(a) || isNaN(e) || Math.abs(a - e) > epsilon) { + return false; + } + return true; + } + function expectValuesInRange(actual, low, high) { + var actualVals; + if (actual instanceof Tensor) { + actualVals = actual.dataSync(); + } + else { + actualVals = actual; + } + for (var i = 0; i < actualVals.length; i++) { + if (actualVals[i] < low || actualVals[i] > high) { + throw new Error("Value out of range:" + actualVals[i] + " low: " + low + ", high: " + high); + } + } + } + function expectArrayBuffersEqual(actual, expected) { + expect(new Float32Array(actual)).toEqual(new Float32Array(expected)); + } + + var test_util = /*#__PURE__*/Object.freeze({ + WEBGL_ENVS: WEBGL_ENVS, + NODE_ENVS: NODE_ENVS, + CHROME_ENVS: CHROME_ENVS, + BROWSER_ENVS: BROWSER_ENVS, + CPU_ENVS: CPU_ENVS, + ALL_ENVS: ALL_ENVS, + expectArraysClose: expectArraysClose, + expectPromiseToFail: expectPromiseToFail, + expectArraysEqual: expectArraysEqual, + expectNumbersClose: expectNumbersClose, + expectValuesInRange: expectValuesInRange, + expectArrayBuffersEqual: expectArrayBuffersEqual + }); + + var version = '0.12.8'; + + + + var webgl = /*#__PURE__*/Object.freeze({ + gpgpu_util: gpgpu_util, + webgl_util: webgl_util, + MathBackendWebGL: MathBackendWebGL, + GPGPUContext: GPGPUContext + }); + + var Optimizer = (function (_super) { + __extends(Optimizer, _super); + function Optimizer() { + return _super !== null && _super.apply(this, arguments) || this; + } + Optimizer.prototype.minimize = function (f, returnCost, varList) { + if (returnCost === void 0) { returnCost = false; } + var _a = this.computeGradients(f, varList), value = _a.value, grads$$1 = _a.grads; + this.applyGradients(grads$$1); + var varNames = Object.keys(grads$$1); + varNames.forEach(function (varName) { return grads$$1[varName].dispose(); }); + if (returnCost) { + return value; + } + else { + value.dispose(); + return null; + } + }; + Optimizer.prototype.computeGradients = function (f, varList) { + return variableGrads(f, varList); + }; + return Optimizer; + }(Serializable)); + + var DEFAULT_FLOAT32_EPSILON = 1e-8; + var DEFAULT_FLOAT16_EPSILON = 1e-4; + function getOptimizerDefaultEpsilonValue() { + if (ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) { + return DEFAULT_FLOAT32_EPSILON; + } + return DEFAULT_FLOAT16_EPSILON; + } + + var AdadeltaOptimizer = (function (_super) { + __extends(AdadeltaOptimizer, _super); + function AdadeltaOptimizer(learningRate, rho, epsilon) { + if (epsilon === void 0) { epsilon = null; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.rho = rho; + _this.epsilon = epsilon; + _this.accumulatedGrads = {}; + _this.accumulatedUpdates = {}; + _this.c = keep(scalar(-learningRate)); + _this.rhoScalar = keep(scalar(rho)); + _this.oneMinusRho = keep(scalar(1 - rho)); + if (epsilon === null) { + epsilon = getOptimizerDefaultEpsilonValue(); + } + _this.epsilonScalar = keep(scalar(epsilon)); + return _this; + } + AdadeltaOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedGrads[variableName] == null) { + var trainable_1 = false; + tidy(function () { + _this.accumulatedGrads[variableName] = + zerosLike(value).variable(trainable_1); + }); + } + if (this_1.accumulatedUpdates[variableName] == null) { + var trainable_2 = false; + tidy(function () { + _this.accumulatedUpdates[variableName] = + zerosLike(value).variable(trainable_2); + }); + } + var gradient = variableGradients[variableName]; + var accumulatedGrad = this_1.accumulatedGrads[variableName]; + var accumulatedUpdate = this_1.accumulatedUpdates[variableName]; + tidy(function () { + var newAccumulatedGrad = _this.rhoScalar.mul(accumulatedGrad) + .add(_this.oneMinusRho.mul(gradient.square())); + var updates = accumulatedUpdate.add(_this.epsilonScalar) + .sqrt() + .div(accumulatedGrad.add(_this.epsilonScalar).sqrt()) + .mul(gradient); + var newAccumulatedUpdate = _this.rhoScalar.mul(accumulatedUpdate) + .add(_this.oneMinusRho.mul(updates.square())); + _this.accumulatedGrads[variableName].assign(newAccumulatedGrad); + _this.accumulatedUpdates[variableName].assign(newAccumulatedUpdate); + var newValue = _this.c.mul(updates).add(value); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + AdadeltaOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsilonScalar.dispose(); + this.rhoScalar.dispose(); + this.oneMinusRho.dispose(); + if (this.accumulatedUpdates != null) { + Object.keys(this.accumulatedUpdates) + .forEach(function (name) { return _this.accumulatedUpdates[name].dispose(); }); + Object.keys(this.accumulatedGrads) + .forEach(function (name) { return _this.accumulatedGrads[name].dispose(); }); + } + }; + AdadeltaOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + rho: this.rho, + epsilon: this.epsilon + }; + }; + AdadeltaOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.rho, config.epsilon); + }; + AdadeltaOptimizer.className = 'AdadeltaOptimizer'; + return AdadeltaOptimizer; + }(Optimizer)); + SerializationMap.register(AdadeltaOptimizer); + + var AdagradOptimizer = (function (_super) { + __extends(AdagradOptimizer, _super); + function AdagradOptimizer(learningRate, initialAccumulatorValue) { + if (initialAccumulatorValue === void 0) { initialAccumulatorValue = 0.1; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.initialAccumulatorValue = initialAccumulatorValue; + _this.accumulatedGrads = {}; + _this.c = keep(scalar(-learningRate)); + var epsilon = getOptimizerDefaultEpsilonValue(); + _this.epsilon = keep(scalar(epsilon)); + return _this; + } + AdagradOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedGrads[variableName] == null) { + var trainable_1 = false; + tidy(function () { + _this.accumulatedGrads[variableName] = + fill(value.shape, _this.initialAccumulatorValue) + .variable(trainable_1); + }); + } + var gradient = variableGradients[variableName]; + var accumulatedGrad = this_1.accumulatedGrads[variableName]; + tidy(function () { + var newAccumulatedGrad = accumulatedGrad.add(gradient.square()); + _this.accumulatedGrads[variableName].assign(newAccumulatedGrad); + var newValue = _this.c + .mul(gradient.div(newAccumulatedGrad.add(_this.epsilon).sqrt())) + .add(value); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + AdagradOptimizer.prototype.dispose = function () { + var _this = this; + this.epsilon.dispose(); + this.c.dispose(); + if (this.accumulatedGrads != null) { + Object.keys(this.accumulatedGrads) + .forEach(function (name) { return _this.accumulatedGrads[name].dispose(); }); + } + }; + AdagradOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + initialAccumulatorValue: this.initialAccumulatorValue, + }; + }; + AdagradOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.initialAccumulatorValue); + }; + AdagradOptimizer.className = 'AdagradOptimizer'; + return AdagradOptimizer; + }(Optimizer)); + SerializationMap.register(AdagradOptimizer); + + var AdamOptimizer = (function (_super) { + __extends(AdamOptimizer, _super); + function AdamOptimizer(learningRate, beta1, beta2, epsilon) { + if (epsilon === void 0) { epsilon = null; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.beta1 = beta1; + _this.beta2 = beta2; + _this.epsilon = epsilon; + _this.accumulatedFirstMoment = {}; + _this.accumulatedSecondMoment = {}; + _this.c = keep(scalar(-learningRate)); + _this.beta1Scalar = keep(scalar(beta1)); + _this.beta2Scalar = keep(scalar(beta2)); + tidy(function () { + _this.accBeta1 = scalar(beta1).variable(); + _this.accBeta2 = scalar(beta2).variable(); + }); + _this.oneMinusBeta1 = keep(scalar(1 - beta1)); + _this.oneMinusBeta2 = keep(scalar(1 - beta2)); + _this.one = keep(scalar(1)); + if (epsilon === null) { + epsilon = getOptimizerDefaultEpsilonValue(); + } + _this.epsScalar = keep(scalar(epsilon)); + return _this; + } + AdamOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + tidy(function () { + var oneMinusAccBeta1 = _this.one.sub(_this.accBeta1); + var oneMinusAccBeta2 = _this.one.sub(_this.accBeta2); + for (var variableName in variableGradients) { + var value = ENV.engine.registeredVariables[variableName]; + if (_this.accumulatedFirstMoment[variableName] == null) { + var trainable = false; + _this.accumulatedFirstMoment[variableName] = + zerosLike(value).variable(trainable); + } + if (_this.accumulatedSecondMoment[variableName] == null) { + var trainable = false; + _this.accumulatedSecondMoment[variableName] = + zerosLike(value).variable(trainable); + } + var gradient = variableGradients[variableName]; + var firstMoment = _this.accumulatedFirstMoment[variableName]; + var secondMoment = _this.accumulatedSecondMoment[variableName]; + var newFirstMoment = _this.beta1Scalar.mul(firstMoment) + .add(_this.oneMinusBeta1.mul(gradient)); + var newSecondMoment = _this.beta2Scalar.mul(secondMoment) + .add(_this.oneMinusBeta2.mul(gradient.square())); + var biasCorrectedFirstMoment = newFirstMoment.div(oneMinusAccBeta1); + var biasCorrectedSecondMoment = newSecondMoment.div(oneMinusAccBeta2); + _this.accumulatedFirstMoment[variableName].assign(newFirstMoment); + _this.accumulatedSecondMoment[variableName].assign(newSecondMoment); + var newValue = _this.c + .mul(biasCorrectedFirstMoment.div(_this.epsScalar.add(biasCorrectedSecondMoment.sqrt()))) + .add(value); + value.assign(newValue); + } + _this.accBeta1.assign(_this.accBeta1.mul(_this.beta1Scalar)); + _this.accBeta2.assign(_this.accBeta2.mul(_this.beta2Scalar)); + }); + }; + AdamOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsScalar.dispose(); + this.beta1Scalar.dispose(); + this.beta2Scalar.dispose(); + this.accBeta1.dispose(); + this.accBeta2.dispose(); + this.oneMinusBeta1.dispose(); + this.oneMinusBeta2.dispose(); + this.one.dispose(); + if (this.accumulatedFirstMoment != null) { + Object.keys(this.accumulatedFirstMoment) + .forEach(function (name) { return _this.accumulatedFirstMoment[name].dispose(); }); + } + if (this.accumulatedSecondMoment != null) { + Object.keys(this.accumulatedSecondMoment) + .forEach(function (name) { return _this.accumulatedSecondMoment[name].dispose(); }); + } + }; + AdamOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + beta1: this.beta1, + beta2: this.beta2, + epsilon: this.epsilon, + }; + }; + AdamOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.beta1, config.beta2, config.epsilon); + }; + AdamOptimizer.className = 'AdamOptimizer'; + return AdamOptimizer; + }(Optimizer)); + SerializationMap.register(AdamOptimizer); + + var AdamaxOptimizer = (function (_super) { + __extends(AdamaxOptimizer, _super); + function AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay) { + if (epsilon === void 0) { epsilon = null; } + if (decay === void 0) { decay = 0.0; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.beta1 = beta1; + _this.beta2 = beta2; + _this.epsilon = epsilon; + _this.decay = decay; + _this.accumulatedFirstMoment = {}; + _this.accumulatedWeightedInfNorm = {}; + _this.c = keep(scalar(-learningRate)); + _this.beta1Scalar = keep(scalar(beta1)); + _this.beta2Scalar = keep(scalar(beta2)); + _this.decayScalar = keep(scalar(decay)); + tidy(function () { + _this.iteration = scalar(0).variable(); + _this.accBeta1 = scalar(beta1).variable(); + }); + _this.oneMinusBeta1 = keep(scalar(1 - beta1)); + _this.one = keep(scalar(1)); + if (epsilon === null) { + epsilon = getOptimizerDefaultEpsilonValue(); + } + _this.epsScalar = keep(scalar(epsilon)); + return _this; + } + AdamaxOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + tidy(function () { + var oneMinusAccBeta1 = _this.one.sub(_this.accBeta1); + var lr = _this.c.div(_this.one.add(_this.decayScalar.mul(_this.iteration))); + for (var variableName in variableGradients) { + var value = ENV.engine.registeredVariables[variableName]; + if (_this.accumulatedFirstMoment[variableName] == null) { + var trainable = false; + _this.accumulatedFirstMoment[variableName] = + zerosLike(value).variable(trainable); + } + if (_this.accumulatedWeightedInfNorm[variableName] == null) { + var trainable = false; + _this.accumulatedWeightedInfNorm[variableName] = + zerosLike(value).variable(trainable); + } + var gradient = variableGradients[variableName]; + var firstMoment = _this.accumulatedFirstMoment[variableName]; + var weightedInfNorm = _this.accumulatedWeightedInfNorm[variableName]; + var newFirstMoment = _this.beta1Scalar.mul(firstMoment) + .add(_this.oneMinusBeta1.mul(gradient)); + var ut0 = _this.beta2Scalar.mul(weightedInfNorm); + var ut1 = gradient.abs(); + var newWeightedInfNorm = ut0.maximum(ut1); + _this.accumulatedFirstMoment[variableName].assign(newFirstMoment); + _this.accumulatedWeightedInfNorm[variableName].assign(newWeightedInfNorm); + var newValue = lr.div(oneMinusAccBeta1) + .mul(newFirstMoment.div(_this.epsScalar.add(newWeightedInfNorm))) + .add(value); + value.assign(newValue); + } + _this.iteration.assign(_this.iteration.add(_this.one)); + _this.accBeta1.assign(_this.accBeta1.mul(_this.beta1Scalar)); + }); + }; + AdamaxOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsScalar.dispose(); + this.accBeta1.dispose(); + this.beta1Scalar.dispose(); + this.beta2Scalar.dispose(); + this.oneMinusBeta1.dispose(); + this.decayScalar.dispose(); + this.iteration.dispose(); + this.one.dispose(); + if (this.accumulatedFirstMoment != null) { + Object.keys(this.accumulatedFirstMoment) + .forEach(function (name) { return _this.accumulatedFirstMoment[name].dispose(); }); + } + if (this.accumulatedWeightedInfNorm != null) { + Object.keys(this.accumulatedWeightedInfNorm) + .forEach(function (name) { return _this.accumulatedWeightedInfNorm[name].dispose(); }); + } + }; + AdamaxOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + beta1: this.beta1, + beta2: this.beta2, + epsilon: this.epsilon, + decay: this.decay + }; + }; + AdamaxOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.beta1, config.beta2, config.epsilon, config.decay); + }; + AdamaxOptimizer.className = 'AdamaxOptimizer'; + return AdamaxOptimizer; + }(Optimizer)); + SerializationMap.register(AdamaxOptimizer); + + var SGDOptimizer = (function (_super) { + __extends(SGDOptimizer, _super); + function SGDOptimizer(learningRate) { + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.setLearningRate(learningRate); + return _this; + } + SGDOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var varNames = Object.keys(variableGradients); + varNames.forEach(function (varName) { + var gradient = variableGradients[varName]; + var value = ENV.engine.registeredVariables[varName]; + tidy(function () { + var newValue = _this.c.mul(gradient).add(value); + value.assign(newValue); + }); + }); + }; + SGDOptimizer.prototype.setLearningRate = function (learningRate) { + this.learningRate = learningRate; + if (this.c != null) { + this.c.dispose(); + } + this.c = keep(scalar(-learningRate)); + }; + SGDOptimizer.prototype.dispose = function () { + this.c.dispose(); + }; + SGDOptimizer.prototype.getConfig = function () { + return { learningRate: this.learningRate }; + }; + SGDOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate); + }; + SGDOptimizer.className = 'SGDOptimizer'; + return SGDOptimizer; + }(Optimizer)); + SerializationMap.register(SGDOptimizer); + + var MomentumOptimizer = (function (_super) { + __extends(MomentumOptimizer, _super); + function MomentumOptimizer(learningRate, momentum, useNesterov) { + if (useNesterov === void 0) { useNesterov = false; } + var _this = _super.call(this, learningRate) || this; + _this.learningRate = learningRate; + _this.momentum = momentum; + _this.useNesterov = useNesterov; + _this.m = scalar(_this.momentum); + _this.accumulations = {}; + return _this; + } + MomentumOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = ENV.engine.registeredVariables[variableName]; + if (this_1.accumulations[variableName] == null) { + var trainable_1 = false; + tidy(function () { + _this.accumulations[variableName] = + zerosLike(value).variable(trainable_1); + }); + } + var accumulation = this_1.accumulations[variableName]; + var gradient = variableGradients[variableName]; + tidy(function () { + var newValue; + var newAccumulation = _this.m.mul(accumulation).add(gradient); + if (_this.useNesterov) { + newValue = + _this.c.mul(gradient.add(newAccumulation.mul(_this.m))).add(value); + } + else { + newValue = _this.c.mul(newAccumulation).add(value); + } + _this.accumulations[variableName].assign(newAccumulation); + value.assign(newValue); + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + MomentumOptimizer.prototype.dispose = function () { + _super.prototype.dispose.call(this); + this.m.dispose(); + if (this.accumulations != null) { + for (var variableName in this.accumulations) { + this.accumulations[variableName].dispose(); + } + } + }; + MomentumOptimizer.prototype.setMomentum = function (momentum) { + this.momentum = momentum; + }; + MomentumOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + momentum: this.momentum, + useNesterov: this.useNesterov + }; + }; + MomentumOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.momentum, config.useNesterov); + }; + MomentumOptimizer.className = 'MomentumOptimizer'; + return MomentumOptimizer; + }(SGDOptimizer)); + SerializationMap.register(MomentumOptimizer); + + var RMSPropOptimizer = (function (_super) { + __extends(RMSPropOptimizer, _super); + function RMSPropOptimizer(learningRate, decay, momentum, epsilon, centered) { + if (decay === void 0) { decay = 0.9; } + if (momentum === void 0) { momentum = 0.0; } + if (epsilon === void 0) { epsilon = null; } + if (centered === void 0) { centered = false; } + var _this = _super.call(this) || this; + _this.learningRate = learningRate; + _this.decay = decay; + _this.momentum = momentum; + _this.epsilon = epsilon; + _this.accumulatedMeanSquares = {}; + _this.accumulatedMeanGrads = {}; + _this.accumulatedMoments = {}; + _this.c = keep(scalar(learningRate)); + _this.decayScalar = keep(scalar(decay)); + _this.momentumScalar = keep(scalar(momentum)); + _this.oneMinusDecay = keep(scalar(1 - decay)); + _this.centered = centered; + if (epsilon === null) { + epsilon = getOptimizerDefaultEpsilonValue(); + } + _this.epsilonScalar = keep(scalar(epsilon)); + return _this; + } + RMSPropOptimizer.prototype.applyGradients = function (variableGradients) { + var _this = this; + var _loop_1 = function (variableName) { + var value = ENV.engine.registeredVariables[variableName]; + if (this_1.accumulatedMeanSquares[variableName] == null) { + var trainable_1 = false; + tidy(function () { + _this.accumulatedMeanSquares[variableName] = + zerosLike(value).variable(trainable_1); + }); + } + if (this_1.accumulatedMeanGrads[variableName] == null && this_1.centered) { + var trainable_2 = false; + tidy(function () { + _this.accumulatedMeanGrads[variableName] = + zerosLike(value).variable(trainable_2); + }); + } + if (this_1.accumulatedMoments[variableName] == null) { + var trainable_3 = false; + tidy(function () { + _this.accumulatedMoments[variableName] = + zerosLike(value).variable(trainable_3); + }); + } + var accumulatedMeanSquare = this_1.accumulatedMeanSquares[variableName]; + var accumulatedMeanGrad = this_1.accumulatedMeanGrads[variableName]; + var accumulatedMoments = this_1.accumulatedMoments[variableName]; + var gradient = variableGradients[variableName]; + tidy(function () { + var newAccumulatedMeanSquare = _this.decayScalar.mul(accumulatedMeanSquare) + .add(_this.oneMinusDecay.mul(gradient.square())); + if (_this.centered) { + var newAccumulatedMeanGrad = _this.decayScalar.mul(accumulatedMeanGrad) + .add(_this.oneMinusDecay.mul(gradient)); + var newAccumulatedMoments = _this.momentumScalar.mul(accumulatedMoments) + .add(_this.c.mul(gradient).div(newAccumulatedMeanSquare + .sub(newAccumulatedMeanGrad.square().add(_this.epsilonScalar)) + .sqrt())); + _this.accumulatedMeanSquares[variableName].assign(newAccumulatedMeanSquare); + _this.accumulatedMeanGrads[variableName].assign(newAccumulatedMeanGrad); + _this.accumulatedMoments[variableName].assign(newAccumulatedMoments); + var newValue = value.sub(newAccumulatedMoments); + value.assign(newValue); + } + else { + var newAccumulatedMeanSquare_1 = _this.decayScalar.mul(accumulatedMeanSquare) + .add(_this.oneMinusDecay.mul(gradient.square())); + var newAccumulatedMoments = _this.momentumScalar.mul(accumulatedMoments) + .add(_this.c.mul(gradient).div(newAccumulatedMeanSquare_1.add(_this.epsilonScalar).sqrt())); + _this.accumulatedMeanSquares[variableName].assign(newAccumulatedMeanSquare_1); + _this.accumulatedMoments[variableName].assign(newAccumulatedMoments); + var newValue = value.sub(newAccumulatedMoments); + value.assign(newValue); + } + }); + }; + var this_1 = this; + for (var variableName in variableGradients) { + _loop_1(variableName); + } + }; + RMSPropOptimizer.prototype.dispose = function () { + var _this = this; + this.c.dispose(); + this.epsilonScalar.dispose(); + this.decayScalar.dispose(); + this.momentumScalar.dispose(); + this.oneMinusDecay.dispose(); + if (this.accumulatedMeanSquares != null) { + Object.keys(this.accumulatedMeanSquares) + .forEach(function (name) { return _this.accumulatedMeanSquares[name].dispose(); }); + } + if (this.accumulatedMeanGrads != null && this.centered) { + Object.keys(this.accumulatedMeanGrads) + .forEach(function (name) { return _this.accumulatedMeanGrads[name].dispose(); }); + } + if (this.accumulatedMoments != null) { + Object.keys(this.accumulatedMoments) + .forEach(function (name) { return _this.accumulatedMoments[name].dispose(); }); + } + }; + RMSPropOptimizer.prototype.getConfig = function () { + return { + learningRate: this.learningRate, + decay: this.decay, + momentum: this.momentum, + epsilon: this.epsilon, + centered: this.centered + }; + }; + RMSPropOptimizer.fromConfig = function (cls, config) { + return new cls(config.learningRate, config.decay, config.momentum, config.epsilon, config.centered); + }; + RMSPropOptimizer.className = 'RMSPropOptimizer'; + return RMSPropOptimizer; + }(Optimizer)); + SerializationMap.register(RMSPropOptimizer); + + var OptimizerConstructors = (function () { + function OptimizerConstructors() { + } + OptimizerConstructors.sgd = function (learningRate) { + return new SGDOptimizer(learningRate); + }; + OptimizerConstructors.momentum = function (learningRate, momentum, useNesterov) { + if (useNesterov === void 0) { useNesterov = false; } + return new MomentumOptimizer(learningRate, momentum, useNesterov); + }; + OptimizerConstructors.rmsprop = function (learningRate, decay, momentum, epsilon, centered) { + if (decay === void 0) { decay = .9; } + if (momentum === void 0) { momentum = 0.0; } + if (epsilon === void 0) { epsilon = null; } + if (centered === void 0) { centered = false; } + return new RMSPropOptimizer(learningRate, decay, momentum, epsilon, centered); + }; + OptimizerConstructors.adam = function (learningRate, beta1, beta2, epsilon) { + if (learningRate === void 0) { learningRate = 0.001; } + if (beta1 === void 0) { beta1 = 0.9; } + if (beta2 === void 0) { beta2 = 0.999; } + if (epsilon === void 0) { epsilon = null; } + return new AdamOptimizer(learningRate, beta1, beta2, epsilon); + }; + OptimizerConstructors.adadelta = function (learningRate, rho, epsilon) { + if (learningRate === void 0) { learningRate = .001; } + if (rho === void 0) { rho = .95; } + if (epsilon === void 0) { epsilon = null; } + return new AdadeltaOptimizer(learningRate, rho, epsilon); + }; + OptimizerConstructors.adamax = function (learningRate, beta1, beta2, epsilon, decay) { + if (learningRate === void 0) { learningRate = 0.002; } + if (beta1 === void 0) { beta1 = 0.9; } + if (beta2 === void 0) { beta2 = 0.999; } + if (epsilon === void 0) { epsilon = null; } + if (decay === void 0) { decay = 0.0; } + return new AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay); + }; + OptimizerConstructors.adagrad = function (learningRate, initialAccumulatorValue) { + if (initialAccumulatorValue === void 0) { initialAccumulatorValue = 0.1; } + return new AdagradOptimizer(learningRate, initialAccumulatorValue); + }; + return OptimizerConstructors; + }()); + + var train = { + sgd: OptimizerConstructors.sgd, + momentum: OptimizerConstructors.momentum, + adadelta: OptimizerConstructors.adadelta, + adagrad: OptimizerConstructors.adagrad, + rmsprop: OptimizerConstructors.rmsprop, + adamax: OptimizerConstructors.adamax, + adam: OptimizerConstructors.adam + }; + + var setBackend = Environment.setBackend; + var getBackend = Environment.getBackend; + var disposeVariables = Environment.disposeVariables; + var memory = Environment.memory; + setOpHandler(ops); + + exports.setBackend = setBackend; + exports.getBackend = getBackend; + exports.disposeVariables = disposeVariables; + exports.memory = memory; + exports.version_core = version; + exports.nextFrame = nextFrame; + exports.environment = environment; + exports.io = io; + exports.serialization = serialization; + exports.test_util = test_util; + exports.util = util; + exports.webgl = webgl; + exports.AdadeltaOptimizer = AdadeltaOptimizer; + exports.AdagradOptimizer = AdagradOptimizer; + exports.AdamOptimizer = AdamOptimizer; + exports.AdamaxOptimizer = AdamaxOptimizer; + exports.MomentumOptimizer = MomentumOptimizer; + exports.Optimizer = Optimizer; + exports.RMSPropOptimizer = RMSPropOptimizer; + exports.SGDOptimizer = SGDOptimizer; + exports.Tensor = Tensor; + exports.TensorBuffer = TensorBuffer; + exports.variable = variable; + exports.Variable = Variable; + exports.ENV = ENV; + exports.Environment = Environment; + exports.image = image_ops; + exports.linalg = linalg_ops; + exports.losses = loss_ops; + exports.op = op; + exports.batchNormalization2d = batchNormalization2d; + exports.batchNormalization3d = batchNormalization3d; + exports.batchNormalization4d = batchNormalization4d; + exports.batchNormalization = batchNormalization; + exports.concat = concat; + exports.concat1d = concat1d; + exports.concat2d = concat2d; + exports.concat3d = concat3d; + exports.concat4d = concat4d; + exports.conv1d = conv1d; + exports.conv2d = conv2d; + exports.depthwiseConv2d = depthwiseConv2d; + exports.separableConv2d = separableConv2d; + exports.conv2dTranspose = conv2dTranspose; + exports.matMul = matMul; + exports.dot = dot; + exports.outerProduct = outerProduct; + exports.reverse = reverse; + exports.reverse1d = reverse1d; + exports.reverse2d = reverse2d; + exports.reverse3d = reverse3d; + exports.reverse4d = reverse4d; + exports.maxPool = maxPool; + exports.avgPool = avgPool; + exports.slice = slice; + exports.slice1d = slice1d; + exports.slice2d = slice2d; + exports.slice3d = slice3d; + exports.slice4d = slice4d; + exports.abs = abs; + exports.acos = acos; + exports.acosh = acosh; + exports.asin = asin; + exports.asinh = asinh; + exports.atan = atan; + exports.atanh = atanh; + exports.ceil = ceil; + exports.clipByValue = clipByValue; + exports.cos = cos; + exports.cosh = cosh; + exports.erf = erf; + exports.exp = exp; + exports.expm1 = expm1; + exports.floor = floor; + exports.log = log$1; + exports.log1p = log1p; + exports.logSigmoid = logSigmoid; + exports.neg = neg; + exports.reciprocal = reciprocal; + exports.round = round; + exports.rsqrt = rsqrt; + exports.sigmoid = sigmoid; + exports.sign = sign; + exports.sin = sin; + exports.sinh = sinh; + exports.softplus = softplus; + exports.sqrt = sqrt; + exports.square = square; + exports.step = step; + exports.tan = tan; + exports.tanh = tanh$1; + exports.all = all; + exports.any = any; + exports.argMax = argMax; + exports.argMin = argMin; + exports.logSumExp = logSumExp; + exports.max = max; + exports.mean = mean; + exports.min = min; + exports.moments = moments; + exports.sum = sum; + exports.equal = equal; + exports.equalStrict = equalStrict; + exports.greater = greater; + exports.greaterEqual = greaterEqual; + exports.greaterEqualStrict = greaterEqualStrict; + exports.greaterStrict = greaterStrict; + exports.less = less; + exports.lessEqual = lessEqual; + exports.lessEqualStrict = lessEqualStrict; + exports.lessStrict = lessStrict; + exports.notEqual = notEqual; + exports.notEqualStrict = notEqualStrict; + exports.add = add; + exports.addN = addN; + exports.addStrict = addStrict; + exports.atan2 = atan2; + exports.div = div; + exports.divStrict = divStrict; + exports.floorDiv = floorDiv; + exports.maximum = maximum; + exports.maximumStrict = maximumStrict; + exports.minimum = minimum; + exports.minimumStrict = minimumStrict; + exports.mod = mod; + exports.modStrict = modStrict; + exports.mul = mul; + exports.mulStrict = mulStrict; + exports.pow = pow; + exports.powStrict = powStrict; + exports.squaredDifference = squaredDifference; + exports.squaredDifferenceStrict = squaredDifferenceStrict; + exports.sub = sub; + exports.subStrict = subStrict; + exports.elu = elu; + exports.leakyRelu = leakyRelu; + exports.prelu = prelu; + exports.relu = relu; + exports.selu = selu; + exports.logicalAnd = logicalAnd; + exports.logicalNot = logicalNot; + exports.logicalOr = logicalOr; + exports.logicalXor = logicalXor; + exports.where = where; + exports.whereAsync = whereAsync; + exports.buffer = buffer; + exports.toPixels = toPixels; + exports.print = print; + exports.cast = cast; + exports.clone = clone; + exports.cumsum = cumsum; + exports.expandDims = expandDims; + exports.eye = eye; + exports.fromPixels = fromPixels; + exports.multinomial = multinomial; + exports.oneHot = oneHot; + exports.pad = pad; + exports.pad1d = pad1d; + exports.pad2d = pad2d; + exports.pad3d = pad3d; + exports.pad4d = pad4d; + exports.rand = rand; + exports.randomNormal = randomNormal; + exports.randomUniform = randomUniform; + exports.reshape = reshape; + exports.split = split; + exports.squeeze = squeeze; + exports.stack = stack; + exports.tile = tile; + exports.truncatedNormal = truncatedNormal; + exports.unstack = unstack; + exports.batchToSpaceND = batchToSpaceND; + exports.spaceToBatchND = spaceToBatchND; + exports.fill = fill; + exports.linspace = linspace; + exports.ones = ones$1; + exports.range = range; + exports.scalar = scalar; + exports.tensor = tensor; + exports.tensor1d = tensor1d; + exports.tensor2d = tensor2d; + exports.tensor3d = tensor3d; + exports.tensor4d = tensor4d; + exports.tensor5d = tensor5d; + exports.tensor6d = tensor6d; + exports.zeros = zeros; + exports.onesLike = onesLike; + exports.zerosLike = zerosLike; + exports.transpose = transpose; + exports.softmax = softmax; + exports.localResponseNormalization = localResponseNormalization; + exports.norm = norm; + exports.gather = gather; + exports.unsortedSegmentSum = unsortedSegmentSum; + exports.basicLSTMCell = basicLSTMCell; + exports.multiRNNCell = multiRNNCell; + exports.movingAverage = movingAverage; + exports.stridedSlice = stridedSlice; + exports.topk = topk; + exports.train = train; + exports.tidy = tidy; + exports.keep = keep; + exports.dispose = dispose; + exports.time = time; + exports.customGrad = customGrad; + exports.grad = grad; + exports.grads = grads; + exports.valueAndGrad = valueAndGrad; + exports.valueAndGrads = valueAndGrads; + exports.variableGrads = variableGrads; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); +//# sourceMappingURL=tf-core.js.map diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.js.map b/node_modules/@tensorflow/tfjs-core/dist/tf-core.js.map new file mode 100644 index 0000000..d8a5d99 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf-core.js","sources":["../src/device_util.ts","../src/util.ts","../src/profiler.ts","../src/tape.ts","../src/tensor_format.ts","../src/tensor.ts","../src/tensor_util.ts","../src/engine.ts","../src/environment_util.ts","../src/environment.ts","../src/log.ts","../src/ops/array_ops_util.ts","../src/ops/axis_util.ts","../src/ops/reduce_util.ts","../src/ops/segment_util.ts","../src/ops/slice_util.ts","../src/gradients.ts","../src/tensor_util_env.ts","../src/ops/operation.ts","../src/ops/softmax.ts","../src/ops/tensor_ops.ts","../src/types.ts","../src/kernels/backend_util.ts","../src/kernels/non_max_suppression_impl.ts","../src/kernels/topk_impl.ts","../src/kernels/webgl/argminmax_gpu.ts","../src/kernels/webgl/avg_pool_backprop_gpu.ts","../src/ops/broadcast_util.ts","../src/kernels/webgl/batchnorm_gpu.ts","../src/kernels/webgl/binaryop_gpu.ts","../src/kernels/webgl/clip_gpu.ts","../src/ops/concat_util.ts","../src/kernels/webgl/concat_gpu.ts","../src/kernels/webgl/conv_backprop_gpu.ts","../src/kernels/webgl/conv_backprop_gpu_depthwise.ts","../src/kernels/webgl/conv_gpu.ts","../src/kernels/webgl/conv_gpu_depthwise.ts","../src/kernels/webgl/shader_compiler.ts","../src/kernels/webgl/cumsum_gpu.ts","../src/kernels/webgl/encode_float_gpu.ts","../src/kernels/webgl/from_pixels_gpu.ts","../src/kernels/webgl/gather_gpu.ts","../src/kernels/webgl/tex_util.ts","../src/kernels/webgl/webgl_util.ts","../src/kernels/webgl/gpgpu_util.ts","../src/kernels/webgl/gpgpu_context.ts","../src/kernels/webgl/gpgpu_math.ts","../src/kernels/webgl/lrn_gpu.ts","../src/kernels/webgl/lrn_grad_gpu.ts","../src/kernels/webgl/max_pool_backprop_gpu.ts","../src/kernels/webgl/mulmat_gpu.ts","../src/kernels/webgl/multinomial_gpu.ts","../src/kernels/webgl/onehot_gpu.ts","../src/kernels/webgl/pad_gpu.ts","../src/kernels/webgl/pool_gpu.ts","../src/kernels/webgl/reduce_gpu.ts","../src/kernels/webgl/resize_bilinear_backprop_gpu.ts","../src/kernels/webgl/resize_bilinear_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_backprop_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_gpu.ts","../src/kernels/webgl/reverse_gpu.ts","../src/kernels/webgl/segment_gpu.ts","../src/kernels/webgl/select_gpu.ts","../src/kernels/webgl/slice_gpu.ts","../src/kernels/webgl/strided_slice_gpu.ts","../src/kernels/webgl/texture_manager.ts","../src/kernels/webgl/tile_gpu.ts","../src/kernels/webgl/transpose_gpu.ts","../src/ops/erf_util.ts","../src/ops/selu_util.ts","../src/kernels/webgl/unaryop_gpu.ts","../src/ops/concat.ts","../node_modules/seedrandom/lib/alea.js","../node_modules/seedrandom/lib/xor128.js","../node_modules/seedrandom/lib/xorwow.js","../node_modules/seedrandom/lib/xorshift7.js","../node_modules/seedrandom/lib/xor4096.js","../node_modules/seedrandom/lib/tychei.js","../node_modules/seedrandom/seedrandom.js","../node_modules/seedrandom/index.js","../src/ops/rand.ts","../src/ops/array_ops.ts","../src/kernels/where_impl.ts","../src/kernels/backend_webgl.ts","../src/ops/unary_ops.ts","../src/ops/batchnorm.ts","../src/ops/conv_util.ts","../src/ops/conv.ts","../src/ops/matmul.ts","../src/ops/reverse.ts","../src/ops/pool.ts","../src/ops/slice.ts","../src/globals.ts","../src/ops/reduction_ops.ts","../src/ops/compare.ts","../src/ops/binary_ops.ts","../src/ops/logical_ops.ts","../src/ops/relu_ops.ts","../src/ops/transpose.ts","../src/ops/lrn.ts","../src/ops/norm.ts","../src/ops/segment_ops.ts","../src/ops/lstm.ts","../src/ops/moving_average.ts","../src/ops/strided_slice.ts","../src/ops/topk.ts","../src/ops/loss_ops.ts","../src/ops/linalg_ops.ts","../src/ops/image_ops.ts","../src/kernels/backend_cpu.ts","../src/browser_util.ts","../src/io/types.ts","../src/io/io_utils.ts","../src/io/router_registry.ts","../src/io/model_management.ts","../src/io/indexed_db.ts","../src/io/local_storage.ts","../src/io/browser_files.ts","../src/io/weights_loader.ts","../src/io/browser_http.ts","../src/io/passthrough.ts","../src/io/io.ts","../src/serialization.ts","../src/test_util.ts","../src/version.ts","../src/optimizers/optimizer.ts","../src/optimizers/optimizer_utils.ts","../src/optimizers/adadelta_optimizer.ts","../src/optimizers/adagrad_optimizer.ts","../src/optimizers/adam_optimizer.ts","../src/optimizers/adamax_optimizer.ts","../src/optimizers/sgd_optimizer.ts","../src/optimizers/momentum_optimizer.ts","../src/optimizers/rmsprop_optimizer.ts","../src/optimizers/optimizer_constructors.ts","../src/train.ts","../src/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport function isMobile(): boolean {\n // tslint:disable-next-line:no-any\n const a = navigator.userAgent || navigator.vendor || (window as any).opera;\n // tslint:disable-next-line:max-line-length\n return /(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i\n .test(a) ||\n // tslint:disable-next-line:max-line-length\n /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i\n .test(a.substr(0, 4));\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ArrayData, DataType, DataTypeMap, FlatVector, RecursiveArray, RegularArray, TensorLike, TypedArray} from './types';\n\n/** Shuffles the array using Fisher-Yates algorithm. */\n// tslint:disable-next-line:no-any\nexport function shuffle(array: any[]|Uint32Array|Int32Array|\n Float32Array): void {\n let counter = array.length;\n let temp = 0;\n let index = 0;\n // While there are elements in the array\n while (counter > 0) {\n // Pick a random index\n index = (Math.random() * counter) | 0;\n // Decrease counter by 1\n counter--;\n // And swap the last element with it\n temp = array[counter];\n array[counter] = array[index];\n array[index] = temp;\n }\n}\n\n/** Clamps a value to a specified range. */\nexport function clamp(min: number, x: number, max: number): number {\n return Math.max(min, Math.min(x, max));\n}\n\n/** Returns a sample from a uniform [a, b] distribution. */\nexport function randUniform(a: number, b: number) {\n return Math.random() * (b - a) + a;\n}\n\n/** Returns squared eucledian distance between two vectors. */\nexport function distSquared(a: FlatVector, b: FlatVector): number {\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n const diff = Number(a[i]) - Number(b[i]);\n result += diff * diff;\n }\n return result;\n}\n\nexport function assert(expr: boolean, msg: string|(() => string)) {\n if (!expr) {\n throw new Error(typeof msg === 'string' ? msg : msg());\n }\n}\n\nexport function assertShapesMatch(\n shapeA: number[], shapeB: number[], errorMessagePrefix = ''): void {\n assert(\n arraysEqual(shapeA, shapeB),\n errorMessagePrefix + ` Shapes ${shapeA} and ${shapeB} must match`);\n}\n\nexport function assertNonNull(a: TensorLike): void {\n assert(\n a != null,\n `The input to the tensor constructor must be a non-null value.`);\n}\n\n// NOTE: We explicitly type out what T extends instead of any so that\n// util.flatten on a nested array of number doesn't try to infer T as a\n// number[][], causing us to explicitly type util.flatten().\nexport function flatten>(\n arr: T|RecursiveArray, ret: T[] = []): T[] {\n if (Array.isArray(arr)) {\n for (let i = 0; i < arr.length; ++i) {\n flatten(arr[i], ret);\n }\n } else {\n ret.push(arr as T);\n }\n return ret;\n}\n\nexport function inferShape(val: TypedArray|number|boolean|RegularArray|\n RegularArray): number[] {\n let firstElem: typeof val = val;\n\n if (isTypedArray(val)) {\n return [(val as TypedArray).length];\n }\n if (!Array.isArray(val)) {\n return []; // Scalar.\n }\n const shape: number[] = [];\n\n while (firstElem instanceof Array) {\n shape.push(firstElem.length);\n firstElem = firstElem[0];\n }\n if (val instanceof Array) {\n deepAssertShapeConsistency(val, shape, []);\n }\n return shape;\n}\n\nfunction deepAssertShapeConsistency(\n val: number|boolean|RegularArray|RegularArray,\n shape: number[], indices?: number[]) {\n indices = indices || [];\n if (!(val instanceof Array)) {\n assert(\n shape.length === 0,\n () => `Element arr[${indices.join('][')}] is a primitive, ` +\n `but should be an array of ${shape[0]} elements`);\n return;\n }\n assert(\n shape.length > 0,\n () => `Element arr[${indices.join('][')}] should be a primitive, ` +\n `but is an array of ${val.length} elements`);\n assert(\n val.length === shape[0],\n () => `Element arr[${indices.join('][')}] should have ${shape[0]} ` +\n `elements, but has ${val.length} elements`);\n const subShape = shape.slice(1);\n for (let i = 0; i < val.length; ++i) {\n deepAssertShapeConsistency(val[i], subShape, indices.concat(i));\n }\n}\n\nexport function sizeFromShape(shape: number[]): number {\n if (shape.length === 0) {\n // Scalar.\n return 1;\n }\n let size = shape[0];\n for (let i = 1; i < shape.length; i++) {\n size *= shape[i];\n }\n return size;\n}\n\nexport function isScalarShape(shape: number[]): boolean {\n return shape.length === 0;\n}\n\nexport function arraysEqual(n1: FlatVector, n2: FlatVector) {\n if (n1.length !== n2.length) {\n return false;\n }\n for (let i = 0; i < n1.length; i++) {\n if (n1[i] !== n2[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function isInt(a: number): boolean {\n return a % 1 === 0;\n}\n\nexport function tanh(x: number): number {\n // tslint:disable-next-line:no-any\n if ((Math as any).tanh != null) {\n // tslint:disable-next-line:no-any\n return (Math as any).tanh(x);\n }\n if (x === Infinity) {\n return 1;\n } else if (x === -Infinity) {\n return -1;\n } else {\n const e2x = Math.exp(2 * x);\n return (e2x - 1) / (e2x + 1);\n }\n}\n\nexport function sizeToSquarishShape(size: number): [number, number] {\n for (let a = Math.floor(Math.sqrt(size)); a > 1; --a) {\n if (size % a === 0) {\n return [a, size / a];\n }\n }\n return [1, size];\n}\n\nexport function createShuffledIndices(n: number): Uint32Array {\n const shuffledIndices = new Uint32Array(n);\n for (let i = 0; i < n; ++i) {\n shuffledIndices[i] = i;\n }\n shuffle(shuffledIndices);\n return shuffledIndices;\n}\n\nexport function rightPad(a: string, size: number): string {\n if (size <= a.length) {\n return a;\n }\n return a + ' '.repeat(size - a.length);\n}\n\nexport function repeatedTry(\n checkFn: () => boolean, delayFn = (counter: number) => 0,\n maxCounter?: number): Promise {\n return new Promise((resolve, reject) => {\n let tryCount = 0;\n\n const tryFn = () => {\n if (checkFn()) {\n resolve();\n return;\n }\n\n tryCount++;\n\n const nextBackoff = delayFn(tryCount);\n\n if (maxCounter != null && tryCount >= maxCounter) {\n reject();\n return;\n }\n setTimeout(tryFn, nextBackoff);\n };\n\n tryFn();\n });\n}\n\n/**\n * Given the full size of the array and a shape that may contain -1 as the\n * implicit dimension, returns the inferred shape where -1 is replaced.\n * E.g. For shape=[2, -1, 3] and size=24, it will return [2, 4, 3].\n *\n * @param shape The shape, which may contain -1 in some dimension.\n * @param size The full size (number of elements) of the array.\n * @return The inferred shape where -1 is replaced with the inferred size.\n */\nexport function inferFromImplicitShape(\n shape: number[], size: number): number[] {\n let shapeProd = 1;\n let implicitIdx = -1;\n\n for (let i = 0; i < shape.length; ++i) {\n if (shape[i] > 0) {\n shapeProd *= shape[i];\n } else if (shape[i] === -1) {\n if (implicitIdx !== -1) {\n throw Error(\n `Shapes can only have 1 implicit size. ` +\n `Found - 1 at dim ${implicitIdx} and dim ${i}`);\n }\n implicitIdx = i;\n } else if (shape[i] <= 0) {\n throw Error(`Shapes can not be <= 0. Found ${shape[i]} at dim ${i}`);\n }\n }\n\n if (implicitIdx === -1) {\n if (size > 0 && size !== shapeProd) {\n throw Error(`Size(${size}) must match the product of shape ${shape}`);\n }\n return shape;\n }\n\n if (size % shapeProd !== 0) {\n throw Error(\n `The implicit shape can't be a fractional number. ` +\n `Got ${size} / ${shapeProd}`);\n }\n\n const newShape = shape.slice();\n newShape[implicitIdx] = size / shapeProd;\n return newShape;\n}\n\n/** Reduces the shape by removing all dimensions of shape 1. */\nexport function squeezeShape(shape: number[], axis?: number[]):\n {newShape: number[], keptDims: number[]} {\n const newShape: number[] = [];\n const keptDims: number[] = [];\n let j = 0;\n for (let i = 0; i < shape.length; ++i) {\n if (axis != null) {\n if (axis[j] === i && shape[i] > 1) {\n throw new Error(\n `Can't squeeze axis ${i} since its dim '${shape[i]}' is not 1`);\n }\n if ((axis[j] == null || axis[j] > i) && shape[i] === 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n if (axis[j] <= i) {\n j++;\n }\n }\n if (shape[i] > 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n }\n return {newShape, keptDims};\n}\n\nexport function getTypedArrayFromDType(\n dtype: D, size: number): DataTypeMap[D] {\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n return values;\n}\n\nexport function checkComputationForNaN(\n vals: DataTypeMap[D], dtype: D, name: string): void {\n if (dtype !== 'float32') {\n // Only floating point computations will generate NaN values\n return;\n }\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`The result of the '${name}' has NaNs.`);\n }\n }\n}\n\nexport function checkConversionForNaN(\n vals: DataTypeMap[D]|number[], dtype: D): void {\n if (dtype === 'float32') {\n // NaN is valid for floating point conversions\n return;\n }\n\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`NaN is not a valid value for dtype: '${dtype}'.`);\n }\n }\n}\n\n/**\n * Returns true if the new type can't encode the old type without loss of\n * precision.\n */\nexport function hasEncodingLoss(oldType: DataType, newType: DataType): boolean {\n if (newType === 'float32') {\n return false;\n }\n if (newType === 'int32' && oldType !== 'float32') {\n return false;\n }\n if (newType === 'bool' && oldType === 'bool') {\n return false;\n }\n return true;\n}\n\nfunction copyTypedArray(\n array: DataTypeMap[D]|number[]|boolean[], dtype: D,\n debugMode: boolean): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(array as number[]);\n } else if (dtype === 'int32') {\n if (debugMode) {\n checkConversionForNaN(array as number[], dtype);\n }\n return new Int32Array(array as number[]);\n } else if (dtype === 'bool') {\n const bool = new Uint8Array(array.length);\n for (let i = 0; i < bool.length; ++i) {\n if (Math.round(array[i] as number) !== 0) {\n bool[i] = 1;\n }\n }\n return bool;\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\nexport function isTypedArray(a: TypedArray|number|boolean|RegularArray|\n RegularArray): boolean {\n return a instanceof Float32Array || a instanceof Int32Array ||\n a instanceof Uint8Array;\n}\n\nexport function bytesPerElement(dtype: DataType): number {\n if (dtype === 'float32' || dtype === 'int32') {\n return 4;\n } else if (dtype === 'bool') {\n return 1;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nexport function isFunction(f: Function) {\n return !!(f && f.constructor && f.call && f.apply);\n}\n\nexport function nearestDivisor(size: number, start: number): number {\n for (let i = start; i < size; ++i) {\n if (size % i === 0) {\n return i;\n }\n }\n return size;\n}\n\nexport function computeStrides(shape: number[]): number[] {\n const rank = shape.length;\n if (rank < 2) {\n return [];\n }\n\n // Last dimension has implicit stride of 1, thus having D-1 (instead of D)\n // strides.\n const strides = new Array(rank - 1);\n strides[rank - 2] = shape[rank - 1];\n for (let i = rank - 3; i >= 0; --i) {\n strides[i] = strides[i + 1] * shape[i + 1];\n }\n return strides;\n}\n\nexport function toTypedArray(\n a: ArrayData, dtype: D, debugMode: boolean): DataTypeMap[D] {\n if (noConversionNeeded(a, dtype)) {\n return a as DataTypeMap[D];\n }\n if (Array.isArray(a)) {\n a = flatten(a as number[]);\n }\n return copyTypedArray(a, dtype, debugMode);\n}\n\nfunction noConversionNeeded(\n a: ArrayData, dtype: D): boolean {\n return (a instanceof Float32Array && dtype === 'float32') ||\n (a instanceof Int32Array && dtype === 'int32') ||\n (a instanceof Uint8Array && dtype === 'bool');\n}\n\nexport function makeOnesTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n const array = makeZerosTypedArray(size, dtype);\n for (let i = 0; i < array.length; i++) {\n array[i] = 1;\n }\n return array;\n}\n\nexport function makeZerosTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(size);\n } else if (dtype === 'int32') {\n return new Int32Array(size);\n } else if (dtype === 'bool') {\n return new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\n/**\n * Returns the current high-resolution real time in milliseconds. It is\n * relative to an arbitrary time in the past.\n */\nexport function now(): number {\n if (typeof performance !== 'undefined') {\n return performance.now();\n } else if (typeof process !== 'undefined') {\n const time = process.hrtime();\n return time[0] * 1000 + time[1] / 1000000;\n } else {\n throw new Error(\n 'Can not measure time in this environment. You should run tf.js ' +\n 'in the browser or in Node.js');\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimer} from './kernels/backend';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\nexport class Profiler {\n constructor(private backendTimer: BackendTimer, private logger?: Logger) {\n if (logger == null) {\n this.logger = new Logger();\n }\n }\n\n profileKernel(name: string, f: () => T | Tensor[]):\n T {\n let result: T|Tensor[];\n const holdResultWrapperFn = () => {\n result = f();\n };\n const timer = this.backendTimer.time(holdResultWrapperFn);\n\n const results: Tensor[] =\n Array.isArray(result) ? result : [result] as Tensor[];\n results.forEach(r => {\n const vals = r.dataSync();\n util.checkComputationForNaN(vals, r.dtype, name);\n\n timer.then(timing => {\n this.logger.logKernelProfile(name, r, vals, timing.kernelMs);\n });\n });\n\n return result as T;\n }\n}\n\nexport class Logger {\n logKernelProfile(\n name: string, result: Tensor, vals: TypedArray, timeMs: number) {\n const time = util.rightPad(`${timeMs}ms`, 9);\n const paddedName = util.rightPad(name, 25);\n const rank = result.rank;\n const size = result.size;\n const shape = util.rightPad(result.shape.toString(), 14);\n console.log(\n `%c${paddedName}\\t%c${time}\\t%c${rank}D ${shape}\\t%c${size}`,\n 'font-weight:bold', 'color:red', 'color:blue', 'color: orange');\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap} from './tensor_types';\nimport * as util from './util';\n\nexport interface TapeNode {\n id: number;\n name: string;\n output: Tensor;\n inputs: NamedTensorMap;\n // Optional params, defined only for ops with gradient impl.\n gradient?: (dy: Tensor|NamedTensorMap) => NamedGradientMap;\n}\n\nexport type NamedGradientMap = {\n [inputName: string]: () => Tensor;\n};\n\n/**\n * Computes a list of TapeNodes that connect x to y, filtering everything else\n * out and preserving the order of the original tape elements.\n * @param tape The tape elements to filter.\n * @param xs The input Tensors.\n * @param y The output Tensor.\n */\nexport function getFilteredNodesXToY(\n tape: TapeNode[], xs: Tensor[], y: Tensor): TapeNode[] {\n // Forward pass to compute all the nodes and Tensors that are transitively a\n // function of x.\n const tensorsFromX: {[tensorId: number]: boolean} = {};\n const nodesFromX: {[nodeId: number]: boolean} = {};\n for (let i = 0; i < xs.length; i++) {\n tensorsFromX[xs[i].id] = true;\n }\n\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n for (const inputName in nodeInputs) {\n const input = nodeInputs[inputName];\n\n let anyInputFromX = false;\n for (let j = 0; j < xs.length; j++) {\n if (tensorsFromX[input.id]) {\n tensorsFromX[node.output.id] = true;\n anyInputFromX = true;\n nodesFromX[node.id] = true;\n break;\n }\n }\n\n if (anyInputFromX) {\n break;\n }\n }\n }\n\n // Backwards pass to find all of the nodes and Tensors that lead to y.\n const tensorsLeadToY: {[tensorId: number]: boolean} = {};\n tensorsLeadToY[y.id] = true;\n const nodesToY: {[nodeId: number]: boolean} = {};\n\n for (let i = tape.length - 1; i >= 0; i--) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n\n const outputs: Tensor[] = [];\n outputs.push(node.output);\n\n // If any of the outputs lead to y, mark all of the inputs as leading to y.\n for (let j = 0; j < outputs.length; j++) {\n if (tensorsLeadToY[outputs[j].id]) {\n for (const inputName in nodeInputs) {\n tensorsLeadToY[nodeInputs[inputName].id] = true;\n nodesToY[node.id] = true;\n }\n break;\n }\n }\n }\n\n // Return the paths that come from x and lead to y.\n const filteredTape: TapeNode[] = [];\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n\n if (nodesFromX[node.id] && nodesToY[node.id]) {\n // Prune the inputs from the node that aren't a function of x.\n const prunedInputs: {[inputName: string]: Tensor} = {};\n for (const inputName in node.inputs) {\n const nodeInput = node.inputs[inputName];\n if (tensorsFromX[nodeInput.id]) {\n prunedInputs[inputName] = nodeInput;\n }\n }\n\n // Copy the node and overwrite inputsAndArgs to the pruned version.\n const prunedNode = Object.assign({}, node) as TapeNode;\n prunedNode.inputs = prunedInputs;\n prunedNode.output = node.output;\n\n filteredTape.push(prunedNode);\n }\n }\n\n return filteredTape;\n}\n\n/**\n * Backpropagate gradients through the filtered TapeNodes.\n * @param tensorAccumulatedGradientMap A map of Tensor to its gradient. This map\n * is mutated by this method.\n * @param filteredTape The filtered TapeNodes to backprop through.\n */\nexport function backpropagateGradients(\n tensorAccumulatedGradientMap: {[tensorId: number]: Tensor},\n filteredTape: TapeNode[]) {\n // Walk the tape backwards and keep a map of Tensor to its gradient.\n for (let i = filteredTape.length - 1; i >= 0; i--) {\n const node = filteredTape[i];\n\n const dy = tensorAccumulatedGradientMap[node.output.id];\n\n if (node.gradient == null) {\n throw new Error(\n `Cannot compute gradient: gradient function not found ` +\n `for ${node.name}.`);\n }\n\n // Backprop dy through this node and accumulate gradients over the inputs.\n const inputGradients = node.gradient(dy);\n for (const inputName in node.inputs) {\n if (!(inputName in inputGradients)) {\n throw new Error(\n `Cannot backprop through input ${inputName}. ` +\n `Available gradients found: ${Object.keys(inputGradients)}.`);\n }\n\n // Call the gradient function.\n const dx = inputGradients[inputName]();\n const x = node.inputs[inputName];\n if (!util.arraysEqual(dx.shape, x.shape)) {\n throw new Error(\n `Error in gradient for op ${node.name}. The gradient of input ` +\n `'${inputName}' has shape '${dx.shape}', which does not match ` +\n `the shape of the input '${x.shape}'`);\n }\n\n if (tensorAccumulatedGradientMap[x.id] == null) {\n tensorAccumulatedGradientMap[x.id] = dx;\n } else {\n const curGradient = tensorAccumulatedGradientMap[x.id];\n tensorAccumulatedGradientMap[x.id] = curGradient.add(dx);\n curGradient.dispose();\n }\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, TypedArray} from './types';\nimport {computeStrides, rightPad, sizeFromShape} from './util';\n\n// Maximum number of values before we decide to show ellipsis.\nconst FORMAT_LIMIT_NUM_VALS = 20;\n// Number of first and last values to show when displaying a, b,...,y, z.\nconst FORMAT_NUM_FIRST_LAST_VALS = 3;\n// Number of significant digits to show.\nconst FORMAT_NUM_SIG_DIGITS = 7;\n\nexport function tensorToString(\n vals: TypedArray, shape: number[], dtype: DataType, verbose: boolean) {\n const strides = computeStrides(shape);\n const padPerCol = computeMaxSizePerColumn(vals, shape, strides);\n const rank = shape.length;\n const valsLines = subTensorToString(vals, shape, strides, padPerCol);\n const lines = ['Tensor'];\n if (verbose) {\n lines.push(` dtype: ${dtype}`);\n lines.push(` rank: ${rank}`);\n lines.push(` shape: [${shape}]`);\n lines.push(` values:`);\n }\n lines.push(valsLines.map(l => ' ' + l).join('\\n'));\n return lines.join('\\n');\n}\n\nfunction computeMaxSizePerColumn(\n vals: TypedArray, shape: number[], strides: number[]): number[] {\n const n = sizeFromShape(shape);\n const numCols = strides[strides.length - 1];\n const padPerCol = new Array(numCols).fill(0);\n const rank = shape.length;\n if (rank > 1) {\n for (let row = 0; row < n / numCols; row++) {\n const offset = row * numCols;\n for (let j = 0; j < numCols; j++) {\n padPerCol[j] =\n Math.max(padPerCol[j], valToString(vals[offset + j], 0).length);\n }\n }\n }\n return padPerCol;\n}\n\nfunction valToString(val: number, pad: number) {\n return rightPad(\n parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), pad);\n}\n\nfunction subTensorToString(\n vals: TypedArray, shape: number[], strides: number[], padPerCol: number[],\n isLast = true): string[] {\n const size = shape[0];\n const rank = shape.length;\n if (rank === 0) {\n return [vals[0].toString()];\n }\n\n if (rank === 1) {\n if (size > FORMAT_LIMIT_NUM_VALS) {\n const firstVals =\n Array.from(vals.subarray(0, FORMAT_NUM_FIRST_LAST_VALS));\n const lastVals =\n Array.from(vals.subarray(size - FORMAT_NUM_FIRST_LAST_VALS, size));\n return [\n '[' + firstVals.map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ', ..., ' +\n lastVals\n .map(\n (x, i) => valToString(\n x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i]))\n .join(', ') +\n ']'\n ];\n }\n return [\n '[' +\n Array.from(vals).map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ']'\n ];\n }\n\n // The array is rank 2 or more.\n const subshape = shape.slice(1);\n const substrides = strides.slice(1);\n const stride = strides[0];\n const lines: string[] = [];\n if (size > FORMAT_LIMIT_NUM_VALS) {\n for (let i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n false /* isLast */));\n }\n lines.push('...');\n for (let i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n } else {\n for (let i = 0; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n }\n const sep = rank === 2 ? ',' : '';\n lines[0] = '[' + lines[0] + sep;\n for (let i = 1; i < lines.length - 1; i++) {\n lines[i] = ' ' + lines[i] + sep;\n }\n let newLineSep = ',\\n';\n for (let i = 2; i < rank; i++) {\n newLineSep += '\\n';\n }\n lines[lines.length - 1] =\n ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep);\n return lines;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensorToString} from './tensor_format';\nimport {DataType, Rank, ShapeMap, TypedArray} from './types';\nimport * as util from './util';\nimport {computeStrides} from './util';\n\n/** @hidden */\nexport interface TensorData {\n dataId?: DataId;\n values?: TypedArray;\n}\n\n/**\n * A mutable object, similar to `Tensor`, that allows users to set values\n * at locations before converting to an immutable `Tensor`.\n *\n * See `buffer` for creating a tensor buffer.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class TensorBuffer {\n size: number;\n shape: ShapeMap[R];\n strides: number[];\n values: TypedArray;\n\n constructor(shape: ShapeMap[R], public dtype: DataType, values: TypedArray) {\n if (values != null) {\n const n = values.length;\n const size = util.sizeFromShape(shape);\n util.assert(\n n === size,\n `Length of values '${n}' does not match the size ` +\n `inferred by the shape '${size}'`);\n }\n this.shape = shape.slice();\n this.values =\n values || util.getTypedArrayFromDType(dtype, util.sizeFromShape(shape));\n this.strides = computeStrides(shape);\n this.size = util.sizeFromShape(shape);\n }\n\n /**\n * Sets a value in the buffer at a given location.\n *\n * @param value The value to set.\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n set(value: number, ...locs: number[]) {\n if (locs.length === 0) {\n locs = [0];\n }\n util.assert(\n locs.length === this.rank,\n `The number of provided coordinates (${locs.length}) must ` +\n `match the rank (${this.rank})`);\n const index = this.locToIndex(locs);\n this.values[index] = value;\n }\n\n /**\n * Returns the value in the buffer at the provided location.\n *\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n get(...locs: number[]): number {\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.values[index];\n }\n\n locToIndex(locs: number[]): number {\n if (this.rank === 0) {\n return 0;\n } else if (this.rank === 1) {\n return locs[0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return index;\n }\n\n indexToLoc(index: number): number[] {\n if (this.rank === 0) {\n return [];\n } else if (this.rank === 1) {\n return [index];\n }\n const locs: number[] = new Array(this.shape.length);\n for (let i = 0; i < locs.length - 1; ++i) {\n locs[i] = Math.floor(index / this.strides[i]);\n index -= locs[i] * this.strides[i];\n }\n locs[locs.length - 1] = index;\n return locs;\n }\n\n get rank() {\n return this.shape.length;\n }\n\n /**\n * Creates an immutable `Tensor` object from the buffer.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n toTensor(): Tensor {\n return Tensor.make(this.shape, {values: this.values}, this.dtype);\n }\n}\n\nexport interface TensorTracker {\n registerTensor(t: Tensor): void;\n disposeTensor(t: Tensor): void;\n write(dataId: DataId, values: TypedArray): void;\n read(dataId: DataId): Promise;\n readSync(dataId: DataId): TypedArray;\n registerVariable(v: Variable): void;\n}\n\n/**\n * The Tensor class calls into this handler to delegate chaining operations.\n */\nexport interface OpHandler {\n cast(x: T, dtype: DataType): T;\n buffer(\n shape: ShapeMap[R], dtype: DataType,\n values?: TypedArray): TensorBuffer;\n print(x: T, verbose: boolean): void;\n reshape(x: Tensor, shape: ShapeMap[R2]): Tensor;\n expandDims(x: Tensor, axis: number): Tensor;\n cumsum(\n x: Tensor, axis: number, exclusive: boolean, reverse: boolean): T;\n squeeze(x: Tensor, axis?: number[]): T;\n clone(x: T): T;\n tile(x: T, reps: number[]): T;\n gather(x: T, indices: Tensor1D, axis: number): T;\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D;\n dot(t1: Tensor, t2: Tensor): Tensor;\n norm(\n x: Tensor, ord: number|'euclidean'|'fro', axis: number|number[],\n keepDims: boolean): Tensor;\n slice>(\n x: T, begin: number|number[], size?: number|number[]): T;\n reverse(x: T, axis?: number|number[]): T;\n concat(tensors: T[], axis: number): T;\n stack(tensors: T[], axis: number): Tensor;\n unstack(value: T, axis: number): Tensor[];\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T;\n batchNormalization(\n x: Tensor, mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon: number, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor;\n all(x: Tensor, axis: number|number[], keepDims: boolean): T;\n any(x: Tensor, axis: number|number[], keepDims: boolean): T;\n logSumExp(\n x: Tensor, axis: number|number[], keepDims: boolean): T;\n sum(x: Tensor, axis: number|number[], keepDims: boolean): T;\n mean(x: Tensor, axis: number|number[], keepDims: boolean):\n T;\n min(x: Tensor, axis: number|number[], keepDims: boolean): T;\n max(x: Tensor, axis: number|number[], keepDims: boolean): T;\n argMin(x: Tensor, axis: number): T;\n argMax(x: Tensor, axis: number): T;\n add(a: Tensor, b: Tensor): T;\n addStrict(a: T, b: T): T;\n sub(a: Tensor, b: Tensor): T;\n subStrict(a: T, b: T): T;\n pow(base: T, exp: Tensor): T;\n powStrict(base: T, exp: Tensor): T;\n mul(a: Tensor, b: Tensor): T;\n mulStrict(a: T, b: T): T;\n div(a: Tensor, b: Tensor): T;\n floorDiv(a: Tensor, b: Tensor): T;\n divStrict(a: T, b: T): T;\n mod(a: Tensor, b: Tensor): T;\n modStrict(a: T, b: T): T;\n minimum(a: Tensor, b: Tensor): T;\n minimumStrict(a: T, b: T): T;\n maximum(a: Tensor, b: Tensor): T;\n maximumStrict(a: T, b: T): T;\n squaredDifference(a: Tensor, b: Tensor): T;\n squaredDifferenceStrict(a: T, b: T): T;\n transpose(x: T, perm?: number[]): T;\n logicalNot(x: T): T;\n logicalAnd(a: Tensor, b: Tensor): T;\n logicalOr(a: Tensor, b: Tensor): T;\n logicalXor(a: Tensor, b: Tensor): T;\n where(condition: Tensor, a: T, b: T): T;\n notEqual(a: Tensor, b: Tensor): T;\n notEqualStrict(a: T, b: T): T;\n less(a: Tensor, b: Tensor): T;\n lessStrict(a: T, b: T): T;\n equal(a: Tensor, b: Tensor): T;\n equalStrict(a: T, b: T): T;\n lessEqual(a: Tensor, b: Tensor): T;\n lessEqualStrict(a: T, b: T): T;\n greater(a: Tensor, b: Tensor): T;\n greaterStrict(a: T, b: T): T;\n greaterEqual(a: Tensor, b: Tensor): T;\n greaterEqualStrict(a: T, b: T): T;\n neg(x: T): T;\n ceil(x: T): T;\n floor(x: T): T;\n sign(x: T): T;\n round(x: T): T;\n exp(x: T): T;\n expm1(x: T): T;\n log(x: T): T;\n log1p(x: T): T;\n sqrt(x: T): T;\n rsqrt(x: T): T;\n square(x: T): T;\n reciprocal(x: T): T;\n abs(x: T): T;\n clipByValue(\n x: T, clipValueMin: number, clipValueMax: number): T;\n sigmoid(x: T): T;\n logSigmoid(x: T): T;\n softplus(x: T): T;\n sin(x: T): T;\n cos(x: T): T;\n tan(x: T): T;\n asin(x: T): T;\n acos(x: T): T;\n atan(x: T): T;\n sinh(x: T): T;\n cosh(x: T): T;\n tanh(x: T): T;\n asinh(x: T): T;\n acosh(x: T): T;\n atanh(x: T): T;\n erf(x: T): T;\n step(x: T, alpha: number): T;\n relu(x: T): T;\n elu(x: T): T;\n selu(x: T): T;\n leakyRelu(x: T, alpha: number): T;\n prelu(x: T, alpha: T): T;\n softmax(logits: T, dim: number): T;\n image: {\n resizeBilinear(\n images: T, size: [number, number], alignCorners: boolean): T;\n resizeNearestNeighbor(\n images: T, size: [number, number], alignCorners: boolean): T;\n };\n conv1d(\n x: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW', dilation: number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2dTranspose(\n x: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n depthwiseConv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n maxPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n avgPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n localResponseNormalization(\n x: T, depthRadius: number, bias: number, alpha: number, beta: number): T;\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): T;\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T;\n spaceToBatchND(\n x: T, blockShape: number[], paddings: number[][]): T;\n}\n\n// For tracking tensor creation and disposal.\nlet trackerFn: () => TensorTracker = null;\n// Used by chaining methods to call into ops.\nlet opHandler: OpHandler = null;\n\n/**\n * An external consumer can register itself as the tensor tracker. This way\n * the Tensor class can notify the tracker for every tensor created and\n * disposed.\n */\nexport function setTensorTracker(fn: () => TensorTracker) {\n trackerFn = fn;\n}\n\n/**\n * An external consumer can register itself as the op handler. This way the\n * Tensor class can have chaining methods that call into ops via the op handler.\n */\nexport function setOpHandler(handler: OpHandler) {\n opHandler = handler;\n}\n\n/**\n * We wrap data id since we use weak map to avoid memory leaks.\n * Since we have our own memory management, we have a reference counter\n * mapping a tensor to its data, so there is always a pointer (even if that\n * data is otherwise garbage collectable).\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/\n * Global_Objects/WeakMap\n */\nexport type DataId = object; // object instead of {} to force non-primitive.\n\n/**\n * A `Tensor` object represents an immutable, multidimensional array of numbers\n * that has a shape and a data type.\n *\n * See `tensor` for details on how to create a `Tensor`.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Tensor {\n private static nextId = 0;\n\n /** Unique id of this tensor. */\n readonly id: number;\n /**\n * Id of the bucket holding the data for this tensor. Multiple arrays can\n * point to the same bucket (e.g. when calling array.reshape()).\n */\n dataId: DataId;\n /** The shape of the tensor. */\n readonly shape: ShapeMap[R];\n /** Number of elements in the tensor. */\n readonly size: number;\n /** The data type for the array. */\n readonly dtype: DataType;\n /** The rank type for the array (see `Rank` enum). */\n readonly rankType: R;\n\n /**\n * Number of elements to skip in each dimension when indexing. See\n * https://docs.scipy.org/doc/numpy/reference/generated/\\\n * numpy.ndarray.strides.html\n */\n readonly strides: number[];\n\n protected constructor(\n shape: ShapeMap[R], dtype: DataType, values?: TypedArray,\n dataId?: DataId) {\n this.size = util.sizeFromShape(shape);\n if (values != null) {\n util.assert(\n this.size === values.length,\n `Constructing tensor of shape (${this.size}) should match the ` +\n `length of values (${values.length})`);\n }\n this.shape = shape.slice();\n this.dtype = dtype || 'float32';\n this.strides = computeStrides(shape);\n this.dataId = dataId != null ? dataId : {};\n this.id = Tensor.nextId++;\n this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher') as R;\n trackerFn().registerTensor(this);\n if (values != null) {\n trackerFn().write(this.dataId, values);\n }\n }\n\n /**\n * Makes a new tensor with the provided shape and values. Values should be in\n * a flat array.\n */\n static make, D extends DataType = 'float32',\n R extends Rank = Rank>(\n shape: ShapeMap[R], data: TensorData, dtype?: D): T {\n return new Tensor(shape, dtype, data.values, data.dataId) as T;\n }\n\n /** Flatten a Tensor to a 1D array. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n flatten(): Tensor1D {\n this.throwIfDisposed();\n return this.as1D();\n }\n\n /** Converts a size-1 `Tensor` to a `Scalar`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asScalar(): Scalar {\n this.throwIfDisposed();\n util.assert(this.size === 1, 'The array must have only 1 element.');\n return this.reshape([]);\n }\n\n /** Converts a `Tensor` to a `Tensor1D`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as1D(): Tensor1D {\n this.throwIfDisposed();\n return this.reshape([this.size]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor2D`.\n *\n * @param rows Number of rows in `Tensor2D`.\n * @param columns Number of columns in `Tensor2D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as2D(rows: number, columns: number): Tensor2D {\n this.throwIfDisposed();\n return this.reshape([rows, columns]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor3D`.\n *\n * @param rows Number of rows in `Tensor3D`.\n * @param columns Number of columns in `Tensor3D`.\n * @param depth Depth of `Tensor3D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as3D(rows: number, columns: number, depth: number): Tensor3D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor4D`.\n *\n * @param rows Number of rows in `Tensor4D`.\n * @param columns Number of columns in `Tensor4D`.\n * @param depth Depth of `Tensor4D`.\n * @param depth2 4th dimension of `Tensor4D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as4D(rows: number, columns: number, depth: number, depth2: number): Tensor4D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth, depth2]);\n }\n\n /**\n * Casts a `Tensor` to a specified dtype.\n *\n * @param dtype Data-type to cast the tensor to.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asType(this: T, dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this, dtype) as T;\n }\n\n get rank(): number {\n return this.shape.length;\n }\n\n /**\n * Returns the value in the tensor at the provided location.\n * If using WebGL backend, this is a blocking call.\n * Prefer calling the `async data()[flatIndex]` method instead.\n *\n * @param locs The location indices.\n */\n get(...locs: number[]) {\n util.assert(\n locs.length === this.rank,\n 'Number of coordinates in get() must match the rank of the tensor');\n this.throwIfDisposed();\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.dataSync()[index];\n }\n\n /** Returns a `TensorBuffer` that holds the underlying data. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n buffer(): TensorBuffer {\n return opHandler.buffer(this.shape, this.dtype, this.dataSync());\n }\n\n /**\n * Asynchronously downloads the values from the `Tensor`. Returns a promise of\n * `TypedArray` that resolves when the computation has finished.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n async data(): Promise {\n this.throwIfDisposed();\n return trackerFn().read(this.dataId);\n }\n\n /**\n * Synchronously downloads the values from the `Tensor`. This blocks the UI\n * thread until the values are ready, which can cause performance issues.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dataSync(): TypedArray {\n this.throwIfDisposed();\n return trackerFn().readSync(this.dataId);\n }\n\n /**\n * Disposes `Tensor` from memory.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n trackerFn().disposeTensor(this);\n this.isDisposedInternal = true;\n }\n\n private isDisposedInternal = false;\n get isDisposed(): boolean {\n return this.isDisposedInternal;\n }\n\n private throwIfDisposed() {\n if (this.isDisposed) {\n throw new Error(`Tensor is disposed.`);\n }\n }\n\n /** Casts the array to type `float32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toFloat(this: T): T {\n return this.asType('float32');\n }\n\n /** Casts the array to type `int32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toInt() {\n return this.asType('int32');\n }\n\n /** Casts the array to type `bool` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toBool() {\n return this.asType('bool');\n }\n\n /**\n * Prints the `Tensor`. See `print` for details.\n *\n * @param verbose Whether to print verbose information about the tensor,\n * including dtype and size.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n print(verbose = false): void {\n return opHandler.print(this, verbose);\n }\n\n /**\n * Reshapes the tensor into the provided shape.\n * See `reshape` for more details.\n *\n * @param newShape An array of integers defining the output tensor shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshape(newShape: ShapeMap[R2]): Tensor {\n this.throwIfDisposed();\n return opHandler.reshape(this, newShape);\n }\n\n /**\n * Reshapes the tensor into the shape of the provided tensor.\n *\n * @param x The tensor of required shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshapeAs(x: T): T {\n this.throwIfDisposed();\n return this.reshape(x.shape) as T;\n }\n\n /**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape. See `expandDims` for details.\n *\n * @param axis The dimension index at which to insert shape of 1. Defaults to\n * 0 (the first dimension).\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n expandDims(axis = 0): Tensor {\n return opHandler.expandDims(this, axis);\n }\n\n /**\n * Returns the cumulative sum of the `Tensor` along `axis`.\n *\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Defaults to\n * false. If set to true then the sum of each tensor entry does not include\n * its own value, but only the values previous to it along the specified\n * axis.\n * @param reverse Whether to sum in the opposite direction. Defaults to\n * false.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n cumsum(axis = 0, exclusive = false, reverse = false): T {\n return opHandler.cumsum(this, axis, exclusive, reverse);\n }\n\n /**\n * Returns a `Tensor` with dimensions of size 1 removed from the shape.\n * See `squeeze` for more details.\n *\n * @param axis A list of numbers. If specified, only squeezes the\n * dimensions listed. The dimension index starts at 0. It is an error to\n * squeeze a dimension that is not 1.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n squeeze(axis?: number[]): T {\n this.throwIfDisposed();\n return opHandler.squeeze(this, axis);\n }\n\n /** Returns a copy of the tensor. See `clone` for details. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n clone(this: T): T {\n this.throwIfDisposed();\n return opHandler.clone(this);\n }\n\n /** Returns a human-readable description of the tensor. Useful for logging. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toString(verbose = false): string {\n const vals = this.dataSync();\n return tensorToString(vals, this.shape, this.dtype, verbose);\n }\n\n // Below is chain API that is not exposed to docs to avoid repetition. To\n // expose a method, move it above this comment and add @doc and jsdoc.\n\n tile(this: T, reps: number[]): T {\n this.throwIfDisposed();\n return opHandler.tile(this, reps) as T;\n }\n\n gather(this: T, indices: Tensor1D, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.gather(this, indices, axis) as T;\n }\n\n matMul(b: Tensor2D, transposeA = false, transposeB = false): Tensor2D {\n this.throwIfDisposed();\n return opHandler.matMul(this as Tensor2D, b, transposeA, transposeB);\n }\n dot(b: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.dot(this, b);\n }\n norm(\n ord: number|'euclidean'|'fro' = 'euclidean', axis: number|number[] = null,\n keepDims = false): Tensor {\n this.throwIfDisposed();\n return opHandler.norm(this, ord, axis, keepDims);\n }\n slice>(\n this: T, begin: number|number[], size?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.slice(this, begin, size);\n }\n reverse(this: T, axis?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.reverse(this, axis);\n }\n concat(this: T, x: T, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.concat([this, x], axis);\n }\n stack(x: Tensor, axis = 0): Tensor {\n return opHandler.stack([this, x], axis);\n }\n unstack(x: Tensor, axis = 0): Tensor[] {\n return opHandler.unstack(this, axis);\n }\n pad(\n this: T, paddings: Array<[number, number]>, constantValue = 0): T {\n return opHandler.pad(this, paddings, constantValue);\n }\n batchNormalization(\n mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon = .001, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor {\n this.throwIfDisposed();\n return opHandler.batchNormalization(\n this, mean, variance, varianceEpsilon, scale, offset);\n }\n\n // Reduction ops.\n all(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.all(this, axis, keepDims);\n }\n any(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.any(this, axis, keepDims);\n }\n logSumExp(axis: number|number[] = null, keepDims = false):\n T {\n this.throwIfDisposed();\n return opHandler.logSumExp(this, axis, keepDims);\n }\n sum(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.sum(this, axis, keepDims);\n }\n mean(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.mean(this, axis, keepDims);\n }\n min(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.min(this, axis, keepDims);\n }\n max(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.max(this, axis, keepDims);\n }\n argMin(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMin(this, axis);\n }\n argMax(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMax(this, axis);\n }\n\n // Transformations\n cast(dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this as T, dtype) as T;\n }\n\n // Binary ops.\n\n add(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.add(this, x);\n }\n addStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.addStrict(this, x) as T;\n }\n sub(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.sub(this, x);\n }\n subStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.subStrict(this, x) as T;\n }\n pow(this: T, exp: Tensor): T {\n this.throwIfDisposed();\n return opHandler.pow(this, exp);\n }\n powStrict(exp: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.powStrict(this, exp);\n }\n mul(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mul(this, x);\n }\n mulStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.mulStrict(this, x) as T;\n }\n div(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.div(this, x);\n }\n floorDiv(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.floorDiv(this, x);\n }\n divStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.divStrict(this, x) as T;\n }\n minimum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.minimum(this, x);\n }\n minimumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.minimumStrict(this, x) as T;\n }\n maximum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.maximum(this, x);\n }\n maximumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.maximumStrict(this, x) as T;\n }\n mod(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mod(this, x);\n }\n modStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.modStrict(this, x) as T;\n }\n squaredDifference(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.squaredDifference(this, x);\n }\n squaredDifferenceStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.squaredDifferenceStrict(this, x) as T;\n }\n transpose(this: T, perm?: number[]): T {\n this.throwIfDisposed();\n return opHandler.transpose(this, perm);\n }\n\n // Compare ops.\n\n notEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.notEqual(this, x);\n }\n notEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.notEqualStrict(this, x) as T;\n }\n less(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.less(this, x);\n }\n lessStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessStrict(this, x) as T;\n }\n equal(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.equal(this, x);\n }\n equalStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.equalStrict(this, x) as T;\n }\n lessEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.lessEqual(this, x);\n }\n lessEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessEqualStrict(this, x) as T;\n }\n greater(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greater(this, x);\n }\n greaterStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterStrict(this, x) as T;\n }\n greaterEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greaterEqual(this, x);\n }\n greaterEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterEqualStrict(this, x) as T;\n }\n\n // Compare ops.\n logicalAnd(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalAnd(this, x);\n }\n logicalOr(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalOr(this, x);\n }\n logicalNot(this: T): T {\n this.throwIfDisposed();\n return opHandler.logicalNot(this);\n }\n logicalXor(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalXor(this, x);\n }\n where(condition: Tensor, x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.where(condition, this, x);\n }\n\n // Unary ops.\n neg(this: T): T {\n this.throwIfDisposed();\n return opHandler.neg(this);\n }\n ceil(this: T): T {\n this.throwIfDisposed();\n return opHandler.ceil(this);\n }\n floor(this: T): T {\n this.throwIfDisposed();\n return opHandler.floor(this);\n }\n sign(this: T): T {\n this.throwIfDisposed();\n return opHandler.sign(this);\n }\n exp(this: T): T {\n this.throwIfDisposed();\n return opHandler.exp(this);\n }\n expm1(this: T): T {\n this.throwIfDisposed();\n return opHandler.expm1(this);\n }\n log(this: T): T {\n this.throwIfDisposed();\n return opHandler.log(this);\n }\n log1p(this: T): T {\n this.throwIfDisposed();\n return opHandler.log1p(this);\n }\n sqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.sqrt(this);\n }\n rsqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.rsqrt(this);\n }\n square(this: T): T {\n this.throwIfDisposed();\n return opHandler.square(this);\n }\n reciprocal(this: T): T {\n this.throwIfDisposed();\n return opHandler.reciprocal(this);\n }\n abs(this: T): T {\n this.throwIfDisposed();\n return opHandler.abs(this);\n }\n clipByValue(min: number, max: number): Tensor {\n this.throwIfDisposed();\n return opHandler.clipByValue(this, min, max);\n }\n relu(this: T): T {\n this.throwIfDisposed();\n return opHandler.relu(this);\n }\n elu(this: T): T {\n this.throwIfDisposed();\n return opHandler.elu(this);\n }\n selu(this: T): T {\n this.throwIfDisposed();\n return opHandler.selu(this);\n }\n leakyRelu(alpha = 0.2): Tensor {\n this.throwIfDisposed();\n return opHandler.leakyRelu(this, alpha);\n }\n prelu(alpha: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.prelu(this, alpha);\n }\n sigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.sigmoid(this);\n }\n logSigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.logSigmoid(this);\n }\n softplus(this: T): T {\n this.throwIfDisposed();\n return opHandler.softplus(this);\n }\n sin(this: T): T {\n this.throwIfDisposed();\n return opHandler.sin(this);\n }\n cos(this: T): T {\n this.throwIfDisposed();\n return opHandler.cos(this);\n }\n tan(this: T): T {\n this.throwIfDisposed();\n return opHandler.tan(this);\n }\n asin(this: T): T {\n this.throwIfDisposed();\n return opHandler.asin(this);\n }\n acos(this: T): T {\n this.throwIfDisposed();\n return opHandler.acos(this);\n }\n atan(this: T): T {\n this.throwIfDisposed();\n return opHandler.atan(this);\n }\n sinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.sinh(this);\n }\n cosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.cosh(this);\n }\n tanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.tanh(this);\n }\n asinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.asinh(this);\n }\n acosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.acosh(this);\n }\n atanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.atanh(this);\n }\n erf(this: T): T {\n this.throwIfDisposed();\n return opHandler.erf(this);\n }\n round(this: T): T {\n this.throwIfDisposed();\n return opHandler.round(this);\n }\n step(this: T, alpha = 0.0): T {\n this.throwIfDisposed();\n return opHandler.step(this, alpha);\n }\n softmax(this: T, dim = -1): T {\n this.throwIfDisposed();\n return opHandler.softmax(this, dim) as T;\n }\n\n // Image ops.\n resizeBilinear(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeBilinear(this, newShape2D, alignCorners);\n }\n\n resizeNearestNeighbor(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeNearestNeighbor(\n this, newShape2D, alignCorners);\n }\n\n // Convolutions.\n conv1d(\n this: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv1d(\n this, filter, stride, pad, dataFormat, dilation, dimRoundingMode);\n }\n conv2d(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n conv2dTranspose(\n this: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2dTranspose(\n this, filter, outputShape, strides, pad, dimRoundingMode);\n }\n depthwiseConv2D(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.depthwiseConv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n\n // Pooling.\n avgPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.avgPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n maxPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.maxPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n localResponseNormalization(\n this: T, radius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n return opHandler.localResponseNormalization(\n this, radius, bias, alpha, beta);\n }\n\n variable(trainable = true, name?: string, dtype?: DataType): Variable {\n this.throwIfDisposed();\n return Variable.variable(this, trainable, name, dtype);\n }\n\n unsortedSegmentSum(\n this: T, segmentIds: Tensor1D, numSegments: number): T {\n this.throwIfDisposed();\n return opHandler.unsortedSegmentSum(this, segmentIds, numSegments);\n }\n\n batchToSpaceND(\n this: T, blockShape: number[], crops: number[][]): T {\n this.throwIfDisposed();\n return opHandler.batchToSpaceND(this, blockShape, crops);\n }\n\n spaceToBatchND(\n this: T, blockShape: number[], paddings: number[][]): T {\n this.throwIfDisposed();\n return opHandler.spaceToBatchND(this, blockShape, paddings);\n }\n}\nObject.defineProperty(Tensor, Symbol.hasInstance, {\n value: (instance: Tensor) => {\n return !!instance && instance.shape != null && instance.dtype != null;\n }\n});\n\n/** @doclink Tensor */\nexport type Scalar = Tensor;\n/** @doclink Tensor */\nexport type Tensor1D = Tensor;\n/** @doclink Tensor */\nexport type Tensor2D = Tensor;\n/** @doclink Tensor */\nexport type Tensor3D = Tensor;\n/** @doclink Tensor */\nexport type Tensor4D = Tensor;\n/** @doclink Tensor */\nexport type Tensor5D = Tensor;\n/** @doclink Tensor */\nexport type Tensor6D = Tensor;\n\n/**\n * A mutable `Tensor`, useful for persisting state, e.g. for training.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Variable extends Tensor {\n private static nextVarId = 0;\n name: string;\n\n /**\n * Private constructor since we can not add logic before calling `super()`.\n * Instead, we expose static `Variable.variable` method below, which will be\n * added to global namespace.\n */\n private constructor(\n initialValue: Tensor, public trainable = true, name?: string) {\n super(\n initialValue.shape, initialValue.dtype, null /* values */,\n initialValue.dataId);\n this.name = name;\n if (this.name == null) {\n this.name = Variable.nextVarId.toString();\n Variable.nextVarId++;\n }\n try {\n trackerFn().registerVariable(this);\n } catch (ex) {\n trackerFn().disposeTensor(this);\n throw ex;\n }\n }\n\n /**\n * Creates a new variable with the provided initial value.\n * ```js\n * const x = tf.variable(tf.tensor([1, 2, 3]));\n * x.assign(tf.tensor([4, 5, 6]));\n *\n * x.print();\n * ```\n *\n * @param initialValue Initial value for the tensor.\n * @param trainable If true, optimizers are allowed to update it.\n * @param name Name of the variable. Defaults to a unique id.\n * @param dtype If set, initialValue will be converted to the given type.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n static variable(\n initialValue: Tensor, trainable = true, name?: string,\n dtype?: DataType): Variable {\n if (dtype != null && dtype !== initialValue.dtype) {\n initialValue = initialValue.asType(dtype) as Tensor;\n }\n return new Variable(initialValue, trainable, name);\n }\n\n /**\n * Assign a new `Tensor` to this variable. The new `Tensor` must have the\n * same shape and dtype as the old `Tensor`.\n *\n * @param newValue New tensor to be assigned to this variable.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n assign(newValue: Tensor): void {\n if (newValue.dtype !== this.dtype) {\n throw new Error(\n `dtype of the new value (${newValue.dtype}) and ` +\n `previous value (${this.dtype}) must match`);\n }\n if (!util.arraysEqual(newValue.shape, this.shape)) {\n throw new Error(\n `shape of the new value (${newValue.shape}) and ` +\n `previous value (${this.shape}) must match`);\n }\n trackerFn().disposeTensor(this);\n this.dataId = newValue.dataId;\n trackerFn().registerTensor(this);\n }\n}\nObject.defineProperty(Variable, Symbol.hasInstance, {\n value: (instance: Variable) => {\n return instance instanceof Tensor && instance.assign != null &&\n instance.assign instanceof Function;\n }\n});\n\nconst variable = Variable.variable;\nexport {variable};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap, TensorContainer, TensorContainerArray} from './tensor_types';\nimport {assert} from './util';\n\nexport function assertTypesMatch(a: Tensor, b: Tensor): void {\n assert(\n a.dtype === b.dtype,\n ` The dtypes of the first(${a.dtype}) and` +\n ` second(${b.dtype}) input must match`);\n}\n\nexport function isTensorInList(tensor: Tensor, tensorList: Tensor[]): boolean {\n for (let i = 0; i < tensorList.length; i++) {\n if (tensorList[i].id === tensor.id) {\n return true;\n }\n }\n return false;\n}\n\nexport function flattenNameArrayMap(\n nameArrayMap: Tensor|NamedTensorMap, keys?: string[]): Tensor[] {\n const xs: Tensor[] = [];\n if (nameArrayMap instanceof Tensor) {\n xs.push(nameArrayMap);\n } else {\n const xMap = nameArrayMap as {[xName: string]: Tensor};\n for (let i = 0; i < keys.length; i++) {\n xs.push(xMap[keys[i]]);\n }\n }\n return xs;\n}\n\nexport function unflattenToNameArrayMap(\n keys: string[], flatArrays: Tensor[]): NamedTensorMap {\n if (keys.length !== flatArrays.length) {\n throw new Error(\n `Cannot unflatten Tensor[], keys and arrays are not of same length.`);\n }\n const result: NamedTensorMap = {};\n for (let i = 0; i < keys.length; i++) {\n result[keys[i]] = flatArrays[i];\n }\n return result;\n}\n\n/**\n * Extracts any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. In general it\n * is safe to pass any object here, except that `Promise`s are not\n * supported.\n * @returns An array of `Tensors` found within the passed object. If the\n * argument is simply a `Tensor', a list containing that `Tensor` is\n * returned. If the object is not a `Tensor` or does not\n * contain `Tensors`, an empty list is returned.\n */\nexport function getTensorsInContainer(result: TensorContainer): Tensor[] {\n const list: Tensor[] = [];\n const seen = new Set<{}|void>();\n walkTensorContainer(result, list, seen);\n return list;\n}\n\nfunction walkTensorContainer(\n container: TensorContainer, list: Tensor[], seen: Set<{}|void>): void {\n if (container == null) {\n return;\n }\n if (container instanceof Tensor) {\n list.push(container);\n return;\n }\n if (!isIterable(container)) {\n return;\n }\n // Iteration over keys works also for arrays.\n const iterable = container as TensorContainerArray;\n for (const k in iterable) {\n const val = iterable[k];\n if (!seen.has(val)) {\n seen.add(val);\n walkTensorContainer(val, list, seen);\n }\n }\n}\n\n// tslint:disable-next-line:no-any\nfunction isIterable(obj: any): boolean {\n return Array.isArray(obj) || typeof obj === 'object';\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimingInfo, KernelBackend} from './kernels/backend';\nimport {Profiler} from './profiler';\nimport {backpropagateGradients, getFilteredNodesXToY, NamedGradientMap, TapeNode} from './tape';\nimport {DataId, Tensor, Tensor3D, Variable} from './tensor';\nimport {NamedTensorMap, NamedVariableMap, TensorContainer} from './tensor_types';\nimport {getTensorsInContainer, isTensorInList} from './tensor_util';\nimport {TypedArray} from './types';\nimport * as util from './util';\nimport {makeOnesTypedArray, now, sizeFromShape} from './util';\n\n/**\n * A function that computes an output. The save function is for saving tensors\n * computed in the forward pass, that we need in the backwards pass.\n */\nexport type ForwardFunc =\n (backend: KernelBackend, save?: (tensor: S) => S) => T;\n\n/**\n * @docalias (a: Tensor, b: Tensor,...) => {\n * value: Tensor, * gradFunc: (dy: Tensor) => Tensor | Tensor[] * }\n */\nexport type CustomGradientFunc = (...args: Tensor[]) => {\n value: T, gradFunc: (dy: T) => Tensor | Tensor[];\n};\n\nexport type MemoryInfo = {\n numTensors: number; numDataBuffers: number; numBytes: number;\n unreliable?: boolean;\n};\n\nexport interface TimingInfo extends BackendTimingInfo {\n wallMs: number;\n}\n\n/** @docalias Function */\nexport type ScopeFn = () => T;\n\nexport interface TensorManager {\n registerTensor(a: Tensor): void;\n registerVariable(v: Variable): void;\n disposeTensor(a: Tensor): void;\n memory(): {numDataBuffers: number; numBytes: number;};\n}\n\ninterface ScopeState {\n track: Tensor[];\n name: string;\n}\n\nexport class Engine implements TensorManager {\n // Public since optimizers will use it.\n registeredVariables: NamedVariableMap = {};\n\n private refCounter = new WeakMap();\n private nextTapeNodeId = 0;\n private numBytes = 0;\n private numTensors = 0;\n private numDataBuffers = 0;\n\n private activeTape: TapeNode[];\n private gradientScopeCount = 0;\n private customGradientDepth = 0;\n\n // Keep Tensors that parallel the tapes.\n private activeScope: ScopeState;\n private scopeStack: ScopeState[];\n private keepTensors: Set = new Set();\n private profiler: Profiler;\n\n constructor(\n private backend: KernelBackend, public safeMode: boolean,\n private debugMode: () => boolean) {\n // Create a default outer scope.\n this.activeScope = {track: [], name: 'default scope'};\n this.scopeStack = [this.activeScope];\n this.profiler = new Profiler(backend);\n }\n\n tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n // gradMode Primarily for internal use during backprop\n // If true, will start a tape if it is the outermost tidy.\n\n let name: string = null;\n if (fn == null) {\n // Called with only 1 argument.\n if (typeof nameOrFn !== 'function') {\n throw new Error('Please provide a function to tidy()');\n }\n fn = nameOrFn;\n } else {\n // Called with 2 arguments.\n if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) {\n throw new Error(\n 'When calling with two arguments, the first argument ' +\n 'to tidy() must be a string');\n }\n if (typeof fn !== 'function') {\n throw new Error(\n 'When calling with two arguments, the 2nd argument ' +\n 'to tidy() must be a function');\n }\n name = nameOrFn as string;\n // TODO(nsthorat,smilkov): Do operation logging and performance\n // profiling.\n }\n let result: T;\n return this.scopedRun(\n () => this.startScope(name, gradMode),\n () => this.endScope(result, gradMode), () => {\n result = fn();\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n return result;\n });\n }\n\n private scopedRun(start: () => void, end: () => void, f: () => T): T {\n start();\n try {\n const res = f();\n end();\n return res;\n } catch (ex) {\n end();\n throw ex;\n }\n }\n\n runKernel(\n forwardFunc: ForwardFunc,\n inputs: I,\n backwardsFunc?: (dy: T, saved: Tensor[]) => {[P in keyof I]: () => I[P]},\n ): T {\n let result: T;\n const saved: Tensor[] = [];\n const saveFunc = (x: T): T => {\n saved.push(x);\n return x;\n };\n const scopeName = this.activeScope.name;\n\n // Stop recording to a tape when running a kernel.\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n if (!this.debugMode()) {\n result = forwardFunc(this.backend, saveFunc);\n } else {\n result = this.profiler.profileKernel(\n scopeName, () => forwardFunc(this.backend, saveFunc));\n }\n });\n\n if (this.shouldRecord()) {\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: scopeName,\n inputs,\n // Keep gradient records only for the first output.\n output: Array.isArray(result) ? result[0] : result\n };\n if (backwardsFunc != null) {\n tapeNode.gradient =\n ((dy: T) => backwardsFunc(dy, saved)) as (dy: Tensor) =>\n NamedGradientMap;\n }\n this.activeTape.push(tapeNode);\n }\n return result;\n }\n\n // TensorManager implementation.\n\n registerTensor(a: Tensor|Variable): void {\n const refCount =\n this.refCounter.has(a.dataId) ? this.refCounter.get(a.dataId) : 0;\n this.numTensors++;\n if (refCount === 0) {\n this.numDataBuffers++;\n this.numBytes +=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n this.backend.register(a.dataId, a.shape, a.dtype);\n }\n this.refCounter.set(a.dataId, refCount + 1);\n if (!(a instanceof Variable)) {\n this.track(a);\n }\n }\n\n registerVariable(v: Variable) {\n if (this.registeredVariables[v.name] != null) {\n throw new Error(`Variable with name ${v.name} was already registered`);\n }\n this.registeredVariables[v.name] = v;\n }\n\n disposeTensor(a: Tensor): void {\n if (!this.refCounter.has(a.dataId)) {\n return;\n }\n if (this.keepTensors.has(a.id)) {\n this.keepTensors.delete(a.id);\n }\n this.numTensors--;\n const refCount = this.refCounter.get(a.dataId);\n if (refCount <= 1) {\n this.refCounter.delete(a.dataId);\n this.backend.disposeData(a.dataId);\n this.numDataBuffers--;\n this.numBytes -=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n } else {\n this.refCounter.set(a.dataId, refCount - 1);\n }\n // TODO(nsthorat): Construct an error and save the stack trace for\n // debugging when in debug mode. Creating a stack trace is too expensive\n // to do unconditionally.\n }\n\n disposeVariables(): void {\n for (const varName in this.registeredVariables) {\n const v = this.registeredVariables[varName];\n this.disposeTensor(v);\n delete this.registeredVariables[varName];\n }\n }\n\n memory(): MemoryInfo {\n const info = this.backend.memory() as MemoryInfo;\n info.numTensors = this.numTensors;\n info.numDataBuffers = this.numDataBuffers;\n info.numBytes = this.numBytes;\n return info;\n }\n\n private shouldRecord(): boolean {\n return this.activeTape != null && this.customGradientDepth === 0;\n }\n\n private addTapeNode(\n inputs: Tensor[], result: Tensor,\n gradientsFunc: (dy: Tensor) => Tensor[]): void {\n const inputsMap: NamedTensorMap = {};\n inputs.forEach((input, idx) => {\n inputsMap[idx] = input;\n });\n\n const gradient = (dy: Tensor) => {\n const res = gradientsFunc(dy);\n const resMap: NamedGradientMap = {};\n res.forEach((r, idx) => {\n resMap[idx] = () => r;\n });\n return resMap;\n };\n\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: this.activeScope.name,\n inputs: inputsMap,\n output: result,\n gradient\n };\n this.activeTape.push(tapeNode);\n }\n\n keep(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {...}) to avoid memory leaks.');\n }\n this.keepTensors.add(result.id);\n return result;\n }\n\n /**\n * Start a scope. Use this with endScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n startScope(name?: string, gradientsMode = false) {\n if (gradientsMode && this.gradientScopeCount === 0) {\n this.activeTape = [];\n }\n if (gradientsMode) {\n this.gradientScopeCount++;\n }\n\n const scopeInfo: ScopeState = {track: [], name: 'unnamed scope'};\n if (name) {\n scopeInfo.name = name;\n }\n this.scopeStack.push(scopeInfo);\n this.activeScope = scopeInfo;\n }\n\n /**\n * End a scope. Use this with startScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n endScope(result?: TensorContainer, gradientsMode = false) {\n if (gradientsMode) {\n this.gradientScopeCount--;\n if (this.gradientScopeCount === 0) {\n this.activeTape = null;\n }\n }\n\n const tensorsToKeep = new Set(this.keepTensors);\n\n const tensorsToTrackInParent = getTensorsInContainer(result);\n tensorsToTrackInParent.forEach(tensor => tensorsToKeep.add(tensor.id));\n\n // Dispose the arrays tracked in this scope.\n for (let i = 0; i < this.activeScope.track.length; i++) {\n const tensor = this.activeScope.track[i];\n if (tensorsToKeep.has(tensor.id)) {\n continue;\n }\n\n if (this.activeTape != null) {\n tensorsToTrackInParent.push(tensor);\n } else {\n tensor.dispose();\n }\n }\n\n const oldScope = this.scopeStack.pop();\n this.activeScope = this.scopeStack.length === 0 ?\n {track: [], name: 'default scope'} :\n this.scopeStack[this.scopeStack.length - 1];\n\n // Track the current result in the parent scope.\n tensorsToTrackInParent.forEach(tensor => {\n // Only track the tensor if was allocated in the inner scope and is not\n // globally kept.\n if (!this.keepTensors.has(tensor.id) &&\n isTensorInList(tensor, oldScope.track)) {\n this.track(tensor);\n }\n });\n }\n\n /**\n * Returns gradients of `f` with respect to each of the `xs`. The gradients\n * returned are of the same length as `xs`, but some might be null if `f` was\n * not a function of that `x`. It also takes optional dy to multiply the\n * gradient, which defaults to `1`.\n */\n gradients(\n f: () => T, xs: Tensor[], dy?: T,\n allowNoGradients = false): {value: T, grads: Tensor[]} {\n util.assert(xs.length > 0, 'gradients() received an empty list of xs.');\n\n return this.tidy('gradients', () => {\n const y = f();\n util.assert(\n y instanceof Tensor,\n 'The result y returned by f() must be a tensor.');\n // Filter out the nodes that don't connect x => y.\n const filteredTape = getFilteredNodesXToY(this.activeTape, xs, y);\n if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) {\n throw new Error(\n 'Cannot compute gradient of y=f(x) with respect to x. Make sure ' +\n 'that the f you passed encloses all operations that lead from x ' +\n 'to y.');\n }\n\n const accumulatedGradientMap: {[tensorId: number]: Tensor} = {};\n accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy;\n\n // Backprop gradients through the filtered nodes.\n backpropagateGradients(accumulatedGradientMap, filteredTape);\n\n const grads = xs.map(x => accumulatedGradientMap[x.id]);\n return {value: y, grads};\n }, true /* gradientsMode */);\n }\n\n customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n util.assert(\n util.isFunction(f),\n 'The f passed in customGrad(f) must be a function.');\n return (...inputs: Tensor[]): T => {\n util.assert(\n inputs.every(t => t instanceof Tensor),\n 'The args passed in customGrad(f)(x1, x2,...) must all be tensors');\n\n let gradientsFunc: (dy: T) => Tensor | Tensor[];\n let result: T;\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n const gradientsMode = true;\n result = this.tidy(f.name, () => {\n const {value, gradFunc} = f(...inputs);\n util.assert(\n value instanceof Tensor,\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.value` is a tensor');\n util.assert(\n util.isFunction(gradFunc),\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function.');\n gradientsFunc = gradFunc;\n return value;\n }, gradientsMode);\n });\n\n if (this.shouldRecord()) {\n const gradFunc = (dy: T): Tensor[] => {\n const res = gradientsFunc(dy);\n const grads: Tensor[] = Array.isArray(res) ? res : [res];\n util.assert(\n grads.length === inputs.length,\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns the same ' +\n 'number of tensors as inputs passed to f(...).');\n util.assert(\n grads.every(t => t instanceof Tensor),\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns a list of ' +\n 'only tensors.');\n return grads;\n };\n this.addTapeNode(inputs, result, gradFunc);\n }\n return result;\n };\n }\n\n // Forwarding to backend.\n write(dataId: DataId, values: TypedArray): void {\n this.backend.write(dataId, values);\n }\n readSync(dataId: DataId): TypedArray {\n return this.backend.readSync(dataId);\n }\n read(dataId: DataId): Promise {\n return this.backend.read(dataId);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n return this.backend.fromPixels(pixels, numChannels);\n }\n async time(query: () => void): Promise {\n const start = now();\n const timingInfo = await this.backend.time(query) as TimingInfo;\n timingInfo.wallMs = now() - start;\n return timingInfo;\n }\n\n /**\n * Tracks a Tensor in the current scope to be automatically cleaned up\n * when the current scope ends, and returns the value.\n *\n * @param result The Tensor to track in the current scope.\n */\n private track(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {op();...}); to avoid memory leaks.');\n }\n this.activeScope.track.push(result);\n return result;\n }\n}\n\nfunction ones(shape: number[]): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), 'float32');\n return Tensor.make(shape, {values});\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport interface Features {\n // Whether to enable debug mode.\n 'DEBUG'?: boolean;\n // Whether we are in a browser (as versus, say, node.js) environment.\n 'IS_BROWSER'?: boolean;\n // Whether we are in the Node.js environment.\n 'IS_NODE'?: boolean;\n // The disjoint_query_timer extension version.\n // 0: disabled, 1: EXT_disjoint_timer_query, 2:\n // EXT_disjoint_timer_query_webgl2.\n // In Firefox with WebGL 2.0,\n // EXT_disjoint_timer_query_webgl2 is not available, so we must use the\n // WebGL 1.0 extension.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'?: number;\n // Whether the timer object from the disjoint_query_timer extension gives\n // timing information that is reliable.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE'?: boolean;\n // 0: No WebGL, 1: WebGL 1.0, 2: WebGL 2.0.\n 'WEBGL_VERSION'?: number;\n // True if WebGL is supported.\n 'HAS_WEBGL'?: boolean;\n // Whether rendering to float32 textures is enabled. If disabled, renders to\n // float16 textures.\n 'WEBGL_RENDER_FLOAT32_ENABLED'?: boolean;\n // Whether downloading float textures is enabled. If disabled, uses IEEE 754\n // encoding of the float32 values to 4 uint8 when downloading.\n 'WEBGL_DOWNLOAD_FLOAT_ENABLED'?: boolean;\n // Whether the fence API is available.\n 'WEBGL_FENCE_API_ENABLED'?: boolean;\n 'BACKEND'?: string;\n // Test precision for unit tests. This is decreased when we can't render\n // float32 textures.\n 'TEST_EPSILON'?: number;\n 'IS_CHROME'?: boolean;\n // True if running unit tests.\n 'IS_TEST'?: boolean;\n}\n\nexport enum Type {\n NUMBER,\n BOOLEAN,\n STRING\n}\n\nexport const URL_PROPERTIES: URLProperty[] = [\n {name: 'DEBUG', type: Type.BOOLEAN}, {name: 'IS_BROWSER', type: Type.BOOLEAN},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', type: Type.BOOLEAN},\n {name: 'WEBGL_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_RENDER_FLOAT32_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_DOWNLOAD_FLOAT_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_FENCE_API_ENABLED', type: Type.BOOLEAN},\n {name: 'BACKEND', type: Type.STRING}\n];\n\nexport interface URLProperty {\n name: keyof Features;\n type: Type;\n}\n\nexport function isWebGLVersionEnabled(webGLVersion: 1|2, isBrowser: boolean) {\n let gl;\n try {\n gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n } catch (e) {\n return false;\n }\n\n if (gl != null) {\n loseContext(gl);\n return true;\n }\n return false;\n}\n\nexport function getWebGLDisjointQueryTimerVersion(\n webGLVersion: number, isBrowser: boolean): number {\n if (webGLVersion === 0) {\n return 0;\n }\n\n let queryTimerVersion: number;\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (hasExtension(gl, 'EXT_disjoint_timer_query_webgl2') &&\n webGLVersion === 2) {\n queryTimerVersion = 2;\n } else if (hasExtension(gl, 'EXT_disjoint_timer_query')) {\n queryTimerVersion = 1;\n } else {\n queryTimerVersion = 0;\n }\n\n if (gl != null) {\n loseContext(gl);\n }\n return queryTimerVersion;\n}\n\nexport function isRenderToFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n\n const isFrameBufferComplete =\n gl.checkFramebufferStatus(gl.FRAMEBUFFER) === gl.FRAMEBUFFER_COMPLETE;\n\n loseContext(gl);\n return isFrameBufferComplete;\n}\n\nexport function isDownloadFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.FLOAT, new Float32Array(4));\n\n const readPixelsNoError = gl.getError() === gl.NO_ERROR;\n\n loseContext(gl);\n\n return readPixelsNoError;\n}\n\nexport function isWebGLFenceEnabled(webGLVersion: number, isBrowser: boolean) {\n if (webGLVersion !== 2) {\n return false;\n }\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n // tslint:disable-next-line:no-any\n const isEnabled = (gl as any).fenceSync != null;\n loseContext(gl);\n return isEnabled;\n}\n\nexport function isChrome() {\n return typeof navigator !== 'undefined' && navigator != null &&\n navigator.userAgent != null && /Chrome/.test(navigator.userAgent) &&\n /Google Inc/.test(navigator.vendor);\n}\n\n// Expects flags from URL in the format ?tfjsflags=FLAG1:1,FLAG2:true.\nconst TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags';\nexport function getFeaturesFromURL(): Features {\n const features: Features = {};\n\n if (typeof window === 'undefined' || typeof window.location === 'undefined') {\n return features;\n }\n\n const urlParams = getQueryParams(window.location.search);\n if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) {\n const urlFlags: {[key: string]: string} = {};\n\n const keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(',');\n keyValues.forEach(keyValue => {\n const [key, value] = keyValue.split(':') as [string, string];\n urlFlags[key] = value;\n });\n\n URL_PROPERTIES.forEach(urlProperty => {\n if (urlProperty.name in urlFlags) {\n console.log(\n `Setting feature override from URL ${urlProperty.name}: ` +\n `${urlFlags[urlProperty.name]}`);\n if (urlProperty.type === Type.NUMBER) {\n features[urlProperty.name] = +urlFlags[urlProperty.name];\n } else if (urlProperty.type === Type.BOOLEAN) {\n features[urlProperty.name] = urlFlags[urlProperty.name] === 'true';\n } else if (urlProperty.type === Type.STRING) {\n // tslint:disable-next-line:no-any\n features[urlProperty.name] = urlFlags[urlProperty.name] as any;\n } else {\n console.warn(`Unknown URL param: ${urlProperty.name}.`);\n }\n }\n });\n }\n\n return features;\n}\n\nfunction hasExtension(gl: WebGLRenderingContext, extensionName: string) {\n const ext = gl.getExtension(extensionName);\n return ext != null;\n}\n\nfunction getWebGLRenderingContext(\n webGLVersion: number, isBrowser: boolean): WebGLRenderingContext {\n if (webGLVersion === 0 || !isBrowser) {\n throw new Error('Cannot get WebGL rendering context, WebGL is disabled.');\n }\n\n const tempCanvas = document.createElement('canvas');\n\n if (webGLVersion === 1) {\n return (tempCanvas.getContext('webgl') ||\n tempCanvas.getContext('experimental-webgl')) as\n WebGLRenderingContext;\n }\n return tempCanvas.getContext('webgl2') as WebGLRenderingContext;\n}\n\nfunction loseContext(gl: WebGLRenderingContext) {\n if (gl != null) {\n const loseContextExtension = gl.getExtension('WEBGL_lose_context');\n if (loseContextExtension == null) {\n throw new Error(\n 'Extension WEBGL_lose_context not supported on this browser.');\n }\n loseContextExtension.loseContext();\n }\n}\n\nfunction createFloatTextureAndBindToFramebuffer(\n gl: WebGLRenderingContext, webGLVersion: number) {\n const frameBuffer = gl.createFramebuffer();\n const texture = gl.createTexture();\n\n gl.bindTexture(gl.TEXTURE_2D, texture);\n\n // tslint:disable-next-line:no-any\n const internalFormat = webGLVersion === 2 ? (gl as any).RGBA32F : gl.RGBA;\n gl.texImage2D(\n gl.TEXTURE_2D, 0, internalFormat, 1, 1, 0, gl.RGBA, gl.FLOAT, null);\n\n gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer);\n gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n}\n\nexport function getQueryParams(queryString: string): {[key: string]: string} {\n const params = {};\n queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (s, ...t) => {\n decodeParam(params, t[0], t[1]);\n return t.join('=');\n });\n return params;\n}\n\nfunction decodeParam(\n params: {[key: string]: string}, name: string, value?: string) {\n params[decodeURIComponent(name)] = decodeURIComponent(value || '');\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as device_util from './device_util';\nimport {Engine, MemoryInfo, ScopeFn, TimingInfo} from './engine';\nimport {Features, getFeaturesFromURL, getWebGLDisjointQueryTimerVersion, isChrome, isDownloadFloatTextureEnabled, isRenderToFloatTextureEnabled, isWebGLFenceEnabled, isWebGLVersionEnabled} from './environment_util';\nimport {KernelBackend} from './kernels/backend';\nimport {setTensorTracker, Tensor, TensorTracker} from './tensor';\nimport {TensorContainer} from './tensor_types';\nimport {getTensorsInContainer} from './tensor_util';\n\nconst TEST_EPSILON_FLOAT32_ENABLED = 1e-3;\nconst TEST_EPSILON_FLOAT32_DISABLED = 1e-1;\n\nexport class Environment {\n private features: Features = {};\n private globalEngine: Engine;\n private registry:\n {[id: string]: {backend: KernelBackend, priority: number}} = {};\n backendName: string;\n backend: KernelBackend;\n\n constructor(features?: Features) {\n if (features != null) {\n this.features = features;\n }\n\n if (this.get('DEBUG')) {\n console.warn(\n 'Debugging mode is ON. The output of every math call will ' +\n 'be downloaded to CPU and checked for NaNs. ' +\n 'This significantly impacts performance.');\n }\n }\n\n /**\n * Sets the backend (cpu, webgl, etc) responsible for creating tensors and\n * executing operations on those tensors.\n *\n * Note this disposes the current backend, if any, as well as any tensors\n * associated with it. A new backend is initialized, even if it is of the\n * same type as the previous one.\n *\n * @param backendName The name of the backend. Currently supports\n * `'webgl'|'cpu'` in the browser, and `'tensorflow'` under node.js\n * (requires tfjs-node).\n * @param safeMode Defaults to false. In safe mode, you are forced to\n * construct tensors and call math operations inside a `tidy()` which\n * will automatically clean up intermediate tensors.\n */\n /** @doc {heading: 'Environment'} */\n static setBackend(backendName: string, safeMode = false) {\n if (!(backendName in ENV.registry)) {\n throw new Error(`Backend name '${backendName}' not found in registry`);\n }\n ENV.initBackend(backendName, safeMode);\n }\n\n /**\n * Returns the current backend name (cpu, webgl, etc). The backend is\n * responsible for creating tensors and executing operations on those tensors.\n */\n /** @doc {heading: 'Environment'} */\n static getBackend(): string {\n ENV.initDefaultBackend();\n return ENV.backendName;\n }\n\n /**\n * Dispose all variables kept in backend engine.\n */\n /** @doc {heading: 'Environment'} */\n static disposeVariables(): void {\n ENV.engine.disposeVariables();\n }\n\n /**\n * Returns memory info at the current time in the program. The result is an\n * object with the following properties:\n *\n * - `numBytes`: Number of bytes allocated (undisposed) at this time.\n * - `numTensors`: Number of unique tensors allocated.\n * - `numDataBuffers`: Number of unique data buffers allocated\n * (undisposed) at this time, which is ≤ the number of tensors\n * (e.g. `a.reshape(newShape)` makes a new Tensor that shares the same\n * data buffer with `a`).\n * - `unreliable`: `Optional` `boolean`:\n * - On WebGL, not present (always reliable).\n * - On CPU, true. Due to automatic garbage collection, these numbers\n * represent undisposed tensors, i.e. not wrapped in `tidy()`, or\n * lacking a call to `tensor.dispose()`.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static memory(): MemoryInfo {\n return ENV.engine.memory();\n }\n\n /**\n * Executes the provided function `fn` and after it is executed, cleans up all\n * intermediate tensors allocated by `fn` except those returned by `fn`.\n * `f` must not return a Promise (async functions not allowed).\n * The returned result can be a complex object, however tidy only walks the\n * top-level properties (depth 1) of that object to search for tensors, or\n * lists of tensors that need to be tracked in the parent scope.\n *\n * Using this method helps avoid memory leaks. In general, wrap calls to\n * operations in `tidy` for automatic memory cleanup.\n *\n * When in safe mode, you must enclose all `Tensor` creation and ops\n * inside a `tidy` to prevent memory leaks.\n *\n * ```js\n * // y = 2 ^ 2 + 1\n * const y = tf.tidy(() => {\n * // a, b, and one will be cleaned up when the tidy ends.\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n * const b = a.square();\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * y.print();\n * ```\n *\n * @param nameOrFn The name of the closure, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If debug mode is on, the timing and the memory usage of the function\n * will be tracked and displayed on the console using the provided name.\n * @param fn The function to execute.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n return ENV.engine.tidy(nameOrFn, fn, gradMode);\n }\n\n /**\n * Disposes any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. If the\n * object is not a `Tensor` or does not contain `Tensors`, nothing\n * happens. In general it is safe to pass any object here, except that\n * `Promise`s are not supported.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static dispose(container: TensorContainer) {\n const tensors = getTensorsInContainer(container);\n tensors.forEach(tensor => tensor.dispose());\n }\n\n /**\n * Keeps a `Tensor` generated inside a `tidy` from being disposed\n * automatically.\n *\n * ```js\n * let b;\n * const y = tf.tidy(() => {\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n *\n * // b will not be cleaned up by the tidy. a and one will be cleaned up\n * // when the tidy ends.\n * b = tf.keep(a.square());\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * console.log('y:');\n * y.print();\n * console.log('b:');\n * b.print();\n * ```\n *\n * @param result The tensor to keep from being disposed.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static keep(result: T): T {\n return ENV.engine.keep(result);\n }\n\n /**\n * Executes `f()` and returns a promise that resolves with timing\n * information.\n *\n * The result is an object with the following properties:\n *\n * - `wallMs`: Wall execution time.\n * - `kernelMs`: Kernel execution time, ignoring data transfer.\n * - On `WebGL` The following additional properties exist:\n * - `uploadWaitMs`: CPU blocking time on texture uploads.\n * - `downloadWaitMs`: CPU blocking time on texture downloads (readPixels).\n *\n * ```js\n * const x = tf.randomNormal([20, 20]);\n * const time = await tf.time(() => x.matMul(x));\n *\n * console.log(`kernelMs: ${time.kernelMs}, wallTimeMs: ${time.wallMs}`);\n * ```\n *\n * @param f The function to execute and time.\n */\n /** @doc {heading: 'Performance', subheading: 'Timing'} */\n static time(f: () => void): Promise {\n return ENV.engine.time(f);\n }\n\n get(feature: K): Features[K] {\n if (feature in this.features) {\n return this.features[feature];\n }\n\n this.features[feature] = this.evaluateFeature(feature);\n\n return this.features[feature];\n }\n\n getFeatures(): Features {\n return this.features;\n }\n\n set(feature: K, value: Features[K]): void {\n this.features[feature] = value;\n }\n\n private getBestBackendName(): string {\n if (Object.keys(this.registry).length === 0) {\n throw new Error('No backend found in registry.');\n }\n const sortedBackends = Object.keys(this.registry)\n .map(name => {\n return {name, entry: this.registry[name]};\n })\n .sort((a, b) => {\n // Highest priority comes first.\n return b.entry.priority - a.entry.priority;\n });\n return sortedBackends[0].name;\n }\n\n private evaluateFeature(feature: K): Features[K] {\n if (feature === 'DEBUG') {\n return false;\n } else if (feature === 'IS_BROWSER') {\n return typeof window !== 'undefined';\n } else if (feature === 'IS_NODE') {\n return (typeof process !== 'undefined') &&\n (typeof process.versions.node !== 'undefined');\n } else if (feature === 'IS_CHROME') {\n return isChrome();\n } else if (feature === 'IS_TEST') {\n return false;\n } else if (feature === 'BACKEND') {\n return this.getBestBackendName();\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') {\n const webGLVersion = this.get('WEBGL_VERSION');\n\n if (webGLVersion === 0) {\n return 0;\n }\n // Remove this and reenable this extension when the\n // EXT_disjoint_query_timer extension is reenabled in chrome.\n // https://github.com/tensorflow/tfjs/issues/544\n if (webGLVersion > 0) {\n return 0;\n }\n return getWebGLDisjointQueryTimerVersion(\n webGLVersion, this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE') {\n return this.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0 &&\n !device_util.isMobile();\n } else if (feature === 'HAS_WEBGL') {\n return this.get('WEBGL_VERSION') > 0;\n } else if (feature === 'WEBGL_VERSION') {\n if (isWebGLVersionEnabled(2, this.get('IS_BROWSER'))) {\n return 2;\n } else if (isWebGLVersionEnabled(1, this.get('IS_BROWSER'))) {\n return 1;\n }\n return 0;\n } else if (feature === 'WEBGL_RENDER_FLOAT32_ENABLED') {\n return isRenderToFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DOWNLOAD_FLOAT_ENABLED') {\n return isDownloadFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_FENCE_API_ENABLED') {\n return isWebGLFenceEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'TEST_EPSILON') {\n if (this.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return TEST_EPSILON_FLOAT32_ENABLED;\n }\n return TEST_EPSILON_FLOAT32_DISABLED;\n }\n throw new Error(`Unknown feature ${feature}.`);\n }\n\n setFeatures(features: Features) {\n this.features = Object.assign({}, features);\n }\n\n reset() {\n this.features = getFeaturesFromURL();\n if (this.globalEngine != null) {\n this.globalEngine = null;\n }\n }\n\n private initBackend(backendName?: string, safeMode = false) {\n this.backendName = backendName;\n this.backend = this.findBackend(backendName);\n this.globalEngine =\n new Engine(this.backend, safeMode, () => this.get('DEBUG'));\n }\n\n findBackend(name: string): KernelBackend {\n if (!(name in this.registry)) {\n return null;\n }\n return this.registry[name].backend;\n }\n\n /**\n * Registers a global backend. The registration should happen when importing\n * a module file (e.g. when importing `backend_webgl.ts`), and is used for\n * modular builds (e.g. custom tfjs bundle with only webgl support).\n *\n * @param factory: The backend factory function. When called, it should\n * return an instance of the backend.\n * @param priority The priority of the backend (higher = more important).\n * In case multiple backends are registered, the priority is used to find\n * the best backend. Defaults to 1.\n * @return False if the creation/registration failed. True otherwise.\n */\n registerBackend(\n name: string, factory: () => KernelBackend, priority = 1,\n setTensorTrackerFn?: (f: () => TensorTracker) => void): boolean {\n if (name in this.registry) {\n console.warn(\n `${name} backend was already registered. Reusing existing backend`);\n if (setTensorTrackerFn != null) {\n setTensorTrackerFn(() => this.engine);\n }\n return false;\n }\n try {\n const backend = factory();\n this.registry[name] = {backend, priority};\n return true;\n } catch (err) {\n console.warn(`Registration of backend ${name} failed`);\n console.warn(err.stack || err.message);\n return false;\n }\n }\n\n removeBackend(name: string): void {\n if (!(name in this.registry)) {\n throw new Error(`${name} backend not found in registry`);\n }\n this.registry[name].backend.dispose();\n delete this.registry[name];\n }\n\n get engine(): Engine {\n this.initDefaultBackend();\n return this.globalEngine;\n }\n\n private initDefaultBackend() {\n if (this.globalEngine == null) {\n this.initBackend(this.get('BACKEND'), false /* safeMode */);\n }\n }\n}\n\nfunction getGlobalNamespace(): {ENV: Environment} {\n // tslint:disable-next-line:no-any\n let ns: any;\n if (typeof (window) !== 'undefined') {\n ns = window;\n } else if (typeof (process) !== 'undefined') {\n ns = process;\n } else {\n throw new Error('Could not find a global object');\n }\n return ns;\n}\n\nfunction getOrMakeEnvironment(): Environment {\n const ns = getGlobalNamespace();\n if (ns.ENV == null) {\n ns.ENV = new Environment(getFeaturesFromURL());\n setTensorTracker(() => ns.ENV.engine);\n }\n return ns.ENV;\n}\n\nexport let ENV = getOrMakeEnvironment();\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\n\nexport function warn(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.warn(...msg);\n }\n}\n\nexport function log(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.log(...msg);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Gets the new shape of the input Tensor after it's been reshaped\n * to :\n * [blockShape[0], ..., blockShape[M-1], batch / prod(blockShape),\n * inputShape[1], ..., inputShape[N-1]]\n *\n * See step 1: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshaped(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n let reshaped: number[] = [];\n if (batchToSpace) {\n reshaped = reshaped.concat(blockShape.slice(0));\n reshaped.push(inputShape[0] / prod);\n reshaped = reshaped.concat(inputShape.slice(1));\n } else {\n reshaped = reshaped.concat(inputShape[0]);\n const spatialLength = blockShape.length;\n for (let i = 0; i < spatialLength; ++i) {\n reshaped =\n reshaped.concat([inputShape[i + 1] / blockShape[i], blockShape[i]]);\n }\n reshaped = reshaped.concat(inputShape.slice(spatialLength + 1));\n }\n return reshaped;\n}\n\n/**\n * Gets the permutation that will transpose the dimensions of the\n * reshaped tensor to shape:\n *\n * [batch / prod(block_shape),inputShape[1], blockShape[0], ...,\n * inputShape[M], blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * see step 2: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getPermuted(\n reshapedRank: number, blockShapeRank: number,\n batchToSpace = true): number[] {\n const permuted = [];\n if (batchToSpace) {\n permuted.push(blockShapeRank);\n for (let i = blockShapeRank + 1; i < reshapedRank; ++i) {\n if (i <= 2 * blockShapeRank) {\n permuted.push(i);\n permuted.push(i - (blockShapeRank + 1));\n } else {\n permuted.push(i);\n }\n }\n } else {\n const permutedBeforeBatch = [];\n const permutedAfterBatch = [];\n for (let i = 1; i < reshapedRank; ++i) {\n if (i >= blockShapeRank * 2 + 1 || i % 2 === 1) {\n permutedAfterBatch.push(i);\n } else {\n permutedBeforeBatch.push(i);\n }\n }\n permuted.push(...permutedBeforeBatch);\n permuted.push(0);\n permuted.push(...permutedAfterBatch);\n }\n return permuted;\n}\n\n/**\n * Gets the shape of the reshaped and permuted input Tensor before any cropping\n * is applied. The new shape will be:\n *\n * [batch / prod(blockShape),inputShape[1] * blockShape[0], ...,\n * inputShape[M] * blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 3: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshapedPermuted(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n const reshapedPermuted = [];\n\n if (batchToSpace) {\n reshapedPermuted.push(inputShape[0] / prod);\n } else {\n reshapedPermuted.push(inputShape[0] * prod);\n }\n\n for (let i = 1; i < inputShape.length; ++i) {\n if (i <= blockShape.length) {\n if (batchToSpace) {\n reshapedPermuted.push(blockShape[i - 1] * inputShape[i]);\n } else {\n reshapedPermuted.push(inputShape[i] / blockShape[i - 1]);\n }\n } else {\n reshapedPermuted.push(inputShape[i]);\n }\n }\n\n return reshapedPermuted;\n}\n\n/**\n * Converts the crops argument into the beginning coordinates of a slice\n * operation\n */\nexport function getSliceBeginCoords(\n crops: number[][], blockShape: number): number[] {\n const sliceBeginCoords = [0];\n for (let i = 0; i < blockShape; ++i) {\n sliceBeginCoords.push(crops[i][0]);\n }\n return sliceBeginCoords;\n}\n\n/**\n * converts the crops argument into the size of a slice operation. When\n * combined with getSliceBeginCoords this function allows the reshaped and\n * permuted Tensor to be cropped to its final output shape of:\n *\n * inputShape[1] * blockShape[0] - crops[0,0] - crops[0,1], ...,\n * inputShape[M] * blockShape[M-1] -crops[M-1,0] -\n * crops[M-1,1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 4: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getSliceSize(\n uncroppedShape: number[], crops: number[][], blockShape: number): number[] {\n const sliceSize = uncroppedShape.slice(0, 1);\n for (let i = 0; i < blockShape; ++i) {\n sliceSize.push(uncroppedShape[i + 1] - crops[i][0] - crops[i][1]);\n }\n\n return sliceSize;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\n/**\n * Returns true if the axis specifies the inner most dimensions of the\n * array.\n */\nexport function axesAreInnerMostDims(axes: number[], rank: number): boolean {\n for (let i = 0; i < axes.length; ++i) {\n if (axes[axes.length - i - 1] !== rank - 1 - i) {\n return false;\n }\n }\n return true;\n}\n\nexport function combineLocations(\n outputLoc: number[], reduceLoc: number[], axes: number[]): number[] {\n const rank = outputLoc.length + reduceLoc.length;\n const loc = [];\n let outIdx = 0;\n let reduceIdx = 0;\n   for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n loc.push(outputLoc[outIdx++]);\n } else {\n loc.push(reduceLoc[reduceIdx++]);\n }\n }\n return loc;\n}\n\nexport function computeOutAndReduceShapes(\n aShape: number[], axes: number[]): [number[], number[]] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n outShape.push(aShape[dim]);\n }\n }\n const reduceShape = axes.map(dim => aShape[dim]);\n return [outShape, reduceShape];\n}\n\nexport function expandShapeToKeepDim(\n shape: number[], axes: number[]): number[] {\n const reduceSubShape = axes.map(x => 1);\n return combineLocations(shape, reduceSubShape, axes);\n}\n\nexport function parseAxisParam(\n axis: number|number[], shape: number[]): number[] {\n const rank = shape.length;\n\n // Normalize input\n axis = axis == null ? shape.map((s, i) => i) : [].concat(axis);\n\n // Check for valid range\n util.assert(\n axis.every(ax => ax >= -rank && ax < rank),\n `All values in axis param must be in range [-${rank}, ${rank}) but ` +\n `got axis ${axis}`);\n\n // Check for only integers\n util.assert(\n axis.every(ax => util.isInt(ax)),\n `All values in axis param must be integers but ` +\n `got axis ${axis}`);\n\n // Handle negative axis.\n return axis.map(a => a < 0 ? rank + a : a);\n}\n\nexport function assertAxesAreInnerMostDims(\n msg: string, axes: number[], rank: number): void {\n util.assert(\n axesAreInnerMostDims(axes, rank),\n `${msg} supports only inner-most axes for now. ` +\n `Got axes ${axes} and rank-${rank} input.`);\n}\n\n/**\n * Returns the axes permutation to be used with `tf.transpose`, if such\n * permutation is neccesary. Otherwise it returns null. This method is used by\n * operations that operate only on inner-most axes.\n */\nexport function getAxesPermutation(axes: number[], rank: number): number[]|\n null {\n if (axesAreInnerMostDims(axes, rank)) {\n return null;\n }\n const result: number[] = [];\n for (let i = 0; i < rank; ++i) {\n if (axes.indexOf(i) === -1) {\n result.push(i);\n }\n }\n axes.forEach(axis => result.push(axis));\n return result;\n}\n\n/** Returns the axes permutation that undoes the original permutation. */\nexport function getUndoAxesPermutation(axes: number[]): number[] {\n return axes.map((axis, i) => [i, axis])\n .sort((a, b) => a[1] - b[1])\n .map(x => x[0]);\n}\n\nexport function getInnerMostAxes(numAxes: number, rank: number): number[] {\n const res: number[] = [];\n for (let i = rank - numAxes; i < rank; ++i) {\n res.push(i);\n }\n return res;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Inputs of size above this threshold will be parallelized by calling multiple\n * shader programs.\n */\nimport {nearestDivisor} from '../util';\n\nexport const PARALLELIZE_THRESHOLD = 30;\n\nexport interface ReduceInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n}\n\nexport function computeOptimalWindowSize(inSize: number): number {\n if (inSize <= PARALLELIZE_THRESHOLD) {\n return inSize;\n }\n return nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {nearestDivisor} from '../util';\nimport {PARALLELIZE_THRESHOLD} from './reduce_util';\n\nexport interface SegOpInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n numSegments: number;\n}\n\nexport function segOpComputeOptimalWindowSize(\n inSize: number, numSegments: number): number {\n let done = false;\n let res;\n\n if (inSize <= PARALLELIZE_THRESHOLD) {\n res = inSize;\n done = true;\n } else {\n res = nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n }\n\n while (!done) {\n if (res > numSegments || res === inSize) {\n done = true;\n break;\n } else {\n res = nearestDivisor(inSize, res + 1);\n }\n }\n return res;\n}\n\nexport function computeOutShape(\n aShape: number[], axis: number, numSegments: number): number[] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (dim !== axis) {\n outShape.push(aShape[dim]);\n } else {\n outShape.push(numSegments);\n }\n }\n return outShape;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport * as util from '../util';\n\nexport function assertParamsValid(\n input: Tensor, begin: number[], size: number[]): void {\n util.assert(\n input.rank === begin.length,\n `Error in slice${input.rank}D: Length of begin ${begin} must ` +\n `match the rank of the array (${input.rank}).`);\n util.assert(\n input.rank === size.length,\n `Error in slice${input.rank}D: Length of size ${size} must ` +\n `match the rank of the array (${input.rank}).`);\n\n for (let i = 0; i < input.rank; ++i) {\n util.assert(\n begin[i] + size[i] <= input.shape[i],\n `Error in slice${input.rank}D: begin[${i}] + size[${i}] ` +\n `(${begin[i] + size[i]}) would overflow input.shape[${i}] (${\n input.shape[i]})`);\n }\n}\n\n/**\n * Calculate the start index and output tensor shape for strided slice op.\n */\nexport function getStridedSlicedInfo(\n shape: number[], begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): [number[], number[]] {\n // Note that the axis orders are reversed for runtime ops, so the indices,\n // strides and masks must be as well too.\n const startIndex: number[] = [];\n const endIndex: number[] = [];\n for (let i = 0; i < shape.length; i++) {\n startIndex[i] = startForAxis(beginMask, begin, strides, shape, i);\n endIndex[i] = stopForAxis(endMask, end, strides, shape, i);\n }\n\n let size = new Array(shape.length).fill(0);\n size = size.map((d, i) => {\n let count = 0;\n for (let start = startIndex[i];\n !(strides[i] > 0 ? start >= endIndex[i] : start <= endIndex[i]);\n start += strides[i]) {\n count += 1;\n }\n return count;\n });\n return [startIndex, size];\n}\n\nexport function startForAxis(\n beginMask: number, startIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let start = startIndices[axis];\n\n // Check the axis bit from right of beginMask\n if (beginMask & 1 << axis) {\n if (strides[axis] > 0) {\n // Forward iteration - use the first element. These values will get\n // clamped below (Note: We could have set them to 0 and axis_size-1, but\n // use lowest() and max() to maintain symmetry with StopForAxis())\n start = Number.MIN_SAFE_INTEGER;\n } else {\n // Backward iteration - use the last element.\n start = Number.MAX_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (start < 0) {\n start += axisSize;\n }\n\n // Clamping\n start = util.clamp(0, start, axisSize - 1);\n\n return start;\n}\n\nexport function stopForAxis(\n endMask: number, stopIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let stop = stopIndices[axis];\n\n // Check the axis bit from right of endMask\n if (endMask & (1 << axis)) {\n if (strides[axis] > 0) {\n // Forward iteration - use the last element. These values will get\n // clamped below\n stop = Number.MAX_SAFE_INTEGER;\n } else {\n // Backward iteration - use the first element.\n stop = Number.MIN_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (stop < 0) {\n stop += axisSize;\n }\n\n // Clamping\n // Because the end index points one past the last element, we need slightly\n // different clamping ranges depending on the direction.\n if (strides[axis] > 0) {\n // Forward iteration\n stop = util.clamp(0, stop, axisSize);\n } else {\n // Backward iteration\n stop = util.clamp(-1, stop, axisSize - 1);\n }\n\n return stop;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {CustomGradientFunc, ScopeFn} from './engine';\nimport {ENV} from './environment';\nimport {Scalar, Tensor, Variable} from './tensor';\nimport {NamedTensorMap, TensorContainer} from './tensor_types';\nimport * as util from './util';\n\n/**\n * Create a new gradient scope. Similar to scope, but forces all inner scopes\n * to not clean up so that gradient operations can be used inside of this\n * scope.\n * @param nameOrScopeFn The name of the scope, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If a name is provided, and debug mode is on, the timing and the memory\n * usage of the function will be tracked and displayed on the console\n * using the provided name.\n * @param scopeFn The function to execute.\n */\nfunction gradScope(\n nameOrScopeFn: string|ScopeFn, scopeFn?: ScopeFn): T {\n return ENV.engine.tidy(nameOrScopeFn, scopeFn, true /* gradScope */);\n}\n\n/**\n * Provided `f(x)`, returns another function `g(x, dy?)`, which gives the\n * gradient of `f(x)` with respect to `x`.\n *\n * If `dy` is provided, the gradient of `f(x).mul(dy).sum()` with respect to\n * `x` is computed instead. `f(x)` must take a single tensor `x` and return a\n * single tensor `y`. If `f()` takes multiple inputs, use `grads` instead.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.grad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * g(x).print();\n * ```\n *\n * ```js\n * // f(x) = x ^ 3\n * const f = x => x.pow(tf.scalar(3, 'int32'));\n * // f'(x) = 3x ^ 2\n * const g = tf.grad(f);\n * // f''(x) = 6x\n * const gg = tf.grad(g);\n *\n * const x = tf.tensor1d([2, 3]);\n * gg(x).print();\n * ```\n *\n * @param f The function f(x), to compute gradient for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grad(f: (x: I) => O): (\n x: I, dy?: O) => I {\n util.assert(util.isFunction(f), 'The f passed in grad(f) must be a function');\n return (x: I, dy?: O): I => {\n util.assert(\n x instanceof Tensor, 'The x passed in grad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grad(f)(x, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(x), [x], dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grad(f)(x, dy) must match the shape ' +\n 'returned by f(x)');\n }\n checkGrads(grads);\n return grads[0] as I;\n });\n };\n}\n\n/**\n * Provided `f(x1, x2,...)`, returns another function `g([x1, x2,...], dy?)`,\n * which gives an array of gradients of `f()` with respect to each input\n * [`x1`,`x2`,...].\n *\n * If `dy` is passed when calling `g()`, the gradient of\n * `f(x1,...).mul(dy).sum()` with respect to each input is computed instead.\n * The provided `f` must take one or more tensors and return a single tensor\n * `y`. If `f()` takes a single input, we recommend using `grad` instead.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df / da = b, df / db = a\n * const g = tf.grads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const [da, db] = g([a, b]);\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n *\n * @param f The function `f(x1, x2,...)` to compute gradients for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => Tensor[] {\n util.assert(\n util.isFunction(f), 'The f passed in grads(f) must be a function');\n return (args: Tensor[], dy?: O): Tensor[] => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in grads(f)(args) must be an array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grads(f)(args, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(grads);\n return grads;\n });\n };\n}\n\n/**\n * Like `grad`, but also returns the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grad: The gradient of `f(x)` w.r.t `x` (result of `grad`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.valueAndGrad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * const {value, grad} = g(x);\n *\n * console.log('value');\n * value.print();\n * console.log('grad');\n * grad.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrad(f: (x: I) => O): (\n x: I, dy?: O) => {\n value: O;\n grad: I;\n} {\n util.assert(\n util.isFunction(f), 'The f passed in valueAndGrad(f) must be a function');\n return (x: I, dy?: O) => {\n util.assert(\n x instanceof Tensor,\n 'The x passed in valueAndGrad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrad(f)(x, dy) must be a tensor');\n const {grads, value} = ENV.engine.gradients(() => f(x), [x], dy);\n checkGrads(grads);\n return {grad: grads[0] as I, value: value as O};\n };\n}\n\n/**\n * Like `grads`, but returns also the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grads: The gradients of `f()` w.r.t each input (result of `grads`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df/da = b, df/db = a\n * const g = tf.valueAndGrads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const {value, grads} = g([a, b]);\n *\n * const [da, db] = grads;\n *\n * console.log('value');\n * value.print();\n *\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => {\n grads: Tensor[];\n value: O;\n} {\n util.assert(\n util.isFunction(f),\n 'The f passed in valueAndGrads(f) must be a function');\n return (args: Tensor[], dy?: O) => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in valueAndGrads(f)(args) must be array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrads(f)(args, dy) must be a tensor');\n const res = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n res.value.shape, dy.shape,\n 'The shape of dy passed in valueAndGrads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(res.grads);\n return res;\n };\n}\n\n/**\n * Computes and returns the gradient of f(x) with respect to the list of\n * trainable variables provided by `varList`. If no list is provided, it\n * defaults to all trainable variables.\n *\n * ```js\n * const a = tf.variable(tf.tensor1d([3, 4]));\n * const b = tf.variable(tf.tensor1d([5, 6]));\n * const x = tf.tensor1d([1, 2]);\n *\n * // f(a, b) = a * x ^ 2 + b * x\n * const f = () => a.mul(x.square()).add(b.mul(x)).sum();\n * // df/da = x ^ 2, df/db = x\n * const {value, grads} = tf.variableGrads(f);\n *\n * Object.keys(grads).forEach(varName => grads[varName].print());\n * ```\n *\n * @param f The function to execute. f() should return a scalar.\n * @param varList The list of trainable variables. Defaults to all variables.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction variableGrads(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n util.assert(\n util.isFunction(f),\n 'The f passed in variableGrads(f) must be a function');\n util.assert(\n varList == null ||\n Array.isArray(varList) && varList.every(v => v instanceof Variable),\n 'The varList passed in variableGrads(f, varList) must be an array ' +\n 'of variables');\n if (varList == null) {\n // Get all of the trainable variables.\n varList = [];\n for (const varName in ENV.engine.registeredVariables) {\n varList.push(ENV.engine.registeredVariables[varName]);\n }\n }\n // Prune non-trainable variables.\n const originalVarCount = varList.length;\n varList = varList.filter(variable => variable.trainable);\n util.assert(\n varList.length > 0,\n `variableGrads() expects at least one of the input variables to be ` +\n `trainable, but none of the ${originalVarCount} variables is ` +\n `trainable.`);\n\n const allowNoGradients = true;\n const {value, grads} =\n ENV.engine.gradients(f, varList, null, allowNoGradients);\n\n util.assert(\n grads.some(g => g != null),\n 'Cannot find a connection between any variable and the result of the ' +\n 'loss function y=f(x). Please make sure the operations that use ' +\n 'variables are inside the function f passed to minimize().');\n util.assert(\n value.rank === 0,\n `The f passed in variableGrads(f) must return a scalar, but it ` +\n `returned a rank-${value.rank} tensor`);\n\n const namedGrads: NamedTensorMap = {};\n varList.forEach((v, i) => {\n if (grads[i] != null) {\n namedGrads[v.name] = grads[i];\n }\n });\n return {value, grads: namedGrads};\n}\n\n/**\n * Overrides the gradient computation of a function `f`.\n *\n * Takes a function\n * `f(...inputs) => {value: Tensor, gradFunc: dy => Tensor[]}` and returns\n * another function `g(...inputs)` which takes the same inputs as `f`. When\n * called, `g` returns `f().value`. In backward mode, custom gradients with\n * respect to each input of `f` are computed using `f().gradFunc`.\n *\n * ```js\n * const customOp = tf.customGrad(x => {\n * // Override gradient of our custom x ^ 2 op to be dy * abs(x);\n * return {value: x.square(), gradFunc: dy => [dy.mul(x.abs())]};\n * });\n *\n * const x = tf.tensor1d([-1, -2, 3]);\n * const dx = tf.grad(x => customOp(x));\n *\n * console.log(`f(x):`);\n * customOp(x).print();\n * console.log(`f'(x):`);\n * dx(x).print();\n * ```\n *\n * @param f The function to evaluate in forward mode, which should return\n * `{value: Tensor, gradFunc: (dy) => Tensor[]}`, where `gradFunc` returns\n * the custom gradients of `f` with respect to its inputs.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n return ENV.engine.customGrad(f);\n}\n\nfunction checkGrads(grads: Tensor[]) {\n const numNullGradients = grads.filter(g => g == null).length;\n if (numNullGradients > 0) {\n throw new Error(\n `Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.`);\n }\n}\n\nexport {\n gradScope,\n customGrad,\n variableGrads,\n valueAndGrad,\n valueAndGrads,\n grad,\n grads,\n};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Tensor} from './tensor';\nimport {ArrayData, DataType, TensorLike} from './types';\nimport {inferShape, isTypedArray, toTypedArray} from './util';\n\nexport function convertToTensor(\n x: T|TensorLike, argName: string, functionName: string,\n dtype: DataType = 'float32'): T {\n dtype = dtype || 'float32';\n if (x instanceof Tensor) {\n return x;\n }\n if (!isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' &&\n typeof x !== 'boolean') {\n throw new Error(\n `Argument '${argName}' passed to '${functionName}' must be a ` +\n `Tensor or TensorLike, but got ${x.constructor.name}`);\n }\n const inferredShape = inferShape(x);\n if (!isTypedArray(x) && !Array.isArray(x)) {\n x = [x] as number[];\n }\n return Tensor.make(\n inferredShape,\n {values: toTypedArray(x as ArrayData, dtype, ENV.get('DEBUG'))},\n dtype);\n}\n\nexport function convertToTensorArray(\n arg: T[]|TensorLike[], argName: string, functionName: string): T[] {\n if (!Array.isArray(arg)) {\n throw new Error(\n `Argument ${argName} passed to ${functionName} must be a ` +\n '`Tensor[]` or `TensorLike[]`');\n }\n const tensors = arg as T[];\n return tensors.map(\n (t, i) => convertToTensor(t, `${argName}[${i}]`, functionName));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\n\n/**\n * Used for wrapping functions that perform math operations on\n * Tensors. The function will be wrapped in a named scope that cleans all\n * memory usage after the function is done.\n */\nexport function op(f: {[name: string]: T}): T {\n const keys = Object.keys(f);\n if (keys.length !== 1) {\n throw new Error(\n `Please provide an object with a single key ` +\n `(operation name) mapping to a function. Got an object with ` +\n `${keys.length} keys.`);\n }\n\n let opName = keys[0];\n const fn = f[opName];\n\n // Strip the underscore from the end of the function name.\n if (opName.endsWith('_')) {\n opName = opName.substring(0, opName.length - 1);\n }\n\n // tslint:disable-next-line:no-any\n const f2 = (...args: any[]) => {\n ENV.engine.startScope(opName);\n try {\n const result = fn(...args);\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n ENV.engine.endScope(result);\n return result;\n } catch (ex) {\n ENV.engine.endScope(null);\n throw ex;\n }\n };\n Object.defineProperty(f2, 'name', {value: opName, configurable: true});\n\n // tslint:disable-next-line:no-any\n return f2 as any as T;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../gradients';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Computes the softmax normalized vector given the logits.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * ```js\n * const a = tf.tensor2d([2, 4, 6, 1, 2, 3], [2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction softmax_(logits: T|TensorLike, dim = -1): T {\n const $logits = convertToTensor(logits, 'logits', 'softmax');\n\n if (dim === -1) {\n dim = $logits.rank - 1;\n }\n if (dim !== $logits.rank - 1) {\n throw Error(\n 'Softmax along a non-last dimension is not yet supported. ' +\n `Logits was rank ${$logits.rank} and dim was ${dim}`);\n }\n\n const customOp = customGrad(logits => {\n // Do it in log space for numerical stability.\n // exp(X - logSumExp(X))\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n const logResult = logits.toFloat().sub(lse);\n const y = logResult.exp() as T;\n\n const gradFunc = (dy: T) => {\n const dyTimesY = dy.mul(y);\n const keepDims = true;\n return dyTimesY.sub(dyTimesY.sum([dim], keepDims).mul(y));\n };\n\n return {value: y, gradFunc};\n });\n\n return customOp($logits);\n}\n\nexport const softmax = op({softmax_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, Tensor5D, Tensor6D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, TensorLike1D, TensorLike2D, TensorLike3D, TensorLike4D, TensorLike5D, TensorLike6D} from '../types';\nimport {ArrayData, DataType, Rank, ShapeMap} from '../types';\nimport {assertNonNull, assertShapesMatch, getTypedArrayFromDType, inferShape, isTypedArray, makeOnesTypedArray, makeZerosTypedArray, sizeFromShape, toTypedArray} from '../util';\nimport {op} from './operation';\n\n/**\n * Creates a `Tensor` with the provided values, shape and dtype.\n *\n * ```js\n * // Pass an array of values to create a vector.\n * tf.tensor([1, 2, 3, 4]).print();\n * ```\n *\n * ```js\n * // Pass a nested array of values to make a matrix or a higher\n * // dimensional tensor.\n * tf.tensor([[1, 2], [3, 4]]).print();\n * ```\n *\n * ```js\n * // Pass a flat array and specify a shape yourself.\n * tf.tensor([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor(\n values: TensorLike, shape?: ShapeMap[R],\n dtype: DataType = 'float32'): Tensor {\n if (!isTypedArray(values) && !Array.isArray(values) &&\n typeof values !== 'number' && typeof values !== 'boolean') {\n throw new Error(\n 'values passed to tensor(values) must be an ' +\n 'array of numbers or booleans, or a TypedArray');\n }\n const inferredShape = inferShape(values);\n if (shape != null && inferredShape.length !== 1) {\n assertShapesMatch(\n shape, inferredShape,\n `Error creating a new Tensor. ` +\n `Inferred shape (${inferredShape}) does not match the ` +\n `provided shape (${shape}). `);\n }\n if (!isTypedArray(values) && !Array.isArray(values)) {\n values = [values] as number[];\n }\n shape = shape || inferredShape;\n return Tensor.make(\n shape, {\n values:\n toTypedArray(values as ArrayData, dtype, ENV.get('DEBUG'))\n },\n dtype);\n}\n\n/**\n * Creates rank-0 `Tensor` (scalar) with the provided value and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `scalar` as it makes the code more readable.\n *\n * ```js\n * tf.scalar(3.14).print();\n * ```\n *\n * @param value The value of the scalar.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction scalar(value: number|boolean, dtype: DataType = 'float32'): Scalar {\n if (isTypedArray(value) || Array.isArray(value)) {\n throw new Error(\n 'Error creating a new Scalar: value must be a primitive ' +\n '(number|boolean)');\n }\n return tensor(value, [], dtype);\n}\n\n/**\n * Creates rank-1 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor1d` as it makes the code more readable.\n *\n * ```js\n * tf.tensor1d([1, 2, 3]).print();\n * ```\n *\n * @param values The values of the tensor. Can be array of numbers,\n * or a `TypedArray`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor1d(values: TensorLike1D, dtype: DataType = 'float32'): Tensor1D {\n assertNonNull(values);\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 1) {\n throw new Error('tensor1d() requires values to be a flat/TypedArray');\n }\n return tensor(values, inferredShape as [number], dtype);\n}\n\n/**\n * Creates rank-2 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor2d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor2d([[1, 2], [3, 4]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor2d(\n values: TensorLike2D, shape?: [number, number],\n dtype: DataType = 'float32'): Tensor2D {\n assertNonNull(values);\n if (shape != null && shape.length !== 2) {\n throw new Error('tensor2d() requires shape to have two numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 2 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor2d() requires values to be number[][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor2d() requires shape to be provided when `values` ' +\n 'are a flat/TypedArray');\n }\n shape = shape || inferredShape as [number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-3 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor3d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor3d([[[1], [2]], [[3], [4]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor3d([1, 2, 3, 4], [2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor3d(\n values: TensorLike3D, shape?: [number, number, number],\n dtype: DataType = 'float32'): Tensor3D {\n assertNonNull(values);\n if (shape != null && shape.length !== 3) {\n throw new Error('tensor3d() requires shape to have three numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 3 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor3d() requires values to be number[][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor3d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-4 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor4d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor4d([[[[1], [2]], [[3], [4]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor4d([1, 2, 3, 4], [1, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor4d(\n values: TensorLike4D, shape?: [number, number, number, number],\n dtype: DataType = 'float32'): Tensor4D {\n assertNonNull(values);\n if (shape != null && shape.length !== 4) {\n throw new Error('tensor4d() requires shape to have four numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 4 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor4d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor4d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-5 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor5d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor5d([[[[[1], [2]], [[3], [4]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor5d([1, 2, 3, 4, 5, 6, 7, 8], [1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor5d(\n values: TensorLike5D, shape?: [number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor5D {\n assertNonNull(values);\n if (shape != null && shape.length !== 5) {\n throw new Error('tensor5d() requires shape to have five numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 5 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor5d() requires values to be ' +\n 'number[][][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor5d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-6 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor6d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor6d([[[[[[1],[2]],[[3],[4]]],[[[5],[6]],[[7],[8]]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor6d([1, 2, 3, 4, 5, 6, 7, 8], [1, 1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor6d(\n values: TensorLike6D,\n shape?: [number, number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor6D {\n assertNonNull(values);\n if (shape != null && shape.length !== 6) {\n throw new Error('tensor6d() requires shape to have six numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 6 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor6d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor6d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape ||\n inferredShape as [number, number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1.\n *\n * ```js\n * tf.ones([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction ones(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0.\n *\n * ```js\n * tf.zeros([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Can\n * be 'float32', 'int32' or 'bool'. Defaults to 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zeros(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeZerosTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` filled with a scalar value.\n *\n * ```js\n * tf.fill([2, 2], 4).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param value The scalar value to fill the tensor with.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fill(\n shape: ShapeMap[R], value: number, dtype: DataType = 'float32'): Tensor {\n const values = getTypedArrayFromDType(dtype, sizeFromShape(shape));\n values.fill(value);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.onesLike(x).print();\n * ```\n * @param x A tensor.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction onesLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'onesLike');\n return ones($x.shape, $x.dtype) as T;\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.zerosLike(x).print();\n * ```\n *\n * @param x The tensor of required shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zerosLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'zerosLike');\n return zeros($x.shape, $x.dtype) as T;\n}\n\n/**\n * Return an evenly spaced sequence of numbers over the given interval.\n *\n * ```js\n * tf.linspace(0, 9, 10).print();\n * ```\n * @param start The start value of the sequence.\n * @param stop The end value of the sequence.\n * @param num The number of values to generate.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction linspace(start: number, stop: number, num: number): Tensor1D {\n if (num === 0) {\n throw new Error('Cannot request zero samples');\n }\n\n const step = (stop - start) / (num - 1);\n\n const values = makeZerosTypedArray(num, 'float32');\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, 'float32');\n}\n\n/**\n * Creates a new `Tensor1D` filled with the numbers in the range provided.\n *\n * The tensor is a is half-open interval meaning it includes start, but\n * excludes stop. Decrementing ranges and negative step values are also\n * supported.\n *\n * ```js\n * tf.range(0, 9, 2).print();\n * ```\n *\n * @param start An integer start value\n * @param stop An integer stop value\n * @param step An integer increment (will default to 1 or -1)\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction range(\n start: number, stop: number, step = 1,\n dtype: 'float32'|'int32' = 'float32'): Tensor1D {\n if (step === 0) {\n throw new Error('Cannot have a step of zero');\n }\n\n const sameStartStop = start === stop;\n const increasingRangeNegativeStep = start < stop && step < 0;\n const decreasingRangePositiveStep = stop < start && step > 1;\n\n if (sameStartStop || increasingRangeNegativeStep ||\n decreasingRangePositiveStep) {\n return zeros([0], dtype);\n }\n\n const numElements = Math.abs(Math.ceil((stop - start) / step));\n const values = makeZerosTypedArray(numElements, dtype);\n\n if (stop < start && step === 1) {\n // Auto adjust the step's sign if it hasn't been set\n // (or was set to 1)\n step = -1;\n }\n\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, dtype);\n}\n\nexport {\n fill,\n linspace,\n ones,\n range,\n scalar,\n tensor,\n tensor1d,\n tensor2d,\n tensor3d,\n tensor4d,\n tensor5d,\n tensor6d,\n zeros\n};\n\nexport const onesLike = op({onesLike_});\nexport const zerosLike = op({zerosLike_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport enum DType {\n float32 = 'float32',\n int32 = 'int32',\n bool = 'bool'\n}\n\n/** @docalias number[] */\nexport interface ShapeMap {\n R0: number[];\n R1: [number];\n R2: [number, number];\n R3: [number, number, number];\n R4: [number, number, number, number];\n R5: [number, number, number, number, number];\n R6: [number, number, number, number, number, number];\n}\n\n/** @hidden */\nexport interface DataTypeMap {\n float32: Float32Array;\n int32: Int32Array;\n bool: Uint8Array;\n}\n/** @docalias 'float32'|'int32'|'bool' */\nexport type DataType = keyof DataTypeMap;\nexport type TypedArray = DataTypeMap[DataType];\n\nexport enum Rank {\n R0 = 'R0',\n R1 = 'R1',\n R2 = 'R2',\n R3 = 'R3',\n R4 = 'R4',\n R5 = 'R5',\n R6 = 'R6'\n}\n\nexport type FlatVector = boolean[]|number[]|TypedArray;\nexport type RegularArray =\n T[]|T[][]|T[][][]|T[][][][]|T[][][][][]|T[][][][][][];\nexport type ArrayData =\n DataTypeMap[D]|RegularArray|RegularArray;\n\n// tslint:disable-next-line:no-any\nexport interface RecursiveArray {\n [index: number]: T|RecursiveArray;\n}\n\nenum UpcastInt32AndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'int32'\n}\n\nenum UpcastBoolAndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'bool'\n}\n\nenum UpcastFloat32AndMap {\n 'float32' = 'float32',\n 'int32' = 'float32',\n 'bool' = 'float32'\n}\n\nconst upcastTypeMap = {\n 'float32': UpcastFloat32AndMap,\n 'int32': UpcastInt32AndMap,\n 'bool': UpcastBoolAndMap\n};\n\nexport function upcastType(typeA: DataType, typeB: DataType): DataType {\n return upcastTypeMap[typeA][typeB];\n}\n\n/** Returns the output type after summation. */\nexport function sumOutType(type: DataType) {\n return upcastType(type, 'int32');\n}\n\n/** @docalias TypedArray|Array */\nexport type TensorLike =\n TypedArray|number|boolean|number[]|number[][]|number[][][]|number[][][][]|\n number[][][][][]|number[][][][][][]|boolean[]|boolean[][]|boolean[][][]|\n boolean[][][][]|boolean[][][][][]|boolean[][][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike1D = TypedArray|number[]|boolean[];\n/** @docalias TypedArray|Array */\nexport type TensorLike2D = TypedArray|number[]|number[][]|boolean[]|boolean[][];\n/** @docalias TypedArray|Array */\nexport type TensorLike3D =\n TypedArray|number[]|number[][][]|boolean[]|boolean[][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike4D =\n TypedArray|number[]|number[][][][]|boolean[]|boolean[][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike5D =\n TypedArray|number[]|number[][][][][]|boolean[]|boolean[][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike6D =\n TypedArray|number[]|number[][][][][][]|boolean[]|boolean[][][][][][];\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {scalar} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {Rank} from '../types';\nimport {DataType, ShapeMap} from '../types';\nimport {hasEncodingLoss} from '../util';\nimport {KernelBackend} from './backend';\n\nexport function castTensor(\n x: T, dtype: DataType, backend: KernelBackend): T {\n if (!hasEncodingLoss(x.dtype, dtype)) {\n // We don't change the underlying data, since we cast to higher\n // precision.\n return Tensor.make(x.shape, {dataId: x.dataId}, dtype) as T;\n }\n if (dtype === 'int32') {\n return backend.int(x);\n } else if (dtype === 'bool') {\n return backend.notEqual(x, scalar(0, x.dtype)) as T;\n } else {\n throw new Error(`Error in Cast: unknown dtype argument (${dtype})`);\n }\n}\n\nexport function reshapeTensor(\n x: T, shape: ShapeMap[R]): Tensor {\n return Tensor.make(shape, {dataId: x.dataId}, x.dtype);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Implementation of the NonMaxSuppression kernel shared between webgl and cpu.\n */\n\nimport {tensor1d} from '../ops/tensor_ops';\nimport {Tensor1D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function nonMaxSuppressionImpl(\n boxes: TypedArray, scores: TypedArray, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const candidates = Array.from(scores)\n .map((score, boxIndex) => ({score, boxIndex}))\n .filter(c => c.score > scoreThreshold)\n .sort((c1, c2) => c2.score - c1.score);\n\n const selected: number[] = [];\n\n for (let i = 0; i < candidates.length; i++) {\n const {score, boxIndex} = candidates[i];\n if (score < scoreThreshold) {\n break;\n }\n\n let ignoreCandidate = false;\n for (let j = selected.length - 1; j >= 0; --j) {\n const iou = intersectionOverUnion(boxes, boxIndex, selected[j]);\n if (iou >= iouThreshold) {\n ignoreCandidate = true;\n break;\n }\n }\n\n if (!ignoreCandidate) {\n selected.push(boxIndex);\n if (selected.length >= maxOutputSize) {\n break;\n }\n }\n }\n\n return tensor1d(selected, 'int32');\n}\n\nfunction intersectionOverUnion(boxes: TypedArray, i: number, j: number) {\n const iCoord = boxes.subarray(i * 4, i * 4 + 4);\n const jCoord = boxes.subarray(j * 4, j * 4 + 4);\n const yminI = Math.min(iCoord[0], iCoord[2]);\n const xminI = Math.min(iCoord[1], iCoord[3]);\n const ymaxI = Math.max(iCoord[0], iCoord[2]);\n const xmaxI = Math.max(iCoord[1], iCoord[3]);\n const yminJ = Math.min(jCoord[0], jCoord[2]);\n const xminJ = Math.min(jCoord[1], jCoord[3]);\n const ymaxJ = Math.max(jCoord[0], jCoord[2]);\n const xmaxJ = Math.max(jCoord[1], jCoord[3]);\n const areaI = (ymaxI - yminI) * (xmaxI - xminI);\n const areaJ = (ymaxJ - yminJ) * (xmaxJ - xminJ);\n if (areaI <= 0 || areaJ <= 0) {\n return 0.0;\n }\n const intersectionYmin = Math.max(yminI, yminJ);\n const intersectionXmin = Math.max(xminI, xminJ);\n const intersectionYmax = Math.min(ymaxI, ymaxJ);\n const intersectionXmax = Math.min(xmaxI, xmaxJ);\n const intersectionArea = Math.max(intersectionYmax - intersectionYmin, 0.0) *\n Math.max(intersectionXmax - intersectionXmin, 0.0);\n return intersectionArea / (areaI + areaJ - intersectionArea);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the TopK kernel shared between webgl and cpu. */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {DataType, TypedArray} from '../types';\nimport {getTypedArrayFromDType} from '../util';\n\nexport function topkImpl(\n x: TypedArray, xShape: number[], xDtype: DataType, k: number,\n sorted: boolean): [T, T] {\n // Reshape into a 2d tensor [batch, lastDim] and compute topk along lastDim.\n const lastDim = xShape[xShape.length - 1];\n const [batch, size] = [x.length / lastDim, lastDim];\n const allTopKVals = getTypedArrayFromDType(xDtype, batch * k);\n const allTopKIndices = getTypedArrayFromDType('int32', batch * k);\n\n for (let b = 0; b < batch; b++) {\n const offset = b * size;\n const vals = x.subarray(offset, offset + size);\n const valAndInd: Array<{value: number, index: number}> = [];\n for (let i = 0; i < vals.length; i++) {\n valAndInd.push({value: vals[i], index: i});\n }\n valAndInd.sort((a, b) => b.value - a.value);\n\n const outOffset = b * k;\n const topKVals = allTopKVals.subarray(outOffset, outOffset + k);\n const topKIndices = allTopKIndices.subarray(outOffset, outOffset + k);\n for (let i = 0; i < k; i++) {\n topKVals[i] = valAndInd[i].value;\n topKIndices[i] = valAndInd[i].index;\n }\n }\n // Reshape back to the original input shape, except that the last\n // dimension is k.\n const outputShape = xShape.slice();\n outputShape[outputShape.length - 1] = k;\n return [\n tensor(allTopKVals, outputShape, xDtype) as T,\n tensor(allTopKIndices, outputShape, 'int32') as T\n ];\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ArgMinMaxProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n\n constructor(reduceInfo: ReduceInfo, op: 'max'|'min', firstPass: boolean) {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n if (!firstPass) {\n this.variableNames.push('bestIndicesA');\n }\n this.outputShape = [batchSize, outSize];\n const compOp = (op === 'max') ? '>' : '<';\n const indexSnippet = firstPass ?\n 'inOffset + i;' :\n 'round(getBestIndicesA(batch, inOffset + i));';\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < ${windowSize}; i++) {\n int inIdx = ${indexSnippet};\n float candidate = getA(batch, inIdx);\n if (candidate ${compOp} bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class AvgPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float avgMultiplier = float(${avgMultiplier});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Returns the dimensions in the input shape that are broadcasted to\n * produce the provided output shape.\n *\n * The returned dimensions are 0-indexed and sorted. An example:\n * inShape = [4, 1, 3]\n * outShape = [5, 4, 3, 3]\n * result = [1]. Dimension 1 (2nd dimension of input) gets broadcasted 1 => 3.\n */\nexport function getBroadcastDims(\n inShape: number[], outShape: number[]): number[] {\n const inRank = inShape.length;\n const dims: number[] = [];\n for (let i = 0; i < inRank; i++) {\n const dim = inRank - 1 - i;\n const a = inShape[dim] || 1;\n const b = outShape[outShape.length - 1 - i] || 1;\n if (b > 1 && a === 1) {\n dims.unshift(dim);\n }\n }\n return dims;\n}\n\n/**\n * Returns the axes in the output space that should be reduced to produce\n * the input space.\n */\nexport function getReductionAxes(\n inShape: number[], outShape: number[]): number[] {\n const result: number[] = [];\n for (let i = 0; i < outShape.length; i++) {\n const inDim = inShape[inShape.length - i - 1];\n const outAxis = outShape.length - i - 1;\n const outDim = outShape[outAxis];\n if (inDim == null || (inDim === 1 && outDim > 1)) {\n result.unshift(outAxis);\n }\n }\n return result;\n}\n\n/**\n * Given the output of `getBroadcastDims()`, returns true if the broadcasting\n * is along the outer-most dimensions of the input.\n */\nexport function broadcastDimsAreOuter(dims: number[]): boolean {\n for (let i = 0; i < dims.length; i++) {\n if (dims[i] !== i) {\n return false;\n }\n }\n return true;\n}\n\nexport function assertAndGetBroadcastShape(\n shapeA: number[], shapeB: number[]): number[] {\n const result: number[] = [];\n const errMsg = `Operands could not be broadcast together with shapes ` +\n `${shapeA} and ${shapeB}.`;\n const l = Math.max(shapeA.length, shapeB.length);\n\n for (let i = 0; i < l; i++) {\n const a = shapeA[shapeA.length - i - 1] || 1;\n const b = shapeB[shapeB.length - i - 1] || 1;\n if (a > 1 && b > 1 && a !== b) {\n throw Error(errMsg);\n }\n result.unshift(Math.max(a, b));\n }\n return result;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class BatchNormProgram implements GPGPUProgram {\n variableNames: string[];\n outputShape: number[] = [];\n userCode: string;\n supportsBroadcasting = true;\n\n constructor(\n xShape: number[], meanShape: number[], varianceShape: number[],\n offsetShape: number[]|null, scaleShape: number[]|null,\n varianceEpsilon: number) {\n this.variableNames = ['x', 'mean', 'variance'];\n broadcast_util.assertAndGetBroadcastShape(xShape, meanShape);\n broadcast_util.assertAndGetBroadcastShape(xShape, varianceShape);\n\n let offsetSnippet = '0.0';\n if (offsetShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, offsetShape);\n this.variableNames.push('offset');\n offsetSnippet = 'getOffsetAtOutCoords()';\n }\n\n let scaleSnippet = '1.0';\n if (scaleShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, scaleShape);\n this.variableNames.push('scale');\n scaleSnippet = 'getScaleAtOutCoords()';\n }\n\n this.outputShape = xShape;\n this.userCode = `\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = ${offsetSnippet};\n float scale = ${scaleSnippet};\n float inv = scale * inversesqrt(variance + float(${varianceEpsilon}));\n setOutput((x - mean) * inv + offset);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nconst CHECK_NAN_SNIPPET = `\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n`;\n\nexport const ADD = 'return a + b;';\nexport const SUB = 'return a - b;';\nexport const MUL = 'return a * b;';\nexport const DIV = `if (a == b) return 1.0;\n return a / b;`;\n\n// We use native integer division to deal with floating point imprecision. Since\n// we implement floor division and glsl implements truncated division, we\n// correct for this by subtracting 1 from result when the result is negative and\n// there is a remainder.\nexport const INT_DIV = `\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n`;\n\nexport const POW = `\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n`;\nexport const SQUARED_DIFFERENCE = 'return (a - b) * (a - b);';\n\nexport const EQUAL = `return float(a == b);`;\n\nexport const NOT_EQUAL = `return float(a != b);`;\n\nexport const LESS = `return float(a < b);`;\n\nexport const LESS_EQUAL = `return float(a <= b);`;\n\nexport const GREATER = `return float(a > b);`;\n\nexport const GREATER_EQUAL = `return float(a >= b);`;\n\nexport const LOGICAL_AND = `return float(a >= 1.0 && b >= 1.0);`;\n\nexport const LOGICAL_OR = `return float(a >= 1.0 || b >= 1.0);`;\n\nexport const MAX = CHECK_NAN_SNIPPET + `\n return max(a, b);\n`;\nexport const MIN = CHECK_NAN_SNIPPET + `\n return min(a, b);\n`;\nexport const MOD = `if (b == 0.0) return NAN;\n return mod(a, b);`;\n\nexport const ATAN2 = CHECK_NAN_SNIPPET + `\n return atan(a, b);\n`;\n\nexport const ELU_DER = `return (b >= 1.0) ? a : a * (b + 1.0);`;\n\nexport class BinaryOpProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting = true;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(op: string, aShape: number[], bShape: number[]) {\n this.outputShape =\n broadcast_util.assertAndGetBroadcastShape(aShape, bShape);\n this.userCode = `\n uniform float NAN;\n float binaryOperation(float a, float b) {\n ${op}\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ClipProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(aShape: number[], min: number, max: number) {\n this.outputShape = aShape;\n const minFixed = min.toFixed(20);\n const maxFixed = max.toFixed(20);\n this.userCode = `\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, ${minFixed}, ${maxFixed}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport function assertParams(aShape: number[], bShape: number[], axis: number) {\n const aRank = aShape.length;\n const bRank = bShape.length;\n util.assert(\n aShape.length === bShape.length,\n `Error in concat${aRank}D: rank of x1 (${aRank}) and x2 (${bRank}) ` +\n `must be the same.`);\n\n util.assert(\n axis >= 0 && axis < aRank,\n `Error in concat${aRank}D: axis must be ` +\n `between 0 and ${aRank - 1}.`);\n\n for (let i = 0; i < aRank; i++) {\n util.assert(\n (i === axis) || (aShape[i] === bShape[i]),\n `Error in concat${aRank}D: Shape (${aShape}) does not match ` +\n `(${bShape}) along the non-concatenated axis ${i}.`);\n }\n}\n\nexport function computeOutShape(\n x1Shape: number[], x2Shape: number[], axis: number): number[] {\n util.assert(\n x1Shape.length === x2Shape.length,\n 'x1 and x2 should have the same rank.');\n const outputShape = x1Shape.slice();\n outputShape[axis] += x2Shape[axis];\n return outputShape;\n}\n\nexport function computeGradientSliceShapes(\n aShape: [number, number], bShape: [number, number]) {\n return {\n aBegin: [0, 0] as [number, number],\n aSize: aShape,\n bBegin: [0, aShape[1]] as [number, number],\n bSize: bShape\n };\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as concat_util from '../../ops/concat_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ConcatProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[] = [];\n userCode: string;\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n constructor(aShape: [number, number], bShape: [number, number]) {\n this.outputShape =\n concat_util.computeOutShape(aShape, bShape, 1 /* axis */);\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < ${aShape[1]}) {\n value = getA(yR, yC);\n } else {\n yC -= ${aShape[1]};\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class Conv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n for (int d2 = 0; d2 < ${convInfo.outChannels}; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * ${channelMul} + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class DepthwiseConv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < ${channelMul}; dm++) {\n int d2 = d1 * ${channelMul} + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n\n const inputDepthNearestVec4 = Math.floor(convInfo.inChannels / 4) * 4;\n const inputDepthVec4Remainder = convInfo.inChannels % 4;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n for (int d1 = 0; d1 < ${inputDepthNearestVec4}; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (${inputDepthVec4Remainder === 1}) {\n dotProd +=\n getX(batch, xR, xC, ${inputDepthNearestVec4}) *\n getW(wR, wC, ${inputDepthNearestVec4}, d2);\n } else if (${inputDepthVec4Remainder === 2}) {\n vec2 xValues = vec2(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (${inputDepthVec4Remainder === 3}) {\n vec3 xValues = vec3(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n\n const xNumRows = convInfo.inHeight;\n const xNumCols = convInfo.inWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / ${channelMul};\n int q = d2 - d1 * ${channelMul};\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${xNumRows}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${xNumCols}) {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport * as util from '../../util';\n\nexport type ShapeInfo = {\n logicalShape: number[],\n texShape: [number, number],\n isUniform: boolean\n};\n\nexport type InputInfo = {\n name: string,\n shapeInfo: ShapeInfo\n};\n\nexport function makeShader(\n inputsInfo: InputInfo[], outputShape: ShapeInfo, userCode: string,\n broadcast: boolean): string {\n let inputPrefixSnippet: string[]|string = inputsInfo.map(x => {\n const size = util.sizeFromShape(x.shapeInfo.logicalShape);\n if (x.shapeInfo.isUniform) {\n return `uniform float ${x.name}${size > 1 ? `[${size}]` : ''};`;\n }\n return `uniform sampler2D ${x.name};`;\n });\n inputPrefixSnippet = inputPrefixSnippet.join('\\n');\n const inputSamplingSnippet =\n inputsInfo.map(x => getInputSamplingSnippet(x, outputShape, broadcast))\n .join('\\n');\n const outTexShape = outputShape.texShape;\n const outputSamplingSnippet =\n getOutputSamplingSnippet(outputShape.logicalShape, outTexShape);\n const source = [\n SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET,\n FLOAT_TEXTURE_SETOUTPUT_SNIPPET, inputPrefixSnippet, outputSamplingSnippet,\n inputSamplingSnippet, userCode\n ].join('\\n');\n return source;\n}\n\nfunction getSamplerFromInInfo(inInfo: InputInfo): string {\n const shape = inInfo.shapeInfo.logicalShape;\n switch (shape.length) {\n case 0:\n return getSamplerScalar(inInfo);\n case 1:\n return getSampler1D(inInfo);\n case 2:\n return getSampler2D(inInfo);\n case 3:\n return getSampler3D(inInfo);\n case 4:\n return getSampler4D(inInfo);\n case 5:\n return getSampler5D(inInfo);\n case 6:\n return getSampler6D(inInfo);\n default:\n throw new Error(\n `${shape.length}-D input sampling` +\n ` is not yet supported`);\n }\n}\n\nfunction getInputSamplingSnippet(\n inInfo: InputInfo, outShapeInfo: ShapeInfo, broadcast: boolean): string {\n let res = getSamplerFlat(inInfo);\n res += getSamplerFromInInfo(inInfo);\n\n // If input and output have matching logical shapes, add\n // getTexNameAtOutCoord() method that samples the input\n // textureSampler using the output coordinates.\n if (broadcast ||\n util.arraysEqual(\n inInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape)) {\n res += getSamplerAtOutputCoords(inInfo, outShapeInfo, broadcast);\n }\n return res;\n}\n\nfunction getOutputSamplingSnippet(\n outShape: number[], outTexShape: [number, number]): string {\n switch (outShape.length) {\n case 0:\n return getOutputScalarCoords();\n case 1:\n return getOutput1DCoords(outShape as [number], outTexShape);\n case 2:\n return getOutput2DCoords(outShape as [number, number], outTexShape);\n case 3:\n return getOutput3DCoords(\n outShape as [number, number, number], outTexShape);\n case 4:\n return getOutput4DCoords(\n outShape as [number, number, number, number], outTexShape);\n case 5:\n return getOutput5DCoords(\n outShape as [number, number, number, number, number], outTexShape);\n case 6:\n return getOutput6DCoords(\n outShape as [number, number, number, number, number, number],\n outTexShape);\n default:\n throw new Error(\n `${outShape.length}-D output sampling is not yet supported`);\n }\n}\n\nconst SAMPLE_1D_SNIPPET = `\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_2D_SNIPPET = `\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_3D_SNIPPET = `\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_4D_SNIPPET = `\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_5D_SNIPPET = `\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_6D_SNIPPET = `\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst FLOAT_TEXTURE_SAMPLE_SNIPPET = `\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n`;\n\nconst FLOAT_TEXTURE_SETOUTPUT_SNIPPET = `\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n`;\n\nconst SHADER_PREFIX = `\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n ${SAMPLE_1D_SNIPPET}\n ${SAMPLE_2D_SNIPPET}\n ${SAMPLE_3D_SNIPPET}\n ${SAMPLE_4D_SNIPPET}\n ${SAMPLE_5D_SNIPPET}\n ${SAMPLE_6D_SNIPPET}\n`;\n\nfunction getOutputScalarCoords() {\n return `\n int getOutputCoords() {\n return 0;\n }\n `;\n}\n\nfunction getOutput1DCoords(\n shape: [number], texShape: [number, number]): string {\n if (texShape[0] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.x * ${texShape[1]}.0);\n }\n `;\n }\n if (texShape[1] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.y * ${texShape[0]}.0);\n }\n `;\n }\n return `\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n return resTexRC.x * ${texShape[1]} + resTexRC.y;\n }\n `;\n}\n\nfunction getOutput3DCoords(\n shape: [number, number, number], texShape: [number, number]): string {\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n return `\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${stride0};\n index -= r * ${stride0};\n int c = index / ${stride1};\n int d = index - c * ${stride1};\n return ivec3(r, c, d);\n }\n `;\n}\n\nfunction getOutput4DCoords(\n shape: [number, number, number, number],\n texShape: [number, number]): string {\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n int d2 = index - d * ${stride2};\n\n return ivec4(r, c, d, d2);\n }\n `;\n}\n\nfunction getOutput5DCoords(\n shape: [number, number, number, number, number],\n texShape: [number, number]): string {\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(${texShape[0]},\n ${texShape[1]}));\n\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n int d3 = index - d2 * ${stride3};\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n `;\n}\n\nfunction getOutput6DCoords(\n shape: [number, number, number, number, number, number],\n texShape: [number, number]): string {\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n return `\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n index -= d2 * ${stride3};\n\n int d3 = index / ${stride4};\n int d4 = index - d3 * ${stride4};\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n `;\n}\n\nfunction getOutput2DCoords(\n shape: [number, number], texShape: [number, number]): string {\n if (util.arraysEqual(shape, texShape)) {\n return `\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(${texShape[0]}, ${texShape[1]}));\n }\n `;\n }\n if (shape[1] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(index, 0);\n }\n `;\n }\n if (shape[0] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(0, index);\n }\n `;\n }\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${shape[1]};\n int c = index - r * ${shape[1]};\n return ivec2(r, c);\n }\n `;\n}\n\nfunction getSamplerScalar(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n if (inputInfo.shapeInfo.isUniform) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n}\n\nfunction getSampler1D(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n return `\n float ${funcName}(int index) {\n return ${funcName}Flat(index);\n }\n `;\n}\n\nfunction getSampler2D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n const texShape = inputInfo.shapeInfo.texShape;\n if (texShape != null && util.arraysEqual(shape, texShape)) {\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumR === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2((float(index) + 0.5) / ${texNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = UVfrom2D(${texNumR}, ${texNumC}, ${shape[1]}, row, col);\n return sampleTexture(${texName}, uv);\n }\n`;\n}\n\nfunction getSampler3D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col', 'depth'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int index = row * ${stride0} + col * ${stride1} + depth;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row;\n int texC = col * ${stride1} + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride1) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row * ${shape[1]} + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n ${texNumR}, ${texNumC}, ${stride0}, ${stride1}, row, col, depth);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler4D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride2) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, row, col, depth, depth2);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler5D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} +\n depth2 * ${stride3} + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride3) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} +\n depth * ${shape[3]} + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, row, col, depth, depth2, depth3);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler6D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3 * ${stride3}\n + depth4\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride4) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, ${stride4}\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSamplerFlat(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName =\n 'get' + texName.charAt(0).toUpperCase() + texName.slice(1) + 'Flat';\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n\n if (inputInfo.shapeInfo.isUniform) {\n if (inSize === 1) {\n return `float ${funcName}(int index) {return ${texName};}`;\n }\n return `\n float ${funcName}(int index) {\n for (int i = 0; i < ${inSize}; i++) {\n if (i == index) {\n return ${texName}[i];\n }\n }\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const tNumR = texShape[0];\n const tNumC = texShape[1];\n if (tNumC === 1 && tNumR === 1) {\n return `\n float ${funcName}(int index) {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n }\n if (tNumC === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${tNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (tNumR === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2((float(index) + 0.5) / ${tNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int index) {\n vec2 uv = UVfrom1D(${tNumR}, ${tNumC}, index);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getBroadcastOutputCoordsSampler(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo, texFuncSnippet: string,\n funcName: string): string {\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n\n let type = 'int';\n if (outRank === 2) {\n type = 'ivec2';\n } else if (outRank === 3) {\n type = 'ivec3';\n } else if (outRank === 4) {\n type = 'ivec4';\n }\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const rankDiff = outRank - inRank;\n let coordsSnippet: string;\n if (inRank === 0) {\n coordsSnippet = '';\n } else if (outRank < 2 && broadcastDims.length >= 1) {\n coordsSnippet = 'coords = 0;';\n } else {\n coordsSnippet =\n broadcastDims.map(d => `coords[${d + rankDiff}] = 0;`).join('\\n');\n }\n let unpackedCoordsSnippet = '';\n if (outRank < 2 && inRank > 0) {\n unpackedCoordsSnippet = 'coords';\n } else {\n unpackedCoordsSnippet = inputInfo.shapeInfo.logicalShape\n .map((s, i) => `coords[${i + rankDiff}]`)\n .join(', ');\n }\n return `\n float ${funcName}() {\n ${type} coords = getOutputCoords();\n ${coordsSnippet}\n return get${texFuncSnippet}(${unpackedCoordsSnippet});\n }\n `;\n}\n\nfunction getSamplerAtOutputCoords(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo,\n supportsBroadcasting: boolean) {\n const texName = inputInfo.name;\n const texFuncSnippet = texName.charAt(0).toUpperCase() + texName.slice(1);\n const funcName = 'get' + texFuncSnippet + 'AtOutCoords';\n\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n const doBroadcast =\n supportsBroadcasting && ((outRank > inRank) || broadcastDims.length > 0);\n const broadcastOverOuter =\n broadcast_util.broadcastDimsAreOuter(broadcastDims);\n const isUniform = inputInfo.shapeInfo.isUniform;\n\n if (doBroadcast && !broadcastOverOuter) {\n return getBroadcastOutputCoordsSampler(\n inputInfo, outShapeInfo, texFuncSnippet, funcName);\n }\n\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n let broadcastSnippet = '';\n if (doBroadcast && broadcastOverOuter) {\n broadcastSnippet = `\n int mainPart = index / ${inSize};\n index -= mainPart * ${inSize};\n `;\n }\n\n const outTexShape = outShapeInfo.texShape;\n if (isUniform) {\n if (inSize === 1) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n return get${texFuncSnippet}Flat(index);\n }\n `;\n }\n\n // At this point, the input is not a uniform.\n const inTexShape = inputInfo.shapeInfo.texShape;\n if (util.arraysEqual(inTexShape, outTexShape)) {\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, resultUV);\n }\n `;\n }\n\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n int texR = index / ${inTexShape[1]};\n int texC = index - texR * ${inTexShape[1]};\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${inTexShape[1]}.0, ${inTexShape[0]}.0);\n\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nexport function getCoordsDataType(rank: number): string {\n if (rank <= 1) {\n return 'int';\n } else if (rank === 2) {\n return 'ivec2';\n } else if (rank === 3) {\n return 'ivec3';\n } else if (rank === 4) {\n return 'ivec4';\n } else if (rank === 5) {\n return 'ivec5';\n } else if (rank === 6) {\n return 'ivec6';\n } else {\n throw Error(`GPU for rank ${rank} is not yet supported`);\n }\n}\n\n/** Returns a new input info (a copy) that has a squeezed logical shape. */\nfunction squeezeInputInfo(\n inInfo: InputInfo, squeezedShape: number[]): InputInfo {\n // Deep copy.\n const newInputInfo: InputInfo = JSON.parse(JSON.stringify(inInfo));\n newInputInfo.shapeInfo.logicalShape = squeezedShape;\n return newInputInfo;\n}\n\nfunction getSqueezedParams(params: string[], keptDims: number[]): string {\n return keptDims.map(d => params[d]).join(', ');\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class CumSumProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(shape: number[], exclusive: boolean, reverse: boolean) {\n this.outputShape = shape;\n const rank = shape.length;\n const finalDim = shape[shape.length - 1];\n const comparator = reverse ? '<' : '>';\n\n this.userCode = `\n int getIndex(int i) {\n ${reverse ? `return ${finalDim} -i - 1;` : 'return i;'}\n }\n\n void main() {\n ${getCoordsDataType(rank)} coords = getOutputCoords();\n int end = ${getFinalCoord(rank, 'coords')};\n float val = 0.0;\n for (int i = ${finalDim} - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx ${comparator} end) {\n continue;\n }\n if (idx == end && ${exclusive}) {\n continue;\n }\n ${getFinalCoord(rank, 'coords')} = idx;\n val += getX(${getCoords(rank, 'coords')});\n }\n setOutput(val);\n }\n `;\n }\n}\n\nfunction getCoords(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.x, ${name}.y`;\n } else if (rank === 3) {\n return `${name}.x, ${name}.y, ${name}.z`;\n } else if (rank === 4) {\n return `${name}.x, ${name}.y, ${name}.z, ${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n\nfunction getFinalCoord(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.y`;\n } else if (rank === 3) {\n return `${name}.z`;\n } else if (rank === 4) {\n return `${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class EncodeFloatProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n this.outputShape = outputShape;\n this.userCode = `\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class FromPixelsProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n const [height, width, ] = outputShape;\n this.outputShape = outputShape;\n this.userCode = `\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${width}.0, ${height}.0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class GatherProgram implements GPGPUProgram {\n variableNames = ['A', 'indices'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], indicesLength: number, axis: number) {\n const outputShape: number[] = aShape.slice();\n outputShape[axis] = indicesLength;\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape, axis);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[], axis: number): string {\n const rank = aShape.length;\n if (rank > 4) {\n throw Error(`Gather for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `int(getIndices(resRC))`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n if (i === axis) {\n sourceCoords.push(`int(getIndices(${currentCoords[i]}))`);\n } else {\n sourceCoords.push(`${currentCoords[i]}`);\n }\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, DataTypeMap} from '../../types';\n\nexport enum TextureUsage {\n RENDER,\n UPLOAD,\n PIXELS,\n DOWNLOAD\n}\n\nexport enum PhysicalTextureType {\n FLOAT16,\n FLOAT32,\n UNSIGNED_BYTE\n}\n\nexport interface TextureData {\n texture: WebGLTexture;\n shape: number[];\n /** [rows, columns] shape of the texture. */\n texShape: [number, number];\n dtype: DataType;\n values: DataTypeMap[DataType];\n usage: TextureUsage;\n}\n\nexport function getUnpackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns, rows];\n}\n\nexport function getUnpackedArraySizeFromMatrixSize(\n matrixSize: number, channelsPerTexture: number): number {\n return matrixSize * channelsPerTexture;\n}\n\nexport function getColorMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns * 4, rows];\n}\n\nexport function getMatrixSizeFromUnpackedArraySize(\n unpackedSize: number, channelsPerTexture: number): number {\n if (unpackedSize % channelsPerTexture !== 0) {\n throw new Error(\n `unpackedSize (${unpackedSize}) must be a multiple of ` +\n `${channelsPerTexture}`);\n }\n return unpackedSize / channelsPerTexture;\n}\n\nexport type TypedArray = Float32Array|Uint8Array;\n\nexport function encodeMatrixToUnpackedArray(\n matrix: TypedArray, unpackedArray: TypedArray, channelsPerTexture: number) {\n const requiredSize =\n getUnpackedArraySizeFromMatrixSize(matrix.length, channelsPerTexture);\n if (unpackedArray.length < requiredSize) {\n throw new Error(\n `unpackedArray length (${unpackedArray.length}) must be >= ` +\n `${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < matrix.length; ++src) {\n unpackedArray[dst] = matrix[src];\n dst += channelsPerTexture;\n }\n}\n\nexport function decodeMatrixFromUnpackedArray(\n unpackedArray: Float32Array, matrix: Float32Array,\n channelsPerTexture: number) {\n const requiredSize = getMatrixSizeFromUnpackedArraySize(\n unpackedArray.length, channelsPerTexture);\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += channelsPerTexture) {\n matrix[dst++] = unpackedArray[src];\n }\n}\n\nexport function decodeMatrixFromUnpackedColorRGBAArray(\n unpackedArray: Float32Array, matrix: Float32Array, channels: number) {\n const requiredSize = unpackedArray.length * channels / 4;\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += 4) {\n for (let c = 0; c < channels; c++) {\n matrix[dst++] = unpackedArray[src + c];\n }\n }\n}\n\nexport function getPackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [Math.ceil(columns / 2), Math.ceil(rows / 2)];\n}\n\nexport function getPackedRGBAArraySizeFromMatrixShape(\n rows: number, columns: number): number {\n const [w, h] = getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return w * h * 4;\n}\n\nexport function encodeMatrixToPackedRGBA(\n matrix: Float32Array, rows: number, columns: number,\n packedRGBA: Float32Array) {\n const requiredSize = getPackedRGBAArraySizeFromMatrixShape(rows, columns);\n if (packedRGBA.length < requiredSize) {\n throw new Error(\n `packedRGBA length (${packedRGBA.length}) must be >= ${requiredSize}`);\n }\n /*\n Unpacked matrix, row-major order in Float32Array[16]: A B C D\n E F G H\n I J K L\n M N O P\n\n Packed matrix, 2x2 RGBA32 texture (memory view): ABEF CDGH IJMN KLOP\n\n Packed matrix, 2x2 RGBA32 texture (matrix view): AB|CD\n EF|GH\n --+--\n IJ|KL\n MN|OP\n */\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n\n // loop over full 2x2 blocks\n {\n const dstStride = (oddWidth ? 4 : 0);\n const oneRow = columns;\n let dst = 0;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n const matrixSrcRow = (blockY * 2 * columns);\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n const matrixSrcCol = blockX * 2;\n const src = matrixSrcRow + matrixSrcCol;\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 1] = matrix[src + 1];\n packedRGBA[dst + 2] = matrix[src + oneRow];\n packedRGBA[dst + 3] = matrix[src + oneRow + 1];\n dst += 4;\n }\n dst += dstStride;\n }\n }\n\n // loop down final odd column\n if (oddWidth) {\n let src = columns - 1;\n let dst = (textureWidth - 1) * 4;\n const srcStride = 2 * columns;\n const dstStride = textureWidth * 4;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 2] = matrix[src + columns];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (rows - 1) * columns;\n let dst = (textureHeight - 1) * textureWidth * 4;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n packedRGBA[dst++] = matrix[src++];\n packedRGBA[dst++] = matrix[src++];\n dst += 2;\n }\n }\n\n // fill in bottom-right texel\n if (oddWidth && oddHeight) {\n packedRGBA[packedRGBA.length - 4] = matrix[matrix.length - 1];\n }\n\n return packedRGBA;\n}\n\nexport function decodeMatrixFromPackedRGBA(\n packedRGBA: Float32Array, rows: number, columns: number,\n matrix: Float32Array): Float32Array {\n const requiredSize = rows * columns;\n if (requiredSize < matrix.length) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n\n // loop over full 2x2 blocks\n {\n const srcStride = oddWidth ? 4 : 0;\n const dstStride = columns + (oddWidth ? 1 : 0);\n let src = 0;\n let dstRow1 = 0;\n let dstRow2 = columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n }\n src += srcStride;\n dstRow1 += dstStride;\n dstRow2 += dstStride;\n }\n }\n\n // loop down final column\n if (oddWidth) {\n let src = (textureWidth - 1) * 4;\n let dst = columns - 1;\n const srcStride = textureWidth * 4;\n const dstStride = 2 * columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n matrix[dst] = packedRGBA[src];\n matrix[dst + columns] = packedRGBA[src + 2];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (textureHeight - 1) * textureWidth * 4;\n let dst = (rows - 1) * columns;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dst++] = packedRGBA[src++];\n matrix[dst++] = packedRGBA[src++];\n src += 2;\n }\n }\n\n // fill in bottom-right cell\n if (oddWidth && oddHeight) {\n matrix[matrix.length - 1] = packedRGBA[packedRGBA.length - 4];\n }\n\n return matrix;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nlet MAX_TEXTURE_SIZE: number = null;\n\nimport * as util from '../../util';\nimport {ENV} from '../../environment';\n\nexport function createWebGLRenderingContext(attributes: WebGLContextAttributes):\n WebGLRenderingContext {\n const canvas = document.createElement('canvas');\n canvas.width = 1;\n canvas.height = 1;\n return createWebGLRenderingContextFromCanvas(canvas, attributes);\n}\n\nexport function createWebGLRenderingContextFromCanvas(\n canvas: HTMLCanvasElement,\n attributes: WebGLContextAttributes): WebGLRenderingContext {\n let gl: WebGLRenderingContext;\n\n const webglVersion = ENV.get('WEBGL_VERSION');\n if (webglVersion === 2) {\n gl = canvas.getContext('webgl2', attributes) as WebGLRenderingContext;\n } else if (webglVersion === 1) {\n gl = (canvas.getContext('webgl', attributes) ||\n canvas.getContext('experimental-webgl', attributes)) as\n WebGLRenderingContext;\n }\n\n if (webglVersion === 0 || gl == null) {\n throw new Error('This browser does not support WebGL.');\n }\n return gl;\n}\n\nexport function callAndCheck(gl: WebGLRenderingContext, func: () => T): T {\n const returnValue = func();\n checkWebGLError(gl);\n return returnValue;\n}\n\nlet webGLDebugErrorCheckingEnabled = false;\n\nexport function enableDebugWebGLErrorChecking(enabled: boolean) {\n webGLDebugErrorCheckingEnabled = enabled;\n}\n\nexport function checkWebGLError(gl: WebGLRenderingContext) {\n if (webGLDebugErrorCheckingEnabled) {\n const error = gl.getError();\n if (error !== gl.NO_ERROR) {\n throw new Error('WebGL Error: ' + getWebGLErrorMessage(gl, error));\n }\n }\n}\n\nexport function getWebGLErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.NO_ERROR:\n return 'NO_ERROR';\n case gl.INVALID_ENUM:\n return 'INVALID_ENUM';\n case gl.INVALID_VALUE:\n return 'INVALID_VALUE';\n case gl.INVALID_OPERATION:\n return 'INVALID_OPERATION';\n case gl.INVALID_FRAMEBUFFER_OPERATION:\n return 'INVALID_FRAMEBUFFER_OPERATION';\n case gl.OUT_OF_MEMORY:\n return 'OUT_OF_MEMORY';\n case gl.CONTEXT_LOST_WEBGL:\n return 'CONTEXT_LOST_WEBGL';\n default:\n return `Unknown error code ${status}`;\n }\n}\n\nexport function getExtensionOrThrow(\n gl: WebGLRenderingContext, extensionName: string): {} {\n return throwIfNull<{}>(\n gl, () => gl.getExtension(extensionName),\n 'Extension \"' + extensionName + '\" not supported on this browser.');\n}\n\nexport function createVertexShader(\n gl: WebGLRenderingContext, vertexShaderSource: string): WebGLShader {\n const vertexShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.VERTEX_SHADER),\n 'Unable to create vertex WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(vertexShader, vertexShaderSource));\n callAndCheck(gl, () => gl.compileShader(vertexShader));\n if (gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS) === false) {\n console.log(gl.getShaderInfoLog(vertexShader));\n throw new Error('Failed to compile vertex shader.');\n }\n return vertexShader;\n}\n\nexport function createFragmentShader(\n gl: WebGLRenderingContext, fragmentShaderSource: string): WebGLShader {\n const fragmentShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.FRAGMENT_SHADER),\n 'Unable to create fragment WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(fragmentShader, fragmentShaderSource));\n callAndCheck(gl, () => gl.compileShader(fragmentShader));\n if (gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS) === false) {\n logShaderSourceAndInfoLog(\n fragmentShaderSource, gl.getShaderInfoLog(fragmentShader));\n throw new Error('Failed to compile fragment shader.');\n }\n return fragmentShader;\n}\n\nconst lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g;\nfunction logShaderSourceAndInfoLog(\n shaderSource: string, shaderInfoLog: string) {\n const lineNumberRegexResult = lineNumberRegex.exec(shaderInfoLog);\n if (lineNumberRegexResult == null) {\n console.log(`Couldn't parse line number in error: ${shaderInfoLog}`);\n console.log(shaderSource);\n return;\n }\n\n const lineNumber = +lineNumberRegexResult[1];\n\n const shaderLines = shaderSource.split('\\n');\n const pad = shaderLines.length.toString().length + 2;\n const linesWithLineNumbers = shaderLines.map(\n (line, lineNumber) =>\n util.rightPad((lineNumber + 1).toString(), pad) + line);\n let maxLineLength = 0;\n for (let i = 0; i < linesWithLineNumbers.length; i++) {\n maxLineLength = Math.max(linesWithLineNumbers[i].length, maxLineLength);\n }\n\n const beforeErrorLines = linesWithLineNumbers.slice(0, lineNumber - 1);\n const errorLine = linesWithLineNumbers.slice(lineNumber - 1, lineNumber);\n const afterErrorLines = linesWithLineNumbers.slice(lineNumber);\n\n console.log(beforeErrorLines.join('\\n'));\n console.log(shaderInfoLog.split('\\n')[0]);\n console.log(\n `%c ${util.rightPad(errorLine[0], maxLineLength)}`,\n 'border:1px solid red; background-color:#e3d2d2; color:#a61717');\n console.log(afterErrorLines.join('\\n'));\n}\n\nexport function createProgram(gl: WebGLRenderingContext): WebGLProgram {\n return throwIfNull(\n gl, () => gl.createProgram(), 'Unable to create WebGLProgram.');\n}\n\nexport function linkProgram(gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.linkProgram(program));\n if (gl.getProgramParameter(program, gl.LINK_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Failed to link vertex and fragment shaders.');\n }\n}\n\nexport function validateProgram(\n gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.validateProgram(program));\n if (gl.getProgramParameter(program, gl.VALIDATE_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Shader program validation failed.');\n }\n}\n\nexport function createStaticVertexBuffer(\n gl: WebGLRenderingContext, data: Float32Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(gl, () => gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function createStaticIndexBuffer(\n gl: WebGLRenderingContext, data: Uint16Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, buffer));\n callAndCheck(\n gl, () => gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function queryMaxTextureSize(gl: WebGLRenderingContext): number {\n if (MAX_TEXTURE_SIZE != null) {\n return MAX_TEXTURE_SIZE;\n }\n MAX_TEXTURE_SIZE =\n callAndCheck(gl, () => gl.getParameter(gl.MAX_TEXTURE_SIZE));\n return MAX_TEXTURE_SIZE;\n}\n\nexport function getNumChannels(): number {\n if (ENV.get('WEBGL_VERSION') === 2) {\n return 1;\n }\n return 4;\n}\n\nexport function createTexture(gl: WebGLRenderingContext): WebGLTexture {\n return throwIfNull(\n gl, () => gl.createTexture(), 'Unable to create WebGLTexture.');\n}\n\nexport function validateTextureSize(\n gl: WebGLRenderingContext, width: number, height: number) {\n const maxTextureSize: number = queryMaxTextureSize(gl);\n if ((width <= 0) || (height <= 0)) {\n const requested = `[${width}x${height}]`;\n throw new Error('Requested texture size ' + requested + ' is invalid.');\n }\n if ((width > maxTextureSize) || (height > maxTextureSize)) {\n const requested = `[${width}x${height}]`;\n const max = `[${maxTextureSize}x${maxTextureSize}]`;\n throw new Error(\n 'Requested texture size ' + requested +\n ' greater than WebGL maximum on this browser / GPU ' + max + '.');\n }\n}\n\nexport function createFramebuffer(gl: WebGLRenderingContext): WebGLFramebuffer {\n return throwIfNull(\n gl, () => gl.createFramebuffer(), 'Unable to create WebGLFramebuffer.');\n}\n\nexport function bindVertexBufferToProgramAttribute(\n gl: WebGLRenderingContext, program: WebGLProgram, attribute: string,\n buffer: WebGLBuffer, arrayEntriesPerItem: number, itemStrideInBytes: number,\n itemOffsetInBytes: number): boolean {\n const loc = gl.getAttribLocation(program, attribute);\n if (loc === -1) {\n // The GPU compiler decided to strip out this attribute because it's unused,\n // thus no need to bind.\n return false;\n }\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(\n gl,\n () => gl.vertexAttribPointer(\n loc, arrayEntriesPerItem, gl.FLOAT, false, itemStrideInBytes,\n itemOffsetInBytes));\n callAndCheck(gl, () => gl.enableVertexAttribArray(loc));\n return true;\n}\n\nexport function bindTextureUnit(\n gl: WebGLRenderingContext, texture: WebGLTexture, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n}\n\nexport function unbindTextureUnit(\n gl: WebGLRenderingContext, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function getProgramUniformLocationOrThrow(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return throwIfNull(\n gl, () => gl.getUniformLocation(program, uniformName),\n 'uniform \"' + uniformName + '\" not present in program.');\n}\n\nexport function getProgramUniformLocation(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return gl.getUniformLocation(program, uniformName);\n}\n\nexport function bindTextureToProgramUniformSampler(\n gl: WebGLRenderingContext, program: WebGLProgram, texture: WebGLTexture,\n uniformSamplerLocation: WebGLUniformLocation, textureUnit: number) {\n callAndCheck(gl, () => bindTextureUnit(gl, texture, textureUnit));\n callAndCheck(gl, () => gl.uniform1i(uniformSamplerLocation, textureUnit));\n}\n\nexport function bindCanvasToFramebuffer(gl: WebGLRenderingContext) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n callAndCheck(gl, () => gl.viewport(0, 0, gl.canvas.width, gl.canvas.height));\n callAndCheck(gl, () => gl.scissor(0, 0, gl.canvas.width, gl.canvas.height));\n}\n\nexport function bindColorTextureToFramebuffer(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0));\n}\n\nexport function unbindColorTextureFromFramebuffer(\n gl: WebGLRenderingContext, framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, null, 0));\n}\n\nexport function validateFramebuffer(gl: WebGLRenderingContext) {\n const status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n if (status !== gl.FRAMEBUFFER_COMPLETE) {\n throw new Error(\n 'Error binding framebuffer: ' + getFramebufferErrorMessage(gl, status));\n }\n}\n\nexport function getFramebufferErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:\n return 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS';\n case gl.FRAMEBUFFER_UNSUPPORTED:\n return 'FRAMEBUFFER_UNSUPPORTED';\n default:\n return `unknown error ${status}`;\n }\n}\n\nfunction throwIfNull(\n gl: WebGLRenderingContext, returnTOrNull: () => T | null,\n failureMessage: string): T {\n const tOrNull: T|null = callAndCheck(gl, () => returnTOrNull());\n if (tOrNull == null) {\n throw new Error(failureMessage);\n }\n return tOrNull as T;\n}\n\nfunction validateTextureUnit(gl: WebGLRenderingContext, textureUnit: number) {\n const maxTextureUnit = gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1;\n const glTextureUnit = textureUnit + gl.TEXTURE0;\n if (glTextureUnit < gl.TEXTURE0 || glTextureUnit > maxTextureUnit) {\n const textureUnitRange = `[gl.TEXTURE0, gl.TEXTURE${maxTextureUnit}]`;\n throw new Error(`textureUnit must be in ${textureUnitRange}.`);\n }\n}\n\nexport function getTextureShapeFromLogicalShape(\n gl: WebGLRenderingContext, logShape: number[]): [number, number] {\n // If logical shape is 2, we don't squeeze, since we want to match physical.\n if (logShape.length !== 2) {\n const squeezeResult = util.squeezeShape(logShape);\n logShape = squeezeResult.newShape;\n }\n\n const maxTexSize = queryMaxTextureSize(gl);\n const size = util.sizeFromShape(logShape);\n if (logShape.length <= 1 && size <= maxTexSize) {\n return [size, 1];\n } else if (\n logShape.length === 2 && logShape[0] <= maxTexSize &&\n logShape[1] <= maxTexSize) {\n return logShape as [number, number];\n } else if (\n logShape.length === 3 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2]];\n } else if (\n logShape.length === 4 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] * logShape[3] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2] * logShape[3]];\n } else {\n return util.sizeToSquarishShape(size);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport * as tex_util from './tex_util';\nimport * as webgl_util from './webgl_util';\n\nexport function getWebGLContextAttributes(): WebGLContextAttributes {\n return {\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: true\n };\n}\n\nexport interface TextureConfig {\n internalFormatFloat: number;\n textureFormatFloat: number;\n internalFormatHalfFloat: number;\n internalFormatPackedFloat: number;\n\n // The format to use during a gl.readPixels call.\n downloadTextureFormat: number;\n // How many channels need to be unpacked after a gl.readPixels call.\n downloadUnpackNumChannels: number;\n\n defaultNumChannels: number;\n textureTypeHalfFloat: number;\n}\n\nexport function createWebGLContext(canvas?: HTMLCanvasElement) {\n const attributes = getWebGLContextAttributes();\n let gl: WebGLRenderingContext;\n if (canvas != null) {\n gl = webgl_util.createWebGLRenderingContextFromCanvas(canvas, attributes);\n } else {\n gl = webgl_util.createWebGLRenderingContext(attributes);\n }\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DEPTH_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.STENCIL_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.BLEND));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DITHER));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.POLYGON_OFFSET_FILL));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.SAMPLE_COVERAGE));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.SCISSOR_TEST));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.CULL_FACE));\n webgl_util.callAndCheck(gl, () => gl.cullFace(gl.BACK));\n\n return gl;\n}\n\nexport function createVertexShader(gl: WebGLRenderingContext): WebGLShader {\n const vertexShaderSource = `\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }`;\n return webgl_util.createVertexShader(gl, vertexShaderSource);\n}\n\nexport function createVertexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // [x y z u v] * [upper-left, lower-left, upper-right, lower-right]\n const vertexArray = new Float32Array(\n [-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]);\n return webgl_util.createStaticVertexBuffer(gl, vertexArray);\n}\n\nexport function createIndexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // OpenGL (and WebGL) have \"CCW == front\" winding\n const triangleVertexIndices = new Uint16Array([0, 1, 2, 2, 1, 3]);\n return webgl_util.createStaticIndexBuffer(gl, triangleVertexIndices);\n}\n\nexport function getTextureConfig(\n // tslint:disable-next-line:no-any\n gl: WebGLRenderingContext, textureHalfFloatExtension?: any): TextureConfig {\n // tslint:disable-next-line:no-any\n const glany = gl as any;\n\n let internalFormatFloat: number;\n let internalFormatHalfFloat: number;\n let internalFormatPackedFloat: number;\n let textureFormatFloat: number;\n\n let downloadTextureFormat: number;\n let downloadUnpackNumChannels: number;\n\n let defaultNumChannels: number;\n let textureTypeHalfFloat: number;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n internalFormatFloat = glany.R32F;\n internalFormatHalfFloat = glany.R16F;\n internalFormatPackedFloat = glany.RGBA32F;\n textureFormatFloat = glany.RED;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 1;\n textureTypeHalfFloat = glany.HALF_FLOAT;\n } else {\n internalFormatFloat = gl.RGBA;\n internalFormatHalfFloat = gl.RGBA;\n internalFormatPackedFloat = glany.RGBA;\n textureFormatFloat = gl.RGBA;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 4;\n textureTypeHalfFloat = textureHalfFloatExtension != null ?\n textureHalfFloatExtension.HALF_FLOAT_OES :\n null;\n }\n downloadTextureFormat = gl.RGBA;\n\n return {\n internalFormatFloat,\n internalFormatHalfFloat,\n internalFormatPackedFloat,\n textureFormatFloat,\n downloadTextureFormat,\n downloadUnpackNumChannels,\n defaultNumChannels,\n textureTypeHalfFloat\n };\n}\n\nfunction createAndConfigureTexture(\n gl: WebGLRenderingContext, width: number, height: number,\n internalFormat: number, textureFormat: number,\n textureType: number): WebGLTexture {\n webgl_util.validateTextureSize(gl, width, height);\n const texture = webgl_util.createTexture(gl);\n\n const tex2d = gl.TEXTURE_2D;\n webgl_util.callAndCheck(gl, () => gl.bindTexture(tex2d, texture));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MIN_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MAG_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n tex2d, 0, internalFormat, width, height, 0, textureFormat,\n textureType, null));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n return texture;\n}\n\nexport function createFloat32MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, gl.FLOAT);\n}\n\nexport function createFloat16MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, textureConfig.textureTypeHalfFloat);\n}\n\nexport function createUnsignedBytesMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE);\n}\n\nexport function createPackedMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatPackedFloat, gl.RGBA,\n gl.FLOAT);\n}\n\nexport function bindVertexProgramAttributeStreams(\n gl: WebGLRenderingContext, program: WebGLProgram,\n vertexBuffer: WebGLBuffer): boolean {\n const posOffset = 0; // x is the first buffer element\n const uvOffset = 3 * 4; // uv comes after [x y z]\n const stride = (3 * 4) + (2 * 4); // xyz + uv, each entry is 4-byte float.\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer));\n const success = webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'clipSpacePos', vertexBuffer, 3, stride, posOffset);\n return success &&\n webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'uv', vertexBuffer, 2, stride, uvOffset);\n}\n\nexport function uploadPixelDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement) {\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, pixels));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nfunction uploadDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, width: number,\n height: number, data: Float32Array, textureFormat: number) {\n webgl_util.validateTextureSize(gl, width, height);\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texSubImage2D(\n gl.TEXTURE_2D, 0, 0, 0, width, height, textureFormat, gl.FLOAT,\n data));\n\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function uploadMatrixToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, numChannels: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n let unpackedArray: Float32Array;\n if (textureConfig.defaultNumChannels === 1) {\n // No need to allocate a temporary array.\n unpackedArray = matrix;\n } else {\n unpackedArray =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n matrix.length, numChannels));\n tex_util.encodeMatrixToUnpackedArray(matrix, unpackedArray, numChannels);\n }\n\n uploadDataToTexture(\n gl, texture, w, h, unpackedArray, textureConfig.textureFormatFloat);\n}\n\nexport function uploadMatrixToPackedTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, textureConfig: TextureConfig) {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n tex_util.encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA);\n uploadDataToTexture(gl, texture, w, h, packedRGBA, gl.RGBA);\n}\n\nexport function maybeCreateBufferFromOutputTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, textureConfig: TextureConfig): WebGLBuffer|WebGLTexture {\n let bufferOrTexture: WebGLBuffer|WebGLTexture = texture;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n const gl2 = gl as WebGL2RenderingContext;\n\n // Create and bind the buffer.\n const buffer = gl2.createBuffer();\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, buffer));\n\n // Initialize the buffer to the size of the texture in bytes.\n const bytesPerFloat = 4;\n const bufferSizeBytes = bytesPerFloat *\n tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels);\n\n webgl_util.callAndCheck(\n gl,\n () => gl.bufferData(\n gl2.PIXEL_PACK_BUFFER, bufferSizeBytes, gl.STATIC_DRAW));\n\n // Enqueue a command on the GPU command queue to copy of texture into the\n // buffer.\n webgl_util.callAndCheck(\n gl, () => gl2.readPixels(0, 0, columns, rows, gl.RGBA, gl.FLOAT, 0));\n\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, null));\n\n bufferOrTexture = buffer;\n }\n\n return bufferOrTexture;\n}\n\nexport function downloadFloat32MatrixFromBuffer(\n gl: WebGLRenderingContext, buffer: WebGLBuffer, rows: number,\n columns: number, textureConfig: TextureConfig): Float32Array {\n const gl2 = gl as WebGL2RenderingContext;\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n gl2.bindBuffer(gl.ARRAY_BUFFER, buffer);\n gl2.getBufferSubData(gl.ARRAY_BUFFER, 0, downloadTarget);\n gl2.bindBuffer(gl.ARRAY_BUFFER, null);\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n\n return matrix;\n}\n\nexport function downloadFloat32MatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.FLOAT,\n downloadTarget));\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n return matrix;\n}\n\nexport function downloadByteEncodedFloatMatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const numChannels = 4;\n const downloadTarget = new Uint8Array(\n tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, numChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.UNSIGNED_BYTE,\n downloadTarget));\n\n // By wrapping the buffer in a Float32Array, we use native browser IEEE 754\n // decoding of the 4 bytes that back each 32 bit float.\n return new Float32Array(downloadTarget.buffer);\n}\n\nexport function downloadMatrixFromPackedOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n webgl_util.callAndCheck(\n gl, () => gl.readPixels(0, 0, w, h, gl.RGBA, gl.FLOAT, packedRGBA));\n const matrix = new Float32Array(rows * columns);\n return tex_util.decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix);\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\nimport * as util from '../../util';\nimport * as gpgpu_util from './gpgpu_util';\nimport {TextureConfig} from './gpgpu_util';\nimport * as tex_util from './tex_util';\nimport {WebGL1DisjointQueryTimerExtension, WebGL2DisjointQueryTimerExtension} from './webgl_types';\nimport * as webgl_util from './webgl_util';\n\nexport interface FenceContext {\n query: WebGLQuery|WebGLSync;\n isFencePassed(): boolean;\n}\n\nexport class GPGPUContext {\n gl: WebGLRenderingContext;\n textureFloatExtension: {};\n textureHalfFloatExtension: {};\n colorBufferFloatExtension: {};\n colorBufferHalfFloatExtension: {};\n getBufferSubDataAsyncExtension: {};\n loseContextExtension: WebGLLoseContext;\n disjointQueryTimerExtension: WebGL2DisjointQueryTimerExtension|\n WebGL1DisjointQueryTimerExtension;\n vertexBuffer: WebGLBuffer;\n indexBuffer: WebGLBuffer;\n framebuffer: WebGLFramebuffer;\n outputTexture: WebGLTexture|null = null;\n program: WebGLProgram|null = null;\n private disposed = false;\n private autoDebugValidate = false;\n private disjoint: boolean;\n\n private textureConfig: TextureConfig;\n\n constructor(gl?: WebGLRenderingContext) {\n if (gl != null) {\n this.gl = gl;\n } else {\n this.gl = gpgpu_util.createWebGLContext();\n }\n // WebGL 2.0 enables texture floats without an extension.\n if (ENV.get('WEBGL_VERSION') === 1) {\n this.textureFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_float');\n this.colorBufferFloatExtension =\n this.gl.getExtension('WEBGL_color_buffer_float');\n\n if (!ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n this.textureHalfFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_half_float');\n this.colorBufferHalfFloatExtension =\n this.gl.getExtension('EXT_color_buffer_half_float');\n }\n } else {\n this.colorBufferFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'EXT_color_buffer_float');\n }\n\n this.loseContextExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'WEBGL_lose_context') as\n WebGLLoseContext;\n\n this.vertexBuffer = gpgpu_util.createVertexBuffer(this.gl);\n this.indexBuffer = gpgpu_util.createIndexBuffer(this.gl);\n this.framebuffer = webgl_util.createFramebuffer(this.gl);\n\n this.textureConfig =\n gpgpu_util.getTextureConfig(this.gl, this.textureHalfFloatExtension);\n }\n\n public dispose() {\n if (this.disposed) {\n return;\n }\n if (this.program != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound WebGLProgram.' +\n ' This is probably a resource leak, delete the program with ' +\n 'GPGPUContext.deleteProgram before disposing.');\n }\n if (this.outputTexture != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound output matrix ' +\n 'texture. This is probably a resource leak, delete the output ' +\n 'matrix texture with GPGPUContext.deleteMatrixTexture before ' +\n 'disposing.');\n }\n const gl = this.gl;\n webgl_util.callAndCheck(gl, () => gl.finish());\n webgl_util.callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteFramebuffer(this.framebuffer));\n webgl_util.callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.vertexBuffer));\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.indexBuffer));\n this.loseContextExtension.loseContext();\n this.disposed = true;\n }\n\n public enableAutomaticDebugValidation(enabled: boolean) {\n this.autoDebugValidate = enabled;\n webgl_util.enableDebugWebGLErrorChecking(enabled);\n }\n\n public createFloat32MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat32MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createFloat16MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat16MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createUnsignedBytesMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createUnsignedBytesMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public uploadPixelDataToTexture(\n texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement) {\n this.throwIfDisposed();\n gpgpu_util.uploadPixelDataToTexture(this.gl, texture, pixels);\n }\n\n public createPackedMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createPackedMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public deleteMatrixTexture(texture: WebGLTexture) {\n this.throwIfDisposed();\n if (this.outputTexture === texture) {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n this.outputTexture = null;\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteTexture(texture));\n }\n\n public uploadMatrixToTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n const numChannels = webgl_util.getNumChannels();\n return gpgpu_util.uploadMatrixToTexture(\n this.gl, texture, rows, columns, matrix, numChannels,\n this.textureConfig);\n }\n\n public uploadMatrixToPackedTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n return gpgpu_util.uploadMatrixToPackedTexture(\n this.gl, texture, rows, columns, matrix, this.textureConfig);\n }\n\n public downloadFloat32MatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadFloat32MatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadByteEncodedFloatMatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadFloat32MatrixFromBuffer(\n buffer: WebGLBuffer, rows: number, columns: number): Float32Array {\n return gpgpu_util.downloadFloat32MatrixFromBuffer(\n this.gl, buffer, rows, columns, this.textureConfig);\n }\n\n public maybeCreateBufferFromTexture(\n texture: WebGLTexture, rows: number, columns: number): WebGLBuffer\n |WebGLTexture {\n this.bindTextureToFrameBuffer(texture);\n const result = gpgpu_util.maybeCreateBufferFromOutputTexture(\n this.gl, texture, rows, columns, this.textureConfig);\n this.unbindTextureToFrameBuffer();\n return result;\n }\n\n public createAndWaitForFence(): Promise {\n const fenceContext = this.createFence(this.gl);\n return this.pollFence(fenceContext);\n }\n\n private createFence(gl: WebGLRenderingContext): FenceContext {\n let query: WebGLQuery|WebGLSync;\n let isFencePassed: () => boolean;\n\n if (ENV.get('WEBGL_FENCE_API_ENABLED')) {\n const gl2 = gl as WebGL2RenderingContext;\n\n const sync = gl2.fenceSync(gl2.SYNC_GPU_COMMANDS_COMPLETE, 0);\n gl.flush();\n\n isFencePassed = () => {\n const status = gl2.clientWaitSync(sync, 0, 0);\n return status === gl2.ALREADY_SIGNALED ||\n status === gl2.CONDITION_SATISFIED;\n };\n\n query = sync;\n } else if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n query = this.beginQuery();\n this.endQuery();\n isFencePassed = () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n } else {\n // If we have no way to fence, return true immediately. This will fire in\n // WebGL 1.0 when there is no disjoint query timer. In this case, because\n // the fence passes immediately, we'll immediately ask for a download of\n // the texture, which will cause the UI thread to hang.\n isFencePassed = () => true;\n }\n\n return {query, isFencePassed};\n }\n\n public downloadMatrixFromPackedTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadMatrixFromPackedOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n private vertexAttrsAreBound = false;\n\n public createProgram(fragmentShaderSource: string): WebGLProgram {\n this.throwIfDisposed();\n const gl = this.gl;\n const fragmentShader: WebGLShader =\n webgl_util.createFragmentShader(gl, fragmentShaderSource);\n const vertexShader: WebGLShader = gpgpu_util.createVertexShader(gl);\n const program: WebGLProgram = webgl_util.createProgram(gl);\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, vertexShader));\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, fragmentShader));\n webgl_util.linkProgram(gl, program);\n if (this.autoDebugValidate) {\n webgl_util.validateProgram(gl, program);\n }\n if (!this.vertexAttrsAreBound) {\n this.setProgram(program);\n this.vertexAttrsAreBound = gpgpu_util.bindVertexProgramAttributeStreams(\n gl, this.program, this.vertexBuffer);\n }\n return program;\n }\n\n public deleteProgram(program: WebGLProgram) {\n this.throwIfDisposed();\n if (program === this.program) {\n this.program = null;\n }\n if (program != null) {\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteProgram(program));\n }\n }\n\n public setProgram(program: WebGLProgram|null) {\n this.throwIfDisposed();\n this.program = program;\n if ((this.program != null) && this.autoDebugValidate) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.useProgram(program));\n }\n\n public getUniformLocation(\n program: WebGLProgram, uniformName: string,\n shouldThrow = true): WebGLUniformLocation {\n this.throwIfDisposed();\n if (shouldThrow) {\n return webgl_util.getProgramUniformLocationOrThrow(\n this.gl, program, uniformName);\n } else {\n return webgl_util.getProgramUniformLocation(\n this.gl, program, uniformName);\n }\n }\n\n public getAttributeLocation(program: WebGLProgram, attribute: string):\n number {\n this.throwIfDisposed();\n return webgl_util.callAndCheck(\n this.gl, () => this.gl.getAttribLocation(program, attribute));\n }\n\n public getUniformLocationNoThrow(program: WebGLProgram, uniformName: string):\n WebGLUniformLocation {\n this.throwIfDisposed();\n return this.gl.getUniformLocation(program, uniformName);\n }\n\n public setInputMatrixTexture(\n inputMatrixTexture: WebGLTexture, uniformLocation: WebGLUniformLocation,\n textureUnit: number) {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n webgl_util.bindTextureToProgramUniformSampler(\n this.gl, this.program, inputMatrixTexture, uniformLocation,\n textureUnit);\n }\n\n public setOutputMatrixTexture(\n outputMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.setOutputMatrixTextureDriver(outputMatrixTexture, columns, rows);\n }\n\n public setOutputPackedMatrixTexture(\n outputPackedMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.throwIfDisposed();\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n this.setOutputMatrixTextureDriver(outputPackedMatrixTexture, width, height);\n }\n\n public setOutputMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n this.setOutputMatrixWriteRegionDriver(\n startColumn, startRow, numColumns, numRows);\n }\n\n public setOutputPackedMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n throw new Error('setOutputPackedMatrixWriteRegion not implemented.');\n }\n\n public debugValidate() {\n if (this.program != null) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.validateFramebuffer(this.gl);\n }\n\n public executeProgram() {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n const gl = this.gl;\n if (this.autoDebugValidate) {\n this.debugValidate();\n }\n webgl_util.callAndCheck(\n gl, () => gl.drawElements(gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0));\n }\n\n public blockUntilAllProgramsCompleted() {\n this.throwIfDisposed();\n webgl_util.callAndCheck(this.gl, () => this.gl.finish());\n }\n\n private getQueryTimerExtension(): WebGL1DisjointQueryTimerExtension\n |WebGL2DisjointQueryTimerExtension {\n if (this.disjointQueryTimerExtension == null) {\n this.disjointQueryTimerExtension =\n webgl_util.getExtensionOrThrow(\n this.gl,\n ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2 ?\n 'EXT_disjoint_timer_query_webgl2' :\n 'EXT_disjoint_timer_query') as\n WebGL1DisjointQueryTimerExtension |\n WebGL2DisjointQueryTimerExtension;\n }\n return this.disjointQueryTimerExtension;\n }\n\n private getQueryTimerExtensionWebGL2(): WebGL2DisjointQueryTimerExtension {\n return this.getQueryTimerExtension();\n }\n\n private getQueryTimerExtensionWebGL1(): WebGL1DisjointQueryTimerExtension {\n return this.getQueryTimerExtension() as WebGL1DisjointQueryTimerExtension;\n }\n\n beginQuery(): WebGLQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const query = gl2.createQuery();\n gl2.beginQuery(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n const query = ext.createQueryEXT();\n ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n\n endQuery() {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n gl2.endQuery(ext.TIME_ELAPSED_EXT);\n return;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n ext.endQueryEXT(ext.TIME_ELAPSED_EXT);\n }\n\n public async waitForQueryAndGetTime(query: WebGLQuery): Promise {\n await util.repeatedTry(\n () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')));\n return this.getQueryTime(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n }\n\n private getQueryTime(query: WebGLQuery, queryTimerVersion: number): number {\n if (queryTimerVersion === 0) {\n return null;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n\n const timeElapsedNanos = gl2.getQueryParameter(query, gl2.QUERY_RESULT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const timeElapsedNanos =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_EXT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n }\n }\n\n private isQueryAvailable(query: WebGLQuery, queryTimerVersion: number):\n boolean {\n if (queryTimerVersion === 0) {\n return true;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const available =\n gl2.getQueryParameter(query, gl2.QUERY_RESULT_AVAILABLE);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const available =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_AVAILABLE_EXT);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n }\n }\n\n pollFence(fenceContext: FenceContext) {\n return new Promise(resolve => {\n this.addItemToPoll(() => fenceContext.isFencePassed(), () => resolve());\n });\n }\n\n private itemsToPoll: PollItem[] = [];\n\n pollItems(): void {\n // Find the last query that has finished using binary search.\n // All other queries before it are also done.\n const index = binSearchLastTrue(this.itemsToPoll.map(x => x.isDoneFn));\n for (let i = 0; i <= index; ++i) {\n const {resolveFn} = this.itemsToPoll[i];\n resolveFn();\n }\n this.itemsToPoll = this.itemsToPoll.slice(index + 1);\n }\n\n private addItemToPoll(isDoneFn: () => boolean, resolveFn: () => void) {\n this.itemsToPoll.push({isDoneFn, resolveFn});\n if (this.itemsToPoll.length > 1) {\n // We already have a running loop that polls.\n return;\n }\n // Start a new loop that polls.\n util.repeatedTry(() => {\n this.pollItems();\n // End the loop if no more items to poll.\n return this.itemsToPoll.length === 0;\n });\n }\n private bindTextureToFrameBuffer(texture: WebGLTexture) {\n this.throwIfDisposed();\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, texture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n }\n\n private unbindTextureToFrameBuffer() {\n if (this.outputTexture != null) {\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, this.outputTexture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n } else {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n }\n }\n\n private downloadMatrixDriver(\n texture: WebGLTexture,\n downloadAndDecode: () => Float32Array): Float32Array {\n this.bindTextureToFrameBuffer(texture);\n const result = downloadAndDecode();\n this.unbindTextureToFrameBuffer();\n\n return result;\n }\n\n private setOutputMatrixTextureDriver(\n outputMatrixTextureMaybePacked: WebGLTexture, width: number,\n height: number) {\n this.throwIfDisposed();\n const gl = this.gl;\n webgl_util.bindColorTextureToFramebuffer(\n gl, outputMatrixTextureMaybePacked, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(gl);\n }\n this.outputTexture = outputMatrixTextureMaybePacked;\n webgl_util.callAndCheck(gl, () => gl.viewport(0, 0, width, height));\n webgl_util.callAndCheck(gl, () => gl.scissor(0, 0, width, height));\n }\n\n private setOutputMatrixWriteRegionDriver(\n x: number, y: number, width: number, height: number) {\n this.throwIfDisposed();\n webgl_util.callAndCheck(\n this.gl, () => this.gl.scissor(x, y, width, height));\n }\n\n private throwIfDisposed() {\n if (this.disposed) {\n throw new Error('Attempted to use disposed GPGPUContext.');\n }\n }\n\n private throwIfNoProgram() {\n if (this.program == null) {\n throw new Error('No GPU program is currently set.');\n }\n }\n}\n\ntype PollItem = {\n isDoneFn: () => boolean,\n resolveFn: () => void\n};\n\n/**\n * Finds the index of the last true element using binary search where\n * evaluation of an entry is expensive.\n */\nexport function binSearchLastTrue(arr: Array<() => boolean>): number {\n let start = 0;\n let end = arr.length - 1;\n let best = -1;\n while (start <= end) {\n const mid = (start + end) >> 1;\n const isDone = arr[mid]();\n if (isDone) {\n best = mid;\n start = mid + 1;\n } else {\n end = mid - 1;\n }\n }\n return best;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../../tensor';\nimport * as util from '../../util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport * as shader_compiler from './shader_compiler';\nimport {InputInfo, ShapeInfo} from './shader_compiler';\nimport {TextureData} from './tex_util';\n\nexport interface GPGPUProgram {\n variableNames: string[];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting?: boolean;\n}\n\nexport interface GPGPUBinary {\n webGLProgram: WebGLProgram;\n program: GPGPUProgram;\n uniformLocations: {[name: string]: WebGLUniformLocation};\n gpgpu: GPGPUContext;\n source: string;\n inShapeInfos: ShapeInfo[];\n outShapeInfo: ShapeInfo;\n}\n\nexport interface TensorData {\n tensor: T;\n texData: TextureData;\n isUniform: boolean;\n}\n\nexport function compileProgram(\n gpgpu: GPGPUContext, program: GPGPUProgram, inputs: Array>,\n output: TensorData): GPGPUBinary {\n const userCode = program.userCode;\n const inputInfos: InputInfo[] = inputs.map((input, i) => {\n const shapeInfo = {\n logicalShape: input.tensor.shape,\n texShape: input.isUniform ? null : input.texData.texShape,\n isUniform: input.isUniform\n };\n return {name: program.variableNames[i], shapeInfo};\n });\n const inShapeInfos = inputInfos.map(x => x.shapeInfo);\n const outShapeInfo = {\n logicalShape: output.tensor.shape,\n texShape: output.texData.texShape,\n isUniform: false\n };\n const source = shader_compiler.makeShader(\n inputInfos, outShapeInfo, userCode,\n program.supportsBroadcasting === true);\n\n const webGLProgram = gpgpu.createProgram(source);\n\n const uniformLocations: {[name: string]: WebGLUniformLocation} = {};\n for (let i = 0; i < program.variableNames.length; i++) {\n const uniformName = program.variableNames[i];\n const shouldThrow = false;\n uniformLocations[uniformName] =\n gpgpu.getUniformLocation(webGLProgram, uniformName, shouldThrow);\n }\n\n return {\n program,\n source,\n webGLProgram,\n uniformLocations,\n gpgpu,\n inShapeInfos,\n outShapeInfo\n };\n}\n\nfunction validateBinaryAndProgram(\n shapeInfos: ShapeInfo[], inputs: Array>) {\n if (shapeInfos.length !== inputs.length) {\n throw Error(\n `Binary was compiled with ${shapeInfos.length} inputs, but ` +\n `was executed with ${inputs.length} inputs`);\n }\n\n shapeInfos.forEach((s, i) => {\n const shapeA = s.logicalShape;\n const input = inputs[i];\n const shapeB = input.tensor.shape;\n\n if (!util.arraysEqual(shapeA, shapeB)) {\n throw Error(\n `Binary was compiled with different shapes than ` +\n `the current args. Shapes ${shapeA} and ${shapeB} must match`);\n }\n // The input is uploaded as uniform.\n if (s.isUniform && input.isUniform) {\n return;\n }\n\n const texShapeA = s.texShape;\n const texShapeB = input.isUniform ? null : input.texData.texShape;\n if (!util.arraysEqual(texShapeA, texShapeB)) {\n throw Error(\n `Binary was compiled with different texture shapes than the` +\n ` current args. Shape ${texShapeA} and ${texShapeB} must match`);\n }\n });\n}\n\nexport function runProgram(\n binary: GPGPUBinary, inputs: Array>, output: TensorData,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) =>\n void): void {\n validateBinaryAndProgram(binary.inShapeInfos, inputs);\n validateBinaryAndProgram([binary.outShapeInfo], [output]);\n\n const outTex = output.texData.texture;\n const outTexShape = output.texData.texShape;\n const gpgpu = binary.gpgpu;\n gpgpu.setOutputMatrixTexture(outTex, outTexShape[0], outTexShape[1]);\n gpgpu.setProgram(binary.webGLProgram);\n inputs.forEach((input, i) => {\n const variableName = binary.program.variableNames[i];\n const variableUniformLocation = binary.uniformLocations[variableName];\n if (variableUniformLocation != null) {\n if (input.isUniform) {\n if (input.tensor.size === 1) {\n gpgpu.gl.uniform1f(\n variableUniformLocation, input.tensor.dataSync()[0]);\n } else {\n let vals = input.tensor.dataSync();\n if (!(vals instanceof Float32Array)) {\n vals = new Float32Array(vals);\n }\n gpgpu.gl.uniform1fv(variableUniformLocation, vals);\n }\n return;\n }\n const tex = input.texData.texture;\n gpgpu.setInputMatrixTexture(tex, variableUniformLocation, i);\n }\n });\n\n if (customSetup != null) {\n customSetup(gpgpu, binary.webGLProgram);\n }\n gpgpu.executeProgram();\n}\n\nexport function makeShaderKey(\n program: GPGPUProgram, inputs: Array>,\n output: TensorData): string {\n let keyInputs = '';\n inputs.concat(output).forEach(x => {\n keyInputs +=\n `${x.tensor.shape}_${x.isUniform ? 'uniform' : x.texData.texShape}`;\n });\n const keyUserCode = program.userCode;\n const keyBroadcast = (program.supportsBroadcasting === true).toString();\n let key = program.constructor.name;\n // Fast string concat. See https://jsperf.com/string-concatenation/14.\n key += '_' + keyBroadcast + '_' + keyInputs + '_' + keyUserCode;\n return key;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n xShape: number[], radius: number, bias: number, alpha: number,\n beta: number) {\n const rad = radius;\n const maxD = xShape[3] - 1;\n this.outputShape = xShape;\n\n // optimize pow(bias + alpha * sum, -beta)\n // src: https://github.com/tensorflow/tensorflow/..\n // blob/26033a1644a9c4a5fbe3170ab2e864b6a4ccd4ca/..\n // tensorflow/core/kernels/mkl_lrn_op.cc#L320\n let powOperator;\n const basis = `float(${bias}) + float(${alpha}) * sum`;\n if (beta === 0.5) {\n powOperator = `inversesqrt(${basis})`;\n } else if (beta === 1.0) {\n powOperator = `1.0/(${basis})`;\n } else {\n powOperator = `exp(log(${basis}) * float(-${beta}));`;\n }\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -${rad}; j <= ${rad}; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= ${maxD}) {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * ${powOperator};\n setOutput(val);\n }\n `;\n }\n}\n","import {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNGradProgram implements GPGPUProgram {\n variableNames = ['inputImage', 'outputImage', 'dy'];\n outputShape: number[] = [];\n userCode: string;\n depthRadius: number;\n bias: number;\n alpha: number;\n beta: number;\n depth: number;\n\n constructor(\n inputShape: number[], depthRadius: number, bias: number, alpha: number,\n beta: number) {\n this.outputShape = inputShape;\n this.depth = inputShape[3];\n this.depthRadius = depthRadius;\n this.bias = bias;\n this.alpha = alpha;\n this.beta = beta;\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < ${this.depth}; ++d) {\n int depthBegin = int(max(0.0, float(d - ${depthRadius})));\n int depthEnd = int(min(float(${this.depth}),\n float(d + ${depthRadius} + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = ${this.depth};\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(${alpha}) * norm + float(${bias});\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(${alpha})\n * float(${beta})\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * ${beta});\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MaxPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy', 'maxPos'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const lastIndex = filterHeight * filterWidth - 1;\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = ${lastIndex} - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * ${filterWidth} + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MatMulProgram implements GPGPUProgram {\n variableNames = ['matrixA', 'matrixB'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n aShape: [number, number], bShape: [number, number], transposeA = false,\n transposeB = false) {\n const outerShapeA = transposeA ? aShape[1] : aShape[0];\n const outerShapeB = transposeB ? bShape[0] : bShape[1];\n const sharedDim = transposeA ? aShape[0] : aShape[1];\n this.outputShape = [outerShapeA, outerShapeB];\n\n const aSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeA ? `${indexVar} + ${vec4Offset}, aRow` :\n `aRow, ${indexVar} + ${vec4Offset}`;\n const bSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeB ? `bCol, ${indexVar} + ${vec4Offset}` :\n `${indexVar} + ${vec4Offset}, bCol`;\n\n const sharedDimNearestVec4 = Math.floor(sharedDim / 4) * 4;\n const sharedDimVec4Remainder = sharedDim % 4;\n\n this.userCode = ` float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < ${sharedDimNearestVec4}; i += 4) {\n vec4 a = vec4(\n getMatrixA(${aSnippetFromOffset(0, 'i')}),\n getMatrixA(${aSnippetFromOffset(1, 'i')}),\n getMatrixA(${aSnippetFromOffset(2, 'i')}),\n getMatrixA(${aSnippetFromOffset(3, 'i')})\n );\n vec4 b = vec4(\n getMatrixB(${bSnippetFromOffset(0, 'i')}),\n getMatrixB(${bSnippetFromOffset(1, 'i')}),\n getMatrixB(${bSnippetFromOffset(2, 'i')}),\n getMatrixB(${bSnippetFromOffset(3, 'i')})\n );\n\n result += dot(a, b);\n }\n\n if (${sharedDimVec4Remainder === 1}) {\n result += getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}) *\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)});\n } else if (${sharedDimVec4Remainder === 2}) {\n vec2 a = vec2(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n vec2 b = vec2(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n } else if (${sharedDimVec4Remainder === 3}) {\n vec3 a = vec3(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n vec3 b = vec3(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MultinomialProgram implements GPGPUProgram {\n variableNames = ['probs'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(batchSize: number, numOutcomes: number, numSamples: number) {\n this.outputShape = [batchSize, numSamples];\n\n this.userCode = `\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < ${numOutcomes - 1}; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(${numOutcomes - 1}));\n }\n `;\n }\n\n getCustomSetupFunc(seed: number) {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.seedLoc == null) {\n this.seedLoc = gpgpu.getUniformLocation(webGLProgram, 'seed');\n }\n gpgpu.gl.uniform1f(this.seedLoc, seed);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class OneHotProgram implements GPGPUProgram {\n variableNames = ['indices'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(\n numIndices: number, depth: number, onValue: number, offValue: number) {\n this.outputShape = [numIndices, depth];\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(${offValue}), float(${onValue}),\n float(index == coords.y)));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class PadProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n xShape: number[], paddings: Array<[number, number]>,\n constantValue: number) {\n this.outputShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + xShape[i] + p[1] /* afterPad */);\n const rank = xShape.length;\n const type = getCoordsDataType(rank);\n\n const start = paddings.map(p => p[0]).join(',');\n const end = paddings.map((p, i) => p[0] + xShape[i]).join(',');\n const unpackedCoords =\n ['coords[0]', 'coords[1]', 'coords[2]','coords[3]'].slice(0, rank);\n\n if (rank === 1) {\n this.userCode = `\n int start = ${start};\n int end = ${end};\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(${constantValue}));\n } else {\n setOutput(getX(outC - start));\n }\n }\n `;\n return;\n }\n this.userCode = `\n ${type} start = ${type}(${start});\n ${type} end = ${type}(${end});\n\n void main() {\n ${type} outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(${constantValue}));\n } else {\n ${type} coords = outC - start;\n setOutput(getX(${unpackedCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Pool2DProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n convInfo: Conv2DInfo, poolType: 'max'|'avg', computePositions: boolean) {\n if (poolType === 'avg' && computePositions) {\n throw new Error('Cannot compute positions for average pool.');\n }\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n this.outputShape = convInfo.outShape;\n\n const isAvgPool = poolType === 'avg';\n\n let initializationValue = '0.0';\n if (!isAvgPool) {\n initializationValue = '-1.0 / 0.0';\n }\n\n if (computePositions) {\n const compareOp = '>=';\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value ${compareOp} currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * ${filterWidth} + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n `;\n return;\n }\n\n const compareOp = 'max';\n\n let returnValue = `${poolType}(${poolType}(${poolType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n if (poolType === 'avg') {\n returnValue = `avgValue / count`;\n }\n\n const filterWidthNearestVec4 = Math.floor(filterWidth / 4) * 4;\n const filterWidthVec4Remainder = filterWidth % 4;\n\n const updateSnippet = `\n if (${isAvgPool}) {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(${initializationValue});\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidthNearestVec4}; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n ${updateSnippet}\n }\n\n int xC = xCCorner + ${filterWidthNearestVec4};\n if (${filterWidthVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n ${updateSnippet}\n }\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ReduceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n reduceInfo: ReduceInfo, reduceType: 'all'|'any'|'max'|'min'|'sum') {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n let initializationValue = '0.0';\n let compareOp = ``;\n\n if (reduceType === 'min') {\n initializationValue = '1.0 / 0.0';\n compareOp = `min`;\n } else if (reduceType === 'max') {\n initializationValue = '-1.0 / 0.0';\n compareOp = `max`;\n }\n\n let returnValue = `${reduceType}(${reduceType}(${reduceType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n\n if (reduceType === 'sum') {\n returnValue = `sumValue`;\n } else if (reduceType === 'all') {\n returnValue = `allValue`;\n } else if (reduceType === 'any') {\n returnValue = `anyValue`;\n }\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n let updateSnippet = `\n if (${reduceType === 'sum'}) {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n let vecType = `vec4`;\n\n if (reduceType === 'all') {\n initializationValue = '1.0';\n updateSnippet = `\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n `;\n vecType = `bvec4`;\n } else if (reduceType === 'any') {\n initializationValue = '0.0';\n updateSnippet = `\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n `;\n vecType = `bvec4`;\n }\n\n let checkOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n this.userCode = `\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n ${checkOutOfBounds}\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n vec4 minMaxValue = vec4(${initializationValue});\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), ${xHeight - 1}.0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), ${xWidth - 1}.0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeigborBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float sourceFracRow =\n float(${effectiveXSize[0]}) *\n (float(dyR) / float(${effectiveYSize[0]}));\n\n float sourceFracCol =\n float(${effectiveXSize[1]}) *\n (float(dyC) / float(${effectiveYSize[1]}));\n\n int sourceNearestRow = int(min(\n float(int(${xHeight}) - 1),\n ${alignCorners} ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(${xWidth}) - 1),\n ${alignCorners} ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeighborProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n // When align corners is false, we rounds the value with floor.\n const roundBase = alignCorners ? '0.5' : '0.0';\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${roundBase})));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class ReverseProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(xShape: number[], axis: number[]) {\n const rank = xShape.length;\n if (rank > 4) {\n throw new Error(\n `WebGL backend: Reverse of rank-${rank} tensor is not yet supported`);\n }\n this.outputShape = xShape;\n\n if (rank === 1) {\n this.userCode = `\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(${xShape[0]} - coord - 1));\n }\n `;\n return;\n }\n const getInCoord = (i: number) => {\n if (axis.indexOf(i) !== -1 && xShape[i] !== 1) {\n return `${xShape[i]} - coords[${i}] - 1`;\n }\n return `coords[${i}]`;\n };\n const inCoords = xShape.map((_, i) => getInCoord(i)).join(',');\n const type = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${type} coords = getOutputCoords();\n setOutput(getX(${inCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {SegOpInfo} from '../../ops/segment_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class SegmentOpProgram implements GPGPUProgram {\n variableNames = ['x', 'segmentIds'];\n outputShape: number[];\n userCode: string;\n\n constructor(segOpInfo: SegOpInfo, segOpType: 'unsortedSegmentSum') {\n const windowSize = segOpInfo.windowSize;\n const batchSize = segOpInfo.batchSize;\n const inSize = segOpInfo.inSize;\n const numSegments = segOpInfo.numSegments;\n const outSize = numSegments * Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n const initializationValue = '0.0';\n const returnValue = `sumValue`;\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n const updateSnippet = `\n sumValue += dot(values, filter);\n `;\n\n let checkValueOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkValueOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n\n let checkSegmentIdOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkSegmentIdOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return -1.0;\n }\n `;\n }\n\n this.userCode = `\n const float initializationValue = ${initializationValue};\n\n float getValue(int batch, int inIdx) {\n ${checkValueOutOfBounds}\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n ${checkSegmentIdOutOfBounds}\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n ${numSegments})) * float(${windowSize}));\n int currentSeg = int(mod(float(outIdx), float(${numSegments})));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SelectProgram implements GPGPUProgram {\n variableNames = ['c', 'a', 'b'];\n outputShape: number[];\n userCode: string;\n\n constructor(cRank: number, shape: number[], rank: number) {\n this.outputShape = shape;\n\n let cCoords;\n let abCoords;\n if (rank > 4) {\n throw Error(`Where for rank ${rank} is not yet supported`);\n }\n\n if (rank === 1) {\n abCoords = `resRC`;\n cCoords = `resRC`;\n } else {\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n const cCoordVars = [];\n const abCoordVars = [];\n for (let i = 0; i < shape.length; i++) {\n abCoordVars.push(`${currentCoords[i]}`);\n if (i < cRank) {\n cCoordVars.push(`${currentCoords[i]}`);\n }\n }\n cCoords = cCoordVars.join();\n abCoords = abCoordVars.join();\n }\n\n const dtype = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n float cVal = getC(${cCoords});\n if (cVal >= 1.0) {\n setOutput(getA(${abCoords}));\n } else {\n setOutput(getB(${abCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SliceProgram implements GPGPUProgram {\n variableNames = ['source'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(destSize: number[]) {\n this.outputShape = destSize;\n this.rank = destSize.length;\n\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getCoords(this.rank);\n\n this.userCode = `\n uniform ${dtype} start;\n\n void main() {\n ${dtype} sourceLoc = start + getOutputCoords();\n setOutput(getSource(${sourceCoords}));\n }\n `;\n }\n\n getCustomSetupFunc(start: number[]) {\n if (start.length !== this.rank) {\n throw Error(\n `The rank (${this.rank}) of the program must match the ` +\n `length of start (${start.length})`);\n }\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'start');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n if (this.rank === 1) {\n gpgpu.gl.uniform1i(this.startLoc, start[0]);\n } else if (this.rank === 2) {\n gpgpu.gl.uniform2i(this.startLoc, start[0], start[1]);\n } else if (this.rank === 3) {\n gpgpu.gl.uniform3i(this.startLoc, start[0], start[1], start[2]);\n } else if (this.rank === 4) {\n gpgpu.gl.uniform4i(\n this.startLoc, start[0], start[1], start[2], start[3]);\n } else {\n throw Error(`Slicing for rank ${this.rank} is not yet supported`);\n }\n };\n }\n}\n\nfunction getCoords(rank: number): string {\n if (rank === 1) {\n return 'sourceLoc';\n } else if (rank === 2) {\n return 'sourceLoc.x, sourceLoc.y';\n } else if (rank === 3) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z';\n } else if (rank === 4) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w';\n } else {\n throw Error(`Slicing for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class StridedSliceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(begin: number[], strides: number[], shape: number[]) {\n this.outputShape = shape;\n this.rank = shape.length;\n const dtype = getCoordsDataType(this.rank);\n\n let newCoords = '';\n if (this.rank === 1) {\n newCoords = 'coords * strides + begin';\n } else {\n newCoords =\n shape.map((_, i) => `coords[${i}] * strides[${i}] + begin[${i}]`)\n .join(',');\n }\n\n this.userCode = `\n ${dtype} begin = ${dtype}(${begin});\n ${dtype} strides = ${dtype}(${strides});\n\n void main() {\n ${dtype} coords = getOutputCoords();\n setOutput(getX(${newCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {PhysicalTextureType, TextureUsage} from './tex_util';\n\nexport class TextureManager {\n private numUsedTextures = 0;\n private numFreeTextures = 0;\n private freeTextures: {[shape: string]: WebGLTexture[]} = {};\n private logEnabled = false;\n private usedTextures: {[shape: string]: WebGLTexture[]} = {};\n\n constructor(private gpgpu: GPGPUContext) {}\n\n acquireTexture(shapeRC: [number, number], usage: TextureUsage): WebGLTexture {\n const physicalTexType = getPhysicalFromLogicalTextureType(usage);\n\n const shapeKey = getKeyFromTextureShape(shapeRC, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n if (!(shapeKey in this.usedTextures)) {\n this.usedTextures[shapeKey] = [];\n }\n\n if (this.freeTextures[shapeKey].length > 0) {\n this.numFreeTextures--;\n this.numUsedTextures++;\n this.log();\n const newTexture = this.freeTextures[shapeKey].shift();\n this.usedTextures[shapeKey].push(newTexture);\n return newTexture;\n }\n this.numUsedTextures++;\n this.log();\n\n let newTexture: WebGLTexture;\n if (physicalTexType === PhysicalTextureType.FLOAT32) {\n newTexture =\n this.gpgpu.createFloat32MatrixTexture(shapeRC[0], shapeRC[1]);\n } else if (physicalTexType === PhysicalTextureType.FLOAT16) {\n newTexture =\n this.gpgpu.createFloat16MatrixTexture(shapeRC[0], shapeRC[1]);\n\n } else if (physicalTexType === PhysicalTextureType.UNSIGNED_BYTE) {\n newTexture =\n this.gpgpu.createUnsignedBytesMatrixTexture(shapeRC[0], shapeRC[1]);\n }\n this.usedTextures[shapeKey].push(newTexture);\n\n return newTexture;\n }\n\n releaseTexture(\n texture: WebGLTexture, shape: [number, number],\n logicalTexType: TextureUsage): void {\n const physicalTexType = getPhysicalFromLogicalTextureType(logicalTexType);\n const shapeKey = getKeyFromTextureShape(shape, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n this.freeTextures[shapeKey].push(texture);\n this.numFreeTextures++;\n this.numUsedTextures--;\n const texList = this.usedTextures[shapeKey];\n const texIndex = texList.indexOf(texture);\n if (texIndex < 0) {\n throw new Error(\n 'Cannot release a texture that was never provided by this ' +\n 'texture manager');\n }\n texList.splice(texIndex, 1);\n this.log();\n }\n\n private log() {\n if (!this.logEnabled) {\n return;\n }\n const total = this.numFreeTextures + this.numUsedTextures;\n console.log(\n 'Free/Used', `${this.numFreeTextures} / ${this.numUsedTextures}`,\n `(${total})`);\n }\n\n getNumUsedTextures(): number {\n return this.numUsedTextures;\n }\n\n getNumFreeTextures(): number {\n return this.numFreeTextures;\n }\n\n dispose() {\n if (this.freeTextures == null) {\n // Already disposed.\n return;\n }\n for (const texShape in this.freeTextures) {\n this.freeTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n for (const texShape in this.usedTextures) {\n this.usedTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n this.freeTextures = null;\n this.usedTextures = null;\n this.numUsedTextures = 0;\n this.numFreeTextures = 0;\n }\n}\n\nfunction getPhysicalFromLogicalTextureType(logicalTexType: TextureUsage):\n PhysicalTextureType {\n if (logicalTexType === TextureUsage.DOWNLOAD ||\n logicalTexType === TextureUsage.PIXELS) {\n return PhysicalTextureType.UNSIGNED_BYTE;\n } else if (logicalTexType === TextureUsage.UPLOAD) {\n return PhysicalTextureType.FLOAT32;\n } else if (logicalTexType === TextureUsage.RENDER) {\n return ENV.get('WEBGL_RENDER_FLOAT32_ENABLED') ?\n PhysicalTextureType.FLOAT32 :\n PhysicalTextureType.FLOAT16;\n }\n throw new Error(`Unknown logical texture type ${logicalTexType}`);\n}\n\nfunction getKeyFromTextureShape(\n shapeRowsCol: [number, number],\n physicalTexType: PhysicalTextureType): string {\n return `${shapeRowsCol[0]}_${shapeRowsCol[1]}_${physicalTexType}`;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TileProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], reps: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[i] * reps[i];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[]): string {\n const rank = aShape.length;\n if (rank > 5) {\n throw Error(`Tile for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `imod(resRC, ${aShape[0]})`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n sourceCoords.push(`imod(${currentCoords[i]}, ${aShape[i]})`);\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TransposeProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], newDim: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[newDim[i]];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const switched = getSwitchedCoords(newDim);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${switched}));\n }\n `;\n }\n}\n\nfunction getSwitchedCoords(newDim: number[]): string {\n const rank = newDim.length;\n if (rank > 6) {\n throw Error(`Transpose for rank ${rank} is not yet supported`);\n }\n const originalOrder =\n ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u', 'resRC.v'];\n const switchedCoords = new Array(rank);\n for (let i = 0; i < newDim.length; i++) {\n switchedCoords[newDim[i]] = originalOrder[i];\n }\n return switchedCoords.join();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const ERF_P = 0.3275911;\nexport const ERF_A1 = 0.254829592;\nexport const ERF_A2 = -0.284496736;\nexport const ERF_A3 = 1.421413741;\nexport const ERF_A4 = -1.453152027;\nexport const ERF_A5 = 1.061405429;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const SELU_SCALEALPHA = 1.7580993408473768599402175208123;\nexport const SELU_SCALE = 1.0507009873554804934193349852946;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as erf_util from '../../ops/erf_util';\nimport * as selu_util from '../../ops/selu_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {GPGPUContext} from './gpgpu_context';\n\nexport class UnaryOpProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(aShape: number[], opSnippet: string) {\n this.outputShape = aShape;\n this.userCode = `\n uniform float NAN;\n float unaryOperation(float x) {\n ${opSnippet}\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n\nconst CHECK_NAN_SNIPPET = `if (isNaN(x)) return x;`;\n\nexport const ABS = `return abs(x);`;\n\nexport const RELU = CHECK_NAN_SNIPPET + `\n return (x < 0.0) ? 0.0 : x;\n`;\n\nexport const ELU = `return (x >= 0.0) ? x : (exp(x) - 1.0);`;\n\nexport const SELU = `\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = ${selu_util.SELU_SCALEALPHA};\n float scale = ${selu_util.SELU_SCALE};\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n`;\n\nexport function STEP(alpha = 0.0) {\n return CHECK_NAN_SNIPPET + `\n return x > 0.0 ? 1.0 : float(${alpha});\n `;\n}\n\nexport const NEG = `return -x;`;\n\nexport const CEIL = `return ceil(x);`;\n\nexport const FLOOR = `return floor(x);`;\n\nexport const SIGN = `\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n`;\n\nexport const ROUND = `\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n`;\n\nexport const EXP = `return exp(x);`;\n\nexport const EXPM1 = `return exp(x) - 1.0;`;\n\nexport const LOG = `if (x < 0.0) return NAN;\n return log(x);`;\n\nexport const LOG1P = `return log(1.0 + x);`;\n\nexport const SQRT = `return sqrt(x);`;\n\nexport const RSQRT = `return inversesqrt(x);`;\n\nexport const SIGMOID = `return 1.0 / (1.0 + exp(-1.0 * x));`;\n\n/**\n * mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n *\n * epsilon is the difference between 1.0 and the next representable\n * float. For a single precision 32 bit float this should be 2^-23, see:\n * https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n *\n * too_large = (x > -threshold) is value above which exp(x) may overflow\n * but softplus(x) == x is within machine epsilon\n *\n * too_small = (x < threshold) is value below which exp(x) may underflow,\n * but softplus(x) == exp(x) is within machine epsilon.\n */\nexport const SOFTPLUS = `\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n`;\n\nexport const SIN = CHECK_NAN_SNIPPET + `\n return sin(x);\n`;\n\nexport const COS = CHECK_NAN_SNIPPET + `\n return cos(x);\n`;\n\nexport const TAN = `return tan(x);`;\n\nexport const ASIN = `return asin(x);`;\n\nexport const ACOS = `return acos(x);`;\n\nexport const ATAN = CHECK_NAN_SNIPPET + `\n return atan(x);\n`;\n\nexport const SINH = `\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n`;\n\nexport const COSH = `\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n`;\n\nexport const TANH = `\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n`;\n\nexport const ASINH = `return log(x + sqrt(x * x + 1.0));`;\n\nexport const ACOSH = CHECK_NAN_SNIPPET + `\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));`;\n\nexport const ATANH = CHECK_NAN_SNIPPET + `\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;`;\n\nexport const ERF = `\n // Error function is calculated approximately with elementary function.\n // See \"Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\n float p = ${erf_util.ERF_P};\n float a1 = ${erf_util.ERF_A1};\n float a2 = ${erf_util.ERF_A2};\n float a3 = ${erf_util.ERF_A3};\n float a4 = ${erf_util.ERF_A4};\n float a5 = ${erf_util.ERF_A5};\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n`;\n\nexport const SQUARE = `return x * x;`;\n\nexport const RECIPROCAL = `return 1.0 / x;`;\n\nexport const LOGICAL_NOT = `return float(!(x >= 1.0));`;\n\nexport const TO_INT = `return float(int(x));`;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, sizeFromShape} from '../util';\nimport {parseAxisParam} from './axis_util';\nimport * as concat_util from './concat_util';\nimport {op} from './operation';\n\n/**\n * Concatenates a list of `Tensor1D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(3) = |r1, g1, b1|\n * B: shape(2) = |r2, g2|\n * C = tf.concat1d([A, B]) == |r1, g1, b1, r2, g2|\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @return The concatenated array.\n */\nfunction concat1d_(tensors: Tensor1D[]|TensorLike[]): Tensor1D {\n return concat(tensors, 0 /* axis */);\n}\n\n/**\n * Concatenates a list of `Tensor2D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat2d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C = shape(2, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concatenate along.\n * @return The concatenated array.\n */\nfunction concat2d_(tensors: Tensor2D[]|TensorLike[], axis: number): Tensor2D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor3D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 1, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat3d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C: shape(2, 2, 3) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * if axis = 2:\n * C = shape(2, 1, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat3d_(tensors: Tensor3D[]|TensorLike[], axis: number): Tensor3D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor4D`s along an axis. See `concat` for details.\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat4d_(tensors: Tensor4D[]|TensorLike[], axis: number): Tensor4D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor`s along a given axis.\n *\n * The tensors ranks and types must match, and their sizes must match in all\n * dimensions except `axis`.\n *\n * Also available are stricter rank-specific methods that assert that\n * `tensors` are of the given rank:\n * - `tf.concat1d`\n * - `tf.concat2d`\n * - `tf.concat3d`\n * - `tf.concat4d`\n *\n * Except `tf.concat1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * a.concat(b).print(); // or a.concat(b)\n * ```\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.concat([a, b, c]).print();\n * ```\n *\n * ```js\n * const a = tf.tensor2d([[1, 2], [10, 20]]);\n * const b = tf.tensor2d([[3, 4], [30, 40]]);\n * const axis = 1;\n * tf.concat([a, b], axis).print();\n * ```\n * @param tensors A list of tensors to concatenate.\n * @param axis The axis to concate along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction concat_(tensors: T[]|TensorLike[], axis = 0): T {\n assert(tensors.length >= 1, 'Pass at least one tensor to concat');\n const $tensors = convertToTensorArray(tensors, 'tensors', 'concat');\n\n let result = $tensors[0] as T;\n if ($tensors.length === 1) {\n return result;\n }\n const axes = parseAxisParam(axis, result.shape);\n\n for (let i = 1; i < $tensors.length; ++i) {\n result = concat2Tensors(result, $tensors[i], axes[0]) as T;\n }\n return result;\n}\n\nfunction concat2Tensors(a: T, b: T, axis: number): T {\n concat_util.assertParams(a.shape, b.shape, axis);\n const outShape = concat_util.computeOutShape(a.shape, b.shape, axis);\n\n // Do the reshape.\n const a2D = a.as2D(-1, sizeFromShape(a.shape.slice(axis)));\n const b2D = b.as2D(-1, sizeFromShape(b.shape.slice(axis)));\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n const {aBegin, aSize, bBegin, bSize} =\n concat_util.computeGradientSliceShapes(a2D.shape, b2D.shape);\n const der = (dy: Tensor2D) => {\n return {a: () => dy.slice(aBegin, aSize), b: () => dy.slice(bBegin, bSize)};\n };\n const res = ENV.engine.runKernel(\n backend => backend.concat(a2D, b2D), {a: a2D, b: b2D}, der);\n return res.reshape(outShape) as T;\n}\n\nexport const concat = op({concat_});\nexport const concat1d = op({concat1d_});\nexport const concat2d = op({concat2d_});\nexport const concat3d = op({concat3d_});\nexport const concat4d = op({concat4d_});\n","// A port of an algorithm by Johannes Baagøe , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baagøe \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n// \n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n// \n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = data.toString();\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorshift7\" algorithm by\n// François Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n","// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n","// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","/*\nCopyright 2014 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\nvar global = this,\n width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\nmath['seed' + rngname] = seedrandom;\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n}\n\n// End anonymous scope, and pass initial values.\n})(\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n","// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by François Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\n\nexport interface RandGauss {\n nextValue(): number;\n}\n\nexport interface RandNormalDataTypes {\n float32: Float32Array;\n int32: Int32Array;\n}\n\n// https://en.wikipedia.org/wiki/Marsaglia_polar_method\nexport class MPRandGauss implements RandGauss {\n private mean: number;\n private stdDev: number;\n private nextVal: number;\n private dtype?: keyof RandNormalDataTypes;\n private truncated?: boolean;\n private upper?: number;\n private lower?: number;\n private random: seedrandom.prng;\n\n constructor(\n mean: number, stdDeviation: number, dtype?: keyof RandNormalDataTypes,\n truncated?: boolean, seed?: number) {\n this.mean = mean;\n this.stdDev = stdDeviation;\n this.dtype = dtype;\n this.nextVal = NaN;\n this.truncated = truncated;\n if (this.truncated) {\n this.upper = this.mean + this.stdDev * 2;\n this.lower = this.mean - this.stdDev * 2;\n }\n const seedValue = seed ? seed : Math.random();\n this.random = seedrandom.alea(seedValue.toString());\n }\n\n /** Returns next sample from a gaussian distribution. */\n public nextValue(): number {\n if (!isNaN(this.nextVal)) {\n const value = this.nextVal;\n this.nextVal = NaN;\n return value;\n }\n\n let resultX: number, resultY: number;\n let isValid = false;\n while (!isValid) {\n let v1: number, v2: number, s: number;\n do {\n v1 = 2 * this.random() - 1;\n v2 = 2 * this.random() - 1;\n s = v1 * v1 + v2 * v2;\n } while (s >= 1 || s === 0);\n\n const mul = Math.sqrt(-2.0 * Math.log(s) / s);\n resultX = this.mean + this.stdDev * v1 * mul;\n resultY = this.mean + this.stdDev * v2 * mul;\n\n if (!this.truncated || this.isValidTruncated(resultX)) {\n isValid = true;\n }\n }\n\n if (!this.truncated || this.isValidTruncated(resultY)) {\n this.nextVal = this.convertValue(resultY);\n }\n return this.convertValue(resultX);\n }\n\n /** Handles proper rounding for non floating point numbers. */\n private convertValue(value: number): number {\n if (this.dtype == null || this.dtype === 'float32') {\n return value;\n }\n return Math.round(value);\n }\n\n /** Returns true if less than 2-standard-deviations from the mean. */\n private isValidTruncated(value: number): boolean {\n return value <= this.upper && value >= this.lower;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {DataType, Rank, ShapeMap, TensorLike, TensorLike1D, TypedArray} from '../types';\nimport * as util from '../util';\nimport {getAxesPermutation, getInnerMostAxes, parseAxisParam} from './axis_util';\nimport {concat} from './concat';\nimport {op} from './operation';\nimport {MPRandGauss} from './rand';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Creates a new tensor with the same values and shape as the specified\n * tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n *\n * x.clone().print();\n * ```\n *\n * @param x The tensor to clone.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction clone_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'clone');\n const der = (dy: T) => {\n return {$x: () => dy.toFloat()};\n };\n\n return ENV.engine.runKernel(\n backend =>\n Tensor.make($x.shape, {dataId: $x.dataId}, $x.dtype) as T,\n {$x}, der) as T;\n}\n\n/**\n * Create an identity matrix.\n *\n * @param numRows Number of rows.\n * @param numColumns Number of columns. Defaults to `numRows`.\n * @param batchShape If provided, will add the batch shape to the beginning\n * of the shape of the returned `Tensor` by repeating the identity\n * matrix.\n * @param dtype Data type.\n * @returns Identity matrix of the specified size and data type, possibly\n * with batch repetition if `batchShape` is specified.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction eye_(\n numRows: number, numColumns?: number,\n batchShape?:\n [\n number\n ]|[number,\n number]|[number, number, number]|[number, number, number, number],\n dtype: DataType = 'float32'): Tensor2D {\n if (numColumns == null) {\n numColumns = numRows;\n }\n const buff = buffer([numRows, numColumns], dtype);\n const n = numRows <= numColumns ? numRows : numColumns;\n for (let i = 0; i < n; ++i) {\n buff.set(1, i, i);\n }\n const out = buff.toTensor().as2D(numRows, numColumns);\n if (batchShape == null) {\n return out;\n } else {\n if (batchShape.length === 1) {\n return tile(expandDims(out, 0), [batchShape[0], 1, 1]);\n } else if (batchShape.length === 2) {\n return tile(\n expandDims(expandDims(out, 0), 0),\n [batchShape[0], batchShape[1], 1, 1]);\n } else if (batchShape.length === 3) {\n return tile(\n expandDims(expandDims(expandDims(out, 0), 0), 0),\n [batchShape[0], batchShape[1], batchShape[2], 1, 1]);\n } else {\n throw new Error(\n `eye() currently supports only 1D and 2D ` +\n // tslint:disable-next-line:no-any\n `batchShapes, but received ${(batchShape as any).length}D.`);\n }\n }\n}\n\n/**\n * Creates a `Tensor` with values sampled from a normal distribution.\n *\n * ```js\n * tf.randomNormal([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, false /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a truncated normal\n * distribution.\n *\n * ```js\n * tf.truncatedNormal([2, 2]).print();\n * ```\n *\n * The generated values follow a normal distribution with specified mean and\n * standard deviation, except that values whose magnitude is more than 2\n * standard deviations from the mean are dropped and re-picked.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output tensor.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction truncatedNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, true /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a uniform distribution.\n *\n * The generated values follow a uniform distribution in the range [minval,\n * maxval). The lower bound minval is included in the range, while the upper\n * bound maxval is excluded.\n *\n * ```js\n * tf.randomUniform([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param minval The lower bound on the range of random values to generate.\n * Defaults to 0.\n * @param maxval The upper bound on the range of random values to generate.\n * Defaults to 1.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomUniform_(\n shape: ShapeMap[R], minval = 0, maxval = 1,\n dtype: DataType = 'float32'): Tensor {\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = util.randUniform(minval, maxval);\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a random number generator\n * function defined by the user.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param randFunction A random number generator function which is called\n * for each element in the output tensor.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\nfunction rand_(\n shape: ShapeMap[R], randFunction: () => number,\n dtype?: DataType): Tensor {\n const size = util.sizeFromShape(shape);\n\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n\n for (let i = 0; i < size; i++) {\n values[i] = randFunction();\n }\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with values drawn from a multinomial distribution.\n *\n * ```js\n * const probs = tf.tensor([.75, .25]);\n * tf.multinomial(probs, 3).print();\n * ```\n *\n * @param logits 1D array with unnormalized log-probabilities, or\n * 2D array of shape `[batchSize, numOutcomes]`. See the `normalized`\n * parameter.\n * @param numSamples Number of samples to draw for each row slice.\n * @param seed The seed number.\n * @param normalized Whether the provided `logits` are normalized true\n * probabilities (sum to 1). Defaults to false.\n * @return 1D array of shape `[numSamples]`, or 2D array of shape\n * `[batchSize, numSamples]`, depending on the rank of the input.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction multinomial_(\n logits: Tensor1D|Tensor2D|TensorLike, numSamples: number, seed?: number,\n normalized = false): Tensor1D|Tensor2D {\n const $logits = convertToTensor(logits, 'logits', 'multinomial');\n const numOutcomes = $logits.size;\n const origRank = $logits.rank;\n if (numOutcomes < 2) {\n throw new Error(\n `Error in multinomial: you need at least 2 outcomes, but got ` +\n `${numOutcomes}.`);\n }\n if (origRank > 2) {\n throw new Error(`Rank of probabilities must be 1 or 2, but is ${origRank}`);\n }\n seed = seed || Math.random();\n const logits2D = origRank === 1 ? $logits.as2D(1, -1) : $logits as Tensor2D;\n const res = ENV.engine.runKernel(\n backend => backend.multinomial(logits2D, normalized, numSamples, seed),\n {logits2D});\n\n return origRank === 1 ? res.as1D() : res;\n}\n\n/**\n * Creates a one-hot `Tensor`. The locations represented by `indices` take\n * value `onValue` (defaults to 1), while all other locations take value\n * `offValue` (defaults to 0).\n *\n * ```js\n * tf.oneHot(tf.tensor1d([0, 1], 'int32'), 3).print();\n * ```\n *\n * @param indices `Tensor1D` of indices with dtype `int32`.\n * @param depth The depth of the one hot dimension.\n * @param onValue A number used to fill in output when the index matches\n * the location.\n * @param offValue A number used to fill in the output when the index does\n * not match the location.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction oneHot_(\n indices: Tensor1D|TensorLike1D, depth: number, onValue = 1,\n offValue = 0): Tensor2D {\n const $indices = convertToTensor(indices, 'indices', 'oneHot', 'int32');\n util.assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n\n if (depth < 2) {\n throw new Error(`Error in oneHot: depth must be >=2, but it is ${depth}`);\n }\n return ENV.engine.runKernel(\n backend => backend.oneHot($indices, depth, onValue, offValue),\n {$indices});\n}\n\n/**\n * Creates a `Tensor` from an image.\n *\n * ```js\n * const image = new ImageData(1, 1);\n * image.data[0] = 100;\n * image.data[1] = 150;\n * image.data[2] = 200;\n * image.data[3] = 255;\n *\n * tf.fromPixels(image).print();\n * ```\n *\n * @param pixels The input image to construct the tensor from. The\n * supported image types are all 4-channel.\n * @param numChannels The number of channels of the output tensor. A\n * numChannels value less than 4 allows you to ignore channels. Defaults to\n * 3 (ignores alpha channel of input image).\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fromPixels_(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels = 3): Tensor3D {\n if (numChannels > 4) {\n throw new Error(\n 'Cannot construct Tensor with more than 4 channels from pixels.');\n }\n return ENV.engine.fromPixels(pixels, numChannels);\n}\n\n/**\n * Draws a `Tensor` of pixel values to a byte array or optionally a\n * canvas.\n *\n * When the dtype of the input is 'float32', we assume values in the range\n * [0-1]. Otherwise, when input is 'int32', we assume values in the range\n * [0-255].\n *\n * Returns a promise that resolves when the canvas has been drawn to.\n *\n * @param img A rank-2 or rank-3 tensor. If rank-2, draws grayscale. If\n * rank-3, must have depth of 1, 3 or 4. When depth of 1, draws\n * grayscale. When depth of 3, we draw with the first three components of\n * the depth dimension corresponding to r, g, b and alpha = 1. When depth of\n * 4, all four components of the depth dimension correspond to r, g, b, a.\n * @param canvas The canvas to draw to.\n */\n/** @doc {heading: 'Visualization'} */\nasync function toPixels(\n img: Tensor2D|Tensor3D|TensorLike,\n canvas?: HTMLCanvasElement): Promise {\n const $img = convertToTensor(img, 'img', 'toPixels', 'int32');\n if ($img.rank !== 2 && $img.rank !== 3) {\n throw new Error(\n `toPixels only supports rank 2 or 3 tensors, got rank ${$img.rank}.`);\n }\n const [height, width] = $img.shape.slice(0, 2);\n const depth = $img.rank === 2 ? 1 : $img.shape[2];\n\n if (depth > 4 || depth === 2) {\n throw new Error(\n `toPixels only supports depth of size ` +\n `1, 3 or 4 but got ${depth}`);\n }\n\n const minTensor = $img.min();\n const maxTensor = $img.max();\n const min = (await minTensor.data())[0];\n const max = (await maxTensor.data())[0];\n minTensor.dispose();\n maxTensor.dispose();\n if ($img.dtype === 'float32') {\n if (min < 0 || max > 1) {\n throw new Error(\n `Tensor values for a float32 Tensor must be in the ` +\n `range [0 - 1] but got range [${min} - ${max}].`);\n }\n } else if ($img.dtype === 'int32') {\n if (min < 0 || max > 255) {\n throw new Error(\n `Tensor values for a int32 Tensor must be in the ` +\n `range [0 - 255] but got range [${min} - ${max}].`);\n }\n } else {\n throw new Error(\n `Unsupported type for toPixels: ${$img.dtype}.` +\n ` Please use float32 or int32 tensors.`);\n }\n\n const data = await $img.data();\n const multiplier = $img.dtype === 'float32' ? 255 : 1;\n const bytes = new Uint8ClampedArray(width * height * 4);\n\n for (let i = 0; i < height * width; ++i) {\n let r, g, b, a;\n if (depth === 1) {\n r = data[i] * multiplier;\n g = data[i] * multiplier;\n b = data[i] * multiplier;\n a = 255;\n } else if (depth === 3) {\n r = data[i * 3] * multiplier;\n g = data[i * 3 + 1] * multiplier;\n b = data[i * 3 + 2] * multiplier;\n a = 255;\n } else if (depth === 4) {\n r = data[i * 4] * multiplier;\n g = data[i * 4 + 1] * multiplier;\n b = data[i * 4 + 2] * multiplier;\n a = data[i * 4 + 3] * multiplier;\n }\n\n const j = i * 4;\n bytes[j + 0] = Math.round(r);\n bytes[j + 1] = Math.round(g);\n bytes[j + 2] = Math.round(b);\n bytes[j + 3] = Math.round(a);\n }\n\n if (canvas != null) {\n canvas.width = width;\n canvas.height = height;\n const ctx = canvas.getContext('2d');\n const imageData = new ImageData(bytes, width, height);\n ctx.putImageData(imageData, 0, 0);\n }\n if ($img !== img) {\n $img.dispose();\n }\n return bytes;\n}\n\n/**\n * Reshapes a `Tensor` to a given shape.\n *\n * Given a input tensor, returns a new tensor with the same values as the\n * input tensor with shape `shape`.\n *\n * If one component of shape is the special value -1, the size of that\n * dimension is computed so that the total size remains constant. In\n * particular, a shape of [-1] flattens into 1-D. At most one component of\n * shape can be -1.\n *\n * If shape is 1-D or higher, then the operation returns a tensor with shape\n * shape filled with the values of tensor. In this case, the number of\n * elements implied by shape must be the same as the number of elements in\n * tensor.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.reshape([2, 2]).print();\n * ```\n *\n * @param x The input tensor to be reshaped.\n * @param shape An array of integers defining the output tensor shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction reshape_(\n x: Tensor|TensorLike, shape: ShapeMap[R2]): Tensor {\n const $x = convertToTensor(x, 'x', 'reshape');\n shape = util.inferFromImplicitShape(shape, $x.size);\n util.assert(\n $x.size === util.sizeFromShape(shape),\n 'new shape and old shape must have the same number of elements.');\n\n const grad = (dy: Tensor) => {\n return {$x: () => dy.reshape($x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.reshape($x, shape), {$x}, grad);\n}\n\n/**\n * Removes dimensions of size 1 from the shape of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4], [1, 1, 4]);\n * x.squeeze().print();\n * ```\n *\n * @param x The input tensor to be squeezed.\n * @param axis An optional list of numbers. If specified, only\n * squeezes the dimensions listed. The dimension index starts at 0. It\n * is an error to squeeze a dimension that is not 1.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction squeeze_(x: Tensor|TensorLike, axis?: number[]): T {\n const $x = convertToTensor(x, 'x', 'squeeze');\n return reshape($x, util.squeezeShape($x.shape, axis).newShape) as T;\n}\n\n/**\n * Casts a `Tensor` to a new dtype.\n *\n * ```js\n * const x = tf.tensor1d([1.5, 2.5, 3]);\n * tf.cast(x, 'int32').print();\n * ```\n * @param x The input tensor to be casted.\n * @param dtype The dtype to cast the input tensor to.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction cast_(x: T|TensorLike, dtype: DataType): T {\n const $x = convertToTensor(x, 'x', 'cast');\n\n const grad = (dy: T) => {\n return {$x: () => dy.clone()};\n };\n return ENV.engine.runKernel(backend => backend.cast($x, dtype), {$x}, grad) as\n T;\n}\n\n/**\n * Construct an tensor by repeating it the number of times given by reps.\n *\n * This operation creates a new tensor by replicating `input` `reps`\n * times. The output tensor's i'th dimension has `input.shape[i] *\n * reps[i]` elements, and the values of `input` are replicated\n * `reps[i]` times along the i'th dimension. For example, tiling\n * `[a, b, c, d]` by `[2]` produces `[a, b, c, d, a, b, c, d]`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n *\n * a.tile([2]).print(); // or a.tile([2])\n * ```\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.tile([1, 2]).print(); // or a.tile([1, 2])\n * ```\n * @param x The tensor to tile.\n * @param reps Determines the number of replications per dimension.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction tile_(x: T|TensorLike, reps: number[]): T {\n const $x = convertToTensor(x, 'x', 'tile');\n\n util.assert(\n $x.rank === reps.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of reps ${reps}.`);\n const grad = (dy: T) => {\n const derX = () => {\n let xGrad = zerosLike($x);\n // TODO(cais): Maybe reduce memory footprint by avoiding repeated\n // slicing.\n if ($x.rank === 1) {\n for (let i = 0; i < reps[0]; ++i) {\n xGrad = xGrad.add(dy.slice([i * $x.shape[0]], [$x.shape[0]]));\n }\n } else if ($x.rank === 2) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1]],\n [$x.shape[0], $x.shape[1]]));\n }\n }\n } else if ($x.rank === 3) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1], k * $x.shape[2]],\n [$x.shape[0], $x.shape[1], $x.shape[2]]));\n }\n }\n }\n } else if ($x.rank === 4) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n for (let l = 0; l < reps[3]; ++l) {\n xGrad = xGrad.add(dy.slice(\n [\n i * $x.shape[0], j * $x.shape[1], k * $x.shape[2],\n l * $x.shape[3]\n ],\n [$x.shape[0], $x.shape[1], $x.shape[2], $x.shape[3]]));\n }\n }\n }\n }\n } else {\n throw new Error(\n `Gradient for tile operation is not implemented for rank-` +\n `${$x.rank} tensors yet.`);\n }\n return xGrad;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(backend => backend.tile($x, reps), {$x}, grad);\n}\n\n/**\n * Pads a `Tensor1D` with a given value and paddings. See `pad` for details.\n */\nfunction pad1d_(\n x: Tensor1D|TensorLike, paddings: [number, number],\n constantValue = 0): Tensor1D {\n util.assert(\n paddings.length === 2,\n 'Invalid number of paddings. Must be length of 2.');\n return pad(x, [paddings], constantValue);\n}\n\n/**\n * Pads a `Tensor2D` with a given value and paddings. See `pad` for details.\n */\nfunction pad2d_(\n x: Tensor2D|TensorLike, paddings: [[number, number], [number, number]],\n constantValue = 0): Tensor2D {\n util.assert(\n paddings.length === 2 && paddings[0].length === 2 &&\n paddings[1].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor3D` with a given value and paddings. See `pad` for details.\n */\nfunction pad3d_(\n x: Tensor3D|TensorLike,\n paddings: [[number, number], [number, number], [number, number]],\n constantValue = 0): Tensor3D {\n util.assert(\n paddings.length === 3 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor4D` with a given value and paddings. See `pad` for details.\n */\nfunction pad4d_(\n x: Tensor4D|TensorLike,\n paddings:\n [\n [number, number], [number, number], [number, number],\n [number, number]\n ],\n constantValue = 0): Tensor4D {\n util.assert(\n paddings.length === 4 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2 &&\n paddings[3].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor` with a given value and paddings.\n *\n * This operation currently only implements the `CONSTANT` mode.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `paddings` is of given length.\n * - `tf.pad1d`\n * - `tf.pad2d`\n * - `tf.pad3d`\n * - `tf.pad4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.pad([[1, 2]]).print();\n * ```\n * @param x The tensor to pad.\n * @param paddings An array of length `R` (the rank of the tensor), where\n * each element is a length-2 tuple of ints `[padBefore, padAfter]`,\n * specifying how much to pad along each dimension of the tensor.\n * @param constantValue The pad value to use. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction pad_(\n x: T|TensorLike, paddings: Array<[number, number]>, constantValue = 0): T {\n const $x = convertToTensor(x, 'x', 'pad');\n\n if ($x.rank === 0) {\n throw new Error('pad(scalar) is not defined. Pass non-scalar to pad');\n }\n // Pad introduces values around the original tensor, so the gradient\n // slices the original shape out of the gradient.\n const begin = paddings.map(p => p[0]);\n const grad = (dy: T) => {\n return {$x: () => dy.slice(begin, $x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.pad($x, paddings, constantValue), {$x}, grad) as\n T;\n}\n\n/**\n * Stacks a list of rank-`R` `Tensor`s into one rank-`(R+1)` `Tensor`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.stack([a, b, c]).print();\n * ```\n *\n * @param tensors A list of tensor objects with the same shape and dtype.\n * @param axis The axis to stack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction stack_(tensors: T[]|TensorLike[], axis = 0): Tensor {\n const $tensors = convertToTensorArray(tensors, 'tensors', 'stack');\n\n util.assert($tensors.length >= 1, 'Pass at least one tensor to tf.stack');\n if ($tensors.length === 1) {\n return $tensors[0].expandDims(axis);\n }\n const rank = $tensors[0].rank;\n const shape = $tensors[0].shape;\n const dtype = $tensors[0].dtype;\n\n util.assert(axis <= rank, 'Axis must be <= rank of the tensor');\n\n $tensors.forEach(t => {\n util.assertShapesMatch(\n shape, t.shape,\n 'All tensors passed to stack must have matching shapes');\n });\n\n $tensors.forEach(t => {\n util.assert(\n dtype === t.dtype,\n 'All tensors passed to stack must have matching dtypes');\n });\n const expandedTensors = $tensors.map(t => t.expandDims(axis));\n return concat(expandedTensors, axis);\n}\n\n/**\n * This operation reshapes the \"batch\" dimension 0 into `M + 1` dimensions of\n * shape `blockShape + [batch]`, interleaves these blocks back into the grid\n * defined by the spatial dimensions `[1, ..., M]`, to obtain a result with\n * the same rank as the input. The spatial dimensions of this intermediate\n * result are then optionally cropped according to `crops` to produce the\n * output. This is the reverse of `spaceToBatchND`. See below for a precise\n * description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const crops = [[0, 0], [0, 0]];\n *\n * x.batchToSpaceND(blockShape, crops).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param crops A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `crops[i] =\n * [cropStart, cropEnd]` specifies the amount to crop from input dimension `i\n * + 1`, which corresponds to spatial dimension `i`. It is required that\n * `cropStart[i] + cropEnd[i] <= blockShape[i] * inputShape[i + 1]`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Reshape `x` to `reshaped` of shape: `[blockShape[0], ...,\n * blockShape[M-1], batch / prod(blockShape), x.shape[1], ...,\n * x.shape[N-1]]`\n *\n * 2. Permute dimensions of `reshaped`to produce `permuted` of shape `[batch /\n * prod(blockShape),x.shape[1], blockShape[0], ..., x.shape[M],\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 3. Reshape `permuted` to produce `reshapedPermuted` of shape `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0], ..., x.shape[M] *\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 4. Crop the start and end of dimensions `[1, ..., M]` of `reshapedPermuted`\n * according to `crops` to produce the output of shape: `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0] - crops[0,0] - crops[0,1],\n * ..., x.shape[M] * blockShape[M-1] - crops[M-1,0] -\n * crops[M-1,1],x.shape[M+1], ..., x.shape[N-1]]`\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction batchToSpaceND_(\n x: T|TensorLike, blockShape: number[], crops: number[][]): T {\n const $x = convertToTensor(x, 'x', 'batchToSpaceND');\n const prod = blockShape.reduce((a, b) => a * b);\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n crops.length === blockShape.length,\n `crops.shape[0] must be equal to [blockShape] but got ${crops.length}`);\n\n util.assert(\n $x.shape[0] % prod === 0,\n `input tensor batch must be divisible by prod( blockShape )`);\n return ENV.engine.runKernel(\n backend => backend.batchToSpaceND($x, blockShape, crops), {});\n}\n\n/**\n * This operation divides \"spatial\" dimensions [1, ..., M] of the input into\n * a grid of blocks of shape block_shape, and interleaves these blocks with\n * the \"batch\" dimension (0) such that in the output, the spatial\n * dimensions [1, ..., M] correspond to the position within the grid,\n * and the batch dimension combines both the position within a spatial block\n * and the original batch position. Prior to division into blocks,\n * the spatial dimensions of the input are optionally zero padded\n * according to paddings. See below for a precise description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const paddings = [[0, 0], [0, 0]];\n *\n * x.spaceToBatchND(blockShape, paddings).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param paddings A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `paddings[i] =\n * [padStart, padEnd]` specifies the amount to zero-pad from input dimension\n * `i + 1`, which corresponds to spatial dimension `i`.\n * It is required that\n * `(inputShape[i + 1] + padStart + padEnd) % blockShape[i] === 0`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Zero-pad the start and end of dimensions [1, ..., M] of the input\n * according to paddings to produce padded of shape padded_shape.\n *\n * 2. Reshape padded to reshaped_padded of shape:\n * [batch] + [padded_shape[1] / block_shape[0], block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1], block_shape[M-1]] + remaining_shape\n *\n * 3. Permute dimensions of reshaped_padded to produce permuted_\n * reshaped_padded of shape:\n * block_shape + [batch] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n *\n * 4. Reshape permuted_reshaped_padded to flatten block_shape into the\n * batch dimension, producing an output tensor of shape:\n * [batch * prod(block_shape)] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction spaceToBatchND_(\n x: T|TensorLike, blockShape: number[], paddings: number[][]): T {\n const $x = convertToTensor(x, 'x', 'spaceToBatchND');\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n paddings.length === blockShape.length,\n `paddings.shape[0] must be equal to [blockShape], got ${\n paddings.length}`);\n\n util.assert($x.shape.reduce((a, b, i) => {\n if (i > 0 && i <= blockShape.length) {\n return a && (b % blockShape[i - 1] === 0);\n }\n return a;\n }, true), `input spatial dimensions must be divisible by blockShapes`);\n return ENV.engine.runKernel(\n backend => backend.spaceToBatchND($x, blockShape, paddings), {});\n}\n\n/**\n * Unstacks a `Tensor` of rank-`R` into a list of rank-`(R-1)` `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * tf.unstack(a).forEach(tensor => tensor.print());\n * ```\n *\n * @param x A tensor object.\n * @param axis The axis to unstack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction unstack_(x: T|TensorLike, axis = 0): Tensor[] {\n const $x = convertToTensor(x, 'x', 'unstack');\n const num = $x.shape[axis];\n const outputShape: number[] = Array($x.rank - 1).fill(0);\n let outIndex = 0;\n for (let i = 0; i < $x.rank; i++) {\n if (i !== axis) {\n outputShape[outIndex] = $x.shape[i];\n outIndex++;\n }\n }\n\n let splitSizes: number[];\n splitSizes = Array(num).fill(1);\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice.reshape(outputShape);\n });\n}\n\n/**\n * Splits a `Tensor` into sub tensors.\n *\n * If `numOrSizeSplits` is a number, splits `x` along dimension `axis`\n * into `numOrSizeSplits` smaller tensors.\n * Requires that `numOrSizeSplits` evenly divides `x.shape[axis]`.\n *\n * If `numOrSizeSplits` is a number array, splits `x` into\n * `(numOrSizeSplits.length` pieces. The shape of the `i`-th piece has the\n * same size as `x` except along dimension `axis` where the size is\n * `numOrSizeSplits[i]`.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]);\n * const [a, b] = tf.split(x, 2, 1);\n * a.print();\n * b.print();\n *\n * const [c, d, e] = tf.split(x, [1, 2, 1], 1);\n * c.print();\n * d.print();\n * e.print();\n * ```\n *\n * @param x The input tensor to split.\n * @param numOrSizeSplits Either an integer indicating the number of\n * splits along the axis or an array of integers containing the sizes of\n * each output tensor along the axis. If a number then it must evenly divide\n * `x.shape[axis]`; otherwise the sum of sizes must match `x.shape[axis]`.\n * @param axis The dimension along which to split. Defaults to 0 (the first\n * dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction split_(\n x: T|TensorLike, numOrSizeSplits: number[]|number, axis = 0): T[] {\n const $x = convertToTensor(x, 'x', 'split');\n\n axis = parseAxisParam(axis, $x.shape)[0];\n let splitSizes: number[];\n if (typeof (numOrSizeSplits) === 'number') {\n util.assert(\n $x.shape[axis] % numOrSizeSplits === 0,\n 'Number of splits must evenly divide the axis.');\n splitSizes = Array(numOrSizeSplits).fill($x.shape[axis] / numOrSizeSplits);\n } else {\n util.assert(\n $x.shape[axis] === numOrSizeSplits.reduce((a, b) => a + b),\n 'The sum of sizes must match the size of the axis dimension.');\n splitSizes = numOrSizeSplits;\n }\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice;\n });\n}\n\n/**\n * Computes the cumulative sum of a `Tensor` along `axis`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4]);\n * x.cumsum().print();\n * ```\n * ```js\n * const x = tf.tensor([[1, 2], [3, 4]]);\n * x.cumsum().print();\n * ```\n *\n * @param x The input tensor to be summed.\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Optional.\n * Defaults to false. If set to true then the sum of each tensor entry\n * does not include its own value, but only the values previous to it\n * along the specified axis.\n * @param reverse Whether to sum in the opposite direction. Optional.\n * Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Scan'} */\nfunction cumsum_(\n x: Tensor|TensorLike, axis = 0, exclusive = false, reverse = false): T {\n const $x = convertToTensor(x, 'x', 'cumsum');\n\n axis = axis | 0;\n const permutation = getAxesPermutation([axis], $x.rank);\n let permutedX = $x;\n if (permutation != null) {\n permutedX = $x.transpose(permutation);\n }\n const permutedAxis = getInnerMostAxes(1, $x.rank)[0];\n\n const grad = (dy: T) => {\n return {permutedX: () => dy.cumsum(axis, exclusive, !reverse)};\n };\n let value = ENV.engine.runKernel(\n backend => backend.cumsum(\n permutedX, permutedAxis, exclusive, reverse),\n {permutedX}, grad) as T;\n\n if (permutation != null) {\n value = value.transpose(permutation);\n }\n return value;\n}\n\n/**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const axis = 1;\n * x.expandDims(axis).print();\n * ```\n *\n * @param x The input tensor whose dimensions to be expanded.\n * @param axis The dimension index at which to insert shape of `1`. Defaults\n * to 0 (the first dimension).\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction expandDims_(\n x: Tensor|TensorLike, axis = 0): Tensor {\n const $x = convertToTensor(x, 'x', 'expandDims');\n\n util.assert(axis <= $x.rank, 'Axis must be <= rank of the tensor');\n const newShape = $x.shape.slice();\n if (axis < 0) {\n // Negative value is counted from the tail of rank.\n util.assert(\n -($x.rank + 1) <= axis,\n `Axis must be in the interval [${- ($x.rank + 1)}, ${$x.rank}]`);\n axis = $x.rank + axis + 1;\n }\n newShape.splice(axis, 0, 1);\n return reshape($x, newShape);\n}\n\n/**\n * Creates an empty `TensorBuffer` with the specified `shape` and `dtype`.\n *\n * The values are stored in cpu as `TypedArray`. Fill the buffer using\n * `buffer.set()`, or by modifying directly `buffer.values`.\n *\n * When done, call `buffer.toTensor()` to get an immutable `Tensor` with\n * those values.\n *\n * ```js\n * // Create a buffer and set values at particular indices.\n * const buffer = tf.buffer([2, 2]);\n * buffer.set(3, 0, 0);\n * buffer.set(5, 1, 0);\n *\n * // Convert the buffer back to a tensor.\n * buffer.toTensor().print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The dtype of the buffer. Defaults to 'float32'.\n * @param values The values of the buffer as `TypedArray`. Defaults to\n * zeros.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction buffer(\n shape: ShapeMap[R], dtype: DataType = 'float32',\n values?: TypedArray): TensorBuffer {\n return new TensorBuffer(shape, dtype, values);\n}\n\n/**\n * Prints information about the `Tensor` including its data.\n *\n * ```js\n * const verbose = true;\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print(verbose);\n * ```\n * @param x The tensor to be printed.\n * @param verbose Whether to print verbose information about the ` Tensor`,\n * including dtype and size.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction print(x: T, verbose = false): void {\n console.log(x.toString(verbose));\n}\n\nexport {\n buffer, // Not wrapped in op() since no tensors.\n toPixels, // Not wrapped in op() since async.\n print // Not wrapped in op() since no need to increase stack trace.\n};\n\nexport const cast = op({cast_});\nexport const clone = op({clone_});\nexport const cumsum = op({cumsum_});\nexport const expandDims = op({expandDims_});\nexport const eye = op({eye_});\nexport const fromPixels = op({fromPixels_});\nexport const multinomial = op({multinomial_});\nexport const oneHot = op({oneHot_});\nexport const pad = op({pad_});\nexport const pad1d = op({pad1d_});\nexport const pad2d = op({pad2d_});\nexport const pad3d = op({pad3d_});\nexport const pad4d = op({pad4d_});\nexport const rand = op({rand_});\nexport const randomNormal = op({randomNormal_});\nexport const randomUniform = op({randomUniform_});\nexport const reshape = op({reshape_});\nexport const split = op({split_});\nexport const squeeze = op({squeeze_});\nexport const stack = op({stack_});\nexport const tile = op({tile_});\nexport const truncatedNormal = op({truncatedNormal_});\nexport const unstack = op({unstack_});\nexport const batchToSpaceND = op({batchToSpaceND_});\nexport const spaceToBatchND = op({spaceToBatchND_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the Where kernel shared between cpu and webgl */\n\nimport {buffer} from '../ops/array_ops';\nimport {Tensor2D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function whereImpl(condShape: number[], condVals: TypedArray): Tensor2D {\n const indices = [];\n for (let i = 0; i < condVals.length; i++) {\n if (condVals[i]) {\n indices.push(i);\n }\n }\n\n const inBuffer = buffer(condShape, 'int32');\n\n const out = buffer([indices.length, condShape.length], 'int32');\n for (let i = 0; i < indices.length; i++) {\n const loc = inBuffer.indexToLoc(indices[i]);\n const offset = i * condShape.length;\n out.values.set(loc, offset);\n }\n return out.toTensor() as Tensor2D;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {MemoryInfo, TimingInfo} from '../engine';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as reduce_util from '../ops/reduce_util';\nimport * as segment_util from '../ops/segment_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {softmax} from '../ops/softmax';\nimport {range, tensor} from '../ops/tensor_ops';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, RecursiveArray, ShapeMap, sumOutType, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\n\nimport {KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {ArgMinMaxProgram} from './webgl/argminmax_gpu';\nimport {AvgPool2DBackpropProgram} from './webgl/avg_pool_backprop_gpu';\nimport {BatchNormProgram} from './webgl/batchnorm_gpu';\nimport * as binaryop_gpu from './webgl/binaryop_gpu';\nimport {BinaryOpProgram} from './webgl/binaryop_gpu';\nimport {ClipProgram} from './webgl/clip_gpu';\nimport {ConcatProgram} from './webgl/concat_gpu';\nimport {Conv2DDerFilterProgram, Conv2DDerInputProgram} from './webgl/conv_backprop_gpu';\nimport {DepthwiseConv2DDerFilterProgram, DepthwiseConv2DDerInputProgram} from './webgl/conv_backprop_gpu_depthwise';\nimport {Conv2DProgram} from './webgl/conv_gpu';\nimport {DepthwiseConv2DProgram} from './webgl/conv_gpu_depthwise';\nimport {CumSumProgram} from './webgl/cumsum_gpu';\nimport {EncodeFloatProgram} from './webgl/encode_float_gpu';\nimport {FromPixelsProgram} from './webgl/from_pixels_gpu';\nimport {GatherProgram} from './webgl/gather_gpu';\nimport {GPGPUContext} from './webgl/gpgpu_context';\nimport * as gpgpu_math from './webgl/gpgpu_math';\nimport {GPGPUBinary, GPGPUProgram, TensorData} from './webgl/gpgpu_math';\nimport * as gpgpu_util from './webgl/gpgpu_util';\nimport {LRNProgram} from './webgl/lrn_gpu';\nimport {LRNGradProgram} from './webgl/lrn_grad_gpu';\nimport {MaxPool2DBackpropProgram} from './webgl/max_pool_backprop_gpu';\nimport {MatMulProgram} from './webgl/mulmat_gpu';\nimport {MultinomialProgram} from './webgl/multinomial_gpu';\nimport {OneHotProgram} from './webgl/onehot_gpu';\nimport {PadProgram} from './webgl/pad_gpu';\nimport {Pool2DProgram} from './webgl/pool_gpu';\nimport {ReduceProgram} from './webgl/reduce_gpu';\nimport {ResizeBilinearBackpropProgram} from './webgl/resize_bilinear_backprop_gpu';\nimport {ResizeBilinearProgram} from './webgl/resize_bilinear_gpu';\nimport {ResizeNearestNeigborBackpropProgram} from './webgl/resize_nearest_neighbor_backprop_gpu';\nimport {ResizeNearestNeighborProgram} from './webgl/resize_nearest_neighbor_gpu';\nimport {ReverseProgram} from './webgl/reverse_gpu';\nimport {SegmentOpProgram} from './webgl/segment_gpu';\nimport {SelectProgram} from './webgl/select_gpu';\nimport {SliceProgram} from './webgl/slice_gpu';\nimport {StridedSliceProgram} from './webgl/strided_slice_gpu';\nimport {TextureData, TextureUsage} from './webgl/tex_util';\nimport {TextureManager} from './webgl/texture_manager';\nimport {TileProgram} from './webgl/tile_gpu';\nimport {TransposeProgram} from './webgl/transpose_gpu';\nimport * as unary_op from './webgl/unaryop_gpu';\nimport {UnaryOpProgram} from './webgl/unaryop_gpu';\nimport * as webgl_util from './webgl/webgl_util';\nimport {whereImpl} from './where_impl';\n\ntype TimerNode = RecursiveArray>|Promise;\nexport interface CPUTimerQuery {\n startMs: number;\n endMs?: number;\n}\n\nexport interface WebGLMemoryInfo extends MemoryInfo {\n numBytesInGPU: number;\n unreliable: boolean;\n}\n\nexport interface WebGLTimingInfo extends TimingInfo {\n uploadWaitMs: number;\n downloadWaitMs: number;\n}\n\n// Empirically determined constant used to decide the number of bytes on GPU\n// before we start paging. The bytes are this constant * screen area * dpi.\nconst BEFORE_PAGING_CONSTANT = 300;\n// Tensors with size <= than this will be uploaded as uniforms, not textures.\nexport const SIZE_UPLOAD_UNIFORM = 32;\n\nexport class MathBackendWebGL implements KernelBackend {\n private texData = new WeakMap();\n // Maps data ids that have a pending read operation, to list of subscribers.\n private pendingRead = new WeakMap void>>();\n // List of data ids that are scheduled for disposal, but are waiting on a\n // pending read operation.\n private pendingDisposal = new WeakSet();\n // List of data ids that are currently residing on gpu memory. Sorted with\n // least recently used being first.\n private lruDataGPU: DataId[] = [];\n private numBytesInGPU = 0;\n /**\n * Number of bytes allocated on the GPU before we start moving data to cpu.\n * Moving avoids gpu memory leaks and relies on JS's garbage collector.\n */\n private NUM_BYTES_BEFORE_PAGING: number;\n\n private canvas: HTMLCanvasElement;\n private fromPixelsCanvas: HTMLCanvasElement;\n\n private programTimersStack: TimerNode[];\n private activeTimers: TimerNode[];\n // Accumulated time spent (including blocking) in uploading data to webgl.\n private uploadWaitMs = 0;\n // Accumulated time spent (including blocking in downloading data from webgl.\n private downloadWaitMs = 0;\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.texData.has(dataId)) {\n throw new Error('Data buffer is already registered');\n }\n this.texData.set(dataId, {\n shape,\n dtype,\n values: null,\n texture: null,\n texShape: null,\n usage: TextureUsage.RENDER\n });\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n const texShape: [number, number] = [pixels.height, pixels.width];\n const outShape = [pixels.height, pixels.width, numChannels];\n\n if (!(pixels instanceof HTMLVideoElement) &&\n !(pixels instanceof HTMLImageElement) &&\n !(pixels instanceof HTMLCanvasElement) &&\n !(pixels instanceof ImageData)) {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n if (pixels instanceof HTMLVideoElement) {\n if (this.fromPixelsCanvas == null) {\n if (!ENV.get('IS_BROWSER')) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside the browser.');\n }\n if (document.readyState !== 'complete') {\n throw new Error(\n 'The DOM is not ready yet. Please call tf.fromPixels() ' +\n 'once the DOM is ready. One way to do that is to add an event ' +\n 'listener for `DOMContentLoaded` on the document object');\n }\n this.fromPixelsCanvas = document.createElement('canvas');\n }\n this.fromPixelsCanvas.width = pixels.width;\n this.fromPixelsCanvas.height = pixels.height;\n this.fromPixelsCanvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n pixels = this.fromPixelsCanvas;\n }\n const tempPixelArray = Tensor.make(texShape, {}, 'int32');\n\n // This is a byte texture with pixels.\n this.texData.get(tempPixelArray.dataId).usage = TextureUsage.PIXELS;\n this.gpgpu.uploadPixelDataToTexture(\n this.getTexture(tempPixelArray.dataId), pixels);\n const program = new FromPixelsProgram(outShape);\n const res = this.compileAndRun(program, [tempPixelArray]);\n\n tempPixelArray.dispose();\n\n return res as Tensor3D;\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendWebGL.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n\n const texData = this.texData.get(dataId);\n const {texture, texShape, usage} = texData;\n if (texture != null) {\n // Release the old texture.\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n texData.usage = TextureUsage.UPLOAD;\n texData.values = values;\n\n if (!this.delayedStorage) {\n this.uploadToGPU(dataId);\n }\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n\n const float32Values =\n this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n\n if (shouldTimeProgram) {\n this.downloadWaitMs += performance.now() - start;\n }\n this.cacheOnCPU(dataId, float32Values);\n return texData.values;\n }\n\n async read(dataId: DataId): Promise {\n if (this.pendingRead.has(dataId)) {\n const subscribers = this.pendingRead.get(dataId);\n return new Promise(resolve => subscribers.push(resolve));\n }\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n\n this.pendingRead.set(dataId, []);\n\n if (!ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED') &&\n ENV.get('WEBGL_VERSION') === 2) {\n throw new Error(\n `tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and ` +\n `WEBGL_VERSION=2 not yet supported.`);\n }\n\n // Possibly copy the texture into a buffer before inserting a fence.\n const bufferOrTexture = this.gpgpu.maybeCreateBufferFromTexture(\n texture, texShape[0], texShape[1]);\n\n // Create a fence and wait for it to resolve.\n await this.gpgpu.createAndWaitForFence();\n\n // Download the values from the GPU.\n let vals: Float32Array;\n if (bufferOrTexture instanceof WebGLTexture) {\n vals = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n } else {\n vals = this.gpgpu.downloadFloat32MatrixFromBuffer(\n bufferOrTexture, texShape[0], texShape[1]);\n }\n this.cacheOnCPU(dataId, vals);\n\n const subscribers = this.pendingRead.get(dataId);\n this.pendingRead.delete(dataId);\n\n // Notify all pending reads.\n subscribers.forEach(resolve => resolve(vals));\n if (this.pendingDisposal.has(dataId)) {\n this.pendingDisposal.delete(dataId);\n this.disposeData(dataId);\n }\n return vals;\n }\n\n private getValuesFromTexture(\n texture: WebGLTexture, dataId: DataId, dtype: DataType,\n texShape: [number, number], shape: number[]): Float32Array {\n if (ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED')) {\n return this.gpgpu.downloadFloat32MatrixFromOutputTexture(\n texture, texShape[0], texShape[1]);\n }\n\n const tmpTarget = Tensor.make(shape, {});\n this.texData.get(tmpTarget.dataId).usage = TextureUsage.DOWNLOAD;\n\n const tmpInput = Tensor.make(shape, {dataId}, dtype);\n const program = new EncodeFloatProgram(shape);\n const pageToCpu = false;\n this.compileAndRun(program, [tmpInput], tmpTarget, null, pageToCpu);\n const tmpData = this.texData.get(tmpTarget.dataId);\n const vals = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(\n tmpData.texture, tmpData.texShape[0], tmpData.texShape[1]);\n\n tmpInput.dispose();\n tmpTarget.dispose();\n\n return vals;\n }\n\n async time(f: () => void): Promise {\n const oldActiveTimers = this.activeTimers;\n const newActiveTimers: TimerNode[] = [];\n\n let outerMostTime = false;\n if (this.programTimersStack == null) {\n this.programTimersStack = newActiveTimers;\n outerMostTime = true;\n } else {\n this.activeTimers.push(newActiveTimers);\n }\n this.activeTimers = newActiveTimers;\n\n f();\n\n const flattenedActiveTimers = util.flatten(this.activeTimers);\n this.activeTimers = oldActiveTimers;\n\n if (outerMostTime) {\n this.programTimersStack = null;\n }\n\n const kernelMs = await Promise.all(flattenedActiveTimers).then(results => {\n let sum = 0;\n results.forEach(result => sum += result);\n return sum;\n });\n const res: WebGLTimingInfo = {\n uploadWaitMs: this.uploadWaitMs,\n downloadWaitMs: this.downloadWaitMs,\n kernelMs,\n wallMs: null // will be filled by the engine\n };\n this.uploadWaitMs = 0;\n this.downloadWaitMs = 0;\n return res;\n }\n memory(): WebGLMemoryInfo {\n return {unreliable: false, numBytesInGPU: this.numBytesInGPU} as\n WebGLMemoryInfo;\n }\n\n private startTimer(): WebGLQuery|CPUTimerQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.beginQuery();\n }\n return {startMs: performance.now(), endMs: null};\n }\n\n private endTimer(query: WebGLQuery|CPUTimerQuery): WebGLQuery|\n {startMs: number, endMs: number} {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n this.gpgpu.endQuery();\n return query;\n }\n (query as CPUTimerQuery).endMs = performance.now();\n return query;\n }\n\n private async getQueryTime(query: WebGLQuery|CPUTimerQuery): Promise {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.waitForQueryAndGetTime(query);\n }\n const timerQuery = query as CPUTimerQuery;\n return timerQuery.endMs - timerQuery.startMs;\n }\n\n disposeData(dataId: DataId): void {\n if (this.pendingDisposal.has(dataId)) {\n return;\n }\n if (this.pendingRead.has(dataId)) {\n this.pendingDisposal.add(dataId);\n return;\n }\n if (this.texData.has(dataId)) {\n const {texture, texShape, usage} = this.texData.get(dataId);\n if (texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n }\n this.texData.delete(dataId);\n }\n }\n\n getTexture(dataId: DataId): WebGLTexture {\n this.uploadToGPU(dataId);\n return this.texData.get(dataId).texture;\n }\n\n private textureManager: TextureManager;\n private binaryCache: {[key: string]: GPGPUBinary} = {};\n private gpgpuCreatedLocally: boolean;\n\n constructor(private gpgpu?: GPGPUContext, private delayedStorage = true) {\n if (ENV.get('WEBGL_VERSION') < 1) {\n throw new Error('WebGL is not supported on this device');\n }\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n if (gpgpu == null) {\n this.gpgpu = new GPGPUContext(gpgpu_util.createWebGLContext(this.canvas));\n this.gpgpuCreatedLocally = true;\n } else {\n this.gpgpuCreatedLocally = false;\n }\n // Use the device screen's resolution as a heuristic to decide on the\n // maximum memory allocated on the GPU before starting to page.\n this.NUM_BYTES_BEFORE_PAGING =\n (window.screen.height * window.screen.width * window.devicePixelRatio) *\n BEFORE_PAGING_CONSTANT;\n this.textureManager = new TextureManager(this.gpgpu);\n }\n\n getGPGPUContext(): GPGPUContext {\n return this.gpgpu;\n }\n getCanvas(): HTMLCanvasElement {\n return this.canvas;\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const program = new SliceProgram(size);\n const customSetup = program.getCustomSetupFunc(begin);\n return this.compileAndRun(program, [x], null, customSetup);\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return tensor([], size) as T;\n }\n\n const program = new StridedSliceProgram(beginIndex, strides, size);\n return this.compileAndRun(program, [x]);\n }\n\n reverse(x: T, axis: number[]): T {\n const program = new ReverseProgram(x.shape, axis);\n return this.compileAndRun(program, [x]);\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const program = new ConcatProgram(a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n neg(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.NEG);\n return this.compileAndRun(program, [x]) as T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const program = new MatMulProgram(a.shape, b.shape, transposeA, transposeB);\n return this.compileAndRun(program, [a, b]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MUL, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output) as Tensor;\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const inputs = [x, mean, variance];\n\n let offsetShape = null;\n if (offset != null) {\n offsetShape = offset.shape;\n inputs.push(offset);\n }\n\n let scaleShape = null;\n if (scale != null) {\n scaleShape = scale.shape;\n inputs.push(scale);\n }\n\n const program = new BatchNormProgram(\n x.shape, mean.shape, variance.shape, offsetShape, scaleShape,\n varianceEpsilon);\n return this.compileAndRun(program, inputs);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program = new LRNProgram(x.shape, radius, bias, alpha, beta);\n return this.compileAndRun(program, [x]);\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program =\n new LRNGradProgram(inputImage.shape, depthRadius, bias, alpha, beta);\n return this.compileAndRun(program, [inputImage, outputImage, dy]);\n }\n\n tile(x: T, reps: number[]): T {\n const program = new TileProgram(x.shape, reps);\n return this.compileAndRun(program, [x]);\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const program = new PadProgram(x.shape, paddings, constantValue);\n return this.compileAndRun(program, [x]);\n }\n\n transpose(x: T, perm: number[]): T {\n const program = new TransposeProgram(x.shape, perm);\n return this.compileAndRun(program, [x]);\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const program = new GatherProgram(x.shape, indices.size, axis);\n return this.compileAndRun(program, [x, indices]);\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n util.assert(\n x.rank <= 4,\n 'batchToSpaceND for rank > 4 with a WebGL backend not implemented yet');\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n util.assert(\n x.rank <= 4,\n 'spaceToBatchND for rank > 4 with a WebGL backend not implemented yet');\n\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private reduce(\n x: Tensor2D, reduceType: 'all'|'any'|'max'|'min'|'sum',\n dtype: DataType): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program = new ReduceProgram(reduceInfo, reduceType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.reduce(output, reduceType, dtype);\n }\n\n private argReduce(\n x: Tensor2D, reduceType: 'max'|'min',\n bestIndicesA: Tensor2D = null): Tensor2D {\n let batchSize = x.shape[0];\n let inSize = x.shape[1];\n if (bestIndicesA != null) {\n batchSize = bestIndicesA.shape[0];\n inSize = bestIndicesA.shape[1];\n }\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program =\n new ArgMinMaxProgram(reduceInfo, reduceType, bestIndicesA == null);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], 'int32');\n const inputs = [x];\n if (bestIndicesA != null) {\n inputs.push(bestIndicesA);\n }\n this.compileAndRun(program, inputs, output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.argReduce(x, reduceType, output);\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n return this.reduce(a2D, 'sum', outputDType).reshape(outShape);\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n let axis = 0;\n const permutation = axis_util.getAxesPermutation([axis], x.rank);\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n axis = axis_util.getInnerMostAxes(1, x.rank)[0];\n }\n\n const outShape =\n segment_util.computeOutShape(permutedX.shape, axis, numSegments);\n const inSize = util.sizeFromShape([permutedX.shape[axis]]);\n const a2D = permutedX.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n let result =\n this.segOpCompute(\n a2D, 'unsortedSegmentSum', segmentIds, outputDType, numSegments)\n .reshape(outShape);\n if (permutation != null) {\n result = result.transpose(axis_util.getUndoAxesPermutation(permutation));\n }\n return result;\n }\n\n private segOpCompute(\n x: Tensor2D, segOpType: 'unsortedSegmentSum', segmentIds: Tensor1D,\n dtype: DataType, numSegments: number): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize =\n segment_util.segOpComputeOptimalWindowSize(inSize, numSegments);\n const segOpInfo = {windowSize, inSize, batchSize, numSegments};\n const program = new SegmentOpProgram(segOpInfo, segOpType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x, segmentIds], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === numSegments) {\n return output;\n }\n segmentIds = range(0, numSegments).tile([inSize / windowSize]);\n return this.segOpCompute(output, segOpType, segmentIds, dtype, numSegments);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'min').reshape(outShape);\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'max').reshape(outShape);\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `WebGL cumsum shader expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const program = new CumSumProgram(x.shape, exclusive, reverse);\n return this.compileAndRun(program, [x]);\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.NOT_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.LESS, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LESS_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.GREATER, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.GREATER_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalNot(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOGICAL_NOT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_AND, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_OR, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const program = new SelectProgram(condition.rank, a.shape, a.rank);\n const output =\n this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype));\n return this.compileAndRun(program, [condition, a, b], output);\n }\n\n where(condition: Tensor): Tensor2D {\n warn(\n 'tf.where() in webgl locks the UI thread. ' +\n 'Call tf.whereAsync() instead');\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'min', a2D.dtype).reshape(outShape);\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MIN, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MOD, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [a, b], null, customSetup);\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'max', a2D.dtype).reshape(outShape);\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MAX, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'all', a2D.dtype).reshape(outShape);\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'any', a2D.dtype).reshape(outShape);\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.SQUARED_DIFFERENCE, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.DIV;\n const outputDtype = 'float32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.INT_DIV;\n const outputDtype = 'int32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.ADD, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n addN(tensors: T[]): T {\n let res = tensors[0];\n for (let i = 1; i < tensors.length; i++) {\n res = this.add(res, tensors[i]) as T;\n }\n return res;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.SUB, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n pow(a: T, b: Tensor): T {\n const program = new BinaryOpProgram(binaryop_gpu.POW, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n const output = this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as T;\n return this.compileAndRun(program, [a, b], output, customSetup);\n }\n\n ceil(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.CEIL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n floor(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.FLOOR);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sign(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n round(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ROUND);\n return this.compileAndRun(program, [x]) as T;\n }\n\n exp(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXP);\n return this.compileAndRun(program, [x]) as T;\n }\n\n expm1(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXPM1);\n return this.compileAndRun(program, [x]) as T;\n }\n\n log(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n log1p(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG1P);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n rsqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RSQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n square(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQUARE);\n return this.compileAndRun(program, [x]) as T;\n }\n\n reciprocal(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RECIPROCAL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n relu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n elu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const program =\n new BinaryOpProgram(binaryop_gpu.ELU_DER, dy.shape, y.shape);\n return this.compileAndRun(program, [dy, y]) as T;\n }\n\n selu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n int(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TO_INT);\n const output = this.makeOutputArray(program.outputShape, 'int32');\n return this.compileAndRun(program, [x], output) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const program = new ClipProgram(x.shape, min, max);\n return this.compileAndRun(program, [x]) as T;\n }\n\n abs(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ABS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sigmoid(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGMOID);\n return this.compileAndRun(program, [x]) as T;\n }\n\n softplus(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SOFTPLUS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan2(a: T, b: T): T {\n const program = new BinaryOpProgram(binaryop_gpu.ATAN2, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]) as T;\n }\n\n sinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COSH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TANH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOSH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n atanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATANH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n erf(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ERF);\n return this.compileAndRun(program, [x]) as T;\n }\n\n step(x: T, alpha: number): T {\n const program = new UnaryOpProgram(x.shape, unary_op.STEP(alpha));\n return this.compileAndRun(program, [x]) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new Conv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'max', false);\n const output =\n this.makeOutputArray(program.outputShape, x.dtype) as Tensor4D;\n return this.compileAndRun(program, [x], output);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'avg', false);\n const output = this.makeOutputArray(program.outputShape, 'float32');\n return this.compileAndRun(program, [x], output) as Tensor4D;\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const getPositions = true;\n const maxPoolPositionsProgram =\n new Pool2DProgram(convInfo, 'max', getPositions);\n const maxPoolPositions: Tensor4D =\n this.compileAndRun(maxPoolPositionsProgram, [x]);\n\n const maxPoolBackPropProgram = new MaxPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(maxPoolBackPropProgram.outputShape, x.dtype);\n const result = this.compileAndRun(\n maxPoolBackPropProgram, [dy, maxPoolPositions], output);\n maxPoolPositions.dispose();\n return result as Tensor4D;\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const avgPoolBackpropProgram = new AvgPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(avgPoolBackpropProgram.outputShape, x.dtype);\n return this.compileAndRun(avgPoolBackpropProgram, [dy], output) as Tensor4D;\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program =\n new ResizeBilinearProgram(x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean):\n Tensor4D {\n const program = new ResizeBilinearBackpropProgram(dy, x, alignCorners);\n\n return this.compileAndRun(program, [dy]);\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program = new ResizeNearestNeighborProgram(\n x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D {\n const program =\n new ResizeNearestNeigborBackpropProgram(dy, x, alignCorners);\n return this.compileAndRun(program, [dy]);\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probs = normalized ? logits : softmax(logits);\n const batchSize = probs.shape[0];\n const numOutcomes = probs.shape[1];\n const program = new MultinomialProgram(batchSize, numOutcomes, numSamples);\n const output =\n this.makeOutputArray(program.outputShape, 'int32') as Tensor2D;\n const customSetup = program.getCustomSetupFunc(seed);\n return this.compileAndRun(program, [probs], output, customSetup);\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const program = new OneHotProgram(indices.size, depth, onValue, offValue);\n return this.compileAndRun(program, [indices]);\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n warn(\n 'tf.nonMaxSuppression() in webgl locks the UI thread. ' +\n 'Call tf.nonMaxSuppressionAsync() instead');\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private makeOutputArray(shape: number[], dtype: DataType):\n T {\n return Tensor.make(shape, {}, dtype) as T;\n }\n\n private compileAndRun(\n program: GPGPUProgram, inputs: T[], output?: K,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void,\n pageToCpu = true): K {\n if (output == null) {\n output = this.makeOutputArray(program.outputShape, inputs[0].dtype);\n }\n const inputsData: Array> = inputs.map(tensor => {\n const texData = this.texData.get(tensor.dataId);\n // Upload small tensors that live on the CPU as uniforms, not as\n // textures.\n if (texData.texture == null && tensor.size <= SIZE_UPLOAD_UNIFORM) {\n return {tensor, texData: null, isUniform: true};\n }\n this.uploadToGPU(tensor.dataId);\n return {tensor, texData, isUniform: false};\n });\n this.uploadToGPU(output.dataId);\n const outputData = {\n tensor: output,\n texData: this.texData.get(output.dataId),\n isUniform: false\n };\n const key = gpgpu_math.makeShaderKey(program, inputsData, outputData);\n const binary = this.getAndSaveBinary(key, () => {\n return gpgpu_math.compileProgram(\n this.gpgpu, program, inputsData, outputData);\n });\n const shouldTimeProgram = this.activeTimers != null;\n let query: WebGLQuery|CPUTimerQuery;\n if (shouldTimeProgram) {\n query = this.startTimer();\n }\n\n gpgpu_math.runProgram(binary, inputsData, outputData, customSetup);\n\n if (pageToCpu && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) {\n let numBytesToPage = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING;\n while (numBytesToPage > 0 && this.lruDataGPU.length > 0) {\n const dataId = this.lruDataGPU.shift();\n const {shape, dtype} = this.texData.get(dataId);\n numBytesToPage -= this.computeBytes(shape, dtype);\n this.read(dataId);\n }\n }\n\n if (shouldTimeProgram) {\n query = this.endTimer(query);\n this.activeTimers.push(this.getQueryTime(query));\n }\n return output;\n }\n\n private getAndSaveBinary(key: string, getBinary: () => GPGPUBinary):\n GPGPUBinary {\n if (!(key in this.binaryCache)) {\n this.binaryCache[key] = getBinary();\n }\n return this.binaryCache[key];\n }\n\n getTextureManager(): TextureManager {\n return this.textureManager;\n }\n\n private disposed = false;\n\n dispose() {\n if (this.disposed) {\n return;\n }\n for (const key in this.binaryCache) {\n this.gpgpu.deleteProgram(this.binaryCache[key].webGLProgram);\n }\n this.textureManager.dispose();\n this.canvas.remove();\n if (this.fromPixelsCanvas != null) {\n this.fromPixelsCanvas.remove();\n }\n if (this.gpgpuCreatedLocally) {\n this.gpgpu.dispose();\n }\n this.disposed = true;\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.texData.has(dataId)) {\n throw new Error(\n `WebGL backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n private uploadToGPU(dataId: DataId): void {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, values, texture, dtype, usage} = texData;\n if (texture != null) {\n // Array is already on GPU. No-op.\n // Touching the texture.\n const index = this.lruDataGPU.indexOf(dataId);\n if (index >= 0) {\n this.lruDataGPU.splice(this.lruDataGPU.indexOf(dataId), 1);\n this.lruDataGPU.push(dataId);\n }\n return;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n const texShape =\n webgl_util.getTextureShapeFromLogicalShape(this.gpgpu.gl, shape);\n texData.texShape = texShape;\n const newTexture = this.acquireTexture(dataId, texShape, usage);\n texData.texture = newTexture;\n if (values != null) {\n this.gpgpu.uploadMatrixToTexture(\n newTexture, texShape[0],\n // TODO(smilkov): Propagate the original typed array to gpgpu.\n texShape[1], typedArrayToFloat32(values, dtype));\n // Once uploaded, don't store the values on cpu.\n texData.values = null;\n if (shouldTimeProgram) {\n this.uploadWaitMs += performance.now() - start;\n }\n }\n }\n\n private cacheOnCPU(dataId: DataId, float32Values?: Float32Array) {\n // In delayed storage mode, when the user reads data, we don't keep a\n // copy on the gpu, to minimize likelihood of memory leak. We re-upload\n // to gpu the next time a gpgpu program needs the texture.\n const dontKeepCopyOnGPU = this.delayedStorage;\n const texData = this.texData.get(dataId);\n const {texture, texShape, dtype, usage} = texData;\n if (dontKeepCopyOnGPU && texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n if (float32Values != null) {\n texData.values = float32ToTypedArray(float32Values, dtype);\n }\n }\n\n private releaseTexture(\n dataId: DataId, texture: WebGLTexture, texShape: [number, number],\n texType: TextureUsage) {\n const {shape, dtype} = this.texData.get(dataId);\n const idx = this.lruDataGPU.indexOf(dataId);\n if (idx >= 0) {\n this.lruDataGPU.splice(idx, 1);\n }\n this.numBytesInGPU -= this.computeBytes(shape, dtype);\n this.textureManager.releaseTexture(texture, texShape, texType);\n }\n\n private acquireTexture(\n dataId: DataId, texShape: [number, number],\n texType: TextureUsage): WebGLTexture {\n const {shape, dtype} = this.texData.get(dataId);\n this.lruDataGPU.push(dataId);\n this.numBytesInGPU += this.computeBytes(shape, dtype);\n return this.textureManager.acquireTexture(texShape, texType);\n }\n\n private computeBytes(shape: number[], dtype: DataType) {\n return util.sizeFromShape(shape) * util.bytesPerElement(dtype);\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n ENV.registerBackend(\n 'webgl', () => new MathBackendWebGL(), 2 /* priority */,\n setTensorTracker);\n}\n\nfunction float32ToTypedArray(\n a: Float32Array, dtype: D): DataTypeMap[D] {\n if (dtype === 'float32') {\n return a;\n } else if (dtype === 'int32' || dtype === 'bool') {\n const result = (dtype === 'int32') ? new Int32Array(a.length) :\n new Uint8Array(a.length);\n for (let i = 0; i < result.length; ++i) {\n result[i] = Math.round(a[i]);\n }\n return result;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nfunction typedArrayToFloat32(\n a: DataTypeMap[D], dtype: D): Float32Array {\n return (a instanceof Float32Array) ? a : new Float32Array(a);\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\nimport {scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes `-1 * x` element-wise.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, -2, 0], [2, 2]);\n *\n * x.neg().print(); // or tf.neg(x)\n * ```\n *\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction neg_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'neg');\n\n const grad = (dy: T) => {\n return {$x: () => dy.neg()};\n };\n return ENV.engine.runKernel(backend => backend.neg($x), {$x}, grad);\n}\n\n/**\n * Computes ceiling of input `Tensor` element-wise: `ceil(x)`\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.ceil().print(); // or tf.ceil(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction ceil_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'ceil');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.ceil($x), {$x}, grad);\n}\n\n/**\n * Computes floor of input `Tensor` element-wise: `floor(x)`.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.floor().print(); // or tf.floor(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction floor_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'floor');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.floor($x), {$x}, grad);\n}\n\n/**\n * Returns an element-wise indication of the sign of a number.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3, NaN, 0]);\n *\n * x.sign().print(); // or tf.sign(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sign_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sign');\n\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sign($x), {$x}, grad);\n}\n\n/**\n * Computes round of input `Tensor` element-wise: `round(x)`.\n * It implements banker's rounding.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.round().print(); // or tf.round(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction round_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'round');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.round($x), {$x}, grad);\n}\n\n/**\n * Computes exponential of the input `Tensor` element-wise. `e ^ x`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.exp().print(); // or tf.exp(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction exp_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'exp');\n\n const bck = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y as T)};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.exp($x)), {$x}, bck);\n}\n\n/**\n * Computes exponential of the input `Tensor` minus one element-wise.\n * `e ^ x - 1`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.expm1().print(); // or tf.expm1(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction expm1_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'expm1');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.exp())};\n };\n return ENV.engine.runKernel(backend => backend.expm1($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` element-wise: `ln(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E]);\n *\n * x.log().print(); // or tf.log(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.log($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` plus one\n * element-wise: `ln(1 + x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E - 1]);\n *\n * x.log1p().print(); // or tf.log1p(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log1p_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log1p');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.add(scalar(1)))};\n };\n return ENV.engine.runKernel(backend => backend.log1p($x), {$x}, grad);\n}\n\n/**\n * Computes square root of the input `Tensor` element-wise: `y = sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.sqrt().print(); // or tf.sqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat().sqrt().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.sqrt($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of square root of the input `Tensor` element-wise:\n * `y = 1 / sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.rsqrt().print(); // or tf.rsqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction rsqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'rsqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.pow(scalar(1.5)).mul(scalar(2))).neg()};\n };\n return ENV.engine.runKernel(backend => backend.rsqrt($x), {$x}, grad);\n}\n\n/**\n * Computes square of `x` element-wise: `x ^ 2`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.sqrt(2), -1]);\n *\n * x.square().print(); // or tf.square(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction square_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'square');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.square($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of x element-wise: `1 / x`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, 2]);\n *\n * x.reciprocal().print(); // or tf.reciprocal(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction reciprocal_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'reciprocal');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.square().neg())};\n };\n return ENV.engine.runKernel(backend => backend.reciprocal($x), {$x}, grad);\n}\n\n/**\n * Computes absolute value element-wise: `abs(x)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.abs().print(); // or tf.abs(x)\n * ```\n * @param x The input `Tensor`.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction abs_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'abs');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().step(-1))};\n };\n return ENV.engine.runKernel(backend => backend.abs($x), {$x}, grad);\n}\n\n/**\n * Clips values element-wise. `max(min(x, clipValueMax), clipValueMin)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.clipByValue(-2, 3).print(); // or tf.clipByValue(x, -2, 3)\n * ```\n * @param x The input tensor.\n * @param clipValueMin Lower-bound of range to be clipped to.\n * @param clipValueMax Upper-bound of range to be clipped to.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction clipByValue_(\n x: T|TensorLike, clipValueMin: number, clipValueMax: number): T {\n const $x = convertToTensor(x, 'x', 'clipByValue');\n util.assert(\n (clipValueMin <= clipValueMax),\n `Error in clip: min (${clipValueMin}) must be ` +\n `less than or equal to max (${clipValueMax}).`);\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.where(\n $x.greaterEqual(scalar(clipValueMin))\n .logicalAnd($x.lessEqual(scalar(clipValueMax))),\n zerosLike(dy)) as T,\n };\n };\n return ENV.engine.runKernel(\n backend => backend.clip($x, clipValueMin, clipValueMax), {$x}, grad);\n}\n\n/**\n * Computes sigmoid element-wise, `1 / (1 + exp(-x))`\n *\n * ```js\n * const x = tf.tensor1d([0, -1, 2, -3]);\n *\n * x.sigmoid().print(); // or tf.sigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sigmoid');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y.mul(scalar(1).sub(y)))};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.sigmoid($x)), {$x}, grad);\n}\n\n/**\n * Computes log sigmoid of the input `Tensor` element-wise:\n * `logSigmoid(x)`. For numerical stability, we use `-tf.softplus(-x)`.\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.logSigmoid().print(); // or tf.logSigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction logSigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logSigmoid');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.neg().sigmoid())};\n };\n return ENV.engine.runKernel(\n backend => backend.softplus($x.neg()).neg(), {$x}, grad);\n}\n\n/**\n * Computes softplus of the input `Tensor` element-wise: `log(exp(x) + 1)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.softplus().print(); // or tf.softplus(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction softplus_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'softplus');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.sigmoid())};\n };\n return ENV.engine.runKernel(backend => backend.softplus($x), {$x}, grad);\n}\n\n/**\n * Computes sin of the input Tensor element-wise: `sin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.sin().print(); // or tf.sin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sin');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cos().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sin($x), {$x}, grad);\n}\n\n/**\n * Computes cos of the input `Tensor` element-wise: `cos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.cos().print(); // or tf.cos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cos');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sin().neg().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cos($x), {$x}, grad);\n}\n\n/**\n * Computes tan of the input `Tensor` element-wise, `tan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.tan().print(); // or tf.tan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.cos().square())};\n };\n return ENV.engine.runKernel(backend => backend.tan($x), {$x}, grad);\n}\n\n/**\n * Computes asin of the input `Tensor` element-wise: `asin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asin().print(); // or tf.asin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asin');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asin($x), {$x}, grad);\n}\n\n/**\n * Computes acos of the input `Tensor` element-wise: `acos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.acos().print(); // or tf.acos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acos');\n\n const grad = (dy: T) => {\n return {\n $x: () =>\n dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T).neg()\n };\n };\n return ENV.engine.runKernel(backend => backend.acos($x), {$x}, grad);\n}\n\n/**\n * Computes atan of the input `Tensor` element-wise: `atan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.atan().print(); // or tf.atan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).add($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atan($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic sin of the input `Tensor` element-wise: `sinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.sinh().print(); // or tf.sinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sinh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cosh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sinh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic cos of the input `Tensor` element-wise: `cosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.cosh().print(); // or tf.cosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cosh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sinh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cosh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic tangent of the input `Tensor` element-wise: `tanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, 70]);\n *\n * x.tanh().print(); // or tf.tanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tanh');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => scalar(1).sub(y.square()).mulStrict(dy) as T};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.tanh($x)), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic sin of the input `Tensor` element-wise:\n * `asinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asinh().print(); // or tf.asinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asinh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).add($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asinh($x), {$x}, grad);\n}\n\n/**\n * Computes the inverse hyperbolic cos of the input `Tensor` element-wise:\n * `acosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([10, 1, 3, 5.7]);\n *\n * x.acosh().print(); // or tf.acosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acosh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict($x.toFloat().square().sub(scalar(1)).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.acosh($x), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic tan of the input `Tensor` element-wise:\n * `atanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.atanh().print(); // or tf.atanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atanh');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atanh($x), {$x}, grad);\n}\n\n/**\n * Computes gause error function of the input `Tensor` element-wise:\n * `erf(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.erf().print(); // or tf.erf(x);\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction erf_(x: T|TensorLike): T {\n let $x = convertToTensor(x, 'x', 'erf');\n util.assert(\n $x.dtype === 'int32' || $x.dtype === 'float32',\n 'Input dtype must be `int32` or `float32`.');\n\n if ($x.dtype === 'int32') {\n $x = $x.toFloat();\n }\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.mulStrict(\n scalar(2 / Math.sqrt(Math.PI)).mul($x.square().neg().exp()))\n };\n };\n return ENV.engine.runKernel(backend => backend.erf($x), {$x}, grad);\n}\n\n/**\n * Computes step of the input `Tensor` element-wise: `x > 0 ? 1 : alpha * x`\n *\n * ```js\n * const x = tf.tensor1d([0, 2, -1, -3]);\n *\n * x.step(.5).print(); // or tf.step(x, .5)\n * ```\n * @param x The input tensor.\n * @param alpha The gradient when input is negative.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction step_(x: T|TensorLike, alpha = 0.0): T {\n const $x = convertToTensor(x, 'x', 'step');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports\n // it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.step($x, alpha), {$x}, grad);\n}\n\nexport const abs = op({abs_});\nexport const acos = op({acos_});\nexport const acosh = op({acosh_});\nexport const asin = op({asin_});\nexport const asinh = op({asinh_});\nexport const atan = op({atan_});\nexport const atanh = op({atanh_});\nexport const ceil = op({ceil_});\nexport const clipByValue = op({clipByValue_});\nexport const cos = op({cos_});\nexport const cosh = op({cosh_});\nexport const erf = op({erf_});\nexport const exp = op({exp_});\nexport const expm1 = op({expm1_});\nexport const floor = op({floor_});\nexport const log = op({log_});\nexport const log1p = op({log1p_});\nexport const logSigmoid = op({logSigmoid_});\nexport const neg = op({neg_});\nexport const reciprocal = op({reciprocal_});\nexport const round = op({round_});\nexport const rsqrt = op({rsqrt_});\nexport const sigmoid = op({sigmoid_});\nexport const sign = op({sign_});\nexport const sin = op({sin_});\nexport const sinh = op({sinh_});\nexport const softplus = op({softplus_});\nexport const sqrt = op({sqrt_});\nexport const square = op({square_});\nexport const step = op({step_});\nexport const tan = op({tan_});\nexport const tanh = op({tanh_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {tile} from './array_ops';\nimport {getReductionAxes} from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {rsqrt} from './unary_ops';\n\n/**\n * Batch normalization, strictly for 2D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization2d_(\n x: Tensor2D|TensorLike, mean: Tensor2D|Tensor1D|TensorLike,\n variance: Tensor2D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor2D|Tensor1D|TensorLike,\n offset?: Tensor2D|Tensor1D|TensorLike): Tensor2D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor2D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor2D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 2,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 2 || $mean.rank === 1,\n `Error in batchNormalization2D: mean must be rank 2 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 2 || $variance.rank === 1,\n `Error in batchNormalization2D: variance must be rank 2 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 2 || $scale.rank === 1,\n `Error in batchNormalization2D: scale must be rank 2 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 2 || $offset.rank === 1,\n `Error in batchNormalization2D: offset must be rank 2 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 3D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization3d_(\n x: Tensor3D|TensorLike, mean: Tensor3D|Tensor1D|TensorLike,\n variance: Tensor3D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor3D|Tensor1D|TensorLike,\n offset?: Tensor3D|Tensor1D|TensorLike): Tensor3D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor3D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor3D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 3,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 3 || $mean.rank === 1,\n `Error in batchNormalization3D: mean must be rank 3 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 3 || $variance.rank === 1,\n `Error in batchNormalization3D: variance must be rank 3 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 3 || $scale.rank === 1,\n `Error in batchNormalization3D: scale must be rank 3 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 3 || $offset.rank === 1,\n `Error in batchNormalization3D: offset must be rank 3 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 4D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization4d_(\n x: Tensor4D|TensorLike, mean: Tensor4D|Tensor1D|TensorLike,\n variance: Tensor4D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor4D|Tensor1D|TensorLike,\n offset?: Tensor4D|Tensor1D|TensorLike): Tensor4D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor4D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor4D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 4,\n `Error in batchNormalization4D: x must be rank 4 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 4 || $mean.rank === 1,\n `Error in batchNormalization4D: mean must be rank 4 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 4 || $variance.rank === 1,\n `Error in batchNormalization4D: variance must be rank 4 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 4 || $scale.rank === 1,\n `Error in batchNormalization4D: scale must be rank 4 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 4 || $offset.rank === 1,\n `Error in batchNormalization4D: offset must be rank 4 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization.\n *\n * As described in\n * [http://arxiv.org/abs/1502.03167](http://arxiv.org/abs/1502.03167).\n *\n * Mean, variance, scale, and offset can be of two\n * shapes:\n * - The same shape as the input.\n * - In the common case, the depth dimension is the last dimension of x, so\n * the values would be an `Tensor1D` of shape [depth].\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that parameters passed are of given rank\n * - `tf.batchNormalization2d`\n * - `tf.batchNormalization3d`\n * - `tf.batchNormalization4d`\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction batchNormalization_(\n x: Tensor|Tensor1D|TensorLike, mean: Tensor|Tensor1D|TensorLike,\n variance: Tensor|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor|Tensor1D|TensorLike,\n offset?: Tensor|Tensor1D|TensorLike): Tensor {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n\n util.assert(\n $mean.rank === $variance.rank,\n 'Batch normalization gradient requires mean and variance to have ' +\n 'equal ranks.');\n util.assert(\n $offset == null || $mean.rank === $offset.rank,\n 'Batch normalization gradient requires mean and offset to have ' +\n 'equal ranks.');\n util.assert(\n $scale == null || $mean.rank === $scale.rank,\n 'Batch normalization gradient requires mean and scale to have ' +\n 'equal ranks.');\n\n let x4D: Tensor4D;\n if ($x.rank === 0 || $x.rank === 1) {\n x4D = $x.as4D(1, 1, 1, $x.size);\n } else if ($x.rank === 2) {\n x4D = $x.as4D(1, 1, $x.shape[0], $x.shape[1]);\n } else if ($x.rank === 3) {\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]) as Tensor4D;\n } else {\n x4D = $x as Tensor4D;\n }\n\n const der = (dy: Tensor) => {\n const scaleValue = $scale == null ? scalar(1) : $scale;\n const reductionAxes = getReductionAxes($mean.shape, x4D.shape);\n const tileShape: number[] = [];\n if ($mean.rank === 1) {\n for (let i = 0; i < x4D.shape.length - 1; ++i) {\n tileShape.push(x4D.shape[i]);\n }\n tileShape.push(1);\n }\n\n const xMinusMean = $x.sub($mean);\n const dyTimesScaleValue = dy.mul(scaleValue);\n const oneOverSqrtVariance = rsqrt($variance.add(scalar(varianceEpsilon)));\n const minusHalfRCube = oneOverSqrtVariance.mul(oneOverSqrtVariance)\n .mul(oneOverSqrtVariance)\n .mul(scalar(-0.5));\n const derX = () => {\n if ($mean.rank === 1) {\n return dy\n .mul(tile(\n oneOverSqrtVariance.as4D(1, 1, 1, $mean.shape[0]), tileShape))\n .mul(scaleValue)\n .reshape($x.shape);\n } else {\n return dy.mul(oneOverSqrtVariance).mul(scaleValue).reshape($x.shape);\n }\n };\n const derMean = () => {\n let meanDer = oneOverSqrtVariance.mul(scalar(-1)).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n meanDer = meanDer.sum(reductionAxes);\n }\n return meanDer.reshape($mean.shape);\n };\n const derVariance = () => {\n let varianceDer = minusHalfRCube.mul(xMinusMean).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n varianceDer = varianceDer.sum(reductionAxes);\n }\n return varianceDer.reshape($mean.shape);\n };\n const derScale = () => {\n const xMinusMean2TimesRsqrt = xMinusMean.mul(oneOverSqrtVariance);\n let scaleDer = dy.mul(xMinusMean2TimesRsqrt);\n if ($mean.rank === 1) {\n scaleDer = scaleDer.sum(reductionAxes);\n }\n return scaleDer.reshape($mean.shape);\n };\n const derOffset = () => {\n let offsetDer = dy;\n if ($mean.rank === 1) {\n offsetDer = offsetDer.sum(reductionAxes);\n }\n return offsetDer.reshape($mean.shape);\n };\n return {\n $x: derX,\n $mean: derMean,\n $variance: derVariance,\n $scale: derScale,\n $offset: derOffset\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.batchNormalization(\n x4D, batchnormReshape4D($mean), batchnormReshape4D($variance),\n varianceEpsilon, batchnormReshape4D($scale),\n batchnormReshape4D($offset)),\n {$x, $mean, $variance, $scale, $offset}, der);\n return res.reshape($x.shape);\n}\n\nfunction batchnormReshape4D(x: Tensor): Tensor4D|Tensor1D {\n if (x == null) {\n return null;\n }\n if (x.rank === 0) {\n return x.as1D();\n } else if (x.rank === 1) {\n return x as Tensor1D;\n } else if (x.rank === 2) {\n return x.as4D(1, 1, x.shape[0], x.shape[1]);\n } else if (x.rank === 3) {\n return x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n return x as Tensor4D;\n}\n\nexport const batchNormalization2d = op({batchNormalization2d_});\nexport const batchNormalization3d = op({batchNormalization3d_});\nexport const batchNormalization4d = op({batchNormalization4d_});\nexport const batchNormalization = op({batchNormalization_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport type PadInfo = {\n top: number,\n left: number,\n right: number,\n bottom: number,\n type: string\n};\n\n/**\n * Information about the forward pass of a convolution/pooling operation.\n * It includes input and output shape, strides, filter size and padding\n * information.\n */\nexport type Conv2DInfo = {\n batchSize: number,\n inHeight: number,\n inWidth: number,\n inChannels: number,\n outHeight: number,\n outWidth: number,\n outChannels: number,\n dataFormat: 'channelsFirst'|'channelsLast',\n strideHeight: number,\n strideWidth: number,\n dilationHeight: number,\n dilationWidth: number,\n filterHeight: number,\n filterWidth: number,\n padInfo: PadInfo,\n inShape: [number, number, number, number],\n outShape: [number, number, number, number],\n filterShape: [number, number, number, number]\n};\n\nexport function computePool2DInfo(\n inShape: [number, number, number, number],\n filterSize: [number, number]|number, strides: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n const [filterHeight, filterWidth] = parseTupleParam(filterSize);\n\n let filterShape: [number, number, number, number];\n if (dataFormat === 'channelsLast') {\n filterShape = [filterHeight, filterWidth, inShape[3], inShape[3]];\n } else if (dataFormat === 'channelsFirst') {\n filterShape = [filterHeight, filterWidth, inShape[1], inShape[1]];\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n const dilations = 1;\n\n return computeConv2DInfo(\n inShape, filterShape, strides, dilations, pad, roundingMode, false,\n dataFormat);\n}\n\n/**\n * Computes the information for a forward pass of a convolution/pooling\n * operation.\n */\nexport function computeConv2DInfo(\n inShape: [number, number, number, number],\n filterShape: [number, number, number, number],\n strides: number|[number, number], dilations: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n depthwise = false,\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n let [batchSize, inHeight, inWidth, inChannels] = [-1, -1, -1, -1];\n if (dataFormat === 'channelsLast') {\n [batchSize, inHeight, inWidth, inChannels] = inShape;\n } else if (dataFormat === 'channelsFirst') {\n [batchSize, inChannels, inHeight, inWidth] = inShape;\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n\n const [filterHeight, filterWidth, , filterChannels] = filterShape;\n const [strideHeight, strideWidth] = parseTupleParam(strides);\n const [dilationHeight, dilationWidth] = parseTupleParam(dilations);\n\n const effectiveFilterHeight =\n getEffectiveFilterSize(filterHeight, dilationHeight);\n const effectiveFilterWidth =\n getEffectiveFilterSize(filterWidth, dilationWidth);\n const {padInfo, outHeight, outWidth} = getPadAndOutInfo(\n pad, inHeight, inWidth, strideHeight, strideWidth, effectiveFilterHeight,\n effectiveFilterWidth, roundingMode);\n\n const outChannels = depthwise ? filterChannels * inChannels : filterChannels;\n\n let outShape: [number, number, number, number];\n if (dataFormat === 'channelsFirst') {\n outShape = [batchSize, outChannels, outHeight, outWidth];\n } else if (dataFormat === 'channelsLast') {\n outShape = [batchSize, outHeight, outWidth, outChannels];\n }\n\n return {\n batchSize,\n dataFormat,\n inHeight,\n inWidth,\n inChannels,\n outHeight,\n outWidth,\n outChannels,\n padInfo,\n strideHeight,\n strideWidth,\n filterHeight,\n filterWidth,\n dilationHeight,\n dilationWidth,\n inShape,\n outShape,\n filterShape\n };\n}\n\nfunction computeOutputShape3D(\n inShape: [number, number, number], fieldSize: number, outDepth: number,\n stride: number, zeroPad?: number,\n roundingMode?: 'floor'|'round'|'ceil'): [number, number, number] {\n if (zeroPad == null) {\n zeroPad = computeDefaultPad(inShape, fieldSize, stride);\n }\n const inputRows = inShape[0];\n const inputCols = inShape[1];\n\n const outputRows = conditionalRound(\n (inputRows - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputRows),\n `The output # of rows (${outputRows}) must be an integer. Change the ` +\n `stride and/or zero pad parameters`);\n\n const outputCols = conditionalRound(\n (inputCols - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputCols),\n `The output # of columns (${outputCols}) must be an integer. Change ` +\n `the stride and/or zero pad parameters`);\n\n return [outputRows, outputCols, outDepth];\n}\n\nexport function computeDefaultPad(\n inputShape: [number, number, number], fieldSize: number, stride: number,\n dilation = 1): number {\n const effectiveFieldSize = getEffectiveFilterSize(fieldSize, dilation);\n return Math.floor(\n (inputShape[0] * (stride - 1) - stride + effectiveFieldSize) / 2);\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\n/* See https://www.tensorflow.org/api_docs/python/tf/nn/atrous_conv2d\n * Atrous convolution is equivalent to standard convolution with upsampled\n * filters with effective_filter_height =\n * filter_height + (filter_height - 1) * (dilation - 1)\n * and effective_filter_width =\n * filter_width + (filter_width - 1) * (dilation - 1),\n * produced by inserting dilation - 1 zeros along consecutive elements across\n * the filters' spatial dimensions.\n * When there is a dilation, this converts a filter dimension to the\n * effective filter dimension, so it can be used in a standard convolution.\n */\nfunction getEffectiveFilterSize(filterSize: number, dilation: number) {\n if (dilation <= 1) {\n return filterSize;\n }\n\n return filterSize + (filterSize - 1) * (dilation - 1);\n}\n\nfunction getPadAndOutInfo(\n pad: 'same'|'valid'|number, inHeight: number, inWidth: number,\n strideHeight: number, strideWidth: number, filterHeight: number,\n filterWidth: number, roundingMode?: 'floor'|'round'|'ceil'):\n {padInfo: PadInfo, outHeight: number, outWidth: number} {\n let padInfo: PadInfo;\n let outHeight: number;\n let outWidth: number;\n\n if (typeof pad === 'number') {\n const padType = (pad === 0) ? 'VALID' : 'NUMBER';\n padInfo = {top: pad, bottom: pad, left: pad, right: pad, type: padType};\n const outShape = computeOutputShape3D(\n [inHeight, inWidth, 1], filterHeight, 1, strideHeight, pad,\n roundingMode);\n outHeight = outShape[0];\n outWidth = outShape[1];\n } else if (pad === 'same') {\n outHeight = Math.ceil(inHeight / strideHeight);\n outWidth = Math.ceil(inWidth / strideWidth);\n const padAlongHeight =\n (outHeight - 1) * strideHeight + filterHeight - inHeight;\n const padAlongWidth = (outWidth - 1) * strideWidth + filterWidth - inWidth;\n const top = Math.floor(padAlongHeight / 2);\n const bottom = padAlongHeight - top;\n const left = Math.floor(padAlongWidth / 2);\n const right = padAlongWidth - left;\n padInfo = {top, bottom, left, right, type: 'SAME'};\n } else if (pad === 'valid') {\n padInfo = {top: 0, bottom: 0, left: 0, right: 0, type: 'VALID'};\n outHeight = Math.ceil((inHeight - filterHeight + 1) / strideHeight);\n outWidth = Math.ceil((inWidth - filterWidth + 1) / strideWidth);\n } else {\n throw Error(`Unknown padding parameter: ${pad}`);\n }\n return {padInfo, outHeight, outWidth};\n}\n\n/**\n * Rounds a value depending on the rounding mode\n * @param value\n * @param roundingMode\n */\nfunction conditionalRound(\n value: number, roundingMode?: 'floor'|'round'|'ceil') {\n if (!roundingMode) {\n return value;\n }\n switch (roundingMode) {\n case 'round':\n // used for Caffe Conv\n return Math.round(value);\n case 'ceil':\n // used for Caffe Pool\n return Math.ceil(value);\n case 'floor':\n return Math.floor(value);\n default:\n throw new Error(`Unknown roundingMode ${roundingMode}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes a 1D convolution over the input x.\n *\n * @param x The input tensor, of rank 3 or rank 2, of shape\n * `[batch, width, inChannels]`. If rank 2, batch of 1 is assumed.\n * @param filter The filter, rank 3, of shape\n * `[filterWidth, inDepth, outDepth]`.\n * @param stride The number of entries by which the filter is moved right at\n * each step.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat An optional string from \"NWC\", \"NCW\". Defaults to \"NWC\",\n * the data is stored in the order of [batch, in_width, in_channels]. Only\n * \"NWC\" is currently supported.\n * @param dilation The dilation rate in which we sample input values in\n * atrous convolution. Defaults to `1`. If it is greater than 1, then\n * stride must be `1`.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv1d_(\n x: T|TensorLike, filter: Tensor3D|TensorLike, stride: number,\n pad: 'valid'|'same'|number, dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv1d');\n const $filter = convertToTensor(filter, 'filter', 'conv1d');\n\n let x3D = $x as Tensor3D;\n let reshapedTo3D = false;\n if ($x.rank === 2) {\n reshapedTo3D = true;\n x3D = $x.as3D(1, $x.shape[0], $x.shape[1]);\n }\n\n util.assert(\n x3D.rank === 3,\n `Error in conv1d: input must be rank 3, but got rank ${x3D.rank}.`);\n util.assert(\n $filter.rank === 3,\n `Error in conv1d: filter must be rank 3, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv1d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x3D.shape[2] === $filter.shape[1],\n `Error in conv1d: depth of input (${x3D.shape[2]}) must match ` +\n `input depth for filter ${$filter.shape[1]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(stride, dilation),\n 'Error in conv1D: Either stride or dilation must be 1. ' +\n `Got stride ${stride} and dilation '${dilation}'`);\n util.assert(\n dataFormat === 'NWC',\n `Error in conv1d: got dataFormat of ${\n dataFormat} but only NWC is currently supported.`);\n\n const filter4D =\n $filter.as4D(1, $filter.shape[0], $filter.shape[1], $filter.shape[2]);\n const input4D = x3D.as4D(x3D.shape[0], 1, x3D.shape[1], x3D.shape[2]);\n const strides: [number, number] = [1, stride];\n const dilations: [number, number] = [1, dilation];\n\n const conv2dDataFormat = 'NHWC';\n\n const res = conv2d(\n input4D, filter4D, strides, pad, conv2dDataFormat, dilations,\n dimRoundingMode);\n\n if (reshapedTo3D) {\n return res.as2D(res.shape[2], res.shape[3]) as T;\n }\n return res.as3D(res.shape[0], res.shape[2], res.shape[3]) as T;\n}\n\n/**\n * Computes a 2D convolution over the input x.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `dilations` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2d');\n const $filter = convertToTensor(filter, 'filter', 'conv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2d: input must be rank 4, but got rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in conv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in conv2d: depth of input (${x4D.shape[3]}) must match ` +\n `input depth for filter ${$filter.shape[2]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in conv2D: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n util.assert(\n dataFormat === 'NHWC',\n `Error in conv2d: got dataFormat of ${\n dataFormat} but only NHWC is currently supported.`);\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of conv2D: dilation rates greater than 1 are not' +\n `yet supported in gradients. Got dilations '${dilations}'`);\n\n return {\n x: () => conv2dDerInput_(x4D.shape, dy, $filter, strides, pad),\n $filter: () => conv2dDerFilter_(x4D, dy, $filter.shape, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.conv2d(x4D, $filter, convInfo), {x: x4D, $filter},\n grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the input of a 2D convolution.\n *\n * @param xShape The shape of the input: [batch, height, width, inDepth].\n * If length of 3, batch of 1 is assumed.\n * @param dy The derivative of the output, of rank 4 or rank 3 of shape\n * `[batch, outHeight, outWidth, outDepth]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm used:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\nfunction conv2dDerInput_(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n util.assert(\n xShape.length === dy.rank,\n `Length of inShape ` +\n `(${xShape.length}) and rank of dy (${dy.rank}) must match`);\n\n let xShape4D = xShape as [number, number, number, number];\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n xShape4D = [1, xShape[0], xShape[1], xShape[2]];\n }\n\n const inDepth = xShape4D[3];\n const outDepth = dy4D.shape[3];\n util.assert(\n xShape4D.length === 4,\n `Error in conv2dDerInput: inShape must be length 4, but got length ` +\n `${xShape4D.length}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerInput: dy must be rank 4, but got ` +\n `rank ${dy4D.rank}`);\n util.assert(\n filter.rank === 4,\n `Error in conv2dDerInput: filter must be rank 4, but got ` +\n `rank ${filter.rank}`);\n util.assert(\n inDepth === filter.shape[2],\n `Error in conv2dDerInput: depth of input (${inDepth}) must ` +\n `match input depth for filter ${filter.shape[2]}.`);\n util.assert(\n outDepth === filter.shape[3],\n `Error in conv2dDerInput: depth of output (${outDepth}) must ` +\n `match output depth for filter ${filter.shape[3]}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerInput: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n xShape4D, filter.shape, strides, dilations, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.conv2dDerInput(dy4D, filter, convInfo), {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the filter of a 2D convolution.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * [batch, height, width, inChannels]. If rank 3, batch of 1 is assumed.\n * @param dy The dy image, of rank 4 or rank 3, of shape\n * [batch, height, width, outDepth]. If rank 3, batch of 1 is assumed.\n * @param filterShape The shape of the filter, length 4,\n * [filterHeight, filterWidth, inDepth, outDepth].\n * @param strides The strides of the convolution: [strideHeight,\n * strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction conv2dDerFilter_(\n x: T, dy: T, filterShape: [number, number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2dDerFilter: input must be rank 4, but got shape ` +\n `${x4D.shape}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerFilter: dy must be rank 4, but got shape ` +\n `${dy4D.shape}.`);\n util.assert(\n filterShape.length === 4,\n `Error in conv2dDerFilter: filterShape must be length 4, but got ` +\n `${filterShape}.`);\n util.assert(\n x4D.shape[3] === filterShape[2],\n `Error in conv2dDerFilter: depth of input ${x4D.shape[3]}) must ` +\n `match input depth in filter (${filterShape[2]}.`);\n util.assert(\n dy4D.shape[3] === filterShape[3],\n `Error in conv2dDerFilter: depth of dy (${dy4D.shape[3]}) must ` +\n `match output depth for filter (${filterShape[3]}).`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerFilter: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, filterShape, strides, dilations, pad, dimRoundingMode);\n return ENV.engine.runKernel(\n backend => backend.conv2dDerFilter(x4D, dy4D, convInfo), {x4D, dy4D});\n}\n\n/**\n * Computes the transposed 2D convolution of an image, also known as a\n * deconvolution.\n *\n * @param x The input image, of rank 4 or rank 3, of shape\n * `[batch, height, width, inDepth]`. If rank 3, batch of 1 is assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, outDepth, inDepth]`.\n * `inDepth` must match `inDepth` in `x`.\n * @param outputShape Output shape, of rank 4 or rank 3:\n * `[batch, height, width, outDepth]`. If rank 3, batch of 1 is assumed.\n * @param strides The strides of the original convolution:\n * `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm used in the non-transpose version\n * of the op.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2dTranspose_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2dTranspose');\n const $filter = convertToTensor(filter, 'filter', 'conv2dTranspose');\n\n return conv2dDerInput_(\n outputShape, $x, $filter, strides, pad, dimRoundingMode);\n}\n\n/**\n * Depthwise 2D convolution.\n *\n * Given a 4D `input` array and a `filter` array of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]` containing\n * `inChannels` convolutional filters of depth 1, this op applies a\n * different filter to each input channel (expanding from 1 channel to\n * `channelMultiplier` channels for each), then concatenates the results\n * together. The output has `inChannels * channelMultiplier` channels.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction depthwiseConv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'depthwiseConv2d');\n const $filter = convertToTensor(filter, 'filter', 'depthwiseConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in depthwiseConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in depthwiseConv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in depthwiseConv2d: number of input channels ` +\n `(${x4D.shape[3]}) must match the inChannels dimension in ` +\n `filter ${$filter.shape[2]}.`);\n if (dilations == null) {\n dilations = [1, 1];\n }\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in depthwiseConv2d: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in depthwiseConv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode,\n true /* depthwise */);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of depthwiseConv2d: dilation rates greater than ' +\n `1 are not yet supported. Got dilations '${dilations}'`);\n return {\n x: () => depthwiseConv2dDerInput(x4D.shape, dy, $filter, convInfo),\n $filter: () => depthwiseConv2dDerFilter(x4D, dy, $filter.shape, convInfo),\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2D(x4D, $filter, convInfo),\n {x: x4D, $filter}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * 2-D convolution with separable filters.\n *\n * Performs a depthwise convolution that acts separately on channels followed\n * by a pointwise convolution that mixes channels. Note that this is\n * separability between dimensions [1, 2] and 3, not spatial separability\n * between dimensions 1 and 2.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param depthwiseFilter The depthwise filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`. This is\n * the filter used in the first step.\n * @param pointwiseFilter The pointwise filter tensor, rank 4, of shape\n * `[1, 1, inChannels * channelMultiplier, outChannels]`. This is\n * the filter used in the second step.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction separableConv2d_(\n x: T|TensorLike, depthwiseFilter: Tensor4D|TensorLike,\n pointwiseFilter: Tensor4D|TensorLike, strides: [number, number]|number,\n pad: 'valid'|'same', dilation: [number, number]|number = [1, 1],\n dataFormat: 'NHWC'|'NCHW' = 'NHWC'): T {\n const $x = convertToTensor(x, 'x', 'separableConv2d');\n const $depthwiseFilter =\n convertToTensor(depthwiseFilter, 'depthwiseFilter', 'separableConv2d');\n const $pointwiseFilter =\n convertToTensor(pointwiseFilter, 'pointwiseFilter', 'separableConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n\n if (dataFormat === 'NCHW') {\n throw new Error(\n 'separableConv2d currently does not support dataFormat NCHW; only ' +\n 'NHWC is supported');\n }\n\n util.assert(\n x4D.rank === 4,\n `Error in separableConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $depthwiseFilter.rank === 4,\n `Error in separableConv2d: depthwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.rank === 4,\n `Error in separableConv2d: pointwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.shape[0] === 1,\n `Error in separableConv2d: the first dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[0]}.`);\n util.assert(\n $pointwiseFilter.shape[1] === 1,\n `Error in separableConv2d: the second dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[1]}.`);\n\n const inChannels = $depthwiseFilter.shape[2];\n const channelMultiplier = $depthwiseFilter.shape[3];\n util.assert(\n $pointwiseFilter.shape[2] === inChannels * channelMultiplier,\n `Error in separableConv2d: the third dimension of pointwise filter ` +\n `must be ${inChannels * channelMultiplier}, ` +\n `but got ${$pointwiseFilter.shape[2]}.`);\n\n const depthwise = depthwiseConv2d(\n x4D, $depthwiseFilter, strides, pad, dataFormat, dilation);\n const pointwiseStride = 1;\n const res =\n conv2d(depthwise, $pointwiseFilter, pointwiseStride, 'valid', dataFormat);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\nfunction tupleValuesAreOne(param: number|[number, number]): boolean {\n const [dimA, dimB] = parseTupleParam(param);\n return dimA === 1 && dimB === 1;\n}\n\nfunction eitherStridesOrDilationsAreOne(\n strides: number|[number, number],\n dilations: number|[number, number]): boolean {\n return tupleValuesAreOne(strides) || tupleValuesAreOne(dilations);\n}\n\nfunction depthwiseConv2dDerInput(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, convInfo: conv_util.Conv2DInfo): T {\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerInput(dy4D, filter, convInfo),\n {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction depthwiseConv2dDerFilter(\n x: T, dy: T, filterShape: [number, number, number, number],\n convInfo: conv_util.Conv2DInfo): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n return ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerFilter(x4D, dy4D, convInfo),\n {x4D, dy4D});\n}\n\nexport const conv1d = op({conv1d_});\nexport const conv2d = op({conv2d_});\nexport const depthwiseConv2d = op({depthwiseConv2d_});\nexport const separableConv2d = op({separableConv2d_});\nexport const conv2dTranspose = op({conv2dTranspose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Computes the dot product of two matrices, A * B. These must be matrices.\n *\n * ```js\n * const a = tf.tensor2d([1, 2], [1, 2]);\n * const b = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.matMul(b).print(); // or tf.matMul(a, b)\n * ```\n * @param a First matrix in dot product operation.\n * @param b Second matrix in dot product operation.\n * @param transposeA If true, `a` is transposed before multiplication.\n * @param transposeB If true, `b` is transposed before multiplication.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction matMul_(\n a: Tensor2D|TensorLike, b: Tensor2D|TensorLike, transposeA = false,\n transposeB = false): Tensor2D {\n const $a = convertToTensor(a, 'a', 'matMul');\n const $b = convertToTensor(b, 'b', 'matMul');\n\n const innerShapeA = transposeA ? $a.shape[0] : $a.shape[1];\n const innerShapeB = transposeB ? $b.shape[1] : $b.shape[0];\n\n util.assert(\n $a.rank === 2 && $b.rank === 2,\n `Error in matMul: inputs must be rank 2, got ranks ${$a.rank}` +\n ` and ${$b.rank}.`);\n\n util.assert(\n innerShapeA === innerShapeB,\n `Error in matMul: inner shapes (${innerShapeA}) and (` +\n `${innerShapeB}) of Tensors with shapes ${$a.shape} and ` +\n `${$b.shape} and transposeA=${transposeA}` +\n ` and transposeB=${transposeB} must match.`);\n\n const grad = (dy: Tensor2D) => {\n if (!transposeA && !transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, true),\n $b: () => $a.toFloat().matMul(dy, true, false)\n };\n } else if (!transposeA && transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, false),\n $b: () => dy.matMul($a.toFloat(), true, false)\n };\n } else if (transposeA && !transposeB) {\n return {\n $a: () => $b.toFloat().matMul(dy, false, true),\n $b: () => $a.toFloat().matMul(dy, false, false)\n };\n } else {\n return {\n $a: () => $b.toFloat().matMul(dy, true, true),\n $b: () => dy.matMul($a.toFloat(), true, true)\n };\n }\n };\n return ENV.engine.runKernel(\n backend => backend.matMul($a, $b, transposeA, transposeB), {$a, $b},\n grad);\n}\n\n/**\n * Computes the outer product of two vectors, v1 and v2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([3, 4, 5]);\n *\n * tf.outerProduct(a, b).print();\n * ```\n * @param v1 The first vector in the outer product operation.\n * @param v2 The second vector in the dot product operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction outerProduct_(\n v1: Tensor1D|TensorLike, v2: Tensor1D|TensorLike): Tensor2D {\n const $v1 = convertToTensor(v1, 'v1', 'outerProduct');\n const $v2 = convertToTensor(v2, 'v2', 'outerProduct');\n\n util.assert(\n $v1.rank === 1 && $v2.rank === 1,\n `Error in outerProduct: inputs must be rank 1, but got ranks ` +\n `${$v1.rank} and ${$v2.rank}.`);\n\n return $v1.as2D(-1, 1).matMul($v2.as2D(1, -1));\n}\n\n/**\n * Computes the dot product of two matrices and/or vectors, t1 and t2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor2d([[1, 2], [3, 4]]);\n * const c = tf.tensor2d([[1, 2, 3], [4, 5, 6]]);\n *\n * a.dot(b).print(); // or tf.dot(a, b)\n * b.dot(a).print();\n * b.dot(c).print();\n * ```\n * @param t1 The first tensor in the dot operation.\n * @param t2 The second tensor in the dot operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction dot_(t1: Tensor|TensorLike, t2: Tensor|TensorLike): Tensor {\n const $t1 = convertToTensor(t1, 't1', 'dot');\n const $t2 = convertToTensor(t2, 't2', 'dot');\n util.assert(\n ($t1.rank === 1 || $t1.rank === 2) && ($t2.rank === 1 || $t2.rank === 2),\n `Error in dot: inputs must all be rank 1 or 2, but got ranks ` +\n `${$t1.rank} and ${$t2.rank}.`);\n\n const t1Inner = ($t1.rank === 1 ? $t1.size : $t1.shape[1]);\n const t2Inner = ($t2.rank === 1 ? $t2.size : $t2.shape[0]);\n\n util.assert(\n t1Inner === t2Inner,\n `Error in dot: inner dimensions of inputs must match, but got ` +\n `${t1Inner} and ${t2Inner}.`);\n\n if ($t1.rank === 1 && $t2.rank === 1) {\n return $t1.as2D(1, -1).matMul($t2.as2D(-1, 1)).asScalar();\n } else if ($t1.rank === 1 && $t2.rank === 2) {\n return $t1.as2D(1, -1).matMul($t2.as2D($t2.shape[0], $t2.shape[1])).as1D();\n } else if ($t1.rank === 2 && $t2.rank === 1) {\n return $t1.matMul($t2.as2D(-1, 1)).as1D();\n } else {\n return $t1.matMul($t2.as2D($t2.shape[0], $t2.shape[1]));\n }\n}\n\nexport const matMul = op({matMul_});\nexport const dot = op({dot_});\nexport const outerProduct = op({outerProduct_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {parseAxisParam} from './axis_util';\nimport {op} from './operation';\n\n/**\n * Reverses a `Tensor1D`.\n *\n * @param x The input tensor.\n */\nfunction reverse1d_(x: Tensor1D|TensorLike): Tensor1D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 1, `Error in reverse1D: x must be rank 1 but got\n rank ${$x.rank}.`);\n return reverse($x, 0);\n}\n\n/**\n * Reverses a `Tensor2D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse2d_(x: Tensor2D|TensorLike, axis?: number|number[]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 2, `Error in reverse2D: x must be rank 2 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor3D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse3d_(x: Tensor3D|TensorLike, axis?: number|number[]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 3, `Error in reverse3D: x must be rank 3 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor4D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse4d_(x: Tensor4D|TensorLike, axis?: number|number[]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 4, `Error in reverse4D: x must be rank 4 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor` along a specified axis.\n *\n * Also available are stricter rank-specific methods that assert that `x` is\n * of the given rank:\n * - `tf.reverse1d`\n * - `tf.reverse2d`\n * - `tf.reverse3d`\n * - `tf.reverse4d`\n *\n * Except `tf.reverse1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.reverse().print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.reverse(axis).print();\n * ```\n * @param x The input tensor to be reversed.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction reverse_(\n x: T|TensorLike, axis?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'reverse');\n\n if ($x.rank === 0) {\n return $x.clone();\n }\n const axes = parseAxisParam(axis, $x.shape);\n const grad = (dy: T) => {\n return {$x: () => dy.reverse(axes)};\n };\n const res =\n ENV.engine.runKernel(backend => backend.reverse($x, axes), {$x}, grad);\n return res.reshapeAs($x);\n}\n\nexport const reverse = op({reverse_});\nexport const reverse1d = op({reverse1d_});\nexport const reverse2d = op({reverse2d_});\nexport const reverse3d = op({reverse3d_});\nexport const reverse4d = op({reverse4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes the 2D max pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction maxPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'maxPool');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in maxPool: input must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n const convInfo = conv_util.computePool2DInfo(\n x4D.shape, filterSize, strides, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D, saved: Tensor[]) => {\n const [y4D] = saved;\n return {\n x: () =>\n maxPoolBackprop(dy, x4D, y4D as Tensor4D, filterSize, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.maxPool(x4D, convInfo)), {x: x4D}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the 2D average pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction avgPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'avgPool');\n util.assert(\n $x.dtype === 'float32', 'The input dtype to avgPool must be float32');\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in avgPool: x must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in avgPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo =\n conv_util.computePool2DInfo(x4D.shape, filterSize, strides, pad);\n\n const grad = (dy: Tensor4D) => {\n return {x: () => avgPoolBackprop(dy, x4D, filterSize, strides, pad)};\n };\n let res = ENV.engine.runKernel(\n backend => backend.avgPool(x4D, convInfo), {x: x4D}, grad);\n res = res.cast($x.dtype);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the backprop of a max pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The original input image, of rank 4, of shape\n * [batchSize, height, width, channels].\n * @param output The original output image, of rank 4, of shape\n * [batchSize, outHeight, outWidth, channels].\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction maxPoolBackprop(\n dy: Tensor4D|TensorLike, input: Tensor4D|TensorLike,\n output: Tensor4D|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n const $dy = convertToTensor(dy, 'dy', 'maxPoolBackprop');\n const $input = convertToTensor(input, 'input', 'maxPoolBackprop');\n const $output = convertToTensor(output, 'output', 'maxPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n util.assert(\n $dy.rank === 4,\n `Error in maxPoolBackprop: dy must be rank 4 but got rank ` +\n `${$dy.rank}.`);\n util.assert(\n $input.rank === 4,\n `Error in maxPoolBackprop: input must be rank 4 but got rank ` +\n `${$input.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPoolBackprop: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computePool2DInfo(\n $input.shape, filterSize, strides, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.maxPoolBackprop($dy, $input, $output, convInfo),\n {$dy, $input});\n return res;\n}\n\n/**\n * Computes the backprop of an avg pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The input image, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n */\nfunction avgPoolBackprop(\n dy: T|TensorLike, input: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number): T {\n const $dy = convertToTensor(dy, 'dy', 'avgPoolBackprop');\n const $input = convertToTensor(input, 'input', 'avgPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n let input4D = $input as Tensor4D;\n let dy4D = $dy as Tensor4D;\n let reshapedTo4D = false;\n if ($input.rank === 3) {\n reshapedTo4D = true;\n input4D = $input.as4D(1, $input.shape[0], $input.shape[1], $input.shape[2]);\n dy4D = $dy.as4D(1, $dy.shape[0], $dy.shape[1], $dy.shape[2]);\n }\n\n util.assert(\n dy4D.rank === 4,\n `Error in avgPoolBackprop: dy must be rank 4 but got rank ` +\n `${dy4D.rank}.`);\n util.assert(\n input4D.rank === 4,\n `Error in avgPoolBackprop: input must be rank 4 but got rank ` +\n `${input4D.rank}.`);\n\n const convInfo =\n conv_util.computePool2DInfo(input4D.shape, filterSize, strides, pad);\n const res = ENV.engine.runKernel(\n backend => backend.avgPoolBackprop(dy4D, input4D, convInfo),\n {dy4D, input4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nexport const maxPool = op({maxPool_});\nexport const avgPool = op({avgPool_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\nimport * as slice_util from './slice_util';\n\n/**\n * Extracts a 1D slice from 1D array starting at coordinates `begin` and is\n * of length `size`. See `slice` for details.\n */\nfunction slice1d_(\n x: Tensor1D|TensorLike, begin: number, size: number): Tensor1D {\n const $x = convertToTensor(x, 'x', 'slice1d');\n util.assert(\n $x.rank === 1,\n `slice1d expects a rank-1 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, [begin], [size]);\n}\n\n/**\n * Extracts a 2D slice from a 2D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice2d_(\n x: Tensor2D|TensorLike, begin: [number, number],\n size: [number, number]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'slice2d');\n util.assert(\n $x.rank === 2,\n `slice1d expects a rank-2 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 3D slice from a 3D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice3d_(\n x: Tensor3D|TensorLike, begin: [number, number, number],\n size: [number, number, number]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'slice3d');\n util.assert(\n $x.rank === 3,\n `slice1d expects a rank-3 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 4D slice from a 4D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice4d_(\n x: Tensor4D|TensorLike, begin: [number, number, number, number],\n size: [number, number, number, number]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'slice4d');\n util.assert(\n $x.rank === 4,\n `slice1d expects a rank-4 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a slice from a `Tensor` starting at coordinates `begin`\n * and is of size `size`.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `x` is of the given rank:\n * - `tf.slice1d`\n * - `tf.slice2d`\n * - `tf.slice3d`\n * - `tf.slice4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.slice([1], [2]).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * x.slice([1, 0], [1, 2]).print();\n * ```\n * @param x The input `Tensor` to slice from.\n * @param begin The coordinates to start the slice from. The length can be\n * less than the rank of x - the rest of the axes will have implicit 0 as\n * start. Can also be a single number, in which case it specifies the\n * first axis.\n * @param size The size of the slice. The length can be less than the rank of\n * x - the rest of the axes will have implicit -1. A value of -1 requests\n * the rest of the dimensions in the axis. Can also be a single number,\n * in which case it specifies the size of the first axis.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction slice_>(\n x: T|TensorLike, begin: number|number[], size?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'slice');\n\n if ($x.rank === 0) {\n throw new Error('Slicing scalar is not possible');\n }\n // The following logic allows for more ergonomic calls.\n let begin_: number[];\n if (typeof begin === 'number') {\n begin_ = [begin, ...new Array($x.rank - 1).fill(0)];\n } else if (begin.length < $x.rank) {\n begin_ = begin.concat(new Array($x.rank - begin.length).fill(0));\n } else {\n begin_ = begin;\n }\n let size_: number[];\n if (size == null) {\n size_ = new Array($x.rank).fill(-1);\n } else if (typeof size === 'number') {\n size_ = [size, ...new Array($x.rank - 1).fill(-1)];\n } else if (size.length < $x.rank) {\n size_ = size.concat(new Array($x.rank - size.length).fill(-1));\n } else {\n size_ = size;\n }\n size_ = size_.map((d, i) => {\n if (d >= 0) {\n return d;\n } else {\n util.assert(d === -1, 'Bad value in size');\n return $x.shape[i] - begin_[i];\n }\n });\n slice_util.assertParamsValid($x, begin_, size_);\n const inputShape = $x.shape;\n const grad = (dy: T) => {\n // Create an Nx2 padding where the first column represents how many\n // zeros are prepended (at start) for each dimension, and the second\n // column indicates how many zeros are appended (at end).\n\n // The number of zeros to append is the shape of the input\n // elementwise-subtracted by both the begin vector and sizes vector.\n const paddings: Array<[number, number]> = [];\n for (let i = 0; i < dy.rank; i++) {\n paddings.push([begin_[i], inputShape[i] - begin_[i] - size_[i]]);\n }\n return {$x: () => dy.pad(paddings)};\n };\n return ENV.engine.runKernel(\n backend => backend.slice($x, begin_, size_), {$x}, grad) as T;\n}\n\nexport const slice = op({slice_});\nexport const slice1d = op({slice1d_});\nexport const slice2d = op({slice2d_});\nexport const slice3d = op({slice3d_});\nexport const slice4d = op({slice4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Environment} from './environment';\nexport {customGrad, grad, grads, valueAndGrad, valueAndGrads, variableGrads} from './gradients';\n\nexport const tidy = Environment.tidy;\nexport const keep = Environment.keep;\nexport const dispose = Environment.dispose;\nexport const time = Environment.time;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\n/**\n * Computes the log(sum(exp(elements across the reduction dimensions)).\n *\n * Reduces the input along the dimensions given in `axis`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.logSumExp().print(); // or tf.logSumExp(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.logSumExp(axis).print(); // or tf.logSumExp(a, axis)\n * ```\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. If null (the default),\n * reduces all dimensions.\n * @param keepDims If true, retains reduced dimensions with length\n * of 1. Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction logSumExp_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'logSumExp');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const xMax = $x.max(axes, true /* keepDims */);\n const a = $x.sub(xMax);\n const b = a.exp();\n const c = b.sum(axes);\n const d = c.log();\n const res = xMax.reshape(d.shape).add(d);\n\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, axes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the sum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If axes has no entries, all dimensions are reduced, and a `Tensor` with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.sum().print(); // or tf.sum(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.sum(axis).print(); // or tf.sum(x, axis)\n * ```\n *\n * @param x The input tensor to compute the sum over. If the dtype is `bool`\n * it will be converted to `int32` and the output dtype will be `int32`.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction sum_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'sum');\n\n if ($x.dtype === 'bool') {\n $x = $x.toInt();\n }\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n\n // Use a custom gradient to bypass 2 gradient backprops since sum is used\n // extremely often.\n const customOp = customGrad(x => {\n const permutation = axis_util.getAxesPermutation(axes, x.rank);\n let reductionAxes = axes;\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n reductionAxes = axis_util.getInnerMostAxes(reductionAxes.length, x.rank);\n }\n let value = ENV.engine.runKernel(\n backend => backend.sum(permutedX, reductionAxes), {permutedX});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(value.shape, axes);\n value = value.reshape(newShape);\n }\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX = expandedDy.mul(ones(x.shape, 'float32'));\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the mean of elements across dimensions of a `Tensor`.\n *\n * Reduces `x` along the dimensions given in `axis`. Unless `keepDims` is\n * true, the rank of the `Tensor` is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and a `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.mean().print(); // or tf.mean(a)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.mean(axis).print(); // or tf.mean(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction mean_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'mean');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const shapes = axis_util.computeOutAndReduceShapes($x.shape, axes);\n const reduceShape = shapes[1];\n const reduceSize = util.sizeFromShape(reduceShape);\n\n // Use a custom gradient to bypass 2 gradient backprops since mean is used\n // extremely often.\n const customOp = customGrad(x => {\n const reduceSizeScalar = scalar(reduceSize);\n // Cast if needed.\n const xReduce =\n reduceSizeScalar.dtype === x.dtype ? x : x.cast(reduceSizeScalar.dtype);\n const res = xReduce.div(reduceSizeScalar);\n const value = res.sum(axis, keepDims);\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX =\n expandedDy.mul(ones(x.shape, 'float32')).div(reduceSizeScalar);\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the minimum value from the input.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.min().print(); // or tf.min(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.min(axis).print(); // or tf.min(x, axis)\n * ```\n *\n * @param x The input Tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction min_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'min');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.min($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the maximum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.max().print(); // or tf.max(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.max(axis).print(); // or tf.max(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction max_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'max');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.max($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Returns the indices of the minimum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMin().print(); // or tf.argMin(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMin(axis).print(); // or tf.argMin(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMin_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMin');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMin($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Returns the indices of the maximum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMax().print(); // or tf.argMax(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMax(axis).print(); // or tf.argMax(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMax_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMax');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMax($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Computes the logical and of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.all().print(); // or tf.all(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.all(axis).print(); // or tf.all(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction all_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'all', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.all($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the logical or of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.any().print(); // or tf.any(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.any(axis).print(); // or tf.any(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction any_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'any', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.any($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Calculates the mean and variance of `x`. The mean and variance are\n * calculated by aggregating the contents of `x` across `axes`. If `x` is\n * 1-D and `axes = [0]` this is just the mean and variance of a vector.\n *\n * @param x The input tensor.\n * @param axis The dimension(s) along with to compute mean and\n * variance. By default it reduces all dimensions.\n * @param keepDims If true, the moments have the same dimensionality as the\n * input.\n * @return An object with two keys: `mean` and `variance`.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction moments_(\n x: Tensor|TensorLike, axis: number|number[] = null,\n keepDims = false): {mean: Tensor, variance: Tensor} {\n x = convertToTensor(x, 'x', 'moments');\n const axes = axis_util.parseAxisParam(axis, x.shape);\n const mean = x.mean(axes, keepDims);\n let keepDimsShape = mean.shape;\n if (!keepDims) {\n keepDimsShape = axis_util.expandShapeToKeepDim(mean.shape, axes);\n }\n const devSquared = x.toFloat().sub(mean.reshape(keepDimsShape)).square();\n const variance = devSquared.mean(axes, keepDims);\n return {mean, variance};\n}\n\nexport const all = op({all_});\n// tslint:disable-next-line:variable-name\nexport const any = op({any_});\nexport const argMax = op({argMax_});\nexport const argMin = op({argMin_});\nexport const logSumExp = op({logSumExp_});\nexport const max = op({max_});\nexport const mean = op({mean_});\nexport const min = op({min_});\nexport const moments = op({moments_});\nexport const sum = op({sum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\n\n/**\n * Returns the truth value of (a != b) element-wise. Supports broadcasting.\n *\n * We also expose `notEqualStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([0, 2, 3]);\n *\n * a.notEqual(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction notEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqual');\n const $b = convertToTensor(b, 'b', 'notEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n return ENV.engine.runKernel(backend => backend.notEqual($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Strict version of `notEqual` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction notEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqualStrict');\n const $b = convertToTensor(b, 'b', 'notEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in notEqualStrict: ');\n return $a.notEqual($b);\n}\n\n/**\n * Returns the truth value of (a < b) element-wise. Supports broadcasting.\n *\n * We also expose `lessStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.less(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction less_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'less');\n const $b = convertToTensor(b, 'b', 'less');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.less($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Strict version of `less` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction lessStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessStrict');\n const $b = convertToTensor(b, 'b', 'lessStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessStrict: ');\n return $a.less($b);\n}\n\n/**\n * Returns the truth value of (a == b) element-wise. Supports broadcasting.\n *\n * We also expose `equalStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.equal(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction equal_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equal');\n const $b = convertToTensor(b, 'b', 'equal');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.equal($a, $b), {$a, $b}) as T;\n}\n\nfunction equalStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equalStrict');\n const $b = convertToTensor(b, 'b', 'equalStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in equalStrict: ');\n return $a.equal($b);\n}\n\n/**\n * Returns the truth value of (a <= b) element-wise. Supports broadcasting.\n *\n * We also expose `lessEqualStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.lessEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction lessEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqual');\n const $b = convertToTensor(b, 'b', 'lessEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.lessEqual($a, $b), {$a, $b}) as\n T;\n}\n\nfunction lessEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqualStrict');\n const $b = convertToTensor(b, 'b', 'lessEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessEqualStrict: ');\n return $a.lessEqual($b);\n}\n\n/**\n * Returns the truth value of (a > b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greater(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greater_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greater');\n const $b = convertToTensor(b, 'b', 'greater');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.greater($a, $b), {$a, $b}) as\n T;\n}\n\nfunction greaterStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterStrict');\n const $b = convertToTensor(b, 'b', 'greaterStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterStrict: ');\n return $a.greater($b);\n}\n\n/**\n * Returns the truth value of (a >= b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterEqualStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greaterEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greaterEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqual');\n const $b = convertToTensor(b, 'b', 'greaterEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.greaterEqual($a, $b), {$a, $b}) as T;\n}\n\nfunction greaterEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqualStrict');\n const $b = convertToTensor(b, 'b', 'greaterEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterEqualStrict: ');\n return $a.greaterEqual($b);\n}\n\nexport const equal = op({equal_});\nexport const equalStrict = op({equalStrict_});\nexport const greater = op({greater_});\nexport const greaterEqual = op({greaterEqual_});\nexport const greaterEqualStrict = op({greaterEqualStrict_});\nexport const greaterStrict = op({greaterStrict_});\nexport const less = op({less_});\nexport const lessEqual = op({lessEqual_});\nexport const lessEqualStrict = op({lessEqualStrict_});\nexport const lessStrict = op({lessStrict_});\nexport const notEqual = op({notEqual_});\nexport const notEqualStrict = op({notEqualStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {KernelBackend} from '../kernels/backend';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, upcastType} from '../types';\nimport * as util from '../util';\nimport * as broadcast_util from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {neg} from './unary_ops';\n\n/**\n * Adds two `Tensor`s element-wise, A + B. Supports broadcasting.\n *\n * We also expose `addStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n *\n * ```js\n * // Broadcast add a with b.\n * const a = tf.scalar(5);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n * @param a The first `Tensor` to add.\n * @param b The second `Tensor` to add. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction add_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'add');\n const $b = convertToTensor(b, 'b', 'add');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.add($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Adds a list of `Tensor`s element-wise, each with the same shape and dtype.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n *\n * tf.addN([a, b, c]).print();\n * ```\n * @param tensors A list of tensors with the same shape and dtype.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction addN_(tensors: Array): T {\n util.assert(\n Array.isArray(tensors),\n () => 'The param passed to tf.addN() must be a list of tensors');\n util.assert(\n tensors.length >= 1,\n () => `Must pass at least one tensor to tf.addN(), but got ` +\n `${tensors.length}`);\n const $tensors =\n tensors.map((t, i) => convertToTensor(t, `tensors${i}`, 'addN'));\n const firstTensor = $tensors[0];\n $tensors.forEach(t => {\n if (t.dtype !== firstTensor.dtype) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same dtype');\n }\n });\n $tensors.forEach(t => {\n if (!util.arraysEqual(t.shape, firstTensor.shape)) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same shape');\n }\n });\n\n const der = (dy: T) => {\n const ders: {[key: string]: () => Tensor} = {};\n $tensors.forEach((t, i) => {\n ders[i] = () => dy.clone();\n });\n return ders;\n };\n const inputs: NamedTensorMap = $tensors as {} as NamedTensorMap;\n return ENV.engine.runKernel(backend => backend.addN($tensors), inputs, der);\n}\n\n/**\n * Adds two `Tensor`s element-wise, A + B.\n *\n * Inputs must be the same shape. For broadcasting support, use add() instead.\n *\n * @param a The first Tensor to add element-wise.\n * @param b The second Tensor to add element-wise.\n */\nfunction addStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in addStrict: ');\n return a.add(b);\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Supports broadcasting.\n *\n * We also expose `subStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n *\n * ```js\n * // Broadcast subtract a with b.\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.scalar(5);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n * @param a The first `Tensor` to subtract from.\n * @param b The second `Tensor` to be subtracted. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction sub_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'sub');\n const $b = convertToTensor(b, 'b', 'sub');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.neg().reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.subtract($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use sub() instead.\n *\n * @param a The first Tensor to subtract element-wise.\n * @param b The second Tensor to subtract element-wise.\n */\nfunction subStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in subStrict: ');\n return a.sub(b);\n}\n\n/**\n * Computes the power of one `Tensor` to another. Supports broadcasting.\n *\n * Given a `Tensor` x and a `Tensor` y, this operation computes x^y for\n * corresponding elements in x and y. The result's dtype will be the upcasted\n * type of the `base` and `exp` dtypes.\n *\n * ```js\n * const a = tf.tensor([[2, 3], [4, 5]])\n * const b = tf.tensor([[1, 2], [3, 0]]).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n *\n * ```js\n * const a = tf.tensor([[1, 2], [3, 4]])\n * const b = tf.tensor(2).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n * We also expose `powStrict` which has the same signature as this op and\n * asserts that `base` and `exp` are the same shape (does not broadcast).\n *\n * @param base The base `Tensor` to pow element-wise.\n * @param exp The exponent `Tensor` to pow element-wise.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction pow_(base: T|TensorLike, exp: Tensor|TensorLike): T {\n const $base = convertToTensor(base, 'base', 'pow');\n const $exp = convertToTensor(exp, 'exp', 'pow');\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($base.shape, $exp.shape);\n base = $base.cast(upcastType($base.dtype, $exp.dtype));\n exp = $exp.cast(upcastType($base.dtype, $exp.dtype));\n const grad = (dy: Tensor, saved: Tensor[]) => {\n const [y] = saved;\n const derBase = () => {\n let res = dy.mul($exp.toFloat().mul(y.div($base)));\n const reduceAxes = broadcast_util.getReductionAxes($base.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($base.shape) as T;\n };\n const derExp = () => {\n let res = dy.mul(y.mul($base.log()).toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($exp.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($exp.shape);\n };\n return {$base: derBase, $exp: derExp};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.pow($base, $exp)), {$base, $exp},\n grad) as T;\n}\n\n/**\n * Computes the power of one `Tensor` to another. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use pow() instead.\n *\n * @param base The base tensor to pow element-wise.\n * @param exp The exponent tensor to pow element-wise.\n */\nfunction powStrict_(base: T, exp: Tensor): T {\n util.assertShapesMatch(base.shape, exp.shape, 'Error in powStrict: ');\n return base.pow(exp);\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B. Supports broadcasting.\n *\n * We also expose `mulStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([2, 3, 4, 5]);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n *\n * ```js\n * // Broadcast mul a with b.\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.scalar(5);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n * @param a The first tensor to multiply.\n * @param b The second tensor to multiply. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mul_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mul');\n const $b = convertToTensor(b, 'b', 'mul');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.mul($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n const res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.multiply($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B.\n *\n * Inputs must be the same shape. For broadcasting support, use mul().\n *\n * @param a The first tensor to multiply.\n * @param b The first tensor to multiply. Must have the same\n * dtype as `a`.\n */\nfunction mulStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in multiplyStrict: ');\n return a.mul(b) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n *\n * We also expose `divStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction div_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'div');\n const $b = convertToTensor(b, 'b', 'div');\n assertTypesMatch($a, $b);\n\n let forwardFunc: (backend: KernelBackend) => Tensor;\n if ($a.dtype === 'int32' && $b.dtype === 'int32') {\n return floorDiv($a, $b);\n } else {\n forwardFunc = (backend: KernelBackend) => backend.realDivide($a, $b);\n }\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n * The result is rounded with floor function.\n *\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.floorDiv(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.floorDiv(b).print(); // or tf.floorDiv(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction floorDiv_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'floorDiv');\n const $b = convertToTensor(b, 'b', 'floorDiv');\n assertTypesMatch($a, $b);\n\n const forwardFunc = (backend: KernelBackend) => backend.floorDiv($a, $b);\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Inputs must\n * be the same shape.\n *\n * @param a The first tensor as the numerator for element-wise division.\n * @param b The second tensor as the denominator for element-wise division.\n */\nfunction divStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in divideStrict: ');\n return a.div(b) as T;\n}\n\n/**\n * Returns the mod of a and b element-wise.\n * `floor(x / y) * y + mod(x, y) = x`\n * Supports broadcasting.\n *\n * We also expose `modStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * ```js\n * // Broadcast a mod b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mod_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mod');\n const $b = convertToTensor(b, 'b', 'mod');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return dy.sum(reduceAxes).reshape($a.shape);\n }\n return dy;\n };\n const derB = () => {\n const res = dy.mul($a.div($b).floor().neg());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.mod($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Returns the mod of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use mod().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction modStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in modStrict: ');\n return a.mod(b);\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `minimumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * ```js\n * // Broadcast minimum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction minimum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'minimum');\n let $b = convertToTensor(b, 'b', 'minimum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.lessEqual($b).toFloat());\n const derB = () => dy.mul($a.greater($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.minimum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use minimum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction minimumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.minimum(b);\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `maximumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * ```js\n * // Broadcast maximum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction maximum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'maximum');\n let $b = convertToTensor(b, 'b', 'maximum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.greaterEqual($b).toFloat());\n const derB = () => dy.mul($a.less($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.maximum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use maximum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction maximumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.maximum(b);\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n * Supports broadcasting.\n *\n * We also expose `squaredDifferenceStrict` which has the same signature as\n * this op and asserts that `a` and `b` are the same shape (does not\n * broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * ```js\n * // Broadcast squared difference a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction squaredDifference_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'squaredDifference');\n const $b = convertToTensor(b, 'b', 'squaredDifference');\n assertTypesMatch($a, $b);\n\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const two = scalar(2);\n const derA = () => dy.mul($a.sub($b).mul(two));\n const derB = () => dy.mul($b.sub($a).mul(two));\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.squaredDifference($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n *\n * Inputs must be the same shape. For broadcasting support, use\n * squaredDifference() instead.\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\nfunction squaredDifferenceStrict_(a: T, b: T): T {\n util.assertShapesMatch(\n a.shape, b.shape, 'Error in squaredDifferenceStrict: ');\n return a.squaredDifference(b);\n}\n\n/**\n * Computes arctangent of `Tensor`s a / b element-wise: `atan2(a, b)`.\n * Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([1.0, 1.0, -1.0, .7]);\n * const b = tf.tensor1d([2.0, 13.0, 3.5, .21]);\n *\n * tf.atan2(a, b).print()\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan2_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'atan2');\n const $b = convertToTensor(b, 'b', 'atan2');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const d = add($a.square(), $b.square());\n let res = dy.mul($b.div(d));\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n const d = add($a.square(), $b.square()) as T;\n let res = neg(dy.mul($a.div(d)));\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.atan2($a, $b), {$a, $b}, der) as T;\n}\n\nexport const add = op({add_});\nexport const addN = op({addN_});\nexport const addStrict = op({addStrict_});\nexport const atan2 = op({atan2_});\nexport const div = op({div_});\nexport const divStrict = op({divStrict_});\nexport const floorDiv = op({floorDiv_});\nexport const maximum = op({maximum_});\nexport const maximumStrict = op({maximumStrict_});\nexport const minimum = op({minimum_});\nexport const minimumStrict = op({minimumStrict_});\nexport const mod = op({mod_});\nexport const modStrict = op({modStrict_});\nexport const mul = op({mul_});\nexport const mulStrict = op({mulStrict_});\nexport const pow = op({pow_});\nexport const powStrict = op({powStrict_});\nexport const squaredDifference = op({squaredDifference_});\nexport const squaredDifferenceStrict = op({squaredDifferenceStrict_});\nexport const sub = op({sub_});\nexport const subStrict = op({subStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {whereImpl} from '../kernels/where_impl';\nimport {Tensor, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Returns the truth value of `NOT x` element-wise.\n *\n * ```js\n * const a = tf.tensor1d([false, true], 'bool');\n *\n * a.logicalNot().print();\n * ```\n *\n * @param x The input tensor. Must be of dtype 'bool'.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalNot_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logicalNot', 'bool');\n assert($x.dtype === 'bool', 'Error Array must be of type bool.');\n\n return ENV.engine.runKernel(backend => backend.logicalNot($x), {$x});\n}\n\n/**\n * Returns the truth value of a AND b element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalAnd(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalAnd_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalAnd', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalAnd', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.logicalAnd($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Returns the truth value of `a OR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalOr(b).print();\n * ```\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalOr_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalOr', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalOr', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.logicalOr($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Returns the truth value of `a XOR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalXor(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalXor_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalXor', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalXor', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n // x ^ y = (x | y) & ~(x & y)\n return logicalOr(a, b).logicalAnd(logicalAnd(a, b).logicalNot()) as T;\n}\n\n/**\n * Returns the elements, either `a` or `b` depending on the `condition`.\n *\n * If the condition is true, select from `a`, otherwise select from `b`.\n *\n * ```js\n * const cond = tf.tensor1d([false, false, true], 'bool');\n * const a = tf.tensor1d([1 , 2, 3]);\n * const b = tf.tensor1d([-1, -2, -3]);\n *\n * a.where(cond, b).print();\n * ```\n *\n * @param condition The input condition. Must be of dtype bool.\n * @param a If `condition` is rank 1, `a` may have a higher rank but\n * its first dimension must match the size of `condition`.\n * @param b A tensor with the same shape and type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction where_(\n condition: Tensor|TensorLike, a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'where');\n const $b = convertToTensor(b, 'b', 'where');\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n\n assert($condition.dtype === 'bool', 'Error Condition must be of type bool.');\n assertShapesMatch($a.shape, $b.shape, 'Error in where: ');\n\n if ($condition.rank === 1) {\n // If condition rank is 1, then the first dimension must match the size of\n // condition.\n assert(\n $condition.shape[0] === $a.shape[0],\n 'The first dimension of `a` must match the size of `condition`.');\n } else {\n // A must have the same shape as condition.\n assertShapesMatch($condition.shape, $b.shape, 'Error in where: ');\n }\n\n // TODO(julianoks): Return null for condition gradient\n // when backprop supports it.\n const grad = (dy: T) => ({\n $condition: () => zerosLike($condition),\n $a: () => dy.mul($condition.cast($a.dtype)) as T,\n $b: () => dy.mul($condition.logicalNot().cast($b.dtype)) as T\n });\n\n return ENV.engine.runKernel(\n backend => backend.select($condition, $a, $b),\n {$condition, $a, $b}, grad) as T;\n}\n\n/**\n * Returns the coordinates of true elements of condition.\n *\n * The coordinates are returned in a 2-D tensor where the first dimension (rows)\n * represents the number of true elements, and the second dimension (columns)\n * represents the coordinates of the true elements. Keep in mind, the shape of\n * the output tensor can vary depending on how many true values there are in\n * input. Indices are output in row-major order. The resulting tensor has the\n * shape `[numTrueElems, condition.rank]`.\n */\nasync function whereAsync_(condition: Tensor|TensorLike): Promise {\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n assert($condition.dtype === 'bool', 'Condition must be of type bool.');\n const vals = await $condition.data();\n const res = whereImpl($condition.shape, vals);\n if (condition !== $condition) {\n $condition.dispose();\n }\n return res;\n}\n\nexport const logicalAnd = op({logicalAnd_});\nexport const logicalNot = op({logicalNot_});\nexport const logicalOr = op({logicalOr_});\nexport const logicalXor = op({logicalXor_});\nexport const where = op({where_});\nexport const whereAsync = whereAsync_;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {maximum, minimum} from './binary_ops';\nimport {where} from './logical_ops';\nimport {op} from './operation';\nimport {SELU_SCALE, SELU_SCALEALPHA} from './selu_util';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes rectified linear element-wise: `max(x, 0)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.relu().print(); // or tf.relu(x)\n * ```\n * @param x The input tensor. If the dtype is `bool`, the output dtype will be\n * `int32'.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction relu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'relu');\n\n if ($x.dtype === 'bool') {\n return $x.toInt();\n }\n const grad = (dy: T) => {\n const stepRes = $x.step();\n return {$x: () => dy.mulStrict(stepRes.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.relu($x), {$x}, grad);\n}\n\n/**\n * Computes exponential linear element-wise, `x > 0 ? e ^ x - 1 : 0`\n *\n * ```js\n * const x = tf.tensor1d([-1, 1, -3, 2]);\n *\n * x.elu().print(); // or tf.elu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction elu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'elu');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {\n $x: () =>\n ENV.engine.runKernel(backend => backend.eluDer(dy, y), {dy, y}) as T\n };\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.elu($x)), {$x}, grad);\n}\n\n/**\n * Computes scaled exponential linear element-wise.\n *\n * `x < 0 ? scale * alpha * (exp(x) - 1) : x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.selu().print(); // or tf.selu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction selu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'selu');\n\n const grad = (dy: T) => {\n return {\n $x: () => {\n const mask = $x.greater(scalar(0));\n\n const scaleAlpha = scalar(SELU_SCALEALPHA);\n const scale = scalar(SELU_SCALE);\n\n const greaterThanZeroDer = dy.mul(scale);\n const lessEqualZeroDer = dy.mul(scaleAlpha).mul($x.toFloat().exp());\n\n return where(mask, greaterThanZeroDer, lessEqualZeroDer) as T;\n }\n };\n };\n return ENV.engine.runKernel(backend => backend.selu($x), {$x}, grad);\n}\n\n/**\n * Computes leaky rectified linear element-wise.\n *\n * See\n * [http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf](\n * http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf)\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.leakyRelu(0.1).print(); // or tf.leakyRelu(x, 0.1)\n * ```\n * @param x The input tensor.\n * @param alpha The scaling factor for negative values, defaults to 0.2.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction leakyRelu_(x: T|TensorLike, alpha = 0.2): T {\n const $x = convertToTensor(x, 'x', 'leakyRelu');\n return maximum(scalar(alpha).mul($x), $x);\n}\n\n/**\n * Computes leaky rectified linear element-wise with parametric alphas.\n *\n * `x < 0 ? alpha * x : f(x) = x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n * const alpha = tf.scalar(0.1);\n *\n * x.prelu(alpha).print(); // or tf.prelu(x, alpha)\n * ```\n * @param x The input tensor.\n * @param alpha Scaling factor for negative values.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction prelu_(x: T|TensorLike, alpha: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'prelu');\n const $alpha = convertToTensor(alpha, 'alpha', 'prelu');\n\n const zero = scalar(0);\n return maximum(zero, $x).add($alpha.mul(minimum(zero, $x)));\n}\n\nexport const elu = op({elu_});\nexport const leakyRelu = op({leakyRelu_});\nexport const prelu = op({prelu_});\nexport const relu = op({relu_});\nexport const selu = op({selu_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\n\n/**\n * Transposes the `Tensor`. Permutes the dimensions according to `perm`.\n *\n * The returned `Tensor`'s dimension `i` will correspond to the input\n * dimension `perm[i]`. If `perm` is not given, it is set to `[n-1...0]`,\n * where `n` is the rank of the input `Tensor`. Hence by default, this\n * operation performs a regular matrix transpose on 2-D input `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]);\n *\n * a.transpose().print(); // or tf.transpose(a)\n * ```\n *\n * @param x The tensor to transpose.\n * @param perm The permutation of the dimensions of a.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction transpose_(x: T|TensorLike, perm?: number[]): T {\n const $x = convertToTensor(x, 'x', 'transpose');\n\n if (perm == null) {\n perm = $x.shape.map((s, i) => i).reverse();\n }\n util.assert(\n $x.rank === perm.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of perm ${perm}.`);\n perm.forEach(axis => {\n util.assert(\n axis >= 0 && axis < $x.rank,\n `All entries in 'perm' must be between 0 and ${$x.rank - 1}` +\n ` but got ${perm}`);\n });\n\n if ($x.rank <= 1) {\n return $x.clone();\n }\n\n const der = (dy: T) => {\n const undoPerm = axis_util.getUndoAxesPermutation(perm);\n return {$x: () => dy.transpose(undoPerm)};\n };\n return ENV.engine.runKernel(\n backend => backend.transpose($x, perm), {$x}, der);\n}\n\nexport const transpose = op({transpose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Normalizes the activation of a local neighborhood across or within\n * channels.\n *\n * @param x The input tensor. The 4-D input tensor is treated as a 3-D array\n * of 1D vectors (along the last dimension), and each vector is\n * normalized independently.\n * @param depthRadius The number of adjacent channels in the 1D normalization\n * window.\n * @param bias A constant bias term for the basis.\n * @param alpha A scale factor, usually positive.\n * @param beta An exponent.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction localResponseNormalization_(\n x: T|TensorLike, depthRadius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n const $x = convertToTensor(x, 'x', 'localResponseNormalization');\n util.assert(\n $x.rank === 4 || $x.rank === 3,\n `Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank ${$x.rank}.`);\n util.assert(\n util.isInt(depthRadius),\n `Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius ${depthRadius}.`);\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n const [outputImage] = saved;\n return {\n x4D: () => ENV.engine.runKernel(\n backend => backend.LRNGrad(\n dy, x4D, outputImage as Tensor4D, depthRadius, bias, alpha, beta),\n {})\n };\n };\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.localResponseNormalization4D(\n x4D, depthRadius, bias, alpha, beta)),\n {x4D}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n } else {\n return res as T;\n }\n}\n\nexport const localResponseNormalization = op({localResponseNormalization_});","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes the norm of scalar, vectors, and matrices.\n * This function can compute several different vector norms (the 1-norm, the\n * Euclidean or 2-norm, the inf-norm, and in general the p-norm for p > 0)\n * and matrix norms (Frobenius, 1-norm, and inf-norm).\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.norm().print(); // or tf.norm(x)\n * ```\n *\n * @param x The input array.\n * @param ord Optional. Order of the norm. Supported norm types are\n * following:\n *\n * | ord | norm for matrices | norm for vectors\n * |------------|---------------------------|---------------------\n * |'euclidean' |Frobenius norm |2-norm\n * |'fro' |Frobenius norm\t |\n * |Infinity |max(sum(abs(x), axis=1)) |max(abs(x))\n * |-Infinity |min(sum(abs(x), axis=1)) |min(abs(x))\n * |1 |max(sum(abs(x), axis=0)) |sum(abs(x))\n * |2 | |sum(abs(x)^2)^1/2*\n *\n * @param axis Optional. If axis is null (the default), the input is\n * considered a vector and a single vector norm is computed over the entire\n * set of values in the Tensor, i.e. norm(x, ord) is equivalent\n * to norm(x.reshape([-1]), ord). If axis is a integer, the input\n * is considered a batch of vectors, and axis determines the axis in x\n * over which to compute vector norms. If axis is a 2-tuple of integer it is\n * considered a batch of matrices and axis determines the axes in NDArray\n * over which to compute a matrix norm.\n * @param keepDims Optional. If true, the norm have the same dimensionality\n * as the input.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction norm_(\n x: Tensor|TensorLike, ord: number|'euclidean'|'fro' = 'euclidean',\n axis: number|number[] = null, keepDims = false): Tensor {\n x = convertToTensor(x, 'x', 'norm');\n\n const norm = normImpl(x, ord, axis);\n let keepDimsShape = norm.shape;\n if (keepDims) {\n const axes = axis_util.parseAxisParam(axis, x.shape);\n keepDimsShape = axis_util.expandShapeToKeepDim(norm.shape, axes);\n }\n return norm.reshape(keepDimsShape);\n}\n\nfunction normImpl(\n x: Tensor, p: number|string, axis: number|number[] = null): Tensor {\n if (x.rank === 0) {\n return x.abs();\n }\n\n // consider vector when no axis is specified\n if (x.rank !== 1 && axis === null) {\n return normImpl(x.reshape([-1]), p, axis);\n }\n\n // vector\n if (x.rank === 1 || typeof axis === 'number' ||\n axis instanceof Array && axis.length === 1) {\n if (p === 1) {\n return x.abs().sum(axis);\n }\n if (p === Infinity) {\n return x.abs().max(axis);\n }\n if (p === -Infinity) {\n return x.abs().min(axis);\n }\n if (p === 'euclidean' || p === 2) {\n // norm(x, 2) = sum(abs(xi) ^ 2) ^ 1/2\n return x.abs().pow(scalar(2, 'int32')).sum(axis).sqrt() as Tensor;\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n // matrix (assumption axis[0] < axis[1])\n if (axis instanceof Array && axis.length === 2) {\n if (p === 1) {\n return x.abs().sum(axis[0]).max(axis[1] - 1);\n }\n if (p === Infinity) {\n return x.abs().sum(axis[1]).max(axis[0]);\n }\n if (p === -Infinity) {\n return x.abs().sum(axis[1]).min(axis[0]);\n }\n if (p === 'fro' || p === 'euclidean') {\n // norm(x) = sqrt(sum(pow(x, 2)))\n return x.square().sum(axis).sqrt();\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n throw new Error(`Error in norm: invalid axis: ${axis}`);\n}\n\nexport const norm = op({norm_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, isInt} from '../util';\nimport {expandDims} from './array_ops';\nimport {getUndoAxesPermutation, parseAxisParam} from './axis_util';\nimport {maximum} from './binary_ops';\nimport {greaterEqual} from './compare';\nimport {logicalAnd, where} from './logical_ops';\nimport {op} from './operation';\nimport {ones, scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes the sum along segments of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const segmentIds = tf.tensor1d([1, 2, 0, 1], 'int32');\n * const numSegments = 3;\n *\n * x.unsortedSegmentSum(segmentIds, numSegments).print()\n * //or tf.unsortedSegmentSum(x, segmentIds, numSegments)\n * ```\n * @param x The `Tensor` that will be summed along its segments\n * @param segmentIds A `Tensor1D` whose rank is equal to the rank of `x`'s\n * dimension along the `axis`. Maps each element of `x` to a segment.\n * @param numSegments The number of distinct `segmentIds`\n */\n/** @doc {heading: 'Operations', subheading: 'Segment'} */\nfunction unsortedSegmentSum_(\n x: T|TensorLike, segmentIds: Tensor1D|TensorLike, numSegments: number): T {\n const $x = convertToTensor(x, 'x', 'unsortedSegmentSum');\n const $segmentIds =\n convertToTensor(segmentIds, 'segmentIds', 'unsortedSegmentSum', 'int32');\n assert($segmentIds.dtype === 'int32', 'segmentIds must be of dtype `int32`');\n assert(isInt(numSegments), 'numSegments must be of dtype int');\n\n const gradFunc = (dy: T) => {\n const derX = () => {\n return gatherDropNegatives(dy, $segmentIds);\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend =>\n backend.unsortedSegmentSum($x, $segmentIds, numSegments),\n {$x}, gradFunc) as T;\n}\n\n/**\n * Gather slices from tensor `x`'s axis `axis` according to `indices`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const indices = tf.tensor1d([1, 3, 3], 'int32');\n *\n * x.gather(indices).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const indices = tf.tensor1d([1, 1, 0], 'int32');\n *\n * x.gather(indices).print();\n * ```\n * @param x The input tensor whose slices to be gathered.\n * @param indices The indices of the values to extract.\n * @param axis The axis over which to select values. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction gather_(\n x: T|TensorLike, indices: Tensor1D|TensorLike, axis = 0): T {\n const $x = convertToTensor(x, 'x', 'gather');\n const $indices = convertToTensor(indices, 'indices', 'gather', 'int32');\n\n assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n axis = parseAxisParam(axis, $x.shape)[0];\n const grad = (dy: T) => {\n const derX = () => {\n if (axis === 0) {\n return unsortedSegmentSum(dy, $indices, $x.shape[axis]);\n }\n const paramsShape = $x.shape;\n const indicesSize = $indices.size;\n\n const outerShape = paramsShape.slice(0, axis);\n const outerDims = outerShape.length;\n const innerShape = paramsShape.slice(axis, paramsShape.length).slice(1);\n const innerDims = innerShape.length;\n\n const outerAxesIndices = arrayRange(0, outerDims);\n const innerAxesIndices =\n arrayRange(outerDims + 1, outerDims + 1 + innerDims);\n\n const valuesShape = arrayConcat([outerShape, [indicesSize], innerShape]);\n\n const values = dy.reshape(valuesShape);\n const reshapedIndices = $indices.reshape([indicesSize]);\n\n const transposeDims =\n arrayConcat([[outerDims], outerAxesIndices, innerAxesIndices]);\n const valuesTranspose = values.transpose(transposeDims);\n\n let paramsGrad = unsortedSegmentSum(\n valuesTranspose, reshapedIndices as Tensor1D, $x.shape[axis]);\n\n const invertTransposeDims = getUndoAxesPermutation(transposeDims);\n paramsGrad = paramsGrad.transpose(invertTransposeDims);\n\n return paramsGrad as T;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend => backend.gather($x, $indices as Tensor1D, axis), {$x},\n grad) as T;\n}\n\nfunction arrayRange(start: number, stop: number): number[] {\n const result = [];\n for (let i = start; i < stop; ++i) {\n result.push(i);\n }\n return result;\n}\n\nfunction arrayConcat(arrays: number[][]): number[] {\n const result = [];\n for (let i = 0; i < arrays.length; ++i) {\n for (let j = 0; j < arrays[i].length; ++j) {\n result.push(arrays[i][j]);\n }\n }\n return result;\n}\n\nfunction gatherDropNegatives(x: T, indices: Tensor1D) {\n // Helper function for unsorted segment ops. Gathers params for\n // positive segment ids and gathers 0 for inputs with negative segment id.\n // Mirrors _GatherDropNegatives from tensorflow/python/ops/math_grad.py\n const zeroClippedIndices = maximum(indices, zerosLike(indices));\n const gathered = gather(x, zeroClippedIndices as Tensor1D);\n let isPositive = greaterEqual(indices, scalar(0, 'int32'));\n const numIters = gathered.rank - isPositive.rank;\n for (let i = 0; i < numIters; ++i) {\n isPositive = expandDims(isPositive, i + 1);\n }\n isPositive = logicalAnd(isPositive, ones(gathered.shape, 'bool'));\n const zeroSlice = zerosLike(gathered);\n return where(isPositive, gathered, zeroSlice);\n}\n\nexport const gather = op({gather_});\nexport const unsortedSegmentSum = op({unsortedSegmentSum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * @docalias (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D]\n */\nexport type LSTMCellFunc = {\n (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D];\n};\n\n/**\n * Computes the next states and outputs of a stack of LSTMCells.\n *\n * Each cell output is used as input to the next cell.\n *\n * Returns `[cellState, cellOutput]`.\n *\n * Derived from tf.contrib.rn.MultiRNNCell.\n *\n * @param lstmCells Array of LSTMCell functions.\n * @param data The input to the cell.\n * @param c Array of previous cell states.\n * @param h Array of previous cell outputs.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction multiRNNCell_(\n lstmCells: LSTMCellFunc[], data: Tensor2D|TensorLike,\n c: Tensor2D[]|TensorLike[],\n h: Tensor2D[]|TensorLike[]): [Tensor2D[], Tensor2D[]] {\n const $data = convertToTensor(data, 'data', 'multiRNNCell');\n const $c = convertToTensorArray(c, 'c', 'multiRNNCell');\n const $h = convertToTensorArray(h, 'h', 'multiRNNCell');\n\n let input = $data;\n const newStates = [];\n for (let i = 0; i < lstmCells.length; i++) {\n const output = lstmCells[i](input, $c[i], $h[i]);\n newStates.push(output[0]);\n newStates.push(output[1]);\n input = output[1];\n }\n const newC: Tensor2D[] = [];\n const newH: Tensor2D[] = [];\n for (let i = 0; i < newStates.length; i += 2) {\n newC.push(newStates[i]);\n newH.push(newStates[i + 1]);\n }\n return [newC, newH];\n}\n\n/**\n * Computes the next state and output of a BasicLSTMCell.\n *\n * Returns `[newC, newH]`.\n *\n * Derived from tf.contrib.rnn.BasicLSTMCell.\n *\n * @param forgetBias Forget bias for the cell.\n * @param lstmKernel The weights for the cell.\n * @param lstmBias The bias for the cell.\n * @param data The input to the cell.\n * @param c Previous cell state.\n * @param h Previous cell output.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction basicLSTMCell_(\n forgetBias: Scalar|TensorLike, lstmKernel: Tensor2D|TensorLike,\n lstmBias: Tensor1D|TensorLike, data: Tensor2D|TensorLike,\n c: Tensor2D|TensorLike, h: Tensor2D|TensorLike): [Tensor2D, Tensor2D] {\n const $forgetBias =\n convertToTensor(forgetBias, 'forgetBias', 'basicLSTMCell');\n const $lstmKernel =\n convertToTensor(lstmKernel, 'lstmKernel', 'basicLSTMCell');\n const $lstmBias = convertToTensor(lstmBias, 'lstmBias', 'basicLSTMCell');\n const $data = convertToTensor(data, 'data', 'basicLSTMCell');\n const $c = convertToTensor(c, 'c', 'basicLSTMCell');\n const $h = convertToTensor(h, 'h', 'basicLSTMCell');\n\n const combined = $data.concat($h, 1);\n const weighted = combined.matMul($lstmKernel);\n const res = weighted.add($lstmBias) as Tensor2D;\n\n // i = input_gate, j = new_input, f = forget_gate, o = output_gate\n const batchSize = res.shape[0];\n const sliceCols = res.shape[1] / 4;\n const sliceSize: [number, number] = [batchSize, sliceCols];\n const i = res.slice([0, 0], sliceSize);\n const j = res.slice([0, sliceCols], sliceSize);\n const f = res.slice([0, sliceCols * 2], sliceSize);\n const o = res.slice([0, sliceCols * 3], sliceSize);\n\n const newC = i.sigmoid().mulStrict(j.tanh()).addStrict(\n $c.mulStrict($forgetBias.add(f).sigmoid() as Tensor2D));\n const newH = newC.tanh().mulStrict(o.sigmoid());\n return [newC, newH];\n}\n\nexport const basicLSTMCell = op({basicLSTMCell_});\nexport const multiRNNCell = op({multiRNNCell_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {pow} from './binary_ops';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Compute the moving average of a variable.\n *\n * Without zeroDebias, the moving average operation is defined by:\n * `v += delta`\n * where\n * `delta = (1 - decay) * (x - v)`\n *\n * With zeroDebias (default), the `delta` term is scaled to debias the\n * effect of the (assumed) zero-initialization of `v`.\n * `delta /= (1 - decay ^ step)`\n *\n * For more details on the zero-debiasing algorithm, see:\n * https://arxiv.org/abs/1412.6980\n *\n * Note that this function is completely stateless and does not keep track of\n * step count. The step count needs to be maintained by the caller and passed\n * in as `step`.\n *\n * @param v The current moving average value.\n * @param x New input value, must have the same shape and dtype as `v`.\n * @param decay The decay factor. Typical values are 0.95 and 0.99.\n * @param step Step count.\n * @param zeroDebias: Whether zeroDebias is to be performed (default: `true`).\n * @returns The new moving average value.\n */\n/** @doc {heading: 'Operations', subheading: 'Moving Average'} */\nfunction movingAverage_(\n v: T|TensorLike, x: T|TensorLike, decay: number|Scalar,\n step?: number|Scalar, zeroDebias = true): T {\n const $v = convertToTensor(v, 'v', 'movingAverage');\n const $x = convertToTensor(x, 'x', 'movingAverage');\n const $decay = convertToTensor(decay, 'decay', 'movingAverage');\n\n assertTypesMatch($v, $x);\n util.assert(\n util.arraysEqual($v.shape, $x.shape), 'Shape mismatch in v and x');\n\n const one = scalar(1);\n const oneMinusDecay = one.sub($decay);\n\n let update = $x.sub($v).mul(oneMinusDecay);\n if (zeroDebias) {\n util.assert(step != null, 'When using zeroDebias: true, step is required.');\n const $step = convertToTensor(step, 'step', 'movingAverage');\n update = update.div(one.sub(pow($decay, $step)));\n }\n return $v.add(update);\n}\n\nexport const movingAverage = op({movingAverage_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Extracts a strided slice of a tensor.\n *\n * Roughly speaking, this op extracts a slice of size (end-begin)/stride from\n * the given input_ tensor. Starting at the location specified by begin the\n * slice continues by adding stride to the index until all dimensions are not\n * less than end. Note that a stride can be negative, which causes a reverse\n * slice.\n *\n * ```js\n * t = tf.tensor3d([1, 1, 1 ,2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6],\n * [3, 2, 3]);\n * t.stridedSlice([1, 0, 0], [2, 1, 3], [1, 1, 1]).print() // [[[3, 3, 3]]]\n * t.stridedSlice([1, 0, 0], [2, 2, 3], [1, 1, 1]).print() // [[[3, 3, 3],\n * // [4, 4, 4]]]\n * t.stridedSlice([1, -1, 0], [2, -3, 3], [1, -1, 1]).print() // [[[4, 4, 4],\n * // [3, 3, 3]]]\n * ```\n *\n * @param x The tensor to stride slice.\n * @param begin The coordinates to start the slice from.\n * @param end: The coordinates to end the slice at.\n * @param strides: The size of the slice.\n * @param beginMask: If the ith bit of begin_mask is set, begin[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n * @param endMask: If the ith bit of end_mask is set, end[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n */\n/** @doc {heading: 'Operations', subheading: 'Slicing and Joining'} */\nfunction stridedSlice_(\n x: T|TensorLike, begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): T {\n const $x = convertToTensor(x, 'x', 'stridedSlice');\n return ENV.engine.runKernel(\n backend => backend.stridedSlice(\n $x, begin, end, strides, beginMask, endMask),\n {$x}) as T;\n}\n\nexport const stridedSlice = op({stridedSlice_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Finds the values and indices of the `k` largest entries along the last\n * dimension.\n *\n * If the input is a vector (rank=1), finds the k largest entries in the vector\n * and outputs their values and indices as vectors. Thus values[j] is the j-th\n * largest entry in input, and its index is indices[j].\n * For higher rank inputs, computes the top k entries along the last dimension.\n *\n * If two elements are equal, the lower-index element appears first.\n *\n * ```js\n * const a = tensor2d([[1, 5], [4, 3]]);\n * const {values, indices} = tf.topk(a);\n * values.print();\n * indices.print();\n * ```\n * @param x 1-D or higher `Tensor` with last dimension being at least `k`.\n * @param k Number of top elements to look for along the last dimension.\n * @param sorted If true, the resulting `k` elements will be sorted by the\n * values in descending order.\n */\n/** @doc {heading: 'Operations', subheading: 'Evaluation'} */\nfunction topk_(\n x: T|TensorLike, k = 1, sorted = true): {values: T, indices: T} {\n const $x = convertToTensor(x, 'x', 'topk');\n if ($x.rank === 0) {\n throw new Error('topk() expects the input to be of rank 1 or higher');\n }\n const lastDim = $x.shape[$x.shape.length - 1];\n if (k > lastDim) {\n throw new Error(\n `'k' passed to topk() must be <= the last dimension (${lastDim}) ` +\n `but got ${k}`);\n }\n\n const [values, indices] =\n ENV.engine.runKernel(b => b.topk($x, k, sorted), {$x});\n return {values, indices};\n}\n\nexport const topk = op({topk_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch, sizeFromShape} from '../util';\n\nimport {expandShapeToKeepDim} from './axis_util';\n\nimport {minimum} from './binary_ops';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\nexport enum Reduction {\n NONE,\n MEAN,\n SUM,\n SUM_BY_NONZERO_WEIGHTS\n}\n\n/**\n * Computes the weighted loss between two tensors.\n *\n * @param losses Tensor of shape `[batch_size, d1, ... dN]`.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `losses`, and must be broadcastable to `losses` (i.e., all\n * dimensions must be either `1`, or the same as the corresponding\n * `losses` dimension).\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction computeWeightedLoss_(\n losses: T|TensorLike, weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $losses = convertToTensor(losses, 'losses', 'computeWeightedLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'computeWeightedLoss');\n }\n\n const weightedLoss = ($weights == null) ? $losses : $losses.mul($weights);\n\n if (reduction === Reduction.NONE) {\n return weightedLoss as O;\n }\n if (reduction === Reduction.SUM) {\n return weightedLoss.sum();\n }\n if (reduction === Reduction.MEAN) {\n if ($weights == null) {\n return weightedLoss.mean();\n } else {\n const broadcastFactor =\n sizeFromShape($losses.shape) / sizeFromShape($weights.shape);\n const result = weightedLoss.sum().div($weights.sum());\n return broadcastFactor > 1 ? result.div(scalar(broadcastFactor)) :\n result as O;\n }\n }\n if (reduction === Reduction.SUM_BY_NONZERO_WEIGHTS) {\n if ($weights == null) {\n return weightedLoss.sum().div(scalar($losses.size));\n } else {\n const broadcastedWeights = $weights.mul(ones($losses.shape));\n\n const numNonZeros =\n broadcastedWeights.notEqual(scalar(0)).sum().toFloat();\n return weightedLoss.sum().div(numNonZeros);\n }\n }\n\n throw Error(`Unknown reduction: ${reduction}`);\n}\n\n/**\n * Computes the absolute difference loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction absoluteDifference_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'absoluteDifference');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'absoluteDifference');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'absoluteDifference');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in absoluteDifference: ');\n\n const losses = $labels.sub($predictions).abs();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the mean squared error between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction meanSquaredError_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'meanSquaredError');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'meanSquaredError');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'meanSquaredError');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in meanSquaredError: ');\n\n const losses = $labels.squaredDifference($predictions);\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the cosine distance loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param axis The dimension along which the cosine distance is computed.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction cosineDistance_(\n labels: T|TensorLike, predictions: T|TensorLike, axis: number,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'cosineDistance');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'cosineDistance');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'cosineDistance');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in cosineDistance: ');\n\n const one = scalar(1);\n const losses = one.sub($labels.mul($predictions).sum(axis, true));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the Hinge loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction hingeLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $labels = convertToTensor(labels, 'labels', 'hingeLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'hingeLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'hingeLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in hingeLoss: ');\n\n const one = scalar(1);\n // Convert binary labels to (-1, 1)\n $labels = scalar(2).mul($labels).sub(one);\n const losses = one.sub($labels.mul($predictions)).relu();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the log loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param epsilon A small increment to avoid taking log of zero\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction logLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, epsilon = 1e-7,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'logLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'logLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'logLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in logLoss: ');\n\n const one = scalar(1);\n const epsilonScalar = scalar(epsilon);\n const losses = $labels.mul($predictions.add(epsilonScalar).log())\n .neg()\n .sub(one.sub($labels).mul(\n one.sub($predictions).add(epsilonScalar).log()));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nfunction sigmoidCrossEntropyWithLogits_(\n labels: T|TensorLike, logits: T|TensorLike): O {\n const $labels =\n convertToTensor(labels, 'labels', 'sigmoidCrossEntropyWithLogits');\n const $logits =\n convertToTensor(logits, 'logits', 'sigmoidCrossEntropyWithLogits');\n assertShapesMatch(\n $labels.shape, $logits.shape, 'Error in sigmoidCrossEntropyWithLogits: ');\n\n /**\n * Implementation Details:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n *\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n *\n * Hence, to ensure stability and avoid overflow, the implementation uses\n * this equivalent formulation:\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n */\n const maxOutput = $logits.relu();\n const outputXTarget = $logits.mul($labels);\n const sigmoidOutput = $logits.abs().neg().exp().log1p();\n\n return maxOutput.sub(outputXTarget).add(sigmoidOutput);\n}\n\n/**\n * Computes the sigmoid cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newMulticlassLabels = multiclassLabels * (1 - labelSmoothing)\n * + 0.5 * labelSmoothing\n *\n * @param multiClassLabels The ground truth output tensor of shape\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction sigmoidCrossEntropy_(\n multiClassLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $multiClassLabels = convertToTensor(\n multiClassLabels, 'multiClassLabels', 'sigmoidCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'sigmoidCrossEntropy');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'sigmoidCrossEntropy');\n }\n assertShapesMatch(\n $multiClassLabels.shape, $logits.shape, 'Error in sigmoidCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const half = scalar(0.5);\n\n $multiClassLabels = $multiClassLabels.mul(one.sub(labelSmoothingScalar))\n .add(half.mul(labelSmoothingScalar));\n }\n const losses = sigmoidCrossEntropyWithLogits_($multiClassLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the huber loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param delta Point where huber loss changes from quadratic to linear.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`.\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction huberLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, delta = 1.0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'huberLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'huberLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'huberLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in huberLoss: ');\n\n const deltaScalar = scalar(delta);\n const error = $predictions.sub($labels).abs();\n const quadratic = minimum(error, deltaScalar);\n const linear = error.sub(quadratic);\n\n const losses =\n scalar(0.5).mul(quadratic.square()).add(deltaScalar.mul(linear));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes softmax cross entropy between logits and labels.\n *\n * Measures the probability error in discrete classification tasks in which\n * the classes are mutually exclusive (each entry is in exactly one class).\n * For example, each CIFAR-10 image is labeled with one and only one label: an\n * image can be a dog or a truck, but not both.\n *\n * `NOTE`: While the classes are mutually exclusive, their probabilities need\n * not be. All that is required is that each row of labels is a valid\n * probability distribution. If they are not, the computation of the gradient\n * will be incorrect.\n *\n * `WARNING`: This op expects unscaled logits, since it performs a softmax on\n * logits internally for efficiency. Do not call this op with the output of\n * softmax, as it will produce incorrect results.\n *\n * logits and labels must have the same shape, e.g. [batch_size, num_classes]\n * and the same dtype.\n * @param labels The labels array.\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\nfunction softmaxCrossEntropyWithLogits_(\n labels: T, logits: T, dim = -1): O {\n if (dim === -1) {\n dim = logits.rank - 1;\n }\n\n if (dim !== logits.rank - 1) {\n throw Error(\n `Softmax cross entropy along a non-last dimension is not yet ` +\n `supported. Labels / logits was rank ${logits.rank} ` +\n `and dim was ${dim}`);\n }\n // Use a custom gradient for numerical stability.\n const customOp = customGrad((labels, logits) => {\n // Reference:\n // 1. http://cs231n.github.io/linear-classify/#softmax\n // 2. https://blog.feedly.com/tricks-of-the-trade-logsumexp/\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n\n const logResult = logits.toFloat().sub(lse);\n const costVector = logResult.mul(labels).neg();\n\n const value = costVector.sum([dim]) as O;\n\n const gradFunc = (dy: O) => {\n const dyShape = expandShapeToKeepDim(dy.shape, [dim]);\n return [\n dy.reshape(dyShape).mul(labels.toFloat().sub(logResult.exp())),\n dy.reshape(dyShape).mul(logResult.exp().sub(labels.toFloat())),\n ];\n };\n return {value, gradFunc};\n });\n\n return customOp(labels, logits);\n}\n\n/**\n * Computes the softmax cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newOnehotLabels = onehotLabels * (1 - labelSmoothing)\n * + labelSmoothing / numClasses\n *\n * @param onehotLabels One hot encoded labels\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or 1, and must be\n * broadcastable to `loss` of shape [batch_size]\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction softmaxCrossEntropy_(\n onehotLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $onehotLabels =\n convertToTensor(onehotLabels, 'onehotLabels', 'softmaxCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'softmaxCrossEntropy');\n let $weights: Tensor = null;\n\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'softmaxCrossEntropy');\n }\n\n assertShapesMatch(\n $onehotLabels.shape, $logits.shape, 'Error in softmaxCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const numClasses = scalar($onehotLabels.shape[1]);\n\n $onehotLabels = $onehotLabels.mul(one.sub(labelSmoothingScalar))\n .add(labelSmoothingScalar.div(numClasses));\n }\n\n const losses = softmaxCrossEntropyWithLogits_($onehotLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nexport const absoluteDifference = op({absoluteDifference_});\nexport const computeWeightedLoss = op({computeWeightedLoss_});\nexport const cosineDistance = op({cosineDistance_});\nexport const hingeLoss = op({hingeLoss_});\nexport const huberLoss = op({huberLoss_});\nexport const logLoss = op({logLoss_});\nexport const meanSquaredError = op({meanSquaredError_});\nexport const sigmoidCrossEntropy = op({sigmoidCrossEntropy_});\nexport const softmaxCrossEntropy = op({softmaxCrossEntropy_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Linear algebra ops.\n */\n\nimport {ENV} from '../environment';\nimport {dispose} from '../globals';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {assert} from '../util';\nimport {eye, split, squeeze, stack, unstack} from './array_ops';\nimport {norm} from './norm';\nimport {op} from './operation';\nimport {sum} from './reduction_ops';\nimport {tensor2d} from './tensor_ops';\n\n/**\n * Gram-Schmidt orthogonalization.\n *\n * @param xs The vectors to be orthogonalized, in one of the two following\n * formats:\n * - An Array of `Tensor1D`.\n * - A `Tensor2D`, i.e., a matrix, in which case the vectors are the rows\n * of `xs`.\n * In each case, all the vectors must have the same length and the length\n * must be greater than or equal to the number of vectors.\n * @returns The orthogonalized and normalized vectors or matrix.\n * Orthogonalization means that the vectors or the rows of the matrix\n * are orthogonal (zero inner products). Normalization means that each\n * vector or each row of the matrix has an L2 norm that equals `1`.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction gramSchmidt_(xs: Tensor1D[]|Tensor2D): Tensor1D[]|Tensor2D {\n let inputIsTensor2D: boolean;\n if (Array.isArray(xs)) {\n inputIsTensor2D = false;\n assert(\n xs != null && xs.length > 0,\n 'Gram-Schmidt process: input must not be null, undefined, or empty');\n const dim = xs[0].shape[0];\n for (let i = 1; i < xs.length; ++i) {\n assert(\n xs[i].shape[0] === dim,\n 'Gram-Schmidt: Non-unique lengths found in the input vectors: ' +\n `(${xs[i].shape[0]} vs. ${dim})`);\n }\n } else {\n inputIsTensor2D = true;\n xs = split(xs, xs.shape[0], 0).map(x => squeeze(x, [0]));\n }\n\n assert(\n xs.length <= xs[0].shape[0],\n `Gram-Schmidt: Number of vectors (${xs.length}) exceeds ` +\n `number of dimensions (${xs[0].shape[0]}).`);\n\n const ys: Tensor1D[] = [];\n const xs1d = xs as Tensor1D[];\n for (let i = 0; i < xs.length; ++i) {\n ys.push(ENV.engine.tidy(() => {\n let x = xs1d[i];\n if (i > 0) {\n for (let j = 0; j < i; ++j) {\n const proj = sum(ys[j].mulStrict(x)).mul(ys[j]);\n x = x.sub(proj);\n }\n }\n return x.div(norm(x, 'euclidean'));\n }));\n }\n\n if (inputIsTensor2D) {\n return stack(ys, 0) as Tensor2D;\n } else {\n return ys;\n }\n}\n\n/**\n * Compute QR decomposition of m-by-n matrix using Householder transformation.\n *\n * Implementation based on\n * [http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf]\n * (http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf)\n *\n * @param x The `Tensor` to be QR-decomposed. Must have rank >= 2. Suppose\n * it has the shape `[..., M, N]`.\n * @param fullMatrices An optional boolean parameter. Defaults to `false`.\n * If `true`, compute full-sized `Q`. If `false` (the default),\n * compute only the leading N columns of `Q` and `R`.\n * @return An `Array` of two `Tensor`s: `[Q, R]`. `Q` is a unitary matrix,\n * i.e., its columns all have unit norm and are mutually orthogonal.\n * If `M >= N`,\n * If `fullMatrices` is `false` (default),\n * - `Q` has a shape of `[..., M, N]`,\n * - `R` has a shape of `[..., N, N]`.\n * If `fullMatrices` is `true` (default),\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * If `M < N`,\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * @throws If the rank of `x` is less than 2.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction qr_(x: Tensor, fullMatrices = false): [Tensor, Tensor] {\n if (x.rank < 2) {\n throw new Error(\n `qr() requires input tensor to have a rank >= 2, but got rank ${\n x.rank}`);\n } else if (x.rank === 2) {\n return qr2d(x as Tensor2D, fullMatrices);\n } else {\n // Rank > 2.\n // TODO(cais): Below we split the input into individual 2D tensors,\n // perform QR decomposition on them and then stack the results back\n // together. We should explore whether this can be parallelized.\n const outerDimsProd = x.shape.slice(0, x.shape.length - 2)\n .reduce((value, prev) => value * prev);\n const x2ds = unstack(\n x.reshape([\n outerDimsProd, x.shape[x.shape.length - 2],\n x.shape[x.shape.length - 1]\n ]),\n 0);\n const q2ds: Tensor2D[] = [];\n const r2ds: Tensor2D[] = [];\n x2ds.forEach(x2d => {\n const [q2d, r2d] = qr2d(x2d as Tensor2D, fullMatrices);\n q2ds.push(q2d);\n r2ds.push(r2d);\n });\n const q = stack(q2ds, 0).reshape(x.shape);\n const r = stack(r2ds, 0).reshape(x.shape);\n return [q, r];\n }\n}\n\nfunction qr2d(x: Tensor2D, fullMatrices = false): [Tensor2D, Tensor2D] {\n return ENV.engine.tidy(() => {\n if (x.shape.length !== 2) {\n throw new Error(\n `qr2d() requires a 2D Tensor, but got a ${x.shape.length}D Tensor.`);\n }\n\n const m = x.shape[0];\n const n = x.shape[1];\n\n let q = eye(m) as Tensor2D; // Orthogonal transform so far.\n let r = x.clone(); // Transformed matrix so far.\n\n const one2D = tensor2d([[1]], [1, 1]);\n let w: Tensor2D = one2D.clone();\n\n const iters = m >= n ? n : m;\n for (let j = 0; j < iters; ++j) {\n // This tidy within the for-loop ensures we clean up temporary\n // tensors as soon as they are no longer needed.\n const rTemp = r;\n const wTemp = w;\n const qTemp = q;\n [w, r, q] = ENV.engine.tidy((): [Tensor2D, Tensor2D, Tensor2D] => {\n // Find H = I - tau * w * w', to put zeros below R(j, j).\n const rjEnd1 = r.slice([j, j], [m - j, 1]);\n const normX = rjEnd1.norm();\n const rjj = r.slice([j, j], [1, 1]);\n const s = rjj.sign().neg() as Tensor2D;\n const u1 = rjj.sub(s.mul(normX)) as Tensor2D;\n const wPre = rjEnd1.div(u1);\n if (wPre.shape[0] === 1) {\n w = one2D.clone();\n } else {\n w = one2D.concat(\n wPre.slice([1, 0], [wPre.shape[0] - 1, wPre.shape[1]]), 0) as\n Tensor2D;\n }\n const tau = s.matMul(u1).div(normX).neg() as Tensor2D;\n\n // -- R := HR, Q := QH.\n const rjEndAll = r.slice([j, 0], [m - j, n]);\n const tauTimesW = tau.mul(w) as Tensor2D;\n if (j === 0) {\n r = rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll)));\n } else {\n r = r.slice([0, 0], [j, n])\n .concat(\n rjEndAll.sub(\n tauTimesW.matMul(w.transpose().matMul(rjEndAll))),\n 0) as Tensor2D;\n }\n const qAllJEnd = q.slice([0, j], [m, q.shape[1] - j]);\n if (j === 0) {\n q = qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose()));\n } else {\n q = q.slice([0, 0], [m, j])\n .concat(\n qAllJEnd.sub(\n qAllJEnd.matMul(w).matMul(tauTimesW.transpose())),\n 1) as Tensor2D;\n }\n return [w, r, q];\n });\n dispose([rTemp, wTemp, qTemp]);\n }\n\n if (!fullMatrices && m > n) {\n q = q.slice([0, 0], [m, n]);\n r = r.slice([0, 0], [n, n]);\n }\n\n return [q, r];\n }) as [Tensor2D, Tensor2D];\n}\n\nexport const gramSchmidt = op({gramSchmidt_});\nexport const qr = op({qr_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ForwardFunc} from '../engine';\nimport {ENV} from '../environment';\nimport {nonMaxSuppressionImpl} from '../kernels/non_max_suppression_impl';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Bilinear resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeBilinear_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeBilinear');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeBilinear: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeBilinear: new shape must 2D, but got shape ` +\n `${size}.`);\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n\n const [newHeight, newWidth] = size;\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeBilinear(batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend =>\n backend.resizeBilinearBackprop(dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * NearestNeighbor resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeNearestNeighbor_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeNearestNeighbor');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeNearestNeighbor: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeNearestNeighbor: new shape must 2D, but got shape ` +\n `${size}.`);\n util.assert(\n $images.dtype === 'float32' || $images.dtype === 'int32',\n '`images` must have `int32` or `float32` as dtype');\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n const [newHeight, newWidth] = size;\n\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeNearestNeighbor(\n batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend => backend.resizeNearestNeighborBackprop(\n dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Performs non maximum suppression of bounding boxes based on\n * iou (intersection over union)\n *\n * @param boxes a 2d tensor of shape `[numBoxes, 4]`. Each entry is\n * `[y1, x1, y2, x2]`, where `(y1, x1)` and `(y2, x2)` are the corners of\n * the bounding box.\n * @param scores a 1d tensor providing the box scores of shape `[numBoxes]`.\n * @param maxOutputSize The maximum number of boxes to be selected.\n * @param iouThreshold A float representing the threshold for deciding whether\n * boxes overlap too much with respect to IOU. Must be betwen [0, 1].\n * Defaults to 0.5 (50% box overlap).\n * @param scoreThreshold A threshold for deciding when to remove boxes based\n * on score. Defaults to -inf, which means any score is accepted.\n * @return A 1D tensor with the selected box indices.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction nonMaxSuppression_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Tensor1D {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppression');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppression');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n return ENV.engine.runKernel(\n b => b.nonMaxSuppression(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold),\n {$boxes});\n}\n\n/** This is the async version of `nonMaxSuppression` */\nasync function nonMaxSuppressionAsync_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Promise {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppressionAsync');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppressionAsync');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n const boxesVals = await $boxes.data();\n const scoresVals = await $scores.data();\n const res = nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n if ($boxes !== boxes) {\n $boxes.dispose();\n }\n if ($scores !== scores) {\n $scores.dispose();\n }\n return res;\n}\n\nfunction nonMaxSuppSanityCheck(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number):\n {maxOutputSize: number, iouThreshold: number, scoreThreshold: number} {\n if (iouThreshold == null) {\n iouThreshold = 0.5;\n }\n if (scoreThreshold == null) {\n scoreThreshold = Number.NEGATIVE_INFINITY;\n }\n const numBoxes = boxes.shape[0];\n maxOutputSize = Math.min(maxOutputSize, numBoxes);\n\n util.assert(\n 0 <= iouThreshold && iouThreshold <= 1,\n `iouThreshold must be in [0, 1], but was '${iouThreshold}'`);\n util.assert(\n boxes.rank === 2,\n `boxes must be a 2D tensor, but was of rank '${boxes.rank}'`);\n util.assert(\n boxes.shape[1] === 4,\n `boxes must have 4 columns, but 2nd dimension was ${boxes.shape[1]}`);\n util.assert(scores.rank === 1, 'scores must be a 1D tensor');\n util.assert(\n scores.shape[0] === numBoxes,\n `scores has incompatible shape with boxes. Expected ${numBoxes}, ` +\n `but was ${scores.shape[0]}`);\n return {maxOutputSize, iouThreshold, scoreThreshold};\n}\n\nexport const resizeBilinear = op({resizeBilinear_});\nexport const resizeNearestNeighbor = op({resizeNearestNeighbor_});\nexport const nonMaxSuppression = op({nonMaxSuppression_});\nexport const nonMaxSuppressionAsync = nonMaxSuppressionAsync_;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport * as broadcast_util from '../ops/broadcast_util';\nimport * as concat_util from '../ops/concat_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as erf_util from '../ops/erf_util';\nimport * as ops from '../ops/ops';\nimport {buffer, tensor3d, tensor4d} from '../ops/ops';\nimport * as selu_util from '../ops/selu_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, ShapeMap, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\nimport {now} from '../util';\nimport {BackendTimingInfo, KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {whereImpl} from './where_impl';\n\nexport class MathBackendCPU implements KernelBackend {\n private data = new WeakMap();\n private canvas: HTMLCanvasElement;\n private firstUse = true;\n\n constructor() {\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n }\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.firstUse) {\n this.firstUse = false;\n if (ENV.get('IS_NODE')) {\n warn(\n '\\n============================\\n' +\n 'Hi there 👋. Looks like you are running TensorFlow.js in ' +\n 'Node.js. To speed things up dramatically, install our node ' +\n 'backend, which binds to TensorFlow C++, by running ' +\n 'npm i @tensorflow/tfjs-node, ' +\n 'or npm i @tensorflow/tfjs-node-gpu if you have CUDA. ' +\n 'Then call require(\\'@tensorflow/tfjs-node\\'); (-gpu ' +\n 'suffix for CUDA) at the start of your program. ' +\n 'Visit https://github.com/tensorflow/tfjs-node for more details.' +\n '\\n============================\\n');\n }\n }\n if (this.data.has(dataId)) {\n throw new Error(`Data buffer is already registered`);\n }\n this.data.set(dataId, null);\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendCPU.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n this.data.set(dataId, values);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n let vals: Uint8ClampedArray;\n // tslint:disable-next-line:no-any\n if (ENV.get('IS_NODE') && (pixels as any).getContext == null) {\n throw new Error(\n 'When running in node, pixels must be an HTMLCanvasElement ' +\n 'like the one returned by the `canvas` npm package');\n }\n // tslint:disable-next-line:no-any\n if ((pixels as any).getContext != null) {\n // tslint:disable-next-line:no-any\n vals = (pixels as any)\n .getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else if (pixels instanceof ImageData) {\n vals = pixels.data;\n } else if (\n pixels instanceof HTMLImageElement ||\n pixels instanceof HTMLVideoElement) {\n if (this.canvas == null) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside ' +\n 'the browser.');\n }\n this.canvas.width = pixels.width;\n this.canvas.height = pixels.height;\n this.canvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n vals = this.canvas.getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n let values: Int32Array;\n if (numChannels === 4) {\n values = new Int32Array(vals);\n } else {\n const numPixels = pixels.width * pixels.height;\n values = new Int32Array(numPixels * numChannels);\n for (let i = 0; i < numPixels; i++) {\n for (let channel = 0; channel < numChannels; ++channel) {\n values[i * numChannels + channel] = vals[i * 4 + channel];\n }\n }\n }\n const outShape: [number, number, number] =\n [pixels.height, pixels.width, numChannels];\n return tensor3d(values, outShape, 'int32');\n }\n async read(dataId: DataId): Promise {\n return this.readSync(dataId);\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n return this.data.get(dataId);\n }\n\n disposeData(dataId: DataId): void {\n if (this.data.has(dataId)) {\n this.data.delete(dataId);\n }\n }\n\n async time(f: () => void): Promise {\n const start = now();\n f();\n const kernelMs = now() - start;\n return {kernelMs};\n }\n memory() {\n return {\n // Unreliable due to automatic gc. The numbers above are cumulative.\n unreliable: true\n };\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.data.has(dataId)) {\n throw new Error(\n `CPU backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; ++i) {\n const loc = buffer.indexToLoc(i);\n const xLoc = loc.map((idx, j) => idx + begin[j]);\n buffer.set(x.get(...xLoc), ...loc);\n }\n return buffer.toTensor() as T;\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return ops.tensor([], size) as T;\n }\n\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; i++) {\n const loc = buffer.indexToLoc(i);\n\n const newLoc: number[] = new Array(loc.length);\n for (let j = 0; j < newLoc.length; j++) {\n newLoc[j] = loc[j] * strides[j] + beginIndex[j];\n }\n buffer.set(x.get(...newLoc), ...loc);\n }\n\n return buffer.toTensor() as T;\n }\n\n reverse(x: T, axis: number[]): T {\n const buffer = ops.buffer(x.shape, x.dtype);\n const xBuffer = x.buffer();\n\n for (let i = 0; i < buffer.size; i++) {\n const outLoc = buffer.indexToLoc(i);\n const inLoc = outLoc.slice();\n axis.forEach(ax => inLoc[ax] = x.shape[ax] - 1 - inLoc[ax]);\n buffer.set(xBuffer.get(...inLoc), ...outLoc);\n }\n\n return buffer.toTensor() as T;\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const outShape = concat_util.computeOutShape(\n a.shape, b.shape, 1 /* axis */) as [number, number];\n const buffer = ops.buffer(outShape, a.dtype);\n\n if (a.shape[0] === 1 && b.shape[0] === 1) {\n // Use built-in TypedArray.set() method for speed.\n const aVals = a.dataSync();\n const bVals = b.dataSync();\n const vals = buffer.values;\n vals.set(aVals, 0);\n vals.set(bVals, a.size);\n return buffer.toTensor();\n }\n\n for (let i = 0; i < outShape[0]; ++i) {\n for (let j = 0; j < a.shape[1]; ++j) {\n buffer.set(a.get(i, j), i, j);\n }\n for (let j = 0; j < b.shape[1]; ++j) {\n buffer.set(b.get(i, j), i, j + a.shape[1]);\n }\n }\n return buffer.toTensor();\n }\n\n neg(x: T): T {\n return this.multiply(ops.scalar(-1), x) as T;\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue + bValue) as Tensor;\n }\n\n addN(tensors: T[]): T {\n const vals = tensors.map(t => t.dataSync());\n const result = ops.buffer(tensors[0].shape, tensors[0].dtype);\n const resultVals = result.values;\n for (let i = 0; i < tensors.length; i++) {\n const currVals = vals[i];\n for (let j = 0; j < resultVals.length; j++) {\n resultVals[j] += currVals[j];\n }\n }\n return result.toTensor() as T;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue - bValue) as Tensor;\n }\n\n pow(a: T, b: Tensor): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.pow(aValue, bValue)) as\n T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const sharedDim = transposeA ? a.shape[0] : a.shape[1];\n const leftDim = transposeA ? a.shape[1] : a.shape[0];\n const rightDim = transposeB ? b.shape[0] : b.shape[1];\n\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const [aOuterStep, aInnerStep] =\n transposeA ? [1, a.strides[0]] : [a.strides[0], 1];\n const [bOuterStep, bInnerStep] =\n transposeB ? [b.strides[0], 1] : [1, b.strides[0]];\n\n const aOuterEnd = leftDim * aOuterStep;\n const bOuterEnd = rightDim * bOuterStep;\n\n const result = new Float32Array(leftDim * rightDim);\n let resultIndex = 0;\n\n for (let aOuter = 0; aOuter < aOuterEnd; aOuter += aOuterStep) {\n for (let bOuter = 0; bOuter < bOuterEnd; bOuter += bOuterStep) {\n let aInner = aOuter;\n let bInner = bOuter;\n let sum = 0;\n for (let k = 0; k < sharedDim; ++k) {\n sum += aValues[aInner] * bValues[bInner];\n aInner += aInnerStep;\n bInner += bInnerStep;\n }\n result[resultIndex++] = sum;\n }\n }\n return ops.tensor2d(result, [leftDim, rightDim]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue * bValue) as Tensor;\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => a / b;\n const outputDtype = 'float32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => Math.floor(a / b);\n const outputDtype = 'int32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(outShape, resultDtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let sum = 0;\n for (let j = 0; j < reduceSize; ++j) {\n sum += aVals[offset + j];\n }\n vals[i] = sum;\n }\n return result;\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n const res = [];\n\n // Reshape the segment id's so that they can be broadcast with\n // x. The new shape should be [segmentIds.shape, 1, ..., 1]\n const numIters = x.rank - segmentIds.rank;\n for (let i = 0; i < numIters; ++i) {\n segmentIds = segmentIds.expandDims(i + 1);\n }\n\n for (let i = 0; i < numSegments; ++i) {\n const segmentId = ops.scalar(i, 'int32');\n const mask = ops.equal(segmentId, segmentIds).asType('float32');\n const sum = mask.mul(x).sum(0);\n res.push(sum);\n }\n\n return ops.stack(res);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n let minIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n minIndex = j;\n }\n }\n vals[i] = minIndex;\n }\n return result;\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n let maxIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n maxIndex = j;\n }\n }\n vals[i] = maxIndex;\n }\n return result;\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `backend.cumsum in CPU expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(x.shape, resultDtype);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n const finalDim = x.shape[x.rank - 1];\n const indexAdjuster = reverse ?\n (i: number, j: number) => i + finalDim - j - 1 :\n (i: number, j: number) => i + j;\n for (let i = 0; i < aVals.length; i += finalDim) {\n for (let j = 0; j < finalDim; j++) {\n const idx = indexAdjuster(i, j);\n if (j === 0) {\n vals[idx] = exclusive ? 0 : aVals[idx];\n } else {\n const prevIdx = indexAdjuster(i, j - 1);\n vals[idx] = exclusive ? aVals[prevIdx] + vals[prevIdx] :\n aVals[idx] + vals[prevIdx];\n }\n }\n }\n return result;\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal === bVal) ? 1 : 0;\n });\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal !== bVal) ? 1 : 0;\n });\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal < bVal) ? 1 : 0;\n });\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal <= bVal) ? 1 : 0;\n });\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal > bVal) ? 1 : 0;\n });\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal >= bVal) ? 1 : 0;\n });\n }\n\n logicalNot(x: T): T {\n const values = x.dataSync();\n const newValues = new Int32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = values[i] ? 0 : 1;\n }\n return Tensor.make(x.shape, {values: newValues}, 'bool') as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal && bVal;\n });\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal || bVal;\n });\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const values = condition.dataSync();\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n const result = ops.zeros(a.shape, upcastType(a.dtype, b.dtype));\n const newValues = result.dataSync();\n let index = 0;\n const offset = condition.rank === 0 || condition.rank > 1 || a.rank === 1 ?\n 1 :\n a.shape[1];\n\n for (let i = 0; i < values.length; i++) {\n for (let j = 0; j < offset; j++) {\n if (values[i] === 1) {\n newValues[index++] = aValues[i];\n } else {\n newValues[index++] = bValues[i];\n }\n }\n }\n return result;\n }\n\n where(condition: Tensor): Tensor2D {\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n }\n }\n vals[i] = min;\n }\n return result;\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.min(aVal, bVal));\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const rem = aVal % bVal;\n if ((aVal < 0 && bVal < 0) || (aVal >= 0 && bVal >= 0)) {\n return rem;\n } else {\n return (rem + bVal) % bVal;\n }\n });\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n }\n }\n vals[i] = max;\n }\n return result;\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.max(aVal, bVal));\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let all = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n all = all && value;\n }\n vals[i] = all;\n }\n return result;\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let anyVal = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n anyVal = anyVal || value;\n }\n vals[i] = anyVal;\n }\n return result;\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const diff = aVal - bVal;\n return diff * diff;\n });\n }\n\n ceil(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.ceil(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n floor(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.floor(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sign(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n if (values[i] < 0) {\n newValues[i] = -1;\n } else if (values[i] > 0) {\n newValues[i] = 1;\n } else {\n newValues[i] = 0;\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n round(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n // The algorithm is based on banker's rounding.\n const base = Math.floor(values[i]);\n if (values[i] - base < 0.5) {\n newValues[i] = Math.floor(values[i]);\n } else if (values[i] - base > 0.5) {\n newValues[i] = Math.ceil(values[i]);\n } else {\n if (base % 2.0 === 0.0) {\n newValues[i] = base;\n } else {\n newValues[i] = base + 1.0;\n }\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n exp(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.exp(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n expm1(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.expm1(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log1p(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log1p(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n rsqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = 1 / Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n square(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = value * value;\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n reciprocal(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = 1 / values[i];\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n relu(x: T): T {\n const res = ops.zeros(x.shape, x.dtype);\n const resVals = res.dataSync();\n const inVals = x.dataSync();\n for (let i = 0; i < inVals.length; ++i) {\n resVals[i] = Math.max(0, inVals[i]);\n }\n return res as T;\n }\n\n elu(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = v;\n } else {\n resultValues[i] = (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const resultValues = new Float32Array(y.size);\n const values = y.dataSync();\n const dyValues = dy.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 1) {\n resultValues[i] = dyValues[i];\n } else {\n resultValues[i] = dyValues[i] * (v + 1);\n }\n }\n return Tensor.make(y.shape, {values: resultValues}) as T;\n }\n\n selu(x: T): T {\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n const scaleAlpha = selu_util.SELU_SCALEALPHA;\n const scale = selu_util.SELU_SCALE;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = scale * v;\n } else {\n resultValues[i] = scaleAlpha * (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.min(max, Math.max(min, values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n abs(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.abs(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n int(x: T): T {\n const resultValues = new Int32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = values[i];\n }\n return Tensor.make(x.shape, {values: resultValues}, 'int32');\n }\n\n sigmoid(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = 1 / (1 + Math.exp(-values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n softplus(x: T): T {\n // mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n\n // epsilon is the difference between 1.0 and the next representable float.\n // For a single precision 32 bit float this should be 2^-23, see:\n // https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n const epsilon = 1.1920928955078125e-7;\n const threshold = Math.log(epsilon) + 2.0;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n\n for (let i = 0; i < values.length; ++i) {\n // Value above which exp(x) may overflow, but softplus(x) == x\n // is within machine epsilon.\n const tooLarge = values[i] > -threshold;\n\n // Value below which exp(x) may underflow, but softplus(x) == exp(x)\n // is within machine epsilon.\n const tooSmall = values[i] < threshold;\n\n const expX = Math.exp(values[i]);\n let result;\n\n if (tooSmall) {\n result = expX;\n } else if (tooLarge) {\n result = values[i];\n } else {\n result = Math.log(1.0 + expX);\n }\n resultValues[i] = result;\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n sin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.tan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan2(a: T, b: T): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.atan2(aValue, bValue)) as\n T;\n }\n\n sinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = util.tanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n erf(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n const p = erf_util.ERF_P;\n const a1 = erf_util.ERF_A1;\n const a2 = erf_util.ERF_A2;\n const a3 = erf_util.ERF_A3;\n const a4 = erf_util.ERF_A4;\n const a5 = erf_util.ERF_A5;\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n const t = 1.0 / (1.0 + p * v);\n resultValues[i] = 1.0 -\n (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t *\n Math.exp(-v * v);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n step(x: T, alpha = 0): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n if (isNaN(value)) {\n resultValues[i] = NaN;\n } else {\n resultValues[i] = value > 0 ? 1 : alpha;\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; wR++) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; wC++) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, d2);\n dotProd += pixel * weight;\n }\n }\n }\n y.set(dotProd, b, yR, yC, d2);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let d2 = 0; d2 < outChannels; ++d2) {\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + d2];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n // Need to convolve.\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, d2);\n }\n }\n }\n }\n return dW.toTensor();\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n for (let q = 0; q < chMul; ++q) {\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, q);\n dotProd += pixel * weight;\n }\n }\n y.set(dotProd, b, yR, yC, d1 * chMul + q);\n }\n }\n }\n }\n }\n\n return y.toTensor();\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n const chMul = outChannels / inChannels;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let dm = 0; dm < chMul; ++dm) {\n const d2 = d1 * chMul + dm;\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + dm];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n const d1 = Math.trunc(d2 / chMul);\n const dm = d2 % chMul;\n\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, dm);\n }\n }\n }\n return dW.toTensor();\n }\n\n tile(x: T, reps: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[i] * reps[i];\n }\n const result = ops.buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = new Array(x.rank);\n for (let i = 0; i < originalLoc.length; i++) {\n originalLoc[i] = newLoc[i] % x.shape[i];\n }\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const outShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + x.shape[i] + p[1] /* afterPad */);\n const start = paddings.map(p => p[0]);\n const xBuffer = x.buffer();\n const buffer = ops.buffer(outShape, x.dtype);\n if (constantValue !== 0) {\n buffer.values.fill(constantValue);\n }\n\n for (let i = 0; i < x.size; i++) {\n const coords = xBuffer.indexToLoc(i);\n const outCoords = coords.map((c, i) => c + start[i]);\n buffer.set(x.get(...coords), ...outCoords);\n }\n return buffer.toTensor() as T;\n }\n\n transpose(x: T, perm: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[perm[i]];\n }\n const values = x.dataSync();\n const result = buffer(newShape, x.dtype);\n\n const xBuf = x.buffer();\n for (let i = 0; i < x.size; ++i) {\n const loc = xBuf.indexToLoc(i);\n\n // Permute location.\n const newLoc: number[] = new Array(loc.length);\n for (let i = 0; i < newLoc.length; i++) {\n newLoc[i] = loc[perm[i]];\n }\n\n const newIndex = result.locToIndex(newLoc);\n result.values[newIndex] = values[i];\n }\n return result.toTensor() as T;\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const newShape: number[] = x.shape.slice();\n const indicesValues = indices.dataSync();\n newShape[axis] = indicesValues.length;\n const result = buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n\n for (let i = 0; i < result.size; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = newLoc.slice();\n originalLoc[axis] = indicesValues[newLoc[axis]];\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private pool(x: Tensor4D, convInfo: Conv2DInfo, poolType: 'max'|'avg'):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const y = ops.buffer(convInfo.outShape, 'float32');\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n\n let minMaxValue =\n (poolType === 'max' ? Number.NEGATIVE_INFINITY :\n Number.POSITIVE_INFINITY);\n let avgValue = 0;\n let count = 0;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const pixel = x.get(b, xR, xC, d);\n if ((poolType === 'max' && pixel > minMaxValue)) {\n minMaxValue = pixel;\n } else if (poolType === 'avg') {\n avgValue += pixel;\n count++;\n }\n }\n if (isNaN(minMaxValue)) {\n break;\n }\n }\n y.set(\n poolType === 'avg' ? avgValue / count : minMaxValue, b, yR, yC,\n d);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'max');\n }\n\n private maxPoolPositions(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const maxPositions = ops.buffer(convInfo.outShape, 'int32');\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n let maxValue = Number.NEGATIVE_INFINITY;\n let maxPosition = -1;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n const wR = xR - xRCorner;\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const wC = xC - xCCorner;\n const pixel = x.get(b, xR, xC, d);\n if (pixel > maxValue) {\n maxValue = pixel;\n maxPosition = wR * filterWidth + wC;\n }\n }\n }\n maxPositions.set(maxPosition, b, yR, yC, d);\n }\n }\n }\n }\n return maxPositions.toTensor();\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const maxPositions = this.maxPoolPositions(x, convInfo);\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n const maxPos = filterHeight * filterWidth - 1 -\n maxPositions.get(b, dyR, dyC, d);\n const curPos = wR * filterWidth + wC;\n\n const mask = maxPos === curPos ? 1 : 0;\n if (mask === 0) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel * mask;\n }\n }\n dx.set(dotProd, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel;\n }\n }\n dx.set(dotProd * avgMultiplier, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'avg').toFloat();\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n\n const sourceRowFloor = Math.floor(sourceFracRow);\n const sourceRowCeil =\n Math.min(oldHeight - 1, Math.ceil(sourceFracRow));\n const sourceColFloor = Math.floor(sourceFracCol);\n const sourceColCeil =\n Math.min(oldWidth - 1, Math.ceil(sourceFracCol));\n\n const topLeft = x.get(b, sourceRowFloor, sourceColFloor, d);\n const bottomLeft = x.get(b, sourceRowCeil, sourceColFloor, d);\n const topRight = x.get(b, sourceRowFloor, sourceColCeil, d);\n const bottomRight = x.get(b, sourceRowCeil, sourceColCeil, d);\n\n const rowFrac = sourceFracRow - sourceRowFloor;\n const colFrac = sourceFracCol - sourceColFloor;\n\n const top = topLeft + (topRight - topLeft) * colFrac;\n const bottom = bottomLeft + (bottomRight - bottomLeft) * colFrac;\n const newValue = top + (bottom - top) * rowFrac;\n\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n // Reference implementation\n // tslint:disable-next-line:max-line-length\n // https://github.com/tensorflow/tensorflow/blob/3039375c86a5bbc9610c7725dcaa95d635f87ba2/tensorflow/core/kernels/resize_bilinear_op.cc#L275\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < yHeight; r++) {\n const dxR = r * heightScale;\n const topDxRIndex = Math.floor(dxR);\n const bottomDxRIndex = Math.min(Math.ceil(dxR), xHeight - 1);\n const dxRLerp = dxR - topDxRIndex;\n const inverseDxRLerp = 1.0 - dxRLerp;\n\n for (let c = 0; c < yWidth; c++) {\n const dxC = c * widthScale;\n const leftDxCIndex = Math.floor(dxC);\n const rightDxCIndex = Math.min(Math.ceil(dxC), xWidth - 1);\n const dxCLerp = dxC - leftDxCIndex;\n const inverseDxCLerp = 1.0 - dxCLerp;\n\n for (let d = 0; d < depth; d++) {\n const dyVal = dy.get(b, r, c, d);\n\n let topLeft = output.get(b, topDxRIndex, leftDxCIndex, d);\n topLeft += dyVal * inverseDxRLerp * inverseDxCLerp;\n output.set(topLeft, b, topDxRIndex, leftDxCIndex, d);\n\n let topRight = output.get(b, topDxRIndex, rightDxCIndex, d);\n topRight += dyVal * inverseDxRLerp * dxCLerp;\n output.set(topRight, b, topDxRIndex, rightDxCIndex, d);\n\n let bottomLeft = output.get(b, bottomDxRIndex, leftDxCIndex, d);\n bottomLeft += dyVal * dxRLerp * inverseDxCLerp;\n output.set(bottomLeft, b, bottomDxRIndex, leftDxCIndex, d);\n\n let bottomRight = output.get(b, bottomDxRIndex, rightDxCIndex, d);\n bottomRight += dyVal * dxRLerp * dxCLerp;\n output.set(bottomRight, b, bottomDxRIndex, rightDxCIndex, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n const sourceNearestRow = Math.min(\n oldHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n const sourceNearestCol = Math.min(\n oldWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n const newValue = x.get(b, sourceNearestRow, sourceNearestCol, d);\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n // Loop over the output space.\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < xHeight; r++) {\n for (let c = 0; c < xWidth; c++) {\n // Compute bounds for where in dy we will look\n const startRLerp = Math.floor(r * invHeightScale);\n const startDyR = Math.floor(startRLerp - (winHeight / 2));\n\n const startCLerp = Math.floor(c * invWidthScale);\n const startDyC = Math.floor(startCLerp - (winWidth / 2));\n\n for (let d = 0; d < depth; d++) {\n let accum = 0;\n // loop over dy\n\n for (let dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n const dyR = dyROffset + startDyR;\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= yHeight) {\n continue;\n }\n\n for (let dyCOffSet = 0; dyCOffSet < winWidth; dyCOffSet++) {\n const dyC = dyCOffSet + startDyC;\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= yWidth) {\n continue;\n }\n\n const sourceFracRow =\n effectiveXSize[0] * (dyR / effectiveYSize[0]);\n const sourceFracCol =\n effectiveXSize[1] * (dyC / effectiveYSize[1]);\n\n const sourceNearestRow = Math.min(\n xHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n\n const sourceNearestCol = Math.min(\n xWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n\n if (r === sourceNearestRow && c === sourceNearestCol) {\n accum += dy.get(b, dyR, dyC, d);\n }\n }\n }\n\n output.set(accum, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const xValues = x.dataSync();\n const meanValues = mean.dataSync();\n const varianceValues = variance.dataSync();\n const scaleValues = scale ? scale.dataSync() : new Float32Array([1]);\n const offsetValues = offset ? offset.dataSync() : new Float32Array([0]);\n const outValues = new Float32Array(xValues.length);\n\n for (let i = 0; i < xValues.length; i++) {\n outValues[i] = offsetValues[i % offsetValues.length] +\n (xValues[i] - meanValues[i % meanValues.length]) *\n scaleValues[i % scaleValues.length] /\n Math.sqrt(\n varianceValues[i % varianceValues.length] + varianceEpsilon);\n }\n return tensor4d(outValues, x.shape);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const output = ops.buffer(x.shape, 'float32');\n const rad = radius;\n const maxD = output.shape[3] - 1;\n\n function sumAcrossChannels(\n b: number, r: number, c: number, d: number): number {\n let sum = 0.0;\n for (let j = Math.max(0, d - rad); j <= Math.min(d + rad, maxD); j++) {\n const z = x.get(b, r, c, j);\n sum += z * z;\n }\n return sum;\n }\n\n for (let b = 0; b < output.shape[0]; b++) {\n for (let r = 0; r <= output.shape[1]; r++) {\n for (let c = 0; c < output.shape[2]; c++) {\n for (let d = 0; d < output.shape[3]; d++) {\n const sum = sumAcrossChannels(b, r, c, d);\n const val = x.get(b, r, c, d) * Math.pow(bias + alpha * sum, -beta);\n output.set(val, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const batch = dy.shape[0];\n const rows = dy.shape[1];\n const cols = dy.shape[2];\n const depth = dy.shape[3];\n const output = ops.buffer([batch, rows, cols, depth], 'float32');\n\n for (let b = 0; b < batch; ++b) {\n for (let r = 0; r < rows; ++r) {\n for (let c = 0; c < cols; ++c) {\n for (let d = 0; d < depth; ++d) {\n const depthBegin = Math.max(0, d - depthRadius);\n const depthEnd = Math.min(depth, d + depthRadius + 1);\n\n let norm = 0;\n for (let k = depthBegin; k < depthEnd; ++k) {\n norm += inputImage.get(b, r, c, k) * inputImage.get(b, r, c, k);\n }\n norm = alpha * norm + bias;\n for (let k = depthBegin; k < depthEnd; ++k) {\n let dyi = -2 * alpha * beta * inputImage.get(b, r, c, k) *\n outputImage.get(b, r, c, d) / norm;\n if (d === k) {\n dyi += Math.pow(norm, -beta);\n }\n dyi *= dy.get(b, r, c, d);\n output.set(dyi + output.get(b, r, c, k), b, r, c, k);\n }\n }\n }\n }\n }\n return output.toTensor();\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probabilities = normalized ? logits : ops.softmax(logits);\n const batchSize = probabilities.shape[0];\n const numEvents = probabilities.shape[1];\n const res = ops.zeros([batchSize, numSamples], 'int32');\n const resVals = res.dataSync();\n const probVals = probabilities.dataSync();\n\n for (let b = 0; b < batchSize; ++b) {\n const offset = b * numEvents;\n // The cdf won't include the last event. It will be implicit if no other\n // event happened.\n const cdf = new Float32Array(numEvents - 1);\n cdf[0] = probVals[offset];\n for (let event = 1; event < cdf.length; ++event) {\n cdf[event] = cdf[event - 1] + probVals[offset + event];\n }\n\n const random = seedrandom.alea(seed.toString());\n const outOffset = b * numSamples;\n for (let sampleId = 0; sampleId < numSamples; ++sampleId) {\n const r = random();\n\n // Assume last event happened by default.\n resVals[outOffset + sampleId] = cdf.length;\n\n for (let event = 0; event < cdf.length; event++) {\n if (r < cdf[event]) {\n resVals[outOffset + sampleId] = event;\n break;\n }\n }\n }\n }\n return res;\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const res = new Float32Array(indices.size * depth);\n res.fill(offValue);\n\n for (let event = 0; event < indices.size; ++event) {\n if (indices.get(event) >= 0 && indices.get(event) < depth) {\n res[event * depth + indices.get(event)] = onValue;\n }\n }\n return ops.tensor2d(res, [indices.size, depth], 'int32');\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private broadcastedBinaryOp(\n a: Tensor, b: Tensor, dtype: DataType,\n op: (a: number, b: number) => number): Tensor {\n const newShape =\n broadcast_util.assertAndGetBroadcastShape(a.shape, b.shape);\n const result = ops.buffer(newShape, dtype);\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const aBroadcastDims = broadcast_util.getBroadcastDims(a.shape, newShape);\n const bBroadcastDims = broadcast_util.getBroadcastDims(b.shape, newShape);\n\n const aBuf = a.buffer();\n const bBuf = b.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const loc = result.indexToLoc(i);\n\n const aLoc = loc.slice(-a.rank);\n aBroadcastDims.forEach(d => aLoc[d] = 0);\n const aIndex = aBuf.locToIndex(aLoc);\n\n const bLoc = loc.slice(-b.rank);\n bBroadcastDims.forEach(d => bLoc[d] = 0);\n const bIndex = bBuf.locToIndex(bLoc);\n\n result.values[i] = op(aValues[aIndex], bValues[bIndex]);\n }\n return result.toTensor();\n }\n dispose() {}\n}\n\nENV.registerBackend(\n 'cpu', () => new MathBackendCPU(), 1 /* priority */, setTensorTracker);\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nconst delayCallback = typeof requestAnimationFrame !== 'undefined' ?\n requestAnimationFrame : // Browsers\n setImmediate; // Node.js\n\n/**\n * Returns a promise that resolve when a requestAnimationFrame has completed.\n *\n * On Node.js this uses setImmediate instead of requestAnimationFrame.\n *\n * This is simply a sugar method so that users can do the following:\n * `await tf.nextFrame();`\n */\n/** @doc {heading: 'Performance', subheading: 'Timing'} */\nfunction nextFrame(): Promise {\n return new Promise(resolve => delayCallback(() => resolve()));\n}\n\nexport {nextFrame};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/* Type definitions for exporting and importing of models. */\n\n/**\n * A map from Tensor dtype to number of bytes per element of the Tensor.\n */\nexport const DTYPE_VALUE_SIZE_MAP: {[dtype: string]: number} = {\n 'float32': 4,\n 'int32': 4,\n 'uint16': 2,\n 'uint8': 1,\n 'bool': 1,\n};\n\n/**\n * A weight manifest.\n *\n * The weight manifest consists of an ordered list of weight-manifest groups.\n * Each weight-manifest group (\"group\" for short hereafter) consists of a\n * number of weight values stored in a number of paths.\n * See the documentation of `WeightManifestGroupConfig` below for more details.\n */\nexport declare type WeightsManifestConfig = WeightsManifestGroupConfig[];\n\n/**\n * A weight-manifest group.\n *\n * Consists of an ordered list of weight values encoded in binary format,\n * stored in an ordered list of paths.\n */\nexport declare interface WeightsManifestGroupConfig {\n /**\n * An ordered list of paths.\n *\n * Paths are intentionally abstract in order to be general. For example, they\n * can be relative URL paths or relative paths on the file system.\n */\n paths: string[];\n\n /**\n * Specifications of the weights stored in the paths.\n */\n weights: WeightsManifestEntry[];\n}\n\n/**\n * An entry in the weight manifest.\n *\n * The entry contains specification of a weight.\n */\nexport declare interface WeightsManifestEntry {\n /**\n * Name of the weight, e.g., 'Dense_1/bias'\n */\n name: string;\n\n /**\n * Shape of the weight.\n */\n shape: number[];\n\n /**\n * Data type of the weight.\n */\n dtype: 'float32'|'int32'|'bool';\n\n /**\n * Information for dequantization of the weight.\n */\n quantization?: {\n scale: number, // The scaling constant to multiply by.\n min: number, // The (possibly nudged) minimum weight to add.\n dtype: 'uint16'|'uint8' // The dtype of the quantized weights.\n };\n}\n\n/**\n * Options for saving a model.\n */\nexport interface SaveConfig {\n /**\n * Whether to save only the trainable weights of the model, ignoring the\n * untrainable ones.\n */\n trainableOnly?: boolean;\n}\n\n/**\n * Result of a saving operation.\n */\nexport interface SaveResult {\n /**\n * Information about the model artifacts saved.\n */\n modelArtifactsInfo: ModelArtifactsInfo;\n\n /**\n * HTTP responses from the server that handled the model-saving request (if\n * any). This is applicable only to server-based saving routes.\n */\n responses?: Response[];\n\n /**\n * Error messages and related data (if any).\n */\n errors?: Array<{}|string>;\n}\n\nexport declare interface ModelArtifactsInfo {\n /**\n * Timestamp for when the model is saved.\n */\n dateSaved: Date;\n\n /**\n * Type of the model topology\n *\n * Possible values:\n * - JSON: JSON config (human-readable, e.g., Keras JSON).\n * - GraphDef: TensorFlow\n * [GraphDef](https://www.tensorflow.org/extend/tool_developers/#graphdef)\n * protocal buffer (binary).\n */\n modelTopologyType: 'JSON'|'GraphDef';\n\n /**\n * Size of model topology (Keras JSON or GraphDef), in bytes.\n */\n modelTopologyBytes?: number;\n\n /**\n * Size of weight specification or manifest, in bytes.\n */\n weightSpecsBytes?: number;\n\n /**\n * Size of weight value data, in bytes.\n */\n weightDataBytes?: number;\n}\n\n/**\n * The serialized artifacts of a model, including topology and weights.\n *\n * The `modelTopology`, `weightSpecs` and `weightData` fields of this interface\n * are optional, in order to support topology- or weights-only saving and\n * loading.\n */\nexport declare interface ModelArtifacts {\n /**\n * Model topology.\n *\n * For Keras-style `tf.Model`s, this is a JSON object.\n * For TensorFlow-style models (e.g., `FrozenModel`), this is a binary buffer\n * carrying the `GraphDef` protocol buffer.\n */\n modelTopology?: {}|ArrayBuffer;\n\n /**\n * Weight specifications.\n *\n * This corresponds to the weightsData below.\n */\n weightSpecs?: WeightsManifestEntry[];\n\n /**\n * Binary buffer for all weight values concatenated in the order specified\n * by `weightSpecs`.\n */\n weightData?: ArrayBuffer;\n}\n\n/**\n * Type definition for handlers of loading operations.\n */\nexport type LoadHandler = () => Promise;\n\n/**\n * Type definition for handlers of saving operations.\n */\nexport type SaveHandler = (modelArtifact: ModelArtifacts) =>\n Promise;\n\n/**\n * Interface for a model import/export handler.\n *\n * The `save` and `load` handlers are both optional, in order to allow handlers\n * that support only saving or loading.\n */\n// tslint:disable-next-line:interface-name\nexport interface IOHandler {\n save?: SaveHandler;\n load?: LoadHandler;\n}\n\n/**\n * An interface for the manager of a model store.\n *\n * A model store is defined as a storage medium on which multiple models can\n * be stored. Each stored model has a unique `path` as its identifier.\n * A `ModelStoreManager` for the store allows actions including\n *\n * - Listing the models stored in the store.\n * - Deleting a model from the store.\n */\nexport interface ModelStoreManager {\n /**\n * List all models in the model store.\n *\n * @returns A dictionary mapping paths of existing models to their\n * model artifacts info. Model artifacts info include type of the model's\n * topology, byte sizes of the topology, weights, etc.\n */\n listModels(): Promise<{[path: string]: ModelArtifactsInfo}>;\n\n /**\n * Remove a model specified by `path`.\n *\n * @param path\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n removeModel(path: string): Promise;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport {sizeFromShape} from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, ModelArtifacts, ModelArtifactsInfo, WeightsManifestEntry} from './types';\n\n/**\n * Encode a map from names to weight values as an ArrayBuffer, along with an\n * `Array` of `WeightsManifestEntry` as specification of the encoded weights.\n *\n * This function does not perform sharding.\n *\n * This function is the reverse of `decodeWeights`.\n *\n * @param tensors A map (\"dict\") from names to tensors.\n * @returns A `Promise` of\n * - A flat `ArrayBuffer` with all the binary values of the `Tensor`s\n * concatenated.\n * - An `Array` of `WeightManifestEntry`s, carrying information including\n * tensor names, `dtype`s and shapes.\n * @throws Error: on unsupported tensor `dtype`.\n */\nexport async function encodeWeights(tensors: NamedTensorMap):\n Promise<{data: ArrayBuffer, specs: WeightsManifestEntry[]}> {\n // TODO(adarob, cais): Support quantization.\n const specs: WeightsManifestEntry[] = [];\n const dataPromises: Array> = [];\n for (const name in tensors) {\n const t = tensors[name];\n\n if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool') {\n throw new Error(`Unsupported dtype in weight '${name}': ${t.dtype}`);\n }\n specs.push({name, shape: t.shape, dtype: t.dtype});\n dataPromises.push(t.data());\n }\n const tensorValues = await Promise.all(dataPromises);\n return {data: concatenateTypedArrays(tensorValues), specs};\n}\n\n/**\n * Decode flat ArrayBuffer as weights.\n *\n * This function does not handle sharding.\n *\n * This function is the reverse of `encodeWeights`.\n *\n * @param buffer A flat ArrayBuffer carrying the binary values of the tensors\n * concatenated in the order specified in `specs`.\n * @param specs Specifications of the names, dtypes and shapes of the tensors\n * whose value are encoded by `buffer`.\n * @return A map from tensor name to tensor value, with the names corresponding\n * to names in `specs`.\n * @throws Error, if any of the tensors has unsupported dtype.\n */\nexport function decodeWeights(\n buffer: ArrayBuffer, specs: WeightsManifestEntry[]): NamedTensorMap {\n // TODO(adarob, cais): Support quantization.\n const out: NamedTensorMap = {};\n let offset = 0;\n for (const spec of specs) {\n const name = spec.name;\n const dtype = spec.dtype;\n const shape = spec.shape;\n\n if (spec.quantization != null) {\n throw new Error(\n `decodeWeights does not support quantization yet, but encountered ` +\n `weight '${name} with quantization.'`);\n }\n\n const size = sizeFromShape(shape);\n let value: Tensor;\n if (dtype === 'float32') {\n value = tensor(new Float32Array(buffer, offset, size), shape, 'float32');\n } else if (dtype === 'int32') {\n value = tensor(new Int32Array(buffer, offset, size), shape, 'int32');\n } else if (dtype === 'bool') {\n value = tensor(new Uint8Array(buffer, offset, size), shape, 'bool');\n } else {\n throw new Error(`Unsupported dtype in weight '${name}': ${dtype}`);\n }\n out[name] = value;\n\n offset += size * DTYPE_VALUE_SIZE_MAP[dtype];\n }\n return out;\n}\n\n/**\n * Concatenate TypedArrays into an ArrayBuffer.\n */\nexport function concatenateTypedArrays(xs: TypedArray[]): ArrayBuffer {\n // TODO(adarob, cais): Support quantization.\n if (xs === null) {\n throw new Error(`Invalid input value: ${JSON.stringify(xs)}`);\n }\n\n let totalByteLength = 0;\n\n // `normalizedXs` is here for this reason: a `TypedArray`'s `buffer'\n // can have a different byte length from that of the `TypedArray` itself,\n // for example, when the `TypedArray` is created from an offset in an\n // `ArrayBuffer`. `normliazedXs` holds `TypedArray`s whose `buffer`s match\n // the `TypedArray` in byte length. If an element of `xs` does not show\n // this property, a new `TypedArray` that satisfy this property will be\n // constructed and pushed into `normalizedXs`.\n const normalizedXs: TypedArray[] = [];\n xs.forEach((x: TypedArray) => {\n totalByteLength += x.byteLength;\n // tslint:disable:no-any\n normalizedXs.push(\n x.byteLength === x.buffer.byteLength ? x :\n new (x.constructor as any)(x));\n if (!(x as any instanceof Float32Array || x as any instanceof Int32Array ||\n x as any instanceof Uint8Array)) {\n throw new Error(`Unsupported TypedArray subtype: ${x.constructor.name}`);\n }\n // tslint:enable:no-any\n });\n\n const y = new Uint8Array(totalByteLength);\n let offset = 0;\n normalizedXs.forEach((x: TypedArray) => {\n y.set(new Uint8Array(x.buffer), offset);\n offset += x.byteLength;\n });\n\n return y.buffer;\n}\n\n// Use Buffer on Node.js instead of Blob/atob/btoa\nconst useNodeBuffer = typeof Buffer !== 'undefined' &&\n (typeof Blob === 'undefined' || typeof atob === 'undefined' ||\n typeof btoa === 'undefined');\n\n/**\n * Calculate the byte length of a JavaScript string.\n *\n * Note that a JavaScript string can contain wide characters, therefore the\n * length of the string is not necessarily equal to the byte length.\n *\n * @param str Input string.\n * @returns Byte length.\n */\nexport function stringByteLength(str: string): number {\n if (useNodeBuffer) {\n return Buffer.byteLength(str);\n }\n return new Blob([str]).size;\n}\n\n/**\n * Encode an ArrayBuffer as a base64 encoded string.\n *\n * @param buffer `ArrayBuffer` to be converted.\n * @returns A string that base64-encodes `buffer`.\n */\nexport function arrayBufferToBase64String(buffer: ArrayBuffer): string {\n if (useNodeBuffer) {\n return Buffer.from(buffer).toString('base64');\n }\n return btoa(String.fromCharCode.apply(null, new Uint8Array(buffer)));\n}\n\n/**\n * Decode a base64 string as an ArrayBuffer.\n *\n * @param str Base64 string.\n * @returns Decoded `ArrayBuffer`.\n */\nexport function base64StringToArrayBuffer(str: string): ArrayBuffer {\n if (useNodeBuffer) {\n const buf = Buffer.from(str, 'base64');\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);\n }\n const s = atob(str);\n const buffer = new Uint8Array(s.length);\n for (let i = 0; i < s.length; ++i) {\n buffer.set([s.charCodeAt(i)], i);\n }\n return buffer.buffer;\n}\n\n/**\n * Concatenate a number of ArrayBuffers into one.\n *\n * @param buffers A number of array buffers to concatenate.\n * @returns Result of concatenating `buffers` in order.\n */\nexport function concatenateArrayBuffers(buffers: ArrayBuffer[]): ArrayBuffer {\n let totalByteLength = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n totalByteLength += buffer.byteLength;\n });\n\n const temp = new Uint8Array(totalByteLength);\n let offset = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n temp.set(new Uint8Array(buffer), offset);\n offset += buffer.byteLength;\n });\n return temp.buffer;\n}\n\n/**\n * Get the basename of a path.\n *\n * Behaves in a way analogous to Linux's basename command.\n *\n * @param path\n */\nexport function basename(path: string): string {\n const SEPARATOR = '/';\n path = path.trim();\n while (path.endsWith(SEPARATOR)) {\n path = path.slice(0, path.length - 1);\n }\n const items = path.split(SEPARATOR);\n return items[items.length - 1];\n}\n\n/**\n * Populate ModelArtifactsInfo fields for a model with JSON topology.\n * @param modelArtifacts\n * @returns A ModelArtifactsInfo object.\n */\nexport function getModelArtifactsInfoForJSON(modelArtifacts: ModelArtifacts):\n ModelArtifactsInfo {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error('Expected JSON model topology, received ArrayBuffer.');\n }\n\n return {\n dateSaved: new Date(),\n modelTopologyType: 'JSON',\n modelTopologyBytes: modelArtifacts.modelTopology == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.modelTopology)),\n weightSpecsBytes: modelArtifacts.weightSpecs == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)),\n weightDataBytes: modelArtifacts.weightData == null ?\n 0 :\n modelArtifacts.weightData.byteLength,\n };\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {IOHandler} from './types';\n\nexport type IORouter = (url: string) => IOHandler;\n\nexport class IORouterRegistry {\n // Singleton instance.\n private static instance: IORouterRegistry;\n\n private saveRouters: IORouter[];\n private loadRouters: IORouter[];\n\n private constructor() {\n this.saveRouters = [];\n this.loadRouters = [];\n }\n\n private static getInstance(): IORouterRegistry {\n if (IORouterRegistry.instance == null) {\n IORouterRegistry.instance = new IORouterRegistry();\n }\n return IORouterRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerSaveRouter(saveRouter: IORouter) {\n IORouterRegistry.getInstance().saveRouters.push(saveRouter);\n }\n\n /**\n * Register a load-handler router.\n *\n * @param loadRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `load` method defined or `null`.\n */\n static registerLoadRouter(loadRouter: IORouter) {\n IORouterRegistry.getInstance().loadRouters.push(loadRouter);\n }\n\n /**\n * Look up IOHandler for saving, given a URL-like string.\n *\n * @param url\n * @returns If only one match is found, an instance of IOHandler with the\n * `save` method defined. If no match is found, `null`.\n * @throws Error, if more than one match is found.\n */\n static getSaveHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'save');\n }\n\n /**\n * Look up IOHandler for loading, given a URL-like string.\n *\n * @param url\n * @returns All valid handlers for `url`, given the currently registered\n * handler routers.\n */\n static getLoadHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'load');\n }\n\n private static getHandlers(url: string, handlerType: 'save'|'load'):\n IOHandler[] {\n const validHandlers: IOHandler[] = [];\n const routers = handlerType === 'load' ? this.getInstance().loadRouters :\n this.getInstance().saveRouters;\n routers.forEach(router => {\n const handler = router(url);\n if (handler !== null) {\n validHandlers.push(handler);\n }\n });\n return validHandlers;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Classes and functions for model management across multiple storage mediums.\n *\n * Supported client actions:\n * - Listing models on all registered storage mediums.\n * - Remove model by URL from any registered storage mediums, by using URL\n * string.\n * - Moving or copying model from one path to another in the same medium or from\n * one medium to another, by using URL strings.\n */\n\nimport {assert} from '../util';\n\nimport {IORouterRegistry} from './router_registry';\nimport {ModelArtifactsInfo, ModelStoreManager} from './types';\n\nconst URL_SCHEME_SUFFIX = '://';\n\nexport class ModelStoreManagerRegistry {\n // Singleton instance.\n private static instance: ModelStoreManagerRegistry;\n\n private managers: {[scheme: string]: ModelStoreManager};\n\n private constructor() {\n this.managers = {};\n }\n\n private static getInstance(): ModelStoreManagerRegistry {\n if (ModelStoreManagerRegistry.instance == null) {\n ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry();\n }\n return ModelStoreManagerRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerManager(scheme: string, manager: ModelStoreManager) {\n assert(scheme != null, 'scheme must not be undefined or null.');\n if (scheme.endsWith(URL_SCHEME_SUFFIX)) {\n scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX));\n }\n assert(scheme.length > 0, 'scheme must not be an empty string.');\n const registry = ModelStoreManagerRegistry.getInstance();\n assert(\n registry.managers[scheme] == null,\n `A model store manager is already registered for scheme '${scheme}'.`);\n registry.managers[scheme] = manager;\n }\n\n static getManager(scheme: string): ModelStoreManager {\n const manager = this.getInstance().managers[scheme];\n if (manager == null) {\n throw new Error(`Cannot find model manager for scheme '${scheme}'`);\n }\n return manager;\n }\n\n static getSchemes(): string[] {\n return Object.keys(this.getInstance().managers);\n }\n}\n\n/**\n * Helper method for parsing a URL string into a scheme and a path.\n *\n * @param url E.g., 'localstorage://my-model'\n * @returns A dictionary with two fields: scheme and path.\n * Scheme: e.g., 'localstorage' in the example above.\n * Path: e.g., 'my-model' in the example above.\n */\nfunction parseURL(url: string): {scheme: string, path: string} {\n if (url.indexOf(URL_SCHEME_SUFFIX) === -1) {\n throw new Error(\n `The url string provided does not contain a scheme. ` +\n `Supported schemes are: ` +\n `${ModelStoreManagerRegistry.getSchemes().join(',')}`);\n }\n return {\n scheme: url.split(URL_SCHEME_SUFFIX)[0],\n path: url.split(URL_SCHEME_SUFFIX)[1],\n };\n}\n\nasync function cloneModelInternal(\n sourceURL: string, destURL: string,\n deleteSource = false): Promise {\n assert(\n sourceURL !== destURL,\n `Old path and new path are the same: '${sourceURL}'`);\n\n const loadHandlers = IORouterRegistry.getLoadHandlers(sourceURL);\n assert(\n loadHandlers.length > 0,\n `Copying failed because no load handler is found for source URL ${\n sourceURL}.`);\n assert(\n loadHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `load handlers for source URL ${sourceURL}.`);\n const loadHandler = loadHandlers[0];\n\n const saveHandlers = IORouterRegistry.getSaveHandlers(destURL);\n assert(\n saveHandlers.length > 0,\n `Copying failed because no save handler is found for destination URL ` +\n `${destURL}.`);\n assert(\n saveHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `save handlers for destination URL ${destURL}.`);\n const saveHandler = saveHandlers[0];\n\n const sourceScheme = parseURL(sourceURL).scheme;\n const sourcePath = parseURL(sourceURL).path;\n const sameMedium = sourceScheme === parseURL(sourceURL).scheme;\n\n const modelArtifacts = await loadHandler.load();\n\n // If moving within the same storage medium, remove the old model as soon as\n // the loading is done. Without doing this, it is possible that the combined\n // size of the two models will cause the cloning to fail.\n if (deleteSource && sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n const saveResult = await saveHandler.save(modelArtifacts);\n\n // If moving between mediums, the deletion is done after the save succeeds.\n // This guards against the case in which saving to the destination medium\n // fails.\n if (deleteSource && !sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n return saveResult.modelArtifactsInfo;\n}\n\n/**\n * List all models stored in registered storage mediums.\n *\n * For a web browser environment, the registered mediums are Local Storage and\n * IndexedDB.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @returns A `Promise` of a dictionary mapping URLs of existing models to\n * their model artifacts info. URLs include medium-specific schemes, e.g.,\n * 'indexeddb://my/model/1'. Model artifacts info include type of the\n * model's topology, byte sizes of the topology, weights, etc.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function listModels(): Promise<{[url: string]: ModelArtifactsInfo}> {\n const schemes = ModelStoreManagerRegistry.getSchemes();\n const out: {[url: string]: ModelArtifactsInfo} = {};\n for (const scheme of schemes) {\n const schemeOut =\n await ModelStoreManagerRegistry.getManager(scheme).listModels();\n for (const path in schemeOut) {\n const url = scheme + URL_SCHEME_SUFFIX + path;\n out[url] = schemeOut[path];\n }\n }\n return out;\n}\n\n/**\n * Remove a model specified by URL from a reigstered storage medium.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @param url A URL to a stored model, with a scheme prefix, e.g.,\n * 'localstorage://my-model-1', 'indexeddb://my/model/2'.\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function removeModel(url: string): Promise {\n const schemeAndPath = parseURL(url);\n const manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme);\n return await manager.removeModel(schemeAndPath.path);\n}\n\n/**\n * Copy a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Copying within a storage medium, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Copying between two storage mediums, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Copy the model, from Local Storage to IndexedDB.\n * await tf.io.copyModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove both models.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of copying.\n * @param destURL Destination URL of copying.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if copying fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function copyModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = false;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\n/**\n * Move a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Moving within a storage medium, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Moving between two storage mediums, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Move the model, from Local Storage to IndexedDB.\n * await tf.io.moveModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove the moved model.\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of moving.\n * @param destURL Destination URL of moving.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if moving fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function moveModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = true;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\nexport {moveModel, copyModel, removeModel, listModels};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst DATABASE_NAME = 'tensorflowjs';\nconst DATABASE_VERSION = 1;\n\n// Model data and ModelArtifactsInfo (metadata) are stored in two separate\n// stores for efficient access of the list of stored models and their metadata.\n// 1. The object store for model data: topology, weights and weight manifests.\nconst MODEL_STORE_NAME = 'models_store';\n// 2. The object store for ModelArtifactsInfo, including meta-information such\n// as the type of topology (JSON vs binary), byte size of the topology, byte\n// size of the weights, etc.\nconst INFO_STORE_NAME = 'model_info_store';\n\n/**\n * Delete the entire database for tensorflow.js, including the models store.\n */\nexport async function deleteDatabase(): Promise {\n const idbFactory = getIndexedDBFactory();\n\n return new Promise((resolve, reject) => {\n const deleteRequest = idbFactory.deleteDatabase(DATABASE_NAME);\n deleteRequest.onsuccess = () => resolve();\n deleteRequest.onerror = error => reject(error);\n });\n}\n\nfunction getIndexedDBFactory(): IDBFactory {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Add more info about what IOHandler subtypes are available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'Failed to obtain IndexedDB factory because the current environment' +\n 'is not a web browser.');\n }\n // tslint:disable-next-line:no-any\n const theWindow: any = window;\n const factory = theWindow.indexedDB || theWindow.mozIndexedDB ||\n theWindow.webkitIndexedDB || theWindow.msIndexedDB ||\n theWindow.shimIndexedDB;\n if (factory == null) {\n throw new Error(\n 'The current browser does not appear to support IndexedDB.');\n }\n return factory;\n}\n\nfunction setUpDatabase(openRequest: IDBRequest) {\n const db = openRequest.result as IDBDatabase;\n db.createObjectStore(MODEL_STORE_NAME, {keyPath: 'modelPath'});\n db.createObjectStore(INFO_STORE_NAME, {keyPath: 'modelPath'});\n}\n\n/**\n * IOHandler subclass: Browser IndexedDB.\n *\n * See the doc string of `browserIndexedDB` for more details.\n */\nexport class BrowserIndexedDB implements IOHandler {\n protected readonly indexedDB: IDBFactory;\n protected readonly modelPath: string;\n\n static readonly URL_SCHEME = 'indexeddb://';\n\n constructor(modelPath: string) {\n this.indexedDB = getIndexedDBFactory();\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For IndexedDB, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n // TODO(cais): Support saving GraphDef models.\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n return this.databaseAction(this.modelPath, modelArtifacts) as\n Promise;\n }\n\n async load(): Promise {\n return this.databaseAction(this.modelPath) as Promise;\n }\n\n /**\n * Perform database action to put model artifacts into or read model artifacts\n * from IndexedDB object store.\n *\n * Whether the action is put or get depends on whether `modelArtifacts` is\n * specified. If it is specified, the action will be put; otherwise the action\n * will be get.\n *\n * @param modelPath A unique string path for the model.\n * @param modelArtifacts If specified, it will be the model artifacts to be\n * stored in IndexedDB.\n * @returns A `Promise` of `SaveResult`, if the action is put, or a `Promise`\n * of `ModelArtifacts`, if the action is get.\n */\n private databaseAction(modelPath: string, modelArtifacts?: ModelArtifacts):\n Promise {\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n\n if (modelArtifacts == null) {\n // Read model out from object store.\n const modelTx = db.transaction(MODEL_STORE_NAME, 'readonly');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const getRequest = modelStore.get(this.modelPath);\n getRequest.onsuccess = () => {\n if (getRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${this.modelPath}' ` +\n `in IndexedDB.`));\n } else {\n resolve(getRequest.result.modelArtifacts);\n }\n };\n getRequest.onerror = error => {\n db.close();\n return reject(getRequest.error);\n };\n modelTx.oncomplete = () => db.close();\n } else {\n // Put model into object store.\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n // First, put ModelArtifactsInfo into info store.\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n let infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const putInfoRequest =\n infoStore.put({modelPath: this.modelPath, modelArtifactsInfo});\n let modelTx: IDBTransaction;\n putInfoRequest.onsuccess = () => {\n // Second, put model data into model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const putModelRequest = modelStore.put({\n modelPath: this.modelPath,\n modelArtifacts,\n modelArtifactsInfo\n });\n putModelRequest.onsuccess = () => resolve({modelArtifactsInfo});\n putModelRequest.onerror = error => {\n // If the put-model request fails, roll back the info entry as\n // well.\n infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const deleteInfoRequest = infoStore.delete(this.modelPath);\n deleteInfoRequest.onsuccess = () => {\n db.close();\n return reject(putModelRequest.error);\n };\n deleteInfoRequest.onerror = error => {\n db.close();\n return reject(putModelRequest.error);\n };\n };\n };\n putInfoRequest.onerror = error => {\n db.close();\n return reject(putInfoRequest.error);\n };\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n }\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nexport const indexedDBRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserIndexedDB.URL_SCHEME)) {\n return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(indexedDBRouter);\nIORouterRegistry.registerLoadRouter(indexedDBRouter);\n\n/**\n * Creates a browser IndexedDB IOHandler for saving and loading models.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save('indexeddb://MyModel'));\n * console.log(saveResult);\n * ```\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `BrowserIndexedDB` (sublcass of `IOHandler`),\n * which can be used with, e.g., `tf.Model.save`.\n */\nexport function browserIndexedDB(modelPath: string): IOHandler {\n return new BrowserIndexedDB(modelPath);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserIndexedDB.URL_SCHEME) ?\n key.slice(BrowserIndexedDB.URL_SCHEME.length) :\n key;\n}\n\nexport class BrowserIndexedDBManager implements ModelStoreManager {\n private indexedDB: IDBFactory;\n\n constructor() {\n this.indexedDB = getIndexedDBFactory();\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n return new Promise<{[path: string]: ModelArtifactsInfo}>(\n (resolve, reject) => {\n const openRequest =\n this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const tx = db.transaction(INFO_STORE_NAME, 'readonly');\n const store = tx.objectStore(INFO_STORE_NAME);\n // tslint:disable:max-line-length\n // Need to cast `store` as `any` here because TypeScript's DOM\n // library does not have the `getAll()` method even though the\n // method is supported in the latest version of most mainstream\n // browsers:\n // https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/getAll\n // tslint:enable:max-line-length\n // tslint:disable-next-line:no-any\n const getAllInfoRequest = (store as any).getAll() as IDBRequest;\n getAllInfoRequest.onsuccess = () => {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n for (const item of getAllInfoRequest.result) {\n out[item.modelPath] = item.modelArtifactsInfo;\n }\n resolve(out);\n };\n getAllInfoRequest.onerror = error => {\n db.close();\n return reject(getAllInfoRequest.error);\n };\n tx.oncomplete = () => db.close();\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n const infoStore = infoTx.objectStore(INFO_STORE_NAME);\n\n const getInfoRequest = infoStore.get(path);\n let modelTx: IDBTransaction;\n getInfoRequest.onsuccess = () => {\n if (getInfoRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${path}' ` +\n `in IndexedDB.`));\n } else {\n // First, delete the entry in the info store.\n const deleteInfoRequest = infoStore.delete(path);\n const deleteModelData = () => {\n // Second, delete the entry in the model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const deleteModelRequest = modelStore.delete(path);\n deleteModelRequest.onsuccess = () =>\n resolve(getInfoRequest.result.modelArtifactsInfo);\n deleteModelRequest.onerror = error =>\n reject(getInfoRequest.error);\n };\n // Proceed with deleting model data regardless of whether deletion\n // of info data succeeds or not.\n deleteInfoRequest.onsuccess = deleteModelData;\n deleteInfoRequest.onerror = error => {\n deleteModelData();\n db.close();\n return reject(getInfoRequest.error);\n };\n }\n };\n getInfoRequest.onerror = error => {\n db.close();\n return reject(getInfoRequest.error);\n };\n\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {assert} from '../util';\nimport {arrayBufferToBase64String, base64StringToArrayBuffer, getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst PATH_SEPARATOR = '/';\nconst PATH_PREFIX = 'tensorflowjs_models';\nconst INFO_SUFFIX = 'info';\nconst MODEL_TOPOLOGY_SUFFIX = 'model_topology';\nconst WEIGHT_SPECS_SUFFIX = 'weight_specs';\nconst WEIGHT_DATA_SUFFIX = 'weight_data';\n\n/**\n * Purge all tensorflow.js-saved model artifacts from local storage.\n *\n * @returns Paths of the models purged.\n */\nexport function purgeLocalStorageArtifacts(): string[] {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n throw new Error(\n 'purgeLocalStorageModels() cannot proceed because local storage is ' +\n 'unavailable in the current environment.');\n }\n const LS = window.localStorage;\n const purgedModelPaths: string[] = [];\n for (let i = 0; i < LS.length; ++i) {\n const key = LS.key(i);\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n if (key.startsWith(prefix) && key.length > prefix.length) {\n LS.removeItem(key);\n const modelName = getModelPathFromKey(key);\n if (purgedModelPaths.indexOf(modelName) === -1) {\n purgedModelPaths.push(modelName);\n }\n }\n }\n return purgedModelPaths;\n}\n\nfunction getModelKeys(path: string):\n {info: string, topology: string, weightSpecs: string, weightData: string} {\n return {\n info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR),\n topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR),\n weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR),\n weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR)\n };\n}\n\n/**\n * Get model path from a local-storage key.\n *\n * E.g., 'tensorflowjs_models/my/model/1/info' --> 'my/model/1'\n *\n * @param key\n */\nfunction getModelPathFromKey(key: string) {\n const items = key.split(PATH_SEPARATOR);\n if (items.length < 3) {\n throw new Error(`Invalid key format: ${key}`);\n }\n return items.slice(1, items.length - 1).join(PATH_SEPARATOR);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserLocalStorage.URL_SCHEME) ?\n key.slice(BrowserLocalStorage.URL_SCHEME.length) :\n key;\n}\n\n/**\n * IOHandler subclass: Browser Local Storage.\n *\n * See the doc string to `browserLocalStorage` for more details.\n */\nexport class BrowserLocalStorage implements IOHandler {\n protected readonly LS: Storage;\n protected readonly modelPath: string;\n protected readonly keys: {[key: string]: string};\n\n static readonly URL_SCHEME = 'localstorage://';\n\n constructor(modelPath: string) {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n // TODO(cais): Add more info about what IOHandler subtypes are\n // available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'The current environment does not support local storage.');\n }\n this.LS = window.localStorage;\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For local storage, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n this.keys = getModelKeys(this.modelPath);\n }\n\n /**\n * Save model artifacts to browser local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @param modelArtifacts The model artifacts to be stored.\n * @returns An instance of SaveResult.\n */\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const topology = JSON.stringify(modelArtifacts.modelTopology);\n const weightSpecs = JSON.stringify(modelArtifacts.weightSpecs);\n\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n\n try {\n this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo));\n this.LS.setItem(this.keys.topology, topology);\n this.LS.setItem(this.keys.weightSpecs, weightSpecs);\n this.LS.setItem(\n this.keys.weightData,\n arrayBufferToBase64String(modelArtifacts.weightData));\n\n return {modelArtifactsInfo};\n } catch (err) {\n // If saving failed, clean up all items saved so far.\n for (const key in this.keys) {\n this.LS.removeItem(this.keys[key]);\n }\n\n throw new Error(\n `Failed to save model '${this.modelPath}' to local storage: ` +\n `size quota being exceeded is a possible cause of this failure: ` +\n `modelTopologyBytes=${modelArtifactsInfo.modelTopologyBytes}, ` +\n `weightSpecsBytes=${modelArtifactsInfo.weightSpecsBytes}, ` +\n `weightDataBytes=${modelArtifactsInfo.weightDataBytes}.`);\n }\n }\n }\n\n /**\n * Load a model from local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @returns The loaded model (if loading succeeds).\n */\n async load(): Promise {\n const info =\n JSON.parse(this.LS.getItem(this.keys.info)) as ModelArtifactsInfo;\n if (info == null) {\n throw new Error(\n `In local storage, there is no model with name '${this.modelPath}'`);\n }\n\n if (info.modelTopologyType !== 'JSON') {\n throw new Error(\n 'BrowserLocalStorage does not support loading non-JSON model ' +\n 'topology yet.');\n }\n\n const out: ModelArtifacts = {};\n\n // Load topology.\n const topology = JSON.parse(this.LS.getItem(this.keys.topology));\n if (topology == null) {\n throw new Error(\n `In local storage, the topology of model '${this.modelPath}' ` +\n `is missing.`);\n }\n out.modelTopology = topology;\n\n // Load weight specs.\n const weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs));\n if (weightSpecs == null) {\n throw new Error(\n `In local storage, the weight specs of model '${this.modelPath}' ` +\n `are missing.`);\n }\n out.weightSpecs = weightSpecs;\n\n // Load weight data.\n const weightDataBase64 = this.LS.getItem(this.keys.weightData);\n if (weightDataBase64 == null) {\n throw new Error(\n `In local storage, the binary weight values of model ` +\n `'${this.modelPath}' are missing.`);\n }\n out.weightData = base64StringToArrayBuffer(weightDataBase64);\n\n return out;\n }\n}\n\nexport const localStorageRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserLocalStorage.URL_SCHEME)) {\n return browserLocalStorage(\n url.slice(BrowserLocalStorage.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(localStorageRouter);\nIORouterRegistry.registerLoadRouter(localStorageRouter);\n\n/**\n * Factory function for local storage IOHandler.\n *\n * This `IOHandler` supports both `save` and `load`.\n *\n * For each model's saved artifacts, four items are saved to local storage.\n * - `${PATH_SEPARATOR}/${modelPath}/info`: Contains meta-info about the\n * model, such as date saved, type of the topology, size in bytes, etc.\n * - `${PATH_SEPARATOR}/${modelPath}/topology`: Model topology. For Keras-\n * style models, this is a stringized JSON.\n * - `${PATH_SEPARATOR}/${modelPath}/weight_specs`: Weight specs of the\n * model, can be used to decode the saved binary weight values (see\n * item below).\n * - `${PATH_SEPARATOR}/${modelPath}/weight_data`: Concatenated binary\n * weight values, stored as a base64-encoded string.\n *\n * Saving may throw an `Error` if the total size of the artifacts exceed the\n * browser-specific quota.\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `IOHandler`, which can be used with, e.g.,\n * `tf.Model.save`.\n */\nexport function browserLocalStorage(modelPath: string): IOHandler {\n return new BrowserLocalStorage(modelPath);\n}\n\nexport class BrowserLocalStorageManager implements ModelStoreManager {\n private readonly LS: Storage;\n\n constructor() {\n assert(ENV.get('IS_BROWSER'), 'Current environment is not a web browser');\n assert(\n typeof window.localStorage !== 'undefined',\n 'Current browser does not appear to support localStorage');\n this.LS = window.localStorage;\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n const suffix = PATH_SEPARATOR + INFO_SUFFIX;\n for (let i = 0; i < this.LS.length; ++i) {\n const key = this.LS.key(i);\n if (key.startsWith(prefix) && key.endsWith(suffix)) {\n const modelPath = getModelPathFromKey(key);\n out[modelPath] = JSON.parse(this.LS.getItem(key)) as ModelArtifactsInfo;\n }\n }\n return out;\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n const keys = getModelKeys(path);\n if (this.LS.getItem(keys.info) == null) {\n throw new Error(`Cannot find model at path '${path}'`);\n }\n const info = JSON.parse(this.LS.getItem(keys.info)) as ModelArtifactsInfo;\n\n this.LS.removeItem(keys.info);\n this.LS.removeItem(keys.topology);\n this.LS.removeItem(keys.weightSpecs);\n this.LS.removeItem(keys.weightData);\n return info;\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers related to files, such as browser-triggered file downloads,\n * user-selected files in browser.\n */\n\nimport {ENV} from '../environment';\nimport {basename, concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\nconst DEFAULT_FILE_NAME_PREFIX = 'model';\nconst DEFAULT_JSON_EXTENSION_NAME = '.json';\nconst DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin';\n\nexport class BrowserDownloads implements IOHandler {\n private readonly modelTopologyFileName: string;\n private readonly weightDataFileName: string;\n private readonly jsonAnchor: HTMLAnchorElement;\n private readonly weightDataAnchor: HTMLAnchorElement;\n\n static readonly URL_SCHEME = 'downloads://';\n\n constructor(fileNamePrefix?: string) {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Provide info on what IOHandlers are available under the\n // current environment.\n throw new Error(\n 'triggerDownloads() cannot proceed because the current environment ' +\n 'is not a browser.');\n }\n\n if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) {\n fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length);\n }\n if (fileNamePrefix == null || fileNamePrefix.length === 0) {\n fileNamePrefix = DEFAULT_FILE_NAME_PREFIX;\n }\n\n this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME;\n this.weightDataFileName =\n fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n const weightsURL = window.URL.createObjectURL(new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}));\n\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'DownloadTrigger.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./' + this.weightDataFileName],\n weights: modelArtifacts.weightSpecs\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n const modelTopologyAndWeightManifestURL =\n window.URL.createObjectURL(new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}));\n\n // If anchor elements are not provided, create them without attaching them\n // to parents, so that the downloaded file names can be controlled.\n const jsonAnchor = this.jsonAnchor == null ? document.createElement('a') :\n this.jsonAnchor;\n jsonAnchor.download = this.modelTopologyFileName;\n jsonAnchor.href = modelTopologyAndWeightManifestURL;\n // Trigger downloads by calling the `click` methods on the download\n // anchors.\n jsonAnchor.click();\n\n if (modelArtifacts.weightData != null) {\n const weightDataAnchor = this.weightDataAnchor == null ?\n document.createElement('a') :\n this.weightDataAnchor;\n weightDataAnchor.download = this.weightDataFileName;\n weightDataAnchor.href = weightsURL;\n weightDataAnchor.click();\n }\n\n return {modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts)};\n }\n }\n}\n\nclass BrowserFiles implements IOHandler {\n private readonly files: File[];\n\n constructor(files: File[]) {\n if (files == null || files.length < 1) {\n throw new Error(\n `When calling browserFiles, at least 1 file is required, ` +\n `but received ${files}`);\n }\n this.files = files;\n }\n\n async load(): Promise {\n const jsonFile = this.files[0];\n const weightFiles = this.files.slice(1);\n\n return new Promise((resolve, reject) => {\n const jsonReader = new FileReader();\n jsonReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const modelJSON = JSON.parse((event.target as any).result);\n const modelTopology = modelJSON.modelTopology as {};\n if (modelTopology == null) {\n reject(new Error(\n `modelTopology field is missing from file ${jsonFile.name}`));\n return;\n }\n\n if (weightFiles.length === 0) {\n resolve({modelTopology});\n }\n\n const weightsManifest =\n modelJSON.weightsManifest as WeightsManifestConfig;\n if (weightsManifest == null) {\n reject(new Error(\n `weightManifest field is missing from file ${jsonFile.name}`));\n return;\n }\n\n let pathToFile: {[path: string]: File};\n try {\n pathToFile =\n this.checkManifestAndWeightFiles(weightsManifest, weightFiles);\n } catch (err) {\n reject(err);\n return;\n }\n\n const weightSpecs: WeightsManifestEntry[] = [];\n const paths: string[] = [];\n const perFileBuffers: ArrayBuffer[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n paths.push(path);\n perFileBuffers.push(null);\n });\n weightSpecs.push(...weightsGroup.weights);\n });\n\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n const weightFileReader = new FileReader();\n weightFileReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const weightData = (event.target as any).result as ArrayBuffer;\n const index = paths.indexOf(path);\n perFileBuffers[index] = weightData;\n if (perFileBuffers.indexOf(null) === -1) {\n resolve({\n modelTopology,\n weightSpecs,\n weightData: concatenateArrayBuffers(perFileBuffers),\n });\n }\n };\n weightFileReader.onerror = (error: FileReaderProgressEvent) => {\n reject(`Failed to weights data from file of path '${path}'.`);\n return;\n };\n weightFileReader.readAsArrayBuffer(pathToFile[path]);\n });\n });\n };\n jsonReader.onerror = (error: FileReaderProgressEvent) => {\n reject(\n `Failed to read model topology and weights manifest JSON ` +\n `from file '${jsonFile.name}'. BrowserFiles supports loading ` +\n `Keras-style tf.Model artifacts only.`);\n return;\n };\n jsonReader.readAsText(jsonFile);\n });\n }\n\n /**\n * Check the compatibility between weights manifest and weight files.\n */\n private checkManifestAndWeightFiles(\n manifest: WeightsManifestConfig, files: File[]): {[path: string]: File} {\n const basenames: string[] = [];\n const fileNames = files.map(file => basename(file.name));\n const pathToFile: {[path: string]: File} = {};\n for (const group of manifest) {\n group.paths.forEach(path => {\n const pathBasename = basename(path);\n if (basenames.indexOf(pathBasename) !== -1) {\n throw new Error(\n `Duplicate file basename found in weights manifest: ` +\n `'${pathBasename}'`);\n }\n basenames.push(pathBasename);\n if (fileNames.indexOf(pathBasename) === -1) {\n throw new Error(\n `Weight file with basename '${pathBasename}' is not provided.`);\n } else {\n pathToFile[path] = files[fileNames.indexOf(pathBasename)];\n }\n });\n }\n\n if (basenames.length !== files.length) {\n throw new Error(\n `Mismatch in the number of files in weights manifest ` +\n `(${basenames.length}) and the number of weight files provided ` +\n `(${files.length}).`);\n }\n return pathToFile;\n }\n}\n\nexport const browserDownloadsRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserDownloads.URL_SCHEME)) {\n return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(browserDownloadsRouter);\n\n/**\n * Creates an IOHandler that triggers file downloads from the browser.\n *\n * The returned `IOHandler` instance can be used as model exporting methods such\n * as `tf.Model.save` and supports only saving.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * const saveResult = await model.save('downloads://mymodel'));\n * // This will trigger downloading of two files:\n * // 'mymodel.json' and 'mymodel.weights.bin'.\n * console.log(saveResult);\n * ```\n *\n * @param fileNamePrefix Prefix name of the files to be downloaded. For use with\n * `tf.Model`, `fileNamePrefix` should follow either of the following two\n * formats:\n * 1. `null` or `undefined`, in which case the default file\n * names will be used:\n * - 'model.json' for the JSON file containing the model topology and\n * weights manifest.\n * - 'model.weights.bin' for the binary file containing the binary weight\n * values.\n * 2. A single string or an Array of a single string, as the file name prefix.\n * For example, if `'foo'` is provided, the downloaded JSON\n * file and binary weights file will be named 'foo.json' and\n * 'foo.weights.bin', respectively.\n * @param config Additional configuration for triggering downloads.\n * @returns An instance of `DownloadTrigger` `IOHandler`.\n */\nexport function browserDownloads(fileNamePrefix = 'model'): IOHandler {\n return new BrowserDownloads(fileNamePrefix);\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from user-selected files.\n *\n * This method can be used for loading from files such as user-selected files\n * in the browser.\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * // Note: This code snippet won't run properly without the actual file input\n * // elements in the HTML DOM.\n *\n * // Suppose there are two HTML file input (``)\n * // elements.\n * const uploadJSONInput = document.getElementById('upload-json');\n * const uploadWeightsInput = document.getElementById('upload-weights');\n * const model = await tfl.loadModel(tf.io.browserFiles(\n * [uploadJSONInput.files[0], uploadWeightsInput.files[0]]));\n * ```\n *\n * @param files `File`s to load from. Currently, this function supports only\n * loading from files that contain Keras-style models (i.e., `tf.Model`s), for\n * which an `Array` of `File`s is expected (in that order):\n * - A JSON file containing the model topology and weight manifest.\n * - Optionally, One or more binary files containing the binary weights.\n * These files must have names that match the paths in the `weightsManifest`\n * contained by the aforementioned JSON file, or errors will be thrown\n * during loading. These weights files have the same format as the ones\n * generated by `tensorflowjs_converter` that comes with the `tensorflowjs`\n * Python PIP package. If no weights files are provided, only the model\n * topology will be loaded from the JSON file above.\n * @returns An instance of `Files` `IOHandler`.\n */\nexport function browserFiles(files: File[]): IOHandler {\n return new BrowserFiles(files);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/ops';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport * as util from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\n/**\n * Reads binary weights data from a number of URLs.\n *\n * @param fetchURLs URLs to send the HTTP requests at, using `fetch` calls.\n * @param requestOptions RequestInit (options) for the HTTP requests.\n * @returns A `Promise` of an Array of `ArrayBuffer`. The Array has the same\n * length as `fetchURLs`.\n */\nexport async function loadWeightsAsArrayBuffer(\n fetchURLs: string[], requestOptions?: RequestInit): Promise {\n // Create the requests for all of the weights in parallel.\n const requests = fetchURLs.map(fetchURL => fetch(fetchURL, requestOptions));\n const responses = await Promise.all(requests);\n const buffers =\n await Promise.all(responses.map(response => response.arrayBuffer()));\n return buffers;\n}\n\n/**\n * Reads a weights manifest JSON configuration, fetches the weights and\n * returns them as `Tensor`s.\n *\n * @param manifest The weights manifest JSON.\n * @param filePathPrefix The path prefix for filenames given in the manifest.\n * Defaults to the empty string.\n * @param weightNames The names of the weights to be fetched.\n */\nexport async function loadWeights(\n manifest: WeightsManifestConfig, filePathPrefix = '',\n weightNames?: string[],\n requestOptions?: RequestInit): Promise {\n // TODO(nsthorat): Groups are currently fetched atomically. If you need a\n // single weight from a group, the whole group will be fetched. At a future\n // date, we should support fetching only the individual shards within a\n // group that are needed to reconstruct the requested weight.\n // TODO(cais): Use `decodeWeights` for implementation.\n\n // Collect all the groups, weights, and their relative offsets to be\n // fetched.\n const groupIndicesToFetchMap = manifest.map(() => false);\n const groupWeightsToFetch: {\n [group: number]: Array<{\n manifestEntry: WeightsManifestEntry; groupOffset: number;\n sizeBytes: number;\n }>\n } = {};\n const weightsFound = weightNames != null ? weightNames.map(() => false) : [];\n const allManifestWeightNames: string[] = [];\n manifest.forEach((manifestGroupConfig, groupIndex) => {\n let groupOffset = 0;\n manifestGroupConfig.weights.forEach(weightsEntry => {\n const rawDtype = ('quantization' in weightsEntry) ?\n weightsEntry.quantization.dtype :\n weightsEntry.dtype;\n\n const weightsBytes = DTYPE_VALUE_SIZE_MAP[rawDtype] *\n util.sizeFromShape(weightsEntry.shape);\n\n const enqueueWeightsForFetchingFn = () => {\n groupIndicesToFetchMap[groupIndex] = true;\n if (groupWeightsToFetch[groupIndex] == null) {\n groupWeightsToFetch[groupIndex] = [];\n }\n\n groupWeightsToFetch[groupIndex].push({\n manifestEntry: weightsEntry,\n groupOffset,\n sizeBytes: weightsBytes\n });\n };\n\n if (weightNames != null) {\n weightNames.forEach((weightName, weightIndex) => {\n if (weightName === weightsEntry.name) {\n enqueueWeightsForFetchingFn();\n weightsFound[weightIndex] = true;\n }\n });\n } else {\n enqueueWeightsForFetchingFn();\n }\n\n allManifestWeightNames.push(weightsEntry.name);\n groupOffset += weightsBytes;\n });\n });\n\n if (!weightsFound.every(found => found)) {\n const weightsNotFound = weightNames.filter((weight, i) => !weightsFound[i]);\n throw new Error(\n `Could not find weights in manifest with names: ` +\n `${weightsNotFound.join(', ')}. \\n` +\n `Manifest JSON has weights with names: ` +\n `${allManifestWeightNames.join(', ')}.`);\n }\n\n // Convert the one-hot boolean groupId => shouldFetch map to a list of group\n // IDs.\n const groupIndicesToFetch =\n groupIndicesToFetchMap.reduce((accumulator, shouldFetch, i) => {\n if (shouldFetch) {\n accumulator.push(i);\n }\n return accumulator;\n }, []);\n\n const fetchUrls: string[] = [];\n groupIndicesToFetch.forEach(i => {\n manifest[i].paths.forEach(filepath => {\n const fetchUrl = filePathPrefix +\n (!filePathPrefix.endsWith('/') ? '/' : '') + filepath;\n fetchUrls.push(fetchUrl);\n });\n });\n const buffers = await loadWeightsAsArrayBuffer(fetchUrls, requestOptions);\n\n const weightsTensorMap: NamedTensorMap = {};\n let bufferIndexOffset = 0;\n groupIndicesToFetch.forEach(i => {\n const numBuffers = manifest[i].paths.length;\n\n let groupBytes = 0;\n for (let i = 0; i < numBuffers; i++) {\n groupBytes += buffers[bufferIndexOffset + i].byteLength;\n }\n\n // Create a buffer for the whole group.\n const groupBuffer = new ArrayBuffer(groupBytes);\n const groupByteBuffer = new Uint8Array(groupBuffer);\n let groupBufferOffset = 0;\n for (let i = 0; i < numBuffers; i++) {\n const buffer = new Uint8Array(buffers[bufferIndexOffset + i]);\n groupByteBuffer.set(buffer, groupBufferOffset);\n groupBufferOffset += buffer.byteLength;\n }\n\n const weightsEntries = groupWeightsToFetch[i];\n\n weightsEntries.forEach(weightsEntry => {\n const byteBuffer = groupBuffer.slice(\n weightsEntry.groupOffset,\n weightsEntry.groupOffset + weightsEntry.sizeBytes);\n\n let typedArray: TypedArray;\n\n const dtype = weightsEntry.manifestEntry.dtype;\n\n if ('quantization' in weightsEntry.manifestEntry) {\n const quantization = weightsEntry.manifestEntry.quantization;\n if (quantization.dtype !== 'uint8' && quantization.dtype !== 'uint16') {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown ` +\n `quantization dtype ${quantization.dtype}.`);\n }\n const quantizedArray = (quantization.dtype === 'uint8') ?\n new Uint8Array(byteBuffer) :\n new Uint16Array(byteBuffer);\n if (dtype === 'float32') {\n typedArray = Float32Array.from(\n quantizedArray, v => v * quantization.scale + quantization.min);\n } else if (dtype === 'int32') {\n typedArray = Int32Array.from(\n quantizedArray,\n v => Math.round(v * quantization.scale + quantization.min));\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has a dtype not ` +\n `supported by quantization: ${dtype}`);\n }\n } else {\n if (dtype === 'float32') {\n typedArray = new Float32Array(byteBuffer);\n } else if (dtype === 'int32') {\n typedArray = new Int32Array(byteBuffer);\n } else if (dtype === 'bool') {\n typedArray = new Uint8Array(byteBuffer);\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown dtype ` +\n `${dtype}.`);\n }\n }\n\n const weightName = weightsEntry.manifestEntry.name;\n if (weightsTensorMap[weightName] != null) {\n throw new Error(\n `Duplicate weight with name ${weightName}. ` +\n `Please make sure weights names are unique in the manifest JSON.`);\n }\n weightsTensorMap[weightName] = tensor(\n typedArray, weightsEntry.manifestEntry.shape,\n weightsEntry.manifestEntry.dtype);\n });\n\n bufferIndexOffset += numBuffers;\n });\n\n return weightsTensorMap;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandler implementations based on HTTP requests in the web browser.\n *\n * Uses [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).\n */\n\nimport {assert} from '../util';\nimport {concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeightsAsArrayBuffer} from './weights_loader';\n\nexport class BrowserHTTPRequest implements IOHandler {\n protected readonly path: string;\n protected readonly requestInit: RequestInit;\n\n readonly DEFAULT_METHOD = 'POST';\n\n static readonly URL_SCHEMES = ['http://', 'https://'];\n\n constructor(path: string, requestInit?: RequestInit) {\n if (typeof fetch === 'undefined') {\n throw new Error(\n // tslint:disable-next-line:max-line-length\n 'browserHTTPRequest is not supported outside the web browser without a fetch polyfill.');\n }\n\n assert(\n path != null && path.length > 0,\n 'URL path for browserHTTPRequest must not be null, undefined or ' +\n 'empty.');\n this.path = path;\n\n if (requestInit != null && requestInit.body != null) {\n throw new Error(\n 'requestInit is expected to have no pre-existing body, but has one.');\n }\n this.requestInit = requestInit || {};\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserHTTPRequest.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n const init = Object.assign({method: this.DEFAULT_METHOD}, this.requestInit);\n init.body = new FormData();\n\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./model.weights.bin'],\n weights: modelArtifacts.weightSpecs,\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n\n init.body.append(\n 'model.json',\n new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}),\n 'model.json');\n\n if (modelArtifacts.weightData != null) {\n init.body.append(\n 'model.weights.bin',\n new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}),\n 'model.weights.bin');\n }\n\n const response = await fetch(this.path, init);\n\n if (response.status === 200) {\n return {\n modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts),\n responses: [response],\n };\n } else {\n throw new Error(\n `BrowserHTTPRequest.save() failed due to HTTP response status ` +\n `${response.status}.`);\n }\n }\n\n /**\n * Load model artifacts via HTTP request(s).\n *\n * See the documentation to `browserHTTPRequest` for details on the saved\n * artifacts.\n *\n * @returns The loaded model artifacts (if loading succeeds).\n */\n async load(): Promise {\n const modelConfigRequest = await fetch(this.path, this.requestInit);\n const modelConfig = await modelConfigRequest.json();\n const modelTopology = modelConfig['modelTopology'];\n const weightsManifest = modelConfig['weightsManifest'];\n\n // We do not allow both modelTopology and weightsManifest to be missing.\n if (modelTopology == null && weightsManifest == null) {\n throw new Error(\n `The JSON from HTTP path ${this.path} contains neither model ` +\n `topology or manifest for weights.`);\n }\n\n let weightSpecs: WeightsManifestEntry[];\n let weightData: ArrayBuffer;\n if (weightsManifest != null) {\n const weightsManifest =\n modelConfig['weightsManifest'] as WeightsManifestConfig;\n weightSpecs = [];\n for (const entry of weightsManifest) {\n weightSpecs.push(...entry.weights);\n }\n\n let pathPrefix = this.path.substring(0, this.path.lastIndexOf('/'));\n if (!pathPrefix.endsWith('/')) {\n pathPrefix = pathPrefix + '/';\n }\n\n const fetchURLs: string[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n fetchURLs.push(pathPrefix + path);\n });\n });\n weightData = concatenateArrayBuffers(\n await loadWeightsAsArrayBuffer(fetchURLs, this.requestInit));\n }\n\n return {modelTopology, weightSpecs, weightData};\n }\n}\n\nexport const httpRequestRouter: IORouter = (url: string) => {\n if (typeof fetch === 'undefined') {\n // browserHTTPRequest uses `fetch`, if one wants to use it in node.js\n // they have to setup a global fetch polyfill.\n return null;\n } else {\n for (const scheme of BrowserHTTPRequest.URL_SCHEMES) {\n if (url.startsWith(scheme)) {\n return browserHTTPRequest(url);\n }\n }\n return null;\n }\n};\nIORouterRegistry.registerSaveRouter(httpRequestRouter);\nIORouterRegistry.registerLoadRouter(httpRequestRouter);\n\n/**\n * Creates an IOHandler subtype that sends model artifacts to HTTP server.\n *\n * An HTTP request of the `multipart/form-data` mime type will be sent to the\n * `path` URL. The form data includes artifacts that represent the topology\n * and/or weights of the model. In the case of Keras-style `tf.Model`, two\n * blobs (files) exist in form-data:\n * - A JSON file consisting of `modelTopology` and `weightsManifest`.\n * - A binary weights file consisting of the concatenated weight values.\n * These files are in the same format as the one generated by\n * [tfjs_converter](https://js.tensorflow.org/tutorials/import-keras.html).\n *\n * The following code snippet exemplifies the client-side code that uses this\n * function:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save(tf.io.browserHTTPRequest(\n * 'http://model-server:5000/upload', {method: 'PUT'}));\n * console.log(saveResult);\n * ```\n *\n * If the default `POST` method is to be used, without any custom parameters\n * such as headers, you can simply pass an HTTP or HTTPS URL to `model.save`:\n *\n * ```js\n * const saveResult = await model.save('http://model-server:5000/upload');\n * ```\n *\n * The following Python code snippet based on the\n * [flask](https://github.com/pallets/flask) server framework implements a\n * server that can receive the request. Upon receiving the model artifacts\n * via the requst, this particular server reconsistutes instances of\n * [Keras Models](https://keras.io/models/model/) in memory.\n *\n * ```python\n * # pip install -U flask flask-cors tensorflow tensorflowjs\n *\n * from __future__ import absolute_import\n * from __future__ import division\n * from __future__ import print_function\n *\n * import io\n *\n * from flask import Flask, Response, request\n * from flask_cors import CORS, cross_origin\n * import tensorflow as tf\n * import tensorflowjs as tfjs\n * import werkzeug.formparser\n *\n *\n * class ModelReceiver(object):\n *\n * def __init__(self):\n * self._model = None\n * self._model_json_bytes = None\n * self._model_json_writer = None\n * self._weight_bytes = None\n * self._weight_writer = None\n *\n * @property\n * def model(self):\n * self._model_json_writer.flush()\n * self._weight_writer.flush()\n * self._model_json_writer.seek(0)\n * self._weight_writer.seek(0)\n *\n * json_content = self._model_json_bytes.read()\n * weights_content = self._weight_bytes.read()\n * return tfjs.converters.deserialize_keras_model(\n * json_content,\n * weight_data=[weights_content],\n * use_unique_name_scope=True)\n *\n * def stream_factory(self,\n * total_content_length,\n * content_type,\n * filename,\n * content_length=None):\n * # Note: this example code is *not* thread-safe.\n * if filename == 'model.json':\n * self._model_json_bytes = io.BytesIO()\n * self._model_json_writer = io.BufferedWriter(self._model_json_bytes)\n * return self._model_json_writer\n * elif filename == 'model.weights.bin':\n * self._weight_bytes = io.BytesIO()\n * self._weight_writer = io.BufferedWriter(self._weight_bytes)\n * return self._weight_writer\n *\n *\n * def main():\n * app = Flask('model-server')\n * CORS(app)\n * app.config['CORS_HEADER'] = 'Content-Type'\n *\n * model_receiver = ModelReceiver()\n *\n * @app.route('/upload', methods=['POST'])\n * @cross_origin()\n * def upload():\n * print('Handling request...')\n * werkzeug.formparser.parse_form_data(\n * request.environ, stream_factory=model_receiver.stream_factory)\n * print('Received model:')\n * with tf.Graph().as_default(), tf.Session():\n * model = model_receiver.model\n * model.summary()\n * # You can perform `model.predict()`, `model.fit()`,\n * # `model.evaluate()` etc. here.\n * return Response(status=200)\n *\n * app.run('localhost', 5000)\n *\n *\n * if __name__ == '__main__':\n * main()\n * ```\n *\n * @param path URL path. Can be an absolute HTTP path (e.g.,\n * 'http://localhost:8000/model-upload)') or a relative path (e.g.,\n * './model-upload').\n * @param requestInit Request configurations to be used when sending\n * HTTP request to server using `fetch`. It can contain fields such as\n * `method`, `credentials`, `headers`, `mode`, etc. See\n * https://developer.mozilla.org/en-US/docs/Web/API/Request/Request\n * for more information. `requestInit` must not have a body, because the body\n * will be set by TensorFlow.js. File blobs representing\n * the model topology (filename: 'model.json') and the weights of the\n * model (filename: 'model.weights.bin') will be appended to the body.\n * If `requestInit` has a `body`, an Error will be thrown.\n * @returns An instance of `IOHandler`.\n */\nexport function browserHTTPRequest(\n path: string, requestInit?: RequestInit): IOHandler {\n return new BrowserHTTPRequest(path, requestInit);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers that pass through the in-memory ModelArtifacts format.\n */\n\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestEntry} from './types';\n\nclass PassthroughLoader implements IOHandler {\n constructor(\n private readonly modelTopology?: {}|ArrayBuffer,\n private readonly weightSpecs?: WeightsManifestEntry[],\n private readonly weightData?: ArrayBuffer) {}\n\n async load(): Promise {\n let result = {};\n if (this.modelTopology != null) {\n result = {modelTopology: this.modelTopology, ...result};\n }\n if (this.weightSpecs != null && this.weightSpecs.length > 0) {\n result = {weightSpecs: this.weightSpecs, ...result};\n }\n if (this.weightData != null && this.weightData.byteLength > 0) {\n result = {weightData: this.weightData, ...result};\n }\n return result;\n }\n}\n\nclass PassthroughSaver implements IOHandler {\n constructor(\n private readonly saveHandler: (artifacts: ModelArtifacts) => SaveResult) {\n }\n\n async save(modelArtifacts: ModelArtifacts) {\n return this.saveHandler(modelArtifacts);\n }\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from memory.\n *\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * const model = await tf.loadModel(tf.io.fromMemory(\n * modelTopology, weightSpecs, weightData));\n * ```\n *\n * @param modelTopology a object containing model topology (i.e., parsed from\n * the JSON format).\n * @param weightSpecs An array of `WeightsManifestEntry` objects describing the\n * names, shapes, types, and quantization of the weight data.\n * @param weightData A single `ArrayBuffer` containing the weight data,\n * concatenated in the order described by the weightSpecs.\n *\n * @returns A passthrough `IOHandler` that simply loads the provided data.\n */\nexport function fromMemory(\n modelTopology: {}, weightSpecs?: WeightsManifestEntry[],\n weightData?: ArrayBuffer): IOHandler {\n return new PassthroughLoader(modelTopology, weightSpecs, weightData);\n}\n\n/**\n * Creates an IOHandler that passes saved model artifacts to a callback.\n *\n * ```js\n * function handleSave(artifacts) {\n * // ... do something with the artifacts ...\n * return {modelArtifactsInfo: {...}, ...};\n * }\n *\n * const saveResult = model.save(tf.io.withSaveHandler(handleSave));\n * ```\n *\n * @param saveHandler A function that accepts a `ModelArtifacts` and returns a\n * `SaveResult`.\n */\nexport function withSaveHandler(\n saveHandler: (artifacts: ModelArtifacts) => SaveResult): IOHandler {\n return new PassthroughSaver(saveHandler);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Importing local_storage and indexed_db is necessary for the routers to be\n// registered.\nimport './indexed_db';\nimport './local_storage';\n\nimport {browserFiles} from './browser_files';\nimport {browserHTTPRequest} from './browser_http';\nimport {concatenateArrayBuffers, decodeWeights, encodeWeights, getModelArtifactsInfoForJSON} from './io_utils';\nimport {fromMemory, withSaveHandler} from './passthrough';\nimport {IORouterRegistry} from './router_registry';\nimport {IOHandler, LoadHandler, ModelArtifacts, ModelStoreManager, SaveConfig, SaveHandler, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeights} from './weights_loader';\n\nconst registerSaveRouter = IORouterRegistry.registerSaveRouter;\nconst registerLoadRouter = IORouterRegistry.registerLoadRouter;\nconst getSaveHandlers = IORouterRegistry.getSaveHandlers;\nconst getLoadHandlers = IORouterRegistry.getLoadHandlers;\n\nexport {copyModel, listModels, moveModel, removeModel} from './model_management';\n\nexport {\n browserFiles,\n browserHTTPRequest,\n concatenateArrayBuffers,\n decodeWeights,\n encodeWeights,\n fromMemory,\n getLoadHandlers,\n getModelArtifactsInfoForJSON,\n getSaveHandlers,\n IOHandler,\n LoadHandler,\n loadWeights,\n ModelArtifacts,\n ModelStoreManager,\n registerLoadRouter,\n registerSaveRouter,\n SaveConfig,\n SaveHandler,\n SaveResult,\n WeightsManifestConfig,\n WeightsManifestEntry,\n withSaveHandler\n};\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Types to support JSON-esque data structures internally.\n *\n * Internally ConfigDict's use camelCase keys and values where the\n * values are class names to be instantiated. On the python side, these\n * will be snake_case. Internally we allow Enums into the values for better\n * type safety, but these need to be converted to raw primitives (usually\n * strings) for round-tripping with python.\n *\n * toConfig returns the TS-friendly representation. model.toJSON() returns\n * the pythonic version as that's the portable format. If you need to\n * python-ify a non-model level toConfig output, you'll need to use a\n * convertTsToPythonic from serialization_utils in -Layers.\n *\n */\nexport type ConfigDictValue =\n boolean|number|string|null|ConfigDictArray|ConfigDict;\nexport interface ConfigDict {\n [key: string]: ConfigDictValue;\n}\nexport interface ConfigDictArray extends Array {}\n\n/**\n * Type to represent the class-type of Serializable objects.\n *\n * Ie the class prototype with access to the constructor and any\n * static members/methods. Instance methods are not listed here.\n *\n * Source for this idea: https://stackoverflow.com/a/43607255\n */\nexport type SerializableConstructor = {\n // tslint:disable-next-line:no-any\n new (...args: any[]): T; className: string; fromConfig: FromConfigMethod;\n};\nexport type FromConfigMethod =\n (cls: SerializableConstructor, config: ConfigDict) => T;\n\n/**\n * Serializable defines the serialization contract.\n *\n * TFJS requires serializable classes to return their className when asked\n * to avoid issues with minification.\n */\nexport abstract class Serializable {\n /**\n * Return the class name for this class to use in serialization contexts.\n *\n * Generally speaking this will be the same thing that constructor.name\n * would have returned. However, the class name needs to be robust\n * against minification for serialization/deserialazation to work properly.\n *\n * There's also places such as initializers.VarianceScaling, where\n * implementation details between different languages led to different\n * class hierarchies and a non-leaf node is used for serialization purposes.\n */\n getClassName(): string {\n return (this.constructor as SerializableConstructor)\n .className;\n }\n\n /**\n * Return all the non-weight state needed to serialize this object.\n */\n abstract getConfig(): ConfigDict;\n\n /**\n * Creates an instance of T from a ConfigDict.\n *\n * This works for most descendants of serializable. A few need to\n * provide special handling.\n * @param cls A Constructor for the class to instantiate.\n * @param config The Configuration for the object.\n */\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config);\n }\n}\n\n/**\n * Maps string keys to class constructors.\n *\n * Used during (de)serialization from the cross-language JSON format, which\n * requires the class name in the serialization format matches the class\n * names as used in Python, should it exist.\n */\nexport class SerializationMap {\n private static instance: SerializationMap;\n classNameMap: {\n [className: string]:\n [\n SerializableConstructor, FromConfigMethod\n ]\n };\n\n private constructor() {\n this.classNameMap = {};\n }\n\n /**\n * Returns the singleton instance of the map.\n */\n static getMap(): SerializationMap {\n if (SerializationMap.instance == null) {\n SerializationMap.instance = new SerializationMap();\n }\n return SerializationMap.instance;\n }\n\n /**\n * Registers the class as serializable.\n */\n static register(cls: SerializableConstructor) {\n SerializationMap.getMap().classNameMap[cls.className] =\n [cls, cls.fromConfig];\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Features} from './environment_util';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\n// TODO(smilkov): Move these constants to jasmine_util.\nexport const WEBGL_ENVS: Features = {\n 'HAS_WEBGL': true\n};\nexport const NODE_ENVS: Features = {\n 'IS_NODE': true\n};\nexport const CHROME_ENVS: Features = {\n 'IS_CHROME': true\n};\nexport const BROWSER_ENVS: Features = {\n 'IS_BROWSER': true\n};\nexport const CPU_ENVS: Features = {\n 'HAS_WEBGL': false\n};\nexport const ALL_ENVS: Features = {};\n\nexport function expectArraysClose(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[], epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!(actual instanceof Tensor) && !(expected instanceof Tensor)) {\n const aType = actual.constructor.name;\n const bType = expected.constructor.name;\n\n if (aType !== bType) {\n throw new Error(\n `Arrays are of different type actual: ${aType} ` +\n `vs expected: ${bType}`);\n }\n } else if (actual instanceof Tensor && expected instanceof Tensor) {\n if (actual.dtype !== expected.dtype) {\n throw new Error(\n `Arrays are of different type actual: ${actual.dtype} ` +\n `vs expected: ${expected.dtype}.`);\n }\n if (!util.arraysEqual(actual.shape, expected.shape)) {\n throw new Error(\n `Arrays are of different shape actual: ${actual.shape} ` +\n `vs expected: ${expected.shape}.`);\n }\n }\n\n let actualValues: TypedArray|number[];\n let expectedValues: TypedArray|number[]|boolean[];\n if (actual instanceof Tensor) {\n actualValues = actual.dataSync();\n } else {\n actualValues = actual;\n }\n if (expected instanceof Tensor) {\n expectedValues = expected.dataSync();\n } else {\n expectedValues = expected;\n }\n\n if (actualValues.length !== expectedValues.length) {\n throw new Error(\n `Arrays have different lengths actual: ${actualValues.length} vs ` +\n `expected: ${expectedValues.length}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n for (let i = 0; i < expectedValues.length; ++i) {\n const a = actualValues[i];\n const e = expectedValues[i];\n\n if (!areClose(a, Number(e), epsilon)) {\n throw new Error(\n `Arrays differ: actual[${i}] = ${a}, expected[${i}] = ${e}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n }\n}\n\nexport interface DoneFn {\n (): void;\n fail: (message?: Error|string) => void;\n}\n\nexport function expectPromiseToFail(fn: () => Promise<{}>, done: DoneFn): void {\n fn().then(() => done.fail(), () => done());\n}\n\nexport function expectArraysEqual(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[]) {\n return expectArraysClose(actual, expected, 0);\n}\n\nexport function expectNumbersClose(a: number, e: number, epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!areClose(a, e, epsilon)) {\n throw new Error(`Numbers differ: actual === ${a}, expected === ${e}`);\n }\n}\n\nfunction areClose(a: number, e: number, epsilon: number): boolean {\n if (isNaN(a) && isNaN(e)) {\n return true;\n }\n if (isNaN(a) || isNaN(e) || Math.abs(a - e) > epsilon) {\n return false;\n }\n return true;\n}\n\nexport function expectValuesInRange(\n actual: Tensor|TypedArray|number[], low: number, high: number) {\n let actualVals: TypedArray|number[];\n if (actual instanceof Tensor) {\n actualVals = actual.dataSync();\n } else {\n actualVals = actual;\n }\n for (let i = 0; i < actualVals.length; i++) {\n if (actualVals[i] < low || actualVals[i] > high) {\n throw new Error(\n `Value out of range:${actualVals[i]} low: ${low}, high: ${high}`);\n }\n }\n}\n\nexport function expectArrayBuffersEqual(\n actual: ArrayBuffer, expected: ArrayBuffer) {\n // Safari & Jasmine dont like comparing ArrayBuffers directly. Wrapping in\n // a Float32Array solves this issue.\n expect(new Float32Array(actual)).toEqual(new Float32Array(expected));\n}\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.8';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {variableGrads} from '../globals';\nimport {Serializable} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\n\n/** @doc {heading: 'Training', subheading: 'Classes', namespace: 'train'} */\nexport abstract class Optimizer extends Serializable {\n /**\n * Executes `f()` and minimizes the scalar output of `f()` by computing\n * gradients of y with respect to the list of trainable variables provided by\n * `varList`. If no list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to minimize.\n * @param returnCost Whether to return the scalar cost value produced by\n * executing `f()`.\n * @param varList An optional list of variables to update. If specified, only\n * the trainable variables in varList will be updated by minimize. Defaults to\n * all trainable variables.\n */\n /** @doc {heading: 'Training', subheading: 'Optimizers'} */\n minimize(f: () => Scalar, returnCost = false, varList?: Variable[]): Scalar\n |null {\n const {value, grads} = this.computeGradients(f, varList);\n\n this.applyGradients(grads);\n\n // Dispose gradients.\n const varNames = Object.keys(grads);\n varNames.forEach(varName => grads[varName].dispose());\n\n if (returnCost) {\n return value as Scalar;\n } else {\n value.dispose();\n return null;\n }\n }\n\n /**\n * Executes f() and computes the gradient of the scalar output of f() with\n * respect to the list of trainable variables provided by `varList`. If no\n * list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to use for computing\n * gradients with respect to variables.\n * @param varList An optional list of variables to compute gradients with\n * respect to. If specified, only the trainable variables in varList will have\n * gradients computed with respect to. Defaults to all trainable variables.\n */\n computeGradients(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n return variableGrads(f, varList);\n }\n\n /**\n * Updates variables by using the computed gradients.\n * @param variableGradients A mapping of variable name to its gradient value.\n */\n abstract applyGradients(variableGradients: NamedTensorMap): void;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\n\nconst DEFAULT_FLOAT32_EPSILON = 1e-8;\nconst DEFAULT_FLOAT16_EPSILON = 1e-4;\n\nexport function getOptimizerDefaultEpsilonValue() {\n if (ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return DEFAULT_FLOAT32_EPSILON;\n }\n\n return DEFAULT_FLOAT16_EPSILON;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdadeltaOptimizer extends Optimizer {\n static className = 'AdadeltaOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private rhoScalar: Scalar;\n private oneMinusRho: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n private accumulatedUpdates: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected rho: number,\n protected epsilon: number = null) {\n super();\n\n this.c = keep(scalar(-learningRate));\n this.rhoScalar = keep(scalar(rho));\n this.oneMinusRho = keep(scalar(1 - rho));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedUpdates[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedUpdates[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n const accumulatedUpdate = this.accumulatedUpdates[variableName];\n\n tidy(() => {\n const newAccumulatedGrad =\n this.rhoScalar.mul(accumulatedGrad)\n .add(this.oneMinusRho.mul(gradient.square()));\n\n const updates = accumulatedUpdate.add(this.epsilonScalar)\n .sqrt()\n .div(accumulatedGrad.add(this.epsilonScalar).sqrt())\n .mul(gradient);\n\n const newAccumulatedUpdate =\n this.rhoScalar.mul(accumulatedUpdate)\n .add(this.oneMinusRho.mul(updates.square()));\n\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n this.accumulatedUpdates[variableName].assign(newAccumulatedUpdate);\n\n const newValue = this.c.mul(updates).add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.rhoScalar.dispose();\n this.oneMinusRho.dispose();\n if (this.accumulatedUpdates != null) {\n Object.keys(this.accumulatedUpdates)\n .forEach(name => this.accumulatedUpdates[name].dispose());\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n rho: this.rho,\n epsilon: this.epsilon\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.rho, config.epsilon);\n }\n}\nSerializationMap.register(AdadeltaOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {fill, scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdagradOptimizer extends Optimizer {\n static className = 'AdagradOptimizer';\n private c: Scalar;\n private epsilon: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, private initialAccumulatorValue = 0.1) {\n super();\n this.c = keep(scalar(-learningRate));\n\n const epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n this.epsilon = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n fill(value.shape, this.initialAccumulatorValue)\n .variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n\n tidy(() => {\n const newAccumulatedGrad = accumulatedGrad.add(gradient.square());\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n\n const newValue =\n this.c\n .mul(gradient.div(newAccumulatedGrad.add(this.epsilon).sqrt()))\n .add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.epsilon.dispose();\n this.c.dispose();\n if (this.accumulatedGrads != null) {\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n initialAccumulatorValue: this.initialAccumulatorValue,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.initialAccumulatorValue);\n }\n}\nSerializationMap.register(AdagradOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamOptimizer extends Optimizer {\n static className = 'AdamOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private accBeta1: Variable;\n private accBeta2: Variable;\n private oneMinusBeta1: Scalar;\n private oneMinusBeta2: Scalar;\n private one: Scalar;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedSecondMoment: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null) {\n super();\n this.c = keep(scalar(-learningRate));\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n tidy(() => {\n // accB* will be updated by batch.\n this.accBeta1 = scalar(beta1).variable();\n this.accBeta2 = scalar(beta2).variable();\n });\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.oneMinusBeta2 = keep(scalar(1 - beta2));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const oneMinusAccBeta2 = this.one.sub(this.accBeta2);\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedSecondMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedSecondMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const secondMoment = this.accumulatedSecondMoment[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n const newSecondMoment =\n this.beta2Scalar.mul(secondMoment)\n .add(this.oneMinusBeta2.mul(gradient.square()));\n\n const biasCorrectedFirstMoment = newFirstMoment.div(oneMinusAccBeta1);\n const biasCorrectedSecondMoment = newSecondMoment.div(oneMinusAccBeta2);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedSecondMoment[variableName].assign(newSecondMoment);\n\n const newValue =\n this.c\n .mul(biasCorrectedFirstMoment.div(\n this.epsScalar.add(biasCorrectedSecondMoment.sqrt())))\n .add(value);\n value.assign(newValue);\n }\n\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n this.accBeta2.assign(this.accBeta2.mul(this.beta2Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.accBeta1.dispose();\n this.accBeta2.dispose();\n this.oneMinusBeta1.dispose();\n this.oneMinusBeta2.dispose();\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedSecondMoment != null) {\n Object.keys(this.accumulatedSecondMoment)\n .forEach(name => this.accumulatedSecondMoment[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon);\n }\n}\nSerializationMap.register(AdamOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamaxOptimizer extends Optimizer {\n static className = 'AdamaxOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private accBeta1: Variable;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private decayScalar: Scalar;\n private oneMinusBeta1: Scalar;\n private one: Scalar;\n private iteration: Variable;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedWeightedInfNorm: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null,\n protected decay = 0.0) {\n super();\n this.c = keep(scalar(-learningRate));\n\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n\n this.decayScalar = keep(scalar(decay));\n\n tidy(() => {\n this.iteration = scalar(0).variable();\n this.accBeta1 = scalar(beta1).variable();\n });\n\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const lr = this.c.div(this.one.add(this.decayScalar.mul(this.iteration)));\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedWeightedInfNorm[variableName] == null) {\n const trainable = false;\n this.accumulatedWeightedInfNorm[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const weightedInfNorm = this.accumulatedWeightedInfNorm[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n\n const ut0 = this.beta2Scalar.mul(weightedInfNorm);\n const ut1 = gradient.abs();\n\n const newWeightedInfNorm = ut0.maximum(ut1);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedWeightedInfNorm[variableName].assign(\n newWeightedInfNorm);\n\n const newValue =\n lr.div(oneMinusAccBeta1)\n .mul(newFirstMoment.div(this.epsScalar.add(newWeightedInfNorm)))\n .add(value);\n\n value.assign(newValue);\n }\n\n this.iteration.assign(this.iteration.add(this.one));\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.accBeta1.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.oneMinusBeta1.dispose();\n\n this.decayScalar.dispose();\n this.iteration.dispose();\n\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedWeightedInfNorm != null) {\n Object.keys(this.accumulatedWeightedInfNorm)\n .forEach(name => this.accumulatedWeightedInfNorm[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n decay: this.decay\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon,\n config.decay);\n }\n}\nSerializationMap.register(AdamaxOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\n\n/** @doclink Optimizer */\nexport class SGDOptimizer extends Optimizer {\n static className = 'SGDOptimizer';\n protected c: Scalar;\n\n constructor(protected learningRate: number) {\n super();\n this.setLearningRate(learningRate);\n }\n\n applyGradients(variableGradients: NamedTensorMap) {\n const varNames = Object.keys(variableGradients);\n varNames.forEach(varName => {\n const gradient = variableGradients[varName];\n const value = ENV.engine.registeredVariables[varName];\n\n tidy(() => {\n const newValue = this.c.mul(gradient).add(value);\n value.assign(newValue);\n });\n });\n }\n\n /**\n * Sets the learning rate of the optimizer.\n */\n setLearningRate(learningRate: number) {\n this.learningRate = learningRate;\n if (this.c != null) {\n this.c.dispose();\n }\n this.c = keep(scalar(-learningRate));\n }\n\n dispose() {\n this.c.dispose();\n }\n\n getConfig(): ConfigDict {\n return {learningRate: this.learningRate};\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate);\n }\n}\nSerializationMap.register(SGDOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Tensor} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {SGDOptimizer} from './sgd_optimizer';\n\n/** @doclink Optimizer */\nexport class MomentumOptimizer extends SGDOptimizer {\n static className = 'MomentumOptimizer';\n private m: Scalar;\n private accumulations: NamedVariableMap;\n\n constructor(\n protected learningRate: number, private momentum: number,\n private useNesterov = false) {\n super(learningRate);\n this.m = scalar(this.momentum);\n this.accumulations = {};\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulations[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulations[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulation = this.accumulations[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n let newValue: Tensor;\n const newAccumulation = this.m.mul(accumulation).add(gradient);\n if (this.useNesterov) {\n newValue =\n this.c.mul(gradient.add(newAccumulation.mul(this.m))).add(value);\n } else {\n newValue = this.c.mul(newAccumulation).add(value);\n }\n this.accumulations[variableName].assign(newAccumulation);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n super.dispose();\n this.m.dispose();\n if (this.accumulations != null) {\n for (const variableName in this.accumulations) {\n this.accumulations[variableName].dispose();\n }\n }\n }\n\n /**\n * Sets the momentum of the optimizer.\n *\n * @param momentum\n */\n setMomentum(momentum: number) {\n this.momentum = momentum;\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n momentum: this.momentum,\n useNesterov: this.useNesterov\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.momentum, config.useNesterov);\n }\n}\nSerializationMap.register(MomentumOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class RMSPropOptimizer extends Optimizer {\n static className = 'RMSPropOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private decayScalar: Scalar;\n private momentumScalar: Scalar;\n private oneMinusDecay: Scalar;\n private centered: boolean;\n\n private accumulatedMeanSquares: NamedVariableMap = {};\n private accumulatedMeanGrads: NamedVariableMap = {};\n private accumulatedMoments: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected decay = 0.9,\n protected momentum = 0.0, protected epsilon: number = null,\n centered = false) {\n super();\n\n this.c = keep(scalar(learningRate));\n this.decayScalar = keep(scalar(decay));\n this.momentumScalar = keep(scalar(momentum));\n this.oneMinusDecay = keep(scalar(1 - decay));\n this.centered = centered;\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedMeanSquares[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanSquares[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMeanGrads[variableName] == null && this.centered) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMoments[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMoments[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulatedMeanSquare = this.accumulatedMeanSquares[variableName];\n const accumulatedMeanGrad = this.accumulatedMeanGrads[variableName];\n const accumulatedMoments = this.accumulatedMoments[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n if (this.centered) {\n // Centered gradient\n const newAccumulatedMeanGrad =\n this.decayScalar.mul(accumulatedMeanGrad)\n .add(this.oneMinusDecay.mul(gradient));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare\n .sub(newAccumulatedMeanGrad.square().add(\n this.epsilonScalar))\n .sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMeanGrads[variableName].assign(\n newAccumulatedMeanGrad);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n } else {\n // Plain gradient\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare.add(this.epsilonScalar).sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n }\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.decayScalar.dispose();\n this.momentumScalar.dispose();\n this.oneMinusDecay.dispose();\n if (this.accumulatedMeanSquares != null) {\n Object.keys(this.accumulatedMeanSquares)\n .forEach(name => this.accumulatedMeanSquares[name].dispose());\n }\n if (this.accumulatedMeanGrads != null && this.centered) {\n Object.keys(this.accumulatedMeanGrads)\n .forEach(name => this.accumulatedMeanGrads[name].dispose());\n }\n if (this.accumulatedMoments != null) {\n Object.keys(this.accumulatedMoments)\n .forEach(name => this.accumulatedMoments[name].dispose());\n }\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n decay: this.decay,\n momentum: this.momentum,\n epsilon: this.epsilon,\n centered: this.centered\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.decay, config.momentum, config.epsilon,\n config.centered);\n }\n}\nSerializationMap.register(RMSPropOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {AdadeltaOptimizer} from './adadelta_optimizer';\nimport {AdagradOptimizer} from './adagrad_optimizer';\nimport {AdamOptimizer} from './adam_optimizer';\nimport {AdamaxOptimizer} from './adamax_optimizer';\nimport {MomentumOptimizer} from './momentum_optimizer';\nimport {RMSPropOptimizer} from './rmsprop_optimizer';\nimport {SGDOptimizer} from './sgd_optimizer';\n\nexport class OptimizerConstructors {\n /**\n * Constructs a `SGDOptimizer` that uses stochastic gradient descent.\n *\n * ```js\n * // Fit a quadratic function by learning the coefficients a, b, c.\n * const xs = tf.tensor1d([0, 1, 2, 3]);\n * const ys = tf.tensor1d([1.1, 5.9, 16.8, 33.9]);\n *\n * const a = tf.scalar(Math.random()).variable();\n * const b = tf.scalar(Math.random()).variable();\n * const c = tf.scalar(Math.random()).variable();\n *\n * // y = a * x^2 + b * x + c.\n * const f = x => a.mul(x.square()).add(b.mul(x)).add(c);\n * const loss = (pred, label) => pred.sub(label).square().mean();\n *\n * const learningRate = 0.01;\n * const optimizer = tf.train.sgd(learningRate);\n *\n * // Train the model.\n * for (let i = 0; i < 10; i++) {\n * optimizer.minimize(() => loss(f(xs), ys));\n * }\n *\n * // Make predictions.\n * console.log(\n * `a: ${a.dataSync()}, b: ${b.dataSync()}, c: ${c.dataSync()}`);\n * const preds = f(xs).dataSync();\n * preds.forEach((pred, i) => {\n * console.log(`x: ${i}, pred: ${pred}`);\n * });\n * ```\n *\n * @param learningRate The learning rate to use for the SGD algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static sgd(learningRate: number): SGDOptimizer {\n return new SGDOptimizer(learningRate);\n }\n\n /**\n * Constructs a `MomentumOptimizer` that uses momentum gradient\n * descent.\n *\n * See\n * [http://proceedings.mlr.press/v28/sutskever13.pdf](\n * http://proceedings.mlr.press/v28/sutskever13.pdf)\n *\n * @param learningRate The learning rate to use for the Momentum gradient\n * descent algorithm.\n * @param momentum The momentum to use for the momentum gradient descent\n * algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static momentum(learningRate: number, momentum: number, useNesterov = false):\n MomentumOptimizer {\n return new MomentumOptimizer(learningRate, momentum, useNesterov);\n }\n\n /**\n * Constructs a `RMSPropOptimizer` that uses RMSProp gradient\n * descent. This implementation uses plain momentum and is not centered\n * version of RMSProp.\n *\n * See\n * [http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf](\n * http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf)\n *\n * @param learningRate The learning rate to use for the RMSProp gradient\n * descent algorithm.\n * @param decay The discounting factor for the history/coming gradient.\n * @param momentum The momentum to use for the RMSProp gradient descent\n * algorithm.\n * @param epsilon Small value to avoid zero denominator.\n * @param centered If true, gradients are normalized by the estimated\n * variance of the gradient.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static rmsprop(\n learningRate: number, decay = .9, momentum = 0.0, epsilon: number = null,\n centered = false): RMSPropOptimizer {\n return new RMSPropOptimizer(\n learningRate, decay, momentum, epsilon, centered);\n }\n\n /**\n * Constructs a `AdamOptimizer` that uses the Adam algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adam gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adam(\n learningRate = 0.001, beta1 = 0.9, beta2 = 0.999,\n epsilon: number = null): AdamOptimizer {\n return new AdamOptimizer(learningRate, beta1, beta2, epsilon);\n }\n\n /**\n * Constructs a `AdadeltaOptimizer` that uses the Adadelta algorithm.\n * See [https://arxiv.org/abs/1212.5701](https://arxiv.org/abs/1212.5701)\n *\n * @param learningRate The learning rate to use for the Adadelta gradient\n * descent algorithm.\n * @param rho The learning rate decay over each update.\n * @param epsilon A constant epsilon used to better condition the grad\n * update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adadelta(learningRate = .001, rho = .95, epsilon: number = null):\n AdadeltaOptimizer {\n return new AdadeltaOptimizer(learningRate, rho, epsilon);\n }\n\n /**\n * Constructs a `AdamaxOptimizer` that uses the Adamax algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adamax gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n * @param decay The learning rate decay over each update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adamax(\n learningRate = 0.002, beta1 = 0.9, beta2 = 0.999, epsilon: number = null,\n decay = 0.0): AdamaxOptimizer {\n return new AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay);\n }\n\n /**\n * Constructs a `AdagradOptimizer` that uses the Adagrad algorithm.\n * See\n * [http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf](\n * http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf)\n * or\n * [http://ruder.io/optimizing-gradient-descent/index.html#adagrad](\n * http://ruder.io/optimizing-gradient-descent/index.html#adagrad)\n *\n * @param learningRate The learning rate to use for the Adagrad gradient\n * descent algorithm.\n * @param initialAccumulatorValue Starting value for the accumulators, must be\n * positive.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adagrad(learningRate: number, initialAccumulatorValue = 0.1):\n AdagradOptimizer {\n return new AdagradOptimizer(learningRate, initialAccumulatorValue);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// So typings can propagate.\nimport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nimport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nimport {AdamOptimizer} from './optimizers/adam_optimizer';\nimport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nimport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nimport {OptimizerConstructors} from './optimizers/optimizer_constructors';\nimport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nimport {SGDOptimizer} from './optimizers/sgd_optimizer';\n\n// tslint:disable-next-line:no-unused-expression\n[MomentumOptimizer, SGDOptimizer, AdadeltaOptimizer, AdagradOptimizer,\n RMSPropOptimizer, AdamaxOptimizer, AdamOptimizer];\n\nexport const train = {\n sgd: OptimizerConstructors.sgd,\n momentum: OptimizerConstructors.momentum,\n adadelta: OptimizerConstructors.adadelta,\n adagrad: OptimizerConstructors.adagrad,\n rmsprop: OptimizerConstructors.rmsprop,\n adamax: OptimizerConstructors.adamax,\n adam: OptimizerConstructors.adam\n};\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// backend_cpu.ts and backend_webgl.ts are standalone files and should be\n// explicily included here. Below, there is an export from backend_webgl, but\n// that doesn't count since it's exporting a Typescript interface.\nimport './kernels/backend_webgl';\nimport './kernels/backend_cpu';\n\nimport {nextFrame} from './browser_util';\nimport * as environment from './environment';\nimport {Environment} from './environment';\n\n// Serialization.\nimport * as io from './io/io';\nimport * as serialization from './serialization';\nimport {setOpHandler} from './tensor';\nimport * as test_util from './test_util';\nimport * as util from './util';\nimport {version} from './version';\nimport * as webgl from './webgl';\n\nexport {InferenceModel, ModelPredictConfig} from './model_types';\n\n// Optimizers.\nexport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nexport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nexport {AdamOptimizer} from './optimizers/adam_optimizer';\nexport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nexport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nexport {Optimizer} from './optimizers/optimizer';\nexport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nexport {SGDOptimizer} from './optimizers/sgd_optimizer';\nexport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer, variable, Variable} from './tensor';\nexport {NamedTensorMap} from './tensor_types';\nexport {DataType, Rank, ShapeMap} from './types';\n\nexport * from './ops/ops';\nexport {LSTMCellFunc} from './ops/lstm';\nexport {Reduction} from './ops/loss_ops';\n\nexport * from './train';\nexport * from './globals';\n\nexport {Features} from './environment_util';\nexport {TimingInfo} from './engine';\nexport {ENV, Environment} from './environment';\n\nexport const setBackend = Environment.setBackend;\nexport const getBackend = Environment.getBackend;\nexport const disposeVariables = Environment.disposeVariables;\nexport const memory = Environment.memory;\nexport {version as version_core};\n\nexport {nextFrame};\n\n// Second level exports.\nexport {environment, io, serialization, test_util, util, webgl};\n\n// Backend specific.\nexport {KernelBackend, BackendTimingInfo} from './kernels/backend';\n\nimport * as ops from './ops/ops';\nsetOpHandler(ops);\n"],"names":["util.checkComputationForNaN","util.rightPad","util.arraysEqual","util.sizeFromShape","util.assert","util.getTypedArrayFromDType","tslib_1.__extends","util.bytesPerElement","util.isFunction","device_util.isMobile","util.isInt","util.clamp","util.assertShapesMatch","variable","ones","Rank","broadcast_util.assertAndGetBroadcastShape","concat_util.computeOutShape","broadcast_util.getBroadcastDims","broadcast_util.broadcastDimsAreOuter","util.squeezeShape","util.sizeToSquarishShape","webgl_util.createWebGLRenderingContextFromCanvas","webgl_util.createWebGLRenderingContext","webgl_util.callAndCheck","webgl_util.createVertexShader","webgl_util.createStaticVertexBuffer","webgl_util.createStaticIndexBuffer","webgl_util.validateTextureSize","webgl_util.createTexture","webgl_util.bindVertexBufferToProgramAttribute","tex_util.getUnpackedArraySizeFromMatrixSize","tex_util.encodeMatrixToUnpackedArray","tex_util.getPackedRGBAArraySizeFromMatrixShape","tex_util.encodeMatrixToPackedRGBA","tex_util.decodeMatrixFromUnpackedArray","tex_util.decodeMatrixFromPackedRGBA","gpgpu_util.createWebGLContext","webgl_util.getExtensionOrThrow","gpgpu_util.createVertexBuffer","gpgpu_util.createIndexBuffer","webgl_util.createFramebuffer","gpgpu_util.getTextureConfig","webgl_util.enableDebugWebGLErrorChecking","gpgpu_util.createFloat32MatrixTexture","gpgpu_util.createFloat16MatrixTexture","gpgpu_util.createUnsignedBytesMatrixTexture","gpgpu_util.uploadPixelDataToTexture","gpgpu_util.createPackedMatrixTexture","webgl_util.unbindColorTextureFromFramebuffer","webgl_util.getNumChannels","gpgpu_util.uploadMatrixToTexture","gpgpu_util.uploadMatrixToPackedTexture","gpgpu_util.downloadFloat32MatrixFromOutputTexture","gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture","gpgpu_util.downloadFloat32MatrixFromBuffer","gpgpu_util.maybeCreateBufferFromOutputTexture","gpgpu_util.downloadMatrixFromPackedOutputTexture","webgl_util.createFragmentShader","gpgpu_util.createVertexShader","webgl_util.createProgram","webgl_util.linkProgram","webgl_util.validateProgram","gpgpu_util.bindVertexProgramAttributeStreams","webgl_util.getProgramUniformLocationOrThrow","webgl_util.getProgramUniformLocation","webgl_util.bindTextureToProgramUniformSampler","webgl_util.validateFramebuffer","util.repeatedTry","webgl_util.bindColorTextureToFramebuffer","shader_compiler.makeShader","getCoords","getSourceCoords","CHECK_NAN_SNIPPET","selu_util.SELU_SCALEALPHA","selu_util.SELU_SCALE","erf_util.ERF_P","erf_util.ERF_A1","erf_util.ERF_A2","erf_util.ERF_A3","erf_util.ERF_A4","erf_util.ERF_A5","concat_util.assertParams","this","define","sr","seedrandom.alea","util.randUniform","util.inferFromImplicitShape","util.flatten","unary_op.NEG","binaryop_gpu.MUL","array_ops_util.getReshaped","array_ops_util.getPermuted","array_ops_util.getReshapedPermuted","array_ops_util.getSliceBeginCoords","array_ops_util.getSliceSize","reduce_util.computeOptimalWindowSize","axis_util.assertAxesAreInnerMostDims","axis_util.getAxesPermutation","axis_util.getInnerMostAxes","segment_util.computeOutShape","axis_util.getUndoAxesPermutation","segment_util.segOpComputeOptimalWindowSize","binaryop_gpu.EQUAL","binaryop_gpu.NOT_EQUAL","binaryop_gpu.LESS","binaryop_gpu.LESS_EQUAL","binaryop_gpu.GREATER","binaryop_gpu.GREATER_EQUAL","unary_op.LOGICAL_NOT","binaryop_gpu.LOGICAL_AND","binaryop_gpu.LOGICAL_OR","binaryop_gpu.MIN","binaryop_gpu.MOD","binaryop_gpu.MAX","binaryop_gpu.SQUARED_DIFFERENCE","binaryop_gpu.DIV","binaryop_gpu.INT_DIV","binaryop_gpu.ADD","binaryop_gpu.SUB","binaryop_gpu.POW","unary_op.CEIL","unary_op.FLOOR","unary_op.SIGN","unary_op.ROUND","unary_op.EXP","unary_op.EXPM1","unary_op.LOG","unary_op.LOG1P","unary_op.SQRT","unary_op.RSQRT","unary_op.SQUARE","unary_op.RECIPROCAL","unary_op.RELU","unary_op.ELU","binaryop_gpu.ELU_DER","unary_op.SELU","unary_op.TO_INT","unary_op.ABS","unary_op.SIGMOID","unary_op.SOFTPLUS","unary_op.SIN","unary_op.COS","unary_op.TAN","unary_op.ASIN","unary_op.ACOS","unary_op.ATAN","binaryop_gpu.ATAN2","unary_op.SINH","unary_op.COSH","unary_op.TANH","unary_op.ASINH","unary_op.ACOSH","unary_op.ATANH","unary_op.ERF","unary_op.STEP","backend_util.castTensor","backend_util.reshapeTensor","tensor","gpgpu_math.makeShaderKey","gpgpu_math.compileProgram","gpgpu_math.runProgram","webgl_util.getTextureShapeFromLogicalShape","log","tanh","conv_util.computeConv2DInfo","conv_util.computePool2DInfo","slice_util.assertParamsValid","axis_util.parseAxisParam","axis_util.expandShapeToKeepDim","axis_util.computeOutAndReduceShapes","broadcast_util.getReductionAxes","exp","Reduction","buffer","ops.buffer","ops.tensor","ops.scalar","sum","ops.tensor2d","op","ops.zeros","ops.equal","ops.stack","min","max","reverse","all","util.tanh","mean","norm","ops.softmax","maybeStripScheme","grads","optimizer_utils.getOptimizerDefaultEpsilonValue"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js b/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js new file mode 100644 index 0000000..f7c3416 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js @@ -0,0 +1,18 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e(t.tf=t.tf||{})}(this,function(t){"use strict";var e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])};function n(t,n){function r(){this.constructor=t}e(t,n),t.prototype=null===n?Object.create(n):(r.prototype=n.prototype,new r)}var r=Object.assign||function(t){for(var e,n=1,r=arguments.length;n0&&o[o.length-1])&&(6===a[0]||2===a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]0;)r=Math.random()*e|0,n=t[--e],t[e]=t[r],t[r]=n}function u(t,e,n){return Math.max(t,Math.min(e,n))}function s(t,e){return Math.random()*(e-t)+t}function l(t,e){if(!t)throw new Error("string"==typeof e?e:e())}function c(t,e,n){void 0===n&&(n=""),l(v(t,e),n+" Shapes "+t+" and "+e+" must match")}function h(t){l(null!=t,"The input to the tensor constructor must be a non-null value.")}function f(t,e){if(void 0===e&&(e=[]),Array.isArray(t))for(var n=0;n0,function(){return"Element arr["+r.join("][")+"] should be a primitive, but is an array of "+e.length+" elements"});l(e.length===n[0],function(){return"Element arr["+r.join("][")+"] should have "+n[0]+" elements, but has "+e.length+" elements"});var o=n.slice(1);for(var a=0;a1;--e)if(t%e==0)return[e,t/e];return[1,t]}function x(t,e){return e<=t.length?t:t+" ".repeat(e-t.length)}function b(t,e,n){return void 0===e&&(e=function(t){return 0}),new Promise(function(r,o){var a=0,i=function(){if(t())r();else{var u=e(++a);null!=n&&a>=n?o():setTimeout(i,u)}};i()})}function w(t,e){for(var n=1,r=-1,o=0;o0)n*=t[o];else if(-1===t[o]){if(-1!==r)throw Error("Shapes can only have 1 implicit size. Found - 1 at dim "+r+" and dim "+o);r=o}else if(t[o]<=0)throw Error("Shapes can not be <= 0. Found "+t[o]+" at dim "+o);if(-1===r){if(e>0&&e!==n)throw Error("Size("+e+") must match the product of shape "+t);return t}if(e%n!=0)throw Error("The implicit shape can't be a fractional number. Got "+e+" / "+n);var a=t.slice();return a[r]=e/n,a}function E(t,e){for(var n=[],r=[],o=0,a=0;a1)throw new Error("Can't squeeze axis "+a+" since its dim '"+t[a]+"' is not 1");(null==e[o]||e[o]>a)&&1===t[a]&&(n.push(t[a]),r.push(a)),e[o]<=a&&o++}t[a]>1&&(n.push(t[a]),r.push(a))}return{newShape:n,keptDims:r}}function S(t,e){var n=null;if(null==t||"float32"===t)n=new Float32Array(e);else if("int32"===t)n=new Int32Array(e);else{if("bool"!==t)throw new Error("Unknown data type "+t);n=new Uint8Array(e)}return n}function R(t,e,n){if("float32"===e)for(var r=0;r=0;--r)n[r]=n[r+1]*t[r+1];return n}function M(t,e,n){return function(t,e){return t instanceof Float32Array&&"float32"===e||t instanceof Int32Array&&"int32"===e||t instanceof Uint8Array&&"bool"===e}(t,e)?t:(Array.isArray(t)&&(t=f(t)),function(t,e,n){if(null==e||"float32"===e)return new Float32Array(t);if("int32"===e)return n&&C(t,e),new Int32Array(t);if("bool"===e){for(var r=new Uint8Array(t.length),o=0;o1)for(var i=0;iU){var s=Array.from(e.subarray(0,z)),l=Array.from(e.subarray(i-z,i));return["["+s.map(function(t,e){return G(t,o[e])}).join(", ")+", ..., "+l.map(function(t,e){return G(t,o[i-z+e])}).join(", ")+"]"]}return["["+Array.from(e).map(function(t,e){return G(t,o[e])}).join(", ")+"]"]}var c=n.slice(1);var h=r.slice(1);var f=r[0];var p=[];if(i>U){for(var d=0;d {...}) to avoid memory leaks.");return this.keepTensors.add(t.id),t},t.prototype.startScope=function(t,e){void 0===e&&(e=!1),e&&0===this.gradientScopeCount&&(this.activeTape=[]),e&&this.gradientScopeCount++;var n={track:[],name:"unnamed scope"};t&&(n.name=t),this.scopeStack.push(n),this.activeScope=n},t.prototype.endScope=function(t,e){var n=this;void 0===e&&(e=!1),e&&(this.gradientScopeCount--,0===this.gradientScopeCount&&(this.activeTape=null));var r=new Set(this.keepTensors),o=J(t);o.forEach(function(t){return r.add(t.id)});for(var a=0;a0,"gradients() received an empty list of xs."),this.tidy("gradients",function(){var a=t();l(a instanceof X,"The result y returned by f() must be a tensor.");var i=function(t,e,n){for(var r={},o={},a=0;a=0;a--){i=(v=t[a]).inputs;var p=[];for(p.push(v.output),c=0;c0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");var u,s,c={};return c[a.id]=null==n?(u=a.shape,s=_(d(u),"float32"),X.make(u,{values:s})):n,function(t,e){for(var n=e.length-1;n>=0;n--){var r=e[n],o=t[r.output.id];if(null==r.gradient)throw new Error("Cannot compute gradient: gradient function not found for "+r.name+".");var a=r.gradient(o);for(var i in r.inputs){if(!(i in a))throw new Error("Cannot backprop through input "+i+". Available gradients found: "+Object.keys(a)+".");var u=a[i](),s=r.inputs[i];if(!v(u.shape,s.shape))throw new Error("Error in gradient for op "+r.name+". The gradient of input '"+i+"' has shape '"+u.shape+"', which does not match the shape of the input '"+s.shape+"'");if(null==t[s.id])t[s.id]=u;else{var l=t[s.id];t[s.id]=l.add(u),l.dispose()}}}}(c,i),{value:a,grads:e.map(function(t){return c[t.id]})}},!0)},t.prototype.customGrad=function(t){var e=this;return l(A(t),"The f passed in customGrad(f) must be a function."),function(){for(var n,r,o=[],a=0;a {op();...}); to avoid memory leaks.");return this.activeScope.track.push(t),t},t}();!function(t){t[t.NUMBER=0]="NUMBER",t[t.BOOLEAN=1]="BOOLEAN",t[t.STRING=2]="STRING"}(Z||(Z={}));var et=[{name:"DEBUG",type:Z.BOOLEAN},{name:"IS_BROWSER",type:Z.BOOLEAN},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",type:Z.NUMBER},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",type:Z.BOOLEAN},{name:"WEBGL_VERSION",type:Z.NUMBER},{name:"WEBGL_RENDER_FLOAT32_ENABLED",type:Z.BOOLEAN},{name:"WEBGL_DOWNLOAD_FLOAT_ENABLED",type:Z.BOOLEAN},{name:"WEBGL_FENCE_API_ENABLED",type:Z.BOOLEAN},{name:"BACKEND",type:Z.STRING}];function nt(t,e){var n;try{n=it(t,e)}catch(t){return!1}return null!=n&&(ut(n),!0)}var rt="tfjsflags";function ot(){var t={};if("undefined"==typeof window||void 0===window.location)return t;var e,n,r=(e=window.location.search,n={},e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,function(t){for(var e=[],r=1;r0?0:function(t,e){if(0===t)return 0;var n,r=it(t,e);return n=at(r,"EXT_disjoint_timer_query_webgl2")&&2===t?2:at(r,"EXT_disjoint_timer_query")?1:0,null!=r&&ut(r),n}(e,this.get("IS_BROWSER"))}if("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE"===t)return this.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&(n=navigator.userAgent||navigator.vendor||window.opera,!(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(n)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(n.substr(0,4))));if("HAS_WEBGL"===t)return this.get("WEBGL_VERSION")>0;if("WEBGL_VERSION"===t)return nt(2,this.get("IS_BROWSER"))?2:nt(1,this.get("IS_BROWSER"))?1:0;if("WEBGL_RENDER_FLOAT32_ENABLED"===t)return function(t,e){if(0===t)return!1;var n=it(t,e);if(1===t){if(!at(n,"OES_texture_float"))return!1}else if(!at(n,"EXT_color_buffer_float"))return!1;st(n,t);var r=n.checkFramebufferStatus(n.FRAMEBUFFER)===n.FRAMEBUFFER_COMPLETE;return ut(n),r}(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_DOWNLOAD_FLOAT_ENABLED"===t)return function(t,e){if(0===t)return!1;var n=it(t,e);if(1===t){if(!at(n,"OES_texture_float"))return!1}else if(!at(n,"EXT_color_buffer_float"))return!1;st(n,t),n.readPixels(0,0,1,1,n.RGBA,n.FLOAT,new Float32Array(4));var r=n.getError()===n.NO_ERROR;return ut(n),r}(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_FENCE_API_ENABLED"===t)return function(t,e){if(2!==t)return!1;var n=it(t,e),r=null!=n.fenceSync;return ut(n),r}(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("TEST_EPSILON"===t)return this.get("WEBGL_RENDER_FLOAT32_ENABLED")?.001:.1;var n;throw new Error("Unknown feature "+t+".")},t.prototype.setFeatures=function(t){this.features=Object.assign({},t)},t.prototype.reset=function(){this.features=ot(),null!=this.globalEngine&&(this.globalEngine=null)},t.prototype.initBackend=function(t,e){var n=this;void 0===e&&(e=!1),this.backendName=t,this.backend=this.findBackend(t),this.globalEngine=new tt(this.backend,e,function(){return n.get("DEBUG")})},t.prototype.findBackend=function(t){return t in this.registry?this.registry[t].backend:null},t.prototype.registerBackend=function(t,e,n,r){var o=this;if(void 0===n&&(n=1),t in this.registry)return console.warn(t+" backend was already registered. Reusing existing backend"),null!=r&&r(function(){return o.engine}),!1;try{var a=e();return this.registry[t]={backend:a,priority:n},!0}catch(e){return console.warn("Registration of backend "+t+" failed"),console.warn(e.stack||e.message),!1}},t.prototype.removeBackend=function(t){if(!(t in this.registry))throw new Error(t+" backend not found in registry");this.registry[t].backend.dispose(),delete this.registry[t]},Object.defineProperty(t.prototype,"engine",{get:function(){return this.initDefaultBackend(),this.globalEngine},enumerable:!0,configurable:!0}),t.prototype.initDefaultBackend=function(){null==this.globalEngine&&this.initBackend(this.get("BACKEND"),!1)},t}();var ct,ht=(null==(ct=function(){var t;if("undefined"!=typeof window)t=window;else{if("undefined"==typeof process)throw new Error("Could not find a global object");t=process}return t}()).ENV&&(ct.ENV=new lt(ot()),j(function(){return ct.ENV.engine})),ct.ENV),ft=Object.freeze({Environment:lt,ENV:ht});function pt(){for(var t=[],e=0;e=2*e+1||o%2==1?i.push(o):a.push(o);r.push.apply(r,a),r.push(0),r.push.apply(r,i)}return r}function mt(t,e,n,r){void 0===r&&(r=!0);var o=[];r?o.push(t[0]/n):o.push(t[0]*n);for(var a=1;a=-n&&t0?o>=u[e]:o<=u[e]);o+=r[e])n+=1;return n}),[i,l]}function Dt(t,e,n,r,o){var a=e[o];t&1<0?Number.MIN_SAFE_INTEGER:Number.MAX_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=u(0,a,i-1)}function Nt(t,e,n,r,o){var a=e[o];t&1<0?Number.MAX_SAFE_INTEGER:Number.MIN_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=n[o]>0?u(0,a,i):u(-1,a,i-1)}function Mt(t,e){if(l(A(t),"The f passed in variableGrads(f) must be a function"),l(null==e||Array.isArray(e)&&e.every(function(t){return t instanceof K}),"The varList passed in variableGrads(f, varList) must be an array of variables"),null==e)for(var n in e=[],ht.engine.registeredVariables)e.push(ht.engine.registeredVariables[n]);var r=e.length;l((e=e.filter(function(t){return t.trainable})).length>0,"variableGrads() expects at least one of the input variables to be trainable, but none of the "+r+" variables is trainable.");var o=ht.engine.gradients(t,e,null,!0),a=o.value,i=o.grads;l(i.some(function(t){return null!=t}),"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),l(0===a.rank,"The f passed in variableGrads(f) must return a scalar, but it returned a rank-"+a.rank+" tensor");var u={};return e.forEach(function(t,e){null!=i[e]&&(u[t.name]=i[e])}),{value:a,grads:u}}function _t(t){return ht.engine.customGrad(t)}function Ot(t){if(t.filter(function(t){return null==t}).length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.")}function Ft(t,e,n,r){if(void 0===r&&(r="float32"),r=r||"float32",t instanceof X)return t;if(!T(t)&&!Array.isArray(t)&&"number"!=typeof t&&"boolean"!=typeof t)throw new Error("Argument '"+e+"' passed to '"+n+"' must be a Tensor or TensorLike, but got "+t.constructor.name);var o=p(t);return T(t)||Array.isArray(t)||(t=[t]),X.make(o,{values:M(t,r,ht.get("DEBUG"))},r)}function Lt(t,e,n){if(!Array.isArray(t))throw new Error("Argument "+e+" passed to "+n+" must be a `Tensor[]` or `TensorLike[]`");return t.map(function(t,r){return Ft(t,e+"["+r+"]",n)})}function Bt(t){var e=Object.keys(t);if(1!==e.length)throw new Error("Please provide an object with a single key (operation name) mapping to a function. Got an object with "+e.length+" keys.");var n=e[0],r=t[n];n.endsWith("_")&&(n=n.substring(0,n.length-1));var o=function(){for(var t=[],e=0;e1)return Xt([0],r);var o=O(Math.abs(Math.ceil((e-t)/n)),r);eo}).sort(function(t,e){return e.score-t.score}),i=[],u=0;u=0;--f){if(he(t,c,i[f])>=r){h=!0;break}}if(!h&&(i.push(c),i.length>=n))break}return Vt(i,"int32")}function he(t,e,n){var r=t.subarray(4*e,4*e+4),o=t.subarray(4*n,4*n+4),a=Math.min(r[0],r[2]),i=Math.min(r[1],r[3]),u=Math.max(r[0],r[2]),s=Math.max(r[1],r[3]),l=Math.min(o[0],o[2]),c=Math.min(o[1],o[3]),h=Math.max(o[0],o[2]),f=Math.max(o[1],o[3]),p=(u-a)*(s-i),d=(h-l)*(f-c);if(p<=0||d<=0)return 0;var v=Math.max(a,l),m=Math.max(i,c),g=Math.min(u,h),y=Math.min(s,f),x=Math.max(g-v,0)*Math.max(y-m,0);return x/(p+d-x)}function fe(t,e,n,r,o){for(var a=e[e.length-1],i=[t.length/a,a],u=i[0],s=i[1],l=S(n,u*r),c=S("int32",u*r),h=0;h":"<",s=n?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+r+";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < "+r+"; i++) {\n int inIdx = "+s+";\n float candidate = getA(batch, inIdx);\n if (candidate "+u+" bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "}}(),de=function(){return function(t){this.variableNames=["dy"],this.outputShape=t.inShape;var e=t.filterHeight,n=t.filterWidth,r=t.strideHeight,o=t.strideWidth,a=e-1-t.padInfo.top,i=n-1-t.padInfo.left,u=1/(e*n);this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n const float avgMultiplier = float("+u+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+e+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+t.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+t.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "}}();function ve(t,e){for(var n=t.length,r=[],o=0;o1&&1===i&&r.unshift(a)}return r}function me(t,e){for(var n=[],r=0;r1)&&n.unshift(a)}return n}function ge(t,e){for(var n=[],r="Operands could not be broadcast together with shapes "+t+" and "+e+".",o=Math.max(t.length,e.length),a=0;a1&&u>1&&i!==u)throw Error(r);n.unshift(Math.max(i,u))}return n}var ye=function(){return function(t,e,n,r,o,a){this.outputShape=[],this.supportsBroadcasting=!0,this.variableNames=["x","mean","variance"],ge(t,e),ge(t,n);var i="0.0";null!=r&&(ge(t,r),this.variableNames.push("offset"),i="getOffsetAtOutCoords()");var u="1.0";null!=o&&(ge(t,o),this.variableNames.push("scale"),u="getScaleAtOutCoords()"),this.outputShape=t,this.userCode="\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = "+i+";\n float scale = "+u+";\n float inv = scale * inversesqrt(variance + float("+a+"));\n setOutput((x - mean) * inv + offset);\n }\n "}}(),xe=function(){function t(t,e,n){this.variableNames=["A","B"],this.supportsBroadcasting=!0,this.outputShape=ge(e,n),this.userCode="\n uniform float NAN;\n float binaryOperation(float a, float b) {\n "+t+"\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "}return t.prototype.getCustomSetupFunc=function(){var t=this;return function(e,n){null==t.startLoc&&(t.startLoc=e.getUniformLocationNoThrow(n,"NAN"),null==t.startLoc)||e.gl.uniform1f(t.startLoc,NaN)}},t}(),be=function(){return function(t,e,n){this.variableNames=["A"],this.outputShape=t;var r=e.toFixed(20),o=n.toFixed(20);this.userCode="\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, "+r+", "+o+"));\n }\n "}}();function we(t,e,n){l(t.length===e.length,"x1 and x2 should have the same rank.");var r=t.slice();return r[n]+=e[n],r}var Ee=function(){return function(t,e){this.variableNames=["A","B"],this.outputShape=[],this.outputShape=we(t,e,1),this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < "+t[1]+") {\n value = getA(yR, yC);\n } else {\n yC -= "+t[1]+";\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n "}}(),Se=function(){return function(t){this.variableNames=["x","dy"],this.outputShape=t.filterShape;var e=t.strideHeight,n=t.strideWidth,r=t.padInfo.top,o=t.padInfo.left;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < "+t.batchSize+"; b++) {\n for (int yR = 0; yR < "+t.outHeight+"; yR++) {\n int xR = wR + yR * "+e+" - "+r+";\n\n if (xR < 0 || xR >= "+t.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+t.outWidth+"; yC++) {\n int xC = wC + yC * "+n+" - "+o+";\n\n if (xC < 0 || xC >= "+t.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Re=function(){return function(t){this.variableNames=["dy","W"],this.outputShape=t.inShape;var e=t.filterHeight,n=t.filterWidth,r=t.strideHeight,o=t.strideWidth,a=e-1-t.padInfo.top,i=n-1-t.padInfo.left;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+e+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+t.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+e+" - 1 - wR;\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+t.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+n+" - 1 - wC;\n\n for (int d2 = 0; d2 < "+t.outChannels+"; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Ce=function(){return function(t){this.variableNames=["x","dy"],this.outputShape=t.filterShape;var e=t.strideHeight,n=t.strideWidth,r=t.padInfo.top,o=t.padInfo.left,a=t.outChannels/t.inChannels;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * "+a+" + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < "+t.batchSize+"; b++) {\n for (int yR = 0; yR < "+t.outHeight+"; yR++) {\n int xR = wR + yR * "+e+" - "+r+";\n\n if (xR < 0 || xR >= "+t.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+t.outWidth+"; yC++) {\n int xC = wC + yC * "+n+" - "+o+";\n\n if (xC < 0 || xC >= "+t.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),ke=function(){return function(t){this.variableNames=["dy","W"],this.outputShape=t.inShape;var e=t.filterHeight,n=t.filterWidth,r=t.strideHeight,o=t.strideWidth,a=e-1-t.padInfo.top,i=n-1-t.padInfo.left,u=t.outChannels/t.inChannels;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < "+e+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+t.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+e+" - 1 - wR;\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+t.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+n+" - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < "+u+"; dm++) {\n int d2 = d1 * "+u+" + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Te=function(){return function(t){this.variableNames=["x","W"],this.outputShape=t.outShape;var e=t.padInfo.top,n=t.padInfo.left,r=t.strideHeight,o=t.strideWidth,a=t.dilationHeight,i=t.dilationWidth,u=t.filterHeight,s=t.filterWidth,l=4*Math.floor(t.inChannels/4),c=t.inChannels%4;this.userCode="\n const ivec2 strides = ivec2("+r+", "+o+");\n const ivec2 pads = ivec2("+e+", "+n+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+u+"; wR++) {\n int xR = xRCorner + wR * "+a+";\n\n if (xR < 0 || xR >= "+t.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+s+"; wC++) {\n int xC = xCCorner + wC * "+i+";\n\n if (xC < 0 || xC >= "+t.inWidth+") {\n continue;\n }\n\n for (int d1 = 0; d1 < "+l+"; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if ("+(1===c)+") {\n dotProd +=\n getX(batch, xR, xC, "+l+") *\n getW(wR, wC, "+l+", d2);\n } else if ("+(2===c)+") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if ("+(3===c)+") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1),\n getX(batch, xR, xC, "+l+" + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2),\n getW(wR, wC, "+l+" + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "}}(),Ie=function(){return function(t){this.variableNames=["x","W"],this.outputShape=t.outShape;var e=t.inHeight,n=t.inWidth,r=t.padInfo.top,o=t.padInfo.left,a=t.strideHeight,i=t.strideWidth,u=t.dilationHeight,s=t.dilationWidth,l=t.filterHeight,c=t.filterWidth,h=t.outChannels/t.inChannels;this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+r+", "+o+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / "+h+";\n int q = d2 - d1 * "+h+";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < "+l+"; wR++) {\n int xR = xRCorner + wR * "+u+";\n\n if (xR < 0 || xR >= "+e+") {\n continue;\n }\n\n for (int wC = 0; wC < "+c+"; wC++) {\n int xC = xCCorner + wC * "+s+";\n\n if (xC < 0 || xC >= "+n+") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "}}();function Ae(t,e,n,r){var o=t.map(function(t){var e=d(t.shapeInfo.logicalShape);return t.shapeInfo.isUniform?"uniform float "+t.name+(e>1?"["+e+"]":"")+";":"uniform sampler2D "+t.name+";"});o=o.join("\n");var a=t.map(function(t){return function(t,e,n){var r=function(t){var e=t.name,n="get"+e.charAt(0).toUpperCase()+e.slice(1)+"Flat",r=d(t.shapeInfo.logicalShape);if(t.shapeInfo.isUniform)return 1===r?"float "+n+"(int index) {return "+e+";}":"\n float "+n+"(int index) {\n for (int i = 0; i < "+r+"; i++) {\n if (i == index) {\n return "+e+"[i];\n }\n }\n }\n ";var o=t.shapeInfo.texShape,a=o[0],i=o[1];if(1===i&&1===a)return"\n float "+n+"(int index) {\n return sampleTexture("+e+", halfCR);\n }\n ";if(1===i)return"\n float "+n+"(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / "+a+".0);\n return sampleTexture("+e+", uv);\n }\n ";if(1===a)return"\n float "+n+"(int index) {\n vec2 uv = vec2((float(index) + 0.5) / "+i+".0, 0.5);\n return sampleTexture("+e+", uv);\n }\n ";return"\n float "+n+"(int index) {\n vec2 uv = UVfrom1D("+a+", "+i+", index);\n return sampleTexture("+e+", uv);\n }\n "}(t);r+=De(t),(n||v(t.shapeInfo.logicalShape,e.logicalShape))&&(r+=function(t,e,n){var r=t.name,o=r.charAt(0).toUpperCase()+r.slice(1),a="get"+o+"AtOutCoords",i=ve(t.shapeInfo.logicalShape,e.logicalShape),u=t.shapeInfo.logicalShape.length,s=e.logicalShape.length,l=n&&(s>u||i.length>0),c=function(t){for(var e=0;e=1?"coords = 0;":s.map(function(t){return"coords["+(t+l)+"] = 0;"}).join("\n");var c="";c=a<2&&o>0?"coords":t.shapeInfo.logicalShape.map(function(t,e){return"coords["+(e+l)+"]"}).join(", ");return"\n float "+r+"() {\n "+i+" coords = getOutputCoords();\n "+u+"\n return get"+n+"("+c+");\n }\n "}(t,e,o,a);var f=d(t.shapeInfo.logicalShape),p="";l&&c&&(p="\n int mainPart = index / "+f+";\n index -= mainPart * "+f+";\n ");var m=e.texShape;if(h)return 1===f?"float "+a+"() {return "+r+";}":"\n float "+a+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+m[0]+", "+m[1]+"));\n int index = resTexRC.x * "+m[1]+" + resTexRC.y;\n "+p+"\n return get"+o+"Flat(index);\n }\n ";var g=t.shapeInfo.texShape;if(v(g,m))return"\n float "+a+"() {\n return sampleTexture("+r+", resultUV);\n }\n ";return"\n float "+a+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+m[0]+", "+m[1]+"));\n int index = resTexRC.x * "+m[1]+" + resTexRC.y;\n "+p+"\n int texR = index / "+g[1]+";\n int texC = index - texR * "+g[1]+";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2("+g[1]+".0, "+g[0]+".0);\n\n return sampleTexture("+r+", uv);\n }\n "}(t,e,n));return r}(t,e,r)}).join("\n"),i=e.texShape,u=function(t,e){switch(t.length){case 0:return"\n int getOutputCoords() {\n return 0;\n }\n ";case 1:return function(t,e){if(1===e[0])return"\n int getOutputCoords() {\n return int(resultUV.x * "+e[1]+".0);\n }\n ";if(1===e[1])return"\n int getOutputCoords() {\n return int(resultUV.y * "+e[0]+".0);\n }\n ";return"\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n return resTexRC.x * "+e[1]+" + resTexRC.y;\n }\n "}(0,e);case 2:return function(t,e){if(v(t,e))return"\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2("+e[0]+", "+e[1]+"));\n }\n ";if(1===t[1])return"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n return ivec2(index, 0);\n }\n ";if(1===t[0])return"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n return ivec2(0, index);\n }\n ";return"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n int r = index / "+t[1]+";\n int c = index - r * "+t[1]+";\n return ivec2(r, c);\n }\n "}(t,e);case 3:return r=e,o=(n=t)[1]*n[2],a=n[2],"\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+r[0]+", "+r[1]+"));\n int index = resTexRC.x * "+r[1]+" + resTexRC.y;\n int r = index / "+o+";\n index -= r * "+o+";\n int c = index / "+a+";\n int d = index - c * "+a+";\n return ivec3(r, c, d);\n }\n ";case 4:return function(t,e){var n=t[3],r=t[2]*n,o=t[1]*r;return"\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n\n int r = index / "+o+";\n index -= r * "+o+";\n\n int c = index / "+r+";\n index -= c * "+r+";\n\n int d = index / "+n+";\n int d2 = index - d * "+n+";\n\n return ivec4(r, c, d, d2);\n }\n "}(t,e);case 5:return function(t,e){var n=t[4],r=t[3]*n,o=t[2]*r,a=t[1]*o;return"\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2("+e[0]+",\n "+e[1]+"));\n\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n\n int r = index / "+a+";\n index -= r * "+a+";\n\n int c = index / "+o+";\n index -= c * "+o+";\n\n int d = index / "+r+";\n index -= d * "+r+";\n\n int d2 = index / "+n+";\n int d3 = index - d2 * "+n+";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "}(t,e);case 6:return function(t,e){var n=t[5],r=t[4]*n,o=t[3]*r,a=t[2]*o,i=t[1]*a;return"\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+e[0]+", "+e[1]+"));\n int index = resTexRC.x * "+e[1]+" + resTexRC.y;\n\n int r = index / "+i+";\n index -= r * "+i+";\n\n int c = index / "+a+";\n index -= c * "+a+";\n\n int d = index / "+o+";\n index -= d * "+o+";\n\n int d2 = index / "+r+";\n index -= d2 * "+r+";\n\n int d3 = index / "+n+";\n int d4 = index - d3 * "+n+";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "}(t,e);default:throw new Error(t.length+"-D output sampling is not yet supported")}var n,r,o,a}(e.logicalShape,i);return[_e,Ne,Me,o,u,a,n].join("\n")}function De(t){var e,n,r=t.shapeInfo.logicalShape;switch(r.length){case 0:return function(t){var e=t.name,n="get"+e.charAt(0).toUpperCase()+e.slice(1);if(t.shapeInfo.isUniform)return"float "+n+"() {return "+e+";}";return"\n float "+n+"() {\n return sampleTexture("+e+", halfCR);\n }\n "}(t);case 1:return e=t.name,"\n float "+(n="get"+e.charAt(0).toUpperCase()+e.slice(1))+"(int index) {\n return "+n+"Flat(index);\n }\n ";case 2:return function(t){var e=t.shapeInfo.logicalShape,n=t.name,r="get"+n.charAt(0).toUpperCase()+n.slice(1),o=t.shapeInfo.texShape;if(null!=o&&v(e,o)){var a=o[0],i=o[1];return"\n float "+r+"(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2("+i+".0, "+a+".0);\n return sampleTexture("+n+", uv);\n }\n "}var u=E(e),s=u.newShape,l=u.keptDims,c=s;if(c.length";this.userCode="\n int getIndex(int i) {\n "+(n?"return "+o+" -i - 1;":"return i;")+"\n }\n\n void main() {\n "+Oe(r)+" coords = getOutputCoords();\n int end = "+Pe(r,"coords")+";\n float val = 0.0;\n for (int i = "+o+" - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx "+a+" end) {\n continue;\n }\n if (idx == end && "+e+") {\n continue;\n }\n "+Pe(r,"coords")+" = idx;\n val += getX("+function(t,e){if(1===t)return""+e;if(2===t)return e+".x, "+e+".y";if(3===t)return e+".x, "+e+".y, "+e+".z";if(4===t)return e+".x, "+e+".y, "+e+".z, "+e+".w";throw Error("Cumulative sum for rank "+t+" is not yet supported")}(r,"coords")+");\n }\n setOutput(val);\n }\n "}}();function Pe(t,e){if(1===t)return""+e;if(2===t)return e+".y";if(3===t)return e+".z";if(4===t)return e+".w";throw Error("Cumulative sum for rank "+t+" is not yet supported")}var Ue,ze,Ve=function(){return function(t){this.variableNames=["A"],this.outputShape=t,this.userCode="\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "}}(),We=function(){return function(t){this.variableNames=["A"];var e=t[0],n=t[1];this.outputShape=t,this.userCode="\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2("+n+".0, "+e+".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "}}(),Ge=function(){return function(t,e,n){this.variableNames=["A","indices"];var r=t.slice();r[n]=e,this.outputShape=r,this.rank=r.length;var o=Oe(this.rank),a=function(t,e){var n=t.length;if(n>4)throw Error("Gather for rank "+n+" is not yet supported");if(1===n)return"int(getIndices(resRC))";for(var r=["resRC.x","resRC.y","resRC.z","resRC.w"],o=[],a=0;a= "+r);for(var o=0,a=0;ar||n>r){o="["+e+"x"+n+"]";throw new Error("Requested texture size "+o+" greater than WebGL maximum on this browser / GPU "+("["+r+"x"+r+"]")+".")}}function gn(t){return Tn(t,function(){return t.createFramebuffer()},"Unable to create WebGLFramebuffer.")}function yn(t,e,n,r,o,a,i){var u=t.getAttribLocation(e,n);return-1!==u&&(Je(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,r)}),Je(t,function(){return t.vertexAttribPointer(u,o,t.FLOAT,!1,a,i)}),Je(t,function(){return t.enableVertexAttribArray(u)}),!0)}function xn(t,e,n){In(t,n),Je(t,function(){return t.activeTexture(t.TEXTURE0+n)}),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,e)})}function bn(t,e,n){return Tn(t,function(){return t.getUniformLocation(e,n)},'uniform "'+n+'" not present in program.')}function wn(t,e,n){return t.getUniformLocation(e,n)}function En(t,e,n,r,o){Je(t,function(){return xn(t,n,o)}),Je(t,function(){return t.uniform1i(r,o)})}function Sn(t,e,n){Je(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,n)}),Je(t,function(){return t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,e,0)})}function Rn(t,e){Je(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,e)}),Je(t,function(){return t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,null,0)})}function Cn(t){var e=t.checkFramebufferStatus(t.FRAMEBUFFER);if(e!==t.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+kn(t,e))}function kn(t,e){switch(e){case t.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case t.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return"unknown error "+e}}function Tn(t,e,n){var r=Je(t,function(){return e()});if(null==r)throw new Error(n);return r}function In(t,e){var n=t.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,r=e+t.TEXTURE0;if(rn)throw new Error("textureUnit must be in "+("[gl.TEXTURE0, gl.TEXTURE"+n+"]")+".")}function An(t,e){2!==e.length&&(e=E(e).newShape);var n=pn(t),r=d(e);return e.length<=1&&r<=n?[r,1]:2===e.length&&e[0]<=n&&e[1]<=n?e:3===e.length&&e[0]<=n&&e[1]*e[2]<=n?[e[0],e[1]*e[2]]:4===e.length&&e[0]<=n&&e[1]*e[2]*e[3]<=n?[e[0],e[1]*e[2]*e[3]]:y(r)}var Dn=Object.freeze({createWebGLRenderingContext:Ye,createWebGLRenderingContextFromCanvas:Qe,callAndCheck:Je,enableDebugWebGLErrorChecking:tn,checkWebGLError:en,getWebGLErrorMessage:nn,getExtensionOrThrow:rn,createVertexShader:on,createFragmentShader:an,createProgram:sn,linkProgram:ln,validateProgram:cn,createStaticVertexBuffer:hn,createStaticIndexBuffer:fn,queryMaxTextureSize:pn,getNumChannels:dn,createTexture:vn,validateTextureSize:mn,createFramebuffer:gn,bindVertexBufferToProgramAttribute:yn,bindTextureUnit:xn,unbindTextureUnit:function(t,e){In(t,e),Je(t,function(){return t.activeTexture(t.TEXTURE0+e)}),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,null)})},getProgramUniformLocationOrThrow:bn,getProgramUniformLocation:wn,bindTextureToProgramUniformSampler:En,bindCanvasToFramebuffer:function(t){Je(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,null)}),Je(t,function(){return t.viewport(0,0,t.canvas.width,t.canvas.height)}),Je(t,function(){return t.scissor(0,0,t.canvas.width,t.canvas.height)})},bindColorTextureToFramebuffer:Sn,unbindColorTextureFromFramebuffer:Rn,validateFramebuffer:Cn,getFramebufferErrorMessage:kn,getTextureShapeFromLogicalShape:An});function Nn(){return{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0}}function Mn(t){var e,n={alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0};return Je(e=null!=t?Qe(t,n):Ye(n),function(){return e.disable(e.DEPTH_TEST)}),Je(e,function(){return e.disable(e.STENCIL_TEST)}),Je(e,function(){return e.disable(e.BLEND)}),Je(e,function(){return e.disable(e.DITHER)}),Je(e,function(){return e.disable(e.POLYGON_OFFSET_FILL)}),Je(e,function(){return e.disable(e.SAMPLE_COVERAGE)}),Je(e,function(){return e.enable(e.SCISSOR_TEST)}),Je(e,function(){return e.enable(e.CULL_FACE)}),Je(e,function(){return e.cullFace(e.BACK)}),e}function _n(t){return on(t,"\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }")}function On(t){return hn(t,new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]))}function Fn(t){return fn(t,new Uint16Array([0,1,2,2,1,3]))}function Ln(t,e){var n,r,o,a,i,u,s,l=t;return 2===ht.get("WEBGL_VERSION")?(n=l.R32F,r=l.R16F,o=l.RGBA32F,a=l.RED,i=4,u=1,s=l.HALF_FLOAT):(n=t.RGBA,r=t.RGBA,o=l.RGBA,a=t.RGBA,i=4,u=4,s=null!=e?e.HALF_FLOAT_OES:null),{internalFormatFloat:n,internalFormatHalfFloat:r,internalFormatPackedFloat:o,textureFormatFloat:a,downloadTextureFormat:t.RGBA,downloadUnpackNumChannels:i,defaultNumChannels:u,textureTypeHalfFloat:s}}function Bn(t,e,n,r,o,a){mn(t,e,n);var i=vn(t),u=t.TEXTURE_2D;return Je(t,function(){return t.bindTexture(u,i)}),Je(t,function(){return t.texParameteri(u,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE)}),Je(t,function(){return t.texParameteri(u,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE)}),Je(t,function(){return t.texParameteri(u,t.TEXTURE_MIN_FILTER,t.NEAREST)}),Je(t,function(){return t.texParameteri(u,t.TEXTURE_MAG_FILTER,t.NEAREST)}),Je(t,function(){return t.texImage2D(u,0,r,e,n,0,o,a,null)}),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,null)}),i}function Pn(t,e,n,r){var o=qe(e,n);return Bn(t,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,t.FLOAT)}function Un(t,e,n,r){var o=qe(e,n);return Bn(t,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,r.textureTypeHalfFloat)}function zn(t,e,n,r){var o=qe(e,n);return Bn(t,o[0],o[1],t.RGBA,t.RGBA,t.UNSIGNED_BYTE)}function Vn(t,e,n,r){var o=je(e,n);return Bn(t,o[0],o[1],r.internalFormatPackedFloat,t.RGBA,t.FLOAT)}function Wn(t,e,n){return Je(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,n)}),yn(t,e,"clipSpacePos",n,3,20,0)&&yn(t,e,"uv",n,2,20,12)}function Gn(t,e,n){Je(t,function(){return t.bindTexture(t.TEXTURE_2D,e)}),Je(t,function(){return t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,n)}),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,null)})}function qn(t,e,n,r,o,a){mn(t,n,r),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,e)}),Je(t,function(){return t.texSubImage2D(t.TEXTURE_2D,0,0,0,n,r,a,t.FLOAT,o)}),Je(t,function(){return t.bindTexture(t.TEXTURE_2D,null)})}function Hn(t,e,n,r,o,a,i){var u,s=qe(n,r),l=s[0],c=s[1];1===i.defaultNumChannels?u=o:function(t,e,n){var r=He(t.length,n);if(e.length= "+r);for(var o=0,a=0;a= "+o);for(var a=je(e,n),i=a[0],u=a[1],s=n%2==1,l=e%2==1,c=Math.floor(n/2),h=Math.floor(e/2),f=s?4:0,p=n,d=0,v=0;v= "+o);for(var a=n%2==1,i=e%2==1,u=Math.floor(n/2),s=Math.floor(e/2),l=je(e,n),c=l[0],h=l[1],f=a?4:0,p=n+(a?1:0),d=0,v=0,m=n,g=0;g0?(e=this.beginQuery(),this.endQuery(),n=function(){return r.isQueryAvailable(e,ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}):n=function(){return!0};return{query:e,isFencePassed:n}},t.prototype.downloadMatrixFromPackedTexture=function(t,e,n){var r=this;return this.downloadMatrixDriver(t,function(){return Qn(r.gl,e,n,r.textureConfig)})},t.prototype.createProgram=function(t){this.throwIfDisposed();var e=this.gl,n=an(e,t),r=_n(e),o=sn(e);return Je(e,function(){return e.attachShader(o,r)}),Je(e,function(){return e.attachShader(o,n)}),ln(e,o),this.autoDebugValidate&&cn(e,o),this.vertexAttrsAreBound||(this.setProgram(o),this.vertexAttrsAreBound=Wn(e,this.program,this.vertexBuffer)),o},t.prototype.deleteProgram=function(t){var e=this;this.throwIfDisposed(),t===this.program&&(this.program=null),null!=t&&Je(this.gl,function(){return e.gl.deleteProgram(t)})},t.prototype.setProgram=function(t){var e=this;this.throwIfDisposed(),this.program=t,null!=this.program&&this.autoDebugValidate&&cn(this.gl,this.program),Je(this.gl,function(){return e.gl.useProgram(t)})},t.prototype.getUniformLocation=function(t,e,n){return void 0===n&&(n=!0),this.throwIfDisposed(),n?bn(this.gl,t,e):wn(this.gl,t,e)},t.prototype.getAttributeLocation=function(t,e){var n=this;return this.throwIfDisposed(),Je(this.gl,function(){return n.gl.getAttribLocation(t,e)})},t.prototype.getUniformLocationNoThrow=function(t,e){return this.throwIfDisposed(),this.gl.getUniformLocation(t,e)},t.prototype.setInputMatrixTexture=function(t,e,n){this.throwIfDisposed(),this.throwIfNoProgram(),En(this.gl,this.program,t,e,n)},t.prototype.setOutputMatrixTexture=function(t,e,n){this.setOutputMatrixTextureDriver(t,n,e)},t.prototype.setOutputPackedMatrixTexture=function(t,e,n){this.throwIfDisposed();var r=je(e,n),o=r[0],a=r[1];this.setOutputMatrixTextureDriver(t,o,a)},t.prototype.setOutputMatrixWriteRegion=function(t,e,n,r){this.setOutputMatrixWriteRegionDriver(n,t,r,e)},t.prototype.setOutputPackedMatrixWriteRegion=function(t,e,n,r){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")},t.prototype.debugValidate=function(){null!=this.program&&cn(this.gl,this.program),Cn(this.gl)},t.prototype.executeProgram=function(){this.throwIfDisposed(),this.throwIfNoProgram();var t=this.gl;this.autoDebugValidate&&this.debugValidate(),Je(t,function(){return t.drawElements(t.TRIANGLES,6,t.UNSIGNED_SHORT,0)})},t.prototype.blockUntilAllProgramsCompleted=function(){var t=this;this.throwIfDisposed(),Je(this.gl,function(){return t.gl.finish()})},t.prototype.getQueryTimerExtension=function(){return null==this.disjointQueryTimerExtension&&(this.disjointQueryTimerExtension=rn(this.gl,2===ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension},t.prototype.getQueryTimerExtensionWebGL2=function(){return this.getQueryTimerExtension()},t.prototype.getQueryTimerExtensionWebGL1=function(){return this.getQueryTimerExtension()},t.prototype.beginQuery=function(){if(2===ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var t=this.gl,e=this.getQueryTimerExtensionWebGL2(),n=t.createQuery();return t.beginQuery(e.TIME_ELAPSED_EXT,n),n}var r=this.getQueryTimerExtensionWebGL1(),o=r.createQueryEXT();return r.beginQueryEXT(r.TIME_ELAPSED_EXT,o),o},t.prototype.endQuery=function(){if(2!==ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var t=this.getQueryTimerExtensionWebGL1();t.endQueryEXT(t.TIME_ELAPSED_EXT)}else{var e=this.gl,n=this.getQueryTimerExtensionWebGL2();e.endQuery(n.TIME_ELAPSED_EXT)}},t.prototype.waitForQueryAndGetTime=function(t){return o(this,void 0,void 0,function(){var e=this;return a(this,function(n){switch(n.label){case 0:return[4,b(function(){return e.isQueryAvailable(t,ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))})];case 1:return n.sent(),[2,this.getQueryTime(t,ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))]}})})},t.prototype.getQueryTime=function(t,e){if(0===e)return null;if(2===e){var n=this.gl;return n.getQueryParameter(t,n.QUERY_RESULT)/1e6}var r=this.getQueryTimerExtensionWebGL1();return r.getQueryObjectEXT(t,r.QUERY_RESULT_EXT)/1e6},t.prototype.isQueryAvailable=function(t,e){if(0===e)return!0;if(2===e){var n=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=n.getQueryParameter(t,n.QUERY_RESULT_AVAILABLE);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}o=(r=this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(t,r.QUERY_RESULT_AVAILABLE_EXT);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint},t.prototype.pollFence=function(t){var e=this;return new Promise(function(n){e.addItemToPoll(function(){return t.isFencePassed()},function(){return n()})})},t.prototype.pollItems=function(){for(var t=function(t){var e=0,n=t.length-1,r=-1;for(;e<=n;){var o=e+n>>1,a=t[o]();a?(r=o,e=o+1):n=o-1}return r}(this.itemsToPoll.map(function(t){return t.isDoneFn})),e=0;e<=t;++e){(0,this.itemsToPoll[e].resolveFn)()}this.itemsToPoll=this.itemsToPoll.slice(t+1)},t.prototype.addItemToPoll=function(t,e){var n=this;this.itemsToPoll.push({isDoneFn:t,resolveFn:e}),this.itemsToPoll.length>1||b(function(){return n.pollItems(),0===n.itemsToPoll.length})},t.prototype.bindTextureToFrameBuffer=function(t){this.throwIfDisposed(),Sn(this.gl,t,this.framebuffer),this.autoDebugValidate&&Cn(this.gl)},t.prototype.unbindTextureToFrameBuffer=function(){null!=this.outputTexture?(Sn(this.gl,this.outputTexture,this.framebuffer),this.autoDebugValidate&&Cn(this.gl)):Rn(this.gl,this.framebuffer)},t.prototype.downloadMatrixDriver=function(t,e){this.bindTextureToFrameBuffer(t);var n=e();return this.unbindTextureToFrameBuffer(),n},t.prototype.setOutputMatrixTextureDriver=function(t,e,n){this.throwIfDisposed();var r=this.gl;Sn(r,t,this.framebuffer),this.autoDebugValidate&&Cn(r),this.outputTexture=t,Je(r,function(){return r.viewport(0,0,e,n)}),Je(r,function(){return r.scissor(0,0,e,n)})},t.prototype.setOutputMatrixWriteRegionDriver=function(t,e,n,r){var o=this;this.throwIfDisposed(),Je(this.gl,function(){return o.gl.scissor(t,e,n,r)})},t.prototype.throwIfDisposed=function(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")},t.prototype.throwIfNoProgram=function(){if(null==this.program)throw new Error("No GPU program is currently set.")},t}();function tr(t,e){if(t.length!==e.length)throw Error("Binary was compiled with "+t.length+" inputs, but was executed with "+e.length+" inputs");t.forEach(function(t,n){var r=t.logicalShape,o=e[n],a=o.tensor.shape;if(!v(r,a))throw Error("Binary was compiled with different shapes than the current args. Shapes "+r+" and "+a+" must match");if(!t.isUniform||!o.isUniform){var i=t.texShape,u=o.isUniform?null:o.texData.texShape;if(!v(i,u))throw Error("Binary was compiled with different texture shapes than the current args. Shape "+i+" and "+u+" must match")}})}var er=function(){return function(t,e,n,r,o){this.variableNames=["x"],this.outputShape=[];var a,i=e,u=t[3]-1;this.outputShape=t;var s="float("+n+") + float("+r+") * sum";a=.5===o?"inversesqrt("+s+")":1===o?"1.0/("+s+")":"exp(log("+s+") * float(-"+o+"));",this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -"+i+"; j <= "+i+"; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= "+u+") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * "+a+";\n setOutput(val);\n }\n "}}(),nr=function(){return function(t,e,n,r,o){this.variableNames=["inputImage","outputImage","dy"],this.outputShape=[],this.outputShape=t,this.depth=t[3],this.depthRadius=e,this.bias=n,this.alpha=r,this.beta=o,this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < "+this.depth+"; ++d) {\n int depthBegin = int(max(0.0, float(d - "+e+")));\n int depthEnd = int(min(float("+this.depth+"),\n float(d + "+e+" + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = "+this.depth+";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float("+r+") * norm + float("+n+");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float("+r+")\n * float("+o+")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * "+o+");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "}}(),rr=function(){return function(t){this.variableNames=["dy","maxPos"],this.outputShape=t.inShape;var e=t.filterHeight,n=t.filterWidth,r=t.strideHeight,o=t.strideWidth,a=e-1-t.padInfo.top,i=n-1-t.padInfo.left,u=e*n-1;this.userCode="\n const ivec2 pads = ivec2("+a+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+e+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+r+".0;\n\n if (dyR < 0.0 || dyR >= "+t.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+n+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+o+".0;\n\n if (dyC < 0.0 || dyC >= "+t.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = "+u+" - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * "+n+" + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "}}(),or=function(){return function(t,e,n,r){void 0===n&&(n=!1),void 0===r&&(r=!1),this.variableNames=["matrixA","matrixB"];var o=n?t[1]:t[0],a=r?e[0]:e[1],i=n?t[0]:t[1];this.outputShape=[o,a];var u=function(t,e){return n?e+" + "+t+", aRow":"aRow, "+e+" + "+t},s=function(t,e){return r?"bCol, "+e+" + "+t:e+" + "+t+", bCol"},l=4*Math.floor(i/4),c=i%4;this.userCode=" float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < "+l+"; i += 4) {\n vec4 a = vec4(\n getMatrixA("+u(0,"i")+"),\n getMatrixA("+u(1,"i")+"),\n getMatrixA("+u(2,"i")+"),\n getMatrixA("+u(3,"i")+")\n );\n vec4 b = vec4(\n getMatrixB("+s(0,"i")+"),\n getMatrixB("+s(1,"i")+"),\n getMatrixB("+s(2,"i")+"),\n getMatrixB("+s(3,"i")+")\n );\n\n result += dot(a, b);\n }\n\n if ("+(1===c)+") {\n result += getMatrixA("+u(0,l)+") *\n getMatrixB("+s(0,l)+");\n } else if ("+(2===c)+") {\n vec2 a = vec2(\n getMatrixA("+u(0,l)+"),\n getMatrixA("+u(1,l)+")\n );\n vec2 b = vec2(\n getMatrixB("+s(0,l)+"),\n getMatrixB("+s(1,l)+")\n );\n result += dot(a, b);\n } else if ("+(3===c)+") {\n vec3 a = vec3(\n getMatrixA("+u(0,l)+"),\n getMatrixA("+u(1,l)+"),\n getMatrixA("+u(2,l)+")\n );\n vec3 b = vec3(\n getMatrixB("+s(0,l)+"),\n getMatrixB("+s(1,l)+"),\n getMatrixB("+s(2,l)+")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "}}(),ar=function(){function t(t,e,n){this.variableNames=["probs"],this.outputShape=[t,n],this.userCode="\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < "+(e-1)+"; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float("+(e-1)+"));\n }\n "}return t.prototype.getCustomSetupFunc=function(t){var e=this;return function(n,r){null==e.seedLoc&&(e.seedLoc=n.getUniformLocation(r,"seed")),n.gl.uniform1f(e.seedLoc,t)}},t}(),ir=function(){return function(t,e,n,r){this.variableNames=["indices"],this.outputShape=[t,e],this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float("+r+"), float("+n+"),\n float(index == coords.y)));\n }\n "}}(),ur=function(){return function(t,e,n){this.variableNames=["x"],this.outputShape=e.map(function(e,n){return e[0]+t[n]+e[1]});var r=t.length,o=Oe(r),a=e.map(function(t){return t[0]}).join(","),i=e.map(function(e,n){return e[0]+t[n]}).join(","),u=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r);this.userCode=1!==r?"\n "+o+" start = "+o+"("+a+");\n "+o+" end = "+o+"("+i+");\n\n void main() {\n "+o+" outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float("+n+"));\n } else {\n "+o+" coords = outC - start;\n setOutput(getX("+u+"));\n }\n }\n ":"\n int start = "+a+";\n int end = "+i+";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float("+n+"));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "}}(),sr=function(){return function(t,e,n){if(this.variableNames=["x"],"avg"===e&&n)throw new Error("Cannot compute positions for average pool.");var r=t.filterHeight,o=t.filterWidth,a=t.strideHeight,i=t.strideWidth,u=t.padInfo.top,s=t.padInfo.left;this.outputShape=t.outShape;var l="avg"===e,c="0.0";if(l||(c="-1.0 / 0.0"),n)this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+u+", "+s+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < "+r+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+t.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+o+"; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= "+t.inWidth+") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value >= currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * "+o+" + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n ";else{var h=e+"("+e+"("+e+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"avg"===e&&(h="avgValue / count");var f=4*Math.floor(o/4),p=o%4,d="\n if ("+l+") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = max(values, minMaxValue);\n }\n ";this.userCode="\n const ivec2 strides = ivec2("+a+", "+i+");\n const ivec2 pads = ivec2("+u+", "+s+");\n const float initializationValue = "+c+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= "+t.inWidth+") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4("+c+");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < "+r+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+t.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+f+"; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n "+d+"\n }\n\n int xC = xCCorner + "+f+";\n if ("+(1===p)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+d+"\n } else if ("+(2===p)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n "+d+"\n } else if ("+(3===p)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n "+d+"\n }\n }\n setOutput("+h+");\n }\n "}}}(),lr=function(){return function(t,e){this.variableNames=["x"];var n=t.windowSize,r=t.batchSize,o=t.inSize,a=Math.ceil(o/n);this.outputShape=[r,a];var i="0.0",u="";"min"===e?(i="1.0 / 0.0",u="min"):"max"===e&&(i="-1.0 / 0.0",u="max");var s=e+"("+e+"("+e+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"sum"===e?s="sumValue":"all"===e?s="allValue":"any"===e&&(s="anyValue");var l=4*Math.floor(n/4),c=n%4,h="\n if ("+("sum"===e)+") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = "+u+"(values, minMaxValue);\n }\n ",f="vec4";"all"===e?(i="1.0",h="\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n ",f="bvec4"):"any"===e&&(i="0.0",h="\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n ",f="bvec4");var p="";o%n>0&&(p="\n if (inIdx < 0 || inIdx >= "+o+") {\n return initializationValue;\n }\n "),this.userCode="\n const float initializationValue = "+i+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n "+p+"\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+n+";\n\n vec4 minMaxValue = vec4("+i+");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < "+l+"; i += 4) {\n int inIdx = inOffset + i;\n "+f+" values = "+f+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n "+h+"\n }\n\n int inIdx = inOffset + "+l+";\n if ("+(1===c)+") {\n "+f+" values = "+f+"(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+h+"\n } else if ("+(2===c)+") {\n "+f+" values = "+f+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n "+h+"\n } else if ("+(3===c)+") {\n "+f+" values = "+f+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n "+h+"\n }\n setOutput("+s+");\n }\n "}}(),cr=function(){return function(t,e,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=e.shape;var r=e.shape,o=r[1],a=r[2],i=t.shape,u=i[1],s=i[2],l=[n&&u>1?o-1:o,n&&s>1?a-1:a],c=[n&&u>1?u-1:u,n&&s>1?s-1:s],h=l[0]/c[0],f=l[1]/c[1],p=1/h,d=1/f,v=2*Math.ceil(p)+2,m=2*Math.ceil(d)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+h+");\n const float widthScale = float("+f+");\n\n const float invHeightScale = float("+p+");\n const float invWidthScale = float("+d+");\n\n const int winHeight = int("+v+");\n const int winWidth = int("+m+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+u+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+s+") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), "+(o-1)+".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), "+(a-1)+".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "}}(),hr=function(){return function(t,e,n,r){this.variableNames=["A"],this.outputShape=[];var o=t[0],a=t[1],i=t[2],u=t[3];this.outputShape=[o,e,n,u];var s=[r&&e>1?a-1:a,r&&n>1?i-1:i],l=[r&&e>1?e-1:e,r&&n>1?n-1:n];this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+s[0]/l[0]+",\n "+s[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+a+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "}}(),fr=function(){return function(t,e,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=e.shape;var r=e.shape,o=r[1],a=r[2],i=t.shape,u=i[1],s=i[2],l=[n&&u>1?o-1:o,n&&s>1?a-1:a],c=[n&&u>1?u-1:u,n&&s>1?s-1:s],h=l[0]/c[0],f=l[1]/c[1],p=1/h,d=1/f,v=2*Math.ceil(p)+2,m=2*Math.ceil(d)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+h+");\n const float widthScale = float("+f+");\n\n const float invHeightScale = float("+p+");\n const float invWidthScale = float("+d+");\n\n const int winHeight = int("+v+");\n const int winWidth = int("+m+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+u+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+s+") {\n continue;\n }\n\n float sourceFracRow =\n float("+l[0]+") *\n (float(dyR) / float("+c[0]+"));\n\n float sourceFracCol =\n float("+l[1]+") *\n (float(dyC) / float("+c[1]+"));\n\n int sourceNearestRow = int(min(\n float(int("+o+") - 1),\n "+n+" ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int("+a+") - 1),\n "+n+" ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "}}(),pr=function(){return function(t,e,n,r){this.variableNames=["A"],this.outputShape=[];var o=t[0],a=t[1],i=t[2],u=t[3];this.outputShape=[o,e,n,u];var s=[r&&e>1?a-1:a,r&&n>1?i-1:i],l=[r&&e>1?e-1:e,r&&n>1?n-1:n],c=r?"0.5":"0.0";this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+s[0]/l[0]+",\n "+s[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+a+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + "+c+")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "}}(),dr=function(){return function(t,e){this.variableNames=["x"];var n=t.length;if(n>4)throw new Error("WebGL backend: Reverse of rank-"+n+" tensor is not yet supported");if(this.outputShape=t,1!==n){var r=t.map(function(n,r){return function(n){return-1!==e.indexOf(n)&&1!==t[n]?t[n]+" - coords["+n+"] - 1":"coords["+n+"]"}(r)}).join(","),o=Oe(n);this.userCode="\n void main() {\n "+o+" coords = getOutputCoords();\n setOutput(getX("+r+"));\n }\n "}else this.userCode="\n void main() {\n int coord = getOutputCoords();\n setOutput(getX("+t[0]+" - coord - 1));\n }\n "}}(),vr=function(){return function(t,e){this.variableNames=["x","segmentIds"];var n=t.windowSize,r=t.batchSize,o=t.inSize,a=t.numSegments,i=a*Math.ceil(o/n);this.outputShape=[r,i];var u=4*Math.floor(n/4),s=n%4,l="\n sumValue += dot(values, filter);\n ",c="";o%n>0&&(c="\n if (inIdx < 0 || inIdx >= "+o+") {\n return initializationValue;\n }\n ");var h="";o%n>0&&(h="\n if (inIdx < 0 || inIdx >= "+o+") {\n return -1.0;\n }\n "),this.userCode="\n const float initializationValue = 0.0;\n\n float getValue(int batch, int inIdx) {\n "+c+"\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n "+h+"\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n "+a+")) * float("+n+"));\n int currentSeg = int(mod(float(outIdx), float("+a+")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < "+u+"; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n "+l+"\n }\n\n int inIdx = inOffset + "+u+";\n if ("+(1===s)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(2===s)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(3===s)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n "+l+"\n }\n setOutput(sumValue);\n }\n "}}(),mr=function(){return function(t,e,n){var r,o;if(this.variableNames=["c","a","b"],this.outputShape=e,n>4)throw Error("Where for rank "+n+" is not yet supported");if(1===n)o="resRC",r="resRC";else{for(var a=["resRC.x","resRC.y","resRC.z","resRC.w"],i=[],u=[],s=0;s= 1.0) {\n setOutput(getA("+o+"));\n } else {\n setOutput(getB("+o+"));\n }\n }\n "}}(),gr=function(){function t(t){this.variableNames=["source"],this.outputShape=t,this.rank=t.length;var e=Oe(this.rank),n=function(t){if(1===t)return"sourceLoc";if(2===t)return"sourceLoc.x, sourceLoc.y";if(3===t)return"sourceLoc.x, sourceLoc.y, sourceLoc.z";if(4===t)return"sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w";throw Error("Slicing for rank "+t+" is not yet supported")}(this.rank);this.userCode="\n uniform "+e+" start;\n\n void main() {\n "+e+" sourceLoc = start + getOutputCoords();\n setOutput(getSource("+n+"));\n }\n "}return t.prototype.getCustomSetupFunc=function(t){var e=this;if(t.length!==this.rank)throw Error("The rank ("+this.rank+") of the program must match the length of start ("+t.length+")");return function(n,r){if(null!=e.startLoc||(e.startLoc=n.getUniformLocationNoThrow(r,"start"),null!=e.startLoc))if(1===e.rank)n.gl.uniform1i(e.startLoc,t[0]);else if(2===e.rank)n.gl.uniform2i(e.startLoc,t[0],t[1]);else if(3===e.rank)n.gl.uniform3i(e.startLoc,t[0],t[1],t[2]);else{if(4!==e.rank)throw Error("Slicing for rank "+e.rank+" is not yet supported");n.gl.uniform4i(e.startLoc,t[0],t[1],t[2],t[3])}}},t}();var yr=function(){return function(t,e,n){this.variableNames=["x"],this.outputShape=n,this.rank=n.length;var r=Oe(this.rank),o="";o=1===this.rank?"coords * strides + begin":n.map(function(t,e){return"coords["+e+"] * strides["+e+"] + begin["+e+"]"}).join(","),this.userCode="\n "+r+" begin = "+r+"("+t+");\n "+r+" strides = "+r+"("+e+");\n\n void main() {\n "+r+" coords = getOutputCoords();\n setOutput(getX("+o+"));\n }\n "}}(),xr=function(){function t(t){this.gpgpu=t,this.numUsedTextures=0,this.numFreeTextures=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}return t.prototype.acquireTexture=function(t,e){var n,r=br(e),o=wr(t,r);if(o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]),this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this.log();var a=this.freeTextures[o].shift();return this.usedTextures[o].push(a),a}return this.numUsedTextures++,this.log(),r===ze.FLOAT32?n=this.gpgpu.createFloat32MatrixTexture(t[0],t[1]):r===ze.FLOAT16?n=this.gpgpu.createFloat16MatrixTexture(t[0],t[1]):r===ze.UNSIGNED_BYTE&&(n=this.gpgpu.createUnsignedBytesMatrixTexture(t[0],t[1])),this.usedTextures[o].push(n),n},t.prototype.releaseTexture=function(t,e,n){var r=wr(e,br(n));r in this.freeTextures||(this.freeTextures[r]=[]),this.freeTextures[r].push(t),this.numFreeTextures++,this.numUsedTextures--;var o=this.usedTextures[r],a=o.indexOf(t);if(a<0)throw new Error("Cannot release a texture that was never provided by this texture manager");o.splice(a,1),this.log()},t.prototype.log=function(){if(this.logEnabled){var t=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",this.numFreeTextures+" / "+this.numUsedTextures,"("+t+")")}},t.prototype.getNumUsedTextures=function(){return this.numUsedTextures},t.prototype.getNumFreeTextures=function(){return this.numFreeTextures},t.prototype.dispose=function(){var t=this;if(null!=this.freeTextures){for(var e in this.freeTextures)this.freeTextures[e].forEach(function(e){t.gpgpu.deleteMatrixTexture(e)});for(var e in this.usedTextures)this.usedTextures[e].forEach(function(e){t.gpgpu.deleteMatrixTexture(e)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0}},t}();function br(t){if(t===Ue.DOWNLOAD||t===Ue.PIXELS)return ze.UNSIGNED_BYTE;if(t===Ue.UPLOAD)return ze.FLOAT32;if(t===Ue.RENDER)return ht.get("WEBGL_RENDER_FLOAT32_ENABLED")?ze.FLOAT32:ze.FLOAT16;throw new Error("Unknown logical texture type "+t)}function wr(t,e){return t[0]+"_"+t[1]+"_"+e}var Er=function(){return function(t,e){this.variableNames=["A"];for(var n=new Array(t.length),r=0;r5)throw Error("Tile for rank "+e+" is not yet supported");if(1===e)return"imod(resRC, "+t[0]+")";for(var n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],r=[],o=0;o6)throw Error("Transpose for rank "+e+" is not yet supported");for(var n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u","resRC.v"],r=new Array(e),o=0;o= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n";var Dr=Tr+"\n return sin(x);\n",Nr=Tr+"\n return cos(x);\n",Mr=Tr+"\n return atan(x);\n",_r=Tr+"\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));",Or=Tr+"\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;";function Fr(t,e,n){!function(t,e,n){var r=t.length,o=e.length;l(t.length===e.length,"Error in concat"+r+"D: rank of x1 ("+r+") and x2 ("+o+") must be the same."),l(n>=0&&n=1,"Pass at least one tensor to concat");var n=Lt(t,"tensors","concat"),r=n[0];if(1===n.length)return r;for(var o=Et(e,r.shape),a=1;a>>0,e=(r*=e)>>>0,e+=4294967296*(r-=e)}return 2.3283064365386963e-10*(e>>>0)});n.next=function(){var t=2091639*n.s0+2.3283064365386963e-10*n.c;return n.s0=n.s1,n.s1=n.s2,n.s2=t-(n.c=0|t)},n.c=1,n.s0=r(" "),n.s1=r(" "),n.s2=r(" "),n.s0-=r(t),n.s0<0&&(n.s0+=1),n.s1-=r(t),n.s1<0&&(n.s1+=1),n.s2-=r(t),n.s2<0&&(n.s2+=1),r=null}(t),o=e&&e.state,a=n.next;return a.int32=function(){return 4294967296*n.next()|0},a.double=function(){return a()+1.1102230246251565e-16*(2097152*a()|0)},a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.alea=o}(0,t,!1)}),Gr=Vr(function(t){!function(t,e,n){function r(t,e){return e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e}function o(t,e){var n=new function(t){var e=this,n="";e.x=0,e.y=0,e.z=0,e.w=0,e.next=function(){var t=e.x^e.x<<11;return e.x=e.y,e.y=e.z,e.z=e.w,e.w^=e.w>>>19^t^t>>>8},t===(0|t)?e.x=t:n+=t;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var t=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.xor128=o}(0,t,!1)}),qr=Vr(function(t){!function(t,e,n){function r(t,e){return e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e.v=t.v,e.d=t.d,e}function o(t,e){var n=new function(t){var e=this,n="";e.next=function(){var t=e.x^e.x>>>2;return e.x=e.y,e.y=e.z,e.z=e.w,e.w=e.v,(e.d=e.d+362437|0)+(e.v=e.v^e.v<<4^t^t<<1)|0},e.x=0,e.y=0,e.z=0,e.w=0,e.v=0,t===(0|t)?e.x=t:n+=t;for(var r=0;r>>4),e.next()}(t),o=e&&e.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var t=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.xorwow=o}(0,t,!1)}),Hr=Vr(function(t){!function(t,e,n){function r(t,e){return e.x=t.x.slice(),e.i=t.i,e}function o(t,e){null==t&&(t=+new Date);var n=new function(t){var e=this;e.next=function(){var t,n,r=e.x,o=e.i;return t=r[o],n=(t^=t>>>7)^t<<24,n^=(t=r[o+1&7])^t>>>10,n^=(t=r[o+3&7])^t>>>3,n^=(t=r[o+4&7])^t<<7,t=r[o+7&7],n^=(t^=t<<13)^t<<9,r[o]=n,e.i=o+1&7,n},function(t,e){var n,r=[];if(e===(0|e))r[0]=e;else for(e=""+e,n=0;n0;--n)t.next()}(e,t)}(t),o=e&&e.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var t=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},a.int32=n.next,a.quick=a,o&&(o.x&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.xorshift7=o}(0,t,!1)}),$r=Vr(function(t){!function(t,e,n){function r(t,e){return e.i=t.i,e.w=t.w,e.X=t.X.slice(),e}function o(t,e){null==t&&(t=+new Date);var n=new function(t){var e=this;e.next=function(){var t,n,r=e.w,o=e.X,a=e.i;return e.w=r=r+1640531527|0,n=o[a+34&127],t=o[a=a+1&127],n^=n<<13,t^=t<<17,n^=n>>>15,t^=t>>>12,n=o[a]=n^t,e.i=a,n+(r^r>>>16)|0},function(t,e){var n,r,o,a,i,u=[],s=128;for(e===(0|e)?(r=e,e=null):(e+="\0",r=0,s=Math.max(s,e.length)),o=0,a=-32;a>>15,r^=r<<4,r^=r>>>13,a>=0&&(i=i+1640531527|0,o=0==(n=u[127&a]^=r+i)?o+1:0);for(o>=128&&(u[127&(e&&e.length||0)]=-1),o=127,a=512;a>0;--a)r=u[o+34&127],n=u[o=o+1&127],r^=r<<13,n^=n<<17,r^=r>>>15,n^=n>>>12,u[o]=r^n;t.w=i,t.X=u,t.i=o}(e,t)}(t),o=e&&e.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var t=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},a.int32=n.next,a.quick=a,o&&(o.X&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.xor4096=o}(0,t,!1)}),jr=Vr(function(t){!function(t,e,n){function r(t,e){return e.a=t.a,e.b=t.b,e.c=t.c,e.d=t.d,e}function o(t,e){var n=new function(t){var e=this,n="";e.next=function(){var t=e.b,n=e.c,r=e.d,o=e.a;return t=t<<25^t>>>7^n,n=n-r|0,r=r<<24^r>>>8^o,o=o-t|0,e.b=t=t<<20^t>>>12^n,e.c=n=n-r|0,e.d=r<<16^n>>>16^o,e.a=o-t|0},e.a=0,e.b=0,e.c=-1640531527,e.d=1367130551,t===Math.floor(t)?(e.a=t/4294967296|0,e.b=0|t):n+=t;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var t=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},a.int32=n.next,a.quick=a,o&&("object"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}e&&e.exports?e.exports=o:n&&n.amd?n(function(){return o}):this.tychei=o}(0,t,!1)}),Xr=Vr(function(t){!function(e,n){var r,o=this,a=256,i=6,u="random",s=n.pow(a,i),l=n.pow(2,52),c=2*l,h=a-1;function f(t,f,m){var g=[],y=d(function t(e,n){var r,o=[],a=typeof e;if(n&&"object"==a)for(r in e)try{o.push(t(e[r],n-1))}catch(t){}return o.length?o:"string"==a?e:e+"\0"}((f=1==f?{entropy:!0}:f||{}).entropy?[t,v(e)]:null==t?function(){try{var t;return r&&(t=r.randomBytes)?t=t(a):(t=new Uint8Array(a),(o.crypto||o.msCrypto).getRandomValues(t)),v(t)}catch(t){var n=o.navigator,i=n&&n.plugins;return[+new Date,o,i,o.screen,v(e)]}}():t,3),g),x=new function(t){var e,n=t.length,r=this,o=0,i=r.i=r.j=0,u=r.S=[];n||(t=[n++]);for(;o=c;)t/=2,e/=2,n>>>=1;return(t+n)/e};return b.int32=function(){return 0|x.g(4)},b.quick=function(){return x.g(4)/4294967296},b.double=b,d(v(x.S),e),(f.pass||m||function(t,e,r,o){return o&&(o.S&&p(o,x),t.state=function(){return p(x,{})}),r?(n[u]=t,e):t})(b,y,"global"in f?f.global:this==n,f.state)}function p(t,e){return e.i=t.i,e.j=t.j,e.S=t.S.slice(),e}function d(t,e){for(var n,r=t+"",o=0;o=1||0===i);var u=Math.sqrt(-2*Math.log(i)/i);e=this.mean+this.stdDev*o*u,n=this.mean+this.stdDev*a*u,this.truncated&&!this.isValidTruncated(e)||(r=!0)}return this.truncated&&!this.isValidTruncated(n)||(this.nextVal=this.convertValue(n)),this.convertValue(e)},t.prototype.convertValue=function(t){return null==this.dtype||"float32"===this.dtype?t:Math.round(t)},t.prototype.isValidTruncated=function(t){return t<=this.upper&&t>=this.lower},t}();function Qr(t,e){return o(this,void 0,void 0,function(){var n,r,o,i,u,s,l,c,h,f,p,d,v,m,g,y,x,b,w,E;return a(this,function(a){switch(a.label){case 0:if(2!==(n=Ft(t,"img","toPixels","int32")).rank&&3!==n.rank)throw new Error("toPixels only supports rank 2 or 3 tensors, got rank "+n.rank+".");if(r=n.shape.slice(0,2),o=r[0],i=r[1],(u=2===n.rank?1:n.shape[2])>4||2===u)throw new Error("toPixels only supports depth of size 1, 3 or 4 but got "+u);return s=n.min(),l=n.max(),[4,s.data()];case 1:return c=a.sent()[0],[4,l.data()];case 2:if(h=a.sent()[0],s.dispose(),l.dispose(),"float32"===n.dtype){if(c<0||h>1)throw new Error("Tensor values for a float32 Tensor must be in the range [0 - 1] but got range ["+c+" - "+h+"].")}else{if("int32"!==n.dtype)throw new Error("Unsupported type for toPixels: "+n.dtype+". Please use float32 or int32 tensors.");if(c<0||h>255)throw new Error("Tensor values for a int32 Tensor must be in the range [0 - 255] but got range ["+c+" - "+h+"].")}return[4,n.data()];case 3:for(f=a.sent(),p="float32"===n.dtype?255:1,d=new Uint8ClampedArray(i*o*4),v=0;v4)throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");return ht.engine.fromPixels(t,e)}}),io=Bt({multinomial_:function(t,e,n,r){void 0===r&&(r=!1);var o=Ft(t,"logits","multinomial"),a=o.size,i=o.rank;if(a<2)throw new Error("Error in multinomial: you need at least 2 outcomes, but got "+a+".");if(i>2)throw new Error("Rank of probabilities must be 1 or 2, but is "+i);n=n||Math.random();var u=1===i?o.as2D(1,-1):o,s=ht.engine.runKernel(function(t){return t.multinomial(u,r,e,n)},{logits2D:u});return 1===i?s.as1D():s}}),uo=Bt({oneHot_:function(t,e,n,r){void 0===n&&(n=1),void 0===r&&(r=0);var o=Ft(t,"indices","oneHot","int32");if(l("int32"===o.dtype,"Indices must be of dtype `int32`"),e<2)throw new Error("Error in oneHot: depth must be >=2, but it is "+e);return ht.engine.runKernel(function(t){return t.oneHot(o,e,n,r)},{$indices:o})}}),so=Bt({pad_:function(t,e,n){void 0===n&&(n=0);var r=Ft(t,"x","pad");if(0===r.rank)throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");var o=e.map(function(t){return t[0]});return ht.engine.runKernel(function(t){return t.pad(r,e,n)},{$x:r},function(t){return{$x:function(){return t.slice(o,r.shape)}}})}}),lo=Bt({pad1d_:function(t,e,n){return void 0===n&&(n=0),l(2===e.length,"Invalid number of paddings. Must be length of 2."),so(t,[e],n)}}),co=Bt({pad2d_:function(t,e,n){return void 0===n&&(n=0),l(2===e.length&&2===e[0].length&&2===e[1].length,"Invalid number of paddings. Must be length of 2 each."),so(t,e,n)}}),ho=Bt({pad3d_:function(t,e,n){return void 0===n&&(n=0),l(3===e.length&&2===e[0].length&&2===e[1].length&&2===e[2].length,"Invalid number of paddings. Must be length of 2 each."),so(t,e,n)}}),fo=Bt({pad4d_:function(t,e,n){return void 0===n&&(n=0),l(4===e.length&&2===e[0].length&&2===e[1].length&&2===e[2].length&&2===e[3].length,"Invalid number of paddings. Must be length of 2 each."),so(t,e,n)}}),po=Bt({rand_:function(t,e,n){var r=d(t),o=null;if(null==n||"float32"===n)o=new Float32Array(r);else if("int32"===n)o=new Int32Array(r);else{if("bool"!==n)throw new Error("Unknown data type "+n);o=new Uint8Array(r)}for(var a=0;a=1,"Pass at least one tensor to tf.stack"),1===n.length)return n[0].expandDims(e);var r=n[0].rank,o=n[0].shape,a=n[0].dtype;l(e<=r,"Axis must be <= rank of the tensor"),n.forEach(function(t){c(o,t.shape,"All tensors passed to stack must have matching shapes")}),n.forEach(function(t){l(a===t.dtype,"All tensors passed to stack must have matching dtypes")});var i=n.map(function(t){return t.expandDims(e)});return Lr(i,e)}}),wo=Bt({tile_:function(t,e){var n=Ft(t,"x","tile");return l(n.rank===e.length,"Error in transpose: rank of input "+n.rank+" must match length of reps "+e+"."),ht.engine.runKernel(function(t){return t.tile(n,e)},{$x:n},function(t){return{$x:function(){var r=oe(n);if(1===n.rank)for(var o=0;o=1+e.length,"input rank should be > than [blockShape] but got "+r.rank),l(n.length===e.length,"crops.shape[0] must be equal to [blockShape] but got "+n.length),l(r.shape[0]%o==0,"input tensor batch must be divisible by prod( blockShape )"),ht.engine.runKernel(function(t){return t.batchToSpaceND(r,e,n)},{})}}),Co=Bt({spaceToBatchND_:function(t,e,n){var r=Ft(t,"x","spaceToBatchND");return l(r.rank>=1+e.length,"input rank should be > than [blockShape] but got "+r.rank),l(n.length===e.length,"paddings.shape[0] must be equal to [blockShape], got "+n.length),l(r.shape.reduce(function(t,n,r){return r>0&&r<=e.length?t&&n%e[r-1]==0:t},!0),"input spatial dimensions must be divisible by blockShapes"),ht.engine.runKernel(function(t){return t.spaceToBatchND(r,e,n)},{})}});function ko(t,e){for(var n=[],r=0;r0?this.gpgpu.beginQuery():{startMs:performance.now(),endMs:null}},t.prototype.endTimer=function(t){return ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(this.gpgpu.endQuery(),t):(t.endMs=performance.now(),t)},t.prototype.getQueryTime=function(t){return o(this,void 0,void 0,function(){var e;return a(this,function(n){return ht.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?[2,this.gpgpu.waitForQueryAndGetTime(t)]:[2,(e=t).endMs-e.startMs]})})},t.prototype.disposeData=function(t){if(!this.pendingDisposal.has(t))if(this.pendingRead.has(t))this.pendingDisposal.add(t);else if(this.texData.has(t)){var e=this.texData.get(t),n=e.texture,r=e.texShape,o=e.usage;null!=n&&this.releaseTexture(t,n,r,o),this.texData.delete(t)}},t.prototype.getTexture=function(t){return this.uploadToGPU(t),this.texData.get(t).texture},t.prototype.getGPGPUContext=function(){return this.gpgpu},t.prototype.getCanvas=function(){return this.canvas},t.prototype.slice=function(t,e,n){var r=new gr(n),o=r.getCustomSetupFunc(e);return this.compileAndRun(r,[t],null,o)},t.prototype.stridedSlice=function(t,e,n,r,o,a){var i=At(t.shape,e,n,r,o,a),u=i[0],s=i[1];if(s.some(function(t){return 0===t}))return Ut([],s);var l=new yr(u,r,s);return this.compileAndRun(l,[t])},t.prototype.reverse=function(t,e){var n=new dr(t.shape,e);return this.compileAndRun(n,[t])},t.prototype.concat=function(t,e){var n=new Ee(t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.neg=function(t){var e=new kr(t.shape,"return -x;");return this.compileAndRun(e,[t])},t.prototype.matMul=function(t,e,n,r){var o=new or(t.shape,e.shape,n,r);return this.compileAndRun(o,[t,e])},t.prototype.multiply=function(t,e){var n=new xe("return a * b;",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,ie(t.dtype,e.dtype));return this.compileAndRun(n,[t,e],r)},t.prototype.batchNormalization=function(t,e,n,r,o,a){var i=[t,e,n],u=null;null!=a&&(u=a.shape,i.push(a));var s=null;null!=o&&(s=o.shape,i.push(o));var l=new ye(t.shape,e.shape,n.shape,u,s,r);return this.compileAndRun(l,i)},t.prototype.localResponseNormalization4D=function(t,e,n,r,o){var a=new er(t.shape,e,n,r,o);return this.compileAndRun(a,[t])},t.prototype.LRNGrad=function(t,e,n,r,o,a,i){var u=new nr(e.shape,r,o,a,i);return this.compileAndRun(u,[e,n,t])},t.prototype.tile=function(t,e){var n=new Er(t.shape,e);return this.compileAndRun(n,[t])},t.prototype.pad=function(t,e,n){var r=new ur(t.shape,e,n);return this.compileAndRun(r,[t])},t.prototype.transpose=function(t,e){var n=new Sr(t.shape,e);return this.compileAndRun(n,[t])},t.prototype.gather=function(t,e,n){var r=new Ge(t.shape,e.size,n);return this.compileAndRun(r,[t,e])},t.prototype.batchToSpaceND=function(t,e,n){l(t.rank<=4,"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");var r=e.reduce(function(t,e){return t*e}),o=dt(t.shape,e,r),a=vt(o.length,e.length),i=mt(t.shape,e,r),u=gt(n,e.length),s=yt(i,n,e.length);return t.reshape(o).transpose(a).reshape(i).slice(u,s)},t.prototype.spaceToBatchND=function(t,e,n){l(t.rank<=4,"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");var r=e.reduce(function(t,e){return t*e}),o=[[0,0]];o.push.apply(o,n);for(var a=1+e.length;ae||n===t){r=!0;break}n=D(t,n+1)}return n}(i,o),s=new vr({windowSize:u,inSize:i,batchSize:a,numSegments:o},e),l=s.outputShape,c=l[0],h=l[1],f=this.makeOutputArray([c,h],r);return this.compileAndRun(s,[t,n],f),f.shape[1]===o?f:(n=Qt(0,o).tile([i/u]),this.segOpCompute(f,e,n,r,o))},t.prototype.argMin=function(t,e){var n=[e];St("argMin",n,t.rank);var r=bt(t.shape,n),o=r[0],a=d(r[1]),i=t.as2D(-1,a);return this.argReduce(i,"min").reshape(o)},t.prototype.argMax=function(t,e){var n=[e];St("argMax",n,t.rank);var r=bt(t.shape,n),o=r[0],a=d(r[1]),i=t.as2D(-1,a);return this.argReduce(i,"max").reshape(o)},t.prototype.cumsum=function(t,e,n,r){if(e!==t.rank-1)throw new Error("WebGL cumsum shader expects an inner-most axis="+(t.rank-1)+" but got axis="+e);var o=new Be(t.shape,n,r);return this.compileAndRun(o,[t])},t.prototype.equal=function(t,e){var n=new xe("return float(a == b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.notEqual=function(t,e){var n=new xe("return float(a != b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.less=function(t,e){var n=new xe("return float(a < b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.lessEqual=function(t,e){var n=new xe("return float(a <= b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.greater=function(t,e){var n=new xe("return float(a > b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.greaterEqual=function(t,e){var n=new xe("return float(a >= b);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.logicalNot=function(t){var e=new kr(t.shape,"return float(!(x >= 1.0));");return this.compileAndRun(e,[t])},t.prototype.logicalAnd=function(t,e){var n=new xe("return float(a >= 1.0 && b >= 1.0);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.logicalOr=function(t,e){var n=new xe("return float(a >= 1.0 || b >= 1.0);",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"bool");return this.compileAndRun(n,[t,e],r)},t.prototype.select=function(t,e,n){var r=new mr(t.rank,e.shape,e.rank),o=this.makeOutputArray(r.outputShape,ie(e.dtype,n.dtype));return this.compileAndRun(r,[t,e,n],o)},t.prototype.where=function(t){pt("tf.where() in webgl locks the UI thread. Call tf.whereAsync() instead");var e=t.dataSync();return ko(t.shape,e)},t.prototype.topk=function(t,e,n){return fe(t.dataSync(),t.shape,t.dtype,e)},t.prototype.min=function(t,e){St("min",e,t.rank);var n=bt(t.shape,e),r=n[0],o=d(n[1]),a=t.as2D(-1,o);return this.reduce(a,"min",a.dtype).reshape(r)},t.prototype.minimum=function(t,e){var n=new xe("\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n\n return min(a, b);\n",t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.mod=function(t,e){var n=new xe("if (b == 0.0) return NAN;\n return mod(a, b);",t.shape,e.shape),r=n.getCustomSetupFunc();return this.compileAndRun(n,[t,e],null,r)},t.prototype.max=function(t,e){St("max",e,t.rank);var n=bt(t.shape,e),r=n[0],o=d(n[1]),a=t.as2D(-1,o);return this.reduce(a,"max",a.dtype).reshape(r)},t.prototype.maximum=function(t,e){var n=new xe("\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n\n return max(a, b);\n",t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.all=function(t,e){St("all",e,t.rank);var n=bt(t.shape,e),r=n[0],o=d(n[1]),a=t.as2D(-1,o);return this.reduce(a,"all",a.dtype).reshape(r)},t.prototype.any=function(t,e){St("any",e,t.rank);var n=bt(t.shape,e),r=n[0],o=d(n[1]),a=t.as2D(-1,o);return this.reduce(a,"any",a.dtype).reshape(r)},t.prototype.squaredDifference=function(t,e){var n=new xe("return (a - b) * (a - b);",t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.realDivide=function(t,e){var n=new xe("if (a == b) return 1.0;\n return a / b;",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"float32");return this.compileAndRun(n,[t,e],r)},t.prototype.floorDiv=function(t,e){var n=new xe("\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,"int32");return this.compileAndRun(n,[t,e],r)},t.prototype.add=function(t,e){var n=new xe("return a + b;",t.shape,e.shape),r=this.makeOutputArray(n.outputShape,ie(t.dtype,e.dtype));return this.compileAndRun(n,[t,e],r)},t.prototype.addN=function(t){for(var e=t[0],n=1;n 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n");return this.compileAndRun(e,[t])},t.prototype.exp=function(t){var e=new kr(t.shape,"return exp(x);");return this.compileAndRun(e,[t])},t.prototype.expm1=function(t){var e=new kr(t.shape,"return exp(x) - 1.0;");return this.compileAndRun(e,[t])},t.prototype.log=function(t){var e=new kr(t.shape,"if (x < 0.0) return NAN;\n return log(x);"),n=e.getCustomSetupFunc();return this.compileAndRun(e,[t],null,n)},t.prototype.log1p=function(t){var e=new kr(t.shape,"return log(1.0 + x);");return this.compileAndRun(e,[t])},t.prototype.sqrt=function(t){var e=new kr(t.shape,"return sqrt(x);");return this.compileAndRun(e,[t])},t.prototype.rsqrt=function(t){var e=new kr(t.shape,"return inversesqrt(x);");return this.compileAndRun(e,[t])},t.prototype.square=function(t){var e=new kr(t.shape,"return x * x;");return this.compileAndRun(e,[t])},t.prototype.reciprocal=function(t){var e=new kr(t.shape,"return 1.0 / x;");return this.compileAndRun(e,[t])},t.prototype.relu=function(t){var e=new kr(t.shape,Ir);return this.compileAndRun(e,[t])},t.prototype.elu=function(t){var e=new kr(t.shape,"return (x >= 0.0) ? x : (exp(x) - 1.0);");return this.compileAndRun(e,[t])},t.prototype.eluDer=function(t,e){var n=new xe("return (b >= 1.0) ? a : a * (b + 1.0);",t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.selu=function(t){var e=new kr(t.shape,Ar);return this.compileAndRun(e,[t])},t.prototype.int=function(t){var e=new kr(t.shape,"return float(int(x));"),n=this.makeOutputArray(e.outputShape,"int32");return this.compileAndRun(e,[t],n)},t.prototype.clip=function(t,e,n){var r=new be(t.shape,e,n);return this.compileAndRun(r,[t])},t.prototype.abs=function(t){var e=new kr(t.shape,"return abs(x);");return this.compileAndRun(e,[t])},t.prototype.sigmoid=function(t){var e=new kr(t.shape,"return 1.0 / (1.0 + exp(-1.0 * x));");return this.compileAndRun(e,[t])},t.prototype.softplus=function(t){var e=new kr(t.shape,"\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n");return this.compileAndRun(e,[t])},t.prototype.sin=function(t){var e=new kr(t.shape,Dr);return this.compileAndRun(e,[t])},t.prototype.cos=function(t){var e=new kr(t.shape,Nr);return this.compileAndRun(e,[t])},t.prototype.tan=function(t){var e=new kr(t.shape,"return tan(x);");return this.compileAndRun(e,[t])},t.prototype.asin=function(t){var e=new kr(t.shape,"return asin(x);");return this.compileAndRun(e,[t])},t.prototype.acos=function(t){var e=new kr(t.shape,"return acos(x);");return this.compileAndRun(e,[t])},t.prototype.atan=function(t){var e=new kr(t.shape,Mr);return this.compileAndRun(e,[t])},t.prototype.atan2=function(t,e){var n=new xe("\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n\n return atan(a, b);\n",t.shape,e.shape);return this.compileAndRun(n,[t,e])},t.prototype.sinh=function(t){var e=new kr(t.shape,"\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n");return this.compileAndRun(e,[t])},t.prototype.cosh=function(t){var e=new kr(t.shape,"\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n");return this.compileAndRun(e,[t])},t.prototype.tanh=function(t){var e=new kr(t.shape,"\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n");return this.compileAndRun(e,[t])},t.prototype.asinh=function(t){var e=new kr(t.shape,"return log(x + sqrt(x * x + 1.0));");return this.compileAndRun(e,[t])},t.prototype.acosh=function(t){var e=new kr(t.shape,_r),n=e.getCustomSetupFunc();return this.compileAndRun(e,[t],null,n)},t.prototype.atanh=function(t){var e=new kr(t.shape,Or),n=e.getCustomSetupFunc();return this.compileAndRun(e,[t],null,n)},t.prototype.erf=function(t){var e=new kr(t.shape,'\n // Error function is calculated approximately with elementary function.\n // See "Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables", Abramowitz and Stegun.\n float p = 0.3275911;\n float a1 = 0.254829592;\n float a2 = -0.284496736;\n float a3 = 1.421413741;\n float a4 = -1.453152027;\n float a5 = 1.061405429;\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n');return this.compileAndRun(e,[t])},t.prototype.step=function(t,e){var n=new kr(t.shape,function(t){return void 0===t&&(t=0),Tr+"\n return x > 0.0 ? 1.0 : float("+t+");\n "}(e));return this.compileAndRun(n,[t])},t.prototype.conv2d=function(t,e,n){var r=new Te(n);return this.compileAndRun(r,[t,e])},t.prototype.conv2dDerInput=function(t,e,n){var r=new Re(n);return this.compileAndRun(r,[t,e])},t.prototype.conv2dDerFilter=function(t,e,n){var r=new Se(n);return this.compileAndRun(r,[t,e])},t.prototype.depthwiseConv2D=function(t,e,n){var r=new Ie(n);return this.compileAndRun(r,[t,e])},t.prototype.depthwiseConv2DDerInput=function(t,e,n){var r=new ke(n);return this.compileAndRun(r,[t,e])},t.prototype.depthwiseConv2DDerFilter=function(t,e,n){var r=new Ce(n);return this.compileAndRun(r,[t,e])},t.prototype.maxPool=function(t,e){var n=new sr(e,"max",!1),r=this.makeOutputArray(n.outputShape,t.dtype);return this.compileAndRun(n,[t],r)},t.prototype.avgPool=function(t,e){var n=new sr(e,"avg",!1),r=this.makeOutputArray(n.outputShape,"float32");return this.compileAndRun(n,[t],r)},t.prototype.maxPoolBackprop=function(t,e,n,r){var o=new sr(r,"max",!0),a=this.compileAndRun(o,[e]),i=new rr(r),u=this.makeOutputArray(i.outputShape,e.dtype),s=this.compileAndRun(i,[t,a],u);return a.dispose(),s},t.prototype.avgPoolBackprop=function(t,e,n){var r=new de(n),o=this.makeOutputArray(r.outputShape,e.dtype);return this.compileAndRun(r,[t],o)},t.prototype.cast=function(t,e){return se(t,e,this)},t.prototype.reshape=function(t,e){return le(t,e)},t.prototype.resizeBilinear=function(t,e,n,r){var o=new hr(t.shape,e,n,r);return this.compileAndRun(o,[t])},t.prototype.resizeBilinearBackprop=function(t,e,n){var r=new cr(t,e,n);return this.compileAndRun(r,[t])},t.prototype.resizeNearestNeighbor=function(t,e,n,r){var o=new pr(t.shape,e,n,r);return this.compileAndRun(o,[t])},t.prototype.resizeNearestNeighborBackprop=function(t,e,n){var r=new fr(t,e,n);return this.compileAndRun(r,[t])},t.prototype.multinomial=function(t,e,n,r){var o=e?t:Pt(t),a=o.shape[0],i=o.shape[1],u=new ar(a,i,n),s=this.makeOutputArray(u.outputShape,"int32"),l=u.getCustomSetupFunc(r);return this.compileAndRun(u,[o],s,l)},t.prototype.oneHot=function(t,e,n,r){var o=new ir(t.size,e,n,r);return this.compileAndRun(o,[t])},t.prototype.nonMaxSuppression=function(t,e,n,r,o){return pt("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead"),ce(t.dataSync(),e.dataSync(),n,r,o)},t.prototype.makeOutputArray=function(t,e){return X.make(t,{},e)},t.prototype.compileAndRun=function(t,e,n,r,o){var a=this;void 0===o&&(o=!0),null==n&&(n=this.makeOutputArray(t.outputShape,e[0].dtype));var i=e.map(function(t){var e=a.texData.get(t.dataId);return null==e.texture&&t.size<=32?{tensor:t,texData:null,isUniform:!0}:(a.uploadToGPU(t.dataId),{tensor:t,texData:e,isUniform:!1})});this.uploadToGPU(n.dataId);var u,s={tensor:n,texData:this.texData.get(n.dataId),isUniform:!1},l=function(t,e,n){var r="";e.concat(n).forEach(function(t){r+=t.tensor.shape+"_"+(t.isUniform?"uniform":t.texData.texShape)});var o=t.userCode,a=(!0===t.supportsBroadcasting).toString(),i=t.constructor.name;return i+="_"+a+"_"+r+"_"+o}(t,i,s),c=this.getAndSaveBinary(l,function(){return function(t,e,n,r){for(var o=e.userCode,a=n.map(function(t,n){var r={logicalShape:t.tensor.shape,texShape:t.isUniform?null:t.texData.texShape,isUniform:t.isUniform};return{name:e.variableNames[n],shapeInfo:r}}),i=a.map(function(t){return t.shapeInfo}),u={logicalShape:r.tensor.shape,texShape:r.texData.texShape,isUniform:!1},s=Ae(a,u,o,!0===e.supportsBroadcasting),l=t.createProgram(s),c={},h=0;hthis.NUM_BYTES_BEFORE_PAGING)for(var f=this.numBytesInGPU-this.NUM_BYTES_BEFORE_PAGING;f>0&&this.lruDataGPU.length>0;){var p=this.lruDataGPU.shift(),d=this.texData.get(p),v=d.shape,m=d.dtype;f-=this.computeBytes(v,m),this.read(p)}return h&&(u=this.endTimer(u),this.activeTimers.push(this.getQueryTime(u))),n},t.prototype.getAndSaveBinary=function(t,e){return t in this.binaryCache||(this.binaryCache[t]=e()),this.binaryCache[t]},t.prototype.getTextureManager=function(){return this.textureManager},t.prototype.dispose=function(){if(!this.disposed){for(var t in this.binaryCache)this.gpgpu.deleteProgram(this.binaryCache[t].webGLProgram);this.textureManager.dispose(),this.canvas.remove(),null!=this.fromPixelsCanvas&&this.fromPixelsCanvas.remove(),this.gpgpuCreatedLocally&&this.gpgpu.dispose(),this.disposed=!0}},t.prototype.throwIfNoData=function(t){if(!this.texData.has(t))throw new Error("WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends")},t.prototype.uploadToGPU=function(t){this.throwIfNoData(t);var e=this.texData.get(t),n=e.shape,r=e.values,o=e.texture,a=(e.dtype,e.usage);if(null==o){var i,u=null!=this.activeTimers;u&&(i=performance.now());var s=An(this.gpgpu.gl,n);e.texShape=s;var l,c=this.acquireTexture(t,s,a);e.texture=c,null!=r&&(this.gpgpu.uploadMatrixToTexture(c,s[0],s[1],(l=r)instanceof Float32Array?l:new Float32Array(l)),e.values=null,u&&(this.uploadWaitMs+=performance.now()-i))}else{this.lruDataGPU.indexOf(t)>=0&&(this.lruDataGPU.splice(this.lruDataGPU.indexOf(t),1),this.lruDataGPU.push(t))}},t.prototype.cacheOnCPU=function(t,e){var n=this.delayedStorage,r=this.texData.get(t),o=r.texture,a=r.texShape,i=r.dtype,u=r.usage;n&&null!=o&&(this.releaseTexture(t,o,a,u),r.texture=null,r.texShape=null),null!=e&&(r.values=function(t,e){if("float32"===e)return t;if("int32"===e||"bool"===e){for(var n="int32"===e?new Int32Array(t.length):new Uint8Array(t.length),r=0;r=0&&this.lruDataGPU.splice(u,1),this.numBytesInGPU-=this.computeBytes(a,i),this.textureManager.releaseTexture(e,n,r)},t.prototype.acquireTexture=function(t,e,n){var r=this.texData.get(t),o=r.shape,a=r.dtype;return this.lruDataGPU.push(t),this.numBytesInGPU+=this.computeBytes(o,a),this.textureManager.acquireTexture(e,n)},t.prototype.computeBytes=function(t,e){return d(t)*I(e)},t}();ht.get("IS_BROWSER")&&ht.registerBackend("webgl",function(){return new Io},2,j);var Ao=Bt({abs_:function(t){var e=Ft(t,"x","abs");return ht.engine.runKernel(function(t){return t.abs(e)},{$x:e},function(t){return{$x:function(){return t.mulStrict(e.toFloat().step(-1))}}})}}),Do=Bt({acos_:function(t){var e=Ft(t,"x","acos");return ht.engine.runKernel(function(t){return t.acos(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(zt(1).sub(e.toFloat().square()).sqrt()).neg()}}})}}),No=Bt({acosh_:function(t){var e=Ft(t,"x","acosh");return ht.engine.runKernel(function(t){return t.acosh(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.toFloat().square().sub(zt(1)).sqrt())}}})}}),Mo=Bt({asin_:function(t){var e=Ft(t,"x","asin");return ht.engine.runKernel(function(t){return t.asin(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(zt(1).sub(e.toFloat().square()).sqrt())}}})}}),_o=Bt({asinh_:function(t){var e=Ft(t,"x","asinh");return ht.engine.runKernel(function(t){return t.asinh(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(zt(1).add(e.toFloat().square()).sqrt())}}})}}),Oo=Bt({atan_:function(t){var e=Ft(t,"x","atan");return ht.engine.runKernel(function(t){return t.atan(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(zt(1).add(e.toFloat().square()))}}})}}),Fo=Bt({atanh_:function(t){var e=Ft(t,"x","atanh");return ht.engine.runKernel(function(t){return t.atanh(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(zt(1).sub(e.toFloat().square()))}}})}}),Lo=Bt({ceil_:function(t){var e=Ft(t,"x","ceil");return ht.engine.runKernel(function(t){return t.ceil(e)},{$x:e},function(t){return{$x:function(){return oe(t)}}})}}),Bo=Bt({clipByValue_:function(t,e,n){var r=Ft(t,"x","clipByValue");return l(e<=n,"Error in clip: min ("+e+") must be less than or equal to max ("+n+")."),ht.engine.runKernel(function(t){return t.clip(r,e,n)},{$x:r},function(t){return{$x:function(){return t.where(r.greaterEqual(zt(e)).logicalAnd(r.lessEqual(zt(n))),oe(t))}}})}}),Po=Bt({cos_:function(t){var e=Ft(t,"x","cos");return ht.engine.runKernel(function(t){return t.cos(e)},{$x:e},function(t){return{$x:function(){return e.toFloat().sin().neg().mulStrict(t)}}})}}),Uo=Bt({cosh_:function(t){var e=Ft(t,"x","cosh");return ht.engine.runKernel(function(t){return t.cosh(e)},{$x:e},function(t){return{$x:function(){return e.toFloat().sinh().mulStrict(t)}}})}}),zo=Bt({erf_:function(t){var e=Ft(t,"x","erf");return l("int32"===e.dtype||"float32"===e.dtype,"Input dtype must be `int32` or `float32`."),"int32"===e.dtype&&(e=e.toFloat()),ht.engine.runKernel(function(t){return t.erf(e)},{$x:e},function(t){return{$x:function(){return t.mulStrict(zt(2/Math.sqrt(Math.PI)).mul(e.square().neg().exp()))}}})}}),Vo=Bt({exp_:function(t){var e=Ft(t,"x","exp");return ht.engine.runKernel(function(t,n){return n(t.exp(e))},{$x:e},function(t,e){var n=e[0];return{$x:function(){return t.mulStrict(n)}}})}}),Wo=Bt({expm1_:function(t){var e=Ft(t,"x","expm1");return ht.engine.runKernel(function(t){return t.expm1(e)},{$x:e},function(t){return{$x:function(){return t.mulStrict(e.exp())}}})}}),Go=Bt({floor_:function(t){var e=Ft(t,"x","floor");return ht.engine.runKernel(function(t){return t.floor(e)},{$x:e},function(t){return{$x:function(){return oe(t)}}})}}),qo=Bt({log_:function(t){var e=Ft(t,"x","log");return ht.engine.runKernel(function(t){return t.log(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.toFloat())}}})}}),Ho=Bt({log1p_:function(t){var e=Ft(t,"x","log1p");return ht.engine.runKernel(function(t){return t.log1p(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.add(zt(1)))}}})}}),$o=Bt({logSigmoid_:function(t){var e=Ft(t,"x","logSigmoid");return ht.engine.runKernel(function(t){return t.softplus(e.neg()).neg()},{$x:e},function(t){return{$x:function(){return t.mulStrict(e.neg().sigmoid())}}})}}),jo=Bt({neg_:function(t){var e=Ft(t,"x","neg");return ht.engine.runKernel(function(t){return t.neg(e)},{$x:e},function(t){return{$x:function(){return t.neg()}}})}}),Xo=Bt({reciprocal_:function(t){var e=Ft(t,"x","reciprocal");return ht.engine.runKernel(function(t){return t.reciprocal(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.square().neg())}}})}}),Ko=Bt({round_:function(t){var e=Ft(t,"x","round");return ht.engine.runKernel(function(t){return t.round(e)},{$x:e},function(t){return{$x:function(){return oe(t)}}})}}),Yo=Bt({rsqrt_:function(t){var e=Ft(t,"x","rsqrt");return ht.engine.runKernel(function(t){return t.rsqrt(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.pow(zt(1.5)).mul(zt(2))).neg()}}})}}),Qo=Bt({sigmoid_:function(t){var e=Ft(t,"x","sigmoid");return ht.engine.runKernel(function(t,n){return n(t.sigmoid(e))},{$x:e},function(t,e){var n=e[0];return{$x:function(){return t.mulStrict(n.mul(zt(1).sub(n)))}}})}}),Jo=Bt({sign_:function(t){var e=Ft(t,"x","sign");return ht.engine.runKernel(function(t){return t.sign(e)},{$x:e},function(t){return{$x:function(){return oe(t)}}})}}),Zo=Bt({sin_:function(t){var e=Ft(t,"x","sin");return ht.engine.runKernel(function(t){return t.sin(e)},{$x:e},function(t){return{$x:function(){return e.toFloat().cos().mulStrict(t)}}})}}),ta=Bt({sinh_:function(t){var e=Ft(t,"x","sinh");return ht.engine.runKernel(function(t){return t.sinh(e)},{$x:e},function(t){return{$x:function(){return e.toFloat().cosh().mulStrict(t)}}})}}),ea=Bt({softplus_:function(t){var e=Ft(t,"x","softplus");return ht.engine.runKernel(function(t){return t.softplus(e)},{$x:e},function(t){return{$x:function(){return t.mulStrict(e.sigmoid())}}})}}),na=Bt({sqrt_:function(t){var e=Ft(t,"x","sqrt");return ht.engine.runKernel(function(t){return t.sqrt(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.toFloat().sqrt().mul(zt(2)))}}})}}),ra=Bt({square_:function(t){var e=Ft(t,"x","square");return ht.engine.runKernel(function(t){return t.square(e)},{$x:e},function(t){return{$x:function(){return t.mulStrict(e.toFloat().mul(zt(2)))}}})}}),oa=Bt({step_:function(t,e){void 0===e&&(e=0);var n=Ft(t,"x","step");return ht.engine.runKernel(function(t){return t.step(n,e)},{$x:n},function(t){return{$x:function(){return oe(t)}}})}}),aa=Bt({tan_:function(t){var e=Ft(t,"x","tan");return ht.engine.runKernel(function(t){return t.tan(e)},{$x:e},function(t){return{$x:function(){return t.divStrict(e.cos().square())}}})}}),ia=Bt({tanh_:function(t){var e=Ft(t,"x","tanh");return ht.engine.runKernel(function(t,n){return n(t.tanh(e))},{$x:e},function(t,e){var n=e[0];return{$x:function(){return zt(1).sub(n.square()).mulStrict(t)}}})}});function ua(t){return null==t?null:0===t.rank?t.as1D():1===t.rank?t:2===t.rank?t.as4D(1,1,t.shape[0],t.shape[1]):3===t.rank?t.as4D(1,t.shape[0],t.shape[1],t.shape[2]):t}var sa=Bt({batchNormalization2d_:function(t,e,n,r,o,a){void 0===r&&(r=.001);var i,u,s=Ft(t,"x","batchNormalization"),c=Ft(e,"mean","batchNormalization"),h=Ft(n,"variance","batchNormalization");return null!=o&&(i=Ft(o,"scale","batchNormalization")),null!=a&&(u=Ft(a,"offset","batchNormalization")),l(2===s.rank,"Error in batchNormalization3D: x must be rank 3 but got rank "+s.rank+"."),l(2===c.rank||1===c.rank,"Error in batchNormalization2D: mean must be rank 2 or rank 1 but got rank "+c.rank+"."),l(2===h.rank||1===h.rank,"Error in batchNormalization2D: variance must be rank 2 or rank 1 but got rank "+h.rank+"."),null!=i&&l(2===i.rank||1===i.rank,"Error in batchNormalization2D: scale must be rank 2 or rank 1 but got rank "+i.rank+"."),null!=u&&l(2===u.rank||1===u.rank,"Error in batchNormalization2D: offset must be rank 2 or rank 1 but got rank "+u.rank+"."),ha(s,c,h,r,i,u)}}),la=Bt({batchNormalization3d_:function(t,e,n,r,o,a){void 0===r&&(r=.001);var i,u,s=Ft(t,"x","batchNormalization"),c=Ft(e,"mean","batchNormalization"),h=Ft(n,"variance","batchNormalization");return null!=o&&(i=Ft(o,"scale","batchNormalization")),null!=a&&(u=Ft(a,"offset","batchNormalization")),l(3===s.rank,"Error in batchNormalization3D: x must be rank 3 but got rank "+s.rank+"."),l(3===c.rank||1===c.rank,"Error in batchNormalization3D: mean must be rank 3 or rank 1 but got rank "+c.rank+"."),l(3===h.rank||1===h.rank,"Error in batchNormalization3D: variance must be rank 3 or rank 1 but got rank "+h.rank+"."),null!=i&&l(3===i.rank||1===i.rank,"Error in batchNormalization3D: scale must be rank 3 or rank 1 but got rank "+i.rank+"."),null!=u&&l(3===u.rank||1===u.rank,"Error in batchNormalization3D: offset must be rank 3 or rank 1 but got rank "+u.rank+"."),ha(s,c,h,r,i,u)}}),ca=Bt({batchNormalization4d_:function(t,e,n,r,o,a){void 0===r&&(r=.001);var i,u,s=Ft(t,"x","batchNormalization"),c=Ft(e,"mean","batchNormalization"),h=Ft(n,"variance","batchNormalization");return null!=o&&(i=Ft(o,"scale","batchNormalization")),null!=a&&(u=Ft(a,"offset","batchNormalization")),l(4===s.rank,"Error in batchNormalization4D: x must be rank 4 but got rank "+s.rank+"."),l(4===c.rank||1===c.rank,"Error in batchNormalization4D: mean must be rank 4 or rank 1 but got rank "+c.rank+"."),l(4===h.rank||1===h.rank,"Error in batchNormalization4D: variance must be rank 4 or rank 1 but got rank "+h.rank+"."),null!=i&&l(4===i.rank||1===i.rank,"Error in batchNormalization4D: scale must be rank 4 or rank 1 but got rank "+i.rank+"."),null!=u&&l(4===u.rank||1===u.rank,"Error in batchNormalization4D: offset must be rank 4 or rank 1 but got rank "+u.rank+"."),ha(s,c,h,r,i,u)}}),ha=Bt({batchNormalization_:function(t,e,n,r,o,a){void 0===r&&(r=.001);var i,u,s,c=Ft(t,"x","batchNormalization"),h=Ft(e,"mean","batchNormalization"),f=Ft(n,"variance","batchNormalization");return null!=o&&(i=Ft(o,"scale","batchNormalization")),null!=a&&(u=Ft(a,"offset","batchNormalization")),l(h.rank===f.rank,"Batch normalization gradient requires mean and variance to have equal ranks."),l(null==u||h.rank===u.rank,"Batch normalization gradient requires mean and offset to have equal ranks."),l(null==i||h.rank===i.rank,"Batch normalization gradient requires mean and scale to have equal ranks."),s=0===c.rank||1===c.rank?c.as4D(1,1,1,c.size):2===c.rank?c.as4D(1,1,c.shape[0],c.shape[1]):3===c.rank?c.as4D(1,c.shape[0],c.shape[1],c.shape[2]):c,ht.engine.runKernel(function(t){return t.batchNormalization(s,ua(h),ua(f),r,ua(i),ua(u))},{$x:c,$mean:h,$variance:f,$scale:i,$offset:u},function(t){var e=null==i?zt(1):i,n=me(h.shape,s.shape),o=[];if(1===h.rank){for(var a=0;a=0?t:(l(-1===t,"Bad value in size"),a.shape[e]-r[e])}),function(t,e,n){l(t.rank===e.length,"Error in slice"+t.rank+"D: Length of begin "+e+" must match the rank of the array ("+t.rank+")."),l(t.rank===n.length,"Error in slice"+t.rank+"D: Length of size "+n+" must match the rank of the array ("+t.rank+").");for(var r=0;r0&&(e=e.sum(r)),e.reshape(n.shape)},$b:function(){var e=t,n=me(r.shape,o);return n.length>0&&(e=e.sum(n)),e.reshape(r.shape)}}})}}),pi=Bt({addN_:function(t){l(Array.isArray(t),function(){return"The param passed to tf.addN() must be a list of tensors"}),l(t.length>=1,function(){return"Must pass at least one tensor to tf.addN(), but got "+t.length});var e=t.map(function(t,e){return Ft(t,"tensors"+e,"addN")}),n=e[0];e.forEach(function(t){if(t.dtype!==n.dtype)throw new Error("All tensors passed to tf.addN() must have the same dtype")}),e.forEach(function(t){if(!v(t.shape,n.shape))throw new Error("All tensors passed to tf.addN() must have the same shape")});var r=e;return ht.engine.runKernel(function(t){return t.addN(e)},r,function(t){var n={};return e.forEach(function(e,r){n[r]=function(){return t.clone()}}),n})}}),di=Bt({addStrict_:function(t,e){return c(t.shape,e.shape,"Error in addStrict: "),t.add(e)}}),vi=Bt({atan2_:function(t,e){var n=Ft(t,"a","atan2"),r=Ft(e,"b","atan2");Q(n,r);var o=ge(n.shape,r.shape);return ht.engine.runKernel(function(t){return t.atan2(n,r)},{$a:n,$b:r},function(t){return{$a:function(){var e=fi(n.square(),r.square()),a=t.mul(r.div(e)),i=me(n.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(n.shape)},$b:function(){var e=fi(n.square(),r.square()),a=jo(t.mul(n.div(e))),i=me(r.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(r.shape)}}})}}),mi=Bt({div_:function(t,e){var n,r=Ft(t,"a","div"),o=Ft(e,"b","div");if(Q(r,o),"int32"===r.dtype&&"int32"===o.dtype)return yi(r,o);n=function(t){return t.realDivide(r,o)};var a=ge(r.shape,o.shape);return ht.engine.runKernel(n,{$a:r,$b:o},function(t){return{$a:function(){var e=t.div(o.toFloat()),n=me(r.shape,a);return n.length>0?e.sum(n).reshape(r.shape):e},$b:function(){var e=t.mul(r.toFloat()),n=me(o.shape,a);n.length>0&&(e=e.sum(n).reshape(o.shape));var i=o.square();return e.div(i.toFloat()).neg()}}})}}),gi=Bt({divStrict_:function(t,e){return c(t.shape,e.shape,"Error in divideStrict: "),t.div(e)}}),yi=Bt({floorDiv_:function(t,e){var n=Ft(t,"a","floorDiv"),r=Ft(e,"b","floorDiv");Q(n,r);var o=ge(n.shape,r.shape);return ht.engine.runKernel(function(t){return t.floorDiv(n,r)},{$a:n,$b:r},function(t){return{$a:function(){var e=t.div(r.toFloat()),a=me(n.shape,o);return a.length>0?e.sum(a).reshape(n.shape):e},$b:function(){var e=t.mul(n.toFloat()),a=me(r.shape,o);a.length>0&&(e=e.sum(a).reshape(r.shape));var i=r.square();return e.div(i.toFloat()).neg()}}})}}),xi=Bt({maximum_:function(t,e){var n=Ft(t,"a","maximum"),r=Ft(e,"b","maximum");return Q(n,r),"bool"===n.dtype&&(n=n.toInt()),"bool"===r.dtype&&(r=r.toInt()),ge(n.shape,r.shape),ht.engine.runKernel(function(t){return t.maximum(n,r)},{$a:n,$b:r},function(t){return{$a:function(){return t.mul(n.greaterEqual(r).toFloat())},$b:function(){return t.mul(n.less(r).toFloat())}}})}}),bi=Bt({maximumStrict_:function(t,e){return c(t.shape,e.shape,"Error in minimumStrict: "),t.maximum(e)}}),wi=Bt({minimum_:function(t,e){var n=Ft(t,"a","minimum"),r=Ft(e,"b","minimum");return Q(n,r),"bool"===n.dtype&&(n=n.toInt()),"bool"===r.dtype&&(r=r.toInt()),ge(n.shape,r.shape),ht.engine.runKernel(function(t){return t.minimum(n,r)},{$a:n,$b:r},function(t){return{$a:function(){return t.mul(n.lessEqual(r).toFloat())},$b:function(){return t.mul(n.greater(r).toFloat())}}})}}),Ei=Bt({minimumStrict_:function(t,e){return c(t.shape,e.shape,"Error in minimumStrict: "),t.minimum(e)}}),Si=Bt({mod_:function(t,e){var n=Ft(t,"a","mod"),r=Ft(e,"b","mod");Q(n,r);var o=ge(n.shape,r.shape);return ht.engine.runKernel(function(t){return t.mod(n,r)},{$a:n,$b:r},function(t){return{$a:function(){var e=me(n.shape,o);return e.length>0?t.sum(e).reshape(n.shape):t},$b:function(){var e=t.mul(n.div(r).floor().neg()),a=me(r.shape,o);return a.length>0?e.sum(a).reshape(r.shape):e}}})}}),Ri=Bt({modStrict_:function(t,e){return c(t.shape,e.shape,"Error in modStrict: "),t.mod(e)}}),Ci=Bt({mul_:function(t,e){var n=Ft(t,"a","mul"),r=Ft(e,"b","mul");Q(n,r);var o=ge(n.shape,r.shape);return ht.engine.runKernel(function(t){return t.multiply(n,r)},{$a:n,$b:r},function(t){return{$a:function(){var e=t.mul(r.toFloat()),a=me(n.shape,o);return a.length>0?e.sum(a).reshape(n.shape):e},$b:function(){var e=t.mul(n.toFloat()),a=me(r.shape,o);return a.length>0?e.sum(a).reshape(r.shape):e}}})}}),ki=Bt({mulStrict_:function(t,e){return c(t.shape,e.shape,"Error in multiplyStrict: "),t.mul(e)}}),Ti=Bt({pow_:function(t,e){var n=Ft(t,"base","pow"),r=Ft(e,"exp","pow"),o=ge(n.shape,r.shape);return t=n.cast(ie(n.dtype,r.dtype)),e=r.cast(ie(n.dtype,r.dtype)),ht.engine.runKernel(function(t,e){return e(t.pow(n,r))},{$base:n,$exp:r},function(t,e){var a=e[0];return{$base:function(){var e=t.mul(r.toFloat().mul(a.div(n))),i=me(n.shape,o);return i.length>0&&(e=e.sum(i)),e.reshape(n.shape)},$exp:function(){var e=t.mul(a.mul(n.log()).toFloat()),i=me(r.shape,o);return i.length>0&&(e=e.sum(i)),e.reshape(r.shape)}}})}}),Ii=Bt({powStrict_:function(t,e){return c(t.shape,e.shape,"Error in powStrict: "),t.pow(e)}}),Ai=Bt({squaredDifference_:function(t,e){var n=Ft(t,"a","squaredDifference"),r=Ft(e,"b","squaredDifference");return Q(n,r),ge(n.shape,r.shape),ht.engine.runKernel(function(t){return t.squaredDifference(n,r)},{$a:n,$b:r},function(t){var e=zt(2);return{$a:function(){return t.mul(n.sub(r).mul(e))},$b:function(){return t.mul(r.sub(n).mul(e))}}})}}),Di=Bt({squaredDifferenceStrict_:function(t,e){return c(t.shape,e.shape,"Error in squaredDifferenceStrict: "),t.squaredDifference(e)}}),Ni=Bt({sub_:function(t,e){var n=Ft(t,"a","sub"),r=Ft(e,"b","sub");Q(n,r);var o=ge(n.shape,r.shape);return ht.engine.runKernel(function(t){return t.subtract(n,r)},{$a:n,$b:r},function(t){return{$a:function(){var e=t,r=me(n.shape,o);return r.length>0&&(e=e.sum(r)),e.reshape(n.shape)},$b:function(){var e=t,n=me(r.shape,o);return n.length>0&&(e=e.sum(n)),e.neg().reshape(r.shape)}}})}}),Mi=Bt({subStrict_:function(t,e){return c(t.shape,e.shape,"Error in subStrict: "),t.sub(e)}});var _i=Bt({logicalAnd_:function(t,e){var n=Ft(t,"a","logicalAnd","bool"),r=Ft(e,"b","logicalAnd","bool");return l("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),ge(n.shape,r.shape),ht.engine.runKernel(function(t){return t.logicalAnd(n,r)},{$a:n,$b:r})}}),Oi=Bt({logicalNot_:function(t){var e=Ft(t,"x","logicalNot","bool");return l("bool"===e.dtype,"Error Array must be of type bool."),ht.engine.runKernel(function(t){return t.logicalNot(e)},{$x:e})}}),Fi=Bt({logicalOr_:function(t,e){var n=Ft(t,"a","logicalOr","bool"),r=Ft(e,"b","logicalOr","bool");return l("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),ge(n.shape,r.shape),ht.engine.runKernel(function(t){return t.logicalOr(n,r)},{$a:n,$b:r})}}),Li=Bt({logicalXor_:function(t,e){var n=Ft(t,"a","logicalXor","bool"),r=Ft(e,"b","logicalXor","bool");return l("bool"===n.dtype&&"bool"===r.dtype,"Error Array must be of type bool."),ge(n.shape,r.shape),Fi(t,e).logicalAnd(_i(t,e).logicalNot())}}),Bi=Bt({where_:function(t,e,n){var r=Ft(e,"a","where"),o=Ft(n,"b","where"),a=Ft(t,"condition","where","bool");return l("bool"===a.dtype,"Error Condition must be of type bool."),c(r.shape,o.shape,"Error in where: "),1===a.rank?l(a.shape[0]===r.shape[0],"The first dimension of `a` must match the size of `condition`."):c(a.shape,o.shape,"Error in where: "),ht.engine.runKernel(function(t){return t.select(a,r,o)},{$condition:a,$a:r,$b:o},function(t){return{$condition:function(){return oe(a)},$a:function(){return t.mul(a.cast(r.dtype))},$b:function(){return t.mul(a.logicalNot().cast(o.dtype))}}})}}),Pi=function(t){return o(this,void 0,void 0,function(){var e,n,r;return a(this,function(o){switch(o.label){case 0:return l("bool"===(e=Ft(t,"condition","where","bool")).dtype,"Condition must be of type bool."),[4,e.data()];case 1:return n=o.sent(),r=ko(e.shape,n),t!==e&&e.dispose(),[2,r]}})})};var Ui=Bt({elu_:function(t){var e=Ft(t,"x","elu");return ht.engine.runKernel(function(t,n){return n(t.elu(e))},{$x:e},function(t,e){var n=e[0];return{$x:function(){return ht.engine.runKernel(function(e){return e.eluDer(t,n)},{dy:t,y:n})}}})}}),zi=Bt({leakyRelu_:function(t,e){void 0===e&&(e=.2);var n=Ft(t,"x","leakyRelu");return xi(zt(e).mul(n),n)}}),Vi=Bt({prelu_:function(t,e){var n=Ft(t,"x","prelu"),r=Ft(e,"alpha","prelu"),o=zt(0);return xi(o,n).add(r.mul(wi(o,n)))}}),Wi=Bt({relu_:function(t){var e=Ft(t,"x","relu");return"bool"===e.dtype?e.toInt():ht.engine.runKernel(function(t){return t.relu(e)},{$x:e},function(t){var n=e.step();return{$x:function(){return t.mulStrict(n.toFloat())}}})}}),Gi=Bt({selu_:function(t){var e=Ft(t,"x","selu");return ht.engine.runKernel(function(t){return t.selu(e)},{$x:e},function(t){return{$x:function(){var n=e.greater(zt(0)),r=zt(Rr),o=zt(Cr),a=t.mul(o),i=t.mul(r).mul(e.toFloat().exp());return Bi(n,a,i)}}})}});var qi=Bt({transpose_:function(t,e){var n=Ft(t,"x","transpose");return null==e&&(e=n.shape.map(function(t,e){return e}).reverse()),l(n.rank===e.length,"Error in transpose: rank of input "+n.rank+" must match length of perm "+e+"."),e.forEach(function(t){l(t>=0&&to)throw new Error("'k' passed to topk() must be <= the last dimension ("+o+") but got "+e);var a=ht.engine.runKernel(function(t){return t.topk(r,e,n)},{$x:r});return{values:a[0],indices:a[1]}}});(eu=t.Reduction||(t.Reduction={}))[eu.NONE=0]="NONE",eu[eu.MEAN=1]="MEAN",eu[eu.SUM=2]="SUM",eu[eu.SUM_BY_NONZERO_WEIGHTS=3]="SUM_BY_NONZERO_WEIGHTS";var ru=Bt({absoluteDifference_:function(e,n,r,o){void 0===o&&(o=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=Ft(e,"labels","absoluteDifference"),i=Ft(n,"predictions","absoluteDifference"),u=null;null!=r&&(u=Ft(r,"weights","absoluteDifference")),c(a.shape,i.shape,"Error in absoluteDifference: ");var s=a.sub(i).abs();return ou(s,u,o)}}),ou=Bt({computeWeightedLoss_:function(e,n,r){void 0===r&&(r=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=Ft(e,"losses","computeWeightedLoss"),a=null;null!=n&&(a=Ft(n,"weights","computeWeightedLoss"));var i=null==a?o:o.mul(a);if(r===t.Reduction.NONE)return i;if(r===t.Reduction.SUM)return i.sum();if(r===t.Reduction.MEAN){if(null==a)return i.mean();var u=d(o.shape)/d(a.shape),s=i.sum().div(a.sum());return u>1?s.div(zt(u)):s}if(r===t.Reduction.SUM_BY_NONZERO_WEIGHTS){if(null==a)return i.sum().div(zt(o.size));var l=a.mul(jt(o.shape)).notEqual(zt(0)).sum().toFloat();return i.sum().div(l)}throw Error("Unknown reduction: "+r)}}),au=Bt({cosineDistance_:function(e,n,r,o,a){void 0===a&&(a=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var i=Ft(e,"labels","cosineDistance"),u=Ft(n,"predictions","cosineDistance"),s=null;null!=o&&(s=Ft(o,"weights","cosineDistance")),c(i.shape,u.shape,"Error in cosineDistance: ");var l=zt(1).sub(i.mul(u).sum(r,!0));return ou(l,s,a)}}),iu=Bt({hingeLoss_:function(e,n,r,o){void 0===o&&(o=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=Ft(e,"labels","hingeLoss"),i=Ft(n,"predictions","hingeLoss"),u=null;null!=r&&(u=Ft(r,"weights","hingeLoss")),c(a.shape,i.shape,"Error in hingeLoss: ");var s=zt(1);a=zt(2).mul(a).sub(s);var l=s.sub(a.mul(i)).relu();return ou(l,u,o)}}),uu=Bt({huberLoss_:function(e,n,r,o,a){void 0===o&&(o=1),void 0===a&&(a=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var i=Ft(e,"labels","huberLoss"),u=Ft(n,"predictions","huberLoss"),s=null;null!=r&&(s=Ft(r,"weights","huberLoss")),c(i.shape,u.shape,"Error in huberLoss: ");var l=zt(o),h=u.sub(i).abs(),f=wi(h,l),p=h.sub(f),d=zt(.5).mul(f.square()).add(l.mul(p));return ou(d,s,a)}}),su=Bt({logLoss_:function(e,n,r,o,a){void 0===o&&(o=1e-7),void 0===a&&(a=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var i=Ft(e,"labels","logLoss"),u=Ft(n,"predictions","logLoss"),s=null;null!=r&&(s=Ft(r,"weights","logLoss")),c(i.shape,u.shape,"Error in logLoss: ");var l=zt(1),h=zt(o),f=i.mul(u.add(h).log()).neg().sub(l.sub(i).mul(l.sub(u).add(h).log()));return ou(f,s,a)}}),lu=Bt({meanSquaredError_:function(e,n,r,o){void 0===o&&(o=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=Ft(e,"labels","meanSquaredError"),i=Ft(n,"predictions","meanSquaredError"),u=null;null!=r&&(u=Ft(r,"weights","meanSquaredError")),c(a.shape,i.shape,"Error in meanSquaredError: ");var s=a.squaredDifference(i);return ou(s,u,o)}}),cu=Bt({sigmoidCrossEntropy_:function(e,n,r,o,a){void 0===o&&(o=0),void 0===a&&(a=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var i=Ft(e,"multiClassLabels","sigmoidCrossEntropy"),u=Ft(n,"logits","sigmoidCrossEntropy"),s=null;if(null!=r&&(s=Ft(r,"weights","sigmoidCrossEntropy")),c(i.shape,u.shape,"Error in sigmoidCrossEntropy: "),o>0){var l=zt(o),h=zt(1),f=zt(.5);i=i.mul(h.sub(l)).add(f.mul(l))}var p=function(t,e){var n=Ft(t,"labels","sigmoidCrossEntropyWithLogits"),r=Ft(e,"logits","sigmoidCrossEntropyWithLogits");c(n.shape,r.shape,"Error in sigmoidCrossEntropyWithLogits: ");var o=r.relu(),a=r.mul(n),i=r.abs().neg().exp().log1p();return o.sub(a).add(i)}(i,u);return ou(p,s,a)}}),hu=Bt({softmaxCrossEntropy_:function(e,n,r,o,a){void 0===o&&(o=0),void 0===a&&(a=t.Reduction.SUM_BY_NONZERO_WEIGHTS);var i=Ft(e,"onehotLabels","softmaxCrossEntropy"),u=Ft(n,"logits","softmaxCrossEntropy"),s=null;if(null!=r&&(s=Ft(r,"weights","softmaxCrossEntropy")),c(i.shape,u.shape,"Error in softmaxCrossEntropy: "),o>0){var l=zt(o),h=zt(1),f=zt(i.shape[1]);i=i.mul(h.sub(l)).add(l.div(f))}var p=function(t,e,n){if(void 0===n&&(n=-1),-1===n&&(n=e.rank-1),n!==e.rank-1)throw Error("Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank "+e.rank+" and dim was "+n);return _t(function(t,e){var r=e.logSumExp([n],!0),o=e.toFloat().sub(r);return{value:o.mul(t).neg().sum([n]),gradFunc:function(e){var r=wt(e.shape,[n]);return[e.reshape(r).mul(t.toFloat().sub(o.exp())),e.reshape(r).mul(o.exp().sub(t.toFloat()))]}}})(t,e)}(i,u);return ou(p,s,a)}}),fu=Object.freeze({get Reduction(){return t.Reduction},absoluteDifference:ru,computeWeightedLoss:ou,cosineDistance:au,hingeLoss:iu,huberLoss:uu,logLoss:su,meanSquaredError:lu,sigmoidCrossEntropy:cu,softmaxCrossEntropy:hu});function pu(t,e){return void 0===e&&(e=!1),ht.engine.tidy(function(){if(2!==t.shape.length)throw new Error("qr2d() requires a 2D Tensor, but got a "+t.shape.length+"D Tensor.");for(var n=t.shape[0],r=t.shape[1],o=oo(n),a=t.clone(),i=Wt([[1]],[1,1]),u=i.clone(),s=n>=r?r:n,l=function(t){var e,s=a,l=u,c=o;e=ht.engine.tidy(function(){var e=a.slice([t,t],[n-t,1]),s=e.norm(),l=a.slice([t,t],[1,1]),c=l.sign().neg(),h=l.sub(c.mul(s)),f=e.div(h);u=1===f.shape[0]?i.clone():i.concat(f.slice([1,0],[f.shape[0]-1,f.shape[1]]),0);var p=c.matMul(h).div(s).neg(),d=a.slice([t,0],[n-t,r]),v=p.mul(u);a=0===t?d.sub(v.matMul(u.transpose().matMul(d))):a.slice([0,0],[t,r]).concat(d.sub(v.matMul(u.transpose().matMul(d))),0);var m=o.slice([0,t],[n,o.shape[1]-t]);return o=0===t?m.sub(m.matMul(u).matMul(v.transpose())):o.slice([0,0],[n,t]).concat(m.sub(m.matMul(u).matMul(v.transpose())),1),[u,a,o]}),u=e[0],a=e[1],o=e[2],Wa([s,l,c])},c=0;cr&&(o=o.slice([0,0],[n,r]),a=a.slice([0,0],[r,r])),[o,a]})}var du=Bt({gramSchmidt_:function(t){var e;if(Array.isArray(t)){e=!1,l(null!=t&&t.length>0,"Gram-Schmidt process: input must not be null, undefined, or empty");for(var n=t[0].shape[0],r=1;r0)for(var n=0;n= 2, but got rank "+t.rank);if(2===t.rank)return pu(t,e);var n=t.shape.slice(0,t.shape.length-2).reduce(function(t,e){return t*e}),r=[],o=[];return So(t.reshape([n,t.shape[t.shape.length-2],t.shape[t.shape.length-1]]),0).forEach(function(t){var n=pu(t,e),a=n[0],i=n[1];r.push(a),o.push(i)}),[bo(r,0).reshape(t.shape),bo(o,0).reshape(t.shape)]}}),mu=Object.freeze({gramSchmidt:du,qr:vu});function gu(t,e,n,r,o){null==r&&(r=.5),null==o&&(o=Number.NEGATIVE_INFINITY);var a=t.shape[0];return n=Math.min(n,a),l(0<=r&&r<=1,"iouThreshold must be in [0, 1], but was '"+r+"'"),l(2===t.rank,"boxes must be a 2D tensor, but was of rank '"+t.rank+"'"),l(4===t.shape[1],"boxes must have 4 columns, but 2nd dimension was "+t.shape[1]),l(1===e.rank,"scores must be a 1D tensor"),l(e.shape[0]===a,"scores has incompatible shape with boxes. Expected "+a+", but was "+e.shape[0]),{maxOutputSize:n,iouThreshold:r,scoreThreshold:o}}var yu=Bt({resizeBilinear_:function(t,e,n){void 0===n&&(n=!1);var r=Ft(t,"images","resizeBilinear");l(3===r.rank||4===r.rank,"Error in resizeBilinear: x must be rank 3 or 4, but got rank "+r.rank+"."),l(2===e.length,"Error in resizeBilinear: new shape must 2D, but got shape "+e+".");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=e[0],u=e[1],s=ht.engine.runKernel(function(t,e){return t.resizeBilinear(o,i,u,n)},{batchImages:o},function(t,e){return{batchImages:function(){return ht.engine.runKernel(function(e){return e.resizeBilinearBackprop(t,o,n)},{})}}});return a?s.as3D(s.shape[1],s.shape[2],s.shape[3]):s}}),xu=Bt({resizeNearestNeighbor_:function(t,e,n){void 0===n&&(n=!1);var r=Ft(t,"images","resizeNearestNeighbor");l(3===r.rank||4===r.rank,"Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank "+r.rank+"."),l(2===e.length,"Error in resizeNearestNeighbor: new shape must 2D, but got shape "+e+"."),l("float32"===r.dtype||"int32"===r.dtype,"`images` must have `int32` or `float32` as dtype");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=e[0],u=e[1],s=ht.engine.runKernel(function(t,e){return t.resizeNearestNeighbor(o,i,u,n)},{batchImages:o},function(t,e){return{batchImages:function(){return ht.engine.runKernel(function(e){return e.resizeNearestNeighborBackprop(t,o,n)},{})}}});return a?s.as3D(s.shape[1],s.shape[2],s.shape[3]):s}}),bu=Bt({nonMaxSuppression_:function(t,e,n,r,o){void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY);var a=Ft(t,"boxes","nonMaxSuppression"),i=Ft(e,"scores","nonMaxSuppression"),u=gu(a,i,n,r,o);return n=u.maxOutputSize,r=u.iouThreshold,o=u.scoreThreshold,ht.engine.runKernel(function(t){return t.nonMaxSuppression(a,i,n,r,o)},{$boxes:a})}}),wu=function(t,e,n,r,i){return void 0===r&&(r=.5),void 0===i&&(i=Number.NEGATIVE_INFINITY),o(this,void 0,void 0,function(){var o,u,s,l,c,h;return a(this,function(a){switch(a.label){case 0:return o=Ft(t,"boxes","nonMaxSuppressionAsync"),u=Ft(e,"scores","nonMaxSuppressionAsync"),s=gu(o,u,n,r,i),n=s.maxOutputSize,r=s.iouThreshold,i=s.scoreThreshold,[4,o.data()];case 1:return l=a.sent(),[4,u.data()];case 2:return c=a.sent(),h=ce(l,c,n,r,i),o!==t&&o.dispose(),u!==e&&u.dispose(),[2,h]}})})},Eu=Object.freeze({resizeBilinear:yu,resizeNearestNeighbor:xu,nonMaxSuppression:bu,nonMaxSuppressionAsync:wu}),Su=Object.freeze({image:Eu,linalg:mu,losses:fu,op:Bt,batchNormalization2d:sa,batchNormalization3d:la,batchNormalization4d:ca,batchNormalization:ha,concat:Lr,concat1d:Br,concat2d:Pr,concat3d:Ur,concat4d:zr,conv1d:ba,conv2d:wa,depthwiseConv2d:Ea,separableConv2d:Sa,conv2dTranspose:Ra,matMul:Ca,dot:ka,outerProduct:Ta,reverse:Ia,reverse1d:Aa,reverse2d:Da,reverse3d:Na,reverse4d:Ma,maxPool:_a,avgPool:Oa,slice:Fa,slice1d:La,slice2d:Ba,slice3d:Pa,slice4d:Ua,abs:Ao,acos:Do,acosh:No,asin:Mo,asinh:_o,atan:Oo,atanh:Fo,ceil:Lo,clipByValue:Bo,cos:Po,cosh:Uo,erf:zo,exp:Vo,expm1:Wo,floor:Go,log:qo,log1p:Ho,logSigmoid:$o,neg:jo,reciprocal:Xo,round:Ko,rsqrt:Yo,sigmoid:Qo,sign:Jo,sin:Zo,sinh:ta,softplus:ea,sqrt:na,square:ra,step:oa,tan:aa,tanh:ia,all:qa,any:Ha,argMax:$a,argMin:ja,logSumExp:Xa,max:Ka,mean:Ya,min:Qa,moments:Ja,sum:Za,equal:ti,equalStrict:ei,greater:ni,greaterEqual:ri,greaterEqualStrict:oi,greaterStrict:ai,less:ii,lessEqual:ui,lessEqualStrict:si,lessStrict:li,notEqual:ci,notEqualStrict:hi,add:fi,addN:pi,addStrict:di,atan2:vi,div:mi,divStrict:gi,floorDiv:yi,maximum:xi,maximumStrict:bi,minimum:wi,minimumStrict:Ei,mod:Si,modStrict:Ri,mul:Ci,mulStrict:ki,pow:Ti,powStrict:Ii,squaredDifference:Ai,squaredDifferenceStrict:Di,sub:Ni,subStrict:Mi,elu:Ui,leakyRelu:zi,prelu:Vi,relu:Wi,selu:Gi,logicalAnd:_i,logicalNot:Oi,logicalOr:Fi,logicalXor:Li,where:Bi,whereAsync:Pi,buffer:Jr,toPixels:Qr,print:Zr,cast:to,clone:eo,cumsum:no,expandDims:ro,eye:oo,fromPixels:ao,multinomial:io,oneHot:uo,pad:so,pad1d:lo,pad2d:co,pad3d:ho,pad4d:fo,rand:po,randomNormal:vo,randomUniform:mo,reshape:go,split:yo,squeeze:xo,stack:bo,tile:wo,truncatedNormal:Eo,unstack:So,batchToSpaceND:Ro,spaceToBatchND:Co,fill:Kt,linspace:Yt,ones:jt,range:Qt,scalar:zt,tensor:Ut,tensor1d:Vt,tensor2d:Wt,tensor3d:Gt,tensor4d:qt,tensor5d:Ht,tensor6d:$t,zeros:Xt,onesLike:re,zerosLike:oe,transpose:qi,softmax:Pt,localResponseNormalization:Hi,norm:$i,gather:Ki,unsortedSegmentSum:Yi,basicLSTMCell:Qi,multiRNNCell:Ji,movingAverage:Zi,stridedSlice:tu,topk:nu}),Ru=function(){function t(){this.data=new WeakMap,this.firstUse=!0,ht.get("IS_BROWSER")&&(this.canvas=document.createElement("canvas"))}return t.prototype.register=function(t,e,n){if(this.firstUse&&(this.firstUse=!1,ht.get("IS_NODE")&&pt("\n============================\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\n============================\n")),this.data.has(t))throw new Error("Data buffer is already registered");this.data.set(t,null)},t.prototype.write=function(t,e){if(null==e)throw new Error("MathBackendCPU.write(): values can not be null");this.throwIfNoData(t),this.data.set(t,e)},t.prototype.fromPixels=function(t,e){if(null==t)throw new Error("pixels passed to tf.fromPixels() can not be null");var n,r;if(ht.get("IS_NODE")&&null==t.getContext)throw new Error("When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package");if(null!=t.getContext)n=t.getContext("2d").getImageData(0,0,t.width,t.height).data;else if(t instanceof ImageData)n=t.data;else{if(!(t instanceof HTMLImageElement||t instanceof HTMLVideoElement))throw new Error("pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was "+t.constructor.name);if(null==this.canvas)throw new Error("Can't read pixels from HTMLImageElement outside the browser.");this.canvas.width=t.width,this.canvas.height=t.height,this.canvas.getContext("2d").drawImage(t,0,0,t.width,t.height),n=this.canvas.getContext("2d").getImageData(0,0,t.width,t.height).data}if(4===e)r=new Int32Array(n);else{var o=t.width*t.height;r=new Int32Array(o*e);for(var a=0;af&&(f=m,p=v)}s[c]=p}return i},t.prototype.cumsum=function(t,e,n,r){if(e!==t.rank-1)throw new Error("backend.cumsum in CPU expects an inner-most axis="+(t.rank-1)+" but got axis="+e);for(var o=ie(t.dtype,"int32"),a=Xt(t.shape,o),i=a.dataSync(),u=t.dataSync(),s=t.shape[t.rank-1],l=r?function(t,e){return t+s-e-1}:function(t,e){return t+e},c=0;ce?1:0})},t.prototype.greaterEqual=function(t,e){return this.broadcastedBinaryOp(t,e,"bool",function(t,e){return t>=e?1:0})},t.prototype.logicalNot=function(t){for(var e=t.dataSync(),n=new Int32Array(e.length),r=0;r1||1===e.rank?1:e.shape[1],c=0;c=0&&e>=0?n:(n+e)%e})},t.prototype.max=function(t,e){St("max",e,t.rank);for(var n=bt(t.shape,e),r=n[0],o=n[1],a=Xt(r,t.dtype),i=d(o),u=a.dataSync(),s=t.dataSync(),l=0;lh&&(h=p)}u[l]=h}return a},t.prototype.maximum=function(t,e){return this.broadcastedBinaryOp(t,e,t.dtype,function(t,e){return Math.max(t,e)})},t.prototype.all=function(t,e){St("all",e,t.rank);for(var n=bt(t.shape,e),r=n[0],o=n[1],a=Xt(r,t.dtype),i=d(o),u=a.dataSync(),s=t.dataSync(),l=0;l0?n[r]=1:n[r]=0;return X.make(t.shape,{values:n})},t.prototype.round=function(t){for(var e=t.dataSync(),n=new Float32Array(e.length),r=0;r.5?n[r]=Math.ceil(e[r]):n[r]=o%2==0?o:o+1}return X.make(t.shape,{values:n})},t.prototype.exp=function(t){for(var e=t.dataSync(),n=new Float32Array(e.length),r=0;r=0?o:Math.exp(o)-1}return X.make(t.shape,{values:e})},t.prototype.eluDer=function(t,e){for(var n=new Float32Array(e.size),r=e.dataSync(),o=t.dataSync(),a=0;a=1?o[a]:o[a]*(i+1)}return X.make(e.shape,{values:n})},t.prototype.selu=function(t){for(var e=Rr,n=Cr,r=new Float32Array(t.size),o=t.dataSync(),a=0;a=0?n*i:e*(Math.exp(i)-1)}return X.make(t.shape,{values:r})},t.prototype.clip=function(t,e,n){for(var r=new Float32Array(t.size),o=t.dataSync(),a=0;a-e,i=r[o]0?1:e}return X.make(t.shape,{values:n})},t.prototype.conv2d=function(t,e,n){for(var r=n.filterHeight,o=n.filterWidth,a=n.dilationHeight,i=n.dilationWidth,u=n.padInfo.left,s=n.padInfo.top,l=Jr(n.outShape,t.dtype),c=0;c=n.inHeight))for(var x=0;x=n.inWidth))for(var w=0;w=n.inHeight))for(var w=0;w=n.inWidth))y+=t.get(h,b,E,f)*e.get(x,w,f,g)}}c.set(y,h,p,v,f*l+g)}return c.toTensor()},t.prototype.depthwiseConv2DDerInput=function(t,e,n){for(var r=Jr(n.inShape,"float32"),o=r.values,a=r.strides,i=a[0],u=a[1],s=a[2],l=t.dataSync(),c=t.strides,h=c[0],f=c[1],p=c[2],d=e.dataSync(),v=e.strides,m=v[0],g=v[1],y=v[2],x=n.batchSize,b=n.filterHeight,w=n.filterWidth,E=n.inChannels,S=n.inHeight,R=n.inWidth,C=n.outChannels,k=n.outHeight,T=n.outWidth,I=n.strideHeight,A=n.strideWidth,D=b-1-n.padInfo.top,N=w-1-n.padInfo.left,M=C/E,_=0;_b?b=C:"avg"===n&&(w+=C,E++)}if(isNaN(b))break}u.set("avg"===n?w/E:b,c,f,m,h)}return u.toTensor()},t.prototype.maxPool=function(t,e){return this.pool(t,e,"max")},t.prototype.maxPoolPositions=function(t,e){for(var n=Jr(e.outShape,"int32"),r=e.strideHeight,o=e.strideWidth,a=e.filterHeight,i=e.filterWidth,u=e.padInfo.top,s=e.padInfo.left,l=0;lx&&(x=C,b=E*i+R)}n.set(b,l,h,v,c)}return n.toTensor()},t.prototype.maxPoolBackprop=function(t,e,n,r){for(var o=this.maxPoolPositions(e,r),a=r.strideHeight,i=r.strideWidth,u=r.filterHeight,s=r.filterWidth,l=s-1-r.padInfo.left,c=u-1-r.padInfo.top,h=Jr(e.shape,"float32"),f=0;f=r.outHeight||Math.floor(b)!==b))for(var w=0;w=r.outWidth||Math.floor(E)!==E)){var S=u*s-1-o.get(f,b,E,p)===x*s+w?1:0;if(0!==S)y+=t.get(f,b,E,p)*S}}}h.set(y,f,d,v,p)}return h.toTensor()},t.prototype.avgPoolBackprop=function(t,e,n){for(var r=n.strideHeight,o=n.strideWidth,a=n.filterHeight,i=n.filterWidth,u=i-1-n.padInfo.left,s=a-1-n.padInfo.top,l=Jr(e.shape,"float32"),c=1/(a*i),h=0;h=n.outHeight||Math.floor(x)!==x))for(var b=0;b=n.outWidth||Math.floor(w)!==w))g+=t.get(h,x,w,f)}}l.set(g*c,h,p,d,f)}return l.toTensor()},t.prototype.cast=function(t,e){return se(t,e,this)},t.prototype.reshape=function(t,e){return le(t,e)},t.prototype.avgPool=function(t,e){return this.pool(t,e,"avg").toFloat()},t.prototype.resizeBilinear=function(t,e,n,r){for(var o=t.shape,a=o[0],i=o[1],u=o[2],s=o[3],l=Jr([a,e,n,s],t.dtype),c=[r&&e>1?i-1:i,r&&n>1?u-1:u],h=[r&&e>1?e-1:e,r&&n>1?n-1:n],f=0;f1?a-1:a,n&&c>1?i-1:i],p=[n&&l>1?l-1:l,n&&c>1?c-1:c],d=f[0]/p[0],v=f[1]/p[1],m=0;m1?i-1:i,r&&n>1?u-1:u],h=[r&&e>1?e-1:e,r&&n>1?n-1:n],f=0;f1?a-1:a,n&&c>1?i-1:i],p=[n&&l>1?l-1:l,n&&c>1?c-1:c],d=1/(f[0]/p[0]),v=1/(f[1]/p[1]),m=2*Math.ceil(d)+2,g=2*Math.ceil(v)+2,y=0;y=l))for(var A=0;A=c)){var N=f[0]*(I/p[0]),M=f[1]*(D/p[1]),_=Math.min(a-1,n?Math.round(N):Math.floor(N)),O=Math.min(i-1,n?Math.round(M):Math.floor(M));x===_&&b===O&&(k+=t.get(y,I,D,C))}}}h.set(k,y,x,b,C)}return h.toTensor()},t.prototype.batchNormalization=function(t,e,n,r,o,a){for(var i=t.dataSync(),u=e.dataSync(),s=n.dataSync(),l=o?o.dataSync():new Float32Array([1]),c=a?a.dataSync():new Float32Array([0]),h=new Float32Array(i.length),f=0;f=0&&t.get(a)0,"scheme must not be an empty string.");var r=t.getInstance();l(null==r.managers[e],"A model store manager is already registered for scheme '"+e+"'."),r.managers[e]=n},t.getManager=function(t){var e=this.getInstance().managers[t];if(null==e)throw new Error("Cannot find model manager for scheme '"+t+"'");return e},t.getSchemes=function(){return Object.keys(this.getInstance().managers)},t}();function Fu(t){if(-1===t.indexOf(_u))throw new Error("The url string provided does not contain a scheme. Supported schemes are: "+Ou.getSchemes().join(","));return{scheme:t.split(_u)[0],path:t.split(_u)[1]}}function Lu(t,e,n){return void 0===n&&(n=!1),o(this,void 0,void 0,function(){var r,o,i,u,s,c,h,f,p;return a(this,function(a){switch(a.label){case 0:return l(t!==e,"Old path and new path are the same: '"+t+"'"),l((r=Mu.getLoadHandlers(t)).length>0,"Copying failed because no load handler is found for source URL "+t+"."),l(r.length<2,"Copying failed because more than one ("+r.length+") load handlers for source URL "+t+"."),o=r[0],l((i=Mu.getSaveHandlers(e)).length>0,"Copying failed because no save handler is found for destination URL "+e+"."),l(i.length<2,"Copying failed because more than one ("+r.length+") save handlers for destination URL "+e+"."),u=i[0],s=Fu(t).scheme,c=Fu(t).path,h=s===Fu(t).scheme,[4,o.load()];case 1:return f=a.sent(),n&&h?[4,Ou.getManager(s).removeModel(c)]:[3,3];case 2:a.sent(),a.label=3;case 3:return[4,u.save(f)];case 4:return p=a.sent(),!n||h?[3,6]:[4,Ou.getManager(s).removeModel(c)];case 5:a.sent(),a.label=6;case 6:return[2,p.modelArtifactsInfo]}})})}var Bu="models_store",Pu="model_info_store";function Uu(){if(!ht.get("IS_BROWSER"))throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");var t=window,e=t.indexedDB||t.mozIndexedDB||t.webkitIndexedDB||t.msIndexedDB||t.shimIndexedDB;if(null==e)throw new Error("The current browser does not appear to support IndexedDB.");return e}function zu(t){var e=t.result;e.createObjectStore(Bu,{keyPath:"modelPath"}),e.createObjectStore(Pu,{keyPath:"modelPath"})}var Vu=function(){function t(t){if(this.indexedDB=Uu(),null==t||!t)throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath=t}return t.prototype.save=function(t){return o(this,void 0,void 0,function(){return a(this,function(e){if(t.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return[2,this.databaseAction(this.modelPath,t)]})})},t.prototype.load=function(){return o(this,void 0,void 0,function(){return a(this,function(t){return[2,this.databaseAction(this.modelPath)]})})},t.prototype.databaseAction=function(t,e){var n=this;return new Promise(function(t,r){var o=n.indexedDB.open("tensorflowjs",1);o.onupgradeneeded=function(){return zu(o)},o.onsuccess=function(){var a=o.result;if(null==e){var i=a.transaction(Bu,"readonly"),u=i.objectStore(Bu).get(n.modelPath);u.onsuccess=function(){if(null==u.result)return a.close(),r(new Error("Cannot find model with path '"+n.modelPath+"' in IndexedDB."));t(u.result.modelArtifacts)},u.onerror=function(t){return a.close(),r(u.error)},i.oncomplete=function(){return a.close()}}else{var s,l=Nu(e),c=a.transaction(Pu,"readwrite"),h=c.objectStore(Pu),f=h.put({modelPath:n.modelPath,modelArtifactsInfo:l});f.onsuccess=function(){var o=(s=a.transaction(Bu,"readwrite")).objectStore(Bu).put({modelPath:n.modelPath,modelArtifacts:e,modelArtifactsInfo:l});o.onsuccess=function(){return t({modelArtifactsInfo:l})},o.onerror=function(t){var e=(h=c.objectStore(Pu)).delete(n.modelPath);e.onsuccess=function(){return a.close(),r(o.error)},e.onerror=function(t){return a.close(),r(o.error)}}},f.onerror=function(t){return a.close(),r(f.error)},c.oncomplete=function(){null==s?a.close():s.oncomplete=function(){return a.close()}}}},o.onerror=function(t){return r(o.error)}})},t.URL_SCHEME="indexeddb://",t}(),Wu=function(t){return ht.get("IS_BROWSER")&&t.startsWith(Vu.URL_SCHEME)?(e=t.slice(Vu.URL_SCHEME.length),new Vu(e)):null;var e};Mu.registerSaveRouter(Wu),Mu.registerLoadRouter(Wu);var Gu=function(){function t(){this.indexedDB=Uu()}return t.prototype.listModels=function(){return o(this,void 0,void 0,function(){var t=this;return a(this,function(e){return[2,new Promise(function(e,n){var r=t.indexedDB.open("tensorflowjs",1);r.onupgradeneeded=function(){return zu(r)},r.onsuccess=function(){var t=r.result,o=t.transaction(Pu,"readonly"),a=o.objectStore(Pu).getAll();a.onsuccess=function(){for(var t={},n=0,r=a.result;n0,"URL path for browserHTTPRequest must not be null, undefined or empty."),this.path=t,null!=e&&null!=e.body)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=e||{}}return t.prototype.save=function(t){return o(this,void 0,void 0,function(){var e,n,r,o;return a(this,function(a){switch(a.label){case 0:if(t.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");return(e=Object.assign({method:this.DEFAULT_METHOD},this.requestInit)).body=new FormData,n=[{paths:["./model.weights.bin"],weights:t.weightSpecs}],r={modelTopology:t.modelTopology,weightsManifest:n},e.body.append("model.json",new Blob([JSON.stringify(r)],{type:"application/json"}),"model.json"),null!=t.weightData&&e.body.append("model.weights.bin",new Blob([t.weightData],{type:"application/octet-stream"}),"model.weights.bin"),[4,fetch(this.path,e)];case 1:if(200===(o=a.sent()).status)return[2,{modelArtifactsInfo:Nu(t),responses:[o]}];throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status "+o.status+".")}})})},t.prototype.load=function(){return o(this,void 0,void 0,function(){var t,e,n,r,o,i,u,s,l,c,h,f;return a(this,function(a){switch(a.label){case 0:return[4,fetch(this.path,this.requestInit)];case 1:return[4,a.sent().json()];case 2:if(t=a.sent(),e=t.modelTopology,n=t.weightsManifest,null==e&&null==n)throw new Error("The JSON from HTTP path "+this.path+" contains neither model topology or manifest for weights.");if(null==n)return[3,4];for(i=t.weightsManifest,r=[],u=0,s=i;u0&&(t=r({weightSpecs:this.weightSpecs},t)),null!=this.weightData&&this.weightData.byteLength>0&&(t=r({weightData:this.weightData},t)),[2,t]})})},t}(),hs=function(){function t(t){this.saveHandler=t}return t.prototype.save=function(t){return o(this,void 0,void 0,function(){return a(this,function(e){return[2,this.saveHandler(t)]})})},t}();var fs=Mu.registerSaveRouter,ps=Mu.registerLoadRouter,ds=Mu.getSaveHandlers,vs=Mu.getLoadHandlers,ms=Object.freeze({browserFiles:function(t){return new as(t)},browserHTTPRequest:ls,concatenateArrayBuffers:Au,decodeWeights:function(t,e){for(var n={},r=0,o=0,a=e;on)}var Es=Object.freeze({WEBGL_ENVS:{HAS_WEBGL:!0},NODE_ENVS:{IS_NODE:!0},CHROME_ENVS:{IS_CHROME:!0},BROWSER_ENVS:{IS_BROWSER:!0},CPU_ENVS:{HAS_WEBGL:!1},ALL_ENVS:{},expectArraysClose:bs,expectPromiseToFail:function(t,e){t().then(function(){return e.fail()},function(){return e()})},expectArraysEqual:function(t,e){return bs(t,e,0)},expectNumbersClose:function(t,e,n){if(null==n&&(n=ht.get("TEST_EPSILON")),!ws(t,e,n))throw new Error("Numbers differ: actual === "+t+", expected === "+e)},expectValuesInRange:function(t,e,n){var r;r=t instanceof X?t.dataSync():t;for(var o=0;on)throw new Error("Value out of range:"+r[o]+" low: "+e+", high: "+n)},expectArrayBuffersEqual:function(t,e){expect(new Float32Array(t)).toEqual(new Float32Array(e))}}),Ss=Object.freeze({gpgpu_util:Jn,webgl_util:Dn,MathBackendWebGL:Io,GPGPUContext:Zn}),Rs=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return n(e,t),e.prototype.minimize=function(t,e,n){void 0===e&&(e=!1);var r=this.computeGradients(t,n),o=r.value,a=r.grads;return this.applyGradients(a),Object.keys(a).forEach(function(t){return a[t].dispose()}),e?o:(o.dispose(),null)},e.prototype.computeGradients=function(t,e){return Mt(t,e)},e}(gs),Cs=1e-8,ks=1e-4;function Ts(){return ht.get("WEBGL_RENDER_FLOAT32_ENABLED")?Cs:ks}var Is=function(t){function e(e,n,r){void 0===r&&(r=null);var o=t.call(this)||this;return o.learningRate=e,o.rho=n,o.epsilon=r,o.accumulatedGrads={},o.accumulatedUpdates={},o.c=Va(zt(-e)),o.rhoScalar=Va(zt(n)),o.oneMinusRho=Va(zt(1-n)),null===r&&(r=Ts()),o.epsilonScalar=Va(zt(r)),o}return n(e,t),e.prototype.applyGradients=function(t){var e=this,n=function(n){var o=ht.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){za(function(){e.accumulatedGrads[n]=oe(o).variable(!1)})}if(null==r.accumulatedUpdates[n]){za(function(){e.accumulatedUpdates[n]=oe(o).variable(!1)})}var a=t[n],i=r.accumulatedGrads[n],u=r.accumulatedUpdates[n];za(function(){var t=e.rhoScalar.mul(i).add(e.oneMinusRho.mul(a.square())),r=u.add(e.epsilonScalar).sqrt().div(i.add(e.epsilonScalar).sqrt()).mul(a),s=e.rhoScalar.mul(u).add(e.oneMinusRho.mul(r.square()));e.accumulatedGrads[n].assign(t),e.accumulatedUpdates[n].assign(s);var l=e.c.mul(r).add(o);o.assign(l)})},r=this;for(var o in t)n(o)},e.prototype.dispose=function(){var t=this;this.c.dispose(),this.epsilonScalar.dispose(),this.rhoScalar.dispose(),this.oneMinusRho.dispose(),null!=this.accumulatedUpdates&&(Object.keys(this.accumulatedUpdates).forEach(function(e){return t.accumulatedUpdates[e].dispose()}),Object.keys(this.accumulatedGrads).forEach(function(e){return t.accumulatedGrads[e].dispose()}))},e.prototype.getConfig=function(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}},e.fromConfig=function(t,e){return new t(e.learningRate,e.rho,e.epsilon)},e.className="AdadeltaOptimizer",e}(Rs);ys.register(Is);var As=function(t){function e(e,n){void 0===n&&(n=.1);var r=t.call(this)||this;r.learningRate=e,r.initialAccumulatorValue=n,r.accumulatedGrads={},r.c=Va(zt(-e));var o=Ts();return r.epsilon=Va(zt(o)),r}return n(e,t),e.prototype.applyGradients=function(t){var e=this,n=function(n){var o=ht.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){za(function(){e.accumulatedGrads[n]=Kt(o.shape,e.initialAccumulatorValue).variable(!1)})}var a=t[n],i=r.accumulatedGrads[n];za(function(){var t=i.add(a.square());e.accumulatedGrads[n].assign(t);var r=e.c.mul(a.div(t.add(e.epsilon).sqrt())).add(o);o.assign(r)})},r=this;for(var o in t)n(o)},e.prototype.dispose=function(){var t=this;this.epsilon.dispose(),this.c.dispose(),null!=this.accumulatedGrads&&Object.keys(this.accumulatedGrads).forEach(function(e){return t.accumulatedGrads[e].dispose()})},e.prototype.getConfig=function(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}},e.fromConfig=function(t,e){return new t(e.learningRate,e.initialAccumulatorValue)},e.className="AdagradOptimizer",e}(Rs);ys.register(As);var Ds=function(t){function e(e,n,r,o){void 0===o&&(o=null);var a=t.call(this)||this;return a.learningRate=e,a.beta1=n,a.beta2=r,a.epsilon=o,a.accumulatedFirstMoment={},a.accumulatedSecondMoment={},a.c=Va(zt(-e)),a.beta1Scalar=Va(zt(n)),a.beta2Scalar=Va(zt(r)),za(function(){a.accBeta1=zt(n).variable(),a.accBeta2=zt(r).variable()}),a.oneMinusBeta1=Va(zt(1-n)),a.oneMinusBeta2=Va(zt(1-r)),a.one=Va(zt(1)),null===o&&(o=Ts()),a.epsScalar=Va(zt(o)),a}return n(e,t),e.prototype.applyGradients=function(t){var e=this;za(function(){var n=e.one.sub(e.accBeta1),r=e.one.sub(e.accBeta2);for(var o in t){var a=ht.engine.registeredVariables[o];if(null==e.accumulatedFirstMoment[o]){var i=!1;e.accumulatedFirstMoment[o]=oe(a).variable(i)}if(null==e.accumulatedSecondMoment[o]){i=!1;e.accumulatedSecondMoment[o]=oe(a).variable(i)}var u=t[o],s=e.accumulatedFirstMoment[o],l=e.accumulatedSecondMoment[o],c=e.beta1Scalar.mul(s).add(e.oneMinusBeta1.mul(u)),h=e.beta2Scalar.mul(l).add(e.oneMinusBeta2.mul(u.square())),f=c.div(n),p=h.div(r);e.accumulatedFirstMoment[o].assign(c),e.accumulatedSecondMoment[o].assign(h);var d=e.c.mul(f.div(e.epsScalar.add(p.sqrt()))).add(a);a.assign(d)}e.accBeta1.assign(e.accBeta1.mul(e.beta1Scalar)),e.accBeta2.assign(e.accBeta2.mul(e.beta2Scalar))})},e.prototype.dispose=function(){var t=this;this.c.dispose(),this.epsScalar.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.accBeta1.dispose(),this.accBeta2.dispose(),this.oneMinusBeta1.dispose(),this.oneMinusBeta2.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(e){return t.accumulatedFirstMoment[e].dispose()}),null!=this.accumulatedSecondMoment&&Object.keys(this.accumulatedSecondMoment).forEach(function(e){return t.accumulatedSecondMoment[e].dispose()})},e.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}},e.fromConfig=function(t,e){return new t(e.learningRate,e.beta1,e.beta2,e.epsilon)},e.className="AdamOptimizer",e}(Rs);ys.register(Ds);var Ns=function(t){function e(e,n,r,o,a){void 0===o&&(o=null),void 0===a&&(a=0);var i=t.call(this)||this;return i.learningRate=e,i.beta1=n,i.beta2=r,i.epsilon=o,i.decay=a,i.accumulatedFirstMoment={},i.accumulatedWeightedInfNorm={},i.c=Va(zt(-e)),i.beta1Scalar=Va(zt(n)),i.beta2Scalar=Va(zt(r)),i.decayScalar=Va(zt(a)),za(function(){i.iteration=zt(0).variable(),i.accBeta1=zt(n).variable()}),i.oneMinusBeta1=Va(zt(1-n)),i.one=Va(zt(1)),null===o&&(o=Ts()),i.epsScalar=Va(zt(o)),i}return n(e,t),e.prototype.applyGradients=function(t){var e=this;za(function(){var n=e.one.sub(e.accBeta1),r=e.c.div(e.one.add(e.decayScalar.mul(e.iteration)));for(var o in t){var a=ht.engine.registeredVariables[o];if(null==e.accumulatedFirstMoment[o]){var i=!1;e.accumulatedFirstMoment[o]=oe(a).variable(i)}if(null==e.accumulatedWeightedInfNorm[o]){i=!1;e.accumulatedWeightedInfNorm[o]=oe(a).variable(i)}var u=t[o],s=e.accumulatedFirstMoment[o],l=e.accumulatedWeightedInfNorm[o],c=e.beta1Scalar.mul(s).add(e.oneMinusBeta1.mul(u)),h=e.beta2Scalar.mul(l),f=u.abs(),p=h.maximum(f);e.accumulatedFirstMoment[o].assign(c),e.accumulatedWeightedInfNorm[o].assign(p);var d=r.div(n).mul(c.div(e.epsScalar.add(p))).add(a);a.assign(d)}e.iteration.assign(e.iteration.add(e.one)),e.accBeta1.assign(e.accBeta1.mul(e.beta1Scalar))})},e.prototype.dispose=function(){var t=this;this.c.dispose(),this.epsScalar.dispose(),this.accBeta1.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.oneMinusBeta1.dispose(),this.decayScalar.dispose(),this.iteration.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(e){return t.accumulatedFirstMoment[e].dispose()}),null!=this.accumulatedWeightedInfNorm&&Object.keys(this.accumulatedWeightedInfNorm).forEach(function(e){return t.accumulatedWeightedInfNorm[e].dispose()})},e.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}},e.fromConfig=function(t,e){return new t(e.learningRate,e.beta1,e.beta2,e.epsilon,e.decay)},e.className="AdamaxOptimizer",e}(Rs);ys.register(Ns);var Ms=function(t){function e(e){var n=t.call(this)||this;return n.learningRate=e,n.setLearningRate(e),n}return n(e,t),e.prototype.applyGradients=function(t){var e=this;Object.keys(t).forEach(function(n){var r=t[n],o=ht.engine.registeredVariables[n];za(function(){var t=e.c.mul(r).add(o);o.assign(t)})})},e.prototype.setLearningRate=function(t){this.learningRate=t,null!=this.c&&this.c.dispose(),this.c=Va(zt(-t))},e.prototype.dispose=function(){this.c.dispose()},e.prototype.getConfig=function(){return{learningRate:this.learningRate}},e.fromConfig=function(t,e){return new t(e.learningRate)},e.className="SGDOptimizer",e}(Rs);ys.register(Ms);var _s=function(t){function e(e,n,r){void 0===r&&(r=!1);var o=t.call(this,e)||this;return o.learningRate=e,o.momentum=n,o.useNesterov=r,o.m=zt(o.momentum),o.accumulations={},o}return n(e,t),e.prototype.applyGradients=function(t){var e=this,n=function(n){var o=ht.engine.registeredVariables[n];if(null==r.accumulations[n]){za(function(){e.accumulations[n]=oe(o).variable(!1)})}var a=r.accumulations[n],i=t[n];za(function(){var t,r=e.m.mul(a).add(i);t=e.useNesterov?e.c.mul(i.add(r.mul(e.m))).add(o):e.c.mul(r).add(o),e.accumulations[n].assign(r),o.assign(t)})},r=this;for(var o in t)n(o)},e.prototype.dispose=function(){if(t.prototype.dispose.call(this),this.m.dispose(),null!=this.accumulations)for(var e in this.accumulations)this.accumulations[e].dispose()},e.prototype.setMomentum=function(t){this.momentum=t},e.prototype.getConfig=function(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}},e.fromConfig=function(t,e){return new t(e.learningRate,e.momentum,e.useNesterov)},e.className="MomentumOptimizer",e}(Ms);ys.register(_s);var Os=function(t){function e(e,n,r,o,a){void 0===n&&(n=.9),void 0===r&&(r=0),void 0===o&&(o=null),void 0===a&&(a=!1);var i=t.call(this)||this;return i.learningRate=e,i.decay=n,i.momentum=r,i.epsilon=o,i.accumulatedMeanSquares={},i.accumulatedMeanGrads={},i.accumulatedMoments={},i.c=Va(zt(e)),i.decayScalar=Va(zt(n)),i.momentumScalar=Va(zt(r)),i.oneMinusDecay=Va(zt(1-n)),i.centered=a,null===o&&(o=Ts()),i.epsilonScalar=Va(zt(o)),i}return n(e,t),e.prototype.applyGradients=function(t){var e=this,n=function(n){var o=ht.engine.registeredVariables[n];if(null==r.accumulatedMeanSquares[n]){za(function(){e.accumulatedMeanSquares[n]=oe(o).variable(!1)})}if(null==r.accumulatedMeanGrads[n]&&r.centered){za(function(){e.accumulatedMeanGrads[n]=oe(o).variable(!1)})}if(null==r.accumulatedMoments[n]){za(function(){e.accumulatedMoments[n]=oe(o).variable(!1)})}var a=r.accumulatedMeanSquares[n],i=r.accumulatedMeanGrads[n],u=r.accumulatedMoments[n],s=t[n];za(function(){var t=e.decayScalar.mul(a).add(e.oneMinusDecay.mul(s.square()));if(e.centered){var r=e.decayScalar.mul(i).add(e.oneMinusDecay.mul(s)),l=e.momentumScalar.mul(u).add(e.c.mul(s).div(t.sub(r.square().add(e.epsilonScalar)).sqrt()));e.accumulatedMeanSquares[n].assign(t),e.accumulatedMeanGrads[n].assign(r),e.accumulatedMoments[n].assign(l);var c=o.sub(l);o.assign(c)}else{var h=e.decayScalar.mul(a).add(e.oneMinusDecay.mul(s.square()));l=e.momentumScalar.mul(u).add(e.c.mul(s).div(h.add(e.epsilonScalar).sqrt()));e.accumulatedMeanSquares[n].assign(h),e.accumulatedMoments[n].assign(l);c=o.sub(l);o.assign(c)}})},r=this;for(var o in t)n(o)},e.prototype.dispose=function(){var t=this;this.c.dispose(),this.epsilonScalar.dispose(),this.decayScalar.dispose(),this.momentumScalar.dispose(),this.oneMinusDecay.dispose(),null!=this.accumulatedMeanSquares&&Object.keys(this.accumulatedMeanSquares).forEach(function(e){return t.accumulatedMeanSquares[e].dispose()}),null!=this.accumulatedMeanGrads&&this.centered&&Object.keys(this.accumulatedMeanGrads).forEach(function(e){return t.accumulatedMeanGrads[e].dispose()}),null!=this.accumulatedMoments&&Object.keys(this.accumulatedMoments).forEach(function(e){return t.accumulatedMoments[e].dispose()})},e.prototype.getConfig=function(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}},e.fromConfig=function(t,e){return new t(e.learningRate,e.decay,e.momentum,e.epsilon,e.centered)},e.className="RMSPropOptimizer",e}(Rs);ys.register(Os);var Fs=function(){function t(){}return t.sgd=function(t){return new Ms(t)},t.momentum=function(t,e,n){return void 0===n&&(n=!1),new _s(t,e,n)},t.rmsprop=function(t,e,n,r,o){return void 0===e&&(e=.9),void 0===n&&(n=0),void 0===r&&(r=null),void 0===o&&(o=!1),new Os(t,e,n,r,o)},t.adam=function(t,e,n,r){return void 0===t&&(t=.001),void 0===e&&(e=.9),void 0===n&&(n=.999),void 0===r&&(r=null),new Ds(t,e,n,r)},t.adadelta=function(t,e,n){return void 0===t&&(t=.001),void 0===e&&(e=.95),void 0===n&&(n=null),new Is(t,e,n)},t.adamax=function(t,e,n,r,o){return void 0===t&&(t=.002),void 0===e&&(e=.9),void 0===n&&(n=.999),void 0===r&&(r=null),void 0===o&&(o=0),new Ns(t,e,n,r,o)},t.adagrad=function(t,e){return void 0===e&&(e=.1),new As(t,e)},t}(),Ls={sgd:Fs.sgd,momentum:Fs.momentum,adadelta:Fs.adadelta,adagrad:Fs.adagrad,rmsprop:Fs.rmsprop,adamax:Fs.adamax,adam:Fs.adam},Bs=lt.setBackend,Ps=lt.getBackend,Us=lt.disposeVariables,zs=lt.memory;$=Su,t.setBackend=Bs,t.getBackend=Ps,t.disposeVariables=Us,t.memory=zs,t.version_core="0.12.8",t.nextFrame=function(){return new Promise(function(t){return Cu(function(){return t()})})},t.environment=ft,t.io=ms,t.serialization=xs,t.test_util=Es,t.util=L,t.webgl=Ss,t.AdadeltaOptimizer=Is,t.AdagradOptimizer=As,t.AdamOptimizer=Ds,t.AdamaxOptimizer=Ns,t.MomentumOptimizer=_s,t.Optimizer=Rs,t.RMSPropOptimizer=Os,t.SGDOptimizer=Ms,t.Tensor=X,t.TensorBuffer=q,t.variable=Y,t.Variable=K,t.ENV=ht,t.Environment=lt,t.image=Eu,t.linalg=mu,t.losses=fu,t.op=Bt,t.batchNormalization2d=sa,t.batchNormalization3d=la,t.batchNormalization4d=ca,t.batchNormalization=ha,t.concat=Lr,t.concat1d=Br,t.concat2d=Pr,t.concat3d=Ur,t.concat4d=zr,t.conv1d=ba,t.conv2d=wa,t.depthwiseConv2d=Ea,t.separableConv2d=Sa,t.conv2dTranspose=Ra,t.matMul=Ca,t.dot=ka,t.outerProduct=Ta,t.reverse=Ia,t.reverse1d=Aa,t.reverse2d=Da,t.reverse3d=Na,t.reverse4d=Ma,t.maxPool=_a,t.avgPool=Oa,t.slice=Fa,t.slice1d=La,t.slice2d=Ba,t.slice3d=Pa,t.slice4d=Ua,t.abs=Ao,t.acos=Do,t.acosh=No,t.asin=Mo,t.asinh=_o,t.atan=Oo,t.atanh=Fo,t.ceil=Lo,t.clipByValue=Bo,t.cos=Po,t.cosh=Uo,t.erf=zo,t.exp=Vo,t.expm1=Wo,t.floor=Go,t.log=qo,t.log1p=Ho,t.logSigmoid=$o,t.neg=jo,t.reciprocal=Xo,t.round=Ko,t.rsqrt=Yo,t.sigmoid=Qo,t.sign=Jo,t.sin=Zo,t.sinh=ta,t.softplus=ea,t.sqrt=na,t.square=ra,t.step=oa,t.tan=aa,t.tanh=ia,t.all=qa,t.any=Ha,t.argMax=$a,t.argMin=ja,t.logSumExp=Xa,t.max=Ka,t.mean=Ya,t.min=Qa,t.moments=Ja,t.sum=Za,t.equal=ti,t.equalStrict=ei,t.greater=ni,t.greaterEqual=ri,t.greaterEqualStrict=oi,t.greaterStrict=ai,t.less=ii,t.lessEqual=ui,t.lessEqualStrict=si,t.lessStrict=li,t.notEqual=ci,t.notEqualStrict=hi,t.add=fi,t.addN=pi,t.addStrict=di,t.atan2=vi,t.div=mi,t.divStrict=gi,t.floorDiv=yi,t.maximum=xi,t.maximumStrict=bi,t.minimum=wi,t.minimumStrict=Ei,t.mod=Si,t.modStrict=Ri,t.mul=Ci,t.mulStrict=ki,t.pow=Ti,t.powStrict=Ii,t.squaredDifference=Ai,t.squaredDifferenceStrict=Di,t.sub=Ni,t.subStrict=Mi,t.elu=Ui,t.leakyRelu=zi,t.prelu=Vi,t.relu=Wi,t.selu=Gi,t.logicalAnd=_i,t.logicalNot=Oi,t.logicalOr=Fi,t.logicalXor=Li,t.where=Bi,t.whereAsync=Pi,t.buffer=Jr,t.toPixels=Qr,t.print=Zr,t.cast=to,t.clone=eo,t.cumsum=no,t.expandDims=ro,t.eye=oo,t.fromPixels=ao,t.multinomial=io,t.oneHot=uo,t.pad=so,t.pad1d=lo,t.pad2d=co,t.pad3d=ho,t.pad4d=fo,t.rand=po,t.randomNormal=vo,t.randomUniform=mo,t.reshape=go,t.split=yo,t.squeeze=xo,t.stack=bo,t.tile=wo,t.truncatedNormal=Eo,t.unstack=So,t.batchToSpaceND=Ro,t.spaceToBatchND=Co,t.fill=Kt,t.linspace=Yt,t.ones=jt,t.range=Qt,t.scalar=zt,t.tensor=Ut,t.tensor1d=Vt,t.tensor2d=Wt,t.tensor3d=Gt,t.tensor4d=qt,t.tensor5d=Ht,t.tensor6d=$t,t.zeros=Xt,t.onesLike=re,t.zerosLike=oe,t.transpose=qi,t.softmax=Pt,t.localResponseNormalization=Hi,t.norm=$i,t.gather=Ki,t.unsortedSegmentSum=Yi,t.basicLSTMCell=Qi,t.multiRNNCell=Ji,t.movingAverage=Zi,t.stridedSlice=tu,t.topk=nu,t.train=Ls,t.tidy=za,t.keep=Va,t.dispose=Wa,t.time=Ga,t.customGrad=_t,t.grad=function(t){return l(A(t),"The f passed in grad(f) must be a function"),function(e,n){return l(e instanceof X,"The x passed in grad(f)(x) must be a tensor"),l(null==n||n instanceof X,"The dy passed in grad(f)(x, dy) must be a tensor"),ht.engine.tidy(function(){var r=ht.engine.gradients(function(){return t(e)},[e],n),o=r.value,a=r.grads;return null!=n&&c(o.shape,n.shape,"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"),Ot(a),a[0]})}},t.grads=function(t){return l(A(t),"The f passed in grads(f) must be a function"),function(e,n){return l(Array.isArray(e)&&e.every(function(t){return t instanceof X}),"The args passed in grads(f)(args) must be an array of tensors"),l(null==n||n instanceof X,"The dy passed in grads(f)(args, dy) must be a tensor"),ht.engine.tidy(function(){var r=ht.engine.gradients(function(){return t.apply(void 0,e)},e,n),o=r.value,a=r.grads;return null!=n&&c(o.shape,n.shape,"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Ot(a),a})}},t.valueAndGrad=function(t){return l(A(t),"The f passed in valueAndGrad(f) must be a function"),function(e,n){l(e instanceof X,"The x passed in valueAndGrad(f)(x) must be a tensor"),l(null==n||n instanceof X,"The dy passed in valueAndGrad(f)(x, dy) must be a tensor");var r=ht.engine.gradients(function(){return t(e)},[e],n),o=r.grads,a=r.value;return Ot(o),{grad:o[0],value:a}}},t.valueAndGrads=function(t){return l(A(t),"The f passed in valueAndGrads(f) must be a function"),function(e,n){l(Array.isArray(e)&&e.every(function(t){return t instanceof X}),"The args passed in valueAndGrads(f)(args) must be array of tensors"),l(null==n||n instanceof X,"The dy passed in valueAndGrads(f)(args, dy) must be a tensor");var r=ht.engine.gradients(function(){return t.apply(void 0,e)},e,n);return null!=n&&c(r.value.shape,n.shape,"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Ot(r.grads),r}},t.variableGrads=Mt,Object.defineProperty(t,"__esModule",{value:!0})}); +//# sourceMappingURL=tf-core.min.js.map diff --git a/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js.map b/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js.map new file mode 100644 index 0000000..121abaa --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tf-core.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf-core.min.js","sources":["../src/util.ts","../src/profiler.ts","../src/tensor_format.ts","../src/tensor.ts","../src/tensor_util.ts","../src/engine.ts","../src/environment_util.ts","../src/tape.ts","../src/environment.ts","../src/device_util.ts","../src/log.ts","../src/ops/array_ops_util.ts","../src/ops/axis_util.ts","../src/ops/reduce_util.ts","../src/ops/slice_util.ts","../src/gradients.ts","../src/tensor_util_env.ts","../src/ops/operation.ts","../src/ops/softmax.ts","../src/ops/tensor_ops.ts","../src/types.ts","../src/kernels/backend_util.ts","../src/kernels/non_max_suppression_impl.ts","../src/kernels/topk_impl.ts","../src/kernels/webgl/argminmax_gpu.ts","../src/kernels/webgl/avg_pool_backprop_gpu.ts","../src/ops/broadcast_util.ts","../src/kernels/webgl/batchnorm_gpu.ts","../src/kernels/webgl/binaryop_gpu.ts","../src/kernels/webgl/clip_gpu.ts","../src/ops/concat_util.ts","../src/kernels/webgl/concat_gpu.ts","../src/kernels/webgl/conv_backprop_gpu.ts","../src/kernels/webgl/conv_backprop_gpu_depthwise.ts","../src/kernels/webgl/conv_gpu.ts","../src/kernels/webgl/conv_gpu_depthwise.ts","../src/kernels/webgl/shader_compiler.ts","../src/kernels/webgl/cumsum_gpu.ts","../src/kernels/webgl/encode_float_gpu.ts","../src/kernels/webgl/tex_util.ts","../src/kernels/webgl/from_pixels_gpu.ts","../src/kernels/webgl/gather_gpu.ts","../src/kernels/webgl/webgl_util.ts","../src/kernels/webgl/gpgpu_util.ts","../src/kernels/webgl/gpgpu_context.ts","../src/kernels/webgl/gpgpu_math.ts","../src/kernels/webgl/lrn_gpu.ts","../src/kernels/webgl/lrn_grad_gpu.ts","../src/kernels/webgl/max_pool_backprop_gpu.ts","../src/kernels/webgl/mulmat_gpu.ts","../src/kernels/webgl/multinomial_gpu.ts","../src/kernels/webgl/onehot_gpu.ts","../src/kernels/webgl/pad_gpu.ts","../src/kernels/webgl/pool_gpu.ts","../src/kernels/webgl/reduce_gpu.ts","../src/kernels/webgl/resize_bilinear_backprop_gpu.ts","../src/kernels/webgl/resize_bilinear_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_backprop_gpu.ts","../src/kernels/webgl/resize_nearest_neighbor_gpu.ts","../src/kernels/webgl/reverse_gpu.ts","../src/kernels/webgl/segment_gpu.ts","../src/kernels/webgl/select_gpu.ts","../src/kernels/webgl/slice_gpu.ts","../src/kernels/webgl/strided_slice_gpu.ts","../src/kernels/webgl/texture_manager.ts","../src/kernels/webgl/tile_gpu.ts","../src/kernels/webgl/transpose_gpu.ts","../src/ops/erf_util.ts","../src/ops/selu_util.ts","../src/kernels/webgl/unaryop_gpu.ts","../src/ops/concat.ts","../node_modules/seedrandom/lib/alea.js","../node_modules/seedrandom/lib/xor128.js","../node_modules/seedrandom/lib/xorwow.js","../node_modules/seedrandom/lib/xorshift7.js","../node_modules/seedrandom/lib/xor4096.js","../node_modules/seedrandom/lib/tychei.js","../node_modules/seedrandom/seedrandom.js","../node_modules/seedrandom/index.js","../src/ops/rand.ts","../src/ops/array_ops.ts","../src/kernels/where_impl.ts","../src/kernels/backend_webgl.ts","../src/ops/segment_util.ts","../src/ops/unary_ops.ts","../src/ops/batchnorm.ts","../src/ops/conv_util.ts","../src/ops/conv.ts","../src/ops/matmul.ts","../src/ops/reverse.ts","../src/ops/pool.ts","../src/ops/slice.ts","../src/globals.ts","../src/ops/reduction_ops.ts","../src/ops/compare.ts","../src/ops/binary_ops.ts","../src/ops/logical_ops.ts","../src/ops/relu_ops.ts","../src/ops/transpose.ts","../src/ops/lrn.ts","../src/ops/norm.ts","../src/ops/segment_ops.ts","../src/ops/lstm.ts","../src/ops/moving_average.ts","../src/ops/strided_slice.ts","../src/ops/loss_ops.ts","../src/ops/topk.ts","../src/ops/linalg_ops.ts","../src/ops/image_ops.ts","../src/kernels/backend_cpu.ts","../src/browser_util.ts","../src/io/types.ts","../src/io/io_utils.ts","../src/io/router_registry.ts","../src/io/model_management.ts","../src/io/indexed_db.ts","../src/io/local_storage.ts","../src/io/browser_files.ts","../src/io/weights_loader.ts","../src/io/browser_http.ts","../src/io/passthrough.ts","../src/io/io.ts","../src/serialization.ts","../src/test_util.ts","../src/optimizers/optimizer.ts","../src/optimizers/optimizer_utils.ts","../src/optimizers/adadelta_optimizer.ts","../src/optimizers/adagrad_optimizer.ts","../src/optimizers/adam_optimizer.ts","../src/optimizers/adamax_optimizer.ts","../src/optimizers/sgd_optimizer.ts","../src/optimizers/momentum_optimizer.ts","../src/optimizers/rmsprop_optimizer.ts","../src/optimizers/optimizer_constructors.ts","../src/train.ts","../src/index.ts","../src/version.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ArrayData, DataType, DataTypeMap, FlatVector, RecursiveArray, RegularArray, TensorLike, TypedArray} from './types';\n\n/** Shuffles the array using Fisher-Yates algorithm. */\n// tslint:disable-next-line:no-any\nexport function shuffle(array: any[]|Uint32Array|Int32Array|\n Float32Array): void {\n let counter = array.length;\n let temp = 0;\n let index = 0;\n // While there are elements in the array\n while (counter > 0) {\n // Pick a random index\n index = (Math.random() * counter) | 0;\n // Decrease counter by 1\n counter--;\n // And swap the last element with it\n temp = array[counter];\n array[counter] = array[index];\n array[index] = temp;\n }\n}\n\n/** Clamps a value to a specified range. */\nexport function clamp(min: number, x: number, max: number): number {\n return Math.max(min, Math.min(x, max));\n}\n\n/** Returns a sample from a uniform [a, b] distribution. */\nexport function randUniform(a: number, b: number) {\n return Math.random() * (b - a) + a;\n}\n\n/** Returns squared eucledian distance between two vectors. */\nexport function distSquared(a: FlatVector, b: FlatVector): number {\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n const diff = Number(a[i]) - Number(b[i]);\n result += diff * diff;\n }\n return result;\n}\n\nexport function assert(expr: boolean, msg: string|(() => string)) {\n if (!expr) {\n throw new Error(typeof msg === 'string' ? msg : msg());\n }\n}\n\nexport function assertShapesMatch(\n shapeA: number[], shapeB: number[], errorMessagePrefix = ''): void {\n assert(\n arraysEqual(shapeA, shapeB),\n errorMessagePrefix + ` Shapes ${shapeA} and ${shapeB} must match`);\n}\n\nexport function assertNonNull(a: TensorLike): void {\n assert(\n a != null,\n `The input to the tensor constructor must be a non-null value.`);\n}\n\n// NOTE: We explicitly type out what T extends instead of any so that\n// util.flatten on a nested array of number doesn't try to infer T as a\n// number[][], causing us to explicitly type util.flatten().\nexport function flatten>(\n arr: T|RecursiveArray, ret: T[] = []): T[] {\n if (Array.isArray(arr)) {\n for (let i = 0; i < arr.length; ++i) {\n flatten(arr[i], ret);\n }\n } else {\n ret.push(arr as T);\n }\n return ret;\n}\n\nexport function inferShape(val: TypedArray|number|boolean|RegularArray|\n RegularArray): number[] {\n let firstElem: typeof val = val;\n\n if (isTypedArray(val)) {\n return [(val as TypedArray).length];\n }\n if (!Array.isArray(val)) {\n return []; // Scalar.\n }\n const shape: number[] = [];\n\n while (firstElem instanceof Array) {\n shape.push(firstElem.length);\n firstElem = firstElem[0];\n }\n if (val instanceof Array) {\n deepAssertShapeConsistency(val, shape, []);\n }\n return shape;\n}\n\nfunction deepAssertShapeConsistency(\n val: number|boolean|RegularArray|RegularArray,\n shape: number[], indices?: number[]) {\n indices = indices || [];\n if (!(val instanceof Array)) {\n assert(\n shape.length === 0,\n () => `Element arr[${indices.join('][')}] is a primitive, ` +\n `but should be an array of ${shape[0]} elements`);\n return;\n }\n assert(\n shape.length > 0,\n () => `Element arr[${indices.join('][')}] should be a primitive, ` +\n `but is an array of ${val.length} elements`);\n assert(\n val.length === shape[0],\n () => `Element arr[${indices.join('][')}] should have ${shape[0]} ` +\n `elements, but has ${val.length} elements`);\n const subShape = shape.slice(1);\n for (let i = 0; i < val.length; ++i) {\n deepAssertShapeConsistency(val[i], subShape, indices.concat(i));\n }\n}\n\nexport function sizeFromShape(shape: number[]): number {\n if (shape.length === 0) {\n // Scalar.\n return 1;\n }\n let size = shape[0];\n for (let i = 1; i < shape.length; i++) {\n size *= shape[i];\n }\n return size;\n}\n\nexport function isScalarShape(shape: number[]): boolean {\n return shape.length === 0;\n}\n\nexport function arraysEqual(n1: FlatVector, n2: FlatVector) {\n if (n1.length !== n2.length) {\n return false;\n }\n for (let i = 0; i < n1.length; i++) {\n if (n1[i] !== n2[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function isInt(a: number): boolean {\n return a % 1 === 0;\n}\n\nexport function tanh(x: number): number {\n // tslint:disable-next-line:no-any\n if ((Math as any).tanh != null) {\n // tslint:disable-next-line:no-any\n return (Math as any).tanh(x);\n }\n if (x === Infinity) {\n return 1;\n } else if (x === -Infinity) {\n return -1;\n } else {\n const e2x = Math.exp(2 * x);\n return (e2x - 1) / (e2x + 1);\n }\n}\n\nexport function sizeToSquarishShape(size: number): [number, number] {\n for (let a = Math.floor(Math.sqrt(size)); a > 1; --a) {\n if (size % a === 0) {\n return [a, size / a];\n }\n }\n return [1, size];\n}\n\nexport function createShuffledIndices(n: number): Uint32Array {\n const shuffledIndices = new Uint32Array(n);\n for (let i = 0; i < n; ++i) {\n shuffledIndices[i] = i;\n }\n shuffle(shuffledIndices);\n return shuffledIndices;\n}\n\nexport function rightPad(a: string, size: number): string {\n if (size <= a.length) {\n return a;\n }\n return a + ' '.repeat(size - a.length);\n}\n\nexport function repeatedTry(\n checkFn: () => boolean, delayFn = (counter: number) => 0,\n maxCounter?: number): Promise {\n return new Promise((resolve, reject) => {\n let tryCount = 0;\n\n const tryFn = () => {\n if (checkFn()) {\n resolve();\n return;\n }\n\n tryCount++;\n\n const nextBackoff = delayFn(tryCount);\n\n if (maxCounter != null && tryCount >= maxCounter) {\n reject();\n return;\n }\n setTimeout(tryFn, nextBackoff);\n };\n\n tryFn();\n });\n}\n\n/**\n * Given the full size of the array and a shape that may contain -1 as the\n * implicit dimension, returns the inferred shape where -1 is replaced.\n * E.g. For shape=[2, -1, 3] and size=24, it will return [2, 4, 3].\n *\n * @param shape The shape, which may contain -1 in some dimension.\n * @param size The full size (number of elements) of the array.\n * @return The inferred shape where -1 is replaced with the inferred size.\n */\nexport function inferFromImplicitShape(\n shape: number[], size: number): number[] {\n let shapeProd = 1;\n let implicitIdx = -1;\n\n for (let i = 0; i < shape.length; ++i) {\n if (shape[i] > 0) {\n shapeProd *= shape[i];\n } else if (shape[i] === -1) {\n if (implicitIdx !== -1) {\n throw Error(\n `Shapes can only have 1 implicit size. ` +\n `Found - 1 at dim ${implicitIdx} and dim ${i}`);\n }\n implicitIdx = i;\n } else if (shape[i] <= 0) {\n throw Error(`Shapes can not be <= 0. Found ${shape[i]} at dim ${i}`);\n }\n }\n\n if (implicitIdx === -1) {\n if (size > 0 && size !== shapeProd) {\n throw Error(`Size(${size}) must match the product of shape ${shape}`);\n }\n return shape;\n }\n\n if (size % shapeProd !== 0) {\n throw Error(\n `The implicit shape can't be a fractional number. ` +\n `Got ${size} / ${shapeProd}`);\n }\n\n const newShape = shape.slice();\n newShape[implicitIdx] = size / shapeProd;\n return newShape;\n}\n\n/** Reduces the shape by removing all dimensions of shape 1. */\nexport function squeezeShape(shape: number[], axis?: number[]):\n {newShape: number[], keptDims: number[]} {\n const newShape: number[] = [];\n const keptDims: number[] = [];\n let j = 0;\n for (let i = 0; i < shape.length; ++i) {\n if (axis != null) {\n if (axis[j] === i && shape[i] > 1) {\n throw new Error(\n `Can't squeeze axis ${i} since its dim '${shape[i]}' is not 1`);\n }\n if ((axis[j] == null || axis[j] > i) && shape[i] === 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n if (axis[j] <= i) {\n j++;\n }\n }\n if (shape[i] > 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n }\n return {newShape, keptDims};\n}\n\nexport function getTypedArrayFromDType(\n dtype: D, size: number): DataTypeMap[D] {\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n return values;\n}\n\nexport function checkComputationForNaN(\n vals: DataTypeMap[D], dtype: D, name: string): void {\n if (dtype !== 'float32') {\n // Only floating point computations will generate NaN values\n return;\n }\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`The result of the '${name}' has NaNs.`);\n }\n }\n}\n\nexport function checkConversionForNaN(\n vals: DataTypeMap[D]|number[], dtype: D): void {\n if (dtype === 'float32') {\n // NaN is valid for floating point conversions\n return;\n }\n\n for (let i = 0; i < vals.length; i++) {\n if (isNaN(vals[i])) {\n throw Error(`NaN is not a valid value for dtype: '${dtype}'.`);\n }\n }\n}\n\n/**\n * Returns true if the new type can't encode the old type without loss of\n * precision.\n */\nexport function hasEncodingLoss(oldType: DataType, newType: DataType): boolean {\n if (newType === 'float32') {\n return false;\n }\n if (newType === 'int32' && oldType !== 'float32') {\n return false;\n }\n if (newType === 'bool' && oldType === 'bool') {\n return false;\n }\n return true;\n}\n\nfunction copyTypedArray(\n array: DataTypeMap[D]|number[]|boolean[], dtype: D,\n debugMode: boolean): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(array as number[]);\n } else if (dtype === 'int32') {\n if (debugMode) {\n checkConversionForNaN(array as number[], dtype);\n }\n return new Int32Array(array as number[]);\n } else if (dtype === 'bool') {\n const bool = new Uint8Array(array.length);\n for (let i = 0; i < bool.length; ++i) {\n if (Math.round(array[i] as number) !== 0) {\n bool[i] = 1;\n }\n }\n return bool;\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\nexport function isTypedArray(a: TypedArray|number|boolean|RegularArray|\n RegularArray): boolean {\n return a instanceof Float32Array || a instanceof Int32Array ||\n a instanceof Uint8Array;\n}\n\nexport function bytesPerElement(dtype: DataType): number {\n if (dtype === 'float32' || dtype === 'int32') {\n return 4;\n } else if (dtype === 'bool') {\n return 1;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nexport function isFunction(f: Function) {\n return !!(f && f.constructor && f.call && f.apply);\n}\n\nexport function nearestDivisor(size: number, start: number): number {\n for (let i = start; i < size; ++i) {\n if (size % i === 0) {\n return i;\n }\n }\n return size;\n}\n\nexport function computeStrides(shape: number[]): number[] {\n const rank = shape.length;\n if (rank < 2) {\n return [];\n }\n\n // Last dimension has implicit stride of 1, thus having D-1 (instead of D)\n // strides.\n const strides = new Array(rank - 1);\n strides[rank - 2] = shape[rank - 1];\n for (let i = rank - 3; i >= 0; --i) {\n strides[i] = strides[i + 1] * shape[i + 1];\n }\n return strides;\n}\n\nexport function toTypedArray(\n a: ArrayData, dtype: D, debugMode: boolean): DataTypeMap[D] {\n if (noConversionNeeded(a, dtype)) {\n return a as DataTypeMap[D];\n }\n if (Array.isArray(a)) {\n a = flatten(a as number[]);\n }\n return copyTypedArray(a, dtype, debugMode);\n}\n\nfunction noConversionNeeded(\n a: ArrayData, dtype: D): boolean {\n return (a instanceof Float32Array && dtype === 'float32') ||\n (a instanceof Int32Array && dtype === 'int32') ||\n (a instanceof Uint8Array && dtype === 'bool');\n}\n\nexport function makeOnesTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n const array = makeZerosTypedArray(size, dtype);\n for (let i = 0; i < array.length; i++) {\n array[i] = 1;\n }\n return array;\n}\n\nexport function makeZerosTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32') {\n return new Float32Array(size);\n } else if (dtype === 'int32') {\n return new Int32Array(size);\n } else if (dtype === 'bool') {\n return new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\n/**\n * Returns the current high-resolution real time in milliseconds. It is\n * relative to an arbitrary time in the past.\n */\nexport function now(): number {\n if (typeof performance !== 'undefined') {\n return performance.now();\n } else if (typeof process !== 'undefined') {\n const time = process.hrtime();\n return time[0] * 1000 + time[1] / 1000000;\n } else {\n throw new Error(\n 'Can not measure time in this environment. You should run tf.js ' +\n 'in the browser or in Node.js');\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimer} from './kernels/backend';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\nexport class Profiler {\n constructor(private backendTimer: BackendTimer, private logger?: Logger) {\n if (logger == null) {\n this.logger = new Logger();\n }\n }\n\n profileKernel(name: string, f: () => T | Tensor[]):\n T {\n let result: T|Tensor[];\n const holdResultWrapperFn = () => {\n result = f();\n };\n const timer = this.backendTimer.time(holdResultWrapperFn);\n\n const results: Tensor[] =\n Array.isArray(result) ? result : [result] as Tensor[];\n results.forEach(r => {\n const vals = r.dataSync();\n util.checkComputationForNaN(vals, r.dtype, name);\n\n timer.then(timing => {\n this.logger.logKernelProfile(name, r, vals, timing.kernelMs);\n });\n });\n\n return result as T;\n }\n}\n\nexport class Logger {\n logKernelProfile(\n name: string, result: Tensor, vals: TypedArray, timeMs: number) {\n const time = util.rightPad(`${timeMs}ms`, 9);\n const paddedName = util.rightPad(name, 25);\n const rank = result.rank;\n const size = result.size;\n const shape = util.rightPad(result.shape.toString(), 14);\n console.log(\n `%c${paddedName}\\t%c${time}\\t%c${rank}D ${shape}\\t%c${size}`,\n 'font-weight:bold', 'color:red', 'color:blue', 'color: orange');\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, TypedArray} from './types';\nimport {computeStrides, rightPad, sizeFromShape} from './util';\n\n// Maximum number of values before we decide to show ellipsis.\nconst FORMAT_LIMIT_NUM_VALS = 20;\n// Number of first and last values to show when displaying a, b,...,y, z.\nconst FORMAT_NUM_FIRST_LAST_VALS = 3;\n// Number of significant digits to show.\nconst FORMAT_NUM_SIG_DIGITS = 7;\n\nexport function tensorToString(\n vals: TypedArray, shape: number[], dtype: DataType, verbose: boolean) {\n const strides = computeStrides(shape);\n const padPerCol = computeMaxSizePerColumn(vals, shape, strides);\n const rank = shape.length;\n const valsLines = subTensorToString(vals, shape, strides, padPerCol);\n const lines = ['Tensor'];\n if (verbose) {\n lines.push(` dtype: ${dtype}`);\n lines.push(` rank: ${rank}`);\n lines.push(` shape: [${shape}]`);\n lines.push(` values:`);\n }\n lines.push(valsLines.map(l => ' ' + l).join('\\n'));\n return lines.join('\\n');\n}\n\nfunction computeMaxSizePerColumn(\n vals: TypedArray, shape: number[], strides: number[]): number[] {\n const n = sizeFromShape(shape);\n const numCols = strides[strides.length - 1];\n const padPerCol = new Array(numCols).fill(0);\n const rank = shape.length;\n if (rank > 1) {\n for (let row = 0; row < n / numCols; row++) {\n const offset = row * numCols;\n for (let j = 0; j < numCols; j++) {\n padPerCol[j] =\n Math.max(padPerCol[j], valToString(vals[offset + j], 0).length);\n }\n }\n }\n return padPerCol;\n}\n\nfunction valToString(val: number, pad: number) {\n return rightPad(\n parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), pad);\n}\n\nfunction subTensorToString(\n vals: TypedArray, shape: number[], strides: number[], padPerCol: number[],\n isLast = true): string[] {\n const size = shape[0];\n const rank = shape.length;\n if (rank === 0) {\n return [vals[0].toString()];\n }\n\n if (rank === 1) {\n if (size > FORMAT_LIMIT_NUM_VALS) {\n const firstVals =\n Array.from(vals.subarray(0, FORMAT_NUM_FIRST_LAST_VALS));\n const lastVals =\n Array.from(vals.subarray(size - FORMAT_NUM_FIRST_LAST_VALS, size));\n return [\n '[' + firstVals.map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ', ..., ' +\n lastVals\n .map(\n (x, i) => valToString(\n x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i]))\n .join(', ') +\n ']'\n ];\n }\n return [\n '[' +\n Array.from(vals).map((x, i) => valToString(x, padPerCol[i])).join(', ') +\n ']'\n ];\n }\n\n // The array is rank 2 or more.\n const subshape = shape.slice(1);\n const substrides = strides.slice(1);\n const stride = strides[0];\n const lines: string[] = [];\n if (size > FORMAT_LIMIT_NUM_VALS) {\n for (let i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n false /* isLast */));\n }\n lines.push('...');\n for (let i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n } else {\n for (let i = 0; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.subarray(start, end), subshape, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n }\n const sep = rank === 2 ? ',' : '';\n lines[0] = '[' + lines[0] + sep;\n for (let i = 1; i < lines.length - 1; i++) {\n lines[i] = ' ' + lines[i] + sep;\n }\n let newLineSep = ',\\n';\n for (let i = 2; i < rank; i++) {\n newLineSep += '\\n';\n }\n lines[lines.length - 1] =\n ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep);\n return lines;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensorToString} from './tensor_format';\nimport {DataType, Rank, ShapeMap, TypedArray} from './types';\nimport * as util from './util';\nimport {computeStrides} from './util';\n\n/** @hidden */\nexport interface TensorData {\n dataId?: DataId;\n values?: TypedArray;\n}\n\n/**\n * A mutable object, similar to `Tensor`, that allows users to set values\n * at locations before converting to an immutable `Tensor`.\n *\n * See `buffer` for creating a tensor buffer.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class TensorBuffer {\n size: number;\n shape: ShapeMap[R];\n strides: number[];\n values: TypedArray;\n\n constructor(shape: ShapeMap[R], public dtype: DataType, values: TypedArray) {\n if (values != null) {\n const n = values.length;\n const size = util.sizeFromShape(shape);\n util.assert(\n n === size,\n `Length of values '${n}' does not match the size ` +\n `inferred by the shape '${size}'`);\n }\n this.shape = shape.slice();\n this.values =\n values || util.getTypedArrayFromDType(dtype, util.sizeFromShape(shape));\n this.strides = computeStrides(shape);\n this.size = util.sizeFromShape(shape);\n }\n\n /**\n * Sets a value in the buffer at a given location.\n *\n * @param value The value to set.\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n set(value: number, ...locs: number[]) {\n if (locs.length === 0) {\n locs = [0];\n }\n util.assert(\n locs.length === this.rank,\n `The number of provided coordinates (${locs.length}) must ` +\n `match the rank (${this.rank})`);\n const index = this.locToIndex(locs);\n this.values[index] = value;\n }\n\n /**\n * Returns the value in the buffer at the provided location.\n *\n * @param locs The location indices.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n get(...locs: number[]): number {\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.values[index];\n }\n\n locToIndex(locs: number[]): number {\n if (this.rank === 0) {\n return 0;\n } else if (this.rank === 1) {\n return locs[0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return index;\n }\n\n indexToLoc(index: number): number[] {\n if (this.rank === 0) {\n return [];\n } else if (this.rank === 1) {\n return [index];\n }\n const locs: number[] = new Array(this.shape.length);\n for (let i = 0; i < locs.length - 1; ++i) {\n locs[i] = Math.floor(index / this.strides[i]);\n index -= locs[i] * this.strides[i];\n }\n locs[locs.length - 1] = index;\n return locs;\n }\n\n get rank() {\n return this.shape.length;\n }\n\n /**\n * Creates an immutable `Tensor` object from the buffer.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n toTensor(): Tensor {\n return Tensor.make(this.shape, {values: this.values}, this.dtype);\n }\n}\n\nexport interface TensorTracker {\n registerTensor(t: Tensor): void;\n disposeTensor(t: Tensor): void;\n write(dataId: DataId, values: TypedArray): void;\n read(dataId: DataId): Promise;\n readSync(dataId: DataId): TypedArray;\n registerVariable(v: Variable): void;\n}\n\n/**\n * The Tensor class calls into this handler to delegate chaining operations.\n */\nexport interface OpHandler {\n cast(x: T, dtype: DataType): T;\n buffer(\n shape: ShapeMap[R], dtype: DataType,\n values?: TypedArray): TensorBuffer;\n print(x: T, verbose: boolean): void;\n reshape(x: Tensor, shape: ShapeMap[R2]): Tensor;\n expandDims(x: Tensor, axis: number): Tensor;\n cumsum(\n x: Tensor, axis: number, exclusive: boolean, reverse: boolean): T;\n squeeze(x: Tensor, axis?: number[]): T;\n clone(x: T): T;\n tile(x: T, reps: number[]): T;\n gather(x: T, indices: Tensor1D, axis: number): T;\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D;\n dot(t1: Tensor, t2: Tensor): Tensor;\n norm(\n x: Tensor, ord: number|'euclidean'|'fro', axis: number|number[],\n keepDims: boolean): Tensor;\n slice>(\n x: T, begin: number|number[], size?: number|number[]): T;\n reverse(x: T, axis?: number|number[]): T;\n concat(tensors: T[], axis: number): T;\n stack(tensors: T[], axis: number): Tensor;\n unstack(value: T, axis: number): Tensor[];\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T;\n batchNormalization(\n x: Tensor, mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon: number, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor;\n all(x: Tensor, axis: number|number[], keepDims: boolean): T;\n any(x: Tensor, axis: number|number[], keepDims: boolean): T;\n logSumExp(\n x: Tensor, axis: number|number[], keepDims: boolean): T;\n sum(x: Tensor, axis: number|number[], keepDims: boolean): T;\n mean(x: Tensor, axis: number|number[], keepDims: boolean):\n T;\n min(x: Tensor, axis: number|number[], keepDims: boolean): T;\n max(x: Tensor, axis: number|number[], keepDims: boolean): T;\n argMin(x: Tensor, axis: number): T;\n argMax(x: Tensor, axis: number): T;\n add(a: Tensor, b: Tensor): T;\n addStrict(a: T, b: T): T;\n sub(a: Tensor, b: Tensor): T;\n subStrict(a: T, b: T): T;\n pow(base: T, exp: Tensor): T;\n powStrict(base: T, exp: Tensor): T;\n mul(a: Tensor, b: Tensor): T;\n mulStrict(a: T, b: T): T;\n div(a: Tensor, b: Tensor): T;\n floorDiv(a: Tensor, b: Tensor): T;\n divStrict(a: T, b: T): T;\n mod(a: Tensor, b: Tensor): T;\n modStrict(a: T, b: T): T;\n minimum(a: Tensor, b: Tensor): T;\n minimumStrict(a: T, b: T): T;\n maximum(a: Tensor, b: Tensor): T;\n maximumStrict(a: T, b: T): T;\n squaredDifference(a: Tensor, b: Tensor): T;\n squaredDifferenceStrict(a: T, b: T): T;\n transpose(x: T, perm?: number[]): T;\n logicalNot(x: T): T;\n logicalAnd(a: Tensor, b: Tensor): T;\n logicalOr(a: Tensor, b: Tensor): T;\n logicalXor(a: Tensor, b: Tensor): T;\n where(condition: Tensor, a: T, b: T): T;\n notEqual(a: Tensor, b: Tensor): T;\n notEqualStrict(a: T, b: T): T;\n less(a: Tensor, b: Tensor): T;\n lessStrict(a: T, b: T): T;\n equal(a: Tensor, b: Tensor): T;\n equalStrict(a: T, b: T): T;\n lessEqual(a: Tensor, b: Tensor): T;\n lessEqualStrict(a: T, b: T): T;\n greater(a: Tensor, b: Tensor): T;\n greaterStrict(a: T, b: T): T;\n greaterEqual(a: Tensor, b: Tensor): T;\n greaterEqualStrict(a: T, b: T): T;\n neg(x: T): T;\n ceil(x: T): T;\n floor(x: T): T;\n sign(x: T): T;\n round(x: T): T;\n exp(x: T): T;\n expm1(x: T): T;\n log(x: T): T;\n log1p(x: T): T;\n sqrt(x: T): T;\n rsqrt(x: T): T;\n square(x: T): T;\n reciprocal(x: T): T;\n abs(x: T): T;\n clipByValue(\n x: T, clipValueMin: number, clipValueMax: number): T;\n sigmoid(x: T): T;\n logSigmoid(x: T): T;\n softplus(x: T): T;\n sin(x: T): T;\n cos(x: T): T;\n tan(x: T): T;\n asin(x: T): T;\n acos(x: T): T;\n atan(x: T): T;\n sinh(x: T): T;\n cosh(x: T): T;\n tanh(x: T): T;\n asinh(x: T): T;\n acosh(x: T): T;\n atanh(x: T): T;\n erf(x: T): T;\n step(x: T, alpha: number): T;\n relu(x: T): T;\n elu(x: T): T;\n selu(x: T): T;\n leakyRelu(x: T, alpha: number): T;\n prelu(x: T, alpha: T): T;\n softmax(logits: T, dim: number): T;\n image: {\n resizeBilinear(\n images: T, size: [number, number], alignCorners: boolean): T;\n resizeNearestNeighbor(\n images: T, size: [number, number], alignCorners: boolean): T;\n };\n conv1d(\n x: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW', dilation: number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n conv2dTranspose(\n x: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n depthwiseConv2d(\n x: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW',\n dilations: [number, number]|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n maxPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n avgPool(\n x: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T;\n localResponseNormalization(\n x: T, depthRadius: number, bias: number, alpha: number, beta: number): T;\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): T;\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T;\n spaceToBatchND(\n x: T, blockShape: number[], paddings: number[][]): T;\n}\n\n// For tracking tensor creation and disposal.\nlet trackerFn: () => TensorTracker = null;\n// Used by chaining methods to call into ops.\nlet opHandler: OpHandler = null;\n\n/**\n * An external consumer can register itself as the tensor tracker. This way\n * the Tensor class can notify the tracker for every tensor created and\n * disposed.\n */\nexport function setTensorTracker(fn: () => TensorTracker) {\n trackerFn = fn;\n}\n\n/**\n * An external consumer can register itself as the op handler. This way the\n * Tensor class can have chaining methods that call into ops via the op handler.\n */\nexport function setOpHandler(handler: OpHandler) {\n opHandler = handler;\n}\n\n/**\n * We wrap data id since we use weak map to avoid memory leaks.\n * Since we have our own memory management, we have a reference counter\n * mapping a tensor to its data, so there is always a pointer (even if that\n * data is otherwise garbage collectable).\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/\n * Global_Objects/WeakMap\n */\nexport type DataId = object; // object instead of {} to force non-primitive.\n\n/**\n * A `Tensor` object represents an immutable, multidimensional array of numbers\n * that has a shape and a data type.\n *\n * See `tensor` for details on how to create a `Tensor`.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Tensor {\n private static nextId = 0;\n\n /** Unique id of this tensor. */\n readonly id: number;\n /**\n * Id of the bucket holding the data for this tensor. Multiple arrays can\n * point to the same bucket (e.g. when calling array.reshape()).\n */\n dataId: DataId;\n /** The shape of the tensor. */\n readonly shape: ShapeMap[R];\n /** Number of elements in the tensor. */\n readonly size: number;\n /** The data type for the array. */\n readonly dtype: DataType;\n /** The rank type for the array (see `Rank` enum). */\n readonly rankType: R;\n\n /**\n * Number of elements to skip in each dimension when indexing. See\n * https://docs.scipy.org/doc/numpy/reference/generated/\\\n * numpy.ndarray.strides.html\n */\n readonly strides: number[];\n\n protected constructor(\n shape: ShapeMap[R], dtype: DataType, values?: TypedArray,\n dataId?: DataId) {\n this.size = util.sizeFromShape(shape);\n if (values != null) {\n util.assert(\n this.size === values.length,\n `Constructing tensor of shape (${this.size}) should match the ` +\n `length of values (${values.length})`);\n }\n this.shape = shape.slice();\n this.dtype = dtype || 'float32';\n this.strides = computeStrides(shape);\n this.dataId = dataId != null ? dataId : {};\n this.id = Tensor.nextId++;\n this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher') as R;\n trackerFn().registerTensor(this);\n if (values != null) {\n trackerFn().write(this.dataId, values);\n }\n }\n\n /**\n * Makes a new tensor with the provided shape and values. Values should be in\n * a flat array.\n */\n static make, D extends DataType = 'float32',\n R extends Rank = Rank>(\n shape: ShapeMap[R], data: TensorData, dtype?: D): T {\n return new Tensor(shape, dtype, data.values, data.dataId) as T;\n }\n\n /** Flatten a Tensor to a 1D array. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n flatten(): Tensor1D {\n this.throwIfDisposed();\n return this.as1D();\n }\n\n /** Converts a size-1 `Tensor` to a `Scalar`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asScalar(): Scalar {\n this.throwIfDisposed();\n util.assert(this.size === 1, 'The array must have only 1 element.');\n return this.reshape([]);\n }\n\n /** Converts a `Tensor` to a `Tensor1D`. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as1D(): Tensor1D {\n this.throwIfDisposed();\n return this.reshape([this.size]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor2D`.\n *\n * @param rows Number of rows in `Tensor2D`.\n * @param columns Number of columns in `Tensor2D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as2D(rows: number, columns: number): Tensor2D {\n this.throwIfDisposed();\n return this.reshape([rows, columns]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor3D`.\n *\n * @param rows Number of rows in `Tensor3D`.\n * @param columns Number of columns in `Tensor3D`.\n * @param depth Depth of `Tensor3D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as3D(rows: number, columns: number, depth: number): Tensor3D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth]);\n }\n\n /**\n * Converts a `Tensor` to a `Tensor4D`.\n *\n * @param rows Number of rows in `Tensor4D`.\n * @param columns Number of columns in `Tensor4D`.\n * @param depth Depth of `Tensor4D`.\n * @param depth2 4th dimension of `Tensor4D`.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n as4D(rows: number, columns: number, depth: number, depth2: number): Tensor4D {\n this.throwIfDisposed();\n return this.reshape([rows, columns, depth, depth2]);\n }\n\n /**\n * Casts a `Tensor` to a specified dtype.\n *\n * @param dtype Data-type to cast the tensor to.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n asType(this: T, dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this, dtype) as T;\n }\n\n get rank(): number {\n return this.shape.length;\n }\n\n /**\n * Returns the value in the tensor at the provided location.\n * If using WebGL backend, this is a blocking call.\n * Prefer calling the `async data()[flatIndex]` method instead.\n *\n * @param locs The location indices.\n */\n get(...locs: number[]) {\n util.assert(\n locs.length === this.rank,\n 'Number of coordinates in get() must match the rank of the tensor');\n this.throwIfDisposed();\n if (locs.length === 0) {\n locs = [0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.dataSync()[index];\n }\n\n /** Returns a `TensorBuffer` that holds the underlying data. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n buffer(): TensorBuffer {\n return opHandler.buffer(this.shape, this.dtype, this.dataSync());\n }\n\n /**\n * Asynchronously downloads the values from the `Tensor`. Returns a promise of\n * `TypedArray` that resolves when the computation has finished.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n async data(): Promise {\n this.throwIfDisposed();\n return trackerFn().read(this.dataId);\n }\n\n /**\n * Synchronously downloads the values from the `Tensor`. This blocks the UI\n * thread until the values are ready, which can cause performance issues.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dataSync(): TypedArray {\n this.throwIfDisposed();\n return trackerFn().readSync(this.dataId);\n }\n\n /**\n * Disposes `Tensor` from memory.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n trackerFn().disposeTensor(this);\n this.isDisposedInternal = true;\n }\n\n private isDisposedInternal = false;\n get isDisposed(): boolean {\n return this.isDisposedInternal;\n }\n\n private throwIfDisposed() {\n if (this.isDisposed) {\n throw new Error(`Tensor is disposed.`);\n }\n }\n\n /** Casts the array to type `float32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toFloat(this: T): T {\n return this.asType('float32');\n }\n\n /** Casts the array to type `int32` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toInt() {\n return this.asType('int32');\n }\n\n /** Casts the array to type `bool` */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toBool() {\n return this.asType('bool');\n }\n\n /**\n * Prints the `Tensor`. See `print` for details.\n *\n * @param verbose Whether to print verbose information about the tensor,\n * including dtype and size.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n print(verbose = false): void {\n return opHandler.print(this, verbose);\n }\n\n /**\n * Reshapes the tensor into the provided shape.\n * See `reshape` for more details.\n *\n * @param newShape An array of integers defining the output tensor shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshape(newShape: ShapeMap[R2]): Tensor {\n this.throwIfDisposed();\n return opHandler.reshape(this, newShape);\n }\n\n /**\n * Reshapes the tensor into the shape of the provided tensor.\n *\n * @param x The tensor of required shape.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n reshapeAs(x: T): T {\n this.throwIfDisposed();\n return this.reshape(x.shape) as T;\n }\n\n /**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape. See `expandDims` for details.\n *\n * @param axis The dimension index at which to insert shape of 1. Defaults to\n * 0 (the first dimension).\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n expandDims(axis = 0): Tensor {\n return opHandler.expandDims(this, axis);\n }\n\n /**\n * Returns the cumulative sum of the `Tensor` along `axis`.\n *\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Defaults to\n * false. If set to true then the sum of each tensor entry does not include\n * its own value, but only the values previous to it along the specified\n * axis.\n * @param reverse Whether to sum in the opposite direction. Defaults to\n * false.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n cumsum(axis = 0, exclusive = false, reverse = false): T {\n return opHandler.cumsum(this, axis, exclusive, reverse);\n }\n\n /**\n * Returns a `Tensor` with dimensions of size 1 removed from the shape.\n * See `squeeze` for more details.\n *\n * @param axis A list of numbers. If specified, only squeezes the\n * dimensions listed. The dimension index starts at 0. It is an error to\n * squeeze a dimension that is not 1.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n squeeze(axis?: number[]): T {\n this.throwIfDisposed();\n return opHandler.squeeze(this, axis);\n }\n\n /** Returns a copy of the tensor. See `clone` for details. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n clone(this: T): T {\n this.throwIfDisposed();\n return opHandler.clone(this);\n }\n\n /** Returns a human-readable description of the tensor. Useful for logging. */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n toString(verbose = false): string {\n const vals = this.dataSync();\n return tensorToString(vals, this.shape, this.dtype, verbose);\n }\n\n // Below is chain API that is not exposed to docs to avoid repetition. To\n // expose a method, move it above this comment and add @doc and jsdoc.\n\n tile(this: T, reps: number[]): T {\n this.throwIfDisposed();\n return opHandler.tile(this, reps) as T;\n }\n\n gather(this: T, indices: Tensor1D, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.gather(this, indices, axis) as T;\n }\n\n matMul(b: Tensor2D, transposeA = false, transposeB = false): Tensor2D {\n this.throwIfDisposed();\n return opHandler.matMul(this as Tensor2D, b, transposeA, transposeB);\n }\n dot(b: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.dot(this, b);\n }\n norm(\n ord: number|'euclidean'|'fro' = 'euclidean', axis: number|number[] = null,\n keepDims = false): Tensor {\n this.throwIfDisposed();\n return opHandler.norm(this, ord, axis, keepDims);\n }\n slice>(\n this: T, begin: number|number[], size?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.slice(this, begin, size);\n }\n reverse(this: T, axis?: number|number[]): T {\n this.throwIfDisposed();\n return opHandler.reverse(this, axis);\n }\n concat(this: T, x: T, axis = 0): T {\n this.throwIfDisposed();\n return opHandler.concat([this, x], axis);\n }\n stack(x: Tensor, axis = 0): Tensor {\n return opHandler.stack([this, x], axis);\n }\n unstack(x: Tensor, axis = 0): Tensor[] {\n return opHandler.unstack(this, axis);\n }\n pad(\n this: T, paddings: Array<[number, number]>, constantValue = 0): T {\n return opHandler.pad(this, paddings, constantValue);\n }\n batchNormalization(\n mean: Tensor|Tensor1D, variance: Tensor|Tensor1D,\n varianceEpsilon = .001, scale?: Tensor|Tensor1D,\n offset?: Tensor|Tensor1D): Tensor {\n this.throwIfDisposed();\n return opHandler.batchNormalization(\n this, mean, variance, varianceEpsilon, scale, offset);\n }\n\n // Reduction ops.\n all(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.all(this, axis, keepDims);\n }\n any(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.any(this, axis, keepDims);\n }\n logSumExp(axis: number|number[] = null, keepDims = false):\n T {\n this.throwIfDisposed();\n return opHandler.logSumExp(this, axis, keepDims);\n }\n sum(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.sum(this, axis, keepDims);\n }\n mean(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.mean(this, axis, keepDims);\n }\n min(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.min(this, axis, keepDims);\n }\n max(axis: number|number[] = null, keepDims = false): T {\n this.throwIfDisposed();\n return opHandler.max(this, axis, keepDims);\n }\n argMin(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMin(this, axis);\n }\n argMax(axis: number = null): T {\n this.throwIfDisposed();\n return opHandler.argMax(this, axis);\n }\n\n // Transformations\n cast(dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this as T, dtype) as T;\n }\n\n // Binary ops.\n\n add(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.add(this, x);\n }\n addStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.addStrict(this, x) as T;\n }\n sub(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.sub(this, x);\n }\n subStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.subStrict(this, x) as T;\n }\n pow(this: T, exp: Tensor): T {\n this.throwIfDisposed();\n return opHandler.pow(this, exp);\n }\n powStrict(exp: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.powStrict(this, exp);\n }\n mul(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mul(this, x);\n }\n mulStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.mulStrict(this, x) as T;\n }\n div(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.div(this, x);\n }\n floorDiv(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.floorDiv(this, x);\n }\n divStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.divStrict(this, x) as T;\n }\n minimum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.minimum(this, x);\n }\n minimumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.minimumStrict(this, x) as T;\n }\n maximum(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.maximum(this, x);\n }\n maximumStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.maximumStrict(this, x) as T;\n }\n mod(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.mod(this, x);\n }\n modStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.modStrict(this, x) as T;\n }\n squaredDifference(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.squaredDifference(this, x);\n }\n squaredDifferenceStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.squaredDifferenceStrict(this, x) as T;\n }\n transpose(this: T, perm?: number[]): T {\n this.throwIfDisposed();\n return opHandler.transpose(this, perm);\n }\n\n // Compare ops.\n\n notEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.notEqual(this, x);\n }\n notEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.notEqualStrict(this, x) as T;\n }\n less(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.less(this, x);\n }\n lessStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessStrict(this, x) as T;\n }\n equal(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.equal(this, x);\n }\n equalStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.equalStrict(this, x) as T;\n }\n lessEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.lessEqual(this, x);\n }\n lessEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.lessEqualStrict(this, x) as T;\n }\n greater(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greater(this, x);\n }\n greaterStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterStrict(this, x) as T;\n }\n greaterEqual(x: Tensor): T {\n this.throwIfDisposed();\n return opHandler.greaterEqual(this, x);\n }\n greaterEqualStrict(this: T, x: T): T {\n this.throwIfDisposed();\n return opHandler.greaterEqualStrict(this, x) as T;\n }\n\n // Compare ops.\n logicalAnd(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalAnd(this, x);\n }\n logicalOr(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalOr(this, x);\n }\n logicalNot(this: T): T {\n this.throwIfDisposed();\n return opHandler.logicalNot(this);\n }\n logicalXor(x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.logicalXor(this, x);\n }\n where(condition: Tensor, x: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.where(condition, this, x);\n }\n\n // Unary ops.\n neg(this: T): T {\n this.throwIfDisposed();\n return opHandler.neg(this);\n }\n ceil(this: T): T {\n this.throwIfDisposed();\n return opHandler.ceil(this);\n }\n floor(this: T): T {\n this.throwIfDisposed();\n return opHandler.floor(this);\n }\n sign(this: T): T {\n this.throwIfDisposed();\n return opHandler.sign(this);\n }\n exp(this: T): T {\n this.throwIfDisposed();\n return opHandler.exp(this);\n }\n expm1(this: T): T {\n this.throwIfDisposed();\n return opHandler.expm1(this);\n }\n log(this: T): T {\n this.throwIfDisposed();\n return opHandler.log(this);\n }\n log1p(this: T): T {\n this.throwIfDisposed();\n return opHandler.log1p(this);\n }\n sqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.sqrt(this);\n }\n rsqrt(this: T): T {\n this.throwIfDisposed();\n return opHandler.rsqrt(this);\n }\n square(this: T): T {\n this.throwIfDisposed();\n return opHandler.square(this);\n }\n reciprocal(this: T): T {\n this.throwIfDisposed();\n return opHandler.reciprocal(this);\n }\n abs(this: T): T {\n this.throwIfDisposed();\n return opHandler.abs(this);\n }\n clipByValue(min: number, max: number): Tensor {\n this.throwIfDisposed();\n return opHandler.clipByValue(this, min, max);\n }\n relu(this: T): T {\n this.throwIfDisposed();\n return opHandler.relu(this);\n }\n elu(this: T): T {\n this.throwIfDisposed();\n return opHandler.elu(this);\n }\n selu(this: T): T {\n this.throwIfDisposed();\n return opHandler.selu(this);\n }\n leakyRelu(alpha = 0.2): Tensor {\n this.throwIfDisposed();\n return opHandler.leakyRelu(this, alpha);\n }\n prelu(alpha: Tensor): Tensor {\n this.throwIfDisposed();\n return opHandler.prelu(this, alpha);\n }\n sigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.sigmoid(this);\n }\n logSigmoid(this: T): T {\n this.throwIfDisposed();\n return opHandler.logSigmoid(this);\n }\n softplus(this: T): T {\n this.throwIfDisposed();\n return opHandler.softplus(this);\n }\n sin(this: T): T {\n this.throwIfDisposed();\n return opHandler.sin(this);\n }\n cos(this: T): T {\n this.throwIfDisposed();\n return opHandler.cos(this);\n }\n tan(this: T): T {\n this.throwIfDisposed();\n return opHandler.tan(this);\n }\n asin(this: T): T {\n this.throwIfDisposed();\n return opHandler.asin(this);\n }\n acos(this: T): T {\n this.throwIfDisposed();\n return opHandler.acos(this);\n }\n atan(this: T): T {\n this.throwIfDisposed();\n return opHandler.atan(this);\n }\n sinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.sinh(this);\n }\n cosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.cosh(this);\n }\n tanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.tanh(this);\n }\n asinh(this: T): T {\n this.throwIfDisposed();\n return opHandler.asinh(this);\n }\n acosh(this: T): T {\n this.throwIfDisposed();\n return opHandler.acosh(this);\n }\n atanh(this: T): T {\n this.throwIfDisposed();\n return opHandler.atanh(this);\n }\n erf(this: T): T {\n this.throwIfDisposed();\n return opHandler.erf(this);\n }\n round(this: T): T {\n this.throwIfDisposed();\n return opHandler.round(this);\n }\n step(this: T, alpha = 0.0): T {\n this.throwIfDisposed();\n return opHandler.step(this, alpha);\n }\n softmax(this: T, dim = -1): T {\n this.throwIfDisposed();\n return opHandler.softmax(this, dim) as T;\n }\n\n // Image ops.\n resizeBilinear(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeBilinear(this, newShape2D, alignCorners);\n }\n\n resizeNearestNeighbor(\n this: T, newShape2D: [number, number], alignCorners = false): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.image.resizeNearestNeighbor(\n this, newShape2D, alignCorners);\n }\n\n // Convolutions.\n conv1d(\n this: T, filter: Tensor3D, stride: number, pad: 'valid'|'same'|number,\n dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv1d(\n this, filter, stride, pad, dataFormat, dilation, dimRoundingMode);\n }\n conv2d(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n conv2dTranspose(\n this: T, filter: Tensor4D,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.conv2dTranspose(\n this, filter, outputShape, strides, pad, dimRoundingMode);\n }\n depthwiseConv2D(\n this: T, filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.depthwiseConv2d(\n this, filter, strides, pad, dataFormat, dilations, dimRoundingMode);\n }\n\n // Pooling.\n avgPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.avgPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n maxPool(\n this: T, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n (this as Tensor).throwIfDisposed();\n return opHandler.maxPool(this, filterSize, strides, pad, dimRoundingMode);\n }\n localResponseNormalization(\n this: T, radius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n return opHandler.localResponseNormalization(\n this, radius, bias, alpha, beta);\n }\n\n variable(trainable = true, name?: string, dtype?: DataType): Variable {\n this.throwIfDisposed();\n return Variable.variable(this, trainable, name, dtype);\n }\n\n unsortedSegmentSum(\n this: T, segmentIds: Tensor1D, numSegments: number): T {\n this.throwIfDisposed();\n return opHandler.unsortedSegmentSum(this, segmentIds, numSegments);\n }\n\n batchToSpaceND(\n this: T, blockShape: number[], crops: number[][]): T {\n this.throwIfDisposed();\n return opHandler.batchToSpaceND(this, blockShape, crops);\n }\n\n spaceToBatchND(\n this: T, blockShape: number[], paddings: number[][]): T {\n this.throwIfDisposed();\n return opHandler.spaceToBatchND(this, blockShape, paddings);\n }\n}\nObject.defineProperty(Tensor, Symbol.hasInstance, {\n value: (instance: Tensor) => {\n return !!instance && instance.shape != null && instance.dtype != null;\n }\n});\n\n/** @doclink Tensor */\nexport type Scalar = Tensor;\n/** @doclink Tensor */\nexport type Tensor1D = Tensor;\n/** @doclink Tensor */\nexport type Tensor2D = Tensor;\n/** @doclink Tensor */\nexport type Tensor3D = Tensor;\n/** @doclink Tensor */\nexport type Tensor4D = Tensor;\n/** @doclink Tensor */\nexport type Tensor5D = Tensor;\n/** @doclink Tensor */\nexport type Tensor6D = Tensor;\n\n/**\n * A mutable `Tensor`, useful for persisting state, e.g. for training.\n */\n/** @doc {heading: 'Tensors', subheading: 'Classes'} */\nexport class Variable extends Tensor {\n private static nextVarId = 0;\n name: string;\n\n /**\n * Private constructor since we can not add logic before calling `super()`.\n * Instead, we expose static `Variable.variable` method below, which will be\n * added to global namespace.\n */\n private constructor(\n initialValue: Tensor, public trainable = true, name?: string) {\n super(\n initialValue.shape, initialValue.dtype, null /* values */,\n initialValue.dataId);\n this.name = name;\n if (this.name == null) {\n this.name = Variable.nextVarId.toString();\n Variable.nextVarId++;\n }\n try {\n trackerFn().registerVariable(this);\n } catch (ex) {\n trackerFn().disposeTensor(this);\n throw ex;\n }\n }\n\n /**\n * Creates a new variable with the provided initial value.\n * ```js\n * const x = tf.variable(tf.tensor([1, 2, 3]));\n * x.assign(tf.tensor([4, 5, 6]));\n *\n * x.print();\n * ```\n *\n * @param initialValue Initial value for the tensor.\n * @param trainable If true, optimizers are allowed to update it.\n * @param name Name of the variable. Defaults to a unique id.\n * @param dtype If set, initialValue will be converted to the given type.\n */\n /** @doc {heading: 'Tensors', subheading: 'Creation'} */\n static variable(\n initialValue: Tensor, trainable = true, name?: string,\n dtype?: DataType): Variable {\n if (dtype != null && dtype !== initialValue.dtype) {\n initialValue = initialValue.asType(dtype) as Tensor;\n }\n return new Variable(initialValue, trainable, name);\n }\n\n /**\n * Assign a new `Tensor` to this variable. The new `Tensor` must have the\n * same shape and dtype as the old `Tensor`.\n *\n * @param newValue New tensor to be assigned to this variable.\n */\n /** @doc {heading: 'Tensors', subheading: 'Classes'} */\n assign(newValue: Tensor): void {\n if (newValue.dtype !== this.dtype) {\n throw new Error(\n `dtype of the new value (${newValue.dtype}) and ` +\n `previous value (${this.dtype}) must match`);\n }\n if (!util.arraysEqual(newValue.shape, this.shape)) {\n throw new Error(\n `shape of the new value (${newValue.shape}) and ` +\n `previous value (${this.shape}) must match`);\n }\n trackerFn().disposeTensor(this);\n this.dataId = newValue.dataId;\n trackerFn().registerTensor(this);\n }\n}\nObject.defineProperty(Variable, Symbol.hasInstance, {\n value: (instance: Variable) => {\n return instance instanceof Tensor && instance.assign != null &&\n instance.assign instanceof Function;\n }\n});\n\nconst variable = Variable.variable;\nexport {variable};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap, TensorContainer, TensorContainerArray} from './tensor_types';\nimport {assert} from './util';\n\nexport function assertTypesMatch(a: Tensor, b: Tensor): void {\n assert(\n a.dtype === b.dtype,\n ` The dtypes of the first(${a.dtype}) and` +\n ` second(${b.dtype}) input must match`);\n}\n\nexport function isTensorInList(tensor: Tensor, tensorList: Tensor[]): boolean {\n for (let i = 0; i < tensorList.length; i++) {\n if (tensorList[i].id === tensor.id) {\n return true;\n }\n }\n return false;\n}\n\nexport function flattenNameArrayMap(\n nameArrayMap: Tensor|NamedTensorMap, keys?: string[]): Tensor[] {\n const xs: Tensor[] = [];\n if (nameArrayMap instanceof Tensor) {\n xs.push(nameArrayMap);\n } else {\n const xMap = nameArrayMap as {[xName: string]: Tensor};\n for (let i = 0; i < keys.length; i++) {\n xs.push(xMap[keys[i]]);\n }\n }\n return xs;\n}\n\nexport function unflattenToNameArrayMap(\n keys: string[], flatArrays: Tensor[]): NamedTensorMap {\n if (keys.length !== flatArrays.length) {\n throw new Error(\n `Cannot unflatten Tensor[], keys and arrays are not of same length.`);\n }\n const result: NamedTensorMap = {};\n for (let i = 0; i < keys.length; i++) {\n result[keys[i]] = flatArrays[i];\n }\n return result;\n}\n\n/**\n * Extracts any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. In general it\n * is safe to pass any object here, except that `Promise`s are not\n * supported.\n * @returns An array of `Tensors` found within the passed object. If the\n * argument is simply a `Tensor', a list containing that `Tensor` is\n * returned. If the object is not a `Tensor` or does not\n * contain `Tensors`, an empty list is returned.\n */\nexport function getTensorsInContainer(result: TensorContainer): Tensor[] {\n const list: Tensor[] = [];\n const seen = new Set<{}|void>();\n walkTensorContainer(result, list, seen);\n return list;\n}\n\nfunction walkTensorContainer(\n container: TensorContainer, list: Tensor[], seen: Set<{}|void>): void {\n if (container == null) {\n return;\n }\n if (container instanceof Tensor) {\n list.push(container);\n return;\n }\n if (!isIterable(container)) {\n return;\n }\n // Iteration over keys works also for arrays.\n const iterable = container as TensorContainerArray;\n for (const k in iterable) {\n const val = iterable[k];\n if (!seen.has(val)) {\n seen.add(val);\n walkTensorContainer(val, list, seen);\n }\n }\n}\n\n// tslint:disable-next-line:no-any\nfunction isIterable(obj: any): boolean {\n return Array.isArray(obj) || typeof obj === 'object';\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimingInfo, KernelBackend} from './kernels/backend';\nimport {Profiler} from './profiler';\nimport {backpropagateGradients, getFilteredNodesXToY, NamedGradientMap, TapeNode} from './tape';\nimport {DataId, Tensor, Tensor3D, Variable} from './tensor';\nimport {NamedTensorMap, NamedVariableMap, TensorContainer} from './tensor_types';\nimport {getTensorsInContainer, isTensorInList} from './tensor_util';\nimport {TypedArray} from './types';\nimport * as util from './util';\nimport {makeOnesTypedArray, now, sizeFromShape} from './util';\n\n/**\n * A function that computes an output. The save function is for saving tensors\n * computed in the forward pass, that we need in the backwards pass.\n */\nexport type ForwardFunc =\n (backend: KernelBackend, save?: (tensor: S) => S) => T;\n\n/**\n * @docalias (a: Tensor, b: Tensor,...) => {\n * value: Tensor, * gradFunc: (dy: Tensor) => Tensor | Tensor[] * }\n */\nexport type CustomGradientFunc = (...args: Tensor[]) => {\n value: T, gradFunc: (dy: T) => Tensor | Tensor[];\n};\n\nexport type MemoryInfo = {\n numTensors: number; numDataBuffers: number; numBytes: number;\n unreliable?: boolean;\n};\n\nexport interface TimingInfo extends BackendTimingInfo {\n wallMs: number;\n}\n\n/** @docalias Function */\nexport type ScopeFn = () => T;\n\nexport interface TensorManager {\n registerTensor(a: Tensor): void;\n registerVariable(v: Variable): void;\n disposeTensor(a: Tensor): void;\n memory(): {numDataBuffers: number; numBytes: number;};\n}\n\ninterface ScopeState {\n track: Tensor[];\n name: string;\n}\n\nexport class Engine implements TensorManager {\n // Public since optimizers will use it.\n registeredVariables: NamedVariableMap = {};\n\n private refCounter = new WeakMap();\n private nextTapeNodeId = 0;\n private numBytes = 0;\n private numTensors = 0;\n private numDataBuffers = 0;\n\n private activeTape: TapeNode[];\n private gradientScopeCount = 0;\n private customGradientDepth = 0;\n\n // Keep Tensors that parallel the tapes.\n private activeScope: ScopeState;\n private scopeStack: ScopeState[];\n private keepTensors: Set = new Set();\n private profiler: Profiler;\n\n constructor(\n private backend: KernelBackend, public safeMode: boolean,\n private debugMode: () => boolean) {\n // Create a default outer scope.\n this.activeScope = {track: [], name: 'default scope'};\n this.scopeStack = [this.activeScope];\n this.profiler = new Profiler(backend);\n }\n\n tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n // gradMode Primarily for internal use during backprop\n // If true, will start a tape if it is the outermost tidy.\n\n let name: string = null;\n if (fn == null) {\n // Called with only 1 argument.\n if (typeof nameOrFn !== 'function') {\n throw new Error('Please provide a function to tidy()');\n }\n fn = nameOrFn;\n } else {\n // Called with 2 arguments.\n if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) {\n throw new Error(\n 'When calling with two arguments, the first argument ' +\n 'to tidy() must be a string');\n }\n if (typeof fn !== 'function') {\n throw new Error(\n 'When calling with two arguments, the 2nd argument ' +\n 'to tidy() must be a function');\n }\n name = nameOrFn as string;\n // TODO(nsthorat,smilkov): Do operation logging and performance\n // profiling.\n }\n let result: T;\n return this.scopedRun(\n () => this.startScope(name, gradMode),\n () => this.endScope(result, gradMode), () => {\n result = fn();\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n return result;\n });\n }\n\n private scopedRun(start: () => void, end: () => void, f: () => T): T {\n start();\n try {\n const res = f();\n end();\n return res;\n } catch (ex) {\n end();\n throw ex;\n }\n }\n\n runKernel(\n forwardFunc: ForwardFunc,\n inputs: I,\n backwardsFunc?: (dy: T, saved: Tensor[]) => {[P in keyof I]: () => I[P]},\n ): T {\n let result: T;\n const saved: Tensor[] = [];\n const saveFunc = (x: T): T => {\n saved.push(x);\n return x;\n };\n const scopeName = this.activeScope.name;\n\n // Stop recording to a tape when running a kernel.\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n if (!this.debugMode()) {\n result = forwardFunc(this.backend, saveFunc);\n } else {\n result = this.profiler.profileKernel(\n scopeName, () => forwardFunc(this.backend, saveFunc));\n }\n });\n\n if (this.shouldRecord()) {\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: scopeName,\n inputs,\n // Keep gradient records only for the first output.\n output: Array.isArray(result) ? result[0] : result\n };\n if (backwardsFunc != null) {\n tapeNode.gradient =\n ((dy: T) => backwardsFunc(dy, saved)) as (dy: Tensor) =>\n NamedGradientMap;\n }\n this.activeTape.push(tapeNode);\n }\n return result;\n }\n\n // TensorManager implementation.\n\n registerTensor(a: Tensor|Variable): void {\n const refCount =\n this.refCounter.has(a.dataId) ? this.refCounter.get(a.dataId) : 0;\n this.numTensors++;\n if (refCount === 0) {\n this.numDataBuffers++;\n this.numBytes +=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n this.backend.register(a.dataId, a.shape, a.dtype);\n }\n this.refCounter.set(a.dataId, refCount + 1);\n if (!(a instanceof Variable)) {\n this.track(a);\n }\n }\n\n registerVariable(v: Variable) {\n if (this.registeredVariables[v.name] != null) {\n throw new Error(`Variable with name ${v.name} was already registered`);\n }\n this.registeredVariables[v.name] = v;\n }\n\n disposeTensor(a: Tensor): void {\n if (!this.refCounter.has(a.dataId)) {\n return;\n }\n if (this.keepTensors.has(a.id)) {\n this.keepTensors.delete(a.id);\n }\n this.numTensors--;\n const refCount = this.refCounter.get(a.dataId);\n if (refCount <= 1) {\n this.refCounter.delete(a.dataId);\n this.backend.disposeData(a.dataId);\n this.numDataBuffers--;\n this.numBytes -=\n util.sizeFromShape(a.shape) * util.bytesPerElement(a.dtype);\n } else {\n this.refCounter.set(a.dataId, refCount - 1);\n }\n // TODO(nsthorat): Construct an error and save the stack trace for\n // debugging when in debug mode. Creating a stack trace is too expensive\n // to do unconditionally.\n }\n\n disposeVariables(): void {\n for (const varName in this.registeredVariables) {\n const v = this.registeredVariables[varName];\n this.disposeTensor(v);\n delete this.registeredVariables[varName];\n }\n }\n\n memory(): MemoryInfo {\n const info = this.backend.memory() as MemoryInfo;\n info.numTensors = this.numTensors;\n info.numDataBuffers = this.numDataBuffers;\n info.numBytes = this.numBytes;\n return info;\n }\n\n private shouldRecord(): boolean {\n return this.activeTape != null && this.customGradientDepth === 0;\n }\n\n private addTapeNode(\n inputs: Tensor[], result: Tensor,\n gradientsFunc: (dy: Tensor) => Tensor[]): void {\n const inputsMap: NamedTensorMap = {};\n inputs.forEach((input, idx) => {\n inputsMap[idx] = input;\n });\n\n const gradient = (dy: Tensor) => {\n const res = gradientsFunc(dy);\n const resMap: NamedGradientMap = {};\n res.forEach((r, idx) => {\n resMap[idx] = () => r;\n });\n return resMap;\n };\n\n const tapeNode: TapeNode = {\n id: this.nextTapeNodeId++,\n name: this.activeScope.name,\n inputs: inputsMap,\n output: result,\n gradient\n };\n this.activeTape.push(tapeNode);\n }\n\n keep(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {...}) to avoid memory leaks.');\n }\n this.keepTensors.add(result.id);\n return result;\n }\n\n /**\n * Start a scope. Use this with endScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n startScope(name?: string, gradientsMode = false) {\n if (gradientsMode && this.gradientScopeCount === 0) {\n this.activeTape = [];\n }\n if (gradientsMode) {\n this.gradientScopeCount++;\n }\n\n const scopeInfo: ScopeState = {track: [], name: 'unnamed scope'};\n if (name) {\n scopeInfo.name = name;\n }\n this.scopeStack.push(scopeInfo);\n this.activeScope = scopeInfo;\n }\n\n /**\n * End a scope. Use this with startScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n endScope(result?: TensorContainer, gradientsMode = false) {\n if (gradientsMode) {\n this.gradientScopeCount--;\n if (this.gradientScopeCount === 0) {\n this.activeTape = null;\n }\n }\n\n const tensorsToKeep = new Set(this.keepTensors);\n\n const tensorsToTrackInParent = getTensorsInContainer(result);\n tensorsToTrackInParent.forEach(tensor => tensorsToKeep.add(tensor.id));\n\n // Dispose the arrays tracked in this scope.\n for (let i = 0; i < this.activeScope.track.length; i++) {\n const tensor = this.activeScope.track[i];\n if (tensorsToKeep.has(tensor.id)) {\n continue;\n }\n\n if (this.activeTape != null) {\n tensorsToTrackInParent.push(tensor);\n } else {\n tensor.dispose();\n }\n }\n\n const oldScope = this.scopeStack.pop();\n this.activeScope = this.scopeStack.length === 0 ?\n {track: [], name: 'default scope'} :\n this.scopeStack[this.scopeStack.length - 1];\n\n // Track the current result in the parent scope.\n tensorsToTrackInParent.forEach(tensor => {\n // Only track the tensor if was allocated in the inner scope and is not\n // globally kept.\n if (!this.keepTensors.has(tensor.id) &&\n isTensorInList(tensor, oldScope.track)) {\n this.track(tensor);\n }\n });\n }\n\n /**\n * Returns gradients of `f` with respect to each of the `xs`. The gradients\n * returned are of the same length as `xs`, but some might be null if `f` was\n * not a function of that `x`. It also takes optional dy to multiply the\n * gradient, which defaults to `1`.\n */\n gradients(\n f: () => T, xs: Tensor[], dy?: T,\n allowNoGradients = false): {value: T, grads: Tensor[]} {\n util.assert(xs.length > 0, 'gradients() received an empty list of xs.');\n\n return this.tidy('gradients', () => {\n const y = f();\n util.assert(\n y instanceof Tensor,\n 'The result y returned by f() must be a tensor.');\n // Filter out the nodes that don't connect x => y.\n const filteredTape = getFilteredNodesXToY(this.activeTape, xs, y);\n if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) {\n throw new Error(\n 'Cannot compute gradient of y=f(x) with respect to x. Make sure ' +\n 'that the f you passed encloses all operations that lead from x ' +\n 'to y.');\n }\n\n const accumulatedGradientMap: {[tensorId: number]: Tensor} = {};\n accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy;\n\n // Backprop gradients through the filtered nodes.\n backpropagateGradients(accumulatedGradientMap, filteredTape);\n\n const grads = xs.map(x => accumulatedGradientMap[x.id]);\n return {value: y, grads};\n }, true /* gradientsMode */);\n }\n\n customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n util.assert(\n util.isFunction(f),\n 'The f passed in customGrad(f) must be a function.');\n return (...inputs: Tensor[]): T => {\n util.assert(\n inputs.every(t => t instanceof Tensor),\n 'The args passed in customGrad(f)(x1, x2,...) must all be tensors');\n\n let gradientsFunc: (dy: T) => Tensor | Tensor[];\n let result: T;\n this.scopedRun(\n () => this.customGradientDepth++, () => this.customGradientDepth--,\n () => {\n const gradientsMode = true;\n result = this.tidy(f.name, () => {\n const {value, gradFunc} = f(...inputs);\n util.assert(\n value instanceof Tensor,\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.value` is a tensor');\n util.assert(\n util.isFunction(gradFunc),\n 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function.');\n gradientsFunc = gradFunc;\n return value;\n }, gradientsMode);\n });\n\n if (this.shouldRecord()) {\n const gradFunc = (dy: T): Tensor[] => {\n const res = gradientsFunc(dy);\n const grads: Tensor[] = Array.isArray(res) ? res : [res];\n util.assert(\n grads.length === inputs.length,\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns the same ' +\n 'number of tensors as inputs passed to f(...).');\n util.assert(\n grads.every(t => t instanceof Tensor),\n 'The function f passed in customGrad(f) must return an object ' +\n 'where `obj.gradFunc` is a function that returns a list of ' +\n 'only tensors.');\n return grads;\n };\n this.addTapeNode(inputs, result, gradFunc);\n }\n return result;\n };\n }\n\n // Forwarding to backend.\n write(dataId: DataId, values: TypedArray): void {\n this.backend.write(dataId, values);\n }\n readSync(dataId: DataId): TypedArray {\n return this.backend.readSync(dataId);\n }\n read(dataId: DataId): Promise {\n return this.backend.read(dataId);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n return this.backend.fromPixels(pixels, numChannels);\n }\n async time(query: () => void): Promise {\n const start = now();\n const timingInfo = await this.backend.time(query) as TimingInfo;\n timingInfo.wallMs = now() - start;\n return timingInfo;\n }\n\n /**\n * Tracks a Tensor in the current scope to be automatically cleaned up\n * when the current scope ends, and returns the value.\n *\n * @param result The Tensor to track in the current scope.\n */\n private track(result: T): T {\n if (this.scopeStack.length === 1 && this.safeMode) {\n throw new Error(\n 'Safe mode is ON. Enclose all tensor operations inside tf.tidy(): ' +\n 'tf.tidy(() => {op();...}); to avoid memory leaks.');\n }\n this.activeScope.track.push(result);\n return result;\n }\n}\n\nfunction ones(shape: number[]): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), 'float32');\n return Tensor.make(shape, {values});\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport interface Features {\n // Whether to enable debug mode.\n 'DEBUG'?: boolean;\n // Whether we are in a browser (as versus, say, node.js) environment.\n 'IS_BROWSER'?: boolean;\n // Whether we are in the Node.js environment.\n 'IS_NODE'?: boolean;\n // The disjoint_query_timer extension version.\n // 0: disabled, 1: EXT_disjoint_timer_query, 2:\n // EXT_disjoint_timer_query_webgl2.\n // In Firefox with WebGL 2.0,\n // EXT_disjoint_timer_query_webgl2 is not available, so we must use the\n // WebGL 1.0 extension.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'?: number;\n // Whether the timer object from the disjoint_query_timer extension gives\n // timing information that is reliable.\n 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE'?: boolean;\n // 0: No WebGL, 1: WebGL 1.0, 2: WebGL 2.0.\n 'WEBGL_VERSION'?: number;\n // True if WebGL is supported.\n 'HAS_WEBGL'?: boolean;\n // Whether rendering to float32 textures is enabled. If disabled, renders to\n // float16 textures.\n 'WEBGL_RENDER_FLOAT32_ENABLED'?: boolean;\n // Whether downloading float textures is enabled. If disabled, uses IEEE 754\n // encoding of the float32 values to 4 uint8 when downloading.\n 'WEBGL_DOWNLOAD_FLOAT_ENABLED'?: boolean;\n // Whether the fence API is available.\n 'WEBGL_FENCE_API_ENABLED'?: boolean;\n 'BACKEND'?: string;\n // Test precision for unit tests. This is decreased when we can't render\n // float32 textures.\n 'TEST_EPSILON'?: number;\n 'IS_CHROME'?: boolean;\n // True if running unit tests.\n 'IS_TEST'?: boolean;\n}\n\nexport enum Type {\n NUMBER,\n BOOLEAN,\n STRING\n}\n\nexport const URL_PROPERTIES: URLProperty[] = [\n {name: 'DEBUG', type: Type.BOOLEAN}, {name: 'IS_BROWSER', type: Type.BOOLEAN},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE', type: Type.BOOLEAN},\n {name: 'WEBGL_VERSION', type: Type.NUMBER},\n {name: 'WEBGL_RENDER_FLOAT32_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_DOWNLOAD_FLOAT_ENABLED', type: Type.BOOLEAN},\n {name: 'WEBGL_FENCE_API_ENABLED', type: Type.BOOLEAN},\n {name: 'BACKEND', type: Type.STRING}\n];\n\nexport interface URLProperty {\n name: keyof Features;\n type: Type;\n}\n\nexport function isWebGLVersionEnabled(webGLVersion: 1|2, isBrowser: boolean) {\n let gl;\n try {\n gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n } catch (e) {\n return false;\n }\n\n if (gl != null) {\n loseContext(gl);\n return true;\n }\n return false;\n}\n\nexport function getWebGLDisjointQueryTimerVersion(\n webGLVersion: number, isBrowser: boolean): number {\n if (webGLVersion === 0) {\n return 0;\n }\n\n let queryTimerVersion: number;\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (hasExtension(gl, 'EXT_disjoint_timer_query_webgl2') &&\n webGLVersion === 2) {\n queryTimerVersion = 2;\n } else if (hasExtension(gl, 'EXT_disjoint_timer_query')) {\n queryTimerVersion = 1;\n } else {\n queryTimerVersion = 0;\n }\n\n if (gl != null) {\n loseContext(gl);\n }\n return queryTimerVersion;\n}\n\nexport function isRenderToFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n\n const isFrameBufferComplete =\n gl.checkFramebufferStatus(gl.FRAMEBUFFER) === gl.FRAMEBUFFER_COMPLETE;\n\n loseContext(gl);\n return isFrameBufferComplete;\n}\n\nexport function isDownloadFloatTextureEnabled(\n webGLVersion: number, isBrowser: boolean): boolean {\n if (webGLVersion === 0) {\n return false;\n }\n\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n if (webGLVersion === 1) {\n if (!hasExtension(gl, 'OES_texture_float')) {\n return false;\n }\n } else {\n if (!hasExtension(gl, 'EXT_color_buffer_float')) {\n return false;\n }\n }\n\n createFloatTextureAndBindToFramebuffer(gl, webGLVersion);\n gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.FLOAT, new Float32Array(4));\n\n const readPixelsNoError = gl.getError() === gl.NO_ERROR;\n\n loseContext(gl);\n\n return readPixelsNoError;\n}\n\nexport function isWebGLFenceEnabled(webGLVersion: number, isBrowser: boolean) {\n if (webGLVersion !== 2) {\n return false;\n }\n const gl = getWebGLRenderingContext(webGLVersion, isBrowser);\n\n // tslint:disable-next-line:no-any\n const isEnabled = (gl as any).fenceSync != null;\n loseContext(gl);\n return isEnabled;\n}\n\nexport function isChrome() {\n return typeof navigator !== 'undefined' && navigator != null &&\n navigator.userAgent != null && /Chrome/.test(navigator.userAgent) &&\n /Google Inc/.test(navigator.vendor);\n}\n\n// Expects flags from URL in the format ?tfjsflags=FLAG1:1,FLAG2:true.\nconst TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags';\nexport function getFeaturesFromURL(): Features {\n const features: Features = {};\n\n if (typeof window === 'undefined' || typeof window.location === 'undefined') {\n return features;\n }\n\n const urlParams = getQueryParams(window.location.search);\n if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) {\n const urlFlags: {[key: string]: string} = {};\n\n const keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(',');\n keyValues.forEach(keyValue => {\n const [key, value] = keyValue.split(':') as [string, string];\n urlFlags[key] = value;\n });\n\n URL_PROPERTIES.forEach(urlProperty => {\n if (urlProperty.name in urlFlags) {\n console.log(\n `Setting feature override from URL ${urlProperty.name}: ` +\n `${urlFlags[urlProperty.name]}`);\n if (urlProperty.type === Type.NUMBER) {\n features[urlProperty.name] = +urlFlags[urlProperty.name];\n } else if (urlProperty.type === Type.BOOLEAN) {\n features[urlProperty.name] = urlFlags[urlProperty.name] === 'true';\n } else if (urlProperty.type === Type.STRING) {\n // tslint:disable-next-line:no-any\n features[urlProperty.name] = urlFlags[urlProperty.name] as any;\n } else {\n console.warn(`Unknown URL param: ${urlProperty.name}.`);\n }\n }\n });\n }\n\n return features;\n}\n\nfunction hasExtension(gl: WebGLRenderingContext, extensionName: string) {\n const ext = gl.getExtension(extensionName);\n return ext != null;\n}\n\nfunction getWebGLRenderingContext(\n webGLVersion: number, isBrowser: boolean): WebGLRenderingContext {\n if (webGLVersion === 0 || !isBrowser) {\n throw new Error('Cannot get WebGL rendering context, WebGL is disabled.');\n }\n\n const tempCanvas = document.createElement('canvas');\n\n if (webGLVersion === 1) {\n return (tempCanvas.getContext('webgl') ||\n tempCanvas.getContext('experimental-webgl')) as\n WebGLRenderingContext;\n }\n return tempCanvas.getContext('webgl2') as WebGLRenderingContext;\n}\n\nfunction loseContext(gl: WebGLRenderingContext) {\n if (gl != null) {\n const loseContextExtension = gl.getExtension('WEBGL_lose_context');\n if (loseContextExtension == null) {\n throw new Error(\n 'Extension WEBGL_lose_context not supported on this browser.');\n }\n loseContextExtension.loseContext();\n }\n}\n\nfunction createFloatTextureAndBindToFramebuffer(\n gl: WebGLRenderingContext, webGLVersion: number) {\n const frameBuffer = gl.createFramebuffer();\n const texture = gl.createTexture();\n\n gl.bindTexture(gl.TEXTURE_2D, texture);\n\n // tslint:disable-next-line:no-any\n const internalFormat = webGLVersion === 2 ? (gl as any).RGBA32F : gl.RGBA;\n gl.texImage2D(\n gl.TEXTURE_2D, 0, internalFormat, 1, 1, 0, gl.RGBA, gl.FLOAT, null);\n\n gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer);\n gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n}\n\nexport function getQueryParams(queryString: string): {[key: string]: string} {\n const params = {};\n queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (s, ...t) => {\n decodeParam(params, t[0], t[1]);\n return t.join('=');\n });\n return params;\n}\n\nfunction decodeParam(\n params: {[key: string]: string}, name: string, value?: string) {\n params[decodeURIComponent(name)] = decodeURIComponent(value || '');\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap} from './tensor_types';\nimport * as util from './util';\n\nexport interface TapeNode {\n id: number;\n name: string;\n output: Tensor;\n inputs: NamedTensorMap;\n // Optional params, defined only for ops with gradient impl.\n gradient?: (dy: Tensor|NamedTensorMap) => NamedGradientMap;\n}\n\nexport type NamedGradientMap = {\n [inputName: string]: () => Tensor;\n};\n\n/**\n * Computes a list of TapeNodes that connect x to y, filtering everything else\n * out and preserving the order of the original tape elements.\n * @param tape The tape elements to filter.\n * @param xs The input Tensors.\n * @param y The output Tensor.\n */\nexport function getFilteredNodesXToY(\n tape: TapeNode[], xs: Tensor[], y: Tensor): TapeNode[] {\n // Forward pass to compute all the nodes and Tensors that are transitively a\n // function of x.\n const tensorsFromX: {[tensorId: number]: boolean} = {};\n const nodesFromX: {[nodeId: number]: boolean} = {};\n for (let i = 0; i < xs.length; i++) {\n tensorsFromX[xs[i].id] = true;\n }\n\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n for (const inputName in nodeInputs) {\n const input = nodeInputs[inputName];\n\n let anyInputFromX = false;\n for (let j = 0; j < xs.length; j++) {\n if (tensorsFromX[input.id]) {\n tensorsFromX[node.output.id] = true;\n anyInputFromX = true;\n nodesFromX[node.id] = true;\n break;\n }\n }\n\n if (anyInputFromX) {\n break;\n }\n }\n }\n\n // Backwards pass to find all of the nodes and Tensors that lead to y.\n const tensorsLeadToY: {[tensorId: number]: boolean} = {};\n tensorsLeadToY[y.id] = true;\n const nodesToY: {[nodeId: number]: boolean} = {};\n\n for (let i = tape.length - 1; i >= 0; i--) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n\n const outputs: Tensor[] = [];\n outputs.push(node.output);\n\n // If any of the outputs lead to y, mark all of the inputs as leading to y.\n for (let j = 0; j < outputs.length; j++) {\n if (tensorsLeadToY[outputs[j].id]) {\n for (const inputName in nodeInputs) {\n tensorsLeadToY[nodeInputs[inputName].id] = true;\n nodesToY[node.id] = true;\n }\n break;\n }\n }\n }\n\n // Return the paths that come from x and lead to y.\n const filteredTape: TapeNode[] = [];\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n\n if (nodesFromX[node.id] && nodesToY[node.id]) {\n // Prune the inputs from the node that aren't a function of x.\n const prunedInputs: {[inputName: string]: Tensor} = {};\n for (const inputName in node.inputs) {\n const nodeInput = node.inputs[inputName];\n if (tensorsFromX[nodeInput.id]) {\n prunedInputs[inputName] = nodeInput;\n }\n }\n\n // Copy the node and overwrite inputsAndArgs to the pruned version.\n const prunedNode = Object.assign({}, node) as TapeNode;\n prunedNode.inputs = prunedInputs;\n prunedNode.output = node.output;\n\n filteredTape.push(prunedNode);\n }\n }\n\n return filteredTape;\n}\n\n/**\n * Backpropagate gradients through the filtered TapeNodes.\n * @param tensorAccumulatedGradientMap A map of Tensor to its gradient. This map\n * is mutated by this method.\n * @param filteredTape The filtered TapeNodes to backprop through.\n */\nexport function backpropagateGradients(\n tensorAccumulatedGradientMap: {[tensorId: number]: Tensor},\n filteredTape: TapeNode[]) {\n // Walk the tape backwards and keep a map of Tensor to its gradient.\n for (let i = filteredTape.length - 1; i >= 0; i--) {\n const node = filteredTape[i];\n\n const dy = tensorAccumulatedGradientMap[node.output.id];\n\n if (node.gradient == null) {\n throw new Error(\n `Cannot compute gradient: gradient function not found ` +\n `for ${node.name}.`);\n }\n\n // Backprop dy through this node and accumulate gradients over the inputs.\n const inputGradients = node.gradient(dy);\n for (const inputName in node.inputs) {\n if (!(inputName in inputGradients)) {\n throw new Error(\n `Cannot backprop through input ${inputName}. ` +\n `Available gradients found: ${Object.keys(inputGradients)}.`);\n }\n\n // Call the gradient function.\n const dx = inputGradients[inputName]();\n const x = node.inputs[inputName];\n if (!util.arraysEqual(dx.shape, x.shape)) {\n throw new Error(\n `Error in gradient for op ${node.name}. The gradient of input ` +\n `'${inputName}' has shape '${dx.shape}', which does not match ` +\n `the shape of the input '${x.shape}'`);\n }\n\n if (tensorAccumulatedGradientMap[x.id] == null) {\n tensorAccumulatedGradientMap[x.id] = dx;\n } else {\n const curGradient = tensorAccumulatedGradientMap[x.id];\n tensorAccumulatedGradientMap[x.id] = curGradient.add(dx);\n curGradient.dispose();\n }\n }\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as device_util from './device_util';\nimport {Engine, MemoryInfo, ScopeFn, TimingInfo} from './engine';\nimport {Features, getFeaturesFromURL, getWebGLDisjointQueryTimerVersion, isChrome, isDownloadFloatTextureEnabled, isRenderToFloatTextureEnabled, isWebGLFenceEnabled, isWebGLVersionEnabled} from './environment_util';\nimport {KernelBackend} from './kernels/backend';\nimport {setTensorTracker, Tensor, TensorTracker} from './tensor';\nimport {TensorContainer} from './tensor_types';\nimport {getTensorsInContainer} from './tensor_util';\n\nconst TEST_EPSILON_FLOAT32_ENABLED = 1e-3;\nconst TEST_EPSILON_FLOAT32_DISABLED = 1e-1;\n\nexport class Environment {\n private features: Features = {};\n private globalEngine: Engine;\n private registry:\n {[id: string]: {backend: KernelBackend, priority: number}} = {};\n backendName: string;\n backend: KernelBackend;\n\n constructor(features?: Features) {\n if (features != null) {\n this.features = features;\n }\n\n if (this.get('DEBUG')) {\n console.warn(\n 'Debugging mode is ON. The output of every math call will ' +\n 'be downloaded to CPU and checked for NaNs. ' +\n 'This significantly impacts performance.');\n }\n }\n\n /**\n * Sets the backend (cpu, webgl, etc) responsible for creating tensors and\n * executing operations on those tensors.\n *\n * Note this disposes the current backend, if any, as well as any tensors\n * associated with it. A new backend is initialized, even if it is of the\n * same type as the previous one.\n *\n * @param backendName The name of the backend. Currently supports\n * `'webgl'|'cpu'` in the browser, and `'tensorflow'` under node.js\n * (requires tfjs-node).\n * @param safeMode Defaults to false. In safe mode, you are forced to\n * construct tensors and call math operations inside a `tidy()` which\n * will automatically clean up intermediate tensors.\n */\n /** @doc {heading: 'Environment'} */\n static setBackend(backendName: string, safeMode = false) {\n if (!(backendName in ENV.registry)) {\n throw new Error(`Backend name '${backendName}' not found in registry`);\n }\n ENV.initBackend(backendName, safeMode);\n }\n\n /**\n * Returns the current backend name (cpu, webgl, etc). The backend is\n * responsible for creating tensors and executing operations on those tensors.\n */\n /** @doc {heading: 'Environment'} */\n static getBackend(): string {\n ENV.initDefaultBackend();\n return ENV.backendName;\n }\n\n /**\n * Dispose all variables kept in backend engine.\n */\n /** @doc {heading: 'Environment'} */\n static disposeVariables(): void {\n ENV.engine.disposeVariables();\n }\n\n /**\n * Returns memory info at the current time in the program. The result is an\n * object with the following properties:\n *\n * - `numBytes`: Number of bytes allocated (undisposed) at this time.\n * - `numTensors`: Number of unique tensors allocated.\n * - `numDataBuffers`: Number of unique data buffers allocated\n * (undisposed) at this time, which is ≤ the number of tensors\n * (e.g. `a.reshape(newShape)` makes a new Tensor that shares the same\n * data buffer with `a`).\n * - `unreliable`: `Optional` `boolean`:\n * - On WebGL, not present (always reliable).\n * - On CPU, true. Due to automatic garbage collection, these numbers\n * represent undisposed tensors, i.e. not wrapped in `tidy()`, or\n * lacking a call to `tensor.dispose()`.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static memory(): MemoryInfo {\n return ENV.engine.memory();\n }\n\n /**\n * Executes the provided function `fn` and after it is executed, cleans up all\n * intermediate tensors allocated by `fn` except those returned by `fn`.\n * `f` must not return a Promise (async functions not allowed).\n * The returned result can be a complex object, however tidy only walks the\n * top-level properties (depth 1) of that object to search for tensors, or\n * lists of tensors that need to be tracked in the parent scope.\n *\n * Using this method helps avoid memory leaks. In general, wrap calls to\n * operations in `tidy` for automatic memory cleanup.\n *\n * When in safe mode, you must enclose all `Tensor` creation and ops\n * inside a `tidy` to prevent memory leaks.\n *\n * ```js\n * // y = 2 ^ 2 + 1\n * const y = tf.tidy(() => {\n * // a, b, and one will be cleaned up when the tidy ends.\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n * const b = a.square();\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * y.print();\n * ```\n *\n * @param nameOrFn The name of the closure, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If debug mode is on, the timing and the memory usage of the function\n * will be tracked and displayed on the console using the provided name.\n * @param fn The function to execute.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static tidy(\n nameOrFn: string|ScopeFn, fn?: ScopeFn, gradMode = false): T {\n return ENV.engine.tidy(nameOrFn, fn, gradMode);\n }\n\n /**\n * Disposes any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. If the\n * object is not a `Tensor` or does not contain `Tensors`, nothing\n * happens. In general it is safe to pass any object here, except that\n * `Promise`s are not supported.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static dispose(container: TensorContainer) {\n const tensors = getTensorsInContainer(container);\n tensors.forEach(tensor => tensor.dispose());\n }\n\n /**\n * Keeps a `Tensor` generated inside a `tidy` from being disposed\n * automatically.\n *\n * ```js\n * let b;\n * const y = tf.tidy(() => {\n * const one = tf.scalar(1);\n * const a = tf.scalar(2);\n *\n * // b will not be cleaned up by the tidy. a and one will be cleaned up\n * // when the tidy ends.\n * b = tf.keep(a.square());\n *\n * console.log('numTensors (in tidy): ' + tf.memory().numTensors);\n *\n * // The value returned inside the tidy function will return\n * // through the tidy, in this case to the variable y.\n * return b.add(one);\n * });\n *\n * console.log('numTensors (outside tidy): ' + tf.memory().numTensors);\n * console.log('y:');\n * y.print();\n * console.log('b:');\n * b.print();\n * ```\n *\n * @param result The tensor to keep from being disposed.\n */\n /** @doc {heading: 'Performance', subheading: 'Memory'} */\n static keep(result: T): T {\n return ENV.engine.keep(result);\n }\n\n /**\n * Executes `f()` and returns a promise that resolves with timing\n * information.\n *\n * The result is an object with the following properties:\n *\n * - `wallMs`: Wall execution time.\n * - `kernelMs`: Kernel execution time, ignoring data transfer.\n * - On `WebGL` The following additional properties exist:\n * - `uploadWaitMs`: CPU blocking time on texture uploads.\n * - `downloadWaitMs`: CPU blocking time on texture downloads (readPixels).\n *\n * ```js\n * const x = tf.randomNormal([20, 20]);\n * const time = await tf.time(() => x.matMul(x));\n *\n * console.log(`kernelMs: ${time.kernelMs}, wallTimeMs: ${time.wallMs}`);\n * ```\n *\n * @param f The function to execute and time.\n */\n /** @doc {heading: 'Performance', subheading: 'Timing'} */\n static time(f: () => void): Promise {\n return ENV.engine.time(f);\n }\n\n get(feature: K): Features[K] {\n if (feature in this.features) {\n return this.features[feature];\n }\n\n this.features[feature] = this.evaluateFeature(feature);\n\n return this.features[feature];\n }\n\n getFeatures(): Features {\n return this.features;\n }\n\n set(feature: K, value: Features[K]): void {\n this.features[feature] = value;\n }\n\n private getBestBackendName(): string {\n if (Object.keys(this.registry).length === 0) {\n throw new Error('No backend found in registry.');\n }\n const sortedBackends = Object.keys(this.registry)\n .map(name => {\n return {name, entry: this.registry[name]};\n })\n .sort((a, b) => {\n // Highest priority comes first.\n return b.entry.priority - a.entry.priority;\n });\n return sortedBackends[0].name;\n }\n\n private evaluateFeature(feature: K): Features[K] {\n if (feature === 'DEBUG') {\n return false;\n } else if (feature === 'IS_BROWSER') {\n return typeof window !== 'undefined';\n } else if (feature === 'IS_NODE') {\n return (typeof process !== 'undefined') &&\n (typeof process.versions.node !== 'undefined');\n } else if (feature === 'IS_CHROME') {\n return isChrome();\n } else if (feature === 'IS_TEST') {\n return false;\n } else if (feature === 'BACKEND') {\n return this.getBestBackendName();\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') {\n const webGLVersion = this.get('WEBGL_VERSION');\n\n if (webGLVersion === 0) {\n return 0;\n }\n // Remove this and reenable this extension when the\n // EXT_disjoint_query_timer extension is reenabled in chrome.\n // https://github.com/tensorflow/tfjs/issues/544\n if (webGLVersion > 0) {\n return 0;\n }\n return getWebGLDisjointQueryTimerVersion(\n webGLVersion, this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE') {\n return this.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0 &&\n !device_util.isMobile();\n } else if (feature === 'HAS_WEBGL') {\n return this.get('WEBGL_VERSION') > 0;\n } else if (feature === 'WEBGL_VERSION') {\n if (isWebGLVersionEnabled(2, this.get('IS_BROWSER'))) {\n return 2;\n } else if (isWebGLVersionEnabled(1, this.get('IS_BROWSER'))) {\n return 1;\n }\n return 0;\n } else if (feature === 'WEBGL_RENDER_FLOAT32_ENABLED') {\n return isRenderToFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_DOWNLOAD_FLOAT_ENABLED') {\n return isDownloadFloatTextureEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'WEBGL_FENCE_API_ENABLED') {\n return isWebGLFenceEnabled(\n this.get('WEBGL_VERSION'), this.get('IS_BROWSER'));\n } else if (feature === 'TEST_EPSILON') {\n if (this.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return TEST_EPSILON_FLOAT32_ENABLED;\n }\n return TEST_EPSILON_FLOAT32_DISABLED;\n }\n throw new Error(`Unknown feature ${feature}.`);\n }\n\n setFeatures(features: Features) {\n this.features = Object.assign({}, features);\n }\n\n reset() {\n this.features = getFeaturesFromURL();\n if (this.globalEngine != null) {\n this.globalEngine = null;\n }\n }\n\n private initBackend(backendName?: string, safeMode = false) {\n this.backendName = backendName;\n this.backend = this.findBackend(backendName);\n this.globalEngine =\n new Engine(this.backend, safeMode, () => this.get('DEBUG'));\n }\n\n findBackend(name: string): KernelBackend {\n if (!(name in this.registry)) {\n return null;\n }\n return this.registry[name].backend;\n }\n\n /**\n * Registers a global backend. The registration should happen when importing\n * a module file (e.g. when importing `backend_webgl.ts`), and is used for\n * modular builds (e.g. custom tfjs bundle with only webgl support).\n *\n * @param factory: The backend factory function. When called, it should\n * return an instance of the backend.\n * @param priority The priority of the backend (higher = more important).\n * In case multiple backends are registered, the priority is used to find\n * the best backend. Defaults to 1.\n * @return False if the creation/registration failed. True otherwise.\n */\n registerBackend(\n name: string, factory: () => KernelBackend, priority = 1,\n setTensorTrackerFn?: (f: () => TensorTracker) => void): boolean {\n if (name in this.registry) {\n console.warn(\n `${name} backend was already registered. Reusing existing backend`);\n if (setTensorTrackerFn != null) {\n setTensorTrackerFn(() => this.engine);\n }\n return false;\n }\n try {\n const backend = factory();\n this.registry[name] = {backend, priority};\n return true;\n } catch (err) {\n console.warn(`Registration of backend ${name} failed`);\n console.warn(err.stack || err.message);\n return false;\n }\n }\n\n removeBackend(name: string): void {\n if (!(name in this.registry)) {\n throw new Error(`${name} backend not found in registry`);\n }\n this.registry[name].backend.dispose();\n delete this.registry[name];\n }\n\n get engine(): Engine {\n this.initDefaultBackend();\n return this.globalEngine;\n }\n\n private initDefaultBackend() {\n if (this.globalEngine == null) {\n this.initBackend(this.get('BACKEND'), false /* safeMode */);\n }\n }\n}\n\nfunction getGlobalNamespace(): {ENV: Environment} {\n // tslint:disable-next-line:no-any\n let ns: any;\n if (typeof (window) !== 'undefined') {\n ns = window;\n } else if (typeof (process) !== 'undefined') {\n ns = process;\n } else {\n throw new Error('Could not find a global object');\n }\n return ns;\n}\n\nfunction getOrMakeEnvironment(): Environment {\n const ns = getGlobalNamespace();\n if (ns.ENV == null) {\n ns.ENV = new Environment(getFeaturesFromURL());\n setTensorTracker(() => ns.ENV.engine);\n }\n return ns.ENV;\n}\n\nexport let ENV = getOrMakeEnvironment();\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport function isMobile(): boolean {\n // tslint:disable-next-line:no-any\n const a = navigator.userAgent || navigator.vendor || (window as any).opera;\n // tslint:disable-next-line:max-line-length\n return /(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i\n .test(a) ||\n // tslint:disable-next-line:max-line-length\n /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i\n .test(a.substr(0, 4));\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\n\nexport function warn(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.warn(...msg);\n }\n}\n\nexport function log(...msg: Array<{}>): void {\n if (!ENV.get('IS_TEST')) {\n console.log(...msg);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Gets the new shape of the input Tensor after it's been reshaped\n * to :\n * [blockShape[0], ..., blockShape[M-1], batch / prod(blockShape),\n * inputShape[1], ..., inputShape[N-1]]\n *\n * See step 1: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshaped(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n let reshaped: number[] = [];\n if (batchToSpace) {\n reshaped = reshaped.concat(blockShape.slice(0));\n reshaped.push(inputShape[0] / prod);\n reshaped = reshaped.concat(inputShape.slice(1));\n } else {\n reshaped = reshaped.concat(inputShape[0]);\n const spatialLength = blockShape.length;\n for (let i = 0; i < spatialLength; ++i) {\n reshaped =\n reshaped.concat([inputShape[i + 1] / blockShape[i], blockShape[i]]);\n }\n reshaped = reshaped.concat(inputShape.slice(spatialLength + 1));\n }\n return reshaped;\n}\n\n/**\n * Gets the permutation that will transpose the dimensions of the\n * reshaped tensor to shape:\n *\n * [batch / prod(block_shape),inputShape[1], blockShape[0], ...,\n * inputShape[M], blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * see step 2: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getPermuted(\n reshapedRank: number, blockShapeRank: number,\n batchToSpace = true): number[] {\n const permuted = [];\n if (batchToSpace) {\n permuted.push(blockShapeRank);\n for (let i = blockShapeRank + 1; i < reshapedRank; ++i) {\n if (i <= 2 * blockShapeRank) {\n permuted.push(i);\n permuted.push(i - (blockShapeRank + 1));\n } else {\n permuted.push(i);\n }\n }\n } else {\n const permutedBeforeBatch = [];\n const permutedAfterBatch = [];\n for (let i = 1; i < reshapedRank; ++i) {\n if (i >= blockShapeRank * 2 + 1 || i % 2 === 1) {\n permutedAfterBatch.push(i);\n } else {\n permutedBeforeBatch.push(i);\n }\n }\n permuted.push(...permutedBeforeBatch);\n permuted.push(0);\n permuted.push(...permutedAfterBatch);\n }\n return permuted;\n}\n\n/**\n * Gets the shape of the reshaped and permuted input Tensor before any cropping\n * is applied. The new shape will be:\n *\n * [batch / prod(blockShape),inputShape[1] * blockShape[0], ...,\n * inputShape[M] * blockShape[M-1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 3: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getReshapedPermuted(\n inputShape: number[], blockShape: number[], prod: number,\n batchToSpace = true): number[] {\n const reshapedPermuted = [];\n\n if (batchToSpace) {\n reshapedPermuted.push(inputShape[0] / prod);\n } else {\n reshapedPermuted.push(inputShape[0] * prod);\n }\n\n for (let i = 1; i < inputShape.length; ++i) {\n if (i <= blockShape.length) {\n if (batchToSpace) {\n reshapedPermuted.push(blockShape[i - 1] * inputShape[i]);\n } else {\n reshapedPermuted.push(inputShape[i] / blockShape[i - 1]);\n }\n } else {\n reshapedPermuted.push(inputShape[i]);\n }\n }\n\n return reshapedPermuted;\n}\n\n/**\n * Converts the crops argument into the beginning coordinates of a slice\n * operation\n */\nexport function getSliceBeginCoords(\n crops: number[][], blockShape: number): number[] {\n const sliceBeginCoords = [0];\n for (let i = 0; i < blockShape; ++i) {\n sliceBeginCoords.push(crops[i][0]);\n }\n return sliceBeginCoords;\n}\n\n/**\n * converts the crops argument into the size of a slice operation. When\n * combined with getSliceBeginCoords this function allows the reshaped and\n * permuted Tensor to be cropped to its final output shape of:\n *\n * inputShape[1] * blockShape[0] - crops[0,0] - crops[0,1], ...,\n * inputShape[M] * blockShape[M-1] -crops[M-1,0] -\n * crops[M-1,1],inputShape[M+1], ..., inputShape[N-1]]\n *\n * See step 4: https://www.tensorflow.org/api_docs/python/tf/batch_to_space_nd\n */\nexport function getSliceSize(\n uncroppedShape: number[], crops: number[][], blockShape: number): number[] {\n const sliceSize = uncroppedShape.slice(0, 1);\n for (let i = 0; i < blockShape; ++i) {\n sliceSize.push(uncroppedShape[i + 1] - crops[i][0] - crops[i][1]);\n }\n\n return sliceSize;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\n/**\n * Returns true if the axis specifies the inner most dimensions of the\n * array.\n */\nexport function axesAreInnerMostDims(axes: number[], rank: number): boolean {\n for (let i = 0; i < axes.length; ++i) {\n if (axes[axes.length - i - 1] !== rank - 1 - i) {\n return false;\n }\n }\n return true;\n}\n\nexport function combineLocations(\n outputLoc: number[], reduceLoc: number[], axes: number[]): number[] {\n const rank = outputLoc.length + reduceLoc.length;\n const loc = [];\n let outIdx = 0;\n let reduceIdx = 0;\n   for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n loc.push(outputLoc[outIdx++]);\n } else {\n loc.push(reduceLoc[reduceIdx++]);\n }\n }\n return loc;\n}\n\nexport function computeOutAndReduceShapes(\n aShape: number[], axes: number[]): [number[], number[]] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (axes.indexOf(dim) === -1) {\n outShape.push(aShape[dim]);\n }\n }\n const reduceShape = axes.map(dim => aShape[dim]);\n return [outShape, reduceShape];\n}\n\nexport function expandShapeToKeepDim(\n shape: number[], axes: number[]): number[] {\n const reduceSubShape = axes.map(x => 1);\n return combineLocations(shape, reduceSubShape, axes);\n}\n\nexport function parseAxisParam(\n axis: number|number[], shape: number[]): number[] {\n const rank = shape.length;\n\n // Normalize input\n axis = axis == null ? shape.map((s, i) => i) : [].concat(axis);\n\n // Check for valid range\n util.assert(\n axis.every(ax => ax >= -rank && ax < rank),\n `All values in axis param must be in range [-${rank}, ${rank}) but ` +\n `got axis ${axis}`);\n\n // Check for only integers\n util.assert(\n axis.every(ax => util.isInt(ax)),\n `All values in axis param must be integers but ` +\n `got axis ${axis}`);\n\n // Handle negative axis.\n return axis.map(a => a < 0 ? rank + a : a);\n}\n\nexport function assertAxesAreInnerMostDims(\n msg: string, axes: number[], rank: number): void {\n util.assert(\n axesAreInnerMostDims(axes, rank),\n `${msg} supports only inner-most axes for now. ` +\n `Got axes ${axes} and rank-${rank} input.`);\n}\n\n/**\n * Returns the axes permutation to be used with `tf.transpose`, if such\n * permutation is neccesary. Otherwise it returns null. This method is used by\n * operations that operate only on inner-most axes.\n */\nexport function getAxesPermutation(axes: number[], rank: number): number[]|\n null {\n if (axesAreInnerMostDims(axes, rank)) {\n return null;\n }\n const result: number[] = [];\n for (let i = 0; i < rank; ++i) {\n if (axes.indexOf(i) === -1) {\n result.push(i);\n }\n }\n axes.forEach(axis => result.push(axis));\n return result;\n}\n\n/** Returns the axes permutation that undoes the original permutation. */\nexport function getUndoAxesPermutation(axes: number[]): number[] {\n return axes.map((axis, i) => [i, axis])\n .sort((a, b) => a[1] - b[1])\n .map(x => x[0]);\n}\n\nexport function getInnerMostAxes(numAxes: number, rank: number): number[] {\n const res: number[] = [];\n for (let i = rank - numAxes; i < rank; ++i) {\n res.push(i);\n }\n return res;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Inputs of size above this threshold will be parallelized by calling multiple\n * shader programs.\n */\nimport {nearestDivisor} from '../util';\n\nexport const PARALLELIZE_THRESHOLD = 30;\n\nexport interface ReduceInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n}\n\nexport function computeOptimalWindowSize(inSize: number): number {\n if (inSize <= PARALLELIZE_THRESHOLD) {\n return inSize;\n }\n return nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport * as util from '../util';\n\nexport function assertParamsValid(\n input: Tensor, begin: number[], size: number[]): void {\n util.assert(\n input.rank === begin.length,\n `Error in slice${input.rank}D: Length of begin ${begin} must ` +\n `match the rank of the array (${input.rank}).`);\n util.assert(\n input.rank === size.length,\n `Error in slice${input.rank}D: Length of size ${size} must ` +\n `match the rank of the array (${input.rank}).`);\n\n for (let i = 0; i < input.rank; ++i) {\n util.assert(\n begin[i] + size[i] <= input.shape[i],\n `Error in slice${input.rank}D: begin[${i}] + size[${i}] ` +\n `(${begin[i] + size[i]}) would overflow input.shape[${i}] (${\n input.shape[i]})`);\n }\n}\n\n/**\n * Calculate the start index and output tensor shape for strided slice op.\n */\nexport function getStridedSlicedInfo(\n shape: number[], begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): [number[], number[]] {\n // Note that the axis orders are reversed for runtime ops, so the indices,\n // strides and masks must be as well too.\n const startIndex: number[] = [];\n const endIndex: number[] = [];\n for (let i = 0; i < shape.length; i++) {\n startIndex[i] = startForAxis(beginMask, begin, strides, shape, i);\n endIndex[i] = stopForAxis(endMask, end, strides, shape, i);\n }\n\n let size = new Array(shape.length).fill(0);\n size = size.map((d, i) => {\n let count = 0;\n for (let start = startIndex[i];\n !(strides[i] > 0 ? start >= endIndex[i] : start <= endIndex[i]);\n start += strides[i]) {\n count += 1;\n }\n return count;\n });\n return [startIndex, size];\n}\n\nexport function startForAxis(\n beginMask: number, startIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let start = startIndices[axis];\n\n // Check the axis bit from right of beginMask\n if (beginMask & 1 << axis) {\n if (strides[axis] > 0) {\n // Forward iteration - use the first element. These values will get\n // clamped below (Note: We could have set them to 0 and axis_size-1, but\n // use lowest() and max() to maintain symmetry with StopForAxis())\n start = Number.MIN_SAFE_INTEGER;\n } else {\n // Backward iteration - use the last element.\n start = Number.MAX_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (start < 0) {\n start += axisSize;\n }\n\n // Clamping\n start = util.clamp(0, start, axisSize - 1);\n\n return start;\n}\n\nexport function stopForAxis(\n endMask: number, stopIndices: number[], strides: number[],\n inputShape: number[], axis: number): number {\n // Begin with the specified index\n let stop = stopIndices[axis];\n\n // Check the axis bit from right of endMask\n if (endMask & (1 << axis)) {\n if (strides[axis] > 0) {\n // Forward iteration - use the last element. These values will get\n // clamped below\n stop = Number.MAX_SAFE_INTEGER;\n } else {\n // Backward iteration - use the first element.\n stop = Number.MIN_SAFE_INTEGER;\n }\n }\n\n // Handle negative indices\n const axisSize = inputShape[axis];\n if (stop < 0) {\n stop += axisSize;\n }\n\n // Clamping\n // Because the end index points one past the last element, we need slightly\n // different clamping ranges depending on the direction.\n if (strides[axis] > 0) {\n // Forward iteration\n stop = util.clamp(0, stop, axisSize);\n } else {\n // Backward iteration\n stop = util.clamp(-1, stop, axisSize - 1);\n }\n\n return stop;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {CustomGradientFunc, ScopeFn} from './engine';\nimport {ENV} from './environment';\nimport {Scalar, Tensor, Variable} from './tensor';\nimport {NamedTensorMap, TensorContainer} from './tensor_types';\nimport * as util from './util';\n\n/**\n * Create a new gradient scope. Similar to scope, but forces all inner scopes\n * to not clean up so that gradient operations can be used inside of this\n * scope.\n * @param nameOrScopeFn The name of the scope, or the function to execute.\n * If a name is provided, the 2nd argument should be the function.\n * If a name is provided, and debug mode is on, the timing and the memory\n * usage of the function will be tracked and displayed on the console\n * using the provided name.\n * @param scopeFn The function to execute.\n */\nfunction gradScope(\n nameOrScopeFn: string|ScopeFn, scopeFn?: ScopeFn): T {\n return ENV.engine.tidy(nameOrScopeFn, scopeFn, true /* gradScope */);\n}\n\n/**\n * Provided `f(x)`, returns another function `g(x, dy?)`, which gives the\n * gradient of `f(x)` with respect to `x`.\n *\n * If `dy` is provided, the gradient of `f(x).mul(dy).sum()` with respect to\n * `x` is computed instead. `f(x)` must take a single tensor `x` and return a\n * single tensor `y`. If `f()` takes multiple inputs, use `grads` instead.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.grad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * g(x).print();\n * ```\n *\n * ```js\n * // f(x) = x ^ 3\n * const f = x => x.pow(tf.scalar(3, 'int32'));\n * // f'(x) = 3x ^ 2\n * const g = tf.grad(f);\n * // f''(x) = 6x\n * const gg = tf.grad(g);\n *\n * const x = tf.tensor1d([2, 3]);\n * gg(x).print();\n * ```\n *\n * @param f The function f(x), to compute gradient for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grad(f: (x: I) => O): (\n x: I, dy?: O) => I {\n util.assert(util.isFunction(f), 'The f passed in grad(f) must be a function');\n return (x: I, dy?: O): I => {\n util.assert(\n x instanceof Tensor, 'The x passed in grad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grad(f)(x, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(x), [x], dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grad(f)(x, dy) must match the shape ' +\n 'returned by f(x)');\n }\n checkGrads(grads);\n return grads[0] as I;\n });\n };\n}\n\n/**\n * Provided `f(x1, x2,...)`, returns another function `g([x1, x2,...], dy?)`,\n * which gives an array of gradients of `f()` with respect to each input\n * [`x1`,`x2`,...].\n *\n * If `dy` is passed when calling `g()`, the gradient of\n * `f(x1,...).mul(dy).sum()` with respect to each input is computed instead.\n * The provided `f` must take one or more tensors and return a single tensor\n * `y`. If `f()` takes a single input, we recommend using `grad` instead.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df / da = b, df / db = a\n * const g = tf.grads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const [da, db] = g([a, b]);\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n *\n * @param f The function `f(x1, x2,...)` to compute gradients for.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction grads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => Tensor[] {\n util.assert(\n util.isFunction(f), 'The f passed in grads(f) must be a function');\n return (args: Tensor[], dy?: O): Tensor[] => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in grads(f)(args) must be an array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in grads(f)(args, dy) must be a tensor');\n return ENV.engine.tidy(() => {\n const {value, grads} = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n value.shape, dy.shape,\n 'The shape of dy passed in grads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(grads);\n return grads;\n });\n };\n}\n\n/**\n * Like `grad`, but also returns the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grad: The gradient of `f(x)` w.r.t `x` (result of `grad`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(x) = x ^ 2\n * const f = x => x.square();\n * // f'(x) = 2x\n * const g = tf.valueAndGrad(f);\n *\n * const x = tf.tensor1d([2, 3]);\n * const {value, grad} = g(x);\n *\n * console.log('value');\n * value.print();\n * console.log('grad');\n * grad.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrad(f: (x: I) => O): (\n x: I, dy?: O) => {\n value: O;\n grad: I;\n} {\n util.assert(\n util.isFunction(f), 'The f passed in valueAndGrad(f) must be a function');\n return (x: I, dy?: O) => {\n util.assert(\n x instanceof Tensor,\n 'The x passed in valueAndGrad(f)(x) must be a tensor');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrad(f)(x, dy) must be a tensor');\n const {grads, value} = ENV.engine.gradients(() => f(x), [x], dy);\n checkGrads(grads);\n return {grad: grads[0] as I, value: value as O};\n };\n}\n\n/**\n * Like `grads`, but returns also the value of `f()`. Useful when `f()`\n * returns a metric you want to show.\n *\n * The result is a rich object with the following properties:\n * - grads: The gradients of `f()` w.r.t each input (result of `grads`).\n * - value: The value returned by `f(x)`.\n *\n * ```js\n * // f(a, b) = a * b\n * const f = (a, b) => a.mul(b);\n * // df/da = b, df/db = a\n * const g = tf.valueAndGrads(f);\n *\n * const a = tf.tensor1d([2, 3]);\n * const b = tf.tensor1d([-2, -3]);\n * const {value, grads} = g([a, b]);\n *\n * const [da, db] = grads;\n *\n * console.log('value');\n * value.print();\n *\n * console.log('da');\n * da.print();\n * console.log('db');\n * db.print();\n * ```\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction valueAndGrads(f: (...args: Tensor[]) => O): (\n args: Tensor[], dy?: O) => {\n grads: Tensor[];\n value: O;\n} {\n util.assert(\n util.isFunction(f),\n 'The f passed in valueAndGrads(f) must be a function');\n return (args: Tensor[], dy?: O) => {\n util.assert(\n Array.isArray(args) && args.every(arg => arg instanceof Tensor),\n 'The args passed in valueAndGrads(f)(args) must be array of tensors');\n util.assert(\n dy == null || dy instanceof Tensor,\n 'The dy passed in valueAndGrads(f)(args, dy) must be a tensor');\n const res = ENV.engine.gradients(() => f(...args), args, dy);\n if (dy != null) {\n util.assertShapesMatch(\n res.value.shape, dy.shape,\n 'The shape of dy passed in valueAndGrads(f)([x1,...], dy) must ' +\n 'match the shape returned by f([x1,...])');\n }\n checkGrads(res.grads);\n return res;\n };\n}\n\n/**\n * Computes and returns the gradient of f(x) with respect to the list of\n * trainable variables provided by `varList`. If no list is provided, it\n * defaults to all trainable variables.\n *\n * ```js\n * const a = tf.variable(tf.tensor1d([3, 4]));\n * const b = tf.variable(tf.tensor1d([5, 6]));\n * const x = tf.tensor1d([1, 2]);\n *\n * // f(a, b) = a * x ^ 2 + b * x\n * const f = () => a.mul(x.square()).add(b.mul(x)).sum();\n * // df/da = x ^ 2, df/db = x\n * const {value, grads} = tf.variableGrads(f);\n *\n * Object.keys(grads).forEach(varName => grads[varName].print());\n * ```\n *\n * @param f The function to execute. f() should return a scalar.\n * @param varList The list of trainable variables. Defaults to all variables.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction variableGrads(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n util.assert(\n util.isFunction(f),\n 'The f passed in variableGrads(f) must be a function');\n util.assert(\n varList == null ||\n Array.isArray(varList) && varList.every(v => v instanceof Variable),\n 'The varList passed in variableGrads(f, varList) must be an array ' +\n 'of variables');\n if (varList == null) {\n // Get all of the trainable variables.\n varList = [];\n for (const varName in ENV.engine.registeredVariables) {\n varList.push(ENV.engine.registeredVariables[varName]);\n }\n }\n // Prune non-trainable variables.\n const originalVarCount = varList.length;\n varList = varList.filter(variable => variable.trainable);\n util.assert(\n varList.length > 0,\n `variableGrads() expects at least one of the input variables to be ` +\n `trainable, but none of the ${originalVarCount} variables is ` +\n `trainable.`);\n\n const allowNoGradients = true;\n const {value, grads} =\n ENV.engine.gradients(f, varList, null, allowNoGradients);\n\n util.assert(\n grads.some(g => g != null),\n 'Cannot find a connection between any variable and the result of the ' +\n 'loss function y=f(x). Please make sure the operations that use ' +\n 'variables are inside the function f passed to minimize().');\n util.assert(\n value.rank === 0,\n `The f passed in variableGrads(f) must return a scalar, but it ` +\n `returned a rank-${value.rank} tensor`);\n\n const namedGrads: NamedTensorMap = {};\n varList.forEach((v, i) => {\n if (grads[i] != null) {\n namedGrads[v.name] = grads[i];\n }\n });\n return {value, grads: namedGrads};\n}\n\n/**\n * Overrides the gradient computation of a function `f`.\n *\n * Takes a function\n * `f(...inputs) => {value: Tensor, gradFunc: dy => Tensor[]}` and returns\n * another function `g(...inputs)` which takes the same inputs as `f`. When\n * called, `g` returns `f().value`. In backward mode, custom gradients with\n * respect to each input of `f` are computed using `f().gradFunc`.\n *\n * ```js\n * const customOp = tf.customGrad(x => {\n * // Override gradient of our custom x ^ 2 op to be dy * abs(x);\n * return {value: x.square(), gradFunc: dy => [dy.mul(x.abs())]};\n * });\n *\n * const x = tf.tensor1d([-1, -2, 3]);\n * const dx = tf.grad(x => customOp(x));\n *\n * console.log(`f(x):`);\n * customOp(x).print();\n * console.log(`f'(x):`);\n * dx(x).print();\n * ```\n *\n * @param f The function to evaluate in forward mode, which should return\n * `{value: Tensor, gradFunc: (dy) => Tensor[]}`, where `gradFunc` returns\n * the custom gradients of `f` with respect to its inputs.\n */\n/** @doc {heading: 'Training', subheading: 'Gradients'} */\nfunction customGrad(f: CustomGradientFunc):\n (...args: Tensor[]) => T {\n return ENV.engine.customGrad(f);\n}\n\nfunction checkGrads(grads: Tensor[]) {\n const numNullGradients = grads.filter(g => g == null).length;\n if (numNullGradients > 0) {\n throw new Error(\n `Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.`);\n }\n}\n\nexport {\n gradScope,\n customGrad,\n variableGrads,\n valueAndGrad,\n valueAndGrads,\n grad,\n grads,\n};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Tensor} from './tensor';\nimport {ArrayData, DataType, TensorLike} from './types';\nimport {inferShape, isTypedArray, toTypedArray} from './util';\n\nexport function convertToTensor(\n x: T|TensorLike, argName: string, functionName: string,\n dtype: DataType = 'float32'): T {\n dtype = dtype || 'float32';\n if (x instanceof Tensor) {\n return x;\n }\n if (!isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' &&\n typeof x !== 'boolean') {\n throw new Error(\n `Argument '${argName}' passed to '${functionName}' must be a ` +\n `Tensor or TensorLike, but got ${x.constructor.name}`);\n }\n const inferredShape = inferShape(x);\n if (!isTypedArray(x) && !Array.isArray(x)) {\n x = [x] as number[];\n }\n return Tensor.make(\n inferredShape,\n {values: toTypedArray(x as ArrayData, dtype, ENV.get('DEBUG'))},\n dtype);\n}\n\nexport function convertToTensorArray(\n arg: T[]|TensorLike[], argName: string, functionName: string): T[] {\n if (!Array.isArray(arg)) {\n throw new Error(\n `Argument ${argName} passed to ${functionName} must be a ` +\n '`Tensor[]` or `TensorLike[]`');\n }\n const tensors = arg as T[];\n return tensors.map(\n (t, i) => convertToTensor(t, `${argName}[${i}]`, functionName));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\n\n/**\n * Used for wrapping functions that perform math operations on\n * Tensors. The function will be wrapped in a named scope that cleans all\n * memory usage after the function is done.\n */\nexport function op(f: {[name: string]: T}): T {\n const keys = Object.keys(f);\n if (keys.length !== 1) {\n throw new Error(\n `Please provide an object with a single key ` +\n `(operation name) mapping to a function. Got an object with ` +\n `${keys.length} keys.`);\n }\n\n let opName = keys[0];\n const fn = f[opName];\n\n // Strip the underscore from the end of the function name.\n if (opName.endsWith('_')) {\n opName = opName.substring(0, opName.length - 1);\n }\n\n // tslint:disable-next-line:no-any\n const f2 = (...args: any[]) => {\n ENV.engine.startScope(opName);\n try {\n const result = fn(...args);\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n ENV.engine.endScope(result);\n return result;\n } catch (ex) {\n ENV.engine.endScope(null);\n throw ex;\n }\n };\n Object.defineProperty(f2, 'name', {value: opName, configurable: true});\n\n // tslint:disable-next-line:no-any\n return f2 as any as T;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../gradients';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Computes the softmax normalized vector given the logits.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * ```js\n * const a = tf.tensor2d([2, 4, 6, 1, 2, 3], [2, 3]);\n *\n * a.softmax().print(); // or tf.softmax(a)\n * ```\n *\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction softmax_(logits: T|TensorLike, dim = -1): T {\n const $logits = convertToTensor(logits, 'logits', 'softmax');\n\n if (dim === -1) {\n dim = $logits.rank - 1;\n }\n if (dim !== $logits.rank - 1) {\n throw Error(\n 'Softmax along a non-last dimension is not yet supported. ' +\n `Logits was rank ${$logits.rank} and dim was ${dim}`);\n }\n\n const customOp = customGrad(logits => {\n // Do it in log space for numerical stability.\n // exp(X - logSumExp(X))\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n const logResult = logits.toFloat().sub(lse);\n const y = logResult.exp() as T;\n\n const gradFunc = (dy: T) => {\n const dyTimesY = dy.mul(y);\n const keepDims = true;\n return dyTimesY.sub(dyTimesY.sum([dim], keepDims).mul(y));\n };\n\n return {value: y, gradFunc};\n });\n\n return customOp($logits);\n}\n\nexport const softmax = op({softmax_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, Tensor5D, Tensor6D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, TensorLike1D, TensorLike2D, TensorLike3D, TensorLike4D, TensorLike5D, TensorLike6D} from '../types';\nimport {ArrayData, DataType, Rank, ShapeMap} from '../types';\nimport {assertNonNull, assertShapesMatch, getTypedArrayFromDType, inferShape, isTypedArray, makeOnesTypedArray, makeZerosTypedArray, sizeFromShape, toTypedArray} from '../util';\nimport {op} from './operation';\n\n/**\n * Creates a `Tensor` with the provided values, shape and dtype.\n *\n * ```js\n * // Pass an array of values to create a vector.\n * tf.tensor([1, 2, 3, 4]).print();\n * ```\n *\n * ```js\n * // Pass a nested array of values to make a matrix or a higher\n * // dimensional tensor.\n * tf.tensor([[1, 2], [3, 4]]).print();\n * ```\n *\n * ```js\n * // Pass a flat array and specify a shape yourself.\n * tf.tensor([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor(\n values: TensorLike, shape?: ShapeMap[R],\n dtype: DataType = 'float32'): Tensor {\n if (!isTypedArray(values) && !Array.isArray(values) &&\n typeof values !== 'number' && typeof values !== 'boolean') {\n throw new Error(\n 'values passed to tensor(values) must be an ' +\n 'array of numbers or booleans, or a TypedArray');\n }\n const inferredShape = inferShape(values);\n if (shape != null && inferredShape.length !== 1) {\n assertShapesMatch(\n shape, inferredShape,\n `Error creating a new Tensor. ` +\n `Inferred shape (${inferredShape}) does not match the ` +\n `provided shape (${shape}). `);\n }\n if (!isTypedArray(values) && !Array.isArray(values)) {\n values = [values] as number[];\n }\n shape = shape || inferredShape;\n return Tensor.make(\n shape, {\n values:\n toTypedArray(values as ArrayData, dtype, ENV.get('DEBUG'))\n },\n dtype);\n}\n\n/**\n * Creates rank-0 `Tensor` (scalar) with the provided value and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `scalar` as it makes the code more readable.\n *\n * ```js\n * tf.scalar(3.14).print();\n * ```\n *\n * @param value The value of the scalar.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction scalar(value: number|boolean, dtype: DataType = 'float32'): Scalar {\n if (isTypedArray(value) || Array.isArray(value)) {\n throw new Error(\n 'Error creating a new Scalar: value must be a primitive ' +\n '(number|boolean)');\n }\n return tensor(value, [], dtype);\n}\n\n/**\n * Creates rank-1 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor1d` as it makes the code more readable.\n *\n * ```js\n * tf.tensor1d([1, 2, 3]).print();\n * ```\n *\n * @param values The values of the tensor. Can be array of numbers,\n * or a `TypedArray`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor1d(values: TensorLike1D, dtype: DataType = 'float32'): Tensor1D {\n assertNonNull(values);\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 1) {\n throw new Error('tensor1d() requires values to be a flat/TypedArray');\n }\n return tensor(values, inferredShape as [number], dtype);\n}\n\n/**\n * Creates rank-2 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor2d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor2d([[1, 2], [3, 4]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor2d(\n values: TensorLike2D, shape?: [number, number],\n dtype: DataType = 'float32'): Tensor2D {\n assertNonNull(values);\n if (shape != null && shape.length !== 2) {\n throw new Error('tensor2d() requires shape to have two numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 2 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor2d() requires values to be number[][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor2d() requires shape to be provided when `values` ' +\n 'are a flat/TypedArray');\n }\n shape = shape || inferredShape as [number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-3 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor3d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor3d([[[1], [2]], [[3], [4]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor3d([1, 2, 3, 4], [2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. If not provided, it is inferred from\n * `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor3d(\n values: TensorLike3D, shape?: [number, number, number],\n dtype: DataType = 'float32'): Tensor3D {\n assertNonNull(values);\n if (shape != null && shape.length !== 3) {\n throw new Error('tensor3d() requires shape to have three numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 3 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor3d() requires values to be number[][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor3d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-4 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor4d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor4d([[[[1], [2]], [[3], [4]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor4d([1, 2, 3, 4], [1, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor4d(\n values: TensorLike4D, shape?: [number, number, number, number],\n dtype: DataType = 'float32'): Tensor4D {\n assertNonNull(values);\n if (shape != null && shape.length !== 4) {\n throw new Error('tensor4d() requires shape to have four numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 4 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor4d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor4d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-5 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor5d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor5d([[[[[1], [2]], [[3], [4]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor5d([1, 2, 3, 4, 5, 6, 7, 8], [1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor5d(\n values: TensorLike5D, shape?: [number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor5D {\n assertNonNull(values);\n if (shape != null && shape.length !== 5) {\n throw new Error('tensor5d() requires shape to have five numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 5 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor5d() requires values to be ' +\n 'number[][][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor5d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape || inferredShape as [number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates rank-6 `Tensor` with the provided values, shape and dtype.\n *\n * The same functionality can be achieved with `tensor`, but in general\n * we recommend using `tensor6d` as it makes the code more readable.\n *\n * ```js\n * // Pass a nested array.\n * tf.tensor6d([[[[[[1],[2]],[[3],[4]]],[[[5],[6]],[[7],[8]]]]]]).print();\n * ```\n * ```js\n * // Pass a flat array and specify a shape.\n * tf.tensor6d([1, 2, 3, 4, 5, 6, 7, 8], [1, 1, 2, 2, 2, 1]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction tensor6d(\n values: TensorLike6D,\n shape?: [number, number, number, number, number, number],\n dtype: DataType = 'float32'): Tensor6D {\n assertNonNull(values);\n if (shape != null && shape.length !== 6) {\n throw new Error('tensor6d() requires shape to have six numbers');\n }\n const inferredShape = inferShape(values);\n if (inferredShape.length !== 6 && inferredShape.length !== 1) {\n throw new Error(\n 'tensor6d() requires values to be number[][][][] or flat/TypedArray');\n }\n if (inferredShape.length === 1 && shape == null) {\n throw new Error(\n 'tensor6d() requires shape to be provided when `values` ' +\n 'are a flat array');\n }\n shape = shape ||\n inferredShape as [number, number, number, number, number, number];\n return tensor(values, shape, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1.\n *\n * ```js\n * tf.ones([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction ones(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0.\n *\n * ```js\n * tf.zeros([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The type of an element in the resulting tensor. Can\n * be 'float32', 'int32' or 'bool'. Defaults to 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zeros(\n shape: ShapeMap[R], dtype: DataType = 'float32'): Tensor {\n const values = makeZerosTypedArray(sizeFromShape(shape), dtype);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` filled with a scalar value.\n *\n * ```js\n * tf.fill([2, 2], 4).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param value The scalar value to fill the tensor with.\n * @param dtype The type of an element in the resulting tensor. Defaults to\n * 'float'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fill(\n shape: ShapeMap[R], value: number, dtype: DataType = 'float32'): Tensor {\n const values = getTypedArrayFromDType(dtype, sizeFromShape(shape));\n values.fill(value);\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with all elements set to 1 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.onesLike(x).print();\n * ```\n * @param x A tensor.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction onesLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'onesLike');\n return ones($x.shape, $x.dtype) as T;\n}\n\n/**\n * Creates a `Tensor` with all elements set to 0 with the same shape as the\n * given tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n * tf.zerosLike(x).print();\n * ```\n *\n * @param x The tensor of required shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction zerosLike_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'zerosLike');\n return zeros($x.shape, $x.dtype) as T;\n}\n\n/**\n * Return an evenly spaced sequence of numbers over the given interval.\n *\n * ```js\n * tf.linspace(0, 9, 10).print();\n * ```\n * @param start The start value of the sequence.\n * @param stop The end value of the sequence.\n * @param num The number of values to generate.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction linspace(start: number, stop: number, num: number): Tensor1D {\n if (num === 0) {\n throw new Error('Cannot request zero samples');\n }\n\n const step = (stop - start) / (num - 1);\n\n const values = makeZerosTypedArray(num, 'float32');\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, 'float32');\n}\n\n/**\n * Creates a new `Tensor1D` filled with the numbers in the range provided.\n *\n * The tensor is a is half-open interval meaning it includes start, but\n * excludes stop. Decrementing ranges and negative step values are also\n * supported.\n *\n * ```js\n * tf.range(0, 9, 2).print();\n * ```\n *\n * @param start An integer start value\n * @param stop An integer stop value\n * @param step An integer increment (will default to 1 or -1)\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction range(\n start: number, stop: number, step = 1,\n dtype: 'float32'|'int32' = 'float32'): Tensor1D {\n if (step === 0) {\n throw new Error('Cannot have a step of zero');\n }\n\n const sameStartStop = start === stop;\n const increasingRangeNegativeStep = start < stop && step < 0;\n const decreasingRangePositiveStep = stop < start && step > 1;\n\n if (sameStartStop || increasingRangeNegativeStep ||\n decreasingRangePositiveStep) {\n return zeros([0], dtype);\n }\n\n const numElements = Math.abs(Math.ceil((stop - start) / step));\n const values = makeZerosTypedArray(numElements, dtype);\n\n if (stop < start && step === 1) {\n // Auto adjust the step's sign if it hasn't been set\n // (or was set to 1)\n step = -1;\n }\n\n values[0] = start;\n for (let i = 1; i < values.length; i++) {\n values[i] = values[i - 1] + step;\n }\n\n return tensor1d(values, dtype);\n}\n\nexport {\n fill,\n linspace,\n ones,\n range,\n scalar,\n tensor,\n tensor1d,\n tensor2d,\n tensor3d,\n tensor4d,\n tensor5d,\n tensor6d,\n zeros\n};\n\nexport const onesLike = op({onesLike_});\nexport const zerosLike = op({zerosLike_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport enum DType {\n float32 = 'float32',\n int32 = 'int32',\n bool = 'bool'\n}\n\n/** @docalias number[] */\nexport interface ShapeMap {\n R0: number[];\n R1: [number];\n R2: [number, number];\n R3: [number, number, number];\n R4: [number, number, number, number];\n R5: [number, number, number, number, number];\n R6: [number, number, number, number, number, number];\n}\n\n/** @hidden */\nexport interface DataTypeMap {\n float32: Float32Array;\n int32: Int32Array;\n bool: Uint8Array;\n}\n/** @docalias 'float32'|'int32'|'bool' */\nexport type DataType = keyof DataTypeMap;\nexport type TypedArray = DataTypeMap[DataType];\n\nexport enum Rank {\n R0 = 'R0',\n R1 = 'R1',\n R2 = 'R2',\n R3 = 'R3',\n R4 = 'R4',\n R5 = 'R5',\n R6 = 'R6'\n}\n\nexport type FlatVector = boolean[]|number[]|TypedArray;\nexport type RegularArray =\n T[]|T[][]|T[][][]|T[][][][]|T[][][][][]|T[][][][][][];\nexport type ArrayData =\n DataTypeMap[D]|RegularArray|RegularArray;\n\n// tslint:disable-next-line:no-any\nexport interface RecursiveArray {\n [index: number]: T|RecursiveArray;\n}\n\nenum UpcastInt32AndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'int32'\n}\n\nenum UpcastBoolAndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'bool'\n}\n\nenum UpcastFloat32AndMap {\n 'float32' = 'float32',\n 'int32' = 'float32',\n 'bool' = 'float32'\n}\n\nconst upcastTypeMap = {\n 'float32': UpcastFloat32AndMap,\n 'int32': UpcastInt32AndMap,\n 'bool': UpcastBoolAndMap\n};\n\nexport function upcastType(typeA: DataType, typeB: DataType): DataType {\n return upcastTypeMap[typeA][typeB];\n}\n\n/** Returns the output type after summation. */\nexport function sumOutType(type: DataType) {\n return upcastType(type, 'int32');\n}\n\n/** @docalias TypedArray|Array */\nexport type TensorLike =\n TypedArray|number|boolean|number[]|number[][]|number[][][]|number[][][][]|\n number[][][][][]|number[][][][][][]|boolean[]|boolean[][]|boolean[][][]|\n boolean[][][][]|boolean[][][][][]|boolean[][][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike1D = TypedArray|number[]|boolean[];\n/** @docalias TypedArray|Array */\nexport type TensorLike2D = TypedArray|number[]|number[][]|boolean[]|boolean[][];\n/** @docalias TypedArray|Array */\nexport type TensorLike3D =\n TypedArray|number[]|number[][][]|boolean[]|boolean[][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike4D =\n TypedArray|number[]|number[][][][]|boolean[]|boolean[][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike5D =\n TypedArray|number[]|number[][][][][]|boolean[]|boolean[][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike6D =\n TypedArray|number[]|number[][][][][][]|boolean[]|boolean[][][][][][];\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {scalar} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {Rank} from '../types';\nimport {DataType, ShapeMap} from '../types';\nimport {hasEncodingLoss} from '../util';\nimport {KernelBackend} from './backend';\n\nexport function castTensor(\n x: T, dtype: DataType, backend: KernelBackend): T {\n if (!hasEncodingLoss(x.dtype, dtype)) {\n // We don't change the underlying data, since we cast to higher\n // precision.\n return Tensor.make(x.shape, {dataId: x.dataId}, dtype) as T;\n }\n if (dtype === 'int32') {\n return backend.int(x);\n } else if (dtype === 'bool') {\n return backend.notEqual(x, scalar(0, x.dtype)) as T;\n } else {\n throw new Error(`Error in Cast: unknown dtype argument (${dtype})`);\n }\n}\n\nexport function reshapeTensor(\n x: T, shape: ShapeMap[R]): Tensor {\n return Tensor.make(shape, {dataId: x.dataId}, x.dtype);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Implementation of the NonMaxSuppression kernel shared between webgl and cpu.\n */\n\nimport {tensor1d} from '../ops/tensor_ops';\nimport {Tensor1D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function nonMaxSuppressionImpl(\n boxes: TypedArray, scores: TypedArray, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const candidates = Array.from(scores)\n .map((score, boxIndex) => ({score, boxIndex}))\n .filter(c => c.score > scoreThreshold)\n .sort((c1, c2) => c2.score - c1.score);\n\n const selected: number[] = [];\n\n for (let i = 0; i < candidates.length; i++) {\n const {score, boxIndex} = candidates[i];\n if (score < scoreThreshold) {\n break;\n }\n\n let ignoreCandidate = false;\n for (let j = selected.length - 1; j >= 0; --j) {\n const iou = intersectionOverUnion(boxes, boxIndex, selected[j]);\n if (iou >= iouThreshold) {\n ignoreCandidate = true;\n break;\n }\n }\n\n if (!ignoreCandidate) {\n selected.push(boxIndex);\n if (selected.length >= maxOutputSize) {\n break;\n }\n }\n }\n\n return tensor1d(selected, 'int32');\n}\n\nfunction intersectionOverUnion(boxes: TypedArray, i: number, j: number) {\n const iCoord = boxes.subarray(i * 4, i * 4 + 4);\n const jCoord = boxes.subarray(j * 4, j * 4 + 4);\n const yminI = Math.min(iCoord[0], iCoord[2]);\n const xminI = Math.min(iCoord[1], iCoord[3]);\n const ymaxI = Math.max(iCoord[0], iCoord[2]);\n const xmaxI = Math.max(iCoord[1], iCoord[3]);\n const yminJ = Math.min(jCoord[0], jCoord[2]);\n const xminJ = Math.min(jCoord[1], jCoord[3]);\n const ymaxJ = Math.max(jCoord[0], jCoord[2]);\n const xmaxJ = Math.max(jCoord[1], jCoord[3]);\n const areaI = (ymaxI - yminI) * (xmaxI - xminI);\n const areaJ = (ymaxJ - yminJ) * (xmaxJ - xminJ);\n if (areaI <= 0 || areaJ <= 0) {\n return 0.0;\n }\n const intersectionYmin = Math.max(yminI, yminJ);\n const intersectionXmin = Math.max(xminI, xminJ);\n const intersectionYmax = Math.min(ymaxI, ymaxJ);\n const intersectionXmax = Math.min(xmaxI, xmaxJ);\n const intersectionArea = Math.max(intersectionYmax - intersectionYmin, 0.0) *\n Math.max(intersectionXmax - intersectionXmin, 0.0);\n return intersectionArea / (areaI + areaJ - intersectionArea);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the TopK kernel shared between webgl and cpu. */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {DataType, TypedArray} from '../types';\nimport {getTypedArrayFromDType} from '../util';\n\nexport function topkImpl(\n x: TypedArray, xShape: number[], xDtype: DataType, k: number,\n sorted: boolean): [T, T] {\n // Reshape into a 2d tensor [batch, lastDim] and compute topk along lastDim.\n const lastDim = xShape[xShape.length - 1];\n const [batch, size] = [x.length / lastDim, lastDim];\n const allTopKVals = getTypedArrayFromDType(xDtype, batch * k);\n const allTopKIndices = getTypedArrayFromDType('int32', batch * k);\n\n for (let b = 0; b < batch; b++) {\n const offset = b * size;\n const vals = x.subarray(offset, offset + size);\n const valAndInd: Array<{value: number, index: number}> = [];\n for (let i = 0; i < vals.length; i++) {\n valAndInd.push({value: vals[i], index: i});\n }\n valAndInd.sort((a, b) => b.value - a.value);\n\n const outOffset = b * k;\n const topKVals = allTopKVals.subarray(outOffset, outOffset + k);\n const topKIndices = allTopKIndices.subarray(outOffset, outOffset + k);\n for (let i = 0; i < k; i++) {\n topKVals[i] = valAndInd[i].value;\n topKIndices[i] = valAndInd[i].index;\n }\n }\n // Reshape back to the original input shape, except that the last\n // dimension is k.\n const outputShape = xShape.slice();\n outputShape[outputShape.length - 1] = k;\n return [\n tensor(allTopKVals, outputShape, xDtype) as T,\n tensor(allTopKIndices, outputShape, 'int32') as T\n ];\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ArgMinMaxProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n\n constructor(reduceInfo: ReduceInfo, op: 'max'|'min', firstPass: boolean) {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n if (!firstPass) {\n this.variableNames.push('bestIndicesA');\n }\n this.outputShape = [batchSize, outSize];\n const compOp = (op === 'max') ? '>' : '<';\n const indexSnippet = firstPass ?\n 'inOffset + i;' :\n 'round(getBestIndicesA(batch, inOffset + i));';\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < ${windowSize}; i++) {\n int inIdx = ${indexSnippet};\n float candidate = getA(batch, inIdx);\n if (candidate ${compOp} bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class AvgPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float avgMultiplier = float(${avgMultiplier});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Returns the dimensions in the input shape that are broadcasted to\n * produce the provided output shape.\n *\n * The returned dimensions are 0-indexed and sorted. An example:\n * inShape = [4, 1, 3]\n * outShape = [5, 4, 3, 3]\n * result = [1]. Dimension 1 (2nd dimension of input) gets broadcasted 1 => 3.\n */\nexport function getBroadcastDims(\n inShape: number[], outShape: number[]): number[] {\n const inRank = inShape.length;\n const dims: number[] = [];\n for (let i = 0; i < inRank; i++) {\n const dim = inRank - 1 - i;\n const a = inShape[dim] || 1;\n const b = outShape[outShape.length - 1 - i] || 1;\n if (b > 1 && a === 1) {\n dims.unshift(dim);\n }\n }\n return dims;\n}\n\n/**\n * Returns the axes in the output space that should be reduced to produce\n * the input space.\n */\nexport function getReductionAxes(\n inShape: number[], outShape: number[]): number[] {\n const result: number[] = [];\n for (let i = 0; i < outShape.length; i++) {\n const inDim = inShape[inShape.length - i - 1];\n const outAxis = outShape.length - i - 1;\n const outDim = outShape[outAxis];\n if (inDim == null || (inDim === 1 && outDim > 1)) {\n result.unshift(outAxis);\n }\n }\n return result;\n}\n\n/**\n * Given the output of `getBroadcastDims()`, returns true if the broadcasting\n * is along the outer-most dimensions of the input.\n */\nexport function broadcastDimsAreOuter(dims: number[]): boolean {\n for (let i = 0; i < dims.length; i++) {\n if (dims[i] !== i) {\n return false;\n }\n }\n return true;\n}\n\nexport function assertAndGetBroadcastShape(\n shapeA: number[], shapeB: number[]): number[] {\n const result: number[] = [];\n const errMsg = `Operands could not be broadcast together with shapes ` +\n `${shapeA} and ${shapeB}.`;\n const l = Math.max(shapeA.length, shapeB.length);\n\n for (let i = 0; i < l; i++) {\n const a = shapeA[shapeA.length - i - 1] || 1;\n const b = shapeB[shapeB.length - i - 1] || 1;\n if (a > 1 && b > 1 && a !== b) {\n throw Error(errMsg);\n }\n result.unshift(Math.max(a, b));\n }\n return result;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class BatchNormProgram implements GPGPUProgram {\n variableNames: string[];\n outputShape: number[] = [];\n userCode: string;\n supportsBroadcasting = true;\n\n constructor(\n xShape: number[], meanShape: number[], varianceShape: number[],\n offsetShape: number[]|null, scaleShape: number[]|null,\n varianceEpsilon: number) {\n this.variableNames = ['x', 'mean', 'variance'];\n broadcast_util.assertAndGetBroadcastShape(xShape, meanShape);\n broadcast_util.assertAndGetBroadcastShape(xShape, varianceShape);\n\n let offsetSnippet = '0.0';\n if (offsetShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, offsetShape);\n this.variableNames.push('offset');\n offsetSnippet = 'getOffsetAtOutCoords()';\n }\n\n let scaleSnippet = '1.0';\n if (scaleShape != null) {\n broadcast_util.assertAndGetBroadcastShape(xShape, scaleShape);\n this.variableNames.push('scale');\n scaleSnippet = 'getScaleAtOutCoords()';\n }\n\n this.outputShape = xShape;\n this.userCode = `\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = ${offsetSnippet};\n float scale = ${scaleSnippet};\n float inv = scale * inversesqrt(variance + float(${varianceEpsilon}));\n setOutput((x - mean) * inv + offset);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as broadcast_util from '../../ops/broadcast_util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nconst CHECK_NAN_SNIPPET = `\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n`;\n\nexport const ADD = 'return a + b;';\nexport const SUB = 'return a - b;';\nexport const MUL = 'return a * b;';\nexport const DIV = `if (a == b) return 1.0;\n return a / b;`;\n\n// We use native integer division to deal with floating point imprecision. Since\n// we implement floor division and glsl implements truncated division, we\n// correct for this by subtracting 1 from result when the result is negative and\n// there is a remainder.\nexport const INT_DIV = `\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n`;\n\nexport const POW = `\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n`;\nexport const SQUARED_DIFFERENCE = 'return (a - b) * (a - b);';\n\nexport const EQUAL = `return float(a == b);`;\n\nexport const NOT_EQUAL = `return float(a != b);`;\n\nexport const LESS = `return float(a < b);`;\n\nexport const LESS_EQUAL = `return float(a <= b);`;\n\nexport const GREATER = `return float(a > b);`;\n\nexport const GREATER_EQUAL = `return float(a >= b);`;\n\nexport const LOGICAL_AND = `return float(a >= 1.0 && b >= 1.0);`;\n\nexport const LOGICAL_OR = `return float(a >= 1.0 || b >= 1.0);`;\n\nexport const MAX = CHECK_NAN_SNIPPET + `\n return max(a, b);\n`;\nexport const MIN = CHECK_NAN_SNIPPET + `\n return min(a, b);\n`;\nexport const MOD = `if (b == 0.0) return NAN;\n return mod(a, b);`;\n\nexport const ATAN2 = CHECK_NAN_SNIPPET + `\n return atan(a, b);\n`;\n\nexport const ELU_DER = `return (b >= 1.0) ? a : a * (b + 1.0);`;\n\nexport class BinaryOpProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting = true;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(op: string, aShape: number[], bShape: number[]) {\n this.outputShape =\n broadcast_util.assertAndGetBroadcastShape(aShape, bShape);\n this.userCode = `\n uniform float NAN;\n float binaryOperation(float a, float b) {\n ${op}\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ClipProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(aShape: number[], min: number, max: number) {\n this.outputShape = aShape;\n const minFixed = min.toFixed(20);\n const maxFixed = max.toFixed(20);\n this.userCode = `\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, ${minFixed}, ${maxFixed}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport function assertParams(aShape: number[], bShape: number[], axis: number) {\n const aRank = aShape.length;\n const bRank = bShape.length;\n util.assert(\n aShape.length === bShape.length,\n `Error in concat${aRank}D: rank of x1 (${aRank}) and x2 (${bRank}) ` +\n `must be the same.`);\n\n util.assert(\n axis >= 0 && axis < aRank,\n `Error in concat${aRank}D: axis must be ` +\n `between 0 and ${aRank - 1}.`);\n\n for (let i = 0; i < aRank; i++) {\n util.assert(\n (i === axis) || (aShape[i] === bShape[i]),\n `Error in concat${aRank}D: Shape (${aShape}) does not match ` +\n `(${bShape}) along the non-concatenated axis ${i}.`);\n }\n}\n\nexport function computeOutShape(\n x1Shape: number[], x2Shape: number[], axis: number): number[] {\n util.assert(\n x1Shape.length === x2Shape.length,\n 'x1 and x2 should have the same rank.');\n const outputShape = x1Shape.slice();\n outputShape[axis] += x2Shape[axis];\n return outputShape;\n}\n\nexport function computeGradientSliceShapes(\n aShape: [number, number], bShape: [number, number]) {\n return {\n aBegin: [0, 0] as [number, number],\n aSize: aShape,\n bBegin: [0, aShape[1]] as [number, number],\n bSize: bShape\n };\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as concat_util from '../../ops/concat_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ConcatProgram implements GPGPUProgram {\n variableNames = ['A', 'B'];\n outputShape: number[] = [];\n userCode: string;\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n constructor(aShape: [number, number], bShape: [number, number]) {\n this.outputShape =\n concat_util.computeOutShape(aShape, bShape, 1 /* axis */);\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < ${aShape[1]}) {\n value = getA(yR, yC);\n } else {\n yC -= ${aShape[1]};\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class Conv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n for (int d2 = 0; d2 < ${convInfo.outChannels}; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DDerFilterProgram implements GPGPUProgram {\n variableNames = ['x', 'dy'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.filterShape;\n\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * ${channelMul} + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < ${convInfo.batchSize}; b++) {\n for (int yR = 0; yR < ${convInfo.outHeight}; yR++) {\n int xR = wR + yR * ${strideHeight} - ${padTop};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int yC = 0; yC < ${convInfo.outWidth}; yC++) {\n int xC = wC + yC * ${strideWidth} - ${padLeft};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n\nexport class DepthwiseConv2DDerInputProgram implements GPGPUProgram {\n variableNames = ['dy', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = ${filterHeight} - 1 - wR;\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = ${filterWidth} - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < ${channelMul}; dm++) {\n int d2 = d1 * ${channelMul} + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Conv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n\n const inputDepthNearestVec4 = Math.floor(convInfo.inChannels / 4) * 4;\n const inputDepthVec4Remainder = convInfo.inChannels % 4;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n for (int d1 = 0; d1 < ${inputDepthNearestVec4}; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (${inputDepthVec4Remainder === 1}) {\n dotProd +=\n getX(batch, xR, xC, ${inputDepthNearestVec4}) *\n getW(wR, wC, ${inputDepthNearestVec4}, d2);\n } else if (${inputDepthVec4Remainder === 2}) {\n vec2 xValues = vec2(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (${inputDepthVec4Remainder === 3}) {\n vec3 xValues = vec3(\n getX(batch, xR, xC, ${inputDepthNearestVec4}),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 1),\n getX(batch, xR, xC, ${inputDepthNearestVec4} + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, ${inputDepthNearestVec4}, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 1, d2),\n getW(wR, wC, ${inputDepthNearestVec4} + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class DepthwiseConv2DProgram implements GPGPUProgram {\n variableNames = ['x', 'W'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.outShape;\n\n const xNumRows = convInfo.inHeight;\n const xNumCols = convInfo.inWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const channelMul = convInfo.outChannels / convInfo.inChannels;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / ${channelMul};\n int q = d2 - d1 * ${channelMul};\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR * ${dilationHeight};\n\n if (xR < 0 || xR >= ${xNumRows}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC * ${dilationWidth};\n\n if (xC < 0 || xC >= ${xNumCols}) {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport * as broadcast_util from '../../ops/broadcast_util';\nimport * as util from '../../util';\n\nexport type ShapeInfo = {\n logicalShape: number[],\n texShape: [number, number],\n isUniform: boolean\n};\n\nexport type InputInfo = {\n name: string,\n shapeInfo: ShapeInfo\n};\n\nexport function makeShader(\n inputsInfo: InputInfo[], outputShape: ShapeInfo, userCode: string,\n broadcast: boolean): string {\n let inputPrefixSnippet: string[]|string = inputsInfo.map(x => {\n const size = util.sizeFromShape(x.shapeInfo.logicalShape);\n if (x.shapeInfo.isUniform) {\n return `uniform float ${x.name}${size > 1 ? `[${size}]` : ''};`;\n }\n return `uniform sampler2D ${x.name};`;\n });\n inputPrefixSnippet = inputPrefixSnippet.join('\\n');\n const inputSamplingSnippet =\n inputsInfo.map(x => getInputSamplingSnippet(x, outputShape, broadcast))\n .join('\\n');\n const outTexShape = outputShape.texShape;\n const outputSamplingSnippet =\n getOutputSamplingSnippet(outputShape.logicalShape, outTexShape);\n const source = [\n SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET,\n FLOAT_TEXTURE_SETOUTPUT_SNIPPET, inputPrefixSnippet, outputSamplingSnippet,\n inputSamplingSnippet, userCode\n ].join('\\n');\n return source;\n}\n\nfunction getSamplerFromInInfo(inInfo: InputInfo): string {\n const shape = inInfo.shapeInfo.logicalShape;\n switch (shape.length) {\n case 0:\n return getSamplerScalar(inInfo);\n case 1:\n return getSampler1D(inInfo);\n case 2:\n return getSampler2D(inInfo);\n case 3:\n return getSampler3D(inInfo);\n case 4:\n return getSampler4D(inInfo);\n case 5:\n return getSampler5D(inInfo);\n case 6:\n return getSampler6D(inInfo);\n default:\n throw new Error(\n `${shape.length}-D input sampling` +\n ` is not yet supported`);\n }\n}\n\nfunction getInputSamplingSnippet(\n inInfo: InputInfo, outShapeInfo: ShapeInfo, broadcast: boolean): string {\n let res = getSamplerFlat(inInfo);\n res += getSamplerFromInInfo(inInfo);\n\n // If input and output have matching logical shapes, add\n // getTexNameAtOutCoord() method that samples the input\n // textureSampler using the output coordinates.\n if (broadcast ||\n util.arraysEqual(\n inInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape)) {\n res += getSamplerAtOutputCoords(inInfo, outShapeInfo, broadcast);\n }\n return res;\n}\n\nfunction getOutputSamplingSnippet(\n outShape: number[], outTexShape: [number, number]): string {\n switch (outShape.length) {\n case 0:\n return getOutputScalarCoords();\n case 1:\n return getOutput1DCoords(outShape as [number], outTexShape);\n case 2:\n return getOutput2DCoords(outShape as [number, number], outTexShape);\n case 3:\n return getOutput3DCoords(\n outShape as [number, number, number], outTexShape);\n case 4:\n return getOutput4DCoords(\n outShape as [number, number, number, number], outTexShape);\n case 5:\n return getOutput5DCoords(\n outShape as [number, number, number, number, number], outTexShape);\n case 6:\n return getOutput6DCoords(\n outShape as [number, number, number, number, number, number],\n outTexShape);\n default:\n throw new Error(\n `${outShape.length}-D output sampling is not yet supported`);\n }\n}\n\nconst SAMPLE_1D_SNIPPET = `\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_2D_SNIPPET = `\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_3D_SNIPPET = `\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_4D_SNIPPET = `\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_5D_SNIPPET = `\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst SAMPLE_6D_SNIPPET = `\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n`;\n\nconst FLOAT_TEXTURE_SAMPLE_SNIPPET = `\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n`;\n\nconst FLOAT_TEXTURE_SETOUTPUT_SNIPPET = `\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n`;\n\nconst SHADER_PREFIX = `\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n ${SAMPLE_1D_SNIPPET}\n ${SAMPLE_2D_SNIPPET}\n ${SAMPLE_3D_SNIPPET}\n ${SAMPLE_4D_SNIPPET}\n ${SAMPLE_5D_SNIPPET}\n ${SAMPLE_6D_SNIPPET}\n`;\n\nfunction getOutputScalarCoords() {\n return `\n int getOutputCoords() {\n return 0;\n }\n `;\n}\n\nfunction getOutput1DCoords(\n shape: [number], texShape: [number, number]): string {\n if (texShape[0] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.x * ${texShape[1]}.0);\n }\n `;\n }\n if (texShape[1] === 1) {\n return `\n int getOutputCoords() {\n return int(resultUV.y * ${texShape[0]}.0);\n }\n `;\n }\n return `\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n return resTexRC.x * ${texShape[1]} + resTexRC.y;\n }\n `;\n}\n\nfunction getOutput3DCoords(\n shape: [number, number, number], texShape: [number, number]): string {\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n return `\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${stride0};\n index -= r * ${stride0};\n int c = index / ${stride1};\n int d = index - c * ${stride1};\n return ivec3(r, c, d);\n }\n `;\n}\n\nfunction getOutput4DCoords(\n shape: [number, number, number, number],\n texShape: [number, number]): string {\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n int d2 = index - d * ${stride2};\n\n return ivec4(r, c, d, d2);\n }\n `;\n}\n\nfunction getOutput5DCoords(\n shape: [number, number, number, number, number],\n texShape: [number, number]): string {\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n return `\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(${texShape[0]},\n ${texShape[1]}));\n\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n int d3 = index - d2 * ${stride3};\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n `;\n}\n\nfunction getOutput6DCoords(\n shape: [number, number, number, number, number, number],\n texShape: [number, number]): string {\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n return `\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n\n int r = index / ${stride0};\n index -= r * ${stride0};\n\n int c = index / ${stride1};\n index -= c * ${stride1};\n\n int d = index / ${stride2};\n index -= d * ${stride2};\n\n int d2 = index / ${stride3};\n index -= d2 * ${stride3};\n\n int d3 = index / ${stride4};\n int d4 = index - d3 * ${stride4};\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n `;\n}\n\nfunction getOutput2DCoords(\n shape: [number, number], texShape: [number, number]): string {\n if (util.arraysEqual(shape, texShape)) {\n return `\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(${texShape[0]}, ${texShape[1]}));\n }\n `;\n }\n if (shape[1] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(index, 0);\n }\n `;\n }\n if (shape[0] === 1) {\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n return ivec2(0, index);\n }\n `;\n }\n return `\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${texShape[0]}, ${texShape[1]}));\n int index = resTexRC.x * ${texShape[1]} + resTexRC.y;\n int r = index / ${shape[1]};\n int c = index - r * ${shape[1]};\n return ivec2(r, c);\n }\n `;\n}\n\nfunction getSamplerScalar(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n if (inputInfo.shapeInfo.isUniform) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n}\n\nfunction getSampler1D(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n return `\n float ${funcName}(int index) {\n return ${funcName}Flat(index);\n }\n `;\n}\n\nfunction getSampler2D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n\n const texShape = inputInfo.shapeInfo.texShape;\n if (texShape != null && util.arraysEqual(shape, texShape)) {\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumR === 1) {\n return `\n float ${funcName}(int row, int col) {\n int index = row * ${shape[1]} + col;\n vec2 uv = vec2((float(index) + 0.5) / ${texNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col) {\n vec2 uv = UVfrom2D(${texNumR}, ${texNumC}, ${shape[1]}, row, col);\n return sampleTexture(${texName}, uv);\n }\n`;\n}\n\nfunction getSampler3D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride0 = shape[1] * shape[2];\n const stride1 = shape[2];\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n const squeezedShape = newShape;\n if (squeezedShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, squeezedShape);\n const params = ['row', 'col', 'depth'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int index = row * ${stride0} + col * ${stride1} + depth;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row;\n int texC = col * ${stride1} + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride1) {\n return `\n float ${funcName}(int row, int col, int depth) {\n int texR = row * ${shape[1]} + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n ${texNumR}, ${texNumC}, ${stride0}, ${stride1}, row, col, depth);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler4D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride2 = shape[3];\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride2) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, row, col, depth, depth2);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler5D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride3 = shape[4];\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3;\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} +\n depth2 * ${stride3} + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n if (texNumC === stride3) {\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} +\n depth * ${shape[3]} + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n\n return `\n float ${funcName}(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, row, col, depth, depth2, depth3);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSampler6D(inputInfo: InputInfo): string {\n const shape = inputInfo.shapeInfo.logicalShape;\n const texName = inputInfo.name;\n const funcName = 'get' + texName.charAt(0).toUpperCase() + texName.slice(1);\n const stride4 = shape[5];\n const stride3 = shape[4] * stride4;\n const stride2 = shape[3] * stride3;\n const stride1 = shape[2] * stride2;\n const stride0 = shape[1] * stride1;\n const {newShape, keptDims} = util.squeezeShape(shape);\n if (newShape.length < shape.length) {\n const newInputInfo = squeezeInputInfo(inputInfo, newShape);\n const params = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4'];\n return `\n ${getSamplerFromInInfo(newInputInfo)}\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return ${funcName}(${getSqueezedParams(params, keptDims)});\n }\n `;\n }\n\n if (inputInfo.shapeInfo.isUniform) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * ${stride0} + col * ${stride1} +\n depth * ${stride2} + depth2 * ${stride3} + depth3 * ${stride3}\n + depth4\n return ${funcName}Flat(index);\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const texNumR = texShape[0];\n const texNumC = texShape[1];\n if (texNumC === stride0) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * ${stride1} + depth * ${stride2} + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (texNumC === stride4) {\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * ${shape[1] * shape[2]} + col * ${shape[2]} + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${texNumC}.0, ${texNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(${texNumR}, ${texNumC}, ${stride0}, ${stride1},\n ${stride2}, ${stride3}, ${stride4}\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getSamplerFlat(inputInfo: InputInfo): string {\n const texName = inputInfo.name;\n const funcName =\n 'get' + texName.charAt(0).toUpperCase() + texName.slice(1) + 'Flat';\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n\n if (inputInfo.shapeInfo.isUniform) {\n if (inSize === 1) {\n return `float ${funcName}(int index) {return ${texName};}`;\n }\n return `\n float ${funcName}(int index) {\n for (int i = 0; i < ${inSize}; i++) {\n if (i == index) {\n return ${texName}[i];\n }\n }\n }\n `;\n }\n\n const texShape = inputInfo.shapeInfo.texShape;\n const tNumR = texShape[0];\n const tNumC = texShape[1];\n if (tNumC === 1 && tNumR === 1) {\n return `\n float ${funcName}(int index) {\n return sampleTexture(${texName}, halfCR);\n }\n `;\n }\n if (tNumC === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / ${tNumR}.0);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n if (tNumR === 1) {\n return `\n float ${funcName}(int index) {\n vec2 uv = vec2((float(index) + 0.5) / ${tNumC}.0, 0.5);\n return sampleTexture(${texName}, uv);\n }\n `;\n }\n return `\n float ${funcName}(int index) {\n vec2 uv = UVfrom1D(${tNumR}, ${tNumC}, index);\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nfunction getBroadcastOutputCoordsSampler(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo, texFuncSnippet: string,\n funcName: string): string {\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n\n let type = 'int';\n if (outRank === 2) {\n type = 'ivec2';\n } else if (outRank === 3) {\n type = 'ivec3';\n } else if (outRank === 4) {\n type = 'ivec4';\n }\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const rankDiff = outRank - inRank;\n let coordsSnippet: string;\n if (inRank === 0) {\n coordsSnippet = '';\n } else if (outRank < 2 && broadcastDims.length >= 1) {\n coordsSnippet = 'coords = 0;';\n } else {\n coordsSnippet =\n broadcastDims.map(d => `coords[${d + rankDiff}] = 0;`).join('\\n');\n }\n let unpackedCoordsSnippet = '';\n if (outRank < 2 && inRank > 0) {\n unpackedCoordsSnippet = 'coords';\n } else {\n unpackedCoordsSnippet = inputInfo.shapeInfo.logicalShape\n .map((s, i) => `coords[${i + rankDiff}]`)\n .join(', ');\n }\n return `\n float ${funcName}() {\n ${type} coords = getOutputCoords();\n ${coordsSnippet}\n return get${texFuncSnippet}(${unpackedCoordsSnippet});\n }\n `;\n}\n\nfunction getSamplerAtOutputCoords(\n inputInfo: InputInfo, outShapeInfo: ShapeInfo,\n supportsBroadcasting: boolean) {\n const texName = inputInfo.name;\n const texFuncSnippet = texName.charAt(0).toUpperCase() + texName.slice(1);\n const funcName = 'get' + texFuncSnippet + 'AtOutCoords';\n\n const broadcastDims = broadcast_util.getBroadcastDims(\n inputInfo.shapeInfo.logicalShape, outShapeInfo.logicalShape);\n const inRank = inputInfo.shapeInfo.logicalShape.length;\n const outRank = outShapeInfo.logicalShape.length;\n const doBroadcast =\n supportsBroadcasting && ((outRank > inRank) || broadcastDims.length > 0);\n const broadcastOverOuter =\n broadcast_util.broadcastDimsAreOuter(broadcastDims);\n const isUniform = inputInfo.shapeInfo.isUniform;\n\n if (doBroadcast && !broadcastOverOuter) {\n return getBroadcastOutputCoordsSampler(\n inputInfo, outShapeInfo, texFuncSnippet, funcName);\n }\n\n const inSize = util.sizeFromShape(inputInfo.shapeInfo.logicalShape);\n let broadcastSnippet = '';\n if (doBroadcast && broadcastOverOuter) {\n broadcastSnippet = `\n int mainPart = index / ${inSize};\n index -= mainPart * ${inSize};\n `;\n }\n\n const outTexShape = outShapeInfo.texShape;\n if (isUniform) {\n if (inSize === 1) {\n return `float ${funcName}() {return ${texName};}`;\n }\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n return get${texFuncSnippet}Flat(index);\n }\n `;\n }\n\n // At this point, the input is not a uniform.\n const inTexShape = inputInfo.shapeInfo.texShape;\n if (util.arraysEqual(inTexShape, outTexShape)) {\n return `\n float ${funcName}() {\n return sampleTexture(${texName}, resultUV);\n }\n `;\n }\n\n return `\n float ${funcName}() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(${outTexShape[0]}, ${outTexShape[1]}));\n int index = resTexRC.x * ${outTexShape[1]} + resTexRC.y;\n ${broadcastSnippet}\n int texR = index / ${inTexShape[1]};\n int texC = index - texR * ${inTexShape[1]};\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(${inTexShape[1]}.0, ${inTexShape[0]}.0);\n\n return sampleTexture(${texName}, uv);\n }\n `;\n}\n\nexport function getCoordsDataType(rank: number): string {\n if (rank <= 1) {\n return 'int';\n } else if (rank === 2) {\n return 'ivec2';\n } else if (rank === 3) {\n return 'ivec3';\n } else if (rank === 4) {\n return 'ivec4';\n } else if (rank === 5) {\n return 'ivec5';\n } else if (rank === 6) {\n return 'ivec6';\n } else {\n throw Error(`GPU for rank ${rank} is not yet supported`);\n }\n}\n\n/** Returns a new input info (a copy) that has a squeezed logical shape. */\nfunction squeezeInputInfo(\n inInfo: InputInfo, squeezedShape: number[]): InputInfo {\n // Deep copy.\n const newInputInfo: InputInfo = JSON.parse(JSON.stringify(inInfo));\n newInputInfo.shapeInfo.logicalShape = squeezedShape;\n return newInputInfo;\n}\n\nfunction getSqueezedParams(params: string[], keptDims: number[]): string {\n return keptDims.map(d => params[d]).join(', ');\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class CumSumProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(shape: number[], exclusive: boolean, reverse: boolean) {\n this.outputShape = shape;\n const rank = shape.length;\n const finalDim = shape[shape.length - 1];\n const comparator = reverse ? '<' : '>';\n\n this.userCode = `\n int getIndex(int i) {\n ${reverse ? `return ${finalDim} -i - 1;` : 'return i;'}\n }\n\n void main() {\n ${getCoordsDataType(rank)} coords = getOutputCoords();\n int end = ${getFinalCoord(rank, 'coords')};\n float val = 0.0;\n for (int i = ${finalDim} - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx ${comparator} end) {\n continue;\n }\n if (idx == end && ${exclusive}) {\n continue;\n }\n ${getFinalCoord(rank, 'coords')} = idx;\n val += getX(${getCoords(rank, 'coords')});\n }\n setOutput(val);\n }\n `;\n }\n}\n\nfunction getCoords(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.x, ${name}.y`;\n } else if (rank === 3) {\n return `${name}.x, ${name}.y, ${name}.z`;\n } else if (rank === 4) {\n return `${name}.x, ${name}.y, ${name}.z, ${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n\nfunction getFinalCoord(rank: number, name: string): string {\n if (rank === 1) {\n return `${name}`;\n } else if (rank === 2) {\n return `${name}.y`;\n } else if (rank === 3) {\n return `${name}.z`;\n } else if (rank === 4) {\n return `${name}.w`;\n } else {\n throw Error(`Cumulative sum for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class EncodeFloatProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n this.outputShape = outputShape;\n this.userCode = `\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, DataTypeMap} from '../../types';\n\nexport enum TextureUsage {\n RENDER,\n UPLOAD,\n PIXELS,\n DOWNLOAD\n}\n\nexport enum PhysicalTextureType {\n FLOAT16,\n FLOAT32,\n UNSIGNED_BYTE\n}\n\nexport interface TextureData {\n texture: WebGLTexture;\n shape: number[];\n /** [rows, columns] shape of the texture. */\n texShape: [number, number];\n dtype: DataType;\n values: DataTypeMap[DataType];\n usage: TextureUsage;\n}\n\nexport function getUnpackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns, rows];\n}\n\nexport function getUnpackedArraySizeFromMatrixSize(\n matrixSize: number, channelsPerTexture: number): number {\n return matrixSize * channelsPerTexture;\n}\n\nexport function getColorMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [columns * 4, rows];\n}\n\nexport function getMatrixSizeFromUnpackedArraySize(\n unpackedSize: number, channelsPerTexture: number): number {\n if (unpackedSize % channelsPerTexture !== 0) {\n throw new Error(\n `unpackedSize (${unpackedSize}) must be a multiple of ` +\n `${channelsPerTexture}`);\n }\n return unpackedSize / channelsPerTexture;\n}\n\nexport type TypedArray = Float32Array|Uint8Array;\n\nexport function encodeMatrixToUnpackedArray(\n matrix: TypedArray, unpackedArray: TypedArray, channelsPerTexture: number) {\n const requiredSize =\n getUnpackedArraySizeFromMatrixSize(matrix.length, channelsPerTexture);\n if (unpackedArray.length < requiredSize) {\n throw new Error(\n `unpackedArray length (${unpackedArray.length}) must be >= ` +\n `${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < matrix.length; ++src) {\n unpackedArray[dst] = matrix[src];\n dst += channelsPerTexture;\n }\n}\n\nexport function decodeMatrixFromUnpackedArray(\n unpackedArray: Float32Array, matrix: Float32Array,\n channelsPerTexture: number) {\n const requiredSize = getMatrixSizeFromUnpackedArraySize(\n unpackedArray.length, channelsPerTexture);\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += channelsPerTexture) {\n matrix[dst++] = unpackedArray[src];\n }\n}\n\nexport function decodeMatrixFromUnpackedColorRGBAArray(\n unpackedArray: Float32Array, matrix: Float32Array, channels: number) {\n const requiredSize = unpackedArray.length * channels / 4;\n if (matrix.length < requiredSize) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n let dst = 0;\n for (let src = 0; src < unpackedArray.length; src += 4) {\n for (let c = 0; c < channels; c++) {\n matrix[dst++] = unpackedArray[src + c];\n }\n }\n}\n\nexport function getPackedMatrixTextureShapeWidthHeight(\n rows: number, columns: number): [number, number] {\n return [Math.ceil(columns / 2), Math.ceil(rows / 2)];\n}\n\nexport function getPackedRGBAArraySizeFromMatrixShape(\n rows: number, columns: number): number {\n const [w, h] = getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return w * h * 4;\n}\n\nexport function encodeMatrixToPackedRGBA(\n matrix: Float32Array, rows: number, columns: number,\n packedRGBA: Float32Array) {\n const requiredSize = getPackedRGBAArraySizeFromMatrixShape(rows, columns);\n if (packedRGBA.length < requiredSize) {\n throw new Error(\n `packedRGBA length (${packedRGBA.length}) must be >= ${requiredSize}`);\n }\n /*\n Unpacked matrix, row-major order in Float32Array[16]: A B C D\n E F G H\n I J K L\n M N O P\n\n Packed matrix, 2x2 RGBA32 texture (memory view): ABEF CDGH IJMN KLOP\n\n Packed matrix, 2x2 RGBA32 texture (matrix view): AB|CD\n EF|GH\n --+--\n IJ|KL\n MN|OP\n */\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n\n // loop over full 2x2 blocks\n {\n const dstStride = (oddWidth ? 4 : 0);\n const oneRow = columns;\n let dst = 0;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n const matrixSrcRow = (blockY * 2 * columns);\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n const matrixSrcCol = blockX * 2;\n const src = matrixSrcRow + matrixSrcCol;\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 1] = matrix[src + 1];\n packedRGBA[dst + 2] = matrix[src + oneRow];\n packedRGBA[dst + 3] = matrix[src + oneRow + 1];\n dst += 4;\n }\n dst += dstStride;\n }\n }\n\n // loop down final odd column\n if (oddWidth) {\n let src = columns - 1;\n let dst = (textureWidth - 1) * 4;\n const srcStride = 2 * columns;\n const dstStride = textureWidth * 4;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n packedRGBA[dst] = matrix[src];\n packedRGBA[dst + 2] = matrix[src + columns];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (rows - 1) * columns;\n let dst = (textureHeight - 1) * textureWidth * 4;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n packedRGBA[dst++] = matrix[src++];\n packedRGBA[dst++] = matrix[src++];\n dst += 2;\n }\n }\n\n // fill in bottom-right texel\n if (oddWidth && oddHeight) {\n packedRGBA[packedRGBA.length - 4] = matrix[matrix.length - 1];\n }\n\n return packedRGBA;\n}\n\nexport function decodeMatrixFromPackedRGBA(\n packedRGBA: Float32Array, rows: number, columns: number,\n matrix: Float32Array): Float32Array {\n const requiredSize = rows * columns;\n if (requiredSize < matrix.length) {\n throw new Error(\n `matrix length (${matrix.length}) must be >= ${requiredSize}`);\n }\n const oddWidth = (columns % 2) === 1;\n const oddHeight = (rows % 2) === 1;\n const widthInFullBlocks = Math.floor(columns / 2);\n const heightInFullBlocks = Math.floor(rows / 2);\n const [textureWidth, textureHeight] =\n getPackedMatrixTextureShapeWidthHeight(rows, columns);\n\n // loop over full 2x2 blocks\n {\n const srcStride = oddWidth ? 4 : 0;\n const dstStride = columns + (oddWidth ? 1 : 0);\n let src = 0;\n let dstRow1 = 0;\n let dstRow2 = columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow1++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n matrix[dstRow2++] = packedRGBA[src++];\n }\n src += srcStride;\n dstRow1 += dstStride;\n dstRow2 += dstStride;\n }\n }\n\n // loop down final column\n if (oddWidth) {\n let src = (textureWidth - 1) * 4;\n let dst = columns - 1;\n const srcStride = textureWidth * 4;\n const dstStride = 2 * columns;\n for (let blockY = 0; blockY < heightInFullBlocks; ++blockY) {\n matrix[dst] = packedRGBA[src];\n matrix[dst + columns] = packedRGBA[src + 2];\n src += srcStride;\n dst += dstStride;\n }\n }\n\n // loop across final row\n if (oddHeight) {\n let src = (textureHeight - 1) * textureWidth * 4;\n let dst = (rows - 1) * columns;\n for (let blockX = 0; blockX < widthInFullBlocks; ++blockX) {\n matrix[dst++] = packedRGBA[src++];\n matrix[dst++] = packedRGBA[src++];\n src += 2;\n }\n }\n\n // fill in bottom-right cell\n if (oddWidth && oddHeight) {\n matrix[matrix.length - 1] = packedRGBA[packedRGBA.length - 4];\n }\n\n return matrix;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class FromPixelsProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n constructor(outputShape: number[]) {\n const [height, width, ] = outputShape;\n this.outputShape = outputShape;\n this.userCode = `\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${width}.0, ${height}.0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class GatherProgram implements GPGPUProgram {\n variableNames = ['A', 'indices'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], indicesLength: number, axis: number) {\n const outputShape: number[] = aShape.slice();\n outputShape[axis] = indicesLength;\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape, axis);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[], axis: number): string {\n const rank = aShape.length;\n if (rank > 4) {\n throw Error(`Gather for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `int(getIndices(resRC))`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n if (i === axis) {\n sourceCoords.push(`int(getIndices(${currentCoords[i]}))`);\n } else {\n sourceCoords.push(`${currentCoords[i]}`);\n }\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nlet MAX_TEXTURE_SIZE: number = null;\n\nimport * as util from '../../util';\nimport {ENV} from '../../environment';\n\nexport function createWebGLRenderingContext(attributes: WebGLContextAttributes):\n WebGLRenderingContext {\n const canvas = document.createElement('canvas');\n canvas.width = 1;\n canvas.height = 1;\n return createWebGLRenderingContextFromCanvas(canvas, attributes);\n}\n\nexport function createWebGLRenderingContextFromCanvas(\n canvas: HTMLCanvasElement,\n attributes: WebGLContextAttributes): WebGLRenderingContext {\n let gl: WebGLRenderingContext;\n\n const webglVersion = ENV.get('WEBGL_VERSION');\n if (webglVersion === 2) {\n gl = canvas.getContext('webgl2', attributes) as WebGLRenderingContext;\n } else if (webglVersion === 1) {\n gl = (canvas.getContext('webgl', attributes) ||\n canvas.getContext('experimental-webgl', attributes)) as\n WebGLRenderingContext;\n }\n\n if (webglVersion === 0 || gl == null) {\n throw new Error('This browser does not support WebGL.');\n }\n return gl;\n}\n\nexport function callAndCheck(gl: WebGLRenderingContext, func: () => T): T {\n const returnValue = func();\n checkWebGLError(gl);\n return returnValue;\n}\n\nlet webGLDebugErrorCheckingEnabled = false;\n\nexport function enableDebugWebGLErrorChecking(enabled: boolean) {\n webGLDebugErrorCheckingEnabled = enabled;\n}\n\nexport function checkWebGLError(gl: WebGLRenderingContext) {\n if (webGLDebugErrorCheckingEnabled) {\n const error = gl.getError();\n if (error !== gl.NO_ERROR) {\n throw new Error('WebGL Error: ' + getWebGLErrorMessage(gl, error));\n }\n }\n}\n\nexport function getWebGLErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.NO_ERROR:\n return 'NO_ERROR';\n case gl.INVALID_ENUM:\n return 'INVALID_ENUM';\n case gl.INVALID_VALUE:\n return 'INVALID_VALUE';\n case gl.INVALID_OPERATION:\n return 'INVALID_OPERATION';\n case gl.INVALID_FRAMEBUFFER_OPERATION:\n return 'INVALID_FRAMEBUFFER_OPERATION';\n case gl.OUT_OF_MEMORY:\n return 'OUT_OF_MEMORY';\n case gl.CONTEXT_LOST_WEBGL:\n return 'CONTEXT_LOST_WEBGL';\n default:\n return `Unknown error code ${status}`;\n }\n}\n\nexport function getExtensionOrThrow(\n gl: WebGLRenderingContext, extensionName: string): {} {\n return throwIfNull<{}>(\n gl, () => gl.getExtension(extensionName),\n 'Extension \"' + extensionName + '\" not supported on this browser.');\n}\n\nexport function createVertexShader(\n gl: WebGLRenderingContext, vertexShaderSource: string): WebGLShader {\n const vertexShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.VERTEX_SHADER),\n 'Unable to create vertex WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(vertexShader, vertexShaderSource));\n callAndCheck(gl, () => gl.compileShader(vertexShader));\n if (gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS) === false) {\n console.log(gl.getShaderInfoLog(vertexShader));\n throw new Error('Failed to compile vertex shader.');\n }\n return vertexShader;\n}\n\nexport function createFragmentShader(\n gl: WebGLRenderingContext, fragmentShaderSource: string): WebGLShader {\n const fragmentShader: WebGLShader = throwIfNull(\n gl, () => gl.createShader(gl.FRAGMENT_SHADER),\n 'Unable to create fragment WebGLShader.');\n callAndCheck(gl, () => gl.shaderSource(fragmentShader, fragmentShaderSource));\n callAndCheck(gl, () => gl.compileShader(fragmentShader));\n if (gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS) === false) {\n logShaderSourceAndInfoLog(\n fragmentShaderSource, gl.getShaderInfoLog(fragmentShader));\n throw new Error('Failed to compile fragment shader.');\n }\n return fragmentShader;\n}\n\nconst lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g;\nfunction logShaderSourceAndInfoLog(\n shaderSource: string, shaderInfoLog: string) {\n const lineNumberRegexResult = lineNumberRegex.exec(shaderInfoLog);\n if (lineNumberRegexResult == null) {\n console.log(`Couldn't parse line number in error: ${shaderInfoLog}`);\n console.log(shaderSource);\n return;\n }\n\n const lineNumber = +lineNumberRegexResult[1];\n\n const shaderLines = shaderSource.split('\\n');\n const pad = shaderLines.length.toString().length + 2;\n const linesWithLineNumbers = shaderLines.map(\n (line, lineNumber) =>\n util.rightPad((lineNumber + 1).toString(), pad) + line);\n let maxLineLength = 0;\n for (let i = 0; i < linesWithLineNumbers.length; i++) {\n maxLineLength = Math.max(linesWithLineNumbers[i].length, maxLineLength);\n }\n\n const beforeErrorLines = linesWithLineNumbers.slice(0, lineNumber - 1);\n const errorLine = linesWithLineNumbers.slice(lineNumber - 1, lineNumber);\n const afterErrorLines = linesWithLineNumbers.slice(lineNumber);\n\n console.log(beforeErrorLines.join('\\n'));\n console.log(shaderInfoLog.split('\\n')[0]);\n console.log(\n `%c ${util.rightPad(errorLine[0], maxLineLength)}`,\n 'border:1px solid red; background-color:#e3d2d2; color:#a61717');\n console.log(afterErrorLines.join('\\n'));\n}\n\nexport function createProgram(gl: WebGLRenderingContext): WebGLProgram {\n return throwIfNull(\n gl, () => gl.createProgram(), 'Unable to create WebGLProgram.');\n}\n\nexport function linkProgram(gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.linkProgram(program));\n if (gl.getProgramParameter(program, gl.LINK_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Failed to link vertex and fragment shaders.');\n }\n}\n\nexport function validateProgram(\n gl: WebGLRenderingContext, program: WebGLProgram) {\n callAndCheck(gl, () => gl.validateProgram(program));\n if (gl.getProgramParameter(program, gl.VALIDATE_STATUS) === false) {\n console.log(gl.getProgramInfoLog(program));\n throw new Error('Shader program validation failed.');\n }\n}\n\nexport function createStaticVertexBuffer(\n gl: WebGLRenderingContext, data: Float32Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(gl, () => gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function createStaticIndexBuffer(\n gl: WebGLRenderingContext, data: Uint16Array): WebGLBuffer {\n const buffer: WebGLBuffer = throwIfNull(\n gl, () => gl.createBuffer(), 'Unable to create WebGLBuffer');\n callAndCheck(gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, buffer));\n callAndCheck(\n gl, () => gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, data, gl.STATIC_DRAW));\n return buffer;\n}\n\nexport function queryMaxTextureSize(gl: WebGLRenderingContext): number {\n if (MAX_TEXTURE_SIZE != null) {\n return MAX_TEXTURE_SIZE;\n }\n MAX_TEXTURE_SIZE =\n callAndCheck(gl, () => gl.getParameter(gl.MAX_TEXTURE_SIZE));\n return MAX_TEXTURE_SIZE;\n}\n\nexport function getNumChannels(): number {\n if (ENV.get('WEBGL_VERSION') === 2) {\n return 1;\n }\n return 4;\n}\n\nexport function createTexture(gl: WebGLRenderingContext): WebGLTexture {\n return throwIfNull(\n gl, () => gl.createTexture(), 'Unable to create WebGLTexture.');\n}\n\nexport function validateTextureSize(\n gl: WebGLRenderingContext, width: number, height: number) {\n const maxTextureSize: number = queryMaxTextureSize(gl);\n if ((width <= 0) || (height <= 0)) {\n const requested = `[${width}x${height}]`;\n throw new Error('Requested texture size ' + requested + ' is invalid.');\n }\n if ((width > maxTextureSize) || (height > maxTextureSize)) {\n const requested = `[${width}x${height}]`;\n const max = `[${maxTextureSize}x${maxTextureSize}]`;\n throw new Error(\n 'Requested texture size ' + requested +\n ' greater than WebGL maximum on this browser / GPU ' + max + '.');\n }\n}\n\nexport function createFramebuffer(gl: WebGLRenderingContext): WebGLFramebuffer {\n return throwIfNull(\n gl, () => gl.createFramebuffer(), 'Unable to create WebGLFramebuffer.');\n}\n\nexport function bindVertexBufferToProgramAttribute(\n gl: WebGLRenderingContext, program: WebGLProgram, attribute: string,\n buffer: WebGLBuffer, arrayEntriesPerItem: number, itemStrideInBytes: number,\n itemOffsetInBytes: number): boolean {\n const loc = gl.getAttribLocation(program, attribute);\n if (loc === -1) {\n // The GPU compiler decided to strip out this attribute because it's unused,\n // thus no need to bind.\n return false;\n }\n callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, buffer));\n callAndCheck(\n gl,\n () => gl.vertexAttribPointer(\n loc, arrayEntriesPerItem, gl.FLOAT, false, itemStrideInBytes,\n itemOffsetInBytes));\n callAndCheck(gl, () => gl.enableVertexAttribArray(loc));\n return true;\n}\n\nexport function bindTextureUnit(\n gl: WebGLRenderingContext, texture: WebGLTexture, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n}\n\nexport function unbindTextureUnit(\n gl: WebGLRenderingContext, textureUnit: number) {\n validateTextureUnit(gl, textureUnit);\n callAndCheck(gl, () => gl.activeTexture(gl.TEXTURE0 + textureUnit));\n callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function getProgramUniformLocationOrThrow(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return throwIfNull(\n gl, () => gl.getUniformLocation(program, uniformName),\n 'uniform \"' + uniformName + '\" not present in program.');\n}\n\nexport function getProgramUniformLocation(\n gl: WebGLRenderingContext, program: WebGLProgram,\n uniformName: string): WebGLUniformLocation {\n return gl.getUniformLocation(program, uniformName);\n}\n\nexport function bindTextureToProgramUniformSampler(\n gl: WebGLRenderingContext, program: WebGLProgram, texture: WebGLTexture,\n uniformSamplerLocation: WebGLUniformLocation, textureUnit: number) {\n callAndCheck(gl, () => bindTextureUnit(gl, texture, textureUnit));\n callAndCheck(gl, () => gl.uniform1i(uniformSamplerLocation, textureUnit));\n}\n\nexport function bindCanvasToFramebuffer(gl: WebGLRenderingContext) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n callAndCheck(gl, () => gl.viewport(0, 0, gl.canvas.width, gl.canvas.height));\n callAndCheck(gl, () => gl.scissor(0, 0, gl.canvas.width, gl.canvas.height));\n}\n\nexport function bindColorTextureToFramebuffer(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0));\n}\n\nexport function unbindColorTextureFromFramebuffer(\n gl: WebGLRenderingContext, framebuffer: WebGLFramebuffer) {\n callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer));\n callAndCheck(\n gl,\n () => gl.framebufferTexture2D(\n gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, null, 0));\n}\n\nexport function validateFramebuffer(gl: WebGLRenderingContext) {\n const status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n if (status !== gl.FRAMEBUFFER_COMPLETE) {\n throw new Error(\n 'Error binding framebuffer: ' + getFramebufferErrorMessage(gl, status));\n }\n}\n\nexport function getFramebufferErrorMessage(\n gl: WebGLRenderingContext, status: number): string {\n switch (status) {\n case gl.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:\n return 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT';\n case gl.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:\n return 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS';\n case gl.FRAMEBUFFER_UNSUPPORTED:\n return 'FRAMEBUFFER_UNSUPPORTED';\n default:\n return `unknown error ${status}`;\n }\n}\n\nfunction throwIfNull(\n gl: WebGLRenderingContext, returnTOrNull: () => T | null,\n failureMessage: string): T {\n const tOrNull: T|null = callAndCheck(gl, () => returnTOrNull());\n if (tOrNull == null) {\n throw new Error(failureMessage);\n }\n return tOrNull as T;\n}\n\nfunction validateTextureUnit(gl: WebGLRenderingContext, textureUnit: number) {\n const maxTextureUnit = gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1;\n const glTextureUnit = textureUnit + gl.TEXTURE0;\n if (glTextureUnit < gl.TEXTURE0 || glTextureUnit > maxTextureUnit) {\n const textureUnitRange = `[gl.TEXTURE0, gl.TEXTURE${maxTextureUnit}]`;\n throw new Error(`textureUnit must be in ${textureUnitRange}.`);\n }\n}\n\nexport function getTextureShapeFromLogicalShape(\n gl: WebGLRenderingContext, logShape: number[]): [number, number] {\n // If logical shape is 2, we don't squeeze, since we want to match physical.\n if (logShape.length !== 2) {\n const squeezeResult = util.squeezeShape(logShape);\n logShape = squeezeResult.newShape;\n }\n\n const maxTexSize = queryMaxTextureSize(gl);\n const size = util.sizeFromShape(logShape);\n if (logShape.length <= 1 && size <= maxTexSize) {\n return [size, 1];\n } else if (\n logShape.length === 2 && logShape[0] <= maxTexSize &&\n logShape[1] <= maxTexSize) {\n return logShape as [number, number];\n } else if (\n logShape.length === 3 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2]];\n } else if (\n logShape.length === 4 && logShape[0] <= maxTexSize &&\n logShape[1] * logShape[2] * logShape[3] <= maxTexSize) {\n return [logShape[0], logShape[1] * logShape[2] * logShape[3]];\n } else {\n return util.sizeToSquarishShape(size);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport * as tex_util from './tex_util';\nimport * as webgl_util from './webgl_util';\n\nexport function getWebGLContextAttributes(): WebGLContextAttributes {\n return {\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: true\n };\n}\n\nexport interface TextureConfig {\n internalFormatFloat: number;\n textureFormatFloat: number;\n internalFormatHalfFloat: number;\n internalFormatPackedFloat: number;\n\n // The format to use during a gl.readPixels call.\n downloadTextureFormat: number;\n // How many channels need to be unpacked after a gl.readPixels call.\n downloadUnpackNumChannels: number;\n\n defaultNumChannels: number;\n textureTypeHalfFloat: number;\n}\n\nexport function createWebGLContext(canvas?: HTMLCanvasElement) {\n const attributes = getWebGLContextAttributes();\n let gl: WebGLRenderingContext;\n if (canvas != null) {\n gl = webgl_util.createWebGLRenderingContextFromCanvas(canvas, attributes);\n } else {\n gl = webgl_util.createWebGLRenderingContext(attributes);\n }\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DEPTH_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.STENCIL_TEST));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.BLEND));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.DITHER));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.POLYGON_OFFSET_FILL));\n webgl_util.callAndCheck(gl, () => gl.disable(gl.SAMPLE_COVERAGE));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.SCISSOR_TEST));\n webgl_util.callAndCheck(gl, () => gl.enable(gl.CULL_FACE));\n webgl_util.callAndCheck(gl, () => gl.cullFace(gl.BACK));\n\n return gl;\n}\n\nexport function createVertexShader(gl: WebGLRenderingContext): WebGLShader {\n const vertexShaderSource = `\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }`;\n return webgl_util.createVertexShader(gl, vertexShaderSource);\n}\n\nexport function createVertexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // [x y z u v] * [upper-left, lower-left, upper-right, lower-right]\n const vertexArray = new Float32Array(\n [-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]);\n return webgl_util.createStaticVertexBuffer(gl, vertexArray);\n}\n\nexport function createIndexBuffer(gl: WebGLRenderingContext): WebGLBuffer {\n // OpenGL (and WebGL) have \"CCW == front\" winding\n const triangleVertexIndices = new Uint16Array([0, 1, 2, 2, 1, 3]);\n return webgl_util.createStaticIndexBuffer(gl, triangleVertexIndices);\n}\n\nexport function getTextureConfig(\n // tslint:disable-next-line:no-any\n gl: WebGLRenderingContext, textureHalfFloatExtension?: any): TextureConfig {\n // tslint:disable-next-line:no-any\n const glany = gl as any;\n\n let internalFormatFloat: number;\n let internalFormatHalfFloat: number;\n let internalFormatPackedFloat: number;\n let textureFormatFloat: number;\n\n let downloadTextureFormat: number;\n let downloadUnpackNumChannels: number;\n\n let defaultNumChannels: number;\n let textureTypeHalfFloat: number;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n internalFormatFloat = glany.R32F;\n internalFormatHalfFloat = glany.R16F;\n internalFormatPackedFloat = glany.RGBA32F;\n textureFormatFloat = glany.RED;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 1;\n textureTypeHalfFloat = glany.HALF_FLOAT;\n } else {\n internalFormatFloat = gl.RGBA;\n internalFormatHalfFloat = gl.RGBA;\n internalFormatPackedFloat = glany.RGBA;\n textureFormatFloat = gl.RGBA;\n downloadUnpackNumChannels = 4;\n defaultNumChannels = 4;\n textureTypeHalfFloat = textureHalfFloatExtension != null ?\n textureHalfFloatExtension.HALF_FLOAT_OES :\n null;\n }\n downloadTextureFormat = gl.RGBA;\n\n return {\n internalFormatFloat,\n internalFormatHalfFloat,\n internalFormatPackedFloat,\n textureFormatFloat,\n downloadTextureFormat,\n downloadUnpackNumChannels,\n defaultNumChannels,\n textureTypeHalfFloat\n };\n}\n\nfunction createAndConfigureTexture(\n gl: WebGLRenderingContext, width: number, height: number,\n internalFormat: number, textureFormat: number,\n textureType: number): WebGLTexture {\n webgl_util.validateTextureSize(gl, width, height);\n const texture = webgl_util.createTexture(gl);\n\n const tex2d = gl.TEXTURE_2D;\n webgl_util.callAndCheck(gl, () => gl.bindTexture(tex2d, texture));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MIN_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl, () => gl.texParameteri(tex2d, gl.TEXTURE_MAG_FILTER, gl.NEAREST));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n tex2d, 0, internalFormat, width, height, 0, textureFormat,\n textureType, null));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n return texture;\n}\n\nexport function createFloat32MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, gl.FLOAT);\n}\n\nexport function createFloat16MatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatFloat,\n textureConfig.textureFormatFloat, textureConfig.textureTypeHalfFloat);\n}\n\nexport function createUnsignedBytesMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE);\n}\n\nexport function createPackedMatrixTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): WebGLTexture {\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n return createAndConfigureTexture(\n gl, width, height, textureConfig.internalFormatPackedFloat, gl.RGBA,\n gl.FLOAT);\n}\n\nexport function bindVertexProgramAttributeStreams(\n gl: WebGLRenderingContext, program: WebGLProgram,\n vertexBuffer: WebGLBuffer): boolean {\n const posOffset = 0; // x is the first buffer element\n const uvOffset = 3 * 4; // uv comes after [x y z]\n const stride = (3 * 4) + (2 * 4); // xyz + uv, each entry is 4-byte float.\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer));\n const success = webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'clipSpacePos', vertexBuffer, 3, stride, posOffset);\n return success &&\n webgl_util.bindVertexBufferToProgramAttribute(\n gl, program, 'uv', vertexBuffer, 2, stride, uvOffset);\n}\n\nexport function uploadPixelDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement) {\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texImage2D(\n gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, pixels));\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nfunction uploadDataToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, width: number,\n height: number, data: Float32Array, textureFormat: number) {\n webgl_util.validateTextureSize(gl, width, height);\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, texture));\n webgl_util.callAndCheck(\n gl,\n () => gl.texSubImage2D(\n gl.TEXTURE_2D, 0, 0, 0, width, height, textureFormat, gl.FLOAT,\n data));\n\n webgl_util.callAndCheck(gl, () => gl.bindTexture(gl.TEXTURE_2D, null));\n}\n\nexport function uploadMatrixToTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, numChannels: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n let unpackedArray: Float32Array;\n if (textureConfig.defaultNumChannels === 1) {\n // No need to allocate a temporary array.\n unpackedArray = matrix;\n } else {\n unpackedArray =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n matrix.length, numChannels));\n tex_util.encodeMatrixToUnpackedArray(matrix, unpackedArray, numChannels);\n }\n\n uploadDataToTexture(\n gl, texture, w, h, unpackedArray, textureConfig.textureFormatFloat);\n}\n\nexport function uploadMatrixToPackedTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, matrix: Float32Array, textureConfig: TextureConfig) {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n tex_util.encodeMatrixToPackedRGBA(matrix, rows, columns, packedRGBA);\n uploadDataToTexture(gl, texture, w, h, packedRGBA, gl.RGBA);\n}\n\nexport function maybeCreateBufferFromOutputTexture(\n gl: WebGLRenderingContext, texture: WebGLTexture, rows: number,\n columns: number, textureConfig: TextureConfig): WebGLBuffer|WebGLTexture {\n let bufferOrTexture: WebGLBuffer|WebGLTexture = texture;\n\n if (ENV.get('WEBGL_VERSION') === 2) {\n const gl2 = gl as WebGL2RenderingContext;\n\n // Create and bind the buffer.\n const buffer = gl2.createBuffer();\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, buffer));\n\n // Initialize the buffer to the size of the texture in bytes.\n const bytesPerFloat = 4;\n const bufferSizeBytes = bytesPerFloat *\n tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels);\n\n webgl_util.callAndCheck(\n gl,\n () => gl.bufferData(\n gl2.PIXEL_PACK_BUFFER, bufferSizeBytes, gl.STATIC_DRAW));\n\n // Enqueue a command on the GPU command queue to copy of texture into the\n // buffer.\n webgl_util.callAndCheck(\n gl, () => gl2.readPixels(0, 0, columns, rows, gl.RGBA, gl.FLOAT, 0));\n\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl2.PIXEL_PACK_BUFFER, null));\n\n bufferOrTexture = buffer;\n }\n\n return bufferOrTexture;\n}\n\nexport function downloadFloat32MatrixFromBuffer(\n gl: WebGLRenderingContext, buffer: WebGLBuffer, rows: number,\n columns: number, textureConfig: TextureConfig): Float32Array {\n const gl2 = gl as WebGL2RenderingContext;\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n gl2.bindBuffer(gl.ARRAY_BUFFER, buffer);\n gl2.getBufferSubData(gl.ARRAY_BUFFER, 0, downloadTarget);\n gl2.bindBuffer(gl.ARRAY_BUFFER, null);\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n\n return matrix;\n}\n\nexport function downloadFloat32MatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const downloadTarget =\n new Float32Array(tex_util.getUnpackedArraySizeFromMatrixSize(\n rows * columns, textureConfig.downloadUnpackNumChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.FLOAT,\n downloadTarget));\n\n const matrix = new Float32Array(rows * columns);\n tex_util.decodeMatrixFromUnpackedArray(\n downloadTarget as Float32Array, matrix,\n textureConfig.downloadUnpackNumChannels);\n return matrix;\n}\n\nexport function downloadByteEncodedFloatMatrixFromOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig) {\n const [w, h] =\n tex_util.getUnpackedMatrixTextureShapeWidthHeight(rows, columns);\n\n const numChannels = 4;\n const downloadTarget = new Uint8Array(\n tex_util.getUnpackedArraySizeFromMatrixSize(rows * columns, numChannels));\n\n webgl_util.callAndCheck(\n gl,\n () => gl.readPixels(\n 0, 0, w, h, textureConfig.downloadTextureFormat, gl.UNSIGNED_BYTE,\n downloadTarget));\n\n // By wrapping the buffer in a Float32Array, we use native browser IEEE 754\n // decoding of the 4 bytes that back each 32 bit float.\n return new Float32Array(downloadTarget.buffer);\n}\n\nexport function downloadMatrixFromPackedOutputTexture(\n gl: WebGLRenderingContext, rows: number, columns: number,\n textureConfig: TextureConfig): Float32Array {\n const [w, h] = tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n const packedRGBA = new Float32Array(\n tex_util.getPackedRGBAArraySizeFromMatrixShape(rows, columns));\n webgl_util.callAndCheck(\n gl, () => gl.readPixels(0, 0, w, h, gl.RGBA, gl.FLOAT, packedRGBA));\n const matrix = new Float32Array(rows * columns);\n return tex_util.decodeMatrixFromPackedRGBA(packedRGBA, rows, columns, matrix);\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\nimport * as util from '../../util';\nimport * as gpgpu_util from './gpgpu_util';\nimport {TextureConfig} from './gpgpu_util';\nimport * as tex_util from './tex_util';\nimport {WebGL1DisjointQueryTimerExtension, WebGL2DisjointQueryTimerExtension} from './webgl_types';\nimport * as webgl_util from './webgl_util';\n\nexport interface FenceContext {\n query: WebGLQuery|WebGLSync;\n isFencePassed(): boolean;\n}\n\nexport class GPGPUContext {\n gl: WebGLRenderingContext;\n textureFloatExtension: {};\n textureHalfFloatExtension: {};\n colorBufferFloatExtension: {};\n colorBufferHalfFloatExtension: {};\n getBufferSubDataAsyncExtension: {};\n loseContextExtension: WebGLLoseContext;\n disjointQueryTimerExtension: WebGL2DisjointQueryTimerExtension|\n WebGL1DisjointQueryTimerExtension;\n vertexBuffer: WebGLBuffer;\n indexBuffer: WebGLBuffer;\n framebuffer: WebGLFramebuffer;\n outputTexture: WebGLTexture|null = null;\n program: WebGLProgram|null = null;\n private disposed = false;\n private autoDebugValidate = false;\n private disjoint: boolean;\n\n private textureConfig: TextureConfig;\n\n constructor(gl?: WebGLRenderingContext) {\n if (gl != null) {\n this.gl = gl;\n } else {\n this.gl = gpgpu_util.createWebGLContext();\n }\n // WebGL 2.0 enables texture floats without an extension.\n if (ENV.get('WEBGL_VERSION') === 1) {\n this.textureFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_float');\n this.colorBufferFloatExtension =\n this.gl.getExtension('WEBGL_color_buffer_float');\n\n if (!ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n this.textureHalfFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'OES_texture_half_float');\n this.colorBufferHalfFloatExtension =\n this.gl.getExtension('EXT_color_buffer_half_float');\n }\n } else {\n this.colorBufferFloatExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'EXT_color_buffer_float');\n }\n\n this.loseContextExtension =\n webgl_util.getExtensionOrThrow(this.gl, 'WEBGL_lose_context') as\n WebGLLoseContext;\n\n this.vertexBuffer = gpgpu_util.createVertexBuffer(this.gl);\n this.indexBuffer = gpgpu_util.createIndexBuffer(this.gl);\n this.framebuffer = webgl_util.createFramebuffer(this.gl);\n\n this.textureConfig =\n gpgpu_util.getTextureConfig(this.gl, this.textureHalfFloatExtension);\n }\n\n public dispose() {\n if (this.disposed) {\n return;\n }\n if (this.program != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound WebGLProgram.' +\n ' This is probably a resource leak, delete the program with ' +\n 'GPGPUContext.deleteProgram before disposing.');\n }\n if (this.outputTexture != null) {\n console.warn(\n 'Disposing a GPGPUContext that still has a bound output matrix ' +\n 'texture. This is probably a resource leak, delete the output ' +\n 'matrix texture with GPGPUContext.deleteMatrixTexture before ' +\n 'disposing.');\n }\n const gl = this.gl;\n webgl_util.callAndCheck(gl, () => gl.finish());\n webgl_util.callAndCheck(gl, () => gl.bindFramebuffer(gl.FRAMEBUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteFramebuffer(this.framebuffer));\n webgl_util.callAndCheck(gl, () => gl.bindBuffer(gl.ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.vertexBuffer));\n webgl_util.callAndCheck(\n gl, () => gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null));\n webgl_util.callAndCheck(gl, () => gl.deleteBuffer(this.indexBuffer));\n this.loseContextExtension.loseContext();\n this.disposed = true;\n }\n\n public enableAutomaticDebugValidation(enabled: boolean) {\n this.autoDebugValidate = enabled;\n webgl_util.enableDebugWebGLErrorChecking(enabled);\n }\n\n public createFloat32MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat32MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createFloat16MatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createFloat16MatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public createUnsignedBytesMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createUnsignedBytesMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public uploadPixelDataToTexture(\n texture: WebGLTexture,\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement) {\n this.throwIfDisposed();\n gpgpu_util.uploadPixelDataToTexture(this.gl, texture, pixels);\n }\n\n public createPackedMatrixTexture(rows: number, columns: number):\n WebGLTexture {\n this.throwIfDisposed();\n return gpgpu_util.createPackedMatrixTexture(\n this.gl, rows, columns, this.textureConfig);\n }\n\n public deleteMatrixTexture(texture: WebGLTexture) {\n this.throwIfDisposed();\n if (this.outputTexture === texture) {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n this.outputTexture = null;\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteTexture(texture));\n }\n\n public uploadMatrixToTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n const numChannels = webgl_util.getNumChannels();\n return gpgpu_util.uploadMatrixToTexture(\n this.gl, texture, rows, columns, matrix, numChannels,\n this.textureConfig);\n }\n\n public uploadMatrixToPackedTexture(\n texture: WebGLTexture, rows: number, columns: number,\n matrix: Float32Array) {\n this.throwIfDisposed();\n return gpgpu_util.uploadMatrixToPackedTexture(\n this.gl, texture, rows, columns, matrix, this.textureConfig);\n }\n\n public downloadFloat32MatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadFloat32MatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadByteEncodedFloatMatrixFromOutputTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n public downloadFloat32MatrixFromBuffer(\n buffer: WebGLBuffer, rows: number, columns: number): Float32Array {\n return gpgpu_util.downloadFloat32MatrixFromBuffer(\n this.gl, buffer, rows, columns, this.textureConfig);\n }\n\n public maybeCreateBufferFromTexture(\n texture: WebGLTexture, rows: number, columns: number): WebGLBuffer\n |WebGLTexture {\n this.bindTextureToFrameBuffer(texture);\n const result = gpgpu_util.maybeCreateBufferFromOutputTexture(\n this.gl, texture, rows, columns, this.textureConfig);\n this.unbindTextureToFrameBuffer();\n return result;\n }\n\n public createAndWaitForFence(): Promise {\n const fenceContext = this.createFence(this.gl);\n return this.pollFence(fenceContext);\n }\n\n private createFence(gl: WebGLRenderingContext): FenceContext {\n let query: WebGLQuery|WebGLSync;\n let isFencePassed: () => boolean;\n\n if (ENV.get('WEBGL_FENCE_API_ENABLED')) {\n const gl2 = gl as WebGL2RenderingContext;\n\n const sync = gl2.fenceSync(gl2.SYNC_GPU_COMMANDS_COMPLETE, 0);\n gl.flush();\n\n isFencePassed = () => {\n const status = gl2.clientWaitSync(sync, 0, 0);\n return status === gl2.ALREADY_SIGNALED ||\n status === gl2.CONDITION_SATISFIED;\n };\n\n query = sync;\n } else if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n query = this.beginQuery();\n this.endQuery();\n isFencePassed = () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n } else {\n // If we have no way to fence, return true immediately. This will fire in\n // WebGL 1.0 when there is no disjoint query timer. In this case, because\n // the fence passes immediately, we'll immediately ask for a download of\n // the texture, which will cause the UI thread to hang.\n isFencePassed = () => true;\n }\n\n return {query, isFencePassed};\n }\n\n public downloadMatrixFromPackedTexture(\n texture: WebGLTexture, rows: number, columns: number): Float32Array {\n return this.downloadMatrixDriver(\n texture,\n () => gpgpu_util.downloadMatrixFromPackedOutputTexture(\n this.gl, rows, columns, this.textureConfig));\n }\n\n private vertexAttrsAreBound = false;\n\n public createProgram(fragmentShaderSource: string): WebGLProgram {\n this.throwIfDisposed();\n const gl = this.gl;\n const fragmentShader: WebGLShader =\n webgl_util.createFragmentShader(gl, fragmentShaderSource);\n const vertexShader: WebGLShader = gpgpu_util.createVertexShader(gl);\n const program: WebGLProgram = webgl_util.createProgram(gl);\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, vertexShader));\n webgl_util.callAndCheck(gl, () => gl.attachShader(program, fragmentShader));\n webgl_util.linkProgram(gl, program);\n if (this.autoDebugValidate) {\n webgl_util.validateProgram(gl, program);\n }\n if (!this.vertexAttrsAreBound) {\n this.setProgram(program);\n this.vertexAttrsAreBound = gpgpu_util.bindVertexProgramAttributeStreams(\n gl, this.program, this.vertexBuffer);\n }\n return program;\n }\n\n public deleteProgram(program: WebGLProgram) {\n this.throwIfDisposed();\n if (program === this.program) {\n this.program = null;\n }\n if (program != null) {\n webgl_util.callAndCheck(this.gl, () => this.gl.deleteProgram(program));\n }\n }\n\n public setProgram(program: WebGLProgram|null) {\n this.throwIfDisposed();\n this.program = program;\n if ((this.program != null) && this.autoDebugValidate) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.callAndCheck(this.gl, () => this.gl.useProgram(program));\n }\n\n public getUniformLocation(\n program: WebGLProgram, uniformName: string,\n shouldThrow = true): WebGLUniformLocation {\n this.throwIfDisposed();\n if (shouldThrow) {\n return webgl_util.getProgramUniformLocationOrThrow(\n this.gl, program, uniformName);\n } else {\n return webgl_util.getProgramUniformLocation(\n this.gl, program, uniformName);\n }\n }\n\n public getAttributeLocation(program: WebGLProgram, attribute: string):\n number {\n this.throwIfDisposed();\n return webgl_util.callAndCheck(\n this.gl, () => this.gl.getAttribLocation(program, attribute));\n }\n\n public getUniformLocationNoThrow(program: WebGLProgram, uniformName: string):\n WebGLUniformLocation {\n this.throwIfDisposed();\n return this.gl.getUniformLocation(program, uniformName);\n }\n\n public setInputMatrixTexture(\n inputMatrixTexture: WebGLTexture, uniformLocation: WebGLUniformLocation,\n textureUnit: number) {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n webgl_util.bindTextureToProgramUniformSampler(\n this.gl, this.program, inputMatrixTexture, uniformLocation,\n textureUnit);\n }\n\n public setOutputMatrixTexture(\n outputMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.setOutputMatrixTextureDriver(outputMatrixTexture, columns, rows);\n }\n\n public setOutputPackedMatrixTexture(\n outputPackedMatrixTexture: WebGLTexture, rows: number, columns: number) {\n this.throwIfDisposed();\n const [width, height] =\n tex_util.getPackedMatrixTextureShapeWidthHeight(rows, columns);\n this.setOutputMatrixTextureDriver(outputPackedMatrixTexture, width, height);\n }\n\n public setOutputMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n this.setOutputMatrixWriteRegionDriver(\n startColumn, startRow, numColumns, numRows);\n }\n\n public setOutputPackedMatrixWriteRegion(\n startRow: number, numRows: number, startColumn: number,\n numColumns: number) {\n throw new Error('setOutputPackedMatrixWriteRegion not implemented.');\n }\n\n public debugValidate() {\n if (this.program != null) {\n webgl_util.validateProgram(this.gl, this.program);\n }\n webgl_util.validateFramebuffer(this.gl);\n }\n\n public executeProgram() {\n this.throwIfDisposed();\n this.throwIfNoProgram();\n const gl = this.gl;\n if (this.autoDebugValidate) {\n this.debugValidate();\n }\n webgl_util.callAndCheck(\n gl, () => gl.drawElements(gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0));\n }\n\n public blockUntilAllProgramsCompleted() {\n this.throwIfDisposed();\n webgl_util.callAndCheck(this.gl, () => this.gl.finish());\n }\n\n private getQueryTimerExtension(): WebGL1DisjointQueryTimerExtension\n |WebGL2DisjointQueryTimerExtension {\n if (this.disjointQueryTimerExtension == null) {\n this.disjointQueryTimerExtension =\n webgl_util.getExtensionOrThrow(\n this.gl,\n ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2 ?\n 'EXT_disjoint_timer_query_webgl2' :\n 'EXT_disjoint_timer_query') as\n WebGL1DisjointQueryTimerExtension |\n WebGL2DisjointQueryTimerExtension;\n }\n return this.disjointQueryTimerExtension;\n }\n\n private getQueryTimerExtensionWebGL2(): WebGL2DisjointQueryTimerExtension {\n return this.getQueryTimerExtension();\n }\n\n private getQueryTimerExtensionWebGL1(): WebGL1DisjointQueryTimerExtension {\n return this.getQueryTimerExtension() as WebGL1DisjointQueryTimerExtension;\n }\n\n beginQuery(): WebGLQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const query = gl2.createQuery();\n gl2.beginQuery(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n const query = ext.createQueryEXT();\n ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, query);\n return query;\n }\n\n endQuery() {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n gl2.endQuery(ext.TIME_ELAPSED_EXT);\n return;\n }\n const ext = this.getQueryTimerExtensionWebGL1();\n ext.endQueryEXT(ext.TIME_ELAPSED_EXT);\n }\n\n public async waitForQueryAndGetTime(query: WebGLQuery): Promise {\n await util.repeatedTry(\n () => this.isQueryAvailable(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION')));\n return this.getQueryTime(\n query, ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION'));\n }\n\n private getQueryTime(query: WebGLQuery, queryTimerVersion: number): number {\n if (queryTimerVersion === 0) {\n return null;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n\n const timeElapsedNanos = gl2.getQueryParameter(query, gl2.QUERY_RESULT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const timeElapsedNanos =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_EXT);\n // Return milliseconds.\n return timeElapsedNanos / 1000000;\n }\n }\n\n private isQueryAvailable(query: WebGLQuery, queryTimerVersion: number):\n boolean {\n if (queryTimerVersion === 0) {\n return true;\n }\n\n if (queryTimerVersion === 2) {\n const gl2 = this.gl as WebGL2RenderingContext;\n const ext = this.getQueryTimerExtensionWebGL2();\n\n const available =\n gl2.getQueryParameter(query, gl2.QUERY_RESULT_AVAILABLE);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n } else {\n const ext = this.getQueryTimerExtensionWebGL1();\n\n const available =\n ext.getQueryObjectEXT(query, ext.QUERY_RESULT_AVAILABLE_EXT);\n if (this.disjoint == null) {\n this.disjoint = this.gl.getParameter(ext.GPU_DISJOINT_EXT);\n }\n\n return available && !this.disjoint;\n }\n }\n\n pollFence(fenceContext: FenceContext) {\n return new Promise(resolve => {\n this.addItemToPoll(() => fenceContext.isFencePassed(), () => resolve());\n });\n }\n\n private itemsToPoll: PollItem[] = [];\n\n pollItems(): void {\n // Find the last query that has finished using binary search.\n // All other queries before it are also done.\n const index = binSearchLastTrue(this.itemsToPoll.map(x => x.isDoneFn));\n for (let i = 0; i <= index; ++i) {\n const {resolveFn} = this.itemsToPoll[i];\n resolveFn();\n }\n this.itemsToPoll = this.itemsToPoll.slice(index + 1);\n }\n\n private addItemToPoll(isDoneFn: () => boolean, resolveFn: () => void) {\n this.itemsToPoll.push({isDoneFn, resolveFn});\n if (this.itemsToPoll.length > 1) {\n // We already have a running loop that polls.\n return;\n }\n // Start a new loop that polls.\n util.repeatedTry(() => {\n this.pollItems();\n // End the loop if no more items to poll.\n return this.itemsToPoll.length === 0;\n });\n }\n private bindTextureToFrameBuffer(texture: WebGLTexture) {\n this.throwIfDisposed();\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, texture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n }\n\n private unbindTextureToFrameBuffer() {\n if (this.outputTexture != null) {\n webgl_util.bindColorTextureToFramebuffer(\n this.gl, this.outputTexture, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(this.gl);\n }\n } else {\n webgl_util.unbindColorTextureFromFramebuffer(this.gl, this.framebuffer);\n }\n }\n\n private downloadMatrixDriver(\n texture: WebGLTexture,\n downloadAndDecode: () => Float32Array): Float32Array {\n this.bindTextureToFrameBuffer(texture);\n const result = downloadAndDecode();\n this.unbindTextureToFrameBuffer();\n\n return result;\n }\n\n private setOutputMatrixTextureDriver(\n outputMatrixTextureMaybePacked: WebGLTexture, width: number,\n height: number) {\n this.throwIfDisposed();\n const gl = this.gl;\n webgl_util.bindColorTextureToFramebuffer(\n gl, outputMatrixTextureMaybePacked, this.framebuffer);\n if (this.autoDebugValidate) {\n webgl_util.validateFramebuffer(gl);\n }\n this.outputTexture = outputMatrixTextureMaybePacked;\n webgl_util.callAndCheck(gl, () => gl.viewport(0, 0, width, height));\n webgl_util.callAndCheck(gl, () => gl.scissor(0, 0, width, height));\n }\n\n private setOutputMatrixWriteRegionDriver(\n x: number, y: number, width: number, height: number) {\n this.throwIfDisposed();\n webgl_util.callAndCheck(\n this.gl, () => this.gl.scissor(x, y, width, height));\n }\n\n private throwIfDisposed() {\n if (this.disposed) {\n throw new Error('Attempted to use disposed GPGPUContext.');\n }\n }\n\n private throwIfNoProgram() {\n if (this.program == null) {\n throw new Error('No GPU program is currently set.');\n }\n }\n}\n\ntype PollItem = {\n isDoneFn: () => boolean,\n resolveFn: () => void\n};\n\n/**\n * Finds the index of the last true element using binary search where\n * evaluation of an entry is expensive.\n */\nexport function binSearchLastTrue(arr: Array<() => boolean>): number {\n let start = 0;\n let end = arr.length - 1;\n let best = -1;\n while (start <= end) {\n const mid = (start + end) >> 1;\n const isDone = arr[mid]();\n if (isDone) {\n best = mid;\n start = mid + 1;\n } else {\n end = mid - 1;\n }\n }\n return best;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../../tensor';\nimport * as util from '../../util';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport * as shader_compiler from './shader_compiler';\nimport {InputInfo, ShapeInfo} from './shader_compiler';\nimport {TextureData} from './tex_util';\n\nexport interface GPGPUProgram {\n variableNames: string[];\n outputShape: number[];\n userCode: string;\n supportsBroadcasting?: boolean;\n}\n\nexport interface GPGPUBinary {\n webGLProgram: WebGLProgram;\n program: GPGPUProgram;\n uniformLocations: {[name: string]: WebGLUniformLocation};\n gpgpu: GPGPUContext;\n source: string;\n inShapeInfos: ShapeInfo[];\n outShapeInfo: ShapeInfo;\n}\n\nexport interface TensorData {\n tensor: T;\n texData: TextureData;\n isUniform: boolean;\n}\n\nexport function compileProgram(\n gpgpu: GPGPUContext, program: GPGPUProgram, inputs: Array>,\n output: TensorData): GPGPUBinary {\n const userCode = program.userCode;\n const inputInfos: InputInfo[] = inputs.map((input, i) => {\n const shapeInfo = {\n logicalShape: input.tensor.shape,\n texShape: input.isUniform ? null : input.texData.texShape,\n isUniform: input.isUniform\n };\n return {name: program.variableNames[i], shapeInfo};\n });\n const inShapeInfos = inputInfos.map(x => x.shapeInfo);\n const outShapeInfo = {\n logicalShape: output.tensor.shape,\n texShape: output.texData.texShape,\n isUniform: false\n };\n const source = shader_compiler.makeShader(\n inputInfos, outShapeInfo, userCode,\n program.supportsBroadcasting === true);\n\n const webGLProgram = gpgpu.createProgram(source);\n\n const uniformLocations: {[name: string]: WebGLUniformLocation} = {};\n for (let i = 0; i < program.variableNames.length; i++) {\n const uniformName = program.variableNames[i];\n const shouldThrow = false;\n uniformLocations[uniformName] =\n gpgpu.getUniformLocation(webGLProgram, uniformName, shouldThrow);\n }\n\n return {\n program,\n source,\n webGLProgram,\n uniformLocations,\n gpgpu,\n inShapeInfos,\n outShapeInfo\n };\n}\n\nfunction validateBinaryAndProgram(\n shapeInfos: ShapeInfo[], inputs: Array>) {\n if (shapeInfos.length !== inputs.length) {\n throw Error(\n `Binary was compiled with ${shapeInfos.length} inputs, but ` +\n `was executed with ${inputs.length} inputs`);\n }\n\n shapeInfos.forEach((s, i) => {\n const shapeA = s.logicalShape;\n const input = inputs[i];\n const shapeB = input.tensor.shape;\n\n if (!util.arraysEqual(shapeA, shapeB)) {\n throw Error(\n `Binary was compiled with different shapes than ` +\n `the current args. Shapes ${shapeA} and ${shapeB} must match`);\n }\n // The input is uploaded as uniform.\n if (s.isUniform && input.isUniform) {\n return;\n }\n\n const texShapeA = s.texShape;\n const texShapeB = input.isUniform ? null : input.texData.texShape;\n if (!util.arraysEqual(texShapeA, texShapeB)) {\n throw Error(\n `Binary was compiled with different texture shapes than the` +\n ` current args. Shape ${texShapeA} and ${texShapeB} must match`);\n }\n });\n}\n\nexport function runProgram(\n binary: GPGPUBinary, inputs: Array>, output: TensorData,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) =>\n void): void {\n validateBinaryAndProgram(binary.inShapeInfos, inputs);\n validateBinaryAndProgram([binary.outShapeInfo], [output]);\n\n const outTex = output.texData.texture;\n const outTexShape = output.texData.texShape;\n const gpgpu = binary.gpgpu;\n gpgpu.setOutputMatrixTexture(outTex, outTexShape[0], outTexShape[1]);\n gpgpu.setProgram(binary.webGLProgram);\n inputs.forEach((input, i) => {\n const variableName = binary.program.variableNames[i];\n const variableUniformLocation = binary.uniformLocations[variableName];\n if (variableUniformLocation != null) {\n if (input.isUniform) {\n if (input.tensor.size === 1) {\n gpgpu.gl.uniform1f(\n variableUniformLocation, input.tensor.dataSync()[0]);\n } else {\n let vals = input.tensor.dataSync();\n if (!(vals instanceof Float32Array)) {\n vals = new Float32Array(vals);\n }\n gpgpu.gl.uniform1fv(variableUniformLocation, vals);\n }\n return;\n }\n const tex = input.texData.texture;\n gpgpu.setInputMatrixTexture(tex, variableUniformLocation, i);\n }\n });\n\n if (customSetup != null) {\n customSetup(gpgpu, binary.webGLProgram);\n }\n gpgpu.executeProgram();\n}\n\nexport function makeShaderKey(\n program: GPGPUProgram, inputs: Array>,\n output: TensorData): string {\n let keyInputs = '';\n inputs.concat(output).forEach(x => {\n keyInputs +=\n `${x.tensor.shape}_${x.isUniform ? 'uniform' : x.texData.texShape}`;\n });\n const keyUserCode = program.userCode;\n const keyBroadcast = (program.supportsBroadcasting === true).toString();\n let key = program.constructor.name;\n // Fast string concat. See https://jsperf.com/string-concatenation/14.\n key += '_' + keyBroadcast + '_' + keyInputs + '_' + keyUserCode;\n return key;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n xShape: number[], radius: number, bias: number, alpha: number,\n beta: number) {\n const rad = radius;\n const maxD = xShape[3] - 1;\n this.outputShape = xShape;\n\n // optimize pow(bias + alpha * sum, -beta)\n // src: https://github.com/tensorflow/tensorflow/..\n // blob/26033a1644a9c4a5fbe3170ab2e864b6a4ccd4ca/..\n // tensorflow/core/kernels/mkl_lrn_op.cc#L320\n let powOperator;\n const basis = `float(${bias}) + float(${alpha}) * sum`;\n if (beta === 0.5) {\n powOperator = `inversesqrt(${basis})`;\n } else if (beta === 1.0) {\n powOperator = `1.0/(${basis})`;\n } else {\n powOperator = `exp(log(${basis}) * float(-${beta}));`;\n }\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -${rad}; j <= ${rad}; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= ${maxD}) {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * ${powOperator};\n setOutput(val);\n }\n `;\n }\n}\n","import {GPGPUProgram} from './gpgpu_math';\n\nexport class LRNGradProgram implements GPGPUProgram {\n variableNames = ['inputImage', 'outputImage', 'dy'];\n outputShape: number[] = [];\n userCode: string;\n depthRadius: number;\n bias: number;\n alpha: number;\n beta: number;\n depth: number;\n\n constructor(\n inputShape: number[], depthRadius: number, bias: number, alpha: number,\n beta: number) {\n this.outputShape = inputShape;\n this.depth = inputShape[3];\n this.depthRadius = depthRadius;\n this.bias = bias;\n this.alpha = alpha;\n this.beta = beta;\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < ${this.depth}; ++d) {\n int depthBegin = int(max(0.0, float(d - ${depthRadius})));\n int depthEnd = int(min(float(${this.depth}),\n float(d + ${depthRadius} + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = ${this.depth};\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(${alpha}) * norm + float(${bias});\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(${alpha})\n * float(${beta})\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * ${beta});\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MaxPool2DBackpropProgram implements GPGPUProgram {\n variableNames = ['dy', 'maxPos'];\n outputShape: number[];\n userCode: string;\n\n constructor(convInfo: Conv2DInfo) {\n this.outputShape = convInfo.inShape;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n\n const lastIndex = filterHeight * filterWidth - 1;\n this.userCode = `\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n float dyR = float(dyRCorner + wR) / ${strideHeight}.0;\n\n if (dyR < 0.0 || dyR >= ${convInfo.outHeight}.0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n float dyC = float(dyCCorner + wC) / ${strideWidth}.0;\n\n if (dyC < 0.0 || dyC >= ${convInfo.outWidth}.0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = ${lastIndex} - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * ${filterWidth} + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MatMulProgram implements GPGPUProgram {\n variableNames = ['matrixA', 'matrixB'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n aShape: [number, number], bShape: [number, number], transposeA = false,\n transposeB = false) {\n const outerShapeA = transposeA ? aShape[1] : aShape[0];\n const outerShapeB = transposeB ? bShape[0] : bShape[1];\n const sharedDim = transposeA ? aShape[0] : aShape[1];\n this.outputShape = [outerShapeA, outerShapeB];\n\n const aSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeA ? `${indexVar} + ${vec4Offset}, aRow` :\n `aRow, ${indexVar} + ${vec4Offset}`;\n const bSnippetFromOffset = (vec4Offset: number, indexVar: string|number) =>\n transposeB ? `bCol, ${indexVar} + ${vec4Offset}` :\n `${indexVar} + ${vec4Offset}, bCol`;\n\n const sharedDimNearestVec4 = Math.floor(sharedDim / 4) * 4;\n const sharedDimVec4Remainder = sharedDim % 4;\n\n this.userCode = ` float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < ${sharedDimNearestVec4}; i += 4) {\n vec4 a = vec4(\n getMatrixA(${aSnippetFromOffset(0, 'i')}),\n getMatrixA(${aSnippetFromOffset(1, 'i')}),\n getMatrixA(${aSnippetFromOffset(2, 'i')}),\n getMatrixA(${aSnippetFromOffset(3, 'i')})\n );\n vec4 b = vec4(\n getMatrixB(${bSnippetFromOffset(0, 'i')}),\n getMatrixB(${bSnippetFromOffset(1, 'i')}),\n getMatrixB(${bSnippetFromOffset(2, 'i')}),\n getMatrixB(${bSnippetFromOffset(3, 'i')})\n );\n\n result += dot(a, b);\n }\n\n if (${sharedDimVec4Remainder === 1}) {\n result += getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}) *\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)});\n } else if (${sharedDimVec4Remainder === 2}) {\n vec2 a = vec2(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n vec2 b = vec2(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n } else if (${sharedDimVec4Remainder === 3}) {\n vec3 a = vec3(\n getMatrixA(${aSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixA(${aSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n vec3 b = vec3(\n getMatrixB(${bSnippetFromOffset(0, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(1, sharedDimNearestVec4)}),\n getMatrixB(${bSnippetFromOffset(2, sharedDimNearestVec4)})\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class MultinomialProgram implements GPGPUProgram {\n variableNames = ['probs'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(batchSize: number, numOutcomes: number, numSamples: number) {\n this.outputShape = [batchSize, numSamples];\n\n this.userCode = `\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < ${numOutcomes - 1}; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(${numOutcomes - 1}));\n }\n `;\n }\n\n getCustomSetupFunc(seed: number) {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.seedLoc == null) {\n this.seedLoc = gpgpu.getUniformLocation(webGLProgram, 'seed');\n }\n gpgpu.gl.uniform1f(this.seedLoc, seed);\n };\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class OneHotProgram implements GPGPUProgram {\n variableNames = ['indices'];\n outputShape: number[];\n userCode: string;\n\n // Caching uniform location for speed.\n seedLoc: WebGLUniformLocation;\n\n constructor(\n numIndices: number, depth: number, onValue: number, offValue: number) {\n this.outputShape = [numIndices, depth];\n\n this.userCode = `\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(${offValue}), float(${onValue}),\n float(index == coords.y)));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class PadProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n xShape: number[], paddings: Array<[number, number]>,\n constantValue: number) {\n this.outputShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + xShape[i] + p[1] /* afterPad */);\n const rank = xShape.length;\n const type = getCoordsDataType(rank);\n\n const start = paddings.map(p => p[0]).join(',');\n const end = paddings.map((p, i) => p[0] + xShape[i]).join(',');\n const unpackedCoords =\n ['coords[0]', 'coords[1]', 'coords[2]','coords[3]'].slice(0, rank);\n\n if (rank === 1) {\n this.userCode = `\n int start = ${start};\n int end = ${end};\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(${constantValue}));\n } else {\n setOutput(getX(outC - start));\n }\n }\n `;\n return;\n }\n this.userCode = `\n ${type} start = ${type}(${start});\n ${type} end = ${type}(${end});\n\n void main() {\n ${type} outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(${constantValue}));\n } else {\n ${type} coords = outC - start;\n setOutput(getX(${unpackedCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Conv2DInfo} from '../../ops/conv_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class Pool2DProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n convInfo: Conv2DInfo, poolType: 'max'|'avg', computePositions: boolean) {\n if (poolType === 'avg' && computePositions) {\n throw new Error('Cannot compute positions for average pool.');\n }\n\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n this.outputShape = convInfo.outShape;\n\n const isAvgPool = poolType === 'avg';\n\n let initializationValue = '0.0';\n if (!isAvgPool) {\n initializationValue = '-1.0 / 0.0';\n }\n\n if (computePositions) {\n const compareOp = '>=';\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidth}; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value ${compareOp} currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * ${filterWidth} + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n `;\n return;\n }\n\n const compareOp = 'max';\n\n let returnValue = `${poolType}(${poolType}(${poolType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n if (poolType === 'avg') {\n returnValue = `avgValue / count`;\n }\n\n const filterWidthNearestVec4 = Math.floor(filterWidth / 4) * 4;\n const filterWidthVec4Remainder = filterWidth % 4;\n\n const updateSnippet = `\n if (${isAvgPool}) {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n this.userCode = `\n const ivec2 strides = ivec2(${strideHeight}, ${strideWidth});\n const ivec2 pads = ivec2(${padTop}, ${padLeft});\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= ${convInfo.inWidth}) {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(${initializationValue});\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < ${filterHeight}; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= ${convInfo.inHeight}) {\n continue;\n }\n\n for (int wC = 0; wC < ${filterWidthNearestVec4}; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n ${updateSnippet}\n }\n\n int xC = xCCorner + ${filterWidthNearestVec4};\n if (${filterWidthVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${filterWidthVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n ${updateSnippet}\n }\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ReduceInfo} from '../../ops/reduce_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ReduceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(\n reduceInfo: ReduceInfo, reduceType: 'all'|'any'|'max'|'min'|'sum') {\n const windowSize = reduceInfo.windowSize;\n const batchSize = reduceInfo.batchSize;\n const inSize = reduceInfo.inSize;\n const outSize = Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n let initializationValue = '0.0';\n let compareOp = ``;\n\n if (reduceType === 'min') {\n initializationValue = '1.0 / 0.0';\n compareOp = `min`;\n } else if (reduceType === 'max') {\n initializationValue = '-1.0 / 0.0';\n compareOp = `max`;\n }\n\n let returnValue = `${reduceType}(${reduceType}(${reduceType}(` +\n 'minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])';\n\n if (reduceType === 'sum') {\n returnValue = `sumValue`;\n } else if (reduceType === 'all') {\n returnValue = `allValue`;\n } else if (reduceType === 'any') {\n returnValue = `anyValue`;\n }\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n let updateSnippet = `\n if (${reduceType === 'sum'}) {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = ${compareOp}(values, minMaxValue);\n }\n `;\n\n let vecType = `vec4`;\n\n if (reduceType === 'all') {\n initializationValue = '1.0';\n updateSnippet = `\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n `;\n vecType = `bvec4`;\n } else if (reduceType === 'any') {\n initializationValue = '0.0';\n updateSnippet = `\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n `;\n vecType = `bvec4`;\n }\n\n let checkOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n this.userCode = `\n const float initializationValue = ${initializationValue};\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n ${checkOutOfBounds}\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * ${windowSize};\n\n vec4 minMaxValue = vec4(${initializationValue});\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n ${vecType} values = ${vecType}(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), ${xHeight - 1}.0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), ${xWidth - 1}.0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeBilinearProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor4D} from '../../tensor';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeigborBackpropProgram implements GPGPUProgram {\n variableNames = ['dy'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n this.outputShape = x.shape;\n const [, xHeight, xWidth, ] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n this.userCode = `\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(${heightScale});\n const float widthScale = float(${widthScale});\n\n const float invHeightScale = float(${invHeightScale});\n const float invWidthScale = float(${invWidthScale});\n\n const int winHeight = int(${winHeight});\n const int winWidth = int(${winWidth});\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= ${yHeight}) {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= ${yWidth}) {\n continue;\n }\n\n float sourceFracRow =\n float(${effectiveXSize[0]}) *\n (float(dyR) / float(${effectiveYSize[0]}));\n\n float sourceFracCol =\n float(${effectiveXSize[1]}) *\n (float(dyC) / float(${effectiveYSize[1]}));\n\n int sourceNearestRow = int(min(\n float(int(${xHeight}) - 1),\n ${alignCorners} ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(${xWidth}) - 1),\n ${alignCorners} ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class ResizeNearestNeighborProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[] = [];\n userCode: string;\n\n constructor(\n inputShape: [number, number, number, number], newHeight: number,\n newWidth: number, alignCorners: boolean) {\n const [batch, oldHeight, oldWidth, depth] = inputShape;\n this.outputShape = [batch, newHeight, newWidth, depth];\n\n const effectiveInSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n // When align corners is false, we rounds the value with floor.\n const roundBase = alignCorners ? '0.5' : '0.0';\n\n this.userCode = `\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n ${effectiveInSize[0] / effectiveOutSize[0]},\n ${effectiveInSize[1] / effectiveOutSize[1]});\n const vec2 inputShapeRC = vec2(${oldHeight}.0, ${oldWidth}.0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${roundBase})));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class ReverseProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n\n constructor(xShape: number[], axis: number[]) {\n const rank = xShape.length;\n if (rank > 4) {\n throw new Error(\n `WebGL backend: Reverse of rank-${rank} tensor is not yet supported`);\n }\n this.outputShape = xShape;\n\n if (rank === 1) {\n this.userCode = `\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(${xShape[0]} - coord - 1));\n }\n `;\n return;\n }\n const getInCoord = (i: number) => {\n if (axis.indexOf(i) !== -1 && xShape[i] !== 1) {\n return `${xShape[i]} - coords[${i}] - 1`;\n }\n return `coords[${i}]`;\n };\n const inCoords = xShape.map((_, i) => getInCoord(i)).join(',');\n const type = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${type} coords = getOutputCoords();\n setOutput(getX(${inCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {SegOpInfo} from '../../ops/segment_util';\nimport {GPGPUProgram} from './gpgpu_math';\n\nexport class SegmentOpProgram implements GPGPUProgram {\n variableNames = ['x', 'segmentIds'];\n outputShape: number[];\n userCode: string;\n\n constructor(segOpInfo: SegOpInfo, segOpType: 'unsortedSegmentSum') {\n const windowSize = segOpInfo.windowSize;\n const batchSize = segOpInfo.batchSize;\n const inSize = segOpInfo.inSize;\n const numSegments = segOpInfo.numSegments;\n const outSize = numSegments * Math.ceil(inSize / windowSize);\n this.outputShape = [batchSize, outSize];\n\n const initializationValue = '0.0';\n const returnValue = `sumValue`;\n\n const windowSizeNearestVec4 = Math.floor(windowSize / 4) * 4;\n const windowSizeVec4Remainder = windowSize % 4;\n\n const updateSnippet = `\n sumValue += dot(values, filter);\n `;\n\n let checkValueOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkValueOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return initializationValue;\n }\n `;\n }\n\n let checkSegmentIdOutOfBounds = '';\n if (inSize % windowSize > 0) {\n checkSegmentIdOutOfBounds = `\n if (inIdx < 0 || inIdx >= ${inSize}) {\n return -1.0;\n }\n `;\n }\n\n this.userCode = `\n const float initializationValue = ${initializationValue};\n\n float getValue(int batch, int inIdx) {\n ${checkValueOutOfBounds}\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n ${checkSegmentIdOutOfBounds}\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n ${numSegments})) * float(${windowSize}));\n int currentSeg = int(mod(float(outIdx), float(${numSegments})));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < ${windowSizeNearestVec4}; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n ${updateSnippet}\n }\n\n int inIdx = inOffset + ${windowSizeNearestVec4};\n if (${windowSizeVec4Remainder === 1}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 2}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n ${updateSnippet}\n } else if (${windowSizeVec4Remainder === 3}) {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n ${updateSnippet}\n }\n setOutput(${returnValue});\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SelectProgram implements GPGPUProgram {\n variableNames = ['c', 'a', 'b'];\n outputShape: number[];\n userCode: string;\n\n constructor(cRank: number, shape: number[], rank: number) {\n this.outputShape = shape;\n\n let cCoords;\n let abCoords;\n if (rank > 4) {\n throw Error(`Where for rank ${rank} is not yet supported`);\n }\n\n if (rank === 1) {\n abCoords = `resRC`;\n cCoords = `resRC`;\n } else {\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w'];\n const cCoordVars = [];\n const abCoordVars = [];\n for (let i = 0; i < shape.length; i++) {\n abCoordVars.push(`${currentCoords[i]}`);\n if (i < cRank) {\n cCoordVars.push(`${currentCoords[i]}`);\n }\n }\n cCoords = cCoordVars.join();\n abCoords = abCoordVars.join();\n }\n\n const dtype = getCoordsDataType(rank);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n float cVal = getC(${cCoords});\n if (cVal >= 1.0) {\n setOutput(getA(${abCoords}));\n } else {\n setOutput(getB(${abCoords}));\n }\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class SliceProgram implements GPGPUProgram {\n variableNames = ['source'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(destSize: number[]) {\n this.outputShape = destSize;\n this.rank = destSize.length;\n\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getCoords(this.rank);\n\n this.userCode = `\n uniform ${dtype} start;\n\n void main() {\n ${dtype} sourceLoc = start + getOutputCoords();\n setOutput(getSource(${sourceCoords}));\n }\n `;\n }\n\n getCustomSetupFunc(start: number[]) {\n if (start.length !== this.rank) {\n throw Error(\n `The rank (${this.rank}) of the program must match the ` +\n `length of start (${start.length})`);\n }\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'start');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n if (this.rank === 1) {\n gpgpu.gl.uniform1i(this.startLoc, start[0]);\n } else if (this.rank === 2) {\n gpgpu.gl.uniform2i(this.startLoc, start[0], start[1]);\n } else if (this.rank === 3) {\n gpgpu.gl.uniform3i(this.startLoc, start[0], start[1], start[2]);\n } else if (this.rank === 4) {\n gpgpu.gl.uniform4i(\n this.startLoc, start[0], start[1], start[2], start[3]);\n } else {\n throw Error(`Slicing for rank ${this.rank} is not yet supported`);\n }\n };\n }\n}\n\nfunction getCoords(rank: number): string {\n if (rank === 1) {\n return 'sourceLoc';\n } else if (rank === 2) {\n return 'sourceLoc.x, sourceLoc.y';\n } else if (rank === 3) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z';\n } else if (rank === 4) {\n return 'sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w';\n } else {\n throw Error(`Slicing for rank ${rank} is not yet supported`);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class StridedSliceProgram implements GPGPUProgram {\n variableNames = ['x'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(begin: number[], strides: number[], shape: number[]) {\n this.outputShape = shape;\n this.rank = shape.length;\n const dtype = getCoordsDataType(this.rank);\n\n let newCoords = '';\n if (this.rank === 1) {\n newCoords = 'coords * strides + begin';\n } else {\n newCoords =\n shape.map((_, i) => `coords[${i}] * strides[${i}] + begin[${i}]`)\n .join(',');\n }\n\n this.userCode = `\n ${dtype} begin = ${dtype}(${begin});\n ${dtype} strides = ${dtype}(${strides});\n\n void main() {\n ${dtype} coords = getOutputCoords();\n setOutput(getX(${newCoords}));\n }\n `;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../../environment';\n\nimport {GPGPUContext} from './gpgpu_context';\nimport {PhysicalTextureType, TextureUsage} from './tex_util';\n\nexport class TextureManager {\n private numUsedTextures = 0;\n private numFreeTextures = 0;\n private freeTextures: {[shape: string]: WebGLTexture[]} = {};\n private logEnabled = false;\n private usedTextures: {[shape: string]: WebGLTexture[]} = {};\n\n constructor(private gpgpu: GPGPUContext) {}\n\n acquireTexture(shapeRC: [number, number], usage: TextureUsage): WebGLTexture {\n const physicalTexType = getPhysicalFromLogicalTextureType(usage);\n\n const shapeKey = getKeyFromTextureShape(shapeRC, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n if (!(shapeKey in this.usedTextures)) {\n this.usedTextures[shapeKey] = [];\n }\n\n if (this.freeTextures[shapeKey].length > 0) {\n this.numFreeTextures--;\n this.numUsedTextures++;\n this.log();\n const newTexture = this.freeTextures[shapeKey].shift();\n this.usedTextures[shapeKey].push(newTexture);\n return newTexture;\n }\n this.numUsedTextures++;\n this.log();\n\n let newTexture: WebGLTexture;\n if (physicalTexType === PhysicalTextureType.FLOAT32) {\n newTexture =\n this.gpgpu.createFloat32MatrixTexture(shapeRC[0], shapeRC[1]);\n } else if (physicalTexType === PhysicalTextureType.FLOAT16) {\n newTexture =\n this.gpgpu.createFloat16MatrixTexture(shapeRC[0], shapeRC[1]);\n\n } else if (physicalTexType === PhysicalTextureType.UNSIGNED_BYTE) {\n newTexture =\n this.gpgpu.createUnsignedBytesMatrixTexture(shapeRC[0], shapeRC[1]);\n }\n this.usedTextures[shapeKey].push(newTexture);\n\n return newTexture;\n }\n\n releaseTexture(\n texture: WebGLTexture, shape: [number, number],\n logicalTexType: TextureUsage): void {\n const physicalTexType = getPhysicalFromLogicalTextureType(logicalTexType);\n const shapeKey = getKeyFromTextureShape(shape, physicalTexType);\n if (!(shapeKey in this.freeTextures)) {\n this.freeTextures[shapeKey] = [];\n }\n this.freeTextures[shapeKey].push(texture);\n this.numFreeTextures++;\n this.numUsedTextures--;\n const texList = this.usedTextures[shapeKey];\n const texIndex = texList.indexOf(texture);\n if (texIndex < 0) {\n throw new Error(\n 'Cannot release a texture that was never provided by this ' +\n 'texture manager');\n }\n texList.splice(texIndex, 1);\n this.log();\n }\n\n private log() {\n if (!this.logEnabled) {\n return;\n }\n const total = this.numFreeTextures + this.numUsedTextures;\n console.log(\n 'Free/Used', `${this.numFreeTextures} / ${this.numUsedTextures}`,\n `(${total})`);\n }\n\n getNumUsedTextures(): number {\n return this.numUsedTextures;\n }\n\n getNumFreeTextures(): number {\n return this.numFreeTextures;\n }\n\n dispose() {\n if (this.freeTextures == null) {\n // Already disposed.\n return;\n }\n for (const texShape in this.freeTextures) {\n this.freeTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n for (const texShape in this.usedTextures) {\n this.usedTextures[texShape].forEach(tex => {\n this.gpgpu.deleteMatrixTexture(tex);\n });\n }\n this.freeTextures = null;\n this.usedTextures = null;\n this.numUsedTextures = 0;\n this.numFreeTextures = 0;\n }\n}\n\nfunction getPhysicalFromLogicalTextureType(logicalTexType: TextureUsage):\n PhysicalTextureType {\n if (logicalTexType === TextureUsage.DOWNLOAD ||\n logicalTexType === TextureUsage.PIXELS) {\n return PhysicalTextureType.UNSIGNED_BYTE;\n } else if (logicalTexType === TextureUsage.UPLOAD) {\n return PhysicalTextureType.FLOAT32;\n } else if (logicalTexType === TextureUsage.RENDER) {\n return ENV.get('WEBGL_RENDER_FLOAT32_ENABLED') ?\n PhysicalTextureType.FLOAT32 :\n PhysicalTextureType.FLOAT16;\n }\n throw new Error(`Unknown logical texture type ${logicalTexType}`);\n}\n\nfunction getKeyFromTextureShape(\n shapeRowsCol: [number, number],\n physicalTexType: PhysicalTextureType): string {\n return `${shapeRowsCol[0]}_${shapeRowsCol[1]}_${physicalTexType}`;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TileProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], reps: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[i] * reps[i];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const sourceCoords = getSourceCoords(aShape);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${sourceCoords}));\n }\n `;\n }\n}\n\nfunction getSourceCoords(aShape: number[]): string {\n const rank = aShape.length;\n if (rank > 5) {\n throw Error(`Tile for rank ${rank} is not yet supported`);\n }\n if (rank === 1) {\n return `imod(resRC, ${aShape[0]})`;\n }\n\n const currentCoords = ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u'];\n\n const sourceCoords = [];\n for (let i = 0; i < aShape.length; i++) {\n sourceCoords.push(`imod(${currentCoords[i]}, ${aShape[i]})`);\n }\n return sourceCoords.join();\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {getCoordsDataType} from './shader_compiler';\n\nexport class TransposeProgram implements GPGPUProgram {\n variableNames = ['A'];\n outputShape: number[];\n userCode: string;\n rank: number;\n\n constructor(aShape: number[], newDim: number[]) {\n const outputShape: number[] = new Array(aShape.length);\n for (let i = 0; i < outputShape.length; i++) {\n outputShape[i] = aShape[newDim[i]];\n }\n this.outputShape = outputShape;\n this.rank = outputShape.length;\n const dtype = getCoordsDataType(this.rank);\n const switched = getSwitchedCoords(newDim);\n\n this.userCode = `\n void main() {\n ${dtype} resRC = getOutputCoords();\n setOutput(getA(${switched}));\n }\n `;\n }\n}\n\nfunction getSwitchedCoords(newDim: number[]): string {\n const rank = newDim.length;\n if (rank > 6) {\n throw Error(`Transpose for rank ${rank} is not yet supported`);\n }\n const originalOrder =\n ['resRC.x', 'resRC.y', 'resRC.z', 'resRC.w', 'resRC.u', 'resRC.v'];\n const switchedCoords = new Array(rank);\n for (let i = 0; i < newDim.length; i++) {\n switchedCoords[newDim[i]] = originalOrder[i];\n }\n return switchedCoords.join();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const ERF_P = 0.3275911;\nexport const ERF_A1 = 0.254829592;\nexport const ERF_A2 = -0.284496736;\nexport const ERF_A3 = 1.421413741;\nexport const ERF_A4 = -1.453152027;\nexport const ERF_A5 = 1.061405429;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport const SELU_SCALEALPHA = 1.7580993408473768599402175208123;\nexport const SELU_SCALE = 1.0507009873554804934193349852946;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as erf_util from '../../ops/erf_util';\nimport * as selu_util from '../../ops/selu_util';\n\nimport {GPGPUProgram} from './gpgpu_math';\nimport {GPGPUContext} from './gpgpu_context';\n\nexport class UnaryOpProgram implements GPGPUProgram {\n variableNames = ['A'];\n userCode: string;\n outputShape: number[];\n\n // Caching uniform location for speed.\n startLoc: WebGLUniformLocation;\n\n constructor(aShape: number[], opSnippet: string) {\n this.outputShape = aShape;\n this.userCode = `\n uniform float NAN;\n float unaryOperation(float x) {\n ${opSnippet}\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n `;\n }\n\n getCustomSetupFunc() {\n return (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => {\n if (this.startLoc == null) {\n this.startLoc = gpgpu.getUniformLocationNoThrow(webGLProgram, 'NAN');\n if (this.startLoc == null) {\n // This means the compiler has optimized and realized it doesn't need\n // the uniform.\n return;\n }\n }\n gpgpu.gl.uniform1f(this.startLoc, NaN);\n };\n }\n}\n\nconst CHECK_NAN_SNIPPET = `if (isNaN(x)) return x;`;\n\nexport const ABS = `return abs(x);`;\n\nexport const RELU = CHECK_NAN_SNIPPET + `\n return (x < 0.0) ? 0.0 : x;\n`;\n\nexport const ELU = `return (x >= 0.0) ? x : (exp(x) - 1.0);`;\n\nexport const SELU = `\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = ${selu_util.SELU_SCALEALPHA};\n float scale = ${selu_util.SELU_SCALE};\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n`;\n\nexport function STEP(alpha = 0.0) {\n return CHECK_NAN_SNIPPET + `\n return x > 0.0 ? 1.0 : float(${alpha});\n `;\n}\n\nexport const NEG = `return -x;`;\n\nexport const CEIL = `return ceil(x);`;\n\nexport const FLOOR = `return floor(x);`;\n\nexport const SIGN = `\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n`;\n\nexport const ROUND = `\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n`;\n\nexport const EXP = `return exp(x);`;\n\nexport const EXPM1 = `return exp(x) - 1.0;`;\n\nexport const LOG = `if (x < 0.0) return NAN;\n return log(x);`;\n\nexport const LOG1P = `return log(1.0 + x);`;\n\nexport const SQRT = `return sqrt(x);`;\n\nexport const RSQRT = `return inversesqrt(x);`;\n\nexport const SIGMOID = `return 1.0 / (1.0 + exp(-1.0 * x));`;\n\n/**\n * mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n *\n * epsilon is the difference between 1.0 and the next representable\n * float. For a single precision 32 bit float this should be 2^-23, see:\n * https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n *\n * too_large = (x > -threshold) is value above which exp(x) may overflow\n * but softplus(x) == x is within machine epsilon\n *\n * too_small = (x < threshold) is value below which exp(x) may underflow,\n * but softplus(x) == exp(x) is within machine epsilon.\n */\nexport const SOFTPLUS = `\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n`;\n\nexport const SIN = CHECK_NAN_SNIPPET + `\n return sin(x);\n`;\n\nexport const COS = CHECK_NAN_SNIPPET + `\n return cos(x);\n`;\n\nexport const TAN = `return tan(x);`;\n\nexport const ASIN = `return asin(x);`;\n\nexport const ACOS = `return acos(x);`;\n\nexport const ATAN = CHECK_NAN_SNIPPET + `\n return atan(x);\n`;\n\nexport const SINH = `\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n`;\n\nexport const COSH = `\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n`;\n\nexport const TANH = `\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n`;\n\nexport const ASINH = `return log(x + sqrt(x * x + 1.0));`;\n\nexport const ACOSH = CHECK_NAN_SNIPPET + `\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));`;\n\nexport const ATANH = CHECK_NAN_SNIPPET + `\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;`;\n\nexport const ERF = `\n // Error function is calculated approximately with elementary function.\n // See \"Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\n float p = ${erf_util.ERF_P};\n float a1 = ${erf_util.ERF_A1};\n float a2 = ${erf_util.ERF_A2};\n float a3 = ${erf_util.ERF_A3};\n float a4 = ${erf_util.ERF_A4};\n float a5 = ${erf_util.ERF_A5};\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n`;\n\nexport const SQUARE = `return x * x;`;\n\nexport const RECIPROCAL = `return 1.0 / x;`;\n\nexport const LOGICAL_NOT = `return float(!(x >= 1.0));`;\n\nexport const TO_INT = `return float(int(x));`;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, sizeFromShape} from '../util';\nimport {parseAxisParam} from './axis_util';\nimport * as concat_util from './concat_util';\nimport {op} from './operation';\n\n/**\n * Concatenates a list of `Tensor1D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(3) = |r1, g1, b1|\n * B: shape(2) = |r2, g2|\n * C = tf.concat1d([A, B]) == |r1, g1, b1, r2, g2|\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @return The concatenated array.\n */\nfunction concat1d_(tensors: Tensor1D[]|TensorLike[]): Tensor1D {\n return concat(tensors, 0 /* axis */);\n}\n\n/**\n * Concatenates a list of `Tensor2D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat2d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C = shape(2, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concatenate along.\n * @return The concatenated array.\n */\nfunction concat2d_(tensors: Tensor2D[]|TensorLike[], axis: number): Tensor2D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor3D`s along an axis. See `concat` for details.\n *\n * For example, if:\n * A: shape(2, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n *\n * B: shape(2, 1, 3) = | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * C = tf.concat3d([A, B], axis)\n *\n * if axis = 0:\n * C: shape(4, 1, 3) = | r1, g1, b1 |\n * | r2, g2, b2 |\n * | r3, g3, b3 |\n * | r4, g4, b4 |\n *\n * if axis = 1:\n * C: shape(2, 2, 3) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * if axis = 2:\n * C = shape(2, 1, 6) = | r1, g1, b1, r3, g3, b3 |\n * | r2, g2, b2, r4, g4, b4 |\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat3d_(tensors: Tensor3D[]|TensorLike[], axis: number): Tensor3D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor4D`s along an axis. See `concat` for details.\n *\n * @param tensors A list of `Tensor`s to concatenate.\n * @param axis The axis to concate along.\n * @return The concatenated array.\n */\nfunction concat4d_(tensors: Tensor4D[]|TensorLike[], axis: number): Tensor4D {\n return concat(tensors, axis);\n}\n\n/**\n * Concatenates a list of `Tensor`s along a given axis.\n *\n * The tensors ranks and types must match, and their sizes must match in all\n * dimensions except `axis`.\n *\n * Also available are stricter rank-specific methods that assert that\n * `tensors` are of the given rank:\n * - `tf.concat1d`\n * - `tf.concat2d`\n * - `tf.concat3d`\n * - `tf.concat4d`\n *\n * Except `tf.concat1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * a.concat(b).print(); // or a.concat(b)\n * ```\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.concat([a, b, c]).print();\n * ```\n *\n * ```js\n * const a = tf.tensor2d([[1, 2], [10, 20]]);\n * const b = tf.tensor2d([[3, 4], [30, 40]]);\n * const axis = 1;\n * tf.concat([a, b], axis).print();\n * ```\n * @param tensors A list of tensors to concatenate.\n * @param axis The axis to concate along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction concat_(tensors: T[]|TensorLike[], axis = 0): T {\n assert(tensors.length >= 1, 'Pass at least one tensor to concat');\n const $tensors = convertToTensorArray(tensors, 'tensors', 'concat');\n\n let result = $tensors[0] as T;\n if ($tensors.length === 1) {\n return result;\n }\n const axes = parseAxisParam(axis, result.shape);\n\n for (let i = 1; i < $tensors.length; ++i) {\n result = concat2Tensors(result, $tensors[i], axes[0]) as T;\n }\n return result;\n}\n\nfunction concat2Tensors(a: T, b: T, axis: number): T {\n concat_util.assertParams(a.shape, b.shape, axis);\n const outShape = concat_util.computeOutShape(a.shape, b.shape, axis);\n\n // Do the reshape.\n const a2D = a.as2D(-1, sizeFromShape(a.shape.slice(axis)));\n const b2D = b.as2D(-1, sizeFromShape(b.shape.slice(axis)));\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n const {aBegin, aSize, bBegin, bSize} =\n concat_util.computeGradientSliceShapes(a2D.shape, b2D.shape);\n const der = (dy: Tensor2D) => {\n return {a: () => dy.slice(aBegin, aSize), b: () => dy.slice(bBegin, bSize)};\n };\n const res = ENV.engine.runKernel(\n backend => backend.concat(a2D, b2D), {a: a2D, b: b2D}, der);\n return res.reshape(outShape) as T;\n}\n\nexport const concat = op({concat_});\nexport const concat1d = op({concat1d_});\nexport const concat2d = op({concat2d_});\nexport const concat3d = op({concat3d_});\nexport const concat4d = op({concat4d_});\n","// A port of an algorithm by Johannes Baagøe , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baagøe \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n// \n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n// \n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = data.toString();\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xorshift7\" algorithm by\n// François Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n","// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n","// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","/*\nCopyright 2014 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\nvar global = this,\n width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\nmath['seed' + rngname] = seedrandom;\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n}\n\n// End anonymous scope, and pass initial values.\n})(\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n","// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by François Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\n\nexport interface RandGauss {\n nextValue(): number;\n}\n\nexport interface RandNormalDataTypes {\n float32: Float32Array;\n int32: Int32Array;\n}\n\n// https://en.wikipedia.org/wiki/Marsaglia_polar_method\nexport class MPRandGauss implements RandGauss {\n private mean: number;\n private stdDev: number;\n private nextVal: number;\n private dtype?: keyof RandNormalDataTypes;\n private truncated?: boolean;\n private upper?: number;\n private lower?: number;\n private random: seedrandom.prng;\n\n constructor(\n mean: number, stdDeviation: number, dtype?: keyof RandNormalDataTypes,\n truncated?: boolean, seed?: number) {\n this.mean = mean;\n this.stdDev = stdDeviation;\n this.dtype = dtype;\n this.nextVal = NaN;\n this.truncated = truncated;\n if (this.truncated) {\n this.upper = this.mean + this.stdDev * 2;\n this.lower = this.mean - this.stdDev * 2;\n }\n const seedValue = seed ? seed : Math.random();\n this.random = seedrandom.alea(seedValue.toString());\n }\n\n /** Returns next sample from a gaussian distribution. */\n public nextValue(): number {\n if (!isNaN(this.nextVal)) {\n const value = this.nextVal;\n this.nextVal = NaN;\n return value;\n }\n\n let resultX: number, resultY: number;\n let isValid = false;\n while (!isValid) {\n let v1: number, v2: number, s: number;\n do {\n v1 = 2 * this.random() - 1;\n v2 = 2 * this.random() - 1;\n s = v1 * v1 + v2 * v2;\n } while (s >= 1 || s === 0);\n\n const mul = Math.sqrt(-2.0 * Math.log(s) / s);\n resultX = this.mean + this.stdDev * v1 * mul;\n resultY = this.mean + this.stdDev * v2 * mul;\n\n if (!this.truncated || this.isValidTruncated(resultX)) {\n isValid = true;\n }\n }\n\n if (!this.truncated || this.isValidTruncated(resultY)) {\n this.nextVal = this.convertValue(resultY);\n }\n return this.convertValue(resultX);\n }\n\n /** Handles proper rounding for non floating point numbers. */\n private convertValue(value: number): number {\n if (this.dtype == null || this.dtype === 'float32') {\n return value;\n }\n return Math.round(value);\n }\n\n /** Returns true if less than 2-standard-deviations from the mean. */\n private isValidTruncated(value: number): boolean {\n return value <= this.upper && value >= this.lower;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {DataType, Rank, ShapeMap, TensorLike, TensorLike1D, TypedArray} from '../types';\nimport * as util from '../util';\nimport {getAxesPermutation, getInnerMostAxes, parseAxisParam} from './axis_util';\nimport {concat} from './concat';\nimport {op} from './operation';\nimport {MPRandGauss} from './rand';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Creates a new tensor with the same values and shape as the specified\n * tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n *\n * x.clone().print();\n * ```\n *\n * @param x The tensor to clone.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction clone_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'clone');\n const der = (dy: T) => {\n return {$x: () => dy.toFloat()};\n };\n\n return ENV.engine.runKernel(\n backend =>\n Tensor.make($x.shape, {dataId: $x.dataId}, $x.dtype) as T,\n {$x}, der) as T;\n}\n\n/**\n * Create an identity matrix.\n *\n * @param numRows Number of rows.\n * @param numColumns Number of columns. Defaults to `numRows`.\n * @param batchShape If provided, will add the batch shape to the beginning\n * of the shape of the returned `Tensor` by repeating the identity\n * matrix.\n * @param dtype Data type.\n * @returns Identity matrix of the specified size and data type, possibly\n * with batch repetition if `batchShape` is specified.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction eye_(\n numRows: number, numColumns?: number,\n batchShape?:\n [\n number\n ]|[number,\n number]|[number, number, number]|[number, number, number, number],\n dtype: DataType = 'float32'): Tensor2D {\n if (numColumns == null) {\n numColumns = numRows;\n }\n const buff = buffer([numRows, numColumns], dtype);\n const n = numRows <= numColumns ? numRows : numColumns;\n for (let i = 0; i < n; ++i) {\n buff.set(1, i, i);\n }\n const out = buff.toTensor().as2D(numRows, numColumns);\n if (batchShape == null) {\n return out;\n } else {\n if (batchShape.length === 1) {\n return tile(expandDims(out, 0), [batchShape[0], 1, 1]);\n } else if (batchShape.length === 2) {\n return tile(\n expandDims(expandDims(out, 0), 0),\n [batchShape[0], batchShape[1], 1, 1]);\n } else if (batchShape.length === 3) {\n return tile(\n expandDims(expandDims(expandDims(out, 0), 0), 0),\n [batchShape[0], batchShape[1], batchShape[2], 1, 1]);\n } else {\n throw new Error(\n `eye() currently supports only 1D and 2D ` +\n // tslint:disable-next-line:no-any\n `batchShapes, but received ${(batchShape as any).length}D.`);\n }\n }\n}\n\n/**\n * Creates a `Tensor` with values sampled from a normal distribution.\n *\n * ```js\n * tf.randomNormal([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, false /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a truncated normal\n * distribution.\n *\n * ```js\n * tf.truncatedNormal([2, 2]).print();\n * ```\n *\n * The generated values follow a normal distribution with specified mean and\n * standard deviation, except that values whose magnitude is more than 2\n * standard deviations from the mean are dropped and re-picked.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param mean The mean of the normal distribution.\n * @param stdDev The standard deviation of the normal distribution.\n * @param dtype The data type of the output tensor.\n * @param seed The seed for the random number generator.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction truncatedNormal_(\n shape: ShapeMap[R], mean = 0, stdDev = 1, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n if (dtype != null && (dtype as DataType) === 'bool') {\n throw new Error(`Unsupported data type ${dtype}`);\n }\n const randGauss =\n new MPRandGauss(mean, stdDev, dtype, true /* truncated */, seed);\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = randGauss.nextValue();\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a uniform distribution.\n *\n * The generated values follow a uniform distribution in the range [minval,\n * maxval). The lower bound minval is included in the range, while the upper\n * bound maxval is excluded.\n *\n * ```js\n * tf.randomUniform([2, 2]).print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param minval The lower bound on the range of random values to generate.\n * Defaults to 0.\n * @param maxval The upper bound on the range of random values to generate.\n * Defaults to 1.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction randomUniform_(\n shape: ShapeMap[R], minval = 0, maxval = 1,\n dtype: DataType = 'float32'): Tensor {\n const res = buffer(shape, dtype);\n for (let i = 0; i < res.values.length; i++) {\n res.values[i] = util.randUniform(minval, maxval);\n }\n return res.toTensor();\n}\n\n/**\n * Creates a `Tensor` with values sampled from a random number generator\n * function defined by the user.\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param randFunction A random number generator function which is called\n * for each element in the output tensor.\n * @param dtype The data type of the output tensor. Defaults to 'float32'.\n */\nfunction rand_(\n shape: ShapeMap[R], randFunction: () => number,\n dtype?: DataType): Tensor {\n const size = util.sizeFromShape(shape);\n\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n\n for (let i = 0; i < size; i++) {\n values[i] = randFunction();\n }\n return Tensor.make(shape, {values}, dtype);\n}\n\n/**\n * Creates a `Tensor` with values drawn from a multinomial distribution.\n *\n * ```js\n * const probs = tf.tensor([.75, .25]);\n * tf.multinomial(probs, 3).print();\n * ```\n *\n * @param logits 1D array with unnormalized log-probabilities, or\n * 2D array of shape `[batchSize, numOutcomes]`. See the `normalized`\n * parameter.\n * @param numSamples Number of samples to draw for each row slice.\n * @param seed The seed number.\n * @param normalized Whether the provided `logits` are normalized true\n * probabilities (sum to 1). Defaults to false.\n * @return 1D array of shape `[numSamples]`, or 2D array of shape\n * `[batchSize, numSamples]`, depending on the rank of the input.\n */\n/** @doc {heading: 'Tensors', subheading: 'Random'} */\nfunction multinomial_(\n logits: Tensor1D|Tensor2D|TensorLike, numSamples: number, seed?: number,\n normalized = false): Tensor1D|Tensor2D {\n const $logits = convertToTensor(logits, 'logits', 'multinomial');\n const numOutcomes = $logits.size;\n const origRank = $logits.rank;\n if (numOutcomes < 2) {\n throw new Error(\n `Error in multinomial: you need at least 2 outcomes, but got ` +\n `${numOutcomes}.`);\n }\n if (origRank > 2) {\n throw new Error(`Rank of probabilities must be 1 or 2, but is ${origRank}`);\n }\n seed = seed || Math.random();\n const logits2D = origRank === 1 ? $logits.as2D(1, -1) : $logits as Tensor2D;\n const res = ENV.engine.runKernel(\n backend => backend.multinomial(logits2D, normalized, numSamples, seed),\n {logits2D});\n\n return origRank === 1 ? res.as1D() : res;\n}\n\n/**\n * Creates a one-hot `Tensor`. The locations represented by `indices` take\n * value `onValue` (defaults to 1), while all other locations take value\n * `offValue` (defaults to 0).\n *\n * ```js\n * tf.oneHot(tf.tensor1d([0, 1], 'int32'), 3).print();\n * ```\n *\n * @param indices `Tensor1D` of indices with dtype `int32`.\n * @param depth The depth of the one hot dimension.\n * @param onValue A number used to fill in output when the index matches\n * the location.\n * @param offValue A number used to fill in the output when the index does\n * not match the location.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction oneHot_(\n indices: Tensor1D|TensorLike1D, depth: number, onValue = 1,\n offValue = 0): Tensor2D {\n const $indices = convertToTensor(indices, 'indices', 'oneHot', 'int32');\n util.assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n\n if (depth < 2) {\n throw new Error(`Error in oneHot: depth must be >=2, but it is ${depth}`);\n }\n return ENV.engine.runKernel(\n backend => backend.oneHot($indices, depth, onValue, offValue),\n {$indices});\n}\n\n/**\n * Creates a `Tensor` from an image.\n *\n * ```js\n * const image = new ImageData(1, 1);\n * image.data[0] = 100;\n * image.data[1] = 150;\n * image.data[2] = 200;\n * image.data[3] = 255;\n *\n * tf.fromPixels(image).print();\n * ```\n *\n * @param pixels The input image to construct the tensor from. The\n * supported image types are all 4-channel.\n * @param numChannels The number of channels of the output tensor. A\n * numChannels value less than 4 allows you to ignore channels. Defaults to\n * 3 (ignores alpha channel of input image).\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction fromPixels_(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels = 3): Tensor3D {\n if (numChannels > 4) {\n throw new Error(\n 'Cannot construct Tensor with more than 4 channels from pixels.');\n }\n return ENV.engine.fromPixels(pixels, numChannels);\n}\n\n/**\n * Draws a `Tensor` of pixel values to a byte array or optionally a\n * canvas.\n *\n * When the dtype of the input is 'float32', we assume values in the range\n * [0-1]. Otherwise, when input is 'int32', we assume values in the range\n * [0-255].\n *\n * Returns a promise that resolves when the canvas has been drawn to.\n *\n * @param img A rank-2 or rank-3 tensor. If rank-2, draws grayscale. If\n * rank-3, must have depth of 1, 3 or 4. When depth of 1, draws\n * grayscale. When depth of 3, we draw with the first three components of\n * the depth dimension corresponding to r, g, b and alpha = 1. When depth of\n * 4, all four components of the depth dimension correspond to r, g, b, a.\n * @param canvas The canvas to draw to.\n */\n/** @doc {heading: 'Visualization'} */\nasync function toPixels(\n img: Tensor2D|Tensor3D|TensorLike,\n canvas?: HTMLCanvasElement): Promise {\n const $img = convertToTensor(img, 'img', 'toPixels', 'int32');\n if ($img.rank !== 2 && $img.rank !== 3) {\n throw new Error(\n `toPixels only supports rank 2 or 3 tensors, got rank ${$img.rank}.`);\n }\n const [height, width] = $img.shape.slice(0, 2);\n const depth = $img.rank === 2 ? 1 : $img.shape[2];\n\n if (depth > 4 || depth === 2) {\n throw new Error(\n `toPixels only supports depth of size ` +\n `1, 3 or 4 but got ${depth}`);\n }\n\n const minTensor = $img.min();\n const maxTensor = $img.max();\n const min = (await minTensor.data())[0];\n const max = (await maxTensor.data())[0];\n minTensor.dispose();\n maxTensor.dispose();\n if ($img.dtype === 'float32') {\n if (min < 0 || max > 1) {\n throw new Error(\n `Tensor values for a float32 Tensor must be in the ` +\n `range [0 - 1] but got range [${min} - ${max}].`);\n }\n } else if ($img.dtype === 'int32') {\n if (min < 0 || max > 255) {\n throw new Error(\n `Tensor values for a int32 Tensor must be in the ` +\n `range [0 - 255] but got range [${min} - ${max}].`);\n }\n } else {\n throw new Error(\n `Unsupported type for toPixels: ${$img.dtype}.` +\n ` Please use float32 or int32 tensors.`);\n }\n\n const data = await $img.data();\n const multiplier = $img.dtype === 'float32' ? 255 : 1;\n const bytes = new Uint8ClampedArray(width * height * 4);\n\n for (let i = 0; i < height * width; ++i) {\n let r, g, b, a;\n if (depth === 1) {\n r = data[i] * multiplier;\n g = data[i] * multiplier;\n b = data[i] * multiplier;\n a = 255;\n } else if (depth === 3) {\n r = data[i * 3] * multiplier;\n g = data[i * 3 + 1] * multiplier;\n b = data[i * 3 + 2] * multiplier;\n a = 255;\n } else if (depth === 4) {\n r = data[i * 4] * multiplier;\n g = data[i * 4 + 1] * multiplier;\n b = data[i * 4 + 2] * multiplier;\n a = data[i * 4 + 3] * multiplier;\n }\n\n const j = i * 4;\n bytes[j + 0] = Math.round(r);\n bytes[j + 1] = Math.round(g);\n bytes[j + 2] = Math.round(b);\n bytes[j + 3] = Math.round(a);\n }\n\n if (canvas != null) {\n canvas.width = width;\n canvas.height = height;\n const ctx = canvas.getContext('2d');\n const imageData = new ImageData(bytes, width, height);\n ctx.putImageData(imageData, 0, 0);\n }\n if ($img !== img) {\n $img.dispose();\n }\n return bytes;\n}\n\n/**\n * Reshapes a `Tensor` to a given shape.\n *\n * Given a input tensor, returns a new tensor with the same values as the\n * input tensor with shape `shape`.\n *\n * If one component of shape is the special value -1, the size of that\n * dimension is computed so that the total size remains constant. In\n * particular, a shape of [-1] flattens into 1-D. At most one component of\n * shape can be -1.\n *\n * If shape is 1-D or higher, then the operation returns a tensor with shape\n * shape filled with the values of tensor. In this case, the number of\n * elements implied by shape must be the same as the number of elements in\n * tensor.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.reshape([2, 2]).print();\n * ```\n *\n * @param x The input tensor to be reshaped.\n * @param shape An array of integers defining the output tensor shape.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction reshape_(\n x: Tensor|TensorLike, shape: ShapeMap[R2]): Tensor {\n const $x = convertToTensor(x, 'x', 'reshape');\n shape = util.inferFromImplicitShape(shape, $x.size);\n util.assert(\n $x.size === util.sizeFromShape(shape),\n 'new shape and old shape must have the same number of elements.');\n\n const grad = (dy: Tensor) => {\n return {$x: () => dy.reshape($x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.reshape($x, shape), {$x}, grad);\n}\n\n/**\n * Removes dimensions of size 1 from the shape of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4], [1, 1, 4]);\n * x.squeeze().print();\n * ```\n *\n * @param x The input tensor to be squeezed.\n * @param axis An optional list of numbers. If specified, only\n * squeezes the dimensions listed. The dimension index starts at 0. It\n * is an error to squeeze a dimension that is not 1.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction squeeze_(x: Tensor|TensorLike, axis?: number[]): T {\n const $x = convertToTensor(x, 'x', 'squeeze');\n return reshape($x, util.squeezeShape($x.shape, axis).newShape) as T;\n}\n\n/**\n * Casts a `Tensor` to a new dtype.\n *\n * ```js\n * const x = tf.tensor1d([1.5, 2.5, 3]);\n * tf.cast(x, 'int32').print();\n * ```\n * @param x The input tensor to be casted.\n * @param dtype The dtype to cast the input tensor to.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction cast_(x: T|TensorLike, dtype: DataType): T {\n const $x = convertToTensor(x, 'x', 'cast');\n\n const grad = (dy: T) => {\n return {$x: () => dy.clone()};\n };\n return ENV.engine.runKernel(backend => backend.cast($x, dtype), {$x}, grad) as\n T;\n}\n\n/**\n * Construct an tensor by repeating it the number of times given by reps.\n *\n * This operation creates a new tensor by replicating `input` `reps`\n * times. The output tensor's i'th dimension has `input.shape[i] *\n * reps[i]` elements, and the values of `input` are replicated\n * `reps[i]` times along the i'th dimension. For example, tiling\n * `[a, b, c, d]` by `[2]` produces `[a, b, c, d, a, b, c, d]`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n *\n * a.tile([2]).print(); // or a.tile([2])\n * ```\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.tile([1, 2]).print(); // or a.tile([1, 2])\n * ```\n * @param x The tensor to tile.\n * @param reps Determines the number of replications per dimension.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction tile_(x: T|TensorLike, reps: number[]): T {\n const $x = convertToTensor(x, 'x', 'tile');\n\n util.assert(\n $x.rank === reps.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of reps ${reps}.`);\n const grad = (dy: T) => {\n const derX = () => {\n let xGrad = zerosLike($x);\n // TODO(cais): Maybe reduce memory footprint by avoiding repeated\n // slicing.\n if ($x.rank === 1) {\n for (let i = 0; i < reps[0]; ++i) {\n xGrad = xGrad.add(dy.slice([i * $x.shape[0]], [$x.shape[0]]));\n }\n } else if ($x.rank === 2) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1]],\n [$x.shape[0], $x.shape[1]]));\n }\n }\n } else if ($x.rank === 3) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n xGrad = xGrad.add(dy.slice(\n [i * $x.shape[0], j * $x.shape[1], k * $x.shape[2]],\n [$x.shape[0], $x.shape[1], $x.shape[2]]));\n }\n }\n }\n } else if ($x.rank === 4) {\n for (let i = 0; i < reps[0]; ++i) {\n for (let j = 0; j < reps[1]; ++j) {\n for (let k = 0; k < reps[2]; ++k) {\n for (let l = 0; l < reps[3]; ++l) {\n xGrad = xGrad.add(dy.slice(\n [\n i * $x.shape[0], j * $x.shape[1], k * $x.shape[2],\n l * $x.shape[3]\n ],\n [$x.shape[0], $x.shape[1], $x.shape[2], $x.shape[3]]));\n }\n }\n }\n }\n } else {\n throw new Error(\n `Gradient for tile operation is not implemented for rank-` +\n `${$x.rank} tensors yet.`);\n }\n return xGrad;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(backend => backend.tile($x, reps), {$x}, grad);\n}\n\n/**\n * Pads a `Tensor1D` with a given value and paddings. See `pad` for details.\n */\nfunction pad1d_(\n x: Tensor1D|TensorLike, paddings: [number, number],\n constantValue = 0): Tensor1D {\n util.assert(\n paddings.length === 2,\n 'Invalid number of paddings. Must be length of 2.');\n return pad(x, [paddings], constantValue);\n}\n\n/**\n * Pads a `Tensor2D` with a given value and paddings. See `pad` for details.\n */\nfunction pad2d_(\n x: Tensor2D|TensorLike, paddings: [[number, number], [number, number]],\n constantValue = 0): Tensor2D {\n util.assert(\n paddings.length === 2 && paddings[0].length === 2 &&\n paddings[1].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor3D` with a given value and paddings. See `pad` for details.\n */\nfunction pad3d_(\n x: Tensor3D|TensorLike,\n paddings: [[number, number], [number, number], [number, number]],\n constantValue = 0): Tensor3D {\n util.assert(\n paddings.length === 3 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor4D` with a given value and paddings. See `pad` for details.\n */\nfunction pad4d_(\n x: Tensor4D|TensorLike,\n paddings:\n [\n [number, number], [number, number], [number, number],\n [number, number]\n ],\n constantValue = 0): Tensor4D {\n util.assert(\n paddings.length === 4 && paddings[0].length === 2 &&\n paddings[1].length === 2 && paddings[2].length === 2 &&\n paddings[3].length === 2,\n 'Invalid number of paddings. Must be length of 2 each.');\n return pad(x, paddings, constantValue);\n}\n\n/**\n * Pads a `Tensor` with a given value and paddings.\n *\n * This operation currently only implements the `CONSTANT` mode.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `paddings` is of given length.\n * - `tf.pad1d`\n * - `tf.pad2d`\n * - `tf.pad3d`\n * - `tf.pad4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * x.pad([[1, 2]]).print();\n * ```\n * @param x The tensor to pad.\n * @param paddings An array of length `R` (the rank of the tensor), where\n * each element is a length-2 tuple of ints `[padBefore, padAfter]`,\n * specifying how much to pad along each dimension of the tensor.\n * @param constantValue The pad value to use. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction pad_(\n x: T|TensorLike, paddings: Array<[number, number]>, constantValue = 0): T {\n const $x = convertToTensor(x, 'x', 'pad');\n\n if ($x.rank === 0) {\n throw new Error('pad(scalar) is not defined. Pass non-scalar to pad');\n }\n // Pad introduces values around the original tensor, so the gradient\n // slices the original shape out of the gradient.\n const begin = paddings.map(p => p[0]);\n const grad = (dy: T) => {\n return {$x: () => dy.slice(begin, $x.shape)};\n };\n return ENV.engine.runKernel(\n backend => backend.pad($x, paddings, constantValue), {$x}, grad) as\n T;\n}\n\n/**\n * Stacks a list of rank-`R` `Tensor`s into one rank-`(R+1)` `Tensor`.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n * tf.stack([a, b, c]).print();\n * ```\n *\n * @param tensors A list of tensor objects with the same shape and dtype.\n * @param axis The axis to stack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction stack_(tensors: T[]|TensorLike[], axis = 0): Tensor {\n const $tensors = convertToTensorArray(tensors, 'tensors', 'stack');\n\n util.assert($tensors.length >= 1, 'Pass at least one tensor to tf.stack');\n if ($tensors.length === 1) {\n return $tensors[0].expandDims(axis);\n }\n const rank = $tensors[0].rank;\n const shape = $tensors[0].shape;\n const dtype = $tensors[0].dtype;\n\n util.assert(axis <= rank, 'Axis must be <= rank of the tensor');\n\n $tensors.forEach(t => {\n util.assertShapesMatch(\n shape, t.shape,\n 'All tensors passed to stack must have matching shapes');\n });\n\n $tensors.forEach(t => {\n util.assert(\n dtype === t.dtype,\n 'All tensors passed to stack must have matching dtypes');\n });\n const expandedTensors = $tensors.map(t => t.expandDims(axis));\n return concat(expandedTensors, axis);\n}\n\n/**\n * This operation reshapes the \"batch\" dimension 0 into `M + 1` dimensions of\n * shape `blockShape + [batch]`, interleaves these blocks back into the grid\n * defined by the spatial dimensions `[1, ..., M]`, to obtain a result with\n * the same rank as the input. The spatial dimensions of this intermediate\n * result are then optionally cropped according to `crops` to produce the\n * output. This is the reverse of `spaceToBatchND`. See below for a precise\n * description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const crops = [[0, 0], [0, 0]];\n *\n * x.batchToSpaceND(blockShape, crops).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param crops A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `crops[i] =\n * [cropStart, cropEnd]` specifies the amount to crop from input dimension `i\n * + 1`, which corresponds to spatial dimension `i`. It is required that\n * `cropStart[i] + cropEnd[i] <= blockShape[i] * inputShape[i + 1]`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Reshape `x` to `reshaped` of shape: `[blockShape[0], ...,\n * blockShape[M-1], batch / prod(blockShape), x.shape[1], ...,\n * x.shape[N-1]]`\n *\n * 2. Permute dimensions of `reshaped`to produce `permuted` of shape `[batch /\n * prod(blockShape),x.shape[1], blockShape[0], ..., x.shape[M],\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 3. Reshape `permuted` to produce `reshapedPermuted` of shape `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0], ..., x.shape[M] *\n * blockShape[M-1],x.shape[M+1], ..., x.shape[N-1]]`\n *\n * 4. Crop the start and end of dimensions `[1, ..., M]` of `reshapedPermuted`\n * according to `crops` to produce the output of shape: `[batch /\n * prod(blockShape),x.shape[1] * blockShape[0] - crops[0,0] - crops[0,1],\n * ..., x.shape[M] * blockShape[M-1] - crops[M-1,0] -\n * crops[M-1,1],x.shape[M+1], ..., x.shape[N-1]]`\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction batchToSpaceND_(\n x: T|TensorLike, blockShape: number[], crops: number[][]): T {\n const $x = convertToTensor(x, 'x', 'batchToSpaceND');\n const prod = blockShape.reduce((a, b) => a * b);\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n crops.length === blockShape.length,\n `crops.shape[0] must be equal to [blockShape] but got ${crops.length}`);\n\n util.assert(\n $x.shape[0] % prod === 0,\n `input tensor batch must be divisible by prod( blockShape )`);\n return ENV.engine.runKernel(\n backend => backend.batchToSpaceND($x, blockShape, crops), {});\n}\n\n/**\n * This operation divides \"spatial\" dimensions [1, ..., M] of the input into\n * a grid of blocks of shape block_shape, and interleaves these blocks with\n * the \"batch\" dimension (0) such that in the output, the spatial\n * dimensions [1, ..., M] correspond to the position within the grid,\n * and the batch dimension combines both the position within a spatial block\n * and the original batch position. Prior to division into blocks,\n * the spatial dimensions of the input are optionally zero padded\n * according to paddings. See below for a precise description.\n *\n * ```js\n * const x = tf.tensor4d([1, 2, 3, 4], [4, 1, 1, 1]);\n * const blockShape = [2, 2];\n * const paddings = [[0, 0], [0, 0]];\n *\n * x.spaceToBatchND(blockShape, paddings).print();\n * ```\n *\n * @param x A `Tensor`. N-D with `x.shape` = `[batch] + spatialShape +\n * remainingShape`, where spatialShape has `M` dimensions.\n * @param blockShape A 1-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M]`, all values must be >= 1.\n * @param paddings A 2-D array. Must be one of the following types: `int32`,\n * `int64`. Must have shape `[M, 2]`, all values must be >= 0. `paddings[i] =\n * [padStart, padEnd]` specifies the amount to zero-pad from input dimension\n * `i + 1`, which corresponds to spatial dimension `i`.\n * It is required that\n * `(inputShape[i + 1] + padStart + padEnd) % blockShape[i] === 0`\n *\n * This operation is equivalent to the following steps:\n *\n * 1. Zero-pad the start and end of dimensions [1, ..., M] of the input\n * according to paddings to produce padded of shape padded_shape.\n *\n * 2. Reshape padded to reshaped_padded of shape:\n * [batch] + [padded_shape[1] / block_shape[0], block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1], block_shape[M-1]] + remaining_shape\n *\n * 3. Permute dimensions of reshaped_padded to produce permuted_\n * reshaped_padded of shape:\n * block_shape + [batch] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n *\n * 4. Reshape permuted_reshaped_padded to flatten block_shape into the\n * batch dimension, producing an output tensor of shape:\n * [batch * prod(block_shape)] + [padded_shape[1] / block_shape[0], ...,\n * padded_shape[M] / block_shape[M-1]] + remaining_shape\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction spaceToBatchND_(\n x: T|TensorLike, blockShape: number[], paddings: number[][]): T {\n const $x = convertToTensor(x, 'x', 'spaceToBatchND');\n\n util.assert(\n $x.rank >= 1 + blockShape.length,\n `input rank should be > than [blockShape] but got ${$x.rank}`);\n\n util.assert(\n paddings.length === blockShape.length,\n `paddings.shape[0] must be equal to [blockShape], got ${\n paddings.length}`);\n\n util.assert($x.shape.reduce((a, b, i) => {\n if (i > 0 && i <= blockShape.length) {\n return a && (b % blockShape[i - 1] === 0);\n }\n return a;\n }, true), `input spatial dimensions must be divisible by blockShapes`);\n return ENV.engine.runKernel(\n backend => backend.spaceToBatchND($x, blockShape, paddings), {});\n}\n\n/**\n * Unstacks a `Tensor` of rank-`R` into a list of rank-`(R-1)` `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * tf.unstack(a).forEach(tensor => tensor.print());\n * ```\n *\n * @param x A tensor object.\n * @param axis The axis to unstack along. Defaults to 0 (the first dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction unstack_(x: T|TensorLike, axis = 0): Tensor[] {\n const $x = convertToTensor(x, 'x', 'unstack');\n const num = $x.shape[axis];\n const outputShape: number[] = Array($x.rank - 1).fill(0);\n let outIndex = 0;\n for (let i = 0; i < $x.rank; i++) {\n if (i !== axis) {\n outputShape[outIndex] = $x.shape[i];\n outIndex++;\n }\n }\n\n let splitSizes: number[];\n splitSizes = Array(num).fill(1);\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice.reshape(outputShape);\n });\n}\n\n/**\n * Splits a `Tensor` into sub tensors.\n *\n * If `numOrSizeSplits` is a number, splits `x` along dimension `axis`\n * into `numOrSizeSplits` smaller tensors.\n * Requires that `numOrSizeSplits` evenly divides `x.shape[axis]`.\n *\n * If `numOrSizeSplits` is a number array, splits `x` into\n * `(numOrSizeSplits.length` pieces. The shape of the `i`-th piece has the\n * same size as `x` except along dimension `axis` where the size is\n * `numOrSizeSplits[i]`.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8], [2, 4]);\n * const [a, b] = tf.split(x, 2, 1);\n * a.print();\n * b.print();\n *\n * const [c, d, e] = tf.split(x, [1, 2, 1], 1);\n * c.print();\n * d.print();\n * e.print();\n * ```\n *\n * @param x The input tensor to split.\n * @param numOrSizeSplits Either an integer indicating the number of\n * splits along the axis or an array of integers containing the sizes of\n * each output tensor along the axis. If a number then it must evenly divide\n * `x.shape[axis]`; otherwise the sum of sizes must match `x.shape[axis]`.\n * @param axis The dimension along which to split. Defaults to 0 (the first\n * dim).\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction split_(\n x: T|TensorLike, numOrSizeSplits: number[]|number, axis = 0): T[] {\n const $x = convertToTensor(x, 'x', 'split');\n\n axis = parseAxisParam(axis, $x.shape)[0];\n let splitSizes: number[];\n if (typeof (numOrSizeSplits) === 'number') {\n util.assert(\n $x.shape[axis] % numOrSizeSplits === 0,\n 'Number of splits must evenly divide the axis.');\n splitSizes = Array(numOrSizeSplits).fill($x.shape[axis] / numOrSizeSplits);\n } else {\n util.assert(\n $x.shape[axis] === numOrSizeSplits.reduce((a, b) => a + b),\n 'The sum of sizes must match the size of the axis dimension.');\n splitSizes = numOrSizeSplits;\n }\n const begin = Array($x.rank).fill(0);\n const size = $x.shape.slice();\n return splitSizes.map(s => {\n size[axis] = s;\n const slice = $x.slice(begin, size);\n begin[axis] += s;\n return slice;\n });\n}\n\n/**\n * Computes the cumulative sum of a `Tensor` along `axis`.\n *\n * ```js\n * const x = tf.tensor([1, 2, 3, 4]);\n * x.cumsum().print();\n * ```\n * ```js\n * const x = tf.tensor([[1, 2], [3, 4]]);\n * x.cumsum().print();\n * ```\n *\n * @param x The input tensor to be summed.\n * @param axis The axis along which to sum. Optional. Defaults to 0.\n * @param exclusive Whether to perform exclusive cumulative sum. Optional.\n * Defaults to false. If set to true then the sum of each tensor entry\n * does not include its own value, but only the values previous to it\n * along the specified axis.\n * @param reverse Whether to sum in the opposite direction. Optional.\n * Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Scan'} */\nfunction cumsum_(\n x: Tensor|TensorLike, axis = 0, exclusive = false, reverse = false): T {\n const $x = convertToTensor(x, 'x', 'cumsum');\n\n axis = axis | 0;\n const permutation = getAxesPermutation([axis], $x.rank);\n let permutedX = $x;\n if (permutation != null) {\n permutedX = $x.transpose(permutation);\n }\n const permutedAxis = getInnerMostAxes(1, $x.rank)[0];\n\n const grad = (dy: T) => {\n return {permutedX: () => dy.cumsum(axis, exclusive, !reverse)};\n };\n let value = ENV.engine.runKernel(\n backend => backend.cumsum(\n permutedX, permutedAxis, exclusive, reverse),\n {permutedX}, grad) as T;\n\n if (permutation != null) {\n value = value.transpose(permutation);\n }\n return value;\n}\n\n/**\n * Returns a `Tensor` that has expanded rank, by inserting a dimension\n * into the tensor's shape.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const axis = 1;\n * x.expandDims(axis).print();\n * ```\n *\n * @param x The input tensor whose dimensions to be expanded.\n * @param axis The dimension index at which to insert shape of `1`. Defaults\n * to 0 (the first dimension).\n */\n/** @doc {heading: 'Tensors', subheading: 'Transformations'} */\nfunction expandDims_(\n x: Tensor|TensorLike, axis = 0): Tensor {\n const $x = convertToTensor(x, 'x', 'expandDims');\n\n util.assert(axis <= $x.rank, 'Axis must be <= rank of the tensor');\n const newShape = $x.shape.slice();\n if (axis < 0) {\n // Negative value is counted from the tail of rank.\n util.assert(\n -($x.rank + 1) <= axis,\n `Axis must be in the interval [${- ($x.rank + 1)}, ${$x.rank}]`);\n axis = $x.rank + axis + 1;\n }\n newShape.splice(axis, 0, 1);\n return reshape($x, newShape);\n}\n\n/**\n * Creates an empty `TensorBuffer` with the specified `shape` and `dtype`.\n *\n * The values are stored in cpu as `TypedArray`. Fill the buffer using\n * `buffer.set()`, or by modifying directly `buffer.values`.\n *\n * When done, call `buffer.toTensor()` to get an immutable `Tensor` with\n * those values.\n *\n * ```js\n * // Create a buffer and set values at particular indices.\n * const buffer = tf.buffer([2, 2]);\n * buffer.set(3, 0, 0);\n * buffer.set(5, 1, 0);\n *\n * // Convert the buffer back to a tensor.\n * buffer.toTensor().print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The dtype of the buffer. Defaults to 'float32'.\n * @param values The values of the buffer as `TypedArray`. Defaults to\n * zeros.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction buffer(\n shape: ShapeMap[R], dtype: DataType = 'float32',\n values?: TypedArray): TensorBuffer {\n return new TensorBuffer(shape, dtype, values);\n}\n\n/**\n * Prints information about the `Tensor` including its data.\n *\n * ```js\n * const verbose = true;\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print(verbose);\n * ```\n * @param x The tensor to be printed.\n * @param verbose Whether to print verbose information about the ` Tensor`,\n * including dtype and size.\n */\n/** @doc {heading: 'Tensors', subheading: 'Creation'} */\nfunction print(x: T, verbose = false): void {\n console.log(x.toString(verbose));\n}\n\nexport {\n buffer, // Not wrapped in op() since no tensors.\n toPixels, // Not wrapped in op() since async.\n print // Not wrapped in op() since no need to increase stack trace.\n};\n\nexport const cast = op({cast_});\nexport const clone = op({clone_});\nexport const cumsum = op({cumsum_});\nexport const expandDims = op({expandDims_});\nexport const eye = op({eye_});\nexport const fromPixels = op({fromPixels_});\nexport const multinomial = op({multinomial_});\nexport const oneHot = op({oneHot_});\nexport const pad = op({pad_});\nexport const pad1d = op({pad1d_});\nexport const pad2d = op({pad2d_});\nexport const pad3d = op({pad3d_});\nexport const pad4d = op({pad4d_});\nexport const rand = op({rand_});\nexport const randomNormal = op({randomNormal_});\nexport const randomUniform = op({randomUniform_});\nexport const reshape = op({reshape_});\nexport const split = op({split_});\nexport const squeeze = op({squeeze_});\nexport const stack = op({stack_});\nexport const tile = op({tile_});\nexport const truncatedNormal = op({truncatedNormal_});\nexport const unstack = op({unstack_});\nexport const batchToSpaceND = op({batchToSpaceND_});\nexport const spaceToBatchND = op({spaceToBatchND_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** An implementation of the Where kernel shared between cpu and webgl */\n\nimport {buffer} from '../ops/array_ops';\nimport {Tensor2D} from '../tensor';\nimport {TypedArray} from '../types';\n\nexport function whereImpl(condShape: number[], condVals: TypedArray): Tensor2D {\n const indices = [];\n for (let i = 0; i < condVals.length; i++) {\n if (condVals[i]) {\n indices.push(i);\n }\n }\n\n const inBuffer = buffer(condShape, 'int32');\n\n const out = buffer([indices.length, condShape.length], 'int32');\n for (let i = 0; i < indices.length; i++) {\n const loc = inBuffer.indexToLoc(indices[i]);\n const offset = i * condShape.length;\n out.values.set(loc, offset);\n }\n return out.toTensor() as Tensor2D;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {MemoryInfo, TimingInfo} from '../engine';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as reduce_util from '../ops/reduce_util';\nimport * as segment_util from '../ops/segment_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {softmax} from '../ops/softmax';\nimport {range, tensor} from '../ops/tensor_ops';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, RecursiveArray, ShapeMap, sumOutType, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\n\nimport {KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {ArgMinMaxProgram} from './webgl/argminmax_gpu';\nimport {AvgPool2DBackpropProgram} from './webgl/avg_pool_backprop_gpu';\nimport {BatchNormProgram} from './webgl/batchnorm_gpu';\nimport * as binaryop_gpu from './webgl/binaryop_gpu';\nimport {BinaryOpProgram} from './webgl/binaryop_gpu';\nimport {ClipProgram} from './webgl/clip_gpu';\nimport {ConcatProgram} from './webgl/concat_gpu';\nimport {Conv2DDerFilterProgram, Conv2DDerInputProgram} from './webgl/conv_backprop_gpu';\nimport {DepthwiseConv2DDerFilterProgram, DepthwiseConv2DDerInputProgram} from './webgl/conv_backprop_gpu_depthwise';\nimport {Conv2DProgram} from './webgl/conv_gpu';\nimport {DepthwiseConv2DProgram} from './webgl/conv_gpu_depthwise';\nimport {CumSumProgram} from './webgl/cumsum_gpu';\nimport {EncodeFloatProgram} from './webgl/encode_float_gpu';\nimport {FromPixelsProgram} from './webgl/from_pixels_gpu';\nimport {GatherProgram} from './webgl/gather_gpu';\nimport {GPGPUContext} from './webgl/gpgpu_context';\nimport * as gpgpu_math from './webgl/gpgpu_math';\nimport {GPGPUBinary, GPGPUProgram, TensorData} from './webgl/gpgpu_math';\nimport * as gpgpu_util from './webgl/gpgpu_util';\nimport {LRNProgram} from './webgl/lrn_gpu';\nimport {LRNGradProgram} from './webgl/lrn_grad_gpu';\nimport {MaxPool2DBackpropProgram} from './webgl/max_pool_backprop_gpu';\nimport {MatMulProgram} from './webgl/mulmat_gpu';\nimport {MultinomialProgram} from './webgl/multinomial_gpu';\nimport {OneHotProgram} from './webgl/onehot_gpu';\nimport {PadProgram} from './webgl/pad_gpu';\nimport {Pool2DProgram} from './webgl/pool_gpu';\nimport {ReduceProgram} from './webgl/reduce_gpu';\nimport {ResizeBilinearBackpropProgram} from './webgl/resize_bilinear_backprop_gpu';\nimport {ResizeBilinearProgram} from './webgl/resize_bilinear_gpu';\nimport {ResizeNearestNeigborBackpropProgram} from './webgl/resize_nearest_neighbor_backprop_gpu';\nimport {ResizeNearestNeighborProgram} from './webgl/resize_nearest_neighbor_gpu';\nimport {ReverseProgram} from './webgl/reverse_gpu';\nimport {SegmentOpProgram} from './webgl/segment_gpu';\nimport {SelectProgram} from './webgl/select_gpu';\nimport {SliceProgram} from './webgl/slice_gpu';\nimport {StridedSliceProgram} from './webgl/strided_slice_gpu';\nimport {TextureData, TextureUsage} from './webgl/tex_util';\nimport {TextureManager} from './webgl/texture_manager';\nimport {TileProgram} from './webgl/tile_gpu';\nimport {TransposeProgram} from './webgl/transpose_gpu';\nimport * as unary_op from './webgl/unaryop_gpu';\nimport {UnaryOpProgram} from './webgl/unaryop_gpu';\nimport * as webgl_util from './webgl/webgl_util';\nimport {whereImpl} from './where_impl';\n\ntype TimerNode = RecursiveArray>|Promise;\nexport interface CPUTimerQuery {\n startMs: number;\n endMs?: number;\n}\n\nexport interface WebGLMemoryInfo extends MemoryInfo {\n numBytesInGPU: number;\n unreliable: boolean;\n}\n\nexport interface WebGLTimingInfo extends TimingInfo {\n uploadWaitMs: number;\n downloadWaitMs: number;\n}\n\n// Empirically determined constant used to decide the number of bytes on GPU\n// before we start paging. The bytes are this constant * screen area * dpi.\nconst BEFORE_PAGING_CONSTANT = 300;\n// Tensors with size <= than this will be uploaded as uniforms, not textures.\nexport const SIZE_UPLOAD_UNIFORM = 32;\n\nexport class MathBackendWebGL implements KernelBackend {\n private texData = new WeakMap();\n // Maps data ids that have a pending read operation, to list of subscribers.\n private pendingRead = new WeakMap void>>();\n // List of data ids that are scheduled for disposal, but are waiting on a\n // pending read operation.\n private pendingDisposal = new WeakSet();\n // List of data ids that are currently residing on gpu memory. Sorted with\n // least recently used being first.\n private lruDataGPU: DataId[] = [];\n private numBytesInGPU = 0;\n /**\n * Number of bytes allocated on the GPU before we start moving data to cpu.\n * Moving avoids gpu memory leaks and relies on JS's garbage collector.\n */\n private NUM_BYTES_BEFORE_PAGING: number;\n\n private canvas: HTMLCanvasElement;\n private fromPixelsCanvas: HTMLCanvasElement;\n\n private programTimersStack: TimerNode[];\n private activeTimers: TimerNode[];\n // Accumulated time spent (including blocking) in uploading data to webgl.\n private uploadWaitMs = 0;\n // Accumulated time spent (including blocking in downloading data from webgl.\n private downloadWaitMs = 0;\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.texData.has(dataId)) {\n throw new Error('Data buffer is already registered');\n }\n this.texData.set(dataId, {\n shape,\n dtype,\n values: null,\n texture: null,\n texShape: null,\n usage: TextureUsage.RENDER\n });\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n const texShape: [number, number] = [pixels.height, pixels.width];\n const outShape = [pixels.height, pixels.width, numChannels];\n\n if (!(pixels instanceof HTMLVideoElement) &&\n !(pixels instanceof HTMLImageElement) &&\n !(pixels instanceof HTMLCanvasElement) &&\n !(pixels instanceof ImageData)) {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n if (pixels instanceof HTMLVideoElement) {\n if (this.fromPixelsCanvas == null) {\n if (!ENV.get('IS_BROWSER')) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside the browser.');\n }\n if (document.readyState !== 'complete') {\n throw new Error(\n 'The DOM is not ready yet. Please call tf.fromPixels() ' +\n 'once the DOM is ready. One way to do that is to add an event ' +\n 'listener for `DOMContentLoaded` on the document object');\n }\n this.fromPixelsCanvas = document.createElement('canvas');\n }\n this.fromPixelsCanvas.width = pixels.width;\n this.fromPixelsCanvas.height = pixels.height;\n this.fromPixelsCanvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n pixels = this.fromPixelsCanvas;\n }\n const tempPixelArray = Tensor.make(texShape, {}, 'int32');\n\n // This is a byte texture with pixels.\n this.texData.get(tempPixelArray.dataId).usage = TextureUsage.PIXELS;\n this.gpgpu.uploadPixelDataToTexture(\n this.getTexture(tempPixelArray.dataId), pixels);\n const program = new FromPixelsProgram(outShape);\n const res = this.compileAndRun(program, [tempPixelArray]);\n\n tempPixelArray.dispose();\n\n return res as Tensor3D;\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendWebGL.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n\n const texData = this.texData.get(dataId);\n const {texture, texShape, usage} = texData;\n if (texture != null) {\n // Release the old texture.\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n texData.usage = TextureUsage.UPLOAD;\n texData.values = values;\n\n if (!this.delayedStorage) {\n this.uploadToGPU(dataId);\n }\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n\n const float32Values =\n this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n\n if (shouldTimeProgram) {\n this.downloadWaitMs += performance.now() - start;\n }\n this.cacheOnCPU(dataId, float32Values);\n return texData.values;\n }\n\n async read(dataId: DataId): Promise {\n if (this.pendingRead.has(dataId)) {\n const subscribers = this.pendingRead.get(dataId);\n return new Promise(resolve => subscribers.push(resolve));\n }\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, texture, values, texShape, dtype} = texData;\n if (values != null) {\n this.cacheOnCPU(dataId);\n return values;\n }\n\n this.pendingRead.set(dataId, []);\n\n if (!ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED') &&\n ENV.get('WEBGL_VERSION') === 2) {\n throw new Error(\n `tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and ` +\n `WEBGL_VERSION=2 not yet supported.`);\n }\n\n // Possibly copy the texture into a buffer before inserting a fence.\n const bufferOrTexture = this.gpgpu.maybeCreateBufferFromTexture(\n texture, texShape[0], texShape[1]);\n\n // Create a fence and wait for it to resolve.\n await this.gpgpu.createAndWaitForFence();\n\n // Download the values from the GPU.\n let vals: Float32Array;\n if (bufferOrTexture instanceof WebGLTexture) {\n vals = this.getValuesFromTexture(texture, dataId, dtype, texShape, shape);\n } else {\n vals = this.gpgpu.downloadFloat32MatrixFromBuffer(\n bufferOrTexture, texShape[0], texShape[1]);\n }\n this.cacheOnCPU(dataId, vals);\n\n const subscribers = this.pendingRead.get(dataId);\n this.pendingRead.delete(dataId);\n\n // Notify all pending reads.\n subscribers.forEach(resolve => resolve(vals));\n if (this.pendingDisposal.has(dataId)) {\n this.pendingDisposal.delete(dataId);\n this.disposeData(dataId);\n }\n return vals;\n }\n\n private getValuesFromTexture(\n texture: WebGLTexture, dataId: DataId, dtype: DataType,\n texShape: [number, number], shape: number[]): Float32Array {\n if (ENV.get('WEBGL_DOWNLOAD_FLOAT_ENABLED')) {\n return this.gpgpu.downloadFloat32MatrixFromOutputTexture(\n texture, texShape[0], texShape[1]);\n }\n\n const tmpTarget = Tensor.make(shape, {});\n this.texData.get(tmpTarget.dataId).usage = TextureUsage.DOWNLOAD;\n\n const tmpInput = Tensor.make(shape, {dataId}, dtype);\n const program = new EncodeFloatProgram(shape);\n const pageToCpu = false;\n this.compileAndRun(program, [tmpInput], tmpTarget, null, pageToCpu);\n const tmpData = this.texData.get(tmpTarget.dataId);\n const vals = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(\n tmpData.texture, tmpData.texShape[0], tmpData.texShape[1]);\n\n tmpInput.dispose();\n tmpTarget.dispose();\n\n return vals;\n }\n\n async time(f: () => void): Promise {\n const oldActiveTimers = this.activeTimers;\n const newActiveTimers: TimerNode[] = [];\n\n let outerMostTime = false;\n if (this.programTimersStack == null) {\n this.programTimersStack = newActiveTimers;\n outerMostTime = true;\n } else {\n this.activeTimers.push(newActiveTimers);\n }\n this.activeTimers = newActiveTimers;\n\n f();\n\n const flattenedActiveTimers = util.flatten(this.activeTimers);\n this.activeTimers = oldActiveTimers;\n\n if (outerMostTime) {\n this.programTimersStack = null;\n }\n\n const kernelMs = await Promise.all(flattenedActiveTimers).then(results => {\n let sum = 0;\n results.forEach(result => sum += result);\n return sum;\n });\n const res: WebGLTimingInfo = {\n uploadWaitMs: this.uploadWaitMs,\n downloadWaitMs: this.downloadWaitMs,\n kernelMs,\n wallMs: null // will be filled by the engine\n };\n this.uploadWaitMs = 0;\n this.downloadWaitMs = 0;\n return res;\n }\n memory(): WebGLMemoryInfo {\n return {unreliable: false, numBytesInGPU: this.numBytesInGPU} as\n WebGLMemoryInfo;\n }\n\n private startTimer(): WebGLQuery|CPUTimerQuery {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.beginQuery();\n }\n return {startMs: performance.now(), endMs: null};\n }\n\n private endTimer(query: WebGLQuery|CPUTimerQuery): WebGLQuery|\n {startMs: number, endMs: number} {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n this.gpgpu.endQuery();\n return query;\n }\n (query as CPUTimerQuery).endMs = performance.now();\n return query;\n }\n\n private async getQueryTime(query: WebGLQuery|CPUTimerQuery): Promise {\n if (ENV.get('WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION') > 0) {\n return this.gpgpu.waitForQueryAndGetTime(query);\n }\n const timerQuery = query as CPUTimerQuery;\n return timerQuery.endMs - timerQuery.startMs;\n }\n\n disposeData(dataId: DataId): void {\n if (this.pendingDisposal.has(dataId)) {\n return;\n }\n if (this.pendingRead.has(dataId)) {\n this.pendingDisposal.add(dataId);\n return;\n }\n if (this.texData.has(dataId)) {\n const {texture, texShape, usage} = this.texData.get(dataId);\n if (texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n }\n this.texData.delete(dataId);\n }\n }\n\n getTexture(dataId: DataId): WebGLTexture {\n this.uploadToGPU(dataId);\n return this.texData.get(dataId).texture;\n }\n\n private textureManager: TextureManager;\n private binaryCache: {[key: string]: GPGPUBinary} = {};\n private gpgpuCreatedLocally: boolean;\n\n constructor(private gpgpu?: GPGPUContext, private delayedStorage = true) {\n if (ENV.get('WEBGL_VERSION') < 1) {\n throw new Error('WebGL is not supported on this device');\n }\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n if (gpgpu == null) {\n this.gpgpu = new GPGPUContext(gpgpu_util.createWebGLContext(this.canvas));\n this.gpgpuCreatedLocally = true;\n } else {\n this.gpgpuCreatedLocally = false;\n }\n // Use the device screen's resolution as a heuristic to decide on the\n // maximum memory allocated on the GPU before starting to page.\n this.NUM_BYTES_BEFORE_PAGING =\n (window.screen.height * window.screen.width * window.devicePixelRatio) *\n BEFORE_PAGING_CONSTANT;\n this.textureManager = new TextureManager(this.gpgpu);\n }\n\n getGPGPUContext(): GPGPUContext {\n return this.gpgpu;\n }\n getCanvas(): HTMLCanvasElement {\n return this.canvas;\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const program = new SliceProgram(size);\n const customSetup = program.getCustomSetupFunc(begin);\n return this.compileAndRun(program, [x], null, customSetup);\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return tensor([], size) as T;\n }\n\n const program = new StridedSliceProgram(beginIndex, strides, size);\n return this.compileAndRun(program, [x]);\n }\n\n reverse(x: T, axis: number[]): T {\n const program = new ReverseProgram(x.shape, axis);\n return this.compileAndRun(program, [x]);\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const program = new ConcatProgram(a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n neg(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.NEG);\n return this.compileAndRun(program, [x]) as T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const program = new MatMulProgram(a.shape, b.shape, transposeA, transposeB);\n return this.compileAndRun(program, [a, b]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MUL, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output) as Tensor;\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const inputs = [x, mean, variance];\n\n let offsetShape = null;\n if (offset != null) {\n offsetShape = offset.shape;\n inputs.push(offset);\n }\n\n let scaleShape = null;\n if (scale != null) {\n scaleShape = scale.shape;\n inputs.push(scale);\n }\n\n const program = new BatchNormProgram(\n x.shape, mean.shape, variance.shape, offsetShape, scaleShape,\n varianceEpsilon);\n return this.compileAndRun(program, inputs);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program = new LRNProgram(x.shape, radius, bias, alpha, beta);\n return this.compileAndRun(program, [x]);\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const program =\n new LRNGradProgram(inputImage.shape, depthRadius, bias, alpha, beta);\n return this.compileAndRun(program, [inputImage, outputImage, dy]);\n }\n\n tile(x: T, reps: number[]): T {\n const program = new TileProgram(x.shape, reps);\n return this.compileAndRun(program, [x]);\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const program = new PadProgram(x.shape, paddings, constantValue);\n return this.compileAndRun(program, [x]);\n }\n\n transpose(x: T, perm: number[]): T {\n const program = new TransposeProgram(x.shape, perm);\n return this.compileAndRun(program, [x]);\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const program = new GatherProgram(x.shape, indices.size, axis);\n return this.compileAndRun(program, [x, indices]);\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n util.assert(\n x.rank <= 4,\n 'batchToSpaceND for rank > 4 with a WebGL backend not implemented yet');\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n util.assert(\n x.rank <= 4,\n 'spaceToBatchND for rank > 4 with a WebGL backend not implemented yet');\n\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private reduce(\n x: Tensor2D, reduceType: 'all'|'any'|'max'|'min'|'sum',\n dtype: DataType): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program = new ReduceProgram(reduceInfo, reduceType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.reduce(output, reduceType, dtype);\n }\n\n private argReduce(\n x: Tensor2D, reduceType: 'max'|'min',\n bestIndicesA: Tensor2D = null): Tensor2D {\n let batchSize = x.shape[0];\n let inSize = x.shape[1];\n if (bestIndicesA != null) {\n batchSize = bestIndicesA.shape[0];\n inSize = bestIndicesA.shape[1];\n }\n const windowSize = reduce_util.computeOptimalWindowSize(inSize);\n const reduceInfo = {windowSize, inSize, batchSize};\n const program =\n new ArgMinMaxProgram(reduceInfo, reduceType, bestIndicesA == null);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], 'int32');\n const inputs = [x];\n if (bestIndicesA != null) {\n inputs.push(bestIndicesA);\n }\n this.compileAndRun(program, inputs, output);\n // No need to run another GPGPU program.\n if (output.shape[1] === 1) {\n return output;\n }\n return this.argReduce(x, reduceType, output);\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n return this.reduce(a2D, 'sum', outputDType).reshape(outShape);\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n let axis = 0;\n const permutation = axis_util.getAxesPermutation([axis], x.rank);\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n axis = axis_util.getInnerMostAxes(1, x.rank)[0];\n }\n\n const outShape =\n segment_util.computeOutShape(permutedX.shape, axis, numSegments);\n const inSize = util.sizeFromShape([permutedX.shape[axis]]);\n const a2D = permutedX.as2D(-1, inSize);\n const outputDType = sumOutType(x.dtype);\n let result =\n this.segOpCompute(\n a2D, 'unsortedSegmentSum', segmentIds, outputDType, numSegments)\n .reshape(outShape);\n if (permutation != null) {\n result = result.transpose(axis_util.getUndoAxesPermutation(permutation));\n }\n return result;\n }\n\n private segOpCompute(\n x: Tensor2D, segOpType: 'unsortedSegmentSum', segmentIds: Tensor1D,\n dtype: DataType, numSegments: number): Tensor2D {\n const batchSize = x.shape[0];\n const inSize = x.shape[1];\n const windowSize =\n segment_util.segOpComputeOptimalWindowSize(inSize, numSegments);\n const segOpInfo = {windowSize, inSize, batchSize, numSegments};\n const program = new SegmentOpProgram(segOpInfo, segOpType);\n const [rows, cols] = program.outputShape;\n const output = this.makeOutputArray([rows, cols], dtype);\n this.compileAndRun(program, [x, segmentIds], output);\n // No need to run another GPGPU program.\n if (output.shape[1] === numSegments) {\n return output;\n }\n segmentIds = range(0, numSegments).tile([inSize / windowSize]);\n return this.segOpCompute(output, segOpType, segmentIds, dtype, numSegments);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'min').reshape(outShape);\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.argReduce(a2D, 'max').reshape(outShape);\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `WebGL cumsum shader expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const program = new CumSumProgram(x.shape, exclusive, reverse);\n return this.compileAndRun(program, [x]);\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.NOT_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.LESS, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LESS_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.GREATER, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.GREATER_EQUAL, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalNot(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOGICAL_NOT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_AND, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.LOGICAL_OR, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, 'bool');\n return this.compileAndRun(program, [a, b], output);\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const program = new SelectProgram(condition.rank, a.shape, a.rank);\n const output =\n this.makeOutputArray(program.outputShape, upcastType(a.dtype, b.dtype));\n return this.compileAndRun(program, [condition, a, b], output);\n }\n\n where(condition: Tensor): Tensor2D {\n warn(\n 'tf.where() in webgl locks the UI thread. ' +\n 'Call tf.whereAsync() instead');\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'min', a2D.dtype).reshape(outShape);\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MIN, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MOD, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [a, b], null, customSetup);\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'max', a2D.dtype).reshape(outShape);\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.MAX, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'all', a2D.dtype).reshape(outShape);\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const inSize = util.sizeFromShape(reduceShape);\n const a2D = x.as2D(-1, inSize);\n return this.reduce(a2D, 'any', a2D.dtype).reshape(outShape);\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n const program =\n new BinaryOpProgram(binaryop_gpu.SQUARED_DIFFERENCE, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]);\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.DIV;\n const outputDtype = 'float32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = binaryop_gpu.INT_DIV;\n const outputDtype = 'int32';\n const program = new BinaryOpProgram(op, a.shape, b.shape);\n const output = this.makeOutputArray(program.outputShape, outputDtype);\n return this.compileAndRun(program, [a, b], output);\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.ADD, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n addN(tensors: T[]): T {\n let res = tensors[0];\n for (let i = 1; i < tensors.length; i++) {\n res = this.add(res, tensors[i]) as T;\n }\n return res;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n const program = new BinaryOpProgram(binaryop_gpu.SUB, a.shape, b.shape);\n const output =\n this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as Tensor;\n return this.compileAndRun(program, [a, b], output);\n }\n\n pow(a: T, b: Tensor): T {\n const program = new BinaryOpProgram(binaryop_gpu.POW, a.shape, b.shape);\n const customSetup = program.getCustomSetupFunc();\n const output = this.makeOutputArray(\n program.outputShape, upcastType(a.dtype, b.dtype)) as T;\n return this.compileAndRun(program, [a, b], output, customSetup);\n }\n\n ceil(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.CEIL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n floor(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.FLOOR);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sign(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n round(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ROUND);\n return this.compileAndRun(program, [x]) as T;\n }\n\n exp(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXP);\n return this.compileAndRun(program, [x]) as T;\n }\n\n expm1(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.EXPM1);\n return this.compileAndRun(program, [x]) as T;\n }\n\n log(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n log1p(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.LOG1P);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n rsqrt(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RSQRT);\n return this.compileAndRun(program, [x]) as T;\n }\n\n square(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SQUARE);\n return this.compileAndRun(program, [x]) as T;\n }\n\n reciprocal(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RECIPROCAL);\n return this.compileAndRun(program, [x]) as T;\n }\n\n relu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.RELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n elu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const program =\n new BinaryOpProgram(binaryop_gpu.ELU_DER, dy.shape, y.shape);\n return this.compileAndRun(program, [dy, y]) as T;\n }\n\n selu(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SELU);\n return this.compileAndRun(program, [x]) as T;\n }\n\n int(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TO_INT);\n const output = this.makeOutputArray(program.outputShape, 'int32');\n return this.compileAndRun(program, [x], output) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const program = new ClipProgram(x.shape, min, max);\n return this.compileAndRun(program, [x]) as T;\n }\n\n abs(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ABS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sigmoid(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIGMOID);\n return this.compileAndRun(program, [x]) as T;\n }\n\n softplus(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SOFTPLUS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n sin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asin(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASIN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acos(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOS);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATAN);\n return this.compileAndRun(program, [x]) as T;\n }\n\n atan2(a: T, b: T): T {\n const program = new BinaryOpProgram(binaryop_gpu.ATAN2, a.shape, b.shape);\n return this.compileAndRun(program, [a, b]) as T;\n }\n\n sinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.SINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n cosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.COSH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n tanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.TANH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n asinh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ASINH);\n return this.compileAndRun(program, [x]) as T;\n }\n\n acosh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ACOSH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n atanh(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ATANH);\n const customSetup = program.getCustomSetupFunc();\n return this.compileAndRun(program, [x], null, customSetup) as T;\n }\n\n erf(x: T): T {\n const program = new UnaryOpProgram(x.shape, unary_op.ERF);\n return this.compileAndRun(program, [x]) as T;\n }\n\n step(x: T, alpha: number): T {\n const program = new UnaryOpProgram(x.shape, unary_op.STEP(alpha));\n return this.compileAndRun(program, [x]) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new Conv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Conv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DProgram(convInfo);\n return this.compileAndRun(program, [x, filter]);\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerInputProgram(convInfo);\n return this.compileAndRun(program, [dy, filter]);\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const program = new DepthwiseConv2DDerFilterProgram(convInfo);\n return this.compileAndRun(program, [x, dy]);\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'max', false);\n const output =\n this.makeOutputArray(program.outputShape, x.dtype) as Tensor4D;\n return this.compileAndRun(program, [x], output);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const program = new Pool2DProgram(convInfo, 'avg', false);\n const output = this.makeOutputArray(program.outputShape, 'float32');\n return this.compileAndRun(program, [x], output) as Tensor4D;\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const getPositions = true;\n const maxPoolPositionsProgram =\n new Pool2DProgram(convInfo, 'max', getPositions);\n const maxPoolPositions: Tensor4D =\n this.compileAndRun(maxPoolPositionsProgram, [x]);\n\n const maxPoolBackPropProgram = new MaxPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(maxPoolBackPropProgram.outputShape, x.dtype);\n const result = this.compileAndRun(\n maxPoolBackPropProgram, [dy, maxPoolPositions], output);\n maxPoolPositions.dispose();\n return result as Tensor4D;\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const avgPoolBackpropProgram = new AvgPool2DBackpropProgram(convInfo);\n const output =\n this.makeOutputArray(avgPoolBackpropProgram.outputShape, x.dtype);\n return this.compileAndRun(avgPoolBackpropProgram, [dy], output) as Tensor4D;\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program =\n new ResizeBilinearProgram(x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean):\n Tensor4D {\n const program = new ResizeBilinearBackpropProgram(dy, x, alignCorners);\n\n return this.compileAndRun(program, [dy]);\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const program = new ResizeNearestNeighborProgram(\n x.shape, newHeight, newWidth, alignCorners);\n return this.compileAndRun(program, [x]);\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean): Tensor4D {\n const program =\n new ResizeNearestNeigborBackpropProgram(dy, x, alignCorners);\n return this.compileAndRun(program, [dy]);\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probs = normalized ? logits : softmax(logits);\n const batchSize = probs.shape[0];\n const numOutcomes = probs.shape[1];\n const program = new MultinomialProgram(batchSize, numOutcomes, numSamples);\n const output =\n this.makeOutputArray(program.outputShape, 'int32') as Tensor2D;\n const customSetup = program.getCustomSetupFunc(seed);\n return this.compileAndRun(program, [probs], output, customSetup);\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const program = new OneHotProgram(indices.size, depth, onValue, offValue);\n return this.compileAndRun(program, [indices]);\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n warn(\n 'tf.nonMaxSuppression() in webgl locks the UI thread. ' +\n 'Call tf.nonMaxSuppressionAsync() instead');\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private makeOutputArray(shape: number[], dtype: DataType):\n T {\n return Tensor.make(shape, {}, dtype) as T;\n }\n\n private compileAndRun(\n program: GPGPUProgram, inputs: T[], output?: K,\n customSetup?: (gpgpu: GPGPUContext, webGLProgram: WebGLProgram) => void,\n pageToCpu = true): K {\n if (output == null) {\n output = this.makeOutputArray(program.outputShape, inputs[0].dtype);\n }\n const inputsData: Array> = inputs.map(tensor => {\n const texData = this.texData.get(tensor.dataId);\n // Upload small tensors that live on the CPU as uniforms, not as\n // textures.\n if (texData.texture == null && tensor.size <= SIZE_UPLOAD_UNIFORM) {\n return {tensor, texData: null, isUniform: true};\n }\n this.uploadToGPU(tensor.dataId);\n return {tensor, texData, isUniform: false};\n });\n this.uploadToGPU(output.dataId);\n const outputData = {\n tensor: output,\n texData: this.texData.get(output.dataId),\n isUniform: false\n };\n const key = gpgpu_math.makeShaderKey(program, inputsData, outputData);\n const binary = this.getAndSaveBinary(key, () => {\n return gpgpu_math.compileProgram(\n this.gpgpu, program, inputsData, outputData);\n });\n const shouldTimeProgram = this.activeTimers != null;\n let query: WebGLQuery|CPUTimerQuery;\n if (shouldTimeProgram) {\n query = this.startTimer();\n }\n\n gpgpu_math.runProgram(binary, inputsData, outputData, customSetup);\n\n if (pageToCpu && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) {\n let numBytesToPage = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING;\n while (numBytesToPage > 0 && this.lruDataGPU.length > 0) {\n const dataId = this.lruDataGPU.shift();\n const {shape, dtype} = this.texData.get(dataId);\n numBytesToPage -= this.computeBytes(shape, dtype);\n this.read(dataId);\n }\n }\n\n if (shouldTimeProgram) {\n query = this.endTimer(query);\n this.activeTimers.push(this.getQueryTime(query));\n }\n return output;\n }\n\n private getAndSaveBinary(key: string, getBinary: () => GPGPUBinary):\n GPGPUBinary {\n if (!(key in this.binaryCache)) {\n this.binaryCache[key] = getBinary();\n }\n return this.binaryCache[key];\n }\n\n getTextureManager(): TextureManager {\n return this.textureManager;\n }\n\n private disposed = false;\n\n dispose() {\n if (this.disposed) {\n return;\n }\n for (const key in this.binaryCache) {\n this.gpgpu.deleteProgram(this.binaryCache[key].webGLProgram);\n }\n this.textureManager.dispose();\n this.canvas.remove();\n if (this.fromPixelsCanvas != null) {\n this.fromPixelsCanvas.remove();\n }\n if (this.gpgpuCreatedLocally) {\n this.gpgpu.dispose();\n }\n this.disposed = true;\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.texData.has(dataId)) {\n throw new Error(\n `WebGL backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n private uploadToGPU(dataId: DataId): void {\n this.throwIfNoData(dataId);\n const texData = this.texData.get(dataId);\n const {shape, values, texture, dtype, usage} = texData;\n if (texture != null) {\n // Array is already on GPU. No-op.\n // Touching the texture.\n const index = this.lruDataGPU.indexOf(dataId);\n if (index >= 0) {\n this.lruDataGPU.splice(this.lruDataGPU.indexOf(dataId), 1);\n this.lruDataGPU.push(dataId);\n }\n return;\n }\n const shouldTimeProgram = this.activeTimers != null;\n let start: number;\n if (shouldTimeProgram) {\n start = performance.now();\n }\n const texShape =\n webgl_util.getTextureShapeFromLogicalShape(this.gpgpu.gl, shape);\n texData.texShape = texShape;\n const newTexture = this.acquireTexture(dataId, texShape, usage);\n texData.texture = newTexture;\n if (values != null) {\n this.gpgpu.uploadMatrixToTexture(\n newTexture, texShape[0],\n // TODO(smilkov): Propagate the original typed array to gpgpu.\n texShape[1], typedArrayToFloat32(values, dtype));\n // Once uploaded, don't store the values on cpu.\n texData.values = null;\n if (shouldTimeProgram) {\n this.uploadWaitMs += performance.now() - start;\n }\n }\n }\n\n private cacheOnCPU(dataId: DataId, float32Values?: Float32Array) {\n // In delayed storage mode, when the user reads data, we don't keep a\n // copy on the gpu, to minimize likelihood of memory leak. We re-upload\n // to gpu the next time a gpgpu program needs the texture.\n const dontKeepCopyOnGPU = this.delayedStorage;\n const texData = this.texData.get(dataId);\n const {texture, texShape, dtype, usage} = texData;\n if (dontKeepCopyOnGPU && texture != null) {\n this.releaseTexture(dataId, texture, texShape, usage);\n texData.texture = null;\n texData.texShape = null;\n }\n if (float32Values != null) {\n texData.values = float32ToTypedArray(float32Values, dtype);\n }\n }\n\n private releaseTexture(\n dataId: DataId, texture: WebGLTexture, texShape: [number, number],\n texType: TextureUsage) {\n const {shape, dtype} = this.texData.get(dataId);\n const idx = this.lruDataGPU.indexOf(dataId);\n if (idx >= 0) {\n this.lruDataGPU.splice(idx, 1);\n }\n this.numBytesInGPU -= this.computeBytes(shape, dtype);\n this.textureManager.releaseTexture(texture, texShape, texType);\n }\n\n private acquireTexture(\n dataId: DataId, texShape: [number, number],\n texType: TextureUsage): WebGLTexture {\n const {shape, dtype} = this.texData.get(dataId);\n this.lruDataGPU.push(dataId);\n this.numBytesInGPU += this.computeBytes(shape, dtype);\n return this.textureManager.acquireTexture(texShape, texType);\n }\n\n private computeBytes(shape: number[], dtype: DataType) {\n return util.sizeFromShape(shape) * util.bytesPerElement(dtype);\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n ENV.registerBackend(\n 'webgl', () => new MathBackendWebGL(), 2 /* priority */,\n setTensorTracker);\n}\n\nfunction float32ToTypedArray(\n a: Float32Array, dtype: D): DataTypeMap[D] {\n if (dtype === 'float32') {\n return a;\n } else if (dtype === 'int32' || dtype === 'bool') {\n const result = (dtype === 'int32') ? new Int32Array(a.length) :\n new Uint8Array(a.length);\n for (let i = 0; i < result.length; ++i) {\n result[i] = Math.round(a[i]);\n }\n return result;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\nfunction typedArrayToFloat32(\n a: DataTypeMap[D], dtype: D): Float32Array {\n return (a instanceof Float32Array) ? a : new Float32Array(a);\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {nearestDivisor} from '../util';\nimport {PARALLELIZE_THRESHOLD} from './reduce_util';\n\nexport interface SegOpInfo {\n windowSize: number;\n batchSize: number;\n inSize: number;\n numSegments: number;\n}\n\nexport function segOpComputeOptimalWindowSize(\n inSize: number, numSegments: number): number {\n let done = false;\n let res;\n\n if (inSize <= PARALLELIZE_THRESHOLD) {\n res = inSize;\n done = true;\n } else {\n res = nearestDivisor(inSize, Math.floor(Math.sqrt(inSize)));\n }\n\n while (!done) {\n if (res > numSegments || res === inSize) {\n done = true;\n break;\n } else {\n res = nearestDivisor(inSize, res + 1);\n }\n }\n return res;\n}\n\nexport function computeOutShape(\n aShape: number[], axis: number, numSegments: number): number[] {\n const outShape = [];\n const rank = aShape.length;\n for (let dim = 0; dim < rank; dim++) {\n if (dim !== axis) {\n outShape.push(aShape[dim]);\n } else {\n outShape.push(numSegments);\n }\n }\n return outShape;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\nimport {scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes `-1 * x` element-wise.\n *\n * ```js\n * const x = tf.tensor2d([1, 2, -2, 0], [2, 2]);\n *\n * x.neg().print(); // or tf.neg(x)\n * ```\n *\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction neg_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'neg');\n\n const grad = (dy: T) => {\n return {$x: () => dy.neg()};\n };\n return ENV.engine.runKernel(backend => backend.neg($x), {$x}, grad);\n}\n\n/**\n * Computes ceiling of input `Tensor` element-wise: `ceil(x)`\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.ceil().print(); // or tf.ceil(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction ceil_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'ceil');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.ceil($x), {$x}, grad);\n}\n\n/**\n * Computes floor of input `Tensor` element-wise: `floor(x)`.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.floor().print(); // or tf.floor(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction floor_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'floor');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.floor($x), {$x}, grad);\n}\n\n/**\n * Returns an element-wise indication of the sign of a number.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3, NaN, 0]);\n *\n * x.sign().print(); // or tf.sign(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sign_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sign');\n\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sign($x), {$x}, grad);\n}\n\n/**\n * Computes round of input `Tensor` element-wise: `round(x)`.\n * It implements banker's rounding.\n *\n * ```js\n * const x = tf.tensor1d([.6, 1.1, -3.3]);\n *\n * x.round().print(); // or tf.round(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction round_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'round');\n\n // TODO(nsthorat): Let gradients be null for cases where we want to stop\n // backpropgation.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.round($x), {$x}, grad);\n}\n\n/**\n * Computes exponential of the input `Tensor` element-wise. `e ^ x`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.exp().print(); // or tf.exp(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction exp_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'exp');\n\n const bck = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y as T)};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.exp($x)), {$x}, bck);\n}\n\n/**\n * Computes exponential of the input `Tensor` minus one element-wise.\n * `e ^ x - 1`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, -3]);\n *\n * x.expm1().print(); // or tf.expm1(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction expm1_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'expm1');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.exp())};\n };\n return ENV.engine.runKernel(backend => backend.expm1($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` element-wise: `ln(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E]);\n *\n * x.log().print(); // or tf.log(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.log($x), {$x}, grad);\n}\n\n/**\n * Computes natural logarithm of the input `Tensor` plus one\n * element-wise: `ln(1 + x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.E - 1]);\n *\n * x.log1p().print(); // or tf.log1p(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction log1p_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'log1p');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.add(scalar(1)))};\n };\n return ENV.engine.runKernel(backend => backend.log1p($x), {$x}, grad);\n}\n\n/**\n * Computes square root of the input `Tensor` element-wise: `y = sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.sqrt().print(); // or tf.sqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.toFloat().sqrt().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.sqrt($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of square root of the input `Tensor` element-wise:\n * `y = 1 / sqrt(x)`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 4, -1]);\n *\n * x.rsqrt().print(); // or tf.rsqrt(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction rsqrt_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'rsqrt');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.pow(scalar(1.5)).mul(scalar(2))).neg()};\n };\n return ENV.engine.runKernel(backend => backend.rsqrt($x), {$x}, grad);\n}\n\n/**\n * Computes square of `x` element-wise: `x ^ 2`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, Math.sqrt(2), -1]);\n *\n * x.square().print(); // or tf.square(x)\n * ```\n * @param x The input Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction square_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'square');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().mul(scalar(2)))};\n };\n return ENV.engine.runKernel(backend => backend.square($x), {$x}, grad);\n}\n\n/**\n * Computes reciprocal of x element-wise: `1 / x`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, 2]);\n *\n * x.reciprocal().print(); // or tf.reciprocal(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction reciprocal_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'reciprocal');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.square().neg())};\n };\n return ENV.engine.runKernel(backend => backend.reciprocal($x), {$x}, grad);\n}\n\n/**\n * Computes absolute value element-wise: `abs(x)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.abs().print(); // or tf.abs(x)\n * ```\n * @param x The input `Tensor`.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction abs_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'abs');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.toFloat().step(-1))};\n };\n return ENV.engine.runKernel(backend => backend.abs($x), {$x}, grad);\n}\n\n/**\n * Clips values element-wise. `max(min(x, clipValueMax), clipValueMin)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.clipByValue(-2, 3).print(); // or tf.clipByValue(x, -2, 3)\n * ```\n * @param x The input tensor.\n * @param clipValueMin Lower-bound of range to be clipped to.\n * @param clipValueMax Upper-bound of range to be clipped to.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction clipByValue_(\n x: T|TensorLike, clipValueMin: number, clipValueMax: number): T {\n const $x = convertToTensor(x, 'x', 'clipByValue');\n util.assert(\n (clipValueMin <= clipValueMax),\n `Error in clip: min (${clipValueMin}) must be ` +\n `less than or equal to max (${clipValueMax}).`);\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.where(\n $x.greaterEqual(scalar(clipValueMin))\n .logicalAnd($x.lessEqual(scalar(clipValueMax))),\n zerosLike(dy)) as T,\n };\n };\n return ENV.engine.runKernel(\n backend => backend.clip($x, clipValueMin, clipValueMax), {$x}, grad);\n}\n\n/**\n * Computes sigmoid element-wise, `1 / (1 + exp(-x))`\n *\n * ```js\n * const x = tf.tensor1d([0, -1, 2, -3]);\n *\n * x.sigmoid().print(); // or tf.sigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sigmoid');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => dy.mulStrict(y.mul(scalar(1).sub(y)))};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.sigmoid($x)), {$x}, grad);\n}\n\n/**\n * Computes log sigmoid of the input `Tensor` element-wise:\n * `logSigmoid(x)`. For numerical stability, we use `-tf.softplus(-x)`.\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.logSigmoid().print(); // or tf.logSigmoid(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction logSigmoid_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logSigmoid');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.neg().sigmoid())};\n };\n return ENV.engine.runKernel(\n backend => backend.softplus($x.neg()).neg(), {$x}, grad);\n}\n\n/**\n * Computes softplus of the input `Tensor` element-wise: `log(exp(x) + 1)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.softplus().print(); // or tf.softplus(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction softplus_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'softplus');\n\n const grad = (dy: T) => {\n return {$x: () => dy.mulStrict($x.sigmoid())};\n };\n return ENV.engine.runKernel(backend => backend.softplus($x), {$x}, grad);\n}\n\n/**\n * Computes sin of the input Tensor element-wise: `sin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.sin().print(); // or tf.sin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sin');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cos().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sin($x), {$x}, grad);\n}\n\n/**\n * Computes cos of the input `Tensor` element-wise: `cos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.cos().print(); // or tf.cos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cos');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sin().neg().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cos($x), {$x}, grad);\n}\n\n/**\n * Computes tan of the input `Tensor` element-wise, `tan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, Math.PI / 2, Math.PI * 3 / 4]);\n *\n * x.tan().print(); // or tf.tan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict($x.cos().square())};\n };\n return ENV.engine.runKernel(backend => backend.tan($x), {$x}, grad);\n}\n\n/**\n * Computes asin of the input `Tensor` element-wise: `asin(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asin().print(); // or tf.asin(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asin_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asin');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asin($x), {$x}, grad);\n}\n\n/**\n * Computes acos of the input `Tensor` element-wise: `acos(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.acos().print(); // or tf.acos(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acos_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acos');\n\n const grad = (dy: T) => {\n return {\n $x: () =>\n dy.divStrict(scalar(1).sub($x.toFloat().square()).sqrt() as T).neg()\n };\n };\n return ENV.engine.runKernel(backend => backend.acos($x), {$x}, grad);\n}\n\n/**\n * Computes atan of the input `Tensor` element-wise: `atan(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.atan().print(); // or tf.atan(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atan');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).add($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atan($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic sin of the input `Tensor` element-wise: `sinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.sinh().print(); // or tf.sinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction sinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'sinh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().cosh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.sinh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic cos of the input `Tensor` element-wise: `cosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.cosh().print(); // or tf.cosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction cosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'cosh');\n\n const grad = (dy: T) => {\n return {$x: () => $x.toFloat().sinh().mulStrict(dy)};\n };\n return ENV.engine.runKernel(backend => backend.cosh($x), {$x}, grad);\n}\n\n/**\n * Computes hyperbolic tangent of the input `Tensor` element-wise: `tanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, 70]);\n *\n * x.tanh().print(); // or tf.tanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction tanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'tanh');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {$x: () => scalar(1).sub(y.square()).mulStrict(dy) as T};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.tanh($x)), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic sin of the input `Tensor` element-wise:\n * `asinh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, 1, -1, .7]);\n *\n * x.asinh().print(); // or tf.asinh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction asinh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'asinh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict(scalar(1).add($x.toFloat().square()).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.asinh($x), {$x}, grad);\n}\n\n/**\n * Computes the inverse hyperbolic cos of the input `Tensor` element-wise:\n * `acosh(x)`\n *\n * ```js\n * const x = tf.tensor1d([10, 1, 3, 5.7]);\n *\n * x.acosh().print(); // or tf.acosh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction acosh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'acosh');\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.divStrict($x.toFloat().square().sub(scalar(1)).sqrt() as T)\n };\n };\n return ENV.engine.runKernel(backend => backend.acosh($x), {$x}, grad);\n}\n\n/**\n * Computes inverse hyperbolic tan of the input `Tensor` element-wise:\n * `atanh(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.atanh().print(); // or tf.atanh(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atanh_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'atanh');\n\n const grad = (dy: T) => {\n return {$x: () => dy.divStrict(scalar(1).sub($x.toFloat().square()))};\n };\n return ENV.engine.runKernel(backend => backend.atanh($x), {$x}, grad);\n}\n\n/**\n * Computes gause error function of the input `Tensor` element-wise:\n * `erf(x)`\n *\n * ```js\n * const x = tf.tensor1d([0, .1, -.1, .7]);\n *\n * x.erf().print(); // or tf.erf(x);\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction erf_(x: T|TensorLike): T {\n let $x = convertToTensor(x, 'x', 'erf');\n util.assert(\n $x.dtype === 'int32' || $x.dtype === 'float32',\n 'Input dtype must be `int32` or `float32`.');\n\n if ($x.dtype === 'int32') {\n $x = $x.toFloat();\n }\n\n const grad = (dy: T) => {\n return {\n $x: () => dy.mulStrict(\n scalar(2 / Math.sqrt(Math.PI)).mul($x.square().neg().exp()))\n };\n };\n return ENV.engine.runKernel(backend => backend.erf($x), {$x}, grad);\n}\n\n/**\n * Computes step of the input `Tensor` element-wise: `x > 0 ? 1 : alpha * x`\n *\n * ```js\n * const x = tf.tensor1d([0, 2, -1, -3]);\n *\n * x.step(.5).print(); // or tf.step(x, .5)\n * ```\n * @param x The input tensor.\n * @param alpha The gradient when input is negative.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction step_(x: T|TensorLike, alpha = 0.0): T {\n const $x = convertToTensor(x, 'x', 'step');\n\n // TODO(manrajgrover): Return null for gradients when backprop supports\n // it.\n const grad = (dy: T) => {\n return {$x: () => zerosLike(dy)};\n };\n return ENV.engine.runKernel(backend => backend.step($x, alpha), {$x}, grad);\n}\n\nexport const abs = op({abs_});\nexport const acos = op({acos_});\nexport const acosh = op({acosh_});\nexport const asin = op({asin_});\nexport const asinh = op({asinh_});\nexport const atan = op({atan_});\nexport const atanh = op({atanh_});\nexport const ceil = op({ceil_});\nexport const clipByValue = op({clipByValue_});\nexport const cos = op({cos_});\nexport const cosh = op({cosh_});\nexport const erf = op({erf_});\nexport const exp = op({exp_});\nexport const expm1 = op({expm1_});\nexport const floor = op({floor_});\nexport const log = op({log_});\nexport const log1p = op({log1p_});\nexport const logSigmoid = op({logSigmoid_});\nexport const neg = op({neg_});\nexport const reciprocal = op({reciprocal_});\nexport const round = op({round_});\nexport const rsqrt = op({rsqrt_});\nexport const sigmoid = op({sigmoid_});\nexport const sign = op({sign_});\nexport const sin = op({sin_});\nexport const sinh = op({sinh_});\nexport const softplus = op({softplus_});\nexport const sqrt = op({sqrt_});\nexport const square = op({square_});\nexport const step = op({step_});\nexport const tan = op({tan_});\nexport const tanh = op({tanh_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {tile} from './array_ops';\nimport {getReductionAxes} from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {rsqrt} from './unary_ops';\n\n/**\n * Batch normalization, strictly for 2D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization2d_(\n x: Tensor2D|TensorLike, mean: Tensor2D|Tensor1D|TensorLike,\n variance: Tensor2D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor2D|Tensor1D|TensorLike,\n offset?: Tensor2D|Tensor1D|TensorLike): Tensor2D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor2D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor2D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 2,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 2 || $mean.rank === 1,\n `Error in batchNormalization2D: mean must be rank 2 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 2 || $variance.rank === 1,\n `Error in batchNormalization2D: variance must be rank 2 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 2 || $scale.rank === 1,\n `Error in batchNormalization2D: scale must be rank 2 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 2 || $offset.rank === 1,\n `Error in batchNormalization2D: offset must be rank 2 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 3D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization3d_(\n x: Tensor3D|TensorLike, mean: Tensor3D|Tensor1D|TensorLike,\n variance: Tensor3D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor3D|Tensor1D|TensorLike,\n offset?: Tensor3D|Tensor1D|TensorLike): Tensor3D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor3D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor3D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 3,\n `Error in batchNormalization3D: x must be rank 3 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 3 || $mean.rank === 1,\n `Error in batchNormalization3D: mean must be rank 3 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 3 || $variance.rank === 1,\n `Error in batchNormalization3D: variance must be rank 3 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 3 || $scale.rank === 1,\n `Error in batchNormalization3D: scale must be rank 3 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 3 || $offset.rank === 1,\n `Error in batchNormalization3D: offset must be rank 3 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization, strictly for 4D. For the more relaxed version, see\n * `batchNormalization`.\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\nfunction batchNormalization4d_(\n x: Tensor4D|TensorLike, mean: Tensor4D|Tensor1D|TensorLike,\n variance: Tensor4D|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor4D|Tensor1D|TensorLike,\n offset?: Tensor4D|Tensor1D|TensorLike): Tensor4D {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor4D|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor4D|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n util.assert(\n $x.rank === 4,\n `Error in batchNormalization4D: x must be rank 4 but got rank ` +\n `${$x.rank}.`);\n util.assert(\n $mean.rank === 4 || $mean.rank === 1,\n `Error in batchNormalization4D: mean must be rank 4 or rank 1 but ` +\n `got rank ${$mean.rank}.`);\n util.assert(\n $variance.rank === 4 || $variance.rank === 1,\n `Error in batchNormalization4D: variance must be rank 4 or rank 1 ` +\n `but got rank ${$variance.rank}.`);\n if ($scale != null) {\n util.assert(\n $scale.rank === 4 || $scale.rank === 1,\n `Error in batchNormalization4D: scale must be rank 4 or rank 1 ` +\n `but got rank ${$scale.rank}.`);\n }\n if ($offset != null) {\n util.assert(\n $offset.rank === 4 || $offset.rank === 1,\n `Error in batchNormalization4D: offset must be rank 4 or rank 1 ` +\n `but got rank ${$offset.rank}.`);\n }\n return batchNormalization(\n $x, $mean, $variance, varianceEpsilon, $scale, $offset);\n}\n\n/**\n * Batch normalization.\n *\n * As described in\n * [http://arxiv.org/abs/1502.03167](http://arxiv.org/abs/1502.03167).\n *\n * Mean, variance, scale, and offset can be of two\n * shapes:\n * - The same shape as the input.\n * - In the common case, the depth dimension is the last dimension of x, so\n * the values would be an `Tensor1D` of shape [depth].\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that parameters passed are of given rank\n * - `tf.batchNormalization2d`\n * - `tf.batchNormalization3d`\n * - `tf.batchNormalization4d`\n *\n * @param x The input Tensor.\n * @param mean A mean Tensor.\n * @param variance A variance Tensor.\n * @param varianceEpsilon A small float number to avoid dividing by 0.\n * @param scale A scale Tensor.\n * @param offset An offset Tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction batchNormalization_(\n x: Tensor|Tensor1D|TensorLike, mean: Tensor|Tensor1D|TensorLike,\n variance: Tensor|Tensor1D|TensorLike, varianceEpsilon = .001,\n scale?: Tensor|Tensor1D|TensorLike,\n offset?: Tensor|Tensor1D|TensorLike): Tensor {\n const $x = convertToTensor(x, 'x', 'batchNormalization');\n const $mean = convertToTensor(mean, 'mean', 'batchNormalization');\n const $variance = convertToTensor(variance, 'variance', 'batchNormalization');\n let $scale: Tensor|Tensor1D;\n if (scale != null) {\n $scale = convertToTensor(scale, 'scale', 'batchNormalization');\n }\n let $offset: Tensor|Tensor1D;\n if (offset != null) {\n $offset = convertToTensor(offset, 'offset', 'batchNormalization');\n }\n\n util.assert(\n $mean.rank === $variance.rank,\n 'Batch normalization gradient requires mean and variance to have ' +\n 'equal ranks.');\n util.assert(\n $offset == null || $mean.rank === $offset.rank,\n 'Batch normalization gradient requires mean and offset to have ' +\n 'equal ranks.');\n util.assert(\n $scale == null || $mean.rank === $scale.rank,\n 'Batch normalization gradient requires mean and scale to have ' +\n 'equal ranks.');\n\n let x4D: Tensor4D;\n if ($x.rank === 0 || $x.rank === 1) {\n x4D = $x.as4D(1, 1, 1, $x.size);\n } else if ($x.rank === 2) {\n x4D = $x.as4D(1, 1, $x.shape[0], $x.shape[1]);\n } else if ($x.rank === 3) {\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]) as Tensor4D;\n } else {\n x4D = $x as Tensor4D;\n }\n\n const der = (dy: Tensor) => {\n const scaleValue = $scale == null ? scalar(1) : $scale;\n const reductionAxes = getReductionAxes($mean.shape, x4D.shape);\n const tileShape: number[] = [];\n if ($mean.rank === 1) {\n for (let i = 0; i < x4D.shape.length - 1; ++i) {\n tileShape.push(x4D.shape[i]);\n }\n tileShape.push(1);\n }\n\n const xMinusMean = $x.sub($mean);\n const dyTimesScaleValue = dy.mul(scaleValue);\n const oneOverSqrtVariance = rsqrt($variance.add(scalar(varianceEpsilon)));\n const minusHalfRCube = oneOverSqrtVariance.mul(oneOverSqrtVariance)\n .mul(oneOverSqrtVariance)\n .mul(scalar(-0.5));\n const derX = () => {\n if ($mean.rank === 1) {\n return dy\n .mul(tile(\n oneOverSqrtVariance.as4D(1, 1, 1, $mean.shape[0]), tileShape))\n .mul(scaleValue)\n .reshape($x.shape);\n } else {\n return dy.mul(oneOverSqrtVariance).mul(scaleValue).reshape($x.shape);\n }\n };\n const derMean = () => {\n let meanDer = oneOverSqrtVariance.mul(scalar(-1)).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n meanDer = meanDer.sum(reductionAxes);\n }\n return meanDer.reshape($mean.shape);\n };\n const derVariance = () => {\n let varianceDer = minusHalfRCube.mul(xMinusMean).mul(dyTimesScaleValue);\n if ($mean.rank === 1) {\n varianceDer = varianceDer.sum(reductionAxes);\n }\n return varianceDer.reshape($mean.shape);\n };\n const derScale = () => {\n const xMinusMean2TimesRsqrt = xMinusMean.mul(oneOverSqrtVariance);\n let scaleDer = dy.mul(xMinusMean2TimesRsqrt);\n if ($mean.rank === 1) {\n scaleDer = scaleDer.sum(reductionAxes);\n }\n return scaleDer.reshape($mean.shape);\n };\n const derOffset = () => {\n let offsetDer = dy;\n if ($mean.rank === 1) {\n offsetDer = offsetDer.sum(reductionAxes);\n }\n return offsetDer.reshape($mean.shape);\n };\n return {\n $x: derX,\n $mean: derMean,\n $variance: derVariance,\n $scale: derScale,\n $offset: derOffset\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.batchNormalization(\n x4D, batchnormReshape4D($mean), batchnormReshape4D($variance),\n varianceEpsilon, batchnormReshape4D($scale),\n batchnormReshape4D($offset)),\n {$x, $mean, $variance, $scale, $offset}, der);\n return res.reshape($x.shape);\n}\n\nfunction batchnormReshape4D(x: Tensor): Tensor4D|Tensor1D {\n if (x == null) {\n return null;\n }\n if (x.rank === 0) {\n return x.as1D();\n } else if (x.rank === 1) {\n return x as Tensor1D;\n } else if (x.rank === 2) {\n return x.as4D(1, 1, x.shape[0], x.shape[1]);\n } else if (x.rank === 3) {\n return x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n return x as Tensor4D;\n}\n\nexport const batchNormalization2d = op({batchNormalization2d_});\nexport const batchNormalization3d = op({batchNormalization3d_});\nexport const batchNormalization4d = op({batchNormalization4d_});\nexport const batchNormalization = op({batchNormalization_});\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as util from '../util';\n\nexport type PadInfo = {\n top: number,\n left: number,\n right: number,\n bottom: number,\n type: string\n};\n\n/**\n * Information about the forward pass of a convolution/pooling operation.\n * It includes input and output shape, strides, filter size and padding\n * information.\n */\nexport type Conv2DInfo = {\n batchSize: number,\n inHeight: number,\n inWidth: number,\n inChannels: number,\n outHeight: number,\n outWidth: number,\n outChannels: number,\n dataFormat: 'channelsFirst'|'channelsLast',\n strideHeight: number,\n strideWidth: number,\n dilationHeight: number,\n dilationWidth: number,\n filterHeight: number,\n filterWidth: number,\n padInfo: PadInfo,\n inShape: [number, number, number, number],\n outShape: [number, number, number, number],\n filterShape: [number, number, number, number]\n};\n\nexport function computePool2DInfo(\n inShape: [number, number, number, number],\n filterSize: [number, number]|number, strides: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n const [filterHeight, filterWidth] = parseTupleParam(filterSize);\n\n let filterShape: [number, number, number, number];\n if (dataFormat === 'channelsLast') {\n filterShape = [filterHeight, filterWidth, inShape[3], inShape[3]];\n } else if (dataFormat === 'channelsFirst') {\n filterShape = [filterHeight, filterWidth, inShape[1], inShape[1]];\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n const dilations = 1;\n\n return computeConv2DInfo(\n inShape, filterShape, strides, dilations, pad, roundingMode, false,\n dataFormat);\n}\n\n/**\n * Computes the information for a forward pass of a convolution/pooling\n * operation.\n */\nexport function computeConv2DInfo(\n inShape: [number, number, number, number],\n filterShape: [number, number, number, number],\n strides: number|[number, number], dilations: number|[number, number],\n pad: 'same'|'valid'|number, roundingMode?: 'floor'|'round'|'ceil',\n depthwise = false,\n dataFormat: 'channelsFirst'|'channelsLast' = 'channelsLast'): Conv2DInfo {\n let [batchSize, inHeight, inWidth, inChannels] = [-1, -1, -1, -1];\n if (dataFormat === 'channelsLast') {\n [batchSize, inHeight, inWidth, inChannels] = inShape;\n } else if (dataFormat === 'channelsFirst') {\n [batchSize, inChannels, inHeight, inWidth] = inShape;\n } else {\n throw new Error(`Unknown dataFormat ${dataFormat}`);\n }\n\n const [filterHeight, filterWidth, , filterChannels] = filterShape;\n const [strideHeight, strideWidth] = parseTupleParam(strides);\n const [dilationHeight, dilationWidth] = parseTupleParam(dilations);\n\n const effectiveFilterHeight =\n getEffectiveFilterSize(filterHeight, dilationHeight);\n const effectiveFilterWidth =\n getEffectiveFilterSize(filterWidth, dilationWidth);\n const {padInfo, outHeight, outWidth} = getPadAndOutInfo(\n pad, inHeight, inWidth, strideHeight, strideWidth, effectiveFilterHeight,\n effectiveFilterWidth, roundingMode);\n\n const outChannels = depthwise ? filterChannels * inChannels : filterChannels;\n\n let outShape: [number, number, number, number];\n if (dataFormat === 'channelsFirst') {\n outShape = [batchSize, outChannels, outHeight, outWidth];\n } else if (dataFormat === 'channelsLast') {\n outShape = [batchSize, outHeight, outWidth, outChannels];\n }\n\n return {\n batchSize,\n dataFormat,\n inHeight,\n inWidth,\n inChannels,\n outHeight,\n outWidth,\n outChannels,\n padInfo,\n strideHeight,\n strideWidth,\n filterHeight,\n filterWidth,\n dilationHeight,\n dilationWidth,\n inShape,\n outShape,\n filterShape\n };\n}\n\nfunction computeOutputShape3D(\n inShape: [number, number, number], fieldSize: number, outDepth: number,\n stride: number, zeroPad?: number,\n roundingMode?: 'floor'|'round'|'ceil'): [number, number, number] {\n if (zeroPad == null) {\n zeroPad = computeDefaultPad(inShape, fieldSize, stride);\n }\n const inputRows = inShape[0];\n const inputCols = inShape[1];\n\n const outputRows = conditionalRound(\n (inputRows - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputRows),\n `The output # of rows (${outputRows}) must be an integer. Change the ` +\n `stride and/or zero pad parameters`);\n\n const outputCols = conditionalRound(\n (inputCols - fieldSize + 2 * zeroPad) / stride + 1, roundingMode);\n util.assert(\n util.isInt(outputCols),\n `The output # of columns (${outputCols}) must be an integer. Change ` +\n `the stride and/or zero pad parameters`);\n\n return [outputRows, outputCols, outDepth];\n}\n\nexport function computeDefaultPad(\n inputShape: [number, number, number], fieldSize: number, stride: number,\n dilation = 1): number {\n const effectiveFieldSize = getEffectiveFilterSize(fieldSize, dilation);\n return Math.floor(\n (inputShape[0] * (stride - 1) - stride + effectiveFieldSize) / 2);\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\n/* See https://www.tensorflow.org/api_docs/python/tf/nn/atrous_conv2d\n * Atrous convolution is equivalent to standard convolution with upsampled\n * filters with effective_filter_height =\n * filter_height + (filter_height - 1) * (dilation - 1)\n * and effective_filter_width =\n * filter_width + (filter_width - 1) * (dilation - 1),\n * produced by inserting dilation - 1 zeros along consecutive elements across\n * the filters' spatial dimensions.\n * When there is a dilation, this converts a filter dimension to the\n * effective filter dimension, so it can be used in a standard convolution.\n */\nfunction getEffectiveFilterSize(filterSize: number, dilation: number) {\n if (dilation <= 1) {\n return filterSize;\n }\n\n return filterSize + (filterSize - 1) * (dilation - 1);\n}\n\nfunction getPadAndOutInfo(\n pad: 'same'|'valid'|number, inHeight: number, inWidth: number,\n strideHeight: number, strideWidth: number, filterHeight: number,\n filterWidth: number, roundingMode?: 'floor'|'round'|'ceil'):\n {padInfo: PadInfo, outHeight: number, outWidth: number} {\n let padInfo: PadInfo;\n let outHeight: number;\n let outWidth: number;\n\n if (typeof pad === 'number') {\n const padType = (pad === 0) ? 'VALID' : 'NUMBER';\n padInfo = {top: pad, bottom: pad, left: pad, right: pad, type: padType};\n const outShape = computeOutputShape3D(\n [inHeight, inWidth, 1], filterHeight, 1, strideHeight, pad,\n roundingMode);\n outHeight = outShape[0];\n outWidth = outShape[1];\n } else if (pad === 'same') {\n outHeight = Math.ceil(inHeight / strideHeight);\n outWidth = Math.ceil(inWidth / strideWidth);\n const padAlongHeight =\n (outHeight - 1) * strideHeight + filterHeight - inHeight;\n const padAlongWidth = (outWidth - 1) * strideWidth + filterWidth - inWidth;\n const top = Math.floor(padAlongHeight / 2);\n const bottom = padAlongHeight - top;\n const left = Math.floor(padAlongWidth / 2);\n const right = padAlongWidth - left;\n padInfo = {top, bottom, left, right, type: 'SAME'};\n } else if (pad === 'valid') {\n padInfo = {top: 0, bottom: 0, left: 0, right: 0, type: 'VALID'};\n outHeight = Math.ceil((inHeight - filterHeight + 1) / strideHeight);\n outWidth = Math.ceil((inWidth - filterWidth + 1) / strideWidth);\n } else {\n throw Error(`Unknown padding parameter: ${pad}`);\n }\n return {padInfo, outHeight, outWidth};\n}\n\n/**\n * Rounds a value depending on the rounding mode\n * @param value\n * @param roundingMode\n */\nfunction conditionalRound(\n value: number, roundingMode?: 'floor'|'round'|'ceil') {\n if (!roundingMode) {\n return value;\n }\n switch (roundingMode) {\n case 'round':\n // used for Caffe Conv\n return Math.round(value);\n case 'ceil':\n // used for Caffe Pool\n return Math.ceil(value);\n case 'floor':\n return Math.floor(value);\n default:\n throw new Error(`Unknown roundingMode ${roundingMode}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes a 1D convolution over the input x.\n *\n * @param x The input tensor, of rank 3 or rank 2, of shape\n * `[batch, width, inChannels]`. If rank 2, batch of 1 is assumed.\n * @param filter The filter, rank 3, of shape\n * `[filterWidth, inDepth, outDepth]`.\n * @param stride The number of entries by which the filter is moved right at\n * each step.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat An optional string from \"NWC\", \"NCW\". Defaults to \"NWC\",\n * the data is stored in the order of [batch, in_width, in_channels]. Only\n * \"NWC\" is currently supported.\n * @param dilation The dilation rate in which we sample input values in\n * atrous convolution. Defaults to `1`. If it is greater than 1, then\n * stride must be `1`.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv1d_(\n x: T|TensorLike, filter: Tensor3D|TensorLike, stride: number,\n pad: 'valid'|'same'|number, dataFormat: 'NWC'|'NCW' = 'NWC', dilation = 1,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv1d');\n const $filter = convertToTensor(filter, 'filter', 'conv1d');\n\n let x3D = $x as Tensor3D;\n let reshapedTo3D = false;\n if ($x.rank === 2) {\n reshapedTo3D = true;\n x3D = $x.as3D(1, $x.shape[0], $x.shape[1]);\n }\n\n util.assert(\n x3D.rank === 3,\n `Error in conv1d: input must be rank 3, but got rank ${x3D.rank}.`);\n util.assert(\n $filter.rank === 3,\n `Error in conv1d: filter must be rank 3, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv1d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x3D.shape[2] === $filter.shape[1],\n `Error in conv1d: depth of input (${x3D.shape[2]}) must match ` +\n `input depth for filter ${$filter.shape[1]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(stride, dilation),\n 'Error in conv1D: Either stride or dilation must be 1. ' +\n `Got stride ${stride} and dilation '${dilation}'`);\n util.assert(\n dataFormat === 'NWC',\n `Error in conv1d: got dataFormat of ${\n dataFormat} but only NWC is currently supported.`);\n\n const filter4D =\n $filter.as4D(1, $filter.shape[0], $filter.shape[1], $filter.shape[2]);\n const input4D = x3D.as4D(x3D.shape[0], 1, x3D.shape[1], x3D.shape[2]);\n const strides: [number, number] = [1, stride];\n const dilations: [number, number] = [1, dilation];\n\n const conv2dDataFormat = 'NHWC';\n\n const res = conv2d(\n input4D, filter4D, strides, pad, conv2dDataFormat, dilations,\n dimRoundingMode);\n\n if (reshapedTo3D) {\n return res.as2D(res.shape[2], res.shape[3]) as T;\n }\n return res.as3D(res.shape[0], res.shape[2], res.shape[3]) as T;\n}\n\n/**\n * Computes a 2D convolution over the input x.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `dilations` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2d');\n const $filter = convertToTensor(filter, 'filter', 'conv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2d: input must be rank 4, but got rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in conv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in conv2d: depth of input (${x4D.shape[3]}) must match ` +\n `input depth for filter ${$filter.shape[2]}.`);\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in conv2D: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n util.assert(\n dataFormat === 'NHWC',\n `Error in conv2d: got dataFormat of ${\n dataFormat} but only NHWC is currently supported.`);\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of conv2D: dilation rates greater than 1 are not' +\n `yet supported in gradients. Got dilations '${dilations}'`);\n\n return {\n x: () => conv2dDerInput_(x4D.shape, dy, $filter, strides, pad),\n $filter: () => conv2dDerFilter_(x4D, dy, $filter.shape, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.conv2d(x4D, $filter, convInfo), {x: x4D, $filter},\n grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the input of a 2D convolution.\n *\n * @param xShape The shape of the input: [batch, height, width, inDepth].\n * If length of 3, batch of 1 is assumed.\n * @param dy The derivative of the output, of rank 4 or rank 3 of shape\n * `[batch, outHeight, outWidth, outDepth]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, inDepth, outDepth]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`.\n * @param pad The type of padding algorithm used:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\nfunction conv2dDerInput_(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, strides: [number, number]|number,\n pad: 'valid'|'same'|number, dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n util.assert(\n xShape.length === dy.rank,\n `Length of inShape ` +\n `(${xShape.length}) and rank of dy (${dy.rank}) must match`);\n\n let xShape4D = xShape as [number, number, number, number];\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n xShape4D = [1, xShape[0], xShape[1], xShape[2]];\n }\n\n const inDepth = xShape4D[3];\n const outDepth = dy4D.shape[3];\n util.assert(\n xShape4D.length === 4,\n `Error in conv2dDerInput: inShape must be length 4, but got length ` +\n `${xShape4D.length}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerInput: dy must be rank 4, but got ` +\n `rank ${dy4D.rank}`);\n util.assert(\n filter.rank === 4,\n `Error in conv2dDerInput: filter must be rank 4, but got ` +\n `rank ${filter.rank}`);\n util.assert(\n inDepth === filter.shape[2],\n `Error in conv2dDerInput: depth of input (${inDepth}) must ` +\n `match input depth for filter ${filter.shape[2]}.`);\n util.assert(\n outDepth === filter.shape[3],\n `Error in conv2dDerInput: depth of output (${outDepth}) must ` +\n `match output depth for filter ${filter.shape[3]}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerInput: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n xShape4D, filter.shape, strides, dilations, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.conv2dDerInput(dy4D, filter, convInfo), {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the derivative of the filter of a 2D convolution.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * [batch, height, width, inChannels]. If rank 3, batch of 1 is assumed.\n * @param dy The dy image, of rank 4 or rank 3, of shape\n * [batch, height, width, outDepth]. If rank 3, batch of 1 is assumed.\n * @param filterShape The shape of the filter, length 4,\n * [filterHeight, filterWidth, inDepth, outDepth].\n * @param strides The strides of the convolution: [strideHeight,\n * strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction conv2dDerFilter_(\n x: T, dy: T, filterShape: [number, number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in conv2dDerFilter: input must be rank 4, but got shape ` +\n `${x4D.shape}.`);\n util.assert(\n dy4D.rank === 4,\n `Error in conv2dDerFilter: dy must be rank 4, but got shape ` +\n `${dy4D.shape}.`);\n util.assert(\n filterShape.length === 4,\n `Error in conv2dDerFilter: filterShape must be length 4, but got ` +\n `${filterShape}.`);\n util.assert(\n x4D.shape[3] === filterShape[2],\n `Error in conv2dDerFilter: depth of input ${x4D.shape[3]}) must ` +\n `match input depth in filter (${filterShape[2]}.`);\n util.assert(\n dy4D.shape[3] === filterShape[3],\n `Error in conv2dDerFilter: depth of dy (${dy4D.shape[3]}) must ` +\n `match output depth for filter (${filterShape[3]}).`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in conv2dDerFilter: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const dilations = 1;\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, filterShape, strides, dilations, pad, dimRoundingMode);\n return ENV.engine.runKernel(\n backend => backend.conv2dDerFilter(x4D, dy4D, convInfo), {x4D, dy4D});\n}\n\n/**\n * Computes the transposed 2D convolution of an image, also known as a\n * deconvolution.\n *\n * @param x The input image, of rank 4 or rank 3, of shape\n * `[batch, height, width, inDepth]`. If rank 3, batch of 1 is assumed.\n * @param filter The filter, rank 4, of shape\n * `[filterHeight, filterWidth, outDepth, inDepth]`.\n * `inDepth` must match `inDepth` in `x`.\n * @param outputShape Output shape, of rank 4 or rank 3:\n * `[batch, height, width, outDepth]`. If rank 3, batch of 1 is assumed.\n * @param strides The strides of the original convolution:\n * `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm used in the non-transpose version\n * of the op.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction conv2dTranspose_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n outputShape: [number, number, number, number]|[number, number, number],\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'conv2dTranspose');\n const $filter = convertToTensor(filter, 'filter', 'conv2dTranspose');\n\n return conv2dDerInput_(\n outputShape, $x, $filter, strides, pad, dimRoundingMode);\n}\n\n/**\n * Depthwise 2D convolution.\n *\n * Given a 4D `input` array and a `filter` array of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]` containing\n * `inChannels` convolutional filters of depth 1, this op applies a\n * different filter to each input channel (expanding from 1 channel to\n * `channelMultiplier` channels for each), then concatenates the results\n * together. The output has `inChannels * channelMultiplier` channels.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/depthwise_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param filter The filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction depthwiseConv2d_(\n x: T|TensorLike, filter: Tensor4D|TensorLike,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dataFormat: 'NHWC'|'NCHW' = 'NHWC',\n dilations: [number, number]|number = [1, 1],\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'depthwiseConv2d');\n const $filter = convertToTensor(filter, 'filter', 'depthwiseConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in depthwiseConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $filter.rank === 4,\n `Error in depthwiseConv2d: filter must be rank 4, but got rank ` +\n `${$filter.rank}.`);\n util.assert(\n x4D.shape[3] === $filter.shape[2],\n `Error in depthwiseConv2d: number of input channels ` +\n `(${x4D.shape[3]}) must match the inChannels dimension in ` +\n `filter ${$filter.shape[2]}.`);\n if (dilations == null) {\n dilations = [1, 1];\n }\n util.assert(\n eitherStridesOrDilationsAreOne(strides, dilations),\n 'Error in depthwiseConv2d: Either strides or dilations must be 1. ' +\n `Got strides ${strides} and dilations '${dilations}'`);\n\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in depthwiseConv2d: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computeConv2DInfo(\n x4D.shape, $filter.shape, strides, dilations, pad, dimRoundingMode,\n true /* depthwise */);\n\n const grad = (dy: Tensor4D) => {\n util.assert(\n tupleValuesAreOne(dilations),\n 'Error in gradient of depthwiseConv2d: dilation rates greater than ' +\n `1 are not yet supported. Got dilations '${dilations}'`);\n return {\n x: () => depthwiseConv2dDerInput(x4D.shape, dy, $filter, convInfo),\n $filter: () => depthwiseConv2dDerFilter(x4D, dy, $filter.shape, convInfo),\n };\n };\n\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2D(x4D, $filter, convInfo),\n {x: x4D, $filter}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * 2-D convolution with separable filters.\n *\n * Performs a depthwise convolution that acts separately on channels followed\n * by a pointwise convolution that mixes channels. Note that this is\n * separability between dimensions [1, 2] and 3, not spatial separability\n * between dimensions 1 and 2.\n *\n * See\n * [https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d](\n * https://www.tensorflow.org/api_docs/python/tf/nn/separable_conv2d)\n * for more details.\n *\n * @param x The input tensor, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is\n * assumed.\n * @param depthwiseFilter The depthwise filter tensor, rank 4, of shape\n * `[filterHeight, filterWidth, inChannels, channelMultiplier]`. This is\n * the filter used in the first step.\n * @param pointwiseFilter The pointwise filter tensor, rank 4, of shape\n * `[1, 1, inChannels * channelMultiplier, outChannels]`. This is\n * the filter used in the second step.\n * @param strides The strides of the convolution: `[strideHeight,\n * strideWidth]`. If strides is a single number, then `strideHeight ==\n * strideWidth`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dilations The dilation rates: `[dilationHeight, dilationWidth]`\n * in which we sample input values across the height and width dimensions\n * in atrous convolution. Defaults to `[1, 1]`. If `rate` is a single\n * number, then `dilationHeight == dilationWidth`. If it is greater than\n * 1, then all values of `strides` must be 1.\n * @param dataFormat: An optional string from: \"NHWC\", \"NCHW\". Defaults to\n * \"NHWC\". Specify the data format of the input and output data. With the\n * default format \"NHWC\", the data is stored in the order of: [batch,\n * height, width, channels]. Only \"NHWC\" is currently supported.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction separableConv2d_(\n x: T|TensorLike, depthwiseFilter: Tensor4D|TensorLike,\n pointwiseFilter: Tensor4D|TensorLike, strides: [number, number]|number,\n pad: 'valid'|'same', dilation: [number, number]|number = [1, 1],\n dataFormat: 'NHWC'|'NCHW' = 'NHWC'): T {\n const $x = convertToTensor(x, 'x', 'separableConv2d');\n const $depthwiseFilter =\n convertToTensor(depthwiseFilter, 'depthwiseFilter', 'separableConv2d');\n const $pointwiseFilter =\n convertToTensor(pointwiseFilter, 'pointwiseFilter', 'separableConv2d');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n\n if (dataFormat === 'NCHW') {\n throw new Error(\n 'separableConv2d currently does not support dataFormat NCHW; only ' +\n 'NHWC is supported');\n }\n\n util.assert(\n x4D.rank === 4,\n `Error in separableConv2d: input must be rank 4, but got ` +\n `rank ${x4D.rank}.`);\n util.assert(\n $depthwiseFilter.rank === 4,\n `Error in separableConv2d: depthwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.rank === 4,\n `Error in separableConv2d: pointwise filter must be rank 4, but got ` +\n `rank ${$depthwiseFilter.rank}.`);\n util.assert(\n $pointwiseFilter.shape[0] === 1,\n `Error in separableConv2d: the first dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[0]}.`);\n util.assert(\n $pointwiseFilter.shape[1] === 1,\n `Error in separableConv2d: the second dimension of pointwise filter ` +\n ` must be 1, but got ${$pointwiseFilter.shape[1]}.`);\n\n const inChannels = $depthwiseFilter.shape[2];\n const channelMultiplier = $depthwiseFilter.shape[3];\n util.assert(\n $pointwiseFilter.shape[2] === inChannels * channelMultiplier,\n `Error in separableConv2d: the third dimension of pointwise filter ` +\n `must be ${inChannels * channelMultiplier}, ` +\n `but got ${$pointwiseFilter.shape[2]}.`);\n\n const depthwise = depthwiseConv2d(\n x4D, $depthwiseFilter, strides, pad, dataFormat, dilation);\n const pointwiseStride = 1;\n const res =\n conv2d(depthwise, $pointwiseFilter, pointwiseStride, 'valid', dataFormat);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction parseTupleParam(param: number|[number, number]): [number, number] {\n return typeof param === 'number' ? [param, param] : param;\n}\n\nfunction tupleValuesAreOne(param: number|[number, number]): boolean {\n const [dimA, dimB] = parseTupleParam(param);\n return dimA === 1 && dimB === 1;\n}\n\nfunction eitherStridesOrDilationsAreOne(\n strides: number|[number, number],\n dilations: number|[number, number]): boolean {\n return tupleValuesAreOne(strides) || tupleValuesAreOne(dilations);\n}\n\nfunction depthwiseConv2dDerInput(\n xShape: [number, number, number, number]|[number, number, number], dy: T,\n filter: Tensor4D, convInfo: conv_util.Conv2DInfo): T {\n let dy4D = dy as Tensor4D;\n let reshapedTo4D = false;\n if (dy.rank === 3) {\n reshapedTo4D = true;\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n const res = ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerInput(dy4D, filter, convInfo),\n {dy4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nfunction depthwiseConv2dDerFilter(\n x: T, dy: T, filterShape: [number, number, number, number],\n convInfo: conv_util.Conv2DInfo): Tensor4D {\n let x4D = x as Tensor4D;\n if (x.rank === 3) {\n x4D = x.as4D(1, x.shape[0], x.shape[1], x.shape[2]);\n }\n let dy4D = dy as Tensor4D;\n if (dy4D.rank === 3) {\n dy4D = dy.as4D(1, dy.shape[0], dy.shape[1], dy.shape[2]);\n }\n return ENV.engine.runKernel(\n backend => backend.depthwiseConv2DDerFilter(x4D, dy4D, convInfo),\n {x4D, dy4D});\n}\n\nexport const conv1d = op({conv1d_});\nexport const conv2d = op({conv2d_});\nexport const depthwiseConv2d = op({depthwiseConv2d_});\nexport const separableConv2d = op({separableConv2d_});\nexport const conv2dTranspose = op({conv2dTranspose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Computes the dot product of two matrices, A * B. These must be matrices.\n *\n * ```js\n * const a = tf.tensor2d([1, 2], [1, 2]);\n * const b = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.matMul(b).print(); // or tf.matMul(a, b)\n * ```\n * @param a First matrix in dot product operation.\n * @param b Second matrix in dot product operation.\n * @param transposeA If true, `a` is transposed before multiplication.\n * @param transposeB If true, `b` is transposed before multiplication.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction matMul_(\n a: Tensor2D|TensorLike, b: Tensor2D|TensorLike, transposeA = false,\n transposeB = false): Tensor2D {\n const $a = convertToTensor(a, 'a', 'matMul');\n const $b = convertToTensor(b, 'b', 'matMul');\n\n const innerShapeA = transposeA ? $a.shape[0] : $a.shape[1];\n const innerShapeB = transposeB ? $b.shape[1] : $b.shape[0];\n\n util.assert(\n $a.rank === 2 && $b.rank === 2,\n `Error in matMul: inputs must be rank 2, got ranks ${$a.rank}` +\n ` and ${$b.rank}.`);\n\n util.assert(\n innerShapeA === innerShapeB,\n `Error in matMul: inner shapes (${innerShapeA}) and (` +\n `${innerShapeB}) of Tensors with shapes ${$a.shape} and ` +\n `${$b.shape} and transposeA=${transposeA}` +\n ` and transposeB=${transposeB} must match.`);\n\n const grad = (dy: Tensor2D) => {\n if (!transposeA && !transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, true),\n $b: () => $a.toFloat().matMul(dy, true, false)\n };\n } else if (!transposeA && transposeB) {\n return {\n $a: () => dy.matMul($b.toFloat(), false, false),\n $b: () => dy.matMul($a.toFloat(), true, false)\n };\n } else if (transposeA && !transposeB) {\n return {\n $a: () => $b.toFloat().matMul(dy, false, true),\n $b: () => $a.toFloat().matMul(dy, false, false)\n };\n } else {\n return {\n $a: () => $b.toFloat().matMul(dy, true, true),\n $b: () => dy.matMul($a.toFloat(), true, true)\n };\n }\n };\n return ENV.engine.runKernel(\n backend => backend.matMul($a, $b, transposeA, transposeB), {$a, $b},\n grad);\n}\n\n/**\n * Computes the outer product of two vectors, v1 and v2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([3, 4, 5]);\n *\n * tf.outerProduct(a, b).print();\n * ```\n * @param v1 The first vector in the outer product operation.\n * @param v2 The second vector in the dot product operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction outerProduct_(\n v1: Tensor1D|TensorLike, v2: Tensor1D|TensorLike): Tensor2D {\n const $v1 = convertToTensor(v1, 'v1', 'outerProduct');\n const $v2 = convertToTensor(v2, 'v2', 'outerProduct');\n\n util.assert(\n $v1.rank === 1 && $v2.rank === 1,\n `Error in outerProduct: inputs must be rank 1, but got ranks ` +\n `${$v1.rank} and ${$v2.rank}.`);\n\n return $v1.as2D(-1, 1).matMul($v2.as2D(1, -1));\n}\n\n/**\n * Computes the dot product of two matrices and/or vectors, t1 and t2.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor2d([[1, 2], [3, 4]]);\n * const c = tf.tensor2d([[1, 2, 3], [4, 5, 6]]);\n *\n * a.dot(b).print(); // or tf.dot(a, b)\n * b.dot(a).print();\n * b.dot(c).print();\n * ```\n * @param t1 The first tensor in the dot operation.\n * @param t2 The second tensor in the dot operation.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction dot_(t1: Tensor|TensorLike, t2: Tensor|TensorLike): Tensor {\n const $t1 = convertToTensor(t1, 't1', 'dot');\n const $t2 = convertToTensor(t2, 't2', 'dot');\n util.assert(\n ($t1.rank === 1 || $t1.rank === 2) && ($t2.rank === 1 || $t2.rank === 2),\n `Error in dot: inputs must all be rank 1 or 2, but got ranks ` +\n `${$t1.rank} and ${$t2.rank}.`);\n\n const t1Inner = ($t1.rank === 1 ? $t1.size : $t1.shape[1]);\n const t2Inner = ($t2.rank === 1 ? $t2.size : $t2.shape[0]);\n\n util.assert(\n t1Inner === t2Inner,\n `Error in dot: inner dimensions of inputs must match, but got ` +\n `${t1Inner} and ${t2Inner}.`);\n\n if ($t1.rank === 1 && $t2.rank === 1) {\n return $t1.as2D(1, -1).matMul($t2.as2D(-1, 1)).asScalar();\n } else if ($t1.rank === 1 && $t2.rank === 2) {\n return $t1.as2D(1, -1).matMul($t2.as2D($t2.shape[0], $t2.shape[1])).as1D();\n } else if ($t1.rank === 2 && $t2.rank === 1) {\n return $t1.matMul($t2.as2D(-1, 1)).as1D();\n } else {\n return $t1.matMul($t2.as2D($t2.shape[0], $t2.shape[1]));\n }\n}\n\nexport const matMul = op({matMul_});\nexport const dot = op({dot_});\nexport const outerProduct = op({outerProduct_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {parseAxisParam} from './axis_util';\nimport {op} from './operation';\n\n/**\n * Reverses a `Tensor1D`.\n *\n * @param x The input tensor.\n */\nfunction reverse1d_(x: Tensor1D|TensorLike): Tensor1D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 1, `Error in reverse1D: x must be rank 1 but got\n rank ${$x.rank}.`);\n return reverse($x, 0);\n}\n\n/**\n * Reverses a `Tensor2D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse2d_(x: Tensor2D|TensorLike, axis?: number|number[]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 2, `Error in reverse2D: x must be rank 2 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor3D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse3d_(x: Tensor3D|TensorLike, axis?: number|number[]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 3, `Error in reverse3D: x must be rank 3 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor4D` along a specified axis\n *\n * @param x The input tensor.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\nfunction reverse4d_(x: Tensor4D|TensorLike, axis?: number|number[]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'reverse');\n util.assert($x.rank === 4, `Error in reverse4D: x must be rank 4 but got\n rank ${$x.rank}.`);\n return reverse($x, axis);\n}\n\n/**\n * Reverses a `Tensor` along a specified axis.\n *\n * Also available are stricter rank-specific methods that assert that `x` is\n * of the given rank:\n * - `tf.reverse1d`\n * - `tf.reverse2d`\n * - `tf.reverse3d`\n * - `tf.reverse4d`\n *\n * Except `tf.reverse1d` (which does not have axis param), all methods have\n * same signature as this method.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.reverse().print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.reverse(axis).print();\n * ```\n * @param x The input tensor to be reversed.\n * @param axis The set of dimensions to reverse. Must be in the\n * range [-rank(x), rank(x)). Defaults to all axes.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction reverse_(\n x: T|TensorLike, axis?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'reverse');\n\n if ($x.rank === 0) {\n return $x.clone();\n }\n const axes = parseAxisParam(axis, $x.shape);\n const grad = (dy: T) => {\n return {$x: () => dy.reverse(axes)};\n };\n const res =\n ENV.engine.runKernel(backend => backend.reverse($x, axes), {$x}, grad);\n return res.reshapeAs($x);\n}\n\nexport const reverse = op({reverse_});\nexport const reverse1d = op({reverse1d_});\nexport const reverse2d = op({reverse2d_});\nexport const reverse3d = op({reverse3d_});\nexport const reverse4d = op({reverse4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as conv_util from './conv_util';\nimport {op} from './operation';\n\n/**\n * Computes the 2D max pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm.\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction maxPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'maxPool');\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in maxPool: input must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n const convInfo = conv_util.computePool2DInfo(\n x4D.shape, filterSize, strides, pad, dimRoundingMode);\n\n const grad = (dy: Tensor4D, saved: Tensor[]) => {\n const [y4D] = saved;\n return {\n x: () =>\n maxPoolBackprop(dy, x4D, y4D as Tensor4D, filterSize, strides, pad)\n };\n };\n\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.maxPool(x4D, convInfo)), {x: x4D}, grad);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the 2D average pooling of an image.\n *\n * @param x The input tensor, of rank 4 or rank 3 of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param filterSize The filter size, a tuple `[filterHeight, filterWidth]`.\n * @param strides The strides of the pooling: `[strideHeight, strideWidth]`.\n * @param pad The type of padding algorithm:\n * - `same` and stride 1: output will be of same size as input,\n * regardless of filter size.\n * - `valid`: output will be smaller than input if filter is larger\n * than 1x1.\n * - For more info, see this guide:\n * [https://www.tensorflow.org/api_guides/python/nn#Convolution](\n * https://www.tensorflow.org/api_guides/python/nn#Convolution)\n * @param dimRoundingMode The rounding mode used when computing output\n * dimensions if pad is a number. If none is provided, it will not round\n * and error if the output is of fractional size.\n */\n/** @doc {heading: 'Operations', subheading: 'Convolution'} */\nfunction avgPool_(\n x: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): T {\n const $x = convertToTensor(x, 'x', 'avgPool');\n util.assert(\n $x.dtype === 'float32', 'The input dtype to avgPool must be float32');\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n util.assert(\n x4D.rank === 4,\n `Error in avgPool: x must be rank 4 but got rank ${x4D.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in avgPool: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo =\n conv_util.computePool2DInfo(x4D.shape, filterSize, strides, pad);\n\n const grad = (dy: Tensor4D) => {\n return {x: () => avgPoolBackprop(dy, x4D, filterSize, strides, pad)};\n };\n let res = ENV.engine.runKernel(\n backend => backend.avgPool(x4D, convInfo), {x: x4D}, grad);\n res = res.cast($x.dtype);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the backprop of a max pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The original input image, of rank 4, of shape\n * [batchSize, height, width, channels].\n * @param output The original output image, of rank 4, of shape\n * [batchSize, outHeight, outWidth, channels].\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n * @param dimRoundingMode A string from: 'ceil', 'round', 'floor'. The\n * rounding mode used when computing output dimensions if pad is a\n * number. If none is provided, it will not round and error if the output\n * is of fractional size.\n */\nfunction maxPoolBackprop(\n dy: Tensor4D|TensorLike, input: Tensor4D|TensorLike,\n output: Tensor4D|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number,\n dimRoundingMode?: 'floor'|'round'|'ceil'): Tensor4D {\n const $dy = convertToTensor(dy, 'dy', 'maxPoolBackprop');\n const $input = convertToTensor(input, 'input', 'maxPoolBackprop');\n const $output = convertToTensor(output, 'output', 'maxPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n util.assert(\n $dy.rank === 4,\n `Error in maxPoolBackprop: dy must be rank 4 but got rank ` +\n `${$dy.rank}.`);\n util.assert(\n $input.rank === 4,\n `Error in maxPoolBackprop: input must be rank 4 but got rank ` +\n `${$input.rank}.`);\n if (dimRoundingMode != null) {\n util.assert(\n util.isInt(pad as number),\n `Error in maxPoolBackprop: pad must be an integer when using, ` +\n `dimRoundingMode ${dimRoundingMode} but got pad ${pad}.`);\n }\n\n const convInfo = conv_util.computePool2DInfo(\n $input.shape, filterSize, strides, pad, dimRoundingMode);\n const res = ENV.engine.runKernel(\n backend => backend.maxPoolBackprop($dy, $input, $output, convInfo),\n {$dy, $input});\n return res;\n}\n\n/**\n * Computes the backprop of an avg pool.\n *\n * @param dy The dy error, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param input The input image, of rank 4 or rank 3 of shape\n * [batchSize, height, width, channels]. If rank 3, batch of 1 is\n * assumed.\n * @param filterSize The filter size, a tuple [filterHeight, filterWidth].\n * @param strides The strides of the pooling: [strideHeight, strideWidth].\n * @param pad A string from: 'same', 'valid'. The type of padding algorithm\n * used in the forward prop of the op.\n */\nfunction avgPoolBackprop(\n dy: T|TensorLike, input: T|TensorLike, filterSize: [number, number]|number,\n strides: [number, number]|number, pad: 'valid'|'same'|number): T {\n const $dy = convertToTensor(dy, 'dy', 'avgPoolBackprop');\n const $input = convertToTensor(input, 'input', 'avgPoolBackprop');\n util.assert(\n $input.rank === $dy.rank,\n `Rank of input (${$input.rank}) does not match rank of dy (${$dy.rank})`);\n\n let input4D = $input as Tensor4D;\n let dy4D = $dy as Tensor4D;\n let reshapedTo4D = false;\n if ($input.rank === 3) {\n reshapedTo4D = true;\n input4D = $input.as4D(1, $input.shape[0], $input.shape[1], $input.shape[2]);\n dy4D = $dy.as4D(1, $dy.shape[0], $dy.shape[1], $dy.shape[2]);\n }\n\n util.assert(\n dy4D.rank === 4,\n `Error in avgPoolBackprop: dy must be rank 4 but got rank ` +\n `${dy4D.rank}.`);\n util.assert(\n input4D.rank === 4,\n `Error in avgPoolBackprop: input must be rank 4 but got rank ` +\n `${input4D.rank}.`);\n\n const convInfo =\n conv_util.computePool2DInfo(input4D.shape, filterSize, strides, pad);\n const res = ENV.engine.runKernel(\n backend => backend.avgPoolBackprop(dy4D, input4D, convInfo),\n {dy4D, input4D});\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\nexport const maxPool = op({maxPool_});\nexport const avgPool = op({avgPool_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {Rank, TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\nimport * as slice_util from './slice_util';\n\n/**\n * Extracts a 1D slice from 1D array starting at coordinates `begin` and is\n * of length `size`. See `slice` for details.\n */\nfunction slice1d_(\n x: Tensor1D|TensorLike, begin: number, size: number): Tensor1D {\n const $x = convertToTensor(x, 'x', 'slice1d');\n util.assert(\n $x.rank === 1,\n `slice1d expects a rank-1 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, [begin], [size]);\n}\n\n/**\n * Extracts a 2D slice from a 2D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice2d_(\n x: Tensor2D|TensorLike, begin: [number, number],\n size: [number, number]): Tensor2D {\n const $x = convertToTensor(x, 'x', 'slice2d');\n util.assert(\n $x.rank === 2,\n `slice1d expects a rank-2 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 3D slice from a 3D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice3d_(\n x: Tensor3D|TensorLike, begin: [number, number, number],\n size: [number, number, number]): Tensor3D {\n const $x = convertToTensor(x, 'x', 'slice3d');\n util.assert(\n $x.rank === 3,\n `slice1d expects a rank-3 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a 4D slice from a 4D array starting at coordinates `begin` and\n * is of size `size`. See `slice` for details.\n */\nfunction slice4d_(\n x: Tensor4D|TensorLike, begin: [number, number, number, number],\n size: [number, number, number, number]): Tensor4D {\n const $x = convertToTensor(x, 'x', 'slice4d');\n util.assert(\n $x.rank === 4,\n `slice1d expects a rank-4 tensor, but got a rank-${$x.rank} tensor`);\n return slice($x, begin, size);\n}\n\n/**\n * Extracts a slice from a `Tensor` starting at coordinates `begin`\n * and is of size `size`.\n *\n * Also available are stricter rank-specific methods with the same signature\n * as this method that assert that `x` is of the given rank:\n * - `tf.slice1d`\n * - `tf.slice2d`\n * - `tf.slice3d`\n * - `tf.slice4d`\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.slice([1], [2]).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * x.slice([1, 0], [1, 2]).print();\n * ```\n * @param x The input `Tensor` to slice from.\n * @param begin The coordinates to start the slice from. The length can be\n * less than the rank of x - the rest of the axes will have implicit 0 as\n * start. Can also be a single number, in which case it specifies the\n * first axis.\n * @param size The size of the slice. The length can be less than the rank of\n * x - the rest of the axes will have implicit -1. A value of -1 requests\n * the rest of the dimensions in the axis. Can also be a single number,\n * in which case it specifies the size of the first axis.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction slice_>(\n x: T|TensorLike, begin: number|number[], size?: number|number[]): T {\n const $x = convertToTensor(x, 'x', 'slice');\n\n if ($x.rank === 0) {\n throw new Error('Slicing scalar is not possible');\n }\n // The following logic allows for more ergonomic calls.\n let begin_: number[];\n if (typeof begin === 'number') {\n begin_ = [begin, ...new Array($x.rank - 1).fill(0)];\n } else if (begin.length < $x.rank) {\n begin_ = begin.concat(new Array($x.rank - begin.length).fill(0));\n } else {\n begin_ = begin;\n }\n let size_: number[];\n if (size == null) {\n size_ = new Array($x.rank).fill(-1);\n } else if (typeof size === 'number') {\n size_ = [size, ...new Array($x.rank - 1).fill(-1)];\n } else if (size.length < $x.rank) {\n size_ = size.concat(new Array($x.rank - size.length).fill(-1));\n } else {\n size_ = size;\n }\n size_ = size_.map((d, i) => {\n if (d >= 0) {\n return d;\n } else {\n util.assert(d === -1, 'Bad value in size');\n return $x.shape[i] - begin_[i];\n }\n });\n slice_util.assertParamsValid($x, begin_, size_);\n const inputShape = $x.shape;\n const grad = (dy: T) => {\n // Create an Nx2 padding where the first column represents how many\n // zeros are prepended (at start) for each dimension, and the second\n // column indicates how many zeros are appended (at end).\n\n // The number of zeros to append is the shape of the input\n // elementwise-subtracted by both the begin vector and sizes vector.\n const paddings: Array<[number, number]> = [];\n for (let i = 0; i < dy.rank; i++) {\n paddings.push([begin_[i], inputShape[i] - begin_[i] - size_[i]]);\n }\n return {$x: () => dy.pad(paddings)};\n };\n return ENV.engine.runKernel(\n backend => backend.slice($x, begin_, size_), {$x}, grad) as T;\n}\n\nexport const slice = op({slice_});\nexport const slice1d = op({slice1d_});\nexport const slice2d = op({slice2d_});\nexport const slice3d = op({slice3d_});\nexport const slice4d = op({slice4d_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Environment} from './environment';\nexport {customGrad, grad, grads, valueAndGrad, valueAndGrads, variableGrads} from './gradients';\n\nexport const tidy = Environment.tidy;\nexport const keep = Environment.keep;\nexport const dispose = Environment.dispose;\nexport const time = Environment.time;\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\n/**\n * Computes the log(sum(exp(elements across the reduction dimensions)).\n *\n * Reduces the input along the dimensions given in `axis`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.logSumExp().print(); // or tf.logSumExp(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.logSumExp(axis).print(); // or tf.logSumExp(a, axis)\n * ```\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. If null (the default),\n * reduces all dimensions.\n * @param keepDims If true, retains reduced dimensions with length\n * of 1. Defaults to false.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction logSumExp_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'logSumExp');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const xMax = $x.max(axes, true /* keepDims */);\n const a = $x.sub(xMax);\n const b = a.exp();\n const c = b.sum(axes);\n const d = c.log();\n const res = xMax.reshape(d.shape).add(d);\n\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, axes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the sum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If axes has no entries, all dimensions are reduced, and a `Tensor` with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.sum().print(); // or tf.sum(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.sum(axis).print(); // or tf.sum(x, axis)\n * ```\n *\n * @param x The input tensor to compute the sum over. If the dtype is `bool`\n * it will be converted to `int32` and the output dtype will be `int32`.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction sum_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'sum');\n\n if ($x.dtype === 'bool') {\n $x = $x.toInt();\n }\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n\n // Use a custom gradient to bypass 2 gradient backprops since sum is used\n // extremely often.\n const customOp = customGrad(x => {\n const permutation = axis_util.getAxesPermutation(axes, x.rank);\n let reductionAxes = axes;\n let permutedX = x;\n if (permutation != null) {\n permutedX = x.transpose(permutation);\n reductionAxes = axis_util.getInnerMostAxes(reductionAxes.length, x.rank);\n }\n let value = ENV.engine.runKernel(\n backend => backend.sum(permutedX, reductionAxes), {permutedX});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(value.shape, axes);\n value = value.reshape(newShape);\n }\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX = expandedDy.mul(ones(x.shape, 'float32'));\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the mean of elements across dimensions of a `Tensor`.\n *\n * Reduces `x` along the dimensions given in `axis`. Unless `keepDims` is\n * true, the rank of the `Tensor` is reduced by 1 for each entry in `axis`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axis` has no entries, all dimensions are reduced, and a `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.mean().print(); // or tf.mean(a)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.mean(axis).print(); // or tf.mean(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction mean_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n const $x = convertToTensor(x, 'x', 'mean');\n\n const axes = axis_util.parseAxisParam(axis, $x.shape);\n const shapes = axis_util.computeOutAndReduceShapes($x.shape, axes);\n const reduceShape = shapes[1];\n const reduceSize = util.sizeFromShape(reduceShape);\n\n // Use a custom gradient to bypass 2 gradient backprops since mean is used\n // extremely often.\n const customOp = customGrad(x => {\n const reduceSizeScalar = scalar(reduceSize);\n // Cast if needed.\n const xReduce =\n reduceSizeScalar.dtype === x.dtype ? x : x.cast(reduceSizeScalar.dtype);\n const res = xReduce.div(reduceSizeScalar);\n const value = res.sum(axis, keepDims);\n\n const gradFunc = (dy: Tensor) => {\n const expandedDyShape = x.shape.slice();\n axes.forEach(axis => {\n expandedDyShape[axis] = 1;\n });\n const expandedDy = dy.reshape(expandedDyShape);\n const derX =\n expandedDy.mul(ones(x.shape, 'float32')).div(reduceSizeScalar);\n return derX;\n };\n return {value, gradFunc};\n });\n\n return customOp($x) as T;\n}\n\n/**\n * Computes the minimum value from the input.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the array is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an array with a\n * single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.min().print(); // or tf.min(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.min(axis).print(); // or tf.min(x, axis)\n * ```\n *\n * @param x The input Tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction min_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'min');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.min($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the maximum of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.max().print(); // or tf.max(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * const axis = 1;\n * x.max(axis).print(); // or tf.max(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction max_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'max');\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.max($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Returns the indices of the minimum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMin().print(); // or tf.argMin(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMin(axis).print(); // or tf.argMin(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMin_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMin');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMin($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Returns the indices of the maximum values along an `axis`.\n *\n * The result has the same shape as `input` with the dimension along `axis`\n * removed.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3]);\n *\n * x.argMax().print(); // or tf.argMax(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 4, 3], [2, 2]);\n *\n * const axis = 1;\n * x.argMax(axis).print(); // or tf.argMax(x, axis)\n * ```\n *\n * @param x The input tensor.\n * @param axis The dimension to reduce. Defaults to 0 (outer-most dimension).\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction argMax_(x: Tensor|TensorLike, axis = 0): T {\n let $x = convertToTensor(x, 'x', 'argMax');\n\n if (axis == null) {\n axis = 0;\n }\n let axes = axis_util.parseAxisParam(axis, $x.shape);\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n return ENV.engine.runKernel(backend => backend.argMax($x, axes[0]), {$x}) as\n T;\n}\n\n/**\n * Computes the logical and of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.all().print(); // or tf.all(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.all(axis).print(); // or tf.all(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction all_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'all', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.all($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Computes the logical or of elements across dimensions of a `Tensor`.\n *\n * Reduces the input along the dimensions given in `axes`. Unless `keepDims`\n * is true, the rank of the `Tensor` is reduced by 1 for each entry in `axes`.\n * If `keepDims` is true, the reduced dimensions are retained with length 1.\n * If `axes` has no entries, all dimensions are reduced, and an `Tensor` with\n * a single element is returned.\n *\n * ```js\n * const x = tf.tensor1d([1, 1, 1]);\n *\n * x.any().print(); // or tf.any(x)\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 1, 0, 0], [2, 2], 'bool');\n *\n * const axis = 1;\n * x.any(axis).print(); // or tf.any(x, axis)\n * ```\n *\n * @param x The input tensor. Must be of dtype bool.\n * @param axis The dimension(s) to reduce. By default it reduces\n * all dimensions.\n * @param keepDims If true, retains reduced dimensions with size 1.\n */\n/** @doc {heading: 'Operations', subheading: 'Reduction'} */\nfunction any_(\n x: Tensor|TensorLike, axis: number|number[] = null, keepDims = false): T {\n let $x = convertToTensor(x, 'x', 'any', 'bool');\n util.assert(\n $x.dtype === 'bool',\n `Error Tensor must be of type bool. Got: ${$x.dtype}`);\n\n const origAxes = axis_util.parseAxisParam(axis, $x.shape);\n let axes = origAxes;\n const permutedAxes = axis_util.getAxesPermutation(axes, $x.rank);\n if (permutedAxes != null) {\n $x = $x.transpose(permutedAxes);\n axes = axis_util.getInnerMostAxes(axes.length, $x.rank);\n }\n const res = ENV.engine.runKernel(backend => backend.any($x, axes), {$x});\n if (keepDims) {\n const newShape = axis_util.expandShapeToKeepDim(res.shape, origAxes);\n return res.reshape(newShape) as T;\n }\n return res as T;\n}\n\n/**\n * Calculates the mean and variance of `x`. The mean and variance are\n * calculated by aggregating the contents of `x` across `axes`. If `x` is\n * 1-D and `axes = [0]` this is just the mean and variance of a vector.\n *\n * @param x The input tensor.\n * @param axis The dimension(s) along with to compute mean and\n * variance. By default it reduces all dimensions.\n * @param keepDims If true, the moments have the same dimensionality as the\n * input.\n * @return An object with two keys: `mean` and `variance`.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction moments_(\n x: Tensor|TensorLike, axis: number|number[] = null,\n keepDims = false): {mean: Tensor, variance: Tensor} {\n x = convertToTensor(x, 'x', 'moments');\n const axes = axis_util.parseAxisParam(axis, x.shape);\n const mean = x.mean(axes, keepDims);\n let keepDimsShape = mean.shape;\n if (!keepDims) {\n keepDimsShape = axis_util.expandShapeToKeepDim(mean.shape, axes);\n }\n const devSquared = x.toFloat().sub(mean.reshape(keepDimsShape)).square();\n const variance = devSquared.mean(axes, keepDims);\n return {mean, variance};\n}\n\nexport const all = op({all_});\n// tslint:disable-next-line:variable-name\nexport const any = op({any_});\nexport const argMax = op({argMax_});\nexport const argMin = op({argMin_});\nexport const logSumExp = op({logSumExp_});\nexport const max = op({max_});\nexport const mean = op({mean_});\nexport const min = op({min_});\nexport const moments = op({moments_});\nexport const sum = op({sum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\n\n/**\n * Returns the truth value of (a != b) element-wise. Supports broadcasting.\n *\n * We also expose `notEqualStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([0, 2, 3]);\n *\n * a.notEqual(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction notEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqual');\n const $b = convertToTensor(b, 'b', 'notEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n return ENV.engine.runKernel(backend => backend.notEqual($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Strict version of `notEqual` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction notEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'notEqualStrict');\n const $b = convertToTensor(b, 'b', 'notEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in notEqualStrict: ');\n return $a.notEqual($b);\n}\n\n/**\n * Returns the truth value of (a < b) element-wise. Supports broadcasting.\n *\n * We also expose `lessStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.less(b).print();\n * ```\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction less_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'less');\n const $b = convertToTensor(b, 'b', 'less');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.less($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Strict version of `less` that forces `a` and `b` to be of the same\n * shape.\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same shape and dtype as\n * `a`.\n */\nfunction lessStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessStrict');\n const $b = convertToTensor(b, 'b', 'lessStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessStrict: ');\n return $a.less($b);\n}\n\n/**\n * Returns the truth value of (a == b) element-wise. Supports broadcasting.\n *\n * We also expose `equalStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.equal(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction equal_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equal');\n const $b = convertToTensor(b, 'b', 'equal');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.equal($a, $b), {$a, $b}) as T;\n}\n\nfunction equalStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'equalStrict');\n const $b = convertToTensor(b, 'b', 'equalStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in equalStrict: ');\n return $a.equal($b);\n}\n\n/**\n * Returns the truth value of (a <= b) element-wise. Supports broadcasting.\n *\n * We also expose `lessEqualStrict` which has the same signature as this op\n * and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.lessEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction lessEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqual');\n const $b = convertToTensor(b, 'b', 'lessEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.lessEqual($a, $b), {$a, $b}) as\n T;\n}\n\nfunction lessEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'lessEqualStrict');\n const $b = convertToTensor(b, 'b', 'lessEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in lessEqualStrict: ');\n return $a.lessEqual($b);\n}\n\n/**\n * Returns the truth value of (a > b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greater(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greater_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greater');\n const $b = convertToTensor(b, 'b', 'greater');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.greater($a, $b), {$a, $b}) as\n T;\n}\n\nfunction greaterStrict_(a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterStrict');\n const $b = convertToTensor(b, 'b', 'greaterStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterStrict: ');\n return $a.greater($b);\n}\n\n/**\n * Returns the truth value of (a >= b) element-wise. Supports broadcasting.\n *\n * We also expose `greaterEqualStrict` which has the same signature as this\n * op and asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3]);\n * const b = tf.tensor1d([2, 2, 2]);\n *\n * a.greaterEqual(b).print();\n * ```\n *\n * @param a The first input tensor.\n * @param b The second input tensor. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction greaterEqual_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqual');\n const $b = convertToTensor(b, 'b', 'greaterEqual');\n assertTypesMatch($a, $b);\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.greaterEqual($a, $b), {$a, $b}) as T;\n}\n\nfunction greaterEqualStrict_(\n a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'greaterEqualStrict');\n const $b = convertToTensor(b, 'b', 'greaterEqualStrict');\n assertShapesMatch($a.shape, $b.shape, 'Error in greaterEqualStrict: ');\n return $a.greaterEqual($b);\n}\n\nexport const equal = op({equal_});\nexport const equalStrict = op({equalStrict_});\nexport const greater = op({greater_});\nexport const greaterEqual = op({greaterEqual_});\nexport const greaterEqualStrict = op({greaterEqualStrict_});\nexport const greaterStrict = op({greaterStrict_});\nexport const less = op({less_});\nexport const lessEqual = op({lessEqual_});\nexport const lessEqualStrict = op({lessEqualStrict_});\nexport const lessStrict = op({lessStrict_});\nexport const notEqual = op({notEqual_});\nexport const notEqualStrict = op({notEqualStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {KernelBackend} from '../kernels/backend';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike, upcastType} from '../types';\nimport * as util from '../util';\nimport * as broadcast_util from './broadcast_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\nimport {neg} from './unary_ops';\n\n/**\n * Adds two `Tensor`s element-wise, A + B. Supports broadcasting.\n *\n * We also expose `addStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n *\n * ```js\n * // Broadcast add a with b.\n * const a = tf.scalar(5);\n * const b = tf.tensor1d([10, 20, 30, 40]);\n *\n * a.add(b).print(); // or tf.add(a, b)\n * ```\n * @param a The first `Tensor` to add.\n * @param b The second `Tensor` to add. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction add_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'add');\n const $b = convertToTensor(b, 'b', 'add');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.add($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Adds a list of `Tensor`s element-wise, each with the same shape and dtype.\n *\n * ```js\n * const a = tf.tensor1d([1, 2]);\n * const b = tf.tensor1d([3, 4]);\n * const c = tf.tensor1d([5, 6]);\n *\n * tf.addN([a, b, c]).print();\n * ```\n * @param tensors A list of tensors with the same shape and dtype.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction addN_(tensors: Array): T {\n util.assert(\n Array.isArray(tensors),\n () => 'The param passed to tf.addN() must be a list of tensors');\n util.assert(\n tensors.length >= 1,\n () => `Must pass at least one tensor to tf.addN(), but got ` +\n `${tensors.length}`);\n const $tensors =\n tensors.map((t, i) => convertToTensor(t, `tensors${i}`, 'addN'));\n const firstTensor = $tensors[0];\n $tensors.forEach(t => {\n if (t.dtype !== firstTensor.dtype) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same dtype');\n }\n });\n $tensors.forEach(t => {\n if (!util.arraysEqual(t.shape, firstTensor.shape)) {\n throw new Error(\n 'All tensors passed to tf.addN() must have the same shape');\n }\n });\n\n const der = (dy: T) => {\n const ders: {[key: string]: () => Tensor} = {};\n $tensors.forEach((t, i) => {\n ders[i] = () => dy.clone();\n });\n return ders;\n };\n const inputs: NamedTensorMap = $tensors as {} as NamedTensorMap;\n return ENV.engine.runKernel(backend => backend.addN($tensors), inputs, der);\n}\n\n/**\n * Adds two `Tensor`s element-wise, A + B.\n *\n * Inputs must be the same shape. For broadcasting support, use add() instead.\n *\n * @param a The first Tensor to add element-wise.\n * @param b The second Tensor to add element-wise.\n */\nfunction addStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in addStrict: ');\n return a.add(b);\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Supports broadcasting.\n *\n * We also expose `subStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n *\n * ```js\n * // Broadcast subtract a with b.\n * const a = tf.tensor1d([10, 20, 30, 40]);\n * const b = tf.scalar(5);\n *\n * a.sub(b).print(); // or tf.sub(a, b)\n * ```\n * @param a The first `Tensor` to subtract from.\n * @param b The second `Tensor` to be subtracted. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction sub_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'sub');\n const $b = convertToTensor(b, 'b', 'sub');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n let res = dy;\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.neg().reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.subtract($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Subtracts two `Tensor`s element-wise, A - B. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use sub() instead.\n *\n * @param a The first Tensor to subtract element-wise.\n * @param b The second Tensor to subtract element-wise.\n */\nfunction subStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in subStrict: ');\n return a.sub(b);\n}\n\n/**\n * Computes the power of one `Tensor` to another. Supports broadcasting.\n *\n * Given a `Tensor` x and a `Tensor` y, this operation computes x^y for\n * corresponding elements in x and y. The result's dtype will be the upcasted\n * type of the `base` and `exp` dtypes.\n *\n * ```js\n * const a = tf.tensor([[2, 3], [4, 5]])\n * const b = tf.tensor([[1, 2], [3, 0]]).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n *\n * ```js\n * const a = tf.tensor([[1, 2], [3, 4]])\n * const b = tf.tensor(2).toInt();\n *\n * a.pow(b).print(); // or tf.pow(a, b)\n * ```\n * We also expose `powStrict` which has the same signature as this op and\n * asserts that `base` and `exp` are the same shape (does not broadcast).\n *\n * @param base The base `Tensor` to pow element-wise.\n * @param exp The exponent `Tensor` to pow element-wise.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction pow_(base: T|TensorLike, exp: Tensor|TensorLike): T {\n const $base = convertToTensor(base, 'base', 'pow');\n const $exp = convertToTensor(exp, 'exp', 'pow');\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($base.shape, $exp.shape);\n base = $base.cast(upcastType($base.dtype, $exp.dtype));\n exp = $exp.cast(upcastType($base.dtype, $exp.dtype));\n const grad = (dy: Tensor, saved: Tensor[]) => {\n const [y] = saved;\n const derBase = () => {\n let res = dy.mul($exp.toFloat().mul(y.div($base)));\n const reduceAxes = broadcast_util.getReductionAxes($base.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($base.shape) as T;\n };\n const derExp = () => {\n let res = dy.mul(y.mul($base.log()).toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($exp.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($exp.shape);\n };\n return {$base: derBase, $exp: derExp};\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.pow($base, $exp)), {$base, $exp},\n grad) as T;\n}\n\n/**\n * Computes the power of one `Tensor` to another. Inputs must\n * be the same shape.\n *\n * For broadcasting support, use pow() instead.\n *\n * @param base The base tensor to pow element-wise.\n * @param exp The exponent tensor to pow element-wise.\n */\nfunction powStrict_(base: T, exp: Tensor): T {\n util.assertShapesMatch(base.shape, exp.shape, 'Error in powStrict: ');\n return base.pow(exp);\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B. Supports broadcasting.\n *\n * We also expose `mulStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.tensor1d([2, 3, 4, 5]);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n *\n * ```js\n * // Broadcast mul a with b.\n * const a = tf.tensor1d([1, 2, 3, 4]);\n * const b = tf.scalar(5);\n *\n * a.mul(b).print(); // or tf.mul(a, b)\n * ```\n * @param a The first tensor to multiply.\n * @param b The second tensor to multiply. Must have the same dtype as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mul_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mul');\n const $b = convertToTensor(b, 'b', 'mul');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.mul($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n const res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.multiply($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Multiplies two `Tensor`s element-wise, A * B.\n *\n * Inputs must be the same shape. For broadcasting support, use mul().\n *\n * @param a The first tensor to multiply.\n * @param b The first tensor to multiply. Must have the same\n * dtype as `a`.\n */\nfunction mulStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in multiplyStrict: ');\n return a.mul(b) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n *\n * We also expose `divStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.div(b).print(); // or tf.div(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction div_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'div');\n const $b = convertToTensor(b, 'b', 'div');\n assertTypesMatch($a, $b);\n\n let forwardFunc: (backend: KernelBackend) => Tensor;\n if ($a.dtype === 'int32' && $b.dtype === 'int32') {\n return floorDiv($a, $b);\n } else {\n forwardFunc = (backend: KernelBackend) => backend.realDivide($a, $b);\n }\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Supports broadcasting.\n * The result is rounded with floor function.\n *\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 9, 16]);\n * const b = tf.tensor1d([1, 2, 3, 4]);\n *\n * a.floorDiv(b).print(); // or tf.div(a, b)\n * ```\n *\n * ```js\n * // Broadcast div a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(2);\n *\n * a.floorDiv(b).print(); // or tf.floorDiv(a, b)\n * ```\n *\n * @param a The first tensor as the numerator.\n * @param b The second tensor as the denominator. Must have the same dtype as\n * `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction floorDiv_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'floorDiv');\n const $b = convertToTensor(b, 'b', 'floorDiv');\n assertTypesMatch($a, $b);\n\n const forwardFunc = (backend: KernelBackend) => backend.floorDiv($a, $b);\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const res = dy.div($b.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($a.shape);\n }\n return res;\n };\n const derB = () => {\n let res = dy.mul($a.toFloat());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes).reshape($b.shape);\n }\n const tmp = $b.square() as Tensor;\n return res.div(tmp.toFloat()).neg() as Tensor;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(forwardFunc, {$a, $b}, der) as T;\n}\n\n/**\n * Divides two `Tensor`s element-wise, A / B. Inputs must\n * be the same shape.\n *\n * @param a The first tensor as the numerator for element-wise division.\n * @param b The second tensor as the denominator for element-wise division.\n */\nfunction divStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in divideStrict: ');\n return a.div(b) as T;\n}\n\n/**\n * Returns the mod of a and b element-wise.\n * `floor(x / y) * y + mod(x, y) = x`\n * Supports broadcasting.\n *\n * We also expose `modStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * ```js\n * // Broadcast a mod b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.mod(b).print(); // or tf.mod(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction mod_(a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'mod');\n const $b = convertToTensor(b, 'b', 'mod');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => {\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n return dy.sum(reduceAxes).reshape($a.shape);\n }\n return dy;\n };\n const derB = () => {\n const res = dy.mul($a.div($b).floor().neg());\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n return res.sum(reduceAxes).reshape($b.shape);\n }\n return res;\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(backend => backend.mod($a, $b), {$a, $b}, der) as\n T;\n}\n\n/**\n * Returns the mod of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use mod().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction modStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in modStrict: ');\n return a.mod(b);\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `minimumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * ```js\n * // Broadcast minimum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.minimum(b).print(); // or tf.minimum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction minimum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'minimum');\n let $b = convertToTensor(b, 'b', 'minimum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.lessEqual($b).toFloat());\n const derB = () => dy.mul($a.greater($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.minimum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the min of a and b (`a < b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use minimum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction minimumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.minimum(b);\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise.\n * Supports broadcasting.\n *\n * We also expose `maximumStrict` which has the same signature as this op and\n * asserts that `a` and `b` are the same shape (does not broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * ```js\n * // Broadcast maximum a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.maximum(b).print(); // or tf.maximum(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction maximum_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n let $a = convertToTensor(a, 'a', 'maximum');\n let $b = convertToTensor(b, 'b', 'maximum');\n assertTypesMatch($a, $b);\n\n if ($a.dtype === 'bool') {\n $a = $a.toInt();\n }\n if ($b.dtype === 'bool') {\n $b = $b.toInt();\n }\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const derA = () => dy.mul($a.greaterEqual($b).toFloat());\n const derB = () => dy.mul($a.less($b).toFloat());\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.maximum($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns the max of a and b (`a > b ? a : b`) element-wise. Inputs must\n * be the same shape. For broadcasting support, use maximum().\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n */\nfunction maximumStrict_(a: T, b: T): T {\n util.assertShapesMatch(a.shape, b.shape, 'Error in minimumStrict: ');\n return a.maximum(b);\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n * Supports broadcasting.\n *\n * We also expose `squaredDifferenceStrict` which has the same signature as\n * this op and asserts that `a` and `b` are the same shape (does not\n * broadcast).\n *\n * ```js\n * const a = tf.tensor1d([1, 4, 3, 16]);\n * const b = tf.tensor1d([1, 2, 9, 4]);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * ```js\n * // Broadcast squared difference a with b.\n * const a = tf.tensor1d([2, 4, 6, 8]);\n * const b = tf.scalar(5);\n *\n * a.squaredDifference(b).print(); // or tf.squaredDifference(a, b)\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Arithmetic'} */\nfunction squaredDifference_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'squaredDifference');\n const $b = convertToTensor(b, 'b', 'squaredDifference');\n assertTypesMatch($a, $b);\n\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n const der = (dy: Tensor) => {\n const two = scalar(2);\n const derA = () => dy.mul($a.sub($b).mul(two));\n const derB = () => dy.mul($b.sub($a).mul(two));\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.squaredDifference($a, $b), {$a, $b}, der) as T;\n}\n\n/**\n * Returns (a - b) * (a - b) element-wise.\n *\n * Inputs must be the same shape. For broadcasting support, use\n * squaredDifference() instead.\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same type as `a`.\n */\nfunction squaredDifferenceStrict_(a: T, b: T): T {\n util.assertShapesMatch(\n a.shape, b.shape, 'Error in squaredDifferenceStrict: ');\n return a.squaredDifference(b);\n}\n\n/**\n * Computes arctangent of `Tensor`s a / b element-wise: `atan2(a, b)`.\n * Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([1.0, 1.0, -1.0, .7]);\n * const b = tf.tensor1d([2.0, 13.0, 3.5, .21]);\n *\n * tf.atan2(a, b).print()\n * ```\n *\n * @param a The first tensor.\n * @param b The second tensor. Must have the same dtype as `a`.\n *\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction atan2_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'atan2');\n const $b = convertToTensor(b, 'b', 'atan2');\n assertTypesMatch($a, $b);\n\n const outShape =\n broadcast_util.assertAndGetBroadcastShape($a.shape, $b.shape);\n\n const der = (dy: Tensor) => {\n const derA = () => {\n const d = add($a.square(), $b.square());\n let res = dy.mul($b.div(d));\n const reduceAxes = broadcast_util.getReductionAxes($a.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($a.shape);\n };\n const derB = () => {\n const d = add($a.square(), $b.square()) as T;\n let res = neg(dy.mul($a.div(d)));\n const reduceAxes = broadcast_util.getReductionAxes($b.shape, outShape);\n if (reduceAxes.length > 0) {\n res = res.sum(reduceAxes);\n }\n return res.reshape($b.shape);\n };\n return {$a: derA, $b: derB};\n };\n return ENV.engine.runKernel(\n backend => backend.atan2($a, $b), {$a, $b}, der) as T;\n}\n\nexport const add = op({add_});\nexport const addN = op({addN_});\nexport const addStrict = op({addStrict_});\nexport const atan2 = op({atan2_});\nexport const div = op({div_});\nexport const divStrict = op({divStrict_});\nexport const floorDiv = op({floorDiv_});\nexport const maximum = op({maximum_});\nexport const maximumStrict = op({maximumStrict_});\nexport const minimum = op({minimum_});\nexport const minimumStrict = op({minimumStrict_});\nexport const mod = op({mod_});\nexport const modStrict = op({modStrict_});\nexport const mul = op({mul_});\nexport const mulStrict = op({mulStrict_});\nexport const pow = op({pow_});\nexport const powStrict = op({powStrict_});\nexport const squaredDifference = op({squaredDifference_});\nexport const squaredDifferenceStrict = op({squaredDifferenceStrict_});\nexport const sub = op({sub_});\nexport const subStrict = op({subStrict_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {whereImpl} from '../kernels/where_impl';\nimport {Tensor, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, assertShapesMatch} from '../util';\nimport {assertAndGetBroadcastShape} from './broadcast_util';\nimport {op} from './operation';\nimport {zerosLike} from './tensor_ops';\n\n/**\n * Returns the truth value of `NOT x` element-wise.\n *\n * ```js\n * const a = tf.tensor1d([false, true], 'bool');\n *\n * a.logicalNot().print();\n * ```\n *\n * @param x The input tensor. Must be of dtype 'bool'.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalNot_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'logicalNot', 'bool');\n assert($x.dtype === 'bool', 'Error Array must be of type bool.');\n\n return ENV.engine.runKernel(backend => backend.logicalNot($x), {$x});\n}\n\n/**\n * Returns the truth value of a AND b element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalAnd(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalAnd_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalAnd', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalAnd', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(\n backend => backend.logicalAnd($a, $b), {$a, $b}) as T;\n}\n\n/**\n * Returns the truth value of `a OR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalOr(b).print();\n * ```\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalOr_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalOr', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalOr', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n return ENV.engine.runKernel(backend => backend.logicalOr($a, $b), {$a, $b}) as\n T;\n}\n\n/**\n * Returns the truth value of `a XOR b` element-wise. Supports broadcasting.\n *\n * ```js\n * const a = tf.tensor1d([false, false, true, true], 'bool');\n * const b = tf.tensor1d([false, true, false, true], 'bool');\n *\n * a.logicalXor(b).print();\n * ```\n *\n * @param a The first input tensor. Must be of dtype bool.\n * @param b The second input tensor. Must be of dtype bool.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction logicalXor_(\n a: Tensor|TensorLike, b: Tensor|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'logicalXor', 'bool');\n const $b = convertToTensor(b, 'b', 'logicalXor', 'bool');\n assert(\n $a.dtype === 'bool' && $b.dtype === 'bool',\n 'Error Array must be of type bool.');\n assertAndGetBroadcastShape($a.shape, $b.shape);\n\n // x ^ y = (x | y) & ~(x & y)\n return logicalOr(a, b).logicalAnd(logicalAnd(a, b).logicalNot()) as T;\n}\n\n/**\n * Returns the elements, either `a` or `b` depending on the `condition`.\n *\n * If the condition is true, select from `a`, otherwise select from `b`.\n *\n * ```js\n * const cond = tf.tensor1d([false, false, true], 'bool');\n * const a = tf.tensor1d([1 , 2, 3]);\n * const b = tf.tensor1d([-1, -2, -3]);\n *\n * a.where(cond, b).print();\n * ```\n *\n * @param condition The input condition. Must be of dtype bool.\n * @param a If `condition` is rank 1, `a` may have a higher rank but\n * its first dimension must match the size of `condition`.\n * @param b A tensor with the same shape and type as `a`.\n */\n/** @doc {heading: 'Operations', subheading: 'Logical'} */\nfunction where_(\n condition: Tensor|TensorLike, a: T|TensorLike, b: T|TensorLike): T {\n const $a = convertToTensor(a, 'a', 'where');\n const $b = convertToTensor(b, 'b', 'where');\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n\n assert($condition.dtype === 'bool', 'Error Condition must be of type bool.');\n assertShapesMatch($a.shape, $b.shape, 'Error in where: ');\n\n if ($condition.rank === 1) {\n // If condition rank is 1, then the first dimension must match the size of\n // condition.\n assert(\n $condition.shape[0] === $a.shape[0],\n 'The first dimension of `a` must match the size of `condition`.');\n } else {\n // A must have the same shape as condition.\n assertShapesMatch($condition.shape, $b.shape, 'Error in where: ');\n }\n\n // TODO(julianoks): Return null for condition gradient\n // when backprop supports it.\n const grad = (dy: T) => ({\n $condition: () => zerosLike($condition),\n $a: () => dy.mul($condition.cast($a.dtype)) as T,\n $b: () => dy.mul($condition.logicalNot().cast($b.dtype)) as T\n });\n\n return ENV.engine.runKernel(\n backend => backend.select($condition, $a, $b),\n {$condition, $a, $b}, grad) as T;\n}\n\n/**\n * Returns the coordinates of true elements of condition.\n *\n * The coordinates are returned in a 2-D tensor where the first dimension (rows)\n * represents the number of true elements, and the second dimension (columns)\n * represents the coordinates of the true elements. Keep in mind, the shape of\n * the output tensor can vary depending on how many true values there are in\n * input. Indices are output in row-major order. The resulting tensor has the\n * shape `[numTrueElems, condition.rank]`.\n */\nasync function whereAsync_(condition: Tensor|TensorLike): Promise {\n const $condition = convertToTensor(condition, 'condition', 'where', 'bool');\n assert($condition.dtype === 'bool', 'Condition must be of type bool.');\n const vals = await $condition.data();\n const res = whereImpl($condition.shape, vals);\n if (condition !== $condition) {\n $condition.dispose();\n }\n return res;\n}\n\nexport const logicalAnd = op({logicalAnd_});\nexport const logicalNot = op({logicalNot_});\nexport const logicalOr = op({logicalOr_});\nexport const logicalXor = op({logicalXor_});\nexport const where = op({where_});\nexport const whereAsync = whereAsync_;\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {maximum, minimum} from './binary_ops';\nimport {where} from './logical_ops';\nimport {op} from './operation';\nimport {SELU_SCALE, SELU_SCALEALPHA} from './selu_util';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes rectified linear element-wise: `max(x, 0)`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.relu().print(); // or tf.relu(x)\n * ```\n * @param x The input tensor. If the dtype is `bool`, the output dtype will be\n * `int32'.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction relu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'relu');\n\n if ($x.dtype === 'bool') {\n return $x.toInt();\n }\n const grad = (dy: T) => {\n const stepRes = $x.step();\n return {$x: () => dy.mulStrict(stepRes.toFloat())};\n };\n return ENV.engine.runKernel(backend => backend.relu($x), {$x}, grad);\n}\n\n/**\n * Computes exponential linear element-wise, `x > 0 ? e ^ x - 1 : 0`\n *\n * ```js\n * const x = tf.tensor1d([-1, 1, -3, 2]);\n *\n * x.elu().print(); // or tf.elu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction elu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'elu');\n\n const grad = (dy: T, saved: Tensor[]) => {\n const [y] = saved;\n return {\n $x: () =>\n ENV.engine.runKernel(backend => backend.eluDer(dy, y), {dy, y}) as T\n };\n };\n return ENV.engine.runKernel(\n (backend, save) => save(backend.elu($x)), {$x}, grad);\n}\n\n/**\n * Computes scaled exponential linear element-wise.\n *\n * `x < 0 ? scale * alpha * (exp(x) - 1) : x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.selu().print(); // or tf.selu(x)\n * ```\n * @param x The input tensor.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction selu_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'selu');\n\n const grad = (dy: T) => {\n return {\n $x: () => {\n const mask = $x.greater(scalar(0));\n\n const scaleAlpha = scalar(SELU_SCALEALPHA);\n const scale = scalar(SELU_SCALE);\n\n const greaterThanZeroDer = dy.mul(scale);\n const lessEqualZeroDer = dy.mul(scaleAlpha).mul($x.toFloat().exp());\n\n return where(mask, greaterThanZeroDer, lessEqualZeroDer) as T;\n }\n };\n };\n return ENV.engine.runKernel(backend => backend.selu($x), {$x}, grad);\n}\n\n/**\n * Computes leaky rectified linear element-wise.\n *\n * See\n * [http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf](\n * http://web.stanford.edu/~awni/papers/relu_hybrid_icml2013_final.pdf)\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n *\n * x.leakyRelu(0.1).print(); // or tf.leakyRelu(x, 0.1)\n * ```\n * @param x The input tensor.\n * @param alpha The scaling factor for negative values, defaults to 0.2.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction leakyRelu_(x: T|TensorLike, alpha = 0.2): T {\n const $x = convertToTensor(x, 'x', 'leakyRelu');\n return maximum(scalar(alpha).mul($x), $x);\n}\n\n/**\n * Computes leaky rectified linear element-wise with parametric alphas.\n *\n * `x < 0 ? alpha * x : f(x) = x`\n *\n * ```js\n * const x = tf.tensor1d([-1, 2, -3, 4]);\n * const alpha = tf.scalar(0.1);\n *\n * x.prelu(alpha).print(); // or tf.prelu(x, alpha)\n * ```\n * @param x The input tensor.\n * @param alpha Scaling factor for negative values.\n */\n/** @doc {heading: 'Operations', subheading: 'Basic math'} */\nfunction prelu_(x: T|TensorLike, alpha: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'prelu');\n const $alpha = convertToTensor(alpha, 'alpha', 'prelu');\n\n const zero = scalar(0);\n return maximum(zero, $x).add($alpha.mul(minimum(zero, $x)));\n}\n\nexport const elu = op({elu_});\nexport const leakyRelu = op({leakyRelu_});\nexport const prelu = op({prelu_});\nexport const relu = op({relu_});\nexport const selu = op({selu_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\n\n/**\n * Transposes the `Tensor`. Permutes the dimensions according to `perm`.\n *\n * The returned `Tensor`'s dimension `i` will correspond to the input\n * dimension `perm[i]`. If `perm` is not given, it is set to `[n-1...0]`,\n * where `n` is the rank of the input `Tensor`. Hence by default, this\n * operation performs a regular matrix transpose on 2-D input `Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]);\n *\n * a.transpose().print(); // or tf.transpose(a)\n * ```\n *\n * @param x The tensor to transpose.\n * @param perm The permutation of the dimensions of a.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction transpose_(x: T|TensorLike, perm?: number[]): T {\n const $x = convertToTensor(x, 'x', 'transpose');\n\n if (perm == null) {\n perm = $x.shape.map((s, i) => i).reverse();\n }\n util.assert(\n $x.rank === perm.length,\n `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of perm ${perm}.`);\n perm.forEach(axis => {\n util.assert(\n axis >= 0 && axis < $x.rank,\n `All entries in 'perm' must be between 0 and ${$x.rank - 1}` +\n ` but got ${perm}`);\n });\n\n if ($x.rank <= 1) {\n return $x.clone();\n }\n\n const der = (dy: T) => {\n const undoPerm = axis_util.getUndoAxesPermutation(perm);\n return {$x: () => dy.transpose(undoPerm)};\n };\n return ENV.engine.runKernel(\n backend => backend.transpose($x, perm), {$x}, der);\n}\n\nexport const transpose = op({transpose_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Normalizes the activation of a local neighborhood across or within\n * channels.\n *\n * @param x The input tensor. The 4-D input tensor is treated as a 3-D array\n * of 1D vectors (along the last dimension), and each vector is\n * normalized independently.\n * @param depthRadius The number of adjacent channels in the 1D normalization\n * window.\n * @param bias A constant bias term for the basis.\n * @param alpha A scale factor, usually positive.\n * @param beta An exponent.\n */\n/** @doc {heading: 'Operations', subheading: 'Normalization'} */\nfunction localResponseNormalization_(\n x: T|TensorLike, depthRadius = 5, bias = 1, alpha = 1, beta = 0.5): T {\n const $x = convertToTensor(x, 'x', 'localResponseNormalization');\n util.assert(\n $x.rank === 4 || $x.rank === 3,\n `Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank ${$x.rank}.`);\n util.assert(\n util.isInt(depthRadius),\n `Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius ${depthRadius}.`);\n\n let x4D = $x as Tensor4D;\n let reshapedTo4D = false;\n if ($x.rank === 3) {\n reshapedTo4D = true;\n x4D = $x.as4D(1, $x.shape[0], $x.shape[1], $x.shape[2]);\n }\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n const [outputImage] = saved;\n return {\n x4D: () => ENV.engine.runKernel(\n backend => backend.LRNGrad(\n dy, x4D, outputImage as Tensor4D, depthRadius, bias, alpha, beta),\n {})\n };\n };\n const res = ENV.engine.runKernel(\n (backend, save) => save(backend.localResponseNormalization4D(\n x4D, depthRadius, bias, alpha, beta)),\n {x4D}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n } else {\n return res as T;\n }\n}\n\nexport const localResponseNormalization = op({localResponseNormalization_});","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as axis_util from './axis_util';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Computes the norm of scalar, vectors, and matrices.\n * This function can compute several different vector norms (the 1-norm, the\n * Euclidean or 2-norm, the inf-norm, and in general the p-norm for p > 0)\n * and matrix norms (Frobenius, 1-norm, and inf-norm).\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n *\n * x.norm().print(); // or tf.norm(x)\n * ```\n *\n * @param x The input array.\n * @param ord Optional. Order of the norm. Supported norm types are\n * following:\n *\n * | ord | norm for matrices | norm for vectors\n * |------------|---------------------------|---------------------\n * |'euclidean' |Frobenius norm |2-norm\n * |'fro' |Frobenius norm\t |\n * |Infinity |max(sum(abs(x), axis=1)) |max(abs(x))\n * |-Infinity |min(sum(abs(x), axis=1)) |min(abs(x))\n * |1 |max(sum(abs(x), axis=0)) |sum(abs(x))\n * |2 | |sum(abs(x)^2)^1/2*\n *\n * @param axis Optional. If axis is null (the default), the input is\n * considered a vector and a single vector norm is computed over the entire\n * set of values in the Tensor, i.e. norm(x, ord) is equivalent\n * to norm(x.reshape([-1]), ord). If axis is a integer, the input\n * is considered a batch of vectors, and axis determines the axis in x\n * over which to compute vector norms. If axis is a 2-tuple of integer it is\n * considered a batch of matrices and axis determines the axes in NDArray\n * over which to compute a matrix norm.\n * @param keepDims Optional. If true, the norm have the same dimensionality\n * as the input.\n */\n/** @doc {heading: 'Operations', subheading: 'Matrices'} */\nfunction norm_(\n x: Tensor|TensorLike, ord: number|'euclidean'|'fro' = 'euclidean',\n axis: number|number[] = null, keepDims = false): Tensor {\n x = convertToTensor(x, 'x', 'norm');\n\n const norm = normImpl(x, ord, axis);\n let keepDimsShape = norm.shape;\n if (keepDims) {\n const axes = axis_util.parseAxisParam(axis, x.shape);\n keepDimsShape = axis_util.expandShapeToKeepDim(norm.shape, axes);\n }\n return norm.reshape(keepDimsShape);\n}\n\nfunction normImpl(\n x: Tensor, p: number|string, axis: number|number[] = null): Tensor {\n if (x.rank === 0) {\n return x.abs();\n }\n\n // consider vector when no axis is specified\n if (x.rank !== 1 && axis === null) {\n return normImpl(x.reshape([-1]), p, axis);\n }\n\n // vector\n if (x.rank === 1 || typeof axis === 'number' ||\n axis instanceof Array && axis.length === 1) {\n if (p === 1) {\n return x.abs().sum(axis);\n }\n if (p === Infinity) {\n return x.abs().max(axis);\n }\n if (p === -Infinity) {\n return x.abs().min(axis);\n }\n if (p === 'euclidean' || p === 2) {\n // norm(x, 2) = sum(abs(xi) ^ 2) ^ 1/2\n return x.abs().pow(scalar(2, 'int32')).sum(axis).sqrt() as Tensor;\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n // matrix (assumption axis[0] < axis[1])\n if (axis instanceof Array && axis.length === 2) {\n if (p === 1) {\n return x.abs().sum(axis[0]).max(axis[1] - 1);\n }\n if (p === Infinity) {\n return x.abs().sum(axis[1]).max(axis[0]);\n }\n if (p === -Infinity) {\n return x.abs().sum(axis[1]).min(axis[0]);\n }\n if (p === 'fro' || p === 'euclidean') {\n // norm(x) = sqrt(sum(pow(x, 2)))\n return x.square().sum(axis).sqrt();\n }\n\n throw new Error(`Error in norm: invalid ord value: ${p}`);\n }\n\n throw new Error(`Error in norm: invalid axis: ${axis}`);\n}\n\nexport const norm = op({norm_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor, Tensor1D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assert, isInt} from '../util';\nimport {expandDims} from './array_ops';\nimport {getUndoAxesPermutation, parseAxisParam} from './axis_util';\nimport {maximum} from './binary_ops';\nimport {greaterEqual} from './compare';\nimport {logicalAnd, where} from './logical_ops';\nimport {op} from './operation';\nimport {ones, scalar, zerosLike} from './tensor_ops';\n\n/**\n * Computes the sum along segments of a `Tensor`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const segmentIds = tf.tensor1d([1, 2, 0, 1], 'int32');\n * const numSegments = 3;\n *\n * x.unsortedSegmentSum(segmentIds, numSegments).print()\n * //or tf.unsortedSegmentSum(x, segmentIds, numSegments)\n * ```\n * @param x The `Tensor` that will be summed along its segments\n * @param segmentIds A `Tensor1D` whose rank is equal to the rank of `x`'s\n * dimension along the `axis`. Maps each element of `x` to a segment.\n * @param numSegments The number of distinct `segmentIds`\n */\n/** @doc {heading: 'Operations', subheading: 'Segment'} */\nfunction unsortedSegmentSum_(\n x: T|TensorLike, segmentIds: Tensor1D|TensorLike, numSegments: number): T {\n const $x = convertToTensor(x, 'x', 'unsortedSegmentSum');\n const $segmentIds =\n convertToTensor(segmentIds, 'segmentIds', 'unsortedSegmentSum', 'int32');\n assert($segmentIds.dtype === 'int32', 'segmentIds must be of dtype `int32`');\n assert(isInt(numSegments), 'numSegments must be of dtype int');\n\n const gradFunc = (dy: T) => {\n const derX = () => {\n return gatherDropNegatives(dy, $segmentIds);\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend =>\n backend.unsortedSegmentSum($x, $segmentIds, numSegments),\n {$x}, gradFunc) as T;\n}\n\n/**\n * Gather slices from tensor `x`'s axis `axis` according to `indices`.\n *\n * ```js\n * const x = tf.tensor1d([1, 2, 3, 4]);\n * const indices = tf.tensor1d([1, 3, 3], 'int32');\n *\n * x.gather(indices).print();\n * ```\n *\n * ```js\n * const x = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const indices = tf.tensor1d([1, 1, 0], 'int32');\n *\n * x.gather(indices).print();\n * ```\n * @param x The input tensor whose slices to be gathered.\n * @param indices The indices of the values to extract.\n * @param axis The axis over which to select values. Defaults to 0.\n */\n/** @doc {heading: 'Tensors', subheading: 'Slicing and Joining'} */\nfunction gather_(\n x: T|TensorLike, indices: Tensor1D|TensorLike, axis = 0): T {\n const $x = convertToTensor(x, 'x', 'gather');\n const $indices = convertToTensor(indices, 'indices', 'gather', 'int32');\n\n assert($indices.dtype === 'int32', 'Indices must be of dtype `int32`');\n axis = parseAxisParam(axis, $x.shape)[0];\n const grad = (dy: T) => {\n const derX = () => {\n if (axis === 0) {\n return unsortedSegmentSum(dy, $indices, $x.shape[axis]);\n }\n const paramsShape = $x.shape;\n const indicesSize = $indices.size;\n\n const outerShape = paramsShape.slice(0, axis);\n const outerDims = outerShape.length;\n const innerShape = paramsShape.slice(axis, paramsShape.length).slice(1);\n const innerDims = innerShape.length;\n\n const outerAxesIndices = arrayRange(0, outerDims);\n const innerAxesIndices =\n arrayRange(outerDims + 1, outerDims + 1 + innerDims);\n\n const valuesShape = arrayConcat([outerShape, [indicesSize], innerShape]);\n\n const values = dy.reshape(valuesShape);\n const reshapedIndices = $indices.reshape([indicesSize]);\n\n const transposeDims =\n arrayConcat([[outerDims], outerAxesIndices, innerAxesIndices]);\n const valuesTranspose = values.transpose(transposeDims);\n\n let paramsGrad = unsortedSegmentSum(\n valuesTranspose, reshapedIndices as Tensor1D, $x.shape[axis]);\n\n const invertTransposeDims = getUndoAxesPermutation(transposeDims);\n paramsGrad = paramsGrad.transpose(invertTransposeDims);\n\n return paramsGrad as T;\n };\n return {$x: derX};\n };\n return ENV.engine.runKernel(\n backend => backend.gather($x, $indices as Tensor1D, axis), {$x},\n grad) as T;\n}\n\nfunction arrayRange(start: number, stop: number): number[] {\n const result = [];\n for (let i = start; i < stop; ++i) {\n result.push(i);\n }\n return result;\n}\n\nfunction arrayConcat(arrays: number[][]): number[] {\n const result = [];\n for (let i = 0; i < arrays.length; ++i) {\n for (let j = 0; j < arrays[i].length; ++j) {\n result.push(arrays[i][j]);\n }\n }\n return result;\n}\n\nfunction gatherDropNegatives(x: T, indices: Tensor1D) {\n // Helper function for unsorted segment ops. Gathers params for\n // positive segment ids and gathers 0 for inputs with negative segment id.\n // Mirrors _GatherDropNegatives from tensorflow/python/ops/math_grad.py\n const zeroClippedIndices = maximum(indices, zerosLike(indices));\n const gathered = gather(x, zeroClippedIndices as Tensor1D);\n let isPositive = greaterEqual(indices, scalar(0, 'int32'));\n const numIters = gathered.rank - isPositive.rank;\n for (let i = 0; i < numIters; ++i) {\n isPositive = expandDims(isPositive, i + 1);\n }\n isPositive = logicalAnd(isPositive, ones(gathered.shape, 'bool'));\n const zeroSlice = zerosLike(gathered);\n return where(isPositive, gathered, zeroSlice);\n}\n\nexport const gather = op({gather_});\nexport const unsortedSegmentSum = op({unsortedSegmentSum_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor, convertToTensorArray} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * @docalias (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D]\n */\nexport type LSTMCellFunc = {\n (data: Tensor2D, c: Tensor2D, h: Tensor2D): [Tensor2D, Tensor2D];\n};\n\n/**\n * Computes the next states and outputs of a stack of LSTMCells.\n *\n * Each cell output is used as input to the next cell.\n *\n * Returns `[cellState, cellOutput]`.\n *\n * Derived from tf.contrib.rn.MultiRNNCell.\n *\n * @param lstmCells Array of LSTMCell functions.\n * @param data The input to the cell.\n * @param c Array of previous cell states.\n * @param h Array of previous cell outputs.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction multiRNNCell_(\n lstmCells: LSTMCellFunc[], data: Tensor2D|TensorLike,\n c: Tensor2D[]|TensorLike[],\n h: Tensor2D[]|TensorLike[]): [Tensor2D[], Tensor2D[]] {\n const $data = convertToTensor(data, 'data', 'multiRNNCell');\n const $c = convertToTensorArray(c, 'c', 'multiRNNCell');\n const $h = convertToTensorArray(h, 'h', 'multiRNNCell');\n\n let input = $data;\n const newStates = [];\n for (let i = 0; i < lstmCells.length; i++) {\n const output = lstmCells[i](input, $c[i], $h[i]);\n newStates.push(output[0]);\n newStates.push(output[1]);\n input = output[1];\n }\n const newC: Tensor2D[] = [];\n const newH: Tensor2D[] = [];\n for (let i = 0; i < newStates.length; i += 2) {\n newC.push(newStates[i]);\n newH.push(newStates[i + 1]);\n }\n return [newC, newH];\n}\n\n/**\n * Computes the next state and output of a BasicLSTMCell.\n *\n * Returns `[newC, newH]`.\n *\n * Derived from tf.contrib.rnn.BasicLSTMCell.\n *\n * @param forgetBias Forget bias for the cell.\n * @param lstmKernel The weights for the cell.\n * @param lstmBias The bias for the cell.\n * @param data The input to the cell.\n * @param c Previous cell state.\n * @param h Previous cell output.\n */\n/** @doc {heading: 'Operations', subheading: 'RNN'} */\nfunction basicLSTMCell_(\n forgetBias: Scalar|TensorLike, lstmKernel: Tensor2D|TensorLike,\n lstmBias: Tensor1D|TensorLike, data: Tensor2D|TensorLike,\n c: Tensor2D|TensorLike, h: Tensor2D|TensorLike): [Tensor2D, Tensor2D] {\n const $forgetBias =\n convertToTensor(forgetBias, 'forgetBias', 'basicLSTMCell');\n const $lstmKernel =\n convertToTensor(lstmKernel, 'lstmKernel', 'basicLSTMCell');\n const $lstmBias = convertToTensor(lstmBias, 'lstmBias', 'basicLSTMCell');\n const $data = convertToTensor(data, 'data', 'basicLSTMCell');\n const $c = convertToTensor(c, 'c', 'basicLSTMCell');\n const $h = convertToTensor(h, 'h', 'basicLSTMCell');\n\n const combined = $data.concat($h, 1);\n const weighted = combined.matMul($lstmKernel);\n const res = weighted.add($lstmBias) as Tensor2D;\n\n // i = input_gate, j = new_input, f = forget_gate, o = output_gate\n const batchSize = res.shape[0];\n const sliceCols = res.shape[1] / 4;\n const sliceSize: [number, number] = [batchSize, sliceCols];\n const i = res.slice([0, 0], sliceSize);\n const j = res.slice([0, sliceCols], sliceSize);\n const f = res.slice([0, sliceCols * 2], sliceSize);\n const o = res.slice([0, sliceCols * 3], sliceSize);\n\n const newC = i.sigmoid().mulStrict(j.tanh()).addStrict(\n $c.mulStrict($forgetBias.add(f).sigmoid() as Tensor2D));\n const newH = newC.tanh().mulStrict(o.sigmoid());\n return [newC, newH];\n}\n\nexport const basicLSTMCell = op({basicLSTMCell_});\nexport const multiRNNCell = op({multiRNNCell_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Scalar, Tensor} from '../tensor';\nimport {assertTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {pow} from './binary_ops';\nimport {op} from './operation';\nimport {scalar} from './tensor_ops';\n\n/**\n * Compute the moving average of a variable.\n *\n * Without zeroDebias, the moving average operation is defined by:\n * `v += delta`\n * where\n * `delta = (1 - decay) * (x - v)`\n *\n * With zeroDebias (default), the `delta` term is scaled to debias the\n * effect of the (assumed) zero-initialization of `v`.\n * `delta /= (1 - decay ^ step)`\n *\n * For more details on the zero-debiasing algorithm, see:\n * https://arxiv.org/abs/1412.6980\n *\n * Note that this function is completely stateless and does not keep track of\n * step count. The step count needs to be maintained by the caller and passed\n * in as `step`.\n *\n * @param v The current moving average value.\n * @param x New input value, must have the same shape and dtype as `v`.\n * @param decay The decay factor. Typical values are 0.95 and 0.99.\n * @param step Step count.\n * @param zeroDebias: Whether zeroDebias is to be performed (default: `true`).\n * @returns The new moving average value.\n */\n/** @doc {heading: 'Operations', subheading: 'Moving Average'} */\nfunction movingAverage_(\n v: T|TensorLike, x: T|TensorLike, decay: number|Scalar,\n step?: number|Scalar, zeroDebias = true): T {\n const $v = convertToTensor(v, 'v', 'movingAverage');\n const $x = convertToTensor(x, 'x', 'movingAverage');\n const $decay = convertToTensor(decay, 'decay', 'movingAverage');\n\n assertTypesMatch($v, $x);\n util.assert(\n util.arraysEqual($v.shape, $x.shape), 'Shape mismatch in v and x');\n\n const one = scalar(1);\n const oneMinusDecay = one.sub($decay);\n\n let update = $x.sub($v).mul(oneMinusDecay);\n if (zeroDebias) {\n util.assert(step != null, 'When using zeroDebias: true, step is required.');\n const $step = convertToTensor(step, 'step', 'movingAverage');\n update = update.div(one.sub(pow($decay, $step)));\n }\n return $v.add(update);\n}\n\nexport const movingAverage = op({movingAverage_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Extracts a strided slice of a tensor.\n *\n * Roughly speaking, this op extracts a slice of size (end-begin)/stride from\n * the given input_ tensor. Starting at the location specified by begin the\n * slice continues by adding stride to the index until all dimensions are not\n * less than end. Note that a stride can be negative, which causes a reverse\n * slice.\n *\n * ```js\n * t = tf.tensor3d([1, 1, 1 ,2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6],\n * [3, 2, 3]);\n * t.stridedSlice([1, 0, 0], [2, 1, 3], [1, 1, 1]).print() // [[[3, 3, 3]]]\n * t.stridedSlice([1, 0, 0], [2, 2, 3], [1, 1, 1]).print() // [[[3, 3, 3],\n * // [4, 4, 4]]]\n * t.stridedSlice([1, -1, 0], [2, -3, 3], [1, -1, 1]).print() // [[[4, 4, 4],\n * // [3, 3, 3]]]\n * ```\n *\n * @param x The tensor to stride slice.\n * @param begin The coordinates to start the slice from.\n * @param end: The coordinates to end the slice at.\n * @param strides: The size of the slice.\n * @param beginMask: If the ith bit of begin_mask is set, begin[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n * @param endMask: If the ith bit of end_mask is set, end[i] is ignored\n * and the fullest possible range in that dimension is used instead.\n */\n/** @doc {heading: 'Operations', subheading: 'Slicing and Joining'} */\nfunction stridedSlice_(\n x: T|TensorLike, begin: number[], end: number[], strides: number[],\n beginMask = 0, endMask = 0): T {\n const $x = convertToTensor(x, 'x', 'stridedSlice');\n return ENV.engine.runKernel(\n backend => backend.stridedSlice(\n $x, begin, end, strides, beginMask, endMask),\n {$x}) as T;\n}\n\nexport const stridedSlice = op({stridedSlice_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {customGrad} from '../globals';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {assertShapesMatch, sizeFromShape} from '../util';\n\nimport {expandShapeToKeepDim} from './axis_util';\n\nimport {minimum} from './binary_ops';\nimport {op} from './operation';\nimport {ones, scalar} from './tensor_ops';\n\nexport enum Reduction {\n NONE,\n MEAN,\n SUM,\n SUM_BY_NONZERO_WEIGHTS\n}\n\n/**\n * Computes the weighted loss between two tensors.\n *\n * @param losses Tensor of shape `[batch_size, d1, ... dN]`.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `losses`, and must be broadcastable to `losses` (i.e., all\n * dimensions must be either `1`, or the same as the corresponding\n * `losses` dimension).\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction computeWeightedLoss_(\n losses: T|TensorLike, weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $losses = convertToTensor(losses, 'losses', 'computeWeightedLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'computeWeightedLoss');\n }\n\n const weightedLoss = ($weights == null) ? $losses : $losses.mul($weights);\n\n if (reduction === Reduction.NONE) {\n return weightedLoss as O;\n }\n if (reduction === Reduction.SUM) {\n return weightedLoss.sum();\n }\n if (reduction === Reduction.MEAN) {\n if ($weights == null) {\n return weightedLoss.mean();\n } else {\n const broadcastFactor =\n sizeFromShape($losses.shape) / sizeFromShape($weights.shape);\n const result = weightedLoss.sum().div($weights.sum());\n return broadcastFactor > 1 ? result.div(scalar(broadcastFactor)) :\n result as O;\n }\n }\n if (reduction === Reduction.SUM_BY_NONZERO_WEIGHTS) {\n if ($weights == null) {\n return weightedLoss.sum().div(scalar($losses.size));\n } else {\n const broadcastedWeights = $weights.mul(ones($losses.shape));\n\n const numNonZeros =\n broadcastedWeights.notEqual(scalar(0)).sum().toFloat();\n return weightedLoss.sum().div(numNonZeros);\n }\n }\n\n throw Error(`Unknown reduction: ${reduction}`);\n}\n\n/**\n * Computes the absolute difference loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction absoluteDifference_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'absoluteDifference');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'absoluteDifference');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'absoluteDifference');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in absoluteDifference: ');\n\n const losses = $labels.sub($predictions).abs();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the mean squared error between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction meanSquaredError_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'meanSquaredError');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'meanSquaredError');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'meanSquaredError');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in meanSquaredError: ');\n\n const losses = $labels.squaredDifference($predictions);\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the cosine distance loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param axis The dimension along which the cosine distance is computed.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction cosineDistance_(\n labels: T|TensorLike, predictions: T|TensorLike, axis: number,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'cosineDistance');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'cosineDistance');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'cosineDistance');\n }\n assertShapesMatch(\n $labels.shape, $predictions.shape, 'Error in cosineDistance: ');\n\n const one = scalar(1);\n const losses = one.sub($labels.mul($predictions).sum(axis, true));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the Hinge loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction hingeLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $labels = convertToTensor(labels, 'labels', 'hingeLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'hingeLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'hingeLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in hingeLoss: ');\n\n const one = scalar(1);\n // Convert binary labels to (-1, 1)\n $labels = scalar(2).mul($labels).sub(one);\n const losses = one.sub($labels.mul($predictions)).relu();\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the log loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param epsilon A small increment to avoid taking log of zero\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction logLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, epsilon = 1e-7,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'logLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'logLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'logLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in logLoss: ');\n\n const one = scalar(1);\n const epsilonScalar = scalar(epsilon);\n const losses = $labels.mul($predictions.add(epsilonScalar).log())\n .neg()\n .sub(one.sub($labels).mul(\n one.sub($predictions).add(epsilonScalar).log()));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nfunction sigmoidCrossEntropyWithLogits_(\n labels: T|TensorLike, logits: T|TensorLike): O {\n const $labels =\n convertToTensor(labels, 'labels', 'sigmoidCrossEntropyWithLogits');\n const $logits =\n convertToTensor(logits, 'logits', 'sigmoidCrossEntropyWithLogits');\n assertShapesMatch(\n $labels.shape, $logits.shape, 'Error in sigmoidCrossEntropyWithLogits: ');\n\n /**\n * Implementation Details:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n *\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n *\n * Hence, to ensure stability and avoid overflow, the implementation uses\n * this equivalent formulation:\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n */\n const maxOutput = $logits.relu();\n const outputXTarget = $logits.mul($labels);\n const sigmoidOutput = $logits.abs().neg().exp().log1p();\n\n return maxOutput.sub(outputXTarget).add(sigmoidOutput);\n}\n\n/**\n * Computes the sigmoid cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newMulticlassLabels = multiclassLabels * (1 - labelSmoothing)\n * + 0.5 * labelSmoothing\n *\n * @param multiClassLabels The ground truth output tensor of shape\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction sigmoidCrossEntropy_(\n multiClassLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $multiClassLabels = convertToTensor(\n multiClassLabels, 'multiClassLabels', 'sigmoidCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'sigmoidCrossEntropy');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'sigmoidCrossEntropy');\n }\n assertShapesMatch(\n $multiClassLabels.shape, $logits.shape, 'Error in sigmoidCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const half = scalar(0.5);\n\n $multiClassLabels = $multiClassLabels.mul(one.sub(labelSmoothingScalar))\n .add(half.mul(labelSmoothingScalar));\n }\n const losses = sigmoidCrossEntropyWithLogits_($multiClassLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes the huber loss between two tensors.\n *\n * @param labels The ground truth output tensor, same dimensions as\n * 'predictions'.\n * @param predictions The predicted outputs.\n * @param weights Tensor whose rank is either 0, or the same rank as\n * `labels`, and must be broadcastable to `labels` (i.e., all dimensions\n * must be either `1`, or the same as the corresponding `losses`\n * dimension).\n * @param delta Point where huber loss changes from quadratic to linear.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`.\n */\n/** @doc {heading: 'Training', subheading: 'Losses', namespace: 'losses'} */\nfunction huberLoss_(\n labels: T|TensorLike, predictions: T|TensorLike,\n weights?: Tensor|TensorLike, delta = 1.0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n const $labels = convertToTensor(labels, 'labels', 'huberLoss');\n const $predictions = convertToTensor(predictions, 'predictions', 'huberLoss');\n let $weights: Tensor = null;\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'huberLoss');\n }\n assertShapesMatch($labels.shape, $predictions.shape, 'Error in huberLoss: ');\n\n const deltaScalar = scalar(delta);\n const error = $predictions.sub($labels).abs();\n const quadratic = minimum(error, deltaScalar);\n const linear = error.sub(quadratic);\n\n const losses =\n scalar(0.5).mul(quadratic.square()).add(deltaScalar.mul(linear));\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\n/**\n * Computes softmax cross entropy between logits and labels.\n *\n * Measures the probability error in discrete classification tasks in which\n * the classes are mutually exclusive (each entry is in exactly one class).\n * For example, each CIFAR-10 image is labeled with one and only one label: an\n * image can be a dog or a truck, but not both.\n *\n * `NOTE`: While the classes are mutually exclusive, their probabilities need\n * not be. All that is required is that each row of labels is a valid\n * probability distribution. If they are not, the computation of the gradient\n * will be incorrect.\n *\n * `WARNING`: This op expects unscaled logits, since it performs a softmax on\n * logits internally for efficiency. Do not call this op with the output of\n * softmax, as it will produce incorrect results.\n *\n * logits and labels must have the same shape, e.g. [batch_size, num_classes]\n * and the same dtype.\n * @param labels The labels array.\n * @param logits The logits array.\n * @param dim The dimension softmax would be performed on. Defaults to `-1`\n * which indicates the last dimension.\n */\nfunction softmaxCrossEntropyWithLogits_(\n labels: T, logits: T, dim = -1): O {\n if (dim === -1) {\n dim = logits.rank - 1;\n }\n\n if (dim !== logits.rank - 1) {\n throw Error(\n `Softmax cross entropy along a non-last dimension is not yet ` +\n `supported. Labels / logits was rank ${logits.rank} ` +\n `and dim was ${dim}`);\n }\n // Use a custom gradient for numerical stability.\n const customOp = customGrad((labels, logits) => {\n // Reference:\n // 1. http://cs231n.github.io/linear-classify/#softmax\n // 2. https://blog.feedly.com/tricks-of-the-trade-logsumexp/\n const keepDims = true;\n const lse = logits.logSumExp([dim], keepDims);\n\n const logResult = logits.toFloat().sub(lse);\n const costVector = logResult.mul(labels).neg();\n\n const value = costVector.sum([dim]) as O;\n\n const gradFunc = (dy: O) => {\n const dyShape = expandShapeToKeepDim(dy.shape, [dim]);\n return [\n dy.reshape(dyShape).mul(labels.toFloat().sub(logResult.exp())),\n dy.reshape(dyShape).mul(logResult.exp().sub(labels.toFloat())),\n ];\n };\n return {value, gradFunc};\n });\n\n return customOp(labels, logits);\n}\n\n/**\n * Computes the softmax cross entropy loss between two tensors.\n *\n * If labelSmoothing is nonzero, smooth the labels towards 1/2:\n *\n * newOnehotLabels = onehotLabels * (1 - labelSmoothing)\n * + labelSmoothing / numClasses\n *\n * @param onehotLabels One hot encoded labels\n * [batch_size, num_classes], same dimensions as 'predictions'.\n * @param logits The predicted outputs.\n * @param weights Tensor whose rank is either 0, or 1, and must be\n * broadcastable to `loss` of shape [batch_size]\n * @param labelSmoothing If greater than 0, then smooth the labels.\n * @param reduction Type of reduction to apply to loss. Should be of type\n * `Reduction`\n */\n/** @doc { heading: 'Training', subheading: 'Losses', namespace: 'losses' } */\nfunction softmaxCrossEntropy_(\n onehotLabels: T|TensorLike, logits: T|TensorLike,\n weights?: Tensor|TensorLike, labelSmoothing = 0,\n reduction = Reduction.SUM_BY_NONZERO_WEIGHTS): O {\n let $onehotLabels =\n convertToTensor(onehotLabels, 'onehotLabels', 'softmaxCrossEntropy');\n const $logits = convertToTensor(logits, 'logits', 'softmaxCrossEntropy');\n let $weights: Tensor = null;\n\n if (weights != null) {\n $weights = convertToTensor(weights, 'weights', 'softmaxCrossEntropy');\n }\n\n assertShapesMatch(\n $onehotLabels.shape, $logits.shape, 'Error in softmaxCrossEntropy: ');\n\n if (labelSmoothing > 0) {\n const labelSmoothingScalar = scalar(labelSmoothing);\n const one = scalar(1);\n const numClasses = scalar($onehotLabels.shape[1]);\n\n $onehotLabels = $onehotLabels.mul(one.sub(labelSmoothingScalar))\n .add(labelSmoothingScalar.div(numClasses));\n }\n\n const losses = softmaxCrossEntropyWithLogits_($onehotLabels, $logits);\n\n return computeWeightedLoss(losses, $weights, reduction);\n}\n\nexport const absoluteDifference = op({absoluteDifference_});\nexport const computeWeightedLoss = op({computeWeightedLoss_});\nexport const cosineDistance = op({cosineDistance_});\nexport const hingeLoss = op({hingeLoss_});\nexport const huberLoss = op({huberLoss_});\nexport const logLoss = op({logLoss_});\nexport const meanSquaredError = op({meanSquaredError_});\nexport const sigmoidCrossEntropy = op({sigmoidCrossEntropy_});\nexport const softmaxCrossEntropy = op({softmaxCrossEntropy_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {Tensor} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {op} from './operation';\n\n/**\n * Finds the values and indices of the `k` largest entries along the last\n * dimension.\n *\n * If the input is a vector (rank=1), finds the k largest entries in the vector\n * and outputs their values and indices as vectors. Thus values[j] is the j-th\n * largest entry in input, and its index is indices[j].\n * For higher rank inputs, computes the top k entries along the last dimension.\n *\n * If two elements are equal, the lower-index element appears first.\n *\n * ```js\n * const a = tensor2d([[1, 5], [4, 3]]);\n * const {values, indices} = tf.topk(a);\n * values.print();\n * indices.print();\n * ```\n * @param x 1-D or higher `Tensor` with last dimension being at least `k`.\n * @param k Number of top elements to look for along the last dimension.\n * @param sorted If true, the resulting `k` elements will be sorted by the\n * values in descending order.\n */\n/** @doc {heading: 'Operations', subheading: 'Evaluation'} */\nfunction topk_(\n x: T|TensorLike, k = 1, sorted = true): {values: T, indices: T} {\n const $x = convertToTensor(x, 'x', 'topk');\n if ($x.rank === 0) {\n throw new Error('topk() expects the input to be of rank 1 or higher');\n }\n const lastDim = $x.shape[$x.shape.length - 1];\n if (k > lastDim) {\n throw new Error(\n `'k' passed to topk() must be <= the last dimension (${lastDim}) ` +\n `but got ${k}`);\n }\n\n const [values, indices] =\n ENV.engine.runKernel(b => b.topk($x, k, sorted), {$x});\n return {values, indices};\n}\n\nexport const topk = op({topk_});\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Linear algebra ops.\n */\n\nimport {ENV} from '../environment';\nimport {dispose} from '../globals';\nimport {Tensor, Tensor1D, Tensor2D} from '../tensor';\nimport {assert} from '../util';\nimport {eye, split, squeeze, stack, unstack} from './array_ops';\nimport {norm} from './norm';\nimport {op} from './operation';\nimport {sum} from './reduction_ops';\nimport {tensor2d} from './tensor_ops';\n\n/**\n * Gram-Schmidt orthogonalization.\n *\n * @param xs The vectors to be orthogonalized, in one of the two following\n * formats:\n * - An Array of `Tensor1D`.\n * - A `Tensor2D`, i.e., a matrix, in which case the vectors are the rows\n * of `xs`.\n * In each case, all the vectors must have the same length and the length\n * must be greater than or equal to the number of vectors.\n * @returns The orthogonalized and normalized vectors or matrix.\n * Orthogonalization means that the vectors or the rows of the matrix\n * are orthogonal (zero inner products). Normalization means that each\n * vector or each row of the matrix has an L2 norm that equals `1`.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction gramSchmidt_(xs: Tensor1D[]|Tensor2D): Tensor1D[]|Tensor2D {\n let inputIsTensor2D: boolean;\n if (Array.isArray(xs)) {\n inputIsTensor2D = false;\n assert(\n xs != null && xs.length > 0,\n 'Gram-Schmidt process: input must not be null, undefined, or empty');\n const dim = xs[0].shape[0];\n for (let i = 1; i < xs.length; ++i) {\n assert(\n xs[i].shape[0] === dim,\n 'Gram-Schmidt: Non-unique lengths found in the input vectors: ' +\n `(${xs[i].shape[0]} vs. ${dim})`);\n }\n } else {\n inputIsTensor2D = true;\n xs = split(xs, xs.shape[0], 0).map(x => squeeze(x, [0]));\n }\n\n assert(\n xs.length <= xs[0].shape[0],\n `Gram-Schmidt: Number of vectors (${xs.length}) exceeds ` +\n `number of dimensions (${xs[0].shape[0]}).`);\n\n const ys: Tensor1D[] = [];\n const xs1d = xs as Tensor1D[];\n for (let i = 0; i < xs.length; ++i) {\n ys.push(ENV.engine.tidy(() => {\n let x = xs1d[i];\n if (i > 0) {\n for (let j = 0; j < i; ++j) {\n const proj = sum(ys[j].mulStrict(x)).mul(ys[j]);\n x = x.sub(proj);\n }\n }\n return x.div(norm(x, 'euclidean'));\n }));\n }\n\n if (inputIsTensor2D) {\n return stack(ys, 0) as Tensor2D;\n } else {\n return ys;\n }\n}\n\n/**\n * Compute QR decomposition of m-by-n matrix using Householder transformation.\n *\n * Implementation based on\n * [http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf]\n * (http://www.cs.cornell.edu/~bindel/class/cs6210-f09/lec18.pdf)\n *\n * @param x The `Tensor` to be QR-decomposed. Must have rank >= 2. Suppose\n * it has the shape `[..., M, N]`.\n * @param fullMatrices An optional boolean parameter. Defaults to `false`.\n * If `true`, compute full-sized `Q`. If `false` (the default),\n * compute only the leading N columns of `Q` and `R`.\n * @return An `Array` of two `Tensor`s: `[Q, R]`. `Q` is a unitary matrix,\n * i.e., its columns all have unit norm and are mutually orthogonal.\n * If `M >= N`,\n * If `fullMatrices` is `false` (default),\n * - `Q` has a shape of `[..., M, N]`,\n * - `R` has a shape of `[..., N, N]`.\n * If `fullMatrices` is `true` (default),\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * If `M < N`,\n * - `Q` has a shape of `[..., M, M]`,\n * - `R` has a shape of `[..., M, N]`.\n * @throws If the rank of `x` is less than 2.\n */\n/** @doc {heading: 'Operations', subheading: 'Linear Algebra'} */\nfunction qr_(x: Tensor, fullMatrices = false): [Tensor, Tensor] {\n if (x.rank < 2) {\n throw new Error(\n `qr() requires input tensor to have a rank >= 2, but got rank ${\n x.rank}`);\n } else if (x.rank === 2) {\n return qr2d(x as Tensor2D, fullMatrices);\n } else {\n // Rank > 2.\n // TODO(cais): Below we split the input into individual 2D tensors,\n // perform QR decomposition on them and then stack the results back\n // together. We should explore whether this can be parallelized.\n const outerDimsProd = x.shape.slice(0, x.shape.length - 2)\n .reduce((value, prev) => value * prev);\n const x2ds = unstack(\n x.reshape([\n outerDimsProd, x.shape[x.shape.length - 2],\n x.shape[x.shape.length - 1]\n ]),\n 0);\n const q2ds: Tensor2D[] = [];\n const r2ds: Tensor2D[] = [];\n x2ds.forEach(x2d => {\n const [q2d, r2d] = qr2d(x2d as Tensor2D, fullMatrices);\n q2ds.push(q2d);\n r2ds.push(r2d);\n });\n const q = stack(q2ds, 0).reshape(x.shape);\n const r = stack(r2ds, 0).reshape(x.shape);\n return [q, r];\n }\n}\n\nfunction qr2d(x: Tensor2D, fullMatrices = false): [Tensor2D, Tensor2D] {\n return ENV.engine.tidy(() => {\n if (x.shape.length !== 2) {\n throw new Error(\n `qr2d() requires a 2D Tensor, but got a ${x.shape.length}D Tensor.`);\n }\n\n const m = x.shape[0];\n const n = x.shape[1];\n\n let q = eye(m) as Tensor2D; // Orthogonal transform so far.\n let r = x.clone(); // Transformed matrix so far.\n\n const one2D = tensor2d([[1]], [1, 1]);\n let w: Tensor2D = one2D.clone();\n\n const iters = m >= n ? n : m;\n for (let j = 0; j < iters; ++j) {\n // This tidy within the for-loop ensures we clean up temporary\n // tensors as soon as they are no longer needed.\n const rTemp = r;\n const wTemp = w;\n const qTemp = q;\n [w, r, q] = ENV.engine.tidy((): [Tensor2D, Tensor2D, Tensor2D] => {\n // Find H = I - tau * w * w', to put zeros below R(j, j).\n const rjEnd1 = r.slice([j, j], [m - j, 1]);\n const normX = rjEnd1.norm();\n const rjj = r.slice([j, j], [1, 1]);\n const s = rjj.sign().neg() as Tensor2D;\n const u1 = rjj.sub(s.mul(normX)) as Tensor2D;\n const wPre = rjEnd1.div(u1);\n if (wPre.shape[0] === 1) {\n w = one2D.clone();\n } else {\n w = one2D.concat(\n wPre.slice([1, 0], [wPre.shape[0] - 1, wPre.shape[1]]), 0) as\n Tensor2D;\n }\n const tau = s.matMul(u1).div(normX).neg() as Tensor2D;\n\n // -- R := HR, Q := QH.\n const rjEndAll = r.slice([j, 0], [m - j, n]);\n const tauTimesW = tau.mul(w) as Tensor2D;\n if (j === 0) {\n r = rjEndAll.sub(tauTimesW.matMul(w.transpose().matMul(rjEndAll)));\n } else {\n r = r.slice([0, 0], [j, n])\n .concat(\n rjEndAll.sub(\n tauTimesW.matMul(w.transpose().matMul(rjEndAll))),\n 0) as Tensor2D;\n }\n const qAllJEnd = q.slice([0, j], [m, q.shape[1] - j]);\n if (j === 0) {\n q = qAllJEnd.sub(qAllJEnd.matMul(w).matMul(tauTimesW.transpose()));\n } else {\n q = q.slice([0, 0], [m, j])\n .concat(\n qAllJEnd.sub(\n qAllJEnd.matMul(w).matMul(tauTimesW.transpose())),\n 1) as Tensor2D;\n }\n return [w, r, q];\n });\n dispose([rTemp, wTemp, qTemp]);\n }\n\n if (!fullMatrices && m > n) {\n q = q.slice([0, 0], [m, n]);\n r = r.slice([0, 0], [n, n]);\n }\n\n return [q, r];\n }) as [Tensor2D, Tensor2D];\n}\n\nexport const gramSchmidt = op({gramSchmidt_});\nexport const qr = op({qr_});\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ForwardFunc} from '../engine';\nimport {ENV} from '../environment';\nimport {nonMaxSuppressionImpl} from '../kernels/non_max_suppression_impl';\nimport {Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\nimport {op} from './operation';\n\n/**\n * Bilinear resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeBilinear_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeBilinear');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeBilinear: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeBilinear: new shape must 2D, but got shape ` +\n `${size}.`);\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n\n const [newHeight, newWidth] = size;\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeBilinear(batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend =>\n backend.resizeBilinearBackprop(dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * NearestNeighbor resize a batch of 3D images to a new shape.\n *\n * @param images The images, of rank 4 or rank 3, of shape\n * `[batch, height, width, inChannels]`. If rank 3, batch of 1 is assumed.\n * @param size The new shape `[newHeight, newWidth]` to resize the\n * images to. Each channel is resized individually.\n * @param alignCorners Defaults to False. If true, rescale\n * input by `(new_height - 1) / (height - 1)`, which exactly aligns the 4\n * corners of images and resized images. If false, rescale by\n * `new_height / height`. Treat similarly the width dimension.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction resizeNearestNeighbor_(\n images: T|TensorLike, size: [number, number], alignCorners = false): T {\n const $images = convertToTensor(images, 'images', 'resizeNearestNeighbor');\n util.assert(\n $images.rank === 3 || $images.rank === 4,\n `Error in resizeNearestNeighbor: x must be rank 3 or 4, but got ` +\n `rank ${$images.rank}.`);\n util.assert(\n size.length === 2,\n `Error in resizeNearestNeighbor: new shape must 2D, but got shape ` +\n `${size}.`);\n util.assert(\n $images.dtype === 'float32' || $images.dtype === 'int32',\n '`images` must have `int32` or `float32` as dtype');\n\n let batchImages = $images as Tensor4D;\n let reshapedTo4D = false;\n if ($images.rank === 3) {\n reshapedTo4D = true;\n batchImages =\n $images.as4D(1, $images.shape[0], $images.shape[1], $images.shape[2]);\n }\n const [newHeight, newWidth] = size;\n\n const forward: ForwardFunc = (backend, save) =>\n backend.resizeNearestNeighbor(\n batchImages, newHeight, newWidth, alignCorners);\n\n const backward = (dy: Tensor4D, saved: Tensor[]) => {\n return {\n batchImages: () => ENV.engine.runKernel(\n backend => backend.resizeNearestNeighborBackprop(\n dy, batchImages, alignCorners),\n {})\n };\n };\n\n const res = ENV.engine.runKernel(forward, {batchImages}, backward);\n\n if (reshapedTo4D) {\n return res.as3D(res.shape[1], res.shape[2], res.shape[3]) as T;\n }\n return res as T;\n}\n\n/**\n * Performs non maximum suppression of bounding boxes based on\n * iou (intersection over union)\n *\n * @param boxes a 2d tensor of shape `[numBoxes, 4]`. Each entry is\n * `[y1, x1, y2, x2]`, where `(y1, x1)` and `(y2, x2)` are the corners of\n * the bounding box.\n * @param scores a 1d tensor providing the box scores of shape `[numBoxes]`.\n * @param maxOutputSize The maximum number of boxes to be selected.\n * @param iouThreshold A float representing the threshold for deciding whether\n * boxes overlap too much with respect to IOU. Must be betwen [0, 1].\n * Defaults to 0.5 (50% box overlap).\n * @param scoreThreshold A threshold for deciding when to remove boxes based\n * on score. Defaults to -inf, which means any score is accepted.\n * @return A 1D tensor with the selected box indices.\n */\n/** @doc {heading: 'Operations', subheading: 'Images', namespace: 'image'} */\nfunction nonMaxSuppression_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Tensor1D {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppression');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppression');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n return ENV.engine.runKernel(\n b => b.nonMaxSuppression(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold),\n {$boxes});\n}\n\n/** This is the async version of `nonMaxSuppression` */\nasync function nonMaxSuppressionAsync_(\n boxes: Tensor2D|TensorLike, scores: Tensor1D|TensorLike,\n maxOutputSize: number, iouThreshold = 0.5,\n scoreThreshold = Number.NEGATIVE_INFINITY): Promise {\n const $boxes = convertToTensor(boxes, 'boxes', 'nonMaxSuppressionAsync');\n const $scores = convertToTensor(scores, 'scores', 'nonMaxSuppressionAsync');\n\n const inputs = nonMaxSuppSanityCheck(\n $boxes, $scores, maxOutputSize, iouThreshold, scoreThreshold);\n maxOutputSize = inputs.maxOutputSize;\n iouThreshold = inputs.iouThreshold;\n scoreThreshold = inputs.scoreThreshold;\n\n const boxesVals = await $boxes.data();\n const scoresVals = await $scores.data();\n const res = nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n if ($boxes !== boxes) {\n $boxes.dispose();\n }\n if ($scores !== scores) {\n $scores.dispose();\n }\n return res;\n}\n\nfunction nonMaxSuppSanityCheck(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number):\n {maxOutputSize: number, iouThreshold: number, scoreThreshold: number} {\n if (iouThreshold == null) {\n iouThreshold = 0.5;\n }\n if (scoreThreshold == null) {\n scoreThreshold = Number.NEGATIVE_INFINITY;\n }\n const numBoxes = boxes.shape[0];\n maxOutputSize = Math.min(maxOutputSize, numBoxes);\n\n util.assert(\n 0 <= iouThreshold && iouThreshold <= 1,\n `iouThreshold must be in [0, 1], but was '${iouThreshold}'`);\n util.assert(\n boxes.rank === 2,\n `boxes must be a 2D tensor, but was of rank '${boxes.rank}'`);\n util.assert(\n boxes.shape[1] === 4,\n `boxes must have 4 columns, but 2nd dimension was ${boxes.shape[1]}`);\n util.assert(scores.rank === 1, 'scores must be a 1D tensor');\n util.assert(\n scores.shape[0] === numBoxes,\n `scores has incompatible shape with boxes. Expected ${numBoxes}, ` +\n `but was ${scores.shape[0]}`);\n return {maxOutputSize, iouThreshold, scoreThreshold};\n}\n\nexport const resizeBilinear = op({resizeBilinear_});\nexport const resizeNearestNeighbor = op({resizeNearestNeighbor_});\nexport const nonMaxSuppression = op({nonMaxSuppression_});\nexport const nonMaxSuppressionAsync = nonMaxSuppressionAsync_;\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport * as seedrandom from 'seedrandom';\nimport {ENV} from '../environment';\nimport {warn} from '../log';\nimport * as array_ops_util from '../ops/array_ops_util';\nimport * as axis_util from '../ops/axis_util';\nimport * as broadcast_util from '../ops/broadcast_util';\nimport * as concat_util from '../ops/concat_util';\nimport {Conv2DInfo} from '../ops/conv_util';\nimport * as erf_util from '../ops/erf_util';\nimport * as ops from '../ops/ops';\nimport {buffer, tensor3d, tensor4d} from '../ops/ops';\nimport * as selu_util from '../ops/selu_util';\nimport {getStridedSlicedInfo} from '../ops/slice_util';\nimport {DataId, setTensorTracker, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D} from '../tensor';\nimport {DataType, DataTypeMap, Rank, ShapeMap, TypedArray, upcastType} from '../types';\nimport * as util from '../util';\nimport {now} from '../util';\nimport {BackendTimingInfo, KernelBackend} from './backend';\nimport * as backend_util from './backend_util';\nimport {nonMaxSuppressionImpl} from './non_max_suppression_impl';\nimport {topkImpl} from './topk_impl';\nimport {whereImpl} from './where_impl';\n\nexport class MathBackendCPU implements KernelBackend {\n private data = new WeakMap();\n private canvas: HTMLCanvasElement;\n private firstUse = true;\n\n constructor() {\n if (ENV.get('IS_BROWSER')) {\n this.canvas = document.createElement('canvas');\n }\n }\n\n register(dataId: DataId, shape: number[], dtype: DataType): void {\n if (this.firstUse) {\n this.firstUse = false;\n if (ENV.get('IS_NODE')) {\n warn(\n '\\n============================\\n' +\n 'Hi there 👋. Looks like you are running TensorFlow.js in ' +\n 'Node.js. To speed things up dramatically, install our node ' +\n 'backend, which binds to TensorFlow C++, by running ' +\n 'npm i @tensorflow/tfjs-node, ' +\n 'or npm i @tensorflow/tfjs-node-gpu if you have CUDA. ' +\n 'Then call require(\\'@tensorflow/tfjs-node\\'); (-gpu ' +\n 'suffix for CUDA) at the start of your program. ' +\n 'Visit https://github.com/tensorflow/tfjs-node for more details.' +\n '\\n============================\\n');\n }\n }\n if (this.data.has(dataId)) {\n throw new Error(`Data buffer is already registered`);\n }\n this.data.set(dataId, null);\n }\n write(dataId: DataId, values: TypedArray): void {\n if (values == null) {\n throw new Error('MathBackendCPU.write(): values can not be null');\n }\n this.throwIfNoData(dataId);\n this.data.set(dataId, values);\n }\n fromPixels(\n pixels: ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement,\n numChannels: number): Tensor3D {\n if (pixels == null) {\n throw new Error('pixels passed to tf.fromPixels() can not be null');\n }\n let vals: Uint8ClampedArray;\n // tslint:disable-next-line:no-any\n if (ENV.get('IS_NODE') && (pixels as any).getContext == null) {\n throw new Error(\n 'When running in node, pixels must be an HTMLCanvasElement ' +\n 'like the one returned by the `canvas` npm package');\n }\n // tslint:disable-next-line:no-any\n if ((pixels as any).getContext != null) {\n // tslint:disable-next-line:no-any\n vals = (pixels as any)\n .getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else if (pixels instanceof ImageData) {\n vals = pixels.data;\n } else if (\n pixels instanceof HTMLImageElement ||\n pixels instanceof HTMLVideoElement) {\n if (this.canvas == null) {\n throw new Error(\n 'Can\\'t read pixels from HTMLImageElement outside ' +\n 'the browser.');\n }\n this.canvas.width = pixels.width;\n this.canvas.height = pixels.height;\n this.canvas.getContext('2d').drawImage(\n pixels, 0, 0, pixels.width, pixels.height);\n vals = this.canvas.getContext('2d')\n .getImageData(0, 0, pixels.width, pixels.height)\n .data;\n } else {\n throw new Error(\n 'pixels passed to tf.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ` +\n `ImageData, but was ${(pixels as {}).constructor.name}`);\n }\n let values: Int32Array;\n if (numChannels === 4) {\n values = new Int32Array(vals);\n } else {\n const numPixels = pixels.width * pixels.height;\n values = new Int32Array(numPixels * numChannels);\n for (let i = 0; i < numPixels; i++) {\n for (let channel = 0; channel < numChannels; ++channel) {\n values[i * numChannels + channel] = vals[i * 4 + channel];\n }\n }\n }\n const outShape: [number, number, number] =\n [pixels.height, pixels.width, numChannels];\n return tensor3d(values, outShape, 'int32');\n }\n async read(dataId: DataId): Promise {\n return this.readSync(dataId);\n }\n readSync(dataId: DataId): TypedArray {\n this.throwIfNoData(dataId);\n return this.data.get(dataId);\n }\n\n disposeData(dataId: DataId): void {\n if (this.data.has(dataId)) {\n this.data.delete(dataId);\n }\n }\n\n async time(f: () => void): Promise {\n const start = now();\n f();\n const kernelMs = now() - start;\n return {kernelMs};\n }\n memory() {\n return {\n // Unreliable due to automatic gc. The numbers above are cumulative.\n unreliable: true\n };\n }\n\n private throwIfNoData(dataId: DataId) {\n if (!this.data.has(dataId)) {\n throw new Error(\n `CPU backend: No data found for this tensor. ` +\n `Did you change your backend in the middle of the program? ` +\n `New backends can't use Tensors created with previous backends`);\n }\n }\n\n slice(x: T, begin: number[], size: number[]): T {\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; ++i) {\n const loc = buffer.indexToLoc(i);\n const xLoc = loc.map((idx, j) => idx + begin[j]);\n buffer.set(x.get(...xLoc), ...loc);\n }\n return buffer.toTensor() as T;\n }\n\n stridedSlice(\n x: T, begin: number[], end: number[], strides: number[],\n beginMask: number, endMask: number): T {\n const [beginIndex, size] =\n getStridedSlicedInfo(x.shape, begin, end, strides, beginMask, endMask);\n\n if (size.some(axis => axis === 0)) {\n return ops.tensor([], size) as T;\n }\n\n const buffer = ops.buffer(size, x.dtype);\n\n for (let i = 0; i < buffer.size; i++) {\n const loc = buffer.indexToLoc(i);\n\n const newLoc: number[] = new Array(loc.length);\n for (let j = 0; j < newLoc.length; j++) {\n newLoc[j] = loc[j] * strides[j] + beginIndex[j];\n }\n buffer.set(x.get(...newLoc), ...loc);\n }\n\n return buffer.toTensor() as T;\n }\n\n reverse(x: T, axis: number[]): T {\n const buffer = ops.buffer(x.shape, x.dtype);\n const xBuffer = x.buffer();\n\n for (let i = 0; i < buffer.size; i++) {\n const outLoc = buffer.indexToLoc(i);\n const inLoc = outLoc.slice();\n axis.forEach(ax => inLoc[ax] = x.shape[ax] - 1 - inLoc[ax]);\n buffer.set(xBuffer.get(...inLoc), ...outLoc);\n }\n\n return buffer.toTensor() as T;\n }\n\n // Concats 2d tensors along axis=1. See comments in MathBackend.concat().\n concat(a: Tensor2D, b: Tensor2D): Tensor2D {\n const outShape = concat_util.computeOutShape(\n a.shape, b.shape, 1 /* axis */) as [number, number];\n const buffer = ops.buffer(outShape, a.dtype);\n\n if (a.shape[0] === 1 && b.shape[0] === 1) {\n // Use built-in TypedArray.set() method for speed.\n const aVals = a.dataSync();\n const bVals = b.dataSync();\n const vals = buffer.values;\n vals.set(aVals, 0);\n vals.set(bVals, a.size);\n return buffer.toTensor();\n }\n\n for (let i = 0; i < outShape[0]; ++i) {\n for (let j = 0; j < a.shape[1]; ++j) {\n buffer.set(a.get(i, j), i, j);\n }\n for (let j = 0; j < b.shape[1]; ++j) {\n buffer.set(b.get(i, j), i, j + a.shape[1]);\n }\n }\n return buffer.toTensor();\n }\n\n neg(x: T): T {\n return this.multiply(ops.scalar(-1), x) as T;\n }\n\n add(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue + bValue) as Tensor;\n }\n\n addN(tensors: T[]): T {\n const vals = tensors.map(t => t.dataSync());\n const result = ops.buffer(tensors[0].shape, tensors[0].dtype);\n const resultVals = result.values;\n for (let i = 0; i < tensors.length; i++) {\n const currVals = vals[i];\n for (let j = 0; j < resultVals.length; j++) {\n resultVals[j] += currVals[j];\n }\n }\n return result.toTensor() as T;\n }\n\n subtract(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue - bValue) as Tensor;\n }\n\n pow(a: T, b: Tensor): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.pow(aValue, bValue)) as\n T;\n }\n\n matMul(a: Tensor2D, b: Tensor2D, transposeA: boolean, transposeB: boolean):\n Tensor2D {\n const sharedDim = transposeA ? a.shape[0] : a.shape[1];\n const leftDim = transposeA ? a.shape[1] : a.shape[0];\n const rightDim = transposeB ? b.shape[0] : b.shape[1];\n\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const [aOuterStep, aInnerStep] =\n transposeA ? [1, a.strides[0]] : [a.strides[0], 1];\n const [bOuterStep, bInnerStep] =\n transposeB ? [b.strides[0], 1] : [1, b.strides[0]];\n\n const aOuterEnd = leftDim * aOuterStep;\n const bOuterEnd = rightDim * bOuterStep;\n\n const result = new Float32Array(leftDim * rightDim);\n let resultIndex = 0;\n\n for (let aOuter = 0; aOuter < aOuterEnd; aOuter += aOuterStep) {\n for (let bOuter = 0; bOuter < bOuterEnd; bOuter += bOuterStep) {\n let aInner = aOuter;\n let bInner = bOuter;\n let sum = 0;\n for (let k = 0; k < sharedDim; ++k) {\n sum += aValues[aInner] * bValues[bInner];\n aInner += aInnerStep;\n bInner += bInnerStep;\n }\n result[resultIndex++] = sum;\n }\n }\n return ops.tensor2d(result, [leftDim, rightDim]);\n }\n\n multiply(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, upcastType(a.dtype, b.dtype),\n (aValue, bValue) => aValue * bValue) as Tensor;\n }\n\n realDivide(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => a / b;\n const outputDtype = 'float32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n floorDiv(a: Tensor, b: Tensor): Tensor {\n const op = (a: number, b: number) => Math.floor(a / b);\n const outputDtype = 'int32';\n return this.broadcastedBinaryOp(a, b, outputDtype, op) as Tensor;\n }\n\n sum(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('sum', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(outShape, resultDtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let sum = 0;\n for (let j = 0; j < reduceSize; ++j) {\n sum += aVals[offset + j];\n }\n vals[i] = sum;\n }\n return result;\n }\n\n unsortedSegmentSum(\n x: T, segmentIds: Tensor1D, numSegments: number): Tensor {\n const res = [];\n\n // Reshape the segment id's so that they can be broadcast with\n // x. The new shape should be [segmentIds.shape, 1, ..., 1]\n const numIters = x.rank - segmentIds.rank;\n for (let i = 0; i < numIters; ++i) {\n segmentIds = segmentIds.expandDims(i + 1);\n }\n\n for (let i = 0; i < numSegments; ++i) {\n const segmentId = ops.scalar(i, 'int32');\n const mask = ops.equal(segmentId, segmentIds).asType('float32');\n const sum = mask.mul(x).sum(0);\n res.push(sum);\n }\n\n return ops.stack(res);\n }\n\n argMin(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMin', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n let minIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n minIndex = j;\n }\n }\n vals[i] = minIndex;\n }\n return result;\n }\n\n argMax(x: Tensor, axis: number): Tensor {\n const axes = [axis];\n axis_util.assertAxesAreInnerMostDims('argMax', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, 'int32');\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n let maxIndex = 0;\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n maxIndex = j;\n }\n }\n vals[i] = maxIndex;\n }\n return result;\n }\n\n cumsum(x: Tensor, axis: number, exclusive: boolean, reverse: boolean):\n Tensor {\n if (axis !== x.rank - 1) {\n throw new Error(\n `backend.cumsum in CPU expects an inner-most axis=${x.rank - 1} ` +\n `but got axis=${axis}`);\n }\n const resultDtype = upcastType(x.dtype, 'int32');\n const result = ops.zeros(x.shape, resultDtype);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n const finalDim = x.shape[x.rank - 1];\n const indexAdjuster = reverse ?\n (i: number, j: number) => i + finalDim - j - 1 :\n (i: number, j: number) => i + j;\n for (let i = 0; i < aVals.length; i += finalDim) {\n for (let j = 0; j < finalDim; j++) {\n const idx = indexAdjuster(i, j);\n if (j === 0) {\n vals[idx] = exclusive ? 0 : aVals[idx];\n } else {\n const prevIdx = indexAdjuster(i, j - 1);\n vals[idx] = exclusive ? aVals[prevIdx] + vals[prevIdx] :\n aVals[idx] + vals[prevIdx];\n }\n }\n }\n return result;\n }\n\n equal(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal === bVal) ? 1 : 0;\n });\n }\n\n notEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal !== bVal) ? 1 : 0;\n });\n }\n\n less(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal < bVal) ? 1 : 0;\n });\n }\n\n lessEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal <= bVal) ? 1 : 0;\n });\n }\n\n greater(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal > bVal) ? 1 : 0;\n });\n }\n\n greaterEqual(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return (aVal >= bVal) ? 1 : 0;\n });\n }\n\n logicalNot(x: T): T {\n const values = x.dataSync();\n const newValues = new Int32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = values[i] ? 0 : 1;\n }\n return Tensor.make(x.shape, {values: newValues}, 'bool') as T;\n }\n\n logicalAnd(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal && bVal;\n });\n }\n\n logicalOr(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, 'bool', (aVal, bVal) => {\n return aVal || bVal;\n });\n }\n\n select(condition: Tensor, a: Tensor, b: Tensor): Tensor {\n const values = condition.dataSync();\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n const result = ops.zeros(a.shape, upcastType(a.dtype, b.dtype));\n const newValues = result.dataSync();\n let index = 0;\n const offset = condition.rank === 0 || condition.rank > 1 || a.rank === 1 ?\n 1 :\n a.shape[1];\n\n for (let i = 0; i < values.length; i++) {\n for (let j = 0; j < offset; j++) {\n if (values[i] === 1) {\n newValues[index++] = aValues[i];\n } else {\n newValues[index++] = bValues[i];\n }\n }\n }\n return result;\n }\n\n where(condition: Tensor): Tensor2D {\n const condVals = condition.dataSync();\n return whereImpl(condition.shape, condVals);\n }\n\n topk(x: T, k: number, sorted: boolean): [T, T] {\n const xVals = x.dataSync();\n return topkImpl(xVals, x.shape, x.dtype, k, sorted);\n }\n\n min(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('min', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let min = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value < min) {\n min = value;\n }\n }\n vals[i] = min;\n }\n return result;\n }\n\n minimum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.min(aVal, bVal));\n }\n\n mod(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const rem = aVal % bVal;\n if ((aVal < 0 && bVal < 0) || (aVal >= 0 && bVal >= 0)) {\n return rem;\n } else {\n return (rem + bVal) % bVal;\n }\n });\n }\n\n max(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('max', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let max = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n if (value > max) {\n max = value;\n }\n }\n vals[i] = max;\n }\n return result;\n }\n\n maximum(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aVal, bVal) => Math.max(aVal, bVal));\n }\n\n all(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('all', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let all = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n all = all && value;\n }\n vals[i] = all;\n }\n return result;\n }\n\n any(x: Tensor, axes: number[]): Tensor {\n axis_util.assertAxesAreInnerMostDims('any', axes, x.rank);\n const [outShape, reduceShape] =\n axis_util.computeOutAndReduceShapes(x.shape, axes);\n const result = ops.zeros(outShape, x.dtype);\n const reduceSize = util.sizeFromShape(reduceShape);\n const vals = result.dataSync();\n\n const aVals = x.dataSync();\n for (let i = 0; i < vals.length; ++i) {\n const offset = i * reduceSize;\n let anyVal = aVals[offset];\n for (let j = 0; j < reduceSize; ++j) {\n const value = aVals[offset + j];\n anyVal = anyVal || value;\n }\n vals[i] = anyVal;\n }\n return result;\n }\n\n squaredDifference(a: Tensor, b: Tensor): Tensor {\n return this.broadcastedBinaryOp(a, b, a.dtype, (aVal, bVal) => {\n const diff = aVal - bVal;\n return diff * diff;\n });\n }\n\n ceil(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.ceil(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n floor(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.floor(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sign(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n if (values[i] < 0) {\n newValues[i] = -1;\n } else if (values[i] > 0) {\n newValues[i] = 1;\n } else {\n newValues[i] = 0;\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n round(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n // The algorithm is based on banker's rounding.\n const base = Math.floor(values[i]);\n if (values[i] - base < 0.5) {\n newValues[i] = Math.floor(values[i]);\n } else if (values[i] - base > 0.5) {\n newValues[i] = Math.ceil(values[i]);\n } else {\n if (base % 2.0 === 0.0) {\n newValues[i] = base;\n } else {\n newValues[i] = base + 1.0;\n }\n }\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n exp(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.exp(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n expm1(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = Math.expm1(values[i]);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n log1p(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.log1p(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n sqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n rsqrt(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = 1 / Math.sqrt(value);\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n square(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n newValues[i] = value * value;\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n reciprocal(x: T): T {\n const values = x.dataSync();\n const newValues = new Float32Array(values.length);\n for (let i = 0; i < values.length; ++i) {\n newValues[i] = 1 / values[i];\n }\n return Tensor.make(x.shape, {values: newValues}) as T;\n }\n\n relu(x: T): T {\n const res = ops.zeros(x.shape, x.dtype);\n const resVals = res.dataSync();\n const inVals = x.dataSync();\n for (let i = 0; i < inVals.length; ++i) {\n resVals[i] = Math.max(0, inVals[i]);\n }\n return res as T;\n }\n\n elu(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = v;\n } else {\n resultValues[i] = (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n eluDer(dy: T, y: T): T {\n const resultValues = new Float32Array(y.size);\n const values = y.dataSync();\n const dyValues = dy.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 1) {\n resultValues[i] = dyValues[i];\n } else {\n resultValues[i] = dyValues[i] * (v + 1);\n }\n }\n return Tensor.make(y.shape, {values: resultValues}) as T;\n }\n\n selu(x: T): T {\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n const scaleAlpha = selu_util.SELU_SCALEALPHA;\n const scale = selu_util.SELU_SCALE;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n if (v >= 0) {\n resultValues[i] = scale * v;\n } else {\n resultValues[i] = scaleAlpha * (Math.exp(v) - 1);\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n clip(x: T, min: number, max: number): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.min(max, Math.max(min, values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n abs(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.abs(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n int(x: T): T {\n const resultValues = new Int32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = values[i];\n }\n return Tensor.make(x.shape, {values: resultValues}, 'int32');\n }\n\n sigmoid(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = 1 / (1 + Math.exp(-values[i]));\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n softplus(x: T): T {\n // mirrors the implementation of tf.nn.softplus: https://goo.gl/vkcvwX\n\n // epsilon is the difference between 1.0 and the next representable float.\n // For a single precision 32 bit float this should be 2^-23, see:\n // https://math.byu.edu/~schow/work/IEEEFloatingPoint.htm\n const epsilon = 1.1920928955078125e-7;\n const threshold = Math.log(epsilon) + 2.0;\n\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n\n for (let i = 0; i < values.length; ++i) {\n // Value above which exp(x) may overflow, but softplus(x) == x\n // is within machine epsilon.\n const tooLarge = values[i] > -threshold;\n\n // Value below which exp(x) may underflow, but softplus(x) == exp(x)\n // is within machine epsilon.\n const tooSmall = values[i] < threshold;\n\n const expX = Math.exp(values[i]);\n let result;\n\n if (tooSmall) {\n result = expX;\n } else if (tooLarge) {\n result = values[i];\n } else {\n result = Math.log(1.0 + expX);\n }\n resultValues[i] = result;\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n sin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.tan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asin(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asin(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acos(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acos(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atan(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atan2(a: T, b: T): T {\n return this.broadcastedBinaryOp(\n a, b, a.dtype, (aValue, bValue) => Math.atan2(aValue, bValue)) as\n T;\n }\n\n sinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.sinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n cosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.cosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n tanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = util.tanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n asinh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.asinh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n acosh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.acosh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n atanh(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n resultValues[i] = Math.atanh(values[i]);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n erf(x: T): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n const p = erf_util.ERF_P;\n const a1 = erf_util.ERF_A1;\n const a2 = erf_util.ERF_A2;\n const a3 = erf_util.ERF_A3;\n const a4 = erf_util.ERF_A4;\n const a5 = erf_util.ERF_A5;\n for (let i = 0; i < values.length; ++i) {\n const v = values[i];\n const t = 1.0 / (1.0 + p * v);\n resultValues[i] = 1.0 -\n (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t *\n Math.exp(-v * v);\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n step(x: T, alpha = 0): T {\n const resultValues = new Float32Array(x.size);\n const values = x.dataSync();\n for (let i = 0; i < values.length; ++i) {\n const value = values[i];\n if (isNaN(value)) {\n resultValues[i] = NaN;\n } else {\n resultValues[i] = value > 0 ? 1 : alpha;\n }\n }\n return Tensor.make(x.shape, {values: resultValues}) as T;\n }\n\n conv2d(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; wR++) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; wC++) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, d2);\n dotProd += pixel * weight;\n }\n }\n }\n y.set(dotProd, b, yR, yC, d2);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n conv2dDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let d2 = 0; d2 < outChannels; ++d2) {\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + d2];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n conv2dDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n // Need to convolve.\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, d2);\n }\n }\n }\n }\n return dW.toTensor();\n }\n\n depthwiseConv2D(x: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dilationHeight = convInfo.dilationHeight;\n const dilationWidth = convInfo.dilationWidth;\n const padLeft = convInfo.padInfo.left;\n const padTop = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n const y = ops.buffer(convInfo.outShape, x.dtype);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d1 = 0; d1 < convInfo.inChannels; ++d1) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * convInfo.strideHeight - padLeft;\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * convInfo.strideWidth - padTop;\n for (let q = 0; q < chMul; ++q) {\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const xR = xRCorner + wR * dilationHeight;\n\n if (xR < 0 || xR >= convInfo.inHeight) {\n continue;\n }\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const xC = xCCorner + wC * dilationWidth;\n\n if (xC < 0 || xC >= convInfo.inWidth) {\n continue;\n }\n\n const pixel = x.get(b, xR, xC, d1);\n const weight = filter.get(wR, wC, d1, q);\n dotProd += pixel * weight;\n }\n }\n y.set(dotProd, b, yR, yC, d1 * chMul + q);\n }\n }\n }\n }\n }\n\n return y.toTensor();\n }\n\n depthwiseConv2DDerInput(dy: Tensor4D, filter: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const dx = ops.buffer(convInfo.inShape, 'float32');\n const dxValues = dx.values;\n const [dxS0, dxS1, dxS2] = dx.strides;\n const dyValues = dy.dataSync();\n const [dyS0, dyS1, dyS2] = dy.strides;\n const fltValues = filter.dataSync();\n const [fltS0, fltS1, fltS2] = filter.strides;\n const {\n batchSize,\n filterHeight,\n filterWidth,\n inChannels,\n inHeight,\n inWidth,\n outChannels,\n outHeight,\n outWidth,\n strideHeight,\n strideWidth\n } = convInfo;\n const topPad = filterHeight - 1 - convInfo.padInfo.top;\n const leftPad = filterWidth - 1 - convInfo.padInfo.left;\n const chMul = outChannels / inChannels;\n\n for (let b = 0; b < batchSize; ++b) {\n for (let d1 = 0; d1 < inChannels; ++d1) {\n for (let xR = 0; xR < inHeight; ++xR) {\n const xRCorner = xR - topPad;\n const xRMin = Math.max(0, Math.ceil(xRCorner / strideHeight));\n const yRMax =\n Math.min(outHeight, (filterHeight + xRCorner) / strideHeight);\n\n for (let xC = 0; xC < inWidth; ++xC) {\n const xCCorner = xC - leftPad;\n const xCMin = Math.max(0, Math.ceil(xCCorner / strideWidth));\n const yCMax =\n Math.min(outWidth, (filterWidth + xCCorner) / strideWidth);\n\n let dotProd = 0;\n for (let yR = xRMin; yR < yRMax; ++yR) {\n const wR = yR * strideHeight - xRCorner;\n\n for (let yC = xCMin; yC < yCMax; ++yC) {\n const wC = yC * strideWidth - xCCorner;\n const dyOffset = dyS0 * b + dyS1 * yR + dyS2 * yC;\n const fltOffset = fltS0 * (filterHeight - 1 - wR) +\n fltS1 * (filterWidth - 1 - wC) + fltS2 * d1;\n\n for (let dm = 0; dm < chMul; ++dm) {\n const d2 = d1 * chMul + dm;\n const pixel = dyValues[dyOffset + d2];\n const weight = fltValues[fltOffset + dm];\n dotProd += pixel * weight;\n }\n }\n }\n dxValues[dxS0 * b + dxS1 * xR + dxS2 * xC + d1] = dotProd;\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n depthwiseConv2DDerFilter(x: Tensor4D, dy: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const dW = ops.buffer(convInfo.filterShape, 'float32');\n\n const leftPad = convInfo.padInfo.left;\n const topPad = convInfo.padInfo.top;\n const chMul = convInfo.outChannels / convInfo.inChannels;\n\n for (let wR = 0; wR < filterHeight; ++wR) {\n const yRMin = Math.max(0, Math.ceil((topPad - wR) / strideHeight));\n const yRMax = Math.min(\n convInfo.outHeight, (convInfo.inHeight + topPad - wR) / strideHeight);\n\n for (let wC = 0; wC < filterWidth; ++wC) {\n const yCMin = Math.max(0, Math.ceil((leftPad - wC) / strideWidth));\n const yCMax = Math.min(\n convInfo.outWidth, (convInfo.inWidth + leftPad - wC) / strideWidth);\n\n for (let d2 = 0; d2 < convInfo.outChannels; ++d2) {\n const d1 = Math.trunc(d2 / chMul);\n const dm = d2 % chMul;\n\n let dotProd = 0;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let yR = yRMin; yR < yRMax; ++yR) {\n const xR = wR + yR * strideHeight - topPad;\n for (let yC = yCMin; yC < yCMax; ++yC) {\n const xC = wC + yC * strideWidth - leftPad;\n dotProd += x.get(b, xR, xC, d1) * dy.get(b, yR, yC, d2);\n }\n }\n }\n dW.set(dotProd, wR, wC, d1, dm);\n }\n }\n }\n return dW.toTensor();\n }\n\n tile(x: T, reps: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[i] * reps[i];\n }\n const result = ops.buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = new Array(x.rank);\n for (let i = 0; i < originalLoc.length; i++) {\n originalLoc[i] = newLoc[i] % x.shape[i];\n }\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n pad(\n x: T, paddings: Array<[number, number]>, constantValue: number): T {\n const outShape = paddings.map(\n (p, i) => p[0] /* beforePad */ + x.shape[i] + p[1] /* afterPad */);\n const start = paddings.map(p => p[0]);\n const xBuffer = x.buffer();\n const buffer = ops.buffer(outShape, x.dtype);\n if (constantValue !== 0) {\n buffer.values.fill(constantValue);\n }\n\n for (let i = 0; i < x.size; i++) {\n const coords = xBuffer.indexToLoc(i);\n const outCoords = coords.map((c, i) => c + start[i]);\n buffer.set(x.get(...coords), ...outCoords);\n }\n return buffer.toTensor() as T;\n }\n\n transpose(x: T, perm: number[]): T {\n const newShape: number[] = new Array(x.rank);\n for (let i = 0; i < newShape.length; i++) {\n newShape[i] = x.shape[perm[i]];\n }\n const values = x.dataSync();\n const result = buffer(newShape, x.dtype);\n\n const xBuf = x.buffer();\n for (let i = 0; i < x.size; ++i) {\n const loc = xBuf.indexToLoc(i);\n\n // Permute location.\n const newLoc: number[] = new Array(loc.length);\n for (let i = 0; i < newLoc.length; i++) {\n newLoc[i] = loc[perm[i]];\n }\n\n const newIndex = result.locToIndex(newLoc);\n result.values[newIndex] = values[i];\n }\n return result.toTensor() as T;\n }\n\n gather(x: T, indices: Tensor1D, axis: number): T {\n const newShape: number[] = x.shape.slice();\n const indicesValues = indices.dataSync();\n newShape[axis] = indicesValues.length;\n const result = buffer(newShape, x.dtype);\n const xBuf = x.buffer();\n\n for (let i = 0; i < result.size; ++i) {\n const newLoc = result.indexToLoc(i);\n\n const originalLoc: number[] = newLoc.slice();\n originalLoc[axis] = indicesValues[newLoc[axis]];\n\n const originalIndex = xBuf.locToIndex(originalLoc);\n result.values[i] = xBuf.values[originalIndex];\n }\n return result.toTensor() as T;\n }\n\n batchToSpaceND(\n x: T, blockShape: number[], crops: number[][]): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const reshaped = array_ops_util.getReshaped(x.shape, blockShape, prod);\n const permuted =\n array_ops_util.getPermuted(reshaped.length, blockShape.length);\n const reshapedPermuted =\n array_ops_util.getReshapedPermuted(x.shape, blockShape, prod);\n const sliceBeginCoords =\n array_ops_util.getSliceBeginCoords(crops, blockShape.length);\n const sliceSize =\n array_ops_util.getSliceSize(reshapedPermuted, crops, blockShape.length);\n\n return x.reshape(reshaped)\n .transpose(permuted)\n .reshape(reshapedPermuted)\n .slice(sliceBeginCoords, sliceSize) as T;\n }\n\n spaceToBatchND(\n x: T, blockShape: number[], paddings: Array<[number, number]>): T {\n const prod = blockShape.reduce((a, b) => a * b);\n\n const completePaddings: Array<[number, number]> = [[0, 0]];\n completePaddings.push(...paddings);\n for (let i = 1 + blockShape.length; i < x.shape.length; ++i) {\n completePaddings.push([0, 0]);\n }\n\n const paddedX = x.pad(completePaddings);\n\n const reshapedPaddedShape =\n array_ops_util.getReshaped(paddedX.shape, blockShape, prod, false);\n const permutedReshapedPaddedPermutation = array_ops_util.getPermuted(\n reshapedPaddedShape.length, blockShape.length, false);\n const flattenShape = array_ops_util.getReshapedPermuted(\n paddedX.shape, blockShape, prod, false);\n\n return paddedX.reshape(reshapedPaddedShape)\n .transpose(permutedReshapedPaddedPermutation)\n .reshape(flattenShape) as T;\n }\n\n private pool(x: Tensor4D, convInfo: Conv2DInfo, poolType: 'max'|'avg'):\n Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const y = ops.buffer(convInfo.outShape, 'float32');\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n\n let minMaxValue =\n (poolType === 'max' ? Number.NEGATIVE_INFINITY :\n Number.POSITIVE_INFINITY);\n let avgValue = 0;\n let count = 0;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const pixel = x.get(b, xR, xC, d);\n if ((poolType === 'max' && pixel > minMaxValue)) {\n minMaxValue = pixel;\n } else if (poolType === 'avg') {\n avgValue += pixel;\n count++;\n }\n }\n if (isNaN(minMaxValue)) {\n break;\n }\n }\n y.set(\n poolType === 'avg' ? avgValue / count : minMaxValue, b, yR, yC,\n d);\n }\n }\n }\n }\n return y.toTensor();\n }\n\n maxPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'max');\n }\n\n private maxPoolPositions(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const maxPositions = ops.buffer(convInfo.outShape, 'int32');\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padTop = convInfo.padInfo.top;\n const padLeft = convInfo.padInfo.left;\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let yR = 0; yR < convInfo.outHeight; ++yR) {\n const xRCorner = yR * strideHeight - padTop;\n const xRMin = Math.max(0, xRCorner);\n const xRMax = Math.min(convInfo.inHeight, filterHeight + xRCorner);\n for (let yC = 0; yC < convInfo.outWidth; ++yC) {\n const xCCorner = yC * strideWidth - padLeft;\n const xCMin = Math.max(0, xCCorner);\n const xCMax = Math.min(convInfo.inWidth, filterWidth + xCCorner);\n let maxValue = Number.NEGATIVE_INFINITY;\n let maxPosition = -1;\n for (let xR = xRMin; xR < xRMax; ++xR) {\n const wR = xR - xRCorner;\n for (let xC = xCMin; xC < xCMax; ++xC) {\n const wC = xC - xCCorner;\n const pixel = x.get(b, xR, xC, d);\n if (pixel > maxValue) {\n maxValue = pixel;\n maxPosition = wR * filterWidth + wC;\n }\n }\n }\n maxPositions.set(maxPosition, b, yR, yC, d);\n }\n }\n }\n }\n return maxPositions.toTensor();\n }\n\n maxPoolBackprop(dy: Tensor4D, x: Tensor4D, y: Tensor4D, convInfo: Conv2DInfo):\n Tensor4D {\n const maxPositions = this.maxPoolPositions(x, convInfo);\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n const maxPos = filterHeight * filterWidth - 1 -\n maxPositions.get(b, dyR, dyC, d);\n const curPos = wR * filterWidth + wC;\n\n const mask = maxPos === curPos ? 1 : 0;\n if (mask === 0) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel * mask;\n }\n }\n dx.set(dotProd, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n avgPoolBackprop(dy: Tensor4D, x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n const strideHeight = convInfo.strideHeight;\n const strideWidth = convInfo.strideWidth;\n const filterHeight = convInfo.filterHeight;\n const filterWidth = convInfo.filterWidth;\n const padLeft = filterWidth - 1 - convInfo.padInfo.left;\n const padTop = filterHeight - 1 - convInfo.padInfo.top;\n const dx = ops.buffer(x.shape, 'float32');\n\n const avgMultiplier = 1 / (filterHeight * filterWidth);\n\n for (let b = 0; b < convInfo.batchSize; ++b) {\n for (let d = 0; d < convInfo.inChannels; ++d) {\n for (let dxR = 0; dxR < convInfo.inHeight; ++dxR) {\n for (let dxC = 0; dxC < convInfo.inWidth; ++dxC) {\n // Shader code begins.\n const dyRCorner = dxR - padTop;\n const dyCCorner = dxC - padLeft;\n let dotProd = 0;\n for (let wR = 0; wR < filterHeight; ++wR) {\n const dyR = (dyRCorner + wR) / strideHeight;\n if (dyR < 0 || dyR >= convInfo.outHeight ||\n Math.floor(dyR) !== dyR) {\n continue;\n }\n for (let wC = 0; wC < filterWidth; ++wC) {\n const dyC = (dyCCorner + wC) / strideWidth;\n if (dyC < 0 || dyC >= convInfo.outWidth ||\n Math.floor(dyC) !== dyC) {\n continue;\n }\n\n const pixel = dy.get(b, dyR, dyC, d);\n dotProd += pixel;\n }\n }\n dx.set(dotProd * avgMultiplier, b, dxR, dxC, d);\n }\n }\n }\n }\n return dx.toTensor();\n }\n\n cast(x: T, dtype: DataType): T {\n return backend_util.castTensor(x, dtype, this);\n }\n\n reshape(x: Tensor, shape: ShapeMap[R]): Tensor {\n return backend_util.reshapeTensor(x, shape);\n }\n\n avgPool(x: Tensor4D, convInfo: Conv2DInfo): Tensor4D {\n return this.pool(x, convInfo, 'avg').toFloat();\n }\n\n resizeBilinear(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n\n const sourceRowFloor = Math.floor(sourceFracRow);\n const sourceRowCeil =\n Math.min(oldHeight - 1, Math.ceil(sourceFracRow));\n const sourceColFloor = Math.floor(sourceFracCol);\n const sourceColCeil =\n Math.min(oldWidth - 1, Math.ceil(sourceFracCol));\n\n const topLeft = x.get(b, sourceRowFloor, sourceColFloor, d);\n const bottomLeft = x.get(b, sourceRowCeil, sourceColFloor, d);\n const topRight = x.get(b, sourceRowFloor, sourceColCeil, d);\n const bottomRight = x.get(b, sourceRowCeil, sourceColCeil, d);\n\n const rowFrac = sourceFracRow - sourceRowFloor;\n const colFrac = sourceFracCol - sourceColFloor;\n\n const top = topLeft + (topRight - topLeft) * colFrac;\n const bottom = bottomLeft + (bottomRight - bottomLeft) * colFrac;\n const newValue = top + (bottom - top) * rowFrac;\n\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n resizeBilinearBackprop(dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass and add the corresponding\n // coefficient from dy to the gradient (with some interpolation).\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n // Reference implementation\n // tslint:disable-next-line:max-line-length\n // https://github.com/tensorflow/tensorflow/blob/3039375c86a5bbc9610c7725dcaa95d635f87ba2/tensorflow/core/kernels/resize_bilinear_op.cc#L275\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < yHeight; r++) {\n const dxR = r * heightScale;\n const topDxRIndex = Math.floor(dxR);\n const bottomDxRIndex = Math.min(Math.ceil(dxR), xHeight - 1);\n const dxRLerp = dxR - topDxRIndex;\n const inverseDxRLerp = 1.0 - dxRLerp;\n\n for (let c = 0; c < yWidth; c++) {\n const dxC = c * widthScale;\n const leftDxCIndex = Math.floor(dxC);\n const rightDxCIndex = Math.min(Math.ceil(dxC), xWidth - 1);\n const dxCLerp = dxC - leftDxCIndex;\n const inverseDxCLerp = 1.0 - dxCLerp;\n\n for (let d = 0; d < depth; d++) {\n const dyVal = dy.get(b, r, c, d);\n\n let topLeft = output.get(b, topDxRIndex, leftDxCIndex, d);\n topLeft += dyVal * inverseDxRLerp * inverseDxCLerp;\n output.set(topLeft, b, topDxRIndex, leftDxCIndex, d);\n\n let topRight = output.get(b, topDxRIndex, rightDxCIndex, d);\n topRight += dyVal * inverseDxRLerp * dxCLerp;\n output.set(topRight, b, topDxRIndex, rightDxCIndex, d);\n\n let bottomLeft = output.get(b, bottomDxRIndex, leftDxCIndex, d);\n bottomLeft += dyVal * dxRLerp * inverseDxCLerp;\n output.set(bottomLeft, b, bottomDxRIndex, leftDxCIndex, d);\n\n let bottomRight = output.get(b, bottomDxRIndex, rightDxCIndex, d);\n bottomRight += dyVal * dxRLerp * dxCLerp;\n output.set(bottomRight, b, bottomDxRIndex, rightDxCIndex, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighbor(\n x: Tensor4D, newHeight: number, newWidth: number,\n alignCorners: boolean): Tensor4D {\n const [batch, oldHeight, oldWidth, numChannels] = x.shape;\n const output =\n ops.buffer([batch, newHeight, newWidth, numChannels], x.dtype);\n\n const effectiveInputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? oldHeight - 1 : oldHeight,\n (alignCorners && newWidth > 1) ? oldWidth - 1 : oldWidth\n ];\n\n const effectiveOutputSize: [number, number] = [\n (alignCorners && newHeight > 1) ? newHeight - 1 : newHeight,\n (alignCorners && newWidth > 1) ? newWidth - 1 : newWidth\n ];\n\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < newHeight; r++) {\n for (let c = 0; c < newWidth; c++) {\n for (let d = 0; d < numChannels; d++) {\n // Begin shader.\n // Compute the fractional index of the source.\n const sourceFracRow =\n (effectiveInputSize[0]) * r / (effectiveOutputSize[0]);\n const sourceFracCol =\n (effectiveInputSize[1]) * c / (effectiveOutputSize[1]);\n const sourceNearestRow = Math.min(\n oldHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n const sourceNearestCol = Math.min(\n oldWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n const newValue = x.get(b, sourceNearestRow, sourceNearestCol, d);\n output.set(newValue, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n resizeNearestNeighborBackprop(\n dy: Tensor4D, x: Tensor4D, alignCorners: boolean) {\n const [batch, xHeight, xWidth, depth] = x.shape;\n const [, yHeight, yWidth] = dy.shape;\n\n const output =\n ops.buffer([batch, xHeight, xWidth, depth], x.dtype);\n\n // In the backwards pass, we want to find the pixels that were generated for\n // each pixel in the input image the forward pass\n\n const effectiveXSize: [number, number] = [\n (alignCorners && yHeight > 1) ? xHeight - 1 : xHeight,\n (alignCorners && yWidth > 1) ? xWidth - 1 : xWidth\n ];\n\n const effectiveYSize: [number, number] = [\n (alignCorners && yHeight > 1) ? yHeight - 1 : yHeight,\n (alignCorners && yWidth > 1) ? yWidth - 1 : yWidth\n ];\n\n const heightScale = effectiveXSize[0] / effectiveYSize[0];\n const widthScale = effectiveXSize[1] / effectiveYSize[1];\n\n const invHeightScale = 1 / heightScale;\n const invWidthScale = 1 / widthScale;\n\n // This defines the size of the window of values around a particular\n // index in dy that we want to search for contributions to dx.\n const winHeight = (Math.ceil(invHeightScale) * 2) + 2;\n const winWidth = (Math.ceil(invWidthScale) * 2) + 2;\n\n // Loop over the output space.\n for (let b = 0; b < batch; b++) {\n for (let r = 0; r < xHeight; r++) {\n for (let c = 0; c < xWidth; c++) {\n // Compute bounds for where in dy we will look\n const startRLerp = Math.floor(r * invHeightScale);\n const startDyR = Math.floor(startRLerp - (winHeight / 2));\n\n const startCLerp = Math.floor(c * invWidthScale);\n const startDyC = Math.floor(startCLerp - (winWidth / 2));\n\n for (let d = 0; d < depth; d++) {\n let accum = 0;\n // loop over dy\n\n for (let dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n const dyR = dyROffset + startDyR;\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= yHeight) {\n continue;\n }\n\n for (let dyCOffSet = 0; dyCOffSet < winWidth; dyCOffSet++) {\n const dyC = dyCOffSet + startDyC;\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= yWidth) {\n continue;\n }\n\n const sourceFracRow =\n effectiveXSize[0] * (dyR / effectiveYSize[0]);\n const sourceFracCol =\n effectiveXSize[1] * (dyC / effectiveYSize[1]);\n\n const sourceNearestRow = Math.min(\n xHeight - 1,\n alignCorners ? Math.round(sourceFracRow) :\n Math.floor(sourceFracRow));\n\n const sourceNearestCol = Math.min(\n xWidth - 1,\n alignCorners ? Math.round(sourceFracCol) :\n Math.floor(sourceFracCol));\n\n if (r === sourceNearestRow && c === sourceNearestCol) {\n accum += dy.get(b, dyR, dyC, d);\n }\n }\n }\n\n output.set(accum, b, r, c, d);\n }\n }\n }\n }\n return output.toTensor();\n }\n\n batchNormalization(\n x: Tensor4D, mean: Tensor4D|Tensor1D, variance: Tensor4D|Tensor1D,\n varianceEpsilon: number, scale?: Tensor4D|Tensor1D,\n offset?: Tensor4D|Tensor1D): Tensor4D {\n const xValues = x.dataSync();\n const meanValues = mean.dataSync();\n const varianceValues = variance.dataSync();\n const scaleValues = scale ? scale.dataSync() : new Float32Array([1]);\n const offsetValues = offset ? offset.dataSync() : new Float32Array([0]);\n const outValues = new Float32Array(xValues.length);\n\n for (let i = 0; i < xValues.length; i++) {\n outValues[i] = offsetValues[i % offsetValues.length] +\n (xValues[i] - meanValues[i % meanValues.length]) *\n scaleValues[i % scaleValues.length] /\n Math.sqrt(\n varianceValues[i % varianceValues.length] + varianceEpsilon);\n }\n return tensor4d(outValues, x.shape);\n }\n\n localResponseNormalization4D(\n x: Tensor4D, radius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const output = ops.buffer(x.shape, 'float32');\n const rad = radius;\n const maxD = output.shape[3] - 1;\n\n function sumAcrossChannels(\n b: number, r: number, c: number, d: number): number {\n let sum = 0.0;\n for (let j = Math.max(0, d - rad); j <= Math.min(d + rad, maxD); j++) {\n const z = x.get(b, r, c, j);\n sum += z * z;\n }\n return sum;\n }\n\n for (let b = 0; b < output.shape[0]; b++) {\n for (let r = 0; r <= output.shape[1]; r++) {\n for (let c = 0; c < output.shape[2]; c++) {\n for (let d = 0; d < output.shape[3]; d++) {\n const sum = sumAcrossChannels(b, r, c, d);\n const val = x.get(b, r, c, d) * Math.pow(bias + alpha * sum, -beta);\n output.set(val, b, r, c, d);\n }\n }\n }\n }\n\n return output.toTensor();\n }\n\n LRNGrad(\n dy: Tensor4D, inputImage: Tensor4D, outputImage: Tensor4D,\n depthRadius: number, bias: number, alpha: number,\n beta: number): Tensor4D {\n const batch = dy.shape[0];\n const rows = dy.shape[1];\n const cols = dy.shape[2];\n const depth = dy.shape[3];\n const output = ops.buffer([batch, rows, cols, depth], 'float32');\n\n for (let b = 0; b < batch; ++b) {\n for (let r = 0; r < rows; ++r) {\n for (let c = 0; c < cols; ++c) {\n for (let d = 0; d < depth; ++d) {\n const depthBegin = Math.max(0, d - depthRadius);\n const depthEnd = Math.min(depth, d + depthRadius + 1);\n\n let norm = 0;\n for (let k = depthBegin; k < depthEnd; ++k) {\n norm += inputImage.get(b, r, c, k) * inputImage.get(b, r, c, k);\n }\n norm = alpha * norm + bias;\n for (let k = depthBegin; k < depthEnd; ++k) {\n let dyi = -2 * alpha * beta * inputImage.get(b, r, c, k) *\n outputImage.get(b, r, c, d) / norm;\n if (d === k) {\n dyi += Math.pow(norm, -beta);\n }\n dyi *= dy.get(b, r, c, d);\n output.set(dyi + output.get(b, r, c, k), b, r, c, k);\n }\n }\n }\n }\n }\n return output.toTensor();\n }\n\n multinomial(\n logits: Tensor2D, normalized: boolean, numSamples: number,\n seed: number): Tensor2D {\n const probabilities = normalized ? logits : ops.softmax(logits);\n const batchSize = probabilities.shape[0];\n const numEvents = probabilities.shape[1];\n const res = ops.zeros([batchSize, numSamples], 'int32');\n const resVals = res.dataSync();\n const probVals = probabilities.dataSync();\n\n for (let b = 0; b < batchSize; ++b) {\n const offset = b * numEvents;\n // The cdf won't include the last event. It will be implicit if no other\n // event happened.\n const cdf = new Float32Array(numEvents - 1);\n cdf[0] = probVals[offset];\n for (let event = 1; event < cdf.length; ++event) {\n cdf[event] = cdf[event - 1] + probVals[offset + event];\n }\n\n const random = seedrandom.alea(seed.toString());\n const outOffset = b * numSamples;\n for (let sampleId = 0; sampleId < numSamples; ++sampleId) {\n const r = random();\n\n // Assume last event happened by default.\n resVals[outOffset + sampleId] = cdf.length;\n\n for (let event = 0; event < cdf.length; event++) {\n if (r < cdf[event]) {\n resVals[outOffset + sampleId] = event;\n break;\n }\n }\n }\n }\n return res;\n }\n\n oneHot(indices: Tensor1D, depth: number, onValue: number, offValue: number):\n Tensor2D {\n const res = new Float32Array(indices.size * depth);\n res.fill(offValue);\n\n for (let event = 0; event < indices.size; ++event) {\n if (indices.get(event) >= 0 && indices.get(event) < depth) {\n res[event * depth + indices.get(event)] = onValue;\n }\n }\n return ops.tensor2d(res, [indices.size, depth], 'int32');\n }\n\n nonMaxSuppression(\n boxes: Tensor2D, scores: Tensor1D, maxOutputSize: number,\n iouThreshold: number, scoreThreshold: number): Tensor1D {\n const boxesVals = boxes.dataSync();\n const scoresVals = scores.dataSync();\n return nonMaxSuppressionImpl(\n boxesVals, scoresVals, maxOutputSize, iouThreshold, scoreThreshold);\n }\n\n private broadcastedBinaryOp(\n a: Tensor, b: Tensor, dtype: DataType,\n op: (a: number, b: number) => number): Tensor {\n const newShape =\n broadcast_util.assertAndGetBroadcastShape(a.shape, b.shape);\n const result = ops.buffer(newShape, dtype);\n const aValues = a.dataSync();\n const bValues = b.dataSync();\n\n const aBroadcastDims = broadcast_util.getBroadcastDims(a.shape, newShape);\n const bBroadcastDims = broadcast_util.getBroadcastDims(b.shape, newShape);\n\n const aBuf = a.buffer();\n const bBuf = b.buffer();\n for (let i = 0; i < result.values.length; ++i) {\n const loc = result.indexToLoc(i);\n\n const aLoc = loc.slice(-a.rank);\n aBroadcastDims.forEach(d => aLoc[d] = 0);\n const aIndex = aBuf.locToIndex(aLoc);\n\n const bLoc = loc.slice(-b.rank);\n bBroadcastDims.forEach(d => bLoc[d] = 0);\n const bIndex = bBuf.locToIndex(bLoc);\n\n result.values[i] = op(aValues[aIndex], bValues[bIndex]);\n }\n return result.toTensor();\n }\n dispose() {}\n}\n\nENV.registerBackend(\n 'cpu', () => new MathBackendCPU(), 1 /* priority */, setTensorTracker);\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nconst delayCallback = typeof requestAnimationFrame !== 'undefined' ?\n requestAnimationFrame : // Browsers\n setImmediate; // Node.js\n\n/**\n * Returns a promise that resolve when a requestAnimationFrame has completed.\n *\n * On Node.js this uses setImmediate instead of requestAnimationFrame.\n *\n * This is simply a sugar method so that users can do the following:\n * `await tf.nextFrame();`\n */\n/** @doc {heading: 'Performance', subheading: 'Timing'} */\nfunction nextFrame(): Promise {\n return new Promise(resolve => delayCallback(() => resolve()));\n}\n\nexport {nextFrame};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/* Type definitions for exporting and importing of models. */\n\n/**\n * A map from Tensor dtype to number of bytes per element of the Tensor.\n */\nexport const DTYPE_VALUE_SIZE_MAP: {[dtype: string]: number} = {\n 'float32': 4,\n 'int32': 4,\n 'uint16': 2,\n 'uint8': 1,\n 'bool': 1,\n};\n\n/**\n * A weight manifest.\n *\n * The weight manifest consists of an ordered list of weight-manifest groups.\n * Each weight-manifest group (\"group\" for short hereafter) consists of a\n * number of weight values stored in a number of paths.\n * See the documentation of `WeightManifestGroupConfig` below for more details.\n */\nexport declare type WeightsManifestConfig = WeightsManifestGroupConfig[];\n\n/**\n * A weight-manifest group.\n *\n * Consists of an ordered list of weight values encoded in binary format,\n * stored in an ordered list of paths.\n */\nexport declare interface WeightsManifestGroupConfig {\n /**\n * An ordered list of paths.\n *\n * Paths are intentionally abstract in order to be general. For example, they\n * can be relative URL paths or relative paths on the file system.\n */\n paths: string[];\n\n /**\n * Specifications of the weights stored in the paths.\n */\n weights: WeightsManifestEntry[];\n}\n\n/**\n * An entry in the weight manifest.\n *\n * The entry contains specification of a weight.\n */\nexport declare interface WeightsManifestEntry {\n /**\n * Name of the weight, e.g., 'Dense_1/bias'\n */\n name: string;\n\n /**\n * Shape of the weight.\n */\n shape: number[];\n\n /**\n * Data type of the weight.\n */\n dtype: 'float32'|'int32'|'bool';\n\n /**\n * Information for dequantization of the weight.\n */\n quantization?: {\n scale: number, // The scaling constant to multiply by.\n min: number, // The (possibly nudged) minimum weight to add.\n dtype: 'uint16'|'uint8' // The dtype of the quantized weights.\n };\n}\n\n/**\n * Options for saving a model.\n */\nexport interface SaveConfig {\n /**\n * Whether to save only the trainable weights of the model, ignoring the\n * untrainable ones.\n */\n trainableOnly?: boolean;\n}\n\n/**\n * Result of a saving operation.\n */\nexport interface SaveResult {\n /**\n * Information about the model artifacts saved.\n */\n modelArtifactsInfo: ModelArtifactsInfo;\n\n /**\n * HTTP responses from the server that handled the model-saving request (if\n * any). This is applicable only to server-based saving routes.\n */\n responses?: Response[];\n\n /**\n * Error messages and related data (if any).\n */\n errors?: Array<{}|string>;\n}\n\nexport declare interface ModelArtifactsInfo {\n /**\n * Timestamp for when the model is saved.\n */\n dateSaved: Date;\n\n /**\n * Type of the model topology\n *\n * Possible values:\n * - JSON: JSON config (human-readable, e.g., Keras JSON).\n * - GraphDef: TensorFlow\n * [GraphDef](https://www.tensorflow.org/extend/tool_developers/#graphdef)\n * protocal buffer (binary).\n */\n modelTopologyType: 'JSON'|'GraphDef';\n\n /**\n * Size of model topology (Keras JSON or GraphDef), in bytes.\n */\n modelTopologyBytes?: number;\n\n /**\n * Size of weight specification or manifest, in bytes.\n */\n weightSpecsBytes?: number;\n\n /**\n * Size of weight value data, in bytes.\n */\n weightDataBytes?: number;\n}\n\n/**\n * The serialized artifacts of a model, including topology and weights.\n *\n * The `modelTopology`, `weightSpecs` and `weightData` fields of this interface\n * are optional, in order to support topology- or weights-only saving and\n * loading.\n */\nexport declare interface ModelArtifacts {\n /**\n * Model topology.\n *\n * For Keras-style `tf.Model`s, this is a JSON object.\n * For TensorFlow-style models (e.g., `FrozenModel`), this is a binary buffer\n * carrying the `GraphDef` protocol buffer.\n */\n modelTopology?: {}|ArrayBuffer;\n\n /**\n * Weight specifications.\n *\n * This corresponds to the weightsData below.\n */\n weightSpecs?: WeightsManifestEntry[];\n\n /**\n * Binary buffer for all weight values concatenated in the order specified\n * by `weightSpecs`.\n */\n weightData?: ArrayBuffer;\n}\n\n/**\n * Type definition for handlers of loading operations.\n */\nexport type LoadHandler = () => Promise;\n\n/**\n * Type definition for handlers of saving operations.\n */\nexport type SaveHandler = (modelArtifact: ModelArtifacts) =>\n Promise;\n\n/**\n * Interface for a model import/export handler.\n *\n * The `save` and `load` handlers are both optional, in order to allow handlers\n * that support only saving or loading.\n */\n// tslint:disable-next-line:interface-name\nexport interface IOHandler {\n save?: SaveHandler;\n load?: LoadHandler;\n}\n\n/**\n * An interface for the manager of a model store.\n *\n * A model store is defined as a storage medium on which multiple models can\n * be stored. Each stored model has a unique `path` as its identifier.\n * A `ModelStoreManager` for the store allows actions including\n *\n * - Listing the models stored in the store.\n * - Deleting a model from the store.\n */\nexport interface ModelStoreManager {\n /**\n * List all models in the model store.\n *\n * @returns A dictionary mapping paths of existing models to their\n * model artifacts info. Model artifacts info include type of the model's\n * topology, byte sizes of the topology, weights, etc.\n */\n listModels(): Promise<{[path: string]: ModelArtifactsInfo}>;\n\n /**\n * Remove a model specified by `path`.\n *\n * @param path\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n removeModel(path: string): Promise;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/tensor_ops';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport {sizeFromShape} from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, ModelArtifacts, ModelArtifactsInfo, WeightsManifestEntry} from './types';\n\n/**\n * Encode a map from names to weight values as an ArrayBuffer, along with an\n * `Array` of `WeightsManifestEntry` as specification of the encoded weights.\n *\n * This function does not perform sharding.\n *\n * This function is the reverse of `decodeWeights`.\n *\n * @param tensors A map (\"dict\") from names to tensors.\n * @returns A `Promise` of\n * - A flat `ArrayBuffer` with all the binary values of the `Tensor`s\n * concatenated.\n * - An `Array` of `WeightManifestEntry`s, carrying information including\n * tensor names, `dtype`s and shapes.\n * @throws Error: on unsupported tensor `dtype`.\n */\nexport async function encodeWeights(tensors: NamedTensorMap):\n Promise<{data: ArrayBuffer, specs: WeightsManifestEntry[]}> {\n // TODO(adarob, cais): Support quantization.\n const specs: WeightsManifestEntry[] = [];\n const dataPromises: Array> = [];\n for (const name in tensors) {\n const t = tensors[name];\n\n if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool') {\n throw new Error(`Unsupported dtype in weight '${name}': ${t.dtype}`);\n }\n specs.push({name, shape: t.shape, dtype: t.dtype});\n dataPromises.push(t.data());\n }\n const tensorValues = await Promise.all(dataPromises);\n return {data: concatenateTypedArrays(tensorValues), specs};\n}\n\n/**\n * Decode flat ArrayBuffer as weights.\n *\n * This function does not handle sharding.\n *\n * This function is the reverse of `encodeWeights`.\n *\n * @param buffer A flat ArrayBuffer carrying the binary values of the tensors\n * concatenated in the order specified in `specs`.\n * @param specs Specifications of the names, dtypes and shapes of the tensors\n * whose value are encoded by `buffer`.\n * @return A map from tensor name to tensor value, with the names corresponding\n * to names in `specs`.\n * @throws Error, if any of the tensors has unsupported dtype.\n */\nexport function decodeWeights(\n buffer: ArrayBuffer, specs: WeightsManifestEntry[]): NamedTensorMap {\n // TODO(adarob, cais): Support quantization.\n const out: NamedTensorMap = {};\n let offset = 0;\n for (const spec of specs) {\n const name = spec.name;\n const dtype = spec.dtype;\n const shape = spec.shape;\n\n if (spec.quantization != null) {\n throw new Error(\n `decodeWeights does not support quantization yet, but encountered ` +\n `weight '${name} with quantization.'`);\n }\n\n const size = sizeFromShape(shape);\n let value: Tensor;\n if (dtype === 'float32') {\n value = tensor(new Float32Array(buffer, offset, size), shape, 'float32');\n } else if (dtype === 'int32') {\n value = tensor(new Int32Array(buffer, offset, size), shape, 'int32');\n } else if (dtype === 'bool') {\n value = tensor(new Uint8Array(buffer, offset, size), shape, 'bool');\n } else {\n throw new Error(`Unsupported dtype in weight '${name}': ${dtype}`);\n }\n out[name] = value;\n\n offset += size * DTYPE_VALUE_SIZE_MAP[dtype];\n }\n return out;\n}\n\n/**\n * Concatenate TypedArrays into an ArrayBuffer.\n */\nexport function concatenateTypedArrays(xs: TypedArray[]): ArrayBuffer {\n // TODO(adarob, cais): Support quantization.\n if (xs === null) {\n throw new Error(`Invalid input value: ${JSON.stringify(xs)}`);\n }\n\n let totalByteLength = 0;\n\n // `normalizedXs` is here for this reason: a `TypedArray`'s `buffer'\n // can have a different byte length from that of the `TypedArray` itself,\n // for example, when the `TypedArray` is created from an offset in an\n // `ArrayBuffer`. `normliazedXs` holds `TypedArray`s whose `buffer`s match\n // the `TypedArray` in byte length. If an element of `xs` does not show\n // this property, a new `TypedArray` that satisfy this property will be\n // constructed and pushed into `normalizedXs`.\n const normalizedXs: TypedArray[] = [];\n xs.forEach((x: TypedArray) => {\n totalByteLength += x.byteLength;\n // tslint:disable:no-any\n normalizedXs.push(\n x.byteLength === x.buffer.byteLength ? x :\n new (x.constructor as any)(x));\n if (!(x as any instanceof Float32Array || x as any instanceof Int32Array ||\n x as any instanceof Uint8Array)) {\n throw new Error(`Unsupported TypedArray subtype: ${x.constructor.name}`);\n }\n // tslint:enable:no-any\n });\n\n const y = new Uint8Array(totalByteLength);\n let offset = 0;\n normalizedXs.forEach((x: TypedArray) => {\n y.set(new Uint8Array(x.buffer), offset);\n offset += x.byteLength;\n });\n\n return y.buffer;\n}\n\n// Use Buffer on Node.js instead of Blob/atob/btoa\nconst useNodeBuffer = typeof Buffer !== 'undefined' &&\n (typeof Blob === 'undefined' || typeof atob === 'undefined' ||\n typeof btoa === 'undefined');\n\n/**\n * Calculate the byte length of a JavaScript string.\n *\n * Note that a JavaScript string can contain wide characters, therefore the\n * length of the string is not necessarily equal to the byte length.\n *\n * @param str Input string.\n * @returns Byte length.\n */\nexport function stringByteLength(str: string): number {\n if (useNodeBuffer) {\n return Buffer.byteLength(str);\n }\n return new Blob([str]).size;\n}\n\n/**\n * Encode an ArrayBuffer as a base64 encoded string.\n *\n * @param buffer `ArrayBuffer` to be converted.\n * @returns A string that base64-encodes `buffer`.\n */\nexport function arrayBufferToBase64String(buffer: ArrayBuffer): string {\n if (useNodeBuffer) {\n return Buffer.from(buffer).toString('base64');\n }\n return btoa(String.fromCharCode.apply(null, new Uint8Array(buffer)));\n}\n\n/**\n * Decode a base64 string as an ArrayBuffer.\n *\n * @param str Base64 string.\n * @returns Decoded `ArrayBuffer`.\n */\nexport function base64StringToArrayBuffer(str: string): ArrayBuffer {\n if (useNodeBuffer) {\n const buf = Buffer.from(str, 'base64');\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);\n }\n const s = atob(str);\n const buffer = new Uint8Array(s.length);\n for (let i = 0; i < s.length; ++i) {\n buffer.set([s.charCodeAt(i)], i);\n }\n return buffer.buffer;\n}\n\n/**\n * Concatenate a number of ArrayBuffers into one.\n *\n * @param buffers A number of array buffers to concatenate.\n * @returns Result of concatenating `buffers` in order.\n */\nexport function concatenateArrayBuffers(buffers: ArrayBuffer[]): ArrayBuffer {\n let totalByteLength = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n totalByteLength += buffer.byteLength;\n });\n\n const temp = new Uint8Array(totalByteLength);\n let offset = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n temp.set(new Uint8Array(buffer), offset);\n offset += buffer.byteLength;\n });\n return temp.buffer;\n}\n\n/**\n * Get the basename of a path.\n *\n * Behaves in a way analogous to Linux's basename command.\n *\n * @param path\n */\nexport function basename(path: string): string {\n const SEPARATOR = '/';\n path = path.trim();\n while (path.endsWith(SEPARATOR)) {\n path = path.slice(0, path.length - 1);\n }\n const items = path.split(SEPARATOR);\n return items[items.length - 1];\n}\n\n/**\n * Populate ModelArtifactsInfo fields for a model with JSON topology.\n * @param modelArtifacts\n * @returns A ModelArtifactsInfo object.\n */\nexport function getModelArtifactsInfoForJSON(modelArtifacts: ModelArtifacts):\n ModelArtifactsInfo {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error('Expected JSON model topology, received ArrayBuffer.');\n }\n\n return {\n dateSaved: new Date(),\n modelTopologyType: 'JSON',\n modelTopologyBytes: modelArtifacts.modelTopology == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.modelTopology)),\n weightSpecsBytes: modelArtifacts.weightSpecs == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)),\n weightDataBytes: modelArtifacts.weightData == null ?\n 0 :\n modelArtifacts.weightData.byteLength,\n };\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {IOHandler} from './types';\n\nexport type IORouter = (url: string) => IOHandler;\n\nexport class IORouterRegistry {\n // Singleton instance.\n private static instance: IORouterRegistry;\n\n private saveRouters: IORouter[];\n private loadRouters: IORouter[];\n\n private constructor() {\n this.saveRouters = [];\n this.loadRouters = [];\n }\n\n private static getInstance(): IORouterRegistry {\n if (IORouterRegistry.instance == null) {\n IORouterRegistry.instance = new IORouterRegistry();\n }\n return IORouterRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerSaveRouter(saveRouter: IORouter) {\n IORouterRegistry.getInstance().saveRouters.push(saveRouter);\n }\n\n /**\n * Register a load-handler router.\n *\n * @param loadRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `load` method defined or `null`.\n */\n static registerLoadRouter(loadRouter: IORouter) {\n IORouterRegistry.getInstance().loadRouters.push(loadRouter);\n }\n\n /**\n * Look up IOHandler for saving, given a URL-like string.\n *\n * @param url\n * @returns If only one match is found, an instance of IOHandler with the\n * `save` method defined. If no match is found, `null`.\n * @throws Error, if more than one match is found.\n */\n static getSaveHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'save');\n }\n\n /**\n * Look up IOHandler for loading, given a URL-like string.\n *\n * @param url\n * @returns All valid handlers for `url`, given the currently registered\n * handler routers.\n */\n static getLoadHandlers(url: string): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'load');\n }\n\n private static getHandlers(url: string, handlerType: 'save'|'load'):\n IOHandler[] {\n const validHandlers: IOHandler[] = [];\n const routers = handlerType === 'load' ? this.getInstance().loadRouters :\n this.getInstance().saveRouters;\n routers.forEach(router => {\n const handler = router(url);\n if (handler !== null) {\n validHandlers.push(handler);\n }\n });\n return validHandlers;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Classes and functions for model management across multiple storage mediums.\n *\n * Supported client actions:\n * - Listing models on all registered storage mediums.\n * - Remove model by URL from any registered storage mediums, by using URL\n * string.\n * - Moving or copying model from one path to another in the same medium or from\n * one medium to another, by using URL strings.\n */\n\nimport {assert} from '../util';\n\nimport {IORouterRegistry} from './router_registry';\nimport {ModelArtifactsInfo, ModelStoreManager} from './types';\n\nconst URL_SCHEME_SUFFIX = '://';\n\nexport class ModelStoreManagerRegistry {\n // Singleton instance.\n private static instance: ModelStoreManagerRegistry;\n\n private managers: {[scheme: string]: ModelStoreManager};\n\n private constructor() {\n this.managers = {};\n }\n\n private static getInstance(): ModelStoreManagerRegistry {\n if (ModelStoreManagerRegistry.instance == null) {\n ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry();\n }\n return ModelStoreManagerRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerManager(scheme: string, manager: ModelStoreManager) {\n assert(scheme != null, 'scheme must not be undefined or null.');\n if (scheme.endsWith(URL_SCHEME_SUFFIX)) {\n scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX));\n }\n assert(scheme.length > 0, 'scheme must not be an empty string.');\n const registry = ModelStoreManagerRegistry.getInstance();\n assert(\n registry.managers[scheme] == null,\n `A model store manager is already registered for scheme '${scheme}'.`);\n registry.managers[scheme] = manager;\n }\n\n static getManager(scheme: string): ModelStoreManager {\n const manager = this.getInstance().managers[scheme];\n if (manager == null) {\n throw new Error(`Cannot find model manager for scheme '${scheme}'`);\n }\n return manager;\n }\n\n static getSchemes(): string[] {\n return Object.keys(this.getInstance().managers);\n }\n}\n\n/**\n * Helper method for parsing a URL string into a scheme and a path.\n *\n * @param url E.g., 'localstorage://my-model'\n * @returns A dictionary with two fields: scheme and path.\n * Scheme: e.g., 'localstorage' in the example above.\n * Path: e.g., 'my-model' in the example above.\n */\nfunction parseURL(url: string): {scheme: string, path: string} {\n if (url.indexOf(URL_SCHEME_SUFFIX) === -1) {\n throw new Error(\n `The url string provided does not contain a scheme. ` +\n `Supported schemes are: ` +\n `${ModelStoreManagerRegistry.getSchemes().join(',')}`);\n }\n return {\n scheme: url.split(URL_SCHEME_SUFFIX)[0],\n path: url.split(URL_SCHEME_SUFFIX)[1],\n };\n}\n\nasync function cloneModelInternal(\n sourceURL: string, destURL: string,\n deleteSource = false): Promise {\n assert(\n sourceURL !== destURL,\n `Old path and new path are the same: '${sourceURL}'`);\n\n const loadHandlers = IORouterRegistry.getLoadHandlers(sourceURL);\n assert(\n loadHandlers.length > 0,\n `Copying failed because no load handler is found for source URL ${\n sourceURL}.`);\n assert(\n loadHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `load handlers for source URL ${sourceURL}.`);\n const loadHandler = loadHandlers[0];\n\n const saveHandlers = IORouterRegistry.getSaveHandlers(destURL);\n assert(\n saveHandlers.length > 0,\n `Copying failed because no save handler is found for destination URL ` +\n `${destURL}.`);\n assert(\n saveHandlers.length < 2,\n `Copying failed because more than one (${loadHandlers.length}) ` +\n `save handlers for destination URL ${destURL}.`);\n const saveHandler = saveHandlers[0];\n\n const sourceScheme = parseURL(sourceURL).scheme;\n const sourcePath = parseURL(sourceURL).path;\n const sameMedium = sourceScheme === parseURL(sourceURL).scheme;\n\n const modelArtifacts = await loadHandler.load();\n\n // If moving within the same storage medium, remove the old model as soon as\n // the loading is done. Without doing this, it is possible that the combined\n // size of the two models will cause the cloning to fail.\n if (deleteSource && sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n const saveResult = await saveHandler.save(modelArtifacts);\n\n // If moving between mediums, the deletion is done after the save succeeds.\n // This guards against the case in which saving to the destination medium\n // fails.\n if (deleteSource && !sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n return saveResult.modelArtifactsInfo;\n}\n\n/**\n * List all models stored in registered storage mediums.\n *\n * For a web browser environment, the registered mediums are Local Storage and\n * IndexedDB.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @returns A `Promise` of a dictionary mapping URLs of existing models to\n * their model artifacts info. URLs include medium-specific schemes, e.g.,\n * 'indexeddb://my/model/1'. Model artifacts info include type of the\n * model's topology, byte sizes of the topology, weights, etc.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function listModels(): Promise<{[url: string]: ModelArtifactsInfo}> {\n const schemes = ModelStoreManagerRegistry.getSchemes();\n const out: {[url: string]: ModelArtifactsInfo} = {};\n for (const scheme of schemes) {\n const schemeOut =\n await ModelStoreManagerRegistry.getManager(scheme).listModels();\n for (const path in schemeOut) {\n const url = scheme + URL_SCHEME_SUFFIX + path;\n out[url] = schemeOut[path];\n }\n }\n return out;\n}\n\n/**\n * Remove a model specified by URL from a reigstered storage medium.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @param url A URL to a stored model, with a scheme prefix, e.g.,\n * 'localstorage://my-model-1', 'indexeddb://my/model/2'.\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function removeModel(url: string): Promise {\n const schemeAndPath = parseURL(url);\n const manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme);\n return await manager.removeModel(schemeAndPath.path);\n}\n\n/**\n * Copy a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Copying within a storage medium, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Copying between two storage mediums, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Copy the model, from Local Storage to IndexedDB.\n * await tf.io.copyModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove both models.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of copying.\n * @param destURL Destination URL of copying.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if copying fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function copyModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = false;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\n/**\n * Move a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Moving within a storage medium, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Moving between two storage mediums, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Move the model, from Local Storage to IndexedDB.\n * await tf.io.moveModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove the moved model.\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of moving.\n * @param destURL Destination URL of moving.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if moving fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n */\n/** @doc {heading: 'Models', subheading: 'Management', namespace: 'io'} */\nasync function moveModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = true;\n return await cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\nexport {moveModel, copyModel, removeModel, listModels};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst DATABASE_NAME = 'tensorflowjs';\nconst DATABASE_VERSION = 1;\n\n// Model data and ModelArtifactsInfo (metadata) are stored in two separate\n// stores for efficient access of the list of stored models and their metadata.\n// 1. The object store for model data: topology, weights and weight manifests.\nconst MODEL_STORE_NAME = 'models_store';\n// 2. The object store for ModelArtifactsInfo, including meta-information such\n// as the type of topology (JSON vs binary), byte size of the topology, byte\n// size of the weights, etc.\nconst INFO_STORE_NAME = 'model_info_store';\n\n/**\n * Delete the entire database for tensorflow.js, including the models store.\n */\nexport async function deleteDatabase(): Promise {\n const idbFactory = getIndexedDBFactory();\n\n return new Promise((resolve, reject) => {\n const deleteRequest = idbFactory.deleteDatabase(DATABASE_NAME);\n deleteRequest.onsuccess = () => resolve();\n deleteRequest.onerror = error => reject(error);\n });\n}\n\nfunction getIndexedDBFactory(): IDBFactory {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Add more info about what IOHandler subtypes are available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'Failed to obtain IndexedDB factory because the current environment' +\n 'is not a web browser.');\n }\n // tslint:disable-next-line:no-any\n const theWindow: any = window;\n const factory = theWindow.indexedDB || theWindow.mozIndexedDB ||\n theWindow.webkitIndexedDB || theWindow.msIndexedDB ||\n theWindow.shimIndexedDB;\n if (factory == null) {\n throw new Error(\n 'The current browser does not appear to support IndexedDB.');\n }\n return factory;\n}\n\nfunction setUpDatabase(openRequest: IDBRequest) {\n const db = openRequest.result as IDBDatabase;\n db.createObjectStore(MODEL_STORE_NAME, {keyPath: 'modelPath'});\n db.createObjectStore(INFO_STORE_NAME, {keyPath: 'modelPath'});\n}\n\n/**\n * IOHandler subclass: Browser IndexedDB.\n *\n * See the doc string of `browserIndexedDB` for more details.\n */\nexport class BrowserIndexedDB implements IOHandler {\n protected readonly indexedDB: IDBFactory;\n protected readonly modelPath: string;\n\n static readonly URL_SCHEME = 'indexeddb://';\n\n constructor(modelPath: string) {\n this.indexedDB = getIndexedDBFactory();\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For IndexedDB, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n // TODO(cais): Support saving GraphDef models.\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n return this.databaseAction(this.modelPath, modelArtifacts) as\n Promise;\n }\n\n async load(): Promise {\n return this.databaseAction(this.modelPath) as Promise;\n }\n\n /**\n * Perform database action to put model artifacts into or read model artifacts\n * from IndexedDB object store.\n *\n * Whether the action is put or get depends on whether `modelArtifacts` is\n * specified. If it is specified, the action will be put; otherwise the action\n * will be get.\n *\n * @param modelPath A unique string path for the model.\n * @param modelArtifacts If specified, it will be the model artifacts to be\n * stored in IndexedDB.\n * @returns A `Promise` of `SaveResult`, if the action is put, or a `Promise`\n * of `ModelArtifacts`, if the action is get.\n */\n private databaseAction(modelPath: string, modelArtifacts?: ModelArtifacts):\n Promise {\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n\n if (modelArtifacts == null) {\n // Read model out from object store.\n const modelTx = db.transaction(MODEL_STORE_NAME, 'readonly');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const getRequest = modelStore.get(this.modelPath);\n getRequest.onsuccess = () => {\n if (getRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${this.modelPath}' ` +\n `in IndexedDB.`));\n } else {\n resolve(getRequest.result.modelArtifacts);\n }\n };\n getRequest.onerror = error => {\n db.close();\n return reject(getRequest.error);\n };\n modelTx.oncomplete = () => db.close();\n } else {\n // Put model into object store.\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n // First, put ModelArtifactsInfo into info store.\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n let infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const putInfoRequest =\n infoStore.put({modelPath: this.modelPath, modelArtifactsInfo});\n let modelTx: IDBTransaction;\n putInfoRequest.onsuccess = () => {\n // Second, put model data into model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const putModelRequest = modelStore.put({\n modelPath: this.modelPath,\n modelArtifacts,\n modelArtifactsInfo\n });\n putModelRequest.onsuccess = () => resolve({modelArtifactsInfo});\n putModelRequest.onerror = error => {\n // If the put-model request fails, roll back the info entry as\n // well.\n infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const deleteInfoRequest = infoStore.delete(this.modelPath);\n deleteInfoRequest.onsuccess = () => {\n db.close();\n return reject(putModelRequest.error);\n };\n deleteInfoRequest.onerror = error => {\n db.close();\n return reject(putModelRequest.error);\n };\n };\n };\n putInfoRequest.onerror = error => {\n db.close();\n return reject(putInfoRequest.error);\n };\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n }\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nexport const indexedDBRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserIndexedDB.URL_SCHEME)) {\n return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(indexedDBRouter);\nIORouterRegistry.registerLoadRouter(indexedDBRouter);\n\n/**\n * Creates a browser IndexedDB IOHandler for saving and loading models.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save('indexeddb://MyModel'));\n * console.log(saveResult);\n * ```\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `BrowserIndexedDB` (sublcass of `IOHandler`),\n * which can be used with, e.g., `tf.Model.save`.\n */\nexport function browserIndexedDB(modelPath: string): IOHandler {\n return new BrowserIndexedDB(modelPath);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserIndexedDB.URL_SCHEME) ?\n key.slice(BrowserIndexedDB.URL_SCHEME.length) :\n key;\n}\n\nexport class BrowserIndexedDBManager implements ModelStoreManager {\n private indexedDB: IDBFactory;\n\n constructor() {\n this.indexedDB = getIndexedDBFactory();\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n return new Promise<{[path: string]: ModelArtifactsInfo}>(\n (resolve, reject) => {\n const openRequest =\n this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const tx = db.transaction(INFO_STORE_NAME, 'readonly');\n const store = tx.objectStore(INFO_STORE_NAME);\n // tslint:disable:max-line-length\n // Need to cast `store` as `any` here because TypeScript's DOM\n // library does not have the `getAll()` method even though the\n // method is supported in the latest version of most mainstream\n // browsers:\n // https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/getAll\n // tslint:enable:max-line-length\n // tslint:disable-next-line:no-any\n const getAllInfoRequest = (store as any).getAll() as IDBRequest;\n getAllInfoRequest.onsuccess = () => {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n for (const item of getAllInfoRequest.result) {\n out[item.modelPath] = item.modelArtifactsInfo;\n }\n resolve(out);\n };\n getAllInfoRequest.onerror = error => {\n db.close();\n return reject(getAllInfoRequest.error);\n };\n tx.oncomplete = () => db.close();\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result as IDBDatabase;\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n const infoStore = infoTx.objectStore(INFO_STORE_NAME);\n\n const getInfoRequest = infoStore.get(path);\n let modelTx: IDBTransaction;\n getInfoRequest.onsuccess = () => {\n if (getInfoRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${path}' ` +\n `in IndexedDB.`));\n } else {\n // First, delete the entry in the info store.\n const deleteInfoRequest = infoStore.delete(path);\n const deleteModelData = () => {\n // Second, delete the entry in the model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const deleteModelRequest = modelStore.delete(path);\n deleteModelRequest.onsuccess = () =>\n resolve(getInfoRequest.result.modelArtifactsInfo);\n deleteModelRequest.onerror = error =>\n reject(getInfoRequest.error);\n };\n // Proceed with deleting model data regardless of whether deletion\n // of info data succeeds or not.\n deleteInfoRequest.onsuccess = deleteModelData;\n deleteInfoRequest.onerror = error => {\n deleteModelData();\n db.close();\n return reject(getInfoRequest.error);\n };\n }\n };\n getInfoRequest.onerror = error => {\n db.close();\n return reject(getInfoRequest.error);\n };\n\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {assert} from '../util';\nimport {arrayBufferToBase64String, base64StringToArrayBuffer, getModelArtifactsInfoForJSON} from './io_utils';\nimport {ModelStoreManagerRegistry} from './model_management';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst PATH_SEPARATOR = '/';\nconst PATH_PREFIX = 'tensorflowjs_models';\nconst INFO_SUFFIX = 'info';\nconst MODEL_TOPOLOGY_SUFFIX = 'model_topology';\nconst WEIGHT_SPECS_SUFFIX = 'weight_specs';\nconst WEIGHT_DATA_SUFFIX = 'weight_data';\n\n/**\n * Purge all tensorflow.js-saved model artifacts from local storage.\n *\n * @returns Paths of the models purged.\n */\nexport function purgeLocalStorageArtifacts(): string[] {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n throw new Error(\n 'purgeLocalStorageModels() cannot proceed because local storage is ' +\n 'unavailable in the current environment.');\n }\n const LS = window.localStorage;\n const purgedModelPaths: string[] = [];\n for (let i = 0; i < LS.length; ++i) {\n const key = LS.key(i);\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n if (key.startsWith(prefix) && key.length > prefix.length) {\n LS.removeItem(key);\n const modelName = getModelPathFromKey(key);\n if (purgedModelPaths.indexOf(modelName) === -1) {\n purgedModelPaths.push(modelName);\n }\n }\n }\n return purgedModelPaths;\n}\n\nfunction getModelKeys(path: string):\n {info: string, topology: string, weightSpecs: string, weightData: string} {\n return {\n info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR),\n topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR),\n weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR),\n weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR)\n };\n}\n\n/**\n * Get model path from a local-storage key.\n *\n * E.g., 'tensorflowjs_models/my/model/1/info' --> 'my/model/1'\n *\n * @param key\n */\nfunction getModelPathFromKey(key: string) {\n const items = key.split(PATH_SEPARATOR);\n if (items.length < 3) {\n throw new Error(`Invalid key format: ${key}`);\n }\n return items.slice(1, items.length - 1).join(PATH_SEPARATOR);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserLocalStorage.URL_SCHEME) ?\n key.slice(BrowserLocalStorage.URL_SCHEME.length) :\n key;\n}\n\n/**\n * IOHandler subclass: Browser Local Storage.\n *\n * See the doc string to `browserLocalStorage` for more details.\n */\nexport class BrowserLocalStorage implements IOHandler {\n protected readonly LS: Storage;\n protected readonly modelPath: string;\n protected readonly keys: {[key: string]: string};\n\n static readonly URL_SCHEME = 'localstorage://';\n\n constructor(modelPath: string) {\n if (!ENV.get('IS_BROWSER') || typeof window.localStorage === 'undefined') {\n // TODO(cais): Add more info about what IOHandler subtypes are\n // available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'The current environment does not support local storage.');\n }\n this.LS = window.localStorage;\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For local storage, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n this.keys = getModelKeys(this.modelPath);\n }\n\n /**\n * Save model artifacts to browser local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @param modelArtifacts The model artifacts to be stored.\n * @returns An instance of SaveResult.\n */\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const topology = JSON.stringify(modelArtifacts.modelTopology);\n const weightSpecs = JSON.stringify(modelArtifacts.weightSpecs);\n\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n\n try {\n this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo));\n this.LS.setItem(this.keys.topology, topology);\n this.LS.setItem(this.keys.weightSpecs, weightSpecs);\n this.LS.setItem(\n this.keys.weightData,\n arrayBufferToBase64String(modelArtifacts.weightData));\n\n return {modelArtifactsInfo};\n } catch (err) {\n // If saving failed, clean up all items saved so far.\n for (const key in this.keys) {\n this.LS.removeItem(this.keys[key]);\n }\n\n throw new Error(\n `Failed to save model '${this.modelPath}' to local storage: ` +\n `size quota being exceeded is a possible cause of this failure: ` +\n `modelTopologyBytes=${modelArtifactsInfo.modelTopologyBytes}, ` +\n `weightSpecsBytes=${modelArtifactsInfo.weightSpecsBytes}, ` +\n `weightDataBytes=${modelArtifactsInfo.weightDataBytes}.`);\n }\n }\n }\n\n /**\n * Load a model from local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @returns The loaded model (if loading succeeds).\n */\n async load(): Promise {\n const info =\n JSON.parse(this.LS.getItem(this.keys.info)) as ModelArtifactsInfo;\n if (info == null) {\n throw new Error(\n `In local storage, there is no model with name '${this.modelPath}'`);\n }\n\n if (info.modelTopologyType !== 'JSON') {\n throw new Error(\n 'BrowserLocalStorage does not support loading non-JSON model ' +\n 'topology yet.');\n }\n\n const out: ModelArtifacts = {};\n\n // Load topology.\n const topology = JSON.parse(this.LS.getItem(this.keys.topology));\n if (topology == null) {\n throw new Error(\n `In local storage, the topology of model '${this.modelPath}' ` +\n `is missing.`);\n }\n out.modelTopology = topology;\n\n // Load weight specs.\n const weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs));\n if (weightSpecs == null) {\n throw new Error(\n `In local storage, the weight specs of model '${this.modelPath}' ` +\n `are missing.`);\n }\n out.weightSpecs = weightSpecs;\n\n // Load weight data.\n const weightDataBase64 = this.LS.getItem(this.keys.weightData);\n if (weightDataBase64 == null) {\n throw new Error(\n `In local storage, the binary weight values of model ` +\n `'${this.modelPath}' are missing.`);\n }\n out.weightData = base64StringToArrayBuffer(weightDataBase64);\n\n return out;\n }\n}\n\nexport const localStorageRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserLocalStorage.URL_SCHEME)) {\n return browserLocalStorage(\n url.slice(BrowserLocalStorage.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(localStorageRouter);\nIORouterRegistry.registerLoadRouter(localStorageRouter);\n\n/**\n * Factory function for local storage IOHandler.\n *\n * This `IOHandler` supports both `save` and `load`.\n *\n * For each model's saved artifacts, four items are saved to local storage.\n * - `${PATH_SEPARATOR}/${modelPath}/info`: Contains meta-info about the\n * model, such as date saved, type of the topology, size in bytes, etc.\n * - `${PATH_SEPARATOR}/${modelPath}/topology`: Model topology. For Keras-\n * style models, this is a stringized JSON.\n * - `${PATH_SEPARATOR}/${modelPath}/weight_specs`: Weight specs of the\n * model, can be used to decode the saved binary weight values (see\n * item below).\n * - `${PATH_SEPARATOR}/${modelPath}/weight_data`: Concatenated binary\n * weight values, stored as a base64-encoded string.\n *\n * Saving may throw an `Error` if the total size of the artifacts exceed the\n * browser-specific quota.\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `IOHandler`, which can be used with, e.g.,\n * `tf.Model.save`.\n */\nexport function browserLocalStorage(modelPath: string): IOHandler {\n return new BrowserLocalStorage(modelPath);\n}\n\nexport class BrowserLocalStorageManager implements ModelStoreManager {\n private readonly LS: Storage;\n\n constructor() {\n assert(ENV.get('IS_BROWSER'), 'Current environment is not a web browser');\n assert(\n typeof window.localStorage !== 'undefined',\n 'Current browser does not appear to support localStorage');\n this.LS = window.localStorage;\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n const suffix = PATH_SEPARATOR + INFO_SUFFIX;\n for (let i = 0; i < this.LS.length; ++i) {\n const key = this.LS.key(i);\n if (key.startsWith(prefix) && key.endsWith(suffix)) {\n const modelPath = getModelPathFromKey(key);\n out[modelPath] = JSON.parse(this.LS.getItem(key)) as ModelArtifactsInfo;\n }\n }\n return out;\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n const keys = getModelKeys(path);\n if (this.LS.getItem(keys.info) == null) {\n throw new Error(`Cannot find model at path '${path}'`);\n }\n const info = JSON.parse(this.LS.getItem(keys.info)) as ModelArtifactsInfo;\n\n this.LS.removeItem(keys.info);\n this.LS.removeItem(keys.topology);\n this.LS.removeItem(keys.weightSpecs);\n this.LS.removeItem(keys.weightData);\n return info;\n }\n}\n\nif (ENV.get('IS_BROWSER')) {\n // Wrap the construction and registration, to guard against browsers that\n // don't support Local Storage.\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager());\n } catch (err) {\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers related to files, such as browser-triggered file downloads,\n * user-selected files in browser.\n */\n\nimport {ENV} from '../environment';\nimport {basename, concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\nconst DEFAULT_FILE_NAME_PREFIX = 'model';\nconst DEFAULT_JSON_EXTENSION_NAME = '.json';\nconst DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin';\n\nexport class BrowserDownloads implements IOHandler {\n private readonly modelTopologyFileName: string;\n private readonly weightDataFileName: string;\n private readonly jsonAnchor: HTMLAnchorElement;\n private readonly weightDataAnchor: HTMLAnchorElement;\n\n static readonly URL_SCHEME = 'downloads://';\n\n constructor(fileNamePrefix?: string) {\n if (!ENV.get('IS_BROWSER')) {\n // TODO(cais): Provide info on what IOHandlers are available under the\n // current environment.\n throw new Error(\n 'triggerDownloads() cannot proceed because the current environment ' +\n 'is not a browser.');\n }\n\n if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) {\n fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length);\n }\n if (fileNamePrefix == null || fileNamePrefix.length === 0) {\n fileNamePrefix = DEFAULT_FILE_NAME_PREFIX;\n }\n\n this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME;\n this.weightDataFileName =\n fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n const weightsURL = window.URL.createObjectURL(new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}));\n\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'DownloadTrigger.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./' + this.weightDataFileName],\n weights: modelArtifacts.weightSpecs\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n const modelTopologyAndWeightManifestURL =\n window.URL.createObjectURL(new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}));\n\n // If anchor elements are not provided, create them without attaching them\n // to parents, so that the downloaded file names can be controlled.\n const jsonAnchor = this.jsonAnchor == null ? document.createElement('a') :\n this.jsonAnchor;\n jsonAnchor.download = this.modelTopologyFileName;\n jsonAnchor.href = modelTopologyAndWeightManifestURL;\n // Trigger downloads by calling the `click` methods on the download\n // anchors.\n jsonAnchor.click();\n\n if (modelArtifacts.weightData != null) {\n const weightDataAnchor = this.weightDataAnchor == null ?\n document.createElement('a') :\n this.weightDataAnchor;\n weightDataAnchor.download = this.weightDataFileName;\n weightDataAnchor.href = weightsURL;\n weightDataAnchor.click();\n }\n\n return {modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts)};\n }\n }\n}\n\nclass BrowserFiles implements IOHandler {\n private readonly files: File[];\n\n constructor(files: File[]) {\n if (files == null || files.length < 1) {\n throw new Error(\n `When calling browserFiles, at least 1 file is required, ` +\n `but received ${files}`);\n }\n this.files = files;\n }\n\n async load(): Promise {\n const jsonFile = this.files[0];\n const weightFiles = this.files.slice(1);\n\n return new Promise((resolve, reject) => {\n const jsonReader = new FileReader();\n jsonReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const modelJSON = JSON.parse((event.target as any).result);\n const modelTopology = modelJSON.modelTopology as {};\n if (modelTopology == null) {\n reject(new Error(\n `modelTopology field is missing from file ${jsonFile.name}`));\n return;\n }\n\n if (weightFiles.length === 0) {\n resolve({modelTopology});\n }\n\n const weightsManifest =\n modelJSON.weightsManifest as WeightsManifestConfig;\n if (weightsManifest == null) {\n reject(new Error(\n `weightManifest field is missing from file ${jsonFile.name}`));\n return;\n }\n\n let pathToFile: {[path: string]: File};\n try {\n pathToFile =\n this.checkManifestAndWeightFiles(weightsManifest, weightFiles);\n } catch (err) {\n reject(err);\n return;\n }\n\n const weightSpecs: WeightsManifestEntry[] = [];\n const paths: string[] = [];\n const perFileBuffers: ArrayBuffer[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n paths.push(path);\n perFileBuffers.push(null);\n });\n weightSpecs.push(...weightsGroup.weights);\n });\n\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n const weightFileReader = new FileReader();\n weightFileReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const weightData = (event.target as any).result as ArrayBuffer;\n const index = paths.indexOf(path);\n perFileBuffers[index] = weightData;\n if (perFileBuffers.indexOf(null) === -1) {\n resolve({\n modelTopology,\n weightSpecs,\n weightData: concatenateArrayBuffers(perFileBuffers),\n });\n }\n };\n weightFileReader.onerror = (error: FileReaderProgressEvent) => {\n reject(`Failed to weights data from file of path '${path}'.`);\n return;\n };\n weightFileReader.readAsArrayBuffer(pathToFile[path]);\n });\n });\n };\n jsonReader.onerror = (error: FileReaderProgressEvent) => {\n reject(\n `Failed to read model topology and weights manifest JSON ` +\n `from file '${jsonFile.name}'. BrowserFiles supports loading ` +\n `Keras-style tf.Model artifacts only.`);\n return;\n };\n jsonReader.readAsText(jsonFile);\n });\n }\n\n /**\n * Check the compatibility between weights manifest and weight files.\n */\n private checkManifestAndWeightFiles(\n manifest: WeightsManifestConfig, files: File[]): {[path: string]: File} {\n const basenames: string[] = [];\n const fileNames = files.map(file => basename(file.name));\n const pathToFile: {[path: string]: File} = {};\n for (const group of manifest) {\n group.paths.forEach(path => {\n const pathBasename = basename(path);\n if (basenames.indexOf(pathBasename) !== -1) {\n throw new Error(\n `Duplicate file basename found in weights manifest: ` +\n `'${pathBasename}'`);\n }\n basenames.push(pathBasename);\n if (fileNames.indexOf(pathBasename) === -1) {\n throw new Error(\n `Weight file with basename '${pathBasename}' is not provided.`);\n } else {\n pathToFile[path] = files[fileNames.indexOf(pathBasename)];\n }\n });\n }\n\n if (basenames.length !== files.length) {\n throw new Error(\n `Mismatch in the number of files in weights manifest ` +\n `(${basenames.length}) and the number of weight files provided ` +\n `(${files.length}).`);\n }\n return pathToFile;\n }\n}\n\nexport const browserDownloadsRouter: IORouter = (url: string) => {\n if (!ENV.get('IS_BROWSER')) {\n return null;\n } else {\n if (url.startsWith(BrowserDownloads.URL_SCHEME)) {\n return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(browserDownloadsRouter);\n\n/**\n * Creates an IOHandler that triggers file downloads from the browser.\n *\n * The returned `IOHandler` instance can be used as model exporting methods such\n * as `tf.Model.save` and supports only saving.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * const saveResult = await model.save('downloads://mymodel'));\n * // This will trigger downloading of two files:\n * // 'mymodel.json' and 'mymodel.weights.bin'.\n * console.log(saveResult);\n * ```\n *\n * @param fileNamePrefix Prefix name of the files to be downloaded. For use with\n * `tf.Model`, `fileNamePrefix` should follow either of the following two\n * formats:\n * 1. `null` or `undefined`, in which case the default file\n * names will be used:\n * - 'model.json' for the JSON file containing the model topology and\n * weights manifest.\n * - 'model.weights.bin' for the binary file containing the binary weight\n * values.\n * 2. A single string or an Array of a single string, as the file name prefix.\n * For example, if `'foo'` is provided, the downloaded JSON\n * file and binary weights file will be named 'foo.json' and\n * 'foo.weights.bin', respectively.\n * @param config Additional configuration for triggering downloads.\n * @returns An instance of `DownloadTrigger` `IOHandler`.\n */\nexport function browserDownloads(fileNamePrefix = 'model'): IOHandler {\n return new BrowserDownloads(fileNamePrefix);\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from user-selected files.\n *\n * This method can be used for loading from files such as user-selected files\n * in the browser.\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * // Note: This code snippet won't run properly without the actual file input\n * // elements in the HTML DOM.\n *\n * // Suppose there are two HTML file input (``)\n * // elements.\n * const uploadJSONInput = document.getElementById('upload-json');\n * const uploadWeightsInput = document.getElementById('upload-weights');\n * const model = await tfl.loadModel(tf.io.browserFiles(\n * [uploadJSONInput.files[0], uploadWeightsInput.files[0]]));\n * ```\n *\n * @param files `File`s to load from. Currently, this function supports only\n * loading from files that contain Keras-style models (i.e., `tf.Model`s), for\n * which an `Array` of `File`s is expected (in that order):\n * - A JSON file containing the model topology and weight manifest.\n * - Optionally, One or more binary files containing the binary weights.\n * These files must have names that match the paths in the `weightsManifest`\n * contained by the aforementioned JSON file, or errors will be thrown\n * during loading. These weights files have the same format as the ones\n * generated by `tensorflowjs_converter` that comes with the `tensorflowjs`\n * Python PIP package. If no weights files are provided, only the model\n * topology will be loaded from the JSON file above.\n * @returns An instance of `Files` `IOHandler`.\n */\nexport function browserFiles(files: File[]): IOHandler {\n return new BrowserFiles(files);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {tensor} from '../ops/ops';\nimport {NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport * as util from '../util';\nimport {DTYPE_VALUE_SIZE_MAP, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\n/**\n * Reads binary weights data from a number of URLs.\n *\n * @param fetchURLs URLs to send the HTTP requests at, using `fetch` calls.\n * @param requestOptions RequestInit (options) for the HTTP requests.\n * @returns A `Promise` of an Array of `ArrayBuffer`. The Array has the same\n * length as `fetchURLs`.\n */\nexport async function loadWeightsAsArrayBuffer(\n fetchURLs: string[], requestOptions?: RequestInit): Promise {\n // Create the requests for all of the weights in parallel.\n const requests = fetchURLs.map(fetchURL => fetch(fetchURL, requestOptions));\n const responses = await Promise.all(requests);\n const buffers =\n await Promise.all(responses.map(response => response.arrayBuffer()));\n return buffers;\n}\n\n/**\n * Reads a weights manifest JSON configuration, fetches the weights and\n * returns them as `Tensor`s.\n *\n * @param manifest The weights manifest JSON.\n * @param filePathPrefix The path prefix for filenames given in the manifest.\n * Defaults to the empty string.\n * @param weightNames The names of the weights to be fetched.\n */\nexport async function loadWeights(\n manifest: WeightsManifestConfig, filePathPrefix = '',\n weightNames?: string[],\n requestOptions?: RequestInit): Promise {\n // TODO(nsthorat): Groups are currently fetched atomically. If you need a\n // single weight from a group, the whole group will be fetched. At a future\n // date, we should support fetching only the individual shards within a\n // group that are needed to reconstruct the requested weight.\n // TODO(cais): Use `decodeWeights` for implementation.\n\n // Collect all the groups, weights, and their relative offsets to be\n // fetched.\n const groupIndicesToFetchMap = manifest.map(() => false);\n const groupWeightsToFetch: {\n [group: number]: Array<{\n manifestEntry: WeightsManifestEntry; groupOffset: number;\n sizeBytes: number;\n }>\n } = {};\n const weightsFound = weightNames != null ? weightNames.map(() => false) : [];\n const allManifestWeightNames: string[] = [];\n manifest.forEach((manifestGroupConfig, groupIndex) => {\n let groupOffset = 0;\n manifestGroupConfig.weights.forEach(weightsEntry => {\n const rawDtype = ('quantization' in weightsEntry) ?\n weightsEntry.quantization.dtype :\n weightsEntry.dtype;\n\n const weightsBytes = DTYPE_VALUE_SIZE_MAP[rawDtype] *\n util.sizeFromShape(weightsEntry.shape);\n\n const enqueueWeightsForFetchingFn = () => {\n groupIndicesToFetchMap[groupIndex] = true;\n if (groupWeightsToFetch[groupIndex] == null) {\n groupWeightsToFetch[groupIndex] = [];\n }\n\n groupWeightsToFetch[groupIndex].push({\n manifestEntry: weightsEntry,\n groupOffset,\n sizeBytes: weightsBytes\n });\n };\n\n if (weightNames != null) {\n weightNames.forEach((weightName, weightIndex) => {\n if (weightName === weightsEntry.name) {\n enqueueWeightsForFetchingFn();\n weightsFound[weightIndex] = true;\n }\n });\n } else {\n enqueueWeightsForFetchingFn();\n }\n\n allManifestWeightNames.push(weightsEntry.name);\n groupOffset += weightsBytes;\n });\n });\n\n if (!weightsFound.every(found => found)) {\n const weightsNotFound = weightNames.filter((weight, i) => !weightsFound[i]);\n throw new Error(\n `Could not find weights in manifest with names: ` +\n `${weightsNotFound.join(', ')}. \\n` +\n `Manifest JSON has weights with names: ` +\n `${allManifestWeightNames.join(', ')}.`);\n }\n\n // Convert the one-hot boolean groupId => shouldFetch map to a list of group\n // IDs.\n const groupIndicesToFetch =\n groupIndicesToFetchMap.reduce((accumulator, shouldFetch, i) => {\n if (shouldFetch) {\n accumulator.push(i);\n }\n return accumulator;\n }, []);\n\n const fetchUrls: string[] = [];\n groupIndicesToFetch.forEach(i => {\n manifest[i].paths.forEach(filepath => {\n const fetchUrl = filePathPrefix +\n (!filePathPrefix.endsWith('/') ? '/' : '') + filepath;\n fetchUrls.push(fetchUrl);\n });\n });\n const buffers = await loadWeightsAsArrayBuffer(fetchUrls, requestOptions);\n\n const weightsTensorMap: NamedTensorMap = {};\n let bufferIndexOffset = 0;\n groupIndicesToFetch.forEach(i => {\n const numBuffers = manifest[i].paths.length;\n\n let groupBytes = 0;\n for (let i = 0; i < numBuffers; i++) {\n groupBytes += buffers[bufferIndexOffset + i].byteLength;\n }\n\n // Create a buffer for the whole group.\n const groupBuffer = new ArrayBuffer(groupBytes);\n const groupByteBuffer = new Uint8Array(groupBuffer);\n let groupBufferOffset = 0;\n for (let i = 0; i < numBuffers; i++) {\n const buffer = new Uint8Array(buffers[bufferIndexOffset + i]);\n groupByteBuffer.set(buffer, groupBufferOffset);\n groupBufferOffset += buffer.byteLength;\n }\n\n const weightsEntries = groupWeightsToFetch[i];\n\n weightsEntries.forEach(weightsEntry => {\n const byteBuffer = groupBuffer.slice(\n weightsEntry.groupOffset,\n weightsEntry.groupOffset + weightsEntry.sizeBytes);\n\n let typedArray: TypedArray;\n\n const dtype = weightsEntry.manifestEntry.dtype;\n\n if ('quantization' in weightsEntry.manifestEntry) {\n const quantization = weightsEntry.manifestEntry.quantization;\n if (quantization.dtype !== 'uint8' && quantization.dtype !== 'uint16') {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown ` +\n `quantization dtype ${quantization.dtype}.`);\n }\n const quantizedArray = (quantization.dtype === 'uint8') ?\n new Uint8Array(byteBuffer) :\n new Uint16Array(byteBuffer);\n if (dtype === 'float32') {\n typedArray = Float32Array.from(\n quantizedArray, v => v * quantization.scale + quantization.min);\n } else if (dtype === 'int32') {\n typedArray = Int32Array.from(\n quantizedArray,\n v => Math.round(v * quantization.scale + quantization.min));\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has a dtype not ` +\n `supported by quantization: ${dtype}`);\n }\n } else {\n if (dtype === 'float32') {\n typedArray = new Float32Array(byteBuffer);\n } else if (dtype === 'int32') {\n typedArray = new Int32Array(byteBuffer);\n } else if (dtype === 'bool') {\n typedArray = new Uint8Array(byteBuffer);\n } else {\n throw new Error(\n `Weight ${weightsEntry.manifestEntry.name} has unknown dtype ` +\n `${dtype}.`);\n }\n }\n\n const weightName = weightsEntry.manifestEntry.name;\n if (weightsTensorMap[weightName] != null) {\n throw new Error(\n `Duplicate weight with name ${weightName}. ` +\n `Please make sure weights names are unique in the manifest JSON.`);\n }\n weightsTensorMap[weightName] = tensor(\n typedArray, weightsEntry.manifestEntry.shape,\n weightsEntry.manifestEntry.dtype);\n });\n\n bufferIndexOffset += numBuffers;\n });\n\n return weightsTensorMap;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandler implementations based on HTTP requests in the web browser.\n *\n * Uses [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).\n */\n\nimport {assert} from '../util';\nimport {concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeightsAsArrayBuffer} from './weights_loader';\n\nexport class BrowserHTTPRequest implements IOHandler {\n protected readonly path: string;\n protected readonly requestInit: RequestInit;\n\n readonly DEFAULT_METHOD = 'POST';\n\n static readonly URL_SCHEMES = ['http://', 'https://'];\n\n constructor(path: string, requestInit?: RequestInit) {\n if (typeof fetch === 'undefined') {\n throw new Error(\n // tslint:disable-next-line:max-line-length\n 'browserHTTPRequest is not supported outside the web browser without a fetch polyfill.');\n }\n\n assert(\n path != null && path.length > 0,\n 'URL path for browserHTTPRequest must not be null, undefined or ' +\n 'empty.');\n this.path = path;\n\n if (requestInit != null && requestInit.body != null) {\n throw new Error(\n 'requestInit is expected to have no pre-existing body, but has one.');\n }\n this.requestInit = requestInit || {};\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserHTTPRequest.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n const init = Object.assign({method: this.DEFAULT_METHOD}, this.requestInit);\n init.body = new FormData();\n\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./model.weights.bin'],\n weights: modelArtifacts.weightSpecs,\n }];\n const modelTopologyAndWeightManifest = {\n modelTopology: modelArtifacts.modelTopology,\n weightsManifest\n };\n\n init.body.append(\n 'model.json',\n new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}),\n 'model.json');\n\n if (modelArtifacts.weightData != null) {\n init.body.append(\n 'model.weights.bin',\n new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}),\n 'model.weights.bin');\n }\n\n const response = await fetch(this.path, init);\n\n if (response.status === 200) {\n return {\n modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts),\n responses: [response],\n };\n } else {\n throw new Error(\n `BrowserHTTPRequest.save() failed due to HTTP response status ` +\n `${response.status}.`);\n }\n }\n\n /**\n * Load model artifacts via HTTP request(s).\n *\n * See the documentation to `browserHTTPRequest` for details on the saved\n * artifacts.\n *\n * @returns The loaded model artifacts (if loading succeeds).\n */\n async load(): Promise {\n const modelConfigRequest = await fetch(this.path, this.requestInit);\n const modelConfig = await modelConfigRequest.json();\n const modelTopology = modelConfig['modelTopology'];\n const weightsManifest = modelConfig['weightsManifest'];\n\n // We do not allow both modelTopology and weightsManifest to be missing.\n if (modelTopology == null && weightsManifest == null) {\n throw new Error(\n `The JSON from HTTP path ${this.path} contains neither model ` +\n `topology or manifest for weights.`);\n }\n\n let weightSpecs: WeightsManifestEntry[];\n let weightData: ArrayBuffer;\n if (weightsManifest != null) {\n const weightsManifest =\n modelConfig['weightsManifest'] as WeightsManifestConfig;\n weightSpecs = [];\n for (const entry of weightsManifest) {\n weightSpecs.push(...entry.weights);\n }\n\n let pathPrefix = this.path.substring(0, this.path.lastIndexOf('/'));\n if (!pathPrefix.endsWith('/')) {\n pathPrefix = pathPrefix + '/';\n }\n\n const fetchURLs: string[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n fetchURLs.push(pathPrefix + path);\n });\n });\n weightData = concatenateArrayBuffers(\n await loadWeightsAsArrayBuffer(fetchURLs, this.requestInit));\n }\n\n return {modelTopology, weightSpecs, weightData};\n }\n}\n\nexport const httpRequestRouter: IORouter = (url: string) => {\n if (typeof fetch === 'undefined') {\n // browserHTTPRequest uses `fetch`, if one wants to use it in node.js\n // they have to setup a global fetch polyfill.\n return null;\n } else {\n for (const scheme of BrowserHTTPRequest.URL_SCHEMES) {\n if (url.startsWith(scheme)) {\n return browserHTTPRequest(url);\n }\n }\n return null;\n }\n};\nIORouterRegistry.registerSaveRouter(httpRequestRouter);\nIORouterRegistry.registerLoadRouter(httpRequestRouter);\n\n/**\n * Creates an IOHandler subtype that sends model artifacts to HTTP server.\n *\n * An HTTP request of the `multipart/form-data` mime type will be sent to the\n * `path` URL. The form data includes artifacts that represent the topology\n * and/or weights of the model. In the case of Keras-style `tf.Model`, two\n * blobs (files) exist in form-data:\n * - A JSON file consisting of `modelTopology` and `weightsManifest`.\n * - A binary weights file consisting of the concatenated weight values.\n * These files are in the same format as the one generated by\n * [tfjs_converter](https://js.tensorflow.org/tutorials/import-keras.html).\n *\n * The following code snippet exemplifies the client-side code that uses this\n * function:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save(tf.io.browserHTTPRequest(\n * 'http://model-server:5000/upload', {method: 'PUT'}));\n * console.log(saveResult);\n * ```\n *\n * If the default `POST` method is to be used, without any custom parameters\n * such as headers, you can simply pass an HTTP or HTTPS URL to `model.save`:\n *\n * ```js\n * const saveResult = await model.save('http://model-server:5000/upload');\n * ```\n *\n * The following Python code snippet based on the\n * [flask](https://github.com/pallets/flask) server framework implements a\n * server that can receive the request. Upon receiving the model artifacts\n * via the requst, this particular server reconsistutes instances of\n * [Keras Models](https://keras.io/models/model/) in memory.\n *\n * ```python\n * # pip install -U flask flask-cors tensorflow tensorflowjs\n *\n * from __future__ import absolute_import\n * from __future__ import division\n * from __future__ import print_function\n *\n * import io\n *\n * from flask import Flask, Response, request\n * from flask_cors import CORS, cross_origin\n * import tensorflow as tf\n * import tensorflowjs as tfjs\n * import werkzeug.formparser\n *\n *\n * class ModelReceiver(object):\n *\n * def __init__(self):\n * self._model = None\n * self._model_json_bytes = None\n * self._model_json_writer = None\n * self._weight_bytes = None\n * self._weight_writer = None\n *\n * @property\n * def model(self):\n * self._model_json_writer.flush()\n * self._weight_writer.flush()\n * self._model_json_writer.seek(0)\n * self._weight_writer.seek(0)\n *\n * json_content = self._model_json_bytes.read()\n * weights_content = self._weight_bytes.read()\n * return tfjs.converters.deserialize_keras_model(\n * json_content,\n * weight_data=[weights_content],\n * use_unique_name_scope=True)\n *\n * def stream_factory(self,\n * total_content_length,\n * content_type,\n * filename,\n * content_length=None):\n * # Note: this example code is *not* thread-safe.\n * if filename == 'model.json':\n * self._model_json_bytes = io.BytesIO()\n * self._model_json_writer = io.BufferedWriter(self._model_json_bytes)\n * return self._model_json_writer\n * elif filename == 'model.weights.bin':\n * self._weight_bytes = io.BytesIO()\n * self._weight_writer = io.BufferedWriter(self._weight_bytes)\n * return self._weight_writer\n *\n *\n * def main():\n * app = Flask('model-server')\n * CORS(app)\n * app.config['CORS_HEADER'] = 'Content-Type'\n *\n * model_receiver = ModelReceiver()\n *\n * @app.route('/upload', methods=['POST'])\n * @cross_origin()\n * def upload():\n * print('Handling request...')\n * werkzeug.formparser.parse_form_data(\n * request.environ, stream_factory=model_receiver.stream_factory)\n * print('Received model:')\n * with tf.Graph().as_default(), tf.Session():\n * model = model_receiver.model\n * model.summary()\n * # You can perform `model.predict()`, `model.fit()`,\n * # `model.evaluate()` etc. here.\n * return Response(status=200)\n *\n * app.run('localhost', 5000)\n *\n *\n * if __name__ == '__main__':\n * main()\n * ```\n *\n * @param path URL path. Can be an absolute HTTP path (e.g.,\n * 'http://localhost:8000/model-upload)') or a relative path (e.g.,\n * './model-upload').\n * @param requestInit Request configurations to be used when sending\n * HTTP request to server using `fetch`. It can contain fields such as\n * `method`, `credentials`, `headers`, `mode`, etc. See\n * https://developer.mozilla.org/en-US/docs/Web/API/Request/Request\n * for more information. `requestInit` must not have a body, because the body\n * will be set by TensorFlow.js. File blobs representing\n * the model topology (filename: 'model.json') and the weights of the\n * model (filename: 'model.weights.bin') will be appended to the body.\n * If `requestInit` has a `body`, an Error will be thrown.\n * @returns An instance of `IOHandler`.\n */\nexport function browserHTTPRequest(\n path: string, requestInit?: RequestInit): IOHandler {\n return new BrowserHTTPRequest(path, requestInit);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers that pass through the in-memory ModelArtifacts format.\n */\n\nimport {IOHandler, ModelArtifacts, SaveResult, WeightsManifestEntry} from './types';\n\nclass PassthroughLoader implements IOHandler {\n constructor(\n private readonly modelTopology?: {}|ArrayBuffer,\n private readonly weightSpecs?: WeightsManifestEntry[],\n private readonly weightData?: ArrayBuffer) {}\n\n async load(): Promise {\n let result = {};\n if (this.modelTopology != null) {\n result = {modelTopology: this.modelTopology, ...result};\n }\n if (this.weightSpecs != null && this.weightSpecs.length > 0) {\n result = {weightSpecs: this.weightSpecs, ...result};\n }\n if (this.weightData != null && this.weightData.byteLength > 0) {\n result = {weightData: this.weightData, ...result};\n }\n return result;\n }\n}\n\nclass PassthroughSaver implements IOHandler {\n constructor(\n private readonly saveHandler: (artifacts: ModelArtifacts) => SaveResult) {\n }\n\n async save(modelArtifacts: ModelArtifacts) {\n return this.saveHandler(modelArtifacts);\n }\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from memory.\n *\n * When used in conjunction with `tf.loadModel`, an instance of `tf.Model`\n * (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * const model = await tf.loadModel(tf.io.fromMemory(\n * modelTopology, weightSpecs, weightData));\n * ```\n *\n * @param modelTopology a object containing model topology (i.e., parsed from\n * the JSON format).\n * @param weightSpecs An array of `WeightsManifestEntry` objects describing the\n * names, shapes, types, and quantization of the weight data.\n * @param weightData A single `ArrayBuffer` containing the weight data,\n * concatenated in the order described by the weightSpecs.\n *\n * @returns A passthrough `IOHandler` that simply loads the provided data.\n */\nexport function fromMemory(\n modelTopology: {}, weightSpecs?: WeightsManifestEntry[],\n weightData?: ArrayBuffer): IOHandler {\n return new PassthroughLoader(modelTopology, weightSpecs, weightData);\n}\n\n/**\n * Creates an IOHandler that passes saved model artifacts to a callback.\n *\n * ```js\n * function handleSave(artifacts) {\n * // ... do something with the artifacts ...\n * return {modelArtifactsInfo: {...}, ...};\n * }\n *\n * const saveResult = model.save(tf.io.withSaveHandler(handleSave));\n * ```\n *\n * @param saveHandler A function that accepts a `ModelArtifacts` and returns a\n * `SaveResult`.\n */\nexport function withSaveHandler(\n saveHandler: (artifacts: ModelArtifacts) => SaveResult): IOHandler {\n return new PassthroughSaver(saveHandler);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Importing local_storage and indexed_db is necessary for the routers to be\n// registered.\nimport './indexed_db';\nimport './local_storage';\n\nimport {browserFiles} from './browser_files';\nimport {browserHTTPRequest} from './browser_http';\nimport {concatenateArrayBuffers, decodeWeights, encodeWeights, getModelArtifactsInfoForJSON} from './io_utils';\nimport {fromMemory, withSaveHandler} from './passthrough';\nimport {IORouterRegistry} from './router_registry';\nimport {IOHandler, LoadHandler, ModelArtifacts, ModelStoreManager, SaveConfig, SaveHandler, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeights} from './weights_loader';\n\nconst registerSaveRouter = IORouterRegistry.registerSaveRouter;\nconst registerLoadRouter = IORouterRegistry.registerLoadRouter;\nconst getSaveHandlers = IORouterRegistry.getSaveHandlers;\nconst getLoadHandlers = IORouterRegistry.getLoadHandlers;\n\nexport {copyModel, listModels, moveModel, removeModel} from './model_management';\n\nexport {\n browserFiles,\n browserHTTPRequest,\n concatenateArrayBuffers,\n decodeWeights,\n encodeWeights,\n fromMemory,\n getLoadHandlers,\n getModelArtifactsInfoForJSON,\n getSaveHandlers,\n IOHandler,\n LoadHandler,\n loadWeights,\n ModelArtifacts,\n ModelStoreManager,\n registerLoadRouter,\n registerSaveRouter,\n SaveConfig,\n SaveHandler,\n SaveResult,\n WeightsManifestConfig,\n WeightsManifestEntry,\n withSaveHandler\n};\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Types to support JSON-esque data structures internally.\n *\n * Internally ConfigDict's use camelCase keys and values where the\n * values are class names to be instantiated. On the python side, these\n * will be snake_case. Internally we allow Enums into the values for better\n * type safety, but these need to be converted to raw primitives (usually\n * strings) for round-tripping with python.\n *\n * toConfig returns the TS-friendly representation. model.toJSON() returns\n * the pythonic version as that's the portable format. If you need to\n * python-ify a non-model level toConfig output, you'll need to use a\n * convertTsToPythonic from serialization_utils in -Layers.\n *\n */\nexport type ConfigDictValue =\n boolean|number|string|null|ConfigDictArray|ConfigDict;\nexport interface ConfigDict {\n [key: string]: ConfigDictValue;\n}\nexport interface ConfigDictArray extends Array {}\n\n/**\n * Type to represent the class-type of Serializable objects.\n *\n * Ie the class prototype with access to the constructor and any\n * static members/methods. Instance methods are not listed here.\n *\n * Source for this idea: https://stackoverflow.com/a/43607255\n */\nexport type SerializableConstructor = {\n // tslint:disable-next-line:no-any\n new (...args: any[]): T; className: string; fromConfig: FromConfigMethod;\n};\nexport type FromConfigMethod =\n (cls: SerializableConstructor, config: ConfigDict) => T;\n\n/**\n * Serializable defines the serialization contract.\n *\n * TFJS requires serializable classes to return their className when asked\n * to avoid issues with minification.\n */\nexport abstract class Serializable {\n /**\n * Return the class name for this class to use in serialization contexts.\n *\n * Generally speaking this will be the same thing that constructor.name\n * would have returned. However, the class name needs to be robust\n * against minification for serialization/deserialazation to work properly.\n *\n * There's also places such as initializers.VarianceScaling, where\n * implementation details between different languages led to different\n * class hierarchies and a non-leaf node is used for serialization purposes.\n */\n getClassName(): string {\n return (this.constructor as SerializableConstructor)\n .className;\n }\n\n /**\n * Return all the non-weight state needed to serialize this object.\n */\n abstract getConfig(): ConfigDict;\n\n /**\n * Creates an instance of T from a ConfigDict.\n *\n * This works for most descendants of serializable. A few need to\n * provide special handling.\n * @param cls A Constructor for the class to instantiate.\n * @param config The Configuration for the object.\n */\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config);\n }\n}\n\n/**\n * Maps string keys to class constructors.\n *\n * Used during (de)serialization from the cross-language JSON format, which\n * requires the class name in the serialization format matches the class\n * names as used in Python, should it exist.\n */\nexport class SerializationMap {\n private static instance: SerializationMap;\n classNameMap: {\n [className: string]:\n [\n SerializableConstructor, FromConfigMethod\n ]\n };\n\n private constructor() {\n this.classNameMap = {};\n }\n\n /**\n * Returns the singleton instance of the map.\n */\n static getMap(): SerializationMap {\n if (SerializationMap.instance == null) {\n SerializationMap.instance = new SerializationMap();\n }\n return SerializationMap.instance;\n }\n\n /**\n * Registers the class as serializable.\n */\n static register(cls: SerializableConstructor) {\n SerializationMap.getMap().classNameMap[cls.className] =\n [cls, cls.fromConfig];\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from './environment';\nimport {Features} from './environment_util';\nimport {Tensor} from './tensor';\nimport {TypedArray} from './types';\nimport * as util from './util';\n\n// TODO(smilkov): Move these constants to jasmine_util.\nexport const WEBGL_ENVS: Features = {\n 'HAS_WEBGL': true\n};\nexport const NODE_ENVS: Features = {\n 'IS_NODE': true\n};\nexport const CHROME_ENVS: Features = {\n 'IS_CHROME': true\n};\nexport const BROWSER_ENVS: Features = {\n 'IS_BROWSER': true\n};\nexport const CPU_ENVS: Features = {\n 'HAS_WEBGL': false\n};\nexport const ALL_ENVS: Features = {};\n\nexport function expectArraysClose(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[], epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!(actual instanceof Tensor) && !(expected instanceof Tensor)) {\n const aType = actual.constructor.name;\n const bType = expected.constructor.name;\n\n if (aType !== bType) {\n throw new Error(\n `Arrays are of different type actual: ${aType} ` +\n `vs expected: ${bType}`);\n }\n } else if (actual instanceof Tensor && expected instanceof Tensor) {\n if (actual.dtype !== expected.dtype) {\n throw new Error(\n `Arrays are of different type actual: ${actual.dtype} ` +\n `vs expected: ${expected.dtype}.`);\n }\n if (!util.arraysEqual(actual.shape, expected.shape)) {\n throw new Error(\n `Arrays are of different shape actual: ${actual.shape} ` +\n `vs expected: ${expected.shape}.`);\n }\n }\n\n let actualValues: TypedArray|number[];\n let expectedValues: TypedArray|number[]|boolean[];\n if (actual instanceof Tensor) {\n actualValues = actual.dataSync();\n } else {\n actualValues = actual;\n }\n if (expected instanceof Tensor) {\n expectedValues = expected.dataSync();\n } else {\n expectedValues = expected;\n }\n\n if (actualValues.length !== expectedValues.length) {\n throw new Error(\n `Arrays have different lengths actual: ${actualValues.length} vs ` +\n `expected: ${expectedValues.length}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n for (let i = 0; i < expectedValues.length; ++i) {\n const a = actualValues[i];\n const e = expectedValues[i];\n\n if (!areClose(a, Number(e), epsilon)) {\n throw new Error(\n `Arrays differ: actual[${i}] = ${a}, expected[${i}] = ${e}.\\n` +\n `Actual: ${actualValues}.\\n` +\n `Expected: ${expectedValues}.`);\n }\n }\n}\n\nexport interface DoneFn {\n (): void;\n fail: (message?: Error|string) => void;\n}\n\nexport function expectPromiseToFail(fn: () => Promise<{}>, done: DoneFn): void {\n fn().then(() => done.fail(), () => done());\n}\n\nexport function expectArraysEqual(\n actual: Tensor|TypedArray|number[],\n expected: Tensor|TypedArray|number[]|boolean[]) {\n return expectArraysClose(actual, expected, 0);\n}\n\nexport function expectNumbersClose(a: number, e: number, epsilon?: number) {\n if (epsilon == null) {\n epsilon = ENV.get('TEST_EPSILON');\n }\n if (!areClose(a, e, epsilon)) {\n throw new Error(`Numbers differ: actual === ${a}, expected === ${e}`);\n }\n}\n\nfunction areClose(a: number, e: number, epsilon: number): boolean {\n if (isNaN(a) && isNaN(e)) {\n return true;\n }\n if (isNaN(a) || isNaN(e) || Math.abs(a - e) > epsilon) {\n return false;\n }\n return true;\n}\n\nexport function expectValuesInRange(\n actual: Tensor|TypedArray|number[], low: number, high: number) {\n let actualVals: TypedArray|number[];\n if (actual instanceof Tensor) {\n actualVals = actual.dataSync();\n } else {\n actualVals = actual;\n }\n for (let i = 0; i < actualVals.length; i++) {\n if (actualVals[i] < low || actualVals[i] > high) {\n throw new Error(\n `Value out of range:${actualVals[i]} low: ${low}, high: ${high}`);\n }\n }\n}\n\nexport function expectArrayBuffersEqual(\n actual: ArrayBuffer, expected: ArrayBuffer) {\n // Safari & Jasmine dont like comparing ArrayBuffers directly. Wrapping in\n // a Float32Array solves this issue.\n expect(new Float32Array(actual)).toEqual(new Float32Array(expected));\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {variableGrads} from '../globals';\nimport {Serializable} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\n\n/** @doc {heading: 'Training', subheading: 'Classes', namespace: 'train'} */\nexport abstract class Optimizer extends Serializable {\n /**\n * Executes `f()` and minimizes the scalar output of `f()` by computing\n * gradients of y with respect to the list of trainable variables provided by\n * `varList`. If no list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to minimize.\n * @param returnCost Whether to return the scalar cost value produced by\n * executing `f()`.\n * @param varList An optional list of variables to update. If specified, only\n * the trainable variables in varList will be updated by minimize. Defaults to\n * all trainable variables.\n */\n /** @doc {heading: 'Training', subheading: 'Optimizers'} */\n minimize(f: () => Scalar, returnCost = false, varList?: Variable[]): Scalar\n |null {\n const {value, grads} = this.computeGradients(f, varList);\n\n this.applyGradients(grads);\n\n // Dispose gradients.\n const varNames = Object.keys(grads);\n varNames.forEach(varName => grads[varName].dispose());\n\n if (returnCost) {\n return value as Scalar;\n } else {\n value.dispose();\n return null;\n }\n }\n\n /**\n * Executes f() and computes the gradient of the scalar output of f() with\n * respect to the list of trainable variables provided by `varList`. If no\n * list is provided, it defaults to all trainable variables.\n * @param f The function to execute and whose output to use for computing\n * gradients with respect to variables.\n * @param varList An optional list of variables to compute gradients with\n * respect to. If specified, only the trainable variables in varList will have\n * gradients computed with respect to. Defaults to all trainable variables.\n */\n computeGradients(f: () => Scalar, varList?: Variable[]):\n {value: Scalar, grads: NamedTensorMap} {\n return variableGrads(f, varList);\n }\n\n /**\n * Updates variables by using the computed gradients.\n * @param variableGradients A mapping of variable name to its gradient value.\n */\n abstract applyGradients(variableGradients: NamedTensorMap): void;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENV} from '../environment';\n\nconst DEFAULT_FLOAT32_EPSILON = 1e-8;\nconst DEFAULT_FLOAT16_EPSILON = 1e-4;\n\nexport function getOptimizerDefaultEpsilonValue() {\n if (ENV.get('WEBGL_RENDER_FLOAT32_ENABLED')) {\n return DEFAULT_FLOAT32_EPSILON;\n }\n\n return DEFAULT_FLOAT16_EPSILON;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdadeltaOptimizer extends Optimizer {\n static className = 'AdadeltaOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private rhoScalar: Scalar;\n private oneMinusRho: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n private accumulatedUpdates: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected rho: number,\n protected epsilon: number = null) {\n super();\n\n this.c = keep(scalar(-learningRate));\n this.rhoScalar = keep(scalar(rho));\n this.oneMinusRho = keep(scalar(1 - rho));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedUpdates[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedUpdates[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n const accumulatedUpdate = this.accumulatedUpdates[variableName];\n\n tidy(() => {\n const newAccumulatedGrad =\n this.rhoScalar.mul(accumulatedGrad)\n .add(this.oneMinusRho.mul(gradient.square()));\n\n const updates = accumulatedUpdate.add(this.epsilonScalar)\n .sqrt()\n .div(accumulatedGrad.add(this.epsilonScalar).sqrt())\n .mul(gradient);\n\n const newAccumulatedUpdate =\n this.rhoScalar.mul(accumulatedUpdate)\n .add(this.oneMinusRho.mul(updates.square()));\n\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n this.accumulatedUpdates[variableName].assign(newAccumulatedUpdate);\n\n const newValue = this.c.mul(updates).add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.rhoScalar.dispose();\n this.oneMinusRho.dispose();\n if (this.accumulatedUpdates != null) {\n Object.keys(this.accumulatedUpdates)\n .forEach(name => this.accumulatedUpdates[name].dispose());\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n rho: this.rho,\n epsilon: this.epsilon\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.rho, config.epsilon);\n }\n}\nSerializationMap.register(AdadeltaOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {fill, scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class AdagradOptimizer extends Optimizer {\n static className = 'AdagradOptimizer';\n private c: Scalar;\n private epsilon: Scalar;\n\n private accumulatedGrads: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, private initialAccumulatorValue = 0.1) {\n super();\n this.c = keep(scalar(-learningRate));\n\n const epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n this.epsilon = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedGrads[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedGrads[variableName] =\n fill(value.shape, this.initialAccumulatorValue)\n .variable(trainable);\n });\n }\n\n const gradient = variableGradients[variableName];\n const accumulatedGrad = this.accumulatedGrads[variableName];\n\n tidy(() => {\n const newAccumulatedGrad = accumulatedGrad.add(gradient.square());\n this.accumulatedGrads[variableName].assign(newAccumulatedGrad);\n\n const newValue =\n this.c\n .mul(gradient.div(newAccumulatedGrad.add(this.epsilon).sqrt()))\n .add(value);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n this.epsilon.dispose();\n this.c.dispose();\n if (this.accumulatedGrads != null) {\n Object.keys(this.accumulatedGrads)\n .forEach(name => this.accumulatedGrads[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n initialAccumulatorValue: this.initialAccumulatorValue,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.initialAccumulatorValue);\n }\n}\nSerializationMap.register(AdagradOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamOptimizer extends Optimizer {\n static className = 'AdamOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private accBeta1: Variable;\n private accBeta2: Variable;\n private oneMinusBeta1: Scalar;\n private oneMinusBeta2: Scalar;\n private one: Scalar;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedSecondMoment: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null) {\n super();\n this.c = keep(scalar(-learningRate));\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n tidy(() => {\n // accB* will be updated by batch.\n this.accBeta1 = scalar(beta1).variable();\n this.accBeta2 = scalar(beta2).variable();\n });\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.oneMinusBeta2 = keep(scalar(1 - beta2));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const oneMinusAccBeta2 = this.one.sub(this.accBeta2);\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedSecondMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedSecondMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const secondMoment = this.accumulatedSecondMoment[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n const newSecondMoment =\n this.beta2Scalar.mul(secondMoment)\n .add(this.oneMinusBeta2.mul(gradient.square()));\n\n const biasCorrectedFirstMoment = newFirstMoment.div(oneMinusAccBeta1);\n const biasCorrectedSecondMoment = newSecondMoment.div(oneMinusAccBeta2);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedSecondMoment[variableName].assign(newSecondMoment);\n\n const newValue =\n this.c\n .mul(biasCorrectedFirstMoment.div(\n this.epsScalar.add(biasCorrectedSecondMoment.sqrt())))\n .add(value);\n value.assign(newValue);\n }\n\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n this.accBeta2.assign(this.accBeta2.mul(this.beta2Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.accBeta1.dispose();\n this.accBeta2.dispose();\n this.oneMinusBeta1.dispose();\n this.oneMinusBeta2.dispose();\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedSecondMoment != null) {\n Object.keys(this.accumulatedSecondMoment)\n .forEach(name => this.accumulatedSecondMoment[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon);\n }\n}\nSerializationMap.register(AdamOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Variable} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\nexport class AdamaxOptimizer extends Optimizer {\n static className = 'AdamaxOptimizer';\n private c: Scalar;\n private epsScalar: Scalar;\n private accBeta1: Variable;\n private beta1Scalar: Scalar;\n private beta2Scalar: Scalar;\n private decayScalar: Scalar;\n private oneMinusBeta1: Scalar;\n private one: Scalar;\n private iteration: Variable;\n\n private accumulatedFirstMoment: NamedVariableMap = {};\n private accumulatedWeightedInfNorm: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected beta1: number,\n protected beta2: number, protected epsilon: number = null,\n protected decay = 0.0) {\n super();\n this.c = keep(scalar(-learningRate));\n\n // b1, b2 keep initial value of beta* hyperparameters.\n this.beta1Scalar = keep(scalar(beta1));\n this.beta2Scalar = keep(scalar(beta2));\n\n this.decayScalar = keep(scalar(decay));\n\n tidy(() => {\n this.iteration = scalar(0).variable();\n this.accBeta1 = scalar(beta1).variable();\n });\n\n this.oneMinusBeta1 = keep(scalar(1 - beta1));\n this.one = keep(scalar(1));\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n tidy(() => {\n const oneMinusAccBeta1 = this.one.sub(this.accBeta1);\n const lr = this.c.div(this.one.add(this.decayScalar.mul(this.iteration)));\n\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedFirstMoment[variableName] == null) {\n const trainable = false;\n this.accumulatedFirstMoment[variableName] =\n zerosLike(value).variable(trainable);\n }\n if (this.accumulatedWeightedInfNorm[variableName] == null) {\n const trainable = false;\n this.accumulatedWeightedInfNorm[variableName] =\n zerosLike(value).variable(trainable);\n }\n\n const gradient = variableGradients[variableName];\n const firstMoment = this.accumulatedFirstMoment[variableName];\n const weightedInfNorm = this.accumulatedWeightedInfNorm[variableName];\n\n const newFirstMoment = this.beta1Scalar.mul(firstMoment)\n .add(this.oneMinusBeta1.mul(gradient));\n\n const ut0 = this.beta2Scalar.mul(weightedInfNorm);\n const ut1 = gradient.abs();\n\n const newWeightedInfNorm = ut0.maximum(ut1);\n\n this.accumulatedFirstMoment[variableName].assign(newFirstMoment);\n this.accumulatedWeightedInfNorm[variableName].assign(\n newWeightedInfNorm);\n\n const newValue =\n lr.div(oneMinusAccBeta1)\n .mul(newFirstMoment.div(this.epsScalar.add(newWeightedInfNorm)))\n .add(value);\n\n value.assign(newValue);\n }\n\n this.iteration.assign(this.iteration.add(this.one));\n this.accBeta1.assign(this.accBeta1.mul(this.beta1Scalar));\n });\n }\n\n dispose() {\n this.c.dispose();\n this.epsScalar.dispose();\n this.accBeta1.dispose();\n this.beta1Scalar.dispose();\n this.beta2Scalar.dispose();\n this.oneMinusBeta1.dispose();\n\n this.decayScalar.dispose();\n this.iteration.dispose();\n\n this.one.dispose();\n\n if (this.accumulatedFirstMoment != null) {\n Object.keys(this.accumulatedFirstMoment)\n .forEach(name => this.accumulatedFirstMoment[name].dispose());\n }\n\n if (this.accumulatedWeightedInfNorm != null) {\n Object.keys(this.accumulatedWeightedInfNorm)\n .forEach(name => this.accumulatedWeightedInfNorm[name].dispose());\n }\n }\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n beta1: this.beta1,\n beta2: this.beta2,\n epsilon: this.epsilon,\n decay: this.decay\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.beta1, config.beta2, config.epsilon,\n config.decay);\n }\n}\nSerializationMap.register(AdamaxOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\n\n/** @doclink Optimizer */\nexport class SGDOptimizer extends Optimizer {\n static className = 'SGDOptimizer';\n protected c: Scalar;\n\n constructor(protected learningRate: number) {\n super();\n this.setLearningRate(learningRate);\n }\n\n applyGradients(variableGradients: NamedTensorMap) {\n const varNames = Object.keys(variableGradients);\n varNames.forEach(varName => {\n const gradient = variableGradients[varName];\n const value = ENV.engine.registeredVariables[varName];\n\n tidy(() => {\n const newValue = this.c.mul(gradient).add(value);\n value.assign(newValue);\n });\n });\n }\n\n /**\n * Sets the learning rate of the optimizer.\n */\n setLearningRate(learningRate: number) {\n this.learningRate = learningRate;\n if (this.c != null) {\n this.c.dispose();\n }\n this.c = keep(scalar(-learningRate));\n }\n\n dispose() {\n this.c.dispose();\n }\n\n getConfig(): ConfigDict {\n return {learningRate: this.learningRate};\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate);\n }\n}\nSerializationMap.register(SGDOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar, Tensor} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {SGDOptimizer} from './sgd_optimizer';\n\n/** @doclink Optimizer */\nexport class MomentumOptimizer extends SGDOptimizer {\n static className = 'MomentumOptimizer';\n private m: Scalar;\n private accumulations: NamedVariableMap;\n\n constructor(\n protected learningRate: number, private momentum: number,\n private useNesterov = false) {\n super(learningRate);\n this.m = scalar(this.momentum);\n this.accumulations = {};\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulations[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulations[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulation = this.accumulations[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n let newValue: Tensor;\n const newAccumulation = this.m.mul(accumulation).add(gradient);\n if (this.useNesterov) {\n newValue =\n this.c.mul(gradient.add(newAccumulation.mul(this.m))).add(value);\n } else {\n newValue = this.c.mul(newAccumulation).add(value);\n }\n this.accumulations[variableName].assign(newAccumulation);\n value.assign(newValue);\n });\n }\n }\n\n dispose() {\n super.dispose();\n this.m.dispose();\n if (this.accumulations != null) {\n for (const variableName in this.accumulations) {\n this.accumulations[variableName].dispose();\n }\n }\n }\n\n /**\n * Sets the momentum of the optimizer.\n *\n * @param momentum\n */\n setMomentum(momentum: number) {\n this.momentum = momentum;\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n momentum: this.momentum,\n useNesterov: this.useNesterov\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(config.learningRate, config.momentum, config.useNesterov);\n }\n}\nSerializationMap.register(MomentumOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENV} from '../environment';\nimport {keep, tidy} from '../globals';\nimport {scalar, zerosLike} from '../ops/ops';\nimport {ConfigDict, Serializable, SerializableConstructor, SerializationMap} from '../serialization';\nimport {Scalar} from '../tensor';\nimport {NamedVariableMap} from '../tensor_types';\nimport {Optimizer} from './optimizer';\nimport * as optimizer_utils from './optimizer_utils';\n\n/** @doclink Optimizer */\nexport class RMSPropOptimizer extends Optimizer {\n static className = 'RMSPropOptimizer';\n private c: Scalar;\n private epsilonScalar: Scalar;\n private decayScalar: Scalar;\n private momentumScalar: Scalar;\n private oneMinusDecay: Scalar;\n private centered: boolean;\n\n private accumulatedMeanSquares: NamedVariableMap = {};\n private accumulatedMeanGrads: NamedVariableMap = {};\n private accumulatedMoments: NamedVariableMap = {};\n\n constructor(\n protected learningRate: number, protected decay = 0.9,\n protected momentum = 0.0, protected epsilon: number = null,\n centered = false) {\n super();\n\n this.c = keep(scalar(learningRate));\n this.decayScalar = keep(scalar(decay));\n this.momentumScalar = keep(scalar(momentum));\n this.oneMinusDecay = keep(scalar(1 - decay));\n this.centered = centered;\n\n if (epsilon === null) {\n epsilon = optimizer_utils.getOptimizerDefaultEpsilonValue();\n }\n\n this.epsilonScalar = keep(scalar(epsilon));\n }\n\n applyGradients(variableGradients: NamedVariableMap) {\n for (const variableName in variableGradients) {\n const value = ENV.engine.registeredVariables[variableName];\n if (this.accumulatedMeanSquares[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanSquares[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMeanGrads[variableName] == null && this.centered) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMeanGrads[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n if (this.accumulatedMoments[variableName] == null) {\n const trainable = false;\n tidy(() => {\n this.accumulatedMoments[variableName] =\n zerosLike(value).variable(trainable);\n });\n }\n\n const accumulatedMeanSquare = this.accumulatedMeanSquares[variableName];\n const accumulatedMeanGrad = this.accumulatedMeanGrads[variableName];\n const accumulatedMoments = this.accumulatedMoments[variableName];\n const gradient = variableGradients[variableName];\n\n tidy(() => {\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n if (this.centered) {\n // Centered gradient\n const newAccumulatedMeanGrad =\n this.decayScalar.mul(accumulatedMeanGrad)\n .add(this.oneMinusDecay.mul(gradient));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare\n .sub(newAccumulatedMeanGrad.square().add(\n this.epsilonScalar))\n .sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMeanGrads[variableName].assign(\n newAccumulatedMeanGrad);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n } else {\n // Plain gradient\n const newAccumulatedMeanSquare =\n this.decayScalar.mul(accumulatedMeanSquare)\n .add(this.oneMinusDecay.mul(gradient.square()));\n\n const newAccumulatedMoments =\n this.momentumScalar.mul(accumulatedMoments)\n .add(this.c.mul(gradient).div(\n newAccumulatedMeanSquare.add(this.epsilonScalar).sqrt()));\n\n this.accumulatedMeanSquares[variableName].assign(\n newAccumulatedMeanSquare);\n this.accumulatedMoments[variableName].assign(newAccumulatedMoments);\n\n const newValue = value.sub(newAccumulatedMoments);\n value.assign(newValue);\n }\n });\n }\n }\n\n dispose() {\n this.c.dispose();\n this.epsilonScalar.dispose();\n this.decayScalar.dispose();\n this.momentumScalar.dispose();\n this.oneMinusDecay.dispose();\n if (this.accumulatedMeanSquares != null) {\n Object.keys(this.accumulatedMeanSquares)\n .forEach(name => this.accumulatedMeanSquares[name].dispose());\n }\n if (this.accumulatedMeanGrads != null && this.centered) {\n Object.keys(this.accumulatedMeanGrads)\n .forEach(name => this.accumulatedMeanGrads[name].dispose());\n }\n if (this.accumulatedMoments != null) {\n Object.keys(this.accumulatedMoments)\n .forEach(name => this.accumulatedMoments[name].dispose());\n }\n }\n\n getConfig(): ConfigDict {\n return {\n learningRate: this.learningRate,\n decay: this.decay,\n momentum: this.momentum,\n epsilon: this.epsilon,\n centered: this.centered\n };\n }\n static fromConfig(\n cls: SerializableConstructor, config: ConfigDict): T {\n return new cls(\n config.learningRate, config.decay, config.momentum, config.epsilon,\n config.centered);\n }\n}\nSerializationMap.register(RMSPropOptimizer);\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {AdadeltaOptimizer} from './adadelta_optimizer';\nimport {AdagradOptimizer} from './adagrad_optimizer';\nimport {AdamOptimizer} from './adam_optimizer';\nimport {AdamaxOptimizer} from './adamax_optimizer';\nimport {MomentumOptimizer} from './momentum_optimizer';\nimport {RMSPropOptimizer} from './rmsprop_optimizer';\nimport {SGDOptimizer} from './sgd_optimizer';\n\nexport class OptimizerConstructors {\n /**\n * Constructs a `SGDOptimizer` that uses stochastic gradient descent.\n *\n * ```js\n * // Fit a quadratic function by learning the coefficients a, b, c.\n * const xs = tf.tensor1d([0, 1, 2, 3]);\n * const ys = tf.tensor1d([1.1, 5.9, 16.8, 33.9]);\n *\n * const a = tf.scalar(Math.random()).variable();\n * const b = tf.scalar(Math.random()).variable();\n * const c = tf.scalar(Math.random()).variable();\n *\n * // y = a * x^2 + b * x + c.\n * const f = x => a.mul(x.square()).add(b.mul(x)).add(c);\n * const loss = (pred, label) => pred.sub(label).square().mean();\n *\n * const learningRate = 0.01;\n * const optimizer = tf.train.sgd(learningRate);\n *\n * // Train the model.\n * for (let i = 0; i < 10; i++) {\n * optimizer.minimize(() => loss(f(xs), ys));\n * }\n *\n * // Make predictions.\n * console.log(\n * `a: ${a.dataSync()}, b: ${b.dataSync()}, c: ${c.dataSync()}`);\n * const preds = f(xs).dataSync();\n * preds.forEach((pred, i) => {\n * console.log(`x: ${i}, pred: ${pred}`);\n * });\n * ```\n *\n * @param learningRate The learning rate to use for the SGD algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static sgd(learningRate: number): SGDOptimizer {\n return new SGDOptimizer(learningRate);\n }\n\n /**\n * Constructs a `MomentumOptimizer` that uses momentum gradient\n * descent.\n *\n * See\n * [http://proceedings.mlr.press/v28/sutskever13.pdf](\n * http://proceedings.mlr.press/v28/sutskever13.pdf)\n *\n * @param learningRate The learning rate to use for the Momentum gradient\n * descent algorithm.\n * @param momentum The momentum to use for the momentum gradient descent\n * algorithm.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static momentum(learningRate: number, momentum: number, useNesterov = false):\n MomentumOptimizer {\n return new MomentumOptimizer(learningRate, momentum, useNesterov);\n }\n\n /**\n * Constructs a `RMSPropOptimizer` that uses RMSProp gradient\n * descent. This implementation uses plain momentum and is not centered\n * version of RMSProp.\n *\n * See\n * [http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf](\n * http://www.cs.toronto.edu/~tijmen/csc321/slides/lecture_slides_lec6.pdf)\n *\n * @param learningRate The learning rate to use for the RMSProp gradient\n * descent algorithm.\n * @param decay The discounting factor for the history/coming gradient.\n * @param momentum The momentum to use for the RMSProp gradient descent\n * algorithm.\n * @param epsilon Small value to avoid zero denominator.\n * @param centered If true, gradients are normalized by the estimated\n * variance of the gradient.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static rmsprop(\n learningRate: number, decay = .9, momentum = 0.0, epsilon: number = null,\n centered = false): RMSPropOptimizer {\n return new RMSPropOptimizer(\n learningRate, decay, momentum, epsilon, centered);\n }\n\n /**\n * Constructs a `AdamOptimizer` that uses the Adam algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adam gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adam(\n learningRate = 0.001, beta1 = 0.9, beta2 = 0.999,\n epsilon: number = null): AdamOptimizer {\n return new AdamOptimizer(learningRate, beta1, beta2, epsilon);\n }\n\n /**\n * Constructs a `AdadeltaOptimizer` that uses the Adadelta algorithm.\n * See [https://arxiv.org/abs/1212.5701](https://arxiv.org/abs/1212.5701)\n *\n * @param learningRate The learning rate to use for the Adadelta gradient\n * descent algorithm.\n * @param rho The learning rate decay over each update.\n * @param epsilon A constant epsilon used to better condition the grad\n * update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adadelta(learningRate = .001, rho = .95, epsilon: number = null):\n AdadeltaOptimizer {\n return new AdadeltaOptimizer(learningRate, rho, epsilon);\n }\n\n /**\n * Constructs a `AdamaxOptimizer` that uses the Adamax algorithm.\n * See [https://arxiv.org/abs/1412.6980](https://arxiv.org/abs/1412.6980)\n *\n * @param learningRate The learning rate to use for the Adamax gradient\n * descent algorithm.\n * @param beta1 The exponential decay rate for the 1st moment estimates.\n * @param beta2 The exponential decay rate for the 2nd moment estimates.\n * @param epsilon A small constant for numerical stability.\n * @param decay The learning rate decay over each update.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adamax(\n learningRate = 0.002, beta1 = 0.9, beta2 = 0.999, epsilon: number = null,\n decay = 0.0): AdamaxOptimizer {\n return new AdamaxOptimizer(learningRate, beta1, beta2, epsilon, decay);\n }\n\n /**\n * Constructs a `AdagradOptimizer` that uses the Adagrad algorithm.\n * See\n * [http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf](\n * http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf)\n * or\n * [http://ruder.io/optimizing-gradient-descent/index.html#adagrad](\n * http://ruder.io/optimizing-gradient-descent/index.html#adagrad)\n *\n * @param learningRate The learning rate to use for the Adagrad gradient\n * descent algorithm.\n * @param initialAccumulatorValue Starting value for the accumulators, must be\n * positive.\n */\n /**\n * @doc {heading: 'Training', subheading: 'Optimizers', namespace: 'train'}\n */\n static adagrad(learningRate: number, initialAccumulatorValue = 0.1):\n AdagradOptimizer {\n return new AdagradOptimizer(learningRate, initialAccumulatorValue);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// So typings can propagate.\nimport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nimport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nimport {AdamOptimizer} from './optimizers/adam_optimizer';\nimport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nimport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nimport {OptimizerConstructors} from './optimizers/optimizer_constructors';\nimport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nimport {SGDOptimizer} from './optimizers/sgd_optimizer';\n\n// tslint:disable-next-line:no-unused-expression\n[MomentumOptimizer, SGDOptimizer, AdadeltaOptimizer, AdagradOptimizer,\n RMSPropOptimizer, AdamaxOptimizer, AdamOptimizer];\n\nexport const train = {\n sgd: OptimizerConstructors.sgd,\n momentum: OptimizerConstructors.momentum,\n adadelta: OptimizerConstructors.adadelta,\n adagrad: OptimizerConstructors.adagrad,\n rmsprop: OptimizerConstructors.rmsprop,\n adamax: OptimizerConstructors.adamax,\n adam: OptimizerConstructors.adam\n};\n","/**\n * @license\n * Copyright 2017 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// backend_cpu.ts and backend_webgl.ts are standalone files and should be\n// explicily included here. Below, there is an export from backend_webgl, but\n// that doesn't count since it's exporting a Typescript interface.\nimport './kernels/backend_webgl';\nimport './kernels/backend_cpu';\n\nimport {nextFrame} from './browser_util';\nimport * as environment from './environment';\nimport {Environment} from './environment';\n\n// Serialization.\nimport * as io from './io/io';\nimport * as serialization from './serialization';\nimport {setOpHandler} from './tensor';\nimport * as test_util from './test_util';\nimport * as util from './util';\nimport {version} from './version';\nimport * as webgl from './webgl';\n\nexport {InferenceModel, ModelPredictConfig} from './model_types';\n\n// Optimizers.\nexport {AdadeltaOptimizer} from './optimizers/adadelta_optimizer';\nexport {AdagradOptimizer} from './optimizers/adagrad_optimizer';\nexport {AdamOptimizer} from './optimizers/adam_optimizer';\nexport {AdamaxOptimizer} from './optimizers/adamax_optimizer';\nexport {MomentumOptimizer} from './optimizers/momentum_optimizer';\nexport {Optimizer} from './optimizers/optimizer';\nexport {RMSPropOptimizer} from './optimizers/rmsprop_optimizer';\nexport {SGDOptimizer} from './optimizers/sgd_optimizer';\nexport {Scalar, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, TensorBuffer, variable, Variable} from './tensor';\nexport {NamedTensorMap} from './tensor_types';\nexport {DataType, Rank, ShapeMap} from './types';\n\nexport * from './ops/ops';\nexport {LSTMCellFunc} from './ops/lstm';\nexport {Reduction} from './ops/loss_ops';\n\nexport * from './train';\nexport * from './globals';\n\nexport {Features} from './environment_util';\nexport {TimingInfo} from './engine';\nexport {ENV, Environment} from './environment';\n\nexport const setBackend = Environment.setBackend;\nexport const getBackend = Environment.getBackend;\nexport const disposeVariables = Environment.disposeVariables;\nexport const memory = Environment.memory;\nexport {version as version_core};\n\nexport {nextFrame};\n\n// Second level exports.\nexport {environment, io, serialization, test_util, util, webgl};\n\n// Backend specific.\nexport {KernelBackend, BackendTimingInfo} from './kernels/backend';\n\nimport * as ops from './ops/ops';\nsetOpHandler(ops);\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.8';\nexport {version};\n"],"names":["array","counter","length","temp","index","Math","random","min","x","max","a","b","expr","msg","Error","shapeA","shapeB","errorMessagePrefix","assert","arraysEqual","arr","ret","Array","isArray","i","flatten","push","val","firstElem","isTypedArray","shape","indices","join","subShape","slice","deepAssertShapeConsistency","concat","size","n1","n2","tanh","Infinity","e2x","exp","floor","sqrt","repeat","checkFn","delayFn","maxCounter","Promise","resolve","reject","tryCount","tryFn","nextBackoff","setTimeout","shapeProd","implicitIdx","newShape","axis","keptDims","j","dtype","values","Float32Array","Int32Array","Uint8Array","vals","name","isNaN","oldType","newType","f","constructor","call","apply","start","rank","strides","debugMode","noConversionNeeded","checkConversionForNaN","bool","round","copyTypedArray","makeZerosTypedArray","performance","now","process","time","hrtime","result","diff","Number","n","shuffledIndices","Uint32Array","shuffle","backendTimer","logger","this","Logger","Profiler","timer","forEach","r","dataSync","util.checkComputationForNaN","then","timing","_this","logKernelProfile","kernelMs","timeMs","util.rightPad","paddedName","toString","console","log","FORMAT_LIMIT_NUM_VALS","FORMAT_NUM_FIRST_LAST_VALS","FORMAT_NUM_SIG_DIGITS","verbose","computeStrides","padPerCol","sizeFromShape","numCols","fill","row","offset","valToString","computeMaxSizePerColumn","valsLines","isLast","firstVals","from","subarray","lastVals","map","subshape","substrides","stride","lines","end","subTensorToString","sep","newLineSep","l","pad","rightPad","parseFloat","toFixed","util.sizeFromShape","util.assert","util.getTypedArrayFromDType","TensorBuffer","value","_i","locs","locToIndex","Object","Tensor","make","trackerFn","opHandler","fn","dataId","id","nextId","rankType","registerTensor","write","data","throwIfDisposed","as1D","reshape","rows","columns","depth","depth2","cast","buffer","read","readSync","isDisposed","disposeTensor","isDisposedInternal","asType","print","expandDims","exclusive","reverse","cumsum","squeeze","clone","tensorToString","reps","tile","gather","transposeA","transposeB","matMul","dot","ord","keepDims","norm","begin","stack","unstack","paddings","constantValue","mean","variance","varianceEpsilon","scale","batchNormalization","all","any","logSumExp","sum","argMin","argMax","add","addStrict","sub","subStrict","pow","powStrict","mul","mulStrict","div","floorDiv","divStrict","minimum","minimumStrict","maximum","maximumStrict","mod","modStrict","squaredDifference","squaredDifferenceStrict","perm","transpose","notEqual","notEqualStrict","less","lessStrict","equal","equalStrict","lessEqual","lessEqualStrict","greater","greaterStrict","greaterEqual","greaterEqualStrict","logicalAnd","logicalOr","logicalNot","logicalXor","condition","where","neg","ceil","sign","expm1","log1p","rsqrt","square","reciprocal","abs","clipByValue","relu","elu","selu","alpha","leakyRelu","prelu","sigmoid","logSigmoid","softplus","sin","cos","tan","asin","acos","atan","sinh","cosh","asinh","acosh","atanh","erf","step","dim","softmax","newShape2D","alignCorners","image","resizeBilinear","resizeNearestNeighbor","filter","dataFormat","dilation","dimRoundingMode","conv1d","dilations","conv2d","outputShape","conv2dTranspose","depthwiseConv2d","filterSize","avgPool","maxPool","radius","bias","beta","localResponseNormalization","trainable","Variable","variable","segmentIds","numSegments","unsortedSegmentSum","blockShape","crops","batchToSpaceND","spaceToBatchND","defineProperty","Symbol","hasInstance","instance","initialValue","_super","nextVarId","registerVariable","ex","tslib_1.__extends","newValue","util.arraysEqual","assign","Function","list","container","seen","obj","iterable","k","has","walkTensorContainer","Set","Type","backend","safeMode","WeakMap","activeScope","track","scopeStack","profiler","Engine","nameOrFn","gradMode","String","scopedRun","startScope","endScope","error","res","forwardFunc","inputs","backwardsFunc","saved","saveFunc","scopeName","customGradientDepth","profileKernel","shouldRecord","tapeNode","nextTapeNodeId","output","gradient","dy","activeTape","refCount","refCounter","get","numTensors","numDataBuffers","numBytes","util.bytesPerElement","register","set","v","registeredVariables","keepTensors","delete","disposeData","varName","info","memory","gradientsFunc","inputsMap","input","idx","resMap","gradientsMode","gradientScopeCount","scopeInfo","tensorsToKeep","tensorsToTrackInParent","getTensorsInContainer","tensor","dispose","oldScope","pop","tensorList","isTensorInList","xs","allowNoGradients","tidy","y","filteredTape","tape","tensorsFromX","nodesFromX","nodeInputs","node","inputName","anyInputFromX","tensorsLeadToY","nodesToY","outputs","prunedInputs","nodeInput","prunedNode","getFilteredNodesXToY","accumulatedGradientMap","makeOnesTypedArray","tensorAccumulatedGradientMap","inputGradients","keys","dx","curGradient","backpropagateGradients","grads","util.isFunction","every","t","_a","gradFunc","addTapeNode","pixels","numChannels","fromPixels","query","timingInfo","wallMs","URL_PROPERTIES","type","BOOLEAN","NUMBER","STRING","webGLVersion","isBrowser","gl","getWebGLRenderingContext","e","loseContext","TENSORFLOWJS_FLAGS_PREFIX","features","window","location","queryString","params","urlParams","search","replace","s","decodeURIComponent","decodeParam","urlFlags_1","split","keyValue","key","urlProperty","warn","extensionName","getExtension","tempCanvas","document","createElement","getContext","loseContextExtension","frameBuffer","createFramebuffer","texture","createTexture","bindTexture","TEXTURE_2D","internalFormat","RGBA32F","RGBA","texImage2D","FLOAT","bindFramebuffer","FRAMEBUFFER","framebufferTexture2D","COLOR_ATTACHMENT0","Environment","backendName","ENV","registry","initBackend","initDefaultBackend","engine","disposeVariables","keep","feature","evaluateFeature","entry","sort","priority","versions","navigator","userAgent","test","vendor","getBestBackendName","queryTimerVersion","hasExtension","getWebGLDisjointQueryTimerVersion","opera","substr","isWebGLVersionEnabled","createFloatTextureAndBindToFramebuffer","isFrameBufferComplete","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","isRenderToFloatTextureEnabled","readPixels","readPixelsNoError","getError","NO_ERROR","isDownloadFloatTextureEnabled","isEnabled","fenceSync","isWebGLFenceEnabled","getFeaturesFromURL","globalEngine","findBackend","factory","setTensorTrackerFn","err","message","ns","getGlobalNamespace","setTensorTracker","inputShape","prod","batchToSpace","reshaped","spatialLength","reshapedRank","blockShapeRank","permuted","permutedBeforeBatch","permutedAfterBatch","reshapedPermuted","sliceBeginCoords","uncroppedShape","sliceSize","axes","aShape","outShape","indexOf","outputLoc","reduceLoc","loc","outIdx","reduceIdx","combineLocations","ax","util.isInt","axesAreInnerMostDims","numAxes","PARALLELIZE_THRESHOLD","inSize","nearestDivisor","beginMask","endMask","startIndex","endIndex","startForAxis","stopForAxis","d","count","startIndices","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","axisSize","util.clamp","stopIndices","stop","varList","originalVarCount","some","g","namedGrads","customGrad","argName","functionName","inferredShape","inferShape","toTypedArray","arg","convertToTensor","opName","endsWith","substring","f2","args","configurable","op","softmax_","logits","$logits","lse","toFloat","dyTimesY","customOp","assertShapesMatch","assertNonNull","getTypedArrayFromDType","num","tensor1d","zeros","DType","Rank","UpcastInt32AndMap","UpcastBoolAndMap","UpcastFloat32AndMap","onesLike","onesLike_","$x","ones","zerosLike","zerosLike_","upcastTypeMap","float32","int32","typeA","typeB","upcastType","hasEncodingLoss","int","scalar","boxes","scores","maxOutputSize","iouThreshold","scoreThreshold","candidates","score","boxIndex","c","c1","c2","selected","ignoreCandidate","intersectionOverUnion","iCoord","jCoord","yminI","xminI","ymaxI","xmaxI","yminJ","xminJ","ymaxJ","xmaxJ","areaI","areaJ","intersectionYmin","intersectionXmin","intersectionYmax","intersectionXmax","intersectionArea","xShape","xDtype","sorted","lastDim","batch","allTopKVals","allTopKIndices","valAndInd","outOffset","topKVals","topKIndices","reduceInfo","firstPass","windowSize","batchSize","outSize","variableNames","compOp","indexSnippet","userCode","convInfo","inShape","filterHeight","filterWidth","strideHeight","strideWidth","padTop","padInfo","top","padLeft","left","avgMultiplier","outHeight","outWidth","inRank","dims","unshift","inDim","outAxis","outDim","errMsg","meanShape","varianceShape","offsetShape","scaleShape","broadcast_util.assertAndGetBroadcastShape","offsetSnippet","scaleSnippet","bShape","BinaryOpProgram","gpgpu","webGLProgram","startLoc","getUniformLocationNoThrow","uniform1f","NaN","minFixed","maxFixed","x1Shape","x2Shape","concat_util.computeOutShape","filterShape","inHeight","inWidth","outChannels","channelMul","inChannels","dilationHeight","dilationWidth","inputDepthNearestVec4","inputDepthVec4Remainder","xNumRows","xNumCols","inputsInfo","broadcast","inputPrefixSnippet","shapeInfo","logicalShape","isUniform","inputSamplingSnippet","inInfo","outShapeInfo","inputInfo","texName","funcName","charAt","toUpperCase","texShape","tNumR","tNumC","getSamplerFlat","getSamplerFromInInfo","supportsBroadcasting","texFuncSnippet","broadcastDims","broadcast_util.getBroadcastDims","outRank","doBroadcast","broadcastOverOuter","broadcast_util.broadcastDimsAreOuter","coordsSnippet","rankDiff","unpackedCoordsSnippet","getBroadcastOutputCoordsSampler","broadcastSnippet","outTexShape","inTexShape","getSamplerAtOutputCoords","getInputSamplingSnippet","outputSamplingSnippet","getOutput1DCoords","getOutput2DCoords","stride0","stride1","stride2","getOutput4DCoords","stride3","getOutput5DCoords","stride4","getOutput6DCoords","getOutputSamplingSnippet","SHADER_PREFIX","FLOAT_TEXTURE_SAMPLE_SNIPPET","FLOAT_TEXTURE_SETOUTPUT_SNIPPET","getSamplerScalar","texNumR_1","texNumC_1","squeezedShape","newInputInfo","squeezeInputInfo","getSqueezedParams","texNumR","texNumC","getSampler2D","getSampler3D","getSampler4D","getSampler5D","getSampler6D","JSON","parse","stringify","finalDim","comparator","getCoordsDataType","getFinalCoord","getCoords","TextureUsage","PhysicalTextureType","height","width","indicesLength","sourceCoords","currentCoords","getSourceCoords","matrixSize","channelsPerTexture","unpackedArray","matrix","requiredSize","unpackedSize","getMatrixSizeFromUnpackedArraySize","dst","src","MAX_TEXTURE_SIZE","attributes","canvas","createWebGLRenderingContextFromCanvas","webglVersion","func","returnValue","checkWebGLError","webGLDebugErrorCheckingEnabled","enabled","getWebGLErrorMessage","status","INVALID_ENUM","INVALID_VALUE","INVALID_OPERATION","INVALID_FRAMEBUFFER_OPERATION","OUT_OF_MEMORY","CONTEXT_LOST_WEBGL","throwIfNull","vertexShaderSource","vertexShader","createShader","VERTEX_SHADER","callAndCheck","shaderSource","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","fragmentShaderSource","fragmentShader","FRAGMENT_SHADER","shaderInfoLog","lineNumberRegexResult","lineNumberRegex","exec","lineNumber","shaderLines","linesWithLineNumbers","line","maxLineLength","beforeErrorLines","errorLine","afterErrorLines","logShaderSourceAndInfoLog","createProgram","program","linkProgram","getProgramParameter","LINK_STATUS","getProgramInfoLog","validateProgram","VALIDATE_STATUS","createBuffer","bindBuffer","ARRAY_BUFFER","bufferData","STATIC_DRAW","ELEMENT_ARRAY_BUFFER","getParameter","maxTextureSize","queryMaxTextureSize","requested","attribute","arrayEntriesPerItem","itemStrideInBytes","itemOffsetInBytes","getAttribLocation","vertexAttribPointer","enableVertexAttribArray","textureUnit","validateTextureUnit","activeTexture","TEXTURE0","uniformName","getUniformLocation","uniformSamplerLocation","bindTextureUnit","uniform1i","framebuffer","getFramebufferErrorMessage","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_UNSUPPORTED","returnTOrNull","failureMessage","tOrNull","maxTextureUnit","MAX_COMBINED_TEXTURE_IMAGE_UNITS","glTextureUnit","logShape","util.squeezeShape","maxTexSize","util.sizeToSquarishShape","viewport","scissor","antialias","premultipliedAlpha","preserveDrawingBuffer","stencil","failIfMajorPerformanceCaveat","webgl_util.callAndCheck","webgl_util.createWebGLRenderingContextFromCanvas","webgl_util.createWebGLRenderingContext","disable","DEPTH_TEST","STENCIL_TEST","BLEND","DITHER","POLYGON_OFFSET_FILL","SAMPLE_COVERAGE","enable","SCISSOR_TEST","CULL_FACE","cullFace","BACK","webgl_util.createVertexShader","webgl_util.createStaticVertexBuffer","webgl_util.createStaticIndexBuffer","Uint16Array","textureHalfFloatExtension","internalFormatFloat","internalFormatHalfFloat","internalFormatPackedFloat","textureFormatFloat","downloadUnpackNumChannels","defaultNumChannels","textureTypeHalfFloat","glany","R32F","R16F","RED","HALF_FLOAT","HALF_FLOAT_OES","downloadTextureFormat","textureFormat","textureType","webgl_util.validateTextureSize","webgl_util.createTexture","tex2d","texParameteri","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","textureConfig","createAndConfigureTexture","UNSIGNED_BYTE","vertexBuffer","webgl_util.bindVertexBufferToProgramAttribute","texSubImage2D","w","h","getUnpackedArraySizeFromMatrixSize","tex_util.encodeMatrixToUnpackedArray","tex_util.getUnpackedArraySizeFromMatrixSize","uploadDataToTexture","packedRGBA","tex_util.getPackedRGBAArraySizeFromMatrixShape","getPackedRGBAArraySizeFromMatrixShape","textureWidth","textureHeight","oddWidth","oddHeight","widthInFullBlocks","heightInFullBlocks","dstStride","oneRow","blockY","matrixSrcRow","blockX","srcStride","tex_util.encodeMatrixToPackedRGBA","bufferOrTexture","gl2_1","buffer_1","PIXEL_PACK_BUFFER","bufferSizeBytes_1","gl2","downloadTarget","getBufferSubData","tex_util.decodeMatrixFromUnpackedArray","dstRow1","dstRow2","tex_util.decodeMatrixFromPackedRGBA","gpgpu_util.createWebGLContext","textureFloatExtension","webgl_util.getExtensionOrThrow","colorBufferFloatExtension","colorBufferHalfFloatExtension","gpgpu_util.createVertexBuffer","indexBuffer","gpgpu_util.createIndexBuffer","webgl_util.createFramebuffer","gpgpu_util.getTextureConfig","GPGPUContext","disposed","outputTexture","finish","deleteFramebuffer","deleteBuffer","autoDebugValidate","webgl_util.enableDebugWebGLErrorChecking","gpgpu_util.createFloat32MatrixTexture","gpgpu_util.createFloat16MatrixTexture","gpgpu_util.createUnsignedBytesMatrixTexture","gpgpu_util.uploadPixelDataToTexture","gpgpu_util.createPackedMatrixTexture","webgl_util.unbindColorTextureFromFramebuffer","deleteTexture","webgl_util.getNumChannels","gpgpu_util.uploadMatrixToTexture","gpgpu_util.uploadMatrixToPackedTexture","downloadMatrixDriver","gpgpu_util.downloadFloat32MatrixFromOutputTexture","gpgpu_util.downloadByteEncodedFloatMatrixFromOutputTexture","gpgpu_util.downloadFloat32MatrixFromBuffer","bindTextureToFrameBuffer","gpgpu_util.maybeCreateBufferFromOutputTexture","unbindTextureToFrameBuffer","fenceContext","createFence","pollFence","isFencePassed","sync_1","SYNC_GPU_COMMANDS_COMPLETE","flush","clientWaitSync","ALREADY_SIGNALED","CONDITION_SATISFIED","beginQuery","endQuery","isQueryAvailable","gpgpu_util.downloadMatrixFromPackedOutputTexture","webgl_util.createFragmentShader","gpgpu_util.createVertexShader","webgl_util.createProgram","attachShader","webgl_util.linkProgram","webgl_util.validateProgram","vertexAttrsAreBound","setProgram","gpgpu_util.bindVertexProgramAttributeStreams","deleteProgram","useProgram","shouldThrow","webgl_util.getProgramUniformLocationOrThrow","webgl_util.getProgramUniformLocation","inputMatrixTexture","uniformLocation","throwIfNoProgram","webgl_util.bindTextureToProgramUniformSampler","outputMatrixTexture","setOutputMatrixTextureDriver","outputPackedMatrixTexture","startRow","numRows","startColumn","numColumns","setOutputMatrixWriteRegionDriver","webgl_util.validateFramebuffer","debugValidate","drawElements","TRIANGLES","UNSIGNED_SHORT","disjointQueryTimerExtension","getQueryTimerExtension","ext_1","getQueryTimerExtensionWebGL2","query_1","createQuery","TIME_ELAPSED_EXT","ext","getQueryTimerExtensionWebGL1","createQueryEXT","beginQueryEXT","endQueryEXT","ext_2","util.repeatedTry","getQueryTime","getQueryParameter","QUERY_RESULT","getQueryObjectEXT","QUERY_RESULT_EXT","available","QUERY_RESULT_AVAILABLE","disjoint","GPU_DISJOINT_EXT","QUERY_RESULT_AVAILABLE_EXT","addItemToPoll","best","mid","isDone","binSearchLastTrue","itemsToPoll","isDoneFn","resolveFn","pollItems","webgl_util.bindColorTextureToFramebuffer","downloadAndDecode","outputMatrixTextureMaybePacked","shapeInfos","texShapeA","texShapeB","texData","powOperator","rad","maxD","basis","depthRadius","lastIndex","outerShapeA","outerShapeB","sharedDim","aSnippetFromOffset","vec4Offset","indexVar","bSnippetFromOffset","sharedDimNearestVec4","sharedDimVec4Remainder","numOutcomes","numSamples","MultinomialProgram","seed","seedLoc","numIndices","onValue","offValue","p","unpackedCoords","poolType","computePositions","isAvgPool","initializationValue","filterWidthNearestVec4","filterWidthVec4Remainder","updateSnippet","reduceType","compareOp","windowSizeNearestVec4","windowSizeVec4Remainder","vecType","checkOutOfBounds","xHeight","xWidth","_b","yHeight","yWidth","effectiveXSize","effectiveYSize","heightScale","widthScale","invHeightScale","invWidthScale","winHeight","winWidth","newHeight","newWidth","oldHeight","oldWidth","effectiveInSize","effectiveOutSize","roundBase","inCoords","_","getInCoord","segOpInfo","segOpType","checkValueOutOfBounds","checkSegmentIdOutOfBounds","cRank","cCoords","abCoords","cCoordVars","abCoordVars","destSize","SliceProgram","uniform2i","uniform3i","uniform4i","newCoords","TextureManager","shapeRC","usage","newTexture","physicalTexType","getPhysicalFromLogicalTextureType","shapeKey","getKeyFromTextureShape","freeTextures","usedTextures","numFreeTextures","numUsedTextures","newTexture_1","shift","FLOAT32","createFloat32MatrixTexture","FLOAT16","createFloat16MatrixTexture","createUnsignedBytesMatrixTexture","logicalTexType","texList","texIndex","splice","logEnabled","total","tex","deleteMatrixTexture","DOWNLOAD","PIXELS","UPLOAD","RENDER","shapeRowsCol","newDim","switched","originalOrder","switchedCoords","getSwitchedCoords","SELU_SCALEALPHA","SELU_SCALE","opSnippet","UnaryOpProgram","CHECK_NAN_SNIPPET","RELU","SELU","selu_util.SELU_SCALEALPHA","selu_util.SELU_SCALE","SIN","COS","ATAN","ACOSH","ATANH","aRank","bRank","concat_util.assertParams","a2D","as2D","b2D","aBegin","aSize","bBegin","bSize","runKernel","concat_","tensors","$tensors","convertToTensorArray","parseAxisParam","concat2Tensors","concat1d","concat1d_","concat2d","concat2d_","concat3d","concat3d_","concat4d","concat4d_","global","module","define","copy","s0","s1","s2","impl","opts","xg","me","mash","charCodeAt","next","state","prng","double","quick","exports","amd","alea","z","strseed","xor128","xorwow","Date","X","init","xorshift7","limit","xor4096","tychei","pool","math","nodecrypto","chunks","rngname","startdenom","significance","overflow","mask","seedrandom","options","callback","shortseed","mixkey","prop","typ","entropy","tostring","out","randomBytes","crypto","msCrypto","getRandomValues","browser","plugins","screen","autoseed","arc4","keylen","S","pass","is_math_call","smear","stringseed","fromCharCode","require","sr","stdDeviation","truncated","stdDev","nextVal","upper","lower","seedValue","seedrandom.alea","MPRandGauss","resultX","resultY","isValid","v1","v2","isValidTruncated","convertValue","img","$img","minTensor","maxTensor","multiplier","bytes","Uint8ClampedArray","ctx","imageData","ImageData","putImageData","cast_","clone_","cumsum_","permutation","getAxesPermutation","permutedX","permutedAxis","getInnerMostAxes","expandDims_","eye","eye_","batchShape","buff","toTensor","fromPixels_","multinomial","multinomial_","normalized","origRank","logits2D","oneHot","oneHot_","$indices","pad_","pad1d","pad1d_","pad2d","pad2d_","pad3d","pad3d_","pad4d","pad4d_","rand","rand_","randFunction","randomNormal","randomNormal_","randGauss","nextValue","randomUniform","randomUniform_","minval","maxval","util.randUniform","reshape_","util.inferFromImplicitShape","split_","numOrSizeSplits","splitSizes","reduce","squeeze_","stack_","util.assertShapesMatch","expandedTensors","tile_","xGrad","truncatedNormal","truncatedNormal_","unstack_","outIndex","batchToSpaceND_","spaceToBatchND_","condShape","condVals","inBuffer","indexToLoc","BEFORE_PAGING_CONSTANT","delayedStorage","WeakSet","gpgpuCreatedLocally","NUM_BYTES_BEFORE_PAGING","devicePixelRatio","textureManager","MathBackendWebGL","HTMLVideoElement","HTMLImageElement","HTMLCanvasElement","fromPixelsCanvas","readyState","drawImage","tempPixelArray","uploadPixelDataToTexture","getTexture","FromPixelsProgram","compileAndRun","throwIfNoData","releaseTexture","uploadToGPU","cacheOnCPU","shouldTimeProgram","activeTimers","float32Values","getValuesFromTexture","downloadWaitMs","pendingRead","subscribers_1","maybeCreateBufferFromTexture","createAndWaitForFence","WebGLTexture","downloadFloat32MatrixFromBuffer","subscribers","pendingDisposal","downloadFloat32MatrixFromOutputTexture","tmpTarget","tmpInput","EncodeFloatProgram","tmpData","downloadByteEncodedFloatMatrixFromOutputTexture","oldActiveTimers","newActiveTimers","outerMostTime","programTimersStack","flattenedActiveTimers","util.flatten","results","uploadWaitMs","unreliable","numBytesInGPU","startMs","endMs","waitForQueryAndGetTime","timerQuery","customSetup","getCustomSetupFunc","beginIndex","StridedSliceProgram","ReverseProgram","ConcatProgram","MatMulProgram","makeOutputArray","BatchNormProgram","LRNProgram","inputImage","outputImage","LRNGradProgram","TileProgram","PadProgram","TransposeProgram","GatherProgram","array_ops_util.getReshaped","array_ops_util.getPermuted","array_ops_util.getReshapedPermuted","array_ops_util.getSliceBeginCoords","array_ops_util.getSliceSize","completePaddings","paddedX","reshapedPaddedShape","permutedReshapedPaddedPermutation","flattenShape","reduce_util.computeOptimalWindowSize","ReduceProgram","cols","bestIndicesA","ArgMinMaxProgram","argReduce","axis_util.assertAxesAreInnerMostDims","outputDType","sumOutType","axis_util.getAxesPermutation","axis_util.getInnerMostAxes","segment_util.computeOutShape","segOpCompute","axis_util.getUndoAxesPermutation","done","segment_util.segOpComputeOptimalWindowSize","SegmentOpProgram","range","CumSumProgram","SelectProgram","whereImpl","topkImpl","unary_op.RELU","unary_op.SELU","ClipProgram","unary_op.SIN","unary_op.COS","unary_op.ATAN","unary_op.ACOSH","unary_op.ATANH","unary_op.STEP","Conv2DProgram","Conv2DDerInputProgram","Conv2DDerFilterProgram","DepthwiseConv2DProgram","DepthwiseConv2DDerInputProgram","DepthwiseConv2DDerFilterProgram","Pool2DProgram","maxPoolPositionsProgram","maxPoolPositions","maxPoolBackPropProgram","MaxPool2DBackpropProgram","avgPoolBackpropProgram","AvgPool2DBackpropProgram","backend_util.castTensor","backend_util.reshapeTensor","ResizeBilinearProgram","ResizeBilinearBackpropProgram","ResizeNearestNeighborProgram","ResizeNearestNeigborBackpropProgram","probs","OneHotProgram","nonMaxSuppressionImpl","pageToCpu","inputsData","outputData","keyInputs","keyUserCode","keyBroadcast","gpgpu_math.makeShaderKey","binary","getAndSaveBinary","inputInfos","inShapeInfos","source","shader_compiler.makeShader","uniformLocations","gpgpu_math.compileProgram","startTimer","validateBinaryAndProgram","outTex","setOutputMatrixTexture","variableName","variableUniformLocation","uniform1fv","setInputMatrixTexture","executeProgram","gpgpu_math.runProgram","numBytesToPage","lruDataGPU","computeBytes","endTimer","getBinary","binaryCache","remove","webgl_util.getTextureShapeFromLogicalShape","acquireTexture","uploadMatrixToTexture","dontKeepCopyOnGPU","float32ToTypedArray","texType","registerBackend","abs_","acos_","acosh_","asin_","asinh_","atan_","atanh_","ceil_","clipByValue_","clipValueMin","clipValueMax","clip","cos_","cosh_","erf_","PI","exp_","save","expm1_","floor_","log_","log1p_","logSigmoid_","neg_","reciprocal_","round_","rsqrt_","sigmoid_","sign_","sin_","sinh_","softplus_","sqrt_","square_","step_","tan_","tanh_","as4D","batchNormalization2d","batchNormalization2d_","$scale","$offset","$mean","$variance","batchNormalization3d","batchNormalization3d_","batchNormalization4d","batchNormalization4d_","batchNormalization_","x4D","batchnormReshape4D","scaleValue","reductionAxes","getReductionAxes","tileShape","xMinusMean","dyTimesScaleValue","oneOverSqrtVariance","minusHalfRCube","meanDer","varianceDer","xMinusMean2TimesRsqrt","scaleDer","offsetDer","roundingMode","computeConv2DInfo","depthwise","filterChannels","_c","_d","padType","bottom","right","fieldSize","outDepth","zeroPad","effectiveFieldSize","getEffectiveFilterSize","computeDefaultPad","inputRows","inputCols","outputRows","conditionalRound","outputCols","computeOutputShape3D","padAlongHeight","padAlongWidth","top_1","param","xShape4D","dy4D","reshapedTo4D","inDepth","conv_util.computeConv2DInfo","conv2dDerInput","as3D","dimA","dimB","tupleValuesAreOne","conv1d_","$filter","x3D","reshapedTo3D","eitherStridesOrDilationsAreOne","filter4D","input4D","conv2d_","conv2dDerInput_","conv2dDerFilter","conv2dDerFilter_","depthwiseConv2d_","depthwiseConv2D","depthwiseConv2DDerInput","depthwiseConv2dDerInput","depthwiseConv2DDerFilter","depthwiseConv2dDerFilter","separableConv2d","separableConv2d_","depthwiseFilter","pointwiseFilter","$depthwiseFilter","$pointwiseFilter","channelMultiplier","conv2dTranspose_","matMul_","$a","$b","innerShapeA","innerShapeB","dot_","t1","t2","$t1","$t2","t1Inner","t2Inner","asScalar","outerProduct","outerProduct_","$v1","$v2","reverse_","reshapeAs","reverse1d","reverse1d_","reverse2d","reverse2d_","reverse3d","reverse3d_","reverse4d","reverse4d_","maxPool_","conv_util.computePool2DInfo","y4D","$dy","$input","$output","maxPoolBackprop","avgPool_","avgPoolBackprop","slice_","begin_","size_","slice_util.assertParamsValid","slice1d","slice1d_","slice2d","slice2d_","slice3d","slice3d_","slice4d","slice4d_","all_","origAxes","axis_util.parseAxisParam","permutedAxes","axis_util.expandShapeToKeepDim","any_","argMax_","argMin_","logSumExp_","xMax","max_","mean_","reduceSize","axis_util.computeOutAndReduceShapes","reduceSizeScalar","expandedDyShape","min_","moments","moments_","keepDimsShape","sum_","toInt","equal_","assertTypesMatch","assertAndGetBroadcastShape","equalStrict_","greater_","greaterEqual_","greaterEqualStrict_","greaterStrict_","less_","lessEqual_","lessEqualStrict_","lessStrict_","notEqual_","notEqualStrict_","add_","reduceAxes","broadcast_util.getReductionAxes","addN","addN_","firstTensor","ders","addStrict_","atan2","atan2_","div_","realDivide","tmp","divStrict_","floorDiv_","maximum_","maximumStrict_","minimum_","minimumStrict_","mod_","modStrict_","mul_","multiply","mulStrict_","pow_","base","$base","$exp","powStrict_","squaredDifference_","two","squaredDifferenceStrict_","sub_","subtract","subStrict_","logicalAnd_","logicalNot_","logicalOr_","logicalXor_","where_","$condition","select","whereAsync","elu_","eluDer","leakyRelu_","prelu_","$alpha","zero","relu_","stepRes","selu_","scaleAlpha","greaterThanZeroDer","lessEqualZeroDer","transpose_","undoPerm","localResponseNormalization_","localResponseNormalization4D","LRNGrad","norm_","normImpl","arrays","gather_","paramsShape","indicesSize","outerShape","outerDims","innerShape","innerDims","outerAxesIndices","arrayRange","innerAxesIndices","valuesShape","arrayConcat","reshapedIndices","transposeDims","valuesTranspose","paramsGrad","invertTransposeDims","getUndoAxesPermutation","unsortedSegmentSum_","$segmentIds","isInt","zeroClippedIndices","gathered","isPositive","numIters","zeroSlice","gatherDropNegatives","basicLSTMCell","basicLSTMCell_","forgetBias","lstmKernel","lstmBias","$forgetBias","$lstmKernel","$lstmBias","$data","$c","$h","sliceCols","o","newC","multiRNNCell","multiRNNCell_","lstmCells","newStates","newH","movingAverage","movingAverage_","decay","zeroDebias","$v","$decay","one","oneMinusDecay","update","$step","stridedSlice","stridedSlice_","Reduction","topk","topk_","absoluteDifference","absoluteDifference_","labels","predictions","weights","reduction","SUM_BY_NONZERO_WEIGHTS","$labels","$predictions","$weights","losses","computeWeightedLoss","computeWeightedLoss_","$losses","weightedLoss","NONE","SUM","MEAN","broadcastFactor","numNonZeros","cosineDistance","cosineDistance_","hingeLoss","hingeLoss_","huberLoss","huberLoss_","delta","deltaScalar","quadratic","linear","logLoss","logLoss_","epsilon","epsilonScalar","meanSquaredError","meanSquaredError_","sigmoidCrossEntropy","sigmoidCrossEntropy_","multiClassLabels","labelSmoothing","$multiClassLabels","labelSmoothingScalar","half","maxOutput","outputXTarget","sigmoidOutput","sigmoidCrossEntropyWithLogits_","softmaxCrossEntropy","softmaxCrossEntropy_","onehotLabels","$onehotLabels","numClasses","logResult","dyShape","expandShapeToKeepDim","softmaxCrossEntropyWithLogits_","fullMatrices","m","q","one2D","tensor2d","iters","rTemp","wTemp","qTemp","gramSchmidt","gramSchmidt_","inputIsTensor2D","ys","xs1d","proj","qr","qr_","qr2d","outerDimsProd","prev","q2ds_1","r2ds_1","x2d","q2d","r2d","NEGATIVE_INFINITY","numBoxes","resizeBilinear_","images","$images","batchImages","resizeBilinearBackprop","resizeNearestNeighbor_","resizeNearestNeighborBackprop","nonMaxSuppression","nonMaxSuppression_","$boxes","$scores","nonMaxSuppSanityCheck","nonMaxSuppressionAsync","boxesVals","scoresVals","MathBackendCPU","firstUse","getImageData","numPixels","channel","tensor3d","ops.buffer","xLoc","ops.tensor","newLoc","xBuffer","outLoc","inLoc","aVals","bVals","ops.scalar","broadcastedBinaryOp","aValue","bValue","resultVals","currVals","leftDim","rightDim","aValues","bValues","aOuterStep","aInnerStep","bOuterStep","bInnerStep","aOuterEnd","bOuterEnd","resultIndex","aOuter","bOuter","aInner","bInner","ops.tensor2d","reduceShape","ops.zeros","segmentId","ops.equal","ops.stack","minIndex","maxIndex","resultDtype","indexAdjuster","prevIdx","aVal","bVal","newValues","rem","anyVal","resVals","inVals","resultValues","dyValues","threshold","tooLarge","tooSmall","expX","util.tanh","d2","yR","xRCorner","yC","xCCorner","dotProd","wR","xR","wC","xC","d1","dxValues","dxS0","dxS1","dxS2","dyS0","dyS1","dyS2","fltValues","fltS0","fltS1","fltS2","topPad","leftPad","xRMin","yRMax","xCMin","yCMax","dyOffset","fltOffset","dW","yRMin","yCMin","chMul","dm","trunc","xBuf","originalLoc","i_1","originalIndex","coords","outCoords","i_2","newIndex","indicesValues","xRMax","xCMax","minMaxValue","POSITIVE_INFINITY","avgValue","pixel","maxPositions","maxValue","maxPosition","dxR","dxC","dyRCorner","dyCCorner","dyR","dyC","effectiveInputSize","effectiveOutputSize","sourceFracRow","sourceFracCol","sourceRowFloor","sourceRowCeil","sourceColFloor","sourceColCeil","topLeft","bottomLeft","colFrac","topDxRIndex","bottomDxRIndex","dxRLerp","inverseDxRLerp","leftDxCIndex","rightDxCIndex","dxCLerp","inverseDxCLerp","dyVal","topRight","bottomRight","sourceNearestRow","sourceNearestCol","startRLerp","startDyR","startCLerp","startDyC","accum","dyROffset","dyCOffSet","xValues","meanValues","varianceValues","scaleValues","offsetValues","outValues","tensor4d","sumAcrossChannels","depthBegin","depthEnd","dyi","probabilities","ops.softmax","numEvents","probVals","cdf","event_1","sampleId","event_2","event_3","aBroadcastDims","bBroadcastDims","aBuf","bBuf","aLoc","aIndex","bLoc","bIndex","delayCallback","requestAnimationFrame","setImmediate","DTYPE_VALUE_SIZE_MAP","uint16","uint8","useNodeBuffer","Buffer","Blob","atob","btoa","str","byteLength","buffers","totalByteLength","path","trim","items","modelArtifacts","modelTopology","ArrayBuffer","dateSaved","modelTopologyType","modelTopologyBytes","stringByteLength","weightSpecsBytes","weightSpecs","weightDataBytes","weightData","saveRouters","loadRouters","IORouterRegistry","saveRouter","getInstance","loadRouter","url","getHandlers","handlerType","validHandlers","router","handler","URL_SCHEME_SUFFIX","managers","ModelStoreManagerRegistry","scheme","manager","getSchemes","sourceURL","destURL","deleteSource","loadHandlers","getLoadHandlers","loadHandler","saveHandlers","getSaveHandlers","saveHandler","sourceScheme","parseURL","sourcePath","sameMedium","load","getManager","removeModel","saveResult","modelArtifactsInfo","MODEL_STORE_NAME","INFO_STORE_NAME","theWindow","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","shimIndexedDB","openRequest","db","createObjectStore","keyPath","modelPath","getIndexedDBFactory","BrowserIndexedDB","databaseAction","open","onupgradeneeded","setUpDatabase","onsuccess","modelTx","transaction","getRequest_1","objectStore","close","onerror","oncomplete","modelTx_1","modelArtifactsInfo_1","getModelArtifactsInfoForJSON","infoTx_1","infoStore_1","putInfoRequest_1","put","putModelRequest","deleteInfoRequest","indexedDBRouter","startsWith","URL_SCHEME","registerSaveRouter","registerLoadRouter","BrowserIndexedDBManager","tx","getAllInfoRequest","getAll","item","infoTx","infoStore","getInfoRequest","deleteModelData_1","deleteModelRequest","registerManager","PATH_SEPARATOR","PATH_PREFIX","INFO_SUFFIX","MODEL_TOPOLOGY_SUFFIX","WEIGHT_SPECS_SUFFIX","WEIGHT_DATA_SUFFIX","topology","localStorage","LS","getModelKeys","BrowserLocalStorage","setItem","removeItem","getItem","weightDataBase64","buf","byteOffset","base64StringToArrayBuffer","localStorageRouter","BrowserLocalStorageManager","prefix","suffix","getModelPathFromKey","DEFAULT_FILE_NAME_PREFIX","DEFAULT_JSON_EXTENSION_NAME","DEFAULT_WEIGHT_DATA_EXTENSION_NAME","fileNamePrefix","BrowserDownloads","modelTopologyFileName","weightDataFileName","weightsURL","URL","createObjectURL","weightsManifest","paths","modelTopologyAndWeightManifest","modelTopologyAndWeightManifestURL","jsonAnchor","download","href","click","weightDataAnchor","files","BrowserFiles","jsonFile","weightFiles","jsonReader","FileReader","onload","event","modelJSON","target","pathToFile","checkManifestAndWeightFiles","perFileBuffers","weightsGroup","weightFileReader","concatenateArrayBuffers","readAsArrayBuffer","readAsText","manifest","basenames","fileNames","file","basename","manifest_1","pathBasename","fetchURLs","requestOptions","requests","fetchURL","fetch","responses","response","arrayBuffer","requestInit","body","BrowserHTTPRequest","method","DEFAULT_METHOD","FormData","append","json","modelConfig","weightsManifest_2","weightsManifest_1","pathPrefix_1","lastIndexOf","fetchURLs_1","loadWeightsAsArrayBuffer","httpRequestRouter","URL_SCHEMES","browserHTTPRequest","PassthroughLoader","PassthroughSaver","specs","specs_1","spec","name_2","quantization","name_1","dataPromises","normalizedXs","concatenateTypedArrays","filePathPrefix","weightNames","groupIndicesToFetchMap","groupWeightsToFetch","weightsFound","allManifestWeightNames","manifestGroupConfig","groupIndex","groupOffset","weightsEntry","rawDtype","weightsBytes","enqueueWeightsForFetchingFn","manifestEntry","sizeBytes","weightName","weightIndex","found","weightsNotFound","weight","groupIndicesToFetch","accumulator","shouldFetch","fetchUrls","filepath","fetchUrl","weightsTensorMap","bufferIndexOffset","numBuffers","groupBytes","groupBuffer","groupByteBuffer","groupBufferOffset","typedArray","byteBuffer","quantization_1","quantizedArray","cloneModelInternal","schemes","schemes_1","listModels","schemeOut","schemeAndPath","Serializable","className","cls","config","classNameMap","SerializationMap","getMap","fromConfig","actual","expected","aType","bType","actualValues","expectedValues","areClose","HAS_WEBGL","IS_NODE","IS_CHROME","IS_BROWSER","fail","expectArraysClose","low","high","actualVals","expect","toEqual","Optimizer","returnCost","applyGradients","variableGrads","DEFAULT_FLOAT32_EPSILON","DEFAULT_FLOAT16_EPSILON","learningRate","rho","rhoScalar","oneMinusRho","optimizer_utils.getOptimizerDefaultEpsilonValue","AdadeltaOptimizer","variableGradients","this_1","accumulatedGrads","accumulatedUpdates","accumulatedGrad","accumulatedUpdate","newAccumulatedGrad","updates","newAccumulatedUpdate","initialAccumulatorValue","AdagradOptimizer","beta1","beta2","beta1Scalar","beta2Scalar","accBeta1","accBeta2","oneMinusBeta1","oneMinusBeta2","epsScalar","AdamOptimizer","oneMinusAccBeta1","oneMinusAccBeta2","accumulatedFirstMoment","accumulatedSecondMoment","firstMoment","secondMoment","newFirstMoment","newSecondMoment","biasCorrectedFirstMoment","biasCorrectedSecondMoment","decayScalar","iteration","AdamaxOptimizer","lr","accumulatedWeightedInfNorm","weightedInfNorm","ut0","ut1","newWeightedInfNorm","setLearningRate","SGDOptimizer","momentum","useNesterov","accumulations","MomentumOptimizer","accumulation","newAccumulation","centered","momentumScalar","RMSPropOptimizer","accumulatedMeanSquares","accumulatedMeanGrads","accumulatedMoments","accumulatedMeanSquare","accumulatedMeanGrad","newAccumulatedMeanSquare","newAccumulatedMeanGrad","newAccumulatedMoments","newAccumulatedMeanSquare_1","OptimizerConstructors","train","sgd","adadelta","adagrad","rmsprop","adamax","adam","setBackend","getBackend","ops","checkGrads","grad","gradients"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tracking_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js new file mode 100644 index 0000000..dc4a31c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js @@ -0,0 +1,300 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +var _this = this; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('time webgl', test_util_1.WEBGL_ENVS, function () { + it('upload + compute', function () { return __awaiter(_this, void 0, void 0, function () { + var a, time; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + a = tf.zeros([10, 10]); + return [4, tf.time(function () { return a.square(); })]; + case 1: + time = _a.sent(); + expect(time.uploadWaitMs > 0); + expect(time.downloadWaitMs === 0); + expect(time.kernelMs > 0); + expect(time.wallMs >= time.kernelMs); + return [2]; + } + }); + }); }); + it('upload + compute + dataSync', function () { return __awaiter(_this, void 0, void 0, function () { + var a, time; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + a = tf.zeros([10, 10]); + return [4, tf.time(function () { return a.square().dataSync(); })]; + case 1: + time = _a.sent(); + expect(time.uploadWaitMs > 0); + expect(time.downloadWaitMs > 0); + expect(time.kernelMs > 0); + expect(time.wallMs >= time.kernelMs); + return [2]; + } + }); + }); }); + it('upload + compute + data', function () { return __awaiter(_this, void 0, void 0, function () { + var a, time; + var _this = this; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + a = tf.zeros([10, 10]); + return [4, tf.time(function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, a.square().data()]; + case 1: return [2, _a.sent()]; + } + }); }); })]; + case 1: + time = _a.sent(); + expect(time.uploadWaitMs > 0); + expect(time.downloadWaitMs > 0); + expect(time.kernelMs > 0); + expect(time.wallMs >= time.kernelMs); + return [2]; + } + }); + }); }); + it('preupload (not included) + compute + data', function () { return __awaiter(_this, void 0, void 0, function () { + var a, time; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + a = tf.zeros([10, 10]); + a.square(); + return [4, tf.time(function () { return a.sqrt(); })]; + case 1: + time = _a.sent(); + expect(time.uploadWaitMs === 0); + expect(time.downloadWaitMs === 0); + expect(time.kernelMs > 0); + expect(time.wallMs >= time.kernelMs); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('time cpu', test_util_1.NODE_ENVS, function () { + it('simple upload', function () { return __awaiter(_this, void 0, void 0, function () { + var a, time; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + a = tf.zeros([10, 10]); + return [4, tf.time(function () { return a.square(); })]; + case 1: + time = _a.sent(); + expect(time.kernelMs > 0); + expect(time.wallMs >= time.kernelMs); + return [2]; + } + }); + }); }); +}); +jasmine_util_1.describeWithFlags('tidy', test_util_1.ALL_ENVS, function () { + it('returns Tensor', function () { + tf.tidy(function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([0, 0, 0]); + expect(tf.memory().numTensors).toBe(2); + tf.tidy(function () { + var result = tf.tidy(function () { + b = tf.addStrict(a, b); + b = tf.addStrict(a, b); + b = tf.addStrict(a, b); + return tf.add(a, b); + }); + expect(tf.memory().numTensors).toBe(2 + 1); + test_util_1.expectArraysClose(result, [4, 8, 12]); + }); + expect(tf.memory().numTensors).toBe(2); + }); + expect(tf.memory().numTensors).toBe(0); + }); + it('multiple disposes does not affect num arrays', function () { + expect(tf.memory().numTensors).toBe(0); + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([1, 2, 3]); + expect(tf.memory().numTensors).toBe(2); + a.dispose(); + a.dispose(); + expect(tf.memory().numTensors).toBe(1); + b.dispose(); + expect(tf.memory().numTensors).toBe(0); + }); + it('allows primitive types', function () { + var a = tf.tidy(function () { return 5; }); + expect(a).toBe(5); + var b = tf.tidy(function () { return 'hello'; }); + expect(b).toBe('hello'); + }); + it('allows complex types', function () { + var res = tf.tidy(function () { + return { a: tf.scalar(1), b: 'hello', c: [tf.scalar(2), 'world'] }; + }); + test_util_1.expectArraysClose(res.a, [1]); + test_util_1.expectArraysClose(res.c[0], [2]); + }); + it('returns Tensor[]', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([0, -1, 1]); + expect(tf.memory().numTensors).toBe(2); + tf.tidy(function () { + var result = tf.tidy(function () { + tf.add(a, b); + return [tf.add(a, b), tf.sub(a, b)]; + }); + expect(tf.memory().numTensors).toBe(4); + test_util_1.expectArraysClose(result[0], [1, 1, 4]); + test_util_1.expectArraysClose(result[1], [1, 3, 2]); + expect(tf.memory().numTensors).toBe(4); + }); + expect(tf.memory().numTensors).toBe(2); + a.dispose(); + b.dispose(); + expect(tf.memory().numTensors).toBe(0); + }); + it('basic usage without return', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([0, 0, 0]); + expect(tf.memory().numTensors).toBe(2); + tf.tidy(function () { + b = tf.addStrict(a, b); + b = tf.addStrict(a, b); + b = tf.addStrict(a, b); + tf.add(a, b); + }); + expect(tf.memory().numTensors).toBe(2); + }); + it('nested usage', function () { + var a = tf.tensor1d([1, 2, 3]); + var b = tf.tensor1d([0, 0, 0]); + expect(tf.memory().numTensors).toBe(2); + tf.tidy(function () { + var result = tf.tidy(function () { + b = tf.addStrict(a, b); + b = tf.tidy(function () { + b = tf.tidy(function () { + return tf.addStrict(a, b); + }); + expect(tf.memory().numTensors).toBe(4); + tf.tidy(function () { + tf.addStrict(a, b); + }); + expect(tf.memory().numTensors).toBe(4); + return tf.addStrict(a, b); + }); + expect(tf.memory().numTensors).toBe(4); + return tf.addStrict(a, b); + }); + expect(tf.memory().numTensors).toBe(3); + test_util_1.expectArraysClose(result, [4, 8, 12]); + }); + expect(tf.memory().numTensors).toBe(2); + }); + it('nested usage returns tensor created from outside scope', function () { + var x = tf.scalar(1); + tf.tidy(function () { + tf.tidy(function () { + return x; + }); + }); + expect(x.isDisposed).toBe(false); + }); + it('nested usage with keep works', function () { + var b; + tf.tidy(function () { + var a = tf.scalar(1); + tf.tidy(function () { + b = tf.keep(a); + }); + }); + expect(b.isDisposed).toBe(false); + b.dispose(); + }); + it('single argument', function () { + var hasRan = false; + tf.tidy(function () { + hasRan = true; + }); + expect(hasRan).toBe(true); + }); + it('single argument, but not a function throws error', function () { + expect(function () { + tf.tidy('asdf'); + }).toThrowError(); + }); + it('2 arguments, first is string', function () { + var hasRan = false; + tf.tidy('name', function () { + hasRan = true; + }); + expect(hasRan).toBe(true); + }); + it('2 arguments, but first is not string throws error', function () { + expect(function () { + tf.tidy(4, function () { }); + }).toThrowError(); + }); + it('2 arguments, but second is not a function throws error', function () { + expect(function () { + tf.tidy('name', 'another name'); + }).toThrowError(); + }); + it('works with arbitrary depth of result', function () { + tf.tidy(function () { + var res = tf.tidy(function () { + return [tf.scalar(1), [[tf.scalar(2)]], { list: [tf.scalar(3)] }]; + }); + test_util_1.expectArraysEqual(res[0], [1]); + test_util_1.expectArraysEqual(res[1][0][0], [2]); + test_util_1.expectArraysEqual(res[2].list[0], [3]); + expect(tf.memory().numTensors).toBe(3); + return res[0]; + }); + expect(tf.memory().numTensors).toBe(1); + }); +}); +//# sourceMappingURL=tracking_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js.map new file mode 100644 index 0000000..47faf5a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/tracking_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tracking_test.js","sourceRoot":"","sources":["../src/tracking_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/train.d.ts b/node_modules/@tensorflow/tfjs-core/dist/train.d.ts new file mode 100644 index 0000000..6410d67 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/train.d.ts @@ -0,0 +1,10 @@ +import { OptimizerConstructors } from './optimizers/optimizer_constructors'; +export declare const train: { + sgd: typeof OptimizerConstructors.sgd; + momentum: typeof OptimizerConstructors.momentum; + adadelta: typeof OptimizerConstructors.adadelta; + adagrad: typeof OptimizerConstructors.adagrad; + rmsprop: typeof OptimizerConstructors.rmsprop; + adamax: typeof OptimizerConstructors.adamax; + adam: typeof OptimizerConstructors.adam; +}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/train.js b/node_modules/@tensorflow/tfjs-core/dist/train.js new file mode 100644 index 0000000..4f2dd40 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/train.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var adadelta_optimizer_1 = require("./optimizers/adadelta_optimizer"); +var adagrad_optimizer_1 = require("./optimizers/adagrad_optimizer"); +var adam_optimizer_1 = require("./optimizers/adam_optimizer"); +var adamax_optimizer_1 = require("./optimizers/adamax_optimizer"); +var momentum_optimizer_1 = require("./optimizers/momentum_optimizer"); +var optimizer_constructors_1 = require("./optimizers/optimizer_constructors"); +var rmsprop_optimizer_1 = require("./optimizers/rmsprop_optimizer"); +var sgd_optimizer_1 = require("./optimizers/sgd_optimizer"); +[momentum_optimizer_1.MomentumOptimizer, sgd_optimizer_1.SGDOptimizer, adadelta_optimizer_1.AdadeltaOptimizer, adagrad_optimizer_1.AdagradOptimizer, + rmsprop_optimizer_1.RMSPropOptimizer, adamax_optimizer_1.AdamaxOptimizer, adam_optimizer_1.AdamOptimizer]; +exports.train = { + sgd: optimizer_constructors_1.OptimizerConstructors.sgd, + momentum: optimizer_constructors_1.OptimizerConstructors.momentum, + adadelta: optimizer_constructors_1.OptimizerConstructors.adadelta, + adagrad: optimizer_constructors_1.OptimizerConstructors.adagrad, + rmsprop: optimizer_constructors_1.OptimizerConstructors.rmsprop, + adamax: optimizer_constructors_1.OptimizerConstructors.adamax, + adam: optimizer_constructors_1.OptimizerConstructors.adam +}; +//# sourceMappingURL=train.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/train.js.map b/node_modules/@tensorflow/tfjs-core/dist/train.js.map new file mode 100644 index 0000000..94b2e3b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/train.js.map @@ -0,0 +1 @@ +{"version":3,"file":"train.js","sourceRoot":"","sources":["../src/train.ts"],"names":[],"mappings":";;AAkBA,sEAAkE;AAClE,oEAAgE;AAChE,8DAA0D;AAC1D,kEAA8D;AAC9D,sEAAkE;AAClE,8EAA0E;AAC1E,oEAAgE;AAChE,4DAAwD;AAGxD,CAAC,sCAAiB,EAAE,4BAAY,EAAE,sCAAiB,EAAE,oCAAgB;IACpE,oCAAgB,EAAE,kCAAe,EAAE,8BAAa,CAAC,CAAC;AAEtC,QAAA,KAAK,GAAG;IACnB,GAAG,EAAE,8CAAqB,CAAC,GAAG;IAC9B,QAAQ,EAAE,8CAAqB,CAAC,QAAQ;IACxC,QAAQ,EAAE,8CAAqB,CAAC,QAAQ;IACxC,OAAO,EAAE,8CAAqB,CAAC,OAAO;IACtC,OAAO,EAAE,8CAAqB,CAAC,OAAO;IACtC,MAAM,EAAE,8CAAqB,CAAC,MAAM;IACpC,IAAI,EAAE,8CAAqB,CAAC,IAAI;CACjC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/types.d.ts b/node_modules/@tensorflow/tfjs-core/dist/types.d.ts new file mode 100644 index 0000000..af3e336 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/types.d.ts @@ -0,0 +1,45 @@ +export declare enum DType { + float32 = "float32", + int32 = "int32", + bool = "bool" +} +export interface ShapeMap { + R0: number[]; + R1: [number]; + R2: [number, number]; + R3: [number, number, number]; + R4: [number, number, number, number]; + R5: [number, number, number, number, number]; + R6: [number, number, number, number, number, number]; +} +export interface DataTypeMap { + float32: Float32Array; + int32: Int32Array; + bool: Uint8Array; +} +export declare type DataType = keyof DataTypeMap; +export declare type TypedArray = DataTypeMap[DataType]; +export declare enum Rank { + R0 = "R0", + R1 = "R1", + R2 = "R2", + R3 = "R3", + R4 = "R4", + R5 = "R5", + R6 = "R6" +} +export declare type FlatVector = boolean[] | number[] | TypedArray; +export declare type RegularArray = T[] | T[][] | T[][][] | T[][][][] | T[][][][][] | T[][][][][][]; +export declare type ArrayData = DataTypeMap[D] | RegularArray | RegularArray; +export interface RecursiveArray { + [index: number]: T | RecursiveArray; +} +export declare function upcastType(typeA: DataType, typeB: DataType): DataType; +export declare function sumOutType(type: DataType): "float32" | "int32" | "bool"; +export declare type TensorLike = TypedArray | number | boolean | number[] | number[][] | number[][][] | number[][][][] | number[][][][][] | number[][][][][][] | boolean[] | boolean[][] | boolean[][][] | boolean[][][][] | boolean[][][][][] | boolean[][][][][][]; +export declare type TensorLike1D = TypedArray | number[] | boolean[]; +export declare type TensorLike2D = TypedArray | number[] | number[][] | boolean[] | boolean[][]; +export declare type TensorLike3D = TypedArray | number[] | number[][][] | boolean[] | boolean[][][]; +export declare type TensorLike4D = TypedArray | number[] | number[][][][] | boolean[] | boolean[][][][]; +export declare type TensorLike5D = TypedArray | number[] | number[][][][][] | boolean[] | boolean[][][][][]; +export declare type TensorLike6D = TypedArray | number[] | number[][][][][][] | boolean[] | boolean[][][][][][]; diff --git a/node_modules/@tensorflow/tfjs-core/dist/types.js b/node_modules/@tensorflow/tfjs-core/dist/types.js new file mode 100644 index 0000000..d0b869e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/types.js @@ -0,0 +1,50 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var DType; +(function (DType) { + DType["float32"] = "float32"; + DType["int32"] = "int32"; + DType["bool"] = "bool"; +})(DType = exports.DType || (exports.DType = {})); +var Rank; +(function (Rank) { + Rank["R0"] = "R0"; + Rank["R1"] = "R1"; + Rank["R2"] = "R2"; + Rank["R3"] = "R3"; + Rank["R4"] = "R4"; + Rank["R5"] = "R5"; + Rank["R6"] = "R6"; +})(Rank = exports.Rank || (exports.Rank = {})); +var UpcastInt32AndMap; +(function (UpcastInt32AndMap) { + UpcastInt32AndMap["float32"] = "float32"; + UpcastInt32AndMap["int32"] = "int32"; + UpcastInt32AndMap["bool"] = "int32"; +})(UpcastInt32AndMap || (UpcastInt32AndMap = {})); +var UpcastBoolAndMap; +(function (UpcastBoolAndMap) { + UpcastBoolAndMap["float32"] = "float32"; + UpcastBoolAndMap["int32"] = "int32"; + UpcastBoolAndMap["bool"] = "bool"; +})(UpcastBoolAndMap || (UpcastBoolAndMap = {})); +var UpcastFloat32AndMap; +(function (UpcastFloat32AndMap) { + UpcastFloat32AndMap["float32"] = "float32"; + UpcastFloat32AndMap["int32"] = "float32"; + UpcastFloat32AndMap["bool"] = "float32"; +})(UpcastFloat32AndMap || (UpcastFloat32AndMap = {})); +var upcastTypeMap = { + 'float32': UpcastFloat32AndMap, + 'int32': UpcastInt32AndMap, + 'bool': UpcastBoolAndMap +}; +function upcastType(typeA, typeB) { + return upcastTypeMap[typeA][typeB]; +} +exports.upcastType = upcastType; +function sumOutType(type) { + return upcastType(type, 'int32'); +} +exports.sumOutType = sumOutType; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/types.js.map b/node_modules/@tensorflow/tfjs-core/dist/types.js.map new file mode 100644 index 0000000..5c92718 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;AAiBA,IAAY,KAIX;AAJD,WAAY,KAAK;IACf,4BAAmB,CAAA;IACnB,wBAAe,CAAA;IACf,sBAAa,CAAA;AACf,CAAC,EAJW,KAAK,GAAL,aAAK,KAAL,aAAK,QAIhB;AAuBD,IAAY,IAQX;AARD,WAAY,IAAI;IACd,iBAAS,CAAA;IACT,iBAAS,CAAA;IACT,iBAAS,CAAA;IACT,iBAAS,CAAA;IACT,iBAAS,CAAA;IACT,iBAAS,CAAA;IACT,iBAAS,CAAA;AACX,CAAC,EARW,IAAI,GAAJ,YAAI,KAAJ,YAAI,QAQf;AAaD,IAAK,iBAIJ;AAJD,WAAK,iBAAiB;IACpB,wCAAqB,CAAA;IACrB,oCAAiB,CAAA;IACjB,mCAAgB,CAAA;AAClB,CAAC,EAJI,iBAAiB,KAAjB,iBAAiB,QAIrB;AAED,IAAK,gBAIJ;AAJD,WAAK,gBAAgB;IACnB,uCAAqB,CAAA;IACrB,mCAAiB,CAAA;IACjB,iCAAe,CAAA;AACjB,CAAC,EAJI,gBAAgB,KAAhB,gBAAgB,QAIpB;AAED,IAAK,mBAIJ;AAJD,WAAK,mBAAmB;IACtB,0CAAqB,CAAA;IACrB,wCAAmB,CAAA;IACnB,uCAAkB,CAAA;AACpB,CAAC,EAJI,mBAAmB,KAAnB,mBAAmB,QAIvB;AAED,IAAM,aAAa,GAAG;IACpB,SAAS,EAAE,mBAAmB;IAC9B,OAAO,EAAE,iBAAiB;IAC1B,MAAM,EAAE,gBAAgB;CACzB,CAAC;AAEF,oBAA2B,KAAe,EAAE,KAAe;IACzD,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC;AACrC,CAAC;AAFD,gCAEC;AAGD,oBAA2B,IAAc;IACvC,OAAO,UAAU,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACnC,CAAC;AAFD,gCAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/util.d.ts b/node_modules/@tensorflow/tfjs-core/dist/util.d.ts new file mode 100644 index 0000000..e543830 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util.d.ts @@ -0,0 +1,37 @@ +import { ArrayData, DataType, DataTypeMap, FlatVector, RecursiveArray, RegularArray, TensorLike, TypedArray } from './types'; +export declare function shuffle(array: any[] | Uint32Array | Int32Array | Float32Array): void; +export declare function clamp(min: number, x: number, max: number): number; +export declare function randUniform(a: number, b: number): number; +export declare function distSquared(a: FlatVector, b: FlatVector): number; +export declare function assert(expr: boolean, msg: string | (() => string)): void; +export declare function assertShapesMatch(shapeA: number[], shapeB: number[], errorMessagePrefix?: string): void; +export declare function assertNonNull(a: TensorLike): void; +export declare function flatten>(arr: T | RecursiveArray, ret?: T[]): T[]; +export declare function inferShape(val: TypedArray | number | boolean | RegularArray | RegularArray): number[]; +export declare function sizeFromShape(shape: number[]): number; +export declare function isScalarShape(shape: number[]): boolean; +export declare function arraysEqual(n1: FlatVector, n2: FlatVector): boolean; +export declare function isInt(a: number): boolean; +export declare function tanh(x: number): number; +export declare function sizeToSquarishShape(size: number): [number, number]; +export declare function createShuffledIndices(n: number): Uint32Array; +export declare function rightPad(a: string, size: number): string; +export declare function repeatedTry(checkFn: () => boolean, delayFn?: (counter: number) => number, maxCounter?: number): Promise; +export declare function inferFromImplicitShape(shape: number[], size: number): number[]; +export declare function squeezeShape(shape: number[], axis?: number[]): { + newShape: number[]; + keptDims: number[]; +}; +export declare function getTypedArrayFromDType(dtype: D, size: number): DataTypeMap[D]; +export declare function checkComputationForNaN(vals: DataTypeMap[D], dtype: D, name: string): void; +export declare function checkConversionForNaN(vals: DataTypeMap[D] | number[], dtype: D): void; +export declare function hasEncodingLoss(oldType: DataType, newType: DataType): boolean; +export declare function isTypedArray(a: TypedArray | number | boolean | RegularArray | RegularArray): boolean; +export declare function bytesPerElement(dtype: DataType): number; +export declare function isFunction(f: Function): boolean; +export declare function nearestDivisor(size: number, start: number): number; +export declare function computeStrides(shape: number[]): number[]; +export declare function toTypedArray(a: ArrayData, dtype: D, debugMode: boolean): DataTypeMap[D]; +export declare function makeOnesTypedArray(size: number, dtype: D): DataTypeMap[D]; +export declare function makeZerosTypedArray(size: number, dtype: D): DataTypeMap[D]; +export declare function now(): number; diff --git a/node_modules/@tensorflow/tfjs-core/dist/util.js b/node_modules/@tensorflow/tfjs-core/dist/util.js new file mode 100644 index 0000000..303576a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util.js @@ -0,0 +1,417 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function shuffle(array) { + var counter = array.length; + var temp = 0; + var index = 0; + while (counter > 0) { + index = (Math.random() * counter) | 0; + counter--; + temp = array[counter]; + array[counter] = array[index]; + array[index] = temp; + } +} +exports.shuffle = shuffle; +function clamp(min, x, max) { + return Math.max(min, Math.min(x, max)); +} +exports.clamp = clamp; +function randUniform(a, b) { + return Math.random() * (b - a) + a; +} +exports.randUniform = randUniform; +function distSquared(a, b) { + var result = 0; + for (var i = 0; i < a.length; i++) { + var diff = Number(a[i]) - Number(b[i]); + result += diff * diff; + } + return result; +} +exports.distSquared = distSquared; +function assert(expr, msg) { + if (!expr) { + throw new Error(typeof msg === 'string' ? msg : msg()); + } +} +exports.assert = assert; +function assertShapesMatch(shapeA, shapeB, errorMessagePrefix) { + if (errorMessagePrefix === void 0) { errorMessagePrefix = ''; } + assert(arraysEqual(shapeA, shapeB), errorMessagePrefix + (" Shapes " + shapeA + " and " + shapeB + " must match")); +} +exports.assertShapesMatch = assertShapesMatch; +function assertNonNull(a) { + assert(a != null, "The input to the tensor constructor must be a non-null value."); +} +exports.assertNonNull = assertNonNull; +function flatten(arr, ret) { + if (ret === void 0) { ret = []; } + if (Array.isArray(arr)) { + for (var i = 0; i < arr.length; ++i) { + flatten(arr[i], ret); + } + } + else { + ret.push(arr); + } + return ret; +} +exports.flatten = flatten; +function inferShape(val) { + var firstElem = val; + if (isTypedArray(val)) { + return [val.length]; + } + if (!Array.isArray(val)) { + return []; + } + var shape = []; + while (firstElem instanceof Array) { + shape.push(firstElem.length); + firstElem = firstElem[0]; + } + if (val instanceof Array) { + deepAssertShapeConsistency(val, shape, []); + } + return shape; +} +exports.inferShape = inferShape; +function deepAssertShapeConsistency(val, shape, indices) { + indices = indices || []; + if (!(val instanceof Array)) { + assert(shape.length === 0, function () { return "Element arr[" + indices.join('][') + "] is a primitive, " + + ("but should be an array of " + shape[0] + " elements"); }); + return; + } + assert(shape.length > 0, function () { return "Element arr[" + indices.join('][') + "] should be a primitive, " + + ("but is an array of " + val.length + " elements"); }); + assert(val.length === shape[0], function () { return "Element arr[" + indices.join('][') + "] should have " + shape[0] + " " + + ("elements, but has " + val.length + " elements"); }); + var subShape = shape.slice(1); + for (var i = 0; i < val.length; ++i) { + deepAssertShapeConsistency(val[i], subShape, indices.concat(i)); + } +} +function sizeFromShape(shape) { + if (shape.length === 0) { + return 1; + } + var size = shape[0]; + for (var i = 1; i < shape.length; i++) { + size *= shape[i]; + } + return size; +} +exports.sizeFromShape = sizeFromShape; +function isScalarShape(shape) { + return shape.length === 0; +} +exports.isScalarShape = isScalarShape; +function arraysEqual(n1, n2) { + if (n1.length !== n2.length) { + return false; + } + for (var i = 0; i < n1.length; i++) { + if (n1[i] !== n2[i]) { + return false; + } + } + return true; +} +exports.arraysEqual = arraysEqual; +function isInt(a) { + return a % 1 === 0; +} +exports.isInt = isInt; +function tanh(x) { + if (Math.tanh != null) { + return Math.tanh(x); + } + if (x === Infinity) { + return 1; + } + else if (x === -Infinity) { + return -1; + } + else { + var e2x = Math.exp(2 * x); + return (e2x - 1) / (e2x + 1); + } +} +exports.tanh = tanh; +function sizeToSquarishShape(size) { + for (var a = Math.floor(Math.sqrt(size)); a > 1; --a) { + if (size % a === 0) { + return [a, size / a]; + } + } + return [1, size]; +} +exports.sizeToSquarishShape = sizeToSquarishShape; +function createShuffledIndices(n) { + var shuffledIndices = new Uint32Array(n); + for (var i = 0; i < n; ++i) { + shuffledIndices[i] = i; + } + shuffle(shuffledIndices); + return shuffledIndices; +} +exports.createShuffledIndices = createShuffledIndices; +function rightPad(a, size) { + if (size <= a.length) { + return a; + } + return a + ' '.repeat(size - a.length); +} +exports.rightPad = rightPad; +function repeatedTry(checkFn, delayFn, maxCounter) { + if (delayFn === void 0) { delayFn = function (counter) { return 0; }; } + return new Promise(function (resolve, reject) { + var tryCount = 0; + var tryFn = function () { + if (checkFn()) { + resolve(); + return; + } + tryCount++; + var nextBackoff = delayFn(tryCount); + if (maxCounter != null && tryCount >= maxCounter) { + reject(); + return; + } + setTimeout(tryFn, nextBackoff); + }; + tryFn(); + }); +} +exports.repeatedTry = repeatedTry; +function inferFromImplicitShape(shape, size) { + var shapeProd = 1; + var implicitIdx = -1; + for (var i = 0; i < shape.length; ++i) { + if (shape[i] > 0) { + shapeProd *= shape[i]; + } + else if (shape[i] === -1) { + if (implicitIdx !== -1) { + throw Error("Shapes can only have 1 implicit size. " + + ("Found - 1 at dim " + implicitIdx + " and dim " + i)); + } + implicitIdx = i; + } + else if (shape[i] <= 0) { + throw Error("Shapes can not be <= 0. Found " + shape[i] + " at dim " + i); + } + } + if (implicitIdx === -1) { + if (size > 0 && size !== shapeProd) { + throw Error("Size(" + size + ") must match the product of shape " + shape); + } + return shape; + } + if (size % shapeProd !== 0) { + throw Error("The implicit shape can't be a fractional number. " + + ("Got " + size + " / " + shapeProd)); + } + var newShape = shape.slice(); + newShape[implicitIdx] = size / shapeProd; + return newShape; +} +exports.inferFromImplicitShape = inferFromImplicitShape; +function squeezeShape(shape, axis) { + var newShape = []; + var keptDims = []; + var j = 0; + for (var i = 0; i < shape.length; ++i) { + if (axis != null) { + if (axis[j] === i && shape[i] > 1) { + throw new Error("Can't squeeze axis " + i + " since its dim '" + shape[i] + "' is not 1"); + } + if ((axis[j] == null || axis[j] > i) && shape[i] === 1) { + newShape.push(shape[i]); + keptDims.push(i); + } + if (axis[j] <= i) { + j++; + } + } + if (shape[i] > 1) { + newShape.push(shape[i]); + keptDims.push(i); + } + } + return { newShape: newShape, keptDims: keptDims }; +} +exports.squeezeShape = squeezeShape; +function getTypedArrayFromDType(dtype, size) { + var values = null; + if (dtype == null || dtype === 'float32') { + values = new Float32Array(size); + } + else if (dtype === 'int32') { + values = new Int32Array(size); + } + else if (dtype === 'bool') { + values = new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } + return values; +} +exports.getTypedArrayFromDType = getTypedArrayFromDType; +function checkComputationForNaN(vals, dtype, name) { + if (dtype !== 'float32') { + return; + } + for (var i = 0; i < vals.length; i++) { + if (isNaN(vals[i])) { + throw Error("The result of the '" + name + "' has NaNs."); + } + } +} +exports.checkComputationForNaN = checkComputationForNaN; +function checkConversionForNaN(vals, dtype) { + if (dtype === 'float32') { + return; + } + for (var i = 0; i < vals.length; i++) { + if (isNaN(vals[i])) { + throw Error("NaN is not a valid value for dtype: '" + dtype + "'."); + } + } +} +exports.checkConversionForNaN = checkConversionForNaN; +function hasEncodingLoss(oldType, newType) { + if (newType === 'float32') { + return false; + } + if (newType === 'int32' && oldType !== 'float32') { + return false; + } + if (newType === 'bool' && oldType === 'bool') { + return false; + } + return true; +} +exports.hasEncodingLoss = hasEncodingLoss; +function copyTypedArray(array, dtype, debugMode) { + if (dtype == null || dtype === 'float32') { + return new Float32Array(array); + } + else if (dtype === 'int32') { + if (debugMode) { + checkConversionForNaN(array, dtype); + } + return new Int32Array(array); + } + else if (dtype === 'bool') { + var bool = new Uint8Array(array.length); + for (var i = 0; i < bool.length; ++i) { + if (Math.round(array[i]) !== 0) { + bool[i] = 1; + } + } + return bool; + } + else { + throw new Error("Unknown data type " + dtype); + } +} +function isTypedArray(a) { + return a instanceof Float32Array || a instanceof Int32Array || + a instanceof Uint8Array; +} +exports.isTypedArray = isTypedArray; +function bytesPerElement(dtype) { + if (dtype === 'float32' || dtype === 'int32') { + return 4; + } + else if (dtype === 'bool') { + return 1; + } + else { + throw new Error("Unknown dtype " + dtype); + } +} +exports.bytesPerElement = bytesPerElement; +function isFunction(f) { + return !!(f && f.constructor && f.call && f.apply); +} +exports.isFunction = isFunction; +function nearestDivisor(size, start) { + for (var i = start; i < size; ++i) { + if (size % i === 0) { + return i; + } + } + return size; +} +exports.nearestDivisor = nearestDivisor; +function computeStrides(shape) { + var rank = shape.length; + if (rank < 2) { + return []; + } + var strides = new Array(rank - 1); + strides[rank - 2] = shape[rank - 1]; + for (var i = rank - 3; i >= 0; --i) { + strides[i] = strides[i + 1] * shape[i + 1]; + } + return strides; +} +exports.computeStrides = computeStrides; +function toTypedArray(a, dtype, debugMode) { + if (noConversionNeeded(a, dtype)) { + return a; + } + if (Array.isArray(a)) { + a = flatten(a); + } + return copyTypedArray(a, dtype, debugMode); +} +exports.toTypedArray = toTypedArray; +function noConversionNeeded(a, dtype) { + return (a instanceof Float32Array && dtype === 'float32') || + (a instanceof Int32Array && dtype === 'int32') || + (a instanceof Uint8Array && dtype === 'bool'); +} +function makeOnesTypedArray(size, dtype) { + var array = makeZerosTypedArray(size, dtype); + for (var i = 0; i < array.length; i++) { + array[i] = 1; + } + return array; +} +exports.makeOnesTypedArray = makeOnesTypedArray; +function makeZerosTypedArray(size, dtype) { + if (dtype == null || dtype === 'float32') { + return new Float32Array(size); + } + else if (dtype === 'int32') { + return new Int32Array(size); + } + else if (dtype === 'bool') { + return new Uint8Array(size); + } + else { + throw new Error("Unknown data type " + dtype); + } +} +exports.makeZerosTypedArray = makeZerosTypedArray; +function now() { + if (typeof performance !== 'undefined') { + return performance.now(); + } + else if (typeof process !== 'undefined') { + var time = process.hrtime(); + return time[0] * 1000 + time[1] / 1000000; + } + else { + throw new Error('Can not measure time in this environment. You should run tf.js ' + + 'in the browser or in Node.js'); + } +} +exports.now = now; +//# sourceMappingURL=util.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/util.js.map b/node_modules/@tensorflow/tfjs-core/dist/util.js.map new file mode 100644 index 0000000..9aa13dc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util.js.map @@ -0,0 +1 @@ +{"version":3,"file":"util.js","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/util_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/util_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/util_test.js b/node_modules/@tensorflow/tfjs-core/dist/util_test.js new file mode 100644 index 0000000..1739995 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util_test.js @@ -0,0 +1,199 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var util = require("./util"); +describe('Util', function () { + it('Flatten arrays', function () { + expect(util.flatten([[1, 2, 3], [4, 5, 6]])).toEqual([1, 2, 3, 4, 5, 6]); + expect(util.flatten([[[1, 2], [3, 4], [5, 6], [7, 8]]])).toEqual([ + 1, 2, 3, 4, 5, 6, 7, 8 + ]); + expect(util.flatten([1, 2, 3, 4, 5, 6])).toEqual([1, 2, 3, 4, 5, 6]); + }); + it('Correctly gets size from shape', function () { + expect(util.sizeFromShape([1, 2, 3, 4])).toEqual(24); + }); + it('Correctly identifies scalars', function () { + expect(util.isScalarShape([])).toBe(true); + expect(util.isScalarShape([1, 2])).toBe(false); + expect(util.isScalarShape([1])).toBe(false); + }); + it('Number arrays equal', function () { + expect(util.arraysEqual([1, 2, 3, 6], [1, 2, 3, 6])).toBe(true); + expect(util.arraysEqual([1, 2], [1, 2, 3])).toBe(false); + expect(util.arraysEqual([1, 2, 5], [1, 2])).toBe(false); + }); + it('Is integer', function () { + expect(util.isInt(0.5)).toBe(false); + expect(util.isInt(1)).toBe(true); + }); + it('Size to squarish shape (perfect square)', function () { + expect(util.sizeToSquarishShape(9)).toEqual([3, 3]); + }); + it('Size to squarish shape (prime number)', function () { + expect(util.sizeToSquarishShape(11)).toEqual([1, 11]); + }); + it('Size to squarish shape (almost square)', function () { + expect(util.sizeToSquarishShape(35)).toEqual([5, 7]); + }); + it('Size of 1 to squarish shape', function () { + expect(util.sizeToSquarishShape(1)).toEqual([1, 1]); + }); + it('infer shape single number', function () { + expect(util.inferShape(4)).toEqual([]); + }); + it('infer shape 1d array', function () { + expect(util.inferShape([1, 2, 5])).toEqual([3]); + }); + it('infer shape 2d array', function () { + expect(util.inferShape([[1, 2, 5], [5, 4, 1]])).toEqual([2, 3]); + }); + it('infer shape 3d array', function () { + var a = [[[1, 2], [2, 3], [5, 6]], [[5, 6], [4, 5], [1, 2]]]; + expect(util.inferShape(a)).toEqual([2, 3, 2]); + }); + it('infer shape 4d array', function () { + var a = [ + [[[1], [2]], [[2], [3]], [[5], [6]]], + [[[5], [6]], [[4], [5]], [[1], [2]]] + ]; + expect(util.inferShape(a)).toEqual([2, 3, 2, 1]); + }); + it('infer shape of typed array', function () { + var a = new Float32Array([1, 2, 3, 4, 5]); + expect(util.inferShape(a)).toEqual([5]); + }); +}); +describe('util.repeatedTry', function () { + it('resolves', function (doneFn) { + var counter = 0; + var checkFn = function () { + counter++; + if (counter === 2) { + return true; + } + return false; + }; + util.repeatedTry(checkFn).then(doneFn).catch(function () { + throw new Error('Rejected backoff.'); + }); + }); + it('rejects', function (doneFn) { + var checkFn = function () { return false; }; + util.repeatedTry(checkFn, function () { return 0; }, 5) + .then(function () { + throw new Error('Backoff resolved'); + }) + .catch(doneFn); + }); +}); +describe('util.inferFromImplicitShape', function () { + it('empty shape', function () { + var result = util.inferFromImplicitShape([], 0); + expect(result).toEqual([]); + }); + it('[2, 3, 4] -> [2, 3, 4]', function () { + var result = util.inferFromImplicitShape([2, 3, 4], 24); + expect(result).toEqual([2, 3, 4]); + }); + it('[2, -1, 4] -> [2, 3, 4], size=24', function () { + var result = util.inferFromImplicitShape([2, -1, 4], 24); + expect(result).toEqual([2, 3, 4]); + }); + it('[-1, 3, 4] -> [2, 3, 4], size=24', function () { + var result = util.inferFromImplicitShape([-1, 3, 4], 24); + expect(result).toEqual([2, 3, 4]); + }); + it('[2, 3, -1] -> [2, 3, 4], size=24', function () { + var result = util.inferFromImplicitShape([2, 3, -1], 24); + expect(result).toEqual([2, 3, 4]); + }); + it('[2, -1, -1] throws error', function () { + expect(function () { return util.inferFromImplicitShape([2, -1, -1], 24); }).toThrowError(); + }); + it('[2, 3, -1] size=13 throws error', function () { + expect(function () { return util.inferFromImplicitShape([2, 3, -1], 13); }).toThrowError(); + }); + it('[2, 3, 4] size=25 (should be 24) throws error', function () { + expect(function () { return util.inferFromImplicitShape([2, 3, 4], 25); }).toThrowError(); + }); +}); +describe('util.squeezeShape', function () { + it('scalar', function () { + var _a = util.squeezeShape([]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([]); + expect(keptDims).toEqual([]); + }); + it('1x1 reduced to scalar', function () { + var _a = util.squeezeShape([1, 1]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([]); + expect(keptDims).toEqual([]); + }); + it('1x3x1 reduced to [3]', function () { + var _a = util.squeezeShape([1, 3, 1]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([3]); + expect(keptDims).toEqual([1]); + }); + it('1x1x4 reduced to [4]', function () { + var _a = util.squeezeShape([1, 1, 4]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([4]); + expect(keptDims).toEqual([2]); + }); + it('2x3x4 not reduction', function () { + var _a = util.squeezeShape([2, 3, 4]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([2, 3, 4]); + expect(keptDims).toEqual([0, 1, 2]); + }); + describe('with axis', function () { + it('should only reduce dimensions specified by axis', function () { + var _a = util.squeezeShape([1, 1, 1, 1, 4], [1, 2]), newShape = _a.newShape, keptDims = _a.keptDims; + expect(newShape).toEqual([1, 1, 4]); + expect(keptDims).toEqual([0, 3, 4]); + }); + it('throws error when specified axis is not squeezable', function () { + expect(function () { return util.squeezeShape([1, 1, 2, 1, 4], [1, 2]); }).toThrowError(); + }); + }); +}); +describe('util.checkComputationForNaN', function () { + it('Float32Array has NaN', function () { + expect(function () { return util.checkComputationForNaN(new Float32Array([1, 2, 3, NaN, 4, 255]), 'float32', ''); }) + .toThrowError(); + }); + it('Float32Array no NaN', function () { + expect(function () { return util.checkComputationForNaN(new Float32Array([1, 2, 3, 4, -1, 255]), 'float32', ''); }) + .not.toThrowError(); + }); +}); +describe('util.checkConversionForNaN', function () { + it('Float32Array has NaN', function () { + expect(function () { return util.checkConversionForNaN(new Float32Array([1, 2, 3, NaN, 4, 255]), 'float32'); }) + .not.toThrowError(); + }); + it('Int32Array has NaN', function () { + expect(function () { return util.checkConversionForNaN([1, 2, 3, 4, NaN], 'int32'); }) + .toThrowError(); + }); +}); +describe('util.hasEncodingLoss', function () { + it('any to float32', function () { + expect(util.hasEncodingLoss('bool', 'float32')).toBe(false); + expect(util.hasEncodingLoss('int32', 'float32')).toBe(false); + expect(util.hasEncodingLoss('float32', 'float32')).toBe(false); + }); + it('float32 to any', function () { + expect(util.hasEncodingLoss('float32', 'float32')).toBe(false); + expect(util.hasEncodingLoss('float32', 'int32')).toBe(true); + expect(util.hasEncodingLoss('float32', 'bool')).toBe(true); + }); + it('int32 to lower', function () { + expect(util.hasEncodingLoss('int32', 'int32')).toBe(false); + expect(util.hasEncodingLoss('int32', 'bool')).toBe(true); + }); + it('lower to int32', function () { + expect(util.hasEncodingLoss('bool', 'int32')).toBe(false); + }); + it('bool to bool', function () { + expect(util.hasEncodingLoss('bool', 'bool')).toBe(false); + }); +}); +//# sourceMappingURL=util_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/util_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/util_test.js.map new file mode 100644 index 0000000..3a3e31a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/util_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"util_test.js","sourceRoot":"","sources":["../src/util_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/variable_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/variable_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/variable_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/variable_test.js b/node_modules/@tensorflow/tfjs-core/dist/variable_test.js new file mode 100644 index 0000000..c98e1c3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/variable_test.js @@ -0,0 +1,137 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tf = require("./index"); +var jasmine_util_1 = require("./jasmine_util"); +var tensor_1 = require("./tensor"); +var test_util_1 = require("./test_util"); +jasmine_util_1.describeWithFlags('variable', test_util_1.ALL_ENVS, function () { + it('simple assign', function () { + var v = tensor_1.variable(tf.tensor1d([1, 2, 3])); + test_util_1.expectArraysClose(v, [1, 2, 3]); + v.assign(tf.tensor1d([4, 5, 6])); + test_util_1.expectArraysClose(v, [4, 5, 6]); + }); + it('simple chain assign', function () { + var v = tf.tensor1d([1, 2, 3]).variable(); + test_util_1.expectArraysClose(v, [1, 2, 3]); + v.assign(tf.tensor1d([4, 5, 6])); + test_util_1.expectArraysClose(v, [4, 5, 6]); + }); + it('default names are unique', function () { + var v = tensor_1.variable(tf.tensor1d([1, 2, 3])); + expect(v.name).not.toBeNull(); + var v2 = tensor_1.variable(tf.tensor1d([1, 2, 3])); + expect(v2.name).not.toBeNull(); + expect(v.name).not.toBe(v2.name); + }); + it('user provided name', function () { + var v = tensor_1.variable(tf.tensor1d([1, 2, 3]), true, 'myName'); + expect(v.name).toBe('myName'); + }); + it('if name already used, throw error', function () { + tensor_1.variable(tf.tensor1d([1, 2, 3]), true, 'myName'); + expect(function () { return tensor_1.variable(tf.tensor1d([1, 2, 3]), true, 'myName'); }) + .toThrowError(); + }); + it('ops can take variables', function () { + var value = tf.tensor1d([1, 2, 3]); + var v = tensor_1.variable(value); + var res = tf.sum(v); + test_util_1.expectArraysClose(res, [6]); + }); + it('chained variables works', function () { + var v = tf.tensor1d([1, 2, 3]).variable(); + var res = tf.sum(v); + test_util_1.expectArraysClose(res, [6]); + }); + it('variables are not affected by tidy', function () { + var v; + expect(tf.memory().numTensors).toBe(0); + tf.tidy(function () { + var value = tf.tensor1d([1, 2, 3], 'float32'); + expect(tf.memory().numTensors).toBe(1); + v = tensor_1.variable(value); + expect(tf.memory().numTensors).toBe(2); + }); + expect(tf.memory().numTensors).toBe(1); + test_util_1.expectArraysClose(v, [1, 2, 3]); + v.dispose(); + expect(tf.memory().numTensors).toBe(0); + }); + it('constructor does not dispose', function () { + var a = tf.scalar(2); + var v = tf.variable(a); + expect(tf.memory().numTensors).toBe(2); + expect(tf.memory().numDataBuffers).toBe(1); + test_util_1.expectArraysClose(v, [2]); + test_util_1.expectArraysClose(a, [2]); + }); + it('variables are assignable to tensors', function () { + var x0 = null; + var y0 = x0; + expect(y0).toBeNull(); + var x1 = null; + var y1 = x1; + expect(y1).toBeNull(); + var x2 = null; + var y2 = x2; + expect(y2).toBeNull(); + var x3 = null; + var y3 = x3; + expect(y3).toBeNull(); + var x4 = null; + var y4 = x4; + expect(y4).toBeNull(); + var xh = null; + var yh = xh; + expect(yh).toBeNull(); + }); + it('assign does not dispose old data', function () { + var v; + v = tensor_1.variable(tf.tensor1d([1, 2, 3])); + expect(tf.memory().numTensors).toBe(2); + expect(tf.memory().numDataBuffers).toBe(1); + test_util_1.expectArraysClose(v, [1, 2, 3]); + var secondArray = tf.tensor1d([4, 5, 6]); + expect(tf.memory().numTensors).toBe(3); + expect(tf.memory().numDataBuffers).toBe(2); + v.assign(secondArray); + test_util_1.expectArraysClose(v, [4, 5, 6]); + expect(tf.memory().numTensors).toBe(3); + expect(tf.memory().numDataBuffers).toBe(2); + v.dispose(); + expect(tf.memory().numTensors).toBe(2); + expect(tf.memory().numDataBuffers).toBe(2); + }); + it('shape must match', function () { + var v = tensor_1.variable(tf.tensor1d([1, 2, 3])); + expect(function () { return v.assign(tf.tensor1d([1, 2])); }).toThrowError(); + expect(function () { return v.assign(tf.tensor2d([3, 4], [1, 2])); }).toThrowError(); + }); + it('dtype must match', function () { + var v = tensor_1.variable(tf.tensor1d([1, 2, 3])); + expect(function () { return v.assign(tf.tensor1d([1, 1, 1], 'int32')); }) + .toThrowError(); + expect(function () { return v.assign(tf.tensor1d([true, false, true], 'bool')); }) + .toThrowError(); + }); +}); +jasmine_util_1.describeWithFlags('x instanceof Variable', test_util_1.ALL_ENVS, function () { + it('x: Variable', function () { + var t = tf.variable(tf.scalar(1)); + expect(t instanceof tensor_1.Variable).toBe(true); + }); + it('x: Variable-like', function () { + var t = { assign: function () { }, shape: [2], dtype: 'float32' }; + expect(t instanceof tensor_1.Variable).toBe(true); + }); + it('x: other object, fails', function () { + var t = { something: 'else' }; + expect(t instanceof tensor_1.Variable).toBe(false); + }); + it('x: Tensor, fails', function () { + var t = tf.scalar(1); + expect(t instanceof tensor_1.Variable).toBe(false); + }); +}); +//# sourceMappingURL=variable_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/variable_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/variable_test.js.map new file mode 100644 index 0000000..25118c9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/variable_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"variable_test.js","sourceRoot":"","sources":["../src/variable_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/version.d.ts b/node_modules/@tensorflow/tfjs-core/dist/version.d.ts new file mode 100644 index 0000000..77e0ff7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version.d.ts @@ -0,0 +1,2 @@ +declare const version = "0.12.8"; +export { version }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/version.js b/node_modules/@tensorflow/tfjs-core/dist/version.js new file mode 100644 index 0000000..a5e3ce8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var version = '0.12.8'; +exports.version = version; +//# sourceMappingURL=version.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/version.js.map b/node_modules/@tensorflow/tfjs-core/dist/version.js.map new file mode 100644 index 0000000..71e4f86 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version.js","sourceRoot":"","sources":["../src/version.ts"],"names":[],"mappings":";;AAGA,IAAM,OAAO,GAAG,QAAQ,CAAC;AACjB,0BAAO"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/version_test.d.ts b/node_modules/@tensorflow/tfjs-core/dist/version_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs-core/dist/version_test.js b/node_modules/@tensorflow/tfjs-core/dist/version_test.js new file mode 100644 index 0000000..deb40b6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version_test.js @@ -0,0 +1,10 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var index_1 = require("./index"); +describe('version', function () { + it('version is contained', function () { + var expected = require('../package.json').version; + expect(index_1.version_core).toBe(expected); + }); +}); +//# sourceMappingURL=version_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/version_test.js.map b/node_modules/@tensorflow/tfjs-core/dist/version_test.js.map new file mode 100644 index 0000000..5a33330 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/version_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version_test.js","sourceRoot":"","sources":["../src/version_test.ts"],"names":[],"mappings":";;AAiBA,iCAAqC;AAErC,QAAQ,CAAC,SAAS,EAAE;IAClB,EAAE,CAAC,sBAAsB,EAAE;QAEzB,IAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;QACpD,MAAM,CAAC,oBAAY,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/webgl.d.ts b/node_modules/@tensorflow/tfjs-core/dist/webgl.d.ts new file mode 100644 index 0000000..4317d1b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/webgl.d.ts @@ -0,0 +1,5 @@ +import * as gpgpu_util from './kernels/webgl/gpgpu_util'; +import * as webgl_util from './kernels/webgl/webgl_util'; +export { MathBackendWebGL, WebGLMemoryInfo, WebGLTimingInfo } from './kernels/backend_webgl'; +export { GPGPUContext } from './kernels/webgl/gpgpu_context'; +export { gpgpu_util, webgl_util }; diff --git a/node_modules/@tensorflow/tfjs-core/dist/webgl.js b/node_modules/@tensorflow/tfjs-core/dist/webgl.js new file mode 100644 index 0000000..318be41 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/webgl.js @@ -0,0 +1,11 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var gpgpu_util = require("./kernels/webgl/gpgpu_util"); +exports.gpgpu_util = gpgpu_util; +var webgl_util = require("./kernels/webgl/webgl_util"); +exports.webgl_util = webgl_util; +var backend_webgl_1 = require("./kernels/backend_webgl"); +exports.MathBackendWebGL = backend_webgl_1.MathBackendWebGL; +var gpgpu_context_1 = require("./kernels/webgl/gpgpu_context"); +exports.GPGPUContext = gpgpu_context_1.GPGPUContext; +//# sourceMappingURL=webgl.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/dist/webgl.js.map b/node_modules/@tensorflow/tfjs-core/dist/webgl.js.map new file mode 100644 index 0000000..99aad60 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/dist/webgl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"webgl.js","sourceRoot":"","sources":["../src/webgl.ts"],"names":[],"mappings":";;AAiBA,uDAAyD;AAKjD,gCAAU;AAJlB,uDAAyD;AAIrC,gCAAU;AAH9B,yDAA2F;AAAnF,2CAAA,gBAAgB,CAAA;AACxB,+DAA2D;AAAnD,uCAAA,YAAY,CAAA"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-core/package.json b/node_modules/@tensorflow/tfjs-core/package.json new file mode 100644 index 0000000..e8be992 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-core/package.json @@ -0,0 +1,90 @@ +{ + "_from": "@tensorflow/tfjs-core@0.12.8", + "_id": "@tensorflow/tfjs-core@0.12.8", + "_inBundle": false, + "_integrity": "sha512-Rm3HgjZ0hMbWz8Vj/s9wLtP4ddp+1mi7SyrAbcQ9dU/jnjGupiXBWnAUjiSsID5FtBpVYvvlIxSegmWQxcXorg==", + "_location": "/@tensorflow/tfjs-core", + "_phantomChildren": {}, + "_requested": { + "type": "version", + "registry": true, + "raw": "@tensorflow/tfjs-core@0.12.8", + "name": "@tensorflow/tfjs-core", + "escapedName": "@tensorflow%2ftfjs-core", + "scope": "@tensorflow", + "rawSpec": "0.12.8", + "saveSpec": null, + "fetchSpec": "0.12.8" + }, + "_requiredBy": [ + "/@tensorflow/tfjs" + ], + "_resolved": "https://registry.npmjs.org/@tensorflow/tfjs-core/-/tfjs-core-0.12.8.tgz", + "_shasum": "d7bb5fb17da080374a4918aa5cd423378c0cdc0c", + "_spec": "@tensorflow/tfjs-core@0.12.8", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs", + "bugs": { + "url": "https://github.com/tensorflow/tfjs-core/issues" + }, + "bundleDependencies": false, + "dependencies": { + "@types/seedrandom": "~2.4.27", + "@types/webgl-ext": "~0.0.29", + "@types/webgl2": "~0.0.4", + "seedrandom": "~2.4.3" + }, + "deprecated": false, + "description": "Hardware-accelerated JavaScript library for machine intelligence", + "devDependencies": { + "@types/jasmine": "~2.5.53", + "@types/node": "~9.6.0", + "clang-format": "~1.2.2", + "jasmine": "~3.1.0", + "jasmine-core": "~3.1.0", + "karma": "~2.0.2", + "karma-browserstack-launcher": "~1.3.0", + "karma-chrome-launcher": "~2.2.0", + "karma-jasmine": "~1.1.0", + "karma-typescript": "~3.0.12", + "npm-run-all": "~4.1.3", + "rimraf": "~2.6.2", + "rollup": "~0.58.2", + "rollup-plugin-commonjs": "~9.1.3", + "rollup-plugin-node-resolve": "~3.3.0", + "rollup-plugin-typescript2": "~0.13.0", + "rollup-plugin-uglify": "~3.0.0", + "shelljs": "~0.7.8", + "ts-node": "~7.0.0", + "tslint": "~5.11.0", + "tslint-no-circular-imports": "~0.5.0", + "typescript": "2.9.2", + "yalc": "~1.0.0-pre.21" + }, + "homepage": "https://github.com/tensorflow/tfjs-core#readme", + "jsdelivr": "dist/tf-core.min.js", + "jsnext:main": "dist/tf-core.esm.js", + "license": "Apache-2.0", + "main": "dist/index.js", + "module": "dist/tf-core.esm.js", + "name": "@tensorflow/tfjs-core", + "private": false, + "repository": { + "type": "git", + "url": "git+https://github.com/tensorflow/tfjs-core.git" + }, + "scripts": { + "build": "tsc", + "build-npm": "./scripts/build-npm.sh", + "coverage": "KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun", + "link-local": "yalc link", + "lint": "tslint -p . -t verbose", + "publish-local": "yarn build-npm && yalc push", + "test": "karma start", + "test-all": "./scripts/test-all.sh", + "test-node": "ts-node src/test_node.ts", + "test-travis": "karma start --singleRun --reporters='dots,karma-typescript,BrowserStack' --hostname='bs-local.com'" + }, + "types": "dist/index.d.ts", + "unpkg": "dist/tf-core.min.js", + "version": "0.12.8" +} diff --git a/node_modules/@tensorflow/tfjs-layers/LICENSE b/node_modules/@tensorflow/tfjs-layers/LICENSE new file mode 100644 index 0000000..d6da748 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/LICENSE @@ -0,0 +1,249 @@ +TensorFlow.js Layers is licensed under both the MIT and the Apache 2.0 licenses. + +================================================================================ +COPYRIGHT + +All contributions by François Chollet: +Copyright (c) 2015 - 2018, François Chollet. +All rights reserved. + +All contributions by Google: +Copyright (c) 2015 - 2018, Google LLC. +All rights reserved. + +All contributions by Microsoft: +Copyright (c) 2017 - 2018, Microsoft, Inc. +All rights reserved. + +All other contributions: +Copyright (c) 2015 - 2018, the respective contributors. +All rights reserved. + +Each contributor holds copyright over their respective contributions. +The project versioning (Git) records all such contribution source information. + +LICENSE + +The MIT License (MIT) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +================================================================================ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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. diff --git a/node_modules/@tensorflow/tfjs-layers/README.md b/node_modules/@tensorflow/tfjs-layers/README.md new file mode 100644 index 0000000..2a24fbc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/README.md @@ -0,0 +1,96 @@ +[![Build Status](https://travis-ci.org/tensorflow/tfjs-layers.svg?branch=master)](https://travis-ci.org/tensorflow/tfjs-layers) + +# TensorFlow.js Layers: High-Level Machine Learning Model API + +A part of the TensorFlow.js ecosystem, TensorFlow.js Layers is a high-level +API built on [TensorFlow.js Core](https://github.com/tensorflow/tfjs-core), +enabling users to build, train and execute deep learning models in the browser. +TensorFlow.js Layers is modeled after +[Keras](https://keras.io/) and +[tf.keras](https://www.tensorflow.org/api_docs/python/tf/keras) and can +load models saved from those libraries. + +## Importing + +There are three ways to import TensorFlow.js Layers + +1. You can access TensorFlow.js Layers through the union package + between the TensorFlow.js Core and Layers: + [@tensorflow/tfjs](https://www.npmjs.com/package/@tensorflow/tfjs) +2. You can get [TensorFlow.js] Layers as a module: + [@tensorflow/tfjs-layers](https://www.npmjs.com/package/@tensorflow/tfjs-layers). + Note that `tfjs-layers` has peer dependency on tfjs-core, so if you import + `@tensorflow/tfjs-layers`, you also need to import + `@tensorflow/tfjs-core`. +3. As a standalone through [unpkg](https://unpkg.com/). + +Option 1 is the most convenient, but leads to a larger bundle size (we will be +adding more packages to it in the future). Use option 2 if you care about bundle +size. + +## Getting started + +### Building, training and executing a model + +The following example shows how to build a toy model with only one `dense` layer +to perform linear regression. + +```js +import * as tf from '@tensorflow/tfjs'; + +// A sequential model is a container which you can add layers to. +const model = tf.sequential(); + +// Add a dense layer with 1 output unit. +model.add(tf.layers.dense({units: 1, inputShape: [1]})); + +// Specify the loss type and optimizer for training. +model.compile({loss: 'meanSquaredError', optimizer: 'SGD'}); + +// Generate some synthetic data for training. +const xs = tf.tensor2d([[1], [2], [3], [4]], [4, 1]); +const ys = tf.tensor2d([[1], [3], [5], [7]], [4, 1]); + +// Train the model. +await model.fit(xs, ys, {epochs: 500}); + +// Ater the training, perform inference. +const output = model.predict(tf.tensor2d([[5]], [1, 1])); +output.print(); +``` + +### Loading a pretrained Keras model + +You can also load a model previously trained and saved from elsewhere (e.g., +from Python Keras) and use it for inference or transfer learning in the browser. + +For example, in Python, save your Keras model using +[tensorflowjs](https://pypi.org/project/tensorflowjs/), +which can be installed using `pip install tensorflowjs`. + + +```python +import tensorflowjs as tfjs + +# ... Create and train your Keras model. + +# Save your Keras model in TensorFlow.js format. +tfjs.converters.save_keras_model(model, '/path/to/tfjs_artifacts/') + +# Then use your favorite web server to serve the directory at a URL, say +# http://foo.bar/tfjs_artifacts/model.json +``` + +To load the model with TensorFlow.js Layers: + +```js +import * as tf from '@tensorflow/tfjs'; + +const model = await tf.loadModel('http://foo.bar/tfjs_artifacts/model.json'); +// Now the model is ready for inference, evaluation or re-training. +``` + +## For more information + +- [TensorFlow.js API documentation](https://js.tensorflow.org/api/index.html) +- [TensorFlow.js Tutorials](https://js.tensorflow.org/tutorials/) diff --git a/node_modules/@tensorflow/tfjs-layers/dist/activations.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/activations.d.ts new file mode 100644 index 0000000..063383a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/activations.d.ts @@ -0,0 +1,53 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +export declare abstract class Activation extends serialization.Serializable { + abstract apply(tensor: Tensor, axis?: number): Tensor; + getConfig(): serialization.ConfigDict; +} +export declare type ActivationIdentifier = 'elu' | 'hardSigmoid' | 'linear' | 'relu' | 'relu6' | 'selu' | 'sigmoid' | 'softmax' | 'softplus' | 'softsign' | 'tanh' | string; +export declare class Elu extends Activation { + static readonly className: string; + apply(x: Tensor, alpha?: number): Tensor; +} +export declare class Selu extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Relu extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Relu6 extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Linear extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Sigmoid extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class HardSigmoid extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Softplus extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Softsign extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Tanh extends Activation { + static readonly className: string; + apply(x: Tensor): Tensor; +} +export declare class Softmax extends Activation { + static readonly className: string; + apply(x: Tensor, axis?: number): Tensor; +} +export declare function serializeActivation(activation: Activation): string; +export declare function deserializeActivation(config: serialization.ConfigDict, customObjects?: serialization.ConfigDict): Activation; +export declare function getActivation(identifier: ActivationIdentifier | serialization.ConfigDict | Activation): Activation; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/activations.js b/node_modules/@tensorflow/tfjs-layers/dist/activations.js new file mode 100644 index 0000000..c1520e3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/activations.js @@ -0,0 +1,200 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var K = require("./backend/tfjs_backend"); +var state_1 = require("./backend/state"); +var generic_utils_1 = require("./utils/generic_utils"); +var Activation = (function (_super) { + __extends(Activation, _super); + function Activation() { + return _super !== null && _super.apply(this, arguments) || this; + } + Activation.prototype.getConfig = function () { + return {}; + }; + return Activation; +}(tfjs_core_1.serialization.Serializable)); +exports.Activation = Activation; +var Elu = (function (_super) { + __extends(Elu, _super); + function Elu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Elu.prototype.apply = function (x, alpha) { + if (alpha === void 0) { alpha = 1; } + return K.elu(x, alpha); + }; + Elu.className = 'elu'; + return Elu; +}(Activation)); +exports.Elu = Elu; +tfjs_core_1.serialization.SerializationMap.register(Elu); +var Selu = (function (_super) { + __extends(Selu, _super); + function Selu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Selu.prototype.apply = function (x) { + return tfc.selu(x); + }; + Selu.className = 'selu'; + return Selu; +}(Activation)); +exports.Selu = Selu; +tfjs_core_1.serialization.SerializationMap.register(Selu); +var Relu = (function (_super) { + __extends(Relu, _super); + function Relu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Relu.prototype.apply = function (x) { + return tfc.relu(x); + }; + Relu.className = 'relu'; + return Relu; +}(Activation)); +exports.Relu = Relu; +tfjs_core_1.serialization.SerializationMap.register(Relu); +var Relu6 = (function (_super) { + __extends(Relu6, _super); + function Relu6() { + return _super !== null && _super.apply(this, arguments) || this; + } + Relu6.prototype.apply = function (x) { + return tfjs_core_1.tidy(function () { return tfc.minimum(state_1.getScalar(6.0), tfc.relu(x)); }); + }; + Relu6.className = 'relu6'; + return Relu6; +}(Activation)); +exports.Relu6 = Relu6; +tfjs_core_1.serialization.SerializationMap.register(Relu6); +var Linear = (function (_super) { + __extends(Linear, _super); + function Linear() { + return _super !== null && _super.apply(this, arguments) || this; + } + Linear.prototype.apply = function (x) { + return x; + }; + Linear.className = 'linear'; + return Linear; +}(Activation)); +exports.Linear = Linear; +tfjs_core_1.serialization.SerializationMap.register(Linear); +var Sigmoid = (function (_super) { + __extends(Sigmoid, _super); + function Sigmoid() { + return _super !== null && _super.apply(this, arguments) || this; + } + Sigmoid.prototype.apply = function (x) { + return tfc.sigmoid(x); + }; + Sigmoid.className = 'sigmoid'; + return Sigmoid; +}(Activation)); +exports.Sigmoid = Sigmoid; +tfjs_core_1.serialization.SerializationMap.register(Sigmoid); +var HardSigmoid = (function (_super) { + __extends(HardSigmoid, _super); + function HardSigmoid() { + return _super !== null && _super.apply(this, arguments) || this; + } + HardSigmoid.prototype.apply = function (x) { + return K.hardSigmoid(x); + }; + HardSigmoid.className = 'hardSigmoid'; + return HardSigmoid; +}(Activation)); +exports.HardSigmoid = HardSigmoid; +tfjs_core_1.serialization.SerializationMap.register(HardSigmoid); +var Softplus = (function (_super) { + __extends(Softplus, _super); + function Softplus() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softplus.prototype.apply = function (x) { + return tfc.softplus(x); + }; + Softplus.className = 'softplus'; + return Softplus; +}(Activation)); +exports.Softplus = Softplus; +tfjs_core_1.serialization.SerializationMap.register(Softplus); +var Softsign = (function (_super) { + __extends(Softsign, _super); + function Softsign() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softsign.prototype.apply = function (x) { + return K.softsign(x); + }; + Softsign.className = 'softsign'; + return Softsign; +}(Activation)); +exports.Softsign = Softsign; +tfjs_core_1.serialization.SerializationMap.register(Softsign); +var Tanh = (function (_super) { + __extends(Tanh, _super); + function Tanh() { + return _super !== null && _super.apply(this, arguments) || this; + } + Tanh.prototype.apply = function (x) { + return tfc.tanh(x); + }; + Tanh.className = 'tanh'; + return Tanh; +}(Activation)); +exports.Tanh = Tanh; +tfjs_core_1.serialization.SerializationMap.register(Tanh); +var Softmax = (function (_super) { + __extends(Softmax, _super); + function Softmax() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softmax.prototype.apply = function (x, axis) { + if (axis === void 0) { axis = (-1); } + return tfc.softmax(x, axis); + }; + Softmax.className = 'softmax'; + return Softmax; +}(Activation)); +exports.Softmax = Softmax; +tfjs_core_1.serialization.SerializationMap.register(Softmax); +function serializeActivation(activation) { + return activation.getClassName(); +} +exports.serializeActivation = serializeActivation; +function deserializeActivation(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return generic_utils_1.deserializeKerasObject(config, tfjs_core_1.serialization.SerializationMap.getMap().classNameMap, customObjects, 'activation'); +} +exports.deserializeActivation = deserializeActivation; +function getActivation(identifier) { + if (identifier == null) { + var config = { className: 'linear', config: {} }; + return deserializeActivation(config); + } + if (typeof identifier === 'string') { + var config = { className: identifier, config: {} }; + return deserializeActivation(config); + } + else if (identifier instanceof Activation) { + return identifier; + } + else { + return deserializeActivation(identifier); + } +} +exports.getActivation = getActivation; +//# sourceMappingURL=activations.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/activations.js.map b/node_modules/@tensorflow/tfjs-layers/dist/activations.js.map new file mode 100644 index 0000000..72ba7db --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/activations.js.map @@ -0,0 +1 @@ +{"version":3,"file":"activations.js","sourceRoot":"","sources":["../src/activations.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/activations_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/activations_test.js.map new file mode 100644 index 0000000..34cbfe1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/activations_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"activations_test.js","sourceRoot":"","sources":["../src/activations_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/common.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.d.ts new file mode 100644 index 0000000..56af0f6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.d.ts @@ -0,0 +1,4 @@ +import { DataFormat } from '../common'; +export declare function epsilon(): number; +export declare function setEpsilon(e: number): void; +export declare function imageDataFormat(): DataFormat; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js new file mode 100644 index 0000000..8117ed6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js @@ -0,0 +1,16 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var _epsilon = 1e-7; +function epsilon() { + return _epsilon; +} +exports.epsilon = epsilon; +function setEpsilon(e) { + _epsilon = e; +} +exports.setEpsilon = setEpsilon; +function imageDataFormat() { + return 'channelsLast'; +} +exports.imageDataFormat = imageDataFormat; +//# sourceMappingURL=common.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js.map b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js.map new file mode 100644 index 0000000..bb59add --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/common.js.map @@ -0,0 +1 @@ +{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/backend/common.ts"],"names":[],"mappings":";;AAYA,IAAI,QAAQ,GAAG,IAAI,CAAC;AAKpB;IACE,OAAO,QAAQ,CAAC;AAClB,CAAC;AAFD,0BAEC;AAMD,oBAA2B,CAAS;IAClC,QAAQ,GAAG,CAAC,CAAC;AACf,CAAC;AAFD,gCAEC;AAKD;IACE,OAAO,cAAc,CAAC;AACxB,CAAC;AAFD,0CAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/state.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.d.ts new file mode 100644 index 0000000..324988a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.d.ts @@ -0,0 +1,5 @@ +import { DataType, Scalar } from '@tensorflow/tfjs-core'; +export declare function getNextUniqueTensorId(): number; +export declare function getUid(prefix?: string): string; +export declare function getScalar(value: number, dtype?: DataType): Scalar; +export declare function disposeScalarCache(): void; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js new file mode 100644 index 0000000..46f7289 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js @@ -0,0 +1,44 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var _nextUniqueTensorId = 0; +function getNextUniqueTensorId() { + return _nextUniqueTensorId++; +} +exports.getNextUniqueTensorId = getNextUniqueTensorId; +var _uidPrefixes = {}; +function getUid(prefix) { + if (prefix === void 0) { prefix = ''; } + if (!(prefix in _uidPrefixes)) { + _uidPrefixes[prefix] = 0; + } + _uidPrefixes[prefix] += 1; + return prefix + _uidPrefixes[prefix].toString(); +} +exports.getUid = getUid; +var scalarCache = { + float32: {}, + int32: {} +}; +var DEFAULT_DTYPE = 'float32'; +function getScalar(value, dtype) { + if (dtype === undefined) { + dtype = DEFAULT_DTYPE; + } + if (scalarCache[dtype][value] == null) { + scalarCache[dtype][value] = tfjs_core_1.scalar(value, dtype); + tfjs_core_1.keep(scalarCache[dtype][value]); + } + return scalarCache[dtype][value]; +} +exports.getScalar = getScalar; +function disposeScalarCache() { + for (var typeKey in scalarCache) { + for (var key in scalarCache[typeKey]) { + scalarCache[typeKey][key].dispose(); + delete scalarCache[typeKey][key]; + } + } +} +exports.disposeScalarCache = disposeScalarCache; +//# sourceMappingURL=state.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js.map b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js.map new file mode 100644 index 0000000..98e146c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/state.js.map @@ -0,0 +1 @@ +{"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/backend/state.ts"],"names":[],"mappings":";;AAcA,mDAAqE;AAOrE,IAAI,mBAAmB,GAAG,CAAC,CAAC;AAE5B;IACE,OAAO,mBAAmB,EAAE,CAAC;AAC/B,CAAC;AAFD,sDAEC;AAED,IAAM,YAAY,GAA+B,EAAE,CAAC;AAOpD,gBAAuB,MAAW;IAAX,uBAAA,EAAA,WAAW;IAChC,IAAI,CAAC,CAAC,MAAM,IAAI,YAAY,CAAC,EAAE;QAC7B,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;KAC1B;IACD,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1B,OAAO,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;AAClD,CAAC;AAND,wBAMC;AAED,IAAM,WAAW,GAAiD;IAChE,OAAO,EAAE,EAAE;IACX,KAAK,EAAE,EAAE;CACV,CAAC;AAEF,IAAM,aAAa,GAAa,SAAS,CAAC;AAK1C,mBAA0B,KAAa,EAAE,KAAgB;IACvD,IAAI,KAAK,KAAK,SAAS,EAAE;QACvB,KAAK,GAAG,aAAa,CAAC;KACvB;IACD,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;QACrC,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,GAAG,kBAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACjD,gBAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;KACjC;IACD,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC;AACnC,CAAC;AATD,8BASC;AAED;IACE,KAAK,IAAM,OAAO,IAAI,WAAW,EAAE;QACjC,KAAK,IAAM,GAAG,IAAI,WAAW,CAAC,OAAO,CAAC,EAAE;YACtC,WAAW,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACpC,OAAO,WAAW,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC;SAClC;KACF;AACH,CAAC;AAPD,gDAOC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/state_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/backend/state_test.js.map new file mode 100644 index 0000000..719b257 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/state_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"state_test.js","sourceRoot":"","sources":["../../src/backend/state_test.ts"],"names":[],"mappings":";;AAUA,0CAAwC;AAExC,QAAQ,CAAC,SAAS,EAAE;IAClB,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,IAAI,GAAG,KAAK,CAAC;QACnB,IAAM,QAAQ,GAAG,cAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAM,SAAS,GAAG,cAAM,CAAC,IAAI,CAAC,CAAC;QAC/B,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAM,QAAQ,GAAG,cAAM,EAAE,CAAC;QAC1B,IAAM,SAAS,GAAG,cAAM,EAAE,CAAC;QAC3B,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.d.ts new file mode 100644 index 0000000..dfa1367 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.d.ts @@ -0,0 +1,31 @@ +import { Scalar, Tensor, Tensor1D } from '@tensorflow/tfjs-core'; +import { DataFormat } from '../common'; +import { HasShape, Shape } from '../types'; +export declare function setBackend(requestedBackend: 'cpu' | 'webgl'): void; +export declare function getBackend(): 'cpu' | 'webgl'; +export declare function isBackendSymbolic(): boolean; +export declare function countParams(x: HasShape): number; +export declare function cast(x: Tensor, dtype: 'float32' | 'int32' | 'bool'): Tensor; +export declare function expandDims(x: Tensor, axis?: number): Tensor; +export declare function repeat(x: Tensor, n: number): Tensor; +export declare function flatten(x: Tensor): Tensor; +export declare function batchFlatten(x: Tensor): Tensor; +export declare function sliceAlongFirstAxis(array: Tensor, start: number, size: number): Tensor; +export declare function sliceAlongLastAxis(array: Tensor, start: number, size: number): Tensor; +export declare function sliceAlongAxis(array: Tensor, start: number, size: number, axis: number): Tensor; +export declare function concatenate(tensors: Tensor[], axis?: number): Tensor; +export declare function concatAlongFirstAxis(a: Tensor, b: Tensor): Tensor; +export declare function tile(x: Tensor, n: number | number[]): Tensor; +export declare function randomNormal(shape: Shape, mean?: number, stddev?: number, dtype?: 'float32' | 'int32', seed?: number): Tensor; +export declare function dot(x: Tensor, y: Tensor): Tensor; +export declare function sign(x: Tensor): Tensor; +export declare function oneHot(indices: Tensor, numClasses: number): Tensor; +export declare function gather(reference: Tensor, indices: number[] | Tensor1D, axis?: number): Tensor; +export declare function square(x: Tensor): Tensor; +export declare function pow(x: Tensor, a: Tensor | number): Tensor; +export declare function biasAdd(x: Tensor, bias: Tensor, dataFormat?: DataFormat): Tensor; +export declare function elu(x: Tensor, alpha?: number): Tensor; +export declare function softsign(x: Tensor): Tensor; +export declare function dropout(x: Tensor, level: Scalar, noiseShape?: number[], seed?: number): Tensor; +export declare function hardSigmoid(x: Tensor): Tensor; +export declare function inTrainPhase(x: () => T, alt: () => T, training?: boolean): T; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js new file mode 100644 index 0000000..b09ca9c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js @@ -0,0 +1,396 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var common_1 = require("../common"); +var errors_1 = require("../errors"); +var math_utils = require("../utils/math_utils"); +var common_2 = require("./common"); +var backend = 'webgl'; +function setBackend(requestedBackend) { + tfc.setBackend(requestedBackend); + backend = requestedBackend; + state_1.disposeScalarCache(); +} +exports.setBackend = setBackend; +function getBackend() { + return backend; +} +exports.getBackend = getBackend; +function isBackendSymbolic() { + return false; +} +exports.isBackendSymbolic = isBackendSymbolic; +function countParams(x) { + var shape = x.shape; + if (shape.length > 0) { + return shape.reduce(function (a, b) { return a * b; }); + } + else { + return 1; + } +} +exports.countParams = countParams; +function cast(x, dtype) { + return x.asType(dtype); +} +exports.cast = cast; +function expandDims(x, axis) { + if (axis === void 0) { axis = -1; } + var outShape = x.shape.slice(); + if (axis < 0) { + axis = outShape.length + axis + 1; + } + outShape.splice(axis, 0, 1); + return x.reshape(outShape); +} +exports.expandDims = expandDims; +function repeat(x, n) { + return tfjs_core_1.tidy(function () { + if (x.shape.length !== 2) { + throw new errors_1.ValueError("repeat() expects a rank-2 tensor, but received a " + + ("rank-" + x.shape.length + " tensor.")); + } + var y = expandDims(x, 1); + return tile(y, [1, n, 1]); + }); +} +exports.repeat = repeat; +function flatten(x) { + var newShape = [math_utils.arrayProd(x.shape)]; + return x.reshape(newShape); +} +exports.flatten = flatten; +function batchFlatten(x) { + if (x.rank <= 1) { + throw new errors_1.ValueError("batchFlatten requires a minimum rank of 2. Got rank: " + x.rank + "."); + } + var newShape = [x.shape[0], math_utils.arrayProd(x.shape, 1)]; + return x.reshape(newShape); +} +exports.batchFlatten = batchFlatten; +function sliceAlongFirstAxis(array, start, size) { + return tfjs_core_1.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + return tfc.slice2d(array, [start, 0], [size, array.shape[1]]); + case 3: + return tfc.slice3d(array, [start, 0, 0], [size, array.shape[1], array.shape[2]]); + case 4: + return tfc.slice4d(array, [start, 0, 0, 0], [size, array.shape[1], array.shape[2], array.shape[3]]); + default: + throw new errors_1.ValueError("sliceAlongFirstAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); +} +exports.sliceAlongFirstAxis = sliceAlongFirstAxis; +function sliceAlongLastAxis(array, start, size) { + return tfjs_core_1.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + return tfc.slice2d(array, [0, start], [array.shape[0], size]); + case 3: + return tfc.slice3d(array, [0, 0, start], [array.shape[0], array.shape[1], size]); + case 4: + return tfc.slice4d(array, [0, 0, 0, start], [array.shape[0], array.shape[1], array.shape[2], size]); + default: + throw new errors_1.ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); +} +exports.sliceAlongLastAxis = sliceAlongLastAxis; +function sliceAlongAxis(array, start, size, axis) { + return tfjs_core_1.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return sliceAlongLastAxis(array, start, size); + default: + throw new errors_1.ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + case 3: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return tfc.slice3d(array, [0, start, 0], [array.shape[0], size, array.shape[2]]); + case 3: + return sliceAlongLastAxis(array, start, size); + default: + throw new errors_1.ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + case 4: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return tfc.slice4d(array, [0, start, 0, 0], [array.shape[0], size, array.shape[2], array.shape[3]]); + case 3: + return tfc.slice4d(array, [0, 0, start, 0], [array.shape[0], array.shape[1], size, array.shape[3]]); + case 4: + return sliceAlongLastAxis(array, start, size); + default: + throw new errors_1.ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + default: + throw new errors_1.ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); +} +exports.sliceAlongAxis = sliceAlongAxis; +function concatenate(tensors, axis) { + if (axis === void 0) { axis = -1; } + var rank; + if (axis < 0) { + rank = tensors[0].rank; + if (rank !== 0) { + axis = rank; + } + else { + axis = 0; + } + } + if (axis === tensors[0].rank) { + axis = -1; + } + return tfc.concat(tensors, axis); +} +exports.concatenate = concatenate; +function concatAlongFirstAxis(a, b) { + switch (a.rank) { + case 1: + return tfc.concat1d([a, b]); + case 2: + return tfc.concat2d([a, b], 0); + case 3: + return tfc.concat3d([a, b], 0); + case 4: + return tfc.concat4d([a, b], 0); + default: + throw new errors_1.ValueError('concatAlongFirstAxis() received an unsupported tensor rank: ' + + a.rank); + } +} +exports.concatAlongFirstAxis = concatAlongFirstAxis; +function tile(x, n) { + if (!Array.isArray(n)) { + n = [n]; + } + if (x.rank !== n.length) { + throw new errors_1.ValueError("The length of input n (" + n.length + ") does not match " + + ("the number of dimensions in input x (" + x.rank + ")")); + } + return tfc.tile(x, n); +} +exports.tile = tile; +function randomNormal(shape, mean, stddev, dtype, seed) { + if (mean === void 0) { mean = 0.0; } + if (stddev === void 0) { stddev = 1.0; } + return tfc.randomNormal(shape, mean, stddev, dtype, seed); +} +exports.randomNormal = randomNormal; +function dot(x, y) { + if (y.rank !== 2) { + throw new errors_1.NotImplementedError("dot support for y other than rank 2 is not yet implemented: " + + ("y shape = " + y.shape)); + } + else { + if (x.rank === 2) { + return tfc.matMul(x, y); + } + else if (x.rank === 3) { + var xShape0 = x.shape[0]; + var xShape1 = x.shape[1]; + var xShape2 = x.shape[2]; + x = x.reshape([xShape0 * xShape1, xShape2]); + return tfc.matMul(x, y).reshape([ + xShape0, xShape1, y.shape[1] + ]); + } + else { + throw new errors_1.NotImplementedError("dot support for x of rank " + x.rank + " is not yet implemented: " + + ("x shape = " + x.shape)); + } + } +} +exports.dot = dot; +function sign(x) { + return tfjs_core_1.tidy(function () { + var zerosLikeX = tfjs_core_1.zerosLike(x); + var onesLikeX = tfjs_core_1.onesLike(x); + return tfjs_core_1.where(tfc.equal(x, zerosLikeX), zerosLikeX, tfjs_core_1.where(tfc.greater(x, tfjs_core_1.zerosLike(x)), onesLikeX, tfc.mul(state_1.getScalar(-1), onesLikeX))); + }); +} +exports.sign = sign; +function oneHot(indices, numClasses) { + return tfjs_core_1.tidy(function () { + if (indices.rank !== 1) { + throw new Error('Only 1D one-hot tensors are supported in the ' + + 'deeplearn backend, at present.'); + } + indices = indices.toInt(); + return tfc.oneHot(indices, numClasses).toFloat(); + }); +} +exports.oneHot = oneHot; +function gather(reference, indices, axis) { + return tfjs_core_1.tidy(function () { + if (Array.isArray(indices)) { + indices = tfjs_core_1.tensor1d(indices, 'int32'); + } + else { + indices = indices.toInt(); + } + return tfc.gather(reference, indices, axis); + }); +} +exports.gather = gather; +function square(x) { + return tfc.mulStrict(x, x); +} +exports.square = square; +function pow(x, a) { + return tfjs_core_1.tidy(function () { + if (typeof (a) === 'number') { + a = tfjs_core_1.scalar(Math.round(a), 'int32'); + } + if (a.dtype !== 'int32') { + throw new errors_1.NotImplementedError("Non-int32 dtype (" + a.dtype + ") is not supported by pow() yet"); + } + return tfc.pow(x, a); + }); +} +exports.pow = pow; +function biasAdd(x, bias, dataFormat) { + return tfjs_core_1.tidy(function () { + if (dataFormat == null) { + dataFormat = common_2.imageDataFormat(); + } + common_1.checkDataFormat(dataFormat); + if (bias.rank !== 1 && bias.rank !== x.rank) { + throw new errors_1.ValueError('Unexpected bias dimensions: ' + bias.rank + + '; expected it to be 1 or ' + x.rank); + } + var biasShape = bias.shape; + var y; + if (x.rank === 5) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1, 1, 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[3], biasShape[0], biasShape[1], biasShape[2]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, 1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank === 4) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1, 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[2], biasShape[0], biasShape[1]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank === 3) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[1], biasShape[0]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank < 3) { + y = x.add(bias); + } + else { + throw new errors_1.ValueError("Unsupported input rank by biasAdd: " + x.rank); + } + return y; + }); +} +exports.biasAdd = biasAdd; +function elu(x, alpha) { + if (alpha === void 0) { alpha = 1; } + if (alpha !== 1) { + throw new errors_1.NotImplementedError("Support for alpha values other than 1 (" + alpha + ") is not implemented " + + "yet."); + } + return tfc.elu(x); +} +exports.elu = elu; +function softsign(x) { + return tfjs_core_1.tidy(function () { return tfc.div(x, tfc.add(state_1.getScalar(1), tfc.abs(x))); }); +} +exports.softsign = softsign; +function dropout(x, level, noiseShape, seed) { + return tfjs_core_1.tidy(function () { + if (noiseShape != null && !tfjs_core_1.util.arraysEqual(x.shape, noiseShape)) { + throw new errors_1.NotImplementedError('Non-default noise shape is not implemented yet: ' + + JSON.stringify(noiseShape)); + } + if (seed != null) { + throw new errors_1.NotImplementedError('seed is not implemented for dropout yet.'); + } + var multiplier = tfc.step(tfc.add(tfc.neg(level), tfc.randomUniform(x.shape, 0, 1, 'float32'))); + multiplier = tfc.mul(tfc.div(state_1.getScalar(1), tfc.sub(state_1.getScalar(1), level)), multiplier); + return tfc.mul(x, multiplier); + }); +} +exports.dropout = dropout; +function hardSigmoid(x) { + return tfjs_core_1.tidy(function () { + var y = tfc.add(state_1.getScalar(0.5), tfc.mul(state_1.getScalar(0.2), x)); + return tfc.clipByValue(y, 0, 1); + }); +} +exports.hardSigmoid = hardSigmoid; +function inTrainPhase(x, alt, training) { + if (training === void 0) { training = false; } + return training ? x() : alt(); +} +exports.inTrainPhase = inTrainPhase; +//# sourceMappingURL=tfjs_backend.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js.map b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js.map new file mode 100644 index 0000000..b3e781d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tfjs_backend.js","sourceRoot":"","sources":["../../src/backend/tfjs_backend.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend_test.js.map new file mode 100644 index 0000000..2d8067c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/backend/tfjs_backend_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tfjs_backend_test.js","sourceRoot":"","sources":["../../src/backend/tfjs_backend_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.d.ts new file mode 100644 index 0000000..a584155 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.d.ts @@ -0,0 +1,73 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { Container } from './engine/container'; +import { Logs, UnresolvedLogs } from './logs'; +export declare type Params = { + [key: string]: number | string | boolean | number[] | string[] | boolean[]; +}; +export declare abstract class BaseCallback { + validationData: Tensor | Tensor[]; + params: Params; + setParams(params: Params): void; + onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise; + onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise; + onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise; + onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise; + onTrainBegin(logs?: UnresolvedLogs): Promise; + onTrainEnd(logs?: UnresolvedLogs): Promise; + setModel(model: Container): void; +} +export declare class CallbackList { + callbacks: BaseCallback[]; + queueLength: number; + constructor(callbacks?: BaseCallback[], queueLength?: number); + append(callback: BaseCallback): void; + setParams(params: Params): void; + setModel(model: Container): void; + onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise; + onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise; + onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise; + onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise; + onTrainBegin(logs?: UnresolvedLogs): Promise; + onTrainEnd(logs?: UnresolvedLogs): Promise; +} +export declare class BaseLogger extends BaseCallback { + private seen; + private totals; + constructor(); + onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise; + onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise; + onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise; +} +export declare class History extends BaseCallback { + epoch: number[]; + history: { + [key: string]: Array; + }; + onTrainBegin(logs?: UnresolvedLogs): Promise; + onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise; + syncData(): Promise; +} +export interface CustomCallbackConfig { + onTrainBegin?: (logs?: Logs) => Promise; + onTrainEnd?: (logs?: Logs) => Promise; + onEpochBegin?: (epoch: number, logs?: Logs) => Promise; + onEpochEnd?: (epoch: number, logs?: Logs) => Promise; + onBatchBegin?: (batch: number, logs?: Logs) => Promise; + onBatchEnd?: (batch: number, logs?: Logs) => Promise; +} +export declare class CustomCallback extends BaseCallback { + protected readonly trainBegin: (logs?: Logs) => Promise; + protected readonly trainEnd: (logs?: Logs) => Promise; + protected readonly epochBegin: (epoch: number, logs?: Logs) => Promise; + protected readonly epochEnd: (epoch: number, logs?: Logs) => Promise; + protected readonly batchBegin: (batch: number, logs?: Logs) => Promise; + protected readonly batchEnd: (batch: number, logs?: Logs) => Promise; + constructor(config: CustomCallbackConfig); + onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise; + onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise; + onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise; + onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise; + onTrainBegin(logs?: UnresolvedLogs): Promise; + onTrainEnd(logs?: UnresolvedLogs): Promise; +} +export declare function standardizeCallbacks(callbacks: BaseCallback | BaseCallback[] | CustomCallbackConfig | CustomCallbackConfig[]): BaseCallback[]; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js new file mode 100644 index 0000000..2698fc5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js @@ -0,0 +1,570 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("./backend/state"); +var logs_1 = require("./logs"); +var generic_utils = require("./utils/generic_utils"); +var BaseCallback = (function () { + function BaseCallback() { + this.validationData = null; + } + BaseCallback.prototype.setParams = function (params) { + this.params = params; + }; + BaseCallback.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.setModel = function (model) { + }; + return BaseCallback; +}()); +exports.BaseCallback = BaseCallback; +var CallbackList = (function () { + function CallbackList(callbacks, queueLength) { + if (queueLength === void 0) { queueLength = 10; } + if (callbacks == null) { + callbacks = []; + } + this.callbacks = callbacks; + this.queueLength = queueLength; + } + CallbackList.prototype.append = function (callback) { + this.callbacks.push(callback); + }; + CallbackList.prototype.setParams = function (params) { + for (var _i = 0, _a = this.callbacks; _i < _a.length; _i++) { + var callback = _a[_i]; + callback.setParams(params); + } + }; + CallbackList.prototype.setModel = function (model) { + for (var _i = 0, _a = this.callbacks; _i < _a.length; _i++) { + var callback = _a[_i]; + callback.setModel(model); + } + }; + CallbackList.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onEpochBegin(epoch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onEpochEnd(epoch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onBatchBegin(batch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onBatchEnd(batch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onTrainBegin(logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onTrainEnd(logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + return CallbackList; +}()); +exports.CallbackList = CallbackList; +var BaseLogger = (function (_super) { + __extends(BaseLogger, _super); + function BaseLogger() { + return _super.call(this) || this; + } + BaseLogger.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.seen = 0; + this.totals = {}; + return [2]; + }); + }); + }; + BaseLogger.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var batchSize, _loop_1, this_1, key; + return __generator(this, function (_a) { + if (logs == null) { + logs = {}; + } + batchSize = logs['size'] == null ? 0 : logs['size']; + this.seen += batchSize; + _loop_1 = function (key) { + var value = logs[key]; + if (typeof value === 'number') { + if (!this_1.totals.hasOwnProperty(key)) { + this_1.totals[key] = 0; + } + this_1.totals[key] = this_1.totals[key] + value * batchSize; + } + else { + var oldTotalsToDispose = void 0; + if (key in this_1.totals) { + oldTotalsToDispose = this_1.totals[key]; + } + else { + this_1.totals[key] = state_1.getScalar(0); + } + this_1.totals[key] = tfjs_core_1.tidy(function () { return tfjs_core_1.add(_this.totals[key], tfjs_core_1.mul(value, state_1.getScalar(batchSize))); }); + if (oldTotalsToDispose != null) { + oldTotalsToDispose.dispose(); + } + } + }; + this_1 = this; + for (key in logs) { + _loop_1(key); + } + return [2]; + }); + }); + }; + BaseLogger.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var _loop_2, this_2, _i, _a, key; + return __generator(this, function (_b) { + if (logs != null) { + _loop_2 = function (key) { + if (this_2.totals[key] == null) { + return "continue"; + } + if (typeof this_2.totals[key] === 'number') { + logs[key] = this_2.totals[key] / this_2.seen; + } + else { + tfjs_core_1.tidy(function () { + logs[key] = tfjs_core_1.mul(tfjs_core_1.div(state_1.getScalar(1), state_1.getScalar(_this.seen)), _this.totals[key]); + _this.totals[key].dispose(); + tfjs_core_1.keep(logs[key]); + }); + } + }; + this_2 = this; + for (_i = 0, _a = this.params['metrics']; _i < _a.length; _i++) { + key = _a[_i]; + _loop_2(key); + } + } + return [2]; + }); + }); + }; + return BaseLogger; +}(BaseCallback)); +exports.BaseLogger = BaseLogger; +var History = (function (_super) { + __extends(History, _super); + function History() { + return _super !== null && _super.apply(this, arguments) || this; + } + History.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.epoch = []; + this.history = {}; + return [2]; + }); + }); + }; + History.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var key; + return __generator(this, function (_a) { + if (logs == null) { + logs = {}; + } + this.epoch.push(epoch); + for (key in logs) { + if (this.history[key] == null) { + this.history[key] = []; + } + this.history[key].push(logs[key]); + } + return [2]; + }); + }); + }; + History.prototype.syncData = function () { + return __awaiter(this, void 0, void 0, function () { + var promises, keys, indices, key, valueArray, i, valueScalar, values, n, tensorToDispose; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + promises = []; + keys = []; + indices = []; + for (key in this.history) { + valueArray = this.history[key]; + for (i = 0; i < valueArray.length; ++i) { + if (typeof valueArray[i] !== 'number') { + valueScalar = valueArray[i]; + promises.push(valueScalar.data()); + keys.push(key); + indices.push(i); + } + } + } + return [4, Promise.all(promises)]; + case 1: + values = _a.sent(); + for (n = 0; n < values.length; ++n) { + tensorToDispose = this.history[keys[n]][indices[n]]; + tensorToDispose.dispose(); + this.history[keys[n]][indices[n]] = values[n][0]; + } + return [2]; + } + }); + }); + }; + return History; +}(BaseCallback)); +exports.History = History; +var CustomCallback = (function (_super) { + __extends(CustomCallback, _super); + function CustomCallback(config) { + var _this = _super.call(this) || this; + _this.trainBegin = config.onTrainBegin; + _this.trainEnd = config.onTrainEnd; + _this.epochBegin = config.onEpochBegin; + _this.epochEnd = config.onEpochEnd; + _this.batchBegin = config.onBatchBegin; + _this.batchEnd = config.onBatchEnd; + return _this; + } + CustomCallback.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.epochBegin != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.epochBegin(epoch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.epochEnd != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.epochEnd(epoch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.batchBegin != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.batchBegin(batch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.batchEnd != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.batchEnd(batch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.trainBegin != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.trainBegin(logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.trainEnd != null)) return [3, 3]; + return [4, logs_1.resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.trainEnd(logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + return CustomCallback; +}(BaseCallback)); +exports.CustomCallback = CustomCallback; +function standardizeCallbacks(callbacks) { + if (callbacks == null) { + return null; + } + if (callbacks instanceof BaseCallback) { + return [callbacks]; + } + if (Array.isArray(callbacks) && callbacks[0] instanceof BaseCallback) { + return callbacks; + } + var callbackConfigs = generic_utils.toList(callbacks); + return callbackConfigs.map(function (callbackConfig) { return new CustomCallback(callbackConfig); }); +} +exports.standardizeCallbacks = standardizeCallbacks; +//# sourceMappingURL=base_callbacks.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js.map b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js.map new file mode 100644 index 0000000..40924e6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks.js.map @@ -0,0 +1 @@ +{"version":3,"file":"base_callbacks.js","sourceRoot":"","sources":["../src/base_callbacks.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks_test.js.map new file mode 100644 index 0000000..f78eba8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/base_callbacks_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"base_callbacks_test.js","sourceRoot":"","sources":["../src/base_callbacks_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/callbacks.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.d.ts new file mode 100644 index 0000000..115d7ca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.d.ts @@ -0,0 +1,7 @@ +import { BaseCallback } from './base_callbacks'; +import { Container } from './engine/container'; +import { Model } from './engine/training'; +export declare abstract class Callback extends BaseCallback { + model: Model; + setModel(model: Container): void; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js new file mode 100644 index 0000000..59a42d7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js @@ -0,0 +1,31 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var base_callbacks_1 = require("./base_callbacks"); +var training_1 = require("./engine/training"); +var Callback = (function (_super) { + __extends(Callback, _super); + function Callback() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.model = null; + return _this; + } + Callback.prototype.setModel = function (model) { + if (!(model instanceof training_1.Model)) { + throw new Error('model must be a Model, not some other Container'); + } + this.model = model; + }; + return Callback; +}(base_callbacks_1.BaseCallback)); +exports.Callback = Callback; +//# sourceMappingURL=callbacks.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js.map b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js.map new file mode 100644 index 0000000..a92ad7a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/callbacks.js.map @@ -0,0 +1 @@ +{"version":3,"file":"callbacks.js","sourceRoot":"","sources":["../src/callbacks.ts"],"names":[],"mappings":";;;;;;;;;;;;AAYA,mDAA8C;AAE9C,8CAAwC;AAExC;IAAuC,4BAAY;IAAnD;QAAA,qEAUC;QARC,WAAK,GAAU,IAAI,CAAC;;IAQtB,CAAC;IANC,2BAAQ,GAAR,UAAS,KAAgB;QACvB,IAAI,CAAC,CAAC,KAAK,YAAY,gBAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;SACpE;QACD,IAAI,CAAC,KAAK,GAAG,KAAc,CAAC;IAC9B,CAAC;IACH,eAAC;AAAD,CAAC,AAVD,CAAuC,6BAAY,GAUlD;AAVqB,4BAAQ"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/common.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/common.d.ts new file mode 100644 index 0000000..54cad85 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/common.d.ts @@ -0,0 +1,13 @@ +export declare type DataFormat = 'channelsFirst' | 'channelsLast'; +export declare const VALID_DATA_FORMAT_VALUES: string[]; +export declare function checkDataFormat(value?: string): void; +export declare type PaddingMode = 'valid' | 'same' | 'causal'; +export declare const VALID_PADDING_MODE_VALUES: string[]; +export declare function checkPaddingMode(value?: string): void; +export declare type PoolMode = 'max' | 'avg'; +export declare const VALID_POOL_MODE_VALUES: string[]; +export declare function checkPoolMode(value?: string): void; +export declare function nameScope(name: string, fn: () => T): T; +export declare function getScopedTensorName(tensorName: string): string; +export declare function getUniqueTensorName(scopedName: string): string; +export declare function isValidTensorName(name: string): boolean; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/common.js b/node_modules/@tensorflow/tfjs-layers/dist/common.js new file mode 100644 index 0000000..d75d92b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/common.js @@ -0,0 +1,74 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var generic_utils_1 = require("./utils/generic_utils"); +var nameMap = new Map(); +exports.VALID_DATA_FORMAT_VALUES = ['channelsFirst', 'channelsLast']; +function checkDataFormat(value) { + generic_utils_1.checkStringTypeUnionValue(exports.VALID_DATA_FORMAT_VALUES, 'DataFormat', value); +} +exports.checkDataFormat = checkDataFormat; +exports.VALID_PADDING_MODE_VALUES = ['valid', 'same', 'causal']; +function checkPaddingMode(value) { + generic_utils_1.checkStringTypeUnionValue(exports.VALID_PADDING_MODE_VALUES, 'PaddingMode', value); +} +exports.checkPaddingMode = checkPaddingMode; +exports.VALID_POOL_MODE_VALUES = ['max', 'avg']; +function checkPoolMode(value) { + generic_utils_1.checkStringTypeUnionValue(exports.VALID_POOL_MODE_VALUES, 'PoolMode', value); +} +exports.checkPoolMode = checkPoolMode; +var _nameScopeStack = []; +var _nameScopeDivider = '/'; +function nameScope(name, fn) { + _nameScopeStack.push(name); + try { + var val = fn(); + _nameScopeStack.pop(); + return val; + } + catch (e) { + _nameScopeStack.pop(); + throw e; + } +} +exports.nameScope = nameScope; +function currentNameScopePrefix() { + if (_nameScopeStack.length === 0) { + return ''; + } + else { + return _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider; + } +} +function getScopedTensorName(tensorName) { + if (!isValidTensorName(tensorName)) { + throw new Error('Not a valid tensor name: \'' + tensorName + '\''); + } + return currentNameScopePrefix() + tensorName; +} +exports.getScopedTensorName = getScopedTensorName; +function getUniqueTensorName(scopedName) { + if (!isValidTensorName(scopedName)) { + throw new Error('Not a valid tensor name: \'' + scopedName + '\''); + } + if (!nameMap.has(scopedName)) { + nameMap.set(scopedName, 0); + } + var index = nameMap.get(scopedName); + nameMap.set(scopedName, nameMap.get(scopedName) + 1); + if (index > 0) { + var result = scopedName + '_' + index; + nameMap.set(result, 1); + return result; + } + else { + return scopedName; + } +} +exports.getUniqueTensorName = getUniqueTensorName; +var tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/); +function isValidTensorName(name) { + return name.match(tensorNameRegex) ? true : false; +} +exports.isValidTensorName = isValidTensorName; +//# sourceMappingURL=common.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/common.js.map b/node_modules/@tensorflow/tfjs-layers/dist/common.js.map new file mode 100644 index 0000000..41afc3b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/common.js.map @@ -0,0 +1 @@ +{"version":3,"file":"common.js","sourceRoot":"","sources":["../src/common.ts"],"names":[],"mappings":";;AAaA,uDAAgE;AAIhE,IAAM,OAAO,GAAwB,IAAI,GAAG,EAAkB,CAAC;AAMlD,QAAA,wBAAwB,GAAG,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC;AAC1E,yBAAgC,KAAc;IAC5C,yCAAyB,CAAC,gCAAwB,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;AAC3E,CAAC;AAFD,0CAEC;AAIY,QAAA,yBAAyB,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;AACrE,0BAAiC,KAAc;IAC7C,yCAAyB,CAAC,iCAAyB,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;AAC7E,CAAC;AAFD,4CAEC;AAIY,QAAA,sBAAsB,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AACrD,uBAA8B,KAAc;IAC1C,yCAAyB,CAAC,8BAAsB,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;AACvE,CAAC;AAFD,sCAEC;AAED,IAAM,eAAe,GAAa,EAAE,CAAC;AACrC,IAAM,iBAAiB,GAAG,GAAG,CAAC;AAK9B,mBAA6B,IAAY,EAAE,EAAW;IACpD,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,IAAI;QACF,IAAM,GAAG,GAAM,EAAE,EAAE,CAAC;QACpB,eAAe,CAAC,GAAG,EAAE,CAAC;QACtB,OAAO,GAAG,CAAC;KACZ;IAAC,OAAO,CAAC,EAAE;QACV,eAAe,CAAC,GAAG,EAAE,CAAC;QACtB,MAAM,CAAC,CAAC;KACT;AACH,CAAC;AAVD,8BAUC;AAKD;IACE,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;QAChC,OAAO,EAAE,CAAC;KACX;SAAM;QACL,OAAO,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,iBAAiB,CAAC;KACpE;AACH,CAAC;AAOD,6BAAoC,UAAkB;IACpD,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC;KACpE;IACD,OAAO,sBAAsB,EAAE,GAAG,UAAU,CAAC;AAC/C,CAAC;AALD,kDAKC;AAYD,6BAAoC,UAAkB;IACpD,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC;KACpE;IACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;QAC5B,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;KAC5B;IACD,IAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACtC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IAErD,IAAI,KAAK,GAAG,CAAC,EAAE;QACb,IAAM,MAAM,GAAG,UAAU,GAAG,GAAG,GAAG,KAAK,CAAC;QAGxC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACvB,OAAO,MAAM,CAAC;KACf;SAAM;QACL,OAAO,UAAU,CAAC;KACnB;AACH,CAAC;AAnBD,kDAmBC;AAED,IAAM,eAAe,GAAG,IAAI,MAAM,CAAC,6BAA6B,CAAC,CAAC;AAOlE,2BAAkC,IAAY;IAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;AACpD,CAAC;AAFD,8CAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/common_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/common_test.js.map new file mode 100644 index 0000000..19e0ed7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/common_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"common_test.js","sourceRoot":"","sources":["../src/common_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/constraints.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/constraints.d.ts new file mode 100644 index 0000000..7591604 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/constraints.d.ts @@ -0,0 +1,61 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +export declare abstract class Constraint extends serialization.Serializable { + abstract apply(w: Tensor): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface MaxNormConfig { + maxValue?: number; + axis?: number; +} +export declare class MaxNorm extends Constraint { + static readonly className: string; + private maxValue; + private axis; + private readonly defaultMaxValue; + private readonly defaultAxis; + constructor(config: MaxNormConfig); + apply(w: Tensor): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface UnitNormConfig { + axis?: number; +} +export declare class UnitNorm extends Constraint { + static readonly className: string; + private axis; + private readonly defaultAxis; + constructor(config: UnitNormConfig); + apply(w: Tensor): Tensor; + getConfig(): serialization.ConfigDict; +} +export declare class NonNeg extends Constraint { + static readonly className: string; + apply(w: Tensor): Tensor; +} +export interface MinMaxNormConfig { + minValue?: number; + maxValue?: number; + axis?: number; + rate?: number; +} +export declare class MinMaxNorm extends Constraint { + static readonly className: string; + private minValue; + private maxValue; + private rate; + private axis; + private readonly defaultMinValue; + private readonly defaultMaxValue; + private readonly defaultRate; + private readonly defaultAxis; + constructor(config: MinMaxNormConfig); + apply(w: Tensor): Tensor; + getConfig(): serialization.ConfigDict; +} +export declare type ConstraintIdentifier = 'maxNorm' | 'minMaxNorm' | 'nonNeg' | 'unitNorm' | string; +export declare const CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP: { + [identifier in ConstraintIdentifier]: string; +}; +export declare function serializeConstraint(constraint: Constraint): serialization.ConfigDictValue; +export declare function deserializeConstraint(config: serialization.ConfigDict, customObjects?: serialization.ConfigDict): Constraint; +export declare function getConstraint(identifier: ConstraintIdentifier | serialization.ConfigDict | Constraint): Constraint; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/constraints.js b/node_modules/@tensorflow/tfjs-layers/dist/constraints.js new file mode 100644 index 0000000..d7f13ab --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/constraints.js @@ -0,0 +1,163 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("./backend/common"); +var state_1 = require("./backend/state"); +var generic_utils_1 = require("./utils/generic_utils"); +function calcL2Norms(w, axis) { + return tfjs_core_1.tidy(function () { return tfc.sqrt(tfc.sum(tfc.mulStrict(w, w), axis, true)); }); +} +var Constraint = (function (_super) { + __extends(Constraint, _super); + function Constraint() { + return _super !== null && _super.apply(this, arguments) || this; + } + Constraint.prototype.getConfig = function () { + return {}; + }; + return Constraint; +}(tfjs_core_1.serialization.Serializable)); +exports.Constraint = Constraint; +var MaxNorm = (function (_super) { + __extends(MaxNorm, _super); + function MaxNorm(config) { + var _this = _super.call(this) || this; + _this.defaultMaxValue = 2; + _this.defaultAxis = 0; + _this.maxValue = + config.maxValue != null ? config.maxValue : _this.defaultMaxValue; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + MaxNorm.prototype.apply = function (w) { + var _this = this; + return tfjs_core_1.tidy(function () { + var norms = calcL2Norms(w, _this.axis); + var desired = tfc.clipByValue(norms, 0, _this.maxValue); + return tfc.mul(w, tfc.div(desired, tfc.add(state_1.getScalar(common_1.epsilon()), norms))); + }); + }; + MaxNorm.prototype.getConfig = function () { + return { maxValue: this.maxValue, axis: this.axis }; + }; + MaxNorm.className = 'MaxNorm'; + return MaxNorm; +}(Constraint)); +exports.MaxNorm = MaxNorm; +tfjs_core_1.serialization.SerializationMap.register(MaxNorm); +var UnitNorm = (function (_super) { + __extends(UnitNorm, _super); + function UnitNorm(config) { + var _this = _super.call(this) || this; + _this.defaultAxis = 0; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + UnitNorm.prototype.apply = function (w) { + var _this = this; + return tfjs_core_1.tidy(function () { return tfc.div(w, tfc.add(state_1.getScalar(common_1.epsilon()), calcL2Norms(w, _this.axis))); }); + }; + UnitNorm.prototype.getConfig = function () { + return { axis: this.axis }; + }; + UnitNorm.className = 'UnitNorm'; + return UnitNorm; +}(Constraint)); +exports.UnitNorm = UnitNorm; +tfjs_core_1.serialization.SerializationMap.register(UnitNorm); +var NonNeg = (function (_super) { + __extends(NonNeg, _super); + function NonNeg() { + return _super !== null && _super.apply(this, arguments) || this; + } + NonNeg.prototype.apply = function (w) { + return tfc.relu(w); + }; + NonNeg.className = 'NonNeg'; + return NonNeg; +}(Constraint)); +exports.NonNeg = NonNeg; +tfjs_core_1.serialization.SerializationMap.register(NonNeg); +var MinMaxNorm = (function (_super) { + __extends(MinMaxNorm, _super); + function MinMaxNorm(config) { + var _this = _super.call(this) || this; + _this.defaultMinValue = 0.0; + _this.defaultMaxValue = 1.0; + _this.defaultRate = 1.0; + _this.defaultAxis = 0; + _this.minValue = + config.minValue != null ? config.minValue : _this.defaultMinValue; + _this.maxValue = + config.maxValue != null ? config.maxValue : _this.defaultMaxValue; + _this.rate = config.rate != null ? config.rate : _this.defaultRate; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + MinMaxNorm.prototype.apply = function (w) { + var _this = this; + return tfjs_core_1.tidy(function () { + var norms = calcL2Norms(w, _this.axis); + var desired = tfc.add(tfc.mul(state_1.getScalar(_this.rate), tfc.clipByValue(norms, _this.minValue, _this.maxValue)), tfc.mul(state_1.getScalar(1.0 - _this.rate), norms)); + return tfc.mul(w, tfc.div(desired, tfc.add(state_1.getScalar(common_1.epsilon()), norms))); + }); + }; + MinMaxNorm.prototype.getConfig = function () { + return { + minValue: this.minValue, + maxValue: this.maxValue, + rate: this.rate, + axis: this.axis + }; + }; + MinMaxNorm.className = 'MinMaxNorm'; + return MinMaxNorm; +}(Constraint)); +exports.MinMaxNorm = MinMaxNorm; +tfjs_core_1.serialization.SerializationMap.register(MinMaxNorm); +exports.CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'maxNorm': 'MaxNorm', + 'minMaxNorm': 'MinMaxNorm', + 'nonNeg': 'NonNeg', + 'unitNorm': 'UnitNorm' +}; +function serializeConstraint(constraint) { + return generic_utils_1.serializeKerasObject(constraint); +} +exports.serializeConstraint = serializeConstraint; +function deserializeConstraint(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return generic_utils_1.deserializeKerasObject(config, tfjs_core_1.serialization.SerializationMap.getMap().classNameMap, customObjects, 'constraint'); +} +exports.deserializeConstraint = deserializeConstraint; +function getConstraint(identifier) { + if (identifier == null) { + return null; + } + if (typeof identifier === 'string') { + var className = identifier in exports.CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + exports.CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + var config = { className: className, config: {} }; + return deserializeConstraint(config); + } + else if (identifier instanceof Constraint) { + return identifier; + } + else { + return deserializeConstraint(identifier); + } +} +exports.getConstraint = getConstraint; +//# sourceMappingURL=constraints.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/constraints.js.map b/node_modules/@tensorflow/tfjs-layers/dist/constraints.js.map new file mode 100644 index 0000000..46465f3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/constraints.js.map @@ -0,0 +1 @@ +{"version":3,"file":"constraints.js","sourceRoot":"","sources":["../src/constraints.ts"],"names":[],"mappings":";;;;;;;;;;;;AAaA,2CAA6C;AAC7C,mDAAkE;AAElE,2CAAyC;AACzC,yCAA0C;AAC1C,uDAAmF;AAMnF,qBAAqB,CAAS,EAAE,IAAY;IAC1C,OAAO,gBAAI,CAAC,cAAM,OAAA,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,EAAlD,CAAkD,CAAC,CAAC;AACxE,CAAC;AAYD;IAAyC,8BAA0B;IAAnE;;IAMA,CAAC;IAHC,8BAAS,GAAT;QACE,OAAO,EAAE,CAAC;IACZ,CAAC;IACH,iBAAC;AAAD,CAAC,AAND,CAAyC,yBAAa,CAAC,YAAY,GAMlE;AANqB,gCAAU;AAyChC;IAA6B,2BAAU;IAOrC,iBAAY,MAAqB;QAAjC,YACE,iBAAO,SAIR;QARgB,qBAAe,GAAG,CAAC,CAAC;QACpB,iBAAW,GAAG,CAAC,CAAC;QAI/B,KAAI,CAAC,QAAQ;YACT,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAI,CAAC,eAAe,CAAC;QACrE,KAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,WAAW,CAAC;;IACnE,CAAC;IAED,uBAAK,GAAL,UAAM,CAAS;QAAf,iBAMC;QALC,OAAO,gBAAI,CAAC;YACV,IAAM,KAAK,GAAG,WAAW,CAAC,CAAC,EAAE,KAAI,CAAC,IAAI,CAAC,CAAC;YACxC,IAAM,OAAO,GAAG,GAAG,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,EAAE,KAAI,CAAC,QAAQ,CAAC,CAAC;YACzD,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,CAAC,iBAAS,CAAC,gBAAO,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACL,CAAC;IAED,2BAAS,GAAT;QACE,OAAO,EAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC;IACpD,CAAC;IAvBe,iBAAS,GAAG,SAAS,CAAC;IAwBxC,cAAC;CAAA,AAzBD,CAA6B,UAAU,GAyBtC;AAzBY,0BAAO;AA0BpB,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;AAuBjD;IAA8B,4BAAU;IAItC,kBAAY,MAAsB;QAAlC,YACE,iBAAO,SAER;QAJgB,iBAAW,GAAG,CAAC,CAAC;QAG/B,KAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,WAAW,CAAC;;IACnE,CAAC;IAED,wBAAK,GAAL,UAAM,CAAS;QAAf,iBAIC;QAHC,OAAO,gBAAI,CACP,cAAM,OAAA,GAAG,CAAC,GAAG,CACT,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,iBAAS,CAAC,gBAAO,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC,EAAE,KAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAD1D,CAC0D,CAAC,CAAC;IACxE,CAAC;IAED,4BAAS,GAAT;QACE,OAAO,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC;IAC3B,CAAC;IAhBe,kBAAS,GAAG,UAAU,CAAC;IAiBzC,eAAC;CAAA,AAlBD,CAA8B,UAAU,GAkBvC;AAlBY,4BAAQ;AAmBrB,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAKlD;IAA4B,0BAAU;IAAtC;;IAMA,CAAC;IAHC,sBAAK,GAAL,UAAM,CAAS;QACb,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAJe,gBAAS,GAAG,QAAQ,CAAC;IAKvC,aAAC;CAAA,AAND,CAA4B,UAAU,GAMrC;AANY,wBAAM;AAOnB,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AAoChD;IAAgC,8BAAU;IAWxC,oBAAY,MAAwB;QAApC,YACE,iBAAO,SAOR;QAbgB,qBAAe,GAAG,GAAG,CAAC;QACtB,qBAAe,GAAG,GAAG,CAAC;QACtB,iBAAW,GAAG,GAAG,CAAC;QAClB,iBAAW,GAAG,CAAC,CAAC;QAI/B,KAAI,CAAC,QAAQ;YACT,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAI,CAAC,eAAe,CAAC;QACrE,KAAI,CAAC,QAAQ;YACT,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAI,CAAC,eAAe,CAAC;QACrE,KAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,WAAW,CAAC;QACjE,KAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,WAAW,CAAC;;IACnE,CAAC;IAED,0BAAK,GAAL,UAAM,CAAS;QAAf,iBAUC;QATC,OAAO,gBAAI,CAAC;YACV,IAAM,KAAK,GAAG,WAAW,CAAC,CAAC,EAAE,KAAI,CAAC,IAAI,CAAC,CAAC;YACxC,IAAM,OAAO,GAAG,GAAG,CAAC,GAAG,CACnB,GAAG,CAAC,GAAG,CACH,iBAAS,CAAC,KAAI,CAAC,IAAI,CAAC,EACpB,GAAG,CAAC,WAAW,CAAC,KAAK,EAAE,KAAI,CAAC,QAAQ,EAAE,KAAI,CAAC,QAAQ,CAAC,CAAC,EACzD,GAAG,CAAC,GAAG,CAAC,iBAAS,CAAC,GAAG,GAAG,KAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;YAChD,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,CAAC,iBAAS,CAAC,gBAAO,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACL,CAAC;IAED,8BAAS,GAAT;QACE,OAAO;YACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;IACJ,CAAC;IAvCe,oBAAS,GAAG,YAAY,CAAC;IAwC3C,iBAAC;CAAA,AAzCD,CAAgC,UAAU,GAyCzC;AAzCY,gCAAU;AA0CvB,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;AAQvC,QAAA,yCAAyC,GACD;IAC/C,SAAS,EAAE,SAAS;IACpB,YAAY,EAAE,YAAY;IAC1B,QAAQ,EAAE,QAAQ;IAClB,UAAU,EAAE,UAAU;CACvB,CAAC;AAEN,6BAAoC,UAAsB;IAExD,OAAO,oCAAoB,CAAC,UAAU,CAAC,CAAC;AAC1C,CAAC;AAHD,kDAGC;AAED,+BACI,MAAgC,EAChC,aAA4C;IAA5C,8BAAA,EAAA,kBAA4C;IAC9C,OAAO,sCAAsB,CACzB,MAAM,EAAE,yBAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,YAAY,EAC5D,aAAa,EAAE,YAAY,CAAC,CAAC;AACnC,CAAC;AAND,sDAMC;AAED,uBAA8B,UACmC;IAC/D,IAAI,UAAU,IAAI,IAAI,EAAE;QACtB,OAAO,IAAI,CAAC;KACb;IACD,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;QAClC,IAAM,SAAS,GAAG,UAAU,IAAI,iDAAyC,CAAC,CAAC;YACvE,iDAAyC,CAAC,UAAU,CAAC,CAAC,CAAC;YACvD,UAAU,CAAC;QACf,IAAM,MAAM,GAAG,EAAC,SAAS,WAAA,EAAE,MAAM,EAAE,EAAE,EAAC,CAAC;QACvC,OAAO,qBAAqB,CAAC,MAAM,CAAC,CAAC;KACtC;SAAM,IAAI,UAAU,YAAY,UAAU,EAAE;QAC3C,OAAO,UAAU,CAAC;KACnB;SAAM;QACL,OAAO,qBAAqB,CAAC,UAAU,CAAC,CAAC;KAC1C;AACH,CAAC;AAhBD,sCAgBC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/constraints_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/constraints_test.js.map new file mode 100644 index 0000000..8acfad6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/constraints_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"constraints_test.js","sourceRoot":"","sources":["../src/constraints_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/container.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.d.ts new file mode 100644 index 0000000..7c29564 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.d.ts @@ -0,0 +1,53 @@ +import { Scalar, serialization, Tensor } from '@tensorflow/tfjs-core'; +import { JsonDict, Kwargs, NamedTensorMap, Shape } from '../types'; +import { LayerVariable } from '../variables'; +import { Layer, Node, SymbolicTensor } from './topology'; +export declare function loadWeightsFromJson(weightsJSON: JsonDict, layers: Layer[], skipMismatch?: boolean): void; +export declare function loadWeightsFromNamedTensorMap(weights: NamedTensorMap, layers: Layer[]): void; +export interface ContainerConfig { + inputs: SymbolicTensor | SymbolicTensor[]; + outputs: SymbolicTensor | SymbolicTensor[]; + name?: string; +} +export declare abstract class Container extends Layer { + inputs: SymbolicTensor[]; + outputs: SymbolicTensor[]; + inputLayers: Layer[]; + inputLayersNodeIndices: number[]; + inputLayersTensorIndices: number[]; + outputLayers: Layer[]; + outputLayersNodeIndices: number[]; + outputLayersTensorIndices: number[]; + layers: Layer[]; + layersByDepth: { + [depth: string]: Layer[]; + }; + nodesByDepth: { + [depth: string]: Node[]; + }; + containerNodes: Set; + inputNames: string[]; + outputNames: string[]; + feedInputShapes: Shape[]; + protected internalInputShapes: Shape[]; + protected internalOutputShapes: Shape[]; + protected feedInputNames: string[]; + protected feedOutputNames: string[]; + constructor(config: ContainerConfig); + readonly trainableWeights: LayerVariable[]; + readonly nonTrainableWeights: LayerVariable[]; + readonly weights: LayerVariable[]; + loadWeights(weightsJSON: JsonDict | NamedTensorMap, skipMismatch?: boolean, isNamedTensorMap?: boolean): void; + private updatedConfig(); + toJSON(unused?: any, returnString?: boolean): string | JsonDict; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeMask(inputs: Tensor | Tensor[], mask?: Tensor | Tensor[]): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + protected runInternalGraph(inputs: Tensor[], masks?: Tensor[]): [Tensor[], Tensor[], Shape[]]; + private buildNodeConversionMap(layers); + getLayer(name?: string, index?: number): Layer; + calculateLosses(): Scalar[]; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; + readonly stateful: boolean; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js new file mode 100644 index 0000000..a25306a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js @@ -0,0 +1,895 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var serialization_1 = require("../layers/serialization"); +var generic_utils = require("../utils/generic_utils"); +var serialization_utils_1 = require("../utils/serialization_utils"); +var types_utils = require("../utils/types_utils"); +var variables_1 = require("../variables"); +var version_1 = require("../version"); +var input_layer_1 = require("./input_layer"); +var topology_1 = require("./topology"); +function preprocessWeightsForLoading(layer, weights, originalKerasVersion, originalBackend) { + if (!originalKerasVersion.startsWith('2.')) { + throw new errors_1.ValueError('Unsupported Keras version in weights being loaded: ' + + originalKerasVersion); + } + return weights; +} +function loadTensor(dtype, shape, value) { + var dataType = generic_utils.stringToDType(dtype); + return tfjs_core_1.Tensor.make(shape, { values: shape.length === 0 ? value : tfjs_core_1.util.flatten(value) }, dataType); +} +function loadWeightsFromJson(weightsJSON, layers, skipMismatch) { + if (skipMismatch === void 0) { skipMismatch = false; } + var originalKerasVersion = weightsJSON['keras_version']; + var originalBackend = weightsJSON['backend']; + var layerNames = layers.map(function (layer) { return layer.name; }); + var index = {}; + for (var _i = 0, layers_1 = layers; _i < layers_1.length; _i++) { + var layer = layers_1[_i]; + if (layer.name != null) { + if (index[layer.name] == null) { + index[layer.name] = []; + } + index[layer.name].push(layer); + } + } + var nameToWeights = weightsJSON['weights']; + var weightValueTuples = []; + for (var k = 0; k < layerNames.length; ++k) { + var name_1 = layerNames[k]; + var layerWeights = nameToWeights[name_1]; + if (layerWeights == null) { + layerWeights = []; + } + var weightValues = []; + for (var n = 0; n < layerWeights.length; ++n) { + var weightEntry = layerWeights[n]; + weightValues.push(new variables_1.LayerVariable(loadTensor(weightEntry['dtype'], weightEntry['shape'], weightEntry['value']))); + } + for (var _a = 0, _b = index[name_1]; _a < _b.length; _a++) { + var layer = _b[_a]; + var symbolicWeights = layer.weights; + weightValues = preprocessWeightsForLoading(layer, weightValues, originalKerasVersion, originalBackend); + if (weightValues.length !== symbolicWeights.length) { + if (skipMismatch) { + console.warn("Skipping loading of weights of layer " + layer.name + " " + + ("due to mismatch in number of weights: (" + weightValues.length + " ") + + ("vs " + symbolicWeights.length + ").")); + } + else { + throw new errors_1.ValueError("Layer #" + k + " (named \"" + layer.name + "\") expects " + + (symbolicWeights.length + " weight(s), but the saved weights ") + + ("have " + weightValues.length + " element(s).")); + } + } + for (var i = 0; i < weightValues.length; ++i) { + if (skipMismatch) { + if (!tfjs_core_1.util.arraysEqual(symbolicWeights[i].shape, weightValues[i].shape)) { + console.warn("Skipping loading of weights for layer " + layer.name + " due " + + ("to mismatch in shape (" + symbolicWeights[i].shape + " vs ") + + (weightValues[i].shape + ")")); + continue; + } + } + weightValueTuples.push([symbolicWeights[i], weightValues[i].read()]); + } + } + } + variables_1.batchSetValue(weightValueTuples); +} +exports.loadWeightsFromJson = loadWeightsFromJson; +function loadWeightsFromNamedTensorMap(weights, layers) { + var nameToWeight = {}; + var totalWeightsCount = 0; + for (var _i = 0, layers_2 = layers; _i < layers_2.length; _i++) { + var layer = layers_2[_i]; + for (var _a = 0, _b = layer.weights; _a < _b.length; _a++) { + var weight = _b[_a]; + if (nameToWeight[weight.originalName] != null) { + throw new errors_1.ValueError("Duplicate weight name: " + weight.originalName); + } + nameToWeight[weight.originalName] = weight; + totalWeightsCount++; + } + } + var weightValueTuples = []; + for (var name_2 in weights) { + weightValueTuples.push([nameToWeight[name_2], weights[name_2]]); + delete nameToWeight[name_2]; + } + var unsetNames = []; + for (var name_3 in nameToWeight) { + unsetNames.push(name_3); + } + if (unsetNames.length > 0) { + throw new errors_1.ValueError(unsetNames.length + " of " + totalWeightsCount + " weights are not set: " + + ("" + unsetNames)); + } + variables_1.batchSetValue(weightValueTuples); +} +exports.loadWeightsFromNamedTensorMap = loadWeightsFromNamedTensorMap; +var Container = (function (_super) { + __extends(Container, _super); + function Container(config) { + var _this = _super.call(this, {}) || this; + _this.containerNodes = new Set(); + _this.name = config.name; + if (_this.name == null) { + var prefix = _this.getClassName().toLowerCase(); + _this.name = state_1.getUid(prefix); + } + _this.supportsMasking = false; + _this.trainable = true; + _this.updatable = true; + if (Array.isArray(config.inputs)) { + _this.inputs = config.inputs.slice(); + } + else { + _this.inputs = [config.inputs]; + } + if (Array.isArray(config.outputs)) { + _this.outputs = config.outputs.slice(); + } + else { + _this.outputs = [config.outputs]; + } + if (generic_utils.unique(_this.inputs).length !== _this.inputs.length) { + throw new errors_1.ValueError('The list of inputs passed to the model is ' + + 'redundant. All inputs should only appear once. Found: ' + + _this.inputs.map(function (x) { return x.name; })); + } + if (generic_utils.unique(_this.outputs).length !== _this.outputs.length) { + console.warn('The list of outputs passed to the model is redundant. ' + + 'All outputs should only appear once. Found: ' + + _this.outputs.map(function (x) { return x.name; })); + } + _this.inputLayers = []; + _this.inputLayersNodeIndices = []; + _this.inputLayersTensorIndices = []; + _this.outputLayers = []; + _this.outputLayersNodeIndices = []; + _this.outputLayersTensorIndices = []; + _this.layers = []; + for (var _i = 0, _a = _this.outputs; _i < _a.length; _i++) { + var x = _a[_i]; + var layer = x.sourceLayer; + var nodeIndex = x.nodeIndex; + var tensorIndex = x.tensorIndex; + _this.outputLayers.push(layer); + _this.outputLayersNodeIndices.push(nodeIndex); + _this.outputLayersTensorIndices.push(tensorIndex); + } + for (var _b = 0, _c = _this.inputs; _b < _c.length; _b++) { + var x = _c[_b]; + var layer = x.sourceLayer; + var nodeIndex = x.nodeIndex; + var tensorIndex = x.tensorIndex; + generic_utils.assert(nodeIndex === 0, 'input layer has >1 nodes'); + generic_utils.assert(tensorIndex === 0, 'input layer has >1 tensors'); + _this.inputLayers.push(layer); + _this.inputLayersNodeIndices.push(nodeIndex); + _this.inputLayersTensorIndices.push(tensorIndex); + } + _this.inputNames = []; + _this.outputNames = []; + _this.feedInputShapes = []; + _this.feedInputNames = []; + _this.feedOutputNames = []; + for (var i = 0; i < _this.inputLayers.length; i++) { + var layer = _this.inputLayers[i]; + if (!(layer instanceof input_layer_1.InputLayer)) { + throw new TypeError('Input layers to a Model must be InputLayer objects. ' + + ("Received inputs: " + config.inputs + ". ") + + ("Input " + i + " (0-based) originates ") + + ("from layer type " + layer.getClassName() + ".")); + } + _this.inputNames.push(layer.name); + _this.feedInputShapes.push(layer.batchInputShape); + _this.feedInputNames.push(layer.name); + } + for (var _d = 0, _e = _this.outputLayers; _d < _e.length; _d++) { + var layer = _e[_d]; + _this.outputNames.push(layer.name); + } + _this.internalInputShapes = _this.inputs.map(function (x) { return x.shape; }); + _this.internalOutputShapes = _this.outputs.map(function (x) { return x.shape; }); + var nodesDepths = {}; + var nodeIDToNode = {}; + var layersDepths = {}; + var layerIDToLayer = {}; + var layerIndices = {}; + var nodesInDecreasingDepth = []; + var buildMapOfGraph = function (tensor, finishedNodes, nodesInProgress, layer, nodeIndex, tensorIndex) { + if (layer == null || nodeIndex == null || tensorIndex == null) { + layer = tensor.sourceLayer; + nodeIndex = tensor.nodeIndex; + tensorIndex = tensor.tensorIndex; + } + var node = layer.inboundNodes[nodeIndex]; + if (nodesInProgress.indexOf(node) !== -1) { + throw new errors_1.RuntimeError("The tensor " + tensor.name + " at layer \"" + layer.name + "\" " + + 'is part of a cycle.'); + } + if (finishedNodes.indexOf(node) !== -1) { + return; + } + _this.containerNodes.add(Container.nodeKey(layer, nodeIndex)); + if (!(layer.id in layerIndices)) { + layerIndices[layer.id] = Object.keys(layerIndices).length; + } + if (nodesInProgress.indexOf(node) === -1) { + nodesInProgress.push(node); + } + var numInboundLayers = node.inboundLayers.length; + for (var i = 0; i < numInboundLayers; i++) { + var x = node.inputTensors[i]; + var layer_1 = node.inboundLayers[i]; + var nodeIndex_1 = node.nodeIndices[i]; + var tensorIndex_1 = node.tensorIndices[i]; + buildMapOfGraph(x, finishedNodes, nodesInProgress, layer_1, nodeIndex_1, tensorIndex_1); + } + finishedNodes.push(node); + while (nodesInProgress.indexOf(node) >= 0) { + nodesInProgress.splice(nodesInProgress.indexOf(node), 1); + } + nodesInDecreasingDepth.push(node); + }; + var finishedNodes = []; + var nodesInProgress = []; + for (var _f = 0, _g = _this.outputs; _f < _g.length; _f++) { + var x = _g[_f]; + buildMapOfGraph(x, finishedNodes, nodesInProgress); + } + var reversedNodesInDecreasingDepth = nodesInDecreasingDepth.slice().reverse(); + for (var _h = 0, reversedNodesInDecreasingDepth_1 = reversedNodesInDecreasingDepth; _h < reversedNodesInDecreasingDepth_1.length; _h++) { + var node = reversedNodesInDecreasingDepth_1[_h]; + nodeIDToNode[node.id] = node; + if (!(node.id in nodesDepths)) { + nodesDepths[node.id] = 0; + } + var depth = nodesDepths[node.id]; + var previousDepth = (layersDepths[node.outboundLayer.id] == null ? + 0 : + layersDepths[node.outboundLayer.id]); + depth = Math.max(depth, previousDepth); + layersDepths[node.outboundLayer.id] = depth; + layerIDToLayer[node.outboundLayer.id] = node.outboundLayer; + nodesDepths[node.id] = depth; + for (var i = 0; i < node.inboundLayers.length; i++) { + var inboundLayer = node.inboundLayers[i]; + var nodeIndex = node.nodeIndices[i]; + var inboundNode = inboundLayer.inboundNodes[nodeIndex]; + var previousDepth_1 = (nodesDepths[inboundNode.id] == null ? 0 : + nodesDepths[inboundNode.id]); + nodesDepths[inboundNode.id] = Math.max(depth + 1, previousDepth_1); + nodeIDToNode[inboundNode.id] = inboundNode; + } + } + var nodesByDepth = {}; + for (var nodeID in nodesDepths) { + var depth = nodesDepths[nodeID]; + if (!(depth in nodesByDepth)) { + nodesByDepth[depth] = []; + } + nodesByDepth[depth].push(nodeIDToNode[nodeID]); + } + var layersByDepth = {}; + for (var layerID in layersDepths) { + var depth = layersDepths[layerID]; + if (!(depth in layersByDepth)) { + layersByDepth[depth] = []; + } + layersByDepth[depth].push(layerIDToLayer[layerID]); + } + var depthKeys = Object.keys(layersByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(generic_utils.reverseNumberCompare); + _this.layers = []; + for (var _j = 0, depthKeys_1 = depthKeys; _j < depthKeys_1.length; _j++) { + var depth = depthKeys_1[_j]; + var layersForDepth = layersByDepth[depth]; + layersForDepth.sort(function (a, b) { + var aIndex = layerIndices[a.id]; + var bIndex = layerIndices[b.id]; + if (aIndex < bIndex) { + return -1; + } + if (aIndex > bIndex) { + return 1; + } + return 0; + }); + for (var _k = 0, layersForDepth_1 = layersForDepth; _k < layersForDepth_1.length; _k++) { + var layer = layersForDepth_1[_k]; + _this.layers.push(layer); + } + } + _this.layersByDepth = layersByDepth; + depthKeys = Object.keys(nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(generic_utils.reverseNumberCompare); + var computableTensors = _this.inputs.slice(); + var layersWithCompleteInput = []; + for (var _l = 0, depthKeys_2 = depthKeys; _l < depthKeys_2.length; _l++) { + var depth = depthKeys_2[_l]; + for (var _m = 0, _o = nodesByDepth[depth]; _m < _o.length; _m++) { + var node = _o[_m]; + var layer = node.outboundLayer; + if (layer != null) { + for (var _p = 0, _q = node.inputTensors; _p < _q.length; _p++) { + var x = _q[_p]; + if (computableTensors.indexOf(x) === -1) { + throw new errors_1.RuntimeError("Graph disconnected: cannot obtain value for tensor " + x + + (" at layer \"" + layer.name + "\". ") + + 'The following previous layers were accessed without ' + + ("issue: " + layersWithCompleteInput)); + } + } + for (var _r = 0, _s = node.outputTensors; _r < _s.length; _r++) { + var x = _s[_r]; + computableTensors.push(x); + } + layersWithCompleteInput.push(layer.name); + } + } + } + _this.nodesByDepth = nodesByDepth; + var allNames = _this.layers.map(function (x) { return x.name; }); + var _loop_1 = function (name_4) { + var numOccurrences = allNames.filter(function (x) { return x === name_4; }).length; + if (numOccurrences !== 1) { + throw new errors_1.RuntimeError("The name \"" + name_4 + "\" is used " + numOccurrences + " times " + + 'in the model. All layer names should be unique. Layer names: ' + + JSON.stringify(allNames)); + } + }; + for (var _t = 0, allNames_1 = allNames; _t < allNames_1.length; _t++) { + var name_4 = allNames_1[_t]; + _loop_1(name_4); + } + _this.outboundNodes = []; + _this.inboundNodes = []; + new topology_1.Node({ + outboundLayer: _this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: _this.inputs, + outputTensors: _this.outputs, + inputMasks: _this.inputs.map(function (x) { return null; }), + outputMasks: _this.outputs.map(function (x) { return null; }), + inputShapes: _this.inputs.map(function (x) { return x.shape; }), + outputShapes: _this.outputs.map(function (x) { return x.shape; }) + }); + _this.built = true; + return _this; + } + Object.defineProperty(Container.prototype, "trainableWeights", { + get: function () { + if (this._trainableWeights.length > 0) { + throw new errors_1.ValueError('Container instance unexpectedly contains _trainableWeights.' + + 'The trainable weights of a Container are a union of the ' + + 'trainable weights of its consituent Layers. Its own ' + + '_trainableWeights must remain an empty Array.'); + } + if (!this.trainable) { + return []; + } + var weights = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + weights = weights.concat(layer.trainableWeights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Container.prototype, "nonTrainableWeights", { + get: function () { + var weights = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + weights.push.apply(weights, layer.nonTrainableWeights); + } + if (!this.trainable) { + var trainableWeights = []; + for (var _b = 0, _c = this.layers; _b < _c.length; _b++) { + var layer = _c[_b]; + trainableWeights.push.apply(trainableWeights, layer.trainableWeights); + } + return trainableWeights.concat(weights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Container.prototype, "weights", { + get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Container.prototype.loadWeights = function (weightsJSON, skipMismatch, isNamedTensorMap) { + if (skipMismatch === void 0) { skipMismatch = false; } + if (isNamedTensorMap === void 0) { isNamedTensorMap = false; } + if (isNamedTensorMap) { + loadWeightsFromNamedTensorMap(weightsJSON, this.layers); + } + else { + loadWeightsFromJson(weightsJSON, this.layers, skipMismatch); + } + }; + Container.prototype.updatedConfig = function () { + var theConfig = this.getConfig(); + var modelConfig = { + className: this.getClassName(), + config: theConfig, + kerasVersion: "tfjs-layers " + version_1.version, + backend: 'TensorFlow.js' + }; + return modelConfig; + }; + Container.prototype.toJSON = function (unused, returnString) { + if (returnString === void 0) { returnString = true; } + var modelConfig = serialization_utils_1.convertTsToPythonic(this.updatedConfig()); + return returnString ? JSON.stringify(modelConfig) : modelConfig; + }; + Container.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = generic_utils.toList(inputs); + var masks; + if ('mask' in kwargs) { + masks = generic_utils.toList(kwargs['mask']); + } + else { + masks = generic_utils.pyListRepeat(null, inputs.length); + } + return _this.runInternalGraph(inputs, masks)[0]; + }); + }; + Container.prototype.computeMask = function (inputs, mask) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = generic_utils.toList(inputs); + var masks; + if (mask == null) { + masks = generic_utils.pyListRepeat(null, inputs.length); + } + else { + masks = generic_utils.toList(mask); + } + return _this.runInternalGraph(inputs, masks)[1]; + }); + }; + Container.prototype.computeOutputShape = function (inputShape) { + var inputShapes = types_utils.normalizeShapeList(inputShape); + if (inputShapes.length !== this.inputLayers.length) { + throw new errors_1.ValueError("Invalid inputShape argument " + inputShape + ": " + + ("model has " + this.inputLayers.length + " tensor inputs.")); + } + var layersToOutputShapes = {}; + for (var i = 0; i < inputShapes.length; i++) { + var layer = this.inputLayers[i]; + var inputShape_1 = inputShapes[i]; + var shapeKey = layer.name + '_0_0'; + layersToOutputShapes[shapeKey] = inputShape_1; + } + var depthKeys = Object.keys(this.nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(generic_utils.reverseNumberCompare); + if (depthKeys.length > 1) { + for (var _i = 0, depthKeys_3 = depthKeys; _i < depthKeys_3.length; _i++) { + var depth = depthKeys_3[_i]; + var nodes = this.nodesByDepth[depth]; + for (var _a = 0, nodes_1 = nodes; _a < nodes_1.length; _a++) { + var node = nodes_1[_a]; + var layer = node.outboundLayer; + if (this.inputLayers.map(function (x) { return x.id; }).indexOf(layer.id) !== -1) { + continue; + } + var inputShapes_1 = []; + for (var j = 0; j < node.inboundLayers.length; j++) { + var inboundLayer = node.inboundLayers[j]; + var nodeIndex_2 = node.nodeIndices[j]; + var tensorIndex = node.tensorIndices[j]; + var shapeKey = inboundLayer.name + "_" + nodeIndex_2 + "_" + tensorIndex; + var inputShape_2 = layersToOutputShapes[shapeKey]; + inputShapes_1.push(inputShape_2); + } + var outputShape = layer.computeOutputShape(generic_utils.singletonOrArray(inputShapes_1)); + var outputShapes_1 = types_utils.normalizeShapeList(outputShape); + var nodeIndex = layer.inboundNodes.indexOf(node); + for (var j = 0; j < outputShapes_1.length; j++) { + var shapeKey = layer.name + "_" + nodeIndex + "_" + j; + layersToOutputShapes[shapeKey] = outputShapes_1[j]; + } + } + } + } + var outputShapes = []; + var outputShapeKeys = []; + for (var i = 0; i < this.outputLayers.length; i++) { + var layer = this.outputLayers[i]; + var nodeIndex = this.outputLayersNodeIndices[i]; + var tensorIndex = this.outputLayersTensorIndices[i]; + var shapeKey = layer.name + "_" + nodeIndex + "_" + tensorIndex; + outputShapeKeys.push(shapeKey); + } + for (var i = 0; i < outputShapeKeys.length; i++) { + var key = outputShapeKeys[i]; + generic_utils.assert(key in layersToOutputShapes); + outputShapes.push(layersToOutputShapes[key]); + } + return generic_utils.singletonOrArray(outputShapes); + }; + Container.prototype.runInternalGraph = function (inputs, masks) { + if (masks == null) { + masks = generic_utils.pyListRepeat(null, inputs.length); + } + var tensorMap = {}; + for (var i = 0; i < this.inputs.length; ++i) { + var x = this.inputs[i]; + var y = inputs[i]; + var mask = masks[i]; + tensorMap[x.id] = [y, mask]; + } + var depthKeys = Object.keys(this.nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(generic_utils.reverseNumberCompare); + for (var _i = 0, depthKeys_4 = depthKeys; _i < depthKeys_4.length; _i++) { + var depth = depthKeys_4[_i]; + var nodes = this.nodesByDepth[depth]; + for (var _a = 0, nodes_2 = nodes; _a < nodes_2.length; _a++) { + var node = nodes_2[_a]; + var layer = node.outboundLayer; + var referenceInputTensors = node.inputTensors; + var referenceOutputTensors = node.outputTensors; + var computedData = new Array(); + for (var _b = 0, referenceInputTensors_1 = referenceInputTensors; _b < referenceInputTensors_1.length; _b++) { + var x = referenceInputTensors_1[_b]; + if (x.id in tensorMap) { + computedData.push(tensorMap[x.id]); + } + } + if (computedData.length === referenceInputTensors.length) { + var kwargs = {}; + var computedTensors = void 0; + var computedMasks = void 0; + var outputTensors_1 = void 0; + var outputMasks_1 = void 0; + if (node.callArgs != null) { + kwargs = node.callArgs; + } + if (computedData.length === 1) { + var _c = computedData[0], computedTensor = _c[0], computedMask = _c[1]; + if (kwargs.mask == null) { + kwargs['mask'] = computedMask; + } + outputTensors_1 = + generic_utils.toList(layer.call(computedTensor, kwargs)); + outputMasks_1 = generic_utils.toList(layer.computeMask(computedTensor, computedMask)); + computedTensors = [computedTensor]; + computedMasks = [computedMask]; + } + else { + computedTensors = computedData.map(function (x) { return x[0]; }); + computedMasks = computedData.map(function (x) { return x[1]; }); + if (kwargs.mask == null) { + kwargs['mask'] = computedMasks; + } + outputTensors_1 = + generic_utils.toList(layer.call(computedTensors, kwargs)); + outputMasks_1 = generic_utils.toList(layer.computeMask(computedTensors, computedMasks)); + } + if (layer.activityRegularizer) { + throw new errors_1.NotImplementedError('Model invocation with concrete Tensor value(s) in the ' + + 'presence of activity regularizer(s) is not supported yet.'); + } + for (var i = 0; i < referenceOutputTensors.length; ++i) { + var x = referenceOutputTensors[i]; + var y = outputTensors_1[i]; + var mask = outputMasks_1[i]; + tensorMap[x.id] = [y, mask]; + } + } + } + } + var outputTensors = []; + var outputMasks = []; + var outputShapes = []; + for (var _d = 0, _e = this.outputs; _d < _e.length; _d++) { + var x = _e[_d]; + generic_utils.assert(x.id in tensorMap, "Could not compute output " + x.name + " : " + x.id); + var _f = tensorMap[x.id], tensor = _f[0], mask = _f[1]; + outputShapes.push(tensor.shape); + outputTensors.push(tensor); + outputMasks.push(mask); + } + return [outputTensors, outputMasks, outputShapes]; + }; + Container.prototype.buildNodeConversionMap = function (layers) { + var nodeConversionMap = {}; + var keptNodes; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + keptNodes = layer instanceof Container ? 1 : 0; + for (var originalNodeIndex = 0; originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) { + var nodeKey = Container.nodeKey(layer, originalNodeIndex); + if (nodeKey in this.containerNodes) { + nodeConversionMap[nodeKey] = keptNodes; + keptNodes += 1; + } + } + } + return nodeConversionMap; + }; + Container.prototype.getLayer = function (name, index) { + if (index != null) { + if (this.layers.length <= index) { + throw new errors_1.ValueError("Was asked to retrieve layer at index " + index + ", but model only " + + ("has " + this.layers.length + " layer(s).")); + } + else { + return this.layers[index]; + } + } + else { + if (name == null) { + throw new errors_1.ValueError('Provide either a layer name or layer index'); + } + } + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer.name === name) { + return layer; + } + } + throw new errors_1.ValueError("No such layer: " + name); + }; + Container.prototype.calculateLosses = function () { + var _this = this; + return tfjs_core_1.tidy(function () { + var losses = []; + for (var _i = 0, _a = _this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + for (var nodeIndex = 0; nodeIndex < layer.inboundNodes.length; ++nodeIndex) { + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (_this.containerNodes.has(nodeKey)) { + losses.push.apply(losses, layer.calculateLosses()); + } + } + } + return losses; + }); + }; + Container.prototype.getConfig = function () { + var config = { name: this.name }; + var nodeConversionMap = this.buildNodeConversionMap(this.layers); + var layerConfigs = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + var layerClassName = layer.getClassName(); + var layerConfig = layer.getConfig(); + var filteredInboundNodes = []; + for (var originalNodeIndex = 0; originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) { + var node = layer.inboundNodes[originalNodeIndex]; + var nodeKey = Container.nodeKey(layer, originalNodeIndex); + var kwargs = {}; + if (this.containerNodes.has(nodeKey)) { + if (node.callArgs) { + try { + JSON.stringify(node.callArgs); + kwargs = node.callArgs; + } + catch (err) { + console.warn("Layer " + layer.name + " was passed " + + "non-serializable keyword arguments: " + + (node.callArgs + ". They will not be included ") + + "in the serialized model (and thus will be " + + "missing at deserialization time)."); + kwargs = {}; + } + } + if (node.inboundLayers.length > 0) { + var nodeData = []; + for (var i = 0; i < node.inboundLayers.length; i++) { + var inboundLayer = node.inboundLayers[i]; + var nodeIndex = node.nodeIndices[i]; + var tensorIndex = node.tensorIndices[i]; + var nodeKey_1 = Container.nodeKey(inboundLayer, nodeIndex); + var newNodeIndex = nodeConversionMap[nodeKey_1]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + nodeData.push([inboundLayer.name, newNodeIndex, tensorIndex, kwargs]); + } + filteredInboundNodes.push(nodeData); + } + } + } + layerConfigs.push({ + name: layer.name, + className: layerClassName, + config: layerConfig, + inboundNodes: filteredInboundNodes + }); + } + config['layers'] = layerConfigs; + var modelInputs = []; + for (var i = 0; i < this.inputLayers.length; i++) { + var layer = this.inputLayers[i]; + var nodeIndex = this.inputLayersNodeIndices[i]; + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (!this.containerNodes.has(nodeKey)) { + continue; + } + var newNodeIndex = nodeConversionMap[nodeKey]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + var tensorIndex = this.inputLayersTensorIndices[i]; + modelInputs.push([layer.name, newNodeIndex, tensorIndex]); + } + config['inputLayers'] = modelInputs; + var modelOutputs = []; + for (var i = 0; i < this.outputLayers.length; i++) { + var layer = this.outputLayers[i]; + var nodeIndex = this.outputLayersNodeIndices[i]; + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (!this.containerNodes.has(nodeKey)) { + continue; + } + var newNodeIndex = nodeConversionMap[nodeKey]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + var tensorIndex = this.outputLayersTensorIndices[i]; + modelOutputs.push([layer.name, newNodeIndex, tensorIndex]); + } + config['outputLayers'] = modelOutputs; + return config; + }; + Container.fromConfig = function (cls, config) { + var createdLayers = {}; + var unprocessedNodes = {}; + function addUnprocessedNode(layer, nodeData) { + if (!(layer.name in unprocessedNodes)) { + unprocessedNodes[layer.name] = [nodeData]; + } + else { + unprocessedNodes[layer.name].push(nodeData); + } + } + function processNode(layer, nodeData) { + var inputTensors = []; + var kwargs; + for (var _i = 0, nodeData_1 = nodeData; _i < nodeData_1.length; _i++) { + var inputData = nodeData_1[_i]; + var inboundLayerName = inputData[0]; + var inboundNodeIndex = inputData[1]; + var inboundTensorIndex = inputData[2]; + if (inputData.length === 3) { + kwargs = {}; + } + else if (inputData.length === 4) { + kwargs = inputData[3]; + } + else { + throw new errors_1.ValueError("Improperly formatted model config for layer " + JSON.stringify(layer) + ": " + JSON.stringify(inputData)); + } + if (!(inboundLayerName in createdLayers)) { + addUnprocessedNode(layer, nodeData); + return; + } + var inboundLayer = createdLayers[inboundLayerName]; + if (inboundLayer.inboundNodes.length <= inboundNodeIndex) { + addUnprocessedNode(layer, nodeData); + return; + } + var inboundNode = inboundLayer.inboundNodes[inboundNodeIndex]; + inputTensors.push(inboundNode.outputTensors[inboundTensorIndex]); + } + if (inputTensors.length > 0) { + layer.apply(generic_utils.singletonOrArray(inputTensors), kwargs); + } + } + function processLayer(layerData) { + var layerName = layerData.name; + var layer = serialization_1.deserialize(layerData, config.customObjects != null ? + config.customObjects : + {}); + createdLayers[layerName] = layer; + var inboundNodesData = layerData.inboundNodes; + for (var _i = 0, inboundNodesData_1 = inboundNodesData; _i < inboundNodesData_1.length; _i++) { + var nodeData = inboundNodesData_1[_i]; + if (!(nodeData instanceof Array)) { + throw new errors_1.ValueError("Corrupted configuration, expected array for nodeData: " + nodeData); + } + addUnprocessedNode(layer, nodeData); + } + } + var name = config.name; + var layersFromConfig = config.layers; + for (var _i = 0, layersFromConfig_1 = layersFromConfig; _i < layersFromConfig_1.length; _i++) { + var layerData = layersFromConfig_1[_i]; + processLayer(layerData); + } + while (!generic_utils.isObjectEmpty(unprocessedNodes)) { + for (var _a = 0, layersFromConfig_2 = layersFromConfig; _a < layersFromConfig_2.length; _a++) { + var layerData = layersFromConfig_2[_a]; + var layer = createdLayers[layerData.name]; + if (layer.name in unprocessedNodes) { + for (var _b = 0, _c = unprocessedNodes[layer.name]; _b < _c.length; _b++) { + var nodeData = _c[_b]; + processNode(layer, nodeData); + } + delete unprocessedNodes[layer.name]; + } + } + } + var inputTensors = []; + var outputTensors = []; + var inputLayersFromConfig = config.inputLayers; + for (var _d = 0, inputLayersFromConfig_1 = inputLayersFromConfig; _d < inputLayersFromConfig_1.length; _d++) { + var layerData = inputLayersFromConfig_1[_d]; + var layerName = layerData[0]; + var nodeIndex = layerData[1]; + var tensorIndex = layerData[2]; + generic_utils.assert(layerName in createdLayers); + var layer = createdLayers[layerName]; + var layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors; + inputTensors.push(layerOutputTensors[tensorIndex]); + } + var outputLayersFromConfig = config.outputLayers; + for (var _e = 0, outputLayersFromConfig_1 = outputLayersFromConfig; _e < outputLayersFromConfig_1.length; _e++) { + var layerData = outputLayersFromConfig_1[_e]; + var layerName = layerData[0]; + var nodeIndex = layerData[1]; + var tensorIndex = layerData[2]; + generic_utils.assert(layerName in createdLayers); + var layer = createdLayers[layerName]; + var layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors; + outputTensors.push(layerOutputTensors[tensorIndex]); + } + return new cls({ inputs: inputTensors, outputs: outputTensors, name: name }); + }; + Object.defineProperty(Container.prototype, "stateful", { + get: function () { + if (this._stateful) { + throw new errors_1.ValueError('Container instance unexpectedly has _stateful = true. The ' + + 'statefulness of a Container is determined by the Layers it ' + + 'contains. Its _stateful property must remain the default false.'); + } + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer.stateful) { + return true; + } + } + return false; + }, + enumerable: true, + configurable: true + }); + return Container; +}(topology_1.Layer)); +exports.Container = Container; +//# sourceMappingURL=container.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js.map new file mode 100644 index 0000000..ff1b553 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/container.js.map @@ -0,0 +1 @@ +{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/engine/container.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/container_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/container_test.js.map new file mode 100644 index 0000000..ae2c9c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/container_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"container_test.js","sourceRoot":"","sources":["../../src/engine/container_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.d.ts new file mode 100644 index 0000000..95dc946 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.d.ts @@ -0,0 +1,16 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { Kwargs } from '../types'; +import { SymbolicTensor } from './topology'; +export interface Feed { + key: SymbolicTensor; + value: Tensor; +} +export declare class FeedDict { + private id2Value; + constructor(feeds?: Feed[] | FeedDict); + add(key: SymbolicTensor, value: Tensor): FeedDict; + addFeed(feed: Feed): void; + hasKey(key: SymbolicTensor): boolean; + getValue(key: SymbolicTensor): Tensor; +} +export declare function execute(fetches: SymbolicTensor | SymbolicTensor[], feedDict: FeedDict, kwargs?: Kwargs): Tensor | Tensor[] | [Tensor | Tensor[]]; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js new file mode 100644 index 0000000..31a2d53 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js @@ -0,0 +1,133 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var errors_1 = require("../errors"); +var input_layer_1 = require("./input_layer"); +function assertFeedCompatibility(key, val) { + if (key.shape != null) { + if (key.shape.length !== val.shape.length) { + throw new errors_1.ValueError("The rank of feed (" + val.shape.length + ") does not match the rank of " + + ("the key (" + key.shape.length + ").")); + } + for (var i = 0; i < key.shape.length; ++i) { + if (key.shape[i] != null && key.shape[i] !== val.shape[i]) { + throw new errors_1.ValueError("The " + i + "-th dimension of the feed (" + val.shape[i] + ") is " + + ("incompatible with that of the key (" + key.shape[i] + ").")); + } + } + } + if (key.dtype == null || key.dtype === val.dtype) { + return val; + } + try { + return tfjs_core_1.cast(val, key.dtype); + } + catch (err) { + throw new errors_1.ValueError("The dtype of the feed (" + val.dtype + ") can not be cast to the dtype " + + ("of the key '" + key.name + "' (" + key.dtype + ").")); + } +} +var FeedDict = (function () { + function FeedDict(feeds) { + this.id2Value = {}; + if (feeds instanceof FeedDict) { + for (var id in feeds.id2Value) { + this.id2Value[id] = feeds.id2Value[id]; + } + } + else { + if (feeds == null) { + return; + } + for (var _i = 0, feeds_1 = feeds; _i < feeds_1.length; _i++) { + var feed = feeds_1[_i]; + this.add(feed.key, feed.value); + } + } + } + FeedDict.prototype.add = function (key, value) { + if (this.id2Value[key.id] == null) { + this.id2Value[key.id] = assertFeedCompatibility(key, value); + } + else { + throw new errors_1.ValueError("Duplicate key: name=" + key.name + ", id=" + key.id); + } + return this; + }; + FeedDict.prototype.addFeed = function (feed) { + this.add(feed.key, feed.value); + }; + FeedDict.prototype.hasKey = function (key) { + return this.id2Value[key.id] != null; + }; + FeedDict.prototype.getValue = function (key) { + if (this.id2Value[key.id] == null) { + throw new errors_1.ValueError("Nonexistent key: " + JSON.stringify(key)); + } + else { + return this.id2Value[key.id]; + } + }; + return FeedDict; +}()); +exports.FeedDict = FeedDict; +function execute(fetches, feedDict, kwargs) { + var arrayFetches = Array.isArray(fetches); + var fetchArray = arrayFetches ? fetches : [fetches]; + var outputs = []; + var internalFeedDict = new FeedDict(feedDict); + for (var _i = 0, fetchArray_1 = fetchArray; _i < fetchArray_1.length; _i++) { + var fetch_1 = fetchArray_1[_i]; + outputs.push(executeInternal(fetch_1, internalFeedDict, kwargs)); + } + return arrayFetches ? outputs : outputs[0]; +} +exports.execute = execute; +function executeInternal(fetch, internalFeedDict, kwargs) { + if (internalFeedDict.hasKey(fetch)) { + return internalFeedDict.getValue(fetch); + } + if (fetch.sourceLayer instanceof input_layer_1.InputLayer) { + throw new errors_1.ValueError("Missing a feed value for SymbolicTensor from InputLayer " + + ("'" + input_layer_1.InputLayer.name + "'")); + } + var inputs = fetch.inputs; + var inputValues = []; + for (var _i = 0, inputs_1 = inputs; _i < inputs_1.length; _i++) { + var input = inputs_1[_i]; + var inputVal = executeInternal(input, internalFeedDict, kwargs); + inputValues.push(inputVal); + } + var output = fetch.sourceLayer.apply(inputValues, kwargs); + if (!Array.isArray(output)) { + output = [output]; + } + var layerOutputs = getNodeOutputs(fetch); + var outputSymbolicTensors = Array.isArray(layerOutputs) ? layerOutputs : [layerOutputs]; + for (var i = 0; i < outputSymbolicTensors.length; ++i) { + internalFeedDict.add(outputSymbolicTensors[i], output[i]); + } + return output.length === 1 ? output[0] : output[fetch.outputTensorIndex]; +} +function getNodeOutputs(fetch) { + var layerOutputs; + if (fetch.sourceLayer.inboundNodes.length === 1) { + layerOutputs = fetch.sourceLayer.output; + } + else { + var nodeIndex = null; + for (var i = 0; i < fetch.sourceLayer.inboundNodes.length; ++i) { + for (var _i = 0, _a = fetch.sourceLayer.inboundNodes[i] + .outputTensors; _i < _a.length; _i++) { + var outputTensor = _a[_i]; + if (outputTensor.id === fetch.id) { + nodeIndex = i; + break; + } + } + } + layerOutputs = fetch.sourceLayer.getOutputAt(nodeIndex); + } + return layerOutputs; +} +//# sourceMappingURL=executor.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js.map new file mode 100644 index 0000000..0854310 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor.js.map @@ -0,0 +1 @@ +{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/engine/executor.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/executor_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor_test.js.map new file mode 100644 index 0000000..ba39397 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/executor_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"executor_test.js","sourceRoot":"","sources":["../../src/engine/executor_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.d.ts new file mode 100644 index 0000000..584aaf7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.d.ts @@ -0,0 +1,26 @@ +import { DataType, serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Kwargs, Shape } from '../types'; +import { Layer, SymbolicTensor } from './topology'; +export interface InputLayerConfig { + inputShape?: Shape; + batchSize?: number; + batchInputShape?: Shape; + dtype?: DataType; + sparse?: boolean; + name?: string; +} +export declare class InputLayer extends Layer { + static readonly className: string; + sparse: boolean; + constructor(config: InputLayerConfig); + apply(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], kwargs?: Kwargs): Tensor | Tensor[] | SymbolicTensor; + getConfig(): serialization.ConfigDict; +} +export interface InputConfig { + shape?: Shape; + batchShape?: Shape; + name?: string; + dtype?: DataType; + sparse?: boolean; +} +export declare function Input(config: InputConfig): SymbolicTensor; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js new file mode 100644 index 0000000..8fb69e3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js @@ -0,0 +1,120 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var topology_1 = require("./topology"); +var InputLayer = (function (_super) { + __extends(InputLayer, _super); + function InputLayer(config) { + var _this = _super.call(this, { + dtype: config.dtype, + name: config.name != null ? config.name : state_1.getUid('input').toString() + }) || this; + if (config.batchSize == null) { + config.batchSize = null; + } + if (config.sparse == null) { + config.sparse = false; + } + _this.trainable = false; + _this.built = true; + _this.sparse = config.sparse; + if (config.inputShape != null && config.batchInputShape != null) { + throw new errors_1.ValueError('Only provide the inputShape OR ' + + 'batchInputShape argument to inputLayer, not both at the same time.'); + } + var batchInputShape = config.batchInputShape; + if (batchInputShape == null) { + if (config.inputShape == null) { + throw new errors_1.ValueError('An InputLayer should be passed either a ' + + '`batchInputShape` or an `inputShape`.'); + } + else { + batchInputShape = [config.batchSize].concat(config.inputShape); + } + } + else { + if (config.batchSize != null) { + throw new errors_1.ValueError('Cannot specify batchSize if batchInputShape is' + + 'specified when creating an InputLayer.'); + } + } + var dtype = config.dtype || 'float32'; + _this.batchInputShape = batchInputShape; + _this.dtype = dtype; + _this.inputSpec = [{ shape: batchInputShape }]; + var inputTensor = new topology_1.SymbolicTensor(_this.dtype, _this.batchInputShape, _this, [], {}, _this.name); + inputTensor.nodeIndex = 0; + inputTensor.tensorIndex = 0; + new topology_1.Node({ + outboundLayer: _this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: [inputTensor], + outputTensors: [inputTensor], + inputMasks: [null], + outputMasks: [null], + inputShapes: [batchInputShape], + outputShapes: [batchInputShape] + }); + return _this; + } + InputLayer.prototype.apply = function (inputs, kwargs) { + throw new errors_1.ValueError('Cannot pass any input to an ' + + ("InputLayer's apply() method. InputLayer name: " + this.name)); + }; + InputLayer.prototype.getConfig = function () { + return { + batchInputShape: this.batchInputShape, + dtype: this.dtype, + sparse: this.sparse, + name: this.name + }; + }; + InputLayer.className = 'InputLayer'; + return InputLayer; +}(topology_1.Layer)); +exports.InputLayer = InputLayer; +tfjs_core_1.serialization.SerializationMap.register(InputLayer); +function Input(config) { + if (config.batchShape == null && config.shape == null) { + throw new Error('Please provide to Input either a `shape`' + + ' or a `batchShape` argument. Note that ' + + '`shape` does not include the batch ' + + 'dimension.'); + } + if (config.batchShape != null && config.shape != null) { + throw new errors_1.ValueError('Please provide either a `shape` or `batchShape` ' + + 'argument to Input, but not both.'); + } + var batchShape = config.batchShape; + if (config.shape != null && batchShape == null) { + batchShape = [null].concat(config.shape); + } + var dtype = config.dtype; + if (dtype == null) { + dtype = 'float32'; + } + var inputLayer = new InputLayer({ + batchInputShape: batchShape, + name: config.name, + dtype: dtype, + sparse: config.sparse + }); + var outputs = inputLayer.inboundNodes[0].outputTensors; + return outputs[0]; +} +exports.Input = Input; +//# sourceMappingURL=input_layer.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js.map new file mode 100644 index 0000000..dc67374 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"input_layer.js","sourceRoot":"","sources":["../../src/engine/input_layer.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer_test.js.map new file mode 100644 index 0000000..0ac33e9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/input_layer_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"input_layer_test.js","sourceRoot":"","sources":["../../src/engine/input_layer_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.d.ts new file mode 100644 index 0000000..278d9a3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.d.ts @@ -0,0 +1,139 @@ +import { DataType, Scalar, serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Constraint } from '../constraints'; +import { Initializer } from '../initializers'; +import { Regularizer } from '../regularizers'; +import { Kwargs, RegularizerFn, Shape } from '../types'; +import { LayerVariable } from '../variables'; +export declare type Op = (x: LayerVariable) => LayerVariable; +export interface InputSpecConfig { + dtype?: DataType; + shape?: Shape; + ndim?: number; + maxNDim?: number; + minNDim?: number; + axes?: { + [axis: number]: number; + }; +} +export declare class InputSpec { + dtype?: DataType; + shape?: Shape; + ndim?: number; + maxNDim?: number; + minNDim?: number; + axes?: { + [axis: number]: number; + }; + constructor(config: InputSpecConfig); +} +export declare class SymbolicTensor { + readonly dtype: DataType; + readonly shape: Shape; + sourceLayer: Layer; + readonly inputs: SymbolicTensor[]; + readonly callArgs: Kwargs; + readonly outputTensorIndex: number; + readonly id: number; + readonly name: string; + readonly originalName?: string; + readonly rank: number; + nodeIndex: number; + tensorIndex: number; + constructor(dtype: DataType, shape: Shape, sourceLayer: Layer, inputs: SymbolicTensor[], callArgs: Kwargs, name?: string, outputTensorIndex?: number); +} +export interface NodeConfig { + outboundLayer: Layer; + inboundLayers: Layer[]; + nodeIndices: number[]; + tensorIndices: number[]; + inputTensors: SymbolicTensor[]; + outputTensors: SymbolicTensor[]; + inputMasks: Tensor[]; + outputMasks: Tensor[]; + inputShapes: Shape | Shape[]; + outputShapes: Shape | Shape[]; +} +export declare class Node { + callArgs: Kwargs; + outboundLayer: Layer; + inboundLayers: Layer[]; + nodeIndices: number[]; + tensorIndices: number[]; + inputTensors: SymbolicTensor[]; + outputTensors: SymbolicTensor[]; + inputMasks: Tensor[]; + outputMasks: Tensor[]; + inputShapes: Shape | Shape[]; + outputShapes: Shape | Shape[]; + readonly id: number; + constructor(config: NodeConfig, callArgs?: Kwargs); + getConfig(): serialization.ConfigDict; +} +export interface LayerConfig { + inputShape?: Shape; + batchInputShape?: Shape; + batchSize?: number; + dtype?: DataType; + name?: string; + trainable?: boolean; + updatable?: boolean; + weights?: Tensor[]; + inputDType?: DataType; +} +export declare type CallHook = (inputs: Tensor | Tensor[], kwargs: Kwargs) => void; +export declare abstract class Layer extends serialization.Serializable { + name: string; + inputSpec: InputSpec[]; + supportsMasking: boolean; + trainable: boolean; + updatable: boolean; + batchInputShape: Shape; + dtype: DataType; + initialWeights: Tensor[]; + inboundNodes: Node[]; + outboundNodes: Node[]; + activityRegularizer: Regularizer; + protected _trainableWeights: LayerVariable[]; + private _nonTrainableWeights; + private _losses; + private _updates; + private _built; + private _callHook; + private _addedWeightNames; + readonly id: number; + protected _stateful: boolean; + constructor(config: LayerConfig); + protected static nodeKey(layer: Layer, nodeIndex: number): string; + private getNodeAtIndex(nodeIndex, attrName); + getInputAt(nodeIndex: number): SymbolicTensor | SymbolicTensor[]; + getOutputAt(nodeIndex: number): SymbolicTensor | SymbolicTensor[]; + readonly input: SymbolicTensor | SymbolicTensor[]; + readonly output: SymbolicTensor | SymbolicTensor[]; + readonly losses: RegularizerFn[]; + calculateLosses(): Scalar[]; + readonly updates: Tensor[]; + built: boolean; + trainableWeights: LayerVariable[]; + nonTrainableWeights: LayerVariable[]; + readonly weights: LayerVariable[]; + readonly stateful: boolean; + protected assertInputCompatibility(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + protected invokeCallHook(inputs: Tensor | Tensor[], kwargs: Kwargs): void; + setCallHook(callHook: CallHook): void; + clearCallHook(): void; + apply(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], kwargs?: Kwargs): Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[]; + protected warnOnIncompatibleInputShape(inputShape: Shape): void; + readonly outputShape: Shape | Shape[]; + countParams(): number; + build(inputShape: Shape | Shape[]): void; + getWeights(trainableOnly?: boolean): Tensor[]; + setWeights(weights: Tensor[]): void; + protected addWeight(name: string, shape: Shape, dtype?: DataType, initializer?: Initializer, regularizer?: Regularizer, trainable?: boolean, constraint?: Constraint): LayerVariable; + addLoss(losses: RegularizerFn | RegularizerFn[]): void; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + computeMask(inputs: Tensor | Tensor[], mask?: Tensor | Tensor[]): Tensor | Tensor[]; + private addInboundNode(inputTensors, outputTensors, inputMasks, outputMasks, inputShapes, outputShapes, kwargs?); + getConfig(): serialization.ConfigDict; +} +export declare function getSourceInputs(tensor: SymbolicTensor, layer?: Layer, nodeIndex?: number): SymbolicTensor[]; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js new file mode 100644 index 0000000..7e22609 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js @@ -0,0 +1,701 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var common_1 = require("../common"); +var errors_1 = require("../errors"); +var generic_utils = require("../utils/generic_utils"); +var types_utils = require("../utils/types_utils"); +var variable_utils = require("../utils/variable_utils"); +var variables_1 = require("../variables"); +var InputSpec = (function () { + function InputSpec(config) { + this.dtype = config.dtype; + this.shape = config.shape; + if (config.shape != null) { + this.ndim = config.shape.length; + } + else { + this.ndim = config.ndim; + } + this.maxNDim = config.maxNDim; + this.minNDim = config.minNDim; + this.axes = config.axes || {}; + } + return InputSpec; +}()); +exports.InputSpec = InputSpec; +var SymbolicTensor = (function () { + function SymbolicTensor(dtype, shape, sourceLayer, inputs, callArgs, name, outputTensorIndex) { + this.dtype = dtype; + this.shape = shape; + this.sourceLayer = sourceLayer; + this.inputs = inputs; + this.callArgs = callArgs; + this.outputTensorIndex = outputTensorIndex; + this.id = state_1.getNextUniqueTensorId(); + if (name != null) { + this.originalName = common_1.getScopedTensorName(name); + this.name = common_1.getUniqueTensorName(this.originalName); + } + this.rank = shape.length; + } + return SymbolicTensor; +}()); +exports.SymbolicTensor = SymbolicTensor; +var _nextNodeID = 0; +var Node = (function () { + function Node(config, callArgs) { + this.callArgs = callArgs; + this.id = _nextNodeID++; + this.outboundLayer = config.outboundLayer; + this.inboundLayers = config.inboundLayers; + this.nodeIndices = config.nodeIndices; + this.tensorIndices = config.tensorIndices; + this.inputTensors = config.inputTensors; + this.outputTensors = config.outputTensors; + this.inputMasks = config.inputMasks; + this.outputMasks = config.outputMasks; + this.inputShapes = config.inputShapes; + this.outputShapes = config.outputShapes; + for (var _i = 0, _a = config.inboundLayers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer != null) { + layer.outboundNodes.push(this); + } + } + config.outboundLayer.inboundNodes.push(this); + } + Node.prototype.getConfig = function () { + var inboundNames = []; + for (var _i = 0, _a = this.inboundLayers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer != null) { + inboundNames.push(layer.name); + } + else { + inboundNames.push(null); + } + } + return { + outboundLayer: this.outboundLayer ? this.outboundLayer.name : null, + inboundLayers: inboundNames, + nodeIndices: this.nodeIndices, + tensorIndices: this.tensorIndices + }; + }; + return Node; +}()); +exports.Node = Node; +var _nextLayerID = 0; +var Layer = (function (_super) { + __extends(Layer, _super); + function Layer(config) { + var _this = _super.call(this) || this; + _this._callHook = null; + _this._addedWeightNames = []; + _this._stateful = false; + _this.id = _nextLayerID++; + _this.activityRegularizer = null; + _this.inputSpec = null; + _this.supportsMasking = false; + _this._trainableWeights = []; + _this._nonTrainableWeights = []; + _this._losses = []; + _this._updates = []; + _this._built = false; + _this.inboundNodes = []; + _this.outboundNodes = []; + var name = config.name; + if (!name) { + var prefix = _this.getClassName(); + name = generic_utils.toSnakeCase(prefix) + '_' + state_1.getUid(prefix); + } + _this.name = name; + _this.trainable = config.trainable == null ? true : config.trainable; + _this.updatable = config.updatable == null ? true : config.updatable; + if (config.inputShape != null || config.batchInputShape != null) { + var batchInputShape = void 0; + if (config.batchInputShape != null) { + batchInputShape = config.batchInputShape; + } + else if (config.inputShape != null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + batchInputShape = [batchSize].concat(config.inputShape); + } + _this.batchInputShape = batchInputShape; + var dtype = config.dtype; + if (dtype == null) { + dtype = config.inputDType; + } + if (dtype == null) { + dtype = 'float32'; + } + _this.dtype = dtype; + } + if (config.weights != null) { + _this.initialWeights = config.weights; + } + else { + _this.initialWeights = null; + } + return _this; + } + Layer.nodeKey = function (layer, nodeIndex) { + return layer.name + '_ib-' + nodeIndex.toString(); + }; + Layer.prototype.getNodeAtIndex = function (nodeIndex, attrName) { + if (this.inboundNodes.length === 0) { + throw new errors_1.RuntimeError('The layer has never been called ' + + ("and thus has no defined " + attrName + ".")); + } + if (this.inboundNodes.length <= nodeIndex) { + throw new errors_1.ValueError("Asked to get " + attrName + " at node " + nodeIndex + ", " + + ("but the layer has only " + this.inboundNodes.length + " inbound nodes.")); + } + return this.inboundNodes[nodeIndex]; + }; + Layer.prototype.getInputAt = function (nodeIndex) { + return generic_utils.singletonOrArray(this.getNodeAtIndex(nodeIndex, 'input').inputTensors); + }; + Layer.prototype.getOutputAt = function (nodeIndex) { + return generic_utils.singletonOrArray(this.getNodeAtIndex(nodeIndex, 'output').outputTensors); + }; + Object.defineProperty(Layer.prototype, "input", { + get: function () { + if (this.inboundNodes.length > 1) { + throw new errors_1.AttributeError("Layer " + this.name + + ' has multiple inbound nodes, ' + + 'hence the notion of "layer input" ' + + 'is ill-defined. ' + + 'Use `getInputAt(nodeIndex)` instead.'); + } + else if (this.inboundNodes.length === 0) { + throw new errors_1.AttributeError("Layer " + this.name + + ' is not connected, no input to return.'); + } + return generic_utils.singletonOrArray(this.getNodeAtIndex(0, 'input').inputTensors); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "output", { + get: function () { + if (this.inboundNodes.length === 0) { + throw new errors_1.AttributeError("Layer " + this.name + + ' has no inbound nodes.'); + } + if (this.inboundNodes.length > 1) { + throw new errors_1.AttributeError("Layer " + this.name + + ' has multiple inbound nodes, ' + + 'hence the notion of "layer output" ' + + 'is ill-defined. ' + + 'Use `getOutputAt(nodeIndex)` instead.'); + } + return generic_utils.singletonOrArray(this.getNodeAtIndex(0, 'output').outputTensors); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "losses", { + get: function () { + return this._losses; + }, + enumerable: true, + configurable: true + }); + Layer.prototype.calculateLosses = function () { + return this.losses.map(function (lossFn) { return lossFn(); }); + }; + Object.defineProperty(Layer.prototype, "updates", { + get: function () { + return this._updates; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "built", { + get: function () { + return this._built; + }, + set: function (built) { + this._built = built; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "trainableWeights", { + get: function () { + if (this.trainable) { + return this._trainableWeights; + } + else { + return []; + } + }, + set: function (weights) { + this._trainableWeights = weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "nonTrainableWeights", { + get: function () { + if (!this.trainable) { + return this._trainableWeights.concat(this._nonTrainableWeights); + } + else { + return this._nonTrainableWeights; + } + }, + set: function (weights) { + this._nonTrainableWeights = weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "weights", { + get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "stateful", { + get: function () { + return this._stateful; + }, + enumerable: true, + configurable: true + }); + Layer.prototype.assertInputCompatibility = function (inputs) { + inputs = generic_utils.toList(inputs); + if (this.inputSpec == null || this.inputSpec.length === 0) { + return; + } + var inputSpec = generic_utils.toList(this.inputSpec); + if (inputs.length !== inputSpec.length) { + throw new errors_1.ValueError("Layer " + this.name + " expects " + inputSpec.length + " inputs, " + + ("but it received " + inputs.length + " input tensors. ") + + ("Input received: " + inputs)); + } + for (var inputIndex = 0; inputIndex < inputs.length; inputIndex++) { + var x = inputs[inputIndex]; + var spec = inputSpec[inputIndex]; + if (spec == null) { + continue; + } + var ndim = x.rank; + if (spec.ndim != null) { + if (ndim !== spec.ndim) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + ": " + + ("expected ndim=" + spec.ndim + ", found ndim=" + ndim)); + } + } + if (spec.maxNDim != null) { + if (ndim > spec.maxNDim) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + + (": expected max_ndim=" + spec.maxNDim + ", found ndim=" + ndim)); + } + } + if (spec.minNDim != null) { + if (ndim < spec.minNDim) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + + (": expected min_ndim=" + spec.minNDim + ", found ndim=" + ndim + ".")); + } + } + if (spec.dtype != null) { + if (x.dtype !== spec.dtype) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + " " + + (": expected dtype=" + spec.dtype + ", found dtype=" + x.dtype + ".")); + } + } + if (spec.axes) { + var xShape = x.shape; + for (var key in spec.axes) { + var axis = Number(key); + var value = spec.axes[key]; + var xShapeAtAxis = axis >= 0 ? xShape[axis] : xShape[xShape.length + axis]; + if (value != null && [value, null].indexOf(xShapeAtAxis) === -1) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + + (this.name + ": expected axis " + axis + " of input shape to ") + + ("have value " + value + " but got shape " + xShape + ".")); + } + } + } + if (spec.shape != null) { + for (var i = 0; i < spec.shape.length; ++i) { + var specDim = spec.shape[i]; + var dim = x.shape[i]; + if (specDim != null && dim != null) { + if (specDim !== dim) { + throw new errors_1.ValueError("Input " + inputIndex + " is incompatible with layer " + + (this.name + ": expected shape=" + spec.shape + ", ") + + 'found shape=${xShape}.'); + } + } + } + } + } + }; + Layer.prototype.call = function (inputs, kwargs) { + return inputs; + }; + Layer.prototype.invokeCallHook = function (inputs, kwargs) { + if (this._callHook != null) { + this._callHook(inputs, kwargs); + } + }; + Layer.prototype.setCallHook = function (callHook) { + this._callHook = callHook; + }; + Layer.prototype.clearCallHook = function () { + this._callHook = null; + }; + Layer.prototype.apply = function (inputs, kwargs) { + var _this = this; + kwargs = kwargs || {}; + var inputsList = generic_utils.toList(inputs); + var allAreSymbolic = true; + for (var _i = 0, inputsList_1 = inputsList; _i < inputsList_1.length; _i++) { + var input = inputsList_1[_i]; + if (!(input instanceof SymbolicTensor)) { + allAreSymbolic = false; + break; + } + } + var noneAreSymbolic = true; + for (var _a = 0, inputsList_2 = inputsList; _a < inputsList_2.length; _a++) { + var input = inputsList_2[_a]; + if (input instanceof SymbolicTensor) { + noneAreSymbolic = false; + break; + } + } + if (allAreSymbolic === noneAreSymbolic) { + throw new errors_1.ValueError('Arguments to apply() must be all ' + + 'SymbolicTensors or all Tensors'); + } + return common_1.nameScope(this.name, function () { + if (!_this.built) { + _this.assertInputCompatibility(inputs); + var inputShapes = []; + for (var _i = 0, _a = generic_utils.toList(inputs); _i < _a.length; _i++) { + var xElem = _a[_i]; + inputShapes.push(xElem.shape); + } + _this.build(generic_utils.singletonOrArray(inputShapes)); + _this.built = true; + if (_this.initialWeights) { + _this.setWeights(_this.initialWeights); + } + } + _this.assertInputCompatibility(inputs); + if (noneAreSymbolic) { + var output = _this.call(inputs, kwargs); + var outputList = generic_utils.toList(output); + var outputListCopy = []; + for (var _b = 0, outputList_1 = outputList; _b < outputList_1.length; _b++) { + var x = outputList_1[_b]; + if (inputsList.indexOf(x) !== -1) { + x = x.clone(); + } + outputListCopy.push(x); + } + output = generic_utils.singletonOrArray(outputListCopy); + if (_this.activityRegularizer != null) { + throw new errors_1.NotImplementedError('Layer invocation in the presence of activity ' + + 'regularizer(s) is not supported yet.'); + } + return output; + } + else { + var inputShape = collectInputShape(inputs); + var outputShape = _this.computeOutputShape(inputShape); + var output = void 0; + var outputDType_1 = guessOutputDType(inputs); + _this.warnOnIncompatibleInputShape(Array.isArray(inputs) ? inputShape[0] : + inputShape); + if (outputShape != null && outputShape.length > 0 && + Array.isArray(outputShape[0])) { + output = outputShape + .map(function (shape, index) { return new SymbolicTensor(outputDType_1, shape, _this, generic_utils.toList(inputs), kwargs, _this.name, index); }); + } + else { + output = new SymbolicTensor(outputDType_1, outputShape, _this, generic_utils.toList(inputs), kwargs, _this.name); + } + _this.addInboundNode(inputs, output, null, null, inputShape, outputShape, kwargs); + if (_this.activityRegularizer != null) { + throw new errors_1.NotImplementedError('Layer invocation in the presence of activity ' + + 'regularizer(s) is not supported yet.'); + } + return output; + } + }); + }; + Layer.prototype.warnOnIncompatibleInputShape = function (inputShape) { + if (this.batchInputShape == null) { + return; + } + else if (inputShape.length !== this.batchInputShape.length) { + console.warn("The rank of the input tensor provided (shape: " + + (JSON.stringify(inputShape) + ") does not match that of the ") + + ("batchInputShape (" + JSON.stringify(this.batchInputShape) + ") ") + + ("of the layer " + this.name)); + } + else { + var dimMismatch_1 = false; + this.batchInputShape.forEach(function (dimension, i) { + if (dimension != null && inputShape[i] != null && + inputShape[i] !== dimension) { + dimMismatch_1 = true; + } + }); + if (dimMismatch_1) { + console.warn("The shape of the input tensor " + + ("(" + JSON.stringify(inputShape) + ") does not ") + + ("match the expectation of layer " + this.name + ": ") + + ("" + JSON.stringify(this.batchInputShape))); + } + } + }; + Object.defineProperty(Layer.prototype, "outputShape", { + get: function () { + if (this.inboundNodes == null || this.inboundNodes.length === 0) { + throw new errors_1.AttributeError("The layer " + this.name + " has never been called and thus has no " + + "defined output shape."); + } + var allOutputShapes = []; + for (var _i = 0, _a = this.inboundNodes; _i < _a.length; _i++) { + var node = _a[_i]; + var shapeString = JSON.stringify(node.outputShapes); + if (allOutputShapes.indexOf(shapeString) === -1) { + allOutputShapes.push(shapeString); + } + } + if (allOutputShapes.length === 1) { + var outputShapes = this.inboundNodes[0].outputShapes; + if (Array.isArray(outputShapes) && Array.isArray(outputShapes[0]) && + outputShapes.length === 1) { + return outputShapes[0]; + } + else { + return outputShapes; + } + } + else { + throw new errors_1.AttributeError("The layer " + this.name + " has multiple inbound nodes with different " + + "output shapes. Hence the notion of \"outut shape\" is ill-defined " + + "for the layer."); + } + }, + enumerable: true, + configurable: true + }); + Layer.prototype.countParams = function () { + if (!this.built) { + throw new errors_1.RuntimeError("You tried to call countParams() on " + this.name + ", " + + "but the layer is not built yet. Build it first by calling " + + "build(batchInputShape)."); + } + return variable_utils.countParamsInWeights(this.weights); + }; + Layer.prototype.build = function (inputShape) { + this.built = true; + }; + Layer.prototype.getWeights = function (trainableOnly) { + if (trainableOnly === void 0) { trainableOnly = false; } + return variables_1.batchGetValue(trainableOnly ? this.trainableWeights : this.weights); + }; + Layer.prototype.setWeights = function (weights) { + var _this = this; + tfjs_core_1.tidy(function () { + var params = _this.weights; + if (params.length !== weights.length) { + throw new errors_1.ValueError("You called setWeights(weights) on layer \"" + _this.name + "\" " + + ("with a weight list of length " + weights.length + ", ") + + ("but the layer was expecting " + params.length + " weights. ") + + ("Provided weights: " + weights + "...")); + } + if (params.length === 0) { + return; + } + var weightValueTuples = []; + var paramValues = variables_1.batchGetValue(params); + for (var i = 0; i < paramValues.length; ++i) { + var pv = paramValues[i]; + var p = params[i]; + var w = weights[i]; + if (!tfjs_core_1.util.arraysEqual(pv.shape, w.shape)) { + throw new errors_1.ValueError("Layer weight shape " + pv.shape + " " + + ("not compatible with provided weight shape " + w.shape)); + } + weightValueTuples.push([p, w]); + } + variables_1.batchSetValue(weightValueTuples); + }); + }; + Layer.prototype.addWeight = function (name, shape, dtype, initializer, regularizer, trainable, constraint) { + if (this._addedWeightNames.indexOf(name) !== -1) { + throw new errors_1.ValueError("Duplicate weight name " + name + " for layer " + this.name); + } + this._addedWeightNames.push(name); + if (dtype == null) { + dtype = 'float32'; + } + var weight = new variables_1.LayerVariable(initializer.apply(shape, dtype), dtype, name, trainable, constraint); + if (regularizer != null) { + this.addLoss(function () { return regularizer.apply(weight.read()); }); + } + if (trainable == null) { + trainable = true; + } + if (trainable) { + this._trainableWeights.push(weight); + } + else { + this._nonTrainableWeights.push(weight); + } + return weight; + }; + Layer.prototype.addLoss = function (losses) { + if (losses == null || Array.isArray(losses) && losses.length === 0) { + return; + } + losses = generic_utils.toList(losses); + if (this._losses !== undefined && this._losses !== null) { + (_a = this.losses).push.apply(_a, losses); + } + var _a; + }; + Layer.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + Layer.prototype.computeMask = function (inputs, mask) { + var _this = this; + if (!this.supportsMasking) { + if (mask != null) { + if (Array.isArray(mask)) { + mask.forEach(function (maskElement) { + if (maskElement != null) { + throw new TypeError("Layer " + _this.name + " does not support masking," + + 'but was passed an inputMask.'); + } + }); + } + else { + throw new TypeError("Layer " + this.name + " does not support masking," + + 'but was passed an inputMask.'); + } + } + return null; + } + return mask; + }; + Layer.prototype.addInboundNode = function (inputTensors, outputTensors, inputMasks, outputMasks, inputShapes, outputShapes, kwargs) { + if (kwargs === void 0) { kwargs = null; } + var inputTensorList = generic_utils.toList(inputTensors); + outputTensors = generic_utils.toList(outputTensors); + inputMasks = generic_utils.toList(inputMasks); + outputMasks = generic_utils.toList(outputMasks); + inputShapes = types_utils.normalizeShapeList(inputShapes); + outputShapes = types_utils.normalizeShapeList(outputShapes); + var inboundLayers = []; + var nodeIndices = []; + var tensorIndices = []; + for (var _i = 0, inputTensorList_1 = inputTensorList; _i < inputTensorList_1.length; _i++) { + var x = inputTensorList_1[_i]; + inboundLayers.push(x.sourceLayer); + nodeIndices.push(x.nodeIndex); + tensorIndices.push(x.tensorIndex); + } + new Node({ + outboundLayer: this, + inboundLayers: inboundLayers, + nodeIndices: nodeIndices, + tensorIndices: tensorIndices, + inputTensors: inputTensorList, + outputTensors: outputTensors, + inputMasks: inputMasks, + outputMasks: outputMasks, + inputShapes: inputShapes, + outputShapes: outputShapes + }, kwargs); + for (var i = 0; i < outputTensors.length; i++) { + outputTensors[i].sourceLayer = this; + outputTensors[i].nodeIndex = this.inboundNodes.length - 1; + outputTensors[i].tensorIndex = i; + } + }; + Layer.prototype.getConfig = function () { + var config = { name: this.name, trainable: this.trainable }; + if (this.batchInputShape != null) { + config['batchInputShape'] = this.batchInputShape; + } + if (this.dtype != null) { + config['dtype'] = this.dtype; + } + return config; + }; + return Layer; +}(tfjs_core_1.serialization.Serializable)); +exports.Layer = Layer; +function collectInputShape(inputTensors) { + inputTensors = + generic_utils.toList(inputTensors); + var shapes = []; + for (var _i = 0, inputTensors_1 = inputTensors; _i < inputTensors_1.length; _i++) { + var x = inputTensors_1[_i]; + shapes.push(x.shape); + } + return generic_utils.singletonOrArray(shapes); +} +function guessOutputDType(inputTensors) { + return 'float32'; +} +function getSourceInputs(tensor, layer, nodeIndex) { + if (layer == null || (nodeIndex != null && nodeIndex > 0)) { + layer = tensor.sourceLayer; + nodeIndex = tensor.nodeIndex; + } + if (layer.inboundNodes.length === 0) { + return [tensor]; + } + else { + var node = layer.inboundNodes[nodeIndex]; + if (node.inboundLayers.length === 0) { + return node.inputTensors; + } + else { + var sourceTensors = []; + for (var i = 0; i < node.inboundLayers.length; i++) { + var x = node.inputTensors[i]; + var layer_1 = node.inboundLayers[i]; + var nodeIndex_1 = node.nodeIndices[i]; + var previousSources = getSourceInputs(x, layer_1, nodeIndex_1); + for (var _i = 0, previousSources_1 = previousSources; _i < previousSources_1.length; _i++) { + var x_1 = previousSources_1[_i]; + if (sourceTensors.indexOf(x_1) === -1) { + sourceTensors.push(x_1); + } + } + } + return sourceTensors; + } + } +} +exports.getSourceInputs = getSourceInputs; +//# sourceMappingURL=topology.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js.map new file mode 100644 index 0000000..e1e9d8c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology.js.map @@ -0,0 +1 @@ +{"version":3,"file":"topology.js","sourceRoot":"","sources":["../../src/engine/topology.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/topology_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology_test.js.map new file mode 100644 index 0000000..1a77b6a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/topology_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"topology_test.js","sourceRoot":"","sources":["../../src/engine/topology_test.ts"],"names":[],"mappings":";;;;;;;;;;;;AAWA,mDAAmF;AACnF,8BAAgC;AAChC,8CAAgD;AAEhD,kDAA+F;AAC/F,0CAAwE;AAExE,yCAA+E;AAC/E,uCAA+D;AAG/D;IAA2B,gCAAgB;IAEzC,sBAAY,MAAmB;eAC7B,kBAAM,MAAM,CAAC;IACf,CAAC;IAHM,sBAAS,GAAG,cAAc,CAAC;IAIpC,mBAAC;CAAA,AALD,CAA2B,GAAG,CAAC,MAAM,CAAC,KAAK,GAK1C;AAED,QAAQ,CAAC,WAAW,EAAE;IACpB,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,SAAS,GAAG,IAAI,oBAAS,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;QACxC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;QACxC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC;QACvC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;QAC1C,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;QAC1C,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EACzE;QACE,IAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,IAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC;QACnC,IAAM,SAAS,GAAG,IAAI,oBAAS,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;QAC9D,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEN,EAAE,CAAC,iDAAiD,EAAE;QACpD,IAAM,aAAa,GAAG,EAAC,CAAC,EAAE,CAAC,EAAC,CAAC;QAC7B,IAAM,SAAS,GAAG,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QACvD,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,MAAM,EAAE;IACf,IAAM,iBAAiB,GAAG,eAAe,CAAC;IAC1C,IAAM,gBAAgB,GAAG,cAAc,CAAC;IACxC,IAAM,aAAa,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,iBAAiB,EAAC,CAAC,CAAC;IAClE,IAAM,aAAa,GAAG,CAAC,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,gBAAgB,EAAC,CAAC,CAAC,CAAC;IACnE,IAAM,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC;IACxB,IAAM,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1B,IAAM,YAAY,GAAG,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAC5E,IAAM,aAAa,GACf,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAC9D,IAAM,UAAU,GAAG,CAAC,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,IAAM,WAAW,GAAG,CAAC,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACjC,IAAM,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1B,IAAM,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,IAAM,QAAQ,GAAG,EAAC,IAAI,EAAE,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC;IACpC,IAAM,IAAI,GAAG,IAAI,eAAI,CACjB;QACE,aAAa,eAAA;QACb,aAAa,eAAA;QACb,WAAW,aAAA;QACX,aAAa,eAAA;QACb,YAAY,cAAA;QACZ,aAAa,eAAA;QACb,UAAU,YAAA;QACV,WAAW,aAAA;QACX,WAAW,aAAA;QACX,YAAY,cAAA;KACb,EACD,QAAQ,CAAC,CAAC;IAEd,EAAE,CAAC,iCAAiC,EAAE;QACpC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAChD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC5C,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAChD,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;QAC/C,IAAM,UAAU,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QACpC,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QAC5D,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,UAAU,GAAG,IAAI,eAAI,CACvB;YACE,aAAa,eAAA;YACb,aAAa,eAAA;YACb,WAAW,aAAA;YACX,aAAa,eAAA;YACb,YAAY,cAAA;YACZ,aAAa,eAAA;YACb,UAAU,YAAA;YACV,WAAW,aAAA;YACX,WAAW,aAAA;YACX,YAAY,cAAA;SACb,EACD,QAAQ,CAAC,CAAC;QACd,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,4BAAe,CAAC,OAAO,EAAE;IACvB,QAAQ,CAAC,6BAA6B,EAAE;QAGtC,IAAI,YAAmB,CAAC;QAExB,UAAU,CAAC;YACT,YAAY,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE;YAC3C,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sBAAsB,EAAE;YACzB,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sDAAsD,EAAE;YACzD,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,eAAe,EAAE;YAClB,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE;YACtC,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC,aAAa,EAAE,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yBAAyB,EAAE;YAC5B,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0BAA0B,EAAE;YAC7B,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,QAAQ,EAAE,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE;YACpC,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE;YACrC,MAAM,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2BAA2B,EAAE;YAC9B,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE;YAC/B,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE;YACnC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qCAAqC,EAAE;YACxC,MAAM,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE;YAC3C,MAAM,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE;YAC/B,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sBAAsB,EAAE;YACzB,IAAM,WAAW,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACzC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8BAA8B,EAAE;YACjC,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sEAAsE,EACtE;YACE,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACxD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,uDAAuD;YACnD,oBAAoB,EACxB;YACE,IAAM,IAAI,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,EAAlC,CAAkC,CAAC;iBAC3C,YAAY,CAAC,0BAA0B,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,wDAAwD,EAAE;YAC3D,IAAM,IAAI,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,YAAY,CAAC,eAAe,GAAG,IAAI,CAAC;YACpC,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,gDAAgD,EAAE;YACnD,IAAM,MAAM,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;YACxC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAC/C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YACzD,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,aAAa,EAAE,CAAC;YAC/C,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oCAAoC,EAAE;QAC7C,EAAE,CAAC,oCAAoC,EAAE;YACvC,IAAM,IAAI,GAAG,YAAY,CAAC;YAC1B,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,MAAA,EAAC,CAAC,CAAC;YACvC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACjC,IAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;YACjC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;gCAEQ,SAAS;YAClB,EAAE,CAAC,+CAA+C,EAAE;gBAClD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC;gBAC5C,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;gBAC3C,IAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;gBACjC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpD,CAAC,CAAC,CAAC;QACL,CAAC;QAPD,KAAwB,UAAa,EAAb,MAAC,IAAI,EAAE,KAAK,CAAC,EAAb,cAAa,EAAb,IAAa;YAAhC,IAAM,SAAS,SAAA;oBAAT,SAAS;SAOnB;gCAEU,eAAe;YACxB,EAAE,CAAC,6DAA6D,EAAE;gBAChE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,eAAe,iBAAA,EAAC,CAAC,CAAC;gBAClD,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;gBACvD,IAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;gBACjC,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAChE,CAAC,CAAC,CAAC;QACL,CAAC;QAPD,KAA8B,UAAS,EAAT,MAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAT,cAAS,EAAT,IAAS;YAAlC,IAAM,eAAe,SAAA;oBAAf,eAAe;SAOzB;QAED,EAAE,CAAC,qEAAqE;YACjE,oCAAoC,EACxC;YACE,IAAM,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC;YAC5B,IAAM,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC1B,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,eAAe,iBAAA,EAAE,UAAU,YAAA,EAAC,CAAC,CAAC;YAC9D,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;gCAEM,SAAS,EAAE,UAAU,EAAE,uBAAuB;YAGxD,EAAE,CAAC,wDAAwD,EAAE;gBAC3D,IAAM,KAAK,GAAG,IAAI,YAAY,CAC1B,EAAC,SAAS,EAAE,SAAmB,EAAE,UAAU,EAAE,UAAmB,EAAC,CAAC,CAAC;gBACvE,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,uBAAgC,CAAC,CAAC;YAC1E,CAAC,CAAC,CAAC;QACL,CAAC;QARD,KAA+D,UAErC,EAFqC;YACtD,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACxD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAAC,EAFqC,cAErC,EAFqC,IAErC;YAFf,IAAA,WAAgD,EAA/C,iBAAS,EAAE,kBAAU,EAAE,+BAAuB;oBAA9C,SAAS,EAAE,UAAU,EAAE,uBAAuB;SAQzD;QAED,EAAE,CAAC,gEAAgE,EAAE;YACnE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,UAAU,EAAE,EAAE,EAAC,CAAC,CAAC;YACjD,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACvC,IAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;YACjC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qEAAqE,EACrE;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,eAAe,EAAE,EAAE,EAAC,CAAC,CAAC;YACtD,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,wCAAwC,EAAE;YAC3C,IAAM,OAAO,GAAG,CAAC,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,OAAO,SAAA,EAAC,CAAC,CAAC;YAC1C,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gDAAgD,EAAE;YACnD;gBAA2B,gCAAgB;gBAEzC,sBAAY,MAAmB;oBAA/B,YACE,kBAAM,MAAM,CAAC,SAKd;oBAJC,KAAI,CAAC,SAAS,CACV,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;oBACpE,KAAI,CAAC,SAAS,CACV,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;;gBACtE,CAAC;gBAPM,sBAAS,GAAG,cAAc,CAAC;gBAQpC,mBAAC;aAAA,AATD,CAA2B,GAAG,CAAC,MAAM,CAAC,KAAK,GAS1C;YACD,MAAM,CAAC,cAAM,OAAA,IAAI,YAAY,CAAC,EAAE,CAAC,EAApB,CAAoB,CAAC;iBAC7B,YAAY,CAAC,0BAA0B,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAGH,EAAE,CAAC,sBAAsB,EAAE;QACzB,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QACnC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAGH,IAAM,gBAAgB,GAAG,CAAC,yBAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,IAAM,mBAAmB,GAAG,CAAC,wBAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QACnC,KAAK,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE;QAC/D,eAAe,EACnB;QACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QACnD,KAAK,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEN,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QACnC,KAAK,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAChD,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE;QACpE,eAAe,EACnB;QACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC;QAClD,KAAK,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC1C,KAAK,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAChD,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEN,EAAE,CAAC,uEAAuE;QACnE,gBAAgB,EACpB;QACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QACnD,IAAM,eAAe,GAAG,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACrE,KAAK,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC1C,KAAK,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAChD,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;4BAEK,SAAS;QAClB,EAAE,CAAC,sEAAsE;YAClE,2CAA2C,EAC/C;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,SAAS,WAAA,EAAC,CAAC,CAAC;YAC5C,IAAM,eAAe,GAAG,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;YACrE,KAAK,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;YAC1C,KAAK,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;YAChD,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACR,CAAC;IAVD,KAAwB,UAAa,EAAb,MAAC,IAAI,EAAE,KAAK,CAAC,EAAb,cAAa,EAAb,IAAa;QAAhC,IAAM,SAAS,SAAA;gBAAT,SAAS;KAUnB;IAED,QAAQ,CAAC,4BAA4B,EAAE;QACrC,mBACI,KAAY,EACZ,MAA+D;YAEhE,KAAa,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;QAClD,CAAC;QACD,IAAM,UAAU,GAAG;YACjB,cAAM,OAAA,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAT,CAAS,EAAE,cAAM,OAAA,CAAC,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAX,CAAW;YAClC,cAAM,OAAA,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,EAApD,CAAoD;YAC1D,cAAM,OAAA,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAtD,CAAsD;SAC7D,CAAC;gCAES,MAAM;YACf,EAAE,CAAC,0DAA0D,EAAE;gBAC7D,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,4DAA4D;gBACxD,aAAa,EACjB;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAE,CAAC,CAAC,CAAC;gBACvC,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,+DAA+D,EAC/D;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAE,CAAC,EAAE,IAAI,oBAAS,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC1D,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC;qBACnC,YAAY,CAAC,uBAAuB,CAAC,CAAC;YAC7C,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,+DAA+D,EAC/D;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBAC9C,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,uDAAuD,EAAE;gBAC1D,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBAC9C,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;YAC1E,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,kEAAkE,EAClE;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,yDAAyD,EAAE;gBAC5D,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC;qBACnC,YAAY,CAAC,oBAAoB,CAAC,CAAC;YAC1C,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,kEAAkE,EAClE;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,yDAAyD,EAAE;gBAC5D,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC;qBACnC,YAAY,CAAC,oBAAoB,CAAC,CAAC;YAC1C,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,iEAAiE,EACjE;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,KAAK,EAAE,SAAS,EAAC,CAAC,CAAC,CAAC;gBACvD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAIN,EAAE,CAAC,qEAAqE,EACrE;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,EAAC,CAAC,EAAE,CAAC,EAAC,EAAC,CAAC,CAAC,CAAC;gBACnD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,6DAA6D,EAAE;gBAChE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,EAAC,CAAC,EAAE,CAAC,EAAC,EAAC,CAAC,CAAC,CAAC;gBACnD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;YACzE,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,+DAA+D;gBAC3D,4BAA4B,EAChC;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,EAAC,CAAC,CAAC,CAAC;gBACzD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC;qBACnC,YAAY,CAAC,eAAe,CAAC,CAAC;YACrC,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,iEAAiE,EACjE;gBACE,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC9D,CAAC,CAAC,CAAC;YAEN,EAAE,CAAC,yDAAyD,EAAE;gBAC5D,IAAM,UAAU,GAAG,CAAC,IAAI,oBAAS,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;gBACjD,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC7B,MAAM,CAAC,cAAM,OAAA,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAA1B,CAA0B,CAAC,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;YAC1E,CAAC,CAAC,CAAC;QACL,CAAC;QAxHD,KAAqB,UAAU,EAAV,yBAAU,EAAV,wBAAU,EAAV,IAAU;YAA1B,IAAM,MAAM,mBAAA;oBAAN,MAAM;SAwHhB;IACH,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iCAAiC,EAAE;QAC1C,IAAM,UAAU,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QAC1D,IAAM,WAAW,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QAC5D,IAAM,QAAQ,GAAG,EAAC,CAAC,EAAE,CAAC,EAAC,CAAC;QACxB,IAAM,oBAAoB,GACtB,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC/D,IAAM,cAAc,GAChB,WAAW,CAAC,KAAK,CAAC,oBAAoB,EAAE,QAAQ,CAAuB,CAAC;QAE5E,EAAE,CAAC,2BAA2B,EAAE;YAC9B,MAAM,CAAC,cAAc,YAAY,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gEAAgE,EAAE;YACnE,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iEAAiE;YAC7D,aAAa,EACjB;YACE,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC;YAC9D,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,8DAA8D,EAAE;YACjE,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;YAC/C,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6CAA6C,EAAE;YAChD,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,WAAW,EAAE;YACd,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE;YAC7C,IAAI,mBAA2B,CAAC;YAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;iBACjB,GAAG,CAAC,QAAQ,CAAC,UAAC,OAAe,IAAK,OAAA,mBAAmB,GAAG,OAAO,EAA7B,CAA6B,CAAC,CAAC;YACtE,IAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC;YAC7D,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;YACtC,MAAM,CAAC,mBAAmB,CAAC;iBACtB,OAAO,CAAC,2DAA2D,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2DAA2D,EAAE;YAC9D,IAAI,mBAA2B,CAAC;YAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;iBACjB,GAAG,CAAC,QAAQ,CAAC,UAAC,OAAe,IAAK,OAAA,mBAAmB,GAAG,OAAO,EAA7B,CAA6B,CAAC,CAAC;YACtE,IAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;YACxE,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;YACzC,MAAM,CAAC,mBAAmB,CAAC;iBACtB,OAAO,CACJ,4DAA4D,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE;YAClD,IAAI,mBAA2B,CAAC;YAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;iBACjB,GAAG,CAAC,QAAQ,CAAC,UAAC,OAAe,IAAK,OAAA,mBAAmB,GAAG,OAAO,EAA7B,CAA6B,CAAC,CAAC;YACtE,IAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC;YAC7D,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;YACzC,MAAM,CAAC,mBAAmB,CAAC;iBACtB,OAAO,CAAC,6CAA6C,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gEAAgE,EAAE;YACnE,IAAI,mBAA2B,CAAC;YAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;iBACjB,GAAG,CAAC,QAAQ,CAAC,UAAC,OAAe,IAAK,OAAA,mBAAmB,GAAG,OAAO,EAA7B,CAA6B,CAAC,CAAC;YACtE,IAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;YACrE,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;YACzC,MAAM,CAAC,mBAAmB,CAAC;iBACtB,OAAO,CAAC,0CAA0C,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE;YAC9C,IAAI,mBAA2B,CAAC;YAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;iBACjB,GAAG,CAAC,QAAQ,CAAC,UAAC,OAAe,IAAK,OAAA,mBAAmB,GAAG,OAAO,EAA7B,CAA6B,CAAC,CAAC;YACtE,IAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC;YAC7D,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;YACtC,MAAM,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kCAAkC,EAAE;QAC3C,EAAE,CAAC,mDAAmD,EAAE;YACtD,IAAM,UAAU,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;YAC3D,IAAM,WAAW,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,cAAc,EAAC,CAAC,CAAC;YAC7D,IAAM,kBAAkB,GAAG;gBACzB,IAAI,GAAG,CAAC,cAAc,CAClB,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE,EAAE,uBAAuB,CAAC;gBAChE,IAAI,GAAG,CAAC,cAAc,CAClB,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE,EAAE,wBAAwB,CAAC;aAClE,CAAC;YAGF,MAAM,CAAC,cAAM,OAAA,WAAW,CAAC,KAAK,CAAC,kBAAkB,CAAC,EAArC,CAAqC,CAAC,CAAC,YAAY,EAAE,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,0CAA0C,EAAE;QACnD,EAAE,CAAC,sBAAsB,EAAE;YACzB,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,IAAM,MAAM,GAAG;gBACb,IAAI,GAAG,CAAC,cAAc,CAClB,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,uBAAuB,CAAC;gBAC1D,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aACV,CAAC;YACF,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,KAAK,CAAC,MAAkB,CAAC,EAA/B,CAA+B,CAAC;iBACxC,YAAY,CAAC,4CAA4C,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD;QACrD,eAAe,EACnB;QACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;QACnC,IAAM,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,KAAK,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAEnE,KAAK,CAAE,KAAa,EAAE,oBAAoB,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;YACvD,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,IAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAyB,CAAC;QAC3D,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,KAAK,EAAP,CAAO,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACxD,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,iBAAiB,EAAnB,CAAmB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEN,QAAQ,CAAC,2BAA2B,EAAE;QACpC,EAAE,CAAC,yDAAyD,EAAE;YAC5D,IAAM,OAAO,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE1B,KAAqB,UAA6B,EAA7B,MAAC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,EAA7B,cAA6B,EAA7B,IAA6B;gBAA7C,IAAM,MAAM,SAAA;gBACf,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;gBACnC,IAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAsB,CAAC;gBAExD,MAAM,CAAC,MAAM,YAAY,kBAAM,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,kBAAM,CAAC,CAAC;qBAC5D,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEhB,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAE/B,IAAI,MAAM,YAAY,KAAK,EAAE;oBAC3B,IAAM,UAAU,GAAG,MAAkB,CAAC;oBACtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,+BAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC9C;iBACF;qBAAM;oBACL,+BAAkB,CAAC,MAAM,EAAE,MAAgB,CAAC,CAAC;iBAC9C;gBACD,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACvC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,+CAA+C,EAAE;QACxD,EAAE,CAAC,2CAA2C,EAAE;YAC9C,IAAM,cAAc,GAAG,eAAG,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAM,UAAU,GAAG,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oCAE9C,MAAM;gBACf,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAC,OAAO,EAAE,CAAC,cAAc,CAAC,EAAC,CAAC,CAAC;gBAG5D,KAAK,CAAE,KAAa,EAAE,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;oBAC1C,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;oBACnB,KAAK,CAAC,gBAAgB,GAAG,CAAC,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9D,CAAC,CAAC,CAAC;gBACH,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBACxC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBACpB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBACxC,+BAAkB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,cAAc,CAAC,CAAC;YAC9D,CAAC;YAZD,KAAqB,UAA2B,EAA3B,MAAC,UAAU,EAAE,aAAa,CAAC,EAA3B,cAA2B,EAA3B,IAA2B;gBAA3C,IAAM,MAAM,SAAA;wBAAN,MAAM;aAYhB;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iBAAiB,EAAE;QAC1B,EAAE,CAAC,iEAAiE;YAC7D,gBAAgB,EACpB;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC9C,KAAK,CAAC,KAAK,CAAC,eAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACpB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,0DAA0D;YACtD,gBAAgB,EACpB;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,IAAM,KAAK,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YACnE,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC9C,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACnB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC9C,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,kEAAkE,EAClE;YACE,IAAM,UAAU,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;YAC3D,IAAM,WAAW,GAAG,IAAI,YAAY,CAAC,EAAC,IAAI,EAAE,cAAc,EAAC,CAAC,CAAC;YAC7D,IAAM,YAAY,GACd,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YACzD,IAAM,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACnD,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAE/B,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAClD,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACnD,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACnD,MAAM,CAAC,WAAW,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACpD,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;IACR,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,mBAAmB,EAAE;QAC5B,EAAE,CAAC,wBAAwB,EAAE;YAC3B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YAC3C,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACxE,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yBAAyB,EAAE;YAC5B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,IAAI,EAAC,CAAC,CAAC;YAClE,KAAK,CAAC,KAAK,CACP,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACnE,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sDAAsD,EAAE;YACzD,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YAC3C,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACxE,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACxE,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wDAAwD,EAAE;YAC3D,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YAC3C,KAAK,CAAC,KAAK,CACP,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACnE,KAAK,CAAC,KAAK,CACP,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACnE,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,WAAW,EAAjB,CAAiB,CAAC;iBAC1B,YAAY,CAAC,4BAA4B,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE;YAC/B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YAC3C,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,WAAW,EAAjB,CAAiB,CAAC,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,mBAAmB,EAAE;QAC5B,EAAE,CAAC,qBAAqB,EAAE;YACxB,IAAM,KAAK,GAAG,CAAC,CAAC;YAChB,IAAM,SAAS,GAAG,CAAC,CAAC;YACpB,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,OAAA,EAAC,CAAC,CAAC;YACxC,KAAK,CAAC,KAAK,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;YACnC,IAAM,SAAS,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;YACtC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,KAAK,GAAG,SAAS,GAAG,KAAK,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uBAAuB,EAAE;YAC1B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACnC,KAAK,CAAC,KAAK,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAM,SAAS,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;YACtC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,YAAY,EAAE;QACrB,EAAE,CAAC,sDAAsD;YAClD,qBAAqB,EACzB;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,KAAK,CAAC,gBAAgB,GAAG,CAAC,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5D,IAAM,UAAU,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,UAAU,CAAC;gBAC5B,UAAU,EAAE,UAAU;aACvB,CAAC,EAFW,CAEX,CAAC,CAAC,YAAY,CAAC,8BAA8B,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,qDAAqD;YACjD,qBAAqB,EACzB;YACE,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,IAAM,UAAU,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,KAAK,CAAC,gBAAgB,GAAG,CAAC,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5D,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,CAAC,EAA9B,CAA8B,CAAC;iBACvC,YAAY,CAAC,2CAA2C,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,kBAAkB,EAAE;YACrB,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,IAAM,UAAU,GAAG,gBAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,KAAK,CAAC,gBAAgB,GAAG,CAAC,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACzD,KAAK,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;YAC/B,+BAAkB,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,UAAU,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,sBAAsB,EAAE;QAC/B,EAAE,CAAC,0CAA0C,EAAE;YAC7C,IAAM,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YACnC,IAAM,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;YAClB,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,+BAA+B,EAAE;QACxC,IAAI,KAAyB,CAAC;QAC9B,IAAI,KAAY,CAAC;QACjB,IAAI,MAA0B,CAAC;QAE/B,UAAU,CAAC;YACT,KAAK;gBACD,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,YAAY,CAAC,CAAC;YACvE,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YAC7B,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAuB,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE;YACrC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE;YACtC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wDAAwD,EAAE;YAC3D,IAAM,WAAW,GACb,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC;YACxE,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YACzB,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,KAAK,EAAX,CAAW,CAAC,CAAC,YAAY,CAAC,8BAA8B,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0DAA0D,EAAE;YAC7D,IAAM,WAAW,GACb,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC;YACxE,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YACzB,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,MAAM,EAAZ,CAAY,CAAC,CAAC,YAAY,CAAC,+BAA+B,CAAC,CAAC;QAC3E,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,8BAA8B,EAAE;QACvC,IAAI,KAAyB,CAAC;QAC9B,IAAI,KAAY,CAAC;QACjB,IAAI,MAA0B,CAAC;QAE/B,UAAU,CAAC;YACT,KAAK;gBACD,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,YAAY,CAAC,CAAC;YACvE,KAAK,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;YAC7B,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAuB,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE;YAC5C,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE;YAC9C,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wDAAwD,EAAE;YAC3D,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,EAAnB,CAAmB,CAAC;iBAC5B,YAAY,CAAC,mCAAmC,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yDAAyD,EAAE;YAC5D,MAAM,CAAC,cAAM,OAAA,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,EAApB,CAAoB,CAAC;iBAC7B,YAAY,CAAC,oCAAoC,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAIH,kCAAqB,CAAC,qBAAqB,EAAE;IAC3C,IAAM,WAAW,GACb,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAC,CAAC,CAAC;IAEzE,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QACpE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE;gBACT,YAAY,EAAE;oBACZ;wBACE,MAAM,EAAE,qBAAqB;wBAC7B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;qBAC9C;oBACD;wBACE,MAAM,EAAE,mBAAmB;wBAC3B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,CAAC;wBACZ,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC;qBACtB;iBACF;aACF;SACF,CAAC;QACF,+BAAmB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QAG/C,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAW,EACzD,oBAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,IAAM,WAAW,GACb,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QACrE,IAAM,WAAW,GACb,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QACtE,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;QAClD,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE;gBACT,aAAa,EAAE;oBACb;wBACE,MAAM,EAAE,sBAAsB;wBAC9B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;qBAC9C;oBACD;wBACE,MAAM,EAAE,oBAAoB;wBAC5B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,CAAC;wBACZ,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC;qBACtB;iBACF;gBACD,aAAa,EAAE;oBACb;wBACE,MAAM,EAAE,sBAAsB;wBAC9B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;qBACxB;iBACF;aACF;SACF,CAAC;QACF,+BAAmB,CAAC,WAAW,EAAE,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC;QAG7D,+BAAkB,CACd,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CACxD,EACV,oBAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE;QAChC,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QACpE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE,EAAE;SACd,CAAC;QACF,MAAM,CAAC;YACL,+BAAmB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC;aACG,YAAY,CACT,4DAA4D,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;QAC5B,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QACpE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE;gBACT,YAAY,EAAE;oBACZ;wBACE,MAAM,EAAE,sBAAsB;wBAC9B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;qBAC9C;oBACD;wBACE,MAAM,EAAE,oBAAoB;wBAC5B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,CAAC;wBACZ,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC;qBAChB;iBACF;aACF;SACF,CAAC;QACF,MAAM,CAAC;YACL,+BAAmB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC,YAAY,CAAC,oCAAoC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QACpE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE;gBACT,YAAY,EAAE;oBACZ;wBACE,MAAM,EAAE,sBAAsB;wBAC9B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;qBAC9C;iBAEF;aACF;SACF,CAAC;QACF,MAAM,CAAC;YACL,+BAAmB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC;aACG,YAAY,CACT,4DAA4D,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE;QACxD,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC,CAAC,CAAC;QACpE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG;YAClB,eAAe,EAAE,OAAO;YACxB,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE;gBACT,YAAY,EAAE;oBACZ;wBACE,MAAM,EAAE,sBAAsB;wBAC9B,OAAO,EAAE,SAAS;wBAClB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;wBACf,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;qBAC9C;iBACF;aACF;SACF,CAAC;QACF,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QACvB,+BAAmB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAMxC,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAW,EACzD,oBAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,+BAA+B,EAAE;IACrD,IAAM,WAAW,GACb,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAC,CAAC,CAAC;IAEzE,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QACrE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,eAAe,GAAmB,EAAE,CAAC;QAC3C,eAAe,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;YAC/C,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,eAAe,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,oBAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACzE,yCAA6B,CAAC,eAAe,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QAC7D,+BAAkB,CACd,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,+BAAkB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,oBAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE;QACjC,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAC;QACrE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC9B,IAAM,eAAe,GAAmB,EAAE,CAAC;QAC3C,eAAe,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;YAC/C,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,cAAM,OAAA,yCAA6B,CAAC,eAAe,EAAE,CAAC,UAAU,CAAC,CAAC,EAA5D,CAA4D,CAAC;aACrE,YAAY,CAAC,sCAAsC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/training.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.d.ts new file mode 100644 index 0000000..a53369f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.d.ts @@ -0,0 +1,108 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { io, ModelPredictConfig, Optimizer, Scalar, Tensor, Tensor1D } from '@tensorflow/tfjs-core'; +import { BaseCallback, CustomCallbackConfig, History } from '../base_callbacks'; +import { LossOrMetricFn, NamedTensorMap, Shape } from '../types'; +import { Container, ContainerConfig } from './container'; +export declare function isDataTensor(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; +} | { + [inputName: string]: Tensor[]; +}): boolean; +export declare function isDataArray(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; +}): boolean; +export declare function isDataDict(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; +}): boolean; +export declare function standardizeInputData(data: Tensor | Tensor[] | { + [inputName: string]: Tensor; +}, names: string[], shapes?: Shape[], checkBatchAxis?: boolean, exceptionPrefix?: string): Tensor[]; +export declare function checkArrayLengths(inputs: Tensor[], targets: Tensor[], weights?: Tensor[]): void; +export declare function makeBatches(size: number, batchSize: number): Array<[number, number]>; +export declare function sliceArraysByIndices(arrays: Tensor | Tensor[], indices: Tensor1D): Tensor | Tensor[]; +export declare enum ModelLoggingVerbosity { + SILENT = 0, + VERBOSE = 1, +} +export interface ModelEvaluateConfig { + batchSize?: number; + verbose?: ModelLoggingVerbosity; + sampleWeight?: Tensor; + steps?: number; +} +export interface ModelFitConfig { + batchSize?: number; + epochs?: number; + verbose?: ModelLoggingVerbosity; + callbacks?: BaseCallback[] | CustomCallbackConfig | CustomCallbackConfig[]; + validationSplit?: number; + validationData?: [Tensor | Tensor[], Tensor | Tensor[]] | [Tensor | Tensor[], Tensor | Tensor[], Tensor | Tensor[]]; + shuffle?: boolean; + classWeight?: { + [classIndex: string]: number; + }; + sampleWeight?: Tensor; + initialEpoch?: number; + stepsPerEpoch?: number; + validationSteps?: number; + yieldEvery?: 'batch' | 'epoch' | 'never'; +} +export interface ModelCompileConfig { + optimizer: string | Optimizer; + loss: string | string[] | { + [outputName: string]: string; + } | LossOrMetricFn | LossOrMetricFn[] | { + [outputName: string]: LossOrMetricFn; + }; + metrics?: string[] | { + [outputName: string]: string; + }; +} +export declare class Model extends Container implements tfc.InferenceModel { + static className: string; + optimizer: Optimizer; + loss: string | string[] | { + [outputName: string]: string; + } | LossOrMetricFn | LossOrMetricFn[] | { + [outputName: string]: LossOrMetricFn; + }; + lossFunctions: LossOrMetricFn[]; + private feedOutputShapes; + private feedLossFns; + private collectedTrainableWeights; + private testFunction; + history: History; + stopTraining: boolean; + metrics: string[] | { + [outputName: string]: string; + }; + metricsNames: string[]; + metricsTensors: Array<[LossOrMetricFn, number]>; + constructor(config: ContainerConfig); + summary(lineLength?: number, positions?: number[], printFn?: (message?: any, ...optionalParams: any[]) => void): void; + compile(config: ModelCompileConfig): void; + private checkTrainableWeightsConsistency(); + evaluate(x: Tensor | Tensor[], y: Tensor | Tensor[], config?: ModelEvaluateConfig): Scalar | Scalar[]; + private checkNumSamples(ins, batchSize?, steps?, stepsName?); + execute(inputs: Tensor | Tensor[] | NamedTensorMap, outputs: string | string[]): Tensor | Tensor[]; + private retrieveSymbolicTensors(symbolicTensorNames); + private predictLoop(ins, batchSize?, verbose?); + predict(x: Tensor | Tensor[], config?: ModelPredictConfig): Tensor | Tensor[]; + predictOnBatch(x: Tensor): Tensor | Tensor[]; + protected standardizeUserData(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, y: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, checkBatchAxis?: boolean, batchSize?: number): [Tensor[], Tensor[], Tensor[]]; + private fitLoop(f, ins, outLabels?, batchSize?, epochs?, verbose?, callbacks?, valF?, valIns?, shuffle?, callbackMetrics?, initialEpoch?, stepsPerEpoch?, validationSteps?); + private testLoop(f, ins, batchSize?, verbose?, steps?); + private getDedupedMetricsNames(); + private makeTestFunction(); + fit(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, y: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, config?: ModelFitConfig): Promise; + protected getNamedWeights(config?: io.SaveConfig): NamedTensorMap; + save(handlerOrURL: io.IOHandler | string, config?: io.SaveConfig): Promise; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js new file mode 100644 index 0000000..7d80c41 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js @@ -0,0 +1,1158 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var K = require("../backend/tfjs_backend"); +var base_callbacks_1 = require("../base_callbacks"); +var common_1 = require("../common"); +var errors_1 = require("../errors"); +var logs_1 = require("../logs"); +var losses = require("../losses"); +var Metrics = require("../metrics"); +var optimizers = require("../optimizers"); +var generic_utils_1 = require("../utils/generic_utils"); +var layer_utils_1 = require("../utils/layer_utils"); +var math_utils_1 = require("../utils/math_utils"); +var container_1 = require("./container"); +var executor_1 = require("./executor"); +function isDataTensor(x) { + return x instanceof tfjs_core_1.Tensor; +} +exports.isDataTensor = isDataTensor; +function isDataArray(x) { + return Array.isArray(x); +} +exports.isDataArray = isDataArray; +function isDataDict(x) { + return !isDataTensor(x) && !isDataArray(x); +} +exports.isDataDict = isDataDict; +function standardizeInputData(data, names, shapes, checkBatchAxis, exceptionPrefix) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (exceptionPrefix === void 0) { exceptionPrefix = ''; } + if (names == null || names.length === 0) { + if (data != null) { + var gotUnexpectedData = false; + if (isDataArray(data) && data.length > 0) { + gotUnexpectedData = true; + } + else if (isDataDict(data)) { + for (var key in data) { + if (data.hasOwnProperty(key)) { + gotUnexpectedData = true; + break; + } + } + } + else { + gotUnexpectedData = true; + } + if (gotUnexpectedData) { + throw new errors_1.ValueError("Error when checking model " + exceptionPrefix + " expected no data, " + + ("but got " + data)); + } + } + return []; + } + if (data == null) { + return names.map(function (name) { return null; }); + } + var arrays; + if (isDataDict(data)) { + data = data; + arrays = []; + for (var _i = 0, names_1 = names; _i < names_1.length; _i++) { + var name_1 = names_1[_i]; + if (data[name_1] == null) { + throw new errors_1.ValueError("No data provided for \"" + name_1 + "\". Need data for each key in: " + + ("" + names)); + } + arrays.push(data[name_1]); + } + } + else if (isDataArray(data)) { + data = data; + if (data.length !== names.length) { + throw new errors_1.ValueError("Error when checking model " + exceptionPrefix + ": the Array of " + + "Tensors that you are passing to your model is not the size the " + + ("model expected. Expected to see " + names.length + " Tensor(s), but ") + + ("instead got the following list of Tensor(s): " + data)); + } + arrays = data; + } + else { + data = data; + if (names.length > 1) { + throw new errors_1.ValueError("The model " + exceptionPrefix + " expects " + names.length + " Tensor(s), " + + ("but only received one Tensor. Found: Tensor with shape " + data.shape)); + } + arrays = [data]; + } + for (var i = 0; i < names.length; ++i) { + var array = arrays[i]; + if (array.shape.length === 1) { + arrays[i] = K.expandDims(array, 1); + } + } + if (shapes != null) { + for (var i = 0; i < names.length; ++i) { + if (shapes[i] == null) { + continue; + } + var array = arrays[i]; + if (array.shape.length !== shapes[i].length) { + throw new errors_1.ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have " + shapes[i].length + " dimension(s). but got array with ") + + ("shape " + array.shape)); + } + for (var j = 0; j < shapes[i].length; ++j) { + if (j === 0 && !checkBatchAxis) { + continue; + } + var dim = array.shape[j]; + var refDim = shapes[i][j]; + if (refDim != null && refDim >= 0 && dim !== refDim) { + throw new errors_1.ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have shape [" + shapes[i] + "], but got array with shape ") + + ("[" + array.shape + "].")); + } + } + } + } + return arrays; +} +exports.standardizeInputData = standardizeInputData; +function checkArrayLengths(inputs, targets, weights) { + var setX = generic_utils_1.unique(inputs.map(function (input) { return input.shape[0]; })); + setX.sort(); + var setY = generic_utils_1.unique(targets.map(function (target) { return target.shape[0]; })); + setY.sort(); + if (setX.length > 1) { + throw new errors_1.ValueError("All input Tensors (x) should have the same number of samples. " + + "Got array shapes: " + + ("" + JSON.stringify(inputs.map(function (input) { return input.shape; })))); + } + if (setY.length > 1) { + throw new errors_1.ValueError("All target Tensors (y) should have the same number of samples. " + + "Got array shapes: " + + ("" + JSON.stringify(targets.map(function (target) { return target.shape; })))); + } + if (setX.length > 0 && setY.length > 0 && !tfjs_core_1.util.arraysEqual(setX, setY)) { + throw new errors_1.ValueError("Input Tensors should have the same number of samples as target " + + ("Tensors. Found " + setX[0] + " input sample(s) and " + setY[0] + " target ") + + "sample(s)."); + } +} +exports.checkArrayLengths = checkArrayLengths; +function checkLossAndTargetCompatibility(targets, lossFns, outputShapes) { + var keyLosses = [ + losses.meanSquaredError, losses.binaryCrossentropy, + losses.categoricalCrossentropy + ]; + for (var i = 0; i < targets.length; ++i) { + var y = targets[i]; + var loss = lossFns[i]; + var shape = outputShapes[i]; + if (loss == null) { + continue; + } + if (loss === losses.categoricalCrossentropy) { + if (y.shape[y.shape.length - 1] === 1) { + throw new errors_1.ValueError("You are passing a target array of shape " + y.shape + " while using " + + "a loss 'categorical_crossentropy'. 'categorical_crossentropy'" + + "expects targets to be binary matrices (1s and 0s) of shape " + + "[samples, classes]."); + } + } + if (keyLosses.indexOf(loss) !== -1) { + var slicedYShape = y.shape.slice(1); + var slicedShape = shape.slice(1); + for (var j = 0; j < slicedYShape.length; ++j) { + var targetDim = slicedYShape[j]; + var outDim = slicedShape[j]; + if (outDim != null && targetDim !== outDim) { + throw new errors_1.ValueError("A target Tensor with shape " + y.shape + " was passed for an " + + ("output of shape " + shape + ", while using a loss function that ") + + "expects targets to have the same shape as the output."); + } + } + } + } +} +function makeBatches(size, batchSize) { + var output = []; + var batchStart = 0; + var batchEnd = null; + while (batchStart < size) { + batchEnd = batchStart + batchSize; + if (batchEnd >= size) { + batchEnd = size; + } + output.push([batchStart, batchEnd]); + batchStart = batchEnd; + } + return output; +} +exports.makeBatches = makeBatches; +function sliceArrays(arrays, start, stop) { + if (arrays == null) { + return [null]; + } + else if (Array.isArray(arrays)) { + return arrays.map(function (array) { return K.sliceAlongFirstAxis(array, start, stop - start); }); + } + else { + return K.sliceAlongFirstAxis(arrays, start, stop - start); + } +} +function sliceArraysByIndices(arrays, indices) { + return tfc.tidy(function () { + if (arrays == null) { + return null; + } + else if (Array.isArray(arrays)) { + return arrays.map(function (array) { return sliceArraysByIndices(array, indices); }); + } + else { + return K.gather(arrays, indices.dtype === 'int32' ? indices : indices.toInt()); + } + }); +} +exports.sliceArraysByIndices = sliceArraysByIndices; +function checkInputData(data, names, shapes, checkBatchAxis, exceptionPrefix) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (exceptionPrefix === void 0) { exceptionPrefix = ''; } + var arrays; + if (Array.isArray(data)) { + if (data.length !== names.length) { + throw new errors_1.ValueError("Error when checking model " + exceptionPrefix + ": the Array of " + + "Tensors that you are passing to your model is not the size the " + + ("the model expected. Expected to see " + names.length + " Tensor(s),") + + (" but instead got " + data.length + " Tensors(s).")); + } + arrays = data; + } + else { + if (names.length > 1) { + throw new errors_1.ValueError("The model expects " + names.length + " " + exceptionPrefix + " Tensors, " + + "but only received one Tensor. Found: array with shape " + + (JSON.stringify(data.shape) + ".")); + } + arrays = [data]; + } + if (shapes != null) { + for (var i = 0; i < names.length; ++i) { + if (shapes[i] == null) { + continue; + } + var array = arrays[i]; + if (array.shape.length !== shapes[i].length) { + throw new errors_1.ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have " + shapes[i].length + " dimension(s), but got array with ") + + ("shape " + JSON.stringify(array.shape))); + } + for (var j = 0; j < shapes[i].length; ++j) { + if (j === 0 && !checkBatchAxis) { + continue; + } + var dim = array.shape[j]; + var refDim = shapes[i][j]; + if (refDim != null) { + if (refDim !== dim) { + throw new errors_1.ValueError("Error when checking " + exceptionPrefix + ": expected " + + (names[i] + " to have shape " + JSON.stringify(shapes[i]) + " but ") + + ("got array with shape " + JSON.stringify(array.shape) + ".")); + } + } + } + } + } +} +function collectMetrics(metrics, outputNames) { + if (metrics == null || Array.isArray(metrics) && metrics.length === 0) { + return outputNames.map(function (name) { return []; }); + } + if (Array.isArray(metrics)) { + return outputNames.map(function (name) { return metrics; }); + } + else if (metrics != null) { + var nestedMetrics = []; + for (var _i = 0, outputNames_1 = outputNames; _i < outputNames_1.length; _i++) { + var name_2 = outputNames_1[_i]; + var outputMetrics = metrics.hasOwnProperty(name_2) ? metrics[name_2] : []; + if (!Array.isArray(outputMetrics)) { + outputMetrics = [outputMetrics]; + } + nestedMetrics.push(outputMetrics); + } + return nestedMetrics; + } + else { + throw new TypeError('Type of metrics argument not understood. Expected an Array or ' + + 'Object, found: ' + metrics); + } +} +var ModelLoggingVerbosity; +(function (ModelLoggingVerbosity) { + ModelLoggingVerbosity[ModelLoggingVerbosity["SILENT"] = 0] = "SILENT"; + ModelLoggingVerbosity[ModelLoggingVerbosity["VERBOSE"] = 1] = "VERBOSE"; +})(ModelLoggingVerbosity = exports.ModelLoggingVerbosity || (exports.ModelLoggingVerbosity = {})); +var Model = (function (_super) { + __extends(Model, _super); + function Model(config) { + return _super.call(this, config) || this; + } + Model.prototype.summary = function (lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + if (!this.built) { + throw new errors_1.ValueError("This model has never been called, thus its weights have not been " + + "created yet. So no summary can be displayed. Build the model " + + "first (e.g., by calling it on some test data)."); + } + layer_utils_1.printSummary(this, lineLength, positions, printFn); + }; + Model.prototype.compile = function (config) { + var _this = this; + if (config.loss == null) { + config.loss = []; + } + this.loss = config.loss; + if (typeof config.optimizer === 'string') { + this.optimizer = optimizers.getOptimizer(config.optimizer); + } + else { + if (!(config.optimizer instanceof tfjs_core_1.Optimizer)) { + throw new errors_1.ValueError("User-defined optimizer must be an instance of tf.Optimizer."); + } + this.optimizer = config.optimizer; + } + var lossFunctions = []; + if (!Array.isArray(config.loss) && typeof config.loss !== 'string' && + typeof config.loss !== 'function') { + config.loss = config.loss; + for (var name_3 in config.loss) { + if (this.outputNames.indexOf(name_3) === -1) { + throw new errors_1.ValueError("Unknown entry in loss dictionary: \"" + name_3 + "\". Only expect the " + + ("following keys: " + this.outputNames)); + } + } + for (var name_4 in this.outputNames) { + if (config.loss[name_4] == null) { + console.warn("Output \"" + name_4 + "\" is missing from loss dictionary. We assume " + + "this was done on purpose, and we will not be expecting data " + + ("to be passed to " + name_4 + " during training")); + } + lossFunctions.push(losses.get(config.loss[name_4])); + } + } + else if (Array.isArray(config.loss)) { + if (config.loss.length !== this.outputs.length) { + throw new errors_1.ValueError("When passing an Array as loss, it should have one entry per " + + ("model output. The model has " + this.outputs.length + " output(s), ") + + ("but you passed loss=" + config.loss + ".")); + } + var theLosses = config.loss; + lossFunctions = theLosses.map(function (l) { return losses.get(l); }); + } + else { + var lossFunction_1 = losses.get(config.loss); + this.outputs.map(function (layer) { + lossFunctions.push(lossFunction_1); + }); + } + this.lossFunctions = lossFunctions; + this.feedOutputNames = []; + this.feedOutputShapes = []; + this.feedLossFns = []; + for (var i = 0; i < this.outputs.length; ++i) { + var shape = this.internalOutputShapes[i]; + var name_5 = this.outputNames[i]; + this.feedOutputNames.push(name_5); + this.feedOutputShapes.push(shape); + this.feedLossFns.push(this.lossFunctions[i]); + } + var skipTargetIndices = []; + this.metrics = config.metrics; + this.metricsNames = ['loss']; + this.metricsTensors = []; + common_1.nameScope('loss', function () { + for (var i = 0; i < _this.outputs.length; ++i) { + if (skipTargetIndices.indexOf(i) !== -1) { + continue; + } + var weightedLoss = _this.lossFunctions[i]; + if (_this.outputs.length > 1) { + _this.metricsTensors.push([weightedLoss, i]); + _this.metricsNames.push(_this.outputNames[i] + '_loss'); + } + } + }); + var nestedMetrics = collectMetrics(config.metrics, this.outputNames); + var appendMetric = function (outputIndex, metricName, metricTensor) { + if (_this.outputNames.length > 1) { + metricName = _this.outputNames[outputIndex] + '_' + metricName; + } + _this.metricsNames.push(metricName); + _this.metricsTensors.push([metricTensor, outputIndex]); + }; + common_1.nameScope('metric', function () { + var _loop_1 = function (i) { + if (skipTargetIndices.indexOf(i) !== -1) { + return "continue"; + } + var outputMetrics = nestedMetrics[i]; + var handleMetrics = function (metrics) { + var metricNamePrefix = ''; + var metricName; + var accFn; + var weightedMetricFn; + var _loop_2 = function (metric) { + if (['accuracy', 'acc', 'crossentropy', 'ce'].indexOf(metric) !== + -1) { + var outputShape = _this.internalOutputShapes[i]; + if (outputShape[outputShape.length - 1] === 1 || + _this.lossFunctions[i] === losses.binaryCrossentropy) { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = Metrics.binaryAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = Metrics.binaryCrossentropy; + } + } + else if (_this.lossFunctions[i] === + losses.sparseCategoricalCrossentropy) { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = Metrics.sparseCategoricalAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = Metrics.sparseCategoricalCrossentropy; + } + } + else { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = Metrics.categoricalAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = Metrics.categoricalCrossentropy; + } + } + var suffix = void 0; + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + suffix = 'acc'; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + suffix = 'ce'; + } + weightedMetricFn = accFn; + metricName = metricNamePrefix + suffix; + } + else { + var metricFn = Metrics.get(metric); + weightedMetricFn = metricFn; + metricName = metricNamePrefix + metric; + } + var metricResult; + common_1.nameScope(metricName, function () { + metricResult = weightedMetricFn; + }); + appendMetric(i, metricName, metricResult); + }; + for (var _i = 0, metrics_1 = metrics; _i < metrics_1.length; _i++) { + var metric = metrics_1[_i]; + _loop_2(metric); + } + }; + handleMetrics(outputMetrics); + }; + for (var i = 0; i < _this.outputs.length; ++i) { + _loop_1(i); + } + }); + this.collectedTrainableWeights = this.trainableWeights; + }; + Model.prototype.checkTrainableWeightsConsistency = function () { + if (this.collectedTrainableWeights == null) { + return; + } + if (this.trainableWeights.length !== + this.collectedTrainableWeights.length) { + console.warn('Discrepancy between trainableweights and collected trainable ' + + 'weights. Did you set `model.trainable` without calling ' + + '`model.compile()` afterwards?'); + } + }; + Model.prototype.evaluate = function (x, y, config) { + if (config === void 0) { config = {}; } + var batchSize = config.batchSize == null ? 32 : config.batchSize; + var standardizedOuts = this.standardizeUserData(x, y, true, batchSize); + var ins = standardizedOuts[0].concat(standardizedOuts[1]); + this.makeTestFunction(); + var f = this.testFunction; + var testOuts = this.testLoop(f, ins, batchSize, config.verbose, config.steps); + return generic_utils_1.singletonOrArray(testOuts); + }; + Model.prototype.checkNumSamples = function (ins, batchSize, steps, stepsName) { + if (stepsName === void 0) { stepsName = 'steps'; } + var numSamples; + if (steps != null) { + numSamples = null; + if (batchSize != null) { + throw new errors_1.ValueError("If " + stepsName + " is set, batchSize must be null or undefined." + + ("Got batchSize = " + batchSize)); + } + } + else if (ins != null) { + if (Array.isArray(ins)) { + numSamples = ins[0].shape[0]; + } + else { + numSamples = ins.shape[0]; + } + } + else { + throw new errors_1.ValueError("Either the input data should have a defined shape, or " + + (stepsName + " shoud be specified.")); + } + return numSamples; + }; + Model.prototype.execute = function (inputs, outputs) { + if (Array.isArray(outputs) && outputs.length === 0) { + throw new errors_1.ValueError('`outputs` is an empty Array, which is not allowed.'); + } + var outputsIsArray = Array.isArray(outputs); + var outputNames = (outputsIsArray ? outputs : + [outputs]); + var outputSymbolicTensors = this.retrieveSymbolicTensors(outputNames); + var feedDict = new executor_1.FeedDict(); + if (inputs instanceof tfjs_core_1.Tensor) { + inputs = [inputs]; + } + if (Array.isArray(inputs)) { + if (inputs.length !== this.inputs.length) { + throw new errors_1.ValueError("The number of inputs provided (" + inputs.length + ") " + + "does not match the number of inputs of this model " + + ("(" + this.inputs.length + ").")); + } + for (var i = 0; i < this.inputs.length; ++i) { + feedDict.add(this.inputs[i], inputs[i]); + } + } + else { + for (var _i = 0, _a = this.inputs; _i < _a.length; _i++) { + var input = _a[_i]; + var tensorValue = inputs[input.name]; + if (tensorValue == null) { + throw new errors_1.ValueError("No value is provided for the model's input " + input.name); + } + feedDict.add(input, tensorValue); + } + } + var executeOutputs = executor_1.execute(outputSymbolicTensors, feedDict); + return outputsIsArray ? executeOutputs : executeOutputs[0]; + }; + Model.prototype.retrieveSymbolicTensors = function (symbolicTensorNames) { + var outputSymbolicTensors = generic_utils_1.pyListRepeat(null, symbolicTensorNames.length); + var outputsRemaining = symbolicTensorNames.length; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + var layerOutputs = Array.isArray(layer.output) ? + layer.output : + [layer.output]; + var layerOutputNames = layerOutputs.map(function (output) { return output.name; }); + for (var i = 0; i < symbolicTensorNames.length; ++i) { + var index = layerOutputNames.indexOf(symbolicTensorNames[i]); + if (index !== -1) { + outputSymbolicTensors[i] = layerOutputs[index]; + outputsRemaining--; + } + if (outputsRemaining === 0) { + break; + } + } + if (outputsRemaining === 0) { + break; + } + } + if (outputsRemaining > 0) { + var remainingNames_1 = []; + outputSymbolicTensors.forEach(function (tensor, i) { + if (tensor == null) { + remainingNames_1.push(symbolicTensorNames[i]); + } + }); + throw new errors_1.ValueError("Cannot find SymbolicTensors for output name(s): " + + ("" + JSON.stringify(remainingNames_1))); + } + return outputSymbolicTensors; + }; + Model.prototype.predictLoop = function (ins, batchSize, verbose) { + var _this = this; + if (batchSize === void 0) { batchSize = 32; } + if (verbose === void 0) { verbose = false; } + return tfc.tidy(function () { + var numSamples = _this.checkNumSamples(ins); + if (verbose) { + throw new errors_1.NotImplementedError('Verbose predictLoop() is not implemented yet.'); + } + var batches = makeBatches(numSamples, batchSize); + var outs = []; + var _loop_3 = function (batchIndex) { + var batchOuts = tfc.tidy(function () { + var batchStart = batches[batchIndex][0]; + var batchEnd = batches[batchIndex][1]; + var insBatch = sliceArrays(ins, batchStart, batchEnd); + var feeds = []; + if (Array.isArray(insBatch)) { + for (var i = 0; i < insBatch.length; ++i) { + feeds.push({ key: _this.inputs[i], value: insBatch[i] }); + } + } + else { + feeds.push({ key: _this.inputs[0], value: insBatch }); + } + var feedDict = new executor_1.FeedDict(feeds); + return executor_1.execute(_this.outputs, feedDict); + }); + if (batchIndex === 0) { + for (var _i = 0, batchOuts_1 = batchOuts; _i < batchOuts_1.length; _i++) { + var batchOut = batchOuts_1[_i]; + outs.push(batchOut); + } + } + else { + for (var i = 0; i < batchOuts.length; ++i) { + outs[i] = K.concatAlongFirstAxis(outs[i], batchOuts[i]); + } + } + }; + for (var batchIndex = 0; batchIndex < batches.length; ++batchIndex) { + _loop_3(batchIndex); + } + return generic_utils_1.singletonOrArray(outs); + }); + }; + Model.prototype.predict = function (x, config) { + if (config === void 0) { config = {}; } + checkInputData(x, this.inputNames, this.feedInputShapes, false); + var batchSize = config.batchSize == null ? 32 : config.batchSize; + return this.predictLoop(x, batchSize); + }; + Model.prototype.predictOnBatch = function (x) { + checkInputData(x, this.inputNames, this.feedInputShapes, true); + return this.predictLoop(x, x.shape[0]); + }; + Model.prototype.standardizeUserData = function (x, y, checkBatchAxis, batchSize) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (this.optimizer == null) { + throw new errors_1.RuntimeError('You must compile a model before training/testing. Use ' + + 'Model.compile(modelCompileConfig).'); + } + var outputShapes = []; + for (var i = 0; i < this.feedOutputShapes.length; ++i) { + var outputShape = this.feedOutputShapes[i]; + var lossFn = this.feedLossFns[i]; + if (lossFn === losses.sparseCategoricalCrossentropy) { + outputShapes.push(outputShape.slice(0, outputShape.length - 1).concat([1])); + } + else { + outputShapes.push(outputShape); + } + } + x = standardizeInputData(x, this.feedInputNames, this.feedInputShapes, false, 'input'); + y = standardizeInputData(y, this.feedOutputNames, outputShapes, false, 'target'); + checkArrayLengths(x, y, null); + checkLossAndTargetCompatibility(y, this.feedLossFns, this.feedOutputShapes); + if (this.stateful && batchSize != null && batchSize > 0) { + if (x[0].shape[0] % batchSize !== 0) { + throw new errors_1.ValueError("In a stateful network, you should only pass inputs with a " + + "number of samples that is divisible by the batch size " + + (batchSize + ". Found: " + x[0].shape[0] + " sample(s).")); + } + } + return [x, y, null]; + }; + Model.prototype.fitLoop = function (f, ins, outLabels, batchSize, epochs, verbose, callbacks, valF, valIns, shuffle, callbackMetrics, initialEpoch, stepsPerEpoch, validationSteps) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var doValidation, numTrainSamples, indexArray, callbackList, _loop_4, this_1, epoch, state_2; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (batchSize == null) { + batchSize = 32; + } + if (epochs == null) { + epochs = 1; + } + if (shuffle == null) { + shuffle = true; + } + if (initialEpoch == null) { + initialEpoch = 0; + } + doValidation = false; + if (valF != null && valIns != null) { + doValidation = true; + } + if (validationSteps != null) { + doValidation = true; + if (stepsPerEpoch == null) { + throw new errors_1.ValueError('Can only use `validationSteps` when doing step-wise training, ' + + 'i.e., `stepsPerEpoch` must be set.'); + } + } + numTrainSamples = this.checkNumSamples(ins, batchSize, stepsPerEpoch, 'steps_per_epoch'); + if (numTrainSamples != null) { + indexArray = math_utils_1.range(0, numTrainSamples); + } + this.history = new base_callbacks_1.History(); + if (callbacks == null) { + callbacks = [new base_callbacks_1.BaseLogger()]; + } + else { + callbacks = [new base_callbacks_1.BaseLogger()].concat(callbacks); + } + callbacks = callbacks.concat([this.history]); + if (verbose > 0) { + throw new errors_1.NotImplementedError('Verbose mode is not implemented yet.'); + } + callbackList = new base_callbacks_1.CallbackList(callbacks); + callbackList.setModel(this); + callbackList.setParams({ + epochs: epochs, + initialEpoch: initialEpoch, + steps: stepsPerEpoch, + verbose: verbose, + doValidation: doValidation, + metrics: callbackMetrics, + }); + return [4, callbackList.onTrainBegin()]; + case 1: + _a.sent(); + this.stopTraining = false; + _loop_4 = function (epoch) { + var epochLogs, epochIndexArray1D_1, batches_1, _loop_5, batchIndex, state_3; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, callbackList.onEpochBegin(epoch)]; + case 1: + _a.sent(); + epochLogs = {}; + if (!(stepsPerEpoch != null)) return [3, 2]; + throw new errors_1.NotImplementedError('stepsPerEpoch mode is not implemented yet.'); + case 2: + if (shuffle === 'batch') { + throw new errors_1.NotImplementedError('batch shuffling is not implemneted yet'); + } + else if (shuffle) { + tfjs_core_1.util.shuffle(indexArray); + } + epochIndexArray1D_1 = tfjs_core_1.tensor1d(indexArray); + batches_1 = makeBatches(numTrainSamples, batchSize); + _loop_5 = function (batchIndex) { + var batchLogs; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + batchLogs = {}; + return [4, callbackList.onBatchBegin(batchIndex, batchLogs)]; + case 1: + _a.sent(); + tfc.tidy(function () { + var batchStart = batches_1[batchIndex][0]; + var batchEnd = batches_1[batchIndex][1]; + var batchIds = K.sliceAlongFirstAxis(epochIndexArray1D_1, batchStart, batchEnd - batchStart); + batchLogs['batch'] = batchIndex; + batchLogs['size'] = batchEnd - batchStart; + var insBatch = sliceArraysByIndices(ins, batchIds); + var outs = f(insBatch); + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var out = outs[i]; + batchLogs[label] = out; + tfc.keep(out); + } + if (batchIndex === batches_1.length - 1) { + if (doValidation) { + var valOuts = _this.testLoop(valF, valIns, batchSize); + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var out = valOuts[i]; + tfc.keep(out); + epochLogs['val_' + label] = out; + } + } + } + }); + return [4, callbackList.onBatchEnd(batchIndex, batchLogs)]; + case 2: + _a.sent(); + logs_1.disposeTensorsInLogs(batchLogs); + if (this_1.stopTraining) { + return [2, "break"]; + } + return [2]; + } + }); + }; + batchIndex = 0; + _a.label = 3; + case 3: + if (!(batchIndex < batches_1.length)) return [3, 6]; + return [5, _loop_5(batchIndex)]; + case 4: + state_3 = _a.sent(); + if (state_3 === "break") + return [3, 6]; + _a.label = 5; + case 5: + ++batchIndex; + return [3, 3]; + case 6: + epochIndexArray1D_1.dispose(); + _a.label = 7; + case 7: return [4, callbackList.onEpochEnd(epoch, epochLogs)]; + case 8: + _a.sent(); + if (this_1.stopTraining) { + return [2, "break"]; + } + return [2]; + } + }); + }; + this_1 = this; + epoch = initialEpoch; + _a.label = 2; + case 2: + if (!(epoch < epochs)) return [3, 5]; + return [5, _loop_4(epoch)]; + case 3: + state_2 = _a.sent(); + if (state_2 === "break") + return [3, 5]; + _a.label = 4; + case 4: + ++epoch; + return [3, 2]; + case 5: return [4, callbackList.onTrainEnd()]; + case 6: + _a.sent(); + return [4, this.history.syncData()]; + case 7: + _a.sent(); + return [2, this.history]; + } + }); + }); + }; + Model.prototype.testLoop = function (f, ins, batchSize, verbose, steps) { + var _this = this; + if (verbose === void 0) { verbose = 0; } + return tfc.tidy(function () { + var numSamples = _this.checkNumSamples(ins, batchSize, steps, 'steps'); + var outs = []; + if (verbose === 1) { + throw new errors_1.NotImplementedError('Verbose mode is not implemented yet.'); + } + if (steps != null) { + throw new errors_1.NotImplementedError('steps mode in testLoop() is not implemented yet'); + } + else { + var batches = makeBatches(numSamples, batchSize); + var indexArray = tfjs_core_1.tensor1d(math_utils_1.range(0, numSamples)); + for (var batchIndex = 0; batchIndex < batches.length; ++batchIndex) { + var batchStart = batches[batchIndex][0]; + var batchEnd = batches[batchIndex][1]; + var batchIds = K.sliceAlongFirstAxis(indexArray, batchStart, batchEnd - batchStart); + var insBatch = sliceArraysByIndices(ins, batchIds); + var batchOuts = f(insBatch); + if (batchIndex === 0) { + for (var i = 0; i < batchOuts.length; ++i) { + outs.push(state_1.getScalar(0)); + } + } + for (var i = 0; i < batchOuts.length; ++i) { + var batchOut = batchOuts[i]; + outs[i] = + tfc.add(outs[i], tfc.mul(state_1.getScalar(batchEnd - batchStart), batchOut)); + } + } + for (var i = 0; i < outs.length; ++i) { + outs[i] = tfc.div(outs[i], state_1.getScalar(numSamples)); + } + } + return outs; + }); + }; + Model.prototype.getDedupedMetricsNames = function () { + var outLabels = this.metricsNames; + var dedupedOutLabels = []; + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var newLabel = label; + if (generic_utils_1.count(outLabels, label) > 1) { + var dupIndex = generic_utils_1.count(outLabels.slice(0, i), label); + newLabel += "_" + dupIndex; + } + dedupedOutLabels.push(newLabel); + } + return dedupedOutLabels; + }; + Model.prototype.makeTestFunction = function () { + var _this = this; + this.testFunction = function (data) { + return tfc.tidy(function () { + var valOutputs = []; + var totalLoss; + var inputs = data.slice(0, _this.inputs.length); + var targets = data.slice(_this.inputs.length, _this.inputs.length + _this.outputs.length); + var feeds = []; + for (var i = 0; i < _this.inputs.length; ++i) { + feeds.push({ key: _this.inputs[i], value: inputs[i] }); + } + var feedDict = new executor_1.FeedDict(feeds); + var outputs = executor_1.execute(_this.outputs, feedDict); + for (var i = 0; i < _this.lossFunctions.length; ++i) { + var lossFunction = _this.lossFunctions[i]; + var loss = tfc.mean(lossFunction(targets[i], outputs[i])); + if (i === 0) { + totalLoss = loss; + } + else { + totalLoss = tfc.add(totalLoss, loss); + } + valOutputs.push(totalLoss); + } + for (var i = 0; i < _this.metricsTensors.length; ++i) { + var metric = _this.metricsTensors[i][0]; + var outputIndex = _this.metricsTensors[i][1]; + var meanMetric = tfc.mean(metric(targets[outputIndex], outputs[outputIndex])); + valOutputs.push(meanMetric); + } + return valOutputs; + }); + }; + }; + Model.prototype.fit = function (x, y, config) { + if (config === void 0) { config = {}; } + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var batchSize, standardizedOuts, inputs, targets, doValidation, valX, valY, valIns, needValidationDisposal, valStandardized, splitAt, originalBatchSize, ins, trainFunction, outLabels, valFunction, callbackMetrics, callbacks, out; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + batchSize = config.batchSize == null ? 32 : config.batchSize; + standardizedOuts = this.standardizeUserData(x, y, false, batchSize); + inputs = standardizedOuts[0]; + targets = standardizedOuts[1]; + doValidation = false; + needValidationDisposal = false; + if (config.validationData != null && config.validationData.length > 0) { + doValidation = true; + if (config.validationData.length === 2) { + valX = config.validationData[0]; + valY = config.validationData[1]; + } + else if (config.validationData.length === 3) { + throw new errors_1.NotImplementedError('validationData including sample weights is not supported yet.'); + } + else { + throw new errors_1.ValueError("When passing validation data, it must contain 2 (valX, valY) " + + "or 3 (valX, valY, valSampleWeight) items; " + + (config.validationData + " is invalid.")); + } + valStandardized = this.standardizeUserData(valX, valY, true, batchSize); + valX = valStandardized[0]; + valY = valStandardized[1]; + valIns = valX.concat(valY); + } + else if (config.validationSplit != null && config.validationSplit > 0 && + config.validationSplit < 1) { + doValidation = true; + splitAt = Math.floor(inputs[0].shape[0] * (1 - config.validationSplit)); + originalBatchSize = inputs[0].shape[0]; + valX = sliceArrays(inputs, splitAt, originalBatchSize); + inputs = sliceArrays(inputs, 0, splitAt); + valY = sliceArrays(targets, splitAt, originalBatchSize); + targets = sliceArrays(targets, 0, splitAt); + needValidationDisposal = true; + valIns = valX.concat(valY); + } + else if (config.validationSteps != null) { + doValidation = true; + } + ins = inputs.concat(targets); + this.checkTrainableWeightsConsistency(); + trainFunction = function (data) { + var losses = []; + var lossValues = []; + var inputs = data.slice(0, _this.inputs.length); + var targets = data.slice(_this.inputs.length, _this.inputs.length + _this.outputs.length); + var metricsValues = []; + var totalLossFunction = function () { + var feeds = []; + for (var i = 0; i < _this.inputs.length; ++i) { + feeds.push({ key: _this.inputs[i], value: inputs[i] }); + } + var feedDict = new executor_1.FeedDict(feeds); + var outputs = executor_1.execute(_this.outputs, feedDict, { 'training': true }); + var totalLoss; + for (var i = 0; i < _this.lossFunctions.length; ++i) { + var lossFunction = _this.lossFunctions[i]; + var loss = lossFunction(targets[i], outputs[i]); + losses.push(loss); + var meanLoss = tfc.mean(loss); + lossValues.push(meanLoss); + if (i === 0) { + totalLoss = loss; + } + else { + totalLoss = tfc.add(totalLoss, loss); + } + } + for (var i = 0; i < _this.metricsTensors.length; ++i) { + var metric = _this.metricsTensors[i][0]; + var outputIndex = _this.metricsTensors[i][1]; + var meanMetric = tfc.mean(metric(targets[outputIndex], outputs[outputIndex])); + tfc.keep(meanMetric); + metricsValues.push(meanMetric); + } + totalLoss = tfc.mean(totalLoss); + _this.calculateLosses().forEach(function (regularizerLoss) { + totalLoss = tfc.add(totalLoss, regularizerLoss); + }); + return totalLoss; + }; + var variables = _this.collectedTrainableWeights.map(function (param) { return param.read(); }); + var returnCost = true; + var totalLossValue = _this.optimizer.minimize(totalLossFunction, returnCost, variables); + return [totalLossValue].concat(metricsValues); + }; + outLabels = this.getDedupedMetricsNames(); + if (doValidation) { + this.makeTestFunction(); + valFunction = this.testFunction; + callbackMetrics = + outLabels.slice().concat(outLabels.map(function (n) { return 'val_' + n; })); + } + else { + valFunction = null; + valIns = []; + callbackMetrics = outLabels.slice(); + } + callbacks = base_callbacks_1.standardizeCallbacks(config.callbacks); + return [4, this.fitLoop(trainFunction, ins, outLabels, batchSize, config.epochs, config.verbose, callbacks, valFunction, valIns, config.shuffle, callbackMetrics, config.initialEpoch, null, null)]; + case 1: + out = _a.sent(); + if (needValidationDisposal) { + valIns.forEach(function (tensor) { return tensor.dispose(); }); + inputs.forEach(function (tensor) { return tensor.dispose(); }); + targets.forEach(function (tensor) { return tensor.dispose(); }); + } + return [2, out]; + } + }); + }); + }; + Model.prototype.getNamedWeights = function (config) { + var namedWeights = {}; + var trainableOnly = config != null && config.trainableOnly; + var weights = trainableOnly ? this.trainableWeights : this.weights; + var weightValues = this.getWeights(trainableOnly); + for (var i = 0; i < weights.length; ++i) { + if (trainableOnly && !weights[i].trainable) { + continue; + } + namedWeights[weights[i].originalName] = weightValues[i]; + } + return namedWeights; + }; + Model.prototype.save = function (handlerOrURL, config) { + return __awaiter(this, void 0, void 0, function () { + var handlers, weightDataAndSpecs, returnString, unusedArg, modelConfig; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (typeof handlerOrURL === 'string') { + handlers = tfjs_core_1.io.getSaveHandlers(handlerOrURL); + if (handlers.length === 0) { + throw new errors_1.ValueError("Cannot find any save handlers for URL '" + handlerOrURL + "'"); + } + else if (handlers.length > 1) { + throw new errors_1.ValueError("Found more than one (" + handlers.length + ") save handlers for " + + ("URL '" + handlerOrURL + "'")); + } + handlerOrURL = handlers[0]; + } + if (handlerOrURL.save == null) { + throw new errors_1.ValueError('Model.save() cannot proceed because the IOHandler provided does ' + + 'not have the `save` attribute defined.'); + } + return [4, tfjs_core_1.io.encodeWeights(this.getNamedWeights(config))]; + case 1: + weightDataAndSpecs = _a.sent(); + returnString = false; + unusedArg = null; + modelConfig = this.toJSON(unusedArg, returnString); + return [2, handlerOrURL.save({ + modelTopology: modelConfig, + weightData: weightDataAndSpecs.data, + weightSpecs: weightDataAndSpecs.specs + })]; + } + }); + }); + }; + Model.className = 'Model'; + return Model; +}(container_1.Container)); +exports.Model = Model; +tfjs_core_1.serialization.SerializationMap.register(Model); +//# sourceMappingURL=training.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js.map new file mode 100644 index 0000000..402deba --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/training.js.map @@ -0,0 +1 @@ +{"version":3,"file":"training.js","sourceRoot":"","sources":["../../src/engine/training.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/engine/training_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/engine/training_test.js.map new file mode 100644 index 0000000..529d301 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/engine/training_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"training_test.js","sourceRoot":"","sources":["../../src/engine/training_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/errors.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/errors.d.ts new file mode 100644 index 0000000..6b1d87f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/errors.d.ts @@ -0,0 +1,18 @@ +export declare class AttributeError extends Error { + constructor(message?: string); +} +export declare class RuntimeError extends Error { + constructor(message?: string); +} +export declare class ValueError extends Error { + constructor(message?: string); +} +export declare class NotImplementedError extends Error { + constructor(message?: string); +} +export declare class AssertionError extends Error { + constructor(message?: string); +} +export declare class IndexError extends Error { + constructor(message?: string); +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/errors.js b/node_modules/@tensorflow/tfjs-layers/dist/errors.js new file mode 100644 index 0000000..7a9af3d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/errors.js @@ -0,0 +1,73 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var AttributeError = (function (_super) { + __extends(AttributeError, _super); + function AttributeError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, AttributeError.prototype); + return _this; + } + return AttributeError; +}(Error)); +exports.AttributeError = AttributeError; +var RuntimeError = (function (_super) { + __extends(RuntimeError, _super); + function RuntimeError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, RuntimeError.prototype); + return _this; + } + return RuntimeError; +}(Error)); +exports.RuntimeError = RuntimeError; +var ValueError = (function (_super) { + __extends(ValueError, _super); + function ValueError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, ValueError.prototype); + return _this; + } + return ValueError; +}(Error)); +exports.ValueError = ValueError; +var NotImplementedError = (function (_super) { + __extends(NotImplementedError, _super); + function NotImplementedError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, NotImplementedError.prototype); + return _this; + } + return NotImplementedError; +}(Error)); +exports.NotImplementedError = NotImplementedError; +var AssertionError = (function (_super) { + __extends(AssertionError, _super); + function AssertionError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, AssertionError.prototype); + return _this; + } + return AssertionError; +}(Error)); +exports.AssertionError = AssertionError; +var IndexError = (function (_super) { + __extends(IndexError, _super); + function IndexError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, IndexError.prototype); + return _this; + } + return IndexError; +}(Error)); +exports.IndexError = IndexError; +//# sourceMappingURL=errors.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/errors.js.map b/node_modules/@tensorflow/tfjs-layers/dist/errors.js.map new file mode 100644 index 0000000..aff48ea --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/errors.js.map @@ -0,0 +1 @@ +{"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":";;;;;;;;;;;;AAwBA;IAAoC,kCAAK;IACvC,wBAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC;;IACxD,CAAC;IACH,qBAAC;AAAD,CAAC,AAND,CAAoC,KAAK,GAMxC;AANY,wCAAc;AAW3B;IAAkC,gCAAK;IACrC,sBAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC;;IACtD,CAAC;IACH,mBAAC;AAAD,CAAC,AAND,CAAkC,KAAK,GAMtC;AANY,oCAAY;AAWzB;IAAgC,8BAAK;IACnC,oBAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;;IACpD,CAAC;IACH,iBAAC;AAAD,CAAC,AAND,CAAgC,KAAK,GAMpC;AANY,gCAAU;AAWvB;IAAyC,uCAAK;IAC5C,6BAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,mBAAmB,CAAC,SAAS,CAAC,CAAC;;IAC7D,CAAC;IACH,0BAAC;AAAD,CAAC,AAND,CAAyC,KAAK,GAM7C;AANY,kDAAmB;AAWhC;IAAoC,kCAAK;IACvC,wBAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC;;IACxD,CAAC;IACH,qBAAC;AAAD,CAAC,AAND,CAAoC,KAAK,GAMxC;AANY,wCAAc;AAW3B;IAAgC,8BAAK;IACnC,oBAAY,OAAgB;QAA5B,YACE,kBAAM,OAAO,CAAC,SAGf;QADC,MAAM,CAAC,cAAc,CAAC,KAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;;IACpD,CAAC;IACH,iBAAC;AAAD,CAAC,AAND,CAAgC,KAAK,GAMpC;AANY,gCAAU"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/errors_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/errors_test.js.map new file mode 100644 index 0000000..5ab7867 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/errors_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"errors_test.js","sourceRoot":"","sources":["../src/errors_test.ts"],"names":[],"mappings":";;AAUA,mCAAkE;AAElE,QAAQ,CAAC,eAAe,EAAE;4BAEb,SAAS;QAClB,EAAE,CAAC,wBAAwB,EAAE;YAC3B,IAAM,GAAG,GAAG,cAAc,CAAC;YAC3B,IAAM,CAAC,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,YAAY,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;IACL,CAAC;IAPD,KAAwB,UAA0C,EAA1C,MAAC,uBAAc,EAAE,qBAAY,EAAE,mBAAU,CAAC,EAA1C,cAA0C,EAA1C,IAA0C;QAA7D,IAAM,SAAS,SAAA;gBAAT,SAAS;KAOnB;AACH,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports.d.ts new file mode 100644 index 0000000..e3d0482 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports.d.ts @@ -0,0 +1,10 @@ +import { io } from '@tensorflow/tfjs-core'; +import { ContainerConfig } from './engine/container'; +import { InputConfig } from './engine/input_layer'; +import { SymbolicTensor } from './engine/topology'; +import { Model } from './engine/training'; +import { Sequential, SequentialConfig } from './models'; +export declare function model(config: ContainerConfig): Model; +export declare function sequential(config?: SequentialConfig): Sequential; +export declare function loadModel(pathOrIOHandler: string | io.IOHandler): Promise; +export declare function input(config: InputConfig): SymbolicTensor; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports.js b/node_modules/@tensorflow/tfjs-layers/dist/exports.js new file mode 100644 index 0000000..bb75ef3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports.js @@ -0,0 +1,22 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var input_layer_1 = require("./engine/input_layer"); +var training_1 = require("./engine/training"); +var models_1 = require("./models"); +function model(config) { + return new training_1.Model(config); +} +exports.model = model; +function sequential(config) { + return new models_1.Sequential(config); +} +exports.sequential = sequential; +function loadModel(pathOrIOHandler) { + return models_1.loadModelInternal(pathOrIOHandler); +} +exports.loadModel = loadModel; +function input(config) { + return input_layer_1.Input(config); +} +exports.input = input; +//# sourceMappingURL=exports.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports.js.map new file mode 100644 index 0000000..ebbc39e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports.js","sourceRoot":"","sources":["../src/exports.ts"],"names":[],"mappings":";;AAkBA,oDAAyD;AAEzD,8CAAwC;AACxC,mCAAyE;AAmDzE,eAAsB,MAAuB;IAC3C,OAAO,IAAI,gBAAK,CAAC,MAAM,CAAC,CAAC;AAC3B,CAAC;AAFD,sBAEC;AA8DD,oBAA2B,MAAyB;IAClD,OAAO,IAAI,mBAAU,CAAC,MAAM,CAAC,CAAC;AAChC,CAAC;AAFD,gCAEC;AASD,mBAA0B,eACY;IACpC,OAAO,0BAAiB,CAAC,eAAe,CAAC,CAAC;AAC5C,CAAC;AAHD,8BAGC;AAUD,eAAsB,MAAmB;IACvC,OAAO,mBAAK,CAAC,MAAM,CAAC,CAAC;AACvB,CAAC;AAFD,sBAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.d.ts new file mode 100644 index 0000000..b6f53db --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.d.ts @@ -0,0 +1,5 @@ +import { Constraint, MaxNormConfig, MinMaxNormConfig, UnitNormConfig } from './constraints'; +export declare function maxNorm(config: MaxNormConfig): Constraint; +export declare function unitNorm(config: UnitNormConfig): Constraint; +export declare function nonNeg(): Constraint; +export declare function minMaxNorm(config: MinMaxNormConfig): Constraint; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js new file mode 100644 index 0000000..356397c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js @@ -0,0 +1,20 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var constraints_1 = require("./constraints"); +function maxNorm(config) { + return new constraints_1.MaxNorm(config); +} +exports.maxNorm = maxNorm; +function unitNorm(config) { + return new constraints_1.UnitNorm(config); +} +exports.unitNorm = unitNorm; +function nonNeg() { + return new constraints_1.NonNeg(); +} +exports.nonNeg = nonNeg; +function minMaxNorm(config) { + return new constraints_1.MinMaxNorm(config); +} +exports.minMaxNorm = minMaxNorm; +//# sourceMappingURL=exports_constraints.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js.map new file mode 100644 index 0000000..a9d2a5f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_constraints.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports_constraints.js","sourceRoot":"","sources":["../src/exports_constraints.ts"],"names":[],"mappings":";;AAUA,6CAAiI;AAUjI,iBAAwB,MAAqB;IAC3C,OAAO,IAAI,qBAAO,CAAC,MAAM,CAAC,CAAC;AAC7B,CAAC;AAFD,0BAEC;AAUD,kBAAyB,MAAsB;IAC7C,OAAO,IAAI,sBAAQ,CAAC,MAAM,CAAC,CAAC;AAC9B,CAAC;AAFD,4BAEC;AASD;IACE,OAAO,IAAI,oBAAM,EAAE,CAAC;AACtB,CAAC;AAFD,wBAEC;AAUD,oBAA2B,MAAwB;IACjD,OAAO,IAAI,wBAAU,CAAC,MAAM,CAAC,CAAC;AAChC,CAAC;AAFD,gCAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.d.ts new file mode 100644 index 0000000..7844d02 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.d.ts @@ -0,0 +1,14 @@ +import { ConstantConfig, IdentityConfig, Initializer, OrthogonalConfig, RandomNormalConfig, RandomUniformConfig, SeedOnlyInitializerConfig, TruncatedNormalConfig, VarianceScalingConfig, Zeros } from './initializers'; +export declare function zeros(): Zeros; +export declare function ones(): Initializer; +export declare function constant(config: ConstantConfig): Initializer; +export declare function randomUniform(config: RandomUniformConfig): Initializer; +export declare function randomNormal(config: RandomNormalConfig): Initializer; +export declare function truncatedNormal(config: TruncatedNormalConfig): Initializer; +export declare function identity(config: IdentityConfig): Initializer; +export declare function varianceScaling(config: VarianceScalingConfig): Initializer; +export declare function glorotUniform(config: SeedOnlyInitializerConfig): Initializer; +export declare function glorotNormal(config: SeedOnlyInitializerConfig): Initializer; +export declare function heNormal(config: SeedOnlyInitializerConfig): Initializer; +export declare function leCunNormal(config: SeedOnlyInitializerConfig): Initializer; +export declare function orthogonal(config: OrthogonalConfig): Initializer; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js new file mode 100644 index 0000000..da38050 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js @@ -0,0 +1,56 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var initializers_1 = require("./initializers"); +function zeros() { + return new initializers_1.Zeros(); +} +exports.zeros = zeros; +function ones() { + return new initializers_1.Ones(); +} +exports.ones = ones; +function constant(config) { + return new initializers_1.Constant(config); +} +exports.constant = constant; +function randomUniform(config) { + return new initializers_1.RandomUniform(config); +} +exports.randomUniform = randomUniform; +function randomNormal(config) { + return new initializers_1.RandomNormal(config); +} +exports.randomNormal = randomNormal; +function truncatedNormal(config) { + return new initializers_1.TruncatedNormal(config); +} +exports.truncatedNormal = truncatedNormal; +function identity(config) { + return new initializers_1.Identity(config); +} +exports.identity = identity; +function varianceScaling(config) { + return new initializers_1.VarianceScaling(config); +} +exports.varianceScaling = varianceScaling; +function glorotUniform(config) { + return new initializers_1.GlorotUniform(config); +} +exports.glorotUniform = glorotUniform; +function glorotNormal(config) { + return new initializers_1.GlorotNormal(config); +} +exports.glorotNormal = glorotNormal; +function heNormal(config) { + return new initializers_1.HeNormal(config); +} +exports.heNormal = heNormal; +function leCunNormal(config) { + return new initializers_1.LeCunNormal(config); +} +exports.leCunNormal = leCunNormal; +function orthogonal(config) { + return new initializers_1.Orthogonal(config); +} +exports.orthogonal = orthogonal; +//# sourceMappingURL=exports_initializers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js.map new file mode 100644 index 0000000..df375a5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_initializers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports_initializers.js","sourceRoot":"","sources":["../src/exports_initializers.ts"],"names":[],"mappings":";;AAUA,+CAA+W;AAS/W;IACE,OAAO,IAAI,oBAAK,EAAE,CAAC;AACrB,CAAC;AAFD,sBAEC;AASD;IACE,OAAO,IAAI,mBAAI,EAAE,CAAC;AACpB,CAAC;AAFD,oBAEC;AAUD,kBAAyB,MAAsB;IAC7C,OAAO,IAAI,uBAAQ,CAAC,MAAM,CAAC,CAAC;AAC9B,CAAC;AAFD,4BAEC;AAUD,uBAA8B,MAA2B;IACvD,OAAO,IAAI,4BAAa,CAAC,MAAM,CAAC,CAAC;AACnC,CAAC;AAFD,sCAEC;AAUD,sBAA6B,MAA0B;IACrD,OAAO,IAAI,2BAAY,CAAC,MAAM,CAAC,CAAC;AAClC,CAAC;AAFD,oCAEC;AAUD,yBAAgC,MAA6B;IAC3D,OAAO,IAAI,8BAAe,CAAC,MAAM,CAAC,CAAC;AACrC,CAAC;AAFD,0CAEC;AAUD,kBAAyB,MAAsB;IAC7C,OAAO,IAAI,uBAAQ,CAAC,MAAM,CAAC,CAAC;AAC9B,CAAC;AAFD,4BAEC;AAUD,yBAAgC,MAA6B;IAC3D,OAAO,IAAI,8BAAe,CAAC,MAAM,CAAC,CAAC;AACrC,CAAC;AAFD,0CAEC;AAUD,uBAA8B,MAAiC;IAC7D,OAAO,IAAI,4BAAa,CAAC,MAAM,CAAC,CAAC;AACnC,CAAC;AAFD,sCAEC;AAUD,sBAA6B,MAAiC;IAC5D,OAAO,IAAI,2BAAY,CAAC,MAAM,CAAC,CAAC;AAClC,CAAC;AAFD,oCAEC;AAUD,kBAAyB,MAAiC;IACxD,OAAO,IAAI,uBAAQ,CAAC,MAAM,CAAC,CAAC;AAC9B,CAAC;AAFD,4BAEC;AAUD,qBAA4B,MAAiC;IAC3D,OAAO,IAAI,0BAAW,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAFD,kCAEC;AAUD,oBAA2B,MAAwB;IACjD,OAAO,IAAI,yBAAU,CAAC,MAAM,CAAC,CAAC;AAChC,CAAC;AAFD,gCAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.d.ts new file mode 100644 index 0000000..ac64c89 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.d.ts @@ -0,0 +1,68 @@ +import { InputLayerConfig } from './engine/input_layer'; +import { Layer, LayerConfig } from './engine/topology'; +import { input } from './exports'; +import { ELULayerConfig, LeakyReLULayerConfig, SoftmaxLayerConfig, ThresholdedReLULayerConfig } from './layers/advanced_activations'; +import { ConvLayerConfig, Cropping2DLayerConfig, SeparableConvLayerConfig, UpSampling2DLayerConfig } from './layers/convolutional'; +import { DepthwiseConv2DLayerConfig } from './layers/convolutional_depthwise'; +import { ActivationLayerConfig, DenseLayerConfig, DropoutLayerConfig, RepeatVectorLayerConfig, ReshapeLayerConfig } from './layers/core'; +import { EmbeddingLayerConfig } from './layers/embeddings'; +import { ConcatenateLayerConfig } from './layers/merge'; +import { BatchNormalizationLayerConfig } from './layers/normalization'; +import { ZeroPadding2DLayerConfig } from './layers/padding'; +import { GlobalPooling2DLayerConfig, Pooling1DLayerConfig, Pooling2DLayerConfig } from './layers/pooling'; +import { GRUCellLayerConfig, GRULayerConfig, LSTMCellLayerConfig, LSTMLayerConfig, RNNCell, RNNLayerConfig, SimpleRNNCellLayerConfig, SimpleRNNLayerConfig, StackedRNNCellsConfig } from './layers/recurrent'; +import { BidirectionalLayerConfig, Wrapper, WrapperLayerConfig } from './layers/wrappers'; +export declare function inputLayer(config: InputLayerConfig): Layer; +export declare function elu(config?: ELULayerConfig): Layer; +export declare function leakyReLU(config?: LeakyReLULayerConfig): Layer; +export declare function softmax(config?: SoftmaxLayerConfig): Layer; +export declare function thresholdedReLU(config?: ThresholdedReLULayerConfig): Layer; +export declare function conv1d(config: ConvLayerConfig): Layer; +export declare function conv2d(config: ConvLayerConfig): Layer; +export declare function conv2dTranspose(config: ConvLayerConfig): Layer; +export declare function separableConv2d(config: SeparableConvLayerConfig): Layer; +export declare function cropping2D(config: Cropping2DLayerConfig): Layer; +export declare function upSampling2d(config: UpSampling2DLayerConfig): Layer; +export declare function depthwiseConv2d(config: DepthwiseConv2DLayerConfig): Layer; +export declare function activation(config: ActivationLayerConfig): Layer; +export declare function dense(config: DenseLayerConfig): Layer; +export declare function dropout(config: DropoutLayerConfig): Layer; +export declare function flatten(config?: LayerConfig): Layer; +export declare function repeatVector(config: RepeatVectorLayerConfig): Layer; +export declare function reshape(config: ReshapeLayerConfig): Layer; +export declare function embedding(config: EmbeddingLayerConfig): Layer; +export declare function add(config?: LayerConfig): Layer; +export declare function average(config?: LayerConfig): Layer; +export declare function concatenate(config?: ConcatenateLayerConfig): Layer; +export declare function maximum(config?: LayerConfig): Layer; +export declare function minimum(config?: LayerConfig): Layer; +export declare function multiply(config?: LayerConfig): Layer; +export declare function batchNormalization(config: BatchNormalizationLayerConfig): Layer; +export declare function zeroPadding2d(config?: ZeroPadding2DLayerConfig): Layer; +export declare function averagePooling1d(config: Pooling1DLayerConfig): Layer; +export declare function avgPool1d(config: Pooling1DLayerConfig): Layer; +export declare function avgPooling1d(config: Pooling1DLayerConfig): Layer; +export declare function averagePooling2d(config: Pooling2DLayerConfig): Layer; +export declare function avgPool2d(config: Pooling2DLayerConfig): Layer; +export declare function avgPooling2d(config: Pooling2DLayerConfig): Layer; +export declare function globalAveragePooling1d(config: LayerConfig): Layer; +export declare function globalAveragePooling2d(config: GlobalPooling2DLayerConfig): Layer; +export declare function globalMaxPooling1d(config: LayerConfig): Layer; +export declare function globalMaxPooling2d(config: GlobalPooling2DLayerConfig): Layer; +export declare function maxPooling1d(config: Pooling1DLayerConfig): Layer; +export declare function maxPooling2d(config: Pooling2DLayerConfig): Layer; +export declare function gru(config: GRULayerConfig): Layer; +export declare function gruCell(config: GRUCellLayerConfig): RNNCell; +export declare function lstm(config: LSTMLayerConfig): Layer; +export declare function lstmCell(config: LSTMCellLayerConfig): RNNCell; +export declare function simpleRNN(config: SimpleRNNLayerConfig): Layer; +export declare function simpleRNNCell(config: SimpleRNNCellLayerConfig): RNNCell; +export declare function rnn(config: RNNLayerConfig): Layer; +export declare function stackedRNNCells(config: StackedRNNCellsConfig): RNNCell; +export declare function bidirectional(config: BidirectionalLayerConfig): Wrapper; +export declare function timeDistributed(config: WrapperLayerConfig): Layer; +export declare const globalMaxPool1d: typeof globalMaxPooling1d; +export declare const globalMaxPool2d: typeof globalMaxPooling2d; +export declare const maxPool1d: typeof maxPooling1d; +export declare const maxPool2d: typeof maxPooling2d; +export { Layer, input }; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js new file mode 100644 index 0000000..ac769dd --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js @@ -0,0 +1,219 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var input_layer_1 = require("./engine/input_layer"); +var topology_1 = require("./engine/topology"); +exports.Layer = topology_1.Layer; +var exports_1 = require("./exports"); +exports.input = exports_1.input; +var advanced_activations_1 = require("./layers/advanced_activations"); +var convolutional_1 = require("./layers/convolutional"); +var convolutional_depthwise_1 = require("./layers/convolutional_depthwise"); +var core_1 = require("./layers/core"); +var embeddings_1 = require("./layers/embeddings"); +var merge_1 = require("./layers/merge"); +var normalization_1 = require("./layers/normalization"); +var padding_1 = require("./layers/padding"); +var pooling_1 = require("./layers/pooling"); +var recurrent_1 = require("./layers/recurrent"); +var wrappers_1 = require("./layers/wrappers"); +function inputLayer(config) { + return new input_layer_1.InputLayer(config); +} +exports.inputLayer = inputLayer; +function elu(config) { + return new advanced_activations_1.ELU(config); +} +exports.elu = elu; +function leakyReLU(config) { + return new advanced_activations_1.LeakyReLU(config); +} +exports.leakyReLU = leakyReLU; +function softmax(config) { + return new advanced_activations_1.Softmax(config); +} +exports.softmax = softmax; +function thresholdedReLU(config) { + return new advanced_activations_1.ThresholdedReLU(config); +} +exports.thresholdedReLU = thresholdedReLU; +function conv1d(config) { + return new convolutional_1.Conv1D(config); +} +exports.conv1d = conv1d; +function conv2d(config) { + return new convolutional_1.Conv2D(config); +} +exports.conv2d = conv2d; +function conv2dTranspose(config) { + return new convolutional_1.Conv2DTranspose(config); +} +exports.conv2dTranspose = conv2dTranspose; +function separableConv2d(config) { + return new convolutional_1.SeparableConv2D(config); +} +exports.separableConv2d = separableConv2d; +function cropping2D(config) { + return new convolutional_1.Cropping2D(config); +} +exports.cropping2D = cropping2D; +function upSampling2d(config) { + return new convolutional_1.UpSampling2D(config); +} +exports.upSampling2d = upSampling2d; +function depthwiseConv2d(config) { + return new convolutional_depthwise_1.DepthwiseConv2D(config); +} +exports.depthwiseConv2d = depthwiseConv2d; +function activation(config) { + return new core_1.Activation(config); +} +exports.activation = activation; +function dense(config) { + return new core_1.Dense(config); +} +exports.dense = dense; +function dropout(config) { + return new core_1.Dropout(config); +} +exports.dropout = dropout; +function flatten(config) { + return new core_1.Flatten(config); +} +exports.flatten = flatten; +function repeatVector(config) { + return new core_1.RepeatVector(config); +} +exports.repeatVector = repeatVector; +function reshape(config) { + return new core_1.Reshape(config); +} +exports.reshape = reshape; +function embedding(config) { + return new embeddings_1.Embedding(config); +} +exports.embedding = embedding; +function add(config) { + return new merge_1.Add(config); +} +exports.add = add; +function average(config) { + return new merge_1.Average(config); +} +exports.average = average; +function concatenate(config) { + return new merge_1.Concatenate(config); +} +exports.concatenate = concatenate; +function maximum(config) { + return new merge_1.Maximum(config); +} +exports.maximum = maximum; +function minimum(config) { + return new merge_1.Minimum(config); +} +exports.minimum = minimum; +function multiply(config) { + return new merge_1.Multiply(config); +} +exports.multiply = multiply; +function batchNormalization(config) { + return new normalization_1.BatchNormalization(config); +} +exports.batchNormalization = batchNormalization; +function zeroPadding2d(config) { + return new padding_1.ZeroPadding2D(config); +} +exports.zeroPadding2d = zeroPadding2d; +function averagePooling1d(config) { + return new pooling_1.AveragePooling1D(config); +} +exports.averagePooling1d = averagePooling1d; +function avgPool1d(config) { + return averagePooling1d(config); +} +exports.avgPool1d = avgPool1d; +function avgPooling1d(config) { + return averagePooling1d(config); +} +exports.avgPooling1d = avgPooling1d; +function averagePooling2d(config) { + return new pooling_1.AveragePooling2D(config); +} +exports.averagePooling2d = averagePooling2d; +function avgPool2d(config) { + return averagePooling2d(config); +} +exports.avgPool2d = avgPool2d; +function avgPooling2d(config) { + return averagePooling2d(config); +} +exports.avgPooling2d = avgPooling2d; +function globalAveragePooling1d(config) { + return new pooling_1.GlobalAveragePooling1D(config); +} +exports.globalAveragePooling1d = globalAveragePooling1d; +function globalAveragePooling2d(config) { + return new pooling_1.GlobalAveragePooling2D(config); +} +exports.globalAveragePooling2d = globalAveragePooling2d; +function globalMaxPooling1d(config) { + return new pooling_1.GlobalMaxPooling1D(config); +} +exports.globalMaxPooling1d = globalMaxPooling1d; +function globalMaxPooling2d(config) { + return new pooling_1.GlobalMaxPooling2D(config); +} +exports.globalMaxPooling2d = globalMaxPooling2d; +function maxPooling1d(config) { + return new pooling_1.MaxPooling1D(config); +} +exports.maxPooling1d = maxPooling1d; +function maxPooling2d(config) { + return new pooling_1.MaxPooling2D(config); +} +exports.maxPooling2d = maxPooling2d; +function gru(config) { + return new recurrent_1.GRU(config); +} +exports.gru = gru; +function gruCell(config) { + return new recurrent_1.GRUCell(config); +} +exports.gruCell = gruCell; +function lstm(config) { + return new recurrent_1.LSTM(config); +} +exports.lstm = lstm; +function lstmCell(config) { + return new recurrent_1.LSTMCell(config); +} +exports.lstmCell = lstmCell; +function simpleRNN(config) { + return new recurrent_1.SimpleRNN(config); +} +exports.simpleRNN = simpleRNN; +function simpleRNNCell(config) { + return new recurrent_1.SimpleRNNCell(config); +} +exports.simpleRNNCell = simpleRNNCell; +function rnn(config) { + return new recurrent_1.RNN(config); +} +exports.rnn = rnn; +function stackedRNNCells(config) { + return new recurrent_1.StackedRNNCells(config); +} +exports.stackedRNNCells = stackedRNNCells; +function bidirectional(config) { + return new wrappers_1.Bidirectional(config); +} +exports.bidirectional = bidirectional; +function timeDistributed(config) { + return new wrappers_1.TimeDistributed(config); +} +exports.timeDistributed = timeDistributed; +exports.globalMaxPool1d = globalMaxPooling1d; +exports.globalMaxPool2d = globalMaxPooling2d; +exports.maxPool1d = maxPooling1d; +exports.maxPool2d = maxPooling2d; +//# sourceMappingURL=exports_layers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js.map new file mode 100644 index 0000000..30c2468 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_layers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports_layers.js","sourceRoot":"","sources":["../src/exports_layers.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.d.ts new file mode 100644 index 0000000..e2c2009 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.d.ts @@ -0,0 +1,13 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +export declare function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function categoricalCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanAbsolutePercentageError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function MAPE(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function mape(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function MSE(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function mse(yTrue: Tensor, yPred: Tensor): Tensor; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js new file mode 100644 index 0000000..2b0aca0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js @@ -0,0 +1,53 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var losses = require("./losses"); +var metrics = require("./metrics"); +function binaryAccuracy(yTrue, yPred) { + return metrics.binaryAccuracy(yTrue, yPred); +} +exports.binaryAccuracy = binaryAccuracy; +function binaryCrossentropy(yTrue, yPred) { + return metrics.binaryCrossentropy(yTrue, yPred); +} +exports.binaryCrossentropy = binaryCrossentropy; +function categoricalAccuracy(yTrue, yPred) { + return metrics.categoricalAccuracy(yTrue, yPred); +} +exports.categoricalAccuracy = categoricalAccuracy; +function categoricalCrossentropy(yTrue, yPred) { + return metrics.categoricalCrossentropy(yTrue, yPred); +} +exports.categoricalCrossentropy = categoricalCrossentropy; +function cosineProximity(yTrue, yPred) { + return losses.cosineProximity(yTrue, yPred); +} +exports.cosineProximity = cosineProximity; +function meanAbsoluteError(yTrue, yPred) { + return losses.meanAbsoluteError(yTrue, yPred); +} +exports.meanAbsoluteError = meanAbsoluteError; +function meanAbsolutePercentageError(yTrue, yPred) { + return losses.meanAbsolutePercentageError(yTrue, yPred); +} +exports.meanAbsolutePercentageError = meanAbsolutePercentageError; +function MAPE(yTrue, yPred) { + return losses.meanAbsolutePercentageError(yTrue, yPred); +} +exports.MAPE = MAPE; +function mape(yTrue, yPred) { + return losses.meanAbsolutePercentageError(yTrue, yPred); +} +exports.mape = mape; +function meanSquaredError(yTrue, yPred) { + return losses.meanSquaredError(yTrue, yPred); +} +exports.meanSquaredError = meanSquaredError; +function MSE(yTrue, yPred) { + return losses.meanSquaredError(yTrue, yPred); +} +exports.MSE = MSE; +function mse(yTrue, yPred) { + return losses.meanSquaredError(yTrue, yPred); +} +exports.mse = mse; +//# sourceMappingURL=exports_metrics.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js.map new file mode 100644 index 0000000..ea2dbb6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_metrics.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports_metrics.js","sourceRoot":"","sources":["../src/exports_metrics.ts"],"names":[],"mappings":";;AAWA,iCAAmC;AACnC,mCAAqC;AASrC,wBAA+B,KAAa,EAAE,KAAa;IACzD,OAAO,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAFD,wCAEC;AASD,4BAAmC,KAAa,EAAE,KAAa;IAC7D,OAAO,OAAO,CAAC,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAClD,CAAC;AAFD,gDAEC;AASD,6BAAoC,KAAa,EAAE,KAAa;IAC9D,OAAO,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AACnD,CAAC;AAFD,kDAEC;AASD,iCAAwC,KAAa,EAAE,KAAa;IAClE,OAAO,OAAO,CAAC,uBAAuB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AACvD,CAAC;AAFD,0DAEC;AASD,yBAAgC,KAAa,EAAE,KAAa;IAC1D,OAAO,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAFD,0CAEC;AASD,2BAAkC,KAAa,EAAE,KAAa;IAC5D,OAAO,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAChD,CAAC;AAFD,8CAEC;AASD,qCACI,KAAa,EAAE,KAAa;IAC9B,OAAO,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC1D,CAAC;AAHD,kEAGC;AAED,cAAqB,KAAa,EAAE,KAAa;IAC/C,OAAO,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC1D,CAAC;AAFD,oBAEC;AAED,cAAqB,KAAa,EAAE,KAAa;IAC/C,OAAO,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC1D,CAAC;AAFD,oBAEC;AASD,0BAAiC,KAAa,EAAE,KAAa;IAC3D,OAAO,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC/C,CAAC;AAFD,4CAEC;AAED,aAAoB,KAAa,EAAE,KAAa;IAC9C,OAAO,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC/C,CAAC;AAFD,kBAEC;AAED,aAAoB,KAAa,EAAE,KAAa;IAC9C,OAAO,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC/C,CAAC;AAFD,kBAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.d.ts new file mode 100644 index 0000000..0e499b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.d.ts @@ -0,0 +1,4 @@ +import { L1Config, L1L2Config, L2Config, Regularizer } from './regularizers'; +export declare function l1l2(config?: L1L2Config): Regularizer; +export declare function l1(config?: L1Config): Regularizer; +export declare function l2(config?: L2Config): Regularizer; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js new file mode 100644 index 0000000..7d48d77 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js @@ -0,0 +1,17 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var regularizers = require("./regularizers"); +var regularizers_1 = require("./regularizers"); +function l1l2(config) { + return new regularizers_1.L1L2(config); +} +exports.l1l2 = l1l2; +function l1(config) { + return regularizers.l1(config); +} +exports.l1 = l1; +function l2(config) { + return regularizers.l2(config); +} +exports.l2 = l2; +//# sourceMappingURL=exports_regularizers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js.map new file mode 100644 index 0000000..c1b9059 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/exports_regularizers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports_regularizers.js","sourceRoot":"","sources":["../src/exports_regularizers.ts"],"names":[],"mappings":";;AASA,6CAA+C;AAE/C,+CAAiF;AAUjF,cAAqB,MAAmB;IACtC,OAAO,IAAI,mBAAI,CAAC,MAAM,CAAC,CAAC;AAC1B,CAAC;AAFD,oBAEC;AAUD,YAAmB,MAAiB;IAClC,OAAO,YAAY,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAFD,gBAEC;AAUD,YAAmB,MAAiB;IAClC,OAAO,YAAY,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAFD,gBAEC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/index.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/index.d.ts new file mode 100644 index 0000000..3403504 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/index.d.ts @@ -0,0 +1,17 @@ +import * as constraints from './exports_constraints'; +import * as initializers from './exports_initializers'; +import * as layers from './exports_layers'; +import * as metrics from './exports_metrics'; +import * as regularizers from './exports_regularizers'; +export { CallbackList, CustomCallback, CustomCallbackConfig } from './base_callbacks'; +export { Callback } from './callbacks'; +export { SymbolicTensor } from './engine/topology'; +export { Model, ModelCompileConfig, ModelEvaluateConfig, ModelFitConfig } from './engine/training'; +export { input, loadModel, model, sequential } from './exports'; +export { GRUCellLayerConfig, GRULayerConfig, LSTMCellLayerConfig, LSTMLayerConfig, RNN, RNNLayerConfig, SimpleRNNCellLayerConfig, SimpleRNNLayerConfig } from './layers/recurrent'; +export { Logs } from './logs'; +export { ModelAndWeightsConfig, Sequential, SequentialConfig } from './models'; +export { Shape } from './types'; +export { LayerVariable } from './variables'; +export { version as version_layers } from './version'; +export { constraints, initializers, layers, metrics, regularizers }; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/index.js b/node_modules/@tensorflow/tfjs-layers/dist/index.js new file mode 100644 index 0000000..fc516e2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/index.js @@ -0,0 +1,35 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var constraints = require("./exports_constraints"); +exports.constraints = constraints; +var initializers = require("./exports_initializers"); +exports.initializers = initializers; +var layers = require("./exports_layers"); +exports.layers = layers; +var metrics = require("./exports_metrics"); +exports.metrics = metrics; +var regularizers = require("./exports_regularizers"); +exports.regularizers = regularizers; +var base_callbacks_1 = require("./base_callbacks"); +exports.CallbackList = base_callbacks_1.CallbackList; +exports.CustomCallback = base_callbacks_1.CustomCallback; +var callbacks_1 = require("./callbacks"); +exports.Callback = callbacks_1.Callback; +var topology_1 = require("./engine/topology"); +exports.SymbolicTensor = topology_1.SymbolicTensor; +var training_1 = require("./engine/training"); +exports.Model = training_1.Model; +var exports_1 = require("./exports"); +exports.input = exports_1.input; +exports.loadModel = exports_1.loadModel; +exports.model = exports_1.model; +exports.sequential = exports_1.sequential; +var recurrent_1 = require("./layers/recurrent"); +exports.RNN = recurrent_1.RNN; +var models_1 = require("./models"); +exports.Sequential = models_1.Sequential; +var variables_1 = require("./variables"); +exports.LayerVariable = variables_1.LayerVariable; +var version_1 = require("./version"); +exports.version_layers = version_1.version; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/index.js.map b/node_modules/@tensorflow/tfjs-layers/dist/index.js.map new file mode 100644 index 0000000..9d90053 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAaA,mDAAqD;AAoB7C,kCAAW;AAnBnB,qDAAuD;AAmBlC,oCAAY;AAlBjC,yCAA2C;AAkBR,wBAAM;AAjBzC,2CAA6C;AAiBF,0BAAO;AAhBlD,qDAAuD;AAgBH,oCAAY;AAdhE,mDAAoF;AAA5E,wCAAA,YAAY,CAAA;AAAE,0CAAA,cAAc,CAAA;AACpC,yCAAqC;AAA7B,+BAAA,QAAQ,CAAA;AAChB,8CAAiD;AAAzC,oCAAA,cAAc,CAAA;AACtB,8CAAiG;AAAzF,2BAAA,KAAK,CAAA;AAGb,qCAA8D;AAAtD,0BAAA,KAAK,CAAA;AAAE,8BAAA,SAAS,CAAA;AAAE,0BAAA,KAAK,CAAA;AAAE,+BAAA,UAAU,CAAA;AAE3C,gDAAiL;AAA/F,0BAAA,GAAG,CAAA;AAErF,mCAA6E;AAA9C,8BAAA,UAAU,CAAA;AAEzC,yCAA0C;AAAlC,oCAAA,aAAa,CAAA;AACrB,qCAAoD;AAA5C,mCAAA,OAAO,CAAkB"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/initializers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/initializers.d.ts new file mode 100644 index 0000000..253c206 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/initializers.d.ts @@ -0,0 +1,142 @@ +import { DataType, serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Shape } from './types'; +export declare type FanMode = 'fanIn' | 'fanOut' | 'fanAvg'; +export declare const VALID_FAN_MODE_VALUES: string[]; +export declare function checkFanMode(value?: string): void; +export declare type Distribution = 'normal' | 'uniform'; +export declare const VALID_DISTRIBUTION_VALUES: string[]; +export declare function checkDistribution(value?: string): void; +export declare abstract class Initializer extends serialization.Serializable { + fromConfigUsesCustomObjects(): boolean; + abstract apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export declare class Zeros extends Initializer { + static className: string; + apply(shape: Shape, dtype?: DataType): Tensor; +} +export declare class Ones extends Initializer { + static className: string; + apply(shape: Shape, dtype?: DataType): Tensor; +} +export interface ConstantConfig { + value: number; +} +export declare class Constant extends Initializer { + static className: string; + private value; + constructor(config: ConstantConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface RandomUniformConfig { + minval?: number; + maxval?: number; + seed?: number; +} +export declare class RandomUniform extends Initializer { + static className: string; + readonly DEFAULT_MINVAL: number; + readonly DEFAULT_MAXVAL: number; + private minval; + private maxval; + private seed; + constructor(config: RandomUniformConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface RandomNormalConfig { + mean?: number; + stddev?: number; + seed?: number; +} +export declare class RandomNormal extends Initializer { + static className: string; + readonly DEFAULT_MEAN: number; + readonly DEFAULT_STDDEV: number; + private mean; + private stddev; + private seed; + constructor(config: RandomNormalConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface TruncatedNormalConfig { + mean?: number; + stddev?: number; + seed?: number; +} +export declare class TruncatedNormal extends Initializer { + static className: string; + readonly DEFAULT_MEAN: number; + readonly DEFAULT_STDDEV: number; + private mean; + private stddev; + private seed; + constructor(config: TruncatedNormalConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface IdentityConfig { + gain?: number; +} +export declare class Identity extends Initializer { + static className: string; + private gain; + constructor(config: IdentityConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface VarianceScalingConfig { + scale: number; + mode: FanMode; + distribution: Distribution; + seed?: number; +} +export declare class VarianceScaling extends Initializer { + static className: string; + private scale; + private mode; + private distribution; + private seed; + constructor(config: VarianceScalingConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export interface SeedOnlyInitializerConfig { + seed?: number; +} +export declare class GlorotUniform extends VarianceScaling { + constructor(config?: SeedOnlyInitializerConfig); + getClassName(): string; +} +export declare class GlorotNormal extends VarianceScaling { + constructor(config?: SeedOnlyInitializerConfig); + getClassName(): string; +} +export declare class HeNormal extends VarianceScaling { + constructor(config?: SeedOnlyInitializerConfig); + getClassName(): string; +} +export declare class LeCunNormal extends VarianceScaling { + constructor(config?: SeedOnlyInitializerConfig); + getClassName(): string; +} +export interface OrthogonalConfig extends SeedOnlyInitializerConfig { + gain?: number; +} +export declare class Orthogonal extends Initializer { + static className: string; + readonly DEFAULT_GAIN: number; + protected readonly gain: number; + protected readonly seed: number; + constructor(config?: OrthogonalConfig); + apply(shape: Shape, dtype?: DataType): Tensor; + getConfig(): serialization.ConfigDict; +} +export declare type InitializerIdentifier = 'constant' | 'glorotNormal' | 'glorotUniform' | 'heNormal' | 'identity' | 'leCunNormal' | 'ones' | 'orthogonal' | 'randomNormal' | 'randomUniform' | 'truncatedNormal' | 'varianceScaling' | 'zeros' | string; +export declare const INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP: { + [identifier in InitializerIdentifier]: string; +}; +export declare function serializeInitializer(initializer: Initializer): serialization.ConfigDictValue; +export declare function getInitializer(identifier: InitializerIdentifier | Initializer | serialization.ConfigDict): Initializer; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/initializers.js b/node_modules/@tensorflow/tfjs-layers/dist/initializers.js new file mode 100644 index 0000000..f209141 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/initializers.js @@ -0,0 +1,438 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("./backend/state"); +var K = require("./backend/tfjs_backend"); +var common_1 = require("./common"); +var errors_1 = require("./errors"); +var generic_utils_1 = require("./utils/generic_utils"); +var math_utils_1 = require("./utils/math_utils"); +exports.VALID_FAN_MODE_VALUES = ['fanIn', 'fanOut', 'fanAvg']; +function checkFanMode(value) { + generic_utils_1.checkStringTypeUnionValue(exports.VALID_FAN_MODE_VALUES, 'FanMode', value); +} +exports.checkFanMode = checkFanMode; +exports.VALID_DISTRIBUTION_VALUES = ['normal', 'uniform']; +function checkDistribution(value) { + generic_utils_1.checkStringTypeUnionValue(exports.VALID_DISTRIBUTION_VALUES, 'Distribution', value); +} +exports.checkDistribution = checkDistribution; +var Initializer = (function (_super) { + __extends(Initializer, _super); + function Initializer() { + return _super !== null && _super.apply(this, arguments) || this; + } + Initializer.prototype.fromConfigUsesCustomObjects = function () { + return false; + }; + Initializer.prototype.getConfig = function () { + return {}; + }; + return Initializer; +}(tfjs_core_1.serialization.Serializable)); +exports.Initializer = Initializer; +var Zeros = (function (_super) { + __extends(Zeros, _super); + function Zeros() { + return _super !== null && _super.apply(this, arguments) || this; + } + Zeros.prototype.apply = function (shape, dtype) { + return tfjs_core_1.zeros(shape, dtype); + }; + Zeros.className = 'Zeros'; + return Zeros; +}(Initializer)); +exports.Zeros = Zeros; +tfjs_core_1.serialization.SerializationMap.register(Zeros); +var Ones = (function (_super) { + __extends(Ones, _super); + function Ones() { + return _super !== null && _super.apply(this, arguments) || this; + } + Ones.prototype.apply = function (shape, dtype) { + return tfjs_core_1.ones(shape, dtype); + }; + Ones.className = 'Ones'; + return Ones; +}(Initializer)); +exports.Ones = Ones; +tfjs_core_1.serialization.SerializationMap.register(Ones); +var Constant = (function (_super) { + __extends(Constant, _super); + function Constant(config) { + var _this = _super.call(this) || this; + if (typeof config !== 'object') { + throw new errors_1.ValueError("Expected argument of type ConstantConfig but got " + config); + } + if (config.value === undefined) { + throw new errors_1.ValueError("config must have value set but got " + config); + } + _this.value = config.value; + return _this; + } + Constant.prototype.apply = function (shape, dtype) { + var _this = this; + return tfjs_core_1.tidy(function () { return tfjs_core_1.mul(tfjs_core_1.scalar(_this.value), tfjs_core_1.ones(shape, dtype)); }); + }; + Constant.prototype.getConfig = function () { + return { + value: this.value, + }; + }; + Constant.className = 'Constant'; + return Constant; +}(Initializer)); +exports.Constant = Constant; +tfjs_core_1.serialization.SerializationMap.register(Constant); +var RandomUniform = (function (_super) { + __extends(RandomUniform, _super); + function RandomUniform(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MINVAL = -0.05; + _this.DEFAULT_MAXVAL = 0.05; + _this.minval = config.minval || _this.DEFAULT_MINVAL; + _this.maxval = config.maxval || _this.DEFAULT_MAXVAL; + _this.seed = config.seed; + return _this; + } + RandomUniform.prototype.apply = function (shape, dtype) { + return tfjs_core_1.randomUniform(shape, this.minval, this.maxval, dtype); + }; + RandomUniform.prototype.getConfig = function () { + return { minval: this.minval, maxval: this.maxval, seed: this.seed }; + }; + RandomUniform.className = 'RandomUniform'; + return RandomUniform; +}(Initializer)); +exports.RandomUniform = RandomUniform; +tfjs_core_1.serialization.SerializationMap.register(RandomUniform); +var RandomNormal = (function (_super) { + __extends(RandomNormal, _super); + function RandomNormal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MEAN = 0.; + _this.DEFAULT_STDDEV = 0.05; + _this.mean = config.mean || _this.DEFAULT_MEAN; + _this.stddev = config.stddev || _this.DEFAULT_STDDEV; + _this.seed = config.seed; + return _this; + } + RandomNormal.prototype.apply = function (shape, dtype) { + if (dtype === 'bool') { + throw new errors_1.NotImplementedError("randomNormal does not support dType bool."); + } + return K.randomNormal(shape, this.mean, this.stddev, dtype, this.seed); + }; + RandomNormal.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }; + RandomNormal.className = 'RandomNormal'; + return RandomNormal; +}(Initializer)); +exports.RandomNormal = RandomNormal; +tfjs_core_1.serialization.SerializationMap.register(RandomNormal); +var TruncatedNormal = (function (_super) { + __extends(TruncatedNormal, _super); + function TruncatedNormal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MEAN = 0.; + _this.DEFAULT_STDDEV = 0.05; + _this.mean = config.mean || _this.DEFAULT_MEAN; + _this.stddev = config.stddev || _this.DEFAULT_STDDEV; + _this.seed = config.seed; + return _this; + } + TruncatedNormal.prototype.apply = function (shape, dtype) { + if (dtype === 'bool') { + throw new errors_1.NotImplementedError("truncatedNormal does not support dType bool."); + } + return tfjs_core_1.truncatedNormal(shape, this.mean, this.stddev, dtype, this.seed); + }; + TruncatedNormal.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }; + TruncatedNormal.className = 'TruncatedNormal'; + return TruncatedNormal; +}(Initializer)); +exports.TruncatedNormal = TruncatedNormal; +tfjs_core_1.serialization.SerializationMap.register(TruncatedNormal); +var Identity = (function (_super) { + __extends(Identity, _super); + function Identity(config) { + var _this = _super.call(this) || this; + _this.gain = config.gain != null ? tfjs_core_1.scalar(config.gain) : state_1.getScalar(1.0); + return _this; + } + Identity.prototype.apply = function (shape, dtype) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (shape.length !== 2 || shape[0] !== shape[1]) { + throw new errors_1.ValueError('Identity matrix initializer can only be used for' + + ' 2D square matrices.'); + } + else { + return tfjs_core_1.mul(_this.gain, tfjs_core_1.eye(shape[0])); + } + }); + }; + Identity.prototype.getConfig = function () { + return { gain: this.gain.get() }; + }; + Identity.className = 'Identity'; + return Identity; +}(Initializer)); +exports.Identity = Identity; +tfjs_core_1.serialization.SerializationMap.register(Identity); +function computeFans(shape, dataFormat) { + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var fanIn; + var fanOut; + common_1.checkDataFormat(dataFormat); + if (shape.length === 2) { + fanIn = shape[0]; + fanOut = shape[1]; + } + else if ([3, 4, 5].indexOf(shape.length) !== -1) { + if (dataFormat === 'channelsFirst') { + var receptiveFieldSize = math_utils_1.arrayProd(shape, 2); + fanIn = shape[1] * receptiveFieldSize; + fanOut = shape[0] * receptiveFieldSize; + } + else if (dataFormat === 'channelsLast') { + var receptiveFieldSize = math_utils_1.arrayProd(shape, 0, shape.length - 2); + fanIn = shape[shape.length - 2] * receptiveFieldSize; + fanOut = shape[shape.length - 1] * receptiveFieldSize; + } + } + else { + var shapeProd = math_utils_1.arrayProd(shape); + fanIn = Math.sqrt(shapeProd); + fanOut = Math.sqrt(shapeProd); + } + return [fanIn, fanOut]; +} +var VarianceScaling = (function (_super) { + __extends(VarianceScaling, _super); + function VarianceScaling(config) { + var _this = _super.call(this) || this; + if (config.scale < 0.0) { + throw new errors_1.ValueError("scale must be a positive float. Got: " + config.scale); + } + _this.scale = config.scale == null ? 1.0 : config.scale; + _this.mode = config.mode; + checkFanMode(_this.mode); + _this.distribution = config.distribution; + checkDistribution(_this.distribution); + _this.seed = config.seed; + return _this; + } + VarianceScaling.prototype.apply = function (shape, dtype) { + var fans = computeFans(shape); + var fanIn = fans[0]; + var fanOut = fans[1]; + var scale = this.scale; + if (this.mode === 'fanIn') { + scale /= Math.max(1, fanIn); + } + else if (this.mode === 'fanOut') { + scale /= Math.max(1, fanOut); + } + else { + scale /= Math.max(1, (fanIn + fanOut) / 2); + } + if (this.distribution === 'normal') { + var stddev = Math.sqrt(scale); + if (dtype === 'bool') { + throw new errors_1.NotImplementedError(this.getClassName() + " does not support dType bool."); + } + return tfjs_core_1.truncatedNormal(shape, 0, stddev, dtype, this.seed); + } + else { + var limit = Math.sqrt(3 * scale); + return tfjs_core_1.randomUniform(shape, -limit, limit, dtype); + } + }; + VarianceScaling.prototype.getConfig = function () { + return { + scale: this.scale, + mode: this.mode, + distribution: this.distribution, + seed: this.seed + }; + }; + VarianceScaling.className = 'VarianceScaling'; + return VarianceScaling; +}(Initializer)); +exports.VarianceScaling = VarianceScaling; +tfjs_core_1.serialization.SerializationMap.register(VarianceScaling); +var GlorotUniform = (function (_super) { + __extends(GlorotUniform, _super); + function GlorotUniform(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanAvg', + distribution: 'uniform', + seed: config == null ? null : config.seed + }) || this; + } + GlorotUniform.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return GlorotUniform; +}(VarianceScaling)); +exports.GlorotUniform = GlorotUniform; +var GlorotNormal = (function (_super) { + __extends(GlorotNormal, _super); + function GlorotNormal(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanAvg', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + GlorotNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return GlorotNormal; +}(VarianceScaling)); +exports.GlorotNormal = GlorotNormal; +var HeNormal = (function (_super) { + __extends(HeNormal, _super); + function HeNormal(config) { + return _super.call(this, { + scale: 2.0, + mode: 'fanIn', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + HeNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return HeNormal; +}(VarianceScaling)); +exports.HeNormal = HeNormal; +var LeCunNormal = (function (_super) { + __extends(LeCunNormal, _super); + function LeCunNormal(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanIn', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + LeCunNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return LeCunNormal; +}(VarianceScaling)); +exports.LeCunNormal = LeCunNormal; +var Orthogonal = (function (_super) { + __extends(Orthogonal, _super); + function Orthogonal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_GAIN = 1; + _this.gain = config.gain == null ? _this.DEFAULT_GAIN : config.gain; + _this.seed = config.seed; + if (_this.seed != null) { + throw new errors_1.NotImplementedError('Random seed is not implemented for Orthogonal Initializer yet.'); + } + return _this; + } + Orthogonal.prototype.apply = function (shape, dtype) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (shape.length !== 2) { + throw new errors_1.NotImplementedError('The Orthogonal Initializer does not support non-2D shapes yet.'); + } + if (shape[0] * shape[1] > 2000) { + console.warn("Orthogonal initializer is being called on a matrix with more " + + ("than 2000 (" + shape[0] * shape[1] + ") elements: ") + + "Slowness may result."); + } + var normalizedShape = shape[0] > shape[1] ? [shape[1], shape[0]] : shape; + var a = K.randomNormal(normalizedShape, 0, 1, 'float32'); + var q = tfjs_core_1.linalg.gramSchmidt(a); + if (shape[0] > shape[1]) { + q = q.transpose(); + } + return tfjs_core_1.mul(state_1.getScalar(_this.gain), q); + }); + }; + Orthogonal.prototype.getConfig = function () { + return { + gain: this.gain, + seed: this.seed, + }; + }; + Orthogonal.className = 'Orthogonal'; + return Orthogonal; +}(Initializer)); +exports.Orthogonal = Orthogonal; +tfjs_core_1.serialization.SerializationMap.register(Orthogonal); +exports.INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'constant': 'Constant', + 'glorotNormal': 'GlorotNormal', + 'glorotUniform': 'GlorotUniform', + 'heNormal': 'HeNormal', + 'identity': 'Identity', + 'leCunNormal': 'LeCunNormal', + 'ones': 'Ones', + 'orthogonal': 'Orthogonal', + 'randomNormal': 'RandomNormal', + 'randomUniform': 'RandomUniform', + 'truncatedNormal': 'TruncatedNormal', + 'varianceScaling': 'VarianceScaling', + 'zeros': 'Zeros' +}; +function deserializeInitializer(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return generic_utils_1.deserializeKerasObject(config, tfjs_core_1.serialization.SerializationMap.getMap().classNameMap, customObjects, 'initializer'); +} +function serializeInitializer(initializer) { + return generic_utils_1.serializeKerasObject(initializer); +} +exports.serializeInitializer = serializeInitializer; +function getInitializer(identifier) { + if (typeof identifier === 'string') { + var className = identifier in exports.INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + exports.INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + if (className === 'GlorotUniform') { + return new GlorotUniform(); + } + else if (className === 'GlorotNormal') { + return new GlorotNormal(); + } + else if (className === 'HeNormal') { + return new HeNormal(); + } + else if (className === 'LeCunNormal') { + return new LeCunNormal(); + } + else { + var config = { className: className, config: {} }; + return deserializeInitializer(config); + } + } + else if (identifier instanceof Initializer) { + return identifier; + } + else { + return deserializeInitializer(identifier); + } +} +exports.getInitializer = getInitializer; +//# sourceMappingURL=initializers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/initializers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/initializers.js.map new file mode 100644 index 0000000..03cec76 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/initializers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"initializers.js","sourceRoot":"","sources":["../src/initializers.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/initializers_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/initializers_test.js.map new file mode 100644 index 0000000..a95edca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/initializers_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"initializers_test.js","sourceRoot":"","sources":["../src/initializers_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activation_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activation_test.js.map new file mode 100644 index 0000000..f1c428a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activation_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"advanced_activation_test.js","sourceRoot":"","sources":["../../src/layers/advanced_activation_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.d.ts new file mode 100644 index 0000000..ad7b2ca --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.d.ts @@ -0,0 +1,53 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Kwargs, Shape } from '../types'; +export interface LeakyReLULayerConfig extends LayerConfig { + alpha?: number; +} +export declare class LeakyReLU extends Layer { + static className: string; + readonly alpha: number; + readonly DEFAULT_ALPHA: number; + constructor(config?: LeakyReLULayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} +export interface ELULayerConfig extends LayerConfig { + alpha?: number; +} +export declare class ELU extends Layer { + static className: string; + readonly alpha: number; + readonly DEFAULT_ALPHA: number; + constructor(config?: ELULayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} +export interface ThresholdedReLULayerConfig extends LayerConfig { + theta?: number; +} +export declare class ThresholdedReLU extends Layer { + static className: string; + readonly theta: number; + private readonly thetaTensor; + readonly DEFAULT_THETA: number; + constructor(config?: ThresholdedReLULayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} +export interface SoftmaxLayerConfig extends LayerConfig { + axis?: number; +} +export declare class Softmax extends Layer { + static className: string; + readonly axis: number; + readonly softmax: (t: Tensor, a?: number) => Tensor; + readonly DEFAULT_AXIS: number; + constructor(config?: SoftmaxLayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js new file mode 100644 index 0000000..cb7b439 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js @@ -0,0 +1,142 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var activations_1 = require("../activations"); +var tfjs_backend_1 = require("../backend/tfjs_backend"); +var topology_1 = require("../engine/topology"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var types_utils_1 = require("../utils/types_utils"); +var LeakyReLU = (function (_super) { + __extends(LeakyReLU, _super); + function LeakyReLU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_ALPHA = 0.3; + if (config == null) { + config = {}; + } + _this.alpha = config.alpha == null ? _this.DEFAULT_ALPHA : config.alpha; + return _this; + } + LeakyReLU.prototype.call = function (inputs, kwargs) { + var x = types_utils_1.getExactlyOneTensor(inputs); + return tfjs_core_1.leakyRelu(x, this.alpha); + }; + LeakyReLU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + LeakyReLU.prototype.getConfig = function () { + var config = { alpha: this.alpha }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + LeakyReLU.className = 'LeakyReLU'; + return LeakyReLU; +}(topology_1.Layer)); +exports.LeakyReLU = LeakyReLU; +tfjs_core_1.serialization.SerializationMap.register(LeakyReLU); +var ELU = (function (_super) { + __extends(ELU, _super); + function ELU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_ALPHA = 1.0; + if (config == null) { + config = {}; + } + if (config.alpha != null && config.alpha !== _this.DEFAULT_ALPHA) { + throw new errors_1.NotImplementedError("Non-default alpha value (" + config.alpha + ") is not supported by the " + + "ELU layer yet."); + } + _this.alpha = config.alpha == null ? _this.DEFAULT_ALPHA : config.alpha; + return _this; + } + ELU.prototype.call = function (inputs, kwargs) { + var x = types_utils_1.getExactlyOneTensor(inputs); + return tfjs_core_1.elu(x); + }; + ELU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + ELU.prototype.getConfig = function () { + var config = { alpha: this.alpha }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ELU.className = 'ELU'; + return ELU; +}(topology_1.Layer)); +exports.ELU = ELU; +tfjs_core_1.serialization.SerializationMap.register(ELU); +var ThresholdedReLU = (function (_super) { + __extends(ThresholdedReLU, _super); + function ThresholdedReLU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_THETA = 1.0; + if (config == null) { + config = {}; + } + _this.theta = config.theta == null ? _this.DEFAULT_THETA : config.theta; + _this.thetaTensor = state_1.getScalar(_this.theta); + return _this; + } + ThresholdedReLU.prototype.call = function (inputs, kwargs) { + var x = types_utils_1.getExactlyOneTensor(inputs); + return x.mul(tfjs_backend_1.cast(x.greater(this.thetaTensor), 'float32')); + }; + ThresholdedReLU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + ThresholdedReLU.prototype.getConfig = function () { + var config = { theta: this.theta }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ThresholdedReLU.className = 'ThresholdedReLU'; + return ThresholdedReLU; +}(topology_1.Layer)); +exports.ThresholdedReLU = ThresholdedReLU; +tfjs_core_1.serialization.SerializationMap.register(ThresholdedReLU); +var Softmax = (function (_super) { + __extends(Softmax, _super); + function Softmax(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_AXIS = 1.0; + if (config == null) { + config = {}; + } + _this.softmax = new activations_1.Softmax().apply; + _this.axis = config.axis == null ? _this.DEFAULT_AXIS : config.axis; + return _this; + } + Softmax.prototype.call = function (inputs, kwargs) { + var x = types_utils_1.getExactlyOneTensor(inputs); + return this.softmax(x, this.axis); + }; + Softmax.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + Softmax.prototype.getConfig = function () { + var config = { axis: this.axis }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Softmax.className = 'Softmax'; + return Softmax; +}(topology_1.Layer)); +exports.Softmax = Softmax; +tfjs_core_1.serialization.SerializationMap.register(Softmax); +//# sourceMappingURL=advanced_activations.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js.map new file mode 100644 index 0000000..2ce7fed --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/advanced_activations.js.map @@ -0,0 +1 @@ +{"version":3,"file":"advanced_activations.js","sourceRoot":"","sources":["../../src/layers/advanced_activations.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.d.ts new file mode 100644 index 0000000..dc1624b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.d.ts @@ -0,0 +1,144 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Activation } from '../activations'; +import { DataFormat, PaddingMode } from '../common'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { InputSpec, Layer, LayerConfig } from '../engine/topology'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, Shape } from '../types'; +import { LayerVariable } from '../variables'; +export declare function preprocessConv2DInput(x: Tensor, dataFormat: DataFormat): Tensor; +export declare function conv1dWithBias(x: Tensor, kernel: Tensor, bias: Tensor, strides?: number, padding?: string, dataFormat?: DataFormat, dilationRate?: number): Tensor; +export declare function conv1d(x: Tensor, kernel: Tensor, strides?: number, padding?: string, dataFormat?: DataFormat, dilationRate?: number): Tensor; +export declare function conv2d(x: Tensor, kernel: Tensor, strides?: number[], padding?: string, dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor; +export declare function conv2dWithBias(x: Tensor, kernel: Tensor, bias: Tensor, strides?: number[], padding?: string, dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor; +export interface BaseConvLayerConfig extends LayerConfig { + kernelSize: number | number[]; + strides?: number | number[]; + padding?: PaddingMode; + dataFormat?: DataFormat; + dilationRate?: number | [number] | [number, number]; + activation?: string; + useBias?: boolean; + kernelInitializer?: InitializerIdentifier | Initializer; + biasInitializer?: InitializerIdentifier | Initializer; + kernelConstraint?: ConstraintIdentifier | Constraint; + biasConstraint?: ConstraintIdentifier | Constraint; + kernelRegularizer?: RegularizerIdentifier | Regularizer; + biasRegularizer?: RegularizerIdentifier | Regularizer; + activityRegularizer?: RegularizerIdentifier | Regularizer; +} +export interface ConvLayerConfig extends BaseConvLayerConfig { + filters: number; +} +export declare abstract class BaseConv extends Layer { + protected readonly rank: number; + protected readonly kernelSize: number[]; + protected readonly strides: number[]; + protected readonly padding: PaddingMode; + protected readonly dataFormat: DataFormat; + protected readonly activation: Activation; + protected readonly useBias: boolean; + protected readonly dilationRate: number[]; + protected readonly biasInitializer?: Initializer; + protected readonly biasConstraint?: Constraint; + protected readonly biasRegularizer?: Regularizer; + protected bias: LayerVariable; + readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier; + readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier; + constructor(rank: number, config: BaseConvLayerConfig); + protected static verifyConfig(config: BaseConvLayerConfig): void; + getConfig(): serialization.ConfigDict; +} +export declare abstract class Conv extends BaseConv { + protected readonly filters: number; + protected kernel: LayerVariable; + protected readonly kernelInitializer?: Initializer; + protected readonly kernelConstraint?: Constraint; + protected readonly kernelRegularizer?: Regularizer; + constructor(rank: number, config: ConvLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; + protected static verifyConfig(config: ConvLayerConfig): void; +} +export declare class Conv2D extends Conv { + static className: string; + constructor(config: ConvLayerConfig); + getConfig(): serialization.ConfigDict; + protected static verifyConfig(config: ConvLayerConfig): void; +} +export declare class Conv2DTranspose extends Conv2D { + static className: string; + inputSpec: InputSpec[]; + constructor(config: ConvLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} +export interface SeparableConvLayerConfig extends ConvLayerConfig { + depthMultiplier?: number; + depthwiseInitializer?: InitializerIdentifier | Initializer; + pointwiseInitializer?: InitializerIdentifier | Initializer; + depthwiseRegularizer?: RegularizerIdentifier | Regularizer; + pointwiseRegularizer?: RegularizerIdentifier | Regularizer; + depthwiseConstraint?: ConstraintIdentifier | Constraint; + pointwiseConstraint?: ConstraintIdentifier | Constraint; +} +export declare class SeparableConv extends Conv { + static className: string; + readonly depthMultiplier: number; + protected readonly depthwiseInitializer?: Initializer; + protected readonly depthwiseRegularizer?: Regularizer; + protected readonly depthwiseConstraint?: Constraint; + protected readonly pointwiseInitializer?: Initializer; + protected readonly pointwiseRegularizer?: Regularizer; + protected readonly pointwiseConstraint?: Constraint; + readonly DEFAULT_DEPTHWISE_INITIALIZER: InitializerIdentifier; + readonly DEFAULT_POINTWISE_INITIALIZER: InitializerIdentifier; + protected depthwiseKernel: LayerVariable; + protected pointwiseKernel: LayerVariable; + constructor(rank: number, config?: SeparableConvLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class SeparableConv2D extends SeparableConv { + static className: string; + constructor(config?: SeparableConvLayerConfig); +} +export declare class Conv1D extends Conv { + static className: string; + constructor(config: ConvLayerConfig); + getConfig(): serialization.ConfigDict; + static verifyConfig(config: ConvLayerConfig): void; +} +export interface Cropping2DLayerConfig extends LayerConfig { + cropping: number | [number, number] | [[number, number], [number, number]]; + dataFormat?: DataFormat; +} +export declare class Cropping2D extends Layer { + static className: string; + protected readonly cropping: [[number, number], [number, number]]; + protected readonly dataFormat: DataFormat; + constructor(config: Cropping2DLayerConfig); + computeOutputShape(inputShape: Shape): Shape; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface UpSampling2DLayerConfig extends LayerConfig { + size?: number[]; + dataFormat?: DataFormat; +} +export declare class UpSampling2D extends Layer { + static className: string; + protected readonly DEFAULT_SIZE: number[]; + protected readonly size: number[]; + protected readonly dataFormat: DataFormat; + constructor(config: UpSampling2DLayerConfig); + computeOutputShape(inputShape: Shape): Shape; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js new file mode 100644 index 0000000..deb55b1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js @@ -0,0 +1,696 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var activations_1 = require("../activations"); +var common_1 = require("../backend/common"); +var K = require("../backend/tfjs_backend"); +var common_2 = require("../common"); +var constraints_1 = require("../constraints"); +var topology_1 = require("../engine/topology"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var conv_utils_1 = require("../utils/conv_utils"); +var generic_utils = require("../utils/generic_utils"); +var types_utils_1 = require("../utils/types_utils"); +function preprocessConv2DInput(x, dataFormat) { + return tfjs_core_1.tidy(function () { + common_2.checkDataFormat(dataFormat); + if (dataFormat === 'channelsFirst') { + return tfc.transpose(x, [0, 2, 3, 1]); + } + else { + return x; + } + }); +} +exports.preprocessConv2DInput = preprocessConv2DInput; +function conv1dWithBias(x, kernel, bias, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = 1; } + if (padding === void 0) { padding = 'valid'; } + if (dilationRate === void 0) { dilationRate = 1; } + return tfjs_core_1.tidy(function () { + if (dataFormat == null) { + dataFormat = common_1.imageDataFormat(); + } + common_2.checkDataFormat(dataFormat); + if (x.shape.length !== 3) { + throw new errors_1.ValueError("The input of a conv1dWithBias operation should be 3, but is " + + (x.shape.length + " instead.")); + } + if (kernel.shape.length !== 3) { + throw new errors_1.ValueError("The kernel for a conv1dWithBias operation should be 3, but is " + + (kernel.shape.length + " instead")); + } + if (bias != null && bias.shape.length !== 1) { + throw new errors_1.ValueError("The bias for a conv1dWithBias operation should be 1, but is " + + (kernel.shape.length + " instead")); + } + if (dataFormat === 'channelsFirst') { + x = tfc.transpose(x, [0, 2, 1]); + } + if (padding === 'causal') { + throw new errors_1.NotImplementedError('The support for CAUSAL padding mode in conv1dWithBias is not ' + + 'implemented yet.'); + } + var y = tfc.conv1d(x, kernel, strides, padding === 'same' ? 'same' : 'valid', 'NWC', dilationRate); + if (bias != null) { + y = K.biasAdd(y, bias); + } + return y; + }); +} +exports.conv1dWithBias = conv1dWithBias; +function conv1d(x, kernel, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = 1; } + if (padding === void 0) { padding = 'valid'; } + if (dilationRate === void 0) { dilationRate = 1; } + return tfjs_core_1.tidy(function () { + common_2.checkDataFormat(dataFormat); + return conv1dWithBias(x, kernel, null, strides, padding, dataFormat, dilationRate); + }); +} +exports.conv1d = conv1d; +function conv2d(x, kernel, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = [1, 1]; } + if (padding === void 0) { padding = 'valid'; } + return tfjs_core_1.tidy(function () { + common_2.checkDataFormat(dataFormat); + return conv2dWithBias(x, kernel, null, strides, padding, dataFormat, dilationRate); + }); +} +exports.conv2d = conv2d; +function conv2dWithBias(x, kernel, bias, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = [1, 1]; } + if (padding === void 0) { padding = 'valid'; } + return tfjs_core_1.tidy(function () { + if (dataFormat == null) { + dataFormat = common_1.imageDataFormat(); + } + common_2.checkDataFormat(dataFormat); + if (x.rank !== 3 && x.rank !== 4) { + throw new errors_1.ValueError("conv2dWithBias expects input to be of rank 3 or 4, but received " + + (x.rank + ".")); + } + if (kernel.rank !== 3 && kernel.rank !== 4) { + throw new errors_1.ValueError("conv2dWithBias expects kernel to be of rank 3 or 4, but received " + + (x.rank + ".")); + } + var y = preprocessConv2DInput(x, dataFormat); + if (padding === 'causal') { + throw new errors_1.NotImplementedError('The support for CAUSAL padding mode in conv1dWithBias is not ' + + 'implemented yet.'); + } + y = tfc.conv2d(y, kernel, strides, padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate); + if (bias != null) { + y = K.biasAdd(y, bias); + } + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); +} +exports.conv2dWithBias = conv2dWithBias; +var BaseConv = (function (_super) { + __extends(BaseConv, _super); + function BaseConv(rank, config) { + var _this = _super.call(this, config) || this; + _this.bias = null; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + BaseConv.verifyConfig(config); + _this.rank = rank; + if (_this.rank !== 1 && _this.rank !== 2) { + throw new errors_1.NotImplementedError("Convolution layer for rank other than 1 or 2 (" + _this.rank + ") is " + + "not implemented yet."); + } + _this.kernelSize = conv_utils_1.normalizeArray(config.kernelSize, rank, 'kernelSize'); + _this.strides = conv_utils_1.normalizeArray(config.strides == null ? 1 : config.strides, rank, 'strides'); + _this.padding = config.padding == null ? 'valid' : config.padding; + common_2.checkPaddingMode(_this.padding); + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + common_2.checkDataFormat(_this.dataFormat); + _this.activation = activations_1.getActivation(config.activation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.biasInitializer = + initializers_1.getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.biasConstraint = constraints_1.getConstraint(config.biasConstraint); + _this.biasRegularizer = regularizers_1.getRegularizer(config.biasRegularizer); + _this.activityRegularizer = regularizers_1.getRegularizer(config.activityRegularizer); + _this.dilationRate = conv_utils_1.normalizeArray(config.dilationRate == null ? 1 : config.dilationRate, rank, 'dilationRate'); + if (_this.rank === 1 && + (Array.isArray(_this.dilationRate) && + _this.dilationRate.length !== 1)) { + throw new errors_1.ValueError("dilationRate must be a number or an array of a single number " + + "for 1D convolution, but received " + + ("" + JSON.stringify(_this.dilationRate))); + } + if (_this.rank === 2) { + if (typeof _this.dilationRate === 'number') { + _this.dilationRate = [_this.dilationRate, _this.dilationRate]; + } + else if (_this.dilationRate.length !== 2) { + throw new errors_1.ValueError("dilationRate must be a number or array of two numbers for 2D " + + ("convolution, but received " + JSON.stringify(_this.dilationRate))); + } + } + return _this; + } + BaseConv.verifyConfig = function (config) { + generic_utils.assert('kernelSize' in config, "required key 'kernelSize' not in config"); + if (typeof config.kernelSize !== 'number' && + !generic_utils.checkArrayTypeAndLength(config.kernelSize, 'number', 1, 2)) + throw new errors_1.ValueError("BaseConv expects config.kernelSize to be number or number[] with " + + ("length 1 or 2, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + BaseConv.prototype.getConfig = function () { + var config = { + kernelSize: this.kernelSize, + strides: this.strides, + padding: this.padding, + dataFormat: this.dataFormat, + dilationRate: this.dilationRate, + activation: activations_1.serializeActivation(this.activation), + useBias: this.useBias, + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return BaseConv; +}(topology_1.Layer)); +exports.BaseConv = BaseConv; +var Conv = (function (_super) { + __extends(Conv, _super); + function Conv(rank, config) { + var _this = _super.call(this, rank, config) || this; + _this.kernel = null; + Conv.verifyConfig(config); + _this.filters = config.filters; + _this.kernelInitializer = initializers_1.getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.kernelConstraint = constraints_1.getConstraint(config.kernelConstraint); + _this.kernelRegularizer = regularizers_1.getRegularizer(config.kernelRegularizer); + return _this; + } + Conv.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null) { + throw new errors_1.ValueError("The channel dimension of the input should be defined. " + + ("Found " + inputShape[channelAxis])); + } + var inputDim = inputShape[channelAxis]; + var kernelShape = this.kernelSize.concat([inputDim, this.filters]); + this.kernel = this.addWeight('kernel', kernelShape, null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + this.inputSpec = [{ ndim: this.rank + 2, axes: (_a = {}, _a[channelAxis] = inputDim, _a) }]; + this.built = true; + var _a; + }; + Conv.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + var outputs; + var biasValue = _this.bias == null ? null : _this.bias.read(); + if (_this.rank === 1) { + outputs = conv1dWithBias(inputs, _this.kernel.read(), biasValue, _this.strides[0], _this.padding, _this.dataFormat, _this.dilationRate[0]); + } + else if (_this.rank === 2) { + outputs = conv2dWithBias(inputs, _this.kernel.read(), biasValue, _this.strides, _this.padding, _this.dataFormat, _this.dilationRate); + } + else if (_this.rank === 3) { + throw new errors_1.NotImplementedError('3D convolution is not implemented yet.'); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + Conv.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var newSpace = []; + var space = (this.dataFormat === 'channelsLast') ? + inputShape.slice(1, inputShape.length - 1) : + inputShape.slice(2); + for (var i = 0; i < space.length; ++i) { + var newDim = conv_utils_1.convOutputLength(space[i], this.kernelSize[i], this.padding, this.strides[i], typeof this.dilationRate === 'number' ? this.dilationRate : + this.dilationRate[i]); + newSpace.push(newDim); + } + var outputShape = [inputShape[0]]; + if (this.dataFormat === 'channelsLast') { + outputShape = outputShape.concat(newSpace); + outputShape.push(this.filters); + } + else { + outputShape.push(this.filters); + outputShape = outputShape.concat(newSpace); + } + return outputShape; + }; + Conv.prototype.getConfig = function () { + var config = { + filters: this.filters, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Conv.verifyConfig = function (config) { + if (!('filters' in config) || typeof config.filters !== 'number' || + config.filters < 1) { + throw new errors_1.ValueError("Convolution layer expected config.filters to be a 'number' > 0 " + + ("but got " + JSON.stringify(config.filters))); + } + }; + return Conv; +}(BaseConv)); +exports.Conv = Conv; +var Conv2D = (function (_super) { + __extends(Conv2D, _super); + function Conv2D(config) { + var _this = _super.call(this, 2, config) || this; + Conv2D.verifyConfig(config); + return _this; + } + Conv2D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + return config; + }; + Conv2D.verifyConfig = function (config) { + if ((typeof config.kernelSize !== 'number') && + !generic_utils.checkArrayTypeAndLength(config.kernelSize, 'number', 1, 2)) + throw new errors_1.ValueError("Conv2D expects config.kernelSize to be number or number[] with " + + ("length 1 or 2, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + Conv2D.className = 'Conv2D'; + return Conv2D; +}(Conv)); +exports.Conv2D = Conv2D; +tfjs_core_1.serialization.SerializationMap.register(Conv2D); +var Conv2DTranspose = (function (_super) { + __extends(Conv2DTranspose, _super); + function Conv2DTranspose(config) { + var _this = _super.call(this, config) || this; + _this.inputSpec = [new topology_1.InputSpec({ ndim: 4 })]; + if (_this.padding !== 'same' && _this.padding !== 'valid') { + throw new errors_1.ValueError("Conv2DTranspose currently supports only padding modes 'same' " + + ("and 'valid', but received padding mode " + _this.padding)); + } + return _this; + } + Conv2DTranspose.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + if (inputShape.length !== 4) { + throw new errors_1.ValueError('Input should have rank 4; Received input shape: ' + + JSON.stringify(inputShape)); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null) { + throw new errors_1.ValueError('The channel dimension of the inputs should be defined. ' + + 'Found `None`.'); + } + var inputDim = inputShape[channelAxis]; + var kernelShape = this.kernelSize.concat([this.filters, inputDim]); + this.kernel = this.addWeight('kernel', kernelShape, 'float32', this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], 'float32', this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + this.inputSpec = + [new topology_1.InputSpec({ ndim: 4, axes: (_a = {}, _a[channelAxis] = inputDim, _a) })]; + this.built = true; + var _a; + }; + Conv2DTranspose.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + if (input.shape.length !== 4) { + throw new errors_1.ValueError("Conv2DTranspose.call() expects input tensor to be rank-4, but " + + ("received a tensor of rank-" + input.shape.length)); + } + var inputShape = input.shape; + var batchSize = inputShape[0]; + var hAxis; + var wAxis; + if (_this.dataFormat === 'channelsFirst') { + hAxis = 2; + wAxis = 3; + } + else { + hAxis = 1; + wAxis = 2; + } + var height = inputShape[hAxis]; + var width = inputShape[wAxis]; + var kernelH = _this.kernelSize[0]; + var kernelW = _this.kernelSize[1]; + var strideH = _this.strides[0]; + var strideW = _this.strides[1]; + var outHeight = conv_utils_1.deconvLength(height, strideH, kernelH, _this.padding); + var outWidth = conv_utils_1.deconvLength(width, strideW, kernelW, _this.padding); + var outputShape = [batchSize, outHeight, outWidth, _this.filters]; + if (_this.dataFormat !== 'channelsLast') { + input = tfc.transpose(input, [0, 2, 3, 1]); + } + var outputs = tfc.conv2dTranspose(input, _this.kernel.read(), outputShape, _this.strides, _this.padding); + if (_this.dataFormat !== 'channelsLast') { + outputs = tfc.transpose(outputs, [0, 3, 1, 2]); + } + if (_this.bias != null) { + outputs = + K.biasAdd(outputs, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + Conv2DTranspose.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var outputShape = inputShape.slice(); + var channelAxis; + var heightAxis; + var widthAxis; + if (this.dataFormat === 'channelsFirst') { + channelAxis = 1; + heightAxis = 2; + widthAxis = 3; + } + else { + channelAxis = 3; + heightAxis = 1; + widthAxis = 2; + } + var kernelH = this.kernelSize[0]; + var kernelW = this.kernelSize[1]; + var strideH = this.strides[0]; + var strideW = this.strides[1]; + outputShape[channelAxis] = this.filters; + outputShape[heightAxis] = + conv_utils_1.deconvLength(outputShape[heightAxis], strideH, kernelH, this.padding); + outputShape[widthAxis] = + conv_utils_1.deconvLength(outputShape[widthAxis], strideW, kernelW, this.padding); + return outputShape; + }; + Conv2DTranspose.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['dilationRate']; + return config; + }; + Conv2DTranspose.className = 'Conv2DTranspose'; + return Conv2DTranspose; +}(Conv2D)); +exports.Conv2DTranspose = Conv2DTranspose; +tfjs_core_1.serialization.SerializationMap.register(Conv2DTranspose); +var SeparableConv = (function (_super) { + __extends(SeparableConv, _super); + function SeparableConv(rank, config) { + var _this = _super.call(this, rank, config) || this; + _this.DEFAULT_DEPTHWISE_INITIALIZER = 'glorotUniform'; + _this.DEFAULT_POINTWISE_INITIALIZER = 'glorotUniform'; + _this.depthwiseKernel = null; + _this.pointwiseKernel = null; + if (config.filters == null) { + throw new errors_1.ValueError('The `filters` configuration field is required by SeparableConv, ' + + 'but is unspecified.'); + } + if (config.kernelInitializer != null || config.kernelRegularizer != null || + config.kernelConstraint != null) { + throw new errors_1.ValueError('Fields kernelInitializer, kernelRegularizer and kernelConstraint ' + + 'are invalid for SeparableConv2D. Use depthwiseInitializer, ' + + 'depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, ' + + 'pointwiseRegularizer and pointwiseConstraint instead.'); + } + if (config.padding != null && config.padding !== 'same' && + config.padding !== 'valid') { + throw new errors_1.ValueError("SeparableConv" + _this.rank + "D supports only padding modes: " + + ("'same' and 'valid', but received " + JSON.stringify(config.padding))); + } + _this.depthMultiplier = + config.depthMultiplier == null ? 1 : config.depthMultiplier; + _this.depthwiseInitializer = initializers_1.getInitializer(config.depthwiseInitializer || _this.DEFAULT_DEPTHWISE_INITIALIZER); + _this.depthwiseRegularizer = regularizers_1.getRegularizer(config.depthwiseRegularizer); + _this.depthwiseConstraint = constraints_1.getConstraint(config.depthwiseConstraint); + _this.pointwiseInitializer = initializers_1.getInitializer(config.depthwiseInitializer || _this.DEFAULT_POINTWISE_INITIALIZER); + _this.pointwiseRegularizer = regularizers_1.getRegularizer(config.pointwiseRegularizer); + _this.pointwiseConstraint = constraints_1.getConstraint(config.pointwiseConstraint); + return _this; + } + SeparableConv.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + if (inputShape.length < this.rank + 2) { + throw new errors_1.ValueError("Inputs to SeparableConv" + this.rank + "D should have rank " + + (this.rank + 2 + ", but received input shape: ") + + ("" + JSON.stringify(inputShape))); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) { + throw new errors_1.ValueError("The channel dimension of the inputs should be defined, " + + ("but found " + JSON.stringify(inputShape[channelAxis]))); + } + var inputDim = inputShape[channelAxis]; + var depthwiseKernelShape = this.kernelSize.concat([inputDim, this.depthMultiplier]); + var pointwiseKernelShape = []; + for (var i = 0; i < this.rank; ++i) { + pointwiseKernelShape.push(1); + } + pointwiseKernelShape.push(inputDim * this.depthMultiplier, this.filters); + var trainable = true; + this.depthwiseKernel = this.addWeight('depthwise_kernel', depthwiseKernelShape, 'float32', this.depthwiseInitializer, this.depthwiseRegularizer, trainable, this.depthwiseConstraint); + this.pointwiseKernel = this.addWeight('pointwise_kernel', pointwiseKernelShape, 'float32', this.pointwiseInitializer, this.pointwiseRegularizer, trainable, this.pointwiseConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], 'float32', this.biasInitializer, this.biasRegularizer, trainable, this.biasConstraint); + } + else { + this.bias = null; + } + this.inputSpec = + [new topology_1.InputSpec({ ndim: this.rank + 2, axes: (_a = {}, _a[channelAxis] = inputDim, _a) })]; + this.built = true; + var _a; + }; + SeparableConv.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + var output; + if (_this.rank === 1) { + throw new errors_1.NotImplementedError('1D separable convolution is not implemented yet.'); + } + else if (_this.rank === 2) { + if (_this.dataFormat === 'channelsFirst') { + inputs = tfc.transpose(inputs, [0, 2, 3, 1]); + } + output = tfc.separableConv2d(inputs, _this.depthwiseKernel.read(), _this.pointwiseKernel.read(), _this.strides, _this.padding, _this.dilationRate, 'NHWC'); + } + if (_this.useBias) { + output = K.biasAdd(output, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + output = _this.activation.apply(output); + } + if (_this.dataFormat === 'channelsFirst') { + output = tfc.transpose(output, [0, 3, 1, 2]); + } + return output; + }); + }; + SeparableConv.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + delete config['kernelInitializer']; + delete config['kernelRegularizer']; + delete config['kernelConstraint']; + config['depthwiseInitializer'] = + initializers_1.serializeInitializer(this.depthwiseInitializer); + config['pointwiseInitializer'] = + initializers_1.serializeInitializer(this.pointwiseInitializer); + config['depthwiseRegularizer'] = + regularizers_1.serializeRegularizer(this.depthwiseRegularizer); + config['pointwiseRegularizer'] = + regularizers_1.serializeRegularizer(this.pointwiseRegularizer); + config['depthwiseConstraint'] = + constraints_1.serializeConstraint(this.depthwiseConstraint); + config['pointwiseConstraint'] = + constraints_1.serializeConstraint(this.pointwiseConstraint); + return config; + }; + SeparableConv.className = 'SeparableConv'; + return SeparableConv; +}(Conv)); +exports.SeparableConv = SeparableConv; +var SeparableConv2D = (function (_super) { + __extends(SeparableConv2D, _super); + function SeparableConv2D(config) { + return _super.call(this, 2, config) || this; + } + SeparableConv2D.className = 'SeparableConv2D'; + return SeparableConv2D; +}(SeparableConv)); +exports.SeparableConv2D = SeparableConv2D; +tfjs_core_1.serialization.SerializationMap.register(SeparableConv2D); +var Conv1D = (function (_super) { + __extends(Conv1D, _super); + function Conv1D(config) { + var _this = _super.call(this, 1, config) || this; + Conv1D.verifyConfig(config); + _this.inputSpec = [{ ndim: 3 }]; + return _this; + } + Conv1D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + delete config['dataFormat']; + return config; + }; + Conv1D.verifyConfig = function (config) { + if (typeof config.kernelSize !== 'number' && + !generic_utils.checkArrayTypeAndLength(config.kernelSize, 'number', 1, 1)) + throw new errors_1.ValueError("Conv1D expects config.kernelSize to be number or number[] with " + + ("length 1, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + Conv1D.className = 'Conv1D'; + return Conv1D; +}(Conv)); +exports.Conv1D = Conv1D; +tfjs_core_1.serialization.SerializationMap.register(Conv1D); +var Cropping2D = (function (_super) { + __extends(Cropping2D, _super); + function Cropping2D(config) { + var _this = _super.call(this, config) || this; + if (typeof config.cropping === 'number') + _this.cropping = [ + [config.cropping, config.cropping], [config.cropping, config.cropping] + ]; + else if (typeof config.cropping[0] === 'number') + _this.cropping = [ + [config.cropping[0], config.cropping[0]], + [config.cropping[1], config.cropping[1]] + ]; + else + _this.cropping = config.cropping; + _this.dataFormat = + config.dataFormat === undefined ? 'channelsLast' : config.dataFormat; + _this.inputSpec = [{ ndim: 4 }]; + return _this; + } + Cropping2D.prototype.computeOutputShape = function (inputShape) { + if (this.dataFormat === 'channelsFirst') + return [ + inputShape[0], inputShape[1], + inputShape[2] - this.cropping[0][0] - this.cropping[0][1], + inputShape[2] - this.cropping[1][0] - this.cropping[1][1] + ]; + else + return [ + inputShape[0], + inputShape[1] - this.cropping[0][0] - this.cropping[0][1], + inputShape[2] - this.cropping[1][0] - this.cropping[1][1], inputShape[3] + ]; + }; + Cropping2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + var hSliced = K.sliceAlongAxis(inputs, _this.cropping[0][0], inputs.shape[1] - _this.cropping[0][0] - _this.cropping[0][1], 2); + return K.sliceAlongAxis(hSliced, _this.cropping[1][0], inputs.shape[2] - _this.cropping[1][1] - _this.cropping[1][0], 3); + } + else { + var hSliced = K.sliceAlongAxis(inputs, _this.cropping[0][0], inputs.shape[2] - _this.cropping[0][0] - _this.cropping[0][1], 3); + return K.sliceAlongAxis(hSliced, _this.cropping[1][0], inputs.shape[3] - _this.cropping[1][1] - _this.cropping[1][0], 4); + } + }); + }; + Cropping2D.prototype.getConfig = function () { + var config = { cropping: this.cropping, dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Cropping2D.className = 'Cropping2D'; + return Cropping2D; +}(topology_1.Layer)); +exports.Cropping2D = Cropping2D; +tfjs_core_1.serialization.SerializationMap.register(Cropping2D); +var UpSampling2D = (function (_super) { + __extends(UpSampling2D, _super); + function UpSampling2D(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_SIZE = [2, 2]; + _this.inputSpec = [{ ndim: 4 }]; + _this.size = config.size == null ? _this.DEFAULT_SIZE : config.size; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + return _this; + } + UpSampling2D.prototype.computeOutputShape = function (inputShape) { + if (this.dataFormat === 'channelsFirst') { + var height = inputShape[2] == null ? null : this.size[0] * inputShape[2]; + var width = inputShape[3] == null ? null : this.size[1] * inputShape[3]; + return [inputShape[0], inputShape[1], height, width]; + } + else { + var height = inputShape[1] == null ? null : this.size[0] * inputShape[1]; + var width = inputShape[2] == null ? null : this.size[1] * inputShape[2]; + return [inputShape[0], height, width, inputShape[3]]; + } + }; + UpSampling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + var inputShape = input.shape; + if (_this.dataFormat === 'channelsFirst') { + input = tfc.transpose(input, [0, 2, 3, 1]); + var height = _this.size[0] * inputShape[2]; + var width = _this.size[1] * inputShape[3]; + var resized = input.resizeNearestNeighbor([height, width]); + return tfc.transpose(resized, [0, 3, 1, 2]); + } + else { + var height = _this.size[0] * inputShape[1]; + var width = _this.size[1] * inputShape[2]; + return input.resizeNearestNeighbor([height, width]); + } + }); + }; + UpSampling2D.prototype.getConfig = function () { + var config = { size: this.size, dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + UpSampling2D.className = 'UpSampling2D'; + return UpSampling2D; +}(topology_1.Layer)); +exports.UpSampling2D = UpSampling2D; +tfjs_core_1.serialization.SerializationMap.register(UpSampling2D); +//# sourceMappingURL=convolutional.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js.map new file mode 100644 index 0000000..8a6a7a1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional.js.map @@ -0,0 +1 @@ +{"version":3,"file":"convolutional.js","sourceRoot":"","sources":["../../src/layers/convolutional.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.d.ts new file mode 100644 index 0000000..e29a2ce --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.d.ts @@ -0,0 +1,28 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { DataFormat } from '../common'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, Shape } from '../types'; +import { BaseConv, BaseConvLayerConfig } from './convolutional'; +export declare function depthwiseConv2d(x: Tensor, depthwiseKernel: Tensor, strides?: [number, number], padding?: string, dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor; +export interface DepthwiseConv2DLayerConfig extends BaseConvLayerConfig { + kernelSize: number | [number, number]; + depthMultiplier?: number; + depthwiseInitializer?: InitializerIdentifier | Initializer; + depthwiseConstraint?: ConstraintIdentifier | Constraint; + depthwiseRegularizer?: RegularizerIdentifier | Regularizer; +} +export declare class DepthwiseConv2D extends BaseConv { + static className: string; + private readonly depthMultiplier; + private readonly depthwiseInitializer; + private readonly depthwiseConstraint; + private readonly depthwiseRegularizer; + private depthwiseKernel; + constructor(config: DepthwiseConv2DLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js new file mode 100644 index 0000000..89013ef --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js @@ -0,0 +1,132 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("../backend/common"); +var K = require("../backend/tfjs_backend"); +var common_2 = require("../common"); +var constraints_1 = require("../constraints"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var conv_utils_1 = require("../utils/conv_utils"); +var types_utils_1 = require("../utils/types_utils"); +var convolutional_1 = require("./convolutional"); +function depthwiseConv2d(x, depthwiseKernel, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = [1, 1]; } + if (padding === void 0) { padding = 'valid'; } + return tfjs_core_1.tidy(function () { + if (dataFormat == null) { + dataFormat = common_1.imageDataFormat(); + } + common_2.checkDataFormat(dataFormat); + var y = convolutional_1.preprocessConv2DInput(x, dataFormat); + if (x.rank !== 4) { + throw new errors_1.ValueError("Input for depthwiseConv2d is required to be 4-D, but is instead " + + (x.rank + "-D")); + } + if (depthwiseKernel.rank !== 4) { + throw new errors_1.ValueError("depthwiseKernel is required to be 4-D, but is instead " + + (depthwiseKernel.rank + "-D")); + } + y = tfc.depthwiseConv2d(y, depthwiseKernel, strides, padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate); + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); +} +exports.depthwiseConv2d = depthwiseConv2d; +var DepthwiseConv2D = (function (_super) { + __extends(DepthwiseConv2D, _super); + function DepthwiseConv2D(config) { + var _this = _super.call(this, 2, config) || this; + _this.depthwiseKernel = null; + _this.depthMultiplier = + config.depthMultiplier == null ? 1 : config.depthMultiplier; + _this.depthwiseInitializer = initializers_1.getInitializer(config.depthwiseInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.depthwiseConstraint = constraints_1.getConstraint(config.depthwiseConstraint); + _this.depthwiseRegularizer = regularizers_1.getRegularizer(config.depthwiseRegularizer); + return _this; + } + DepthwiseConv2D.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + if (inputShape.length < 4) { + throw new errors_1.ValueError("Inputs to DepthwiseConv2D should have rank 4. " + + ("Received input shape: " + JSON.stringify(inputShape) + ".")); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : 3; + if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) { + throw new errors_1.ValueError('The channel dimension of the inputs to DepthwiseConv2D should ' + + ("be defined, but is not (" + inputShape[channelAxis] + ").")); + } + var inputDim = inputShape[channelAxis]; + var depthwiseKernelShape = [ + this.kernelSize[0], this.kernelSize[1], inputDim, this.depthMultiplier + ]; + this.depthwiseKernel = this.addWeight('depthwise_kernel', depthwiseKernelShape, null, this.depthwiseInitializer, this.depthwiseRegularizer, true, this.depthwiseConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [inputDim * this.depthMultiplier], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + DepthwiseConv2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + var outputs = depthwiseConv2d(inputs, _this.depthwiseKernel.read(), _this.strides, _this.padding, _this.dataFormat, null); + if (_this.useBias) { + outputs = K.biasAdd(outputs, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + DepthwiseConv2D.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var rows = this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1]; + var cols = this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2]; + var outFilters = this.dataFormat === 'channelsFirst' ? + inputShape[1] * this.depthMultiplier : + inputShape[3] * this.depthMultiplier; + var outRows = conv_utils_1.convOutputLength(rows, this.kernelSize[0], this.padding, this.strides[0]); + var outCols = conv_utils_1.convOutputLength(cols, this.kernelSize[1], this.padding, this.strides[1]); + if (this.dataFormat === 'channelsFirst') { + return [inputShape[0], outFilters, outRows, outCols]; + } + else { + return [inputShape[0], outRows, outCols, outFilters]; + } + }; + DepthwiseConv2D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + config['depthMultiplier'] = this.depthMultiplier; + config['depthwiseInitializer'] = + initializers_1.serializeInitializer(this.depthwiseInitializer); + config['depthwiseRegularizer'] = + regularizers_1.serializeRegularizer(this.depthwiseRegularizer); + config['depthwiseConstraint'] = + constraints_1.serializeConstraint(this.depthwiseRegularizer); + return config; + }; + DepthwiseConv2D.className = 'DepthwiseConv2D'; + return DepthwiseConv2D; +}(convolutional_1.BaseConv)); +exports.DepthwiseConv2D = DepthwiseConv2D; +tfjs_core_1.serialization.SerializationMap.register(DepthwiseConv2D); +//# sourceMappingURL=convolutional_depthwise.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js.map new file mode 100644 index 0000000..e396a98 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise.js.map @@ -0,0 +1 @@ +{"version":3,"file":"convolutional_depthwise.js","sourceRoot":"","sources":["../../src/layers/convolutional_depthwise.ts"],"names":[],"mappings":";;;;;;;;;;;;AAeA,2CAA6C;AAC7C,mDAA4E;AAE5E,4CAAkD;AAElD,2CAA6C;AAC7C,oCAAsD;AACtD,8CAAoG;AACpG,oCAAqC;AACrC,gDAAyG;AACzG,gDAAyG;AAEzG,kDAAqD;AACrD,oDAA6E;AAG7E,iDAAsG;AAgBtG,yBACI,CAAS,EAAE,eAAuB,EAAE,OAAkC,EACtE,OAAiB,EAAE,UAAuB,EAC1C,YAA+B;IAFK,wBAAA,EAAA,WAA6B,CAAC,EAAE,CAAC,CAAC;IACtE,wBAAA,EAAA,iBAAiB;IAEnB,OAAO,gBAAI,CAAC;QACV,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,UAAU,GAAG,wBAAe,EAAE,CAAC;SAChC;QACD,wBAAe,CAAC,UAAU,CAAC,CAAC;QAC5B,IAAI,CAAC,GAAG,qCAAqB,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QAC7C,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;YAChB,MAAM,IAAI,mBAAU,CAChB,kEAAkE;iBAC/D,CAAC,CAAC,IAAI,OAAI,CAAA,CAAC,CAAC;SACpB;QACD,IAAI,eAAe,CAAC,IAAI,KAAK,CAAC,EAAE;YAC9B,MAAM,IAAI,mBAAU,CAChB,wDAAwD;iBACrD,eAAe,CAAC,IAAI,OAAI,CAAA,CAAC,CAAC;SAClC;QACD,CAAC,GAAG,GAAG,CAAC,eAAe,CACnB,CAAa,EAAE,eAA2B,EAAE,OAAO,EACnD,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QACjE,IAAI,UAAU,KAAK,eAAe,EAAE;YAClC,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SACpC;QACD,OAAO,CAAC,CAAC;IACX,CAAC,CAAC,CAAC;AACL,CAAC;AA5BD,0CA4BC;AA4CD;IAAqC,mCAAQ;IAS3C,yBAAY,MAAkC;QAA9C,YACE,kBAAM,CAAC,EAAE,MAAyB,CAAC,SAOpC;QAVO,qBAAe,GAAkB,IAAI,CAAC;QAI5C,KAAI,CAAC,eAAe;YAChB,MAAM,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC;QAChE,KAAI,CAAC,oBAAoB,GAAG,6BAAc,CACtC,MAAM,CAAC,oBAAoB,IAAI,KAAI,CAAC,0BAA0B,CAAC,CAAC;QACpE,KAAI,CAAC,mBAAmB,GAAG,2BAAa,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACrE,KAAI,CAAC,oBAAoB,GAAG,6BAAc,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;;IAC1E,CAAC;IAED,+BAAK,GAAL,UAAM,UAAyB;QAC7B,UAAU,GAAG,gCAAkB,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,MAAM,IAAI,mBAAU,CAChB,gDAAgD;iBAChD,2BAAyB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,MAAG,CAAA,CAAC,CAAC;SAC7D;QACD,IAAM,WAAW,GAAG,IAAI,CAAC,UAAU,KAAK,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,IAAI,UAAU,CAAC,WAAW,CAAC,IAAI,IAAI,IAAI,UAAU,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE;YAClE,MAAM,IAAI,mBAAU,CAChB,gEAAgE;iBAChE,6BAA2B,UAAU,CAAC,WAAW,CAAC,OAAI,CAAA,CAAC,CAAC;SAC7D;QACD,IAAM,QAAQ,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;QACzC,IAAM,oBAAoB,GAAU;YAClC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,eAAe;SACvE,CAAC;QAEF,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CACjC,kBAAkB,EAAE,oBAAoB,EAAE,IAAI,EAC9C,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,EAC1D,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC9B,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CACtB,MAAM,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,eAAe,EACrE,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;SACtD;aAAM;YACL,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SAClB;QACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,8BAAI,GAAJ,UAAK,MAAuB,EAAE,MAAc;QAA5C,iBAeC;QAdC,OAAO,gBAAI,CAAC;YACV,MAAM,GAAG,iCAAmB,CAAC,MAAM,CAAC,CAAC;YACrC,IAAI,OAAO,GAAG,eAAe,CACzB,MAAM,EAAE,KAAI,CAAC,eAAe,CAAC,IAAI,EAAE,EAAE,KAAI,CAAC,OAA2B,EACrE,KAAI,CAAC,OAAO,EAAE,KAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;YAEzC,IAAI,KAAI,CAAC,OAAO,EAAE;gBAChB,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,KAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,KAAI,CAAC,UAAU,CAAC,CAAC;aACjE;YACD,IAAI,KAAI,CAAC,UAAU,IAAI,IAAI,EAAE;gBAC3B,OAAO,GAAG,KAAI,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aAC1C;YACD,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,4CAAkB,GAAlB,UAAmB,UAAyB;QAC1C,UAAU,GAAG,gCAAkB,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAM,IAAI,GACN,IAAI,CAAC,UAAU,KAAK,eAAe,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACxE,IAAM,IAAI,GACN,IAAI,CAAC,UAAU,KAAK,eAAe,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACxE,IAAM,UAAU,GAAG,IAAI,CAAC,UAAU,KAAK,eAAe,CAAC,CAAC;YACpD,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;YACtC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC;QACzC,IAAM,OAAO,GAAG,6BAAgB,CAC5B,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAM,OAAO,GAAG,6BAAgB,CAC5B,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAI,IAAI,CAAC,UAAU,KAAK,eAAe,EAAE;YACvC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;SACtD;aAAM;YAEL,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;SACtD;IACH,CAAC;IAED,mCAAS,GAAT;QACE,IAAM,MAAM,GAAG,iBAAM,SAAS,WAAE,CAAC;QACjC,MAAM,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC;QACjD,MAAM,CAAC,sBAAsB,CAAC;YAC1B,mCAAoB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACpD,MAAM,CAAC,sBAAsB,CAAC;YAC1B,mCAAoB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACpD,MAAM,CAAC,qBAAqB,CAAC;YACzB,iCAAmB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACnD,OAAO,MAAM,CAAC;IAChB,CAAC;IAlGM,yBAAS,GAAG,iBAAiB,CAAC;IAmGvC,sBAAC;CAAA,AApGD,CAAqC,wBAAQ,GAoG5C;AApGY,0CAAe;AAqG5B,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise_test.js.map new file mode 100644 index 0000000..cf2ef6e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_depthwise_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"convolutional_depthwise_test.js","sourceRoot":"","sources":["../../src/layers/convolutional_depthwise_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_test.js.map new file mode 100644 index 0000000..6ba2ae5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/convolutional_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"convolutional_test.js","sourceRoot":"","sources":["../../src/layers/convolutional_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/core.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.d.ts new file mode 100644 index 0000000..cc5513e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.d.ts @@ -0,0 +1,97 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Activation as ActivationFn, ActivationIdentifier } from '../activations'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, Shape } from '../types'; +export interface DropoutLayerConfig extends LayerConfig { + rate: number; + noiseShape?: number[]; + seed?: number; +} +export declare class Dropout extends Layer { + static className: string; + private readonly rate; + private readonly rateScalar; + private readonly noiseShape; + private readonly seed; + constructor(config: DropoutLayerConfig); + private getNoiseShape(input); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface DenseLayerConfig extends LayerConfig { + units: number; + activation?: ActivationIdentifier; + useBias?: boolean; + kernelInitializer?: InitializerIdentifier | Initializer; + biasInitializer?: InitializerIdentifier | Initializer; + inputDim?: number; + kernelConstraint?: ConstraintIdentifier | Constraint; + biasConstraint?: ConstraintIdentifier | Constraint; + kernelRegularizer?: RegularizerIdentifier | Regularizer; + biasRegularizer?: RegularizerIdentifier | Regularizer; + activityRegularizer?: RegularizerIdentifier | Regularizer; +} +export declare class Dense extends Layer { + static className: string; + private units; + private activation; + private useBias; + private kernelInitializer; + private biasInitializer; + private kernel; + private bias; + readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier; + readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier; + private readonly kernelConstraint?; + private readonly biasConstraint?; + private readonly kernelRegularizer?; + private readonly biasRegularizer?; + constructor(config: DenseLayerConfig); + build(inputShape: Shape | Shape[]): void; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class Flatten extends Layer { + static className: string; + constructor(config?: LayerConfig); + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export interface ActivationLayerConfig extends LayerConfig { + activation: ActivationIdentifier; +} +export declare class Activation extends Layer { + static className: string; + activation: ActivationFn; + constructor(config: ActivationLayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface ReshapeLayerConfig extends LayerConfig { + targetShape: Shape; +} +export interface RepeatVectorLayerConfig extends LayerConfig { + n: number; +} +export declare class RepeatVector extends Layer { + static className: string; + readonly n: number; + constructor(config: RepeatVectorLayerConfig); + computeOutputShape(inputShape: Shape): Shape; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class Reshape extends Layer { + static className: string; + private targetShape; + constructor(config: ReshapeLayerConfig); + private isUnknown(dim); + private fixUnknownDimension(inputShape, outputShape); + computeOutputShape(inputShape: Shape): Shape; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js new file mode 100644 index 0000000..bec84f6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js @@ -0,0 +1,348 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var activations_1 = require("../activations"); +var K = require("../backend/tfjs_backend"); +var constraints_1 = require("../constraints"); +var topology_1 = require("../engine/topology"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var math_utils = require("../utils/math_utils"); +var types_utils_1 = require("../utils/types_utils"); +var Dropout = (function (_super) { + __extends(Dropout, _super); + function Dropout(config) { + var _this = _super.call(this, config) || this; + _this.rate = Math.max(Math.min(config.rate, 1), 0); + _this.rateScalar = state_1.getScalar(_this.rate); + _this.noiseShape = config.noiseShape; + _this.seed = config.seed; + if (_this.seed != null) { + throw new errors_1.NotImplementedError('Non-default seed is not implemented in Dropout layer yet: ' + + _this.seed); + } + _this.supportsMasking = true; + return _this; + } + Dropout.prototype.getNoiseShape = function (input) { + if (this.noiseShape == null) { + return this.noiseShape; + } + var inputShape = input.shape; + var noiseShape = []; + for (var i = 0; i < this.noiseShape.length; ++i) { + noiseShape.push(this.noiseShape[i] == null ? inputShape[i] : this.noiseShape[i]); + } + return noiseShape; + }; + Dropout.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = types_utils_1.getExactlyOneTensor(inputs); + if (_this.noiseShape != null && + !tfjs_core_1.util.arraysEqual(input.shape, _this.noiseShape)) { + throw new errors_1.NotImplementedError('Non-default noise shape is not implemented in Dropout ' + + 'layer yet: ' + JSON.stringify(_this.noiseShape)); + } + if (0 < _this.rate && _this.rate < 1) { + var training = kwargs['training'] == null ? false : kwargs['training']; + var noiseShape_1 = _this.getNoiseShape(input); + var output = K.inTrainPhase(function () { return K.dropout(input, _this.rateScalar, noiseShape_1, _this.seed); }, function () { return input; }, training); + return output; + } + return inputs; + }); + }; + Dropout.prototype.getConfig = function () { + var config = { + rate: this.rate, + noiseShape: this.noiseShape, + seed: this.seed, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Dropout.className = 'Dropout'; + return Dropout; +}(topology_1.Layer)); +exports.Dropout = Dropout; +tfjs_core_1.serialization.SerializationMap.register(Dropout); +var Dense = (function (_super) { + __extends(Dense, _super); + function Dense(config) { + var _this = _super.call(this, config) || this; + _this.activation = null; + _this.useBias = true; + _this.kernel = null; + _this.bias = null; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + if (config.batchInputShape == null && config.inputShape == null && + config.inputDim != null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + _this.batchInputShape = [batchSize, config.inputDim]; + } + _this.units = config.units; + _this.activation = activations_1.getActivation(config.activation); + if (config.useBias != null) { + _this.useBias = config.useBias; + } + _this.kernelInitializer = initializers_1.getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.biasInitializer = + initializers_1.getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelConstraint = constraints_1.getConstraint(config.kernelConstraint); + _this.biasConstraint = constraints_1.getConstraint(config.biasConstraint); + _this.kernelRegularizer = regularizers_1.getRegularizer(config.kernelRegularizer); + _this.biasRegularizer = regularizers_1.getRegularizer(config.biasRegularizer); + _this.activityRegularizer = regularizers_1.getRegularizer(config.activityRegularizer); + _this.inputSpec = [{ minNDim: 2 }]; + return _this; + } + Dense.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var inputLastDim = inputShape[inputShape.length - 1]; + if (this.kernel == null) { + this.kernel = this.addWeight('kernel', [inputLastDim, this.units], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + } + this.inputSpec = [{ minNDim: 2, axes: (_a = {}, _a[-1] = inputLastDim, _a) }]; + this.built = true; + var _a; + }; + Dense.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var outputShape = inputShape.slice(); + outputShape[outputShape.length - 1] = this.units; + return outputShape; + }; + Dense.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = types_utils_1.getExactlyOneTensor(inputs); + var output = K.dot(input, _this.kernel.read()); + if (_this.bias != null) { + output = K.biasAdd(output, _this.bias.read()); + } + if (_this.activation != null) { + output = _this.activation.apply(output); + } + return output; + }); + }; + Dense.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Dense.className = 'Dense'; + return Dense; +}(topology_1.Layer)); +exports.Dense = Dense; +tfjs_core_1.serialization.SerializationMap.register(Dense); +var Flatten = (function (_super) { + __extends(Flatten, _super); + function Flatten(config) { + var _this = _super.call(this, config || {}) || this; + _this.inputSpec = [{ minNDim: 3 }]; + return _this; + } + Flatten.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + for (var _i = 0, _a = inputShape.slice(1); _i < _a.length; _i++) { + var dim = _a[_i]; + if (dim == null) { + throw new errors_1.ValueError("The shape of the input to \"Flatten\" is not fully defined " + + ("(got " + inputShape.slice(1) + "). Make sure to pass a complete ") + + "\"input_shape\" or \"batch_input_shape\" argument to the first " + + "layer in your model."); + } + } + return [inputShape[0], math_utils.arrayProd(inputShape, 1)]; + }; + Flatten.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + return K.batchFlatten(types_utils_1.getExactlyOneTensor(inputs)); + }); + }; + Flatten.className = 'Flatten'; + return Flatten; +}(topology_1.Layer)); +exports.Flatten = Flatten; +tfjs_core_1.serialization.SerializationMap.register(Flatten); +var Activation = (function (_super) { + __extends(Activation, _super); + function Activation(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + _this.activation = activations_1.getActivation(config.activation); + return _this; + } + Activation.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = types_utils_1.getExactlyOneTensor(inputs); + return _this.activation.apply(input); + }); + }; + Activation.prototype.getConfig = function () { + var config = { activation: activations_1.serializeActivation(this.activation) }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Activation.className = 'Activation'; + return Activation; +}(topology_1.Layer)); +exports.Activation = Activation; +tfjs_core_1.serialization.SerializationMap.register(Activation); +var RepeatVector = (function (_super) { + __extends(RepeatVector, _super); + function RepeatVector(config) { + var _this = _super.call(this, config) || this; + _this.n = config.n; + _this.inputSpec = [{ ndim: 2 }]; + return _this; + } + RepeatVector.prototype.computeOutputShape = function (inputShape) { + return [inputShape[0], this.n, inputShape[1]]; + }; + RepeatVector.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + return K.repeat(inputs, _this.n); + }); + }; + RepeatVector.prototype.getConfig = function () { + var config = { + n: this.n, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + RepeatVector.className = 'RepeatVector'; + return RepeatVector; +}(topology_1.Layer)); +exports.RepeatVector = RepeatVector; +tfjs_core_1.serialization.SerializationMap.register(RepeatVector); +var Reshape = (function (_super) { + __extends(Reshape, _super); + function Reshape(config) { + var _this = _super.call(this, config) || this; + _this.targetShape = config.targetShape; + for (var i = 0; i < _this.targetShape.length; ++i) { + if (_this.isUnknown(_this.targetShape[i])) { + _this.targetShape[i] = null; + } + } + return _this; + } + Reshape.prototype.isUnknown = function (dim) { + return dim < 0 || dim == null; + }; + Reshape.prototype.fixUnknownDimension = function (inputShape, outputShape) { + var errorMsg = 'Total size of new array must be unchanged.'; + var finalShape = outputShape.slice(); + var known = 1; + var unknown = null; + for (var i = 0; i < finalShape.length; ++i) { + var dim = finalShape[i]; + if (this.isUnknown(dim)) { + if (unknown === null) { + unknown = i; + } + else { + throw new errors_1.ValueError('Can only specifiy one unknown dimension.'); + } + } + else { + known *= dim; + } + } + var originalSize = math_utils.arrayProd(inputShape); + if (unknown !== null) { + if (known === 0 || originalSize % known !== 0) { + throw new errors_1.ValueError(errorMsg); + } + finalShape[unknown] = originalSize / known; + } + else if (originalSize !== known) { + throw new errors_1.ValueError(errorMsg); + } + return finalShape; + }; + Reshape.prototype.computeOutputShape = function (inputShape) { + var anyUnknownDims = false; + for (var i = 0; i < inputShape.length; ++i) { + if (this.isUnknown(inputShape[i])) { + anyUnknownDims = true; + break; + } + } + if (anyUnknownDims) { + return inputShape.slice(0, 1).concat(this.targetShape); + } + else { + return inputShape.slice(0, 1).concat(this.fixUnknownDimension(inputShape.slice(1), this.targetShape)); + } + }; + Reshape.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = types_utils_1.getExactlyOneTensor(inputs); + var inputShape = input.shape; + var outputShape = inputShape.slice(0, 1).concat(_this.fixUnknownDimension(inputShape.slice(1), _this.targetShape)); + return input.reshape(outputShape); + }); + }; + Reshape.prototype.getConfig = function () { + var config = { + targetShape: this.targetShape, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Reshape.className = 'Reshape'; + return Reshape; +}(topology_1.Layer)); +exports.Reshape = Reshape; +tfjs_core_1.serialization.SerializationMap.register(Reshape); +//# sourceMappingURL=core.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js.map new file mode 100644 index 0000000..601ae57 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/core.js.map @@ -0,0 +1 @@ +{"version":3,"file":"core.js","sourceRoot":"","sources":["../../src/layers/core.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/core_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/core_test.js.map new file mode 100644 index 0000000..9830646 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/core_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"core_test.js","sourceRoot":"","sources":["../../src/layers/core_test.ts"],"names":[],"mappings":";;AAeA,mDAAqG;AAGrG,2CAA6C;AAC7C,8BAAgC;AAEhC,wDAAoD;AACpD,kDAA8C;AAC9C,oEAAsF;AACtF,kDAA+F;AAE/F,+BAAyD;AAGzD,QAAQ,CAAC,yBAAyB,EAAE;IAClC,IAAM,YAAY,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC9B,IAAM,cAAc,GAAG;QACrB,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC1D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC9D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;KAC7D,CAAC;4BAES,IAAI;gCACF,aAAa;YACtB,IAAM,SAAS,GAAG,iBAAe,IAAI,OAAI;iBACrC,iBAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAG,CAAA,CAAC;YACzD,EAAE,CAAC,SAAS,EAAE;gBACZ,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAC,IAAI,MAAA,EAAC,CAAC,CAAC;gBAChD,IAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;gBACvE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAClD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAClD,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;gBACjD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;QACL,CAAC;QAXD,KAA4B,UAAc,EAAd,iCAAc,EAAd,4BAAc,EAAd,IAAc;YAArC,IAAM,aAAa,uBAAA;oBAAb,aAAa;SAWvB;IACH,CAAC;IAbD,KAAmB,UAAY,EAAZ,6BAAY,EAAZ,0BAAY,EAAZ,IAAY;QAA1B,IAAM,IAAI,qBAAA;gBAAJ,IAAI;KAad;AACH,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,eAAe,EAAE;IACrC,QAAQ,CAAC,QAAQ,EAAE;QACjB,IAAM,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7B,IAAM,cAAc,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACrC,IAAM,YAAY,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC9B,IAAM,WAAW,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;gCAG5B,QAAQ;oCACN,IAAI;wCACF,UAAU;oBACnB,IAAM,SAAS,GAAG,cAAY,QAAQ,sBAAiB,IAAI,OAAI;yBAC3D,gBAAc,IAAI,CAAC,SAAS,CAAC,UAAU,CAAG,CAAA,CAAC;oBAC/C,EAAE,CAAC,SAAS,EAAE;wBACZ,IAAM,CAAC,GAAG,gBAAI,CAAC,UAAU,CAAC,CAAC;wBAC3B,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAC,IAAI,MAAA,EAAE,UAAU,YAAA,EAAC,CAAC,CAAC;wBAC5D,IAAM,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,EAAC,QAAQ,UAAA,EAAC,CAAW,CAAC;wBACtD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;wBACjC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;wBACjC,IAAM,MAAM,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;wBAC5B,IAAM,MAAM,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;wBAC5B,IAAI,KAAK,GAAG,CAAC,CAAC;wBACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;4BACtC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;gCACnB,KAAK,EAAE,CAAC;gCACR,IAAI,QAAQ,EAAE;oCACZ,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;iCAC/C;qCAAM;oCACL,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;iCAClC;6BACF;yBACF;wBACD,IAAM,KAAK,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;wBAC/B,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE;4BAC3B,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;yBAC9B;6BAAM;4BACL,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;yBACnC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC;gBA7BD,KAAyB,UAAW,EAAX,2BAAW,EAAX,yBAAW,EAAX,IAAW;oBAA/B,IAAM,UAAU,oBAAA;4BAAV,UAAU;iBA6BpB;YACH,CAAC;YA/BD,KAAmB,UAAY,EAAZ,6BAAY,EAAZ,0BAAY,EAAZ,IAAY;gBAA1B,IAAM,IAAI,qBAAA;wBAAJ,IAAI;aA+Bd;QACH,CAAC;QAjCD,KAAuB,UAAc,EAAd,iCAAc,EAAd,4BAAc,EAAd,IAAc;YAAhC,IAAM,QAAQ,uBAAA;oBAAR,QAAQ;SAiClB;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,4BAAe,CAAC,uBAAuB,EAAE;IACvC,IAAM,KAAK,GAAG,CAAC,CAAC;IAChB,IAAM,WAAW,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IACxD,IAAM,cAAc,GAAG;QACrB,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC1D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC9D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAClE,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC5D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAChE,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;KACrE,CAAC;4BAES,UAAU;gCACR,aAAa;YACtB,EAAE,CAAC,qCAAqC;iBACjC,gBAAc,UAAU,OAAI,CAAA;iBAC5B,iBAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAG,CAAA,EACxD;gBACE,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,OAAA,EAAE,UAAU,YAAA,EAAC,CAAC,CAAC;gBACzD,IAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;gBAErE,IAAM,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC;gBAC1C,aAAa,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;gBAChD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;gBAC5C,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAC/C,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;QACR,CAAC;QAdD,KAA4B,UAAc,EAAd,iCAAc,EAAd,4BAAc,EAAd,IAAc;YAArC,IAAM,aAAa,uBAAA;oBAAb,aAAa;SAcvB;IACH,CAAC;IAhBD,KAAyB,UAAW,EAAX,2BAAW,EAAX,yBAAW,EAAX,IAAW;QAA/B,IAAM,UAAU,oBAAA;gBAAV,UAAU;KAgBpB;IAED,EAAE,CAAC,yCAAyC,EAAE;QAC5C,IAAM,MAAM,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC5E,IAAM,WAAW,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,MAAM,CAAuB,CAAC;QAEhE,IAAM,WAAW,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,OAAO,CAAuB,CAAC;QAEjE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,KAAK,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACrE,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QAChD,MAAM,CAAC,cAAM,OAAA,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,EAAvB,CAAuB,CAAC,CAAC,YAAY,EAAE,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;QAC9C,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC5E,IAAM,MAAM,GACR,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACpE,IAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAuB,CAAC;QAC/D,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAEzC,IAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAuB,CAAC;QAC/D,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE;QACzC,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC5E,IAAM,MAAM,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC5E,IAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAuB,CAAC;QAC/D,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAEzC,MAAM,CAAC;YAEL,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC,YAAY,CAAC,oCAAoC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,MAAM,CAAC;YAEL,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,iBAAiB,EAAE,sBAAsB,EAAC,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE;QACvB,MAAM,CAAC;YAEL,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,oBAAoB,EAAC,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,qBAAqB,EAAE;IAC3C,IAAM,KAAK,GAAG,CAAC,CAAC;IAChB,IAAM,SAAS,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IACtC,IAAM,gBAAgB,GAA4B,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACpE,IAAM,WAAW,GACb,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IACxC,IAAM,aAAa,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;4BAIlB,OAAO;gCACL,eAAe;qCACb,UAAU;yCACR,YAAY;oBACrB,EAAE,CAAC,wBAAsB,OAAO,OAAI;yBAC7B,qBAAmB,eAAe,OAAI,CAAA;yBACtC,gBAAc,UAAU,OAAI,CAAA;yBAC5B,kBAAgB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAG,CAAA,EAClD;wBACE,IAAM,KAAK,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC;wBACtC,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC;4BAClC,KAAK,OAAA;4BACL,OAAO,SAAA;4BACP,eAAe,iBAAA;4BACf,UAAU,YAAA;4BACV,iBAAiB,EAAE,MAAM;yBAC1B,CAAC,CAAC;wBACH,IAAI,oBAA4B,CAAC;wBACjC,IAAI,UAAU,KAAK,SAAS,EAAE;4BAC5B,oBAAoB,GAAG,CAAC,GAAG,KAAK,CAAC;yBAClC;6BAAM;4BACL,oBAAoB,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;4BAC3D,IAAI,OAAO,KAAK,KAAK,IAAI,eAAe,KAAK,MAAM,EAAE;gCACnD,oBAAoB,IAAI,CAAC,CAAC;6BAC3B;yBACF;wBACD,IAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;wBAC1C,aAAa,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;wBAChD,IAAI,cAAc,CAAC;wBACnB,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;4BACpB,cAAc,GAAG,oBAAQ,CACrB,4BAAY,CACR,oBAAoB,EAAE,sBAAS,CAAC,aAAa,CAAC,CAAC,EACnD,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;yBAC3C;wBACD,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;oBAC/D,CAAC,CAAC,CAAC;gBACR,CAAC;gBAnCD,KAA2B,UAAa,EAAb,+BAAa,EAAb,2BAAa,EAAb,IAAa;oBAAnC,IAAM,YAAY,sBAAA;6BAAZ,YAAY;iBAmCtB;YACH,CAAC;YArCD,KAAyB,UAAW,EAAX,2BAAW,EAAX,yBAAW,EAAX,IAAW;gBAA/B,IAAM,UAAU,oBAAA;yBAAV,UAAU;aAqCpB;QACH,CAAC;QAvCD,KAA8B,UAAgB,EAAhB,qCAAgB,EAAhB,8BAAgB,EAAhB,IAAgB;YAAzC,IAAM,eAAe,yBAAA;oBAAf,eAAe;SAuCzB;IACH,CAAC;IAzCD,KAAsB,UAAS,EAAT,uBAAS,EAAT,uBAAS,EAAT,IAAS;QAA1B,IAAM,OAAO,kBAAA;gBAAP,OAAO;KAyCjB;IAED,EAAE,CAAC,4DAA4D,EAAE;QAC/D,IAAM,MAAM,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAM,MAAM,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAM,MAAM,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE5B,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,iBAAiB,EAAE,MAAM,EAAC,CAAC,CAAC;QAC3E,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,MAAM,CAAW,EAClC,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAChD,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,MAAM,CAAW,EAClC,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,MAAM,CAAC,cAAM,OAAA,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,EAAxB,CAAwB,CAAC,CAAC,YAAY,EAAE,CAAC;IACxD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,uEAAuE,EACvE;QACE,IAAM,aAAa,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAM,UAAU,GACZ,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,iBAAiB,EAAE,MAAM,EAAC,CAAC,CAAC;QAE5D,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,aAAa,CAAW,EACzC,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhD,IAAM,cAAc,GAChB,UAAU,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;QAC1D,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QACvD,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IACN,EAAE,CAAC,6DAA6D,EAAE;QAChE,IAAM,aAAa,GAAG,gBAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAC,KAAK,EAAE,CAAC,EAAE,iBAAiB,EAAE,MAAM,EAAC,CAAC,CAAC;QAE3E,+BAAkB,CACd,UAAU,CAAC,KAAK,CAAC,aAAa,CAAW,EACzC,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhD,MAAM,CAAC;YAEL,UAAU,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC,YAAY,CAAC,oCAAoC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE;IAClC,IAAM,cAAc,GAAG;QACrB,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAC9D,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAClE,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;QAChE,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC;KACrE,CAAC;6BAES,aAAa;QACtB,EAAE,CAAC,yDAAyD;aACrD,iBAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAG,CAAA,EACxD;YACE,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAC1C,IAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;YACvE,IAAM,aAAa,GACf,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,sBAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;YAChE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC5C,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACjD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,gEAAgE;aAC5D,iBAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAG,CAAA,EACxD;YACE,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5C,IAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;YACvE,IAAM,aAAa,GACf,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,sBAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;YAChE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC5C,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACjD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACR,CAAC;IAxBD,KAA4B,UAAc,EAAd,iCAAc,EAAd,4BAAc,EAAd,IAAc;QAArC,IAAM,aAAa,uBAAA;iBAAb,aAAa;KAwBvB;IAED,EAAE,CAAC,sCAAsC,EAAE;QACzC,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAM,CAAC,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACvE,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,EAArB,CAAqB,CAAC,CAAC,YAAY,EAAE,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE;QACnD,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5C,IAAM,CAAC,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,EAArB,CAAqB,CAAC,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,uBAAuB,EAAE;IAC7C,EAAE,CAAC,6CAA6C,EAAE;QAChD,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,EAArB,CAAqB,CAAC,CAAC,YAAY,EAAE,CAAC;IACrD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,mBAAmB,EAAE;QACtB,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,cAAc,GAChB,oBAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/D,+BAAkB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,mBAAmB,EAAE;QACtB,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAM,CAAC,GAAG,oBAAQ,CACd;YACE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAChD,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;SACzC,EACD,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClB,IAAM,cAAc,GAAG,oBAAQ,CAC3B,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAChE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,+BAAkB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,0BAA0B,EAAE;IAChD,IAAM,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC;IAEvB,EAAE,CAAC,QAAQ,EAAE;QACX,IAAM,CAAC,GAAG,eAAG,CAAC,kBAAM,CAAC,EAAE,CAAC,EAAE,gBAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC5C,IAAM,KAAK,GAAG,IAAI,iBAAU,CAAC,EAAC,UAAU,EAAE,QAAQ,EAAC,CAAC,CAAC;QACrD,IAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC;QACxC,+BAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,MAAM,EAAE;QACT,IAAM,CAAC,GAAG,eAAG,CAAC,kBAAM,CAAC,CAAC,CAAC,CAAC,EAAE,gBAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC5C,IAAM,aAAa,GAAG,iBAAK,CAAC,UAAU,CAAC,CAAC;QACxC,IAAM,KAAK,GAAG,IAAI,iBAAU,CAAC,EAAC,UAAU,EAAE,MAAM,EAAC,CAAC,CAAC;QACnD,IAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC;QACxC,+BAAkB,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QACZ,IAAM,GAAG,GAAG,EAAE,CAAC;QACf,IAAM,CAAC,GAAG,eAAG,CAAC,kBAAM,CAAC,GAAG,CAAC,EAAE,gBAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC7C,IAAM,aAAa,GAAG,eAAG,CACrB,kBAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,gBAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC5D,IAAM,KAAK,GAAG,IAAI,iBAAU,CAAC,EAAC,UAAU,EAAE,SAAS,EAAC,CAAC,CAAC;QACtD,IAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC;QACxC,+BAAkB,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QACZ,IAAM,CAAC,GAAG,eAAG,CAAC,kBAAM,CAAC,EAAE,CAAC,EAAE,gBAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC5C,IAAM,aAAa,GAAG,gBAAI,CAAC,UAAU,CAAC,CAAC;QACvC,IAAM,KAAK,GAAG,IAAI,iBAAU,CAAC,EAAC,UAAU,EAAE,SAAS,EAAC,CAAC,CAAC;QACtD,IAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC;QACxC,+BAAkB,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,EAAC,UAAU,EAAE,MAAM,EAAC,CAAC,CAAC;QAC1D,IAAM,cAAc,GAAG,yCAAmB,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;QAE9D,IAAM,QAAQ,GAAG,yCAAmB,CAAC,cAAc,CAAQ,CAAC;QAC5D,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QACnD,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,8BAA8B,EAAE;IACvC,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAM,iBAAiB,GAAG,IAAI,mBAAY,CAAC,EAAC,CAAC,EAAE,CAAC,EAAC,CAAC,CAAC;QACnD,IAAM,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;QAC5E,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACtD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,4BAA4B,EAAE;IAClD,EAAE,CAAC,gBAAgB,EAAE;QACnB,IAAM,iBAAiB,GAAG,IAAI,mBAAY,CAAC,EAAC,CAAC,EAAE,CAAC,EAAC,CAAC,CAAC;QACnD,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,cAAc,GAAG,oBAAQ,CAC3B,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAChE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACf,+BAAkB,CACd,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE;IAClC,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3B,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;QACvE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAC9B,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAAuB,CAAC;QACvE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE;QACvB,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3B,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;QAChD,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC,EAAjC,CAAiC,CAAC;aAC1C,YAAY,CAAC,2CAA2C,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;QAC5B,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,IAAM,WAAW,GAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC3C,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;QAChD,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC,EAAjC,CAAiC,CAAC;aAC1C,YAAY,CAAC,yCAAyC,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE;QACvC,IAAM,aAAa,GACf,IAAI,GAAG,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAC9B,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,aAAA,EAAC,CAAC,CAAC;QAChD,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC,EAAjC,CAAiC,CAAC;aAC1C,YAAY,CAAC,2CAA2C,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;QAC7B,IAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;QACxD,IAAM,cAAc,GAAG,yCAAmB,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;QAE9D,IAAM,QAAQ,GAAG,yCAAmB,CAAC,cAAc,CAAQ,CAAC;QAC5D,IAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,uBAAuB,EAAE;IAC7C,EAAE,CAAC,oDAAoD,EAAE;QACvD,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;QACxD,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,cAAc,GAChB,oBAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9D,+BAAkB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE;QACvD,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC;QACrD,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,IAAM,cAAc,GAChB,oBAAQ,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,+BAAkB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE;QACvD,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;QACxD,IAAM,CAAC,GAAG,oBAAQ,CACd,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACxE,IAAM,cAAc,GAAG,oBAAQ,CAC3B,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACvE,+BAAkB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;6BAEQ,UAAU;QACnB,EAAE,CAAC,6DAA2D,UAAY,EACvE;YACE,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,EAAC,CAAC,CAAC;YACjE,IAAM,CAAC,GAAG,oBAAQ,CACd,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAC1D,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACZ,IAAM,cAAc,GAAG,oBAAQ,CAC3B,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACvE,+BAAkB,CACd,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEN,EAAE,CAAC,8DAA4D,UAAY,EACxE;YACE,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,UAAU,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;YACjE,IAAM,CAAC,GAAG,oBAAQ,CACd,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAC1D,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACZ,IAAM,cAAc,GAAG,oBAAQ,CAC3B,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACvE,+BAAkB,CACd,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAW,EAAE,cAAc,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACR,CAAC;IAxBD,KAAyB,UAAU,EAAV,MAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAV,cAAU,EAAV,IAAU;QAA9B,IAAM,UAAU,SAAA;iBAAV,UAAU;KAwBpB;IAED,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;QACxD,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,EAA3B,CAA2B,CAAC;aACpC,YAAY,CAAC,2CAA2C,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;QACxC,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,EAAC,CAAC,CAAC;QAC3D,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,EAA3B,CAA2B,CAAC;aACpC,YAAY,CAAC,2CAA2C,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,YAAY,GAAG,IAAI,cAAO,CAAC,EAAC,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,EAAC,CAAC,CAAC;QAC9D,IAAM,CAAC,GACH,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAM,OAAA,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,EAA3B,CAA2B,CAAC;aACpC,YAAY,CAAC,yCAAyC,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.d.ts new file mode 100644 index 0000000..8f053e9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.d.ts @@ -0,0 +1,35 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, Shape } from '../types'; +export interface EmbeddingLayerConfig extends LayerConfig { + inputDim: number; + outputDim: number; + embeddingsInitializer?: InitializerIdentifier | Initializer; + embeddingsRegularizer?: RegularizerIdentifier | Regularizer; + activityRegularizer?: RegularizerIdentifier | Regularizer; + embeddingsConstraint?: ConstraintIdentifier | Constraint; + maskZero?: boolean; + inputLength?: number | number[]; +} +export declare class Embedding extends Layer { + static className: string; + private inputDim; + private outputDim; + private embeddingsInitializer; + private maskZero; + private inputLength; + private embeddings; + readonly DEFAULT_EMBEDDINGS_INITIALIZER: InitializerIdentifier; + private readonly embeddingsRegularizer?; + private readonly embeddingsConstraint?; + constructor(config: EmbeddingLayerConfig); + build(inputShape: Shape | Shape[]): void; + protected warnOnIncompatibleInputShape(inputShape: Shape): void; + computeMask(inputs: Tensor | Tensor[], mask?: Tensor | Tensor[]): Tensor; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js new file mode 100644 index 0000000..d0c38c5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js @@ -0,0 +1,118 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var K = require("../backend/tfjs_backend"); +var constraints_1 = require("../constraints"); +var topology_1 = require("../engine/topology"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var generic_utils = require("../utils/generic_utils"); +var types_utils_1 = require("../utils/types_utils"); +var Embedding = (function (_super) { + __extends(Embedding, _super); + function Embedding(config) { + var _this = _super.call(this, config) || this; + _this.embeddings = null; + _this.DEFAULT_EMBEDDINGS_INITIALIZER = 'randomUniform'; + if (config.batchInputShape == null && config.inputShape == null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + if (config.inputLength == null) { + _this.batchInputShape = [batchSize, null]; + } + else { + _this.batchInputShape = + [batchSize].concat(generic_utils.toList(config.inputLength)); + } + } + _this.inputDim = config.inputDim; + _this.outputDim = config.outputDim; + _this.embeddingsInitializer = initializers_1.getInitializer(config.embeddingsInitializer || _this.DEFAULT_EMBEDDINGS_INITIALIZER); + _this.embeddingsRegularizer = regularizers_1.getRegularizer(config.embeddingsRegularizer); + _this.activityRegularizer = regularizers_1.getRegularizer(config.activityRegularizer); + _this.embeddingsConstraint = constraints_1.getConstraint(config.embeddingsConstraint); + _this.maskZero = config.maskZero; + _this.inputLength = config.inputLength; + return _this; + } + Embedding.prototype.build = function (inputShape) { + this.embeddings = this.addWeight('embeddings', [this.inputDim, this.outputDim], this.dtype, this.embeddingsInitializer, this.embeddingsRegularizer, true, this.embeddingsConstraint); + this.built = true; + }; + Embedding.prototype.warnOnIncompatibleInputShape = function (inputShape) { }; + Embedding.prototype.computeMask = function (inputs, mask) { + throw new errors_1.NotImplementedError('computeMask has not been implemented for Embedding yet'); + }; + Embedding.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + if (this.inputLength == null) { + return inputShape.concat([this.outputDim]); + } + var inLens = generic_utils.toList(this.inputLength); + if (inLens.length !== inputShape.length - 1) { + throw new errors_1.ValueError("\"inputLength\" is " + this.inputLength + ", but received " + + ("input shape has shape " + inputShape)); + } + else { + var i = 0; + for (var k = 0; k < inLens.length; ++k) { + var s1 = inLens[k]; + var s2 = inputShape[k + 1]; + if ((s1 != null) && (s2 != null) && (s1 !== s2)) { + throw new errors_1.ValueError("\"inputLength\" is " + this.inputLength + ", but received " + + ("input shape has shape " + inputShape)); + } + else if (s1 == null) { + inLens[i] = s2; + } + i++; + } + } + return [inputShape[0]].concat(inLens, [this.outputDim]); + }; + Embedding.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = types_utils_1.getExactlyOneTensor(inputs); + if (input.dtype !== 'int32') { + input = K.cast(input, 'int32'); + } + var output = K.gather(_this.embeddings.read(), input.as1D()); + return output.reshape(types_utils_1.getExactlyOneShape(_this.computeOutputShape(input.shape))); + }); + }; + Embedding.prototype.getConfig = function () { + var config = { + inputDim: this.inputDim, + outputDim: this.outputDim, + embeddingsInitializer: initializers_1.serializeInitializer(this.embeddingsInitializer), + embeddingsRegularizer: regularizers_1.serializeRegularizer(this.embeddingsRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + embeddingsConstraint: constraints_1.serializeConstraint(this.embeddingsConstraint), + maskZero: this.maskZero, + inputLength: this.inputLength + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Embedding.className = 'Embedding'; + return Embedding; +}(topology_1.Layer)); +exports.Embedding = Embedding; +tfjs_core_1.serialization.SerializationMap.register(Embedding); +//# sourceMappingURL=embeddings.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js.map new file mode 100644 index 0000000..ec5e01d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings.js.map @@ -0,0 +1 @@ +{"version":3,"file":"embeddings.js","sourceRoot":"","sources":["../../src/layers/embeddings.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings_test.js.map new file mode 100644 index 0000000..6733646 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/embeddings_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"embeddings_test.js","sourceRoot":"","sources":["../../src/layers/embeddings_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.d.ts new file mode 100644 index 0000000..d2019d4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.d.ts @@ -0,0 +1,56 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Layer, LayerConfig, SymbolicTensor } from '../engine/topology'; +import { Kwargs, Shape } from '../types'; +export declare abstract class Merge extends Layer { + protected reshapeRequired: boolean; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; + private computeElementwiseOpOutputShape(shape1, shape2); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; +} +export declare class Add extends Merge { + static className: string; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; +} +export declare function add(config?: SymbolicTensor[] | Tensor[] | LayerConfig): Layer | SymbolicTensor | Tensor; +export declare class Multiply extends Merge { + static className: string; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; +} +export declare function multiply(config?: SymbolicTensor[] | Tensor[] | LayerConfig): Layer | SymbolicTensor | Tensor; +export declare class Average extends Merge { + static className: string; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; +} +export declare function average(config?: SymbolicTensor[] | Tensor[] | LayerConfig): Layer | SymbolicTensor | Tensor; +export declare class Maximum extends Merge { + static className: string; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; +} +export declare function maximum(config?: SymbolicTensor[] | Tensor[] | LayerConfig): Layer | SymbolicTensor | Tensor; +export declare class Minimum extends Merge { + static className: string; + constructor(config?: LayerConfig); + protected mergeFunction(inputs: Tensor[]): Tensor; +} +export declare function minimum(config?: SymbolicTensor[] | Tensor[] | LayerConfig): Layer | SymbolicTensor | Tensor; +export interface ConcatenateLayerConfig extends LayerConfig { + axis?: number; +} +export declare class Concatenate extends Merge { + static className: string; + readonly DEFAULT_AXIS: number; + private readonly axis; + constructor(config?: ConcatenateLayerConfig); + build(inputShape: Shape | Shape[]): void; + protected mergeFunction(inputs: Tensor[]): Tensor; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + getConfig(): serialization.ConfigDict; +} +export declare function concatenate(config?: SymbolicTensor[] | Tensor[] | ConcatenateLayerConfig): Layer | SymbolicTensor | Tensor; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js new file mode 100644 index 0000000..7215ef5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js @@ -0,0 +1,446 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var K = require("../backend/tfjs_backend"); +var topology_1 = require("../engine/topology"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var generic_utils = require("../utils/generic_utils"); +var mathUtils = require("../utils/math_utils"); +var types_utils_1 = require("../utils/types_utils"); +var Merge = (function (_super) { + __extends(Merge, _super); + function Merge(config) { + var _this = _super.call(this, config || {}) || this; + _this.supportsMasking = true; + return _this; + } + Merge.prototype.mergeFunction = function (inputs) { + throw new errors_1.NotImplementedError(); + }; + Merge.prototype.computeElementwiseOpOutputShape = function (shape1, shape2) { + if (shape1 == null || shape2 == null) { + return null; + } + else if (shape1.length < shape2.length) { + return this.computeElementwiseOpOutputShape(shape2, shape1); + } + else if (shape2.length === 0) { + return shape1; + } + var outputShape = shape1.slice(0, shape1.length - shape2.length); + for (var k = 0; k < shape2.length; ++k) { + var i = shape1[shape1.length - shape2.length + k]; + var j = shape2[k]; + if (i == null || j == null || i < 0 || j < 0) { + outputShape.push(null); + } + else if (i === 1) { + outputShape.push(j); + } + else if (j === 1) { + outputShape.push(i); + } + else { + if (i !== j) { + throw new errors_1.ValueError('Operands could not be broadcast together with shapes ' + + JSON.stringify(shape1) + ' ' + JSON.stringify(shape2)); + } + outputShape.push(i); + } + } + return outputShape; + }; + Merge.prototype.build = function (inputShape) { + if (Array.isArray(inputShape) && !Array.isArray(inputShape[0])) { + inputShape = [types_utils_1.getExactlyOneShape(inputShape)]; + } + inputShape = inputShape; + if (inputShape.length < 2) { + throw new errors_1.ValueError('A merge layer should be called on an Array of at least 2 inputs.' + + (" Got " + inputShape.length + " input(s).")); + } + var batchSizes = []; + for (var _i = 0, inputShape_1 = inputShape; _i < inputShape_1.length; _i++) { + var shape = inputShape_1[_i]; + if (shape != null && shape[0] !== null) { + batchSizes.push(shape[0]); + } + } + batchSizes = generic_utils.unique(batchSizes); + if (batchSizes.length > 1) { + throw new errors_1.ValueError("Can not merge tensors with different batch sizes. " + + ("Got tensors with shapes: " + JSON.stringify(inputShape) + ".")); + } + var outputShape = inputShape[0] == null ? null : inputShape[0].slice(1); + for (var i = 1; i < inputShape.length; ++i) { + var shape = inputShape[i] == null ? null : inputShape[i].slice(1); + outputShape = this.computeElementwiseOpOutputShape(outputShape, shape); + } + var allRanks = inputShape.map(function (shape) { return shape.length; }); + if (inputShape.indexOf(null) === -1 && + generic_utils.unique(allRanks).length === 1) { + this.reshapeRequired = false; + } + else { + this.reshapeRequired = true; + } + }; + Merge.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = inputs; + if (_this.reshapeRequired) { + var reshapedInputs = []; + var inputDims = inputs.map(function (input) { return input.rank; }); + if (inputDims.indexOf(null) === -1) { + var maxNDim = mathUtils.max(inputDims); + for (var _i = 0, inputs_1 = inputs; _i < inputs_1.length; _i++) { + var x = inputs_1[_i]; + var xNDim = x.rank; + for (var k = 0; k < maxNDim - xNDim; ++k) { + x = K.expandDims(x, 1); + } + reshapedInputs.push(x); + } + return _this.mergeFunction(reshapedInputs); + } + else { + var transposed = false; + for (var _a = 0, inputs_2 = inputs; _a < inputs_2.length; _a++) { + var x = inputs_2[_a]; + var xNDim = x.rank; + if (xNDim == null) { + var xShape = x.shape; + var batchSize = xShape[0]; + var newShape = xShape.slice(1).concat([batchSize]); + var xTransposed = x.reshape([batchSize].concat(mathUtils.arrayProd(xShape.slice(1)))); + xTransposed = tfc.transpose(xTransposed, [1, 0]); + xTransposed = xTransposed.reshape(newShape); + reshapedInputs.push(xTransposed); + transposed = true; + } + else if (xNDim > 1) { + var dims = mathUtils.range(1, xNDim).concat([0]); + reshapedInputs.push(tfc.transpose(x, dims)); + transposed = true; + } + else { + reshapedInputs.push(x); + } + } + var y = _this.mergeFunction(reshapedInputs); + var yNDim = y.rank; + if (transposed) { + if (yNDim == null) { + var yShape = y.shape; + var yNDim_1 = yShape.length; + var batchSize = yShape[yNDim_1 - 1]; + var newShape = [batchSize].concat(yShape.slice(0, yShape.length - 1)); + y = tfc.transpose(y.reshape([-1, batchSize]), [1, 0]) + .reshape(newShape); + } + else if (yNDim > 1) { + var dims = [yNDim - 1].concat(mathUtils.range(0, yNDim - 1)); + y = tfc.transpose(y, dims); + } + } + return y; + } + } + else { + return _this.mergeFunction(inputs); + } + }); + }; + Merge.prototype.computeOutputShape = function (inputShape) { + inputShape = inputShape; + var outputShape; + if (inputShape[0] == null) { + outputShape = null; + } + else { + outputShape = inputShape[0].slice(1); + } + for (var i = 1; i < inputShape.length; ++i) { + var shape = inputShape[i] == null ? null : inputShape[i].slice(1); + outputShape = this.computeElementwiseOpOutputShape(outputShape, shape); + } + var batchSizes = []; + for (var _i = 0, inputShape_2 = inputShape; _i < inputShape_2.length; _i++) { + var shape = inputShape_2[_i]; + if (shape != null && shape[0] !== null) { + batchSizes.push(shape[0]); + } + } + batchSizes = generic_utils.unique(batchSizes); + if (batchSizes.length === 1) { + outputShape = batchSizes.concat(outputShape); + } + else { + outputShape = [null].concat(outputShape); + } + return outputShape; + }; + return Merge; +}(topology_1.Layer)); +exports.Merge = Merge; +var Add = (function (_super) { + __extends(Add, _super); + function Add(config) { + return _super.call(this, config) || this; + } + Add.prototype.mergeFunction = function (inputs) { + return tfjs_core_1.tidy(function () { + var output = tfc.zeros(inputs[0].shape); + for (var _i = 0, inputs_3 = inputs; _i < inputs_3.length; _i++) { + var input = inputs_3[_i]; + output = tfc.add(output, input); + } + return output; + }); + }; + Add.className = 'Add'; + return Add; +}(Merge)); +exports.Add = Add; +tfjs_core_1.serialization.SerializationMap.register(Add); +function add(config) { + if (Array.isArray(config)) { + var layer = new Add({}); + return layer.apply(config); + } + else { + return new Add(config); + } +} +exports.add = add; +var Multiply = (function (_super) { + __extends(Multiply, _super); + function Multiply(config) { + return _super.call(this, config) || this; + } + Multiply.prototype.mergeFunction = function (inputs) { + return tfjs_core_1.tidy(function () { + var output = tfc.ones(inputs[0].shape); + for (var _i = 0, inputs_4 = inputs; _i < inputs_4.length; _i++) { + var input = inputs_4[_i]; + output = tfc.mul(output, input); + } + return output; + }); + }; + Multiply.className = 'Multiply'; + return Multiply; +}(Merge)); +exports.Multiply = Multiply; +tfjs_core_1.serialization.SerializationMap.register(Multiply); +function multiply(config) { + if (Array.isArray(config)) { + var layer = new Multiply({}); + return layer.apply(config); + } + else { + return new Multiply(config); + } +} +exports.multiply = multiply; +var Average = (function (_super) { + __extends(Average, _super); + function Average(config) { + return _super.call(this, config) || this; + } + Average.prototype.mergeFunction = function (inputs) { + return tfjs_core_1.tidy(function () { + var output = tfc.zeros(inputs[0].shape); + for (var _i = 0, inputs_5 = inputs; _i < inputs_5.length; _i++) { + var input = inputs_5[_i]; + output = tfc.add(output, input); + } + return tfc.mul(state_1.getScalar(1 / inputs.length), output); + }); + }; + Average.className = 'Average'; + return Average; +}(Merge)); +exports.Average = Average; +tfjs_core_1.serialization.SerializationMap.register(Average); +function average(config) { + if (Array.isArray(config)) { + var layer = new Average({}); + return layer.apply(config); + } + else { + return new Average(config); + } +} +exports.average = average; +var Maximum = (function (_super) { + __extends(Maximum, _super); + function Maximum(config) { + return _super.call(this, config) || this; + } + Maximum.prototype.mergeFunction = function (inputs) { + return tfjs_core_1.tidy(function () { + var output = inputs[0]; + for (var i = 1; i < inputs.length; ++i) { + output = tfc.maximum(output, inputs[i]); + } + return output; + }); + }; + Maximum.className = 'Maximum'; + return Maximum; +}(Merge)); +exports.Maximum = Maximum; +tfjs_core_1.serialization.SerializationMap.register(Maximum); +function maximum(config) { + if (Array.isArray(config)) { + var layer = new Maximum({}); + return layer.apply(config); + } + else { + return new Maximum(config); + } +} +exports.maximum = maximum; +var Minimum = (function (_super) { + __extends(Minimum, _super); + function Minimum(config) { + return _super.call(this, config) || this; + } + Minimum.prototype.mergeFunction = function (inputs) { + return tfjs_core_1.tidy(function () { + var output = inputs[0]; + for (var i = 1; i < inputs.length; ++i) { + output = tfc.minimum(output, inputs[i]); + } + return output; + }); + }; + Minimum.className = 'Minimum'; + return Minimum; +}(Merge)); +exports.Minimum = Minimum; +tfjs_core_1.serialization.SerializationMap.register(Minimum); +function minimum(config) { + if (Array.isArray(config)) { + var layer = new Minimum({}); + return layer.apply(config); + } + else { + return new Minimum(config); + } +} +exports.minimum = minimum; +var Concatenate = (function (_super) { + __extends(Concatenate, _super); + function Concatenate(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_AXIS = -1; + if (config == null) { + config = {}; + } + _this.axis = config.axis == null ? _this.DEFAULT_AXIS : config.axis; + _this.supportsMasking = true; + _this.reshapeRequired = false; + return _this; + } + Concatenate.prototype.build = function (inputShape) { + if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0])) || + inputShape.length === 1) { + throw new errors_1.ValueError('A `Concatenate` layer should be called on a list of at least 2 ' + + 'inputs'); + } + inputShape = inputShape; + var allNoneShape = true; + for (var _i = 0, inputShape_3 = inputShape; _i < inputShape_3.length; _i++) { + var shape = inputShape_3[_i]; + if (shape != null) { + allNoneShape = false; + break; + } + } + if (allNoneShape) { + return; + } + var shapeSet = []; + for (var i = 0; i < inputShape.length; ++i) { + var shapeWithoutConcatAxis = inputShape[i].slice(); + shapeWithoutConcatAxis.splice(this.axis, 1); + var exists = false; + for (var _a = 0, shapeSet_1 = shapeSet; _a < shapeSet_1.length; _a++) { + var shape = shapeSet_1[_a]; + if (tfjs_core_1.util.arraysEqual(shape, shapeWithoutConcatAxis)) { + exists = true; + break; + } + } + if (!exists) { + shapeSet.push(shapeWithoutConcatAxis); + } + } + if (shapeSet.length > 1) { + throw new errors_1.ValueError('A `Concatenate` layer requires inputs with matching shapes ' + + 'except for the concat axis. Got input shapes: ' + + JSON.stringify(inputShape)); + } + }; + Concatenate.prototype.mergeFunction = function (inputs) { + var _this = this; + return tfjs_core_1.tidy(function () { + return K.concatenate(inputs, _this.axis); + }); + }; + Concatenate.prototype.computeOutputShape = function (inputShape) { + if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0]))) { + throw new errors_1.ValueError('A `Concatenate` layer should be called on a list of inputs.'); + } + var inputShapes = inputShape; + var outputShape = inputShapes[0].slice(); + var axis = this.axis < 0 ? outputShape.length + this.axis : this.axis; + for (var _i = 0, _a = inputShapes.slice(1); _i < _a.length; _i++) { + var shape = _a[_i]; + if (outputShape[axis] == null || shape[axis] == null) { + outputShape[axis] = null; + break; + } + outputShape[axis] += shape[axis]; + } + return outputShape; + }; + Concatenate.prototype.getConfig = function () { + var config = { + 'axis': this.axis, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Concatenate.className = 'Concatenate'; + return Concatenate; +}(Merge)); +exports.Concatenate = Concatenate; +tfjs_core_1.serialization.SerializationMap.register(Concatenate); +function concatenate(config) { + if (Array.isArray(config)) { + var layer = new Concatenate({}); + return layer.apply(config); + } + else { + return new Concatenate(config); + } +} +exports.concatenate = concatenate; +//# sourceMappingURL=merge.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js.map new file mode 100644 index 0000000..0371d11 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge.js.map @@ -0,0 +1 @@ +{"version":3,"file":"merge.js","sourceRoot":"","sources":["../../src/layers/merge.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/merge_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge_test.js.map new file mode 100644 index 0000000..bbd57ea --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/merge_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"merge_test.js","sourceRoot":"","sources":["../../src/layers/merge_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.d.ts new file mode 100644 index 0000000..a5cbfa0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.d.ts @@ -0,0 +1,48 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, Shape } from '../types'; +export declare function batchNormalization(x: Tensor, mean: Tensor, variance: Tensor, beta?: Tensor, gamma?: Tensor, epsilon?: number): Tensor; +export declare function normalizeBatchInTraining(x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[], epsilon?: number): [Tensor, Tensor, Tensor]; +export interface BatchNormalizationLayerConfig extends LayerConfig { + axis?: number; + momentum?: number; + epsilon?: number; + center?: boolean; + scale?: boolean; + betaInitializer?: InitializerIdentifier | Initializer; + gammaInitializer?: InitializerIdentifier | Initializer; + movingMeanInitializer?: InitializerIdentifier | Initializer; + movingVarianceInitializer?: InitializerIdentifier | Initializer; + betaConstraint?: ConstraintIdentifier | Constraint; + gammaConstraint?: ConstraintIdentifier | Constraint; + betaRegularizer?: RegularizerIdentifier | Regularizer; + gammaRegularizer?: RegularizerIdentifier | Regularizer; +} +export declare class BatchNormalization extends Layer { + static className: string; + private readonly axis; + private readonly momentum; + private readonly epsilon; + private readonly center; + private readonly scale; + private readonly betaInitializer; + private readonly gammaInitializer; + private readonly movingMeanInitializer; + private readonly movingVarianceInitializer; + private readonly betaConstraint; + private readonly gammaConstraint; + private readonly betaRegularizer; + private readonly gammaRegularizer; + private gamma; + private beta; + private movingMean; + private movingVariance; + private stepCount; + constructor(config: BatchNormalizationLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js new file mode 100644 index 0000000..00b3793 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js @@ -0,0 +1,202 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var constraints_1 = require("../constraints"); +var topology_1 = require("../engine/topology"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var generic_utils = require("../utils/generic_utils"); +var math_utils = require("../utils/math_utils"); +var types_utils_1 = require("../utils/types_utils"); +function batchNormalization(x, mean, variance, beta, gamma, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + var out; + if (x.rank === 2) { + out = tfc.batchNormalization2d(x, mean, variance, epsilon, gamma, beta); + } + else if (x.rank === 3) { + out = tfc.batchNormalization3d(x, mean, variance, epsilon, gamma, beta); + } + else if (x.rank === 4) { + out = tfc.batchNormalization4d(x, mean, variance, epsilon, gamma, beta); + } + else { + throw new errors_1.NotImplementedError("batchNormalization is not implememnted for array of rank " + x.rank + " " + + "yet"); + } + return out; +} +exports.batchNormalization = batchNormalization; +function regularNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + return tfjs_core_1.tidy(function () { + var meanAndVariance = tfc.moments(x, reductionAxes); + var mean = meanAndVariance.mean; + var variance = meanAndVariance.variance; + var normed = batchNormalization(x, mean, variance, beta, gamma, epsilon); + return [normed, mean, variance]; + }); +} +function broadcastNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + return tfjs_core_1.tidy(function () { + var meanAndVariance = tfc.moments(x, reductionAxes); + var mean = meanAndVariance.mean; + var variance = meanAndVariance.variance; + var targetShape = []; + for (var _i = 0, _a = math_utils.range(0, x.rank); _i < _a.length; _i++) { + var axis = _a[_i]; + if (reductionAxes.indexOf(axis) !== -1) { + targetShape.push(1); + } + else { + targetShape.push(x.shape[axis]); + } + } + var broadcastMean = mean.reshape(targetShape); + var broadcastVariance = variance.reshape(targetShape); + var broadcastGamma = gamma == null ? null : gamma.reshape(targetShape); + var broadcastBeta = beta == null ? null : beta.reshape(targetShape); + var normed = batchNormalization(x, broadcastMean, broadcastVariance, broadcastBeta, broadcastGamma, epsilon); + return [normed, mean, variance]; + }); +} +function normalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + if (tfjs_core_1.util.arraysEqual(reductionAxes.slice().sort(), math_utils.range(0, x.rank - 1))) { + return regularNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon); + } + else { + return broadcastNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon); + } +} +exports.normalizeBatchInTraining = normalizeBatchInTraining; +var BatchNormalization = (function (_super) { + __extends(BatchNormalization, _super); + function BatchNormalization(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + _this.axis = config.axis == null ? -1 : config.axis; + _this.momentum = config.momentum == null ? 0.99 : config.momentum; + _this.epsilon = config.epsilon == null ? 1e-3 : config.epsilon; + _this.center = config.center == null ? true : config.center; + _this.scale = config.scale == null ? true : config.scale; + _this.betaInitializer = initializers_1.getInitializer(config.betaInitializer || 'zeros'); + _this.gammaInitializer = initializers_1.getInitializer(config.gammaInitializer || 'ones'); + _this.movingMeanInitializer = + initializers_1.getInitializer(config.movingMeanInitializer || 'zeros'); + _this.movingVarianceInitializer = + initializers_1.getInitializer(config.movingVarianceInitializer || 'ones'); + _this.betaConstraint = constraints_1.getConstraint(config.betaConstraint); + _this.gammaConstraint = constraints_1.getConstraint(config.gammaConstraint); + _this.betaRegularizer = regularizers_1.getRegularizer(config.betaRegularizer); + _this.gammaRegularizer = regularizers_1.getRegularizer(config.gammaRegularizer); + _this.stepCount = 0; + return _this; + } + BatchNormalization.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var axis = this.axis >= 0 ? this.axis : (this.axis + inputShape.length); + var dim = inputShape[axis]; + if (dim == null) { + throw new errors_1.ValueError("Axis " + axis + " of input tensor should have a defined dimension but " + + "the layer received an input with shape " + + (JSON.stringify(inputShape) + ".")); + } + this.inputSpec = + [new topology_1.InputSpec({ ndim: inputShape.length, axes: (_a = {}, _a[axis] = dim, _a) })]; + var shape = [dim]; + if (this.scale) { + this.gamma = this.addWeight('gamma', shape, null, this.gammaInitializer, this.gammaRegularizer, true, this.gammaConstraint); + } + if (this.center) { + this.beta = this.addWeight('beta', shape, null, this.betaInitializer, this.betaRegularizer, true, this.betaConstraint); + } + this.movingMean = this.addWeight('moving_mean', shape, null, this.movingMeanInitializer, null, false); + this.movingVariance = this.addWeight('moving_variance', shape, null, this.movingVarianceInitializer, null, false); + this.built = true; + var _a; + }; + BatchNormalization.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var training = kwargs['training'] == null ? false : kwargs['training']; + var input = types_utils_1.getExactlyOneTensor(inputs); + var inputShape = input.shape; + var ndim = inputShape.length; + var reductionAxes = math_utils.range(0, ndim); + var axis = _this.axis >= 0 ? _this.axis : (_this.axis + ndim); + reductionAxes.splice(axis, 1); + var broadcastShape = generic_utils.pyListRepeat(1, ndim); + broadcastShape[axis] = inputShape[axis]; + var sortedReductionAxes = reductionAxes.slice(); + sortedReductionAxes.sort(); + var needsBroadcasting = !tfjs_core_1.util.arraysEqual(sortedReductionAxes, math_utils.range(0, ndim).slice(0, ndim - 1)); + var normalizeInference = function () { + if (needsBroadcasting) { + var broadcastMovingMean = _this.movingMean.read().reshape(broadcastShape); + var broadcastMovingVariance = _this.movingVariance.read().reshape(broadcastShape); + var broadcastBeta = _this.center ? _this.beta.read().reshape(broadcastShape) : null; + var broadcastGamma = _this.scale ? _this.gamma.read().reshape(broadcastShape) : null; + return batchNormalization(input, broadcastMovingMean, broadcastMovingVariance, broadcastBeta, broadcastGamma, _this.epsilon); + } + else { + return batchNormalization(input, _this.movingMean.read(), _this.movingVariance.read(), _this.beta == null ? null : _this.beta.read(), _this.gamma == null ? null : _this.gamma.read(), _this.epsilon); + } + }; + if (!training) { + return normalizeInference(); + } + var _a = normalizeBatchInTraining(input, _this.gamma.read(), _this.beta.read(), reductionAxes, _this.epsilon), normedTraining = _a[0], mean = _a[1], variance = _a[2]; + var sampleSize = math_utils.arrayProd(reductionAxes.map(function (axis) { return input.shape[axis]; })); + var varianceDebiased = variance.mul(state_1.getScalar(sampleSize / (sampleSize - (1 + _this.epsilon)))); + var updateMovingMeanAndVariance = function () { + _this.stepCount++; + var newMovingMean = tfc.movingAverage(_this.movingMean.read(), mean, _this.momentum, _this.stepCount); + _this.movingMean.write(newMovingMean); + var newMovingVariance = tfc.movingAverage(_this.movingVariance.read(), varianceDebiased, _this.momentum, _this.stepCount); + _this.movingVariance.write(newMovingVariance); + }; + updateMovingMeanAndVariance(); + return normedTraining; + }); + }; + BatchNormalization.prototype.getConfig = function () { + var config = { + axis: this.axis, + momentum: this.momentum, + epsilon: this.epsilon, + center: this.center, + scale: this.scale, + betaInitializer: initializers_1.serializeInitializer(this.betaInitializer), + gammaInitializer: initializers_1.serializeInitializer(this.gammaInitializer), + movingMeanInitializer: initializers_1.serializeInitializer(this.movingMeanInitializer), + movingVarianceInitializer: initializers_1.serializeInitializer(this.movingVarianceInitializer), + betaRegularizer: regularizers_1.serializeRegularizer(this.betaRegularizer), + gammaRegularizer: regularizers_1.serializeRegularizer(this.gammaRegularizer), + betaConstraint: constraints_1.serializeConstraint(this.betaConstraint), + gammaConstraint: constraints_1.serializeConstraint(this.gammaConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + BatchNormalization.className = 'BatchNormalization'; + return BatchNormalization; +}(topology_1.Layer)); +exports.BatchNormalization = BatchNormalization; +tfjs_core_1.serialization.SerializationMap.register(BatchNormalization); +//# sourceMappingURL=normalization.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js.map new file mode 100644 index 0000000..b7686d7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization.js.map @@ -0,0 +1 @@ +{"version":3,"file":"normalization.js","sourceRoot":"","sources":["../../src/layers/normalization.ts"],"names":[],"mappings":";;;;;;;;;;;;AAeA,2CAA6C;AAC7C,mDAAgH;AAEhH,8CAAoG;AACpG,+CAAiE;AACjE,0CAA2C;AAC3C,oCAA0D;AAC1D,gDAAyG;AACzG,gDAAyG;AAEzG,sDAAwD;AACxD,gDAAkD;AAClD,oDAA6E;AAmB7E,4BACI,CAAS,EAAE,IAAY,EAAE,QAAgB,EAAE,IAAa,EAAE,KAAc,EACxE,OAAc;IAAd,wBAAA,EAAA,cAAc;IAChB,IAAI,GAAW,CAAC;IAChB,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QAChB,GAAG,GAAG,GAAG,CAAC,oBAAoB,CAC1B,CAAa,EAAE,IAA2B,EAC1C,QAA+B,EAAE,OAAO,EAAE,KAA4B,EACtE,IAA2B,CAAC,CAAC;KAClC;SAAM,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QAEvB,GAAG,GAAG,GAAG,CAAC,oBAAoB,CAC1B,CAAa,EAAE,IAA2B,EAC1C,QAA+B,EAAE,OAAO,EAAE,KAA4B,EACtE,IAA2B,CAAC,CAAC;KAClC;SAAM,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE;QACvB,GAAG,GAAG,GAAG,CAAC,oBAAoB,CAC1B,CAAa,EAAE,IAA2B,EAC1C,QAA+B,EAAE,OAAO,EAAE,KAA4B,EACtE,IAA2B,CAAC,CAAC;KAClC;SAAM;QACL,MAAM,IAAI,4BAAmB,CACzB,8DAA4D,CAAC,CAAC,IAAI,MAAG;YACrE,KAAK,CAAC,CAAC;KACZ;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AA1BD,gDA0BC;AAmBD,yCACI,CAAS,EAAE,KAAa,EAAE,IAAY,EAAE,aAAuB,EAC/D,OAAc;IAAd,wBAAA,EAAA,cAAc;IAChB,OAAO,gBAAI,CAAC;QACH,IAAM,eAAe,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC;QACtD,IAAM,IAAI,GAAG,eAAe,CAAC,IAAI,CAAC;QAClC,IAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC;QAC1C,IAAM,MAAM,GACR,kBAAkB,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QAChE,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;IAClC,CAAC,CAA6B,CAAC;AACxC,CAAC;AAmBD,2CACI,CAAS,EAAE,KAAa,EAAE,IAAY,EAAE,aAAuB,EAC/D,OAAc;IAAd,wBAAA,EAAA,cAAc;IAChB,OAAO,gBAAI,CAAC;QACH,IAAM,eAAe,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC;QACtD,IAAM,IAAI,GAAG,eAAe,CAAC,IAAI,CAAC;QAClC,IAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC;QAC1C,IAAM,WAAW,GAAa,EAAE,CAAC;QACjC,KAAmB,UAA2B,EAA3B,KAAA,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAA3B,cAA2B,EAA3B,IAA2B;YAAzC,IAAM,IAAI,SAAA;YACb,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;gBACtC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACrB;iBAAM;gBACL,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;aACjC;SACF;QACD,IAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAChD,IAAM,iBAAiB,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACxD,IAAM,cAAc,GAChB,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACtD,IAAM,aAAa,GACf,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACpD,IAAM,MAAM,GAAG,kBAAkB,CAC7B,CAAC,EAAE,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAClD,cAAc,EAAE,OAAO,CAAC,CAAC;QAC7B,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;IAClC,CAAC,CAA6B,CAAC;AACxC,CAAC;AAaD,kCACI,CAAS,EAAE,KAAa,EAAE,IAAY,EAAE,aAAuB,EAC/D,OAAc;IAAd,wBAAA,EAAA,cAAc;IAChB,IAAI,gBAAI,CAAC,WAAW,CACZ,aAAa,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE;QACtE,OAAO,+BAA+B,CAClC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;KAC7C;SAAM;QACL,OAAO,iCAAiC,CACpC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;KAC7C;AACH,CAAC;AAXD,4DAWC;AAwGD;IAAwC,sCAAK;IAqB3C,4BAAY,MAAqC;QAAjD,YACE,kBAAM,MAAM,CAAC,SAkBd;QAjBC,KAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,KAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC;QACnD,KAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC;QACjE,KAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;QAC9D,KAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;QAC3D,KAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QACxD,KAAI,CAAC,eAAe,GAAG,6BAAc,CAAC,MAAM,CAAC,eAAe,IAAI,OAAO,CAAC,CAAC;QACzE,KAAI,CAAC,gBAAgB,GAAG,6BAAc,CAAC,MAAM,CAAC,gBAAgB,IAAI,MAAM,CAAC,CAAC;QAC1E,KAAI,CAAC,qBAAqB;YACtB,6BAAc,CAAC,MAAM,CAAC,qBAAqB,IAAI,OAAO,CAAC,CAAC;QAC5D,KAAI,CAAC,yBAAyB;YAC1B,6BAAc,CAAC,MAAM,CAAC,yBAAyB,IAAI,MAAM,CAAC,CAAC;QAC/D,KAAI,CAAC,cAAc,GAAG,2BAAa,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QAC3D,KAAI,CAAC,eAAe,GAAG,2BAAa,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAC7D,KAAI,CAAC,eAAe,GAAG,6BAAc,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAC9D,KAAI,CAAC,gBAAgB,GAAG,6BAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAChE,KAAI,CAAC,SAAS,GAAG,CAAC,CAAC;;IACrB,CAAC;IAEM,kCAAK,GAAZ,UAAa,UAAyB;QACpC,UAAU,GAAG,gCAAkB,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAM,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;QAC1E,IAAM,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,GAAG,IAAI,IAAI,EAAE;YACf,MAAM,IAAI,mBAAU,CAChB,UAAQ,IAAI,0DAAuD;gBACnE,yCAAyC;iBACtC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,MAAG,CAAA,CAAC,CAAC;SACvC;QACD,IAAI,CAAC,SAAS;YACV,CAAC,IAAI,oBAAS,CAAC,EAAC,IAAI,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,YAAG,GAAC,IAAI,IAAG,GAAG,KAAC,EAAC,CAAC,CAAC,CAAC;QACpE,IAAM,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;QACpB,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CACvB,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAClE,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;SACjC;QACD,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CACtB,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,EACrE,IAAI,CAAC,cAAc,CAAC,CAAC;SAC1B;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAC5B,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,qBAAqB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACzE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAChC,iBAAiB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,yBAAyB,EAAE,IAAI,EACpE,KAAK,CAAC,CAAC;QACX,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;;IACpB,CAAC;IAED,iCAAI,GAAJ,UAAK,MAAuB,EAAE,MAAc;QAA5C,iBAwEC;QAvEC,OAAO,gBAAI,CAAC;YACV,IAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACzE,IAAM,KAAK,GAAG,iCAAmB,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC;YAC/B,IAAM,IAAI,GAAG,UAAU,CAAC,MAAM,CAAC;YAC/B,IAAM,aAAa,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAChD,IAAM,IAAI,GAAG,KAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,KAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;YAC7D,aAAa,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC9B,IAAM,cAAc,GAAG,aAAa,CAAC,YAAY,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAC3D,cAAc,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;YAExC,IAAM,mBAAmB,GAAG,aAAa,CAAC,KAAK,EAAE,CAAC;YAClD,mBAAmB,CAAC,IAAI,EAAE,CAAC;YAC3B,IAAM,iBAAiB,GAAG,CAAC,gBAAI,CAAC,WAAW,CACvC,mBAAmB,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;YAEvE,IAAM,kBAAkB,GAAiB;gBACvC,IAAI,iBAAiB,EAAE;oBACrB,IAAM,mBAAmB,GACrB,KAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;oBACnD,IAAM,uBAAuB,GACzB,KAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;oBACvD,IAAM,aAAa,GACf,KAAI,CAAC,MAAM,CAAC,CAAC,CAAC,KAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAClE,IAAM,cAAc,GAChB,KAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAClE,OAAO,kBAAkB,CACrB,KAAK,EAAE,mBAAmB,EAAE,uBAAuB,EACnD,aAAa,EAAE,cAAc,EAAE,KAAI,CAAC,OAAO,CAAC,CAAC;iBAClD;qBAAM;oBACL,OAAO,kBAAkB,CACrB,KAAK,EAAE,KAAI,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,KAAI,CAAC,cAAc,CAAC,IAAI,EAAE,EACzD,KAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAC3C,KAAI,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,KAAI,CAAC,OAAO,CAAC,CAAC;iBAClE;YACH,CAAC,CAAC;YAEF,IAAI,CAAC,QAAQ,EAAE;gBACb,OAAO,kBAAkB,EAAE,CAAC;aAC7B;YAEK,IAAA,yGAEW,EAFV,sBAAc,EAAE,YAAI,EAAE,gBAAQ,CAEnB;YAGlB,IAAM,UAAU,GACZ,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,UAAA,IAAI,IAAI,OAAA,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAjB,CAAiB,CAAC,CAAC,CAAC;YACvE,IAAM,gBAAgB,GAAG,QAAQ,CAAC,GAAG,CACjC,iBAAS,CAAC,UAAU,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,KAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YAQ/D,IAAM,2BAA2B,GAAG;gBAClC,KAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAM,aAAa,GAAG,GAAG,CAAC,aAAa,CACnC,KAAI,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,KAAI,CAAC,QAAQ,EAAE,KAAI,CAAC,SAAS,CAAC,CAAC;gBACjE,KAAI,CAAC,UAAU,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;gBACrC,IAAM,iBAAiB,GAAG,GAAG,CAAC,aAAa,CACvC,KAAI,CAAC,cAAc,CAAC,IAAI,EAAE,EAAE,gBAAgB,EAAE,KAAI,CAAC,QAAQ,EAC3D,KAAI,CAAC,SAAS,CAAC,CAAC;gBACpB,KAAI,CAAC,cAAc,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;YAC/C,CAAC,CAAC;YACF,2BAA2B,EAAE,CAAC;YAE9B,OAAO,cAAc,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,sCAAS,GAAT;QACE,IAAM,MAAM,GAA6B;YACvC,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,eAAe,EAAE,mCAAoB,CAAC,IAAI,CAAC,eAAe,CAAC;YAC3D,gBAAgB,EAAE,mCAAoB,CAAC,IAAI,CAAC,gBAAgB,CAAC;YAC7D,qBAAqB,EAAE,mCAAoB,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACvE,yBAAyB,EACrB,mCAAoB,CAAC,IAAI,CAAC,yBAAyB,CAAC;YACxD,eAAe,EAAE,mCAAoB,CAAC,IAAI,CAAC,eAAe,CAAC;YAC3D,gBAAgB,EAAE,mCAAoB,CAAC,IAAI,CAAC,gBAAgB,CAAC;YAC7D,cAAc,EAAE,iCAAmB,CAAC,IAAI,CAAC,cAAc,CAAC;YACxD,eAAe,EAAE,iCAAmB,CAAC,IAAI,CAAC,eAAe,CAAC;SAC3D,CAAC;QACF,IAAM,UAAU,GAAG,iBAAM,SAAS,WAAE,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAClC,OAAO,MAAM,CAAC;IAChB,CAAC;IAtKM,4BAAS,GAAG,oBAAoB,CAAC;IAuK1C,yBAAC;CAAA,AAxKD,CAAwC,gBAAK,GAwK5C;AAxKY,gDAAkB;AAyK/B,yBAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization_test.js.map new file mode 100644 index 0000000..967a39e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/normalization_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"normalization_test.js","sourceRoot":"","sources":["../../src/layers/normalization_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.d.ts new file mode 100644 index 0000000..28a16c5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.d.ts @@ -0,0 +1,19 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { DataFormat } from '../common'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Kwargs, Shape } from '../types'; +export declare function temporalPadding(x: Tensor, padding?: [number, number]): Tensor; +export declare function spatial2dPadding(x: Tensor, padding?: [[number, number], [number, number]], dataFormat?: DataFormat): Tensor; +export interface ZeroPadding2DLayerConfig extends LayerConfig { + padding?: number | [number, number] | [[number, number], [number, number]]; + dataFormat?: DataFormat; +} +export declare class ZeroPadding2D extends Layer { + static className: string; + readonly dataFormat: DataFormat; + readonly padding: [[number, number], [number, number]]; + constructor(config?: ZeroPadding2DLayerConfig); + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js new file mode 100644 index 0000000..d5a651d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js @@ -0,0 +1,171 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("../backend/common"); +var topology_1 = require("../engine/topology"); +var errors_1 = require("../errors"); +var types_utils_1 = require("../utils/types_utils"); +function temporalPadding(x, padding) { + return tfjs_core_1.tidy(function () { + if (x.rank !== 3) { + throw new errors_1.ValueError("temporalPadding expects input tensor to be 3-D, but received a " + + (x.rank + "-D tensor.")); + } + if (padding == null) { + padding = [1, 1]; + } + if (padding.length !== 2) { + throw new errors_1.ValueError("temporalPadding expects input padding pattern to be a length-2 " + + ("array, but received a length-" + padding.length + " array.")); + } + var pattern = [[0, 0], padding, [0, 0]]; + return tfc.pad(x, pattern); + }); +} +exports.temporalPadding = temporalPadding; +function spatial2dPadding(x, padding, dataFormat) { + return tfjs_core_1.tidy(function () { + if (x.rank !== 4) { + throw new errors_1.ValueError("temporalPadding expects input tensor to be 4-D, but received a " + + (x.rank + "-D tensor.")); + } + if (padding == null) { + padding = [[1, 1], [1, 1]]; + } + if (padding.length !== 2 || padding[0].length !== 2 || + padding[1].length !== 2) { + throw new errors_1.ValueError('spatial2dPadding expects `padding` to be an Array of two Arrays, ' + + 'each of which is an Array of two integers.'); + } + if (dataFormat == null) { + dataFormat = common_1.imageDataFormat(); + } + if (dataFormat !== 'channelsLast' && dataFormat !== 'channelsFirst') { + throw new errors_1.ValueError("Unknown data format: " + dataFormat + ". " + + "Supported data formats are 'channelsLast' and 'channelsFirst."); + } + var pattern; + if (dataFormat === 'channelsFirst') { + pattern = [[0, 0], [0, 0], padding[0], padding[1]]; + } + else { + pattern = [[0, 0], padding[0], padding[1], [0, 0]]; + } + return tfc.pad(x, pattern); + }); +} +exports.spatial2dPadding = spatial2dPadding; +var ZeroPadding2D = (function (_super) { + __extends(ZeroPadding2D, _super); + function ZeroPadding2D(config) { + var _this = this; + if (config == null) { + config = {}; + } + _this = _super.call(this, config) || this; + _this.dataFormat = + config.dataFormat == null ? common_1.imageDataFormat() : config.dataFormat; + if (config.padding == null) { + _this.padding = [[1, 1], [1, 1]]; + } + else if (typeof config.padding === 'number') { + _this.padding = + [[config.padding, config.padding], [config.padding, config.padding]]; + } + else { + config.padding = config.padding; + if (config.padding.length !== 2) { + throw new errors_1.ValueError("ZeroPadding2D expects padding to be a length-2 array, but " + + ("received a length-" + config.padding.length + " array.")); + } + var heightPadding = void 0; + var widthPadding = void 0; + if (typeof config.padding[0] === 'number') { + heightPadding = + [config.padding[0], config.padding[0]]; + widthPadding = + [config.padding[1], config.padding[1]]; + } + else { + config.padding = config.padding; + if (config.padding[0].length !== 2) { + throw new errors_1.ValueError("ZeroPadding2D expects height padding to be a length-2 array, " + + ("but received a length-" + config.padding[0].length + " array.")); + } + heightPadding = config.padding[0]; + if (config.padding[1].length !== 2) { + throw new errors_1.ValueError("ZeroPadding2D expects width padding to be a length-2 array, " + + ("but received a length-" + config.padding[1].length + " array.")); + } + widthPadding = config.padding[1]; + } + _this.padding = [heightPadding, widthPadding]; + } + _this.inputSpec = [new topology_1.InputSpec({ ndim: 4 })]; + return _this; + } + ZeroPadding2D.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var rows; + var cols; + if (this.dataFormat === 'channelsFirst') { + if (inputShape[2] != null && inputShape[2] >= 0) { + rows = inputShape[2] + this.padding[0][0] + this.padding[0][1]; + } + else { + rows = null; + } + if (inputShape[3] != null && inputShape[3] >= 0) { + cols = inputShape[3] + this.padding[1][0] + this.padding[1][1]; + } + else { + cols = null; + } + return [inputShape[0], inputShape[1], rows, cols]; + } + else { + if (inputShape[1] != null && inputShape[1] >= 0) { + rows = inputShape[1] + this.padding[0][0] + this.padding[0][1]; + } + else { + rows = null; + } + if (inputShape[2] != null && inputShape[2] >= 0) { + cols = inputShape[2] + this.padding[1][0] + this.padding[1][1]; + } + else { + cols = null; + } + return [inputShape[0], rows, cols, inputShape[3]]; + } + }; + ZeroPadding2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { return spatial2dPadding(types_utils_1.getExactlyOneTensor(inputs), _this.padding, _this.dataFormat); }); + }; + ZeroPadding2D.prototype.getConfig = function () { + var config = { + padding: this.padding, + dataFormat: this.dataFormat, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ZeroPadding2D.className = 'ZeroPadding2D'; + return ZeroPadding2D; +}(topology_1.Layer)); +exports.ZeroPadding2D = ZeroPadding2D; +tfjs_core_1.serialization.SerializationMap.register(ZeroPadding2D); +//# sourceMappingURL=padding.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js.map new file mode 100644 index 0000000..d278899 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding.js.map @@ -0,0 +1 @@ +{"version":3,"file":"padding.js","sourceRoot":"","sources":["../../src/layers/padding.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/padding_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding_test.js.map new file mode 100644 index 0000000..e77e70f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/padding_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"padding_test.js","sourceRoot":"","sources":["../../src/layers/padding_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.d.ts new file mode 100644 index 0000000..ede7914 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.d.ts @@ -0,0 +1,90 @@ +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { DataFormat, PaddingMode, PoolMode } from '../common'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Kwargs, Shape } from '../types'; +export declare function pool2d(x: Tensor, poolSize: [number, number], strides?: [number, number], padding?: PaddingMode, dataFormat?: DataFormat, poolMode?: PoolMode): Tensor; +export interface Pooling1DLayerConfig extends LayerConfig { + poolSize?: number; + strides?: number; + padding?: PaddingMode; +} +export declare abstract class Pooling1D extends Layer { + protected readonly poolSize: [number]; + protected readonly strides: [number]; + protected readonly padding: PaddingMode; + constructor(config: Pooling1DLayerConfig); + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + protected abstract poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class MaxPooling1D extends Pooling1D { + static className: string; + constructor(config: Pooling1DLayerConfig); + protected poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; +} +export declare class AveragePooling1D extends Pooling1D { + static className: string; + constructor(config: Pooling1DLayerConfig); + protected poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; +} +export interface Pooling2DLayerConfig extends LayerConfig { + poolSize?: number | [number, number]; + strides?: number | [number, number]; + padding?: PaddingMode; + dataFormat?: DataFormat; +} +export declare abstract class Pooling2D extends Layer { + protected readonly poolSize: [number, number]; + protected readonly strides: [number, number]; + protected readonly padding: PaddingMode; + protected readonly dataFormat: DataFormat; + constructor(config: Pooling2DLayerConfig); + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + protected abstract poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class MaxPooling2D extends Pooling2D { + static className: string; + constructor(config: Pooling2DLayerConfig); + protected poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; +} +export declare class AveragePooling2D extends Pooling2D { + static className: string; + constructor(config: Pooling2DLayerConfig); + protected poolingFunction(inputs: Tensor, poolSize: [number, number], strides: [number, number], padding: PaddingMode, dataFormat: DataFormat): Tensor; +} +export declare abstract class GlobalPooling1D extends Layer { + constructor(config: LayerConfig); + computeOutputShape(inputShape: Shape): Shape; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export declare class GlobalAveragePooling1D extends GlobalPooling1D { + static className: string; + constructor(config: LayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export declare class GlobalMaxPooling1D extends GlobalPooling1D { + static className: string; + constructor(config: LayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export interface GlobalPooling2DLayerConfig extends LayerConfig { + dataFormat?: DataFormat; +} +export declare abstract class GlobalPooling2D extends Layer { + protected dataFormat: DataFormat; + constructor(config: GlobalPooling2DLayerConfig); + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export declare class GlobalAveragePooling2D extends GlobalPooling2D { + static className: string; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export declare class GlobalMaxPooling2D extends GlobalPooling2D { + static className: string; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js new file mode 100644 index 0000000..dda6337 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js @@ -0,0 +1,380 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("../backend/common"); +var K = require("../backend/tfjs_backend"); +var common_2 = require("../common"); +var topology_1 = require("../engine/topology"); +var topology_2 = require("../engine/topology"); +var errors_1 = require("../errors"); +var conv_utils_1 = require("../utils/conv_utils"); +var types_utils_1 = require("../utils/types_utils"); +var convolutional_1 = require("./convolutional"); +function pool2d(x, poolSize, strides, padding, dataFormat, poolMode) { + return tfjs_core_1.tidy(function () { + common_2.checkDataFormat(dataFormat); + common_2.checkPoolMode(poolMode); + common_2.checkPaddingMode(padding); + if (strides == null) { + strides = [1, 1]; + } + if (padding == null) { + padding = 'valid'; + } + if (dataFormat == null) { + dataFormat = common_1.imageDataFormat(); + } + if (poolMode == null) { + poolMode = 'max'; + } + x = convolutional_1.preprocessConv2DInput(x, dataFormat); + var y; + var paddingString = (padding === 'same') ? 'same' : 'valid'; + if (poolMode === 'max') { + y = tfc.maxPool(x, poolSize, strides, paddingString); + } + else { + y = tfc.avgPool(x, poolSize, strides, paddingString); + } + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); +} +exports.pool2d = pool2d; +var Pooling1D = (function (_super) { + __extends(Pooling1D, _super); + function Pooling1D(config) { + var _this = this; + if (config.poolSize == null) { + config.poolSize = 2; + } + _this = _super.call(this, config) || this; + if (typeof config.poolSize === 'number') { + _this.poolSize = [config.poolSize]; + } + else if (Array.isArray(config.poolSize) && + config.poolSize.length === 1 && + typeof config.poolSize[0] === 'number') { + _this.poolSize = config.poolSize; + } + else { + throw new errors_1.ValueError("poolSize for 1D convolutional layer must be a number or an " + + "Array of a single number, but received " + + ("" + JSON.stringify(config.poolSize))); + } + if (config.strides == null) { + _this.strides = _this.poolSize; + } + else { + if (typeof config.strides === 'number') { + _this.strides = [config.strides]; + } + else if (Array.isArray(config.strides) && + config.strides.length === 1 && + typeof config.strides[0] === 'number') { + _this.strides = config.strides; + } + else { + throw new errors_1.ValueError("strides for 1D convolutional layer must be a number or an " + + "Array of a single number, but received " + + ("" + JSON.stringify(config.strides))); + } + } + _this.padding = config.padding == null ? 'valid' : config.padding; + common_2.checkPaddingMode(_this.padding); + _this.inputSpec = [new topology_1.InputSpec({ ndim: 3 })]; + return _this; + } + Pooling1D.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var length = conv_utils_1.convOutputLength(inputShape[1], this.poolSize[0], this.padding, this.strides[0]); + return [inputShape[0], length, inputShape[2]]; + }; + Pooling1D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + inputs = K.expandDims(types_utils_1.getExactlyOneTensor(inputs), 2); + var output = _this.poolingFunction(types_utils_1.getExactlyOneTensor(inputs), [_this.poolSize[0], 1], [_this.strides[0], 1], _this.padding, 'channelsLast'); + return tfc.squeeze(output, [2]); + }); + }; + Pooling1D.prototype.getConfig = function () { + var config = { + poolSize: this.poolSize, + padding: this.padding, + strides: this.strides, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return Pooling1D; +}(topology_2.Layer)); +exports.Pooling1D = Pooling1D; +var MaxPooling1D = (function (_super) { + __extends(MaxPooling1D, _super); + function MaxPooling1D(config) { + return _super.call(this, config) || this; + } + MaxPooling1D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + common_2.checkDataFormat(dataFormat); + common_2.checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max'); + }; + MaxPooling1D.className = 'MaxPooling1D'; + return MaxPooling1D; +}(Pooling1D)); +exports.MaxPooling1D = MaxPooling1D; +tfjs_core_1.serialization.SerializationMap.register(MaxPooling1D); +var AveragePooling1D = (function (_super) { + __extends(AveragePooling1D, _super); + function AveragePooling1D(config) { + return _super.call(this, config) || this; + } + AveragePooling1D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + common_2.checkDataFormat(dataFormat); + common_2.checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg'); + }; + AveragePooling1D.className = 'AveragePooling1D'; + return AveragePooling1D; +}(Pooling1D)); +exports.AveragePooling1D = AveragePooling1D; +tfjs_core_1.serialization.SerializationMap.register(AveragePooling1D); +var Pooling2D = (function (_super) { + __extends(Pooling2D, _super); + function Pooling2D(config) { + var _this = this; + if (config.poolSize == null) { + config.poolSize = [2, 2]; + } + _this = _super.call(this, config) || this; + _this.poolSize = Array.isArray(config.poolSize) ? + config.poolSize : + [config.poolSize, config.poolSize]; + if (config.strides == null) { + _this.strides = _this.poolSize; + } + else if (Array.isArray(config.strides)) { + if (config.strides.length !== 2) { + throw new errors_1.ValueError("If the strides property of a 2D pooling layer is an Array, " + + "it is expected to have a length of 2, but received length " + + (config.strides.length + ".")); + } + _this.strides = config.strides; + } + else { + _this.strides = [config.strides, config.strides]; + } + _this.padding = config.padding == null ? 'valid' : config.padding; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + common_2.checkDataFormat(_this.dataFormat); + common_2.checkPaddingMode(_this.padding); + _this.inputSpec = [new topology_1.InputSpec({ ndim: 4 })]; + return _this; + } + Pooling2D.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var rows = this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1]; + var cols = this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2]; + rows = + conv_utils_1.convOutputLength(rows, this.poolSize[0], this.padding, this.strides[0]); + cols = + conv_utils_1.convOutputLength(cols, this.poolSize[1], this.padding, this.strides[1]); + if (this.dataFormat === 'channelsFirst') { + return [inputShape[0], inputShape[1], rows, cols]; + } + else { + return [inputShape[0], rows, cols, inputShape[3]]; + } + }; + Pooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + return _this.poolingFunction(types_utils_1.getExactlyOneTensor(inputs), _this.poolSize, _this.strides, _this.padding, _this.dataFormat); + }); + }; + Pooling2D.prototype.getConfig = function () { + var config = { + poolSize: this.poolSize, + padding: this.padding, + strides: this.strides, + dataFormat: this.dataFormat + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return Pooling2D; +}(topology_2.Layer)); +exports.Pooling2D = Pooling2D; +var MaxPooling2D = (function (_super) { + __extends(MaxPooling2D, _super); + function MaxPooling2D(config) { + return _super.call(this, config) || this; + } + MaxPooling2D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + common_2.checkDataFormat(dataFormat); + common_2.checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max'); + }; + MaxPooling2D.className = 'MaxPooling2D'; + return MaxPooling2D; +}(Pooling2D)); +exports.MaxPooling2D = MaxPooling2D; +tfjs_core_1.serialization.SerializationMap.register(MaxPooling2D); +var AveragePooling2D = (function (_super) { + __extends(AveragePooling2D, _super); + function AveragePooling2D(config) { + return _super.call(this, config) || this; + } + AveragePooling2D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + common_2.checkDataFormat(dataFormat); + common_2.checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg'); + }; + AveragePooling2D.className = 'AveragePooling2D'; + return AveragePooling2D; +}(Pooling2D)); +exports.AveragePooling2D = AveragePooling2D; +tfjs_core_1.serialization.SerializationMap.register(AveragePooling2D); +var GlobalPooling1D = (function (_super) { + __extends(GlobalPooling1D, _super); + function GlobalPooling1D(config) { + var _this = _super.call(this, config) || this; + _this.inputSpec = [new topology_1.InputSpec({ ndim: 3 })]; + return _this; + } + GlobalPooling1D.prototype.computeOutputShape = function (inputShape) { + return [inputShape[0], inputShape[2]]; + }; + GlobalPooling1D.prototype.call = function (inputs, kwargs) { + throw new errors_1.NotImplementedError(); + }; + return GlobalPooling1D; +}(topology_2.Layer)); +exports.GlobalPooling1D = GlobalPooling1D; +var GlobalAveragePooling1D = (function (_super) { + __extends(GlobalAveragePooling1D, _super); + function GlobalAveragePooling1D(config) { + return _super.call(this, config) || this; + } + GlobalAveragePooling1D.prototype.call = function (inputs, kwargs) { + return tfjs_core_1.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + return tfc.mean(input, 1); + }); + }; + GlobalAveragePooling1D.className = 'GlobalAveragePooling1D'; + return GlobalAveragePooling1D; +}(GlobalPooling1D)); +exports.GlobalAveragePooling1D = GlobalAveragePooling1D; +tfjs_core_1.serialization.SerializationMap.register(GlobalAveragePooling1D); +var GlobalMaxPooling1D = (function (_super) { + __extends(GlobalMaxPooling1D, _super); + function GlobalMaxPooling1D(config) { + return _super.call(this, config) || this; + } + GlobalMaxPooling1D.prototype.call = function (inputs, kwargs) { + return tfjs_core_1.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + return tfc.max(input, 1); + }); + }; + GlobalMaxPooling1D.className = 'GlobalMaxPooling1D'; + return GlobalMaxPooling1D; +}(GlobalPooling1D)); +exports.GlobalMaxPooling1D = GlobalMaxPooling1D; +tfjs_core_1.serialization.SerializationMap.register(GlobalMaxPooling1D); +var GlobalPooling2D = (function (_super) { + __extends(GlobalPooling2D, _super); + function GlobalPooling2D(config) { + var _this = _super.call(this, config) || this; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + common_2.checkDataFormat(_this.dataFormat); + _this.inputSpec = [new topology_1.InputSpec({ ndim: 4 })]; + return _this; + } + GlobalPooling2D.prototype.computeOutputShape = function (inputShape) { + inputShape = inputShape; + if (this.dataFormat === 'channelsLast') { + return [inputShape[0], inputShape[3]]; + } + else { + return [inputShape[0], inputShape[1]]; + } + }; + GlobalPooling2D.prototype.call = function (inputs, kwargs) { + throw new errors_1.NotImplementedError(); + }; + GlobalPooling2D.prototype.getConfig = function () { + var config = { dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return GlobalPooling2D; +}(topology_2.Layer)); +exports.GlobalPooling2D = GlobalPooling2D; +var GlobalAveragePooling2D = (function (_super) { + __extends(GlobalAveragePooling2D, _super); + function GlobalAveragePooling2D() { + return _super !== null && _super.apply(this, arguments) || this; + } + GlobalAveragePooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + return tfc.mean(input, [1, 2]); + } + else { + return tfc.mean(input, [2, 3]); + } + }); + }; + GlobalAveragePooling2D.className = 'GlobalAveragePooling2D'; + return GlobalAveragePooling2D; +}(GlobalPooling2D)); +exports.GlobalAveragePooling2D = GlobalAveragePooling2D; +tfjs_core_1.serialization.SerializationMap.register(GlobalAveragePooling2D); +var GlobalMaxPooling2D = (function (_super) { + __extends(GlobalMaxPooling2D, _super); + function GlobalMaxPooling2D() { + return _super !== null && _super.apply(this, arguments) || this; + } + GlobalMaxPooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var input = types_utils_1.getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + return tfc.max(input, [1, 2]); + } + else { + return tfc.max(input, [2, 3]); + } + }); + }; + GlobalMaxPooling2D.className = 'GlobalMaxPooling2D'; + return GlobalMaxPooling2D; +}(GlobalPooling2D)); +exports.GlobalMaxPooling2D = GlobalMaxPooling2D; +tfjs_core_1.serialization.SerializationMap.register(GlobalMaxPooling2D); +//# sourceMappingURL=pooling.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js.map new file mode 100644 index 0000000..7f4df15 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pooling.js","sourceRoot":"","sources":["../../src/layers/pooling.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling_test.js.map new file mode 100644 index 0000000..79a19e5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/pooling_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pooling_test.js","sourceRoot":"","sources":["../../src/layers/pooling_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.d.ts new file mode 100644 index 0000000..8818eee --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.d.ts @@ -0,0 +1,286 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Activation, ActivationIdentifier } from '../activations'; +import { Constraint, ConstraintIdentifier } from '../constraints'; +import { InputSpec, SymbolicTensor } from '../engine/topology'; +import { Layer, LayerConfig } from '../engine/topology'; +import { Initializer, InitializerIdentifier } from '../initializers'; +import { Regularizer, RegularizerIdentifier } from '../regularizers'; +import { Kwargs, RnnStepFunction, Shape } from '../types'; +import { LayerVariable } from '../variables'; +export declare function standardizeArgs(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], initialState: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], constants: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], numConstants?: number): { + inputs: Tensor | SymbolicTensor; + initialState: Tensor[] | SymbolicTensor[]; + constants: Tensor[] | SymbolicTensor[]; +}; +export declare function rnn(stepFunction: RnnStepFunction, inputs: Tensor, initialStates: Tensor[], goBackwards?: boolean, mask?: Tensor, constants?: Tensor[], unroll?: boolean, inputLength?: number): [Tensor, Tensor, Tensor[]]; +export interface BaseRNNLayerConfig extends LayerConfig { + cell?: RNNCell | RNNCell[]; + returnSequences?: boolean; + returnState?: boolean; + goBackwards?: boolean; + stateful?: boolean; + unroll?: boolean; + inputDim?: number; + inputLength?: number; +} +export interface RNNLayerConfig extends BaseRNNLayerConfig { + cell: RNNCell | RNNCell[]; +} +export declare class RNN extends Layer { + static className: string; + readonly cell: RNNCell; + readonly returnSequences: boolean; + readonly returnState: boolean; + readonly goBackwards: boolean; + readonly unroll: boolean; + stateSpec: InputSpec[]; + states: Tensor[]; + private numConstants; + constructor(config: RNNLayerConfig); + getStates(): Tensor[]; + setStates(states: Tensor[]): void; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + computeMask(inputs: Tensor | Tensor[], mask?: Tensor | Tensor[]): Tensor; + build(inputShape: Shape | Shape[]): void; + resetStates(states?: Tensor | Tensor[]): void; + apply(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], kwargs?: Kwargs): Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getInitialState(inputs: Tensor): Tensor[]; + readonly trainableWeights: LayerVariable[]; + readonly nonTrainableWeights: LayerVariable[]; + getConfig(): serialization.ConfigDict; +} +export declare abstract class RNNCell extends Layer { + stateSize: number | number[]; + dropoutMask: Tensor | Tensor[]; + recurrentDropoutMask: Tensor | Tensor[]; +} +export interface SimpleRNNCellLayerConfig extends LayerConfig { + units: number; + activation?: ActivationIdentifier; + useBias?: boolean; + kernelInitializer?: InitializerIdentifier | Initializer; + recurrentInitializer?: InitializerIdentifier | Initializer; + biasInitializer?: InitializerIdentifier | Initializer; + kernelRegularizer?: RegularizerIdentifier | Regularizer; + recurrentRegularizer?: RegularizerIdentifier | Regularizer; + biasRegularizer?: RegularizerIdentifier | Regularizer; + kernelConstraint?: ConstraintIdentifier | Constraint; + recurrentConstraint?: ConstraintIdentifier | Constraint; + biasConstraint?: ConstraintIdentifier | Constraint; + dropout?: number; + recurrentDropout?: number; +} +export declare class SimpleRNNCell extends RNNCell { + static className: string; + readonly units: number; + readonly activation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly dropout: number; + readonly recurrentDropout: number; + readonly stateSize: number; + kernel: LayerVariable; + recurrentKernel: LayerVariable; + bias: LayerVariable; + readonly DEFAULT_ACTIVATION: string; + readonly DEFAULT_KERNEL_INITIALIZER: string; + readonly DEFAULT_RECURRENT_INITIALIZER: string; + readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier; + constructor(config: SimpleRNNCellLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface SimpleRNNLayerConfig extends BaseRNNLayerConfig { + units: number; + activation?: ActivationIdentifier; + useBias?: boolean; + kernelInitializer?: InitializerIdentifier | Initializer; + recurrentInitializer?: InitializerIdentifier | Initializer; + biasInitializer?: InitializerIdentifier | Initializer; + kernelRegularizer?: RegularizerIdentifier | Regularizer; + recurrentRegularizer?: RegularizerIdentifier | Regularizer; + biasRegularizer?: RegularizerIdentifier | Regularizer; + kernelConstraint?: ConstraintIdentifier | Constraint; + recurrentConstraint?: ConstraintIdentifier | Constraint; + biasConstraint?: ConstraintIdentifier | Constraint; + dropout?: number; + recurrentDropout?: number; +} +export declare class SimpleRNN extends RNN { + static className: string; + constructor(config: SimpleRNNLayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + readonly units: number; + readonly activation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly dropout: number; + readonly recurrentDropout: number; + getConfig(): serialization.ConfigDict; +} +export interface GRUCellLayerConfig extends SimpleRNNCellLayerConfig { + recurrentActivation?: string; + implementation?: number; +} +export declare class GRUCell extends RNNCell { + static className: string; + readonly units: number; + readonly activation: Activation; + readonly recurrentActivation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly dropout: number; + readonly recurrentDropout: number; + readonly stateSize: number; + readonly implementation: number; + readonly DEFAULT_ACTIVATION: string; + readonly DEFAULT_RECURRENT_ACTIVATION: string; + readonly DEFAULT_KERNEL_INITIALIZER: string; + readonly DEFAULT_RECURRENT_INITIALIZER: string; + readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier; + kernel: LayerVariable; + recurrentKernel: LayerVariable; + bias: LayerVariable; + constructor(config: GRUCellLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface GRULayerConfig extends SimpleRNNLayerConfig { + recurrentActivation?: string; + implementation?: number; +} +export declare class GRU extends RNN { + static className: string; + constructor(config: GRULayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + readonly units: number; + readonly activation: Activation; + readonly recurrentActivation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly dropout: number; + readonly recurrentDropout: number; + readonly implementation: number; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; +} +export interface LSTMCellLayerConfig extends SimpleRNNCellLayerConfig { + recurrentActivation?: ActivationIdentifier; + unitForgetBias?: boolean; + implementation?: 1 | 2; +} +export declare class LSTMCell extends RNNCell { + static className: string; + readonly units: number; + readonly activation: Activation; + readonly recurrentActivation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly unitForgetBias: boolean; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly dropout: number; + readonly recurrentDropout: number; + readonly stateSize: number[]; + readonly implementation: number; + readonly DEFAULT_ACTIVATION: string; + readonly DEFAULT_RECURRENT_ACTIVATION: string; + readonly DEFAULT_KERNEL_INITIALIZER: string; + readonly DEFAULT_RECURRENT_INITIALIZER: string; + readonly DEFAULT_BIAS_INITIALIZER: string; + kernel: LayerVariable; + recurrentKernel: LayerVariable; + bias: LayerVariable; + constructor(config: LSTMCellLayerConfig); + build(inputShape: Shape | Shape[]): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + getConfig(): serialization.ConfigDict; +} +export interface LSTMLayerConfig extends SimpleRNNLayerConfig { + recurrentActivation?: string; + unitForgetBias?: boolean; + implementation?: 1 | 2; +} +export declare class LSTM extends RNN { + static className: string; + constructor(config: LSTMLayerConfig); + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + readonly units: number; + readonly activation: Activation; + readonly recurrentActivation: Activation; + readonly useBias: boolean; + readonly kernelInitializer: Initializer; + readonly recurrentInitializer: Initializer; + readonly biasInitializer: Initializer; + readonly unitForgetBias: boolean; + readonly kernelRegularizer: Regularizer; + readonly recurrentRegularizer: Regularizer; + readonly biasRegularizer: Regularizer; + readonly kernelConstraint: Constraint; + readonly recurrentConstraint: Constraint; + readonly biasConstraint: Constraint; + readonly dropout: number; + readonly recurrentDropout: number; + readonly implementation: number; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; +} +export interface StackedRNNCellsConfig extends LayerConfig { + cells: RNNCell[]; +} +export declare class StackedRNNCells extends RNNCell { + static className: string; + protected cells: RNNCell[]; + constructor(config: StackedRNNCellsConfig); + readonly stateSize: number[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + build(inputShape: Shape | Shape[]): void; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict, customObjects?: tfc.serialization.ConfigDict): T; + readonly trainableWeights: LayerVariable[]; + readonly nonTrainableWeights: LayerVariable[]; + getWeights(): Tensor[]; + setWeights(weights: Tensor[]): void; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js new file mode 100644 index 0000000..f0c6246 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js @@ -0,0 +1,1628 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var activations_1 = require("../activations"); +var state_1 = require("../backend/state"); +var K = require("../backend/tfjs_backend"); +var constraints_1 = require("../constraints"); +var topology_1 = require("../engine/topology"); +var topology_2 = require("../engine/topology"); +var errors_1 = require("../errors"); +var initializers_1 = require("../initializers"); +var regularizers_1 = require("../regularizers"); +var math_utils = require("../utils/math_utils"); +var types_utils_1 = require("../utils/types_utils"); +var variables_1 = require("../variables"); +var serialization_1 = require("./serialization"); +function standardizeArgs(inputs, initialState, constants, numConstants) { + if (Array.isArray(inputs)) { + if (initialState != null || constants != null) { + throw new errors_1.ValueError('When inputs is an array, neither initialState or constants ' + + 'should be provided'); + } + if (numConstants != null) { + constants = inputs.slice(inputs.length - numConstants, inputs.length); + inputs = inputs.slice(0, inputs.length - numConstants); + } + if (inputs.length > 1) { + initialState = inputs.slice(1, inputs.length); + } + inputs = inputs[0]; + } + function toListOrNull(x) { + if (x == null || Array.isArray(x)) { + return x; + } + else { + return [x]; + } + } + initialState = toListOrNull(initialState); + constants = toListOrNull(constants); + return { inputs: inputs, initialState: initialState, constants: constants }; +} +exports.standardizeArgs = standardizeArgs; +function rnn(stepFunction, inputs, initialStates, goBackwards, mask, constants, unroll, inputLength) { + if (goBackwards === void 0) { goBackwards = false; } + if (unroll === void 0) { unroll = false; } + var ndim = inputs.shape.length; + if (ndim < 3) { + throw new errors_1.ValueError("Input should be at least 3D, but is " + ndim + "D."); + } + var axes = [1, 0].concat(math_utils.range(2, ndim)); + inputs = tfc.transpose(inputs, axes); + if (mask != null) { + throw new errors_1.NotImplementedError('The rnn() function of the deeplearn.js backend does not support ' + + 'masking yet.'); + } + if (constants != null) { + throw new errors_1.NotImplementedError('The rnn() functoin of the deeplearn.js backend does not support ' + + 'constants yet.'); + } + if (unroll) { + console.warn('Backend rnn(): the unroll = true option is not applicable to the ' + + 'imperative deeplearn.js backend.'); + } + if (goBackwards) { + inputs = tfc.reverse(inputs, 0); + } + var outputs; + var lastOutput; + var states = initialStates; + var timeSteps = inputs.shape[0]; + for (var t = 0; t < timeSteps; ++t) { + var currentInput = K.sliceAlongFirstAxis(inputs, t, 1); + currentInput = currentInput.reshape(currentInput.shape.slice(1)); + var stepOutputs = stepFunction(currentInput, states); + lastOutput = stepOutputs[0]; + if (t === 0) { + outputs = lastOutput.reshape([1].concat(lastOutput.shape)); + } + else { + outputs = K.concatAlongFirstAxis(outputs, lastOutput.reshape([1].concat(lastOutput.shape))); + } + states = stepOutputs[1]; + } + return [ + lastOutput, + tfc.transpose(outputs, [1, 0].concat(math_utils.range(2, outputs.shape.length))), + states + ]; +} +exports.rnn = rnn; +var RNN = (function (_super) { + __extends(RNN, _super); + function RNN(config) { + var _this = _super.call(this, config) || this; + var cell; + if (config.cell == null) { + throw new errors_1.ValueError('cell property is missing for the constructor of RNN.'); + } + else if (Array.isArray(config.cell)) { + cell = new StackedRNNCells({ cells: config.cell }); + } + else { + cell = config.cell; + } + if (cell.stateSize == null) { + throw new errors_1.ValueError('The RNN cell should have an attribute `stateSize` (tuple of ' + + 'integers, one integer per RNN state).'); + } + _this.cell = cell; + _this.returnSequences = + config.returnSequences == null ? false : config.returnSequences; + _this.returnState = config.returnState == null ? false : config.returnState; + _this.goBackwards = config.goBackwards == null ? false : config.goBackwards; + _this._stateful = config.stateful == null ? false : config.stateful; + _this.unroll = config.unroll == null ? false : config.unroll; + _this.supportsMasking = true; + _this.inputSpec = [new topology_1.InputSpec({ ndim: 3 })]; + _this.stateSpec = null; + _this.states = null; + _this.numConstants = null; + return _this; + } + RNN.prototype.getStates = function () { + if (this.states == null) { + var numStates = Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1; + return math_utils.range(0, numStates).map(function (x) { return null; }); + } + else { + return this.states; + } + }; + RNN.prototype.setStates = function (states) { + this.states = states; + }; + RNN.prototype.computeOutputShape = function (inputShape) { + if (types_utils_1.isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var stateSize = this.cell.stateSize; + if (!Array.isArray(stateSize)) { + stateSize = [stateSize]; + } + var outputDim = stateSize[0]; + var outputShape; + if (this.returnSequences) { + outputShape = [inputShape[0], inputShape[1], outputDim]; + } + else { + outputShape = [inputShape[0], outputDim]; + } + if (this.returnState) { + var stateShape = []; + for (var _i = 0, stateSize_1 = stateSize; _i < stateSize_1.length; _i++) { + var dim = stateSize_1[_i]; + stateShape.push([inputShape[0], dim]); + } + return [outputShape].concat(stateShape); + } + else { + return outputShape; + } + }; + RNN.prototype.computeMask = function (inputs, mask) { + throw new errors_1.NotImplementedError('computeMask has not been implemented for RNN yet'); + }; + RNN.prototype.build = function (inputShape) { + var constantShape = null; + if (this.numConstants != null) { + throw new errors_1.NotImplementedError('Constants support is not implemented in RNN yet.'); + } + if (types_utils_1.isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var batchSize = this.stateful ? inputShape[0] : null; + var inputDim = inputShape[inputShape.length - 1]; + this.inputSpec[0] = new topology_1.InputSpec({ shape: [batchSize, null, inputDim] }); + var stepInputShape = [inputShape[0]].concat(inputShape.slice(2)); + if (constantShape != null) { + throw new errors_1.NotImplementedError('Constants support is not implemented in RNN yet.'); + } + else { + this.cell.build(stepInputShape); + } + var stateSize; + if (Array.isArray(this.cell.stateSize)) { + stateSize = this.cell.stateSize; + } + else { + stateSize = [this.cell.stateSize]; + } + if (this.stateSpec != null) { + if (!tfjs_core_1.util.arraysEqual(this.stateSpec.map(function (spec) { return spec.shape[spec.shape.length - 1]; }), stateSize)) { + throw new errors_1.ValueError("An initialState was passed that is not compatible with " + + ("cell.stateSize. Received stateSpec=" + this.stateSpec + "; ") + + ("However cell.stateSize is " + this.cell.stateSize)); + } + } + else { + this.stateSpec = + stateSize.map(function (dim) { return new topology_1.InputSpec({ shape: [null, dim] }); }); + } + if (this.stateful) { + throw new errors_1.NotImplementedError('stateful RNN layer is not implemented yet'); + } + }; + RNN.prototype.resetStates = function (states) { + var _this = this; + tfjs_core_1.tidy(function () { + if (!_this.stateful) { + throw new errors_1.AttributeError('Cannot call resetState() on an RNN Layer that is not stateful.'); + } + var batchSize = _this.inputSpec[0].shape[0]; + if (batchSize == null) { + throw new errors_1.ValueError('If an RNN is stateful, it needs to know its batch size. Specify ' + + 'the batch size of your input tensors: \n' + + '- If using a Sequential model, specify the batch size by ' + + 'passing a `batchInputShape` option to your first layer.\n' + + '- If using the functional API, specify the batch size by ' + + 'passing a `batchShape` option to your Input layer.'); + } + if (_this.states == null) { + if (Array.isArray(_this.cell.stateSize)) { + _this.states = + _this.cell.stateSize.map(function (dim) { return tfc.zeros([batchSize, dim]); }); + } + else { + _this.states = [tfc.zeros([batchSize, _this.cell.stateSize])]; + } + } + else if (states == null) { + if (Array.isArray(_this.cell.stateSize)) { + _this.states = + _this.cell.stateSize.map(function (dim) { return tfc.zeros([batchSize, dim]); }); + } + else { + _this.states[0] = tfc.zeros([batchSize, _this.cell.stateSize]); + } + } + else { + if (!Array.isArray(states)) { + states = [states]; + } + if (states.length !== _this.states.length) { + throw new errors_1.ValueError("Layer " + _this.name + " expects " + _this.states.length + " state(s), " + + ("but it received " + states.length + " state value(s). Input ") + + ("received: " + states)); + } + for (var index = 0; index < _this.states.length; ++index) { + var value = states[index]; + var dim = Array.isArray(_this.cell.stateSize) ? + _this.cell.stateSize[index] : + _this.cell.stateSize; + var expectedShape = [batchSize, dim]; + if (!tfjs_core_1.util.arraysEqual(value.shape, expectedShape)) { + throw new errors_1.ValueError("State " + index + " is incompatible with layer " + _this.name + ": " + + ("expected shape=" + expectedShape + ", received shape=" + value.shape)); + } + _this.states[index] = value; + } + } + }); + }; + RNN.prototype.apply = function (inputs, kwargs) { + var initialState = kwargs == null ? null : kwargs['initialState']; + var constants = kwargs == null ? null : kwargs['constants']; + if (kwargs == null) { + kwargs = {}; + } + var standardized = standardizeArgs(inputs, initialState, constants, this.numConstants); + inputs = standardized.inputs; + initialState = standardized.initialState; + constants = standardized.constants; + var additionalInputs = []; + var additionalSpecs = []; + if (initialState != null) { + kwargs['initialState'] = initialState; + additionalInputs = additionalInputs.concat(initialState); + this.stateSpec = []; + for (var _i = 0, initialState_1 = initialState; _i < initialState_1.length; _i++) { + var state = initialState_1[_i]; + this.stateSpec.push(new topology_1.InputSpec({ shape: state.shape })); + } + additionalSpecs = additionalSpecs.concat(this.stateSpec); + } + if (constants != null) { + kwargs['constants'] = constants; + additionalInputs = additionalInputs.concat(constants); + this.numConstants = constants.length; + } + var isTensor = additionalInputs[0] instanceof topology_1.SymbolicTensor; + if (isTensor) { + var fullInput = [inputs].concat(additionalInputs); + var fullInputSpec = this.inputSpec.concat(additionalSpecs); + var originalInputSpec = this.inputSpec; + this.inputSpec = fullInputSpec; + var output = _super.prototype.apply.call(this, fullInput, kwargs); + this.inputSpec = originalInputSpec; + return output; + } + else { + return _super.prototype.apply.call(this, inputs, kwargs); + } + }; + RNN.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + inputs = types_utils_1.getExactlyOneTensor(inputs); + if (initialState == null) { + if (_this.stateful) { + throw new errors_1.NotImplementedError('stateful RNN layer is not implemented yet.'); + } + else { + initialState = _this.getInitialState(inputs); + } + } + if (mask != null) { + throw new errors_1.NotImplementedError('Masking is not implemented for RNN yet'); + } + var numStates = Array.isArray(_this.cell.stateSize) ? _this.cell.stateSize.length : 1; + if (initialState.length !== numStates) { + throw new errors_1.ValueError("RNN Layer has " + numStates + " state(s) but was passed " + + (initialState.length + " initial state(s).")); + } + var inputShape = inputs.shape; + var timesteps = inputShape[1]; + if (_this.unroll) { + console.warn('Ignoring unroll = true for RNN layer, due to imperative backend.'); + } + var cellCallKwargs = { training: training }; + var step = function (inputs, states) { + var outputs = _this.cell.call([inputs].concat(states), cellCallKwargs); + return [outputs[0], outputs.slice(1)]; + }; + var rnnOutputs = rnn(step, inputs, initialState, _this.goBackwards, null, null, _this.unroll, timesteps); + var lastOutput = rnnOutputs[0]; + var outputs = rnnOutputs[1]; + var states = rnnOutputs[2]; + if (_this.stateful) { + throw new errors_1.NotImplementedError('stateful RNN layer is not implemented yet'); + } + var output = _this.returnSequences ? outputs : lastOutput; + if (_this.returnState) { + return [output].concat(states); + } + else { + return output; + } + }); + }; + RNN.prototype.getInitialState = function (inputs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var initialState = tfc.zeros(inputs.shape); + initialState = tfc.sum(initialState, [1, 2]); + initialState = K.expandDims(initialState); + if (Array.isArray(_this.cell.stateSize)) { + return _this.cell.stateSize.map(function (dim) { return dim > 1 ? K.tile(initialState, [1, dim]) : initialState; }); + } + else { + return _this.cell.stateSize > 1 ? + [K.tile(initialState, [1, _this.cell.stateSize])] : + [initialState]; + } + }); + }; + Object.defineProperty(RNN.prototype, "trainableWeights", { + get: function () { + if (!this.trainable) { + return []; + } + return this.cell.trainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(RNN.prototype, "nonTrainableWeights", { + get: function () { + if (!this.trainable) { + return this.cell.weights; + } + return this.cell.nonTrainableWeights; + }, + enumerable: true, + configurable: true + }); + RNN.prototype.getConfig = function () { + var config = { + returnSequences: this.returnSequences, + returnState: this.returnState, + goBackwards: this.goBackwards, + stateful: this.stateful, + unroll: this.unroll, + }; + if (this.numConstants != null) { + config.numConstants = this.numConstants; + } + var cellConfig = this.cell.getConfig(); + config.cell = { + className: this.cell.getClassName(), + config: cellConfig, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + RNN.className = 'RNN'; + return RNN; +}(topology_2.Layer)); +exports.RNN = RNN; +tfjs_core_1.serialization.SerializationMap.register(RNN); +var RNNCell = (function (_super) { + __extends(RNNCell, _super); + function RNNCell() { + return _super !== null && _super.apply(this, arguments) || this; + } + return RNNCell; +}(topology_2.Layer)); +exports.RNNCell = RNNCell; +var SimpleRNNCell = (function (_super) { + __extends(SimpleRNNCell, _super); + function SimpleRNNCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = activations_1.getActivation(config.activation == null ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = initializers_1.getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = initializers_1.getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + initializers_1.getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelRegularizer = regularizers_1.getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = regularizers_1.getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = regularizers_1.getRegularizer(config.biasRegularizer); + _this.kernelConstraint = constraints_1.getConstraint(config.kernelConstraint); + _this.recurrentConstraint = constraints_1.getConstraint(config.recurrentConstraint); + _this.biasConstraint = constraints_1.getConstraint(config.biasConstraint); + _this.dropout = math_utils.min([1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = math_utils.min([ + 1, + math_utils.max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.stateSize = _this.units; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + SimpleRNNCell.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + this.kernel = this.addWeight('kernel', [inputShape[inputShape.length - 1], this.units], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + SimpleRNNCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = inputs; + if (inputs.length !== 2) { + throw new errors_1.ValueError("SimpleRNNCell expects 2 input Tensors, got " + inputs.length + "."); + } + var prevOutput = inputs[1]; + inputs = inputs[0]; + var training = kwargs['training'] == null ? false : kwargs['training']; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(prevOutput); }, _this.recurrentDropout, training); + } + var h; + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + if (dpMask != null) { + h = K.dot(tfc.mul(inputs, dpMask), _this.kernel.read()); + } + else { + h = K.dot(inputs, _this.kernel.read()); + } + if (_this.bias != null) { + h = K.biasAdd(h, _this.bias.read()); + } + if (recDpMask != null) { + prevOutput = tfc.mul(prevOutput, recDpMask); + } + var output = tfc.add(h, K.dot(prevOutput, _this.recurrentKernel.read())); + if (_this.activation != null) { + output = _this.activation.apply(output); + } + return [output, output]; + }); + }; + SimpleRNNCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + SimpleRNNCell.className = 'SimpleRNNCell'; + return SimpleRNNCell; +}(RNNCell)); +exports.SimpleRNNCell = SimpleRNNCell; +tfjs_core_1.serialization.SerializationMap.register(SimpleRNNCell); +var SimpleRNN = (function (_super) { + __extends(SimpleRNN, _super); + function SimpleRNN(config) { + var _this = this; + config.cell = new SimpleRNNCell(config); + _this = _super.call(this, config) || this; + return _this; + } + SimpleRNN.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(SimpleRNN.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + SimpleRNN.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + SimpleRNN.className = 'SimpleRNN'; + return SimpleRNN; +}(RNN)); +exports.SimpleRNN = SimpleRNN; +tfjs_core_1.serialization.SerializationMap.register(SimpleRNN); +var GRUCell = (function (_super) { + __extends(GRUCell, _super); + function GRUCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = activations_1.getActivation(config.activation === undefined ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.recurrentActivation = activations_1.getActivation(config.recurrentActivation === undefined ? + _this.DEFAULT_RECURRENT_ACTIVATION : + config.recurrentActivation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = initializers_1.getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = initializers_1.getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + initializers_1.getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelRegularizer = regularizers_1.getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = regularizers_1.getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = regularizers_1.getRegularizer(config.biasRegularizer); + _this.kernelConstraint = constraints_1.getConstraint(config.kernelConstraint); + _this.recurrentConstraint = constraints_1.getConstraint(config.recurrentConstraint); + _this.biasConstraint = constraints_1.getConstraint(config.biasConstraint); + _this.dropout = math_utils.min([1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = math_utils.min([ + 1, + math_utils.max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.implementation = config.implementation; + _this.stateSize = _this.units; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + GRUCell.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var inputDim = inputShape[inputShape.length - 1]; + this.kernel = this.addWeight('kernel', [inputDim, this.units * 3], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units * 3], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units * 3], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + GRUCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = inputs; + if (inputs.length !== 2) { + throw new errors_1.ValueError("GRUCell expects 2 input Tensors (inputs, h, c), got " + + (inputs.length + ".")); + } + var training = kwargs['training'] == null ? false : kwargs['training']; + var hTMinus1 = inputs[1]; + inputs = inputs[0]; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training, 3); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(hTMinus1); }, _this.recurrentDropout, training, 3); + } + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + var z; + var r; + var hh; + if (_this.implementation === 1) { + var kernelZ = K.sliceAlongLastAxis(_this.kernel.read(), 0, _this.units); + var kernelR = K.sliceAlongLastAxis(_this.kernel.read(), _this.units, _this.units); + var kernelH = K.sliceAlongLastAxis(_this.kernel.read(), _this.units * 2, _this.units); + var recurrentKernelZ = K.sliceAlongLastAxis(_this.recurrentKernel.read(), 0, _this.units); + var recurrentKernelR = K.sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units, _this.units); + var recurrentKernelH = K.sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 2, _this.units); + var inputsZ = void 0, inputsR = void 0, inputsH = void 0; + if (0 < _this.dropout && _this.dropout < 1) { + inputsZ = tfc.mul(inputs, dpMask[0]); + inputsR = tfc.mul(inputs, dpMask[1]); + inputsH = tfc.mul(inputs, dpMask[2]); + } + else { + inputsZ = inputs; + inputsR = inputs; + inputsH = inputs; + } + var xZ = K.dot(inputsZ, kernelZ); + var xR = K.dot(inputsR, kernelR); + var xH = K.dot(inputsH, kernelH); + if (_this.useBias) { + var biasZ = K.sliceAlongFirstAxis(_this.bias.read(), 0, _this.units); + var biasR = K.sliceAlongFirstAxis(_this.bias.read(), _this.units, _this.units); + var biasH = K.sliceAlongFirstAxis(_this.bias.read(), _this.units * 2, _this.units); + xZ = K.biasAdd(xZ, biasZ); + xR = K.biasAdd(xR, biasR); + xH = K.biasAdd(xH, biasH); + } + var hTMinus1Z = void 0; + var hTMinus1R = void 0; + var hTMinus1H = void 0; + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1Z = tfc.mul(hTMinus1, recDpMask[0]); + hTMinus1R = tfc.mul(hTMinus1, recDpMask[1]); + hTMinus1H = tfc.mul(hTMinus1, recDpMask[2]); + } + else { + hTMinus1Z = hTMinus1; + hTMinus1R = hTMinus1; + hTMinus1H = hTMinus1; + } + z = _this.recurrentActivation.apply(tfc.add(xZ, K.dot(hTMinus1Z, recurrentKernelZ))); + r = _this.recurrentActivation.apply(tfc.add(xR, K.dot(hTMinus1R, recurrentKernelR))); + hh = _this.activation.apply(tfc.add(xH, K.dot(tfc.mul(r, hTMinus1H), recurrentKernelH))); + } + else { + if (0 < _this.dropout && _this.dropout < 1) { + inputs = tfc.mul(inputs, dpMask[0]); + } + var matrixX = K.dot(inputs, _this.kernel.read()); + if (_this.useBias) { + matrixX = K.biasAdd(matrixX, _this.bias.read()); + } + if (0 < _this.dropout && _this.dropout < 1) { + hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]); + } + var matrixInner = K.dot(hTMinus1, K.sliceAlongLastAxis(_this.recurrentKernel.read(), 0, 2 * _this.units)); + var xZ = K.sliceAlongLastAxis(matrixX, 0, _this.units); + var xR = K.sliceAlongLastAxis(matrixX, _this.units, _this.units); + var recurrentZ = K.sliceAlongLastAxis(matrixInner, 0, _this.units); + var recurrentR = K.sliceAlongLastAxis(matrixInner, _this.units, _this.units); + z = _this.recurrentActivation.apply(tfc.add(xZ, recurrentZ)); + r = _this.recurrentActivation.apply(tfc.add(xR, recurrentR)); + var xH = K.sliceAlongLastAxis(matrixX, 2 * _this.units, _this.units); + var recurrentH = K.dot(tfc.mul(r, hTMinus1), K.sliceAlongLastAxis(_this.recurrentKernel.read(), 2 * _this.units, _this.units)); + hh = _this.activation.apply(tfc.add(xH, recurrentH)); + } + var h = tfc.add(tfc.mul(z, hTMinus1), tfc.mul(tfc.add(state_1.getScalar(1), tfc.neg(z)), hh)); + return [h, h]; + }); + }; + GRUCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + recurrentActivation: activations_1.serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + GRUCell.className = 'GRUCell'; + return GRUCell; +}(RNNCell)); +exports.GRUCell = GRUCell; +tfjs_core_1.serialization.SerializationMap.register(GRUCell); +var GRU = (function (_super) { + __extends(GRU, _super); + function GRU(config) { + var _this = this; + if (config.implementation === 0) { + console.warn('`implementation=0` has been deprecated, and now defaults to ' + + '`implementation=1`. Please update your layer call.'); + } + config.cell = new GRUCell(config); + _this = _super.call(this, config) || this; + return _this; + } + GRU.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(GRU.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentActivation", { + get: function () { + return this.cell.recurrentActivation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "implementation", { + get: function () { + return this.cell.implementation; + }, + enumerable: true, + configurable: true + }); + GRU.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + recurrentActivation: activations_1.serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + GRU.fromConfig = function (cls, config) { + if (config['implmentation'] === 0) { + config['implementation'] = 1; + } + return new cls(config); + }; + GRU.className = 'GRU'; + return GRU; +}(RNN)); +exports.GRU = GRU; +tfjs_core_1.serialization.SerializationMap.register(GRU); +var LSTMCell = (function (_super) { + __extends(LSTMCell, _super); + function LSTMCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = activations_1.getActivation(config.activation === undefined ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.recurrentActivation = activations_1.getActivation(config.recurrentActivation === undefined ? + _this.DEFAULT_RECURRENT_ACTIVATION : + config.recurrentActivation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = initializers_1.getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = initializers_1.getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + initializers_1.getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.unitForgetBias = config.unitForgetBias; + _this.kernelRegularizer = regularizers_1.getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = regularizers_1.getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = regularizers_1.getRegularizer(config.biasRegularizer); + _this.kernelConstraint = constraints_1.getConstraint(config.kernelConstraint); + _this.recurrentConstraint = constraints_1.getConstraint(config.recurrentConstraint); + _this.biasConstraint = constraints_1.getConstraint(config.biasConstraint); + _this.dropout = math_utils.min([1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = math_utils.min([ + 1, + math_utils.max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.implementation = config.implementation; + _this.stateSize = [_this.units, _this.units]; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + LSTMCell.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var inputDim = inputShape[inputShape.length - 1]; + this.kernel = this.addWeight('kernel', [inputDim, this.units * 4], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units * 4], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + var biasInitializer; + if (this.useBias) { + if (this.unitForgetBias) { + var capturedBiasInit_1 = this.biasInitializer; + var capturedUnits_1 = this.units; + biasInitializer = new (_a = (function (_super) { + __extends(CustomInit, _super); + function CustomInit() { + return _super !== null && _super.apply(this, arguments) || this; + } + CustomInit.prototype.apply = function (shape, dtype) { + var bI = capturedBiasInit_1.apply([capturedUnits_1]); + var bF = (new initializers_1.Ones()).apply([capturedUnits_1]); + var bCAndH = capturedBiasInit_1.apply([capturedUnits_1 * 2]); + return K.concatAlongFirstAxis(K.concatAlongFirstAxis(bI, bF), bCAndH); + }; + return CustomInit; + }(initializers_1.Initializer)), + _a.className = 'CustomInit', + _a)(); + } + else { + biasInitializer = this.biasInitializer; + } + this.bias = this.addWeight('bias', [this.units * 4], null, biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + var _a; + }; + LSTMCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + var training = kwargs['training'] == null ? false : kwargs['training']; + inputs = inputs; + if (inputs.length !== 3) { + throw new errors_1.ValueError("LSTMCell expects 3 input Tensors (inputs, h, c), got " + + (inputs.length + ".")); + } + var hTMinus1 = inputs[1]; + var cTMinus1 = inputs[2]; + inputs = inputs[0]; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training, 4); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(hTMinus1); }, _this.recurrentDropout, training, 4); + } + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + var i; + var f; + var c; + var o; + if (_this.implementation === 1) { + var kernelI = K.sliceAlongLastAxis(_this.kernel.read(), 0, _this.units); + var kernelF = K.sliceAlongLastAxis(_this.kernel.read(), _this.units, _this.units); + var kernelC = K.sliceAlongLastAxis(_this.kernel.read(), _this.units * 2, _this.units); + var kernelO = K.sliceAlongLastAxis(_this.kernel.read(), _this.units * 3, _this.units); + var recurrentKernelI = K.sliceAlongLastAxis(_this.recurrentKernel.read(), 0, _this.units); + var recurrentKernelF = K.sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units, _this.units); + var recurrentKernelC = K.sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 2, _this.units); + var recurrentKernelO = K.sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 3, _this.units); + var inputsI = void 0, inputsF = void 0, inputsC = void 0, inputsO = void 0; + if (0 < _this.dropout && _this.dropout < 1) { + inputsI = tfc.mul(inputs, dpMask[0]); + inputsF = tfc.mul(inputs, dpMask[1]); + inputsC = tfc.mul(inputs, dpMask[2]); + inputsO = tfc.mul(inputs, dpMask[3]); + } + else { + inputsI = inputs; + inputsF = inputs; + inputsC = inputs; + inputsO = inputs; + } + var xI = K.dot(inputsI, kernelI); + var xF = K.dot(inputsF, kernelF); + var xC = K.dot(inputsC, kernelC); + var xO = K.dot(inputsO, kernelO); + if (_this.useBias) { + var biasI = K.sliceAlongFirstAxis(_this.bias.read(), 0, _this.units); + var biasF = K.sliceAlongFirstAxis(_this.bias.read(), _this.units, _this.units); + var biasC = K.sliceAlongFirstAxis(_this.bias.read(), _this.units * 2, _this.units); + var biasO = K.sliceAlongFirstAxis(_this.bias.read(), _this.units * 3, _this.units); + xI = K.biasAdd(xI, biasI); + xF = K.biasAdd(xF, biasF); + xC = K.biasAdd(xC, biasC); + xO = K.biasAdd(xO, biasO); + } + var hTMinus1I = void 0, hTMinus1F = void 0, hTMinus1C = void 0, hTMinus1O = void 0; + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1I = tfc.mul(hTMinus1, recDpMask[0]); + hTMinus1F = tfc.mul(hTMinus1, recDpMask[1]); + hTMinus1C = tfc.mul(hTMinus1, recDpMask[2]); + hTMinus1O = tfc.mul(hTMinus1, recDpMask[3]); + } + else { + hTMinus1I = hTMinus1; + hTMinus1F = hTMinus1; + hTMinus1C = hTMinus1; + hTMinus1O = hTMinus1; + } + i = _this.recurrentActivation.apply(tfc.add(xI, K.dot(hTMinus1I, recurrentKernelI))); + f = _this.recurrentActivation.apply(tfc.add(xF, K.dot(hTMinus1F, recurrentKernelF))); + c = tfc.add(tfc.mul(f, cTMinus1), tfc.mul(i, _this.activation.apply(tfc.add(xC, K.dot(hTMinus1C, recurrentKernelC))))); + o = _this.recurrentActivation.apply(tfc.add(xO, K.dot(hTMinus1O, recurrentKernelO))); + } + else { + if (0 < _this.dropout && _this.dropout < 1) { + inputs = tfc.mul(inputs, dpMask[0]); + } + var z = K.dot(inputs, _this.kernel.read()); + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]); + } + z = tfc.add(z, K.dot(hTMinus1, _this.recurrentKernel.read())); + if (_this.useBias) { + z = K.biasAdd(z, _this.bias.read()); + } + var z0 = K.sliceAlongLastAxis(z, 0, _this.units); + var z1 = K.sliceAlongLastAxis(z, _this.units, _this.units); + var z2 = K.sliceAlongLastAxis(z, _this.units * 2, _this.units); + var z3 = K.sliceAlongLastAxis(z, _this.units * 3, _this.units); + i = _this.recurrentActivation.apply(z0); + f = _this.recurrentActivation.apply(z1); + c = tfc.add(tfc.mul(f, cTMinus1), tfc.mul(i, _this.activation.apply(z2))); + o = _this.recurrentActivation.apply(z3); + } + var h = tfc.mul(o, _this.activation.apply(c)); + return [h, h, c]; + }); + }; + LSTMCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + recurrentActivation: activations_1.serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + unitForgetBias: this.unitForgetBias, + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + LSTMCell.className = 'LSTMCell'; + return LSTMCell; +}(RNNCell)); +exports.LSTMCell = LSTMCell; +tfjs_core_1.serialization.SerializationMap.register(LSTMCell); +var LSTM = (function (_super) { + __extends(LSTM, _super); + function LSTM(config) { + var _this = this; + if (config.implementation === 0) { + console.warn('`implementation=0` has been deprecated, and now defaults to ' + + '`implementation=1`. Please update your layer call.'); + } + config.cell = new LSTMCell(config); + _this = _super.call(this, config) || this; + return _this; + } + LSTM.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(LSTM.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentActivation", { + get: function () { + return this.cell.recurrentActivation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "unitForgetBias", { + get: function () { + return this.cell.unitForgetBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "implementation", { + get: function () { + return this.cell.implementation; + }, + enumerable: true, + configurable: true + }); + LSTM.prototype.getConfig = function () { + var config = { + units: this.units, + activation: activations_1.serializeActivation(this.activation), + recurrentActivation: activations_1.serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: initializers_1.serializeInitializer(this.kernelInitializer), + recurrentInitializer: initializers_1.serializeInitializer(this.recurrentInitializer), + biasInitializer: initializers_1.serializeInitializer(this.biasInitializer), + unitForgetBias: this.unitForgetBias, + kernelRegularizer: regularizers_1.serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: regularizers_1.serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: regularizers_1.serializeRegularizer(this.biasRegularizer), + activityRegularizer: regularizers_1.serializeRegularizer(this.activityRegularizer), + kernelConstraint: constraints_1.serializeConstraint(this.kernelConstraint), + recurrentConstraint: constraints_1.serializeConstraint(this.recurrentConstraint), + biasConstraint: constraints_1.serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + LSTM.fromConfig = function (cls, config) { + if (config['implmentation'] === 0) { + config['implementation'] = 1; + } + return new cls(config); + }; + LSTM.className = 'LSTM'; + return LSTM; +}(RNN)); +exports.LSTM = LSTM; +tfjs_core_1.serialization.SerializationMap.register(LSTM); +var StackedRNNCells = (function (_super) { + __extends(StackedRNNCells, _super); + function StackedRNNCells(config) { + var _this = _super.call(this, config) || this; + _this.cells = config.cells; + return _this; + } + Object.defineProperty(StackedRNNCells.prototype, "stateSize", { + get: function () { + var stateSize = []; + for (var _i = 0, _a = this.cells.slice().reverse(); _i < _a.length; _i++) { + var cell = _a[_i]; + if (Array.isArray(cell.stateSize)) { + stateSize.push.apply(stateSize, cell.stateSize); + } + else { + stateSize.push(cell.stateSize); + } + } + return stateSize; + }, + enumerable: true, + configurable: true + }); + StackedRNNCells.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = inputs; + var states = inputs.slice(1); + var nestedStates = []; + for (var _i = 0, _a = _this.cells.slice().reverse(); _i < _a.length; _i++) { + var cell = _a[_i]; + if (Array.isArray(cell.stateSize)) { + nestedStates.push(states.splice(0, cell.stateSize.length)); + } + else { + nestedStates.push(states.splice(0, 1)); + } + } + nestedStates.reverse(); + var newNestedStates = []; + var callInputs; + for (var i = 0; i < _this.cells.length; ++i) { + var cell = _this.cells[i]; + states = nestedStates[i]; + if (i === 0) { + callInputs = [inputs[0]].concat(states); + } + else { + callInputs = [callInputs[0]].concat(states); + } + callInputs = cell.call(callInputs, kwargs); + newNestedStates.push(callInputs.slice(1)); + } + states = []; + for (var _b = 0, _c = newNestedStates.slice().reverse(); _b < _c.length; _b++) { + var cellStates = _c[_b]; + states.push.apply(states, cellStates); + } + return [callInputs[0]].concat(states); + }); + }; + StackedRNNCells.prototype.build = function (inputShape) { + if (types_utils_1.isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var outputDim; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + cell.build(inputShape); + if (Array.isArray(cell.stateSize)) { + outputDim = cell.stateSize[0]; + } + else { + outputDim = cell.stateSize; + } + inputShape = [inputShape[0], outputDim]; + } + this.built = true; + }; + StackedRNNCells.prototype.getConfig = function () { + var cellConfigs = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + cellConfigs.push({ + 'className': this.getClassName(), + 'config': cell.getConfig(), + }); + } + var config = { 'cells': cellConfigs }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + StackedRNNCells.fromConfig = function (cls, config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + var cells = []; + for (var _i = 0, _a = config['cells']; _i < _a.length; _i++) { + var cellConfig = _a[_i]; + cells.push(serialization_1.deserialize(cellConfig, customObjects)); + } + return new cls({ cells: cells }); + }; + Object.defineProperty(StackedRNNCells.prototype, "trainableWeights", { + get: function () { + if (!this.trainable) { + return []; + } + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.trainableWeights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(StackedRNNCells.prototype, "nonTrainableWeights", { + get: function () { + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.nonTrainableWeights); + } + if (!this.trainable) { + var trainableWeights = []; + for (var _b = 0, _c = this.cells; _b < _c.length; _b++) { + var cell = _c[_b]; + trainableWeights.push.apply(trainableWeights, cell.trainableWeights); + } + return trainableWeights.concat(weights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + StackedRNNCells.prototype.getWeights = function () { + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.weights); + } + return variables_1.batchGetValue(weights); + }; + StackedRNNCells.prototype.setWeights = function (weights) { + var tuples = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + var numParams = cell.weights.length; + var inputWeights = weights.splice(numParams); + for (var i = 0; i < cell.weights.length; ++i) { + tuples.push([cell.weights[i], inputWeights[i]]); + } + } + variables_1.batchSetValue(tuples); + }; + StackedRNNCells.className = 'StackedRNNCells'; + return StackedRNNCells; +}(RNNCell)); +exports.StackedRNNCells = StackedRNNCells; +tfjs_core_1.serialization.SerializationMap.register(StackedRNNCells); +function generateDropoutMask(ones, rate, training, count) { + if (training === void 0) { training = null; } + if (count === void 0) { count = 1; } + function droppedInputs() { + return K.dropout(ones(), state_1.getScalar(rate)); + } + if (count > 1) { + var mask = []; + for (var i = 0; i < count; i++) { + mask.push(K.inTrainPhase(droppedInputs, ones, training)); + } + mask.forEach(function (m) { return tfc.keep(m); }); + return mask; + } + else { + return tfc.keep(K.inTrainPhase(droppedInputs, ones, training)); + } +} +//# sourceMappingURL=recurrent.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js.map new file mode 100644 index 0000000..d8cb70b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent.js.map @@ -0,0 +1 @@ +{"version":3,"file":"recurrent.js","sourceRoot":"","sources":["../../src/layers/recurrent.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent_test.js.map new file mode 100644 index 0000000..2784ae7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/recurrent_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"recurrent_test.js","sourceRoot":"","sources":["../../src/layers/recurrent_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.d.ts new file mode 100644 index 0000000..377f7e4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.d.ts @@ -0,0 +1,2 @@ +import { serialization } from '@tensorflow/tfjs-core'; +export declare function deserialize(config: serialization.ConfigDict, customObjects?: serialization.ConfigDict): serialization.Serializable; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js new file mode 100644 index 0000000..4d9fa00 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js @@ -0,0 +1,10 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var generic_utils_1 = require("../utils/generic_utils"); +function deserialize(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return generic_utils_1.deserializeKerasObject(config, tfjs_core_1.serialization.SerializationMap.getMap().classNameMap, customObjects, 'layer'); +} +exports.deserialize = deserialize; +//# sourceMappingURL=serialization.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js.map new file mode 100644 index 0000000..68c2410 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization.js.map @@ -0,0 +1 @@ +{"version":3,"file":"serialization.js","sourceRoot":"","sources":["../../src/layers/serialization.ts"],"names":[],"mappings":";;AAWA,mDAAoD;AAEpD,wDAA8D;AAS9D,qBACI,MAAgC,EAChC,aAC4B;IAD5B,8BAAA,EAAA,gBAAgB,EACY;IAC9B,OAAO,sCAAsB,CACzB,MAAM,EAAE,yBAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,YAAY,EAC5D,aAAa,EAAE,OAAO,CAAC,CAAC;AAC9B,CAAC;AAPD,kCAOC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization_test.js.map new file mode 100644 index 0000000..22d4a51 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/serialization_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"serialization_test.js","sourceRoot":"","sources":["../../src/layers/serialization_test.ts"],"names":[],"mappings":";;AAYA,gDAAyD;AACzD,iDAA4C;AAE5C,QAAQ,CAAC,iBAAiB,EAAE;IAC1B,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,MAAM,GAA6B,EAAC,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAC,CAAC;QAC1E,IAAM,WAAW,GAAU,2BAAW,CAAC,MAAM,CAAgB,CAAC;QAC9D,MAAM,CAAC,WAAW,YAAY,CAAC,oBAAK,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,iBAAiB,EAAE;QACpB,IAAM,MAAM,GAA6B,EAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAC,CAAC;QACzE,IAAM,WAAW,GAAS,2BAAW,CAAC,MAAM,CAAgB,CAAC;QAC7D,MAAM,CAAC,WAAW,YAAY,CAAC,mBAAI,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.d.ts new file mode 100644 index 0000000..8145c2f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.d.ts @@ -0,0 +1,61 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { serialization, Tensor } from '@tensorflow/tfjs-core'; +import { Layer, LayerConfig, SymbolicTensor } from '../engine/topology'; +import { Kwargs, Shape } from '../types'; +import { RegularizerFn } from '../types'; +import { LayerVariable } from '../variables'; +import { RNN } from './recurrent'; +export interface WrapperLayerConfig extends LayerConfig { + layer: Layer; +} +export declare abstract class Wrapper extends Layer { + readonly layer: Layer; + constructor(config: WrapperLayerConfig); + build(inputShape: Shape | Shape[]): void; + trainable: boolean; + readonly trainableWeights: LayerVariable[]; + readonly nonTrainableWeights: LayerVariable[]; + readonly updates: Tensor[]; + readonly losses: RegularizerFn[]; + getWeights(): Tensor[]; + setWeights(weights: Tensor[]): void; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict, customObjects?: tfc.serialization.ConfigDict): T; +} +export declare class TimeDistributed extends Wrapper { + static className: string; + constructor(config: WrapperLayerConfig); + build(inputShape: Shape | Shape[]): void; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; +} +export declare type BidirectionalMergeMode = 'sum' | 'mul' | 'concat' | 'ave'; +export declare const VALID_BIDIRECTIONAL_MERGE_MODES: string[]; +export declare function checkBidirectionalMergeMode(value?: string): void; +export interface BidirectionalLayerConfig extends WrapperLayerConfig { + layer: RNN; + mergeMode?: BidirectionalMergeMode; +} +export declare class Bidirectional extends Wrapper { + static className: string; + private forwardLayer; + private backwardLayer; + private mergeMode; + private returnSequences; + private returnState; + private numConstants?; + private _trainable; + constructor(config: BidirectionalLayerConfig); + trainable: boolean; + getWeights(): Tensor[]; + setWeights(weights: Tensor[]): void; + computeOutputShape(inputShape: Shape | Shape[]): Shape | Shape[]; + apply(inputs: Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[], kwargs?: Kwargs): Tensor | Tensor[] | SymbolicTensor | SymbolicTensor[]; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + resetStates(states?: Tensor | Tensor[]): void; + build(inputShape: Shape | Shape[]): void; + readonly trainableWeights: LayerVariable[]; + readonly nonTrainableWeights: LayerVariable[]; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js new file mode 100644 index 0000000..f6c2db1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js @@ -0,0 +1,416 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("../backend/state"); +var K = require("../backend/tfjs_backend"); +var common_1 = require("../common"); +var topology_1 = require("../engine/topology"); +var errors_1 = require("../errors"); +var generic_utils = require("../utils/generic_utils"); +var types_utils_1 = require("../utils/types_utils"); +var recurrent_1 = require("./recurrent"); +var serialization_1 = require("./serialization"); +var Wrapper = (function (_super) { + __extends(Wrapper, _super); + function Wrapper(config) { + var _this = _super.call(this, config) || this; + _this.layer = config.layer; + return _this; + } + Wrapper.prototype.build = function (inputShape) { + this.built = true; + }; + Object.defineProperty(Wrapper.prototype, "trainable", { + get: function () { + if (this.layer != null) { + return this.layer.trainable; + } + else { + return false; + } + }, + set: function (value) { + if (this.layer != null) { + this.layer.trainable = value; + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "trainableWeights", { + get: function () { + return this.layer.trainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "nonTrainableWeights", { + get: function () { + return this.layer.nonTrainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "updates", { + get: function () { + return this.layer._updates; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "losses", { + get: function () { + return this.layer.losses; + }, + enumerable: true, + configurable: true + }); + Wrapper.prototype.getWeights = function () { + return this.layer.getWeights(); + }; + Wrapper.prototype.setWeights = function (weights) { + this.layer.setWeights(weights); + }; + Wrapper.prototype.getConfig = function () { + var config = { + 'layer': { + 'className': this.layer.getClassName(), + 'config': this.layer.getConfig(), + } + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Wrapper.fromConfig = function (cls, config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + var layerConfig = config['layer']; + var layer = serialization_1.deserialize(layerConfig, customObjects); + delete config['layer']; + var newConfig = { layer: layer }; + Object.assign(newConfig, config); + return new cls(newConfig); + }; + return Wrapper; +}(topology_1.Layer)); +exports.Wrapper = Wrapper; +var TimeDistributed = (function (_super) { + __extends(TimeDistributed, _super); + function TimeDistributed(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + return _this; + } + TimeDistributed.prototype.build = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + if (inputShape.length < 3) { + throw new errors_1.ValueError("TimeDistributed layer expects an input shape >= 3D, but received " + + ("input shape " + JSON.stringify(inputShape))); + } + this.inputSpec = [{ shape: inputShape }]; + var childInputShape = [inputShape[0]].concat(inputShape.slice(2)); + if (!this.layer.built) { + this.layer.build(childInputShape); + this.layer.built = true; + } + _super.prototype.build.call(this, inputShape); + }; + TimeDistributed.prototype.computeOutputShape = function (inputShape) { + inputShape = types_utils_1.getExactlyOneShape(inputShape); + var childInputShape = [inputShape[0]].concat(inputShape.slice(2)); + var childOutputShape = this.layer.computeOutputShape(childInputShape); + var timesteps = inputShape[1]; + return [childOutputShape[0], timesteps].concat(childOutputShape.slice(1)); + }; + TimeDistributed.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + inputs = types_utils_1.getExactlyOneTensor(inputs); + var step = function (inputs, states) { + var output = _this.layer.call(inputs, kwargs); + return [output, []]; + }; + var rnnOutputs = recurrent_1.rnn(step, inputs, [], false, null, null, false, inputs.shape[1]); + var y = rnnOutputs[1]; + return y; + }); + }; + TimeDistributed.className = 'TimeDistributed'; + return TimeDistributed; +}(Wrapper)); +exports.TimeDistributed = TimeDistributed; +tfjs_core_1.serialization.SerializationMap.register(TimeDistributed); +exports.VALID_BIDIRECTIONAL_MERGE_MODES = ['sum', 'mul', 'concat', 'ave']; +function checkBidirectionalMergeMode(value) { + generic_utils.checkStringTypeUnionValue(exports.VALID_BIDIRECTIONAL_MERGE_MODES, 'BidirectionalMergeMode', value); +} +exports.checkBidirectionalMergeMode = checkBidirectionalMergeMode; +var Bidirectional = (function (_super) { + __extends(Bidirectional, _super); + function Bidirectional(config) { + var _this = _super.call(this, config) || this; + var layerConfig = config.layer.getConfig(); + _this.forwardLayer = + serialization_1.deserialize({ className: config.layer.getClassName(), config: layerConfig }); + layerConfig['goBackwards'] = + layerConfig['goBackwards'] === true ? false : true; + _this.backwardLayer = + serialization_1.deserialize({ className: config.layer.getClassName(), config: layerConfig }); + _this.forwardLayer.name = 'forward_' + _this.forwardLayer.name; + _this.backwardLayer.name = 'backward_' + _this.backwardLayer.name; + checkBidirectionalMergeMode(config.mergeMode); + _this.mergeMode = config.mergeMode; + if (config.weights) { + throw new errors_1.NotImplementedError('weights support is not implemented for Bidirectional layer yet.'); + } + _this._stateful = config.layer.stateful; + _this.returnSequences = config.layer.returnSequences; + _this.returnState = config.layer.returnState; + _this.supportsMasking = true; + _this._trainable = true; + _this.inputSpec = config.layer.inputSpec; + _this.numConstants = null; + return _this; + } + Object.defineProperty(Bidirectional.prototype, "trainable", { + get: function () { + return this._trainable; + }, + set: function (value) { + this._trainable = value; + if (this.forwardLayer != null) { + this.forwardLayer.trainable = value; + } + if (this.backwardLayer != null) { + this.backwardLayer.trainable = value; + } + }, + enumerable: true, + configurable: true + }); + Bidirectional.prototype.getWeights = function () { + return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights()); + }; + Bidirectional.prototype.setWeights = function (weights) { + var numWeights = weights.length; + var numeightsOver2 = Math.floor(numWeights / 2); + this.forwardLayer.setWeights(weights.slice(0, numeightsOver2)); + this.backwardLayer.setWeights(weights.slice(numeightsOver2)); + }; + Bidirectional.prototype.computeOutputShape = function (inputShape) { + var layerShapes = this.forwardLayer.computeOutputShape(inputShape); + if (!(Array.isArray(layerShapes) && Array.isArray(layerShapes[0]))) { + layerShapes = [layerShapes]; + } + layerShapes = layerShapes; + var outputShape; + var outputShapes; + var stateShape; + if (this.returnState) { + stateShape = layerShapes.slice(1); + outputShape = layerShapes[0]; + } + else { + outputShape = layerShapes[0]; + } + outputShape = outputShape; + if (this.mergeMode === 'concat') { + outputShape[outputShape.length - 1] *= 2; + outputShapes = [outputShape]; + } + else if (this.mergeMode == null) { + outputShapes = [outputShape, outputShape.slice()]; + } + else { + outputShapes = [outputShape]; + } + if (this.returnState) { + if (this.mergeMode == null) { + return outputShapes.concat(stateShape).concat(stateShape.slice()); + } + return [outputShape].concat(stateShape).concat(stateShape.slice()); + } + return generic_utils.singletonOrArray(outputShapes); + }; + Bidirectional.prototype.apply = function (inputs, kwargs) { + var initialState = kwargs == null ? null : kwargs['initialState']; + var constants = kwargs == null ? null : kwargs['constants']; + if (kwargs == null) { + kwargs = {}; + } + var standardized = recurrent_1.standardizeArgs(inputs, initialState, constants, this.numConstants); + inputs = standardized.inputs; + initialState = standardized.initialState; + constants = standardized.constants; + if (Array.isArray(inputs)) { + initialState = inputs.slice(1); + inputs = inputs[0]; + } + if ((initialState == null || initialState.length === 0) && + constants == null) { + return _super.prototype.apply.call(this, inputs, kwargs); + } + var additionalInputs = []; + var additionalSpecs = []; + if (initialState != null) { + var numStates = initialState.length; + if (numStates % 2 > 0) { + throw new errors_1.ValueError('When passing `initialState` to a Bidrectional RNN, ' + + 'the state should be an Array containing the states of ' + + 'the underlying RNNs.'); + } + kwargs['initialState'] = initialState; + additionalInputs.push.apply(additionalInputs, initialState); + var stateSpecs = initialState + .map(function (state) { return new topology_1.InputSpec({ shape: state.shape }); }); + this.forwardLayer.stateSpec = stateSpecs.slice(0, numStates / 2); + this.backwardLayer.stateSpec = stateSpecs.slice(numStates / 2); + additionalSpecs.push.apply(additionalSpecs, stateSpecs); + } + if (constants != null) { + throw new errors_1.NotImplementedError('Support for constants in Bidirectional layers is not ' + + 'implemented yet.'); + } + var isSymbolicTensor = additionalInputs[0] instanceof topology_1.SymbolicTensor; + for (var _i = 0, additionalInputs_1 = additionalInputs; _i < additionalInputs_1.length; _i++) { + var tensor = additionalInputs_1[_i]; + if (tensor instanceof topology_1.SymbolicTensor !== isSymbolicTensor) { + throw new errors_1.ValueError('The initial state of a Bidirectional layer cannot be ' + + 'specified as a mix of symbolic and non-symbolic tensors'); + } + } + if (isSymbolicTensor) { + var fullInput = [inputs].concat(additionalInputs); + var fullInputSpec = this.inputSpec.concat(additionalSpecs); + var originalInputSpec = this.inputSpec; + this.inputSpec = fullInputSpec; + var output = _super.prototype.apply.call(this, fullInput, kwargs); + this.inputSpec = originalInputSpec; + return output; + } + else { + return _super.prototype.apply.call(this, inputs, kwargs); + } + }; + Bidirectional.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfjs_core_1.tidy(function () { + if (kwargs['mask'] != null) { + throw new errors_1.NotImplementedError('The support for masking is not implemented for ' + + 'Bidirectional layers yet.'); + } + var initialState = kwargs['initialState']; + var y; + var yRev; + if (initialState == null) { + y = _this.forwardLayer.call(inputs, kwargs); + yRev = _this.backwardLayer.call(inputs, kwargs); + } + else { + var forwardState = initialState.slice(0, initialState.length / 2); + var backwardState = initialState.slice(initialState.length / 2); + y = _this.forwardLayer.call(inputs, Object.assign(kwargs, { initialState: forwardState })); + yRev = _this.forwardLayer.call(inputs, Object.assign(kwargs, { initialState: backwardState })); + } + var states; + if (_this.returnState) { + if (Array.isArray(y)) { + states = y.slice(1).concat(yRev.slice(1)); + } + else { + } + y = y[0]; + yRev = yRev[0]; + } + if (_this.returnSequences) { + yRev = tfc.reverse(yRev, 1); + } + var output; + if (_this.mergeMode === 'concat') { + output = K.concatenate([y, yRev]); + } + else if (_this.mergeMode === 'sum') { + output = tfc.add(y, yRev); + } + else if (_this.mergeMode === 'ave') { + output = tfc.mul(state_1.getScalar(0.5), tfc.add(y, yRev)); + } + else if (_this.mergeMode === 'mul') { + output = tfc.mul(y, yRev); + } + else if (_this.mergeMode == null) { + output = [y, yRev]; + } + if (_this.returnState) { + if (_this.mergeMode == null) { + return output.concat(states); + } + return [output].concat(states); + } + return output; + }); + }; + Bidirectional.prototype.resetStates = function (states) { + this.forwardLayer.resetStates(); + this.backwardLayer.resetStates(); + }; + Bidirectional.prototype.build = function (inputShape) { + var _this = this; + common_1.nameScope(this.forwardLayer.name, function () { + _this.forwardLayer.build(inputShape); + }); + common_1.nameScope(this.backwardLayer.name, function () { + _this.backwardLayer.build(inputShape); + }); + this.built = true; + }; + Object.defineProperty(Bidirectional.prototype, "trainableWeights", { + get: function () { + return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Bidirectional.prototype, "nonTrainableWeights", { + get: function () { + return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Bidirectional.prototype.getConfig = function () { + var config = { + 'mergeMode': this.mergeMode, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Bidirectional.fromConfig = function (cls, config) { + var rnnLayer = serialization_1.deserialize(config['layer']); + delete config['layer']; + if (config['numConstants'] != null) { + throw new errors_1.NotImplementedError("Deserialization of a Bidirectional layer with numConstants " + + "present is not supported yet."); + } + var newConfig = config; + newConfig['layer'] = rnnLayer; + return new cls(newConfig); + }; + Bidirectional.className = 'Bidirectional'; + return Bidirectional; +}(Wrapper)); +exports.Bidirectional = Bidirectional; +tfjs_core_1.serialization.SerializationMap.register(Bidirectional); +//# sourceMappingURL=wrappers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js.map new file mode 100644 index 0000000..8996dd0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"wrappers.js","sourceRoot":"","sources":["../../src/layers/wrappers.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers_test.js.map new file mode 100644 index 0000000..00e7af2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/layers/wrappers_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"wrappers_test.js","sourceRoot":"","sources":["../../src/layers/wrappers_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/logs.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/logs.d.ts new file mode 100644 index 0000000..c997c55 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/logs.d.ts @@ -0,0 +1,9 @@ +import { Scalar } from '@tensorflow/tfjs-core'; +export declare type UnresolvedLogs = { + [key: string]: number | Scalar; +}; +export declare function resolveScalarsInLogs(logs: UnresolvedLogs): Promise; +export declare function disposeTensorsInLogs(logs: UnresolvedLogs): void; +export declare type Logs = { + [key: string]: number; +}; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/logs.js b/node_modules/@tensorflow/tfjs-layers/dist/logs.js new file mode 100644 index 0000000..6954c11 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/logs.js @@ -0,0 +1,85 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +function resolveScalarsInLogs(logs) { + return __awaiter(this, void 0, void 0, function () { + var promises, keys, scalarsToDispose, key, value, valueScalar, values, i; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (logs == null) { + return [2]; + } + promises = []; + keys = []; + scalarsToDispose = []; + for (key in logs) { + value = logs[key]; + if (typeof value !== 'number') { + valueScalar = value; + promises.push(valueScalar.data()); + keys.push(key); + scalarsToDispose.push(valueScalar); + } + } + return [4, Promise.all(promises)]; + case 1: + values = _a.sent(); + for (i = 0; i < values.length; ++i) { + logs[keys[i]] = values[i][0]; + } + tfjs_core_1.dispose(scalarsToDispose); + return [2]; + } + }); + }); +} +exports.resolveScalarsInLogs = resolveScalarsInLogs; +function disposeTensorsInLogs(logs) { + if (logs == null) { + return; + } + for (var key in logs) { + var value = logs[key]; + if (typeof value !== 'number') { + value.dispose(); + } + } +} +exports.disposeTensorsInLogs = disposeTensorsInLogs; +//# sourceMappingURL=logs.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/logs.js.map b/node_modules/@tensorflow/tfjs-layers/dist/logs.js.map new file mode 100644 index 0000000..2773560 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/logs.js.map @@ -0,0 +1 @@ +{"version":3,"file":"logs.js","sourceRoot":"","sources":["../src/logs.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,mDAAsD;AAgBtD,8BAA2C,IAAoB;;;;;;oBAC7D,IAAI,IAAI,IAAI,IAAI,EAAE;wBAChB,WAAO;qBACR;oBACK,QAAQ,GAAuD,EAAE,CAAC;oBAClE,IAAI,GAAa,EAAE,CAAC;oBACpB,gBAAgB,GAAa,EAAE,CAAC;oBACtC,KAAW,GAAG,IAAI,IAAI,EAAE;wBAChB,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;wBACxB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;4BACvB,WAAW,GAAG,KAAe,CAAC;4BACpC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;4BAClC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;4BACf,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;yBACpC;qBACF;oBACc,WAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAA;;oBAApC,MAAM,GAAG,SAA2B;oBAC1C,KAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;wBACtC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC9B;oBAGD,mBAAO,CAAC,gBAAgB,CAAC,CAAC;;;;;CAC3B;AAvBD,oDAuBC;AAQD,8BAAqC,IAAoB;IACvD,IAAI,IAAI,IAAI,IAAI,EAAE;QAChB,OAAO;KACR;IACD,KAAK,IAAM,GAAG,IAAI,IAAI,EAAE;QACtB,IAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QACxB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,KAAK,CAAC,OAAO,EAAE,CAAC;SACjB;KACF;AACH,CAAC;AAVD,oDAUC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/losses.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/losses.d.ts new file mode 100644 index 0000000..10d7f45 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/losses.d.ts @@ -0,0 +1,30 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { LossOrMetricFn } from './types'; +export declare function l2Normalize(x: Tensor, axis?: number): Tensor; +export declare function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanAbsolutePercentageError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function meanSquaredLogarithmicError(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function squaredHinge(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function hinge(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function categoricalHinge(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function logcosh(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function categoricalCrossentropy(target: Tensor, output: Tensor, fromLogits?: boolean): Tensor; +export declare function sparseCategoricalCrossentropy(target: Tensor, output: Tensor, fromLogits?: boolean): Tensor; +export declare function sigmoidCrossEntropyWithLogits(target: Tensor, output: Tensor): Tensor; +export declare function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function kullbackLeiblerDivergence(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function poisson(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor; +export declare const mse: typeof meanSquaredError; +export declare const MSE: typeof meanSquaredError; +export declare const mae: typeof meanAbsoluteError; +export declare const MAE: typeof meanAbsoluteError; +export declare const mape: typeof meanAbsolutePercentageError; +export declare const MAPE: typeof meanAbsolutePercentageError; +export declare const msle: typeof meanSquaredLogarithmicError; +export declare const MSLE: typeof meanSquaredLogarithmicError; +export declare const kld: typeof kullbackLeiblerDivergence; +export declare const KLD: typeof kullbackLeiblerDivergence; +export declare const cosine: typeof cosineProximity; +export declare function get(identifierOrFn: string | LossOrMetricFn): LossOrMetricFn; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/losses.js b/node_modules/@tensorflow/tfjs-layers/dist/losses.js new file mode 100644 index 0000000..b9eae9a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/losses.js @@ -0,0 +1,191 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("./backend/common"); +var K = require("./backend/tfjs_backend"); +var state_1 = require("./backend/state"); +var errors_1 = require("./errors"); +function l2Normalize(x, axis) { + return tfjs_core_1.tidy(function () { + var squareSum = tfc.sum(K.square(x), axis, true); + var epsilonTensor = tfc.mul(tfjs_core_1.scalar(common_1.epsilon()), tfc.onesLike(x)); + var norm = tfc.sqrt(tfc.maximum(squareSum, epsilonTensor)); + return tfc.div(x, norm); + }); +} +exports.l2Normalize = l2Normalize; +function meanSquaredError(yTrue, yPred) { + return tfjs_core_1.tidy(function () { return tfc.mean(K.square(tfc.sub(yPred, yTrue)), -1); }); +} +exports.meanSquaredError = meanSquaredError; +function meanAbsoluteError(yTrue, yPred) { + return tfjs_core_1.tidy(function () { return tfc.mean(tfc.abs(tfc.sub(yPred, yTrue)), -1); }); +} +exports.meanAbsoluteError = meanAbsoluteError; +function meanAbsolutePercentageError(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var diff = tfc.sub(yTrue, yPred); + var clippedTrue = tfc.clipByValue(tfc.abs(yTrue), common_1.epsilon(), Number.MAX_VALUE); + var absResult = tfc.abs(tfc.div(diff, clippedTrue)); + return tfc.mul(state_1.getScalar(100.0), tfc.mean(absResult, -1)); + }); +} +exports.meanAbsolutePercentageError = meanAbsolutePercentageError; +function meanSquaredLogarithmicError(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var one = state_1.getScalar(1.0); + var clippedPred = tfc.clipByValue(yPred, common_1.epsilon(), Number.MAX_VALUE); + var firstLog = tfc.log(tfc.add(one, clippedPred)); + var clippedTrue = tfc.clipByValue(yTrue, common_1.epsilon(), Number.MAX_VALUE); + var secondLog = tfc.log(tfc.add(one, clippedTrue)); + return tfc.mean(K.square(tfc.sub(firstLog, secondLog)), -1); + }); +} +exports.meanSquaredLogarithmicError = meanSquaredLogarithmicError; +function squaredHinge(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var zeroTensor = state_1.getScalar(0.0); + var one = state_1.getScalar(1.0); + var maxResult = tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred))); + return tfc.mean(K.square(maxResult), -1); + }); +} +exports.squaredHinge = squaredHinge; +function hinge(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var zeroTensor = state_1.getScalar(0.0); + var one = state_1.getScalar(1.0); + var maxResult = tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred))); + return tfc.mean(maxResult, -1); + }); +} +exports.hinge = hinge; +function categoricalHinge(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var zeroTensor = state_1.getScalar(0.0); + var one = state_1.getScalar(1.0); + var pos = tfc.sum(tfc.mul(yTrue, yPred), -1); + var neg = tfc.max(tfc.mul(tfc.sub(one, yTrue), yPred), -1); + return tfc.maximum(zeroTensor, tfc.add(one, tfc.sub(neg, pos))); + }); +} +exports.categoricalHinge = categoricalHinge; +function logcosh(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var log2 = state_1.getScalar(Math.log(2.0)); + var predictionDiff = tfc.sub(yPred, yTrue); + var logcoshResult = tfc.sub(tfc.add(predictionDiff, tfc.softplus(tfc.mul(state_1.getScalar(-2.0), predictionDiff))), log2); + return tfc.mean(logcoshResult, -1); + }); +} +exports.logcosh = logcosh; +function categoricalCrossentropy(target, output, fromLogits) { + if (fromLogits === void 0) { fromLogits = false; } + return tfjs_core_1.tidy(function () { + if (fromLogits) { + output = tfc.softmax(output); + } + else { + var outputSum = tfc.sum(output, output.shape.length - 1, true); + output = tfc.div(output, outputSum); + } + output = tfc.clipByValue(output, common_1.epsilon(), 1 - common_1.epsilon()); + return tfc.neg(tfc.sum(tfc.mul(target.toFloat(), tfc.log(output)), output.shape.length - 1)); + }); +} +exports.categoricalCrossentropy = categoricalCrossentropy; +function sparseCategoricalCrossentropy(target, output, fromLogits) { + if (fromLogits === void 0) { fromLogits = false; } + return tfjs_core_1.tidy(function () { + var flatTarget = tfc.floor(K.flatten(target)).toInt(); + var outputShape = output.shape; + var oneHotTarget = tfc.oneHot(flatTarget, outputShape[outputShape.length - 1]) + .reshape(outputShape); + return categoricalCrossentropy(oneHotTarget, output, fromLogits); + }); +} +exports.sparseCategoricalCrossentropy = sparseCategoricalCrossentropy; +function sigmoidCrossEntropyWithLogits(target, output) { + return tfjs_core_1.tidy(function () { + var maxOutput = tfc.maximum(output, tfc.zerosLike(output)); + var outputXTarget = tfc.mul(output, target); + var sigmoidOutput = tfc.log(tfc.add(state_1.getScalar(1), tfc.exp(tfc.neg(tfc.abs(output))))); + var result = tfc.add(tfc.sub(maxOutput, outputXTarget), sigmoidOutput); + return result; + }); +} +exports.sigmoidCrossEntropyWithLogits = sigmoidCrossEntropyWithLogits; +function binaryCrossentropy(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var y; + y = tfc.clipByValue(yPred, common_1.epsilon(), 1 - common_1.epsilon()); + y = tfc.log(tfc.div(y, tfc.sub(tfc.onesLike(y), y))); + return tfc.mean(sigmoidCrossEntropyWithLogits(yTrue, y), -1); + }); +} +exports.binaryCrossentropy = binaryCrossentropy; +function kullbackLeiblerDivergence(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var clippedTrue = tfc.clipByValue(yTrue, common_1.epsilon(), 1); + var clippedPred = tfc.clipByValue(yPred, common_1.epsilon(), 1); + return tfc.sum(tfc.mul(yTrue, tfc.log(tfc.div(clippedTrue, clippedPred))), -1); + }); +} +exports.kullbackLeiblerDivergence = kullbackLeiblerDivergence; +function poisson(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var logPred = tfc.log(tfc.add(state_1.getScalar(common_1.epsilon()), yPred)); + return tfc.mean(tfc.sub(yPred, tfc.mul(yTrue, logPred)), -1); + }); +} +exports.poisson = poisson; +function cosineProximity(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var trueNormalized = l2Normalize(yTrue, -1); + var predNormalized = l2Normalize(yPred, -1); + var trueXPred = tfc.mul(trueNormalized, predNormalized); + return tfc.neg(tfc.sum(trueXPred, -1)); + }); +} +exports.cosineProximity = cosineProximity; +exports.mse = meanSquaredError; +exports.MSE = meanSquaredError; +exports.mae = meanAbsoluteError; +exports.MAE = meanAbsoluteError; +exports.mape = meanAbsolutePercentageError; +exports.MAPE = meanAbsolutePercentageError; +exports.msle = meanSquaredLogarithmicError; +exports.MSLE = meanSquaredLogarithmicError; +exports.kld = kullbackLeiblerDivergence; +exports.KLD = kullbackLeiblerDivergence; +exports.cosine = cosineProximity; +function get(identifierOrFn) { + var lossesMap = { + meanSquaredError: meanSquaredError, + meanAbsoluteError: meanAbsoluteError, + meanAbsolutePercentageError: meanAbsolutePercentageError, + meanSquaredLogarithmicError: meanSquaredLogarithmicError, + squaredHinge: squaredHinge, + hinge: hinge, + categoricalHinge: categoricalHinge, + logcosh: logcosh, + categoricalCrossentropy: categoricalCrossentropy, + sparseCategoricalCrossentropy: sparseCategoricalCrossentropy, + binaryCrossentropy: binaryCrossentropy, + kullbackLeiblerDivergence: kullbackLeiblerDivergence, + poisson: poisson, + cosineProximity: cosineProximity + }; + if (typeof identifierOrFn === 'string') { + if (identifierOrFn in lossesMap) { + return lossesMap[identifierOrFn]; + } + throw new errors_1.ValueError("Unknown loss " + identifierOrFn); + } + else { + return identifierOrFn; + } +} +exports.get = get; +//# sourceMappingURL=losses.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/losses.js.map b/node_modules/@tensorflow/tfjs-layers/dist/losses.js.map new file mode 100644 index 0000000..f83c16a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/losses.js.map @@ -0,0 +1 @@ +{"version":3,"file":"losses.js","sourceRoot":"","sources":["../src/losses.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/losses_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/losses_test.js.map new file mode 100644 index 0000000..310a87b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/losses_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"losses_test.js","sourceRoot":"","sources":["../src/losses_test.ts"],"names":[],"mappings":";;AAcA,2CAA6C;AAC7C,mDAAyE;AAEzE,2CAAyC;AACzC,iCAAmC;AACnC,iDAA6E;AAE7E,kCAAqB,CAAC,kBAAkB,EAAE;IACxC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,IAAM,WAAW,GAAG,kBAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACxD,IAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzE,IAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,mBAAmB,EAAE;IACzC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrC,IAAM,WAAW,GAAG,kBAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5C,IAAM,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACtD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzD,IAAM,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACtD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,6BAA6B,EAAE;IACnD,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrC,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAM,WAAW,GAAG,kBAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;QAC5D,IAAM,MAAM,GAAG,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAChE,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,WAAW,GACb,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;QACjE,IAAM,MAAM,GAAG,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAChE,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,6BAA6B,EAAE;IACnD,uCAAuC,CAAW,EAAE,CAAW;QAC7D,IAAM,OAAO,GAAG,UAAC,GAAW,IAAK,OAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,gBAAO,EAAE,CAAC,GAAG,CAAC,CAAC,EAAtC,CAAsC,CAAC;QACxE,IAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC5B,IAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC5B,IAAI,GAAG,GAAG,GAAG,CAAC;QACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjC,IAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YAC/B,GAAG,IAAI,IAAI,GAAG,IAAI,CAAC;SACpB;QACD,OAAO,GAAG,GAAG,CAAC,CAAC,MAAM,CAAC;IACxB,CAAC;IAED,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,WAAW,GAAG,oBAAQ,CAAC;YAC3B,6BAA6B,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC7C,6BAA6B,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC9C,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAChE,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,cAAc,EAAE;IACpC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEnD,IAAM,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,GAAG,CAAC,EAAL,CAAK,CAAC,CAAC;QAC/D,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACjD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,OAAO,EAAE;IAC7B,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEnD,IAAM,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC1C,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,kBAAkB,EAAE;IACxC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACvD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEvD,IAAM,YAAY,GAAG,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5C,IAAM,YAAY,GAAG,YAAY,GAAG,YAAY,GAAG,CAAC,CAAC;QACrD,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,SAAS,EAAE;IAC/B,kBAAkB,CAAS;QACzB,OAAO,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IACD,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAM,SAAS,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACvC,IAAM,QAAQ,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,IAAM,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACpD,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;QACpD,IAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC5C,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAGH,kCAAqB,CAAC,0BAA0B,EAAE;IAChD,EAAE,CAAC,aAAa,EAAE;QAChB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,QAAQ,GAAG,oBAAQ,CAAC;YACxB,CAAC,CAAC;gBACE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;oBAC1D,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;YAChE,CAAC,CAAC;gBACE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG;oBACzD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;SAChE,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,uBAAuB,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;QAC/D,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,QAAQ,GAAG,oBAAQ,CAAC;YACxB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;YAClD,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;SACjD,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,uBAAuB,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;QAChE,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,gCAAgC,EAAE;IACtD,EAAE,CAAC,aAAa,EAAE;QAChB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnD,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GAAG,oBAAQ,CAAC;YACxB,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACtE,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SACvE,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,6BAA6B,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;QACrE,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/D,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,QAAQ,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpE,IAAM,MAAM,GAAG,MAAM,CAAC,6BAA6B,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;QACtE,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,+BAA+B,EAAE;IACrD,EAAE,CAAC,+BAA+B,EAAE;QAClC,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,gBAAgB,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAC7D,IAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChC,IAAM,kBAAkB,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjE,IAAM,QAAQ,GAAG,GAAG,CAAC,GAAG,CACpB,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,EAC3C,GAAG,CAAC,GAAG,CAAC,gBAAgB,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,IAAM,MAAM,GAAG,MAAM,CAAC,6BAA6B,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAC/D,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAGH,kCAAqB,CAAC,yBAAyB,EAAE;IAC/C,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,KAAK,GAAG,KAAK,CAAC;QACpB,IAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,MAAM,GAAG,MAAM,CAAC,uBAAuB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC5D,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,+BAA+B,EAAE;IACrD,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,MAAM,GAAG,MAAM,CAAC,6BAA6B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAClE,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,oBAAoB,EAAE;IAC1C,6BAA6B,MAAc,EAAE,MAAc;QACzD,IAAM,gBAAgB,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAC7D,IAAM,gBAAgB,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAC7D,OAAO,GAAG,CAAC,IAAI,CACX,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CACX,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAChC,GAAG,CAAC,GAAG,CAAC,gBAAgB,EAAE,GAAG,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAC1D,CAAC,CAAC,CAAC,CAAC;IACV,CAAC;IAED,EAAE,CAAC,cAAc,EAAE;QACjB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,IAAM,MAAM,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAM,QAAQ,GAAG,mBAAmB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAChD,IAAM,MAAM,GAAG,MAAM,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACpD,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,2BAA2B,EAAE;IACjD,mBAAmB,MAAc,EAAE,SAAiB;QAClD,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAO,EAAE,CAAC,CAAC;QACrC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,gBAAO,EAAE,CAAC,CAAC;QAC3C,OAAO,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;IAC/C,CAAC;IAED,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,IAAM,WAAW,GAAG,oBAAQ,CAAC;YAC3B,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC;YACvC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC;SACtC,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,yBAAyB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9D,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,SAAS,EAAE;IAC/B,wBAAwB,MAAc,EAAE,SAAiB;QACvD,OAAO,SAAS,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,gBAAO,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,IAAM,WAAW,GAAG,oBAAQ,CAAC;YAC3B,CAAC,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC;YACvD,CAAC,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC;SACtD,CAAC,CAAC;QACH,IAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC5C,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,iBAAiB,EAAE;IACvC,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,KAAK,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,WAAW,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACpD,+BAAkB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAGH,QAAQ,CAAC,YAAY,EAAE;4BACV,QAAQ;QAOjB,EAAE,CAAC,aAAW,QAAU,EAAE;YACxB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAVD,KACY,UAKmB,EALnB,MAAC,kBAAkB,EAAE,mBAAmB;QACvC,6BAA6B,EAAE,6BAA6B;QAC5D,cAAc,EAAE,OAAO,EAAE,kBAAkB,EAAE,SAAS;QACtD,yBAAyB,EAAE,+BAA+B;QAC1D,oBAAoB,EAAE,2BAA2B,EAAE,SAAS;QAC5D,iBAAiB,CAAC,EALnB,cAKmB,EALnB,IAKmB;QAN1B,IAAM,QAAQ,SAAA;gBAAR,QAAQ;KAUlB;IAED,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,UAAU,GAAG,UAAC,CAAS,EAAE,CAAS,IAAK,OAAA,kBAAM,CAAC,IAAI,CAAC,EAAZ,CAAY,CAAC;QAC1D,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,kCAAqB,CAAC,aAAa,EAAE;IACnC,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QACtD,IAAM,QAAQ,GACV,oBAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACrC,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE;QAChC,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAC3C,IAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5C,IAAM,QAAQ,GAAG,oBAAQ,CACrB,CAAC,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,EAClE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACZ,IAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzC,+BAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE;QAC3B,IAAM,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACrC,+BAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/metrics.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/metrics.d.ts new file mode 100644 index 0000000..0c00736 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/metrics.d.ts @@ -0,0 +1,19 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { categoricalCrossentropy as categoricalCrossentropyLoss, cosineProximity, meanAbsoluteError, meanAbsolutePercentageError, meanSquaredError, sparseCategoricalCrossentropy as sparseCategoricalCrossentropyLoss } from './losses'; +import { LossOrMetricFn } from './types'; +export declare function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function sparseCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function topKCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare function sparseTopKCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor; +export declare const mse: typeof meanSquaredError; +export declare const MSE: typeof meanSquaredError; +export declare const mae: typeof meanAbsoluteError; +export declare const MAE: typeof meanAbsoluteError; +export declare const mape: typeof meanAbsolutePercentageError; +export declare const MAPE: typeof meanAbsolutePercentageError; +export declare const categoricalCrossentropy: typeof categoricalCrossentropyLoss; +export declare const cosine: typeof cosineProximity; +export declare const sparseCategoricalCrossentropy: typeof sparseCategoricalCrossentropyLoss; +export declare function get(identifier: string | LossOrMetricFn): LossOrMetricFn; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/metrics.js b/node_modules/@tensorflow/tfjs-layers/dist/metrics.js new file mode 100644 index 0000000..91e03f3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/metrics.js @@ -0,0 +1,72 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var K = require("./backend/tfjs_backend"); +var state_1 = require("./backend/state"); +var errors_1 = require("./errors"); +var losses_1 = require("./losses"); +var losses_2 = require("./losses"); +function binaryAccuracy(yTrue, yPred) { + return tfjs_core_1.tidy(function () { + var threshold = tfc.mul(state_1.getScalar(0.5), tfc.onesLike(yPred)); + var yPredThresholded = K.cast(tfc.greater(yPred, threshold), yTrue.dtype); + return tfc.mean(tfc.equal(yTrue, yPredThresholded), -1); + }); +} +exports.binaryAccuracy = binaryAccuracy; +function categoricalAccuracy(yTrue, yPred) { + return tfjs_core_1.tidy(function () { return K.cast(tfc.equal(tfc.argMax(yTrue, -1), tfc.argMax(yPred, -1)), 'float32'); }); +} +exports.categoricalAccuracy = categoricalAccuracy; +function binaryCrossentropy(yTrue, yPred) { + return losses_2.binaryCrossentropy(yTrue, yPred); +} +exports.binaryCrossentropy = binaryCrossentropy; +function sparseCategoricalAccuracy(yTrue, yPred) { + throw new errors_1.NotImplementedError(); +} +exports.sparseCategoricalAccuracy = sparseCategoricalAccuracy; +function topKCategoricalAccuracy(yTrue, yPred) { + throw new errors_1.NotImplementedError(); +} +exports.topKCategoricalAccuracy = topKCategoricalAccuracy; +function sparseTopKCategoricalAccuracy(yTrue, yPred) { + throw new errors_1.NotImplementedError(); +} +exports.sparseTopKCategoricalAccuracy = sparseTopKCategoricalAccuracy; +exports.mse = losses_1.meanSquaredError; +exports.MSE = losses_1.meanSquaredError; +exports.mae = losses_1.meanAbsoluteError; +exports.MAE = losses_1.meanAbsoluteError; +exports.mape = losses_1.meanAbsolutePercentageError; +exports.MAPE = losses_1.meanAbsolutePercentageError; +exports.categoricalCrossentropy = losses_1.categoricalCrossentropy; +exports.cosine = losses_1.cosineProximity; +exports.sparseCategoricalCrossentropy = losses_1.sparseCategoricalCrossentropy; +function get(identifier) { + var metricsMap = { + binaryAccuracy: binaryAccuracy, + categoricalAccuracy: categoricalAccuracy, + categoricalCrossentropy: exports.categoricalCrossentropy, + sparseCategoricalCrossentropy: exports.sparseCategoricalCrossentropy, + mse: exports.mse, + MSE: exports.MSE, + mae: exports.mae, + MAE: exports.MAE, + mape: exports.mape, + MAPE: exports.MAPE, + cosine: exports.cosine, + }; + if (typeof identifier === 'string' && identifier in metricsMap) { + return metricsMap[identifier]; + } + else if (typeof identifier !== 'string' && identifier != null) { + return identifier; + } + else { + throw new errors_1.ValueError("Unknown metric " + identifier); + } +} +exports.get = get; +//# sourceMappingURL=metrics.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/metrics.js.map b/node_modules/@tensorflow/tfjs-layers/dist/metrics.js.map new file mode 100644 index 0000000..f3c4d65 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/metrics.js.map @@ -0,0 +1 @@ +{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../src/metrics.ts"],"names":[],"mappings":";;AAeA,2CAA6C;AAC7C,mDAAmD;AAEnD,0CAA4C;AAC5C,yCAA0C;AAC1C,mCAAyD;AACzD,mCAAuO;AACvO,mCAAsE;AA+BtE,wBAA+B,KAAa,EAAE,KAAa;IACzD,OAAO,gBAAI,CAAC;QACV,IAAM,SAAS,GAAG,GAAG,CAAC,GAAG,CAAC,iBAAS,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/D,IAAM,gBAAgB,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAC5E,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC;AAND,wCAMC;AAkBD,6BAAoC,KAAa,EAAE,KAAa;IAC9D,OAAO,gBAAI,CACP,cAAM,OAAA,CAAC,CAAC,IAAI,CACR,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EADjE,CACiE,CAAC,CAAC;AAC/E,CAAC;AAJD,kDAIC;AAiBD,4BAAmC,KAAa,EAAE,KAAa;IAC7D,OAAO,2BAAsB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAFD,gDAEC;AAED,mCACI,KAAa,EAAE,KAAa;IAC9B,MAAM,IAAI,4BAAmB,EAAE,CAAC;AAClC,CAAC;AAHD,8DAGC;AAED,iCAAwC,KAAa,EAAE,KAAa;IAClE,MAAM,IAAI,4BAAmB,EAAE,CAAC;AAClC,CAAC;AAFD,0DAEC;AAED,uCACI,KAAa,EAAE,KAAa;IAC9B,MAAM,IAAI,4BAAmB,EAAE,CAAC;AAClC,CAAC;AAHD,sEAGC;AAGY,QAAA,GAAG,GAAG,yBAAgB,CAAC;AACvB,QAAA,GAAG,GAAG,yBAAgB,CAAC;AACvB,QAAA,GAAG,GAAG,0BAAiB,CAAC;AACxB,QAAA,GAAG,GAAG,0BAAiB,CAAC;AACxB,QAAA,IAAI,GAAG,oCAA2B,CAAC;AACnC,QAAA,IAAI,GAAG,oCAA2B,CAAC;AACnC,QAAA,uBAAuB,GAAG,gCAA2B,CAAC;AACtD,QAAA,MAAM,GAAG,wBAAe,CAAC;AACzB,QAAA,6BAA6B,GAAG,sCAAiC,CAAC;AAI/E,aAAoB,UAAiC;IACnD,IAAM,UAAU,GAA6C;QAC3D,cAAc,gBAAA;QACd,mBAAmB,qBAAA;QACnB,uBAAuB,iCAAA;QACvB,6BAA6B,uCAAA;QAC7B,GAAG,aAAA;QACH,GAAG,aAAA;QACH,GAAG,aAAA;QACH,GAAG,aAAA;QACH,IAAI,cAAA;QACJ,IAAI,cAAA;QACJ,MAAM,gBAAA;KACP,CAAC;IACF,IAAI,OAAO,UAAU,KAAK,QAAQ,IAAI,UAAU,IAAI,UAAU,EAAE;QAC9D,OAAO,UAAU,CAAC,UAAU,CAAC,CAAC;KAC/B;SAAM,IAAI,OAAO,UAAU,KAAK,QAAQ,IAAI,UAAU,IAAI,IAAI,EAAE;QAC/D,OAAO,UAAU,CAAC;KACnB;SAAM;QACL,MAAM,IAAI,mBAAU,CAAC,oBAAkB,UAAY,CAAC,CAAC;KACtD;AACH,CAAC;AArBD,kBAqBC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/metrics_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/metrics_test.js.map new file mode 100644 index 0000000..63ff7f3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/metrics_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"metrics_test.js","sourceRoot":"","sources":["../src/metrics_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/model_save_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/model_save_test.js.map new file mode 100644 index 0000000..cc070aa --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/model_save_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"model_save_test.js","sourceRoot":"","sources":["../src/model_save_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/model_summary_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/model_summary_test.js.map new file mode 100644 index 0000000..157222a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/model_summary_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"model_summary_test.js","sourceRoot":"","sources":["../src/model_summary_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/models.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/models.d.ts new file mode 100644 index 0000000..17b16bc --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/models.d.ts @@ -0,0 +1,47 @@ +import { io, Scalar, serialization, Tensor } from '@tensorflow/tfjs-core'; +import { History } from './base_callbacks'; +import { Layer } from './engine/topology'; +import { Model, ModelCompileConfig, ModelEvaluateConfig, ModelFitConfig } from './engine/training'; +import { Kwargs, Shape } from './types'; +import { JsonDict } from './types'; +export declare function modelFromJSON(modelAndWeightsConfig: ModelAndWeightsConfig, customObjects?: serialization.ConfigDict): Promise; +export interface ModelAndWeightsConfig { + modelTopology: JsonDict; + weightsManifest?: io.WeightsManifestConfig; + pathPrefix?: string; +} +export interface ModelPredictConfig { + batchSize?: number; + verbose?: boolean; +} +export declare function loadModelInternal(pathOrIOHandler: string | io.IOHandler): Promise; +export declare function loadModelFromIOHandler(handler: io.IOHandler, customObjects?: serialization.ConfigDict): Promise; +export interface SequentialConfig { + layers?: Layer[]; + name?: string; +} +export declare class Sequential extends Model { + static className: string; + private model; + private _updatable; + constructor(config?: SequentialConfig); + add(layer: Layer): void; + pop(): void; + call(inputs: Tensor | Tensor[], kwargs: Kwargs): Tensor | Tensor[]; + build(inputShape?: Shape | Shape[]): void; + countParams(): number; + summary(lineLength?: number, positions?: number[], printFn?: (message?: any, ...optionalParams: any[]) => void): void; + setWeights(weights: Tensor[]): void; + updatable: boolean; + evaluate(x: Tensor | Tensor[], y: Tensor | Tensor[], config?: ModelEvaluateConfig): Scalar | Scalar[]; + predict(x: Tensor | Tensor[], config?: ModelPredictConfig): Tensor | Tensor[]; + predictOnBatch(x: Tensor): Tensor | Tensor[]; + compile(config: ModelCompileConfig): void; + fit(x: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, y: Tensor | Tensor[] | { + [inputName: string]: Tensor; + }, config?: ModelFitConfig): Promise; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; + getConfig(): any; +} diff --git a/node_modules/@tensorflow/tfjs-layers/dist/models.js b/node_modules/@tensorflow/tfjs-layers/dist/models.js new file mode 100644 index 0000000..dcce67e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/models.js @@ -0,0 +1,397 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __generator = (this && this.__generator) || function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("./backend/state"); +var input_layer_1 = require("./engine/input_layer"); +var topology_1 = require("./engine/topology"); +var training_1 = require("./engine/training"); +var errors_1 = require("./errors"); +var serialization_1 = require("./layers/serialization"); +var generic_utils = require("./utils/generic_utils"); +var serialization_utils_1 = require("./utils/serialization_utils"); +var types_utils_1 = require("./utils/types_utils"); +function modelFromJSON(modelAndWeightsConfig, customObjects) { + return __awaiter(this, void 0, void 0, function () { + var modelTopology, tsConfig, model, weightValues, uniqueWeightValues, _i, _a, weight, skipMismatches, isNamedTensorMap; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + modelTopology = modelAndWeightsConfig.modelTopology; + if (modelTopology['model_config'] != null) { + modelTopology = modelTopology['model_config']; + } + tsConfig = serialization_utils_1.convertPythonicToTs(modelTopology); + model = serialization_1.deserialize(tsConfig, customObjects); + if (!(modelAndWeightsConfig.weightsManifest != null)) return [3, 2]; + return [4, tfjs_core_1.io.loadWeights(modelAndWeightsConfig.weightsManifest, modelAndWeightsConfig.pathPrefix, model.weights.map(function (weight) { return weight.originalName; }))]; + case 1: + weightValues = _b.sent(); + uniqueWeightValues = {}; + for (_i = 0, _a = model.weights; _i < _a.length; _i++) { + weight = _a[_i]; + uniqueWeightValues[weight.originalName] = + weightValues[weight.originalName]; + } + skipMismatches = null; + isNamedTensorMap = true; + model.loadWeights(uniqueWeightValues, skipMismatches, isNamedTensorMap); + _b.label = 2; + case 2: return [2, model]; + } + }); + }); +} +exports.modelFromJSON = modelFromJSON; +function loadModelInternal(pathOrIOHandler) { + return __awaiter(this, void 0, void 0, function () { + var handlers; + return __generator(this, function (_a) { + if (typeof pathOrIOHandler === 'string') { + handlers = tfjs_core_1.io.getLoadHandlers(pathOrIOHandler); + if (handlers.length === 0) { + handlers.push(tfjs_core_1.io.browserHTTPRequest(pathOrIOHandler)); + } + else if (handlers.length > 1) { + throw new errors_1.ValueError("Found more than one (" + handlers.length + ") load handlers for " + + ("URL '" + pathOrIOHandler + "'")); + } + pathOrIOHandler = handlers[0]; + } + return [2, loadModelFromIOHandler(pathOrIOHandler)]; + }); + }); +} +exports.loadModelInternal = loadModelInternal; +function loadModelFromIOHandler(handler, customObjects) { + return __awaiter(this, void 0, void 0, function () { + var artifacts, modelTopology, model, skipMismatch, isNamedTensorMap; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (handler.load == null) { + throw new errors_1.ValueError('Cannot proceed with model loading because the IOHandler provided ' + + 'does not have the `load` method implemented.'); + } + return [4, handler.load()]; + case 1: + artifacts = _a.sent(); + modelTopology = artifacts.modelTopology; + if (modelTopology['model_config'] != null) { + modelTopology = modelTopology['model_config']; + } + model = serialization_1.deserialize(serialization_utils_1.convertPythonicToTs(modelTopology), customObjects); + if (artifacts.weightData != null) { + if (artifacts.weightSpecs == null) { + throw new errors_1.ValueError('Model artifacts contains weight data, but not weight specs. ' + + 'Therefore loading of weights cannot proceed.'); + } + skipMismatch = false; + isNamedTensorMap = true; + model.loadWeights(tfjs_core_1.io.decodeWeights(artifacts.weightData, artifacts.weightSpecs), skipMismatch, isNamedTensorMap); + } + return [2, model]; + } + }); + }); +} +exports.loadModelFromIOHandler = loadModelFromIOHandler; +var Sequential = (function (_super) { + __extends(Sequential, _super); + function Sequential(config) { + var _this = _super.call(this, { inputs: [], outputs: [] }) || this; + config = config || {}; + _this.trainable = true; + _this._updatable = true; + _this.built = false; + _this.name = (config.name != null) ? config.name : state_1.getUid('sequential_'); + if (config.layers != null) { + for (var _i = 0, _a = config.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + _this.add(layer); + } + } + return _this; + } + Sequential.prototype.add = function (layer) { + var isLayerModelInstance = layer instanceof Sequential || layer instanceof training_1.Model; + var modelLayer; + if (isLayerModelInstance) { + modelLayer = layer; + if (modelLayer.outputs.length !== 1) { + throw new errors_1.ValueError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + if (modelLayer.inputs.length !== 1) { + throw new errors_1.ValueError('All layers in a Sequential model ' + + 'should have a single input tensor. ' + + 'For multi-input layers, ' + + 'use the functional API.'); + } + } + if (this.outputs.length === 0) { + if (layer.inboundNodes.length === 0) { + if (layer.batchInputShape == null) { + throw new errors_1.ValueError('The first layer in a Sequential model must ' + + 'get an `inputShape` or `batchInputShape` argument.'); + } + var x = input_layer_1.Input({ + batchShape: layer.batchInputShape, + dtype: layer.dtype, + name: layer.name + '_input' + }); + layer.apply(x); + } + if (isLayerModelInstance) { + this.outputs = modelLayer.outputs; + this.inputs = modelLayer.inputs; + } + else { + if (layer.inboundNodes.length !== 1) { + throw new errors_1.ValueError('A layer added to a Sequential model must not already be ' + + ("connected somewhere else. Model received layer " + layer.name + " ") + + ("which has " + layer.inboundNodes.length + " pre-existing inbound ") + + 'connections.'); + } + if (layer.inboundNodes[0].outputTensors.length !== 1) { + throw new errors_1.ValueError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + this.outputs = [layer.inboundNodes[0].outputTensors[0]]; + this.inputs = topology_1.getSourceInputs(this.outputs[0]); + } + this.inboundNodes = []; + new topology_1.Node({ + outboundLayer: this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: this.inputs, + outputTensors: this.outputs, + inputMasks: generic_utils.pyListRepeat(null, this.inputs.length), + outputMasks: [null], + inputShapes: this.inputs.map(function (x) { return x.shape; }), + outputShapes: this.outputs[0].shape + }); + } + else { + var outputTensor = layer.apply(this.outputs[0]); + if (Array.isArray(outputTensor)) { + throw new TypeError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + this.outputs = [outputTensor]; + this.inboundNodes[0].outputTensors = this.outputs; + this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + } + this.layers.push(layer); + this.built = false; + }; + Sequential.prototype.pop = function () { + if (this.layers.length === 0) { + throw new TypeError('There are no layers in the model.'); + } + this.layers.pop(); + if (this.layers.length === 0) { + this.outputs = []; + this.inboundNodes = []; + this.outboundNodes = []; + } + else { + var lastLayerIndex = this.layers.length - 1; + this.layers[lastLayerIndex].outboundNodes = []; + this.outputs = [this.layers[lastLayerIndex].output]; + this.inboundNodes[0].outputTensors = this.outputs; + this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + } + }; + Sequential.prototype.call = function (inputs, kwargs) { + if (this.model == null) { + this.build(); + } + return this.model.call(inputs, kwargs); + }; + Sequential.prototype.build = function (inputShape) { + types_utils_1.getExactlyOneShape(inputShape); + if (this.inputs.length === 0 || this.outputs.length === 0) { + throw new TypeError('Sequential model cannot be built: model is empty.' + + ' Add some layers first.'); + } + this.model = new training_1.Model({ + inputs: this.inputs, + outputs: this.outputs[0], + name: this.name + '_model' + }); + this.model.trainable = this.trainable; + this.model.updatable = this.updatable; + this.supportsMasking = this.model.supportsMasking; + this.inputLayers = this.model.inputLayers; + this.inputLayersNodeIndices = this.model.inputLayersNodeIndices; + this.inputLayersTensorIndices = this.model.inputLayersTensorIndices; + this.outputLayers = this.model.outputLayers; + this.outputLayersNodeIndices = this.model.outputLayersNodeIndices; + this.outputLayersTensorIndices = this.model.outputLayersTensorIndices; + this.nodesByDepth = this.model.nodesByDepth; + this.containerNodes = this.model.containerNodes; + this.outputNames = this.model.outputNames; + this.inputNames = this.model.inputNames; + this.built = true; + }; + Sequential.prototype.countParams = function () { + if (!this.built) { + this.build(); + } + return _super.prototype.countParams.call(this); + }; + Sequential.prototype.summary = function (lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + if (!this.built) { + this.build(); + } + _super.prototype.summary.call(this, lineLength, positions, printFn); + }; + Sequential.prototype.setWeights = function (weights) { + if (this.model == null) { + this.build(); + } + this.model.setWeights(weights); + }; + Object.defineProperty(Sequential.prototype, "updatable", { + get: function () { + return this._updatable; + }, + set: function (value) { + if (this.built) { + this.model.updatable = value; + } + this._updatable = value; + }, + enumerable: true, + configurable: true + }); + Sequential.prototype.evaluate = function (x, y, config) { + if (config === void 0) { config = {}; } + if (!this.built) { + throw new errors_1.RuntimeError('The model needs to be compiled before being used.'); + } + return this.model.evaluate(x, y, config); + }; + Sequential.prototype.predict = function (x, config) { + if (config === void 0) { config = {}; } + if (this.model == null) { + this.build(); + } + return this.model.predict(x, config); + }; + Sequential.prototype.predictOnBatch = function (x) { + if (this.model == null) { + this.build(); + } + return this.model.predictOnBatch(x); + }; + Sequential.prototype.compile = function (config) { + this.build(); + this.model.compile(config); + this.optimizer = this.model.optimizer; + this.loss = this.model.loss; + this.metrics = this.model.metrics; + this.metricsTensors = this.model.metricsTensors; + this.metricsNames = this.model.metricsNames; + }; + Sequential.prototype.fit = function (x, y, config) { + if (config === void 0) { config = {}; } + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + if (!this.built) { + throw new errors_1.RuntimeError('The model needs to be compiled before ' + + 'being used.'); + } + return [2, this.model.fit(x, y, config)]; + }); + }); + }; + Sequential.fromConfig = function (cls, config) { + var model = new cls({}); + if (!(model instanceof Sequential)) { + throw new errors_1.ValueError("Sequential.fromConfig called on non-Sequential input: " + model); + } + if (!(config instanceof Array)) { + throw new errors_1.ValueError("Sequential.fromConfig called without an array of configs"); + } + if (!(config[0].className != null) || config[0]['className'] === 'Merge') { + throw new errors_1.ValueError('Legacy serialization format not supported yet.'); + } + for (var _i = 0, _a = config; _i < _a.length; _i++) { + var conf = _a[_i]; + var layer = serialization_1.deserialize(conf); + model.add(layer); + } + return model; + }; + Sequential.prototype.getConfig = function () { + var config = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + config.push({ + className: layer.getClassName(), + config: layer.getConfig(), + }); + } + return config; + }; + Sequential.className = 'Sequential'; + return Sequential; +}(training_1.Model)); +exports.Sequential = Sequential; +tfjs_core_1.serialization.SerializationMap.register(Sequential); +//# sourceMappingURL=models.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/models.js.map b/node_modules/@tensorflow/tfjs-layers/dist/models.js.map new file mode 100644 index 0000000..dbd25b1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/models.js.map @@ -0,0 +1 @@ +{"version":3,"file":"models.js","sourceRoot":"","sources":["../src/models.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/models_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/models_test.js.map new file mode 100644 index 0000000..b90ca22 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/models_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"models_test.js","sourceRoot":"","sources":["../src/models_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/optimizers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.d.ts new file mode 100644 index 0000000..9f944a5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.d.ts @@ -0,0 +1,2 @@ +import { Optimizer } from '@tensorflow/tfjs-core'; +export declare function getOptimizer(identifier: string): Optimizer; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js new file mode 100644 index 0000000..264270b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js @@ -0,0 +1,27 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var common_1 = require("./backend/common"); +var errors_1 = require("./errors"); +function getOptimizer(identifier) { + var optimizerMap = { + 'Adagrad': function () { return tfjs_core_1.train.adagrad(0.01); }, + 'Adadelta': function () { return tfjs_core_1.train.adadelta(1, 0.95, common_1.epsilon()); }, + 'Adam': function () { return tfjs_core_1.train.adam(0.001, 0.9, 0.999, common_1.epsilon()); }, + 'Adamax': function () { return tfjs_core_1.train.adamax(0.002, 0.9, 0.999, common_1.epsilon(), 0); }, + 'RMSProp': function () { return tfjs_core_1.train.rmsprop(0.001, 0.9, 0, common_1.epsilon()); }, + 'SGD': function () { return tfjs_core_1.train.sgd(0.01); } + }; + optimizerMap['adagrad'] = optimizerMap['Adagrad']; + optimizerMap['adadelta'] = optimizerMap['Adadelta']; + optimizerMap['adam'] = optimizerMap['Adam']; + optimizerMap['adamax'] = optimizerMap['Adamax']; + optimizerMap['rmsprop'] = optimizerMap['RMSProp']; + optimizerMap['sgd'] = optimizerMap['SGD']; + if (identifier in optimizerMap) { + return optimizerMap[identifier](); + } + throw new errors_1.ValueError("Unknown Optimizer " + identifier); +} +exports.getOptimizer = getOptimizer; +//# sourceMappingURL=optimizers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js.map new file mode 100644 index 0000000..0a887c7 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/optimizers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizers.js","sourceRoot":"","sources":["../src/optimizers.ts"],"names":[],"mappings":";;AAeA,mDAAuD;AAEvD,2CAAyC;AAGzC,mCAAoC;AAMpC,sBAA6B,UAAkB;IAC7C,IAAM,YAAY,GAA+C;QAC/D,SAAS,EAAE,cAAM,OAAA,iBAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAnB,CAAmB;QACpC,UAAU,EAAE,cAAM,OAAA,iBAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,gBAAO,EAAE,CAAC,EAAlC,CAAkC;QACpD,MAAM,EAAE,cAAM,OAAA,iBAAK,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,gBAAO,EAAE,CAAC,EAAxC,CAAwC;QACtD,QAAQ,EAAE,cAAM,OAAA,iBAAK,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,gBAAO,EAAE,EAAE,CAAC,CAAC,EAA7C,CAA6C;QAC7D,SAAS,EAAE,cAAM,OAAA,iBAAK,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,gBAAO,EAAE,CAAC,EAAvC,CAAuC;QACxD,KAAK,EAAE,cAAM,OAAA,iBAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAf,CAAe;KAC7B,CAAC;IACF,YAAY,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IAClD,YAAY,CAAC,UAAU,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC;IACpD,YAAY,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IAC5C,YAAY,CAAC,QAAQ,CAAC,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;IAChD,YAAY,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IAClD,YAAY,CAAC,KAAK,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;IAE1C,IAAI,UAAU,IAAI,YAAY,EAAE;QAC9B,OAAO,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC;KACnC;IACD,MAAM,IAAI,mBAAU,CAAC,uBAAqB,UAAY,CAAC,CAAC;AAC1D,CAAC;AApBD,oCAoBC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/optimizers_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/optimizers_test.js.map new file mode 100644 index 0000000..2c1bb0d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/optimizers_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"optimizers_test.js","sourceRoot":"","sources":["../src/optimizers_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/regularizers.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.d.ts new file mode 100644 index 0000000..f3c6bc0 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.d.ts @@ -0,0 +1,34 @@ +import { Scalar, serialization, Tensor } from '@tensorflow/tfjs-core'; +export declare abstract class Regularizer extends serialization.Serializable { + abstract apply(x: Tensor): Scalar; +} +export interface L1L2Config { + l1?: number; + l2?: number; +} +export interface L1Config { + l1: number; +} +export interface L2Config { + l2: number; +} +export declare class L1L2 extends Regularizer { + static className: string; + private readonly l1; + private readonly l2; + private readonly hasL1; + private readonly hasL2; + constructor(config?: L1L2Config); + apply(x: Tensor): Scalar; + getConfig(): serialization.ConfigDict; + static fromConfig(cls: serialization.SerializableConstructor, config: serialization.ConfigDict): T; +} +export declare function l1(config?: L1Config): L1L2; +export declare function l2(config: L2Config): L1L2; +export declare type RegularizerIdentifier = 'l1l2' | string; +export declare const REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP: { + [identifier in RegularizerIdentifier]: string; +}; +export declare function serializeRegularizer(constraint: Regularizer): serialization.ConfigDictValue; +export declare function deserializeRegularizer(config: serialization.ConfigDict, customObjects?: serialization.ConfigDict): Regularizer; +export declare function getRegularizer(identifier: RegularizerIdentifier | serialization.ConfigDict | Regularizer): Regularizer; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js new file mode 100644 index 0000000..cf6694b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js @@ -0,0 +1,102 @@ +"use strict"; +var __extends = (this && this.__extends) || (function () { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("./backend/state"); +var K = require("./backend/tfjs_backend"); +var generic_utils_1 = require("./utils/generic_utils"); +var Regularizer = (function (_super) { + __extends(Regularizer, _super); + function Regularizer() { + return _super !== null && _super.apply(this, arguments) || this; + } + return Regularizer; +}(tfjs_core_1.serialization.Serializable)); +exports.Regularizer = Regularizer; +var L1L2 = (function (_super) { + __extends(L1L2, _super); + function L1L2(config) { + var _this = _super.call(this) || this; + var l1 = config == null || config.l1 == null ? 0.01 : config.l1; + var l2 = config == null || config.l2 == null ? 0.01 : config.l2; + _this.hasL1 = l1 !== 0; + _this.hasL2 = l2 !== 0; + _this.l1 = state_1.getScalar(l1); + _this.l2 = state_1.getScalar(l2); + return _this; + } + L1L2.prototype.apply = function (x) { + var _this = this; + return tfjs_core_1.tidy(function () { + var regularization = tfjs_core_1.zeros([1]); + if (_this.hasL1) { + regularization = tfjs_core_1.add(regularization, tfjs_core_1.sum(tfc.mul(_this.l1, tfjs_core_1.abs(x)))); + } + if (_this.hasL2) { + regularization = + tfjs_core_1.add(regularization, tfjs_core_1.sum(tfc.mul(_this.l2, K.square(x)))); + } + return regularization.asScalar(); + }); + }; + L1L2.prototype.getConfig = function () { + return { 'l1': this.l1.dataSync()[0], 'l2': this.l2.dataSync()[0] }; + }; + L1L2.fromConfig = function (cls, config) { + return new cls({ l1: config.l1, l2: config.l2 }); + }; + L1L2.className = 'L1L2'; + return L1L2; +}(Regularizer)); +exports.L1L2 = L1L2; +tfjs_core_1.serialization.SerializationMap.register(L1L2); +function l1(config) { + return new L1L2({ l1: config != null ? config.l1 : null, l2: 0 }); +} +exports.l1 = l1; +function l2(config) { + return new L1L2({ l2: config != null ? config.l2 : null, l1: 0 }); +} +exports.l2 = l2; +exports.REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'l1l2': 'L1L2' +}; +function serializeRegularizer(constraint) { + return generic_utils_1.serializeKerasObject(constraint); +} +exports.serializeRegularizer = serializeRegularizer; +function deserializeRegularizer(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return generic_utils_1.deserializeKerasObject(config, tfjs_core_1.serialization.SerializationMap.getMap().classNameMap, customObjects, 'regularizer'); +} +exports.deserializeRegularizer = deserializeRegularizer; +function getRegularizer(identifier) { + if (identifier == null) { + return null; + } + if (typeof identifier === 'string') { + var className = identifier in exports.REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + exports.REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + var config = { className: className, config: {} }; + return deserializeRegularizer(config); + } + else if (identifier instanceof Regularizer) { + return identifier; + } + else { + return deserializeRegularizer(identifier); + } +} +exports.getRegularizer = getRegularizer; +//# sourceMappingURL=regularizers.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js.map new file mode 100644 index 0000000..b197c0b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/regularizers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"regularizers.js","sourceRoot":"","sources":["../src/regularizers.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/regularizers_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/regularizers_test.js.map new file mode 100644 index 0000000..7a2569a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/regularizers_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"regularizers_test.js","sourceRoot":"","sources":["../src/regularizers_test.ts"],"names":[],"mappings":";;AAYA,mDAA8E;AAE9E,6BAA+B;AAE/B,+CAA4F;AAC5F,iDAAuE;AAIvE,4BAAe,CAAC,uBAAuB,EAAE;IACvC,EAAE,CAAC,OAAO,EAAE;QACV,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC5C,IAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,+BAAkB,CACd,KAAK,EAAE,kBAAM,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC;QAC1C,IAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,+BAAkB,CAAC,KAAK,EAAE,kBAAM,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,IAAI,EAAE;QACP,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC;QAC1C,IAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,+BAAkB,CAAC,KAAK,EAAE,kBAAM,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,mBAAmB,EAAE;QACtB,IAAM,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,IAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;QAC1D,IAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,+BAAkB,CACd,KAAK,EAAE,kBAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,4BAAe,CAAC,kBAAkB,EAAE;IAClC,IAAI,CAAS,CAAC;IACd,UAAU,CAAC;QACT,CAAC,GAAG,oBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;QAC5B,IAAM,WAAW,GAAG,6BAAc,CAAC,MAAM,CAAC,CAAC;QAC3C,+BAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,yBAAyB,EAAE;QAC5B,IAAM,WAAW,GAAG,6BAAc,CAAC,MAAM,CAAC,CAAC;QAC3C,+BAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE;QACvB,IAAM,OAAO,GAAG,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;QACtD,IAAM,WAAW,GAAG,6BAAc,CAAC,OAAO,CAAC,CAAC;QAC5C,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,gBAAgB,EAAE;QACnB,IAAM,OAAO,GAAG,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;QACtD,IAAM,WAAW,GAAG,6BAAc,CAC9B,mCAAoB,CAAC,OAAO,CAA6B,CAAC,CAAC;QAC/D,+BAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,4BAAe,CAAC,2BAA2B,EAAE;IAC3C,EAAE,CAAC,WAAW,EAAE;QACd,IAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;QAC1D,IAAM,MAAM,GACR,mCAAoB,CAAC,WAAW,CAA6B,CAAC;QAClE,IAAM,aAAa,GAAG,qCAAsB,CAAC,MAAM,CAAC,CAAC;QACrD,IAAM,eAAe,GACjB,mCAAoB,CAAC,aAAa,CAA6B,CAAC;QACpE,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAClD,IAAM,YAAY,GAAG,eAAe,CAAC,MAAkC,CAAC;QACxE,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js new file mode 100644 index 0000000..51103da --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js @@ -0,0 +1,18 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +import{keep,scalar,tidy,onesLike,tensor1d,util,zerosLike,train,cast,serialization,add,mul,div,Tensor,Optimizer,mean,io,transpose,reverse,zeros,sum,dispose,neg,variable,ones,eye,randomUniform,truncatedNormal,randomNormal,sub,sqrt,mulStrict,clipByValue,relu,linalg,leakyRelu,elu,conv1d,conv2d,conv2dTranspose,separableConv2d,depthwiseConv2d,maximum,minimum,batchNormalization2d,batchNormalization3d,batchNormalization4d,moments,movingAverage,pad,maxPool,avgPool,squeeze,max,abs,log,softplus,softmax,floor,oneHot,exp,greater,equal,argMax,slice1d,slice2d,slice3d,slice4d,concat,concat1d,concat2d,concat3d,concat4d,tile,matMul,gather,step,min,selu,sigmoid,tanh}from"@tensorflow/tfjs-core";var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])&&(6===a[0]||2===a[0])){o=0;continue}if(3===a[0]&&(!i||a[1]>i[0]&&a[1]t?1:0}function reverseNumberCompare(e,t){return-1*numberCompare(e,t)}function stringToDType(e){switch(e){case"float32":return"float32";default:throw new ValueError("Invalid dtype: "+e)}}function unique(e){if(null==e)return e;for(var t=[],n=0,r=e;n=0),assert(r>=n),Array.isArray(e)&&e.length>=n&&e.length<=r&&e.every(function(e){return typeof e===t})}function calcL2Norms(e,t){return tidy(function(){return sqrt(sum(mulStrict(e,e),t,!0))})}var Constraint=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.getConfig=function(){return{}},t}(serialization.Serializable),MaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMaxValue=2,n.defaultAxis=0,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=clipByValue(n,0,t.maxValue);return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{maxValue:this.maxValue,axis:this.axis}},t.className="MaxNorm",t}(Constraint);serialization.SerializationMap.register(MaxNorm);var UnitNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultAxis=0,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){return div(e,add(getScalar(epsilon()),calcL2Norms(e,t.axis)))})},t.prototype.getConfig=function(){return{axis:this.axis}},t.className="UnitNorm",t}(Constraint);serialization.SerializationMap.register(UnitNorm);var NonNeg=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.apply=function(e){return relu(e)},t.className="NonNeg",t}(Constraint);serialization.SerializationMap.register(NonNeg);var MinMaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMinValue=0,n.defaultMaxValue=1,n.defaultRate=1,n.defaultAxis=0,n.minValue=null!=t.minValue?t.minValue:n.defaultMinValue,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.rate=null!=t.rate?t.rate:n.defaultRate,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=add(mul(getScalar(t.rate),clipByValue(n,t.minValue,t.maxValue)),mul(getScalar(1-t.rate),n));return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}},t.className="MinMaxNorm",t}(Constraint);serialization.SerializationMap.register(MinMaxNorm);var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function serializeConstraint(e){return serializeKerasObject(e)}function deserializeConstraint(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,"constraint")}function getConstraint(e){return null==e?null:"string"==typeof e?deserializeConstraint({className:e in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP?CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e,config:{}}):e instanceof Constraint?e:deserializeConstraint(e)}function maxNorm(e){return new MaxNorm(e)}function unitNorm(e){return new UnitNorm(e)}function nonNeg(){return new NonNeg}function minMaxNorm(e){return new MinMaxNorm(e)}var exports_constraints=Object.freeze({maxNorm:maxNorm,unitNorm:unitNorm,nonNeg:nonNeg,minMaxNorm:minMaxNorm}),nameMap=new Map,VALID_DATA_FORMAT_VALUES=["channelsFirst","channelsLast"];function checkDataFormat(e){checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES,"DataFormat",e)}var VALID_PADDING_MODE_VALUES=["valid","same","causal"];function checkPaddingMode(e){checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES,"PaddingMode",e)}var VALID_POOL_MODE_VALUES=["max","avg"];function checkPoolMode(e){checkStringTypeUnionValue(VALID_POOL_MODE_VALUES,"PoolMode",e)}var _nameScopeStack=[],_nameScopeDivider="/";function nameScope(e,t){_nameScopeStack.push(e);try{var n=t();return _nameScopeStack.pop(),n}catch(e){throw _nameScopeStack.pop(),e}}function currentNameScopePrefix(){return 0===_nameScopeStack.length?"":_nameScopeStack.join(_nameScopeDivider)+_nameScopeDivider}function getScopedTensorName(e){if(!isValidTensorName(e))throw new Error("Not a valid tensor name: '"+e+"'");return currentNameScopePrefix()+e}function getUniqueTensorName(e){if(!isValidTensorName(e))throw new Error("Not a valid tensor name: '"+e+"'");nameMap.has(e)||nameMap.set(e,0);var t=nameMap.get(e);if(nameMap.set(e,nameMap.get(e)+1),t>0){var n=e+"_"+t;return nameMap.set(n,1),n}return e}var tensorNameRegex=new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/);function isValidTensorName(e){return!!e.match(tensorNameRegex)}function isInteger(e){return e===parseInt(e.toString(),10)}function arrayProd(e,t,n){null==t&&(t=0),null==n&&(n=e.length);for(var r=1,i=t;i2e3&&console.warn("Orthogonal initializer is being called on a matrix with more than 2000 ("+e[0]*e[1]+") elements: Slowness may result.");var t=randomNormal$1(e[0]>e[1]?[e[1],e[0]]:e,0,1,"float32"),r=linalg.gramSchmidt(t);return e[0]>e[1]&&(r=r.transpose()),mul(getScalar(n.gain),r)})},t.prototype.getConfig=function(){return{gain:this.gain,seed:this.seed}},t.className="Orthogonal",t}(Initializer);serialization.SerializationMap.register(Orthogonal);var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP={constant:"Constant",glorotNormal:"GlorotNormal",glorotUniform:"GlorotUniform",heNormal:"HeNormal",identity:"Identity",leCunNormal:"LeCunNormal",ones:"Ones",orthogonal:"Orthogonal",randomNormal:"RandomNormal",randomUniform:"RandomUniform",truncatedNormal:"TruncatedNormal",varianceScaling:"VarianceScaling",zeros:"Zeros"};function deserializeInitializer(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,"initializer")}function serializeInitializer(e){return serializeKerasObject(e)}function getInitializer(e){if("string"==typeof e){var t=e in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP?INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e;return"GlorotUniform"===t?new GlorotUniform:"GlorotNormal"===t?new GlorotNormal:"HeNormal"===t?new HeNormal:"LeCunNormal"===t?new LeCunNormal:deserializeInitializer({className:t,config:{}})}return e instanceof Initializer?e:deserializeInitializer(e)}function zeros$1(){return new Zeros}function ones$1(){return new Ones}function constant(e){return new Constant(e)}function randomUniform$1(e){return new RandomUniform(e)}function randomNormal$2(e){return new RandomNormal(e)}function truncatedNormal$1(e){return new TruncatedNormal(e)}function identity(e){return new Identity(e)}function varianceScaling(e){return new VarianceScaling(e)}function glorotUniform(e){return new GlorotUniform(e)}function glorotNormal(e){return new GlorotNormal(e)}function heNormal(e){return new HeNormal(e)}function leCunNormal(e){return new LeCunNormal(e)}function orthogonal(e){return new Orthogonal(e)}var exports_initializers=Object.freeze({zeros:zeros$1,ones:ones$1,constant:constant,randomUniform:randomUniform$1,randomNormal:randomNormal$2,truncatedNormal:truncatedNormal$1,identity:identity,varianceScaling:varianceScaling,glorotUniform:glorotUniform,glorotNormal:glorotNormal,heNormal:heNormal,leCunNormal:leCunNormal,orthogonal:orthogonal});function isArrayOfShapes(e){return Array.isArray(e)&&Array.isArray(e[0])}function normalizeShapeList(e){return 0===e.length?[]:Array.isArray(e[0])?e:[e]}function getExactlyOneTensor(e){var t;if(Array.isArray(e)){if(1!==e.length)throw new ValueError("Expected Tensor length to be 1; got "+e.length);t=e[0]}else t=e;return t}function getExactlyOneShape(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(1===e.length)return(e=e)[0];throw new ValueError("Expected exactly 1 Shape; got "+e.length)}return e}function countParamsInWeights(e){for(var t=0,n=0,r=e;n1)throw new AttributeError("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if(0===this.inboundNodes.length)throw new AttributeError("Layer "+this.name+" is not connected, no input to return.");return singletonOrArray(this.getNodeAtIndex(0,"input").inputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"output",{get:function(){if(0===this.inboundNodes.length)throw new AttributeError("Layer "+this.name+" has no inbound nodes.");if(this.inboundNodes.length>1)throw new AttributeError("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return singletonOrArray(this.getNodeAtIndex(0,"output").outputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"losses",{get:function(){return this._losses},enumerable:!0,configurable:!0}),t.prototype.calculateLosses=function(){return this.losses.map(function(e){return e()})},Object.defineProperty(t.prototype,"updates",{get:function(){return this._updates},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"built",{get:function(){return this._built},set:function(e){this._built=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"trainableWeights",{get:function(){return this.trainable?this._trainableWeights:[]},set:function(e){this._trainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this._nonTrainableWeights:this._trainableWeights.concat(this._nonTrainableWeights)},set:function(e){this._nonTrainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"weights",{get:function(){return this.trainableWeights.concat(this.nonTrainableWeights)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"stateful",{get:function(){return this._stateful},enumerable:!0,configurable:!0}),t.prototype.assertInputCompatibility=function(e){if(e=toList(e),null!=this.inputSpec&&0!==this.inputSpec.length){var t=toList(this.inputSpec);if(e.length!==t.length)throw new ValueError("Layer "+this.name+" expects "+t.length+" inputs, but it received "+e.length+" input tensors. Input received: "+e);for(var n=0;n=0?o[l]:o[o.length+l];if(null!=u&&-1===[u,null].indexOf(c))throw new ValueError("Input "+n+" is incompatible with layer "+this.name+": expected axis "+l+" of input shape to have value "+u+" but got shape "+o+".")}}if(null!=i.shape)for(var p=0;p0&&Array.isArray(g[0])?g.map(function(r,i){return new SymbolicTensor(m,r,n,toList(e),t,n.name,i)}):new SymbolicTensor(m,g,n,toList(e),t,n.name),n.addInboundNode(e,f,null,null,d,g,t),null!=n.activityRegularizer)throw new NotImplementedError("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return f})},t.prototype.warnOnIncompatibleInputShape=function(e){if(null!=this.batchInputShape)if(e.length!==this.batchInputShape.length)console.warn("The rank of the input tensor provided (shape: "+JSON.stringify(e)+") does not match that of the batchInputShape ("+JSON.stringify(this.batchInputShape)+") of the layer "+this.name);else{var t=!1;this.batchInputShape.forEach(function(n,r){null!=n&&null!=e[r]&&e[r]!==n&&(t=!0)}),t&&console.warn("The shape of the input tensor ("+JSON.stringify(e)+") does not match the expectation of layer "+this.name+": "+JSON.stringify(this.batchInputShape))}},Object.defineProperty(t.prototype,"outputShape",{get:function(){if(null==this.inboundNodes||0===this.inboundNodes.length)throw new AttributeError("The layer "+this.name+" has never been called and thus has no defined output shape.");for(var e=[],t=0,n=this.inboundNodes;t0)&&(t=e.sourceLayer,n=e.nodeIndex),0===t.inboundNodes.length)return[e];var r=t.inboundNodes[n];if(0===r.inboundLayers.length)return r.inputTensors;for(var i=[],a=0;a1||1===s.length&&s[0].inboundLayers.length>1){t=!1;break}r.push.apply(r,s)}if(t)for(var l=0,u=e.layers;l0&&(r=r.slice(0,r.length-1)+" "),r=(r+=e[i]).slice(0,t[i]),r+=" ".repeat(t[i]-r.length);n(r)}function printLayerSummary(e,t,n){var r;try{r=JSON.stringify(e.outputShape)}catch(e){r="multiple"}printRow([e.name+" ("+e.getClassName()+")",r,e.countParams().toString()],t,n)}function printLayerSummaryWithConnections(e,t,n,r){var i;try{i=JSON.stringify(e.outputShape)}catch(e){i="multiple"}for(var a=[],o=0,s=e.inboundNodes;o0&&-1===n.indexOf(l)))for(var u=0;u0)throw new ValueError(p.length+" of "+r+" weights are not set: "+p);batchSetValue(u)}var Container=function(e){function t(n){var r=e.call(this,{})||this;if(r.containerNodes=new Set,r.name=n.name,null==r.name){var i=r.getClassName().toLowerCase();r.name=getUid(i)}if(r.supportsMasking=!1,r.trainable=!0,r.updatable=!0,Array.isArray(n.inputs)?r.inputs=n.inputs.slice():r.inputs=[n.inputs],Array.isArray(n.outputs)?r.outputs=n.outputs.slice():r.outputs=[n.outputs],unique(r.inputs).length!==r.inputs.length)throw new ValueError("The list of inputs passed to the model is redundant. All inputs should only appear once. Found: "+r.inputs.map(function(e){return e.name}));unique(r.outputs).length!==r.outputs.length&&console.warn("The list of outputs passed to the model is redundant. All outputs should only appear once. Found: "+r.outputs.map(function(e){return e.name})),r.inputLayers=[],r.inputLayersNodeIndices=[],r.inputLayersTensorIndices=[],r.outputLayers=[],r.outputLayersNodeIndices=[],r.outputLayersTensorIndices=[],r.layers=[];for(var a=0,o=r.outputs;a1 nodes"),assert(0===u,"input layer has >1 tensors"),r.inputLayers.push(s),r.inputLayersNodeIndices.push(l),r.inputLayersTensorIndices.push(u)}r.inputNames=[],r.outputNames=[],r.feedInputShapes=[],r.feedInputNames=[],r.feedOutputNames=[];for(var h=0;h=0;)i.splice(i.indexOf(l),1);z.push(l)}},S=[],A=[],I=0,N=r.outputs;Ir?1:0});for(var j=0,W=U;j0)throw new ValueError("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];for(var e=[],t=0,n=this.layers;t1)for(var s=0,l=o;s0){for(var d=[],g=0;g0&&e.apply(singletonOrArray(a),r)}function o(e){var r=e.name,a=deserialize(e,null!=t.customObjects?t.customObjects:{});n[r]=a;for(var o=0,s=e.inboundNodes;o0)a=!0;else if(isDataDict(e)){for(var o in e)if(e.hasOwnProperty(o)){a=!0;break}}else a=!0;if(a)throw new ValueError("Error when checking model "+i+" expected no data, but got "+e)}return[]}if(null==e)return t.map(function(e){return null});var s;if(isDataDict(e)){e=e,s=[];for(var l=0,u=t;l1)throw new ValueError("The model "+i+" expects "+t.length+" Tensor(s), but only received one Tensor. Found: Tensor with shape "+e.shape);s=[e]}for(var p=0;p=0&&g!==f)throw new ValueError("Error when checking "+i+": expected "+t[p]+" to have shape ["+n[p]+"], but got array with shape ["+h.shape+"].")}}return s}function checkArrayLengths(e,t,n){var r=unique(e.map(function(e){return e.shape[0]}));r.sort();var i=unique(t.map(function(e){return e.shape[0]}));if(i.sort(),r.length>1)throw new ValueError("All input Tensors (x) should have the same number of samples. Got array shapes: "+JSON.stringify(e.map(function(e){return e.shape})));if(i.length>1)throw new ValueError("All target Tensors (y) should have the same number of samples. Got array shapes: "+JSON.stringify(t.map(function(e){return e.shape})));if(r.length>0&&i.length>0&&!util.arraysEqual(r,i))throw new ValueError("Input Tensors should have the same number of samples as target Tensors. Found "+r[0]+" input sample(s) and "+i[0]+" target sample(s).")}function checkLossAndTargetCompatibility(e,t,n){for(var r=[meanSquaredError,binaryCrossentropy,categoricalCrossentropy],i=0;i=e&&(i=e),n.push([r,i]),r=i;return n}function sliceArrays(e,t,n){return null==e?[null]:Array.isArray(e)?e.map(function(e){return sliceAlongFirstAxis(e,t,n-t)}):sliceAlongFirstAxis(e,t,n-t)}function sliceArraysByIndices(e,t){return tidy(function(){return null==e?null:Array.isArray(e)?e.map(function(e){return sliceArraysByIndices(e,t)}):gather$1(e,"int32"===t.dtype?t:t.toInt())})}function checkInputData(e,t,n,r,i){var a;if(void 0===r&&(r=!0),void 0===i&&(i=""),Array.isArray(e)){if(e.length!==t.length)throw new ValueError("Error when checking model "+i+": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see "+t.length+" Tensor(s), but instead got "+e.length+" Tensors(s).");a=e}else{if(t.length>1)throw new ValueError("The model expects "+t.length+" "+i+" Tensors, but only received one Tensor. Found: array with shape "+JSON.stringify(e.shape)+".");a=[e]}if(null!=n)for(var o=0;o1&&(t.metricsTensors.push([n,e]),t.metricsNames.push(t.outputNames[e]+"_loss"))}});var p=collectMetrics(e.metrics,this.outputNames);nameScope("metric",function(){for(var e=function(e){if(-1!==c.indexOf(e))return"continue";!function(n){for(var r,i,a,o=function(n){if(-1!==["accuracy","acc","crossentropy","ce"].indexOf(n)){var o=t.internalOutputShapes[e];1===o[o.length-1]||t.lossFunctions[e]===binaryCrossentropy?-1!==["accuracy","acc"].indexOf(n)?i=binaryAccuracy:-1!==["crossentropy","ce"].indexOf(n)&&(i=binaryCrossentropy$1):t.lossFunctions[e]===sparseCategoricalCrossentropy?-1!==["accuracy","acc"].indexOf(n)?i=sparseCategoricalAccuracy:-1!==["crossentropy","ce"].indexOf(n)&&(i=sparseCategoricalCrossentropy$1):-1!==["accuracy","acc"].indexOf(n)?i=categoricalAccuracy:-1!==["crossentropy","ce"].indexOf(n)&&(i=categoricalCrossentropy$1);var s=void 0;-1!==["accuracy","acc"].indexOf(n)?s="acc":-1!==["crossentropy","ce"].indexOf(n)&&(s="ce"),a=i,r=""+s}else{var l=get$1(n);a=l,r=""+n}var u;nameScope(r,function(){u=a}),function(e,n,r){t.outputNames.length>1&&(n=t.outputNames[e]+"_"+n),t.metricsNames.push(n),t.metricsTensors.push([r,e])}(e,r,u)},s=0,l=n;s0){var c=[];throw t.forEach(function(t,n){null==t&&c.push(e[n])}),new ValueError("Cannot find SymbolicTensors for output name(s): "+JSON.stringify(c))}return t},t.prototype.predictLoop=function(e,t,n){var r=this;return void 0===t&&(t=32),void 0===n&&(n=!1),tidy(function(){var i=r.checkNumSamples(e);if(n)throw new NotImplementedError("Verbose predictLoop() is not implemented yet.");for(var a=makeBatches(i,t),o=[],s=function(t){var n=tidy(function(){var n=a[t][0],i=a[t][1],o=sliceArrays(e,n,i),s=[];if(Array.isArray(o))for(var l=0;l0&&e[0].shape[0]%r!=0)throw new ValueError("In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size "+r+". Found: "+e[0].shape[0]+" sample(s).");return[e,t,null]},t.prototype.fitLoop=function(e,t,n,r,i,a,o,s,l,u,c,p,h,d){return __awaiter(this,void 0,void 0,function(){var g,f,m,y,v,b,z,w=this;return __generator(this,function(S){switch(S.label){case 0:if(null==r&&(r=32),null==i&&(i=1),null==u&&(u=!0),null==p&&(p=0),g=!1,null!=s&&null!=l&&(g=!0),null!=d&&(g=!0,null==h))throw new ValueError("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");if(null!=(f=this.checkNumSamples(t,r,h,"steps_per_epoch"))&&(m=range(0,f)),this.history=new History,o=(o=null==o?[new BaseLogger]:[new BaseLogger].concat(o)).concat([this.history]),a>0)throw new NotImplementedError("Verbose mode is not implemented yet.");return(y=new CallbackList(o)).setModel(this),y.setParams({epochs:i,initialEpoch:p,steps:h,verbose:a,doValidation:g,metrics:c}),[4,y.onTrainBegin()];case 1:S.sent(),this.stopTraining=!1,v=function(i){var a,o,c,p,d;return __generator(this,function(v){switch(v.label){case 0:return[4,y.onEpochBegin(i)];case 1:if(v.sent(),a={},null==h)return[3,2];throw new NotImplementedError("stepsPerEpoch mode is not implemented yet.");case 2:if("batch"===u)throw new NotImplementedError("batch shuffling is not implemneted yet");u&&util.shuffle(m),o=tensor1d(m),c=makeBatches(f,r),p=function(i){var u;return __generator(this,function(p){switch(p.label){case 0:return u={},[4,y.onBatchBegin(i,u)];case 1:return p.sent(),tidy(function(){var p=c[i][0],h=c[i][1],d=sliceAlongFirstAxis(o,p,h-p);u.batch=i,u.size=h-p;for(var f=sliceArraysByIndices(t,d),m=e(f),y=0;y1)i+="_"+count(e.slice(0,n),r);t.push(i)}return t},t.prototype.makeTestFunction=function(){var e=this;this.testFunction=function(t){return tidy(function(){for(var n,r=[],i=t.slice(0,e.inputs.length),a=t.slice(e.inputs.length,e.inputs.length+e.outputs.length),o=[],s=0;s0){if(s=!0,2!==n.validationData.length)throw 3===n.validationData.length?new NotImplementedError("validationData including sample weights is not supported yet."):new ValueError("When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; "+n.validationData+" is invalid.");l=n.validationData[0],u=n.validationData[1],h=this.standardizeUserData(l,u,!0,r),l=h[0],u=h[1],c=l.concat(u)}else null!=n.validationSplit&&n.validationSplit>0&&n.validationSplit<1?(s=!0,d=Math.floor(a[0].shape[0]*(1-n.validationSplit)),g=a[0].shape[0],l=sliceArrays(a,d,g),a=sliceArrays(a,0,d),u=sliceArrays(o,d,g),o=sliceArrays(o,0,d),p=!0,c=l.concat(u)):null!=n.validationSteps&&(s=!0);return f=a.concat(o),this.checkTrainableWeightsConsistency(),m=function(e){var t=e.slice(0,S.inputs.length),n=e.slice(S.inputs.length,S.inputs.length+S.outputs.length),r=[],i=S.collectedTrainableWeights.map(function(e){return e.read()});return[S.optimizer.minimize(function(){for(var e=[],i=0;i1)throw new ValueError("Found more than one ("+n.length+") save handlers for URL '"+e+"'");e=n[0]}if(null==e.save)throw new ValueError("Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return[4,io.encodeWeights(this.getNamedWeights(t))];case 1:return r=s.sent(),i=!1,a=null,o=this.toJSON(a,i),[2,e.save({modelTopology:o,weightData:r.data,weightSpecs:r.specs})]}})})},t.className="Model",t}(Container);function loadModelInternal(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){if("string"==typeof e){if(0===(t=io.getLoadHandlers(e)).length)t.push(io.browserHTTPRequest(e));else if(t.length>1)throw new ValueError("Found more than one ("+t.length+") load handlers for URL '"+e+"'");e=t[0]}return[2,loadModelFromIOHandler(e)]})})}function loadModelFromIOHandler(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,i,a,o;return __generator(this,function(s){switch(s.label){case 0:if(null==e.load)throw new ValueError("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");return[4,e.load()];case 1:if(n=s.sent(),null!=(r=n.modelTopology).model_config&&(r=r.model_config),i=deserialize(convertPythonicToTs(r),t),null!=n.weightData){if(null==n.weightSpecs)throw new ValueError("Model artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");a=!1,o=!0,i.loadWeights(io.decodeWeights(n.weightData,n.weightSpecs),a,o)}return[2,i]}})})}serialization.SerializationMap.register(Model);var Sequential=function(e){function t(t){var n=e.call(this,{inputs:[],outputs:[]})||this;if(t=t||{},n.trainable=!0,n._updatable=!0,n.built=!1,n.name=null!=t.name?t.name:getUid("sequential_"),null!=t.layers)for(var r=0,i=t.layers;r 0 but got "+JSON.stringify(e.filters))},t}(BaseConv),Conv2D=function(e){function t(n){var r=e.call(this,2,n)||this;return t.verifyConfig(n),r}return __extends(t,e),t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.rank,t},t.verifyConfig=function(e){if("number"!=typeof e.kernelSize&&!checkArrayTypeAndLength(e.kernelSize,"number",1,2))throw new ValueError("Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received "+JSON.stringify(e.kernelSize)+".")},t.className="Conv2D",t}(Conv);serialization.SerializationMap.register(Conv2D);var Conv2DTranspose=function(e){function t(t){var n=e.call(this,t)||this;if(n.inputSpec=[new InputSpec({ndim:4})],"same"!==n.padding&&"valid"!==n.padding)throw new ValueError("Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode "+n.padding);return n}return __extends(t,e),t.prototype.build=function(e){if(4!==(e=getExactlyOneShape(e)).length)throw new ValueError("Input should have rank 4; Received input shape: "+JSON.stringify(e));var t="channelsFirst"===this.dataFormat?1:e.length-1;if(null==e[t])throw new ValueError("The channel dimension of the inputs should be defined. Found `None`.");var n,r=e[t],i=this.kernelSize.concat([this.filters,r]);this.kernel=this.addWeight("kernel",i,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new InputSpec({ndim:4,axes:(n={},n[t]=r,n)})],this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);if(4!==t.shape.length)throw new ValueError("Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-"+t.shape.length);var r,i,a=t.shape,o=a[0];"channelsFirst"===n.dataFormat?(r=2,i=3):(r=1,i=2);var s=a[r],l=a[i],u=n.kernelSize[0],c=n.kernelSize[1],p=n.strides[0],h=n.strides[1],d=[o,deconvLength(s,p,u,n.padding),deconvLength(l,h,c,n.padding),n.filters];"channelsLast"!==n.dataFormat&&(t=transpose(t,[0,2,3,1]));var g=conv2dTranspose(t,n.kernel.read(),d,n.strides,n.padding);return"channelsLast"!==n.dataFormat&&(g=transpose(g,[0,3,1,2])),null!=n.bias&&(g=biasAdd(g,n.bias.read(),n.dataFormat)),null!=n.activation&&(g=n.activation.apply(g)),g})},t.prototype.computeOutputShape=function(e){var t,n,r,i=(e=getExactlyOneShape(e)).slice();"channelsFirst"===this.dataFormat?(t=1,n=2,r=3):(t=3,n=1,r=2);var a=this.kernelSize[0],o=this.kernelSize[1],s=this.strides[0],l=this.strides[1];return i[t]=this.filters,i[n]=deconvLength(i[n],s,a,this.padding),i[r]=deconvLength(i[r],l,o,this.padding),i},t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.dilationRate,t},t.className="Conv2DTranspose",t}(Conv2D);serialization.SerializationMap.register(Conv2DTranspose);var SeparableConv=function(e){function t(t,n){var r=e.call(this,t,n)||this;if(r.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",r.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",r.depthwiseKernel=null,r.pointwiseKernel=null,null==n.filters)throw new ValueError("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(null!=n.kernelInitializer||null!=n.kernelRegularizer||null!=n.kernelConstraint)throw new ValueError("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(null!=n.padding&&"same"!==n.padding&&"valid"!==n.padding)throw new ValueError("SeparableConv"+r.rank+"D supports only padding modes: 'same' and 'valid', but received "+JSON.stringify(n.padding));return r.depthMultiplier=null==n.depthMultiplier?1:n.depthMultiplier,r.depthwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_DEPTHWISE_INITIALIZER),r.depthwiseRegularizer=getRegularizer(n.depthwiseRegularizer),r.depthwiseConstraint=getConstraint(n.depthwiseConstraint),r.pointwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_POINTWISE_INITIALIZER),r.pointwiseRegularizer=getRegularizer(n.pointwiseRegularizer),r.pointwiseConstraint=getConstraint(n.pointwiseConstraint),r}return __extends(t,e),t.prototype.build=function(e){if((e=getExactlyOneShape(e)).length1)throw new ValueError("Can not merge tensors with different batch sizes. Got tensors with shapes: "+JSON.stringify(e)+".");for(var i=null==e[0]?null:e[0].slice(1),a=1;a1){var y=range(1,s).concat([0]);t.push(transpose(h,y)),u=!0}else t.push(h)}var v=n.mergeFunction(t),b=v.rank;if(u)if(null==b){var z=v.shape;f=[g=z[z.length-1]].concat(z.slice(0,z.length-1));v=transpose(v.reshape([-1,g]),[1,0]).reshape(f)}else if(b>1){y=[b-1].concat(range(0,b-1));v=transpose(v,y)}return v}return n.mergeFunction(e)})},t.prototype.computeOutputShape=function(e){var t;t=null==(e=e)[0]?null:e[0].slice(1);for(var n=1;n1)throw new ValueError("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}},t.prototype.mergeFunction=function(e){var t=this;return tidy(function(){return concatenate(e,t.axis)})},t.prototype.computeOutputShape=function(e){if(!Array.isArray(e)||!Array.isArray(e[0]))throw new ValueError("A `Concatenate` layer should be called on a list of inputs.");for(var t=e,n=t[0].slice(),r=this.axis<0?n.length+this.axis:this.axis,i=0,a=t.slice(1);i=0?this.axis:this.axis+e.length,n=e[t];if(null==n)throw new ValueError("Axis "+t+" of input tensor should have a defined dimension but the layer received an input with shape "+JSON.stringify(e)+".");this.inputSpec=[new InputSpec({ndim:e.length,axes:(r={},r[t]=n,r)})];var r,i=[n];this.scale&&(this.gamma=this.addWeight("gamma",i,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",i,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",i,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",i,null,this.movingVarianceInitializer,null,!1),this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var r=null!=t.training&&t.training,i=getExactlyOneTensor(e),a=i.shape,o=a.length,s=range(0,o),l=n.axis>=0?n.axis:n.axis+o;s.splice(l,1);var u=pyListRepeat(1,o);u[l]=a[l];var c=s.slice();c.sort();var p=!util.arraysEqual(c,range(0,o).slice(0,o-1));if(!r)return function(){if(p){var e=n.movingMean.read().reshape(u),t=n.movingVariance.read().reshape(u),r=n.center?n.beta.read().reshape(u):null,a=n.scale?n.gamma.read().reshape(u):null;return batchNormalization(i,e,t,r,a,n.epsilon)}return batchNormalization(i,n.movingMean.read(),n.movingVariance.read(),null==n.beta?null:n.beta.read(),null==n.gamma?null:n.gamma.read(),n.epsilon)}();var h=normalizeBatchInTraining(i,n.gamma.read(),n.beta.read(),s,n.epsilon),d=h[0],g=h[1],f=h[2],m=arrayProd(s.map(function(e){return i.shape[e]})),y=f.mul(getScalar(m/(m-(1+n.epsilon))));return function(){n.stepCount++;var e=movingAverage(n.movingMean.read(),g,n.momentum,n.stepCount);n.movingMean.write(e);var t=movingAverage(n.movingVariance.read(),y,n.momentum,n.stepCount);n.movingVariance.write(t)}(),d})},t.prototype.getConfig=function(){var t={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:serializeInitializer(this.betaInitializer),gammaInitializer:serializeInitializer(this.gammaInitializer),movingMeanInitializer:serializeInitializer(this.movingMeanInitializer),movingVarianceInitializer:serializeInitializer(this.movingVarianceInitializer),betaRegularizer:serializeRegularizer(this.betaRegularizer),gammaRegularizer:serializeRegularizer(this.gammaRegularizer),betaConstraint:serializeConstraint(this.betaConstraint),gammaConstraint:serializeConstraint(this.gammaConstraint)},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className="BatchNormalization",t}(Layer);function spatial2dPadding(e,t,n){return tidy(function(){if(4!==e.rank)throw new ValueError("temporalPadding expects input tensor to be 4-D, but received a "+e.rank+"-D tensor.");if(null==t&&(t=[[1,1],[1,1]]),2!==t.length||2!==t[0].length||2!==t[1].length)throw new ValueError("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(null==n&&(n=imageDataFormat()),"channelsLast"!==n&&"channelsFirst"!==n)throw new ValueError("Unknown data format: "+n+". Supported data formats are 'channelsLast' and 'channelsFirst.");var r;return r="channelsFirst"===n?[[0,0],[0,0],t[0],t[1]]:[[0,0],t[0],t[1],[0,0]],pad(e,r)})}serialization.SerializationMap.register(BatchNormalization);var ZeroPadding2D=function(e){function t(t){var n=this;if(null==t&&(t={}),(n=e.call(this,t)||this).dataFormat=null==t.dataFormat?imageDataFormat():t.dataFormat,null==t.padding)n.padding=[[1,1],[1,1]];else if("number"==typeof t.padding)n.padding=[[t.padding,t.padding],[t.padding,t.padding]];else{if(t.padding=t.padding,2!==t.padding.length)throw new ValueError("ZeroPadding2D expects padding to be a length-2 array, but received a length-"+t.padding.length+" array.");var r=void 0,i=void 0;if("number"==typeof t.padding[0])r=[t.padding[0],t.padding[0]],i=[t.padding[1],t.padding[1]];else{if(t.padding=t.padding,2!==t.padding[0].length)throw new ValueError("ZeroPadding2D expects height padding to be a length-2 array, but received a length-"+t.padding[0].length+" array.");if(r=t.padding[0],2!==t.padding[1].length)throw new ValueError("ZeroPadding2D expects width padding to be a length-2 array, but received a length-"+t.padding[1].length+" array.");i=t.padding[1]}n.padding=[r,i]}return n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t,n;return e=getExactlyOneShape(e),"channelsFirst"===this.dataFormat?(t=null!=e[2]&&e[2]>=0?e[2]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[3]&&e[3]>=0?e[3]+this.padding[1][0]+this.padding[1][1]:null,[e[0],e[1],t,n]):(t=null!=e[1]&&e[1]>=0?e[1]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[2]&&e[2]>=0?e[2]+this.padding[1][0]+this.padding[1][1]:null,[e[0],t,n,e[3]])},t.prototype.call=function(e,t){var n=this;return tidy(function(){return spatial2dPadding(getExactlyOneTensor(e),n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={padding:this.padding,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className="ZeroPadding2D",t}(Layer);function pool2d(e,t,n,r,i,a){return tidy(function(){var o;checkDataFormat(i),checkPoolMode(a),checkPaddingMode(r),null==n&&(n=[1,1]),null==r&&(r="valid"),null==i&&(i=imageDataFormat()),null==a&&(a="max"),e=preprocessConv2DInput(e,i);var s="same"===r?"same":"valid";return o="max"===a?maxPool(e,t,n,s):avgPool(e,t,n,s),"channelsFirst"===i&&(o=transpose(o,[0,3,1,2])),o})}serialization.SerializationMap.register(ZeroPadding2D);var Pooling1D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=2),n=e.call(this,t)||this,"number"==typeof t.poolSize)n.poolSize=[t.poolSize];else{if(!Array.isArray(t.poolSize)||1!==t.poolSize.length||"number"!=typeof t.poolSize[0])throw new ValueError("poolSize for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(t.poolSize));n.poolSize=t.poolSize}if(null==t.strides)n.strides=n.poolSize;else if("number"==typeof t.strides)n.strides=[t.strides];else{if(!Array.isArray(t.strides)||1!==t.strides.length||"number"!=typeof t.strides[0])throw new ValueError("strides for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(t.strides));n.strides=t.strides}return n.padding=null==t.padding?"valid":t.padding,checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t=convOutputLength((e=getExactlyOneShape(e))[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){n.invokeCallHook(e,t),e=expandDims(getExactlyOneTensor(e),2);var r=n.poolingFunction(getExactlyOneTensor(e),[n.poolSize[0],1],[n.strides[0],1],n.padding,"channelsLast");return squeeze(r,[2])})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,"max")},t.className="MaxPooling1D",t}(Pooling1D);serialization.SerializationMap.register(MaxPooling1D);var AveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,"avg")},t.className="AveragePooling1D",t}(Pooling1D);serialization.SerializationMap.register(AveragePooling1D);var Pooling2D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=[2,2]),(n=e.call(this,t)||this).poolSize=Array.isArray(t.poolSize)?t.poolSize:[t.poolSize,t.poolSize],null==t.strides)n.strides=n.poolSize;else if(Array.isArray(t.strides)){if(2!==t.strides.length)throw new ValueError("If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length "+t.strides.length+".");n.strides=t.strides}else n.strides=[t.strides,t.strides];return n.padding=null==t.padding?"valid":t.padding,n.dataFormat=null==t.dataFormat?"channelsLast":t.dataFormat,checkDataFormat(n.dataFormat),checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){e=getExactlyOneShape(e);var t="channelsFirst"===this.dataFormat?e[2]:e[1],n="channelsFirst"===this.dataFormat?e[3]:e[2];return t=convOutputLength(t,this.poolSize[0],this.padding,this.strides[0]),n=convOutputLength(n,this.poolSize[1],this.padding,this.strides[1]),"channelsFirst"===this.dataFormat?[e[0],e[1],t,n]:[e[0],t,n,e[3]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){return n.invokeCallHook(e,t),n.poolingFunction(getExactlyOneTensor(e),n.poolSize,n.strides,n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,"max")},t.className="MaxPooling2D",t}(Pooling2D);serialization.SerializationMap.register(MaxPooling2D);var AveragePooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,"avg")},t.className="AveragePooling2D",t}(Pooling2D);serialization.SerializationMap.register(AveragePooling2D);var GlobalPooling1D=function(e){function t(t){var n=e.call(this,t)||this;return n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return[e[0],e[2]]},t.prototype.call=function(e,t){throw new NotImplementedError},t}(Layer),GlobalAveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return mean(t,1)})},t.className="GlobalAveragePooling1D",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalAveragePooling1D);var GlobalMaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return max(t,1)})},t.className="GlobalMaxPooling1D",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalMaxPooling1D);var GlobalPooling2D=function(e){function t(t){var n=e.call(this,t)||this;return n.dataFormat=null==t.dataFormat?"channelsLast":t.dataFormat,checkDataFormat(n.dataFormat),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return e=e,"channelsLast"===this.dataFormat?[e[0],e[3]]:[e[0],e[1]]},t.prototype.call=function(e,t){throw new NotImplementedError},t.prototype.getConfig=function(){var t={dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),GlobalAveragePooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return"channelsLast"===n.dataFormat?mean(t,[1,2]):mean(t,[2,3])})},t.className="GlobalAveragePooling2D",t}(GlobalPooling2D);serialization.SerializationMap.register(GlobalAveragePooling2D);var GlobalMaxPooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return"channelsLast"===n.dataFormat?max(t,[1,2]):max(t,[2,3])})},t.className="GlobalMaxPooling2D",t}(GlobalPooling2D);function standardizeArgs(e,t,n,r){if(Array.isArray(e)){if(null!=t||null!=n)throw new ValueError("When inputs is an array, neither initialState or constants should be provided");null!=r&&(n=e.slice(e.length-r,e.length),e=e.slice(0,e.length-r)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function i(e){return null==e||Array.isArray(e)?e:[e]}return{inputs:e,initialState:t=i(t),constants:n=i(n)}}function rnn(e,t,n,r,i,a,o,s){void 0===r&&(r=!1),void 0===o&&(o=!1);var l=t.shape.length;if(l<3)throw new ValueError("Input should be at least 3D, but is "+l+"D.");var u,c,p=[1,0].concat(range(2,l));if(t=transpose(t,p),null!=i)throw new NotImplementedError("The rnn() function of the deeplearn.js backend does not support masking yet.");if(null!=a)throw new NotImplementedError("The rnn() functoin of the deeplearn.js backend does not support constants yet.");o&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),r&&(t=reverse(t,0));for(var h=n,d=t.shape[0],g=0;g1?tile$1(n,[1,e]):n}):t.cell.stateSize>1?[tile$1(n,[1,t.cell.stateSize])]:[n]})},Object.defineProperty(t.prototype,"trainableWeights",{get:function(){return this.trainable?this.cell.trainableWeights:[]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights},enumerable:!0,configurable:!0}),t.prototype.getConfig=function(){var t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};null!=this.numConstants&&(t.numConstants=this.numConstants);var n=this.cell.getConfig();t.cell={className:this.cell.getClassName(),config:n};var r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t.className="RNN",t}(Layer);serialization.SerializationMap.register(RNN);var RNNCell=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t}(Layer),SimpleRNNCell=function(e){function t(t){var n=e.call(this,t)||this;return n.DEFAULT_ACTIVATION="tanh",n.DEFAULT_KERNEL_INITIALIZER="glorotNormal",n.DEFAULT_RECURRENT_INITIALIZER="orthogonal",n.DEFAULT_BIAS_INITIALIZER="zeros",n.units=t.units,n.activation=getActivation(null==t.activation?n.DEFAULT_ACTIVATION:t.activation),n.useBias=null==t.useBias||t.useBias,n.kernelInitializer=getInitializer(t.kernelInitializer||n.DEFAULT_KERNEL_INITIALIZER),n.recurrentInitializer=getInitializer(t.recurrentInitializer||n.DEFAULT_RECURRENT_INITIALIZER),n.biasInitializer=getInitializer(t.biasInitializer||n.DEFAULT_BIAS_INITIALIZER),n.kernelRegularizer=getRegularizer(t.kernelRegularizer),n.recurrentRegularizer=getRegularizer(t.recurrentRegularizer),n.biasRegularizer=getRegularizer(t.biasRegularizer),n.kernelConstraint=getConstraint(t.kernelConstraint),n.recurrentConstraint=getConstraint(t.recurrentConstraint),n.biasConstraint=getConstraint(t.biasConstraint),n.dropout=min$1([1,max$1([0,null==t.dropout?0:t.dropout])]),n.recurrentDropout=min$1([1,max$1([0,null==t.recurrentDropout?0:t.recurrentDropout])]),n.stateSize=n.units,n.dropoutMask=null,n.recurrentDropoutMask=null,n}return __extends(t,e),t.prototype.build=function(e){e=getExactlyOneShape(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){if(2!==(e=e).length)throw new ValueError("SimpleRNNCell expects 2 input Tensors, got "+e.length+".");var r=e[1];e=e[0];var i,a=null!=t.training&&t.training;01){for(var a=[],o=0;o= 3D, but received input shape "+JSON.stringify(t));this.inputSpec=[{shape:t}];var n=[t[0]].concat(t.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),e.prototype.build.call(this,t)},t.prototype.computeOutputShape=function(e){var t=[(e=getExactlyOneShape(e))[0]].concat(e.slice(2)),n=this.layer.computeOutputShape(t),r=e[1];return[n[0],r].concat(n.slice(1))},t.prototype.call=function(e,t){var n=this;return tidy(function(){return rnn(function(e,r){return[n.layer.call(e,t),[]]},e=getExactlyOneTensor(e),[],!1,null,null,!1,e.shape[1])[1]})},t.className="TimeDistributed",t}(Wrapper);serialization.SerializationMap.register(TimeDistributed);var VALID_BIDIRECTIONAL_MERGE_MODES=["sum","mul","concat","ave"];function checkBidirectionalMergeMode(e){checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES,"BidirectionalMergeMode",e)}var Bidirectional=function(e){function t(t){var n=e.call(this,t)||this,r=t.layer.getConfig();if(n.forwardLayer=deserialize({className:t.layer.getClassName(),config:r}),r.goBackwards=!0!==r.goBackwards,n.backwardLayer=deserialize({className:t.layer.getClassName(),config:r}),n.forwardLayer.name="forward_"+n.forwardLayer.name,n.backwardLayer.name="backward_"+n.backwardLayer.name,checkBidirectionalMergeMode(t.mergeMode),n.mergeMode=t.mergeMode,t.weights)throw new NotImplementedError("weights support is not implemented for Bidirectional layer yet.");return n._stateful=t.layer.stateful,n.returnSequences=t.layer.returnSequences,n.returnState=t.layer.returnState,n.supportsMasking=!0,n._trainable=!0,n.inputSpec=t.layer.inputSpec,n.numConstants=null,n}return __extends(t,e),Object.defineProperty(t.prototype,"trainable",{get:function(){return this._trainable},set:function(e){this._trainable=e,null!=this.forwardLayer&&(this.forwardLayer.trainable=e),null!=this.backwardLayer&&(this.backwardLayer.trainable=e)},enumerable:!0,configurable:!0}),t.prototype.getWeights=function(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())},t.prototype.setWeights=function(e){var t=e.length,n=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,n)),this.backwardLayer.setWeights(e.slice(n))},t.prototype.computeOutputShape=function(e){var t,n,r,i=this.forwardLayer.computeOutputShape(e);return Array.isArray(i)&&Array.isArray(i[0])||(i=[i]),i=i,this.returnState?(r=i.slice(1),t=i[0]):t=i[0],t=t,"concat"===this.mergeMode?(t[t.length-1]*=2,n=[t]):n=null==this.mergeMode?[t,t.slice()]:[t],this.returnState?null==this.mergeMode?n.concat(r).concat(r.slice()):[t].concat(r).concat(r.slice()):singletonOrArray(n)},t.prototype.apply=function(t,n){var r=null==n?null:n.initialState,i=null==n?null:n.constants;null==n&&(n={});var a=standardizeArgs(t,r,i,this.numConstants);if(t=a.inputs,r=a.initialState,i=a.constants,Array.isArray(t)&&(r=t.slice(1),t=t[0]),(null==r||0===r.length)&&null==i)return e.prototype.apply.call(this,t,n);var o=[],s=[];if(null!=r){var l=r.length;if(l%2>0)throw new ValueError("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");n.initialState=r,o.push.apply(o,r);var u=r.map(function(e){return new InputSpec({shape:e.shape})});this.forwardLayer.stateSpec=u.slice(0,l/2),this.backwardLayer.stateSpec=u.slice(l/2),s.push.apply(s,u)}if(null!=i)throw new NotImplementedError("Support for constants in Bidirectional layers is not implemented yet.");for(var c=o[0]instanceof SymbolicTensor,p=0,h=o;p(array: T[], refernce: T) {\n let counter = 0;\n for (const item of array) {\n if (item === refernce) {\n counter++;\n }\n }\n return counter;\n}\n\n/**\n * If an array is of length 1, just return the first element. Otherwise, return\n * the full array.\n * @param tensors\n */\nexport function singletonOrArray(xs: T[]): T|T[] {\n if (xs.length === 1) {\n return xs[0];\n }\n return xs;\n}\n\n/**\n * Normalizes a list/tensor into a list.\n *\n * If a tensor is passed, we return\n * a list of size 1 containing the tensor.\n *\n * @param x target object to be normalized.\n */\n// tslint:disable-next-line:no-any\nexport function toList(x: any): any[] {\n if (Array.isArray(x)) {\n return x;\n }\n return [x];\n}\n\n/**\n * Generate a UID for a list\n */\n// tslint:disable-next-line:no-any\nexport function objectListUid(objs: any|any[]): string {\n const objectList = toList(objs);\n let retVal = '';\n for (const obj of objectList) {\n if (obj.id == null) {\n throw new ValueError(\n `Object ${obj} passed to objectListUid without an id`);\n }\n if (retVal !== '') {\n retVal = retVal + ', ';\n }\n retVal = retVal + Math.abs(obj.id);\n }\n return retVal;\n}\n/**\n * Converts string to snake-case.\n * @param name\n */\nexport function toSnakeCase(name: string): string {\n const intermediate = name.replace(/(.)([A-Z][a-z0-9]+)/g, '$1_$2');\n const insecure =\n intermediate.replace(/([a-z])([A-Z])/g, '$1_$2').toLowerCase();\n /*\n If the class is private the name starts with \"_\" which is not secure\n for creating scopes. We prefix the name with \"private\" in this case.\n */\n if (insecure[0] !== '_') {\n return insecure;\n }\n return 'private' + insecure;\n}\n\nexport function toCamelCase(identifier: string): string {\n // quick return for empty string or single character strings\n if (identifier.length <= 1) {\n return identifier;\n }\n // Check for the underscore indicating snake_case\n if (identifier.indexOf('_') === -1) {\n return identifier;\n }\n return identifier.replace(/[_]+(\\w|$)/g, (m, p1) => p1.toUpperCase());\n}\n\n// tslint:disable-next-line:no-any\nlet _GLOBAL_CUSTOM_OBJECTS = {} as {[objName: string]: any};\n\nexport function serializeKerasObject(instance: serialization.Serializable):\n serialization.ConfigDictValue {\n if (instance === null || instance === undefined) {\n return null;\n }\n return {className: instance.getClassName(), config: instance.getConfig()};\n}\n\n/**\n * Deserialize a saved Keras Object\n * @param identifier either a string ID or a saved Keras dictionary\n * @param moduleObjects a list of Python class names to object constructors\n * @param customObjects a list of Python class names to object constructors\n * @param printableModuleName debug text for the object being reconstituted\n * @returns a TensorFlow.js Layers object\n */\n// tslint:disable:no-any\nexport function deserializeKerasObject(\n identifier: string|serialization.ConfigDict,\n moduleObjects = {} as {[objName: string]: any},\n customObjects = {} as {[objName: string]: any},\n printableModuleName = 'object'): any {\n // tslint:enable\n if (typeof identifier === 'string') {\n const functionName = identifier;\n let fn;\n if (functionName in customObjects) {\n fn = customObjects[functionName];\n } else if (functionName in _GLOBAL_CUSTOM_OBJECTS) {\n fn = _GLOBAL_CUSTOM_OBJECTS[functionName];\n } else {\n fn = moduleObjects[functionName];\n if (fn == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${identifier}`);\n }\n }\n return fn;\n } else {\n // In this case we are dealing with a Keras config dictionary.\n const config = identifier;\n if (config.className == null || config.config == null) {\n throw new ValueError(\n `${printableModuleName}: Improper config format: ` +\n `${JSON.stringify(config)}.\\n` +\n `'className' and 'config' must set.`);\n }\n const className = config.className as string;\n let cls, fromConfig;\n if (className in customObjects) {\n [cls, fromConfig] = customObjects.get(className);\n } else if (className in _GLOBAL_CUSTOM_OBJECTS) {\n [cls, fromConfig] = _GLOBAL_CUSTOM_OBJECTS.className;\n } else if (className in moduleObjects) {\n [cls, fromConfig] = moduleObjects[className];\n }\n if (cls == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${className}`);\n }\n if (fromConfig != null) {\n // Porting notes: Instead of checking to see whether fromConfig accepts\n // customObjects, we create a customObjects dictionary and tack it on to\n // config.config as config.config.customObjects. Objects can use it, if\n // they want.\n\n // tslint:disable-next-line:no-any\n const customObjectsCombined = {} as {[objName: string]: any};\n for (const key of Object.keys(_GLOBAL_CUSTOM_OBJECTS)) {\n customObjectsCombined[key] = _GLOBAL_CUSTOM_OBJECTS[key];\n }\n for (const key of Object.keys(customObjects)) {\n customObjectsCombined[key] = customObjects[key];\n }\n // Add the customObjects to config\n const nestedConfig = config.config as serialization.ConfigDict;\n nestedConfig.customObjects = customObjectsCombined;\n\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n const returnObj = fromConfig(cls, config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n\n return returnObj;\n } else {\n // Then `cls` may be a function returning a class.\n // In this case by convention `config` holds\n // the kwargs of the function.\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n // In python this is **config['config'], for tfjs-layers we require\n // classes that use this fall-through construction method to take\n // a config interface that mimics the expansion of named parameters.\n const returnObj = new cls(config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n return returnObj;\n }\n }\n}\n\n/**\n * Compares two numbers for sorting.\n * @param a\n * @param b\n */\nexport function numberCompare(a: number, b: number) {\n return (a < b) ? -1 : ((a > b) ? 1 : 0);\n}\n\n/**\n * Comparison of two numbers for reverse sorting.\n * @param a\n * @param b\n */\nexport function reverseNumberCompare(a: number, b: number) {\n return -1 * numberCompare(a, b);\n}\n\n/**\n * Convert a string into the corresponding DType.\n * @param dtype\n * @returns An instance of DType.\n */\nexport function stringToDType(dtype: string): DataType {\n switch (dtype) {\n case 'float32':\n return 'float32';\n default:\n throw new ValueError(`Invalid dtype: ${dtype}`);\n }\n}\n\n/**\n * Test the element-by-element equality of two Arrays of strings.\n * @param xs First array of strings.\n * @param ys Second array of strings.\n * @returns Wether the two arrays are all equal, element by element.\n */\nexport function stringsEqual(xs: string[], ys: string[]): boolean {\n if (xs == null || ys == null) {\n return xs === ys;\n }\n if (xs.length !== ys.length) {\n return false;\n }\n for (let i = 0; i < xs.length; ++i) {\n if (xs[i] !== ys[i]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Get the unique elements of an array.\n * @param xs Array.\n * @returns An Array consisting of the unique elements in `xs`.\n */\nexport function unique(xs: T[]): T[] {\n if (xs == null) {\n return xs;\n }\n const out: T[] = [];\n // TODO(cais): Maybe improve performance by sorting.\n for (const x of xs) {\n if (out.indexOf(x) === -1) {\n out.push(x);\n }\n }\n return out;\n}\n\n/**\n * Determine if an Object is empty (i.e., does not have own properties).\n * @param obj Object\n * @returns Whether the Object is empty.\n * @throws ValueError: If object is `null` or `undefined`.\n */\nexport function isObjectEmpty(obj: {}): boolean {\n if (obj == null) {\n throw new ValueError(`Invalid value in obj: ${JSON.stringify(obj)}`);\n }\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Helper function used to build type union/enum run-time checkers.\n * @param values The list of allowed values.\n * @param label A string name for the type\n * @param value The value to test.\n * @throws ValueError: If the value is not in values nor `undefined`/`null`.\n */\nexport function checkStringTypeUnionValue(\n values: string[], label: string, value: string): void {\n if (value == null) {\n return;\n }\n if (values.indexOf(value) < 0) {\n throw new ValueError(`${value} is not a valid ${label}. Valid values are ${\n values} or null/undefined.`);\n }\n}\n\n/**\n * Helper function for verifying the types of inputs.\n *\n * Ensures that the elements of `x` are all of type `expectedType`.\n * Also verifies that the length of `x` is within bounds.\n *\n * @param x Object to test.\n * @param expectedType The string expected type of all of the elements in the\n * Array.\n * @param minLength Return false if x.length is less than this.\n * @param maxLength Return false if x.length is greater than this.\n * @returns true if and only if `x` is an `Array` with\n * length >= `minLength` and <= `maxLength`.\n */\n// tslint:disable:no-any\nexport function checkArrayTypeAndLength(\n x: any, expectedType: string, minLength = 0,\n maxLength = Infinity): boolean {\n assert(minLength >= 0);\n assert(maxLength >= minLength);\n return (\n Array.isArray(x) && x.length >= minLength && x.length <= maxLength &&\n x.every(e => typeof e === expectedType));\n}\n// tslint:enable:no-any\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/contraints.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Helper function used by many of the Constraints to find the L2Norms.\n */\nfunction calcL2Norms(w: Tensor, axis: number): Tensor {\n return tidy(() => tfc.sqrt(tfc.sum(tfc.mulStrict(w, w), axis, true)));\n}\n\n/**\n * Base class for functions that impose constraints on weight values\n */\n/**\n * @doc {\n * heading: 'Constraints',\n * subheading: 'Classes',\n * namespace: 'constraints'\n * }\n */\nexport abstract class Constraint extends serialization.Serializable {\n /* Porting note: was __call__, apply chosen to match other similar choices */\n abstract apply(w: Tensor): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\nexport interface MaxNormConfig {\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * MaxNorm weight constraint.\n *\n * Constrains the weights incident to each hidden unit\n * to have a norm less than or equal to a desired value.\n *\n * References\n * - [Dropout: A Simple Way to Prevent Neural Networks from Overfitting\n * Srivastava, Hinton, et al.\n * 2014](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf)\n */\nexport class MaxNorm extends Constraint {\n static readonly className = 'MaxNorm';\n private maxValue: number;\n private axis: number;\n private readonly defaultMaxValue = 2;\n private readonly defaultAxis = 0;\n\n constructor(config: MaxNormConfig) {\n super();\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.clipByValue(norms, 0, this.maxValue);\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {maxValue: this.maxValue, axis: this.axis};\n }\n}\nserialization.SerializationMap.register(MaxNorm);\n\nexport interface UnitNormConfig {\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * [rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * Constrains the weights incident to each hidden unit to have unit norm.\n */\nexport class UnitNorm extends Constraint {\n static readonly className = 'UnitNorm';\n private axis: number;\n private readonly defaultAxis = 0;\n constructor(config: UnitNormConfig) {\n super();\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(\n () => tfc.div(\n w, tfc.add(getScalar(epsilon()), calcL2Norms(w, this.axis))));\n }\n\n getConfig(): serialization.ConfigDict {\n return {axis: this.axis};\n }\n}\nserialization.SerializationMap.register(UnitNorm);\n\n/**\n * Constains the weight to be non-negative.\n */\nexport class NonNeg extends Constraint {\n static readonly className = 'NonNeg';\n\n apply(w: Tensor): Tensor {\n return tfc.relu(w);\n }\n}\nserialization.SerializationMap.register(NonNeg);\n\nexport interface MinMaxNormConfig {\n /**\n * Minimum norm for incoming weights\n */\n minValue?: number;\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n /**\n * Rate for enforcing the constraint: weights will be rescaled to yield:\n * `(1 - rate) * norm + rate * norm.clip(minValue, maxValue)`.\n * Effectively, this means that rate=1.0 stands for strict\n * enforcement of the constraint, while rate<1.0 means that\n * weights will be rescaled at each step to slowly move\n * towards a value inside the desired interval.\n */\n rate?: number;\n}\n\nexport class MinMaxNorm extends Constraint {\n static readonly className = 'MinMaxNorm';\n private minValue: number;\n private maxValue: number;\n private rate: number;\n private axis: number;\n private readonly defaultMinValue = 0.0;\n private readonly defaultMaxValue = 1.0;\n private readonly defaultRate = 1.0;\n private readonly defaultAxis = 0;\n\n constructor(config: MinMaxNormConfig) {\n super();\n this.minValue =\n config.minValue != null ? config.minValue : this.defaultMinValue;\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.rate = config.rate != null ? config.rate : this.defaultRate;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.add(\n tfc.mul(\n getScalar(this.rate),\n tfc.clipByValue(norms, this.minValue, this.maxValue)),\n tfc.mul(getScalar(1.0 - this.rate), norms));\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n minValue: this.minValue,\n maxValue: this.maxValue,\n rate: this.rate,\n axis: this.axis\n };\n }\n}\nserialization.SerializationMap.register(MinMaxNorm);\n\n/** @docinline */\nexport type ConstraintIdentifier =\n 'maxNorm'|'minMaxNorm'|'nonNeg'|'unitNorm'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in ConstraintIdentifier]: string} = {\n 'maxNorm': 'MaxNorm',\n 'minMaxNorm': 'MinMaxNorm',\n 'nonNeg': 'NonNeg',\n 'unitNorm': 'UnitNorm'\n };\n\nexport function serializeConstraint(constraint: Constraint):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeConstraint(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Constraint {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'constraint');\n}\n\nexport function getConstraint(identifier: ConstraintIdentifier|\n serialization.ConfigDict|Constraint): Constraint {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeConstraint(config);\n } else if (identifier instanceof Constraint) {\n return identifier;\n } else {\n return deserializeConstraint(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constraint, MaxNorm, MaxNormConfig, MinMaxNorm, MinMaxNormConfig, NonNeg, UnitNorm, UnitNormConfig} from './constraints';\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MaxNorm',\n * configParamIndices: [0]\n * }\n */\nexport function maxNorm(config: MaxNormConfig): Constraint {\n return new MaxNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'UnitNorm',\n * configParamIndices: [0]\n * }\n */\nexport function unitNorm(config: UnitNormConfig): Constraint {\n return new UnitNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'NonNeg'\n * }\n */\nexport function nonNeg(): Constraint {\n return new NonNeg();\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MinMaxNormConfig',\n * configParamIndices: [0]\n * }\n */\nexport function minMaxNorm(config: MinMaxNormConfig): Constraint {\n return new MinMaxNorm(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Common functions for TensorFlow.js Layers.\n */\nimport {checkStringTypeUnionValue} from './utils/generic_utils';\n// A map from the requested scoped name of a Tensor to the number of Tensors\n// wanting that name so far. This allows enforcing name uniqueness by appending\n// an incrementing index, e.g. scope/name, scope/name_1, scope/name_2, etc.\nconst nameMap: Map = new Map();\n\n// TODO(cais): Perhaps move the enums to a more suitable place, e.g.,\n// constants.ts.\n/** @docinline */\nexport type DataFormat = 'channelsFirst'|'channelsLast';\nexport const VALID_DATA_FORMAT_VALUES = ['channelsFirst', 'channelsLast'];\nexport function checkDataFormat(value?: string): void {\n checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES, 'DataFormat', value);\n}\n\n/** @docinline */\nexport type PaddingMode = 'valid'|'same'|'causal';\nexport const VALID_PADDING_MODE_VALUES = ['valid', 'same', 'causal'];\nexport function checkPaddingMode(value?: string): void {\n checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES, 'PaddingMode', value);\n}\n\n/** @docinline */\nexport type PoolMode = 'max'|'avg';\nexport const VALID_POOL_MODE_VALUES = ['max', 'avg'];\nexport function checkPoolMode(value?: string): void {\n checkStringTypeUnionValue(VALID_POOL_MODE_VALUES, 'PoolMode', value);\n}\n\nconst _nameScopeStack: string[] = [];\nconst _nameScopeDivider = '/';\n\n/**\n * Enter namescope, which can be nested.\n */\nexport function nameScope(name: string, fn: () => T): T {\n _nameScopeStack.push(name);\n try {\n const val: T = fn();\n _nameScopeStack.pop();\n return val;\n } catch (e) {\n _nameScopeStack.pop();\n throw e;\n }\n}\n\n/**\n * Get the current namescope as a flat, concatenated string.\n */\nfunction currentNameScopePrefix(): string {\n if (_nameScopeStack.length === 0) {\n return '';\n } else {\n return _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider;\n }\n}\n\n/**\n * Get the name a Tensor (or Variable) would have if not uniqueified.\n * @param tensorName\n * @return Scoped name string.\n */\nexport function getScopedTensorName(tensorName: string): string {\n if (!isValidTensorName(tensorName)) {\n throw new Error('Not a valid tensor name: \\'' + tensorName + '\\'');\n }\n return currentNameScopePrefix() + tensorName;\n}\n\n/**\n * Get unique names for Tensors and Variables.\n * @param scopedName The fully-qualified name of the Tensor, i.e. as produced by\n * `getScopedTensorName()`.\n * @return A unique version of the given fully scoped name.\n * If this is the first time that the scoped name is seen in this session,\n * then the given `scopedName` is returned unaltered. If the same name is\n * seen again (producing a collision), an incrementing suffix is added to the\n * end of the name, so it takes the form 'scope/name_1', 'scope/name_2', etc.\n */\nexport function getUniqueTensorName(scopedName: string): string {\n if (!isValidTensorName(scopedName)) {\n throw new Error('Not a valid tensor name: \\'' + scopedName + '\\'');\n }\n if (!nameMap.has(scopedName)) {\n nameMap.set(scopedName, 0);\n }\n const index = nameMap.get(scopedName);\n nameMap.set(scopedName, nameMap.get(scopedName) + 1);\n\n if (index > 0) {\n const result = scopedName + '_' + index;\n // Mark the composed name as used in case someone wants\n // to call getUniqueTensorName(\"name_1\").\n nameMap.set(result, 1);\n return result;\n } else {\n return scopedName;\n }\n}\n\nconst tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\\._\\/]*$/);\n\n/**\n * Determine whether a string is a valid tensor name.\n * @param name\n * @returns A Boolean indicating whether `name` is a valid tensor name.\n */\nexport function isValidTensorName(name: string): boolean {\n return name.match(tensorNameRegex) ? true : false;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Math utility functions.\n *\n * This file contains some frequently used math function that operates on\n * number[] or Float32Array and return a number. Many of these functions are\n * not-so-thick wrappers around TF.js Core functions. But they offer the\n * convenience of\n * 1) not having to convert the inputs into Tensors,\n * 2) not having to convert the returned Tensors to numbers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor1D, tensor1d} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\n\nexport type ArrayTypes = Uint8Array|Int32Array|Float32Array;\n\n/**\n * Determine if a number is an integer.\n */\nexport function isInteger(x: number): boolean {\n return x === parseInt(x.toString(), 10);\n}\n\n/**\n * Calculate the product of an array of numbers.\n * @param array The array to calculate the product over.\n * @param begin Beginning index, inclusive.\n * @param end Ending index, exclusive.\n * @return The product.\n */\nexport function arrayProd(\n array: number[]|ArrayTypes, begin?: number, end?: number): number {\n if (begin == null) {\n begin = 0;\n }\n if (end == null) {\n end = array.length;\n }\n\n let prod = 1;\n for (let i = begin; i < end; ++i) {\n prod *= array[i];\n }\n return prod;\n}\n\n/**\n * A helper function transforms the two input types to an instance of Tensor1D,\n * so the return value can be fed directly into various TF.js Core functions.\n * @param array\n */\nfunction toArray1D(array: number[]|Float32Array): Tensor1D {\n array = Array.isArray(array) ? new Float32Array(array) : array;\n return tensor1d(array);\n}\n\n/**\n * Compute minimum value.\n * @param array\n * @return minimum value.\n */\nexport function min(array: number[]|Float32Array): number {\n return tfc.min(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute maximum value.\n * @param array\n * @return maximum value\n */\nexport function max(array: number[]|Float32Array): number {\n return tfc.max(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute sum of array.\n * @param array\n * @return The sum.\n */\nexport function sum(array: number[]|Float32Array): number {\n return tfc.sum(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute mean of array.\n * @param array\n * @return The mean.\n */\nexport function mean(array: number[]|Float32Array): number {\n return sum(array) / array.length;\n}\n\n/**\n * Compute variance of array.\n * @param array\n * @return The variance.\n */\nexport function variance(array: number[]|Float32Array): number {\n const demeaned = tfc.sub(toArray1D(array), scalar(mean(array)));\n const sumSquare = tfc.sum(tfc.mulStrict(demeaned, demeaned)).dataSync()[0];\n return sumSquare / array.length;\n}\n\n/**\n * Compute median of array.\n * @param array\n * @return The median value.\n */\nexport function median(array: number[]|Float32Array): number {\n const arraySorted = array.slice().sort((a, b) => a - b);\n const lowIdx = Math.floor((arraySorted.length - 1) / 2);\n const highIdx = Math.ceil((arraySorted.length - 1) / 2);\n if (lowIdx === highIdx) {\n return arraySorted[lowIdx];\n }\n return (arraySorted[lowIdx] + arraySorted[highIdx]) / 2;\n}\n\n/**\n * Generate an array of integers in [begin, end).\n * @param begin Beginning integer, inclusive.\n * @param end Ending integer, inclusive.\n * @returns Range array.\n * @throws ValueError, iff `end` < `begin`.\n */\nexport function range(begin: number, end: number): number[] {\n if (end < begin) {\n throw new ValueError(`end (${end}) < begin (${begin}) is forbidden.`);\n }\n const out: number[] = [];\n for (let i = begin; i < end; ++i) {\n out.push(i);\n }\n return out;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * deeplearn.js backend.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {onesLike as coreOnesLike, Scalar, scalar, Tensor, Tensor1D, tensor1d, Tensor2D, Tensor3D, Tensor4D, tidy, util, where, zerosLike as coreZerosLike} from '@tensorflow/tfjs-core';\n\nimport {disposeScalarCache, getScalar} from '../backend/state';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {HasShape, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\n\nimport {imageDataFormat} from './common';\n\n// tslint:enable\n\n/* Setting and getting backend from deeplearn.js. */\n\n// Default deeplearn.js backend is WebGL (GPU).\nlet backend: 'cpu'|'webgl' = 'webgl';\n\nexport function setBackend(requestedBackend: 'cpu'|'webgl') {\n tfc.setBackend(requestedBackend);\n backend = requestedBackend;\n disposeScalarCache();\n}\n\nexport function getBackend(): 'cpu'|'webgl' {\n return backend;\n}\n\n/**\n * Indicates whether the backend is operating symbolically.\n *\n * This function will be used to determine how to interpret user code. If\n * it returns true, calls to the backend construct a symbolic graph; if\n * it returns false, calls to the backend execute immediately.\n */\nexport function isBackendSymbolic(): boolean {\n return false;\n}\n\n/**\n * Get the number of elements in a Tensor.\n * @param x The Tensor.\n * @return Number of elements in `x`.\n */\nexport function countParams(x: HasShape): number {\n const shape = x.shape;\n if (shape.length > 0) {\n return shape.reduce((a: number, b: number) => a * b);\n } else {\n // Scalar.\n return 1;\n }\n}\n\n/**\n * Casts a tensor to a different dtype and returns it.\n * @param x Input tensor.\n * @param dtype String: 'float32'|'int32'|'bool'.\n * @returns Tensor of the specified `dtype`.\n */\nexport function cast(x: Tensor, dtype: 'float32'|'int32'|'bool'): Tensor {\n return x.asType(dtype);\n}\n\n/**\n * Adds a 1-sized dimension at index \"axis\".\n * @param x Input tensor.\n * @param axis Position where to add the new axis.\n * @returns Result of the dimension expansion.\n */\nexport function expandDims(x: Tensor, axis = -1): Tensor {\n const outShape = x.shape.slice();\n if (axis < 0) {\n axis = outShape.length + axis + 1;\n }\n outShape.splice(axis, 0, 1);\n return x.reshape(outShape);\n}\n\n/**\n * Repeats a 2D tensor.\n *\n * If `x` has shape `[samples, dim]` and `n` is 2, for example, the output\n * will have shape `[samples, 2, dim]`.\n *\n * @param x Input tensor.\n * @param n Integer, number of times to repeat.\n * @returns The result of the repeat operation.\n * @throws ValueError: If input tensor is not 2D.\n */\nexport function repeat(x: Tensor, n: number): Tensor {\n return tidy(() => {\n if (x.shape.length !== 2) {\n throw new ValueError(\n `repeat() expects a rank-2 tensor, but received a ` +\n `rank-${x.shape.length} tensor.`);\n }\n const y = expandDims(x, 1);\n return tile(y, [1, n, 1]);\n });\n}\n\n/**\n * Flatten an Tensor into 1D.\n * @param x Input tensor.\n * @return The result of the flattening `x`.\n */\nexport function flatten(x: Tensor): Tensor {\n const newShape = [math_utils.arrayProd(x.shape)];\n return x.reshape(newShape);\n}\n\n/**\n * Turn a nD tensor into a 2D tensor with same 0th dimension.\n * In other words, it flattens each data samples of a batch.\n *\n * @param x The tensor to flatten. The rank of this tensor is required to be 2\n * or higher.\n * @return The result of the flattening.\n */\nexport function batchFlatten(x: Tensor): Tensor {\n if (x.rank <= 1) {\n throw new ValueError(\n `batchFlatten requires a minimum rank of 2. Got rank: ${x.rank}.`);\n }\n const newShape = [x.shape[0], math_utils.arrayProd(x.shape, 1)];\n return x.reshape(newShape);\n}\n\n/**\n * Do slicing along the first axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the first axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongFirstAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [start, 0], [size, array.shape[1]]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [start, 0, 0],\n [size, array.shape[1], array.shape[2]]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [start, 0, 0, 0],\n [size, array.shape[1], array.shape[2], array.shape[3]]);\n default:\n throw new ValueError(\n `sliceAlongFirstAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the last axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the last axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongLastAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [0, start], [array.shape[0], size]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [0, 0, start],\n [array.shape[0], array.shape[1], size]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, 0, start],\n [array.shape[0], array.shape[1], array.shape[2], size]);\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the sepcified axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size of the slice along the chosen axis.\n * @param choose an axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongAxis(\n array: Tensor, start: number, size: number, axis: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 3:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice3d(\n array as Tensor3D, [0, start, 0],\n [array.shape[0], size, array.shape[2]]);\n case 3:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 4:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice4d(\n array as Tensor4D, [0, start, 0, 0],\n [array.shape[0], size, array.shape[2], array.shape[3]]);\n case 3:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, start, 0],\n [array.shape[0], array.shape[1], size, array.shape[3]]);\n case 4:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Concatenates a list of tensors alongside the specified axis.\n * @param tensors `Array` of tensors to concatenate.\n * @param axis Concatenation axis.\n * @returns The result of the concatenation.\n */\nexport function concatenate(tensors: Tensor[], axis = -1): Tensor {\n let rank: number;\n if (axis < 0) {\n rank = tensors[0].rank;\n if (rank !== 0) {\n axis = rank;\n } else {\n axis = 0;\n }\n }\n if (axis === tensors[0].rank) {\n // Porting Note: This is necessary because tfc.concat() requires axis to be\n // in the interval [-rank, rank).\n axis = -1;\n }\n // Porting Note: Sparse concat is not supported yet.\n return tfc.concat(tensors, axis);\n}\n\n/**\n * Concatenate two arrays along the first dimension.\n * @param a The 1st `Tensor` to concatenate.\n * @param b The 2nd `Tensor` to concatenate.\n * @returns Result of the concatenation.\n * @throws ValueError: If `a` is of an unsupported subtype of `Tensor`.\n */\nexport function concatAlongFirstAxis(a: Tensor, b: Tensor): Tensor {\n switch (a.rank) {\n case 1:\n return tfc.concat1d([a as Tensor1D, b as Tensor1D]);\n case 2:\n return tfc.concat2d([a as Tensor2D, b as Tensor2D], 0);\n case 3:\n return tfc.concat3d([a as Tensor3D, b as Tensor3D], 0);\n case 4:\n return tfc.concat4d([a as Tensor4D, b as Tensor4D], 0);\n default:\n throw new ValueError(\n 'concatAlongFirstAxis() received an unsupported tensor rank: ' +\n a.rank);\n }\n}\n\n/**\n * Creates a tensor by tiling `x` by `n`.\n * @param x A tensor.\n * @param n An Array of integers or a single integer. If an Array, the length\n * must be the same as the number of dimensions in `x`. If a single integer,\n * it will be treated as an Array of length 1.\n */\nexport function tile(x: Tensor, n: number|number[]): Tensor {\n if (!Array.isArray(n)) {\n n = [n];\n }\n if (x.rank !== n.length) {\n throw new ValueError(\n `The length of input n (${n.length}) does not match ` +\n `the number of dimensions in input x (${x.rank})`);\n }\n return tfc.tile(x, n);\n}\n\n/* Creation of random tensors. */\n\n\n/**\n * Get a tensor with normal distribution of values.\n *\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @return The normal tensor.\n */\nexport function randomNormal(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n return tfc.randomNormal(shape, mean, stddev, dtype, seed);\n}\n\n/* Linear Algebra */\n\n/**\n * Multiply two tensors and returns the result as a tensor.\n *\n * For 2D tensors, this is equivalent to matrix multiplication (matMul).\n * For tensors of higher ranks, it follows the Theano behavior,\n * (e.g. `(2, 3) * (4, 3, 5) -> (2, 4, 5)`).\n *\n * @param x A tensor of at least rank 2.\n * @param y A tensor of at least rank 2.\n * @return Result of the dot operation.\n */\nexport function dot(x: Tensor, y: Tensor): Tensor {\n if (y.rank !== 2) {\n throw new NotImplementedError(\n `dot support for y other than rank 2 is not yet implemented: ` +\n `y shape = ${y.shape}`);\n } else {\n if (x.rank === 2) {\n return tfc.matMul(x as Tensor2D, y as Tensor2D);\n } else if (x.rank === 3) {\n const xShape0 = x.shape[0];\n const xShape1 = x.shape[1];\n const xShape2 = x.shape[2];\n x = x.reshape([xShape0 * xShape1, xShape2]);\n return tfc.matMul(x as Tensor2D, y as Tensor2D).reshape([\n xShape0, xShape1, y.shape[1]\n ]);\n } else {\n throw new NotImplementedError(\n `dot support for x of rank ${x.rank} is not yet implemented: ` +\n `x shape = ${x.shape}`);\n }\n }\n}\n\n/**\n * Compute the sign Tensor of an input Tensor.\n *\n * Elements of the input `Tensor` that are === 0 are mapped to 0.\n * Elements of the input `Tensor` that are > 0 are mapped to 1.\n * Elements of the input `Tensor` that are < 0 are mapped to -1.\n *\n * @param x Input `Tensor`.\n * @return The sign `Tensor`.\n */\nexport function sign(x: Tensor): Tensor {\n // TODO(cais): Move to the core.\n return tidy(() => {\n const zerosLikeX = coreZerosLike(x);\n const onesLikeX = coreOnesLike(x);\n return where(\n tfc.equal(x, zerosLikeX), zerosLikeX,\n where(\n tfc.greater(x, coreZerosLike(x)), onesLikeX,\n tfc.mul(getScalar(-1), onesLikeX)));\n });\n}\n\n/**\n * Computes the one-hot representation of an integer tensor.\n * @param indices nD integer tensor of shape\n * `(batch_size, dim1, dim2, ... dim(n-1))`\n * @param numClasses Integer, number of classes to consider.\n * @returns (n + 1)D one hot representation of the input\n * with shape `(batch_size, dim1, dim2, ... dim(n-1), num_classes)`\n */\nexport function oneHot(indices: Tensor, numClasses: number): Tensor {\n return tidy(() => {\n if (indices.rank !== 1) {\n throw new Error(\n 'Only 1D one-hot tensors are supported in the ' +\n 'deeplearn backend, at present.');\n }\n indices = indices.toInt();\n return tfc.oneHot(indices as Tensor1D, numClasses).toFloat();\n });\n}\n\n/* Elementary math functions. */\n\n/**\n * Retrieves the elements of indices `indices` in the tensor `reference`.\n * @param reference A tensor.\n * @param indices An integer tensor of indices or an `Array` of integers.\n * @param axis Axis along which to perform the gather operation.\n * @returns The result of the gathering as a tensor.\n */\nexport function gather(\n reference: Tensor, indices: number[]|Tensor1D, axis?: number): Tensor {\n return tidy(() => {\n if (Array.isArray(indices)) {\n indices = tensor1d(indices, 'int32');\n } else {\n indices = indices.toInt();\n }\n return tfc.gather(reference, indices, axis);\n });\n}\n\n/**\n * Element-wise square.\n * @param x Input tensor.\n * @return element-wise x^2\n */\nexport function square(x: Tensor): Tensor {\n return tfc.mulStrict(x, x);\n}\n\n/**\n * Element-wise exponentiation.\n *\n * Porting Note: In PyKeras, `a` (the exponent) is a Python integer, which\n * takes advatnage of the backend's (e.g., TensorFlow's) automatic conversion\n * to tensor. Here we allow `a` to be either a number or a tensor.\n *\n * @param x The base tensor.\n * @param a The exponent, tensor or number. If a number, it is rounded to the\n * nearest integer and converted to a tensor.\n * @returns A tensor of the same shape as `x`.\n */\nexport function pow(x: Tensor, a: Tensor|number): Tensor {\n return tidy(() => {\n if (typeof (a) === 'number') {\n a = scalar(Math.round(a), 'int32');\n }\n if (a.dtype !== 'int32') {\n throw new NotImplementedError(\n `Non-int32 dtype (${a.dtype}) is not supported by pow() yet`);\n }\n return tfc.pow(x, a as Tensor);\n });\n}\n\n/* Neural-network operations. */\n\n/**\n * Add a bias to a tensor.\n *\n * @param x The tensor to add the bias to.\n * @param bias The bias to add to `x`. Must be 1D or the same rank as `x`.\n * @return Result of the bias adding.\n * @throws ValueError: If the rank of `bias` is incorrect.\n */\nexport function biasAdd(\n x: Tensor, bias: Tensor, dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n\n if (bias.rank !== 1 && bias.rank !== x.rank) {\n throw new ValueError(\n 'Unexpected bias dimensions: ' + bias.rank +\n '; expected it to be 1 or ' + x.rank);\n }\n const biasShape = bias.shape;\n\n let y: Tensor;\n if (x.rank === 5) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1, 1]));\n } else {\n y = x.add(bias.reshape(\n [1, biasShape[3], biasShape[0], biasShape[1], biasShape[2]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 4) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1]));\n } else {\n y = x.add(\n bias.reshape([1, biasShape[2], biasShape[0], biasShape[1]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 3) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1]));\n } else {\n y = x.add(bias.reshape([1, biasShape[1], biasShape[0]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank < 3) {\n y = x.add(bias);\n } else {\n throw new ValueError(`Unsupported input rank by biasAdd: ${x.rank}`);\n }\n return y;\n });\n}\n\n/**\n * Exponential linear unit (ELU).\n * @param x A tensor or variable to compute the activation function for.\n * @param alpha: A scalar, a scaling factor for the negative section.\n * @return Output of the ELU operation.\n */\nexport function elu(x: Tensor, alpha = 1): Tensor {\n // TODO(cais): Add support for alpha values other than 1.\n if (alpha !== 1) {\n throw new NotImplementedError(\n `Support for alpha values other than 1 (${alpha}) is not implemented ` +\n `yet.`);\n }\n return tfc.elu(x);\n}\n\n/**\n * Softsign of a tensor.\n *\n * Defined as x / (abs(x) + 1), element-wise.\n *\n * @param x: Input.\n * @returns Output.\n */\nexport function softsign(x: Tensor): Tensor {\n return tidy(() => tfc.div(x, tfc.add(getScalar(1), tfc.abs(x))));\n}\n\n/**\n * Sets entries in `x` to zero at random, while scaling the entire tensor.\n *\n * @param x input tensor.\n * @param level fraction of the entries in the tensor that will be set to 0.\n * @param noiseShape shape of randomly generated keep/drop flags, must be\n * broadcastable to the shape of `x`.\n * @param seed random seed to ensure determinism.\n * @returns Result of the dropout operation.\n */\nexport function dropout(\n x: Tensor, level: Scalar, noiseShape?: number[], seed?: number): Tensor {\n return tidy(() => {\n // TODO(cais): Switch to deeplearn.js implementation of dropout when it\n // becomes avaialable.\n if (noiseShape != null && !util.arraysEqual(x.shape, noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented yet: ' +\n JSON.stringify(noiseShape));\n }\n if (seed != null) {\n throw new NotImplementedError('seed is not implemented for dropout yet.');\n }\n let multiplier = tfc.step(tfc.add(\n tfc.neg(level) as Scalar, tfc.randomUniform(x.shape, 0, 1, 'float32')));\n // Scale the kept elements, so the expected sum is unchanged.\n multiplier = tfc.mul(\n tfc.div(getScalar(1), tfc.sub(getScalar(1), level)) as Scalar,\n multiplier);\n return tfc.mul(x, multiplier);\n });\n}\n\n/**\n * Element-wise, segment-wise linear approximation of sigmoid.\n *\n * Returns `0.` if `x < -2.5`, `1.` if `x > 2.5`.\n * In `-2.5 <= x <= 2.5`, returns `0.2 * x + 0.5`.\n *\n * @param x Input tensor.\n * @returns Output tensor.\n */\nexport function hardSigmoid(x: Tensor): Tensor {\n return tidy(() => {\n const y = tfc.add(getScalar(0.5), tfc.mul(getScalar(0.2), x));\n return tfc.clipByValue(y, 0, 1);\n });\n}\n\n/**\n * Invoke `x` in the training phase, and `alt` otherwise.\n *\n * Porting Note: We do not create placeholder tensors for the `training` boolean\n * flag here, because there is no such thing in the TF.js imperative backend.\n *\n * @param x The function to invoke iff `training` is `true`.\n * @param alt The function to invoke iff `training` is `false`.\n * @param training Boolean flag for whether training phase is active.\n * @returns The return value of `x()` if `training` is `true`, or the return\n * value of `alt()` if `training` is `false`.\n */\nexport function inTrainPhase(x: () => T, alt: () => T, training = false): T {\n return training ? x() : alt();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// tslint:disable:max-line-length\nimport {DataType, eye, linalg, mul, ones, randomUniform, scalar, Scalar, serialization, Tensor, Tensor2D, tidy, truncatedNormal, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from './common';\nimport {NotImplementedError, ValueError} from './errors';\nimport {Shape} from './types';\nimport {checkStringTypeUnionValue, deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\nimport {arrayProd} from './utils/math_utils';\n\n// tslint:enable:max-line-length\n\n/** @docinline */\nexport type FanMode = 'fanIn'|'fanOut'|'fanAvg';\nexport const VALID_FAN_MODE_VALUES = ['fanIn', 'fanOut', 'fanAvg'];\nexport function checkFanMode(value?: string): void {\n checkStringTypeUnionValue(VALID_FAN_MODE_VALUES, 'FanMode', value);\n}\n\n/** @docinline */\nexport type Distribution = 'normal'|'uniform';\nexport const VALID_DISTRIBUTION_VALUES = ['normal', 'uniform'];\nexport function checkDistribution(value?: string): void {\n checkStringTypeUnionValue(VALID_DISTRIBUTION_VALUES, 'Distribution', value);\n}\n\n/**\n * Initializer base class.\n *\n * @doc {\n * heading: 'Initializers', subheading: 'Classes', namespace: 'initializers'}\n */\nexport abstract class Initializer extends serialization.Serializable {\n public fromConfigUsesCustomObjects(): boolean {\n return false;\n }\n /**\n * Generate an initial value.\n * @param shape\n * @param dtype\n * @return The init value.\n */\n abstract apply(shape: Shape, dtype?: DataType): Tensor;\n\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/**\n * Initializer that generates tensors initialized to 0.\n */\nexport class Zeros extends Initializer {\n static className = 'Zeros';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return zeros(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Zeros);\n\n/**\n * Initializer that generates tensors initialized to 1.\n */\nexport class Ones extends Initializer {\n static className = 'Ones';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return ones(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Ones);\n\nexport interface ConstantConfig {\n /** The value for each element in the variable. */\n value: number;\n}\n\n/**\n * Initializer that generates values initialized to some constant.\n */\nexport class Constant extends Initializer {\n static className = 'Constant';\n private value: number;\n constructor(config: ConstantConfig) {\n super();\n if (typeof config !== 'object') {\n throw new ValueError(\n `Expected argument of type ConstantConfig but got ${config}`);\n }\n if (config.value === undefined) {\n throw new ValueError(`config must have value set but got ${config}`);\n }\n this.value = config.value;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => mul(scalar(this.value), ones(shape, dtype)));\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n value: this.value,\n };\n }\n}\nserialization.SerializationMap.register(Constant);\n\nexport interface RandomUniformConfig {\n /** Lower bound of the range of random values to generate. */\n minval?: number;\n /** Upper bound of the range of random values to generate. */\n maxval?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a uniform\n * distribution.\n *\n * Values will be distributed uniformly between the configured minval and\n * maxval.\n */\nexport class RandomUniform extends Initializer {\n static className = 'RandomUniform';\n readonly DEFAULT_MINVAL = -0.05;\n readonly DEFAULT_MAXVAL = 0.05;\n private minval: number;\n private maxval: number;\n private seed: number;\n\n constructor(config: RandomUniformConfig) {\n super();\n this.minval = config.minval || this.DEFAULT_MINVAL;\n this.maxval = config.maxval || this.DEFAULT_MAXVAL;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return randomUniform(shape, this.minval, this.maxval, dtype);\n }\n\n getConfig(): serialization.ConfigDict {\n return {minval: this.minval, maxval: this.maxval, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomUniform);\n\nexport interface RandomNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a normal\n * distribution.\n */\nexport class RandomNormal extends Initializer {\n static className = 'RandomNormal';\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: RandomNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormal does not support dType bool.`);\n }\n return K.randomNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomNormal);\n\nexport interface TruncatedNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a truncated normal.\n * distribution.\n *\n * These values are similar to values from a `RandomNormal` except that values\n * more than two standard deviations from the mean are discarded and re-drawn.\n * This is the recommended initializer for neural network weights and filters.\n */\nexport class TruncatedNormal extends Initializer {\n static className = 'TruncatedNormal';\n\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: TruncatedNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `truncatedNormal does not support dType bool.`);\n }\n return truncatedNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(TruncatedNormal);\n\nexport interface IdentityConfig {\n /**\n * Multiplicative factor to apply to the identity matrix.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates the identity matrix.\n * Only use for square 2D matrices.\n */\nexport class Identity extends Initializer {\n static className = 'Identity';\n private gain: Scalar;\n constructor(config: IdentityConfig) {\n super();\n this.gain = config.gain != null ? scalar(config.gain) : getScalar(1.0);\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2 || shape[0] !== shape[1]) {\n throw new ValueError(\n 'Identity matrix initializer can only be used for' +\n ' 2D square matrices.');\n } else {\n return mul(this.gain, eye(shape[0]));\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {gain: this.gain.get()};\n }\n}\nserialization.SerializationMap.register(Identity);\n\n/**\n * Computes the number of input and output units for a weight shape.\n * @param shape Shape of weight.\n * @param dataFormat data format to use for convolution kernels.\n * Note that all kernels in Keras are standardized on the\n * CHANNEL_LAST ordering (even when inputs are set to CHANNEL_FIRST).\n * @return An length-2 array: fanIn, fanOut.\n */\nfunction computeFans(\n shape: Shape, dataFormat: DataFormat = 'channelsLast'): number[] {\n let fanIn: number;\n let fanOut: number;\n checkDataFormat(dataFormat);\n if (shape.length === 2) {\n fanIn = shape[0];\n fanOut = shape[1];\n } else if ([3, 4, 5].indexOf(shape.length) !== -1) {\n if (dataFormat === 'channelsFirst') {\n const receptiveFieldSize = arrayProd(shape, 2);\n fanIn = shape[1] * receptiveFieldSize;\n fanOut = shape[0] * receptiveFieldSize;\n } else if (dataFormat === 'channelsLast') {\n const receptiveFieldSize = arrayProd(shape, 0, shape.length - 2);\n fanIn = shape[shape.length - 2] * receptiveFieldSize;\n fanOut = shape[shape.length - 1] * receptiveFieldSize;\n }\n } else {\n const shapeProd = arrayProd(shape);\n fanIn = Math.sqrt(shapeProd);\n fanOut = Math.sqrt(shapeProd);\n }\n\n return [fanIn, fanOut];\n}\n\nexport interface VarianceScalingConfig {\n /** Scaling factor (positive float). */\n scale: number;\n\n /** Fanning mode for inputs and outputs. */\n mode: FanMode;\n\n /** Probabilistic distribution of the values. */\n distribution: Distribution;\n\n /** Random number generator seed. */\n seed?: number;\n}\n\n\n/**\n * Initializer capable of adapting its scale to the shape of weights.\n * With distribution=NORMAL, samples are drawn from a truncated normal\n * distribution centered on zero, with `stddev = sqrt(scale / n)` where n is:\n * - number of input units in the weight tensor, if mode = FAN_IN.\n * - number of output units, if mode = FAN_OUT.\n * - average of the numbers of input and output units, if mode = FAN_AVG.\n * With distribution=UNIFORM,\n * samples are drawn from a uniform distribution\n * within [-limit, limit], with `limit = sqrt(3 * scale / n)`.\n */\nexport class VarianceScaling extends Initializer {\n static className = 'VarianceScaling';\n private scale: number;\n private mode: FanMode;\n private distribution: Distribution;\n private seed: number;\n\n /**\n * Constructor of VarianceScaling.\n * @throws ValueError for invalid value in scale.\n */\n constructor(config: VarianceScalingConfig) {\n super();\n if (config.scale < 0.0) {\n throw new ValueError(\n `scale must be a positive float. Got: ${config.scale}`);\n }\n this.scale = config.scale == null ? 1.0 : config.scale;\n this.mode = config.mode;\n checkFanMode(this.mode);\n this.distribution = config.distribution;\n checkDistribution(this.distribution);\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n const fans = computeFans(shape);\n const fanIn = fans[0];\n const fanOut = fans[1];\n let scale = this.scale;\n if (this.mode === 'fanIn') {\n scale /= Math.max(1, fanIn);\n } else if (this.mode === 'fanOut') {\n scale /= Math.max(1, fanOut);\n } else {\n scale /= Math.max(1, (fanIn + fanOut) / 2);\n }\n\n if (this.distribution === 'normal') {\n const stddev = Math.sqrt(scale);\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `${this.getClassName()} does not support dType bool.`);\n }\n return truncatedNormal(shape, 0, stddev, dtype, this.seed);\n } else {\n const limit = Math.sqrt(3 * scale);\n return randomUniform(shape, -limit, limit, dtype);\n }\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n scale: this.scale,\n mode: this.mode,\n distribution: this.distribution,\n seed: this.seed\n };\n }\n}\nserialization.SerializationMap.register(VarianceScaling);\n\nexport interface SeedOnlyInitializerConfig {\n /** Random number generator seed. */\n seed?: number;\n}\n\n/**\n * Glorot uniform initializer, also called Xavier uniform initializer.\n * It draws samples from a uniform distribution within [-limit, limit]\n * where `limit` is `sqrt(6 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf.\n */\nexport class GlorotUniform extends VarianceScaling {\n /**\n * Constructor of GlorotUniform\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'uniform',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotUniform is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * Glorot normal initializer, also called Xavier normal initializer.\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor.\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf\n */\nexport class GlorotNormal extends VarianceScaling {\n /**\n * Constructor of GlorotNormal.\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * He normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * Reference:\n * He et al., http://arxiv.org/abs/1502.01852\n */\nexport class HeNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 2.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, HeNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * LeCun normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(1 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * References:\n * [Self-Normalizing Neural Networks](https://arxiv.org/abs/1706.02515)\n * [Efficient Backprop](http://yann.lecun.com/exdb/publis/pdf/lecun-98b.pdf)\n */\nexport class LeCunNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, LeCunNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\nexport interface OrthogonalConfig extends SeedOnlyInitializerConfig {\n /**\n * Multiplicative factor to apply to the orthogonal matrix. Defaults to 1.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates a random orthogonal matrix.\n *\n * Reference:\n * [Saxe et al., http://arxiv.org/abs/1312.6120](http://arxiv.org/abs/1312.6120)\n */\nexport class Orthogonal extends Initializer {\n static className = 'Orthogonal';\n readonly DEFAULT_GAIN = 1;\n protected readonly gain: number;\n protected readonly seed: number;\n\n constructor(config?: OrthogonalConfig) {\n super();\n this.gain = config.gain == null ? this.DEFAULT_GAIN : config.gain;\n this.seed = config.seed;\n\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Random seed is not implemented for Orthogonal Initializer yet.');\n }\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2) {\n throw new NotImplementedError(\n 'The Orthogonal Initializer does not support non-2D shapes yet.');\n }\n if (shape[0] * shape[1] > 2000) {\n console.warn(\n `Orthogonal initializer is being called on a matrix with more ` +\n `than 2000 (${shape[0] * shape[1]}) elements: ` +\n `Slowness may result.`);\n }\n\n // TODO(cais): Add seed support.\n const normalizedShape =\n shape[0] > shape[1] ? [shape[1], shape[0]] : shape;\n const a = K.randomNormal(normalizedShape, 0, 1, 'float32') as Tensor2D;\n let q = linalg.gramSchmidt(a) as Tensor2D;\n if (shape[0] > shape[1]) {\n q = q.transpose();\n }\n return mul(getScalar(this.gain), q);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n gain: this.gain,\n seed: this.seed,\n };\n }\n}\nserialization.SerializationMap.register(Orthogonal);\n\n/** @docinline */\nexport type InitializerIdentifier = 'constant'|'glorotNormal'|'glorotUniform'|\n 'heNormal'|'identity'|'leCunNormal'|'ones'|'orthogonal'|'randomNormal'|\n 'randomUniform'|'truncatedNormal'|'varianceScaling'|'zeros'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in InitializerIdentifier]: string} = {\n 'constant': 'Constant',\n 'glorotNormal': 'GlorotNormal',\n 'glorotUniform': 'GlorotUniform',\n 'heNormal': 'HeNormal',\n 'identity': 'Identity',\n 'leCunNormal': 'LeCunNormal',\n 'ones': 'Ones',\n 'orthogonal': 'Orthogonal',\n 'randomNormal': 'RandomNormal',\n 'randomUniform': 'RandomUniform',\n 'truncatedNormal': 'TruncatedNormal',\n 'varianceScaling': 'VarianceScaling',\n 'zeros': 'Zeros'\n };\n\nfunction deserializeInitializer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Initializer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'initializer');\n}\n\nexport function serializeInitializer(initializer: Initializer):\n serialization.ConfigDictValue {\n return serializeKerasObject(initializer);\n}\n\nexport function getInitializer(identifier: InitializerIdentifier|Initializer|\n serialization.ConfigDict): Initializer {\n if (typeof identifier === 'string') {\n const className = identifier in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n /* We have four 'helper' classes for common initializers that\n all get serialized as 'VarianceScaling' and shouldn't go through\n the deserializeInitializer pathway. */\n if (className === 'GlorotUniform') {\n return new GlorotUniform();\n } else if (className === 'GlorotNormal') {\n return new GlorotNormal();\n } else if (className === 'HeNormal') {\n return new HeNormal();\n } else if (className === 'LeCunNormal') {\n return new LeCunNormal();\n } else {\n const config = {className, config: {}};\n return deserializeInitializer(config);\n }\n } else if (identifier instanceof Initializer) {\n return identifier;\n } else {\n return deserializeInitializer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constant, ConstantConfig, GlorotNormal, GlorotUniform, HeNormal, Identity, IdentityConfig, Initializer, LeCunNormal, Ones, Orthogonal, OrthogonalConfig, RandomNormal, RandomNormalConfig, RandomUniform, RandomUniformConfig, SeedOnlyInitializerConfig, TruncatedNormal, TruncatedNormalConfig, VarianceScaling, VarianceScalingConfig, Zeros} from './initializers';\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Zeros'\n * }\n */\nexport function zeros(): Zeros {\n return new Zeros();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Ones'\n * }\n */\nexport function ones(): Initializer {\n return new Ones();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Constant',\n * configParamIndices: [0]\n * }\n */\nexport function constant(config: ConstantConfig): Initializer {\n return new Constant(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomUniform',\n * configParamIndices: [0]\n * }\n */\nexport function randomUniform(config: RandomUniformConfig): Initializer {\n return new RandomUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomNormal',\n * configParamIndices: [0]\n * }\n */\nexport function randomNormal(config: RandomNormalConfig): Initializer {\n return new RandomNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'TruncatedNormal',\n * configParamIndices: [0]\n * }\n */\nexport function truncatedNormal(config: TruncatedNormalConfig): Initializer {\n return new TruncatedNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Identity',\n * configParamIndices: [0]\n * }\n */\nexport function identity(config: IdentityConfig): Initializer {\n return new Identity(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'VarianceScaling',\n * configParamIndices: [0]\n * }\n */\nexport function varianceScaling(config: VarianceScalingConfig): Initializer {\n return new VarianceScaling(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotUniform',\n * configParamIndices: [0]\n * }\n */\nexport function glorotUniform(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotNormal',\n * configParamIndices: [0]\n * }\n */\nexport function glorotNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'HeNormal',\n * configParamIndices: [0]\n * }\n */\nexport function heNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new HeNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'LeCunNormal',\n * configParamIndices: [0]\n * }\n */\nexport function leCunNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new LeCunNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Orthogonal',\n * configParamIndices: [0]\n * }\n */\nexport function orthogonal(config: OrthogonalConfig): Initializer {\n return new Orthogonal(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: utils/generic_utils.py */\n\n// tslint:disable:max-line-length\nimport {Tensor} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\nimport {Shape} from '../types';\n// tslint:enable\n\n\n/**\n * Determine whether the input is an Array of Shapes.\n */\nexport function isArrayOfShapes(x: Shape|Shape[]): boolean {\n return Array.isArray(x) && Array.isArray(x[0]);\n}\n\n/**\n * Special case of normalizing shapes to lists.\n *\n * @param x A shape or list of shapes to normalize into a list of Shapes.\n * @return A list of Shapes.\n */\nexport function normalizeShapeList(x: Shape|Shape[]): Shape[] {\n if (x.length === 0) {\n return [];\n }\n if (!Array.isArray(x[0])) {\n return [x] as Shape[];\n }\n return x as Shape[];\n}\n\n/**\n * Helper function to obtain exactly one Tensor.\n * @param xs: A single `Tensor` or an `Array` of `Tensor`s.\n * @return A single `Tensor`. If `xs` is an `Array`, return the first one.\n * @throws ValueError: If `xs` is an `Array` and its length is not 1.\n */\nexport function getExactlyOneTensor(xs: Tensor|Tensor[]): Tensor {\n let x: Tensor;\n if (Array.isArray(xs)) {\n if (xs.length !== 1) {\n throw new ValueError(`Expected Tensor length to be 1; got ${xs.length}`);\n }\n x = xs[0];\n } else {\n x = xs as Tensor;\n }\n return x;\n}\n\n/**\n * Helper function to obtain exactly on instance of Shape.\n *\n * @param shapes Input single `Shape` or Array of `Shape`s.\n * @returns If input is a single `Shape`, return it unchanged. If the input is\n * an `Array` containing exactly one instance of `Shape`, return the instance.\n * Otherwise, throw a `ValueError`.\n * @throws ValueError: If input is an `Array` of `Shape`s, and its length is not\n * 1.\n */\nexport function getExactlyOneShape(shapes: Shape|Shape[]): Shape {\n if (Array.isArray(shapes) && Array.isArray(shapes[0])) {\n if (shapes.length === 1) {\n shapes = shapes as Shape[];\n return shapes[0];\n } else {\n throw new ValueError(`Expected exactly 1 Shape; got ${shapes.length}`);\n }\n } else {\n return shapes as Shape;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {LayerVariable} from '../variables';\n\n/**\n * Count the elements in an Array of LayerVariables.\n *\n * @param weights: The LayerVariables of which the constituent numbers are to\n * be counted.\n * @returns A count of the elements in all the LayerVariables\n */\nexport function countParamsInWeights(weights: LayerVariable[]): number {\n let count = 0;\n for (const weight of weights) {\n if (weight.shape.length === 0) {\n count += 1;\n } else {\n count += weight.shape.reduce((a, b) => a * b);\n }\n }\n return count;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, Tensor, variableGrads} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId} from './backend/state';\nimport {getScopedTensorName, getUniqueTensorName} from './common';\nimport {Constraint} from './constraints';\nimport {NotImplementedError} from './errors';\nimport {HasShape, Shape} from './types';\n\nconst DEFAULT_VARIABLE_NAME_PREFIX = 'Variable';\n\n/**\n * A `LayerVariable` is similar to a `Tensor` in that it has a dtype and shape,\n * but its value is mutable. The value is itself represented as a `Tensor`, and\n * can be read with the `read()` method and updated with the `write()` method.\n */\nexport class LayerVariable {\n readonly dtype: DataType;\n readonly shape: Shape;\n\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName: string;\n readonly trainable: boolean;\n\n protected readonly val: tfc.Variable;\n readonly constraint: Constraint;\n /**\n * Construct Variable from a Tensor.\n *\n * If not explicitly named, the Variable will be given a name with the\n * prefix 'Variable'. Variable names are unique. In the case of name\n * collision, suffixies '_' will be added to the name.\n *\n * @param val Initial value of the Variable.\n * @param name Name of the variable. If `null` or `undefined` is provided, it\n * will default a name with the prefix 'Variable'.\n * @param constraint Optional, projection function to be applied to the\n * variable after optimize updates\n * @throws ValueError if `name` is `null` or `undefined`.\n */\n constructor(\n val: Tensor, dtype: DataType = 'float32',\n name = DEFAULT_VARIABLE_NAME_PREFIX, trainable = true,\n constraint: Constraint = null) {\n this.dtype = dtype == null ? 'float32' : dtype;\n this.shape = val.shape;\n this.id = getNextUniqueTensorId();\n\n name = name == null ? DEFAULT_VARIABLE_NAME_PREFIX : name;\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n\n this.trainable = trainable;\n this.constraint = constraint;\n\n this.val = tfc.variable(val, this.trainable, this.name, this.dtype);\n }\n\n /**\n * Get a snapshot of the Variable's value.\n *\n * The returned value is a snapshot of the Variable's value at the time of\n * the invocation. Future mutations in the value of the tensor will only\n * be reflected by future calls to this method.\n */\n read(): Tensor {\n return this.val;\n }\n\n /**\n * Update the value of the Variable.\n *\n * @param newVal: The new value to update to. Must be consistent with the\n * dtype and shape of the Variable.\n * @return This Variable.\n */\n write(newVal: Tensor) {\n // TODO(cais): Once TF.js Core supports Tensor.dtype, check dtype match.\n checkShapesMatch(this.val, newVal);\n this.val.assign(newVal);\n if (this.constraint != null) {\n this.val.assign(this.constraint.apply(this.val));\n }\n return this;\n }\n}\n\nfunction checkShapesMatch(x: HasShape, y: HasShape): void {\n if (x.shape.toString() !== y.shape.toString()) {\n throw new Error(\n 'Shape mismatch: ' + JSON.stringify(x.shape) + ' vs. ' +\n JSON.stringify(y.shape));\n }\n}\n\n/**\n * Create a Variable.\n * @param x The initial value of the `Variable`.\n * @param dtype optional, the type of the variable.\n * @param name optional, the name of the variable, default provided by\n * Variable.\n * @param constraint optional, a constraint to be applied after every update.\n * @return The newly instantiated `Variable`.\n */\nexport function variable(\n x: Tensor, dtype?: DataType, name?: string,\n constraint?: Constraint): LayerVariable {\n return new LayerVariable(x, dtype, name, true, constraint);\n}\n\n/**\n * Instantiates an all-zeros Variable and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-zero Variable.\n */\nexport function zerosVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n return new LayerVariable(tfc.zeros(shape), dtype, name);\n}\n\n/**\n * Instantiates an all-zeros tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function zerosLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.zerosLike(x), dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-ones Variable.\n */\nexport function onesVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n const allocated = tfc.ones(shape);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function onesLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n const allocated = tfc.onesLike(x);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiate an identity matrix and returns it, as a Variable\n *\n * @param size Number of rows/columns.\n * @param dtype Data type of returned Variable.\n * @param name Name of returned Variable.\n * @return A Variable, an identity matrix.\n */\nexport function eyeVariable(\n size: number, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.eye(size), dtype, name);\n}\n\n/**\n * Get a Variable with uniform distribution of values.\n * @param shape Shape of the tensor.\n * @param minval Lower bound of the uniform distribution.\n * @param maxval Upper bound of the uniform distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The uniform-random Variable.\n */\nexport function randomUniformVariable(\n shape: Shape, minval: number, maxval: number, dtype?: DataType,\n seed?: number, name = 'randomUniform'): LayerVariable {\n return new LayerVariable(\n tfc.randomUniform(shape, minval, maxval, dtype), dtype, name);\n}\n\n/**\n * Get a Variable with truncated-normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function truncatedNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'truncatedNormal'): LayerVariable {\n // TODO(cais): Implement logic for dtype and seed once they are supported\n // by deeplearn.js.\n if (dtype === 'bool') {\n throw new NotImplementedError(`randomNormal does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.truncatedNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n/**\n * Get a Variable with normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function randomNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'randomNormal'): LayerVariable {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormalVariable does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.randomNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n\n/**\n * Update the value of a Variable.\n * @param x The Variable to be updated.\n * @param xNew The new value to update to.\n * @return The Variable updated.\n */\nexport function update(x: LayerVariable, xNew: Tensor): LayerVariable {\n return x.write(xNew);\n}\n\n/**\n * Update the value of a Variable by adding an increment.\n * @param x The Variable to be updated.\n * @param increment The incrment to add to `x`.\n * @return The Variable updated.\n */\nexport function updateAdd(x: LayerVariable, increment: Tensor): LayerVariable {\n return x.write(tfc.add(x.read(), increment));\n}\n\n/**\n * Update the value of a Variable by subtracting a decrement.\n * @param x The Variable to be updated.\n * @param decrement The decrement to subtract from `x`.\n * @return The Variable updated.\n */\nexport function updateSub(x: LayerVariable, decrement: Tensor): LayerVariable {\n return x.write(tfc.sub(x.read(), decrement));\n}\n\n/**\n * Get the values of an array of Variables.\n *\n * @param tensors An `Array` of `Variable`s to get the values of.\n * @return The values of the inputs, as an `Array` of `Tensor`s.\n */\nexport function batchGetValue(xs: LayerVariable[]): Tensor[] {\n return xs.map(x => x.read());\n}\n\n/**\n * Update the value of multiple Variables at once.\n *\n * @param variablesAndValues An `Array`, each element is of type\n * [Variable, Tensor]. The first item is the\n * `Variable` of which the value is to be updated. The second item\n * carries the new value.\n */\nexport function batchSetValue(\n variablesAndValues: Array<[LayerVariable, Tensor]>): void {\n variablesAndValues.map((variableAndValue) => {\n const variable: LayerVariable = variableAndValue[0];\n variable.write(variableAndValue[1]);\n });\n}\n\n/**\n * Returns the gradients of `variables` w.r.t. the return value of `lossFn`.\n * @param lossFn A function which returns a Scalar to be used as the function\n * value (i.e., numerator) for differentiation.\n * @param variables List of variables to be used as the independent variables\n * (i.e., denominator) for differentiation.\n * @returns An Array of gradients tensors.\n */\nexport function gradients(\n lossFn: () => tfc.Scalar, variables: LayerVariable[]): Tensor[] {\n // TODO(cais): The return type signature can be simplified if deeplearn makes\n // the corresponding type public.\n const variableList =\n variables.map(variable => variable.read() as tfc.Variable);\n const valudAndGrads = variableGrads(lossFn, variableList);\n return variables.map(variable => valudAndGrads.grads[variable.name]);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {DataType, Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId, getUid} from '../backend/state';\nimport {getScopedTensorName, getUniqueTensorName, nameScope} from '../common';\nimport {Constraint} from '../constraints';\nimport {AttributeError, NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {Initializer} from '../initializers';\nimport {Regularizer} from '../regularizers';\nimport {Kwargs, RegularizerFn, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as types_utils from '../utils/types_utils';\nimport * as variable_utils from '../utils/variable_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n// TODO(michaelterry): This is a stub until it's defined.\nexport type Op = (x: LayerVariable) => LayerVariable;\n\n/**\n * Constructor arguments for InputSpec.\n */\nexport interface InputSpecConfig {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n}\n\n/**\n * Specifies the ndim, dtype and shape of every input to a layer.\n *\n * Every layer should expose (if appropriate) an `inputSpec` attribute:\n * a list of instances of InputSpec (one per input tensor).\n *\n * A null entry in a shape is compatible with any dimension,\n * a null shape is compatible with any shape.\n */\nexport class InputSpec {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n\n constructor(config: InputSpecConfig) {\n this.dtype = config.dtype;\n this.shape = config.shape;\n /*\n TODO(michaelterry): Could throw error if ndim and shape are both defined\n (then backport).\n */\n if (config.shape != null) {\n this.ndim = config.shape.length;\n } else {\n this.ndim = config.ndim;\n }\n this.maxNDim = config.maxNDim;\n this.minNDim = config.minNDim;\n this.axes = config.axes || {};\n }\n}\n\n/**\n * `SymbolicTensor` is a placeholder for a Tensor without any concrete value.\n *\n * They are most often encountered when building a graph of `Layer`s for a\n * a `Model` and the input data's shape, but not values are known.\n */\n/** @doc {heading: 'Models', 'subheading': 'Classes'} */\nexport class SymbolicTensor {\n /* A unique ID for the tensor to be able to differentiate tensors. */\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName?: string;\n /**\n * Rank/dimensionality of the tensor.\n */\n readonly rank: number;\n /**\n * Replacement for _keras_history.\n */\n nodeIndex: number;\n /**\n * Replacement for _keras_history.\n */\n tensorIndex: number;\n\n /**\n *\n * @param dtype\n * @param shape\n * @param sourceLayer The Layer that produced this symbolic tensor.\n * @param inputs The inputs passed to sourceLayer's __call__() method.\n * @param nodeIndex\n * @param tensorIndex\n * @param callArgs The keyword arguments passed to the __call__() method.\n * @param name\n * @param outputTensorIndex The index of this tensor in the list of outputs\n * returned by apply().\n */\n constructor(\n readonly dtype: DataType, readonly shape: Shape,\n public sourceLayer: Layer, readonly inputs: SymbolicTensor[],\n readonly callArgs: Kwargs, name?: string,\n readonly outputTensorIndex?: number) {\n this.id = getNextUniqueTensorId();\n if (name != null) {\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n }\n this.rank = shape.length;\n }\n}\n\n/**\n * Constructor arguments for Node.\n */\nexport interface NodeConfig {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`.\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n}\n\nlet _nextNodeID = 0;\n\n/**\n * A `Node` describes the connectivity between two layers.\n *\n * Each time a layer is connected to some new input,\n * a node is added to `layer.inboundNodes`.\n *\n * Each time the output of a layer is used by another layer,\n * a node is added to `layer.outboundNodes`.\n *\n * `nodeIndices` and `tensorIndices` are basically fine-grained coordinates\n * describing the origin of the `inputTensors`, verifying the following:\n *\n * `inputTensors[i] ==\n * inboundLayers[i].inboundNodes[nodeIndices[i]].outputTensors[\n * tensorIndices[i]]`\n *\n * A node from layer A to layer B is added to:\n * A.outboundNodes\n * B.inboundNodes\n */\nexport class Node {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n\n readonly id: number;\n\n constructor(\n config: NodeConfig,\n // TODO(michaelterry): Define actual type for this.\n public callArgs?: Kwargs) {\n this.id = _nextNodeID++;\n /*\n Layer instance (NOT a list).\n this is the layer that takes a list of input tensors\n and turns them into a list of output tensors.\n the current node will be added to\n the inboundNodes of outboundLayer.\n */\n this.outboundLayer = config.outboundLayer;\n\n /*\n The following 3 properties describe where\n the input tensors come from: which layers,\n and for each layer, which node and which\n tensor output of each node.\n */\n\n // List of layer instances.\n this.inboundLayers = config.inboundLayers;\n // List of integers, 1:1 mapping with inboundLayers.\n this.nodeIndices = config.nodeIndices;\n // List of integers, 1:1 mapping with inboundLayers.\n this.tensorIndices = config.tensorIndices;\n\n /*\n Following 2 properties:\n tensor inputs and outputs of outboundLayer.\n */\n\n // List of tensors. 1:1 mapping with inboundLayers.\n this.inputTensors = config.inputTensors;\n // List of tensors, created by outboundLayer.call().\n this.outputTensors = config.outputTensors;\n\n /*\n Following 2 properties: input and output masks.\n List of tensors, 1:1 mapping with inputTensor.\n */\n this.inputMasks = config.inputMasks;\n // List of tensors, created by outboundLayer.computeMask().\n this.outputMasks = config.outputMasks;\n\n // Following 2 properties: input and output shapes.\n\n // List of shape tuples, shapes of inputTensors.\n this.inputShapes = config.inputShapes;\n // List of shape tuples, shapes of outputTensors.\n this.outputShapes = config.outputShapes;\n\n // Add nodes to all layers involved.\n for (const layer of config.inboundLayers) {\n if (layer != null) {\n layer.outboundNodes.push(this);\n }\n }\n config.outboundLayer.inboundNodes.push(this);\n }\n\n getConfig(): serialization.ConfigDict {\n const inboundNames: string[] = [];\n for (const layer of this.inboundLayers) {\n if (layer != null) {\n inboundNames.push(layer.name);\n } else {\n inboundNames.push(null);\n }\n }\n return {\n outboundLayer: this.outboundLayer ? this.outboundLayer.name : null,\n inboundLayers: inboundNames,\n nodeIndices: this.nodeIndices,\n tensorIndices: this.tensorIndices\n };\n }\n}\n\n/** Constructor arguments for Layer. */\nexport interface LayerConfig {\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n inputShape?: Shape;\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n batchInputShape?: Shape;\n /**\n * If `inputShape` is specified and `batchInputShape` is *not* specifiedd,\n * `batchSize` is used to construct the `batchInputShape`: `[batchSize,\n * ...inputShape]`\n */\n batchSize?: number;\n /**\n * The data-type for this layer. Defaults to 'float32'.\n * This argument is only applicable to input layers (the first layer of a\n * model).\n */\n dtype?: DataType;\n /** Name for this layer. */\n name?: string;\n /** Whether this layer is trainable. Defaults to true. */\n trainable?: boolean;\n /** Whether the weights of this layer are updatable by `fit`. */\n updatable?: boolean;\n /**\n * Initial weight values of the layer.\n */\n weights?: Tensor[];\n /** Legacy support. Do not use for new code. */\n inputDType?: DataType;\n}\n\n// If necessary, add `output` arguments to the CallHook function.\n// This is currently used for testing only, but may be used for debugger-related\n// purposes in the future.\nexport type CallHook = (inputs: Tensor|Tensor[], kwargs: Kwargs) => void;\n\nlet _nextLayerID = 0;\n\n/**\n * A layer is a grouping of operations and weights that can be composed to\n * create a `Model`.\n *\n * Layers are constructed by using the functions under the\n * [tf.layers](#Layers-Basic) namespace.\n */\n/** @doc {heading: 'Layers', subheading: 'Classes', namespace: 'layers'} */\nexport abstract class Layer extends serialization.Serializable {\n /** Name for this layer. Must be unique within a model. */\n name: string;\n /**\n * List of InputSpec class instances.\n *\n * Each entry describes one required input:\n * - ndim\n * - dtype\n * A layer with `n` input tensors must have an `inputSpec` of length `n`.\n */\n inputSpec: InputSpec[];\n supportsMasking: boolean;\n /** Whether the layer weights will be updated during training. */\n trainable: boolean;\n updatable: boolean;\n batchInputShape: Shape;\n dtype: DataType;\n initialWeights: Tensor[];\n\n inboundNodes: Node[];\n outboundNodes: Node[];\n\n activityRegularizer: Regularizer;\n\n protected _trainableWeights: LayerVariable[];\n private _nonTrainableWeights: LayerVariable[];\n private _losses: RegularizerFn[];\n // TODO(cais): _updates is currently unused.\n private _updates: Tensor[];\n private _built: boolean;\n private _callHook: CallHook = null;\n\n private _addedWeightNames: string[] = [];\n\n readonly id: number;\n\n // Porting Notes: PyKeras does not have this property in this base Layer\n // class. Instead lets Layer subclass set it dynamically and checks the\n // value with `hasattr`. In tfjs-layers, we let this be a member of this\n // base class.\n protected _stateful = false;\n\n constructor(config: LayerConfig) {\n super();\n this.id = _nextLayerID++;\n\n this.activityRegularizer = null;\n\n this.inputSpec = null;\n this.supportsMasking = false;\n\n // These properties will be set upon call of this.build()\n this._trainableWeights = [];\n this._nonTrainableWeights = [];\n this._losses = [];\n this._updates = [];\n this._built = false;\n\n /*\n These lists will be filled via successive calls\n to this.addInboundNode().\n */\n this.inboundNodes = [];\n this.outboundNodes = [];\n\n let name = config.name;\n if (!name) {\n const prefix = this.getClassName();\n name = generic_utils.toSnakeCase(prefix) + '_' + getUid(prefix);\n }\n this.name = name;\n\n this.trainable = config.trainable == null ? true : config.trainable;\n this.updatable = config.updatable == null ? true : config.updatable;\n\n if (config.inputShape != null || config.batchInputShape != null) {\n /*\n In this case we will later create an input layer\n to insert before the current layer\n */\n let batchInputShape: Shape;\n if (config.batchInputShape != null) {\n batchInputShape = config.batchInputShape;\n } else if (config.inputShape != null) {\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n batchInputShape = [batchSize].concat(config.inputShape);\n }\n this.batchInputShape = batchInputShape;\n\n // Set dtype.\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = config.inputDType;\n }\n if (dtype == null) {\n dtype = 'float32';\n }\n this.dtype = dtype;\n }\n\n if (config.weights != null) {\n this.initialWeights = config.weights;\n } else {\n this.initialWeights = null;\n }\n }\n\n /**\n * Converts a layer and its index to a unique (immutable type) name.\n * This function is used internally with `this.containerNodes`.\n * @param layer The layer.\n * @param nodeIndex The layer's position (e.g. via enumerate) in a list of\n * nodes.\n *\n * @returns The unique name.\n */\n protected static nodeKey(layer: Layer, nodeIndex: number) {\n return layer.name + '_ib-' + nodeIndex.toString();\n }\n\n /**\n * Returns this.inboundNode at index nodeIndex.\n *\n * Porting note: This is a replacement for _get_node_attribute_at_index()\n * @param nodeIndex\n * @param attrName The name of the attribute related to request for this node.\n */\n private getNodeAtIndex(nodeIndex: number, attrName: string): Node {\n if (this.inboundNodes.length === 0) {\n throw new RuntimeError(\n 'The layer has never been called ' +\n `and thus has no defined ${attrName}.`);\n }\n if (this.inboundNodes.length <= nodeIndex) {\n throw new ValueError(\n `Asked to get ${attrName} at node ${nodeIndex}, ` +\n `but the layer has only ${this.inboundNodes.length} inbound nodes.`);\n }\n return this.inboundNodes[nodeIndex];\n }\n\n /**\n * Retrieves the input tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple inputs).\n */\n getInputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple outputs).\n */\n getOutputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'output').outputTensors);\n }\n\n // Properties\n\n /**\n * Retrieves the input tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Input tensor or list of input tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get input(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer input\" ' +\n 'is ill-defined. ' +\n 'Use `getInputAt(nodeIndex)` instead.');\n } else if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' is not connected, no input to return.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Output tensor or list of output tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get output(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has no inbound nodes.');\n }\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer output\" ' +\n 'is ill-defined. ' +\n 'Use `getOutputAt(nodeIndex)` instead.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'output').outputTensors);\n }\n\n get losses(): RegularizerFn[] {\n return this._losses;\n }\n\n /**\n * Retrieves the Layer's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Layer.loss in PyKeras.\n // In PyKeras, Layer.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return this.losses.map(lossFn => lossFn());\n }\n\n get updates(): Tensor[] {\n return this._updates;\n }\n\n get built(): boolean {\n return this._built;\n }\n\n set built(built: boolean) {\n this._built = built;\n }\n\n get trainableWeights(): LayerVariable[] {\n if (this.trainable) {\n return this._trainableWeights;\n } else {\n return [];\n }\n }\n\n set trainableWeights(weights: LayerVariable[]) {\n this._trainableWeights = weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return this._trainableWeights.concat(this._nonTrainableWeights);\n } else {\n return this._nonTrainableWeights;\n }\n }\n\n set nonTrainableWeights(weights: LayerVariable[]) {\n this._nonTrainableWeights = weights;\n }\n\n /**\n * The concatenation of the lists trainableWeights and nonTrainableWeights\n * (in this order).\n */\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n get stateful(): boolean {\n return this._stateful;\n }\n\n /**\n * Checks compatibility between the layer and provided inputs.\n *\n * This checks that the tensor(s) `input`\n * verify the input assumptions of the layer\n * (if any). If not, exceptions are raised.\n *\n * @param inputs Input tensor or list of input tensors.\n *\n * @exception ValueError in case of mismatch between\n * the provided inputs and the expectations of the layer.\n */\n protected assertInputCompatibility(inputs: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): void {\n inputs = generic_utils.toList(inputs);\n if (this.inputSpec == null || this.inputSpec.length === 0) {\n return;\n }\n const inputSpec = generic_utils.toList(this.inputSpec);\n if (inputs.length !== inputSpec.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${inputSpec.length} inputs, ` +\n `but it received ${inputs.length} input tensors. ` +\n `Input received: ${inputs}`);\n }\n for (let inputIndex = 0; inputIndex < inputs.length; inputIndex++) {\n const x = inputs[inputIndex];\n const spec: InputSpec = inputSpec[inputIndex];\n if (spec == null) {\n continue;\n }\n\n // Check ndim.\n const ndim = x.rank;\n if (spec.ndim != null) {\n if (ndim !== spec.ndim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}: ` +\n `expected ndim=${spec.ndim}, found ndim=${ndim}`);\n }\n }\n if (spec.maxNDim != null) {\n if (ndim > spec.maxNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected max_ndim=${spec.maxNDim}, found ndim=${ndim}`);\n }\n }\n if (spec.minNDim != null) {\n if (ndim < spec.minNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected min_ndim=${spec.minNDim}, found ndim=${ndim}.`);\n }\n }\n\n // Check dtype.\n if (spec.dtype != null) {\n if (x.dtype !== spec.dtype) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name} ` +\n `: expected dtype=${spec.dtype}, found dtype=${x.dtype}.`);\n }\n }\n\n // Check specific shape axes.\n if (spec.axes) {\n const xShape = x.shape;\n for (const key in spec.axes) {\n const axis = Number(key);\n const value = spec.axes[key];\n // Perform Python-style slicing in case axis < 0;\n // TODO(cais): Use https://github.com/alvivi/typescript-underscore to\n // ensure type safety through Underscore calls.\n const xShapeAtAxis =\n axis >= 0 ? xShape[axis] : xShape[xShape.length + axis];\n if (value != null && [value, null].indexOf(xShapeAtAxis) === -1) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected axis ${axis} of input shape to ` +\n `have value ${value} but got shape ${xShape}.`);\n }\n }\n }\n\n // Check shape.\n if (spec.shape != null) {\n for (let i = 0; i < spec.shape.length; ++i) {\n const specDim = spec.shape[i];\n const dim = x.shape[i];\n if (specDim != null && dim != null) {\n if (specDim !== dim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected shape=${spec.shape}, ` +\n 'found shape=${xShape}.');\n }\n }\n }\n }\n }\n }\n\n /**\n * This is where the layer's logic lives.\n *\n * @param inputs Input tensor, or list/tuple of input tensors.\n * @param kwargs Additional keyword arguments.\n *\n * @return A tensor or list/tuple of tensors.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return inputs;\n }\n\n protected invokeCallHook(inputs: Tensor|Tensor[], kwargs: Kwargs) {\n if (this._callHook != null) {\n this._callHook(inputs, kwargs);\n }\n }\n\n /**\n * Set call hook.\n * This is currently used for testing only.\n * @param callHook\n */\n setCallHook(callHook: CallHook) {\n this._callHook = callHook;\n }\n\n /**\n * Clear call hook.\n * This is currently used for testing only.\n */\n clearCallHook() {\n this._callHook = null;\n }\n\n /**\n * Builds or executes a `Layer's logic.\n *\n * When called with `Tensor`(s), execute the `Layer`s computation and\n * return Tensor(s). For example:\n *\n * ```js\n * const denseLayer = tf.layers.dense({\n * units: 1,\n * kernelInitializer: 'zeros',\n * useBias: false\n * });\n *\n * // Invoke the layer's apply() method with a `Tensor` (with concrete\n * // numeric values).\n * const input = tf.ones([2, 2]);\n * const output = denseLayer.apply(input);\n *\n * // The output's value is expected to be [[0], [0]], due to the fact that\n * // the dense layer has a kernel initialized to all-zeros and does not have\n * // a bias.\n * output.print();\n * ```\n *\n * When called with `SymbolicTensor`(s), this will prepare the layer for\n * future execution. This entails internal book-keeping on shapes of\n * expected Tensors, wiring layers together, and initializing weights.\n *\n * Calling `apply` with `SymbolicTensor`s are typically used during the\n * building of non-`Sequential` models. For example:\n *\n * ```js\n * const flattenLayer = tf.layers.flatten();\n * const denseLayer = tf.layers.dense({units: 1});\n *\n * // Use tf.layers.input() to obtain a SymbolicTensor as input to apply().\n * const input = tf.input({shape: [2, 2]});\n * const output1 = flattenLayer.apply(input);\n *\n * // output1.shape is [null, 4]. The first dimension is the undetermined\n * // batch size. The second dimension comes from flattening the [2, 2]\n * // shape.\n * console.log(JSON.stringify(output1.shape));\n *\n * // The output SymbolicTensor of the flatten layer can be used to call\n * // the apply() of the dense layer:\n * const output2 = denseLayer.apply(output1);\n *\n * // output2.shape is [null, 1]. The first dimension is the undetermined\n * // batch size. The second dimension matches the number of units of the\n * // dense layer.\n * console.log(JSON.stringify(output2.shape));\n *\n * // The input and output and be used to construct a model that consists\n * // of the flatten and dense layers.\n * const model = tf.model({inputs: input, outputs: output2});\n * ```\n *\n * @param inputs a `Tensor` or `SymbolicTensor` or an Array of them.\n * @param kwargs Additional keyword arguments to be passed to `call()`.\n *\n * @return Output of the layer's `call` method.\n *\n * @exception ValueError error in case the layer is missing shape information\n * for its `build` call.\n */\n // Porting Note: This is a replacement for __call__() in Python.\n /** @doc {heading: 'Models', 'subheading': 'Classes'} */\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n kwargs = kwargs || {};\n\n // Ensure inputs are all the same type.\n const inputsList = generic_utils.toList(inputs);\n\n let allAreSymbolic = true;\n for (const input of inputsList) {\n if (!(input instanceof SymbolicTensor)) {\n allAreSymbolic = false;\n break;\n }\n }\n let noneAreSymbolic = true;\n for (const input of inputsList) {\n if (input instanceof SymbolicTensor) {\n noneAreSymbolic = false;\n break;\n }\n }\n\n if (allAreSymbolic === noneAreSymbolic) {\n throw new ValueError(\n 'Arguments to apply() must be all ' +\n 'SymbolicTensors or all Tensors');\n }\n\n // TODO(michaelterry): nameScope() may not be necessary.\n return nameScope(this.name, () => {\n // Handle laying building (weight creating, input spec locking).\n if (!this.built) {\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec specified in the layer constructor.\n */\n this.assertInputCompatibility(inputs);\n\n // Collect input shapes to build layer.\n const inputShapes: Shape[] = [];\n for (const xElem of generic_utils.toList(inputs)) {\n inputShapes.push(xElem.shape);\n }\n this.build(generic_utils.singletonOrArray(inputShapes));\n this.built = true;\n\n // Load weights that were specified at layer instantiation.\n if (this.initialWeights) {\n this.setWeights(this.initialWeights);\n }\n }\n\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec set at build time.\n */\n this.assertInputCompatibility(inputs);\n\n // Handle mask propagation.\n // TODO(michaelterry): Mask propagation not currently implemented.\n\n // Actually call the layer, collecting output(s), mask(s), and shape(s).\n if (noneAreSymbolic) {\n let output = this.call(inputs as Tensor | Tensor[], kwargs);\n // TODO(michaelterry): Compute the outputMask\n\n // If the layer returns tensors from its inputs, unmodified,\n // we copy them to avoid loss of tensor metadata.\n const outputList: Tensor[] = generic_utils.toList(output);\n const outputListCopy: Tensor[] = [];\n // TODO(michaelterry): This copying may not be necessary given our eager\n // backend.\n for (let x of outputList) {\n if (inputsList.indexOf(x) !== -1) {\n x = x.clone();\n }\n outputListCopy.push(x);\n }\n output = generic_utils.singletonOrArray(outputListCopy);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n // TODO(michaelterry): Call addInboundNode()?\n return output;\n } else {\n const inputShape = collectInputShape(inputs);\n const outputShape = this.computeOutputShape(inputShape);\n let output: SymbolicTensor|SymbolicTensor[];\n const outputDType = guessOutputDType(inputs);\n this.warnOnIncompatibleInputShape(\n Array.isArray(inputs) ? inputShape[0] as Shape :\n inputShape as Shape);\n\n if (outputShape != null && outputShape.length > 0 &&\n Array.isArray(outputShape[0])) {\n // We have multiple output shapes. Create multiple output tensors.\n output = (outputShape as Shape[])\n .map(\n (shape, index) => new SymbolicTensor(\n outputDType, shape, this,\n generic_utils.toList(inputs), kwargs, this.name,\n index));\n } else {\n output = new SymbolicTensor(\n outputDType, outputShape as Shape, this,\n generic_utils.toList(inputs), kwargs, this.name);\n }\n\n /*\n Add an inbound node to the layer, so that it keeps track\n of the call and of all new variables created during the call.\n This also updates the layer history of the output tensor(s).\n If the input tensor(s) had no previous history,\n this does nothing.\n */\n this.addInboundNode(\n inputs as SymbolicTensor | SymbolicTensor[], output, null, null,\n inputShape, outputShape, kwargs);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n return output;\n }\n });\n }\n\n /**\n * Check compatibility between input shape and this layer's batchInputShape.\n *\n * Print warning if any incompatibility is found.\n *\n * @param inputShape Input shape to be checked.\n */\n protected warnOnIncompatibleInputShape(inputShape: Shape) {\n if (this.batchInputShape == null) {\n return;\n } else if (inputShape.length !== this.batchInputShape.length) {\n console.warn(\n `The rank of the input tensor provided (shape: ` +\n `${JSON.stringify(inputShape)}) does not match that of the ` +\n `batchInputShape (${JSON.stringify(this.batchInputShape)}) ` +\n `of the layer ${this.name}`);\n } else {\n let dimMismatch = false;\n this.batchInputShape.forEach((dimension, i) => {\n if (dimension != null && inputShape[i] != null &&\n inputShape[i] !== dimension) {\n dimMismatch = true;\n }\n });\n if (dimMismatch) {\n console.warn(\n `The shape of the input tensor ` +\n `(${JSON.stringify(inputShape)}) does not ` +\n `match the expectation of layer ${this.name}: ` +\n `${JSON.stringify(this.batchInputShape)}`);\n }\n }\n }\n\n /**\n * Retrieves the output shape(s) of a layer.\n *\n * Only applicable if the layer has only one inbound node, or if all inbound\n * nodes have the same output shape.\n *\n * @returns Output shape or shapes.\n * @throws AttributeError: if the layer is connected to more than one incoming\n * nodes.\n */\n get outputShape(): Shape|Shape[] {\n if (this.inboundNodes == null || this.inboundNodes.length === 0) {\n throw new AttributeError(\n `The layer ${this.name} has never been called and thus has no ` +\n `defined output shape.`);\n }\n const allOutputShapes: string[] = [];\n for (const node of this.inboundNodes) {\n const shapeString = JSON.stringify(node.outputShapes);\n if (allOutputShapes.indexOf(shapeString) === -1) {\n allOutputShapes.push(shapeString);\n }\n }\n if (allOutputShapes.length === 1) {\n const outputShapes = this.inboundNodes[0].outputShapes;\n if (Array.isArray(outputShapes) && Array.isArray(outputShapes[0]) &&\n outputShapes.length === 1) {\n return (outputShapes as Shape[])[0];\n } else {\n return outputShapes;\n }\n\n } else {\n throw new AttributeError(\n `The layer ${this.name} has multiple inbound nodes with different ` +\n `output shapes. Hence the notion of \"outut shape\" is ill-defined ` +\n `for the layer.`);\n // TODO(cais): Implement getOutputShapeAt().\n }\n }\n\n /**\n * Counts the total number of numbers (e.g., float32, int32) in the\n * weights.\n *\n * @returns An integer count.\n * @throws RuntimeError: If the layer is not built yet (in which case its\n * weights are not defined yet.)\n */\n countParams(): number {\n if (!this.built) {\n throw new RuntimeError(\n `You tried to call countParams() on ${this.name}, ` +\n `but the layer is not built yet. Build it first by calling ` +\n `build(batchInputShape).`);\n }\n return variable_utils.countParamsInWeights(this.weights);\n }\n\n /**\n * Creates the layer weights.\n *\n * Must be implemented on all layers that have weights.\n *\n * Called when apply() is called to construct the weights.\n *\n * @param inputShape A `Shape` or array of `Shape` (unused).\n */\n build(inputShape: Shape|Shape[]) {\n this.built = true;\n }\n\n /**\n * Returns the current values of the weights of the layer.\n *\n * @param trainableOnly Whether to get the values of only trainable weights.\n * @returns Weight values as an `Array` of `Tensor`s.\n */\n getWeights(trainableOnly = false): Tensor[] {\n return batchGetValue(trainableOnly ? this.trainableWeights : this.weights);\n }\n\n /**\n * Sets the weights of the layer, from Tensors.\n *\n * @param weights a list of Tensors. The number of arrays and their shape\n * must match number of the dimensions of the weights of the layer (i.e.\n * it should match the output of `getWeights`).\n *\n * @exception ValueError If the provided weights list does not match the\n * layer's specifications.\n */\n setWeights(weights: Tensor[]): void {\n tidy(() => {\n const params = this.weights;\n if (params.length !== weights.length) {\n // TODO(cais): Restore the following and use `providedWeights`, instead\n // of `weights` in the error message, once the deeplearn.js bug is\n // fixed: https://github.com/PAIR-code/deeplearnjs/issues/498 const\n // providedWeights = JSON.stringify(weights).substr(0, 50);\n throw new ValueError(\n `You called setWeights(weights) on layer \"${this.name}\" ` +\n `with a weight list of length ${weights.length}, ` +\n `but the layer was expecting ${params.length} weights. ` +\n `Provided weights: ${weights}...`);\n }\n if (params.length === 0) {\n return;\n }\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n const paramValues = batchGetValue(params);\n for (let i = 0; i < paramValues.length; ++i) {\n const pv = paramValues[i];\n const p = params[i];\n const w = weights[i];\n if (!util.arraysEqual(pv.shape, w.shape)) {\n throw new ValueError(\n `Layer weight shape ${pv.shape} ` +\n `not compatible with provided weight shape ${w.shape}`);\n }\n weightValueTuples.push([p, w]);\n }\n batchSetValue(weightValueTuples);\n });\n }\n\n /**\n * Adds a weight variable to the layer.\n *\n * @param name Name of the new weight variable.\n * @param shape The shape of the weight.\n * @param dtype The dtype of the weight.\n * @param initializer An initializer instance.\n * @param regularizer A regularizer instance.\n * @param trainable Whether the weight should be trained via backprop or not\n * (assuming that the layer itself is also trainable).\n * @param constraint An optional trainable.\n * @return The created weight variable.\n */\n protected addWeight(\n name: string, shape: Shape, dtype?: DataType, initializer?: Initializer,\n regularizer?: Regularizer, trainable?: boolean,\n constraint?: Constraint): LayerVariable {\n // Reject duplicate weight names.\n if (this._addedWeightNames.indexOf(name) !== -1) {\n throw new ValueError(\n `Duplicate weight name ${name} for layer ${this.name}`);\n }\n this._addedWeightNames.push(name);\n\n if (dtype == null) {\n dtype = 'float32';\n }\n const weight = new LayerVariable(\n initializer.apply(shape, dtype), dtype, name, trainable, constraint);\n // Request backend not to dispose the weights of the model on scope() exit.\n if (regularizer != null) {\n this.addLoss(() => regularizer.apply(weight.read()));\n }\n if (trainable == null) {\n trainable = true;\n }\n if (trainable) {\n this._trainableWeights.push(weight);\n } else {\n this._nonTrainableWeights.push(weight);\n }\n return weight;\n }\n\n /**\n * Add losses to the layer.\n *\n * The loss may potentionally be conditional on some inputs tensors,\n * for instance activity losses are conditional on the layer's inputs.\n */\n addLoss(losses: RegularizerFn|RegularizerFn[]): void {\n if (losses == null || Array.isArray(losses) && losses.length === 0) {\n return;\n }\n // Update this.losses\n losses = generic_utils.toList(losses);\n if (this._losses !== undefined && this._losses !== null) {\n this.losses.push(...losses);\n }\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n if (!this.supportsMasking) {\n if (mask != null) {\n if (Array.isArray(mask)) {\n mask.forEach(maskElement => {\n if (maskElement != null) {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n });\n } else {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n }\n // masking not explicitly supported: return null as mask\n return null;\n }\n // if masking is explictly supported, by default\n // carry over the input mask\n return mask;\n }\n\n /**\n * Internal method to create an inbound node for the layer.\n *\n * @param inputTensors List of input tensors.\n * @param outputTensors List of output tensors.\n * @param inputMasks List of input masks (a mask can be a tensor, or null).\n * @param outputMasks List of output masks (a mask can be a tensor, or null).\n * @param inputShapes List of input shape tuples.\n * @param outputShapes List of output shape tuples.\n * @param kwargs Dictionary of keyword arguments that were passed to the\n * `call` method of the layer at the call that created the node.\n */\n private addInboundNode(\n inputTensors: SymbolicTensor|SymbolicTensor[],\n outputTensors: SymbolicTensor|SymbolicTensor[],\n inputMasks: Tensor|Tensor[], outputMasks: Tensor|Tensor[],\n inputShapes: Shape|Shape[], outputShapes: Shape|Shape[],\n kwargs: {} = null): void {\n const inputTensorList: SymbolicTensor[] =\n generic_utils.toList(inputTensors);\n outputTensors = generic_utils.toList(outputTensors);\n inputMasks = generic_utils.toList(inputMasks);\n outputMasks = generic_utils.toList(outputMasks);\n inputShapes = types_utils.normalizeShapeList(inputShapes);\n outputShapes = types_utils.normalizeShapeList(outputShapes);\n\n // Collect input tensor(s) coordinates.\n const inboundLayers: Layer[] = [];\n const nodeIndices: number[] = [];\n const tensorIndices: number[] = [];\n for (const x of inputTensorList) {\n /*\n * TODO(michaelterry): Keras adds this value to tensors; it's not\n * clear whether we'll use this or not.\n */\n inboundLayers.push(x.sourceLayer as Layer);\n nodeIndices.push(x.nodeIndex);\n tensorIndices.push(x.tensorIndex);\n }\n\n // Create node, add it to inbound nodes.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node(\n {\n outboundLayer: this,\n inboundLayers,\n nodeIndices,\n tensorIndices,\n inputTensors: inputTensorList,\n outputTensors,\n inputMasks,\n outputMasks,\n inputShapes,\n outputShapes\n },\n kwargs);\n\n // Update tensor history\n for (let i = 0; i < outputTensors.length; i++) {\n // TODO(michaelterry: _uses_learning_phase not tracked.\n outputTensors[i].sourceLayer = this;\n outputTensors[i].nodeIndex = this.inboundNodes.length - 1;\n outputTensors[i].tensorIndex = i;\n }\n }\n\n /**\n * Returns the config of the layer.\n *\n * A layer config is a TS dictionary (serializable)\n * containing the configuration of a layer.\n * The same layer can be reinstantiated later\n * (without its trained weights) from this configuration.\n *\n * The config of a layer does not include connectivity\n * information, nor the layer class name. These are handled\n * by 'Container' (one layer of abstraction above).\n *\n * Porting Note: The TS dictionary follows TS naming standrds for\n * keys, and uses tfjs-layers type-safe Enums. Serialization methods\n * should use a helper function to convert to the pythonic storage\n * standard. (see serialization_utils.convertTsToPythonic)\n *\n * @returns TS dictionary of configuration.\n */\n getConfig(): serialization.ConfigDict {\n const config:\n serialization.ConfigDict = {name: this.name, trainable: this.trainable};\n if (this.batchInputShape != null) {\n config['batchInputShape'] = this.batchInputShape;\n }\n if (this.dtype != null) {\n config['dtype'] = this.dtype;\n }\n return config;\n }\n}\n\n/**\n * Collects the input shape(s) of a list of `Tensor`s or `SymbolicTensor`s.\n *\n * TODO(michaelterry): Update PyKeras docs (backport).\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return List of shape tuples (or single tuple), one tuple per input.\n */\nfunction collectInputShape(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): Shape|Shape[] {\n inputTensors =\n generic_utils.toList(inputTensors) as SymbolicTensor[] | Tensor[];\n const shapes: Shape[] = [];\n for (const x of inputTensors) {\n shapes.push(x.shape);\n }\n return generic_utils.singletonOrArray(shapes);\n}\n\n/**\n * Guesses output dtype based on inputs.\n *\n * At present, just returns 'float32' for any input.\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return The guessed DType. At present, always returns 'float32'.\n */\nfunction guessOutputDType(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): DataType {\n return 'float32';\n}\n\n/**\n * Returns the list of input tensors necessary to compute `tensor`.\n *\n * Output will always be a list of tensors (potentially with 1 element).\n *\n * @param tensor The tensor to start from.\n * @param layer Origin layer of the tensor.\n * @param nodeIndex Origin node index of the tensor.\n *\n * @return Array of input tensors.\n */\nexport function getSourceInputs(\n tensor: SymbolicTensor, layer?: Layer,\n nodeIndex?: number): SymbolicTensor[] {\n if (layer == null || (nodeIndex != null && nodeIndex > 0)) {\n layer = tensor.sourceLayer;\n nodeIndex = tensor.nodeIndex;\n }\n if (layer.inboundNodes.length === 0) {\n return [tensor];\n } else {\n const node = layer.inboundNodes[nodeIndex];\n if (node.inboundLayers.length === 0) {\n return node.inputTensors;\n } else {\n const sourceTensors: SymbolicTensor[] = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const previousSources = getSourceInputs(x, layer, nodeIndex);\n // Avoid input redundancy.\n for (const x of previousSources) {\n if (sourceTensors.indexOf(x) === -1) {\n sourceTensors.push(x);\n }\n }\n }\n return sourceTensors;\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {DataType, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\n\nimport {Layer, Node, SymbolicTensor} from './topology';\n\n/**\n * Constructor arguments for InputLayer.\n *\n * Note: You should provide only inputShape or batchInputShape (not both).\n * If only inputShape is provided, then the batchInputShape is determined by\n * the batchSize argument and the inputShape: [batchSize].concat(inputShape).\n */\nexport interface InputLayerConfig {\n /** Input shape, not including the batch axis. */\n inputShape?: Shape;\n /** Optional input batch size (integer or null). */\n batchSize?: number;\n /** Batch input shape, including the batch axis. */\n batchInputShape?: Shape;\n /** Datatype of the input. */\n dtype?: DataType;\n /**\n * Whether the placeholder created is meant to be sparse.\n */\n sparse?: boolean; // TODO(michaelterry): Not clear whether we'll need this.\n\n /** Name of the layer. */\n name?: string;\n}\n\n/**\n * An input layer is an entry point into a `Model`.\n *\n * `InputLayer` is generated automatically for `Sequential` models by specifying\n * the `inputshape` or `batchInputShape` for the first layer. It should not be\n * specified explicitly.\n *\n * ```js\n * // Define a model which simply adds two inputs.\n * const inputA = tf.input({shape: [3]});\n * const inputB = tf.input({shape: [3]});\n * const sum = tf.layers.add().apply([inputA, inputB]);\n * const model = tf.model({inputs: [inputA, inputB], outputs: sum});\n * const batchSize = 2;\n * model.predict([tf.ones([batchSize, 3]), tf.ones([batchSize, 3])]).print();\n * ```\n */\nexport class InputLayer extends Layer {\n static readonly className = 'InputLayer';\n sparse: boolean;\n constructor(config: InputLayerConfig) {\n super({\n dtype: config.dtype,\n name: config.name != null ? config.name : getUid('input').toString()\n });\n // Normalize config.batchSize and config.sparse\n if (config.batchSize == null) {\n config.batchSize = null;\n }\n if (config.sparse == null) {\n config.sparse = false;\n }\n\n this.trainable = false;\n this.built = true;\n this.sparse = config.sparse;\n\n if (config.inputShape != null && config.batchInputShape != null) {\n throw new ValueError(\n 'Only provide the inputShape OR ' +\n 'batchInputShape argument to inputLayer, not both at the same time.');\n }\n let batchInputShape = config.batchInputShape;\n if (batchInputShape == null) {\n if (config.inputShape == null) {\n throw new ValueError(\n 'An InputLayer should be passed either a ' +\n '`batchInputShape` or an `inputShape`.');\n } else {\n batchInputShape = [config.batchSize].concat(config.inputShape);\n }\n } else {\n // TODO(michaelterry): Backport to PyKeras\n if (config.batchSize != null) {\n throw new ValueError(\n 'Cannot specify batchSize if batchInputShape is' +\n 'specified when creating an InputLayer.');\n }\n }\n\n const dtype = config.dtype || 'float32';\n\n this.batchInputShape = batchInputShape;\n this.dtype = dtype;\n // TODO(michaelterry): Backport this to PyKeras?\n this.inputSpec = [{shape: batchInputShape}];\n\n const inputTensor = new SymbolicTensor(\n this.dtype, this.batchInputShape, this, [], {}, this.name);\n inputTensor.nodeIndex = 0;\n inputTensor.tensorIndex = 0;\n\n // Create an input node to add to this.outboundNode.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: [inputTensor],\n outputTensors: [inputTensor],\n inputMasks: [null],\n outputMasks: [null],\n inputShapes: [batchInputShape],\n outputShapes: [batchInputShape]\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor {\n throw new ValueError(\n 'Cannot pass any input to an ' +\n `InputLayer's apply() method. InputLayer name: ${this.name}`);\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n batchInputShape: this.batchInputShape,\n dtype: this.dtype,\n sparse: this.sparse,\n name: this.name\n };\n }\n}\nserialization.SerializationMap.register(InputLayer);\n\n/**\n * Config for the Input function.\n *\n * Note: You should provide only shape or batchShape (not both).\n * If only shape is provided, then the batchShape becomes\n * [null].concat(inputShape).\n */\nexport interface InputConfig {\n /**\n * A shape, not including the batch size. For instance, `shape=[32]`\n * indicates that the expected input will be batches of 32-dimensional\n * vectors.\n */\n shape?: Shape;\n /**\n * A shape tuple (integer), including the batch size. For instance,\n * `batchShape=[10, 32]` indicates that the expected input will be batches of\n * 10 32-dimensional vectors. `batchShape=[null, 32]` indicates batches of an\n * arbitrary number of 32-dimensional vectors.\n */\n batchShape?: Shape;\n /**\n * An optional name string for the layer. Should be unique in a model (do not\n * reuse the same name twice). It will be autogenerated if it isn't provided.\n */\n name?: string;\n dtype?: DataType;\n /**\n * A boolean specifying whether the placeholder to be created is sparse.\n */\n sparse?: boolean;\n}\n\n/**\n * Used to instantiate an input to a model as a `SymbolicTensor`.\n *\n * Users should call the `input` factory function for\n * consistency with other generator functions.\n *\n * Example:\n *\n * ```js\n * // Defines a simple logistic regression model with 32 dimensional input\n * // and 3 dimensional output.\n * const x = tf.input({shape: [32]});\n * const y = tf.layers.dense({units: 3, activation: 'softmax'}).apply(x);\n * const model = tf.model({inputs: x, outputs: y});\n * model.predict(tf.ones([2, 32])).print();\n * ```\n *\n * Note: `input` is only necessary when using `model`. When using\n * `sequential`, specify `inputShape` for the first layer or use `inputLayer`\n * as the first layer.\n */\nexport function Input(config: InputConfig): SymbolicTensor {\n if (config.batchShape == null && config.shape == null) {\n throw new Error(\n 'Please provide to Input either a `shape`' +\n ' or a `batchShape` argument. Note that ' +\n '`shape` does not include the batch ' +\n 'dimension.');\n }\n if (config.batchShape != null && config.shape != null) {\n // TODO(michaelterry): Backport to PyKeras.\n throw new ValueError(\n 'Please provide either a `shape` or `batchShape` ' +\n 'argument to Input, but not both.');\n }\n let batchShape = config.batchShape;\n if (config.shape != null && batchShape == null) {\n batchShape = [null].concat(config.shape);\n }\n\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = 'float32';\n }\n\n const inputLayer = new InputLayer({\n batchInputShape: batchShape,\n name: config.name,\n dtype,\n sparse: config.sparse\n });\n\n const outputs = inputLayer.inboundNodes[0].outputTensors;\n return outputs[0];\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {dispose, Scalar} from '@tensorflow/tfjs-core';\n\n/**\n * Logs in which values can be either numbers or Tensors (Scalars).\n *\n * Used internally.\n */\nexport type UnresolvedLogs = {\n [key: string]: number|Scalar;\n};\n\n/**\n * Turn any Scalar values in a Logs object into actual number values.\n *\n * @param logs The `Logs` object to be resolved in place.\n */\nexport async function resolveScalarsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n const promises: Array> = [];\n const keys: string[] = [];\n const scalarsToDispose: Scalar[] = [];\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n const valueScalar = value as Scalar;\n promises.push(valueScalar.data());\n keys.push(key);\n scalarsToDispose.push(valueScalar);\n }\n }\n const values = await Promise.all(promises);\n for (let i = 0; i < values.length; ++i) {\n logs[keys[i]] = values[i][0];\n }\n\n // Dispose the original scalar tensors.\n dispose(scalarsToDispose);\n}\n\n/**\n * Dispose all Tensors in an UnresolvedLogs object.\n *\n * @param logs An `UnresolvedLogs` object potentially containing `Tensor`s in\n * places where the values can be `Tensor` or `number`.\n */\nexport function disposeTensorsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n value.dispose();\n }\n }\n}\n\n/**\n * Logs in which values can only be numbers.\n *\n * Used when calling client-provided custom callbacks.\n */\nexport type Logs = {\n [key: string]: number;\n};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {add, div, keep, mul, Scalar, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport {Container} from './engine/container';\nimport {Logs, resolveScalarsInLogs, UnresolvedLogs} from './logs';\nimport * as generic_utils from './utils/generic_utils';\n\n\nexport type Params = {\n [key: string]: number|string|boolean|number[]|string[]|boolean[];\n};\n\n/**\n * Abstract base class used to build new callbacks.\n *\n * The `logs` dictionary that callback methods take as argument will contain\n * keys for quantities relevant to the current batch or epoch.\n *\n * Currently, the `.fit()` method of the `Sequential` model class\n * will include the following quantities in the `logs` that\n * it passes to its callbacks:\n *\n * onEpochEnd: Logs include `acc` and `loss`, and optionally include `valLoss`\n * (if validation is enabled in `fit`), and `valAcc` (if validation and\n * accuracy monitoring are enabled).\n * onBatchBegin: Logs include `size`, the number of samples in the current\n * batch.\n * onBatchEnd: Logs include `loss`, and optionally `acc` (if accuracy monitoring\n * is enabled).\n */\nexport abstract class BaseCallback {\n // TODO(michaelterry): This type is a best guess.\n validationData: Tensor|Tensor[] = null;\n /**\n * Training parameters (eg. verbosity, batch size, number of epochs...).\n */\n params: Params;\n\n setParams(params: Params): void {\n this.params = params;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {}\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {}\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {}\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {}\n\n async onTrainBegin(logs?: UnresolvedLogs) {}\n\n async onTrainEnd(logs?: UnresolvedLogs) {}\n\n // Model needs to call Callback.setModel(), but cannot actually depend on\n // Callback because that creates a cyclic dependency. Providing this no-op\n // method on BaseCallback breaks the cycle: this way Model can depend on\n // BaseCallback but not on Callback. The argument is typed as `Container`\n // (the superclass of Model) to avoid recapitulating the cycle. Callback\n // overrides this method and enforces that the argument is really a Model.\n setModel(model: Container): void {\n // Do nothing. Use Callback instead of BaseCallback to track the model.\n }\n}\n\n/**\n * Container abstracting a list of callbacks.\n */\nexport class CallbackList {\n callbacks: BaseCallback[];\n queueLength: number;\n\n // TODO(cais): When the need arises, uncomment the following lines and\n // implement the queue for time values.\n // private deltaTBatch: number;\n // private deltaTsBatchBegin: Array;\n // private deltaTsBatchEnd: Array;\n\n /**\n * Constructor of CallbackList.\n * @param callbacks Array of `Callback` instances.\n * @param queueLength Queue length for keeping running statistics over\n * callback execution time.\n */\n constructor(callbacks?: BaseCallback[], queueLength = 10) {\n // TODO(cais): Make use of queueLength when implementing the queue for time\n // values.\n if (callbacks == null) {\n callbacks = [];\n }\n this.callbacks = callbacks;\n this.queueLength = queueLength;\n }\n\n append(callback: BaseCallback): void {\n this.callbacks.push(callback);\n }\n\n setParams(params: Params): void {\n for (const callback of this.callbacks) {\n callback.setParams(params);\n }\n }\n\n setModel(model: Container): void {\n for (const callback of this.callbacks) {\n callback.setModel(model);\n }\n }\n\n /**\n * Called at the start of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochBegin(epoch, logs);\n }\n }\n\n /**\n * Called at the end of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochEnd(epoch, logs);\n }\n }\n\n /**\n * Called right before processing a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchBegin(batch, logs);\n }\n }\n\n /**\n * Called at the end of a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchEnd(batch, logs);\n }\n }\n\n /**\n * Called at the beginning of training.\n * @param logs Dictionary of logs.\n */\n async onTrainBegin(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainBegin(logs);\n }\n }\n\n /**\n * Called at the end of training.\n * @param logs Dictionary of logs.\n */\n async onTrainEnd(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainEnd(logs);\n }\n }\n}\n\n\n/**\n * Callback that accumulates epoch averages of metrics.\n *\n * This callback is automatically applied to every Model.\n */\nexport class BaseLogger extends BaseCallback {\n private seen: number;\n private totals: UnresolvedLogs;\n\n constructor() {\n super();\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n this.seen = 0;\n this.totals = {};\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n const batchSize = logs['size'] == null ? 0 : logs['size'] as number;\n this.seen += batchSize;\n for (const key in logs) {\n const value = logs[key];\n if (typeof value === 'number') {\n if (!this.totals.hasOwnProperty(key)) {\n this.totals[key] = 0;\n }\n this.totals[key] = this.totals[key] as number + value * batchSize;\n } else {\n let oldTotalsToDispose: Scalar;\n if (key in this.totals) {\n oldTotalsToDispose = this.totals[key] as Scalar;\n } else {\n this.totals[key] = getScalar(0);\n }\n\n this.totals[key] = tidy(\n () => add((this.totals[key] as Scalar),\n mul(value, getScalar(batchSize))) as Scalar);\n if (oldTotalsToDispose != null) {\n oldTotalsToDispose.dispose();\n }\n }\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs != null) {\n for (const key of this.params['metrics'] as string[]) {\n if (this.totals[key] == null) {\n continue;\n }\n if (typeof this.totals[key] === 'number') {\n logs[key] = this.totals[key] as number / this.seen;\n } else {\n tidy(() => {\n logs[key] = mul(div(getScalar(1), getScalar(this.seen)) as Scalar,\n this.totals[key] as Scalar) as Scalar;\n (this.totals[key] as Tensor).dispose();\n keep(logs[key] as Scalar);\n });\n }\n }\n }\n }\n}\n\n/**\n * Callback that records events into a `History` object. This callback is\n * automatically applied to every TF.js Layers model. The `History` object gets\n * returned by the `fit` method of models.\n */\nexport class History extends BaseCallback {\n epoch: number[];\n history: {[key: string]: Array};\n\n async onTrainBegin(logs?: UnresolvedLogs) {\n this.epoch = [];\n this.history = {};\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n this.epoch.push(epoch);\n for (const key in logs) {\n if (this.history[key] == null) {\n this.history[key] = [];\n }\n this.history[key].push(logs[key]);\n }\n }\n\n /**\n * Await the values of all losses and metrics.\n */\n async syncData() {\n const promises: Array> = [];\n const keys: string[] = [];\n const indices: number[] = [];\n for (const key in this.history) {\n const valueArray = this.history[key];\n for (let i = 0; i < valueArray.length; ++i) {\n if (typeof valueArray[i] !== 'number') {\n const valueScalar = valueArray[i] as Tensor;\n promises.push(valueScalar.data());\n keys.push(key);\n indices.push(i);\n }\n }\n }\n const values = await Promise.all(promises);\n for (let n = 0; n < values.length; ++n) {\n const tensorToDispose = this.history[keys[n]][indices[n]] as Tensor;\n tensorToDispose.dispose();\n this.history[keys[n]][indices[n]] = values[n][0];\n }\n }\n}\n\nexport interface CustomCallbackConfig {\n onTrainBegin?: (logs?: Logs) => Promise;\n onTrainEnd?: (logs?: Logs) => Promise;\n onEpochBegin?: (epoch: number, logs?: Logs) => Promise;\n onEpochEnd?: (epoch: number, logs?: Logs) => Promise;\n onBatchBegin?: (batch: number, logs?: Logs) => Promise;\n onBatchEnd?: (batch: number, logs?: Logs) => Promise;\n}\n\n/**\n * Custom callback for training.\n */\nexport class CustomCallback extends BaseCallback {\n protected readonly trainBegin: (logs?: Logs) => Promise;\n protected readonly trainEnd: (logs?: Logs) => Promise;\n protected readonly epochBegin: (epoch: number, logs?: Logs) => Promise;\n protected readonly epochEnd: (epoch: number, logs?: Logs) => Promise;\n protected readonly batchBegin: (batch: number, logs?: Logs) => Promise;\n protected readonly batchEnd: (batch: number, logs?: Logs) => Promise;\n\n constructor(config: CustomCallbackConfig) {\n super();\n this.trainBegin = config.onTrainBegin;\n this.trainEnd = config.onTrainEnd;\n this.epochBegin = config.onEpochBegin;\n this.epochEnd = config.onEpochEnd;\n this.batchBegin = config.onBatchBegin;\n this.batchEnd = config.onBatchEnd;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.epochBegin(epoch, logs as Logs);\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.epochEnd(epoch, logs as Logs);\n }\n }\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.batchBegin(batch, logs as Logs);\n }\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.batchEnd(batch, logs as Logs);\n }\n }\n\n async onTrainBegin(logs?: UnresolvedLogs): Promise {\n if (this.trainBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.trainBegin(logs as Logs);\n }\n }\n\n async onTrainEnd(logs?: UnresolvedLogs): Promise {\n if (this.trainEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.trainEnd(logs as Logs);\n }\n }\n}\n\n/**\n * Standardize callbacks or configurations of them to an Array of callbacks.\n */\nexport function standardizeCallbacks(callbacks: BaseCallback|BaseCallback[]|\n CustomCallbackConfig|\n CustomCallbackConfig[]): BaseCallback[] {\n if (callbacks == null) {\n return null;\n }\n if (callbacks instanceof BaseCallback) {\n return [callbacks as BaseCallback];\n }\n if (Array.isArray(callbacks) && callbacks[0] instanceof BaseCallback) {\n return callbacks as BaseCallback[];\n }\n // Convert custom callback configs to custom callback objects.\n const callbackConfigs =\n generic_utils.toList(callbacks) as CustomCallbackConfig[];\n return callbackConfigs.map(\n callbackConfig => new CustomCallback(callbackConfig));\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: losses.py */\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor, Tensor1D, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {ValueError} from './errors';\nimport {LossOrMetricFn} from './types';\n\n\n/**\n * Normalizes a tensor wrt the L2 norm alongside the specified axis.\n * @param x\n * @param axis Axis along which to perform normalization.\n */\nexport function l2Normalize(x: Tensor, axis?: number): Tensor {\n return tidy(() => {\n const squareSum = tfc.sum(K.square(x), axis, true);\n const epsilonTensor = tfc.mul(scalar(epsilon()), tfc.onesLike(x));\n const norm = tfc.sqrt(tfc.maximum(squareSum, epsilonTensor));\n return tfc.div(x, norm);\n });\n}\n\n/**\n * Loss or metric function: Mean squared error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [3, 4]]);\n * const yPred = tf.tensor2d([[0, 1], [-3, -4]]);\n * const mse = tf.metrics.meanSquaredError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MSE`, `tf.metrics.mse`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean squared error Tensor.\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(K.square(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute error.\n *\n * Mathematically, mean absolute error is defined as:\n * `mean(abs(yPred - yTrue))`,\n * wherein the `mean` is applied over feature dimensions.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [0, 0], [2, 3]]);\n * const yPred = tf.tensor2d([[0, 1], [0, 1], [-2, -3]]);\n * const mse = tf.metrics.meanAbsoluteError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute error Tensor.\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(tfc.abs(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute percentage error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [10, 20]]);\n * const yPred = tf.tensor2d([[0, 1], [11, 24]]);\n * const mse = tf.metrics.meanAbsolutePercentageError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MAPE`, `tf.metrics.mape`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute percentage error Tensor.\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const diff = tfc.sub(yTrue, yPred);\n const clippedTrue =\n tfc.clipByValue(tfc.abs(yTrue), epsilon(), Number.MAX_VALUE);\n const absResult = tfc.abs(tfc.div(diff, clippedTrue));\n return tfc.mul(getScalar(100.0), tfc.mean(absResult, -1));\n });\n}\n\nexport function meanSquaredLogarithmicError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const one = getScalar(1.0);\n\n const clippedPred = tfc.clipByValue(yPred, epsilon(), Number.MAX_VALUE);\n const firstLog = tfc.log(tfc.add(one, clippedPred));\n\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), Number.MAX_VALUE);\n const secondLog = tfc.log(tfc.add(one, clippedTrue));\n\n return tfc.mean(K.square(tfc.sub(firstLog, secondLog)), -1);\n });\n}\n\nexport function squaredHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(K.square(maxResult), -1);\n });\n}\n\nexport function hinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(maxResult, -1);\n });\n}\n\nexport function categoricalHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const pos = tfc.sum(tfc.mul(yTrue, yPred), -1);\n const neg = tfc.max(tfc.mul(tfc.sub(one, yTrue), yPred), -1);\n return tfc.maximum(zeroTensor, tfc.add(one, tfc.sub(neg, pos)));\n });\n}\n\n/**\n * Logarithm of the hyperbolic cosine of the prediction error.\n *\n * `log(cosh(x))` is approximately equal to `(x ** 2) / 2` for small `x` and\n * to `abs(x) - log(2)` for large `x`. This means that 'logcosh' works mostly\n * like the mean squared error, but will not be so strongly affected by the\n * occasional wildly incorrect prediction.\n */\nexport function logcosh(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const log2 = getScalar(Math.log(2.0));\n const predictionDiff = tfc.sub(yPred, yTrue);\n const logcoshResult = tfc.sub(\n tfc.add(\n predictionDiff,\n tfc.softplus(tfc.mul(getScalar(-2.0), predictionDiff))),\n log2);\n return tfc.mean(logcoshResult, -1);\n });\n}\n\n/**\n * Categorical crossentropy between an output tensor and a target tensor.\n *\n * @param target A tensor of the same shape as `output`.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function categoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n if (fromLogits) {\n output = tfc.softmax(output);\n } else {\n // scale preds so that the class probabilities of each sample sum to 1.\n const outputSum = tfc.sum(output, output.shape.length - 1, true);\n output = tfc.div(output, outputSum);\n }\n output = tfc.clipByValue(output, epsilon(), 1 - epsilon());\n return tfc.neg(tfc.sum(\n tfc.mul(target.toFloat(), tfc.log(output)), output.shape.length - 1));\n });\n}\n\n/**\n * Categorical crossentropy with integer targets.\n *\n * @param target An integer tensor.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function sparseCategoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n const flatTarget = tfc.floor(K.flatten(target)).toInt() as Tensor1D;\n const outputShape = output.shape;\n const oneHotTarget =\n tfc.oneHot(flatTarget, outputShape[outputShape.length - 1])\n .reshape(outputShape);\n return categoricalCrossentropy(oneHotTarget, output, fromLogits);\n });\n}\n\n/**\n * From TensorFlow's implementation in nn_impl.py:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n * Hence, to ensure stability and avoid overflow, the implementation uses this\n * equivalent formulation\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n *\n * @param target The labels.\n * @param output The logits.\n */\nexport function sigmoidCrossEntropyWithLogits(\n target: Tensor, output: Tensor): Tensor {\n return tidy(() => {\n const maxOutput = tfc.maximum(output, tfc.zerosLike(output));\n const outputXTarget = tfc.mul(output, target);\n const sigmoidOutput =\n tfc.log(tfc.add(getScalar(1), tfc.exp(tfc.neg(tfc.abs(output)))));\n const result = tfc.add(tfc.sub(maxOutput, outputXTarget), sigmoidOutput);\n return result;\n });\n}\n\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n let y: Tensor;\n y = tfc.clipByValue(yPred, epsilon(), 1 - epsilon());\n y = tfc.log(tfc.div(y, tfc.sub(tfc.onesLike(y), y)));\n return tfc.mean(sigmoidCrossEntropyWithLogits(yTrue, y), -1);\n });\n}\n\nexport function kullbackLeiblerDivergence(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), 1);\n const clippedPred = tfc.clipByValue(yPred, epsilon(), 1);\n return tfc.sum(\n tfc.mul(yTrue, tfc.log(tfc.div(clippedTrue, clippedPred))), -1);\n });\n}\n\nexport function poisson(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const logPred = tfc.log(tfc.add(getScalar(epsilon()), yPred));\n return tfc.mean(tfc.sub(yPred, tfc.mul(yTrue, logPred)), -1);\n });\n}\n\n/**\n * Loss or metric function: Cosine proximity.\n *\n * Mathematically, cosine proximity is defined as:\n * `-sum(l2Normalize(yTrue) * l2Normalize(yPred))`,\n * wherein `l2Normalize()` normalizes the L2 norm of the input to 1 and `*`\n * represents element-wise multiplication.\n *\n * ```js\n * const yTrue = tf.tensor2d([[1, 0], [1, 0]]);\n * const yPred = tf.tensor2d([[1 / Math.sqrt(2), 1 / Math.sqrt(2)], [0, 1]]);\n * const proximity = tf.metrics.cosineProximity(yTrue, yPred);\n * proximity.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Cosine proximity Tensor.\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const trueNormalized = l2Normalize(yTrue, -1);\n const predNormalized = l2Normalize(yPred, -1);\n const trueXPred = tfc.mul(trueNormalized, predNormalized);\n return tfc.neg(tfc.sum(trueXPred, -1));\n });\n}\n\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const msle = meanSquaredLogarithmicError;\nexport const MSLE = meanSquaredLogarithmicError;\nexport const kld = kullbackLeiblerDivergence;\nexport const KLD = kullbackLeiblerDivergence;\nexport const cosine = cosineProximity;\n\n// TODO(michaelterry): Add deserialize() function.\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function get(identifierOrFn: string|LossOrMetricFn): LossOrMetricFn {\n const lossesMap: {[functionName: string]: LossOrMetricFn} = {\n meanSquaredError,\n meanAbsoluteError,\n meanAbsolutePercentageError,\n meanSquaredLogarithmicError,\n squaredHinge,\n hinge,\n categoricalHinge,\n logcosh,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n binaryCrossentropy,\n kullbackLeiblerDivergence,\n poisson,\n cosineProximity\n };\n if (typeof identifierOrFn === 'string') {\n if (identifierOrFn in lossesMap) {\n return lossesMap[identifierOrFn];\n }\n throw new ValueError(`Unknown loss ${identifierOrFn}`);\n } else {\n return identifierOrFn;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Built-in metrics.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {NotImplementedError, ValueError} from './errors';\nimport {categoricalCrossentropy as categoricalCrossentropyLoss, cosineProximity, meanAbsoluteError, meanAbsolutePercentageError, meanSquaredError, sparseCategoricalCrossentropy as sparseCategoricalCrossentropyLoss} from './losses';\nimport {binaryCrossentropy as lossBinaryCrossentropy} from './losses';\nimport {LossOrMetricFn} from './types';\n// tslint:enable:max-line-length\n\n/**\n * Binary accuracy metric function.\n *\n * `yTrue` and `yPred` can have 0-1 values. Example:\n * ```js\n * const x = tensor2d([[1, 1, 1, 1], [0, 0, 0, 0]], [2, 4]);\n * const y = tensor2d([[1, 0, 1, 0], [0, 0, 0, 1]], [2, 4]);\n * const accuracy = tfl.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * `yTrue` and `yPred` can also have floating-number values between 0 and 1, in\n * which case the values will be thresholded at 0.5 to yield 0-1 values (i.e.,\n * a value >= 0.5 and <= 1.0 is interpreted as 1.\n * )\n * Example:\n * ```js\n * const x = tensor1d([1, 1, 1, 1, 0, 0, 0, 0]);\n * const y = tensor1d([0.2, 0.4, 0.6, 0.8, 0.2, 0.3, 0.4, 0.7]);\n * const accuracy = tf.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction.\n * @return Accuracy Tensor.\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const threshold = tfc.mul(getScalar(0.5), tfc.onesLike(yPred));\n const yPredThresholded = K.cast(tfc.greater(yPred, threshold), yTrue.dtype);\n return tfc.mean(tfc.equal(yTrue, yPredThresholded), -1);\n });\n}\n\n/**\n * Categorical accuracy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0, 0, 0, 1], [0, 0, 0, 1]]);\n * const y = tensor2d([[0.1, 0.8, 0.05, 0.05], [0.1, 0.05, 0.05, 0.8]]);\n * const accuracy = tf.metrics.categoricalAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth: one-hot encoding of categories.\n * @param yPred Binary Tensor of prediction: probabilities or logits for the\n * same categories as in `yTrue`.\n * @return Accuracy Tensor.\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(\n () => K.cast(\n tfc.equal(tfc.argMax(yTrue, -1), tfc.argMax(yPred, -1)), 'float32'));\n}\n\n/**\n * Binary crossentropy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0], [1], [1], [1]]);\n * const y = tensor2d([[0], [0], [0.5], [1]]);\n * const crossentropy = tf.metrics.binaryCrossentropy(x, y);\n * crossentropy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction, probabilities for the `1` case.\n * @return Accuracy Tensor.\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return lossBinaryCrossentropy(yTrue, yPred);\n}\n\nexport function sparseCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function topKCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function sparseTopKCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\n// Aliases.\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const categoricalCrossentropy = categoricalCrossentropyLoss;\nexport const cosine = cosineProximity;\nexport const sparseCategoricalCrossentropy = sparseCategoricalCrossentropyLoss;\n\n// TODO(cais, nielsene): Add serialize().\n\nexport function get(identifier: string|LossOrMetricFn): LossOrMetricFn {\n const metricsMap: {[functionName: string]: LossOrMetricFn} = {\n binaryAccuracy,\n categoricalAccuracy,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n mse,\n MSE,\n mae,\n MAE,\n mape,\n MAPE,\n cosine,\n };\n if (typeof identifier === 'string' && identifier in metricsMap) {\n return metricsMap[identifier];\n } else if (typeof identifier !== 'string' && identifier != null) {\n return identifier;\n } else {\n throw new ValueError(`Unknown metric ${identifier}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Optimizers.\n */\n\n// tslint:disable:max-line-length\nimport {Optimizer, train} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\n// tslint:enable:max-line-length\n\nimport {ValueError} from './errors';\n\n// Add (de)serialize()\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function getOptimizer(identifier: string): Optimizer {\n const optimizerMap: {[optimizerName: string]: () => Optimizer} = {\n 'Adagrad': () => train.adagrad(0.01),\n 'Adadelta': () => train.adadelta(1, 0.95, epsilon()),\n 'Adam': () => train.adam(0.001, 0.9, 0.999, epsilon()),\n 'Adamax': () => train.adamax(0.002, 0.9, 0.999, epsilon(), 0),\n 'RMSProp': () => train.rmsprop(0.001, 0.9, 0, epsilon()),\n 'SGD': () => train.sgd(0.01)\n };\n optimizerMap['adagrad'] = optimizerMap['Adagrad'];\n optimizerMap['adadelta'] = optimizerMap['Adadelta'];\n optimizerMap['adam'] = optimizerMap['Adam'];\n optimizerMap['adamax'] = optimizerMap['Adamax'];\n optimizerMap['rmsprop'] = optimizerMap['RMSProp'];\n optimizerMap['sgd'] = optimizerMap['SGD'];\n\n if (identifier in optimizerMap) {\n return optimizerMap[identifier]();\n }\n throw new ValueError(`Unknown Optimizer ${identifier}`);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {Container} from '../engine/container';\nimport {Layer, Node} from '../engine/topology';\nimport {countParamsInWeights} from './variable_utils';\n\n/**\n * Print the summary of a Model object.\n *\n * @param model tf.Model instance.\n * @param lineLength Total length of printed lines. Set this to adapt to the\n * display to different terminal or console sizes.\n * @param positions Relative or absolute positions of log elements in each\n * line. Each number corresponds to right-most (i.e., ending) position of a\n * column.\n * If not provided, defaults to `[0.45, 0.85, 1]` for sequential-like\n * models and `[0.33, 0.55, 0.67, 1]` for non-sequential like models.\n * @param printFn Print function to use.\n * It will be called on each line of the summary. You can provide a custom\n * function in order to capture the string summary. Defaults to `console.log`.\n */\nexport function printSummary(\n model: Container, lineLength?: number, positions?: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void =\n console.log): void {\n const sequentialLike = isModelSequentialLike(model);\n\n // Header names for different log elements.\n const toDisplay: string[] = ['Layer (type)', 'Output shape', 'Param #'];\n if (sequentialLike) {\n lineLength = lineLength || 65;\n positions = positions || [0.45, 0.85, 1];\n } else {\n lineLength = lineLength || 98;\n positions = positions || [0.33, 0.55, 0.67, 1];\n // Header names for different log elements.\n }\n\n if (positions[positions.length - 1] <= 1) {\n // `positions` is relative. Convert it to absolute positioning.\n positions = positions.map(p => Math.floor(lineLength * p));\n }\n\n let relevantNodes: Node[];\n if (!sequentialLike) {\n toDisplay.push('Receives inputs');\n relevantNodes = [];\n for (const depth in model.nodesByDepth) {\n relevantNodes.push(...model.nodesByDepth[depth]);\n }\n }\n\n printFn('_'.repeat(lineLength));\n printRow(toDisplay, positions, printFn);\n printFn('='.repeat(lineLength));\n\n const layers = model.layers;\n for (let i = 0; i < layers.length; ++i) {\n if (sequentialLike) {\n printLayerSummary(layers[i], positions, printFn);\n } else {\n printLayerSummaryWithConnections(\n layers[i], positions, relevantNodes, printFn);\n }\n printFn((i === layers.length - 1 ? '=' : '_').repeat(lineLength));\n }\n\n // tslint:disable-next-line:no-any\n (model as any).checkTrainableWeightsConsistency();\n let trainableCount: number;\n // tslint:disable:no-any\n if ((model as any).collectedTrainableWeights != null) {\n trainableCount =\n countParamsInWeights((model as any).collectedTrainableWeights);\n } else {\n trainableCount = countParamsInWeights(model.trainableWeights);\n }\n // tslint:enable:no-any\n const nonTrainableCount = countParamsInWeights(model.nonTrainableWeights);\n\n printFn(`Total params: ${trainableCount + nonTrainableCount}`);\n printFn(`Trainable params: ${trainableCount}`);\n printFn(`Non-trainable params: ${nonTrainableCount}`);\n printFn('_'.repeat(lineLength));\n}\n\nfunction isModelSequentialLike(model: Container): boolean {\n let sequentialLike = true;\n const nodesByDepth: Node[][] = [];\n const nodes: Node[] = [];\n for (const depth in model.nodesByDepth) {\n nodesByDepth.push(model.nodesByDepth[depth]);\n }\n for (const depthNodes of nodesByDepth) {\n if (depthNodes.length > 1 ||\n depthNodes.length === 1 && depthNodes[0].inboundLayers.length > 1) {\n sequentialLike = false;\n break;\n }\n nodes.push(...depthNodes);\n }\n if (sequentialLike) {\n // Search for shared layers.\n for (const layer of model.layers) {\n let flag = false;\n for (const node of layer.inboundNodes) {\n if (nodes.indexOf(node) !== -1) {\n if (flag) {\n sequentialLike = false;\n break;\n } else {\n flag = true;\n }\n }\n }\n if (!sequentialLike) {\n break;\n }\n }\n }\n return sequentialLike;\n}\n\nfunction printRow(\n fields: string[], positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void = console.log) {\n let line = '';\n for (let i = 0; i < fields.length; ++i) {\n if (i > 0) {\n line = line.slice(0, line.length - 1) + ' ';\n }\n line += fields[i];\n line = line.slice(0, positions[i]);\n line += ' '.repeat(positions[i] - line.length);\n }\n printFn(line);\n}\n\n/**\n * Prints a summary for a single Layer, without connectivity information.\n *\n * @param layer: Layer instance to print.\n */\nfunction printLayerSummary(\n layer: Layer, positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const name = layer.name;\n const className = layer.getClassName();\n const fields: string[] =\n [`${name} (${className})`, outputShape, layer.countParams().toString()];\n printRow(fields, positions, printFn);\n}\n\n/**\n * Prints a summary for a single Layer, with connectivity information.\n */\nfunction printLayerSummaryWithConnections(\n layer: Layer, positions: number[], relevantNodes: Node[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const connections: string[] = [];\n for (const node of layer.inboundNodes) {\n if (relevantNodes != null && relevantNodes.length > 0 &&\n relevantNodes.indexOf(node) === -1) {\n continue;\n }\n for (let i = 0; i < node.inboundLayers.length; ++i) {\n const inboundLayer = node.inboundLayers[i].name;\n const inboundLayerIndex = node.nodeIndices[i];\n const inboundTensorIndex = node.tensorIndices[i];\n connections.push(\n `${inboundLayer}[${inboundLayerIndex}][${inboundTensorIndex}]`);\n }\n }\n const name = layer.name;\n const className = layer.getClassName();\n const firstConnection = connections.length === 0 ? '' : connections[0];\n const fields: string[] = [\n `${name} (${className})`, outputShape, layer.countParams().toString(),\n firstConnection\n ];\n\n printRow(fields, positions, printFn);\n for (let i = 1; i < connections.length; ++i) {\n printRow(['', '', '', connections[i]], positions, printFn);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source layers/__init__.py */\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {deserializeKerasObject} from '../utils/generic_utils';\n\n/**\n * Instantiate a layer from a config dictionary.\n * @param config: dict of the form {class_name: str, config: dict}\n * @param custom_objects: dict mapping class names (or function names)\n * of custom (non-Keras) objects to class/functions\n * @returns Layer instance (may be Model, Sequential, Layer...)\n */\nexport function deserialize(\n config: serialization.ConfigDict,\n customObjects = {} as\n serialization.ConfigDict): serialization.Serializable {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'layer');\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Porting note: This file doesn't exist in PyKeras.\n// Its purpose here is to centralize the boundary layer between\n// tfjs-layers's internal Config TS-Centric format and PyKeras's\n// serialized Python Config format.\n\n// tslint:disable:max-line-length\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {JsonValue} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\n// tslint:enable\n\n/**\n * Test whether a value in an array is the name of a Model or Layer.\n * @param key The key name that the value is found under. Note that the key\n * may not be at the level immediately above the value, if the value is in a\n * nested array.\n * @param index Index of the value in the Array that it is found in.\n * @param value The value object.\n * @returns A boolean indicating whether value is a name.\n */\nfunction isArrayItemInputOrOutputName(\n key: string, index: number, value: T): boolean {\n return (key === 'inboundNodes' || key === 'outputLayers' ||\n key === 'inputLayers') &&\n index === 0 && typeof value === 'string';\n}\n\n/**\n * Convert a Pythonic config object to TypeScript config object.\n * @param pythonicConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertPythonicToTs(\n pythonicConfig: JsonValue, key?: string): serialization.ConfigDictValue {\n if (pythonicConfig === null) {\n return null;\n } else if (typeof pythonicConfig === 'string') {\n return generic_utils.toCamelCase(pythonicConfig);\n } else if (\n (typeof pythonicConfig === 'number') ||\n (typeof pythonicConfig === 'boolean')) {\n return pythonicConfig;\n } else if (pythonicConfig instanceof Array) {\n const tsArray = [];\n const arrayLength = pythonicConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = pythonicConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n tsArray.push(item);\n } else {\n tsArray.push(convertPythonicToTs(item, key));\n }\n }\n return tsArray;\n } else {\n const tsDict: serialization.ConfigDict = {};\n for (const pythonicKey of Object.keys(pythonicConfig)) {\n const pythonicValue = pythonicConfig[pythonicKey];\n if (pythonicKey === 'name' && typeof pythonicValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // camel-case conversion.\n tsDict[pythonicKey] = pythonicValue;\n } else {\n const tsKey = generic_utils.toCamelCase(pythonicKey);\n tsDict[tsKey] = convertPythonicToTs(pythonicValue, tsKey);\n }\n }\n return tsDict;\n }\n}\n\n/**\n * Convert a TypeScript config object to Python config object.\n * @param tsConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertTsToPythonic(\n tsConfig: serialization.ConfigDictValue, key?: string): JsonValue {\n if (tsConfig === null || tsConfig === undefined) {\n return null;\n } else if (typeof tsConfig === 'string') {\n return generic_utils.toSnakeCase(tsConfig);\n } else if (\n (typeof tsConfig === 'number') || (typeof tsConfig === 'boolean')) {\n return tsConfig;\n } else if (tsConfig instanceof Array) {\n const pyArray = [];\n const arrayLength = tsConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = tsConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n pyArray.push(item);\n } else {\n pyArray.push(convertTsToPythonic(item, key));\n }\n }\n return pyArray;\n } else {\n const pyDict: serialization.ConfigDict = {};\n for (const tsKey of Object.keys(tsConfig)) {\n const tsValue = tsConfig[tsKey];\n const pyKey = generic_utils.toSnakeCase(tsKey);\n if ((tsKey === 'name' || tsKey === 'className') &&\n typeof tsValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // snake-case conversion.\n pyDict[pyKey] = tsValue;\n } else {\n pyDict[pyKey] = convertTsToPythonic(tsValue, tsKey);\n }\n }\n return pyDict;\n }\n}\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.7.2';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {deserialize as deserializeLayer} from '../layers/serialization';\nimport {JsonDict, Kwargs, NamedTensorMap, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {convertTsToPythonic} from '../utils/serialization_utils';\nimport * as types_utils from '../utils/types_utils';\nimport {batchSetValue, LayerVariable} from '../variables';\nimport {version as layersVersion} from '../version';\n\nimport {InputLayer} from './input_layer';\nimport {Layer, Node, SymbolicTensor} from './topology';\n// tslint:enable:max-line-length\n\n/**\n * Converts layers weights to a format suitable for TensorFlow.js Layers.\n *\n * Porting Note: The function `preprocess_weights_for_loading()` in PyKeras\n * performs conversion from Keras 1 to Keras 2. But in TypeScript, we\n * require Keras version to be 2. Thus this conversion is not applicable. We\n * simply check the Keras version and pass the weights through.\n *\n * @param layer Layer instance.\n * @param weights Input weights.\n * @param originalKerasVersion Keras version for the weights.\n * @param originalBackend Keras backend the weights were trained with.\n * @returns Output weights as Tensors.\n */\nfunction preprocessWeightsForLoading(\n layer: Layer, weights: LayerVariable[], originalKerasVersion?: string,\n originalBackend?: string): LayerVariable[] {\n if (!originalKerasVersion.startsWith('2.')) {\n throw new ValueError(\n 'Unsupported Keras version in weights being loaded: ' +\n originalKerasVersion);\n }\n return weights;\n}\n\n/**\n * Create an Tensor from info about dtype, shape and values.\n * @param dtype DType string.\n * @param shape Shape.\n * @param value Values of the array, as a scalar or nested Array of proper\n * shape.\n * @returns An Tensor instance.\n */\n// tslint:disable-next-line:no-any\nfunction loadTensor(dtype: string, shape: Shape, value: any): Tensor {\n const dataType = generic_utils.stringToDType(dtype);\n return Tensor.make(\n shape, {values: shape.length === 0 ? value : util.flatten(value)},\n dataType);\n}\n\n// TODO(cais): Maybe remove the following (b/74015805).\n/**\n * Load weights from a weights JSON object to an array of layers.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weightsJSON. The input JSON object represent the weights from a\n * trained Keras model. See scripts/pykeras.py for more details.\n * @param layers An array of target layers.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weights.\n */\nexport function loadWeightsFromJson(\n weightsJSON: JsonDict, layers: Layer[], skipMismatch = false): void {\n const originalKerasVersion = weightsJSON['keras_version'] as string;\n const originalBackend = weightsJSON['backend'] as string;\n const layerNames = layers.map(layer => layer.name);\n\n // Reverse index of layer name to list of layers with name.\n const index: {[layerName: string]: Layer[]} = {};\n for (const layer of layers) {\n if (layer.name != null) {\n if (index[layer.name] == null) {\n index[layer.name] = [];\n }\n index[layer.name].push(layer);\n }\n }\n\n // tslint:disable-next-line:no-any\n const nameToWeights = weightsJSON['weights'] as {[name: string]: any};\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (let k = 0; k < layerNames.length; ++k) {\n const name = layerNames[k];\n let layerWeights = nameToWeights[name];\n if (layerWeights == null) {\n layerWeights = [];\n }\n\n let weightValues: LayerVariable[] = [];\n for (let n = 0; n < layerWeights.length; ++n) {\n // tslint:disable:no-any\n const weightEntry =\n layerWeights[n] as {[key: string]: string | Shape | any};\n // tslint:enable\n weightValues.push(new LayerVariable(loadTensor(\n weightEntry['dtype'], weightEntry['shape'] as Shape,\n weightEntry['value'])));\n }\n for (const layer of index[name]) {\n const symbolicWeights = layer.weights;\n weightValues = preprocessWeightsForLoading(\n layer, weightValues, originalKerasVersion, originalBackend);\n if (weightValues.length !== symbolicWeights.length) {\n if (skipMismatch) {\n console.warn(\n `Skipping loading of weights of layer ${layer.name} ` +\n `due to mismatch in number of weights: (${weightValues.length} ` +\n `vs ${symbolicWeights.length}).`);\n } else {\n throw new ValueError(\n `Layer #${k} (named \"${layer.name}\") expects ` +\n `${symbolicWeights.length} weight(s), but the saved weights ` +\n `have ${weightValues.length} element(s).`);\n }\n }\n\n // Set values.\n for (let i = 0; i < weightValues.length; ++i) {\n if (skipMismatch) {\n if (!util.arraysEqual(\n symbolicWeights[i].shape, weightValues[i].shape)) {\n console.warn(\n `Skipping loading of weights for layer ${layer.name} due ` +\n `to mismatch in shape (${symbolicWeights[i].shape} vs ` +\n `${weightValues[i].shape})`);\n continue;\n }\n }\n weightValueTuples.push([symbolicWeights[i], weightValues[i].read()]);\n }\n }\n }\n batchSetValue(weightValueTuples);\n}\n\n/**\n * Load weights from a named tensor map.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weights The named tensor map mapping names of weights to weight\n * values.\n * @param layers An array of target layers.\n */\nexport function loadWeightsFromNamedTensorMap(\n weights: NamedTensorMap, layers: Layer[]): void {\n // Make a dictionary mapping weight name to weight.\n const nameToWeight: {[name: string]: LayerVariable} = {};\n let totalWeightsCount = 0;\n for (const layer of layers) {\n for (const weight of layer.weights) {\n if (nameToWeight[weight.originalName] != null) {\n throw new ValueError(`Duplicate weight name: ${weight.originalName}`);\n }\n nameToWeight[weight.originalName] = weight;\n totalWeightsCount++;\n }\n }\n\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (const name in weights) {\n weightValueTuples.push([nameToWeight[name], weights[name]]);\n delete nameToWeight[name];\n }\n\n // Check that all weights are set.\n const unsetNames: string[] = [];\n for (const name in nameToWeight) {\n unsetNames.push(name);\n }\n if (unsetNames.length > 0) {\n throw new ValueError(\n `${unsetNames.length} of ${totalWeightsCount} weights are not set: ` +\n `${unsetNames}`);\n }\n\n batchSetValue(weightValueTuples);\n}\n\n/** Constructor config for Container. */\nexport interface ContainerConfig {\n inputs: SymbolicTensor|SymbolicTensor[];\n outputs: SymbolicTensor|SymbolicTensor[];\n name?: string;\n}\n\n/**\n * A Container is a directed acyclic graph of layers.\n *\n * It is the topological form of a \"model\". A Model\n * is simply a Container with added training routines.\n *\n */\nexport abstract class Container extends Layer {\n inputs: SymbolicTensor[];\n outputs: SymbolicTensor[];\n\n inputLayers: Layer[];\n inputLayersNodeIndices: number[];\n inputLayersTensorIndices: number[];\n\n outputLayers: Layer[];\n outputLayersNodeIndices: number[];\n outputLayersTensorIndices: number[];\n\n layers: Layer[];\n layersByDepth: {[depth: string]: Layer[]};\n nodesByDepth: {[depth: string]: Node[]};\n\n containerNodes = new Set();\n\n // TODO(michaelterry): Add cache support\n // private outputMaskCache: any;\n // private outputTensorCache: any;\n // private outputShapeCache: any;\n\n inputNames: string[];\n outputNames: string[];\n feedInputShapes: Shape[];\n\n protected internalInputShapes: Shape[];\n protected internalOutputShapes: Shape[];\n // TODO(cais): Maybe 'feed' should not in the names of these variables,\n // due to the fact that our backend is not symbolic.\n protected feedInputNames: string[];\n protected feedOutputNames: string[];\n\n constructor(config: ContainerConfig) {\n // No args passed to super's constructor.\n super({});\n this.name = config.name;\n if (this.name == null) {\n const prefix = this.getClassName().toLowerCase();\n this.name = getUid(prefix);\n }\n\n this.supportsMasking = false;\n this.trainable = true;\n this.updatable = true;\n\n // TODO(michaelterry): Initialize perInputLosses/Updates here.\n\n // Container-specific properties.\n if (Array.isArray(config.inputs)) {\n this.inputs = config.inputs.slice();\n } else {\n this.inputs = [config.inputs];\n }\n if (Array.isArray(config.outputs)) {\n this.outputs = config.outputs.slice();\n } else {\n this.outputs = [config.outputs];\n }\n\n // Check for redundancy in inputs.\n if (generic_utils.unique(this.inputs).length !== this.inputs.length) {\n throw new ValueError(\n 'The list of inputs passed to the model is ' +\n 'redundant. All inputs should only appear once. Found: ' +\n this.inputs.map(x => x.name));\n }\n\n // Check for redundancy in outputs.\n if (generic_utils.unique(this.outputs).length !== this.outputs.length) {\n console.warn(\n 'The list of outputs passed to the model is redundant. ' +\n 'All outputs should only appear once. Found: ' +\n this.outputs.map(x => x.name));\n }\n\n /*\n List of initial layers (1 to 1 mapping with this.inputs, hence the same\n layer might appear twice)\n */\n this.inputLayers = [];\n this.inputLayersNodeIndices = [];\n this.inputLayersTensorIndices = [];\n /*\n List of layers (1 to 1 mapping with this.outputs, hence the same layer\n might appear twice)\n */\n this.outputLayers = [];\n this.outputLayersNodeIndices = [];\n this.outputLayersTensorIndices = [];\n /*\n All layers in order of horizontal graph traversal. Entries are unique.\n Includes input and output layers.\n */\n this.layers = [];\n\n // TODO(michaelterry): Determine if caching still needed with eager\n // backend.\n /*\n This is for performance optimization when calling the Container on new\n inputs. Every time the Container is called on a set on input tensors,\n we compute the output tensors, output masks and output shapes in one pass,\n then cache them here. When one of these outputs is queried later,\n we retrieve it from there instead of recomputing it.\n */\n // this.outputTensorCache = {};\n // this.outputShapeCache = {};\n\n // Build this.outputLayers:\n for (const x of this.outputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n this.outputLayers.push(layer as Layer);\n this.outputLayersNodeIndices.push(nodeIndex);\n this.outputLayersTensorIndices.push(tensorIndex);\n }\n\n // TODO(michaelterry): Add output mask cache code.\n\n // Build this.inputLayers:\n for (const x of this.inputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n /*\n It's supposed to be an input layer, so only one node\n and one tensor output.\n */\n generic_utils.assert(nodeIndex === 0, 'input layer has >1 nodes');\n generic_utils.assert(tensorIndex === 0, 'input layer has >1 tensors');\n this.inputLayers.push(layer as Layer);\n this.inputLayersNodeIndices.push(nodeIndex);\n this.inputLayersTensorIndices.push(tensorIndex);\n }\n\n // Build this.inputNames and this.outputNames.\n this.inputNames = [];\n this.outputNames = [];\n this.feedInputShapes = [];\n this.feedInputNames = [];\n this.feedOutputNames = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n // Check that layer is an InputLayer.\n if (!(layer instanceof InputLayer)) {\n throw new TypeError(\n 'Input layers to a Model must be InputLayer objects. ' +\n `Received inputs: ${config.inputs}. ` +\n `Input ${i} (0-based) originates ` +\n `from layer type ${layer.getClassName()}.`);\n }\n this.inputNames.push(layer.name);\n this.feedInputShapes.push(layer.batchInputShape);\n\n this.feedInputNames.push(layer.name);\n }\n for (const layer of this.outputLayers) {\n this.outputNames.push(layer.name);\n }\n\n this.internalInputShapes = this.inputs.map(x => x.shape);\n this.internalOutputShapes = this.outputs.map(x => x.shape);\n\n /*\n Container_nodes: set of nodes included in the graph (not all nodes\n included in the layers are relevant to the current graph).\n */\n // ids of all nodes relevant to the Container:\n const nodesDepths: {[nodeID: string]: number} = {};\n // To recover nodes from their ID.\n const nodeIDToNode: {[nodeID: string]: Node} = {};\n const layersDepths: {[layerID: string]: number} = {};\n // To layers from their ID.\n const layerIDToLayer: {[layerID: string]: Layer} = {};\n const layerIndices: {[layerID: string]: number} = {};\n const nodesInDecreasingDepth: Node[] = [];\n\n /**\n * Builds a map of the graph of layers.\n *\n * This recursively updates the map `layerIndices`,\n * the list `nodesInDecreasingDepth` and the set `containerNodes`.\n *\n * @param tensor Some tensor in a graph.\n * @param finishedNodes Set of nodes whose subgraphs have been traversed\n * completely. Useful to prevent duplicated work.\n * @param nodesInProgress Set of nodes that are currently active on the\n * recursion stack. Useful to detect cycles.\n * @param layer Layer from which `tensor` comes from. If not provided,\n * will be obtained from tensor.sourceLayer.\n * @param nodeIndex Node index from which `tensor` comes from.\n * @param tensorIndex TensorIndex from which `tensor` comes from.\n *\n * @exception RuntimeError if a cycle is detected.\n */\n const buildMapOfGraph =\n (tensor: SymbolicTensor, finishedNodes: Node[], nodesInProgress: Node[],\n layer?: Layer, nodeIndex?: number, tensorIndex?: number) => {\n if (layer == null || nodeIndex == null || tensorIndex == null) {\n layer = tensor.sourceLayer as Layer;\n nodeIndex = tensor.nodeIndex;\n tensorIndex = tensor.tensorIndex;\n }\n const node = layer.inboundNodes[nodeIndex];\n\n // Prevent cycles.\n if (nodesInProgress.indexOf(node) !== -1) {\n throw new RuntimeError(\n `The tensor ${tensor.name} at layer \"${layer.name}\" ` +\n 'is part of a cycle.');\n }\n\n // Don't repeat work for shared subgraphs\n if (finishedNodes.indexOf(node) !== -1) {\n return;\n }\n\n // Update containerNodes.\n this.containerNodes.add(Container.nodeKey(layer, nodeIndex));\n\n // Store the traversal order for layer sorting.\n if (!(layer.id in layerIndices)) {\n layerIndices[layer.id] = Object.keys(layerIndices).length;\n }\n\n if (nodesInProgress.indexOf(node) === -1) {\n nodesInProgress.push(node);\n }\n\n // Propagate to all previous tensors connected to this node.\n const numInboundLayers = node.inboundLayers.length;\n for (let i = 0; i < numInboundLayers; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n buildMapOfGraph(\n x, finishedNodes, nodesInProgress, layer, nodeIndex,\n tensorIndex);\n }\n finishedNodes.push(node);\n while (nodesInProgress.indexOf(node) >= 0) {\n nodesInProgress.splice(nodesInProgress.indexOf(node), 1);\n }\n nodesInDecreasingDepth.push(node);\n };\n\n const finishedNodes: Node[] = [];\n const nodesInProgress: Node[] = [];\n for (const x of this.outputs) {\n buildMapOfGraph(x, finishedNodes, nodesInProgress);\n }\n\n const reversedNodesInDecreasingDepth =\n nodesInDecreasingDepth.slice().reverse();\n for (const node of reversedNodesInDecreasingDepth) {\n nodeIDToNode[node.id] = node;\n // If the depth is not set, the node has no outbound nodes (depth 0).\n if (!(node.id in nodesDepths)) {\n nodesDepths[node.id] = 0;\n }\n let depth = nodesDepths[node.id];\n\n // Update the depth of the corresponding layer\n const previousDepth =\n (layersDepths[node.outboundLayer.id] == null ?\n 0 :\n layersDepths[node.outboundLayer.id]);\n\n /*\n If we've seen this layer before at a higher depth, we should use that\n depth instead of the node depth. This is necessary for shared layers\n that have inputs at different depth levels in the graph.\n */\n depth = Math.max(depth, previousDepth);\n layersDepths[node.outboundLayer.id] = depth;\n layerIDToLayer[node.outboundLayer.id] = node.outboundLayer;\n nodesDepths[node.id] = depth;\n\n // Update the depth of inbound nodes.\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const inboundNode = inboundLayer.inboundNodes[nodeIndex];\n const previousDepth =\n (nodesDepths[inboundNode.id] == null ? 0 :\n nodesDepths[inboundNode.id]);\n nodesDepths[inboundNode.id] = Math.max(depth + 1, previousDepth);\n nodeIDToNode[inboundNode.id] = inboundNode;\n }\n }\n\n // Build a dict {depth: list of nodes with this depth}\n const nodesByDepth: {[depth: string]: Node[]} = {};\n for (const nodeID in nodesDepths) {\n const depth = nodesDepths[nodeID];\n if (!(depth in nodesByDepth)) {\n nodesByDepth[depth] = [];\n }\n nodesByDepth[depth].push(nodeIDToNode[nodeID]);\n }\n\n // Build a dict {depth: list of layers with this depth}\n const layersByDepth: {[depth: string]: Layer[]} = {};\n for (const layerID in layersDepths) {\n const depth = layersDepths[layerID];\n if (!(depth in layersByDepth)) {\n layersByDepth[depth] = [];\n }\n layersByDepth[depth].push(layerIDToLayer[layerID]);\n }\n\n // Get sorted list of layer depths.\n let depthKeys = Object.keys(layersByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Set this.layers and this.layersByDepth.\n this.layers = [];\n for (const depth of depthKeys) {\n const layersForDepth = layersByDepth[depth];\n // Container.layers needs to have a deterministic order:\n // here we order them by traversal order.\n layersForDepth.sort((a, b) => {\n const aIndex = layerIndices[a.id];\n const bIndex = layerIndices[b.id];\n if (aIndex < bIndex) {\n return -1;\n }\n if (aIndex > bIndex) {\n return 1;\n }\n return 0;\n });\n for (const layer of layersForDepth) {\n this.layers.push(layer);\n }\n }\n this.layersByDepth = layersByDepth;\n\n // Get sorted list of node depths;\n depthKeys = Object.keys(nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Check that all tensors required are computable.\n // computable_tensors: all tensors in the graph\n // that can be computed from the inputs provided.\n const computableTensors = this.inputs.slice();\n\n // To provide a better error msg.\n const layersWithCompleteInput: string[] = [];\n for (const depth of depthKeys) {\n for (const node of nodesByDepth[depth]) {\n const layer = node.outboundLayer;\n if (layer != null) {\n for (const x of node.inputTensors) {\n if (computableTensors.indexOf(x) === -1) {\n throw new RuntimeError(\n `Graph disconnected: cannot obtain value for tensor ${x}` +\n ` at layer \"${layer.name}\". ` +\n 'The following previous layers were accessed without ' +\n `issue: ${layersWithCompleteInput}`);\n }\n }\n for (const x of node.outputTensors) {\n computableTensors.push(x);\n }\n layersWithCompleteInput.push(layer.name);\n }\n }\n }\n\n // Set this.containerNodes and this.nodesByDepth.\n this.nodesByDepth = nodesByDepth;\n\n // Ensure name unicity, which will be crucial for serialization\n // (since serialized nodes refer to layers by their name).\n const allNames = this.layers.map(x => x.name);\n for (const name of allNames) {\n const numOccurrences = allNames.filter(x => x === name).length;\n if (numOccurrences !== 1) {\n throw new RuntimeError(\n `The name \"${name}\" is used ${numOccurrences} times ` +\n 'in the model. All layer names should be unique. Layer names: ' +\n JSON.stringify(allNames));\n }\n }\n\n // Layer parameters.\n // The new container starts with a single inbound node\n // for its inputs, and no outbound nodes.\n // Will be appended to by future calls to apply().\n this.outboundNodes = [];\n // Will be appended to below, and by future calls to apply().\n this.inboundNodes = [];\n\n // Create the node linking internal inputs to internal outputs.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n inputMasks: this.inputs.map(x => null),\n outputMasks: this.outputs.map(x => null),\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs.map(x => x.shape)\n });\n this.built = true;\n }\n\n get trainableWeights(): LayerVariable[] {\n // Porting Note: This check below is to prevent errors where the\n // _trainableWeights inherited from the parent class (Layer) gets\n // inadvertently used.\n if (this._trainableWeights.length > 0) {\n throw new ValueError(\n 'Container instance unexpectedly contains _trainableWeights.' +\n 'The trainable weights of a Container are a union of the ' +\n 'trainable weights of its consituent Layers. Its own ' +\n '_trainableWeights must remain an empty Array.');\n }\n\n if (!this.trainable) {\n return [];\n }\n let weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights = weights.concat(layer.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights.push(...layer.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const layer of this.layers) {\n trainableWeights.push(...layer.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n /**\n * Loads all layer weights from a JSON object.\n *\n * Porting Note: HDF5 weight files cannot be directly loaded in JavaScript /\n * TypeScript. The utility script at `scripts/pykeras.py` offers means\n * to convert them into JSON strings compatible with this method.\n * Porting Note: TensorFlow.js Layers supports only loading by name currently.\n *\n * @param weightsJSON A JSON mapping weight names to weight values as nested\n * arrays of numbers, or a `NamedTensorMap`, i.e., a JSON mapping weight\n * names to `Tensor` objects.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weight (only valid when `by_name`=True).\n * @param isNamedTensorMap Whether the 1st argument (`weightsJSON`) is a\n * `NamedTensorMap`.\n */\n loadWeights(\n weightsJSON: JsonDict|NamedTensorMap, skipMismatch = false,\n isNamedTensorMap = false) {\n // TODO(cais): Maybe the JsonDict support should be removed after serving\n // weights from XHR is working. If so, the `loadWeightsFromJson` flag\n // should be removed as well. (b/74015805)\n // TODO(cais): See if we can use smarter type resolution to avoid sending\n // the type info as a separate arg (isNamedTensormap).\n if (isNamedTensorMap) {\n loadWeightsFromNamedTensorMap(weightsJSON as NamedTensorMap, this.layers);\n } else {\n loadWeightsFromJson(weightsJSON as JsonDict, this.layers, skipMismatch);\n }\n }\n\n /**\n * Util shared between different serialization methods.\n * @returns Model config with Keras version information added.\n */\n private updatedConfig(): serialization.ConfigDict {\n const theConfig = this.getConfig();\n const modelConfig: serialization.ConfigDict = {\n className: this.getClassName(),\n config: theConfig,\n kerasVersion: `tfjs-layers ${layersVersion}`,\n // TODO(nielsene): Replace something like K.backend() once\n // possible.\n backend: 'TensorFlow.js'\n };\n return modelConfig;\n }\n\n /**\n * Returns a JSON string containing the network configuration.\n *\n * To load a network from a JSON save file, use\n * models.modelFromJSON(jsonString);\n * @param extraJsonArgs Unused in tfjs-layers, maintained for PyKeras\n * @param returnString Whether the return value should be stringified\n * (default: `true`).\n * @returns a JSON string if `returnString` (default), or a JSON object if\n * `!returnString`.\n */\n // tslint:disable-next-line:no-any\n toJSON(unused?: any, returnString = true): string|JsonDict {\n const modelConfig = convertTsToPythonic(this.updatedConfig()) as JsonDict;\n return returnString ? JSON.stringify(modelConfig) : modelConfig;\n }\n\n /**\n * Call the model on new inputs.\n *\n * In this case `call` just reapplies all ops in the graph to the new inputs\n * (e.g. build a new computational graph from the provided inputs).\n *\n * @param inputs A tensor or list of tensors.\n * @param mask A mask or list of masks. A mask can be either a tensor or null\n * (no mask).\n *\n * @return A tensor if there is a single output, or a list of tensors if there\n * are more than one outputs.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n\n if ('mask' in kwargs) {\n masks = generic_utils.toList(kwargs['mask']);\n } else {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n // TODO(michaelterry): Add support for caching.\n return this.runInternalGraph(inputs, masks)[0];\n });\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n if (mask == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n } else {\n masks = generic_utils.toList(mask);\n }\n // TODO(michaelterry): Add support for mask caching.\n return this.runInternalGraph(inputs, masks)[1];\n });\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n const inputShapes = types_utils.normalizeShapeList(inputShape);\n if (inputShapes.length !== this.inputLayers.length) {\n throw new ValueError(\n `Invalid inputShape argument ${inputShape}: ` +\n `model has ${this.inputLayers.length} tensor inputs.`);\n }\n\n // TODO(michaelterry): Add caching\n const layersToOutputShapes: {[shapeKey: string]: Shape} = {};\n for (let i = 0; i < inputShapes.length; i++) {\n const layer = this.inputLayers[i];\n const inputShape = inputShapes[i];\n // It's an input layer: computeOutputShape is identity,\n // and there is only one node and one tensor output.\n const shapeKey = layer.name + '_0_0';\n layersToOutputShapes[shapeKey] = inputShape;\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n // Iterate over nodes, by depth level.\n if (depthKeys.length > 1) {\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n if (this.inputLayers.map(x => x.id).indexOf(layer.id) !== -1) {\n // We've already covered the input layers a few lines above.\n continue;\n }\n // Potentially redundant list, same size of node.inputTensors.\n const inputShapes: Shape[] = [];\n for (let j = 0; j < node.inboundLayers.length; j++) {\n const inboundLayer = node.inboundLayers[j];\n const nodeIndex = node.nodeIndices[j];\n const tensorIndex = node.tensorIndices[j];\n const shapeKey = `${inboundLayer.name}_${nodeIndex}_${tensorIndex}`;\n const inputShape = layersToOutputShapes[shapeKey];\n inputShapes.push(inputShape);\n }\n\n const outputShape = layer.computeOutputShape(\n generic_utils.singletonOrArray(inputShapes));\n\n const outputShapes = types_utils.normalizeShapeList(outputShape);\n const nodeIndex = layer.inboundNodes.indexOf(node);\n for (let j = 0; j < outputShapes.length; j++) {\n const shapeKey = `${layer.name}_${nodeIndex}_${j}`;\n layersToOutputShapes[shapeKey] = outputShapes[j];\n }\n }\n }\n }\n\n // Read final output shapes from layersToOutputShapes.\n const outputShapes: Shape[] = [];\n const outputShapeKeys: string[] = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n const tensorIndex = this.outputLayersTensorIndices[i];\n const shapeKey = `${layer.name}_${nodeIndex}_${tensorIndex}`;\n outputShapeKeys.push(shapeKey);\n }\n\n for (let i = 0; i < outputShapeKeys.length; i++) {\n const key = outputShapeKeys[i];\n generic_utils.assert(key in layersToOutputShapes);\n outputShapes.push(layersToOutputShapes[key]);\n }\n\n // TODO(michaelterry): Update cache\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n /**\n * Computes output tensors for new inputs.\n *\n * Note:\n * - Expects `inputs` to be a list (potentially with 1 element).\n *\n * @param inputs List of tensors\n * @param masks List of masks (tensors or null).\n * @return Three lists: outputTensors, outputMasks, outputShapes\n */\n protected runInternalGraph(inputs: Tensor[], masks?: Tensor[]):\n [Tensor[], Tensor[], Shape[]] {\n if (masks == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n\n // Dictionary mapping reference tensors to tuples\n // (computed tensor, compute mask)\n // we assume a 1:1 mapping from tensor to mask\n // TODO: raise exception when a `.computeMask()` call\n // does not return a list the same size as `call`\n const tensorMap: {[tensorID: string]: [Tensor, Tensor]} = {};\n for (let i = 0; i < this.inputs.length; ++i) {\n const x = this.inputs[i];\n const y = inputs[i];\n const mask = masks[i];\n tensorMap[x.id] = [y, mask];\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n const referenceInputTensors = node.inputTensors;\n const referenceOutputTensors = node.outputTensors;\n\n // If all previous input tensors are available in tensorMap,\n // then call node.inboundLayer on them.\n // List of tuples [input, mask]:\n const computedData = new Array<[Tensor, Tensor]>();\n for (const x of referenceInputTensors) {\n if (x.id in tensorMap) {\n computedData.push(tensorMap[x.id]);\n }\n }\n if (computedData.length === referenceInputTensors.length) {\n // TODO(michaelterry): Add K.name_scope here, if we need it.\n let kwargs: Kwargs = {};\n let computedTensors: Tensor[];\n let computedMasks: Tensor[];\n let outputTensors: Tensor[];\n let outputMasks: Tensor[];\n // call layer\n if (node.callArgs != null) {\n kwargs = node.callArgs;\n }\n if (computedData.length === 1) {\n const [computedTensor, computedMask] = computedData[0];\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMask;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensor, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensor, computedMask));\n computedTensors = [computedTensor];\n computedMasks = [computedMask];\n } else {\n computedTensors = computedData.map(x => x[0]);\n computedMasks = computedData.map(x => x[1]);\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMasks;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensors, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensors, computedMasks));\n }\n\n if (layer.activityRegularizer) {\n throw new NotImplementedError(\n 'Model invocation with concrete Tensor value(s) in the ' +\n 'presence of activity regularizer(s) is not supported yet.');\n }\n // TODO(michaelterry): Add model updates and losses\n\n // Update tensor map.\n for (let i = 0; i < referenceOutputTensors.length; ++i) {\n const x = referenceOutputTensors[i];\n const y = outputTensors[i];\n const mask = outputMasks[i];\n tensorMap[x.id] = [y, mask];\n }\n }\n }\n }\n\n const outputTensors: Tensor[] = [];\n const outputMasks: Tensor[] = [];\n const outputShapes: Shape[] = [];\n for (const x of this.outputs) {\n generic_utils.assert(\n x.id in tensorMap, `Could not compute output ${x.name} : ${x.id}`);\n const [tensor, mask] = tensorMap[x.id];\n outputShapes.push(tensor.shape);\n outputTensors.push(tensor);\n outputMasks.push(mask);\n }\n\n // TODO(michaelterry): Add support for caches.\n return [outputTensors, outputMasks, outputShapes];\n }\n\n /**\n * Builds a map of internal node keys to node ordering.\n * Used in serializaion a node orderings may change as unused nodes are\n * dropped. Porting Note: This helper method was pulled out of getConfig to\n * improve readability.\n * @param layers An array of Layers in the model.\n * @returns Map of Node Keys to index order within the layer.\n */\n private buildNodeConversionMap(layers: Layer[]): {[nodeKey: string]: number} {\n const nodeConversionMap: {[nodeKey: string]: number} = {};\n let keptNodes: number;\n for (const layer of this.layers) {\n keptNodes = layer instanceof Container ? 1 : 0;\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n if (nodeKey in this.containerNodes) {\n // i.e. we mark it to be saved\n nodeConversionMap[nodeKey] = keptNodes;\n keptNodes += 1;\n }\n }\n }\n return nodeConversionMap;\n }\n\n /**\n * Retrieves a layer based on either its name (unique) or index.\n *\n * Indices are based on order of horizontal graph traversal (bottom-up).\n *\n * If both `name` and `index` are specified, `index` takes precedence.\n *\n * @param name Name of layer.\n * @param index Index of layer.\n * @returns A Layer instance.\n * @throws ValueError: In case of invalid layer name or index.\n */\n /**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Classes',\n * namespace: 'layers',\n * subclasses: ['Model']\n * }\n */\n getLayer(name?: string, index?: number): Layer {\n if (index != null) {\n if (this.layers.length <= index) {\n throw new ValueError(\n `Was asked to retrieve layer at index ${index}, but model only ` +\n `has ${this.layers.length} layer(s).`);\n } else {\n return this.layers[index];\n }\n } else {\n if (name == null) {\n throw new ValueError('Provide either a layer name or layer index');\n }\n }\n\n for (const layer of this.layers) {\n if (layer.name === name) {\n return layer;\n }\n }\n throw new ValueError(`No such layer: ${name}`);\n }\n\n /**\n * Retrieves the Container's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Container.loss in PyKeras.\n // In PyKeras, Container.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return tidy(() => {\n const losses: Scalar[] = [];\n for (const layer of this.layers) {\n for (let nodeIndex = 0; nodeIndex < layer.inboundNodes.length;\n ++nodeIndex) {\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (this.containerNodes.has(nodeKey)) {\n losses.push(...layer.calculateLosses());\n }\n }\n }\n // TODO(cais): Add any unconditional model-level losses?\n return losses;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {name: this.name};\n\n // Build a map from layer unique name (self._node_key)\n // to the index of the nodes that are saved in the config.\n // Only nodes in container_nodes are saved.\n const nodeConversionMap: {[nodeKey: string]: number} =\n this.buildNodeConversionMap(this.layers);\n\n // Serialize and save the layers in layerConfigs\n const layerConfigs = [];\n for (const layer of this.layers) {\n const layerClassName = layer.getClassName();\n const layerConfig = layer.getConfig();\n const filteredInboundNodes = [];\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const node = layer.inboundNodes[originalNodeIndex];\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n let kwargs = {};\n if (this.containerNodes.has(nodeKey)) {\n // The node is relevant to the model:\n // add to filteredInboundNodes.\n if (node.callArgs) {\n try {\n JSON.stringify(node.callArgs);\n kwargs = node.callArgs;\n } catch (err) {\n console.warn(\n `Layer ${layer.name} was passed ` +\n `non-serializable keyword arguments: ` +\n `${node.callArgs}. They will not be included ` +\n `in the serialized model (and thus will be ` +\n `missing at deserialization time).`);\n kwargs = {};\n }\n }\n if (node.inboundLayers.length > 0) {\n const nodeData = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n const nodeKey = Container.nodeKey(inboundLayer, nodeIndex);\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n nodeData.push(\n [inboundLayer.name, newNodeIndex, tensorIndex, kwargs]);\n }\n filteredInboundNodes.push(nodeData);\n }\n }\n }\n layerConfigs.push({\n name: layer.name,\n className: layerClassName,\n config: layerConfig,\n inboundNodes: filteredInboundNodes\n });\n }\n config['layers'] = layerConfigs;\n // Gather info about inputs and outputs\n const modelInputs = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n const nodeIndex = this.inputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.inputLayersTensorIndices[i];\n modelInputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['inputLayers'] = modelInputs;\n\n const modelOutputs = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.outputLayersTensorIndices[i];\n modelOutputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['outputLayers'] = modelOutputs;\n return config;\n }\n\n /**\n * Instantiates a Model from its config (output of `get_config()`).\n * @param cls: the class to create\n * @param config: Model config dictionary.\n * @returns A model instance.\n * @throws ValueError: In case of improperly formatted config dict.\n */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n // Layer instances created during\n // the graph reconstruction process\n const createdLayers: {[layerName: string]: Layer} = {};\n\n // Dictionary mapping layer instances to\n // node data that specifies a layer call.\n // It acts as a queue that maintains any unprocessed\n // layer call until it becomes possible to process it\n // (i.e. until the input tensors to the call all exist).\n const unprocessedNodes:\n {[layer: string]: serialization.ConfigDict[][]} = {};\n function addUnprocessedNode(\n layer: Layer, nodeData: serialization.ConfigDict[]) {\n if (!(layer.name in unprocessedNodes)) {\n unprocessedNodes[layer.name] = [nodeData];\n } else {\n unprocessedNodes[layer.name].push(nodeData);\n }\n }\n\n function processNode(layer: Layer, nodeData: serialization.ConfigDict[]) {\n const inputTensors: SymbolicTensor[] = [];\n let kwargs;\n for (const inputData of nodeData) {\n const inboundLayerName = inputData[0] as string;\n const inboundNodeIndex = inputData[1] as number;\n const inboundTensorIndex = inputData[2] as number;\n if (inputData.length === 3) {\n kwargs = {};\n } else if (inputData.length === 4) {\n kwargs = inputData[3] as serialization.ConfigDict;\n } else {\n throw new ValueError(`Improperly formatted model config for layer ${\n JSON.stringify(layer)}: ${JSON.stringify(inputData)}`);\n }\n if (!(inboundLayerName in createdLayers)) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundLayer = createdLayers[inboundLayerName];\n if (inboundLayer.inboundNodes.length <= inboundNodeIndex) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundNode = inboundLayer.inboundNodes[inboundNodeIndex];\n inputTensors.push(inboundNode.outputTensors[inboundTensorIndex]);\n }\n // Call layer on its inputs, thus creating the node\n // and building the layer if needed.\n // Note: This has Eager vs Graph Implications.\n if (inputTensors.length > 0) {\n layer.apply(\n generic_utils.singletonOrArray(inputTensors),\n kwargs); // was ** kwargs\n }\n }\n\n /**\n * Deserialize a layer, then call it on appropriate inputs.\n * @param layerData: layer config dict.\n * @throws ValueError: In case of improperly formatted `layer_data`\n * dict.\n */\n function processLayer(layerData: serialization.ConfigDict|null) {\n const layerName = layerData.name as string;\n // Instantiate layer.\n const layer = deserializeLayer(\n layerData,\n config.customObjects != null ?\n config.customObjects as serialization.ConfigDict :\n {}) as Layer;\n createdLayers[layerName] = layer;\n // Gather layer inputs.\n const inboundNodesData =\n layerData.inboundNodes as serialization.ConfigDict[];\n for (const nodeData of inboundNodesData) {\n if (!(nodeData instanceof Array)) {\n throw new ValueError(\n `Corrupted configuration, expected array for nodeData: ${\n nodeData}`);\n }\n // We don't process nodes (i.e. make layer calls)\n // on the fly because the inbound node may not yet exist,\n // in case of layer shared at different topological depths\n // (e.g.a model such as A(B(A(B(x)))))\n addUnprocessedNode(layer, nodeData);\n }\n }\n\n // First, we create all layers and enqueue nodes to be processed\n const name = config.name;\n const layersFromConfig = config.layers as serialization.ConfigDict[];\n for (const layerData of layersFromConfig) {\n processLayer(layerData);\n }\n\n // Then we process nodes in order of layer depth.\n // Nodes that cannot yet be processed(if the inbound node\n // does not yet exist) are re - enqueued, and the process\n // is repeated until all nodes are processed.\n while (!generic_utils.isObjectEmpty(unprocessedNodes)) {\n for (const layerData of layersFromConfig) {\n const layer = createdLayers[layerData.name as string];\n if (layer.name in unprocessedNodes) {\n for (const nodeData of unprocessedNodes[layer.name]) {\n processNode(layer, nodeData);\n }\n delete unprocessedNodes[layer.name];\n }\n }\n }\n const inputTensors: SymbolicTensor[] = [];\n const outputTensors: SymbolicTensor[] = [];\n const inputLayersFromConfig =\n config.inputLayers as serialization.ConfigDict[];\n for (const layerData of inputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n inputTensors.push(layerOutputTensors[tensorIndex]);\n }\n const outputLayersFromConfig =\n config.outputLayers as serialization.ConfigDict[];\n for (const layerData of outputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n outputTensors.push(layerOutputTensors[tensorIndex]);\n }\n return new cls({inputs: inputTensors, outputs: outputTensors, name});\n }\n\n /**\n * Determine whether the container is stateful.\n *\n * Porting Note: this is the equivalent of the stateful @property of\n * the Container class in PyKeras.\n */\n get stateful(): boolean {\n // Porting Note: This check is to prevent inadvertent setting of the\n // _stateful property of the Container instance.\n if (this._stateful) {\n throw new ValueError(\n 'Container instance unexpectedly has _stateful = true. The ' +\n 'statefulness of a Container is determined by the Layers it ' +\n 'contains. Its _stateful property must remain the default false.');\n }\n for (const layer of this.layers) {\n if (layer.stateful) {\n return true;\n }\n }\n return false;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Executor: Evaluates SymbolicTensor based on feeds.\n */\n\nimport {cast, Tensor} from '@tensorflow/tfjs-core';\n\nimport {ValueError} from '../errors';\nimport {Kwargs} from '../types';\n\nimport {InputLayer} from './input_layer';\nimport {SymbolicTensor} from './topology';\n\n/**\n * Helper function to check the dtype and shape compatibility of a feed value.\n */\nfunction assertFeedCompatibility(key: SymbolicTensor, val: Tensor): Tensor {\n // 1. Check shape compatibility. If shapes are not compatible, error.\n if (key.shape != null) {\n if (key.shape.length !== val.shape.length) {\n throw new ValueError(\n `The rank of feed (${val.shape.length}) does not match the rank of ` +\n `the key (${key.shape.length}).`);\n }\n\n for (let i = 0; i < key.shape.length; ++i) {\n if (key.shape[i] != null && key.shape[i] !== val.shape[i]) {\n throw new ValueError(\n `The ${i}-th dimension of the feed (${val.shape[i]}) is ` +\n `incompatible with that of the key (${key.shape[i]}).`);\n }\n }\n }\n // 2. Check dtype compatibility.\n if (key.dtype == null || key.dtype === val.dtype) {\n // 2a. If types match, return val tensor as is.\n return val;\n }\n try {\n // 2b. Attempt to convert to expected type.\n return cast(val, key.dtype);\n } catch (err) {\n // 2c. If conversion fails, return helpful error.\n throw new ValueError(\n `The dtype of the feed (${val.dtype}) can not be cast to the dtype ` +\n `of the key '${key.name}' (${key.dtype}).`);\n }\n}\n\n/**\n * A concrete Tensor value for a symbolic tensor as the key.\n */\nexport interface Feed {\n key: SymbolicTensor;\n value: Tensor;\n}\n\n/**\n * FeedDict: A mapping from unique SymbolicTensors to feed values for them.\n * A feed value is a concrete value represented as an `Tensor`.\n */\nexport class FeedDict {\n private id2Value: {[id: number]: Tensor} = {};\n\n /**\n * Constructor, optionally does copy-construction.\n * @param feeds An Array of `Feed`s, or another `FeedDict`, in which case\n * copy-construction will be performed.\n */\n constructor(feeds?: Feed[]|FeedDict) {\n if (feeds instanceof FeedDict) {\n for (const id in feeds.id2Value) {\n this.id2Value[id] = feeds.id2Value[id];\n }\n } else {\n if (feeds == null) {\n return;\n }\n for (const feed of feeds) {\n this.add(feed.key, feed.value);\n }\n }\n }\n\n /**\n * Add a key-value pair to the FeedDict.\n * @param key The key of the feed.\n * @param value The value of the feed.\n * @returns This `FeedDict`.\n * @throws ValueError: If the key `SymbolicTensor` already exists in the\n * `FeedDict`.\n */\n add(key: SymbolicTensor, value: Tensor): FeedDict {\n if (this.id2Value[key.id] == null) {\n this.id2Value[key.id] = assertFeedCompatibility(key, value);\n } else {\n throw new ValueError(`Duplicate key: name=${key.name}, id=${key.id}`);\n }\n return this;\n }\n\n /**\n * Add a Feed to the FeedDict.\n * @param feed The new `Feed` to add.\n * @returns This `FeedDict`.\n */\n addFeed(feed: Feed) {\n this.add(feed.key, feed.value);\n }\n\n /**\n * Probe whether a key already exists in the FeedDict.\n * @param key\n */\n hasKey(key: SymbolicTensor): boolean {\n return this.id2Value[key.id] != null;\n }\n\n /**\n * Get the feed value for given key.\n * @param key\n * @returns If `key` exists, the corresponding feed value.\n * @throws ValueError: If `key` does not exist in this `FeedDict`.\n */\n getValue(key: SymbolicTensor): Tensor {\n if (this.id2Value[key.id] == null) {\n throw new ValueError(`Nonexistent key: ${JSON.stringify(key)}`);\n } else {\n return this.id2Value[key.id];\n }\n }\n}\n\n/**\n * Execute a SymbolicTensor by using concrete feed values.\n *\n * A `SymbolicTensor` object is a node in a computation graph of TF.js\n * Layers. The object is backed by a source layer and input\n * `SymbolicTensor`s to the source layer. This method evaluates\n * the `call()` method of the source layer, using concrete values of the inputs\n * obtained from either\n * * `feedDict`, if the input key exists in `feedDict`, or else,\n * * a recursive call to `execute()` itself.\n *\n * @param x: The `SymbolicTensor` to execute.\n * @param feedDict: The feed values, as base condition of the recursion.\n * execution.\n * @param kwargs: Optional keyword arguments.\n * @returns Result of the execution.\n * @throws ValueError: If any `SymbolicTensor`s from `InputLayer`s\n * encountered during the execution lacks a feed value in `feedDict`.\n */\nexport function execute(\n fetches: SymbolicTensor|SymbolicTensor[], feedDict: FeedDict,\n kwargs?: Kwargs): Tensor|Tensor[]|[Tensor | Tensor[]] {\n const arrayFetches = Array.isArray(fetches);\n const fetchArray: SymbolicTensor[] =\n arrayFetches ? fetches as SymbolicTensor[] : [fetches as SymbolicTensor];\n\n const outputs: Tensor[] = [];\n const internalFeedDict = new FeedDict(feedDict);\n\n for (const fetch of fetchArray) {\n outputs.push(executeInternal(fetch, internalFeedDict, kwargs) as Tensor);\n }\n return arrayFetches ? outputs : outputs[0];\n}\n\nfunction executeInternal(\n fetch: SymbolicTensor, internalFeedDict: FeedDict,\n kwargs?: Kwargs): Tensor {\n if (internalFeedDict.hasKey(fetch)) {\n return internalFeedDict.getValue(fetch);\n }\n if (fetch.sourceLayer instanceof InputLayer) {\n throw new ValueError(\n `Missing a feed value for SymbolicTensor from InputLayer ` +\n `'${InputLayer.name}'`);\n }\n\n const inputs = fetch.inputs;\n const inputValues: Tensor[] = [];\n for (const input of inputs) {\n // Recursive call.\n const inputVal = executeInternal(input, internalFeedDict, kwargs) as Tensor;\n inputValues.push(inputVal);\n }\n\n let output =\n fetch.sourceLayer.apply(inputValues, kwargs) as Tensor | Tensor[];\n if (!Array.isArray(output)) {\n output = [output];\n }\n const layerOutputs = getNodeOutputs(fetch);\n const outputSymbolicTensors =\n Array.isArray(layerOutputs) ? layerOutputs : [layerOutputs];\n for (let i = 0; i < outputSymbolicTensors.length; ++i) {\n internalFeedDict.add(outputSymbolicTensors[i], output[i]);\n }\n return output.length === 1 ? output[0] : output[fetch.outputTensorIndex];\n}\n\n/**\n * Get the symbolic output tensors of the node to which a given fetch belongs.\n * @param fetch The fetched symbolic tensor.\n * @returns The Array of symbolic tensors output by the node to which `fetch`\n * belongs.\n */\nfunction getNodeOutputs(fetch: SymbolicTensor): SymbolicTensor|\n SymbolicTensor[] {\n let layerOutputs: SymbolicTensor|SymbolicTensor[];\n if (fetch.sourceLayer.inboundNodes.length === 1) {\n layerOutputs = fetch.sourceLayer.output;\n } else {\n let nodeIndex: number = null;\n for (let i = 0; i < fetch.sourceLayer.inboundNodes.length; ++i) {\n for (const outputTensor of fetch.sourceLayer.inboundNodes[i]\n .outputTensors) {\n if (outputTensor.id === fetch.id) {\n nodeIndex = i;\n break;\n }\n }\n }\n layerOutputs = fetch.sourceLayer.getOutputAt(nodeIndex);\n }\n return layerOutputs;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: engine/training.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {io, ModelPredictConfig, Optimizer, Scalar, serialization, Tensor, Tensor1D, tensor1d, util} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {BaseCallback, BaseLogger, CallbackList, CustomCallbackConfig, History, standardizeCallbacks} from '../base_callbacks';\nimport {nameScope} from '../common';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {disposeTensorsInLogs, UnresolvedLogs} from '../logs';\nimport * as losses from '../losses';\nimport * as Metrics from '../metrics';\nimport * as optimizers from '../optimizers';\nimport {LossOrMetricFn, NamedTensorMap, Shape} from '../types';\nimport {count, pyListRepeat, singletonOrArray, unique} from '../utils/generic_utils';\nimport {printSummary} from '../utils/layer_utils';\nimport {range} from '../utils/math_utils';\nimport {LayerVariable} from '../variables';\n\nimport {Container, ContainerConfig} from './container';\nimport {execute, FeedDict} from './executor';\nimport {SymbolicTensor} from './topology';\n\n// tslint:enable:max-line-length\n\n/**\n * Helper function for polymorphic input data: 1. singleton Tensor.\n */\nexport function isDataTensor(x: Tensor|Tensor[]|{[inputName: string]: Tensor}|\n {[inputName: string]: Tensor[]}): boolean {\n return x instanceof Tensor;\n}\n\n/**\n * Helper function for polymorphic input data: 2. Array of Tensor.\n */\nexport function isDataArray(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return Array.isArray(x);\n}\n\n/**\n * Helper function for polymorphic input data: 3. \"dict\" of Tensor.\n */\nexport function isDataDict(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return !isDataTensor(x) && !isDataArray(x);\n}\n\n/**\n * Normalizes inputs and targets provided by users.\n * @param data User-provided input data (polymorphic).\n * @param names An Array of expected Tensor names.\n * @param shapes Optional Array of expected Tensor shapes.\n * @param checkBatchAxis Whether to check that the batch axis of the arrays\n * match the expected value found in `shapes`.\n * @param exceptionPrefix String prefix used for exception formatting.\n * @returns List of standardized input Tensors (one Tensor per model input).\n * @throws ValueError: in case of improperly formatted user data.\n */\nexport function standardizeInputData(\n data: Tensor|Tensor[]|{[inputName: string]: Tensor}, names: string[],\n shapes?: Shape[], checkBatchAxis = true, exceptionPrefix = ''): Tensor[] {\n if (names == null || names.length === 0) {\n // Check for the case where the model expected no data, but some data got\n // sent.\n if (data != null) {\n let gotUnexpectedData = false;\n if (isDataArray(data) && (data as Tensor[]).length > 0) {\n gotUnexpectedData = true;\n } else if (isDataDict(data)) {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n gotUnexpectedData = true;\n break;\n }\n }\n } else {\n // `data` is a singleton Tensor in this case.\n gotUnexpectedData = true;\n }\n if (gotUnexpectedData) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix} expected no data, ` +\n `but got ${data}`);\n }\n }\n return [];\n }\n if (data == null) {\n return names.map(name => null);\n }\n\n let arrays: Tensor[];\n if (isDataDict(data)) {\n data = data as {[inputName: string]: Tensor};\n arrays = [];\n for (const name of names) {\n if (data[name] == null) {\n throw new ValueError(\n `No data provided for \"${name}\". Need data for each key in: ` +\n `${names}`);\n }\n arrays.push(data[name]);\n }\n } else if (isDataArray(data)) {\n data = data as Tensor[];\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `model expected. Expected to see ${names.length} Tensor(s), but ` +\n `instead got the following list of Tensor(s): ${data}`);\n }\n arrays = data;\n } else {\n data = data as Tensor;\n if (names.length > 1) {\n throw new ValueError(\n `The model ${exceptionPrefix} expects ${names.length} Tensor(s), ` +\n `but only received one Tensor. Found: Tensor with shape ${\n data.shape}`);\n }\n arrays = [data];\n }\n\n // Make Tensors at least 2D.\n for (let i = 0; i < names.length; ++i) {\n const array = arrays[i];\n if (array.shape.length === 1) {\n arrays[i] = K.expandDims(array, 1);\n }\n }\n\n // Check shape compatibility.\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s). but got array with ` +\n `shape ${array.shape}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n // Skip the first (batch) axis.\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null && refDim >= 0 && dim !== refDim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have shape [${shapes[i]}], but got array with shape ` +\n `[${array.shape}].`);\n }\n }\n }\n }\n return arrays;\n}\n\n/**\n * User input validation for Tensors.\n * @param inputs `Array` of `Tensor`s for inputs.\n * @param targets `Array` of `Tensor`s for targets.\n * @param weights Optional `Array` of `Tensor`s for sample weights.\n * @throws ValueError: in case of incorrectly formatted data.\n */\nexport function checkArrayLengths(\n inputs: Tensor[], targets: Tensor[], weights?: Tensor[]) {\n const setX = unique(inputs.map(input => input.shape[0]));\n setX.sort();\n const setY = unique(targets.map(target => target.shape[0]));\n setY.sort();\n // TODO(cais): Check `weights` as well.\n if (setX.length > 1) {\n throw new ValueError(\n `All input Tensors (x) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(inputs.map(input => input.shape))}`);\n }\n if (setY.length > 1) {\n throw new ValueError(\n `All target Tensors (y) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(targets.map(target => target.shape))}`);\n }\n if (setX.length > 0 && setY.length > 0 && !util.arraysEqual(setX, setY)) {\n throw new ValueError(\n `Input Tensors should have the same number of samples as target ` +\n `Tensors. Found ${setX[0]} input sample(s) and ${setY[0]} target ` +\n `sample(s).`);\n }\n}\n\n/**\n * Validation on the compatibility of targes and loss functions.\n *\n * This helps prevent users from using loss functions incorrectly.\n *\n * @param targets `Array` of `Tensor`s of targets.\n * @param lossFns `Array` of loss functions.\n * @param outputShapes `Array` of shapes of model outputs.\n */\nfunction checkLossAndTargetCompatibility(\n targets: Tensor[], lossFns: LossOrMetricFn[], outputShapes: Shape[]) {\n // TODO(cais): Dedicated test coverage?\n const keyLosses = [\n losses.meanSquaredError, losses.binaryCrossentropy,\n losses.categoricalCrossentropy\n ];\n for (let i = 0; i < targets.length; ++i) {\n const y = targets[i];\n const loss = lossFns[i];\n const shape = outputShapes[i];\n if (loss == null) {\n continue;\n }\n if (loss === losses.categoricalCrossentropy) {\n if (y.shape[y.shape.length - 1] === 1) {\n throw new ValueError(\n `You are passing a target array of shape ${y.shape} while using ` +\n `a loss 'categorical_crossentropy'. 'categorical_crossentropy'` +\n `expects targets to be binary matrices (1s and 0s) of shape ` +\n `[samples, classes].`);\n // TODO(cais): Example code in error message.\n }\n }\n if (keyLosses.indexOf(loss) !== -1) {\n const slicedYShape = y.shape.slice(1);\n const slicedShape = shape.slice(1);\n for (let j = 0; j < slicedYShape.length; ++j) {\n const targetDim = slicedYShape[j];\n const outDim = slicedShape[j];\n if (outDim != null && targetDim !== outDim) {\n throw new ValueError(\n `A target Tensor with shape ${y.shape} was passed for an ` +\n `output of shape ${shape}, while using a loss function that ` +\n `expects targets to have the same shape as the output.`);\n }\n }\n }\n }\n}\n\n/**\n * Returns a list of batch indices (tuples of indices).\n * @param size: Integer, total size of the data to slice into batches.\n * @param batchSize: Integer, batch size.\n * @returns An Array of [batchStart, batchEnd] tuples. batchStart is\n * inclusive; batchEnd is exclusive. I.e., each batch consists of indices x\n * that satisfy batchStart <= x < batchEnd.\n */\nexport function makeBatches(\n size: number, batchSize: number): Array<[number, number]> {\n const output: Array<[number, number]> = [];\n let batchStart = 0;\n let batchEnd: number = null;\n while (batchStart < size) {\n batchEnd = batchStart + batchSize;\n if (batchEnd >= size) {\n batchEnd = size;\n }\n output.push([batchStart, batchEnd]);\n batchStart = batchEnd;\n }\n return output;\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by start and stop indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArraysByIndices()` together.\n *\n * @param arrays: the input.\n * @param start: the starting index (inclusive).\n * @param stop: the stopping index (exclusive).\n * @returns The result of the slicing. If `arrays` is an `Array` of\n * `Tensor`s, the slicing will be applied to all elements of the `Array`\n * in the same way.\n */\nfunction sliceArrays(\n arrays: Tensor|Tensor[], start: number, stop: number): Tensor|Tensor[] {\n if (arrays == null) {\n return [null];\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => K.sliceAlongFirstAxis(array, start, stop - start));\n } else { // Tensor.\n return K.sliceAlongFirstAxis(arrays, start, stop - start);\n }\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by random-order indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArrays()` together.\n *\n * @param arrays The input `Tensor` or `Array` of `Tensor`s to slice.\n * If an `Array` of `Tensor`s, all `Tensor`s will be sliced in the\n * same fashion.\n * @param indices The indices to use for slicing along the first (batch)\n * dimension.\n * @returns Result(s) of the slicing.\n */\nexport function sliceArraysByIndices(\n arrays: Tensor|Tensor[], indices: Tensor1D): Tensor|Tensor[] {\n return tfc.tidy(() => {\n if (arrays == null) {\n return null;\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => (sliceArraysByIndices(array, indices) as Tensor));\n } else {\n // TODO(cais): indices should be a pre-constructed Tensor1D to avoid\n // tensor1d() calls.\n return K.gather(\n arrays, indices.dtype === 'int32' ? indices : indices.toInt());\n }\n });\n}\n\n/**\n * Check inputs provided by the user.\n *\n * Porting Note: This corresponds to _standardize_input_data() in Python\n * Keras. Because of the strong typing in TF.js, we do not need to convert\n * the data. Specifically:\n * 1) in PyKeras, `data` can be `DataFrame` instances from pandas, for\n * example. We don't need to worry about that here because there is no\n * widely popular javascript/typesdcript equivalent of pandas (so far).\n * If one becomes available in the future, we can add support.\n * 2) in PyKeras, inputs can be Python dict. But here we are stipulating\n * that the data is either a single `Tensor` or an Array of `Tensor`s. We\n * may add support for `Object` data inputs in the future when the need\n * arises.\n *\n * Instead, we perform basic checks for number of parameters and shapes.\n *\n * @param data: The input data.\n * @param names: Name for the inputs, from the model.\n * @param shapes: Expected shapes for the input data, from the model.\n * @param checkBatchAxis: Whether the size along the batch axis (i.e., the\n * first dimension) will be checked for matching.\n * @param exceptionPrefix: Execption prefix message, used in generating error\n * messages.\n * @throws ValueError: on incorrect number of inputs or mismatches in shapes.\n */\nfunction checkInputData(\n data: Tensor|Tensor[], names: string[], shapes?: Shape[],\n checkBatchAxis = true, exceptionPrefix = '') {\n let arrays: Tensor[];\n if (Array.isArray(data)) {\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `the model expected. Expected to see ${names.length} Tensor(s),` +\n ` but instead got ${data.length} Tensors(s).`);\n }\n arrays = data;\n } else {\n if (names.length > 1) {\n throw new ValueError(\n `The model expects ${names.length} ${exceptionPrefix} Tensors, ` +\n `but only received one Tensor. Found: array with shape ` +\n `${JSON.stringify(data.shape)}.`);\n }\n arrays = [data];\n }\n\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s), but got array with ` +\n `shape ${JSON.stringify(array.shape)}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null) {\n if (refDim !== dim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ` +\n `${names[i]} to have shape ${JSON.stringify(shapes[i])} but ` +\n `got array with shape ${JSON.stringify(array.shape)}.`);\n }\n }\n }\n }\n }\n}\n\n/**\n * Maps metric functions to model outputs.\n * @param metrics An `Array` or dict (`Object`) of metric functions.\n * @param outputNames An `Array` of the names of model outputs.\n * @returns An `Array` (one entry per model output) of `Array` of metric\n * functions. For instance, if the model has 2 outputs, and for the first\n * output we want to compute `binaryAccuracy` and `binaryCrossentropy`,\n * and just `binaryAccuracy` for the second output, the `Array` would look\n * like:\n * `[[binaryAccuracy, binaryCrossentropy], [binaryAccuracy]]`\n * @throws TypeError: if `null` or `undefined` value is provided.\n */\nfunction collectMetrics(\n metrics: string[]|{[outputName: string]: string | string[]},\n outputNames: string[]): string[][] {\n if (metrics == null || Array.isArray(metrics) && metrics.length === 0) {\n return outputNames.map(name => []);\n }\n if (Array.isArray(metrics)) {\n // We then apply all metrics to all outputs.\n return outputNames.map(name => metrics);\n } else if (metrics != null) {\n // In this case, metrics is a dict.\n const nestedMetrics: string[][] = [];\n for (const name of outputNames) {\n let outputMetrics: string|string[] =\n metrics.hasOwnProperty(name) ? metrics[name] : [];\n if (!Array.isArray(outputMetrics)) {\n outputMetrics = [outputMetrics];\n }\n nestedMetrics.push(outputMetrics as string[]);\n }\n return nestedMetrics;\n } else {\n throw new TypeError(\n 'Type of metrics argument not understood. Expected an Array or ' +\n 'Object, found: ' + metrics);\n }\n}\n\n/** Verbosity logging level when fitting a model. */\nexport enum ModelLoggingVerbosity {\n SILENT = 0,\n VERBOSE = 1\n}\n\nexport interface ModelEvaluateConfig {\n /**\n * Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Verbosity mode.\n */\n verbose?: ModelLoggingVerbosity;\n\n /**\n * Tensor of weights to weight the contribution of different samples to the\n * loss and metrics.\n */\n sampleWeight?: Tensor;\n\n /**\n * integer: total number of steps (batches of samples)\n * before declaring the evaluation round finished. Ignored with the default\n * value of `undefined`.\n */\n steps?: number;\n}\n\n/**\n * Interface for specifying data to fit a model to data.\n */\nexport interface ModelFitConfig {\n /**\n * Number of samples per gradient update. If unspecified, it\n * will default to 32.\n */\n batchSize?: number;\n\n /** The number of times to iterate over the training data arrays. */\n epochs?: number;\n\n verbose?: ModelLoggingVerbosity;\n\n /**\n * List of callbacks to be called during training.\n * Can consist of one or more of the following fields: `onTrainBegin`,\n * `onTrainEnd`, `onEpochBegin`, `onEpochEnd`, `onBatchBegin`, `onBatchEnd`.\n */\n callbacks?: BaseCallback[]|CustomCallbackConfig|CustomCallbackConfig[];\n\n /**\n * Float between 0 and 1: fraction of the training data\n * to be used as validation data. The model will set apart this fraction of\n * the training data, will not train on it, and will evaluate the loss and\n * any model metrics on this data at the end of each epoch.\n * The validation data is selected from the last samples in the `x` and `y`\n * data provided, before shuffling.\n */\n validationSplit?: number;\n\n /**\n * Data on which to evaluate the loss and any model\n * metrics at the end of each epoch. The model will not be trained on this\n * data. This could be a tuple [xVal, yVal] or a tuple [xVal, yVal,\n * valSampleWeights]. The model will not be trained on this data.\n * `validationData` will override `validationSplit`.\n */\n validationData?: [\n Tensor|Tensor[], Tensor|Tensor[]\n ]|[Tensor | Tensor[], Tensor|Tensor[], Tensor|Tensor[]];\n\n /**\n * Whether to shuffle the training data before each epoch. Has\n * no effect when `stepsPerEpoch` is not `null`.\n */\n shuffle?: boolean;\n\n /**\n * Optional dictionary mapping class indices (integers) to\n * a weight (float) to apply to the model's loss for the samples from this\n * class during training. This can be useful to tell the model to \"pay more\n * attention\" to samples from an under-represented class.\n */\n classWeight?: {[classIndex: string]: number};\n\n /**\n * Optional array of the same length as x, containing\n * weights to apply to the model's loss for each sample. In the case of\n * temporal data, you can pass a 2D array with shape (samples,\n * sequenceLength), to apply a different weight to every timestep of every\n * sample. In this case you should make sure to specify\n * sampleWeightMode=\"temporal\" in compile().\n */\n sampleWeight?: Tensor;\n\n /**\n * Epoch at which to start training (useful for resuming a previous training\n * run).\n */\n initialEpoch?: number;\n\n /**\n * Total number of steps (batches of samples) before\n * declaring one epoch finished and starting the next epoch. When training\n * with Input Tensors such as TensorFlow data tensors, the default `null` is\n * equal to the number of unique samples in your dataset divided by the\n * batch size, or 1 if that cannot be determined.\n */\n stepsPerEpoch?: number;\n\n /**\n * Only relevant if `stepsPerEpoch` is specified. Total number of steps\n * (batches of samples) to validate before stopping.\n */\n validationSteps?: number;\n\n /**\n *\n */\n yieldEvery?: 'batch'|'epoch'|'never';\n}\n\n/**\n * Configuration for calls to `Model.compile()`.\n */\nexport interface ModelCompileConfig {\n /**\n * An instance of `tf.train.Optimizer` or a string name for an Optimizer.\n */\n optimizer: string|Optimizer;\n\n /**\n * Object function(s) or name(s) of object function(s).\n * If the model has multiple outputs, you can use a different loss\n * on each output by passing a dictionary or an Array of losses.\n * The loss value that will be minimized by the model will then be the sum\n * of all individual losses.\n */\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n\n /**\n * List of metrics to be evaluated by the model during training and testing.\n * Typically you will use `metrics=['accuracy']`.\n * To specify different metrics for different outputs of a multi-output\n * model, you could also pass a dictionary.\n */\n metrics?: string[]|{[outputName: string]: string};\n\n // TODO(cais): Add lossWeights, sampleWeightMode, weightedMetrics, and\n // targetTensors.\n}\n\n/**\n * A `Model` is a directed, acyclic graph of `Layer`s plus methods for\n * training, evaluation, prediction and saving.\n *\n * `Model` is the basic unit of training, inference and evaluation in\n * TensorFlow.js. To create a `Model`, use `model`.\n *\n * See also:\n * `Sequential`, `loadModel`.\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Model extends Container implements tfc.InferenceModel {\n static className = 'Model';\n optimizer: Optimizer;\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n lossFunctions: LossOrMetricFn[];\n\n // TODO(cais): These private variables should probably not have the string\n // 'feed' in their names, because we are not dealing with a symbolic\n // backend.\n private feedOutputShapes: Shape[];\n private feedLossFns: LossOrMetricFn[];\n private collectedTrainableWeights: LayerVariable[];\n private testFunction: (data: Tensor[]) => Scalar[];\n history: History;\n\n // A public property that can be set by Callbacks to order early stopping\n // during `fit()` calls.\n stopTraining: boolean;\n\n metrics: string[]|{[outputName: string]: string};\n metricsNames: string[];\n // Porting Note: `metrics_tensors` in PyKeras is a symbolic tensor. But given\n // the imperative nature of tfjs-core, `metricsTensors` is a\n // TypeScript function here.\n // Also note that due to the imperative nature of tfjs-core, `metricsTensor`\n // here needs an output index to keep track of which output of the Model\n // a metric belongs to. This is unlike `metrics_tensors` in PyKeras,\n // which is a `list` of symbolic tensors, each of which has implicit\n // \"knowledge\" of the outputs it depends on.\n metricsTensors: Array<[LossOrMetricFn, number]>;\n\n constructor(config: ContainerConfig) {\n super(config);\n }\n\n /**\n * Print a text summary of the model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - If the model has non-sequential-like topology, the inputs each layer\n * receives\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const input1 = tf.input({shape: [10]});\n * const input2 = tf.input({shape: [20]});\n * const dense1 = tf.layers.dense({units: 4}).apply(input1);\n * const dense2 = tf.layers.dense({units: 8}).apply(input2);\n * const concat = tf.layers.concatenate().apply([dense1, dense2]);\n * const output =\n * tf.layers.dense({units: 3, activation: 'softmax'}).apply(concat);\n *\n * const model = tf.model({inputs: [input1, input2], outputs: output});\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n throw new ValueError(\n `This model has never been called, thus its weights have not been ` +\n `created yet. So no summary can be displayed. Build the model ` +\n `first (e.g., by calling it on some test data).`);\n }\n printSummary(this, lineLength, positions, printFn);\n }\n\n /**\n * Configures and prepares the model for training and evaluation. Compiling\n * outfits the model with an optimizer, loss, and/or metrics. Calling `fit`\n * or `evaluate` on an un-compiled model will throw an error.\n *\n * @param config a `ModelCompileConfig` specifying the loss, optimizer, and\n * metrics to be used for fitting and evaluating this model.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [0]}\n */\n compile(config: ModelCompileConfig): void {\n if (config.loss == null) {\n config.loss = [];\n }\n this.loss = config.loss;\n\n if (typeof config.optimizer === 'string') {\n this.optimizer = optimizers.getOptimizer(config.optimizer);\n } else {\n if (!(config.optimizer instanceof Optimizer)) {\n throw new ValueError(\n `User-defined optimizer must be an instance of tf.Optimizer.`);\n }\n this.optimizer = config.optimizer;\n }\n\n // TODO(cais): Add lossWeights.\n // TODO(cais): Add sampleWeightMode.\n\n // Prepare loss functions.\n let lossFunctions: LossOrMetricFn[] = [];\n if (!Array.isArray(config.loss) && typeof config.loss !== 'string' &&\n typeof config.loss !== 'function') {\n config.loss = config.loss as {[outputName: string]: string};\n for (const name in config.loss) {\n if (this.outputNames.indexOf(name) === -1) {\n throw new ValueError(\n `Unknown entry in loss dictionary: \"${name}\". Only expect the ` +\n `following keys: ${this.outputNames}`);\n }\n }\n for (const name in this.outputNames) {\n if (config.loss[name] == null) {\n console.warn(\n `Output \"${name}\" is missing from loss dictionary. We assume ` +\n `this was done on purpose, and we will not be expecting data ` +\n `to be passed to ${name} during training`);\n }\n lossFunctions.push(losses.get(config.loss[name]));\n }\n } else if (Array.isArray(config.loss)) {\n if (config.loss.length !== this.outputs.length) {\n throw new ValueError(\n `When passing an Array as loss, it should have one entry per ` +\n `model output. The model has ${this.outputs.length} output(s), ` +\n `but you passed loss=${config.loss}.`);\n }\n const theLosses = config.loss as Array;\n lossFunctions = theLosses.map(l => losses.get(l));\n } else {\n const lossFunction = losses.get(config.loss);\n this.outputs.map(layer => {\n lossFunctions.push(lossFunction);\n });\n }\n\n this.lossFunctions = lossFunctions;\n\n this.feedOutputNames = [];\n this.feedOutputShapes = [];\n this.feedLossFns = [];\n for (let i = 0; i < this.outputs.length; ++i) {\n // TODO(cais): Logic for skipping target(s).\n const shape = this.internalOutputShapes[i];\n const name = this.outputNames[i];\n this.feedOutputNames.push(name);\n this.feedOutputShapes.push(shape);\n this.feedLossFns.push(this.lossFunctions[i]);\n }\n\n // TODO(cais): Add logic for weighted losses.\n // TODO(cais): Add logic for output masks.\n // TODO(cais): Add logic for sample weights.\n const skipTargetIndices: number[] = [];\n\n // Prepare metrics.\n this.metrics = config.metrics;\n // TODO(cais): Add weightedMetrics.\n this.metricsNames = ['loss'];\n this.metricsTensors = [];\n\n // Compute total loss.\n // Porting Note: In PyKeras, metrics_tensors are symbolic tensor objects.\n // Here, metricsTensors are TypeScript functions. This difference is due\n // to the difference in symbolic/imperative property of the backends.\n nameScope('loss', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n // TODO(cais): Add weightedLoss, sampleWeight and mask.\n // The following line should be weightedLoss\n const weightedLoss = this.lossFunctions[i];\n if (this.outputs.length > 1) {\n this.metricsTensors.push([weightedLoss, i]);\n this.metricsNames.push(this.outputNames[i] + '_loss');\n }\n }\n\n // Porting Note: Due to the imperative nature of the backend, we calculate\n // the regularizer penalties in the totalLossFunction, instead of here.\n });\n\n const nestedMetrics = collectMetrics(config.metrics, this.outputNames);\n // TODO(cais): Add nestedWeightedMetrics.\n\n /**\n * Helper function used in loop below.\n */\n const appendMetric =\n (outputIndex: number, metricName: string,\n metricTensor: LossOrMetricFn) => {\n if (this.outputNames.length > 1) {\n metricName = this.outputNames[outputIndex] + '_' + metricName;\n }\n this.metricsNames.push(metricName);\n this.metricsTensors.push([metricTensor, outputIndex]);\n };\n\n nameScope('metric', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n const outputMetrics = nestedMetrics[i];\n // TODO(cais): Add weights and outputWeightedMetrics.\n\n // TODO(cais): Add optional arg `weights` to the following function.\n const handleMetrics = (metrics: string[]) => {\n const metricNamePrefix = '';\n let metricName: string;\n let accFn: LossOrMetricFn;\n let weightedMetricFn: LossOrMetricFn;\n // TODO(cais): Use 'weights_' for weighted metrics.\n\n for (const metric of metrics) {\n if (['accuracy', 'acc', 'crossentropy', 'ce'].indexOf(metric) !==\n -1) {\n const outputShape = this.internalOutputShapes[i];\n\n if (outputShape[outputShape.length - 1] === 1 ||\n this.lossFunctions[i] === losses.binaryCrossentropy) {\n // case: binary accuracy/crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryCrossentropy;\n }\n } else if (\n this.lossFunctions[i] ===\n losses.sparseCategoricalCrossentropy) {\n // case: categorical accuracy / crossentropy with sparse\n // targets.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalCrossentropy;\n }\n } else {\n // case: categorical accuracy / crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalCrossentropy;\n }\n }\n let suffix: string;\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n suffix = 'acc';\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n suffix = 'ce';\n }\n // TODO(cais): Add weighting actually.\n weightedMetricFn = accFn;\n metricName = metricNamePrefix + suffix;\n } else {\n const metricFn = Metrics.get(metric);\n // TODO(cais): Add weighting actually.\n weightedMetricFn = metricFn;\n metricName = metricNamePrefix + metric;\n }\n\n // TODO(cais): Add weighting and masking to metricResult.\n let metricResult: LossOrMetricFn;\n nameScope(metricName, () => {\n metricResult = weightedMetricFn;\n });\n appendMetric(i, metricName, metricResult);\n }\n };\n\n handleMetrics(outputMetrics);\n // TODO(cais): Call handleMetrics with weights.\n }\n });\n\n // Porting Notes: Given the imperative backend of tfjs-core,\n // there is no need for constructing the symbolic graph and placeholders.\n this.collectedTrainableWeights = this.trainableWeights;\n }\n\n /**\n * Check trainable weights count consistency.\n *\n * This will raise a warning if `this.trainableWeights` and\n * `this.collectedTrainableWeights` are inconsistent (i.e., have different\n * numbers of parameters).\n * Inconsistency will typically arise when one modifies `model.trainable`\n * without calling `model.compile()` again.\n */\n private checkTrainableWeightsConsistency(): void {\n if (this.collectedTrainableWeights == null) {\n return;\n }\n if (this.trainableWeights.length !==\n this.collectedTrainableWeights.length) {\n console.warn(\n 'Discrepancy between trainableweights and collected trainable ' +\n 'weights. Did you set `model.trainable` without calling ' +\n '`model.compile()` afterwards?');\n }\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(\n * tf.ones([8, 10]), tf.ones([8, 1]), {batchSize: 4});\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model has\n * multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // TODO(cais): Standardize `config.sampleWeights` as well.\n // Validate user data.\n const standardizedOuts = this.standardizeUserData(x, y, true, batchSize);\n // TODO(cais): If uses `useLearningPhase`, set the corresponding element of\n // the input to 0.\n const ins = standardizedOuts[0].concat(standardizedOuts[1]);\n this.makeTestFunction();\n const f = this.testFunction;\n const testOuts =\n this.testLoop(f, ins, batchSize, config.verbose, config.steps);\n return singletonOrArray(testOuts);\n }\n\n /**\n * Get number of samples provided for training, evaluation or prediction.\n *\n * @param ins Input `Tensor`.\n * @param batchSize Integer batch size, optional.\n * @param steps Total number of steps (batches of samples) before declaring\n * loop finished. Optional.\n * @param stepsName The public API's parameter name for `steps`.\n * @returns Number of samples provided.\n */\n private checkNumSamples(\n ins: Tensor|Tensor[], batchSize?: number, steps?: number,\n stepsName = 'steps'): number {\n let numSamples: number;\n if (steps != null) {\n numSamples = null;\n if (batchSize != null) {\n throw new ValueError(\n `If ${stepsName} is set, batchSize must be null or undefined.` +\n `Got batchSize = ${batchSize}`);\n }\n } else if (ins != null) {\n if (Array.isArray(ins)) {\n numSamples = ins[0].shape[0];\n } else {\n numSamples = ins.shape[0];\n }\n } else {\n throw new ValueError(\n `Either the input data should have a defined shape, or ` +\n `${stepsName} shoud be specified.`);\n }\n return numSamples;\n }\n\n /**\n * Execute intrenal tensors of the model with input data feed.\n * @param inputs Input data feed. Must match the inputs of the model.\n * @param outputs Names of the output tensors to be fetched. Must match\n * names of the SymbolicTensors that belong to the graph.\n * @returns Fetched values for `outputs`.\n */\n execute(inputs: Tensor|Tensor[]|NamedTensorMap, outputs: string|string[]):\n Tensor|Tensor[] {\n if (Array.isArray(outputs) && outputs.length === 0) {\n throw new ValueError(\n '`outputs` is an empty Array, which is not allowed.');\n }\n\n const outputsIsArray = Array.isArray(outputs);\n const outputNames = (outputsIsArray ? outputs as string[] :\n [outputs as string]) as string[];\n const outputSymbolicTensors = this.retrieveSymbolicTensors(outputNames);\n\n // Format the input into a FeedDict.\n const feedDict = new FeedDict();\n if (inputs instanceof Tensor) {\n inputs = [inputs as Tensor];\n }\n if (Array.isArray(inputs)) {\n if ((inputs as Tensor[]).length !== this.inputs.length) {\n throw new ValueError(\n `The number of inputs provided (${(inputs as Tensor[]).length}) ` +\n `does not match the number of inputs of this model ` +\n `(${this.inputs.length}).`);\n }\n for (let i = 0; i < this.inputs.length; ++i) {\n feedDict.add(this.inputs[i], (inputs as Tensor[])[i]);\n }\n } else {\n for (const input of this.inputs) {\n const tensorValue = (inputs as NamedTensorMap)[input.name];\n if (tensorValue == null) {\n throw new ValueError(\n `No value is provided for the model's input ${input.name}`);\n }\n feedDict.add(input, tensorValue);\n }\n }\n\n // Run execution.\n const executeOutputs = execute(outputSymbolicTensors, feedDict) as Tensor[];\n return outputsIsArray ? executeOutputs : executeOutputs[0];\n }\n\n /**\n * Retrieve the model's internal symbolic tensors from symbolic-tensor names.\n */\n private retrieveSymbolicTensors(symbolicTensorNames: string[]):\n SymbolicTensor[] {\n const outputSymbolicTensors: SymbolicTensor[] =\n pyListRepeat(null, symbolicTensorNames.length);\n let outputsRemaining = symbolicTensorNames.length;\n for (const layer of this.layers) {\n const layerOutputs: SymbolicTensor[] = Array.isArray(layer.output) ?\n layer.output as SymbolicTensor[] :\n [layer.output as SymbolicTensor];\n const layerOutputNames = layerOutputs.map(output => output.name);\n for (let i = 0; i < symbolicTensorNames.length; ++i) {\n const index = layerOutputNames.indexOf(symbolicTensorNames[i]);\n if (index !== -1) {\n outputSymbolicTensors[i] = layerOutputs[index];\n outputsRemaining--;\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n\n if (outputsRemaining > 0) {\n const remainingNames: string[] = [];\n outputSymbolicTensors.forEach((tensor, i) => {\n if (tensor == null) {\n remainingNames.push(symbolicTensorNames[i]);\n }\n });\n throw new ValueError(\n `Cannot find SymbolicTensors for output name(s): ` +\n `${JSON.stringify(remainingNames)}`);\n }\n return outputSymbolicTensors;\n }\n\n /**\n * Helper method to loop over some data in batches.\n *\n * Porting Note: Not using the functional approach in the Python equivalent\n * due to the imperative backend.\n * Porting Note: Does not support step mode currently.\n *\n * @param ins: input data\n * @param batchSize: integer batch size.\n * @param verbose: verbosity model\n * @returns: Predictions as `Tensor` (if a single output) or an `Array` of\n * `Tensor` (if multipe outputs).\n */\n private predictLoop(ins: Tensor|Tensor[], batchSize = 32, verbose = false):\n Tensor|Tensor[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins);\n if (verbose) {\n throw new NotImplementedError(\n 'Verbose predictLoop() is not implemented yet.');\n }\n\n // Sample-based predictions.\n // Porting Note: Tensor currently does not support sliced assignments as\n // in numpy, e.g., x[1:3] = y. Therefore we use concatenation while\n // iterating over the batches.\n\n const batches = makeBatches(numSamples, batchSize);\n const outs: Tensor[] = [];\n // TODO(cais): Can the scope() be pushed down inside the for loop?\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchOuts = tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n // TODO(cais): Take care of the case of the last element is a flag for\n // training/test.\n const insBatch = sliceArrays(ins, batchStart, batchEnd);\n\n // Construct the feeds for execute();\n const feeds = [];\n if (Array.isArray(insBatch)) {\n for (let i = 0; i < insBatch.length; ++i) {\n feeds.push({key: this.inputs[i], value: insBatch[i]});\n }\n } else {\n feeds.push({key: this.inputs[0], value: insBatch});\n }\n const feedDict = new FeedDict(feeds);\n return execute(this.outputs, feedDict) as Tensor[];\n });\n if (batchIndex === 0) {\n // Pre-allocate.\n for (const batchOut of batchOuts) {\n outs.push(batchOut);\n }\n } else {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs[i] = K.concatAlongFirstAxis(outs[i], batchOuts[i]);\n }\n }\n }\n return singletonOrArray(outs);\n });\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFlow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([8, 10]), {batchSize: 4}).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param config A `ModelPredictConfig` object containing optional fields.\n *\n * @return Prediction results as a `Tensor`(s).\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, false);\n // TODO(cais): Take care of stateful models.\n // if (this.stateful) ...\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n return this.predictLoop(x, batchSize);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predictOnBatch(tf.ones([8, 10])).print();\n * ```\n * @param x: Input samples, as an Tensor\n * @return Tensor(s) of predictions\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, true);\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n return this.predictLoop(x, x.shape[0]);\n }\n\n protected standardizeUserData(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor}, checkBatchAxis = true,\n batchSize?: number): [Tensor[], Tensor[], Tensor[]] {\n // TODO(cais): Add sampleWeight, classWeight\n if (this.optimizer == null) {\n throw new RuntimeError(\n 'You must compile a model before training/testing. Use ' +\n 'Model.compile(modelCompileConfig).');\n }\n const outputShapes: Shape[] = [];\n for (let i = 0; i < this.feedOutputShapes.length; ++i) {\n const outputShape = this.feedOutputShapes[i];\n const lossFn = this.feedLossFns[i];\n if (lossFn === losses.sparseCategoricalCrossentropy) {\n outputShapes.push(\n outputShape.slice(0, outputShape.length - 1).concat([1]));\n } else {\n // Porting Note: Because of strong typing `lossFn` must be a function.\n outputShapes.push(outputShape);\n }\n }\n x = standardizeInputData(\n x, this.feedInputNames, this.feedInputShapes, false, 'input') as\n Tensor[];\n y = standardizeInputData(\n y, this.feedOutputNames, outputShapes, false, 'target') as Tensor[];\n // TODO(cais): Standardize sampleWeights & classWeights.\n checkArrayLengths(x, y, null);\n // TODO(cais): Check sampleWeights as well.\n checkLossAndTargetCompatibility(y, this.feedLossFns, this.feedOutputShapes);\n if (this.stateful && batchSize != null && batchSize > 0) {\n if (x[0].shape[0] % batchSize !== 0) {\n throw new ValueError(\n `In a stateful network, you should only pass inputs with a ` +\n `number of samples that is divisible by the batch size ` +\n `${batchSize}. Found: ${x[0].shape[0]} sample(s).`);\n }\n }\n // TODO(cais): Deal with the case of model.stateful == true.\n return [x, y, null];\n }\n\n /**\n * Abstract fit function for `f(ins)`.\n * @param f A Function returning a list of tensors. For training, this\n * function is expected to perform the updates to the variables.\n * @param ins List of tensors to be fed to `f`.\n * @param outLabels List of strings, display names of the outputs of `f`.\n * @param batchSize Integer batch size or `== null` if unknown.\n * @param epochs Number of times to iterate over the data.\n * @param verbose Verbosity mode: 0, 1, or 2.\n * @param callbacks List of callbacks to be called during training.\n * @param valF Function to call for validation.\n * @param valIns List of tensors to be fed to `valF`.\n * @param shuffle Whether to shuffle the data at the beginning of every\n * epoch.\n * @param callbackMetrics List of strings, the display names of the metrics\n * passed to the callbacks. They should be the concatenation of the\n * display names of the outputs of `f` and the list of display names\n * of the outputs of `valF`.\n * @param initialEpoch Epoch at which to start training (useful for\n * resuming a previous training run).\n * @param stepsPerEpoch Total number of steps (batches on samples) before\n * declaring one epoch finished and starting the next epoch. Ignored with\n * the default value of `undefined` or `null`.\n * @param validationSteps Number of steps to run validation for (only if\n * doing validation from data tensors). Not applicable for tfjs-layers.\n * @returns A `History` object.\n */\n private async fitLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], outLabels?: string[],\n batchSize?: number, epochs?: number, verbose?: number,\n callbacks?: BaseCallback[], valF?: (data: Tensor[]) => Scalar[],\n valIns?: Tensor[], shuffle?: boolean|string, callbackMetrics?: string[],\n initialEpoch?: number, stepsPerEpoch?: number,\n validationSteps?: number): Promise {\n if (batchSize == null) {\n batchSize = 32;\n }\n if (epochs == null) {\n epochs = 1;\n }\n if (shuffle == null) {\n shuffle = true;\n }\n if (initialEpoch == null) {\n initialEpoch = 0;\n }\n\n // TODO(cais): Change const to let below when implementing validation.\n let doValidation = false;\n if (valF != null && valIns != null) {\n doValidation = true;\n // TODO(cais): verbose message.\n }\n if (validationSteps != null) {\n doValidation = true;\n if (stepsPerEpoch == null) {\n throw new ValueError(\n 'Can only use `validationSteps` when doing step-wise training, ' +\n 'i.e., `stepsPerEpoch` must be set.');\n }\n }\n\n const numTrainSamples =\n this.checkNumSamples(ins, batchSize, stepsPerEpoch, 'steps_per_epoch');\n let indexArray: number[];\n if (numTrainSamples != null) {\n indexArray = range(0, numTrainSamples);\n }\n\n this.history = new History();\n if (callbacks == null) {\n callbacks = [new BaseLogger()];\n } else {\n callbacks = ([new BaseLogger()] as BaseCallback[]).concat(callbacks);\n }\n callbacks = callbacks.concat([this.history]);\n\n if (verbose > 0) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n const callbackList = new CallbackList(callbacks);\n\n // TODO(cais): Figure out when this Model instance can have a dynamically\n // set property called 'callback_model' as in PyKeras.\n callbackList.setModel(this);\n callbackList.setParams({\n epochs,\n initialEpoch,\n steps: stepsPerEpoch,\n verbose,\n doValidation,\n metrics: callbackMetrics,\n });\n await callbackList.onTrainBegin();\n this.stopTraining = false;\n // TODO(cais): Take care of callbacks.validation_data as in PyKeras.\n\n // TODO(cais): Pre-convert feeds for performance as in PyKeras.\n\n for (let epoch = initialEpoch; epoch < epochs; ++epoch) {\n await callbackList.onEpochBegin(epoch);\n const epochLogs: UnresolvedLogs = {};\n if (stepsPerEpoch != null) {\n throw new NotImplementedError(\n 'stepsPerEpoch mode is not implemented yet.');\n } else {\n if (shuffle === 'batch') {\n throw new NotImplementedError(\n 'batch shuffling is not implemneted yet');\n } else if (shuffle) {\n util.shuffle(indexArray);\n }\n // Convert the potentially shuffled indices to Tensor1D, to avoid the\n // cost of repeated creation of Array1Ds later on.\n const epochIndexArray1D = tensor1d(indexArray);\n\n const batches = makeBatches(numTrainSamples, batchSize);\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchLogs: UnresolvedLogs = {};\n await callbackList.onBatchBegin(batchIndex, batchLogs);\n\n tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds = K.sliceAlongFirstAxis(\n epochIndexArray1D, batchStart,\n batchEnd - batchStart) as Tensor1D;\n batchLogs['batch'] = batchIndex;\n batchLogs['size'] = batchEnd - batchStart;\n\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Tensor[];\n const outs = f(insBatch);\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = outs[i];\n batchLogs[label] = out;\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n }\n\n if (batchIndex === batches.length - 1) { // Last batch.\n if (doValidation) {\n const valOuts = this.testLoop(valF, valIns, batchSize);\n // Porting Notes: In tfjs-layers, valOuts is always an Array.\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = valOuts[i];\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n epochLogs['val_' + label] = out;\n }\n }\n }\n });\n\n await callbackList.onBatchEnd(batchIndex, batchLogs);\n disposeTensorsInLogs(batchLogs);\n\n if (this.stopTraining) {\n break;\n }\n // TODO(cais): return outs as list of Tensor.\n }\n\n epochIndexArray1D.dispose();\n }\n // TODO(cais): Run validation at the end of the epoch.\n await callbackList.onEpochEnd(epoch, epochLogs);\n if (this.stopTraining) {\n break;\n }\n }\n await callbackList.onTrainEnd();\n\n await this.history.syncData();\n return this.history;\n }\n\n /**\n * Loop over some test data in batches.\n * @param f A Function returning a list of tensors.\n * @param ins Array of tensors to be fed to `f`.\n * @param batchSize Integer batch size or `null` / `undefined`.\n * @param verbose verbosity mode.\n * @param steps Total number of steps (batches of samples) before declaring\n * test finished. Ignored with the default value of `null` / `undefined`.\n * @returns Array of Scalars.\n */\n private testLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], batchSize?: number,\n verbose = 0, steps?: number): Scalar[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins, batchSize, steps, 'steps');\n const outs: Scalar[] = [];\n if (verbose === 1) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n // TODO(cais): Use `indicesForConversionToDense' to prevent slow down.\n if (steps != null) {\n throw new NotImplementedError(\n 'steps mode in testLoop() is not implemented yet');\n } else {\n const batches = makeBatches(numSamples, batchSize);\n const indexArray = tensor1d(range(0, numSamples));\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds =\n K.sliceAlongFirstAxis(\n indexArray, batchStart, batchEnd - batchStart) as Tensor1D;\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Scalar[];\n const batchOuts = f(insBatch);\n if (batchIndex === 0) {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs.push(getScalar(0));\n }\n }\n for (let i = 0; i < batchOuts.length; ++i) {\n const batchOut = batchOuts[i];\n outs[i] =\n tfc.add(\n outs[i],\n tfc.mul(getScalar(batchEnd - batchStart), batchOut)) as\n Scalar;\n }\n }\n for (let i = 0; i < outs.length; ++i) {\n outs[i] = tfc.div(outs[i], getScalar(numSamples)) as Scalar;\n }\n }\n return outs;\n });\n }\n\n private getDedupedMetricsNames(): string[] {\n const outLabels = this.metricsNames;\n // Rename duplicated metrics names (can happen with an output layer shared\n // among multiple dataflows).\n const dedupedOutLabels = [];\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n let newLabel = label;\n if (count(outLabels, label) > 1) {\n const dupIndex = count(outLabels.slice(0, i), label);\n newLabel += `_${dupIndex}`;\n }\n dedupedOutLabels.push(newLabel);\n }\n return dedupedOutLabels;\n }\n\n private makeTestFunction() {\n this.testFunction = (data: Tensor[]) => {\n return tfc.tidy(() => {\n const valOutputs: Scalar[] = [];\n let totalLoss: Scalar;\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs = execute(this.outputs, feedDict) as Tensor[];\n // Compute total loss.\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n // TODO(cais): Add sample weighting and replace the simple\n // averaging.\n const loss = tfc.mean(lossFunction(targets[i], outputs[i])) as Scalar;\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss) as Scalar;\n }\n valOutputs.push(totalLoss);\n }\n // Compute the metrics.\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0]; // TODO(cais): Restore.\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex]));\n valOutputs.push(meanMetric as Scalar);\n }\n return valOutputs;\n });\n };\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * for (let i = 1; i < 5 ; ++i) {\n * const h = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(\"Loss after Epoch \" + i + \" : \" + h.history.loss[0]);\n * }\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // Validate user data.\n // TODO(cais): Add sampleWeight and classWeight.\n const standardizedOuts = this.standardizeUserData(x, y, false, batchSize);\n let inputs = standardizedOuts[0];\n let targets = standardizedOuts[1];\n // TODO(cais): Make use of sampleWeights in standardizedOuts[2] when\n // available.\n\n // Prepare validation data.\n let doValidation = false;\n let valX: Tensor|Tensor[];\n let valY: Tensor|Tensor[];\n let valIns: Tensor[];\n // A flag to keep track of whether `valIns`, `inputs` and `targets` need\n // to be memory-disposed prior to returning from this method. This is the\n // case if `config.validationSplit` is set to a number between 0 and 1, in\n // which case the input `x` and `y` tensors will be sliced, leading to\n // allocation of new tensor memory.\n let needValidationDisposal = false;\n if (config.validationData != null && config.validationData.length > 0) {\n doValidation = true;\n if (config.validationData.length === 2) {\n // config.validationData consists of valX and valY.\n valX = config.validationData[0];\n valY = config.validationData[1];\n } else if (config.validationData.length === 3) {\n throw new NotImplementedError(\n 'validationData including sample weights is not supported yet.');\n } else {\n throw new ValueError(\n `When passing validation data, it must contain 2 (valX, valY) ` +\n `or 3 (valX, valY, valSampleWeight) items; ` +\n `${config.validationData} is invalid.`);\n }\n\n const valStandardized =\n this.standardizeUserData(valX, valY, true, batchSize);\n valX = valStandardized[0] as Tensor[];\n valY = valStandardized[1] as Tensor[];\n // TODO(cais): Use validation sample weights in valStandardized[2] once\n // it becomes available.\n valIns = valX.concat(valY);\n // TODO(cais): Add useLearningPhase data properly.\n } else if (\n config.validationSplit != null && config.validationSplit > 0 &&\n config.validationSplit < 1) {\n doValidation = true;\n // Porting Note: In tfjs-layers, inputs[0] is always an Tensor.\n const splitAt =\n Math.floor(inputs[0].shape[0] * (1 - config.validationSplit));\n const originalBatchSize = inputs[0].shape[0];\n valX = sliceArrays(inputs, splitAt, originalBatchSize) as Tensor[];\n inputs = sliceArrays(inputs, 0, splitAt) as Tensor[];\n valY = sliceArrays(targets, splitAt, originalBatchSize) as Tensor[];\n targets = sliceArrays(targets, 0, splitAt) as Tensor[];\n needValidationDisposal = true;\n // TODO(cais): Once sampleWeights becomes available, slice it to get\n // valSampleWeights.\n valIns = valX.concat(valY);\n\n // TODO(cais): Add useLearningPhase data properly.\n } else if (config.validationSteps != null) {\n doValidation = true;\n // TODO(cais): Add useLearningPhase.\n }\n\n const ins = inputs.concat(targets);\n\n this.checkTrainableWeightsConsistency();\n\n // TODO(cais): Handle use_learning_phase and learning_phase?\n\n // Porting Note: Here we see a key deviation of tfjs-layers from Keras.\n // Due to the imperative nature of tfjs-layers' backend (tfjs-core),\n // we do not construct symbolic computation graphs to embody the training\n // process. Instead, we define a function that performs the training\n // action.\n // In PyKeras, the data (inputs and targets) are fed through graph\n // placeholders. In tfjs-layers, the data are fed as function arguments.\n // Since the function are defined below in the scope, we don't have\n // equivalents of PyKeras's `_make_train_funciton`.\n\n // Creat a function that performs the following actions:\n // 1) computes the losses,\n // 2) add them to get the total loss,\n // 3) call the optimizer computes the gradients of the Model's trainable\n // weights w.r.t. the total loss and update the variables.\n // 4) calculate the metrics\n // 5) return the values of the losses and metrics.\n const trainFunction = (data: Tensor[]) => {\n const losses: Tensor[] = [];\n const lossValues: Scalar[] = [];\n\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n\n const metricsValues: Scalar[] = [];\n\n // Create a function that computes the total loss based on the inputs.\n // This function is used for obtaining gradients through backprop.\n const totalLossFunction = () => {\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs =\n execute(this.outputs, feedDict, {'training': true}) as Tensor[];\n // TODO(cais): Take care of the case of multiple outputs from a\n // single layer?\n\n let totalLoss: Tensor;\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n const loss = lossFunction(targets[i], outputs[i]);\n losses.push(loss);\n // TODO(cais): push Scalar instead.\n const meanLoss = tfc.mean(loss) as Scalar;\n // TODO(cais): Use a scope() instead, to avoid ownership.\n lossValues.push(meanLoss);\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss);\n }\n }\n\n // Compute the metrics.\n // TODO(cais): These should probably be calculated outside\n // totalLossFunction to benefit speed?\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0];\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex])) as\n Scalar;\n tfc.keep(meanMetric);\n // TODO(cais): Use a scope() instead, to avoid ownership.\n metricsValues.push(meanMetric);\n }\n\n totalLoss = tfc.mean(totalLoss);\n\n // Add regularizer penalties.\n this.calculateLosses().forEach(regularizerLoss => {\n totalLoss = tfc.add(totalLoss, regularizerLoss);\n });\n\n return totalLoss as Scalar;\n };\n\n const variables = this.collectedTrainableWeights.map(\n param => param.read() as tfc.Variable);\n const returnCost = true;\n const totalLossValue =\n this.optimizer.minimize(totalLossFunction, returnCost, variables);\n\n return [totalLossValue].concat(metricsValues);\n };\n\n const outLabels = this.getDedupedMetricsNames();\n\n let valFunction: (data: Tensor[]) => Scalar[];\n let callbackMetrics: string[];\n if (doValidation) {\n this.makeTestFunction();\n valFunction = this.testFunction;\n callbackMetrics =\n outLabels.slice().concat(outLabels.map(n => 'val_' + n));\n } else {\n valFunction = null;\n valIns = [];\n callbackMetrics = outLabels.slice();\n }\n\n const callbacks = standardizeCallbacks(config.callbacks);\n const out = await this.fitLoop(\n trainFunction, ins, outLabels, batchSize, config.epochs, config.verbose,\n callbacks, valFunction, valIns, config.shuffle, callbackMetrics,\n config.initialEpoch, null, null);\n if (needValidationDisposal) {\n valIns.forEach(tensor => tensor.dispose());\n inputs.forEach(tensor => tensor.dispose());\n targets.forEach(tensor => tensor.dispose());\n }\n return out;\n // TODO(cais): Add value to outLabels.\n }\n\n /**\n * Extract weight values of the model.\n *\n * @param config: An instance of `io.SaveConfig`, which specifies\n * model-saving options such as whether only trainable weights are to be\n * saved.\n * @returns A `NamedTensorMap` mapping original weight names (i.e.,\n * non-uniqueified weight names) to their values.\n */\n protected getNamedWeights(config?: io.SaveConfig): NamedTensorMap {\n const namedWeights: NamedTensorMap = {};\n\n const trainableOnly = config != null && config.trainableOnly;\n const weights = trainableOnly ? this.trainableWeights : this.weights;\n const weightValues = this.getWeights(trainableOnly);\n for (let i = 0; i < weights.length; ++i) {\n if (trainableOnly && !weights[i].trainable) {\n // Optionally skip non-trainable weights.\n continue;\n }\n namedWeights[weights[i].originalName] = weightValues[i];\n }\n return namedWeights;\n }\n\n // tslint:disable:max-line-length\n /**\n * Save the configuration and/or weights of the Model.\n *\n * An `IOHandler` is an object that has a `save` method of the proper\n * signature defined. The `save` method manages the storing or transmission\n * of serialized data (\"artifacts\") that represent the model's topology and\n * weights onto or via a specific medium, such as file downloads, local\n * storage, IndexedDB in the web browser and HTTP requests to a server.\n * TensorFlow.js provides `IOHandler` implementations for a number of\n * frequently used saving mediums, such as `tf.io.browserDownloads` and\n * `tf.io.browserLocalStorage`. See `tf.io` for more details.\n *\n * This method also allows you to refer to certain types of `IOHandler`s as\n * URL-like string shortcuts, such as 'localstorage://' and 'indexeddb://'.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Saving `model`'s topology and weights as two files\n * (`my-model-1.json` and `my-model-1.weights.bin`) downloaded from browser.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('downloads://my-model-1');\n * ```\n *\n * Example 4. Send `model`'s topology and weights to an HTTP server.\n * See the documentation of `tf.io.browserHTTPRequests` for more details\n * including specifying request parameters and implementation of the server.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('http://my-server/model/upload');\n * ```\n *\n * @param handlerOrURL An instance of `IOHandler` or a URL-like,\n * scheme-based string shortcut for `IOHandler`.\n * @param config Options for saving the model.\n * @returns A `Promise` of `SaveResult`, which summarizes the result of the\n * saving, such as byte sizes of the saved artifacts for the model's\n * topology and weight values.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n // tslint:enable:max-line-length\n async save(handlerOrURL: io.IOHandler|string, config?: io.SaveConfig):\n Promise {\n if (typeof handlerOrURL === 'string') {\n const handlers = io.getSaveHandlers(handlerOrURL);\n if (handlers.length === 0) {\n throw new ValueError(\n `Cannot find any save handlers for URL '${handlerOrURL}'`);\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) save handlers for ` +\n `URL '${handlerOrURL}'`);\n }\n handlerOrURL = handlers[0];\n }\n if (handlerOrURL.save == null) {\n throw new ValueError(\n 'Model.save() cannot proceed because the IOHandler provided does ' +\n 'not have the `save` attribute defined.');\n }\n\n const weightDataAndSpecs =\n await io.encodeWeights(this.getNamedWeights(config));\n\n const returnString = false;\n const unusedArg: {} = null;\n const modelConfig = this.toJSON(unusedArg, returnString);\n\n return handlerOrURL.save({\n modelTopology: modelConfig,\n weightData: weightDataAndSpecs.data,\n weightSpecs: weightDataAndSpecs.specs\n });\n }\n}\n\nserialization.SerializationMap.register(Model);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source keras/models.py */\n\n// tslint:disable:max-line-length\nimport {io, Scalar, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from './backend/state';\nimport {History} from './base_callbacks';\nimport {Input} from './engine/input_layer';\nimport {getSourceInputs, Layer, Node, SymbolicTensor} from './engine/topology';\nimport {Model, ModelCompileConfig, ModelEvaluateConfig, ModelFitConfig} from './engine/training';\nimport {RuntimeError, ValueError} from './errors';\nimport {deserialize} from './layers/serialization';\nimport {Kwargs, NamedTensorMap, Shape} from './types';\nimport {JsonDict} from './types';\nimport * as generic_utils from './utils/generic_utils';\nimport {convertPythonicToTs} from './utils/serialization_utils';\nimport {getExactlyOneShape} from './utils/types_utils';\n// tslint:enable:max-line-length\n\n/**\n * Parses a JSON model configuration file and returns a model instance.\n * @param modelAndWeightsConfig JSON object or string encoding a model and\n * weights configuration.\n * @param custom_objects Optional dictionary mapping names\n * (strings) to custom classes or functions to be\n * considered during deserialization.\n * @returns A TensorFlow.js Layers `Model` instance (uncompiled).\n */\nexport async function modelFromJSON(\n modelAndWeightsConfig: ModelAndWeightsConfig,\n customObjects?: serialization.ConfigDict): Promise {\n let modelTopology = modelAndWeightsConfig.modelTopology;\n if (modelTopology['model_config'] != null) {\n // If the model-topology JSON contains a 'model_config' field, then it is\n // a full model JSON (e.g., from `keras.Model.save()`), which contains\n // not only the model's architecture in its 'model_config' field, but\n // additional information such as the model's optimizer. We use only the\n // 'model_config' field currently.\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const tsConfig =\n convertPythonicToTs(modelTopology) as serialization.ConfigDict;\n const model = deserialize(tsConfig, customObjects) as Model;\n\n if (modelAndWeightsConfig.weightsManifest != null) {\n // Load the weight values keyed by the original tensor names in the model\n // file that was loaded. These should match the keys of the weight\n // manifest.\n const weightValues =\n await io.loadWeights(\n modelAndWeightsConfig.weightsManifest,\n modelAndWeightsConfig.pathPrefix,\n model.weights.map(weight => weight.originalName)) as NamedTensorMap;\n\n // Map the weights to the unique tensor names generated during model loading\n const uniqueWeightValues: NamedTensorMap = {};\n for (const weight of model.weights) {\n uniqueWeightValues[weight.originalName] =\n weightValues[weight.originalName];\n }\n\n const skipMismatches: boolean = null;\n const isNamedTensorMap = true;\n model.loadWeights(uniqueWeightValues, skipMismatches, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Options for loading a saved mode in TensorFlow.js format.\n */\nexport interface ModelAndWeightsConfig {\n /**\n * A JSON object or JSON string containing the model config.\n *\n * This can be either of the following two formats:\n * - A model archiecture-only config, i.e., a format consistent with the\n * return value of`keras.Model.to_json()`.\n * - A full model config, containing not only model architecture, but also\n * training options and state, i.e., a format consistent with the return\n * value of `keras.models.save_model()`.\n */\n modelTopology: JsonDict;\n\n /**\n * A weights manifest in TensorFlow.js format.\n */\n weightsManifest?: io.WeightsManifestConfig;\n\n /**\n * Path to prepend to the paths in `weightManifest` before fetching.\n *\n * The path may optionally end in a slash ('/').\n */\n pathPrefix?: string;\n}\n\n// TODO(nielsene): Remove after: https://github.com/tensorflow/tfjs/issues/400\nexport interface ModelPredictConfig {\n /**\n * Optional. Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Optional. Verbosity mode. Defaults to false.\n */\n verbose?: boolean;\n}\n\n// tslint:disable:max-line-length\n/**\n * Load a model, including its topology and optionally weights. See the\n * Tutorial named \"How to import a Keras Model\" for usage examples.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Load a model from user-selected files from HTML\n * [file input\n * elements](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file).\n *\n * ```js\n * // Note: this code snippet will not work without the HTML elements in the\n * // page\n * const jsonUpload = document.getElementById('json-upload');\n * const weightsUpload = document.getElementById('weights-upload');\n *\n * const model = await tf.loadModel(\n * tf.io.browserFiles([jsonUpload.files[0], weightsUpload.files[0]]));\n * ```\n *\n * Example 4. Load a model from an HTTP server.\n *\n * ```js\n * const model = await\n * tf.loadModel('https://storage.googleapis.com/tfjs-models/tfjs/iris_v1/model.json')\n * ```\n *\n * @param pathOrIOHandler Can be either of the two formats\n * 1. A string path to the `ModelAndWeightsConfig` JSON describing\n * the model in the canonical TensorFlow.js format. This path will be\n * interpreted as a relative HTTP path, to which `fetch` will be used to\n * request the model topology and weight manifest JSON.\n * The content of the JSON file is assumed to be a JSON object with the\n * following fields and values:\n * - 'modelTopology': A JSON object that can be either of:\n * 1. a model architecture JSON consistent with the format of the return\n * value of `keras.Model.to_json()`\n * 2. a full model JSON in the format of `keras.models.save_model()`.\n * - 'weightsManifest': A TensorFlow.js weights manifest.\n * See the Python converter function `save_model()` for more details.\n * It is also assumed that model weights can be accessed from relative\n * paths described by the `paths` fields in weights manifest.\n * 2. An `tf.io.IOHandler` object that loads model artifacts with its `load`\n * method.\n *\n * @returns A `Promise` of `Model`, with the topology and weights loaded.\n */\n// tslint:enable:max-line-length\nexport async function loadModelInternal(pathOrIOHandler: string|\n io.IOHandler): Promise {\n if (typeof pathOrIOHandler === 'string') {\n const handlers = io.getLoadHandlers(pathOrIOHandler);\n if (handlers.length === 0) {\n // For backward compatibility: if no load handler can be found,\n // assume it is a relative http path.\n handlers.push(io.browserHTTPRequest(pathOrIOHandler));\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) load handlers for ` +\n `URL '${pathOrIOHandler}'`);\n }\n pathOrIOHandler = handlers[0];\n }\n return loadModelFromIOHandler(pathOrIOHandler as io.IOHandler);\n}\n\n/**\n * Load a model and optionally its weights, using an IOHandler object.\n */\nexport async function loadModelFromIOHandler(\n handler: io.IOHandler,\n customObjects?: serialization.ConfigDict): Promise {\n if (handler.load == null) {\n throw new ValueError(\n 'Cannot proceed with model loading because the IOHandler provided ' +\n 'does not have the `load` method implemented.');\n }\n const artifacts = await handler.load();\n let modelTopology = artifacts.modelTopology as JsonDict;\n if (modelTopology['model_config'] != null) {\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const model =\n deserialize(\n convertPythonicToTs(modelTopology) as serialization.ConfigDict,\n customObjects) as Model;\n\n // If weightData is present, load the weights into the model.\n if (artifacts.weightData != null) {\n // Loading weights requires weightSpecs.\n if (artifacts.weightSpecs == null) {\n throw new ValueError(\n 'Model artifacts contains weight data, but not weight specs. ' +\n 'Therefore loading of weights cannot proceed.');\n }\n\n const skipMismatch = false;\n const isNamedTensorMap = true;\n model.loadWeights(\n io.decodeWeights(artifacts.weightData, artifacts.weightSpecs),\n skipMismatch, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Configuration for a Sequential model.\n */\nexport interface SequentialConfig {\n /** Stack of layers for the model. */\n layers?: Layer[];\n\n /** The name of this model. */\n name?: string;\n}\n\n/**\n * A model with a stack of layers, feeding linearly from one to the next.\n *\n * `sequential` is a factory function that creates an instance of\n * `Sequential`.\n *\n * ```js\n * // Define a model for linear regression.\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 1, inputShape: [1]}));\n *\n * // Prepare the model for training: Specify the loss and the optimizer.\n * model.compile({loss: 'meanSquaredError', optimizer: 'sgd'});\n *\n * // Generate some synthetic data for training.\n * const xs = tf.tensor2d([1, 2, 3, 4], [4, 1]);\n * const ys = tf.tensor2d([1, 3, 5, 7], [4, 1]);\n *\n * // Train the model using the data then do inference on a data point the\n * // model hasn't seen:\n * await model.fit(xs, ys);\n * model.predict(tf.tensor2d([5], [1, 1])).print();\n * ```\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Sequential extends Model {\n static className = 'Sequential';\n private model: Model;\n private _updatable: boolean;\n constructor(config?: SequentialConfig) {\n super({inputs: [], outputs: []});\n config = config || {};\n\n this.trainable = true;\n this._updatable = true;\n this.built = false;\n\n // Set model name.\n this.name = (config.name != null) ? config.name : getUid('sequential_');\n\n // Add to the model any layers passed to the constructor.\n if (config.layers != null) {\n for (const layer of config.layers) {\n this.add(layer);\n }\n }\n }\n\n /**\n * Adds a layer instance on top of the layer stack.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 8, inputShape: [1]}));\n * model.add(tf.layers.dense({units: 4, activation: 'relu6'}));\n * model.add(tf.layers.dense({units: 1, activation: 'relu6'}));\n * // Note that the untrained model is random at this point.\n * model.predict(tf.randomNormal([10, 1])).print();\n * ```\n * @param layer Layer instance.\n *\n * @exception ValueError In case the `layer` argument does not know its input\n * shape.\n * @exception ValueError In case the `layer` argument has multiple output\n * tensors, or is already connected somewhere else (forbidden in\n * `Sequential` models).\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n add(layer: Layer): void {\n const isLayerModelInstance =\n layer instanceof Sequential || layer instanceof Model;\n let modelLayer: Model;\n if (isLayerModelInstance) {\n modelLayer = layer as Model;\n if (modelLayer.outputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n if (modelLayer.inputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single input tensor. ' +\n 'For multi-input layers, ' +\n 'use the functional API.');\n }\n }\n\n if (this.outputs.length === 0) {\n // first layer in model: check that it is an input layer\n if (layer.inboundNodes.length === 0) {\n // create an input layer\n if (layer.batchInputShape == null) {\n throw new ValueError(\n 'The first layer in a Sequential model must ' +\n 'get an `inputShape` or `batchInputShape` argument.');\n }\n // Instantiate the input layer.\n const x = Input({\n batchShape: layer.batchInputShape,\n dtype: layer.dtype,\n name: layer.name + '_input'\n });\n // This will build the current layer and create the node connecting\n // the current layer to the input layer we just created.\n layer.apply(x);\n }\n\n if (isLayerModelInstance) {\n this.outputs = modelLayer.outputs;\n this.inputs = modelLayer.inputs;\n } else {\n if (layer.inboundNodes.length !== 1) {\n throw new ValueError(\n 'A layer added to a Sequential model must not already be ' +\n `connected somewhere else. Model received layer ${layer.name} ` +\n `which has ${layer.inboundNodes.length} pre-existing inbound ` +\n 'connections.');\n }\n\n if (layer.inboundNodes[0].outputTensors.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [layer.inboundNodes[0].outputTensors[0]];\n this.inputs = getSourceInputs(this.outputs[0]);\n }\n\n this.inboundNodes = [];\n // We create an input node, which we will keep updated\n // as we add more layers.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n // no model-level masking for now\n inputMasks: generic_utils.pyListRepeat(null, this.inputs.length),\n outputMasks: [null],\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs[0].shape\n });\n } else {\n const outputTensor = layer.apply(this.outputs[0]);\n if (Array.isArray(outputTensor)) {\n throw new TypeError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [outputTensor as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n\n this.layers.push(layer);\n this.built = false;\n }\n\n /**\n * Removes the last layer in the model.\n *\n * @exception TypeError if there are no layers in the model.\n */\n pop(): void {\n if (this.layers.length === 0) {\n throw new TypeError('There are no layers in the model.');\n }\n\n this.layers.pop();\n if (this.layers.length === 0) {\n this.outputs = [];\n this.inboundNodes = [];\n this.outboundNodes = [];\n } else {\n const lastLayerIndex = this.layers.length - 1;\n this.layers[lastLayerIndex].outboundNodes = [];\n this.outputs = [this.layers[lastLayerIndex].output as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.call(inputs, kwargs);\n }\n\n build(inputShape?: Shape|Shape[]) {\n // Call `getExactlyOneShape` without using its return value,\n // to verify that exactly one input shape is provided.\n getExactlyOneShape(inputShape);\n\n if (this.inputs.length === 0 || this.outputs.length === 0) {\n throw new TypeError(\n 'Sequential model cannot be built: model is empty.' +\n ' Add some layers first.');\n }\n // actually create the model\n this.model = new Model({\n inputs: this.inputs,\n outputs: this.outputs[0],\n name: this.name + '_model'\n });\n this.model.trainable = this.trainable;\n this.model.updatable = this.updatable;\n\n // mirror model attributes\n this.supportsMasking = this.model.supportsMasking;\n // TODO(michaelterry): Add caches\n this.inputLayers = this.model.inputLayers;\n this.inputLayersNodeIndices = this.model.inputLayersNodeIndices;\n this.inputLayersTensorIndices = this.model.inputLayersTensorIndices;\n this.outputLayers = this.model.outputLayers;\n this.outputLayersNodeIndices = this.model.outputLayersNodeIndices;\n this.outputLayersTensorIndices = this.model.outputLayersTensorIndices;\n this.nodesByDepth = this.model.nodesByDepth;\n this.containerNodes = this.model.containerNodes;\n this.outputNames = this.model.outputNames;\n this.inputNames = this.model.inputNames;\n // TODO(michaelterry): Add feedInputNames, feedInputs, if needed.\n // TODO(michaelterry): Add callbackModel if needed.\n this.built = true;\n }\n\n countParams(): number {\n if (!this.built) {\n this.build();\n }\n return super.countParams();\n }\n\n /**\n * Print a text summary of the Sequential model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 100, inputShape: [10], activation: 'relu'}));\n * model.add(tf.layers.dense({units: 1, activation: 'sigmoid'}));\n *\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n this.build();\n }\n super.summary(lineLength, positions, printFn);\n }\n\n /**\n * Sets the weights of the model.\n *\n * @param weights Should be a list of Tensors with shapes and types matching\n * the output of `model.getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n if (this.model == null) {\n this.build();\n }\n this.model.setWeights(weights);\n }\n\n get updatable(): boolean {\n return this._updatable;\n }\n\n set updatable(value: boolean) {\n if (this.built) {\n this.model.updatable = value;\n }\n this._updatable = value;\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * });\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model\n * has multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before being used.');\n }\n return this.model.evaluate(x, y, config);\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([2, 10])).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param conifg A `ModelPredictConfig` object containing optional fields.\n *\n * @return `Tensor`(s) of predictions.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predict(x, config);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * @param x: Input samples, as an Tensor, or list of Tensors (if the model\n * has multiple inputs).\n * @return Tensor(s) of predictions\n */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predictOnBatch(x);\n }\n\n /**\n * See `Model.compile`.\n *\n * @param config\n */\n compile(config: ModelCompileConfig): void {\n this.build();\n this.model.compile(config);\n this.optimizer = this.model.optimizer;\n this.loss = this.model.loss;\n this.metrics = this.model.metrics;\n // TODO(cais): Add this.lossWeights, this.sampleWeightMode,\n // this.weightedMetrics, this.targets.\n this.metricsTensors = this.model.metricsTensors;\n this.metricsNames = this.model.metricsNames;\n // TODO(cais): Add sampleWeights.\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const history = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(history.history.loss[0]);\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before ' +\n 'being used.');\n }\n return this.model.fit(x, y, config);\n }\n\n /* See parent class for JsDoc */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const model = new cls({});\n if (!(model instanceof Sequential)) {\n throw new ValueError(\n `Sequential.fromConfig called on non-Sequential input: ${model}`);\n }\n if (!(config instanceof Array)) {\n throw new ValueError(\n `Sequential.fromConfig called without an array of configs`);\n }\n if (!(config[0].className != null) || config[0]['className'] === 'Merge') {\n throw new ValueError('Legacy serialization format not supported yet.');\n }\n for (const conf of config as serialization.ConfigDictArray) {\n const layer = deserialize(conf as serialization.ConfigDict) as Layer;\n model.add(layer);\n }\n return model;\n }\n\n // TODO(cais): Override get trainableWeights() here\n\n // tslint:disable-next-line:no-any\n getConfig(): any {\n // NOTE(cais): We override the return type of getConfig() to `any` here,\n // because the `Sequential` class is a special case among `Container`\n // subtypes in that its getConfig() method returns an Array (not a\n // dict).\n const config: serialization.ConfigDict[] = [];\n for (const layer of this.layers) {\n config.push({\n className: layer.getClassName(),\n config: layer.getConfig(),\n });\n }\n return config;\n }\n}\nserialization.SerializationMap.register(Sequential);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Exported functions.\n */\n\n// tslint:disable:max-line-length\nimport {io} from '@tensorflow/tfjs-core';\n\nimport {ContainerConfig} from './engine/container';\nimport {Input, InputConfig,} from './engine/input_layer';\nimport {SymbolicTensor} from './engine/topology';\nimport {Model} from './engine/training';\nimport {loadModelInternal, Sequential, SequentialConfig} from './models';\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Model and related factory methods.\n\n/**\n * A model is a data structure that consists of `Layers` and defines inputs\n * and outputs.\n *\n * The key difference between `model` and `sequential` is that `model`\n * is more generic, supporting an arbitrary graph (without cycles) of layers.\n * `sequential` is less generic and supports only a linear stack of layers.\n *\n * When creating a `Model`, specify its input(s) and output(s). Layers\n * are used to wire input(s) to output(s).\n *\n * For example, the following code snippet defines a model consisting of\n * two `dense` layers, with 10 and 4 units, respectively.\n *\n * ```js\n * // Define input, which has a size of 5 (not including batch dimension).\n * const input = tf.input({shape: [5]});\n *\n * // First dense layer uses relu activation.\n * const denseLayer1 = tf.layers.dense({units: 10, activation: 'relu'});\n * // Second dense layer uses softmax activation.\n * const denseLayer2 = tf.layers.dense({units: 2, activation: 'softmax'});\n *\n * // Obtain the output symbolic tensor by applying the layers on the input.\n * const output = denseLayer2.apply(denseLayer1.apply(input));\n *\n * // Create the model based on the inputs.\n * const model = tf.model({inputs: input, outputs: output});\n *\n * // The model can be used for training, evaluation and prediction.\n * // For example, the following line runs prediction with the model on\n * // some fake data.\n * model.predict(tf.ones([2, 5])).print();\n * ```\n * See also:\n * `sequential`, `loadModel`.\n */\n\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function model(config: ContainerConfig): Model {\n return new Model(config);\n}\n\n/**\n * Creates a `Sequential` model. A sequential model is any model where the\n * outputs of one layer are the inputs to the next layer, i.e. the model\n * topology is a simple 'stack' of layers, with no branching or skipping.\n *\n * This means that the first layer passed to a Sequential model should have a\n * defined input shape. What that means is that it should have received an\n * `inputShape` or `batchInputShape` argument, or for some type of layers\n * (recurrent, Dense...) an `inputDim` argument.\n *\n * The key difference between `model` and `sequential` is that `sequential`\n * is less generic, supporting only a linear stack of layers. `model` is\n * more generic and supports an arbitrary graph (without cycles) of layers.\n *\n * Examples:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have an input shape defined.\n * model.add(tf.layers.dense({units: 32, inputShape: [50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output, which equals\n * // `[null, 4]`. The 1st dimension is the undetermined batch dimension; the\n * // 2nd is the output size of the model's last layer.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * It is also possible to specify a batch size (with potentially undetermined\n * batch dimension, denoted by \"null\") for the first layer using the\n * `batchInputShape` key. The following example is equivalent to the above:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have a defined input shape\n * model.add(tf.layers.dense({units: 32, batchInputShape: [null, 50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * You can also use an `Array` of already-constructed `Layer`s to create\n * a `Sequential` model:\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 32, inputShape: [50]}),\n * tf.layers.dense({units: 4})]\n * });\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function sequential(config?: SequentialConfig): Sequential {\n return new Sequential(config);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * useDocsFrom: 'loadModelInternal'\n * }\n */\nexport function loadModel(pathOrIOHandler: string|\n io.IOHandler): Promise {\n return loadModelInternal(pathOrIOHandler);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Inputs',\n * useDocsFrom: 'Input',\n * configParamIndices: [0]\n * }\n */\nexport function input(config: InputConfig): SymbolicTensor {\n return Input(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Layer activation functions\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject} from './utils/generic_utils';\n\n/**\n * Base class for Activations.\n *\n * Special note: due to cross-language compatibility reasons, the\n * static readonly className field in this family of classes must be set to\n * the initialLowerCamelCase name of the activation.\n */\nexport abstract class Activation extends serialization.Serializable {\n abstract apply(tensor: Tensor, axis?: number): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/** @docinline */\nexport type ActivationIdentifier = 'elu'|'hardSigmoid'|'linear'|'relu'|'relu6'|\n 'selu'|'sigmoid'|'softmax'|'softplus'|'softsign'|'tanh'|string;\n\n/**\n * Exponential linear unit (ELU).\n * Reference: https://arxiv.org/abs/1511.07289\n */\nexport class Elu extends Activation {\n static readonly className = 'elu';\n /**\n * Calculate the activation function.\n *\n * @param x: Input.\n * @param alpha: Scaling factor the negative section.\n * @return Output of the ELU activation.\n */\n apply(x: Tensor, alpha = 1): Tensor {\n return K.elu(x, alpha);\n }\n}\nserialization.SerializationMap.register(Elu);\n\n/**\n * Scaled Exponential Linear Unit. (Klambauer et al., 2017).\n * Reference: Self-Normalizing Neural Networks, https://arxiv.org/abs/1706.02515\n * Notes:\n * - To be used together with the initialization \"lecunNormal\".\n * - To be used together with the dropout variant \"AlphaDropout\".\n */\nexport class Selu extends Activation {\n static readonly className = 'selu';\n apply(x: Tensor): Tensor {\n return tfc.selu(x);\n }\n}\nserialization.SerializationMap.register(Selu);\n\n/**\n * Rectified linear unit\n */\nexport class Relu extends Activation {\n static readonly className = 'relu';\n apply(x: Tensor): Tensor {\n return tfc.relu(x);\n }\n}\nserialization.SerializationMap.register(Relu);\n\n/**\n * Rectified linear unit activation maxing out at 6.0.\n */\nexport class Relu6 extends Activation {\n static readonly className = 'relu6';\n apply(x: Tensor): Tensor {\n return tidy(() => tfc.minimum(getScalar(6.0), tfc.relu(x)));\n }\n}\nserialization.SerializationMap.register(Relu6);\n\n//* Linear activation (no-op) */\nexport class Linear extends Activation {\n static readonly className = 'linear';\n apply(x: Tensor): Tensor {\n return x;\n }\n}\nserialization.SerializationMap.register(Linear);\n\n/**\n * Sigmoid activation function.\n */\nexport class Sigmoid extends Activation {\n static readonly className = 'sigmoid';\n apply(x: Tensor): Tensor {\n return tfc.sigmoid(x);\n }\n}\nserialization.SerializationMap.register(Sigmoid);\n\n/**\n * Segment-wise linear approximation of sigmoid.\n */\nexport class HardSigmoid extends Activation {\n static readonly className = 'hardSigmoid';\n apply(x: Tensor): Tensor {\n return K.hardSigmoid(x);\n }\n}\nserialization.SerializationMap.register(HardSigmoid);\n\n/**\n * Softplus activation function.\n */\nexport class Softplus extends Activation {\n static readonly className = 'softplus';\n apply(x: Tensor): Tensor {\n return tfc.softplus(x);\n }\n}\nserialization.SerializationMap.register(Softplus);\n\n/**\n * Softsign activation function.\n */\nexport class Softsign extends Activation {\n static readonly className = 'softsign';\n apply(x: Tensor): Tensor {\n return K.softsign(x);\n }\n}\nserialization.SerializationMap.register(Softsign);\n\n/**\n * Hyperbolic tangent function.\n */\nexport class Tanh extends Activation {\n static readonly className = 'tanh';\n apply(x: Tensor): Tensor {\n return tfc.tanh(x);\n }\n}\nserialization.SerializationMap.register(Tanh);\n\n/**\n * Softmax activation function\n */\nexport class Softmax extends Activation {\n static readonly className = 'softmax';\n /**\n * Calculate the activation function.\n *\n * @param x Tensor.\n * @param axis Integer, axis along which the softmax normalization is applied.\n * Invalid if < 2, as softmax across 1 (the batch dimension) is assumed to be\n * an error.\n *\n * @returns a Tensor of the same shape as x\n *\n * @throws ValueError: In case `dim(x) < 2`.\n */\n apply(x: Tensor, axis: number = (-1)): Tensor {\n return tfc.softmax(x, axis);\n }\n}\nserialization.SerializationMap.register(Softmax);\n\nexport function serializeActivation(activation: Activation): string {\n return activation.getClassName();\n}\n\nexport function deserializeActivation(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Activation {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'activation');\n}\n\nexport function getActivation(identifier: ActivationIdentifier|\n serialization.ConfigDict|Activation): Activation {\n if (identifier == null) {\n const config = {className: 'linear', config: {}};\n return deserializeActivation(config);\n }\n if (typeof identifier === 'string') {\n const config = {className: identifier, config: {}};\n return deserializeActivation(config);\n } else if (identifier instanceof Activation) {\n return identifier;\n } else {\n return deserializeActivation(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Advanced activation layers.\n */\n\nimport {elu, leakyRelu, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {Softmax as softmaxActivation} from '../activations';\nimport {cast} from '../backend/tfjs_backend';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneTensor} from '../utils/types_utils';\n\nexport interface LeakyReLULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `0.3`.\n */\n alpha?: number;\n}\n\n/**\n * Leaky version of a rectified linear unit.\n *\n * It allows a small gradient when the unit is not active:\n * `f(x) = alpha * x for x < 0.`\n * `f(x) = x for x >= 0.`\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class LeakyReLU extends Layer {\n static className = 'LeakyReLU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 0.3;\n\n constructor(config?: LeakyReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return leakyRelu(x, this.alpha);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LeakyReLU);\n\n// TODO(cais): Implement PReLU\n\nexport interface ELULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `1.0`.\n */\n alpha?: number;\n}\n\n/**\n * Exponetial Linear Unit (ELU).\n *\n * It follows:\n * `f(x) = alpha * (exp(x) - 1.) for x < 0`,\n * `f(x) = x for x >= 0`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Fast and Accurate Deep Network Learning by Exponential Linear Units\n * (ELUs)](https://arxiv.org/abs/1511.07289v1)\n */\nexport class ELU extends Layer {\n static className = 'ELU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 1.0;\n\n constructor(config?: ELULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n if (config.alpha != null && config.alpha !== this.DEFAULT_ALPHA) {\n throw new NotImplementedError(\n `Non-default alpha value (${config.alpha}) is not supported by the ` +\n `ELU layer yet.`);\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return elu(x);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ELU);\n\nexport interface ThresholdedReLULayerConfig extends LayerConfig {\n /**\n * Float >= 0. Threshold location of activation.\n */\n theta?: number;\n}\n\n/**\n * Thresholded Rectified Linear Unit.\n *\n * It follows:\n * `f(x) = x for x > theta`,\n * `f(x) = 0 otherwise`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Zero-Bias Autoencoders and the Benefits of Co-Adapting\n * Features](http://arxiv.org/abs/1402.3337)\n */\nexport class ThresholdedReLU extends Layer {\n static className = 'ThresholdedReLU';\n readonly theta: number;\n private readonly thetaTensor: Tensor;\n\n readonly DEFAULT_THETA = 1.0;\n\n constructor(config?: ThresholdedReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.theta = config.theta == null ? this.DEFAULT_THETA : config.theta;\n this.thetaTensor = getScalar(this.theta);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return x.mul(cast(x.greater(this.thetaTensor), 'float32'));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {theta: this.theta};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ThresholdedReLU);\n\nexport interface SoftmaxLayerConfig extends LayerConfig {\n /**\n * Integer, axis along which the softmax normalization is applied.\n * Defaults to `-1` (i.e., the last axis).\n */\n axis?: number;\n}\n\n/**\n * Softmax activation layer.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class Softmax extends Layer {\n static className = 'Softmax';\n readonly axis: number;\n readonly softmax: (t: Tensor, a?: number) => Tensor;\n readonly DEFAULT_AXIS = 1.0;\n\n constructor(config?: SoftmaxLayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n this.softmax = new softmaxActivation().apply;\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return this.softmax(x, this.axis);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {axis: this.axis};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Softmax);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* original source: keras/regularizers.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {abs, add, Scalar, serialization, sum, Tensor, tidy, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Regularizer base class.\n */\nexport abstract class Regularizer extends serialization.Serializable {\n abstract apply(x: Tensor): Scalar;\n}\n\nexport interface L1L2Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1?: number;\n /** L2 regularization rate. Defaults to 0.01. */\n l2?: number;\n}\n\nexport interface L1Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1: number;\n}\n\nexport interface L2Config {\n /** L2 regularization rate. Defaults to 0.01. */\n l2: number;\n}\n\n/**\n * Regularizer for L1 and L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x)) + sum(l2 * x^2)\n */\n/** @doc {heading: 'Regularizers', namespace: 'regularizers'} */\nexport class L1L2 extends Regularizer {\n static className = 'L1L2';\n\n private readonly l1: Scalar;\n private readonly l2: Scalar;\n private readonly hasL1: boolean;\n private readonly hasL2: boolean;\n constructor(config?: L1L2Config) {\n super();\n\n const l1 = config == null || config.l1 == null ? 0.01 : config.l1;\n const l2 = config == null || config.l2 == null ? 0.01 : config.l2;\n this.hasL1 = l1 !== 0;\n this.hasL2 = l2 !== 0;\n\n this.l1 = getScalar(l1);\n this.l2 = getScalar(l2);\n }\n\n /**\n * Porting note: Renamed from __call__.\n * @param x Variable of which to calculate the regularization score.\n */\n apply(x: Tensor): Scalar {\n return tidy(() => {\n let regularization: Tensor = zeros([1]);\n if (this.hasL1) {\n regularization = add(regularization, sum(tfc.mul(this.l1, abs(x))));\n }\n if (this.hasL2) {\n regularization =\n add(regularization, sum(tfc.mul(this.l2, K.square(x))));\n }\n return regularization.asScalar();\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {'l1': this.l1.dataSync()[0], 'l2': this.l2.dataSync()[0]};\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n return new cls({l1: config.l1 as number, l2: config.l2 as number});\n }\n}\nserialization.SerializationMap.register(L1L2);\n\n/**\n * Regularizer for L1 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x))\n * @param config l1 config.\n */\nexport function l1(config?: L1Config) {\n return new L1L2({l1: config != null ? config.l1 : null, l2: 0});\n}\n\n/**\n * Regularizer for L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l2 * x^2)\n * @param config l2 config.\n */\nexport function l2(config: L2Config) {\n return new L1L2({l2: config != null ? config.l2 : null, l1: 0});\n}\n\n/** @docinline */\nexport type RegularizerIdentifier = 'l1l2'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding keras symbols.\nexport const REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in RegularizerIdentifier]: string} = {\n 'l1l2': 'L1L2'\n };\n\nexport function serializeRegularizer(constraint: Regularizer):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeRegularizer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Regularizer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'regularizer');\n}\n\nexport function getRegularizer(identifier: RegularizerIdentifier|\n serialization.ConfigDict|\n Regularizer): Regularizer {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeRegularizer(config);\n } else if (identifier instanceof Regularizer) {\n return identifier;\n } else {\n return deserializeRegularizer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {PaddingMode} from '../common';\nimport {ValueError} from '../errors';\n\nimport {pyListRepeat} from './generic_utils';\nimport {isInteger, max} from './math_utils';\n\n/**\n * Transforms a single number of array of numbers into an array of numbers.\n * @param value\n * @param n: The size of the tuple to be returned.\n * @param name: Name of the parameter, used for generating error messages.\n * @returns An array of numbers.\n */\nexport function normalizeArray(\n value: number|number[], n: number, name: string): number[] {\n if (typeof value === 'number') {\n return pyListRepeat(value, n);\n } else {\n if (value.length !== n) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${n} integers. Received: ` +\n `${value.length} elements.`);\n }\n for (let i = 0; i < n; ++i) {\n const singleValue = value[i];\n if (!isInteger(singleValue)) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${\n n} integers. Received: ` +\n `${JSON.stringify(value)} including a non-integer number ` +\n `${singleValue}`);\n }\n }\n return value;\n }\n}\n\n/**\n * Determines output length of a convolution given input length.\n * @param inputLength\n * @param filterSize\n * @param padding\n * @param stride\n * @param dilation: dilation rate.\n */\nexport function convOutputLength(\n inputLength: number, filterSize: number, padding: PaddingMode,\n stride: number, dilation = 1): number {\n if (inputLength == null) {\n return inputLength;\n }\n const dilatedFilterSize = filterSize + (filterSize - 1) * (dilation - 1);\n let outputLength: number;\n if (padding === 'same') {\n outputLength = inputLength;\n } else { // VALID\n outputLength = inputLength - dilatedFilterSize + 1;\n }\n return Math.floor((outputLength + stride - 1) / stride);\n}\n\nexport function deconvLength(\n dimSize: number, strideSize: number, kernelSize: number,\n padding: PaddingMode): number {\n if (dimSize == null) {\n return null;\n }\n\n if (padding === 'valid') {\n dimSize = dimSize * strideSize + max([kernelSize - strideSize, 0]);\n } else if (padding === 'same') {\n dimSize = dimSize * strideSize;\n } else {\n throw new ValueError(`Unsupport padding mode: ${padding}.`);\n }\n return dimSize;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {Activation, getActivation, serializeActivation} from '../activations';\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, DataFormat, PaddingMode} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength, deconvLength, normalizeArray} from '../utils/conv_utils';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n/**\n * Transpose and cast the input before the conv2d.\n * @param x Input image tensor.\n * @param dataFormat\n */\nexport function preprocessConv2DInput(\n x: Tensor, dataFormat: DataFormat): Tensor {\n // TODO(cais): Cast type to float32 if not.\n return tidy(() => {\n checkDataFormat(dataFormat);\n if (dataFormat === 'channelsFirst') {\n return tfc.transpose(x, [0, 2, 3, 1]); // NCHW -> NHWC.\n } else {\n return x;\n }\n });\n}\n\n/**\n * 1D-convolution with bias added.\n *\n * Porting Note: This function does not exist in the Python Keras backend.\n * It is exactly the same as `conv2d`, except the added `bias`.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.\n * @param bias Bias, rank-3, of shape `[outDepth]`.\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n // Check the ranks of x, kernel and bias.\n if (x.shape.length !== 3) {\n throw new ValueError(\n `The input of a conv1dWithBias operation should be 3, but is ` +\n `${x.shape.length} instead.`);\n }\n if (kernel.shape.length !== 3) {\n throw new ValueError(\n `The kernel for a conv1dWithBias operation should be 3, but is ` +\n `${kernel.shape.length} instead`);\n }\n if (bias != null && bias.shape.length !== 1) {\n throw new ValueError(\n `The bias for a conv1dWithBias operation should be 1, but is ` +\n `${kernel.shape.length} instead`);\n }\n // TODO(cais): Support CAUSAL padding mode.\n if (dataFormat === 'channelsFirst') {\n x = tfc.transpose(x, [0, 2, 1]); // NCW -> NWC.\n }\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n let y: Tensor = tfc.conv1d(\n x as Tensor2D | Tensor3D, kernel as Tensor3D, strides,\n padding === 'same' ? 'same' : 'valid', 'NWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias);\n }\n return y;\n });\n}\n\n/**\n * 1D-convolution.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.s\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1d(\n x: Tensor, kernel: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv1dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution\n * @param x\n * @param kernel kernel of the convolution.\n * @param strides strides array.\n * @param padding padding mode. Default to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param dilationRate dilation rate array.\n * @returns Result of the 2D pooling.\n */\nexport function conv2d(\n x: Tensor, kernel: Tensor, strides = [1, 1], padding = 'valid',\n dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv2dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution with an added bias.\n * Note: This function does not exist in the Python Keras Backend. This function\n * is exactly the same as `conv2d`, except the added `bias`.\n */\nexport function conv2dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n if (x.rank !== 3 && x.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects input to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n if (kernel.rank !== 3 && kernel.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects kernel to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n let y = preprocessConv2DInput(x, dataFormat);\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n y = tfc.conv2d(\n y as Tensor3D | Tensor4D, kernel as Tensor4D,\n strides as [number, number], padding === 'same' ? 'same' : 'valid',\n 'NHWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias as Tensor1D);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\n\n/**\n * Base LayerConfig for depthwise and non-depthwise convolutional layers.\n */\nexport interface BaseConvLayerConfig extends LayerConfig {\n /**\n * The dimensions of the convolution window. If kernelSize is a number, the\n * convolutional window will be square.\n */\n kernelSize: number|number[];\n\n /**\n * The strides of the convolution in each dimension. If strides is a number,\n * strides in both dimensions are equal.\n *\n * Specifying any stride value != 1 is incompatible with specifying any\n * `dilationRate` value != 1.\n */\n strides?: number|number[];\n\n /**\n * Padding mode.\n */\n padding?: PaddingMode;\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n\n /**\n * The dilation rate to use for the dilated convolution in each dimension.\n * Should be an integer or array of two integers.\n *\n * Currently, specifying any `dilationRate` value != 1 is incompatible with\n * specifying any `strides` value != 1.\n */\n dilationRate?: number|[number]|[number, number];\n\n /**\n * Activation function of the layer.\n *\n * If you don't specify the activation, none is applied.\n */\n activation?: string;\n\n /**\n * Whether the layer uses a bias vector. Defaults to `true`.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the convolutional kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the convolutional kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * LayerConfig for non-depthwise convolutional layers.\n * Applies to non-depthwise convolution of all ranks (e.g, Conv1D, Conv2D).\n */\nexport interface ConvLayerConfig extends BaseConvLayerConfig {\n /**\n * The dimensionality of the output space (i.e. the number of filters in the\n * convolution).\n */\n filters: number;\n}\n\n/**\n * Abstract convolution layer.\n */\nexport abstract class BaseConv extends Layer {\n protected readonly rank: number;\n protected readonly kernelSize: number[];\n protected readonly strides: number[];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n protected readonly activation: Activation;\n protected readonly useBias: boolean;\n protected readonly dilationRate: number[];\n\n // Bias-related members are here because all convolution subclasses use the\n // same configuration parmeters to control bias. Kernel-related members\n // are in subclass `Conv` because some subclasses use different parameters to\n // control kernel properties, for instance, `DepthwiseConv2D` uses\n // `depthwiseInitializer` instead of `kernelInitializer`.\n protected readonly biasInitializer?: Initializer;\n protected readonly biasConstraint?: Constraint;\n protected readonly biasRegularizer?: Regularizer;\n\n protected bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(rank: number, config: BaseConvLayerConfig) {\n super(config as LayerConfig);\n BaseConv.verifyConfig(config);\n this.rank = rank;\n if (this.rank !== 1 && this.rank !== 2) {\n throw new NotImplementedError(\n `Convolution layer for rank other than 1 or 2 (${this.rank}) is ` +\n `not implemented yet.`);\n }\n this.kernelSize = normalizeArray(config.kernelSize, rank, 'kernelSize');\n this.strides = normalizeArray(\n config.strides == null ? 1 : config.strides, rank, 'strides');\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.activation = getActivation(config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.dilationRate = normalizeArray(\n config.dilationRate == null ? 1 : config.dilationRate, rank,\n 'dilationRate');\n if (this.rank === 1 &&\n (Array.isArray(this.dilationRate) &&\n (this.dilationRate as number[]).length !== 1)) {\n throw new ValueError(\n `dilationRate must be a number or an array of a single number ` +\n `for 1D convolution, but received ` +\n `${JSON.stringify(this.dilationRate)}`);\n }\n if (this.rank === 2) {\n if (typeof this.dilationRate === 'number') {\n this.dilationRate = [this.dilationRate, this.dilationRate];\n } else if (this.dilationRate.length !== 2) {\n throw new ValueError(\n `dilationRate must be a number or array of two numbers for 2D ` +\n `convolution, but received ${JSON.stringify(this.dilationRate)}`);\n }\n }\n }\n\n protected static verifyConfig(config: BaseConvLayerConfig) {\n // Check config.kernelSize type and shape.\n generic_utils.assert(\n 'kernelSize' in config, `required key 'kernelSize' not in config`);\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `BaseConv expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n kernelSize: this.kernelSize,\n strides: this.strides,\n padding: this.padding,\n dataFormat: this.dataFormat,\n dilationRate: this.dilationRate,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n biasInitializer: serializeInitializer(this.biasInitializer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Abstract nD convolution layer. Ancestor of convolution layers which reduce\n * across channels, i.e., Conv1D and Conv2D, but not DepthwiseConv2D.\n */\nexport abstract class Conv extends BaseConv {\n protected readonly filters: number;\n\n protected kernel: LayerVariable = null;\n\n // Bias-related properties are stored in the superclass `BaseConv` because all\n // convolution subclasses use the same configuration parameters to control\n // bias. Kernel-related properties are defined here rather than in the\n // superclass because some convolution subclasses use different names and\n // configuration parameters for their internal kernel state.\n protected readonly kernelInitializer?: Initializer;\n protected readonly kernelConstraint?: Constraint;\n protected readonly kernelRegularizer?: Regularizer;\n\n constructor(rank: number, config: ConvLayerConfig) {\n super(rank, config as BaseConvLayerConfig);\n Conv.verifyConfig(config);\n this.filters = config.filters;\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n `The channel dimension of the input should be defined. ` +\n `Found ${inputShape[channelAxis]}`);\n }\n const inputDim = inputShape[channelAxis];\n\n const kernelShape = this.kernelSize.concat([inputDim, this.filters]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n this.inputSpec = [{ndim: this.rank + 2, axes: {[channelAxis]: inputDim}}];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs: Tensor;\n const biasValue = this.bias == null ? null : this.bias.read();\n\n if (this.rank === 1) {\n outputs = conv1dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides[0],\n this.padding, this.dataFormat, this.dilationRate[0]);\n } else if (this.rank === 2) {\n // TODO(cais): Move up to constructor.\n outputs = conv2dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides, this.padding,\n this.dataFormat, this.dilationRate as [number, number]);\n } else if (this.rank === 3) {\n throw new NotImplementedError('3D convolution is not implemented yet.');\n }\n\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const newSpace: number[] = [];\n const space = (this.dataFormat === 'channelsLast') ?\n inputShape.slice(1, inputShape.length - 1) :\n inputShape.slice(2);\n for (let i = 0; i < space.length; ++i) {\n const newDim = convOutputLength(\n space[i], this.kernelSize[i], this.padding, this.strides[i],\n typeof this.dilationRate === 'number' ? this.dilationRate :\n this.dilationRate[i]);\n newSpace.push(newDim);\n }\n\n let outputShape = [inputShape[0]];\n if (this.dataFormat === 'channelsLast') {\n outputShape = outputShape.concat(newSpace);\n outputShape.push(this.filters);\n } else {\n outputShape.push(this.filters);\n outputShape = outputShape.concat(newSpace);\n }\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n filters: this.filters,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // Check config.filters type, shape, and value.\n if (!('filters' in config) || typeof config.filters !== 'number' ||\n config.filters < 1) {\n throw new ValueError(\n `Convolution layer expected config.filters to be a 'number' > 0 ` +\n `but got ${JSON.stringify(config.filters)}`);\n }\n }\n}\n\n\n/**\n * 2D convolution layer (e.g. spatial convolution over images).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input to produce a tensor of outputs.\n *\n * If `useBias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model,\n * provide the keyword argument `inputShape`\n * (Array of integers, does not include the sample axis),\n * e.g. `inputShape=[128, 128, 3]` for 128x128 RGB pictures\n * in `dataFormat='channelsLast'`.\n */\nexport class Conv2D extends Conv {\n static className = 'Conv2D';\n constructor(config: ConvLayerConfig) {\n super(2, config);\n Conv2D.verifyConfig(config);\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if ((typeof config.kernelSize !== 'number') &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `Conv2D expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv2D);\n\n/**\n * Transposed convolutional layer (sometimes called Deconvolution).\n *\n * The need for transposed convolutions generally arises\n * from the desire to use a transformation going in the opposite direction of\n * a normal convolution, i.e., from something that has the shape of the output\n * of some convolution to something that has the shape of its input while\n * maintaining a connectivity pattern that is compatible with said\n * convolution.\n *\n * When using this layer as the first layer in a model, provide the\n * configuration `inputShape` (`Array` of integers, does not include the\n * sample axis), e.g., `inputShape: [128, 128, 3]` for 128x128 RGB pictures in\n * `dataFormat: 'channelsLast'`.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if `dataFormat` is `'channelsFirst'`.\n * or 4D tensor with shape\n * `[batch, rows, cols, channels]` if `dataFormat` is `'channelsLast`.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if `dataFormat` is\n * `'channelsFirst'`. or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if `dataFormat` is `'channelsLast'`.\n *\n * References:\n * - [A guide to convolution arithmetic for deep\n * learning](https://arxiv.org/abs/1603.07285v1)\n * - [Deconvolutional\n * Networks](http://www.matthewzeiler.com/pubs/cvpr2010/cvpr2010.pdf)\n */\nexport class Conv2DTranspose extends Conv2D {\n static className = 'Conv2DTranspose';\n inputSpec: InputSpec[];\n\n constructor(config: ConvLayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 4})];\n\n if (this.padding !== 'same' && this.padding !== 'valid') {\n throw new ValueError(\n `Conv2DTranspose currently supports only padding modes 'same' ` +\n `and 'valid', but received padding mode ${this.padding}`);\n }\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n\n if (inputShape.length !== 4) {\n throw new ValueError(\n 'Input should have rank 4; Received input shape: ' +\n JSON.stringify(inputShape));\n }\n\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n 'The channel dimension of the inputs should be defined. ' +\n 'Found `None`.');\n }\n const inputDim = inputShape[channelAxis];\n const kernelShape = this.kernelSize.concat([this.filters, inputDim]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, 'float32', this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n // Set input spec.\n this.inputSpec =\n [new InputSpec({ndim: 4, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs);\n if (input.shape.length !== 4) {\n throw new ValueError(\n `Conv2DTranspose.call() expects input tensor to be rank-4, but ` +\n `received a tensor of rank-${input.shape.length}`);\n }\n\n const inputShape = input.shape;\n const batchSize = inputShape[0];\n\n let hAxis: number;\n let wAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n hAxis = 2;\n wAxis = 3;\n } else {\n hAxis = 1;\n wAxis = 2;\n }\n\n const height = inputShape[hAxis];\n const width = inputShape[wAxis];\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n // Infer the dynamic output shape.\n const outHeight = deconvLength(height, strideH, kernelH, this.padding);\n const outWidth = deconvLength(width, strideW, kernelW, this.padding);\n\n // Porting Note: We don't branch based on `this.dataFormat` here,\n // because\n // the tjfs-core function `conv2dTranspose` called below always\n // assumes channelsLast.\n const outputShape: [number, number, number, number] =\n [batchSize, outHeight, outWidth, this.filters];\n\n if (this.dataFormat !== 'channelsLast') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n }\n let outputs = tfc.conv2dTranspose(\n input as Tensor4D, this.kernel.read() as Tensor4D, outputShape,\n this.strides as [number, number], this.padding as 'same' | 'valid');\n if (this.dataFormat !== 'channelsLast') {\n outputs = tfc.transpose(outputs, [0, 3, 1, 2]) as Tensor4D;\n }\n\n if (this.bias != null) {\n outputs =\n K.biasAdd(outputs, this.bias.read(), this.dataFormat) as Tensor4D;\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs) as Tensor4D;\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n\n let channelAxis: number;\n let heightAxis: number;\n let widthAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n channelAxis = 1;\n heightAxis = 2;\n widthAxis = 3;\n } else {\n channelAxis = 3;\n heightAxis = 1;\n widthAxis = 2;\n }\n\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n outputShape[channelAxis] = this.filters;\n outputShape[heightAxis] =\n deconvLength(outputShape[heightAxis], strideH, kernelH, this.padding);\n outputShape[widthAxis] =\n deconvLength(outputShape[widthAxis], strideW, kernelW, this.padding);\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['dilationRate'];\n return config;\n }\n}\nserialization.SerializationMap.register(Conv2DTranspose);\n\n\nexport interface SeparableConvLayerConfig extends ConvLayerConfig {\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal\n * to `filtersIn * depthMultiplier`. Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the pointwise kernel matrix.\n */\n pointwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the pointwise kernel matrix.\n */\n pointwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the pointwise kernel matrix.\n */\n pointwiseConstraint?: ConstraintIdentifier|Constraint;\n}\n\n\nexport class SeparableConv extends Conv {\n static className = 'SeparableConv';\n\n readonly depthMultiplier: number;\n\n protected readonly depthwiseInitializer?: Initializer;\n protected readonly depthwiseRegularizer?: Regularizer;\n protected readonly depthwiseConstraint?: Constraint;\n protected readonly pointwiseInitializer?: Initializer;\n protected readonly pointwiseRegularizer?: Regularizer;\n protected readonly pointwiseConstraint?: Constraint;\n\n readonly DEFAULT_DEPTHWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n readonly DEFAULT_POINTWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n\n protected depthwiseKernel: LayerVariable = null;\n protected pointwiseKernel: LayerVariable = null;\n\n constructor(rank: number, config?: SeparableConvLayerConfig) {\n super(rank, config);\n\n if (config.filters == null) {\n throw new ValueError(\n 'The `filters` configuration field is required by SeparableConv, ' +\n 'but is unspecified.');\n }\n if (config.kernelInitializer != null || config.kernelRegularizer != null ||\n config.kernelConstraint != null) {\n throw new ValueError(\n 'Fields kernelInitializer, kernelRegularizer and kernelConstraint ' +\n 'are invalid for SeparableConv2D. Use depthwiseInitializer, ' +\n 'depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, ' +\n 'pointwiseRegularizer and pointwiseConstraint instead.');\n }\n if (config.padding != null && config.padding !== 'same' &&\n config.padding !== 'valid') {\n throw new ValueError(\n `SeparableConv${this.rank}D supports only padding modes: ` +\n `'same' and 'valid', but received ${JSON.stringify(config.padding)}`);\n }\n\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_DEPTHWISE_INITIALIZER);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.pointwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_POINTWISE_INITIALIZER);\n this.pointwiseRegularizer = getRegularizer(config.pointwiseRegularizer);\n this.pointwiseConstraint = getConstraint(config.pointwiseConstraint);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < this.rank + 2) {\n throw new ValueError(\n `Inputs to SeparableConv${this.rank}D should have rank ` +\n `${this.rank + 2}, but received input shape: ` +\n `${JSON.stringify(inputShape)}`);\n }\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n `The channel dimension of the inputs should be defined, ` +\n `but found ${JSON.stringify(inputShape[channelAxis])}`);\n }\n\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape =\n this.kernelSize.concat([inputDim, this.depthMultiplier]);\n const pointwiseKernelShape = [];\n for (let i = 0; i < this.rank; ++i) {\n pointwiseKernelShape.push(1);\n }\n pointwiseKernelShape.push(inputDim * this.depthMultiplier, this.filters);\n\n const trainable = true;\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, 'float32',\n this.depthwiseInitializer, this.depthwiseRegularizer, trainable,\n this.depthwiseConstraint);\n this.pointwiseKernel = this.addWeight(\n 'pointwise_kernel', pointwiseKernelShape, 'float32',\n this.pointwiseInitializer, this.pointwiseRegularizer, trainable,\n this.pointwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, trainable, this.biasConstraint);\n } else {\n this.bias = null;\n }\n\n this.inputSpec =\n [new InputSpec({ndim: this.rank + 2, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n let output: Tensor;\n if (this.rank === 1) {\n throw new NotImplementedError(\n '1D separable convolution is not implemented yet.');\n } else if (this.rank === 2) {\n if (this.dataFormat === 'channelsFirst') {\n inputs = tfc.transpose(inputs, [0, 2, 3, 1]); // NCHW -> NHWC.\n }\n\n output = tfc.separableConv2d(\n inputs as Tensor4D, this.depthwiseKernel.read() as Tensor4D,\n this.pointwiseKernel.read() as Tensor4D,\n this.strides as [number, number], this.padding as 'same' | 'valid',\n this.dilationRate as [number, number], 'NHWC');\n }\n\n if (this.useBias) {\n output = K.biasAdd(output, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n if (this.dataFormat === 'channelsFirst') {\n output = tfc.transpose(output, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['kernelInitializer'];\n delete config['kernelRegularizer'];\n delete config['kernelConstraint'];\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['pointwiseInitializer'] =\n serializeInitializer(this.pointwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['pointwiseRegularizer'] =\n serializeRegularizer(this.pointwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseConstraint);\n config['pointwiseConstraint'] =\n serializeConstraint(this.pointwiseConstraint);\n return config;\n }\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Separable convolution consists of first performing\n * a depthwise spatial convolution\n * (which acts on each input channel separately)\n * followed by a pointwise convolution which mixes together the resulting\n * output channels. The `depthMultiplier` argument controls how many\n * output channels are generated per input channel in the depthwise step.\n *\n * Intuitively, separable convolutions can be understood as\n * a way to factorize a convolution kernel into two smaller kernels,\n * or as an extreme version of an Inception block.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, rows, cols, channels]` if data_format='channelsLast'.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if data_format='channelsLast'.\n * `rows` and `cols` values might have changed due to padding.\n */\nexport class SeparableConv2D extends SeparableConv {\n static className = 'SeparableConv2D';\n constructor(config?: SeparableConvLayerConfig) {\n super(2, config);\n }\n}\nserialization.SerializationMap.register(SeparableConv2D);\n\n/**\n * 1D convolution layer (e.g., temporal convolution).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input over a single spatial (or temporal) dimension\n * to produce a tensor of outputs.\n *\n * If `use_bias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model, provide an\n * `inputShape` argument `Array` or `null`.\n *\n * For example, `inputShape` would be:\n * - `[10, 128]` for sequences of 10 vectors of 128-dimensional vectors\n * - `[null, 128]` for variable-length sequences of 128-dimensional vectors.\n */\nexport class Conv1D extends Conv {\n static className = 'Conv1D';\n constructor(config: ConvLayerConfig) {\n super(1, config);\n Conv1D.verifyConfig(config);\n this.inputSpec = [{ndim: 3}];\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['dataFormat'];\n return config;\n }\n\n static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 1))\n throw new ValueError(\n `Conv1D expects config.kernelSize to be number or number[] with ` +\n `length 1, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv1D);\n\nexport interface Cropping2DLayerConfig extends LayerConfig {\n /**\n * Dimension of the cropping along the width and the height.\n * - If integer: the same symmetric cropping\n * is applied to width and height.\n * - If list of 2 integers:\n * interpreted as two different\n * symmetric cropping values for height and width:\n * `[symmetric_height_crop, symmetric_width_crop]`.\n * - If a list of 2 list of 2 integers:\n * interpreted as\n * `[[top_crop, bottom_crop], [left_crop, right_crop]]`\n */\n cropping: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Cropping layer for 2D input (e.g., image).\n *\n * This layer can crop an input\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, croppedRows, croppedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, croppedRows, croppedCols]`.\n *\n * Examples\n * ```js\n *\n * const model = tf.sequential();\n * model.add(tf.layers.cropping2D({cropping:[[2, 2], [2, 2]],\n * inputShape: [128, 128, 3]}));\n * //now output shape is [batch, 124, 124, 3]\n * ```\n */\nexport class Cropping2D extends Layer {\n static className = 'Cropping2D';\n protected readonly cropping: [[number, number], [number, number]];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Cropping2DLayerConfig) {\n super(config);\n if (typeof config.cropping === 'number')\n this.cropping = [\n [config.cropping, config.cropping], [config.cropping, config.cropping]\n ];\n else if (typeof config.cropping[0] === 'number')\n this.cropping = [\n [config.cropping[0] as number, config.cropping[0] as number],\n [config.cropping[1] as number, config.cropping[1] as number]\n ];\n else\n this.cropping = config.cropping as [[number, number], [number, number]];\n this.dataFormat =\n config.dataFormat === undefined ? 'channelsLast' : config.dataFormat;\n this.inputSpec = [{ndim: 4}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst')\n return [\n inputShape[0], inputShape[1],\n inputShape[2] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1]\n ];\n else\n return [\n inputShape[0],\n inputShape[1] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1], inputShape[3]\n ];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n if (this.dataFormat === 'channelsLast') {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[1] - this.cropping[0][0] - this.cropping[0][1], 2);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[2] - this.cropping[1][1] - this.cropping[1][0], 3);\n } else {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[2] - this.cropping[0][0] - this.cropping[0][1], 3);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[3] - this.cropping[1][1] - this.cropping[1][0], 4);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {cropping: this.cropping, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Cropping2D);\n\nexport interface UpSampling2DLayerConfig extends LayerConfig {\n /**\n * The upsampling factors for rows and columns.\n *\n * Defaults to `[2, 2]`.\n */\n size?: number[];\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `\"channelsLast\"` corresponds to inputs with shape\n * `[batch, ..., channels]`\n *\n * `\"channelsFirst\"` corresponds to inputs with shape `[batch, channels,\n * ...]`.\n *\n * Defaults to `\"channelsLast\"`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Upsampling layer for 2D inputs.\n *\n * Repeats the rows and columns of the data\n * by size[0] and size[1] respectively.\n *\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, rows, cols]`\n *\n * Output shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, upsampledRows, upsampledCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, upsampledRows, upsampledCols]`\n *\n */\nexport class UpSampling2D extends Layer {\n static className = 'UpSampling2D';\n protected readonly DEFAULT_SIZE = [2, 2];\n protected readonly size: number[];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: UpSampling2DLayerConfig) {\n super(config);\n this.inputSpec = [{ndim: 4}];\n this.size = config.size == null ? this.DEFAULT_SIZE : config.size;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst') {\n const height =\n inputShape[2] == null ? null : this.size[0] * inputShape[2];\n const width = inputShape[3] == null ? null : this.size[1] * inputShape[3];\n return [inputShape[0], inputShape[1], height, width];\n } else {\n const height =\n inputShape[1] == null ? null : this.size[0] * inputShape[1];\n const width = inputShape[2] == null ? null : this.size[1] * inputShape[2];\n return [inputShape[0], height, width, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs) as Tensor4D;\n const inputShape = input.shape;\n\n if (this.dataFormat === 'channelsFirst') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n const height = this.size[0] * inputShape[2];\n const width = this.size[1] * inputShape[3];\n const resized = input.resizeNearestNeighbor([height, width]);\n return tfc.transpose(resized, [0, 3, 1, 2]);\n } else {\n const height = this.size[0] * inputShape[1];\n const width = this.size[1] * inputShape[2];\n return input.resizeNearestNeighbor([height, width]);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {size: this.size, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(UpSampling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Depthwise Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {BaseConv, BaseConvLayerConfig, ConvLayerConfig, preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D convolution with separable filters.\n * @param x Input tensor.\n * @param depthwiseKernel Convolution kernel for depthwise convolution.\n * @param strides Strides (Array of two integers).\n * @param padding Padding model.\n * @param dataFormat Data format.\n * @param dilationRate Array of two integers, dilation rates for the separable\n * convolution.\n * @returns Output tensor.\n * @throws ValueError If depthwiseKernel is not a 4D array.\n */\nexport function depthwiseConv2d(\n x: Tensor, depthwiseKernel: Tensor, strides: [number, number] = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n let y = preprocessConv2DInput(x, dataFormat);\n if (x.rank !== 4) {\n throw new ValueError(\n `Input for depthwiseConv2d is required to be 4-D, but is instead ` +\n `${x.rank}-D`);\n }\n if (depthwiseKernel.rank !== 4) {\n throw new ValueError(\n `depthwiseKernel is required to be 4-D, but is instead ` +\n `${depthwiseKernel.rank}-D`);\n }\n y = tfc.depthwiseConv2d(\n y as Tensor4D, depthwiseKernel as Tensor4D, strides,\n padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate);\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\nexport interface DepthwiseConv2DLayerConfig extends BaseConvLayerConfig {\n /**\n * An integer or Array of 2 integers, specifying the width and height of the\n * 2D convolution window. Can be a single integer to specify the same value\n * for all spatial dimensions.\n */\n kernelSize: number|[number, number];\n\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal to\n * `filtersIn * depthMultiplier`.\n * Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n * Default: GlorotNormal.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regulzarizer function for the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Depthwise Separable convolutions consists in performing just the first step\n * in a depthwise spatial convolution (which acts on each input channel\n * separately). The `depthMultplier` argument controls how many output channels\n * are generated per input channel in the depthwise step.\n */\nexport class DepthwiseConv2D extends BaseConv {\n static className = 'DepthwiseConv2D';\n private readonly depthMultiplier: number;\n private readonly depthwiseInitializer: Initializer;\n private readonly depthwiseConstraint: Constraint;\n private readonly depthwiseRegularizer: Regularizer;\n\n private depthwiseKernel: LayerVariable = null;\n\n constructor(config: DepthwiseConv2DLayerConfig) {\n super(2, config as ConvLayerConfig);\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 4) {\n throw new ValueError(\n `Inputs to DepthwiseConv2D should have rank 4. ` +\n `Received input shape: ${JSON.stringify(inputShape)}.`);\n }\n const channelAxis = this.dataFormat === 'channelsFirst' ? 1 : 3;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n 'The channel dimension of the inputs to DepthwiseConv2D should ' +\n `be defined, but is not (${inputShape[channelAxis]}).`);\n }\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape: Shape = [\n this.kernelSize[0], this.kernelSize[1], inputDim, this.depthMultiplier\n ];\n\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, null,\n this.depthwiseInitializer, this.depthwiseRegularizer, true,\n this.depthwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [inputDim * this.depthMultiplier], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs = depthwiseConv2d(\n inputs, this.depthwiseKernel.read(), this.strides as [number, number],\n this.padding, this.dataFormat, null);\n // TODO(cais): Add support for dilation.\n if (this.useBias) {\n outputs = K.biasAdd(outputs, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n const cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n const outFilters = this.dataFormat === 'channelsFirst' ?\n inputShape[1] * this.depthMultiplier :\n inputShape[3] * this.depthMultiplier;\n const outRows = convOutputLength(\n rows, this.kernelSize[0], this.padding, this.strides[0]);\n const outCols = convOutputLength(\n cols, this.kernelSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], outFilters, outRows, outCols];\n } else {\n // In this case, assume 'channelsLast'.\n return [inputShape[0], outRows, outCols, outFilters];\n }\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n config['depthMultiplier'] = this.depthMultiplier;\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseRegularizer);\n return config;\n }\n}\nserialization.SerializationMap.register(DepthwiseConv2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Basic Layers.\n */\n\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport {Activation as ActivationFn, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface DropoutLayerConfig extends LayerConfig {\n /** Float between 0 and 1. Fraction of the input units to drop. */\n rate: number;\n\n /**\n * Integer array representing the shape of the binary dropout mask that will\n * be multiplied with the input.\n *\n * For instance, if your inputs have shape `(batchSize, timesteps, features)`\n * and you want the dropout mask to be the same for all timesteps, you can use\n * `noise_shape=(batch_size, 1, features)`.\n */\n noiseShape?: number[];\n\n /** An integer to use as random seed. */\n seed?: number;\n}\n\n/**\n * Applies\n * [dropout](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf) to\n * the input.\n *\n * Dropout consists in randomly setting a fraction `rate` of input units to 0 at\n * each update during training time, which helps prevent overfitting.\n */\nexport class Dropout extends Layer {\n static className = 'Dropout';\n private readonly rate: number;\n private readonly rateScalar: Scalar;\n private readonly noiseShape: number[];\n private readonly seed: number;\n\n constructor(config: DropoutLayerConfig) {\n super(config);\n this.rate = Math.max(Math.min(config.rate, 1), 0);\n this.rateScalar = getScalar(this.rate);\n // So that the scalar doesn't get tidied up between executions.\n this.noiseShape = config.noiseShape;\n this.seed = config.seed;\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Non-default seed is not implemented in Dropout layer yet: ' +\n this.seed);\n }\n this.supportsMasking = true;\n }\n\n private getNoiseShape(input: Tensor): Shape {\n if (this.noiseShape == null) {\n return this.noiseShape;\n }\n const inputShape = input.shape;\n const noiseShape: Shape = [];\n for (let i = 0; i < this.noiseShape.length; ++i) {\n noiseShape.push(\n this.noiseShape[i] == null ? inputShape[i] : this.noiseShape[i]);\n }\n return noiseShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n if (this.noiseShape != null &&\n !util.arraysEqual(input.shape, this.noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented in Dropout ' +\n 'layer yet: ' + JSON.stringify(this.noiseShape));\n }\n if (0 < this.rate && this.rate < 1) {\n const training =\n kwargs['training'] == null ? false : kwargs['training'];\n const noiseShape = this.getNoiseShape(input);\n const output =\n K.inTrainPhase(\n () => K.dropout(input, this.rateScalar, noiseShape, this.seed),\n () => input, training) as Tensor;\n return output;\n }\n return inputs;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n rate: this.rate,\n noiseShape: this.noiseShape,\n seed: this.seed,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dropout);\n\nexport interface DenseLayerConfig extends LayerConfig {\n /** Positive integer, dimensionality of the output space. */\n units: number;\n /**\n * Activation function to use.\n *\n * If unspecified, no activation is applied.\n */\n activation?: ActivationIdentifier;\n /** Whether to apply a bias. */\n useBias?: boolean;\n /**\n * Initializer for the dense kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n /**\n * If specified, defines inputShape as `[inputDim]`.\n */\n inputDim?: number;\n\n /**\n * Constraint for the kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the dense kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Creates a dense (fully connected) layer.\n *\n * This layer implements the operation:\n * `output = activation(dot(input, kernel) + bias)`\n *\n * `activation` is the element-wise activation function\n * passed as the `activation` argument.\n *\n * `kernel` is a weights matrix created by the layer.\n *\n * `bias` is a bias vector created by the layer (only applicable if `useBias`\n * is `true`).\n *\n * **Input shape:**\n *\n * nD `Tensor` with shape: `(batchSize, ..., inputDim)`.\n *\n * The most common situation would be\n * a 2D input with shape `(batchSize, inputDim)`.\n *\n * **Output shape:**\n *\n * nD tensor with shape: `(batchSize, ..., units)`.\n *\n * For instance, for a 2D input with shape `(batchSize, inputDim)`,\n * the output would have shape `(batchSize, units)`.\n *\n * Note: if the input to the layer has a rank greater than 2, then it is\n * flattened prior to the initial dot product with the kernel.\n */\nexport class Dense extends Layer {\n static className = 'Dense';\n private units: number;\n // Default activation: Linear (none).\n private activation: ActivationFn = null;\n private useBias = true;\n private kernelInitializer: Initializer;\n private biasInitializer: Initializer;\n private kernel: LayerVariable = null;\n private bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n private readonly kernelConstraint?: Constraint;\n private readonly biasConstraint?: Constraint;\n private readonly kernelRegularizer?: Regularizer;\n private readonly biasRegularizer?: Regularizer;\n\n constructor(config: DenseLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null &&\n config.inputDim != null) {\n // This logic is copied from Layer's constructor, since we can't\n // do exactly what the Python constructor does for Dense().\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n this.batchInputShape = [batchSize, config.inputDim];\n }\n\n this.units = config.units;\n this.activation = getActivation(config.activation);\n if (config.useBias != null) {\n this.useBias = config.useBias;\n }\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n\n this.inputSpec = [{minNDim: 2}];\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputLastDim = inputShape[inputShape.length - 1];\n if (this.kernel == null) {\n this.kernel = this.addWeight(\n 'kernel', [inputLastDim, this.units], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n }\n\n this.inputSpec = [{minNDim: 2, axes: {[-1]: inputLastDim}}];\n this.built = true;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n outputShape[outputShape.length - 1] = this.units;\n return outputShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Dense layer accepts only a single input.\n const input = getExactlyOneTensor(inputs);\n let output = K.dot(input, this.kernel.read());\n if (this.bias != null) {\n output = K.biasAdd(output, this.bias.read());\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dense);\n\n/**\n * Flattens the input. Does not affect the batch size.\n *\n * A `Flatten` layer flattens each batch in its inputs to 1D (making the output\n * 2D).\n *\n * For example:\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const flattenLayer = tf.layers.flatten();\n * // Inspect the inferred output shape of the flatten layer, which\n * // equals `[null, 12]`. The 2nd dimension is 4 * 3, i.e., the result of the\n * // flattening. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(flattenLayer.apply(input).shape));\n * ```\n */\nexport class Flatten extends Layer {\n static className = 'Flatten';\n constructor(config?: LayerConfig) {\n super(config || {});\n this.inputSpec = [{minNDim: 3}];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n for (const dim of inputShape.slice(1)) {\n if (dim == null) {\n throw new ValueError(\n `The shape of the input to \"Flatten\" is not fully defined ` +\n `(got ${inputShape.slice(1)}). Make sure to pass a complete ` +\n `\"input_shape\" or \"batch_input_shape\" argument to the first ` +\n `layer in your model.`);\n }\n }\n return [inputShape[0], math_utils.arrayProd(inputShape, 1)];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return K.batchFlatten(getExactlyOneTensor(inputs));\n });\n }\n}\nserialization.SerializationMap.register(Flatten);\n\nexport interface ActivationLayerConfig extends LayerConfig {\n /**\n * Name of the activation function to use.\n */\n activation: ActivationIdentifier;\n}\n\n/**\n * Applies an activation function to an output.\n *\n * This layer applies element-wise activation function. Other layers, notably\n * `dense` can also apply activation functions. Use this isolated activation\n * function to extract the values before and after the\n * activation. For instance:\n *\n * ```js\n * const input = tf.input({shape: [5]});\n * const denseLayer = tf.layers.dense({units: 1});\n * const activationLayer = tf.layers.activation({activation: 'relu6'});\n *\n * // Obtain the output symbolic tensors by applying the layers in order.\n * const denseOutput = denseLayer.apply(input);\n * const activationOutput = activationLayer.apply(denseOutput);\n *\n * // Create the model based on the inputs.\n * const model = tf.model({\n * inputs: input,\n * outputs: [denseOutput, activationOutput]\n * });\n *\n * // Collect both outputs and print separately.\n * const [denseOut, activationOut] = model.predict(tf.randomNormal([6, 5]));\n * denseOut.print();\n * activationOut.print();\n * ```\n *\n */\nexport class Activation extends Layer {\n static className = 'Activation';\n activation: ActivationFn;\n\n constructor(config: ActivationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.activation = getActivation(config.activation);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n return this.activation.apply(input);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {activation: serializeActivation(this.activation)};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Activation);\n\nexport interface ReshapeLayerConfig extends LayerConfig {\n /** The target shape. Does not include the batch axis. */\n targetShape: Shape;\n}\n\nexport interface RepeatVectorLayerConfig extends LayerConfig {\n /**\n * The integer number of times to repeat the input.\n */\n n: number;\n}\n\n/**\n * Repeats the input n times in a new dimension.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.repeatVector({n: 4, inputShape: [2]}));\n * const x = tf.tensor2d([[10, 20]]);\n * // Use the model to do inference on a data point the model hasn't see\n * model.predict(x).print();\n * // output shape is now [batch, 2, 4]\n * ```\n */\nexport class RepeatVector extends Layer {\n static className = 'RepeatVector';\n readonly n: number;\n\n constructor(config: RepeatVectorLayerConfig) {\n super(config);\n this.n = config.n;\n this.inputSpec = [{ndim: 2}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], this.n, inputShape[1]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n return K.repeat(inputs, this.n);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n n: this.n,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RepeatVector);\n\n/**\n * Reshapes an input to a certain shape.\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const reshapeLayer = tf.layers.reshape({targetShape: [2, 6]});\n * // Inspect the inferred output shape of the Reshape layer, which\n * // equals `[null, 2, 6]`. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(reshapeLayer.apply(input).shape));\n * ```\n *\n * Input shape:\n * Arbitrary: although all dimensions in the input shape must be fixed.\n * Use the ReshapeLayerConfig field `input_shape` when using this layer\n * as the first layer in a model.\n *\n * Output shape:\n * [batchSize, targetShape[0], targetShape[1], ...,\n * targetShape[targetShape.length - 1]].\n */\nexport class Reshape extends Layer {\n static className = 'Reshape';\n private targetShape: Shape;\n\n constructor(config: ReshapeLayerConfig) {\n super(config);\n this.targetShape = config.targetShape;\n\n // Make sure that all unknown dimensions are represented as `null`.\n for (let i = 0; i < this.targetShape.length; ++i) {\n if (this.isUnknown(this.targetShape[i])) {\n this.targetShape[i] = null;\n }\n }\n }\n\n private isUnknown(dim: number): boolean {\n return dim < 0 || dim == null;\n }\n\n /**\n * Finds and replaces a missing dimension in output shape.\n *\n * This is a near direct port of the internal Numpy function\n * `_fix_unknown_dimension` in `numpy/core/src/multiarray/shape.c`.\n *\n * @param inputShape: Original shape of array begin reshape.\n * @param outputShape: Target shape of the array, with at most a single\n * `null` or negative number, which indicates an underdetermined dimension\n * that should be derived from `inputShape` and the known dimensions of\n * `outputShape`.\n * @returns: The output shape with `null` replaced with its computed value.\n * @throws: ValueError: If `inputShape` and `outputShape` do not match.\n */\n private fixUnknownDimension(inputShape: Shape, outputShape: Shape): Shape {\n const errorMsg = 'Total size of new array must be unchanged.';\n const finalShape = outputShape.slice();\n let known = 1;\n let unknown = null;\n for (let i = 0; i < finalShape.length; ++i) {\n const dim = finalShape[i];\n if (this.isUnknown(dim)) {\n if (unknown === null) {\n unknown = i;\n } else {\n throw new ValueError('Can only specifiy one unknown dimension.');\n }\n } else {\n known *= dim;\n }\n }\n\n const originalSize = math_utils.arrayProd(inputShape);\n if (unknown !== null) {\n if (known === 0 || originalSize % known !== 0) {\n throw new ValueError(errorMsg);\n }\n finalShape[unknown] = originalSize / known;\n } else if (originalSize !== known) {\n throw new ValueError(errorMsg);\n }\n\n return finalShape;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n let anyUnknownDims = false;\n for (let i = 0; i < inputShape.length; ++i) {\n if (this.isUnknown(inputShape[i])) {\n anyUnknownDims = true;\n break;\n }\n }\n\n if (anyUnknownDims) {\n return inputShape.slice(0, 1).concat(this.targetShape);\n } else {\n return inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const outputShape = inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n return input.reshape(outputShape);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n targetShape: this.targetShape,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Reshape);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Embedding Layer.\n *\n * Original source: keras/constraints.py\n */\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface EmbeddingLayerConfig extends LayerConfig {\n /**\n * Integer > 0. Size of the vocabulary, i.e. maximum integer index + 1.\n */\n inputDim: number;\n /**\n * Integer >= 0. Dimension of the dense embedding.\n */\n outputDim: number;\n /**\n * Initializer for the `embeddings` matrix.\n */\n embeddingsInitializer?: InitializerIdentifier|Initializer;\n /**\n * Regularizer function applied to the `embeddings` matrix.\n */\n embeddingsRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Constraint function applied to the `embeddings` matrix.\n */\n embeddingsConstraint?: ConstraintIdentifier|Constraint;\n /**\n * Whether the input value 0 is a special \"padding\" value that should be\n * masked out. This is useful when using recurrent layers which may take\n * variable length input.\n *\n * If this is `True` then all subsequent layers in the model need to support\n * masking or an exception will be raised. If maskZero is set to `True`, as a\n * consequence, index 0 cannot be used in the vocabulary (inputDim should\n * equal size of vocabulary + 1).\n */\n maskZero?: boolean;\n /**\n * Length of input sequences, when it is constant.\n *\n * This argument is required if you are going to connect `flatten` then\n * `dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed).\n */\n inputLength?: number|number[];\n}\n\n/**\n * Maps positive integers (indices) into dense vectors of fixed size.\n * eg. [[4], [20]] -> [[0.25, 0.1], [0.6, -0.2]]\n *\n * **Input shape:** 2D tensor with shape: `[batchSize, sequenceLength]`.\n *\n * **Output shape:** 3D tensor with shape: `[batchSize, sequenceLength,\n * outputDim]`.\n */\nexport class Embedding extends Layer {\n static className = 'Embedding';\n private inputDim: number;\n private outputDim: number;\n private embeddingsInitializer: Initializer;\n private maskZero: boolean;\n private inputLength: number|number[];\n\n private embeddings: LayerVariable = null;\n\n readonly DEFAULT_EMBEDDINGS_INITIALIZER: InitializerIdentifier =\n 'randomUniform';\n private readonly embeddingsRegularizer?: Regularizer;\n private readonly embeddingsConstraint?: Constraint;\n\n constructor(config: EmbeddingLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null) {\n // Porting Note: This logic is copied from Layer's constructor, since we\n // can't do exactly what the Python constructor does for Embedding().\n // Specifically, the super constructor can not be called after the\n // mutation of the `config` argument.\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n if (config.inputLength == null) {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (None, )\n this.batchInputShape = [batchSize, null];\n } else {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (config.inputLength, )\n this.batchInputShape =\n [batchSize].concat(generic_utils.toList(config.inputLength));\n }\n }\n this.inputDim = config.inputDim;\n this.outputDim = config.outputDim;\n this.embeddingsInitializer = getInitializer(\n config.embeddingsInitializer || this.DEFAULT_EMBEDDINGS_INITIALIZER);\n this.embeddingsRegularizer = getRegularizer(config.embeddingsRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.embeddingsConstraint = getConstraint(config.embeddingsConstraint);\n this.maskZero = config.maskZero;\n this.inputLength = config.inputLength;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n this.embeddings = this.addWeight(\n 'embeddings', [this.inputDim, this.outputDim], this.dtype,\n this.embeddingsInitializer, this.embeddingsRegularizer, true,\n this.embeddingsConstraint);\n this.built = true;\n }\n\n // Override warnOnIncompatibleInputShape because an embedding layer allows\n // the input to have varying ranks.\n protected warnOnIncompatibleInputShape(inputShape: Shape) {}\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for Embedding yet');\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n if (this.inputLength == null) {\n return [...inputShape, this.outputDim];\n }\n // inputLength can be an array if input is 3D or higher.\n const inLens: number[] = generic_utils.toList(this.inputLength);\n if (inLens.length !== inputShape.length - 1) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else {\n let i = 0;\n for (let k = 0; k < inLens.length; ++k) {\n const s1 = inLens[k];\n const s2 = inputShape[k + 1];\n if ((s1 != null) && (s2 != null) && (s1 !== s2)) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else if (s1 == null) {\n inLens[i] = s2;\n }\n i++;\n }\n }\n return [inputShape[0], ...inLens, this.outputDim];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Embedding layer accepts only a single input.\n let input = getExactlyOneTensor(inputs);\n if (input.dtype !== 'int32') {\n input = K.cast(input, 'int32');\n }\n const output = K.gather(this.embeddings.read(), input.as1D());\n return output.reshape(\n getExactlyOneShape(this.computeOutputShape(input.shape)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n inputDim: this.inputDim,\n outputDim: this.outputDim,\n embeddingsInitializer: serializeInitializer(this.embeddingsInitializer),\n embeddingsRegularizer: serializeRegularizer(this.embeddingsRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n embeddingsConstraint: serializeConstraint(this.embeddingsConstraint),\n maskZero: this.maskZero,\n inputLength: this.inputLength\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\nserialization.SerializationMap.register(Embedding);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Merge Layers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport * as K from '../backend/tfjs_backend';\nimport {Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as mathUtils from '../utils/math_utils';\nimport {getExactlyOneShape} from '../utils/types_utils';\n\n/**\n * Generic Merge layer for element-wise merge functions.\n *\n * Used to implement `Sum`, `Average`, `Concatenate`, etc.\n */\nexport abstract class Merge extends Layer {\n protected reshapeRequired: boolean;\n\n constructor(config?: LayerConfig) {\n super(config || {});\n this.supportsMasking = true;\n }\n\n /**\n * Logic for merging multiple tensors, to be overridden by subclasses.\n * @param inputs\n */\n protected mergeFunction(inputs: Tensor[]): Tensor {\n throw new NotImplementedError();\n }\n\n /**\n * Computes the shape of the result of an elementwise operation.\n *\n * @param shape1: Shape of the first tensor.\n * @param shape2: Shape of the second tensor.\n * @returns Expected output shape when an elementwise operation is carried\n * out on 2 tensors with shapes `shape1` and `shape2`.\n * @throws ValueError: If `shape1` and `shape2` are not compatible for\n * element-wise operations.\n */\n private computeElementwiseOpOutputShape(shape1: Shape, shape2: Shape): Shape {\n if (shape1 == null || shape2 == null) {\n return null;\n } else if (shape1.length < shape2.length) {\n return this.computeElementwiseOpOutputShape(shape2, shape1);\n } else if (shape2.length === 0) {\n return shape1;\n }\n const outputShape: Shape = shape1.slice(0, shape1.length - shape2.length);\n for (let k = 0; k < shape2.length; ++k) {\n const i = shape1[shape1.length - shape2.length + k];\n const j = shape2[k];\n if (i == null || j == null || i < 0 || j < 0) {\n outputShape.push(null);\n } else if (i === 1) {\n outputShape.push(j);\n } else if (j === 1) {\n outputShape.push(i);\n } else {\n if (i !== j) {\n throw new ValueError(\n 'Operands could not be broadcast together with shapes ' +\n JSON.stringify(shape1) + ' ' + JSON.stringify(shape2));\n }\n outputShape.push(i);\n }\n }\n return outputShape;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.\n if (Array.isArray(inputShape) && !Array.isArray(inputShape[0])) {\n // Make sure that inputShape is an Array of shape.\n inputShape = [getExactlyOneShape(inputShape)];\n }\n inputShape = inputShape as Shape[];\n if (inputShape.length < 2) {\n throw new ValueError(\n 'A merge layer should be called on an Array of at least 2 inputs.' +\n ` Got ${inputShape.length} input(s).`);\n }\n\n // Make sure that there is at most one unique batch size among the input\n // shapes.\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length > 1) {\n throw new ValueError(\n `Can not merge tensors with different batch sizes. ` +\n `Got tensors with shapes: ${JSON.stringify(inputShape)}.`);\n }\n\n let outputShape: Shape =\n inputShape[0] == null ? null : inputShape[0].slice(1);\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n // If the inputs have different ranks, we have to reshape them to make them\n // broadcastable.\n const allRanks = inputShape.map(shape => shape.length);\n if (inputShape.indexOf(null) === -1 &&\n generic_utils.unique(allRanks).length === 1) {\n this.reshapeRequired = false;\n } else {\n this.reshapeRequired = true;\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (this.reshapeRequired) {\n const reshapedInputs: Tensor[] = [];\n const inputDims = inputs.map(input => input.rank);\n if (inputDims.indexOf(null) === -1) {\n // If ranks of all inputs are available, we simply expand each of them\n // at axis=1 until all of them have the same rank.\n const maxNDim = mathUtils.max(inputDims);\n for (let x of inputs) {\n const xNDim = x.rank;\n for (let k = 0; k < maxNDim - xNDim; ++k) {\n x = K.expandDims(x, 1);\n }\n reshapedInputs.push(x);\n }\n return this.mergeFunction(reshapedInputs);\n } else {\n // Transpose all inputs so that batch size is the last dimension.\n // [batchSize, dim1, dim2, ...] -> [dim1, dim2, ..., batchSize]\n let transposed = false;\n for (const x of inputs) {\n const xNDim = x.rank;\n if (xNDim == null) {\n const xShape = x.shape;\n const batchSize = xShape[0];\n const newShape = xShape.slice(1).concat([batchSize]);\n let xTransposed = x.reshape(\n [batchSize].concat(mathUtils.arrayProd(xShape.slice(1))));\n xTransposed = tfc.transpose(xTransposed, [1, 0]);\n xTransposed = xTransposed.reshape(newShape);\n reshapedInputs.push(xTransposed);\n transposed = true;\n } else if (xNDim > 1) {\n const dims = mathUtils.range(1, xNDim).concat([0]);\n reshapedInputs.push(tfc.transpose(x, dims));\n transposed = true;\n } else {\n // We don't transpose inputs if they are 1D vectors or scalars.\n reshapedInputs.push(x);\n }\n }\n let y = this.mergeFunction(reshapedInputs);\n const yNDim = y.rank;\n if (transposed) {\n // If inputs have been transposed, we have to transpose the output\n // too.\n if (yNDim == null) {\n const yShape = y.shape;\n const yNDim = yShape.length;\n const batchSize = yShape[yNDim - 1];\n const newShape =\n [batchSize].concat(yShape.slice(0, yShape.length - 1));\n y = tfc.transpose(y.reshape([-1, batchSize]), [1, 0])\n .reshape(newShape);\n } else if (yNDim > 1) {\n const dims = [yNDim - 1].concat(mathUtils.range(0, yNDim - 1));\n y = tfc.transpose(y, dims);\n }\n }\n return y;\n }\n } else {\n return this.mergeFunction(inputs);\n }\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape[];\n let outputShape: Shape;\n if (inputShape[0] == null) {\n outputShape = null;\n } else {\n outputShape = inputShape[0].slice(1);\n }\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length === 1) {\n outputShape = batchSizes.concat(outputShape);\n } else {\n outputShape = [null].concat(outputShape);\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n}\n\n/**\n * Layer that performs element-wise addition on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). The inputs are specified as an\n * `Array` when the `apply` method of the `Add` layer instance is called. For\n * example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const addLayer = tf.layers.add();\n * const sum = addLayer.apply([input1, input2]);\n * console.log(JSON.stringify(sum.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Add extends Merge {\n static className = 'Add';\n constructor(config?: LayerConfig) {\n super(config as LayerConfig);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Add);\n\n/**\n * Calculate the element-wise sum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Add` layer, by using no input argument\n * or a single configuration argument. The resultant `Add` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const addLayer = tf.layers.add();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = addLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.add([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.add([input1, input2]).print();\n * // Gives [[11, 22], [33, 44]].\n *\n */\nexport function add(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Add({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Add(config);\n }\n}\n\n/**\n * Layer that multiplies (element-wise) an `Array` of inputs.\n *\n * It takes as input an Array of tensors, all of the same\n * shape, and returns a single tensor (also of the same shape).\n * For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const input3 = tf.input({shape: [2, 2]});\n * const multiplyLayer = tf.layers.multiply();\n * const product = multiplyLayer.apply([input1, input2, input3]);\n * console.log(product.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n */\nexport class Multiply extends Merge {\n static className = 'Multiply';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.ones(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.mul(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Multiply);\n\n/**\n * Calculate the element-wise product of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Multiply` layer, by using no input argument\n * or a single configuration argument. The resultant `Multiply` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const multiplyLayer = tf.layers.multiply();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = multiplyLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.multiply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.multiply([input1, input2]).print();\n * // Gives [[10, 40], [90, 160]].\n *\n */\nexport function multiply(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Multiply({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Multiply(config);\n }\n}\n\n/**\n * Layer that performs element-wise averaging on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const averageLayer = tf.layers.average();\n * const average = averageLayer.apply([input1, input2]);\n * console.log(JSON.stringify(average.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Average extends Merge {\n static className = 'Average';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return tfc.mul(getScalar(1 / inputs.length), output);\n });\n }\n}\nserialization.SerializationMap.register(Average);\n\n/**\n * Calculate the element-wise arithmetic mean of inputs, which all have the same\n * shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Average` layer, by using no input argument\n * or a single configuration argument. The resultant `Average` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const averageLayer = tf.layers.average();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = averageLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.average([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.average([input1, input2]).print();\n * // Gives [[5.5, 11], [16.5, 22]].\n *\n */\nexport function average(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Average({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Average(config);\n }\n}\n\n/**\n * Layer that computes the element-wise maximum an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const maxLayer = tf.layers.maximum();\n * const max = maxLayer.apply([input1, input2]);\n * console.log(JSON.stringify(max.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Maximum extends Merge {\n static className = 'Maximum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.maximum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Maximum);\n\n/**\n * Calculate the element-wise maximum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Maximum` layer, by using no input argument\n * or a single configuration argument. The resultant `Maximum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const maximumLayer = tf.layers.maximum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = maximumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.maximum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.maximum([input1, input2]).print();\n * // Gives [[10, 20], [30, 40]].\n *\n */\nexport function maximum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Maximum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Maximum(config);\n }\n}\n\n/**\n * Layer that computes the element-wise minimum of an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const minLayer = tf.layers.minimum();\n * const min = minLayer.apply([input1, input2]);\n * console.log(JSON.stringify(min.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Minimum extends Merge {\n static className = 'Minimum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.minimum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Minimum);\n\n/**\n * Calculate the element-wise minimum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Minimum` layer, by using no input argument\n * or a single configuration argument. The resultant `Minimum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const minimumLayer = tf.layers.minimum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = minimumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.minimum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.minimum([input1, input2]).print();\n * // Gives [[1, 2], [3, 4]].\n *\n */\nexport function minimum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Minimum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Minimum(config);\n }\n}\n\nexport interface ConcatenateLayerConfig extends LayerConfig {\n /**\n * Axis along which to concatenate.\n */\n axis?: number;\n}\n\n/**\n * Layer that concatenates an `Array` of inputs.\n *\n * It takes a list of tensors, all of the same shape except for the\n * concatenation axis, and returns a single tensor, the concatenation\n * of all inputs. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 3]});\n * const concatLayer = tf.layers.concatenate();\n * const output = concatLayer.apply([input1, input2]);\n * console.log(JSON.stringify(output.shape));\n * // You get [null, 2, 5], with the first dimension as the undetermined batch\n * // dimension. The last dimension (5) is the result of concatenating the\n * // last dimensions of the inputs (2 and 3).\n * ```\n */\nexport class Concatenate extends Merge {\n static className = 'Concatenate';\n readonly DEFAULT_AXIS = -1;\n private readonly axis: number;\n\n constructor(config?: ConcatenateLayerConfig) {\n super(config);\n if (config == null) {\n config = {};\n }\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n this.supportsMasking = true;\n this.reshapeRequired = false;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.]\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0])) ||\n inputShape.length === 1) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of at least 2 ' +\n 'inputs');\n }\n inputShape = inputShape as Shape[];\n\n let allNoneShape = true;\n for (const shape of inputShape) {\n if (shape != null) {\n allNoneShape = false;\n break;\n }\n }\n if (allNoneShape) {\n return;\n }\n\n const shapeSet: Shape[] = [];\n for (let i = 0; i < inputShape.length; ++i) {\n const shapeWithoutConcatAxis = inputShape[i].slice();\n shapeWithoutConcatAxis.splice(this.axis, 1);\n let exists = false;\n for (const shape of shapeSet) {\n if (util.arraysEqual(shape, shapeWithoutConcatAxis)) {\n exists = true;\n break;\n }\n }\n if (!exists) {\n shapeSet.push(shapeWithoutConcatAxis);\n }\n }\n if (shapeSet.length > 1) {\n throw new ValueError(\n 'A `Concatenate` layer requires inputs with matching shapes ' +\n 'except for the concat axis. Got input shapes: ' +\n JSON.stringify(inputShape));\n }\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n return K.concatenate(inputs, this.axis);\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0]))) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of inputs.');\n }\n const inputShapes = inputShape as Shape[];\n const outputShape = inputShapes[0].slice();\n const axis = this.axis < 0 ? outputShape.length + this.axis : this.axis;\n // Porting Note: the line above is because TypeScript doesn't support\n // negative indices.\n for (const shape of inputShapes.slice(1)) {\n if (outputShape[axis] == null || shape[axis] == null) {\n outputShape[axis] = null;\n break;\n }\n outputShape[axis] += shape[axis];\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'axis': this.axis,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Concatenate);\n\n/**\n * Concatenate an `Array` of inputs.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Concatenate` layer, by using no input argument\n * or a single configuration argument. The resultant `Concatenate` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const concatLayer = tf.layers.concatenate();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = concatLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 7], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = tf.layers.concatenate([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([[1, 2], [3, 4]], [2, 2]);\n * const input2 = tf.tensor2d([[10, 20], [30, 40]], [2, 2]);\n * tf.layers.concatenate([input1, input2]).print();\n * // Gives [[1, 2, 10, 20], [3, 4, 30, 40]].\n *\n */\nexport function concatenate(config?: SymbolicTensor[]|Tensor[]|\n ConcatenateLayerConfig): Layer|SymbolicTensor|\n Tensor {\n if (Array.isArray(config)) {\n const layer = new Concatenate({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Concatenate(config);\n }\n}\n\n// TODO(cais): Add class Dot.\n\n// TODO(cais): Add functional interfaces for the merge layers.\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Normalization layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\n/**\n * Applies batch normalization on x given mean, var, beta and gamma.\n *\n * I.e. returns:\n * `output = (x - mean) / (sqrt(var) + epsilon) * gamma + beta`\n *\n * @param x Input tensor.\n * @param mean Mean of batch.\n * @param variance Variance of batch.\n * @param beta Tensor with which to center the input.\n * @param gamma Tensor by which to scale the input.\n * @param epsilon Fuzz factor.\n * @returns The result of the batch normalization.\n */\nexport function batchNormalization(\n x: Tensor, mean: Tensor, variance: Tensor, beta?: Tensor, gamma?: Tensor,\n epsilon = 1e-3): Tensor {\n let out: Tensor;\n if (x.rank === 2) {\n out = tfc.batchNormalization2d(\n x as Tensor2D, mean as Tensor2D | Tensor1D,\n variance as Tensor2D | Tensor1D, epsilon, gamma as Tensor2D | Tensor1D,\n beta as Tensor2D | Tensor1D);\n } else if (x.rank === 3) {\n // TODO(cais): Check rank; give proper error message.\n out = tfc.batchNormalization3d(\n x as Tensor3D, mean as Tensor3D | Tensor1D,\n variance as Tensor3D | Tensor1D, epsilon, gamma as Tensor3D | Tensor1D,\n beta as Tensor3D | Tensor1D);\n } else if (x.rank === 4) {\n out = tfc.batchNormalization4d(\n x as Tensor4D, mean as Tensor4D | Tensor1D,\n variance as Tensor4D | Tensor1D, epsilon, gamma as Tensor4D | Tensor1D,\n beta as Tensor4D | Tensor1D);\n } else {\n throw new NotImplementedError(\n `batchNormalization is not implememnted for array of rank ${x.rank} ` +\n `yet`);\n }\n return out;\n}\n\n/**\n * Non-broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction regularNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const normed =\n batchNormalization(x, mean, variance, beta, gamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction broadcastNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const targetShape: number[] = [];\n for (const axis of math_utils.range(0, x.rank)) {\n if (reductionAxes.indexOf(axis) !== -1) {\n targetShape.push(1);\n } else {\n targetShape.push(x.shape[axis]);\n }\n }\n const broadcastMean = mean.reshape(targetShape);\n const broadcastVariance = variance.reshape(targetShape);\n const broadcastGamma =\n gamma == null ? null : gamma.reshape(targetShape);\n const broadcastBeta =\n beta == null ? null : beta.reshape(targetShape);\n const normed = batchNormalization(\n x, broadcastMean, broadcastVariance, broadcastBeta,\n broadcastGamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Batch normalization for use in training (not inference).\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nexport function normalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n if (util.arraysEqual(\n reductionAxes.slice().sort(), math_utils.range(0, x.rank - 1))) {\n return regularNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n } else {\n return broadcastNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n }\n}\n\nexport interface BatchNormalizationLayerConfig extends LayerConfig {\n /**\n * The integer axis that should be normalized (typically the features axis).\n * Defaults to -1.\n *\n * For instance, after a `Conv2D` layer with `data_format=\"channels_first\"`,\n * set `axis=1` in `batchNormalization`.\n */\n axis?: number;\n\n /**\n * Momentum of the moving average. Defaults to 0.99.\n */\n momentum?: number;\n\n /**\n * Small float added to the variance to avoid dividing by zero. Defaults to\n * 1e-3.\n */\n epsilon?: number;\n\n /**\n * If `true`, add offset of `beta` to normalized tensor.\n * If `false`, `beta` is ignored.\n * Defaults to `true`.\n */\n center?: boolean;\n\n /**\n * If `true`, multiply by `gamma`.\n * If `false`, `gamma` is not used.\n * When the next layer is linear (also e.g. `nn.relu`),\n * this can be disabled since the scaling will be done by the next layer.\n * Defaults to `true`.\n */\n scale?: boolean;\n\n /**\n * Initializer for the beta weight.\n * Defaults to 'zeros'.\n */\n betaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the gamma weight.\n * Defaults to `ones`.\n */\n gammaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving mean.\n * Defaults to `zeros`\n */\n movingMeanInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving variance.\n * Defaults to 'Ones'.\n */\n movingVarianceInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the beta weight.\n */\n betaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for gamma weight.\n */\n gammaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer for the beta weight.\n */\n betaRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer for the gamma weight.\n */\n gammaRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n\n/**\n * Batch normalization layer (Ioffe and Szegedy, 2014).\n *\n * Normalize the activations of the previous layer at each batch,\n * i.e. applies a transformation that maintains the mean activation\n * close to 0 and the activation standard deviation close to 1.\n *\n * Input shape:\n * Arbitrary. Use the keyword argument `inputShape` (Array of integers, does\n * not include the sample axis) when calling the constructor of this class,\n * if this layer is used as a first layer in a model.\n *\n * Output shape:\n * Same shape as input.\n *\n * References:\n * - [Batch Normalization: Accelerating Deep Network Training by Reducing\n * Internal Covariate Shift](https://arxiv.org/abs/1502.03167)\n */\nexport class BatchNormalization extends Layer {\n static className = 'BatchNormalization';\n private readonly axis: number;\n private readonly momentum: number;\n private readonly epsilon: number;\n private readonly center: boolean;\n private readonly scale: boolean;\n private readonly betaInitializer: Initializer;\n private readonly gammaInitializer: Initializer;\n private readonly movingMeanInitializer: Initializer;\n private readonly movingVarianceInitializer: Initializer;\n private readonly betaConstraint: Constraint;\n private readonly gammaConstraint: Constraint;\n private readonly betaRegularizer: Regularizer;\n private readonly gammaRegularizer: Regularizer;\n private gamma: LayerVariable;\n private beta: LayerVariable;\n private movingMean: LayerVariable;\n private movingVariance: LayerVariable;\n private stepCount: number;\n\n constructor(config: BatchNormalizationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.axis = config.axis == null ? -1 : config.axis;\n this.momentum = config.momentum == null ? 0.99 : config.momentum;\n this.epsilon = config.epsilon == null ? 1e-3 : config.epsilon;\n this.center = config.center == null ? true : config.center;\n this.scale = config.scale == null ? true : config.scale;\n this.betaInitializer = getInitializer(config.betaInitializer || 'zeros');\n this.gammaInitializer = getInitializer(config.gammaInitializer || 'ones');\n this.movingMeanInitializer =\n getInitializer(config.movingMeanInitializer || 'zeros');\n this.movingVarianceInitializer =\n getInitializer(config.movingVarianceInitializer || 'ones');\n this.betaConstraint = getConstraint(config.betaConstraint);\n this.gammaConstraint = getConstraint(config.gammaConstraint);\n this.betaRegularizer = getRegularizer(config.betaRegularizer);\n this.gammaRegularizer = getRegularizer(config.gammaRegularizer);\n this.stepCount = 0;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const axis = this.axis >= 0 ? this.axis : (this.axis + inputShape.length);\n const dim = inputShape[axis];\n if (dim == null) {\n throw new ValueError(\n `Axis ${axis} of input tensor should have a defined dimension but ` +\n `the layer received an input with shape ` +\n `${JSON.stringify(inputShape)}.`);\n }\n this.inputSpec =\n [new InputSpec({ndim: inputShape.length, axes: {[axis]: dim}})];\n const shape = [dim];\n if (this.scale) {\n this.gamma = this.addWeight(\n 'gamma', shape, null, this.gammaInitializer, this.gammaRegularizer,\n true, this.gammaConstraint);\n }\n if (this.center) {\n this.beta = this.addWeight(\n 'beta', shape, null, this.betaInitializer, this.betaRegularizer, true,\n this.betaConstraint);\n }\n this.movingMean = this.addWeight(\n 'moving_mean', shape, null, this.movingMeanInitializer, null, false);\n this.movingVariance = this.addWeight(\n 'moving_variance', shape, null, this.movingVarianceInitializer, null,\n false);\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const ndim = inputShape.length;\n const reductionAxes = math_utils.range(0, ndim);\n const axis = this.axis >= 0 ? this.axis : (this.axis + ndim);\n reductionAxes.splice(axis, 1);\n const broadcastShape = generic_utils.pyListRepeat(1, ndim);\n broadcastShape[axis] = inputShape[axis];\n\n const sortedReductionAxes = reductionAxes.slice();\n sortedReductionAxes.sort();\n const needsBroadcasting = !util.arraysEqual(\n sortedReductionAxes, math_utils.range(0, ndim).slice(0, ndim - 1));\n\n const normalizeInference: () => Tensor = () => {\n if (needsBroadcasting) {\n const broadcastMovingMean =\n this.movingMean.read().reshape(broadcastShape);\n const broadcastMovingVariance =\n this.movingVariance.read().reshape(broadcastShape);\n const broadcastBeta =\n this.center ? this.beta.read().reshape(broadcastShape) : null;\n const broadcastGamma =\n this.scale ? this.gamma.read().reshape(broadcastShape) : null;\n return batchNormalization(\n input, broadcastMovingMean, broadcastMovingVariance,\n broadcastBeta, broadcastGamma, this.epsilon);\n } else {\n return batchNormalization(\n input, this.movingMean.read(), this.movingVariance.read(),\n this.beta == null ? null : this.beta.read(),\n this.gamma == null ? null : this.gamma.read(), this.epsilon);\n }\n };\n\n if (!training) {\n return normalizeInference();\n }\n\n const [normedTraining, mean, variance] = normalizeBatchInTraining(\n input, this.gamma.read(), this.beta.read(), reductionAxes,\n this.epsilon);\n\n // Debias variance.\n const sampleSize =\n math_utils.arrayProd(reductionAxes.map(axis => input.shape[axis]));\n const varianceDebiased = variance.mul(\n getScalar(sampleSize / (sampleSize - (1 + this.epsilon))));\n\n // Perform updates to moving mean and moving variance for training.\n // Porting Note: In PyKeras, these updates to `movingMean` and\n // `movingAverage` are done as a deferred Graph, added to the `Layer`'s\n // `update`s using the `add_update()` method. Here we do it imperatively\n // and encapsulate the updates in a function that is invoked\n // immediately.\n const updateMovingMeanAndVariance = () => {\n this.stepCount++;\n const newMovingMean = tfc.movingAverage(\n this.movingMean.read(), mean, this.momentum, this.stepCount);\n this.movingMean.write(newMovingMean);\n const newMovingVariance = tfc.movingAverage(\n this.movingVariance.read(), varianceDebiased, this.momentum,\n this.stepCount);\n this.movingVariance.write(newMovingVariance);\n };\n updateMovingMeanAndVariance();\n\n return normedTraining;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n axis: this.axis,\n momentum: this.momentum,\n epsilon: this.epsilon,\n center: this.center,\n scale: this.scale,\n betaInitializer: serializeInitializer(this.betaInitializer),\n gammaInitializer: serializeInitializer(this.gammaInitializer),\n movingMeanInitializer: serializeInitializer(this.movingMeanInitializer),\n movingVarianceInitializer:\n serializeInitializer(this.movingVarianceInitializer),\n betaRegularizer: serializeRegularizer(this.betaRegularizer),\n gammaRegularizer: serializeRegularizer(this.gammaRegularizer),\n betaConstraint: serializeConstraint(this.betaConstraint),\n gammaConstraint: serializeConstraint(this.gammaConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(BatchNormalization);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Padding Layers.\n */\n\n// Porting Note: In Python Keras, the padding layers are in convolutional.py,\n// but we decided to put them in a separate file (padding.ts) for clarity.\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport {DataFormat} from '../common';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\n// tslint:enable:max-line-length\n\n/**\n * Pads the middle dimension of a 3D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of 2 integers, how many zeros to add at the start and\n * end of the middle dimension (i.e., dimension 1).\n * @return A padded 3D `Tensor`.\n */\nexport function temporalPadding(x: Tensor, padding?: [number, number]): Tensor {\n return tidy(() => {\n if (x.rank !== 3) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 3-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [1, 1];\n }\n if (padding.length !== 2) {\n throw new ValueError(\n `temporalPadding expects input padding pattern to be a length-2 ` +\n `array, but received a length-${padding.length} array.`);\n }\n\n const pattern: Array<[number, number]> = [[0, 0], padding, [0, 0]];\n return tfc.pad(x, pattern);\n });\n}\n\n/**\n * Pads the 2nd and 3rd dimensions of a 4D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of two `Array`s, each of which is an `Array` of two\n * integers. The amount of padding at the beginning and end of the 2nd and 3rd\n * dimensions, respectively.\n * @param dataFormat 'channelsLast' (default) or 'channelsFirst'.\n * @return Padded 4D `Tensor`.\n */\nexport function spatial2dPadding(\n x: Tensor, padding?: [[number, number], [number, number]],\n dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (x.rank !== 4) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 4-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [[1, 1], [1, 1]];\n }\n if (padding.length !== 2 || padding[0].length !== 2 ||\n padding[1].length !== 2) {\n throw new ValueError(\n 'spatial2dPadding expects `padding` to be an Array of two Arrays, ' +\n 'each of which is an Array of two integers.');\n }\n\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (dataFormat !== 'channelsLast' && dataFormat !== 'channelsFirst') {\n throw new ValueError(\n `Unknown data format: ${dataFormat}. ` +\n `Supported data formats are 'channelsLast' and 'channelsFirst.`);\n }\n\n let pattern: Array<[number, number]>;\n if (dataFormat === 'channelsFirst') {\n pattern = [[0, 0], [0, 0], padding[0], padding[1]];\n } else {\n pattern = [[0, 0], padding[0], padding[1], [0, 0]];\n }\n\n return tfc.pad(x, pattern);\n });\n}\n\nexport interface ZeroPadding2DLayerConfig extends LayerConfig {\n /**\n * Integer, or `Array` of 2 integers, or `Array` of 2 `Array`s, each of\n * which is an `Array` of 2 integers.\n * - If integer, the same symmetric padding is applied to width and height.\n * - If Array` of 2 integers, interpreted as two different symmetric values\n * for height and width:\n * `[symmetricHeightPad, symmetricWidthPad]`.\n * - If `Array` of 2 `Array`s, interpreted as:\n * `[[topPad, bottomPad], [leftPad, rightPad]]`.\n */\n padding?: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * One of `'channelsLast'` (default) and `'channelsFirst'`.\n *\n * The ordering of the dimensions in the inputs.\n * `channelsLast` corresponds to inputs with shape\n * `[batch, height, width, channels]` while `channelsFirst`\n * corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Zero-padding layer for 2D input (e.g., image).\n *\n * This layer can add rows and columns of zeros\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, paddedRows, paddedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, paddedRows, paddedCols]`.\n */\nexport class ZeroPadding2D extends Layer {\n static className = 'ZeroPadding2D';\n readonly dataFormat: DataFormat;\n readonly padding: [[number, number], [number, number]];\n\n constructor(config?: ZeroPadding2DLayerConfig) {\n if (config == null) {\n config = {};\n }\n super(config);\n\n this.dataFormat =\n config.dataFormat == null ? imageDataFormat() : config.dataFormat;\n // TODO(cais): Maybe refactor the following logic surrounding `padding`\n // into a helper method.\n if (config.padding == null) {\n this.padding = [[1, 1], [1, 1]];\n } else if (typeof config.padding === 'number') {\n this.padding =\n [[config.padding, config.padding], [config.padding, config.padding]];\n } else {\n config.padding = config.padding as [number, number] |\n [[number, number], [number, number]];\n if (config.padding.length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects padding to be a length-2 array, but ` +\n `received a length-${config.padding.length} array.`);\n }\n\n let heightPadding: [number, number];\n let widthPadding: [number, number];\n if (typeof config.padding[0] === 'number') {\n heightPadding =\n [config.padding[0] as number, config.padding[0] as number];\n widthPadding =\n [config.padding[1] as number, config.padding[1] as number];\n } else {\n config.padding = config.padding as [[number, number], [number, number]];\n\n if (config.padding[0].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects height padding to be a length-2 array, ` +\n `but received a length-${config.padding[0].length} array.`);\n }\n heightPadding = config.padding[0] as [number, number];\n\n if (config.padding[1].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects width padding to be a length-2 array, ` +\n `but received a length-${config.padding[1].length} array.`);\n }\n widthPadding = config.padding[1] as [number, number];\n }\n this.padding = [heightPadding, widthPadding];\n }\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n\n let rows: number;\n let cols: number;\n if (this.dataFormat === 'channelsFirst') {\n if (inputShape[2] != null && inputShape[2] >= 0) {\n rows = inputShape[2] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[3] != null && inputShape[3] >= 0) {\n cols = inputShape[3] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n if (inputShape[1] != null && inputShape[1] >= 0) {\n rows = inputShape[1] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[2] != null && inputShape[2] >= 0) {\n cols = inputShape[2] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(\n () => spatial2dPadding(\n getExactlyOneTensor(inputs), this.padding, this.dataFormat));\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n padding: this.padding,\n dataFormat: this.dataFormat,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ZeroPadding2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Pooling Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, checkPoolMode, DataFormat, PaddingMode, PoolMode} from '../common';\nimport {InputSpec} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\nimport {preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D pooling.\n * @param x\n * @param poolSize\n * @param stridesdes strides. Defaults to [1, 1].\n * @param padding padding. Defaults to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param poolMode Mode of pooling. Defaults to 'max'.\n * @returns Result of the 2D pooling.\n */\nexport function pool2d(\n x: Tensor, poolSize: [number, number], strides?: [number, number],\n padding?: PaddingMode, dataFormat?: DataFormat,\n poolMode?: PoolMode): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n checkPoolMode(poolMode);\n checkPaddingMode(padding);\n if (strides == null) {\n strides = [1, 1];\n }\n if (padding == null) {\n padding = 'valid';\n }\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (poolMode == null) {\n poolMode = 'max';\n }\n\n // TODO(cais): Remove the preprocessing step once deeplearn.js supports\n // dataFormat as an input argument.\n x = preprocessConv2DInput(x, dataFormat); // x is NHWC after preprocessing.\n let y: Tensor;\n const paddingString = (padding === 'same') ? 'same' : 'valid';\n if (poolMode === 'max') {\n // TODO(cais): Rank check?\n y = tfc.maxPool(x as Tensor4D, poolSize, strides, paddingString);\n } else { // 'avg'\n // TODO(cais): Check the dtype and rank of x and give clear error message\n // if those are incorrect.\n y = tfc.avgPool(\n // TODO(cais): Rank check?\n x as Tensor3D | Tensor4D, poolSize, strides, paddingString);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return y;\n });\n}\n\n\nexport interface Pooling1DLayerConfig extends LayerConfig {\n /**\n * Size of the window to pool over, should be an integer.\n */\n poolSize?: number;\n /**\n * Period at which to sample the pooled values.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number;\n /** How to fill in data that's not an integer multiple of poolSize. */\n padding?: PaddingMode;\n}\n\n/**\n * Abstract class for different pooling 1D layers.\n */\nexport abstract class Pooling1D extends Layer {\n protected readonly poolSize: [number];\n protected readonly strides: [number];\n protected readonly padding: PaddingMode;\n\n /**\n *\n * @param config Parameters for the Pooling layer.\n *\n * config.poolSize defaults to 2.\n */\n constructor(config: Pooling1DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = 2;\n }\n super(config);\n if (typeof config.poolSize === 'number') {\n this.poolSize = [config.poolSize];\n } else if (\n Array.isArray(config.poolSize) &&\n (config.poolSize as number[]).length === 1 &&\n typeof (config.poolSize as number[])[0] === 'number') {\n this.poolSize = config.poolSize;\n } else {\n throw new ValueError(\n `poolSize for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.poolSize)}`);\n }\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else {\n if (typeof config.strides === 'number') {\n this.strides = [config.strides];\n } else if (\n Array.isArray(config.strides) &&\n (config.strides as number[]).length === 1 &&\n typeof (config.strides as number[])[0] === 'number') {\n this.strides = config.strides;\n } else {\n throw new ValueError(\n `strides for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.strides)}`);\n }\n }\n\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const length = convOutputLength(\n inputShape[1], this.poolSize[0], this.padding, this.strides[0]);\n return [inputShape[0], length, inputShape[2]];\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Add dummy last dimension.\n inputs = K.expandDims(getExactlyOneTensor(inputs), 2);\n const output = this.poolingFunction(\n getExactlyOneTensor(inputs), [this.poolSize[0], 1],\n [this.strides[0], 1], this.padding, 'channelsLast');\n // Remove dummy last dimension.\n return tfc.squeeze(output, [2]);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for temporal data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n */\nexport class MaxPooling1D extends Pooling1D {\n static className = 'MaxPooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling1D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n *\n * `tf.avgPool1d` is an alias.\n */\nexport class AveragePooling1D extends Pooling1D {\n static className = 'AveragePooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling1D);\n\nexport interface Pooling2DLayerConfig extends LayerConfig {\n /**\n * Factors by which to downscale in each dimension [vertical, horizontal].\n * Expects an integer or an array of 2 integers.\n *\n * For example, `[2, 2]` will halve the input in both spatial dimension.\n * If only one integer is specified, the same window length\n * will be used for both dimensions.\n */\n poolSize?: number|[number, number];\n\n /**\n * The size of the stride in each dimension of the pooling window. Expects\n * an integer or an array of 2 integers. Integer, tuple of 2 integers, or\n * None.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number|[number, number];\n\n /** The padding type to use for the pooling layer. */\n padding?: PaddingMode;\n /** The data format to use for the pooling layer. */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different pooling 2D layers.\n */\nexport abstract class Pooling2D extends Layer {\n protected readonly poolSize: [number, number];\n protected readonly strides: [number, number];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Pooling2DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = [2, 2];\n }\n super(config);\n this.poolSize = Array.isArray(config.poolSize) ?\n config.poolSize :\n [config.poolSize, config.poolSize];\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else if (Array.isArray(config.strides)) {\n if (config.strides.length !== 2) {\n throw new ValueError(\n `If the strides property of a 2D pooling layer is an Array, ` +\n `it is expected to have a length of 2, but received length ` +\n `${config.strides.length}.`);\n }\n this.strides = config.strides;\n } else {\n // `config.strides` is a number.\n this.strides = [config.strides, config.strides];\n }\n this.padding = config.padding == null ? 'valid' : config.padding;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n checkPaddingMode(this.padding);\n\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n let rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n let cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n rows =\n convOutputLength(rows, this.poolSize[0], this.padding, this.strides[0]);\n cols =\n convOutputLength(cols, this.poolSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return this.poolingFunction(\n getExactlyOneTensor(inputs), this.poolSize, this.strides,\n this.padding, this.dataFormat);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n dataFormat: this.dataFormat\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for spatial data.\n *\n * Input shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat=CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat=CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n */\nexport class MaxPooling2D extends Pooling2D {\n static className = 'MaxPooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling2D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n *\n * `tf.avgPool2d` is an alias.\n */\nexport class AveragePooling2D extends Pooling2D {\n static className = 'AveragePooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling2D);\n\n/**\n * Abstract class for different global pooling 1D layers.\n */\nexport abstract class GlobalPooling1D extends Layer {\n constructor(config: LayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], inputShape[2]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n}\n\n/**\n * Global average pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalAveragePooling1D extends GlobalPooling1D {\n static className = 'GlobalAveragePooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.mean(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling1D);\n\n/**\n * Global max pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalMaxPooling1D extends GlobalPooling1D {\n static className = 'GlobalMaxPooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.max(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling1D);\n\nexport interface GlobalPooling2DLayerConfig extends LayerConfig {\n /**\n * One of `CHANNEL_LAST` (default) or `CHANNEL_FIRST`.\n *\n * The ordering of the dimensions in the inputs. `CHANNEL_LAST` corresponds\n * to inputs with shape `[batch, height, width, channels[` while\n * `CHANNEL_FIRST` corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different global pooling 2D layers.\n */\nexport abstract class GlobalPooling2D extends Layer {\n protected dataFormat: DataFormat;\n constructor(config: GlobalPooling2DLayerConfig) {\n super(config);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape;\n if (this.dataFormat === 'channelsLast') {\n return [inputShape[0], inputShape[3]];\n } else {\n return [inputShape[0], inputShape[1]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Global average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalAveragePooling2D extends GlobalPooling2D {\n static className = 'GlobalAveragePooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.mean(input, [1, 2]);\n } else {\n return tfc.mean(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling2D);\n\n/**\n * Global max pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalMaxPooling2D extends GlobalPooling2D {\n static className = 'GlobalMaxPooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.max(input, [1, 2]);\n } else {\n return tfc.max(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Recurrent Neural Network Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Activation, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, SymbolicTensor} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {AttributeError, NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, Ones, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, RnnStepFunction, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor, isArrayOfShapes} from '../utils/types_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\n/**\n * Standardize `apply()` args to a single list of tensor inputs.\n *\n * When running a model loaded from file, the input tensors `initialState` and\n * `constants` are passed to `RNN.apply()` as part of `inputs` instead of the\n * dedicated kwargs fields. `inputs` consists of\n * `[inputs, initialState0, initialState1, ..., constant0, constant1]` in this\n * case.\n * This method makes sure that arguments are\n * separated and that `initialState` and `constants` are `Array`s of tensors\n * (or None).\n *\n * @param inputs Tensor or `Array` of tensors.\n * @param initialState Tensor or `Array` of tensors or `null`/`undefined`.\n * @param constants Tensor or `Array` of tensors or `null`/`undefined`.\n * @returns An object consisting of\n * inputs: A tensor.\n * initialState: `Array` of tensors or `null`.\n * constants: `Array` of tensors or `null`.\n * @throws ValueError, if `inputs` is an `Array` but either `initialState` or\n * `constants` is provided.\n */\nexport function standardizeArgs(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n initialState: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n constants: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n numConstants?: number): {\n inputs: Tensor|SymbolicTensor,\n initialState: Tensor[]|SymbolicTensor[],\n constants: Tensor[]|SymbolicTensor[]\n} {\n if (Array.isArray(inputs)) {\n if (initialState != null || constants != null) {\n throw new ValueError(\n 'When inputs is an array, neither initialState or constants ' +\n 'should be provided');\n }\n if (numConstants != null) {\n constants = inputs.slice(inputs.length - numConstants, inputs.length);\n inputs = inputs.slice(0, inputs.length - numConstants);\n }\n if (inputs.length > 1) {\n initialState = inputs.slice(1, inputs.length);\n }\n inputs = inputs[0];\n }\n\n function toListOrNull(x: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): Tensor[]|SymbolicTensor[] {\n if (x == null || Array.isArray(x)) {\n return x as Tensor[] | SymbolicTensor[];\n } else {\n return [x] as Tensor[] | SymbolicTensor[];\n }\n }\n\n initialState = toListOrNull(initialState);\n constants = toListOrNull(constants);\n\n return {inputs, initialState, constants};\n}\n\n/**\n * Iterates over the time dimension of a tensor.\n *\n * @param stepFunction RNN step function.\n * Parameters:\n * inputs: tensor with shape `[samples, ...]` (no time dimension),\n * representing input for the batch of samples at a certain time step.\n * states: an Array of tensors.\n * Returns:\n * outputs: tensor with shape `[samples, outputDim]` (no time dimension).\n * newStates: list of tensors, same length and shapes as `states`. The first\n * state in the list must be the output tensor at the previous timestep.\n * @param inputs Tensor of temporal data of shape `[samples, time, ...]` (at\n * least 3D).\n * @param initialStates Tensor with shape `[samples, outputDim]` (no time\n * dimension), containing the initial values of the states used in the step\n * function.\n * @param goBackwards If `true`, do the iteration over the time dimension in\n * reverse order and return the reversed sequence.\n * @param mask Binary tensor with shape `[sample, time, 1]`, with a zero for\n * every element that is masked.\n * @param constants An Array of constant values passed at each step.\n * @param unroll Whether to unroll the RNN or to use a symbolic loop. *Not*\n * applicable to this imperative deeplearn.js backend. Its value is ignored.\n * @param inputLength Not relevant in this deeplearn.js backend.\n * @returns An Array: `[lastOutput, outputs, newStates]`.\n * lastOutput: the lastest output of the RNN, of shape `[samples, ...]`.\n * outputs: tensor with shape `[samples, time, ...]` where each entry\n * `output[s, t]` is the output of the step function at time `t` for sample\n * `s`.\n * newStates: Array of tensors, latest states returned by the step function,\n * of shape `(samples, ...)`.\n * @throws ValueError If input dimension is less than 3.\n *\n * TODO(nielsene): This needs to be tidy-ed.\n */\nexport function rnn(\n stepFunction: RnnStepFunction, inputs: Tensor, initialStates: Tensor[],\n goBackwards = false, mask?: Tensor, constants?: Tensor[], unroll = false,\n inputLength?: number): [Tensor, Tensor, Tensor[]] {\n const ndim = inputs.shape.length;\n if (ndim < 3) {\n throw new ValueError(`Input should be at least 3D, but is ${ndim}D.`);\n }\n\n // Transpose to time-major, i.e., from [batch, time, ...] to [time, batch,\n // ...].\n const axes = [1, 0].concat(math_utils.range(2, ndim));\n inputs = tfc.transpose(inputs, axes);\n\n if (mask != null) {\n throw new NotImplementedError(\n 'The rnn() function of the deeplearn.js backend does not support ' +\n 'masking yet.');\n }\n\n if (constants != null) {\n throw new NotImplementedError(\n 'The rnn() functoin of the deeplearn.js backend does not support ' +\n 'constants yet.');\n }\n\n // Porting Note: the unroll option is ignored by the imperative backend.\n if (unroll) {\n console.warn(\n 'Backend rnn(): the unroll = true option is not applicable to the ' +\n 'imperative deeplearn.js backend.');\n }\n\n if (goBackwards) {\n inputs = tfc.reverse(inputs, 0);\n }\n\n // Porting Note: PyKeras with TensorFlow backend uses a symbolic loop\n // (tf.while_loop). But for the imperative deeplearn.js backend, we just\n // use the usual TypeScript control flow to iterate over the time steps in\n // the inputs.\n // Porting Note: PyKeras patches a \"_use_learning_phase\" attribute to\n // outputs.\n // This is not idiomatic in TypeScript. The info regarding whether we are\n // in a learning (i.e., training) phase for RNN is passed in a different\n // way.\n // TODO(cais): Determine in what exact way the learning phase information\n // will be passed.\n\n let outputs: Tensor;\n let lastOutput: Tensor;\n let states = initialStates;\n const timeSteps = inputs.shape[0];\n for (let t = 0; t < timeSteps; ++t) {\n let currentInput = K.sliceAlongFirstAxis(inputs, t, 1);\n currentInput = currentInput.reshape(currentInput.shape.slice(1));\n const stepOutputs = stepFunction(currentInput, states);\n lastOutput = stepOutputs[0];\n if (t === 0) {\n outputs = lastOutput.reshape([1].concat(lastOutput.shape));\n } else {\n outputs = K.concatAlongFirstAxis(\n outputs, lastOutput.reshape([1].concat(lastOutput.shape)));\n }\n // TODO(soergel): Call K.concatenate() to perform only one concatenation\n // at the end, once the backend function is available.\n states = stepOutputs[1];\n }\n\n return [\n lastOutput,\n tfc.transpose(\n outputs, [1, 0].concat(math_utils.range(2, outputs.shape.length))),\n states\n ];\n}\n\n\nexport interface BaseRNNLayerConfig extends LayerConfig {\n /**\n * A RNN cell instance. A RNN cell is a class that has:\n * - a `call()` method, which takes `[Tensor, Tensor]` as the\n * first input argument. The first item is the input at time t, and\n * second item is the cell state at time t.\n * The `call()` method returns `[outputAtT, statesAtTPlus1]`.\n * The `call()` method of the cell can also take the argument `constants`,\n * see section \"Note on passing external constants\" below.\n * Porting Node: PyKeras overrides the `call()` signature of RNN cells,\n * which are Layer subtypes, to accept two arguments. tfjs-layers does\n * not do such overriding. Instead we preseve the `call()` signature,\n * which due to its `Tensor|Tensor[]` argument and return value, is\n * flexible enough to handle the inputs and states.\n * - a `stateSize` attribute. This can be a single integer (single state)\n * in which case it is the size of the recurrent state (which should be\n * the same as the size of the cell output). This can also be an Array of\n * integers (one size per state). In this case, the first entry\n * (`stateSize[0]`) should be the same as the size of the cell output.\n * It is also possible for `cell` to be a list of RNN cell instances, in which\n * case the cells get stacked on after the other in the RNN, implementing an\n * efficient stacked RNN.\n */\n cell?: RNNCell|RNNCell[];\n\n /**\n * Whether to return the last output in the output sequence, or the full\n * sequence.\n */\n returnSequences?: boolean;\n\n /**\n * Whether to return the last state in addition to the output.\n */\n returnState?: boolean;\n\n /**\n * If `true`, process the input sequence backwards and return the reversed\n * sequence (default: `false`).\n */\n goBackwards?: boolean;\n\n /**\n * If `true`, the last state for each sample at index i in a batch will be\n * used as initial state of the sample of index i in the following batch\n * (default: `false`).\n */\n stateful?: boolean;\n\n /**\n * If `true`, the network will be unrolled, else a symbolic loop will be\n * used. Unrolling can speed-up a RNN, although it tends to be more memory-\n * intensive. Unrolling is only suitable for short sequences (default:\n * `false`).\n * Porting Note: tfjs-layers has an imperative backend. RNNs are executed with\n * normal TypeScript control flow. Hence this property is inapplicable and\n * ignored in tfjs-layers.\n */\n unroll?: boolean;\n\n /**\n * Dimensionality of the input (integer).\n * This option (or alternatively, the option `inputShape`) is required when\n * this layer is used as the first layer in a model.\n */\n inputDim?: number;\n\n /**\n * Length of the input sequences, to be specified when it is constant.\n * This argument is required if you are going to connect `Flatten` then\n * `Dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed). Note that if the recurrent layer is not the first layer in\n * your model, you would need to specify the input length at the level of the\n * first layer (e.g., via the `inputShape` option).\n */\n inputLength?: number;\n}\n\n/**\n * RNNLayerConfig is identical to BaseRNNLayerConfig, except it makes the\n * `cell` property required. This interface is to be used with constructors\n * of concrete RNN layer sbutypes.\n */\nexport interface RNNLayerConfig extends BaseRNNLayerConfig {\n cell: RNNCell|RNNCell[];\n}\n\n/**\n * Base class for recurrent layers.\n *\n * Input shape:\n * 3D tensor with shape `[batchSize, timeSteps, inputDim]`.\n *\n * Output shape:\n * - if `returnState`, an Array of tensors (i.e., `Tensor`s). The first\n * tensor is the output. The remaining tensors are the states at the\n * last time step, each with shape `[batchSize, units]`.\n * - if `returnSequences`, the output will have shape\n * `[batchSize, timeSteps, units]`.\n * - else, the output will have shape `[batchSize, units]`.\n *\n * Masking:\n * This layer supports masking for input data with a variable number\n * of timesteps. To introduce masks to your data,\n * use an embedding layer with the `mask_zero` parameter\n * set to `True`.\n *\n * Notes on using statefulness in RNNs:\n * You can set RNN layers to be 'stateful', which means that the states\n * computed for the samples in one batch will be reused as initial states\n * for the samples in the next batch. This assumes a one-to-one mapping\n * between samples in different successive batches.\n *\n * To enable statefulness:\n * - specify `stateful: true` in the layer constructor.\n * - specify a fixed batch size for your model, by passing\n * if sequential model:\n * `batchInputShape=[...]` to the first layer in your model.\n * else for functional model with 1 or more Input layers:\n * `batchShape=[...]` to all the first layers in your model.\n * This is the expected shape of your inputs *including the batch size*.\n * It should be a tuple of integers, e.g. `(32, 10, 100)`.\n * - specify `shuffle=False` when calling fit().\n *\n * To reset the states of your model, call `.reset_states()` on either\n * a specific layer, or on your entire model.\n *\n * Note on specifying the initial state of RNNs\n * You can specify the initial state of RNN layers symbolically by\n * calling them with the option `initialState`. The value of\n * `initialState` should be a tensor or list of tensors representing\n * the initial state of the RNN layer.\n *\n * You can specify the initial state of RNN layers numerically by\n * calling `resetStates` with the keyword argument `states`. The value of\n * `states` should be a numpy array or list of numpy arrays representing\n * the initial state of the RNN layer.\n *\n * Note on passing external constants to RNNs\n * You can pass \"external\" constants to the cell using the `constants`\n * keyword argument of `RNN.call` method. This requires that the `cell.call`\n * method accepts the same keyword argument `constants`. Such constants\n * can be used to conditon the cell transformation on additional static inputs\n * (not changing over time), a.k.a an attention mechanism.\n */\nexport class RNN extends Layer {\n static className = 'RNN';\n public readonly cell: RNNCell;\n public readonly returnSequences: boolean;\n public readonly returnState: boolean;\n public readonly goBackwards: boolean;\n public readonly unroll: boolean;\n\n public stateSpec: InputSpec[];\n public states: Tensor[];\n\n private numConstants: number;\n\n constructor(config: RNNLayerConfig) {\n super(config);\n let cell: RNNCell;\n if (config.cell == null) {\n throw new ValueError(\n 'cell property is missing for the constructor of RNN.');\n } else if (Array.isArray(config.cell)) {\n cell = new StackedRNNCells({cells: config.cell});\n } else {\n cell = config.cell;\n }\n if ((cell as RNNCell).stateSize == null) {\n throw new ValueError(\n 'The RNN cell should have an attribute `stateSize` (tuple of ' +\n 'integers, one integer per RNN state).');\n }\n this.cell = cell;\n this.returnSequences =\n config.returnSequences == null ? false : config.returnSequences;\n this.returnState = config.returnState == null ? false : config.returnState;\n this.goBackwards = config.goBackwards == null ? false : config.goBackwards;\n this._stateful = config.stateful == null ? false : config.stateful;\n this.unroll = config.unroll == null ? false : config.unroll;\n\n this.supportsMasking = true;\n this.inputSpec = [new InputSpec({ndim: 3})];\n this.stateSpec = null;\n this.states = null;\n // TODO(cais): Add constantsSpec and numConstants.\n this.numConstants = null;\n // TODO(cais): Look into the use of initial_state in the kwargs of the\n // constructor.\n }\n\n // Porting Note: This is the equivalent of `RNN.states` property getter in\n // PyKeras.\n getStates(): Tensor[] {\n if (this.states == null) {\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n return math_utils.range(0, numStates).map(x => null);\n } else {\n return this.states;\n }\n }\n\n // Porting Note: This is the equivalent of the `RNN.states` property setter in\n // PyKeras.\n setStates(states: Tensor[]): void {\n this.states = states;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n // TODO(cais): Remove the casting once stacked RNN cells become supported.\n let stateSize = this.cell.stateSize;\n if (!Array.isArray(stateSize)) {\n stateSize = [stateSize];\n }\n const outputDim = stateSize[0];\n let outputShape: Shape|Shape[];\n if (this.returnSequences) {\n outputShape = [inputShape[0], inputShape[1], outputDim];\n } else {\n outputShape = [inputShape[0], outputDim];\n }\n\n if (this.returnState) {\n const stateShape: Shape[] = [];\n for (const dim of stateSize) {\n stateShape.push([inputShape[0], dim]);\n }\n return [outputShape].concat(stateShape);\n } else {\n return outputShape;\n }\n }\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for RNN yet');\n }\n\n public build(inputShape: Shape|Shape[]): void {\n // Note inputShape will be an Array of Shapes of initial states and\n // constants if these are passed in apply().\n const constantShape: Shape[] = null;\n if (this.numConstants != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n }\n\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n const batchSize: number = this.stateful ? inputShape[0] : null;\n const inputDim = inputShape[inputShape.length - 1];\n this.inputSpec[0] = new InputSpec({shape: [batchSize, null, inputDim]});\n\n // Allow cell (if RNNCell Layer) to build before we set or validate\n // stateSpec.\n const stepInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (constantShape != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n } else {\n this.cell.build(stepInputShape);\n }\n\n // Set or validate stateSpec.\n let stateSize: number[];\n if (Array.isArray((this.cell as RNNCell).stateSize)) {\n stateSize = this.cell.stateSize as number[];\n } else {\n stateSize = [this.cell.stateSize as number];\n }\n\n if (this.stateSpec != null) {\n if (!util.arraysEqual(\n this.stateSpec.map(spec => spec.shape[spec.shape.length - 1]),\n stateSize)) {\n throw new ValueError(\n `An initialState was passed that is not compatible with ` +\n `cell.stateSize. Received stateSpec=${this.stateSpec}; ` +\n `However cell.stateSize is ${this.cell.stateSize}`);\n }\n } else {\n this.stateSpec =\n stateSize.map(dim => new InputSpec({shape: [null, dim]}));\n }\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n // TODO(cais): Uncomment the following line once stateful = true is\n // implemented.\n // this.resetStates();\n }\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n tidy(() => {\n if (!this.stateful) {\n throw new AttributeError(\n 'Cannot call resetState() on an RNN Layer that is not stateful.');\n }\n const batchSize = this.inputSpec[0].shape[0];\n if (batchSize == null) {\n throw new ValueError(\n 'If an RNN is stateful, it needs to know its batch size. Specify ' +\n 'the batch size of your input tensors: \\n' +\n '- If using a Sequential model, specify the batch size by ' +\n 'passing a `batchInputShape` option to your first layer.\\n' +\n '- If using the functional API, specify the batch size by ' +\n 'passing a `batchShape` option to your Input layer.');\n }\n // Initialize state if null.\n if (this.states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states = [tfc.zeros([batchSize, this.cell.stateSize])];\n }\n } else if (states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states[0] = tfc.zeros([batchSize, this.cell.stateSize]);\n }\n } else {\n if (!Array.isArray(states)) {\n states = [states];\n }\n if (states.length !== this.states.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${this.states.length} state(s), ` +\n `but it received ${states.length} state value(s). Input ` +\n `received: ${states}`);\n }\n for (let index = 0; index < this.states.length; ++index) {\n const value = states[index];\n const dim = Array.isArray(this.cell.stateSize) ?\n this.cell.stateSize[index] :\n this.cell.stateSize;\n const expectedShape = [batchSize, dim];\n if (!util.arraysEqual(value.shape, expectedShape)) {\n throw new ValueError(\n `State ${index} is incompatible with layer ${this.name}: ` +\n `expected shape=${expectedShape}, received shape=${\n value.shape}`);\n }\n this.states[index] = value;\n }\n }\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n // TODO(cais): Figure out whether initialState is in kwargs or inputs.\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n // If any of `initial_state` or `constants` are specified and are\n // `SymbolicTensor`s, then add them to the inputs and temporarily modify the\n // input_spec to include them.\n\n let additionalInputs: Array = [];\n let additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n kwargs['initialState'] = initialState;\n additionalInputs = additionalInputs.concat(initialState);\n this.stateSpec = [];\n for (const state of initialState) {\n this.stateSpec.push(new InputSpec({shape: state.shape}));\n }\n // TODO(cais): Use the following instead.\n // this.stateSpec = initialState.map(state => new InputSpec({shape:\n // state.shape}));\n additionalSpecs = additionalSpecs.concat(this.stateSpec);\n }\n if (constants != null) {\n kwargs['constants'] = constants;\n additionalInputs = additionalInputs.concat(constants);\n // TODO(cais): Add this.constantsSpec.\n this.numConstants = constants.length;\n }\n\n const isTensor = additionalInputs[0] instanceof SymbolicTensor;\n if (isTensor) {\n // Compute full input spec, including state and constants.\n const fullInput =\n [inputs].concat(additionalInputs) as Tensor[] | SymbolicTensor[];\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call with temporarily replaced inputSpec.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output = super.apply(fullInput, kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n // tslint:disable-next-line:no-any\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n // Input shape: `[samples, time (padded with zeros), input_dim]`.\n // Note that the .build() method of subclasses **must** define\n // this.inputSpec and this.stateSpec owith complete input shapes.\n return tidy(() => {\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n let initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n\n inputs = getExactlyOneTensor(inputs);\n if (initialState == null) {\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet.');\n } else {\n initialState = this.getInitialState(inputs);\n }\n }\n\n if (mask != null) {\n throw new NotImplementedError('Masking is not implemented for RNN yet');\n }\n\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n if (initialState.length !== numStates) {\n throw new ValueError(\n `RNN Layer has ${numStates} state(s) but was passed ` +\n `${initialState.length} initial state(s).`);\n }\n const inputShape = inputs.shape;\n const timesteps = inputShape[1];\n if (this.unroll) {\n console.warn(\n 'Ignoring unroll = true for RNN layer, due to imperative backend.');\n }\n\n const cellCallKwargs: Kwargs = {training};\n\n // TODO(cais): Add support for constants.\n const step = (inputs: Tensor, states: Tensor[]) => {\n // `inputs` and `states` are concatenated to form a single `Array` of\n // `Tensor`s as the input to `cell.call()`.\n const outputs =\n this.cell.call([inputs].concat(states), cellCallKwargs) as Tensor[];\n // Marshall the return value into output and new states.\n return [outputs[0], outputs.slice(1)] as [Tensor, Tensor[]];\n };\n\n // TODO(cais): Add support for constants.\n // TODO(cais): Add support for masks.\n\n const rnnOutputs =\n rnn(step, inputs, initialState, this.goBackwards, null, null,\n this.unroll, timesteps);\n const lastOutput = rnnOutputs[0];\n const outputs = rnnOutputs[1];\n const states = rnnOutputs[2];\n\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n }\n\n const output = this.returnSequences ? outputs : lastOutput;\n\n // TODO(cais): Porperty set learning phase flag.\n\n if (this.returnState) {\n return [output].concat(states);\n } else {\n return output;\n }\n });\n }\n\n getInitialState(inputs: Tensor): Tensor[] {\n return tidy(() => {\n // Build an all-zero tensor of shape [samples, outputDim].\n // [Samples, timeSteps, inputDim].\n let initialState = tfc.zeros(inputs.shape);\n // [Samples].\n initialState = tfc.sum(initialState, [1, 2]);\n initialState = K.expandDims(initialState); // [Samples, 1].\n\n if (Array.isArray(this.cell.stateSize)) {\n return this.cell.stateSize.map(\n dim => dim > 1 ? K.tile(initialState, [1, dim]) : initialState);\n } else {\n return this.cell.stateSize > 1 ?\n [K.tile(initialState, [1, this.cell.stateSize])] :\n [initialState];\n }\n });\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n return this.cell.trainableWeights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n if (!this.trainable) {\n return this.cell.weights;\n }\n return this.cell.nonTrainableWeights;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n returnSequences: this.returnSequences,\n returnState: this.returnState,\n goBackwards: this.goBackwards,\n stateful: this.stateful,\n unroll: this.unroll,\n };\n if (this.numConstants != null) {\n config.numConstants = this.numConstants;\n }\n const cellConfig = this.cell.getConfig();\n config.cell = {\n className: this.cell.getClassName(),\n config: cellConfig,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RNN);\n\n/**\n * An RNNCell layer.\n */\n// Porting Note: This is a common parent class for RNN cells. There is no\n// equivalent of this in PyKeras. Having a common parent class forgoes the\n// need for `has_attr(cell, ...)` checks or its TypeScript equivalent.\n/** @doc {heading: 'Layers', subheading: 'Classes'} */\nexport abstract class RNNCell extends Layer {\n /**\n * Size(s) of the states.\n * For RNN cells with only a single state, this is a single integer.\n */\n public stateSize: number|number[];\n public dropoutMask: Tensor|Tensor[];\n public recurrentDropoutMask: Tensor|Tensor[];\n}\n\nexport interface SimpleRNNCellLayerConfig extends LayerConfig {\n /**\n * units: Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n * Default: hyperbolic tangent ('tanh').\n * If you pass `null`, 'linear' activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the `kernel` weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the `recurrent_kernel` weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the `kernel` weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the `recurrentKernel` weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraintfunction applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Cell class for `SimpleRNN`.\n *\n * `SimpleRNNCell` is distinct from the `RNN` subclass `SimpleRNN` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `SimpleRNN` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.simpleRNNCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `SimpleRNNCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.simpleRNNCell({units: 4}),\n * tf.layers.simpleRNNCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `SimpleRNNCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `SimpleRNNCell`, use the\n * `tf.layers.simpleRNN`.\n */\nexport class SimpleRNNCell extends RNNCell {\n static className = 'SimpleRNNCell';\n readonly units: number;\n readonly activation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(config: SimpleRNNCellLayerConfig) {\n super(config);\n this.units = config.units;\n this.activation = getActivation(\n config.activation == null ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n // TODO(cais): Use regularizer.\n this.kernel = this.addWeight(\n 'kernel', [inputShape[inputShape.length - 1], this.units], null,\n this.kernelInitializer, this.kernelRegularizer, true,\n this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n // Porting Note: PyKeras' equivalent of this method takes two tensor inputs:\n // `inputs` and `states`. Here, the two tensors are combined into an\n // `Tensor[]` Array as the first input argument.\n // Similarly, PyKeras' equivalent of this method returns two values:\n // `output` and `[output]`. Here the two are combined into one length-2\n // `Tensor[]`, consisting of `output` repeated.\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `SimpleRNNCell expects 2 input Tensors, got ${inputs.length}.`);\n }\n let prevOutput = inputs[1];\n inputs = inputs[0];\n const training = kwargs['training'] == null ? false : kwargs['training'];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training) as Tensor;\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(prevOutput), this.recurrentDropout,\n training) as Tensor;\n }\n let h: Tensor;\n const dpMask: Tensor = this.dropoutMask as Tensor;\n const recDpMask: Tensor = this.recurrentDropoutMask as Tensor;\n if (dpMask != null) {\n h = K.dot(tfc.mul(inputs, dpMask), this.kernel.read());\n } else {\n h = K.dot(inputs, this.kernel.read());\n }\n if (this.bias != null) {\n h = K.biasAdd(h, this.bias.read());\n }\n if (recDpMask != null) {\n prevOutput = tfc.mul(prevOutput, recDpMask);\n }\n let output = tfc.add(h, K.dot(prevOutput, this.recurrentKernel.read()));\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n // TODO(cais): Properly set learning phase on output tensor?\n return [output, output];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNNCell);\n\nexport interface SimpleRNNLayerConfig extends BaseRNNLayerConfig {\n /**\n * Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n *\n * Defaults to hyperbolic tangent (`tanh`)\n *\n * If you pass `null`, no activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the recurrentKernel weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the kernel weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the recurrentKernel weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Fully-connected RNN where the output is to be fed back to input.\n *\n * This is an `RNN` layer consisting of one `SimpleRNNCell`. However, unlike\n * the underlying `SimpleRNNCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.simpleRNN({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `SimpleRNNCell`'s number of units.\n * ```\n */\nexport class SimpleRNN extends RNN {\n static className = 'SimpleRNN';\n constructor(config: SimpleRNNLayerConfig) {\n config.cell = new SimpleRNNCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n // TODO(cais): Research possibility of refactoring out the tedious all\n // the getters that delegate to `this.cell` below.\n get units(): number {\n return (this.cell as SimpleRNNCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as SimpleRNNCell).activation;\n }\n\n get useBias(): boolean {\n return (this.cell as SimpleRNNCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as SimpleRNNCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as SimpleRNNCell).recurrentDropout;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNN);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface GRUCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Cell class for `GRU`.\n *\n * `GRUCell` is distinct from the `RNN` subclass `GRU` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `GRU` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.gruCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `GRUCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.gruCell({units: 4}),\n * tf.layers.gruCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `gruCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `GRUCell`, use the\n * `tf.layers.gru`.\n */\nexport class GRUCell extends RNNCell {\n static className = 'GRUCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: GRUCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 3], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 3], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units * 3], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `GRUCell expects 2 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n\n const training = kwargs['training'] == null ? false : kwargs['training'];\n let hTMinus1 = inputs[1]; // Previous memory state.\n inputs = inputs[0];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 3) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 3) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor];\n const recDpMask = this.recurrentDropoutMask as [Tensor, Tensor, Tensor];\n let z: Tensor;\n let r: Tensor;\n let hh: Tensor;\n if (this.implementation === 1) {\n const kernelZ = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelR =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelH = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const recurrentKernelZ =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelR = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelH = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n\n let inputsZ: Tensor, inputsR: Tensor, inputsH: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsZ = tfc.mul(inputs, dpMask[0]);\n inputsR = tfc.mul(inputs, dpMask[1]);\n inputsH = tfc.mul(inputs, dpMask[2]);\n } else {\n inputsZ = inputs;\n inputsR = inputs;\n inputsH = inputs;\n }\n\n let xZ = K.dot(inputsZ, kernelZ);\n let xR = K.dot(inputsR, kernelR);\n let xH = K.dot(inputsH, kernelH);\n if (this.useBias) {\n const biasZ = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasR =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasH = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n xZ = K.biasAdd(xZ, biasZ);\n xR = K.biasAdd(xR, biasR);\n xH = K.biasAdd(xH, biasH);\n }\n\n let hTMinus1Z: Tensor;\n let hTMinus1R: Tensor;\n let hTMinus1H: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1Z = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1R = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1H = tfc.mul(hTMinus1, recDpMask[2]);\n } else {\n hTMinus1Z = hTMinus1;\n hTMinus1R = hTMinus1;\n hTMinus1H = hTMinus1;\n }\n z = this.recurrentActivation.apply(\n tfc.add(xZ, K.dot(hTMinus1Z, recurrentKernelZ)));\n r = this.recurrentActivation.apply(\n tfc.add(xR, K.dot(hTMinus1R, recurrentKernelR)));\n hh = this.activation.apply(\n tfc.add(xH, K.dot(tfc.mul(r, hTMinus1H), recurrentKernelH)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let matrixX = K.dot(inputs, this.kernel.read());\n if (this.useBias) {\n matrixX = K.biasAdd(matrixX, this.bias.read());\n }\n if (0 < this.dropout && this.dropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n const matrixInner = K.dot(\n hTMinus1,\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 0, 2 * this.units));\n\n const xZ = K.sliceAlongLastAxis(matrixX, 0, this.units);\n const xR = K.sliceAlongLastAxis(matrixX, this.units, this.units);\n const recurrentZ = K.sliceAlongLastAxis(matrixInner, 0, this.units);\n const recurrentR =\n K.sliceAlongLastAxis(matrixInner, this.units, this.units);\n\n z = this.recurrentActivation.apply(tfc.add(xZ, recurrentZ));\n r = this.recurrentActivation.apply(tfc.add(xR, recurrentR));\n\n const xH = K.sliceAlongLastAxis(matrixX, 2 * this.units, this.units);\n const recurrentH = K.dot(\n tfc.mul(r, hTMinus1),\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 2 * this.units, this.units));\n hh = this.activation.apply(tfc.add(xH, recurrentH));\n }\n\n const h = tfc.add(\n tfc.mul(z, hTMinus1), tfc.mul(tfc.add(getScalar(1), tfc.neg(z)), hh));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(GRUCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface GRULayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Gated Recurrent Unit - Cho et al. 2014.\n *\n * This is an `RNN` layer consisting of one `GRUCell`. However, unlike\n * the underlying `GRUCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.gru({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `GRUCell`'s number of units.\n */\nexport class GRU extends RNN {\n static className = 'GRU';\n constructor(config: GRULayerConfig) {\n if (config.implementation === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new GRUCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as GRUCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as GRUCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as GRUCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as GRUCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as GRUCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as GRUCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as GRUCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as GRUCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as GRUCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as GRUCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as GRUCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as GRUCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as GRUCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as GRUCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as GRUCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as GRUCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(GRU);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface LSTMCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: ActivationIdentifier;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Cell class for `LSTM`.\n *\n * `LSTMCell` is distinct from the `RNN` subclass `LSTM` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `LSTM` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.lstmCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `LSTMCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.lstmCell({units: 4}),\n * tf.layers.lstmCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `lstmCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `LSTMCell`, use the\n * `tf.layers.lstm`.\n */\nexport class LSTMCell extends RNNCell {\n static className = 'LSTMCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n readonly unitForgetBias: boolean;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number[];\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n\n readonly DEFAULT_BIAS_INITIALIZER = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: LSTMCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.unitForgetBias = config.unitForgetBias;\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = [this.units, this.units];\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 4], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 4], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n let biasInitializer: Initializer;\n if (this.useBias) {\n if (this.unitForgetBias) {\n const capturedBiasInit = this.biasInitializer;\n const capturedUnits = this.units;\n biasInitializer = new (class CustomInit extends Initializer {\n static className = 'CustomInit';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n // TODO(cais): More informative variable names?\n const bI = capturedBiasInit.apply([capturedUnits]);\n const bF = (new Ones()).apply([capturedUnits]);\n const bCAndH = capturedBiasInit.apply([capturedUnits * 2]);\n return K.concatAlongFirstAxis(\n K.concatAlongFirstAxis(bI, bF), bCAndH);\n }\n })();\n } else {\n biasInitializer = this.biasInitializer;\n }\n this.bias = this.addWeight(\n 'bias', [this.units * 4], null, biasInitializer, this.biasRegularizer,\n true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n inputs = inputs as Tensor[];\n if (inputs.length !== 3) {\n throw new ValueError(\n `LSTMCell expects 3 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n let hTMinus1 = inputs[1]; // Previous memory state.\n const cTMinus1 = inputs[2]; // Previous carry state.\n inputs = inputs[0];\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 4) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 4) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor, Tensor];\n const recDpMask =\n this.recurrentDropoutMask as [Tensor, Tensor, Tensor, Tensor];\n\n let i: Tensor;\n let f: Tensor;\n let c: Tensor;\n let o: Tensor;\n if (this.implementation === 1) {\n const kernelI = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelF =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelC = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const kernelO = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 3, this.units);\n const recurrentKernelI =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelF = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelC = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n const recurrentKernelO = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 3, this.units);\n\n let inputsI: Tensor, inputsF: Tensor, inputsC: Tensor, inputsO: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsI = tfc.mul(inputs, dpMask[0]);\n inputsF = tfc.mul(inputs, dpMask[1]);\n inputsC = tfc.mul(inputs, dpMask[2]);\n inputsO = tfc.mul(inputs, dpMask[3]);\n } else {\n inputsI = inputs;\n inputsF = inputs;\n inputsC = inputs;\n inputsO = inputs;\n }\n\n let xI = K.dot(inputsI, kernelI);\n let xF = K.dot(inputsF, kernelF);\n let xC = K.dot(inputsC, kernelC);\n let xO = K.dot(inputsO, kernelO);\n if (this.useBias) {\n const biasI = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasF =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasC = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n const biasO = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 3, this.units);\n xI = K.biasAdd(xI, biasI);\n xF = K.biasAdd(xF, biasF);\n xC = K.biasAdd(xC, biasC);\n xO = K.biasAdd(xO, biasO);\n }\n\n let hTMinus1I: Tensor, hTMinus1F: Tensor, hTMinus1C: Tensor,\n hTMinus1O: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1I = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1F = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1C = tfc.mul(hTMinus1, recDpMask[2]);\n hTMinus1O = tfc.mul(hTMinus1, recDpMask[3]);\n } else {\n hTMinus1I = hTMinus1;\n hTMinus1F = hTMinus1;\n hTMinus1C = hTMinus1;\n hTMinus1O = hTMinus1;\n }\n i = this.recurrentActivation.apply(\n tfc.add(xI, K.dot(hTMinus1I, recurrentKernelI)));\n f = this.recurrentActivation.apply(\n tfc.add(xF, K.dot(hTMinus1F, recurrentKernelF)));\n c = tfc.add(\n tfc.mul(f, cTMinus1),\n tfc.mul(\n i,\n this.activation.apply(\n tfc.add(xC, K.dot(hTMinus1C, recurrentKernelC)))));\n o = this.recurrentActivation.apply(\n tfc.add(xO, K.dot(hTMinus1O, recurrentKernelO)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let z = K.dot(inputs, this.kernel.read());\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n z = tfc.add(z, K.dot(hTMinus1, this.recurrentKernel.read()));\n if (this.useBias) {\n z = K.biasAdd(z, this.bias.read());\n }\n\n const z0 = K.sliceAlongLastAxis(z, 0, this.units);\n const z1 = K.sliceAlongLastAxis(z, this.units, this.units);\n const z2 = K.sliceAlongLastAxis(z, this.units * 2, this.units);\n const z3 = K.sliceAlongLastAxis(z, this.units * 3, this.units);\n\n i = this.recurrentActivation.apply(z0);\n f = this.recurrentActivation.apply(z1);\n c = tfc.add(\n tfc.mul(f, cTMinus1), tfc.mul(i, this.activation.apply(z2)));\n o = this.recurrentActivation.apply(z3);\n }\n\n const h = tfc.mul(o, this.activation.apply(c));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h, c];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LSTMCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface LSTMLayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions, whereas mode 2 will\n * batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Long-Short Term Memory layer - Hochreiter 1997.\n *\n * This is an `RNN` layer consisting of one `LSTMCell`. However, unlike\n * the underlying `LSTMCell`, the `apply` method of `LSTM` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const lstm = tf.layers.lstm({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = lstm.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `LSTMCell`'s number of units.\n */\nexport class LSTM extends RNN {\n static className = 'LSTM';\n constructor(config: LSTMLayerConfig) {\n if (config.implementation as number === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new LSTMCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as LSTMCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as LSTMCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as LSTMCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as LSTMCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as LSTMCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as LSTMCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as LSTMCell).biasInitializer;\n }\n\n get unitForgetBias(): boolean {\n return (this.cell as LSTMCell).unitForgetBias;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as LSTMCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as LSTMCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as LSTMCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as LSTMCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as LSTMCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as LSTMCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as LSTMCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as LSTMCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as LSTMCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(LSTM);\n\nexport interface StackedRNNCellsConfig extends LayerConfig {\n /**\n * A `Array` of `RNNCell` instances.\n */\n cells: RNNCell[];\n}\n\n/**\n * Wrapper allowing a stack of RNN cells to behave as a single cell.\n *\n * Used to implement efficient stacked RNNs.\n */\nexport class StackedRNNCells extends RNNCell {\n static className = 'StackedRNNCells';\n protected cells: RNNCell[];\n\n constructor(config: StackedRNNCellsConfig) {\n super(config);\n this.cells = config.cells;\n }\n\n get stateSize(): number[] {\n // States are a flat list in reverse order of the cell stack.\n // This allows perserving the requirement `stack.statesize[0] ===\n // outputDim`. E.g., states of a 2-layer LSTM would be `[h2, c2, h1, c1]`,\n // assuming one LSTM has states `[h, c]`.\n const stateSize: number[] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n stateSize.push(...cell.stateSize);\n } else {\n stateSize.push(cell.stateSize);\n }\n }\n return stateSize;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n let states = inputs.slice(1);\n\n // Recover per-cell states.\n const nestedStates: Tensor[][] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n nestedStates.push(states.splice(0, cell.stateSize.length));\n } else {\n nestedStates.push(states.splice(0, 1));\n }\n }\n nestedStates.reverse();\n\n // Call the cells in order and store the returned states.\n const newNestedStates: Tensor[][] = [];\n let callInputs: Tensor[];\n for (let i = 0; i < this.cells.length; ++i) {\n const cell = this.cells[i];\n states = nestedStates[i];\n // TODO(cais): Take care of constants.\n if (i === 0) {\n callInputs = [inputs[0]].concat(states);\n } else {\n callInputs = [callInputs[0]].concat(states);\n }\n callInputs = cell.call(callInputs, kwargs) as Tensor[];\n newNestedStates.push(callInputs.slice(1));\n }\n\n // Format the new states as a flat list in reverse cell order.\n states = [];\n for (const cellStates of newNestedStates.slice().reverse()) {\n states.push(...cellStates);\n }\n return [callInputs[0]].concat(states);\n });\n }\n\n public build(inputShape: Shape|Shape[]): void {\n if (isArrayOfShapes(inputShape)) {\n // TODO(cais): Take care of input constants.\n // const constantShape = inputShape.slice(1);\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n let outputDim: number;\n for (const cell of this.cells) {\n // TODO(cais): Take care of input constants.\n cell.build(inputShape);\n if (Array.isArray(cell.stateSize)) {\n outputDim = cell.stateSize[0];\n } else {\n outputDim = cell.stateSize;\n }\n inputShape = [inputShape[0], outputDim];\n }\n this.built = true;\n }\n\n getConfig(): serialization.ConfigDict {\n const cellConfigs: serialization.ConfigDict[] = [];\n for (const cell of this.cells) {\n cellConfigs.push({\n 'className': this.getClassName(),\n 'config': cell.getConfig(),\n });\n }\n const config: serialization.ConfigDict = {'cells': cellConfigs};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const cells: RNNCell[] = [];\n for (const cellConfig of (config['cells'] as serialization.ConfigDict[])) {\n cells.push(deserialize(cellConfig, customObjects) as RNNCell);\n }\n return new cls({cells});\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const cell of this.cells) {\n trainableWeights.push(...cell.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n /**\n * Retrieve the weights of a the model.\n *\n * @returns A flat `Array` of `Tensor`s.\n */\n getWeights(): Tensor[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.weights);\n }\n return batchGetValue(weights);\n }\n\n /**\n * Set the weights of the model.\n *\n * @param weights An `Array` of `Tensor`s with shapes and types matching the\n * output of `getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n const tuples: Array<[LayerVariable, Tensor]> = [];\n for (const cell of this.cells) {\n const numParams = cell.weights.length;\n const inputWeights = weights.splice(numParams);\n for (let i = 0; i < cell.weights.length; ++i) {\n tuples.push([cell.weights[i], inputWeights[i]]);\n }\n }\n batchSetValue(tuples);\n }\n\n // TODO(cais): Maybe implemnt `losses` and `getLossesFor`.\n}\nserialization.SerializationMap.register(StackedRNNCells);\n\nfunction generateDropoutMask(\n ones: () => Tensor, rate: number, training: boolean = null,\n count = 1): Tensor|Tensor[] {\n function droppedInputs(): Tensor {\n return K.dropout(ones(), getScalar(rate));\n }\n if (count > 1) {\n const mask: Tensor[] = [];\n for (let i = 0; i < count; i++) {\n mask.push(K.inTrainPhase(droppedInputs, ones, training));\n }\n mask.forEach(m => tfc.keep(m));\n return mask;\n } else {\n return tfc.keep(K.inTrainPhase(droppedInputs, ones, training));\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Layers that augment the functionality of a base layer.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {nameScope} from '../common';\nimport {InputSpec, Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {RegularizerFn, RnnStepFunction} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {rnn, RNN, standardizeArgs} from './recurrent';\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\nexport interface WrapperLayerConfig extends LayerConfig {\n /**\n * The layer to be wrapped.\n */\n layer: Layer;\n}\n\n/**\n * Abstract wrapper base class.\n *\n * Wrappers take another layer and augment it in various ways.\n * Do not use this class as a layer, it is only an abstract base class.\n * Two usable wrappers are the `TimeDistributed` and `Bidirectional` wrappers.\n */\nexport abstract class Wrapper extends Layer {\n readonly layer: Layer;\n\n constructor(config: WrapperLayerConfig) {\n // Porting Note: In PyKeras, `self.layer` is set prior to the calling\n // `super()`. But we can't do that here due to TypeScript's restriction.\n // See: https://github.com/Microsoft/TypeScript/issues/8277\n // As a result, we have to add checks in `get trainable()` and\n // `set trainable()` below in order to prevent using `this.layer` when\n // its value is `undefined`. The super constructor does use the getter\n // and the setter of `this.layer`.\n super(config);\n this.layer = config.layer;\n }\n\n build(inputShape: Shape|Shape[]): void {\n this.built = true;\n }\n\n // TODO(cais): Implement activityRegularizer getter.\n\n get trainable(): boolean {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n return this.layer.trainable;\n } else {\n return false;\n }\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n this.layer.trainable = value;\n }\n }\n\n get trainableWeights(): LayerVariable[] {\n return this.layer.trainableWeights;\n }\n // TODO(cais): Implement setter for trainableWeights.\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.layer.nonTrainableWeights;\n }\n // TODO(cais): Implement setter for nonTrainableWeights.\n\n get updates(): Tensor[] {\n // tslint:disable-next-line:no-any\n return (this.layer as any)._updates;\n }\n\n // TODO(cais): Implement getUpdatesFor().\n\n get losses(): RegularizerFn[] {\n return this.layer.losses;\n }\n\n // TODO(cais): Implement getLossesFor().\n\n getWeights(): Tensor[] {\n return this.layer.getWeights();\n }\n\n setWeights(weights: Tensor[]): void {\n this.layer.setWeights(weights);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'layer': {\n 'className': this.layer.getClassName(),\n 'config': this.layer.getConfig(),\n }\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const layerConfig = config['layer'] as serialization.ConfigDict;\n const layer = deserialize(layerConfig, customObjects) as Layer;\n delete config['layer'];\n const newConfig = {layer};\n Object.assign(newConfig, config);\n return new cls(newConfig);\n }\n}\n\n/**\n * This wrapper applies a layer to every temporal slice of an input.\n *\n * The input should be at least 3D, and the dimension of the index `1` will be\n * considered to be the temporal dimension.\n *\n * Consider a batch of 32 samples, where each sample is a sequence of 10 vectors\n * of 16 dimensions. The batch input shape of the layer is then `[32, 10,\n * 16]`, and the `inputShape`, not including the sample dimension, is\n * `[10, 16]`.\n *\n * You can then use `TimeDistributed` to apply a `Dense` layer to each of the 10\n * timesteps, independently:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.dense({units: 8}),\n * inputShape: [10, 16],\n * }));\n *\n * // Now model.outputShape = [null, 10, 8].\n * // The output will then have shape `[32, 10, 8]`.\n *\n * // In subsequent layers, there is no need for `inputShape`:\n * model.add(tf.layers.timeDistributed({layer: tf.layers.dense({units: 32})}));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * // Now model.outputShape = [null, 10, 32].\n * ```\n *\n * The output will then have shape `[32, 10, 32]`.\n *\n * `TimeDistributed` can be used with arbitrary layers, not just `Dense`, for\n * instance a `Conv2D` layer.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.conv2d({filters: 64, kernelSize: [3, 3]}),\n * inputShape: [10, 299, 299, 3],\n * }));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\nexport class TimeDistributed extends Wrapper {\n static className = 'TimeDistributed';\n constructor(config: WrapperLayerConfig) {\n super(config);\n this.supportsMasking = true;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 3) {\n throw new ValueError(\n `TimeDistributed layer expects an input shape >= 3D, but received ` +\n `input shape ${JSON.stringify(inputShape)}`);\n }\n this.inputSpec = [{shape: inputShape}];\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (!this.layer.built) {\n this.layer.build(childInputShape);\n this.layer.built = true;\n }\n super.build(inputShape);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n const childOutputShape =\n this.layer.computeOutputShape(childInputShape) as Shape;\n const timesteps = inputShape[1];\n return [childOutputShape[0], timesteps].concat(childOutputShape.slice(1));\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n // TODO(cais): Add 'training' and 'useLearningPhase' to kwargs.\n inputs = getExactlyOneTensor(inputs);\n // Porting Note: In tfjs-layers, `inputs` are always concrete tensor\n // values. Hence the inputs can't have an undetermined first (batch)\n // dimension, which is why we always use the K.rnn approach here.\n const step: RnnStepFunction = (inputs: Tensor, states: Tensor[]) => {\n // TODO(cais): Add useLearningPhase.\n const output = this.layer.call(inputs, kwargs) as Tensor;\n return [output, []];\n };\n const rnnOutputs =\n rnn(step, inputs, [], false, null, null, false, inputs.shape[1]);\n const y = rnnOutputs[1];\n // TODO(cais): Add activity regularization.\n // TODO(cais): Add useLearningPhase.\n return y;\n });\n }\n}\nserialization.SerializationMap.register(TimeDistributed);\n\nexport type BidirectionalMergeMode = 'sum'|'mul'|'concat'|'ave';\nexport const VALID_BIDIRECTIONAL_MERGE_MODES = ['sum', 'mul', 'concat', 'ave'];\nexport function checkBidirectionalMergeMode(value?: string): void {\n generic_utils.checkStringTypeUnionValue(\n VALID_BIDIRECTIONAL_MERGE_MODES, 'BidirectionalMergeMode', value);\n}\n\nexport interface BidirectionalLayerConfig extends WrapperLayerConfig {\n /**\n * The instance of an `RNN` layer to be wrapped.\n */\n layer: RNN;\n\n /**\n * Mode by which outputs of the forward and backward RNNs are combinied.\n * If `null` or `undefined`, the output will not be combined, they will be\n * returned as an `Array`.\n */\n mergeMode?: BidirectionalMergeMode;\n}\n\nexport class Bidirectional extends Wrapper {\n static className = 'Bidirectional';\n private forwardLayer: RNN;\n private backwardLayer: RNN;\n private mergeMode: BidirectionalMergeMode;\n private returnSequences: boolean;\n private returnState: boolean;\n private numConstants?: number;\n private _trainable: boolean;\n\n constructor(config: BidirectionalLayerConfig) {\n super(config);\n\n // Note: When creating `this.forwardLayer`, the original Layer object\n // (`config.layer`) ought to be cloned. This is why we call `getConfig()`\n // followed by `deserialize()`. Without this cloning, the layer names\n // saved during serialization will incorrectly contain the 'forward_'\n // prefix.\n // In Python Keras, this is done using `copy.copy` (shallow copy), which\n // does not have a simple equivalent in JavaScript. JavaScript's\n // `Object.assign()` does not copy methods.\n const layerConfig = config.layer.getConfig();\n this.forwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n layerConfig['goBackwards'] =\n layerConfig['goBackwards'] === true ? false : true;\n this.backwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n this.forwardLayer.name = 'forward_' + this.forwardLayer.name;\n this.backwardLayer.name = 'backward_' + this.backwardLayer.name;\n checkBidirectionalMergeMode(config.mergeMode);\n this.mergeMode = config.mergeMode;\n if (config.weights) {\n throw new NotImplementedError(\n 'weights support is not implemented for Bidirectional layer yet.');\n }\n this._stateful = config.layer.stateful;\n this.returnSequences = config.layer.returnSequences;\n this.returnState = config.layer.returnState;\n this.supportsMasking = true;\n this._trainable = true;\n this.inputSpec = config.layer.inputSpec;\n this.numConstants = null;\n }\n\n get trainable(): boolean {\n return this._trainable;\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n this._trainable = value;\n if (this.forwardLayer != null) {\n this.forwardLayer.trainable = value;\n }\n if (this.backwardLayer != null) {\n this.backwardLayer.trainable = value;\n }\n }\n\n getWeights(): Tensor[] {\n return this.forwardLayer.getWeights().concat(\n this.backwardLayer.getWeights());\n }\n\n setWeights(weights: Tensor[]): void {\n const numWeights = weights.length;\n const numeightsOver2 = Math.floor(numWeights / 2);\n this.forwardLayer.setWeights(weights.slice(0, numeightsOver2));\n this.backwardLayer.setWeights(weights.slice(numeightsOver2));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n let layerShapes: Shape|Shape[] =\n this.forwardLayer.computeOutputShape(inputShape);\n if (!(Array.isArray(layerShapes) && Array.isArray(layerShapes[0]))) {\n layerShapes = [layerShapes as Shape];\n }\n layerShapes = layerShapes as Shape[];\n\n let outputShape: Shape;\n let outputShapes: Shape[];\n let stateShape: Shape[];\n if (this.returnState) {\n stateShape = layerShapes.slice(1);\n outputShape = layerShapes[0];\n } else {\n outputShape = layerShapes[0];\n }\n outputShape = outputShape as Shape;\n if (this.mergeMode === 'concat') {\n outputShape[outputShape.length - 1] *= 2;\n outputShapes = [outputShape];\n } else if (this.mergeMode == null) {\n outputShapes = [outputShape, outputShape.slice()];\n } else {\n outputShapes = [outputShape];\n }\n\n if (this.returnState) {\n if (this.mergeMode == null) {\n return outputShapes.concat(stateShape).concat(stateShape.slice());\n }\n return [outputShape].concat(stateShape).concat(stateShape.slice());\n }\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs as Tensor | SymbolicTensor;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n if (Array.isArray(inputs)) {\n initialState = (inputs as Tensor[] | SymbolicTensor[]).slice(1);\n inputs = (inputs as Tensor[] | SymbolicTensor[])[0];\n }\n\n if ((initialState == null || initialState.length === 0) &&\n constants == null) {\n return super.apply(inputs, kwargs);\n }\n const additionalInputs: Array = [];\n const additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n const numStates = initialState.length;\n if (numStates % 2 > 0) {\n throw new ValueError(\n 'When passing `initialState` to a Bidrectional RNN, ' +\n 'the state should be an Array containing the states of ' +\n 'the underlying RNNs.');\n }\n kwargs['initialState'] = initialState;\n additionalInputs.push(...initialState);\n const stateSpecs = (initialState as Array)\n .map(state => new InputSpec({shape: state.shape}));\n this.forwardLayer.stateSpec = stateSpecs.slice(0, numStates / 2);\n this.backwardLayer.stateSpec = stateSpecs.slice(numStates / 2);\n additionalSpecs.push(...stateSpecs);\n }\n if (constants != null) {\n throw new NotImplementedError(\n 'Support for constants in Bidirectional layers is not ' +\n 'implemented yet.');\n }\n\n const isSymbolicTensor = additionalInputs[0] instanceof SymbolicTensor;\n for (const tensor of additionalInputs) {\n if (tensor instanceof SymbolicTensor !== isSymbolicTensor) {\n throw new ValueError(\n 'The initial state of a Bidirectional layer cannot be ' +\n 'specified as a mix of symbolic and non-symbolic tensors');\n }\n }\n\n if (isSymbolicTensor) {\n // Compute the full input and specs, including the states.\n const fullInput = [inputs].concat(additionalInputs);\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call temporarily and replace inputSpec.\n // Note: with initial states symbolic calls and non-symbolic calls to this\n // method differ in how the initial states are passed. For symbolic calls,\n // the initial states are passed in the first arg, as an Array of\n // SymbolicTensors; for non-symbolic calls, they are passed in the second\n // arg as a part of the kwargs. Hence the need to temporarily modify\n // inputSpec here.\n // TODO(cais): Make refactoring so that this hacky code below is no\n // longer needed.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output =\n super.apply(fullInput as Tensor[] | SymbolicTensor[], kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (kwargs['mask'] != null) {\n throw new NotImplementedError(\n 'The support for masking is not implemented for ' +\n 'Bidirectional layers yet.');\n }\n const initialState = kwargs['initialState'];\n\n let y: Tensor|Tensor[];\n let yRev: Tensor|Tensor[];\n if (initialState == null) {\n y = this.forwardLayer.call(inputs, kwargs);\n yRev = this.backwardLayer.call(inputs, kwargs);\n } else {\n const forwardState = initialState.slice(0, initialState.length / 2);\n const backwardState = initialState.slice(initialState.length / 2);\n y = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: forwardState}));\n yRev = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: backwardState}));\n }\n\n let states: Tensor[];\n if (this.returnState) {\n if (Array.isArray(y)) {\n states = (y as Tensor[]).slice(1).concat((yRev as Tensor[]).slice(1));\n } else {\n }\n y = (y as Tensor[])[0];\n yRev = (yRev as Tensor[])[0];\n }\n\n if (this.returnSequences) {\n yRev = tfc.reverse(yRev as Tensor, 1);\n }\n\n let output: Tensor|Tensor[];\n if (this.mergeMode === 'concat') {\n output = K.concatenate([y as Tensor, yRev as Tensor]);\n } else if (this.mergeMode === 'sum') {\n output = tfc.add(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode === 'ave') {\n output = tfc.mul(getScalar(0.5), tfc.add(y as Tensor, yRev as Tensor));\n } else if (this.mergeMode === 'mul') {\n output = tfc.mul(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode == null) {\n output = [y as Tensor, yRev as Tensor];\n }\n\n // TODO(cais): Properly set learning phase.\n if (this.returnState) {\n if (this.mergeMode == null) {\n return (output as Tensor[]).concat(states);\n }\n return [output as Tensor].concat(states);\n }\n return output;\n });\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n this.forwardLayer.resetStates();\n this.backwardLayer.resetStates();\n }\n\n build(inputShape: Shape|Shape[]): void {\n nameScope(this.forwardLayer.name, () => {\n this.forwardLayer.build(inputShape);\n });\n nameScope(this.backwardLayer.name, () => {\n this.backwardLayer.build(inputShape);\n });\n this.built = true;\n }\n\n // TODO(cais): Implement computeMask().\n\n get trainableWeights(): LayerVariable[] {\n return this.forwardLayer.trainableWeights.concat(\n this.backwardLayer.trainableWeights);\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.forwardLayer.nonTrainableWeights.concat(\n this.backwardLayer.nonTrainableWeights);\n }\n\n // TODO(cais): Implement constraints().\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'mergeMode': this.mergeMode,\n };\n // TODO(cais): Add logic for `numConstants` once the property is added.\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const rnnLayer =\n deserialize(config['layer'] as serialization.ConfigDict) as RNN;\n delete config['layer'];\n // TODO(cais): Add logic for `numConstants` once the property is added.\n if (config['numConstants'] != null) {\n throw new NotImplementedError(\n `Deserialization of a Bidirectional layer with numConstants ` +\n `present is not supported yet.`);\n }\n // tslint:disable-next-line:no-any\n const newConfig: {[key: string]: any} = config;\n newConfig['layer'] = rnnLayer;\n return new cls(newConfig);\n }\n}\nserialization.SerializationMap.register(Bidirectional);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable:max-line-length\n\nimport {InputLayer, InputLayerConfig} from './engine/input_layer';\nimport {Layer, LayerConfig} from './engine/topology';\nimport {input} from './exports';\nimport {ELU, ELULayerConfig, LeakyReLU, LeakyReLULayerConfig, Softmax, SoftmaxLayerConfig, ThresholdedReLU, ThresholdedReLULayerConfig} from './layers/advanced_activations';\nimport {Conv1D, Conv2D, Conv2DTranspose, ConvLayerConfig, Cropping2D, Cropping2DLayerConfig, SeparableConv2D, SeparableConvLayerConfig, UpSampling2D, UpSampling2DLayerConfig} from './layers/convolutional';\nimport {DepthwiseConv2D, DepthwiseConv2DLayerConfig} from './layers/convolutional_depthwise';\nimport {Activation, ActivationLayerConfig, Dense, DenseLayerConfig, Dropout, DropoutLayerConfig, Flatten, RepeatVector, RepeatVectorLayerConfig, Reshape, ReshapeLayerConfig} from './layers/core';\nimport {Embedding, EmbeddingLayerConfig} from './layers/embeddings';\nimport {Add, Average, Concatenate, ConcatenateLayerConfig, Maximum, Minimum, Multiply} from './layers/merge';\nimport {BatchNormalization, BatchNormalizationLayerConfig} from './layers/normalization';\nimport {ZeroPadding2D, ZeroPadding2DLayerConfig} from './layers/padding';\nimport {AveragePooling1D, AveragePooling2D, GlobalAveragePooling1D, GlobalAveragePooling2D, GlobalMaxPooling1D, GlobalMaxPooling2D, GlobalPooling2DLayerConfig, MaxPooling1D, MaxPooling2D, Pooling1DLayerConfig, Pooling2DLayerConfig} from './layers/pooling';\nimport {GRU, GRUCell, GRUCellLayerConfig, GRULayerConfig, LSTM, LSTMCell, LSTMCellLayerConfig, LSTMLayerConfig, RNN, RNNCell, RNNLayerConfig, SimpleRNN, SimpleRNNCell, SimpleRNNCellLayerConfig, SimpleRNNLayerConfig, StackedRNNCells, StackedRNNCellsConfig} from './layers/recurrent';\nimport {Bidirectional, BidirectionalLayerConfig, TimeDistributed, Wrapper, WrapperLayerConfig} from './layers/wrappers';\n\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Input Layer.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Inputs',\n * namespace: 'layers',\n * useDocsFrom: 'InputLayer',\n * configParamIndices: [0]\n * }\n */\nexport function inputLayer(config: InputLayerConfig): Layer {\n return new InputLayer(config);\n}\n\n// Advanced Activation Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ELU',\n * configParamIndices: [0]\n * }\n */\nexport function elu(config?: ELULayerConfig): Layer {\n return new ELU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'LeakyReLU',\n * configParamIndices: [0]\n * }\n */\nexport function leakyReLU(config?: LeakyReLULayerConfig): Layer {\n return new LeakyReLU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'Softmax',\n * configParamIndices: [0]\n * }\n */\nexport function softmax(config?: SoftmaxLayerConfig): Layer {\n return new Softmax(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ThresholdedReLU',\n * configParamIndices: [0]\n * }\n */\nexport function thresholdedReLU(config?: ThresholdedReLULayerConfig): Layer {\n return new ThresholdedReLU(config);\n}\n\n// Convolutional Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv1D',\n * configParamIndices: [0]\n * }\n */\nexport function conv1d(config: ConvLayerConfig): Layer {\n return new Conv1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2D',\n * configParamIndices: [0]\n * }\n */\nexport function conv2d(config: ConvLayerConfig): Layer {\n return new Conv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2DTranspose',\n * configParamIndices: [0]\n * }\n */\nexport function conv2dTranspose(config: ConvLayerConfig): Layer {\n return new Conv2DTranspose(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'SeparableConv2D',\n * configParamIndices: [0]\n * }\n */\nexport function separableConv2d(config: SeparableConvLayerConfig): Layer {\n return new SeparableConv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Cropping2D',\n * configParamIndices: [0]\n * }\n */\nexport function cropping2D(config: Cropping2DLayerConfig): Layer {\n return new Cropping2D(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'UpSampling2D',\n * configParamIndices: [0]\n * }\n */\nexport function upSampling2d(config: UpSampling2DLayerConfig): Layer {\n return new UpSampling2D(config);\n}\n\n// Convolutional(depthwise) Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'DepthwiseConv2D',\n * configParamIndices: [0]\n * }\n */\n\nexport function depthwiseConv2d(config: DepthwiseConv2DLayerConfig): Layer {\n return new DepthwiseConv2D(config);\n}\n\n// Basic Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Activation',\n * configParamIndices: [0]\n * }\n */\nexport function activation(config: ActivationLayerConfig): Layer {\n return new Activation(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dense',\n * configParamIndices: [0]\n * }\n */\nexport function dense(config: DenseLayerConfig): Layer {\n return new Dense(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dropout',\n * configParamIndices: [0]\n * }\n */\nexport function dropout(config: DropoutLayerConfig): Layer {\n return new Dropout(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Flatten',\n * configParamIndices: [0]\n * }\n */\nexport function flatten(config?: LayerConfig): Layer {\n return new Flatten(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'RepeatVector',\n * configParamIndices: [0]\n * }\n */\nexport function repeatVector(config: RepeatVectorLayerConfig): Layer {\n return new RepeatVector(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Reshape',\n * configParamIndices: [0]\n * }\n */\nexport function reshape(config: ReshapeLayerConfig): Layer {\n return new Reshape(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Embedding',\n * configParamIndices: [0]\n * }\n */\nexport function embedding(config: EmbeddingLayerConfig): Layer {\n return new Embedding(config);\n}\n\n// Merge Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Add',\n * configParamIndices: [0]\n * }\n */\nexport function add(config?: LayerConfig): Layer {\n return new Add(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Average',\n * configParamIndices: [0]\n * }\n */\nexport function average(config?: LayerConfig): Layer {\n return new Average(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Concatenate',\n * configParamIndices: [0]\n * }\n */\nexport function concatenate(config?: ConcatenateLayerConfig): Layer {\n return new Concatenate(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Maximum',\n * configParamIndices: [0]\n * }\n */\nexport function maximum(config?: LayerConfig): Layer {\n return new Maximum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Minimum',\n * configParamIndices: [0]\n * }\n */\nexport function minimum(config?: LayerConfig): Layer {\n return new Minimum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Multiply',\n * configParamIndices: [0]\n * }\n */\nexport function multiply(config?: LayerConfig): Layer {\n return new Multiply(config);\n}\n\n// Normalization Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Normalization',\n * namespace: 'layers',\n * useDocsFrom: 'BatchNormalization',\n * configParamIndices: [0]\n * }\n */\nexport function batchNormalization(config: BatchNormalizationLayerConfig):\n Layer {\n return new BatchNormalization(config);\n}\n\n// Padding Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Padding',\n * namespace: 'layers',\n * useDocsFrom: 'ZeroPadding2D',\n * configParamIndices: [0]\n * }\n */\nexport function zeroPadding2d(config?: ZeroPadding2DLayerConfig): Layer {\n return new ZeroPadding2D(config);\n}\n\n// Pooling Layers.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling1d(config: Pooling1DLayerConfig): Layer {\n return new AveragePooling1D(config);\n}\nexport function avgPool1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling2d(config: Pooling2DLayerConfig): Layer {\n return new AveragePooling2D(config);\n}\nexport function avgPool2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling1d(config: LayerConfig): Layer {\n return new GlobalAveragePooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling2d(config: GlobalPooling2DLayerConfig):\n Layer {\n return new GlobalAveragePooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling1d(config: LayerConfig): Layer {\n return new GlobalMaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling2d(config: GlobalPooling2DLayerConfig): Layer {\n return new GlobalMaxPooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling1d(config: Pooling1DLayerConfig): Layer {\n return new MaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling2d(config: Pooling2DLayerConfig): Layer {\n return new MaxPooling2D(config);\n}\n\n// Recurrent Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRU',\n * configParamIndices: [0]\n * }\n */\nexport function gru(config: GRULayerConfig): Layer {\n return new GRU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRUCell',\n * configParamIndices: [0]\n * }\n */\nexport function gruCell(config: GRUCellLayerConfig): RNNCell {\n return new GRUCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTM',\n * configParamIndices: [0]\n * }\n */\nexport function lstm(config: LSTMLayerConfig): Layer {\n return new LSTM(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTMCell',\n * configParamIndices: [0]\n * }\n */\nexport function lstmCell(config: LSTMCellLayerConfig): RNNCell {\n return new LSTMCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNN',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNN(config: SimpleRNNLayerConfig): Layer {\n return new SimpleRNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNNCell',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNNCell(config: SimpleRNNCellLayerConfig): RNNCell {\n return new SimpleRNNCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function rnn(config: RNNLayerConfig): Layer {\n return new RNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function stackedRNNCells(config: StackedRNNCellsConfig): RNNCell {\n return new StackedRNNCells(config);\n}\n\n// Wrapper Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'Bidirectional',\n * configParamIndices: [0]\n * }\n */\nexport function bidirectional(config: BidirectionalLayerConfig): Wrapper {\n return new Bidirectional(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'TimeDistributed',\n * configParamIndices: [0]\n * }\n */\nexport function timeDistributed(config: WrapperLayerConfig): Layer {\n return new TimeDistributed(config);\n}\n\n// Aliases for pooling.\nexport const globalMaxPool1d = globalMaxPooling1d;\nexport const globalMaxPool2d = globalMaxPooling2d;\nexport const maxPool1d = maxPooling1d;\nexport const maxPool2d = maxPooling2d;\n\nexport {Layer, input /* alias for tf.input */};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport {Tensor} from '@tensorflow/tfjs-core';\n\nimport * as losses from './losses';\nimport * as metrics from './metrics';\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryAccuracy'\n * }\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryCrossentropy'\n * }\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalAccuracy'\n * }\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalCrossentropy'\n * }\n */\nexport function categoricalCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'cosineProximity'\n * }\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.cosineProximity(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsoluteError'\n * }\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsoluteError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsolutePercentageError'\n * }\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function MAPE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function mape(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanSquaredError'\n * }\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function MSE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function mse(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport * as regularizers from './regularizers';\n// tslint:disable-next-line:max-line-length\nimport {L1Config, L1L2, L1L2Config, L2Config, Regularizer} from './regularizers';\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1l2(config?: L1L2Config): Regularizer {\n return new L1L2(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1(config?: L1Config): Regularizer {\n return regularizers.l1(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l2(config?: L2Config): Regularizer {\n return regularizers.l2(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {BaseCallback} from './base_callbacks';\nimport {Container} from './engine/container';\nimport {Model} from './engine/training';\n\nexport abstract class Callback extends BaseCallback {\n /** Instance of `keras.models.Model`. Reference of the model being trained. */\n model: Model = null;\n\n setModel(model: Container): void {\n if (!(model instanceof Model)) {\n throw new Error('model must be a Model, not some other Container');\n }\n this.model = model as Model;\n }\n}\n"],"names":["_epsilon","_nextUniqueTensorId","_uidPrefixes","prefix","toString","scalarCache","float32","int32","DEFAULT_DTYPE","value","dtype","undefined","scalar","keep","message","_super","Object","setPrototypeOf","_this","AttributeError","prototype","tslib_1.__extends","Error","RuntimeError","ValueError","NotImplementedError","AssertionError","IndexError","numValues","Array","isArray","newArray","i","concat","fill","val","array","refernce","counter","array_1","_i","xs","length","x","name","insecure","replace","toLowerCase","identifier","indexOf","m","p1","toUpperCase","_GLOBAL_CUSTOM_OBJECTS","instance","className","getClassName","config","getConfig","moduleObjects","customObjects","printableModuleName","functionName","fn","JSON","stringify","cls","fromConfig","_a","_b","_c","customObjectsCombined","_d","keys","key","_f","_e","backupCustomObjects","_h","_g","returnObj","_k","_j","a","b","numberCompare","out","xs_1","push","obj","hasOwnProperty","values","label","expectedType","minLength","maxLength","assert","every","e","w","axis","tidy","tfc.sqrt","tfc.sum","tfc.mulStrict","Constraint","serialization","Serializable","maxValue","defaultMaxValue","defaultAxis","MaxNorm","norms","calcL2Norms","desired","tfc.clipByValue","tfc.mul","tfc.div","tfc.add","getScalar","epsilon","this","SerializationMap","register","UnitNorm","NonNeg","tfc.relu","minValue","defaultMinValue","rate","defaultRate","MinMaxNorm","CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP","maxNorm","minMaxNorm","nonNeg","unitNorm","constraint","serializeKerasObject","deserializeKerasObject","getMap","classNameMap","deserializeConstraint","nameMap","Map","VALID_DATA_FORMAT_VALUES","checkStringTypeUnionValue","VALID_PADDING_MODE_VALUES","VALID_POOL_MODE_VALUES","_nameScopeStack","_nameScopeDivider","pop","join","tensorName","isValidTensorName","currentNameScopePrefix","scopedName","has","set","index","get","result","tensorNameRegex","RegExp","match","parseInt","begin","end","prod","Float32Array","tensor1d","tfc.min","toArray1D","dataSync","tfc.max","asType","outShape","shape","slice","splice","reshape","n","tile","expandDims","newShape","math_utils.arrayProd","rank","start","size","tfc.slice1d","tfc.slice2d","tfc.slice3d","tfc.slice4d","sliceAlongFirstAxis","sliceAlongLastAxis","tensors","tfc.concat","tfc.concat1d","tfc.concat2d","tfc.concat3d","tfc.concat4d","tfc.tile","mean","stddev","seed","tfc.randomNormal","y","tfc.matMul","xShape0","xShape1","xShape2","reference","indices","toInt","tfc.gather","bias","dataFormat","imageDataFormat","checkDataFormat","biasShape","add","alpha","tfc.elu","tfc.abs","level","noiseShape","util","arraysEqual","multiplier","tfc.step","tfc.neg","tfc.randomUniform","tfc.sub","alt","training","VALID_FAN_MODE_VALUES","VALID_DISTRIBUTION_VALUES","Initializer","Zeros","zeros","Ones","ones","Constant","mul","minval","DEFAULT_MINVAL","maxval","DEFAULT_MAXVAL","RandomUniform","randomUniform","DEFAULT_MEAN","DEFAULT_STDDEV","RandomNormal","K.randomNormal","TruncatedNormal","truncatedNormal","gain","Identity","eye","fanIn","fanOut","receptiveFieldSize","arrayProd","shapeProd","Math","sqrt","scale","mode","checkFanMode","distribution","checkDistribution","VarianceScaling","fans","computeFans","max","limit","GlorotUniform","GlorotNormal","HeNormal","LeCunNormal","DEFAULT_GAIN","Orthogonal","console","warn","q","linalg","gramSchmidt","transpose","INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","constant","glorotNormal","glorotUniform","heNormal","identity","leCunNormal","orthogonal","randomNormal","varianceScaling","initializer","deserializeInitializer","shapes","weights","count","weights_1","weight","reduce","DEFAULT_VARIABLE_NAME_PREFIX","trainable","id","getNextUniqueTensorId","originalName","getScopedTensorName","getUniqueTensorName","tfc.variable","LayerVariable","newVal","checkShapesMatch","assign","apply","map","read","variablesAndValues","variableAndValue","write","ndim","maxNDim","minNDim","axes","sourceLayer","inputs","callArgs","outputTensorIndex","_nextNodeID","outboundLayer","inboundLayers","nodeIndices","tensorIndices","inputTensors","outputTensors","inputMasks","outputMasks","inputShapes","outputShapes","layer","outboundNodes","inboundNodes","Node","inboundNames","_nextLayerID","activityRegularizer","inputSpec","supportsMasking","_trainableWeights","_nonTrainableWeights","_losses","_updates","_built","generic_utils.toSnakeCase","getUid","updatable","inputShape","batchInputShape","batchSize","inputDType","initialWeights","Layer","nodeIndex","attrName","generic_utils.singletonOrArray","getNodeAtIndex","losses","lossFn","built","trainableWeights","nonTrainableWeights","_stateful","generic_utils.toList","inputIndex","spec","xShape","Number","xShapeAtAxis","specDim","dim","kwargs","_callHook","callHook","inputsList","allAreSymbolic","inputsList_1","SymbolicTensor","noneAreSymbolic","inputsList_2","nameScope","assertInputCompatibility","xElem","build","setWeights","outputListCopy","outputList_1","output","call","clone","collectInputShape","outputShape","computeOutputShape","outputDType_1","guessOutputDType","warnOnIncompatibleInputShape","addInboundNode","dimMismatch_1","forEach","dimension","allOutputShapes","node","shapeString","variable_utils.countParamsInWeights","trainableOnly","batchGetValue","params","weightValueTuples","paramValues","pv","p","batchSetValue","regularizer","_addedWeightNames","addLoss","mask","TypeError","maskElement","inputTensorList","types_utils.normalizeShapeList","inputTensorList_1","tensorIndex","inputTensors_1","tensor","sourceTensors","previousSources_1","getSourceInputs","x_1","sparse","inputTensor","InputLayer","batchShape","logs","promises","scalarsToDispose","valueScalar","data","Promise","all","dispose","BaseCallback","epoch","batch","model","callbacks","queueLength","CallbackList","callback","setParams","setModel","onEpochBegin","onEpochEnd","onBatchBegin","onBatchEnd","onTrainBegin","onTrainEnd","BaseLogger","seen","totals","this_1","oldTotalsToDispose","this_2","div","History","history","valueArray","trainBegin","trainEnd","epochBegin","epochEnd","batchBegin","batchEnd","CustomCallback","resolveScalarsInLogs","callbackConfig","squareSum","K.square","epsilonTensor","tfc.onesLike","norm","tfc.maximum","yTrue","yPred","tfc.mean","diff","clippedTrue","MAX_VALUE","absResult","one","clippedPred","firstLog","tfc.log","secondLog","zeroTensor","maxResult","pos","neg","log2","log","predictionDiff","logcoshResult","tfc.softplus","target","fromLogits","tfc.softmax","outputSum","toFloat","flatTarget","tfc.floor","K.flatten","categoricalCrossentropy","tfc.oneHot","maxOutput","tfc.zerosLike","outputXTarget","sigmoidOutput","tfc.exp","sigmoidCrossEntropyWithLogits","logPred","trueNormalized","l2Normalize","predNormalized","trueXPred","identifierOrFn","lossesMap","meanSquaredError","meanAbsoluteError","meanAbsolutePercentageError","meanSquaredLogarithmicError","squaredHinge","hinge","categoricalHinge","logcosh","sparseCategoricalCrossentropy","binaryCrossentropy","kullbackLeiblerDivergence","poisson","cosineProximity","threshold","yPredThresholded","K.cast","tfc.greater","tfc.equal","tfc.argMax","lossBinaryCrossentropy","mse","MSE","mae","MAE","mape","MAPE","categoricalCrossentropyLoss","cosine","sparseCategoricalCrossentropyLoss","metricsMap","binaryAccuracy","categoricalAccuracy","optimizerMap","Adagrad","train","adagrad","Adadelta","adadelta","Adam","adam","Adamax","adamax","RMSProp","rmsprop","SGD","sgd","lineLength","positions","printFn","relevantNodes","sequentialLike","isModelSequentialLike","toDisplay","floor","depth","nodesByDepth","repeat","printRow","trainableCount","layers","printLayerSummary","printLayerSummaryWithConnections","checkTrainableWeightsConsistency","collectedTrainableWeights","countParamsInWeights","nonTrainableCount","nodes","nodesByDepth_1","depthNodes","flag","fields","line","err","countParams","connections","inboundLayer","inboundLayerIndex","inboundTensorIndex","firstConnection","pythonicConfig","generic_utils.toCamelCase","tsArray","arrayLength","item","isArrayItemInputOrOutputName","convertPythonicToTs","tsDict","pythonicKey","pythonicValue","tsKey","tsConfig","pyArray","convertTsToPythonic","pyDict","tsValue","pyKey","version","originalKerasVersion","originalBackend","startsWith","dataType","generic_utils.stringToDType","Tensor","make","flatten","weightsJSON","skipMismatch","layerNames","layers_1","nameToWeights","k","name_1","layerWeights","weightValues","weightEntry","loadTensor","symbolicWeights","preprocessWeightsForLoading","nameToWeight","totalWeightsCount","layers_2","name_2","unsetNames","name_3","Set","outputs","generic_utils.unique","inputLayers","inputLayersNodeIndices","inputLayersTensorIndices","outputLayers","outputLayersNodeIndices","outputLayersTensorIndices","generic_utils.assert","inputNames","outputNames","feedInputShapes","feedInputNames","feedOutputNames","internalInputShapes","internalOutputShapes","nodesDepths","nodeIDToNode","layersDepths","layerIDToLayer","layerIndices","nodesInDecreasingDepth","buildMapOfGraph","finishedNodes","nodesInProgress","containerNodes","Container","nodeKey","numInboundLayers","layer_1","nodeIndex_1","tensorIndex_1","reversedNodesInDecreasingDepth_1","reverse","previousDepth","inboundNode","previousDepth_1","nodeID","layersByDepth","layerID","depthKeys","sort","generic_utils.reverseNumberCompare","depthKeys_1","layersForDepth","aIndex","bIndex","layersForDepth_1","computableTensors","layersWithCompleteInput","depthKeys_2","_l","_o","_m","_q","_p","_s","_r","allNames","name_4","numOccurrences","filter","allNames_1","_t","isNamedTensorMap","loadWeightsFromNamedTensorMap","loadWeightsFromJson","theConfig","kerasVersion","layersVersion","backend","unused","returnString","modelConfig","updatedConfig","masks","generic_utils.pyListRepeat","runInternalGraph","layersToOutputShapes","inputShape_1","shapeKey","depthKeys_3","nodes_1","inputShapes_1","j","nodeIndex_2","inputShape_2","outputShapes_1","outputShapeKeys","tensorMap","depthKeys_4","nodes_2","referenceInputTensors","referenceOutputTensors","computedData","referenceInputTensors_1","computedTensors","computedMasks","outputTensors_1","outputMasks_1","computedTensor","computedMask","computeMask","keptNodes","nodeConversionMap","originalNodeIndex","calculateLosses","buildNodeConversionMap","layerConfigs","layerClassName","layerConfig","filteredInboundNodes","nodeData","newNodeIndex","modelInputs","modelOutputs","createdLayers","unprocessedNodes","nodeData_1","inputData","inboundLayerName","inboundNodeIndex","addUnprocessedNode","layerData","layerName","deserializeLayer","inboundNodesData_1","layersFromConfig","layersFromConfig_1","processLayer","generic_utils.isObjectEmpty","layersFromConfig_2","processNode","inputLayersFromConfig_1","layerOutputTensors","outputLayersFromConfig_1","stateful","cast","ModelLoggingVerbosity","feeds","FeedDict","id2Value","feeds_1","feed","assertFeedCompatibility","fetches","feedDict","arrayFetches","fetchArray","internalFeedDict","fetchArray_1","fetch_1","executeInternal","fetch","hasKey","getValue","inputValues","inputs_1","inputVal","layerOutputs","getNodeOutputs","outputSymbolicTensors","getOutputAt","isDataTensor","isDataArray","names","checkBatchAxis","exceptionPrefix","gotUnexpectedData","isDataDict","arrays","names_1","K.expandDims","refDim","targets","setX","unique","input","setY","lossFns","keyLosses","losses.meanSquaredError","losses.binaryCrossentropy","losses.categoricalCrossentropy","loss","slicedYShape","slicedShape","targetDim","outDim","batchStart","stop","K.sliceAlongFirstAxis","tfc.tidy","sliceArraysByIndices","K.gather","metrics","nestedMetrics","outputNames_1","outputMetrics","Model","printSummary","optimizer","optimizers.getOptimizer","Optimizer","lossFunctions","theLosses","l","losses.get","lossFunction_1","feedOutputShapes","feedLossFns","name_5","skipTargetIndices","metricsNames","metricsTensors","weightedLoss","collectMetrics","metricName","accFn","weightedMetricFn","metric","Metrics.binaryAccuracy","Metrics.binaryCrossentropy","losses.sparseCategoricalCrossentropy","Metrics.sparseCategoricalAccuracy","Metrics.sparseCategoricalCrossentropy","Metrics.categoricalAccuracy","Metrics.categoricalCrossentropy","suffix","metricFn","Metrics.get","metricResult","outputIndex","metricTensor","appendMetric","metrics_1","handleMetrics","standardizedOuts","standardizeUserData","ins","makeTestFunction","f","testFunction","singletonOrArray","testLoop","verbose","steps","stepsName","numSamples","outputsIsArray","retrieveSymbolicTensors","tensorValue","executeOutputs","execute","symbolicTensorNames","pyListRepeat","outputsRemaining","layerOutputNames","remainingNames_1","checkNumSamples","batches","makeBatches","outs","batchIndex","batchOuts","insBatch","sliceArrays","batchOuts_1","batchOut","K.concatAlongFirstAxis","checkInputData","predictLoop","checkArrayLengths","standardizeInputData","checkLossAndTargetCompatibility","outLabels","epochs","valF","valIns","shuffle","callbackMetrics","initialEpoch","stepsPerEpoch","validationSteps","doValidation","numTrainSamples","indexArray","range","callbackList","stopTraining","epochLogs","epochIndexArray1D_1","batches_1","batchLogs","batchIds","tfc.keep","valOuts","disposeTensorsInLogs","syncData","dedupedOutLabels","newLabel","totalLoss","valOutputs","lossFunction","meanMetric","needValidationDisposal","validationData","valX","valY","valStandardized","validationSplit","splitAt","originalBatchSize","trainFunction","metricsValues","variables","param","minimize","regularizerLoss","getDedupedMetricsNames","valFunction","standardizeCallbacks","fitLoop","namedWeights","getWeights","handlerOrURL","handlers","io","getSaveHandlers","save","encodeWeights","getNamedWeights","weightDataAndSpecs","unusedArg","toJSON","modelTopology","weightData","weightSpecs","specs","pathOrIOHandler","getLoadHandlers","browserHTTPRequest","loadModelFromIOHandler","handler","load","artifacts","deserialize","loadWeights","decodeWeights","_updatable","Sequential","modelLayer","isLayerModelInstance","Input","outputTensor","lastLayerIndex","getExactlyOneShape","summary","evaluate","predict","predictOnBatch","compile","fit","loadModelInternal","Activation","Elu","K.elu","Selu","tfc.selu","Relu","Relu6","tfc.minimum","Linear","Sigmoid","tfc.sigmoid","HardSigmoid","K.hardSigmoid","Softplus","Softsign","K.softsign","Tanh","tfc.tanh","Softmax","activation","deserializeActivation","DEFAULT_ALPHA","LeakyReLU","getExactlyOneTensor","leakyRelu","baseConfig","ELU","elu","theta","DEFAULT_THETA","thetaTensor","ThresholdedReLU","greater","softmax","softmaxActivation","DEFAULT_AXIS","l1","l2","hasL1","hasL2","L1L2","regularization","sum","abs","asScalar","Regularizer","REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","l1l2","deserializeRegularizer","singleValue","isInteger","inputLength","filterSize","padding","stride","dilation","outputLength","dimSize","strideSize","kernelSize","tfc.transpose","kernel","strides","dilationRate","tfc.conv1d","K.biasAdd","preprocessConv2DInput","tfc.conv2d","BaseConv","verifyConfig","normalizeArray","checkPaddingMode","getActivation","useBias","biasInitializer","getInitializer","DEFAULT_BIAS_INITIALIZER","biasConstraint","getConstraint","biasRegularizer","getRegularizer","generic_utils.checkArrayTypeAndLength","serializeActivation","serializeInitializer","serializeRegularizer","serializeConstraint","Conv","filters","kernelInitializer","DEFAULT_KERNEL_INITIALIZER","kernelConstraint","kernelRegularizer","channelAxis","inputDim","kernelShape","addWeight","biasValue","conv1dWithBias","conv2dWithBias","newSpace","space","newDim","convOutputLength","Conv2D","InputSpec","Conv2DTranspose","hAxis","wAxis","height","width","kernelH","kernelW","strideH","strideW","deconvLength","tfc.conv2dTranspose","heightAxis","widthAxis","depthMultiplier","depthwiseInitializer","DEFAULT_DEPTHWISE_INITIALIZER","depthwiseRegularizer","depthwiseConstraint","pointwiseInitializer","DEFAULT_POINTWISE_INITIALIZER","pointwiseRegularizer","pointwiseConstraint","SeparableConv","depthwiseKernelShape","pointwiseKernelShape","depthwiseKernel","pointwiseKernel","tfc.separableConv2d","SeparableConv2D","Conv1D","cropping","Cropping2D","K.sliceAlongAxis","DEFAULT_SIZE","UpSampling2D","resized","resizeNearestNeighbor","tfc.depthwiseConv2d","DepthwiseConv2D","depthwiseConv2d","rows","cols","outFilters","outRows","outCols","min","rateScalar","Dropout","invokeCallHook","noiseShape_1","getNoiseShape","K.inTrainPhase","K.dropout","units","Dense","inputLastDim","K.dot","Flatten","K.batchFlatten","RepeatVector","K.repeat","targetShape","isUnknown","Reshape","errorMsg","finalShape","known","unknown","originalSize","anyUnknownDims","fixUnknownDimension","outputDim","embeddingsInitializer","DEFAULT_EMBEDDINGS_INITIALIZER","embeddingsRegularizer","embeddingsConstraint","maskZero","Embedding","embeddings","inLens","s1","s2","as1D","Merge","shape1","shape2","computeElementwiseOpOutputShape","batchSizes","allRanks","reshapeRequired","reshapedInputs","inputDims","mathUtils.max","xNDim","mergeFunction","transposed","inputs_2","xTransposed","mathUtils.arrayProd","dims","mathUtils.range","yNDim","yShape","Add","tfc.zeros","inputs_3","Multiply","tfc.ones","inputs_4","Average","inputs_5","Maximum","Minimum","Concatenate","allNoneShape","inputShape_3","shapeSet","shapeWithoutConcatAxis","exists","shapeSet_1","K.concatenate","variance","beta","gamma","tfc.batchNormalization2d","tfc.batchNormalization3d","tfc.batchNormalization4d","reductionAxes","meanAndVariance","tfc.moments","batchNormalization","math_utils.range","broadcastMean","broadcastVariance","broadcastGamma","broadcastBeta","regularNormalizeBatchInTraining","broadcastNormalizeBatchInTraining","momentum","center","betaInitializer","gammaInitializer","movingMeanInitializer","movingVarianceInitializer","betaConstraint","gammaConstraint","betaRegularizer","gammaRegularizer","stepCount","BatchNormalization","movingMean","movingVariance","broadcastShape","sortedReductionAxes","needsBroadcasting","broadcastMovingMean","broadcastMovingVariance","normalizeInference","normedTraining","sampleSize","varianceDebiased","newMovingMean","tfc.movingAverage","newMovingVariance","updateMovingMeanAndVariance","pattern","tfc.pad","heightPadding","widthPadding","ZeroPadding2D","spatial2dPadding","poolSize","poolMode","checkPoolMode","paddingString","tfc.maxPool","tfc.avgPool","Pooling1D","poolingFunction","tfc.squeeze","MaxPooling1D","pool2d","AveragePooling1D","Pooling2D","MaxPooling2D","AveragePooling2D","GlobalPooling1D","GlobalAveragePooling1D","GlobalMaxPooling1D","GlobalPooling2D","GlobalAveragePooling2D","GlobalMaxPooling2D","initialState","constants","numConstants","toListOrNull","stepFunction","initialStates","goBackwards","unroll","lastOutput","tfc.reverse","states","timeSteps","t","currentInput","stepOutputs","cell","StackedRNNCells","cells","stateSize","returnSequences","returnState","stateSpec","RNN","isArrayOfShapes","stateShape","stateSize_1","stepInputShape","expectedShape","standardized","standardizeArgs","additionalInputs","additionalSpecs","initialState_1","state","fullInput","fullInputSpec","originalInputSpec","getInitialState","numStates","timesteps","cellCallKwargs","rnnOutputs","rnn","K.tile","cellConfig","DEFAULT_ACTIVATION","recurrentInitializer","DEFAULT_RECURRENT_INITIALIZER","recurrentRegularizer","recurrentConstraint","dropout","math_utils.min","math_utils.max","recurrentDropout","dropoutMask","recurrentDropoutMask","SimpleRNNCell","recurrentKernel","prevOutput","h","generateDropoutMask","dpMask","recDpMask","RNNCell","SimpleRNN","tfc.dispose","recurrentActivation","DEFAULT_RECURRENT_ACTIVATION","implementation","GRUCell","hTMinus1","z","r","hh","kernelZ","K.sliceAlongLastAxis","kernelR","recurrentKernelZ","recurrentKernelR","recurrentKernelH","inputsZ","inputsR","inputsH","xZ","xR","xH","biasZ","biasR","biasH","hTMinus1Z","hTMinus1R","hTMinus1H","matrixX","matrixInner","recurrentZ","recurrentR","recurrentH","GRU","unitForgetBias","LSTMCell","capturedBiasInit_1","capturedUnits_1","CustomInit","bI","bF","bCAndH","cTMinus1","c","o","kernelI","kernelF","kernelC","kernelO","recurrentKernelI","recurrentKernelF","recurrentKernelC","recurrentKernelO","inputsI","inputsF","inputsC","inputsO","xI","xF","xC","xO","biasI","biasF","biasC","biasO","hTMinus1I","hTMinus1F","hTMinus1C","hTMinus1O","z0","z1","z2","z3","LSTM","nestedStates","callInputs","newNestedStates","cellStates","cellConfigs","tuples","numParams","inputWeights","droppedInputs","Wrapper","newConfig","TimeDistributed","childInputShape","childOutputShape","VALID_BIDIRECTIONAL_MERGE_MODES","generic_utils.checkStringTypeUnionValue","forwardLayer","backwardLayer","checkBidirectionalMergeMode","mergeMode","_trainable","Bidirectional","numWeights","numeightsOver2","layerShapes","stateSpecs","isSymbolicTensor","additionalInputs_1","yRev","forwardState","backwardState","resetStates","rnnLayer","averagePooling1d","averagePooling2d","globalMaxPool1d","globalMaxPooling1d","globalMaxPool2d","globalMaxPooling2d","maxPool1d","maxPooling1d","maxPool2d","maxPooling2d","metrics.binaryAccuracy","metrics.binaryCrossentropy","metrics.categoricalAccuracy","metrics.categoricalCrossentropy","losses.cosineProximity","losses.meanAbsoluteError","losses.meanAbsolutePercentageError","regularizers.l1","regularizers.l2","Callback"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js new file mode 100644 index 0000000..5cdb935 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js @@ -0,0 +1,10592 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@tensorflow/tfjs-core')) : + typeof define === 'function' && define.amd ? define(['exports', '@tensorflow/tfjs-core'], factory) : + (factory((global.tf = global.tf || {}),global.tf)); +}(this, (function (exports,tfc) { 'use strict'; + + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. 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 + + THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED + WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, + MERCHANTABLITY OR NON-INFRINGEMENT. + + See the Apache Version 2.0 License for specific language governing permissions + and limitations under the License. + ***************************************************************************** */ + /* global Reflect, Promise */ + + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + + function __extends(d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + } + + var __assign = Object.assign || function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; + + function __awaiter(thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + } + + function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [0, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + } + + var _epsilon = 1e-7; + function epsilon() { + return _epsilon; + } + function imageDataFormat() { + return 'channelsLast'; + } + + var _nextUniqueTensorId = 0; + function getNextUniqueTensorId() { + return _nextUniqueTensorId++; + } + var _uidPrefixes = {}; + function getUid(prefix) { + if (prefix === void 0) { prefix = ''; } + if (!(prefix in _uidPrefixes)) { + _uidPrefixes[prefix] = 0; + } + _uidPrefixes[prefix] += 1; + return prefix + _uidPrefixes[prefix].toString(); + } + var scalarCache = { + float32: {}, + int32: {} + }; + var DEFAULT_DTYPE = 'float32'; + function getScalar(value, dtype) { + if (dtype === undefined) { + dtype = DEFAULT_DTYPE; + } + if (scalarCache[dtype][value] == null) { + scalarCache[dtype][value] = tfc.scalar(value, dtype); + tfc.keep(scalarCache[dtype][value]); + } + return scalarCache[dtype][value]; + } + + var AttributeError = (function (_super) { + __extends(AttributeError, _super); + function AttributeError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, AttributeError.prototype); + return _this; + } + return AttributeError; + }(Error)); + var RuntimeError = (function (_super) { + __extends(RuntimeError, _super); + function RuntimeError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, RuntimeError.prototype); + return _this; + } + return RuntimeError; + }(Error)); + var ValueError = (function (_super) { + __extends(ValueError, _super); + function ValueError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, ValueError.prototype); + return _this; + } + return ValueError; + }(Error)); + var NotImplementedError = (function (_super) { + __extends(NotImplementedError, _super); + function NotImplementedError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, NotImplementedError.prototype); + return _this; + } + return NotImplementedError; + }(Error)); + var AssertionError = (function (_super) { + __extends(AssertionError, _super); + function AssertionError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, AssertionError.prototype); + return _this; + } + return AssertionError; + }(Error)); + var IndexError = (function (_super) { + __extends(IndexError, _super); + function IndexError(message) { + var _this = _super.call(this, message) || this; + Object.setPrototypeOf(_this, IndexError.prototype); + return _this; + } + return IndexError; + }(Error)); + + function pyListRepeat(value, numValues) { + if (Array.isArray(value)) { + var newArray = []; + for (var i = 0; i < numValues; i++) { + newArray = newArray.concat(value); + } + return newArray; + } + else { + var newArray = new Array(numValues); + newArray.fill(value); + return newArray; + } + } + function assert(val, message) { + if (!val) { + throw new AssertionError(message); + } + } + function count(array, refernce) { + var counter = 0; + for (var _i = 0, array_1 = array; _i < array_1.length; _i++) { + var item = array_1[_i]; + if (item === refernce) { + counter++; + } + } + return counter; + } + function singletonOrArray(xs) { + if (xs.length === 1) { + return xs[0]; + } + return xs; + } + function toList(x) { + if (Array.isArray(x)) { + return x; + } + return [x]; + } + function toSnakeCase(name) { + var intermediate = name.replace(/(.)([A-Z][a-z0-9]+)/g, '$1_$2'); + var insecure = intermediate.replace(/([a-z])([A-Z])/g, '$1_$2').toLowerCase(); + if (insecure[0] !== '_') { + return insecure; + } + return 'private' + insecure; + } + function toCamelCase(identifier) { + if (identifier.length <= 1) { + return identifier; + } + if (identifier.indexOf('_') === -1) { + return identifier; + } + return identifier.replace(/[_]+(\w|$)/g, function (m, p1) { return p1.toUpperCase(); }); + } + var _GLOBAL_CUSTOM_OBJECTS = {}; + function serializeKerasObject(instance) { + if (instance === null || instance === undefined) { + return null; + } + return { className: instance.getClassName(), config: instance.getConfig() }; + } + function deserializeKerasObject(identifier, moduleObjects, customObjects, printableModuleName) { + if (moduleObjects === void 0) { moduleObjects = {}; } + if (customObjects === void 0) { customObjects = {}; } + if (printableModuleName === void 0) { printableModuleName = 'object'; } + if (typeof identifier === 'string') { + var functionName = identifier; + var fn = void 0; + if (functionName in customObjects) { + fn = customObjects[functionName]; + } + else if (functionName in _GLOBAL_CUSTOM_OBJECTS) { + fn = _GLOBAL_CUSTOM_OBJECTS[functionName]; + } + else { + fn = moduleObjects[functionName]; + if (fn == null) { + throw new ValueError("Unknown " + printableModuleName + ": " + identifier); + } + } + return fn; + } + else { + var config = identifier; + if (config.className == null || config.config == null) { + throw new ValueError(printableModuleName + ": Improper config format: " + + (JSON.stringify(config) + ".\n") + + "'className' and 'config' must set."); + } + var className = config.className; + var cls = void 0, fromConfig = void 0; + if (className in customObjects) { + _a = customObjects.get(className), cls = _a[0], fromConfig = _a[1]; + } + else if (className in _GLOBAL_CUSTOM_OBJECTS) { + _b = _GLOBAL_CUSTOM_OBJECTS.className, cls = _b[0], fromConfig = _b[1]; + } + else if (className in moduleObjects) { + _c = moduleObjects[className], cls = _c[0], fromConfig = _c[1]; + } + if (cls == null) { + throw new ValueError("Unknown " + printableModuleName + ": " + className); + } + if (fromConfig != null) { + var customObjectsCombined = {}; + for (var _i = 0, _d = Object.keys(_GLOBAL_CUSTOM_OBJECTS); _i < _d.length; _i++) { + var key = _d[_i]; + customObjectsCombined[key] = _GLOBAL_CUSTOM_OBJECTS[key]; + } + for (var _e = 0, _f = Object.keys(customObjects); _e < _f.length; _e++) { + var key = _f[_e]; + customObjectsCombined[key] = customObjects[key]; + } + var nestedConfig = config.config; + nestedConfig.customObjects = customObjectsCombined; + var backupCustomObjects = __assign({}, _GLOBAL_CUSTOM_OBJECTS); + for (var _g = 0, _h = Object.keys(customObjects); _g < _h.length; _g++) { + var key = _h[_g]; + _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key]; + } + var returnObj = fromConfig(cls, config.config); + _GLOBAL_CUSTOM_OBJECTS = __assign({}, backupCustomObjects); + return returnObj; + } + else { + var backupCustomObjects = __assign({}, _GLOBAL_CUSTOM_OBJECTS); + for (var _j = 0, _k = Object.keys(customObjects); _j < _k.length; _j++) { + var key = _k[_j]; + _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key]; + } + var returnObj = new cls(config.config); + _GLOBAL_CUSTOM_OBJECTS = __assign({}, backupCustomObjects); + return returnObj; + } + } + var _a, _b, _c; + } + function numberCompare(a, b) { + return (a < b) ? -1 : ((a > b) ? 1 : 0); + } + function reverseNumberCompare(a, b) { + return -1 * numberCompare(a, b); + } + function stringToDType(dtype) { + switch (dtype) { + case 'float32': + return 'float32'; + default: + throw new ValueError("Invalid dtype: " + dtype); + } + } + function unique(xs) { + if (xs == null) { + return xs; + } + var out = []; + for (var _i = 0, xs_1 = xs; _i < xs_1.length; _i++) { + var x = xs_1[_i]; + if (out.indexOf(x) === -1) { + out.push(x); + } + } + return out; + } + function isObjectEmpty(obj) { + if (obj == null) { + throw new ValueError("Invalid value in obj: " + JSON.stringify(obj)); + } + for (var key in obj) { + if (obj.hasOwnProperty(key)) { + return false; + } + } + return true; + } + function checkStringTypeUnionValue(values, label, value) { + if (value == null) { + return; + } + if (values.indexOf(value) < 0) { + throw new ValueError(value + " is not a valid " + label + ". Valid values are " + values + " or null/undefined."); + } + } + function checkArrayTypeAndLength(x, expectedType, minLength, maxLength) { + if (minLength === void 0) { minLength = 0; } + if (maxLength === void 0) { maxLength = Infinity; } + assert(minLength >= 0); + assert(maxLength >= minLength); + return (Array.isArray(x) && x.length >= minLength && x.length <= maxLength && + x.every(function (e) { return typeof e === expectedType; })); + } + + function calcL2Norms(w, axis) { + return tfc.tidy(function () { return tfc.sqrt(tfc.sum(tfc.mulStrict(w, w), axis, true)); }); + } + var Constraint = (function (_super) { + __extends(Constraint, _super); + function Constraint() { + return _super !== null && _super.apply(this, arguments) || this; + } + Constraint.prototype.getConfig = function () { + return {}; + }; + return Constraint; + }(tfc.serialization.Serializable)); + var MaxNorm = (function (_super) { + __extends(MaxNorm, _super); + function MaxNorm(config) { + var _this = _super.call(this) || this; + _this.defaultMaxValue = 2; + _this.defaultAxis = 0; + _this.maxValue = + config.maxValue != null ? config.maxValue : _this.defaultMaxValue; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + MaxNorm.prototype.apply = function (w) { + var _this = this; + return tfc.tidy(function () { + var norms = calcL2Norms(w, _this.axis); + var desired = tfc.clipByValue(norms, 0, _this.maxValue); + return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms))); + }); + }; + MaxNorm.prototype.getConfig = function () { + return { maxValue: this.maxValue, axis: this.axis }; + }; + MaxNorm.className = 'MaxNorm'; + return MaxNorm; + }(Constraint)); + tfc.serialization.SerializationMap.register(MaxNorm); + var UnitNorm = (function (_super) { + __extends(UnitNorm, _super); + function UnitNorm(config) { + var _this = _super.call(this) || this; + _this.defaultAxis = 0; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + UnitNorm.prototype.apply = function (w) { + var _this = this; + return tfc.tidy(function () { return tfc.div(w, tfc.add(getScalar(epsilon()), calcL2Norms(w, _this.axis))); }); + }; + UnitNorm.prototype.getConfig = function () { + return { axis: this.axis }; + }; + UnitNorm.className = 'UnitNorm'; + return UnitNorm; + }(Constraint)); + tfc.serialization.SerializationMap.register(UnitNorm); + var NonNeg = (function (_super) { + __extends(NonNeg, _super); + function NonNeg() { + return _super !== null && _super.apply(this, arguments) || this; + } + NonNeg.prototype.apply = function (w) { + return tfc.relu(w); + }; + NonNeg.className = 'NonNeg'; + return NonNeg; + }(Constraint)); + tfc.serialization.SerializationMap.register(NonNeg); + var MinMaxNorm = (function (_super) { + __extends(MinMaxNorm, _super); + function MinMaxNorm(config) { + var _this = _super.call(this) || this; + _this.defaultMinValue = 0.0; + _this.defaultMaxValue = 1.0; + _this.defaultRate = 1.0; + _this.defaultAxis = 0; + _this.minValue = + config.minValue != null ? config.minValue : _this.defaultMinValue; + _this.maxValue = + config.maxValue != null ? config.maxValue : _this.defaultMaxValue; + _this.rate = config.rate != null ? config.rate : _this.defaultRate; + _this.axis = config.axis != null ? config.axis : _this.defaultAxis; + return _this; + } + MinMaxNorm.prototype.apply = function (w) { + var _this = this; + return tfc.tidy(function () { + var norms = calcL2Norms(w, _this.axis); + var desired = tfc.add(tfc.mul(getScalar(_this.rate), tfc.clipByValue(norms, _this.minValue, _this.maxValue)), tfc.mul(getScalar(1.0 - _this.rate), norms)); + return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms))); + }); + }; + MinMaxNorm.prototype.getConfig = function () { + return { + minValue: this.minValue, + maxValue: this.maxValue, + rate: this.rate, + axis: this.axis + }; + }; + MinMaxNorm.className = 'MinMaxNorm'; + return MinMaxNorm; + }(Constraint)); + tfc.serialization.SerializationMap.register(MinMaxNorm); + var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'maxNorm': 'MaxNorm', + 'minMaxNorm': 'MinMaxNorm', + 'nonNeg': 'NonNeg', + 'unitNorm': 'UnitNorm' + }; + function serializeConstraint(constraint) { + return serializeKerasObject(constraint); + } + function deserializeConstraint(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return deserializeKerasObject(config, tfc.serialization.SerializationMap.getMap().classNameMap, customObjects, 'constraint'); + } + function getConstraint(identifier) { + if (identifier == null) { + return null; + } + if (typeof identifier === 'string') { + var className = identifier in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + var config = { className: className, config: {} }; + return deserializeConstraint(config); + } + else if (identifier instanceof Constraint) { + return identifier; + } + else { + return deserializeConstraint(identifier); + } + } + + function maxNorm(config) { + return new MaxNorm(config); + } + function unitNorm(config) { + return new UnitNorm(config); + } + function nonNeg() { + return new NonNeg(); + } + function minMaxNorm(config) { + return new MinMaxNorm(config); + } + + var exports_constraints = /*#__PURE__*/Object.freeze({ + maxNorm: maxNorm, + unitNorm: unitNorm, + nonNeg: nonNeg, + minMaxNorm: minMaxNorm + }); + + var nameMap = new Map(); + var VALID_DATA_FORMAT_VALUES = ['channelsFirst', 'channelsLast']; + function checkDataFormat(value) { + checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES, 'DataFormat', value); + } + var VALID_PADDING_MODE_VALUES = ['valid', 'same', 'causal']; + function checkPaddingMode(value) { + checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES, 'PaddingMode', value); + } + var VALID_POOL_MODE_VALUES = ['max', 'avg']; + function checkPoolMode(value) { + checkStringTypeUnionValue(VALID_POOL_MODE_VALUES, 'PoolMode', value); + } + var _nameScopeStack = []; + var _nameScopeDivider = '/'; + function nameScope(name, fn) { + _nameScopeStack.push(name); + try { + var val = fn(); + _nameScopeStack.pop(); + return val; + } + catch (e) { + _nameScopeStack.pop(); + throw e; + } + } + function currentNameScopePrefix() { + if (_nameScopeStack.length === 0) { + return ''; + } + else { + return _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider; + } + } + function getScopedTensorName(tensorName) { + if (!isValidTensorName(tensorName)) { + throw new Error('Not a valid tensor name: \'' + tensorName + '\''); + } + return currentNameScopePrefix() + tensorName; + } + function getUniqueTensorName(scopedName) { + if (!isValidTensorName(scopedName)) { + throw new Error('Not a valid tensor name: \'' + scopedName + '\''); + } + if (!nameMap.has(scopedName)) { + nameMap.set(scopedName, 0); + } + var index = nameMap.get(scopedName); + nameMap.set(scopedName, nameMap.get(scopedName) + 1); + if (index > 0) { + var result = scopedName + '_' + index; + nameMap.set(result, 1); + return result; + } + else { + return scopedName; + } + } + var tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/); + function isValidTensorName(name) { + return name.match(tensorNameRegex) ? true : false; + } + + function isInteger(x) { + return x === parseInt(x.toString(), 10); + } + function arrayProd(array, begin, end) { + if (begin == null) { + begin = 0; + } + if (end == null) { + end = array.length; + } + var prod = 1; + for (var i = begin; i < end; ++i) { + prod *= array[i]; + } + return prod; + } + function toArray1D(array) { + array = Array.isArray(array) ? new Float32Array(array) : array; + return tfc.tensor1d(array); + } + function min(array) { + return tfc.min(toArray1D(array)).dataSync()[0]; + } + function max(array) { + return tfc.max(toArray1D(array)).dataSync()[0]; + } + function range(begin, end) { + if (end < begin) { + throw new ValueError("end (" + end + ") < begin (" + begin + ") is forbidden."); + } + var out = []; + for (var i = begin; i < end; ++i) { + out.push(i); + } + return out; + } + + function cast(x, dtype) { + return x.asType(dtype); + } + function expandDims(x, axis) { + if (axis === void 0) { axis = -1; } + var outShape = x.shape.slice(); + if (axis < 0) { + axis = outShape.length + axis + 1; + } + outShape.splice(axis, 0, 1); + return x.reshape(outShape); + } + function repeat(x, n) { + return tfc.tidy(function () { + if (x.shape.length !== 2) { + throw new ValueError("repeat() expects a rank-2 tensor, but received a " + + ("rank-" + x.shape.length + " tensor.")); + } + var y = expandDims(x, 1); + return tile(y, [1, n, 1]); + }); + } + function flatten(x) { + var newShape = [arrayProd(x.shape)]; + return x.reshape(newShape); + } + function batchFlatten(x) { + if (x.rank <= 1) { + throw new ValueError("batchFlatten requires a minimum rank of 2. Got rank: " + x.rank + "."); + } + var newShape = [x.shape[0], arrayProd(x.shape, 1)]; + return x.reshape(newShape); + } + function sliceAlongFirstAxis(array, start, size) { + return tfc.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + return tfc.slice2d(array, [start, 0], [size, array.shape[1]]); + case 3: + return tfc.slice3d(array, [start, 0, 0], [size, array.shape[1], array.shape[2]]); + case 4: + return tfc.slice4d(array, [start, 0, 0, 0], [size, array.shape[1], array.shape[2], array.shape[3]]); + default: + throw new ValueError("sliceAlongFirstAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); + } + function sliceAlongLastAxis(array, start, size) { + return tfc.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + return tfc.slice2d(array, [0, start], [array.shape[0], size]); + case 3: + return tfc.slice3d(array, [0, 0, start], [array.shape[0], array.shape[1], size]); + case 4: + return tfc.slice4d(array, [0, 0, 0, start], [array.shape[0], array.shape[1], array.shape[2], size]); + default: + throw new ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); + } + function sliceAlongAxis(array, start, size, axis) { + return tfc.tidy(function () { + switch (array.rank) { + case 1: + return tfc.slice1d(array, start, size); + case 2: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return sliceAlongLastAxis(array, start, size); + default: + throw new ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + case 3: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return tfc.slice3d(array, [0, start, 0], [array.shape[0], size, array.shape[2]]); + case 3: + return sliceAlongLastAxis(array, start, size); + default: + throw new ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + case 4: + switch (axis) { + case 1: + return sliceAlongFirstAxis(array, start, size); + case 2: + return tfc.slice4d(array, [0, start, 0, 0], [array.shape[0], size, array.shape[2], array.shape[3]]); + case 3: + return tfc.slice4d(array, [0, 0, start, 0], [array.shape[0], array.shape[1], size, array.shape[3]]); + case 4: + return sliceAlongLastAxis(array, start, size); + default: + throw new ValueError("The axis is not within the rank of the tensor " + + ("" + axis)); + } + default: + throw new ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + + ("" + array.rank)); + } + }); + } + function concatenate(tensors, axis) { + if (axis === void 0) { axis = -1; } + var rank; + if (axis < 0) { + rank = tensors[0].rank; + if (rank !== 0) { + axis = rank; + } + else { + axis = 0; + } + } + if (axis === tensors[0].rank) { + axis = -1; + } + return tfc.concat(tensors, axis); + } + function concatAlongFirstAxis(a, b) { + switch (a.rank) { + case 1: + return tfc.concat1d([a, b]); + case 2: + return tfc.concat2d([a, b], 0); + case 3: + return tfc.concat3d([a, b], 0); + case 4: + return tfc.concat4d([a, b], 0); + default: + throw new ValueError('concatAlongFirstAxis() received an unsupported tensor rank: ' + + a.rank); + } + } + function tile(x, n) { + if (!Array.isArray(n)) { + n = [n]; + } + if (x.rank !== n.length) { + throw new ValueError("The length of input n (" + n.length + ") does not match " + + ("the number of dimensions in input x (" + x.rank + ")")); + } + return tfc.tile(x, n); + } + function randomNormal(shape, mean$$1, stddev, dtype, seed) { + if (mean$$1 === void 0) { mean$$1 = 0.0; } + if (stddev === void 0) { stddev = 1.0; } + return tfc.randomNormal(shape, mean$$1, stddev, dtype, seed); + } + function dot(x, y) { + if (y.rank !== 2) { + throw new NotImplementedError("dot support for y other than rank 2 is not yet implemented: " + + ("y shape = " + y.shape)); + } + else { + if (x.rank === 2) { + return tfc.matMul(x, y); + } + else if (x.rank === 3) { + var xShape0 = x.shape[0]; + var xShape1 = x.shape[1]; + var xShape2 = x.shape[2]; + x = x.reshape([xShape0 * xShape1, xShape2]); + return tfc.matMul(x, y).reshape([ + xShape0, xShape1, y.shape[1] + ]); + } + else { + throw new NotImplementedError("dot support for x of rank " + x.rank + " is not yet implemented: " + + ("x shape = " + x.shape)); + } + } + } + function gather(reference, indices, axis) { + return tfc.tidy(function () { + if (Array.isArray(indices)) { + indices = tfc.tensor1d(indices, 'int32'); + } + else { + indices = indices.toInt(); + } + return tfc.gather(reference, indices, axis); + }); + } + function square(x) { + return tfc.mulStrict(x, x); + } + function biasAdd(x, bias, dataFormat) { + return tfc.tidy(function () { + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + checkDataFormat(dataFormat); + if (bias.rank !== 1 && bias.rank !== x.rank) { + throw new ValueError('Unexpected bias dimensions: ' + bias.rank + + '; expected it to be 1 or ' + x.rank); + } + var biasShape = bias.shape; + var y; + if (x.rank === 5) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1, 1, 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[3], biasShape[0], biasShape[1], biasShape[2]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, 1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank === 4) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1, 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[2], biasShape[0], biasShape[1]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank === 3) { + if (dataFormat === 'channelsFirst') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, biasShape[0], 1])); + } + else { + y = x.add(bias.reshape([1, biasShape[1], biasShape[0]])); + } + } + else if (dataFormat === 'channelsLast') { + if (biasShape.length === 1) { + y = x.add(bias.reshape([1, 1, biasShape[0]])); + } + else { + y = x.add(bias.reshape([1].concat(biasShape))); + } + } + } + else if (x.rank < 3) { + y = x.add(bias); + } + else { + throw new ValueError("Unsupported input rank by biasAdd: " + x.rank); + } + return y; + }); + } + function elu(x, alpha) { + if (alpha === void 0) { alpha = 1; } + if (alpha !== 1) { + throw new NotImplementedError("Support for alpha values other than 1 (" + alpha + ") is not implemented " + + "yet."); + } + return tfc.elu(x); + } + function softsign(x) { + return tfc.tidy(function () { return tfc.div(x, tfc.add(getScalar(1), tfc.abs(x))); }); + } + function dropout(x, level, noiseShape, seed) { + return tfc.tidy(function () { + if (noiseShape != null && !tfc.util.arraysEqual(x.shape, noiseShape)) { + throw new NotImplementedError('Non-default noise shape is not implemented yet: ' + + JSON.stringify(noiseShape)); + } + if (seed != null) { + throw new NotImplementedError('seed is not implemented for dropout yet.'); + } + var multiplier = tfc.step(tfc.add(tfc.neg(level), tfc.randomUniform(x.shape, 0, 1, 'float32'))); + multiplier = tfc.mul(tfc.div(getScalar(1), tfc.sub(getScalar(1), level)), multiplier); + return tfc.mul(x, multiplier); + }); + } + function hardSigmoid(x) { + return tfc.tidy(function () { + var y = tfc.add(getScalar(0.5), tfc.mul(getScalar(0.2), x)); + return tfc.clipByValue(y, 0, 1); + }); + } + function inTrainPhase(x, alt, training) { + if (training === void 0) { training = false; } + return training ? x() : alt(); + } + + var VALID_FAN_MODE_VALUES = ['fanIn', 'fanOut', 'fanAvg']; + function checkFanMode(value) { + checkStringTypeUnionValue(VALID_FAN_MODE_VALUES, 'FanMode', value); + } + var VALID_DISTRIBUTION_VALUES = ['normal', 'uniform']; + function checkDistribution(value) { + checkStringTypeUnionValue(VALID_DISTRIBUTION_VALUES, 'Distribution', value); + } + var Initializer = (function (_super) { + __extends(Initializer, _super); + function Initializer() { + return _super !== null && _super.apply(this, arguments) || this; + } + Initializer.prototype.fromConfigUsesCustomObjects = function () { + return false; + }; + Initializer.prototype.getConfig = function () { + return {}; + }; + return Initializer; + }(tfc.serialization.Serializable)); + var Zeros = (function (_super) { + __extends(Zeros, _super); + function Zeros() { + return _super !== null && _super.apply(this, arguments) || this; + } + Zeros.prototype.apply = function (shape, dtype) { + return tfc.zeros(shape, dtype); + }; + Zeros.className = 'Zeros'; + return Zeros; + }(Initializer)); + tfc.serialization.SerializationMap.register(Zeros); + var Ones = (function (_super) { + __extends(Ones, _super); + function Ones() { + return _super !== null && _super.apply(this, arguments) || this; + } + Ones.prototype.apply = function (shape, dtype) { + return tfc.ones(shape, dtype); + }; + Ones.className = 'Ones'; + return Ones; + }(Initializer)); + tfc.serialization.SerializationMap.register(Ones); + var Constant = (function (_super) { + __extends(Constant, _super); + function Constant(config) { + var _this = _super.call(this) || this; + if (typeof config !== 'object') { + throw new ValueError("Expected argument of type ConstantConfig but got " + config); + } + if (config.value === undefined) { + throw new ValueError("config must have value set but got " + config); + } + _this.value = config.value; + return _this; + } + Constant.prototype.apply = function (shape, dtype) { + var _this = this; + return tfc.tidy(function () { return tfc.mul(tfc.scalar(_this.value), tfc.ones(shape, dtype)); }); + }; + Constant.prototype.getConfig = function () { + return { + value: this.value, + }; + }; + Constant.className = 'Constant'; + return Constant; + }(Initializer)); + tfc.serialization.SerializationMap.register(Constant); + var RandomUniform = (function (_super) { + __extends(RandomUniform, _super); + function RandomUniform(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MINVAL = -0.05; + _this.DEFAULT_MAXVAL = 0.05; + _this.minval = config.minval || _this.DEFAULT_MINVAL; + _this.maxval = config.maxval || _this.DEFAULT_MAXVAL; + _this.seed = config.seed; + return _this; + } + RandomUniform.prototype.apply = function (shape, dtype) { + return tfc.randomUniform(shape, this.minval, this.maxval, dtype); + }; + RandomUniform.prototype.getConfig = function () { + return { minval: this.minval, maxval: this.maxval, seed: this.seed }; + }; + RandomUniform.className = 'RandomUniform'; + return RandomUniform; + }(Initializer)); + tfc.serialization.SerializationMap.register(RandomUniform); + var RandomNormal = (function (_super) { + __extends(RandomNormal, _super); + function RandomNormal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MEAN = 0.; + _this.DEFAULT_STDDEV = 0.05; + _this.mean = config.mean || _this.DEFAULT_MEAN; + _this.stddev = config.stddev || _this.DEFAULT_STDDEV; + _this.seed = config.seed; + return _this; + } + RandomNormal.prototype.apply = function (shape, dtype) { + if (dtype === 'bool') { + throw new NotImplementedError("randomNormal does not support dType bool."); + } + return randomNormal(shape, this.mean, this.stddev, dtype, this.seed); + }; + RandomNormal.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }; + RandomNormal.className = 'RandomNormal'; + return RandomNormal; + }(Initializer)); + tfc.serialization.SerializationMap.register(RandomNormal); + var TruncatedNormal = (function (_super) { + __extends(TruncatedNormal, _super); + function TruncatedNormal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_MEAN = 0.; + _this.DEFAULT_STDDEV = 0.05; + _this.mean = config.mean || _this.DEFAULT_MEAN; + _this.stddev = config.stddev || _this.DEFAULT_STDDEV; + _this.seed = config.seed; + return _this; + } + TruncatedNormal.prototype.apply = function (shape, dtype) { + if (dtype === 'bool') { + throw new NotImplementedError("truncatedNormal does not support dType bool."); + } + return tfc.truncatedNormal(shape, this.mean, this.stddev, dtype, this.seed); + }; + TruncatedNormal.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }; + TruncatedNormal.className = 'TruncatedNormal'; + return TruncatedNormal; + }(Initializer)); + tfc.serialization.SerializationMap.register(TruncatedNormal); + var Identity = (function (_super) { + __extends(Identity, _super); + function Identity(config) { + var _this = _super.call(this) || this; + _this.gain = config.gain != null ? tfc.scalar(config.gain) : getScalar(1.0); + return _this; + } + Identity.prototype.apply = function (shape, dtype) { + var _this = this; + return tfc.tidy(function () { + if (shape.length !== 2 || shape[0] !== shape[1]) { + throw new ValueError('Identity matrix initializer can only be used for' + + ' 2D square matrices.'); + } + else { + return tfc.mul(_this.gain, tfc.eye(shape[0])); + } + }); + }; + Identity.prototype.getConfig = function () { + return { gain: this.gain.get() }; + }; + Identity.className = 'Identity'; + return Identity; + }(Initializer)); + tfc.serialization.SerializationMap.register(Identity); + function computeFans(shape, dataFormat) { + if (dataFormat === void 0) { dataFormat = 'channelsLast'; } + var fanIn; + var fanOut; + checkDataFormat(dataFormat); + if (shape.length === 2) { + fanIn = shape[0]; + fanOut = shape[1]; + } + else if ([3, 4, 5].indexOf(shape.length) !== -1) { + if (dataFormat === 'channelsFirst') { + var receptiveFieldSize = arrayProd(shape, 2); + fanIn = shape[1] * receptiveFieldSize; + fanOut = shape[0] * receptiveFieldSize; + } + else if (dataFormat === 'channelsLast') { + var receptiveFieldSize = arrayProd(shape, 0, shape.length - 2); + fanIn = shape[shape.length - 2] * receptiveFieldSize; + fanOut = shape[shape.length - 1] * receptiveFieldSize; + } + } + else { + var shapeProd = arrayProd(shape); + fanIn = Math.sqrt(shapeProd); + fanOut = Math.sqrt(shapeProd); + } + return [fanIn, fanOut]; + } + var VarianceScaling = (function (_super) { + __extends(VarianceScaling, _super); + function VarianceScaling(config) { + var _this = _super.call(this) || this; + if (config.scale < 0.0) { + throw new ValueError("scale must be a positive float. Got: " + config.scale); + } + _this.scale = config.scale == null ? 1.0 : config.scale; + _this.mode = config.mode; + checkFanMode(_this.mode); + _this.distribution = config.distribution; + checkDistribution(_this.distribution); + _this.seed = config.seed; + return _this; + } + VarianceScaling.prototype.apply = function (shape, dtype) { + var fans = computeFans(shape); + var fanIn = fans[0]; + var fanOut = fans[1]; + var scale = this.scale; + if (this.mode === 'fanIn') { + scale /= Math.max(1, fanIn); + } + else if (this.mode === 'fanOut') { + scale /= Math.max(1, fanOut); + } + else { + scale /= Math.max(1, (fanIn + fanOut) / 2); + } + if (this.distribution === 'normal') { + var stddev = Math.sqrt(scale); + if (dtype === 'bool') { + throw new NotImplementedError(this.getClassName() + " does not support dType bool."); + } + return tfc.truncatedNormal(shape, 0, stddev, dtype, this.seed); + } + else { + var limit = Math.sqrt(3 * scale); + return tfc.randomUniform(shape, -limit, limit, dtype); + } + }; + VarianceScaling.prototype.getConfig = function () { + return { + scale: this.scale, + mode: this.mode, + distribution: this.distribution, + seed: this.seed + }; + }; + VarianceScaling.className = 'VarianceScaling'; + return VarianceScaling; + }(Initializer)); + tfc.serialization.SerializationMap.register(VarianceScaling); + var GlorotUniform = (function (_super) { + __extends(GlorotUniform, _super); + function GlorotUniform(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanAvg', + distribution: 'uniform', + seed: config == null ? null : config.seed + }) || this; + } + GlorotUniform.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return GlorotUniform; + }(VarianceScaling)); + var GlorotNormal = (function (_super) { + __extends(GlorotNormal, _super); + function GlorotNormal(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanAvg', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + GlorotNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return GlorotNormal; + }(VarianceScaling)); + var HeNormal = (function (_super) { + __extends(HeNormal, _super); + function HeNormal(config) { + return _super.call(this, { + scale: 2.0, + mode: 'fanIn', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + HeNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return HeNormal; + }(VarianceScaling)); + var LeCunNormal = (function (_super) { + __extends(LeCunNormal, _super); + function LeCunNormal(config) { + return _super.call(this, { + scale: 1.0, + mode: 'fanIn', + distribution: 'normal', + seed: config == null ? null : config.seed + }) || this; + } + LeCunNormal.prototype.getClassName = function () { + return VarianceScaling.className; + }; + return LeCunNormal; + }(VarianceScaling)); + var Orthogonal = (function (_super) { + __extends(Orthogonal, _super); + function Orthogonal(config) { + var _this = _super.call(this) || this; + _this.DEFAULT_GAIN = 1; + _this.gain = config.gain == null ? _this.DEFAULT_GAIN : config.gain; + _this.seed = config.seed; + if (_this.seed != null) { + throw new NotImplementedError('Random seed is not implemented for Orthogonal Initializer yet.'); + } + return _this; + } + Orthogonal.prototype.apply = function (shape, dtype) { + var _this = this; + return tfc.tidy(function () { + if (shape.length !== 2) { + throw new NotImplementedError('The Orthogonal Initializer does not support non-2D shapes yet.'); + } + if (shape[0] * shape[1] > 2000) { + console.warn("Orthogonal initializer is being called on a matrix with more " + + ("than 2000 (" + shape[0] * shape[1] + ") elements: ") + + "Slowness may result."); + } + var normalizedShape = shape[0] > shape[1] ? [shape[1], shape[0]] : shape; + var a = randomNormal(normalizedShape, 0, 1, 'float32'); + var q = tfc.linalg.gramSchmidt(a); + if (shape[0] > shape[1]) { + q = q.transpose(); + } + return tfc.mul(getScalar(_this.gain), q); + }); + }; + Orthogonal.prototype.getConfig = function () { + return { + gain: this.gain, + seed: this.seed, + }; + }; + Orthogonal.className = 'Orthogonal'; + return Orthogonal; + }(Initializer)); + tfc.serialization.SerializationMap.register(Orthogonal); + var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'constant': 'Constant', + 'glorotNormal': 'GlorotNormal', + 'glorotUniform': 'GlorotUniform', + 'heNormal': 'HeNormal', + 'identity': 'Identity', + 'leCunNormal': 'LeCunNormal', + 'ones': 'Ones', + 'orthogonal': 'Orthogonal', + 'randomNormal': 'RandomNormal', + 'randomUniform': 'RandomUniform', + 'truncatedNormal': 'TruncatedNormal', + 'varianceScaling': 'VarianceScaling', + 'zeros': 'Zeros' + }; + function deserializeInitializer(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return deserializeKerasObject(config, tfc.serialization.SerializationMap.getMap().classNameMap, customObjects, 'initializer'); + } + function serializeInitializer(initializer) { + return serializeKerasObject(initializer); + } + function getInitializer(identifier) { + if (typeof identifier === 'string') { + var className = identifier in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + if (className === 'GlorotUniform') { + return new GlorotUniform(); + } + else if (className === 'GlorotNormal') { + return new GlorotNormal(); + } + else if (className === 'HeNormal') { + return new HeNormal(); + } + else if (className === 'LeCunNormal') { + return new LeCunNormal(); + } + else { + var config = { className: className, config: {} }; + return deserializeInitializer(config); + } + } + else if (identifier instanceof Initializer) { + return identifier; + } + else { + return deserializeInitializer(identifier); + } + } + + function zeros() { + return new Zeros(); + } + function ones() { + return new Ones(); + } + function constant(config) { + return new Constant(config); + } + function randomUniform(config) { + return new RandomUniform(config); + } + function randomNormal$1(config) { + return new RandomNormal(config); + } + function truncatedNormal(config) { + return new TruncatedNormal(config); + } + function identity(config) { + return new Identity(config); + } + function varianceScaling(config) { + return new VarianceScaling(config); + } + function glorotUniform(config) { + return new GlorotUniform(config); + } + function glorotNormal(config) { + return new GlorotNormal(config); + } + function heNormal(config) { + return new HeNormal(config); + } + function leCunNormal(config) { + return new LeCunNormal(config); + } + function orthogonal(config) { + return new Orthogonal(config); + } + + var exports_initializers = /*#__PURE__*/Object.freeze({ + zeros: zeros, + ones: ones, + constant: constant, + randomUniform: randomUniform, + randomNormal: randomNormal$1, + truncatedNormal: truncatedNormal, + identity: identity, + varianceScaling: varianceScaling, + glorotUniform: glorotUniform, + glorotNormal: glorotNormal, + heNormal: heNormal, + leCunNormal: leCunNormal, + orthogonal: orthogonal + }); + + function isArrayOfShapes(x) { + return Array.isArray(x) && Array.isArray(x[0]); + } + function normalizeShapeList(x) { + if (x.length === 0) { + return []; + } + if (!Array.isArray(x[0])) { + return [x]; + } + return x; + } + function getExactlyOneTensor(xs) { + var x; + if (Array.isArray(xs)) { + if (xs.length !== 1) { + throw new ValueError("Expected Tensor length to be 1; got " + xs.length); + } + x = xs[0]; + } + else { + x = xs; + } + return x; + } + function getExactlyOneShape(shapes) { + if (Array.isArray(shapes) && Array.isArray(shapes[0])) { + if (shapes.length === 1) { + shapes = shapes; + return shapes[0]; + } + else { + throw new ValueError("Expected exactly 1 Shape; got " + shapes.length); + } + } + else { + return shapes; + } + } + + function countParamsInWeights(weights) { + var count = 0; + for (var _i = 0, weights_1 = weights; _i < weights_1.length; _i++) { + var weight = weights_1[_i]; + if (weight.shape.length === 0) { + count += 1; + } + else { + count += weight.shape.reduce(function (a, b) { return a * b; }); + } + } + return count; + } + + var DEFAULT_VARIABLE_NAME_PREFIX = 'Variable'; + var LayerVariable = (function () { + function LayerVariable(val, dtype, name, trainable, constraint) { + if (dtype === void 0) { dtype = 'float32'; } + if (name === void 0) { name = DEFAULT_VARIABLE_NAME_PREFIX; } + if (trainable === void 0) { trainable = true; } + if (constraint === void 0) { constraint = null; } + this.dtype = dtype == null ? 'float32' : dtype; + this.shape = val.shape; + this.id = getNextUniqueTensorId(); + name = name == null ? DEFAULT_VARIABLE_NAME_PREFIX : name; + this.originalName = getScopedTensorName(name); + this.name = getUniqueTensorName(this.originalName); + this.trainable = trainable; + this.constraint = constraint; + this.val = tfc.variable(val, this.trainable, this.name, this.dtype); + } + LayerVariable.prototype.read = function () { + return this.val; + }; + LayerVariable.prototype.write = function (newVal) { + checkShapesMatch(this.val, newVal); + this.val.assign(newVal); + if (this.constraint != null) { + this.val.assign(this.constraint.apply(this.val)); + } + return this; + }; + return LayerVariable; + }()); + function checkShapesMatch(x, y) { + if (x.shape.toString() !== y.shape.toString()) { + throw new Error('Shape mismatch: ' + JSON.stringify(x.shape) + ' vs. ' + + JSON.stringify(y.shape)); + } + } + function batchGetValue(xs) { + return xs.map(function (x) { return x.read(); }); + } + function batchSetValue(variablesAndValues) { + variablesAndValues.map(function (variableAndValue) { + var variable = variableAndValue[0]; + variable.write(variableAndValue[1]); + }); + } + + var InputSpec = (function () { + function InputSpec(config) { + this.dtype = config.dtype; + this.shape = config.shape; + if (config.shape != null) { + this.ndim = config.shape.length; + } + else { + this.ndim = config.ndim; + } + this.maxNDim = config.maxNDim; + this.minNDim = config.minNDim; + this.axes = config.axes || {}; + } + return InputSpec; + }()); + var SymbolicTensor = (function () { + function SymbolicTensor(dtype, shape, sourceLayer, inputs, callArgs, name, outputTensorIndex) { + this.dtype = dtype; + this.shape = shape; + this.sourceLayer = sourceLayer; + this.inputs = inputs; + this.callArgs = callArgs; + this.outputTensorIndex = outputTensorIndex; + this.id = getNextUniqueTensorId(); + if (name != null) { + this.originalName = getScopedTensorName(name); + this.name = getUniqueTensorName(this.originalName); + } + this.rank = shape.length; + } + return SymbolicTensor; + }()); + var _nextNodeID = 0; + var Node = (function () { + function Node(config, callArgs) { + this.callArgs = callArgs; + this.id = _nextNodeID++; + this.outboundLayer = config.outboundLayer; + this.inboundLayers = config.inboundLayers; + this.nodeIndices = config.nodeIndices; + this.tensorIndices = config.tensorIndices; + this.inputTensors = config.inputTensors; + this.outputTensors = config.outputTensors; + this.inputMasks = config.inputMasks; + this.outputMasks = config.outputMasks; + this.inputShapes = config.inputShapes; + this.outputShapes = config.outputShapes; + for (var _i = 0, _a = config.inboundLayers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer != null) { + layer.outboundNodes.push(this); + } + } + config.outboundLayer.inboundNodes.push(this); + } + Node.prototype.getConfig = function () { + var inboundNames = []; + for (var _i = 0, _a = this.inboundLayers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer != null) { + inboundNames.push(layer.name); + } + else { + inboundNames.push(null); + } + } + return { + outboundLayer: this.outboundLayer ? this.outboundLayer.name : null, + inboundLayers: inboundNames, + nodeIndices: this.nodeIndices, + tensorIndices: this.tensorIndices + }; + }; + return Node; + }()); + var _nextLayerID = 0; + var Layer = (function (_super) { + __extends(Layer, _super); + function Layer(config) { + var _this = _super.call(this) || this; + _this._callHook = null; + _this._addedWeightNames = []; + _this._stateful = false; + _this.id = _nextLayerID++; + _this.activityRegularizer = null; + _this.inputSpec = null; + _this.supportsMasking = false; + _this._trainableWeights = []; + _this._nonTrainableWeights = []; + _this._losses = []; + _this._updates = []; + _this._built = false; + _this.inboundNodes = []; + _this.outboundNodes = []; + var name = config.name; + if (!name) { + var prefix = _this.getClassName(); + name = toSnakeCase(prefix) + '_' + getUid(prefix); + } + _this.name = name; + _this.trainable = config.trainable == null ? true : config.trainable; + _this.updatable = config.updatable == null ? true : config.updatable; + if (config.inputShape != null || config.batchInputShape != null) { + var batchInputShape = void 0; + if (config.batchInputShape != null) { + batchInputShape = config.batchInputShape; + } + else if (config.inputShape != null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + batchInputShape = [batchSize].concat(config.inputShape); + } + _this.batchInputShape = batchInputShape; + var dtype = config.dtype; + if (dtype == null) { + dtype = config.inputDType; + } + if (dtype == null) { + dtype = 'float32'; + } + _this.dtype = dtype; + } + if (config.weights != null) { + _this.initialWeights = config.weights; + } + else { + _this.initialWeights = null; + } + return _this; + } + Layer.nodeKey = function (layer, nodeIndex) { + return layer.name + '_ib-' + nodeIndex.toString(); + }; + Layer.prototype.getNodeAtIndex = function (nodeIndex, attrName) { + if (this.inboundNodes.length === 0) { + throw new RuntimeError('The layer has never been called ' + + ("and thus has no defined " + attrName + ".")); + } + if (this.inboundNodes.length <= nodeIndex) { + throw new ValueError("Asked to get " + attrName + " at node " + nodeIndex + ", " + + ("but the layer has only " + this.inboundNodes.length + " inbound nodes.")); + } + return this.inboundNodes[nodeIndex]; + }; + Layer.prototype.getInputAt = function (nodeIndex) { + return singletonOrArray(this.getNodeAtIndex(nodeIndex, 'input').inputTensors); + }; + Layer.prototype.getOutputAt = function (nodeIndex) { + return singletonOrArray(this.getNodeAtIndex(nodeIndex, 'output').outputTensors); + }; + Object.defineProperty(Layer.prototype, "input", { + get: function () { + if (this.inboundNodes.length > 1) { + throw new AttributeError("Layer " + this.name + + ' has multiple inbound nodes, ' + + 'hence the notion of "layer input" ' + + 'is ill-defined. ' + + 'Use `getInputAt(nodeIndex)` instead.'); + } + else if (this.inboundNodes.length === 0) { + throw new AttributeError("Layer " + this.name + + ' is not connected, no input to return.'); + } + return singletonOrArray(this.getNodeAtIndex(0, 'input').inputTensors); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "output", { + get: function () { + if (this.inboundNodes.length === 0) { + throw new AttributeError("Layer " + this.name + + ' has no inbound nodes.'); + } + if (this.inboundNodes.length > 1) { + throw new AttributeError("Layer " + this.name + + ' has multiple inbound nodes, ' + + 'hence the notion of "layer output" ' + + 'is ill-defined. ' + + 'Use `getOutputAt(nodeIndex)` instead.'); + } + return singletonOrArray(this.getNodeAtIndex(0, 'output').outputTensors); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "losses", { + get: function () { + return this._losses; + }, + enumerable: true, + configurable: true + }); + Layer.prototype.calculateLosses = function () { + return this.losses.map(function (lossFn) { return lossFn(); }); + }; + Object.defineProperty(Layer.prototype, "updates", { + get: function () { + return this._updates; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "built", { + get: function () { + return this._built; + }, + set: function (built) { + this._built = built; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "trainableWeights", { + get: function () { + if (this.trainable) { + return this._trainableWeights; + } + else { + return []; + } + }, + set: function (weights) { + this._trainableWeights = weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "nonTrainableWeights", { + get: function () { + if (!this.trainable) { + return this._trainableWeights.concat(this._nonTrainableWeights); + } + else { + return this._nonTrainableWeights; + } + }, + set: function (weights) { + this._nonTrainableWeights = weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "weights", { + get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Layer.prototype, "stateful", { + get: function () { + return this._stateful; + }, + enumerable: true, + configurable: true + }); + Layer.prototype.assertInputCompatibility = function (inputs) { + inputs = toList(inputs); + if (this.inputSpec == null || this.inputSpec.length === 0) { + return; + } + var inputSpec = toList(this.inputSpec); + if (inputs.length !== inputSpec.length) { + throw new ValueError("Layer " + this.name + " expects " + inputSpec.length + " inputs, " + + ("but it received " + inputs.length + " input tensors. ") + + ("Input received: " + inputs)); + } + for (var inputIndex = 0; inputIndex < inputs.length; inputIndex++) { + var x = inputs[inputIndex]; + var spec = inputSpec[inputIndex]; + if (spec == null) { + continue; + } + var ndim = x.rank; + if (spec.ndim != null) { + if (ndim !== spec.ndim) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + ": " + + ("expected ndim=" + spec.ndim + ", found ndim=" + ndim)); + } + } + if (spec.maxNDim != null) { + if (ndim > spec.maxNDim) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + + (": expected max_ndim=" + spec.maxNDim + ", found ndim=" + ndim)); + } + } + if (spec.minNDim != null) { + if (ndim < spec.minNDim) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + + (": expected min_ndim=" + spec.minNDim + ", found ndim=" + ndim + ".")); + } + } + if (spec.dtype != null) { + if (x.dtype !== spec.dtype) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + this.name + " " + + (": expected dtype=" + spec.dtype + ", found dtype=" + x.dtype + ".")); + } + } + if (spec.axes) { + var xShape = x.shape; + for (var key in spec.axes) { + var axis = Number(key); + var value = spec.axes[key]; + var xShapeAtAxis = axis >= 0 ? xShape[axis] : xShape[xShape.length + axis]; + if (value != null && [value, null].indexOf(xShapeAtAxis) === -1) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + + (this.name + ": expected axis " + axis + " of input shape to ") + + ("have value " + value + " but got shape " + xShape + ".")); + } + } + } + if (spec.shape != null) { + for (var i = 0; i < spec.shape.length; ++i) { + var specDim = spec.shape[i]; + var dim = x.shape[i]; + if (specDim != null && dim != null) { + if (specDim !== dim) { + throw new ValueError("Input " + inputIndex + " is incompatible with layer " + + (this.name + ": expected shape=" + spec.shape + ", ") + + 'found shape=${xShape}.'); + } + } + } + } + } + }; + Layer.prototype.call = function (inputs, kwargs) { + return inputs; + }; + Layer.prototype.invokeCallHook = function (inputs, kwargs) { + if (this._callHook != null) { + this._callHook(inputs, kwargs); + } + }; + Layer.prototype.setCallHook = function (callHook) { + this._callHook = callHook; + }; + Layer.prototype.clearCallHook = function () { + this._callHook = null; + }; + Layer.prototype.apply = function (inputs, kwargs) { + var _this = this; + kwargs = kwargs || {}; + var inputsList = toList(inputs); + var allAreSymbolic = true; + for (var _i = 0, inputsList_1 = inputsList; _i < inputsList_1.length; _i++) { + var input = inputsList_1[_i]; + if (!(input instanceof SymbolicTensor)) { + allAreSymbolic = false; + break; + } + } + var noneAreSymbolic = true; + for (var _a = 0, inputsList_2 = inputsList; _a < inputsList_2.length; _a++) { + var input = inputsList_2[_a]; + if (input instanceof SymbolicTensor) { + noneAreSymbolic = false; + break; + } + } + if (allAreSymbolic === noneAreSymbolic) { + throw new ValueError('Arguments to apply() must be all ' + + 'SymbolicTensors or all Tensors'); + } + return nameScope(this.name, function () { + if (!_this.built) { + _this.assertInputCompatibility(inputs); + var inputShapes = []; + for (var _i = 0, _a = toList(inputs); _i < _a.length; _i++) { + var xElem = _a[_i]; + inputShapes.push(xElem.shape); + } + _this.build(singletonOrArray(inputShapes)); + _this.built = true; + if (_this.initialWeights) { + _this.setWeights(_this.initialWeights); + } + } + _this.assertInputCompatibility(inputs); + if (noneAreSymbolic) { + var output = _this.call(inputs, kwargs); + var outputList = toList(output); + var outputListCopy = []; + for (var _b = 0, outputList_1 = outputList; _b < outputList_1.length; _b++) { + var x = outputList_1[_b]; + if (inputsList.indexOf(x) !== -1) { + x = x.clone(); + } + outputListCopy.push(x); + } + output = singletonOrArray(outputListCopy); + if (_this.activityRegularizer != null) { + throw new NotImplementedError('Layer invocation in the presence of activity ' + + 'regularizer(s) is not supported yet.'); + } + return output; + } + else { + var inputShape = collectInputShape(inputs); + var outputShape = _this.computeOutputShape(inputShape); + var output = void 0; + var outputDType_1 = guessOutputDType(inputs); + _this.warnOnIncompatibleInputShape(Array.isArray(inputs) ? inputShape[0] : + inputShape); + if (outputShape != null && outputShape.length > 0 && + Array.isArray(outputShape[0])) { + output = outputShape + .map(function (shape, index) { return new SymbolicTensor(outputDType_1, shape, _this, toList(inputs), kwargs, _this.name, index); }); + } + else { + output = new SymbolicTensor(outputDType_1, outputShape, _this, toList(inputs), kwargs, _this.name); + } + _this.addInboundNode(inputs, output, null, null, inputShape, outputShape, kwargs); + if (_this.activityRegularizer != null) { + throw new NotImplementedError('Layer invocation in the presence of activity ' + + 'regularizer(s) is not supported yet.'); + } + return output; + } + }); + }; + Layer.prototype.warnOnIncompatibleInputShape = function (inputShape) { + if (this.batchInputShape == null) { + return; + } + else if (inputShape.length !== this.batchInputShape.length) { + console.warn("The rank of the input tensor provided (shape: " + + (JSON.stringify(inputShape) + ") does not match that of the ") + + ("batchInputShape (" + JSON.stringify(this.batchInputShape) + ") ") + + ("of the layer " + this.name)); + } + else { + var dimMismatch_1 = false; + this.batchInputShape.forEach(function (dimension, i) { + if (dimension != null && inputShape[i] != null && + inputShape[i] !== dimension) { + dimMismatch_1 = true; + } + }); + if (dimMismatch_1) { + console.warn("The shape of the input tensor " + + ("(" + JSON.stringify(inputShape) + ") does not ") + + ("match the expectation of layer " + this.name + ": ") + + ("" + JSON.stringify(this.batchInputShape))); + } + } + }; + Object.defineProperty(Layer.prototype, "outputShape", { + get: function () { + if (this.inboundNodes == null || this.inboundNodes.length === 0) { + throw new AttributeError("The layer " + this.name + " has never been called and thus has no " + + "defined output shape."); + } + var allOutputShapes = []; + for (var _i = 0, _a = this.inboundNodes; _i < _a.length; _i++) { + var node = _a[_i]; + var shapeString = JSON.stringify(node.outputShapes); + if (allOutputShapes.indexOf(shapeString) === -1) { + allOutputShapes.push(shapeString); + } + } + if (allOutputShapes.length === 1) { + var outputShapes = this.inboundNodes[0].outputShapes; + if (Array.isArray(outputShapes) && Array.isArray(outputShapes[0]) && + outputShapes.length === 1) { + return outputShapes[0]; + } + else { + return outputShapes; + } + } + else { + throw new AttributeError("The layer " + this.name + " has multiple inbound nodes with different " + + "output shapes. Hence the notion of \"outut shape\" is ill-defined " + + "for the layer."); + } + }, + enumerable: true, + configurable: true + }); + Layer.prototype.countParams = function () { + if (!this.built) { + throw new RuntimeError("You tried to call countParams() on " + this.name + ", " + + "but the layer is not built yet. Build it first by calling " + + "build(batchInputShape)."); + } + return countParamsInWeights(this.weights); + }; + Layer.prototype.build = function (inputShape) { + this.built = true; + }; + Layer.prototype.getWeights = function (trainableOnly) { + if (trainableOnly === void 0) { trainableOnly = false; } + return batchGetValue(trainableOnly ? this.trainableWeights : this.weights); + }; + Layer.prototype.setWeights = function (weights) { + var _this = this; + tfc.tidy(function () { + var params = _this.weights; + if (params.length !== weights.length) { + throw new ValueError("You called setWeights(weights) on layer \"" + _this.name + "\" " + + ("with a weight list of length " + weights.length + ", ") + + ("but the layer was expecting " + params.length + " weights. ") + + ("Provided weights: " + weights + "...")); + } + if (params.length === 0) { + return; + } + var weightValueTuples = []; + var paramValues = batchGetValue(params); + for (var i = 0; i < paramValues.length; ++i) { + var pv = paramValues[i]; + var p = params[i]; + var w = weights[i]; + if (!tfc.util.arraysEqual(pv.shape, w.shape)) { + throw new ValueError("Layer weight shape " + pv.shape + " " + + ("not compatible with provided weight shape " + w.shape)); + } + weightValueTuples.push([p, w]); + } + batchSetValue(weightValueTuples); + }); + }; + Layer.prototype.addWeight = function (name, shape, dtype, initializer, regularizer, trainable, constraint) { + if (this._addedWeightNames.indexOf(name) !== -1) { + throw new ValueError("Duplicate weight name " + name + " for layer " + this.name); + } + this._addedWeightNames.push(name); + if (dtype == null) { + dtype = 'float32'; + } + var weight = new LayerVariable(initializer.apply(shape, dtype), dtype, name, trainable, constraint); + if (regularizer != null) { + this.addLoss(function () { return regularizer.apply(weight.read()); }); + } + if (trainable == null) { + trainable = true; + } + if (trainable) { + this._trainableWeights.push(weight); + } + else { + this._nonTrainableWeights.push(weight); + } + return weight; + }; + Layer.prototype.addLoss = function (losses) { + if (losses == null || Array.isArray(losses) && losses.length === 0) { + return; + } + losses = toList(losses); + if (this._losses !== undefined && this._losses !== null) { + (_a = this.losses).push.apply(_a, losses); + } + var _a; + }; + Layer.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + Layer.prototype.computeMask = function (inputs, mask) { + var _this = this; + if (!this.supportsMasking) { + if (mask != null) { + if (Array.isArray(mask)) { + mask.forEach(function (maskElement) { + if (maskElement != null) { + throw new TypeError("Layer " + _this.name + " does not support masking," + + 'but was passed an inputMask.'); + } + }); + } + else { + throw new TypeError("Layer " + this.name + " does not support masking," + + 'but was passed an inputMask.'); + } + } + return null; + } + return mask; + }; + Layer.prototype.addInboundNode = function (inputTensors, outputTensors, inputMasks, outputMasks, inputShapes, outputShapes, kwargs) { + if (kwargs === void 0) { kwargs = null; } + var inputTensorList = toList(inputTensors); + outputTensors = toList(outputTensors); + inputMasks = toList(inputMasks); + outputMasks = toList(outputMasks); + inputShapes = normalizeShapeList(inputShapes); + outputShapes = normalizeShapeList(outputShapes); + var inboundLayers = []; + var nodeIndices = []; + var tensorIndices = []; + for (var _i = 0, inputTensorList_1 = inputTensorList; _i < inputTensorList_1.length; _i++) { + var x = inputTensorList_1[_i]; + inboundLayers.push(x.sourceLayer); + nodeIndices.push(x.nodeIndex); + tensorIndices.push(x.tensorIndex); + } + new Node({ + outboundLayer: this, + inboundLayers: inboundLayers, + nodeIndices: nodeIndices, + tensorIndices: tensorIndices, + inputTensors: inputTensorList, + outputTensors: outputTensors, + inputMasks: inputMasks, + outputMasks: outputMasks, + inputShapes: inputShapes, + outputShapes: outputShapes + }, kwargs); + for (var i = 0; i < outputTensors.length; i++) { + outputTensors[i].sourceLayer = this; + outputTensors[i].nodeIndex = this.inboundNodes.length - 1; + outputTensors[i].tensorIndex = i; + } + }; + Layer.prototype.getConfig = function () { + var config = { name: this.name, trainable: this.trainable }; + if (this.batchInputShape != null) { + config['batchInputShape'] = this.batchInputShape; + } + if (this.dtype != null) { + config['dtype'] = this.dtype; + } + return config; + }; + return Layer; + }(tfc.serialization.Serializable)); + function collectInputShape(inputTensors) { + inputTensors = + toList(inputTensors); + var shapes = []; + for (var _i = 0, inputTensors_1 = inputTensors; _i < inputTensors_1.length; _i++) { + var x = inputTensors_1[_i]; + shapes.push(x.shape); + } + return singletonOrArray(shapes); + } + function guessOutputDType(inputTensors) { + return 'float32'; + } + function getSourceInputs(tensor, layer, nodeIndex) { + if (layer == null || (nodeIndex != null && nodeIndex > 0)) { + layer = tensor.sourceLayer; + nodeIndex = tensor.nodeIndex; + } + if (layer.inboundNodes.length === 0) { + return [tensor]; + } + else { + var node = layer.inboundNodes[nodeIndex]; + if (node.inboundLayers.length === 0) { + return node.inputTensors; + } + else { + var sourceTensors = []; + for (var i = 0; i < node.inboundLayers.length; i++) { + var x = node.inputTensors[i]; + var layer_1 = node.inboundLayers[i]; + var nodeIndex_1 = node.nodeIndices[i]; + var previousSources = getSourceInputs(x, layer_1, nodeIndex_1); + for (var _i = 0, previousSources_1 = previousSources; _i < previousSources_1.length; _i++) { + var x_1 = previousSources_1[_i]; + if (sourceTensors.indexOf(x_1) === -1) { + sourceTensors.push(x_1); + } + } + } + return sourceTensors; + } + } + } + + var InputLayer = (function (_super) { + __extends(InputLayer, _super); + function InputLayer(config) { + var _this = _super.call(this, { + dtype: config.dtype, + name: config.name != null ? config.name : getUid('input').toString() + }) || this; + if (config.batchSize == null) { + config.batchSize = null; + } + if (config.sparse == null) { + config.sparse = false; + } + _this.trainable = false; + _this.built = true; + _this.sparse = config.sparse; + if (config.inputShape != null && config.batchInputShape != null) { + throw new ValueError('Only provide the inputShape OR ' + + 'batchInputShape argument to inputLayer, not both at the same time.'); + } + var batchInputShape = config.batchInputShape; + if (batchInputShape == null) { + if (config.inputShape == null) { + throw new ValueError('An InputLayer should be passed either a ' + + '`batchInputShape` or an `inputShape`.'); + } + else { + batchInputShape = [config.batchSize].concat(config.inputShape); + } + } + else { + if (config.batchSize != null) { + throw new ValueError('Cannot specify batchSize if batchInputShape is' + + 'specified when creating an InputLayer.'); + } + } + var dtype = config.dtype || 'float32'; + _this.batchInputShape = batchInputShape; + _this.dtype = dtype; + _this.inputSpec = [{ shape: batchInputShape }]; + var inputTensor = new SymbolicTensor(_this.dtype, _this.batchInputShape, _this, [], {}, _this.name); + inputTensor.nodeIndex = 0; + inputTensor.tensorIndex = 0; + new Node({ + outboundLayer: _this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: [inputTensor], + outputTensors: [inputTensor], + inputMasks: [null], + outputMasks: [null], + inputShapes: [batchInputShape], + outputShapes: [batchInputShape] + }); + return _this; + } + InputLayer.prototype.apply = function (inputs, kwargs) { + throw new ValueError('Cannot pass any input to an ' + + ("InputLayer's apply() method. InputLayer name: " + this.name)); + }; + InputLayer.prototype.getConfig = function () { + return { + batchInputShape: this.batchInputShape, + dtype: this.dtype, + sparse: this.sparse, + name: this.name + }; + }; + InputLayer.className = 'InputLayer'; + return InputLayer; + }(Layer)); + tfc.serialization.SerializationMap.register(InputLayer); + function Input(config) { + if (config.batchShape == null && config.shape == null) { + throw new Error('Please provide to Input either a `shape`' + + ' or a `batchShape` argument. Note that ' + + '`shape` does not include the batch ' + + 'dimension.'); + } + if (config.batchShape != null && config.shape != null) { + throw new ValueError('Please provide either a `shape` or `batchShape` ' + + 'argument to Input, but not both.'); + } + var batchShape = config.batchShape; + if (config.shape != null && batchShape == null) { + batchShape = [null].concat(config.shape); + } + var dtype = config.dtype; + if (dtype == null) { + dtype = 'float32'; + } + var inputLayer = new InputLayer({ + batchInputShape: batchShape, + name: config.name, + dtype: dtype, + sparse: config.sparse + }); + var outputs = inputLayer.inboundNodes[0].outputTensors; + return outputs[0]; + } + + function resolveScalarsInLogs(logs) { + return __awaiter(this, void 0, void 0, function () { + var promises, keys, scalarsToDispose, key, value, valueScalar, values, i; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (logs == null) { + return [2]; + } + promises = []; + keys = []; + scalarsToDispose = []; + for (key in logs) { + value = logs[key]; + if (typeof value !== 'number') { + valueScalar = value; + promises.push(valueScalar.data()); + keys.push(key); + scalarsToDispose.push(valueScalar); + } + } + return [4, Promise.all(promises)]; + case 1: + values = _a.sent(); + for (i = 0; i < values.length; ++i) { + logs[keys[i]] = values[i][0]; + } + tfc.dispose(scalarsToDispose); + return [2]; + } + }); + }); + } + function disposeTensorsInLogs(logs) { + if (logs == null) { + return; + } + for (var key in logs) { + var value = logs[key]; + if (typeof value !== 'number') { + value.dispose(); + } + } + } + + var BaseCallback = (function () { + function BaseCallback() { + this.validationData = null; + } + BaseCallback.prototype.setParams = function (params) { + this.params = params; + }; + BaseCallback.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { + return [2]; + }); }); + }; + BaseCallback.prototype.setModel = function (model) { + }; + return BaseCallback; + }()); + var CallbackList = (function () { + function CallbackList(callbacks, queueLength) { + if (queueLength === void 0) { queueLength = 10; } + if (callbacks == null) { + callbacks = []; + } + this.callbacks = callbacks; + this.queueLength = queueLength; + } + CallbackList.prototype.append = function (callback) { + this.callbacks.push(callback); + }; + CallbackList.prototype.setParams = function (params) { + for (var _i = 0, _a = this.callbacks; _i < _a.length; _i++) { + var callback = _a[_i]; + callback.setParams(params); + } + }; + CallbackList.prototype.setModel = function (model) { + for (var _i = 0, _a = this.callbacks; _i < _a.length; _i++) { + var callback = _a[_i]; + callback.setModel(model); + } + }; + CallbackList.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onEpochBegin(epoch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onEpochEnd(epoch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onBatchBegin(batch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onBatchEnd(batch, logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onTrainBegin(logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + CallbackList.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { + var _i, _a, callback; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (logs == null) { + logs = {}; + } + _i = 0, _a = this.callbacks; + _b.label = 1; + case 1: + if (!(_i < _a.length)) return [3, 4]; + callback = _a[_i]; + return [4, callback.onTrainEnd(logs)]; + case 2: + _b.sent(); + _b.label = 3; + case 3: + _i++; + return [3, 1]; + case 4: return [2]; + } + }); + }); + }; + return CallbackList; + }()); + var BaseLogger = (function (_super) { + __extends(BaseLogger, _super); + function BaseLogger() { + return _super.call(this) || this; + } + BaseLogger.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.seen = 0; + this.totals = {}; + return [2]; + }); + }); + }; + BaseLogger.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var batchSize, _loop_1, this_1, key; + return __generator(this, function (_a) { + if (logs == null) { + logs = {}; + } + batchSize = logs['size'] == null ? 0 : logs['size']; + this.seen += batchSize; + _loop_1 = function (key) { + var value = logs[key]; + if (typeof value === 'number') { + if (!this_1.totals.hasOwnProperty(key)) { + this_1.totals[key] = 0; + } + this_1.totals[key] = this_1.totals[key] + value * batchSize; + } + else { + var oldTotalsToDispose = void 0; + if (key in this_1.totals) { + oldTotalsToDispose = this_1.totals[key]; + } + else { + this_1.totals[key] = getScalar(0); + } + this_1.totals[key] = tfc.tidy(function () { return tfc.add(_this.totals[key], tfc.mul(value, getScalar(batchSize))); }); + if (oldTotalsToDispose != null) { + oldTotalsToDispose.dispose(); + } + } + }; + this_1 = this; + for (key in logs) { + _loop_1(key); + } + return [2]; + }); + }); + }; + BaseLogger.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var _loop_2, this_2, _i, _a, key; + return __generator(this, function (_b) { + if (logs != null) { + _loop_2 = function (key) { + if (this_2.totals[key] == null) { + return "continue"; + } + if (typeof this_2.totals[key] === 'number') { + logs[key] = this_2.totals[key] / this_2.seen; + } + else { + tfc.tidy(function () { + logs[key] = tfc.mul(tfc.div(getScalar(1), getScalar(_this.seen)), _this.totals[key]); + _this.totals[key].dispose(); + tfc.keep(logs[key]); + }); + } + }; + this_2 = this; + for (_i = 0, _a = this.params['metrics']; _i < _a.length; _i++) { + key = _a[_i]; + _loop_2(key); + } + } + return [2]; + }); + }); + }; + return BaseLogger; + }(BaseCallback)); + var History = (function (_super) { + __extends(History, _super); + function History() { + return _super !== null && _super.apply(this, arguments) || this; + } + History.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + this.epoch = []; + this.history = {}; + return [2]; + }); + }); + }; + History.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + var key; + return __generator(this, function (_a) { + if (logs == null) { + logs = {}; + } + this.epoch.push(epoch); + for (key in logs) { + if (this.history[key] == null) { + this.history[key] = []; + } + this.history[key].push(logs[key]); + } + return [2]; + }); + }); + }; + History.prototype.syncData = function () { + return __awaiter(this, void 0, void 0, function () { + var promises, keys, indices, key, valueArray, i, valueScalar, values, n, tensorToDispose; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + promises = []; + keys = []; + indices = []; + for (key in this.history) { + valueArray = this.history[key]; + for (i = 0; i < valueArray.length; ++i) { + if (typeof valueArray[i] !== 'number') { + valueScalar = valueArray[i]; + promises.push(valueScalar.data()); + keys.push(key); + indices.push(i); + } + } + } + return [4, Promise.all(promises)]; + case 1: + values = _a.sent(); + for (n = 0; n < values.length; ++n) { + tensorToDispose = this.history[keys[n]][indices[n]]; + tensorToDispose.dispose(); + this.history[keys[n]][indices[n]] = values[n][0]; + } + return [2]; + } + }); + }); + }; + return History; + }(BaseCallback)); + var CustomCallback = (function (_super) { + __extends(CustomCallback, _super); + function CustomCallback(config) { + var _this = _super.call(this) || this; + _this.trainBegin = config.onTrainBegin; + _this.trainEnd = config.onTrainEnd; + _this.epochBegin = config.onEpochBegin; + _this.epochEnd = config.onEpochEnd; + _this.batchBegin = config.onBatchBegin; + _this.batchEnd = config.onBatchEnd; + return _this; + } + CustomCallback.prototype.onEpochBegin = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.epochBegin != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.epochBegin(epoch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onEpochEnd = function (epoch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.epochEnd != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.epochEnd(epoch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onBatchBegin = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.batchBegin != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.batchBegin(batch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onBatchEnd = function (batch, logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.batchEnd != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.batchEnd(batch, logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onTrainBegin = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.trainBegin != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.trainBegin(logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + CustomCallback.prototype.onTrainEnd = function (logs) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!(this.trainEnd != null)) return [3, 3]; + return [4, resolveScalarsInLogs(logs)]; + case 1: + _a.sent(); + return [4, this.trainEnd(logs)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: return [2]; + } + }); + }); + }; + return CustomCallback; + }(BaseCallback)); + function standardizeCallbacks(callbacks) { + if (callbacks == null) { + return null; + } + if (callbacks instanceof BaseCallback) { + return [callbacks]; + } + if (Array.isArray(callbacks) && callbacks[0] instanceof BaseCallback) { + return callbacks; + } + var callbackConfigs = toList(callbacks); + return callbackConfigs.map(function (callbackConfig) { return new CustomCallback(callbackConfig); }); + } + + function l2Normalize(x, axis) { + return tfc.tidy(function () { + var squareSum = tfc.sum(square(x), axis, true); + var epsilonTensor = tfc.mul(tfc.scalar(epsilon()), tfc.onesLike(x)); + var norm = tfc.sqrt(tfc.maximum(squareSum, epsilonTensor)); + return tfc.div(x, norm); + }); + } + function meanSquaredError(yTrue, yPred) { + return tfc.tidy(function () { return tfc.mean(square(tfc.sub(yPred, yTrue)), -1); }); + } + function meanAbsoluteError(yTrue, yPred) { + return tfc.tidy(function () { return tfc.mean(tfc.abs(tfc.sub(yPred, yTrue)), -1); }); + } + function meanAbsolutePercentageError(yTrue, yPred) { + return tfc.tidy(function () { + var diff = tfc.sub(yTrue, yPred); + var clippedTrue = tfc.clipByValue(tfc.abs(yTrue), epsilon(), Number.MAX_VALUE); + var absResult = tfc.abs(tfc.div(diff, clippedTrue)); + return tfc.mul(getScalar(100.0), tfc.mean(absResult, -1)); + }); + } + function meanSquaredLogarithmicError(yTrue, yPred) { + return tfc.tidy(function () { + var one = getScalar(1.0); + var clippedPred = tfc.clipByValue(yPred, epsilon(), Number.MAX_VALUE); + var firstLog = tfc.log(tfc.add(one, clippedPred)); + var clippedTrue = tfc.clipByValue(yTrue, epsilon(), Number.MAX_VALUE); + var secondLog = tfc.log(tfc.add(one, clippedTrue)); + return tfc.mean(square(tfc.sub(firstLog, secondLog)), -1); + }); + } + function squaredHinge(yTrue, yPred) { + return tfc.tidy(function () { + var zeroTensor = getScalar(0.0); + var one = getScalar(1.0); + var maxResult = tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred))); + return tfc.mean(square(maxResult), -1); + }); + } + function hinge(yTrue, yPred) { + return tfc.tidy(function () { + var zeroTensor = getScalar(0.0); + var one = getScalar(1.0); + var maxResult = tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred))); + return tfc.mean(maxResult, -1); + }); + } + function categoricalHinge(yTrue, yPred) { + return tfc.tidy(function () { + var zeroTensor = getScalar(0.0); + var one = getScalar(1.0); + var pos = tfc.sum(tfc.mul(yTrue, yPred), -1); + var neg = tfc.max(tfc.mul(tfc.sub(one, yTrue), yPred), -1); + return tfc.maximum(zeroTensor, tfc.add(one, tfc.sub(neg, pos))); + }); + } + function logcosh(yTrue, yPred) { + return tfc.tidy(function () { + var log2 = getScalar(Math.log(2.0)); + var predictionDiff = tfc.sub(yPred, yTrue); + var logcoshResult = tfc.sub(tfc.add(predictionDiff, tfc.softplus(tfc.mul(getScalar(-2.0), predictionDiff))), log2); + return tfc.mean(logcoshResult, -1); + }); + } + function categoricalCrossentropy(target, output, fromLogits) { + if (fromLogits === void 0) { fromLogits = false; } + return tfc.tidy(function () { + if (fromLogits) { + output = tfc.softmax(output); + } + else { + var outputSum = tfc.sum(output, output.shape.length - 1, true); + output = tfc.div(output, outputSum); + } + output = tfc.clipByValue(output, epsilon(), 1 - epsilon()); + return tfc.neg(tfc.sum(tfc.mul(target.toFloat(), tfc.log(output)), output.shape.length - 1)); + }); + } + function sparseCategoricalCrossentropy(target, output, fromLogits) { + if (fromLogits === void 0) { fromLogits = false; } + return tfc.tidy(function () { + var flatTarget = tfc.floor(flatten(target)).toInt(); + var outputShape = output.shape; + var oneHotTarget = tfc.oneHot(flatTarget, outputShape[outputShape.length - 1]) + .reshape(outputShape); + return categoricalCrossentropy(oneHotTarget, output, fromLogits); + }); + } + function sigmoidCrossEntropyWithLogits(target, output) { + return tfc.tidy(function () { + var maxOutput = tfc.maximum(output, tfc.zerosLike(output)); + var outputXTarget = tfc.mul(output, target); + var sigmoidOutput = tfc.log(tfc.add(getScalar(1), tfc.exp(tfc.neg(tfc.abs(output))))); + var result = tfc.add(tfc.sub(maxOutput, outputXTarget), sigmoidOutput); + return result; + }); + } + function binaryCrossentropy(yTrue, yPred) { + return tfc.tidy(function () { + var y; + y = tfc.clipByValue(yPred, epsilon(), 1 - epsilon()); + y = tfc.log(tfc.div(y, tfc.sub(tfc.onesLike(y), y))); + return tfc.mean(sigmoidCrossEntropyWithLogits(yTrue, y), -1); + }); + } + function kullbackLeiblerDivergence(yTrue, yPred) { + return tfc.tidy(function () { + var clippedTrue = tfc.clipByValue(yTrue, epsilon(), 1); + var clippedPred = tfc.clipByValue(yPred, epsilon(), 1); + return tfc.sum(tfc.mul(yTrue, tfc.log(tfc.div(clippedTrue, clippedPred))), -1); + }); + } + function poisson(yTrue, yPred) { + return tfc.tidy(function () { + var logPred = tfc.log(tfc.add(getScalar(epsilon()), yPred)); + return tfc.mean(tfc.sub(yPred, tfc.mul(yTrue, logPred)), -1); + }); + } + function cosineProximity(yTrue, yPred) { + return tfc.tidy(function () { + var trueNormalized = l2Normalize(yTrue, -1); + var predNormalized = l2Normalize(yPred, -1); + var trueXPred = tfc.mul(trueNormalized, predNormalized); + return tfc.neg(tfc.sum(trueXPred, -1)); + }); + } + function get(identifierOrFn) { + var lossesMap = { + meanSquaredError: meanSquaredError, + meanAbsoluteError: meanAbsoluteError, + meanAbsolutePercentageError: meanAbsolutePercentageError, + meanSquaredLogarithmicError: meanSquaredLogarithmicError, + squaredHinge: squaredHinge, + hinge: hinge, + categoricalHinge: categoricalHinge, + logcosh: logcosh, + categoricalCrossentropy: categoricalCrossentropy, + sparseCategoricalCrossentropy: sparseCategoricalCrossentropy, + binaryCrossentropy: binaryCrossentropy, + kullbackLeiblerDivergence: kullbackLeiblerDivergence, + poisson: poisson, + cosineProximity: cosineProximity + }; + if (typeof identifierOrFn === 'string') { + if (identifierOrFn in lossesMap) { + return lossesMap[identifierOrFn]; + } + throw new ValueError("Unknown loss " + identifierOrFn); + } + else { + return identifierOrFn; + } + } + + function binaryAccuracy(yTrue, yPred) { + return tfc.tidy(function () { + var threshold = tfc.mul(getScalar(0.5), tfc.onesLike(yPred)); + var yPredThresholded = cast(tfc.greater(yPred, threshold), yTrue.dtype); + return tfc.mean(tfc.equal(yTrue, yPredThresholded), -1); + }); + } + function categoricalAccuracy(yTrue, yPred) { + return tfc.tidy(function () { return cast(tfc.equal(tfc.argMax(yTrue, -1), tfc.argMax(yPred, -1)), 'float32'); }); + } + function binaryCrossentropy$1(yTrue, yPred) { + return binaryCrossentropy(yTrue, yPred); + } + function sparseCategoricalAccuracy(yTrue, yPred) { + throw new NotImplementedError(); + } + var mse$1 = meanSquaredError; + var MSE$1 = meanSquaredError; + var mae$1 = meanAbsoluteError; + var MAE$1 = meanAbsoluteError; + var mape$1 = meanAbsolutePercentageError; + var MAPE$1 = meanAbsolutePercentageError; + var categoricalCrossentropy$1 = categoricalCrossentropy; + var cosine$1 = cosineProximity; + var sparseCategoricalCrossentropy$1 = sparseCategoricalCrossentropy; + function get$1(identifier) { + var metricsMap = { + binaryAccuracy: binaryAccuracy, + categoricalAccuracy: categoricalAccuracy, + categoricalCrossentropy: categoricalCrossentropy$1, + sparseCategoricalCrossentropy: sparseCategoricalCrossentropy$1, + mse: mse$1, + MSE: MSE$1, + mae: mae$1, + MAE: MAE$1, + mape: mape$1, + MAPE: MAPE$1, + cosine: cosine$1, + }; + if (typeof identifier === 'string' && identifier in metricsMap) { + return metricsMap[identifier]; + } + else if (typeof identifier !== 'string' && identifier != null) { + return identifier; + } + else { + throw new ValueError("Unknown metric " + identifier); + } + } + + function getOptimizer(identifier) { + var optimizerMap = { + 'Adagrad': function () { return tfc.train.adagrad(0.01); }, + 'Adadelta': function () { return tfc.train.adadelta(1, 0.95, epsilon()); }, + 'Adam': function () { return tfc.train.adam(0.001, 0.9, 0.999, epsilon()); }, + 'Adamax': function () { return tfc.train.adamax(0.002, 0.9, 0.999, epsilon(), 0); }, + 'RMSProp': function () { return tfc.train.rmsprop(0.001, 0.9, 0, epsilon()); }, + 'SGD': function () { return tfc.train.sgd(0.01); } + }; + optimizerMap['adagrad'] = optimizerMap['Adagrad']; + optimizerMap['adadelta'] = optimizerMap['Adadelta']; + optimizerMap['adam'] = optimizerMap['Adam']; + optimizerMap['adamax'] = optimizerMap['Adamax']; + optimizerMap['rmsprop'] = optimizerMap['RMSProp']; + optimizerMap['sgd'] = optimizerMap['SGD']; + if (identifier in optimizerMap) { + return optimizerMap[identifier](); + } + throw new ValueError("Unknown Optimizer " + identifier); + } + + function printSummary(model, lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + var sequentialLike = isModelSequentialLike(model); + var toDisplay = ['Layer (type)', 'Output shape', 'Param #']; + if (sequentialLike) { + lineLength = lineLength || 65; + positions = positions || [0.45, 0.85, 1]; + } + else { + lineLength = lineLength || 98; + positions = positions || [0.33, 0.55, 0.67, 1]; + } + if (positions[positions.length - 1] <= 1) { + positions = positions.map(function (p) { return Math.floor(lineLength * p); }); + } + var relevantNodes; + if (!sequentialLike) { + toDisplay.push('Receives inputs'); + relevantNodes = []; + for (var depth in model.nodesByDepth) { + relevantNodes.push.apply(relevantNodes, model.nodesByDepth[depth]); + } + } + printFn('_'.repeat(lineLength)); + printRow(toDisplay, positions, printFn); + printFn('='.repeat(lineLength)); + var layers = model.layers; + for (var i = 0; i < layers.length; ++i) { + if (sequentialLike) { + printLayerSummary(layers[i], positions, printFn); + } + else { + printLayerSummaryWithConnections(layers[i], positions, relevantNodes, printFn); + } + printFn((i === layers.length - 1 ? '=' : '_').repeat(lineLength)); + } + model.checkTrainableWeightsConsistency(); + var trainableCount; + if (model.collectedTrainableWeights != null) { + trainableCount = + countParamsInWeights(model.collectedTrainableWeights); + } + else { + trainableCount = countParamsInWeights(model.trainableWeights); + } + var nonTrainableCount = countParamsInWeights(model.nonTrainableWeights); + printFn("Total params: " + (trainableCount + nonTrainableCount)); + printFn("Trainable params: " + trainableCount); + printFn("Non-trainable params: " + nonTrainableCount); + printFn('_'.repeat(lineLength)); + } + function isModelSequentialLike(model) { + var sequentialLike = true; + var nodesByDepth = []; + var nodes = []; + for (var depth in model.nodesByDepth) { + nodesByDepth.push(model.nodesByDepth[depth]); + } + for (var _i = 0, nodesByDepth_1 = nodesByDepth; _i < nodesByDepth_1.length; _i++) { + var depthNodes = nodesByDepth_1[_i]; + if (depthNodes.length > 1 || + depthNodes.length === 1 && depthNodes[0].inboundLayers.length > 1) { + sequentialLike = false; + break; + } + nodes.push.apply(nodes, depthNodes); + } + if (sequentialLike) { + for (var _a = 0, _b = model.layers; _a < _b.length; _a++) { + var layer = _b[_a]; + var flag = false; + for (var _c = 0, _d = layer.inboundNodes; _c < _d.length; _c++) { + var node = _d[_c]; + if (nodes.indexOf(node) !== -1) { + if (flag) { + sequentialLike = false; + break; + } + else { + flag = true; + } + } + } + if (!sequentialLike) { + break; + } + } + } + return sequentialLike; + } + function printRow(fields, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + var line = ''; + for (var i = 0; i < fields.length; ++i) { + if (i > 0) { + line = line.slice(0, line.length - 1) + ' '; + } + line += fields[i]; + line = line.slice(0, positions[i]); + line += ' '.repeat(positions[i] - line.length); + } + printFn(line); + } + function printLayerSummary(layer, positions, printFn) { + var outputShape; + try { + outputShape = JSON.stringify(layer.outputShape); + } + catch (err) { + outputShape = 'multiple'; + } + var name = layer.name; + var className = layer.getClassName(); + var fields = [name + " (" + className + ")", outputShape, layer.countParams().toString()]; + printRow(fields, positions, printFn); + } + function printLayerSummaryWithConnections(layer, positions, relevantNodes, printFn) { + var outputShape; + try { + outputShape = JSON.stringify(layer.outputShape); + } + catch (err) { + outputShape = 'multiple'; + } + var connections = []; + for (var _i = 0, _a = layer.inboundNodes; _i < _a.length; _i++) { + var node = _a[_i]; + if (relevantNodes != null && relevantNodes.length > 0 && + relevantNodes.indexOf(node) === -1) { + continue; + } + for (var i = 0; i < node.inboundLayers.length; ++i) { + var inboundLayer = node.inboundLayers[i].name; + var inboundLayerIndex = node.nodeIndices[i]; + var inboundTensorIndex = node.tensorIndices[i]; + connections.push(inboundLayer + "[" + inboundLayerIndex + "][" + inboundTensorIndex + "]"); + } + } + var name = layer.name; + var className = layer.getClassName(); + var firstConnection = connections.length === 0 ? '' : connections[0]; + var fields = [ + name + " (" + className + ")", outputShape, layer.countParams().toString(), + firstConnection + ]; + printRow(fields, positions, printFn); + for (var i = 1; i < connections.length; ++i) { + printRow(['', '', '', connections[i]], positions, printFn); + } + } + + function deserialize(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return deserializeKerasObject(config, tfc.serialization.SerializationMap.getMap().classNameMap, customObjects, 'layer'); + } + + function isArrayItemInputOrOutputName(key, index, value) { + return (key === 'inboundNodes' || key === 'outputLayers' || + key === 'inputLayers') && + index === 0 && typeof value === 'string'; + } + function convertPythonicToTs(pythonicConfig, key) { + if (pythonicConfig === null) { + return null; + } + else if (typeof pythonicConfig === 'string') { + return toCamelCase(pythonicConfig); + } + else if ((typeof pythonicConfig === 'number') || + (typeof pythonicConfig === 'boolean')) { + return pythonicConfig; + } + else if (pythonicConfig instanceof Array) { + var tsArray = []; + var arrayLength = pythonicConfig.length; + for (var i = 0; i < arrayLength; ++i) { + var item = pythonicConfig[i]; + if (isArrayItemInputOrOutputName(key, i, item)) { + tsArray.push(item); + } + else { + tsArray.push(convertPythonicToTs(item, key)); + } + } + return tsArray; + } + else { + var tsDict = {}; + for (var _i = 0, _a = Object.keys(pythonicConfig); _i < _a.length; _i++) { + var pythonicKey = _a[_i]; + var pythonicValue = pythonicConfig[pythonicKey]; + if (pythonicKey === 'name' && typeof pythonicValue === 'string') { + tsDict[pythonicKey] = pythonicValue; + } + else { + var tsKey = toCamelCase(pythonicKey); + tsDict[tsKey] = convertPythonicToTs(pythonicValue, tsKey); + } + } + return tsDict; + } + } + function convertTsToPythonic(tsConfig, key) { + if (tsConfig === null || tsConfig === undefined) { + return null; + } + else if (typeof tsConfig === 'string') { + return toSnakeCase(tsConfig); + } + else if ((typeof tsConfig === 'number') || (typeof tsConfig === 'boolean')) { + return tsConfig; + } + else if (tsConfig instanceof Array) { + var pyArray = []; + var arrayLength = tsConfig.length; + for (var i = 0; i < arrayLength; ++i) { + var item = tsConfig[i]; + if (isArrayItemInputOrOutputName(key, i, item)) { + pyArray.push(item); + } + else { + pyArray.push(convertTsToPythonic(item, key)); + } + } + return pyArray; + } + else { + var pyDict = {}; + for (var _i = 0, _a = Object.keys(tsConfig); _i < _a.length; _i++) { + var tsKey = _a[_i]; + var tsValue = tsConfig[tsKey]; + var pyKey = toSnakeCase(tsKey); + if ((tsKey === 'name' || tsKey === 'className') && + typeof tsValue === 'string') { + pyDict[pyKey] = tsValue; + } + else { + pyDict[pyKey] = convertTsToPythonic(tsValue, tsKey); + } + } + return pyDict; + } + } + + var version = '0.7.2'; + + function preprocessWeightsForLoading(layer, weights, originalKerasVersion, originalBackend) { + if (!originalKerasVersion.startsWith('2.')) { + throw new ValueError('Unsupported Keras version in weights being loaded: ' + + originalKerasVersion); + } + return weights; + } + function loadTensor(dtype, shape, value) { + var dataType = stringToDType(dtype); + return tfc.Tensor.make(shape, { values: shape.length === 0 ? value : tfc.util.flatten(value) }, dataType); + } + function loadWeightsFromJson(weightsJSON, layers, skipMismatch) { + if (skipMismatch === void 0) { skipMismatch = false; } + var originalKerasVersion = weightsJSON['keras_version']; + var originalBackend = weightsJSON['backend']; + var layerNames = layers.map(function (layer) { return layer.name; }); + var index = {}; + for (var _i = 0, layers_1 = layers; _i < layers_1.length; _i++) { + var layer = layers_1[_i]; + if (layer.name != null) { + if (index[layer.name] == null) { + index[layer.name] = []; + } + index[layer.name].push(layer); + } + } + var nameToWeights = weightsJSON['weights']; + var weightValueTuples = []; + for (var k = 0; k < layerNames.length; ++k) { + var name_1 = layerNames[k]; + var layerWeights = nameToWeights[name_1]; + if (layerWeights == null) { + layerWeights = []; + } + var weightValues = []; + for (var n = 0; n < layerWeights.length; ++n) { + var weightEntry = layerWeights[n]; + weightValues.push(new LayerVariable(loadTensor(weightEntry['dtype'], weightEntry['shape'], weightEntry['value']))); + } + for (var _a = 0, _b = index[name_1]; _a < _b.length; _a++) { + var layer = _b[_a]; + var symbolicWeights = layer.weights; + weightValues = preprocessWeightsForLoading(layer, weightValues, originalKerasVersion, originalBackend); + if (weightValues.length !== symbolicWeights.length) { + if (skipMismatch) { + console.warn("Skipping loading of weights of layer " + layer.name + " " + + ("due to mismatch in number of weights: (" + weightValues.length + " ") + + ("vs " + symbolicWeights.length + ").")); + } + else { + throw new ValueError("Layer #" + k + " (named \"" + layer.name + "\") expects " + + (symbolicWeights.length + " weight(s), but the saved weights ") + + ("have " + weightValues.length + " element(s).")); + } + } + for (var i = 0; i < weightValues.length; ++i) { + if (skipMismatch) { + if (!tfc.util.arraysEqual(symbolicWeights[i].shape, weightValues[i].shape)) { + console.warn("Skipping loading of weights for layer " + layer.name + " due " + + ("to mismatch in shape (" + symbolicWeights[i].shape + " vs ") + + (weightValues[i].shape + ")")); + continue; + } + } + weightValueTuples.push([symbolicWeights[i], weightValues[i].read()]); + } + } + } + batchSetValue(weightValueTuples); + } + function loadWeightsFromNamedTensorMap(weights, layers) { + var nameToWeight = {}; + var totalWeightsCount = 0; + for (var _i = 0, layers_2 = layers; _i < layers_2.length; _i++) { + var layer = layers_2[_i]; + for (var _a = 0, _b = layer.weights; _a < _b.length; _a++) { + var weight = _b[_a]; + if (nameToWeight[weight.originalName] != null) { + throw new ValueError("Duplicate weight name: " + weight.originalName); + } + nameToWeight[weight.originalName] = weight; + totalWeightsCount++; + } + } + var weightValueTuples = []; + for (var name_2 in weights) { + weightValueTuples.push([nameToWeight[name_2], weights[name_2]]); + delete nameToWeight[name_2]; + } + var unsetNames = []; + for (var name_3 in nameToWeight) { + unsetNames.push(name_3); + } + if (unsetNames.length > 0) { + throw new ValueError(unsetNames.length + " of " + totalWeightsCount + " weights are not set: " + + ("" + unsetNames)); + } + batchSetValue(weightValueTuples); + } + var Container = (function (_super) { + __extends(Container, _super); + function Container(config) { + var _this = _super.call(this, {}) || this; + _this.containerNodes = new Set(); + _this.name = config.name; + if (_this.name == null) { + var prefix = _this.getClassName().toLowerCase(); + _this.name = getUid(prefix); + } + _this.supportsMasking = false; + _this.trainable = true; + _this.updatable = true; + if (Array.isArray(config.inputs)) { + _this.inputs = config.inputs.slice(); + } + else { + _this.inputs = [config.inputs]; + } + if (Array.isArray(config.outputs)) { + _this.outputs = config.outputs.slice(); + } + else { + _this.outputs = [config.outputs]; + } + if (unique(_this.inputs).length !== _this.inputs.length) { + throw new ValueError('The list of inputs passed to the model is ' + + 'redundant. All inputs should only appear once. Found: ' + + _this.inputs.map(function (x) { return x.name; })); + } + if (unique(_this.outputs).length !== _this.outputs.length) { + console.warn('The list of outputs passed to the model is redundant. ' + + 'All outputs should only appear once. Found: ' + + _this.outputs.map(function (x) { return x.name; })); + } + _this.inputLayers = []; + _this.inputLayersNodeIndices = []; + _this.inputLayersTensorIndices = []; + _this.outputLayers = []; + _this.outputLayersNodeIndices = []; + _this.outputLayersTensorIndices = []; + _this.layers = []; + for (var _i = 0, _a = _this.outputs; _i < _a.length; _i++) { + var x = _a[_i]; + var layer = x.sourceLayer; + var nodeIndex = x.nodeIndex; + var tensorIndex = x.tensorIndex; + _this.outputLayers.push(layer); + _this.outputLayersNodeIndices.push(nodeIndex); + _this.outputLayersTensorIndices.push(tensorIndex); + } + for (var _b = 0, _c = _this.inputs; _b < _c.length; _b++) { + var x = _c[_b]; + var layer = x.sourceLayer; + var nodeIndex = x.nodeIndex; + var tensorIndex = x.tensorIndex; + assert(nodeIndex === 0, 'input layer has >1 nodes'); + assert(tensorIndex === 0, 'input layer has >1 tensors'); + _this.inputLayers.push(layer); + _this.inputLayersNodeIndices.push(nodeIndex); + _this.inputLayersTensorIndices.push(tensorIndex); + } + _this.inputNames = []; + _this.outputNames = []; + _this.feedInputShapes = []; + _this.feedInputNames = []; + _this.feedOutputNames = []; + for (var i = 0; i < _this.inputLayers.length; i++) { + var layer = _this.inputLayers[i]; + if (!(layer instanceof InputLayer)) { + throw new TypeError('Input layers to a Model must be InputLayer objects. ' + + ("Received inputs: " + config.inputs + ". ") + + ("Input " + i + " (0-based) originates ") + + ("from layer type " + layer.getClassName() + ".")); + } + _this.inputNames.push(layer.name); + _this.feedInputShapes.push(layer.batchInputShape); + _this.feedInputNames.push(layer.name); + } + for (var _d = 0, _e = _this.outputLayers; _d < _e.length; _d++) { + var layer = _e[_d]; + _this.outputNames.push(layer.name); + } + _this.internalInputShapes = _this.inputs.map(function (x) { return x.shape; }); + _this.internalOutputShapes = _this.outputs.map(function (x) { return x.shape; }); + var nodesDepths = {}; + var nodeIDToNode = {}; + var layersDepths = {}; + var layerIDToLayer = {}; + var layerIndices = {}; + var nodesInDecreasingDepth = []; + var buildMapOfGraph = function (tensor, finishedNodes, nodesInProgress, layer, nodeIndex, tensorIndex) { + if (layer == null || nodeIndex == null || tensorIndex == null) { + layer = tensor.sourceLayer; + nodeIndex = tensor.nodeIndex; + tensorIndex = tensor.tensorIndex; + } + var node = layer.inboundNodes[nodeIndex]; + if (nodesInProgress.indexOf(node) !== -1) { + throw new RuntimeError("The tensor " + tensor.name + " at layer \"" + layer.name + "\" " + + 'is part of a cycle.'); + } + if (finishedNodes.indexOf(node) !== -1) { + return; + } + _this.containerNodes.add(Container.nodeKey(layer, nodeIndex)); + if (!(layer.id in layerIndices)) { + layerIndices[layer.id] = Object.keys(layerIndices).length; + } + if (nodesInProgress.indexOf(node) === -1) { + nodesInProgress.push(node); + } + var numInboundLayers = node.inboundLayers.length; + for (var i = 0; i < numInboundLayers; i++) { + var x = node.inputTensors[i]; + var layer_1 = node.inboundLayers[i]; + var nodeIndex_1 = node.nodeIndices[i]; + var tensorIndex_1 = node.tensorIndices[i]; + buildMapOfGraph(x, finishedNodes, nodesInProgress, layer_1, nodeIndex_1, tensorIndex_1); + } + finishedNodes.push(node); + while (nodesInProgress.indexOf(node) >= 0) { + nodesInProgress.splice(nodesInProgress.indexOf(node), 1); + } + nodesInDecreasingDepth.push(node); + }; + var finishedNodes = []; + var nodesInProgress = []; + for (var _f = 0, _g = _this.outputs; _f < _g.length; _f++) { + var x = _g[_f]; + buildMapOfGraph(x, finishedNodes, nodesInProgress); + } + var reversedNodesInDecreasingDepth = nodesInDecreasingDepth.slice().reverse(); + for (var _h = 0, reversedNodesInDecreasingDepth_1 = reversedNodesInDecreasingDepth; _h < reversedNodesInDecreasingDepth_1.length; _h++) { + var node = reversedNodesInDecreasingDepth_1[_h]; + nodeIDToNode[node.id] = node; + if (!(node.id in nodesDepths)) { + nodesDepths[node.id] = 0; + } + var depth = nodesDepths[node.id]; + var previousDepth = (layersDepths[node.outboundLayer.id] == null ? + 0 : + layersDepths[node.outboundLayer.id]); + depth = Math.max(depth, previousDepth); + layersDepths[node.outboundLayer.id] = depth; + layerIDToLayer[node.outboundLayer.id] = node.outboundLayer; + nodesDepths[node.id] = depth; + for (var i = 0; i < node.inboundLayers.length; i++) { + var inboundLayer = node.inboundLayers[i]; + var nodeIndex = node.nodeIndices[i]; + var inboundNode = inboundLayer.inboundNodes[nodeIndex]; + var previousDepth_1 = (nodesDepths[inboundNode.id] == null ? 0 : + nodesDepths[inboundNode.id]); + nodesDepths[inboundNode.id] = Math.max(depth + 1, previousDepth_1); + nodeIDToNode[inboundNode.id] = inboundNode; + } + } + var nodesByDepth = {}; + for (var nodeID in nodesDepths) { + var depth = nodesDepths[nodeID]; + if (!(depth in nodesByDepth)) { + nodesByDepth[depth] = []; + } + nodesByDepth[depth].push(nodeIDToNode[nodeID]); + } + var layersByDepth = {}; + for (var layerID in layersDepths) { + var depth = layersDepths[layerID]; + if (!(depth in layersByDepth)) { + layersByDepth[depth] = []; + } + layersByDepth[depth].push(layerIDToLayer[layerID]); + } + var depthKeys = Object.keys(layersByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(reverseNumberCompare); + _this.layers = []; + for (var _j = 0, depthKeys_1 = depthKeys; _j < depthKeys_1.length; _j++) { + var depth = depthKeys_1[_j]; + var layersForDepth = layersByDepth[depth]; + layersForDepth.sort(function (a, b) { + var aIndex = layerIndices[a.id]; + var bIndex = layerIndices[b.id]; + if (aIndex < bIndex) { + return -1; + } + if (aIndex > bIndex) { + return 1; + } + return 0; + }); + for (var _k = 0, layersForDepth_1 = layersForDepth; _k < layersForDepth_1.length; _k++) { + var layer = layersForDepth_1[_k]; + _this.layers.push(layer); + } + } + _this.layersByDepth = layersByDepth; + depthKeys = Object.keys(nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(reverseNumberCompare); + var computableTensors = _this.inputs.slice(); + var layersWithCompleteInput = []; + for (var _l = 0, depthKeys_2 = depthKeys; _l < depthKeys_2.length; _l++) { + var depth = depthKeys_2[_l]; + for (var _m = 0, _o = nodesByDepth[depth]; _m < _o.length; _m++) { + var node = _o[_m]; + var layer = node.outboundLayer; + if (layer != null) { + for (var _p = 0, _q = node.inputTensors; _p < _q.length; _p++) { + var x = _q[_p]; + if (computableTensors.indexOf(x) === -1) { + throw new RuntimeError("Graph disconnected: cannot obtain value for tensor " + x + + (" at layer \"" + layer.name + "\". ") + + 'The following previous layers were accessed without ' + + ("issue: " + layersWithCompleteInput)); + } + } + for (var _r = 0, _s = node.outputTensors; _r < _s.length; _r++) { + var x = _s[_r]; + computableTensors.push(x); + } + layersWithCompleteInput.push(layer.name); + } + } + } + _this.nodesByDepth = nodesByDepth; + var allNames = _this.layers.map(function (x) { return x.name; }); + var _loop_1 = function (name_4) { + var numOccurrences = allNames.filter(function (x) { return x === name_4; }).length; + if (numOccurrences !== 1) { + throw new RuntimeError("The name \"" + name_4 + "\" is used " + numOccurrences + " times " + + 'in the model. All layer names should be unique. Layer names: ' + + JSON.stringify(allNames)); + } + }; + for (var _t = 0, allNames_1 = allNames; _t < allNames_1.length; _t++) { + var name_4 = allNames_1[_t]; + _loop_1(name_4); + } + _this.outboundNodes = []; + _this.inboundNodes = []; + new Node({ + outboundLayer: _this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: _this.inputs, + outputTensors: _this.outputs, + inputMasks: _this.inputs.map(function (x) { return null; }), + outputMasks: _this.outputs.map(function (x) { return null; }), + inputShapes: _this.inputs.map(function (x) { return x.shape; }), + outputShapes: _this.outputs.map(function (x) { return x.shape; }) + }); + _this.built = true; + return _this; + } + Object.defineProperty(Container.prototype, "trainableWeights", { + get: function () { + if (this._trainableWeights.length > 0) { + throw new ValueError('Container instance unexpectedly contains _trainableWeights.' + + 'The trainable weights of a Container are a union of the ' + + 'trainable weights of its consituent Layers. Its own ' + + '_trainableWeights must remain an empty Array.'); + } + if (!this.trainable) { + return []; + } + var weights = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + weights = weights.concat(layer.trainableWeights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Container.prototype, "nonTrainableWeights", { + get: function () { + var weights = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + weights.push.apply(weights, layer.nonTrainableWeights); + } + if (!this.trainable) { + var trainableWeights = []; + for (var _b = 0, _c = this.layers; _b < _c.length; _b++) { + var layer = _c[_b]; + trainableWeights.push.apply(trainableWeights, layer.trainableWeights); + } + return trainableWeights.concat(weights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Container.prototype, "weights", { + get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Container.prototype.loadWeights = function (weightsJSON, skipMismatch, isNamedTensorMap) { + if (skipMismatch === void 0) { skipMismatch = false; } + if (isNamedTensorMap === void 0) { isNamedTensorMap = false; } + if (isNamedTensorMap) { + loadWeightsFromNamedTensorMap(weightsJSON, this.layers); + } + else { + loadWeightsFromJson(weightsJSON, this.layers, skipMismatch); + } + }; + Container.prototype.updatedConfig = function () { + var theConfig = this.getConfig(); + var modelConfig = { + className: this.getClassName(), + config: theConfig, + kerasVersion: "tfjs-layers " + version, + backend: 'TensorFlow.js' + }; + return modelConfig; + }; + Container.prototype.toJSON = function (unused, returnString) { + if (returnString === void 0) { returnString = true; } + var modelConfig = convertTsToPythonic(this.updatedConfig()); + return returnString ? JSON.stringify(modelConfig) : modelConfig; + }; + Container.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = toList(inputs); + var masks; + if ('mask' in kwargs) { + masks = toList(kwargs['mask']); + } + else { + masks = pyListRepeat(null, inputs.length); + } + return _this.runInternalGraph(inputs, masks)[0]; + }); + }; + Container.prototype.computeMask = function (inputs, mask) { + var _this = this; + return tfc.tidy(function () { + inputs = toList(inputs); + var masks; + if (mask == null) { + masks = pyListRepeat(null, inputs.length); + } + else { + masks = toList(mask); + } + return _this.runInternalGraph(inputs, masks)[1]; + }); + }; + Container.prototype.computeOutputShape = function (inputShape) { + var inputShapes = normalizeShapeList(inputShape); + if (inputShapes.length !== this.inputLayers.length) { + throw new ValueError("Invalid inputShape argument " + inputShape + ": " + + ("model has " + this.inputLayers.length + " tensor inputs.")); + } + var layersToOutputShapes = {}; + for (var i = 0; i < inputShapes.length; i++) { + var layer = this.inputLayers[i]; + var inputShape_1 = inputShapes[i]; + var shapeKey = layer.name + '_0_0'; + layersToOutputShapes[shapeKey] = inputShape_1; + } + var depthKeys = Object.keys(this.nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(reverseNumberCompare); + if (depthKeys.length > 1) { + for (var _i = 0, depthKeys_3 = depthKeys; _i < depthKeys_3.length; _i++) { + var depth = depthKeys_3[_i]; + var nodes = this.nodesByDepth[depth]; + for (var _a = 0, nodes_1 = nodes; _a < nodes_1.length; _a++) { + var node = nodes_1[_a]; + var layer = node.outboundLayer; + if (this.inputLayers.map(function (x) { return x.id; }).indexOf(layer.id) !== -1) { + continue; + } + var inputShapes_1 = []; + for (var j = 0; j < node.inboundLayers.length; j++) { + var inboundLayer = node.inboundLayers[j]; + var nodeIndex_2 = node.nodeIndices[j]; + var tensorIndex = node.tensorIndices[j]; + var shapeKey = inboundLayer.name + "_" + nodeIndex_2 + "_" + tensorIndex; + var inputShape_2 = layersToOutputShapes[shapeKey]; + inputShapes_1.push(inputShape_2); + } + var outputShape = layer.computeOutputShape(singletonOrArray(inputShapes_1)); + var outputShapes_1 = normalizeShapeList(outputShape); + var nodeIndex = layer.inboundNodes.indexOf(node); + for (var j = 0; j < outputShapes_1.length; j++) { + var shapeKey = layer.name + "_" + nodeIndex + "_" + j; + layersToOutputShapes[shapeKey] = outputShapes_1[j]; + } + } + } + } + var outputShapes = []; + var outputShapeKeys = []; + for (var i = 0; i < this.outputLayers.length; i++) { + var layer = this.outputLayers[i]; + var nodeIndex = this.outputLayersNodeIndices[i]; + var tensorIndex = this.outputLayersTensorIndices[i]; + var shapeKey = layer.name + "_" + nodeIndex + "_" + tensorIndex; + outputShapeKeys.push(shapeKey); + } + for (var i = 0; i < outputShapeKeys.length; i++) { + var key = outputShapeKeys[i]; + assert(key in layersToOutputShapes); + outputShapes.push(layersToOutputShapes[key]); + } + return singletonOrArray(outputShapes); + }; + Container.prototype.runInternalGraph = function (inputs, masks) { + if (masks == null) { + masks = pyListRepeat(null, inputs.length); + } + var tensorMap = {}; + for (var i = 0; i < this.inputs.length; ++i) { + var x = this.inputs[i]; + var y = inputs[i]; + var mask = masks[i]; + tensorMap[x.id] = [y, mask]; + } + var depthKeys = Object.keys(this.nodesByDepth) + .map(function (x) { return parseInt(x, 10); }) + .sort(reverseNumberCompare); + for (var _i = 0, depthKeys_4 = depthKeys; _i < depthKeys_4.length; _i++) { + var depth = depthKeys_4[_i]; + var nodes = this.nodesByDepth[depth]; + for (var _a = 0, nodes_2 = nodes; _a < nodes_2.length; _a++) { + var node = nodes_2[_a]; + var layer = node.outboundLayer; + var referenceInputTensors = node.inputTensors; + var referenceOutputTensors = node.outputTensors; + var computedData = new Array(); + for (var _b = 0, referenceInputTensors_1 = referenceInputTensors; _b < referenceInputTensors_1.length; _b++) { + var x = referenceInputTensors_1[_b]; + if (x.id in tensorMap) { + computedData.push(tensorMap[x.id]); + } + } + if (computedData.length === referenceInputTensors.length) { + var kwargs = {}; + var computedTensors = void 0; + var computedMasks = void 0; + var outputTensors_1 = void 0; + var outputMasks_1 = void 0; + if (node.callArgs != null) { + kwargs = node.callArgs; + } + if (computedData.length === 1) { + var _c = computedData[0], computedTensor = _c[0], computedMask = _c[1]; + if (kwargs.mask == null) { + kwargs['mask'] = computedMask; + } + outputTensors_1 = + toList(layer.call(computedTensor, kwargs)); + outputMasks_1 = toList(layer.computeMask(computedTensor, computedMask)); + computedTensors = [computedTensor]; + computedMasks = [computedMask]; + } + else { + computedTensors = computedData.map(function (x) { return x[0]; }); + computedMasks = computedData.map(function (x) { return x[1]; }); + if (kwargs.mask == null) { + kwargs['mask'] = computedMasks; + } + outputTensors_1 = + toList(layer.call(computedTensors, kwargs)); + outputMasks_1 = toList(layer.computeMask(computedTensors, computedMasks)); + } + if (layer.activityRegularizer) { + throw new NotImplementedError('Model invocation with concrete Tensor value(s) in the ' + + 'presence of activity regularizer(s) is not supported yet.'); + } + for (var i = 0; i < referenceOutputTensors.length; ++i) { + var x = referenceOutputTensors[i]; + var y = outputTensors_1[i]; + var mask = outputMasks_1[i]; + tensorMap[x.id] = [y, mask]; + } + } + } + } + var outputTensors = []; + var outputMasks = []; + var outputShapes = []; + for (var _d = 0, _e = this.outputs; _d < _e.length; _d++) { + var x = _e[_d]; + assert(x.id in tensorMap, "Could not compute output " + x.name + " : " + x.id); + var _f = tensorMap[x.id], tensor = _f[0], mask = _f[1]; + outputShapes.push(tensor.shape); + outputTensors.push(tensor); + outputMasks.push(mask); + } + return [outputTensors, outputMasks, outputShapes]; + }; + Container.prototype.buildNodeConversionMap = function (layers) { + var nodeConversionMap = {}; + var keptNodes; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + keptNodes = layer instanceof Container ? 1 : 0; + for (var originalNodeIndex = 0; originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) { + var nodeKey = Container.nodeKey(layer, originalNodeIndex); + if (nodeKey in this.containerNodes) { + nodeConversionMap[nodeKey] = keptNodes; + keptNodes += 1; + } + } + } + return nodeConversionMap; + }; + Container.prototype.getLayer = function (name, index) { + if (index != null) { + if (this.layers.length <= index) { + throw new ValueError("Was asked to retrieve layer at index " + index + ", but model only " + + ("has " + this.layers.length + " layer(s).")); + } + else { + return this.layers[index]; + } + } + else { + if (name == null) { + throw new ValueError('Provide either a layer name or layer index'); + } + } + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer.name === name) { + return layer; + } + } + throw new ValueError("No such layer: " + name); + }; + Container.prototype.calculateLosses = function () { + var _this = this; + return tfc.tidy(function () { + var losses = []; + for (var _i = 0, _a = _this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + for (var nodeIndex = 0; nodeIndex < layer.inboundNodes.length; ++nodeIndex) { + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (_this.containerNodes.has(nodeKey)) { + losses.push.apply(losses, layer.calculateLosses()); + } + } + } + return losses; + }); + }; + Container.prototype.getConfig = function () { + var config = { name: this.name }; + var nodeConversionMap = this.buildNodeConversionMap(this.layers); + var layerConfigs = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + var layerClassName = layer.getClassName(); + var layerConfig = layer.getConfig(); + var filteredInboundNodes = []; + for (var originalNodeIndex = 0; originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) { + var node = layer.inboundNodes[originalNodeIndex]; + var nodeKey = Container.nodeKey(layer, originalNodeIndex); + var kwargs = {}; + if (this.containerNodes.has(nodeKey)) { + if (node.callArgs) { + try { + JSON.stringify(node.callArgs); + kwargs = node.callArgs; + } + catch (err) { + console.warn("Layer " + layer.name + " was passed " + + "non-serializable keyword arguments: " + + (node.callArgs + ". They will not be included ") + + "in the serialized model (and thus will be " + + "missing at deserialization time)."); + kwargs = {}; + } + } + if (node.inboundLayers.length > 0) { + var nodeData = []; + for (var i = 0; i < node.inboundLayers.length; i++) { + var inboundLayer = node.inboundLayers[i]; + var nodeIndex = node.nodeIndices[i]; + var tensorIndex = node.tensorIndices[i]; + var nodeKey_1 = Container.nodeKey(inboundLayer, nodeIndex); + var newNodeIndex = nodeConversionMap[nodeKey_1]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + nodeData.push([inboundLayer.name, newNodeIndex, tensorIndex, kwargs]); + } + filteredInboundNodes.push(nodeData); + } + } + } + layerConfigs.push({ + name: layer.name, + className: layerClassName, + config: layerConfig, + inboundNodes: filteredInboundNodes + }); + } + config['layers'] = layerConfigs; + var modelInputs = []; + for (var i = 0; i < this.inputLayers.length; i++) { + var layer = this.inputLayers[i]; + var nodeIndex = this.inputLayersNodeIndices[i]; + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (!this.containerNodes.has(nodeKey)) { + continue; + } + var newNodeIndex = nodeConversionMap[nodeKey]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + var tensorIndex = this.inputLayersTensorIndices[i]; + modelInputs.push([layer.name, newNodeIndex, tensorIndex]); + } + config['inputLayers'] = modelInputs; + var modelOutputs = []; + for (var i = 0; i < this.outputLayers.length; i++) { + var layer = this.outputLayers[i]; + var nodeIndex = this.outputLayersNodeIndices[i]; + var nodeKey = Container.nodeKey(layer, nodeIndex); + if (!this.containerNodes.has(nodeKey)) { + continue; + } + var newNodeIndex = nodeConversionMap[nodeKey]; + if (newNodeIndex === null || newNodeIndex === undefined) { + newNodeIndex = 0; + } + var tensorIndex = this.outputLayersTensorIndices[i]; + modelOutputs.push([layer.name, newNodeIndex, tensorIndex]); + } + config['outputLayers'] = modelOutputs; + return config; + }; + Container.fromConfig = function (cls, config) { + var createdLayers = {}; + var unprocessedNodes = {}; + function addUnprocessedNode(layer, nodeData) { + if (!(layer.name in unprocessedNodes)) { + unprocessedNodes[layer.name] = [nodeData]; + } + else { + unprocessedNodes[layer.name].push(nodeData); + } + } + function processNode(layer, nodeData) { + var inputTensors = []; + var kwargs; + for (var _i = 0, nodeData_1 = nodeData; _i < nodeData_1.length; _i++) { + var inputData = nodeData_1[_i]; + var inboundLayerName = inputData[0]; + var inboundNodeIndex = inputData[1]; + var inboundTensorIndex = inputData[2]; + if (inputData.length === 3) { + kwargs = {}; + } + else if (inputData.length === 4) { + kwargs = inputData[3]; + } + else { + throw new ValueError("Improperly formatted model config for layer " + JSON.stringify(layer) + ": " + JSON.stringify(inputData)); + } + if (!(inboundLayerName in createdLayers)) { + addUnprocessedNode(layer, nodeData); + return; + } + var inboundLayer = createdLayers[inboundLayerName]; + if (inboundLayer.inboundNodes.length <= inboundNodeIndex) { + addUnprocessedNode(layer, nodeData); + return; + } + var inboundNode = inboundLayer.inboundNodes[inboundNodeIndex]; + inputTensors.push(inboundNode.outputTensors[inboundTensorIndex]); + } + if (inputTensors.length > 0) { + layer.apply(singletonOrArray(inputTensors), kwargs); + } + } + function processLayer(layerData) { + var layerName = layerData.name; + var layer = deserialize(layerData, config.customObjects != null ? + config.customObjects : + {}); + createdLayers[layerName] = layer; + var inboundNodesData = layerData.inboundNodes; + for (var _i = 0, inboundNodesData_1 = inboundNodesData; _i < inboundNodesData_1.length; _i++) { + var nodeData = inboundNodesData_1[_i]; + if (!(nodeData instanceof Array)) { + throw new ValueError("Corrupted configuration, expected array for nodeData: " + nodeData); + } + addUnprocessedNode(layer, nodeData); + } + } + var name = config.name; + var layersFromConfig = config.layers; + for (var _i = 0, layersFromConfig_1 = layersFromConfig; _i < layersFromConfig_1.length; _i++) { + var layerData = layersFromConfig_1[_i]; + processLayer(layerData); + } + while (!isObjectEmpty(unprocessedNodes)) { + for (var _a = 0, layersFromConfig_2 = layersFromConfig; _a < layersFromConfig_2.length; _a++) { + var layerData = layersFromConfig_2[_a]; + var layer = createdLayers[layerData.name]; + if (layer.name in unprocessedNodes) { + for (var _b = 0, _c = unprocessedNodes[layer.name]; _b < _c.length; _b++) { + var nodeData = _c[_b]; + processNode(layer, nodeData); + } + delete unprocessedNodes[layer.name]; + } + } + } + var inputTensors = []; + var outputTensors = []; + var inputLayersFromConfig = config.inputLayers; + for (var _d = 0, inputLayersFromConfig_1 = inputLayersFromConfig; _d < inputLayersFromConfig_1.length; _d++) { + var layerData = inputLayersFromConfig_1[_d]; + var layerName = layerData[0]; + var nodeIndex = layerData[1]; + var tensorIndex = layerData[2]; + assert(layerName in createdLayers); + var layer = createdLayers[layerName]; + var layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors; + inputTensors.push(layerOutputTensors[tensorIndex]); + } + var outputLayersFromConfig = config.outputLayers; + for (var _e = 0, outputLayersFromConfig_1 = outputLayersFromConfig; _e < outputLayersFromConfig_1.length; _e++) { + var layerData = outputLayersFromConfig_1[_e]; + var layerName = layerData[0]; + var nodeIndex = layerData[1]; + var tensorIndex = layerData[2]; + assert(layerName in createdLayers); + var layer = createdLayers[layerName]; + var layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors; + outputTensors.push(layerOutputTensors[tensorIndex]); + } + return new cls({ inputs: inputTensors, outputs: outputTensors, name: name }); + }; + Object.defineProperty(Container.prototype, "stateful", { + get: function () { + if (this._stateful) { + throw new ValueError('Container instance unexpectedly has _stateful = true. The ' + + 'statefulness of a Container is determined by the Layers it ' + + 'contains. Its _stateful property must remain the default false.'); + } + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + if (layer.stateful) { + return true; + } + } + return false; + }, + enumerable: true, + configurable: true + }); + return Container; + }(Layer)); + + function assertFeedCompatibility(key, val) { + if (key.shape != null) { + if (key.shape.length !== val.shape.length) { + throw new ValueError("The rank of feed (" + val.shape.length + ") does not match the rank of " + + ("the key (" + key.shape.length + ").")); + } + for (var i = 0; i < key.shape.length; ++i) { + if (key.shape[i] != null && key.shape[i] !== val.shape[i]) { + throw new ValueError("The " + i + "-th dimension of the feed (" + val.shape[i] + ") is " + + ("incompatible with that of the key (" + key.shape[i] + ").")); + } + } + } + if (key.dtype == null || key.dtype === val.dtype) { + return val; + } + try { + return tfc.cast(val, key.dtype); + } + catch (err) { + throw new ValueError("The dtype of the feed (" + val.dtype + ") can not be cast to the dtype " + + ("of the key '" + key.name + "' (" + key.dtype + ").")); + } + } + var FeedDict = (function () { + function FeedDict(feeds) { + this.id2Value = {}; + if (feeds instanceof FeedDict) { + for (var id in feeds.id2Value) { + this.id2Value[id] = feeds.id2Value[id]; + } + } + else { + if (feeds == null) { + return; + } + for (var _i = 0, feeds_1 = feeds; _i < feeds_1.length; _i++) { + var feed = feeds_1[_i]; + this.add(feed.key, feed.value); + } + } + } + FeedDict.prototype.add = function (key, value) { + if (this.id2Value[key.id] == null) { + this.id2Value[key.id] = assertFeedCompatibility(key, value); + } + else { + throw new ValueError("Duplicate key: name=" + key.name + ", id=" + key.id); + } + return this; + }; + FeedDict.prototype.addFeed = function (feed) { + this.add(feed.key, feed.value); + }; + FeedDict.prototype.hasKey = function (key) { + return this.id2Value[key.id] != null; + }; + FeedDict.prototype.getValue = function (key) { + if (this.id2Value[key.id] == null) { + throw new ValueError("Nonexistent key: " + JSON.stringify(key)); + } + else { + return this.id2Value[key.id]; + } + }; + return FeedDict; + }()); + function execute(fetches, feedDict, kwargs) { + var arrayFetches = Array.isArray(fetches); + var fetchArray = arrayFetches ? fetches : [fetches]; + var outputs = []; + var internalFeedDict = new FeedDict(feedDict); + for (var _i = 0, fetchArray_1 = fetchArray; _i < fetchArray_1.length; _i++) { + var fetch_1 = fetchArray_1[_i]; + outputs.push(executeInternal(fetch_1, internalFeedDict, kwargs)); + } + return arrayFetches ? outputs : outputs[0]; + } + function executeInternal(fetch, internalFeedDict, kwargs) { + if (internalFeedDict.hasKey(fetch)) { + return internalFeedDict.getValue(fetch); + } + if (fetch.sourceLayer instanceof InputLayer) { + throw new ValueError("Missing a feed value for SymbolicTensor from InputLayer " + + ("'" + InputLayer.name + "'")); + } + var inputs = fetch.inputs; + var inputValues = []; + for (var _i = 0, inputs_1 = inputs; _i < inputs_1.length; _i++) { + var input = inputs_1[_i]; + var inputVal = executeInternal(input, internalFeedDict, kwargs); + inputValues.push(inputVal); + } + var output = fetch.sourceLayer.apply(inputValues, kwargs); + if (!Array.isArray(output)) { + output = [output]; + } + var layerOutputs = getNodeOutputs(fetch); + var outputSymbolicTensors = Array.isArray(layerOutputs) ? layerOutputs : [layerOutputs]; + for (var i = 0; i < outputSymbolicTensors.length; ++i) { + internalFeedDict.add(outputSymbolicTensors[i], output[i]); + } + return output.length === 1 ? output[0] : output[fetch.outputTensorIndex]; + } + function getNodeOutputs(fetch) { + var layerOutputs; + if (fetch.sourceLayer.inboundNodes.length === 1) { + layerOutputs = fetch.sourceLayer.output; + } + else { + var nodeIndex = null; + for (var i = 0; i < fetch.sourceLayer.inboundNodes.length; ++i) { + for (var _i = 0, _a = fetch.sourceLayer.inboundNodes[i] + .outputTensors; _i < _a.length; _i++) { + var outputTensor = _a[_i]; + if (outputTensor.id === fetch.id) { + nodeIndex = i; + break; + } + } + } + layerOutputs = fetch.sourceLayer.getOutputAt(nodeIndex); + } + return layerOutputs; + } + + function isDataTensor(x) { + return x instanceof tfc.Tensor; + } + function isDataArray(x) { + return Array.isArray(x); + } + function isDataDict(x) { + return !isDataTensor(x) && !isDataArray(x); + } + function standardizeInputData(data, names, shapes, checkBatchAxis, exceptionPrefix) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (exceptionPrefix === void 0) { exceptionPrefix = ''; } + if (names == null || names.length === 0) { + if (data != null) { + var gotUnexpectedData = false; + if (isDataArray(data) && data.length > 0) { + gotUnexpectedData = true; + } + else if (isDataDict(data)) { + for (var key in data) { + if (data.hasOwnProperty(key)) { + gotUnexpectedData = true; + break; + } + } + } + else { + gotUnexpectedData = true; + } + if (gotUnexpectedData) { + throw new ValueError("Error when checking model " + exceptionPrefix + " expected no data, " + + ("but got " + data)); + } + } + return []; + } + if (data == null) { + return names.map(function (name) { return null; }); + } + var arrays; + if (isDataDict(data)) { + data = data; + arrays = []; + for (var _i = 0, names_1 = names; _i < names_1.length; _i++) { + var name_1 = names_1[_i]; + if (data[name_1] == null) { + throw new ValueError("No data provided for \"" + name_1 + "\". Need data for each key in: " + + ("" + names)); + } + arrays.push(data[name_1]); + } + } + else if (isDataArray(data)) { + data = data; + if (data.length !== names.length) { + throw new ValueError("Error when checking model " + exceptionPrefix + ": the Array of " + + "Tensors that you are passing to your model is not the size the " + + ("model expected. Expected to see " + names.length + " Tensor(s), but ") + + ("instead got the following list of Tensor(s): " + data)); + } + arrays = data; + } + else { + data = data; + if (names.length > 1) { + throw new ValueError("The model " + exceptionPrefix + " expects " + names.length + " Tensor(s), " + + ("but only received one Tensor. Found: Tensor with shape " + data.shape)); + } + arrays = [data]; + } + for (var i = 0; i < names.length; ++i) { + var array = arrays[i]; + if (array.shape.length === 1) { + arrays[i] = expandDims(array, 1); + } + } + if (shapes != null) { + for (var i = 0; i < names.length; ++i) { + if (shapes[i] == null) { + continue; + } + var array = arrays[i]; + if (array.shape.length !== shapes[i].length) { + throw new ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have " + shapes[i].length + " dimension(s). but got array with ") + + ("shape " + array.shape)); + } + for (var j = 0; j < shapes[i].length; ++j) { + if (j === 0 && !checkBatchAxis) { + continue; + } + var dim = array.shape[j]; + var refDim = shapes[i][j]; + if (refDim != null && refDim >= 0 && dim !== refDim) { + throw new ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have shape [" + shapes[i] + "], but got array with shape ") + + ("[" + array.shape + "].")); + } + } + } + } + return arrays; + } + function checkArrayLengths(inputs, targets, weights) { + var setX = unique(inputs.map(function (input) { return input.shape[0]; })); + setX.sort(); + var setY = unique(targets.map(function (target) { return target.shape[0]; })); + setY.sort(); + if (setX.length > 1) { + throw new ValueError("All input Tensors (x) should have the same number of samples. " + + "Got array shapes: " + + ("" + JSON.stringify(inputs.map(function (input) { return input.shape; })))); + } + if (setY.length > 1) { + throw new ValueError("All target Tensors (y) should have the same number of samples. " + + "Got array shapes: " + + ("" + JSON.stringify(targets.map(function (target) { return target.shape; })))); + } + if (setX.length > 0 && setY.length > 0 && !tfc.util.arraysEqual(setX, setY)) { + throw new ValueError("Input Tensors should have the same number of samples as target " + + ("Tensors. Found " + setX[0] + " input sample(s) and " + setY[0] + " target ") + + "sample(s)."); + } + } + function checkLossAndTargetCompatibility(targets, lossFns, outputShapes) { + var keyLosses = [ + meanSquaredError, binaryCrossentropy, + categoricalCrossentropy + ]; + for (var i = 0; i < targets.length; ++i) { + var y = targets[i]; + var loss = lossFns[i]; + var shape = outputShapes[i]; + if (loss == null) { + continue; + } + if (loss === categoricalCrossentropy) { + if (y.shape[y.shape.length - 1] === 1) { + throw new ValueError("You are passing a target array of shape " + y.shape + " while using " + + "a loss 'categorical_crossentropy'. 'categorical_crossentropy'" + + "expects targets to be binary matrices (1s and 0s) of shape " + + "[samples, classes]."); + } + } + if (keyLosses.indexOf(loss) !== -1) { + var slicedYShape = y.shape.slice(1); + var slicedShape = shape.slice(1); + for (var j = 0; j < slicedYShape.length; ++j) { + var targetDim = slicedYShape[j]; + var outDim = slicedShape[j]; + if (outDim != null && targetDim !== outDim) { + throw new ValueError("A target Tensor with shape " + y.shape + " was passed for an " + + ("output of shape " + shape + ", while using a loss function that ") + + "expects targets to have the same shape as the output."); + } + } + } + } + } + function makeBatches(size, batchSize) { + var output = []; + var batchStart = 0; + var batchEnd = null; + while (batchStart < size) { + batchEnd = batchStart + batchSize; + if (batchEnd >= size) { + batchEnd = size; + } + output.push([batchStart, batchEnd]); + batchStart = batchEnd; + } + return output; + } + function sliceArrays(arrays, start, stop) { + if (arrays == null) { + return [null]; + } + else if (Array.isArray(arrays)) { + return arrays.map(function (array) { return sliceAlongFirstAxis(array, start, stop - start); }); + } + else { + return sliceAlongFirstAxis(arrays, start, stop - start); + } + } + function sliceArraysByIndices(arrays, indices) { + return tfc.tidy(function () { + if (arrays == null) { + return null; + } + else if (Array.isArray(arrays)) { + return arrays.map(function (array) { return sliceArraysByIndices(array, indices); }); + } + else { + return gather(arrays, indices.dtype === 'int32' ? indices : indices.toInt()); + } + }); + } + function checkInputData(data, names, shapes, checkBatchAxis, exceptionPrefix) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (exceptionPrefix === void 0) { exceptionPrefix = ''; } + var arrays; + if (Array.isArray(data)) { + if (data.length !== names.length) { + throw new ValueError("Error when checking model " + exceptionPrefix + ": the Array of " + + "Tensors that you are passing to your model is not the size the " + + ("the model expected. Expected to see " + names.length + " Tensor(s),") + + (" but instead got " + data.length + " Tensors(s).")); + } + arrays = data; + } + else { + if (names.length > 1) { + throw new ValueError("The model expects " + names.length + " " + exceptionPrefix + " Tensors, " + + "but only received one Tensor. Found: array with shape " + + (JSON.stringify(data.shape) + ".")); + } + arrays = [data]; + } + if (shapes != null) { + for (var i = 0; i < names.length; ++i) { + if (shapes[i] == null) { + continue; + } + var array = arrays[i]; + if (array.shape.length !== shapes[i].length) { + throw new ValueError("Error when checking " + exceptionPrefix + ": expected " + names[i] + " " + + ("to have " + shapes[i].length + " dimension(s), but got array with ") + + ("shape " + JSON.stringify(array.shape))); + } + for (var j = 0; j < shapes[i].length; ++j) { + if (j === 0 && !checkBatchAxis) { + continue; + } + var dim = array.shape[j]; + var refDim = shapes[i][j]; + if (refDim != null) { + if (refDim !== dim) { + throw new ValueError("Error when checking " + exceptionPrefix + ": expected " + + (names[i] + " to have shape " + JSON.stringify(shapes[i]) + " but ") + + ("got array with shape " + JSON.stringify(array.shape) + ".")); + } + } + } + } + } + } + function collectMetrics(metrics, outputNames) { + if (metrics == null || Array.isArray(metrics) && metrics.length === 0) { + return outputNames.map(function (name) { return []; }); + } + if (Array.isArray(metrics)) { + return outputNames.map(function (name) { return metrics; }); + } + else if (metrics != null) { + var nestedMetrics = []; + for (var _i = 0, outputNames_1 = outputNames; _i < outputNames_1.length; _i++) { + var name_2 = outputNames_1[_i]; + var outputMetrics = metrics.hasOwnProperty(name_2) ? metrics[name_2] : []; + if (!Array.isArray(outputMetrics)) { + outputMetrics = [outputMetrics]; + } + nestedMetrics.push(outputMetrics); + } + return nestedMetrics; + } + else { + throw new TypeError('Type of metrics argument not understood. Expected an Array or ' + + 'Object, found: ' + metrics); + } + } + var ModelLoggingVerbosity; + (function (ModelLoggingVerbosity) { + ModelLoggingVerbosity[ModelLoggingVerbosity["SILENT"] = 0] = "SILENT"; + ModelLoggingVerbosity[ModelLoggingVerbosity["VERBOSE"] = 1] = "VERBOSE"; + })(ModelLoggingVerbosity || (ModelLoggingVerbosity = {})); + var Model = (function (_super) { + __extends(Model, _super); + function Model(config) { + return _super.call(this, config) || this; + } + Model.prototype.summary = function (lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + if (!this.built) { + throw new ValueError("This model has never been called, thus its weights have not been " + + "created yet. So no summary can be displayed. Build the model " + + "first (e.g., by calling it on some test data)."); + } + printSummary(this, lineLength, positions, printFn); + }; + Model.prototype.compile = function (config) { + var _this = this; + if (config.loss == null) { + config.loss = []; + } + this.loss = config.loss; + if (typeof config.optimizer === 'string') { + this.optimizer = getOptimizer(config.optimizer); + } + else { + if (!(config.optimizer instanceof tfc.Optimizer)) { + throw new ValueError("User-defined optimizer must be an instance of tf.Optimizer."); + } + this.optimizer = config.optimizer; + } + var lossFunctions = []; + if (!Array.isArray(config.loss) && typeof config.loss !== 'string' && + typeof config.loss !== 'function') { + config.loss = config.loss; + for (var name_3 in config.loss) { + if (this.outputNames.indexOf(name_3) === -1) { + throw new ValueError("Unknown entry in loss dictionary: \"" + name_3 + "\". Only expect the " + + ("following keys: " + this.outputNames)); + } + } + for (var name_4 in this.outputNames) { + if (config.loss[name_4] == null) { + console.warn("Output \"" + name_4 + "\" is missing from loss dictionary. We assume " + + "this was done on purpose, and we will not be expecting data " + + ("to be passed to " + name_4 + " during training")); + } + lossFunctions.push(get(config.loss[name_4])); + } + } + else if (Array.isArray(config.loss)) { + if (config.loss.length !== this.outputs.length) { + throw new ValueError("When passing an Array as loss, it should have one entry per " + + ("model output. The model has " + this.outputs.length + " output(s), ") + + ("but you passed loss=" + config.loss + ".")); + } + var theLosses = config.loss; + lossFunctions = theLosses.map(function (l) { return get(l); }); + } + else { + var lossFunction_1 = get(config.loss); + this.outputs.map(function (layer) { + lossFunctions.push(lossFunction_1); + }); + } + this.lossFunctions = lossFunctions; + this.feedOutputNames = []; + this.feedOutputShapes = []; + this.feedLossFns = []; + for (var i = 0; i < this.outputs.length; ++i) { + var shape = this.internalOutputShapes[i]; + var name_5 = this.outputNames[i]; + this.feedOutputNames.push(name_5); + this.feedOutputShapes.push(shape); + this.feedLossFns.push(this.lossFunctions[i]); + } + var skipTargetIndices = []; + this.metrics = config.metrics; + this.metricsNames = ['loss']; + this.metricsTensors = []; + nameScope('loss', function () { + for (var i = 0; i < _this.outputs.length; ++i) { + if (skipTargetIndices.indexOf(i) !== -1) { + continue; + } + var weightedLoss = _this.lossFunctions[i]; + if (_this.outputs.length > 1) { + _this.metricsTensors.push([weightedLoss, i]); + _this.metricsNames.push(_this.outputNames[i] + '_loss'); + } + } + }); + var nestedMetrics = collectMetrics(config.metrics, this.outputNames); + var appendMetric = function (outputIndex, metricName, metricTensor) { + if (_this.outputNames.length > 1) { + metricName = _this.outputNames[outputIndex] + '_' + metricName; + } + _this.metricsNames.push(metricName); + _this.metricsTensors.push([metricTensor, outputIndex]); + }; + nameScope('metric', function () { + var _loop_1 = function (i) { + if (skipTargetIndices.indexOf(i) !== -1) { + return "continue"; + } + var outputMetrics = nestedMetrics[i]; + var handleMetrics = function (metrics) { + var metricNamePrefix = ''; + var metricName; + var accFn; + var weightedMetricFn; + var _loop_2 = function (metric) { + if (['accuracy', 'acc', 'crossentropy', 'ce'].indexOf(metric) !== + -1) { + var outputShape = _this.internalOutputShapes[i]; + if (outputShape[outputShape.length - 1] === 1 || + _this.lossFunctions[i] === binaryCrossentropy) { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = binaryAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = binaryCrossentropy$1; + } + } + else if (_this.lossFunctions[i] === + sparseCategoricalCrossentropy) { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = sparseCategoricalAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = sparseCategoricalCrossentropy$1; + } + } + else { + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + accFn = categoricalAccuracy; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + accFn = categoricalCrossentropy$1; + } + } + var suffix = void 0; + if (['accuracy', 'acc'].indexOf(metric) !== -1) { + suffix = 'acc'; + } + else if (['crossentropy', 'ce'].indexOf(metric) !== -1) { + suffix = 'ce'; + } + weightedMetricFn = accFn; + metricName = metricNamePrefix + suffix; + } + else { + var metricFn = get$1(metric); + weightedMetricFn = metricFn; + metricName = metricNamePrefix + metric; + } + var metricResult; + nameScope(metricName, function () { + metricResult = weightedMetricFn; + }); + appendMetric(i, metricName, metricResult); + }; + for (var _i = 0, metrics_1 = metrics; _i < metrics_1.length; _i++) { + var metric = metrics_1[_i]; + _loop_2(metric); + } + }; + handleMetrics(outputMetrics); + }; + for (var i = 0; i < _this.outputs.length; ++i) { + _loop_1(i); + } + }); + this.collectedTrainableWeights = this.trainableWeights; + }; + Model.prototype.checkTrainableWeightsConsistency = function () { + if (this.collectedTrainableWeights == null) { + return; + } + if (this.trainableWeights.length !== + this.collectedTrainableWeights.length) { + console.warn('Discrepancy between trainableweights and collected trainable ' + + 'weights. Did you set `model.trainable` without calling ' + + '`model.compile()` afterwards?'); + } + }; + Model.prototype.evaluate = function (x, y, config) { + if (config === void 0) { config = {}; } + var batchSize = config.batchSize == null ? 32 : config.batchSize; + var standardizedOuts = this.standardizeUserData(x, y, true, batchSize); + var ins = standardizedOuts[0].concat(standardizedOuts[1]); + this.makeTestFunction(); + var f = this.testFunction; + var testOuts = this.testLoop(f, ins, batchSize, config.verbose, config.steps); + return singletonOrArray(testOuts); + }; + Model.prototype.checkNumSamples = function (ins, batchSize, steps, stepsName) { + if (stepsName === void 0) { stepsName = 'steps'; } + var numSamples; + if (steps != null) { + numSamples = null; + if (batchSize != null) { + throw new ValueError("If " + stepsName + " is set, batchSize must be null or undefined." + + ("Got batchSize = " + batchSize)); + } + } + else if (ins != null) { + if (Array.isArray(ins)) { + numSamples = ins[0].shape[0]; + } + else { + numSamples = ins.shape[0]; + } + } + else { + throw new ValueError("Either the input data should have a defined shape, or " + + (stepsName + " shoud be specified.")); + } + return numSamples; + }; + Model.prototype.execute = function (inputs, outputs) { + if (Array.isArray(outputs) && outputs.length === 0) { + throw new ValueError('`outputs` is an empty Array, which is not allowed.'); + } + var outputsIsArray = Array.isArray(outputs); + var outputNames = (outputsIsArray ? outputs : + [outputs]); + var outputSymbolicTensors = this.retrieveSymbolicTensors(outputNames); + var feedDict = new FeedDict(); + if (inputs instanceof tfc.Tensor) { + inputs = [inputs]; + } + if (Array.isArray(inputs)) { + if (inputs.length !== this.inputs.length) { + throw new ValueError("The number of inputs provided (" + inputs.length + ") " + + "does not match the number of inputs of this model " + + ("(" + this.inputs.length + ").")); + } + for (var i = 0; i < this.inputs.length; ++i) { + feedDict.add(this.inputs[i], inputs[i]); + } + } + else { + for (var _i = 0, _a = this.inputs; _i < _a.length; _i++) { + var input = _a[_i]; + var tensorValue = inputs[input.name]; + if (tensorValue == null) { + throw new ValueError("No value is provided for the model's input " + input.name); + } + feedDict.add(input, tensorValue); + } + } + var executeOutputs = execute(outputSymbolicTensors, feedDict); + return outputsIsArray ? executeOutputs : executeOutputs[0]; + }; + Model.prototype.retrieveSymbolicTensors = function (symbolicTensorNames) { + var outputSymbolicTensors = pyListRepeat(null, symbolicTensorNames.length); + var outputsRemaining = symbolicTensorNames.length; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + var layerOutputs = Array.isArray(layer.output) ? + layer.output : + [layer.output]; + var layerOutputNames = layerOutputs.map(function (output) { return output.name; }); + for (var i = 0; i < symbolicTensorNames.length; ++i) { + var index = layerOutputNames.indexOf(symbolicTensorNames[i]); + if (index !== -1) { + outputSymbolicTensors[i] = layerOutputs[index]; + outputsRemaining--; + } + if (outputsRemaining === 0) { + break; + } + } + if (outputsRemaining === 0) { + break; + } + } + if (outputsRemaining > 0) { + var remainingNames_1 = []; + outputSymbolicTensors.forEach(function (tensor, i) { + if (tensor == null) { + remainingNames_1.push(symbolicTensorNames[i]); + } + }); + throw new ValueError("Cannot find SymbolicTensors for output name(s): " + + ("" + JSON.stringify(remainingNames_1))); + } + return outputSymbolicTensors; + }; + Model.prototype.predictLoop = function (ins, batchSize, verbose) { + var _this = this; + if (batchSize === void 0) { batchSize = 32; } + if (verbose === void 0) { verbose = false; } + return tfc.tidy(function () { + var numSamples = _this.checkNumSamples(ins); + if (verbose) { + throw new NotImplementedError('Verbose predictLoop() is not implemented yet.'); + } + var batches = makeBatches(numSamples, batchSize); + var outs = []; + var _loop_3 = function (batchIndex) { + var batchOuts = tfc.tidy(function () { + var batchStart = batches[batchIndex][0]; + var batchEnd = batches[batchIndex][1]; + var insBatch = sliceArrays(ins, batchStart, batchEnd); + var feeds = []; + if (Array.isArray(insBatch)) { + for (var i = 0; i < insBatch.length; ++i) { + feeds.push({ key: _this.inputs[i], value: insBatch[i] }); + } + } + else { + feeds.push({ key: _this.inputs[0], value: insBatch }); + } + var feedDict = new FeedDict(feeds); + return execute(_this.outputs, feedDict); + }); + if (batchIndex === 0) { + for (var _i = 0, batchOuts_1 = batchOuts; _i < batchOuts_1.length; _i++) { + var batchOut = batchOuts_1[_i]; + outs.push(batchOut); + } + } + else { + for (var i = 0; i < batchOuts.length; ++i) { + outs[i] = concatAlongFirstAxis(outs[i], batchOuts[i]); + } + } + }; + for (var batchIndex = 0; batchIndex < batches.length; ++batchIndex) { + _loop_3(batchIndex); + } + return singletonOrArray(outs); + }); + }; + Model.prototype.predict = function (x, config) { + if (config === void 0) { config = {}; } + checkInputData(x, this.inputNames, this.feedInputShapes, false); + var batchSize = config.batchSize == null ? 32 : config.batchSize; + return this.predictLoop(x, batchSize); + }; + Model.prototype.predictOnBatch = function (x) { + checkInputData(x, this.inputNames, this.feedInputShapes, true); + return this.predictLoop(x, x.shape[0]); + }; + Model.prototype.standardizeUserData = function (x, y, checkBatchAxis, batchSize) { + if (checkBatchAxis === void 0) { checkBatchAxis = true; } + if (this.optimizer == null) { + throw new RuntimeError('You must compile a model before training/testing. Use ' + + 'Model.compile(modelCompileConfig).'); + } + var outputShapes = []; + for (var i = 0; i < this.feedOutputShapes.length; ++i) { + var outputShape = this.feedOutputShapes[i]; + var lossFn = this.feedLossFns[i]; + if (lossFn === sparseCategoricalCrossentropy) { + outputShapes.push(outputShape.slice(0, outputShape.length - 1).concat([1])); + } + else { + outputShapes.push(outputShape); + } + } + x = standardizeInputData(x, this.feedInputNames, this.feedInputShapes, false, 'input'); + y = standardizeInputData(y, this.feedOutputNames, outputShapes, false, 'target'); + checkArrayLengths(x, y, null); + checkLossAndTargetCompatibility(y, this.feedLossFns, this.feedOutputShapes); + if (this.stateful && batchSize != null && batchSize > 0) { + if (x[0].shape[0] % batchSize !== 0) { + throw new ValueError("In a stateful network, you should only pass inputs with a " + + "number of samples that is divisible by the batch size " + + (batchSize + ". Found: " + x[0].shape[0] + " sample(s).")); + } + } + return [x, y, null]; + }; + Model.prototype.fitLoop = function (f, ins, outLabels, batchSize, epochs, verbose, callbacks, valF, valIns, shuffle, callbackMetrics, initialEpoch, stepsPerEpoch, validationSteps) { + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var doValidation, numTrainSamples, indexArray, callbackList, _loop_4, this_1, epoch, state_1; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (batchSize == null) { + batchSize = 32; + } + if (epochs == null) { + epochs = 1; + } + if (shuffle == null) { + shuffle = true; + } + if (initialEpoch == null) { + initialEpoch = 0; + } + doValidation = false; + if (valF != null && valIns != null) { + doValidation = true; + } + if (validationSteps != null) { + doValidation = true; + if (stepsPerEpoch == null) { + throw new ValueError('Can only use `validationSteps` when doing step-wise training, ' + + 'i.e., `stepsPerEpoch` must be set.'); + } + } + numTrainSamples = this.checkNumSamples(ins, batchSize, stepsPerEpoch, 'steps_per_epoch'); + if (numTrainSamples != null) { + indexArray = range(0, numTrainSamples); + } + this.history = new History(); + if (callbacks == null) { + callbacks = [new BaseLogger()]; + } + else { + callbacks = [new BaseLogger()].concat(callbacks); + } + callbacks = callbacks.concat([this.history]); + if (verbose > 0) { + throw new NotImplementedError('Verbose mode is not implemented yet.'); + } + callbackList = new CallbackList(callbacks); + callbackList.setModel(this); + callbackList.setParams({ + epochs: epochs, + initialEpoch: initialEpoch, + steps: stepsPerEpoch, + verbose: verbose, + doValidation: doValidation, + metrics: callbackMetrics, + }); + return [4, callbackList.onTrainBegin()]; + case 1: + _a.sent(); + this.stopTraining = false; + _loop_4 = function (epoch) { + var epochLogs, epochIndexArray1D_1, batches_1, _loop_5, batchIndex, state_2; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: return [4, callbackList.onEpochBegin(epoch)]; + case 1: + _a.sent(); + epochLogs = {}; + if (!(stepsPerEpoch != null)) return [3, 2]; + throw new NotImplementedError('stepsPerEpoch mode is not implemented yet.'); + case 2: + if (shuffle === 'batch') { + throw new NotImplementedError('batch shuffling is not implemneted yet'); + } + else if (shuffle) { + tfc.util.shuffle(indexArray); + } + epochIndexArray1D_1 = tfc.tensor1d(indexArray); + batches_1 = makeBatches(numTrainSamples, batchSize); + _loop_5 = function (batchIndex) { + var batchLogs; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + batchLogs = {}; + return [4, callbackList.onBatchBegin(batchIndex, batchLogs)]; + case 1: + _a.sent(); + tfc.tidy(function () { + var batchStart = batches_1[batchIndex][0]; + var batchEnd = batches_1[batchIndex][1]; + var batchIds = sliceAlongFirstAxis(epochIndexArray1D_1, batchStart, batchEnd - batchStart); + batchLogs['batch'] = batchIndex; + batchLogs['size'] = batchEnd - batchStart; + var insBatch = sliceArraysByIndices(ins, batchIds); + var outs = f(insBatch); + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var out = outs[i]; + batchLogs[label] = out; + tfc.keep(out); + } + if (batchIndex === batches_1.length - 1) { + if (doValidation) { + var valOuts = _this.testLoop(valF, valIns, batchSize); + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var out = valOuts[i]; + tfc.keep(out); + epochLogs['val_' + label] = out; + } + } + } + }); + return [4, callbackList.onBatchEnd(batchIndex, batchLogs)]; + case 2: + _a.sent(); + disposeTensorsInLogs(batchLogs); + if (this_1.stopTraining) { + return [2, "break"]; + } + return [2]; + } + }); + }; + batchIndex = 0; + _a.label = 3; + case 3: + if (!(batchIndex < batches_1.length)) return [3, 6]; + return [5, _loop_5(batchIndex)]; + case 4: + state_2 = _a.sent(); + if (state_2 === "break") + return [3, 6]; + _a.label = 5; + case 5: + ++batchIndex; + return [3, 3]; + case 6: + epochIndexArray1D_1.dispose(); + _a.label = 7; + case 7: return [4, callbackList.onEpochEnd(epoch, epochLogs)]; + case 8: + _a.sent(); + if (this_1.stopTraining) { + return [2, "break"]; + } + return [2]; + } + }); + }; + this_1 = this; + epoch = initialEpoch; + _a.label = 2; + case 2: + if (!(epoch < epochs)) return [3, 5]; + return [5, _loop_4(epoch)]; + case 3: + state_1 = _a.sent(); + if (state_1 === "break") + return [3, 5]; + _a.label = 4; + case 4: + ++epoch; + return [3, 2]; + case 5: return [4, callbackList.onTrainEnd()]; + case 6: + _a.sent(); + return [4, this.history.syncData()]; + case 7: + _a.sent(); + return [2, this.history]; + } + }); + }); + }; + Model.prototype.testLoop = function (f, ins, batchSize, verbose, steps) { + var _this = this; + if (verbose === void 0) { verbose = 0; } + return tfc.tidy(function () { + var numSamples = _this.checkNumSamples(ins, batchSize, steps, 'steps'); + var outs = []; + if (verbose === 1) { + throw new NotImplementedError('Verbose mode is not implemented yet.'); + } + if (steps != null) { + throw new NotImplementedError('steps mode in testLoop() is not implemented yet'); + } + else { + var batches = makeBatches(numSamples, batchSize); + var indexArray = tfc.tensor1d(range(0, numSamples)); + for (var batchIndex = 0; batchIndex < batches.length; ++batchIndex) { + var batchStart = batches[batchIndex][0]; + var batchEnd = batches[batchIndex][1]; + var batchIds = sliceAlongFirstAxis(indexArray, batchStart, batchEnd - batchStart); + var insBatch = sliceArraysByIndices(ins, batchIds); + var batchOuts = f(insBatch); + if (batchIndex === 0) { + for (var i = 0; i < batchOuts.length; ++i) { + outs.push(getScalar(0)); + } + } + for (var i = 0; i < batchOuts.length; ++i) { + var batchOut = batchOuts[i]; + outs[i] = + tfc.add(outs[i], tfc.mul(getScalar(batchEnd - batchStart), batchOut)); + } + } + for (var i = 0; i < outs.length; ++i) { + outs[i] = tfc.div(outs[i], getScalar(numSamples)); + } + } + return outs; + }); + }; + Model.prototype.getDedupedMetricsNames = function () { + var outLabels = this.metricsNames; + var dedupedOutLabels = []; + for (var i = 0; i < outLabels.length; ++i) { + var label = outLabels[i]; + var newLabel = label; + if (count(outLabels, label) > 1) { + var dupIndex = count(outLabels.slice(0, i), label); + newLabel += "_" + dupIndex; + } + dedupedOutLabels.push(newLabel); + } + return dedupedOutLabels; + }; + Model.prototype.makeTestFunction = function () { + var _this = this; + this.testFunction = function (data) { + return tfc.tidy(function () { + var valOutputs = []; + var totalLoss; + var inputs = data.slice(0, _this.inputs.length); + var targets = data.slice(_this.inputs.length, _this.inputs.length + _this.outputs.length); + var feeds = []; + for (var i = 0; i < _this.inputs.length; ++i) { + feeds.push({ key: _this.inputs[i], value: inputs[i] }); + } + var feedDict = new FeedDict(feeds); + var outputs = execute(_this.outputs, feedDict); + for (var i = 0; i < _this.lossFunctions.length; ++i) { + var lossFunction = _this.lossFunctions[i]; + var loss = tfc.mean(lossFunction(targets[i], outputs[i])); + if (i === 0) { + totalLoss = loss; + } + else { + totalLoss = tfc.add(totalLoss, loss); + } + valOutputs.push(totalLoss); + } + for (var i = 0; i < _this.metricsTensors.length; ++i) { + var metric = _this.metricsTensors[i][0]; + var outputIndex = _this.metricsTensors[i][1]; + var meanMetric = tfc.mean(metric(targets[outputIndex], outputs[outputIndex])); + valOutputs.push(meanMetric); + } + return valOutputs; + }); + }; + }; + Model.prototype.fit = function (x, y, config) { + if (config === void 0) { config = {}; } + return __awaiter(this, void 0, void 0, function () { + var _this = this; + var batchSize, standardizedOuts, inputs, targets, doValidation, valX, valY, valIns, needValidationDisposal, valStandardized, splitAt, originalBatchSize, ins, trainFunction, outLabels, valFunction, callbackMetrics, callbacks, out; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + batchSize = config.batchSize == null ? 32 : config.batchSize; + standardizedOuts = this.standardizeUserData(x, y, false, batchSize); + inputs = standardizedOuts[0]; + targets = standardizedOuts[1]; + doValidation = false; + needValidationDisposal = false; + if (config.validationData != null && config.validationData.length > 0) { + doValidation = true; + if (config.validationData.length === 2) { + valX = config.validationData[0]; + valY = config.validationData[1]; + } + else if (config.validationData.length === 3) { + throw new NotImplementedError('validationData including sample weights is not supported yet.'); + } + else { + throw new ValueError("When passing validation data, it must contain 2 (valX, valY) " + + "or 3 (valX, valY, valSampleWeight) items; " + + (config.validationData + " is invalid.")); + } + valStandardized = this.standardizeUserData(valX, valY, true, batchSize); + valX = valStandardized[0]; + valY = valStandardized[1]; + valIns = valX.concat(valY); + } + else if (config.validationSplit != null && config.validationSplit > 0 && + config.validationSplit < 1) { + doValidation = true; + splitAt = Math.floor(inputs[0].shape[0] * (1 - config.validationSplit)); + originalBatchSize = inputs[0].shape[0]; + valX = sliceArrays(inputs, splitAt, originalBatchSize); + inputs = sliceArrays(inputs, 0, splitAt); + valY = sliceArrays(targets, splitAt, originalBatchSize); + targets = sliceArrays(targets, 0, splitAt); + needValidationDisposal = true; + valIns = valX.concat(valY); + } + else if (config.validationSteps != null) { + doValidation = true; + } + ins = inputs.concat(targets); + this.checkTrainableWeightsConsistency(); + trainFunction = function (data) { + var inputs = data.slice(0, _this.inputs.length); + var targets = data.slice(_this.inputs.length, _this.inputs.length + _this.outputs.length); + var metricsValues = []; + var totalLossFunction = function () { + var feeds = []; + for (var i = 0; i < _this.inputs.length; ++i) { + feeds.push({ key: _this.inputs[i], value: inputs[i] }); + } + var feedDict = new FeedDict(feeds); + var outputs = execute(_this.outputs, feedDict, { 'training': true }); + var totalLoss; + for (var i = 0; i < _this.lossFunctions.length; ++i) { + var lossFunction = _this.lossFunctions[i]; + var loss = lossFunction(targets[i], outputs[i]); + var meanLoss = tfc.mean(loss); + if (i === 0) { + totalLoss = loss; + } + else { + totalLoss = tfc.add(totalLoss, loss); + } + } + for (var i = 0; i < _this.metricsTensors.length; ++i) { + var metric = _this.metricsTensors[i][0]; + var outputIndex = _this.metricsTensors[i][1]; + var meanMetric = tfc.mean(metric(targets[outputIndex], outputs[outputIndex])); + tfc.keep(meanMetric); + metricsValues.push(meanMetric); + } + totalLoss = tfc.mean(totalLoss); + _this.calculateLosses().forEach(function (regularizerLoss) { + totalLoss = tfc.add(totalLoss, regularizerLoss); + }); + return totalLoss; + }; + var variables = _this.collectedTrainableWeights.map(function (param) { return param.read(); }); + var returnCost = true; + var totalLossValue = _this.optimizer.minimize(totalLossFunction, returnCost, variables); + return [totalLossValue].concat(metricsValues); + }; + outLabels = this.getDedupedMetricsNames(); + if (doValidation) { + this.makeTestFunction(); + valFunction = this.testFunction; + callbackMetrics = + outLabels.slice().concat(outLabels.map(function (n) { return 'val_' + n; })); + } + else { + valFunction = null; + valIns = []; + callbackMetrics = outLabels.slice(); + } + callbacks = standardizeCallbacks(config.callbacks); + return [4, this.fitLoop(trainFunction, ins, outLabels, batchSize, config.epochs, config.verbose, callbacks, valFunction, valIns, config.shuffle, callbackMetrics, config.initialEpoch, null, null)]; + case 1: + out = _a.sent(); + if (needValidationDisposal) { + valIns.forEach(function (tensor) { return tensor.dispose(); }); + inputs.forEach(function (tensor) { return tensor.dispose(); }); + targets.forEach(function (tensor) { return tensor.dispose(); }); + } + return [2, out]; + } + }); + }); + }; + Model.prototype.getNamedWeights = function (config) { + var namedWeights = {}; + var trainableOnly = config != null && config.trainableOnly; + var weights = trainableOnly ? this.trainableWeights : this.weights; + var weightValues = this.getWeights(trainableOnly); + for (var i = 0; i < weights.length; ++i) { + if (trainableOnly && !weights[i].trainable) { + continue; + } + namedWeights[weights[i].originalName] = weightValues[i]; + } + return namedWeights; + }; + Model.prototype.save = function (handlerOrURL, config) { + return __awaiter(this, void 0, void 0, function () { + var handlers, weightDataAndSpecs, returnString, unusedArg, modelConfig; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (typeof handlerOrURL === 'string') { + handlers = tfc.io.getSaveHandlers(handlerOrURL); + if (handlers.length === 0) { + throw new ValueError("Cannot find any save handlers for URL '" + handlerOrURL + "'"); + } + else if (handlers.length > 1) { + throw new ValueError("Found more than one (" + handlers.length + ") save handlers for " + + ("URL '" + handlerOrURL + "'")); + } + handlerOrURL = handlers[0]; + } + if (handlerOrURL.save == null) { + throw new ValueError('Model.save() cannot proceed because the IOHandler provided does ' + + 'not have the `save` attribute defined.'); + } + return [4, tfc.io.encodeWeights(this.getNamedWeights(config))]; + case 1: + weightDataAndSpecs = _a.sent(); + returnString = false; + unusedArg = null; + modelConfig = this.toJSON(unusedArg, returnString); + return [2, handlerOrURL.save({ + modelTopology: modelConfig, + weightData: weightDataAndSpecs.data, + weightSpecs: weightDataAndSpecs.specs + })]; + } + }); + }); + }; + Model.className = 'Model'; + return Model; + }(Container)); + tfc.serialization.SerializationMap.register(Model); + + function loadModelInternal(pathOrIOHandler) { + return __awaiter(this, void 0, void 0, function () { + var handlers; + return __generator(this, function (_a) { + if (typeof pathOrIOHandler === 'string') { + handlers = tfc.io.getLoadHandlers(pathOrIOHandler); + if (handlers.length === 0) { + handlers.push(tfc.io.browserHTTPRequest(pathOrIOHandler)); + } + else if (handlers.length > 1) { + throw new ValueError("Found more than one (" + handlers.length + ") load handlers for " + + ("URL '" + pathOrIOHandler + "'")); + } + pathOrIOHandler = handlers[0]; + } + return [2, loadModelFromIOHandler(pathOrIOHandler)]; + }); + }); + } + function loadModelFromIOHandler(handler, customObjects) { + return __awaiter(this, void 0, void 0, function () { + var artifacts, modelTopology, model, skipMismatch, isNamedTensorMap; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (handler.load == null) { + throw new ValueError('Cannot proceed with model loading because the IOHandler provided ' + + 'does not have the `load` method implemented.'); + } + return [4, handler.load()]; + case 1: + artifacts = _a.sent(); + modelTopology = artifacts.modelTopology; + if (modelTopology['model_config'] != null) { + modelTopology = modelTopology['model_config']; + } + model = deserialize(convertPythonicToTs(modelTopology), customObjects); + if (artifacts.weightData != null) { + if (artifacts.weightSpecs == null) { + throw new ValueError('Model artifacts contains weight data, but not weight specs. ' + + 'Therefore loading of weights cannot proceed.'); + } + skipMismatch = false; + isNamedTensorMap = true; + model.loadWeights(tfc.io.decodeWeights(artifacts.weightData, artifacts.weightSpecs), skipMismatch, isNamedTensorMap); + } + return [2, model]; + } + }); + }); + } + var Sequential = (function (_super) { + __extends(Sequential, _super); + function Sequential(config) { + var _this = _super.call(this, { inputs: [], outputs: [] }) || this; + config = config || {}; + _this.trainable = true; + _this._updatable = true; + _this.built = false; + _this.name = (config.name != null) ? config.name : getUid('sequential_'); + if (config.layers != null) { + for (var _i = 0, _a = config.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + _this.add(layer); + } + } + return _this; + } + Sequential.prototype.add = function (layer) { + var isLayerModelInstance = layer instanceof Sequential || layer instanceof Model; + var modelLayer; + if (isLayerModelInstance) { + modelLayer = layer; + if (modelLayer.outputs.length !== 1) { + throw new ValueError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + if (modelLayer.inputs.length !== 1) { + throw new ValueError('All layers in a Sequential model ' + + 'should have a single input tensor. ' + + 'For multi-input layers, ' + + 'use the functional API.'); + } + } + if (this.outputs.length === 0) { + if (layer.inboundNodes.length === 0) { + if (layer.batchInputShape == null) { + throw new ValueError('The first layer in a Sequential model must ' + + 'get an `inputShape` or `batchInputShape` argument.'); + } + var x = Input({ + batchShape: layer.batchInputShape, + dtype: layer.dtype, + name: layer.name + '_input' + }); + layer.apply(x); + } + if (isLayerModelInstance) { + this.outputs = modelLayer.outputs; + this.inputs = modelLayer.inputs; + } + else { + if (layer.inboundNodes.length !== 1) { + throw new ValueError('A layer added to a Sequential model must not already be ' + + ("connected somewhere else. Model received layer " + layer.name + " ") + + ("which has " + layer.inboundNodes.length + " pre-existing inbound ") + + 'connections.'); + } + if (layer.inboundNodes[0].outputTensors.length !== 1) { + throw new ValueError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + this.outputs = [layer.inboundNodes[0].outputTensors[0]]; + this.inputs = getSourceInputs(this.outputs[0]); + } + this.inboundNodes = []; + new Node({ + outboundLayer: this, + inboundLayers: [], + nodeIndices: [], + tensorIndices: [], + inputTensors: this.inputs, + outputTensors: this.outputs, + inputMasks: pyListRepeat(null, this.inputs.length), + outputMasks: [null], + inputShapes: this.inputs.map(function (x) { return x.shape; }), + outputShapes: this.outputs[0].shape + }); + } + else { + var outputTensor = layer.apply(this.outputs[0]); + if (Array.isArray(outputTensor)) { + throw new TypeError('All layers in a Sequential model ' + + 'should have a single output tensor. ' + + 'For multi-output layers, ' + + 'use the functional API.'); + } + this.outputs = [outputTensor]; + this.inboundNodes[0].outputTensors = this.outputs; + this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + } + this.layers.push(layer); + this.built = false; + }; + Sequential.prototype.pop = function () { + if (this.layers.length === 0) { + throw new TypeError('There are no layers in the model.'); + } + this.layers.pop(); + if (this.layers.length === 0) { + this.outputs = []; + this.inboundNodes = []; + this.outboundNodes = []; + } + else { + var lastLayerIndex = this.layers.length - 1; + this.layers[lastLayerIndex].outboundNodes = []; + this.outputs = [this.layers[lastLayerIndex].output]; + this.inboundNodes[0].outputTensors = this.outputs; + this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + } + }; + Sequential.prototype.call = function (inputs, kwargs) { + if (this.model == null) { + this.build(); + } + return this.model.call(inputs, kwargs); + }; + Sequential.prototype.build = function (inputShape) { + getExactlyOneShape(inputShape); + if (this.inputs.length === 0 || this.outputs.length === 0) { + throw new TypeError('Sequential model cannot be built: model is empty.' + + ' Add some layers first.'); + } + this.model = new Model({ + inputs: this.inputs, + outputs: this.outputs[0], + name: this.name + '_model' + }); + this.model.trainable = this.trainable; + this.model.updatable = this.updatable; + this.supportsMasking = this.model.supportsMasking; + this.inputLayers = this.model.inputLayers; + this.inputLayersNodeIndices = this.model.inputLayersNodeIndices; + this.inputLayersTensorIndices = this.model.inputLayersTensorIndices; + this.outputLayers = this.model.outputLayers; + this.outputLayersNodeIndices = this.model.outputLayersNodeIndices; + this.outputLayersTensorIndices = this.model.outputLayersTensorIndices; + this.nodesByDepth = this.model.nodesByDepth; + this.containerNodes = this.model.containerNodes; + this.outputNames = this.model.outputNames; + this.inputNames = this.model.inputNames; + this.built = true; + }; + Sequential.prototype.countParams = function () { + if (!this.built) { + this.build(); + } + return _super.prototype.countParams.call(this); + }; + Sequential.prototype.summary = function (lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + if (!this.built) { + this.build(); + } + _super.prototype.summary.call(this, lineLength, positions, printFn); + }; + Sequential.prototype.setWeights = function (weights) { + if (this.model == null) { + this.build(); + } + this.model.setWeights(weights); + }; + Object.defineProperty(Sequential.prototype, "updatable", { + get: function () { + return this._updatable; + }, + set: function (value) { + if (this.built) { + this.model.updatable = value; + } + this._updatable = value; + }, + enumerable: true, + configurable: true + }); + Sequential.prototype.evaluate = function (x, y, config) { + if (config === void 0) { config = {}; } + if (!this.built) { + throw new RuntimeError('The model needs to be compiled before being used.'); + } + return this.model.evaluate(x, y, config); + }; + Sequential.prototype.predict = function (x, config) { + if (config === void 0) { config = {}; } + if (this.model == null) { + this.build(); + } + return this.model.predict(x, config); + }; + Sequential.prototype.predictOnBatch = function (x) { + if (this.model == null) { + this.build(); + } + return this.model.predictOnBatch(x); + }; + Sequential.prototype.compile = function (config) { + this.build(); + this.model.compile(config); + this.optimizer = this.model.optimizer; + this.loss = this.model.loss; + this.metrics = this.model.metrics; + this.metricsTensors = this.model.metricsTensors; + this.metricsNames = this.model.metricsNames; + }; + Sequential.prototype.fit = function (x, y, config) { + if (config === void 0) { config = {}; } + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + if (!this.built) { + throw new RuntimeError('The model needs to be compiled before ' + + 'being used.'); + } + return [2, this.model.fit(x, y, config)]; + }); + }); + }; + Sequential.fromConfig = function (cls, config) { + var model = new cls({}); + if (!(model instanceof Sequential)) { + throw new ValueError("Sequential.fromConfig called on non-Sequential input: " + model); + } + if (!(config instanceof Array)) { + throw new ValueError("Sequential.fromConfig called without an array of configs"); + } + if (!(config[0].className != null) || config[0]['className'] === 'Merge') { + throw new ValueError('Legacy serialization format not supported yet.'); + } + for (var _i = 0, _a = config; _i < _a.length; _i++) { + var conf = _a[_i]; + var layer = deserialize(conf); + model.add(layer); + } + return model; + }; + Sequential.prototype.getConfig = function () { + var config = []; + for (var _i = 0, _a = this.layers; _i < _a.length; _i++) { + var layer = _a[_i]; + config.push({ + className: layer.getClassName(), + config: layer.getConfig(), + }); + } + return config; + }; + Sequential.className = 'Sequential'; + return Sequential; + }(Model)); + tfc.serialization.SerializationMap.register(Sequential); + + function model(config) { + return new Model(config); + } + function sequential(config) { + return new Sequential(config); + } + function loadModel(pathOrIOHandler) { + return loadModelInternal(pathOrIOHandler); + } + function input(config) { + return Input(config); + } + + var Activation = (function (_super) { + __extends(Activation, _super); + function Activation() { + return _super !== null && _super.apply(this, arguments) || this; + } + Activation.prototype.getConfig = function () { + return {}; + }; + return Activation; + }(tfc.serialization.Serializable)); + var Elu = (function (_super) { + __extends(Elu, _super); + function Elu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Elu.prototype.apply = function (x, alpha) { + if (alpha === void 0) { alpha = 1; } + return elu(x, alpha); + }; + Elu.className = 'elu'; + return Elu; + }(Activation)); + tfc.serialization.SerializationMap.register(Elu); + var Selu = (function (_super) { + __extends(Selu, _super); + function Selu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Selu.prototype.apply = function (x) { + return tfc.selu(x); + }; + Selu.className = 'selu'; + return Selu; + }(Activation)); + tfc.serialization.SerializationMap.register(Selu); + var Relu = (function (_super) { + __extends(Relu, _super); + function Relu() { + return _super !== null && _super.apply(this, arguments) || this; + } + Relu.prototype.apply = function (x) { + return tfc.relu(x); + }; + Relu.className = 'relu'; + return Relu; + }(Activation)); + tfc.serialization.SerializationMap.register(Relu); + var Relu6 = (function (_super) { + __extends(Relu6, _super); + function Relu6() { + return _super !== null && _super.apply(this, arguments) || this; + } + Relu6.prototype.apply = function (x) { + return tfc.tidy(function () { return tfc.minimum(getScalar(6.0), tfc.relu(x)); }); + }; + Relu6.className = 'relu6'; + return Relu6; + }(Activation)); + tfc.serialization.SerializationMap.register(Relu6); + var Linear = (function (_super) { + __extends(Linear, _super); + function Linear() { + return _super !== null && _super.apply(this, arguments) || this; + } + Linear.prototype.apply = function (x) { + return x; + }; + Linear.className = 'linear'; + return Linear; + }(Activation)); + tfc.serialization.SerializationMap.register(Linear); + var Sigmoid = (function (_super) { + __extends(Sigmoid, _super); + function Sigmoid() { + return _super !== null && _super.apply(this, arguments) || this; + } + Sigmoid.prototype.apply = function (x) { + return tfc.sigmoid(x); + }; + Sigmoid.className = 'sigmoid'; + return Sigmoid; + }(Activation)); + tfc.serialization.SerializationMap.register(Sigmoid); + var HardSigmoid = (function (_super) { + __extends(HardSigmoid, _super); + function HardSigmoid() { + return _super !== null && _super.apply(this, arguments) || this; + } + HardSigmoid.prototype.apply = function (x) { + return hardSigmoid(x); + }; + HardSigmoid.className = 'hardSigmoid'; + return HardSigmoid; + }(Activation)); + tfc.serialization.SerializationMap.register(HardSigmoid); + var Softplus = (function (_super) { + __extends(Softplus, _super); + function Softplus() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softplus.prototype.apply = function (x) { + return tfc.softplus(x); + }; + Softplus.className = 'softplus'; + return Softplus; + }(Activation)); + tfc.serialization.SerializationMap.register(Softplus); + var Softsign = (function (_super) { + __extends(Softsign, _super); + function Softsign() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softsign.prototype.apply = function (x) { + return softsign(x); + }; + Softsign.className = 'softsign'; + return Softsign; + }(Activation)); + tfc.serialization.SerializationMap.register(Softsign); + var Tanh = (function (_super) { + __extends(Tanh, _super); + function Tanh() { + return _super !== null && _super.apply(this, arguments) || this; + } + Tanh.prototype.apply = function (x) { + return tfc.tanh(x); + }; + Tanh.className = 'tanh'; + return Tanh; + }(Activation)); + tfc.serialization.SerializationMap.register(Tanh); + var Softmax = (function (_super) { + __extends(Softmax, _super); + function Softmax() { + return _super !== null && _super.apply(this, arguments) || this; + } + Softmax.prototype.apply = function (x, axis) { + if (axis === void 0) { axis = (-1); } + return tfc.softmax(x, axis); + }; + Softmax.className = 'softmax'; + return Softmax; + }(Activation)); + tfc.serialization.SerializationMap.register(Softmax); + function serializeActivation(activation) { + return activation.getClassName(); + } + function deserializeActivation(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return deserializeKerasObject(config, tfc.serialization.SerializationMap.getMap().classNameMap, customObjects, 'activation'); + } + function getActivation(identifier) { + if (identifier == null) { + var config = { className: 'linear', config: {} }; + return deserializeActivation(config); + } + if (typeof identifier === 'string') { + var config = { className: identifier, config: {} }; + return deserializeActivation(config); + } + else if (identifier instanceof Activation) { + return identifier; + } + else { + return deserializeActivation(identifier); + } + } + + var LeakyReLU = (function (_super) { + __extends(LeakyReLU, _super); + function LeakyReLU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_ALPHA = 0.3; + if (config == null) { + config = {}; + } + _this.alpha = config.alpha == null ? _this.DEFAULT_ALPHA : config.alpha; + return _this; + } + LeakyReLU.prototype.call = function (inputs, kwargs) { + var x = getExactlyOneTensor(inputs); + return tfc.leakyRelu(x, this.alpha); + }; + LeakyReLU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + LeakyReLU.prototype.getConfig = function () { + var config = { alpha: this.alpha }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + LeakyReLU.className = 'LeakyReLU'; + return LeakyReLU; + }(Layer)); + tfc.serialization.SerializationMap.register(LeakyReLU); + var ELU = (function (_super) { + __extends(ELU, _super); + function ELU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_ALPHA = 1.0; + if (config == null) { + config = {}; + } + if (config.alpha != null && config.alpha !== _this.DEFAULT_ALPHA) { + throw new NotImplementedError("Non-default alpha value (" + config.alpha + ") is not supported by the " + + "ELU layer yet."); + } + _this.alpha = config.alpha == null ? _this.DEFAULT_ALPHA : config.alpha; + return _this; + } + ELU.prototype.call = function (inputs, kwargs) { + var x = getExactlyOneTensor(inputs); + return tfc.elu(x); + }; + ELU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + ELU.prototype.getConfig = function () { + var config = { alpha: this.alpha }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ELU.className = 'ELU'; + return ELU; + }(Layer)); + tfc.serialization.SerializationMap.register(ELU); + var ThresholdedReLU = (function (_super) { + __extends(ThresholdedReLU, _super); + function ThresholdedReLU(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_THETA = 1.0; + if (config == null) { + config = {}; + } + _this.theta = config.theta == null ? _this.DEFAULT_THETA : config.theta; + _this.thetaTensor = getScalar(_this.theta); + return _this; + } + ThresholdedReLU.prototype.call = function (inputs, kwargs) { + var x = getExactlyOneTensor(inputs); + return x.mul(cast(x.greater(this.thetaTensor), 'float32')); + }; + ThresholdedReLU.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + ThresholdedReLU.prototype.getConfig = function () { + var config = { theta: this.theta }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ThresholdedReLU.className = 'ThresholdedReLU'; + return ThresholdedReLU; + }(Layer)); + tfc.serialization.SerializationMap.register(ThresholdedReLU); + var Softmax$1 = (function (_super) { + __extends(Softmax$$1, _super); + function Softmax$$1(config) { + var _this = _super.call(this, config == null ? {} : config) || this; + _this.DEFAULT_AXIS = 1.0; + if (config == null) { + config = {}; + } + _this.softmax = new Softmax().apply; + _this.axis = config.axis == null ? _this.DEFAULT_AXIS : config.axis; + return _this; + } + Softmax$$1.prototype.call = function (inputs, kwargs) { + var x = getExactlyOneTensor(inputs); + return this.softmax(x, this.axis); + }; + Softmax$$1.prototype.computeOutputShape = function (inputShape) { + return inputShape; + }; + Softmax$$1.prototype.getConfig = function () { + var config = { axis: this.axis }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Softmax$$1.className = 'Softmax'; + return Softmax$$1; + }(Layer)); + tfc.serialization.SerializationMap.register(Softmax$1); + + var Regularizer = (function (_super) { + __extends(Regularizer, _super); + function Regularizer() { + return _super !== null && _super.apply(this, arguments) || this; + } + return Regularizer; + }(tfc.serialization.Serializable)); + var L1L2 = (function (_super) { + __extends(L1L2, _super); + function L1L2(config) { + var _this = _super.call(this) || this; + var l1 = config == null || config.l1 == null ? 0.01 : config.l1; + var l2 = config == null || config.l2 == null ? 0.01 : config.l2; + _this.hasL1 = l1 !== 0; + _this.hasL2 = l2 !== 0; + _this.l1 = getScalar(l1); + _this.l2 = getScalar(l2); + return _this; + } + L1L2.prototype.apply = function (x) { + var _this = this; + return tfc.tidy(function () { + var regularization = tfc.zeros([1]); + if (_this.hasL1) { + regularization = tfc.add(regularization, tfc.sum(tfc.mul(_this.l1, tfc.abs(x)))); + } + if (_this.hasL2) { + regularization = + tfc.add(regularization, tfc.sum(tfc.mul(_this.l2, square(x)))); + } + return regularization.asScalar(); + }); + }; + L1L2.prototype.getConfig = function () { + return { 'l1': this.l1.dataSync()[0], 'l2': this.l2.dataSync()[0] }; + }; + L1L2.fromConfig = function (cls, config) { + return new cls({ l1: config.l1, l2: config.l2 }); + }; + L1L2.className = 'L1L2'; + return L1L2; + }(Regularizer)); + tfc.serialization.SerializationMap.register(L1L2); + function l1(config) { + return new L1L2({ l1: config != null ? config.l1 : null, l2: 0 }); + } + function l2(config) { + return new L1L2({ l2: config != null ? config.l2 : null, l1: 0 }); + } + var REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { + 'l1l2': 'L1L2' + }; + function serializeRegularizer(constraint) { + return serializeKerasObject(constraint); + } + function deserializeRegularizer(config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + return deserializeKerasObject(config, tfc.serialization.SerializationMap.getMap().classNameMap, customObjects, 'regularizer'); + } + function getRegularizer(identifier) { + if (identifier == null) { + return null; + } + if (typeof identifier === 'string') { + var className = identifier in REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? + REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] : + identifier; + var config = { className: className, config: {} }; + return deserializeRegularizer(config); + } + else if (identifier instanceof Regularizer) { + return identifier; + } + else { + return deserializeRegularizer(identifier); + } + } + + function normalizeArray(value, n, name) { + if (typeof value === 'number') { + return pyListRepeat(value, n); + } + else { + if (value.length !== n) { + throw new ValueError("The " + name + " argument must be a tuple of " + n + " integers. Received: " + + (value.length + " elements.")); + } + for (var i = 0; i < n; ++i) { + var singleValue = value[i]; + if (!isInteger(singleValue)) { + throw new ValueError("The " + name + " argument must be a tuple of " + n + " integers. Received: " + + (JSON.stringify(value) + " including a non-integer number ") + + ("" + singleValue)); + } + } + return value; + } + } + function convOutputLength(inputLength, filterSize, padding, stride, dilation) { + if (dilation === void 0) { dilation = 1; } + if (inputLength == null) { + return inputLength; + } + var dilatedFilterSize = filterSize + (filterSize - 1) * (dilation - 1); + var outputLength; + if (padding === 'same') { + outputLength = inputLength; + } + else { + outputLength = inputLength - dilatedFilterSize + 1; + } + return Math.floor((outputLength + stride - 1) / stride); + } + function deconvLength(dimSize, strideSize, kernelSize, padding) { + if (dimSize == null) { + return null; + } + if (padding === 'valid') { + dimSize = dimSize * strideSize + max([kernelSize - strideSize, 0]); + } + else if (padding === 'same') { + dimSize = dimSize * strideSize; + } + else { + throw new ValueError("Unsupport padding mode: " + padding + "."); + } + return dimSize; + } + + function preprocessConv2DInput(x, dataFormat) { + return tfc.tidy(function () { + checkDataFormat(dataFormat); + if (dataFormat === 'channelsFirst') { + return tfc.transpose(x, [0, 2, 3, 1]); + } + else { + return x; + } + }); + } + function conv1dWithBias(x, kernel, bias, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = 1; } + if (padding === void 0) { padding = 'valid'; } + if (dilationRate === void 0) { dilationRate = 1; } + return tfc.tidy(function () { + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + checkDataFormat(dataFormat); + if (x.shape.length !== 3) { + throw new ValueError("The input of a conv1dWithBias operation should be 3, but is " + + (x.shape.length + " instead.")); + } + if (kernel.shape.length !== 3) { + throw new ValueError("The kernel for a conv1dWithBias operation should be 3, but is " + + (kernel.shape.length + " instead")); + } + if (bias != null && bias.shape.length !== 1) { + throw new ValueError("The bias for a conv1dWithBias operation should be 1, but is " + + (kernel.shape.length + " instead")); + } + if (dataFormat === 'channelsFirst') { + x = tfc.transpose(x, [0, 2, 1]); + } + if (padding === 'causal') { + throw new NotImplementedError('The support for CAUSAL padding mode in conv1dWithBias is not ' + + 'implemented yet.'); + } + var y = tfc.conv1d(x, kernel, strides, padding === 'same' ? 'same' : 'valid', 'NWC', dilationRate); + if (bias != null) { + y = biasAdd(y, bias); + } + return y; + }); + } + function conv2dWithBias(x, kernel, bias, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = [1, 1]; } + if (padding === void 0) { padding = 'valid'; } + return tfc.tidy(function () { + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + checkDataFormat(dataFormat); + if (x.rank !== 3 && x.rank !== 4) { + throw new ValueError("conv2dWithBias expects input to be of rank 3 or 4, but received " + + (x.rank + ".")); + } + if (kernel.rank !== 3 && kernel.rank !== 4) { + throw new ValueError("conv2dWithBias expects kernel to be of rank 3 or 4, but received " + + (x.rank + ".")); + } + var y = preprocessConv2DInput(x, dataFormat); + if (padding === 'causal') { + throw new NotImplementedError('The support for CAUSAL padding mode in conv1dWithBias is not ' + + 'implemented yet.'); + } + y = tfc.conv2d(y, kernel, strides, padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate); + if (bias != null) { + y = biasAdd(y, bias); + } + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); + } + var BaseConv = (function (_super) { + __extends(BaseConv, _super); + function BaseConv(rank, config) { + var _this = _super.call(this, config) || this; + _this.bias = null; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + BaseConv.verifyConfig(config); + _this.rank = rank; + if (_this.rank !== 1 && _this.rank !== 2) { + throw new NotImplementedError("Convolution layer for rank other than 1 or 2 (" + _this.rank + ") is " + + "not implemented yet."); + } + _this.kernelSize = normalizeArray(config.kernelSize, rank, 'kernelSize'); + _this.strides = normalizeArray(config.strides == null ? 1 : config.strides, rank, 'strides'); + _this.padding = config.padding == null ? 'valid' : config.padding; + checkPaddingMode(_this.padding); + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + checkDataFormat(_this.dataFormat); + _this.activation = getActivation(config.activation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.biasInitializer = + getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.biasConstraint = getConstraint(config.biasConstraint); + _this.biasRegularizer = getRegularizer(config.biasRegularizer); + _this.activityRegularizer = getRegularizer(config.activityRegularizer); + _this.dilationRate = normalizeArray(config.dilationRate == null ? 1 : config.dilationRate, rank, 'dilationRate'); + if (_this.rank === 1 && + (Array.isArray(_this.dilationRate) && + _this.dilationRate.length !== 1)) { + throw new ValueError("dilationRate must be a number or an array of a single number " + + "for 1D convolution, but received " + + ("" + JSON.stringify(_this.dilationRate))); + } + if (_this.rank === 2) { + if (typeof _this.dilationRate === 'number') { + _this.dilationRate = [_this.dilationRate, _this.dilationRate]; + } + else if (_this.dilationRate.length !== 2) { + throw new ValueError("dilationRate must be a number or array of two numbers for 2D " + + ("convolution, but received " + JSON.stringify(_this.dilationRate))); + } + } + return _this; + } + BaseConv.verifyConfig = function (config) { + assert('kernelSize' in config, "required key 'kernelSize' not in config"); + if (typeof config.kernelSize !== 'number' && + !checkArrayTypeAndLength(config.kernelSize, 'number', 1, 2)) + throw new ValueError("BaseConv expects config.kernelSize to be number or number[] with " + + ("length 1 or 2, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + BaseConv.prototype.getConfig = function () { + var config = { + kernelSize: this.kernelSize, + strides: this.strides, + padding: this.padding, + dataFormat: this.dataFormat, + dilationRate: this.dilationRate, + activation: serializeActivation(this.activation), + useBias: this.useBias, + biasInitializer: serializeInitializer(this.biasInitializer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + biasConstraint: serializeConstraint(this.biasConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return BaseConv; + }(Layer)); + var Conv = (function (_super) { + __extends(Conv, _super); + function Conv(rank, config) { + var _this = _super.call(this, rank, config) || this; + _this.kernel = null; + Conv.verifyConfig(config); + _this.filters = config.filters; + _this.kernelInitializer = getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.kernelConstraint = getConstraint(config.kernelConstraint); + _this.kernelRegularizer = getRegularizer(config.kernelRegularizer); + return _this; + } + Conv.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null) { + throw new ValueError("The channel dimension of the input should be defined. " + + ("Found " + inputShape[channelAxis])); + } + var inputDim = inputShape[channelAxis]; + var kernelShape = this.kernelSize.concat([inputDim, this.filters]); + this.kernel = this.addWeight('kernel', kernelShape, null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + this.inputSpec = [{ ndim: this.rank + 2, axes: (_a = {}, _a[channelAxis] = inputDim, _a) }]; + this.built = true; + var _a; + }; + Conv.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + var outputs; + var biasValue = _this.bias == null ? null : _this.bias.read(); + if (_this.rank === 1) { + outputs = conv1dWithBias(inputs, _this.kernel.read(), biasValue, _this.strides[0], _this.padding, _this.dataFormat, _this.dilationRate[0]); + } + else if (_this.rank === 2) { + outputs = conv2dWithBias(inputs, _this.kernel.read(), biasValue, _this.strides, _this.padding, _this.dataFormat, _this.dilationRate); + } + else if (_this.rank === 3) { + throw new NotImplementedError('3D convolution is not implemented yet.'); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + Conv.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var newSpace = []; + var space = (this.dataFormat === 'channelsLast') ? + inputShape.slice(1, inputShape.length - 1) : + inputShape.slice(2); + for (var i = 0; i < space.length; ++i) { + var newDim = convOutputLength(space[i], this.kernelSize[i], this.padding, this.strides[i], typeof this.dilationRate === 'number' ? this.dilationRate : + this.dilationRate[i]); + newSpace.push(newDim); + } + var outputShape = [inputShape[0]]; + if (this.dataFormat === 'channelsLast') { + outputShape = outputShape.concat(newSpace); + outputShape.push(this.filters); + } + else { + outputShape.push(this.filters); + outputShape = outputShape.concat(newSpace); + } + return outputShape; + }; + Conv.prototype.getConfig = function () { + var config = { + filters: this.filters, + kernelInitializer: serializeInitializer(this.kernelInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Conv.verifyConfig = function (config) { + if (!('filters' in config) || typeof config.filters !== 'number' || + config.filters < 1) { + throw new ValueError("Convolution layer expected config.filters to be a 'number' > 0 " + + ("but got " + JSON.stringify(config.filters))); + } + }; + return Conv; + }(BaseConv)); + var Conv2D = (function (_super) { + __extends(Conv2D, _super); + function Conv2D(config) { + var _this = _super.call(this, 2, config) || this; + Conv2D.verifyConfig(config); + return _this; + } + Conv2D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + return config; + }; + Conv2D.verifyConfig = function (config) { + if ((typeof config.kernelSize !== 'number') && + !checkArrayTypeAndLength(config.kernelSize, 'number', 1, 2)) + throw new ValueError("Conv2D expects config.kernelSize to be number or number[] with " + + ("length 1 or 2, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + Conv2D.className = 'Conv2D'; + return Conv2D; + }(Conv)); + tfc.serialization.SerializationMap.register(Conv2D); + var Conv2DTranspose = (function (_super) { + __extends(Conv2DTranspose, _super); + function Conv2DTranspose(config) { + var _this = _super.call(this, config) || this; + _this.inputSpec = [new InputSpec({ ndim: 4 })]; + if (_this.padding !== 'same' && _this.padding !== 'valid') { + throw new ValueError("Conv2DTranspose currently supports only padding modes 'same' " + + ("and 'valid', but received padding mode " + _this.padding)); + } + return _this; + } + Conv2DTranspose.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + if (inputShape.length !== 4) { + throw new ValueError('Input should have rank 4; Received input shape: ' + + JSON.stringify(inputShape)); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null) { + throw new ValueError('The channel dimension of the inputs should be defined. ' + + 'Found `None`.'); + } + var inputDim = inputShape[channelAxis]; + var kernelShape = this.kernelSize.concat([this.filters, inputDim]); + this.kernel = this.addWeight('kernel', kernelShape, 'float32', this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], 'float32', this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + this.inputSpec = + [new InputSpec({ ndim: 4, axes: (_a = {}, _a[channelAxis] = inputDim, _a) })]; + this.built = true; + var _a; + }; + Conv2DTranspose.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + if (input.shape.length !== 4) { + throw new ValueError("Conv2DTranspose.call() expects input tensor to be rank-4, but " + + ("received a tensor of rank-" + input.shape.length)); + } + var inputShape = input.shape; + var batchSize = inputShape[0]; + var hAxis; + var wAxis; + if (_this.dataFormat === 'channelsFirst') { + hAxis = 2; + wAxis = 3; + } + else { + hAxis = 1; + wAxis = 2; + } + var height = inputShape[hAxis]; + var width = inputShape[wAxis]; + var kernelH = _this.kernelSize[0]; + var kernelW = _this.kernelSize[1]; + var strideH = _this.strides[0]; + var strideW = _this.strides[1]; + var outHeight = deconvLength(height, strideH, kernelH, _this.padding); + var outWidth = deconvLength(width, strideW, kernelW, _this.padding); + var outputShape = [batchSize, outHeight, outWidth, _this.filters]; + if (_this.dataFormat !== 'channelsLast') { + input = tfc.transpose(input, [0, 2, 3, 1]); + } + var outputs = tfc.conv2dTranspose(input, _this.kernel.read(), outputShape, _this.strides, _this.padding); + if (_this.dataFormat !== 'channelsLast') { + outputs = tfc.transpose(outputs, [0, 3, 1, 2]); + } + if (_this.bias != null) { + outputs = + biasAdd(outputs, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + Conv2DTranspose.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var outputShape = inputShape.slice(); + var channelAxis; + var heightAxis; + var widthAxis; + if (this.dataFormat === 'channelsFirst') { + channelAxis = 1; + heightAxis = 2; + widthAxis = 3; + } + else { + channelAxis = 3; + heightAxis = 1; + widthAxis = 2; + } + var kernelH = this.kernelSize[0]; + var kernelW = this.kernelSize[1]; + var strideH = this.strides[0]; + var strideW = this.strides[1]; + outputShape[channelAxis] = this.filters; + outputShape[heightAxis] = + deconvLength(outputShape[heightAxis], strideH, kernelH, this.padding); + outputShape[widthAxis] = + deconvLength(outputShape[widthAxis], strideW, kernelW, this.padding); + return outputShape; + }; + Conv2DTranspose.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['dilationRate']; + return config; + }; + Conv2DTranspose.className = 'Conv2DTranspose'; + return Conv2DTranspose; + }(Conv2D)); + tfc.serialization.SerializationMap.register(Conv2DTranspose); + var SeparableConv = (function (_super) { + __extends(SeparableConv, _super); + function SeparableConv(rank, config) { + var _this = _super.call(this, rank, config) || this; + _this.DEFAULT_DEPTHWISE_INITIALIZER = 'glorotUniform'; + _this.DEFAULT_POINTWISE_INITIALIZER = 'glorotUniform'; + _this.depthwiseKernel = null; + _this.pointwiseKernel = null; + if (config.filters == null) { + throw new ValueError('The `filters` configuration field is required by SeparableConv, ' + + 'but is unspecified.'); + } + if (config.kernelInitializer != null || config.kernelRegularizer != null || + config.kernelConstraint != null) { + throw new ValueError('Fields kernelInitializer, kernelRegularizer and kernelConstraint ' + + 'are invalid for SeparableConv2D. Use depthwiseInitializer, ' + + 'depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, ' + + 'pointwiseRegularizer and pointwiseConstraint instead.'); + } + if (config.padding != null && config.padding !== 'same' && + config.padding !== 'valid') { + throw new ValueError("SeparableConv" + _this.rank + "D supports only padding modes: " + + ("'same' and 'valid', but received " + JSON.stringify(config.padding))); + } + _this.depthMultiplier = + config.depthMultiplier == null ? 1 : config.depthMultiplier; + _this.depthwiseInitializer = getInitializer(config.depthwiseInitializer || _this.DEFAULT_DEPTHWISE_INITIALIZER); + _this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer); + _this.depthwiseConstraint = getConstraint(config.depthwiseConstraint); + _this.pointwiseInitializer = getInitializer(config.depthwiseInitializer || _this.DEFAULT_POINTWISE_INITIALIZER); + _this.pointwiseRegularizer = getRegularizer(config.pointwiseRegularizer); + _this.pointwiseConstraint = getConstraint(config.pointwiseConstraint); + return _this; + } + SeparableConv.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + if (inputShape.length < this.rank + 2) { + throw new ValueError("Inputs to SeparableConv" + this.rank + "D should have rank " + + (this.rank + 2 + ", but received input shape: ") + + ("" + JSON.stringify(inputShape))); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1; + if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) { + throw new ValueError("The channel dimension of the inputs should be defined, " + + ("but found " + JSON.stringify(inputShape[channelAxis]))); + } + var inputDim = inputShape[channelAxis]; + var depthwiseKernelShape = this.kernelSize.concat([inputDim, this.depthMultiplier]); + var pointwiseKernelShape = []; + for (var i = 0; i < this.rank; ++i) { + pointwiseKernelShape.push(1); + } + pointwiseKernelShape.push(inputDim * this.depthMultiplier, this.filters); + var trainable = true; + this.depthwiseKernel = this.addWeight('depthwise_kernel', depthwiseKernelShape, 'float32', this.depthwiseInitializer, this.depthwiseRegularizer, trainable, this.depthwiseConstraint); + this.pointwiseKernel = this.addWeight('pointwise_kernel', pointwiseKernelShape, 'float32', this.pointwiseInitializer, this.pointwiseRegularizer, trainable, this.pointwiseConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.filters], 'float32', this.biasInitializer, this.biasRegularizer, trainable, this.biasConstraint); + } + else { + this.bias = null; + } + this.inputSpec = + [new InputSpec({ ndim: this.rank + 2, axes: (_a = {}, _a[channelAxis] = inputDim, _a) })]; + this.built = true; + var _a; + }; + SeparableConv.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + var output; + if (_this.rank === 1) { + throw new NotImplementedError('1D separable convolution is not implemented yet.'); + } + else if (_this.rank === 2) { + if (_this.dataFormat === 'channelsFirst') { + inputs = tfc.transpose(inputs, [0, 2, 3, 1]); + } + output = tfc.separableConv2d(inputs, _this.depthwiseKernel.read(), _this.pointwiseKernel.read(), _this.strides, _this.padding, _this.dilationRate, 'NHWC'); + } + if (_this.useBias) { + output = biasAdd(output, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + output = _this.activation.apply(output); + } + if (_this.dataFormat === 'channelsFirst') { + output = tfc.transpose(output, [0, 3, 1, 2]); + } + return output; + }); + }; + SeparableConv.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + delete config['kernelInitializer']; + delete config['kernelRegularizer']; + delete config['kernelConstraint']; + config['depthwiseInitializer'] = + serializeInitializer(this.depthwiseInitializer); + config['pointwiseInitializer'] = + serializeInitializer(this.pointwiseInitializer); + config['depthwiseRegularizer'] = + serializeRegularizer(this.depthwiseRegularizer); + config['pointwiseRegularizer'] = + serializeRegularizer(this.pointwiseRegularizer); + config['depthwiseConstraint'] = + serializeConstraint(this.depthwiseConstraint); + config['pointwiseConstraint'] = + serializeConstraint(this.pointwiseConstraint); + return config; + }; + SeparableConv.className = 'SeparableConv'; + return SeparableConv; + }(Conv)); + var SeparableConv2D = (function (_super) { + __extends(SeparableConv2D, _super); + function SeparableConv2D(config) { + return _super.call(this, 2, config) || this; + } + SeparableConv2D.className = 'SeparableConv2D'; + return SeparableConv2D; + }(SeparableConv)); + tfc.serialization.SerializationMap.register(SeparableConv2D); + var Conv1D = (function (_super) { + __extends(Conv1D, _super); + function Conv1D(config) { + var _this = _super.call(this, 1, config) || this; + Conv1D.verifyConfig(config); + _this.inputSpec = [{ ndim: 3 }]; + return _this; + } + Conv1D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + delete config['rank']; + delete config['dataFormat']; + return config; + }; + Conv1D.verifyConfig = function (config) { + if (typeof config.kernelSize !== 'number' && + !checkArrayTypeAndLength(config.kernelSize, 'number', 1, 1)) + throw new ValueError("Conv1D expects config.kernelSize to be number or number[] with " + + ("length 1, but received " + JSON.stringify(config.kernelSize) + ".")); + }; + Conv1D.className = 'Conv1D'; + return Conv1D; + }(Conv)); + tfc.serialization.SerializationMap.register(Conv1D); + var Cropping2D = (function (_super) { + __extends(Cropping2D, _super); + function Cropping2D(config) { + var _this = _super.call(this, config) || this; + if (typeof config.cropping === 'number') + _this.cropping = [ + [config.cropping, config.cropping], [config.cropping, config.cropping] + ]; + else if (typeof config.cropping[0] === 'number') + _this.cropping = [ + [config.cropping[0], config.cropping[0]], + [config.cropping[1], config.cropping[1]] + ]; + else + _this.cropping = config.cropping; + _this.dataFormat = + config.dataFormat === undefined ? 'channelsLast' : config.dataFormat; + _this.inputSpec = [{ ndim: 4 }]; + return _this; + } + Cropping2D.prototype.computeOutputShape = function (inputShape) { + if (this.dataFormat === 'channelsFirst') + return [ + inputShape[0], inputShape[1], + inputShape[2] - this.cropping[0][0] - this.cropping[0][1], + inputShape[2] - this.cropping[1][0] - this.cropping[1][1] + ]; + else + return [ + inputShape[0], + inputShape[1] - this.cropping[0][0] - this.cropping[0][1], + inputShape[2] - this.cropping[1][0] - this.cropping[1][1], inputShape[3] + ]; + }; + Cropping2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + var hSliced = sliceAlongAxis(inputs, _this.cropping[0][0], inputs.shape[1] - _this.cropping[0][0] - _this.cropping[0][1], 2); + return sliceAlongAxis(hSliced, _this.cropping[1][0], inputs.shape[2] - _this.cropping[1][1] - _this.cropping[1][0], 3); + } + else { + var hSliced = sliceAlongAxis(inputs, _this.cropping[0][0], inputs.shape[2] - _this.cropping[0][0] - _this.cropping[0][1], 3); + return sliceAlongAxis(hSliced, _this.cropping[1][0], inputs.shape[3] - _this.cropping[1][1] - _this.cropping[1][0], 4); + } + }); + }; + Cropping2D.prototype.getConfig = function () { + var config = { cropping: this.cropping, dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Cropping2D.className = 'Cropping2D'; + return Cropping2D; + }(Layer)); + tfc.serialization.SerializationMap.register(Cropping2D); + var UpSampling2D = (function (_super) { + __extends(UpSampling2D, _super); + function UpSampling2D(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_SIZE = [2, 2]; + _this.inputSpec = [{ ndim: 4 }]; + _this.size = config.size == null ? _this.DEFAULT_SIZE : config.size; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + return _this; + } + UpSampling2D.prototype.computeOutputShape = function (inputShape) { + if (this.dataFormat === 'channelsFirst') { + var height = inputShape[2] == null ? null : this.size[0] * inputShape[2]; + var width = inputShape[3] == null ? null : this.size[1] * inputShape[3]; + return [inputShape[0], inputShape[1], height, width]; + } + else { + var height = inputShape[1] == null ? null : this.size[0] * inputShape[1]; + var width = inputShape[2] == null ? null : this.size[1] * inputShape[2]; + return [inputShape[0], height, width, inputShape[3]]; + } + }; + UpSampling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + var inputShape = input.shape; + if (_this.dataFormat === 'channelsFirst') { + input = tfc.transpose(input, [0, 2, 3, 1]); + var height = _this.size[0] * inputShape[2]; + var width = _this.size[1] * inputShape[3]; + var resized = input.resizeNearestNeighbor([height, width]); + return tfc.transpose(resized, [0, 3, 1, 2]); + } + else { + var height = _this.size[0] * inputShape[1]; + var width = _this.size[1] * inputShape[2]; + return input.resizeNearestNeighbor([height, width]); + } + }); + }; + UpSampling2D.prototype.getConfig = function () { + var config = { size: this.size, dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + UpSampling2D.className = 'UpSampling2D'; + return UpSampling2D; + }(Layer)); + tfc.serialization.SerializationMap.register(UpSampling2D); + + function depthwiseConv2d(x, depthwiseKernel, strides, padding, dataFormat, dilationRate) { + if (strides === void 0) { strides = [1, 1]; } + if (padding === void 0) { padding = 'valid'; } + return tfc.tidy(function () { + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + checkDataFormat(dataFormat); + var y = preprocessConv2DInput(x, dataFormat); + if (x.rank !== 4) { + throw new ValueError("Input for depthwiseConv2d is required to be 4-D, but is instead " + + (x.rank + "-D")); + } + if (depthwiseKernel.rank !== 4) { + throw new ValueError("depthwiseKernel is required to be 4-D, but is instead " + + (depthwiseKernel.rank + "-D")); + } + y = tfc.depthwiseConv2d(y, depthwiseKernel, strides, padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate); + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); + } + var DepthwiseConv2D = (function (_super) { + __extends(DepthwiseConv2D, _super); + function DepthwiseConv2D(config) { + var _this = _super.call(this, 2, config) || this; + _this.depthwiseKernel = null; + _this.depthMultiplier = + config.depthMultiplier == null ? 1 : config.depthMultiplier; + _this.depthwiseInitializer = getInitializer(config.depthwiseInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.depthwiseConstraint = getConstraint(config.depthwiseConstraint); + _this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer); + return _this; + } + DepthwiseConv2D.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + if (inputShape.length < 4) { + throw new ValueError("Inputs to DepthwiseConv2D should have rank 4. " + + ("Received input shape: " + JSON.stringify(inputShape) + ".")); + } + var channelAxis = this.dataFormat === 'channelsFirst' ? 1 : 3; + if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) { + throw new ValueError('The channel dimension of the inputs to DepthwiseConv2D should ' + + ("be defined, but is not (" + inputShape[channelAxis] + ").")); + } + var inputDim = inputShape[channelAxis]; + var depthwiseKernelShape = [ + this.kernelSize[0], this.kernelSize[1], inputDim, this.depthMultiplier + ]; + this.depthwiseKernel = this.addWeight('depthwise_kernel', depthwiseKernelShape, null, this.depthwiseInitializer, this.depthwiseRegularizer, true, this.depthwiseConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [inputDim * this.depthMultiplier], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + DepthwiseConv2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + var outputs = depthwiseConv2d(inputs, _this.depthwiseKernel.read(), _this.strides, _this.padding, _this.dataFormat, null); + if (_this.useBias) { + outputs = biasAdd(outputs, _this.bias.read(), _this.dataFormat); + } + if (_this.activation != null) { + outputs = _this.activation.apply(outputs); + } + return outputs; + }); + }; + DepthwiseConv2D.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var rows = this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1]; + var cols = this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2]; + var outFilters = this.dataFormat === 'channelsFirst' ? + inputShape[1] * this.depthMultiplier : + inputShape[3] * this.depthMultiplier; + var outRows = convOutputLength(rows, this.kernelSize[0], this.padding, this.strides[0]); + var outCols = convOutputLength(cols, this.kernelSize[1], this.padding, this.strides[1]); + if (this.dataFormat === 'channelsFirst') { + return [inputShape[0], outFilters, outRows, outCols]; + } + else { + return [inputShape[0], outRows, outCols, outFilters]; + } + }; + DepthwiseConv2D.prototype.getConfig = function () { + var config = _super.prototype.getConfig.call(this); + config['depthMultiplier'] = this.depthMultiplier; + config['depthwiseInitializer'] = + serializeInitializer(this.depthwiseInitializer); + config['depthwiseRegularizer'] = + serializeRegularizer(this.depthwiseRegularizer); + config['depthwiseConstraint'] = + serializeConstraint(this.depthwiseRegularizer); + return config; + }; + DepthwiseConv2D.className = 'DepthwiseConv2D'; + return DepthwiseConv2D; + }(BaseConv)); + tfc.serialization.SerializationMap.register(DepthwiseConv2D); + + var Dropout = (function (_super) { + __extends(Dropout, _super); + function Dropout(config) { + var _this = _super.call(this, config) || this; + _this.rate = Math.max(Math.min(config.rate, 1), 0); + _this.rateScalar = getScalar(_this.rate); + _this.noiseShape = config.noiseShape; + _this.seed = config.seed; + if (_this.seed != null) { + throw new NotImplementedError('Non-default seed is not implemented in Dropout layer yet: ' + + _this.seed); + } + _this.supportsMasking = true; + return _this; + } + Dropout.prototype.getNoiseShape = function (input) { + if (this.noiseShape == null) { + return this.noiseShape; + } + var inputShape = input.shape; + var noiseShape = []; + for (var i = 0; i < this.noiseShape.length; ++i) { + noiseShape.push(this.noiseShape[i] == null ? inputShape[i] : this.noiseShape[i]); + } + return noiseShape; + }; + Dropout.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = getExactlyOneTensor(inputs); + if (_this.noiseShape != null && + !tfc.util.arraysEqual(input.shape, _this.noiseShape)) { + throw new NotImplementedError('Non-default noise shape is not implemented in Dropout ' + + 'layer yet: ' + JSON.stringify(_this.noiseShape)); + } + if (0 < _this.rate && _this.rate < 1) { + var training = kwargs['training'] == null ? false : kwargs['training']; + var noiseShape_1 = _this.getNoiseShape(input); + var output = inTrainPhase(function () { return dropout(input, _this.rateScalar, noiseShape_1, _this.seed); }, function () { return input; }, training); + return output; + } + return inputs; + }); + }; + Dropout.prototype.getConfig = function () { + var config = { + rate: this.rate, + noiseShape: this.noiseShape, + seed: this.seed, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Dropout.className = 'Dropout'; + return Dropout; + }(Layer)); + tfc.serialization.SerializationMap.register(Dropout); + var Dense = (function (_super) { + __extends(Dense, _super); + function Dense(config) { + var _this = _super.call(this, config) || this; + _this.activation = null; + _this.useBias = true; + _this.kernel = null; + _this.bias = null; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + if (config.batchInputShape == null && config.inputShape == null && + config.inputDim != null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + _this.batchInputShape = [batchSize, config.inputDim]; + } + _this.units = config.units; + _this.activation = getActivation(config.activation); + if (config.useBias != null) { + _this.useBias = config.useBias; + } + _this.kernelInitializer = getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.biasInitializer = + getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelConstraint = getConstraint(config.kernelConstraint); + _this.biasConstraint = getConstraint(config.biasConstraint); + _this.kernelRegularizer = getRegularizer(config.kernelRegularizer); + _this.biasRegularizer = getRegularizer(config.biasRegularizer); + _this.activityRegularizer = getRegularizer(config.activityRegularizer); + _this.inputSpec = [{ minNDim: 2 }]; + return _this; + } + Dense.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var inputLastDim = inputShape[inputShape.length - 1]; + if (this.kernel == null) { + this.kernel = this.addWeight('kernel', [inputLastDim, this.units], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + } + this.inputSpec = [{ minNDim: 2, axes: (_a = {}, _a[-1] = inputLastDim, _a) }]; + this.built = true; + var _a; + }; + Dense.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var outputShape = inputShape.slice(); + outputShape[outputShape.length - 1] = this.units; + return outputShape; + }; + Dense.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = getExactlyOneTensor(inputs); + var output = dot(input, _this.kernel.read()); + if (_this.bias != null) { + output = biasAdd(output, _this.bias.read()); + } + if (_this.activation != null) { + output = _this.activation.apply(output); + } + return output; + }); + }; + Dense.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + biasConstraint: serializeConstraint(this.biasConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Dense.className = 'Dense'; + return Dense; + }(Layer)); + tfc.serialization.SerializationMap.register(Dense); + var Flatten = (function (_super) { + __extends(Flatten, _super); + function Flatten(config) { + var _this = _super.call(this, config || {}) || this; + _this.inputSpec = [{ minNDim: 3 }]; + return _this; + } + Flatten.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + for (var _i = 0, _a = inputShape.slice(1); _i < _a.length; _i++) { + var dim = _a[_i]; + if (dim == null) { + throw new ValueError("The shape of the input to \"Flatten\" is not fully defined " + + ("(got " + inputShape.slice(1) + "). Make sure to pass a complete ") + + "\"input_shape\" or \"batch_input_shape\" argument to the first " + + "layer in your model."); + } + } + return [inputShape[0], arrayProd(inputShape, 1)]; + }; + Flatten.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + return batchFlatten(getExactlyOneTensor(inputs)); + }); + }; + Flatten.className = 'Flatten'; + return Flatten; + }(Layer)); + tfc.serialization.SerializationMap.register(Flatten); + var Activation$1 = (function (_super) { + __extends(Activation$$1, _super); + function Activation$$1(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + _this.activation = getActivation(config.activation); + return _this; + } + Activation$$1.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = getExactlyOneTensor(inputs); + return _this.activation.apply(input); + }); + }; + Activation$$1.prototype.getConfig = function () { + var config = { activation: serializeActivation(this.activation) }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Activation$$1.className = 'Activation'; + return Activation$$1; + }(Layer)); + tfc.serialization.SerializationMap.register(Activation$1); + var RepeatVector = (function (_super) { + __extends(RepeatVector, _super); + function RepeatVector(config) { + var _this = _super.call(this, config) || this; + _this.n = config.n; + _this.inputSpec = [{ ndim: 2 }]; + return _this; + } + RepeatVector.prototype.computeOutputShape = function (inputShape) { + return [inputShape[0], this.n, inputShape[1]]; + }; + RepeatVector.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + return repeat(inputs, _this.n); + }); + }; + RepeatVector.prototype.getConfig = function () { + var config = { + n: this.n, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + RepeatVector.className = 'RepeatVector'; + return RepeatVector; + }(Layer)); + tfc.serialization.SerializationMap.register(RepeatVector); + var Reshape = (function (_super) { + __extends(Reshape, _super); + function Reshape(config) { + var _this = _super.call(this, config) || this; + _this.targetShape = config.targetShape; + for (var i = 0; i < _this.targetShape.length; ++i) { + if (_this.isUnknown(_this.targetShape[i])) { + _this.targetShape[i] = null; + } + } + return _this; + } + Reshape.prototype.isUnknown = function (dim) { + return dim < 0 || dim == null; + }; + Reshape.prototype.fixUnknownDimension = function (inputShape, outputShape) { + var errorMsg = 'Total size of new array must be unchanged.'; + var finalShape = outputShape.slice(); + var known = 1; + var unknown = null; + for (var i = 0; i < finalShape.length; ++i) { + var dim = finalShape[i]; + if (this.isUnknown(dim)) { + if (unknown === null) { + unknown = i; + } + else { + throw new ValueError('Can only specifiy one unknown dimension.'); + } + } + else { + known *= dim; + } + } + var originalSize = arrayProd(inputShape); + if (unknown !== null) { + if (known === 0 || originalSize % known !== 0) { + throw new ValueError(errorMsg); + } + finalShape[unknown] = originalSize / known; + } + else if (originalSize !== known) { + throw new ValueError(errorMsg); + } + return finalShape; + }; + Reshape.prototype.computeOutputShape = function (inputShape) { + var anyUnknownDims = false; + for (var i = 0; i < inputShape.length; ++i) { + if (this.isUnknown(inputShape[i])) { + anyUnknownDims = true; + break; + } + } + if (anyUnknownDims) { + return inputShape.slice(0, 1).concat(this.targetShape); + } + else { + return inputShape.slice(0, 1).concat(this.fixUnknownDimension(inputShape.slice(1), this.targetShape)); + } + }; + Reshape.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = getExactlyOneTensor(inputs); + var inputShape = input.shape; + var outputShape = inputShape.slice(0, 1).concat(_this.fixUnknownDimension(inputShape.slice(1), _this.targetShape)); + return input.reshape(outputShape); + }); + }; + Reshape.prototype.getConfig = function () { + var config = { + targetShape: this.targetShape, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Reshape.className = 'Reshape'; + return Reshape; + }(Layer)); + tfc.serialization.SerializationMap.register(Reshape); + + var Embedding = (function (_super) { + __extends(Embedding, _super); + function Embedding(config) { + var _this = _super.call(this, config) || this; + _this.embeddings = null; + _this.DEFAULT_EMBEDDINGS_INITIALIZER = 'randomUniform'; + if (config.batchInputShape == null && config.inputShape == null) { + var batchSize = null; + if (config.batchSize != null) { + batchSize = config.batchSize; + } + if (config.inputLength == null) { + _this.batchInputShape = [batchSize, null]; + } + else { + _this.batchInputShape = + [batchSize].concat(toList(config.inputLength)); + } + } + _this.inputDim = config.inputDim; + _this.outputDim = config.outputDim; + _this.embeddingsInitializer = getInitializer(config.embeddingsInitializer || _this.DEFAULT_EMBEDDINGS_INITIALIZER); + _this.embeddingsRegularizer = getRegularizer(config.embeddingsRegularizer); + _this.activityRegularizer = getRegularizer(config.activityRegularizer); + _this.embeddingsConstraint = getConstraint(config.embeddingsConstraint); + _this.maskZero = config.maskZero; + _this.inputLength = config.inputLength; + return _this; + } + Embedding.prototype.build = function (inputShape) { + this.embeddings = this.addWeight('embeddings', [this.inputDim, this.outputDim], this.dtype, this.embeddingsInitializer, this.embeddingsRegularizer, true, this.embeddingsConstraint); + this.built = true; + }; + Embedding.prototype.warnOnIncompatibleInputShape = function (inputShape) { }; + Embedding.prototype.computeMask = function (inputs, mask) { + throw new NotImplementedError('computeMask has not been implemented for Embedding yet'); + }; + Embedding.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + if (this.inputLength == null) { + return inputShape.concat([this.outputDim]); + } + var inLens = toList(this.inputLength); + if (inLens.length !== inputShape.length - 1) { + throw new ValueError("\"inputLength\" is " + this.inputLength + ", but received " + + ("input shape has shape " + inputShape)); + } + else { + var i = 0; + for (var k = 0; k < inLens.length; ++k) { + var s1 = inLens[k]; + var s2 = inputShape[k + 1]; + if ((s1 != null) && (s2 != null) && (s1 !== s2)) { + throw new ValueError("\"inputLength\" is " + this.inputLength + ", but received " + + ("input shape has shape " + inputShape)); + } + else if (s1 == null) { + inLens[i] = s2; + } + i++; + } + } + return [inputShape[0]].concat(inLens, [this.outputDim]); + }; + Embedding.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + var input = getExactlyOneTensor(inputs); + if (input.dtype !== 'int32') { + input = cast(input, 'int32'); + } + var output = gather(_this.embeddings.read(), input.as1D()); + return output.reshape(getExactlyOneShape(_this.computeOutputShape(input.shape))); + }); + }; + Embedding.prototype.getConfig = function () { + var config = { + inputDim: this.inputDim, + outputDim: this.outputDim, + embeddingsInitializer: serializeInitializer(this.embeddingsInitializer), + embeddingsRegularizer: serializeRegularizer(this.embeddingsRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + embeddingsConstraint: serializeConstraint(this.embeddingsConstraint), + maskZero: this.maskZero, + inputLength: this.inputLength + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Embedding.className = 'Embedding'; + return Embedding; + }(Layer)); + tfc.serialization.SerializationMap.register(Embedding); + + var Merge = (function (_super) { + __extends(Merge, _super); + function Merge(config) { + var _this = _super.call(this, config || {}) || this; + _this.supportsMasking = true; + return _this; + } + Merge.prototype.mergeFunction = function (inputs) { + throw new NotImplementedError(); + }; + Merge.prototype.computeElementwiseOpOutputShape = function (shape1, shape2) { + if (shape1 == null || shape2 == null) { + return null; + } + else if (shape1.length < shape2.length) { + return this.computeElementwiseOpOutputShape(shape2, shape1); + } + else if (shape2.length === 0) { + return shape1; + } + var outputShape = shape1.slice(0, shape1.length - shape2.length); + for (var k = 0; k < shape2.length; ++k) { + var i = shape1[shape1.length - shape2.length + k]; + var j = shape2[k]; + if (i == null || j == null || i < 0 || j < 0) { + outputShape.push(null); + } + else if (i === 1) { + outputShape.push(j); + } + else if (j === 1) { + outputShape.push(i); + } + else { + if (i !== j) { + throw new ValueError('Operands could not be broadcast together with shapes ' + + JSON.stringify(shape1) + ' ' + JSON.stringify(shape2)); + } + outputShape.push(i); + } + } + return outputShape; + }; + Merge.prototype.build = function (inputShape) { + if (Array.isArray(inputShape) && !Array.isArray(inputShape[0])) { + inputShape = [getExactlyOneShape(inputShape)]; + } + inputShape = inputShape; + if (inputShape.length < 2) { + throw new ValueError('A merge layer should be called on an Array of at least 2 inputs.' + + (" Got " + inputShape.length + " input(s).")); + } + var batchSizes = []; + for (var _i = 0, inputShape_1 = inputShape; _i < inputShape_1.length; _i++) { + var shape = inputShape_1[_i]; + if (shape != null && shape[0] !== null) { + batchSizes.push(shape[0]); + } + } + batchSizes = unique(batchSizes); + if (batchSizes.length > 1) { + throw new ValueError("Can not merge tensors with different batch sizes. " + + ("Got tensors with shapes: " + JSON.stringify(inputShape) + ".")); + } + var outputShape = inputShape[0] == null ? null : inputShape[0].slice(1); + for (var i = 1; i < inputShape.length; ++i) { + var shape = inputShape[i] == null ? null : inputShape[i].slice(1); + outputShape = this.computeElementwiseOpOutputShape(outputShape, shape); + } + var allRanks = inputShape.map(function (shape) { return shape.length; }); + if (inputShape.indexOf(null) === -1 && + unique(allRanks).length === 1) { + this.reshapeRequired = false; + } + else { + this.reshapeRequired = true; + } + }; + Merge.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = inputs; + if (_this.reshapeRequired) { + var reshapedInputs = []; + var inputDims = inputs.map(function (input) { return input.rank; }); + if (inputDims.indexOf(null) === -1) { + var maxNDim = max(inputDims); + for (var _i = 0, inputs_1 = inputs; _i < inputs_1.length; _i++) { + var x = inputs_1[_i]; + var xNDim = x.rank; + for (var k = 0; k < maxNDim - xNDim; ++k) { + x = expandDims(x, 1); + } + reshapedInputs.push(x); + } + return _this.mergeFunction(reshapedInputs); + } + else { + var transposed = false; + for (var _a = 0, inputs_2 = inputs; _a < inputs_2.length; _a++) { + var x = inputs_2[_a]; + var xNDim = x.rank; + if (xNDim == null) { + var xShape = x.shape; + var batchSize = xShape[0]; + var newShape = xShape.slice(1).concat([batchSize]); + var xTransposed = x.reshape([batchSize].concat(arrayProd(xShape.slice(1)))); + xTransposed = tfc.transpose(xTransposed, [1, 0]); + xTransposed = xTransposed.reshape(newShape); + reshapedInputs.push(xTransposed); + transposed = true; + } + else if (xNDim > 1) { + var dims = range(1, xNDim).concat([0]); + reshapedInputs.push(tfc.transpose(x, dims)); + transposed = true; + } + else { + reshapedInputs.push(x); + } + } + var y = _this.mergeFunction(reshapedInputs); + var yNDim = y.rank; + if (transposed) { + if (yNDim == null) { + var yShape = y.shape; + var yNDim_1 = yShape.length; + var batchSize = yShape[yNDim_1 - 1]; + var newShape = [batchSize].concat(yShape.slice(0, yShape.length - 1)); + y = tfc.transpose(y.reshape([-1, batchSize]), [1, 0]) + .reshape(newShape); + } + else if (yNDim > 1) { + var dims = [yNDim - 1].concat(range(0, yNDim - 1)); + y = tfc.transpose(y, dims); + } + } + return y; + } + } + else { + return _this.mergeFunction(inputs); + } + }); + }; + Merge.prototype.computeOutputShape = function (inputShape) { + inputShape = inputShape; + var outputShape; + if (inputShape[0] == null) { + outputShape = null; + } + else { + outputShape = inputShape[0].slice(1); + } + for (var i = 1; i < inputShape.length; ++i) { + var shape = inputShape[i] == null ? null : inputShape[i].slice(1); + outputShape = this.computeElementwiseOpOutputShape(outputShape, shape); + } + var batchSizes = []; + for (var _i = 0, inputShape_2 = inputShape; _i < inputShape_2.length; _i++) { + var shape = inputShape_2[_i]; + if (shape != null && shape[0] !== null) { + batchSizes.push(shape[0]); + } + } + batchSizes = unique(batchSizes); + if (batchSizes.length === 1) { + outputShape = batchSizes.concat(outputShape); + } + else { + outputShape = [null].concat(outputShape); + } + return outputShape; + }; + return Merge; + }(Layer)); + var Add = (function (_super) { + __extends(Add, _super); + function Add(config) { + return _super.call(this, config) || this; + } + Add.prototype.mergeFunction = function (inputs) { + return tfc.tidy(function () { + var output = tfc.zeros(inputs[0].shape); + for (var _i = 0, inputs_3 = inputs; _i < inputs_3.length; _i++) { + var input = inputs_3[_i]; + output = tfc.add(output, input); + } + return output; + }); + }; + Add.className = 'Add'; + return Add; + }(Merge)); + tfc.serialization.SerializationMap.register(Add); + var Multiply = (function (_super) { + __extends(Multiply, _super); + function Multiply(config) { + return _super.call(this, config) || this; + } + Multiply.prototype.mergeFunction = function (inputs) { + return tfc.tidy(function () { + var output = tfc.ones(inputs[0].shape); + for (var _i = 0, inputs_4 = inputs; _i < inputs_4.length; _i++) { + var input = inputs_4[_i]; + output = tfc.mul(output, input); + } + return output; + }); + }; + Multiply.className = 'Multiply'; + return Multiply; + }(Merge)); + tfc.serialization.SerializationMap.register(Multiply); + var Average = (function (_super) { + __extends(Average, _super); + function Average(config) { + return _super.call(this, config) || this; + } + Average.prototype.mergeFunction = function (inputs) { + return tfc.tidy(function () { + var output = tfc.zeros(inputs[0].shape); + for (var _i = 0, inputs_5 = inputs; _i < inputs_5.length; _i++) { + var input = inputs_5[_i]; + output = tfc.add(output, input); + } + return tfc.mul(getScalar(1 / inputs.length), output); + }); + }; + Average.className = 'Average'; + return Average; + }(Merge)); + tfc.serialization.SerializationMap.register(Average); + var Maximum = (function (_super) { + __extends(Maximum, _super); + function Maximum(config) { + return _super.call(this, config) || this; + } + Maximum.prototype.mergeFunction = function (inputs) { + return tfc.tidy(function () { + var output = inputs[0]; + for (var i = 1; i < inputs.length; ++i) { + output = tfc.maximum(output, inputs[i]); + } + return output; + }); + }; + Maximum.className = 'Maximum'; + return Maximum; + }(Merge)); + tfc.serialization.SerializationMap.register(Maximum); + var Minimum = (function (_super) { + __extends(Minimum, _super); + function Minimum(config) { + return _super.call(this, config) || this; + } + Minimum.prototype.mergeFunction = function (inputs) { + return tfc.tidy(function () { + var output = inputs[0]; + for (var i = 1; i < inputs.length; ++i) { + output = tfc.minimum(output, inputs[i]); + } + return output; + }); + }; + Minimum.className = 'Minimum'; + return Minimum; + }(Merge)); + tfc.serialization.SerializationMap.register(Minimum); + var Concatenate = (function (_super) { + __extends(Concatenate, _super); + function Concatenate(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_AXIS = -1; + if (config == null) { + config = {}; + } + _this.axis = config.axis == null ? _this.DEFAULT_AXIS : config.axis; + _this.supportsMasking = true; + _this.reshapeRequired = false; + return _this; + } + Concatenate.prototype.build = function (inputShape) { + if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0])) || + inputShape.length === 1) { + throw new ValueError('A `Concatenate` layer should be called on a list of at least 2 ' + + 'inputs'); + } + inputShape = inputShape; + var allNoneShape = true; + for (var _i = 0, inputShape_3 = inputShape; _i < inputShape_3.length; _i++) { + var shape = inputShape_3[_i]; + if (shape != null) { + allNoneShape = false; + break; + } + } + if (allNoneShape) { + return; + } + var shapeSet = []; + for (var i = 0; i < inputShape.length; ++i) { + var shapeWithoutConcatAxis = inputShape[i].slice(); + shapeWithoutConcatAxis.splice(this.axis, 1); + var exists = false; + for (var _a = 0, shapeSet_1 = shapeSet; _a < shapeSet_1.length; _a++) { + var shape = shapeSet_1[_a]; + if (tfc.util.arraysEqual(shape, shapeWithoutConcatAxis)) { + exists = true; + break; + } + } + if (!exists) { + shapeSet.push(shapeWithoutConcatAxis); + } + } + if (shapeSet.length > 1) { + throw new ValueError('A `Concatenate` layer requires inputs with matching shapes ' + + 'except for the concat axis. Got input shapes: ' + + JSON.stringify(inputShape)); + } + }; + Concatenate.prototype.mergeFunction = function (inputs) { + var _this = this; + return tfc.tidy(function () { + return concatenate(inputs, _this.axis); + }); + }; + Concatenate.prototype.computeOutputShape = function (inputShape) { + if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0]))) { + throw new ValueError('A `Concatenate` layer should be called on a list of inputs.'); + } + var inputShapes = inputShape; + var outputShape = inputShapes[0].slice(); + var axis = this.axis < 0 ? outputShape.length + this.axis : this.axis; + for (var _i = 0, _a = inputShapes.slice(1); _i < _a.length; _i++) { + var shape = _a[_i]; + if (outputShape[axis] == null || shape[axis] == null) { + outputShape[axis] = null; + break; + } + outputShape[axis] += shape[axis]; + } + return outputShape; + }; + Concatenate.prototype.getConfig = function () { + var config = { + 'axis': this.axis, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Concatenate.className = 'Concatenate'; + return Concatenate; + }(Merge)); + tfc.serialization.SerializationMap.register(Concatenate); + + function batchNormalization(x, mean$$1, variance$$1, beta, gamma, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + var out; + if (x.rank === 2) { + out = tfc.batchNormalization2d(x, mean$$1, variance$$1, epsilon, gamma, beta); + } + else if (x.rank === 3) { + out = tfc.batchNormalization3d(x, mean$$1, variance$$1, epsilon, gamma, beta); + } + else if (x.rank === 4) { + out = tfc.batchNormalization4d(x, mean$$1, variance$$1, epsilon, gamma, beta); + } + else { + throw new NotImplementedError("batchNormalization is not implememnted for array of rank " + x.rank + " " + + "yet"); + } + return out; + } + function regularNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + return tfc.tidy(function () { + var meanAndVariance = tfc.moments(x, reductionAxes); + var mean$$1 = meanAndVariance.mean; + var variance$$1 = meanAndVariance.variance; + var normed = batchNormalization(x, mean$$1, variance$$1, beta, gamma, epsilon); + return [normed, mean$$1, variance$$1]; + }); + } + function broadcastNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + return tfc.tidy(function () { + var meanAndVariance = tfc.moments(x, reductionAxes); + var mean$$1 = meanAndVariance.mean; + var variance$$1 = meanAndVariance.variance; + var targetShape = []; + for (var _i = 0, _a = range(0, x.rank); _i < _a.length; _i++) { + var axis = _a[_i]; + if (reductionAxes.indexOf(axis) !== -1) { + targetShape.push(1); + } + else { + targetShape.push(x.shape[axis]); + } + } + var broadcastMean = mean$$1.reshape(targetShape); + var broadcastVariance = variance$$1.reshape(targetShape); + var broadcastGamma = gamma == null ? null : gamma.reshape(targetShape); + var broadcastBeta = beta == null ? null : beta.reshape(targetShape); + var normed = batchNormalization(x, broadcastMean, broadcastVariance, broadcastBeta, broadcastGamma, epsilon); + return [normed, mean$$1, variance$$1]; + }); + } + function normalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon) { + if (epsilon === void 0) { epsilon = 1e-3; } + if (tfc.util.arraysEqual(reductionAxes.slice().sort(), range(0, x.rank - 1))) { + return regularNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon); + } + else { + return broadcastNormalizeBatchInTraining(x, gamma, beta, reductionAxes, epsilon); + } + } + var BatchNormalization = (function (_super) { + __extends(BatchNormalization, _super); + function BatchNormalization(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + _this.axis = config.axis == null ? -1 : config.axis; + _this.momentum = config.momentum == null ? 0.99 : config.momentum; + _this.epsilon = config.epsilon == null ? 1e-3 : config.epsilon; + _this.center = config.center == null ? true : config.center; + _this.scale = config.scale == null ? true : config.scale; + _this.betaInitializer = getInitializer(config.betaInitializer || 'zeros'); + _this.gammaInitializer = getInitializer(config.gammaInitializer || 'ones'); + _this.movingMeanInitializer = + getInitializer(config.movingMeanInitializer || 'zeros'); + _this.movingVarianceInitializer = + getInitializer(config.movingVarianceInitializer || 'ones'); + _this.betaConstraint = getConstraint(config.betaConstraint); + _this.gammaConstraint = getConstraint(config.gammaConstraint); + _this.betaRegularizer = getRegularizer(config.betaRegularizer); + _this.gammaRegularizer = getRegularizer(config.gammaRegularizer); + _this.stepCount = 0; + return _this; + } + BatchNormalization.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var axis = this.axis >= 0 ? this.axis : (this.axis + inputShape.length); + var dim = inputShape[axis]; + if (dim == null) { + throw new ValueError("Axis " + axis + " of input tensor should have a defined dimension but " + + "the layer received an input with shape " + + (JSON.stringify(inputShape) + ".")); + } + this.inputSpec = + [new InputSpec({ ndim: inputShape.length, axes: (_a = {}, _a[axis] = dim, _a) })]; + var shape = [dim]; + if (this.scale) { + this.gamma = this.addWeight('gamma', shape, null, this.gammaInitializer, this.gammaRegularizer, true, this.gammaConstraint); + } + if (this.center) { + this.beta = this.addWeight('beta', shape, null, this.betaInitializer, this.betaRegularizer, true, this.betaConstraint); + } + this.movingMean = this.addWeight('moving_mean', shape, null, this.movingMeanInitializer, null, false); + this.movingVariance = this.addWeight('moving_variance', shape, null, this.movingVarianceInitializer, null, false); + this.built = true; + var _a; + }; + BatchNormalization.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var training = kwargs['training'] == null ? false : kwargs['training']; + var input = getExactlyOneTensor(inputs); + var inputShape = input.shape; + var ndim = inputShape.length; + var reductionAxes = range(0, ndim); + var axis = _this.axis >= 0 ? _this.axis : (_this.axis + ndim); + reductionAxes.splice(axis, 1); + var broadcastShape = pyListRepeat(1, ndim); + broadcastShape[axis] = inputShape[axis]; + var sortedReductionAxes = reductionAxes.slice(); + sortedReductionAxes.sort(); + var needsBroadcasting = !tfc.util.arraysEqual(sortedReductionAxes, range(0, ndim).slice(0, ndim - 1)); + var normalizeInference = function () { + if (needsBroadcasting) { + var broadcastMovingMean = _this.movingMean.read().reshape(broadcastShape); + var broadcastMovingVariance = _this.movingVariance.read().reshape(broadcastShape); + var broadcastBeta = _this.center ? _this.beta.read().reshape(broadcastShape) : null; + var broadcastGamma = _this.scale ? _this.gamma.read().reshape(broadcastShape) : null; + return batchNormalization(input, broadcastMovingMean, broadcastMovingVariance, broadcastBeta, broadcastGamma, _this.epsilon); + } + else { + return batchNormalization(input, _this.movingMean.read(), _this.movingVariance.read(), _this.beta == null ? null : _this.beta.read(), _this.gamma == null ? null : _this.gamma.read(), _this.epsilon); + } + }; + if (!training) { + return normalizeInference(); + } + var _a = normalizeBatchInTraining(input, _this.gamma.read(), _this.beta.read(), reductionAxes, _this.epsilon), normedTraining = _a[0], mean$$1 = _a[1], variance$$1 = _a[2]; + var sampleSize = arrayProd(reductionAxes.map(function (axis) { return input.shape[axis]; })); + var varianceDebiased = variance$$1.mul(getScalar(sampleSize / (sampleSize - (1 + _this.epsilon)))); + var updateMovingMeanAndVariance = function () { + _this.stepCount++; + var newMovingMean = tfc.movingAverage(_this.movingMean.read(), mean$$1, _this.momentum, _this.stepCount); + _this.movingMean.write(newMovingMean); + var newMovingVariance = tfc.movingAverage(_this.movingVariance.read(), varianceDebiased, _this.momentum, _this.stepCount); + _this.movingVariance.write(newMovingVariance); + }; + updateMovingMeanAndVariance(); + return normedTraining; + }); + }; + BatchNormalization.prototype.getConfig = function () { + var config = { + axis: this.axis, + momentum: this.momentum, + epsilon: this.epsilon, + center: this.center, + scale: this.scale, + betaInitializer: serializeInitializer(this.betaInitializer), + gammaInitializer: serializeInitializer(this.gammaInitializer), + movingMeanInitializer: serializeInitializer(this.movingMeanInitializer), + movingVarianceInitializer: serializeInitializer(this.movingVarianceInitializer), + betaRegularizer: serializeRegularizer(this.betaRegularizer), + gammaRegularizer: serializeRegularizer(this.gammaRegularizer), + betaConstraint: serializeConstraint(this.betaConstraint), + gammaConstraint: serializeConstraint(this.gammaConstraint) + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + BatchNormalization.className = 'BatchNormalization'; + return BatchNormalization; + }(Layer)); + tfc.serialization.SerializationMap.register(BatchNormalization); + + function spatial2dPadding(x, padding, dataFormat) { + return tfc.tidy(function () { + if (x.rank !== 4) { + throw new ValueError("temporalPadding expects input tensor to be 4-D, but received a " + + (x.rank + "-D tensor.")); + } + if (padding == null) { + padding = [[1, 1], [1, 1]]; + } + if (padding.length !== 2 || padding[0].length !== 2 || + padding[1].length !== 2) { + throw new ValueError('spatial2dPadding expects `padding` to be an Array of two Arrays, ' + + 'each of which is an Array of two integers.'); + } + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + if (dataFormat !== 'channelsLast' && dataFormat !== 'channelsFirst') { + throw new ValueError("Unknown data format: " + dataFormat + ". " + + "Supported data formats are 'channelsLast' and 'channelsFirst."); + } + var pattern; + if (dataFormat === 'channelsFirst') { + pattern = [[0, 0], [0, 0], padding[0], padding[1]]; + } + else { + pattern = [[0, 0], padding[0], padding[1], [0, 0]]; + } + return tfc.pad(x, pattern); + }); + } + var ZeroPadding2D = (function (_super) { + __extends(ZeroPadding2D, _super); + function ZeroPadding2D(config) { + var _this = this; + if (config == null) { + config = {}; + } + _this = _super.call(this, config) || this; + _this.dataFormat = + config.dataFormat == null ? imageDataFormat() : config.dataFormat; + if (config.padding == null) { + _this.padding = [[1, 1], [1, 1]]; + } + else if (typeof config.padding === 'number') { + _this.padding = + [[config.padding, config.padding], [config.padding, config.padding]]; + } + else { + config.padding = config.padding; + if (config.padding.length !== 2) { + throw new ValueError("ZeroPadding2D expects padding to be a length-2 array, but " + + ("received a length-" + config.padding.length + " array.")); + } + var heightPadding = void 0; + var widthPadding = void 0; + if (typeof config.padding[0] === 'number') { + heightPadding = + [config.padding[0], config.padding[0]]; + widthPadding = + [config.padding[1], config.padding[1]]; + } + else { + config.padding = config.padding; + if (config.padding[0].length !== 2) { + throw new ValueError("ZeroPadding2D expects height padding to be a length-2 array, " + + ("but received a length-" + config.padding[0].length + " array.")); + } + heightPadding = config.padding[0]; + if (config.padding[1].length !== 2) { + throw new ValueError("ZeroPadding2D expects width padding to be a length-2 array, " + + ("but received a length-" + config.padding[1].length + " array.")); + } + widthPadding = config.padding[1]; + } + _this.padding = [heightPadding, widthPadding]; + } + _this.inputSpec = [new InputSpec({ ndim: 4 })]; + return _this; + } + ZeroPadding2D.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var rows; + var cols; + if (this.dataFormat === 'channelsFirst') { + if (inputShape[2] != null && inputShape[2] >= 0) { + rows = inputShape[2] + this.padding[0][0] + this.padding[0][1]; + } + else { + rows = null; + } + if (inputShape[3] != null && inputShape[3] >= 0) { + cols = inputShape[3] + this.padding[1][0] + this.padding[1][1]; + } + else { + cols = null; + } + return [inputShape[0], inputShape[1], rows, cols]; + } + else { + if (inputShape[1] != null && inputShape[1] >= 0) { + rows = inputShape[1] + this.padding[0][0] + this.padding[0][1]; + } + else { + rows = null; + } + if (inputShape[2] != null && inputShape[2] >= 0) { + cols = inputShape[2] + this.padding[1][0] + this.padding[1][1]; + } + else { + cols = null; + } + return [inputShape[0], rows, cols, inputShape[3]]; + } + }; + ZeroPadding2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { return spatial2dPadding(getExactlyOneTensor(inputs), _this.padding, _this.dataFormat); }); + }; + ZeroPadding2D.prototype.getConfig = function () { + var config = { + padding: this.padding, + dataFormat: this.dataFormat, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + ZeroPadding2D.className = 'ZeroPadding2D'; + return ZeroPadding2D; + }(Layer)); + tfc.serialization.SerializationMap.register(ZeroPadding2D); + + function pool2d(x, poolSize, strides, padding, dataFormat, poolMode) { + return tfc.tidy(function () { + checkDataFormat(dataFormat); + checkPoolMode(poolMode); + checkPaddingMode(padding); + if (strides == null) { + strides = [1, 1]; + } + if (padding == null) { + padding = 'valid'; + } + if (dataFormat == null) { + dataFormat = imageDataFormat(); + } + if (poolMode == null) { + poolMode = 'max'; + } + x = preprocessConv2DInput(x, dataFormat); + var y; + var paddingString = (padding === 'same') ? 'same' : 'valid'; + if (poolMode === 'max') { + y = tfc.maxPool(x, poolSize, strides, paddingString); + } + else { + y = tfc.avgPool(x, poolSize, strides, paddingString); + } + if (dataFormat === 'channelsFirst') { + y = tfc.transpose(y, [0, 3, 1, 2]); + } + return y; + }); + } + var Pooling1D = (function (_super) { + __extends(Pooling1D, _super); + function Pooling1D(config) { + var _this = this; + if (config.poolSize == null) { + config.poolSize = 2; + } + _this = _super.call(this, config) || this; + if (typeof config.poolSize === 'number') { + _this.poolSize = [config.poolSize]; + } + else if (Array.isArray(config.poolSize) && + config.poolSize.length === 1 && + typeof config.poolSize[0] === 'number') { + _this.poolSize = config.poolSize; + } + else { + throw new ValueError("poolSize for 1D convolutional layer must be a number or an " + + "Array of a single number, but received " + + ("" + JSON.stringify(config.poolSize))); + } + if (config.strides == null) { + _this.strides = _this.poolSize; + } + else { + if (typeof config.strides === 'number') { + _this.strides = [config.strides]; + } + else if (Array.isArray(config.strides) && + config.strides.length === 1 && + typeof config.strides[0] === 'number') { + _this.strides = config.strides; + } + else { + throw new ValueError("strides for 1D convolutional layer must be a number or an " + + "Array of a single number, but received " + + ("" + JSON.stringify(config.strides))); + } + } + _this.padding = config.padding == null ? 'valid' : config.padding; + checkPaddingMode(_this.padding); + _this.inputSpec = [new InputSpec({ ndim: 3 })]; + return _this; + } + Pooling1D.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var length = convOutputLength(inputShape[1], this.poolSize[0], this.padding, this.strides[0]); + return [inputShape[0], length, inputShape[2]]; + }; + Pooling1D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + inputs = expandDims(getExactlyOneTensor(inputs), 2); + var output = _this.poolingFunction(getExactlyOneTensor(inputs), [_this.poolSize[0], 1], [_this.strides[0], 1], _this.padding, 'channelsLast'); + return tfc.squeeze(output, [2]); + }); + }; + Pooling1D.prototype.getConfig = function () { + var config = { + poolSize: this.poolSize, + padding: this.padding, + strides: this.strides, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return Pooling1D; + }(Layer)); + var MaxPooling1D = (function (_super) { + __extends(MaxPooling1D, _super); + function MaxPooling1D(config) { + return _super.call(this, config) || this; + } + MaxPooling1D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + checkDataFormat(dataFormat); + checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max'); + }; + MaxPooling1D.className = 'MaxPooling1D'; + return MaxPooling1D; + }(Pooling1D)); + tfc.serialization.SerializationMap.register(MaxPooling1D); + var AveragePooling1D = (function (_super) { + __extends(AveragePooling1D, _super); + function AveragePooling1D(config) { + return _super.call(this, config) || this; + } + AveragePooling1D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + checkDataFormat(dataFormat); + checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg'); + }; + AveragePooling1D.className = 'AveragePooling1D'; + return AveragePooling1D; + }(Pooling1D)); + tfc.serialization.SerializationMap.register(AveragePooling1D); + var Pooling2D = (function (_super) { + __extends(Pooling2D, _super); + function Pooling2D(config) { + var _this = this; + if (config.poolSize == null) { + config.poolSize = [2, 2]; + } + _this = _super.call(this, config) || this; + _this.poolSize = Array.isArray(config.poolSize) ? + config.poolSize : + [config.poolSize, config.poolSize]; + if (config.strides == null) { + _this.strides = _this.poolSize; + } + else if (Array.isArray(config.strides)) { + if (config.strides.length !== 2) { + throw new ValueError("If the strides property of a 2D pooling layer is an Array, " + + "it is expected to have a length of 2, but received length " + + (config.strides.length + ".")); + } + _this.strides = config.strides; + } + else { + _this.strides = [config.strides, config.strides]; + } + _this.padding = config.padding == null ? 'valid' : config.padding; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + checkDataFormat(_this.dataFormat); + checkPaddingMode(_this.padding); + _this.inputSpec = [new InputSpec({ ndim: 4 })]; + return _this; + } + Pooling2D.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var rows = this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1]; + var cols = this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2]; + rows = + convOutputLength(rows, this.poolSize[0], this.padding, this.strides[0]); + cols = + convOutputLength(cols, this.poolSize[1], this.padding, this.strides[1]); + if (this.dataFormat === 'channelsFirst') { + return [inputShape[0], inputShape[1], rows, cols]; + } + else { + return [inputShape[0], rows, cols, inputShape[3]]; + } + }; + Pooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + _this.invokeCallHook(inputs, kwargs); + return _this.poolingFunction(getExactlyOneTensor(inputs), _this.poolSize, _this.strides, _this.padding, _this.dataFormat); + }); + }; + Pooling2D.prototype.getConfig = function () { + var config = { + poolSize: this.poolSize, + padding: this.padding, + strides: this.strides, + dataFormat: this.dataFormat + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return Pooling2D; + }(Layer)); + var MaxPooling2D = (function (_super) { + __extends(MaxPooling2D, _super); + function MaxPooling2D(config) { + return _super.call(this, config) || this; + } + MaxPooling2D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + checkDataFormat(dataFormat); + checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max'); + }; + MaxPooling2D.className = 'MaxPooling2D'; + return MaxPooling2D; + }(Pooling2D)); + tfc.serialization.SerializationMap.register(MaxPooling2D); + var AveragePooling2D = (function (_super) { + __extends(AveragePooling2D, _super); + function AveragePooling2D(config) { + return _super.call(this, config) || this; + } + AveragePooling2D.prototype.poolingFunction = function (inputs, poolSize, strides, padding, dataFormat) { + checkDataFormat(dataFormat); + checkPaddingMode(padding); + return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg'); + }; + AveragePooling2D.className = 'AveragePooling2D'; + return AveragePooling2D; + }(Pooling2D)); + tfc.serialization.SerializationMap.register(AveragePooling2D); + var GlobalPooling1D = (function (_super) { + __extends(GlobalPooling1D, _super); + function GlobalPooling1D(config) { + var _this = _super.call(this, config) || this; + _this.inputSpec = [new InputSpec({ ndim: 3 })]; + return _this; + } + GlobalPooling1D.prototype.computeOutputShape = function (inputShape) { + return [inputShape[0], inputShape[2]]; + }; + GlobalPooling1D.prototype.call = function (inputs, kwargs) { + throw new NotImplementedError(); + }; + return GlobalPooling1D; + }(Layer)); + var GlobalAveragePooling1D = (function (_super) { + __extends(GlobalAveragePooling1D, _super); + function GlobalAveragePooling1D(config) { + return _super.call(this, config) || this; + } + GlobalAveragePooling1D.prototype.call = function (inputs, kwargs) { + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + return tfc.mean(input, 1); + }); + }; + GlobalAveragePooling1D.className = 'GlobalAveragePooling1D'; + return GlobalAveragePooling1D; + }(GlobalPooling1D)); + tfc.serialization.SerializationMap.register(GlobalAveragePooling1D); + var GlobalMaxPooling1D = (function (_super) { + __extends(GlobalMaxPooling1D, _super); + function GlobalMaxPooling1D(config) { + return _super.call(this, config) || this; + } + GlobalMaxPooling1D.prototype.call = function (inputs, kwargs) { + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + return tfc.max(input, 1); + }); + }; + GlobalMaxPooling1D.className = 'GlobalMaxPooling1D'; + return GlobalMaxPooling1D; + }(GlobalPooling1D)); + tfc.serialization.SerializationMap.register(GlobalMaxPooling1D); + var GlobalPooling2D = (function (_super) { + __extends(GlobalPooling2D, _super); + function GlobalPooling2D(config) { + var _this = _super.call(this, config) || this; + _this.dataFormat = + config.dataFormat == null ? 'channelsLast' : config.dataFormat; + checkDataFormat(_this.dataFormat); + _this.inputSpec = [new InputSpec({ ndim: 4 })]; + return _this; + } + GlobalPooling2D.prototype.computeOutputShape = function (inputShape) { + inputShape = inputShape; + if (this.dataFormat === 'channelsLast') { + return [inputShape[0], inputShape[3]]; + } + else { + return [inputShape[0], inputShape[1]]; + } + }; + GlobalPooling2D.prototype.call = function (inputs, kwargs) { + throw new NotImplementedError(); + }; + GlobalPooling2D.prototype.getConfig = function () { + var config = { dataFormat: this.dataFormat }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + return GlobalPooling2D; + }(Layer)); + var GlobalAveragePooling2D = (function (_super) { + __extends(GlobalAveragePooling2D, _super); + function GlobalAveragePooling2D() { + return _super !== null && _super.apply(this, arguments) || this; + } + GlobalAveragePooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + return tfc.mean(input, [1, 2]); + } + else { + return tfc.mean(input, [2, 3]); + } + }); + }; + GlobalAveragePooling2D.className = 'GlobalAveragePooling2D'; + return GlobalAveragePooling2D; + }(GlobalPooling2D)); + tfc.serialization.SerializationMap.register(GlobalAveragePooling2D); + var GlobalMaxPooling2D = (function (_super) { + __extends(GlobalMaxPooling2D, _super); + function GlobalMaxPooling2D() { + return _super !== null && _super.apply(this, arguments) || this; + } + GlobalMaxPooling2D.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var input = getExactlyOneTensor(inputs); + if (_this.dataFormat === 'channelsLast') { + return tfc.max(input, [1, 2]); + } + else { + return tfc.max(input, [2, 3]); + } + }); + }; + GlobalMaxPooling2D.className = 'GlobalMaxPooling2D'; + return GlobalMaxPooling2D; + }(GlobalPooling2D)); + tfc.serialization.SerializationMap.register(GlobalMaxPooling2D); + + function standardizeArgs(inputs, initialState, constants, numConstants) { + if (Array.isArray(inputs)) { + if (initialState != null || constants != null) { + throw new ValueError('When inputs is an array, neither initialState or constants ' + + 'should be provided'); + } + if (numConstants != null) { + constants = inputs.slice(inputs.length - numConstants, inputs.length); + inputs = inputs.slice(0, inputs.length - numConstants); + } + if (inputs.length > 1) { + initialState = inputs.slice(1, inputs.length); + } + inputs = inputs[0]; + } + function toListOrNull(x) { + if (x == null || Array.isArray(x)) { + return x; + } + else { + return [x]; + } + } + initialState = toListOrNull(initialState); + constants = toListOrNull(constants); + return { inputs: inputs, initialState: initialState, constants: constants }; + } + function rnn(stepFunction, inputs, initialStates, goBackwards, mask, constants, unroll, inputLength) { + if (goBackwards === void 0) { goBackwards = false; } + if (unroll === void 0) { unroll = false; } + var ndim = inputs.shape.length; + if (ndim < 3) { + throw new ValueError("Input should be at least 3D, but is " + ndim + "D."); + } + var axes = [1, 0].concat(range(2, ndim)); + inputs = tfc.transpose(inputs, axes); + if (mask != null) { + throw new NotImplementedError('The rnn() function of the deeplearn.js backend does not support ' + + 'masking yet.'); + } + if (constants != null) { + throw new NotImplementedError('The rnn() functoin of the deeplearn.js backend does not support ' + + 'constants yet.'); + } + if (unroll) { + console.warn('Backend rnn(): the unroll = true option is not applicable to the ' + + 'imperative deeplearn.js backend.'); + } + if (goBackwards) { + inputs = tfc.reverse(inputs, 0); + } + var outputs; + var lastOutput; + var states = initialStates; + var timeSteps = inputs.shape[0]; + for (var t = 0; t < timeSteps; ++t) { + var currentInput = sliceAlongFirstAxis(inputs, t, 1); + currentInput = currentInput.reshape(currentInput.shape.slice(1)); + var stepOutputs = stepFunction(currentInput, states); + lastOutput = stepOutputs[0]; + if (t === 0) { + outputs = lastOutput.reshape([1].concat(lastOutput.shape)); + } + else { + outputs = concatAlongFirstAxis(outputs, lastOutput.reshape([1].concat(lastOutput.shape))); + } + states = stepOutputs[1]; + } + return [ + lastOutput, + tfc.transpose(outputs, [1, 0].concat(range(2, outputs.shape.length))), + states + ]; + } + var RNN = (function (_super) { + __extends(RNN, _super); + function RNN(config) { + var _this = _super.call(this, config) || this; + var cell; + if (config.cell == null) { + throw new ValueError('cell property is missing for the constructor of RNN.'); + } + else if (Array.isArray(config.cell)) { + cell = new StackedRNNCells({ cells: config.cell }); + } + else { + cell = config.cell; + } + if (cell.stateSize == null) { + throw new ValueError('The RNN cell should have an attribute `stateSize` (tuple of ' + + 'integers, one integer per RNN state).'); + } + _this.cell = cell; + _this.returnSequences = + config.returnSequences == null ? false : config.returnSequences; + _this.returnState = config.returnState == null ? false : config.returnState; + _this.goBackwards = config.goBackwards == null ? false : config.goBackwards; + _this._stateful = config.stateful == null ? false : config.stateful; + _this.unroll = config.unroll == null ? false : config.unroll; + _this.supportsMasking = true; + _this.inputSpec = [new InputSpec({ ndim: 3 })]; + _this.stateSpec = null; + _this.states = null; + _this.numConstants = null; + return _this; + } + RNN.prototype.getStates = function () { + if (this.states == null) { + var numStates = Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1; + return range(0, numStates).map(function (x) { return null; }); + } + else { + return this.states; + } + }; + RNN.prototype.setStates = function (states) { + this.states = states; + }; + RNN.prototype.computeOutputShape = function (inputShape) { + if (isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var stateSize = this.cell.stateSize; + if (!Array.isArray(stateSize)) { + stateSize = [stateSize]; + } + var outputDim = stateSize[0]; + var outputShape; + if (this.returnSequences) { + outputShape = [inputShape[0], inputShape[1], outputDim]; + } + else { + outputShape = [inputShape[0], outputDim]; + } + if (this.returnState) { + var stateShape = []; + for (var _i = 0, stateSize_1 = stateSize; _i < stateSize_1.length; _i++) { + var dim = stateSize_1[_i]; + stateShape.push([inputShape[0], dim]); + } + return [outputShape].concat(stateShape); + } + else { + return outputShape; + } + }; + RNN.prototype.computeMask = function (inputs, mask) { + throw new NotImplementedError('computeMask has not been implemented for RNN yet'); + }; + RNN.prototype.build = function (inputShape) { + var constantShape = null; + if (this.numConstants != null) { + throw new NotImplementedError('Constants support is not implemented in RNN yet.'); + } + if (isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var batchSize = this.stateful ? inputShape[0] : null; + var inputDim = inputShape[inputShape.length - 1]; + this.inputSpec[0] = new InputSpec({ shape: [batchSize, null, inputDim] }); + var stepInputShape = [inputShape[0]].concat(inputShape.slice(2)); + if (constantShape != null) { + throw new NotImplementedError('Constants support is not implemented in RNN yet.'); + } + else { + this.cell.build(stepInputShape); + } + var stateSize; + if (Array.isArray(this.cell.stateSize)) { + stateSize = this.cell.stateSize; + } + else { + stateSize = [this.cell.stateSize]; + } + if (this.stateSpec != null) { + if (!tfc.util.arraysEqual(this.stateSpec.map(function (spec) { return spec.shape[spec.shape.length - 1]; }), stateSize)) { + throw new ValueError("An initialState was passed that is not compatible with " + + ("cell.stateSize. Received stateSpec=" + this.stateSpec + "; ") + + ("However cell.stateSize is " + this.cell.stateSize)); + } + } + else { + this.stateSpec = + stateSize.map(function (dim) { return new InputSpec({ shape: [null, dim] }); }); + } + if (this.stateful) { + throw new NotImplementedError('stateful RNN layer is not implemented yet'); + } + }; + RNN.prototype.resetStates = function (states) { + var _this = this; + tfc.tidy(function () { + if (!_this.stateful) { + throw new AttributeError('Cannot call resetState() on an RNN Layer that is not stateful.'); + } + var batchSize = _this.inputSpec[0].shape[0]; + if (batchSize == null) { + throw new ValueError('If an RNN is stateful, it needs to know its batch size. Specify ' + + 'the batch size of your input tensors: \n' + + '- If using a Sequential model, specify the batch size by ' + + 'passing a `batchInputShape` option to your first layer.\n' + + '- If using the functional API, specify the batch size by ' + + 'passing a `batchShape` option to your Input layer.'); + } + if (_this.states == null) { + if (Array.isArray(_this.cell.stateSize)) { + _this.states = + _this.cell.stateSize.map(function (dim) { return tfc.zeros([batchSize, dim]); }); + } + else { + _this.states = [tfc.zeros([batchSize, _this.cell.stateSize])]; + } + } + else if (states == null) { + if (Array.isArray(_this.cell.stateSize)) { + _this.states = + _this.cell.stateSize.map(function (dim) { return tfc.zeros([batchSize, dim]); }); + } + else { + _this.states[0] = tfc.zeros([batchSize, _this.cell.stateSize]); + } + } + else { + if (!Array.isArray(states)) { + states = [states]; + } + if (states.length !== _this.states.length) { + throw new ValueError("Layer " + _this.name + " expects " + _this.states.length + " state(s), " + + ("but it received " + states.length + " state value(s). Input ") + + ("received: " + states)); + } + for (var index = 0; index < _this.states.length; ++index) { + var value = states[index]; + var dim = Array.isArray(_this.cell.stateSize) ? + _this.cell.stateSize[index] : + _this.cell.stateSize; + var expectedShape = [batchSize, dim]; + if (!tfc.util.arraysEqual(value.shape, expectedShape)) { + throw new ValueError("State " + index + " is incompatible with layer " + _this.name + ": " + + ("expected shape=" + expectedShape + ", received shape=" + value.shape)); + } + _this.states[index] = value; + } + } + }); + }; + RNN.prototype.apply = function (inputs, kwargs) { + var initialState = kwargs == null ? null : kwargs['initialState']; + var constants = kwargs == null ? null : kwargs['constants']; + if (kwargs == null) { + kwargs = {}; + } + var standardized = standardizeArgs(inputs, initialState, constants, this.numConstants); + inputs = standardized.inputs; + initialState = standardized.initialState; + constants = standardized.constants; + var additionalInputs = []; + var additionalSpecs = []; + if (initialState != null) { + kwargs['initialState'] = initialState; + additionalInputs = additionalInputs.concat(initialState); + this.stateSpec = []; + for (var _i = 0, initialState_1 = initialState; _i < initialState_1.length; _i++) { + var state = initialState_1[_i]; + this.stateSpec.push(new InputSpec({ shape: state.shape })); + } + additionalSpecs = additionalSpecs.concat(this.stateSpec); + } + if (constants != null) { + kwargs['constants'] = constants; + additionalInputs = additionalInputs.concat(constants); + this.numConstants = constants.length; + } + var isTensor = additionalInputs[0] instanceof SymbolicTensor; + if (isTensor) { + var fullInput = [inputs].concat(additionalInputs); + var fullInputSpec = this.inputSpec.concat(additionalSpecs); + var originalInputSpec = this.inputSpec; + this.inputSpec = fullInputSpec; + var output = _super.prototype.apply.call(this, fullInput, kwargs); + this.inputSpec = originalInputSpec; + return output; + } + else { + return _super.prototype.apply.call(this, inputs, kwargs); + } + }; + RNN.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + inputs = getExactlyOneTensor(inputs); + if (initialState == null) { + if (_this.stateful) { + throw new NotImplementedError('stateful RNN layer is not implemented yet.'); + } + else { + initialState = _this.getInitialState(inputs); + } + } + if (mask != null) { + throw new NotImplementedError('Masking is not implemented for RNN yet'); + } + var numStates = Array.isArray(_this.cell.stateSize) ? _this.cell.stateSize.length : 1; + if (initialState.length !== numStates) { + throw new ValueError("RNN Layer has " + numStates + " state(s) but was passed " + + (initialState.length + " initial state(s).")); + } + var inputShape = inputs.shape; + var timesteps = inputShape[1]; + if (_this.unroll) { + console.warn('Ignoring unroll = true for RNN layer, due to imperative backend.'); + } + var cellCallKwargs = { training: training }; + var step = function (inputs, states) { + var outputs = _this.cell.call([inputs].concat(states), cellCallKwargs); + return [outputs[0], outputs.slice(1)]; + }; + var rnnOutputs = rnn(step, inputs, initialState, _this.goBackwards, null, null, _this.unroll, timesteps); + var lastOutput = rnnOutputs[0]; + var outputs = rnnOutputs[1]; + var states = rnnOutputs[2]; + if (_this.stateful) { + throw new NotImplementedError('stateful RNN layer is not implemented yet'); + } + var output = _this.returnSequences ? outputs : lastOutput; + if (_this.returnState) { + return [output].concat(states); + } + else { + return output; + } + }); + }; + RNN.prototype.getInitialState = function (inputs) { + var _this = this; + return tfc.tidy(function () { + var initialState = tfc.zeros(inputs.shape); + initialState = tfc.sum(initialState, [1, 2]); + initialState = expandDims(initialState); + if (Array.isArray(_this.cell.stateSize)) { + return _this.cell.stateSize.map(function (dim) { return dim > 1 ? tile(initialState, [1, dim]) : initialState; }); + } + else { + return _this.cell.stateSize > 1 ? + [tile(initialState, [1, _this.cell.stateSize])] : + [initialState]; + } + }); + }; + Object.defineProperty(RNN.prototype, "trainableWeights", { + get: function () { + if (!this.trainable) { + return []; + } + return this.cell.trainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(RNN.prototype, "nonTrainableWeights", { + get: function () { + if (!this.trainable) { + return this.cell.weights; + } + return this.cell.nonTrainableWeights; + }, + enumerable: true, + configurable: true + }); + RNN.prototype.getConfig = function () { + var config = { + returnSequences: this.returnSequences, + returnState: this.returnState, + goBackwards: this.goBackwards, + stateful: this.stateful, + unroll: this.unroll, + }; + if (this.numConstants != null) { + config.numConstants = this.numConstants; + } + var cellConfig = this.cell.getConfig(); + config.cell = { + className: this.cell.getClassName(), + config: cellConfig, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + RNN.className = 'RNN'; + return RNN; + }(Layer)); + tfc.serialization.SerializationMap.register(RNN); + var RNNCell = (function (_super) { + __extends(RNNCell, _super); + function RNNCell() { + return _super !== null && _super.apply(this, arguments) || this; + } + return RNNCell; + }(Layer)); + var SimpleRNNCell = (function (_super) { + __extends(SimpleRNNCell, _super); + function SimpleRNNCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = getActivation(config.activation == null ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelRegularizer = getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = getRegularizer(config.biasRegularizer); + _this.kernelConstraint = getConstraint(config.kernelConstraint); + _this.recurrentConstraint = getConstraint(config.recurrentConstraint); + _this.biasConstraint = getConstraint(config.biasConstraint); + _this.dropout = min([1, max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = min([ + 1, + max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.stateSize = _this.units; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + SimpleRNNCell.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + this.kernel = this.addWeight('kernel', [inputShape[inputShape.length - 1], this.units], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + SimpleRNNCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = inputs; + if (inputs.length !== 2) { + throw new ValueError("SimpleRNNCell expects 2 input Tensors, got " + inputs.length + "."); + } + var prevOutput = inputs[1]; + inputs = inputs[0]; + var training = kwargs['training'] == null ? false : kwargs['training']; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(prevOutput); }, _this.recurrentDropout, training); + } + var h; + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + if (dpMask != null) { + h = dot(tfc.mul(inputs, dpMask), _this.kernel.read()); + } + else { + h = dot(inputs, _this.kernel.read()); + } + if (_this.bias != null) { + h = biasAdd(h, _this.bias.read()); + } + if (recDpMask != null) { + prevOutput = tfc.mul(prevOutput, recDpMask); + } + var output = tfc.add(h, dot(prevOutput, _this.recurrentKernel.read())); + if (_this.activation != null) { + output = _this.activation.apply(output); + } + return [output, output]; + }); + }; + SimpleRNNCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + SimpleRNNCell.className = 'SimpleRNNCell'; + return SimpleRNNCell; + }(RNNCell)); + tfc.serialization.SerializationMap.register(SimpleRNNCell); + var SimpleRNN = (function (_super) { + __extends(SimpleRNN, _super); + function SimpleRNN(config) { + var _this = this; + config.cell = new SimpleRNNCell(config); + _this = _super.call(this, config) || this; + return _this; + } + SimpleRNN.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(SimpleRNN.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(SimpleRNN.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + SimpleRNN.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + SimpleRNN.className = 'SimpleRNN'; + return SimpleRNN; + }(RNN)); + tfc.serialization.SerializationMap.register(SimpleRNN); + var GRUCell = (function (_super) { + __extends(GRUCell, _super); + function GRUCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = getActivation(config.activation === undefined ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.recurrentActivation = getActivation(config.recurrentActivation === undefined ? + _this.DEFAULT_RECURRENT_ACTIVATION : + config.recurrentActivation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.kernelRegularizer = getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = getRegularizer(config.biasRegularizer); + _this.kernelConstraint = getConstraint(config.kernelConstraint); + _this.recurrentConstraint = getConstraint(config.recurrentConstraint); + _this.biasConstraint = getConstraint(config.biasConstraint); + _this.dropout = min([1, max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = min([ + 1, + max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.implementation = config.implementation; + _this.stateSize = _this.units; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + GRUCell.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var inputDim = inputShape[inputShape.length - 1]; + this.kernel = this.addWeight('kernel', [inputDim, this.units * 3], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units * 3], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + if (this.useBias) { + this.bias = this.addWeight('bias', [this.units * 3], null, this.biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + }; + GRUCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = inputs; + if (inputs.length !== 2) { + throw new ValueError("GRUCell expects 2 input Tensors (inputs, h, c), got " + + (inputs.length + ".")); + } + var training = kwargs['training'] == null ? false : kwargs['training']; + var hTMinus1 = inputs[1]; + inputs = inputs[0]; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training, 3); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(hTMinus1); }, _this.recurrentDropout, training, 3); + } + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + var z; + var r; + var hh; + if (_this.implementation === 1) { + var kernelZ = sliceAlongLastAxis(_this.kernel.read(), 0, _this.units); + var kernelR = sliceAlongLastAxis(_this.kernel.read(), _this.units, _this.units); + var kernelH = sliceAlongLastAxis(_this.kernel.read(), _this.units * 2, _this.units); + var recurrentKernelZ = sliceAlongLastAxis(_this.recurrentKernel.read(), 0, _this.units); + var recurrentKernelR = sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units, _this.units); + var recurrentKernelH = sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 2, _this.units); + var inputsZ = void 0, inputsR = void 0, inputsH = void 0; + if (0 < _this.dropout && _this.dropout < 1) { + inputsZ = tfc.mul(inputs, dpMask[0]); + inputsR = tfc.mul(inputs, dpMask[1]); + inputsH = tfc.mul(inputs, dpMask[2]); + } + else { + inputsZ = inputs; + inputsR = inputs; + inputsH = inputs; + } + var xZ = dot(inputsZ, kernelZ); + var xR = dot(inputsR, kernelR); + var xH = dot(inputsH, kernelH); + if (_this.useBias) { + var biasZ = sliceAlongFirstAxis(_this.bias.read(), 0, _this.units); + var biasR = sliceAlongFirstAxis(_this.bias.read(), _this.units, _this.units); + var biasH = sliceAlongFirstAxis(_this.bias.read(), _this.units * 2, _this.units); + xZ = biasAdd(xZ, biasZ); + xR = biasAdd(xR, biasR); + xH = biasAdd(xH, biasH); + } + var hTMinus1Z = void 0; + var hTMinus1R = void 0; + var hTMinus1H = void 0; + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1Z = tfc.mul(hTMinus1, recDpMask[0]); + hTMinus1R = tfc.mul(hTMinus1, recDpMask[1]); + hTMinus1H = tfc.mul(hTMinus1, recDpMask[2]); + } + else { + hTMinus1Z = hTMinus1; + hTMinus1R = hTMinus1; + hTMinus1H = hTMinus1; + } + z = _this.recurrentActivation.apply(tfc.add(xZ, dot(hTMinus1Z, recurrentKernelZ))); + r = _this.recurrentActivation.apply(tfc.add(xR, dot(hTMinus1R, recurrentKernelR))); + hh = _this.activation.apply(tfc.add(xH, dot(tfc.mul(r, hTMinus1H), recurrentKernelH))); + } + else { + if (0 < _this.dropout && _this.dropout < 1) { + inputs = tfc.mul(inputs, dpMask[0]); + } + var matrixX = dot(inputs, _this.kernel.read()); + if (_this.useBias) { + matrixX = biasAdd(matrixX, _this.bias.read()); + } + if (0 < _this.dropout && _this.dropout < 1) { + hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]); + } + var matrixInner = dot(hTMinus1, sliceAlongLastAxis(_this.recurrentKernel.read(), 0, 2 * _this.units)); + var xZ = sliceAlongLastAxis(matrixX, 0, _this.units); + var xR = sliceAlongLastAxis(matrixX, _this.units, _this.units); + var recurrentZ = sliceAlongLastAxis(matrixInner, 0, _this.units); + var recurrentR = sliceAlongLastAxis(matrixInner, _this.units, _this.units); + z = _this.recurrentActivation.apply(tfc.add(xZ, recurrentZ)); + r = _this.recurrentActivation.apply(tfc.add(xR, recurrentR)); + var xH = sliceAlongLastAxis(matrixX, 2 * _this.units, _this.units); + var recurrentH = dot(tfc.mul(r, hTMinus1), sliceAlongLastAxis(_this.recurrentKernel.read(), 2 * _this.units, _this.units)); + hh = _this.activation.apply(tfc.add(xH, recurrentH)); + } + var h = tfc.add(tfc.mul(z, hTMinus1), tfc.mul(tfc.add(getScalar(1), tfc.neg(z)), hh)); + return [h, h]; + }); + }; + GRUCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + recurrentActivation: serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + GRUCell.className = 'GRUCell'; + return GRUCell; + }(RNNCell)); + tfc.serialization.SerializationMap.register(GRUCell); + var GRU = (function (_super) { + __extends(GRU, _super); + function GRU(config) { + var _this = this; + if (config.implementation === 0) { + console.warn('`implementation=0` has been deprecated, and now defaults to ' + + '`implementation=1`. Please update your layer call.'); + } + config.cell = new GRUCell(config); + _this = _super.call(this, config) || this; + return _this; + } + GRU.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(GRU.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentActivation", { + get: function () { + return this.cell.recurrentActivation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(GRU.prototype, "implementation", { + get: function () { + return this.cell.implementation; + }, + enumerable: true, + configurable: true + }); + GRU.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + recurrentActivation: serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + GRU.fromConfig = function (cls, config) { + if (config['implmentation'] === 0) { + config['implementation'] = 1; + } + return new cls(config); + }; + GRU.className = 'GRU'; + return GRU; + }(RNN)); + tfc.serialization.SerializationMap.register(GRU); + var LSTMCell = (function (_super) { + __extends(LSTMCell, _super); + function LSTMCell(config) { + var _this = _super.call(this, config) || this; + _this.DEFAULT_ACTIVATION = 'tanh'; + _this.DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid'; + _this.DEFAULT_KERNEL_INITIALIZER = 'glorotNormal'; + _this.DEFAULT_RECURRENT_INITIALIZER = 'orthogonal'; + _this.DEFAULT_BIAS_INITIALIZER = 'zeros'; + _this.units = config.units; + _this.activation = getActivation(config.activation === undefined ? _this.DEFAULT_ACTIVATION : + config.activation); + _this.recurrentActivation = getActivation(config.recurrentActivation === undefined ? + _this.DEFAULT_RECURRENT_ACTIVATION : + config.recurrentActivation); + _this.useBias = config.useBias == null ? true : config.useBias; + _this.kernelInitializer = getInitializer(config.kernelInitializer || _this.DEFAULT_KERNEL_INITIALIZER); + _this.recurrentInitializer = getInitializer(config.recurrentInitializer || _this.DEFAULT_RECURRENT_INITIALIZER); + _this.biasInitializer = + getInitializer(config.biasInitializer || _this.DEFAULT_BIAS_INITIALIZER); + _this.unitForgetBias = config.unitForgetBias; + _this.kernelRegularizer = getRegularizer(config.kernelRegularizer); + _this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer); + _this.biasRegularizer = getRegularizer(config.biasRegularizer); + _this.kernelConstraint = getConstraint(config.kernelConstraint); + _this.recurrentConstraint = getConstraint(config.recurrentConstraint); + _this.biasConstraint = getConstraint(config.biasConstraint); + _this.dropout = min([1, max([0, config.dropout == null ? 0 : config.dropout])]); + _this.recurrentDropout = min([ + 1, + max([0, config.recurrentDropout == null ? 0 : config.recurrentDropout]) + ]); + _this.implementation = config.implementation; + _this.stateSize = [_this.units, _this.units]; + _this.dropoutMask = null; + _this.recurrentDropoutMask = null; + return _this; + } + LSTMCell.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var inputDim = inputShape[inputShape.length - 1]; + this.kernel = this.addWeight('kernel', [inputDim, this.units * 4], null, this.kernelInitializer, this.kernelRegularizer, true, this.kernelConstraint); + this.recurrentKernel = this.addWeight('recurrent_kernel', [this.units, this.units * 4], null, this.recurrentInitializer, this.recurrentRegularizer, true, this.recurrentConstraint); + var biasInitializer; + if (this.useBias) { + if (this.unitForgetBias) { + var capturedBiasInit_1 = this.biasInitializer; + var capturedUnits_1 = this.units; + biasInitializer = new (_a = (function (_super) { + __extends(CustomInit, _super); + function CustomInit() { + return _super !== null && _super.apply(this, arguments) || this; + } + CustomInit.prototype.apply = function (shape, dtype) { + var bI = capturedBiasInit_1.apply([capturedUnits_1]); + var bF = (new Ones()).apply([capturedUnits_1]); + var bCAndH = capturedBiasInit_1.apply([capturedUnits_1 * 2]); + return concatAlongFirstAxis(concatAlongFirstAxis(bI, bF), bCAndH); + }; + return CustomInit; + }(Initializer)), + _a.className = 'CustomInit', + _a)(); + } + else { + biasInitializer = this.biasInitializer; + } + this.bias = this.addWeight('bias', [this.units * 4], null, biasInitializer, this.biasRegularizer, true, this.biasConstraint); + } + else { + this.bias = null; + } + this.built = true; + var _a; + }; + LSTMCell.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + var training = kwargs['training'] == null ? false : kwargs['training']; + inputs = inputs; + if (inputs.length !== 3) { + throw new ValueError("LSTMCell expects 3 input Tensors (inputs, h, c), got " + + (inputs.length + ".")); + } + var hTMinus1 = inputs[1]; + var cTMinus1 = inputs[2]; + inputs = inputs[0]; + if (0 < _this.dropout && _this.dropout < 1 && _this.dropoutMask == null) { + _this.dropoutMask = generateDropoutMask(function () { return tfc.onesLike(inputs); }, _this.dropout, training, 4); + } + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1 && + _this.recurrentDropoutMask == null) { + _this.recurrentDropoutMask = + generateDropoutMask(function () { return tfc.onesLike(hTMinus1); }, _this.recurrentDropout, training, 4); + } + var dpMask = _this.dropoutMask; + var recDpMask = _this.recurrentDropoutMask; + var i; + var f; + var c; + var o; + if (_this.implementation === 1) { + var kernelI = sliceAlongLastAxis(_this.kernel.read(), 0, _this.units); + var kernelF = sliceAlongLastAxis(_this.kernel.read(), _this.units, _this.units); + var kernelC = sliceAlongLastAxis(_this.kernel.read(), _this.units * 2, _this.units); + var kernelO = sliceAlongLastAxis(_this.kernel.read(), _this.units * 3, _this.units); + var recurrentKernelI = sliceAlongLastAxis(_this.recurrentKernel.read(), 0, _this.units); + var recurrentKernelF = sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units, _this.units); + var recurrentKernelC = sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 2, _this.units); + var recurrentKernelO = sliceAlongLastAxis(_this.recurrentKernel.read(), _this.units * 3, _this.units); + var inputsI = void 0, inputsF = void 0, inputsC = void 0, inputsO = void 0; + if (0 < _this.dropout && _this.dropout < 1) { + inputsI = tfc.mul(inputs, dpMask[0]); + inputsF = tfc.mul(inputs, dpMask[1]); + inputsC = tfc.mul(inputs, dpMask[2]); + inputsO = tfc.mul(inputs, dpMask[3]); + } + else { + inputsI = inputs; + inputsF = inputs; + inputsC = inputs; + inputsO = inputs; + } + var xI = dot(inputsI, kernelI); + var xF = dot(inputsF, kernelF); + var xC = dot(inputsC, kernelC); + var xO = dot(inputsO, kernelO); + if (_this.useBias) { + var biasI = sliceAlongFirstAxis(_this.bias.read(), 0, _this.units); + var biasF = sliceAlongFirstAxis(_this.bias.read(), _this.units, _this.units); + var biasC = sliceAlongFirstAxis(_this.bias.read(), _this.units * 2, _this.units); + var biasO = sliceAlongFirstAxis(_this.bias.read(), _this.units * 3, _this.units); + xI = biasAdd(xI, biasI); + xF = biasAdd(xF, biasF); + xC = biasAdd(xC, biasC); + xO = biasAdd(xO, biasO); + } + var hTMinus1I = void 0, hTMinus1F = void 0, hTMinus1C = void 0, hTMinus1O = void 0; + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1I = tfc.mul(hTMinus1, recDpMask[0]); + hTMinus1F = tfc.mul(hTMinus1, recDpMask[1]); + hTMinus1C = tfc.mul(hTMinus1, recDpMask[2]); + hTMinus1O = tfc.mul(hTMinus1, recDpMask[3]); + } + else { + hTMinus1I = hTMinus1; + hTMinus1F = hTMinus1; + hTMinus1C = hTMinus1; + hTMinus1O = hTMinus1; + } + i = _this.recurrentActivation.apply(tfc.add(xI, dot(hTMinus1I, recurrentKernelI))); + f = _this.recurrentActivation.apply(tfc.add(xF, dot(hTMinus1F, recurrentKernelF))); + c = tfc.add(tfc.mul(f, cTMinus1), tfc.mul(i, _this.activation.apply(tfc.add(xC, dot(hTMinus1C, recurrentKernelC))))); + o = _this.recurrentActivation.apply(tfc.add(xO, dot(hTMinus1O, recurrentKernelO))); + } + else { + if (0 < _this.dropout && _this.dropout < 1) { + inputs = tfc.mul(inputs, dpMask[0]); + } + var z = dot(inputs, _this.kernel.read()); + if (0 < _this.recurrentDropout && _this.recurrentDropout < 1) { + hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]); + } + z = tfc.add(z, dot(hTMinus1, _this.recurrentKernel.read())); + if (_this.useBias) { + z = biasAdd(z, _this.bias.read()); + } + var z0 = sliceAlongLastAxis(z, 0, _this.units); + var z1 = sliceAlongLastAxis(z, _this.units, _this.units); + var z2 = sliceAlongLastAxis(z, _this.units * 2, _this.units); + var z3 = sliceAlongLastAxis(z, _this.units * 3, _this.units); + i = _this.recurrentActivation.apply(z0); + f = _this.recurrentActivation.apply(z1); + c = tfc.add(tfc.mul(f, cTMinus1), tfc.mul(i, _this.activation.apply(z2))); + o = _this.recurrentActivation.apply(z3); + } + var h = tfc.mul(o, _this.activation.apply(c)); + return [h, h, c]; + }); + }; + LSTMCell.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + recurrentActivation: serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + unitForgetBias: this.unitForgetBias, + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + LSTMCell.className = 'LSTMCell'; + return LSTMCell; + }(RNNCell)); + tfc.serialization.SerializationMap.register(LSTMCell); + var LSTM = (function (_super) { + __extends(LSTM, _super); + function LSTM(config) { + var _this = this; + if (config.implementation === 0) { + console.warn('`implementation=0` has been deprecated, and now defaults to ' + + '`implementation=1`. Please update your layer call.'); + } + config.cell = new LSTMCell(config); + _this = _super.call(this, config) || this; + return _this; + } + LSTM.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + if (_this.cell.dropoutMask != null) { + tfc.dispose(_this.cell.dropoutMask); + _this.cell.dropoutMask = null; + } + if (_this.cell.recurrentDropoutMask != null) { + tfc.dispose(_this.cell.recurrentDropoutMask); + _this.cell.recurrentDropoutMask = null; + } + var mask = kwargs == null ? null : kwargs['mask']; + var training = kwargs == null ? null : kwargs['training']; + var initialState = kwargs == null ? null : kwargs['initialState']; + return _super.prototype.call.call(_this, inputs, { mask: mask, training: training, initialState: initialState }); + }); + }; + Object.defineProperty(LSTM.prototype, "units", { + get: function () { + return this.cell.units; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "activation", { + get: function () { + return this.cell.activation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentActivation", { + get: function () { + return this.cell.recurrentActivation; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "useBias", { + get: function () { + return this.cell.useBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelInitializer", { + get: function () { + return this.cell.kernelInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentInitializer", { + get: function () { + return this.cell.recurrentInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasInitializer", { + get: function () { + return this.cell.biasInitializer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "unitForgetBias", { + get: function () { + return this.cell.unitForgetBias; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelRegularizer", { + get: function () { + return this.cell.kernelRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentRegularizer", { + get: function () { + return this.cell.recurrentRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasRegularizer", { + get: function () { + return this.cell.biasRegularizer; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "kernelConstraint", { + get: function () { + return this.cell.kernelConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentConstraint", { + get: function () { + return this.cell.recurrentConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "biasConstraint", { + get: function () { + return this.cell.biasConstraint; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "dropout", { + get: function () { + return this.cell.dropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "recurrentDropout", { + get: function () { + return this.cell.recurrentDropout; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(LSTM.prototype, "implementation", { + get: function () { + return this.cell.implementation; + }, + enumerable: true, + configurable: true + }); + LSTM.prototype.getConfig = function () { + var config = { + units: this.units, + activation: serializeActivation(this.activation), + recurrentActivation: serializeActivation(this.recurrentActivation), + useBias: this.useBias, + kernelInitializer: serializeInitializer(this.kernelInitializer), + recurrentInitializer: serializeInitializer(this.recurrentInitializer), + biasInitializer: serializeInitializer(this.biasInitializer), + unitForgetBias: this.unitForgetBias, + kernelRegularizer: serializeRegularizer(this.kernelRegularizer), + recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), + biasRegularizer: serializeRegularizer(this.biasRegularizer), + activityRegularizer: serializeRegularizer(this.activityRegularizer), + kernelConstraint: serializeConstraint(this.kernelConstraint), + recurrentConstraint: serializeConstraint(this.recurrentConstraint), + biasConstraint: serializeConstraint(this.biasConstraint), + dropout: this.dropout, + recurrentDropout: this.recurrentDropout, + implementation: this.implementation, + }; + var baseConfig = _super.prototype.getConfig.call(this); + delete baseConfig['cell']; + Object.assign(config, baseConfig); + return config; + }; + LSTM.fromConfig = function (cls, config) { + if (config['implmentation'] === 0) { + config['implementation'] = 1; + } + return new cls(config); + }; + LSTM.className = 'LSTM'; + return LSTM; + }(RNN)); + tfc.serialization.SerializationMap.register(LSTM); + var StackedRNNCells = (function (_super) { + __extends(StackedRNNCells, _super); + function StackedRNNCells(config) { + var _this = _super.call(this, config) || this; + _this.cells = config.cells; + return _this; + } + Object.defineProperty(StackedRNNCells.prototype, "stateSize", { + get: function () { + var stateSize = []; + for (var _i = 0, _a = this.cells.slice().reverse(); _i < _a.length; _i++) { + var cell = _a[_i]; + if (Array.isArray(cell.stateSize)) { + stateSize.push.apply(stateSize, cell.stateSize); + } + else { + stateSize.push(cell.stateSize); + } + } + return stateSize; + }, + enumerable: true, + configurable: true + }); + StackedRNNCells.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = inputs; + var states = inputs.slice(1); + var nestedStates = []; + for (var _i = 0, _a = _this.cells.slice().reverse(); _i < _a.length; _i++) { + var cell = _a[_i]; + if (Array.isArray(cell.stateSize)) { + nestedStates.push(states.splice(0, cell.stateSize.length)); + } + else { + nestedStates.push(states.splice(0, 1)); + } + } + nestedStates.reverse(); + var newNestedStates = []; + var callInputs; + for (var i = 0; i < _this.cells.length; ++i) { + var cell = _this.cells[i]; + states = nestedStates[i]; + if (i === 0) { + callInputs = [inputs[0]].concat(states); + } + else { + callInputs = [callInputs[0]].concat(states); + } + callInputs = cell.call(callInputs, kwargs); + newNestedStates.push(callInputs.slice(1)); + } + states = []; + for (var _b = 0, _c = newNestedStates.slice().reverse(); _b < _c.length; _b++) { + var cellStates = _c[_b]; + states.push.apply(states, cellStates); + } + return [callInputs[0]].concat(states); + }); + }; + StackedRNNCells.prototype.build = function (inputShape) { + if (isArrayOfShapes(inputShape)) { + inputShape = inputShape[0]; + } + inputShape = inputShape; + var outputDim; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + cell.build(inputShape); + if (Array.isArray(cell.stateSize)) { + outputDim = cell.stateSize[0]; + } + else { + outputDim = cell.stateSize; + } + inputShape = [inputShape[0], outputDim]; + } + this.built = true; + }; + StackedRNNCells.prototype.getConfig = function () { + var cellConfigs = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + cellConfigs.push({ + 'className': this.getClassName(), + 'config': cell.getConfig(), + }); + } + var config = { 'cells': cellConfigs }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + StackedRNNCells.fromConfig = function (cls, config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + var cells = []; + for (var _i = 0, _a = config['cells']; _i < _a.length; _i++) { + var cellConfig = _a[_i]; + cells.push(deserialize(cellConfig, customObjects)); + } + return new cls({ cells: cells }); + }; + Object.defineProperty(StackedRNNCells.prototype, "trainableWeights", { + get: function () { + if (!this.trainable) { + return []; + } + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.trainableWeights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(StackedRNNCells.prototype, "nonTrainableWeights", { + get: function () { + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.nonTrainableWeights); + } + if (!this.trainable) { + var trainableWeights = []; + for (var _b = 0, _c = this.cells; _b < _c.length; _b++) { + var cell = _c[_b]; + trainableWeights.push.apply(trainableWeights, cell.trainableWeights); + } + return trainableWeights.concat(weights); + } + return weights; + }, + enumerable: true, + configurable: true + }); + StackedRNNCells.prototype.getWeights = function () { + var weights = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + weights.push.apply(weights, cell.weights); + } + return batchGetValue(weights); + }; + StackedRNNCells.prototype.setWeights = function (weights) { + var tuples = []; + for (var _i = 0, _a = this.cells; _i < _a.length; _i++) { + var cell = _a[_i]; + var numParams = cell.weights.length; + var inputWeights = weights.splice(numParams); + for (var i = 0; i < cell.weights.length; ++i) { + tuples.push([cell.weights[i], inputWeights[i]]); + } + } + batchSetValue(tuples); + }; + StackedRNNCells.className = 'StackedRNNCells'; + return StackedRNNCells; + }(RNNCell)); + tfc.serialization.SerializationMap.register(StackedRNNCells); + function generateDropoutMask(ones, rate, training, count) { + if (training === void 0) { training = null; } + if (count === void 0) { count = 1; } + function droppedInputs() { + return dropout(ones(), getScalar(rate)); + } + if (count > 1) { + var mask = []; + for (var i = 0; i < count; i++) { + mask.push(inTrainPhase(droppedInputs, ones, training)); + } + mask.forEach(function (m) { return tfc.keep(m); }); + return mask; + } + else { + return tfc.keep(inTrainPhase(droppedInputs, ones, training)); + } + } + + var Wrapper = (function (_super) { + __extends(Wrapper, _super); + function Wrapper(config) { + var _this = _super.call(this, config) || this; + _this.layer = config.layer; + return _this; + } + Wrapper.prototype.build = function (inputShape) { + this.built = true; + }; + Object.defineProperty(Wrapper.prototype, "trainable", { + get: function () { + if (this.layer != null) { + return this.layer.trainable; + } + else { + return false; + } + }, + set: function (value) { + if (this.layer != null) { + this.layer.trainable = value; + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "trainableWeights", { + get: function () { + return this.layer.trainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "nonTrainableWeights", { + get: function () { + return this.layer.nonTrainableWeights; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "updates", { + get: function () { + return this.layer._updates; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Wrapper.prototype, "losses", { + get: function () { + return this.layer.losses; + }, + enumerable: true, + configurable: true + }); + Wrapper.prototype.getWeights = function () { + return this.layer.getWeights(); + }; + Wrapper.prototype.setWeights = function (weights) { + this.layer.setWeights(weights); + }; + Wrapper.prototype.getConfig = function () { + var config = { + 'layer': { + 'className': this.layer.getClassName(), + 'config': this.layer.getConfig(), + } + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Wrapper.fromConfig = function (cls, config, customObjects) { + if (customObjects === void 0) { customObjects = {}; } + var layerConfig = config['layer']; + var layer = deserialize(layerConfig, customObjects); + delete config['layer']; + var newConfig = { layer: layer }; + Object.assign(newConfig, config); + return new cls(newConfig); + }; + return Wrapper; + }(Layer)); + var TimeDistributed = (function (_super) { + __extends(TimeDistributed, _super); + function TimeDistributed(config) { + var _this = _super.call(this, config) || this; + _this.supportsMasking = true; + return _this; + } + TimeDistributed.prototype.build = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + if (inputShape.length < 3) { + throw new ValueError("TimeDistributed layer expects an input shape >= 3D, but received " + + ("input shape " + JSON.stringify(inputShape))); + } + this.inputSpec = [{ shape: inputShape }]; + var childInputShape = [inputShape[0]].concat(inputShape.slice(2)); + if (!this.layer.built) { + this.layer.build(childInputShape); + this.layer.built = true; + } + _super.prototype.build.call(this, inputShape); + }; + TimeDistributed.prototype.computeOutputShape = function (inputShape) { + inputShape = getExactlyOneShape(inputShape); + var childInputShape = [inputShape[0]].concat(inputShape.slice(2)); + var childOutputShape = this.layer.computeOutputShape(childInputShape); + var timesteps = inputShape[1]; + return [childOutputShape[0], timesteps].concat(childOutputShape.slice(1)); + }; + TimeDistributed.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + inputs = getExactlyOneTensor(inputs); + var step = function (inputs, states) { + var output = _this.layer.call(inputs, kwargs); + return [output, []]; + }; + var rnnOutputs = rnn(step, inputs, [], false, null, null, false, inputs.shape[1]); + var y = rnnOutputs[1]; + return y; + }); + }; + TimeDistributed.className = 'TimeDistributed'; + return TimeDistributed; + }(Wrapper)); + tfc.serialization.SerializationMap.register(TimeDistributed); + var VALID_BIDIRECTIONAL_MERGE_MODES = ['sum', 'mul', 'concat', 'ave']; + function checkBidirectionalMergeMode(value) { + checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES, 'BidirectionalMergeMode', value); + } + var Bidirectional = (function (_super) { + __extends(Bidirectional, _super); + function Bidirectional(config) { + var _this = _super.call(this, config) || this; + var layerConfig = config.layer.getConfig(); + _this.forwardLayer = + deserialize({ className: config.layer.getClassName(), config: layerConfig }); + layerConfig['goBackwards'] = + layerConfig['goBackwards'] === true ? false : true; + _this.backwardLayer = + deserialize({ className: config.layer.getClassName(), config: layerConfig }); + _this.forwardLayer.name = 'forward_' + _this.forwardLayer.name; + _this.backwardLayer.name = 'backward_' + _this.backwardLayer.name; + checkBidirectionalMergeMode(config.mergeMode); + _this.mergeMode = config.mergeMode; + if (config.weights) { + throw new NotImplementedError('weights support is not implemented for Bidirectional layer yet.'); + } + _this._stateful = config.layer.stateful; + _this.returnSequences = config.layer.returnSequences; + _this.returnState = config.layer.returnState; + _this.supportsMasking = true; + _this._trainable = true; + _this.inputSpec = config.layer.inputSpec; + _this.numConstants = null; + return _this; + } + Object.defineProperty(Bidirectional.prototype, "trainable", { + get: function () { + return this._trainable; + }, + set: function (value) { + this._trainable = value; + if (this.forwardLayer != null) { + this.forwardLayer.trainable = value; + } + if (this.backwardLayer != null) { + this.backwardLayer.trainable = value; + } + }, + enumerable: true, + configurable: true + }); + Bidirectional.prototype.getWeights = function () { + return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights()); + }; + Bidirectional.prototype.setWeights = function (weights) { + var numWeights = weights.length; + var numeightsOver2 = Math.floor(numWeights / 2); + this.forwardLayer.setWeights(weights.slice(0, numeightsOver2)); + this.backwardLayer.setWeights(weights.slice(numeightsOver2)); + }; + Bidirectional.prototype.computeOutputShape = function (inputShape) { + var layerShapes = this.forwardLayer.computeOutputShape(inputShape); + if (!(Array.isArray(layerShapes) && Array.isArray(layerShapes[0]))) { + layerShapes = [layerShapes]; + } + layerShapes = layerShapes; + var outputShape; + var outputShapes; + var stateShape; + if (this.returnState) { + stateShape = layerShapes.slice(1); + outputShape = layerShapes[0]; + } + else { + outputShape = layerShapes[0]; + } + outputShape = outputShape; + if (this.mergeMode === 'concat') { + outputShape[outputShape.length - 1] *= 2; + outputShapes = [outputShape]; + } + else if (this.mergeMode == null) { + outputShapes = [outputShape, outputShape.slice()]; + } + else { + outputShapes = [outputShape]; + } + if (this.returnState) { + if (this.mergeMode == null) { + return outputShapes.concat(stateShape).concat(stateShape.slice()); + } + return [outputShape].concat(stateShape).concat(stateShape.slice()); + } + return singletonOrArray(outputShapes); + }; + Bidirectional.prototype.apply = function (inputs, kwargs) { + var initialState = kwargs == null ? null : kwargs['initialState']; + var constants = kwargs == null ? null : kwargs['constants']; + if (kwargs == null) { + kwargs = {}; + } + var standardized = standardizeArgs(inputs, initialState, constants, this.numConstants); + inputs = standardized.inputs; + initialState = standardized.initialState; + constants = standardized.constants; + if (Array.isArray(inputs)) { + initialState = inputs.slice(1); + inputs = inputs[0]; + } + if ((initialState == null || initialState.length === 0) && + constants == null) { + return _super.prototype.apply.call(this, inputs, kwargs); + } + var additionalInputs = []; + var additionalSpecs = []; + if (initialState != null) { + var numStates = initialState.length; + if (numStates % 2 > 0) { + throw new ValueError('When passing `initialState` to a Bidrectional RNN, ' + + 'the state should be an Array containing the states of ' + + 'the underlying RNNs.'); + } + kwargs['initialState'] = initialState; + additionalInputs.push.apply(additionalInputs, initialState); + var stateSpecs = initialState + .map(function (state) { return new InputSpec({ shape: state.shape }); }); + this.forwardLayer.stateSpec = stateSpecs.slice(0, numStates / 2); + this.backwardLayer.stateSpec = stateSpecs.slice(numStates / 2); + additionalSpecs.push.apply(additionalSpecs, stateSpecs); + } + if (constants != null) { + throw new NotImplementedError('Support for constants in Bidirectional layers is not ' + + 'implemented yet.'); + } + var isSymbolicTensor = additionalInputs[0] instanceof SymbolicTensor; + for (var _i = 0, additionalInputs_1 = additionalInputs; _i < additionalInputs_1.length; _i++) { + var tensor = additionalInputs_1[_i]; + if (tensor instanceof SymbolicTensor !== isSymbolicTensor) { + throw new ValueError('The initial state of a Bidirectional layer cannot be ' + + 'specified as a mix of symbolic and non-symbolic tensors'); + } + } + if (isSymbolicTensor) { + var fullInput = [inputs].concat(additionalInputs); + var fullInputSpec = this.inputSpec.concat(additionalSpecs); + var originalInputSpec = this.inputSpec; + this.inputSpec = fullInputSpec; + var output = _super.prototype.apply.call(this, fullInput, kwargs); + this.inputSpec = originalInputSpec; + return output; + } + else { + return _super.prototype.apply.call(this, inputs, kwargs); + } + }; + Bidirectional.prototype.call = function (inputs, kwargs) { + var _this = this; + return tfc.tidy(function () { + if (kwargs['mask'] != null) { + throw new NotImplementedError('The support for masking is not implemented for ' + + 'Bidirectional layers yet.'); + } + var initialState = kwargs['initialState']; + var y; + var yRev; + if (initialState == null) { + y = _this.forwardLayer.call(inputs, kwargs); + yRev = _this.backwardLayer.call(inputs, kwargs); + } + else { + var forwardState = initialState.slice(0, initialState.length / 2); + var backwardState = initialState.slice(initialState.length / 2); + y = _this.forwardLayer.call(inputs, Object.assign(kwargs, { initialState: forwardState })); + yRev = _this.forwardLayer.call(inputs, Object.assign(kwargs, { initialState: backwardState })); + } + var states; + if (_this.returnState) { + if (Array.isArray(y)) { + states = y.slice(1).concat(yRev.slice(1)); + } + y = y[0]; + yRev = yRev[0]; + } + if (_this.returnSequences) { + yRev = tfc.reverse(yRev, 1); + } + var output; + if (_this.mergeMode === 'concat') { + output = concatenate([y, yRev]); + } + else if (_this.mergeMode === 'sum') { + output = tfc.add(y, yRev); + } + else if (_this.mergeMode === 'ave') { + output = tfc.mul(getScalar(0.5), tfc.add(y, yRev)); + } + else if (_this.mergeMode === 'mul') { + output = tfc.mul(y, yRev); + } + else if (_this.mergeMode == null) { + output = [y, yRev]; + } + if (_this.returnState) { + if (_this.mergeMode == null) { + return output.concat(states); + } + return [output].concat(states); + } + return output; + }); + }; + Bidirectional.prototype.resetStates = function (states) { + this.forwardLayer.resetStates(); + this.backwardLayer.resetStates(); + }; + Bidirectional.prototype.build = function (inputShape) { + var _this = this; + nameScope(this.forwardLayer.name, function () { + _this.forwardLayer.build(inputShape); + }); + nameScope(this.backwardLayer.name, function () { + _this.backwardLayer.build(inputShape); + }); + this.built = true; + }; + Object.defineProperty(Bidirectional.prototype, "trainableWeights", { + get: function () { + return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(Bidirectional.prototype, "nonTrainableWeights", { + get: function () { + return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights); + }, + enumerable: true, + configurable: true + }); + Bidirectional.prototype.getConfig = function () { + var config = { + 'mergeMode': this.mergeMode, + }; + var baseConfig = _super.prototype.getConfig.call(this); + Object.assign(config, baseConfig); + return config; + }; + Bidirectional.fromConfig = function (cls, config) { + var rnnLayer = deserialize(config['layer']); + delete config['layer']; + if (config['numConstants'] != null) { + throw new NotImplementedError("Deserialization of a Bidirectional layer with numConstants " + + "present is not supported yet."); + } + var newConfig = config; + newConfig['layer'] = rnnLayer; + return new cls(newConfig); + }; + Bidirectional.className = 'Bidirectional'; + return Bidirectional; + }(Wrapper)); + tfc.serialization.SerializationMap.register(Bidirectional); + + function inputLayer(config) { + return new InputLayer(config); + } + function elu$1(config) { + return new ELU(config); + } + function leakyReLU(config) { + return new LeakyReLU(config); + } + function softmax(config) { + return new Softmax$1(config); + } + function thresholdedReLU(config) { + return new ThresholdedReLU(config); + } + function conv1d$1(config) { + return new Conv1D(config); + } + function conv2d$1(config) { + return new Conv2D(config); + } + function conv2dTranspose(config) { + return new Conv2DTranspose(config); + } + function separableConv2d(config) { + return new SeparableConv2D(config); + } + function cropping2D(config) { + return new Cropping2D(config); + } + function upSampling2d(config) { + return new UpSampling2D(config); + } + function depthwiseConv2d$1(config) { + return new DepthwiseConv2D(config); + } + function activation(config) { + return new Activation$1(config); + } + function dense(config) { + return new Dense(config); + } + function dropout$1(config) { + return new Dropout(config); + } + function flatten$1(config) { + return new Flatten(config); + } + function repeatVector(config) { + return new RepeatVector(config); + } + function reshape(config) { + return new Reshape(config); + } + function embedding(config) { + return new Embedding(config); + } + function add$1(config) { + return new Add(config); + } + function average$1(config) { + return new Average(config); + } + function concatenate$2(config) { + return new Concatenate(config); + } + function maximum$1(config) { + return new Maximum(config); + } + function minimum$1(config) { + return new Minimum(config); + } + function multiply$1(config) { + return new Multiply(config); + } + function batchNormalization$1(config) { + return new BatchNormalization(config); + } + function zeroPadding2d(config) { + return new ZeroPadding2D(config); + } + function averagePooling1d(config) { + return new AveragePooling1D(config); + } + function avgPool1d(config) { + return averagePooling1d(config); + } + function avgPooling1d(config) { + return averagePooling1d(config); + } + function averagePooling2d(config) { + return new AveragePooling2D(config); + } + function avgPool2d(config) { + return averagePooling2d(config); + } + function avgPooling2d(config) { + return averagePooling2d(config); + } + function globalAveragePooling1d(config) { + return new GlobalAveragePooling1D(config); + } + function globalAveragePooling2d(config) { + return new GlobalAveragePooling2D(config); + } + function globalMaxPooling1d(config) { + return new GlobalMaxPooling1D(config); + } + function globalMaxPooling2d(config) { + return new GlobalMaxPooling2D(config); + } + function maxPooling1d(config) { + return new MaxPooling1D(config); + } + function maxPooling2d(config) { + return new MaxPooling2D(config); + } + function gru(config) { + return new GRU(config); + } + function gruCell(config) { + return new GRUCell(config); + } + function lstm(config) { + return new LSTM(config); + } + function lstmCell(config) { + return new LSTMCell(config); + } + function simpleRNN(config) { + return new SimpleRNN(config); + } + function simpleRNNCell(config) { + return new SimpleRNNCell(config); + } + function rnn$1(config) { + return new RNN(config); + } + function stackedRNNCells(config) { + return new StackedRNNCells(config); + } + function bidirectional(config) { + return new Bidirectional(config); + } + function timeDistributed(config) { + return new TimeDistributed(config); + } + var globalMaxPool1d = globalMaxPooling1d; + var globalMaxPool2d = globalMaxPooling2d; + var maxPool1d = maxPooling1d; + var maxPool2d = maxPooling2d; + + var exports_layers = /*#__PURE__*/Object.freeze({ + inputLayer: inputLayer, + elu: elu$1, + leakyReLU: leakyReLU, + softmax: softmax, + thresholdedReLU: thresholdedReLU, + conv1d: conv1d$1, + conv2d: conv2d$1, + conv2dTranspose: conv2dTranspose, + separableConv2d: separableConv2d, + cropping2D: cropping2D, + upSampling2d: upSampling2d, + depthwiseConv2d: depthwiseConv2d$1, + activation: activation, + dense: dense, + dropout: dropout$1, + flatten: flatten$1, + repeatVector: repeatVector, + reshape: reshape, + embedding: embedding, + add: add$1, + average: average$1, + concatenate: concatenate$2, + maximum: maximum$1, + minimum: minimum$1, + multiply: multiply$1, + batchNormalization: batchNormalization$1, + zeroPadding2d: zeroPadding2d, + averagePooling1d: averagePooling1d, + avgPool1d: avgPool1d, + avgPooling1d: avgPooling1d, + averagePooling2d: averagePooling2d, + avgPool2d: avgPool2d, + avgPooling2d: avgPooling2d, + globalAveragePooling1d: globalAveragePooling1d, + globalAveragePooling2d: globalAveragePooling2d, + globalMaxPooling1d: globalMaxPooling1d, + globalMaxPooling2d: globalMaxPooling2d, + maxPooling1d: maxPooling1d, + maxPooling2d: maxPooling2d, + gru: gru, + gruCell: gruCell, + lstm: lstm, + lstmCell: lstmCell, + simpleRNN: simpleRNN, + simpleRNNCell: simpleRNNCell, + rnn: rnn$1, + stackedRNNCells: stackedRNNCells, + bidirectional: bidirectional, + timeDistributed: timeDistributed, + globalMaxPool1d: globalMaxPool1d, + globalMaxPool2d: globalMaxPool2d, + maxPool1d: maxPool1d, + maxPool2d: maxPool2d, + Layer: Layer, + input: input + }); + + function binaryAccuracy$1(yTrue, yPred) { + return binaryAccuracy(yTrue, yPred); + } + function binaryCrossentropy$2(yTrue, yPred) { + return binaryCrossentropy$1(yTrue, yPred); + } + function categoricalAccuracy$1(yTrue, yPred) { + return categoricalAccuracy(yTrue, yPred); + } + function categoricalCrossentropy$2(yTrue, yPred) { + return categoricalCrossentropy$1(yTrue, yPred); + } + function cosineProximity$1(yTrue, yPred) { + return cosineProximity(yTrue, yPred); + } + function meanAbsoluteError$1(yTrue, yPred) { + return meanAbsoluteError(yTrue, yPred); + } + function meanAbsolutePercentageError$1(yTrue, yPred) { + return meanAbsolutePercentageError(yTrue, yPred); + } + function MAPE$2(yTrue, yPred) { + return meanAbsolutePercentageError(yTrue, yPred); + } + function mape$2(yTrue, yPred) { + return meanAbsolutePercentageError(yTrue, yPred); + } + function meanSquaredError$1(yTrue, yPred) { + return meanSquaredError(yTrue, yPred); + } + function MSE$2(yTrue, yPred) { + return meanSquaredError(yTrue, yPred); + } + function mse$2(yTrue, yPred) { + return meanSquaredError(yTrue, yPred); + } + + var exports_metrics = /*#__PURE__*/Object.freeze({ + binaryAccuracy: binaryAccuracy$1, + binaryCrossentropy: binaryCrossentropy$2, + categoricalAccuracy: categoricalAccuracy$1, + categoricalCrossentropy: categoricalCrossentropy$2, + cosineProximity: cosineProximity$1, + meanAbsoluteError: meanAbsoluteError$1, + meanAbsolutePercentageError: meanAbsolutePercentageError$1, + MAPE: MAPE$2, + mape: mape$2, + meanSquaredError: meanSquaredError$1, + MSE: MSE$2, + mse: mse$2 + }); + + function l1l2(config) { + return new L1L2(config); + } + function l1$1(config) { + return l1(config); + } + function l2$1(config) { + return l2(config); + } + + var exports_regularizers = /*#__PURE__*/Object.freeze({ + l1l2: l1l2, + l1: l1$1, + l2: l2$1 + }); + + var Callback = (function (_super) { + __extends(Callback, _super); + function Callback() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.model = null; + return _this; + } + Callback.prototype.setModel = function (model) { + if (!(model instanceof Model)) { + throw new Error('model must be a Model, not some other Container'); + } + this.model = model; + }; + return Callback; + }(BaseCallback)); + + exports.constraints = exports_constraints; + exports.initializers = exports_initializers; + exports.layers = exports_layers; + exports.metrics = exports_metrics; + exports.regularizers = exports_regularizers; + exports.CallbackList = CallbackList; + exports.CustomCallback = CustomCallback; + exports.Callback = Callback; + exports.SymbolicTensor = SymbolicTensor; + exports.Model = Model; + exports.input = input; + exports.loadModel = loadModel; + exports.model = model; + exports.sequential = sequential; + exports.RNN = RNN; + exports.Sequential = Sequential; + exports.LayerVariable = LayerVariable; + exports.version_layers = version; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); +//# sourceMappingURL=tf-layers.js.map diff --git a/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js.map b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js.map new file mode 100644 index 0000000..5f6fd7e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf-layers.js","sources":["../src/backend/common.ts","../src/backend/state.ts","../src/errors.ts","../src/utils/generic_utils.ts","../src/constraints.ts","../src/exports_constraints.ts","../src/common.ts","../src/utils/math_utils.ts","../src/backend/tfjs_backend.ts","../src/initializers.ts","../src/exports_initializers.ts","../src/utils/types_utils.ts","../src/utils/variable_utils.ts","../src/variables.ts","../src/engine/topology.ts","../src/engine/input_layer.ts","../src/logs.ts","../src/base_callbacks.ts","../src/losses.ts","../src/metrics.ts","../src/optimizers.ts","../src/utils/layer_utils.ts","../src/layers/serialization.ts","../src/utils/serialization_utils.ts","../src/version.ts","../src/engine/container.ts","../src/engine/executor.ts","../src/engine/training.ts","../src/models.ts","../src/exports.ts","../src/activations.ts","../src/layers/advanced_activations.ts","../src/regularizers.ts","../src/utils/conv_utils.ts","../src/layers/convolutional.ts","../src/layers/convolutional_depthwise.ts","../src/layers/core.ts","../src/layers/embeddings.ts","../src/layers/merge.ts","../src/layers/normalization.ts","../src/layers/padding.ts","../src/layers/pooling.ts","../src/layers/recurrent.ts","../src/layers/wrappers.ts","../src/exports_layers.ts","../src/exports_metrics.ts","../src/exports_regularizers.ts","../src/callbacks.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {DataFormat} from '../common';\n\nlet _epsilon = 1e-7;\n\n/**\n * Returns the value of the fuzz factor used in numeric expressions.\n */\nexport function epsilon() {\n return _epsilon;\n}\n\n/**\n * Sets the value of the fuzz factor used in numeric expressions.\n * @param e New value of epsilon.\n */\nexport function setEpsilon(e: number) {\n _epsilon = e;\n}\n\n/**\n * Returns the default image data format convention.\n */\nexport function imageDataFormat(): DataFormat {\n return 'channelsLast';\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Utilities related to persistent state in the backend.\n */\n\nimport {DataType, keep, Scalar, scalar} from '@tensorflow/tfjs-core';\n\n/**\n * An ID to track `SymbolicTensor`s and derived classes.\n * Required in different places in engine/topology.ts to identify unique\n * tensors.\n */\nlet _nextUniqueTensorId = 0;\n\nexport function getNextUniqueTensorId(): number {\n return _nextUniqueTensorId++;\n}\n\nconst _uidPrefixes: {[prefix: string]: number} = {};\n\n/**\n * Provides a unique UID given a string prefix.\n *\n * @param prefix\n */\nexport function getUid(prefix = ''): string {\n if (!(prefix in _uidPrefixes)) {\n _uidPrefixes[prefix] = 0;\n }\n _uidPrefixes[prefix] += 1;\n return prefix + _uidPrefixes[prefix].toString();\n}\n\nconst scalarCache: {[typeKey: string]: {[key: number]: Scalar}} = {\n float32: {},\n int32: {}\n};\n\nconst DEFAULT_DTYPE: DataType = 'float32';\n\n/**\n * Get scalar, with caching.\n */\nexport function getScalar(value: number, dtype?: DataType): Scalar {\n if (dtype === undefined) {\n dtype = DEFAULT_DTYPE;\n }\n if (scalarCache[dtype][value] == null) {\n scalarCache[dtype][value] = scalar(value, dtype);\n keep(scalarCache[dtype][value]);\n }\n return scalarCache[dtype][value];\n}\n\nexport function disposeScalarCache() {\n for (const typeKey in scalarCache) {\n for (const key in scalarCache[typeKey]) {\n scalarCache[typeKey][key].dispose();\n delete scalarCache[typeKey][key];\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// tslint:disable:max-line-length\n/**\n * Explicit error types.\n *\n * See the following link for more information about why the code includes\n * calls to setPrototypeOf:\n *\n * https://github.com/Microsoft/TypeScript-wiki/blob/master/Breaking-Changes.md#extending-built-ins-like-error-array-and-map-may-no-longer-work\n */\n// tslint:enable\n\n/**\n * Equivalent of Python's AttributeError.\n */\nexport class AttributeError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, AttributeError.prototype);\n }\n}\n\n/**\n * Equivalent of Python's RuntimeError.\n */\nexport class RuntimeError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, RuntimeError.prototype);\n }\n}\n\n/**\n * Equivalent of Python's ValueError.\n */\nexport class ValueError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, ValueError.prototype);\n }\n}\n\n/**\n * Equivalent of Python's NotImplementedError.\n */\nexport class NotImplementedError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, NotImplementedError.prototype);\n }\n}\n\n/**\n * Equivalent of Python's AssertionError.\n */\nexport class AssertionError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, AssertionError.prototype);\n }\n}\n\n/**\n * Equivalent of Python's IndexError.\n */\nexport class IndexError extends Error {\n constructor(message?: string) {\n super(message);\n // Set the prototype explicitly.\n Object.setPrototypeOf(this, IndexError.prototype);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: utils/generic_utils.py */\n\n// tslint:disable:max-line-length\nimport {DataType, serialization} from '@tensorflow/tfjs-core';\n\nimport {AssertionError, ValueError} from '../errors';\n// tslint:enable\n\n/**\n * If `value` is an Array, equivalent to Python's `value * numValues`.\n * If `value` is not an Array, equivalent to Python's `[value] * numValues`\n */\n// tslint:disable-next-line:no-any\nexport function pyListRepeat(value: any, numValues: number): any[] {\n if (Array.isArray(value)) {\n // tslint:disable-next-line:no-any\n let newArray: any[] = [];\n for (let i = 0; i < numValues; i++) {\n newArray = newArray.concat(value);\n }\n return newArray;\n } else {\n const newArray = new Array(numValues);\n newArray.fill(value);\n return newArray;\n }\n}\n\nexport function assert(val: boolean, message?: string): void {\n if (!val) {\n throw new AssertionError(message);\n }\n}\n\n/**\n * Count the number of elements of the `array` that are equal to `reference`.\n */\nexport function count(array: T[], refernce: T) {\n let counter = 0;\n for (const item of array) {\n if (item === refernce) {\n counter++;\n }\n }\n return counter;\n}\n\n/**\n * If an array is of length 1, just return the first element. Otherwise, return\n * the full array.\n * @param tensors\n */\nexport function singletonOrArray(xs: T[]): T|T[] {\n if (xs.length === 1) {\n return xs[0];\n }\n return xs;\n}\n\n/**\n * Normalizes a list/tensor into a list.\n *\n * If a tensor is passed, we return\n * a list of size 1 containing the tensor.\n *\n * @param x target object to be normalized.\n */\n// tslint:disable-next-line:no-any\nexport function toList(x: any): any[] {\n if (Array.isArray(x)) {\n return x;\n }\n return [x];\n}\n\n/**\n * Generate a UID for a list\n */\n// tslint:disable-next-line:no-any\nexport function objectListUid(objs: any|any[]): string {\n const objectList = toList(objs);\n let retVal = '';\n for (const obj of objectList) {\n if (obj.id == null) {\n throw new ValueError(\n `Object ${obj} passed to objectListUid without an id`);\n }\n if (retVal !== '') {\n retVal = retVal + ', ';\n }\n retVal = retVal + Math.abs(obj.id);\n }\n return retVal;\n}\n/**\n * Converts string to snake-case.\n * @param name\n */\nexport function toSnakeCase(name: string): string {\n const intermediate = name.replace(/(.)([A-Z][a-z0-9]+)/g, '$1_$2');\n const insecure =\n intermediate.replace(/([a-z])([A-Z])/g, '$1_$2').toLowerCase();\n /*\n If the class is private the name starts with \"_\" which is not secure\n for creating scopes. We prefix the name with \"private\" in this case.\n */\n if (insecure[0] !== '_') {\n return insecure;\n }\n return 'private' + insecure;\n}\n\nexport function toCamelCase(identifier: string): string {\n // quick return for empty string or single character strings\n if (identifier.length <= 1) {\n return identifier;\n }\n // Check for the underscore indicating snake_case\n if (identifier.indexOf('_') === -1) {\n return identifier;\n }\n return identifier.replace(/[_]+(\\w|$)/g, (m, p1) => p1.toUpperCase());\n}\n\n// tslint:disable-next-line:no-any\nlet _GLOBAL_CUSTOM_OBJECTS = {} as {[objName: string]: any};\n\nexport function serializeKerasObject(instance: serialization.Serializable):\n serialization.ConfigDictValue {\n if (instance === null || instance === undefined) {\n return null;\n }\n return {className: instance.getClassName(), config: instance.getConfig()};\n}\n\n/**\n * Deserialize a saved Keras Object\n * @param identifier either a string ID or a saved Keras dictionary\n * @param moduleObjects a list of Python class names to object constructors\n * @param customObjects a list of Python class names to object constructors\n * @param printableModuleName debug text for the object being reconstituted\n * @returns a TensorFlow.js Layers object\n */\n// tslint:disable:no-any\nexport function deserializeKerasObject(\n identifier: string|serialization.ConfigDict,\n moduleObjects = {} as {[objName: string]: any},\n customObjects = {} as {[objName: string]: any},\n printableModuleName = 'object'): any {\n // tslint:enable\n if (typeof identifier === 'string') {\n const functionName = identifier;\n let fn;\n if (functionName in customObjects) {\n fn = customObjects[functionName];\n } else if (functionName in _GLOBAL_CUSTOM_OBJECTS) {\n fn = _GLOBAL_CUSTOM_OBJECTS[functionName];\n } else {\n fn = moduleObjects[functionName];\n if (fn == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${identifier}`);\n }\n }\n return fn;\n } else {\n // In this case we are dealing with a Keras config dictionary.\n const config = identifier;\n if (config.className == null || config.config == null) {\n throw new ValueError(\n `${printableModuleName}: Improper config format: ` +\n `${JSON.stringify(config)}.\\n` +\n `'className' and 'config' must set.`);\n }\n const className = config.className as string;\n let cls, fromConfig;\n if (className in customObjects) {\n [cls, fromConfig] = customObjects.get(className);\n } else if (className in _GLOBAL_CUSTOM_OBJECTS) {\n [cls, fromConfig] = _GLOBAL_CUSTOM_OBJECTS.className;\n } else if (className in moduleObjects) {\n [cls, fromConfig] = moduleObjects[className];\n }\n if (cls == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${className}`);\n }\n if (fromConfig != null) {\n // Porting notes: Instead of checking to see whether fromConfig accepts\n // customObjects, we create a customObjects dictionary and tack it on to\n // config.config as config.config.customObjects. Objects can use it, if\n // they want.\n\n // tslint:disable-next-line:no-any\n const customObjectsCombined = {} as {[objName: string]: any};\n for (const key of Object.keys(_GLOBAL_CUSTOM_OBJECTS)) {\n customObjectsCombined[key] = _GLOBAL_CUSTOM_OBJECTS[key];\n }\n for (const key of Object.keys(customObjects)) {\n customObjectsCombined[key] = customObjects[key];\n }\n // Add the customObjects to config\n const nestedConfig = config.config as serialization.ConfigDict;\n nestedConfig.customObjects = customObjectsCombined;\n\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n const returnObj = fromConfig(cls, config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n\n return returnObj;\n } else {\n // Then `cls` may be a function returning a class.\n // In this case by convention `config` holds\n // the kwargs of the function.\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n // In python this is **config['config'], for tfjs-layers we require\n // classes that use this fall-through construction method to take\n // a config interface that mimics the expansion of named parameters.\n const returnObj = new cls(config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n return returnObj;\n }\n }\n}\n\n/**\n * Compares two numbers for sorting.\n * @param a\n * @param b\n */\nexport function numberCompare(a: number, b: number) {\n return (a < b) ? -1 : ((a > b) ? 1 : 0);\n}\n\n/**\n * Comparison of two numbers for reverse sorting.\n * @param a\n * @param b\n */\nexport function reverseNumberCompare(a: number, b: number) {\n return -1 * numberCompare(a, b);\n}\n\n/**\n * Convert a string into the corresponding DType.\n * @param dtype\n * @returns An instance of DType.\n */\nexport function stringToDType(dtype: string): DataType {\n switch (dtype) {\n case 'float32':\n return 'float32';\n default:\n throw new ValueError(`Invalid dtype: ${dtype}`);\n }\n}\n\n/**\n * Test the element-by-element equality of two Arrays of strings.\n * @param xs First array of strings.\n * @param ys Second array of strings.\n * @returns Wether the two arrays are all equal, element by element.\n */\nexport function stringsEqual(xs: string[], ys: string[]): boolean {\n if (xs == null || ys == null) {\n return xs === ys;\n }\n if (xs.length !== ys.length) {\n return false;\n }\n for (let i = 0; i < xs.length; ++i) {\n if (xs[i] !== ys[i]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Get the unique elements of an array.\n * @param xs Array.\n * @returns An Array consisting of the unique elements in `xs`.\n */\nexport function unique(xs: T[]): T[] {\n if (xs == null) {\n return xs;\n }\n const out: T[] = [];\n // TODO(cais): Maybe improve performance by sorting.\n for (const x of xs) {\n if (out.indexOf(x) === -1) {\n out.push(x);\n }\n }\n return out;\n}\n\n/**\n * Determine if an Object is empty (i.e., does not have own properties).\n * @param obj Object\n * @returns Whether the Object is empty.\n * @throws ValueError: If object is `null` or `undefined`.\n */\nexport function isObjectEmpty(obj: {}): boolean {\n if (obj == null) {\n throw new ValueError(`Invalid value in obj: ${JSON.stringify(obj)}`);\n }\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Helper function used to build type union/enum run-time checkers.\n * @param values The list of allowed values.\n * @param label A string name for the type\n * @param value The value to test.\n * @throws ValueError: If the value is not in values nor `undefined`/`null`.\n */\nexport function checkStringTypeUnionValue(\n values: string[], label: string, value: string): void {\n if (value == null) {\n return;\n }\n if (values.indexOf(value) < 0) {\n throw new ValueError(`${value} is not a valid ${label}. Valid values are ${\n values} or null/undefined.`);\n }\n}\n\n/**\n * Helper function for verifying the types of inputs.\n *\n * Ensures that the elements of `x` are all of type `expectedType`.\n * Also verifies that the length of `x` is within bounds.\n *\n * @param x Object to test.\n * @param expectedType The string expected type of all of the elements in the\n * Array.\n * @param minLength Return false if x.length is less than this.\n * @param maxLength Return false if x.length is greater than this.\n * @returns true if and only if `x` is an `Array` with\n * length >= `minLength` and <= `maxLength`.\n */\n// tslint:disable:no-any\nexport function checkArrayTypeAndLength(\n x: any, expectedType: string, minLength = 0,\n maxLength = Infinity): boolean {\n assert(minLength >= 0);\n assert(maxLength >= minLength);\n return (\n Array.isArray(x) && x.length >= minLength && x.length <= maxLength &&\n x.every(e => typeof e === expectedType));\n}\n// tslint:enable:no-any\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/contraints.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Helper function used by many of the Constraints to find the L2Norms.\n */\nfunction calcL2Norms(w: Tensor, axis: number): Tensor {\n return tidy(() => tfc.sqrt(tfc.sum(tfc.mulStrict(w, w), axis, true)));\n}\n\n/**\n * Base class for functions that impose constraints on weight values\n */\n/**\n * @doc {\n * heading: 'Constraints',\n * subheading: 'Classes',\n * namespace: 'constraints'\n * }\n */\nexport abstract class Constraint extends serialization.Serializable {\n /* Porting note: was __call__, apply chosen to match other similar choices */\n abstract apply(w: Tensor): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\nexport interface MaxNormConfig {\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * MaxNorm weight constraint.\n *\n * Constrains the weights incident to each hidden unit\n * to have a norm less than or equal to a desired value.\n *\n * References\n * - [Dropout: A Simple Way to Prevent Neural Networks from Overfitting\n * Srivastava, Hinton, et al.\n * 2014](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf)\n */\nexport class MaxNorm extends Constraint {\n static readonly className = 'MaxNorm';\n private maxValue: number;\n private axis: number;\n private readonly defaultMaxValue = 2;\n private readonly defaultAxis = 0;\n\n constructor(config: MaxNormConfig) {\n super();\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.clipByValue(norms, 0, this.maxValue);\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {maxValue: this.maxValue, axis: this.axis};\n }\n}\nserialization.SerializationMap.register(MaxNorm);\n\nexport interface UnitNormConfig {\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * [rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * Constrains the weights incident to each hidden unit to have unit norm.\n */\nexport class UnitNorm extends Constraint {\n static readonly className = 'UnitNorm';\n private axis: number;\n private readonly defaultAxis = 0;\n constructor(config: UnitNormConfig) {\n super();\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(\n () => tfc.div(\n w, tfc.add(getScalar(epsilon()), calcL2Norms(w, this.axis))));\n }\n\n getConfig(): serialization.ConfigDict {\n return {axis: this.axis};\n }\n}\nserialization.SerializationMap.register(UnitNorm);\n\n/**\n * Constains the weight to be non-negative.\n */\nexport class NonNeg extends Constraint {\n static readonly className = 'NonNeg';\n\n apply(w: Tensor): Tensor {\n return tfc.relu(w);\n }\n}\nserialization.SerializationMap.register(NonNeg);\n\nexport interface MinMaxNormConfig {\n /**\n * Minimum norm for incoming weights\n */\n minValue?: number;\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n /**\n * Rate for enforcing the constraint: weights will be rescaled to yield:\n * `(1 - rate) * norm + rate * norm.clip(minValue, maxValue)`.\n * Effectively, this means that rate=1.0 stands for strict\n * enforcement of the constraint, while rate<1.0 means that\n * weights will be rescaled at each step to slowly move\n * towards a value inside the desired interval.\n */\n rate?: number;\n}\n\nexport class MinMaxNorm extends Constraint {\n static readonly className = 'MinMaxNorm';\n private minValue: number;\n private maxValue: number;\n private rate: number;\n private axis: number;\n private readonly defaultMinValue = 0.0;\n private readonly defaultMaxValue = 1.0;\n private readonly defaultRate = 1.0;\n private readonly defaultAxis = 0;\n\n constructor(config: MinMaxNormConfig) {\n super();\n this.minValue =\n config.minValue != null ? config.minValue : this.defaultMinValue;\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.rate = config.rate != null ? config.rate : this.defaultRate;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.add(\n tfc.mul(\n getScalar(this.rate),\n tfc.clipByValue(norms, this.minValue, this.maxValue)),\n tfc.mul(getScalar(1.0 - this.rate), norms));\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n minValue: this.minValue,\n maxValue: this.maxValue,\n rate: this.rate,\n axis: this.axis\n };\n }\n}\nserialization.SerializationMap.register(MinMaxNorm);\n\n/** @docinline */\nexport type ConstraintIdentifier =\n 'maxNorm'|'minMaxNorm'|'nonNeg'|'unitNorm'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in ConstraintIdentifier]: string} = {\n 'maxNorm': 'MaxNorm',\n 'minMaxNorm': 'MinMaxNorm',\n 'nonNeg': 'NonNeg',\n 'unitNorm': 'UnitNorm'\n };\n\nexport function serializeConstraint(constraint: Constraint):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeConstraint(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Constraint {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'constraint');\n}\n\nexport function getConstraint(identifier: ConstraintIdentifier|\n serialization.ConfigDict|Constraint): Constraint {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeConstraint(config);\n } else if (identifier instanceof Constraint) {\n return identifier;\n } else {\n return deserializeConstraint(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constraint, MaxNorm, MaxNormConfig, MinMaxNorm, MinMaxNormConfig, NonNeg, UnitNorm, UnitNormConfig} from './constraints';\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MaxNorm',\n * configParamIndices: [0]\n * }\n */\nexport function maxNorm(config: MaxNormConfig): Constraint {\n return new MaxNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'UnitNorm',\n * configParamIndices: [0]\n * }\n */\nexport function unitNorm(config: UnitNormConfig): Constraint {\n return new UnitNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'NonNeg'\n * }\n */\nexport function nonNeg(): Constraint {\n return new NonNeg();\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MinMaxNormConfig',\n * configParamIndices: [0]\n * }\n */\nexport function minMaxNorm(config: MinMaxNormConfig): Constraint {\n return new MinMaxNorm(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Common functions for TensorFlow.js Layers.\n */\nimport {checkStringTypeUnionValue} from './utils/generic_utils';\n// A map from the requested scoped name of a Tensor to the number of Tensors\n// wanting that name so far. This allows enforcing name uniqueness by appending\n// an incrementing index, e.g. scope/name, scope/name_1, scope/name_2, etc.\nconst nameMap: Map = new Map();\n\n// TODO(cais): Perhaps move the enums to a more suitable place, e.g.,\n// constants.ts.\n/** @docinline */\nexport type DataFormat = 'channelsFirst'|'channelsLast';\nexport const VALID_DATA_FORMAT_VALUES = ['channelsFirst', 'channelsLast'];\nexport function checkDataFormat(value?: string): void {\n checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES, 'DataFormat', value);\n}\n\n/** @docinline */\nexport type PaddingMode = 'valid'|'same'|'causal';\nexport const VALID_PADDING_MODE_VALUES = ['valid', 'same', 'causal'];\nexport function checkPaddingMode(value?: string): void {\n checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES, 'PaddingMode', value);\n}\n\n/** @docinline */\nexport type PoolMode = 'max'|'avg';\nexport const VALID_POOL_MODE_VALUES = ['max', 'avg'];\nexport function checkPoolMode(value?: string): void {\n checkStringTypeUnionValue(VALID_POOL_MODE_VALUES, 'PoolMode', value);\n}\n\nconst _nameScopeStack: string[] = [];\nconst _nameScopeDivider = '/';\n\n/**\n * Enter namescope, which can be nested.\n */\nexport function nameScope(name: string, fn: () => T): T {\n _nameScopeStack.push(name);\n try {\n const val: T = fn();\n _nameScopeStack.pop();\n return val;\n } catch (e) {\n _nameScopeStack.pop();\n throw e;\n }\n}\n\n/**\n * Get the current namescope as a flat, concatenated string.\n */\nfunction currentNameScopePrefix(): string {\n if (_nameScopeStack.length === 0) {\n return '';\n } else {\n return _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider;\n }\n}\n\n/**\n * Get the name a Tensor (or Variable) would have if not uniqueified.\n * @param tensorName\n * @return Scoped name string.\n */\nexport function getScopedTensorName(tensorName: string): string {\n if (!isValidTensorName(tensorName)) {\n throw new Error('Not a valid tensor name: \\'' + tensorName + '\\'');\n }\n return currentNameScopePrefix() + tensorName;\n}\n\n/**\n * Get unique names for Tensors and Variables.\n * @param scopedName The fully-qualified name of the Tensor, i.e. as produced by\n * `getScopedTensorName()`.\n * @return A unique version of the given fully scoped name.\n * If this is the first time that the scoped name is seen in this session,\n * then the given `scopedName` is returned unaltered. If the same name is\n * seen again (producing a collision), an incrementing suffix is added to the\n * end of the name, so it takes the form 'scope/name_1', 'scope/name_2', etc.\n */\nexport function getUniqueTensorName(scopedName: string): string {\n if (!isValidTensorName(scopedName)) {\n throw new Error('Not a valid tensor name: \\'' + scopedName + '\\'');\n }\n if (!nameMap.has(scopedName)) {\n nameMap.set(scopedName, 0);\n }\n const index = nameMap.get(scopedName);\n nameMap.set(scopedName, nameMap.get(scopedName) + 1);\n\n if (index > 0) {\n const result = scopedName + '_' + index;\n // Mark the composed name as used in case someone wants\n // to call getUniqueTensorName(\"name_1\").\n nameMap.set(result, 1);\n return result;\n } else {\n return scopedName;\n }\n}\n\nconst tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\\._\\/]*$/);\n\n/**\n * Determine whether a string is a valid tensor name.\n * @param name\n * @returns A Boolean indicating whether `name` is a valid tensor name.\n */\nexport function isValidTensorName(name: string): boolean {\n return name.match(tensorNameRegex) ? true : false;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Math utility functions.\n *\n * This file contains some frequently used math function that operates on\n * number[] or Float32Array and return a number. Many of these functions are\n * not-so-thick wrappers around TF.js Core functions. But they offer the\n * convenience of\n * 1) not having to convert the inputs into Tensors,\n * 2) not having to convert the returned Tensors to numbers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor1D, tensor1d} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\n\nexport type ArrayTypes = Uint8Array|Int32Array|Float32Array;\n\n/**\n * Determine if a number is an integer.\n */\nexport function isInteger(x: number): boolean {\n return x === parseInt(x.toString(), 10);\n}\n\n/**\n * Calculate the product of an array of numbers.\n * @param array The array to calculate the product over.\n * @param begin Beginning index, inclusive.\n * @param end Ending index, exclusive.\n * @return The product.\n */\nexport function arrayProd(\n array: number[]|ArrayTypes, begin?: number, end?: number): number {\n if (begin == null) {\n begin = 0;\n }\n if (end == null) {\n end = array.length;\n }\n\n let prod = 1;\n for (let i = begin; i < end; ++i) {\n prod *= array[i];\n }\n return prod;\n}\n\n/**\n * A helper function transforms the two input types to an instance of Tensor1D,\n * so the return value can be fed directly into various TF.js Core functions.\n * @param array\n */\nfunction toArray1D(array: number[]|Float32Array): Tensor1D {\n array = Array.isArray(array) ? new Float32Array(array) : array;\n return tensor1d(array);\n}\n\n/**\n * Compute minimum value.\n * @param array\n * @return minimum value.\n */\nexport function min(array: number[]|Float32Array): number {\n return tfc.min(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute maximum value.\n * @param array\n * @return maximum value\n */\nexport function max(array: number[]|Float32Array): number {\n return tfc.max(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute sum of array.\n * @param array\n * @return The sum.\n */\nexport function sum(array: number[]|Float32Array): number {\n return tfc.sum(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute mean of array.\n * @param array\n * @return The mean.\n */\nexport function mean(array: number[]|Float32Array): number {\n return sum(array) / array.length;\n}\n\n/**\n * Compute variance of array.\n * @param array\n * @return The variance.\n */\nexport function variance(array: number[]|Float32Array): number {\n const demeaned = tfc.sub(toArray1D(array), scalar(mean(array)));\n const sumSquare = tfc.sum(tfc.mulStrict(demeaned, demeaned)).dataSync()[0];\n return sumSquare / array.length;\n}\n\n/**\n * Compute median of array.\n * @param array\n * @return The median value.\n */\nexport function median(array: number[]|Float32Array): number {\n const arraySorted = array.slice().sort((a, b) => a - b);\n const lowIdx = Math.floor((arraySorted.length - 1) / 2);\n const highIdx = Math.ceil((arraySorted.length - 1) / 2);\n if (lowIdx === highIdx) {\n return arraySorted[lowIdx];\n }\n return (arraySorted[lowIdx] + arraySorted[highIdx]) / 2;\n}\n\n/**\n * Generate an array of integers in [begin, end).\n * @param begin Beginning integer, inclusive.\n * @param end Ending integer, inclusive.\n * @returns Range array.\n * @throws ValueError, iff `end` < `begin`.\n */\nexport function range(begin: number, end: number): number[] {\n if (end < begin) {\n throw new ValueError(`end (${end}) < begin (${begin}) is forbidden.`);\n }\n const out: number[] = [];\n for (let i = begin; i < end; ++i) {\n out.push(i);\n }\n return out;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * deeplearn.js backend.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {onesLike as coreOnesLike, Scalar, scalar, Tensor, Tensor1D, tensor1d, Tensor2D, Tensor3D, Tensor4D, tidy, util, where, zerosLike as coreZerosLike} from '@tensorflow/tfjs-core';\n\nimport {disposeScalarCache, getScalar} from '../backend/state';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {HasShape, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\n\nimport {imageDataFormat} from './common';\n\n// tslint:enable\n\n/* Setting and getting backend from deeplearn.js. */\n\n// Default deeplearn.js backend is WebGL (GPU).\nlet backend: 'cpu'|'webgl' = 'webgl';\n\nexport function setBackend(requestedBackend: 'cpu'|'webgl') {\n tfc.setBackend(requestedBackend);\n backend = requestedBackend;\n disposeScalarCache();\n}\n\nexport function getBackend(): 'cpu'|'webgl' {\n return backend;\n}\n\n/**\n * Indicates whether the backend is operating symbolically.\n *\n * This function will be used to determine how to interpret user code. If\n * it returns true, calls to the backend construct a symbolic graph; if\n * it returns false, calls to the backend execute immediately.\n */\nexport function isBackendSymbolic(): boolean {\n return false;\n}\n\n/**\n * Get the number of elements in a Tensor.\n * @param x The Tensor.\n * @return Number of elements in `x`.\n */\nexport function countParams(x: HasShape): number {\n const shape = x.shape;\n if (shape.length > 0) {\n return shape.reduce((a: number, b: number) => a * b);\n } else {\n // Scalar.\n return 1;\n }\n}\n\n/**\n * Casts a tensor to a different dtype and returns it.\n * @param x Input tensor.\n * @param dtype String: 'float32'|'int32'|'bool'.\n * @returns Tensor of the specified `dtype`.\n */\nexport function cast(x: Tensor, dtype: 'float32'|'int32'|'bool'): Tensor {\n return x.asType(dtype);\n}\n\n/**\n * Adds a 1-sized dimension at index \"axis\".\n * @param x Input tensor.\n * @param axis Position where to add the new axis.\n * @returns Result of the dimension expansion.\n */\nexport function expandDims(x: Tensor, axis = -1): Tensor {\n const outShape = x.shape.slice();\n if (axis < 0) {\n axis = outShape.length + axis + 1;\n }\n outShape.splice(axis, 0, 1);\n return x.reshape(outShape);\n}\n\n/**\n * Repeats a 2D tensor.\n *\n * If `x` has shape `[samples, dim]` and `n` is 2, for example, the output\n * will have shape `[samples, 2, dim]`.\n *\n * @param x Input tensor.\n * @param n Integer, number of times to repeat.\n * @returns The result of the repeat operation.\n * @throws ValueError: If input tensor is not 2D.\n */\nexport function repeat(x: Tensor, n: number): Tensor {\n return tidy(() => {\n if (x.shape.length !== 2) {\n throw new ValueError(\n `repeat() expects a rank-2 tensor, but received a ` +\n `rank-${x.shape.length} tensor.`);\n }\n const y = expandDims(x, 1);\n return tile(y, [1, n, 1]);\n });\n}\n\n/**\n * Flatten an Tensor into 1D.\n * @param x Input tensor.\n * @return The result of the flattening `x`.\n */\nexport function flatten(x: Tensor): Tensor {\n const newShape = [math_utils.arrayProd(x.shape)];\n return x.reshape(newShape);\n}\n\n/**\n * Turn a nD tensor into a 2D tensor with same 0th dimension.\n * In other words, it flattens each data samples of a batch.\n *\n * @param x The tensor to flatten. The rank of this tensor is required to be 2\n * or higher.\n * @return The result of the flattening.\n */\nexport function batchFlatten(x: Tensor): Tensor {\n if (x.rank <= 1) {\n throw new ValueError(\n `batchFlatten requires a minimum rank of 2. Got rank: ${x.rank}.`);\n }\n const newShape = [x.shape[0], math_utils.arrayProd(x.shape, 1)];\n return x.reshape(newShape);\n}\n\n/**\n * Do slicing along the first axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the first axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongFirstAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [start, 0], [size, array.shape[1]]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [start, 0, 0],\n [size, array.shape[1], array.shape[2]]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [start, 0, 0, 0],\n [size, array.shape[1], array.shape[2], array.shape[3]]);\n default:\n throw new ValueError(\n `sliceAlongFirstAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the last axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the last axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongLastAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [0, start], [array.shape[0], size]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [0, 0, start],\n [array.shape[0], array.shape[1], size]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, 0, start],\n [array.shape[0], array.shape[1], array.shape[2], size]);\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the sepcified axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size of the slice along the chosen axis.\n * @param choose an axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongAxis(\n array: Tensor, start: number, size: number, axis: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 3:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice3d(\n array as Tensor3D, [0, start, 0],\n [array.shape[0], size, array.shape[2]]);\n case 3:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 4:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice4d(\n array as Tensor4D, [0, start, 0, 0],\n [array.shape[0], size, array.shape[2], array.shape[3]]);\n case 3:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, start, 0],\n [array.shape[0], array.shape[1], size, array.shape[3]]);\n case 4:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Concatenates a list of tensors alongside the specified axis.\n * @param tensors `Array` of tensors to concatenate.\n * @param axis Concatenation axis.\n * @returns The result of the concatenation.\n */\nexport function concatenate(tensors: Tensor[], axis = -1): Tensor {\n let rank: number;\n if (axis < 0) {\n rank = tensors[0].rank;\n if (rank !== 0) {\n axis = rank;\n } else {\n axis = 0;\n }\n }\n if (axis === tensors[0].rank) {\n // Porting Note: This is necessary because tfc.concat() requires axis to be\n // in the interval [-rank, rank).\n axis = -1;\n }\n // Porting Note: Sparse concat is not supported yet.\n return tfc.concat(tensors, axis);\n}\n\n/**\n * Concatenate two arrays along the first dimension.\n * @param a The 1st `Tensor` to concatenate.\n * @param b The 2nd `Tensor` to concatenate.\n * @returns Result of the concatenation.\n * @throws ValueError: If `a` is of an unsupported subtype of `Tensor`.\n */\nexport function concatAlongFirstAxis(a: Tensor, b: Tensor): Tensor {\n switch (a.rank) {\n case 1:\n return tfc.concat1d([a as Tensor1D, b as Tensor1D]);\n case 2:\n return tfc.concat2d([a as Tensor2D, b as Tensor2D], 0);\n case 3:\n return tfc.concat3d([a as Tensor3D, b as Tensor3D], 0);\n case 4:\n return tfc.concat4d([a as Tensor4D, b as Tensor4D], 0);\n default:\n throw new ValueError(\n 'concatAlongFirstAxis() received an unsupported tensor rank: ' +\n a.rank);\n }\n}\n\n/**\n * Creates a tensor by tiling `x` by `n`.\n * @param x A tensor.\n * @param n An Array of integers or a single integer. If an Array, the length\n * must be the same as the number of dimensions in `x`. If a single integer,\n * it will be treated as an Array of length 1.\n */\nexport function tile(x: Tensor, n: number|number[]): Tensor {\n if (!Array.isArray(n)) {\n n = [n];\n }\n if (x.rank !== n.length) {\n throw new ValueError(\n `The length of input n (${n.length}) does not match ` +\n `the number of dimensions in input x (${x.rank})`);\n }\n return tfc.tile(x, n);\n}\n\n/* Creation of random tensors. */\n\n\n/**\n * Get a tensor with normal distribution of values.\n *\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @return The normal tensor.\n */\nexport function randomNormal(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n return tfc.randomNormal(shape, mean, stddev, dtype, seed);\n}\n\n/* Linear Algebra */\n\n/**\n * Multiply two tensors and returns the result as a tensor.\n *\n * For 2D tensors, this is equivalent to matrix multiplication (matMul).\n * For tensors of higher ranks, it follows the Theano behavior,\n * (e.g. `(2, 3) * (4, 3, 5) -> (2, 4, 5)`).\n *\n * @param x A tensor of at least rank 2.\n * @param y A tensor of at least rank 2.\n * @return Result of the dot operation.\n */\nexport function dot(x: Tensor, y: Tensor): Tensor {\n if (y.rank !== 2) {\n throw new NotImplementedError(\n `dot support for y other than rank 2 is not yet implemented: ` +\n `y shape = ${y.shape}`);\n } else {\n if (x.rank === 2) {\n return tfc.matMul(x as Tensor2D, y as Tensor2D);\n } else if (x.rank === 3) {\n const xShape0 = x.shape[0];\n const xShape1 = x.shape[1];\n const xShape2 = x.shape[2];\n x = x.reshape([xShape0 * xShape1, xShape2]);\n return tfc.matMul(x as Tensor2D, y as Tensor2D).reshape([\n xShape0, xShape1, y.shape[1]\n ]);\n } else {\n throw new NotImplementedError(\n `dot support for x of rank ${x.rank} is not yet implemented: ` +\n `x shape = ${x.shape}`);\n }\n }\n}\n\n/**\n * Compute the sign Tensor of an input Tensor.\n *\n * Elements of the input `Tensor` that are === 0 are mapped to 0.\n * Elements of the input `Tensor` that are > 0 are mapped to 1.\n * Elements of the input `Tensor` that are < 0 are mapped to -1.\n *\n * @param x Input `Tensor`.\n * @return The sign `Tensor`.\n */\nexport function sign(x: Tensor): Tensor {\n // TODO(cais): Move to the core.\n return tidy(() => {\n const zerosLikeX = coreZerosLike(x);\n const onesLikeX = coreOnesLike(x);\n return where(\n tfc.equal(x, zerosLikeX), zerosLikeX,\n where(\n tfc.greater(x, coreZerosLike(x)), onesLikeX,\n tfc.mul(getScalar(-1), onesLikeX)));\n });\n}\n\n/**\n * Computes the one-hot representation of an integer tensor.\n * @param indices nD integer tensor of shape\n * `(batch_size, dim1, dim2, ... dim(n-1))`\n * @param numClasses Integer, number of classes to consider.\n * @returns (n + 1)D one hot representation of the input\n * with shape `(batch_size, dim1, dim2, ... dim(n-1), num_classes)`\n */\nexport function oneHot(indices: Tensor, numClasses: number): Tensor {\n return tidy(() => {\n if (indices.rank !== 1) {\n throw new Error(\n 'Only 1D one-hot tensors are supported in the ' +\n 'deeplearn backend, at present.');\n }\n indices = indices.toInt();\n return tfc.oneHot(indices as Tensor1D, numClasses).toFloat();\n });\n}\n\n/* Elementary math functions. */\n\n/**\n * Retrieves the elements of indices `indices` in the tensor `reference`.\n * @param reference A tensor.\n * @param indices An integer tensor of indices or an `Array` of integers.\n * @param axis Axis along which to perform the gather operation.\n * @returns The result of the gathering as a tensor.\n */\nexport function gather(\n reference: Tensor, indices: number[]|Tensor1D, axis?: number): Tensor {\n return tidy(() => {\n if (Array.isArray(indices)) {\n indices = tensor1d(indices, 'int32');\n } else {\n indices = indices.toInt();\n }\n return tfc.gather(reference, indices, axis);\n });\n}\n\n/**\n * Element-wise square.\n * @param x Input tensor.\n * @return element-wise x^2\n */\nexport function square(x: Tensor): Tensor {\n return tfc.mulStrict(x, x);\n}\n\n/**\n * Element-wise exponentiation.\n *\n * Porting Note: In PyKeras, `a` (the exponent) is a Python integer, which\n * takes advatnage of the backend's (e.g., TensorFlow's) automatic conversion\n * to tensor. Here we allow `a` to be either a number or a tensor.\n *\n * @param x The base tensor.\n * @param a The exponent, tensor or number. If a number, it is rounded to the\n * nearest integer and converted to a tensor.\n * @returns A tensor of the same shape as `x`.\n */\nexport function pow(x: Tensor, a: Tensor|number): Tensor {\n return tidy(() => {\n if (typeof (a) === 'number') {\n a = scalar(Math.round(a), 'int32');\n }\n if (a.dtype !== 'int32') {\n throw new NotImplementedError(\n `Non-int32 dtype (${a.dtype}) is not supported by pow() yet`);\n }\n return tfc.pow(x, a as Tensor);\n });\n}\n\n/* Neural-network operations. */\n\n/**\n * Add a bias to a tensor.\n *\n * @param x The tensor to add the bias to.\n * @param bias The bias to add to `x`. Must be 1D or the same rank as `x`.\n * @return Result of the bias adding.\n * @throws ValueError: If the rank of `bias` is incorrect.\n */\nexport function biasAdd(\n x: Tensor, bias: Tensor, dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n\n if (bias.rank !== 1 && bias.rank !== x.rank) {\n throw new ValueError(\n 'Unexpected bias dimensions: ' + bias.rank +\n '; expected it to be 1 or ' + x.rank);\n }\n const biasShape = bias.shape;\n\n let y: Tensor;\n if (x.rank === 5) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1, 1]));\n } else {\n y = x.add(bias.reshape(\n [1, biasShape[3], biasShape[0], biasShape[1], biasShape[2]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 4) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1]));\n } else {\n y = x.add(\n bias.reshape([1, biasShape[2], biasShape[0], biasShape[1]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 3) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1]));\n } else {\n y = x.add(bias.reshape([1, biasShape[1], biasShape[0]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank < 3) {\n y = x.add(bias);\n } else {\n throw new ValueError(`Unsupported input rank by biasAdd: ${x.rank}`);\n }\n return y;\n });\n}\n\n/**\n * Exponential linear unit (ELU).\n * @param x A tensor or variable to compute the activation function for.\n * @param alpha: A scalar, a scaling factor for the negative section.\n * @return Output of the ELU operation.\n */\nexport function elu(x: Tensor, alpha = 1): Tensor {\n // TODO(cais): Add support for alpha values other than 1.\n if (alpha !== 1) {\n throw new NotImplementedError(\n `Support for alpha values other than 1 (${alpha}) is not implemented ` +\n `yet.`);\n }\n return tfc.elu(x);\n}\n\n/**\n * Softsign of a tensor.\n *\n * Defined as x / (abs(x) + 1), element-wise.\n *\n * @param x: Input.\n * @returns Output.\n */\nexport function softsign(x: Tensor): Tensor {\n return tidy(() => tfc.div(x, tfc.add(getScalar(1), tfc.abs(x))));\n}\n\n/**\n * Sets entries in `x` to zero at random, while scaling the entire tensor.\n *\n * @param x input tensor.\n * @param level fraction of the entries in the tensor that will be set to 0.\n * @param noiseShape shape of randomly generated keep/drop flags, must be\n * broadcastable to the shape of `x`.\n * @param seed random seed to ensure determinism.\n * @returns Result of the dropout operation.\n */\nexport function dropout(\n x: Tensor, level: Scalar, noiseShape?: number[], seed?: number): Tensor {\n return tidy(() => {\n // TODO(cais): Switch to deeplearn.js implementation of dropout when it\n // becomes avaialable.\n if (noiseShape != null && !util.arraysEqual(x.shape, noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented yet: ' +\n JSON.stringify(noiseShape));\n }\n if (seed != null) {\n throw new NotImplementedError('seed is not implemented for dropout yet.');\n }\n let multiplier = tfc.step(tfc.add(\n tfc.neg(level) as Scalar, tfc.randomUniform(x.shape, 0, 1, 'float32')));\n // Scale the kept elements, so the expected sum is unchanged.\n multiplier = tfc.mul(\n tfc.div(getScalar(1), tfc.sub(getScalar(1), level)) as Scalar,\n multiplier);\n return tfc.mul(x, multiplier);\n });\n}\n\n/**\n * Element-wise, segment-wise linear approximation of sigmoid.\n *\n * Returns `0.` if `x < -2.5`, `1.` if `x > 2.5`.\n * In `-2.5 <= x <= 2.5`, returns `0.2 * x + 0.5`.\n *\n * @param x Input tensor.\n * @returns Output tensor.\n */\nexport function hardSigmoid(x: Tensor): Tensor {\n return tidy(() => {\n const y = tfc.add(getScalar(0.5), tfc.mul(getScalar(0.2), x));\n return tfc.clipByValue(y, 0, 1);\n });\n}\n\n/**\n * Invoke `x` in the training phase, and `alt` otherwise.\n *\n * Porting Note: We do not create placeholder tensors for the `training` boolean\n * flag here, because there is no such thing in the TF.js imperative backend.\n *\n * @param x The function to invoke iff `training` is `true`.\n * @param alt The function to invoke iff `training` is `false`.\n * @param training Boolean flag for whether training phase is active.\n * @returns The return value of `x()` if `training` is `true`, or the return\n * value of `alt()` if `training` is `false`.\n */\nexport function inTrainPhase(x: () => T, alt: () => T, training = false): T {\n return training ? x() : alt();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// tslint:disable:max-line-length\nimport {DataType, eye, linalg, mul, ones, randomUniform, scalar, Scalar, serialization, Tensor, Tensor2D, tidy, truncatedNormal, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from './common';\nimport {NotImplementedError, ValueError} from './errors';\nimport {Shape} from './types';\nimport {checkStringTypeUnionValue, deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\nimport {arrayProd} from './utils/math_utils';\n\n// tslint:enable:max-line-length\n\n/** @docinline */\nexport type FanMode = 'fanIn'|'fanOut'|'fanAvg';\nexport const VALID_FAN_MODE_VALUES = ['fanIn', 'fanOut', 'fanAvg'];\nexport function checkFanMode(value?: string): void {\n checkStringTypeUnionValue(VALID_FAN_MODE_VALUES, 'FanMode', value);\n}\n\n/** @docinline */\nexport type Distribution = 'normal'|'uniform';\nexport const VALID_DISTRIBUTION_VALUES = ['normal', 'uniform'];\nexport function checkDistribution(value?: string): void {\n checkStringTypeUnionValue(VALID_DISTRIBUTION_VALUES, 'Distribution', value);\n}\n\n/**\n * Initializer base class.\n *\n * @doc {\n * heading: 'Initializers', subheading: 'Classes', namespace: 'initializers'}\n */\nexport abstract class Initializer extends serialization.Serializable {\n public fromConfigUsesCustomObjects(): boolean {\n return false;\n }\n /**\n * Generate an initial value.\n * @param shape\n * @param dtype\n * @return The init value.\n */\n abstract apply(shape: Shape, dtype?: DataType): Tensor;\n\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/**\n * Initializer that generates tensors initialized to 0.\n */\nexport class Zeros extends Initializer {\n static className = 'Zeros';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return zeros(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Zeros);\n\n/**\n * Initializer that generates tensors initialized to 1.\n */\nexport class Ones extends Initializer {\n static className = 'Ones';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return ones(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Ones);\n\nexport interface ConstantConfig {\n /** The value for each element in the variable. */\n value: number;\n}\n\n/**\n * Initializer that generates values initialized to some constant.\n */\nexport class Constant extends Initializer {\n static className = 'Constant';\n private value: number;\n constructor(config: ConstantConfig) {\n super();\n if (typeof config !== 'object') {\n throw new ValueError(\n `Expected argument of type ConstantConfig but got ${config}`);\n }\n if (config.value === undefined) {\n throw new ValueError(`config must have value set but got ${config}`);\n }\n this.value = config.value;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => mul(scalar(this.value), ones(shape, dtype)));\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n value: this.value,\n };\n }\n}\nserialization.SerializationMap.register(Constant);\n\nexport interface RandomUniformConfig {\n /** Lower bound of the range of random values to generate. */\n minval?: number;\n /** Upper bound of the range of random values to generate. */\n maxval?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a uniform\n * distribution.\n *\n * Values will be distributed uniformly between the configured minval and\n * maxval.\n */\nexport class RandomUniform extends Initializer {\n static className = 'RandomUniform';\n readonly DEFAULT_MINVAL = -0.05;\n readonly DEFAULT_MAXVAL = 0.05;\n private minval: number;\n private maxval: number;\n private seed: number;\n\n constructor(config: RandomUniformConfig) {\n super();\n this.minval = config.minval || this.DEFAULT_MINVAL;\n this.maxval = config.maxval || this.DEFAULT_MAXVAL;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return randomUniform(shape, this.minval, this.maxval, dtype);\n }\n\n getConfig(): serialization.ConfigDict {\n return {minval: this.minval, maxval: this.maxval, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomUniform);\n\nexport interface RandomNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a normal\n * distribution.\n */\nexport class RandomNormal extends Initializer {\n static className = 'RandomNormal';\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: RandomNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormal does not support dType bool.`);\n }\n return K.randomNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomNormal);\n\nexport interface TruncatedNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a truncated normal.\n * distribution.\n *\n * These values are similar to values from a `RandomNormal` except that values\n * more than two standard deviations from the mean are discarded and re-drawn.\n * This is the recommended initializer for neural network weights and filters.\n */\nexport class TruncatedNormal extends Initializer {\n static className = 'TruncatedNormal';\n\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: TruncatedNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `truncatedNormal does not support dType bool.`);\n }\n return truncatedNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(TruncatedNormal);\n\nexport interface IdentityConfig {\n /**\n * Multiplicative factor to apply to the identity matrix.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates the identity matrix.\n * Only use for square 2D matrices.\n */\nexport class Identity extends Initializer {\n static className = 'Identity';\n private gain: Scalar;\n constructor(config: IdentityConfig) {\n super();\n this.gain = config.gain != null ? scalar(config.gain) : getScalar(1.0);\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2 || shape[0] !== shape[1]) {\n throw new ValueError(\n 'Identity matrix initializer can only be used for' +\n ' 2D square matrices.');\n } else {\n return mul(this.gain, eye(shape[0]));\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {gain: this.gain.get()};\n }\n}\nserialization.SerializationMap.register(Identity);\n\n/**\n * Computes the number of input and output units for a weight shape.\n * @param shape Shape of weight.\n * @param dataFormat data format to use for convolution kernels.\n * Note that all kernels in Keras are standardized on the\n * CHANNEL_LAST ordering (even when inputs are set to CHANNEL_FIRST).\n * @return An length-2 array: fanIn, fanOut.\n */\nfunction computeFans(\n shape: Shape, dataFormat: DataFormat = 'channelsLast'): number[] {\n let fanIn: number;\n let fanOut: number;\n checkDataFormat(dataFormat);\n if (shape.length === 2) {\n fanIn = shape[0];\n fanOut = shape[1];\n } else if ([3, 4, 5].indexOf(shape.length) !== -1) {\n if (dataFormat === 'channelsFirst') {\n const receptiveFieldSize = arrayProd(shape, 2);\n fanIn = shape[1] * receptiveFieldSize;\n fanOut = shape[0] * receptiveFieldSize;\n } else if (dataFormat === 'channelsLast') {\n const receptiveFieldSize = arrayProd(shape, 0, shape.length - 2);\n fanIn = shape[shape.length - 2] * receptiveFieldSize;\n fanOut = shape[shape.length - 1] * receptiveFieldSize;\n }\n } else {\n const shapeProd = arrayProd(shape);\n fanIn = Math.sqrt(shapeProd);\n fanOut = Math.sqrt(shapeProd);\n }\n\n return [fanIn, fanOut];\n}\n\nexport interface VarianceScalingConfig {\n /** Scaling factor (positive float). */\n scale: number;\n\n /** Fanning mode for inputs and outputs. */\n mode: FanMode;\n\n /** Probabilistic distribution of the values. */\n distribution: Distribution;\n\n /** Random number generator seed. */\n seed?: number;\n}\n\n\n/**\n * Initializer capable of adapting its scale to the shape of weights.\n * With distribution=NORMAL, samples are drawn from a truncated normal\n * distribution centered on zero, with `stddev = sqrt(scale / n)` where n is:\n * - number of input units in the weight tensor, if mode = FAN_IN.\n * - number of output units, if mode = FAN_OUT.\n * - average of the numbers of input and output units, if mode = FAN_AVG.\n * With distribution=UNIFORM,\n * samples are drawn from a uniform distribution\n * within [-limit, limit], with `limit = sqrt(3 * scale / n)`.\n */\nexport class VarianceScaling extends Initializer {\n static className = 'VarianceScaling';\n private scale: number;\n private mode: FanMode;\n private distribution: Distribution;\n private seed: number;\n\n /**\n * Constructor of VarianceScaling.\n * @throws ValueError for invalid value in scale.\n */\n constructor(config: VarianceScalingConfig) {\n super();\n if (config.scale < 0.0) {\n throw new ValueError(\n `scale must be a positive float. Got: ${config.scale}`);\n }\n this.scale = config.scale == null ? 1.0 : config.scale;\n this.mode = config.mode;\n checkFanMode(this.mode);\n this.distribution = config.distribution;\n checkDistribution(this.distribution);\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n const fans = computeFans(shape);\n const fanIn = fans[0];\n const fanOut = fans[1];\n let scale = this.scale;\n if (this.mode === 'fanIn') {\n scale /= Math.max(1, fanIn);\n } else if (this.mode === 'fanOut') {\n scale /= Math.max(1, fanOut);\n } else {\n scale /= Math.max(1, (fanIn + fanOut) / 2);\n }\n\n if (this.distribution === 'normal') {\n const stddev = Math.sqrt(scale);\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `${this.getClassName()} does not support dType bool.`);\n }\n return truncatedNormal(shape, 0, stddev, dtype, this.seed);\n } else {\n const limit = Math.sqrt(3 * scale);\n return randomUniform(shape, -limit, limit, dtype);\n }\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n scale: this.scale,\n mode: this.mode,\n distribution: this.distribution,\n seed: this.seed\n };\n }\n}\nserialization.SerializationMap.register(VarianceScaling);\n\nexport interface SeedOnlyInitializerConfig {\n /** Random number generator seed. */\n seed?: number;\n}\n\n/**\n * Glorot uniform initializer, also called Xavier uniform initializer.\n * It draws samples from a uniform distribution within [-limit, limit]\n * where `limit` is `sqrt(6 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf.\n */\nexport class GlorotUniform extends VarianceScaling {\n /**\n * Constructor of GlorotUniform\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'uniform',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotUniform is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * Glorot normal initializer, also called Xavier normal initializer.\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor.\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf\n */\nexport class GlorotNormal extends VarianceScaling {\n /**\n * Constructor of GlorotNormal.\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * He normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * Reference:\n * He et al., http://arxiv.org/abs/1502.01852\n */\nexport class HeNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 2.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, HeNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * LeCun normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(1 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * References:\n * [Self-Normalizing Neural Networks](https://arxiv.org/abs/1706.02515)\n * [Efficient Backprop](http://yann.lecun.com/exdb/publis/pdf/lecun-98b.pdf)\n */\nexport class LeCunNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, LeCunNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\nexport interface OrthogonalConfig extends SeedOnlyInitializerConfig {\n /**\n * Multiplicative factor to apply to the orthogonal matrix. Defaults to 1.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates a random orthogonal matrix.\n *\n * Reference:\n * [Saxe et al., http://arxiv.org/abs/1312.6120](http://arxiv.org/abs/1312.6120)\n */\nexport class Orthogonal extends Initializer {\n static className = 'Orthogonal';\n readonly DEFAULT_GAIN = 1;\n protected readonly gain: number;\n protected readonly seed: number;\n\n constructor(config?: OrthogonalConfig) {\n super();\n this.gain = config.gain == null ? this.DEFAULT_GAIN : config.gain;\n this.seed = config.seed;\n\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Random seed is not implemented for Orthogonal Initializer yet.');\n }\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2) {\n throw new NotImplementedError(\n 'The Orthogonal Initializer does not support non-2D shapes yet.');\n }\n if (shape[0] * shape[1] > 2000) {\n console.warn(\n `Orthogonal initializer is being called on a matrix with more ` +\n `than 2000 (${shape[0] * shape[1]}) elements: ` +\n `Slowness may result.`);\n }\n\n // TODO(cais): Add seed support.\n const normalizedShape =\n shape[0] > shape[1] ? [shape[1], shape[0]] : shape;\n const a = K.randomNormal(normalizedShape, 0, 1, 'float32') as Tensor2D;\n let q = linalg.gramSchmidt(a) as Tensor2D;\n if (shape[0] > shape[1]) {\n q = q.transpose();\n }\n return mul(getScalar(this.gain), q);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n gain: this.gain,\n seed: this.seed,\n };\n }\n}\nserialization.SerializationMap.register(Orthogonal);\n\n/** @docinline */\nexport type InitializerIdentifier = 'constant'|'glorotNormal'|'glorotUniform'|\n 'heNormal'|'identity'|'leCunNormal'|'ones'|'orthogonal'|'randomNormal'|\n 'randomUniform'|'truncatedNormal'|'varianceScaling'|'zeros'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in InitializerIdentifier]: string} = {\n 'constant': 'Constant',\n 'glorotNormal': 'GlorotNormal',\n 'glorotUniform': 'GlorotUniform',\n 'heNormal': 'HeNormal',\n 'identity': 'Identity',\n 'leCunNormal': 'LeCunNormal',\n 'ones': 'Ones',\n 'orthogonal': 'Orthogonal',\n 'randomNormal': 'RandomNormal',\n 'randomUniform': 'RandomUniform',\n 'truncatedNormal': 'TruncatedNormal',\n 'varianceScaling': 'VarianceScaling',\n 'zeros': 'Zeros'\n };\n\nfunction deserializeInitializer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Initializer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'initializer');\n}\n\nexport function serializeInitializer(initializer: Initializer):\n serialization.ConfigDictValue {\n return serializeKerasObject(initializer);\n}\n\nexport function getInitializer(identifier: InitializerIdentifier|Initializer|\n serialization.ConfigDict): Initializer {\n if (typeof identifier === 'string') {\n const className = identifier in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n /* We have four 'helper' classes for common initializers that\n all get serialized as 'VarianceScaling' and shouldn't go through\n the deserializeInitializer pathway. */\n if (className === 'GlorotUniform') {\n return new GlorotUniform();\n } else if (className === 'GlorotNormal') {\n return new GlorotNormal();\n } else if (className === 'HeNormal') {\n return new HeNormal();\n } else if (className === 'LeCunNormal') {\n return new LeCunNormal();\n } else {\n const config = {className, config: {}};\n return deserializeInitializer(config);\n }\n } else if (identifier instanceof Initializer) {\n return identifier;\n } else {\n return deserializeInitializer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constant, ConstantConfig, GlorotNormal, GlorotUniform, HeNormal, Identity, IdentityConfig, Initializer, LeCunNormal, Ones, Orthogonal, OrthogonalConfig, RandomNormal, RandomNormalConfig, RandomUniform, RandomUniformConfig, SeedOnlyInitializerConfig, TruncatedNormal, TruncatedNormalConfig, VarianceScaling, VarianceScalingConfig, Zeros} from './initializers';\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Zeros'\n * }\n */\nexport function zeros(): Zeros {\n return new Zeros();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Ones'\n * }\n */\nexport function ones(): Initializer {\n return new Ones();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Constant',\n * configParamIndices: [0]\n * }\n */\nexport function constant(config: ConstantConfig): Initializer {\n return new Constant(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomUniform',\n * configParamIndices: [0]\n * }\n */\nexport function randomUniform(config: RandomUniformConfig): Initializer {\n return new RandomUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomNormal',\n * configParamIndices: [0]\n * }\n */\nexport function randomNormal(config: RandomNormalConfig): Initializer {\n return new RandomNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'TruncatedNormal',\n * configParamIndices: [0]\n * }\n */\nexport function truncatedNormal(config: TruncatedNormalConfig): Initializer {\n return new TruncatedNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Identity',\n * configParamIndices: [0]\n * }\n */\nexport function identity(config: IdentityConfig): Initializer {\n return new Identity(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'VarianceScaling',\n * configParamIndices: [0]\n * }\n */\nexport function varianceScaling(config: VarianceScalingConfig): Initializer {\n return new VarianceScaling(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotUniform',\n * configParamIndices: [0]\n * }\n */\nexport function glorotUniform(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotNormal',\n * configParamIndices: [0]\n * }\n */\nexport function glorotNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'HeNormal',\n * configParamIndices: [0]\n * }\n */\nexport function heNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new HeNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'LeCunNormal',\n * configParamIndices: [0]\n * }\n */\nexport function leCunNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new LeCunNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Orthogonal',\n * configParamIndices: [0]\n * }\n */\nexport function orthogonal(config: OrthogonalConfig): Initializer {\n return new Orthogonal(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: utils/generic_utils.py */\n\n// tslint:disable:max-line-length\nimport {Tensor} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\nimport {Shape} from '../types';\n// tslint:enable\n\n\n/**\n * Determine whether the input is an Array of Shapes.\n */\nexport function isArrayOfShapes(x: Shape|Shape[]): boolean {\n return Array.isArray(x) && Array.isArray(x[0]);\n}\n\n/**\n * Special case of normalizing shapes to lists.\n *\n * @param x A shape or list of shapes to normalize into a list of Shapes.\n * @return A list of Shapes.\n */\nexport function normalizeShapeList(x: Shape|Shape[]): Shape[] {\n if (x.length === 0) {\n return [];\n }\n if (!Array.isArray(x[0])) {\n return [x] as Shape[];\n }\n return x as Shape[];\n}\n\n/**\n * Helper function to obtain exactly one Tensor.\n * @param xs: A single `Tensor` or an `Array` of `Tensor`s.\n * @return A single `Tensor`. If `xs` is an `Array`, return the first one.\n * @throws ValueError: If `xs` is an `Array` and its length is not 1.\n */\nexport function getExactlyOneTensor(xs: Tensor|Tensor[]): Tensor {\n let x: Tensor;\n if (Array.isArray(xs)) {\n if (xs.length !== 1) {\n throw new ValueError(`Expected Tensor length to be 1; got ${xs.length}`);\n }\n x = xs[0];\n } else {\n x = xs as Tensor;\n }\n return x;\n}\n\n/**\n * Helper function to obtain exactly on instance of Shape.\n *\n * @param shapes Input single `Shape` or Array of `Shape`s.\n * @returns If input is a single `Shape`, return it unchanged. If the input is\n * an `Array` containing exactly one instance of `Shape`, return the instance.\n * Otherwise, throw a `ValueError`.\n * @throws ValueError: If input is an `Array` of `Shape`s, and its length is not\n * 1.\n */\nexport function getExactlyOneShape(shapes: Shape|Shape[]): Shape {\n if (Array.isArray(shapes) && Array.isArray(shapes[0])) {\n if (shapes.length === 1) {\n shapes = shapes as Shape[];\n return shapes[0];\n } else {\n throw new ValueError(`Expected exactly 1 Shape; got ${shapes.length}`);\n }\n } else {\n return shapes as Shape;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {LayerVariable} from '../variables';\n\n/**\n * Count the elements in an Array of LayerVariables.\n *\n * @param weights: The LayerVariables of which the constituent numbers are to\n * be counted.\n * @returns A count of the elements in all the LayerVariables\n */\nexport function countParamsInWeights(weights: LayerVariable[]): number {\n let count = 0;\n for (const weight of weights) {\n if (weight.shape.length === 0) {\n count += 1;\n } else {\n count += weight.shape.reduce((a, b) => a * b);\n }\n }\n return count;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, Tensor, variableGrads} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId} from './backend/state';\nimport {getScopedTensorName, getUniqueTensorName} from './common';\nimport {Constraint} from './constraints';\nimport {NotImplementedError} from './errors';\nimport {HasShape, Shape} from './types';\n\nconst DEFAULT_VARIABLE_NAME_PREFIX = 'Variable';\n\n/**\n * A `LayerVariable` is similar to a `Tensor` in that it has a dtype and shape,\n * but its value is mutable. The value is itself represented as a `Tensor`, and\n * can be read with the `read()` method and updated with the `write()` method.\n */\nexport class LayerVariable {\n readonly dtype: DataType;\n readonly shape: Shape;\n\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName: string;\n readonly trainable: boolean;\n\n protected readonly val: tfc.Variable;\n readonly constraint: Constraint;\n /**\n * Construct Variable from a Tensor.\n *\n * If not explicitly named, the Variable will be given a name with the\n * prefix 'Variable'. Variable names are unique. In the case of name\n * collision, suffixies '_' will be added to the name.\n *\n * @param val Initial value of the Variable.\n * @param name Name of the variable. If `null` or `undefined` is provided, it\n * will default a name with the prefix 'Variable'.\n * @param constraint Optional, projection function to be applied to the\n * variable after optimize updates\n * @throws ValueError if `name` is `null` or `undefined`.\n */\n constructor(\n val: Tensor, dtype: DataType = 'float32',\n name = DEFAULT_VARIABLE_NAME_PREFIX, trainable = true,\n constraint: Constraint = null) {\n this.dtype = dtype == null ? 'float32' : dtype;\n this.shape = val.shape;\n this.id = getNextUniqueTensorId();\n\n name = name == null ? DEFAULT_VARIABLE_NAME_PREFIX : name;\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n\n this.trainable = trainable;\n this.constraint = constraint;\n\n this.val = tfc.variable(val, this.trainable, this.name, this.dtype);\n }\n\n /**\n * Get a snapshot of the Variable's value.\n *\n * The returned value is a snapshot of the Variable's value at the time of\n * the invocation. Future mutations in the value of the tensor will only\n * be reflected by future calls to this method.\n */\n read(): Tensor {\n return this.val;\n }\n\n /**\n * Update the value of the Variable.\n *\n * @param newVal: The new value to update to. Must be consistent with the\n * dtype and shape of the Variable.\n * @return This Variable.\n */\n write(newVal: Tensor) {\n // TODO(cais): Once TF.js Core supports Tensor.dtype, check dtype match.\n checkShapesMatch(this.val, newVal);\n this.val.assign(newVal);\n if (this.constraint != null) {\n this.val.assign(this.constraint.apply(this.val));\n }\n return this;\n }\n}\n\nfunction checkShapesMatch(x: HasShape, y: HasShape): void {\n if (x.shape.toString() !== y.shape.toString()) {\n throw new Error(\n 'Shape mismatch: ' + JSON.stringify(x.shape) + ' vs. ' +\n JSON.stringify(y.shape));\n }\n}\n\n/**\n * Create a Variable.\n * @param x The initial value of the `Variable`.\n * @param dtype optional, the type of the variable.\n * @param name optional, the name of the variable, default provided by\n * Variable.\n * @param constraint optional, a constraint to be applied after every update.\n * @return The newly instantiated `Variable`.\n */\nexport function variable(\n x: Tensor, dtype?: DataType, name?: string,\n constraint?: Constraint): LayerVariable {\n return new LayerVariable(x, dtype, name, true, constraint);\n}\n\n/**\n * Instantiates an all-zeros Variable and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-zero Variable.\n */\nexport function zerosVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n return new LayerVariable(tfc.zeros(shape), dtype, name);\n}\n\n/**\n * Instantiates an all-zeros tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function zerosLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.zerosLike(x), dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-ones Variable.\n */\nexport function onesVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n const allocated = tfc.ones(shape);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function onesLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n const allocated = tfc.onesLike(x);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiate an identity matrix and returns it, as a Variable\n *\n * @param size Number of rows/columns.\n * @param dtype Data type of returned Variable.\n * @param name Name of returned Variable.\n * @return A Variable, an identity matrix.\n */\nexport function eyeVariable(\n size: number, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.eye(size), dtype, name);\n}\n\n/**\n * Get a Variable with uniform distribution of values.\n * @param shape Shape of the tensor.\n * @param minval Lower bound of the uniform distribution.\n * @param maxval Upper bound of the uniform distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The uniform-random Variable.\n */\nexport function randomUniformVariable(\n shape: Shape, minval: number, maxval: number, dtype?: DataType,\n seed?: number, name = 'randomUniform'): LayerVariable {\n return new LayerVariable(\n tfc.randomUniform(shape, minval, maxval, dtype), dtype, name);\n}\n\n/**\n * Get a Variable with truncated-normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function truncatedNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'truncatedNormal'): LayerVariable {\n // TODO(cais): Implement logic for dtype and seed once they are supported\n // by deeplearn.js.\n if (dtype === 'bool') {\n throw new NotImplementedError(`randomNormal does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.truncatedNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n/**\n * Get a Variable with normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function randomNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'randomNormal'): LayerVariable {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormalVariable does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.randomNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n\n/**\n * Update the value of a Variable.\n * @param x The Variable to be updated.\n * @param xNew The new value to update to.\n * @return The Variable updated.\n */\nexport function update(x: LayerVariable, xNew: Tensor): LayerVariable {\n return x.write(xNew);\n}\n\n/**\n * Update the value of a Variable by adding an increment.\n * @param x The Variable to be updated.\n * @param increment The incrment to add to `x`.\n * @return The Variable updated.\n */\nexport function updateAdd(x: LayerVariable, increment: Tensor): LayerVariable {\n return x.write(tfc.add(x.read(), increment));\n}\n\n/**\n * Update the value of a Variable by subtracting a decrement.\n * @param x The Variable to be updated.\n * @param decrement The decrement to subtract from `x`.\n * @return The Variable updated.\n */\nexport function updateSub(x: LayerVariable, decrement: Tensor): LayerVariable {\n return x.write(tfc.sub(x.read(), decrement));\n}\n\n/**\n * Get the values of an array of Variables.\n *\n * @param tensors An `Array` of `Variable`s to get the values of.\n * @return The values of the inputs, as an `Array` of `Tensor`s.\n */\nexport function batchGetValue(xs: LayerVariable[]): Tensor[] {\n return xs.map(x => x.read());\n}\n\n/**\n * Update the value of multiple Variables at once.\n *\n * @param variablesAndValues An `Array`, each element is of type\n * [Variable, Tensor]. The first item is the\n * `Variable` of which the value is to be updated. The second item\n * carries the new value.\n */\nexport function batchSetValue(\n variablesAndValues: Array<[LayerVariable, Tensor]>): void {\n variablesAndValues.map((variableAndValue) => {\n const variable: LayerVariable = variableAndValue[0];\n variable.write(variableAndValue[1]);\n });\n}\n\n/**\n * Returns the gradients of `variables` w.r.t. the return value of `lossFn`.\n * @param lossFn A function which returns a Scalar to be used as the function\n * value (i.e., numerator) for differentiation.\n * @param variables List of variables to be used as the independent variables\n * (i.e., denominator) for differentiation.\n * @returns An Array of gradients tensors.\n */\nexport function gradients(\n lossFn: () => tfc.Scalar, variables: LayerVariable[]): Tensor[] {\n // TODO(cais): The return type signature can be simplified if deeplearn makes\n // the corresponding type public.\n const variableList =\n variables.map(variable => variable.read() as tfc.Variable);\n const valudAndGrads = variableGrads(lossFn, variableList);\n return variables.map(variable => valudAndGrads.grads[variable.name]);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {DataType, Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId, getUid} from '../backend/state';\nimport {getScopedTensorName, getUniqueTensorName, nameScope} from '../common';\nimport {Constraint} from '../constraints';\nimport {AttributeError, NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {Initializer} from '../initializers';\nimport {Regularizer} from '../regularizers';\nimport {Kwargs, RegularizerFn, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as types_utils from '../utils/types_utils';\nimport * as variable_utils from '../utils/variable_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n// TODO(michaelterry): This is a stub until it's defined.\nexport type Op = (x: LayerVariable) => LayerVariable;\n\n/**\n * Constructor arguments for InputSpec.\n */\nexport interface InputSpecConfig {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n}\n\n/**\n * Specifies the ndim, dtype and shape of every input to a layer.\n *\n * Every layer should expose (if appropriate) an `inputSpec` attribute:\n * a list of instances of InputSpec (one per input tensor).\n *\n * A null entry in a shape is compatible with any dimension,\n * a null shape is compatible with any shape.\n */\nexport class InputSpec {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n\n constructor(config: InputSpecConfig) {\n this.dtype = config.dtype;\n this.shape = config.shape;\n /*\n TODO(michaelterry): Could throw error if ndim and shape are both defined\n (then backport).\n */\n if (config.shape != null) {\n this.ndim = config.shape.length;\n } else {\n this.ndim = config.ndim;\n }\n this.maxNDim = config.maxNDim;\n this.minNDim = config.minNDim;\n this.axes = config.axes || {};\n }\n}\n\n/**\n * `SymbolicTensor` is a placeholder for a Tensor without any concrete value.\n *\n * They are most often encountered when building a graph of `Layer`s for a\n * a `Model` and the input data's shape, but not values are known.\n */\n/** @doc {heading: 'Models', 'subheading': 'Classes'} */\nexport class SymbolicTensor {\n /* A unique ID for the tensor to be able to differentiate tensors. */\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName?: string;\n /**\n * Rank/dimensionality of the tensor.\n */\n readonly rank: number;\n /**\n * Replacement for _keras_history.\n */\n nodeIndex: number;\n /**\n * Replacement for _keras_history.\n */\n tensorIndex: number;\n\n /**\n *\n * @param dtype\n * @param shape\n * @param sourceLayer The Layer that produced this symbolic tensor.\n * @param inputs The inputs passed to sourceLayer's __call__() method.\n * @param nodeIndex\n * @param tensorIndex\n * @param callArgs The keyword arguments passed to the __call__() method.\n * @param name\n * @param outputTensorIndex The index of this tensor in the list of outputs\n * returned by apply().\n */\n constructor(\n readonly dtype: DataType, readonly shape: Shape,\n public sourceLayer: Layer, readonly inputs: SymbolicTensor[],\n readonly callArgs: Kwargs, name?: string,\n readonly outputTensorIndex?: number) {\n this.id = getNextUniqueTensorId();\n if (name != null) {\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n }\n this.rank = shape.length;\n }\n}\n\n/**\n * Constructor arguments for Node.\n */\nexport interface NodeConfig {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`.\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n}\n\nlet _nextNodeID = 0;\n\n/**\n * A `Node` describes the connectivity between two layers.\n *\n * Each time a layer is connected to some new input,\n * a node is added to `layer.inboundNodes`.\n *\n * Each time the output of a layer is used by another layer,\n * a node is added to `layer.outboundNodes`.\n *\n * `nodeIndices` and `tensorIndices` are basically fine-grained coordinates\n * describing the origin of the `inputTensors`, verifying the following:\n *\n * `inputTensors[i] ==\n * inboundLayers[i].inboundNodes[nodeIndices[i]].outputTensors[\n * tensorIndices[i]]`\n *\n * A node from layer A to layer B is added to:\n * A.outboundNodes\n * B.inboundNodes\n */\nexport class Node {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n\n readonly id: number;\n\n constructor(\n config: NodeConfig,\n // TODO(michaelterry): Define actual type for this.\n public callArgs?: Kwargs) {\n this.id = _nextNodeID++;\n /*\n Layer instance (NOT a list).\n this is the layer that takes a list of input tensors\n and turns them into a list of output tensors.\n the current node will be added to\n the inboundNodes of outboundLayer.\n */\n this.outboundLayer = config.outboundLayer;\n\n /*\n The following 3 properties describe where\n the input tensors come from: which layers,\n and for each layer, which node and which\n tensor output of each node.\n */\n\n // List of layer instances.\n this.inboundLayers = config.inboundLayers;\n // List of integers, 1:1 mapping with inboundLayers.\n this.nodeIndices = config.nodeIndices;\n // List of integers, 1:1 mapping with inboundLayers.\n this.tensorIndices = config.tensorIndices;\n\n /*\n Following 2 properties:\n tensor inputs and outputs of outboundLayer.\n */\n\n // List of tensors. 1:1 mapping with inboundLayers.\n this.inputTensors = config.inputTensors;\n // List of tensors, created by outboundLayer.call().\n this.outputTensors = config.outputTensors;\n\n /*\n Following 2 properties: input and output masks.\n List of tensors, 1:1 mapping with inputTensor.\n */\n this.inputMasks = config.inputMasks;\n // List of tensors, created by outboundLayer.computeMask().\n this.outputMasks = config.outputMasks;\n\n // Following 2 properties: input and output shapes.\n\n // List of shape tuples, shapes of inputTensors.\n this.inputShapes = config.inputShapes;\n // List of shape tuples, shapes of outputTensors.\n this.outputShapes = config.outputShapes;\n\n // Add nodes to all layers involved.\n for (const layer of config.inboundLayers) {\n if (layer != null) {\n layer.outboundNodes.push(this);\n }\n }\n config.outboundLayer.inboundNodes.push(this);\n }\n\n getConfig(): serialization.ConfigDict {\n const inboundNames: string[] = [];\n for (const layer of this.inboundLayers) {\n if (layer != null) {\n inboundNames.push(layer.name);\n } else {\n inboundNames.push(null);\n }\n }\n return {\n outboundLayer: this.outboundLayer ? this.outboundLayer.name : null,\n inboundLayers: inboundNames,\n nodeIndices: this.nodeIndices,\n tensorIndices: this.tensorIndices\n };\n }\n}\n\n/** Constructor arguments for Layer. */\nexport interface LayerConfig {\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n inputShape?: Shape;\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n batchInputShape?: Shape;\n /**\n * If `inputShape` is specified and `batchInputShape` is *not* specifiedd,\n * `batchSize` is used to construct the `batchInputShape`: `[batchSize,\n * ...inputShape]`\n */\n batchSize?: number;\n /**\n * The data-type for this layer. Defaults to 'float32'.\n * This argument is only applicable to input layers (the first layer of a\n * model).\n */\n dtype?: DataType;\n /** Name for this layer. */\n name?: string;\n /** Whether this layer is trainable. Defaults to true. */\n trainable?: boolean;\n /** Whether the weights of this layer are updatable by `fit`. */\n updatable?: boolean;\n /**\n * Initial weight values of the layer.\n */\n weights?: Tensor[];\n /** Legacy support. Do not use for new code. */\n inputDType?: DataType;\n}\n\n// If necessary, add `output` arguments to the CallHook function.\n// This is currently used for testing only, but may be used for debugger-related\n// purposes in the future.\nexport type CallHook = (inputs: Tensor|Tensor[], kwargs: Kwargs) => void;\n\nlet _nextLayerID = 0;\n\n/**\n * A layer is a grouping of operations and weights that can be composed to\n * create a `Model`.\n *\n * Layers are constructed by using the functions under the\n * [tf.layers](#Layers-Basic) namespace.\n */\n/** @doc {heading: 'Layers', subheading: 'Classes', namespace: 'layers'} */\nexport abstract class Layer extends serialization.Serializable {\n /** Name for this layer. Must be unique within a model. */\n name: string;\n /**\n * List of InputSpec class instances.\n *\n * Each entry describes one required input:\n * - ndim\n * - dtype\n * A layer with `n` input tensors must have an `inputSpec` of length `n`.\n */\n inputSpec: InputSpec[];\n supportsMasking: boolean;\n /** Whether the layer weights will be updated during training. */\n trainable: boolean;\n updatable: boolean;\n batchInputShape: Shape;\n dtype: DataType;\n initialWeights: Tensor[];\n\n inboundNodes: Node[];\n outboundNodes: Node[];\n\n activityRegularizer: Regularizer;\n\n protected _trainableWeights: LayerVariable[];\n private _nonTrainableWeights: LayerVariable[];\n private _losses: RegularizerFn[];\n // TODO(cais): _updates is currently unused.\n private _updates: Tensor[];\n private _built: boolean;\n private _callHook: CallHook = null;\n\n private _addedWeightNames: string[] = [];\n\n readonly id: number;\n\n // Porting Notes: PyKeras does not have this property in this base Layer\n // class. Instead lets Layer subclass set it dynamically and checks the\n // value with `hasattr`. In tfjs-layers, we let this be a member of this\n // base class.\n protected _stateful = false;\n\n constructor(config: LayerConfig) {\n super();\n this.id = _nextLayerID++;\n\n this.activityRegularizer = null;\n\n this.inputSpec = null;\n this.supportsMasking = false;\n\n // These properties will be set upon call of this.build()\n this._trainableWeights = [];\n this._nonTrainableWeights = [];\n this._losses = [];\n this._updates = [];\n this._built = false;\n\n /*\n These lists will be filled via successive calls\n to this.addInboundNode().\n */\n this.inboundNodes = [];\n this.outboundNodes = [];\n\n let name = config.name;\n if (!name) {\n const prefix = this.getClassName();\n name = generic_utils.toSnakeCase(prefix) + '_' + getUid(prefix);\n }\n this.name = name;\n\n this.trainable = config.trainable == null ? true : config.trainable;\n this.updatable = config.updatable == null ? true : config.updatable;\n\n if (config.inputShape != null || config.batchInputShape != null) {\n /*\n In this case we will later create an input layer\n to insert before the current layer\n */\n let batchInputShape: Shape;\n if (config.batchInputShape != null) {\n batchInputShape = config.batchInputShape;\n } else if (config.inputShape != null) {\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n batchInputShape = [batchSize].concat(config.inputShape);\n }\n this.batchInputShape = batchInputShape;\n\n // Set dtype.\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = config.inputDType;\n }\n if (dtype == null) {\n dtype = 'float32';\n }\n this.dtype = dtype;\n }\n\n if (config.weights != null) {\n this.initialWeights = config.weights;\n } else {\n this.initialWeights = null;\n }\n }\n\n /**\n * Converts a layer and its index to a unique (immutable type) name.\n * This function is used internally with `this.containerNodes`.\n * @param layer The layer.\n * @param nodeIndex The layer's position (e.g. via enumerate) in a list of\n * nodes.\n *\n * @returns The unique name.\n */\n protected static nodeKey(layer: Layer, nodeIndex: number) {\n return layer.name + '_ib-' + nodeIndex.toString();\n }\n\n /**\n * Returns this.inboundNode at index nodeIndex.\n *\n * Porting note: This is a replacement for _get_node_attribute_at_index()\n * @param nodeIndex\n * @param attrName The name of the attribute related to request for this node.\n */\n private getNodeAtIndex(nodeIndex: number, attrName: string): Node {\n if (this.inboundNodes.length === 0) {\n throw new RuntimeError(\n 'The layer has never been called ' +\n `and thus has no defined ${attrName}.`);\n }\n if (this.inboundNodes.length <= nodeIndex) {\n throw new ValueError(\n `Asked to get ${attrName} at node ${nodeIndex}, ` +\n `but the layer has only ${this.inboundNodes.length} inbound nodes.`);\n }\n return this.inboundNodes[nodeIndex];\n }\n\n /**\n * Retrieves the input tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple inputs).\n */\n getInputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple outputs).\n */\n getOutputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'output').outputTensors);\n }\n\n // Properties\n\n /**\n * Retrieves the input tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Input tensor or list of input tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get input(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer input\" ' +\n 'is ill-defined. ' +\n 'Use `getInputAt(nodeIndex)` instead.');\n } else if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' is not connected, no input to return.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Output tensor or list of output tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get output(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has no inbound nodes.');\n }\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer output\" ' +\n 'is ill-defined. ' +\n 'Use `getOutputAt(nodeIndex)` instead.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'output').outputTensors);\n }\n\n get losses(): RegularizerFn[] {\n return this._losses;\n }\n\n /**\n * Retrieves the Layer's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Layer.loss in PyKeras.\n // In PyKeras, Layer.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return this.losses.map(lossFn => lossFn());\n }\n\n get updates(): Tensor[] {\n return this._updates;\n }\n\n get built(): boolean {\n return this._built;\n }\n\n set built(built: boolean) {\n this._built = built;\n }\n\n get trainableWeights(): LayerVariable[] {\n if (this.trainable) {\n return this._trainableWeights;\n } else {\n return [];\n }\n }\n\n set trainableWeights(weights: LayerVariable[]) {\n this._trainableWeights = weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return this._trainableWeights.concat(this._nonTrainableWeights);\n } else {\n return this._nonTrainableWeights;\n }\n }\n\n set nonTrainableWeights(weights: LayerVariable[]) {\n this._nonTrainableWeights = weights;\n }\n\n /**\n * The concatenation of the lists trainableWeights and nonTrainableWeights\n * (in this order).\n */\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n get stateful(): boolean {\n return this._stateful;\n }\n\n /**\n * Checks compatibility between the layer and provided inputs.\n *\n * This checks that the tensor(s) `input`\n * verify the input assumptions of the layer\n * (if any). If not, exceptions are raised.\n *\n * @param inputs Input tensor or list of input tensors.\n *\n * @exception ValueError in case of mismatch between\n * the provided inputs and the expectations of the layer.\n */\n protected assertInputCompatibility(inputs: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): void {\n inputs = generic_utils.toList(inputs);\n if (this.inputSpec == null || this.inputSpec.length === 0) {\n return;\n }\n const inputSpec = generic_utils.toList(this.inputSpec);\n if (inputs.length !== inputSpec.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${inputSpec.length} inputs, ` +\n `but it received ${inputs.length} input tensors. ` +\n `Input received: ${inputs}`);\n }\n for (let inputIndex = 0; inputIndex < inputs.length; inputIndex++) {\n const x = inputs[inputIndex];\n const spec: InputSpec = inputSpec[inputIndex];\n if (spec == null) {\n continue;\n }\n\n // Check ndim.\n const ndim = x.rank;\n if (spec.ndim != null) {\n if (ndim !== spec.ndim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}: ` +\n `expected ndim=${spec.ndim}, found ndim=${ndim}`);\n }\n }\n if (spec.maxNDim != null) {\n if (ndim > spec.maxNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected max_ndim=${spec.maxNDim}, found ndim=${ndim}`);\n }\n }\n if (spec.minNDim != null) {\n if (ndim < spec.minNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected min_ndim=${spec.minNDim}, found ndim=${ndim}.`);\n }\n }\n\n // Check dtype.\n if (spec.dtype != null) {\n if (x.dtype !== spec.dtype) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name} ` +\n `: expected dtype=${spec.dtype}, found dtype=${x.dtype}.`);\n }\n }\n\n // Check specific shape axes.\n if (spec.axes) {\n const xShape = x.shape;\n for (const key in spec.axes) {\n const axis = Number(key);\n const value = spec.axes[key];\n // Perform Python-style slicing in case axis < 0;\n // TODO(cais): Use https://github.com/alvivi/typescript-underscore to\n // ensure type safety through Underscore calls.\n const xShapeAtAxis =\n axis >= 0 ? xShape[axis] : xShape[xShape.length + axis];\n if (value != null && [value, null].indexOf(xShapeAtAxis) === -1) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected axis ${axis} of input shape to ` +\n `have value ${value} but got shape ${xShape}.`);\n }\n }\n }\n\n // Check shape.\n if (spec.shape != null) {\n for (let i = 0; i < spec.shape.length; ++i) {\n const specDim = spec.shape[i];\n const dim = x.shape[i];\n if (specDim != null && dim != null) {\n if (specDim !== dim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected shape=${spec.shape}, ` +\n 'found shape=${xShape}.');\n }\n }\n }\n }\n }\n }\n\n /**\n * This is where the layer's logic lives.\n *\n * @param inputs Input tensor, or list/tuple of input tensors.\n * @param kwargs Additional keyword arguments.\n *\n * @return A tensor or list/tuple of tensors.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return inputs;\n }\n\n protected invokeCallHook(inputs: Tensor|Tensor[], kwargs: Kwargs) {\n if (this._callHook != null) {\n this._callHook(inputs, kwargs);\n }\n }\n\n /**\n * Set call hook.\n * This is currently used for testing only.\n * @param callHook\n */\n setCallHook(callHook: CallHook) {\n this._callHook = callHook;\n }\n\n /**\n * Clear call hook.\n * This is currently used for testing only.\n */\n clearCallHook() {\n this._callHook = null;\n }\n\n /**\n * Builds or executes a `Layer's logic.\n *\n * When called with `Tensor`(s), execute the `Layer`s computation and\n * return Tensor(s). For example:\n *\n * ```js\n * const denseLayer = tf.layers.dense({\n * units: 1,\n * kernelInitializer: 'zeros',\n * useBias: false\n * });\n *\n * // Invoke the layer's apply() method with a `Tensor` (with concrete\n * // numeric values).\n * const input = tf.ones([2, 2]);\n * const output = denseLayer.apply(input);\n *\n * // The output's value is expected to be [[0], [0]], due to the fact that\n * // the dense layer has a kernel initialized to all-zeros and does not have\n * // a bias.\n * output.print();\n * ```\n *\n * When called with `SymbolicTensor`(s), this will prepare the layer for\n * future execution. This entails internal book-keeping on shapes of\n * expected Tensors, wiring layers together, and initializing weights.\n *\n * Calling `apply` with `SymbolicTensor`s are typically used during the\n * building of non-`Sequential` models. For example:\n *\n * ```js\n * const flattenLayer = tf.layers.flatten();\n * const denseLayer = tf.layers.dense({units: 1});\n *\n * // Use tf.layers.input() to obtain a SymbolicTensor as input to apply().\n * const input = tf.input({shape: [2, 2]});\n * const output1 = flattenLayer.apply(input);\n *\n * // output1.shape is [null, 4]. The first dimension is the undetermined\n * // batch size. The second dimension comes from flattening the [2, 2]\n * // shape.\n * console.log(JSON.stringify(output1.shape));\n *\n * // The output SymbolicTensor of the flatten layer can be used to call\n * // the apply() of the dense layer:\n * const output2 = denseLayer.apply(output1);\n *\n * // output2.shape is [null, 1]. The first dimension is the undetermined\n * // batch size. The second dimension matches the number of units of the\n * // dense layer.\n * console.log(JSON.stringify(output2.shape));\n *\n * // The input and output and be used to construct a model that consists\n * // of the flatten and dense layers.\n * const model = tf.model({inputs: input, outputs: output2});\n * ```\n *\n * @param inputs a `Tensor` or `SymbolicTensor` or an Array of them.\n * @param kwargs Additional keyword arguments to be passed to `call()`.\n *\n * @return Output of the layer's `call` method.\n *\n * @exception ValueError error in case the layer is missing shape information\n * for its `build` call.\n */\n // Porting Note: This is a replacement for __call__() in Python.\n /** @doc {heading: 'Models', 'subheading': 'Classes'} */\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n kwargs = kwargs || {};\n\n // Ensure inputs are all the same type.\n const inputsList = generic_utils.toList(inputs);\n\n let allAreSymbolic = true;\n for (const input of inputsList) {\n if (!(input instanceof SymbolicTensor)) {\n allAreSymbolic = false;\n break;\n }\n }\n let noneAreSymbolic = true;\n for (const input of inputsList) {\n if (input instanceof SymbolicTensor) {\n noneAreSymbolic = false;\n break;\n }\n }\n\n if (allAreSymbolic === noneAreSymbolic) {\n throw new ValueError(\n 'Arguments to apply() must be all ' +\n 'SymbolicTensors or all Tensors');\n }\n\n // TODO(michaelterry): nameScope() may not be necessary.\n return nameScope(this.name, () => {\n // Handle laying building (weight creating, input spec locking).\n if (!this.built) {\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec specified in the layer constructor.\n */\n this.assertInputCompatibility(inputs);\n\n // Collect input shapes to build layer.\n const inputShapes: Shape[] = [];\n for (const xElem of generic_utils.toList(inputs)) {\n inputShapes.push(xElem.shape);\n }\n this.build(generic_utils.singletonOrArray(inputShapes));\n this.built = true;\n\n // Load weights that were specified at layer instantiation.\n if (this.initialWeights) {\n this.setWeights(this.initialWeights);\n }\n }\n\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec set at build time.\n */\n this.assertInputCompatibility(inputs);\n\n // Handle mask propagation.\n // TODO(michaelterry): Mask propagation not currently implemented.\n\n // Actually call the layer, collecting output(s), mask(s), and shape(s).\n if (noneAreSymbolic) {\n let output = this.call(inputs as Tensor | Tensor[], kwargs);\n // TODO(michaelterry): Compute the outputMask\n\n // If the layer returns tensors from its inputs, unmodified,\n // we copy them to avoid loss of tensor metadata.\n const outputList: Tensor[] = generic_utils.toList(output);\n const outputListCopy: Tensor[] = [];\n // TODO(michaelterry): This copying may not be necessary given our eager\n // backend.\n for (let x of outputList) {\n if (inputsList.indexOf(x) !== -1) {\n x = x.clone();\n }\n outputListCopy.push(x);\n }\n output = generic_utils.singletonOrArray(outputListCopy);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n // TODO(michaelterry): Call addInboundNode()?\n return output;\n } else {\n const inputShape = collectInputShape(inputs);\n const outputShape = this.computeOutputShape(inputShape);\n let output: SymbolicTensor|SymbolicTensor[];\n const outputDType = guessOutputDType(inputs);\n this.warnOnIncompatibleInputShape(\n Array.isArray(inputs) ? inputShape[0] as Shape :\n inputShape as Shape);\n\n if (outputShape != null && outputShape.length > 0 &&\n Array.isArray(outputShape[0])) {\n // We have multiple output shapes. Create multiple output tensors.\n output = (outputShape as Shape[])\n .map(\n (shape, index) => new SymbolicTensor(\n outputDType, shape, this,\n generic_utils.toList(inputs), kwargs, this.name,\n index));\n } else {\n output = new SymbolicTensor(\n outputDType, outputShape as Shape, this,\n generic_utils.toList(inputs), kwargs, this.name);\n }\n\n /*\n Add an inbound node to the layer, so that it keeps track\n of the call and of all new variables created during the call.\n This also updates the layer history of the output tensor(s).\n If the input tensor(s) had no previous history,\n this does nothing.\n */\n this.addInboundNode(\n inputs as SymbolicTensor | SymbolicTensor[], output, null, null,\n inputShape, outputShape, kwargs);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n return output;\n }\n });\n }\n\n /**\n * Check compatibility between input shape and this layer's batchInputShape.\n *\n * Print warning if any incompatibility is found.\n *\n * @param inputShape Input shape to be checked.\n */\n protected warnOnIncompatibleInputShape(inputShape: Shape) {\n if (this.batchInputShape == null) {\n return;\n } else if (inputShape.length !== this.batchInputShape.length) {\n console.warn(\n `The rank of the input tensor provided (shape: ` +\n `${JSON.stringify(inputShape)}) does not match that of the ` +\n `batchInputShape (${JSON.stringify(this.batchInputShape)}) ` +\n `of the layer ${this.name}`);\n } else {\n let dimMismatch = false;\n this.batchInputShape.forEach((dimension, i) => {\n if (dimension != null && inputShape[i] != null &&\n inputShape[i] !== dimension) {\n dimMismatch = true;\n }\n });\n if (dimMismatch) {\n console.warn(\n `The shape of the input tensor ` +\n `(${JSON.stringify(inputShape)}) does not ` +\n `match the expectation of layer ${this.name}: ` +\n `${JSON.stringify(this.batchInputShape)}`);\n }\n }\n }\n\n /**\n * Retrieves the output shape(s) of a layer.\n *\n * Only applicable if the layer has only one inbound node, or if all inbound\n * nodes have the same output shape.\n *\n * @returns Output shape or shapes.\n * @throws AttributeError: if the layer is connected to more than one incoming\n * nodes.\n */\n get outputShape(): Shape|Shape[] {\n if (this.inboundNodes == null || this.inboundNodes.length === 0) {\n throw new AttributeError(\n `The layer ${this.name} has never been called and thus has no ` +\n `defined output shape.`);\n }\n const allOutputShapes: string[] = [];\n for (const node of this.inboundNodes) {\n const shapeString = JSON.stringify(node.outputShapes);\n if (allOutputShapes.indexOf(shapeString) === -1) {\n allOutputShapes.push(shapeString);\n }\n }\n if (allOutputShapes.length === 1) {\n const outputShapes = this.inboundNodes[0].outputShapes;\n if (Array.isArray(outputShapes) && Array.isArray(outputShapes[0]) &&\n outputShapes.length === 1) {\n return (outputShapes as Shape[])[0];\n } else {\n return outputShapes;\n }\n\n } else {\n throw new AttributeError(\n `The layer ${this.name} has multiple inbound nodes with different ` +\n `output shapes. Hence the notion of \"outut shape\" is ill-defined ` +\n `for the layer.`);\n // TODO(cais): Implement getOutputShapeAt().\n }\n }\n\n /**\n * Counts the total number of numbers (e.g., float32, int32) in the\n * weights.\n *\n * @returns An integer count.\n * @throws RuntimeError: If the layer is not built yet (in which case its\n * weights are not defined yet.)\n */\n countParams(): number {\n if (!this.built) {\n throw new RuntimeError(\n `You tried to call countParams() on ${this.name}, ` +\n `but the layer is not built yet. Build it first by calling ` +\n `build(batchInputShape).`);\n }\n return variable_utils.countParamsInWeights(this.weights);\n }\n\n /**\n * Creates the layer weights.\n *\n * Must be implemented on all layers that have weights.\n *\n * Called when apply() is called to construct the weights.\n *\n * @param inputShape A `Shape` or array of `Shape` (unused).\n */\n build(inputShape: Shape|Shape[]) {\n this.built = true;\n }\n\n /**\n * Returns the current values of the weights of the layer.\n *\n * @param trainableOnly Whether to get the values of only trainable weights.\n * @returns Weight values as an `Array` of `Tensor`s.\n */\n getWeights(trainableOnly = false): Tensor[] {\n return batchGetValue(trainableOnly ? this.trainableWeights : this.weights);\n }\n\n /**\n * Sets the weights of the layer, from Tensors.\n *\n * @param weights a list of Tensors. The number of arrays and their shape\n * must match number of the dimensions of the weights of the layer (i.e.\n * it should match the output of `getWeights`).\n *\n * @exception ValueError If the provided weights list does not match the\n * layer's specifications.\n */\n setWeights(weights: Tensor[]): void {\n tidy(() => {\n const params = this.weights;\n if (params.length !== weights.length) {\n // TODO(cais): Restore the following and use `providedWeights`, instead\n // of `weights` in the error message, once the deeplearn.js bug is\n // fixed: https://github.com/PAIR-code/deeplearnjs/issues/498 const\n // providedWeights = JSON.stringify(weights).substr(0, 50);\n throw new ValueError(\n `You called setWeights(weights) on layer \"${this.name}\" ` +\n `with a weight list of length ${weights.length}, ` +\n `but the layer was expecting ${params.length} weights. ` +\n `Provided weights: ${weights}...`);\n }\n if (params.length === 0) {\n return;\n }\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n const paramValues = batchGetValue(params);\n for (let i = 0; i < paramValues.length; ++i) {\n const pv = paramValues[i];\n const p = params[i];\n const w = weights[i];\n if (!util.arraysEqual(pv.shape, w.shape)) {\n throw new ValueError(\n `Layer weight shape ${pv.shape} ` +\n `not compatible with provided weight shape ${w.shape}`);\n }\n weightValueTuples.push([p, w]);\n }\n batchSetValue(weightValueTuples);\n });\n }\n\n /**\n * Adds a weight variable to the layer.\n *\n * @param name Name of the new weight variable.\n * @param shape The shape of the weight.\n * @param dtype The dtype of the weight.\n * @param initializer An initializer instance.\n * @param regularizer A regularizer instance.\n * @param trainable Whether the weight should be trained via backprop or not\n * (assuming that the layer itself is also trainable).\n * @param constraint An optional trainable.\n * @return The created weight variable.\n */\n protected addWeight(\n name: string, shape: Shape, dtype?: DataType, initializer?: Initializer,\n regularizer?: Regularizer, trainable?: boolean,\n constraint?: Constraint): LayerVariable {\n // Reject duplicate weight names.\n if (this._addedWeightNames.indexOf(name) !== -1) {\n throw new ValueError(\n `Duplicate weight name ${name} for layer ${this.name}`);\n }\n this._addedWeightNames.push(name);\n\n if (dtype == null) {\n dtype = 'float32';\n }\n const weight = new LayerVariable(\n initializer.apply(shape, dtype), dtype, name, trainable, constraint);\n // Request backend not to dispose the weights of the model on scope() exit.\n if (regularizer != null) {\n this.addLoss(() => regularizer.apply(weight.read()));\n }\n if (trainable == null) {\n trainable = true;\n }\n if (trainable) {\n this._trainableWeights.push(weight);\n } else {\n this._nonTrainableWeights.push(weight);\n }\n return weight;\n }\n\n /**\n * Add losses to the layer.\n *\n * The loss may potentionally be conditional on some inputs tensors,\n * for instance activity losses are conditional on the layer's inputs.\n */\n addLoss(losses: RegularizerFn|RegularizerFn[]): void {\n if (losses == null || Array.isArray(losses) && losses.length === 0) {\n return;\n }\n // Update this.losses\n losses = generic_utils.toList(losses);\n if (this._losses !== undefined && this._losses !== null) {\n this.losses.push(...losses);\n }\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n if (!this.supportsMasking) {\n if (mask != null) {\n if (Array.isArray(mask)) {\n mask.forEach(maskElement => {\n if (maskElement != null) {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n });\n } else {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n }\n // masking not explicitly supported: return null as mask\n return null;\n }\n // if masking is explictly supported, by default\n // carry over the input mask\n return mask;\n }\n\n /**\n * Internal method to create an inbound node for the layer.\n *\n * @param inputTensors List of input tensors.\n * @param outputTensors List of output tensors.\n * @param inputMasks List of input masks (a mask can be a tensor, or null).\n * @param outputMasks List of output masks (a mask can be a tensor, or null).\n * @param inputShapes List of input shape tuples.\n * @param outputShapes List of output shape tuples.\n * @param kwargs Dictionary of keyword arguments that were passed to the\n * `call` method of the layer at the call that created the node.\n */\n private addInboundNode(\n inputTensors: SymbolicTensor|SymbolicTensor[],\n outputTensors: SymbolicTensor|SymbolicTensor[],\n inputMasks: Tensor|Tensor[], outputMasks: Tensor|Tensor[],\n inputShapes: Shape|Shape[], outputShapes: Shape|Shape[],\n kwargs: {} = null): void {\n const inputTensorList: SymbolicTensor[] =\n generic_utils.toList(inputTensors);\n outputTensors = generic_utils.toList(outputTensors);\n inputMasks = generic_utils.toList(inputMasks);\n outputMasks = generic_utils.toList(outputMasks);\n inputShapes = types_utils.normalizeShapeList(inputShapes);\n outputShapes = types_utils.normalizeShapeList(outputShapes);\n\n // Collect input tensor(s) coordinates.\n const inboundLayers: Layer[] = [];\n const nodeIndices: number[] = [];\n const tensorIndices: number[] = [];\n for (const x of inputTensorList) {\n /*\n * TODO(michaelterry): Keras adds this value to tensors; it's not\n * clear whether we'll use this or not.\n */\n inboundLayers.push(x.sourceLayer as Layer);\n nodeIndices.push(x.nodeIndex);\n tensorIndices.push(x.tensorIndex);\n }\n\n // Create node, add it to inbound nodes.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node(\n {\n outboundLayer: this,\n inboundLayers,\n nodeIndices,\n tensorIndices,\n inputTensors: inputTensorList,\n outputTensors,\n inputMasks,\n outputMasks,\n inputShapes,\n outputShapes\n },\n kwargs);\n\n // Update tensor history\n for (let i = 0; i < outputTensors.length; i++) {\n // TODO(michaelterry: _uses_learning_phase not tracked.\n outputTensors[i].sourceLayer = this;\n outputTensors[i].nodeIndex = this.inboundNodes.length - 1;\n outputTensors[i].tensorIndex = i;\n }\n }\n\n /**\n * Returns the config of the layer.\n *\n * A layer config is a TS dictionary (serializable)\n * containing the configuration of a layer.\n * The same layer can be reinstantiated later\n * (without its trained weights) from this configuration.\n *\n * The config of a layer does not include connectivity\n * information, nor the layer class name. These are handled\n * by 'Container' (one layer of abstraction above).\n *\n * Porting Note: The TS dictionary follows TS naming standrds for\n * keys, and uses tfjs-layers type-safe Enums. Serialization methods\n * should use a helper function to convert to the pythonic storage\n * standard. (see serialization_utils.convertTsToPythonic)\n *\n * @returns TS dictionary of configuration.\n */\n getConfig(): serialization.ConfigDict {\n const config:\n serialization.ConfigDict = {name: this.name, trainable: this.trainable};\n if (this.batchInputShape != null) {\n config['batchInputShape'] = this.batchInputShape;\n }\n if (this.dtype != null) {\n config['dtype'] = this.dtype;\n }\n return config;\n }\n}\n\n/**\n * Collects the input shape(s) of a list of `Tensor`s or `SymbolicTensor`s.\n *\n * TODO(michaelterry): Update PyKeras docs (backport).\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return List of shape tuples (or single tuple), one tuple per input.\n */\nfunction collectInputShape(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): Shape|Shape[] {\n inputTensors =\n generic_utils.toList(inputTensors) as SymbolicTensor[] | Tensor[];\n const shapes: Shape[] = [];\n for (const x of inputTensors) {\n shapes.push(x.shape);\n }\n return generic_utils.singletonOrArray(shapes);\n}\n\n/**\n * Guesses output dtype based on inputs.\n *\n * At present, just returns 'float32' for any input.\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return The guessed DType. At present, always returns 'float32'.\n */\nfunction guessOutputDType(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): DataType {\n return 'float32';\n}\n\n/**\n * Returns the list of input tensors necessary to compute `tensor`.\n *\n * Output will always be a list of tensors (potentially with 1 element).\n *\n * @param tensor The tensor to start from.\n * @param layer Origin layer of the tensor.\n * @param nodeIndex Origin node index of the tensor.\n *\n * @return Array of input tensors.\n */\nexport function getSourceInputs(\n tensor: SymbolicTensor, layer?: Layer,\n nodeIndex?: number): SymbolicTensor[] {\n if (layer == null || (nodeIndex != null && nodeIndex > 0)) {\n layer = tensor.sourceLayer;\n nodeIndex = tensor.nodeIndex;\n }\n if (layer.inboundNodes.length === 0) {\n return [tensor];\n } else {\n const node = layer.inboundNodes[nodeIndex];\n if (node.inboundLayers.length === 0) {\n return node.inputTensors;\n } else {\n const sourceTensors: SymbolicTensor[] = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const previousSources = getSourceInputs(x, layer, nodeIndex);\n // Avoid input redundancy.\n for (const x of previousSources) {\n if (sourceTensors.indexOf(x) === -1) {\n sourceTensors.push(x);\n }\n }\n }\n return sourceTensors;\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {DataType, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\n\nimport {Layer, Node, SymbolicTensor} from './topology';\n\n/**\n * Constructor arguments for InputLayer.\n *\n * Note: You should provide only inputShape or batchInputShape (not both).\n * If only inputShape is provided, then the batchInputShape is determined by\n * the batchSize argument and the inputShape: [batchSize].concat(inputShape).\n */\nexport interface InputLayerConfig {\n /** Input shape, not including the batch axis. */\n inputShape?: Shape;\n /** Optional input batch size (integer or null). */\n batchSize?: number;\n /** Batch input shape, including the batch axis. */\n batchInputShape?: Shape;\n /** Datatype of the input. */\n dtype?: DataType;\n /**\n * Whether the placeholder created is meant to be sparse.\n */\n sparse?: boolean; // TODO(michaelterry): Not clear whether we'll need this.\n\n /** Name of the layer. */\n name?: string;\n}\n\n/**\n * An input layer is an entry point into a `Model`.\n *\n * `InputLayer` is generated automatically for `Sequential` models by specifying\n * the `inputshape` or `batchInputShape` for the first layer. It should not be\n * specified explicitly.\n *\n * ```js\n * // Define a model which simply adds two inputs.\n * const inputA = tf.input({shape: [3]});\n * const inputB = tf.input({shape: [3]});\n * const sum = tf.layers.add().apply([inputA, inputB]);\n * const model = tf.model({inputs: [inputA, inputB], outputs: sum});\n * const batchSize = 2;\n * model.predict([tf.ones([batchSize, 3]), tf.ones([batchSize, 3])]).print();\n * ```\n */\nexport class InputLayer extends Layer {\n static readonly className = 'InputLayer';\n sparse: boolean;\n constructor(config: InputLayerConfig) {\n super({\n dtype: config.dtype,\n name: config.name != null ? config.name : getUid('input').toString()\n });\n // Normalize config.batchSize and config.sparse\n if (config.batchSize == null) {\n config.batchSize = null;\n }\n if (config.sparse == null) {\n config.sparse = false;\n }\n\n this.trainable = false;\n this.built = true;\n this.sparse = config.sparse;\n\n if (config.inputShape != null && config.batchInputShape != null) {\n throw new ValueError(\n 'Only provide the inputShape OR ' +\n 'batchInputShape argument to inputLayer, not both at the same time.');\n }\n let batchInputShape = config.batchInputShape;\n if (batchInputShape == null) {\n if (config.inputShape == null) {\n throw new ValueError(\n 'An InputLayer should be passed either a ' +\n '`batchInputShape` or an `inputShape`.');\n } else {\n batchInputShape = [config.batchSize].concat(config.inputShape);\n }\n } else {\n // TODO(michaelterry): Backport to PyKeras\n if (config.batchSize != null) {\n throw new ValueError(\n 'Cannot specify batchSize if batchInputShape is' +\n 'specified when creating an InputLayer.');\n }\n }\n\n const dtype = config.dtype || 'float32';\n\n this.batchInputShape = batchInputShape;\n this.dtype = dtype;\n // TODO(michaelterry): Backport this to PyKeras?\n this.inputSpec = [{shape: batchInputShape}];\n\n const inputTensor = new SymbolicTensor(\n this.dtype, this.batchInputShape, this, [], {}, this.name);\n inputTensor.nodeIndex = 0;\n inputTensor.tensorIndex = 0;\n\n // Create an input node to add to this.outboundNode.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: [inputTensor],\n outputTensors: [inputTensor],\n inputMasks: [null],\n outputMasks: [null],\n inputShapes: [batchInputShape],\n outputShapes: [batchInputShape]\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor {\n throw new ValueError(\n 'Cannot pass any input to an ' +\n `InputLayer's apply() method. InputLayer name: ${this.name}`);\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n batchInputShape: this.batchInputShape,\n dtype: this.dtype,\n sparse: this.sparse,\n name: this.name\n };\n }\n}\nserialization.SerializationMap.register(InputLayer);\n\n/**\n * Config for the Input function.\n *\n * Note: You should provide only shape or batchShape (not both).\n * If only shape is provided, then the batchShape becomes\n * [null].concat(inputShape).\n */\nexport interface InputConfig {\n /**\n * A shape, not including the batch size. For instance, `shape=[32]`\n * indicates that the expected input will be batches of 32-dimensional\n * vectors.\n */\n shape?: Shape;\n /**\n * A shape tuple (integer), including the batch size. For instance,\n * `batchShape=[10, 32]` indicates that the expected input will be batches of\n * 10 32-dimensional vectors. `batchShape=[null, 32]` indicates batches of an\n * arbitrary number of 32-dimensional vectors.\n */\n batchShape?: Shape;\n /**\n * An optional name string for the layer. Should be unique in a model (do not\n * reuse the same name twice). It will be autogenerated if it isn't provided.\n */\n name?: string;\n dtype?: DataType;\n /**\n * A boolean specifying whether the placeholder to be created is sparse.\n */\n sparse?: boolean;\n}\n\n/**\n * Used to instantiate an input to a model as a `SymbolicTensor`.\n *\n * Users should call the `input` factory function for\n * consistency with other generator functions.\n *\n * Example:\n *\n * ```js\n * // Defines a simple logistic regression model with 32 dimensional input\n * // and 3 dimensional output.\n * const x = tf.input({shape: [32]});\n * const y = tf.layers.dense({units: 3, activation: 'softmax'}).apply(x);\n * const model = tf.model({inputs: x, outputs: y});\n * model.predict(tf.ones([2, 32])).print();\n * ```\n *\n * Note: `input` is only necessary when using `model`. When using\n * `sequential`, specify `inputShape` for the first layer or use `inputLayer`\n * as the first layer.\n */\nexport function Input(config: InputConfig): SymbolicTensor {\n if (config.batchShape == null && config.shape == null) {\n throw new Error(\n 'Please provide to Input either a `shape`' +\n ' or a `batchShape` argument. Note that ' +\n '`shape` does not include the batch ' +\n 'dimension.');\n }\n if (config.batchShape != null && config.shape != null) {\n // TODO(michaelterry): Backport to PyKeras.\n throw new ValueError(\n 'Please provide either a `shape` or `batchShape` ' +\n 'argument to Input, but not both.');\n }\n let batchShape = config.batchShape;\n if (config.shape != null && batchShape == null) {\n batchShape = [null].concat(config.shape);\n }\n\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = 'float32';\n }\n\n const inputLayer = new InputLayer({\n batchInputShape: batchShape,\n name: config.name,\n dtype,\n sparse: config.sparse\n });\n\n const outputs = inputLayer.inboundNodes[0].outputTensors;\n return outputs[0];\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {dispose, Scalar} from '@tensorflow/tfjs-core';\n\n/**\n * Logs in which values can be either numbers or Tensors (Scalars).\n *\n * Used internally.\n */\nexport type UnresolvedLogs = {\n [key: string]: number|Scalar;\n};\n\n/**\n * Turn any Scalar values in a Logs object into actual number values.\n *\n * @param logs The `Logs` object to be resolved in place.\n */\nexport async function resolveScalarsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n const promises: Array> = [];\n const keys: string[] = [];\n const scalarsToDispose: Scalar[] = [];\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n const valueScalar = value as Scalar;\n promises.push(valueScalar.data());\n keys.push(key);\n scalarsToDispose.push(valueScalar);\n }\n }\n const values = await Promise.all(promises);\n for (let i = 0; i < values.length; ++i) {\n logs[keys[i]] = values[i][0];\n }\n\n // Dispose the original scalar tensors.\n dispose(scalarsToDispose);\n}\n\n/**\n * Dispose all Tensors in an UnresolvedLogs object.\n *\n * @param logs An `UnresolvedLogs` object potentially containing `Tensor`s in\n * places where the values can be `Tensor` or `number`.\n */\nexport function disposeTensorsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n value.dispose();\n }\n }\n}\n\n/**\n * Logs in which values can only be numbers.\n *\n * Used when calling client-provided custom callbacks.\n */\nexport type Logs = {\n [key: string]: number;\n};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {add, div, keep, mul, Scalar, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport {Container} from './engine/container';\nimport {Logs, resolveScalarsInLogs, UnresolvedLogs} from './logs';\nimport * as generic_utils from './utils/generic_utils';\n\n\nexport type Params = {\n [key: string]: number|string|boolean|number[]|string[]|boolean[];\n};\n\n/**\n * Abstract base class used to build new callbacks.\n *\n * The `logs` dictionary that callback methods take as argument will contain\n * keys for quantities relevant to the current batch or epoch.\n *\n * Currently, the `.fit()` method of the `Sequential` model class\n * will include the following quantities in the `logs` that\n * it passes to its callbacks:\n *\n * onEpochEnd: Logs include `acc` and `loss`, and optionally include `valLoss`\n * (if validation is enabled in `fit`), and `valAcc` (if validation and\n * accuracy monitoring are enabled).\n * onBatchBegin: Logs include `size`, the number of samples in the current\n * batch.\n * onBatchEnd: Logs include `loss`, and optionally `acc` (if accuracy monitoring\n * is enabled).\n */\nexport abstract class BaseCallback {\n // TODO(michaelterry): This type is a best guess.\n validationData: Tensor|Tensor[] = null;\n /**\n * Training parameters (eg. verbosity, batch size, number of epochs...).\n */\n params: Params;\n\n setParams(params: Params): void {\n this.params = params;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {}\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {}\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {}\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {}\n\n async onTrainBegin(logs?: UnresolvedLogs) {}\n\n async onTrainEnd(logs?: UnresolvedLogs) {}\n\n // Model needs to call Callback.setModel(), but cannot actually depend on\n // Callback because that creates a cyclic dependency. Providing this no-op\n // method on BaseCallback breaks the cycle: this way Model can depend on\n // BaseCallback but not on Callback. The argument is typed as `Container`\n // (the superclass of Model) to avoid recapitulating the cycle. Callback\n // overrides this method and enforces that the argument is really a Model.\n setModel(model: Container): void {\n // Do nothing. Use Callback instead of BaseCallback to track the model.\n }\n}\n\n/**\n * Container abstracting a list of callbacks.\n */\nexport class CallbackList {\n callbacks: BaseCallback[];\n queueLength: number;\n\n // TODO(cais): When the need arises, uncomment the following lines and\n // implement the queue for time values.\n // private deltaTBatch: number;\n // private deltaTsBatchBegin: Array;\n // private deltaTsBatchEnd: Array;\n\n /**\n * Constructor of CallbackList.\n * @param callbacks Array of `Callback` instances.\n * @param queueLength Queue length for keeping running statistics over\n * callback execution time.\n */\n constructor(callbacks?: BaseCallback[], queueLength = 10) {\n // TODO(cais): Make use of queueLength when implementing the queue for time\n // values.\n if (callbacks == null) {\n callbacks = [];\n }\n this.callbacks = callbacks;\n this.queueLength = queueLength;\n }\n\n append(callback: BaseCallback): void {\n this.callbacks.push(callback);\n }\n\n setParams(params: Params): void {\n for (const callback of this.callbacks) {\n callback.setParams(params);\n }\n }\n\n setModel(model: Container): void {\n for (const callback of this.callbacks) {\n callback.setModel(model);\n }\n }\n\n /**\n * Called at the start of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochBegin(epoch, logs);\n }\n }\n\n /**\n * Called at the end of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochEnd(epoch, logs);\n }\n }\n\n /**\n * Called right before processing a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchBegin(batch, logs);\n }\n }\n\n /**\n * Called at the end of a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchEnd(batch, logs);\n }\n }\n\n /**\n * Called at the beginning of training.\n * @param logs Dictionary of logs.\n */\n async onTrainBegin(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainBegin(logs);\n }\n }\n\n /**\n * Called at the end of training.\n * @param logs Dictionary of logs.\n */\n async onTrainEnd(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainEnd(logs);\n }\n }\n}\n\n\n/**\n * Callback that accumulates epoch averages of metrics.\n *\n * This callback is automatically applied to every Model.\n */\nexport class BaseLogger extends BaseCallback {\n private seen: number;\n private totals: UnresolvedLogs;\n\n constructor() {\n super();\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n this.seen = 0;\n this.totals = {};\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n const batchSize = logs['size'] == null ? 0 : logs['size'] as number;\n this.seen += batchSize;\n for (const key in logs) {\n const value = logs[key];\n if (typeof value === 'number') {\n if (!this.totals.hasOwnProperty(key)) {\n this.totals[key] = 0;\n }\n this.totals[key] = this.totals[key] as number + value * batchSize;\n } else {\n let oldTotalsToDispose: Scalar;\n if (key in this.totals) {\n oldTotalsToDispose = this.totals[key] as Scalar;\n } else {\n this.totals[key] = getScalar(0);\n }\n\n this.totals[key] = tidy(\n () => add((this.totals[key] as Scalar),\n mul(value, getScalar(batchSize))) as Scalar);\n if (oldTotalsToDispose != null) {\n oldTotalsToDispose.dispose();\n }\n }\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs != null) {\n for (const key of this.params['metrics'] as string[]) {\n if (this.totals[key] == null) {\n continue;\n }\n if (typeof this.totals[key] === 'number') {\n logs[key] = this.totals[key] as number / this.seen;\n } else {\n tidy(() => {\n logs[key] = mul(div(getScalar(1), getScalar(this.seen)) as Scalar,\n this.totals[key] as Scalar) as Scalar;\n (this.totals[key] as Tensor).dispose();\n keep(logs[key] as Scalar);\n });\n }\n }\n }\n }\n}\n\n/**\n * Callback that records events into a `History` object. This callback is\n * automatically applied to every TF.js Layers model. The `History` object gets\n * returned by the `fit` method of models.\n */\nexport class History extends BaseCallback {\n epoch: number[];\n history: {[key: string]: Array};\n\n async onTrainBegin(logs?: UnresolvedLogs) {\n this.epoch = [];\n this.history = {};\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n this.epoch.push(epoch);\n for (const key in logs) {\n if (this.history[key] == null) {\n this.history[key] = [];\n }\n this.history[key].push(logs[key]);\n }\n }\n\n /**\n * Await the values of all losses and metrics.\n */\n async syncData() {\n const promises: Array> = [];\n const keys: string[] = [];\n const indices: number[] = [];\n for (const key in this.history) {\n const valueArray = this.history[key];\n for (let i = 0; i < valueArray.length; ++i) {\n if (typeof valueArray[i] !== 'number') {\n const valueScalar = valueArray[i] as Tensor;\n promises.push(valueScalar.data());\n keys.push(key);\n indices.push(i);\n }\n }\n }\n const values = await Promise.all(promises);\n for (let n = 0; n < values.length; ++n) {\n const tensorToDispose = this.history[keys[n]][indices[n]] as Tensor;\n tensorToDispose.dispose();\n this.history[keys[n]][indices[n]] = values[n][0];\n }\n }\n}\n\nexport interface CustomCallbackConfig {\n onTrainBegin?: (logs?: Logs) => Promise;\n onTrainEnd?: (logs?: Logs) => Promise;\n onEpochBegin?: (epoch: number, logs?: Logs) => Promise;\n onEpochEnd?: (epoch: number, logs?: Logs) => Promise;\n onBatchBegin?: (batch: number, logs?: Logs) => Promise;\n onBatchEnd?: (batch: number, logs?: Logs) => Promise;\n}\n\n/**\n * Custom callback for training.\n */\nexport class CustomCallback extends BaseCallback {\n protected readonly trainBegin: (logs?: Logs) => Promise;\n protected readonly trainEnd: (logs?: Logs) => Promise;\n protected readonly epochBegin: (epoch: number, logs?: Logs) => Promise;\n protected readonly epochEnd: (epoch: number, logs?: Logs) => Promise;\n protected readonly batchBegin: (batch: number, logs?: Logs) => Promise;\n protected readonly batchEnd: (batch: number, logs?: Logs) => Promise;\n\n constructor(config: CustomCallbackConfig) {\n super();\n this.trainBegin = config.onTrainBegin;\n this.trainEnd = config.onTrainEnd;\n this.epochBegin = config.onEpochBegin;\n this.epochEnd = config.onEpochEnd;\n this.batchBegin = config.onBatchBegin;\n this.batchEnd = config.onBatchEnd;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.epochBegin(epoch, logs as Logs);\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.epochEnd(epoch, logs as Logs);\n }\n }\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.batchBegin(batch, logs as Logs);\n }\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.batchEnd(batch, logs as Logs);\n }\n }\n\n async onTrainBegin(logs?: UnresolvedLogs): Promise {\n if (this.trainBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.trainBegin(logs as Logs);\n }\n }\n\n async onTrainEnd(logs?: UnresolvedLogs): Promise {\n if (this.trainEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.trainEnd(logs as Logs);\n }\n }\n}\n\n/**\n * Standardize callbacks or configurations of them to an Array of callbacks.\n */\nexport function standardizeCallbacks(callbacks: BaseCallback|BaseCallback[]|\n CustomCallbackConfig|\n CustomCallbackConfig[]): BaseCallback[] {\n if (callbacks == null) {\n return null;\n }\n if (callbacks instanceof BaseCallback) {\n return [callbacks as BaseCallback];\n }\n if (Array.isArray(callbacks) && callbacks[0] instanceof BaseCallback) {\n return callbacks as BaseCallback[];\n }\n // Convert custom callback configs to custom callback objects.\n const callbackConfigs =\n generic_utils.toList(callbacks) as CustomCallbackConfig[];\n return callbackConfigs.map(\n callbackConfig => new CustomCallback(callbackConfig));\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: losses.py */\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor, Tensor1D, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {ValueError} from './errors';\nimport {LossOrMetricFn} from './types';\n\n\n/**\n * Normalizes a tensor wrt the L2 norm alongside the specified axis.\n * @param x\n * @param axis Axis along which to perform normalization.\n */\nexport function l2Normalize(x: Tensor, axis?: number): Tensor {\n return tidy(() => {\n const squareSum = tfc.sum(K.square(x), axis, true);\n const epsilonTensor = tfc.mul(scalar(epsilon()), tfc.onesLike(x));\n const norm = tfc.sqrt(tfc.maximum(squareSum, epsilonTensor));\n return tfc.div(x, norm);\n });\n}\n\n/**\n * Loss or metric function: Mean squared error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [3, 4]]);\n * const yPred = tf.tensor2d([[0, 1], [-3, -4]]);\n * const mse = tf.metrics.meanSquaredError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MSE`, `tf.metrics.mse`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean squared error Tensor.\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(K.square(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute error.\n *\n * Mathematically, mean absolute error is defined as:\n * `mean(abs(yPred - yTrue))`,\n * wherein the `mean` is applied over feature dimensions.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [0, 0], [2, 3]]);\n * const yPred = tf.tensor2d([[0, 1], [0, 1], [-2, -3]]);\n * const mse = tf.metrics.meanAbsoluteError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute error Tensor.\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(tfc.abs(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute percentage error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [10, 20]]);\n * const yPred = tf.tensor2d([[0, 1], [11, 24]]);\n * const mse = tf.metrics.meanAbsolutePercentageError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MAPE`, `tf.metrics.mape`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute percentage error Tensor.\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const diff = tfc.sub(yTrue, yPred);\n const clippedTrue =\n tfc.clipByValue(tfc.abs(yTrue), epsilon(), Number.MAX_VALUE);\n const absResult = tfc.abs(tfc.div(diff, clippedTrue));\n return tfc.mul(getScalar(100.0), tfc.mean(absResult, -1));\n });\n}\n\nexport function meanSquaredLogarithmicError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const one = getScalar(1.0);\n\n const clippedPred = tfc.clipByValue(yPred, epsilon(), Number.MAX_VALUE);\n const firstLog = tfc.log(tfc.add(one, clippedPred));\n\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), Number.MAX_VALUE);\n const secondLog = tfc.log(tfc.add(one, clippedTrue));\n\n return tfc.mean(K.square(tfc.sub(firstLog, secondLog)), -1);\n });\n}\n\nexport function squaredHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(K.square(maxResult), -1);\n });\n}\n\nexport function hinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(maxResult, -1);\n });\n}\n\nexport function categoricalHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const pos = tfc.sum(tfc.mul(yTrue, yPred), -1);\n const neg = tfc.max(tfc.mul(tfc.sub(one, yTrue), yPred), -1);\n return tfc.maximum(zeroTensor, tfc.add(one, tfc.sub(neg, pos)));\n });\n}\n\n/**\n * Logarithm of the hyperbolic cosine of the prediction error.\n *\n * `log(cosh(x))` is approximately equal to `(x ** 2) / 2` for small `x` and\n * to `abs(x) - log(2)` for large `x`. This means that 'logcosh' works mostly\n * like the mean squared error, but will not be so strongly affected by the\n * occasional wildly incorrect prediction.\n */\nexport function logcosh(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const log2 = getScalar(Math.log(2.0));\n const predictionDiff = tfc.sub(yPred, yTrue);\n const logcoshResult = tfc.sub(\n tfc.add(\n predictionDiff,\n tfc.softplus(tfc.mul(getScalar(-2.0), predictionDiff))),\n log2);\n return tfc.mean(logcoshResult, -1);\n });\n}\n\n/**\n * Categorical crossentropy between an output tensor and a target tensor.\n *\n * @param target A tensor of the same shape as `output`.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function categoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n if (fromLogits) {\n output = tfc.softmax(output);\n } else {\n // scale preds so that the class probabilities of each sample sum to 1.\n const outputSum = tfc.sum(output, output.shape.length - 1, true);\n output = tfc.div(output, outputSum);\n }\n output = tfc.clipByValue(output, epsilon(), 1 - epsilon());\n return tfc.neg(tfc.sum(\n tfc.mul(target.toFloat(), tfc.log(output)), output.shape.length - 1));\n });\n}\n\n/**\n * Categorical crossentropy with integer targets.\n *\n * @param target An integer tensor.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function sparseCategoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n const flatTarget = tfc.floor(K.flatten(target)).toInt() as Tensor1D;\n const outputShape = output.shape;\n const oneHotTarget =\n tfc.oneHot(flatTarget, outputShape[outputShape.length - 1])\n .reshape(outputShape);\n return categoricalCrossentropy(oneHotTarget, output, fromLogits);\n });\n}\n\n/**\n * From TensorFlow's implementation in nn_impl.py:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n * Hence, to ensure stability and avoid overflow, the implementation uses this\n * equivalent formulation\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n *\n * @param target The labels.\n * @param output The logits.\n */\nexport function sigmoidCrossEntropyWithLogits(\n target: Tensor, output: Tensor): Tensor {\n return tidy(() => {\n const maxOutput = tfc.maximum(output, tfc.zerosLike(output));\n const outputXTarget = tfc.mul(output, target);\n const sigmoidOutput =\n tfc.log(tfc.add(getScalar(1), tfc.exp(tfc.neg(tfc.abs(output)))));\n const result = tfc.add(tfc.sub(maxOutput, outputXTarget), sigmoidOutput);\n return result;\n });\n}\n\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n let y: Tensor;\n y = tfc.clipByValue(yPred, epsilon(), 1 - epsilon());\n y = tfc.log(tfc.div(y, tfc.sub(tfc.onesLike(y), y)));\n return tfc.mean(sigmoidCrossEntropyWithLogits(yTrue, y), -1);\n });\n}\n\nexport function kullbackLeiblerDivergence(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), 1);\n const clippedPred = tfc.clipByValue(yPred, epsilon(), 1);\n return tfc.sum(\n tfc.mul(yTrue, tfc.log(tfc.div(clippedTrue, clippedPred))), -1);\n });\n}\n\nexport function poisson(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const logPred = tfc.log(tfc.add(getScalar(epsilon()), yPred));\n return tfc.mean(tfc.sub(yPred, tfc.mul(yTrue, logPred)), -1);\n });\n}\n\n/**\n * Loss or metric function: Cosine proximity.\n *\n * Mathematically, cosine proximity is defined as:\n * `-sum(l2Normalize(yTrue) * l2Normalize(yPred))`,\n * wherein `l2Normalize()` normalizes the L2 norm of the input to 1 and `*`\n * represents element-wise multiplication.\n *\n * ```js\n * const yTrue = tf.tensor2d([[1, 0], [1, 0]]);\n * const yPred = tf.tensor2d([[1 / Math.sqrt(2), 1 / Math.sqrt(2)], [0, 1]]);\n * const proximity = tf.metrics.cosineProximity(yTrue, yPred);\n * proximity.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Cosine proximity Tensor.\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const trueNormalized = l2Normalize(yTrue, -1);\n const predNormalized = l2Normalize(yPred, -1);\n const trueXPred = tfc.mul(trueNormalized, predNormalized);\n return tfc.neg(tfc.sum(trueXPred, -1));\n });\n}\n\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const msle = meanSquaredLogarithmicError;\nexport const MSLE = meanSquaredLogarithmicError;\nexport const kld = kullbackLeiblerDivergence;\nexport const KLD = kullbackLeiblerDivergence;\nexport const cosine = cosineProximity;\n\n// TODO(michaelterry): Add deserialize() function.\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function get(identifierOrFn: string|LossOrMetricFn): LossOrMetricFn {\n const lossesMap: {[functionName: string]: LossOrMetricFn} = {\n meanSquaredError,\n meanAbsoluteError,\n meanAbsolutePercentageError,\n meanSquaredLogarithmicError,\n squaredHinge,\n hinge,\n categoricalHinge,\n logcosh,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n binaryCrossentropy,\n kullbackLeiblerDivergence,\n poisson,\n cosineProximity\n };\n if (typeof identifierOrFn === 'string') {\n if (identifierOrFn in lossesMap) {\n return lossesMap[identifierOrFn];\n }\n throw new ValueError(`Unknown loss ${identifierOrFn}`);\n } else {\n return identifierOrFn;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Built-in metrics.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {NotImplementedError, ValueError} from './errors';\nimport {categoricalCrossentropy as categoricalCrossentropyLoss, cosineProximity, meanAbsoluteError, meanAbsolutePercentageError, meanSquaredError, sparseCategoricalCrossentropy as sparseCategoricalCrossentropyLoss} from './losses';\nimport {binaryCrossentropy as lossBinaryCrossentropy} from './losses';\nimport {LossOrMetricFn} from './types';\n// tslint:enable:max-line-length\n\n/**\n * Binary accuracy metric function.\n *\n * `yTrue` and `yPred` can have 0-1 values. Example:\n * ```js\n * const x = tensor2d([[1, 1, 1, 1], [0, 0, 0, 0]], [2, 4]);\n * const y = tensor2d([[1, 0, 1, 0], [0, 0, 0, 1]], [2, 4]);\n * const accuracy = tfl.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * `yTrue` and `yPred` can also have floating-number values between 0 and 1, in\n * which case the values will be thresholded at 0.5 to yield 0-1 values (i.e.,\n * a value >= 0.5 and <= 1.0 is interpreted as 1.\n * )\n * Example:\n * ```js\n * const x = tensor1d([1, 1, 1, 1, 0, 0, 0, 0]);\n * const y = tensor1d([0.2, 0.4, 0.6, 0.8, 0.2, 0.3, 0.4, 0.7]);\n * const accuracy = tf.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction.\n * @return Accuracy Tensor.\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const threshold = tfc.mul(getScalar(0.5), tfc.onesLike(yPred));\n const yPredThresholded = K.cast(tfc.greater(yPred, threshold), yTrue.dtype);\n return tfc.mean(tfc.equal(yTrue, yPredThresholded), -1);\n });\n}\n\n/**\n * Categorical accuracy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0, 0, 0, 1], [0, 0, 0, 1]]);\n * const y = tensor2d([[0.1, 0.8, 0.05, 0.05], [0.1, 0.05, 0.05, 0.8]]);\n * const accuracy = tf.metrics.categoricalAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth: one-hot encoding of categories.\n * @param yPred Binary Tensor of prediction: probabilities or logits for the\n * same categories as in `yTrue`.\n * @return Accuracy Tensor.\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(\n () => K.cast(\n tfc.equal(tfc.argMax(yTrue, -1), tfc.argMax(yPred, -1)), 'float32'));\n}\n\n/**\n * Binary crossentropy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0], [1], [1], [1]]);\n * const y = tensor2d([[0], [0], [0.5], [1]]);\n * const crossentropy = tf.metrics.binaryCrossentropy(x, y);\n * crossentropy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction, probabilities for the `1` case.\n * @return Accuracy Tensor.\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return lossBinaryCrossentropy(yTrue, yPred);\n}\n\nexport function sparseCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function topKCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function sparseTopKCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\n// Aliases.\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const categoricalCrossentropy = categoricalCrossentropyLoss;\nexport const cosine = cosineProximity;\nexport const sparseCategoricalCrossentropy = sparseCategoricalCrossentropyLoss;\n\n// TODO(cais, nielsene): Add serialize().\n\nexport function get(identifier: string|LossOrMetricFn): LossOrMetricFn {\n const metricsMap: {[functionName: string]: LossOrMetricFn} = {\n binaryAccuracy,\n categoricalAccuracy,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n mse,\n MSE,\n mae,\n MAE,\n mape,\n MAPE,\n cosine,\n };\n if (typeof identifier === 'string' && identifier in metricsMap) {\n return metricsMap[identifier];\n } else if (typeof identifier !== 'string' && identifier != null) {\n return identifier;\n } else {\n throw new ValueError(`Unknown metric ${identifier}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Optimizers.\n */\n\n// tslint:disable:max-line-length\nimport {Optimizer, train} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\n// tslint:enable:max-line-length\n\nimport {ValueError} from './errors';\n\n// Add (de)serialize()\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function getOptimizer(identifier: string): Optimizer {\n const optimizerMap: {[optimizerName: string]: () => Optimizer} = {\n 'Adagrad': () => train.adagrad(0.01),\n 'Adadelta': () => train.adadelta(1, 0.95, epsilon()),\n 'Adam': () => train.adam(0.001, 0.9, 0.999, epsilon()),\n 'Adamax': () => train.adamax(0.002, 0.9, 0.999, epsilon(), 0),\n 'RMSProp': () => train.rmsprop(0.001, 0.9, 0, epsilon()),\n 'SGD': () => train.sgd(0.01)\n };\n optimizerMap['adagrad'] = optimizerMap['Adagrad'];\n optimizerMap['adadelta'] = optimizerMap['Adadelta'];\n optimizerMap['adam'] = optimizerMap['Adam'];\n optimizerMap['adamax'] = optimizerMap['Adamax'];\n optimizerMap['rmsprop'] = optimizerMap['RMSProp'];\n optimizerMap['sgd'] = optimizerMap['SGD'];\n\n if (identifier in optimizerMap) {\n return optimizerMap[identifier]();\n }\n throw new ValueError(`Unknown Optimizer ${identifier}`);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {Container} from '../engine/container';\nimport {Layer, Node} from '../engine/topology';\nimport {countParamsInWeights} from './variable_utils';\n\n/**\n * Print the summary of a Model object.\n *\n * @param model tf.Model instance.\n * @param lineLength Total length of printed lines. Set this to adapt to the\n * display to different terminal or console sizes.\n * @param positions Relative or absolute positions of log elements in each\n * line. Each number corresponds to right-most (i.e., ending) position of a\n * column.\n * If not provided, defaults to `[0.45, 0.85, 1]` for sequential-like\n * models and `[0.33, 0.55, 0.67, 1]` for non-sequential like models.\n * @param printFn Print function to use.\n * It will be called on each line of the summary. You can provide a custom\n * function in order to capture the string summary. Defaults to `console.log`.\n */\nexport function printSummary(\n model: Container, lineLength?: number, positions?: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void =\n console.log): void {\n const sequentialLike = isModelSequentialLike(model);\n\n // Header names for different log elements.\n const toDisplay: string[] = ['Layer (type)', 'Output shape', 'Param #'];\n if (sequentialLike) {\n lineLength = lineLength || 65;\n positions = positions || [0.45, 0.85, 1];\n } else {\n lineLength = lineLength || 98;\n positions = positions || [0.33, 0.55, 0.67, 1];\n // Header names for different log elements.\n }\n\n if (positions[positions.length - 1] <= 1) {\n // `positions` is relative. Convert it to absolute positioning.\n positions = positions.map(p => Math.floor(lineLength * p));\n }\n\n let relevantNodes: Node[];\n if (!sequentialLike) {\n toDisplay.push('Receives inputs');\n relevantNodes = [];\n for (const depth in model.nodesByDepth) {\n relevantNodes.push(...model.nodesByDepth[depth]);\n }\n }\n\n printFn('_'.repeat(lineLength));\n printRow(toDisplay, positions, printFn);\n printFn('='.repeat(lineLength));\n\n const layers = model.layers;\n for (let i = 0; i < layers.length; ++i) {\n if (sequentialLike) {\n printLayerSummary(layers[i], positions, printFn);\n } else {\n printLayerSummaryWithConnections(\n layers[i], positions, relevantNodes, printFn);\n }\n printFn((i === layers.length - 1 ? '=' : '_').repeat(lineLength));\n }\n\n // tslint:disable-next-line:no-any\n (model as any).checkTrainableWeightsConsistency();\n let trainableCount: number;\n // tslint:disable:no-any\n if ((model as any).collectedTrainableWeights != null) {\n trainableCount =\n countParamsInWeights((model as any).collectedTrainableWeights);\n } else {\n trainableCount = countParamsInWeights(model.trainableWeights);\n }\n // tslint:enable:no-any\n const nonTrainableCount = countParamsInWeights(model.nonTrainableWeights);\n\n printFn(`Total params: ${trainableCount + nonTrainableCount}`);\n printFn(`Trainable params: ${trainableCount}`);\n printFn(`Non-trainable params: ${nonTrainableCount}`);\n printFn('_'.repeat(lineLength));\n}\n\nfunction isModelSequentialLike(model: Container): boolean {\n let sequentialLike = true;\n const nodesByDepth: Node[][] = [];\n const nodes: Node[] = [];\n for (const depth in model.nodesByDepth) {\n nodesByDepth.push(model.nodesByDepth[depth]);\n }\n for (const depthNodes of nodesByDepth) {\n if (depthNodes.length > 1 ||\n depthNodes.length === 1 && depthNodes[0].inboundLayers.length > 1) {\n sequentialLike = false;\n break;\n }\n nodes.push(...depthNodes);\n }\n if (sequentialLike) {\n // Search for shared layers.\n for (const layer of model.layers) {\n let flag = false;\n for (const node of layer.inboundNodes) {\n if (nodes.indexOf(node) !== -1) {\n if (flag) {\n sequentialLike = false;\n break;\n } else {\n flag = true;\n }\n }\n }\n if (!sequentialLike) {\n break;\n }\n }\n }\n return sequentialLike;\n}\n\nfunction printRow(\n fields: string[], positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void = console.log) {\n let line = '';\n for (let i = 0; i < fields.length; ++i) {\n if (i > 0) {\n line = line.slice(0, line.length - 1) + ' ';\n }\n line += fields[i];\n line = line.slice(0, positions[i]);\n line += ' '.repeat(positions[i] - line.length);\n }\n printFn(line);\n}\n\n/**\n * Prints a summary for a single Layer, without connectivity information.\n *\n * @param layer: Layer instance to print.\n */\nfunction printLayerSummary(\n layer: Layer, positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const name = layer.name;\n const className = layer.getClassName();\n const fields: string[] =\n [`${name} (${className})`, outputShape, layer.countParams().toString()];\n printRow(fields, positions, printFn);\n}\n\n/**\n * Prints a summary for a single Layer, with connectivity information.\n */\nfunction printLayerSummaryWithConnections(\n layer: Layer, positions: number[], relevantNodes: Node[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const connections: string[] = [];\n for (const node of layer.inboundNodes) {\n if (relevantNodes != null && relevantNodes.length > 0 &&\n relevantNodes.indexOf(node) === -1) {\n continue;\n }\n for (let i = 0; i < node.inboundLayers.length; ++i) {\n const inboundLayer = node.inboundLayers[i].name;\n const inboundLayerIndex = node.nodeIndices[i];\n const inboundTensorIndex = node.tensorIndices[i];\n connections.push(\n `${inboundLayer}[${inboundLayerIndex}][${inboundTensorIndex}]`);\n }\n }\n const name = layer.name;\n const className = layer.getClassName();\n const firstConnection = connections.length === 0 ? '' : connections[0];\n const fields: string[] = [\n `${name} (${className})`, outputShape, layer.countParams().toString(),\n firstConnection\n ];\n\n printRow(fields, positions, printFn);\n for (let i = 1; i < connections.length; ++i) {\n printRow(['', '', '', connections[i]], positions, printFn);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source layers/__init__.py */\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {deserializeKerasObject} from '../utils/generic_utils';\n\n/**\n * Instantiate a layer from a config dictionary.\n * @param config: dict of the form {class_name: str, config: dict}\n * @param custom_objects: dict mapping class names (or function names)\n * of custom (non-Keras) objects to class/functions\n * @returns Layer instance (may be Model, Sequential, Layer...)\n */\nexport function deserialize(\n config: serialization.ConfigDict,\n customObjects = {} as\n serialization.ConfigDict): serialization.Serializable {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'layer');\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Porting note: This file doesn't exist in PyKeras.\n// Its purpose here is to centralize the boundary layer between\n// tfjs-layers's internal Config TS-Centric format and PyKeras's\n// serialized Python Config format.\n\n// tslint:disable:max-line-length\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {JsonValue} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\n// tslint:enable\n\n/**\n * Test whether a value in an array is the name of a Model or Layer.\n * @param key The key name that the value is found under. Note that the key\n * may not be at the level immediately above the value, if the value is in a\n * nested array.\n * @param index Index of the value in the Array that it is found in.\n * @param value The value object.\n * @returns A boolean indicating whether value is a name.\n */\nfunction isArrayItemInputOrOutputName(\n key: string, index: number, value: T): boolean {\n return (key === 'inboundNodes' || key === 'outputLayers' ||\n key === 'inputLayers') &&\n index === 0 && typeof value === 'string';\n}\n\n/**\n * Convert a Pythonic config object to TypeScript config object.\n * @param pythonicConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertPythonicToTs(\n pythonicConfig: JsonValue, key?: string): serialization.ConfigDictValue {\n if (pythonicConfig === null) {\n return null;\n } else if (typeof pythonicConfig === 'string') {\n return generic_utils.toCamelCase(pythonicConfig);\n } else if (\n (typeof pythonicConfig === 'number') ||\n (typeof pythonicConfig === 'boolean')) {\n return pythonicConfig;\n } else if (pythonicConfig instanceof Array) {\n const tsArray = [];\n const arrayLength = pythonicConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = pythonicConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n tsArray.push(item);\n } else {\n tsArray.push(convertPythonicToTs(item, key));\n }\n }\n return tsArray;\n } else {\n const tsDict: serialization.ConfigDict = {};\n for (const pythonicKey of Object.keys(pythonicConfig)) {\n const pythonicValue = pythonicConfig[pythonicKey];\n if (pythonicKey === 'name' && typeof pythonicValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // camel-case conversion.\n tsDict[pythonicKey] = pythonicValue;\n } else {\n const tsKey = generic_utils.toCamelCase(pythonicKey);\n tsDict[tsKey] = convertPythonicToTs(pythonicValue, tsKey);\n }\n }\n return tsDict;\n }\n}\n\n/**\n * Convert a TypeScript config object to Python config object.\n * @param tsConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertTsToPythonic(\n tsConfig: serialization.ConfigDictValue, key?: string): JsonValue {\n if (tsConfig === null || tsConfig === undefined) {\n return null;\n } else if (typeof tsConfig === 'string') {\n return generic_utils.toSnakeCase(tsConfig);\n } else if (\n (typeof tsConfig === 'number') || (typeof tsConfig === 'boolean')) {\n return tsConfig;\n } else if (tsConfig instanceof Array) {\n const pyArray = [];\n const arrayLength = tsConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = tsConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n pyArray.push(item);\n } else {\n pyArray.push(convertTsToPythonic(item, key));\n }\n }\n return pyArray;\n } else {\n const pyDict: serialization.ConfigDict = {};\n for (const tsKey of Object.keys(tsConfig)) {\n const tsValue = tsConfig[tsKey];\n const pyKey = generic_utils.toSnakeCase(tsKey);\n if ((tsKey === 'name' || tsKey === 'className') &&\n typeof tsValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // snake-case conversion.\n pyDict[pyKey] = tsValue;\n } else {\n pyDict[pyKey] = convertTsToPythonic(tsValue, tsKey);\n }\n }\n return pyDict;\n }\n}\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.7.2';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {deserialize as deserializeLayer} from '../layers/serialization';\nimport {JsonDict, Kwargs, NamedTensorMap, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {convertTsToPythonic} from '../utils/serialization_utils';\nimport * as types_utils from '../utils/types_utils';\nimport {batchSetValue, LayerVariable} from '../variables';\nimport {version as layersVersion} from '../version';\n\nimport {InputLayer} from './input_layer';\nimport {Layer, Node, SymbolicTensor} from './topology';\n// tslint:enable:max-line-length\n\n/**\n * Converts layers weights to a format suitable for TensorFlow.js Layers.\n *\n * Porting Note: The function `preprocess_weights_for_loading()` in PyKeras\n * performs conversion from Keras 1 to Keras 2. But in TypeScript, we\n * require Keras version to be 2. Thus this conversion is not applicable. We\n * simply check the Keras version and pass the weights through.\n *\n * @param layer Layer instance.\n * @param weights Input weights.\n * @param originalKerasVersion Keras version for the weights.\n * @param originalBackend Keras backend the weights were trained with.\n * @returns Output weights as Tensors.\n */\nfunction preprocessWeightsForLoading(\n layer: Layer, weights: LayerVariable[], originalKerasVersion?: string,\n originalBackend?: string): LayerVariable[] {\n if (!originalKerasVersion.startsWith('2.')) {\n throw new ValueError(\n 'Unsupported Keras version in weights being loaded: ' +\n originalKerasVersion);\n }\n return weights;\n}\n\n/**\n * Create an Tensor from info about dtype, shape and values.\n * @param dtype DType string.\n * @param shape Shape.\n * @param value Values of the array, as a scalar or nested Array of proper\n * shape.\n * @returns An Tensor instance.\n */\n// tslint:disable-next-line:no-any\nfunction loadTensor(dtype: string, shape: Shape, value: any): Tensor {\n const dataType = generic_utils.stringToDType(dtype);\n return Tensor.make(\n shape, {values: shape.length === 0 ? value : util.flatten(value)},\n dataType);\n}\n\n// TODO(cais): Maybe remove the following (b/74015805).\n/**\n * Load weights from a weights JSON object to an array of layers.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weightsJSON. The input JSON object represent the weights from a\n * trained Keras model. See scripts/pykeras.py for more details.\n * @param layers An array of target layers.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weights.\n */\nexport function loadWeightsFromJson(\n weightsJSON: JsonDict, layers: Layer[], skipMismatch = false): void {\n const originalKerasVersion = weightsJSON['keras_version'] as string;\n const originalBackend = weightsJSON['backend'] as string;\n const layerNames = layers.map(layer => layer.name);\n\n // Reverse index of layer name to list of layers with name.\n const index: {[layerName: string]: Layer[]} = {};\n for (const layer of layers) {\n if (layer.name != null) {\n if (index[layer.name] == null) {\n index[layer.name] = [];\n }\n index[layer.name].push(layer);\n }\n }\n\n // tslint:disable-next-line:no-any\n const nameToWeights = weightsJSON['weights'] as {[name: string]: any};\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (let k = 0; k < layerNames.length; ++k) {\n const name = layerNames[k];\n let layerWeights = nameToWeights[name];\n if (layerWeights == null) {\n layerWeights = [];\n }\n\n let weightValues: LayerVariable[] = [];\n for (let n = 0; n < layerWeights.length; ++n) {\n // tslint:disable:no-any\n const weightEntry =\n layerWeights[n] as {[key: string]: string | Shape | any};\n // tslint:enable\n weightValues.push(new LayerVariable(loadTensor(\n weightEntry['dtype'], weightEntry['shape'] as Shape,\n weightEntry['value'])));\n }\n for (const layer of index[name]) {\n const symbolicWeights = layer.weights;\n weightValues = preprocessWeightsForLoading(\n layer, weightValues, originalKerasVersion, originalBackend);\n if (weightValues.length !== symbolicWeights.length) {\n if (skipMismatch) {\n console.warn(\n `Skipping loading of weights of layer ${layer.name} ` +\n `due to mismatch in number of weights: (${weightValues.length} ` +\n `vs ${symbolicWeights.length}).`);\n } else {\n throw new ValueError(\n `Layer #${k} (named \"${layer.name}\") expects ` +\n `${symbolicWeights.length} weight(s), but the saved weights ` +\n `have ${weightValues.length} element(s).`);\n }\n }\n\n // Set values.\n for (let i = 0; i < weightValues.length; ++i) {\n if (skipMismatch) {\n if (!util.arraysEqual(\n symbolicWeights[i].shape, weightValues[i].shape)) {\n console.warn(\n `Skipping loading of weights for layer ${layer.name} due ` +\n `to mismatch in shape (${symbolicWeights[i].shape} vs ` +\n `${weightValues[i].shape})`);\n continue;\n }\n }\n weightValueTuples.push([symbolicWeights[i], weightValues[i].read()]);\n }\n }\n }\n batchSetValue(weightValueTuples);\n}\n\n/**\n * Load weights from a named tensor map.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weights The named tensor map mapping names of weights to weight\n * values.\n * @param layers An array of target layers.\n */\nexport function loadWeightsFromNamedTensorMap(\n weights: NamedTensorMap, layers: Layer[]): void {\n // Make a dictionary mapping weight name to weight.\n const nameToWeight: {[name: string]: LayerVariable} = {};\n let totalWeightsCount = 0;\n for (const layer of layers) {\n for (const weight of layer.weights) {\n if (nameToWeight[weight.originalName] != null) {\n throw new ValueError(`Duplicate weight name: ${weight.originalName}`);\n }\n nameToWeight[weight.originalName] = weight;\n totalWeightsCount++;\n }\n }\n\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (const name in weights) {\n weightValueTuples.push([nameToWeight[name], weights[name]]);\n delete nameToWeight[name];\n }\n\n // Check that all weights are set.\n const unsetNames: string[] = [];\n for (const name in nameToWeight) {\n unsetNames.push(name);\n }\n if (unsetNames.length > 0) {\n throw new ValueError(\n `${unsetNames.length} of ${totalWeightsCount} weights are not set: ` +\n `${unsetNames}`);\n }\n\n batchSetValue(weightValueTuples);\n}\n\n/** Constructor config for Container. */\nexport interface ContainerConfig {\n inputs: SymbolicTensor|SymbolicTensor[];\n outputs: SymbolicTensor|SymbolicTensor[];\n name?: string;\n}\n\n/**\n * A Container is a directed acyclic graph of layers.\n *\n * It is the topological form of a \"model\". A Model\n * is simply a Container with added training routines.\n *\n */\nexport abstract class Container extends Layer {\n inputs: SymbolicTensor[];\n outputs: SymbolicTensor[];\n\n inputLayers: Layer[];\n inputLayersNodeIndices: number[];\n inputLayersTensorIndices: number[];\n\n outputLayers: Layer[];\n outputLayersNodeIndices: number[];\n outputLayersTensorIndices: number[];\n\n layers: Layer[];\n layersByDepth: {[depth: string]: Layer[]};\n nodesByDepth: {[depth: string]: Node[]};\n\n containerNodes = new Set();\n\n // TODO(michaelterry): Add cache support\n // private outputMaskCache: any;\n // private outputTensorCache: any;\n // private outputShapeCache: any;\n\n inputNames: string[];\n outputNames: string[];\n feedInputShapes: Shape[];\n\n protected internalInputShapes: Shape[];\n protected internalOutputShapes: Shape[];\n // TODO(cais): Maybe 'feed' should not in the names of these variables,\n // due to the fact that our backend is not symbolic.\n protected feedInputNames: string[];\n protected feedOutputNames: string[];\n\n constructor(config: ContainerConfig) {\n // No args passed to super's constructor.\n super({});\n this.name = config.name;\n if (this.name == null) {\n const prefix = this.getClassName().toLowerCase();\n this.name = getUid(prefix);\n }\n\n this.supportsMasking = false;\n this.trainable = true;\n this.updatable = true;\n\n // TODO(michaelterry): Initialize perInputLosses/Updates here.\n\n // Container-specific properties.\n if (Array.isArray(config.inputs)) {\n this.inputs = config.inputs.slice();\n } else {\n this.inputs = [config.inputs];\n }\n if (Array.isArray(config.outputs)) {\n this.outputs = config.outputs.slice();\n } else {\n this.outputs = [config.outputs];\n }\n\n // Check for redundancy in inputs.\n if (generic_utils.unique(this.inputs).length !== this.inputs.length) {\n throw new ValueError(\n 'The list of inputs passed to the model is ' +\n 'redundant. All inputs should only appear once. Found: ' +\n this.inputs.map(x => x.name));\n }\n\n // Check for redundancy in outputs.\n if (generic_utils.unique(this.outputs).length !== this.outputs.length) {\n console.warn(\n 'The list of outputs passed to the model is redundant. ' +\n 'All outputs should only appear once. Found: ' +\n this.outputs.map(x => x.name));\n }\n\n /*\n List of initial layers (1 to 1 mapping with this.inputs, hence the same\n layer might appear twice)\n */\n this.inputLayers = [];\n this.inputLayersNodeIndices = [];\n this.inputLayersTensorIndices = [];\n /*\n List of layers (1 to 1 mapping with this.outputs, hence the same layer\n might appear twice)\n */\n this.outputLayers = [];\n this.outputLayersNodeIndices = [];\n this.outputLayersTensorIndices = [];\n /*\n All layers in order of horizontal graph traversal. Entries are unique.\n Includes input and output layers.\n */\n this.layers = [];\n\n // TODO(michaelterry): Determine if caching still needed with eager\n // backend.\n /*\n This is for performance optimization when calling the Container on new\n inputs. Every time the Container is called on a set on input tensors,\n we compute the output tensors, output masks and output shapes in one pass,\n then cache them here. When one of these outputs is queried later,\n we retrieve it from there instead of recomputing it.\n */\n // this.outputTensorCache = {};\n // this.outputShapeCache = {};\n\n // Build this.outputLayers:\n for (const x of this.outputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n this.outputLayers.push(layer as Layer);\n this.outputLayersNodeIndices.push(nodeIndex);\n this.outputLayersTensorIndices.push(tensorIndex);\n }\n\n // TODO(michaelterry): Add output mask cache code.\n\n // Build this.inputLayers:\n for (const x of this.inputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n /*\n It's supposed to be an input layer, so only one node\n and one tensor output.\n */\n generic_utils.assert(nodeIndex === 0, 'input layer has >1 nodes');\n generic_utils.assert(tensorIndex === 0, 'input layer has >1 tensors');\n this.inputLayers.push(layer as Layer);\n this.inputLayersNodeIndices.push(nodeIndex);\n this.inputLayersTensorIndices.push(tensorIndex);\n }\n\n // Build this.inputNames and this.outputNames.\n this.inputNames = [];\n this.outputNames = [];\n this.feedInputShapes = [];\n this.feedInputNames = [];\n this.feedOutputNames = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n // Check that layer is an InputLayer.\n if (!(layer instanceof InputLayer)) {\n throw new TypeError(\n 'Input layers to a Model must be InputLayer objects. ' +\n `Received inputs: ${config.inputs}. ` +\n `Input ${i} (0-based) originates ` +\n `from layer type ${layer.getClassName()}.`);\n }\n this.inputNames.push(layer.name);\n this.feedInputShapes.push(layer.batchInputShape);\n\n this.feedInputNames.push(layer.name);\n }\n for (const layer of this.outputLayers) {\n this.outputNames.push(layer.name);\n }\n\n this.internalInputShapes = this.inputs.map(x => x.shape);\n this.internalOutputShapes = this.outputs.map(x => x.shape);\n\n /*\n Container_nodes: set of nodes included in the graph (not all nodes\n included in the layers are relevant to the current graph).\n */\n // ids of all nodes relevant to the Container:\n const nodesDepths: {[nodeID: string]: number} = {};\n // To recover nodes from their ID.\n const nodeIDToNode: {[nodeID: string]: Node} = {};\n const layersDepths: {[layerID: string]: number} = {};\n // To layers from their ID.\n const layerIDToLayer: {[layerID: string]: Layer} = {};\n const layerIndices: {[layerID: string]: number} = {};\n const nodesInDecreasingDepth: Node[] = [];\n\n /**\n * Builds a map of the graph of layers.\n *\n * This recursively updates the map `layerIndices`,\n * the list `nodesInDecreasingDepth` and the set `containerNodes`.\n *\n * @param tensor Some tensor in a graph.\n * @param finishedNodes Set of nodes whose subgraphs have been traversed\n * completely. Useful to prevent duplicated work.\n * @param nodesInProgress Set of nodes that are currently active on the\n * recursion stack. Useful to detect cycles.\n * @param layer Layer from which `tensor` comes from. If not provided,\n * will be obtained from tensor.sourceLayer.\n * @param nodeIndex Node index from which `tensor` comes from.\n * @param tensorIndex TensorIndex from which `tensor` comes from.\n *\n * @exception RuntimeError if a cycle is detected.\n */\n const buildMapOfGraph =\n (tensor: SymbolicTensor, finishedNodes: Node[], nodesInProgress: Node[],\n layer?: Layer, nodeIndex?: number, tensorIndex?: number) => {\n if (layer == null || nodeIndex == null || tensorIndex == null) {\n layer = tensor.sourceLayer as Layer;\n nodeIndex = tensor.nodeIndex;\n tensorIndex = tensor.tensorIndex;\n }\n const node = layer.inboundNodes[nodeIndex];\n\n // Prevent cycles.\n if (nodesInProgress.indexOf(node) !== -1) {\n throw new RuntimeError(\n `The tensor ${tensor.name} at layer \"${layer.name}\" ` +\n 'is part of a cycle.');\n }\n\n // Don't repeat work for shared subgraphs\n if (finishedNodes.indexOf(node) !== -1) {\n return;\n }\n\n // Update containerNodes.\n this.containerNodes.add(Container.nodeKey(layer, nodeIndex));\n\n // Store the traversal order for layer sorting.\n if (!(layer.id in layerIndices)) {\n layerIndices[layer.id] = Object.keys(layerIndices).length;\n }\n\n if (nodesInProgress.indexOf(node) === -1) {\n nodesInProgress.push(node);\n }\n\n // Propagate to all previous tensors connected to this node.\n const numInboundLayers = node.inboundLayers.length;\n for (let i = 0; i < numInboundLayers; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n buildMapOfGraph(\n x, finishedNodes, nodesInProgress, layer, nodeIndex,\n tensorIndex);\n }\n finishedNodes.push(node);\n while (nodesInProgress.indexOf(node) >= 0) {\n nodesInProgress.splice(nodesInProgress.indexOf(node), 1);\n }\n nodesInDecreasingDepth.push(node);\n };\n\n const finishedNodes: Node[] = [];\n const nodesInProgress: Node[] = [];\n for (const x of this.outputs) {\n buildMapOfGraph(x, finishedNodes, nodesInProgress);\n }\n\n const reversedNodesInDecreasingDepth =\n nodesInDecreasingDepth.slice().reverse();\n for (const node of reversedNodesInDecreasingDepth) {\n nodeIDToNode[node.id] = node;\n // If the depth is not set, the node has no outbound nodes (depth 0).\n if (!(node.id in nodesDepths)) {\n nodesDepths[node.id] = 0;\n }\n let depth = nodesDepths[node.id];\n\n // Update the depth of the corresponding layer\n const previousDepth =\n (layersDepths[node.outboundLayer.id] == null ?\n 0 :\n layersDepths[node.outboundLayer.id]);\n\n /*\n If we've seen this layer before at a higher depth, we should use that\n depth instead of the node depth. This is necessary for shared layers\n that have inputs at different depth levels in the graph.\n */\n depth = Math.max(depth, previousDepth);\n layersDepths[node.outboundLayer.id] = depth;\n layerIDToLayer[node.outboundLayer.id] = node.outboundLayer;\n nodesDepths[node.id] = depth;\n\n // Update the depth of inbound nodes.\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const inboundNode = inboundLayer.inboundNodes[nodeIndex];\n const previousDepth =\n (nodesDepths[inboundNode.id] == null ? 0 :\n nodesDepths[inboundNode.id]);\n nodesDepths[inboundNode.id] = Math.max(depth + 1, previousDepth);\n nodeIDToNode[inboundNode.id] = inboundNode;\n }\n }\n\n // Build a dict {depth: list of nodes with this depth}\n const nodesByDepth: {[depth: string]: Node[]} = {};\n for (const nodeID in nodesDepths) {\n const depth = nodesDepths[nodeID];\n if (!(depth in nodesByDepth)) {\n nodesByDepth[depth] = [];\n }\n nodesByDepth[depth].push(nodeIDToNode[nodeID]);\n }\n\n // Build a dict {depth: list of layers with this depth}\n const layersByDepth: {[depth: string]: Layer[]} = {};\n for (const layerID in layersDepths) {\n const depth = layersDepths[layerID];\n if (!(depth in layersByDepth)) {\n layersByDepth[depth] = [];\n }\n layersByDepth[depth].push(layerIDToLayer[layerID]);\n }\n\n // Get sorted list of layer depths.\n let depthKeys = Object.keys(layersByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Set this.layers and this.layersByDepth.\n this.layers = [];\n for (const depth of depthKeys) {\n const layersForDepth = layersByDepth[depth];\n // Container.layers needs to have a deterministic order:\n // here we order them by traversal order.\n layersForDepth.sort((a, b) => {\n const aIndex = layerIndices[a.id];\n const bIndex = layerIndices[b.id];\n if (aIndex < bIndex) {\n return -1;\n }\n if (aIndex > bIndex) {\n return 1;\n }\n return 0;\n });\n for (const layer of layersForDepth) {\n this.layers.push(layer);\n }\n }\n this.layersByDepth = layersByDepth;\n\n // Get sorted list of node depths;\n depthKeys = Object.keys(nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Check that all tensors required are computable.\n // computable_tensors: all tensors in the graph\n // that can be computed from the inputs provided.\n const computableTensors = this.inputs.slice();\n\n // To provide a better error msg.\n const layersWithCompleteInput: string[] = [];\n for (const depth of depthKeys) {\n for (const node of nodesByDepth[depth]) {\n const layer = node.outboundLayer;\n if (layer != null) {\n for (const x of node.inputTensors) {\n if (computableTensors.indexOf(x) === -1) {\n throw new RuntimeError(\n `Graph disconnected: cannot obtain value for tensor ${x}` +\n ` at layer \"${layer.name}\". ` +\n 'The following previous layers were accessed without ' +\n `issue: ${layersWithCompleteInput}`);\n }\n }\n for (const x of node.outputTensors) {\n computableTensors.push(x);\n }\n layersWithCompleteInput.push(layer.name);\n }\n }\n }\n\n // Set this.containerNodes and this.nodesByDepth.\n this.nodesByDepth = nodesByDepth;\n\n // Ensure name unicity, which will be crucial for serialization\n // (since serialized nodes refer to layers by their name).\n const allNames = this.layers.map(x => x.name);\n for (const name of allNames) {\n const numOccurrences = allNames.filter(x => x === name).length;\n if (numOccurrences !== 1) {\n throw new RuntimeError(\n `The name \"${name}\" is used ${numOccurrences} times ` +\n 'in the model. All layer names should be unique. Layer names: ' +\n JSON.stringify(allNames));\n }\n }\n\n // Layer parameters.\n // The new container starts with a single inbound node\n // for its inputs, and no outbound nodes.\n // Will be appended to by future calls to apply().\n this.outboundNodes = [];\n // Will be appended to below, and by future calls to apply().\n this.inboundNodes = [];\n\n // Create the node linking internal inputs to internal outputs.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n inputMasks: this.inputs.map(x => null),\n outputMasks: this.outputs.map(x => null),\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs.map(x => x.shape)\n });\n this.built = true;\n }\n\n get trainableWeights(): LayerVariable[] {\n // Porting Note: This check below is to prevent errors where the\n // _trainableWeights inherited from the parent class (Layer) gets\n // inadvertently used.\n if (this._trainableWeights.length > 0) {\n throw new ValueError(\n 'Container instance unexpectedly contains _trainableWeights.' +\n 'The trainable weights of a Container are a union of the ' +\n 'trainable weights of its consituent Layers. Its own ' +\n '_trainableWeights must remain an empty Array.');\n }\n\n if (!this.trainable) {\n return [];\n }\n let weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights = weights.concat(layer.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights.push(...layer.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const layer of this.layers) {\n trainableWeights.push(...layer.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n /**\n * Loads all layer weights from a JSON object.\n *\n * Porting Note: HDF5 weight files cannot be directly loaded in JavaScript /\n * TypeScript. The utility script at `scripts/pykeras.py` offers means\n * to convert them into JSON strings compatible with this method.\n * Porting Note: TensorFlow.js Layers supports only loading by name currently.\n *\n * @param weightsJSON A JSON mapping weight names to weight values as nested\n * arrays of numbers, or a `NamedTensorMap`, i.e., a JSON mapping weight\n * names to `Tensor` objects.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weight (only valid when `by_name`=True).\n * @param isNamedTensorMap Whether the 1st argument (`weightsJSON`) is a\n * `NamedTensorMap`.\n */\n loadWeights(\n weightsJSON: JsonDict|NamedTensorMap, skipMismatch = false,\n isNamedTensorMap = false) {\n // TODO(cais): Maybe the JsonDict support should be removed after serving\n // weights from XHR is working. If so, the `loadWeightsFromJson` flag\n // should be removed as well. (b/74015805)\n // TODO(cais): See if we can use smarter type resolution to avoid sending\n // the type info as a separate arg (isNamedTensormap).\n if (isNamedTensorMap) {\n loadWeightsFromNamedTensorMap(weightsJSON as NamedTensorMap, this.layers);\n } else {\n loadWeightsFromJson(weightsJSON as JsonDict, this.layers, skipMismatch);\n }\n }\n\n /**\n * Util shared between different serialization methods.\n * @returns Model config with Keras version information added.\n */\n private updatedConfig(): serialization.ConfigDict {\n const theConfig = this.getConfig();\n const modelConfig: serialization.ConfigDict = {\n className: this.getClassName(),\n config: theConfig,\n kerasVersion: `tfjs-layers ${layersVersion}`,\n // TODO(nielsene): Replace something like K.backend() once\n // possible.\n backend: 'TensorFlow.js'\n };\n return modelConfig;\n }\n\n /**\n * Returns a JSON string containing the network configuration.\n *\n * To load a network from a JSON save file, use\n * models.modelFromJSON(jsonString);\n * @param extraJsonArgs Unused in tfjs-layers, maintained for PyKeras\n * @param returnString Whether the return value should be stringified\n * (default: `true`).\n * @returns a JSON string if `returnString` (default), or a JSON object if\n * `!returnString`.\n */\n // tslint:disable-next-line:no-any\n toJSON(unused?: any, returnString = true): string|JsonDict {\n const modelConfig = convertTsToPythonic(this.updatedConfig()) as JsonDict;\n return returnString ? JSON.stringify(modelConfig) : modelConfig;\n }\n\n /**\n * Call the model on new inputs.\n *\n * In this case `call` just reapplies all ops in the graph to the new inputs\n * (e.g. build a new computational graph from the provided inputs).\n *\n * @param inputs A tensor or list of tensors.\n * @param mask A mask or list of masks. A mask can be either a tensor or null\n * (no mask).\n *\n * @return A tensor if there is a single output, or a list of tensors if there\n * are more than one outputs.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n\n if ('mask' in kwargs) {\n masks = generic_utils.toList(kwargs['mask']);\n } else {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n // TODO(michaelterry): Add support for caching.\n return this.runInternalGraph(inputs, masks)[0];\n });\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n if (mask == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n } else {\n masks = generic_utils.toList(mask);\n }\n // TODO(michaelterry): Add support for mask caching.\n return this.runInternalGraph(inputs, masks)[1];\n });\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n const inputShapes = types_utils.normalizeShapeList(inputShape);\n if (inputShapes.length !== this.inputLayers.length) {\n throw new ValueError(\n `Invalid inputShape argument ${inputShape}: ` +\n `model has ${this.inputLayers.length} tensor inputs.`);\n }\n\n // TODO(michaelterry): Add caching\n const layersToOutputShapes: {[shapeKey: string]: Shape} = {};\n for (let i = 0; i < inputShapes.length; i++) {\n const layer = this.inputLayers[i];\n const inputShape = inputShapes[i];\n // It's an input layer: computeOutputShape is identity,\n // and there is only one node and one tensor output.\n const shapeKey = layer.name + '_0_0';\n layersToOutputShapes[shapeKey] = inputShape;\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n // Iterate over nodes, by depth level.\n if (depthKeys.length > 1) {\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n if (this.inputLayers.map(x => x.id).indexOf(layer.id) !== -1) {\n // We've already covered the input layers a few lines above.\n continue;\n }\n // Potentially redundant list, same size of node.inputTensors.\n const inputShapes: Shape[] = [];\n for (let j = 0; j < node.inboundLayers.length; j++) {\n const inboundLayer = node.inboundLayers[j];\n const nodeIndex = node.nodeIndices[j];\n const tensorIndex = node.tensorIndices[j];\n const shapeKey = `${inboundLayer.name}_${nodeIndex}_${tensorIndex}`;\n const inputShape = layersToOutputShapes[shapeKey];\n inputShapes.push(inputShape);\n }\n\n const outputShape = layer.computeOutputShape(\n generic_utils.singletonOrArray(inputShapes));\n\n const outputShapes = types_utils.normalizeShapeList(outputShape);\n const nodeIndex = layer.inboundNodes.indexOf(node);\n for (let j = 0; j < outputShapes.length; j++) {\n const shapeKey = `${layer.name}_${nodeIndex}_${j}`;\n layersToOutputShapes[shapeKey] = outputShapes[j];\n }\n }\n }\n }\n\n // Read final output shapes from layersToOutputShapes.\n const outputShapes: Shape[] = [];\n const outputShapeKeys: string[] = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n const tensorIndex = this.outputLayersTensorIndices[i];\n const shapeKey = `${layer.name}_${nodeIndex}_${tensorIndex}`;\n outputShapeKeys.push(shapeKey);\n }\n\n for (let i = 0; i < outputShapeKeys.length; i++) {\n const key = outputShapeKeys[i];\n generic_utils.assert(key in layersToOutputShapes);\n outputShapes.push(layersToOutputShapes[key]);\n }\n\n // TODO(michaelterry): Update cache\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n /**\n * Computes output tensors for new inputs.\n *\n * Note:\n * - Expects `inputs` to be a list (potentially with 1 element).\n *\n * @param inputs List of tensors\n * @param masks List of masks (tensors or null).\n * @return Three lists: outputTensors, outputMasks, outputShapes\n */\n protected runInternalGraph(inputs: Tensor[], masks?: Tensor[]):\n [Tensor[], Tensor[], Shape[]] {\n if (masks == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n\n // Dictionary mapping reference tensors to tuples\n // (computed tensor, compute mask)\n // we assume a 1:1 mapping from tensor to mask\n // TODO: raise exception when a `.computeMask()` call\n // does not return a list the same size as `call`\n const tensorMap: {[tensorID: string]: [Tensor, Tensor]} = {};\n for (let i = 0; i < this.inputs.length; ++i) {\n const x = this.inputs[i];\n const y = inputs[i];\n const mask = masks[i];\n tensorMap[x.id] = [y, mask];\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n const referenceInputTensors = node.inputTensors;\n const referenceOutputTensors = node.outputTensors;\n\n // If all previous input tensors are available in tensorMap,\n // then call node.inboundLayer on them.\n // List of tuples [input, mask]:\n const computedData = new Array<[Tensor, Tensor]>();\n for (const x of referenceInputTensors) {\n if (x.id in tensorMap) {\n computedData.push(tensorMap[x.id]);\n }\n }\n if (computedData.length === referenceInputTensors.length) {\n // TODO(michaelterry): Add K.name_scope here, if we need it.\n let kwargs: Kwargs = {};\n let computedTensors: Tensor[];\n let computedMasks: Tensor[];\n let outputTensors: Tensor[];\n let outputMasks: Tensor[];\n // call layer\n if (node.callArgs != null) {\n kwargs = node.callArgs;\n }\n if (computedData.length === 1) {\n const [computedTensor, computedMask] = computedData[0];\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMask;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensor, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensor, computedMask));\n computedTensors = [computedTensor];\n computedMasks = [computedMask];\n } else {\n computedTensors = computedData.map(x => x[0]);\n computedMasks = computedData.map(x => x[1]);\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMasks;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensors, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensors, computedMasks));\n }\n\n if (layer.activityRegularizer) {\n throw new NotImplementedError(\n 'Model invocation with concrete Tensor value(s) in the ' +\n 'presence of activity regularizer(s) is not supported yet.');\n }\n // TODO(michaelterry): Add model updates and losses\n\n // Update tensor map.\n for (let i = 0; i < referenceOutputTensors.length; ++i) {\n const x = referenceOutputTensors[i];\n const y = outputTensors[i];\n const mask = outputMasks[i];\n tensorMap[x.id] = [y, mask];\n }\n }\n }\n }\n\n const outputTensors: Tensor[] = [];\n const outputMasks: Tensor[] = [];\n const outputShapes: Shape[] = [];\n for (const x of this.outputs) {\n generic_utils.assert(\n x.id in tensorMap, `Could not compute output ${x.name} : ${x.id}`);\n const [tensor, mask] = tensorMap[x.id];\n outputShapes.push(tensor.shape);\n outputTensors.push(tensor);\n outputMasks.push(mask);\n }\n\n // TODO(michaelterry): Add support for caches.\n return [outputTensors, outputMasks, outputShapes];\n }\n\n /**\n * Builds a map of internal node keys to node ordering.\n * Used in serializaion a node orderings may change as unused nodes are\n * dropped. Porting Note: This helper method was pulled out of getConfig to\n * improve readability.\n * @param layers An array of Layers in the model.\n * @returns Map of Node Keys to index order within the layer.\n */\n private buildNodeConversionMap(layers: Layer[]): {[nodeKey: string]: number} {\n const nodeConversionMap: {[nodeKey: string]: number} = {};\n let keptNodes: number;\n for (const layer of this.layers) {\n keptNodes = layer instanceof Container ? 1 : 0;\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n if (nodeKey in this.containerNodes) {\n // i.e. we mark it to be saved\n nodeConversionMap[nodeKey] = keptNodes;\n keptNodes += 1;\n }\n }\n }\n return nodeConversionMap;\n }\n\n /**\n * Retrieves a layer based on either its name (unique) or index.\n *\n * Indices are based on order of horizontal graph traversal (bottom-up).\n *\n * If both `name` and `index` are specified, `index` takes precedence.\n *\n * @param name Name of layer.\n * @param index Index of layer.\n * @returns A Layer instance.\n * @throws ValueError: In case of invalid layer name or index.\n */\n /**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Classes',\n * namespace: 'layers',\n * subclasses: ['Model']\n * }\n */\n getLayer(name?: string, index?: number): Layer {\n if (index != null) {\n if (this.layers.length <= index) {\n throw new ValueError(\n `Was asked to retrieve layer at index ${index}, but model only ` +\n `has ${this.layers.length} layer(s).`);\n } else {\n return this.layers[index];\n }\n } else {\n if (name == null) {\n throw new ValueError('Provide either a layer name or layer index');\n }\n }\n\n for (const layer of this.layers) {\n if (layer.name === name) {\n return layer;\n }\n }\n throw new ValueError(`No such layer: ${name}`);\n }\n\n /**\n * Retrieves the Container's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Container.loss in PyKeras.\n // In PyKeras, Container.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return tidy(() => {\n const losses: Scalar[] = [];\n for (const layer of this.layers) {\n for (let nodeIndex = 0; nodeIndex < layer.inboundNodes.length;\n ++nodeIndex) {\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (this.containerNodes.has(nodeKey)) {\n losses.push(...layer.calculateLosses());\n }\n }\n }\n // TODO(cais): Add any unconditional model-level losses?\n return losses;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {name: this.name};\n\n // Build a map from layer unique name (self._node_key)\n // to the index of the nodes that are saved in the config.\n // Only nodes in container_nodes are saved.\n const nodeConversionMap: {[nodeKey: string]: number} =\n this.buildNodeConversionMap(this.layers);\n\n // Serialize and save the layers in layerConfigs\n const layerConfigs = [];\n for (const layer of this.layers) {\n const layerClassName = layer.getClassName();\n const layerConfig = layer.getConfig();\n const filteredInboundNodes = [];\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const node = layer.inboundNodes[originalNodeIndex];\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n let kwargs = {};\n if (this.containerNodes.has(nodeKey)) {\n // The node is relevant to the model:\n // add to filteredInboundNodes.\n if (node.callArgs) {\n try {\n JSON.stringify(node.callArgs);\n kwargs = node.callArgs;\n } catch (err) {\n console.warn(\n `Layer ${layer.name} was passed ` +\n `non-serializable keyword arguments: ` +\n `${node.callArgs}. They will not be included ` +\n `in the serialized model (and thus will be ` +\n `missing at deserialization time).`);\n kwargs = {};\n }\n }\n if (node.inboundLayers.length > 0) {\n const nodeData = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n const nodeKey = Container.nodeKey(inboundLayer, nodeIndex);\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n nodeData.push(\n [inboundLayer.name, newNodeIndex, tensorIndex, kwargs]);\n }\n filteredInboundNodes.push(nodeData);\n }\n }\n }\n layerConfigs.push({\n name: layer.name,\n className: layerClassName,\n config: layerConfig,\n inboundNodes: filteredInboundNodes\n });\n }\n config['layers'] = layerConfigs;\n // Gather info about inputs and outputs\n const modelInputs = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n const nodeIndex = this.inputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.inputLayersTensorIndices[i];\n modelInputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['inputLayers'] = modelInputs;\n\n const modelOutputs = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.outputLayersTensorIndices[i];\n modelOutputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['outputLayers'] = modelOutputs;\n return config;\n }\n\n /**\n * Instantiates a Model from its config (output of `get_config()`).\n * @param cls: the class to create\n * @param config: Model config dictionary.\n * @returns A model instance.\n * @throws ValueError: In case of improperly formatted config dict.\n */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n // Layer instances created during\n // the graph reconstruction process\n const createdLayers: {[layerName: string]: Layer} = {};\n\n // Dictionary mapping layer instances to\n // node data that specifies a layer call.\n // It acts as a queue that maintains any unprocessed\n // layer call until it becomes possible to process it\n // (i.e. until the input tensors to the call all exist).\n const unprocessedNodes:\n {[layer: string]: serialization.ConfigDict[][]} = {};\n function addUnprocessedNode(\n layer: Layer, nodeData: serialization.ConfigDict[]) {\n if (!(layer.name in unprocessedNodes)) {\n unprocessedNodes[layer.name] = [nodeData];\n } else {\n unprocessedNodes[layer.name].push(nodeData);\n }\n }\n\n function processNode(layer: Layer, nodeData: serialization.ConfigDict[]) {\n const inputTensors: SymbolicTensor[] = [];\n let kwargs;\n for (const inputData of nodeData) {\n const inboundLayerName = inputData[0] as string;\n const inboundNodeIndex = inputData[1] as number;\n const inboundTensorIndex = inputData[2] as number;\n if (inputData.length === 3) {\n kwargs = {};\n } else if (inputData.length === 4) {\n kwargs = inputData[3] as serialization.ConfigDict;\n } else {\n throw new ValueError(`Improperly formatted model config for layer ${\n JSON.stringify(layer)}: ${JSON.stringify(inputData)}`);\n }\n if (!(inboundLayerName in createdLayers)) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundLayer = createdLayers[inboundLayerName];\n if (inboundLayer.inboundNodes.length <= inboundNodeIndex) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundNode = inboundLayer.inboundNodes[inboundNodeIndex];\n inputTensors.push(inboundNode.outputTensors[inboundTensorIndex]);\n }\n // Call layer on its inputs, thus creating the node\n // and building the layer if needed.\n // Note: This has Eager vs Graph Implications.\n if (inputTensors.length > 0) {\n layer.apply(\n generic_utils.singletonOrArray(inputTensors),\n kwargs); // was ** kwargs\n }\n }\n\n /**\n * Deserialize a layer, then call it on appropriate inputs.\n * @param layerData: layer config dict.\n * @throws ValueError: In case of improperly formatted `layer_data`\n * dict.\n */\n function processLayer(layerData: serialization.ConfigDict|null) {\n const layerName = layerData.name as string;\n // Instantiate layer.\n const layer = deserializeLayer(\n layerData,\n config.customObjects != null ?\n config.customObjects as serialization.ConfigDict :\n {}) as Layer;\n createdLayers[layerName] = layer;\n // Gather layer inputs.\n const inboundNodesData =\n layerData.inboundNodes as serialization.ConfigDict[];\n for (const nodeData of inboundNodesData) {\n if (!(nodeData instanceof Array)) {\n throw new ValueError(\n `Corrupted configuration, expected array for nodeData: ${\n nodeData}`);\n }\n // We don't process nodes (i.e. make layer calls)\n // on the fly because the inbound node may not yet exist,\n // in case of layer shared at different topological depths\n // (e.g.a model such as A(B(A(B(x)))))\n addUnprocessedNode(layer, nodeData);\n }\n }\n\n // First, we create all layers and enqueue nodes to be processed\n const name = config.name;\n const layersFromConfig = config.layers as serialization.ConfigDict[];\n for (const layerData of layersFromConfig) {\n processLayer(layerData);\n }\n\n // Then we process nodes in order of layer depth.\n // Nodes that cannot yet be processed(if the inbound node\n // does not yet exist) are re - enqueued, and the process\n // is repeated until all nodes are processed.\n while (!generic_utils.isObjectEmpty(unprocessedNodes)) {\n for (const layerData of layersFromConfig) {\n const layer = createdLayers[layerData.name as string];\n if (layer.name in unprocessedNodes) {\n for (const nodeData of unprocessedNodes[layer.name]) {\n processNode(layer, nodeData);\n }\n delete unprocessedNodes[layer.name];\n }\n }\n }\n const inputTensors: SymbolicTensor[] = [];\n const outputTensors: SymbolicTensor[] = [];\n const inputLayersFromConfig =\n config.inputLayers as serialization.ConfigDict[];\n for (const layerData of inputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n inputTensors.push(layerOutputTensors[tensorIndex]);\n }\n const outputLayersFromConfig =\n config.outputLayers as serialization.ConfigDict[];\n for (const layerData of outputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n outputTensors.push(layerOutputTensors[tensorIndex]);\n }\n return new cls({inputs: inputTensors, outputs: outputTensors, name});\n }\n\n /**\n * Determine whether the container is stateful.\n *\n * Porting Note: this is the equivalent of the stateful @property of\n * the Container class in PyKeras.\n */\n get stateful(): boolean {\n // Porting Note: This check is to prevent inadvertent setting of the\n // _stateful property of the Container instance.\n if (this._stateful) {\n throw new ValueError(\n 'Container instance unexpectedly has _stateful = true. The ' +\n 'statefulness of a Container is determined by the Layers it ' +\n 'contains. Its _stateful property must remain the default false.');\n }\n for (const layer of this.layers) {\n if (layer.stateful) {\n return true;\n }\n }\n return false;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Executor: Evaluates SymbolicTensor based on feeds.\n */\n\nimport {cast, Tensor} from '@tensorflow/tfjs-core';\n\nimport {ValueError} from '../errors';\nimport {Kwargs} from '../types';\n\nimport {InputLayer} from './input_layer';\nimport {SymbolicTensor} from './topology';\n\n/**\n * Helper function to check the dtype and shape compatibility of a feed value.\n */\nfunction assertFeedCompatibility(key: SymbolicTensor, val: Tensor): Tensor {\n // 1. Check shape compatibility. If shapes are not compatible, error.\n if (key.shape != null) {\n if (key.shape.length !== val.shape.length) {\n throw new ValueError(\n `The rank of feed (${val.shape.length}) does not match the rank of ` +\n `the key (${key.shape.length}).`);\n }\n\n for (let i = 0; i < key.shape.length; ++i) {\n if (key.shape[i] != null && key.shape[i] !== val.shape[i]) {\n throw new ValueError(\n `The ${i}-th dimension of the feed (${val.shape[i]}) is ` +\n `incompatible with that of the key (${key.shape[i]}).`);\n }\n }\n }\n // 2. Check dtype compatibility.\n if (key.dtype == null || key.dtype === val.dtype) {\n // 2a. If types match, return val tensor as is.\n return val;\n }\n try {\n // 2b. Attempt to convert to expected type.\n return cast(val, key.dtype);\n } catch (err) {\n // 2c. If conversion fails, return helpful error.\n throw new ValueError(\n `The dtype of the feed (${val.dtype}) can not be cast to the dtype ` +\n `of the key '${key.name}' (${key.dtype}).`);\n }\n}\n\n/**\n * A concrete Tensor value for a symbolic tensor as the key.\n */\nexport interface Feed {\n key: SymbolicTensor;\n value: Tensor;\n}\n\n/**\n * FeedDict: A mapping from unique SymbolicTensors to feed values for them.\n * A feed value is a concrete value represented as an `Tensor`.\n */\nexport class FeedDict {\n private id2Value: {[id: number]: Tensor} = {};\n\n /**\n * Constructor, optionally does copy-construction.\n * @param feeds An Array of `Feed`s, or another `FeedDict`, in which case\n * copy-construction will be performed.\n */\n constructor(feeds?: Feed[]|FeedDict) {\n if (feeds instanceof FeedDict) {\n for (const id in feeds.id2Value) {\n this.id2Value[id] = feeds.id2Value[id];\n }\n } else {\n if (feeds == null) {\n return;\n }\n for (const feed of feeds) {\n this.add(feed.key, feed.value);\n }\n }\n }\n\n /**\n * Add a key-value pair to the FeedDict.\n * @param key The key of the feed.\n * @param value The value of the feed.\n * @returns This `FeedDict`.\n * @throws ValueError: If the key `SymbolicTensor` already exists in the\n * `FeedDict`.\n */\n add(key: SymbolicTensor, value: Tensor): FeedDict {\n if (this.id2Value[key.id] == null) {\n this.id2Value[key.id] = assertFeedCompatibility(key, value);\n } else {\n throw new ValueError(`Duplicate key: name=${key.name}, id=${key.id}`);\n }\n return this;\n }\n\n /**\n * Add a Feed to the FeedDict.\n * @param feed The new `Feed` to add.\n * @returns This `FeedDict`.\n */\n addFeed(feed: Feed) {\n this.add(feed.key, feed.value);\n }\n\n /**\n * Probe whether a key already exists in the FeedDict.\n * @param key\n */\n hasKey(key: SymbolicTensor): boolean {\n return this.id2Value[key.id] != null;\n }\n\n /**\n * Get the feed value for given key.\n * @param key\n * @returns If `key` exists, the corresponding feed value.\n * @throws ValueError: If `key` does not exist in this `FeedDict`.\n */\n getValue(key: SymbolicTensor): Tensor {\n if (this.id2Value[key.id] == null) {\n throw new ValueError(`Nonexistent key: ${JSON.stringify(key)}`);\n } else {\n return this.id2Value[key.id];\n }\n }\n}\n\n/**\n * Execute a SymbolicTensor by using concrete feed values.\n *\n * A `SymbolicTensor` object is a node in a computation graph of TF.js\n * Layers. The object is backed by a source layer and input\n * `SymbolicTensor`s to the source layer. This method evaluates\n * the `call()` method of the source layer, using concrete values of the inputs\n * obtained from either\n * * `feedDict`, if the input key exists in `feedDict`, or else,\n * * a recursive call to `execute()` itself.\n *\n * @param x: The `SymbolicTensor` to execute.\n * @param feedDict: The feed values, as base condition of the recursion.\n * execution.\n * @param kwargs: Optional keyword arguments.\n * @returns Result of the execution.\n * @throws ValueError: If any `SymbolicTensor`s from `InputLayer`s\n * encountered during the execution lacks a feed value in `feedDict`.\n */\nexport function execute(\n fetches: SymbolicTensor|SymbolicTensor[], feedDict: FeedDict,\n kwargs?: Kwargs): Tensor|Tensor[]|[Tensor | Tensor[]] {\n const arrayFetches = Array.isArray(fetches);\n const fetchArray: SymbolicTensor[] =\n arrayFetches ? fetches as SymbolicTensor[] : [fetches as SymbolicTensor];\n\n const outputs: Tensor[] = [];\n const internalFeedDict = new FeedDict(feedDict);\n\n for (const fetch of fetchArray) {\n outputs.push(executeInternal(fetch, internalFeedDict, kwargs) as Tensor);\n }\n return arrayFetches ? outputs : outputs[0];\n}\n\nfunction executeInternal(\n fetch: SymbolicTensor, internalFeedDict: FeedDict,\n kwargs?: Kwargs): Tensor {\n if (internalFeedDict.hasKey(fetch)) {\n return internalFeedDict.getValue(fetch);\n }\n if (fetch.sourceLayer instanceof InputLayer) {\n throw new ValueError(\n `Missing a feed value for SymbolicTensor from InputLayer ` +\n `'${InputLayer.name}'`);\n }\n\n const inputs = fetch.inputs;\n const inputValues: Tensor[] = [];\n for (const input of inputs) {\n // Recursive call.\n const inputVal = executeInternal(input, internalFeedDict, kwargs) as Tensor;\n inputValues.push(inputVal);\n }\n\n let output =\n fetch.sourceLayer.apply(inputValues, kwargs) as Tensor | Tensor[];\n if (!Array.isArray(output)) {\n output = [output];\n }\n const layerOutputs = getNodeOutputs(fetch);\n const outputSymbolicTensors =\n Array.isArray(layerOutputs) ? layerOutputs : [layerOutputs];\n for (let i = 0; i < outputSymbolicTensors.length; ++i) {\n internalFeedDict.add(outputSymbolicTensors[i], output[i]);\n }\n return output.length === 1 ? output[0] : output[fetch.outputTensorIndex];\n}\n\n/**\n * Get the symbolic output tensors of the node to which a given fetch belongs.\n * @param fetch The fetched symbolic tensor.\n * @returns The Array of symbolic tensors output by the node to which `fetch`\n * belongs.\n */\nfunction getNodeOutputs(fetch: SymbolicTensor): SymbolicTensor|\n SymbolicTensor[] {\n let layerOutputs: SymbolicTensor|SymbolicTensor[];\n if (fetch.sourceLayer.inboundNodes.length === 1) {\n layerOutputs = fetch.sourceLayer.output;\n } else {\n let nodeIndex: number = null;\n for (let i = 0; i < fetch.sourceLayer.inboundNodes.length; ++i) {\n for (const outputTensor of fetch.sourceLayer.inboundNodes[i]\n .outputTensors) {\n if (outputTensor.id === fetch.id) {\n nodeIndex = i;\n break;\n }\n }\n }\n layerOutputs = fetch.sourceLayer.getOutputAt(nodeIndex);\n }\n return layerOutputs;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: engine/training.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {io, ModelPredictConfig, Optimizer, Scalar, serialization, Tensor, Tensor1D, tensor1d, util} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {BaseCallback, BaseLogger, CallbackList, CustomCallbackConfig, History, standardizeCallbacks} from '../base_callbacks';\nimport {nameScope} from '../common';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {disposeTensorsInLogs, UnresolvedLogs} from '../logs';\nimport * as losses from '../losses';\nimport * as Metrics from '../metrics';\nimport * as optimizers from '../optimizers';\nimport {LossOrMetricFn, NamedTensorMap, Shape} from '../types';\nimport {count, pyListRepeat, singletonOrArray, unique} from '../utils/generic_utils';\nimport {printSummary} from '../utils/layer_utils';\nimport {range} from '../utils/math_utils';\nimport {LayerVariable} from '../variables';\n\nimport {Container, ContainerConfig} from './container';\nimport {execute, FeedDict} from './executor';\nimport {SymbolicTensor} from './topology';\n\n// tslint:enable:max-line-length\n\n/**\n * Helper function for polymorphic input data: 1. singleton Tensor.\n */\nexport function isDataTensor(x: Tensor|Tensor[]|{[inputName: string]: Tensor}|\n {[inputName: string]: Tensor[]}): boolean {\n return x instanceof Tensor;\n}\n\n/**\n * Helper function for polymorphic input data: 2. Array of Tensor.\n */\nexport function isDataArray(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return Array.isArray(x);\n}\n\n/**\n * Helper function for polymorphic input data: 3. \"dict\" of Tensor.\n */\nexport function isDataDict(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return !isDataTensor(x) && !isDataArray(x);\n}\n\n/**\n * Normalizes inputs and targets provided by users.\n * @param data User-provided input data (polymorphic).\n * @param names An Array of expected Tensor names.\n * @param shapes Optional Array of expected Tensor shapes.\n * @param checkBatchAxis Whether to check that the batch axis of the arrays\n * match the expected value found in `shapes`.\n * @param exceptionPrefix String prefix used for exception formatting.\n * @returns List of standardized input Tensors (one Tensor per model input).\n * @throws ValueError: in case of improperly formatted user data.\n */\nexport function standardizeInputData(\n data: Tensor|Tensor[]|{[inputName: string]: Tensor}, names: string[],\n shapes?: Shape[], checkBatchAxis = true, exceptionPrefix = ''): Tensor[] {\n if (names == null || names.length === 0) {\n // Check for the case where the model expected no data, but some data got\n // sent.\n if (data != null) {\n let gotUnexpectedData = false;\n if (isDataArray(data) && (data as Tensor[]).length > 0) {\n gotUnexpectedData = true;\n } else if (isDataDict(data)) {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n gotUnexpectedData = true;\n break;\n }\n }\n } else {\n // `data` is a singleton Tensor in this case.\n gotUnexpectedData = true;\n }\n if (gotUnexpectedData) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix} expected no data, ` +\n `but got ${data}`);\n }\n }\n return [];\n }\n if (data == null) {\n return names.map(name => null);\n }\n\n let arrays: Tensor[];\n if (isDataDict(data)) {\n data = data as {[inputName: string]: Tensor};\n arrays = [];\n for (const name of names) {\n if (data[name] == null) {\n throw new ValueError(\n `No data provided for \"${name}\". Need data for each key in: ` +\n `${names}`);\n }\n arrays.push(data[name]);\n }\n } else if (isDataArray(data)) {\n data = data as Tensor[];\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `model expected. Expected to see ${names.length} Tensor(s), but ` +\n `instead got the following list of Tensor(s): ${data}`);\n }\n arrays = data;\n } else {\n data = data as Tensor;\n if (names.length > 1) {\n throw new ValueError(\n `The model ${exceptionPrefix} expects ${names.length} Tensor(s), ` +\n `but only received one Tensor. Found: Tensor with shape ${\n data.shape}`);\n }\n arrays = [data];\n }\n\n // Make Tensors at least 2D.\n for (let i = 0; i < names.length; ++i) {\n const array = arrays[i];\n if (array.shape.length === 1) {\n arrays[i] = K.expandDims(array, 1);\n }\n }\n\n // Check shape compatibility.\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s). but got array with ` +\n `shape ${array.shape}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n // Skip the first (batch) axis.\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null && refDim >= 0 && dim !== refDim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have shape [${shapes[i]}], but got array with shape ` +\n `[${array.shape}].`);\n }\n }\n }\n }\n return arrays;\n}\n\n/**\n * User input validation for Tensors.\n * @param inputs `Array` of `Tensor`s for inputs.\n * @param targets `Array` of `Tensor`s for targets.\n * @param weights Optional `Array` of `Tensor`s for sample weights.\n * @throws ValueError: in case of incorrectly formatted data.\n */\nexport function checkArrayLengths(\n inputs: Tensor[], targets: Tensor[], weights?: Tensor[]) {\n const setX = unique(inputs.map(input => input.shape[0]));\n setX.sort();\n const setY = unique(targets.map(target => target.shape[0]));\n setY.sort();\n // TODO(cais): Check `weights` as well.\n if (setX.length > 1) {\n throw new ValueError(\n `All input Tensors (x) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(inputs.map(input => input.shape))}`);\n }\n if (setY.length > 1) {\n throw new ValueError(\n `All target Tensors (y) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(targets.map(target => target.shape))}`);\n }\n if (setX.length > 0 && setY.length > 0 && !util.arraysEqual(setX, setY)) {\n throw new ValueError(\n `Input Tensors should have the same number of samples as target ` +\n `Tensors. Found ${setX[0]} input sample(s) and ${setY[0]} target ` +\n `sample(s).`);\n }\n}\n\n/**\n * Validation on the compatibility of targes and loss functions.\n *\n * This helps prevent users from using loss functions incorrectly.\n *\n * @param targets `Array` of `Tensor`s of targets.\n * @param lossFns `Array` of loss functions.\n * @param outputShapes `Array` of shapes of model outputs.\n */\nfunction checkLossAndTargetCompatibility(\n targets: Tensor[], lossFns: LossOrMetricFn[], outputShapes: Shape[]) {\n // TODO(cais): Dedicated test coverage?\n const keyLosses = [\n losses.meanSquaredError, losses.binaryCrossentropy,\n losses.categoricalCrossentropy\n ];\n for (let i = 0; i < targets.length; ++i) {\n const y = targets[i];\n const loss = lossFns[i];\n const shape = outputShapes[i];\n if (loss == null) {\n continue;\n }\n if (loss === losses.categoricalCrossentropy) {\n if (y.shape[y.shape.length - 1] === 1) {\n throw new ValueError(\n `You are passing a target array of shape ${y.shape} while using ` +\n `a loss 'categorical_crossentropy'. 'categorical_crossentropy'` +\n `expects targets to be binary matrices (1s and 0s) of shape ` +\n `[samples, classes].`);\n // TODO(cais): Example code in error message.\n }\n }\n if (keyLosses.indexOf(loss) !== -1) {\n const slicedYShape = y.shape.slice(1);\n const slicedShape = shape.slice(1);\n for (let j = 0; j < slicedYShape.length; ++j) {\n const targetDim = slicedYShape[j];\n const outDim = slicedShape[j];\n if (outDim != null && targetDim !== outDim) {\n throw new ValueError(\n `A target Tensor with shape ${y.shape} was passed for an ` +\n `output of shape ${shape}, while using a loss function that ` +\n `expects targets to have the same shape as the output.`);\n }\n }\n }\n }\n}\n\n/**\n * Returns a list of batch indices (tuples of indices).\n * @param size: Integer, total size of the data to slice into batches.\n * @param batchSize: Integer, batch size.\n * @returns An Array of [batchStart, batchEnd] tuples. batchStart is\n * inclusive; batchEnd is exclusive. I.e., each batch consists of indices x\n * that satisfy batchStart <= x < batchEnd.\n */\nexport function makeBatches(\n size: number, batchSize: number): Array<[number, number]> {\n const output: Array<[number, number]> = [];\n let batchStart = 0;\n let batchEnd: number = null;\n while (batchStart < size) {\n batchEnd = batchStart + batchSize;\n if (batchEnd >= size) {\n batchEnd = size;\n }\n output.push([batchStart, batchEnd]);\n batchStart = batchEnd;\n }\n return output;\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by start and stop indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArraysByIndices()` together.\n *\n * @param arrays: the input.\n * @param start: the starting index (inclusive).\n * @param stop: the stopping index (exclusive).\n * @returns The result of the slicing. If `arrays` is an `Array` of\n * `Tensor`s, the slicing will be applied to all elements of the `Array`\n * in the same way.\n */\nfunction sliceArrays(\n arrays: Tensor|Tensor[], start: number, stop: number): Tensor|Tensor[] {\n if (arrays == null) {\n return [null];\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => K.sliceAlongFirstAxis(array, start, stop - start));\n } else { // Tensor.\n return K.sliceAlongFirstAxis(arrays, start, stop - start);\n }\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by random-order indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArrays()` together.\n *\n * @param arrays The input `Tensor` or `Array` of `Tensor`s to slice.\n * If an `Array` of `Tensor`s, all `Tensor`s will be sliced in the\n * same fashion.\n * @param indices The indices to use for slicing along the first (batch)\n * dimension.\n * @returns Result(s) of the slicing.\n */\nexport function sliceArraysByIndices(\n arrays: Tensor|Tensor[], indices: Tensor1D): Tensor|Tensor[] {\n return tfc.tidy(() => {\n if (arrays == null) {\n return null;\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => (sliceArraysByIndices(array, indices) as Tensor));\n } else {\n // TODO(cais): indices should be a pre-constructed Tensor1D to avoid\n // tensor1d() calls.\n return K.gather(\n arrays, indices.dtype === 'int32' ? indices : indices.toInt());\n }\n });\n}\n\n/**\n * Check inputs provided by the user.\n *\n * Porting Note: This corresponds to _standardize_input_data() in Python\n * Keras. Because of the strong typing in TF.js, we do not need to convert\n * the data. Specifically:\n * 1) in PyKeras, `data` can be `DataFrame` instances from pandas, for\n * example. We don't need to worry about that here because there is no\n * widely popular javascript/typesdcript equivalent of pandas (so far).\n * If one becomes available in the future, we can add support.\n * 2) in PyKeras, inputs can be Python dict. But here we are stipulating\n * that the data is either a single `Tensor` or an Array of `Tensor`s. We\n * may add support for `Object` data inputs in the future when the need\n * arises.\n *\n * Instead, we perform basic checks for number of parameters and shapes.\n *\n * @param data: The input data.\n * @param names: Name for the inputs, from the model.\n * @param shapes: Expected shapes for the input data, from the model.\n * @param checkBatchAxis: Whether the size along the batch axis (i.e., the\n * first dimension) will be checked for matching.\n * @param exceptionPrefix: Execption prefix message, used in generating error\n * messages.\n * @throws ValueError: on incorrect number of inputs or mismatches in shapes.\n */\nfunction checkInputData(\n data: Tensor|Tensor[], names: string[], shapes?: Shape[],\n checkBatchAxis = true, exceptionPrefix = '') {\n let arrays: Tensor[];\n if (Array.isArray(data)) {\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `the model expected. Expected to see ${names.length} Tensor(s),` +\n ` but instead got ${data.length} Tensors(s).`);\n }\n arrays = data;\n } else {\n if (names.length > 1) {\n throw new ValueError(\n `The model expects ${names.length} ${exceptionPrefix} Tensors, ` +\n `but only received one Tensor. Found: array with shape ` +\n `${JSON.stringify(data.shape)}.`);\n }\n arrays = [data];\n }\n\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s), but got array with ` +\n `shape ${JSON.stringify(array.shape)}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null) {\n if (refDim !== dim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ` +\n `${names[i]} to have shape ${JSON.stringify(shapes[i])} but ` +\n `got array with shape ${JSON.stringify(array.shape)}.`);\n }\n }\n }\n }\n }\n}\n\n/**\n * Maps metric functions to model outputs.\n * @param metrics An `Array` or dict (`Object`) of metric functions.\n * @param outputNames An `Array` of the names of model outputs.\n * @returns An `Array` (one entry per model output) of `Array` of metric\n * functions. For instance, if the model has 2 outputs, and for the first\n * output we want to compute `binaryAccuracy` and `binaryCrossentropy`,\n * and just `binaryAccuracy` for the second output, the `Array` would look\n * like:\n * `[[binaryAccuracy, binaryCrossentropy], [binaryAccuracy]]`\n * @throws TypeError: if `null` or `undefined` value is provided.\n */\nfunction collectMetrics(\n metrics: string[]|{[outputName: string]: string | string[]},\n outputNames: string[]): string[][] {\n if (metrics == null || Array.isArray(metrics) && metrics.length === 0) {\n return outputNames.map(name => []);\n }\n if (Array.isArray(metrics)) {\n // We then apply all metrics to all outputs.\n return outputNames.map(name => metrics);\n } else if (metrics != null) {\n // In this case, metrics is a dict.\n const nestedMetrics: string[][] = [];\n for (const name of outputNames) {\n let outputMetrics: string|string[] =\n metrics.hasOwnProperty(name) ? metrics[name] : [];\n if (!Array.isArray(outputMetrics)) {\n outputMetrics = [outputMetrics];\n }\n nestedMetrics.push(outputMetrics as string[]);\n }\n return nestedMetrics;\n } else {\n throw new TypeError(\n 'Type of metrics argument not understood. Expected an Array or ' +\n 'Object, found: ' + metrics);\n }\n}\n\n/** Verbosity logging level when fitting a model. */\nexport enum ModelLoggingVerbosity {\n SILENT = 0,\n VERBOSE = 1\n}\n\nexport interface ModelEvaluateConfig {\n /**\n * Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Verbosity mode.\n */\n verbose?: ModelLoggingVerbosity;\n\n /**\n * Tensor of weights to weight the contribution of different samples to the\n * loss and metrics.\n */\n sampleWeight?: Tensor;\n\n /**\n * integer: total number of steps (batches of samples)\n * before declaring the evaluation round finished. Ignored with the default\n * value of `undefined`.\n */\n steps?: number;\n}\n\n/**\n * Interface for specifying data to fit a model to data.\n */\nexport interface ModelFitConfig {\n /**\n * Number of samples per gradient update. If unspecified, it\n * will default to 32.\n */\n batchSize?: number;\n\n /** The number of times to iterate over the training data arrays. */\n epochs?: number;\n\n verbose?: ModelLoggingVerbosity;\n\n /**\n * List of callbacks to be called during training.\n * Can consist of one or more of the following fields: `onTrainBegin`,\n * `onTrainEnd`, `onEpochBegin`, `onEpochEnd`, `onBatchBegin`, `onBatchEnd`.\n */\n callbacks?: BaseCallback[]|CustomCallbackConfig|CustomCallbackConfig[];\n\n /**\n * Float between 0 and 1: fraction of the training data\n * to be used as validation data. The model will set apart this fraction of\n * the training data, will not train on it, and will evaluate the loss and\n * any model metrics on this data at the end of each epoch.\n * The validation data is selected from the last samples in the `x` and `y`\n * data provided, before shuffling.\n */\n validationSplit?: number;\n\n /**\n * Data on which to evaluate the loss and any model\n * metrics at the end of each epoch. The model will not be trained on this\n * data. This could be a tuple [xVal, yVal] or a tuple [xVal, yVal,\n * valSampleWeights]. The model will not be trained on this data.\n * `validationData` will override `validationSplit`.\n */\n validationData?: [\n Tensor|Tensor[], Tensor|Tensor[]\n ]|[Tensor | Tensor[], Tensor|Tensor[], Tensor|Tensor[]];\n\n /**\n * Whether to shuffle the training data before each epoch. Has\n * no effect when `stepsPerEpoch` is not `null`.\n */\n shuffle?: boolean;\n\n /**\n * Optional dictionary mapping class indices (integers) to\n * a weight (float) to apply to the model's loss for the samples from this\n * class during training. This can be useful to tell the model to \"pay more\n * attention\" to samples from an under-represented class.\n */\n classWeight?: {[classIndex: string]: number};\n\n /**\n * Optional array of the same length as x, containing\n * weights to apply to the model's loss for each sample. In the case of\n * temporal data, you can pass a 2D array with shape (samples,\n * sequenceLength), to apply a different weight to every timestep of every\n * sample. In this case you should make sure to specify\n * sampleWeightMode=\"temporal\" in compile().\n */\n sampleWeight?: Tensor;\n\n /**\n * Epoch at which to start training (useful for resuming a previous training\n * run).\n */\n initialEpoch?: number;\n\n /**\n * Total number of steps (batches of samples) before\n * declaring one epoch finished and starting the next epoch. When training\n * with Input Tensors such as TensorFlow data tensors, the default `null` is\n * equal to the number of unique samples in your dataset divided by the\n * batch size, or 1 if that cannot be determined.\n */\n stepsPerEpoch?: number;\n\n /**\n * Only relevant if `stepsPerEpoch` is specified. Total number of steps\n * (batches of samples) to validate before stopping.\n */\n validationSteps?: number;\n\n /**\n *\n */\n yieldEvery?: 'batch'|'epoch'|'never';\n}\n\n/**\n * Configuration for calls to `Model.compile()`.\n */\nexport interface ModelCompileConfig {\n /**\n * An instance of `tf.train.Optimizer` or a string name for an Optimizer.\n */\n optimizer: string|Optimizer;\n\n /**\n * Object function(s) or name(s) of object function(s).\n * If the model has multiple outputs, you can use a different loss\n * on each output by passing a dictionary or an Array of losses.\n * The loss value that will be minimized by the model will then be the sum\n * of all individual losses.\n */\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n\n /**\n * List of metrics to be evaluated by the model during training and testing.\n * Typically you will use `metrics=['accuracy']`.\n * To specify different metrics for different outputs of a multi-output\n * model, you could also pass a dictionary.\n */\n metrics?: string[]|{[outputName: string]: string};\n\n // TODO(cais): Add lossWeights, sampleWeightMode, weightedMetrics, and\n // targetTensors.\n}\n\n/**\n * A `Model` is a directed, acyclic graph of `Layer`s plus methods for\n * training, evaluation, prediction and saving.\n *\n * `Model` is the basic unit of training, inference and evaluation in\n * TensorFlow.js. To create a `Model`, use `model`.\n *\n * See also:\n * `Sequential`, `loadModel`.\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Model extends Container implements tfc.InferenceModel {\n static className = 'Model';\n optimizer: Optimizer;\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n lossFunctions: LossOrMetricFn[];\n\n // TODO(cais): These private variables should probably not have the string\n // 'feed' in their names, because we are not dealing with a symbolic\n // backend.\n private feedOutputShapes: Shape[];\n private feedLossFns: LossOrMetricFn[];\n private collectedTrainableWeights: LayerVariable[];\n private testFunction: (data: Tensor[]) => Scalar[];\n history: History;\n\n // A public property that can be set by Callbacks to order early stopping\n // during `fit()` calls.\n stopTraining: boolean;\n\n metrics: string[]|{[outputName: string]: string};\n metricsNames: string[];\n // Porting Note: `metrics_tensors` in PyKeras is a symbolic tensor. But given\n // the imperative nature of tfjs-core, `metricsTensors` is a\n // TypeScript function here.\n // Also note that due to the imperative nature of tfjs-core, `metricsTensor`\n // here needs an output index to keep track of which output of the Model\n // a metric belongs to. This is unlike `metrics_tensors` in PyKeras,\n // which is a `list` of symbolic tensors, each of which has implicit\n // \"knowledge\" of the outputs it depends on.\n metricsTensors: Array<[LossOrMetricFn, number]>;\n\n constructor(config: ContainerConfig) {\n super(config);\n }\n\n /**\n * Print a text summary of the model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - If the model has non-sequential-like topology, the inputs each layer\n * receives\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const input1 = tf.input({shape: [10]});\n * const input2 = tf.input({shape: [20]});\n * const dense1 = tf.layers.dense({units: 4}).apply(input1);\n * const dense2 = tf.layers.dense({units: 8}).apply(input2);\n * const concat = tf.layers.concatenate().apply([dense1, dense2]);\n * const output =\n * tf.layers.dense({units: 3, activation: 'softmax'}).apply(concat);\n *\n * const model = tf.model({inputs: [input1, input2], outputs: output});\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n throw new ValueError(\n `This model has never been called, thus its weights have not been ` +\n `created yet. So no summary can be displayed. Build the model ` +\n `first (e.g., by calling it on some test data).`);\n }\n printSummary(this, lineLength, positions, printFn);\n }\n\n /**\n * Configures and prepares the model for training and evaluation. Compiling\n * outfits the model with an optimizer, loss, and/or metrics. Calling `fit`\n * or `evaluate` on an un-compiled model will throw an error.\n *\n * @param config a `ModelCompileConfig` specifying the loss, optimizer, and\n * metrics to be used for fitting and evaluating this model.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [0]}\n */\n compile(config: ModelCompileConfig): void {\n if (config.loss == null) {\n config.loss = [];\n }\n this.loss = config.loss;\n\n if (typeof config.optimizer === 'string') {\n this.optimizer = optimizers.getOptimizer(config.optimizer);\n } else {\n if (!(config.optimizer instanceof Optimizer)) {\n throw new ValueError(\n `User-defined optimizer must be an instance of tf.Optimizer.`);\n }\n this.optimizer = config.optimizer;\n }\n\n // TODO(cais): Add lossWeights.\n // TODO(cais): Add sampleWeightMode.\n\n // Prepare loss functions.\n let lossFunctions: LossOrMetricFn[] = [];\n if (!Array.isArray(config.loss) && typeof config.loss !== 'string' &&\n typeof config.loss !== 'function') {\n config.loss = config.loss as {[outputName: string]: string};\n for (const name in config.loss) {\n if (this.outputNames.indexOf(name) === -1) {\n throw new ValueError(\n `Unknown entry in loss dictionary: \"${name}\". Only expect the ` +\n `following keys: ${this.outputNames}`);\n }\n }\n for (const name in this.outputNames) {\n if (config.loss[name] == null) {\n console.warn(\n `Output \"${name}\" is missing from loss dictionary. We assume ` +\n `this was done on purpose, and we will not be expecting data ` +\n `to be passed to ${name} during training`);\n }\n lossFunctions.push(losses.get(config.loss[name]));\n }\n } else if (Array.isArray(config.loss)) {\n if (config.loss.length !== this.outputs.length) {\n throw new ValueError(\n `When passing an Array as loss, it should have one entry per ` +\n `model output. The model has ${this.outputs.length} output(s), ` +\n `but you passed loss=${config.loss}.`);\n }\n const theLosses = config.loss as Array;\n lossFunctions = theLosses.map(l => losses.get(l));\n } else {\n const lossFunction = losses.get(config.loss);\n this.outputs.map(layer => {\n lossFunctions.push(lossFunction);\n });\n }\n\n this.lossFunctions = lossFunctions;\n\n this.feedOutputNames = [];\n this.feedOutputShapes = [];\n this.feedLossFns = [];\n for (let i = 0; i < this.outputs.length; ++i) {\n // TODO(cais): Logic for skipping target(s).\n const shape = this.internalOutputShapes[i];\n const name = this.outputNames[i];\n this.feedOutputNames.push(name);\n this.feedOutputShapes.push(shape);\n this.feedLossFns.push(this.lossFunctions[i]);\n }\n\n // TODO(cais): Add logic for weighted losses.\n // TODO(cais): Add logic for output masks.\n // TODO(cais): Add logic for sample weights.\n const skipTargetIndices: number[] = [];\n\n // Prepare metrics.\n this.metrics = config.metrics;\n // TODO(cais): Add weightedMetrics.\n this.metricsNames = ['loss'];\n this.metricsTensors = [];\n\n // Compute total loss.\n // Porting Note: In PyKeras, metrics_tensors are symbolic tensor objects.\n // Here, metricsTensors are TypeScript functions. This difference is due\n // to the difference in symbolic/imperative property of the backends.\n nameScope('loss', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n // TODO(cais): Add weightedLoss, sampleWeight and mask.\n // The following line should be weightedLoss\n const weightedLoss = this.lossFunctions[i];\n if (this.outputs.length > 1) {\n this.metricsTensors.push([weightedLoss, i]);\n this.metricsNames.push(this.outputNames[i] + '_loss');\n }\n }\n\n // Porting Note: Due to the imperative nature of the backend, we calculate\n // the regularizer penalties in the totalLossFunction, instead of here.\n });\n\n const nestedMetrics = collectMetrics(config.metrics, this.outputNames);\n // TODO(cais): Add nestedWeightedMetrics.\n\n /**\n * Helper function used in loop below.\n */\n const appendMetric =\n (outputIndex: number, metricName: string,\n metricTensor: LossOrMetricFn) => {\n if (this.outputNames.length > 1) {\n metricName = this.outputNames[outputIndex] + '_' + metricName;\n }\n this.metricsNames.push(metricName);\n this.metricsTensors.push([metricTensor, outputIndex]);\n };\n\n nameScope('metric', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n const outputMetrics = nestedMetrics[i];\n // TODO(cais): Add weights and outputWeightedMetrics.\n\n // TODO(cais): Add optional arg `weights` to the following function.\n const handleMetrics = (metrics: string[]) => {\n const metricNamePrefix = '';\n let metricName: string;\n let accFn: LossOrMetricFn;\n let weightedMetricFn: LossOrMetricFn;\n // TODO(cais): Use 'weights_' for weighted metrics.\n\n for (const metric of metrics) {\n if (['accuracy', 'acc', 'crossentropy', 'ce'].indexOf(metric) !==\n -1) {\n const outputShape = this.internalOutputShapes[i];\n\n if (outputShape[outputShape.length - 1] === 1 ||\n this.lossFunctions[i] === losses.binaryCrossentropy) {\n // case: binary accuracy/crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryCrossentropy;\n }\n } else if (\n this.lossFunctions[i] ===\n losses.sparseCategoricalCrossentropy) {\n // case: categorical accuracy / crossentropy with sparse\n // targets.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalCrossentropy;\n }\n } else {\n // case: categorical accuracy / crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalCrossentropy;\n }\n }\n let suffix: string;\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n suffix = 'acc';\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n suffix = 'ce';\n }\n // TODO(cais): Add weighting actually.\n weightedMetricFn = accFn;\n metricName = metricNamePrefix + suffix;\n } else {\n const metricFn = Metrics.get(metric);\n // TODO(cais): Add weighting actually.\n weightedMetricFn = metricFn;\n metricName = metricNamePrefix + metric;\n }\n\n // TODO(cais): Add weighting and masking to metricResult.\n let metricResult: LossOrMetricFn;\n nameScope(metricName, () => {\n metricResult = weightedMetricFn;\n });\n appendMetric(i, metricName, metricResult);\n }\n };\n\n handleMetrics(outputMetrics);\n // TODO(cais): Call handleMetrics with weights.\n }\n });\n\n // Porting Notes: Given the imperative backend of tfjs-core,\n // there is no need for constructing the symbolic graph and placeholders.\n this.collectedTrainableWeights = this.trainableWeights;\n }\n\n /**\n * Check trainable weights count consistency.\n *\n * This will raise a warning if `this.trainableWeights` and\n * `this.collectedTrainableWeights` are inconsistent (i.e., have different\n * numbers of parameters).\n * Inconsistency will typically arise when one modifies `model.trainable`\n * without calling `model.compile()` again.\n */\n private checkTrainableWeightsConsistency(): void {\n if (this.collectedTrainableWeights == null) {\n return;\n }\n if (this.trainableWeights.length !==\n this.collectedTrainableWeights.length) {\n console.warn(\n 'Discrepancy between trainableweights and collected trainable ' +\n 'weights. Did you set `model.trainable` without calling ' +\n '`model.compile()` afterwards?');\n }\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(\n * tf.ones([8, 10]), tf.ones([8, 1]), {batchSize: 4});\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model has\n * multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // TODO(cais): Standardize `config.sampleWeights` as well.\n // Validate user data.\n const standardizedOuts = this.standardizeUserData(x, y, true, batchSize);\n // TODO(cais): If uses `useLearningPhase`, set the corresponding element of\n // the input to 0.\n const ins = standardizedOuts[0].concat(standardizedOuts[1]);\n this.makeTestFunction();\n const f = this.testFunction;\n const testOuts =\n this.testLoop(f, ins, batchSize, config.verbose, config.steps);\n return singletonOrArray(testOuts);\n }\n\n /**\n * Get number of samples provided for training, evaluation or prediction.\n *\n * @param ins Input `Tensor`.\n * @param batchSize Integer batch size, optional.\n * @param steps Total number of steps (batches of samples) before declaring\n * loop finished. Optional.\n * @param stepsName The public API's parameter name for `steps`.\n * @returns Number of samples provided.\n */\n private checkNumSamples(\n ins: Tensor|Tensor[], batchSize?: number, steps?: number,\n stepsName = 'steps'): number {\n let numSamples: number;\n if (steps != null) {\n numSamples = null;\n if (batchSize != null) {\n throw new ValueError(\n `If ${stepsName} is set, batchSize must be null or undefined.` +\n `Got batchSize = ${batchSize}`);\n }\n } else if (ins != null) {\n if (Array.isArray(ins)) {\n numSamples = ins[0].shape[0];\n } else {\n numSamples = ins.shape[0];\n }\n } else {\n throw new ValueError(\n `Either the input data should have a defined shape, or ` +\n `${stepsName} shoud be specified.`);\n }\n return numSamples;\n }\n\n /**\n * Execute intrenal tensors of the model with input data feed.\n * @param inputs Input data feed. Must match the inputs of the model.\n * @param outputs Names of the output tensors to be fetched. Must match\n * names of the SymbolicTensors that belong to the graph.\n * @returns Fetched values for `outputs`.\n */\n execute(inputs: Tensor|Tensor[]|NamedTensorMap, outputs: string|string[]):\n Tensor|Tensor[] {\n if (Array.isArray(outputs) && outputs.length === 0) {\n throw new ValueError(\n '`outputs` is an empty Array, which is not allowed.');\n }\n\n const outputsIsArray = Array.isArray(outputs);\n const outputNames = (outputsIsArray ? outputs as string[] :\n [outputs as string]) as string[];\n const outputSymbolicTensors = this.retrieveSymbolicTensors(outputNames);\n\n // Format the input into a FeedDict.\n const feedDict = new FeedDict();\n if (inputs instanceof Tensor) {\n inputs = [inputs as Tensor];\n }\n if (Array.isArray(inputs)) {\n if ((inputs as Tensor[]).length !== this.inputs.length) {\n throw new ValueError(\n `The number of inputs provided (${(inputs as Tensor[]).length}) ` +\n `does not match the number of inputs of this model ` +\n `(${this.inputs.length}).`);\n }\n for (let i = 0; i < this.inputs.length; ++i) {\n feedDict.add(this.inputs[i], (inputs as Tensor[])[i]);\n }\n } else {\n for (const input of this.inputs) {\n const tensorValue = (inputs as NamedTensorMap)[input.name];\n if (tensorValue == null) {\n throw new ValueError(\n `No value is provided for the model's input ${input.name}`);\n }\n feedDict.add(input, tensorValue);\n }\n }\n\n // Run execution.\n const executeOutputs = execute(outputSymbolicTensors, feedDict) as Tensor[];\n return outputsIsArray ? executeOutputs : executeOutputs[0];\n }\n\n /**\n * Retrieve the model's internal symbolic tensors from symbolic-tensor names.\n */\n private retrieveSymbolicTensors(symbolicTensorNames: string[]):\n SymbolicTensor[] {\n const outputSymbolicTensors: SymbolicTensor[] =\n pyListRepeat(null, symbolicTensorNames.length);\n let outputsRemaining = symbolicTensorNames.length;\n for (const layer of this.layers) {\n const layerOutputs: SymbolicTensor[] = Array.isArray(layer.output) ?\n layer.output as SymbolicTensor[] :\n [layer.output as SymbolicTensor];\n const layerOutputNames = layerOutputs.map(output => output.name);\n for (let i = 0; i < symbolicTensorNames.length; ++i) {\n const index = layerOutputNames.indexOf(symbolicTensorNames[i]);\n if (index !== -1) {\n outputSymbolicTensors[i] = layerOutputs[index];\n outputsRemaining--;\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n\n if (outputsRemaining > 0) {\n const remainingNames: string[] = [];\n outputSymbolicTensors.forEach((tensor, i) => {\n if (tensor == null) {\n remainingNames.push(symbolicTensorNames[i]);\n }\n });\n throw new ValueError(\n `Cannot find SymbolicTensors for output name(s): ` +\n `${JSON.stringify(remainingNames)}`);\n }\n return outputSymbolicTensors;\n }\n\n /**\n * Helper method to loop over some data in batches.\n *\n * Porting Note: Not using the functional approach in the Python equivalent\n * due to the imperative backend.\n * Porting Note: Does not support step mode currently.\n *\n * @param ins: input data\n * @param batchSize: integer batch size.\n * @param verbose: verbosity model\n * @returns: Predictions as `Tensor` (if a single output) or an `Array` of\n * `Tensor` (if multipe outputs).\n */\n private predictLoop(ins: Tensor|Tensor[], batchSize = 32, verbose = false):\n Tensor|Tensor[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins);\n if (verbose) {\n throw new NotImplementedError(\n 'Verbose predictLoop() is not implemented yet.');\n }\n\n // Sample-based predictions.\n // Porting Note: Tensor currently does not support sliced assignments as\n // in numpy, e.g., x[1:3] = y. Therefore we use concatenation while\n // iterating over the batches.\n\n const batches = makeBatches(numSamples, batchSize);\n const outs: Tensor[] = [];\n // TODO(cais): Can the scope() be pushed down inside the for loop?\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchOuts = tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n // TODO(cais): Take care of the case of the last element is a flag for\n // training/test.\n const insBatch = sliceArrays(ins, batchStart, batchEnd);\n\n // Construct the feeds for execute();\n const feeds = [];\n if (Array.isArray(insBatch)) {\n for (let i = 0; i < insBatch.length; ++i) {\n feeds.push({key: this.inputs[i], value: insBatch[i]});\n }\n } else {\n feeds.push({key: this.inputs[0], value: insBatch});\n }\n const feedDict = new FeedDict(feeds);\n return execute(this.outputs, feedDict) as Tensor[];\n });\n if (batchIndex === 0) {\n // Pre-allocate.\n for (const batchOut of batchOuts) {\n outs.push(batchOut);\n }\n } else {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs[i] = K.concatAlongFirstAxis(outs[i], batchOuts[i]);\n }\n }\n }\n return singletonOrArray(outs);\n });\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFlow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([8, 10]), {batchSize: 4}).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param config A `ModelPredictConfig` object containing optional fields.\n *\n * @return Prediction results as a `Tensor`(s).\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, false);\n // TODO(cais): Take care of stateful models.\n // if (this.stateful) ...\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n return this.predictLoop(x, batchSize);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predictOnBatch(tf.ones([8, 10])).print();\n * ```\n * @param x: Input samples, as an Tensor\n * @return Tensor(s) of predictions\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, true);\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n return this.predictLoop(x, x.shape[0]);\n }\n\n protected standardizeUserData(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor}, checkBatchAxis = true,\n batchSize?: number): [Tensor[], Tensor[], Tensor[]] {\n // TODO(cais): Add sampleWeight, classWeight\n if (this.optimizer == null) {\n throw new RuntimeError(\n 'You must compile a model before training/testing. Use ' +\n 'Model.compile(modelCompileConfig).');\n }\n const outputShapes: Shape[] = [];\n for (let i = 0; i < this.feedOutputShapes.length; ++i) {\n const outputShape = this.feedOutputShapes[i];\n const lossFn = this.feedLossFns[i];\n if (lossFn === losses.sparseCategoricalCrossentropy) {\n outputShapes.push(\n outputShape.slice(0, outputShape.length - 1).concat([1]));\n } else {\n // Porting Note: Because of strong typing `lossFn` must be a function.\n outputShapes.push(outputShape);\n }\n }\n x = standardizeInputData(\n x, this.feedInputNames, this.feedInputShapes, false, 'input') as\n Tensor[];\n y = standardizeInputData(\n y, this.feedOutputNames, outputShapes, false, 'target') as Tensor[];\n // TODO(cais): Standardize sampleWeights & classWeights.\n checkArrayLengths(x, y, null);\n // TODO(cais): Check sampleWeights as well.\n checkLossAndTargetCompatibility(y, this.feedLossFns, this.feedOutputShapes);\n if (this.stateful && batchSize != null && batchSize > 0) {\n if (x[0].shape[0] % batchSize !== 0) {\n throw new ValueError(\n `In a stateful network, you should only pass inputs with a ` +\n `number of samples that is divisible by the batch size ` +\n `${batchSize}. Found: ${x[0].shape[0]} sample(s).`);\n }\n }\n // TODO(cais): Deal with the case of model.stateful == true.\n return [x, y, null];\n }\n\n /**\n * Abstract fit function for `f(ins)`.\n * @param f A Function returning a list of tensors. For training, this\n * function is expected to perform the updates to the variables.\n * @param ins List of tensors to be fed to `f`.\n * @param outLabels List of strings, display names of the outputs of `f`.\n * @param batchSize Integer batch size or `== null` if unknown.\n * @param epochs Number of times to iterate over the data.\n * @param verbose Verbosity mode: 0, 1, or 2.\n * @param callbacks List of callbacks to be called during training.\n * @param valF Function to call for validation.\n * @param valIns List of tensors to be fed to `valF`.\n * @param shuffle Whether to shuffle the data at the beginning of every\n * epoch.\n * @param callbackMetrics List of strings, the display names of the metrics\n * passed to the callbacks. They should be the concatenation of the\n * display names of the outputs of `f` and the list of display names\n * of the outputs of `valF`.\n * @param initialEpoch Epoch at which to start training (useful for\n * resuming a previous training run).\n * @param stepsPerEpoch Total number of steps (batches on samples) before\n * declaring one epoch finished and starting the next epoch. Ignored with\n * the default value of `undefined` or `null`.\n * @param validationSteps Number of steps to run validation for (only if\n * doing validation from data tensors). Not applicable for tfjs-layers.\n * @returns A `History` object.\n */\n private async fitLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], outLabels?: string[],\n batchSize?: number, epochs?: number, verbose?: number,\n callbacks?: BaseCallback[], valF?: (data: Tensor[]) => Scalar[],\n valIns?: Tensor[], shuffle?: boolean|string, callbackMetrics?: string[],\n initialEpoch?: number, stepsPerEpoch?: number,\n validationSteps?: number): Promise {\n if (batchSize == null) {\n batchSize = 32;\n }\n if (epochs == null) {\n epochs = 1;\n }\n if (shuffle == null) {\n shuffle = true;\n }\n if (initialEpoch == null) {\n initialEpoch = 0;\n }\n\n // TODO(cais): Change const to let below when implementing validation.\n let doValidation = false;\n if (valF != null && valIns != null) {\n doValidation = true;\n // TODO(cais): verbose message.\n }\n if (validationSteps != null) {\n doValidation = true;\n if (stepsPerEpoch == null) {\n throw new ValueError(\n 'Can only use `validationSteps` when doing step-wise training, ' +\n 'i.e., `stepsPerEpoch` must be set.');\n }\n }\n\n const numTrainSamples =\n this.checkNumSamples(ins, batchSize, stepsPerEpoch, 'steps_per_epoch');\n let indexArray: number[];\n if (numTrainSamples != null) {\n indexArray = range(0, numTrainSamples);\n }\n\n this.history = new History();\n if (callbacks == null) {\n callbacks = [new BaseLogger()];\n } else {\n callbacks = ([new BaseLogger()] as BaseCallback[]).concat(callbacks);\n }\n callbacks = callbacks.concat([this.history]);\n\n if (verbose > 0) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n const callbackList = new CallbackList(callbacks);\n\n // TODO(cais): Figure out when this Model instance can have a dynamically\n // set property called 'callback_model' as in PyKeras.\n callbackList.setModel(this);\n callbackList.setParams({\n epochs,\n initialEpoch,\n steps: stepsPerEpoch,\n verbose,\n doValidation,\n metrics: callbackMetrics,\n });\n await callbackList.onTrainBegin();\n this.stopTraining = false;\n // TODO(cais): Take care of callbacks.validation_data as in PyKeras.\n\n // TODO(cais): Pre-convert feeds for performance as in PyKeras.\n\n for (let epoch = initialEpoch; epoch < epochs; ++epoch) {\n await callbackList.onEpochBegin(epoch);\n const epochLogs: UnresolvedLogs = {};\n if (stepsPerEpoch != null) {\n throw new NotImplementedError(\n 'stepsPerEpoch mode is not implemented yet.');\n } else {\n if (shuffle === 'batch') {\n throw new NotImplementedError(\n 'batch shuffling is not implemneted yet');\n } else if (shuffle) {\n util.shuffle(indexArray);\n }\n // Convert the potentially shuffled indices to Tensor1D, to avoid the\n // cost of repeated creation of Array1Ds later on.\n const epochIndexArray1D = tensor1d(indexArray);\n\n const batches = makeBatches(numTrainSamples, batchSize);\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchLogs: UnresolvedLogs = {};\n await callbackList.onBatchBegin(batchIndex, batchLogs);\n\n tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds = K.sliceAlongFirstAxis(\n epochIndexArray1D, batchStart,\n batchEnd - batchStart) as Tensor1D;\n batchLogs['batch'] = batchIndex;\n batchLogs['size'] = batchEnd - batchStart;\n\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Tensor[];\n const outs = f(insBatch);\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = outs[i];\n batchLogs[label] = out;\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n }\n\n if (batchIndex === batches.length - 1) { // Last batch.\n if (doValidation) {\n const valOuts = this.testLoop(valF, valIns, batchSize);\n // Porting Notes: In tfjs-layers, valOuts is always an Array.\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = valOuts[i];\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n epochLogs['val_' + label] = out;\n }\n }\n }\n });\n\n await callbackList.onBatchEnd(batchIndex, batchLogs);\n disposeTensorsInLogs(batchLogs);\n\n if (this.stopTraining) {\n break;\n }\n // TODO(cais): return outs as list of Tensor.\n }\n\n epochIndexArray1D.dispose();\n }\n // TODO(cais): Run validation at the end of the epoch.\n await callbackList.onEpochEnd(epoch, epochLogs);\n if (this.stopTraining) {\n break;\n }\n }\n await callbackList.onTrainEnd();\n\n await this.history.syncData();\n return this.history;\n }\n\n /**\n * Loop over some test data in batches.\n * @param f A Function returning a list of tensors.\n * @param ins Array of tensors to be fed to `f`.\n * @param batchSize Integer batch size or `null` / `undefined`.\n * @param verbose verbosity mode.\n * @param steps Total number of steps (batches of samples) before declaring\n * test finished. Ignored with the default value of `null` / `undefined`.\n * @returns Array of Scalars.\n */\n private testLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], batchSize?: number,\n verbose = 0, steps?: number): Scalar[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins, batchSize, steps, 'steps');\n const outs: Scalar[] = [];\n if (verbose === 1) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n // TODO(cais): Use `indicesForConversionToDense' to prevent slow down.\n if (steps != null) {\n throw new NotImplementedError(\n 'steps mode in testLoop() is not implemented yet');\n } else {\n const batches = makeBatches(numSamples, batchSize);\n const indexArray = tensor1d(range(0, numSamples));\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds =\n K.sliceAlongFirstAxis(\n indexArray, batchStart, batchEnd - batchStart) as Tensor1D;\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Scalar[];\n const batchOuts = f(insBatch);\n if (batchIndex === 0) {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs.push(getScalar(0));\n }\n }\n for (let i = 0; i < batchOuts.length; ++i) {\n const batchOut = batchOuts[i];\n outs[i] =\n tfc.add(\n outs[i],\n tfc.mul(getScalar(batchEnd - batchStart), batchOut)) as\n Scalar;\n }\n }\n for (let i = 0; i < outs.length; ++i) {\n outs[i] = tfc.div(outs[i], getScalar(numSamples)) as Scalar;\n }\n }\n return outs;\n });\n }\n\n private getDedupedMetricsNames(): string[] {\n const outLabels = this.metricsNames;\n // Rename duplicated metrics names (can happen with an output layer shared\n // among multiple dataflows).\n const dedupedOutLabels = [];\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n let newLabel = label;\n if (count(outLabels, label) > 1) {\n const dupIndex = count(outLabels.slice(0, i), label);\n newLabel += `_${dupIndex}`;\n }\n dedupedOutLabels.push(newLabel);\n }\n return dedupedOutLabels;\n }\n\n private makeTestFunction() {\n this.testFunction = (data: Tensor[]) => {\n return tfc.tidy(() => {\n const valOutputs: Scalar[] = [];\n let totalLoss: Scalar;\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs = execute(this.outputs, feedDict) as Tensor[];\n // Compute total loss.\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n // TODO(cais): Add sample weighting and replace the simple\n // averaging.\n const loss = tfc.mean(lossFunction(targets[i], outputs[i])) as Scalar;\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss) as Scalar;\n }\n valOutputs.push(totalLoss);\n }\n // Compute the metrics.\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0]; // TODO(cais): Restore.\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex]));\n valOutputs.push(meanMetric as Scalar);\n }\n return valOutputs;\n });\n };\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * for (let i = 1; i < 5 ; ++i) {\n * const h = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(\"Loss after Epoch \" + i + \" : \" + h.history.loss[0]);\n * }\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // Validate user data.\n // TODO(cais): Add sampleWeight and classWeight.\n const standardizedOuts = this.standardizeUserData(x, y, false, batchSize);\n let inputs = standardizedOuts[0];\n let targets = standardizedOuts[1];\n // TODO(cais): Make use of sampleWeights in standardizedOuts[2] when\n // available.\n\n // Prepare validation data.\n let doValidation = false;\n let valX: Tensor|Tensor[];\n let valY: Tensor|Tensor[];\n let valIns: Tensor[];\n // A flag to keep track of whether `valIns`, `inputs` and `targets` need\n // to be memory-disposed prior to returning from this method. This is the\n // case if `config.validationSplit` is set to a number between 0 and 1, in\n // which case the input `x` and `y` tensors will be sliced, leading to\n // allocation of new tensor memory.\n let needValidationDisposal = false;\n if (config.validationData != null && config.validationData.length > 0) {\n doValidation = true;\n if (config.validationData.length === 2) {\n // config.validationData consists of valX and valY.\n valX = config.validationData[0];\n valY = config.validationData[1];\n } else if (config.validationData.length === 3) {\n throw new NotImplementedError(\n 'validationData including sample weights is not supported yet.');\n } else {\n throw new ValueError(\n `When passing validation data, it must contain 2 (valX, valY) ` +\n `or 3 (valX, valY, valSampleWeight) items; ` +\n `${config.validationData} is invalid.`);\n }\n\n const valStandardized =\n this.standardizeUserData(valX, valY, true, batchSize);\n valX = valStandardized[0] as Tensor[];\n valY = valStandardized[1] as Tensor[];\n // TODO(cais): Use validation sample weights in valStandardized[2] once\n // it becomes available.\n valIns = valX.concat(valY);\n // TODO(cais): Add useLearningPhase data properly.\n } else if (\n config.validationSplit != null && config.validationSplit > 0 &&\n config.validationSplit < 1) {\n doValidation = true;\n // Porting Note: In tfjs-layers, inputs[0] is always an Tensor.\n const splitAt =\n Math.floor(inputs[0].shape[0] * (1 - config.validationSplit));\n const originalBatchSize = inputs[0].shape[0];\n valX = sliceArrays(inputs, splitAt, originalBatchSize) as Tensor[];\n inputs = sliceArrays(inputs, 0, splitAt) as Tensor[];\n valY = sliceArrays(targets, splitAt, originalBatchSize) as Tensor[];\n targets = sliceArrays(targets, 0, splitAt) as Tensor[];\n needValidationDisposal = true;\n // TODO(cais): Once sampleWeights becomes available, slice it to get\n // valSampleWeights.\n valIns = valX.concat(valY);\n\n // TODO(cais): Add useLearningPhase data properly.\n } else if (config.validationSteps != null) {\n doValidation = true;\n // TODO(cais): Add useLearningPhase.\n }\n\n const ins = inputs.concat(targets);\n\n this.checkTrainableWeightsConsistency();\n\n // TODO(cais): Handle use_learning_phase and learning_phase?\n\n // Porting Note: Here we see a key deviation of tfjs-layers from Keras.\n // Due to the imperative nature of tfjs-layers' backend (tfjs-core),\n // we do not construct symbolic computation graphs to embody the training\n // process. Instead, we define a function that performs the training\n // action.\n // In PyKeras, the data (inputs and targets) are fed through graph\n // placeholders. In tfjs-layers, the data are fed as function arguments.\n // Since the function are defined below in the scope, we don't have\n // equivalents of PyKeras's `_make_train_funciton`.\n\n // Creat a function that performs the following actions:\n // 1) computes the losses,\n // 2) add them to get the total loss,\n // 3) call the optimizer computes the gradients of the Model's trainable\n // weights w.r.t. the total loss and update the variables.\n // 4) calculate the metrics\n // 5) return the values of the losses and metrics.\n const trainFunction = (data: Tensor[]) => {\n const losses: Tensor[] = [];\n const lossValues: Scalar[] = [];\n\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n\n const metricsValues: Scalar[] = [];\n\n // Create a function that computes the total loss based on the inputs.\n // This function is used for obtaining gradients through backprop.\n const totalLossFunction = () => {\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs =\n execute(this.outputs, feedDict, {'training': true}) as Tensor[];\n // TODO(cais): Take care of the case of multiple outputs from a\n // single layer?\n\n let totalLoss: Tensor;\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n const loss = lossFunction(targets[i], outputs[i]);\n losses.push(loss);\n // TODO(cais): push Scalar instead.\n const meanLoss = tfc.mean(loss) as Scalar;\n // TODO(cais): Use a scope() instead, to avoid ownership.\n lossValues.push(meanLoss);\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss);\n }\n }\n\n // Compute the metrics.\n // TODO(cais): These should probably be calculated outside\n // totalLossFunction to benefit speed?\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0];\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex])) as\n Scalar;\n tfc.keep(meanMetric);\n // TODO(cais): Use a scope() instead, to avoid ownership.\n metricsValues.push(meanMetric);\n }\n\n totalLoss = tfc.mean(totalLoss);\n\n // Add regularizer penalties.\n this.calculateLosses().forEach(regularizerLoss => {\n totalLoss = tfc.add(totalLoss, regularizerLoss);\n });\n\n return totalLoss as Scalar;\n };\n\n const variables = this.collectedTrainableWeights.map(\n param => param.read() as tfc.Variable);\n const returnCost = true;\n const totalLossValue =\n this.optimizer.minimize(totalLossFunction, returnCost, variables);\n\n return [totalLossValue].concat(metricsValues);\n };\n\n const outLabels = this.getDedupedMetricsNames();\n\n let valFunction: (data: Tensor[]) => Scalar[];\n let callbackMetrics: string[];\n if (doValidation) {\n this.makeTestFunction();\n valFunction = this.testFunction;\n callbackMetrics =\n outLabels.slice().concat(outLabels.map(n => 'val_' + n));\n } else {\n valFunction = null;\n valIns = [];\n callbackMetrics = outLabels.slice();\n }\n\n const callbacks = standardizeCallbacks(config.callbacks);\n const out = await this.fitLoop(\n trainFunction, ins, outLabels, batchSize, config.epochs, config.verbose,\n callbacks, valFunction, valIns, config.shuffle, callbackMetrics,\n config.initialEpoch, null, null);\n if (needValidationDisposal) {\n valIns.forEach(tensor => tensor.dispose());\n inputs.forEach(tensor => tensor.dispose());\n targets.forEach(tensor => tensor.dispose());\n }\n return out;\n // TODO(cais): Add value to outLabels.\n }\n\n /**\n * Extract weight values of the model.\n *\n * @param config: An instance of `io.SaveConfig`, which specifies\n * model-saving options such as whether only trainable weights are to be\n * saved.\n * @returns A `NamedTensorMap` mapping original weight names (i.e.,\n * non-uniqueified weight names) to their values.\n */\n protected getNamedWeights(config?: io.SaveConfig): NamedTensorMap {\n const namedWeights: NamedTensorMap = {};\n\n const trainableOnly = config != null && config.trainableOnly;\n const weights = trainableOnly ? this.trainableWeights : this.weights;\n const weightValues = this.getWeights(trainableOnly);\n for (let i = 0; i < weights.length; ++i) {\n if (trainableOnly && !weights[i].trainable) {\n // Optionally skip non-trainable weights.\n continue;\n }\n namedWeights[weights[i].originalName] = weightValues[i];\n }\n return namedWeights;\n }\n\n // tslint:disable:max-line-length\n /**\n * Save the configuration and/or weights of the Model.\n *\n * An `IOHandler` is an object that has a `save` method of the proper\n * signature defined. The `save` method manages the storing or transmission\n * of serialized data (\"artifacts\") that represent the model's topology and\n * weights onto or via a specific medium, such as file downloads, local\n * storage, IndexedDB in the web browser and HTTP requests to a server.\n * TensorFlow.js provides `IOHandler` implementations for a number of\n * frequently used saving mediums, such as `tf.io.browserDownloads` and\n * `tf.io.browserLocalStorage`. See `tf.io` for more details.\n *\n * This method also allows you to refer to certain types of `IOHandler`s as\n * URL-like string shortcuts, such as 'localstorage://' and 'indexeddb://'.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Saving `model`'s topology and weights as two files\n * (`my-model-1.json` and `my-model-1.weights.bin`) downloaded from browser.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('downloads://my-model-1');\n * ```\n *\n * Example 4. Send `model`'s topology and weights to an HTTP server.\n * See the documentation of `tf.io.browserHTTPRequests` for more details\n * including specifying request parameters and implementation of the server.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('http://my-server/model/upload');\n * ```\n *\n * @param handlerOrURL An instance of `IOHandler` or a URL-like,\n * scheme-based string shortcut for `IOHandler`.\n * @param config Options for saving the model.\n * @returns A `Promise` of `SaveResult`, which summarizes the result of the\n * saving, such as byte sizes of the saved artifacts for the model's\n * topology and weight values.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n // tslint:enable:max-line-length\n async save(handlerOrURL: io.IOHandler|string, config?: io.SaveConfig):\n Promise {\n if (typeof handlerOrURL === 'string') {\n const handlers = io.getSaveHandlers(handlerOrURL);\n if (handlers.length === 0) {\n throw new ValueError(\n `Cannot find any save handlers for URL '${handlerOrURL}'`);\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) save handlers for ` +\n `URL '${handlerOrURL}'`);\n }\n handlerOrURL = handlers[0];\n }\n if (handlerOrURL.save == null) {\n throw new ValueError(\n 'Model.save() cannot proceed because the IOHandler provided does ' +\n 'not have the `save` attribute defined.');\n }\n\n const weightDataAndSpecs =\n await io.encodeWeights(this.getNamedWeights(config));\n\n const returnString = false;\n const unusedArg: {} = null;\n const modelConfig = this.toJSON(unusedArg, returnString);\n\n return handlerOrURL.save({\n modelTopology: modelConfig,\n weightData: weightDataAndSpecs.data,\n weightSpecs: weightDataAndSpecs.specs\n });\n }\n}\n\nserialization.SerializationMap.register(Model);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source keras/models.py */\n\n// tslint:disable:max-line-length\nimport {io, Scalar, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from './backend/state';\nimport {History} from './base_callbacks';\nimport {Input} from './engine/input_layer';\nimport {getSourceInputs, Layer, Node, SymbolicTensor} from './engine/topology';\nimport {Model, ModelCompileConfig, ModelEvaluateConfig, ModelFitConfig} from './engine/training';\nimport {RuntimeError, ValueError} from './errors';\nimport {deserialize} from './layers/serialization';\nimport {Kwargs, NamedTensorMap, Shape} from './types';\nimport {JsonDict} from './types';\nimport * as generic_utils from './utils/generic_utils';\nimport {convertPythonicToTs} from './utils/serialization_utils';\nimport {getExactlyOneShape} from './utils/types_utils';\n// tslint:enable:max-line-length\n\n/**\n * Parses a JSON model configuration file and returns a model instance.\n * @param modelAndWeightsConfig JSON object or string encoding a model and\n * weights configuration.\n * @param custom_objects Optional dictionary mapping names\n * (strings) to custom classes or functions to be\n * considered during deserialization.\n * @returns A TensorFlow.js Layers `Model` instance (uncompiled).\n */\nexport async function modelFromJSON(\n modelAndWeightsConfig: ModelAndWeightsConfig,\n customObjects?: serialization.ConfigDict): Promise {\n let modelTopology = modelAndWeightsConfig.modelTopology;\n if (modelTopology['model_config'] != null) {\n // If the model-topology JSON contains a 'model_config' field, then it is\n // a full model JSON (e.g., from `keras.Model.save()`), which contains\n // not only the model's architecture in its 'model_config' field, but\n // additional information such as the model's optimizer. We use only the\n // 'model_config' field currently.\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const tsConfig =\n convertPythonicToTs(modelTopology) as serialization.ConfigDict;\n const model = deserialize(tsConfig, customObjects) as Model;\n\n if (modelAndWeightsConfig.weightsManifest != null) {\n // Load the weight values keyed by the original tensor names in the model\n // file that was loaded. These should match the keys of the weight\n // manifest.\n const weightValues =\n await io.loadWeights(\n modelAndWeightsConfig.weightsManifest,\n modelAndWeightsConfig.pathPrefix,\n model.weights.map(weight => weight.originalName)) as NamedTensorMap;\n\n // Map the weights to the unique tensor names generated during model loading\n const uniqueWeightValues: NamedTensorMap = {};\n for (const weight of model.weights) {\n uniqueWeightValues[weight.originalName] =\n weightValues[weight.originalName];\n }\n\n const skipMismatches: boolean = null;\n const isNamedTensorMap = true;\n model.loadWeights(uniqueWeightValues, skipMismatches, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Options for loading a saved mode in TensorFlow.js format.\n */\nexport interface ModelAndWeightsConfig {\n /**\n * A JSON object or JSON string containing the model config.\n *\n * This can be either of the following two formats:\n * - A model archiecture-only config, i.e., a format consistent with the\n * return value of`keras.Model.to_json()`.\n * - A full model config, containing not only model architecture, but also\n * training options and state, i.e., a format consistent with the return\n * value of `keras.models.save_model()`.\n */\n modelTopology: JsonDict;\n\n /**\n * A weights manifest in TensorFlow.js format.\n */\n weightsManifest?: io.WeightsManifestConfig;\n\n /**\n * Path to prepend to the paths in `weightManifest` before fetching.\n *\n * The path may optionally end in a slash ('/').\n */\n pathPrefix?: string;\n}\n\n// TODO(nielsene): Remove after: https://github.com/tensorflow/tfjs/issues/400\nexport interface ModelPredictConfig {\n /**\n * Optional. Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Optional. Verbosity mode. Defaults to false.\n */\n verbose?: boolean;\n}\n\n// tslint:disable:max-line-length\n/**\n * Load a model, including its topology and optionally weights. See the\n * Tutorial named \"How to import a Keras Model\" for usage examples.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Load a model from user-selected files from HTML\n * [file input\n * elements](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file).\n *\n * ```js\n * // Note: this code snippet will not work without the HTML elements in the\n * // page\n * const jsonUpload = document.getElementById('json-upload');\n * const weightsUpload = document.getElementById('weights-upload');\n *\n * const model = await tf.loadModel(\n * tf.io.browserFiles([jsonUpload.files[0], weightsUpload.files[0]]));\n * ```\n *\n * Example 4. Load a model from an HTTP server.\n *\n * ```js\n * const model = await\n * tf.loadModel('https://storage.googleapis.com/tfjs-models/tfjs/iris_v1/model.json')\n * ```\n *\n * @param pathOrIOHandler Can be either of the two formats\n * 1. A string path to the `ModelAndWeightsConfig` JSON describing\n * the model in the canonical TensorFlow.js format. This path will be\n * interpreted as a relative HTTP path, to which `fetch` will be used to\n * request the model topology and weight manifest JSON.\n * The content of the JSON file is assumed to be a JSON object with the\n * following fields and values:\n * - 'modelTopology': A JSON object that can be either of:\n * 1. a model architecture JSON consistent with the format of the return\n * value of `keras.Model.to_json()`\n * 2. a full model JSON in the format of `keras.models.save_model()`.\n * - 'weightsManifest': A TensorFlow.js weights manifest.\n * See the Python converter function `save_model()` for more details.\n * It is also assumed that model weights can be accessed from relative\n * paths described by the `paths` fields in weights manifest.\n * 2. An `tf.io.IOHandler` object that loads model artifacts with its `load`\n * method.\n *\n * @returns A `Promise` of `Model`, with the topology and weights loaded.\n */\n// tslint:enable:max-line-length\nexport async function loadModelInternal(pathOrIOHandler: string|\n io.IOHandler): Promise {\n if (typeof pathOrIOHandler === 'string') {\n const handlers = io.getLoadHandlers(pathOrIOHandler);\n if (handlers.length === 0) {\n // For backward compatibility: if no load handler can be found,\n // assume it is a relative http path.\n handlers.push(io.browserHTTPRequest(pathOrIOHandler));\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) load handlers for ` +\n `URL '${pathOrIOHandler}'`);\n }\n pathOrIOHandler = handlers[0];\n }\n return loadModelFromIOHandler(pathOrIOHandler as io.IOHandler);\n}\n\n/**\n * Load a model and optionally its weights, using an IOHandler object.\n */\nexport async function loadModelFromIOHandler(\n handler: io.IOHandler,\n customObjects?: serialization.ConfigDict): Promise {\n if (handler.load == null) {\n throw new ValueError(\n 'Cannot proceed with model loading because the IOHandler provided ' +\n 'does not have the `load` method implemented.');\n }\n const artifacts = await handler.load();\n let modelTopology = artifacts.modelTopology as JsonDict;\n if (modelTopology['model_config'] != null) {\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const model =\n deserialize(\n convertPythonicToTs(modelTopology) as serialization.ConfigDict,\n customObjects) as Model;\n\n // If weightData is present, load the weights into the model.\n if (artifacts.weightData != null) {\n // Loading weights requires weightSpecs.\n if (artifacts.weightSpecs == null) {\n throw new ValueError(\n 'Model artifacts contains weight data, but not weight specs. ' +\n 'Therefore loading of weights cannot proceed.');\n }\n\n const skipMismatch = false;\n const isNamedTensorMap = true;\n model.loadWeights(\n io.decodeWeights(artifacts.weightData, artifacts.weightSpecs),\n skipMismatch, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Configuration for a Sequential model.\n */\nexport interface SequentialConfig {\n /** Stack of layers for the model. */\n layers?: Layer[];\n\n /** The name of this model. */\n name?: string;\n}\n\n/**\n * A model with a stack of layers, feeding linearly from one to the next.\n *\n * `sequential` is a factory function that creates an instance of\n * `Sequential`.\n *\n * ```js\n * // Define a model for linear regression.\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 1, inputShape: [1]}));\n *\n * // Prepare the model for training: Specify the loss and the optimizer.\n * model.compile({loss: 'meanSquaredError', optimizer: 'sgd'});\n *\n * // Generate some synthetic data for training.\n * const xs = tf.tensor2d([1, 2, 3, 4], [4, 1]);\n * const ys = tf.tensor2d([1, 3, 5, 7], [4, 1]);\n *\n * // Train the model using the data then do inference on a data point the\n * // model hasn't seen:\n * await model.fit(xs, ys);\n * model.predict(tf.tensor2d([5], [1, 1])).print();\n * ```\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Sequential extends Model {\n static className = 'Sequential';\n private model: Model;\n private _updatable: boolean;\n constructor(config?: SequentialConfig) {\n super({inputs: [], outputs: []});\n config = config || {};\n\n this.trainable = true;\n this._updatable = true;\n this.built = false;\n\n // Set model name.\n this.name = (config.name != null) ? config.name : getUid('sequential_');\n\n // Add to the model any layers passed to the constructor.\n if (config.layers != null) {\n for (const layer of config.layers) {\n this.add(layer);\n }\n }\n }\n\n /**\n * Adds a layer instance on top of the layer stack.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 8, inputShape: [1]}));\n * model.add(tf.layers.dense({units: 4, activation: 'relu6'}));\n * model.add(tf.layers.dense({units: 1, activation: 'relu6'}));\n * // Note that the untrained model is random at this point.\n * model.predict(tf.randomNormal([10, 1])).print();\n * ```\n * @param layer Layer instance.\n *\n * @exception ValueError In case the `layer` argument does not know its input\n * shape.\n * @exception ValueError In case the `layer` argument has multiple output\n * tensors, or is already connected somewhere else (forbidden in\n * `Sequential` models).\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n add(layer: Layer): void {\n const isLayerModelInstance =\n layer instanceof Sequential || layer instanceof Model;\n let modelLayer: Model;\n if (isLayerModelInstance) {\n modelLayer = layer as Model;\n if (modelLayer.outputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n if (modelLayer.inputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single input tensor. ' +\n 'For multi-input layers, ' +\n 'use the functional API.');\n }\n }\n\n if (this.outputs.length === 0) {\n // first layer in model: check that it is an input layer\n if (layer.inboundNodes.length === 0) {\n // create an input layer\n if (layer.batchInputShape == null) {\n throw new ValueError(\n 'The first layer in a Sequential model must ' +\n 'get an `inputShape` or `batchInputShape` argument.');\n }\n // Instantiate the input layer.\n const x = Input({\n batchShape: layer.batchInputShape,\n dtype: layer.dtype,\n name: layer.name + '_input'\n });\n // This will build the current layer and create the node connecting\n // the current layer to the input layer we just created.\n layer.apply(x);\n }\n\n if (isLayerModelInstance) {\n this.outputs = modelLayer.outputs;\n this.inputs = modelLayer.inputs;\n } else {\n if (layer.inboundNodes.length !== 1) {\n throw new ValueError(\n 'A layer added to a Sequential model must not already be ' +\n `connected somewhere else. Model received layer ${layer.name} ` +\n `which has ${layer.inboundNodes.length} pre-existing inbound ` +\n 'connections.');\n }\n\n if (layer.inboundNodes[0].outputTensors.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [layer.inboundNodes[0].outputTensors[0]];\n this.inputs = getSourceInputs(this.outputs[0]);\n }\n\n this.inboundNodes = [];\n // We create an input node, which we will keep updated\n // as we add more layers.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n // no model-level masking for now\n inputMasks: generic_utils.pyListRepeat(null, this.inputs.length),\n outputMasks: [null],\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs[0].shape\n });\n } else {\n const outputTensor = layer.apply(this.outputs[0]);\n if (Array.isArray(outputTensor)) {\n throw new TypeError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [outputTensor as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n\n this.layers.push(layer);\n this.built = false;\n }\n\n /**\n * Removes the last layer in the model.\n *\n * @exception TypeError if there are no layers in the model.\n */\n pop(): void {\n if (this.layers.length === 0) {\n throw new TypeError('There are no layers in the model.');\n }\n\n this.layers.pop();\n if (this.layers.length === 0) {\n this.outputs = [];\n this.inboundNodes = [];\n this.outboundNodes = [];\n } else {\n const lastLayerIndex = this.layers.length - 1;\n this.layers[lastLayerIndex].outboundNodes = [];\n this.outputs = [this.layers[lastLayerIndex].output as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.call(inputs, kwargs);\n }\n\n build(inputShape?: Shape|Shape[]) {\n // Call `getExactlyOneShape` without using its return value,\n // to verify that exactly one input shape is provided.\n getExactlyOneShape(inputShape);\n\n if (this.inputs.length === 0 || this.outputs.length === 0) {\n throw new TypeError(\n 'Sequential model cannot be built: model is empty.' +\n ' Add some layers first.');\n }\n // actually create the model\n this.model = new Model({\n inputs: this.inputs,\n outputs: this.outputs[0],\n name: this.name + '_model'\n });\n this.model.trainable = this.trainable;\n this.model.updatable = this.updatable;\n\n // mirror model attributes\n this.supportsMasking = this.model.supportsMasking;\n // TODO(michaelterry): Add caches\n this.inputLayers = this.model.inputLayers;\n this.inputLayersNodeIndices = this.model.inputLayersNodeIndices;\n this.inputLayersTensorIndices = this.model.inputLayersTensorIndices;\n this.outputLayers = this.model.outputLayers;\n this.outputLayersNodeIndices = this.model.outputLayersNodeIndices;\n this.outputLayersTensorIndices = this.model.outputLayersTensorIndices;\n this.nodesByDepth = this.model.nodesByDepth;\n this.containerNodes = this.model.containerNodes;\n this.outputNames = this.model.outputNames;\n this.inputNames = this.model.inputNames;\n // TODO(michaelterry): Add feedInputNames, feedInputs, if needed.\n // TODO(michaelterry): Add callbackModel if needed.\n this.built = true;\n }\n\n countParams(): number {\n if (!this.built) {\n this.build();\n }\n return super.countParams();\n }\n\n /**\n * Print a text summary of the Sequential model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 100, inputShape: [10], activation: 'relu'}));\n * model.add(tf.layers.dense({units: 1, activation: 'sigmoid'}));\n *\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n this.build();\n }\n super.summary(lineLength, positions, printFn);\n }\n\n /**\n * Sets the weights of the model.\n *\n * @param weights Should be a list of Tensors with shapes and types matching\n * the output of `model.getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n if (this.model == null) {\n this.build();\n }\n this.model.setWeights(weights);\n }\n\n get updatable(): boolean {\n return this._updatable;\n }\n\n set updatable(value: boolean) {\n if (this.built) {\n this.model.updatable = value;\n }\n this._updatable = value;\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * });\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model\n * has multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before being used.');\n }\n return this.model.evaluate(x, y, config);\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([2, 10])).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param conifg A `ModelPredictConfig` object containing optional fields.\n *\n * @return `Tensor`(s) of predictions.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predict(x, config);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * @param x: Input samples, as an Tensor, or list of Tensors (if the model\n * has multiple inputs).\n * @return Tensor(s) of predictions\n */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predictOnBatch(x);\n }\n\n /**\n * See `Model.compile`.\n *\n * @param config\n */\n compile(config: ModelCompileConfig): void {\n this.build();\n this.model.compile(config);\n this.optimizer = this.model.optimizer;\n this.loss = this.model.loss;\n this.metrics = this.model.metrics;\n // TODO(cais): Add this.lossWeights, this.sampleWeightMode,\n // this.weightedMetrics, this.targets.\n this.metricsTensors = this.model.metricsTensors;\n this.metricsNames = this.model.metricsNames;\n // TODO(cais): Add sampleWeights.\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const history = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(history.history.loss[0]);\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before ' +\n 'being used.');\n }\n return this.model.fit(x, y, config);\n }\n\n /* See parent class for JsDoc */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const model = new cls({});\n if (!(model instanceof Sequential)) {\n throw new ValueError(\n `Sequential.fromConfig called on non-Sequential input: ${model}`);\n }\n if (!(config instanceof Array)) {\n throw new ValueError(\n `Sequential.fromConfig called without an array of configs`);\n }\n if (!(config[0].className != null) || config[0]['className'] === 'Merge') {\n throw new ValueError('Legacy serialization format not supported yet.');\n }\n for (const conf of config as serialization.ConfigDictArray) {\n const layer = deserialize(conf as serialization.ConfigDict) as Layer;\n model.add(layer);\n }\n return model;\n }\n\n // TODO(cais): Override get trainableWeights() here\n\n // tslint:disable-next-line:no-any\n getConfig(): any {\n // NOTE(cais): We override the return type of getConfig() to `any` here,\n // because the `Sequential` class is a special case among `Container`\n // subtypes in that its getConfig() method returns an Array (not a\n // dict).\n const config: serialization.ConfigDict[] = [];\n for (const layer of this.layers) {\n config.push({\n className: layer.getClassName(),\n config: layer.getConfig(),\n });\n }\n return config;\n }\n}\nserialization.SerializationMap.register(Sequential);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Exported functions.\n */\n\n// tslint:disable:max-line-length\nimport {io} from '@tensorflow/tfjs-core';\n\nimport {ContainerConfig} from './engine/container';\nimport {Input, InputConfig,} from './engine/input_layer';\nimport {SymbolicTensor} from './engine/topology';\nimport {Model} from './engine/training';\nimport {loadModelInternal, Sequential, SequentialConfig} from './models';\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Model and related factory methods.\n\n/**\n * A model is a data structure that consists of `Layers` and defines inputs\n * and outputs.\n *\n * The key difference between `model` and `sequential` is that `model`\n * is more generic, supporting an arbitrary graph (without cycles) of layers.\n * `sequential` is less generic and supports only a linear stack of layers.\n *\n * When creating a `Model`, specify its input(s) and output(s). Layers\n * are used to wire input(s) to output(s).\n *\n * For example, the following code snippet defines a model consisting of\n * two `dense` layers, with 10 and 4 units, respectively.\n *\n * ```js\n * // Define input, which has a size of 5 (not including batch dimension).\n * const input = tf.input({shape: [5]});\n *\n * // First dense layer uses relu activation.\n * const denseLayer1 = tf.layers.dense({units: 10, activation: 'relu'});\n * // Second dense layer uses softmax activation.\n * const denseLayer2 = tf.layers.dense({units: 2, activation: 'softmax'});\n *\n * // Obtain the output symbolic tensor by applying the layers on the input.\n * const output = denseLayer2.apply(denseLayer1.apply(input));\n *\n * // Create the model based on the inputs.\n * const model = tf.model({inputs: input, outputs: output});\n *\n * // The model can be used for training, evaluation and prediction.\n * // For example, the following line runs prediction with the model on\n * // some fake data.\n * model.predict(tf.ones([2, 5])).print();\n * ```\n * See also:\n * `sequential`, `loadModel`.\n */\n\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function model(config: ContainerConfig): Model {\n return new Model(config);\n}\n\n/**\n * Creates a `Sequential` model. A sequential model is any model where the\n * outputs of one layer are the inputs to the next layer, i.e. the model\n * topology is a simple 'stack' of layers, with no branching or skipping.\n *\n * This means that the first layer passed to a Sequential model should have a\n * defined input shape. What that means is that it should have received an\n * `inputShape` or `batchInputShape` argument, or for some type of layers\n * (recurrent, Dense...) an `inputDim` argument.\n *\n * The key difference between `model` and `sequential` is that `sequential`\n * is less generic, supporting only a linear stack of layers. `model` is\n * more generic and supports an arbitrary graph (without cycles) of layers.\n *\n * Examples:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have an input shape defined.\n * model.add(tf.layers.dense({units: 32, inputShape: [50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output, which equals\n * // `[null, 4]`. The 1st dimension is the undetermined batch dimension; the\n * // 2nd is the output size of the model's last layer.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * It is also possible to specify a batch size (with potentially undetermined\n * batch dimension, denoted by \"null\") for the first layer using the\n * `batchInputShape` key. The following example is equivalent to the above:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have a defined input shape\n * model.add(tf.layers.dense({units: 32, batchInputShape: [null, 50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * You can also use an `Array` of already-constructed `Layer`s to create\n * a `Sequential` model:\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 32, inputShape: [50]}),\n * tf.layers.dense({units: 4})]\n * });\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function sequential(config?: SequentialConfig): Sequential {\n return new Sequential(config);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * useDocsFrom: 'loadModelInternal'\n * }\n */\nexport function loadModel(pathOrIOHandler: string|\n io.IOHandler): Promise {\n return loadModelInternal(pathOrIOHandler);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Inputs',\n * useDocsFrom: 'Input',\n * configParamIndices: [0]\n * }\n */\nexport function input(config: InputConfig): SymbolicTensor {\n return Input(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Layer activation functions\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject} from './utils/generic_utils';\n\n/**\n * Base class for Activations.\n *\n * Special note: due to cross-language compatibility reasons, the\n * static readonly className field in this family of classes must be set to\n * the initialLowerCamelCase name of the activation.\n */\nexport abstract class Activation extends serialization.Serializable {\n abstract apply(tensor: Tensor, axis?: number): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/** @docinline */\nexport type ActivationIdentifier = 'elu'|'hardSigmoid'|'linear'|'relu'|'relu6'|\n 'selu'|'sigmoid'|'softmax'|'softplus'|'softsign'|'tanh'|string;\n\n/**\n * Exponential linear unit (ELU).\n * Reference: https://arxiv.org/abs/1511.07289\n */\nexport class Elu extends Activation {\n static readonly className = 'elu';\n /**\n * Calculate the activation function.\n *\n * @param x: Input.\n * @param alpha: Scaling factor the negative section.\n * @return Output of the ELU activation.\n */\n apply(x: Tensor, alpha = 1): Tensor {\n return K.elu(x, alpha);\n }\n}\nserialization.SerializationMap.register(Elu);\n\n/**\n * Scaled Exponential Linear Unit. (Klambauer et al., 2017).\n * Reference: Self-Normalizing Neural Networks, https://arxiv.org/abs/1706.02515\n * Notes:\n * - To be used together with the initialization \"lecunNormal\".\n * - To be used together with the dropout variant \"AlphaDropout\".\n */\nexport class Selu extends Activation {\n static readonly className = 'selu';\n apply(x: Tensor): Tensor {\n return tfc.selu(x);\n }\n}\nserialization.SerializationMap.register(Selu);\n\n/**\n * Rectified linear unit\n */\nexport class Relu extends Activation {\n static readonly className = 'relu';\n apply(x: Tensor): Tensor {\n return tfc.relu(x);\n }\n}\nserialization.SerializationMap.register(Relu);\n\n/**\n * Rectified linear unit activation maxing out at 6.0.\n */\nexport class Relu6 extends Activation {\n static readonly className = 'relu6';\n apply(x: Tensor): Tensor {\n return tidy(() => tfc.minimum(getScalar(6.0), tfc.relu(x)));\n }\n}\nserialization.SerializationMap.register(Relu6);\n\n//* Linear activation (no-op) */\nexport class Linear extends Activation {\n static readonly className = 'linear';\n apply(x: Tensor): Tensor {\n return x;\n }\n}\nserialization.SerializationMap.register(Linear);\n\n/**\n * Sigmoid activation function.\n */\nexport class Sigmoid extends Activation {\n static readonly className = 'sigmoid';\n apply(x: Tensor): Tensor {\n return tfc.sigmoid(x);\n }\n}\nserialization.SerializationMap.register(Sigmoid);\n\n/**\n * Segment-wise linear approximation of sigmoid.\n */\nexport class HardSigmoid extends Activation {\n static readonly className = 'hardSigmoid';\n apply(x: Tensor): Tensor {\n return K.hardSigmoid(x);\n }\n}\nserialization.SerializationMap.register(HardSigmoid);\n\n/**\n * Softplus activation function.\n */\nexport class Softplus extends Activation {\n static readonly className = 'softplus';\n apply(x: Tensor): Tensor {\n return tfc.softplus(x);\n }\n}\nserialization.SerializationMap.register(Softplus);\n\n/**\n * Softsign activation function.\n */\nexport class Softsign extends Activation {\n static readonly className = 'softsign';\n apply(x: Tensor): Tensor {\n return K.softsign(x);\n }\n}\nserialization.SerializationMap.register(Softsign);\n\n/**\n * Hyperbolic tangent function.\n */\nexport class Tanh extends Activation {\n static readonly className = 'tanh';\n apply(x: Tensor): Tensor {\n return tfc.tanh(x);\n }\n}\nserialization.SerializationMap.register(Tanh);\n\n/**\n * Softmax activation function\n */\nexport class Softmax extends Activation {\n static readonly className = 'softmax';\n /**\n * Calculate the activation function.\n *\n * @param x Tensor.\n * @param axis Integer, axis along which the softmax normalization is applied.\n * Invalid if < 2, as softmax across 1 (the batch dimension) is assumed to be\n * an error.\n *\n * @returns a Tensor of the same shape as x\n *\n * @throws ValueError: In case `dim(x) < 2`.\n */\n apply(x: Tensor, axis: number = (-1)): Tensor {\n return tfc.softmax(x, axis);\n }\n}\nserialization.SerializationMap.register(Softmax);\n\nexport function serializeActivation(activation: Activation): string {\n return activation.getClassName();\n}\n\nexport function deserializeActivation(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Activation {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'activation');\n}\n\nexport function getActivation(identifier: ActivationIdentifier|\n serialization.ConfigDict|Activation): Activation {\n if (identifier == null) {\n const config = {className: 'linear', config: {}};\n return deserializeActivation(config);\n }\n if (typeof identifier === 'string') {\n const config = {className: identifier, config: {}};\n return deserializeActivation(config);\n } else if (identifier instanceof Activation) {\n return identifier;\n } else {\n return deserializeActivation(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Advanced activation layers.\n */\n\nimport {elu, leakyRelu, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {Softmax as softmaxActivation} from '../activations';\nimport {cast} from '../backend/tfjs_backend';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneTensor} from '../utils/types_utils';\n\nexport interface LeakyReLULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `0.3`.\n */\n alpha?: number;\n}\n\n/**\n * Leaky version of a rectified linear unit.\n *\n * It allows a small gradient when the unit is not active:\n * `f(x) = alpha * x for x < 0.`\n * `f(x) = x for x >= 0.`\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class LeakyReLU extends Layer {\n static className = 'LeakyReLU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 0.3;\n\n constructor(config?: LeakyReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return leakyRelu(x, this.alpha);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LeakyReLU);\n\n// TODO(cais): Implement PReLU\n\nexport interface ELULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `1.0`.\n */\n alpha?: number;\n}\n\n/**\n * Exponetial Linear Unit (ELU).\n *\n * It follows:\n * `f(x) = alpha * (exp(x) - 1.) for x < 0`,\n * `f(x) = x for x >= 0`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Fast and Accurate Deep Network Learning by Exponential Linear Units\n * (ELUs)](https://arxiv.org/abs/1511.07289v1)\n */\nexport class ELU extends Layer {\n static className = 'ELU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 1.0;\n\n constructor(config?: ELULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n if (config.alpha != null && config.alpha !== this.DEFAULT_ALPHA) {\n throw new NotImplementedError(\n `Non-default alpha value (${config.alpha}) is not supported by the ` +\n `ELU layer yet.`);\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return elu(x);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ELU);\n\nexport interface ThresholdedReLULayerConfig extends LayerConfig {\n /**\n * Float >= 0. Threshold location of activation.\n */\n theta?: number;\n}\n\n/**\n * Thresholded Rectified Linear Unit.\n *\n * It follows:\n * `f(x) = x for x > theta`,\n * `f(x) = 0 otherwise`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Zero-Bias Autoencoders and the Benefits of Co-Adapting\n * Features](http://arxiv.org/abs/1402.3337)\n */\nexport class ThresholdedReLU extends Layer {\n static className = 'ThresholdedReLU';\n readonly theta: number;\n private readonly thetaTensor: Tensor;\n\n readonly DEFAULT_THETA = 1.0;\n\n constructor(config?: ThresholdedReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.theta = config.theta == null ? this.DEFAULT_THETA : config.theta;\n this.thetaTensor = getScalar(this.theta);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return x.mul(cast(x.greater(this.thetaTensor), 'float32'));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {theta: this.theta};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ThresholdedReLU);\n\nexport interface SoftmaxLayerConfig extends LayerConfig {\n /**\n * Integer, axis along which the softmax normalization is applied.\n * Defaults to `-1` (i.e., the last axis).\n */\n axis?: number;\n}\n\n/**\n * Softmax activation layer.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class Softmax extends Layer {\n static className = 'Softmax';\n readonly axis: number;\n readonly softmax: (t: Tensor, a?: number) => Tensor;\n readonly DEFAULT_AXIS = 1.0;\n\n constructor(config?: SoftmaxLayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n this.softmax = new softmaxActivation().apply;\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return this.softmax(x, this.axis);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {axis: this.axis};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Softmax);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* original source: keras/regularizers.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {abs, add, Scalar, serialization, sum, Tensor, tidy, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Regularizer base class.\n */\nexport abstract class Regularizer extends serialization.Serializable {\n abstract apply(x: Tensor): Scalar;\n}\n\nexport interface L1L2Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1?: number;\n /** L2 regularization rate. Defaults to 0.01. */\n l2?: number;\n}\n\nexport interface L1Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1: number;\n}\n\nexport interface L2Config {\n /** L2 regularization rate. Defaults to 0.01. */\n l2: number;\n}\n\n/**\n * Regularizer for L1 and L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x)) + sum(l2 * x^2)\n */\n/** @doc {heading: 'Regularizers', namespace: 'regularizers'} */\nexport class L1L2 extends Regularizer {\n static className = 'L1L2';\n\n private readonly l1: Scalar;\n private readonly l2: Scalar;\n private readonly hasL1: boolean;\n private readonly hasL2: boolean;\n constructor(config?: L1L2Config) {\n super();\n\n const l1 = config == null || config.l1 == null ? 0.01 : config.l1;\n const l2 = config == null || config.l2 == null ? 0.01 : config.l2;\n this.hasL1 = l1 !== 0;\n this.hasL2 = l2 !== 0;\n\n this.l1 = getScalar(l1);\n this.l2 = getScalar(l2);\n }\n\n /**\n * Porting note: Renamed from __call__.\n * @param x Variable of which to calculate the regularization score.\n */\n apply(x: Tensor): Scalar {\n return tidy(() => {\n let regularization: Tensor = zeros([1]);\n if (this.hasL1) {\n regularization = add(regularization, sum(tfc.mul(this.l1, abs(x))));\n }\n if (this.hasL2) {\n regularization =\n add(regularization, sum(tfc.mul(this.l2, K.square(x))));\n }\n return regularization.asScalar();\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {'l1': this.l1.dataSync()[0], 'l2': this.l2.dataSync()[0]};\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n return new cls({l1: config.l1 as number, l2: config.l2 as number});\n }\n}\nserialization.SerializationMap.register(L1L2);\n\n/**\n * Regularizer for L1 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x))\n * @param config l1 config.\n */\nexport function l1(config?: L1Config) {\n return new L1L2({l1: config != null ? config.l1 : null, l2: 0});\n}\n\n/**\n * Regularizer for L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l2 * x^2)\n * @param config l2 config.\n */\nexport function l2(config: L2Config) {\n return new L1L2({l2: config != null ? config.l2 : null, l1: 0});\n}\n\n/** @docinline */\nexport type RegularizerIdentifier = 'l1l2'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding keras symbols.\nexport const REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in RegularizerIdentifier]: string} = {\n 'l1l2': 'L1L2'\n };\n\nexport function serializeRegularizer(constraint: Regularizer):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeRegularizer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Regularizer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'regularizer');\n}\n\nexport function getRegularizer(identifier: RegularizerIdentifier|\n serialization.ConfigDict|\n Regularizer): Regularizer {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeRegularizer(config);\n } else if (identifier instanceof Regularizer) {\n return identifier;\n } else {\n return deserializeRegularizer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {PaddingMode} from '../common';\nimport {ValueError} from '../errors';\n\nimport {pyListRepeat} from './generic_utils';\nimport {isInteger, max} from './math_utils';\n\n/**\n * Transforms a single number of array of numbers into an array of numbers.\n * @param value\n * @param n: The size of the tuple to be returned.\n * @param name: Name of the parameter, used for generating error messages.\n * @returns An array of numbers.\n */\nexport function normalizeArray(\n value: number|number[], n: number, name: string): number[] {\n if (typeof value === 'number') {\n return pyListRepeat(value, n);\n } else {\n if (value.length !== n) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${n} integers. Received: ` +\n `${value.length} elements.`);\n }\n for (let i = 0; i < n; ++i) {\n const singleValue = value[i];\n if (!isInteger(singleValue)) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${\n n} integers. Received: ` +\n `${JSON.stringify(value)} including a non-integer number ` +\n `${singleValue}`);\n }\n }\n return value;\n }\n}\n\n/**\n * Determines output length of a convolution given input length.\n * @param inputLength\n * @param filterSize\n * @param padding\n * @param stride\n * @param dilation: dilation rate.\n */\nexport function convOutputLength(\n inputLength: number, filterSize: number, padding: PaddingMode,\n stride: number, dilation = 1): number {\n if (inputLength == null) {\n return inputLength;\n }\n const dilatedFilterSize = filterSize + (filterSize - 1) * (dilation - 1);\n let outputLength: number;\n if (padding === 'same') {\n outputLength = inputLength;\n } else { // VALID\n outputLength = inputLength - dilatedFilterSize + 1;\n }\n return Math.floor((outputLength + stride - 1) / stride);\n}\n\nexport function deconvLength(\n dimSize: number, strideSize: number, kernelSize: number,\n padding: PaddingMode): number {\n if (dimSize == null) {\n return null;\n }\n\n if (padding === 'valid') {\n dimSize = dimSize * strideSize + max([kernelSize - strideSize, 0]);\n } else if (padding === 'same') {\n dimSize = dimSize * strideSize;\n } else {\n throw new ValueError(`Unsupport padding mode: ${padding}.`);\n }\n return dimSize;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {Activation, getActivation, serializeActivation} from '../activations';\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, DataFormat, PaddingMode} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength, deconvLength, normalizeArray} from '../utils/conv_utils';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n/**\n * Transpose and cast the input before the conv2d.\n * @param x Input image tensor.\n * @param dataFormat\n */\nexport function preprocessConv2DInput(\n x: Tensor, dataFormat: DataFormat): Tensor {\n // TODO(cais): Cast type to float32 if not.\n return tidy(() => {\n checkDataFormat(dataFormat);\n if (dataFormat === 'channelsFirst') {\n return tfc.transpose(x, [0, 2, 3, 1]); // NCHW -> NHWC.\n } else {\n return x;\n }\n });\n}\n\n/**\n * 1D-convolution with bias added.\n *\n * Porting Note: This function does not exist in the Python Keras backend.\n * It is exactly the same as `conv2d`, except the added `bias`.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.\n * @param bias Bias, rank-3, of shape `[outDepth]`.\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n // Check the ranks of x, kernel and bias.\n if (x.shape.length !== 3) {\n throw new ValueError(\n `The input of a conv1dWithBias operation should be 3, but is ` +\n `${x.shape.length} instead.`);\n }\n if (kernel.shape.length !== 3) {\n throw new ValueError(\n `The kernel for a conv1dWithBias operation should be 3, but is ` +\n `${kernel.shape.length} instead`);\n }\n if (bias != null && bias.shape.length !== 1) {\n throw new ValueError(\n `The bias for a conv1dWithBias operation should be 1, but is ` +\n `${kernel.shape.length} instead`);\n }\n // TODO(cais): Support CAUSAL padding mode.\n if (dataFormat === 'channelsFirst') {\n x = tfc.transpose(x, [0, 2, 1]); // NCW -> NWC.\n }\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n let y: Tensor = tfc.conv1d(\n x as Tensor2D | Tensor3D, kernel as Tensor3D, strides,\n padding === 'same' ? 'same' : 'valid', 'NWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias);\n }\n return y;\n });\n}\n\n/**\n * 1D-convolution.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.s\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1d(\n x: Tensor, kernel: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv1dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution\n * @param x\n * @param kernel kernel of the convolution.\n * @param strides strides array.\n * @param padding padding mode. Default to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param dilationRate dilation rate array.\n * @returns Result of the 2D pooling.\n */\nexport function conv2d(\n x: Tensor, kernel: Tensor, strides = [1, 1], padding = 'valid',\n dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv2dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution with an added bias.\n * Note: This function does not exist in the Python Keras Backend. This function\n * is exactly the same as `conv2d`, except the added `bias`.\n */\nexport function conv2dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n if (x.rank !== 3 && x.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects input to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n if (kernel.rank !== 3 && kernel.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects kernel to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n let y = preprocessConv2DInput(x, dataFormat);\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n y = tfc.conv2d(\n y as Tensor3D | Tensor4D, kernel as Tensor4D,\n strides as [number, number], padding === 'same' ? 'same' : 'valid',\n 'NHWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias as Tensor1D);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\n\n/**\n * Base LayerConfig for depthwise and non-depthwise convolutional layers.\n */\nexport interface BaseConvLayerConfig extends LayerConfig {\n /**\n * The dimensions of the convolution window. If kernelSize is a number, the\n * convolutional window will be square.\n */\n kernelSize: number|number[];\n\n /**\n * The strides of the convolution in each dimension. If strides is a number,\n * strides in both dimensions are equal.\n *\n * Specifying any stride value != 1 is incompatible with specifying any\n * `dilationRate` value != 1.\n */\n strides?: number|number[];\n\n /**\n * Padding mode.\n */\n padding?: PaddingMode;\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n\n /**\n * The dilation rate to use for the dilated convolution in each dimension.\n * Should be an integer or array of two integers.\n *\n * Currently, specifying any `dilationRate` value != 1 is incompatible with\n * specifying any `strides` value != 1.\n */\n dilationRate?: number|[number]|[number, number];\n\n /**\n * Activation function of the layer.\n *\n * If you don't specify the activation, none is applied.\n */\n activation?: string;\n\n /**\n * Whether the layer uses a bias vector. Defaults to `true`.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the convolutional kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the convolutional kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * LayerConfig for non-depthwise convolutional layers.\n * Applies to non-depthwise convolution of all ranks (e.g, Conv1D, Conv2D).\n */\nexport interface ConvLayerConfig extends BaseConvLayerConfig {\n /**\n * The dimensionality of the output space (i.e. the number of filters in the\n * convolution).\n */\n filters: number;\n}\n\n/**\n * Abstract convolution layer.\n */\nexport abstract class BaseConv extends Layer {\n protected readonly rank: number;\n protected readonly kernelSize: number[];\n protected readonly strides: number[];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n protected readonly activation: Activation;\n protected readonly useBias: boolean;\n protected readonly dilationRate: number[];\n\n // Bias-related members are here because all convolution subclasses use the\n // same configuration parmeters to control bias. Kernel-related members\n // are in subclass `Conv` because some subclasses use different parameters to\n // control kernel properties, for instance, `DepthwiseConv2D` uses\n // `depthwiseInitializer` instead of `kernelInitializer`.\n protected readonly biasInitializer?: Initializer;\n protected readonly biasConstraint?: Constraint;\n protected readonly biasRegularizer?: Regularizer;\n\n protected bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(rank: number, config: BaseConvLayerConfig) {\n super(config as LayerConfig);\n BaseConv.verifyConfig(config);\n this.rank = rank;\n if (this.rank !== 1 && this.rank !== 2) {\n throw new NotImplementedError(\n `Convolution layer for rank other than 1 or 2 (${this.rank}) is ` +\n `not implemented yet.`);\n }\n this.kernelSize = normalizeArray(config.kernelSize, rank, 'kernelSize');\n this.strides = normalizeArray(\n config.strides == null ? 1 : config.strides, rank, 'strides');\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.activation = getActivation(config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.dilationRate = normalizeArray(\n config.dilationRate == null ? 1 : config.dilationRate, rank,\n 'dilationRate');\n if (this.rank === 1 &&\n (Array.isArray(this.dilationRate) &&\n (this.dilationRate as number[]).length !== 1)) {\n throw new ValueError(\n `dilationRate must be a number or an array of a single number ` +\n `for 1D convolution, but received ` +\n `${JSON.stringify(this.dilationRate)}`);\n }\n if (this.rank === 2) {\n if (typeof this.dilationRate === 'number') {\n this.dilationRate = [this.dilationRate, this.dilationRate];\n } else if (this.dilationRate.length !== 2) {\n throw new ValueError(\n `dilationRate must be a number or array of two numbers for 2D ` +\n `convolution, but received ${JSON.stringify(this.dilationRate)}`);\n }\n }\n }\n\n protected static verifyConfig(config: BaseConvLayerConfig) {\n // Check config.kernelSize type and shape.\n generic_utils.assert(\n 'kernelSize' in config, `required key 'kernelSize' not in config`);\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `BaseConv expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n kernelSize: this.kernelSize,\n strides: this.strides,\n padding: this.padding,\n dataFormat: this.dataFormat,\n dilationRate: this.dilationRate,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n biasInitializer: serializeInitializer(this.biasInitializer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Abstract nD convolution layer. Ancestor of convolution layers which reduce\n * across channels, i.e., Conv1D and Conv2D, but not DepthwiseConv2D.\n */\nexport abstract class Conv extends BaseConv {\n protected readonly filters: number;\n\n protected kernel: LayerVariable = null;\n\n // Bias-related properties are stored in the superclass `BaseConv` because all\n // convolution subclasses use the same configuration parameters to control\n // bias. Kernel-related properties are defined here rather than in the\n // superclass because some convolution subclasses use different names and\n // configuration parameters for their internal kernel state.\n protected readonly kernelInitializer?: Initializer;\n protected readonly kernelConstraint?: Constraint;\n protected readonly kernelRegularizer?: Regularizer;\n\n constructor(rank: number, config: ConvLayerConfig) {\n super(rank, config as BaseConvLayerConfig);\n Conv.verifyConfig(config);\n this.filters = config.filters;\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n `The channel dimension of the input should be defined. ` +\n `Found ${inputShape[channelAxis]}`);\n }\n const inputDim = inputShape[channelAxis];\n\n const kernelShape = this.kernelSize.concat([inputDim, this.filters]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n this.inputSpec = [{ndim: this.rank + 2, axes: {[channelAxis]: inputDim}}];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs: Tensor;\n const biasValue = this.bias == null ? null : this.bias.read();\n\n if (this.rank === 1) {\n outputs = conv1dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides[0],\n this.padding, this.dataFormat, this.dilationRate[0]);\n } else if (this.rank === 2) {\n // TODO(cais): Move up to constructor.\n outputs = conv2dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides, this.padding,\n this.dataFormat, this.dilationRate as [number, number]);\n } else if (this.rank === 3) {\n throw new NotImplementedError('3D convolution is not implemented yet.');\n }\n\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const newSpace: number[] = [];\n const space = (this.dataFormat === 'channelsLast') ?\n inputShape.slice(1, inputShape.length - 1) :\n inputShape.slice(2);\n for (let i = 0; i < space.length; ++i) {\n const newDim = convOutputLength(\n space[i], this.kernelSize[i], this.padding, this.strides[i],\n typeof this.dilationRate === 'number' ? this.dilationRate :\n this.dilationRate[i]);\n newSpace.push(newDim);\n }\n\n let outputShape = [inputShape[0]];\n if (this.dataFormat === 'channelsLast') {\n outputShape = outputShape.concat(newSpace);\n outputShape.push(this.filters);\n } else {\n outputShape.push(this.filters);\n outputShape = outputShape.concat(newSpace);\n }\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n filters: this.filters,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // Check config.filters type, shape, and value.\n if (!('filters' in config) || typeof config.filters !== 'number' ||\n config.filters < 1) {\n throw new ValueError(\n `Convolution layer expected config.filters to be a 'number' > 0 ` +\n `but got ${JSON.stringify(config.filters)}`);\n }\n }\n}\n\n\n/**\n * 2D convolution layer (e.g. spatial convolution over images).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input to produce a tensor of outputs.\n *\n * If `useBias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model,\n * provide the keyword argument `inputShape`\n * (Array of integers, does not include the sample axis),\n * e.g. `inputShape=[128, 128, 3]` for 128x128 RGB pictures\n * in `dataFormat='channelsLast'`.\n */\nexport class Conv2D extends Conv {\n static className = 'Conv2D';\n constructor(config: ConvLayerConfig) {\n super(2, config);\n Conv2D.verifyConfig(config);\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if ((typeof config.kernelSize !== 'number') &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `Conv2D expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv2D);\n\n/**\n * Transposed convolutional layer (sometimes called Deconvolution).\n *\n * The need for transposed convolutions generally arises\n * from the desire to use a transformation going in the opposite direction of\n * a normal convolution, i.e., from something that has the shape of the output\n * of some convolution to something that has the shape of its input while\n * maintaining a connectivity pattern that is compatible with said\n * convolution.\n *\n * When using this layer as the first layer in a model, provide the\n * configuration `inputShape` (`Array` of integers, does not include the\n * sample axis), e.g., `inputShape: [128, 128, 3]` for 128x128 RGB pictures in\n * `dataFormat: 'channelsLast'`.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if `dataFormat` is `'channelsFirst'`.\n * or 4D tensor with shape\n * `[batch, rows, cols, channels]` if `dataFormat` is `'channelsLast`.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if `dataFormat` is\n * `'channelsFirst'`. or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if `dataFormat` is `'channelsLast'`.\n *\n * References:\n * - [A guide to convolution arithmetic for deep\n * learning](https://arxiv.org/abs/1603.07285v1)\n * - [Deconvolutional\n * Networks](http://www.matthewzeiler.com/pubs/cvpr2010/cvpr2010.pdf)\n */\nexport class Conv2DTranspose extends Conv2D {\n static className = 'Conv2DTranspose';\n inputSpec: InputSpec[];\n\n constructor(config: ConvLayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 4})];\n\n if (this.padding !== 'same' && this.padding !== 'valid') {\n throw new ValueError(\n `Conv2DTranspose currently supports only padding modes 'same' ` +\n `and 'valid', but received padding mode ${this.padding}`);\n }\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n\n if (inputShape.length !== 4) {\n throw new ValueError(\n 'Input should have rank 4; Received input shape: ' +\n JSON.stringify(inputShape));\n }\n\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n 'The channel dimension of the inputs should be defined. ' +\n 'Found `None`.');\n }\n const inputDim = inputShape[channelAxis];\n const kernelShape = this.kernelSize.concat([this.filters, inputDim]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, 'float32', this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n // Set input spec.\n this.inputSpec =\n [new InputSpec({ndim: 4, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs);\n if (input.shape.length !== 4) {\n throw new ValueError(\n `Conv2DTranspose.call() expects input tensor to be rank-4, but ` +\n `received a tensor of rank-${input.shape.length}`);\n }\n\n const inputShape = input.shape;\n const batchSize = inputShape[0];\n\n let hAxis: number;\n let wAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n hAxis = 2;\n wAxis = 3;\n } else {\n hAxis = 1;\n wAxis = 2;\n }\n\n const height = inputShape[hAxis];\n const width = inputShape[wAxis];\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n // Infer the dynamic output shape.\n const outHeight = deconvLength(height, strideH, kernelH, this.padding);\n const outWidth = deconvLength(width, strideW, kernelW, this.padding);\n\n // Porting Note: We don't branch based on `this.dataFormat` here,\n // because\n // the tjfs-core function `conv2dTranspose` called below always\n // assumes channelsLast.\n const outputShape: [number, number, number, number] =\n [batchSize, outHeight, outWidth, this.filters];\n\n if (this.dataFormat !== 'channelsLast') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n }\n let outputs = tfc.conv2dTranspose(\n input as Tensor4D, this.kernel.read() as Tensor4D, outputShape,\n this.strides as [number, number], this.padding as 'same' | 'valid');\n if (this.dataFormat !== 'channelsLast') {\n outputs = tfc.transpose(outputs, [0, 3, 1, 2]) as Tensor4D;\n }\n\n if (this.bias != null) {\n outputs =\n K.biasAdd(outputs, this.bias.read(), this.dataFormat) as Tensor4D;\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs) as Tensor4D;\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n\n let channelAxis: number;\n let heightAxis: number;\n let widthAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n channelAxis = 1;\n heightAxis = 2;\n widthAxis = 3;\n } else {\n channelAxis = 3;\n heightAxis = 1;\n widthAxis = 2;\n }\n\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n outputShape[channelAxis] = this.filters;\n outputShape[heightAxis] =\n deconvLength(outputShape[heightAxis], strideH, kernelH, this.padding);\n outputShape[widthAxis] =\n deconvLength(outputShape[widthAxis], strideW, kernelW, this.padding);\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['dilationRate'];\n return config;\n }\n}\nserialization.SerializationMap.register(Conv2DTranspose);\n\n\nexport interface SeparableConvLayerConfig extends ConvLayerConfig {\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal\n * to `filtersIn * depthMultiplier`. Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the pointwise kernel matrix.\n */\n pointwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the pointwise kernel matrix.\n */\n pointwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the pointwise kernel matrix.\n */\n pointwiseConstraint?: ConstraintIdentifier|Constraint;\n}\n\n\nexport class SeparableConv extends Conv {\n static className = 'SeparableConv';\n\n readonly depthMultiplier: number;\n\n protected readonly depthwiseInitializer?: Initializer;\n protected readonly depthwiseRegularizer?: Regularizer;\n protected readonly depthwiseConstraint?: Constraint;\n protected readonly pointwiseInitializer?: Initializer;\n protected readonly pointwiseRegularizer?: Regularizer;\n protected readonly pointwiseConstraint?: Constraint;\n\n readonly DEFAULT_DEPTHWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n readonly DEFAULT_POINTWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n\n protected depthwiseKernel: LayerVariable = null;\n protected pointwiseKernel: LayerVariable = null;\n\n constructor(rank: number, config?: SeparableConvLayerConfig) {\n super(rank, config);\n\n if (config.filters == null) {\n throw new ValueError(\n 'The `filters` configuration field is required by SeparableConv, ' +\n 'but is unspecified.');\n }\n if (config.kernelInitializer != null || config.kernelRegularizer != null ||\n config.kernelConstraint != null) {\n throw new ValueError(\n 'Fields kernelInitializer, kernelRegularizer and kernelConstraint ' +\n 'are invalid for SeparableConv2D. Use depthwiseInitializer, ' +\n 'depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, ' +\n 'pointwiseRegularizer and pointwiseConstraint instead.');\n }\n if (config.padding != null && config.padding !== 'same' &&\n config.padding !== 'valid') {\n throw new ValueError(\n `SeparableConv${this.rank}D supports only padding modes: ` +\n `'same' and 'valid', but received ${JSON.stringify(config.padding)}`);\n }\n\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_DEPTHWISE_INITIALIZER);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.pointwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_POINTWISE_INITIALIZER);\n this.pointwiseRegularizer = getRegularizer(config.pointwiseRegularizer);\n this.pointwiseConstraint = getConstraint(config.pointwiseConstraint);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < this.rank + 2) {\n throw new ValueError(\n `Inputs to SeparableConv${this.rank}D should have rank ` +\n `${this.rank + 2}, but received input shape: ` +\n `${JSON.stringify(inputShape)}`);\n }\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n `The channel dimension of the inputs should be defined, ` +\n `but found ${JSON.stringify(inputShape[channelAxis])}`);\n }\n\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape =\n this.kernelSize.concat([inputDim, this.depthMultiplier]);\n const pointwiseKernelShape = [];\n for (let i = 0; i < this.rank; ++i) {\n pointwiseKernelShape.push(1);\n }\n pointwiseKernelShape.push(inputDim * this.depthMultiplier, this.filters);\n\n const trainable = true;\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, 'float32',\n this.depthwiseInitializer, this.depthwiseRegularizer, trainable,\n this.depthwiseConstraint);\n this.pointwiseKernel = this.addWeight(\n 'pointwise_kernel', pointwiseKernelShape, 'float32',\n this.pointwiseInitializer, this.pointwiseRegularizer, trainable,\n this.pointwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, trainable, this.biasConstraint);\n } else {\n this.bias = null;\n }\n\n this.inputSpec =\n [new InputSpec({ndim: this.rank + 2, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n let output: Tensor;\n if (this.rank === 1) {\n throw new NotImplementedError(\n '1D separable convolution is not implemented yet.');\n } else if (this.rank === 2) {\n if (this.dataFormat === 'channelsFirst') {\n inputs = tfc.transpose(inputs, [0, 2, 3, 1]); // NCHW -> NHWC.\n }\n\n output = tfc.separableConv2d(\n inputs as Tensor4D, this.depthwiseKernel.read() as Tensor4D,\n this.pointwiseKernel.read() as Tensor4D,\n this.strides as [number, number], this.padding as 'same' | 'valid',\n this.dilationRate as [number, number], 'NHWC');\n }\n\n if (this.useBias) {\n output = K.biasAdd(output, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n if (this.dataFormat === 'channelsFirst') {\n output = tfc.transpose(output, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['kernelInitializer'];\n delete config['kernelRegularizer'];\n delete config['kernelConstraint'];\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['pointwiseInitializer'] =\n serializeInitializer(this.pointwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['pointwiseRegularizer'] =\n serializeRegularizer(this.pointwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseConstraint);\n config['pointwiseConstraint'] =\n serializeConstraint(this.pointwiseConstraint);\n return config;\n }\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Separable convolution consists of first performing\n * a depthwise spatial convolution\n * (which acts on each input channel separately)\n * followed by a pointwise convolution which mixes together the resulting\n * output channels. The `depthMultiplier` argument controls how many\n * output channels are generated per input channel in the depthwise step.\n *\n * Intuitively, separable convolutions can be understood as\n * a way to factorize a convolution kernel into two smaller kernels,\n * or as an extreme version of an Inception block.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, rows, cols, channels]` if data_format='channelsLast'.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if data_format='channelsLast'.\n * `rows` and `cols` values might have changed due to padding.\n */\nexport class SeparableConv2D extends SeparableConv {\n static className = 'SeparableConv2D';\n constructor(config?: SeparableConvLayerConfig) {\n super(2, config);\n }\n}\nserialization.SerializationMap.register(SeparableConv2D);\n\n/**\n * 1D convolution layer (e.g., temporal convolution).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input over a single spatial (or temporal) dimension\n * to produce a tensor of outputs.\n *\n * If `use_bias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model, provide an\n * `inputShape` argument `Array` or `null`.\n *\n * For example, `inputShape` would be:\n * - `[10, 128]` for sequences of 10 vectors of 128-dimensional vectors\n * - `[null, 128]` for variable-length sequences of 128-dimensional vectors.\n */\nexport class Conv1D extends Conv {\n static className = 'Conv1D';\n constructor(config: ConvLayerConfig) {\n super(1, config);\n Conv1D.verifyConfig(config);\n this.inputSpec = [{ndim: 3}];\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['dataFormat'];\n return config;\n }\n\n static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 1))\n throw new ValueError(\n `Conv1D expects config.kernelSize to be number or number[] with ` +\n `length 1, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv1D);\n\nexport interface Cropping2DLayerConfig extends LayerConfig {\n /**\n * Dimension of the cropping along the width and the height.\n * - If integer: the same symmetric cropping\n * is applied to width and height.\n * - If list of 2 integers:\n * interpreted as two different\n * symmetric cropping values for height and width:\n * `[symmetric_height_crop, symmetric_width_crop]`.\n * - If a list of 2 list of 2 integers:\n * interpreted as\n * `[[top_crop, bottom_crop], [left_crop, right_crop]]`\n */\n cropping: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Cropping layer for 2D input (e.g., image).\n *\n * This layer can crop an input\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, croppedRows, croppedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, croppedRows, croppedCols]`.\n *\n * Examples\n * ```js\n *\n * const model = tf.sequential();\n * model.add(tf.layers.cropping2D({cropping:[[2, 2], [2, 2]],\n * inputShape: [128, 128, 3]}));\n * //now output shape is [batch, 124, 124, 3]\n * ```\n */\nexport class Cropping2D extends Layer {\n static className = 'Cropping2D';\n protected readonly cropping: [[number, number], [number, number]];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Cropping2DLayerConfig) {\n super(config);\n if (typeof config.cropping === 'number')\n this.cropping = [\n [config.cropping, config.cropping], [config.cropping, config.cropping]\n ];\n else if (typeof config.cropping[0] === 'number')\n this.cropping = [\n [config.cropping[0] as number, config.cropping[0] as number],\n [config.cropping[1] as number, config.cropping[1] as number]\n ];\n else\n this.cropping = config.cropping as [[number, number], [number, number]];\n this.dataFormat =\n config.dataFormat === undefined ? 'channelsLast' : config.dataFormat;\n this.inputSpec = [{ndim: 4}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst')\n return [\n inputShape[0], inputShape[1],\n inputShape[2] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1]\n ];\n else\n return [\n inputShape[0],\n inputShape[1] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1], inputShape[3]\n ];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n if (this.dataFormat === 'channelsLast') {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[1] - this.cropping[0][0] - this.cropping[0][1], 2);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[2] - this.cropping[1][1] - this.cropping[1][0], 3);\n } else {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[2] - this.cropping[0][0] - this.cropping[0][1], 3);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[3] - this.cropping[1][1] - this.cropping[1][0], 4);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {cropping: this.cropping, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Cropping2D);\n\nexport interface UpSampling2DLayerConfig extends LayerConfig {\n /**\n * The upsampling factors for rows and columns.\n *\n * Defaults to `[2, 2]`.\n */\n size?: number[];\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `\"channelsLast\"` corresponds to inputs with shape\n * `[batch, ..., channels]`\n *\n * `\"channelsFirst\"` corresponds to inputs with shape `[batch, channels,\n * ...]`.\n *\n * Defaults to `\"channelsLast\"`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Upsampling layer for 2D inputs.\n *\n * Repeats the rows and columns of the data\n * by size[0] and size[1] respectively.\n *\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, rows, cols]`\n *\n * Output shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, upsampledRows, upsampledCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, upsampledRows, upsampledCols]`\n *\n */\nexport class UpSampling2D extends Layer {\n static className = 'UpSampling2D';\n protected readonly DEFAULT_SIZE = [2, 2];\n protected readonly size: number[];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: UpSampling2DLayerConfig) {\n super(config);\n this.inputSpec = [{ndim: 4}];\n this.size = config.size == null ? this.DEFAULT_SIZE : config.size;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst') {\n const height =\n inputShape[2] == null ? null : this.size[0] * inputShape[2];\n const width = inputShape[3] == null ? null : this.size[1] * inputShape[3];\n return [inputShape[0], inputShape[1], height, width];\n } else {\n const height =\n inputShape[1] == null ? null : this.size[0] * inputShape[1];\n const width = inputShape[2] == null ? null : this.size[1] * inputShape[2];\n return [inputShape[0], height, width, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs) as Tensor4D;\n const inputShape = input.shape;\n\n if (this.dataFormat === 'channelsFirst') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n const height = this.size[0] * inputShape[2];\n const width = this.size[1] * inputShape[3];\n const resized = input.resizeNearestNeighbor([height, width]);\n return tfc.transpose(resized, [0, 3, 1, 2]);\n } else {\n const height = this.size[0] * inputShape[1];\n const width = this.size[1] * inputShape[2];\n return input.resizeNearestNeighbor([height, width]);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {size: this.size, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(UpSampling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Depthwise Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {BaseConv, BaseConvLayerConfig, ConvLayerConfig, preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D convolution with separable filters.\n * @param x Input tensor.\n * @param depthwiseKernel Convolution kernel for depthwise convolution.\n * @param strides Strides (Array of two integers).\n * @param padding Padding model.\n * @param dataFormat Data format.\n * @param dilationRate Array of two integers, dilation rates for the separable\n * convolution.\n * @returns Output tensor.\n * @throws ValueError If depthwiseKernel is not a 4D array.\n */\nexport function depthwiseConv2d(\n x: Tensor, depthwiseKernel: Tensor, strides: [number, number] = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n let y = preprocessConv2DInput(x, dataFormat);\n if (x.rank !== 4) {\n throw new ValueError(\n `Input for depthwiseConv2d is required to be 4-D, but is instead ` +\n `${x.rank}-D`);\n }\n if (depthwiseKernel.rank !== 4) {\n throw new ValueError(\n `depthwiseKernel is required to be 4-D, but is instead ` +\n `${depthwiseKernel.rank}-D`);\n }\n y = tfc.depthwiseConv2d(\n y as Tensor4D, depthwiseKernel as Tensor4D, strides,\n padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate);\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\nexport interface DepthwiseConv2DLayerConfig extends BaseConvLayerConfig {\n /**\n * An integer or Array of 2 integers, specifying the width and height of the\n * 2D convolution window. Can be a single integer to specify the same value\n * for all spatial dimensions.\n */\n kernelSize: number|[number, number];\n\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal to\n * `filtersIn * depthMultiplier`.\n * Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n * Default: GlorotNormal.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regulzarizer function for the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Depthwise Separable convolutions consists in performing just the first step\n * in a depthwise spatial convolution (which acts on each input channel\n * separately). The `depthMultplier` argument controls how many output channels\n * are generated per input channel in the depthwise step.\n */\nexport class DepthwiseConv2D extends BaseConv {\n static className = 'DepthwiseConv2D';\n private readonly depthMultiplier: number;\n private readonly depthwiseInitializer: Initializer;\n private readonly depthwiseConstraint: Constraint;\n private readonly depthwiseRegularizer: Regularizer;\n\n private depthwiseKernel: LayerVariable = null;\n\n constructor(config: DepthwiseConv2DLayerConfig) {\n super(2, config as ConvLayerConfig);\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 4) {\n throw new ValueError(\n `Inputs to DepthwiseConv2D should have rank 4. ` +\n `Received input shape: ${JSON.stringify(inputShape)}.`);\n }\n const channelAxis = this.dataFormat === 'channelsFirst' ? 1 : 3;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n 'The channel dimension of the inputs to DepthwiseConv2D should ' +\n `be defined, but is not (${inputShape[channelAxis]}).`);\n }\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape: Shape = [\n this.kernelSize[0], this.kernelSize[1], inputDim, this.depthMultiplier\n ];\n\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, null,\n this.depthwiseInitializer, this.depthwiseRegularizer, true,\n this.depthwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [inputDim * this.depthMultiplier], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs = depthwiseConv2d(\n inputs, this.depthwiseKernel.read(), this.strides as [number, number],\n this.padding, this.dataFormat, null);\n // TODO(cais): Add support for dilation.\n if (this.useBias) {\n outputs = K.biasAdd(outputs, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n const cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n const outFilters = this.dataFormat === 'channelsFirst' ?\n inputShape[1] * this.depthMultiplier :\n inputShape[3] * this.depthMultiplier;\n const outRows = convOutputLength(\n rows, this.kernelSize[0], this.padding, this.strides[0]);\n const outCols = convOutputLength(\n cols, this.kernelSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], outFilters, outRows, outCols];\n } else {\n // In this case, assume 'channelsLast'.\n return [inputShape[0], outRows, outCols, outFilters];\n }\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n config['depthMultiplier'] = this.depthMultiplier;\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseRegularizer);\n return config;\n }\n}\nserialization.SerializationMap.register(DepthwiseConv2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Basic Layers.\n */\n\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport {Activation as ActivationFn, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface DropoutLayerConfig extends LayerConfig {\n /** Float between 0 and 1. Fraction of the input units to drop. */\n rate: number;\n\n /**\n * Integer array representing the shape of the binary dropout mask that will\n * be multiplied with the input.\n *\n * For instance, if your inputs have shape `(batchSize, timesteps, features)`\n * and you want the dropout mask to be the same for all timesteps, you can use\n * `noise_shape=(batch_size, 1, features)`.\n */\n noiseShape?: number[];\n\n /** An integer to use as random seed. */\n seed?: number;\n}\n\n/**\n * Applies\n * [dropout](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf) to\n * the input.\n *\n * Dropout consists in randomly setting a fraction `rate` of input units to 0 at\n * each update during training time, which helps prevent overfitting.\n */\nexport class Dropout extends Layer {\n static className = 'Dropout';\n private readonly rate: number;\n private readonly rateScalar: Scalar;\n private readonly noiseShape: number[];\n private readonly seed: number;\n\n constructor(config: DropoutLayerConfig) {\n super(config);\n this.rate = Math.max(Math.min(config.rate, 1), 0);\n this.rateScalar = getScalar(this.rate);\n // So that the scalar doesn't get tidied up between executions.\n this.noiseShape = config.noiseShape;\n this.seed = config.seed;\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Non-default seed is not implemented in Dropout layer yet: ' +\n this.seed);\n }\n this.supportsMasking = true;\n }\n\n private getNoiseShape(input: Tensor): Shape {\n if (this.noiseShape == null) {\n return this.noiseShape;\n }\n const inputShape = input.shape;\n const noiseShape: Shape = [];\n for (let i = 0; i < this.noiseShape.length; ++i) {\n noiseShape.push(\n this.noiseShape[i] == null ? inputShape[i] : this.noiseShape[i]);\n }\n return noiseShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n if (this.noiseShape != null &&\n !util.arraysEqual(input.shape, this.noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented in Dropout ' +\n 'layer yet: ' + JSON.stringify(this.noiseShape));\n }\n if (0 < this.rate && this.rate < 1) {\n const training =\n kwargs['training'] == null ? false : kwargs['training'];\n const noiseShape = this.getNoiseShape(input);\n const output =\n K.inTrainPhase(\n () => K.dropout(input, this.rateScalar, noiseShape, this.seed),\n () => input, training) as Tensor;\n return output;\n }\n return inputs;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n rate: this.rate,\n noiseShape: this.noiseShape,\n seed: this.seed,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dropout);\n\nexport interface DenseLayerConfig extends LayerConfig {\n /** Positive integer, dimensionality of the output space. */\n units: number;\n /**\n * Activation function to use.\n *\n * If unspecified, no activation is applied.\n */\n activation?: ActivationIdentifier;\n /** Whether to apply a bias. */\n useBias?: boolean;\n /**\n * Initializer for the dense kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n /**\n * If specified, defines inputShape as `[inputDim]`.\n */\n inputDim?: number;\n\n /**\n * Constraint for the kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the dense kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Creates a dense (fully connected) layer.\n *\n * This layer implements the operation:\n * `output = activation(dot(input, kernel) + bias)`\n *\n * `activation` is the element-wise activation function\n * passed as the `activation` argument.\n *\n * `kernel` is a weights matrix created by the layer.\n *\n * `bias` is a bias vector created by the layer (only applicable if `useBias`\n * is `true`).\n *\n * **Input shape:**\n *\n * nD `Tensor` with shape: `(batchSize, ..., inputDim)`.\n *\n * The most common situation would be\n * a 2D input with shape `(batchSize, inputDim)`.\n *\n * **Output shape:**\n *\n * nD tensor with shape: `(batchSize, ..., units)`.\n *\n * For instance, for a 2D input with shape `(batchSize, inputDim)`,\n * the output would have shape `(batchSize, units)`.\n *\n * Note: if the input to the layer has a rank greater than 2, then it is\n * flattened prior to the initial dot product with the kernel.\n */\nexport class Dense extends Layer {\n static className = 'Dense';\n private units: number;\n // Default activation: Linear (none).\n private activation: ActivationFn = null;\n private useBias = true;\n private kernelInitializer: Initializer;\n private biasInitializer: Initializer;\n private kernel: LayerVariable = null;\n private bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n private readonly kernelConstraint?: Constraint;\n private readonly biasConstraint?: Constraint;\n private readonly kernelRegularizer?: Regularizer;\n private readonly biasRegularizer?: Regularizer;\n\n constructor(config: DenseLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null &&\n config.inputDim != null) {\n // This logic is copied from Layer's constructor, since we can't\n // do exactly what the Python constructor does for Dense().\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n this.batchInputShape = [batchSize, config.inputDim];\n }\n\n this.units = config.units;\n this.activation = getActivation(config.activation);\n if (config.useBias != null) {\n this.useBias = config.useBias;\n }\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n\n this.inputSpec = [{minNDim: 2}];\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputLastDim = inputShape[inputShape.length - 1];\n if (this.kernel == null) {\n this.kernel = this.addWeight(\n 'kernel', [inputLastDim, this.units], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n }\n\n this.inputSpec = [{minNDim: 2, axes: {[-1]: inputLastDim}}];\n this.built = true;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n outputShape[outputShape.length - 1] = this.units;\n return outputShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Dense layer accepts only a single input.\n const input = getExactlyOneTensor(inputs);\n let output = K.dot(input, this.kernel.read());\n if (this.bias != null) {\n output = K.biasAdd(output, this.bias.read());\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dense);\n\n/**\n * Flattens the input. Does not affect the batch size.\n *\n * A `Flatten` layer flattens each batch in its inputs to 1D (making the output\n * 2D).\n *\n * For example:\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const flattenLayer = tf.layers.flatten();\n * // Inspect the inferred output shape of the flatten layer, which\n * // equals `[null, 12]`. The 2nd dimension is 4 * 3, i.e., the result of the\n * // flattening. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(flattenLayer.apply(input).shape));\n * ```\n */\nexport class Flatten extends Layer {\n static className = 'Flatten';\n constructor(config?: LayerConfig) {\n super(config || {});\n this.inputSpec = [{minNDim: 3}];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n for (const dim of inputShape.slice(1)) {\n if (dim == null) {\n throw new ValueError(\n `The shape of the input to \"Flatten\" is not fully defined ` +\n `(got ${inputShape.slice(1)}). Make sure to pass a complete ` +\n `\"input_shape\" or \"batch_input_shape\" argument to the first ` +\n `layer in your model.`);\n }\n }\n return [inputShape[0], math_utils.arrayProd(inputShape, 1)];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return K.batchFlatten(getExactlyOneTensor(inputs));\n });\n }\n}\nserialization.SerializationMap.register(Flatten);\n\nexport interface ActivationLayerConfig extends LayerConfig {\n /**\n * Name of the activation function to use.\n */\n activation: ActivationIdentifier;\n}\n\n/**\n * Applies an activation function to an output.\n *\n * This layer applies element-wise activation function. Other layers, notably\n * `dense` can also apply activation functions. Use this isolated activation\n * function to extract the values before and after the\n * activation. For instance:\n *\n * ```js\n * const input = tf.input({shape: [5]});\n * const denseLayer = tf.layers.dense({units: 1});\n * const activationLayer = tf.layers.activation({activation: 'relu6'});\n *\n * // Obtain the output symbolic tensors by applying the layers in order.\n * const denseOutput = denseLayer.apply(input);\n * const activationOutput = activationLayer.apply(denseOutput);\n *\n * // Create the model based on the inputs.\n * const model = tf.model({\n * inputs: input,\n * outputs: [denseOutput, activationOutput]\n * });\n *\n * // Collect both outputs and print separately.\n * const [denseOut, activationOut] = model.predict(tf.randomNormal([6, 5]));\n * denseOut.print();\n * activationOut.print();\n * ```\n *\n */\nexport class Activation extends Layer {\n static className = 'Activation';\n activation: ActivationFn;\n\n constructor(config: ActivationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.activation = getActivation(config.activation);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n return this.activation.apply(input);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {activation: serializeActivation(this.activation)};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Activation);\n\nexport interface ReshapeLayerConfig extends LayerConfig {\n /** The target shape. Does not include the batch axis. */\n targetShape: Shape;\n}\n\nexport interface RepeatVectorLayerConfig extends LayerConfig {\n /**\n * The integer number of times to repeat the input.\n */\n n: number;\n}\n\n/**\n * Repeats the input n times in a new dimension.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.repeatVector({n: 4, inputShape: [2]}));\n * const x = tf.tensor2d([[10, 20]]);\n * // Use the model to do inference on a data point the model hasn't see\n * model.predict(x).print();\n * // output shape is now [batch, 2, 4]\n * ```\n */\nexport class RepeatVector extends Layer {\n static className = 'RepeatVector';\n readonly n: number;\n\n constructor(config: RepeatVectorLayerConfig) {\n super(config);\n this.n = config.n;\n this.inputSpec = [{ndim: 2}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], this.n, inputShape[1]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n return K.repeat(inputs, this.n);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n n: this.n,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RepeatVector);\n\n/**\n * Reshapes an input to a certain shape.\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const reshapeLayer = tf.layers.reshape({targetShape: [2, 6]});\n * // Inspect the inferred output shape of the Reshape layer, which\n * // equals `[null, 2, 6]`. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(reshapeLayer.apply(input).shape));\n * ```\n *\n * Input shape:\n * Arbitrary: although all dimensions in the input shape must be fixed.\n * Use the ReshapeLayerConfig field `input_shape` when using this layer\n * as the first layer in a model.\n *\n * Output shape:\n * [batchSize, targetShape[0], targetShape[1], ...,\n * targetShape[targetShape.length - 1]].\n */\nexport class Reshape extends Layer {\n static className = 'Reshape';\n private targetShape: Shape;\n\n constructor(config: ReshapeLayerConfig) {\n super(config);\n this.targetShape = config.targetShape;\n\n // Make sure that all unknown dimensions are represented as `null`.\n for (let i = 0; i < this.targetShape.length; ++i) {\n if (this.isUnknown(this.targetShape[i])) {\n this.targetShape[i] = null;\n }\n }\n }\n\n private isUnknown(dim: number): boolean {\n return dim < 0 || dim == null;\n }\n\n /**\n * Finds and replaces a missing dimension in output shape.\n *\n * This is a near direct port of the internal Numpy function\n * `_fix_unknown_dimension` in `numpy/core/src/multiarray/shape.c`.\n *\n * @param inputShape: Original shape of array begin reshape.\n * @param outputShape: Target shape of the array, with at most a single\n * `null` or negative number, which indicates an underdetermined dimension\n * that should be derived from `inputShape` and the known dimensions of\n * `outputShape`.\n * @returns: The output shape with `null` replaced with its computed value.\n * @throws: ValueError: If `inputShape` and `outputShape` do not match.\n */\n private fixUnknownDimension(inputShape: Shape, outputShape: Shape): Shape {\n const errorMsg = 'Total size of new array must be unchanged.';\n const finalShape = outputShape.slice();\n let known = 1;\n let unknown = null;\n for (let i = 0; i < finalShape.length; ++i) {\n const dim = finalShape[i];\n if (this.isUnknown(dim)) {\n if (unknown === null) {\n unknown = i;\n } else {\n throw new ValueError('Can only specifiy one unknown dimension.');\n }\n } else {\n known *= dim;\n }\n }\n\n const originalSize = math_utils.arrayProd(inputShape);\n if (unknown !== null) {\n if (known === 0 || originalSize % known !== 0) {\n throw new ValueError(errorMsg);\n }\n finalShape[unknown] = originalSize / known;\n } else if (originalSize !== known) {\n throw new ValueError(errorMsg);\n }\n\n return finalShape;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n let anyUnknownDims = false;\n for (let i = 0; i < inputShape.length; ++i) {\n if (this.isUnknown(inputShape[i])) {\n anyUnknownDims = true;\n break;\n }\n }\n\n if (anyUnknownDims) {\n return inputShape.slice(0, 1).concat(this.targetShape);\n } else {\n return inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const outputShape = inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n return input.reshape(outputShape);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n targetShape: this.targetShape,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Reshape);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Embedding Layer.\n *\n * Original source: keras/constraints.py\n */\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface EmbeddingLayerConfig extends LayerConfig {\n /**\n * Integer > 0. Size of the vocabulary, i.e. maximum integer index + 1.\n */\n inputDim: number;\n /**\n * Integer >= 0. Dimension of the dense embedding.\n */\n outputDim: number;\n /**\n * Initializer for the `embeddings` matrix.\n */\n embeddingsInitializer?: InitializerIdentifier|Initializer;\n /**\n * Regularizer function applied to the `embeddings` matrix.\n */\n embeddingsRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Constraint function applied to the `embeddings` matrix.\n */\n embeddingsConstraint?: ConstraintIdentifier|Constraint;\n /**\n * Whether the input value 0 is a special \"padding\" value that should be\n * masked out. This is useful when using recurrent layers which may take\n * variable length input.\n *\n * If this is `True` then all subsequent layers in the model need to support\n * masking or an exception will be raised. If maskZero is set to `True`, as a\n * consequence, index 0 cannot be used in the vocabulary (inputDim should\n * equal size of vocabulary + 1).\n */\n maskZero?: boolean;\n /**\n * Length of input sequences, when it is constant.\n *\n * This argument is required if you are going to connect `flatten` then\n * `dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed).\n */\n inputLength?: number|number[];\n}\n\n/**\n * Maps positive integers (indices) into dense vectors of fixed size.\n * eg. [[4], [20]] -> [[0.25, 0.1], [0.6, -0.2]]\n *\n * **Input shape:** 2D tensor with shape: `[batchSize, sequenceLength]`.\n *\n * **Output shape:** 3D tensor with shape: `[batchSize, sequenceLength,\n * outputDim]`.\n */\nexport class Embedding extends Layer {\n static className = 'Embedding';\n private inputDim: number;\n private outputDim: number;\n private embeddingsInitializer: Initializer;\n private maskZero: boolean;\n private inputLength: number|number[];\n\n private embeddings: LayerVariable = null;\n\n readonly DEFAULT_EMBEDDINGS_INITIALIZER: InitializerIdentifier =\n 'randomUniform';\n private readonly embeddingsRegularizer?: Regularizer;\n private readonly embeddingsConstraint?: Constraint;\n\n constructor(config: EmbeddingLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null) {\n // Porting Note: This logic is copied from Layer's constructor, since we\n // can't do exactly what the Python constructor does for Embedding().\n // Specifically, the super constructor can not be called after the\n // mutation of the `config` argument.\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n if (config.inputLength == null) {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (None, )\n this.batchInputShape = [batchSize, null];\n } else {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (config.inputLength, )\n this.batchInputShape =\n [batchSize].concat(generic_utils.toList(config.inputLength));\n }\n }\n this.inputDim = config.inputDim;\n this.outputDim = config.outputDim;\n this.embeddingsInitializer = getInitializer(\n config.embeddingsInitializer || this.DEFAULT_EMBEDDINGS_INITIALIZER);\n this.embeddingsRegularizer = getRegularizer(config.embeddingsRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.embeddingsConstraint = getConstraint(config.embeddingsConstraint);\n this.maskZero = config.maskZero;\n this.inputLength = config.inputLength;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n this.embeddings = this.addWeight(\n 'embeddings', [this.inputDim, this.outputDim], this.dtype,\n this.embeddingsInitializer, this.embeddingsRegularizer, true,\n this.embeddingsConstraint);\n this.built = true;\n }\n\n // Override warnOnIncompatibleInputShape because an embedding layer allows\n // the input to have varying ranks.\n protected warnOnIncompatibleInputShape(inputShape: Shape) {}\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for Embedding yet');\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n if (this.inputLength == null) {\n return [...inputShape, this.outputDim];\n }\n // inputLength can be an array if input is 3D or higher.\n const inLens: number[] = generic_utils.toList(this.inputLength);\n if (inLens.length !== inputShape.length - 1) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else {\n let i = 0;\n for (let k = 0; k < inLens.length; ++k) {\n const s1 = inLens[k];\n const s2 = inputShape[k + 1];\n if ((s1 != null) && (s2 != null) && (s1 !== s2)) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else if (s1 == null) {\n inLens[i] = s2;\n }\n i++;\n }\n }\n return [inputShape[0], ...inLens, this.outputDim];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Embedding layer accepts only a single input.\n let input = getExactlyOneTensor(inputs);\n if (input.dtype !== 'int32') {\n input = K.cast(input, 'int32');\n }\n const output = K.gather(this.embeddings.read(), input.as1D());\n return output.reshape(\n getExactlyOneShape(this.computeOutputShape(input.shape)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n inputDim: this.inputDim,\n outputDim: this.outputDim,\n embeddingsInitializer: serializeInitializer(this.embeddingsInitializer),\n embeddingsRegularizer: serializeRegularizer(this.embeddingsRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n embeddingsConstraint: serializeConstraint(this.embeddingsConstraint),\n maskZero: this.maskZero,\n inputLength: this.inputLength\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\nserialization.SerializationMap.register(Embedding);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Merge Layers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport * as K from '../backend/tfjs_backend';\nimport {Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as mathUtils from '../utils/math_utils';\nimport {getExactlyOneShape} from '../utils/types_utils';\n\n/**\n * Generic Merge layer for element-wise merge functions.\n *\n * Used to implement `Sum`, `Average`, `Concatenate`, etc.\n */\nexport abstract class Merge extends Layer {\n protected reshapeRequired: boolean;\n\n constructor(config?: LayerConfig) {\n super(config || {});\n this.supportsMasking = true;\n }\n\n /**\n * Logic for merging multiple tensors, to be overridden by subclasses.\n * @param inputs\n */\n protected mergeFunction(inputs: Tensor[]): Tensor {\n throw new NotImplementedError();\n }\n\n /**\n * Computes the shape of the result of an elementwise operation.\n *\n * @param shape1: Shape of the first tensor.\n * @param shape2: Shape of the second tensor.\n * @returns Expected output shape when an elementwise operation is carried\n * out on 2 tensors with shapes `shape1` and `shape2`.\n * @throws ValueError: If `shape1` and `shape2` are not compatible for\n * element-wise operations.\n */\n private computeElementwiseOpOutputShape(shape1: Shape, shape2: Shape): Shape {\n if (shape1 == null || shape2 == null) {\n return null;\n } else if (shape1.length < shape2.length) {\n return this.computeElementwiseOpOutputShape(shape2, shape1);\n } else if (shape2.length === 0) {\n return shape1;\n }\n const outputShape: Shape = shape1.slice(0, shape1.length - shape2.length);\n for (let k = 0; k < shape2.length; ++k) {\n const i = shape1[shape1.length - shape2.length + k];\n const j = shape2[k];\n if (i == null || j == null || i < 0 || j < 0) {\n outputShape.push(null);\n } else if (i === 1) {\n outputShape.push(j);\n } else if (j === 1) {\n outputShape.push(i);\n } else {\n if (i !== j) {\n throw new ValueError(\n 'Operands could not be broadcast together with shapes ' +\n JSON.stringify(shape1) + ' ' + JSON.stringify(shape2));\n }\n outputShape.push(i);\n }\n }\n return outputShape;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.\n if (Array.isArray(inputShape) && !Array.isArray(inputShape[0])) {\n // Make sure that inputShape is an Array of shape.\n inputShape = [getExactlyOneShape(inputShape)];\n }\n inputShape = inputShape as Shape[];\n if (inputShape.length < 2) {\n throw new ValueError(\n 'A merge layer should be called on an Array of at least 2 inputs.' +\n ` Got ${inputShape.length} input(s).`);\n }\n\n // Make sure that there is at most one unique batch size among the input\n // shapes.\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length > 1) {\n throw new ValueError(\n `Can not merge tensors with different batch sizes. ` +\n `Got tensors with shapes: ${JSON.stringify(inputShape)}.`);\n }\n\n let outputShape: Shape =\n inputShape[0] == null ? null : inputShape[0].slice(1);\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n // If the inputs have different ranks, we have to reshape them to make them\n // broadcastable.\n const allRanks = inputShape.map(shape => shape.length);\n if (inputShape.indexOf(null) === -1 &&\n generic_utils.unique(allRanks).length === 1) {\n this.reshapeRequired = false;\n } else {\n this.reshapeRequired = true;\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (this.reshapeRequired) {\n const reshapedInputs: Tensor[] = [];\n const inputDims = inputs.map(input => input.rank);\n if (inputDims.indexOf(null) === -1) {\n // If ranks of all inputs are available, we simply expand each of them\n // at axis=1 until all of them have the same rank.\n const maxNDim = mathUtils.max(inputDims);\n for (let x of inputs) {\n const xNDim = x.rank;\n for (let k = 0; k < maxNDim - xNDim; ++k) {\n x = K.expandDims(x, 1);\n }\n reshapedInputs.push(x);\n }\n return this.mergeFunction(reshapedInputs);\n } else {\n // Transpose all inputs so that batch size is the last dimension.\n // [batchSize, dim1, dim2, ...] -> [dim1, dim2, ..., batchSize]\n let transposed = false;\n for (const x of inputs) {\n const xNDim = x.rank;\n if (xNDim == null) {\n const xShape = x.shape;\n const batchSize = xShape[0];\n const newShape = xShape.slice(1).concat([batchSize]);\n let xTransposed = x.reshape(\n [batchSize].concat(mathUtils.arrayProd(xShape.slice(1))));\n xTransposed = tfc.transpose(xTransposed, [1, 0]);\n xTransposed = xTransposed.reshape(newShape);\n reshapedInputs.push(xTransposed);\n transposed = true;\n } else if (xNDim > 1) {\n const dims = mathUtils.range(1, xNDim).concat([0]);\n reshapedInputs.push(tfc.transpose(x, dims));\n transposed = true;\n } else {\n // We don't transpose inputs if they are 1D vectors or scalars.\n reshapedInputs.push(x);\n }\n }\n let y = this.mergeFunction(reshapedInputs);\n const yNDim = y.rank;\n if (transposed) {\n // If inputs have been transposed, we have to transpose the output\n // too.\n if (yNDim == null) {\n const yShape = y.shape;\n const yNDim = yShape.length;\n const batchSize = yShape[yNDim - 1];\n const newShape =\n [batchSize].concat(yShape.slice(0, yShape.length - 1));\n y = tfc.transpose(y.reshape([-1, batchSize]), [1, 0])\n .reshape(newShape);\n } else if (yNDim > 1) {\n const dims = [yNDim - 1].concat(mathUtils.range(0, yNDim - 1));\n y = tfc.transpose(y, dims);\n }\n }\n return y;\n }\n } else {\n return this.mergeFunction(inputs);\n }\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape[];\n let outputShape: Shape;\n if (inputShape[0] == null) {\n outputShape = null;\n } else {\n outputShape = inputShape[0].slice(1);\n }\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length === 1) {\n outputShape = batchSizes.concat(outputShape);\n } else {\n outputShape = [null].concat(outputShape);\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n}\n\n/**\n * Layer that performs element-wise addition on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). The inputs are specified as an\n * `Array` when the `apply` method of the `Add` layer instance is called. For\n * example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const addLayer = tf.layers.add();\n * const sum = addLayer.apply([input1, input2]);\n * console.log(JSON.stringify(sum.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Add extends Merge {\n static className = 'Add';\n constructor(config?: LayerConfig) {\n super(config as LayerConfig);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Add);\n\n/**\n * Calculate the element-wise sum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Add` layer, by using no input argument\n * or a single configuration argument. The resultant `Add` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const addLayer = tf.layers.add();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = addLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.add([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.add([input1, input2]).print();\n * // Gives [[11, 22], [33, 44]].\n *\n */\nexport function add(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Add({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Add(config);\n }\n}\n\n/**\n * Layer that multiplies (element-wise) an `Array` of inputs.\n *\n * It takes as input an Array of tensors, all of the same\n * shape, and returns a single tensor (also of the same shape).\n * For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const input3 = tf.input({shape: [2, 2]});\n * const multiplyLayer = tf.layers.multiply();\n * const product = multiplyLayer.apply([input1, input2, input3]);\n * console.log(product.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n */\nexport class Multiply extends Merge {\n static className = 'Multiply';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.ones(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.mul(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Multiply);\n\n/**\n * Calculate the element-wise product of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Multiply` layer, by using no input argument\n * or a single configuration argument. The resultant `Multiply` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const multiplyLayer = tf.layers.multiply();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = multiplyLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.multiply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.multiply([input1, input2]).print();\n * // Gives [[10, 40], [90, 160]].\n *\n */\nexport function multiply(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Multiply({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Multiply(config);\n }\n}\n\n/**\n * Layer that performs element-wise averaging on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const averageLayer = tf.layers.average();\n * const average = averageLayer.apply([input1, input2]);\n * console.log(JSON.stringify(average.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Average extends Merge {\n static className = 'Average';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return tfc.mul(getScalar(1 / inputs.length), output);\n });\n }\n}\nserialization.SerializationMap.register(Average);\n\n/**\n * Calculate the element-wise arithmetic mean of inputs, which all have the same\n * shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Average` layer, by using no input argument\n * or a single configuration argument. The resultant `Average` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const averageLayer = tf.layers.average();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = averageLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.average([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.average([input1, input2]).print();\n * // Gives [[5.5, 11], [16.5, 22]].\n *\n */\nexport function average(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Average({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Average(config);\n }\n}\n\n/**\n * Layer that computes the element-wise maximum an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const maxLayer = tf.layers.maximum();\n * const max = maxLayer.apply([input1, input2]);\n * console.log(JSON.stringify(max.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Maximum extends Merge {\n static className = 'Maximum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.maximum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Maximum);\n\n/**\n * Calculate the element-wise maximum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Maximum` layer, by using no input argument\n * or a single configuration argument. The resultant `Maximum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const maximumLayer = tf.layers.maximum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = maximumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.maximum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.maximum([input1, input2]).print();\n * // Gives [[10, 20], [30, 40]].\n *\n */\nexport function maximum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Maximum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Maximum(config);\n }\n}\n\n/**\n * Layer that computes the element-wise minimum of an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const minLayer = tf.layers.minimum();\n * const min = minLayer.apply([input1, input2]);\n * console.log(JSON.stringify(min.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Minimum extends Merge {\n static className = 'Minimum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.minimum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Minimum);\n\n/**\n * Calculate the element-wise minimum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Minimum` layer, by using no input argument\n * or a single configuration argument. The resultant `Minimum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const minimumLayer = tf.layers.minimum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = minimumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.minimum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.minimum([input1, input2]).print();\n * // Gives [[1, 2], [3, 4]].\n *\n */\nexport function minimum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Minimum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Minimum(config);\n }\n}\n\nexport interface ConcatenateLayerConfig extends LayerConfig {\n /**\n * Axis along which to concatenate.\n */\n axis?: number;\n}\n\n/**\n * Layer that concatenates an `Array` of inputs.\n *\n * It takes a list of tensors, all of the same shape except for the\n * concatenation axis, and returns a single tensor, the concatenation\n * of all inputs. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 3]});\n * const concatLayer = tf.layers.concatenate();\n * const output = concatLayer.apply([input1, input2]);\n * console.log(JSON.stringify(output.shape));\n * // You get [null, 2, 5], with the first dimension as the undetermined batch\n * // dimension. The last dimension (5) is the result of concatenating the\n * // last dimensions of the inputs (2 and 3).\n * ```\n */\nexport class Concatenate extends Merge {\n static className = 'Concatenate';\n readonly DEFAULT_AXIS = -1;\n private readonly axis: number;\n\n constructor(config?: ConcatenateLayerConfig) {\n super(config);\n if (config == null) {\n config = {};\n }\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n this.supportsMasking = true;\n this.reshapeRequired = false;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.]\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0])) ||\n inputShape.length === 1) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of at least 2 ' +\n 'inputs');\n }\n inputShape = inputShape as Shape[];\n\n let allNoneShape = true;\n for (const shape of inputShape) {\n if (shape != null) {\n allNoneShape = false;\n break;\n }\n }\n if (allNoneShape) {\n return;\n }\n\n const shapeSet: Shape[] = [];\n for (let i = 0; i < inputShape.length; ++i) {\n const shapeWithoutConcatAxis = inputShape[i].slice();\n shapeWithoutConcatAxis.splice(this.axis, 1);\n let exists = false;\n for (const shape of shapeSet) {\n if (util.arraysEqual(shape, shapeWithoutConcatAxis)) {\n exists = true;\n break;\n }\n }\n if (!exists) {\n shapeSet.push(shapeWithoutConcatAxis);\n }\n }\n if (shapeSet.length > 1) {\n throw new ValueError(\n 'A `Concatenate` layer requires inputs with matching shapes ' +\n 'except for the concat axis. Got input shapes: ' +\n JSON.stringify(inputShape));\n }\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n return K.concatenate(inputs, this.axis);\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0]))) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of inputs.');\n }\n const inputShapes = inputShape as Shape[];\n const outputShape = inputShapes[0].slice();\n const axis = this.axis < 0 ? outputShape.length + this.axis : this.axis;\n // Porting Note: the line above is because TypeScript doesn't support\n // negative indices.\n for (const shape of inputShapes.slice(1)) {\n if (outputShape[axis] == null || shape[axis] == null) {\n outputShape[axis] = null;\n break;\n }\n outputShape[axis] += shape[axis];\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'axis': this.axis,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Concatenate);\n\n/**\n * Concatenate an `Array` of inputs.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Concatenate` layer, by using no input argument\n * or a single configuration argument. The resultant `Concatenate` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const concatLayer = tf.layers.concatenate();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = concatLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 7], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = tf.layers.concatenate([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([[1, 2], [3, 4]], [2, 2]);\n * const input2 = tf.tensor2d([[10, 20], [30, 40]], [2, 2]);\n * tf.layers.concatenate([input1, input2]).print();\n * // Gives [[1, 2, 10, 20], [3, 4, 30, 40]].\n *\n */\nexport function concatenate(config?: SymbolicTensor[]|Tensor[]|\n ConcatenateLayerConfig): Layer|SymbolicTensor|\n Tensor {\n if (Array.isArray(config)) {\n const layer = new Concatenate({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Concatenate(config);\n }\n}\n\n// TODO(cais): Add class Dot.\n\n// TODO(cais): Add functional interfaces for the merge layers.\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Normalization layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\n/**\n * Applies batch normalization on x given mean, var, beta and gamma.\n *\n * I.e. returns:\n * `output = (x - mean) / (sqrt(var) + epsilon) * gamma + beta`\n *\n * @param x Input tensor.\n * @param mean Mean of batch.\n * @param variance Variance of batch.\n * @param beta Tensor with which to center the input.\n * @param gamma Tensor by which to scale the input.\n * @param epsilon Fuzz factor.\n * @returns The result of the batch normalization.\n */\nexport function batchNormalization(\n x: Tensor, mean: Tensor, variance: Tensor, beta?: Tensor, gamma?: Tensor,\n epsilon = 1e-3): Tensor {\n let out: Tensor;\n if (x.rank === 2) {\n out = tfc.batchNormalization2d(\n x as Tensor2D, mean as Tensor2D | Tensor1D,\n variance as Tensor2D | Tensor1D, epsilon, gamma as Tensor2D | Tensor1D,\n beta as Tensor2D | Tensor1D);\n } else if (x.rank === 3) {\n // TODO(cais): Check rank; give proper error message.\n out = tfc.batchNormalization3d(\n x as Tensor3D, mean as Tensor3D | Tensor1D,\n variance as Tensor3D | Tensor1D, epsilon, gamma as Tensor3D | Tensor1D,\n beta as Tensor3D | Tensor1D);\n } else if (x.rank === 4) {\n out = tfc.batchNormalization4d(\n x as Tensor4D, mean as Tensor4D | Tensor1D,\n variance as Tensor4D | Tensor1D, epsilon, gamma as Tensor4D | Tensor1D,\n beta as Tensor4D | Tensor1D);\n } else {\n throw new NotImplementedError(\n `batchNormalization is not implememnted for array of rank ${x.rank} ` +\n `yet`);\n }\n return out;\n}\n\n/**\n * Non-broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction regularNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const normed =\n batchNormalization(x, mean, variance, beta, gamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction broadcastNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const targetShape: number[] = [];\n for (const axis of math_utils.range(0, x.rank)) {\n if (reductionAxes.indexOf(axis) !== -1) {\n targetShape.push(1);\n } else {\n targetShape.push(x.shape[axis]);\n }\n }\n const broadcastMean = mean.reshape(targetShape);\n const broadcastVariance = variance.reshape(targetShape);\n const broadcastGamma =\n gamma == null ? null : gamma.reshape(targetShape);\n const broadcastBeta =\n beta == null ? null : beta.reshape(targetShape);\n const normed = batchNormalization(\n x, broadcastMean, broadcastVariance, broadcastBeta,\n broadcastGamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Batch normalization for use in training (not inference).\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nexport function normalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n if (util.arraysEqual(\n reductionAxes.slice().sort(), math_utils.range(0, x.rank - 1))) {\n return regularNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n } else {\n return broadcastNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n }\n}\n\nexport interface BatchNormalizationLayerConfig extends LayerConfig {\n /**\n * The integer axis that should be normalized (typically the features axis).\n * Defaults to -1.\n *\n * For instance, after a `Conv2D` layer with `data_format=\"channels_first\"`,\n * set `axis=1` in `batchNormalization`.\n */\n axis?: number;\n\n /**\n * Momentum of the moving average. Defaults to 0.99.\n */\n momentum?: number;\n\n /**\n * Small float added to the variance to avoid dividing by zero. Defaults to\n * 1e-3.\n */\n epsilon?: number;\n\n /**\n * If `true`, add offset of `beta` to normalized tensor.\n * If `false`, `beta` is ignored.\n * Defaults to `true`.\n */\n center?: boolean;\n\n /**\n * If `true`, multiply by `gamma`.\n * If `false`, `gamma` is not used.\n * When the next layer is linear (also e.g. `nn.relu`),\n * this can be disabled since the scaling will be done by the next layer.\n * Defaults to `true`.\n */\n scale?: boolean;\n\n /**\n * Initializer for the beta weight.\n * Defaults to 'zeros'.\n */\n betaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the gamma weight.\n * Defaults to `ones`.\n */\n gammaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving mean.\n * Defaults to `zeros`\n */\n movingMeanInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving variance.\n * Defaults to 'Ones'.\n */\n movingVarianceInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the beta weight.\n */\n betaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for gamma weight.\n */\n gammaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer for the beta weight.\n */\n betaRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer for the gamma weight.\n */\n gammaRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n\n/**\n * Batch normalization layer (Ioffe and Szegedy, 2014).\n *\n * Normalize the activations of the previous layer at each batch,\n * i.e. applies a transformation that maintains the mean activation\n * close to 0 and the activation standard deviation close to 1.\n *\n * Input shape:\n * Arbitrary. Use the keyword argument `inputShape` (Array of integers, does\n * not include the sample axis) when calling the constructor of this class,\n * if this layer is used as a first layer in a model.\n *\n * Output shape:\n * Same shape as input.\n *\n * References:\n * - [Batch Normalization: Accelerating Deep Network Training by Reducing\n * Internal Covariate Shift](https://arxiv.org/abs/1502.03167)\n */\nexport class BatchNormalization extends Layer {\n static className = 'BatchNormalization';\n private readonly axis: number;\n private readonly momentum: number;\n private readonly epsilon: number;\n private readonly center: boolean;\n private readonly scale: boolean;\n private readonly betaInitializer: Initializer;\n private readonly gammaInitializer: Initializer;\n private readonly movingMeanInitializer: Initializer;\n private readonly movingVarianceInitializer: Initializer;\n private readonly betaConstraint: Constraint;\n private readonly gammaConstraint: Constraint;\n private readonly betaRegularizer: Regularizer;\n private readonly gammaRegularizer: Regularizer;\n private gamma: LayerVariable;\n private beta: LayerVariable;\n private movingMean: LayerVariable;\n private movingVariance: LayerVariable;\n private stepCount: number;\n\n constructor(config: BatchNormalizationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.axis = config.axis == null ? -1 : config.axis;\n this.momentum = config.momentum == null ? 0.99 : config.momentum;\n this.epsilon = config.epsilon == null ? 1e-3 : config.epsilon;\n this.center = config.center == null ? true : config.center;\n this.scale = config.scale == null ? true : config.scale;\n this.betaInitializer = getInitializer(config.betaInitializer || 'zeros');\n this.gammaInitializer = getInitializer(config.gammaInitializer || 'ones');\n this.movingMeanInitializer =\n getInitializer(config.movingMeanInitializer || 'zeros');\n this.movingVarianceInitializer =\n getInitializer(config.movingVarianceInitializer || 'ones');\n this.betaConstraint = getConstraint(config.betaConstraint);\n this.gammaConstraint = getConstraint(config.gammaConstraint);\n this.betaRegularizer = getRegularizer(config.betaRegularizer);\n this.gammaRegularizer = getRegularizer(config.gammaRegularizer);\n this.stepCount = 0;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const axis = this.axis >= 0 ? this.axis : (this.axis + inputShape.length);\n const dim = inputShape[axis];\n if (dim == null) {\n throw new ValueError(\n `Axis ${axis} of input tensor should have a defined dimension but ` +\n `the layer received an input with shape ` +\n `${JSON.stringify(inputShape)}.`);\n }\n this.inputSpec =\n [new InputSpec({ndim: inputShape.length, axes: {[axis]: dim}})];\n const shape = [dim];\n if (this.scale) {\n this.gamma = this.addWeight(\n 'gamma', shape, null, this.gammaInitializer, this.gammaRegularizer,\n true, this.gammaConstraint);\n }\n if (this.center) {\n this.beta = this.addWeight(\n 'beta', shape, null, this.betaInitializer, this.betaRegularizer, true,\n this.betaConstraint);\n }\n this.movingMean = this.addWeight(\n 'moving_mean', shape, null, this.movingMeanInitializer, null, false);\n this.movingVariance = this.addWeight(\n 'moving_variance', shape, null, this.movingVarianceInitializer, null,\n false);\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const ndim = inputShape.length;\n const reductionAxes = math_utils.range(0, ndim);\n const axis = this.axis >= 0 ? this.axis : (this.axis + ndim);\n reductionAxes.splice(axis, 1);\n const broadcastShape = generic_utils.pyListRepeat(1, ndim);\n broadcastShape[axis] = inputShape[axis];\n\n const sortedReductionAxes = reductionAxes.slice();\n sortedReductionAxes.sort();\n const needsBroadcasting = !util.arraysEqual(\n sortedReductionAxes, math_utils.range(0, ndim).slice(0, ndim - 1));\n\n const normalizeInference: () => Tensor = () => {\n if (needsBroadcasting) {\n const broadcastMovingMean =\n this.movingMean.read().reshape(broadcastShape);\n const broadcastMovingVariance =\n this.movingVariance.read().reshape(broadcastShape);\n const broadcastBeta =\n this.center ? this.beta.read().reshape(broadcastShape) : null;\n const broadcastGamma =\n this.scale ? this.gamma.read().reshape(broadcastShape) : null;\n return batchNormalization(\n input, broadcastMovingMean, broadcastMovingVariance,\n broadcastBeta, broadcastGamma, this.epsilon);\n } else {\n return batchNormalization(\n input, this.movingMean.read(), this.movingVariance.read(),\n this.beta == null ? null : this.beta.read(),\n this.gamma == null ? null : this.gamma.read(), this.epsilon);\n }\n };\n\n if (!training) {\n return normalizeInference();\n }\n\n const [normedTraining, mean, variance] = normalizeBatchInTraining(\n input, this.gamma.read(), this.beta.read(), reductionAxes,\n this.epsilon);\n\n // Debias variance.\n const sampleSize =\n math_utils.arrayProd(reductionAxes.map(axis => input.shape[axis]));\n const varianceDebiased = variance.mul(\n getScalar(sampleSize / (sampleSize - (1 + this.epsilon))));\n\n // Perform updates to moving mean and moving variance for training.\n // Porting Note: In PyKeras, these updates to `movingMean` and\n // `movingAverage` are done as a deferred Graph, added to the `Layer`'s\n // `update`s using the `add_update()` method. Here we do it imperatively\n // and encapsulate the updates in a function that is invoked\n // immediately.\n const updateMovingMeanAndVariance = () => {\n this.stepCount++;\n const newMovingMean = tfc.movingAverage(\n this.movingMean.read(), mean, this.momentum, this.stepCount);\n this.movingMean.write(newMovingMean);\n const newMovingVariance = tfc.movingAverage(\n this.movingVariance.read(), varianceDebiased, this.momentum,\n this.stepCount);\n this.movingVariance.write(newMovingVariance);\n };\n updateMovingMeanAndVariance();\n\n return normedTraining;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n axis: this.axis,\n momentum: this.momentum,\n epsilon: this.epsilon,\n center: this.center,\n scale: this.scale,\n betaInitializer: serializeInitializer(this.betaInitializer),\n gammaInitializer: serializeInitializer(this.gammaInitializer),\n movingMeanInitializer: serializeInitializer(this.movingMeanInitializer),\n movingVarianceInitializer:\n serializeInitializer(this.movingVarianceInitializer),\n betaRegularizer: serializeRegularizer(this.betaRegularizer),\n gammaRegularizer: serializeRegularizer(this.gammaRegularizer),\n betaConstraint: serializeConstraint(this.betaConstraint),\n gammaConstraint: serializeConstraint(this.gammaConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(BatchNormalization);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Padding Layers.\n */\n\n// Porting Note: In Python Keras, the padding layers are in convolutional.py,\n// but we decided to put them in a separate file (padding.ts) for clarity.\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport {DataFormat} from '../common';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\n// tslint:enable:max-line-length\n\n/**\n * Pads the middle dimension of a 3D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of 2 integers, how many zeros to add at the start and\n * end of the middle dimension (i.e., dimension 1).\n * @return A padded 3D `Tensor`.\n */\nexport function temporalPadding(x: Tensor, padding?: [number, number]): Tensor {\n return tidy(() => {\n if (x.rank !== 3) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 3-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [1, 1];\n }\n if (padding.length !== 2) {\n throw new ValueError(\n `temporalPadding expects input padding pattern to be a length-2 ` +\n `array, but received a length-${padding.length} array.`);\n }\n\n const pattern: Array<[number, number]> = [[0, 0], padding, [0, 0]];\n return tfc.pad(x, pattern);\n });\n}\n\n/**\n * Pads the 2nd and 3rd dimensions of a 4D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of two `Array`s, each of which is an `Array` of two\n * integers. The amount of padding at the beginning and end of the 2nd and 3rd\n * dimensions, respectively.\n * @param dataFormat 'channelsLast' (default) or 'channelsFirst'.\n * @return Padded 4D `Tensor`.\n */\nexport function spatial2dPadding(\n x: Tensor, padding?: [[number, number], [number, number]],\n dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (x.rank !== 4) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 4-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [[1, 1], [1, 1]];\n }\n if (padding.length !== 2 || padding[0].length !== 2 ||\n padding[1].length !== 2) {\n throw new ValueError(\n 'spatial2dPadding expects `padding` to be an Array of two Arrays, ' +\n 'each of which is an Array of two integers.');\n }\n\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (dataFormat !== 'channelsLast' && dataFormat !== 'channelsFirst') {\n throw new ValueError(\n `Unknown data format: ${dataFormat}. ` +\n `Supported data formats are 'channelsLast' and 'channelsFirst.`);\n }\n\n let pattern: Array<[number, number]>;\n if (dataFormat === 'channelsFirst') {\n pattern = [[0, 0], [0, 0], padding[0], padding[1]];\n } else {\n pattern = [[0, 0], padding[0], padding[1], [0, 0]];\n }\n\n return tfc.pad(x, pattern);\n });\n}\n\nexport interface ZeroPadding2DLayerConfig extends LayerConfig {\n /**\n * Integer, or `Array` of 2 integers, or `Array` of 2 `Array`s, each of\n * which is an `Array` of 2 integers.\n * - If integer, the same symmetric padding is applied to width and height.\n * - If Array` of 2 integers, interpreted as two different symmetric values\n * for height and width:\n * `[symmetricHeightPad, symmetricWidthPad]`.\n * - If `Array` of 2 `Array`s, interpreted as:\n * `[[topPad, bottomPad], [leftPad, rightPad]]`.\n */\n padding?: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * One of `'channelsLast'` (default) and `'channelsFirst'`.\n *\n * The ordering of the dimensions in the inputs.\n * `channelsLast` corresponds to inputs with shape\n * `[batch, height, width, channels]` while `channelsFirst`\n * corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Zero-padding layer for 2D input (e.g., image).\n *\n * This layer can add rows and columns of zeros\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, paddedRows, paddedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, paddedRows, paddedCols]`.\n */\nexport class ZeroPadding2D extends Layer {\n static className = 'ZeroPadding2D';\n readonly dataFormat: DataFormat;\n readonly padding: [[number, number], [number, number]];\n\n constructor(config?: ZeroPadding2DLayerConfig) {\n if (config == null) {\n config = {};\n }\n super(config);\n\n this.dataFormat =\n config.dataFormat == null ? imageDataFormat() : config.dataFormat;\n // TODO(cais): Maybe refactor the following logic surrounding `padding`\n // into a helper method.\n if (config.padding == null) {\n this.padding = [[1, 1], [1, 1]];\n } else if (typeof config.padding === 'number') {\n this.padding =\n [[config.padding, config.padding], [config.padding, config.padding]];\n } else {\n config.padding = config.padding as [number, number] |\n [[number, number], [number, number]];\n if (config.padding.length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects padding to be a length-2 array, but ` +\n `received a length-${config.padding.length} array.`);\n }\n\n let heightPadding: [number, number];\n let widthPadding: [number, number];\n if (typeof config.padding[0] === 'number') {\n heightPadding =\n [config.padding[0] as number, config.padding[0] as number];\n widthPadding =\n [config.padding[1] as number, config.padding[1] as number];\n } else {\n config.padding = config.padding as [[number, number], [number, number]];\n\n if (config.padding[0].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects height padding to be a length-2 array, ` +\n `but received a length-${config.padding[0].length} array.`);\n }\n heightPadding = config.padding[0] as [number, number];\n\n if (config.padding[1].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects width padding to be a length-2 array, ` +\n `but received a length-${config.padding[1].length} array.`);\n }\n widthPadding = config.padding[1] as [number, number];\n }\n this.padding = [heightPadding, widthPadding];\n }\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n\n let rows: number;\n let cols: number;\n if (this.dataFormat === 'channelsFirst') {\n if (inputShape[2] != null && inputShape[2] >= 0) {\n rows = inputShape[2] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[3] != null && inputShape[3] >= 0) {\n cols = inputShape[3] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n if (inputShape[1] != null && inputShape[1] >= 0) {\n rows = inputShape[1] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[2] != null && inputShape[2] >= 0) {\n cols = inputShape[2] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(\n () => spatial2dPadding(\n getExactlyOneTensor(inputs), this.padding, this.dataFormat));\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n padding: this.padding,\n dataFormat: this.dataFormat,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ZeroPadding2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Pooling Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, checkPoolMode, DataFormat, PaddingMode, PoolMode} from '../common';\nimport {InputSpec} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\nimport {preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D pooling.\n * @param x\n * @param poolSize\n * @param stridesdes strides. Defaults to [1, 1].\n * @param padding padding. Defaults to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param poolMode Mode of pooling. Defaults to 'max'.\n * @returns Result of the 2D pooling.\n */\nexport function pool2d(\n x: Tensor, poolSize: [number, number], strides?: [number, number],\n padding?: PaddingMode, dataFormat?: DataFormat,\n poolMode?: PoolMode): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n checkPoolMode(poolMode);\n checkPaddingMode(padding);\n if (strides == null) {\n strides = [1, 1];\n }\n if (padding == null) {\n padding = 'valid';\n }\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (poolMode == null) {\n poolMode = 'max';\n }\n\n // TODO(cais): Remove the preprocessing step once deeplearn.js supports\n // dataFormat as an input argument.\n x = preprocessConv2DInput(x, dataFormat); // x is NHWC after preprocessing.\n let y: Tensor;\n const paddingString = (padding === 'same') ? 'same' : 'valid';\n if (poolMode === 'max') {\n // TODO(cais): Rank check?\n y = tfc.maxPool(x as Tensor4D, poolSize, strides, paddingString);\n } else { // 'avg'\n // TODO(cais): Check the dtype and rank of x and give clear error message\n // if those are incorrect.\n y = tfc.avgPool(\n // TODO(cais): Rank check?\n x as Tensor3D | Tensor4D, poolSize, strides, paddingString);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return y;\n });\n}\n\n\nexport interface Pooling1DLayerConfig extends LayerConfig {\n /**\n * Size of the window to pool over, should be an integer.\n */\n poolSize?: number;\n /**\n * Period at which to sample the pooled values.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number;\n /** How to fill in data that's not an integer multiple of poolSize. */\n padding?: PaddingMode;\n}\n\n/**\n * Abstract class for different pooling 1D layers.\n */\nexport abstract class Pooling1D extends Layer {\n protected readonly poolSize: [number];\n protected readonly strides: [number];\n protected readonly padding: PaddingMode;\n\n /**\n *\n * @param config Parameters for the Pooling layer.\n *\n * config.poolSize defaults to 2.\n */\n constructor(config: Pooling1DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = 2;\n }\n super(config);\n if (typeof config.poolSize === 'number') {\n this.poolSize = [config.poolSize];\n } else if (\n Array.isArray(config.poolSize) &&\n (config.poolSize as number[]).length === 1 &&\n typeof (config.poolSize as number[])[0] === 'number') {\n this.poolSize = config.poolSize;\n } else {\n throw new ValueError(\n `poolSize for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.poolSize)}`);\n }\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else {\n if (typeof config.strides === 'number') {\n this.strides = [config.strides];\n } else if (\n Array.isArray(config.strides) &&\n (config.strides as number[]).length === 1 &&\n typeof (config.strides as number[])[0] === 'number') {\n this.strides = config.strides;\n } else {\n throw new ValueError(\n `strides for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.strides)}`);\n }\n }\n\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const length = convOutputLength(\n inputShape[1], this.poolSize[0], this.padding, this.strides[0]);\n return [inputShape[0], length, inputShape[2]];\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Add dummy last dimension.\n inputs = K.expandDims(getExactlyOneTensor(inputs), 2);\n const output = this.poolingFunction(\n getExactlyOneTensor(inputs), [this.poolSize[0], 1],\n [this.strides[0], 1], this.padding, 'channelsLast');\n // Remove dummy last dimension.\n return tfc.squeeze(output, [2]);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for temporal data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n */\nexport class MaxPooling1D extends Pooling1D {\n static className = 'MaxPooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling1D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n *\n * `tf.avgPool1d` is an alias.\n */\nexport class AveragePooling1D extends Pooling1D {\n static className = 'AveragePooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling1D);\n\nexport interface Pooling2DLayerConfig extends LayerConfig {\n /**\n * Factors by which to downscale in each dimension [vertical, horizontal].\n * Expects an integer or an array of 2 integers.\n *\n * For example, `[2, 2]` will halve the input in both spatial dimension.\n * If only one integer is specified, the same window length\n * will be used for both dimensions.\n */\n poolSize?: number|[number, number];\n\n /**\n * The size of the stride in each dimension of the pooling window. Expects\n * an integer or an array of 2 integers. Integer, tuple of 2 integers, or\n * None.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number|[number, number];\n\n /** The padding type to use for the pooling layer. */\n padding?: PaddingMode;\n /** The data format to use for the pooling layer. */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different pooling 2D layers.\n */\nexport abstract class Pooling2D extends Layer {\n protected readonly poolSize: [number, number];\n protected readonly strides: [number, number];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Pooling2DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = [2, 2];\n }\n super(config);\n this.poolSize = Array.isArray(config.poolSize) ?\n config.poolSize :\n [config.poolSize, config.poolSize];\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else if (Array.isArray(config.strides)) {\n if (config.strides.length !== 2) {\n throw new ValueError(\n `If the strides property of a 2D pooling layer is an Array, ` +\n `it is expected to have a length of 2, but received length ` +\n `${config.strides.length}.`);\n }\n this.strides = config.strides;\n } else {\n // `config.strides` is a number.\n this.strides = [config.strides, config.strides];\n }\n this.padding = config.padding == null ? 'valid' : config.padding;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n checkPaddingMode(this.padding);\n\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n let rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n let cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n rows =\n convOutputLength(rows, this.poolSize[0], this.padding, this.strides[0]);\n cols =\n convOutputLength(cols, this.poolSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return this.poolingFunction(\n getExactlyOneTensor(inputs), this.poolSize, this.strides,\n this.padding, this.dataFormat);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n dataFormat: this.dataFormat\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for spatial data.\n *\n * Input shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat=CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat=CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n */\nexport class MaxPooling2D extends Pooling2D {\n static className = 'MaxPooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling2D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n *\n * `tf.avgPool2d` is an alias.\n */\nexport class AveragePooling2D extends Pooling2D {\n static className = 'AveragePooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling2D);\n\n/**\n * Abstract class for different global pooling 1D layers.\n */\nexport abstract class GlobalPooling1D extends Layer {\n constructor(config: LayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], inputShape[2]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n}\n\n/**\n * Global average pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalAveragePooling1D extends GlobalPooling1D {\n static className = 'GlobalAveragePooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.mean(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling1D);\n\n/**\n * Global max pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalMaxPooling1D extends GlobalPooling1D {\n static className = 'GlobalMaxPooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.max(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling1D);\n\nexport interface GlobalPooling2DLayerConfig extends LayerConfig {\n /**\n * One of `CHANNEL_LAST` (default) or `CHANNEL_FIRST`.\n *\n * The ordering of the dimensions in the inputs. `CHANNEL_LAST` corresponds\n * to inputs with shape `[batch, height, width, channels[` while\n * `CHANNEL_FIRST` corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different global pooling 2D layers.\n */\nexport abstract class GlobalPooling2D extends Layer {\n protected dataFormat: DataFormat;\n constructor(config: GlobalPooling2DLayerConfig) {\n super(config);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape;\n if (this.dataFormat === 'channelsLast') {\n return [inputShape[0], inputShape[3]];\n } else {\n return [inputShape[0], inputShape[1]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Global average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalAveragePooling2D extends GlobalPooling2D {\n static className = 'GlobalAveragePooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.mean(input, [1, 2]);\n } else {\n return tfc.mean(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling2D);\n\n/**\n * Global max pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalMaxPooling2D extends GlobalPooling2D {\n static className = 'GlobalMaxPooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.max(input, [1, 2]);\n } else {\n return tfc.max(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Recurrent Neural Network Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Activation, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, SymbolicTensor} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {AttributeError, NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, Ones, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, RnnStepFunction, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor, isArrayOfShapes} from '../utils/types_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\n/**\n * Standardize `apply()` args to a single list of tensor inputs.\n *\n * When running a model loaded from file, the input tensors `initialState` and\n * `constants` are passed to `RNN.apply()` as part of `inputs` instead of the\n * dedicated kwargs fields. `inputs` consists of\n * `[inputs, initialState0, initialState1, ..., constant0, constant1]` in this\n * case.\n * This method makes sure that arguments are\n * separated and that `initialState` and `constants` are `Array`s of tensors\n * (or None).\n *\n * @param inputs Tensor or `Array` of tensors.\n * @param initialState Tensor or `Array` of tensors or `null`/`undefined`.\n * @param constants Tensor or `Array` of tensors or `null`/`undefined`.\n * @returns An object consisting of\n * inputs: A tensor.\n * initialState: `Array` of tensors or `null`.\n * constants: `Array` of tensors or `null`.\n * @throws ValueError, if `inputs` is an `Array` but either `initialState` or\n * `constants` is provided.\n */\nexport function standardizeArgs(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n initialState: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n constants: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n numConstants?: number): {\n inputs: Tensor|SymbolicTensor,\n initialState: Tensor[]|SymbolicTensor[],\n constants: Tensor[]|SymbolicTensor[]\n} {\n if (Array.isArray(inputs)) {\n if (initialState != null || constants != null) {\n throw new ValueError(\n 'When inputs is an array, neither initialState or constants ' +\n 'should be provided');\n }\n if (numConstants != null) {\n constants = inputs.slice(inputs.length - numConstants, inputs.length);\n inputs = inputs.slice(0, inputs.length - numConstants);\n }\n if (inputs.length > 1) {\n initialState = inputs.slice(1, inputs.length);\n }\n inputs = inputs[0];\n }\n\n function toListOrNull(x: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): Tensor[]|SymbolicTensor[] {\n if (x == null || Array.isArray(x)) {\n return x as Tensor[] | SymbolicTensor[];\n } else {\n return [x] as Tensor[] | SymbolicTensor[];\n }\n }\n\n initialState = toListOrNull(initialState);\n constants = toListOrNull(constants);\n\n return {inputs, initialState, constants};\n}\n\n/**\n * Iterates over the time dimension of a tensor.\n *\n * @param stepFunction RNN step function.\n * Parameters:\n * inputs: tensor with shape `[samples, ...]` (no time dimension),\n * representing input for the batch of samples at a certain time step.\n * states: an Array of tensors.\n * Returns:\n * outputs: tensor with shape `[samples, outputDim]` (no time dimension).\n * newStates: list of tensors, same length and shapes as `states`. The first\n * state in the list must be the output tensor at the previous timestep.\n * @param inputs Tensor of temporal data of shape `[samples, time, ...]` (at\n * least 3D).\n * @param initialStates Tensor with shape `[samples, outputDim]` (no time\n * dimension), containing the initial values of the states used in the step\n * function.\n * @param goBackwards If `true`, do the iteration over the time dimension in\n * reverse order and return the reversed sequence.\n * @param mask Binary tensor with shape `[sample, time, 1]`, with a zero for\n * every element that is masked.\n * @param constants An Array of constant values passed at each step.\n * @param unroll Whether to unroll the RNN or to use a symbolic loop. *Not*\n * applicable to this imperative deeplearn.js backend. Its value is ignored.\n * @param inputLength Not relevant in this deeplearn.js backend.\n * @returns An Array: `[lastOutput, outputs, newStates]`.\n * lastOutput: the lastest output of the RNN, of shape `[samples, ...]`.\n * outputs: tensor with shape `[samples, time, ...]` where each entry\n * `output[s, t]` is the output of the step function at time `t` for sample\n * `s`.\n * newStates: Array of tensors, latest states returned by the step function,\n * of shape `(samples, ...)`.\n * @throws ValueError If input dimension is less than 3.\n *\n * TODO(nielsene): This needs to be tidy-ed.\n */\nexport function rnn(\n stepFunction: RnnStepFunction, inputs: Tensor, initialStates: Tensor[],\n goBackwards = false, mask?: Tensor, constants?: Tensor[], unroll = false,\n inputLength?: number): [Tensor, Tensor, Tensor[]] {\n const ndim = inputs.shape.length;\n if (ndim < 3) {\n throw new ValueError(`Input should be at least 3D, but is ${ndim}D.`);\n }\n\n // Transpose to time-major, i.e., from [batch, time, ...] to [time, batch,\n // ...].\n const axes = [1, 0].concat(math_utils.range(2, ndim));\n inputs = tfc.transpose(inputs, axes);\n\n if (mask != null) {\n throw new NotImplementedError(\n 'The rnn() function of the deeplearn.js backend does not support ' +\n 'masking yet.');\n }\n\n if (constants != null) {\n throw new NotImplementedError(\n 'The rnn() functoin of the deeplearn.js backend does not support ' +\n 'constants yet.');\n }\n\n // Porting Note: the unroll option is ignored by the imperative backend.\n if (unroll) {\n console.warn(\n 'Backend rnn(): the unroll = true option is not applicable to the ' +\n 'imperative deeplearn.js backend.');\n }\n\n if (goBackwards) {\n inputs = tfc.reverse(inputs, 0);\n }\n\n // Porting Note: PyKeras with TensorFlow backend uses a symbolic loop\n // (tf.while_loop). But for the imperative deeplearn.js backend, we just\n // use the usual TypeScript control flow to iterate over the time steps in\n // the inputs.\n // Porting Note: PyKeras patches a \"_use_learning_phase\" attribute to\n // outputs.\n // This is not idiomatic in TypeScript. The info regarding whether we are\n // in a learning (i.e., training) phase for RNN is passed in a different\n // way.\n // TODO(cais): Determine in what exact way the learning phase information\n // will be passed.\n\n let outputs: Tensor;\n let lastOutput: Tensor;\n let states = initialStates;\n const timeSteps = inputs.shape[0];\n for (let t = 0; t < timeSteps; ++t) {\n let currentInput = K.sliceAlongFirstAxis(inputs, t, 1);\n currentInput = currentInput.reshape(currentInput.shape.slice(1));\n const stepOutputs = stepFunction(currentInput, states);\n lastOutput = stepOutputs[0];\n if (t === 0) {\n outputs = lastOutput.reshape([1].concat(lastOutput.shape));\n } else {\n outputs = K.concatAlongFirstAxis(\n outputs, lastOutput.reshape([1].concat(lastOutput.shape)));\n }\n // TODO(soergel): Call K.concatenate() to perform only one concatenation\n // at the end, once the backend function is available.\n states = stepOutputs[1];\n }\n\n return [\n lastOutput,\n tfc.transpose(\n outputs, [1, 0].concat(math_utils.range(2, outputs.shape.length))),\n states\n ];\n}\n\n\nexport interface BaseRNNLayerConfig extends LayerConfig {\n /**\n * A RNN cell instance. A RNN cell is a class that has:\n * - a `call()` method, which takes `[Tensor, Tensor]` as the\n * first input argument. The first item is the input at time t, and\n * second item is the cell state at time t.\n * The `call()` method returns `[outputAtT, statesAtTPlus1]`.\n * The `call()` method of the cell can also take the argument `constants`,\n * see section \"Note on passing external constants\" below.\n * Porting Node: PyKeras overrides the `call()` signature of RNN cells,\n * which are Layer subtypes, to accept two arguments. tfjs-layers does\n * not do such overriding. Instead we preseve the `call()` signature,\n * which due to its `Tensor|Tensor[]` argument and return value, is\n * flexible enough to handle the inputs and states.\n * - a `stateSize` attribute. This can be a single integer (single state)\n * in which case it is the size of the recurrent state (which should be\n * the same as the size of the cell output). This can also be an Array of\n * integers (one size per state). In this case, the first entry\n * (`stateSize[0]`) should be the same as the size of the cell output.\n * It is also possible for `cell` to be a list of RNN cell instances, in which\n * case the cells get stacked on after the other in the RNN, implementing an\n * efficient stacked RNN.\n */\n cell?: RNNCell|RNNCell[];\n\n /**\n * Whether to return the last output in the output sequence, or the full\n * sequence.\n */\n returnSequences?: boolean;\n\n /**\n * Whether to return the last state in addition to the output.\n */\n returnState?: boolean;\n\n /**\n * If `true`, process the input sequence backwards and return the reversed\n * sequence (default: `false`).\n */\n goBackwards?: boolean;\n\n /**\n * If `true`, the last state for each sample at index i in a batch will be\n * used as initial state of the sample of index i in the following batch\n * (default: `false`).\n */\n stateful?: boolean;\n\n /**\n * If `true`, the network will be unrolled, else a symbolic loop will be\n * used. Unrolling can speed-up a RNN, although it tends to be more memory-\n * intensive. Unrolling is only suitable for short sequences (default:\n * `false`).\n * Porting Note: tfjs-layers has an imperative backend. RNNs are executed with\n * normal TypeScript control flow. Hence this property is inapplicable and\n * ignored in tfjs-layers.\n */\n unroll?: boolean;\n\n /**\n * Dimensionality of the input (integer).\n * This option (or alternatively, the option `inputShape`) is required when\n * this layer is used as the first layer in a model.\n */\n inputDim?: number;\n\n /**\n * Length of the input sequences, to be specified when it is constant.\n * This argument is required if you are going to connect `Flatten` then\n * `Dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed). Note that if the recurrent layer is not the first layer in\n * your model, you would need to specify the input length at the level of the\n * first layer (e.g., via the `inputShape` option).\n */\n inputLength?: number;\n}\n\n/**\n * RNNLayerConfig is identical to BaseRNNLayerConfig, except it makes the\n * `cell` property required. This interface is to be used with constructors\n * of concrete RNN layer sbutypes.\n */\nexport interface RNNLayerConfig extends BaseRNNLayerConfig {\n cell: RNNCell|RNNCell[];\n}\n\n/**\n * Base class for recurrent layers.\n *\n * Input shape:\n * 3D tensor with shape `[batchSize, timeSteps, inputDim]`.\n *\n * Output shape:\n * - if `returnState`, an Array of tensors (i.e., `Tensor`s). The first\n * tensor is the output. The remaining tensors are the states at the\n * last time step, each with shape `[batchSize, units]`.\n * - if `returnSequences`, the output will have shape\n * `[batchSize, timeSteps, units]`.\n * - else, the output will have shape `[batchSize, units]`.\n *\n * Masking:\n * This layer supports masking for input data with a variable number\n * of timesteps. To introduce masks to your data,\n * use an embedding layer with the `mask_zero` parameter\n * set to `True`.\n *\n * Notes on using statefulness in RNNs:\n * You can set RNN layers to be 'stateful', which means that the states\n * computed for the samples in one batch will be reused as initial states\n * for the samples in the next batch. This assumes a one-to-one mapping\n * between samples in different successive batches.\n *\n * To enable statefulness:\n * - specify `stateful: true` in the layer constructor.\n * - specify a fixed batch size for your model, by passing\n * if sequential model:\n * `batchInputShape=[...]` to the first layer in your model.\n * else for functional model with 1 or more Input layers:\n * `batchShape=[...]` to all the first layers in your model.\n * This is the expected shape of your inputs *including the batch size*.\n * It should be a tuple of integers, e.g. `(32, 10, 100)`.\n * - specify `shuffle=False` when calling fit().\n *\n * To reset the states of your model, call `.reset_states()` on either\n * a specific layer, or on your entire model.\n *\n * Note on specifying the initial state of RNNs\n * You can specify the initial state of RNN layers symbolically by\n * calling them with the option `initialState`. The value of\n * `initialState` should be a tensor or list of tensors representing\n * the initial state of the RNN layer.\n *\n * You can specify the initial state of RNN layers numerically by\n * calling `resetStates` with the keyword argument `states`. The value of\n * `states` should be a numpy array or list of numpy arrays representing\n * the initial state of the RNN layer.\n *\n * Note on passing external constants to RNNs\n * You can pass \"external\" constants to the cell using the `constants`\n * keyword argument of `RNN.call` method. This requires that the `cell.call`\n * method accepts the same keyword argument `constants`. Such constants\n * can be used to conditon the cell transformation on additional static inputs\n * (not changing over time), a.k.a an attention mechanism.\n */\nexport class RNN extends Layer {\n static className = 'RNN';\n public readonly cell: RNNCell;\n public readonly returnSequences: boolean;\n public readonly returnState: boolean;\n public readonly goBackwards: boolean;\n public readonly unroll: boolean;\n\n public stateSpec: InputSpec[];\n public states: Tensor[];\n\n private numConstants: number;\n\n constructor(config: RNNLayerConfig) {\n super(config);\n let cell: RNNCell;\n if (config.cell == null) {\n throw new ValueError(\n 'cell property is missing for the constructor of RNN.');\n } else if (Array.isArray(config.cell)) {\n cell = new StackedRNNCells({cells: config.cell});\n } else {\n cell = config.cell;\n }\n if ((cell as RNNCell).stateSize == null) {\n throw new ValueError(\n 'The RNN cell should have an attribute `stateSize` (tuple of ' +\n 'integers, one integer per RNN state).');\n }\n this.cell = cell;\n this.returnSequences =\n config.returnSequences == null ? false : config.returnSequences;\n this.returnState = config.returnState == null ? false : config.returnState;\n this.goBackwards = config.goBackwards == null ? false : config.goBackwards;\n this._stateful = config.stateful == null ? false : config.stateful;\n this.unroll = config.unroll == null ? false : config.unroll;\n\n this.supportsMasking = true;\n this.inputSpec = [new InputSpec({ndim: 3})];\n this.stateSpec = null;\n this.states = null;\n // TODO(cais): Add constantsSpec and numConstants.\n this.numConstants = null;\n // TODO(cais): Look into the use of initial_state in the kwargs of the\n // constructor.\n }\n\n // Porting Note: This is the equivalent of `RNN.states` property getter in\n // PyKeras.\n getStates(): Tensor[] {\n if (this.states == null) {\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n return math_utils.range(0, numStates).map(x => null);\n } else {\n return this.states;\n }\n }\n\n // Porting Note: This is the equivalent of the `RNN.states` property setter in\n // PyKeras.\n setStates(states: Tensor[]): void {\n this.states = states;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n // TODO(cais): Remove the casting once stacked RNN cells become supported.\n let stateSize = this.cell.stateSize;\n if (!Array.isArray(stateSize)) {\n stateSize = [stateSize];\n }\n const outputDim = stateSize[0];\n let outputShape: Shape|Shape[];\n if (this.returnSequences) {\n outputShape = [inputShape[0], inputShape[1], outputDim];\n } else {\n outputShape = [inputShape[0], outputDim];\n }\n\n if (this.returnState) {\n const stateShape: Shape[] = [];\n for (const dim of stateSize) {\n stateShape.push([inputShape[0], dim]);\n }\n return [outputShape].concat(stateShape);\n } else {\n return outputShape;\n }\n }\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for RNN yet');\n }\n\n public build(inputShape: Shape|Shape[]): void {\n // Note inputShape will be an Array of Shapes of initial states and\n // constants if these are passed in apply().\n const constantShape: Shape[] = null;\n if (this.numConstants != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n }\n\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n const batchSize: number = this.stateful ? inputShape[0] : null;\n const inputDim = inputShape[inputShape.length - 1];\n this.inputSpec[0] = new InputSpec({shape: [batchSize, null, inputDim]});\n\n // Allow cell (if RNNCell Layer) to build before we set or validate\n // stateSpec.\n const stepInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (constantShape != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n } else {\n this.cell.build(stepInputShape);\n }\n\n // Set or validate stateSpec.\n let stateSize: number[];\n if (Array.isArray((this.cell as RNNCell).stateSize)) {\n stateSize = this.cell.stateSize as number[];\n } else {\n stateSize = [this.cell.stateSize as number];\n }\n\n if (this.stateSpec != null) {\n if (!util.arraysEqual(\n this.stateSpec.map(spec => spec.shape[spec.shape.length - 1]),\n stateSize)) {\n throw new ValueError(\n `An initialState was passed that is not compatible with ` +\n `cell.stateSize. Received stateSpec=${this.stateSpec}; ` +\n `However cell.stateSize is ${this.cell.stateSize}`);\n }\n } else {\n this.stateSpec =\n stateSize.map(dim => new InputSpec({shape: [null, dim]}));\n }\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n // TODO(cais): Uncomment the following line once stateful = true is\n // implemented.\n // this.resetStates();\n }\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n tidy(() => {\n if (!this.stateful) {\n throw new AttributeError(\n 'Cannot call resetState() on an RNN Layer that is not stateful.');\n }\n const batchSize = this.inputSpec[0].shape[0];\n if (batchSize == null) {\n throw new ValueError(\n 'If an RNN is stateful, it needs to know its batch size. Specify ' +\n 'the batch size of your input tensors: \\n' +\n '- If using a Sequential model, specify the batch size by ' +\n 'passing a `batchInputShape` option to your first layer.\\n' +\n '- If using the functional API, specify the batch size by ' +\n 'passing a `batchShape` option to your Input layer.');\n }\n // Initialize state if null.\n if (this.states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states = [tfc.zeros([batchSize, this.cell.stateSize])];\n }\n } else if (states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states[0] = tfc.zeros([batchSize, this.cell.stateSize]);\n }\n } else {\n if (!Array.isArray(states)) {\n states = [states];\n }\n if (states.length !== this.states.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${this.states.length} state(s), ` +\n `but it received ${states.length} state value(s). Input ` +\n `received: ${states}`);\n }\n for (let index = 0; index < this.states.length; ++index) {\n const value = states[index];\n const dim = Array.isArray(this.cell.stateSize) ?\n this.cell.stateSize[index] :\n this.cell.stateSize;\n const expectedShape = [batchSize, dim];\n if (!util.arraysEqual(value.shape, expectedShape)) {\n throw new ValueError(\n `State ${index} is incompatible with layer ${this.name}: ` +\n `expected shape=${expectedShape}, received shape=${\n value.shape}`);\n }\n this.states[index] = value;\n }\n }\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n // TODO(cais): Figure out whether initialState is in kwargs or inputs.\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n // If any of `initial_state` or `constants` are specified and are\n // `SymbolicTensor`s, then add them to the inputs and temporarily modify the\n // input_spec to include them.\n\n let additionalInputs: Array = [];\n let additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n kwargs['initialState'] = initialState;\n additionalInputs = additionalInputs.concat(initialState);\n this.stateSpec = [];\n for (const state of initialState) {\n this.stateSpec.push(new InputSpec({shape: state.shape}));\n }\n // TODO(cais): Use the following instead.\n // this.stateSpec = initialState.map(state => new InputSpec({shape:\n // state.shape}));\n additionalSpecs = additionalSpecs.concat(this.stateSpec);\n }\n if (constants != null) {\n kwargs['constants'] = constants;\n additionalInputs = additionalInputs.concat(constants);\n // TODO(cais): Add this.constantsSpec.\n this.numConstants = constants.length;\n }\n\n const isTensor = additionalInputs[0] instanceof SymbolicTensor;\n if (isTensor) {\n // Compute full input spec, including state and constants.\n const fullInput =\n [inputs].concat(additionalInputs) as Tensor[] | SymbolicTensor[];\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call with temporarily replaced inputSpec.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output = super.apply(fullInput, kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n // tslint:disable-next-line:no-any\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n // Input shape: `[samples, time (padded with zeros), input_dim]`.\n // Note that the .build() method of subclasses **must** define\n // this.inputSpec and this.stateSpec owith complete input shapes.\n return tidy(() => {\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n let initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n\n inputs = getExactlyOneTensor(inputs);\n if (initialState == null) {\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet.');\n } else {\n initialState = this.getInitialState(inputs);\n }\n }\n\n if (mask != null) {\n throw new NotImplementedError('Masking is not implemented for RNN yet');\n }\n\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n if (initialState.length !== numStates) {\n throw new ValueError(\n `RNN Layer has ${numStates} state(s) but was passed ` +\n `${initialState.length} initial state(s).`);\n }\n const inputShape = inputs.shape;\n const timesteps = inputShape[1];\n if (this.unroll) {\n console.warn(\n 'Ignoring unroll = true for RNN layer, due to imperative backend.');\n }\n\n const cellCallKwargs: Kwargs = {training};\n\n // TODO(cais): Add support for constants.\n const step = (inputs: Tensor, states: Tensor[]) => {\n // `inputs` and `states` are concatenated to form a single `Array` of\n // `Tensor`s as the input to `cell.call()`.\n const outputs =\n this.cell.call([inputs].concat(states), cellCallKwargs) as Tensor[];\n // Marshall the return value into output and new states.\n return [outputs[0], outputs.slice(1)] as [Tensor, Tensor[]];\n };\n\n // TODO(cais): Add support for constants.\n // TODO(cais): Add support for masks.\n\n const rnnOutputs =\n rnn(step, inputs, initialState, this.goBackwards, null, null,\n this.unroll, timesteps);\n const lastOutput = rnnOutputs[0];\n const outputs = rnnOutputs[1];\n const states = rnnOutputs[2];\n\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n }\n\n const output = this.returnSequences ? outputs : lastOutput;\n\n // TODO(cais): Porperty set learning phase flag.\n\n if (this.returnState) {\n return [output].concat(states);\n } else {\n return output;\n }\n });\n }\n\n getInitialState(inputs: Tensor): Tensor[] {\n return tidy(() => {\n // Build an all-zero tensor of shape [samples, outputDim].\n // [Samples, timeSteps, inputDim].\n let initialState = tfc.zeros(inputs.shape);\n // [Samples].\n initialState = tfc.sum(initialState, [1, 2]);\n initialState = K.expandDims(initialState); // [Samples, 1].\n\n if (Array.isArray(this.cell.stateSize)) {\n return this.cell.stateSize.map(\n dim => dim > 1 ? K.tile(initialState, [1, dim]) : initialState);\n } else {\n return this.cell.stateSize > 1 ?\n [K.tile(initialState, [1, this.cell.stateSize])] :\n [initialState];\n }\n });\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n return this.cell.trainableWeights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n if (!this.trainable) {\n return this.cell.weights;\n }\n return this.cell.nonTrainableWeights;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n returnSequences: this.returnSequences,\n returnState: this.returnState,\n goBackwards: this.goBackwards,\n stateful: this.stateful,\n unroll: this.unroll,\n };\n if (this.numConstants != null) {\n config.numConstants = this.numConstants;\n }\n const cellConfig = this.cell.getConfig();\n config.cell = {\n className: this.cell.getClassName(),\n config: cellConfig,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RNN);\n\n/**\n * An RNNCell layer.\n */\n// Porting Note: This is a common parent class for RNN cells. There is no\n// equivalent of this in PyKeras. Having a common parent class forgoes the\n// need for `has_attr(cell, ...)` checks or its TypeScript equivalent.\n/** @doc {heading: 'Layers', subheading: 'Classes'} */\nexport abstract class RNNCell extends Layer {\n /**\n * Size(s) of the states.\n * For RNN cells with only a single state, this is a single integer.\n */\n public stateSize: number|number[];\n public dropoutMask: Tensor|Tensor[];\n public recurrentDropoutMask: Tensor|Tensor[];\n}\n\nexport interface SimpleRNNCellLayerConfig extends LayerConfig {\n /**\n * units: Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n * Default: hyperbolic tangent ('tanh').\n * If you pass `null`, 'linear' activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the `kernel` weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the `recurrent_kernel` weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the `kernel` weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the `recurrentKernel` weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraintfunction applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Cell class for `SimpleRNN`.\n *\n * `SimpleRNNCell` is distinct from the `RNN` subclass `SimpleRNN` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `SimpleRNN` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.simpleRNNCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `SimpleRNNCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.simpleRNNCell({units: 4}),\n * tf.layers.simpleRNNCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `SimpleRNNCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `SimpleRNNCell`, use the\n * `tf.layers.simpleRNN`.\n */\nexport class SimpleRNNCell extends RNNCell {\n static className = 'SimpleRNNCell';\n readonly units: number;\n readonly activation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(config: SimpleRNNCellLayerConfig) {\n super(config);\n this.units = config.units;\n this.activation = getActivation(\n config.activation == null ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n // TODO(cais): Use regularizer.\n this.kernel = this.addWeight(\n 'kernel', [inputShape[inputShape.length - 1], this.units], null,\n this.kernelInitializer, this.kernelRegularizer, true,\n this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n // Porting Note: PyKeras' equivalent of this method takes two tensor inputs:\n // `inputs` and `states`. Here, the two tensors are combined into an\n // `Tensor[]` Array as the first input argument.\n // Similarly, PyKeras' equivalent of this method returns two values:\n // `output` and `[output]`. Here the two are combined into one length-2\n // `Tensor[]`, consisting of `output` repeated.\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `SimpleRNNCell expects 2 input Tensors, got ${inputs.length}.`);\n }\n let prevOutput = inputs[1];\n inputs = inputs[0];\n const training = kwargs['training'] == null ? false : kwargs['training'];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training) as Tensor;\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(prevOutput), this.recurrentDropout,\n training) as Tensor;\n }\n let h: Tensor;\n const dpMask: Tensor = this.dropoutMask as Tensor;\n const recDpMask: Tensor = this.recurrentDropoutMask as Tensor;\n if (dpMask != null) {\n h = K.dot(tfc.mul(inputs, dpMask), this.kernel.read());\n } else {\n h = K.dot(inputs, this.kernel.read());\n }\n if (this.bias != null) {\n h = K.biasAdd(h, this.bias.read());\n }\n if (recDpMask != null) {\n prevOutput = tfc.mul(prevOutput, recDpMask);\n }\n let output = tfc.add(h, K.dot(prevOutput, this.recurrentKernel.read()));\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n // TODO(cais): Properly set learning phase on output tensor?\n return [output, output];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNNCell);\n\nexport interface SimpleRNNLayerConfig extends BaseRNNLayerConfig {\n /**\n * Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n *\n * Defaults to hyperbolic tangent (`tanh`)\n *\n * If you pass `null`, no activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the recurrentKernel weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the kernel weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the recurrentKernel weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Fully-connected RNN where the output is to be fed back to input.\n *\n * This is an `RNN` layer consisting of one `SimpleRNNCell`. However, unlike\n * the underlying `SimpleRNNCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.simpleRNN({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `SimpleRNNCell`'s number of units.\n * ```\n */\nexport class SimpleRNN extends RNN {\n static className = 'SimpleRNN';\n constructor(config: SimpleRNNLayerConfig) {\n config.cell = new SimpleRNNCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n // TODO(cais): Research possibility of refactoring out the tedious all\n // the getters that delegate to `this.cell` below.\n get units(): number {\n return (this.cell as SimpleRNNCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as SimpleRNNCell).activation;\n }\n\n get useBias(): boolean {\n return (this.cell as SimpleRNNCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as SimpleRNNCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as SimpleRNNCell).recurrentDropout;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNN);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface GRUCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Cell class for `GRU`.\n *\n * `GRUCell` is distinct from the `RNN` subclass `GRU` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `GRU` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.gruCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `GRUCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.gruCell({units: 4}),\n * tf.layers.gruCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `gruCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `GRUCell`, use the\n * `tf.layers.gru`.\n */\nexport class GRUCell extends RNNCell {\n static className = 'GRUCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: GRUCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 3], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 3], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units * 3], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `GRUCell expects 2 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n\n const training = kwargs['training'] == null ? false : kwargs['training'];\n let hTMinus1 = inputs[1]; // Previous memory state.\n inputs = inputs[0];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 3) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 3) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor];\n const recDpMask = this.recurrentDropoutMask as [Tensor, Tensor, Tensor];\n let z: Tensor;\n let r: Tensor;\n let hh: Tensor;\n if (this.implementation === 1) {\n const kernelZ = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelR =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelH = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const recurrentKernelZ =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelR = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelH = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n\n let inputsZ: Tensor, inputsR: Tensor, inputsH: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsZ = tfc.mul(inputs, dpMask[0]);\n inputsR = tfc.mul(inputs, dpMask[1]);\n inputsH = tfc.mul(inputs, dpMask[2]);\n } else {\n inputsZ = inputs;\n inputsR = inputs;\n inputsH = inputs;\n }\n\n let xZ = K.dot(inputsZ, kernelZ);\n let xR = K.dot(inputsR, kernelR);\n let xH = K.dot(inputsH, kernelH);\n if (this.useBias) {\n const biasZ = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasR =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasH = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n xZ = K.biasAdd(xZ, biasZ);\n xR = K.biasAdd(xR, biasR);\n xH = K.biasAdd(xH, biasH);\n }\n\n let hTMinus1Z: Tensor;\n let hTMinus1R: Tensor;\n let hTMinus1H: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1Z = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1R = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1H = tfc.mul(hTMinus1, recDpMask[2]);\n } else {\n hTMinus1Z = hTMinus1;\n hTMinus1R = hTMinus1;\n hTMinus1H = hTMinus1;\n }\n z = this.recurrentActivation.apply(\n tfc.add(xZ, K.dot(hTMinus1Z, recurrentKernelZ)));\n r = this.recurrentActivation.apply(\n tfc.add(xR, K.dot(hTMinus1R, recurrentKernelR)));\n hh = this.activation.apply(\n tfc.add(xH, K.dot(tfc.mul(r, hTMinus1H), recurrentKernelH)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let matrixX = K.dot(inputs, this.kernel.read());\n if (this.useBias) {\n matrixX = K.biasAdd(matrixX, this.bias.read());\n }\n if (0 < this.dropout && this.dropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n const matrixInner = K.dot(\n hTMinus1,\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 0, 2 * this.units));\n\n const xZ = K.sliceAlongLastAxis(matrixX, 0, this.units);\n const xR = K.sliceAlongLastAxis(matrixX, this.units, this.units);\n const recurrentZ = K.sliceAlongLastAxis(matrixInner, 0, this.units);\n const recurrentR =\n K.sliceAlongLastAxis(matrixInner, this.units, this.units);\n\n z = this.recurrentActivation.apply(tfc.add(xZ, recurrentZ));\n r = this.recurrentActivation.apply(tfc.add(xR, recurrentR));\n\n const xH = K.sliceAlongLastAxis(matrixX, 2 * this.units, this.units);\n const recurrentH = K.dot(\n tfc.mul(r, hTMinus1),\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 2 * this.units, this.units));\n hh = this.activation.apply(tfc.add(xH, recurrentH));\n }\n\n const h = tfc.add(\n tfc.mul(z, hTMinus1), tfc.mul(tfc.add(getScalar(1), tfc.neg(z)), hh));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(GRUCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface GRULayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Gated Recurrent Unit - Cho et al. 2014.\n *\n * This is an `RNN` layer consisting of one `GRUCell`. However, unlike\n * the underlying `GRUCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.gru({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `GRUCell`'s number of units.\n */\nexport class GRU extends RNN {\n static className = 'GRU';\n constructor(config: GRULayerConfig) {\n if (config.implementation === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new GRUCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as GRUCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as GRUCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as GRUCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as GRUCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as GRUCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as GRUCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as GRUCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as GRUCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as GRUCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as GRUCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as GRUCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as GRUCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as GRUCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as GRUCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as GRUCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as GRUCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(GRU);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface LSTMCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: ActivationIdentifier;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Cell class for `LSTM`.\n *\n * `LSTMCell` is distinct from the `RNN` subclass `LSTM` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `LSTM` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.lstmCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `LSTMCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.lstmCell({units: 4}),\n * tf.layers.lstmCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `lstmCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `LSTMCell`, use the\n * `tf.layers.lstm`.\n */\nexport class LSTMCell extends RNNCell {\n static className = 'LSTMCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n readonly unitForgetBias: boolean;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number[];\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n\n readonly DEFAULT_BIAS_INITIALIZER = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: LSTMCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.unitForgetBias = config.unitForgetBias;\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = [this.units, this.units];\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 4], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 4], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n let biasInitializer: Initializer;\n if (this.useBias) {\n if (this.unitForgetBias) {\n const capturedBiasInit = this.biasInitializer;\n const capturedUnits = this.units;\n biasInitializer = new (class CustomInit extends Initializer {\n static className = 'CustomInit';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n // TODO(cais): More informative variable names?\n const bI = capturedBiasInit.apply([capturedUnits]);\n const bF = (new Ones()).apply([capturedUnits]);\n const bCAndH = capturedBiasInit.apply([capturedUnits * 2]);\n return K.concatAlongFirstAxis(\n K.concatAlongFirstAxis(bI, bF), bCAndH);\n }\n })();\n } else {\n biasInitializer = this.biasInitializer;\n }\n this.bias = this.addWeight(\n 'bias', [this.units * 4], null, biasInitializer, this.biasRegularizer,\n true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n inputs = inputs as Tensor[];\n if (inputs.length !== 3) {\n throw new ValueError(\n `LSTMCell expects 3 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n let hTMinus1 = inputs[1]; // Previous memory state.\n const cTMinus1 = inputs[2]; // Previous carry state.\n inputs = inputs[0];\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 4) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 4) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor, Tensor];\n const recDpMask =\n this.recurrentDropoutMask as [Tensor, Tensor, Tensor, Tensor];\n\n let i: Tensor;\n let f: Tensor;\n let c: Tensor;\n let o: Tensor;\n if (this.implementation === 1) {\n const kernelI = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelF =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelC = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const kernelO = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 3, this.units);\n const recurrentKernelI =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelF = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelC = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n const recurrentKernelO = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 3, this.units);\n\n let inputsI: Tensor, inputsF: Tensor, inputsC: Tensor, inputsO: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsI = tfc.mul(inputs, dpMask[0]);\n inputsF = tfc.mul(inputs, dpMask[1]);\n inputsC = tfc.mul(inputs, dpMask[2]);\n inputsO = tfc.mul(inputs, dpMask[3]);\n } else {\n inputsI = inputs;\n inputsF = inputs;\n inputsC = inputs;\n inputsO = inputs;\n }\n\n let xI = K.dot(inputsI, kernelI);\n let xF = K.dot(inputsF, kernelF);\n let xC = K.dot(inputsC, kernelC);\n let xO = K.dot(inputsO, kernelO);\n if (this.useBias) {\n const biasI = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasF =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasC = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n const biasO = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 3, this.units);\n xI = K.biasAdd(xI, biasI);\n xF = K.biasAdd(xF, biasF);\n xC = K.biasAdd(xC, biasC);\n xO = K.biasAdd(xO, biasO);\n }\n\n let hTMinus1I: Tensor, hTMinus1F: Tensor, hTMinus1C: Tensor,\n hTMinus1O: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1I = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1F = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1C = tfc.mul(hTMinus1, recDpMask[2]);\n hTMinus1O = tfc.mul(hTMinus1, recDpMask[3]);\n } else {\n hTMinus1I = hTMinus1;\n hTMinus1F = hTMinus1;\n hTMinus1C = hTMinus1;\n hTMinus1O = hTMinus1;\n }\n i = this.recurrentActivation.apply(\n tfc.add(xI, K.dot(hTMinus1I, recurrentKernelI)));\n f = this.recurrentActivation.apply(\n tfc.add(xF, K.dot(hTMinus1F, recurrentKernelF)));\n c = tfc.add(\n tfc.mul(f, cTMinus1),\n tfc.mul(\n i,\n this.activation.apply(\n tfc.add(xC, K.dot(hTMinus1C, recurrentKernelC)))));\n o = this.recurrentActivation.apply(\n tfc.add(xO, K.dot(hTMinus1O, recurrentKernelO)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let z = K.dot(inputs, this.kernel.read());\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n z = tfc.add(z, K.dot(hTMinus1, this.recurrentKernel.read()));\n if (this.useBias) {\n z = K.biasAdd(z, this.bias.read());\n }\n\n const z0 = K.sliceAlongLastAxis(z, 0, this.units);\n const z1 = K.sliceAlongLastAxis(z, this.units, this.units);\n const z2 = K.sliceAlongLastAxis(z, this.units * 2, this.units);\n const z3 = K.sliceAlongLastAxis(z, this.units * 3, this.units);\n\n i = this.recurrentActivation.apply(z0);\n f = this.recurrentActivation.apply(z1);\n c = tfc.add(\n tfc.mul(f, cTMinus1), tfc.mul(i, this.activation.apply(z2)));\n o = this.recurrentActivation.apply(z3);\n }\n\n const h = tfc.mul(o, this.activation.apply(c));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h, c];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LSTMCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface LSTMLayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions, whereas mode 2 will\n * batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Long-Short Term Memory layer - Hochreiter 1997.\n *\n * This is an `RNN` layer consisting of one `LSTMCell`. However, unlike\n * the underlying `LSTMCell`, the `apply` method of `LSTM` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const lstm = tf.layers.lstm({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = lstm.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `LSTMCell`'s number of units.\n */\nexport class LSTM extends RNN {\n static className = 'LSTM';\n constructor(config: LSTMLayerConfig) {\n if (config.implementation as number === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new LSTMCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as LSTMCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as LSTMCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as LSTMCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as LSTMCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as LSTMCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as LSTMCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as LSTMCell).biasInitializer;\n }\n\n get unitForgetBias(): boolean {\n return (this.cell as LSTMCell).unitForgetBias;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as LSTMCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as LSTMCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as LSTMCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as LSTMCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as LSTMCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as LSTMCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as LSTMCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as LSTMCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as LSTMCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(LSTM);\n\nexport interface StackedRNNCellsConfig extends LayerConfig {\n /**\n * A `Array` of `RNNCell` instances.\n */\n cells: RNNCell[];\n}\n\n/**\n * Wrapper allowing a stack of RNN cells to behave as a single cell.\n *\n * Used to implement efficient stacked RNNs.\n */\nexport class StackedRNNCells extends RNNCell {\n static className = 'StackedRNNCells';\n protected cells: RNNCell[];\n\n constructor(config: StackedRNNCellsConfig) {\n super(config);\n this.cells = config.cells;\n }\n\n get stateSize(): number[] {\n // States are a flat list in reverse order of the cell stack.\n // This allows perserving the requirement `stack.statesize[0] ===\n // outputDim`. E.g., states of a 2-layer LSTM would be `[h2, c2, h1, c1]`,\n // assuming one LSTM has states `[h, c]`.\n const stateSize: number[] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n stateSize.push(...cell.stateSize);\n } else {\n stateSize.push(cell.stateSize);\n }\n }\n return stateSize;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n let states = inputs.slice(1);\n\n // Recover per-cell states.\n const nestedStates: Tensor[][] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n nestedStates.push(states.splice(0, cell.stateSize.length));\n } else {\n nestedStates.push(states.splice(0, 1));\n }\n }\n nestedStates.reverse();\n\n // Call the cells in order and store the returned states.\n const newNestedStates: Tensor[][] = [];\n let callInputs: Tensor[];\n for (let i = 0; i < this.cells.length; ++i) {\n const cell = this.cells[i];\n states = nestedStates[i];\n // TODO(cais): Take care of constants.\n if (i === 0) {\n callInputs = [inputs[0]].concat(states);\n } else {\n callInputs = [callInputs[0]].concat(states);\n }\n callInputs = cell.call(callInputs, kwargs) as Tensor[];\n newNestedStates.push(callInputs.slice(1));\n }\n\n // Format the new states as a flat list in reverse cell order.\n states = [];\n for (const cellStates of newNestedStates.slice().reverse()) {\n states.push(...cellStates);\n }\n return [callInputs[0]].concat(states);\n });\n }\n\n public build(inputShape: Shape|Shape[]): void {\n if (isArrayOfShapes(inputShape)) {\n // TODO(cais): Take care of input constants.\n // const constantShape = inputShape.slice(1);\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n let outputDim: number;\n for (const cell of this.cells) {\n // TODO(cais): Take care of input constants.\n cell.build(inputShape);\n if (Array.isArray(cell.stateSize)) {\n outputDim = cell.stateSize[0];\n } else {\n outputDim = cell.stateSize;\n }\n inputShape = [inputShape[0], outputDim];\n }\n this.built = true;\n }\n\n getConfig(): serialization.ConfigDict {\n const cellConfigs: serialization.ConfigDict[] = [];\n for (const cell of this.cells) {\n cellConfigs.push({\n 'className': this.getClassName(),\n 'config': cell.getConfig(),\n });\n }\n const config: serialization.ConfigDict = {'cells': cellConfigs};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const cells: RNNCell[] = [];\n for (const cellConfig of (config['cells'] as serialization.ConfigDict[])) {\n cells.push(deserialize(cellConfig, customObjects) as RNNCell);\n }\n return new cls({cells});\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const cell of this.cells) {\n trainableWeights.push(...cell.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n /**\n * Retrieve the weights of a the model.\n *\n * @returns A flat `Array` of `Tensor`s.\n */\n getWeights(): Tensor[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.weights);\n }\n return batchGetValue(weights);\n }\n\n /**\n * Set the weights of the model.\n *\n * @param weights An `Array` of `Tensor`s with shapes and types matching the\n * output of `getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n const tuples: Array<[LayerVariable, Tensor]> = [];\n for (const cell of this.cells) {\n const numParams = cell.weights.length;\n const inputWeights = weights.splice(numParams);\n for (let i = 0; i < cell.weights.length; ++i) {\n tuples.push([cell.weights[i], inputWeights[i]]);\n }\n }\n batchSetValue(tuples);\n }\n\n // TODO(cais): Maybe implemnt `losses` and `getLossesFor`.\n}\nserialization.SerializationMap.register(StackedRNNCells);\n\nfunction generateDropoutMask(\n ones: () => Tensor, rate: number, training: boolean = null,\n count = 1): Tensor|Tensor[] {\n function droppedInputs(): Tensor {\n return K.dropout(ones(), getScalar(rate));\n }\n if (count > 1) {\n const mask: Tensor[] = [];\n for (let i = 0; i < count; i++) {\n mask.push(K.inTrainPhase(droppedInputs, ones, training));\n }\n mask.forEach(m => tfc.keep(m));\n return mask;\n } else {\n return tfc.keep(K.inTrainPhase(droppedInputs, ones, training));\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Layers that augment the functionality of a base layer.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {nameScope} from '../common';\nimport {InputSpec, Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {RegularizerFn, RnnStepFunction} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {rnn, RNN, standardizeArgs} from './recurrent';\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\nexport interface WrapperLayerConfig extends LayerConfig {\n /**\n * The layer to be wrapped.\n */\n layer: Layer;\n}\n\n/**\n * Abstract wrapper base class.\n *\n * Wrappers take another layer and augment it in various ways.\n * Do not use this class as a layer, it is only an abstract base class.\n * Two usable wrappers are the `TimeDistributed` and `Bidirectional` wrappers.\n */\nexport abstract class Wrapper extends Layer {\n readonly layer: Layer;\n\n constructor(config: WrapperLayerConfig) {\n // Porting Note: In PyKeras, `self.layer` is set prior to the calling\n // `super()`. But we can't do that here due to TypeScript's restriction.\n // See: https://github.com/Microsoft/TypeScript/issues/8277\n // As a result, we have to add checks in `get trainable()` and\n // `set trainable()` below in order to prevent using `this.layer` when\n // its value is `undefined`. The super constructor does use the getter\n // and the setter of `this.layer`.\n super(config);\n this.layer = config.layer;\n }\n\n build(inputShape: Shape|Shape[]): void {\n this.built = true;\n }\n\n // TODO(cais): Implement activityRegularizer getter.\n\n get trainable(): boolean {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n return this.layer.trainable;\n } else {\n return false;\n }\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n this.layer.trainable = value;\n }\n }\n\n get trainableWeights(): LayerVariable[] {\n return this.layer.trainableWeights;\n }\n // TODO(cais): Implement setter for trainableWeights.\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.layer.nonTrainableWeights;\n }\n // TODO(cais): Implement setter for nonTrainableWeights.\n\n get updates(): Tensor[] {\n // tslint:disable-next-line:no-any\n return (this.layer as any)._updates;\n }\n\n // TODO(cais): Implement getUpdatesFor().\n\n get losses(): RegularizerFn[] {\n return this.layer.losses;\n }\n\n // TODO(cais): Implement getLossesFor().\n\n getWeights(): Tensor[] {\n return this.layer.getWeights();\n }\n\n setWeights(weights: Tensor[]): void {\n this.layer.setWeights(weights);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'layer': {\n 'className': this.layer.getClassName(),\n 'config': this.layer.getConfig(),\n }\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const layerConfig = config['layer'] as serialization.ConfigDict;\n const layer = deserialize(layerConfig, customObjects) as Layer;\n delete config['layer'];\n const newConfig = {layer};\n Object.assign(newConfig, config);\n return new cls(newConfig);\n }\n}\n\n/**\n * This wrapper applies a layer to every temporal slice of an input.\n *\n * The input should be at least 3D, and the dimension of the index `1` will be\n * considered to be the temporal dimension.\n *\n * Consider a batch of 32 samples, where each sample is a sequence of 10 vectors\n * of 16 dimensions. The batch input shape of the layer is then `[32, 10,\n * 16]`, and the `inputShape`, not including the sample dimension, is\n * `[10, 16]`.\n *\n * You can then use `TimeDistributed` to apply a `Dense` layer to each of the 10\n * timesteps, independently:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.dense({units: 8}),\n * inputShape: [10, 16],\n * }));\n *\n * // Now model.outputShape = [null, 10, 8].\n * // The output will then have shape `[32, 10, 8]`.\n *\n * // In subsequent layers, there is no need for `inputShape`:\n * model.add(tf.layers.timeDistributed({layer: tf.layers.dense({units: 32})}));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * // Now model.outputShape = [null, 10, 32].\n * ```\n *\n * The output will then have shape `[32, 10, 32]`.\n *\n * `TimeDistributed` can be used with arbitrary layers, not just `Dense`, for\n * instance a `Conv2D` layer.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.conv2d({filters: 64, kernelSize: [3, 3]}),\n * inputShape: [10, 299, 299, 3],\n * }));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\nexport class TimeDistributed extends Wrapper {\n static className = 'TimeDistributed';\n constructor(config: WrapperLayerConfig) {\n super(config);\n this.supportsMasking = true;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 3) {\n throw new ValueError(\n `TimeDistributed layer expects an input shape >= 3D, but received ` +\n `input shape ${JSON.stringify(inputShape)}`);\n }\n this.inputSpec = [{shape: inputShape}];\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (!this.layer.built) {\n this.layer.build(childInputShape);\n this.layer.built = true;\n }\n super.build(inputShape);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n const childOutputShape =\n this.layer.computeOutputShape(childInputShape) as Shape;\n const timesteps = inputShape[1];\n return [childOutputShape[0], timesteps].concat(childOutputShape.slice(1));\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n // TODO(cais): Add 'training' and 'useLearningPhase' to kwargs.\n inputs = getExactlyOneTensor(inputs);\n // Porting Note: In tfjs-layers, `inputs` are always concrete tensor\n // values. Hence the inputs can't have an undetermined first (batch)\n // dimension, which is why we always use the K.rnn approach here.\n const step: RnnStepFunction = (inputs: Tensor, states: Tensor[]) => {\n // TODO(cais): Add useLearningPhase.\n const output = this.layer.call(inputs, kwargs) as Tensor;\n return [output, []];\n };\n const rnnOutputs =\n rnn(step, inputs, [], false, null, null, false, inputs.shape[1]);\n const y = rnnOutputs[1];\n // TODO(cais): Add activity regularization.\n // TODO(cais): Add useLearningPhase.\n return y;\n });\n }\n}\nserialization.SerializationMap.register(TimeDistributed);\n\nexport type BidirectionalMergeMode = 'sum'|'mul'|'concat'|'ave';\nexport const VALID_BIDIRECTIONAL_MERGE_MODES = ['sum', 'mul', 'concat', 'ave'];\nexport function checkBidirectionalMergeMode(value?: string): void {\n generic_utils.checkStringTypeUnionValue(\n VALID_BIDIRECTIONAL_MERGE_MODES, 'BidirectionalMergeMode', value);\n}\n\nexport interface BidirectionalLayerConfig extends WrapperLayerConfig {\n /**\n * The instance of an `RNN` layer to be wrapped.\n */\n layer: RNN;\n\n /**\n * Mode by which outputs of the forward and backward RNNs are combinied.\n * If `null` or `undefined`, the output will not be combined, they will be\n * returned as an `Array`.\n */\n mergeMode?: BidirectionalMergeMode;\n}\n\nexport class Bidirectional extends Wrapper {\n static className = 'Bidirectional';\n private forwardLayer: RNN;\n private backwardLayer: RNN;\n private mergeMode: BidirectionalMergeMode;\n private returnSequences: boolean;\n private returnState: boolean;\n private numConstants?: number;\n private _trainable: boolean;\n\n constructor(config: BidirectionalLayerConfig) {\n super(config);\n\n // Note: When creating `this.forwardLayer`, the original Layer object\n // (`config.layer`) ought to be cloned. This is why we call `getConfig()`\n // followed by `deserialize()`. Without this cloning, the layer names\n // saved during serialization will incorrectly contain the 'forward_'\n // prefix.\n // In Python Keras, this is done using `copy.copy` (shallow copy), which\n // does not have a simple equivalent in JavaScript. JavaScript's\n // `Object.assign()` does not copy methods.\n const layerConfig = config.layer.getConfig();\n this.forwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n layerConfig['goBackwards'] =\n layerConfig['goBackwards'] === true ? false : true;\n this.backwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n this.forwardLayer.name = 'forward_' + this.forwardLayer.name;\n this.backwardLayer.name = 'backward_' + this.backwardLayer.name;\n checkBidirectionalMergeMode(config.mergeMode);\n this.mergeMode = config.mergeMode;\n if (config.weights) {\n throw new NotImplementedError(\n 'weights support is not implemented for Bidirectional layer yet.');\n }\n this._stateful = config.layer.stateful;\n this.returnSequences = config.layer.returnSequences;\n this.returnState = config.layer.returnState;\n this.supportsMasking = true;\n this._trainable = true;\n this.inputSpec = config.layer.inputSpec;\n this.numConstants = null;\n }\n\n get trainable(): boolean {\n return this._trainable;\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n this._trainable = value;\n if (this.forwardLayer != null) {\n this.forwardLayer.trainable = value;\n }\n if (this.backwardLayer != null) {\n this.backwardLayer.trainable = value;\n }\n }\n\n getWeights(): Tensor[] {\n return this.forwardLayer.getWeights().concat(\n this.backwardLayer.getWeights());\n }\n\n setWeights(weights: Tensor[]): void {\n const numWeights = weights.length;\n const numeightsOver2 = Math.floor(numWeights / 2);\n this.forwardLayer.setWeights(weights.slice(0, numeightsOver2));\n this.backwardLayer.setWeights(weights.slice(numeightsOver2));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n let layerShapes: Shape|Shape[] =\n this.forwardLayer.computeOutputShape(inputShape);\n if (!(Array.isArray(layerShapes) && Array.isArray(layerShapes[0]))) {\n layerShapes = [layerShapes as Shape];\n }\n layerShapes = layerShapes as Shape[];\n\n let outputShape: Shape;\n let outputShapes: Shape[];\n let stateShape: Shape[];\n if (this.returnState) {\n stateShape = layerShapes.slice(1);\n outputShape = layerShapes[0];\n } else {\n outputShape = layerShapes[0];\n }\n outputShape = outputShape as Shape;\n if (this.mergeMode === 'concat') {\n outputShape[outputShape.length - 1] *= 2;\n outputShapes = [outputShape];\n } else if (this.mergeMode == null) {\n outputShapes = [outputShape, outputShape.slice()];\n } else {\n outputShapes = [outputShape];\n }\n\n if (this.returnState) {\n if (this.mergeMode == null) {\n return outputShapes.concat(stateShape).concat(stateShape.slice());\n }\n return [outputShape].concat(stateShape).concat(stateShape.slice());\n }\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs as Tensor | SymbolicTensor;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n if (Array.isArray(inputs)) {\n initialState = (inputs as Tensor[] | SymbolicTensor[]).slice(1);\n inputs = (inputs as Tensor[] | SymbolicTensor[])[0];\n }\n\n if ((initialState == null || initialState.length === 0) &&\n constants == null) {\n return super.apply(inputs, kwargs);\n }\n const additionalInputs: Array = [];\n const additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n const numStates = initialState.length;\n if (numStates % 2 > 0) {\n throw new ValueError(\n 'When passing `initialState` to a Bidrectional RNN, ' +\n 'the state should be an Array containing the states of ' +\n 'the underlying RNNs.');\n }\n kwargs['initialState'] = initialState;\n additionalInputs.push(...initialState);\n const stateSpecs = (initialState as Array)\n .map(state => new InputSpec({shape: state.shape}));\n this.forwardLayer.stateSpec = stateSpecs.slice(0, numStates / 2);\n this.backwardLayer.stateSpec = stateSpecs.slice(numStates / 2);\n additionalSpecs.push(...stateSpecs);\n }\n if (constants != null) {\n throw new NotImplementedError(\n 'Support for constants in Bidirectional layers is not ' +\n 'implemented yet.');\n }\n\n const isSymbolicTensor = additionalInputs[0] instanceof SymbolicTensor;\n for (const tensor of additionalInputs) {\n if (tensor instanceof SymbolicTensor !== isSymbolicTensor) {\n throw new ValueError(\n 'The initial state of a Bidirectional layer cannot be ' +\n 'specified as a mix of symbolic and non-symbolic tensors');\n }\n }\n\n if (isSymbolicTensor) {\n // Compute the full input and specs, including the states.\n const fullInput = [inputs].concat(additionalInputs);\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call temporarily and replace inputSpec.\n // Note: with initial states symbolic calls and non-symbolic calls to this\n // method differ in how the initial states are passed. For symbolic calls,\n // the initial states are passed in the first arg, as an Array of\n // SymbolicTensors; for non-symbolic calls, they are passed in the second\n // arg as a part of the kwargs. Hence the need to temporarily modify\n // inputSpec here.\n // TODO(cais): Make refactoring so that this hacky code below is no\n // longer needed.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output =\n super.apply(fullInput as Tensor[] | SymbolicTensor[], kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (kwargs['mask'] != null) {\n throw new NotImplementedError(\n 'The support for masking is not implemented for ' +\n 'Bidirectional layers yet.');\n }\n const initialState = kwargs['initialState'];\n\n let y: Tensor|Tensor[];\n let yRev: Tensor|Tensor[];\n if (initialState == null) {\n y = this.forwardLayer.call(inputs, kwargs);\n yRev = this.backwardLayer.call(inputs, kwargs);\n } else {\n const forwardState = initialState.slice(0, initialState.length / 2);\n const backwardState = initialState.slice(initialState.length / 2);\n y = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: forwardState}));\n yRev = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: backwardState}));\n }\n\n let states: Tensor[];\n if (this.returnState) {\n if (Array.isArray(y)) {\n states = (y as Tensor[]).slice(1).concat((yRev as Tensor[]).slice(1));\n } else {\n }\n y = (y as Tensor[])[0];\n yRev = (yRev as Tensor[])[0];\n }\n\n if (this.returnSequences) {\n yRev = tfc.reverse(yRev as Tensor, 1);\n }\n\n let output: Tensor|Tensor[];\n if (this.mergeMode === 'concat') {\n output = K.concatenate([y as Tensor, yRev as Tensor]);\n } else if (this.mergeMode === 'sum') {\n output = tfc.add(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode === 'ave') {\n output = tfc.mul(getScalar(0.5), tfc.add(y as Tensor, yRev as Tensor));\n } else if (this.mergeMode === 'mul') {\n output = tfc.mul(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode == null) {\n output = [y as Tensor, yRev as Tensor];\n }\n\n // TODO(cais): Properly set learning phase.\n if (this.returnState) {\n if (this.mergeMode == null) {\n return (output as Tensor[]).concat(states);\n }\n return [output as Tensor].concat(states);\n }\n return output;\n });\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n this.forwardLayer.resetStates();\n this.backwardLayer.resetStates();\n }\n\n build(inputShape: Shape|Shape[]): void {\n nameScope(this.forwardLayer.name, () => {\n this.forwardLayer.build(inputShape);\n });\n nameScope(this.backwardLayer.name, () => {\n this.backwardLayer.build(inputShape);\n });\n this.built = true;\n }\n\n // TODO(cais): Implement computeMask().\n\n get trainableWeights(): LayerVariable[] {\n return this.forwardLayer.trainableWeights.concat(\n this.backwardLayer.trainableWeights);\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.forwardLayer.nonTrainableWeights.concat(\n this.backwardLayer.nonTrainableWeights);\n }\n\n // TODO(cais): Implement constraints().\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'mergeMode': this.mergeMode,\n };\n // TODO(cais): Add logic for `numConstants` once the property is added.\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const rnnLayer =\n deserialize(config['layer'] as serialization.ConfigDict) as RNN;\n delete config['layer'];\n // TODO(cais): Add logic for `numConstants` once the property is added.\n if (config['numConstants'] != null) {\n throw new NotImplementedError(\n `Deserialization of a Bidirectional layer with numConstants ` +\n `present is not supported yet.`);\n }\n // tslint:disable-next-line:no-any\n const newConfig: {[key: string]: any} = config;\n newConfig['layer'] = rnnLayer;\n return new cls(newConfig);\n }\n}\nserialization.SerializationMap.register(Bidirectional);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable:max-line-length\n\nimport {InputLayer, InputLayerConfig} from './engine/input_layer';\nimport {Layer, LayerConfig} from './engine/topology';\nimport {input} from './exports';\nimport {ELU, ELULayerConfig, LeakyReLU, LeakyReLULayerConfig, Softmax, SoftmaxLayerConfig, ThresholdedReLU, ThresholdedReLULayerConfig} from './layers/advanced_activations';\nimport {Conv1D, Conv2D, Conv2DTranspose, ConvLayerConfig, Cropping2D, Cropping2DLayerConfig, SeparableConv2D, SeparableConvLayerConfig, UpSampling2D, UpSampling2DLayerConfig} from './layers/convolutional';\nimport {DepthwiseConv2D, DepthwiseConv2DLayerConfig} from './layers/convolutional_depthwise';\nimport {Activation, ActivationLayerConfig, Dense, DenseLayerConfig, Dropout, DropoutLayerConfig, Flatten, RepeatVector, RepeatVectorLayerConfig, Reshape, ReshapeLayerConfig} from './layers/core';\nimport {Embedding, EmbeddingLayerConfig} from './layers/embeddings';\nimport {Add, Average, Concatenate, ConcatenateLayerConfig, Maximum, Minimum, Multiply} from './layers/merge';\nimport {BatchNormalization, BatchNormalizationLayerConfig} from './layers/normalization';\nimport {ZeroPadding2D, ZeroPadding2DLayerConfig} from './layers/padding';\nimport {AveragePooling1D, AveragePooling2D, GlobalAveragePooling1D, GlobalAveragePooling2D, GlobalMaxPooling1D, GlobalMaxPooling2D, GlobalPooling2DLayerConfig, MaxPooling1D, MaxPooling2D, Pooling1DLayerConfig, Pooling2DLayerConfig} from './layers/pooling';\nimport {GRU, GRUCell, GRUCellLayerConfig, GRULayerConfig, LSTM, LSTMCell, LSTMCellLayerConfig, LSTMLayerConfig, RNN, RNNCell, RNNLayerConfig, SimpleRNN, SimpleRNNCell, SimpleRNNCellLayerConfig, SimpleRNNLayerConfig, StackedRNNCells, StackedRNNCellsConfig} from './layers/recurrent';\nimport {Bidirectional, BidirectionalLayerConfig, TimeDistributed, Wrapper, WrapperLayerConfig} from './layers/wrappers';\n\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Input Layer.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Inputs',\n * namespace: 'layers',\n * useDocsFrom: 'InputLayer',\n * configParamIndices: [0]\n * }\n */\nexport function inputLayer(config: InputLayerConfig): Layer {\n return new InputLayer(config);\n}\n\n// Advanced Activation Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ELU',\n * configParamIndices: [0]\n * }\n */\nexport function elu(config?: ELULayerConfig): Layer {\n return new ELU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'LeakyReLU',\n * configParamIndices: [0]\n * }\n */\nexport function leakyReLU(config?: LeakyReLULayerConfig): Layer {\n return new LeakyReLU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'Softmax',\n * configParamIndices: [0]\n * }\n */\nexport function softmax(config?: SoftmaxLayerConfig): Layer {\n return new Softmax(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ThresholdedReLU',\n * configParamIndices: [0]\n * }\n */\nexport function thresholdedReLU(config?: ThresholdedReLULayerConfig): Layer {\n return new ThresholdedReLU(config);\n}\n\n// Convolutional Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv1D',\n * configParamIndices: [0]\n * }\n */\nexport function conv1d(config: ConvLayerConfig): Layer {\n return new Conv1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2D',\n * configParamIndices: [0]\n * }\n */\nexport function conv2d(config: ConvLayerConfig): Layer {\n return new Conv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2DTranspose',\n * configParamIndices: [0]\n * }\n */\nexport function conv2dTranspose(config: ConvLayerConfig): Layer {\n return new Conv2DTranspose(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'SeparableConv2D',\n * configParamIndices: [0]\n * }\n */\nexport function separableConv2d(config: SeparableConvLayerConfig): Layer {\n return new SeparableConv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Cropping2D',\n * configParamIndices: [0]\n * }\n */\nexport function cropping2D(config: Cropping2DLayerConfig): Layer {\n return new Cropping2D(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'UpSampling2D',\n * configParamIndices: [0]\n * }\n */\nexport function upSampling2d(config: UpSampling2DLayerConfig): Layer {\n return new UpSampling2D(config);\n}\n\n// Convolutional(depthwise) Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'DepthwiseConv2D',\n * configParamIndices: [0]\n * }\n */\n\nexport function depthwiseConv2d(config: DepthwiseConv2DLayerConfig): Layer {\n return new DepthwiseConv2D(config);\n}\n\n// Basic Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Activation',\n * configParamIndices: [0]\n * }\n */\nexport function activation(config: ActivationLayerConfig): Layer {\n return new Activation(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dense',\n * configParamIndices: [0]\n * }\n */\nexport function dense(config: DenseLayerConfig): Layer {\n return new Dense(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dropout',\n * configParamIndices: [0]\n * }\n */\nexport function dropout(config: DropoutLayerConfig): Layer {\n return new Dropout(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Flatten',\n * configParamIndices: [0]\n * }\n */\nexport function flatten(config?: LayerConfig): Layer {\n return new Flatten(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'RepeatVector',\n * configParamIndices: [0]\n * }\n */\nexport function repeatVector(config: RepeatVectorLayerConfig): Layer {\n return new RepeatVector(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Reshape',\n * configParamIndices: [0]\n * }\n */\nexport function reshape(config: ReshapeLayerConfig): Layer {\n return new Reshape(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Embedding',\n * configParamIndices: [0]\n * }\n */\nexport function embedding(config: EmbeddingLayerConfig): Layer {\n return new Embedding(config);\n}\n\n// Merge Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Add',\n * configParamIndices: [0]\n * }\n */\nexport function add(config?: LayerConfig): Layer {\n return new Add(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Average',\n * configParamIndices: [0]\n * }\n */\nexport function average(config?: LayerConfig): Layer {\n return new Average(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Concatenate',\n * configParamIndices: [0]\n * }\n */\nexport function concatenate(config?: ConcatenateLayerConfig): Layer {\n return new Concatenate(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Maximum',\n * configParamIndices: [0]\n * }\n */\nexport function maximum(config?: LayerConfig): Layer {\n return new Maximum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Minimum',\n * configParamIndices: [0]\n * }\n */\nexport function minimum(config?: LayerConfig): Layer {\n return new Minimum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Multiply',\n * configParamIndices: [0]\n * }\n */\nexport function multiply(config?: LayerConfig): Layer {\n return new Multiply(config);\n}\n\n// Normalization Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Normalization',\n * namespace: 'layers',\n * useDocsFrom: 'BatchNormalization',\n * configParamIndices: [0]\n * }\n */\nexport function batchNormalization(config: BatchNormalizationLayerConfig):\n Layer {\n return new BatchNormalization(config);\n}\n\n// Padding Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Padding',\n * namespace: 'layers',\n * useDocsFrom: 'ZeroPadding2D',\n * configParamIndices: [0]\n * }\n */\nexport function zeroPadding2d(config?: ZeroPadding2DLayerConfig): Layer {\n return new ZeroPadding2D(config);\n}\n\n// Pooling Layers.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling1d(config: Pooling1DLayerConfig): Layer {\n return new AveragePooling1D(config);\n}\nexport function avgPool1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling2d(config: Pooling2DLayerConfig): Layer {\n return new AveragePooling2D(config);\n}\nexport function avgPool2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling1d(config: LayerConfig): Layer {\n return new GlobalAveragePooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling2d(config: GlobalPooling2DLayerConfig):\n Layer {\n return new GlobalAveragePooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling1d(config: LayerConfig): Layer {\n return new GlobalMaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling2d(config: GlobalPooling2DLayerConfig): Layer {\n return new GlobalMaxPooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling1d(config: Pooling1DLayerConfig): Layer {\n return new MaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling2d(config: Pooling2DLayerConfig): Layer {\n return new MaxPooling2D(config);\n}\n\n// Recurrent Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRU',\n * configParamIndices: [0]\n * }\n */\nexport function gru(config: GRULayerConfig): Layer {\n return new GRU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRUCell',\n * configParamIndices: [0]\n * }\n */\nexport function gruCell(config: GRUCellLayerConfig): RNNCell {\n return new GRUCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTM',\n * configParamIndices: [0]\n * }\n */\nexport function lstm(config: LSTMLayerConfig): Layer {\n return new LSTM(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTMCell',\n * configParamIndices: [0]\n * }\n */\nexport function lstmCell(config: LSTMCellLayerConfig): RNNCell {\n return new LSTMCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNN',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNN(config: SimpleRNNLayerConfig): Layer {\n return new SimpleRNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNNCell',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNNCell(config: SimpleRNNCellLayerConfig): RNNCell {\n return new SimpleRNNCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function rnn(config: RNNLayerConfig): Layer {\n return new RNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function stackedRNNCells(config: StackedRNNCellsConfig): RNNCell {\n return new StackedRNNCells(config);\n}\n\n// Wrapper Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'Bidirectional',\n * configParamIndices: [0]\n * }\n */\nexport function bidirectional(config: BidirectionalLayerConfig): Wrapper {\n return new Bidirectional(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'TimeDistributed',\n * configParamIndices: [0]\n * }\n */\nexport function timeDistributed(config: WrapperLayerConfig): Layer {\n return new TimeDistributed(config);\n}\n\n// Aliases for pooling.\nexport const globalMaxPool1d = globalMaxPooling1d;\nexport const globalMaxPool2d = globalMaxPooling2d;\nexport const maxPool1d = maxPooling1d;\nexport const maxPool2d = maxPooling2d;\n\nexport {Layer, input /* alias for tf.input */};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport {Tensor} from '@tensorflow/tfjs-core';\n\nimport * as losses from './losses';\nimport * as metrics from './metrics';\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryAccuracy'\n * }\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryCrossentropy'\n * }\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalAccuracy'\n * }\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalCrossentropy'\n * }\n */\nexport function categoricalCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'cosineProximity'\n * }\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.cosineProximity(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsoluteError'\n * }\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsoluteError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsolutePercentageError'\n * }\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function MAPE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function mape(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanSquaredError'\n * }\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function MSE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function mse(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport * as regularizers from './regularizers';\n// tslint:disable-next-line:max-line-length\nimport {L1Config, L1L2, L1L2Config, L2Config, Regularizer} from './regularizers';\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1l2(config?: L1L2Config): Regularizer {\n return new L1L2(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1(config?: L1Config): Regularizer {\n return regularizers.l1(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l2(config?: L2Config): Regularizer {\n return regularizers.l2(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {BaseCallback} from './base_callbacks';\nimport {Container} from './engine/container';\nimport {Model} from './engine/training';\n\nexport abstract class Callback extends BaseCallback {\n /** Instance of `keras.models.Model`. Reference of the model being trained. */\n model: Model = null;\n\n setModel(model: Container): void {\n if (!(model instanceof Model)) {\n throw new Error('model must be a Model, not some other Container');\n }\n this.model = model as Model;\n }\n}\n"],"names":["scalar","keep","tslib_1.__extends","tidy","tfc.sqrt","tfc.sum","tfc.mulStrict","serialization","tfc.clipByValue","tfc.mul","tfc.div","tfc.add","tfc.relu","tensor1d","tfc.min","tfc.max","math_utils.arrayProd","tfc.slice1d","tfc.slice2d","tfc.slice3d","tfc.slice4d","tfc.concat","tfc.concat1d","tfc.concat2d","tfc.concat3d","tfc.concat4d","tfc.tile","mean","tfc.randomNormal","tfc.matMul","tfc.gather","tfc.elu","tfc.abs","util","tfc.step","tfc.neg","tfc.randomUniform","tfc.sub","zeros","ones","mul","randomUniform","K.randomNormal","truncatedNormal","eye","linalg","tfc.variable","generic_utils.toSnakeCase","generic_utils.singletonOrArray","generic_utils.toList","variable_utils.countParamsInWeights","types_utils.normalizeShapeList","dispose","add","div","K.square","tfc.onesLike","tfc.maximum","tfc.mean","tfc.log","tfc.softplus","tfc.softmax","tfc.floor","K.flatten","tfc.oneHot","tfc.zerosLike","tfc.exp","K.cast","tfc.greater","tfc.equal","tfc.argMax","lossBinaryCrossentropy","mse","MSE","mae","MAE","mape","MAPE","categoricalCrossentropy","categoricalCrossentropyLoss","cosine","sparseCategoricalCrossentropy","sparseCategoricalCrossentropyLoss","train","generic_utils.toCamelCase","generic_utils.stringToDType","Tensor","generic_utils.unique","generic_utils.assert","generic_utils.reverseNumberCompare","layersVersion","generic_utils.pyListRepeat","deserializeLayer","generic_utils.isObjectEmpty","cast","K.expandDims","losses.meanSquaredError","losses.binaryCrossentropy","losses.categoricalCrossentropy","K.sliceAlongFirstAxis","tfc.tidy","K.gather","optimizers.getOptimizer","Optimizer","losses.get","Metrics.binaryAccuracy","Metrics.binaryCrossentropy","losses.sparseCategoricalCrossentropy","Metrics.sparseCategoricalAccuracy","Metrics.sparseCategoricalCrossentropy","Metrics.categoricalAccuracy","Metrics.categoricalCrossentropy","Metrics.get","K.concatAlongFirstAxis","tfc.keep","io","K.elu","tfc.selu","tfc.minimum","tfc.sigmoid","K.hardSigmoid","K.softsign","tfc.tanh","leakyRelu","elu","softmaxActivation","Softmax","sum","abs","tfc.transpose","tfc.conv1d","K.biasAdd","tfc.conv2d","generic_utils.checkArrayTypeAndLength","tfc.conv2dTranspose","tfc.separableConv2d","K.sliceAlongAxis","tfc.depthwiseConv2d","K.inTrainPhase","K.dropout","K.dot","K.batchFlatten","Activation","K.repeat","mathUtils.max","mathUtils.arrayProd","mathUtils.range","tfc.zeros","tfc.ones","K.concatenate","variance","tfc.batchNormalization2d","tfc.batchNormalization3d","tfc.batchNormalization4d","tfc.moments","math_utils.range","tfc.movingAverage","tfc.pad","tfc.maxPool","tfc.avgPool","tfc.squeeze","tfc.reverse","K.tile","math_utils.min","math_utils.max","tfc.dispose","K.sliceAlongLastAxis","generic_utils.checkStringTypeUnionValue","metrics.binaryAccuracy","metrics.binaryCrossentropy","metrics.categoricalAccuracy","metrics.categoricalCrossentropy","losses.cosineProximity","losses.meanAbsoluteError","losses.meanAbsolutePercentageError","regularizers.l1","regularizers.l2"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.min.js b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.min.js new file mode 100644 index 0000000..5f1e83f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/tf-layers.min.js @@ -0,0 +1,18 @@ +/** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ +!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@tensorflow/tfjs-core")):"function"==typeof define&&define.amd?define(["exports","@tensorflow/tfjs-core"],e):e(t.tf=t.tf||{},t.tf)}(this,function(t,e){"use strict";var n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])};function r(t,e){function r(){this.constructor=t}n(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}var i=Object.assign||function(t){for(var e,n=1,r=arguments.length;n0&&i[i.length-1])&&(6===a[0]||2===a[0])){o=0;continue}if(3===a[0]&&(!i||a[1]>i[0]&&a[1]e?1:0}(t,e)}function M(t){if(null==t)return t;for(var e=[],n=0,r=t;n=0),S(r>=n),Array.isArray(t)&&t.length>=n&&t.length<=r&&t.every(function(t){return typeof t===e})}function F(t,n){return e.tidy(function(){return e.sqrt(e.sum(e.mulStrict(t,t),n,!0))})}var _=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return r(e,t),e.prototype.getConfig=function(){return{}},e}(e.serialization.Serializable),B=function(t){function n(e){var n=t.call(this)||this;return n.defaultMaxValue=2,n.defaultAxis=0,n.maxValue=null!=e.maxValue?e.maxValue:n.defaultMaxValue,n.axis=null!=e.axis?e.axis:n.defaultAxis,n}return r(n,t),n.prototype.apply=function(t){var n=this;return e.tidy(function(){var r=F(t,n.axis),i=e.clipByValue(r,0,n.maxValue);return e.mul(t,e.div(i,e.add(g(u()),r)))})},n.prototype.getConfig=function(){return{maxValue:this.maxValue,axis:this.axis}},n.className="MaxNorm",n}(_);e.serialization.SerializationMap.register(B);var P=function(t){function n(e){var n=t.call(this)||this;return n.defaultAxis=0,n.axis=null!=e.axis?e.axis:n.defaultAxis,n}return r(n,t),n.prototype.apply=function(t){var n=this;return e.tidy(function(){return e.div(t,e.add(g(u()),F(t,n.axis)))})},n.prototype.getConfig=function(){return{axis:this.axis}},n.className="UnitNorm",n}(_);e.serialization.SerializationMap.register(P);var j=function(t){function n(){return null!==t&&t.apply(this,arguments)||this}return r(n,t),n.prototype.apply=function(t){return e.relu(t)},n.className="NonNeg",n}(_);e.serialization.SerializationMap.register(j);var U=function(t){function n(e){var n=t.call(this)||this;return n.defaultMinValue=0,n.defaultMaxValue=1,n.defaultRate=1,n.defaultAxis=0,n.minValue=null!=e.minValue?e.minValue:n.defaultMinValue,n.maxValue=null!=e.maxValue?e.maxValue:n.defaultMaxValue,n.rate=null!=e.rate?e.rate:n.defaultRate,n.axis=null!=e.axis?e.axis:n.defaultAxis,n}return r(n,t),n.prototype.apply=function(t){var n=this;return e.tidy(function(){var r=F(t,n.axis),i=e.add(e.mul(g(n.rate),e.clipByValue(r,n.minValue,n.maxValue)),e.mul(g(1-n.rate),r));return e.mul(t,e.div(i,e.add(g(u()),r)))})},n.prototype.getConfig=function(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}},n.className="MinMaxNorm",n}(_);e.serialization.SerializationMap.register(U);var W={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function V(t){return T(t)}function q(t,n){return void 0===n&&(n={}),O(t,e.serialization.SerializationMap.getMap().classNameMap,n,"constraint")}function Z(t){return null==t?null:"string"==typeof t?q({className:t in W?W[t]:t,config:{}}):t instanceof _?t:q(t)}var J=Object.freeze({maxNorm:function(t){return new B(t)},unitNorm:function(t){return new P(t)},nonNeg:function(){return new j},minMaxNorm:function(t){return new U(t)}}),K=new Map,H=["channelsFirst","channelsLast"];function G(t){E(H,"DataFormat",t)}var X=["valid","same","causal"];function $(t){E(X,"PaddingMode",t)}var Y=["max","avg"];var Q=[],tt="/";function et(t,e){Q.push(t);try{var n=e();return Q.pop(),n}catch(t){throw Q.pop(),t}}function nt(t){if(!at(t))throw new Error("Not a valid tensor name: '"+t+"'");return(0===Q.length?"":Q.join(tt)+tt)+t}function rt(t){if(!at(t))throw new Error("Not a valid tensor name: '"+t+"'");K.has(t)||K.set(t,0);var e=K.get(t);if(K.set(t,K.get(t)+1),e>0){var n=t+"_"+e;return K.set(n,1),n}return t}var it=new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/);function at(t){return!!t.match(it)}function ot(t,e,n){null==e&&(e=0),null==n&&(n=t.length);for(var r=1,i=e;i2e3&&console.warn("Orthogonal initializer is being called on a matrix with more than 2000 ("+t[0]*t[1]+") elements: Slowness may result.");var n=bt(t[0]>t[1]?[t[1],t[0]]:t,0,1,"float32"),i=e.linalg.gramSchmidt(n);return t[0]>t[1]&&(i=i.transpose()),e.mul(g(r.gain),i)})},n.prototype.getConfig=function(){return{gain:this.gain,seed:this.seed}},n.className="Orthogonal",n}(Lt);e.serialization.SerializationMap.register(Ut);var Wt={constant:"Constant",glorotNormal:"GlorotNormal",glorotUniform:"GlorotUniform",heNormal:"HeNormal",identity:"Identity",leCunNormal:"LeCunNormal",ones:"Ones",orthogonal:"Orthogonal",randomNormal:"RandomNormal",randomUniform:"RandomUniform",truncatedNormal:"TruncatedNormal",varianceScaling:"VarianceScaling",zeros:"Zeros"};function Vt(t,n){return void 0===n&&(n={}),O(t,e.serialization.SerializationMap.getMap().classNameMap,n,"initializer")}function qt(t){return T(t)}function Zt(t){if("string"==typeof t){var e=t in Wt?Wt[t]:t;return"GlorotUniform"===e?new _t:"GlorotNormal"===e?new Bt:"HeNormal"===e?new Pt:"LeCunNormal"===e?new jt:Vt({className:e,config:{}})}return t instanceof Lt?t:Vt(t)}var Jt=Object.freeze({zeros:function(){return new Tt},ones:function(){return new Ot},constant:function(t){return new Rt(t)},randomUniform:function(t){return new Mt(t)},randomNormal:function(t){return new xt(t)},truncatedNormal:function(t){return new Et(t)},identity:function(t){return new Dt(t)},varianceScaling:function(t){return new Ft(t)},glorotUniform:function(t){return new _t(t)},glorotNormal:function(t){return new Bt(t)},heNormal:function(t){return new Pt(t)},leCunNormal:function(t){return new jt(t)},orthogonal:function(t){return new Ut(t)}});function Kt(t){return Array.isArray(t)&&Array.isArray(t[0])}function Ht(t){return 0===t.length?[]:Array.isArray(t[0])?t:[t]}function Gt(t){var e;if(Array.isArray(t)){if(1!==t.length)throw new v("Expected Tensor length to be 1; got "+t.length);e=t[0]}else e=t;return e}function Xt(t){if(Array.isArray(t)&&Array.isArray(t[0])){if(1===t.length)return(t=t)[0];throw new v("Expected exactly 1 Shape; got "+t.length)}return t}function $t(t){for(var e=0,n=0,r=t;n1)throw new y("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if(0===this.inboundNodes.length)throw new y("Layer "+this.name+" is not connected, no input to return.");return I(this.getNodeAtIndex(0,"input").inputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"output",{get:function(){if(0===this.inboundNodes.length)throw new y("Layer "+this.name+" has no inbound nodes.");if(this.inboundNodes.length>1)throw new y("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return I(this.getNodeAtIndex(0,"output").outputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"losses",{get:function(){return this._losses},enumerable:!0,configurable:!0}),n.prototype.calculateLosses=function(){return this.losses.map(function(t){return t()})},Object.defineProperty(n.prototype,"updates",{get:function(){return this._updates},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"built",{get:function(){return this._built},set:function(t){this._built=t},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"trainableWeights",{get:function(){return this.trainable?this._trainableWeights:[]},set:function(t){this._trainableWeights=t},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this._nonTrainableWeights:this._trainableWeights.concat(this._nonTrainableWeights)},set:function(t){this._nonTrainableWeights=t},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"weights",{get:function(){return this.trainableWeights.concat(this.nonTrainableWeights)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"stateful",{get:function(){return this._stateful},enumerable:!0,configurable:!0}),n.prototype.assertInputCompatibility=function(t){if(t=N(t),null!=this.inputSpec&&0!==this.inputSpec.length){var e=N(this.inputSpec);if(t.length!==e.length)throw new v("Layer "+this.name+" expects "+e.length+" inputs, but it received "+t.length+" input tensors. Input received: "+t);for(var n=0;n=0?o[u]:o[o.length+u];if(null!=l&&-1===[l,null].indexOf(h))throw new v("Input "+n+" is incompatible with layer "+this.name+": expected axis "+u+" of input shape to have value "+l+" but got shape "+o+".")}}if(null!=i.shape)for(var p=0;p0&&Array.isArray(d[0])?d.map(function(r,i){return new re("float32",r,n,N(t),e,n.name,i)}):new re("float32",d,n,N(t),e,n.name),n.addInboundNode(t,g,null,null,f,d,e),null!=n.activityRegularizer)throw new b("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return g})},n.prototype.warnOnIncompatibleInputShape=function(t){if(null!=this.batchInputShape)if(t.length!==this.batchInputShape.length)console.warn("The rank of the input tensor provided (shape: "+JSON.stringify(t)+") does not match that of the batchInputShape ("+JSON.stringify(this.batchInputShape)+") of the layer "+this.name);else{var e=!1;this.batchInputShape.forEach(function(n,r){null!=n&&null!=t[r]&&t[r]!==n&&(e=!0)}),e&&console.warn("The shape of the input tensor ("+JSON.stringify(t)+") does not match the expectation of layer "+this.name+": "+JSON.stringify(this.batchInputShape))}},Object.defineProperty(n.prototype,"outputShape",{get:function(){if(null==this.inboundNodes||0===this.inboundNodes.length)throw new y("The layer "+this.name+" has never been called and thus has no defined output shape.");for(var t=[],e=0,n=this.inboundNodes;e0&&(r=r.slice(0,r.length-1)+" "),r=(r+=t[i]).slice(0,e[i]),r+=" ".repeat(e[i]-r.length);n(r)}function Je(t,e,n){var r;try{r=JSON.stringify(t.outputShape)}catch(t){r="multiple"}Ze([t.name+" ("+t.getClassName()+")",r,t.countParams().toString()],e,n)}function Ke(t,e,n,r){var i;try{i=JSON.stringify(t.outputShape)}catch(t){i="multiple"}for(var a=[],o=0,s=t.inboundNodes;o0&&-1===n.indexOf(u)))for(var l=0;l1 nodes"),S(0===l,"input layer has >1 tensors"),r.inputLayers.push(s),r.inputLayersNodeIndices.push(u),r.inputLayersTensorIndices.push(l)}r.inputNames=[],r.outputNames=[],r.feedInputShapes=[],r.feedInputNames=[],r.feedOutputNames=[];for(var f=0;f=0;)i.splice(i.indexOf(u),1);I.push(u)}},A=[],C=[],L=0,T=r.outputs;Lr?1:0});for(var H=0,G=K;H0)throw new v("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];for(var t=[],e=0,n=this.layers;e0)throw new v(p.length+" of "+r+" weights are not set: "+p);ee(l)}(t,this.layers):function(t,n,r){void 0===r&&(r=!1);for(var i=t.keras_version,a=(t.backend,n.map(function(t){return t.name})),o={},s=0,u=n;s1)for(var s=0,u=o;s0){for(var f=[],d=0;d0&&t.apply(I(a),r)}function o(t){var r=t.name,a=He(t,null!=e.customObjects?e.customObjects:{});n[r]=a;for(var o=0,s=t.inboundNodes;o0)a=!0;else if(an(t)){for(var o in t)if(t.hasOwnProperty(o)){a=!0;break}}else a=!0;if(a)throw new v("Error when checking model "+i+" expected no data, but got "+t)}return[]}if(null==t)return e.map(function(t){return null});var s;if(an(t)){t=t,s=[];for(var u=0,l=e;u1)throw new v("The model "+i+" expects "+e.length+" Tensor(s), but only received one Tensor. Found: Tensor with shape "+t.shape);s=[t]}for(var p=0;p=0&&d!==g)throw new v("Error when checking "+i+": expected "+e[p]+" to have shape ["+n[p]+"], but got array with shape ["+c.shape+"].")}}return s}function sn(t,e){for(var n=[],r=0,i=null;r=t&&(i=t),n.push([r,i]),r=i;return n}function un(t,e,n){return null==t?[null]:Array.isArray(t)?t.map(function(t){return ft(t,e,n-e)}):ft(t,e,n-e)}function ln(t,n){return e.tidy(function(){return null==t?null:Array.isArray(t)?t.map(function(t){return ln(t,n)}):zt(t,"int32"===n.dtype?n:n.toInt())})}function hn(t,e,n,r,i){var a;if(void 0===r&&(r=!0),void 0===i&&(i=""),Array.isArray(t)){if(t.length!==e.length)throw new v("Error when checking model "+i+": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see "+e.length+" Tensor(s), but instead got "+t.length+" Tensors(s).");a=t}else{if(e.length>1)throw new v("The model expects "+e.length+" "+i+" Tensors, but only received one Tensor. Found: array with shape "+JSON.stringify(t.shape)+".");a=[t]}if(null!=n)for(var o=0;o1||1===s.length&&s[0].inboundLayers.length>1){e=!1;break}r.push.apply(r,s)}if(e)for(var u=0,l=t.layers;u1&&(n.metricsTensors.push([e,t]),n.metricsNames.push(n.outputNames[t]+"_loss"))}});var f=function(t,e){if(null==t||Array.isArray(t)&&0===t.length)return e.map(function(t){return[]});if(Array.isArray(t))return e.map(function(e){return t});if(null!=t){for(var n=[],r=0,i=e;r1&&(e=n.outputNames[t]+"_"+e),n.metricsNames.push(e),n.metricsTensors.push([r,t])}(t,r,l)},s=0,u=e;s0){var h=[];throw e.forEach(function(e,n){null==e&&h.push(t[n])}),new v("Cannot find SymbolicTensors for output name(s): "+JSON.stringify(h))}return e},n.prototype.predictLoop=function(t,n,r){var i=this;return void 0===n&&(n=32),void 0===r&&(r=!1),e.tidy(function(){var a=i.checkNumSamples(t);if(r)throw new b("Verbose predictLoop() is not implemented yet.");for(var o=sn(a,n),s=[],u=function(n){var r=e.tidy(function(){var e=o[n][0],r=o[n][1],a=un(t,e,r),s=[];if(Array.isArray(a))for(var u=0;u1)throw new v("All input Tensors (x) should have the same number of samples. Got array shapes: "+JSON.stringify(t.map(function(t){return t.shape})));if(a.length>1)throw new v("All target Tensors (y) should have the same number of samples. Got array shapes: "+JSON.stringify(n.map(function(t){return t.shape})));if(i.length>0&&a.length>0&&!e.util.arraysEqual(i,a))throw new v("Input Tensors should have the same number of samples as target Tensors. Found "+i[0]+" input sample(s) and "+a[0]+" target sample(s).")}(t=on(t,this.feedInputNames,this.feedInputShapes,!1,"input"),n=on(n,this.feedOutputNames,a,!1,"target")),function(t,e,n){for(var r=[me,Ce,Ne],i=0;i0&&t[0].shape[0]%i!=0)throw new v("In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size "+i+". Found: "+t[0].shape[0]+" sample(s).");return[t,n,null]},n.prototype.fitLoop=function(t,n,r,i,s,u,l,h,p,c,f,d,g,y){return a(this,void 0,void 0,function(){var a,m,w,z,S,k,I,N=this;return o(this,function(A){switch(A.label){case 0:if(null==i&&(i=32),null==s&&(s=1),null==c&&(c=!0),null==d&&(d=0),a=!1,null!=h&&null!=p&&(a=!0),null!=y&&(a=!0,null==g))throw new v("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");if(null!=(m=this.checkNumSamples(n,i,g,"steps_per_epoch"))&&(w=ht(0,m)),this.history=new de,l=(l=null==l?[new fe]:[new fe].concat(l)).concat([this.history]),u>0)throw new b("Verbose mode is not implemented yet.");return(z=new ce(l)).setModel(this),z.setParams({epochs:s,initialEpoch:d,steps:g,verbose:u,doValidation:a,metrics:f}),[4,z.onTrainBegin()];case 1:A.sent(),this.stopTraining=!1,S=function(s){var u,l,f,d,y;return o(this,function(v){switch(v.label){case 0:return[4,z.onEpochBegin(s)];case 1:if(v.sent(),u={},null==g)return[3,2];throw new b("stepsPerEpoch mode is not implemented yet.");case 2:if("batch"===c)throw new b("batch shuffling is not implemneted yet");c&&e.util.shuffle(w),l=e.tensor1d(w),f=sn(m,i),d=function(s){var c;return o(this,function(o){switch(o.label){case 0:return c={},[4,z.onBatchBegin(s,c)];case 1:return o.sent(),e.tidy(function(){var o=f[s][0],d=f[s][1],g=ft(l,o,d-o);c.batch=s,c.size=d-o;for(var y=ln(n,g),m=t(y),v=0;v1)i+="_"+k(t.slice(0,n),r);e.push(i)}return e},n.prototype.makeTestFunction=function(){var t=this;this.testFunction=function(n){return e.tidy(function(){for(var r,i=[],a=n.slice(0,t.inputs.length),o=n.slice(t.inputs.length,t.inputs.length+t.outputs.length),s=[],u=0;u0){if(l=!0,2!==r.validationData.length)throw 3===r.validationData.length?new b("validationData including sample weights is not supported yet."):new v("When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; "+r.validationData+" is invalid.");h=r.validationData[0],p=r.validationData[1],d=this.standardizeUserData(h,p,!0,i),h=d[0],p=d[1],c=h.concat(p)}else null!=r.validationSplit&&r.validationSplit>0&&r.validationSplit<1?(l=!0,g=Math.floor(s[0].shape[0]*(1-r.validationSplit)),y=s[0].shape[0],h=un(s,g,y),s=un(s,0,g),p=un(u,g,y),u=un(u,0,g),f=!0,c=h.concat(p)):null!=r.validationSteps&&(l=!0);return m=s.concat(u),this.checkTrainableWeightsConsistency(),w=function(t){var n=t.slice(0,C.inputs.length),r=t.slice(C.inputs.length,C.inputs.length+C.outputs.length),i=[],a=C.collectedTrainableWeights.map(function(t){return t.read()});return[C.optimizer.minimize(function(){for(var t=[],a=0;a1)throw new v("Found more than one ("+r.length+") save handlers for URL '"+t+"'");t=r[0]}if(null==t.save)throw new v("Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return[4,e.io.encodeWeights(this.getNamedWeights(n))];case 1:return i=o.sent(),a=!1,s=null,u=this.toJSON(s,a),[2,t.save({modelTopology:u,weightData:i.data,weightSpecs:i.specs})]}})})},n.className="Model",n}(Ye);function cn(t){return a(this,void 0,void 0,function(){var n;return o(this,function(r){if("string"==typeof t){if(0===(n=e.io.getLoadHandlers(t)).length)n.push(e.io.browserHTTPRequest(t));else if(n.length>1)throw new v("Found more than one ("+n.length+") load handlers for URL '"+t+"'");t=n[0]}return[2,function(t,n){return a(this,void 0,void 0,function(){var r,i,a,s,u;return o(this,function(o){switch(o.label){case 0:if(null==t.load)throw new v("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");return[4,t.load()];case 1:if(r=o.sent(),null!=(i=r.modelTopology).model_config&&(i=i.model_config),a=He(function t(e,n){if(null===e)return null;if("string"==typeof e)return C(e);if("number"==typeof e||"boolean"==typeof e)return e;if(e instanceof Array){for(var r=[],i=e.length,a=0;a0)&&(n=e.sourceLayer,r=e.nodeIndex),0===n.inboundNodes.length)return[e];var i=n.inboundNodes[r];if(0===i.inboundLayers.length)return i.inputTensors;for(var a=[],o=0;o 0 but got "+JSON.stringify(t.filters))},n}(qn),Jn=function(t){function e(n){var r=t.call(this,2,n)||this;return e.verifyConfig(n),r}return r(e,t),e.prototype.getConfig=function(){var e=t.prototype.getConfig.call(this);return delete e.rank,e},e.verifyConfig=function(t){if("number"!=typeof t.kernelSize&&!D(t.kernelSize,"number",1,2))throw new v("Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received "+JSON.stringify(t.kernelSize)+".")},e.className="Conv2D",e}(Zn);e.serialization.SerializationMap.register(Jn);var Kn=function(t){function n(e){var n=t.call(this,e)||this;if(n.inputSpec=[new ne({ndim:4})],"same"!==n.padding&&"valid"!==n.padding)throw new v("Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode "+n.padding);return n}return r(n,t),n.prototype.build=function(t){if(4!==(t=Xt(t)).length)throw new v("Input should have rank 4; Received input shape: "+JSON.stringify(t));var e="channelsFirst"===this.dataFormat?1:t.length-1;if(null==t[e])throw new v("The channel dimension of the inputs should be defined. Found `None`.");var n,r=t[e],i=this.kernelSize.concat([this.filters,r]);this.kernel=this.addWeight("kernel",i,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new ne({ndim:4,axes:(n={},n[e]=r,n)})],this.built=!0},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){var n=Gt(t);if(4!==n.shape.length)throw new v("Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-"+n.shape.length);var i,a,o=n.shape,s=o[0];"channelsFirst"===r.dataFormat?(i=2,a=3):(i=1,a=2);var u=o[i],l=o[a],h=r.kernelSize[0],p=r.kernelSize[1],c=r.strides[0],f=r.strides[1],d=[s,Wn(u,c,h,r.padding),Wn(l,f,p,r.padding),r.filters];"channelsLast"!==r.dataFormat&&(n=e.transpose(n,[0,2,3,1]));var g=e.conv2dTranspose(n,r.kernel.read(),d,r.strides,r.padding);return"channelsLast"!==r.dataFormat&&(g=e.transpose(g,[0,3,1,2])),null!=r.bias&&(g=kt(g,r.bias.read(),r.dataFormat)),null!=r.activation&&(g=r.activation.apply(g)),g})},n.prototype.computeOutputShape=function(t){var e,n,r,i=(t=Xt(t)).slice();"channelsFirst"===this.dataFormat?(e=1,n=2,r=3):(e=3,n=1,r=2);var a=this.kernelSize[0],o=this.kernelSize[1],s=this.strides[0],u=this.strides[1];return i[e]=this.filters,i[n]=Wn(i[n],s,a,this.padding),i[r]=Wn(i[r],u,o,this.padding),i},n.prototype.getConfig=function(){var e=t.prototype.getConfig.call(this);return delete e.dilationRate,e},n.className="Conv2DTranspose",n}(Jn);e.serialization.SerializationMap.register(Kn);var Hn=function(t){function e(e){return t.call(this,2,e)||this}return r(e,t),e.className="SeparableConv2D",e}(function(t){function n(e,n){var r=t.call(this,e,n)||this;if(r.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",r.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",r.depthwiseKernel=null,r.pointwiseKernel=null,null==n.filters)throw new v("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(null!=n.kernelInitializer||null!=n.kernelRegularizer||null!=n.kernelConstraint)throw new v("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(null!=n.padding&&"same"!==n.padding&&"valid"!==n.padding)throw new v("SeparableConv"+r.rank+"D supports only padding modes: 'same' and 'valid', but received "+JSON.stringify(n.padding));return r.depthMultiplier=null==n.depthMultiplier?1:n.depthMultiplier,r.depthwiseInitializer=Zt(n.depthwiseInitializer||r.DEFAULT_DEPTHWISE_INITIALIZER),r.depthwiseRegularizer=Pn(n.depthwiseRegularizer),r.depthwiseConstraint=Z(n.depthwiseConstraint),r.pointwiseInitializer=Zt(n.depthwiseInitializer||r.DEFAULT_POINTWISE_INITIALIZER),r.pointwiseRegularizer=Pn(n.pointwiseRegularizer),r.pointwiseConstraint=Z(n.pointwiseConstraint),r}return r(n,t),n.prototype.build=function(t){if((t=Xt(t)).length1)throw new v("Can not merge tensors with different batch sizes. Got tensors with shapes: "+JSON.stringify(t)+".");for(var i=null==t[0]?null:t[0].slice(1),a=1;a1){var v=ht(1,u).concat([0]);n.push(e.transpose(f,v)),h=!0}else n.push(f)}var b=r.mergeFunction(n),w=b.rank;if(h)if(null==w){var z=b.shape;y=[g=z[z.length-1]].concat(z.slice(0,z.length-1));b=e.transpose(b.reshape([-1,g]),[1,0]).reshape(y)}else if(w>1){v=[w-1].concat(ht(0,w-1));b=e.transpose(b,v)}return b}return r.mergeFunction(t)})},n.prototype.computeOutputShape=function(t){var e;e=null==(t=t)[0]?null:t[0].slice(1);for(var n=1;n1)throw new v("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(t))}},n.prototype.mergeFunction=function(t){var n=this;return e.tidy(function(){return yt(t,n.axis)})},n.prototype.computeOutputShape=function(t){if(!Array.isArray(t)||!Array.isArray(t[0]))throw new v("A `Concatenate` layer should be called on a list of inputs.");for(var e=t,n=e[0].slice(),r=this.axis<0?n.length+this.axis:this.axis,i=0,a=e.slice(1);i=0?this.axis:this.axis+t.length,n=t[e];if(null==n)throw new v("Axis "+e+" of input tensor should have a defined dimension but the layer received an input with shape "+JSON.stringify(t)+".");this.inputSpec=[new ne({ndim:t.length,axes:(r={},r[e]=n,r)})];var r,i=[n];this.scale&&(this.gamma=this.addWeight("gamma",i,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",i,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",i,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",i,null,this.movingVarianceInitializer,null,!1),this.built=!0},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){var i=null!=n.training&&n.training,a=Gt(t),o=a.shape,s=o.length,u=ht(0,s),l=r.axis>=0?r.axis:r.axis+s;u.splice(l,1);var h=z(1,s);h[l]=o[l];var p=u.slice();p.sort();var c=!e.util.arraysEqual(p,ht(0,s).slice(0,s-1));if(!i)return function(){if(c){var t=r.movingMean.read().reshape(h),e=r.movingVariance.read().reshape(h),n=r.center?r.beta.read().reshape(h):null,i=r.scale?r.gamma.read().reshape(h):null;return fr(a,t,e,n,i,r.epsilon)}return fr(a,r.movingMean.read(),r.movingVariance.read(),null==r.beta?null:r.beta.read(),null==r.gamma?null:r.gamma.read(),r.epsilon)}();var f=dr(a,r.gamma.read(),r.beta.read(),u,r.epsilon),d=f[0],y=f[1],m=f[2],v=ot(u.map(function(t){return a.shape[t]})),b=m.mul(g(v/(v-(1+r.epsilon))));return function(){r.stepCount++;var t=e.movingAverage(r.movingMean.read(),y,r.momentum,r.stepCount);r.movingMean.write(t);var n=e.movingAverage(r.movingVariance.read(),b,r.momentum,r.stepCount);r.movingVariance.write(n)}(),d})},n.prototype.getConfig=function(){var e={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:qt(this.betaInitializer),gammaInitializer:qt(this.gammaInitializer),movingMeanInitializer:qt(this.movingMeanInitializer),movingVarianceInitializer:qt(this.movingVarianceInitializer),betaRegularizer:_n(this.betaRegularizer),gammaRegularizer:_n(this.gammaRegularizer),betaConstraint:V(this.betaConstraint),gammaConstraint:V(this.gammaConstraint)},n=t.prototype.getConfig.call(this);return Object.assign(e,n),e},n.className="BatchNormalization",n}(se);e.serialization.SerializationMap.register(gr);var yr=function(t){function n(e){var n=this;if(null==e&&(e={}),(n=t.call(this,e)||this).dataFormat=null==e.dataFormat?"channelsLast":e.dataFormat,null==e.padding)n.padding=[[1,1],[1,1]];else if("number"==typeof e.padding)n.padding=[[e.padding,e.padding],[e.padding,e.padding]];else{if(e.padding=e.padding,2!==e.padding.length)throw new v("ZeroPadding2D expects padding to be a length-2 array, but received a length-"+e.padding.length+" array.");var r=void 0,i=void 0;if("number"==typeof e.padding[0])r=[e.padding[0],e.padding[0]],i=[e.padding[1],e.padding[1]];else{if(e.padding=e.padding,2!==e.padding[0].length)throw new v("ZeroPadding2D expects height padding to be a length-2 array, but received a length-"+e.padding[0].length+" array.");if(r=e.padding[0],2!==e.padding[1].length)throw new v("ZeroPadding2D expects width padding to be a length-2 array, but received a length-"+e.padding[1].length+" array.");i=e.padding[1]}n.padding=[r,i]}return n.inputSpec=[new ne({ndim:4})],n}return r(n,t),n.prototype.computeOutputShape=function(t){var e,n;return t=Xt(t),"channelsFirst"===this.dataFormat?(e=null!=t[2]&&t[2]>=0?t[2]+this.padding[0][0]+this.padding[0][1]:null,n=null!=t[3]&&t[3]>=0?t[3]+this.padding[1][0]+this.padding[1][1]:null,[t[0],t[1],e,n]):(e=null!=t[1]&&t[1]>=0?t[1]+this.padding[0][0]+this.padding[0][1]:null,n=null!=t[2]&&t[2]>=0?t[2]+this.padding[1][0]+this.padding[1][1]:null,[t[0],e,n,t[3]])},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){return n=Gt(t),i=r.padding,a=r.dataFormat,e.tidy(function(){if(4!==n.rank)throw new v("temporalPadding expects input tensor to be 4-D, but received a "+n.rank+"-D tensor.");if(null==i&&(i=[[1,1],[1,1]]),2!==i.length||2!==i[0].length||2!==i[1].length)throw new v("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(null==a&&(a="channelsLast"),"channelsLast"!==a&&"channelsFirst"!==a)throw new v("Unknown data format: "+a+". Supported data formats are 'channelsLast' and 'channelsFirst.");var t;return t="channelsFirst"===a?[[0,0],[0,0],i[0],i[1]]:[[0,0],i[0],i[1],[0,0]],e.pad(n,t)});var n,i,a})},n.prototype.getConfig=function(){var e={padding:this.padding,dataFormat:this.dataFormat},n=t.prototype.getConfig.call(this);return Object.assign(e,n),e},n.className="ZeroPadding2D",n}(se);function mr(t,n,r,i,a,o){return e.tidy(function(){var s;G(a),E(Y,"PoolMode",o),$(i),null==r&&(r=[1,1]),null==i&&(i="valid"),null==a&&(a="channelsLast"),null==o&&(o="max"),t=Vn(t,a);var u="same"===i?"same":"valid";return s="max"===o?e.maxPool(t,n,r,u):e.avgPool(t,n,r,u),"channelsFirst"===a&&(s=e.transpose(s,[0,3,1,2])),s})}e.serialization.SerializationMap.register(yr);var vr=function(t){function n(e){var n=this;if(null==e.poolSize&&(e.poolSize=2),n=t.call(this,e)||this,"number"==typeof e.poolSize)n.poolSize=[e.poolSize];else{if(!Array.isArray(e.poolSize)||1!==e.poolSize.length||"number"!=typeof e.poolSize[0])throw new v("poolSize for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(e.poolSize));n.poolSize=e.poolSize}if(null==e.strides)n.strides=n.poolSize;else if("number"==typeof e.strides)n.strides=[e.strides];else{if(!Array.isArray(e.strides)||1!==e.strides.length||"number"!=typeof e.strides[0])throw new v("strides for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(e.strides));n.strides=e.strides}return n.padding=null==e.padding?"valid":e.padding,$(n.padding),n.inputSpec=[new ne({ndim:3})],n}return r(n,t),n.prototype.computeOutputShape=function(t){var e=Un((t=Xt(t))[1],this.poolSize[0],this.padding,this.strides[0]);return[t[0],e,t[2]]},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){r.invokeCallHook(t,n),t=ct(Gt(t),2);var i=r.poolingFunction(Gt(t),[r.poolSize[0],1],[r.strides[0],1],r.padding,"channelsLast");return e.squeeze(i,[2])})},n.prototype.getConfig=function(){var e={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=t.prototype.getConfig.call(this);return Object.assign(e,n),e},n}(se),br=function(t){function e(e){return t.call(this,e)||this}return r(e,t),e.prototype.poolingFunction=function(t,e,n,r,i){return G(i),$(r),mr(t,e,n,r,i,"max")},e.className="MaxPooling1D",e}(vr);e.serialization.SerializationMap.register(br);var wr=function(t){function e(e){return t.call(this,e)||this}return r(e,t),e.prototype.poolingFunction=function(t,e,n,r,i){return G(i),$(r),mr(t,e,n,r,i,"avg")},e.className="AveragePooling1D",e}(vr);e.serialization.SerializationMap.register(wr);var zr=function(t){function n(e){var n=this;if(null==e.poolSize&&(e.poolSize=[2,2]),(n=t.call(this,e)||this).poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize],null==e.strides)n.strides=n.poolSize;else if(Array.isArray(e.strides)){if(2!==e.strides.length)throw new v("If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length "+e.strides.length+".");n.strides=e.strides}else n.strides=[e.strides,e.strides];return n.padding=null==e.padding?"valid":e.padding,n.dataFormat=null==e.dataFormat?"channelsLast":e.dataFormat,G(n.dataFormat),$(n.padding),n.inputSpec=[new ne({ndim:4})],n}return r(n,t),n.prototype.computeOutputShape=function(t){t=Xt(t);var e="channelsFirst"===this.dataFormat?t[2]:t[1],n="channelsFirst"===this.dataFormat?t[3]:t[2];return e=Un(e,this.poolSize[0],this.padding,this.strides[0]),n=Un(n,this.poolSize[1],this.padding,this.strides[1]),"channelsFirst"===this.dataFormat?[t[0],t[1],e,n]:[t[0],e,n,t[3]]},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){return r.invokeCallHook(t,n),r.poolingFunction(Gt(t),r.poolSize,r.strides,r.padding,r.dataFormat)})},n.prototype.getConfig=function(){var e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=t.prototype.getConfig.call(this);return Object.assign(e,n),e},n}(se),Sr=function(t){function e(e){return t.call(this,e)||this}return r(e,t),e.prototype.poolingFunction=function(t,e,n,r,i){return G(i),$(r),mr(t,e,n,r,i,"max")},e.className="MaxPooling2D",e}(zr);e.serialization.SerializationMap.register(Sr);var kr=function(t){function e(e){return t.call(this,e)||this}return r(e,t),e.prototype.poolingFunction=function(t,e,n,r,i){return G(i),$(r),mr(t,e,n,r,i,"avg")},e.className="AveragePooling2D",e}(zr);e.serialization.SerializationMap.register(kr);var Ir=function(t){function e(e){var n=t.call(this,e)||this;return n.inputSpec=[new ne({ndim:3})],n}return r(e,t),e.prototype.computeOutputShape=function(t){return[t[0],t[2]]},e.prototype.call=function(t,e){throw new b},e}(se),Nr=function(t){function n(e){return t.call(this,e)||this}return r(n,t),n.prototype.call=function(t,n){return e.tidy(function(){var n=Gt(t);return e.mean(n,1)})},n.className="GlobalAveragePooling1D",n}(Ir);e.serialization.SerializationMap.register(Nr);var Ar=function(t){function n(e){return t.call(this,e)||this}return r(n,t),n.prototype.call=function(t,n){return e.tidy(function(){var n=Gt(t);return e.max(n,1)})},n.className="GlobalMaxPooling1D",n}(Ir);e.serialization.SerializationMap.register(Ar);var Cr=function(t){function e(e){var n=t.call(this,e)||this;return n.dataFormat=null==e.dataFormat?"channelsLast":e.dataFormat,G(n.dataFormat),n.inputSpec=[new ne({ndim:4})],n}return r(e,t),e.prototype.computeOutputShape=function(t){return t=t,"channelsLast"===this.dataFormat?[t[0],t[3]]:[t[0],t[1]]},e.prototype.call=function(t,e){throw new b},e.prototype.getConfig=function(){var e={dataFormat:this.dataFormat},n=t.prototype.getConfig.call(this);return Object.assign(e,n),e},e}(se),Lr=function(t){function n(){return null!==t&&t.apply(this,arguments)||this}return r(n,t),n.prototype.call=function(t,n){var r=this;return e.tidy(function(){var n=Gt(t);return"channelsLast"===r.dataFormat?e.mean(n,[1,2]):e.mean(n,[2,3])})},n.className="GlobalAveragePooling2D",n}(Cr);e.serialization.SerializationMap.register(Lr);var Tr=function(t){function n(){return null!==t&&t.apply(this,arguments)||this}return r(n,t),n.prototype.call=function(t,n){var r=this;return e.tidy(function(){var n=Gt(t);return"channelsLast"===r.dataFormat?e.max(n,[1,2]):e.max(n,[2,3])})},n.className="GlobalMaxPooling2D",n}(Cr);function Or(t,e,n,r){if(Array.isArray(t)){if(null!=e||null!=n)throw new v("When inputs is an array, neither initialState or constants should be provided");null!=r&&(n=t.slice(t.length-r,t.length),t=t.slice(0,t.length-r)),t.length>1&&(e=t.slice(1,t.length)),t=t[0]}function i(t){return null==t||Array.isArray(t)?t:[t]}return{inputs:t,initialState:e=i(e),constants:n=i(n)}}function Rr(t,n,r,i,a,o,s,u){void 0===i&&(i=!1),void 0===s&&(s=!1);var l=n.shape.length;if(l<3)throw new v("Input should be at least 3D, but is "+l+"D.");var h,p,c=[1,0].concat(ht(2,l));if(n=e.transpose(n,c),null!=a)throw new b("The rnn() function of the deeplearn.js backend does not support masking yet.");if(null!=o)throw new b("The rnn() functoin of the deeplearn.js backend does not support constants yet.");s&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),i&&(n=e.reverse(n,0));for(var f=r,d=n.shape[0],g=0;g1?vt(r,[1,t]):r}):n.cell.stateSize>1?[vt(r,[1,n.cell.stateSize])]:[r]})},Object.defineProperty(n.prototype,"trainableWeights",{get:function(){return this.trainable?this.cell.trainableWeights:[]},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights},enumerable:!0,configurable:!0}),n.prototype.getConfig=function(){var e={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};null!=this.numConstants&&(e.numConstants=this.numConstants);var n=this.cell.getConfig();e.cell={className:this.cell.getClassName(),config:n};var r=t.prototype.getConfig.call(this);return Object.assign(e,r),e},n.className="RNN",n}(se);e.serialization.SerializationMap.register(Mr);var xr=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return r(e,t),e}(se),Er=function(t){function n(e){var n=t.call(this,e)||this;return n.DEFAULT_ACTIVATION="tanh",n.DEFAULT_KERNEL_INITIALIZER="glorotNormal",n.DEFAULT_RECURRENT_INITIALIZER="orthogonal",n.DEFAULT_BIAS_INITIALIZER="zeros",n.units=e.units,n.activation=Tn(null==e.activation?n.DEFAULT_ACTIVATION:e.activation),n.useBias=null==e.useBias||e.useBias,n.kernelInitializer=Zt(e.kernelInitializer||n.DEFAULT_KERNEL_INITIALIZER),n.recurrentInitializer=Zt(e.recurrentInitializer||n.DEFAULT_RECURRENT_INITIALIZER),n.biasInitializer=Zt(e.biasInitializer||n.DEFAULT_BIAS_INITIALIZER),n.kernelRegularizer=Pn(e.kernelRegularizer),n.recurrentRegularizer=Pn(e.recurrentRegularizer),n.biasRegularizer=Pn(e.biasRegularizer),n.kernelConstraint=Z(e.kernelConstraint),n.recurrentConstraint=Z(e.recurrentConstraint),n.biasConstraint=Z(e.biasConstraint),n.dropout=ut([1,lt([0,null==e.dropout?0:e.dropout])]),n.recurrentDropout=ut([1,lt([0,null==e.recurrentDropout?0:e.recurrentDropout])]),n.stateSize=n.units,n.dropoutMask=null,n.recurrentDropoutMask=null,n}return r(n,t),n.prototype.build=function(t){t=Xt(t),this.kernel=this.addWeight("kernel",[t[t.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){if(2!==(t=t).length)throw new v("SimpleRNNCell expects 2 input Tensors, got "+t.length+".");var i=t[1];t=t[0];var a,o=null!=n.training&&n.training;01){for(var o=[],s=0;s= 3D, but received input shape "+JSON.stringify(e));this.inputSpec=[{shape:e}];var n=[e[0]].concat(e.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),t.prototype.build.call(this,e)},n.prototype.computeOutputShape=function(t){var e=[(t=Xt(t))[0]].concat(t.slice(2)),n=this.layer.computeOutputShape(e),r=t[1];return[n[0],r].concat(n.slice(1))},n.prototype.call=function(t,n){var r=this;return e.tidy(function(){return Rr(function(t,e){return[r.layer.call(t,n),[]]},t=Gt(t),[],!1,null,null,!1,t.shape[1])[1]})},n.className="TimeDistributed",n}(Wr);e.serialization.SerializationMap.register(Vr);var qr=["sum","mul","concat","ave"];var Zr=function(t){function n(e){var n,r=t.call(this,e)||this,i=e.layer.getConfig();if(r.forwardLayer=He({className:e.layer.getClassName(),config:i}),i.goBackwards=!0!==i.goBackwards,r.backwardLayer=He({className:e.layer.getClassName(),config:i}),r.forwardLayer.name="forward_"+r.forwardLayer.name,r.backwardLayer.name="backward_"+r.backwardLayer.name,n=e.mergeMode,E(qr,"BidirectionalMergeMode",n),r.mergeMode=e.mergeMode,e.weights)throw new b("weights support is not implemented for Bidirectional layer yet.");return r._stateful=e.layer.stateful,r.returnSequences=e.layer.returnSequences,r.returnState=e.layer.returnState,r.supportsMasking=!0,r._trainable=!0,r.inputSpec=e.layer.inputSpec,r.numConstants=null,r}return r(n,t),Object.defineProperty(n.prototype,"trainable",{get:function(){return this._trainable},set:function(t){this._trainable=t,null!=this.forwardLayer&&(this.forwardLayer.trainable=t),null!=this.backwardLayer&&(this.backwardLayer.trainable=t)},enumerable:!0,configurable:!0}),n.prototype.getWeights=function(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())},n.prototype.setWeights=function(t){var e=t.length,n=Math.floor(e/2);this.forwardLayer.setWeights(t.slice(0,n)),this.backwardLayer.setWeights(t.slice(n))},n.prototype.computeOutputShape=function(t){var e,n,r,i=this.forwardLayer.computeOutputShape(t);return Array.isArray(i)&&Array.isArray(i[0])||(i=[i]),i=i,this.returnState?(r=i.slice(1),e=i[0]):e=i[0],e=e,"concat"===this.mergeMode?(e[e.length-1]*=2,n=[e]):n=null==this.mergeMode?[e,e.slice()]:[e],this.returnState?null==this.mergeMode?n.concat(r).concat(r.slice()):[e].concat(r).concat(r.slice()):I(n)},n.prototype.apply=function(e,n){var r=null==n?null:n.initialState,i=null==n?null:n.constants;null==n&&(n={});var a=Or(e,r,i,this.numConstants);if(e=a.inputs,r=a.initialState,i=a.constants,Array.isArray(e)&&(r=e.slice(1),e=e[0]),(null==r||0===r.length)&&null==i)return t.prototype.apply.call(this,e,n);var o=[],s=[];if(null!=r){var u=r.length;if(u%2>0)throw new v("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");n.initialState=r,o.push.apply(o,r);var l=r.map(function(t){return new ne({shape:t.shape})});this.forwardLayer.stateSpec=l.slice(0,u/2),this.backwardLayer.stateSpec=l.slice(u/2),s.push.apply(s,l)}if(null!=i)throw new b("Support for constants in Bidirectional layers is not implemented yet.");for(var h=o[0]instanceof re,p=0,c=o;p(array: T[], refernce: T) {\n let counter = 0;\n for (const item of array) {\n if (item === refernce) {\n counter++;\n }\n }\n return counter;\n}\n\n/**\n * If an array is of length 1, just return the first element. Otherwise, return\n * the full array.\n * @param tensors\n */\nexport function singletonOrArray(xs: T[]): T|T[] {\n if (xs.length === 1) {\n return xs[0];\n }\n return xs;\n}\n\n/**\n * Normalizes a list/tensor into a list.\n *\n * If a tensor is passed, we return\n * a list of size 1 containing the tensor.\n *\n * @param x target object to be normalized.\n */\n// tslint:disable-next-line:no-any\nexport function toList(x: any): any[] {\n if (Array.isArray(x)) {\n return x;\n }\n return [x];\n}\n\n/**\n * Generate a UID for a list\n */\n// tslint:disable-next-line:no-any\nexport function objectListUid(objs: any|any[]): string {\n const objectList = toList(objs);\n let retVal = '';\n for (const obj of objectList) {\n if (obj.id == null) {\n throw new ValueError(\n `Object ${obj} passed to objectListUid without an id`);\n }\n if (retVal !== '') {\n retVal = retVal + ', ';\n }\n retVal = retVal + Math.abs(obj.id);\n }\n return retVal;\n}\n/**\n * Converts string to snake-case.\n * @param name\n */\nexport function toSnakeCase(name: string): string {\n const intermediate = name.replace(/(.)([A-Z][a-z0-9]+)/g, '$1_$2');\n const insecure =\n intermediate.replace(/([a-z])([A-Z])/g, '$1_$2').toLowerCase();\n /*\n If the class is private the name starts with \"_\" which is not secure\n for creating scopes. We prefix the name with \"private\" in this case.\n */\n if (insecure[0] !== '_') {\n return insecure;\n }\n return 'private' + insecure;\n}\n\nexport function toCamelCase(identifier: string): string {\n // quick return for empty string or single character strings\n if (identifier.length <= 1) {\n return identifier;\n }\n // Check for the underscore indicating snake_case\n if (identifier.indexOf('_') === -1) {\n return identifier;\n }\n return identifier.replace(/[_]+(\\w|$)/g, (m, p1) => p1.toUpperCase());\n}\n\n// tslint:disable-next-line:no-any\nlet _GLOBAL_CUSTOM_OBJECTS = {} as {[objName: string]: any};\n\nexport function serializeKerasObject(instance: serialization.Serializable):\n serialization.ConfigDictValue {\n if (instance === null || instance === undefined) {\n return null;\n }\n return {className: instance.getClassName(), config: instance.getConfig()};\n}\n\n/**\n * Deserialize a saved Keras Object\n * @param identifier either a string ID or a saved Keras dictionary\n * @param moduleObjects a list of Python class names to object constructors\n * @param customObjects a list of Python class names to object constructors\n * @param printableModuleName debug text for the object being reconstituted\n * @returns a TensorFlow.js Layers object\n */\n// tslint:disable:no-any\nexport function deserializeKerasObject(\n identifier: string|serialization.ConfigDict,\n moduleObjects = {} as {[objName: string]: any},\n customObjects = {} as {[objName: string]: any},\n printableModuleName = 'object'): any {\n // tslint:enable\n if (typeof identifier === 'string') {\n const functionName = identifier;\n let fn;\n if (functionName in customObjects) {\n fn = customObjects[functionName];\n } else if (functionName in _GLOBAL_CUSTOM_OBJECTS) {\n fn = _GLOBAL_CUSTOM_OBJECTS[functionName];\n } else {\n fn = moduleObjects[functionName];\n if (fn == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${identifier}`);\n }\n }\n return fn;\n } else {\n // In this case we are dealing with a Keras config dictionary.\n const config = identifier;\n if (config.className == null || config.config == null) {\n throw new ValueError(\n `${printableModuleName}: Improper config format: ` +\n `${JSON.stringify(config)}.\\n` +\n `'className' and 'config' must set.`);\n }\n const className = config.className as string;\n let cls, fromConfig;\n if (className in customObjects) {\n [cls, fromConfig] = customObjects.get(className);\n } else if (className in _GLOBAL_CUSTOM_OBJECTS) {\n [cls, fromConfig] = _GLOBAL_CUSTOM_OBJECTS.className;\n } else if (className in moduleObjects) {\n [cls, fromConfig] = moduleObjects[className];\n }\n if (cls == null) {\n throw new ValueError(`Unknown ${printableModuleName}: ${className}`);\n }\n if (fromConfig != null) {\n // Porting notes: Instead of checking to see whether fromConfig accepts\n // customObjects, we create a customObjects dictionary and tack it on to\n // config.config as config.config.customObjects. Objects can use it, if\n // they want.\n\n // tslint:disable-next-line:no-any\n const customObjectsCombined = {} as {[objName: string]: any};\n for (const key of Object.keys(_GLOBAL_CUSTOM_OBJECTS)) {\n customObjectsCombined[key] = _GLOBAL_CUSTOM_OBJECTS[key];\n }\n for (const key of Object.keys(customObjects)) {\n customObjectsCombined[key] = customObjects[key];\n }\n // Add the customObjects to config\n const nestedConfig = config.config as serialization.ConfigDict;\n nestedConfig.customObjects = customObjectsCombined;\n\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n const returnObj = fromConfig(cls, config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n\n return returnObj;\n } else {\n // Then `cls` may be a function returning a class.\n // In this case by convention `config` holds\n // the kwargs of the function.\n const backupCustomObjects = {..._GLOBAL_CUSTOM_OBJECTS};\n for (const key of Object.keys(customObjects)) {\n _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key];\n }\n // In python this is **config['config'], for tfjs-layers we require\n // classes that use this fall-through construction method to take\n // a config interface that mimics the expansion of named parameters.\n const returnObj = new cls(config.config);\n _GLOBAL_CUSTOM_OBJECTS = {...backupCustomObjects};\n return returnObj;\n }\n }\n}\n\n/**\n * Compares two numbers for sorting.\n * @param a\n * @param b\n */\nexport function numberCompare(a: number, b: number) {\n return (a < b) ? -1 : ((a > b) ? 1 : 0);\n}\n\n/**\n * Comparison of two numbers for reverse sorting.\n * @param a\n * @param b\n */\nexport function reverseNumberCompare(a: number, b: number) {\n return -1 * numberCompare(a, b);\n}\n\n/**\n * Convert a string into the corresponding DType.\n * @param dtype\n * @returns An instance of DType.\n */\nexport function stringToDType(dtype: string): DataType {\n switch (dtype) {\n case 'float32':\n return 'float32';\n default:\n throw new ValueError(`Invalid dtype: ${dtype}`);\n }\n}\n\n/**\n * Test the element-by-element equality of two Arrays of strings.\n * @param xs First array of strings.\n * @param ys Second array of strings.\n * @returns Wether the two arrays are all equal, element by element.\n */\nexport function stringsEqual(xs: string[], ys: string[]): boolean {\n if (xs == null || ys == null) {\n return xs === ys;\n }\n if (xs.length !== ys.length) {\n return false;\n }\n for (let i = 0; i < xs.length; ++i) {\n if (xs[i] !== ys[i]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Get the unique elements of an array.\n * @param xs Array.\n * @returns An Array consisting of the unique elements in `xs`.\n */\nexport function unique(xs: T[]): T[] {\n if (xs == null) {\n return xs;\n }\n const out: T[] = [];\n // TODO(cais): Maybe improve performance by sorting.\n for (const x of xs) {\n if (out.indexOf(x) === -1) {\n out.push(x);\n }\n }\n return out;\n}\n\n/**\n * Determine if an Object is empty (i.e., does not have own properties).\n * @param obj Object\n * @returns Whether the Object is empty.\n * @throws ValueError: If object is `null` or `undefined`.\n */\nexport function isObjectEmpty(obj: {}): boolean {\n if (obj == null) {\n throw new ValueError(`Invalid value in obj: ${JSON.stringify(obj)}`);\n }\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Helper function used to build type union/enum run-time checkers.\n * @param values The list of allowed values.\n * @param label A string name for the type\n * @param value The value to test.\n * @throws ValueError: If the value is not in values nor `undefined`/`null`.\n */\nexport function checkStringTypeUnionValue(\n values: string[], label: string, value: string): void {\n if (value == null) {\n return;\n }\n if (values.indexOf(value) < 0) {\n throw new ValueError(`${value} is not a valid ${label}. Valid values are ${\n values} or null/undefined.`);\n }\n}\n\n/**\n * Helper function for verifying the types of inputs.\n *\n * Ensures that the elements of `x` are all of type `expectedType`.\n * Also verifies that the length of `x` is within bounds.\n *\n * @param x Object to test.\n * @param expectedType The string expected type of all of the elements in the\n * Array.\n * @param minLength Return false if x.length is less than this.\n * @param maxLength Return false if x.length is greater than this.\n * @returns true if and only if `x` is an `Array` with\n * length >= `minLength` and <= `maxLength`.\n */\n// tslint:disable:no-any\nexport function checkArrayTypeAndLength(\n x: any, expectedType: string, minLength = 0,\n maxLength = Infinity): boolean {\n assert(minLength >= 0);\n assert(maxLength >= minLength);\n return (\n Array.isArray(x) && x.length >= minLength && x.length <= maxLength &&\n x.every(e => typeof e === expectedType));\n}\n// tslint:enable:no-any\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/contraints.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Helper function used by many of the Constraints to find the L2Norms.\n */\nfunction calcL2Norms(w: Tensor, axis: number): Tensor {\n return tidy(() => tfc.sqrt(tfc.sum(tfc.mulStrict(w, w), axis, true)));\n}\n\n/**\n * Base class for functions that impose constraints on weight values\n */\n/**\n * @doc {\n * heading: 'Constraints',\n * subheading: 'Classes',\n * namespace: 'constraints'\n * }\n */\nexport abstract class Constraint extends serialization.Serializable {\n /* Porting note: was __call__, apply chosen to match other similar choices */\n abstract apply(w: Tensor): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\nexport interface MaxNormConfig {\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * MaxNorm weight constraint.\n *\n * Constrains the weights incident to each hidden unit\n * to have a norm less than or equal to a desired value.\n *\n * References\n * - [Dropout: A Simple Way to Prevent Neural Networks from Overfitting\n * Srivastava, Hinton, et al.\n * 2014](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf)\n */\nexport class MaxNorm extends Constraint {\n static readonly className = 'MaxNorm';\n private maxValue: number;\n private axis: number;\n private readonly defaultMaxValue = 2;\n private readonly defaultAxis = 0;\n\n constructor(config: MaxNormConfig) {\n super();\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.clipByValue(norms, 0, this.maxValue);\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {maxValue: this.maxValue, axis: this.axis};\n }\n}\nserialization.SerializationMap.register(MaxNorm);\n\nexport interface UnitNormConfig {\n /**\n * Axis along which to calculate norms.\n *\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * [rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n}\n\n/**\n * Constrains the weights incident to each hidden unit to have unit norm.\n */\nexport class UnitNorm extends Constraint {\n static readonly className = 'UnitNorm';\n private axis: number;\n private readonly defaultAxis = 0;\n constructor(config: UnitNormConfig) {\n super();\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(\n () => tfc.div(\n w, tfc.add(getScalar(epsilon()), calcL2Norms(w, this.axis))));\n }\n\n getConfig(): serialization.ConfigDict {\n return {axis: this.axis};\n }\n}\nserialization.SerializationMap.register(UnitNorm);\n\n/**\n * Constains the weight to be non-negative.\n */\nexport class NonNeg extends Constraint {\n static readonly className = 'NonNeg';\n\n apply(w: Tensor): Tensor {\n return tfc.relu(w);\n }\n}\nserialization.SerializationMap.register(NonNeg);\n\nexport interface MinMaxNormConfig {\n /**\n * Minimum norm for incoming weights\n */\n minValue?: number;\n /**\n * Maximum norm for incoming weights\n */\n maxValue?: number;\n /**\n * Axis along which to calculate norms.\n * For instance, in a `Dense` layer the weight matrix\n * has shape `[inputDim, outputDim]`,\n * set `axis` to `0` to constrain each weight vector\n * of length `[inputDim,]`.\n * In a `Conv2D` layer with `dataFormat=\"channels_last\"`,\n * the weight tensor has shape\n * `[rows, cols, inputDepth, outputDepth]`,\n * set `axis` to `[0, 1, 2]`\n * to constrain the weights of each filter tensor of size\n * `[rows, cols, inputDepth]`.\n */\n axis?: number;\n /**\n * Rate for enforcing the constraint: weights will be rescaled to yield:\n * `(1 - rate) * norm + rate * norm.clip(minValue, maxValue)`.\n * Effectively, this means that rate=1.0 stands for strict\n * enforcement of the constraint, while rate<1.0 means that\n * weights will be rescaled at each step to slowly move\n * towards a value inside the desired interval.\n */\n rate?: number;\n}\n\nexport class MinMaxNorm extends Constraint {\n static readonly className = 'MinMaxNorm';\n private minValue: number;\n private maxValue: number;\n private rate: number;\n private axis: number;\n private readonly defaultMinValue = 0.0;\n private readonly defaultMaxValue = 1.0;\n private readonly defaultRate = 1.0;\n private readonly defaultAxis = 0;\n\n constructor(config: MinMaxNormConfig) {\n super();\n this.minValue =\n config.minValue != null ? config.minValue : this.defaultMinValue;\n this.maxValue =\n config.maxValue != null ? config.maxValue : this.defaultMaxValue;\n this.rate = config.rate != null ? config.rate : this.defaultRate;\n this.axis = config.axis != null ? config.axis : this.defaultAxis;\n }\n\n apply(w: Tensor): Tensor {\n return tidy(() => {\n const norms = calcL2Norms(w, this.axis);\n const desired = tfc.add(\n tfc.mul(\n getScalar(this.rate),\n tfc.clipByValue(norms, this.minValue, this.maxValue)),\n tfc.mul(getScalar(1.0 - this.rate), norms));\n return tfc.mul(w, tfc.div(desired, tfc.add(getScalar(epsilon()), norms)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n minValue: this.minValue,\n maxValue: this.maxValue,\n rate: this.rate,\n axis: this.axis\n };\n }\n}\nserialization.SerializationMap.register(MinMaxNorm);\n\n/** @docinline */\nexport type ConstraintIdentifier =\n 'maxNorm'|'minMaxNorm'|'nonNeg'|'unitNorm'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in ConstraintIdentifier]: string} = {\n 'maxNorm': 'MaxNorm',\n 'minMaxNorm': 'MinMaxNorm',\n 'nonNeg': 'NonNeg',\n 'unitNorm': 'UnitNorm'\n };\n\nexport function serializeConstraint(constraint: Constraint):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeConstraint(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Constraint {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'constraint');\n}\n\nexport function getConstraint(identifier: ConstraintIdentifier|\n serialization.ConfigDict|Constraint): Constraint {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeConstraint(config);\n } else if (identifier instanceof Constraint) {\n return identifier;\n } else {\n return deserializeConstraint(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constraint, MaxNorm, MaxNormConfig, MinMaxNorm, MinMaxNormConfig, NonNeg, UnitNorm, UnitNormConfig} from './constraints';\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MaxNorm',\n * configParamIndices: [0]\n * }\n */\nexport function maxNorm(config: MaxNormConfig): Constraint {\n return new MaxNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'UnitNorm',\n * configParamIndices: [0]\n * }\n */\nexport function unitNorm(config: UnitNormConfig): Constraint {\n return new UnitNorm(config);\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'NonNeg'\n * }\n */\nexport function nonNeg(): Constraint {\n return new NonNeg();\n}\n\n/**\n * @doc {\n * heading: 'Constraints',\n * namespace: 'constraints',\n * useDocsFrom: 'MinMaxNormConfig',\n * configParamIndices: [0]\n * }\n */\nexport function minMaxNorm(config: MinMaxNormConfig): Constraint {\n return new MinMaxNorm(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Common functions for TensorFlow.js Layers.\n */\nimport {checkStringTypeUnionValue} from './utils/generic_utils';\n// A map from the requested scoped name of a Tensor to the number of Tensors\n// wanting that name so far. This allows enforcing name uniqueness by appending\n// an incrementing index, e.g. scope/name, scope/name_1, scope/name_2, etc.\nconst nameMap: Map = new Map();\n\n// TODO(cais): Perhaps move the enums to a more suitable place, e.g.,\n// constants.ts.\n/** @docinline */\nexport type DataFormat = 'channelsFirst'|'channelsLast';\nexport const VALID_DATA_FORMAT_VALUES = ['channelsFirst', 'channelsLast'];\nexport function checkDataFormat(value?: string): void {\n checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES, 'DataFormat', value);\n}\n\n/** @docinline */\nexport type PaddingMode = 'valid'|'same'|'causal';\nexport const VALID_PADDING_MODE_VALUES = ['valid', 'same', 'causal'];\nexport function checkPaddingMode(value?: string): void {\n checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES, 'PaddingMode', value);\n}\n\n/** @docinline */\nexport type PoolMode = 'max'|'avg';\nexport const VALID_POOL_MODE_VALUES = ['max', 'avg'];\nexport function checkPoolMode(value?: string): void {\n checkStringTypeUnionValue(VALID_POOL_MODE_VALUES, 'PoolMode', value);\n}\n\nconst _nameScopeStack: string[] = [];\nconst _nameScopeDivider = '/';\n\n/**\n * Enter namescope, which can be nested.\n */\nexport function nameScope(name: string, fn: () => T): T {\n _nameScopeStack.push(name);\n try {\n const val: T = fn();\n _nameScopeStack.pop();\n return val;\n } catch (e) {\n _nameScopeStack.pop();\n throw e;\n }\n}\n\n/**\n * Get the current namescope as a flat, concatenated string.\n */\nfunction currentNameScopePrefix(): string {\n if (_nameScopeStack.length === 0) {\n return '';\n } else {\n return _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider;\n }\n}\n\n/**\n * Get the name a Tensor (or Variable) would have if not uniqueified.\n * @param tensorName\n * @return Scoped name string.\n */\nexport function getScopedTensorName(tensorName: string): string {\n if (!isValidTensorName(tensorName)) {\n throw new Error('Not a valid tensor name: \\'' + tensorName + '\\'');\n }\n return currentNameScopePrefix() + tensorName;\n}\n\n/**\n * Get unique names for Tensors and Variables.\n * @param scopedName The fully-qualified name of the Tensor, i.e. as produced by\n * `getScopedTensorName()`.\n * @return A unique version of the given fully scoped name.\n * If this is the first time that the scoped name is seen in this session,\n * then the given `scopedName` is returned unaltered. If the same name is\n * seen again (producing a collision), an incrementing suffix is added to the\n * end of the name, so it takes the form 'scope/name_1', 'scope/name_2', etc.\n */\nexport function getUniqueTensorName(scopedName: string): string {\n if (!isValidTensorName(scopedName)) {\n throw new Error('Not a valid tensor name: \\'' + scopedName + '\\'');\n }\n if (!nameMap.has(scopedName)) {\n nameMap.set(scopedName, 0);\n }\n const index = nameMap.get(scopedName);\n nameMap.set(scopedName, nameMap.get(scopedName) + 1);\n\n if (index > 0) {\n const result = scopedName + '_' + index;\n // Mark the composed name as used in case someone wants\n // to call getUniqueTensorName(\"name_1\").\n nameMap.set(result, 1);\n return result;\n } else {\n return scopedName;\n }\n}\n\nconst tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\\._\\/]*$/);\n\n/**\n * Determine whether a string is a valid tensor name.\n * @param name\n * @returns A Boolean indicating whether `name` is a valid tensor name.\n */\nexport function isValidTensorName(name: string): boolean {\n return name.match(tensorNameRegex) ? true : false;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Math utility functions.\n *\n * This file contains some frequently used math function that operates on\n * number[] or Float32Array and return a number. Many of these functions are\n * not-so-thick wrappers around TF.js Core functions. But they offer the\n * convenience of\n * 1) not having to convert the inputs into Tensors,\n * 2) not having to convert the returned Tensors to numbers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor1D, tensor1d} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\n\nexport type ArrayTypes = Uint8Array|Int32Array|Float32Array;\n\n/**\n * Determine if a number is an integer.\n */\nexport function isInteger(x: number): boolean {\n return x === parseInt(x.toString(), 10);\n}\n\n/**\n * Calculate the product of an array of numbers.\n * @param array The array to calculate the product over.\n * @param begin Beginning index, inclusive.\n * @param end Ending index, exclusive.\n * @return The product.\n */\nexport function arrayProd(\n array: number[]|ArrayTypes, begin?: number, end?: number): number {\n if (begin == null) {\n begin = 0;\n }\n if (end == null) {\n end = array.length;\n }\n\n let prod = 1;\n for (let i = begin; i < end; ++i) {\n prod *= array[i];\n }\n return prod;\n}\n\n/**\n * A helper function transforms the two input types to an instance of Tensor1D,\n * so the return value can be fed directly into various TF.js Core functions.\n * @param array\n */\nfunction toArray1D(array: number[]|Float32Array): Tensor1D {\n array = Array.isArray(array) ? new Float32Array(array) : array;\n return tensor1d(array);\n}\n\n/**\n * Compute minimum value.\n * @param array\n * @return minimum value.\n */\nexport function min(array: number[]|Float32Array): number {\n return tfc.min(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute maximum value.\n * @param array\n * @return maximum value\n */\nexport function max(array: number[]|Float32Array): number {\n return tfc.max(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute sum of array.\n * @param array\n * @return The sum.\n */\nexport function sum(array: number[]|Float32Array): number {\n return tfc.sum(toArray1D(array)).dataSync()[0];\n}\n\n/**\n * Compute mean of array.\n * @param array\n * @return The mean.\n */\nexport function mean(array: number[]|Float32Array): number {\n return sum(array) / array.length;\n}\n\n/**\n * Compute variance of array.\n * @param array\n * @return The variance.\n */\nexport function variance(array: number[]|Float32Array): number {\n const demeaned = tfc.sub(toArray1D(array), scalar(mean(array)));\n const sumSquare = tfc.sum(tfc.mulStrict(demeaned, demeaned)).dataSync()[0];\n return sumSquare / array.length;\n}\n\n/**\n * Compute median of array.\n * @param array\n * @return The median value.\n */\nexport function median(array: number[]|Float32Array): number {\n const arraySorted = array.slice().sort((a, b) => a - b);\n const lowIdx = Math.floor((arraySorted.length - 1) / 2);\n const highIdx = Math.ceil((arraySorted.length - 1) / 2);\n if (lowIdx === highIdx) {\n return arraySorted[lowIdx];\n }\n return (arraySorted[lowIdx] + arraySorted[highIdx]) / 2;\n}\n\n/**\n * Generate an array of integers in [begin, end).\n * @param begin Beginning integer, inclusive.\n * @param end Ending integer, inclusive.\n * @returns Range array.\n * @throws ValueError, iff `end` < `begin`.\n */\nexport function range(begin: number, end: number): number[] {\n if (end < begin) {\n throw new ValueError(`end (${end}) < begin (${begin}) is forbidden.`);\n }\n const out: number[] = [];\n for (let i = begin; i < end; ++i) {\n out.push(i);\n }\n return out;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * deeplearn.js backend.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {onesLike as coreOnesLike, Scalar, scalar, Tensor, Tensor1D, tensor1d, Tensor2D, Tensor3D, Tensor4D, tidy, util, where, zerosLike as coreZerosLike} from '@tensorflow/tfjs-core';\n\nimport {disposeScalarCache, getScalar} from '../backend/state';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {HasShape, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\n\nimport {imageDataFormat} from './common';\n\n// tslint:enable\n\n/* Setting and getting backend from deeplearn.js. */\n\n// Default deeplearn.js backend is WebGL (GPU).\nlet backend: 'cpu'|'webgl' = 'webgl';\n\nexport function setBackend(requestedBackend: 'cpu'|'webgl') {\n tfc.setBackend(requestedBackend);\n backend = requestedBackend;\n disposeScalarCache();\n}\n\nexport function getBackend(): 'cpu'|'webgl' {\n return backend;\n}\n\n/**\n * Indicates whether the backend is operating symbolically.\n *\n * This function will be used to determine how to interpret user code. If\n * it returns true, calls to the backend construct a symbolic graph; if\n * it returns false, calls to the backend execute immediately.\n */\nexport function isBackendSymbolic(): boolean {\n return false;\n}\n\n/**\n * Get the number of elements in a Tensor.\n * @param x The Tensor.\n * @return Number of elements in `x`.\n */\nexport function countParams(x: HasShape): number {\n const shape = x.shape;\n if (shape.length > 0) {\n return shape.reduce((a: number, b: number) => a * b);\n } else {\n // Scalar.\n return 1;\n }\n}\n\n/**\n * Casts a tensor to a different dtype and returns it.\n * @param x Input tensor.\n * @param dtype String: 'float32'|'int32'|'bool'.\n * @returns Tensor of the specified `dtype`.\n */\nexport function cast(x: Tensor, dtype: 'float32'|'int32'|'bool'): Tensor {\n return x.asType(dtype);\n}\n\n/**\n * Adds a 1-sized dimension at index \"axis\".\n * @param x Input tensor.\n * @param axis Position where to add the new axis.\n * @returns Result of the dimension expansion.\n */\nexport function expandDims(x: Tensor, axis = -1): Tensor {\n const outShape = x.shape.slice();\n if (axis < 0) {\n axis = outShape.length + axis + 1;\n }\n outShape.splice(axis, 0, 1);\n return x.reshape(outShape);\n}\n\n/**\n * Repeats a 2D tensor.\n *\n * If `x` has shape `[samples, dim]` and `n` is 2, for example, the output\n * will have shape `[samples, 2, dim]`.\n *\n * @param x Input tensor.\n * @param n Integer, number of times to repeat.\n * @returns The result of the repeat operation.\n * @throws ValueError: If input tensor is not 2D.\n */\nexport function repeat(x: Tensor, n: number): Tensor {\n return tidy(() => {\n if (x.shape.length !== 2) {\n throw new ValueError(\n `repeat() expects a rank-2 tensor, but received a ` +\n `rank-${x.shape.length} tensor.`);\n }\n const y = expandDims(x, 1);\n return tile(y, [1, n, 1]);\n });\n}\n\n/**\n * Flatten an Tensor into 1D.\n * @param x Input tensor.\n * @return The result of the flattening `x`.\n */\nexport function flatten(x: Tensor): Tensor {\n const newShape = [math_utils.arrayProd(x.shape)];\n return x.reshape(newShape);\n}\n\n/**\n * Turn a nD tensor into a 2D tensor with same 0th dimension.\n * In other words, it flattens each data samples of a batch.\n *\n * @param x The tensor to flatten. The rank of this tensor is required to be 2\n * or higher.\n * @return The result of the flattening.\n */\nexport function batchFlatten(x: Tensor): Tensor {\n if (x.rank <= 1) {\n throw new ValueError(\n `batchFlatten requires a minimum rank of 2. Got rank: ${x.rank}.`);\n }\n const newShape = [x.shape[0], math_utils.arrayProd(x.shape, 1)];\n return x.reshape(newShape);\n}\n\n/**\n * Do slicing along the first axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the first axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongFirstAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [start, 0], [size, array.shape[1]]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [start, 0, 0],\n [size, array.shape[1], array.shape[2]]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [start, 0, 0, 0],\n [size, array.shape[1], array.shape[2], array.shape[3]]);\n default:\n throw new ValueError(\n `sliceAlongFirstAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the last axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size size of the slice along the last axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongLastAxis(\n array: Tensor, start: number, size: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n return tfc.slice2d(\n array as Tensor2D, [0, start], [array.shape[0], size]);\n case 3:\n return tfc.slice3d(\n array as Tensor3D, [0, 0, start],\n [array.shape[0], array.shape[1], size]);\n case 4:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, 0, start],\n [array.shape[0], array.shape[1], array.shape[2], size]);\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Do slicing along the sepcified axis.\n * @param array input `Tensor`.\n * @param start starting index, inclusive.\n * @param size of the slice along the chosen axis.\n * @param choose an axis.\n * @returns result of the slicing.\n * @throws ValueError: If `array` is of an unsupported subtype of `Tensor`.\n */\nexport function sliceAlongAxis(\n array: Tensor, start: number, size: number, axis: number): Tensor {\n return tidy(() => {\n switch (array.rank) {\n case 1:\n return tfc.slice1d(array as Tensor1D, start, size);\n case 2:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 3:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice3d(\n array as Tensor3D, [0, start, 0],\n [array.shape[0], size, array.shape[2]]);\n case 3:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n case 4:\n switch (axis) {\n case 1:\n return sliceAlongFirstAxis(array, start, size);\n case 2:\n return tfc.slice4d(\n array as Tensor4D, [0, start, 0, 0],\n [array.shape[0], size, array.shape[2], array.shape[3]]);\n case 3:\n return tfc.slice4d(\n array as Tensor4D, [0, 0, start, 0],\n [array.shape[0], array.shape[1], size, array.shape[3]]);\n case 4:\n return sliceAlongLastAxis(array, start, size);\n default:\n throw new ValueError(\n `The axis is not within the rank of the tensor ` +\n `${axis}`);\n }\n default:\n throw new ValueError(\n `sliceAlongLastAxis() received an unsupported tensor rank: ` +\n `${array.rank}`);\n }\n });\n}\n\n/**\n * Concatenates a list of tensors alongside the specified axis.\n * @param tensors `Array` of tensors to concatenate.\n * @param axis Concatenation axis.\n * @returns The result of the concatenation.\n */\nexport function concatenate(tensors: Tensor[], axis = -1): Tensor {\n let rank: number;\n if (axis < 0) {\n rank = tensors[0].rank;\n if (rank !== 0) {\n axis = rank;\n } else {\n axis = 0;\n }\n }\n if (axis === tensors[0].rank) {\n // Porting Note: This is necessary because tfc.concat() requires axis to be\n // in the interval [-rank, rank).\n axis = -1;\n }\n // Porting Note: Sparse concat is not supported yet.\n return tfc.concat(tensors, axis);\n}\n\n/**\n * Concatenate two arrays along the first dimension.\n * @param a The 1st `Tensor` to concatenate.\n * @param b The 2nd `Tensor` to concatenate.\n * @returns Result of the concatenation.\n * @throws ValueError: If `a` is of an unsupported subtype of `Tensor`.\n */\nexport function concatAlongFirstAxis(a: Tensor, b: Tensor): Tensor {\n switch (a.rank) {\n case 1:\n return tfc.concat1d([a as Tensor1D, b as Tensor1D]);\n case 2:\n return tfc.concat2d([a as Tensor2D, b as Tensor2D], 0);\n case 3:\n return tfc.concat3d([a as Tensor3D, b as Tensor3D], 0);\n case 4:\n return tfc.concat4d([a as Tensor4D, b as Tensor4D], 0);\n default:\n throw new ValueError(\n 'concatAlongFirstAxis() received an unsupported tensor rank: ' +\n a.rank);\n }\n}\n\n/**\n * Creates a tensor by tiling `x` by `n`.\n * @param x A tensor.\n * @param n An Array of integers or a single integer. If an Array, the length\n * must be the same as the number of dimensions in `x`. If a single integer,\n * it will be treated as an Array of length 1.\n */\nexport function tile(x: Tensor, n: number|number[]): Tensor {\n if (!Array.isArray(n)) {\n n = [n];\n }\n if (x.rank !== n.length) {\n throw new ValueError(\n `The length of input n (${n.length}) does not match ` +\n `the number of dimensions in input x (${x.rank})`);\n }\n return tfc.tile(x, n);\n}\n\n/* Creation of random tensors. */\n\n\n/**\n * Get a tensor with normal distribution of values.\n *\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @return The normal tensor.\n */\nexport function randomNormal(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: 'float32'|'int32',\n seed?: number): Tensor {\n return tfc.randomNormal(shape, mean, stddev, dtype, seed);\n}\n\n/* Linear Algebra */\n\n/**\n * Multiply two tensors and returns the result as a tensor.\n *\n * For 2D tensors, this is equivalent to matrix multiplication (matMul).\n * For tensors of higher ranks, it follows the Theano behavior,\n * (e.g. `(2, 3) * (4, 3, 5) -> (2, 4, 5)`).\n *\n * @param x A tensor of at least rank 2.\n * @param y A tensor of at least rank 2.\n * @return Result of the dot operation.\n */\nexport function dot(x: Tensor, y: Tensor): Tensor {\n if (y.rank !== 2) {\n throw new NotImplementedError(\n `dot support for y other than rank 2 is not yet implemented: ` +\n `y shape = ${y.shape}`);\n } else {\n if (x.rank === 2) {\n return tfc.matMul(x as Tensor2D, y as Tensor2D);\n } else if (x.rank === 3) {\n const xShape0 = x.shape[0];\n const xShape1 = x.shape[1];\n const xShape2 = x.shape[2];\n x = x.reshape([xShape0 * xShape1, xShape2]);\n return tfc.matMul(x as Tensor2D, y as Tensor2D).reshape([\n xShape0, xShape1, y.shape[1]\n ]);\n } else {\n throw new NotImplementedError(\n `dot support for x of rank ${x.rank} is not yet implemented: ` +\n `x shape = ${x.shape}`);\n }\n }\n}\n\n/**\n * Compute the sign Tensor of an input Tensor.\n *\n * Elements of the input `Tensor` that are === 0 are mapped to 0.\n * Elements of the input `Tensor` that are > 0 are mapped to 1.\n * Elements of the input `Tensor` that are < 0 are mapped to -1.\n *\n * @param x Input `Tensor`.\n * @return The sign `Tensor`.\n */\nexport function sign(x: Tensor): Tensor {\n // TODO(cais): Move to the core.\n return tidy(() => {\n const zerosLikeX = coreZerosLike(x);\n const onesLikeX = coreOnesLike(x);\n return where(\n tfc.equal(x, zerosLikeX), zerosLikeX,\n where(\n tfc.greater(x, coreZerosLike(x)), onesLikeX,\n tfc.mul(getScalar(-1), onesLikeX)));\n });\n}\n\n/**\n * Computes the one-hot representation of an integer tensor.\n * @param indices nD integer tensor of shape\n * `(batch_size, dim1, dim2, ... dim(n-1))`\n * @param numClasses Integer, number of classes to consider.\n * @returns (n + 1)D one hot representation of the input\n * with shape `(batch_size, dim1, dim2, ... dim(n-1), num_classes)`\n */\nexport function oneHot(indices: Tensor, numClasses: number): Tensor {\n return tidy(() => {\n if (indices.rank !== 1) {\n throw new Error(\n 'Only 1D one-hot tensors are supported in the ' +\n 'deeplearn backend, at present.');\n }\n indices = indices.toInt();\n return tfc.oneHot(indices as Tensor1D, numClasses).toFloat();\n });\n}\n\n/* Elementary math functions. */\n\n/**\n * Retrieves the elements of indices `indices` in the tensor `reference`.\n * @param reference A tensor.\n * @param indices An integer tensor of indices or an `Array` of integers.\n * @param axis Axis along which to perform the gather operation.\n * @returns The result of the gathering as a tensor.\n */\nexport function gather(\n reference: Tensor, indices: number[]|Tensor1D, axis?: number): Tensor {\n return tidy(() => {\n if (Array.isArray(indices)) {\n indices = tensor1d(indices, 'int32');\n } else {\n indices = indices.toInt();\n }\n return tfc.gather(reference, indices, axis);\n });\n}\n\n/**\n * Element-wise square.\n * @param x Input tensor.\n * @return element-wise x^2\n */\nexport function square(x: Tensor): Tensor {\n return tfc.mulStrict(x, x);\n}\n\n/**\n * Element-wise exponentiation.\n *\n * Porting Note: In PyKeras, `a` (the exponent) is a Python integer, which\n * takes advatnage of the backend's (e.g., TensorFlow's) automatic conversion\n * to tensor. Here we allow `a` to be either a number or a tensor.\n *\n * @param x The base tensor.\n * @param a The exponent, tensor or number. If a number, it is rounded to the\n * nearest integer and converted to a tensor.\n * @returns A tensor of the same shape as `x`.\n */\nexport function pow(x: Tensor, a: Tensor|number): Tensor {\n return tidy(() => {\n if (typeof (a) === 'number') {\n a = scalar(Math.round(a), 'int32');\n }\n if (a.dtype !== 'int32') {\n throw new NotImplementedError(\n `Non-int32 dtype (${a.dtype}) is not supported by pow() yet`);\n }\n return tfc.pow(x, a as Tensor);\n });\n}\n\n/* Neural-network operations. */\n\n/**\n * Add a bias to a tensor.\n *\n * @param x The tensor to add the bias to.\n * @param bias The bias to add to `x`. Must be 1D or the same rank as `x`.\n * @return Result of the bias adding.\n * @throws ValueError: If the rank of `bias` is incorrect.\n */\nexport function biasAdd(\n x: Tensor, bias: Tensor, dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n\n if (bias.rank !== 1 && bias.rank !== x.rank) {\n throw new ValueError(\n 'Unexpected bias dimensions: ' + bias.rank +\n '; expected it to be 1 or ' + x.rank);\n }\n const biasShape = bias.shape;\n\n let y: Tensor;\n if (x.rank === 5) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1, 1]));\n } else {\n y = x.add(bias.reshape(\n [1, biasShape[3], biasShape[0], biasShape[1], biasShape[2]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 4) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1, 1]));\n } else {\n y = x.add(\n bias.reshape([1, biasShape[2], biasShape[0], biasShape[1]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank === 3) {\n if (dataFormat === 'channelsFirst') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, biasShape[0], 1]));\n } else {\n y = x.add(bias.reshape([1, biasShape[1], biasShape[0]]));\n }\n } else if (dataFormat === 'channelsLast') {\n if (biasShape.length === 1) {\n y = x.add(bias.reshape([1, 1, biasShape[0]]));\n } else {\n y = x.add(bias.reshape([1].concat(biasShape)));\n }\n }\n } else if (x.rank < 3) {\n y = x.add(bias);\n } else {\n throw new ValueError(`Unsupported input rank by biasAdd: ${x.rank}`);\n }\n return y;\n });\n}\n\n/**\n * Exponential linear unit (ELU).\n * @param x A tensor or variable to compute the activation function for.\n * @param alpha: A scalar, a scaling factor for the negative section.\n * @return Output of the ELU operation.\n */\nexport function elu(x: Tensor, alpha = 1): Tensor {\n // TODO(cais): Add support for alpha values other than 1.\n if (alpha !== 1) {\n throw new NotImplementedError(\n `Support for alpha values other than 1 (${alpha}) is not implemented ` +\n `yet.`);\n }\n return tfc.elu(x);\n}\n\n/**\n * Softsign of a tensor.\n *\n * Defined as x / (abs(x) + 1), element-wise.\n *\n * @param x: Input.\n * @returns Output.\n */\nexport function softsign(x: Tensor): Tensor {\n return tidy(() => tfc.div(x, tfc.add(getScalar(1), tfc.abs(x))));\n}\n\n/**\n * Sets entries in `x` to zero at random, while scaling the entire tensor.\n *\n * @param x input tensor.\n * @param level fraction of the entries in the tensor that will be set to 0.\n * @param noiseShape shape of randomly generated keep/drop flags, must be\n * broadcastable to the shape of `x`.\n * @param seed random seed to ensure determinism.\n * @returns Result of the dropout operation.\n */\nexport function dropout(\n x: Tensor, level: Scalar, noiseShape?: number[], seed?: number): Tensor {\n return tidy(() => {\n // TODO(cais): Switch to deeplearn.js implementation of dropout when it\n // becomes avaialable.\n if (noiseShape != null && !util.arraysEqual(x.shape, noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented yet: ' +\n JSON.stringify(noiseShape));\n }\n if (seed != null) {\n throw new NotImplementedError('seed is not implemented for dropout yet.');\n }\n let multiplier = tfc.step(tfc.add(\n tfc.neg(level) as Scalar, tfc.randomUniform(x.shape, 0, 1, 'float32')));\n // Scale the kept elements, so the expected sum is unchanged.\n multiplier = tfc.mul(\n tfc.div(getScalar(1), tfc.sub(getScalar(1), level)) as Scalar,\n multiplier);\n return tfc.mul(x, multiplier);\n });\n}\n\n/**\n * Element-wise, segment-wise linear approximation of sigmoid.\n *\n * Returns `0.` if `x < -2.5`, `1.` if `x > 2.5`.\n * In `-2.5 <= x <= 2.5`, returns `0.2 * x + 0.5`.\n *\n * @param x Input tensor.\n * @returns Output tensor.\n */\nexport function hardSigmoid(x: Tensor): Tensor {\n return tidy(() => {\n const y = tfc.add(getScalar(0.5), tfc.mul(getScalar(0.2), x));\n return tfc.clipByValue(y, 0, 1);\n });\n}\n\n/**\n * Invoke `x` in the training phase, and `alt` otherwise.\n *\n * Porting Note: We do not create placeholder tensors for the `training` boolean\n * flag here, because there is no such thing in the TF.js imperative backend.\n *\n * @param x The function to invoke iff `training` is `true`.\n * @param alt The function to invoke iff `training` is `false`.\n * @param training Boolean flag for whether training phase is active.\n * @returns The return value of `x()` if `training` is `true`, or the return\n * value of `alt()` if `training` is `false`.\n */\nexport function inTrainPhase(x: () => T, alt: () => T, training = false): T {\n return training ? x() : alt();\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// tslint:disable:max-line-length\nimport {DataType, eye, linalg, mul, ones, randomUniform, scalar, Scalar, serialization, Tensor, Tensor2D, tidy, truncatedNormal, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from './common';\nimport {NotImplementedError, ValueError} from './errors';\nimport {Shape} from './types';\nimport {checkStringTypeUnionValue, deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\nimport {arrayProd} from './utils/math_utils';\n\n// tslint:enable:max-line-length\n\n/** @docinline */\nexport type FanMode = 'fanIn'|'fanOut'|'fanAvg';\nexport const VALID_FAN_MODE_VALUES = ['fanIn', 'fanOut', 'fanAvg'];\nexport function checkFanMode(value?: string): void {\n checkStringTypeUnionValue(VALID_FAN_MODE_VALUES, 'FanMode', value);\n}\n\n/** @docinline */\nexport type Distribution = 'normal'|'uniform';\nexport const VALID_DISTRIBUTION_VALUES = ['normal', 'uniform'];\nexport function checkDistribution(value?: string): void {\n checkStringTypeUnionValue(VALID_DISTRIBUTION_VALUES, 'Distribution', value);\n}\n\n/**\n * Initializer base class.\n *\n * @doc {\n * heading: 'Initializers', subheading: 'Classes', namespace: 'initializers'}\n */\nexport abstract class Initializer extends serialization.Serializable {\n public fromConfigUsesCustomObjects(): boolean {\n return false;\n }\n /**\n * Generate an initial value.\n * @param shape\n * @param dtype\n * @return The init value.\n */\n abstract apply(shape: Shape, dtype?: DataType): Tensor;\n\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/**\n * Initializer that generates tensors initialized to 0.\n */\nexport class Zeros extends Initializer {\n static className = 'Zeros';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return zeros(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Zeros);\n\n/**\n * Initializer that generates tensors initialized to 1.\n */\nexport class Ones extends Initializer {\n static className = 'Ones';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return ones(shape, dtype);\n }\n}\nserialization.SerializationMap.register(Ones);\n\nexport interface ConstantConfig {\n /** The value for each element in the variable. */\n value: number;\n}\n\n/**\n * Initializer that generates values initialized to some constant.\n */\nexport class Constant extends Initializer {\n static className = 'Constant';\n private value: number;\n constructor(config: ConstantConfig) {\n super();\n if (typeof config !== 'object') {\n throw new ValueError(\n `Expected argument of type ConstantConfig but got ${config}`);\n }\n if (config.value === undefined) {\n throw new ValueError(`config must have value set but got ${config}`);\n }\n this.value = config.value;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => mul(scalar(this.value), ones(shape, dtype)));\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n value: this.value,\n };\n }\n}\nserialization.SerializationMap.register(Constant);\n\nexport interface RandomUniformConfig {\n /** Lower bound of the range of random values to generate. */\n minval?: number;\n /** Upper bound of the range of random values to generate. */\n maxval?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a uniform\n * distribution.\n *\n * Values will be distributed uniformly between the configured minval and\n * maxval.\n */\nexport class RandomUniform extends Initializer {\n static className = 'RandomUniform';\n readonly DEFAULT_MINVAL = -0.05;\n readonly DEFAULT_MAXVAL = 0.05;\n private minval: number;\n private maxval: number;\n private seed: number;\n\n constructor(config: RandomUniformConfig) {\n super();\n this.minval = config.minval || this.DEFAULT_MINVAL;\n this.maxval = config.maxval || this.DEFAULT_MAXVAL;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return randomUniform(shape, this.minval, this.maxval, dtype);\n }\n\n getConfig(): serialization.ConfigDict {\n return {minval: this.minval, maxval: this.maxval, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomUniform);\n\nexport interface RandomNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a normal\n * distribution.\n */\nexport class RandomNormal extends Initializer {\n static className = 'RandomNormal';\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: RandomNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormal does not support dType bool.`);\n }\n return K.randomNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(RandomNormal);\n\nexport interface TruncatedNormalConfig {\n /** Mean of the random values to generate. */\n mean?: number;\n /** Standard deviation of the random values to generate. */\n stddev?: number;\n /** Used to seed the random generator. */\n seed?: number;\n}\n\n/**\n * Initializer that generates random values initialized to a truncated normal.\n * distribution.\n *\n * These values are similar to values from a `RandomNormal` except that values\n * more than two standard deviations from the mean are discarded and re-drawn.\n * This is the recommended initializer for neural network weights and filters.\n */\nexport class TruncatedNormal extends Initializer {\n static className = 'TruncatedNormal';\n\n readonly DEFAULT_MEAN = 0.;\n readonly DEFAULT_STDDEV = 0.05;\n private mean: number;\n private stddev: number;\n private seed: number;\n\n constructor(config: TruncatedNormalConfig) {\n super();\n this.mean = config.mean || this.DEFAULT_MEAN;\n this.stddev = config.stddev || this.DEFAULT_STDDEV;\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `truncatedNormal does not support dType bool.`);\n }\n return truncatedNormal(shape, this.mean, this.stddev, dtype, this.seed);\n }\n\n getConfig(): serialization.ConfigDict {\n return {mean: this.mean, stddev: this.stddev, seed: this.seed};\n }\n}\nserialization.SerializationMap.register(TruncatedNormal);\n\nexport interface IdentityConfig {\n /**\n * Multiplicative factor to apply to the identity matrix.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates the identity matrix.\n * Only use for square 2D matrices.\n */\nexport class Identity extends Initializer {\n static className = 'Identity';\n private gain: Scalar;\n constructor(config: IdentityConfig) {\n super();\n this.gain = config.gain != null ? scalar(config.gain) : getScalar(1.0);\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2 || shape[0] !== shape[1]) {\n throw new ValueError(\n 'Identity matrix initializer can only be used for' +\n ' 2D square matrices.');\n } else {\n return mul(this.gain, eye(shape[0]));\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {gain: this.gain.get()};\n }\n}\nserialization.SerializationMap.register(Identity);\n\n/**\n * Computes the number of input and output units for a weight shape.\n * @param shape Shape of weight.\n * @param dataFormat data format to use for convolution kernels.\n * Note that all kernels in Keras are standardized on the\n * CHANNEL_LAST ordering (even when inputs are set to CHANNEL_FIRST).\n * @return An length-2 array: fanIn, fanOut.\n */\nfunction computeFans(\n shape: Shape, dataFormat: DataFormat = 'channelsLast'): number[] {\n let fanIn: number;\n let fanOut: number;\n checkDataFormat(dataFormat);\n if (shape.length === 2) {\n fanIn = shape[0];\n fanOut = shape[1];\n } else if ([3, 4, 5].indexOf(shape.length) !== -1) {\n if (dataFormat === 'channelsFirst') {\n const receptiveFieldSize = arrayProd(shape, 2);\n fanIn = shape[1] * receptiveFieldSize;\n fanOut = shape[0] * receptiveFieldSize;\n } else if (dataFormat === 'channelsLast') {\n const receptiveFieldSize = arrayProd(shape, 0, shape.length - 2);\n fanIn = shape[shape.length - 2] * receptiveFieldSize;\n fanOut = shape[shape.length - 1] * receptiveFieldSize;\n }\n } else {\n const shapeProd = arrayProd(shape);\n fanIn = Math.sqrt(shapeProd);\n fanOut = Math.sqrt(shapeProd);\n }\n\n return [fanIn, fanOut];\n}\n\nexport interface VarianceScalingConfig {\n /** Scaling factor (positive float). */\n scale: number;\n\n /** Fanning mode for inputs and outputs. */\n mode: FanMode;\n\n /** Probabilistic distribution of the values. */\n distribution: Distribution;\n\n /** Random number generator seed. */\n seed?: number;\n}\n\n\n/**\n * Initializer capable of adapting its scale to the shape of weights.\n * With distribution=NORMAL, samples are drawn from a truncated normal\n * distribution centered on zero, with `stddev = sqrt(scale / n)` where n is:\n * - number of input units in the weight tensor, if mode = FAN_IN.\n * - number of output units, if mode = FAN_OUT.\n * - average of the numbers of input and output units, if mode = FAN_AVG.\n * With distribution=UNIFORM,\n * samples are drawn from a uniform distribution\n * within [-limit, limit], with `limit = sqrt(3 * scale / n)`.\n */\nexport class VarianceScaling extends Initializer {\n static className = 'VarianceScaling';\n private scale: number;\n private mode: FanMode;\n private distribution: Distribution;\n private seed: number;\n\n /**\n * Constructor of VarianceScaling.\n * @throws ValueError for invalid value in scale.\n */\n constructor(config: VarianceScalingConfig) {\n super();\n if (config.scale < 0.0) {\n throw new ValueError(\n `scale must be a positive float. Got: ${config.scale}`);\n }\n this.scale = config.scale == null ? 1.0 : config.scale;\n this.mode = config.mode;\n checkFanMode(this.mode);\n this.distribution = config.distribution;\n checkDistribution(this.distribution);\n this.seed = config.seed;\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n const fans = computeFans(shape);\n const fanIn = fans[0];\n const fanOut = fans[1];\n let scale = this.scale;\n if (this.mode === 'fanIn') {\n scale /= Math.max(1, fanIn);\n } else if (this.mode === 'fanOut') {\n scale /= Math.max(1, fanOut);\n } else {\n scale /= Math.max(1, (fanIn + fanOut) / 2);\n }\n\n if (this.distribution === 'normal') {\n const stddev = Math.sqrt(scale);\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `${this.getClassName()} does not support dType bool.`);\n }\n return truncatedNormal(shape, 0, stddev, dtype, this.seed);\n } else {\n const limit = Math.sqrt(3 * scale);\n return randomUniform(shape, -limit, limit, dtype);\n }\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n scale: this.scale,\n mode: this.mode,\n distribution: this.distribution,\n seed: this.seed\n };\n }\n}\nserialization.SerializationMap.register(VarianceScaling);\n\nexport interface SeedOnlyInitializerConfig {\n /** Random number generator seed. */\n seed?: number;\n}\n\n/**\n * Glorot uniform initializer, also called Xavier uniform initializer.\n * It draws samples from a uniform distribution within [-limit, limit]\n * where `limit` is `sqrt(6 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf.\n */\nexport class GlorotUniform extends VarianceScaling {\n /**\n * Constructor of GlorotUniform\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'uniform',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotUniform is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * Glorot normal initializer, also called Xavier normal initializer.\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor.\n *\n * Reference:\n * Glorot & Bengio, AISTATS 2010\n * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf\n */\nexport class GlorotNormal extends VarianceScaling {\n /**\n * Constructor of GlorotNormal.\n * @param scale\n * @param mode\n * @param distribution\n * @param seed\n */\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanAvg',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, GlorotNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * He normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * Reference:\n * He et al., http://arxiv.org/abs/1502.01852\n */\nexport class HeNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 2.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, HeNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\n/**\n * LeCun normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(1 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * References:\n * [Self-Normalizing Neural Networks](https://arxiv.org/abs/1706.02515)\n * [Efficient Backprop](http://yann.lecun.com/exdb/publis/pdf/lecun-98b.pdf)\n */\nexport class LeCunNormal extends VarianceScaling {\n constructor(config?: SeedOnlyInitializerConfig) {\n super({\n scale: 1.0,\n mode: 'fanIn',\n distribution: 'normal',\n seed: config == null ? null : config.seed\n });\n }\n\n getClassName(): string {\n // In Python Keras, LeCunNormal is not a class, but a helper method\n // that creates a VarianceScaling object. Use 'VarianceScaling' as\n // class name to be compatible with that.\n return VarianceScaling.className;\n }\n}\n\nexport interface OrthogonalConfig extends SeedOnlyInitializerConfig {\n /**\n * Multiplicative factor to apply to the orthogonal matrix. Defaults to 1.\n */\n gain?: number;\n}\n\n/**\n * Initializer that generates a random orthogonal matrix.\n *\n * Reference:\n * [Saxe et al., http://arxiv.org/abs/1312.6120](http://arxiv.org/abs/1312.6120)\n */\nexport class Orthogonal extends Initializer {\n static className = 'Orthogonal';\n readonly DEFAULT_GAIN = 1;\n protected readonly gain: number;\n protected readonly seed: number;\n\n constructor(config?: OrthogonalConfig) {\n super();\n this.gain = config.gain == null ? this.DEFAULT_GAIN : config.gain;\n this.seed = config.seed;\n\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Random seed is not implemented for Orthogonal Initializer yet.');\n }\n }\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n return tidy(() => {\n if (shape.length !== 2) {\n throw new NotImplementedError(\n 'The Orthogonal Initializer does not support non-2D shapes yet.');\n }\n if (shape[0] * shape[1] > 2000) {\n console.warn(\n `Orthogonal initializer is being called on a matrix with more ` +\n `than 2000 (${shape[0] * shape[1]}) elements: ` +\n `Slowness may result.`);\n }\n\n // TODO(cais): Add seed support.\n const normalizedShape =\n shape[0] > shape[1] ? [shape[1], shape[0]] : shape;\n const a = K.randomNormal(normalizedShape, 0, 1, 'float32') as Tensor2D;\n let q = linalg.gramSchmidt(a) as Tensor2D;\n if (shape[0] > shape[1]) {\n q = q.transpose();\n }\n return mul(getScalar(this.gain), q);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n gain: this.gain,\n seed: this.seed,\n };\n }\n}\nserialization.SerializationMap.register(Orthogonal);\n\n/** @docinline */\nexport type InitializerIdentifier = 'constant'|'glorotNormal'|'glorotUniform'|\n 'heNormal'|'identity'|'leCunNormal'|'ones'|'orthogonal'|'randomNormal'|\n 'randomUniform'|'truncatedNormal'|'varianceScaling'|'zeros'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding registry\n// symbols.\nexport const INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in InitializerIdentifier]: string} = {\n 'constant': 'Constant',\n 'glorotNormal': 'GlorotNormal',\n 'glorotUniform': 'GlorotUniform',\n 'heNormal': 'HeNormal',\n 'identity': 'Identity',\n 'leCunNormal': 'LeCunNormal',\n 'ones': 'Ones',\n 'orthogonal': 'Orthogonal',\n 'randomNormal': 'RandomNormal',\n 'randomUniform': 'RandomUniform',\n 'truncatedNormal': 'TruncatedNormal',\n 'varianceScaling': 'VarianceScaling',\n 'zeros': 'Zeros'\n };\n\nfunction deserializeInitializer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Initializer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'initializer');\n}\n\nexport function serializeInitializer(initializer: Initializer):\n serialization.ConfigDictValue {\n return serializeKerasObject(initializer);\n}\n\nexport function getInitializer(identifier: InitializerIdentifier|Initializer|\n serialization.ConfigDict): Initializer {\n if (typeof identifier === 'string') {\n const className = identifier in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n /* We have four 'helper' classes for common initializers that\n all get serialized as 'VarianceScaling' and shouldn't go through\n the deserializeInitializer pathway. */\n if (className === 'GlorotUniform') {\n return new GlorotUniform();\n } else if (className === 'GlorotNormal') {\n return new GlorotNormal();\n } else if (className === 'HeNormal') {\n return new HeNormal();\n } else if (className === 'LeCunNormal') {\n return new LeCunNormal();\n } else {\n const config = {className, config: {}};\n return deserializeInitializer(config);\n }\n } else if (identifier instanceof Initializer) {\n return identifier;\n } else {\n return deserializeInitializer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constant, ConstantConfig, GlorotNormal, GlorotUniform, HeNormal, Identity, IdentityConfig, Initializer, LeCunNormal, Ones, Orthogonal, OrthogonalConfig, RandomNormal, RandomNormalConfig, RandomUniform, RandomUniformConfig, SeedOnlyInitializerConfig, TruncatedNormal, TruncatedNormalConfig, VarianceScaling, VarianceScalingConfig, Zeros} from './initializers';\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Zeros'\n * }\n */\nexport function zeros(): Zeros {\n return new Zeros();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Ones'\n * }\n */\nexport function ones(): Initializer {\n return new Ones();\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Constant',\n * configParamIndices: [0]\n * }\n */\nexport function constant(config: ConstantConfig): Initializer {\n return new Constant(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomUniform',\n * configParamIndices: [0]\n * }\n */\nexport function randomUniform(config: RandomUniformConfig): Initializer {\n return new RandomUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'RandomNormal',\n * configParamIndices: [0]\n * }\n */\nexport function randomNormal(config: RandomNormalConfig): Initializer {\n return new RandomNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'TruncatedNormal',\n * configParamIndices: [0]\n * }\n */\nexport function truncatedNormal(config: TruncatedNormalConfig): Initializer {\n return new TruncatedNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Identity',\n * configParamIndices: [0]\n * }\n */\nexport function identity(config: IdentityConfig): Initializer {\n return new Identity(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'VarianceScaling',\n * configParamIndices: [0]\n * }\n */\nexport function varianceScaling(config: VarianceScalingConfig): Initializer {\n return new VarianceScaling(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotUniform',\n * configParamIndices: [0]\n * }\n */\nexport function glorotUniform(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotUniform(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'GlorotNormal',\n * configParamIndices: [0]\n * }\n */\nexport function glorotNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new GlorotNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'HeNormal',\n * configParamIndices: [0]\n * }\n */\nexport function heNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new HeNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'LeCunNormal',\n * configParamIndices: [0]\n * }\n */\nexport function leCunNormal(config: SeedOnlyInitializerConfig): Initializer {\n return new LeCunNormal(config);\n}\n\n/**\n * @doc {\n * heading: 'Initializers',\n * namespace: 'initializers',\n * useDocsFrom: 'Orthogonal',\n * configParamIndices: [0]\n * }\n */\nexport function orthogonal(config: OrthogonalConfig): Initializer {\n return new Orthogonal(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: utils/generic_utils.py */\n\n// tslint:disable:max-line-length\nimport {Tensor} from '@tensorflow/tfjs-core';\nimport {ValueError} from '../errors';\nimport {Shape} from '../types';\n// tslint:enable\n\n\n/**\n * Determine whether the input is an Array of Shapes.\n */\nexport function isArrayOfShapes(x: Shape|Shape[]): boolean {\n return Array.isArray(x) && Array.isArray(x[0]);\n}\n\n/**\n * Special case of normalizing shapes to lists.\n *\n * @param x A shape or list of shapes to normalize into a list of Shapes.\n * @return A list of Shapes.\n */\nexport function normalizeShapeList(x: Shape|Shape[]): Shape[] {\n if (x.length === 0) {\n return [];\n }\n if (!Array.isArray(x[0])) {\n return [x] as Shape[];\n }\n return x as Shape[];\n}\n\n/**\n * Helper function to obtain exactly one Tensor.\n * @param xs: A single `Tensor` or an `Array` of `Tensor`s.\n * @return A single `Tensor`. If `xs` is an `Array`, return the first one.\n * @throws ValueError: If `xs` is an `Array` and its length is not 1.\n */\nexport function getExactlyOneTensor(xs: Tensor|Tensor[]): Tensor {\n let x: Tensor;\n if (Array.isArray(xs)) {\n if (xs.length !== 1) {\n throw new ValueError(`Expected Tensor length to be 1; got ${xs.length}`);\n }\n x = xs[0];\n } else {\n x = xs as Tensor;\n }\n return x;\n}\n\n/**\n * Helper function to obtain exactly on instance of Shape.\n *\n * @param shapes Input single `Shape` or Array of `Shape`s.\n * @returns If input is a single `Shape`, return it unchanged. If the input is\n * an `Array` containing exactly one instance of `Shape`, return the instance.\n * Otherwise, throw a `ValueError`.\n * @throws ValueError: If input is an `Array` of `Shape`s, and its length is not\n * 1.\n */\nexport function getExactlyOneShape(shapes: Shape|Shape[]): Shape {\n if (Array.isArray(shapes) && Array.isArray(shapes[0])) {\n if (shapes.length === 1) {\n shapes = shapes as Shape[];\n return shapes[0];\n } else {\n throw new ValueError(`Expected exactly 1 Shape; got ${shapes.length}`);\n }\n } else {\n return shapes as Shape;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {LayerVariable} from '../variables';\n\n/**\n * Count the elements in an Array of LayerVariables.\n *\n * @param weights: The LayerVariables of which the constituent numbers are to\n * be counted.\n * @returns A count of the elements in all the LayerVariables\n */\nexport function countParamsInWeights(weights: LayerVariable[]): number {\n let count = 0;\n for (const weight of weights) {\n if (weight.shape.length === 0) {\n count += 1;\n } else {\n count += weight.shape.reduce((a, b) => a * b);\n }\n }\n return count;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, Tensor, variableGrads} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId} from './backend/state';\nimport {getScopedTensorName, getUniqueTensorName} from './common';\nimport {Constraint} from './constraints';\nimport {NotImplementedError} from './errors';\nimport {HasShape, Shape} from './types';\n\nconst DEFAULT_VARIABLE_NAME_PREFIX = 'Variable';\n\n/**\n * A `LayerVariable` is similar to a `Tensor` in that it has a dtype and shape,\n * but its value is mutable. The value is itself represented as a `Tensor`, and\n * can be read with the `read()` method and updated with the `write()` method.\n */\nexport class LayerVariable {\n readonly dtype: DataType;\n readonly shape: Shape;\n\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName: string;\n readonly trainable: boolean;\n\n protected readonly val: tfc.Variable;\n readonly constraint: Constraint;\n /**\n * Construct Variable from a Tensor.\n *\n * If not explicitly named, the Variable will be given a name with the\n * prefix 'Variable'. Variable names are unique. In the case of name\n * collision, suffixies '_' will be added to the name.\n *\n * @param val Initial value of the Variable.\n * @param name Name of the variable. If `null` or `undefined` is provided, it\n * will default a name with the prefix 'Variable'.\n * @param constraint Optional, projection function to be applied to the\n * variable after optimize updates\n * @throws ValueError if `name` is `null` or `undefined`.\n */\n constructor(\n val: Tensor, dtype: DataType = 'float32',\n name = DEFAULT_VARIABLE_NAME_PREFIX, trainable = true,\n constraint: Constraint = null) {\n this.dtype = dtype == null ? 'float32' : dtype;\n this.shape = val.shape;\n this.id = getNextUniqueTensorId();\n\n name = name == null ? DEFAULT_VARIABLE_NAME_PREFIX : name;\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n\n this.trainable = trainable;\n this.constraint = constraint;\n\n this.val = tfc.variable(val, this.trainable, this.name, this.dtype);\n }\n\n /**\n * Get a snapshot of the Variable's value.\n *\n * The returned value is a snapshot of the Variable's value at the time of\n * the invocation. Future mutations in the value of the tensor will only\n * be reflected by future calls to this method.\n */\n read(): Tensor {\n return this.val;\n }\n\n /**\n * Update the value of the Variable.\n *\n * @param newVal: The new value to update to. Must be consistent with the\n * dtype and shape of the Variable.\n * @return This Variable.\n */\n write(newVal: Tensor) {\n // TODO(cais): Once TF.js Core supports Tensor.dtype, check dtype match.\n checkShapesMatch(this.val, newVal);\n this.val.assign(newVal);\n if (this.constraint != null) {\n this.val.assign(this.constraint.apply(this.val));\n }\n return this;\n }\n}\n\nfunction checkShapesMatch(x: HasShape, y: HasShape): void {\n if (x.shape.toString() !== y.shape.toString()) {\n throw new Error(\n 'Shape mismatch: ' + JSON.stringify(x.shape) + ' vs. ' +\n JSON.stringify(y.shape));\n }\n}\n\n/**\n * Create a Variable.\n * @param x The initial value of the `Variable`.\n * @param dtype optional, the type of the variable.\n * @param name optional, the name of the variable, default provided by\n * Variable.\n * @param constraint optional, a constraint to be applied after every update.\n * @return The newly instantiated `Variable`.\n */\nexport function variable(\n x: Tensor, dtype?: DataType, name?: string,\n constraint?: Constraint): LayerVariable {\n return new LayerVariable(x, dtype, name, true, constraint);\n}\n\n/**\n * Instantiates an all-zeros Variable and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-zero Variable.\n */\nexport function zerosVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n return new LayerVariable(tfc.zeros(shape), dtype, name);\n}\n\n/**\n * Instantiates an all-zeros tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function zerosLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.zerosLike(x), dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor and returns it.\n *\n * @param shape Shape of the tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return An all-ones Variable.\n */\nexport function onesVariable(\n shape: Shape, dtype?: DataType, name?: string): LayerVariable {\n // TODO(cais): Implement logic for dtype.\n const allocated = tfc.ones(shape);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiates an all-ones tensor of the same shape as another tensor.\n *\n * @param x The other tensor.\n * @param dtype DType of the tensor.\n * @param name Name of the tensor.\n * @return A newly instantiated Variable.\n */\nexport function onesLike(\n x: Tensor, dtype?: DataType, name?: string): LayerVariable {\n const allocated = tfc.onesLike(x);\n return new LayerVariable(allocated, dtype, name);\n}\n\n/**\n * Instantiate an identity matrix and returns it, as a Variable\n *\n * @param size Number of rows/columns.\n * @param dtype Data type of returned Variable.\n * @param name Name of returned Variable.\n * @return A Variable, an identity matrix.\n */\nexport function eyeVariable(\n size: number, dtype?: DataType, name?: string): LayerVariable {\n return new LayerVariable(tfc.eye(size), dtype, name);\n}\n\n/**\n * Get a Variable with uniform distribution of values.\n * @param shape Shape of the tensor.\n * @param minval Lower bound of the uniform distribution.\n * @param maxval Upper bound of the uniform distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The uniform-random Variable.\n */\nexport function randomUniformVariable(\n shape: Shape, minval: number, maxval: number, dtype?: DataType,\n seed?: number, name = 'randomUniform'): LayerVariable {\n return new LayerVariable(\n tfc.randomUniform(shape, minval, maxval, dtype), dtype, name);\n}\n\n/**\n * Get a Variable with truncated-normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function truncatedNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'truncatedNormal'): LayerVariable {\n // TODO(cais): Implement logic for dtype and seed once they are supported\n // by deeplearn.js.\n if (dtype === 'bool') {\n throw new NotImplementedError(`randomNormal does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.truncatedNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n/**\n * Get a Variable with normal distribution of values.\n * @param shape Shape of the tensor.\n * @param mean mean value of the normal distribution.\n * @param stddev standard deviation of the normal distribution.\n * @param dtype\n * @param seed\n * @param name Optional name.\n * @return The truncated-normal-random Variable.\n */\nexport function randomNormalVariable(\n shape: Shape, mean = 0.0, stddev = 1.0, dtype?: DataType, seed?: number,\n name = 'randomNormal'): LayerVariable {\n if (dtype === 'bool') {\n throw new NotImplementedError(\n `randomNormalVariable does not support dType bool.`);\n }\n return new LayerVariable(\n tfc.randomNormal(shape, mean, stddev, dtype, seed), dtype, name);\n}\n\n/**\n * Update the value of a Variable.\n * @param x The Variable to be updated.\n * @param xNew The new value to update to.\n * @return The Variable updated.\n */\nexport function update(x: LayerVariable, xNew: Tensor): LayerVariable {\n return x.write(xNew);\n}\n\n/**\n * Update the value of a Variable by adding an increment.\n * @param x The Variable to be updated.\n * @param increment The incrment to add to `x`.\n * @return The Variable updated.\n */\nexport function updateAdd(x: LayerVariable, increment: Tensor): LayerVariable {\n return x.write(tfc.add(x.read(), increment));\n}\n\n/**\n * Update the value of a Variable by subtracting a decrement.\n * @param x The Variable to be updated.\n * @param decrement The decrement to subtract from `x`.\n * @return The Variable updated.\n */\nexport function updateSub(x: LayerVariable, decrement: Tensor): LayerVariable {\n return x.write(tfc.sub(x.read(), decrement));\n}\n\n/**\n * Get the values of an array of Variables.\n *\n * @param tensors An `Array` of `Variable`s to get the values of.\n * @return The values of the inputs, as an `Array` of `Tensor`s.\n */\nexport function batchGetValue(xs: LayerVariable[]): Tensor[] {\n return xs.map(x => x.read());\n}\n\n/**\n * Update the value of multiple Variables at once.\n *\n * @param variablesAndValues An `Array`, each element is of type\n * [Variable, Tensor]. The first item is the\n * `Variable` of which the value is to be updated. The second item\n * carries the new value.\n */\nexport function batchSetValue(\n variablesAndValues: Array<[LayerVariable, Tensor]>): void {\n variablesAndValues.map((variableAndValue) => {\n const variable: LayerVariable = variableAndValue[0];\n variable.write(variableAndValue[1]);\n });\n}\n\n/**\n * Returns the gradients of `variables` w.r.t. the return value of `lossFn`.\n * @param lossFn A function which returns a Scalar to be used as the function\n * value (i.e., numerator) for differentiation.\n * @param variables List of variables to be used as the independent variables\n * (i.e., denominator) for differentiation.\n * @returns An Array of gradients tensors.\n */\nexport function gradients(\n lossFn: () => tfc.Scalar, variables: LayerVariable[]): Tensor[] {\n // TODO(cais): The return type signature can be simplified if deeplearn makes\n // the corresponding type public.\n const variableList =\n variables.map(variable => variable.read() as tfc.Variable);\n const valudAndGrads = variableGrads(lossFn, variableList);\n return variables.map(variable => valudAndGrads.grads[variable.name]);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {DataType, Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getNextUniqueTensorId, getUid} from '../backend/state';\nimport {getScopedTensorName, getUniqueTensorName, nameScope} from '../common';\nimport {Constraint} from '../constraints';\nimport {AttributeError, NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {Initializer} from '../initializers';\nimport {Regularizer} from '../regularizers';\nimport {Kwargs, RegularizerFn, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as types_utils from '../utils/types_utils';\nimport * as variable_utils from '../utils/variable_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n// TODO(michaelterry): This is a stub until it's defined.\nexport type Op = (x: LayerVariable) => LayerVariable;\n\n/**\n * Constructor arguments for InputSpec.\n */\nexport interface InputSpecConfig {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n}\n\n/**\n * Specifies the ndim, dtype and shape of every input to a layer.\n *\n * Every layer should expose (if appropriate) an `inputSpec` attribute:\n * a list of instances of InputSpec (one per input tensor).\n *\n * A null entry in a shape is compatible with any dimension,\n * a null shape is compatible with any shape.\n */\nexport class InputSpec {\n /** Expected datatype of the input. */\n dtype?: DataType;\n /** Expected shape of the input (may include null for unchecked axes). */\n shape?: Shape;\n /** Expected rank of the input. */\n ndim?: number;\n /** Maximum rank of the input. */\n maxNDim?: number;\n /** Minimum rank of the input. */\n minNDim?: number;\n /** Dictionary mapping integer axes to a specific dimension value. */\n axes?: {[axis: number]: number};\n\n constructor(config: InputSpecConfig) {\n this.dtype = config.dtype;\n this.shape = config.shape;\n /*\n TODO(michaelterry): Could throw error if ndim and shape are both defined\n (then backport).\n */\n if (config.shape != null) {\n this.ndim = config.shape.length;\n } else {\n this.ndim = config.ndim;\n }\n this.maxNDim = config.maxNDim;\n this.minNDim = config.minNDim;\n this.axes = config.axes || {};\n }\n}\n\n/**\n * `SymbolicTensor` is a placeholder for a Tensor without any concrete value.\n *\n * They are most often encountered when building a graph of `Layer`s for a\n * a `Model` and the input data's shape, but not values are known.\n */\n/** @doc {heading: 'Models', 'subheading': 'Classes'} */\nexport class SymbolicTensor {\n /* A unique ID for the tensor to be able to differentiate tensors. */\n readonly id: number;\n // The fully scoped name of this Variable, including a unique suffix if needed\n readonly name: string;\n // The originally requested fully scoped name of this Variable, not including\n // any unique suffix. This may be needed when restoring weights because this\n // original name is used as a key.\n readonly originalName?: string;\n /**\n * Rank/dimensionality of the tensor.\n */\n readonly rank: number;\n /**\n * Replacement for _keras_history.\n */\n nodeIndex: number;\n /**\n * Replacement for _keras_history.\n */\n tensorIndex: number;\n\n /**\n *\n * @param dtype\n * @param shape\n * @param sourceLayer The Layer that produced this symbolic tensor.\n * @param inputs The inputs passed to sourceLayer's __call__() method.\n * @param nodeIndex\n * @param tensorIndex\n * @param callArgs The keyword arguments passed to the __call__() method.\n * @param name\n * @param outputTensorIndex The index of this tensor in the list of outputs\n * returned by apply().\n */\n constructor(\n readonly dtype: DataType, readonly shape: Shape,\n public sourceLayer: Layer, readonly inputs: SymbolicTensor[],\n readonly callArgs: Kwargs, name?: string,\n readonly outputTensorIndex?: number) {\n this.id = getNextUniqueTensorId();\n if (name != null) {\n this.originalName = getScopedTensorName(name);\n this.name = getUniqueTensorName(this.originalName);\n }\n this.rank = shape.length;\n }\n}\n\n/**\n * Constructor arguments for Node.\n */\nexport interface NodeConfig {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`.\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n}\n\nlet _nextNodeID = 0;\n\n/**\n * A `Node` describes the connectivity between two layers.\n *\n * Each time a layer is connected to some new input,\n * a node is added to `layer.inboundNodes`.\n *\n * Each time the output of a layer is used by another layer,\n * a node is added to `layer.outboundNodes`.\n *\n * `nodeIndices` and `tensorIndices` are basically fine-grained coordinates\n * describing the origin of the `inputTensors`, verifying the following:\n *\n * `inputTensors[i] ==\n * inboundLayers[i].inboundNodes[nodeIndices[i]].outputTensors[\n * tensorIndices[i]]`\n *\n * A node from layer A to layer B is added to:\n * A.outboundNodes\n * B.inboundNodes\n */\nexport class Node {\n /**\n * The layer that takes `inputTensors` and turns them into `outputTensors`\n * (the node gets created when the `call` method of the layer is called).\n */\n outboundLayer: Layer;\n /**\n * A list of layers, the same length as `inputTensors`, the layers from where\n * `inputTensors` originate.\n */\n inboundLayers: Layer[];\n /**\n * A list of integers, the same length as `inboundLayers`. `nodeIndices[i]` is\n * the origin node of `inputTensors[i]` (necessary since each inbound layer\n * might have several nodes, e.g. if the layer is being shared with a\n * different data stream).\n */\n nodeIndices: number[];\n /**\n * A list of integers, the same length as `inboundLayers`. `tensorIndices[i]`\n * is the index of `inputTensors[i]` within the output of the inbound layer\n * (necessary since each inbound layer might have multiple tensor outputs,\n * with each one being independently manipulable).\n */\n tensorIndices: number[];\n /** List of input tensors. */\n inputTensors: SymbolicTensor[];\n /** List of output tensors. */\n outputTensors: SymbolicTensor[];\n /** List of input masks (a mask can be a tensor, or null). */\n inputMasks: Tensor[];\n /** List of output masks (a mask can be a tensor, or null). */\n outputMasks: Tensor[];\n /** List of input shape tuples. */\n inputShapes: Shape|Shape[];\n /** List of output shape tuples. */\n outputShapes: Shape|Shape[];\n\n readonly id: number;\n\n constructor(\n config: NodeConfig,\n // TODO(michaelterry): Define actual type for this.\n public callArgs?: Kwargs) {\n this.id = _nextNodeID++;\n /*\n Layer instance (NOT a list).\n this is the layer that takes a list of input tensors\n and turns them into a list of output tensors.\n the current node will be added to\n the inboundNodes of outboundLayer.\n */\n this.outboundLayer = config.outboundLayer;\n\n /*\n The following 3 properties describe where\n the input tensors come from: which layers,\n and for each layer, which node and which\n tensor output of each node.\n */\n\n // List of layer instances.\n this.inboundLayers = config.inboundLayers;\n // List of integers, 1:1 mapping with inboundLayers.\n this.nodeIndices = config.nodeIndices;\n // List of integers, 1:1 mapping with inboundLayers.\n this.tensorIndices = config.tensorIndices;\n\n /*\n Following 2 properties:\n tensor inputs and outputs of outboundLayer.\n */\n\n // List of tensors. 1:1 mapping with inboundLayers.\n this.inputTensors = config.inputTensors;\n // List of tensors, created by outboundLayer.call().\n this.outputTensors = config.outputTensors;\n\n /*\n Following 2 properties: input and output masks.\n List of tensors, 1:1 mapping with inputTensor.\n */\n this.inputMasks = config.inputMasks;\n // List of tensors, created by outboundLayer.computeMask().\n this.outputMasks = config.outputMasks;\n\n // Following 2 properties: input and output shapes.\n\n // List of shape tuples, shapes of inputTensors.\n this.inputShapes = config.inputShapes;\n // List of shape tuples, shapes of outputTensors.\n this.outputShapes = config.outputShapes;\n\n // Add nodes to all layers involved.\n for (const layer of config.inboundLayers) {\n if (layer != null) {\n layer.outboundNodes.push(this);\n }\n }\n config.outboundLayer.inboundNodes.push(this);\n }\n\n getConfig(): serialization.ConfigDict {\n const inboundNames: string[] = [];\n for (const layer of this.inboundLayers) {\n if (layer != null) {\n inboundNames.push(layer.name);\n } else {\n inboundNames.push(null);\n }\n }\n return {\n outboundLayer: this.outboundLayer ? this.outboundLayer.name : null,\n inboundLayers: inboundNames,\n nodeIndices: this.nodeIndices,\n tensorIndices: this.tensorIndices\n };\n }\n}\n\n/** Constructor arguments for Layer. */\nexport interface LayerConfig {\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n inputShape?: Shape;\n /**\n * If defined, will be used to create an input layer to insert before this\n * layer. If both `inputShape` and `batchInputShape` are defined,\n * `batchInputShape` will be used. This argument is only applicable to input\n * layers (the first layer of a model).\n */\n batchInputShape?: Shape;\n /**\n * If `inputShape` is specified and `batchInputShape` is *not* specifiedd,\n * `batchSize` is used to construct the `batchInputShape`: `[batchSize,\n * ...inputShape]`\n */\n batchSize?: number;\n /**\n * The data-type for this layer. Defaults to 'float32'.\n * This argument is only applicable to input layers (the first layer of a\n * model).\n */\n dtype?: DataType;\n /** Name for this layer. */\n name?: string;\n /** Whether this layer is trainable. Defaults to true. */\n trainable?: boolean;\n /** Whether the weights of this layer are updatable by `fit`. */\n updatable?: boolean;\n /**\n * Initial weight values of the layer.\n */\n weights?: Tensor[];\n /** Legacy support. Do not use for new code. */\n inputDType?: DataType;\n}\n\n// If necessary, add `output` arguments to the CallHook function.\n// This is currently used for testing only, but may be used for debugger-related\n// purposes in the future.\nexport type CallHook = (inputs: Tensor|Tensor[], kwargs: Kwargs) => void;\n\nlet _nextLayerID = 0;\n\n/**\n * A layer is a grouping of operations and weights that can be composed to\n * create a `Model`.\n *\n * Layers are constructed by using the functions under the\n * [tf.layers](#Layers-Basic) namespace.\n */\n/** @doc {heading: 'Layers', subheading: 'Classes', namespace: 'layers'} */\nexport abstract class Layer extends serialization.Serializable {\n /** Name for this layer. Must be unique within a model. */\n name: string;\n /**\n * List of InputSpec class instances.\n *\n * Each entry describes one required input:\n * - ndim\n * - dtype\n * A layer with `n` input tensors must have an `inputSpec` of length `n`.\n */\n inputSpec: InputSpec[];\n supportsMasking: boolean;\n /** Whether the layer weights will be updated during training. */\n trainable: boolean;\n updatable: boolean;\n batchInputShape: Shape;\n dtype: DataType;\n initialWeights: Tensor[];\n\n inboundNodes: Node[];\n outboundNodes: Node[];\n\n activityRegularizer: Regularizer;\n\n protected _trainableWeights: LayerVariable[];\n private _nonTrainableWeights: LayerVariable[];\n private _losses: RegularizerFn[];\n // TODO(cais): _updates is currently unused.\n private _updates: Tensor[];\n private _built: boolean;\n private _callHook: CallHook = null;\n\n private _addedWeightNames: string[] = [];\n\n readonly id: number;\n\n // Porting Notes: PyKeras does not have this property in this base Layer\n // class. Instead lets Layer subclass set it dynamically and checks the\n // value with `hasattr`. In tfjs-layers, we let this be a member of this\n // base class.\n protected _stateful = false;\n\n constructor(config: LayerConfig) {\n super();\n this.id = _nextLayerID++;\n\n this.activityRegularizer = null;\n\n this.inputSpec = null;\n this.supportsMasking = false;\n\n // These properties will be set upon call of this.build()\n this._trainableWeights = [];\n this._nonTrainableWeights = [];\n this._losses = [];\n this._updates = [];\n this._built = false;\n\n /*\n These lists will be filled via successive calls\n to this.addInboundNode().\n */\n this.inboundNodes = [];\n this.outboundNodes = [];\n\n let name = config.name;\n if (!name) {\n const prefix = this.getClassName();\n name = generic_utils.toSnakeCase(prefix) + '_' + getUid(prefix);\n }\n this.name = name;\n\n this.trainable = config.trainable == null ? true : config.trainable;\n this.updatable = config.updatable == null ? true : config.updatable;\n\n if (config.inputShape != null || config.batchInputShape != null) {\n /*\n In this case we will later create an input layer\n to insert before the current layer\n */\n let batchInputShape: Shape;\n if (config.batchInputShape != null) {\n batchInputShape = config.batchInputShape;\n } else if (config.inputShape != null) {\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n batchInputShape = [batchSize].concat(config.inputShape);\n }\n this.batchInputShape = batchInputShape;\n\n // Set dtype.\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = config.inputDType;\n }\n if (dtype == null) {\n dtype = 'float32';\n }\n this.dtype = dtype;\n }\n\n if (config.weights != null) {\n this.initialWeights = config.weights;\n } else {\n this.initialWeights = null;\n }\n }\n\n /**\n * Converts a layer and its index to a unique (immutable type) name.\n * This function is used internally with `this.containerNodes`.\n * @param layer The layer.\n * @param nodeIndex The layer's position (e.g. via enumerate) in a list of\n * nodes.\n *\n * @returns The unique name.\n */\n protected static nodeKey(layer: Layer, nodeIndex: number) {\n return layer.name + '_ib-' + nodeIndex.toString();\n }\n\n /**\n * Returns this.inboundNode at index nodeIndex.\n *\n * Porting note: This is a replacement for _get_node_attribute_at_index()\n * @param nodeIndex\n * @param attrName The name of the attribute related to request for this node.\n */\n private getNodeAtIndex(nodeIndex: number, attrName: string): Node {\n if (this.inboundNodes.length === 0) {\n throw new RuntimeError(\n 'The layer has never been called ' +\n `and thus has no defined ${attrName}.`);\n }\n if (this.inboundNodes.length <= nodeIndex) {\n throw new ValueError(\n `Asked to get ${attrName} at node ${nodeIndex}, ` +\n `but the layer has only ${this.inboundNodes.length} inbound nodes.`);\n }\n return this.inboundNodes[nodeIndex];\n }\n\n /**\n * Retrieves the input tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple inputs).\n */\n getInputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer at a given node.\n *\n * @param nodeIndex Integer, index of the node from which to retrieve the\n * attribute. E.g. `nodeIndex=0` will correspond to the first time the layer\n * was called.\n *\n * @return A tensor (or list of tensors if the layer has multiple outputs).\n */\n getOutputAt(nodeIndex: number): SymbolicTensor|SymbolicTensor[] {\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(nodeIndex, 'output').outputTensors);\n }\n\n // Properties\n\n /**\n * Retrieves the input tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Input tensor or list of input tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get input(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer input\" ' +\n 'is ill-defined. ' +\n 'Use `getInputAt(nodeIndex)` instead.');\n } else if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' is not connected, no input to return.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'input').inputTensors);\n }\n\n /**\n * Retrieves the output tensor(s) of a layer.\n *\n * Only applicable if the layer has exactly one inbound node,\n * i.e. if it is connected to one incoming layer.\n *\n * @return Output tensor or list of output tensors.\n *\n * @exception AttributeError if the layer is connected to more than one\n * incoming layers.\n */\n get output(): SymbolicTensor|SymbolicTensor[] {\n if (this.inboundNodes.length === 0) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has no inbound nodes.');\n }\n if (this.inboundNodes.length > 1) {\n throw new AttributeError(\n `Layer ${this.name}` +\n ' has multiple inbound nodes, ' +\n 'hence the notion of \"layer output\" ' +\n 'is ill-defined. ' +\n 'Use `getOutputAt(nodeIndex)` instead.');\n }\n return generic_utils.singletonOrArray(\n this.getNodeAtIndex(0, 'output').outputTensors);\n }\n\n get losses(): RegularizerFn[] {\n return this._losses;\n }\n\n /**\n * Retrieves the Layer's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Layer.loss in PyKeras.\n // In PyKeras, Layer.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return this.losses.map(lossFn => lossFn());\n }\n\n get updates(): Tensor[] {\n return this._updates;\n }\n\n get built(): boolean {\n return this._built;\n }\n\n set built(built: boolean) {\n this._built = built;\n }\n\n get trainableWeights(): LayerVariable[] {\n if (this.trainable) {\n return this._trainableWeights;\n } else {\n return [];\n }\n }\n\n set trainableWeights(weights: LayerVariable[]) {\n this._trainableWeights = weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return this._trainableWeights.concat(this._nonTrainableWeights);\n } else {\n return this._nonTrainableWeights;\n }\n }\n\n set nonTrainableWeights(weights: LayerVariable[]) {\n this._nonTrainableWeights = weights;\n }\n\n /**\n * The concatenation of the lists trainableWeights and nonTrainableWeights\n * (in this order).\n */\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n get stateful(): boolean {\n return this._stateful;\n }\n\n /**\n * Checks compatibility between the layer and provided inputs.\n *\n * This checks that the tensor(s) `input`\n * verify the input assumptions of the layer\n * (if any). If not, exceptions are raised.\n *\n * @param inputs Input tensor or list of input tensors.\n *\n * @exception ValueError in case of mismatch between\n * the provided inputs and the expectations of the layer.\n */\n protected assertInputCompatibility(inputs: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): void {\n inputs = generic_utils.toList(inputs);\n if (this.inputSpec == null || this.inputSpec.length === 0) {\n return;\n }\n const inputSpec = generic_utils.toList(this.inputSpec);\n if (inputs.length !== inputSpec.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${inputSpec.length} inputs, ` +\n `but it received ${inputs.length} input tensors. ` +\n `Input received: ${inputs}`);\n }\n for (let inputIndex = 0; inputIndex < inputs.length; inputIndex++) {\n const x = inputs[inputIndex];\n const spec: InputSpec = inputSpec[inputIndex];\n if (spec == null) {\n continue;\n }\n\n // Check ndim.\n const ndim = x.rank;\n if (spec.ndim != null) {\n if (ndim !== spec.ndim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}: ` +\n `expected ndim=${spec.ndim}, found ndim=${ndim}`);\n }\n }\n if (spec.maxNDim != null) {\n if (ndim > spec.maxNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected max_ndim=${spec.maxNDim}, found ndim=${ndim}`);\n }\n }\n if (spec.minNDim != null) {\n if (ndim < spec.minNDim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name}` +\n `: expected min_ndim=${spec.minNDim}, found ndim=${ndim}.`);\n }\n }\n\n // Check dtype.\n if (spec.dtype != null) {\n if (x.dtype !== spec.dtype) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ${this.name} ` +\n `: expected dtype=${spec.dtype}, found dtype=${x.dtype}.`);\n }\n }\n\n // Check specific shape axes.\n if (spec.axes) {\n const xShape = x.shape;\n for (const key in spec.axes) {\n const axis = Number(key);\n const value = spec.axes[key];\n // Perform Python-style slicing in case axis < 0;\n // TODO(cais): Use https://github.com/alvivi/typescript-underscore to\n // ensure type safety through Underscore calls.\n const xShapeAtAxis =\n axis >= 0 ? xShape[axis] : xShape[xShape.length + axis];\n if (value != null && [value, null].indexOf(xShapeAtAxis) === -1) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected axis ${axis} of input shape to ` +\n `have value ${value} but got shape ${xShape}.`);\n }\n }\n }\n\n // Check shape.\n if (spec.shape != null) {\n for (let i = 0; i < spec.shape.length; ++i) {\n const specDim = spec.shape[i];\n const dim = x.shape[i];\n if (specDim != null && dim != null) {\n if (specDim !== dim) {\n throw new ValueError(\n `Input ${inputIndex} is incompatible with layer ` +\n `${this.name}: expected shape=${spec.shape}, ` +\n 'found shape=${xShape}.');\n }\n }\n }\n }\n }\n }\n\n /**\n * This is where the layer's logic lives.\n *\n * @param inputs Input tensor, or list/tuple of input tensors.\n * @param kwargs Additional keyword arguments.\n *\n * @return A tensor or list/tuple of tensors.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return inputs;\n }\n\n protected invokeCallHook(inputs: Tensor|Tensor[], kwargs: Kwargs) {\n if (this._callHook != null) {\n this._callHook(inputs, kwargs);\n }\n }\n\n /**\n * Set call hook.\n * This is currently used for testing only.\n * @param callHook\n */\n setCallHook(callHook: CallHook) {\n this._callHook = callHook;\n }\n\n /**\n * Clear call hook.\n * This is currently used for testing only.\n */\n clearCallHook() {\n this._callHook = null;\n }\n\n /**\n * Builds or executes a `Layer's logic.\n *\n * When called with `Tensor`(s), execute the `Layer`s computation and\n * return Tensor(s). For example:\n *\n * ```js\n * const denseLayer = tf.layers.dense({\n * units: 1,\n * kernelInitializer: 'zeros',\n * useBias: false\n * });\n *\n * // Invoke the layer's apply() method with a `Tensor` (with concrete\n * // numeric values).\n * const input = tf.ones([2, 2]);\n * const output = denseLayer.apply(input);\n *\n * // The output's value is expected to be [[0], [0]], due to the fact that\n * // the dense layer has a kernel initialized to all-zeros and does not have\n * // a bias.\n * output.print();\n * ```\n *\n * When called with `SymbolicTensor`(s), this will prepare the layer for\n * future execution. This entails internal book-keeping on shapes of\n * expected Tensors, wiring layers together, and initializing weights.\n *\n * Calling `apply` with `SymbolicTensor`s are typically used during the\n * building of non-`Sequential` models. For example:\n *\n * ```js\n * const flattenLayer = tf.layers.flatten();\n * const denseLayer = tf.layers.dense({units: 1});\n *\n * // Use tf.layers.input() to obtain a SymbolicTensor as input to apply().\n * const input = tf.input({shape: [2, 2]});\n * const output1 = flattenLayer.apply(input);\n *\n * // output1.shape is [null, 4]. The first dimension is the undetermined\n * // batch size. The second dimension comes from flattening the [2, 2]\n * // shape.\n * console.log(JSON.stringify(output1.shape));\n *\n * // The output SymbolicTensor of the flatten layer can be used to call\n * // the apply() of the dense layer:\n * const output2 = denseLayer.apply(output1);\n *\n * // output2.shape is [null, 1]. The first dimension is the undetermined\n * // batch size. The second dimension matches the number of units of the\n * // dense layer.\n * console.log(JSON.stringify(output2.shape));\n *\n * // The input and output and be used to construct a model that consists\n * // of the flatten and dense layers.\n * const model = tf.model({inputs: input, outputs: output2});\n * ```\n *\n * @param inputs a `Tensor` or `SymbolicTensor` or an Array of them.\n * @param kwargs Additional keyword arguments to be passed to `call()`.\n *\n * @return Output of the layer's `call` method.\n *\n * @exception ValueError error in case the layer is missing shape information\n * for its `build` call.\n */\n // Porting Note: This is a replacement for __call__() in Python.\n /** @doc {heading: 'Models', 'subheading': 'Classes'} */\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n kwargs = kwargs || {};\n\n // Ensure inputs are all the same type.\n const inputsList = generic_utils.toList(inputs);\n\n let allAreSymbolic = true;\n for (const input of inputsList) {\n if (!(input instanceof SymbolicTensor)) {\n allAreSymbolic = false;\n break;\n }\n }\n let noneAreSymbolic = true;\n for (const input of inputsList) {\n if (input instanceof SymbolicTensor) {\n noneAreSymbolic = false;\n break;\n }\n }\n\n if (allAreSymbolic === noneAreSymbolic) {\n throw new ValueError(\n 'Arguments to apply() must be all ' +\n 'SymbolicTensors or all Tensors');\n }\n\n // TODO(michaelterry): nameScope() may not be necessary.\n return nameScope(this.name, () => {\n // Handle laying building (weight creating, input spec locking).\n if (!this.built) {\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec specified in the layer constructor.\n */\n this.assertInputCompatibility(inputs);\n\n // Collect input shapes to build layer.\n const inputShapes: Shape[] = [];\n for (const xElem of generic_utils.toList(inputs)) {\n inputShapes.push(xElem.shape);\n }\n this.build(generic_utils.singletonOrArray(inputShapes));\n this.built = true;\n\n // Load weights that were specified at layer instantiation.\n if (this.initialWeights) {\n this.setWeights(this.initialWeights);\n }\n }\n\n /*\n Throw exceptions in case the input is not compatible\n with the inputSpec set at build time.\n */\n this.assertInputCompatibility(inputs);\n\n // Handle mask propagation.\n // TODO(michaelterry): Mask propagation not currently implemented.\n\n // Actually call the layer, collecting output(s), mask(s), and shape(s).\n if (noneAreSymbolic) {\n let output = this.call(inputs as Tensor | Tensor[], kwargs);\n // TODO(michaelterry): Compute the outputMask\n\n // If the layer returns tensors from its inputs, unmodified,\n // we copy them to avoid loss of tensor metadata.\n const outputList: Tensor[] = generic_utils.toList(output);\n const outputListCopy: Tensor[] = [];\n // TODO(michaelterry): This copying may not be necessary given our eager\n // backend.\n for (let x of outputList) {\n if (inputsList.indexOf(x) !== -1) {\n x = x.clone();\n }\n outputListCopy.push(x);\n }\n output = generic_utils.singletonOrArray(outputListCopy);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n // TODO(michaelterry): Call addInboundNode()?\n return output;\n } else {\n const inputShape = collectInputShape(inputs);\n const outputShape = this.computeOutputShape(inputShape);\n let output: SymbolicTensor|SymbolicTensor[];\n const outputDType = guessOutputDType(inputs);\n this.warnOnIncompatibleInputShape(\n Array.isArray(inputs) ? inputShape[0] as Shape :\n inputShape as Shape);\n\n if (outputShape != null && outputShape.length > 0 &&\n Array.isArray(outputShape[0])) {\n // We have multiple output shapes. Create multiple output tensors.\n output = (outputShape as Shape[])\n .map(\n (shape, index) => new SymbolicTensor(\n outputDType, shape, this,\n generic_utils.toList(inputs), kwargs, this.name,\n index));\n } else {\n output = new SymbolicTensor(\n outputDType, outputShape as Shape, this,\n generic_utils.toList(inputs), kwargs, this.name);\n }\n\n /*\n Add an inbound node to the layer, so that it keeps track\n of the call and of all new variables created during the call.\n This also updates the layer history of the output tensor(s).\n If the input tensor(s) had no previous history,\n this does nothing.\n */\n this.addInboundNode(\n inputs as SymbolicTensor | SymbolicTensor[], output, null, null,\n inputShape, outputShape, kwargs);\n\n if (this.activityRegularizer != null) {\n throw new NotImplementedError(\n 'Layer invocation in the presence of activity ' +\n 'regularizer(s) is not supported yet.');\n }\n\n return output;\n }\n });\n }\n\n /**\n * Check compatibility between input shape and this layer's batchInputShape.\n *\n * Print warning if any incompatibility is found.\n *\n * @param inputShape Input shape to be checked.\n */\n protected warnOnIncompatibleInputShape(inputShape: Shape) {\n if (this.batchInputShape == null) {\n return;\n } else if (inputShape.length !== this.batchInputShape.length) {\n console.warn(\n `The rank of the input tensor provided (shape: ` +\n `${JSON.stringify(inputShape)}) does not match that of the ` +\n `batchInputShape (${JSON.stringify(this.batchInputShape)}) ` +\n `of the layer ${this.name}`);\n } else {\n let dimMismatch = false;\n this.batchInputShape.forEach((dimension, i) => {\n if (dimension != null && inputShape[i] != null &&\n inputShape[i] !== dimension) {\n dimMismatch = true;\n }\n });\n if (dimMismatch) {\n console.warn(\n `The shape of the input tensor ` +\n `(${JSON.stringify(inputShape)}) does not ` +\n `match the expectation of layer ${this.name}: ` +\n `${JSON.stringify(this.batchInputShape)}`);\n }\n }\n }\n\n /**\n * Retrieves the output shape(s) of a layer.\n *\n * Only applicable if the layer has only one inbound node, or if all inbound\n * nodes have the same output shape.\n *\n * @returns Output shape or shapes.\n * @throws AttributeError: if the layer is connected to more than one incoming\n * nodes.\n */\n get outputShape(): Shape|Shape[] {\n if (this.inboundNodes == null || this.inboundNodes.length === 0) {\n throw new AttributeError(\n `The layer ${this.name} has never been called and thus has no ` +\n `defined output shape.`);\n }\n const allOutputShapes: string[] = [];\n for (const node of this.inboundNodes) {\n const shapeString = JSON.stringify(node.outputShapes);\n if (allOutputShapes.indexOf(shapeString) === -1) {\n allOutputShapes.push(shapeString);\n }\n }\n if (allOutputShapes.length === 1) {\n const outputShapes = this.inboundNodes[0].outputShapes;\n if (Array.isArray(outputShapes) && Array.isArray(outputShapes[0]) &&\n outputShapes.length === 1) {\n return (outputShapes as Shape[])[0];\n } else {\n return outputShapes;\n }\n\n } else {\n throw new AttributeError(\n `The layer ${this.name} has multiple inbound nodes with different ` +\n `output shapes. Hence the notion of \"outut shape\" is ill-defined ` +\n `for the layer.`);\n // TODO(cais): Implement getOutputShapeAt().\n }\n }\n\n /**\n * Counts the total number of numbers (e.g., float32, int32) in the\n * weights.\n *\n * @returns An integer count.\n * @throws RuntimeError: If the layer is not built yet (in which case its\n * weights are not defined yet.)\n */\n countParams(): number {\n if (!this.built) {\n throw new RuntimeError(\n `You tried to call countParams() on ${this.name}, ` +\n `but the layer is not built yet. Build it first by calling ` +\n `build(batchInputShape).`);\n }\n return variable_utils.countParamsInWeights(this.weights);\n }\n\n /**\n * Creates the layer weights.\n *\n * Must be implemented on all layers that have weights.\n *\n * Called when apply() is called to construct the weights.\n *\n * @param inputShape A `Shape` or array of `Shape` (unused).\n */\n build(inputShape: Shape|Shape[]) {\n this.built = true;\n }\n\n /**\n * Returns the current values of the weights of the layer.\n *\n * @param trainableOnly Whether to get the values of only trainable weights.\n * @returns Weight values as an `Array` of `Tensor`s.\n */\n getWeights(trainableOnly = false): Tensor[] {\n return batchGetValue(trainableOnly ? this.trainableWeights : this.weights);\n }\n\n /**\n * Sets the weights of the layer, from Tensors.\n *\n * @param weights a list of Tensors. The number of arrays and their shape\n * must match number of the dimensions of the weights of the layer (i.e.\n * it should match the output of `getWeights`).\n *\n * @exception ValueError If the provided weights list does not match the\n * layer's specifications.\n */\n setWeights(weights: Tensor[]): void {\n tidy(() => {\n const params = this.weights;\n if (params.length !== weights.length) {\n // TODO(cais): Restore the following and use `providedWeights`, instead\n // of `weights` in the error message, once the deeplearn.js bug is\n // fixed: https://github.com/PAIR-code/deeplearnjs/issues/498 const\n // providedWeights = JSON.stringify(weights).substr(0, 50);\n throw new ValueError(\n `You called setWeights(weights) on layer \"${this.name}\" ` +\n `with a weight list of length ${weights.length}, ` +\n `but the layer was expecting ${params.length} weights. ` +\n `Provided weights: ${weights}...`);\n }\n if (params.length === 0) {\n return;\n }\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n const paramValues = batchGetValue(params);\n for (let i = 0; i < paramValues.length; ++i) {\n const pv = paramValues[i];\n const p = params[i];\n const w = weights[i];\n if (!util.arraysEqual(pv.shape, w.shape)) {\n throw new ValueError(\n `Layer weight shape ${pv.shape} ` +\n `not compatible with provided weight shape ${w.shape}`);\n }\n weightValueTuples.push([p, w]);\n }\n batchSetValue(weightValueTuples);\n });\n }\n\n /**\n * Adds a weight variable to the layer.\n *\n * @param name Name of the new weight variable.\n * @param shape The shape of the weight.\n * @param dtype The dtype of the weight.\n * @param initializer An initializer instance.\n * @param regularizer A regularizer instance.\n * @param trainable Whether the weight should be trained via backprop or not\n * (assuming that the layer itself is also trainable).\n * @param constraint An optional trainable.\n * @return The created weight variable.\n */\n protected addWeight(\n name: string, shape: Shape, dtype?: DataType, initializer?: Initializer,\n regularizer?: Regularizer, trainable?: boolean,\n constraint?: Constraint): LayerVariable {\n // Reject duplicate weight names.\n if (this._addedWeightNames.indexOf(name) !== -1) {\n throw new ValueError(\n `Duplicate weight name ${name} for layer ${this.name}`);\n }\n this._addedWeightNames.push(name);\n\n if (dtype == null) {\n dtype = 'float32';\n }\n const weight = new LayerVariable(\n initializer.apply(shape, dtype), dtype, name, trainable, constraint);\n // Request backend not to dispose the weights of the model on scope() exit.\n if (regularizer != null) {\n this.addLoss(() => regularizer.apply(weight.read()));\n }\n if (trainable == null) {\n trainable = true;\n }\n if (trainable) {\n this._trainableWeights.push(weight);\n } else {\n this._nonTrainableWeights.push(weight);\n }\n return weight;\n }\n\n /**\n * Add losses to the layer.\n *\n * The loss may potentionally be conditional on some inputs tensors,\n * for instance activity losses are conditional on the layer's inputs.\n */\n addLoss(losses: RegularizerFn|RegularizerFn[]): void {\n if (losses == null || Array.isArray(losses) && losses.length === 0) {\n return;\n }\n // Update this.losses\n losses = generic_utils.toList(losses);\n if (this._losses !== undefined && this._losses !== null) {\n this.losses.push(...losses);\n }\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n if (!this.supportsMasking) {\n if (mask != null) {\n if (Array.isArray(mask)) {\n mask.forEach(maskElement => {\n if (maskElement != null) {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n });\n } else {\n throw new TypeError(\n `Layer ${this.name} does not support masking,` +\n 'but was passed an inputMask.');\n }\n }\n // masking not explicitly supported: return null as mask\n return null;\n }\n // if masking is explictly supported, by default\n // carry over the input mask\n return mask;\n }\n\n /**\n * Internal method to create an inbound node for the layer.\n *\n * @param inputTensors List of input tensors.\n * @param outputTensors List of output tensors.\n * @param inputMasks List of input masks (a mask can be a tensor, or null).\n * @param outputMasks List of output masks (a mask can be a tensor, or null).\n * @param inputShapes List of input shape tuples.\n * @param outputShapes List of output shape tuples.\n * @param kwargs Dictionary of keyword arguments that were passed to the\n * `call` method of the layer at the call that created the node.\n */\n private addInboundNode(\n inputTensors: SymbolicTensor|SymbolicTensor[],\n outputTensors: SymbolicTensor|SymbolicTensor[],\n inputMasks: Tensor|Tensor[], outputMasks: Tensor|Tensor[],\n inputShapes: Shape|Shape[], outputShapes: Shape|Shape[],\n kwargs: {} = null): void {\n const inputTensorList: SymbolicTensor[] =\n generic_utils.toList(inputTensors);\n outputTensors = generic_utils.toList(outputTensors);\n inputMasks = generic_utils.toList(inputMasks);\n outputMasks = generic_utils.toList(outputMasks);\n inputShapes = types_utils.normalizeShapeList(inputShapes);\n outputShapes = types_utils.normalizeShapeList(outputShapes);\n\n // Collect input tensor(s) coordinates.\n const inboundLayers: Layer[] = [];\n const nodeIndices: number[] = [];\n const tensorIndices: number[] = [];\n for (const x of inputTensorList) {\n /*\n * TODO(michaelterry): Keras adds this value to tensors; it's not\n * clear whether we'll use this or not.\n */\n inboundLayers.push(x.sourceLayer as Layer);\n nodeIndices.push(x.nodeIndex);\n tensorIndices.push(x.tensorIndex);\n }\n\n // Create node, add it to inbound nodes.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node(\n {\n outboundLayer: this,\n inboundLayers,\n nodeIndices,\n tensorIndices,\n inputTensors: inputTensorList,\n outputTensors,\n inputMasks,\n outputMasks,\n inputShapes,\n outputShapes\n },\n kwargs);\n\n // Update tensor history\n for (let i = 0; i < outputTensors.length; i++) {\n // TODO(michaelterry: _uses_learning_phase not tracked.\n outputTensors[i].sourceLayer = this;\n outputTensors[i].nodeIndex = this.inboundNodes.length - 1;\n outputTensors[i].tensorIndex = i;\n }\n }\n\n /**\n * Returns the config of the layer.\n *\n * A layer config is a TS dictionary (serializable)\n * containing the configuration of a layer.\n * The same layer can be reinstantiated later\n * (without its trained weights) from this configuration.\n *\n * The config of a layer does not include connectivity\n * information, nor the layer class name. These are handled\n * by 'Container' (one layer of abstraction above).\n *\n * Porting Note: The TS dictionary follows TS naming standrds for\n * keys, and uses tfjs-layers type-safe Enums. Serialization methods\n * should use a helper function to convert to the pythonic storage\n * standard. (see serialization_utils.convertTsToPythonic)\n *\n * @returns TS dictionary of configuration.\n */\n getConfig(): serialization.ConfigDict {\n const config:\n serialization.ConfigDict = {name: this.name, trainable: this.trainable};\n if (this.batchInputShape != null) {\n config['batchInputShape'] = this.batchInputShape;\n }\n if (this.dtype != null) {\n config['dtype'] = this.dtype;\n }\n return config;\n }\n}\n\n/**\n * Collects the input shape(s) of a list of `Tensor`s or `SymbolicTensor`s.\n *\n * TODO(michaelterry): Update PyKeras docs (backport).\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return List of shape tuples (or single tuple), one tuple per input.\n */\nfunction collectInputShape(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): Shape|Shape[] {\n inputTensors =\n generic_utils.toList(inputTensors) as SymbolicTensor[] | Tensor[];\n const shapes: Shape[] = [];\n for (const x of inputTensors) {\n shapes.push(x.shape);\n }\n return generic_utils.singletonOrArray(shapes);\n}\n\n/**\n * Guesses output dtype based on inputs.\n *\n * At present, just returns 'float32' for any input.\n *\n * @param inputTensors List of input tensors (or single input tensor).\n *\n * @return The guessed DType. At present, always returns 'float32'.\n */\nfunction guessOutputDType(inputTensors: SymbolicTensor|SymbolicTensor[]|Tensor|\n Tensor[]): DataType {\n return 'float32';\n}\n\n/**\n * Returns the list of input tensors necessary to compute `tensor`.\n *\n * Output will always be a list of tensors (potentially with 1 element).\n *\n * @param tensor The tensor to start from.\n * @param layer Origin layer of the tensor.\n * @param nodeIndex Origin node index of the tensor.\n *\n * @return Array of input tensors.\n */\nexport function getSourceInputs(\n tensor: SymbolicTensor, layer?: Layer,\n nodeIndex?: number): SymbolicTensor[] {\n if (layer == null || (nodeIndex != null && nodeIndex > 0)) {\n layer = tensor.sourceLayer;\n nodeIndex = tensor.nodeIndex;\n }\n if (layer.inboundNodes.length === 0) {\n return [tensor];\n } else {\n const node = layer.inboundNodes[nodeIndex];\n if (node.inboundLayers.length === 0) {\n return node.inputTensors;\n } else {\n const sourceTensors: SymbolicTensor[] = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const previousSources = getSourceInputs(x, layer, nodeIndex);\n // Avoid input redundancy.\n for (const x of previousSources) {\n if (sourceTensors.indexOf(x) === -1) {\n sourceTensors.push(x);\n }\n }\n }\n return sourceTensors;\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {DataType, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\n\nimport {Layer, Node, SymbolicTensor} from './topology';\n\n/**\n * Constructor arguments for InputLayer.\n *\n * Note: You should provide only inputShape or batchInputShape (not both).\n * If only inputShape is provided, then the batchInputShape is determined by\n * the batchSize argument and the inputShape: [batchSize].concat(inputShape).\n */\nexport interface InputLayerConfig {\n /** Input shape, not including the batch axis. */\n inputShape?: Shape;\n /** Optional input batch size (integer or null). */\n batchSize?: number;\n /** Batch input shape, including the batch axis. */\n batchInputShape?: Shape;\n /** Datatype of the input. */\n dtype?: DataType;\n /**\n * Whether the placeholder created is meant to be sparse.\n */\n sparse?: boolean; // TODO(michaelterry): Not clear whether we'll need this.\n\n /** Name of the layer. */\n name?: string;\n}\n\n/**\n * An input layer is an entry point into a `Model`.\n *\n * `InputLayer` is generated automatically for `Sequential` models by specifying\n * the `inputshape` or `batchInputShape` for the first layer. It should not be\n * specified explicitly.\n *\n * ```js\n * // Define a model which simply adds two inputs.\n * const inputA = tf.input({shape: [3]});\n * const inputB = tf.input({shape: [3]});\n * const sum = tf.layers.add().apply([inputA, inputB]);\n * const model = tf.model({inputs: [inputA, inputB], outputs: sum});\n * const batchSize = 2;\n * model.predict([tf.ones([batchSize, 3]), tf.ones([batchSize, 3])]).print();\n * ```\n */\nexport class InputLayer extends Layer {\n static readonly className = 'InputLayer';\n sparse: boolean;\n constructor(config: InputLayerConfig) {\n super({\n dtype: config.dtype,\n name: config.name != null ? config.name : getUid('input').toString()\n });\n // Normalize config.batchSize and config.sparse\n if (config.batchSize == null) {\n config.batchSize = null;\n }\n if (config.sparse == null) {\n config.sparse = false;\n }\n\n this.trainable = false;\n this.built = true;\n this.sparse = config.sparse;\n\n if (config.inputShape != null && config.batchInputShape != null) {\n throw new ValueError(\n 'Only provide the inputShape OR ' +\n 'batchInputShape argument to inputLayer, not both at the same time.');\n }\n let batchInputShape = config.batchInputShape;\n if (batchInputShape == null) {\n if (config.inputShape == null) {\n throw new ValueError(\n 'An InputLayer should be passed either a ' +\n '`batchInputShape` or an `inputShape`.');\n } else {\n batchInputShape = [config.batchSize].concat(config.inputShape);\n }\n } else {\n // TODO(michaelterry): Backport to PyKeras\n if (config.batchSize != null) {\n throw new ValueError(\n 'Cannot specify batchSize if batchInputShape is' +\n 'specified when creating an InputLayer.');\n }\n }\n\n const dtype = config.dtype || 'float32';\n\n this.batchInputShape = batchInputShape;\n this.dtype = dtype;\n // TODO(michaelterry): Backport this to PyKeras?\n this.inputSpec = [{shape: batchInputShape}];\n\n const inputTensor = new SymbolicTensor(\n this.dtype, this.batchInputShape, this, [], {}, this.name);\n inputTensor.nodeIndex = 0;\n inputTensor.tensorIndex = 0;\n\n // Create an input node to add to this.outboundNode.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: [inputTensor],\n outputTensors: [inputTensor],\n inputMasks: [null],\n outputMasks: [null],\n inputShapes: [batchInputShape],\n outputShapes: [batchInputShape]\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor {\n throw new ValueError(\n 'Cannot pass any input to an ' +\n `InputLayer's apply() method. InputLayer name: ${this.name}`);\n }\n\n getConfig(): serialization.ConfigDict {\n return {\n batchInputShape: this.batchInputShape,\n dtype: this.dtype,\n sparse: this.sparse,\n name: this.name\n };\n }\n}\nserialization.SerializationMap.register(InputLayer);\n\n/**\n * Config for the Input function.\n *\n * Note: You should provide only shape or batchShape (not both).\n * If only shape is provided, then the batchShape becomes\n * [null].concat(inputShape).\n */\nexport interface InputConfig {\n /**\n * A shape, not including the batch size. For instance, `shape=[32]`\n * indicates that the expected input will be batches of 32-dimensional\n * vectors.\n */\n shape?: Shape;\n /**\n * A shape tuple (integer), including the batch size. For instance,\n * `batchShape=[10, 32]` indicates that the expected input will be batches of\n * 10 32-dimensional vectors. `batchShape=[null, 32]` indicates batches of an\n * arbitrary number of 32-dimensional vectors.\n */\n batchShape?: Shape;\n /**\n * An optional name string for the layer. Should be unique in a model (do not\n * reuse the same name twice). It will be autogenerated if it isn't provided.\n */\n name?: string;\n dtype?: DataType;\n /**\n * A boolean specifying whether the placeholder to be created is sparse.\n */\n sparse?: boolean;\n}\n\n/**\n * Used to instantiate an input to a model as a `SymbolicTensor`.\n *\n * Users should call the `input` factory function for\n * consistency with other generator functions.\n *\n * Example:\n *\n * ```js\n * // Defines a simple logistic regression model with 32 dimensional input\n * // and 3 dimensional output.\n * const x = tf.input({shape: [32]});\n * const y = tf.layers.dense({units: 3, activation: 'softmax'}).apply(x);\n * const model = tf.model({inputs: x, outputs: y});\n * model.predict(tf.ones([2, 32])).print();\n * ```\n *\n * Note: `input` is only necessary when using `model`. When using\n * `sequential`, specify `inputShape` for the first layer or use `inputLayer`\n * as the first layer.\n */\nexport function Input(config: InputConfig): SymbolicTensor {\n if (config.batchShape == null && config.shape == null) {\n throw new Error(\n 'Please provide to Input either a `shape`' +\n ' or a `batchShape` argument. Note that ' +\n '`shape` does not include the batch ' +\n 'dimension.');\n }\n if (config.batchShape != null && config.shape != null) {\n // TODO(michaelterry): Backport to PyKeras.\n throw new ValueError(\n 'Please provide either a `shape` or `batchShape` ' +\n 'argument to Input, but not both.');\n }\n let batchShape = config.batchShape;\n if (config.shape != null && batchShape == null) {\n batchShape = [null].concat(config.shape);\n }\n\n let dtype = config.dtype;\n if (dtype == null) {\n dtype = 'float32';\n }\n\n const inputLayer = new InputLayer({\n batchInputShape: batchShape,\n name: config.name,\n dtype,\n sparse: config.sparse\n });\n\n const outputs = inputLayer.inboundNodes[0].outputTensors;\n return outputs[0];\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {dispose, Scalar} from '@tensorflow/tfjs-core';\n\n/**\n * Logs in which values can be either numbers or Tensors (Scalars).\n *\n * Used internally.\n */\nexport type UnresolvedLogs = {\n [key: string]: number|Scalar;\n};\n\n/**\n * Turn any Scalar values in a Logs object into actual number values.\n *\n * @param logs The `Logs` object to be resolved in place.\n */\nexport async function resolveScalarsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n const promises: Array> = [];\n const keys: string[] = [];\n const scalarsToDispose: Scalar[] = [];\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n const valueScalar = value as Scalar;\n promises.push(valueScalar.data());\n keys.push(key);\n scalarsToDispose.push(valueScalar);\n }\n }\n const values = await Promise.all(promises);\n for (let i = 0; i < values.length; ++i) {\n logs[keys[i]] = values[i][0];\n }\n\n // Dispose the original scalar tensors.\n dispose(scalarsToDispose);\n}\n\n/**\n * Dispose all Tensors in an UnresolvedLogs object.\n *\n * @param logs An `UnresolvedLogs` object potentially containing `Tensor`s in\n * places where the values can be `Tensor` or `number`.\n */\nexport function disposeTensorsInLogs(logs: UnresolvedLogs) {\n if (logs == null) {\n return;\n }\n for (const key in logs) {\n const value = logs[key];\n if (typeof value !== 'number') {\n value.dispose();\n }\n }\n}\n\n/**\n * Logs in which values can only be numbers.\n *\n * Used when calling client-provided custom callbacks.\n */\nexport type Logs = {\n [key: string]: number;\n};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {add, div, keep, mul, Scalar, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport {Container} from './engine/container';\nimport {Logs, resolveScalarsInLogs, UnresolvedLogs} from './logs';\nimport * as generic_utils from './utils/generic_utils';\n\n\nexport type Params = {\n [key: string]: number|string|boolean|number[]|string[]|boolean[];\n};\n\n/**\n * Abstract base class used to build new callbacks.\n *\n * The `logs` dictionary that callback methods take as argument will contain\n * keys for quantities relevant to the current batch or epoch.\n *\n * Currently, the `.fit()` method of the `Sequential` model class\n * will include the following quantities in the `logs` that\n * it passes to its callbacks:\n *\n * onEpochEnd: Logs include `acc` and `loss`, and optionally include `valLoss`\n * (if validation is enabled in `fit`), and `valAcc` (if validation and\n * accuracy monitoring are enabled).\n * onBatchBegin: Logs include `size`, the number of samples in the current\n * batch.\n * onBatchEnd: Logs include `loss`, and optionally `acc` (if accuracy monitoring\n * is enabled).\n */\nexport abstract class BaseCallback {\n // TODO(michaelterry): This type is a best guess.\n validationData: Tensor|Tensor[] = null;\n /**\n * Training parameters (eg. verbosity, batch size, number of epochs...).\n */\n params: Params;\n\n setParams(params: Params): void {\n this.params = params;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {}\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {}\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {}\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {}\n\n async onTrainBegin(logs?: UnresolvedLogs) {}\n\n async onTrainEnd(logs?: UnresolvedLogs) {}\n\n // Model needs to call Callback.setModel(), but cannot actually depend on\n // Callback because that creates a cyclic dependency. Providing this no-op\n // method on BaseCallback breaks the cycle: this way Model can depend on\n // BaseCallback but not on Callback. The argument is typed as `Container`\n // (the superclass of Model) to avoid recapitulating the cycle. Callback\n // overrides this method and enforces that the argument is really a Model.\n setModel(model: Container): void {\n // Do nothing. Use Callback instead of BaseCallback to track the model.\n }\n}\n\n/**\n * Container abstracting a list of callbacks.\n */\nexport class CallbackList {\n callbacks: BaseCallback[];\n queueLength: number;\n\n // TODO(cais): When the need arises, uncomment the following lines and\n // implement the queue for time values.\n // private deltaTBatch: number;\n // private deltaTsBatchBegin: Array;\n // private deltaTsBatchEnd: Array;\n\n /**\n * Constructor of CallbackList.\n * @param callbacks Array of `Callback` instances.\n * @param queueLength Queue length for keeping running statistics over\n * callback execution time.\n */\n constructor(callbacks?: BaseCallback[], queueLength = 10) {\n // TODO(cais): Make use of queueLength when implementing the queue for time\n // values.\n if (callbacks == null) {\n callbacks = [];\n }\n this.callbacks = callbacks;\n this.queueLength = queueLength;\n }\n\n append(callback: BaseCallback): void {\n this.callbacks.push(callback);\n }\n\n setParams(params: Params): void {\n for (const callback of this.callbacks) {\n callback.setParams(params);\n }\n }\n\n setModel(model: Container): void {\n for (const callback of this.callbacks) {\n callback.setModel(model);\n }\n }\n\n /**\n * Called at the start of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochBegin(epoch, logs);\n }\n }\n\n /**\n * Called at the end of an epoch.\n * @param epoch Index of epoch.\n * @param logs Dictionary of logs.\n */\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onEpochEnd(epoch, logs);\n }\n }\n\n /**\n * Called right before processing a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchBegin(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchBegin(batch, logs);\n }\n }\n\n /**\n * Called at the end of a batch.\n * @param batch Index of batch within the current epoch.\n * @param logs Dictionary of logs.\n */\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onBatchEnd(batch, logs);\n }\n }\n\n /**\n * Called at the beginning of training.\n * @param logs Dictionary of logs.\n */\n async onTrainBegin(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainBegin(logs);\n }\n }\n\n /**\n * Called at the end of training.\n * @param logs Dictionary of logs.\n */\n async onTrainEnd(logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n for (const callback of this.callbacks) {\n await callback.onTrainEnd(logs);\n }\n }\n}\n\n\n/**\n * Callback that accumulates epoch averages of metrics.\n *\n * This callback is automatically applied to every Model.\n */\nexport class BaseLogger extends BaseCallback {\n private seen: number;\n private totals: UnresolvedLogs;\n\n constructor() {\n super();\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs) {\n this.seen = 0;\n this.totals = {};\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n const batchSize = logs['size'] == null ? 0 : logs['size'] as number;\n this.seen += batchSize;\n for (const key in logs) {\n const value = logs[key];\n if (typeof value === 'number') {\n if (!this.totals.hasOwnProperty(key)) {\n this.totals[key] = 0;\n }\n this.totals[key] = this.totals[key] as number + value * batchSize;\n } else {\n let oldTotalsToDispose: Scalar;\n if (key in this.totals) {\n oldTotalsToDispose = this.totals[key] as Scalar;\n } else {\n this.totals[key] = getScalar(0);\n }\n\n this.totals[key] = tidy(\n () => add((this.totals[key] as Scalar),\n mul(value, getScalar(batchSize))) as Scalar);\n if (oldTotalsToDispose != null) {\n oldTotalsToDispose.dispose();\n }\n }\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs != null) {\n for (const key of this.params['metrics'] as string[]) {\n if (this.totals[key] == null) {\n continue;\n }\n if (typeof this.totals[key] === 'number') {\n logs[key] = this.totals[key] as number / this.seen;\n } else {\n tidy(() => {\n logs[key] = mul(div(getScalar(1), getScalar(this.seen)) as Scalar,\n this.totals[key] as Scalar) as Scalar;\n (this.totals[key] as Tensor).dispose();\n keep(logs[key] as Scalar);\n });\n }\n }\n }\n }\n}\n\n/**\n * Callback that records events into a `History` object. This callback is\n * automatically applied to every TF.js Layers model. The `History` object gets\n * returned by the `fit` method of models.\n */\nexport class History extends BaseCallback {\n epoch: number[];\n history: {[key: string]: Array};\n\n async onTrainBegin(logs?: UnresolvedLogs) {\n this.epoch = [];\n this.history = {};\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs) {\n if (logs == null) {\n logs = {};\n }\n this.epoch.push(epoch);\n for (const key in logs) {\n if (this.history[key] == null) {\n this.history[key] = [];\n }\n this.history[key].push(logs[key]);\n }\n }\n\n /**\n * Await the values of all losses and metrics.\n */\n async syncData() {\n const promises: Array> = [];\n const keys: string[] = [];\n const indices: number[] = [];\n for (const key in this.history) {\n const valueArray = this.history[key];\n for (let i = 0; i < valueArray.length; ++i) {\n if (typeof valueArray[i] !== 'number') {\n const valueScalar = valueArray[i] as Tensor;\n promises.push(valueScalar.data());\n keys.push(key);\n indices.push(i);\n }\n }\n }\n const values = await Promise.all(promises);\n for (let n = 0; n < values.length; ++n) {\n const tensorToDispose = this.history[keys[n]][indices[n]] as Tensor;\n tensorToDispose.dispose();\n this.history[keys[n]][indices[n]] = values[n][0];\n }\n }\n}\n\nexport interface CustomCallbackConfig {\n onTrainBegin?: (logs?: Logs) => Promise;\n onTrainEnd?: (logs?: Logs) => Promise;\n onEpochBegin?: (epoch: number, logs?: Logs) => Promise;\n onEpochEnd?: (epoch: number, logs?: Logs) => Promise;\n onBatchBegin?: (batch: number, logs?: Logs) => Promise;\n onBatchEnd?: (batch: number, logs?: Logs) => Promise;\n}\n\n/**\n * Custom callback for training.\n */\nexport class CustomCallback extends BaseCallback {\n protected readonly trainBegin: (logs?: Logs) => Promise;\n protected readonly trainEnd: (logs?: Logs) => Promise;\n protected readonly epochBegin: (epoch: number, logs?: Logs) => Promise;\n protected readonly epochEnd: (epoch: number, logs?: Logs) => Promise;\n protected readonly batchBegin: (batch: number, logs?: Logs) => Promise;\n protected readonly batchEnd: (batch: number, logs?: Logs) => Promise;\n\n constructor(config: CustomCallbackConfig) {\n super();\n this.trainBegin = config.onTrainBegin;\n this.trainEnd = config.onTrainEnd;\n this.epochBegin = config.onEpochBegin;\n this.epochEnd = config.onEpochEnd;\n this.batchBegin = config.onBatchBegin;\n this.batchEnd = config.onBatchEnd;\n }\n\n async onEpochBegin(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.epochBegin(epoch, logs as Logs);\n }\n }\n\n async onEpochEnd(epoch: number, logs?: UnresolvedLogs): Promise {\n if (this.epochEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.epochEnd(epoch, logs as Logs);\n }\n }\n\n async onBatchBegin(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.batchBegin(batch, logs as Logs);\n }\n }\n\n async onBatchEnd(batch: number, logs?: UnresolvedLogs): Promise {\n if (this.batchEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.batchEnd(batch, logs as Logs);\n }\n }\n\n async onTrainBegin(logs?: UnresolvedLogs): Promise {\n if (this.trainBegin != null) {\n await resolveScalarsInLogs(logs);\n await this.trainBegin(logs as Logs);\n }\n }\n\n async onTrainEnd(logs?: UnresolvedLogs): Promise {\n if (this.trainEnd != null) {\n await resolveScalarsInLogs(logs);\n await this.trainEnd(logs as Logs);\n }\n }\n}\n\n/**\n * Standardize callbacks or configurations of them to an Array of callbacks.\n */\nexport function standardizeCallbacks(callbacks: BaseCallback|BaseCallback[]|\n CustomCallbackConfig|\n CustomCallbackConfig[]): BaseCallback[] {\n if (callbacks == null) {\n return null;\n }\n if (callbacks instanceof BaseCallback) {\n return [callbacks as BaseCallback];\n }\n if (Array.isArray(callbacks) && callbacks[0] instanceof BaseCallback) {\n return callbacks as BaseCallback[];\n }\n // Convert custom callback configs to custom callback objects.\n const callbackConfigs =\n generic_utils.toList(callbacks) as CustomCallbackConfig[];\n return callbackConfigs.map(\n callbackConfig => new CustomCallback(callbackConfig));\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: losses.py */\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {scalar, Tensor, Tensor1D, tidy} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {ValueError} from './errors';\nimport {LossOrMetricFn} from './types';\n\n\n/**\n * Normalizes a tensor wrt the L2 norm alongside the specified axis.\n * @param x\n * @param axis Axis along which to perform normalization.\n */\nexport function l2Normalize(x: Tensor, axis?: number): Tensor {\n return tidy(() => {\n const squareSum = tfc.sum(K.square(x), axis, true);\n const epsilonTensor = tfc.mul(scalar(epsilon()), tfc.onesLike(x));\n const norm = tfc.sqrt(tfc.maximum(squareSum, epsilonTensor));\n return tfc.div(x, norm);\n });\n}\n\n/**\n * Loss or metric function: Mean squared error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [3, 4]]);\n * const yPred = tf.tensor2d([[0, 1], [-3, -4]]);\n * const mse = tf.metrics.meanSquaredError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MSE`, `tf.metrics.mse`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean squared error Tensor.\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(K.square(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute error.\n *\n * Mathematically, mean absolute error is defined as:\n * `mean(abs(yPred - yTrue))`,\n * wherein the `mean` is applied over feature dimensions.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [0, 0], [2, 3]]);\n * const yPred = tf.tensor2d([[0, 1], [0, 1], [-2, -3]]);\n * const mse = tf.metrics.meanAbsoluteError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute error Tensor.\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => tfc.mean(tfc.abs(tfc.sub(yPred, yTrue)), -1));\n}\n\n/**\n * Loss or metric function: Mean absolute percentage error.\n *\n * ```js\n * const yTrue = tf.tensor2d([[0, 1], [10, 20]]);\n * const yPred = tf.tensor2d([[0, 1], [11, 24]]);\n * const mse = tf.metrics.meanAbsolutePercentageError(yTrue, yPred);\n * mse.print();\n * ```\n *\n * Aliases: `tf.metrics.MAPE`, `tf.metrics.mape`.\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Mean absolute percentage error Tensor.\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const diff = tfc.sub(yTrue, yPred);\n const clippedTrue =\n tfc.clipByValue(tfc.abs(yTrue), epsilon(), Number.MAX_VALUE);\n const absResult = tfc.abs(tfc.div(diff, clippedTrue));\n return tfc.mul(getScalar(100.0), tfc.mean(absResult, -1));\n });\n}\n\nexport function meanSquaredLogarithmicError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const one = getScalar(1.0);\n\n const clippedPred = tfc.clipByValue(yPred, epsilon(), Number.MAX_VALUE);\n const firstLog = tfc.log(tfc.add(one, clippedPred));\n\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), Number.MAX_VALUE);\n const secondLog = tfc.log(tfc.add(one, clippedTrue));\n\n return tfc.mean(K.square(tfc.sub(firstLog, secondLog)), -1);\n });\n}\n\nexport function squaredHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(K.square(maxResult), -1);\n });\n}\n\nexport function hinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const maxResult =\n tfc.maximum(zeroTensor, tfc.sub(one, tfc.mul(yTrue, yPred)));\n return tfc.mean(maxResult, -1);\n });\n}\n\nexport function categoricalHinge(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const zeroTensor = getScalar(0.0);\n const one = getScalar(1.0);\n const pos = tfc.sum(tfc.mul(yTrue, yPred), -1);\n const neg = tfc.max(tfc.mul(tfc.sub(one, yTrue), yPred), -1);\n return tfc.maximum(zeroTensor, tfc.add(one, tfc.sub(neg, pos)));\n });\n}\n\n/**\n * Logarithm of the hyperbolic cosine of the prediction error.\n *\n * `log(cosh(x))` is approximately equal to `(x ** 2) / 2` for small `x` and\n * to `abs(x) - log(2)` for large `x`. This means that 'logcosh' works mostly\n * like the mean squared error, but will not be so strongly affected by the\n * occasional wildly incorrect prediction.\n */\nexport function logcosh(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const log2 = getScalar(Math.log(2.0));\n const predictionDiff = tfc.sub(yPred, yTrue);\n const logcoshResult = tfc.sub(\n tfc.add(\n predictionDiff,\n tfc.softplus(tfc.mul(getScalar(-2.0), predictionDiff))),\n log2);\n return tfc.mean(logcoshResult, -1);\n });\n}\n\n/**\n * Categorical crossentropy between an output tensor and a target tensor.\n *\n * @param target A tensor of the same shape as `output`.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function categoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n if (fromLogits) {\n output = tfc.softmax(output);\n } else {\n // scale preds so that the class probabilities of each sample sum to 1.\n const outputSum = tfc.sum(output, output.shape.length - 1, true);\n output = tfc.div(output, outputSum);\n }\n output = tfc.clipByValue(output, epsilon(), 1 - epsilon());\n return tfc.neg(tfc.sum(\n tfc.mul(target.toFloat(), tfc.log(output)), output.shape.length - 1));\n });\n}\n\n/**\n * Categorical crossentropy with integer targets.\n *\n * @param target An integer tensor.\n * @param output A tensor resulting from a softmax (unless `fromLogits` is\n * `true`, in which case `output` is expected to be the logits).\n * @param fromLogits Boolean, whether `output` is the result of a softmax, or is\n * a tensor of logits.\n */\nexport function sparseCategoricalCrossentropy(\n target: Tensor, output: Tensor, fromLogits = false): Tensor {\n return tidy(() => {\n const flatTarget = tfc.floor(K.flatten(target)).toInt() as Tensor1D;\n const outputShape = output.shape;\n const oneHotTarget =\n tfc.oneHot(flatTarget, outputShape[outputShape.length - 1])\n .reshape(outputShape);\n return categoricalCrossentropy(oneHotTarget, output, fromLogits);\n });\n}\n\n/**\n * From TensorFlow's implementation in nn_impl.py:\n *\n * For brevity, let `x = logits`, `z = labels`. The logistic loss is\n * z * -log(sigmoid(x)) + (1 - z) * -log(1 - sigmoid(x))\n * = z * -log(1 / (1 + exp(-x))) + (1 - z) * -log(exp(-x) / (1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (-log(exp(-x)) + log(1 + exp(-x)))\n * = z * log(1 + exp(-x)) + (1 - z) * (x + log(1 + exp(-x))\n * = (1 - z) * x + log(1 + exp(-x))\n * = x - x * z + log(1 + exp(-x))\n * For x < 0, to avoid overflow in exp(-x), we reformulate the above\n * x - x * z + log(1 + exp(-x))\n * = log(exp(x)) - x * z + log(1 + exp(-x))\n * = - x * z + log(1 + exp(x))\n * Hence, to ensure stability and avoid overflow, the implementation uses this\n * equivalent formulation\n * max(x, 0) - x * z + log(1 + exp(-abs(x)))\n *\n * @param target The labels.\n * @param output The logits.\n */\nexport function sigmoidCrossEntropyWithLogits(\n target: Tensor, output: Tensor): Tensor {\n return tidy(() => {\n const maxOutput = tfc.maximum(output, tfc.zerosLike(output));\n const outputXTarget = tfc.mul(output, target);\n const sigmoidOutput =\n tfc.log(tfc.add(getScalar(1), tfc.exp(tfc.neg(tfc.abs(output)))));\n const result = tfc.add(tfc.sub(maxOutput, outputXTarget), sigmoidOutput);\n return result;\n });\n}\n\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n let y: Tensor;\n y = tfc.clipByValue(yPred, epsilon(), 1 - epsilon());\n y = tfc.log(tfc.div(y, tfc.sub(tfc.onesLike(y), y)));\n return tfc.mean(sigmoidCrossEntropyWithLogits(yTrue, y), -1);\n });\n}\n\nexport function kullbackLeiblerDivergence(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const clippedTrue = tfc.clipByValue(yTrue, epsilon(), 1);\n const clippedPred = tfc.clipByValue(yPred, epsilon(), 1);\n return tfc.sum(\n tfc.mul(yTrue, tfc.log(tfc.div(clippedTrue, clippedPred))), -1);\n });\n}\n\nexport function poisson(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const logPred = tfc.log(tfc.add(getScalar(epsilon()), yPred));\n return tfc.mean(tfc.sub(yPred, tfc.mul(yTrue, logPred)), -1);\n });\n}\n\n/**\n * Loss or metric function: Cosine proximity.\n *\n * Mathematically, cosine proximity is defined as:\n * `-sum(l2Normalize(yTrue) * l2Normalize(yPred))`,\n * wherein `l2Normalize()` normalizes the L2 norm of the input to 1 and `*`\n * represents element-wise multiplication.\n *\n * ```js\n * const yTrue = tf.tensor2d([[1, 0], [1, 0]]);\n * const yPred = tf.tensor2d([[1 / Math.sqrt(2), 1 / Math.sqrt(2)], [0, 1]]);\n * const proximity = tf.metrics.cosineProximity(yTrue, yPred);\n * proximity.print();\n * ```\n *\n * @param yTrue Truth Tensor.\n * @param yPred Prediction Tensor.\n * @return Cosine proximity Tensor.\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const trueNormalized = l2Normalize(yTrue, -1);\n const predNormalized = l2Normalize(yPred, -1);\n const trueXPred = tfc.mul(trueNormalized, predNormalized);\n return tfc.neg(tfc.sum(trueXPred, -1));\n });\n}\n\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const msle = meanSquaredLogarithmicError;\nexport const MSLE = meanSquaredLogarithmicError;\nexport const kld = kullbackLeiblerDivergence;\nexport const KLD = kullbackLeiblerDivergence;\nexport const cosine = cosineProximity;\n\n// TODO(michaelterry): Add deserialize() function.\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function get(identifierOrFn: string|LossOrMetricFn): LossOrMetricFn {\n const lossesMap: {[functionName: string]: LossOrMetricFn} = {\n meanSquaredError,\n meanAbsoluteError,\n meanAbsolutePercentageError,\n meanSquaredLogarithmicError,\n squaredHinge,\n hinge,\n categoricalHinge,\n logcosh,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n binaryCrossentropy,\n kullbackLeiblerDivergence,\n poisson,\n cosineProximity\n };\n if (typeof identifierOrFn === 'string') {\n if (identifierOrFn in lossesMap) {\n return lossesMap[identifierOrFn];\n }\n throw new ValueError(`Unknown loss ${identifierOrFn}`);\n } else {\n return identifierOrFn;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Built-in metrics.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {NotImplementedError, ValueError} from './errors';\nimport {categoricalCrossentropy as categoricalCrossentropyLoss, cosineProximity, meanAbsoluteError, meanAbsolutePercentageError, meanSquaredError, sparseCategoricalCrossentropy as sparseCategoricalCrossentropyLoss} from './losses';\nimport {binaryCrossentropy as lossBinaryCrossentropy} from './losses';\nimport {LossOrMetricFn} from './types';\n// tslint:enable:max-line-length\n\n/**\n * Binary accuracy metric function.\n *\n * `yTrue` and `yPred` can have 0-1 values. Example:\n * ```js\n * const x = tensor2d([[1, 1, 1, 1], [0, 0, 0, 0]], [2, 4]);\n * const y = tensor2d([[1, 0, 1, 0], [0, 0, 0, 1]], [2, 4]);\n * const accuracy = tfl.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * `yTrue` and `yPred` can also have floating-number values between 0 and 1, in\n * which case the values will be thresholded at 0.5 to yield 0-1 values (i.e.,\n * a value >= 0.5 and <= 1.0 is interpreted as 1.\n * )\n * Example:\n * ```js\n * const x = tensor1d([1, 1, 1, 1, 0, 0, 0, 0]);\n * const y = tensor1d([0.2, 0.4, 0.6, 0.8, 0.2, 0.3, 0.4, 0.7]);\n * const accuracy = tf.metrics.binaryAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction.\n * @return Accuracy Tensor.\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(() => {\n const threshold = tfc.mul(getScalar(0.5), tfc.onesLike(yPred));\n const yPredThresholded = K.cast(tfc.greater(yPred, threshold), yTrue.dtype);\n return tfc.mean(tfc.equal(yTrue, yPredThresholded), -1);\n });\n}\n\n/**\n * Categorical accuracy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0, 0, 0, 1], [0, 0, 0, 1]]);\n * const y = tensor2d([[0.1, 0.8, 0.05, 0.05], [0.1, 0.05, 0.05, 0.8]]);\n * const accuracy = tf.metrics.categoricalAccuracy(x, y);\n * accuracy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth: one-hot encoding of categories.\n * @param yPred Binary Tensor of prediction: probabilities or logits for the\n * same categories as in `yTrue`.\n * @return Accuracy Tensor.\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return tidy(\n () => K.cast(\n tfc.equal(tfc.argMax(yTrue, -1), tfc.argMax(yPred, -1)), 'float32'));\n}\n\n/**\n * Binary crossentropy metric function.\n *\n * Example:\n * ```js\n * const x = tensor2d([[0], [1], [1], [1]]);\n * const y = tensor2d([[0], [0], [0.5], [1]]);\n * const crossentropy = tf.metrics.binaryCrossentropy(x, y);\n * crossentropy.print();\n * ```\n *\n * @param yTrue Binary Tensor of truth.\n * @param yPred Binary Tensor of prediction, probabilities for the `1` case.\n * @return Accuracy Tensor.\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return lossBinaryCrossentropy(yTrue, yPred);\n}\n\nexport function sparseCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function topKCategoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\nexport function sparseTopKCategoricalAccuracy(\n yTrue: Tensor, yPred: Tensor): Tensor {\n throw new NotImplementedError();\n}\n\n// Aliases.\nexport const mse = meanSquaredError;\nexport const MSE = meanSquaredError;\nexport const mae = meanAbsoluteError;\nexport const MAE = meanAbsoluteError;\nexport const mape = meanAbsolutePercentageError;\nexport const MAPE = meanAbsolutePercentageError;\nexport const categoricalCrossentropy = categoricalCrossentropyLoss;\nexport const cosine = cosineProximity;\nexport const sparseCategoricalCrossentropy = sparseCategoricalCrossentropyLoss;\n\n// TODO(cais, nielsene): Add serialize().\n\nexport function get(identifier: string|LossOrMetricFn): LossOrMetricFn {\n const metricsMap: {[functionName: string]: LossOrMetricFn} = {\n binaryAccuracy,\n categoricalAccuracy,\n categoricalCrossentropy,\n sparseCategoricalCrossentropy,\n mse,\n MSE,\n mae,\n MAE,\n mape,\n MAPE,\n cosine,\n };\n if (typeof identifier === 'string' && identifier in metricsMap) {\n return metricsMap[identifier];\n } else if (typeof identifier !== 'string' && identifier != null) {\n return identifier;\n } else {\n throw new ValueError(`Unknown metric ${identifier}`);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {Container} from '../engine/container';\nimport {Layer, Node} from '../engine/topology';\nimport {countParamsInWeights} from './variable_utils';\n\n/**\n * Print the summary of a Model object.\n *\n * @param model tf.Model instance.\n * @param lineLength Total length of printed lines. Set this to adapt to the\n * display to different terminal or console sizes.\n * @param positions Relative or absolute positions of log elements in each\n * line. Each number corresponds to right-most (i.e., ending) position of a\n * column.\n * If not provided, defaults to `[0.45, 0.85, 1]` for sequential-like\n * models and `[0.33, 0.55, 0.67, 1]` for non-sequential like models.\n * @param printFn Print function to use.\n * It will be called on each line of the summary. You can provide a custom\n * function in order to capture the string summary. Defaults to `console.log`.\n */\nexport function printSummary(\n model: Container, lineLength?: number, positions?: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void =\n console.log): void {\n const sequentialLike = isModelSequentialLike(model);\n\n // Header names for different log elements.\n const toDisplay: string[] = ['Layer (type)', 'Output shape', 'Param #'];\n if (sequentialLike) {\n lineLength = lineLength || 65;\n positions = positions || [0.45, 0.85, 1];\n } else {\n lineLength = lineLength || 98;\n positions = positions || [0.33, 0.55, 0.67, 1];\n // Header names for different log elements.\n }\n\n if (positions[positions.length - 1] <= 1) {\n // `positions` is relative. Convert it to absolute positioning.\n positions = positions.map(p => Math.floor(lineLength * p));\n }\n\n let relevantNodes: Node[];\n if (!sequentialLike) {\n toDisplay.push('Receives inputs');\n relevantNodes = [];\n for (const depth in model.nodesByDepth) {\n relevantNodes.push(...model.nodesByDepth[depth]);\n }\n }\n\n printFn('_'.repeat(lineLength));\n printRow(toDisplay, positions, printFn);\n printFn('='.repeat(lineLength));\n\n const layers = model.layers;\n for (let i = 0; i < layers.length; ++i) {\n if (sequentialLike) {\n printLayerSummary(layers[i], positions, printFn);\n } else {\n printLayerSummaryWithConnections(\n layers[i], positions, relevantNodes, printFn);\n }\n printFn((i === layers.length - 1 ? '=' : '_').repeat(lineLength));\n }\n\n // tslint:disable-next-line:no-any\n (model as any).checkTrainableWeightsConsistency();\n let trainableCount: number;\n // tslint:disable:no-any\n if ((model as any).collectedTrainableWeights != null) {\n trainableCount =\n countParamsInWeights((model as any).collectedTrainableWeights);\n } else {\n trainableCount = countParamsInWeights(model.trainableWeights);\n }\n // tslint:enable:no-any\n const nonTrainableCount = countParamsInWeights(model.nonTrainableWeights);\n\n printFn(`Total params: ${trainableCount + nonTrainableCount}`);\n printFn(`Trainable params: ${trainableCount}`);\n printFn(`Non-trainable params: ${nonTrainableCount}`);\n printFn('_'.repeat(lineLength));\n}\n\nfunction isModelSequentialLike(model: Container): boolean {\n let sequentialLike = true;\n const nodesByDepth: Node[][] = [];\n const nodes: Node[] = [];\n for (const depth in model.nodesByDepth) {\n nodesByDepth.push(model.nodesByDepth[depth]);\n }\n for (const depthNodes of nodesByDepth) {\n if (depthNodes.length > 1 ||\n depthNodes.length === 1 && depthNodes[0].inboundLayers.length > 1) {\n sequentialLike = false;\n break;\n }\n nodes.push(...depthNodes);\n }\n if (sequentialLike) {\n // Search for shared layers.\n for (const layer of model.layers) {\n let flag = false;\n for (const node of layer.inboundNodes) {\n if (nodes.indexOf(node) !== -1) {\n if (flag) {\n sequentialLike = false;\n break;\n } else {\n flag = true;\n }\n }\n }\n if (!sequentialLike) {\n break;\n }\n }\n }\n return sequentialLike;\n}\n\nfunction printRow(\n fields: string[], positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void = console.log) {\n let line = '';\n for (let i = 0; i < fields.length; ++i) {\n if (i > 0) {\n line = line.slice(0, line.length - 1) + ' ';\n }\n line += fields[i];\n line = line.slice(0, positions[i]);\n line += ' '.repeat(positions[i] - line.length);\n }\n printFn(line);\n}\n\n/**\n * Prints a summary for a single Layer, without connectivity information.\n *\n * @param layer: Layer instance to print.\n */\nfunction printLayerSummary(\n layer: Layer, positions: number[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const name = layer.name;\n const className = layer.getClassName();\n const fields: string[] =\n [`${name} (${className})`, outputShape, layer.countParams().toString()];\n printRow(fields, positions, printFn);\n}\n\n/**\n * Prints a summary for a single Layer, with connectivity information.\n */\nfunction printLayerSummaryWithConnections(\n layer: Layer, positions: number[], relevantNodes: Node[],\n // tslint:disable-next-line:no-any\n printFn: (message?: any, ...optionalParams: any[]) => void) {\n let outputShape: string;\n try {\n outputShape = JSON.stringify(layer.outputShape);\n } catch (err) {\n outputShape = 'multiple';\n }\n\n const connections: string[] = [];\n for (const node of layer.inboundNodes) {\n if (relevantNodes != null && relevantNodes.length > 0 &&\n relevantNodes.indexOf(node) === -1) {\n continue;\n }\n for (let i = 0; i < node.inboundLayers.length; ++i) {\n const inboundLayer = node.inboundLayers[i].name;\n const inboundLayerIndex = node.nodeIndices[i];\n const inboundTensorIndex = node.tensorIndices[i];\n connections.push(\n `${inboundLayer}[${inboundLayerIndex}][${inboundTensorIndex}]`);\n }\n }\n const name = layer.name;\n const className = layer.getClassName();\n const firstConnection = connections.length === 0 ? '' : connections[0];\n const fields: string[] = [\n `${name} (${className})`, outputShape, layer.countParams().toString(),\n firstConnection\n ];\n\n printRow(fields, positions, printFn);\n for (let i = 1; i < connections.length; ++i) {\n printRow(['', '', '', connections[i]], positions, printFn);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source layers/__init__.py */\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {deserializeKerasObject} from '../utils/generic_utils';\n\n/**\n * Instantiate a layer from a config dictionary.\n * @param config: dict of the form {class_name: str, config: dict}\n * @param custom_objects: dict mapping class names (or function names)\n * of custom (non-Keras) objects to class/functions\n * @returns Layer instance (may be Model, Sequential, Layer...)\n */\nexport function deserialize(\n config: serialization.ConfigDict,\n customObjects = {} as\n serialization.ConfigDict): serialization.Serializable {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'layer');\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Porting note: This file doesn't exist in PyKeras.\n// Its purpose here is to centralize the boundary layer between\n// tfjs-layers's internal Config TS-Centric format and PyKeras's\n// serialized Python Config format.\n\n// tslint:disable:max-line-length\nimport {serialization} from '@tensorflow/tfjs-core';\n\nimport {JsonValue} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\n// tslint:enable\n\n/**\n * Test whether a value in an array is the name of a Model or Layer.\n * @param key The key name that the value is found under. Note that the key\n * may not be at the level immediately above the value, if the value is in a\n * nested array.\n * @param index Index of the value in the Array that it is found in.\n * @param value The value object.\n * @returns A boolean indicating whether value is a name.\n */\nfunction isArrayItemInputOrOutputName(\n key: string, index: number, value: T): boolean {\n return (key === 'inboundNodes' || key === 'outputLayers' ||\n key === 'inputLayers') &&\n index === 0 && typeof value === 'string';\n}\n\n/**\n * Convert a Pythonic config object to TypeScript config object.\n * @param pythonicConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertPythonicToTs(\n pythonicConfig: JsonValue, key?: string): serialization.ConfigDictValue {\n if (pythonicConfig === null) {\n return null;\n } else if (typeof pythonicConfig === 'string') {\n return generic_utils.toCamelCase(pythonicConfig);\n } else if (\n (typeof pythonicConfig === 'number') ||\n (typeof pythonicConfig === 'boolean')) {\n return pythonicConfig;\n } else if (pythonicConfig instanceof Array) {\n const tsArray = [];\n const arrayLength = pythonicConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = pythonicConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n tsArray.push(item);\n } else {\n tsArray.push(convertPythonicToTs(item, key));\n }\n }\n return tsArray;\n } else {\n const tsDict: serialization.ConfigDict = {};\n for (const pythonicKey of Object.keys(pythonicConfig)) {\n const pythonicValue = pythonicConfig[pythonicKey];\n if (pythonicKey === 'name' && typeof pythonicValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // camel-case conversion.\n tsDict[pythonicKey] = pythonicValue;\n } else {\n const tsKey = generic_utils.toCamelCase(pythonicKey);\n tsDict[tsKey] = convertPythonicToTs(pythonicValue, tsKey);\n }\n }\n return tsDict;\n }\n}\n\n/**\n * Convert a TypeScript config object to Python config object.\n * @param tsConfig The config object to convert.\n * @param key Optional key name of the object being converted.\n * @returns Result of the conversion.\n */\nexport function convertTsToPythonic(\n tsConfig: serialization.ConfigDictValue, key?: string): JsonValue {\n if (tsConfig === null || tsConfig === undefined) {\n return null;\n } else if (typeof tsConfig === 'string') {\n return generic_utils.toSnakeCase(tsConfig);\n } else if (\n (typeof tsConfig === 'number') || (typeof tsConfig === 'boolean')) {\n return tsConfig;\n } else if (tsConfig instanceof Array) {\n const pyArray = [];\n const arrayLength = tsConfig.length;\n for (let i = 0; i < arrayLength; ++i) {\n const item = tsConfig[i];\n if (isArrayItemInputOrOutputName(key, i, item)) {\n pyArray.push(item);\n } else {\n pyArray.push(convertTsToPythonic(item, key));\n }\n }\n return pyArray;\n } else {\n const pyDict: serialization.ConfigDict = {};\n for (const tsKey of Object.keys(tsConfig)) {\n const tsValue = tsConfig[tsKey];\n const pyKey = generic_utils.toSnakeCase(tsKey);\n if ((tsKey === 'name' || tsKey === 'className') &&\n typeof tsValue === 'string') {\n // Special case the 'name' key with a string value. Name values, such as\n // the names of Model and Layer instances, should not undergo the\n // snake-case conversion.\n pyDict[pyKey] = tsValue;\n } else {\n pyDict[pyKey] = convertTsToPythonic(tsValue, tsKey);\n }\n }\n return pyDict;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/engine/topology.py */\n\n// tslint:disable:max-line-length\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {getUid} from '../backend/state';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {deserialize as deserializeLayer} from '../layers/serialization';\nimport {JsonDict, Kwargs, NamedTensorMap, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {convertTsToPythonic} from '../utils/serialization_utils';\nimport * as types_utils from '../utils/types_utils';\nimport {batchSetValue, LayerVariable} from '../variables';\nimport {version as layersVersion} from '../version';\n\nimport {InputLayer} from './input_layer';\nimport {Layer, Node, SymbolicTensor} from './topology';\n// tslint:enable:max-line-length\n\n/**\n * Converts layers weights to a format suitable for TensorFlow.js Layers.\n *\n * Porting Note: The function `preprocess_weights_for_loading()` in PyKeras\n * performs conversion from Keras 1 to Keras 2. But in TypeScript, we\n * require Keras version to be 2. Thus this conversion is not applicable. We\n * simply check the Keras version and pass the weights through.\n *\n * @param layer Layer instance.\n * @param weights Input weights.\n * @param originalKerasVersion Keras version for the weights.\n * @param originalBackend Keras backend the weights were trained with.\n * @returns Output weights as Tensors.\n */\nfunction preprocessWeightsForLoading(\n layer: Layer, weights: LayerVariable[], originalKerasVersion?: string,\n originalBackend?: string): LayerVariable[] {\n if (!originalKerasVersion.startsWith('2.')) {\n throw new ValueError(\n 'Unsupported Keras version in weights being loaded: ' +\n originalKerasVersion);\n }\n return weights;\n}\n\n/**\n * Create an Tensor from info about dtype, shape and values.\n * @param dtype DType string.\n * @param shape Shape.\n * @param value Values of the array, as a scalar or nested Array of proper\n * shape.\n * @returns An Tensor instance.\n */\n// tslint:disable-next-line:no-any\nfunction loadTensor(dtype: string, shape: Shape, value: any): Tensor {\n const dataType = generic_utils.stringToDType(dtype);\n return Tensor.make(\n shape, {values: shape.length === 0 ? value : util.flatten(value)},\n dataType);\n}\n\n// TODO(cais): Maybe remove the following (b/74015805).\n/**\n * Load weights from a weights JSON object to an array of layers.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weightsJSON. The input JSON object represent the weights from a\n * trained Keras model. See scripts/pykeras.py for more details.\n * @param layers An array of target layers.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weights.\n */\nexport function loadWeightsFromJson(\n weightsJSON: JsonDict, layers: Layer[], skipMismatch = false): void {\n const originalKerasVersion = weightsJSON['keras_version'] as string;\n const originalBackend = weightsJSON['backend'] as string;\n const layerNames = layers.map(layer => layer.name);\n\n // Reverse index of layer name to list of layers with name.\n const index: {[layerName: string]: Layer[]} = {};\n for (const layer of layers) {\n if (layer.name != null) {\n if (index[layer.name] == null) {\n index[layer.name] = [];\n }\n index[layer.name].push(layer);\n }\n }\n\n // tslint:disable-next-line:no-any\n const nameToWeights = weightsJSON['weights'] as {[name: string]: any};\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (let k = 0; k < layerNames.length; ++k) {\n const name = layerNames[k];\n let layerWeights = nameToWeights[name];\n if (layerWeights == null) {\n layerWeights = [];\n }\n\n let weightValues: LayerVariable[] = [];\n for (let n = 0; n < layerWeights.length; ++n) {\n // tslint:disable:no-any\n const weightEntry =\n layerWeights[n] as {[key: string]: string | Shape | any};\n // tslint:enable\n weightValues.push(new LayerVariable(loadTensor(\n weightEntry['dtype'], weightEntry['shape'] as Shape,\n weightEntry['value'])));\n }\n for (const layer of index[name]) {\n const symbolicWeights = layer.weights;\n weightValues = preprocessWeightsForLoading(\n layer, weightValues, originalKerasVersion, originalBackend);\n if (weightValues.length !== symbolicWeights.length) {\n if (skipMismatch) {\n console.warn(\n `Skipping loading of weights of layer ${layer.name} ` +\n `due to mismatch in number of weights: (${weightValues.length} ` +\n `vs ${symbolicWeights.length}).`);\n } else {\n throw new ValueError(\n `Layer #${k} (named \"${layer.name}\") expects ` +\n `${symbolicWeights.length} weight(s), but the saved weights ` +\n `have ${weightValues.length} element(s).`);\n }\n }\n\n // Set values.\n for (let i = 0; i < weightValues.length; ++i) {\n if (skipMismatch) {\n if (!util.arraysEqual(\n symbolicWeights[i].shape, weightValues[i].shape)) {\n console.warn(\n `Skipping loading of weights for layer ${layer.name} due ` +\n `to mismatch in shape (${symbolicWeights[i].shape} vs ` +\n `${weightValues[i].shape})`);\n continue;\n }\n }\n weightValueTuples.push([symbolicWeights[i], weightValues[i].read()]);\n }\n }\n }\n batchSetValue(weightValueTuples);\n}\n\n/**\n * Load weights from a named tensor map.\n *\n * Porting Note: This is ported from the Python function\n * load_weights_from_hdf5_group_by_name()\n *\n * @param weights The named tensor map mapping names of weights to weight\n * values.\n * @param layers An array of target layers.\n */\nexport function loadWeightsFromNamedTensorMap(\n weights: NamedTensorMap, layers: Layer[]): void {\n // Make a dictionary mapping weight name to weight.\n const nameToWeight: {[name: string]: LayerVariable} = {};\n let totalWeightsCount = 0;\n for (const layer of layers) {\n for (const weight of layer.weights) {\n if (nameToWeight[weight.originalName] != null) {\n throw new ValueError(`Duplicate weight name: ${weight.originalName}`);\n }\n nameToWeight[weight.originalName] = weight;\n totalWeightsCount++;\n }\n }\n\n const weightValueTuples: Array<[LayerVariable, Tensor]> = [];\n for (const name in weights) {\n weightValueTuples.push([nameToWeight[name], weights[name]]);\n delete nameToWeight[name];\n }\n\n // Check that all weights are set.\n const unsetNames: string[] = [];\n for (const name in nameToWeight) {\n unsetNames.push(name);\n }\n if (unsetNames.length > 0) {\n throw new ValueError(\n `${unsetNames.length} of ${totalWeightsCount} weights are not set: ` +\n `${unsetNames}`);\n }\n\n batchSetValue(weightValueTuples);\n}\n\n/** Constructor config for Container. */\nexport interface ContainerConfig {\n inputs: SymbolicTensor|SymbolicTensor[];\n outputs: SymbolicTensor|SymbolicTensor[];\n name?: string;\n}\n\n/**\n * A Container is a directed acyclic graph of layers.\n *\n * It is the topological form of a \"model\". A Model\n * is simply a Container with added training routines.\n *\n */\nexport abstract class Container extends Layer {\n inputs: SymbolicTensor[];\n outputs: SymbolicTensor[];\n\n inputLayers: Layer[];\n inputLayersNodeIndices: number[];\n inputLayersTensorIndices: number[];\n\n outputLayers: Layer[];\n outputLayersNodeIndices: number[];\n outputLayersTensorIndices: number[];\n\n layers: Layer[];\n layersByDepth: {[depth: string]: Layer[]};\n nodesByDepth: {[depth: string]: Node[]};\n\n containerNodes = new Set();\n\n // TODO(michaelterry): Add cache support\n // private outputMaskCache: any;\n // private outputTensorCache: any;\n // private outputShapeCache: any;\n\n inputNames: string[];\n outputNames: string[];\n feedInputShapes: Shape[];\n\n protected internalInputShapes: Shape[];\n protected internalOutputShapes: Shape[];\n // TODO(cais): Maybe 'feed' should not in the names of these variables,\n // due to the fact that our backend is not symbolic.\n protected feedInputNames: string[];\n protected feedOutputNames: string[];\n\n constructor(config: ContainerConfig) {\n // No args passed to super's constructor.\n super({});\n this.name = config.name;\n if (this.name == null) {\n const prefix = this.getClassName().toLowerCase();\n this.name = getUid(prefix);\n }\n\n this.supportsMasking = false;\n this.trainable = true;\n this.updatable = true;\n\n // TODO(michaelterry): Initialize perInputLosses/Updates here.\n\n // Container-specific properties.\n if (Array.isArray(config.inputs)) {\n this.inputs = config.inputs.slice();\n } else {\n this.inputs = [config.inputs];\n }\n if (Array.isArray(config.outputs)) {\n this.outputs = config.outputs.slice();\n } else {\n this.outputs = [config.outputs];\n }\n\n // Check for redundancy in inputs.\n if (generic_utils.unique(this.inputs).length !== this.inputs.length) {\n throw new ValueError(\n 'The list of inputs passed to the model is ' +\n 'redundant. All inputs should only appear once. Found: ' +\n this.inputs.map(x => x.name));\n }\n\n // Check for redundancy in outputs.\n if (generic_utils.unique(this.outputs).length !== this.outputs.length) {\n console.warn(\n 'The list of outputs passed to the model is redundant. ' +\n 'All outputs should only appear once. Found: ' +\n this.outputs.map(x => x.name));\n }\n\n /*\n List of initial layers (1 to 1 mapping with this.inputs, hence the same\n layer might appear twice)\n */\n this.inputLayers = [];\n this.inputLayersNodeIndices = [];\n this.inputLayersTensorIndices = [];\n /*\n List of layers (1 to 1 mapping with this.outputs, hence the same layer\n might appear twice)\n */\n this.outputLayers = [];\n this.outputLayersNodeIndices = [];\n this.outputLayersTensorIndices = [];\n /*\n All layers in order of horizontal graph traversal. Entries are unique.\n Includes input and output layers.\n */\n this.layers = [];\n\n // TODO(michaelterry): Determine if caching still needed with eager\n // backend.\n /*\n This is for performance optimization when calling the Container on new\n inputs. Every time the Container is called on a set on input tensors,\n we compute the output tensors, output masks and output shapes in one pass,\n then cache them here. When one of these outputs is queried later,\n we retrieve it from there instead of recomputing it.\n */\n // this.outputTensorCache = {};\n // this.outputShapeCache = {};\n\n // Build this.outputLayers:\n for (const x of this.outputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n this.outputLayers.push(layer as Layer);\n this.outputLayersNodeIndices.push(nodeIndex);\n this.outputLayersTensorIndices.push(tensorIndex);\n }\n\n // TODO(michaelterry): Add output mask cache code.\n\n // Build this.inputLayers:\n for (const x of this.inputs) {\n const layer = x.sourceLayer;\n const nodeIndex = x.nodeIndex;\n const tensorIndex = x.tensorIndex;\n /*\n It's supposed to be an input layer, so only one node\n and one tensor output.\n */\n generic_utils.assert(nodeIndex === 0, 'input layer has >1 nodes');\n generic_utils.assert(tensorIndex === 0, 'input layer has >1 tensors');\n this.inputLayers.push(layer as Layer);\n this.inputLayersNodeIndices.push(nodeIndex);\n this.inputLayersTensorIndices.push(tensorIndex);\n }\n\n // Build this.inputNames and this.outputNames.\n this.inputNames = [];\n this.outputNames = [];\n this.feedInputShapes = [];\n this.feedInputNames = [];\n this.feedOutputNames = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n // Check that layer is an InputLayer.\n if (!(layer instanceof InputLayer)) {\n throw new TypeError(\n 'Input layers to a Model must be InputLayer objects. ' +\n `Received inputs: ${config.inputs}. ` +\n `Input ${i} (0-based) originates ` +\n `from layer type ${layer.getClassName()}.`);\n }\n this.inputNames.push(layer.name);\n this.feedInputShapes.push(layer.batchInputShape);\n\n this.feedInputNames.push(layer.name);\n }\n for (const layer of this.outputLayers) {\n this.outputNames.push(layer.name);\n }\n\n this.internalInputShapes = this.inputs.map(x => x.shape);\n this.internalOutputShapes = this.outputs.map(x => x.shape);\n\n /*\n Container_nodes: set of nodes included in the graph (not all nodes\n included in the layers are relevant to the current graph).\n */\n // ids of all nodes relevant to the Container:\n const nodesDepths: {[nodeID: string]: number} = {};\n // To recover nodes from their ID.\n const nodeIDToNode: {[nodeID: string]: Node} = {};\n const layersDepths: {[layerID: string]: number} = {};\n // To layers from their ID.\n const layerIDToLayer: {[layerID: string]: Layer} = {};\n const layerIndices: {[layerID: string]: number} = {};\n const nodesInDecreasingDepth: Node[] = [];\n\n /**\n * Builds a map of the graph of layers.\n *\n * This recursively updates the map `layerIndices`,\n * the list `nodesInDecreasingDepth` and the set `containerNodes`.\n *\n * @param tensor Some tensor in a graph.\n * @param finishedNodes Set of nodes whose subgraphs have been traversed\n * completely. Useful to prevent duplicated work.\n * @param nodesInProgress Set of nodes that are currently active on the\n * recursion stack. Useful to detect cycles.\n * @param layer Layer from which `tensor` comes from. If not provided,\n * will be obtained from tensor.sourceLayer.\n * @param nodeIndex Node index from which `tensor` comes from.\n * @param tensorIndex TensorIndex from which `tensor` comes from.\n *\n * @exception RuntimeError if a cycle is detected.\n */\n const buildMapOfGraph =\n (tensor: SymbolicTensor, finishedNodes: Node[], nodesInProgress: Node[],\n layer?: Layer, nodeIndex?: number, tensorIndex?: number) => {\n if (layer == null || nodeIndex == null || tensorIndex == null) {\n layer = tensor.sourceLayer as Layer;\n nodeIndex = tensor.nodeIndex;\n tensorIndex = tensor.tensorIndex;\n }\n const node = layer.inboundNodes[nodeIndex];\n\n // Prevent cycles.\n if (nodesInProgress.indexOf(node) !== -1) {\n throw new RuntimeError(\n `The tensor ${tensor.name} at layer \"${layer.name}\" ` +\n 'is part of a cycle.');\n }\n\n // Don't repeat work for shared subgraphs\n if (finishedNodes.indexOf(node) !== -1) {\n return;\n }\n\n // Update containerNodes.\n this.containerNodes.add(Container.nodeKey(layer, nodeIndex));\n\n // Store the traversal order for layer sorting.\n if (!(layer.id in layerIndices)) {\n layerIndices[layer.id] = Object.keys(layerIndices).length;\n }\n\n if (nodesInProgress.indexOf(node) === -1) {\n nodesInProgress.push(node);\n }\n\n // Propagate to all previous tensors connected to this node.\n const numInboundLayers = node.inboundLayers.length;\n for (let i = 0; i < numInboundLayers; i++) {\n const x = node.inputTensors[i];\n const layer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n buildMapOfGraph(\n x, finishedNodes, nodesInProgress, layer, nodeIndex,\n tensorIndex);\n }\n finishedNodes.push(node);\n while (nodesInProgress.indexOf(node) >= 0) {\n nodesInProgress.splice(nodesInProgress.indexOf(node), 1);\n }\n nodesInDecreasingDepth.push(node);\n };\n\n const finishedNodes: Node[] = [];\n const nodesInProgress: Node[] = [];\n for (const x of this.outputs) {\n buildMapOfGraph(x, finishedNodes, nodesInProgress);\n }\n\n const reversedNodesInDecreasingDepth =\n nodesInDecreasingDepth.slice().reverse();\n for (const node of reversedNodesInDecreasingDepth) {\n nodeIDToNode[node.id] = node;\n // If the depth is not set, the node has no outbound nodes (depth 0).\n if (!(node.id in nodesDepths)) {\n nodesDepths[node.id] = 0;\n }\n let depth = nodesDepths[node.id];\n\n // Update the depth of the corresponding layer\n const previousDepth =\n (layersDepths[node.outboundLayer.id] == null ?\n 0 :\n layersDepths[node.outboundLayer.id]);\n\n /*\n If we've seen this layer before at a higher depth, we should use that\n depth instead of the node depth. This is necessary for shared layers\n that have inputs at different depth levels in the graph.\n */\n depth = Math.max(depth, previousDepth);\n layersDepths[node.outboundLayer.id] = depth;\n layerIDToLayer[node.outboundLayer.id] = node.outboundLayer;\n nodesDepths[node.id] = depth;\n\n // Update the depth of inbound nodes.\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const inboundNode = inboundLayer.inboundNodes[nodeIndex];\n const previousDepth =\n (nodesDepths[inboundNode.id] == null ? 0 :\n nodesDepths[inboundNode.id]);\n nodesDepths[inboundNode.id] = Math.max(depth + 1, previousDepth);\n nodeIDToNode[inboundNode.id] = inboundNode;\n }\n }\n\n // Build a dict {depth: list of nodes with this depth}\n const nodesByDepth: {[depth: string]: Node[]} = {};\n for (const nodeID in nodesDepths) {\n const depth = nodesDepths[nodeID];\n if (!(depth in nodesByDepth)) {\n nodesByDepth[depth] = [];\n }\n nodesByDepth[depth].push(nodeIDToNode[nodeID]);\n }\n\n // Build a dict {depth: list of layers with this depth}\n const layersByDepth: {[depth: string]: Layer[]} = {};\n for (const layerID in layersDepths) {\n const depth = layersDepths[layerID];\n if (!(depth in layersByDepth)) {\n layersByDepth[depth] = [];\n }\n layersByDepth[depth].push(layerIDToLayer[layerID]);\n }\n\n // Get sorted list of layer depths.\n let depthKeys = Object.keys(layersByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Set this.layers and this.layersByDepth.\n this.layers = [];\n for (const depth of depthKeys) {\n const layersForDepth = layersByDepth[depth];\n // Container.layers needs to have a deterministic order:\n // here we order them by traversal order.\n layersForDepth.sort((a, b) => {\n const aIndex = layerIndices[a.id];\n const bIndex = layerIndices[b.id];\n if (aIndex < bIndex) {\n return -1;\n }\n if (aIndex > bIndex) {\n return 1;\n }\n return 0;\n });\n for (const layer of layersForDepth) {\n this.layers.push(layer);\n }\n }\n this.layersByDepth = layersByDepth;\n\n // Get sorted list of node depths;\n depthKeys = Object.keys(nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n\n // Check that all tensors required are computable.\n // computable_tensors: all tensors in the graph\n // that can be computed from the inputs provided.\n const computableTensors = this.inputs.slice();\n\n // To provide a better error msg.\n const layersWithCompleteInput: string[] = [];\n for (const depth of depthKeys) {\n for (const node of nodesByDepth[depth]) {\n const layer = node.outboundLayer;\n if (layer != null) {\n for (const x of node.inputTensors) {\n if (computableTensors.indexOf(x) === -1) {\n throw new RuntimeError(\n `Graph disconnected: cannot obtain value for tensor ${x}` +\n ` at layer \"${layer.name}\". ` +\n 'The following previous layers were accessed without ' +\n `issue: ${layersWithCompleteInput}`);\n }\n }\n for (const x of node.outputTensors) {\n computableTensors.push(x);\n }\n layersWithCompleteInput.push(layer.name);\n }\n }\n }\n\n // Set this.containerNodes and this.nodesByDepth.\n this.nodesByDepth = nodesByDepth;\n\n // Ensure name unicity, which will be crucial for serialization\n // (since serialized nodes refer to layers by their name).\n const allNames = this.layers.map(x => x.name);\n for (const name of allNames) {\n const numOccurrences = allNames.filter(x => x === name).length;\n if (numOccurrences !== 1) {\n throw new RuntimeError(\n `The name \"${name}\" is used ${numOccurrences} times ` +\n 'in the model. All layer names should be unique. Layer names: ' +\n JSON.stringify(allNames));\n }\n }\n\n // Layer parameters.\n // The new container starts with a single inbound node\n // for its inputs, and no outbound nodes.\n // Will be appended to by future calls to apply().\n this.outboundNodes = [];\n // Will be appended to below, and by future calls to apply().\n this.inboundNodes = [];\n\n // Create the node linking internal inputs to internal outputs.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n inputMasks: this.inputs.map(x => null),\n outputMasks: this.outputs.map(x => null),\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs.map(x => x.shape)\n });\n this.built = true;\n }\n\n get trainableWeights(): LayerVariable[] {\n // Porting Note: This check below is to prevent errors where the\n // _trainableWeights inherited from the parent class (Layer) gets\n // inadvertently used.\n if (this._trainableWeights.length > 0) {\n throw new ValueError(\n 'Container instance unexpectedly contains _trainableWeights.' +\n 'The trainable weights of a Container are a union of the ' +\n 'trainable weights of its consituent Layers. Its own ' +\n '_trainableWeights must remain an empty Array.');\n }\n\n if (!this.trainable) {\n return [];\n }\n let weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights = weights.concat(layer.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const layer of this.layers) {\n weights.push(...layer.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const layer of this.layers) {\n trainableWeights.push(...layer.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n get weights(): LayerVariable[] {\n return this.trainableWeights.concat(this.nonTrainableWeights);\n }\n\n /**\n * Loads all layer weights from a JSON object.\n *\n * Porting Note: HDF5 weight files cannot be directly loaded in JavaScript /\n * TypeScript. The utility script at `scripts/pykeras.py` offers means\n * to convert them into JSON strings compatible with this method.\n * Porting Note: TensorFlow.js Layers supports only loading by name currently.\n *\n * @param weightsJSON A JSON mapping weight names to weight values as nested\n * arrays of numbers, or a `NamedTensorMap`, i.e., a JSON mapping weight\n * names to `Tensor` objects.\n * @param skipMismatch Whether to skip loading of layers where there is a\n * mismatch in the number of weights, or a mismatch in the shape of the\n * weight (only valid when `by_name`=True).\n * @param isNamedTensorMap Whether the 1st argument (`weightsJSON`) is a\n * `NamedTensorMap`.\n */\n loadWeights(\n weightsJSON: JsonDict|NamedTensorMap, skipMismatch = false,\n isNamedTensorMap = false) {\n // TODO(cais): Maybe the JsonDict support should be removed after serving\n // weights from XHR is working. If so, the `loadWeightsFromJson` flag\n // should be removed as well. (b/74015805)\n // TODO(cais): See if we can use smarter type resolution to avoid sending\n // the type info as a separate arg (isNamedTensormap).\n if (isNamedTensorMap) {\n loadWeightsFromNamedTensorMap(weightsJSON as NamedTensorMap, this.layers);\n } else {\n loadWeightsFromJson(weightsJSON as JsonDict, this.layers, skipMismatch);\n }\n }\n\n /**\n * Util shared between different serialization methods.\n * @returns Model config with Keras version information added.\n */\n private updatedConfig(): serialization.ConfigDict {\n const theConfig = this.getConfig();\n const modelConfig: serialization.ConfigDict = {\n className: this.getClassName(),\n config: theConfig,\n kerasVersion: `tfjs-layers ${layersVersion}`,\n // TODO(nielsene): Replace something like K.backend() once\n // possible.\n backend: 'TensorFlow.js'\n };\n return modelConfig;\n }\n\n /**\n * Returns a JSON string containing the network configuration.\n *\n * To load a network from a JSON save file, use\n * models.modelFromJSON(jsonString);\n * @param extraJsonArgs Unused in tfjs-layers, maintained for PyKeras\n * @param returnString Whether the return value should be stringified\n * (default: `true`).\n * @returns a JSON string if `returnString` (default), or a JSON object if\n * `!returnString`.\n */\n // tslint:disable-next-line:no-any\n toJSON(unused?: any, returnString = true): string|JsonDict {\n const modelConfig = convertTsToPythonic(this.updatedConfig()) as JsonDict;\n return returnString ? JSON.stringify(modelConfig) : modelConfig;\n }\n\n /**\n * Call the model on new inputs.\n *\n * In this case `call` just reapplies all ops in the graph to the new inputs\n * (e.g. build a new computational graph from the provided inputs).\n *\n * @param inputs A tensor or list of tensors.\n * @param mask A mask or list of masks. A mask can be either a tensor or null\n * (no mask).\n *\n * @return A tensor if there is a single output, or a list of tensors if there\n * are more than one outputs.\n */\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n\n if ('mask' in kwargs) {\n masks = generic_utils.toList(kwargs['mask']);\n } else {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n // TODO(michaelterry): Add support for caching.\n return this.runInternalGraph(inputs, masks)[0];\n });\n }\n\n /**\n * Computes an output mask tensor.\n *\n * @param inputs Tensor or list of tensors.\n * @param mask Tensor or list of tensors.\n *\n * @return null or a tensor (or list of tensors, one per output tensor of the\n * layer).\n */\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor\n |Tensor[] {\n return tidy(() => {\n inputs = generic_utils.toList(inputs);\n let masks: Tensor[];\n if (mask == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n } else {\n masks = generic_utils.toList(mask);\n }\n // TODO(michaelterry): Add support for mask caching.\n return this.runInternalGraph(inputs, masks)[1];\n });\n }\n\n /**\n * Computes the output shape of the layer.\n *\n * Assumes that the layer will be built to match that input shape provided.\n *\n * @param inputShape A shape (tuple of integers) or a list of shape tuples\n * (one per output tensor of the layer). Shape tuples can include null for\n * free dimensions, instead of an integer.\n */\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n const inputShapes = types_utils.normalizeShapeList(inputShape);\n if (inputShapes.length !== this.inputLayers.length) {\n throw new ValueError(\n `Invalid inputShape argument ${inputShape}: ` +\n `model has ${this.inputLayers.length} tensor inputs.`);\n }\n\n // TODO(michaelterry): Add caching\n const layersToOutputShapes: {[shapeKey: string]: Shape} = {};\n for (let i = 0; i < inputShapes.length; i++) {\n const layer = this.inputLayers[i];\n const inputShape = inputShapes[i];\n // It's an input layer: computeOutputShape is identity,\n // and there is only one node and one tensor output.\n const shapeKey = layer.name + '_0_0';\n layersToOutputShapes[shapeKey] = inputShape;\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n // Iterate over nodes, by depth level.\n if (depthKeys.length > 1) {\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n if (this.inputLayers.map(x => x.id).indexOf(layer.id) !== -1) {\n // We've already covered the input layers a few lines above.\n continue;\n }\n // Potentially redundant list, same size of node.inputTensors.\n const inputShapes: Shape[] = [];\n for (let j = 0; j < node.inboundLayers.length; j++) {\n const inboundLayer = node.inboundLayers[j];\n const nodeIndex = node.nodeIndices[j];\n const tensorIndex = node.tensorIndices[j];\n const shapeKey = `${inboundLayer.name}_${nodeIndex}_${tensorIndex}`;\n const inputShape = layersToOutputShapes[shapeKey];\n inputShapes.push(inputShape);\n }\n\n const outputShape = layer.computeOutputShape(\n generic_utils.singletonOrArray(inputShapes));\n\n const outputShapes = types_utils.normalizeShapeList(outputShape);\n const nodeIndex = layer.inboundNodes.indexOf(node);\n for (let j = 0; j < outputShapes.length; j++) {\n const shapeKey = `${layer.name}_${nodeIndex}_${j}`;\n layersToOutputShapes[shapeKey] = outputShapes[j];\n }\n }\n }\n }\n\n // Read final output shapes from layersToOutputShapes.\n const outputShapes: Shape[] = [];\n const outputShapeKeys: string[] = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n const tensorIndex = this.outputLayersTensorIndices[i];\n const shapeKey = `${layer.name}_${nodeIndex}_${tensorIndex}`;\n outputShapeKeys.push(shapeKey);\n }\n\n for (let i = 0; i < outputShapeKeys.length; i++) {\n const key = outputShapeKeys[i];\n generic_utils.assert(key in layersToOutputShapes);\n outputShapes.push(layersToOutputShapes[key]);\n }\n\n // TODO(michaelterry): Update cache\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n /**\n * Computes output tensors for new inputs.\n *\n * Note:\n * - Expects `inputs` to be a list (potentially with 1 element).\n *\n * @param inputs List of tensors\n * @param masks List of masks (tensors or null).\n * @return Three lists: outputTensors, outputMasks, outputShapes\n */\n protected runInternalGraph(inputs: Tensor[], masks?: Tensor[]):\n [Tensor[], Tensor[], Shape[]] {\n if (masks == null) {\n masks = generic_utils.pyListRepeat(null, inputs.length);\n }\n\n // Dictionary mapping reference tensors to tuples\n // (computed tensor, compute mask)\n // we assume a 1:1 mapping from tensor to mask\n // TODO: raise exception when a `.computeMask()` call\n // does not return a list the same size as `call`\n const tensorMap: {[tensorID: string]: [Tensor, Tensor]} = {};\n for (let i = 0; i < this.inputs.length; ++i) {\n const x = this.inputs[i];\n const y = inputs[i];\n const mask = masks[i];\n tensorMap[x.id] = [y, mask];\n }\n\n const depthKeys = Object.keys(this.nodesByDepth)\n .map(x => parseInt(x, 10))\n .sort(generic_utils.reverseNumberCompare);\n for (const depth of depthKeys) {\n const nodes = this.nodesByDepth[depth];\n for (const node of nodes) {\n // This is always a single layer, never a list.\n const layer = node.outboundLayer;\n const referenceInputTensors = node.inputTensors;\n const referenceOutputTensors = node.outputTensors;\n\n // If all previous input tensors are available in tensorMap,\n // then call node.inboundLayer on them.\n // List of tuples [input, mask]:\n const computedData = new Array<[Tensor, Tensor]>();\n for (const x of referenceInputTensors) {\n if (x.id in tensorMap) {\n computedData.push(tensorMap[x.id]);\n }\n }\n if (computedData.length === referenceInputTensors.length) {\n // TODO(michaelterry): Add K.name_scope here, if we need it.\n let kwargs: Kwargs = {};\n let computedTensors: Tensor[];\n let computedMasks: Tensor[];\n let outputTensors: Tensor[];\n let outputMasks: Tensor[];\n // call layer\n if (node.callArgs != null) {\n kwargs = node.callArgs;\n }\n if (computedData.length === 1) {\n const [computedTensor, computedMask] = computedData[0];\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMask;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensor, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensor, computedMask));\n computedTensors = [computedTensor];\n computedMasks = [computedMask];\n } else {\n computedTensors = computedData.map(x => x[0]);\n computedMasks = computedData.map(x => x[1]);\n if (kwargs.mask == null) {\n kwargs['mask'] = computedMasks;\n }\n outputTensors =\n generic_utils.toList(layer.call(computedTensors, kwargs));\n outputMasks = generic_utils.toList(\n layer.computeMask(computedTensors, computedMasks));\n }\n\n if (layer.activityRegularizer) {\n throw new NotImplementedError(\n 'Model invocation with concrete Tensor value(s) in the ' +\n 'presence of activity regularizer(s) is not supported yet.');\n }\n // TODO(michaelterry): Add model updates and losses\n\n // Update tensor map.\n for (let i = 0; i < referenceOutputTensors.length; ++i) {\n const x = referenceOutputTensors[i];\n const y = outputTensors[i];\n const mask = outputMasks[i];\n tensorMap[x.id] = [y, mask];\n }\n }\n }\n }\n\n const outputTensors: Tensor[] = [];\n const outputMasks: Tensor[] = [];\n const outputShapes: Shape[] = [];\n for (const x of this.outputs) {\n generic_utils.assert(\n x.id in tensorMap, `Could not compute output ${x.name} : ${x.id}`);\n const [tensor, mask] = tensorMap[x.id];\n outputShapes.push(tensor.shape);\n outputTensors.push(tensor);\n outputMasks.push(mask);\n }\n\n // TODO(michaelterry): Add support for caches.\n return [outputTensors, outputMasks, outputShapes];\n }\n\n /**\n * Builds a map of internal node keys to node ordering.\n * Used in serializaion a node orderings may change as unused nodes are\n * dropped. Porting Note: This helper method was pulled out of getConfig to\n * improve readability.\n * @param layers An array of Layers in the model.\n * @returns Map of Node Keys to index order within the layer.\n */\n private buildNodeConversionMap(layers: Layer[]): {[nodeKey: string]: number} {\n const nodeConversionMap: {[nodeKey: string]: number} = {};\n let keptNodes: number;\n for (const layer of this.layers) {\n keptNodes = layer instanceof Container ? 1 : 0;\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n if (nodeKey in this.containerNodes) {\n // i.e. we mark it to be saved\n nodeConversionMap[nodeKey] = keptNodes;\n keptNodes += 1;\n }\n }\n }\n return nodeConversionMap;\n }\n\n /**\n * Retrieves a layer based on either its name (unique) or index.\n *\n * Indices are based on order of horizontal graph traversal (bottom-up).\n *\n * If both `name` and `index` are specified, `index` takes precedence.\n *\n * @param name Name of layer.\n * @param index Index of layer.\n * @returns A Layer instance.\n * @throws ValueError: In case of invalid layer name or index.\n */\n /**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Classes',\n * namespace: 'layers',\n * subclasses: ['Model']\n * }\n */\n getLayer(name?: string, index?: number): Layer {\n if (index != null) {\n if (this.layers.length <= index) {\n throw new ValueError(\n `Was asked to retrieve layer at index ${index}, but model only ` +\n `has ${this.layers.length} layer(s).`);\n } else {\n return this.layers[index];\n }\n } else {\n if (name == null) {\n throw new ValueError('Provide either a layer name or layer index');\n }\n }\n\n for (const layer of this.layers) {\n if (layer.name === name) {\n return layer;\n }\n }\n throw new ValueError(`No such layer: ${name}`);\n }\n\n /**\n * Retrieves the Container's current loss values.\n *\n * Used for regularizers during training.\n */\n calculateLosses(): Scalar[] {\n // Porting Node: This is an augmentation to Container.loss in PyKeras.\n // In PyKeras, Container.loss returns symbolic tensors. Here a concrete\n // Tensor (specifically Scalar) values are returned. This is due to the\n // imperative backend.\n return tidy(() => {\n const losses: Scalar[] = [];\n for (const layer of this.layers) {\n for (let nodeIndex = 0; nodeIndex < layer.inboundNodes.length;\n ++nodeIndex) {\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (this.containerNodes.has(nodeKey)) {\n losses.push(...layer.calculateLosses());\n }\n }\n }\n // TODO(cais): Add any unconditional model-level losses?\n return losses;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {name: this.name};\n\n // Build a map from layer unique name (self._node_key)\n // to the index of the nodes that are saved in the config.\n // Only nodes in container_nodes are saved.\n const nodeConversionMap: {[nodeKey: string]: number} =\n this.buildNodeConversionMap(this.layers);\n\n // Serialize and save the layers in layerConfigs\n const layerConfigs = [];\n for (const layer of this.layers) {\n const layerClassName = layer.getClassName();\n const layerConfig = layer.getConfig();\n const filteredInboundNodes = [];\n for (let originalNodeIndex = 0;\n originalNodeIndex < layer.inboundNodes.length; originalNodeIndex++) {\n const node = layer.inboundNodes[originalNodeIndex];\n const nodeKey = Container.nodeKey(layer, originalNodeIndex);\n let kwargs = {};\n if (this.containerNodes.has(nodeKey)) {\n // The node is relevant to the model:\n // add to filteredInboundNodes.\n if (node.callArgs) {\n try {\n JSON.stringify(node.callArgs);\n kwargs = node.callArgs;\n } catch (err) {\n console.warn(\n `Layer ${layer.name} was passed ` +\n `non-serializable keyword arguments: ` +\n `${node.callArgs}. They will not be included ` +\n `in the serialized model (and thus will be ` +\n `missing at deserialization time).`);\n kwargs = {};\n }\n }\n if (node.inboundLayers.length > 0) {\n const nodeData = [];\n for (let i = 0; i < node.inboundLayers.length; i++) {\n const inboundLayer = node.inboundLayers[i];\n const nodeIndex = node.nodeIndices[i];\n const tensorIndex = node.tensorIndices[i];\n const nodeKey = Container.nodeKey(inboundLayer, nodeIndex);\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n nodeData.push(\n [inboundLayer.name, newNodeIndex, tensorIndex, kwargs]);\n }\n filteredInboundNodes.push(nodeData);\n }\n }\n }\n layerConfigs.push({\n name: layer.name,\n className: layerClassName,\n config: layerConfig,\n inboundNodes: filteredInboundNodes\n });\n }\n config['layers'] = layerConfigs;\n // Gather info about inputs and outputs\n const modelInputs = [];\n for (let i = 0; i < this.inputLayers.length; i++) {\n const layer = this.inputLayers[i];\n const nodeIndex = this.inputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.inputLayersTensorIndices[i];\n modelInputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['inputLayers'] = modelInputs;\n\n const modelOutputs = [];\n for (let i = 0; i < this.outputLayers.length; i++) {\n const layer = this.outputLayers[i];\n const nodeIndex = this.outputLayersNodeIndices[i];\n\n const nodeKey = Container.nodeKey(layer, nodeIndex);\n if (!this.containerNodes.has(nodeKey)) {\n continue;\n }\n let newNodeIndex = nodeConversionMap[nodeKey];\n if (newNodeIndex === null || newNodeIndex === undefined) {\n newNodeIndex = 0;\n }\n const tensorIndex = this.outputLayersTensorIndices[i];\n modelOutputs.push([layer.name, newNodeIndex, tensorIndex]);\n }\n config['outputLayers'] = modelOutputs;\n return config;\n }\n\n /**\n * Instantiates a Model from its config (output of `get_config()`).\n * @param cls: the class to create\n * @param config: Model config dictionary.\n * @returns A model instance.\n * @throws ValueError: In case of improperly formatted config dict.\n */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n // Layer instances created during\n // the graph reconstruction process\n const createdLayers: {[layerName: string]: Layer} = {};\n\n // Dictionary mapping layer instances to\n // node data that specifies a layer call.\n // It acts as a queue that maintains any unprocessed\n // layer call until it becomes possible to process it\n // (i.e. until the input tensors to the call all exist).\n const unprocessedNodes:\n {[layer: string]: serialization.ConfigDict[][]} = {};\n function addUnprocessedNode(\n layer: Layer, nodeData: serialization.ConfigDict[]) {\n if (!(layer.name in unprocessedNodes)) {\n unprocessedNodes[layer.name] = [nodeData];\n } else {\n unprocessedNodes[layer.name].push(nodeData);\n }\n }\n\n function processNode(layer: Layer, nodeData: serialization.ConfigDict[]) {\n const inputTensors: SymbolicTensor[] = [];\n let kwargs;\n for (const inputData of nodeData) {\n const inboundLayerName = inputData[0] as string;\n const inboundNodeIndex = inputData[1] as number;\n const inboundTensorIndex = inputData[2] as number;\n if (inputData.length === 3) {\n kwargs = {};\n } else if (inputData.length === 4) {\n kwargs = inputData[3] as serialization.ConfigDict;\n } else {\n throw new ValueError(`Improperly formatted model config for layer ${\n JSON.stringify(layer)}: ${JSON.stringify(inputData)}`);\n }\n if (!(inboundLayerName in createdLayers)) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundLayer = createdLayers[inboundLayerName];\n if (inboundLayer.inboundNodes.length <= inboundNodeIndex) {\n addUnprocessedNode(layer, nodeData);\n return;\n }\n const inboundNode = inboundLayer.inboundNodes[inboundNodeIndex];\n inputTensors.push(inboundNode.outputTensors[inboundTensorIndex]);\n }\n // Call layer on its inputs, thus creating the node\n // and building the layer if needed.\n // Note: This has Eager vs Graph Implications.\n if (inputTensors.length > 0) {\n layer.apply(\n generic_utils.singletonOrArray(inputTensors),\n kwargs); // was ** kwargs\n }\n }\n\n /**\n * Deserialize a layer, then call it on appropriate inputs.\n * @param layerData: layer config dict.\n * @throws ValueError: In case of improperly formatted `layer_data`\n * dict.\n */\n function processLayer(layerData: serialization.ConfigDict|null) {\n const layerName = layerData.name as string;\n // Instantiate layer.\n const layer = deserializeLayer(\n layerData,\n config.customObjects != null ?\n config.customObjects as serialization.ConfigDict :\n {}) as Layer;\n createdLayers[layerName] = layer;\n // Gather layer inputs.\n const inboundNodesData =\n layerData.inboundNodes as serialization.ConfigDict[];\n for (const nodeData of inboundNodesData) {\n if (!(nodeData instanceof Array)) {\n throw new ValueError(\n `Corrupted configuration, expected array for nodeData: ${\n nodeData}`);\n }\n // We don't process nodes (i.e. make layer calls)\n // on the fly because the inbound node may not yet exist,\n // in case of layer shared at different topological depths\n // (e.g.a model such as A(B(A(B(x)))))\n addUnprocessedNode(layer, nodeData);\n }\n }\n\n // First, we create all layers and enqueue nodes to be processed\n const name = config.name;\n const layersFromConfig = config.layers as serialization.ConfigDict[];\n for (const layerData of layersFromConfig) {\n processLayer(layerData);\n }\n\n // Then we process nodes in order of layer depth.\n // Nodes that cannot yet be processed(if the inbound node\n // does not yet exist) are re - enqueued, and the process\n // is repeated until all nodes are processed.\n while (!generic_utils.isObjectEmpty(unprocessedNodes)) {\n for (const layerData of layersFromConfig) {\n const layer = createdLayers[layerData.name as string];\n if (layer.name in unprocessedNodes) {\n for (const nodeData of unprocessedNodes[layer.name]) {\n processNode(layer, nodeData);\n }\n delete unprocessedNodes[layer.name];\n }\n }\n }\n const inputTensors: SymbolicTensor[] = [];\n const outputTensors: SymbolicTensor[] = [];\n const inputLayersFromConfig =\n config.inputLayers as serialization.ConfigDict[];\n for (const layerData of inputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n inputTensors.push(layerOutputTensors[tensorIndex]);\n }\n const outputLayersFromConfig =\n config.outputLayers as serialization.ConfigDict[];\n for (const layerData of outputLayersFromConfig) {\n const layerName = layerData[0] as string;\n const nodeIndex = layerData[1] as number;\n const tensorIndex = layerData[2] as number;\n generic_utils.assert(layerName in createdLayers);\n const layer = createdLayers[layerName];\n const layerOutputTensors = layer.inboundNodes[nodeIndex].outputTensors;\n outputTensors.push(layerOutputTensors[tensorIndex]);\n }\n return new cls({inputs: inputTensors, outputs: outputTensors, name});\n }\n\n /**\n * Determine whether the container is stateful.\n *\n * Porting Note: this is the equivalent of the stateful @property of\n * the Container class in PyKeras.\n */\n get stateful(): boolean {\n // Porting Note: This check is to prevent inadvertent setting of the\n // _stateful property of the Container instance.\n if (this._stateful) {\n throw new ValueError(\n 'Container instance unexpectedly has _stateful = true. The ' +\n 'statefulness of a Container is determined by the Layers it ' +\n 'contains. Its _stateful property must remain the default false.');\n }\n for (const layer of this.layers) {\n if (layer.stateful) {\n return true;\n }\n }\n return false;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Executor: Evaluates SymbolicTensor based on feeds.\n */\n\nimport {cast, Tensor} from '@tensorflow/tfjs-core';\n\nimport {ValueError} from '../errors';\nimport {Kwargs} from '../types';\n\nimport {InputLayer} from './input_layer';\nimport {SymbolicTensor} from './topology';\n\n/**\n * Helper function to check the dtype and shape compatibility of a feed value.\n */\nfunction assertFeedCompatibility(key: SymbolicTensor, val: Tensor): Tensor {\n // 1. Check shape compatibility. If shapes are not compatible, error.\n if (key.shape != null) {\n if (key.shape.length !== val.shape.length) {\n throw new ValueError(\n `The rank of feed (${val.shape.length}) does not match the rank of ` +\n `the key (${key.shape.length}).`);\n }\n\n for (let i = 0; i < key.shape.length; ++i) {\n if (key.shape[i] != null && key.shape[i] !== val.shape[i]) {\n throw new ValueError(\n `The ${i}-th dimension of the feed (${val.shape[i]}) is ` +\n `incompatible with that of the key (${key.shape[i]}).`);\n }\n }\n }\n // 2. Check dtype compatibility.\n if (key.dtype == null || key.dtype === val.dtype) {\n // 2a. If types match, return val tensor as is.\n return val;\n }\n try {\n // 2b. Attempt to convert to expected type.\n return cast(val, key.dtype);\n } catch (err) {\n // 2c. If conversion fails, return helpful error.\n throw new ValueError(\n `The dtype of the feed (${val.dtype}) can not be cast to the dtype ` +\n `of the key '${key.name}' (${key.dtype}).`);\n }\n}\n\n/**\n * A concrete Tensor value for a symbolic tensor as the key.\n */\nexport interface Feed {\n key: SymbolicTensor;\n value: Tensor;\n}\n\n/**\n * FeedDict: A mapping from unique SymbolicTensors to feed values for them.\n * A feed value is a concrete value represented as an `Tensor`.\n */\nexport class FeedDict {\n private id2Value: {[id: number]: Tensor} = {};\n\n /**\n * Constructor, optionally does copy-construction.\n * @param feeds An Array of `Feed`s, or another `FeedDict`, in which case\n * copy-construction will be performed.\n */\n constructor(feeds?: Feed[]|FeedDict) {\n if (feeds instanceof FeedDict) {\n for (const id in feeds.id2Value) {\n this.id2Value[id] = feeds.id2Value[id];\n }\n } else {\n if (feeds == null) {\n return;\n }\n for (const feed of feeds) {\n this.add(feed.key, feed.value);\n }\n }\n }\n\n /**\n * Add a key-value pair to the FeedDict.\n * @param key The key of the feed.\n * @param value The value of the feed.\n * @returns This `FeedDict`.\n * @throws ValueError: If the key `SymbolicTensor` already exists in the\n * `FeedDict`.\n */\n add(key: SymbolicTensor, value: Tensor): FeedDict {\n if (this.id2Value[key.id] == null) {\n this.id2Value[key.id] = assertFeedCompatibility(key, value);\n } else {\n throw new ValueError(`Duplicate key: name=${key.name}, id=${key.id}`);\n }\n return this;\n }\n\n /**\n * Add a Feed to the FeedDict.\n * @param feed The new `Feed` to add.\n * @returns This `FeedDict`.\n */\n addFeed(feed: Feed) {\n this.add(feed.key, feed.value);\n }\n\n /**\n * Probe whether a key already exists in the FeedDict.\n * @param key\n */\n hasKey(key: SymbolicTensor): boolean {\n return this.id2Value[key.id] != null;\n }\n\n /**\n * Get the feed value for given key.\n * @param key\n * @returns If `key` exists, the corresponding feed value.\n * @throws ValueError: If `key` does not exist in this `FeedDict`.\n */\n getValue(key: SymbolicTensor): Tensor {\n if (this.id2Value[key.id] == null) {\n throw new ValueError(`Nonexistent key: ${JSON.stringify(key)}`);\n } else {\n return this.id2Value[key.id];\n }\n }\n}\n\n/**\n * Execute a SymbolicTensor by using concrete feed values.\n *\n * A `SymbolicTensor` object is a node in a computation graph of TF.js\n * Layers. The object is backed by a source layer and input\n * `SymbolicTensor`s to the source layer. This method evaluates\n * the `call()` method of the source layer, using concrete values of the inputs\n * obtained from either\n * * `feedDict`, if the input key exists in `feedDict`, or else,\n * * a recursive call to `execute()` itself.\n *\n * @param x: The `SymbolicTensor` to execute.\n * @param feedDict: The feed values, as base condition of the recursion.\n * execution.\n * @param kwargs: Optional keyword arguments.\n * @returns Result of the execution.\n * @throws ValueError: If any `SymbolicTensor`s from `InputLayer`s\n * encountered during the execution lacks a feed value in `feedDict`.\n */\nexport function execute(\n fetches: SymbolicTensor|SymbolicTensor[], feedDict: FeedDict,\n kwargs?: Kwargs): Tensor|Tensor[]|[Tensor | Tensor[]] {\n const arrayFetches = Array.isArray(fetches);\n const fetchArray: SymbolicTensor[] =\n arrayFetches ? fetches as SymbolicTensor[] : [fetches as SymbolicTensor];\n\n const outputs: Tensor[] = [];\n const internalFeedDict = new FeedDict(feedDict);\n\n for (const fetch of fetchArray) {\n outputs.push(executeInternal(fetch, internalFeedDict, kwargs) as Tensor);\n }\n return arrayFetches ? outputs : outputs[0];\n}\n\nfunction executeInternal(\n fetch: SymbolicTensor, internalFeedDict: FeedDict,\n kwargs?: Kwargs): Tensor {\n if (internalFeedDict.hasKey(fetch)) {\n return internalFeedDict.getValue(fetch);\n }\n if (fetch.sourceLayer instanceof InputLayer) {\n throw new ValueError(\n `Missing a feed value for SymbolicTensor from InputLayer ` +\n `'${InputLayer.name}'`);\n }\n\n const inputs = fetch.inputs;\n const inputValues: Tensor[] = [];\n for (const input of inputs) {\n // Recursive call.\n const inputVal = executeInternal(input, internalFeedDict, kwargs) as Tensor;\n inputValues.push(inputVal);\n }\n\n let output =\n fetch.sourceLayer.apply(inputValues, kwargs) as Tensor | Tensor[];\n if (!Array.isArray(output)) {\n output = [output];\n }\n const layerOutputs = getNodeOutputs(fetch);\n const outputSymbolicTensors =\n Array.isArray(layerOutputs) ? layerOutputs : [layerOutputs];\n for (let i = 0; i < outputSymbolicTensors.length; ++i) {\n internalFeedDict.add(outputSymbolicTensors[i], output[i]);\n }\n return output.length === 1 ? output[0] : output[fetch.outputTensorIndex];\n}\n\n/**\n * Get the symbolic output tensors of the node to which a given fetch belongs.\n * @param fetch The fetched symbolic tensor.\n * @returns The Array of symbolic tensors output by the node to which `fetch`\n * belongs.\n */\nfunction getNodeOutputs(fetch: SymbolicTensor): SymbolicTensor|\n SymbolicTensor[] {\n let layerOutputs: SymbolicTensor|SymbolicTensor[];\n if (fetch.sourceLayer.inboundNodes.length === 1) {\n layerOutputs = fetch.sourceLayer.output;\n } else {\n let nodeIndex: number = null;\n for (let i = 0; i < fetch.sourceLayer.inboundNodes.length; ++i) {\n for (const outputTensor of fetch.sourceLayer.inboundNodes[i]\n .outputTensors) {\n if (outputTensor.id === fetch.id) {\n nodeIndex = i;\n break;\n }\n }\n }\n layerOutputs = fetch.sourceLayer.getOutputAt(nodeIndex);\n }\n return layerOutputs;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original Source: engine/training.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {io, ModelPredictConfig, Optimizer, Scalar, serialization, Tensor, Tensor1D, tensor1d, util} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {BaseCallback, BaseLogger, CallbackList, CustomCallbackConfig, History, standardizeCallbacks} from '../base_callbacks';\nimport {nameScope} from '../common';\nimport {NotImplementedError, RuntimeError, ValueError} from '../errors';\nimport {disposeTensorsInLogs, UnresolvedLogs} from '../logs';\nimport * as losses from '../losses';\nimport * as Metrics from '../metrics';\nimport * as optimizers from '../optimizers';\nimport {LossOrMetricFn, NamedTensorMap, Shape} from '../types';\nimport {count, pyListRepeat, singletonOrArray, unique} from '../utils/generic_utils';\nimport {printSummary} from '../utils/layer_utils';\nimport {range} from '../utils/math_utils';\nimport {LayerVariable} from '../variables';\n\nimport {Container, ContainerConfig} from './container';\nimport {execute, FeedDict} from './executor';\nimport {SymbolicTensor} from './topology';\n\n// tslint:enable:max-line-length\n\n/**\n * Helper function for polymorphic input data: 1. singleton Tensor.\n */\nexport function isDataTensor(x: Tensor|Tensor[]|{[inputName: string]: Tensor}|\n {[inputName: string]: Tensor[]}): boolean {\n return x instanceof Tensor;\n}\n\n/**\n * Helper function for polymorphic input data: 2. Array of Tensor.\n */\nexport function isDataArray(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return Array.isArray(x);\n}\n\n/**\n * Helper function for polymorphic input data: 3. \"dict\" of Tensor.\n */\nexport function isDataDict(x: Tensor|Tensor[]|\n {[inputName: string]: Tensor}): boolean {\n return !isDataTensor(x) && !isDataArray(x);\n}\n\n/**\n * Normalizes inputs and targets provided by users.\n * @param data User-provided input data (polymorphic).\n * @param names An Array of expected Tensor names.\n * @param shapes Optional Array of expected Tensor shapes.\n * @param checkBatchAxis Whether to check that the batch axis of the arrays\n * match the expected value found in `shapes`.\n * @param exceptionPrefix String prefix used for exception formatting.\n * @returns List of standardized input Tensors (one Tensor per model input).\n * @throws ValueError: in case of improperly formatted user data.\n */\nexport function standardizeInputData(\n data: Tensor|Tensor[]|{[inputName: string]: Tensor}, names: string[],\n shapes?: Shape[], checkBatchAxis = true, exceptionPrefix = ''): Tensor[] {\n if (names == null || names.length === 0) {\n // Check for the case where the model expected no data, but some data got\n // sent.\n if (data != null) {\n let gotUnexpectedData = false;\n if (isDataArray(data) && (data as Tensor[]).length > 0) {\n gotUnexpectedData = true;\n } else if (isDataDict(data)) {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n gotUnexpectedData = true;\n break;\n }\n }\n } else {\n // `data` is a singleton Tensor in this case.\n gotUnexpectedData = true;\n }\n if (gotUnexpectedData) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix} expected no data, ` +\n `but got ${data}`);\n }\n }\n return [];\n }\n if (data == null) {\n return names.map(name => null);\n }\n\n let arrays: Tensor[];\n if (isDataDict(data)) {\n data = data as {[inputName: string]: Tensor};\n arrays = [];\n for (const name of names) {\n if (data[name] == null) {\n throw new ValueError(\n `No data provided for \"${name}\". Need data for each key in: ` +\n `${names}`);\n }\n arrays.push(data[name]);\n }\n } else if (isDataArray(data)) {\n data = data as Tensor[];\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `model expected. Expected to see ${names.length} Tensor(s), but ` +\n `instead got the following list of Tensor(s): ${data}`);\n }\n arrays = data;\n } else {\n data = data as Tensor;\n if (names.length > 1) {\n throw new ValueError(\n `The model ${exceptionPrefix} expects ${names.length} Tensor(s), ` +\n `but only received one Tensor. Found: Tensor with shape ${\n data.shape}`);\n }\n arrays = [data];\n }\n\n // Make Tensors at least 2D.\n for (let i = 0; i < names.length; ++i) {\n const array = arrays[i];\n if (array.shape.length === 1) {\n arrays[i] = K.expandDims(array, 1);\n }\n }\n\n // Check shape compatibility.\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s). but got array with ` +\n `shape ${array.shape}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n // Skip the first (batch) axis.\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null && refDim >= 0 && dim !== refDim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have shape [${shapes[i]}], but got array with shape ` +\n `[${array.shape}].`);\n }\n }\n }\n }\n return arrays;\n}\n\n/**\n * User input validation for Tensors.\n * @param inputs `Array` of `Tensor`s for inputs.\n * @param targets `Array` of `Tensor`s for targets.\n * @param weights Optional `Array` of `Tensor`s for sample weights.\n * @throws ValueError: in case of incorrectly formatted data.\n */\nexport function checkArrayLengths(\n inputs: Tensor[], targets: Tensor[], weights?: Tensor[]) {\n const setX = unique(inputs.map(input => input.shape[0]));\n setX.sort();\n const setY = unique(targets.map(target => target.shape[0]));\n setY.sort();\n // TODO(cais): Check `weights` as well.\n if (setX.length > 1) {\n throw new ValueError(\n `All input Tensors (x) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(inputs.map(input => input.shape))}`);\n }\n if (setY.length > 1) {\n throw new ValueError(\n `All target Tensors (y) should have the same number of samples. ` +\n `Got array shapes: ` +\n `${JSON.stringify(targets.map(target => target.shape))}`);\n }\n if (setX.length > 0 && setY.length > 0 && !util.arraysEqual(setX, setY)) {\n throw new ValueError(\n `Input Tensors should have the same number of samples as target ` +\n `Tensors. Found ${setX[0]} input sample(s) and ${setY[0]} target ` +\n `sample(s).`);\n }\n}\n\n/**\n * Validation on the compatibility of targes and loss functions.\n *\n * This helps prevent users from using loss functions incorrectly.\n *\n * @param targets `Array` of `Tensor`s of targets.\n * @param lossFns `Array` of loss functions.\n * @param outputShapes `Array` of shapes of model outputs.\n */\nfunction checkLossAndTargetCompatibility(\n targets: Tensor[], lossFns: LossOrMetricFn[], outputShapes: Shape[]) {\n // TODO(cais): Dedicated test coverage?\n const keyLosses = [\n losses.meanSquaredError, losses.binaryCrossentropy,\n losses.categoricalCrossentropy\n ];\n for (let i = 0; i < targets.length; ++i) {\n const y = targets[i];\n const loss = lossFns[i];\n const shape = outputShapes[i];\n if (loss == null) {\n continue;\n }\n if (loss === losses.categoricalCrossentropy) {\n if (y.shape[y.shape.length - 1] === 1) {\n throw new ValueError(\n `You are passing a target array of shape ${y.shape} while using ` +\n `a loss 'categorical_crossentropy'. 'categorical_crossentropy'` +\n `expects targets to be binary matrices (1s and 0s) of shape ` +\n `[samples, classes].`);\n // TODO(cais): Example code in error message.\n }\n }\n if (keyLosses.indexOf(loss) !== -1) {\n const slicedYShape = y.shape.slice(1);\n const slicedShape = shape.slice(1);\n for (let j = 0; j < slicedYShape.length; ++j) {\n const targetDim = slicedYShape[j];\n const outDim = slicedShape[j];\n if (outDim != null && targetDim !== outDim) {\n throw new ValueError(\n `A target Tensor with shape ${y.shape} was passed for an ` +\n `output of shape ${shape}, while using a loss function that ` +\n `expects targets to have the same shape as the output.`);\n }\n }\n }\n }\n}\n\n/**\n * Returns a list of batch indices (tuples of indices).\n * @param size: Integer, total size of the data to slice into batches.\n * @param batchSize: Integer, batch size.\n * @returns An Array of [batchStart, batchEnd] tuples. batchStart is\n * inclusive; batchEnd is exclusive. I.e., each batch consists of indices x\n * that satisfy batchStart <= x < batchEnd.\n */\nexport function makeBatches(\n size: number, batchSize: number): Array<[number, number]> {\n const output: Array<[number, number]> = [];\n let batchStart = 0;\n let batchEnd: number = null;\n while (batchStart < size) {\n batchEnd = batchStart + batchSize;\n if (batchEnd >= size) {\n batchEnd = size;\n }\n output.push([batchStart, batchEnd]);\n batchStart = batchEnd;\n }\n return output;\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by start and stop indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArraysByIndices()` together.\n *\n * @param arrays: the input.\n * @param start: the starting index (inclusive).\n * @param stop: the stopping index (exclusive).\n * @returns The result of the slicing. If `arrays` is an `Array` of\n * `Tensor`s, the slicing will be applied to all elements of the `Array`\n * in the same way.\n */\nfunction sliceArrays(\n arrays: Tensor|Tensor[], start: number, stop: number): Tensor|Tensor[] {\n if (arrays == null) {\n return [null];\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => K.sliceAlongFirstAxis(array, start, stop - start));\n } else { // Tensor.\n return K.sliceAlongFirstAxis(arrays, start, stop - start);\n }\n}\n\n/**\n * Slice an Tensor or an Array of Tensors, by random-order indices.\n *\n * Porting Note: The `_slice_arrays` function in PyKeras is covered by this\n * function and `sliceArrays()` together.\n *\n * @param arrays The input `Tensor` or `Array` of `Tensor`s to slice.\n * If an `Array` of `Tensor`s, all `Tensor`s will be sliced in the\n * same fashion.\n * @param indices The indices to use for slicing along the first (batch)\n * dimension.\n * @returns Result(s) of the slicing.\n */\nexport function sliceArraysByIndices(\n arrays: Tensor|Tensor[], indices: Tensor1D): Tensor|Tensor[] {\n return tfc.tidy(() => {\n if (arrays == null) {\n return null;\n } else if (Array.isArray(arrays)) {\n return arrays.map(\n array => (sliceArraysByIndices(array, indices) as Tensor));\n } else {\n // TODO(cais): indices should be a pre-constructed Tensor1D to avoid\n // tensor1d() calls.\n return K.gather(\n arrays, indices.dtype === 'int32' ? indices : indices.toInt());\n }\n });\n}\n\n/**\n * Check inputs provided by the user.\n *\n * Porting Note: This corresponds to _standardize_input_data() in Python\n * Keras. Because of the strong typing in TF.js, we do not need to convert\n * the data. Specifically:\n * 1) in PyKeras, `data` can be `DataFrame` instances from pandas, for\n * example. We don't need to worry about that here because there is no\n * widely popular javascript/typesdcript equivalent of pandas (so far).\n * If one becomes available in the future, we can add support.\n * 2) in PyKeras, inputs can be Python dict. But here we are stipulating\n * that the data is either a single `Tensor` or an Array of `Tensor`s. We\n * may add support for `Object` data inputs in the future when the need\n * arises.\n *\n * Instead, we perform basic checks for number of parameters and shapes.\n *\n * @param data: The input data.\n * @param names: Name for the inputs, from the model.\n * @param shapes: Expected shapes for the input data, from the model.\n * @param checkBatchAxis: Whether the size along the batch axis (i.e., the\n * first dimension) will be checked for matching.\n * @param exceptionPrefix: Execption prefix message, used in generating error\n * messages.\n * @throws ValueError: on incorrect number of inputs or mismatches in shapes.\n */\nfunction checkInputData(\n data: Tensor|Tensor[], names: string[], shapes?: Shape[],\n checkBatchAxis = true, exceptionPrefix = '') {\n let arrays: Tensor[];\n if (Array.isArray(data)) {\n if (data.length !== names.length) {\n throw new ValueError(\n `Error when checking model ${exceptionPrefix}: the Array of ` +\n `Tensors that you are passing to your model is not the size the ` +\n `the model expected. Expected to see ${names.length} Tensor(s),` +\n ` but instead got ${data.length} Tensors(s).`);\n }\n arrays = data;\n } else {\n if (names.length > 1) {\n throw new ValueError(\n `The model expects ${names.length} ${exceptionPrefix} Tensors, ` +\n `but only received one Tensor. Found: array with shape ` +\n `${JSON.stringify(data.shape)}.`);\n }\n arrays = [data];\n }\n\n if (shapes != null) {\n for (let i = 0; i < names.length; ++i) {\n if (shapes[i] == null) {\n continue;\n }\n const array = arrays[i];\n if (array.shape.length !== shapes[i].length) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ${names[i]} ` +\n `to have ${shapes[i].length} dimension(s), but got array with ` +\n `shape ${JSON.stringify(array.shape)}`);\n }\n for (let j = 0; j < shapes[i].length; ++j) {\n if (j === 0 && !checkBatchAxis) {\n continue;\n }\n const dim = array.shape[j];\n const refDim = shapes[i][j];\n if (refDim != null) {\n if (refDim !== dim) {\n throw new ValueError(\n `Error when checking ${exceptionPrefix}: expected ` +\n `${names[i]} to have shape ${JSON.stringify(shapes[i])} but ` +\n `got array with shape ${JSON.stringify(array.shape)}.`);\n }\n }\n }\n }\n }\n}\n\n/**\n * Maps metric functions to model outputs.\n * @param metrics An `Array` or dict (`Object`) of metric functions.\n * @param outputNames An `Array` of the names of model outputs.\n * @returns An `Array` (one entry per model output) of `Array` of metric\n * functions. For instance, if the model has 2 outputs, and for the first\n * output we want to compute `binaryAccuracy` and `binaryCrossentropy`,\n * and just `binaryAccuracy` for the second output, the `Array` would look\n * like:\n * `[[binaryAccuracy, binaryCrossentropy], [binaryAccuracy]]`\n * @throws TypeError: if `null` or `undefined` value is provided.\n */\nfunction collectMetrics(\n metrics: string[]|{[outputName: string]: string | string[]},\n outputNames: string[]): string[][] {\n if (metrics == null || Array.isArray(metrics) && metrics.length === 0) {\n return outputNames.map(name => []);\n }\n if (Array.isArray(metrics)) {\n // We then apply all metrics to all outputs.\n return outputNames.map(name => metrics);\n } else if (metrics != null) {\n // In this case, metrics is a dict.\n const nestedMetrics: string[][] = [];\n for (const name of outputNames) {\n let outputMetrics: string|string[] =\n metrics.hasOwnProperty(name) ? metrics[name] : [];\n if (!Array.isArray(outputMetrics)) {\n outputMetrics = [outputMetrics];\n }\n nestedMetrics.push(outputMetrics as string[]);\n }\n return nestedMetrics;\n } else {\n throw new TypeError(\n 'Type of metrics argument not understood. Expected an Array or ' +\n 'Object, found: ' + metrics);\n }\n}\n\n/** Verbosity logging level when fitting a model. */\nexport enum ModelLoggingVerbosity {\n SILENT = 0,\n VERBOSE = 1\n}\n\nexport interface ModelEvaluateConfig {\n /**\n * Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Verbosity mode.\n */\n verbose?: ModelLoggingVerbosity;\n\n /**\n * Tensor of weights to weight the contribution of different samples to the\n * loss and metrics.\n */\n sampleWeight?: Tensor;\n\n /**\n * integer: total number of steps (batches of samples)\n * before declaring the evaluation round finished. Ignored with the default\n * value of `undefined`.\n */\n steps?: number;\n}\n\n/**\n * Interface for specifying data to fit a model to data.\n */\nexport interface ModelFitConfig {\n /**\n * Number of samples per gradient update. If unspecified, it\n * will default to 32.\n */\n batchSize?: number;\n\n /** The number of times to iterate over the training data arrays. */\n epochs?: number;\n\n verbose?: ModelLoggingVerbosity;\n\n /**\n * List of callbacks to be called during training.\n * Can consist of one or more of the following fields: `onTrainBegin`,\n * `onTrainEnd`, `onEpochBegin`, `onEpochEnd`, `onBatchBegin`, `onBatchEnd`.\n */\n callbacks?: BaseCallback[]|CustomCallbackConfig|CustomCallbackConfig[];\n\n /**\n * Float between 0 and 1: fraction of the training data\n * to be used as validation data. The model will set apart this fraction of\n * the training data, will not train on it, and will evaluate the loss and\n * any model metrics on this data at the end of each epoch.\n * The validation data is selected from the last samples in the `x` and `y`\n * data provided, before shuffling.\n */\n validationSplit?: number;\n\n /**\n * Data on which to evaluate the loss and any model\n * metrics at the end of each epoch. The model will not be trained on this\n * data. This could be a tuple [xVal, yVal] or a tuple [xVal, yVal,\n * valSampleWeights]. The model will not be trained on this data.\n * `validationData` will override `validationSplit`.\n */\n validationData?: [\n Tensor|Tensor[], Tensor|Tensor[]\n ]|[Tensor | Tensor[], Tensor|Tensor[], Tensor|Tensor[]];\n\n /**\n * Whether to shuffle the training data before each epoch. Has\n * no effect when `stepsPerEpoch` is not `null`.\n */\n shuffle?: boolean;\n\n /**\n * Optional dictionary mapping class indices (integers) to\n * a weight (float) to apply to the model's loss for the samples from this\n * class during training. This can be useful to tell the model to \"pay more\n * attention\" to samples from an under-represented class.\n */\n classWeight?: {[classIndex: string]: number};\n\n /**\n * Optional array of the same length as x, containing\n * weights to apply to the model's loss for each sample. In the case of\n * temporal data, you can pass a 2D array with shape (samples,\n * sequenceLength), to apply a different weight to every timestep of every\n * sample. In this case you should make sure to specify\n * sampleWeightMode=\"temporal\" in compile().\n */\n sampleWeight?: Tensor;\n\n /**\n * Epoch at which to start training (useful for resuming a previous training\n * run).\n */\n initialEpoch?: number;\n\n /**\n * Total number of steps (batches of samples) before\n * declaring one epoch finished and starting the next epoch. When training\n * with Input Tensors such as TensorFlow data tensors, the default `null` is\n * equal to the number of unique samples in your dataset divided by the\n * batch size, or 1 if that cannot be determined.\n */\n stepsPerEpoch?: number;\n\n /**\n * Only relevant if `stepsPerEpoch` is specified. Total number of steps\n * (batches of samples) to validate before stopping.\n */\n validationSteps?: number;\n\n /**\n *\n */\n yieldEvery?: 'batch'|'epoch'|'never';\n}\n\n/**\n * Configuration for calls to `Model.compile()`.\n */\nexport interface ModelCompileConfig {\n /**\n * An instance of `tf.train.Optimizer` or a string name for an Optimizer.\n */\n optimizer: string|Optimizer;\n\n /**\n * Object function(s) or name(s) of object function(s).\n * If the model has multiple outputs, you can use a different loss\n * on each output by passing a dictionary or an Array of losses.\n * The loss value that will be minimized by the model will then be the sum\n * of all individual losses.\n */\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n\n /**\n * List of metrics to be evaluated by the model during training and testing.\n * Typically you will use `metrics=['accuracy']`.\n * To specify different metrics for different outputs of a multi-output\n * model, you could also pass a dictionary.\n */\n metrics?: string[]|{[outputName: string]: string};\n\n // TODO(cais): Add lossWeights, sampleWeightMode, weightedMetrics, and\n // targetTensors.\n}\n\n/**\n * A `Model` is a directed, acyclic graph of `Layer`s plus methods for\n * training, evaluation, prediction and saving.\n *\n * `Model` is the basic unit of training, inference and evaluation in\n * TensorFlow.js. To create a `Model`, use `model`.\n *\n * See also:\n * `Sequential`, `loadModel`.\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Model extends Container implements tfc.InferenceModel {\n static className = 'Model';\n optimizer: Optimizer;\n loss: string|string[]|{[outputName: string]: string}|LossOrMetricFn|\n LossOrMetricFn[]|{[outputName: string]: LossOrMetricFn};\n lossFunctions: LossOrMetricFn[];\n\n // TODO(cais): These private variables should probably not have the string\n // 'feed' in their names, because we are not dealing with a symbolic\n // backend.\n private feedOutputShapes: Shape[];\n private feedLossFns: LossOrMetricFn[];\n private collectedTrainableWeights: LayerVariable[];\n private testFunction: (data: Tensor[]) => Scalar[];\n history: History;\n\n // A public property that can be set by Callbacks to order early stopping\n // during `fit()` calls.\n stopTraining: boolean;\n\n metrics: string[]|{[outputName: string]: string};\n metricsNames: string[];\n // Porting Note: `metrics_tensors` in PyKeras is a symbolic tensor. But given\n // the imperative nature of tfjs-core, `metricsTensors` is a\n // TypeScript function here.\n // Also note that due to the imperative nature of tfjs-core, `metricsTensor`\n // here needs an output index to keep track of which output of the Model\n // a metric belongs to. This is unlike `metrics_tensors` in PyKeras,\n // which is a `list` of symbolic tensors, each of which has implicit\n // \"knowledge\" of the outputs it depends on.\n metricsTensors: Array<[LossOrMetricFn, number]>;\n\n constructor(config: ContainerConfig) {\n super(config);\n }\n\n /**\n * Print a text summary of the model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - If the model has non-sequential-like topology, the inputs each layer\n * receives\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const input1 = tf.input({shape: [10]});\n * const input2 = tf.input({shape: [20]});\n * const dense1 = tf.layers.dense({units: 4}).apply(input1);\n * const dense2 = tf.layers.dense({units: 8}).apply(input2);\n * const concat = tf.layers.concatenate().apply([dense1, dense2]);\n * const output =\n * tf.layers.dense({units: 3, activation: 'softmax'}).apply(concat);\n *\n * const model = tf.model({inputs: [input1, input2], outputs: output});\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n throw new ValueError(\n `This model has never been called, thus its weights have not been ` +\n `created yet. So no summary can be displayed. Build the model ` +\n `first (e.g., by calling it on some test data).`);\n }\n printSummary(this, lineLength, positions, printFn);\n }\n\n /**\n * Configures and prepares the model for training and evaluation. Compiling\n * outfits the model with an optimizer, loss, and/or metrics. Calling `fit`\n * or `evaluate` on an un-compiled model will throw an error.\n *\n * @param config a `ModelCompileConfig` specifying the loss, optimizer, and\n * metrics to be used for fitting and evaluating this model.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [0]}\n */\n compile(config: ModelCompileConfig): void {\n if (config.loss == null) {\n config.loss = [];\n }\n this.loss = config.loss;\n\n if (typeof config.optimizer === 'string') {\n this.optimizer = optimizers.getOptimizer(config.optimizer);\n } else {\n if (!(config.optimizer instanceof Optimizer)) {\n throw new ValueError(\n `User-defined optimizer must be an instance of tf.Optimizer.`);\n }\n this.optimizer = config.optimizer;\n }\n\n // TODO(cais): Add lossWeights.\n // TODO(cais): Add sampleWeightMode.\n\n // Prepare loss functions.\n let lossFunctions: LossOrMetricFn[] = [];\n if (!Array.isArray(config.loss) && typeof config.loss !== 'string' &&\n typeof config.loss !== 'function') {\n config.loss = config.loss as {[outputName: string]: string};\n for (const name in config.loss) {\n if (this.outputNames.indexOf(name) === -1) {\n throw new ValueError(\n `Unknown entry in loss dictionary: \"${name}\". Only expect the ` +\n `following keys: ${this.outputNames}`);\n }\n }\n for (const name in this.outputNames) {\n if (config.loss[name] == null) {\n console.warn(\n `Output \"${name}\" is missing from loss dictionary. We assume ` +\n `this was done on purpose, and we will not be expecting data ` +\n `to be passed to ${name} during training`);\n }\n lossFunctions.push(losses.get(config.loss[name]));\n }\n } else if (Array.isArray(config.loss)) {\n if (config.loss.length !== this.outputs.length) {\n throw new ValueError(\n `When passing an Array as loss, it should have one entry per ` +\n `model output. The model has ${this.outputs.length} output(s), ` +\n `but you passed loss=${config.loss}.`);\n }\n const theLosses = config.loss as Array;\n lossFunctions = theLosses.map(l => losses.get(l));\n } else {\n const lossFunction = losses.get(config.loss);\n this.outputs.map(layer => {\n lossFunctions.push(lossFunction);\n });\n }\n\n this.lossFunctions = lossFunctions;\n\n this.feedOutputNames = [];\n this.feedOutputShapes = [];\n this.feedLossFns = [];\n for (let i = 0; i < this.outputs.length; ++i) {\n // TODO(cais): Logic for skipping target(s).\n const shape = this.internalOutputShapes[i];\n const name = this.outputNames[i];\n this.feedOutputNames.push(name);\n this.feedOutputShapes.push(shape);\n this.feedLossFns.push(this.lossFunctions[i]);\n }\n\n // TODO(cais): Add logic for weighted losses.\n // TODO(cais): Add logic for output masks.\n // TODO(cais): Add logic for sample weights.\n const skipTargetIndices: number[] = [];\n\n // Prepare metrics.\n this.metrics = config.metrics;\n // TODO(cais): Add weightedMetrics.\n this.metricsNames = ['loss'];\n this.metricsTensors = [];\n\n // Compute total loss.\n // Porting Note: In PyKeras, metrics_tensors are symbolic tensor objects.\n // Here, metricsTensors are TypeScript functions. This difference is due\n // to the difference in symbolic/imperative property of the backends.\n nameScope('loss', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n // TODO(cais): Add weightedLoss, sampleWeight and mask.\n // The following line should be weightedLoss\n const weightedLoss = this.lossFunctions[i];\n if (this.outputs.length > 1) {\n this.metricsTensors.push([weightedLoss, i]);\n this.metricsNames.push(this.outputNames[i] + '_loss');\n }\n }\n\n // Porting Note: Due to the imperative nature of the backend, we calculate\n // the regularizer penalties in the totalLossFunction, instead of here.\n });\n\n const nestedMetrics = collectMetrics(config.metrics, this.outputNames);\n // TODO(cais): Add nestedWeightedMetrics.\n\n /**\n * Helper function used in loop below.\n */\n const appendMetric =\n (outputIndex: number, metricName: string,\n metricTensor: LossOrMetricFn) => {\n if (this.outputNames.length > 1) {\n metricName = this.outputNames[outputIndex] + '_' + metricName;\n }\n this.metricsNames.push(metricName);\n this.metricsTensors.push([metricTensor, outputIndex]);\n };\n\n nameScope('metric', () => {\n for (let i = 0; i < this.outputs.length; ++i) {\n if (skipTargetIndices.indexOf(i) !== -1) {\n continue;\n }\n const outputMetrics = nestedMetrics[i];\n // TODO(cais): Add weights and outputWeightedMetrics.\n\n // TODO(cais): Add optional arg `weights` to the following function.\n const handleMetrics = (metrics: string[]) => {\n const metricNamePrefix = '';\n let metricName: string;\n let accFn: LossOrMetricFn;\n let weightedMetricFn: LossOrMetricFn;\n // TODO(cais): Use 'weights_' for weighted metrics.\n\n for (const metric of metrics) {\n if (['accuracy', 'acc', 'crossentropy', 'ce'].indexOf(metric) !==\n -1) {\n const outputShape = this.internalOutputShapes[i];\n\n if (outputShape[outputShape.length - 1] === 1 ||\n this.lossFunctions[i] === losses.binaryCrossentropy) {\n // case: binary accuracy/crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.binaryCrossentropy;\n }\n } else if (\n this.lossFunctions[i] ===\n losses.sparseCategoricalCrossentropy) {\n // case: categorical accuracy / crossentropy with sparse\n // targets.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.sparseCategoricalCrossentropy;\n }\n } else {\n // case: categorical accuracy / crossentropy.\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalAccuracy;\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n accFn = Metrics.categoricalCrossentropy;\n }\n }\n let suffix: string;\n if (['accuracy', 'acc'].indexOf(metric) !== -1) {\n suffix = 'acc';\n } else if (['crossentropy', 'ce'].indexOf(metric) !== -1) {\n suffix = 'ce';\n }\n // TODO(cais): Add weighting actually.\n weightedMetricFn = accFn;\n metricName = metricNamePrefix + suffix;\n } else {\n const metricFn = Metrics.get(metric);\n // TODO(cais): Add weighting actually.\n weightedMetricFn = metricFn;\n metricName = metricNamePrefix + metric;\n }\n\n // TODO(cais): Add weighting and masking to metricResult.\n let metricResult: LossOrMetricFn;\n nameScope(metricName, () => {\n metricResult = weightedMetricFn;\n });\n appendMetric(i, metricName, metricResult);\n }\n };\n\n handleMetrics(outputMetrics);\n // TODO(cais): Call handleMetrics with weights.\n }\n });\n\n // Porting Notes: Given the imperative backend of tfjs-core,\n // there is no need for constructing the symbolic graph and placeholders.\n this.collectedTrainableWeights = this.trainableWeights;\n }\n\n /**\n * Check trainable weights count consistency.\n *\n * This will raise a warning if `this.trainableWeights` and\n * `this.collectedTrainableWeights` are inconsistent (i.e., have different\n * numbers of parameters).\n * Inconsistency will typically arise when one modifies `model.trainable`\n * without calling `model.compile()` again.\n */\n private checkTrainableWeightsConsistency(): void {\n if (this.collectedTrainableWeights == null) {\n return;\n }\n if (this.trainableWeights.length !==\n this.collectedTrainableWeights.length) {\n console.warn(\n 'Discrepancy between trainableweights and collected trainable ' +\n 'weights. Did you set `model.trainable` without calling ' +\n '`model.compile()` afterwards?');\n }\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(\n * tf.ones([8, 10]), tf.ones([8, 1]), {batchSize: 4});\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model has\n * multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // TODO(cais): Standardize `config.sampleWeights` as well.\n // Validate user data.\n const standardizedOuts = this.standardizeUserData(x, y, true, batchSize);\n // TODO(cais): If uses `useLearningPhase`, set the corresponding element of\n // the input to 0.\n const ins = standardizedOuts[0].concat(standardizedOuts[1]);\n this.makeTestFunction();\n const f = this.testFunction;\n const testOuts =\n this.testLoop(f, ins, batchSize, config.verbose, config.steps);\n return singletonOrArray(testOuts);\n }\n\n /**\n * Get number of samples provided for training, evaluation or prediction.\n *\n * @param ins Input `Tensor`.\n * @param batchSize Integer batch size, optional.\n * @param steps Total number of steps (batches of samples) before declaring\n * loop finished. Optional.\n * @param stepsName The public API's parameter name for `steps`.\n * @returns Number of samples provided.\n */\n private checkNumSamples(\n ins: Tensor|Tensor[], batchSize?: number, steps?: number,\n stepsName = 'steps'): number {\n let numSamples: number;\n if (steps != null) {\n numSamples = null;\n if (batchSize != null) {\n throw new ValueError(\n `If ${stepsName} is set, batchSize must be null or undefined.` +\n `Got batchSize = ${batchSize}`);\n }\n } else if (ins != null) {\n if (Array.isArray(ins)) {\n numSamples = ins[0].shape[0];\n } else {\n numSamples = ins.shape[0];\n }\n } else {\n throw new ValueError(\n `Either the input data should have a defined shape, or ` +\n `${stepsName} shoud be specified.`);\n }\n return numSamples;\n }\n\n /**\n * Execute intrenal tensors of the model with input data feed.\n * @param inputs Input data feed. Must match the inputs of the model.\n * @param outputs Names of the output tensors to be fetched. Must match\n * names of the SymbolicTensors that belong to the graph.\n * @returns Fetched values for `outputs`.\n */\n execute(inputs: Tensor|Tensor[]|NamedTensorMap, outputs: string|string[]):\n Tensor|Tensor[] {\n if (Array.isArray(outputs) && outputs.length === 0) {\n throw new ValueError(\n '`outputs` is an empty Array, which is not allowed.');\n }\n\n const outputsIsArray = Array.isArray(outputs);\n const outputNames = (outputsIsArray ? outputs as string[] :\n [outputs as string]) as string[];\n const outputSymbolicTensors = this.retrieveSymbolicTensors(outputNames);\n\n // Format the input into a FeedDict.\n const feedDict = new FeedDict();\n if (inputs instanceof Tensor) {\n inputs = [inputs as Tensor];\n }\n if (Array.isArray(inputs)) {\n if ((inputs as Tensor[]).length !== this.inputs.length) {\n throw new ValueError(\n `The number of inputs provided (${(inputs as Tensor[]).length}) ` +\n `does not match the number of inputs of this model ` +\n `(${this.inputs.length}).`);\n }\n for (let i = 0; i < this.inputs.length; ++i) {\n feedDict.add(this.inputs[i], (inputs as Tensor[])[i]);\n }\n } else {\n for (const input of this.inputs) {\n const tensorValue = (inputs as NamedTensorMap)[input.name];\n if (tensorValue == null) {\n throw new ValueError(\n `No value is provided for the model's input ${input.name}`);\n }\n feedDict.add(input, tensorValue);\n }\n }\n\n // Run execution.\n const executeOutputs = execute(outputSymbolicTensors, feedDict) as Tensor[];\n return outputsIsArray ? executeOutputs : executeOutputs[0];\n }\n\n /**\n * Retrieve the model's internal symbolic tensors from symbolic-tensor names.\n */\n private retrieveSymbolicTensors(symbolicTensorNames: string[]):\n SymbolicTensor[] {\n const outputSymbolicTensors: SymbolicTensor[] =\n pyListRepeat(null, symbolicTensorNames.length);\n let outputsRemaining = symbolicTensorNames.length;\n for (const layer of this.layers) {\n const layerOutputs: SymbolicTensor[] = Array.isArray(layer.output) ?\n layer.output as SymbolicTensor[] :\n [layer.output as SymbolicTensor];\n const layerOutputNames = layerOutputs.map(output => output.name);\n for (let i = 0; i < symbolicTensorNames.length; ++i) {\n const index = layerOutputNames.indexOf(symbolicTensorNames[i]);\n if (index !== -1) {\n outputSymbolicTensors[i] = layerOutputs[index];\n outputsRemaining--;\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n if (outputsRemaining === 0) {\n break;\n }\n }\n\n if (outputsRemaining > 0) {\n const remainingNames: string[] = [];\n outputSymbolicTensors.forEach((tensor, i) => {\n if (tensor == null) {\n remainingNames.push(symbolicTensorNames[i]);\n }\n });\n throw new ValueError(\n `Cannot find SymbolicTensors for output name(s): ` +\n `${JSON.stringify(remainingNames)}`);\n }\n return outputSymbolicTensors;\n }\n\n /**\n * Helper method to loop over some data in batches.\n *\n * Porting Note: Not using the functional approach in the Python equivalent\n * due to the imperative backend.\n * Porting Note: Does not support step mode currently.\n *\n * @param ins: input data\n * @param batchSize: integer batch size.\n * @param verbose: verbosity model\n * @returns: Predictions as `Tensor` (if a single output) or an `Array` of\n * `Tensor` (if multipe outputs).\n */\n private predictLoop(ins: Tensor|Tensor[], batchSize = 32, verbose = false):\n Tensor|Tensor[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins);\n if (verbose) {\n throw new NotImplementedError(\n 'Verbose predictLoop() is not implemented yet.');\n }\n\n // Sample-based predictions.\n // Porting Note: Tensor currently does not support sliced assignments as\n // in numpy, e.g., x[1:3] = y. Therefore we use concatenation while\n // iterating over the batches.\n\n const batches = makeBatches(numSamples, batchSize);\n const outs: Tensor[] = [];\n // TODO(cais): Can the scope() be pushed down inside the for loop?\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchOuts = tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n // TODO(cais): Take care of the case of the last element is a flag for\n // training/test.\n const insBatch = sliceArrays(ins, batchStart, batchEnd);\n\n // Construct the feeds for execute();\n const feeds = [];\n if (Array.isArray(insBatch)) {\n for (let i = 0; i < insBatch.length; ++i) {\n feeds.push({key: this.inputs[i], value: insBatch[i]});\n }\n } else {\n feeds.push({key: this.inputs[0], value: insBatch});\n }\n const feedDict = new FeedDict(feeds);\n return execute(this.outputs, feedDict) as Tensor[];\n });\n if (batchIndex === 0) {\n // Pre-allocate.\n for (const batchOut of batchOuts) {\n outs.push(batchOut);\n }\n } else {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs[i] = K.concatAlongFirstAxis(outs[i], batchOuts[i]);\n }\n }\n }\n return singletonOrArray(outs);\n });\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFlow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([8, 10]), {batchSize: 4}).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param config A `ModelPredictConfig` object containing optional fields.\n *\n * @return Prediction results as a `Tensor`(s).\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, false);\n // TODO(cais): Take care of stateful models.\n // if (this.stateful) ...\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n return this.predictLoop(x, batchSize);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predictOnBatch(tf.ones([8, 10])).print();\n * ```\n * @param x: Input samples, as an Tensor\n * @return Tensor(s) of predictions\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n checkInputData(x, this.inputNames, this.feedInputShapes, true);\n // TODO(cais): Take care of the learning_phase boolean flag.\n // if (this.useLearningPhase) ...\n return this.predictLoop(x, x.shape[0]);\n }\n\n protected standardizeUserData(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor}, checkBatchAxis = true,\n batchSize?: number): [Tensor[], Tensor[], Tensor[]] {\n // TODO(cais): Add sampleWeight, classWeight\n if (this.optimizer == null) {\n throw new RuntimeError(\n 'You must compile a model before training/testing. Use ' +\n 'Model.compile(modelCompileConfig).');\n }\n const outputShapes: Shape[] = [];\n for (let i = 0; i < this.feedOutputShapes.length; ++i) {\n const outputShape = this.feedOutputShapes[i];\n const lossFn = this.feedLossFns[i];\n if (lossFn === losses.sparseCategoricalCrossentropy) {\n outputShapes.push(\n outputShape.slice(0, outputShape.length - 1).concat([1]));\n } else {\n // Porting Note: Because of strong typing `lossFn` must be a function.\n outputShapes.push(outputShape);\n }\n }\n x = standardizeInputData(\n x, this.feedInputNames, this.feedInputShapes, false, 'input') as\n Tensor[];\n y = standardizeInputData(\n y, this.feedOutputNames, outputShapes, false, 'target') as Tensor[];\n // TODO(cais): Standardize sampleWeights & classWeights.\n checkArrayLengths(x, y, null);\n // TODO(cais): Check sampleWeights as well.\n checkLossAndTargetCompatibility(y, this.feedLossFns, this.feedOutputShapes);\n if (this.stateful && batchSize != null && batchSize > 0) {\n if (x[0].shape[0] % batchSize !== 0) {\n throw new ValueError(\n `In a stateful network, you should only pass inputs with a ` +\n `number of samples that is divisible by the batch size ` +\n `${batchSize}. Found: ${x[0].shape[0]} sample(s).`);\n }\n }\n // TODO(cais): Deal with the case of model.stateful == true.\n return [x, y, null];\n }\n\n /**\n * Abstract fit function for `f(ins)`.\n * @param f A Function returning a list of tensors. For training, this\n * function is expected to perform the updates to the variables.\n * @param ins List of tensors to be fed to `f`.\n * @param outLabels List of strings, display names of the outputs of `f`.\n * @param batchSize Integer batch size or `== null` if unknown.\n * @param epochs Number of times to iterate over the data.\n * @param verbose Verbosity mode: 0, 1, or 2.\n * @param callbacks List of callbacks to be called during training.\n * @param valF Function to call for validation.\n * @param valIns List of tensors to be fed to `valF`.\n * @param shuffle Whether to shuffle the data at the beginning of every\n * epoch.\n * @param callbackMetrics List of strings, the display names of the metrics\n * passed to the callbacks. They should be the concatenation of the\n * display names of the outputs of `f` and the list of display names\n * of the outputs of `valF`.\n * @param initialEpoch Epoch at which to start training (useful for\n * resuming a previous training run).\n * @param stepsPerEpoch Total number of steps (batches on samples) before\n * declaring one epoch finished and starting the next epoch. Ignored with\n * the default value of `undefined` or `null`.\n * @param validationSteps Number of steps to run validation for (only if\n * doing validation from data tensors). Not applicable for tfjs-layers.\n * @returns A `History` object.\n */\n private async fitLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], outLabels?: string[],\n batchSize?: number, epochs?: number, verbose?: number,\n callbacks?: BaseCallback[], valF?: (data: Tensor[]) => Scalar[],\n valIns?: Tensor[], shuffle?: boolean|string, callbackMetrics?: string[],\n initialEpoch?: number, stepsPerEpoch?: number,\n validationSteps?: number): Promise {\n if (batchSize == null) {\n batchSize = 32;\n }\n if (epochs == null) {\n epochs = 1;\n }\n if (shuffle == null) {\n shuffle = true;\n }\n if (initialEpoch == null) {\n initialEpoch = 0;\n }\n\n // TODO(cais): Change const to let below when implementing validation.\n let doValidation = false;\n if (valF != null && valIns != null) {\n doValidation = true;\n // TODO(cais): verbose message.\n }\n if (validationSteps != null) {\n doValidation = true;\n if (stepsPerEpoch == null) {\n throw new ValueError(\n 'Can only use `validationSteps` when doing step-wise training, ' +\n 'i.e., `stepsPerEpoch` must be set.');\n }\n }\n\n const numTrainSamples =\n this.checkNumSamples(ins, batchSize, stepsPerEpoch, 'steps_per_epoch');\n let indexArray: number[];\n if (numTrainSamples != null) {\n indexArray = range(0, numTrainSamples);\n }\n\n this.history = new History();\n if (callbacks == null) {\n callbacks = [new BaseLogger()];\n } else {\n callbacks = ([new BaseLogger()] as BaseCallback[]).concat(callbacks);\n }\n callbacks = callbacks.concat([this.history]);\n\n if (verbose > 0) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n const callbackList = new CallbackList(callbacks);\n\n // TODO(cais): Figure out when this Model instance can have a dynamically\n // set property called 'callback_model' as in PyKeras.\n callbackList.setModel(this);\n callbackList.setParams({\n epochs,\n initialEpoch,\n steps: stepsPerEpoch,\n verbose,\n doValidation,\n metrics: callbackMetrics,\n });\n await callbackList.onTrainBegin();\n this.stopTraining = false;\n // TODO(cais): Take care of callbacks.validation_data as in PyKeras.\n\n // TODO(cais): Pre-convert feeds for performance as in PyKeras.\n\n for (let epoch = initialEpoch; epoch < epochs; ++epoch) {\n await callbackList.onEpochBegin(epoch);\n const epochLogs: UnresolvedLogs = {};\n if (stepsPerEpoch != null) {\n throw new NotImplementedError(\n 'stepsPerEpoch mode is not implemented yet.');\n } else {\n if (shuffle === 'batch') {\n throw new NotImplementedError(\n 'batch shuffling is not implemneted yet');\n } else if (shuffle) {\n util.shuffle(indexArray);\n }\n // Convert the potentially shuffled indices to Tensor1D, to avoid the\n // cost of repeated creation of Array1Ds later on.\n const epochIndexArray1D = tensor1d(indexArray);\n\n const batches = makeBatches(numTrainSamples, batchSize);\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchLogs: UnresolvedLogs = {};\n await callbackList.onBatchBegin(batchIndex, batchLogs);\n\n tfc.tidy(() => {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds = K.sliceAlongFirstAxis(\n epochIndexArray1D, batchStart,\n batchEnd - batchStart) as Tensor1D;\n batchLogs['batch'] = batchIndex;\n batchLogs['size'] = batchEnd - batchStart;\n\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Tensor[];\n const outs = f(insBatch);\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = outs[i];\n batchLogs[label] = out;\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n }\n\n if (batchIndex === batches.length - 1) { // Last batch.\n if (doValidation) {\n const valOuts = this.testLoop(valF, valIns, batchSize);\n // Porting Notes: In tfjs-layers, valOuts is always an Array.\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n const out = valOuts[i];\n tfc.keep(out);\n // TODO(cais): Use scope() to avoid ownership.\n epochLogs['val_' + label] = out;\n }\n }\n }\n });\n\n await callbackList.onBatchEnd(batchIndex, batchLogs);\n disposeTensorsInLogs(batchLogs);\n\n if (this.stopTraining) {\n break;\n }\n // TODO(cais): return outs as list of Tensor.\n }\n\n epochIndexArray1D.dispose();\n }\n // TODO(cais): Run validation at the end of the epoch.\n await callbackList.onEpochEnd(epoch, epochLogs);\n if (this.stopTraining) {\n break;\n }\n }\n await callbackList.onTrainEnd();\n\n await this.history.syncData();\n return this.history;\n }\n\n /**\n * Loop over some test data in batches.\n * @param f A Function returning a list of tensors.\n * @param ins Array of tensors to be fed to `f`.\n * @param batchSize Integer batch size or `null` / `undefined`.\n * @param verbose verbosity mode.\n * @param steps Total number of steps (batches of samples) before declaring\n * test finished. Ignored with the default value of `null` / `undefined`.\n * @returns Array of Scalars.\n */\n private testLoop(\n f: (data: Tensor[]) => Scalar[], ins: Tensor[], batchSize?: number,\n verbose = 0, steps?: number): Scalar[] {\n return tfc.tidy(() => {\n const numSamples = this.checkNumSamples(ins, batchSize, steps, 'steps');\n const outs: Scalar[] = [];\n if (verbose === 1) {\n throw new NotImplementedError('Verbose mode is not implemented yet.');\n }\n // TODO(cais): Use `indicesForConversionToDense' to prevent slow down.\n if (steps != null) {\n throw new NotImplementedError(\n 'steps mode in testLoop() is not implemented yet');\n } else {\n const batches = makeBatches(numSamples, batchSize);\n const indexArray = tensor1d(range(0, numSamples));\n for (let batchIndex = 0; batchIndex < batches.length; ++batchIndex) {\n const batchStart = batches[batchIndex][0];\n const batchEnd = batches[batchIndex][1];\n const batchIds =\n K.sliceAlongFirstAxis(\n indexArray, batchStart, batchEnd - batchStart) as Tensor1D;\n // TODO(cais): In ins, train flag can be a number, instead of an\n // Tensor? Do we need to handle this in tfjs-layers?\n const insBatch = sliceArraysByIndices(ins, batchIds) as Scalar[];\n const batchOuts = f(insBatch);\n if (batchIndex === 0) {\n for (let i = 0; i < batchOuts.length; ++i) {\n outs.push(getScalar(0));\n }\n }\n for (let i = 0; i < batchOuts.length; ++i) {\n const batchOut = batchOuts[i];\n outs[i] =\n tfc.add(\n outs[i],\n tfc.mul(getScalar(batchEnd - batchStart), batchOut)) as\n Scalar;\n }\n }\n for (let i = 0; i < outs.length; ++i) {\n outs[i] = tfc.div(outs[i], getScalar(numSamples)) as Scalar;\n }\n }\n return outs;\n });\n }\n\n private getDedupedMetricsNames(): string[] {\n const outLabels = this.metricsNames;\n // Rename duplicated metrics names (can happen with an output layer shared\n // among multiple dataflows).\n const dedupedOutLabels = [];\n for (let i = 0; i < outLabels.length; ++i) {\n const label = outLabels[i];\n let newLabel = label;\n if (count(outLabels, label) > 1) {\n const dupIndex = count(outLabels.slice(0, i), label);\n newLabel += `_${dupIndex}`;\n }\n dedupedOutLabels.push(newLabel);\n }\n return dedupedOutLabels;\n }\n\n private makeTestFunction() {\n this.testFunction = (data: Tensor[]) => {\n return tfc.tidy(() => {\n const valOutputs: Scalar[] = [];\n let totalLoss: Scalar;\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs = execute(this.outputs, feedDict) as Tensor[];\n // Compute total loss.\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n // TODO(cais): Add sample weighting and replace the simple\n // averaging.\n const loss = tfc.mean(lossFunction(targets[i], outputs[i])) as Scalar;\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss) as Scalar;\n }\n valOutputs.push(totalLoss);\n }\n // Compute the metrics.\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0]; // TODO(cais): Restore.\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex]));\n valOutputs.push(meanMetric as Scalar);\n }\n return valOutputs;\n });\n };\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * for (let i = 1; i < 5 ; ++i) {\n * const h = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(\"Loss after Epoch \" + i + \" : \" + h.history.loss[0]);\n * }\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n const batchSize = config.batchSize == null ? 32 : config.batchSize;\n\n // Validate user data.\n // TODO(cais): Add sampleWeight and classWeight.\n const standardizedOuts = this.standardizeUserData(x, y, false, batchSize);\n let inputs = standardizedOuts[0];\n let targets = standardizedOuts[1];\n // TODO(cais): Make use of sampleWeights in standardizedOuts[2] when\n // available.\n\n // Prepare validation data.\n let doValidation = false;\n let valX: Tensor|Tensor[];\n let valY: Tensor|Tensor[];\n let valIns: Tensor[];\n // A flag to keep track of whether `valIns`, `inputs` and `targets` need\n // to be memory-disposed prior to returning from this method. This is the\n // case if `config.validationSplit` is set to a number between 0 and 1, in\n // which case the input `x` and `y` tensors will be sliced, leading to\n // allocation of new tensor memory.\n let needValidationDisposal = false;\n if (config.validationData != null && config.validationData.length > 0) {\n doValidation = true;\n if (config.validationData.length === 2) {\n // config.validationData consists of valX and valY.\n valX = config.validationData[0];\n valY = config.validationData[1];\n } else if (config.validationData.length === 3) {\n throw new NotImplementedError(\n 'validationData including sample weights is not supported yet.');\n } else {\n throw new ValueError(\n `When passing validation data, it must contain 2 (valX, valY) ` +\n `or 3 (valX, valY, valSampleWeight) items; ` +\n `${config.validationData} is invalid.`);\n }\n\n const valStandardized =\n this.standardizeUserData(valX, valY, true, batchSize);\n valX = valStandardized[0] as Tensor[];\n valY = valStandardized[1] as Tensor[];\n // TODO(cais): Use validation sample weights in valStandardized[2] once\n // it becomes available.\n valIns = valX.concat(valY);\n // TODO(cais): Add useLearningPhase data properly.\n } else if (\n config.validationSplit != null && config.validationSplit > 0 &&\n config.validationSplit < 1) {\n doValidation = true;\n // Porting Note: In tfjs-layers, inputs[0] is always an Tensor.\n const splitAt =\n Math.floor(inputs[0].shape[0] * (1 - config.validationSplit));\n const originalBatchSize = inputs[0].shape[0];\n valX = sliceArrays(inputs, splitAt, originalBatchSize) as Tensor[];\n inputs = sliceArrays(inputs, 0, splitAt) as Tensor[];\n valY = sliceArrays(targets, splitAt, originalBatchSize) as Tensor[];\n targets = sliceArrays(targets, 0, splitAt) as Tensor[];\n needValidationDisposal = true;\n // TODO(cais): Once sampleWeights becomes available, slice it to get\n // valSampleWeights.\n valIns = valX.concat(valY);\n\n // TODO(cais): Add useLearningPhase data properly.\n } else if (config.validationSteps != null) {\n doValidation = true;\n // TODO(cais): Add useLearningPhase.\n }\n\n const ins = inputs.concat(targets);\n\n this.checkTrainableWeightsConsistency();\n\n // TODO(cais): Handle use_learning_phase and learning_phase?\n\n // Porting Note: Here we see a key deviation of tfjs-layers from Keras.\n // Due to the imperative nature of tfjs-layers' backend (tfjs-core),\n // we do not construct symbolic computation graphs to embody the training\n // process. Instead, we define a function that performs the training\n // action.\n // In PyKeras, the data (inputs and targets) are fed through graph\n // placeholders. In tfjs-layers, the data are fed as function arguments.\n // Since the function are defined below in the scope, we don't have\n // equivalents of PyKeras's `_make_train_funciton`.\n\n // Creat a function that performs the following actions:\n // 1) computes the losses,\n // 2) add them to get the total loss,\n // 3) call the optimizer computes the gradients of the Model's trainable\n // weights w.r.t. the total loss and update the variables.\n // 4) calculate the metrics\n // 5) return the values of the losses and metrics.\n const trainFunction = (data: Tensor[]) => {\n const losses: Tensor[] = [];\n const lossValues: Scalar[] = [];\n\n const inputs = data.slice(0, this.inputs.length);\n const targets = data.slice(\n this.inputs.length, this.inputs.length + this.outputs.length);\n\n const metricsValues: Scalar[] = [];\n\n // Create a function that computes the total loss based on the inputs.\n // This function is used for obtaining gradients through backprop.\n const totalLossFunction = () => {\n const feeds = [];\n for (let i = 0; i < this.inputs.length; ++i) {\n feeds.push({key: this.inputs[i], value: inputs[i]});\n }\n const feedDict = new FeedDict(feeds);\n const outputs =\n execute(this.outputs, feedDict, {'training': true}) as Tensor[];\n // TODO(cais): Take care of the case of multiple outputs from a\n // single layer?\n\n let totalLoss: Tensor;\n for (let i = 0; i < this.lossFunctions.length; ++i) {\n const lossFunction = this.lossFunctions[i];\n const loss = lossFunction(targets[i], outputs[i]);\n losses.push(loss);\n // TODO(cais): push Scalar instead.\n const meanLoss = tfc.mean(loss) as Scalar;\n // TODO(cais): Use a scope() instead, to avoid ownership.\n lossValues.push(meanLoss);\n if (i === 0) {\n totalLoss = loss;\n } else {\n totalLoss = tfc.add(totalLoss, loss);\n }\n }\n\n // Compute the metrics.\n // TODO(cais): These should probably be calculated outside\n // totalLossFunction to benefit speed?\n for (let i = 0; i < this.metricsTensors.length; ++i) {\n const metric = this.metricsTensors[i][0];\n const outputIndex = this.metricsTensors[i][1];\n // TODO(cais): Replace K.mean() with a proper weighting function.\n const meanMetric =\n tfc.mean(metric(targets[outputIndex], outputs[outputIndex])) as\n Scalar;\n tfc.keep(meanMetric);\n // TODO(cais): Use a scope() instead, to avoid ownership.\n metricsValues.push(meanMetric);\n }\n\n totalLoss = tfc.mean(totalLoss);\n\n // Add regularizer penalties.\n this.calculateLosses().forEach(regularizerLoss => {\n totalLoss = tfc.add(totalLoss, regularizerLoss);\n });\n\n return totalLoss as Scalar;\n };\n\n const variables = this.collectedTrainableWeights.map(\n param => param.read() as tfc.Variable);\n const returnCost = true;\n const totalLossValue =\n this.optimizer.minimize(totalLossFunction, returnCost, variables);\n\n return [totalLossValue].concat(metricsValues);\n };\n\n const outLabels = this.getDedupedMetricsNames();\n\n let valFunction: (data: Tensor[]) => Scalar[];\n let callbackMetrics: string[];\n if (doValidation) {\n this.makeTestFunction();\n valFunction = this.testFunction;\n callbackMetrics =\n outLabels.slice().concat(outLabels.map(n => 'val_' + n));\n } else {\n valFunction = null;\n valIns = [];\n callbackMetrics = outLabels.slice();\n }\n\n const callbacks = standardizeCallbacks(config.callbacks);\n const out = await this.fitLoop(\n trainFunction, ins, outLabels, batchSize, config.epochs, config.verbose,\n callbacks, valFunction, valIns, config.shuffle, callbackMetrics,\n config.initialEpoch, null, null);\n if (needValidationDisposal) {\n valIns.forEach(tensor => tensor.dispose());\n inputs.forEach(tensor => tensor.dispose());\n targets.forEach(tensor => tensor.dispose());\n }\n return out;\n // TODO(cais): Add value to outLabels.\n }\n\n /**\n * Extract weight values of the model.\n *\n * @param config: An instance of `io.SaveConfig`, which specifies\n * model-saving options such as whether only trainable weights are to be\n * saved.\n * @returns A `NamedTensorMap` mapping original weight names (i.e.,\n * non-uniqueified weight names) to their values.\n */\n protected getNamedWeights(config?: io.SaveConfig): NamedTensorMap {\n const namedWeights: NamedTensorMap = {};\n\n const trainableOnly = config != null && config.trainableOnly;\n const weights = trainableOnly ? this.trainableWeights : this.weights;\n const weightValues = this.getWeights(trainableOnly);\n for (let i = 0; i < weights.length; ++i) {\n if (trainableOnly && !weights[i].trainable) {\n // Optionally skip non-trainable weights.\n continue;\n }\n namedWeights[weights[i].originalName] = weightValues[i];\n }\n return namedWeights;\n }\n\n // tslint:disable:max-line-length\n /**\n * Save the configuration and/or weights of the Model.\n *\n * An `IOHandler` is an object that has a `save` method of the proper\n * signature defined. The `save` method manages the storing or transmission\n * of serialized data (\"artifacts\") that represent the model's topology and\n * weights onto or via a specific medium, such as file downloads, local\n * storage, IndexedDB in the web browser and HTTP requests to a server.\n * TensorFlow.js provides `IOHandler` implementations for a number of\n * frequently used saving mediums, such as `tf.io.browserDownloads` and\n * `tf.io.browserLocalStorage`. See `tf.io` for more details.\n *\n * This method also allows you to refer to certain types of `IOHandler`s as\n * URL-like string shortcuts, such as 'localstorage://' and 'indexeddb://'.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Saving `model`'s topology and weights as two files\n * (`my-model-1.json` and `my-model-1.weights.bin`) downloaded from browser.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('downloads://my-model-1');\n * ```\n *\n * Example 4. Send `model`'s topology and weights to an HTTP server.\n * See the documentation of `tf.io.browserHTTPRequests` for more details\n * including specifying request parameters and implementation of the server.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * const saveResults = await model.save('http://my-server/model/upload');\n * ```\n *\n * @param handlerOrURL An instance of `IOHandler` or a URL-like,\n * scheme-based string shortcut for `IOHandler`.\n * @param config Options for saving the model.\n * @returns A `Promise` of `SaveResult`, which summarizes the result of the\n * saving, such as byte sizes of the saved artifacts for the model's\n * topology and weight values.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n // tslint:enable:max-line-length\n async save(handlerOrURL: io.IOHandler|string, config?: io.SaveConfig):\n Promise {\n if (typeof handlerOrURL === 'string') {\n const handlers = io.getSaveHandlers(handlerOrURL);\n if (handlers.length === 0) {\n throw new ValueError(\n `Cannot find any save handlers for URL '${handlerOrURL}'`);\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) save handlers for ` +\n `URL '${handlerOrURL}'`);\n }\n handlerOrURL = handlers[0];\n }\n if (handlerOrURL.save == null) {\n throw new ValueError(\n 'Model.save() cannot proceed because the IOHandler provided does ' +\n 'not have the `save` attribute defined.');\n }\n\n const weightDataAndSpecs =\n await io.encodeWeights(this.getNamedWeights(config));\n\n const returnString = false;\n const unusedArg: {} = null;\n const modelConfig = this.toJSON(unusedArg, returnString);\n\n return handlerOrURL.save({\n modelTopology: modelConfig,\n weightData: weightDataAndSpecs.data,\n weightSpecs: weightDataAndSpecs.specs\n });\n }\n}\n\nserialization.SerializationMap.register(Model);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Optimizers.\n */\n\n// tslint:disable:max-line-length\nimport {Optimizer, train} from '@tensorflow/tfjs-core';\n\nimport {epsilon} from './backend/common';\n// tslint:enable:max-line-length\n\nimport {ValueError} from './errors';\n\n// Add (de)serialize()\n\n// Porting note: This diverges from the PyKeras implementation and may need to\n// change based on (de)serialization requirements.\nexport function getOptimizer(identifier: string): Optimizer {\n const optimizerMap: {[optimizerName: string]: () => Optimizer} = {\n 'Adagrad': () => train.adagrad(0.01),\n 'Adadelta': () => train.adadelta(1, 0.95, epsilon()),\n 'Adam': () => train.adam(0.001, 0.9, 0.999, epsilon()),\n 'Adamax': () => train.adamax(0.002, 0.9, 0.999, epsilon(), 0),\n 'RMSProp': () => train.rmsprop(0.001, 0.9, 0, epsilon()),\n 'SGD': () => train.sgd(0.01)\n };\n optimizerMap['adagrad'] = optimizerMap['Adagrad'];\n optimizerMap['adadelta'] = optimizerMap['Adadelta'];\n optimizerMap['adam'] = optimizerMap['Adam'];\n optimizerMap['adamax'] = optimizerMap['Adamax'];\n optimizerMap['rmsprop'] = optimizerMap['RMSProp'];\n optimizerMap['sgd'] = optimizerMap['SGD'];\n\n if (identifier in optimizerMap) {\n return optimizerMap[identifier]();\n }\n throw new ValueError(`Unknown Optimizer ${identifier}`);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source keras/models.py */\n\n// tslint:disable:max-line-length\nimport {io, Scalar, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {getUid} from './backend/state';\nimport {History} from './base_callbacks';\nimport {Input} from './engine/input_layer';\nimport {getSourceInputs, Layer, Node, SymbolicTensor} from './engine/topology';\nimport {Model, ModelCompileConfig, ModelEvaluateConfig, ModelFitConfig} from './engine/training';\nimport {RuntimeError, ValueError} from './errors';\nimport {deserialize} from './layers/serialization';\nimport {Kwargs, NamedTensorMap, Shape} from './types';\nimport {JsonDict} from './types';\nimport * as generic_utils from './utils/generic_utils';\nimport {convertPythonicToTs} from './utils/serialization_utils';\nimport {getExactlyOneShape} from './utils/types_utils';\n// tslint:enable:max-line-length\n\n/**\n * Parses a JSON model configuration file and returns a model instance.\n * @param modelAndWeightsConfig JSON object or string encoding a model and\n * weights configuration.\n * @param custom_objects Optional dictionary mapping names\n * (strings) to custom classes or functions to be\n * considered during deserialization.\n * @returns A TensorFlow.js Layers `Model` instance (uncompiled).\n */\nexport async function modelFromJSON(\n modelAndWeightsConfig: ModelAndWeightsConfig,\n customObjects?: serialization.ConfigDict): Promise {\n let modelTopology = modelAndWeightsConfig.modelTopology;\n if (modelTopology['model_config'] != null) {\n // If the model-topology JSON contains a 'model_config' field, then it is\n // a full model JSON (e.g., from `keras.Model.save()`), which contains\n // not only the model's architecture in its 'model_config' field, but\n // additional information such as the model's optimizer. We use only the\n // 'model_config' field currently.\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const tsConfig =\n convertPythonicToTs(modelTopology) as serialization.ConfigDict;\n const model = deserialize(tsConfig, customObjects) as Model;\n\n if (modelAndWeightsConfig.weightsManifest != null) {\n // Load the weight values keyed by the original tensor names in the model\n // file that was loaded. These should match the keys of the weight\n // manifest.\n const weightValues =\n await io.loadWeights(\n modelAndWeightsConfig.weightsManifest,\n modelAndWeightsConfig.pathPrefix,\n model.weights.map(weight => weight.originalName)) as NamedTensorMap;\n\n // Map the weights to the unique tensor names generated during model loading\n const uniqueWeightValues: NamedTensorMap = {};\n for (const weight of model.weights) {\n uniqueWeightValues[weight.originalName] =\n weightValues[weight.originalName];\n }\n\n const skipMismatches: boolean = null;\n const isNamedTensorMap = true;\n model.loadWeights(uniqueWeightValues, skipMismatches, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Options for loading a saved mode in TensorFlow.js format.\n */\nexport interface ModelAndWeightsConfig {\n /**\n * A JSON object or JSON string containing the model config.\n *\n * This can be either of the following two formats:\n * - A model archiecture-only config, i.e., a format consistent with the\n * return value of`keras.Model.to_json()`.\n * - A full model config, containing not only model architecture, but also\n * training options and state, i.e., a format consistent with the return\n * value of `keras.models.save_model()`.\n */\n modelTopology: JsonDict;\n\n /**\n * A weights manifest in TensorFlow.js format.\n */\n weightsManifest?: io.WeightsManifestConfig;\n\n /**\n * Path to prepend to the paths in `weightManifest` before fetching.\n *\n * The path may optionally end in a slash ('/').\n */\n pathPrefix?: string;\n}\n\n// TODO(nielsene): Remove after: https://github.com/tensorflow/tfjs/issues/400\nexport interface ModelPredictConfig {\n /**\n * Optional. Batch size (Integer). If unspecified, it will default to 32.\n */\n batchSize?: number;\n\n /**\n * Optional. Verbosity mode. Defaults to false.\n */\n verbose?: boolean;\n}\n\n// tslint:disable:max-line-length\n/**\n * Load a model, including its topology and optionally weights. See the\n * Tutorial named \"How to import a Keras Model\" for usage examples.\n *\n * Example 1: Save `model`'s topology and weights to browser [local\n * storage](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('localstorage://my-model-1');\n *\n * const loadedModel = await tf.loadModel('localstorage://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 2. Saving `model`'s topology and weights to browser\n * [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API);\n * then load it back.\n *\n * ```js\n * const model = tf.sequential(\n * {layers: [tf.layers.dense({units: 1, inputShape: [3]})]});\n * console.log('Prediction from original model:');\n * model.predict(tf.ones([1, 3])).print();\n *\n * const saveResults = await model.save('indexeddb://my-model-1');\n *\n * const loadedModel = await tf.loadModel('indexeddb://my-model-1');\n * console.log('Prediction from loaded model:');\n * loadedModel.predict(tf.ones([1, 3])).print();\n * ```\n *\n * Example 3. Load a model from user-selected files from HTML\n * [file input\n * elements](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file).\n *\n * ```js\n * // Note: this code snippet will not work without the HTML elements in the\n * // page\n * const jsonUpload = document.getElementById('json-upload');\n * const weightsUpload = document.getElementById('weights-upload');\n *\n * const model = await tf.loadModel(\n * tf.io.browserFiles([jsonUpload.files[0], weightsUpload.files[0]]));\n * ```\n *\n * Example 4. Load a model from an HTTP server.\n *\n * ```js\n * const model = await\n * tf.loadModel('https://storage.googleapis.com/tfjs-models/tfjs/iris_v1/model.json')\n * ```\n *\n * @param pathOrIOHandler Can be either of the two formats\n * 1. A string path to the `ModelAndWeightsConfig` JSON describing\n * the model in the canonical TensorFlow.js format. This path will be\n * interpreted as a relative HTTP path, to which `fetch` will be used to\n * request the model topology and weight manifest JSON.\n * The content of the JSON file is assumed to be a JSON object with the\n * following fields and values:\n * - 'modelTopology': A JSON object that can be either of:\n * 1. a model architecture JSON consistent with the format of the return\n * value of `keras.Model.to_json()`\n * 2. a full model JSON in the format of `keras.models.save_model()`.\n * - 'weightsManifest': A TensorFlow.js weights manifest.\n * See the Python converter function `save_model()` for more details.\n * It is also assumed that model weights can be accessed from relative\n * paths described by the `paths` fields in weights manifest.\n * 2. An `tf.io.IOHandler` object that loads model artifacts with its `load`\n * method.\n *\n * @returns A `Promise` of `Model`, with the topology and weights loaded.\n */\n// tslint:enable:max-line-length\nexport async function loadModelInternal(pathOrIOHandler: string|\n io.IOHandler): Promise {\n if (typeof pathOrIOHandler === 'string') {\n const handlers = io.getLoadHandlers(pathOrIOHandler);\n if (handlers.length === 0) {\n // For backward compatibility: if no load handler can be found,\n // assume it is a relative http path.\n handlers.push(io.browserHTTPRequest(pathOrIOHandler));\n } else if (handlers.length > 1) {\n throw new ValueError(\n `Found more than one (${handlers.length}) load handlers for ` +\n `URL '${pathOrIOHandler}'`);\n }\n pathOrIOHandler = handlers[0];\n }\n return loadModelFromIOHandler(pathOrIOHandler as io.IOHandler);\n}\n\n/**\n * Load a model and optionally its weights, using an IOHandler object.\n */\nexport async function loadModelFromIOHandler(\n handler: io.IOHandler,\n customObjects?: serialization.ConfigDict): Promise {\n if (handler.load == null) {\n throw new ValueError(\n 'Cannot proceed with model loading because the IOHandler provided ' +\n 'does not have the `load` method implemented.');\n }\n const artifacts = await handler.load();\n let modelTopology = artifacts.modelTopology as JsonDict;\n if (modelTopology['model_config'] != null) {\n modelTopology = modelTopology['model_config'] as JsonDict;\n }\n const model =\n deserialize(\n convertPythonicToTs(modelTopology) as serialization.ConfigDict,\n customObjects) as Model;\n\n // If weightData is present, load the weights into the model.\n if (artifacts.weightData != null) {\n // Loading weights requires weightSpecs.\n if (artifacts.weightSpecs == null) {\n throw new ValueError(\n 'Model artifacts contains weight data, but not weight specs. ' +\n 'Therefore loading of weights cannot proceed.');\n }\n\n const skipMismatch = false;\n const isNamedTensorMap = true;\n model.loadWeights(\n io.decodeWeights(artifacts.weightData, artifacts.weightSpecs),\n skipMismatch, isNamedTensorMap);\n }\n return model;\n}\n\n/**\n * Configuration for a Sequential model.\n */\nexport interface SequentialConfig {\n /** Stack of layers for the model. */\n layers?: Layer[];\n\n /** The name of this model. */\n name?: string;\n}\n\n/**\n * A model with a stack of layers, feeding linearly from one to the next.\n *\n * `sequential` is a factory function that creates an instance of\n * `Sequential`.\n *\n * ```js\n * // Define a model for linear regression.\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 1, inputShape: [1]}));\n *\n * // Prepare the model for training: Specify the loss and the optimizer.\n * model.compile({loss: 'meanSquaredError', optimizer: 'sgd'});\n *\n * // Generate some synthetic data for training.\n * const xs = tf.tensor2d([1, 2, 3, 4], [4, 1]);\n * const ys = tf.tensor2d([1, 3, 5, 7], [4, 1]);\n *\n * // Train the model using the data then do inference on a data point the\n * // model hasn't seen:\n * await model.fit(xs, ys);\n * model.predict(tf.tensor2d([5], [1, 1])).print();\n * ```\n */\n/** @doc {heading: 'Models', subheading: 'Classes'} */\nexport class Sequential extends Model {\n static className = 'Sequential';\n private model: Model;\n private _updatable: boolean;\n constructor(config?: SequentialConfig) {\n super({inputs: [], outputs: []});\n config = config || {};\n\n this.trainable = true;\n this._updatable = true;\n this.built = false;\n\n // Set model name.\n this.name = (config.name != null) ? config.name : getUid('sequential_');\n\n // Add to the model any layers passed to the constructor.\n if (config.layers != null) {\n for (const layer of config.layers) {\n this.add(layer);\n }\n }\n }\n\n /**\n * Adds a layer instance on top of the layer stack.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense({units: 8, inputShape: [1]}));\n * model.add(tf.layers.dense({units: 4, activation: 'relu6'}));\n * model.add(tf.layers.dense({units: 1, activation: 'relu6'}));\n * // Note that the untrained model is random at this point.\n * model.predict(tf.randomNormal([10, 1])).print();\n * ```\n * @param layer Layer instance.\n *\n * @exception ValueError In case the `layer` argument does not know its input\n * shape.\n * @exception ValueError In case the `layer` argument has multiple output\n * tensors, or is already connected somewhere else (forbidden in\n * `Sequential` models).\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n add(layer: Layer): void {\n const isLayerModelInstance =\n layer instanceof Sequential || layer instanceof Model;\n let modelLayer: Model;\n if (isLayerModelInstance) {\n modelLayer = layer as Model;\n if (modelLayer.outputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n if (modelLayer.inputs.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single input tensor. ' +\n 'For multi-input layers, ' +\n 'use the functional API.');\n }\n }\n\n if (this.outputs.length === 0) {\n // first layer in model: check that it is an input layer\n if (layer.inboundNodes.length === 0) {\n // create an input layer\n if (layer.batchInputShape == null) {\n throw new ValueError(\n 'The first layer in a Sequential model must ' +\n 'get an `inputShape` or `batchInputShape` argument.');\n }\n // Instantiate the input layer.\n const x = Input({\n batchShape: layer.batchInputShape,\n dtype: layer.dtype,\n name: layer.name + '_input'\n });\n // This will build the current layer and create the node connecting\n // the current layer to the input layer we just created.\n layer.apply(x);\n }\n\n if (isLayerModelInstance) {\n this.outputs = modelLayer.outputs;\n this.inputs = modelLayer.inputs;\n } else {\n if (layer.inboundNodes.length !== 1) {\n throw new ValueError(\n 'A layer added to a Sequential model must not already be ' +\n `connected somewhere else. Model received layer ${layer.name} ` +\n `which has ${layer.inboundNodes.length} pre-existing inbound ` +\n 'connections.');\n }\n\n if (layer.inboundNodes[0].outputTensors.length !== 1) {\n throw new ValueError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [layer.inboundNodes[0].outputTensors[0]];\n this.inputs = getSourceInputs(this.outputs[0]);\n }\n\n this.inboundNodes = [];\n // We create an input node, which we will keep updated\n // as we add more layers.\n // (This call has side effects.)\n // tslint:disable-next-line:no-unused-expression\n new Node({\n outboundLayer: this,\n inboundLayers: [],\n nodeIndices: [],\n tensorIndices: [],\n inputTensors: this.inputs,\n outputTensors: this.outputs,\n // no model-level masking for now\n inputMasks: generic_utils.pyListRepeat(null, this.inputs.length),\n outputMasks: [null],\n inputShapes: this.inputs.map(x => x.shape),\n outputShapes: this.outputs[0].shape\n });\n } else {\n const outputTensor = layer.apply(this.outputs[0]);\n if (Array.isArray(outputTensor)) {\n throw new TypeError(\n 'All layers in a Sequential model ' +\n 'should have a single output tensor. ' +\n 'For multi-output layers, ' +\n 'use the functional API.');\n }\n this.outputs = [outputTensor as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n\n this.layers.push(layer);\n this.built = false;\n }\n\n /**\n * Removes the last layer in the model.\n *\n * @exception TypeError if there are no layers in the model.\n */\n pop(): void {\n if (this.layers.length === 0) {\n throw new TypeError('There are no layers in the model.');\n }\n\n this.layers.pop();\n if (this.layers.length === 0) {\n this.outputs = [];\n this.inboundNodes = [];\n this.outboundNodes = [];\n } else {\n const lastLayerIndex = this.layers.length - 1;\n this.layers[lastLayerIndex].outboundNodes = [];\n this.outputs = [this.layers[lastLayerIndex].output as SymbolicTensor];\n // update self.inbound_nodes\n this.inboundNodes[0].outputTensors = this.outputs;\n this.inboundNodes[0].outputShapes = [this.outputs[0].shape];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.call(inputs, kwargs);\n }\n\n build(inputShape?: Shape|Shape[]) {\n // Call `getExactlyOneShape` without using its return value,\n // to verify that exactly one input shape is provided.\n getExactlyOneShape(inputShape);\n\n if (this.inputs.length === 0 || this.outputs.length === 0) {\n throw new TypeError(\n 'Sequential model cannot be built: model is empty.' +\n ' Add some layers first.');\n }\n // actually create the model\n this.model = new Model({\n inputs: this.inputs,\n outputs: this.outputs[0],\n name: this.name + '_model'\n });\n this.model.trainable = this.trainable;\n this.model.updatable = this.updatable;\n\n // mirror model attributes\n this.supportsMasking = this.model.supportsMasking;\n // TODO(michaelterry): Add caches\n this.inputLayers = this.model.inputLayers;\n this.inputLayersNodeIndices = this.model.inputLayersNodeIndices;\n this.inputLayersTensorIndices = this.model.inputLayersTensorIndices;\n this.outputLayers = this.model.outputLayers;\n this.outputLayersNodeIndices = this.model.outputLayersNodeIndices;\n this.outputLayersTensorIndices = this.model.outputLayersTensorIndices;\n this.nodesByDepth = this.model.nodesByDepth;\n this.containerNodes = this.model.containerNodes;\n this.outputNames = this.model.outputNames;\n this.inputNames = this.model.inputNames;\n // TODO(michaelterry): Add feedInputNames, feedInputs, if needed.\n // TODO(michaelterry): Add callbackModel if needed.\n this.built = true;\n }\n\n countParams(): number {\n if (!this.built) {\n this.build();\n }\n return super.countParams();\n }\n\n /**\n * Print a text summary of the Sequential model's layers.\n *\n * The summary includes\n * - Name and type of all layers that comprise the model.\n * - Output shape(s) of the layers\n * - Number of weight parameters of each layer\n * - The total number of trainable and non-trainable parameters of the model.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 100, inputShape: [10], activation: 'relu'}));\n * model.add(tf.layers.dense({units: 1, activation: 'sigmoid'}));\n *\n * model.summary();\n * ```\n *\n * @param lineLength Custom line length, in number of characters.\n * @param positions Custom widths of each of the columns, as either\n * fractions of `lineLength` (e.g., `[0.5, 0.75, 1]`) or absolute number\n * of characters (e.g., `[30, 50, 65]`). Each number corresponds to\n * right-most (i.e., ending) position of a column.\n * @param printFn Custom print function. Can be used to replace the default\n * `console.log`. For example, you can use `x => {}` to mute the printed\n * messages in the console.\n */\n /** @doc {heading: 'Models', subheading: 'Classes'} */\n summary(\n lineLength?: number, positions?: number[],\n printFn:\n // tslint:disable-next-line:no-any\n (message?: any, ...optionalParams: any[]) => void = console.log) {\n if (!this.built) {\n this.build();\n }\n super.summary(lineLength, positions, printFn);\n }\n\n /**\n * Sets the weights of the model.\n *\n * @param weights Should be a list of Tensors with shapes and types matching\n * the output of `model.getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n if (this.model == null) {\n this.build();\n }\n this.model.setWeights(weights);\n }\n\n get updatable(): boolean {\n return this._updatable;\n }\n\n set updatable(value: boolean) {\n if (this.built) {\n this.model.updatable = value;\n }\n this._updatable = value;\n }\n\n /**\n * Returns the loss value & metrics values for the model in test mode.\n *\n * Loss and metrics are specified during `compile()`, which needs to happen\n * before calls to `evaluate()`.\n *\n * Computation is done in batches.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const result = model.evaluate(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * });\n * result.print();\n * ```\n *\n * @param x `Tensor` of test data, or an `Array` of `Tensor`s if the model\n * has multiple inputs.\n * @param y `Tensor` of target data, or an `Array` of `Tensor`s if the model\n * has multiple outputs.\n * @param config A `ModelEvaluateConfig`, containing optional fields.\n *\n * @return `Scalar` test loss (if the model has a single output and no\n * metrics) or `Array` of `Scalar`s (if the model has multiple outputs\n * and/or metrics). The attribute `model.metricsNames`\n * will give you the display labels for the scalar outputs.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n evaluate(\n x: Tensor|Tensor[], y: Tensor|Tensor[],\n config: ModelEvaluateConfig = {}): Scalar|Scalar[] {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before being used.');\n }\n return this.model.evaluate(x, y, config);\n }\n\n /**\n * Generates output predictions for the input samples.\n *\n * Computation is done in batches.\n *\n * Note: the \"step\" mode of predict() is currently not supported.\n * This is because the TensorFow.js core backend is imperative only.\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.predict(tf.ones([2, 10])).print();\n * ```\n *\n * @param x The input data, as an Tensor, or an `Array` of `Tensor`s if\n * the model has multiple inputs.\n * @param conifg A `ModelPredictConfig` object containing optional fields.\n *\n * @return `Tensor`(s) of predictions.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and the model's expectations, or in case a stateful model receives a\n * number of samples that is not a multiple of the batch size.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [1]}\n */\n predict(x: Tensor|Tensor[], config: ModelPredictConfig = {}): Tensor\n |Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predict(x, config);\n }\n\n /**\n * Returns predictions for a single batch of samples.\n *\n * @param x: Input samples, as an Tensor, or list of Tensors (if the model\n * has multiple inputs).\n * @return Tensor(s) of predictions\n */\n predictOnBatch(x: Tensor): Tensor|Tensor[] {\n if (this.model == null) {\n this.build();\n }\n return this.model.predictOnBatch(x);\n }\n\n /**\n * See `Model.compile`.\n *\n * @param config\n */\n compile(config: ModelCompileConfig): void {\n this.build();\n this.model.compile(config);\n this.optimizer = this.model.optimizer;\n this.loss = this.model.loss;\n this.metrics = this.model.metrics;\n // TODO(cais): Add this.lossWeights, this.sampleWeightMode,\n // this.weightedMetrics, this.targets.\n this.metricsTensors = this.model.metricsTensors;\n this.metricsNames = this.model.metricsNames;\n // TODO(cais): Add sampleWeights.\n }\n\n /**\n * Trains the model for a fixed number of epochs (iterations on a dataset).\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 1, inputShape: [10]})]\n * });\n * model.compile({optimizer: 'sgd', loss: 'meanSquaredError'});\n * const history = await model.fit(tf.ones([8, 10]), tf.ones([8, 1]), {\n * batchSize: 4,\n * epochs: 3\n * });\n * console.log(history.history.loss[0]);\n * ```\n *\n * @param x `Tensor` of training data, or an array of `Tensor`s if the model\n * has multiple inputs. If all inputs in the model are named, you can also\n * pass a dictionary mapping input names to `Tensor`s.\n * @param y `Tensor` of target (label) data, or an array of `Tensor`s if the\n * model has multiple outputs. If all outputs in the model are named, you\n * can also pass a dictionary mapping output names to `Tensor`s.\n * @param config A `ModelFitConfig`, containing optional fields.\n *\n * @return A `History` instance. Its `history` attribute contains all\n * information collected during training.\n *\n * @exception ValueError In case of mismatch between the provided input data\n * and what the model expects.\n */\n /**\n * @doc {heading: 'Models', subheading: 'Classes', configParamIndices: [2]}\n */\n async fit(\n x: Tensor|Tensor[]|{[inputName: string]: Tensor},\n y: Tensor|Tensor[]|{[inputName: string]: Tensor},\n config: ModelFitConfig = {}): Promise {\n if (!this.built) {\n throw new RuntimeError(\n 'The model needs to be compiled before ' +\n 'being used.');\n }\n return this.model.fit(x, y, config);\n }\n\n /* See parent class for JsDoc */\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const model = new cls({});\n if (!(model instanceof Sequential)) {\n throw new ValueError(\n `Sequential.fromConfig called on non-Sequential input: ${model}`);\n }\n if (!(config instanceof Array)) {\n throw new ValueError(\n `Sequential.fromConfig called without an array of configs`);\n }\n if (!(config[0].className != null) || config[0]['className'] === 'Merge') {\n throw new ValueError('Legacy serialization format not supported yet.');\n }\n for (const conf of config as serialization.ConfigDictArray) {\n const layer = deserialize(conf as serialization.ConfigDict) as Layer;\n model.add(layer);\n }\n return model;\n }\n\n // TODO(cais): Override get trainableWeights() here\n\n // tslint:disable-next-line:no-any\n getConfig(): any {\n // NOTE(cais): We override the return type of getConfig() to `any` here,\n // because the `Sequential` class is a special case among `Container`\n // subtypes in that its getConfig() method returns an Array (not a\n // dict).\n const config: serialization.ConfigDict[] = [];\n for (const layer of this.layers) {\n config.push({\n className: layer.getClassName(),\n config: layer.getConfig(),\n });\n }\n return config;\n }\n}\nserialization.SerializationMap.register(Sequential);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Exported functions.\n */\n\n// tslint:disable:max-line-length\nimport {io} from '@tensorflow/tfjs-core';\n\nimport {ContainerConfig} from './engine/container';\nimport {Input, InputConfig,} from './engine/input_layer';\nimport {SymbolicTensor} from './engine/topology';\nimport {Model} from './engine/training';\nimport {loadModelInternal, Sequential, SequentialConfig} from './models';\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Model and related factory methods.\n\n/**\n * A model is a data structure that consists of `Layers` and defines inputs\n * and outputs.\n *\n * The key difference between `model` and `sequential` is that `model`\n * is more generic, supporting an arbitrary graph (without cycles) of layers.\n * `sequential` is less generic and supports only a linear stack of layers.\n *\n * When creating a `Model`, specify its input(s) and output(s). Layers\n * are used to wire input(s) to output(s).\n *\n * For example, the following code snippet defines a model consisting of\n * two `dense` layers, with 10 and 4 units, respectively.\n *\n * ```js\n * // Define input, which has a size of 5 (not including batch dimension).\n * const input = tf.input({shape: [5]});\n *\n * // First dense layer uses relu activation.\n * const denseLayer1 = tf.layers.dense({units: 10, activation: 'relu'});\n * // Second dense layer uses softmax activation.\n * const denseLayer2 = tf.layers.dense({units: 2, activation: 'softmax'});\n *\n * // Obtain the output symbolic tensor by applying the layers on the input.\n * const output = denseLayer2.apply(denseLayer1.apply(input));\n *\n * // Create the model based on the inputs.\n * const model = tf.model({inputs: input, outputs: output});\n *\n * // The model can be used for training, evaluation and prediction.\n * // For example, the following line runs prediction with the model on\n * // some fake data.\n * model.predict(tf.ones([2, 5])).print();\n * ```\n * See also:\n * `sequential`, `loadModel`.\n */\n\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function model(config: ContainerConfig): Model {\n return new Model(config);\n}\n\n/**\n * Creates a `Sequential` model. A sequential model is any model where the\n * outputs of one layer are the inputs to the next layer, i.e. the model\n * topology is a simple 'stack' of layers, with no branching or skipping.\n *\n * This means that the first layer passed to a Sequential model should have a\n * defined input shape. What that means is that it should have received an\n * `inputShape` or `batchInputShape` argument, or for some type of layers\n * (recurrent, Dense...) an `inputDim` argument.\n *\n * The key difference between `model` and `sequential` is that `sequential`\n * is less generic, supporting only a linear stack of layers. `model` is\n * more generic and supports an arbitrary graph (without cycles) of layers.\n *\n * Examples:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have an input shape defined.\n * model.add(tf.layers.dense({units: 32, inputShape: [50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output, which equals\n * // `[null, 4]`. The 1st dimension is the undetermined batch dimension; the\n * // 2nd is the output size of the model's last layer.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * It is also possible to specify a batch size (with potentially undetermined\n * batch dimension, denoted by \"null\") for the first layer using the\n * `batchInputShape` key. The following example is equivalent to the above:\n *\n * ```js\n * const model = tf.sequential();\n *\n * // First layer must have a defined input shape\n * model.add(tf.layers.dense({units: 32, batchInputShape: [null, 50]}));\n * // Afterwards, TF.js does automatic shape inference.\n * model.add(tf.layers.dense({units: 4}));\n *\n * // Inspect the inferred shape of the model's output.\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n *\n * You can also use an `Array` of already-constructed `Layer`s to create\n * a `Sequential` model:\n *\n * ```js\n * const model = tf.sequential({\n * layers: [tf.layers.dense({units: 32, inputShape: [50]}),\n * tf.layers.dense({units: 4})]\n * });\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\n/**\n * @doc {heading: 'Models', subheading: 'Creation', configParamIndices: [0]}\n */\nexport function sequential(config?: SequentialConfig): Sequential {\n return new Sequential(config);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * useDocsFrom: 'loadModelInternal'\n * }\n */\nexport function loadModel(pathOrIOHandler: string|\n io.IOHandler): Promise {\n return loadModelInternal(pathOrIOHandler);\n}\n\n/**\n * @doc {\n * heading: 'Models',\n * subheading: 'Inputs',\n * useDocsFrom: 'Input',\n * configParamIndices: [0]\n * }\n */\nexport function input(config: InputConfig): SymbolicTensor {\n return Input(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n// Layer activation functions\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport * as K from './backend/tfjs_backend';\nimport {getScalar} from './backend/state';\nimport {deserializeKerasObject} from './utils/generic_utils';\n\n/**\n * Base class for Activations.\n *\n * Special note: due to cross-language compatibility reasons, the\n * static readonly className field in this family of classes must be set to\n * the initialLowerCamelCase name of the activation.\n */\nexport abstract class Activation extends serialization.Serializable {\n abstract apply(tensor: Tensor, axis?: number): Tensor;\n getConfig(): serialization.ConfigDict {\n return {};\n }\n}\n\n/** @docinline */\nexport type ActivationIdentifier = 'elu'|'hardSigmoid'|'linear'|'relu'|'relu6'|\n 'selu'|'sigmoid'|'softmax'|'softplus'|'softsign'|'tanh'|string;\n\n/**\n * Exponential linear unit (ELU).\n * Reference: https://arxiv.org/abs/1511.07289\n */\nexport class Elu extends Activation {\n static readonly className = 'elu';\n /**\n * Calculate the activation function.\n *\n * @param x: Input.\n * @param alpha: Scaling factor the negative section.\n * @return Output of the ELU activation.\n */\n apply(x: Tensor, alpha = 1): Tensor {\n return K.elu(x, alpha);\n }\n}\nserialization.SerializationMap.register(Elu);\n\n/**\n * Scaled Exponential Linear Unit. (Klambauer et al., 2017).\n * Reference: Self-Normalizing Neural Networks, https://arxiv.org/abs/1706.02515\n * Notes:\n * - To be used together with the initialization \"lecunNormal\".\n * - To be used together with the dropout variant \"AlphaDropout\".\n */\nexport class Selu extends Activation {\n static readonly className = 'selu';\n apply(x: Tensor): Tensor {\n return tfc.selu(x);\n }\n}\nserialization.SerializationMap.register(Selu);\n\n/**\n * Rectified linear unit\n */\nexport class Relu extends Activation {\n static readonly className = 'relu';\n apply(x: Tensor): Tensor {\n return tfc.relu(x);\n }\n}\nserialization.SerializationMap.register(Relu);\n\n/**\n * Rectified linear unit activation maxing out at 6.0.\n */\nexport class Relu6 extends Activation {\n static readonly className = 'relu6';\n apply(x: Tensor): Tensor {\n return tidy(() => tfc.minimum(getScalar(6.0), tfc.relu(x)));\n }\n}\nserialization.SerializationMap.register(Relu6);\n\n//* Linear activation (no-op) */\nexport class Linear extends Activation {\n static readonly className = 'linear';\n apply(x: Tensor): Tensor {\n return x;\n }\n}\nserialization.SerializationMap.register(Linear);\n\n/**\n * Sigmoid activation function.\n */\nexport class Sigmoid extends Activation {\n static readonly className = 'sigmoid';\n apply(x: Tensor): Tensor {\n return tfc.sigmoid(x);\n }\n}\nserialization.SerializationMap.register(Sigmoid);\n\n/**\n * Segment-wise linear approximation of sigmoid.\n */\nexport class HardSigmoid extends Activation {\n static readonly className = 'hardSigmoid';\n apply(x: Tensor): Tensor {\n return K.hardSigmoid(x);\n }\n}\nserialization.SerializationMap.register(HardSigmoid);\n\n/**\n * Softplus activation function.\n */\nexport class Softplus extends Activation {\n static readonly className = 'softplus';\n apply(x: Tensor): Tensor {\n return tfc.softplus(x);\n }\n}\nserialization.SerializationMap.register(Softplus);\n\n/**\n * Softsign activation function.\n */\nexport class Softsign extends Activation {\n static readonly className = 'softsign';\n apply(x: Tensor): Tensor {\n return K.softsign(x);\n }\n}\nserialization.SerializationMap.register(Softsign);\n\n/**\n * Hyperbolic tangent function.\n */\nexport class Tanh extends Activation {\n static readonly className = 'tanh';\n apply(x: Tensor): Tensor {\n return tfc.tanh(x);\n }\n}\nserialization.SerializationMap.register(Tanh);\n\n/**\n * Softmax activation function\n */\nexport class Softmax extends Activation {\n static readonly className = 'softmax';\n /**\n * Calculate the activation function.\n *\n * @param x Tensor.\n * @param axis Integer, axis along which the softmax normalization is applied.\n * Invalid if < 2, as softmax across 1 (the batch dimension) is assumed to be\n * an error.\n *\n * @returns a Tensor of the same shape as x\n *\n * @throws ValueError: In case `dim(x) < 2`.\n */\n apply(x: Tensor, axis: number = (-1)): Tensor {\n return tfc.softmax(x, axis);\n }\n}\nserialization.SerializationMap.register(Softmax);\n\nexport function serializeActivation(activation: Activation): string {\n return activation.getClassName();\n}\n\nexport function deserializeActivation(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Activation {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'activation');\n}\n\nexport function getActivation(identifier: ActivationIdentifier|\n serialization.ConfigDict|Activation): Activation {\n if (identifier == null) {\n const config = {className: 'linear', config: {}};\n return deserializeActivation(config);\n }\n if (typeof identifier === 'string') {\n const config = {className: identifier, config: {}};\n return deserializeActivation(config);\n } else if (identifier instanceof Activation) {\n return identifier;\n } else {\n return deserializeActivation(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Advanced activation layers.\n */\n\nimport {elu, leakyRelu, serialization, Tensor} from '@tensorflow/tfjs-core';\n\nimport {Softmax as softmaxActivation} from '../activations';\nimport {cast} from '../backend/tfjs_backend';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneTensor} from '../utils/types_utils';\n\nexport interface LeakyReLULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `0.3`.\n */\n alpha?: number;\n}\n\n/**\n * Leaky version of a rectified linear unit.\n *\n * It allows a small gradient when the unit is not active:\n * `f(x) = alpha * x for x < 0.`\n * `f(x) = x for x >= 0.`\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class LeakyReLU extends Layer {\n static className = 'LeakyReLU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 0.3;\n\n constructor(config?: LeakyReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return leakyRelu(x, this.alpha);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LeakyReLU);\n\n// TODO(cais): Implement PReLU\n\nexport interface ELULayerConfig extends LayerConfig {\n /**\n * Float `>= 0`. Negative slope coefficient. Defaults to `1.0`.\n */\n alpha?: number;\n}\n\n/**\n * Exponetial Linear Unit (ELU).\n *\n * It follows:\n * `f(x) = alpha * (exp(x) - 1.) for x < 0`,\n * `f(x) = x for x >= 0`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Fast and Accurate Deep Network Learning by Exponential Linear Units\n * (ELUs)](https://arxiv.org/abs/1511.07289v1)\n */\nexport class ELU extends Layer {\n static className = 'ELU';\n readonly alpha: number;\n\n readonly DEFAULT_ALPHA = 1.0;\n\n constructor(config?: ELULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n if (config.alpha != null && config.alpha !== this.DEFAULT_ALPHA) {\n throw new NotImplementedError(\n `Non-default alpha value (${config.alpha}) is not supported by the ` +\n `ELU layer yet.`);\n }\n\n this.alpha = config.alpha == null ? this.DEFAULT_ALPHA : config.alpha;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return elu(x);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {alpha: this.alpha};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ELU);\n\nexport interface ThresholdedReLULayerConfig extends LayerConfig {\n /**\n * Float >= 0. Threshold location of activation.\n */\n theta?: number;\n}\n\n/**\n * Thresholded Rectified Linear Unit.\n *\n * It follows:\n * `f(x) = x for x > theta`,\n * `f(x) = 0 otherwise`.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n *\n * References:\n * - [Zero-Bias Autoencoders and the Benefits of Co-Adapting\n * Features](http://arxiv.org/abs/1402.3337)\n */\nexport class ThresholdedReLU extends Layer {\n static className = 'ThresholdedReLU';\n readonly theta: number;\n private readonly thetaTensor: Tensor;\n\n readonly DEFAULT_THETA = 1.0;\n\n constructor(config?: ThresholdedReLULayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n\n this.theta = config.theta == null ? this.DEFAULT_THETA : config.theta;\n this.thetaTensor = getScalar(this.theta);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return x.mul(cast(x.greater(this.thetaTensor), 'float32'));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {theta: this.theta};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ThresholdedReLU);\n\nexport interface SoftmaxLayerConfig extends LayerConfig {\n /**\n * Integer, axis along which the softmax normalization is applied.\n * Defaults to `-1` (i.e., the last axis).\n */\n axis?: number;\n}\n\n/**\n * Softmax activation layer.\n *\n * Input shape:\n * Arbitrary. Use the configuration `inputShape` when using this layer as the\n * first layer in a model.\n *\n * Output shape:\n * Same shape as the input.\n */\nexport class Softmax extends Layer {\n static className = 'Softmax';\n readonly axis: number;\n readonly softmax: (t: Tensor, a?: number) => Tensor;\n readonly DEFAULT_AXIS = 1.0;\n\n constructor(config?: SoftmaxLayerConfig) {\n super(config == null ? {} : config);\n if (config == null) {\n config = {};\n }\n this.softmax = new softmaxActivation().apply;\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n const x = getExactlyOneTensor(inputs);\n return this.softmax(x, this.axis);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n return inputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {axis: this.axis};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Softmax);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* original source: keras/regularizers.py */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {abs, add, Scalar, serialization, sum, Tensor, tidy, zeros} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from './backend/state';\nimport * as K from './backend/tfjs_backend';\nimport {deserializeKerasObject, serializeKerasObject} from './utils/generic_utils';\n// tslint:enable:max-line-length\n\n/**\n * Regularizer base class.\n */\nexport abstract class Regularizer extends serialization.Serializable {\n abstract apply(x: Tensor): Scalar;\n}\n\nexport interface L1L2Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1?: number;\n /** L2 regularization rate. Defaults to 0.01. */\n l2?: number;\n}\n\nexport interface L1Config {\n /** L1 regularization rate. Defaults to 0.01. */\n l1: number;\n}\n\nexport interface L2Config {\n /** L2 regularization rate. Defaults to 0.01. */\n l2: number;\n}\n\n/**\n * Regularizer for L1 and L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x)) + sum(l2 * x^2)\n */\n/** @doc {heading: 'Regularizers', namespace: 'regularizers'} */\nexport class L1L2 extends Regularizer {\n static className = 'L1L2';\n\n private readonly l1: Scalar;\n private readonly l2: Scalar;\n private readonly hasL1: boolean;\n private readonly hasL2: boolean;\n constructor(config?: L1L2Config) {\n super();\n\n const l1 = config == null || config.l1 == null ? 0.01 : config.l1;\n const l2 = config == null || config.l2 == null ? 0.01 : config.l2;\n this.hasL1 = l1 !== 0;\n this.hasL2 = l2 !== 0;\n\n this.l1 = getScalar(l1);\n this.l2 = getScalar(l2);\n }\n\n /**\n * Porting note: Renamed from __call__.\n * @param x Variable of which to calculate the regularization score.\n */\n apply(x: Tensor): Scalar {\n return tidy(() => {\n let regularization: Tensor = zeros([1]);\n if (this.hasL1) {\n regularization = add(regularization, sum(tfc.mul(this.l1, abs(x))));\n }\n if (this.hasL2) {\n regularization =\n add(regularization, sum(tfc.mul(this.l2, K.square(x))));\n }\n return regularization.asScalar();\n });\n }\n\n getConfig(): serialization.ConfigDict {\n return {'l1': this.l1.dataSync()[0], 'l2': this.l2.dataSync()[0]};\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n return new cls({l1: config.l1 as number, l2: config.l2 as number});\n }\n}\nserialization.SerializationMap.register(L1L2);\n\n/**\n * Regularizer for L1 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l1 * abs(x))\n * @param config l1 config.\n */\nexport function l1(config?: L1Config) {\n return new L1L2({l1: config != null ? config.l1 : null, l2: 0});\n}\n\n/**\n * Regularizer for L2 regularization.\n *\n * Adds a term to the loss to penalize large weights:\n * loss += sum(l2 * x^2)\n * @param config l2 config.\n */\nexport function l2(config: L2Config) {\n return new L1L2({l2: config != null ? config.l2 : null, l1: 0});\n}\n\n/** @docinline */\nexport type RegularizerIdentifier = 'l1l2'|string;\n\n// Maps the JavaScript-like identifier keys to the corresponding keras symbols.\nexport const REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP:\n {[identifier in RegularizerIdentifier]: string} = {\n 'l1l2': 'L1L2'\n };\n\nexport function serializeRegularizer(constraint: Regularizer):\n serialization.ConfigDictValue {\n return serializeKerasObject(constraint);\n}\n\nexport function deserializeRegularizer(\n config: serialization.ConfigDict,\n customObjects: serialization.ConfigDict = {}): Regularizer {\n return deserializeKerasObject(\n config, serialization.SerializationMap.getMap().classNameMap,\n customObjects, 'regularizer');\n}\n\nexport function getRegularizer(identifier: RegularizerIdentifier|\n serialization.ConfigDict|\n Regularizer): Regularizer {\n if (identifier == null) {\n return null;\n }\n if (typeof identifier === 'string') {\n const className = identifier in REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ?\n REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[identifier] :\n identifier;\n const config = {className, config: {}};\n return deserializeRegularizer(config);\n } else if (identifier instanceof Regularizer) {\n return identifier;\n } else {\n return deserializeRegularizer(identifier);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\nimport {PaddingMode} from '../common';\nimport {ValueError} from '../errors';\n\nimport {pyListRepeat} from './generic_utils';\nimport {isInteger, max} from './math_utils';\n\n/**\n * Transforms a single number of array of numbers into an array of numbers.\n * @param value\n * @param n: The size of the tuple to be returned.\n * @param name: Name of the parameter, used for generating error messages.\n * @returns An array of numbers.\n */\nexport function normalizeArray(\n value: number|number[], n: number, name: string): number[] {\n if (typeof value === 'number') {\n return pyListRepeat(value, n);\n } else {\n if (value.length !== n) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${n} integers. Received: ` +\n `${value.length} elements.`);\n }\n for (let i = 0; i < n; ++i) {\n const singleValue = value[i];\n if (!isInteger(singleValue)) {\n throw new ValueError(\n `The ${name} argument must be a tuple of ${\n n} integers. Received: ` +\n `${JSON.stringify(value)} including a non-integer number ` +\n `${singleValue}`);\n }\n }\n return value;\n }\n}\n\n/**\n * Determines output length of a convolution given input length.\n * @param inputLength\n * @param filterSize\n * @param padding\n * @param stride\n * @param dilation: dilation rate.\n */\nexport function convOutputLength(\n inputLength: number, filterSize: number, padding: PaddingMode,\n stride: number, dilation = 1): number {\n if (inputLength == null) {\n return inputLength;\n }\n const dilatedFilterSize = filterSize + (filterSize - 1) * (dilation - 1);\n let outputLength: number;\n if (padding === 'same') {\n outputLength = inputLength;\n } else { // VALID\n outputLength = inputLength - dilatedFilterSize + 1;\n }\n return Math.floor((outputLength + stride - 1) / stride);\n}\n\nexport function deconvLength(\n dimSize: number, strideSize: number, kernelSize: number,\n padding: PaddingMode): number {\n if (dimSize == null) {\n return null;\n }\n\n if (padding === 'valid') {\n dimSize = dimSize * strideSize + max([kernelSize - strideSize, 0]);\n } else if (padding === 'same') {\n dimSize = dimSize * strideSize;\n } else {\n throw new ValueError(`Unsupport padding mode: ${padding}.`);\n }\n return dimSize;\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {Activation, getActivation, serializeActivation} from '../activations';\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, DataFormat, PaddingMode} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength, deconvLength, normalizeArray} from '../utils/conv_utils';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n// tslint:enable:max-line-length\n\n/**\n * Transpose and cast the input before the conv2d.\n * @param x Input image tensor.\n * @param dataFormat\n */\nexport function preprocessConv2DInput(\n x: Tensor, dataFormat: DataFormat): Tensor {\n // TODO(cais): Cast type to float32 if not.\n return tidy(() => {\n checkDataFormat(dataFormat);\n if (dataFormat === 'channelsFirst') {\n return tfc.transpose(x, [0, 2, 3, 1]); // NCHW -> NHWC.\n } else {\n return x;\n }\n });\n}\n\n/**\n * 1D-convolution with bias added.\n *\n * Porting Note: This function does not exist in the Python Keras backend.\n * It is exactly the same as `conv2d`, except the added `bias`.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.\n * @param bias Bias, rank-3, of shape `[outDepth]`.\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n // Check the ranks of x, kernel and bias.\n if (x.shape.length !== 3) {\n throw new ValueError(\n `The input of a conv1dWithBias operation should be 3, but is ` +\n `${x.shape.length} instead.`);\n }\n if (kernel.shape.length !== 3) {\n throw new ValueError(\n `The kernel for a conv1dWithBias operation should be 3, but is ` +\n `${kernel.shape.length} instead`);\n }\n if (bias != null && bias.shape.length !== 1) {\n throw new ValueError(\n `The bias for a conv1dWithBias operation should be 1, but is ` +\n `${kernel.shape.length} instead`);\n }\n // TODO(cais): Support CAUSAL padding mode.\n if (dataFormat === 'channelsFirst') {\n x = tfc.transpose(x, [0, 2, 1]); // NCW -> NWC.\n }\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n let y: Tensor = tfc.conv1d(\n x as Tensor2D | Tensor3D, kernel as Tensor3D, strides,\n padding === 'same' ? 'same' : 'valid', 'NWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias);\n }\n return y;\n });\n}\n\n/**\n * 1D-convolution.\n *\n * @param x Input tensor, rank-3, of shape `[batchSize, width, inChannels]`.\n * @param kernel Kernel, rank-3, of shape `[filterWidth, inDepth, outDepth]`.s\n * @param strides\n * @param padding Padding mode.\n * @param dataFormat Data format.\n * @param dilationRate\n * @returns The result of the 1D convolution.\n * @throws ValueError, if `x`, `kernel` or `bias` is not of the correct rank.\n */\nexport function conv1d(\n x: Tensor, kernel: Tensor, strides = 1, padding = 'valid',\n dataFormat?: DataFormat, dilationRate = 1): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv1dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution\n * @param x\n * @param kernel kernel of the convolution.\n * @param strides strides array.\n * @param padding padding mode. Default to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param dilationRate dilation rate array.\n * @returns Result of the 2D pooling.\n */\nexport function conv2d(\n x: Tensor, kernel: Tensor, strides = [1, 1], padding = 'valid',\n dataFormat?: DataFormat, dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n return conv2dWithBias(\n x, kernel, null, strides, padding, dataFormat, dilationRate);\n });\n}\n\n/**\n * 2D Convolution with an added bias.\n * Note: This function does not exist in the Python Keras Backend. This function\n * is exactly the same as `conv2d`, except the added `bias`.\n */\nexport function conv2dWithBias(\n x: Tensor, kernel: Tensor, bias: Tensor, strides = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n if (x.rank !== 3 && x.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects input to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n if (kernel.rank !== 3 && kernel.rank !== 4) {\n throw new ValueError(\n `conv2dWithBias expects kernel to be of rank 3 or 4, but received ` +\n `${x.rank}.`);\n }\n let y = preprocessConv2DInput(x, dataFormat);\n if (padding === 'causal') {\n throw new NotImplementedError(\n 'The support for CAUSAL padding mode in conv1dWithBias is not ' +\n 'implemented yet.');\n }\n y = tfc.conv2d(\n y as Tensor3D | Tensor4D, kernel as Tensor4D,\n strides as [number, number], padding === 'same' ? 'same' : 'valid',\n 'NHWC', dilationRate);\n if (bias != null) {\n y = K.biasAdd(y, bias as Tensor1D);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\n\n/**\n * Base LayerConfig for depthwise and non-depthwise convolutional layers.\n */\nexport interface BaseConvLayerConfig extends LayerConfig {\n /**\n * The dimensions of the convolution window. If kernelSize is a number, the\n * convolutional window will be square.\n */\n kernelSize: number|number[];\n\n /**\n * The strides of the convolution in each dimension. If strides is a number,\n * strides in both dimensions are equal.\n *\n * Specifying any stride value != 1 is incompatible with specifying any\n * `dilationRate` value != 1.\n */\n strides?: number|number[];\n\n /**\n * Padding mode.\n */\n padding?: PaddingMode;\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n\n /**\n * The dilation rate to use for the dilated convolution in each dimension.\n * Should be an integer or array of two integers.\n *\n * Currently, specifying any `dilationRate` value != 1 is incompatible with\n * specifying any `strides` value != 1.\n */\n dilationRate?: number|[number]|[number, number];\n\n /**\n * Activation function of the layer.\n *\n * If you don't specify the activation, none is applied.\n */\n activation?: string;\n\n /**\n * Whether the layer uses a bias vector. Defaults to `true`.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the convolutional kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the convolutional kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * LayerConfig for non-depthwise convolutional layers.\n * Applies to non-depthwise convolution of all ranks (e.g, Conv1D, Conv2D).\n */\nexport interface ConvLayerConfig extends BaseConvLayerConfig {\n /**\n * The dimensionality of the output space (i.e. the number of filters in the\n * convolution).\n */\n filters: number;\n}\n\n/**\n * Abstract convolution layer.\n */\nexport abstract class BaseConv extends Layer {\n protected readonly rank: number;\n protected readonly kernelSize: number[];\n protected readonly strides: number[];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n protected readonly activation: Activation;\n protected readonly useBias: boolean;\n protected readonly dilationRate: number[];\n\n // Bias-related members are here because all convolution subclasses use the\n // same configuration parmeters to control bias. Kernel-related members\n // are in subclass `Conv` because some subclasses use different parameters to\n // control kernel properties, for instance, `DepthwiseConv2D` uses\n // `depthwiseInitializer` instead of `kernelInitializer`.\n protected readonly biasInitializer?: Initializer;\n protected readonly biasConstraint?: Constraint;\n protected readonly biasRegularizer?: Regularizer;\n\n protected bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(rank: number, config: BaseConvLayerConfig) {\n super(config as LayerConfig);\n BaseConv.verifyConfig(config);\n this.rank = rank;\n if (this.rank !== 1 && this.rank !== 2) {\n throw new NotImplementedError(\n `Convolution layer for rank other than 1 or 2 (${this.rank}) is ` +\n `not implemented yet.`);\n }\n this.kernelSize = normalizeArray(config.kernelSize, rank, 'kernelSize');\n this.strides = normalizeArray(\n config.strides == null ? 1 : config.strides, rank, 'strides');\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.activation = getActivation(config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.dilationRate = normalizeArray(\n config.dilationRate == null ? 1 : config.dilationRate, rank,\n 'dilationRate');\n if (this.rank === 1 &&\n (Array.isArray(this.dilationRate) &&\n (this.dilationRate as number[]).length !== 1)) {\n throw new ValueError(\n `dilationRate must be a number or an array of a single number ` +\n `for 1D convolution, but received ` +\n `${JSON.stringify(this.dilationRate)}`);\n }\n if (this.rank === 2) {\n if (typeof this.dilationRate === 'number') {\n this.dilationRate = [this.dilationRate, this.dilationRate];\n } else if (this.dilationRate.length !== 2) {\n throw new ValueError(\n `dilationRate must be a number or array of two numbers for 2D ` +\n `convolution, but received ${JSON.stringify(this.dilationRate)}`);\n }\n }\n }\n\n protected static verifyConfig(config: BaseConvLayerConfig) {\n // Check config.kernelSize type and shape.\n generic_utils.assert(\n 'kernelSize' in config, `required key 'kernelSize' not in config`);\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `BaseConv expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n kernelSize: this.kernelSize,\n strides: this.strides,\n padding: this.padding,\n dataFormat: this.dataFormat,\n dilationRate: this.dilationRate,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n biasInitializer: serializeInitializer(this.biasInitializer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Abstract nD convolution layer. Ancestor of convolution layers which reduce\n * across channels, i.e., Conv1D and Conv2D, but not DepthwiseConv2D.\n */\nexport abstract class Conv extends BaseConv {\n protected readonly filters: number;\n\n protected kernel: LayerVariable = null;\n\n // Bias-related properties are stored in the superclass `BaseConv` because all\n // convolution subclasses use the same configuration parameters to control\n // bias. Kernel-related properties are defined here rather than in the\n // superclass because some convolution subclasses use different names and\n // configuration parameters for their internal kernel state.\n protected readonly kernelInitializer?: Initializer;\n protected readonly kernelConstraint?: Constraint;\n protected readonly kernelRegularizer?: Regularizer;\n\n constructor(rank: number, config: ConvLayerConfig) {\n super(rank, config as BaseConvLayerConfig);\n Conv.verifyConfig(config);\n this.filters = config.filters;\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n `The channel dimension of the input should be defined. ` +\n `Found ${inputShape[channelAxis]}`);\n }\n const inputDim = inputShape[channelAxis];\n\n const kernelShape = this.kernelSize.concat([inputDim, this.filters]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n this.inputSpec = [{ndim: this.rank + 2, axes: {[channelAxis]: inputDim}}];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs: Tensor;\n const biasValue = this.bias == null ? null : this.bias.read();\n\n if (this.rank === 1) {\n outputs = conv1dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides[0],\n this.padding, this.dataFormat, this.dilationRate[0]);\n } else if (this.rank === 2) {\n // TODO(cais): Move up to constructor.\n outputs = conv2dWithBias(\n inputs, this.kernel.read(), biasValue, this.strides, this.padding,\n this.dataFormat, this.dilationRate as [number, number]);\n } else if (this.rank === 3) {\n throw new NotImplementedError('3D convolution is not implemented yet.');\n }\n\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const newSpace: number[] = [];\n const space = (this.dataFormat === 'channelsLast') ?\n inputShape.slice(1, inputShape.length - 1) :\n inputShape.slice(2);\n for (let i = 0; i < space.length; ++i) {\n const newDim = convOutputLength(\n space[i], this.kernelSize[i], this.padding, this.strides[i],\n typeof this.dilationRate === 'number' ? this.dilationRate :\n this.dilationRate[i]);\n newSpace.push(newDim);\n }\n\n let outputShape = [inputShape[0]];\n if (this.dataFormat === 'channelsLast') {\n outputShape = outputShape.concat(newSpace);\n outputShape.push(this.filters);\n } else {\n outputShape.push(this.filters);\n outputShape = outputShape.concat(newSpace);\n }\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n filters: this.filters,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // Check config.filters type, shape, and value.\n if (!('filters' in config) || typeof config.filters !== 'number' ||\n config.filters < 1) {\n throw new ValueError(\n `Convolution layer expected config.filters to be a 'number' > 0 ` +\n `but got ${JSON.stringify(config.filters)}`);\n }\n }\n}\n\n\n/**\n * 2D convolution layer (e.g. spatial convolution over images).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input to produce a tensor of outputs.\n *\n * If `useBias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model,\n * provide the keyword argument `inputShape`\n * (Array of integers, does not include the sample axis),\n * e.g. `inputShape=[128, 128, 3]` for 128x128 RGB pictures\n * in `dataFormat='channelsLast'`.\n */\nexport class Conv2D extends Conv {\n static className = 'Conv2D';\n constructor(config: ConvLayerConfig) {\n super(2, config);\n Conv2D.verifyConfig(config);\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n return config;\n }\n\n protected static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if ((typeof config.kernelSize !== 'number') &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 2))\n throw new ValueError(\n `Conv2D expects config.kernelSize to be number or number[] with ` +\n `length 1 or 2, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv2D);\n\n/**\n * Transposed convolutional layer (sometimes called Deconvolution).\n *\n * The need for transposed convolutions generally arises\n * from the desire to use a transformation going in the opposite direction of\n * a normal convolution, i.e., from something that has the shape of the output\n * of some convolution to something that has the shape of its input while\n * maintaining a connectivity pattern that is compatible with said\n * convolution.\n *\n * When using this layer as the first layer in a model, provide the\n * configuration `inputShape` (`Array` of integers, does not include the\n * sample axis), e.g., `inputShape: [128, 128, 3]` for 128x128 RGB pictures in\n * `dataFormat: 'channelsLast'`.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if `dataFormat` is `'channelsFirst'`.\n * or 4D tensor with shape\n * `[batch, rows, cols, channels]` if `dataFormat` is `'channelsLast`.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if `dataFormat` is\n * `'channelsFirst'`. or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if `dataFormat` is `'channelsLast'`.\n *\n * References:\n * - [A guide to convolution arithmetic for deep\n * learning](https://arxiv.org/abs/1603.07285v1)\n * - [Deconvolutional\n * Networks](http://www.matthewzeiler.com/pubs/cvpr2010/cvpr2010.pdf)\n */\nexport class Conv2DTranspose extends Conv2D {\n static className = 'Conv2DTranspose';\n inputSpec: InputSpec[];\n\n constructor(config: ConvLayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 4})];\n\n if (this.padding !== 'same' && this.padding !== 'valid') {\n throw new ValueError(\n `Conv2DTranspose currently supports only padding modes 'same' ` +\n `and 'valid', but received padding mode ${this.padding}`);\n }\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n\n if (inputShape.length !== 4) {\n throw new ValueError(\n 'Input should have rank 4; Received input shape: ' +\n JSON.stringify(inputShape));\n }\n\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null) {\n throw new ValueError(\n 'The channel dimension of the inputs should be defined. ' +\n 'Found `None`.');\n }\n const inputDim = inputShape[channelAxis];\n const kernelShape = this.kernelSize.concat([this.filters, inputDim]);\n\n this.kernel = this.addWeight(\n 'kernel', kernelShape, 'float32', this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n\n // Set input spec.\n this.inputSpec =\n [new InputSpec({ndim: 4, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs);\n if (input.shape.length !== 4) {\n throw new ValueError(\n `Conv2DTranspose.call() expects input tensor to be rank-4, but ` +\n `received a tensor of rank-${input.shape.length}`);\n }\n\n const inputShape = input.shape;\n const batchSize = inputShape[0];\n\n let hAxis: number;\n let wAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n hAxis = 2;\n wAxis = 3;\n } else {\n hAxis = 1;\n wAxis = 2;\n }\n\n const height = inputShape[hAxis];\n const width = inputShape[wAxis];\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n // Infer the dynamic output shape.\n const outHeight = deconvLength(height, strideH, kernelH, this.padding);\n const outWidth = deconvLength(width, strideW, kernelW, this.padding);\n\n // Porting Note: We don't branch based on `this.dataFormat` here,\n // because\n // the tjfs-core function `conv2dTranspose` called below always\n // assumes channelsLast.\n const outputShape: [number, number, number, number] =\n [batchSize, outHeight, outWidth, this.filters];\n\n if (this.dataFormat !== 'channelsLast') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n }\n let outputs = tfc.conv2dTranspose(\n input as Tensor4D, this.kernel.read() as Tensor4D, outputShape,\n this.strides as [number, number], this.padding as 'same' | 'valid');\n if (this.dataFormat !== 'channelsLast') {\n outputs = tfc.transpose(outputs, [0, 3, 1, 2]) as Tensor4D;\n }\n\n if (this.bias != null) {\n outputs =\n K.biasAdd(outputs, this.bias.read(), this.dataFormat) as Tensor4D;\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs) as Tensor4D;\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n\n let channelAxis: number;\n let heightAxis: number;\n let widthAxis: number;\n if (this.dataFormat === 'channelsFirst') {\n channelAxis = 1;\n heightAxis = 2;\n widthAxis = 3;\n } else {\n channelAxis = 3;\n heightAxis = 1;\n widthAxis = 2;\n }\n\n const kernelH = this.kernelSize[0];\n const kernelW = this.kernelSize[1];\n const strideH = this.strides[0];\n const strideW = this.strides[1];\n\n outputShape[channelAxis] = this.filters;\n outputShape[heightAxis] =\n deconvLength(outputShape[heightAxis], strideH, kernelH, this.padding);\n outputShape[widthAxis] =\n deconvLength(outputShape[widthAxis], strideW, kernelW, this.padding);\n return outputShape;\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['dilationRate'];\n return config;\n }\n}\nserialization.SerializationMap.register(Conv2DTranspose);\n\n\nexport interface SeparableConvLayerConfig extends ConvLayerConfig {\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal\n * to `filtersIn * depthMultiplier`. Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the pointwise kernel matrix.\n */\n pointwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the pointwise kernel matrix.\n */\n pointwiseRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the pointwise kernel matrix.\n */\n pointwiseConstraint?: ConstraintIdentifier|Constraint;\n}\n\n\nexport class SeparableConv extends Conv {\n static className = 'SeparableConv';\n\n readonly depthMultiplier: number;\n\n protected readonly depthwiseInitializer?: Initializer;\n protected readonly depthwiseRegularizer?: Regularizer;\n protected readonly depthwiseConstraint?: Constraint;\n protected readonly pointwiseInitializer?: Initializer;\n protected readonly pointwiseRegularizer?: Regularizer;\n protected readonly pointwiseConstraint?: Constraint;\n\n readonly DEFAULT_DEPTHWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n readonly DEFAULT_POINTWISE_INITIALIZER: InitializerIdentifier =\n 'glorotUniform';\n\n protected depthwiseKernel: LayerVariable = null;\n protected pointwiseKernel: LayerVariable = null;\n\n constructor(rank: number, config?: SeparableConvLayerConfig) {\n super(rank, config);\n\n if (config.filters == null) {\n throw new ValueError(\n 'The `filters` configuration field is required by SeparableConv, ' +\n 'but is unspecified.');\n }\n if (config.kernelInitializer != null || config.kernelRegularizer != null ||\n config.kernelConstraint != null) {\n throw new ValueError(\n 'Fields kernelInitializer, kernelRegularizer and kernelConstraint ' +\n 'are invalid for SeparableConv2D. Use depthwiseInitializer, ' +\n 'depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, ' +\n 'pointwiseRegularizer and pointwiseConstraint instead.');\n }\n if (config.padding != null && config.padding !== 'same' &&\n config.padding !== 'valid') {\n throw new ValueError(\n `SeparableConv${this.rank}D supports only padding modes: ` +\n `'same' and 'valid', but received ${JSON.stringify(config.padding)}`);\n }\n\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_DEPTHWISE_INITIALIZER);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.pointwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_POINTWISE_INITIALIZER);\n this.pointwiseRegularizer = getRegularizer(config.pointwiseRegularizer);\n this.pointwiseConstraint = getConstraint(config.pointwiseConstraint);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < this.rank + 2) {\n throw new ValueError(\n `Inputs to SeparableConv${this.rank}D should have rank ` +\n `${this.rank + 2}, but received input shape: ` +\n `${JSON.stringify(inputShape)}`);\n }\n const channelAxis =\n this.dataFormat === 'channelsFirst' ? 1 : inputShape.length - 1;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n `The channel dimension of the inputs should be defined, ` +\n `but found ${JSON.stringify(inputShape[channelAxis])}`);\n }\n\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape =\n this.kernelSize.concat([inputDim, this.depthMultiplier]);\n const pointwiseKernelShape = [];\n for (let i = 0; i < this.rank; ++i) {\n pointwiseKernelShape.push(1);\n }\n pointwiseKernelShape.push(inputDim * this.depthMultiplier, this.filters);\n\n const trainable = true;\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, 'float32',\n this.depthwiseInitializer, this.depthwiseRegularizer, trainable,\n this.depthwiseConstraint);\n this.pointwiseKernel = this.addWeight(\n 'pointwise_kernel', pointwiseKernelShape, 'float32',\n this.pointwiseInitializer, this.pointwiseRegularizer, trainable,\n this.pointwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.filters], 'float32', this.biasInitializer,\n this.biasRegularizer, trainable, this.biasConstraint);\n } else {\n this.bias = null;\n }\n\n this.inputSpec =\n [new InputSpec({ndim: this.rank + 2, axes: {[channelAxis]: inputDim}})];\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n let output: Tensor;\n if (this.rank === 1) {\n throw new NotImplementedError(\n '1D separable convolution is not implemented yet.');\n } else if (this.rank === 2) {\n if (this.dataFormat === 'channelsFirst') {\n inputs = tfc.transpose(inputs, [0, 2, 3, 1]); // NCHW -> NHWC.\n }\n\n output = tfc.separableConv2d(\n inputs as Tensor4D, this.depthwiseKernel.read() as Tensor4D,\n this.pointwiseKernel.read() as Tensor4D,\n this.strides as [number, number], this.padding as 'same' | 'valid',\n this.dilationRate as [number, number], 'NHWC');\n }\n\n if (this.useBias) {\n output = K.biasAdd(output, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n if (this.dataFormat === 'channelsFirst') {\n output = tfc.transpose(output, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['kernelInitializer'];\n delete config['kernelRegularizer'];\n delete config['kernelConstraint'];\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['pointwiseInitializer'] =\n serializeInitializer(this.pointwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['pointwiseRegularizer'] =\n serializeRegularizer(this.pointwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseConstraint);\n config['pointwiseConstraint'] =\n serializeConstraint(this.pointwiseConstraint);\n return config;\n }\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Separable convolution consists of first performing\n * a depthwise spatial convolution\n * (which acts on each input channel separately)\n * followed by a pointwise convolution which mixes together the resulting\n * output channels. The `depthMultiplier` argument controls how many\n * output channels are generated per input channel in the depthwise step.\n *\n * Intuitively, separable convolutions can be understood as\n * a way to factorize a convolution kernel into two smaller kernels,\n * or as an extreme version of an Inception block.\n *\n * Input shape:\n * 4D tensor with shape:\n * `[batch, channels, rows, cols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, rows, cols, channels]` if data_format='channelsLast'.\n *\n * Output shape:\n * 4D tensor with shape:\n * `[batch, filters, newRows, newCols]` if data_format='channelsFirst'\n * or 4D tensor with shape:\n * `[batch, newRows, newCols, filters]` if data_format='channelsLast'.\n * `rows` and `cols` values might have changed due to padding.\n */\nexport class SeparableConv2D extends SeparableConv {\n static className = 'SeparableConv2D';\n constructor(config?: SeparableConvLayerConfig) {\n super(2, config);\n }\n}\nserialization.SerializationMap.register(SeparableConv2D);\n\n/**\n * 1D convolution layer (e.g., temporal convolution).\n *\n * This layer creates a convolution kernel that is convolved\n * with the layer input over a single spatial (or temporal) dimension\n * to produce a tensor of outputs.\n *\n * If `use_bias` is True, a bias vector is created and added to the outputs.\n *\n * If `activation` is not `null`, it is applied to the outputs as well.\n *\n * When using this layer as the first layer in a model, provide an\n * `inputShape` argument `Array` or `null`.\n *\n * For example, `inputShape` would be:\n * - `[10, 128]` for sequences of 10 vectors of 128-dimensional vectors\n * - `[null, 128]` for variable-length sequences of 128-dimensional vectors.\n */\nexport class Conv1D extends Conv {\n static className = 'Conv1D';\n constructor(config: ConvLayerConfig) {\n super(1, config);\n Conv1D.verifyConfig(config);\n this.inputSpec = [{ndim: 3}];\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n delete config['rank'];\n delete config['dataFormat'];\n return config;\n }\n\n static verifyConfig(config: ConvLayerConfig) {\n // config.kernelSize must be a number or array of numbers.\n if (typeof config.kernelSize !== 'number' &&\n !generic_utils.checkArrayTypeAndLength(\n config.kernelSize, 'number', 1, 1))\n throw new ValueError(\n `Conv1D expects config.kernelSize to be number or number[] with ` +\n `length 1, but received ${JSON.stringify(config.kernelSize)}.`);\n }\n}\nserialization.SerializationMap.register(Conv1D);\n\nexport interface Cropping2DLayerConfig extends LayerConfig {\n /**\n * Dimension of the cropping along the width and the height.\n * - If integer: the same symmetric cropping\n * is applied to width and height.\n * - If list of 2 integers:\n * interpreted as two different\n * symmetric cropping values for height and width:\n * `[symmetric_height_crop, symmetric_width_crop]`.\n * - If a list of 2 list of 2 integers:\n * interpreted as\n * `[[top_crop, bottom_crop], [left_crop, right_crop]]`\n */\n cropping: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `channels_last` corresponds to inputs with shape\n * `(batch, ..., channels)`\n *\n * `channels_first` corresponds to inputs with shape `(batch, channels,\n * ...)`.\n *\n * Defaults to `channels_last`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Cropping layer for 2D input (e.g., image).\n *\n * This layer can crop an input\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, croppedRows, croppedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, croppedRows, croppedCols]`.\n *\n * Examples\n * ```js\n *\n * const model = tf.sequential();\n * model.add(tf.layers.cropping2D({cropping:[[2, 2], [2, 2]],\n * inputShape: [128, 128, 3]}));\n * //now output shape is [batch, 124, 124, 3]\n * ```\n */\nexport class Cropping2D extends Layer {\n static className = 'Cropping2D';\n protected readonly cropping: [[number, number], [number, number]];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Cropping2DLayerConfig) {\n super(config);\n if (typeof config.cropping === 'number')\n this.cropping = [\n [config.cropping, config.cropping], [config.cropping, config.cropping]\n ];\n else if (typeof config.cropping[0] === 'number')\n this.cropping = [\n [config.cropping[0] as number, config.cropping[0] as number],\n [config.cropping[1] as number, config.cropping[1] as number]\n ];\n else\n this.cropping = config.cropping as [[number, number], [number, number]];\n this.dataFormat =\n config.dataFormat === undefined ? 'channelsLast' : config.dataFormat;\n this.inputSpec = [{ndim: 4}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst')\n return [\n inputShape[0], inputShape[1],\n inputShape[2] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1]\n ];\n else\n return [\n inputShape[0],\n inputShape[1] - this.cropping[0][0] - this.cropping[0][1],\n inputShape[2] - this.cropping[1][0] - this.cropping[1][1], inputShape[3]\n ];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n\n if (this.dataFormat === 'channelsLast') {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[1] - this.cropping[0][0] - this.cropping[0][1], 2);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[2] - this.cropping[1][1] - this.cropping[1][0], 3);\n } else {\n const hSliced = K.sliceAlongAxis(\n inputs, this.cropping[0][0],\n inputs.shape[2] - this.cropping[0][0] - this.cropping[0][1], 3);\n return K.sliceAlongAxis(\n hSliced, this.cropping[1][0],\n inputs.shape[3] - this.cropping[1][1] - this.cropping[1][0], 4);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {cropping: this.cropping, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Cropping2D);\n\nexport interface UpSampling2DLayerConfig extends LayerConfig {\n /**\n * The upsampling factors for rows and columns.\n *\n * Defaults to `[2, 2]`.\n */\n size?: number[];\n /**\n * Format of the data, which determines the ordering of the dimensions in\n * the inputs.\n *\n * `\"channelsLast\"` corresponds to inputs with shape\n * `[batch, ..., channels]`\n *\n * `\"channelsFirst\"` corresponds to inputs with shape `[batch, channels,\n * ...]`.\n *\n * Defaults to `\"channelsLast\"`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Upsampling layer for 2D inputs.\n *\n * Repeats the rows and columns of the data\n * by size[0] and size[1] respectively.\n *\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, rows, cols]`\n *\n * Output shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, upsampledRows, upsampledCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, upsampledRows, upsampledCols]`\n *\n */\nexport class UpSampling2D extends Layer {\n static className = 'UpSampling2D';\n protected readonly DEFAULT_SIZE = [2, 2];\n protected readonly size: number[];\n protected readonly dataFormat: DataFormat;\n\n constructor(config: UpSampling2DLayerConfig) {\n super(config);\n this.inputSpec = [{ndim: 4}];\n this.size = config.size == null ? this.DEFAULT_SIZE : config.size;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n if (this.dataFormat === 'channelsFirst') {\n const height =\n inputShape[2] == null ? null : this.size[0] * inputShape[2];\n const width = inputShape[3] == null ? null : this.size[1] * inputShape[3];\n return [inputShape[0], inputShape[1], height, width];\n } else {\n const height =\n inputShape[1] == null ? null : this.size[0] * inputShape[1];\n const width = inputShape[2] == null ? null : this.size[1] * inputShape[2];\n return [inputShape[0], height, width, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tfc.tidy(() => {\n let input = getExactlyOneTensor(inputs) as Tensor4D;\n const inputShape = input.shape;\n\n if (this.dataFormat === 'channelsFirst') {\n input = tfc.transpose(input, [0, 2, 3, 1]);\n const height = this.size[0] * inputShape[2];\n const width = this.size[1] * inputShape[3];\n const resized = input.resizeNearestNeighbor([height, width]);\n return tfc.transpose(resized, [0, 3, 1, 2]);\n } else {\n const height = this.size[0] * inputShape[1];\n const width = this.size[1] * inputShape[2];\n return input.resizeNearestNeighbor([height, width]);\n }\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {size: this.size, dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(UpSampling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Depthwise Convolutional Layers\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, DataFormat} from '../common';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {BaseConv, BaseConvLayerConfig, ConvLayerConfig, preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D convolution with separable filters.\n * @param x Input tensor.\n * @param depthwiseKernel Convolution kernel for depthwise convolution.\n * @param strides Strides (Array of two integers).\n * @param padding Padding model.\n * @param dataFormat Data format.\n * @param dilationRate Array of two integers, dilation rates for the separable\n * convolution.\n * @returns Output tensor.\n * @throws ValueError If depthwiseKernel is not a 4D array.\n */\nexport function depthwiseConv2d(\n x: Tensor, depthwiseKernel: Tensor, strides: [number, number] = [1, 1],\n padding = 'valid', dataFormat?: DataFormat,\n dilationRate?: [number, number]): Tensor {\n return tidy(() => {\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n checkDataFormat(dataFormat);\n let y = preprocessConv2DInput(x, dataFormat);\n if (x.rank !== 4) {\n throw new ValueError(\n `Input for depthwiseConv2d is required to be 4-D, but is instead ` +\n `${x.rank}-D`);\n }\n if (depthwiseKernel.rank !== 4) {\n throw new ValueError(\n `depthwiseKernel is required to be 4-D, but is instead ` +\n `${depthwiseKernel.rank}-D`);\n }\n y = tfc.depthwiseConv2d(\n y as Tensor4D, depthwiseKernel as Tensor4D, strides,\n padding === 'same' ? 'same' : 'valid', 'NHWC', dilationRate);\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]);\n }\n return y;\n });\n}\n\nexport interface DepthwiseConv2DLayerConfig extends BaseConvLayerConfig {\n /**\n * An integer or Array of 2 integers, specifying the width and height of the\n * 2D convolution window. Can be a single integer to specify the same value\n * for all spatial dimensions.\n */\n kernelSize: number|[number, number];\n\n /**\n * The number of depthwise convolution output channels for each input\n * channel.\n * The total number of depthwise convolution output channels will be equal to\n * `filtersIn * depthMultiplier`.\n * Default: 1.\n */\n depthMultiplier?: number;\n\n /**\n * Initializer for the depthwise kernel matrix.\n * Default: GlorotNormal.\n */\n depthwiseInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the depthwise kernel matrix.\n */\n depthwiseConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regulzarizer function for the depthwise kernel matrix.\n */\n depthwiseRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Depthwise separable 2D convolution.\n *\n * Depthwise Separable convolutions consists in performing just the first step\n * in a depthwise spatial convolution (which acts on each input channel\n * separately). The `depthMultplier` argument controls how many output channels\n * are generated per input channel in the depthwise step.\n */\nexport class DepthwiseConv2D extends BaseConv {\n static className = 'DepthwiseConv2D';\n private readonly depthMultiplier: number;\n private readonly depthwiseInitializer: Initializer;\n private readonly depthwiseConstraint: Constraint;\n private readonly depthwiseRegularizer: Regularizer;\n\n private depthwiseKernel: LayerVariable = null;\n\n constructor(config: DepthwiseConv2DLayerConfig) {\n super(2, config as ConvLayerConfig);\n this.depthMultiplier =\n config.depthMultiplier == null ? 1 : config.depthMultiplier;\n this.depthwiseInitializer = getInitializer(\n config.depthwiseInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.depthwiseConstraint = getConstraint(config.depthwiseConstraint);\n this.depthwiseRegularizer = getRegularizer(config.depthwiseRegularizer);\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 4) {\n throw new ValueError(\n `Inputs to DepthwiseConv2D should have rank 4. ` +\n `Received input shape: ${JSON.stringify(inputShape)}.`);\n }\n const channelAxis = this.dataFormat === 'channelsFirst' ? 1 : 3;\n if (inputShape[channelAxis] == null || inputShape[channelAxis] < 0) {\n throw new ValueError(\n 'The channel dimension of the inputs to DepthwiseConv2D should ' +\n `be defined, but is not (${inputShape[channelAxis]}).`);\n }\n const inputDim = inputShape[channelAxis];\n const depthwiseKernelShape: Shape = [\n this.kernelSize[0], this.kernelSize[1], inputDim, this.depthMultiplier\n ];\n\n this.depthwiseKernel = this.addWeight(\n 'depthwise_kernel', depthwiseKernelShape, null,\n this.depthwiseInitializer, this.depthwiseRegularizer, true,\n this.depthwiseConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [inputDim * this.depthMultiplier], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n let outputs = depthwiseConv2d(\n inputs, this.depthwiseKernel.read(), this.strides as [number, number],\n this.padding, this.dataFormat, null);\n // TODO(cais): Add support for dilation.\n if (this.useBias) {\n outputs = K.biasAdd(outputs, this.bias.read(), this.dataFormat);\n }\n if (this.activation != null) {\n outputs = this.activation.apply(outputs);\n }\n return outputs;\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n const cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n const outFilters = this.dataFormat === 'channelsFirst' ?\n inputShape[1] * this.depthMultiplier :\n inputShape[3] * this.depthMultiplier;\n const outRows = convOutputLength(\n rows, this.kernelSize[0], this.padding, this.strides[0]);\n const outCols = convOutputLength(\n cols, this.kernelSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], outFilters, outRows, outCols];\n } else {\n // In this case, assume 'channelsLast'.\n return [inputShape[0], outRows, outCols, outFilters];\n }\n }\n\n getConfig(): serialization.ConfigDict {\n const config = super.getConfig();\n config['depthMultiplier'] = this.depthMultiplier;\n config['depthwiseInitializer'] =\n serializeInitializer(this.depthwiseInitializer);\n config['depthwiseRegularizer'] =\n serializeRegularizer(this.depthwiseRegularizer);\n config['depthwiseConstraint'] =\n serializeConstraint(this.depthwiseRegularizer);\n return config;\n }\n}\nserialization.SerializationMap.register(DepthwiseConv2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Basic Layers.\n */\n\nimport {Scalar, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport {Activation as ActivationFn, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface DropoutLayerConfig extends LayerConfig {\n /** Float between 0 and 1. Fraction of the input units to drop. */\n rate: number;\n\n /**\n * Integer array representing the shape of the binary dropout mask that will\n * be multiplied with the input.\n *\n * For instance, if your inputs have shape `(batchSize, timesteps, features)`\n * and you want the dropout mask to be the same for all timesteps, you can use\n * `noise_shape=(batch_size, 1, features)`.\n */\n noiseShape?: number[];\n\n /** An integer to use as random seed. */\n seed?: number;\n}\n\n/**\n * Applies\n * [dropout](http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf) to\n * the input.\n *\n * Dropout consists in randomly setting a fraction `rate` of input units to 0 at\n * each update during training time, which helps prevent overfitting.\n */\nexport class Dropout extends Layer {\n static className = 'Dropout';\n private readonly rate: number;\n private readonly rateScalar: Scalar;\n private readonly noiseShape: number[];\n private readonly seed: number;\n\n constructor(config: DropoutLayerConfig) {\n super(config);\n this.rate = Math.max(Math.min(config.rate, 1), 0);\n this.rateScalar = getScalar(this.rate);\n // So that the scalar doesn't get tidied up between executions.\n this.noiseShape = config.noiseShape;\n this.seed = config.seed;\n if (this.seed != null) {\n throw new NotImplementedError(\n 'Non-default seed is not implemented in Dropout layer yet: ' +\n this.seed);\n }\n this.supportsMasking = true;\n }\n\n private getNoiseShape(input: Tensor): Shape {\n if (this.noiseShape == null) {\n return this.noiseShape;\n }\n const inputShape = input.shape;\n const noiseShape: Shape = [];\n for (let i = 0; i < this.noiseShape.length; ++i) {\n noiseShape.push(\n this.noiseShape[i] == null ? inputShape[i] : this.noiseShape[i]);\n }\n return noiseShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n if (this.noiseShape != null &&\n !util.arraysEqual(input.shape, this.noiseShape)) {\n throw new NotImplementedError(\n 'Non-default noise shape is not implemented in Dropout ' +\n 'layer yet: ' + JSON.stringify(this.noiseShape));\n }\n if (0 < this.rate && this.rate < 1) {\n const training =\n kwargs['training'] == null ? false : kwargs['training'];\n const noiseShape = this.getNoiseShape(input);\n const output =\n K.inTrainPhase(\n () => K.dropout(input, this.rateScalar, noiseShape, this.seed),\n () => input, training) as Tensor;\n return output;\n }\n return inputs;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n rate: this.rate,\n noiseShape: this.noiseShape,\n seed: this.seed,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dropout);\n\nexport interface DenseLayerConfig extends LayerConfig {\n /** Positive integer, dimensionality of the output space. */\n units: number;\n /**\n * Activation function to use.\n *\n * If unspecified, no activation is applied.\n */\n activation?: ActivationIdentifier;\n /** Whether to apply a bias. */\n useBias?: boolean;\n /**\n * Initializer for the dense kernel weights matrix.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n /**\n * If specified, defines inputShape as `[inputDim]`.\n */\n inputDim?: number;\n\n /**\n * Constraint for the kernel weights.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer function applied to the dense kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n/**\n * Creates a dense (fully connected) layer.\n *\n * This layer implements the operation:\n * `output = activation(dot(input, kernel) + bias)`\n *\n * `activation` is the element-wise activation function\n * passed as the `activation` argument.\n *\n * `kernel` is a weights matrix created by the layer.\n *\n * `bias` is a bias vector created by the layer (only applicable if `useBias`\n * is `true`).\n *\n * **Input shape:**\n *\n * nD `Tensor` with shape: `(batchSize, ..., inputDim)`.\n *\n * The most common situation would be\n * a 2D input with shape `(batchSize, inputDim)`.\n *\n * **Output shape:**\n *\n * nD tensor with shape: `(batchSize, ..., units)`.\n *\n * For instance, for a 2D input with shape `(batchSize, inputDim)`,\n * the output would have shape `(batchSize, units)`.\n *\n * Note: if the input to the layer has a rank greater than 2, then it is\n * flattened prior to the initial dot product with the kernel.\n */\nexport class Dense extends Layer {\n static className = 'Dense';\n private units: number;\n // Default activation: Linear (none).\n private activation: ActivationFn = null;\n private useBias = true;\n private kernelInitializer: Initializer;\n private biasInitializer: Initializer;\n private kernel: LayerVariable = null;\n private bias: LayerVariable = null;\n\n readonly DEFAULT_KERNEL_INITIALIZER: InitializerIdentifier = 'glorotNormal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n private readonly kernelConstraint?: Constraint;\n private readonly biasConstraint?: Constraint;\n private readonly kernelRegularizer?: Regularizer;\n private readonly biasRegularizer?: Regularizer;\n\n constructor(config: DenseLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null &&\n config.inputDim != null) {\n // This logic is copied from Layer's constructor, since we can't\n // do exactly what the Python constructor does for Dense().\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n this.batchInputShape = [batchSize, config.inputDim];\n }\n\n this.units = config.units;\n this.activation = getActivation(config.activation);\n if (config.useBias != null) {\n this.useBias = config.useBias;\n }\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n\n this.inputSpec = [{minNDim: 2}];\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputLastDim = inputShape[inputShape.length - 1];\n if (this.kernel == null) {\n this.kernel = this.addWeight(\n 'kernel', [inputLastDim, this.units], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n }\n }\n\n this.inputSpec = [{minNDim: 2, axes: {[-1]: inputLastDim}}];\n this.built = true;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const outputShape = inputShape.slice();\n outputShape[outputShape.length - 1] = this.units;\n return outputShape;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Dense layer accepts only a single input.\n const input = getExactlyOneTensor(inputs);\n let output = K.dot(input, this.kernel.read());\n if (this.bias != null) {\n output = K.biasAdd(output, this.bias.read());\n }\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n return output;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Dense);\n\n/**\n * Flattens the input. Does not affect the batch size.\n *\n * A `Flatten` layer flattens each batch in its inputs to 1D (making the output\n * 2D).\n *\n * For example:\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const flattenLayer = tf.layers.flatten();\n * // Inspect the inferred output shape of the flatten layer, which\n * // equals `[null, 12]`. The 2nd dimension is 4 * 3, i.e., the result of the\n * // flattening. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(flattenLayer.apply(input).shape));\n * ```\n */\nexport class Flatten extends Layer {\n static className = 'Flatten';\n constructor(config?: LayerConfig) {\n super(config || {});\n this.inputSpec = [{minNDim: 3}];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n for (const dim of inputShape.slice(1)) {\n if (dim == null) {\n throw new ValueError(\n `The shape of the input to \"Flatten\" is not fully defined ` +\n `(got ${inputShape.slice(1)}). Make sure to pass a complete ` +\n `\"input_shape\" or \"batch_input_shape\" argument to the first ` +\n `layer in your model.`);\n }\n }\n return [inputShape[0], math_utils.arrayProd(inputShape, 1)];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return K.batchFlatten(getExactlyOneTensor(inputs));\n });\n }\n}\nserialization.SerializationMap.register(Flatten);\n\nexport interface ActivationLayerConfig extends LayerConfig {\n /**\n * Name of the activation function to use.\n */\n activation: ActivationIdentifier;\n}\n\n/**\n * Applies an activation function to an output.\n *\n * This layer applies element-wise activation function. Other layers, notably\n * `dense` can also apply activation functions. Use this isolated activation\n * function to extract the values before and after the\n * activation. For instance:\n *\n * ```js\n * const input = tf.input({shape: [5]});\n * const denseLayer = tf.layers.dense({units: 1});\n * const activationLayer = tf.layers.activation({activation: 'relu6'});\n *\n * // Obtain the output symbolic tensors by applying the layers in order.\n * const denseOutput = denseLayer.apply(input);\n * const activationOutput = activationLayer.apply(denseOutput);\n *\n * // Create the model based on the inputs.\n * const model = tf.model({\n * inputs: input,\n * outputs: [denseOutput, activationOutput]\n * });\n *\n * // Collect both outputs and print separately.\n * const [denseOut, activationOut] = model.predict(tf.randomNormal([6, 5]));\n * denseOut.print();\n * activationOut.print();\n * ```\n *\n */\nexport class Activation extends Layer {\n static className = 'Activation';\n activation: ActivationFn;\n\n constructor(config: ActivationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.activation = getActivation(config.activation);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n return this.activation.apply(input);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {activation: serializeActivation(this.activation)};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Activation);\n\nexport interface ReshapeLayerConfig extends LayerConfig {\n /** The target shape. Does not include the batch axis. */\n targetShape: Shape;\n}\n\nexport interface RepeatVectorLayerConfig extends LayerConfig {\n /**\n * The integer number of times to repeat the input.\n */\n n: number;\n}\n\n/**\n * Repeats the input n times in a new dimension.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.repeatVector({n: 4, inputShape: [2]}));\n * const x = tf.tensor2d([[10, 20]]);\n * // Use the model to do inference on a data point the model hasn't see\n * model.predict(x).print();\n * // output shape is now [batch, 2, 4]\n * ```\n */\nexport class RepeatVector extends Layer {\n static className = 'RepeatVector';\n readonly n: number;\n\n constructor(config: RepeatVectorLayerConfig) {\n super(config);\n this.n = config.n;\n this.inputSpec = [{ndim: 2}];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], this.n, inputShape[1]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = getExactlyOneTensor(inputs);\n return K.repeat(inputs, this.n);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n n: this.n,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RepeatVector);\n\n/**\n * Reshapes an input to a certain shape.\n *\n * ```js\n * const input = tf.input({shape: [4, 3]});\n * const reshapeLayer = tf.layers.reshape({targetShape: [2, 6]});\n * // Inspect the inferred output shape of the Reshape layer, which\n * // equals `[null, 2, 6]`. (The 1st dimension is the undermined batch size.)\n * console.log(JSON.stringify(reshapeLayer.apply(input).shape));\n * ```\n *\n * Input shape:\n * Arbitrary: although all dimensions in the input shape must be fixed.\n * Use the ReshapeLayerConfig field `input_shape` when using this layer\n * as the first layer in a model.\n *\n * Output shape:\n * [batchSize, targetShape[0], targetShape[1], ...,\n * targetShape[targetShape.length - 1]].\n */\nexport class Reshape extends Layer {\n static className = 'Reshape';\n private targetShape: Shape;\n\n constructor(config: ReshapeLayerConfig) {\n super(config);\n this.targetShape = config.targetShape;\n\n // Make sure that all unknown dimensions are represented as `null`.\n for (let i = 0; i < this.targetShape.length; ++i) {\n if (this.isUnknown(this.targetShape[i])) {\n this.targetShape[i] = null;\n }\n }\n }\n\n private isUnknown(dim: number): boolean {\n return dim < 0 || dim == null;\n }\n\n /**\n * Finds and replaces a missing dimension in output shape.\n *\n * This is a near direct port of the internal Numpy function\n * `_fix_unknown_dimension` in `numpy/core/src/multiarray/shape.c`.\n *\n * @param inputShape: Original shape of array begin reshape.\n * @param outputShape: Target shape of the array, with at most a single\n * `null` or negative number, which indicates an underdetermined dimension\n * that should be derived from `inputShape` and the known dimensions of\n * `outputShape`.\n * @returns: The output shape with `null` replaced with its computed value.\n * @throws: ValueError: If `inputShape` and `outputShape` do not match.\n */\n private fixUnknownDimension(inputShape: Shape, outputShape: Shape): Shape {\n const errorMsg = 'Total size of new array must be unchanged.';\n const finalShape = outputShape.slice();\n let known = 1;\n let unknown = null;\n for (let i = 0; i < finalShape.length; ++i) {\n const dim = finalShape[i];\n if (this.isUnknown(dim)) {\n if (unknown === null) {\n unknown = i;\n } else {\n throw new ValueError('Can only specifiy one unknown dimension.');\n }\n } else {\n known *= dim;\n }\n }\n\n const originalSize = math_utils.arrayProd(inputShape);\n if (unknown !== null) {\n if (known === 0 || originalSize % known !== 0) {\n throw new ValueError(errorMsg);\n }\n finalShape[unknown] = originalSize / known;\n } else if (originalSize !== known) {\n throw new ValueError(errorMsg);\n }\n\n return finalShape;\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n let anyUnknownDims = false;\n for (let i = 0; i < inputShape.length; ++i) {\n if (this.isUnknown(inputShape[i])) {\n anyUnknownDims = true;\n break;\n }\n }\n\n if (anyUnknownDims) {\n return inputShape.slice(0, 1).concat(this.targetShape);\n } else {\n return inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const outputShape = inputShape.slice(0, 1).concat(\n this.fixUnknownDimension(inputShape.slice(1), this.targetShape));\n return input.reshape(outputShape);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n targetShape: this.targetShape,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Reshape);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Embedding Layer.\n *\n * Original source: keras/constraints.py\n */\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\n// tslint:disable:max-line-length\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\nexport interface EmbeddingLayerConfig extends LayerConfig {\n /**\n * Integer > 0. Size of the vocabulary, i.e. maximum integer index + 1.\n */\n inputDim: number;\n /**\n * Integer >= 0. Dimension of the dense embedding.\n */\n outputDim: number;\n /**\n * Initializer for the `embeddings` matrix.\n */\n embeddingsInitializer?: InitializerIdentifier|Initializer;\n /**\n * Regularizer function applied to the `embeddings` matrix.\n */\n embeddingsRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Regularizer function applied to the activation.\n */\n activityRegularizer?: RegularizerIdentifier|Regularizer;\n /**\n * Constraint function applied to the `embeddings` matrix.\n */\n embeddingsConstraint?: ConstraintIdentifier|Constraint;\n /**\n * Whether the input value 0 is a special \"padding\" value that should be\n * masked out. This is useful when using recurrent layers which may take\n * variable length input.\n *\n * If this is `True` then all subsequent layers in the model need to support\n * masking or an exception will be raised. If maskZero is set to `True`, as a\n * consequence, index 0 cannot be used in the vocabulary (inputDim should\n * equal size of vocabulary + 1).\n */\n maskZero?: boolean;\n /**\n * Length of input sequences, when it is constant.\n *\n * This argument is required if you are going to connect `flatten` then\n * `dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed).\n */\n inputLength?: number|number[];\n}\n\n/**\n * Maps positive integers (indices) into dense vectors of fixed size.\n * eg. [[4], [20]] -> [[0.25, 0.1], [0.6, -0.2]]\n *\n * **Input shape:** 2D tensor with shape: `[batchSize, sequenceLength]`.\n *\n * **Output shape:** 3D tensor with shape: `[batchSize, sequenceLength,\n * outputDim]`.\n */\nexport class Embedding extends Layer {\n static className = 'Embedding';\n private inputDim: number;\n private outputDim: number;\n private embeddingsInitializer: Initializer;\n private maskZero: boolean;\n private inputLength: number|number[];\n\n private embeddings: LayerVariable = null;\n\n readonly DEFAULT_EMBEDDINGS_INITIALIZER: InitializerIdentifier =\n 'randomUniform';\n private readonly embeddingsRegularizer?: Regularizer;\n private readonly embeddingsConstraint?: Constraint;\n\n constructor(config: EmbeddingLayerConfig) {\n super(config);\n if (config.batchInputShape == null && config.inputShape == null) {\n // Porting Note: This logic is copied from Layer's constructor, since we\n // can't do exactly what the Python constructor does for Embedding().\n // Specifically, the super constructor can not be called after the\n // mutation of the `config` argument.\n let batchSize: number = null;\n if (config.batchSize != null) {\n batchSize = config.batchSize;\n }\n if (config.inputLength == null) {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (None, )\n this.batchInputShape = [batchSize, null];\n } else {\n // Fix super-constructor to what it would have done if\n // 'config.inputShape' were (config.inputLength, )\n this.batchInputShape =\n [batchSize].concat(generic_utils.toList(config.inputLength));\n }\n }\n this.inputDim = config.inputDim;\n this.outputDim = config.outputDim;\n this.embeddingsInitializer = getInitializer(\n config.embeddingsInitializer || this.DEFAULT_EMBEDDINGS_INITIALIZER);\n this.embeddingsRegularizer = getRegularizer(config.embeddingsRegularizer);\n this.activityRegularizer = getRegularizer(config.activityRegularizer);\n this.embeddingsConstraint = getConstraint(config.embeddingsConstraint);\n this.maskZero = config.maskZero;\n this.inputLength = config.inputLength;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n this.embeddings = this.addWeight(\n 'embeddings', [this.inputDim, this.outputDim], this.dtype,\n this.embeddingsInitializer, this.embeddingsRegularizer, true,\n this.embeddingsConstraint);\n this.built = true;\n }\n\n // Override warnOnIncompatibleInputShape because an embedding layer allows\n // the input to have varying ranks.\n protected warnOnIncompatibleInputShape(inputShape: Shape) {}\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for Embedding yet');\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n if (this.inputLength == null) {\n return [...inputShape, this.outputDim];\n }\n // inputLength can be an array if input is 3D or higher.\n const inLens: number[] = generic_utils.toList(this.inputLength);\n if (inLens.length !== inputShape.length - 1) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else {\n let i = 0;\n for (let k = 0; k < inLens.length; ++k) {\n const s1 = inLens[k];\n const s2 = inputShape[k + 1];\n if ((s1 != null) && (s2 != null) && (s1 !== s2)) {\n throw new ValueError(\n `\"inputLength\" is ${this.inputLength}, but received ` +\n `input shape has shape ${inputShape}`);\n } else if (s1 == null) {\n inLens[i] = s2;\n }\n i++;\n }\n }\n return [inputShape[0], ...inLens, this.outputDim];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Embedding layer accepts only a single input.\n let input = getExactlyOneTensor(inputs);\n if (input.dtype !== 'int32') {\n input = K.cast(input, 'int32');\n }\n const output = K.gather(this.embeddings.read(), input.as1D());\n return output.reshape(\n getExactlyOneShape(this.computeOutputShape(input.shape)));\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n inputDim: this.inputDim,\n outputDim: this.outputDim,\n embeddingsInitializer: serializeInitializer(this.embeddingsInitializer),\n embeddingsRegularizer: serializeRegularizer(this.embeddingsRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n embeddingsConstraint: serializeConstraint(this.embeddingsConstraint),\n maskZero: this.maskZero,\n inputLength: this.inputLength\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\nserialization.SerializationMap.register(Embedding);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Merge Layers.\n */\n\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport * as K from '../backend/tfjs_backend';\nimport {Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as mathUtils from '../utils/math_utils';\nimport {getExactlyOneShape} from '../utils/types_utils';\n\n/**\n * Generic Merge layer for element-wise merge functions.\n *\n * Used to implement `Sum`, `Average`, `Concatenate`, etc.\n */\nexport abstract class Merge extends Layer {\n protected reshapeRequired: boolean;\n\n constructor(config?: LayerConfig) {\n super(config || {});\n this.supportsMasking = true;\n }\n\n /**\n * Logic for merging multiple tensors, to be overridden by subclasses.\n * @param inputs\n */\n protected mergeFunction(inputs: Tensor[]): Tensor {\n throw new NotImplementedError();\n }\n\n /**\n * Computes the shape of the result of an elementwise operation.\n *\n * @param shape1: Shape of the first tensor.\n * @param shape2: Shape of the second tensor.\n * @returns Expected output shape when an elementwise operation is carried\n * out on 2 tensors with shapes `shape1` and `shape2`.\n * @throws ValueError: If `shape1` and `shape2` are not compatible for\n * element-wise operations.\n */\n private computeElementwiseOpOutputShape(shape1: Shape, shape2: Shape): Shape {\n if (shape1 == null || shape2 == null) {\n return null;\n } else if (shape1.length < shape2.length) {\n return this.computeElementwiseOpOutputShape(shape2, shape1);\n } else if (shape2.length === 0) {\n return shape1;\n }\n const outputShape: Shape = shape1.slice(0, shape1.length - shape2.length);\n for (let k = 0; k < shape2.length; ++k) {\n const i = shape1[shape1.length - shape2.length + k];\n const j = shape2[k];\n if (i == null || j == null || i < 0 || j < 0) {\n outputShape.push(null);\n } else if (i === 1) {\n outputShape.push(j);\n } else if (j === 1) {\n outputShape.push(i);\n } else {\n if (i !== j) {\n throw new ValueError(\n 'Operands could not be broadcast together with shapes ' +\n JSON.stringify(shape1) + ' ' + JSON.stringify(shape2));\n }\n outputShape.push(i);\n }\n }\n return outputShape;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.\n if (Array.isArray(inputShape) && !Array.isArray(inputShape[0])) {\n // Make sure that inputShape is an Array of shape.\n inputShape = [getExactlyOneShape(inputShape)];\n }\n inputShape = inputShape as Shape[];\n if (inputShape.length < 2) {\n throw new ValueError(\n 'A merge layer should be called on an Array of at least 2 inputs.' +\n ` Got ${inputShape.length} input(s).`);\n }\n\n // Make sure that there is at most one unique batch size among the input\n // shapes.\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length > 1) {\n throw new ValueError(\n `Can not merge tensors with different batch sizes. ` +\n `Got tensors with shapes: ${JSON.stringify(inputShape)}.`);\n }\n\n let outputShape: Shape =\n inputShape[0] == null ? null : inputShape[0].slice(1);\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n // If the inputs have different ranks, we have to reshape them to make them\n // broadcastable.\n const allRanks = inputShape.map(shape => shape.length);\n if (inputShape.indexOf(null) === -1 &&\n generic_utils.unique(allRanks).length === 1) {\n this.reshapeRequired = false;\n } else {\n this.reshapeRequired = true;\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (this.reshapeRequired) {\n const reshapedInputs: Tensor[] = [];\n const inputDims = inputs.map(input => input.rank);\n if (inputDims.indexOf(null) === -1) {\n // If ranks of all inputs are available, we simply expand each of them\n // at axis=1 until all of them have the same rank.\n const maxNDim = mathUtils.max(inputDims);\n for (let x of inputs) {\n const xNDim = x.rank;\n for (let k = 0; k < maxNDim - xNDim; ++k) {\n x = K.expandDims(x, 1);\n }\n reshapedInputs.push(x);\n }\n return this.mergeFunction(reshapedInputs);\n } else {\n // Transpose all inputs so that batch size is the last dimension.\n // [batchSize, dim1, dim2, ...] -> [dim1, dim2, ..., batchSize]\n let transposed = false;\n for (const x of inputs) {\n const xNDim = x.rank;\n if (xNDim == null) {\n const xShape = x.shape;\n const batchSize = xShape[0];\n const newShape = xShape.slice(1).concat([batchSize]);\n let xTransposed = x.reshape(\n [batchSize].concat(mathUtils.arrayProd(xShape.slice(1))));\n xTransposed = tfc.transpose(xTransposed, [1, 0]);\n xTransposed = xTransposed.reshape(newShape);\n reshapedInputs.push(xTransposed);\n transposed = true;\n } else if (xNDim > 1) {\n const dims = mathUtils.range(1, xNDim).concat([0]);\n reshapedInputs.push(tfc.transpose(x, dims));\n transposed = true;\n } else {\n // We don't transpose inputs if they are 1D vectors or scalars.\n reshapedInputs.push(x);\n }\n }\n let y = this.mergeFunction(reshapedInputs);\n const yNDim = y.rank;\n if (transposed) {\n // If inputs have been transposed, we have to transpose the output\n // too.\n if (yNDim == null) {\n const yShape = y.shape;\n const yNDim = yShape.length;\n const batchSize = yShape[yNDim - 1];\n const newShape =\n [batchSize].concat(yShape.slice(0, yShape.length - 1));\n y = tfc.transpose(y.reshape([-1, batchSize]), [1, 0])\n .reshape(newShape);\n } else if (yNDim > 1) {\n const dims = [yNDim - 1].concat(mathUtils.range(0, yNDim - 1));\n y = tfc.transpose(y, dims);\n }\n }\n return y;\n }\n } else {\n return this.mergeFunction(inputs);\n }\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape[];\n let outputShape: Shape;\n if (inputShape[0] == null) {\n outputShape = null;\n } else {\n outputShape = inputShape[0].slice(1);\n }\n for (let i = 1; i < inputShape.length; ++i) {\n const shape = inputShape[i] == null ? null : inputShape[i].slice(1);\n outputShape = this.computeElementwiseOpOutputShape(outputShape, shape);\n }\n\n let batchSizes: number[] = [];\n for (const shape of inputShape) {\n if (shape != null && shape[0] !== null) {\n batchSizes.push(shape[0]);\n }\n }\n batchSizes = generic_utils.unique(batchSizes);\n if (batchSizes.length === 1) {\n outputShape = batchSizes.concat(outputShape);\n } else {\n outputShape = [null].concat(outputShape);\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n}\n\n/**\n * Layer that performs element-wise addition on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). The inputs are specified as an\n * `Array` when the `apply` method of the `Add` layer instance is called. For\n * example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const addLayer = tf.layers.add();\n * const sum = addLayer.apply([input1, input2]);\n * console.log(JSON.stringify(sum.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Add extends Merge {\n static className = 'Add';\n constructor(config?: LayerConfig) {\n super(config as LayerConfig);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Add);\n\n/**\n * Calculate the element-wise sum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Add` layer, by using no input argument\n * or a single configuration argument. The resultant `Add` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const addLayer = tf.layers.add();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = addLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.add([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.add([input1, input2]).print();\n * // Gives [[11, 22], [33, 44]].\n *\n */\nexport function add(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Add({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Add(config);\n }\n}\n\n/**\n * Layer that multiplies (element-wise) an `Array` of inputs.\n *\n * It takes as input an Array of tensors, all of the same\n * shape, and returns a single tensor (also of the same shape).\n * For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const input3 = tf.input({shape: [2, 2]});\n * const multiplyLayer = tf.layers.multiply();\n * const product = multiplyLayer.apply([input1, input2, input3]);\n * console.log(product.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n */\nexport class Multiply extends Merge {\n static className = 'Multiply';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.ones(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.mul(output, input);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Multiply);\n\n/**\n * Calculate the element-wise product of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Multiply` layer, by using no input argument\n * or a single configuration argument. The resultant `Multiply` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const multiplyLayer = tf.layers.multiply();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = multiplyLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.multiply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.multiply([input1, input2]).print();\n * // Gives [[10, 40], [90, 160]].\n *\n */\nexport function multiply(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Multiply({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Multiply(config);\n }\n}\n\n/**\n * Layer that performs element-wise averaging on an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape, and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const averageLayer = tf.layers.average();\n * const average = averageLayer.apply([input1, input2]);\n * console.log(JSON.stringify(average.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Average extends Merge {\n static className = 'Average';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = tfc.zeros(inputs[0].shape);\n for (const input of inputs) {\n output = tfc.add(output, input);\n }\n return tfc.mul(getScalar(1 / inputs.length), output);\n });\n }\n}\nserialization.SerializationMap.register(Average);\n\n/**\n * Calculate the element-wise arithmetic mean of inputs, which all have the same\n * shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Average` layer, by using no input argument\n * or a single configuration argument. The resultant `Average` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const averageLayer = tf.layers.average();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = averageLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.average([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n * const input2 = tf.tensor2d([10, 20, 30, 40], [2, 2]);\n * tf.layers.average([input1, input2]).print();\n * // Gives [[5.5, 11], [16.5, 22]].\n *\n */\nexport function average(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Average({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Average(config);\n }\n}\n\n/**\n * Layer that computes the element-wise maximum an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const maxLayer = tf.layers.maximum();\n * const max = maxLayer.apply([input1, input2]);\n * console.log(JSON.stringify(max.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Maximum extends Merge {\n static className = 'Maximum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.maximum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Maximum);\n\n/**\n * Calculate the element-wise maximum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Maximum` layer, by using no input argument\n * or a single configuration argument. The resultant `Maximum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const maximumLayer = tf.layers.maximum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = maximumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.maximum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.maximum([input1, input2]).print();\n * // Gives [[10, 20], [30, 40]].\n *\n */\nexport function maximum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Maximum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Maximum(config);\n }\n}\n\n/**\n * Layer that computes the element-wise minimum of an `Array` of inputs.\n *\n * It takes as input a list of tensors, all of the same shape and returns a\n * single tensor (also of the same shape). For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const minLayer = tf.layers.minimum();\n * const min = minLayer.apply([input1, input2]);\n * console.log(JSON.stringify(min.shape));\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n */\nexport class Minimum extends Merge {\n static className = 'Minimum';\n constructor(config?: LayerConfig) {\n super(config);\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n let output = inputs[0];\n for (let i = 1; i < inputs.length; ++i) {\n output = tfc.minimum(output, inputs[i]);\n }\n return output;\n });\n }\n}\nserialization.SerializationMap.register(Minimum);\n\n/**\n * Calculate the element-wise minimum of inputs, which all have the same shape.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Minimum` layer, by using no input argument\n * or a single configuration argument. The resultant `Minimum` layer can then\n * be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const minimumLayer = tf.layers.minimum();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = minimumLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 2]});\n * const output = tf.layers.minimum([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([1, 20, 3, 40], [2, 2]);\n * const input2 = tf.tensor2d([10, 2, 30, 4], [2, 2]);\n * tf.layers.minimum([input1, input2]).print();\n * // Gives [[1, 2], [3, 4]].\n *\n */\nexport function minimum(config?: SymbolicTensor[]|Tensor[]|LayerConfig): Layer|\n SymbolicTensor|Tensor {\n if (Array.isArray(config)) {\n const layer = new Minimum({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Minimum(config);\n }\n}\n\nexport interface ConcatenateLayerConfig extends LayerConfig {\n /**\n * Axis along which to concatenate.\n */\n axis?: number;\n}\n\n/**\n * Layer that concatenates an `Array` of inputs.\n *\n * It takes a list of tensors, all of the same shape except for the\n * concatenation axis, and returns a single tensor, the concatenation\n * of all inputs. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 2]});\n * const input2 = tf.input({shape: [2, 3]});\n * const concatLayer = tf.layers.concatenate();\n * const output = concatLayer.apply([input1, input2]);\n * console.log(JSON.stringify(output.shape));\n * // You get [null, 2, 5], with the first dimension as the undetermined batch\n * // dimension. The last dimension (5) is the result of concatenating the\n * // last dimensions of the inputs (2 and 3).\n * ```\n */\nexport class Concatenate extends Merge {\n static className = 'Concatenate';\n readonly DEFAULT_AXIS = -1;\n private readonly axis: number;\n\n constructor(config?: ConcatenateLayerConfig) {\n super(config);\n if (config == null) {\n config = {};\n }\n this.axis = config.axis == null ? this.DEFAULT_AXIS : config.axis;\n this.supportsMasking = true;\n this.reshapeRequired = false;\n }\n\n build(inputShape: Shape|Shape[]): void {\n // Used purely for shape validation.]\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0])) ||\n inputShape.length === 1) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of at least 2 ' +\n 'inputs');\n }\n inputShape = inputShape as Shape[];\n\n let allNoneShape = true;\n for (const shape of inputShape) {\n if (shape != null) {\n allNoneShape = false;\n break;\n }\n }\n if (allNoneShape) {\n return;\n }\n\n const shapeSet: Shape[] = [];\n for (let i = 0; i < inputShape.length; ++i) {\n const shapeWithoutConcatAxis = inputShape[i].slice();\n shapeWithoutConcatAxis.splice(this.axis, 1);\n let exists = false;\n for (const shape of shapeSet) {\n if (util.arraysEqual(shape, shapeWithoutConcatAxis)) {\n exists = true;\n break;\n }\n }\n if (!exists) {\n shapeSet.push(shapeWithoutConcatAxis);\n }\n }\n if (shapeSet.length > 1) {\n throw new ValueError(\n 'A `Concatenate` layer requires inputs with matching shapes ' +\n 'except for the concat axis. Got input shapes: ' +\n JSON.stringify(inputShape));\n }\n }\n\n protected mergeFunction(inputs: Tensor[]): Tensor {\n return tidy(() => {\n return K.concatenate(inputs, this.axis);\n });\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (!(Array.isArray(inputShape) && Array.isArray(inputShape[0]))) {\n throw new ValueError(\n 'A `Concatenate` layer should be called on a list of inputs.');\n }\n const inputShapes = inputShape as Shape[];\n const outputShape = inputShapes[0].slice();\n const axis = this.axis < 0 ? outputShape.length + this.axis : this.axis;\n // Porting Note: the line above is because TypeScript doesn't support\n // negative indices.\n for (const shape of inputShapes.slice(1)) {\n if (outputShape[axis] == null || shape[axis] == null) {\n outputShape[axis] = null;\n break;\n }\n outputShape[axis] += shape[axis];\n }\n return outputShape;\n }\n\n // TODO(cais): Implement computeMask();\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'axis': this.axis,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(Concatenate);\n\n/**\n * Concatenate an `Array` of inputs.\n *\n * This function can be invoked in three ways.\n *\n * 1. Construct an instance of `Concatenate` layer, by using no input argument\n * or a single configuration argument. The resultant `Concatenate` layer can\n * then be used on `SymbolicTensor`s or `Tensor`s. For example:\n *\n * ```js\n * const concatLayer = tf.layers.concatenate();\n *\n * // The layer can be applied to inputs.\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = concatLayer.apply([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 7], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 2. Invoke directly on an `Array` of `SymbolicTensor`s. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `SymbolicTensor`. For example:\n *\n * ```js\n * const input1 = tf.input({shape: [2, 3]});\n * const input2 = tf.input({shape: [2, 4]});\n * const output = tf.layers.concatenate([input1, input2]);\n * console.log(output.shape);\n * // You get [null, 2, 2], with the first dimension as the undetermined batch\n * // dimension and the last dimension as the result of concatenating the\n * // last dimensions of the two inputs.\n * ```\n *\n * 3. Invoke directly on `Tensor`s, i.e., concrete values. This constructs\n * an `Layer` object internally and calls its `apply` method on the inputs,\n * generating a new `Tensor` as the result of the computation. For example:\n *\n * ```js\n * const input1 = tf.tensor2d([[1, 2], [3, 4]], [2, 2]);\n * const input2 = tf.tensor2d([[10, 20], [30, 40]], [2, 2]);\n * tf.layers.concatenate([input1, input2]).print();\n * // Gives [[1, 2, 10, 20], [3, 4, 30, 40]].\n *\n */\nexport function concatenate(config?: SymbolicTensor[]|Tensor[]|\n ConcatenateLayerConfig): Layer|SymbolicTensor|\n Tensor {\n if (Array.isArray(config)) {\n const layer = new Concatenate({});\n return layer.apply(config as SymbolicTensor[] | Tensor[]) as\n SymbolicTensor |\n Tensor;\n } else {\n return new Concatenate(config);\n }\n}\n\n// TODO(cais): Add class Dot.\n\n// TODO(cais): Add functional interfaces for the merge layers.\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Normalization layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor1D, Tensor2D, Tensor3D, Tensor4D, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {getScalar} from '../backend/state';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, Shape} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\n// tslint:enable:max-line-length\n\n/**\n * Applies batch normalization on x given mean, var, beta and gamma.\n *\n * I.e. returns:\n * `output = (x - mean) / (sqrt(var) + epsilon) * gamma + beta`\n *\n * @param x Input tensor.\n * @param mean Mean of batch.\n * @param variance Variance of batch.\n * @param beta Tensor with which to center the input.\n * @param gamma Tensor by which to scale the input.\n * @param epsilon Fuzz factor.\n * @returns The result of the batch normalization.\n */\nexport function batchNormalization(\n x: Tensor, mean: Tensor, variance: Tensor, beta?: Tensor, gamma?: Tensor,\n epsilon = 1e-3): Tensor {\n let out: Tensor;\n if (x.rank === 2) {\n out = tfc.batchNormalization2d(\n x as Tensor2D, mean as Tensor2D | Tensor1D,\n variance as Tensor2D | Tensor1D, epsilon, gamma as Tensor2D | Tensor1D,\n beta as Tensor2D | Tensor1D);\n } else if (x.rank === 3) {\n // TODO(cais): Check rank; give proper error message.\n out = tfc.batchNormalization3d(\n x as Tensor3D, mean as Tensor3D | Tensor1D,\n variance as Tensor3D | Tensor1D, epsilon, gamma as Tensor3D | Tensor1D,\n beta as Tensor3D | Tensor1D);\n } else if (x.rank === 4) {\n out = tfc.batchNormalization4d(\n x as Tensor4D, mean as Tensor4D | Tensor1D,\n variance as Tensor4D | Tensor1D, epsilon, gamma as Tensor4D | Tensor1D,\n beta as Tensor4D | Tensor1D);\n } else {\n throw new NotImplementedError(\n `batchNormalization is not implememnted for array of rank ${x.rank} ` +\n `yet`);\n }\n return out;\n}\n\n/**\n * Non-broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction regularNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const normed =\n batchNormalization(x, mean, variance, beta, gamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Broadcasting batch normalization for use in training (not inference).\n *\n * The input is normalized to zero mean and unit variance along the\n * `reductionAxes`, followed by scaling with `gamma` and shifted by `beta`.\n * The result of that is returned as the first element\n * of the returned `Array`. The other two elements are the mean and variance,\n * respectively.\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nfunction broadcastNormalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n return tidy(() => {\n const meanAndVariance = tfc.moments(x, reductionAxes);\n const mean = meanAndVariance.mean;\n const variance = meanAndVariance.variance;\n const targetShape: number[] = [];\n for (const axis of math_utils.range(0, x.rank)) {\n if (reductionAxes.indexOf(axis) !== -1) {\n targetShape.push(1);\n } else {\n targetShape.push(x.shape[axis]);\n }\n }\n const broadcastMean = mean.reshape(targetShape);\n const broadcastVariance = variance.reshape(targetShape);\n const broadcastGamma =\n gamma == null ? null : gamma.reshape(targetShape);\n const broadcastBeta =\n beta == null ? null : beta.reshape(targetShape);\n const normed = batchNormalization(\n x, broadcastMean, broadcastVariance, broadcastBeta,\n broadcastGamma, epsilon);\n return [normed, mean, variance];\n }) as [Tensor, Tensor, Tensor];\n}\n\n/**\n * Batch normalization for use in training (not inference).\n *\n * @param x Input tensor to be normalized.\n * @param gamma Tensor by which to scale the input.\n * @param beta Tensor by which to center the input.\n * @param reductionAxes Axes over which to normalize.\n * @param epsilon Fuzz factor.\n * @returns An `Array` of three `Tensors`:\n * [normalized tensor, mean of input, variance of input].\n */\nexport function normalizeBatchInTraining(\n x: Tensor, gamma: Tensor, beta: Tensor, reductionAxes: number[],\n epsilon = 1e-3): [Tensor, Tensor, Tensor] {\n if (util.arraysEqual(\n reductionAxes.slice().sort(), math_utils.range(0, x.rank - 1))) {\n return regularNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n } else {\n return broadcastNormalizeBatchInTraining(\n x, gamma, beta, reductionAxes, epsilon);\n }\n}\n\nexport interface BatchNormalizationLayerConfig extends LayerConfig {\n /**\n * The integer axis that should be normalized (typically the features axis).\n * Defaults to -1.\n *\n * For instance, after a `Conv2D` layer with `data_format=\"channels_first\"`,\n * set `axis=1` in `batchNormalization`.\n */\n axis?: number;\n\n /**\n * Momentum of the moving average. Defaults to 0.99.\n */\n momentum?: number;\n\n /**\n * Small float added to the variance to avoid dividing by zero. Defaults to\n * 1e-3.\n */\n epsilon?: number;\n\n /**\n * If `true`, add offset of `beta` to normalized tensor.\n * If `false`, `beta` is ignored.\n * Defaults to `true`.\n */\n center?: boolean;\n\n /**\n * If `true`, multiply by `gamma`.\n * If `false`, `gamma` is not used.\n * When the next layer is linear (also e.g. `nn.relu`),\n * this can be disabled since the scaling will be done by the next layer.\n * Defaults to `true`.\n */\n scale?: boolean;\n\n /**\n * Initializer for the beta weight.\n * Defaults to 'zeros'.\n */\n betaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the gamma weight.\n * Defaults to `ones`.\n */\n gammaInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving mean.\n * Defaults to `zeros`\n */\n movingMeanInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the moving variance.\n * Defaults to 'Ones'.\n */\n movingVarianceInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Constraint for the beta weight.\n */\n betaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint for gamma weight.\n */\n gammaConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Regularizer for the beta weight.\n */\n betaRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer for the gamma weight.\n */\n gammaRegularizer?: RegularizerIdentifier|Regularizer;\n}\n\n\n/**\n * Batch normalization layer (Ioffe and Szegedy, 2014).\n *\n * Normalize the activations of the previous layer at each batch,\n * i.e. applies a transformation that maintains the mean activation\n * close to 0 and the activation standard deviation close to 1.\n *\n * Input shape:\n * Arbitrary. Use the keyword argument `inputShape` (Array of integers, does\n * not include the sample axis) when calling the constructor of this class,\n * if this layer is used as a first layer in a model.\n *\n * Output shape:\n * Same shape as input.\n *\n * References:\n * - [Batch Normalization: Accelerating Deep Network Training by Reducing\n * Internal Covariate Shift](https://arxiv.org/abs/1502.03167)\n */\nexport class BatchNormalization extends Layer {\n static className = 'BatchNormalization';\n private readonly axis: number;\n private readonly momentum: number;\n private readonly epsilon: number;\n private readonly center: boolean;\n private readonly scale: boolean;\n private readonly betaInitializer: Initializer;\n private readonly gammaInitializer: Initializer;\n private readonly movingMeanInitializer: Initializer;\n private readonly movingVarianceInitializer: Initializer;\n private readonly betaConstraint: Constraint;\n private readonly gammaConstraint: Constraint;\n private readonly betaRegularizer: Regularizer;\n private readonly gammaRegularizer: Regularizer;\n private gamma: LayerVariable;\n private beta: LayerVariable;\n private movingMean: LayerVariable;\n private movingVariance: LayerVariable;\n private stepCount: number;\n\n constructor(config: BatchNormalizationLayerConfig) {\n super(config);\n this.supportsMasking = true;\n this.axis = config.axis == null ? -1 : config.axis;\n this.momentum = config.momentum == null ? 0.99 : config.momentum;\n this.epsilon = config.epsilon == null ? 1e-3 : config.epsilon;\n this.center = config.center == null ? true : config.center;\n this.scale = config.scale == null ? true : config.scale;\n this.betaInitializer = getInitializer(config.betaInitializer || 'zeros');\n this.gammaInitializer = getInitializer(config.gammaInitializer || 'ones');\n this.movingMeanInitializer =\n getInitializer(config.movingMeanInitializer || 'zeros');\n this.movingVarianceInitializer =\n getInitializer(config.movingVarianceInitializer || 'ones');\n this.betaConstraint = getConstraint(config.betaConstraint);\n this.gammaConstraint = getConstraint(config.gammaConstraint);\n this.betaRegularizer = getRegularizer(config.betaRegularizer);\n this.gammaRegularizer = getRegularizer(config.gammaRegularizer);\n this.stepCount = 0;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const axis = this.axis >= 0 ? this.axis : (this.axis + inputShape.length);\n const dim = inputShape[axis];\n if (dim == null) {\n throw new ValueError(\n `Axis ${axis} of input tensor should have a defined dimension but ` +\n `the layer received an input with shape ` +\n `${JSON.stringify(inputShape)}.`);\n }\n this.inputSpec =\n [new InputSpec({ndim: inputShape.length, axes: {[axis]: dim}})];\n const shape = [dim];\n if (this.scale) {\n this.gamma = this.addWeight(\n 'gamma', shape, null, this.gammaInitializer, this.gammaRegularizer,\n true, this.gammaConstraint);\n }\n if (this.center) {\n this.beta = this.addWeight(\n 'beta', shape, null, this.betaInitializer, this.betaRegularizer, true,\n this.betaConstraint);\n }\n this.movingMean = this.addWeight(\n 'moving_mean', shape, null, this.movingMeanInitializer, null, false);\n this.movingVariance = this.addWeight(\n 'moving_variance', shape, null, this.movingVarianceInitializer, null,\n false);\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n const input = getExactlyOneTensor(inputs);\n const inputShape = input.shape;\n const ndim = inputShape.length;\n const reductionAxes = math_utils.range(0, ndim);\n const axis = this.axis >= 0 ? this.axis : (this.axis + ndim);\n reductionAxes.splice(axis, 1);\n const broadcastShape = generic_utils.pyListRepeat(1, ndim);\n broadcastShape[axis] = inputShape[axis];\n\n const sortedReductionAxes = reductionAxes.slice();\n sortedReductionAxes.sort();\n const needsBroadcasting = !util.arraysEqual(\n sortedReductionAxes, math_utils.range(0, ndim).slice(0, ndim - 1));\n\n const normalizeInference: () => Tensor = () => {\n if (needsBroadcasting) {\n const broadcastMovingMean =\n this.movingMean.read().reshape(broadcastShape);\n const broadcastMovingVariance =\n this.movingVariance.read().reshape(broadcastShape);\n const broadcastBeta =\n this.center ? this.beta.read().reshape(broadcastShape) : null;\n const broadcastGamma =\n this.scale ? this.gamma.read().reshape(broadcastShape) : null;\n return batchNormalization(\n input, broadcastMovingMean, broadcastMovingVariance,\n broadcastBeta, broadcastGamma, this.epsilon);\n } else {\n return batchNormalization(\n input, this.movingMean.read(), this.movingVariance.read(),\n this.beta == null ? null : this.beta.read(),\n this.gamma == null ? null : this.gamma.read(), this.epsilon);\n }\n };\n\n if (!training) {\n return normalizeInference();\n }\n\n const [normedTraining, mean, variance] = normalizeBatchInTraining(\n input, this.gamma.read(), this.beta.read(), reductionAxes,\n this.epsilon);\n\n // Debias variance.\n const sampleSize =\n math_utils.arrayProd(reductionAxes.map(axis => input.shape[axis]));\n const varianceDebiased = variance.mul(\n getScalar(sampleSize / (sampleSize - (1 + this.epsilon))));\n\n // Perform updates to moving mean and moving variance for training.\n // Porting Note: In PyKeras, these updates to `movingMean` and\n // `movingAverage` are done as a deferred Graph, added to the `Layer`'s\n // `update`s using the `add_update()` method. Here we do it imperatively\n // and encapsulate the updates in a function that is invoked\n // immediately.\n const updateMovingMeanAndVariance = () => {\n this.stepCount++;\n const newMovingMean = tfc.movingAverage(\n this.movingMean.read(), mean, this.momentum, this.stepCount);\n this.movingMean.write(newMovingMean);\n const newMovingVariance = tfc.movingAverage(\n this.movingVariance.read(), varianceDebiased, this.momentum,\n this.stepCount);\n this.movingVariance.write(newMovingVariance);\n };\n updateMovingMeanAndVariance();\n\n return normedTraining;\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n axis: this.axis,\n momentum: this.momentum,\n epsilon: this.epsilon,\n center: this.center,\n scale: this.scale,\n betaInitializer: serializeInitializer(this.betaInitializer),\n gammaInitializer: serializeInitializer(this.gammaInitializer),\n movingMeanInitializer: serializeInitializer(this.movingMeanInitializer),\n movingVarianceInitializer:\n serializeInitializer(this.movingVarianceInitializer),\n betaRegularizer: serializeRegularizer(this.betaRegularizer),\n gammaRegularizer: serializeRegularizer(this.gammaRegularizer),\n betaConstraint: serializeConstraint(this.betaConstraint),\n gammaConstraint: serializeConstraint(this.gammaConstraint)\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(BatchNormalization);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Padding Layers.\n */\n\n// Porting Note: In Python Keras, the padding layers are in convolutional.py,\n// but we decided to put them in a separate file (padding.ts) for clarity.\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport {DataFormat} from '../common';\nimport {InputSpec, Layer, LayerConfig} from '../engine/topology';\nimport {ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\n// tslint:enable:max-line-length\n\n/**\n * Pads the middle dimension of a 3D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of 2 integers, how many zeros to add at the start and\n * end of the middle dimension (i.e., dimension 1).\n * @return A padded 3D `Tensor`.\n */\nexport function temporalPadding(x: Tensor, padding?: [number, number]): Tensor {\n return tidy(() => {\n if (x.rank !== 3) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 3-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [1, 1];\n }\n if (padding.length !== 2) {\n throw new ValueError(\n `temporalPadding expects input padding pattern to be a length-2 ` +\n `array, but received a length-${padding.length} array.`);\n }\n\n const pattern: Array<[number, number]> = [[0, 0], padding, [0, 0]];\n return tfc.pad(x, pattern);\n });\n}\n\n/**\n * Pads the 2nd and 3rd dimensions of a 4D tensor.\n *\n * @param x Input `Tensor` to be padded.\n * @param padding `Array` of two `Array`s, each of which is an `Array` of two\n * integers. The amount of padding at the beginning and end of the 2nd and 3rd\n * dimensions, respectively.\n * @param dataFormat 'channelsLast' (default) or 'channelsFirst'.\n * @return Padded 4D `Tensor`.\n */\nexport function spatial2dPadding(\n x: Tensor, padding?: [[number, number], [number, number]],\n dataFormat?: DataFormat): Tensor {\n return tidy(() => {\n if (x.rank !== 4) {\n throw new ValueError(\n `temporalPadding expects input tensor to be 4-D, but received a ` +\n `${x.rank}-D tensor.`);\n }\n\n if (padding == null) {\n padding = [[1, 1], [1, 1]];\n }\n if (padding.length !== 2 || padding[0].length !== 2 ||\n padding[1].length !== 2) {\n throw new ValueError(\n 'spatial2dPadding expects `padding` to be an Array of two Arrays, ' +\n 'each of which is an Array of two integers.');\n }\n\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (dataFormat !== 'channelsLast' && dataFormat !== 'channelsFirst') {\n throw new ValueError(\n `Unknown data format: ${dataFormat}. ` +\n `Supported data formats are 'channelsLast' and 'channelsFirst.`);\n }\n\n let pattern: Array<[number, number]>;\n if (dataFormat === 'channelsFirst') {\n pattern = [[0, 0], [0, 0], padding[0], padding[1]];\n } else {\n pattern = [[0, 0], padding[0], padding[1], [0, 0]];\n }\n\n return tfc.pad(x, pattern);\n });\n}\n\nexport interface ZeroPadding2DLayerConfig extends LayerConfig {\n /**\n * Integer, or `Array` of 2 integers, or `Array` of 2 `Array`s, each of\n * which is an `Array` of 2 integers.\n * - If integer, the same symmetric padding is applied to width and height.\n * - If Array` of 2 integers, interpreted as two different symmetric values\n * for height and width:\n * `[symmetricHeightPad, symmetricWidthPad]`.\n * - If `Array` of 2 `Array`s, interpreted as:\n * `[[topPad, bottomPad], [leftPad, rightPad]]`.\n */\n padding?: number|[number, number]|[[number, number], [number, number]];\n\n /**\n * One of `'channelsLast'` (default) and `'channelsFirst'`.\n *\n * The ordering of the dimensions in the inputs.\n * `channelsLast` corresponds to inputs with shape\n * `[batch, height, width, channels]` while `channelsFirst`\n * corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Zero-padding layer for 2D input (e.g., image).\n *\n * This layer can add rows and columns of zeros\n * at the top, bottom, left and right side of an image tensor.\n *\n * Input shape:\n * 4D tensor with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, rows, cols, channels]`\n * - If `data_format` is `\"channels_first\"`:\n * `[batch, channels, rows, cols]`.\n *\n * Output shape:\n * 4D with shape:\n * - If `dataFormat` is `\"channelsLast\"`:\n * `[batch, paddedRows, paddedCols, channels]`\n * - If `dataFormat` is `\"channelsFirst\"`:\n * `[batch, channels, paddedRows, paddedCols]`.\n */\nexport class ZeroPadding2D extends Layer {\n static className = 'ZeroPadding2D';\n readonly dataFormat: DataFormat;\n readonly padding: [[number, number], [number, number]];\n\n constructor(config?: ZeroPadding2DLayerConfig) {\n if (config == null) {\n config = {};\n }\n super(config);\n\n this.dataFormat =\n config.dataFormat == null ? imageDataFormat() : config.dataFormat;\n // TODO(cais): Maybe refactor the following logic surrounding `padding`\n // into a helper method.\n if (config.padding == null) {\n this.padding = [[1, 1], [1, 1]];\n } else if (typeof config.padding === 'number') {\n this.padding =\n [[config.padding, config.padding], [config.padding, config.padding]];\n } else {\n config.padding = config.padding as [number, number] |\n [[number, number], [number, number]];\n if (config.padding.length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects padding to be a length-2 array, but ` +\n `received a length-${config.padding.length} array.`);\n }\n\n let heightPadding: [number, number];\n let widthPadding: [number, number];\n if (typeof config.padding[0] === 'number') {\n heightPadding =\n [config.padding[0] as number, config.padding[0] as number];\n widthPadding =\n [config.padding[1] as number, config.padding[1] as number];\n } else {\n config.padding = config.padding as [[number, number], [number, number]];\n\n if (config.padding[0].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects height padding to be a length-2 array, ` +\n `but received a length-${config.padding[0].length} array.`);\n }\n heightPadding = config.padding[0] as [number, number];\n\n if (config.padding[1].length !== 2) {\n throw new ValueError(\n `ZeroPadding2D expects width padding to be a length-2 array, ` +\n `but received a length-${config.padding[1].length} array.`);\n }\n widthPadding = config.padding[1] as [number, number];\n }\n this.padding = [heightPadding, widthPadding];\n }\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n\n let rows: number;\n let cols: number;\n if (this.dataFormat === 'channelsFirst') {\n if (inputShape[2] != null && inputShape[2] >= 0) {\n rows = inputShape[2] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[3] != null && inputShape[3] >= 0) {\n cols = inputShape[3] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n if (inputShape[1] != null && inputShape[1] >= 0) {\n rows = inputShape[1] + this.padding[0][0] + this.padding[0][1];\n } else {\n rows = null;\n }\n if (inputShape[2] != null && inputShape[2] >= 0) {\n cols = inputShape[2] + this.padding[1][0] + this.padding[1][1];\n } else {\n cols = null;\n }\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(\n () => spatial2dPadding(\n getExactlyOneTensor(inputs), this.padding, this.dataFormat));\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n padding: this.padding,\n dataFormat: this.dataFormat,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(ZeroPadding2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Pooling Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, Tensor3D, Tensor4D, tidy} from '@tensorflow/tfjs-core';\n\nimport {imageDataFormat} from '../backend/common';\nimport * as K from '../backend/tfjs_backend';\nimport {checkDataFormat, checkPaddingMode, checkPoolMode, DataFormat, PaddingMode, PoolMode} from '../common';\nimport {InputSpec} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {convOutputLength} from '../utils/conv_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\n\nimport {preprocessConv2DInput} from './convolutional';\n\n// tslint:enable:max-line-length\n\n/**\n * 2D pooling.\n * @param x\n * @param poolSize\n * @param stridesdes strides. Defaults to [1, 1].\n * @param padding padding. Defaults to 'valid'.\n * @param dataFormat data format. Defaults to 'channelsLast'.\n * @param poolMode Mode of pooling. Defaults to 'max'.\n * @returns Result of the 2D pooling.\n */\nexport function pool2d(\n x: Tensor, poolSize: [number, number], strides?: [number, number],\n padding?: PaddingMode, dataFormat?: DataFormat,\n poolMode?: PoolMode): Tensor {\n return tidy(() => {\n checkDataFormat(dataFormat);\n checkPoolMode(poolMode);\n checkPaddingMode(padding);\n if (strides == null) {\n strides = [1, 1];\n }\n if (padding == null) {\n padding = 'valid';\n }\n if (dataFormat == null) {\n dataFormat = imageDataFormat();\n }\n if (poolMode == null) {\n poolMode = 'max';\n }\n\n // TODO(cais): Remove the preprocessing step once deeplearn.js supports\n // dataFormat as an input argument.\n x = preprocessConv2DInput(x, dataFormat); // x is NHWC after preprocessing.\n let y: Tensor;\n const paddingString = (padding === 'same') ? 'same' : 'valid';\n if (poolMode === 'max') {\n // TODO(cais): Rank check?\n y = tfc.maxPool(x as Tensor4D, poolSize, strides, paddingString);\n } else { // 'avg'\n // TODO(cais): Check the dtype and rank of x and give clear error message\n // if those are incorrect.\n y = tfc.avgPool(\n // TODO(cais): Rank check?\n x as Tensor3D | Tensor4D, poolSize, strides, paddingString);\n }\n if (dataFormat === 'channelsFirst') {\n y = tfc.transpose(y, [0, 3, 1, 2]); // NHWC -> NCHW.\n }\n return y;\n });\n}\n\n\nexport interface Pooling1DLayerConfig extends LayerConfig {\n /**\n * Size of the window to pool over, should be an integer.\n */\n poolSize?: number;\n /**\n * Period at which to sample the pooled values.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number;\n /** How to fill in data that's not an integer multiple of poolSize. */\n padding?: PaddingMode;\n}\n\n/**\n * Abstract class for different pooling 1D layers.\n */\nexport abstract class Pooling1D extends Layer {\n protected readonly poolSize: [number];\n protected readonly strides: [number];\n protected readonly padding: PaddingMode;\n\n /**\n *\n * @param config Parameters for the Pooling layer.\n *\n * config.poolSize defaults to 2.\n */\n constructor(config: Pooling1DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = 2;\n }\n super(config);\n if (typeof config.poolSize === 'number') {\n this.poolSize = [config.poolSize];\n } else if (\n Array.isArray(config.poolSize) &&\n (config.poolSize as number[]).length === 1 &&\n typeof (config.poolSize as number[])[0] === 'number') {\n this.poolSize = config.poolSize;\n } else {\n throw new ValueError(\n `poolSize for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.poolSize)}`);\n }\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else {\n if (typeof config.strides === 'number') {\n this.strides = [config.strides];\n } else if (\n Array.isArray(config.strides) &&\n (config.strides as number[]).length === 1 &&\n typeof (config.strides as number[])[0] === 'number') {\n this.strides = config.strides;\n } else {\n throw new ValueError(\n `strides for 1D convolutional layer must be a number or an ` +\n `Array of a single number, but received ` +\n `${JSON.stringify(config.strides)}`);\n }\n }\n\n this.padding = config.padding == null ? 'valid' : config.padding;\n checkPaddingMode(this.padding);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const length = convOutputLength(\n inputShape[1], this.poolSize[0], this.padding, this.strides[0]);\n return [inputShape[0], length, inputShape[2]];\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n // Add dummy last dimension.\n inputs = K.expandDims(getExactlyOneTensor(inputs), 2);\n const output = this.poolingFunction(\n getExactlyOneTensor(inputs), [this.poolSize[0], 1],\n [this.strides[0], 1], this.padding, 'channelsLast');\n // Remove dummy last dimension.\n return tfc.squeeze(output, [2]);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for temporal data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n */\nexport class MaxPooling1D extends Pooling1D {\n static className = 'MaxPooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling1D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape: `[batchSize, inLength, channels]`\n *\n * Output shape: `[batchSize, pooledLength, channels]`\n *\n * `tf.avgPool1d` is an alias.\n */\nexport class AveragePooling1D extends Pooling1D {\n static className = 'AveragePooling1D';\n constructor(config: Pooling1DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling1D);\n\nexport interface Pooling2DLayerConfig extends LayerConfig {\n /**\n * Factors by which to downscale in each dimension [vertical, horizontal].\n * Expects an integer or an array of 2 integers.\n *\n * For example, `[2, 2]` will halve the input in both spatial dimension.\n * If only one integer is specified, the same window length\n * will be used for both dimensions.\n */\n poolSize?: number|[number, number];\n\n /**\n * The size of the stride in each dimension of the pooling window. Expects\n * an integer or an array of 2 integers. Integer, tuple of 2 integers, or\n * None.\n *\n * If `null`, defaults to `poolSize`.\n */\n strides?: number|[number, number];\n\n /** The padding type to use for the pooling layer. */\n padding?: PaddingMode;\n /** The data format to use for the pooling layer. */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different pooling 2D layers.\n */\nexport abstract class Pooling2D extends Layer {\n protected readonly poolSize: [number, number];\n protected readonly strides: [number, number];\n protected readonly padding: PaddingMode;\n protected readonly dataFormat: DataFormat;\n\n constructor(config: Pooling2DLayerConfig) {\n if (config.poolSize == null) {\n config.poolSize = [2, 2];\n }\n super(config);\n this.poolSize = Array.isArray(config.poolSize) ?\n config.poolSize :\n [config.poolSize, config.poolSize];\n if (config.strides == null) {\n this.strides = this.poolSize;\n } else if (Array.isArray(config.strides)) {\n if (config.strides.length !== 2) {\n throw new ValueError(\n `If the strides property of a 2D pooling layer is an Array, ` +\n `it is expected to have a length of 2, but received length ` +\n `${config.strides.length}.`);\n }\n this.strides = config.strides;\n } else {\n // `config.strides` is a number.\n this.strides = [config.strides, config.strides];\n }\n this.padding = config.padding == null ? 'valid' : config.padding;\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n checkPaddingMode(this.padding);\n\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n let rows =\n this.dataFormat === 'channelsFirst' ? inputShape[2] : inputShape[1];\n let cols =\n this.dataFormat === 'channelsFirst' ? inputShape[3] : inputShape[2];\n rows =\n convOutputLength(rows, this.poolSize[0], this.padding, this.strides[0]);\n cols =\n convOutputLength(cols, this.poolSize[1], this.padding, this.strides[1]);\n if (this.dataFormat === 'channelsFirst') {\n return [inputShape[0], inputShape[1], rows, cols];\n } else {\n return [inputShape[0], rows, cols, inputShape[3]];\n }\n }\n\n protected abstract poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor;\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n this.invokeCallHook(inputs, kwargs);\n return this.poolingFunction(\n getExactlyOneTensor(inputs), this.poolSize, this.strides,\n this.padding, this.dataFormat);\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {\n poolSize: this.poolSize,\n padding: this.padding,\n strides: this.strides,\n dataFormat: this.dataFormat\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Max pooling operation for spatial data.\n *\n * Input shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat=CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat=CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n */\nexport class MaxPooling2D extends Pooling2D {\n static className = 'MaxPooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'max');\n }\n}\nserialization.SerializationMap.register(MaxPooling2D);\n\n/**\n * Average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, rows, cols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, rows, cols]`\n *\n * Output shape\n * - If `dataFormat === CHANNEL_LAST`:\n * 4D tensor with shape:\n * `[batchSize, pooleRows, pooledCols, channels]`\n * - If `dataFormat === CHANNEL_FIRST`:\n * 4D tensor with shape:\n * `[batchSize, channels, pooleRows, pooledCols]`\n *\n * `tf.avgPool2d` is an alias.\n */\nexport class AveragePooling2D extends Pooling2D {\n static className = 'AveragePooling2D';\n constructor(config: Pooling2DLayerConfig) {\n super(config);\n }\n\n protected poolingFunction(\n inputs: Tensor, poolSize: [number, number], strides: [number, number],\n padding: PaddingMode, dataFormat: DataFormat): Tensor {\n checkDataFormat(dataFormat);\n checkPaddingMode(padding);\n return pool2d(inputs, poolSize, strides, padding, dataFormat, 'avg');\n }\n}\nserialization.SerializationMap.register(AveragePooling2D);\n\n/**\n * Abstract class for different global pooling 1D layers.\n */\nexport abstract class GlobalPooling1D extends Layer {\n constructor(config: LayerConfig) {\n super(config);\n this.inputSpec = [new InputSpec({ndim: 3})];\n }\n\n computeOutputShape(inputShape: Shape): Shape {\n return [inputShape[0], inputShape[2]];\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n}\n\n/**\n * Global average pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalAveragePooling1D extends GlobalPooling1D {\n static className = 'GlobalAveragePooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.mean(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling1D);\n\n/**\n * Global max pooling operation for temporal data.\n *\n * Input Shape: 3D tensor with shape: `[batchSize, steps, features]`.\n *\n * Output Shape:2D tensor with shape: `[batchSize, features]`.\n */\nexport class GlobalMaxPooling1D extends GlobalPooling1D {\n static className = 'GlobalMaxPooling1D';\n constructor(config: LayerConfig) {\n super(config);\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n return tfc.max(input, 1);\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling1D);\n\nexport interface GlobalPooling2DLayerConfig extends LayerConfig {\n /**\n * One of `CHANNEL_LAST` (default) or `CHANNEL_FIRST`.\n *\n * The ordering of the dimensions in the inputs. `CHANNEL_LAST` corresponds\n * to inputs with shape `[batch, height, width, channels[` while\n * `CHANNEL_FIRST` corresponds to inputs with shape\n * `[batch, channels, height, width]`.\n */\n dataFormat?: DataFormat;\n}\n\n/**\n * Abstract class for different global pooling 2D layers.\n */\nexport abstract class GlobalPooling2D extends Layer {\n protected dataFormat: DataFormat;\n constructor(config: GlobalPooling2DLayerConfig) {\n super(config);\n this.dataFormat =\n config.dataFormat == null ? 'channelsLast' : config.dataFormat;\n checkDataFormat(this.dataFormat);\n this.inputSpec = [new InputSpec({ndim: 4})];\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = inputShape as Shape;\n if (this.dataFormat === 'channelsLast') {\n return [inputShape[0], inputShape[3]];\n } else {\n return [inputShape[0], inputShape[1]];\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n throw new NotImplementedError();\n }\n\n getConfig(): serialization.ConfigDict {\n const config = {dataFormat: this.dataFormat};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\n\n/**\n * Global average pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalAveragePooling2D extends GlobalPooling2D {\n static className = 'GlobalAveragePooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.mean(input, [1, 2]);\n } else {\n return tfc.mean(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalAveragePooling2D);\n\n/**\n * Global max pooling operation for spatial data.\n *\n * Input shape:\n * - If `dataFormat` is `CHANNEL_LAST`:\n * 4D tensor with shape: `[batchSize, rows, cols, channels]`.\n * - If `dataFormat` is `CHANNEL_FIRST`:\n * 4D tensor with shape: `[batchSize, channels, rows, cols]`.\n *\n * Output shape:\n * 2D tensor with shape: `[batchSize, channels]`.\n */\nexport class GlobalMaxPooling2D extends GlobalPooling2D {\n static className = 'GlobalMaxPooling2D';\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const input = getExactlyOneTensor(inputs);\n if (this.dataFormat === 'channelsLast') {\n return tfc.max(input, [1, 2]);\n } else {\n return tfc.max(input, [2, 3]);\n }\n });\n }\n}\nserialization.SerializationMap.register(GlobalMaxPooling2D);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * TensorFlow.js Layers: Recurrent Neural Network Layers.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {DataType, serialization, Tensor, tidy, util} from '@tensorflow/tfjs-core';\n\nimport {Activation, ActivationIdentifier, getActivation, serializeActivation} from '../activations';\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {Constraint, ConstraintIdentifier, getConstraint, serializeConstraint} from '../constraints';\nimport {InputSpec, SymbolicTensor} from '../engine/topology';\nimport {Layer, LayerConfig} from '../engine/topology';\nimport {AttributeError, NotImplementedError, ValueError} from '../errors';\nimport {getInitializer, Initializer, InitializerIdentifier, Ones, serializeInitializer} from '../initializers';\nimport {getRegularizer, Regularizer, RegularizerIdentifier, serializeRegularizer} from '../regularizers';\nimport {Kwargs, RnnStepFunction, Shape} from '../types';\nimport * as math_utils from '../utils/math_utils';\nimport {getExactlyOneShape, getExactlyOneTensor, isArrayOfShapes} from '../utils/types_utils';\nimport {batchGetValue, batchSetValue, LayerVariable} from '../variables';\n\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\n/**\n * Standardize `apply()` args to a single list of tensor inputs.\n *\n * When running a model loaded from file, the input tensors `initialState` and\n * `constants` are passed to `RNN.apply()` as part of `inputs` instead of the\n * dedicated kwargs fields. `inputs` consists of\n * `[inputs, initialState0, initialState1, ..., constant0, constant1]` in this\n * case.\n * This method makes sure that arguments are\n * separated and that `initialState` and `constants` are `Array`s of tensors\n * (or None).\n *\n * @param inputs Tensor or `Array` of tensors.\n * @param initialState Tensor or `Array` of tensors or `null`/`undefined`.\n * @param constants Tensor or `Array` of tensors or `null`/`undefined`.\n * @returns An object consisting of\n * inputs: A tensor.\n * initialState: `Array` of tensors or `null`.\n * constants: `Array` of tensors or `null`.\n * @throws ValueError, if `inputs` is an `Array` but either `initialState` or\n * `constants` is provided.\n */\nexport function standardizeArgs(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n initialState: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n constants: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n numConstants?: number): {\n inputs: Tensor|SymbolicTensor,\n initialState: Tensor[]|SymbolicTensor[],\n constants: Tensor[]|SymbolicTensor[]\n} {\n if (Array.isArray(inputs)) {\n if (initialState != null || constants != null) {\n throw new ValueError(\n 'When inputs is an array, neither initialState or constants ' +\n 'should be provided');\n }\n if (numConstants != null) {\n constants = inputs.slice(inputs.length - numConstants, inputs.length);\n inputs = inputs.slice(0, inputs.length - numConstants);\n }\n if (inputs.length > 1) {\n initialState = inputs.slice(1, inputs.length);\n }\n inputs = inputs[0];\n }\n\n function toListOrNull(x: Tensor|Tensor[]|SymbolicTensor|\n SymbolicTensor[]): Tensor[]|SymbolicTensor[] {\n if (x == null || Array.isArray(x)) {\n return x as Tensor[] | SymbolicTensor[];\n } else {\n return [x] as Tensor[] | SymbolicTensor[];\n }\n }\n\n initialState = toListOrNull(initialState);\n constants = toListOrNull(constants);\n\n return {inputs, initialState, constants};\n}\n\n/**\n * Iterates over the time dimension of a tensor.\n *\n * @param stepFunction RNN step function.\n * Parameters:\n * inputs: tensor with shape `[samples, ...]` (no time dimension),\n * representing input for the batch of samples at a certain time step.\n * states: an Array of tensors.\n * Returns:\n * outputs: tensor with shape `[samples, outputDim]` (no time dimension).\n * newStates: list of tensors, same length and shapes as `states`. The first\n * state in the list must be the output tensor at the previous timestep.\n * @param inputs Tensor of temporal data of shape `[samples, time, ...]` (at\n * least 3D).\n * @param initialStates Tensor with shape `[samples, outputDim]` (no time\n * dimension), containing the initial values of the states used in the step\n * function.\n * @param goBackwards If `true`, do the iteration over the time dimension in\n * reverse order and return the reversed sequence.\n * @param mask Binary tensor with shape `[sample, time, 1]`, with a zero for\n * every element that is masked.\n * @param constants An Array of constant values passed at each step.\n * @param unroll Whether to unroll the RNN or to use a symbolic loop. *Not*\n * applicable to this imperative deeplearn.js backend. Its value is ignored.\n * @param inputLength Not relevant in this deeplearn.js backend.\n * @returns An Array: `[lastOutput, outputs, newStates]`.\n * lastOutput: the lastest output of the RNN, of shape `[samples, ...]`.\n * outputs: tensor with shape `[samples, time, ...]` where each entry\n * `output[s, t]` is the output of the step function at time `t` for sample\n * `s`.\n * newStates: Array of tensors, latest states returned by the step function,\n * of shape `(samples, ...)`.\n * @throws ValueError If input dimension is less than 3.\n *\n * TODO(nielsene): This needs to be tidy-ed.\n */\nexport function rnn(\n stepFunction: RnnStepFunction, inputs: Tensor, initialStates: Tensor[],\n goBackwards = false, mask?: Tensor, constants?: Tensor[], unroll = false,\n inputLength?: number): [Tensor, Tensor, Tensor[]] {\n const ndim = inputs.shape.length;\n if (ndim < 3) {\n throw new ValueError(`Input should be at least 3D, but is ${ndim}D.`);\n }\n\n // Transpose to time-major, i.e., from [batch, time, ...] to [time, batch,\n // ...].\n const axes = [1, 0].concat(math_utils.range(2, ndim));\n inputs = tfc.transpose(inputs, axes);\n\n if (mask != null) {\n throw new NotImplementedError(\n 'The rnn() function of the deeplearn.js backend does not support ' +\n 'masking yet.');\n }\n\n if (constants != null) {\n throw new NotImplementedError(\n 'The rnn() functoin of the deeplearn.js backend does not support ' +\n 'constants yet.');\n }\n\n // Porting Note: the unroll option is ignored by the imperative backend.\n if (unroll) {\n console.warn(\n 'Backend rnn(): the unroll = true option is not applicable to the ' +\n 'imperative deeplearn.js backend.');\n }\n\n if (goBackwards) {\n inputs = tfc.reverse(inputs, 0);\n }\n\n // Porting Note: PyKeras with TensorFlow backend uses a symbolic loop\n // (tf.while_loop). But for the imperative deeplearn.js backend, we just\n // use the usual TypeScript control flow to iterate over the time steps in\n // the inputs.\n // Porting Note: PyKeras patches a \"_use_learning_phase\" attribute to\n // outputs.\n // This is not idiomatic in TypeScript. The info regarding whether we are\n // in a learning (i.e., training) phase for RNN is passed in a different\n // way.\n // TODO(cais): Determine in what exact way the learning phase information\n // will be passed.\n\n let outputs: Tensor;\n let lastOutput: Tensor;\n let states = initialStates;\n const timeSteps = inputs.shape[0];\n for (let t = 0; t < timeSteps; ++t) {\n let currentInput = K.sliceAlongFirstAxis(inputs, t, 1);\n currentInput = currentInput.reshape(currentInput.shape.slice(1));\n const stepOutputs = stepFunction(currentInput, states);\n lastOutput = stepOutputs[0];\n if (t === 0) {\n outputs = lastOutput.reshape([1].concat(lastOutput.shape));\n } else {\n outputs = K.concatAlongFirstAxis(\n outputs, lastOutput.reshape([1].concat(lastOutput.shape)));\n }\n // TODO(soergel): Call K.concatenate() to perform only one concatenation\n // at the end, once the backend function is available.\n states = stepOutputs[1];\n }\n\n return [\n lastOutput,\n tfc.transpose(\n outputs, [1, 0].concat(math_utils.range(2, outputs.shape.length))),\n states\n ];\n}\n\n\nexport interface BaseRNNLayerConfig extends LayerConfig {\n /**\n * A RNN cell instance. A RNN cell is a class that has:\n * - a `call()` method, which takes `[Tensor, Tensor]` as the\n * first input argument. The first item is the input at time t, and\n * second item is the cell state at time t.\n * The `call()` method returns `[outputAtT, statesAtTPlus1]`.\n * The `call()` method of the cell can also take the argument `constants`,\n * see section \"Note on passing external constants\" below.\n * Porting Node: PyKeras overrides the `call()` signature of RNN cells,\n * which are Layer subtypes, to accept two arguments. tfjs-layers does\n * not do such overriding. Instead we preseve the `call()` signature,\n * which due to its `Tensor|Tensor[]` argument and return value, is\n * flexible enough to handle the inputs and states.\n * - a `stateSize` attribute. This can be a single integer (single state)\n * in which case it is the size of the recurrent state (which should be\n * the same as the size of the cell output). This can also be an Array of\n * integers (one size per state). In this case, the first entry\n * (`stateSize[0]`) should be the same as the size of the cell output.\n * It is also possible for `cell` to be a list of RNN cell instances, in which\n * case the cells get stacked on after the other in the RNN, implementing an\n * efficient stacked RNN.\n */\n cell?: RNNCell|RNNCell[];\n\n /**\n * Whether to return the last output in the output sequence, or the full\n * sequence.\n */\n returnSequences?: boolean;\n\n /**\n * Whether to return the last state in addition to the output.\n */\n returnState?: boolean;\n\n /**\n * If `true`, process the input sequence backwards and return the reversed\n * sequence (default: `false`).\n */\n goBackwards?: boolean;\n\n /**\n * If `true`, the last state for each sample at index i in a batch will be\n * used as initial state of the sample of index i in the following batch\n * (default: `false`).\n */\n stateful?: boolean;\n\n /**\n * If `true`, the network will be unrolled, else a symbolic loop will be\n * used. Unrolling can speed-up a RNN, although it tends to be more memory-\n * intensive. Unrolling is only suitable for short sequences (default:\n * `false`).\n * Porting Note: tfjs-layers has an imperative backend. RNNs are executed with\n * normal TypeScript control flow. Hence this property is inapplicable and\n * ignored in tfjs-layers.\n */\n unroll?: boolean;\n\n /**\n * Dimensionality of the input (integer).\n * This option (or alternatively, the option `inputShape`) is required when\n * this layer is used as the first layer in a model.\n */\n inputDim?: number;\n\n /**\n * Length of the input sequences, to be specified when it is constant.\n * This argument is required if you are going to connect `Flatten` then\n * `Dense` layers upstream (without it, the shape of the dense outputs cannot\n * be computed). Note that if the recurrent layer is not the first layer in\n * your model, you would need to specify the input length at the level of the\n * first layer (e.g., via the `inputShape` option).\n */\n inputLength?: number;\n}\n\n/**\n * RNNLayerConfig is identical to BaseRNNLayerConfig, except it makes the\n * `cell` property required. This interface is to be used with constructors\n * of concrete RNN layer sbutypes.\n */\nexport interface RNNLayerConfig extends BaseRNNLayerConfig {\n cell: RNNCell|RNNCell[];\n}\n\n/**\n * Base class for recurrent layers.\n *\n * Input shape:\n * 3D tensor with shape `[batchSize, timeSteps, inputDim]`.\n *\n * Output shape:\n * - if `returnState`, an Array of tensors (i.e., `Tensor`s). The first\n * tensor is the output. The remaining tensors are the states at the\n * last time step, each with shape `[batchSize, units]`.\n * - if `returnSequences`, the output will have shape\n * `[batchSize, timeSteps, units]`.\n * - else, the output will have shape `[batchSize, units]`.\n *\n * Masking:\n * This layer supports masking for input data with a variable number\n * of timesteps. To introduce masks to your data,\n * use an embedding layer with the `mask_zero` parameter\n * set to `True`.\n *\n * Notes on using statefulness in RNNs:\n * You can set RNN layers to be 'stateful', which means that the states\n * computed for the samples in one batch will be reused as initial states\n * for the samples in the next batch. This assumes a one-to-one mapping\n * between samples in different successive batches.\n *\n * To enable statefulness:\n * - specify `stateful: true` in the layer constructor.\n * - specify a fixed batch size for your model, by passing\n * if sequential model:\n * `batchInputShape=[...]` to the first layer in your model.\n * else for functional model with 1 or more Input layers:\n * `batchShape=[...]` to all the first layers in your model.\n * This is the expected shape of your inputs *including the batch size*.\n * It should be a tuple of integers, e.g. `(32, 10, 100)`.\n * - specify `shuffle=False` when calling fit().\n *\n * To reset the states of your model, call `.reset_states()` on either\n * a specific layer, or on your entire model.\n *\n * Note on specifying the initial state of RNNs\n * You can specify the initial state of RNN layers symbolically by\n * calling them with the option `initialState`. The value of\n * `initialState` should be a tensor or list of tensors representing\n * the initial state of the RNN layer.\n *\n * You can specify the initial state of RNN layers numerically by\n * calling `resetStates` with the keyword argument `states`. The value of\n * `states` should be a numpy array or list of numpy arrays representing\n * the initial state of the RNN layer.\n *\n * Note on passing external constants to RNNs\n * You can pass \"external\" constants to the cell using the `constants`\n * keyword argument of `RNN.call` method. This requires that the `cell.call`\n * method accepts the same keyword argument `constants`. Such constants\n * can be used to conditon the cell transformation on additional static inputs\n * (not changing over time), a.k.a an attention mechanism.\n */\nexport class RNN extends Layer {\n static className = 'RNN';\n public readonly cell: RNNCell;\n public readonly returnSequences: boolean;\n public readonly returnState: boolean;\n public readonly goBackwards: boolean;\n public readonly unroll: boolean;\n\n public stateSpec: InputSpec[];\n public states: Tensor[];\n\n private numConstants: number;\n\n constructor(config: RNNLayerConfig) {\n super(config);\n let cell: RNNCell;\n if (config.cell == null) {\n throw new ValueError(\n 'cell property is missing for the constructor of RNN.');\n } else if (Array.isArray(config.cell)) {\n cell = new StackedRNNCells({cells: config.cell});\n } else {\n cell = config.cell;\n }\n if ((cell as RNNCell).stateSize == null) {\n throw new ValueError(\n 'The RNN cell should have an attribute `stateSize` (tuple of ' +\n 'integers, one integer per RNN state).');\n }\n this.cell = cell;\n this.returnSequences =\n config.returnSequences == null ? false : config.returnSequences;\n this.returnState = config.returnState == null ? false : config.returnState;\n this.goBackwards = config.goBackwards == null ? false : config.goBackwards;\n this._stateful = config.stateful == null ? false : config.stateful;\n this.unroll = config.unroll == null ? false : config.unroll;\n\n this.supportsMasking = true;\n this.inputSpec = [new InputSpec({ndim: 3})];\n this.stateSpec = null;\n this.states = null;\n // TODO(cais): Add constantsSpec and numConstants.\n this.numConstants = null;\n // TODO(cais): Look into the use of initial_state in the kwargs of the\n // constructor.\n }\n\n // Porting Note: This is the equivalent of `RNN.states` property getter in\n // PyKeras.\n getStates(): Tensor[] {\n if (this.states == null) {\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n return math_utils.range(0, numStates).map(x => null);\n } else {\n return this.states;\n }\n }\n\n // Porting Note: This is the equivalent of the `RNN.states` property setter in\n // PyKeras.\n setStates(states: Tensor[]): void {\n this.states = states;\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n // TODO(cais): Remove the casting once stacked RNN cells become supported.\n let stateSize = this.cell.stateSize;\n if (!Array.isArray(stateSize)) {\n stateSize = [stateSize];\n }\n const outputDim = stateSize[0];\n let outputShape: Shape|Shape[];\n if (this.returnSequences) {\n outputShape = [inputShape[0], inputShape[1], outputDim];\n } else {\n outputShape = [inputShape[0], outputDim];\n }\n\n if (this.returnState) {\n const stateShape: Shape[] = [];\n for (const dim of stateSize) {\n stateShape.push([inputShape[0], dim]);\n }\n return [outputShape].concat(stateShape);\n } else {\n return outputShape;\n }\n }\n\n computeMask(inputs: Tensor|Tensor[], mask?: Tensor|Tensor[]): Tensor {\n throw new NotImplementedError(\n 'computeMask has not been implemented for RNN yet');\n }\n\n public build(inputShape: Shape|Shape[]): void {\n // Note inputShape will be an Array of Shapes of initial states and\n // constants if these are passed in apply().\n const constantShape: Shape[] = null;\n if (this.numConstants != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n }\n\n if (isArrayOfShapes(inputShape)) {\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n\n const batchSize: number = this.stateful ? inputShape[0] : null;\n const inputDim = inputShape[inputShape.length - 1];\n this.inputSpec[0] = new InputSpec({shape: [batchSize, null, inputDim]});\n\n // Allow cell (if RNNCell Layer) to build before we set or validate\n // stateSpec.\n const stepInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (constantShape != null) {\n throw new NotImplementedError(\n 'Constants support is not implemented in RNN yet.');\n } else {\n this.cell.build(stepInputShape);\n }\n\n // Set or validate stateSpec.\n let stateSize: number[];\n if (Array.isArray((this.cell as RNNCell).stateSize)) {\n stateSize = this.cell.stateSize as number[];\n } else {\n stateSize = [this.cell.stateSize as number];\n }\n\n if (this.stateSpec != null) {\n if (!util.arraysEqual(\n this.stateSpec.map(spec => spec.shape[spec.shape.length - 1]),\n stateSize)) {\n throw new ValueError(\n `An initialState was passed that is not compatible with ` +\n `cell.stateSize. Received stateSpec=${this.stateSpec}; ` +\n `However cell.stateSize is ${this.cell.stateSize}`);\n }\n } else {\n this.stateSpec =\n stateSize.map(dim => new InputSpec({shape: [null, dim]}));\n }\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n // TODO(cais): Uncomment the following line once stateful = true is\n // implemented.\n // this.resetStates();\n }\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n tidy(() => {\n if (!this.stateful) {\n throw new AttributeError(\n 'Cannot call resetState() on an RNN Layer that is not stateful.');\n }\n const batchSize = this.inputSpec[0].shape[0];\n if (batchSize == null) {\n throw new ValueError(\n 'If an RNN is stateful, it needs to know its batch size. Specify ' +\n 'the batch size of your input tensors: \\n' +\n '- If using a Sequential model, specify the batch size by ' +\n 'passing a `batchInputShape` option to your first layer.\\n' +\n '- If using the functional API, specify the batch size by ' +\n 'passing a `batchShape` option to your Input layer.');\n }\n // Initialize state if null.\n if (this.states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states = [tfc.zeros([batchSize, this.cell.stateSize])];\n }\n } else if (states == null) {\n if (Array.isArray(this.cell.stateSize)) {\n this.states =\n this.cell.stateSize.map(dim => tfc.zeros([batchSize, dim]));\n } else {\n this.states[0] = tfc.zeros([batchSize, this.cell.stateSize]);\n }\n } else {\n if (!Array.isArray(states)) {\n states = [states];\n }\n if (states.length !== this.states.length) {\n throw new ValueError(\n `Layer ${this.name} expects ${this.states.length} state(s), ` +\n `but it received ${states.length} state value(s). Input ` +\n `received: ${states}`);\n }\n for (let index = 0; index < this.states.length; ++index) {\n const value = states[index];\n const dim = Array.isArray(this.cell.stateSize) ?\n this.cell.stateSize[index] :\n this.cell.stateSize;\n const expectedShape = [batchSize, dim];\n if (!util.arraysEqual(value.shape, expectedShape)) {\n throw new ValueError(\n `State ${index} is incompatible with layer ${this.name}: ` +\n `expected shape=${expectedShape}, received shape=${\n value.shape}`);\n }\n this.states[index] = value;\n }\n }\n });\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n // TODO(cais): Figure out whether initialState is in kwargs or inputs.\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n // If any of `initial_state` or `constants` are specified and are\n // `SymbolicTensor`s, then add them to the inputs and temporarily modify the\n // input_spec to include them.\n\n let additionalInputs: Array = [];\n let additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n kwargs['initialState'] = initialState;\n additionalInputs = additionalInputs.concat(initialState);\n this.stateSpec = [];\n for (const state of initialState) {\n this.stateSpec.push(new InputSpec({shape: state.shape}));\n }\n // TODO(cais): Use the following instead.\n // this.stateSpec = initialState.map(state => new InputSpec({shape:\n // state.shape}));\n additionalSpecs = additionalSpecs.concat(this.stateSpec);\n }\n if (constants != null) {\n kwargs['constants'] = constants;\n additionalInputs = additionalInputs.concat(constants);\n // TODO(cais): Add this.constantsSpec.\n this.numConstants = constants.length;\n }\n\n const isTensor = additionalInputs[0] instanceof SymbolicTensor;\n if (isTensor) {\n // Compute full input spec, including state and constants.\n const fullInput =\n [inputs].concat(additionalInputs) as Tensor[] | SymbolicTensor[];\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call with temporarily replaced inputSpec.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output = super.apply(fullInput, kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n // tslint:disable-next-line:no-any\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n // Input shape: `[samples, time (padded with zeros), input_dim]`.\n // Note that the .build() method of subclasses **must** define\n // this.inputSpec and this.stateSpec owith complete input shapes.\n return tidy(() => {\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n let initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n\n inputs = getExactlyOneTensor(inputs);\n if (initialState == null) {\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet.');\n } else {\n initialState = this.getInitialState(inputs);\n }\n }\n\n if (mask != null) {\n throw new NotImplementedError('Masking is not implemented for RNN yet');\n }\n\n const numStates =\n Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1;\n if (initialState.length !== numStates) {\n throw new ValueError(\n `RNN Layer has ${numStates} state(s) but was passed ` +\n `${initialState.length} initial state(s).`);\n }\n const inputShape = inputs.shape;\n const timesteps = inputShape[1];\n if (this.unroll) {\n console.warn(\n 'Ignoring unroll = true for RNN layer, due to imperative backend.');\n }\n\n const cellCallKwargs: Kwargs = {training};\n\n // TODO(cais): Add support for constants.\n const step = (inputs: Tensor, states: Tensor[]) => {\n // `inputs` and `states` are concatenated to form a single `Array` of\n // `Tensor`s as the input to `cell.call()`.\n const outputs =\n this.cell.call([inputs].concat(states), cellCallKwargs) as Tensor[];\n // Marshall the return value into output and new states.\n return [outputs[0], outputs.slice(1)] as [Tensor, Tensor[]];\n };\n\n // TODO(cais): Add support for constants.\n // TODO(cais): Add support for masks.\n\n const rnnOutputs =\n rnn(step, inputs, initialState, this.goBackwards, null, null,\n this.unroll, timesteps);\n const lastOutput = rnnOutputs[0];\n const outputs = rnnOutputs[1];\n const states = rnnOutputs[2];\n\n if (this.stateful) {\n throw new NotImplementedError(\n 'stateful RNN layer is not implemented yet');\n }\n\n const output = this.returnSequences ? outputs : lastOutput;\n\n // TODO(cais): Porperty set learning phase flag.\n\n if (this.returnState) {\n return [output].concat(states);\n } else {\n return output;\n }\n });\n }\n\n getInitialState(inputs: Tensor): Tensor[] {\n return tidy(() => {\n // Build an all-zero tensor of shape [samples, outputDim].\n // [Samples, timeSteps, inputDim].\n let initialState = tfc.zeros(inputs.shape);\n // [Samples].\n initialState = tfc.sum(initialState, [1, 2]);\n initialState = K.expandDims(initialState); // [Samples, 1].\n\n if (Array.isArray(this.cell.stateSize)) {\n return this.cell.stateSize.map(\n dim => dim > 1 ? K.tile(initialState, [1, dim]) : initialState);\n } else {\n return this.cell.stateSize > 1 ?\n [K.tile(initialState, [1, this.cell.stateSize])] :\n [initialState];\n }\n });\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n return this.cell.trainableWeights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n // Porting Note: In TypeScript, `this` is always an instance of `Layer`.\n if (!this.trainable) {\n return this.cell.weights;\n }\n return this.cell.nonTrainableWeights;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n returnSequences: this.returnSequences,\n returnState: this.returnState,\n goBackwards: this.goBackwards,\n stateful: this.stateful,\n unroll: this.unroll,\n };\n if (this.numConstants != null) {\n config.numConstants = this.numConstants;\n }\n const cellConfig = this.cell.getConfig();\n config.cell = {\n className: this.cell.getClassName(),\n config: cellConfig,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(RNN);\n\n/**\n * An RNNCell layer.\n */\n// Porting Note: This is a common parent class for RNN cells. There is no\n// equivalent of this in PyKeras. Having a common parent class forgoes the\n// need for `has_attr(cell, ...)` checks or its TypeScript equivalent.\n/** @doc {heading: 'Layers', subheading: 'Classes'} */\nexport abstract class RNNCell extends Layer {\n /**\n * Size(s) of the states.\n * For RNN cells with only a single state, this is a single integer.\n */\n public stateSize: number|number[];\n public dropoutMask: Tensor|Tensor[];\n public recurrentDropoutMask: Tensor|Tensor[];\n}\n\nexport interface SimpleRNNCellLayerConfig extends LayerConfig {\n /**\n * units: Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n * Default: hyperbolic tangent ('tanh').\n * If you pass `null`, 'linear' activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the `kernel` weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the `recurrent_kernel` weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the `kernel` weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the `recurrentKernel` weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraintfunction applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Float number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Cell class for `SimpleRNN`.\n *\n * `SimpleRNNCell` is distinct from the `RNN` subclass `SimpleRNN` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `SimpleRNN` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.simpleRNNCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `SimpleRNNCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.simpleRNNCell({units: 4}),\n * tf.layers.simpleRNNCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `SimpleRNNCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `SimpleRNNCell`, use the\n * `tf.layers.simpleRNN`.\n */\nexport class SimpleRNNCell extends RNNCell {\n static className = 'SimpleRNNCell';\n readonly units: number;\n readonly activation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n constructor(config: SimpleRNNCellLayerConfig) {\n super(config);\n this.units = config.units;\n this.activation = getActivation(\n config.activation == null ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n // TODO(cais): Use regularizer.\n this.kernel = this.addWeight(\n 'kernel', [inputShape[inputShape.length - 1], this.units], null,\n this.kernelInitializer, this.kernelRegularizer, true,\n this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n this.built = true;\n }\n\n // Porting Note: PyKeras' equivalent of this method takes two tensor inputs:\n // `inputs` and `states`. Here, the two tensors are combined into an\n // `Tensor[]` Array as the first input argument.\n // Similarly, PyKeras' equivalent of this method returns two values:\n // `output` and `[output]`. Here the two are combined into one length-2\n // `Tensor[]`, consisting of `output` repeated.\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `SimpleRNNCell expects 2 input Tensors, got ${inputs.length}.`);\n }\n let prevOutput = inputs[1];\n inputs = inputs[0];\n const training = kwargs['training'] == null ? false : kwargs['training'];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training) as Tensor;\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(prevOutput), this.recurrentDropout,\n training) as Tensor;\n }\n let h: Tensor;\n const dpMask: Tensor = this.dropoutMask as Tensor;\n const recDpMask: Tensor = this.recurrentDropoutMask as Tensor;\n if (dpMask != null) {\n h = K.dot(tfc.mul(inputs, dpMask), this.kernel.read());\n } else {\n h = K.dot(inputs, this.kernel.read());\n }\n if (this.bias != null) {\n h = K.biasAdd(h, this.bias.read());\n }\n if (recDpMask != null) {\n prevOutput = tfc.mul(prevOutput, recDpMask);\n }\n let output = tfc.add(h, K.dot(prevOutput, this.recurrentKernel.read()));\n if (this.activation != null) {\n output = this.activation.apply(output);\n }\n\n // TODO(cais): Properly set learning phase on output tensor?\n return [output, output];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNNCell);\n\nexport interface SimpleRNNLayerConfig extends BaseRNNLayerConfig {\n /**\n * Positive integer, dimensionality of the output space.\n */\n units: number;\n\n /**\n * Activation function to use.\n *\n * Defaults to hyperbolic tangent (`tanh`)\n *\n * If you pass `null`, no activation will be applied.\n */\n activation?: ActivationIdentifier;\n\n /**\n * Whether the layer uses a bias vector.\n */\n useBias?: boolean;\n\n /**\n * Initializer for the `kernel` weights matrix, used for the linear\n * transformation of the inputs.\n */\n kernelInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the `recurrentKernel` weights matrix, used for\n * linear transformation of the recurrent state.\n */\n recurrentInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Initializer for the bias vector.\n */\n biasInitializer?: InitializerIdentifier|Initializer;\n\n /**\n * Regularizer function applied to the kernel weights matrix.\n */\n kernelRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the recurrentKernel weights matrix.\n */\n recurrentRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Regularizer function applied to the bias vector.\n */\n biasRegularizer?: RegularizerIdentifier|Regularizer;\n\n /**\n * Constraint function applied to the kernel weights matrix.\n */\n kernelConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the recurrentKernel weights matrix.\n */\n recurrentConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Constraint function applied to the bias vector.\n */\n biasConstraint?: ConstraintIdentifier|Constraint;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the inputs.\n */\n dropout?: number;\n\n /**\n * Number between 0 and 1. Fraction of the units to drop for the linear\n * transformation of the recurrent state.\n */\n recurrentDropout?: number;\n}\n\n/**\n * Fully-connected RNN where the output is to be fed back to input.\n *\n * This is an `RNN` layer consisting of one `SimpleRNNCell`. However, unlike\n * the underlying `SimpleRNNCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.simpleRNN({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `SimpleRNNCell`'s number of units.\n * ```\n */\nexport class SimpleRNN extends RNN {\n static className = 'SimpleRNN';\n constructor(config: SimpleRNNLayerConfig) {\n config.cell = new SimpleRNNCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n // TODO(cais): Research possibility of refactoring out the tedious all\n // the getters that delegate to `this.cell` below.\n get units(): number {\n return (this.cell as SimpleRNNCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as SimpleRNNCell).activation;\n }\n\n get useBias(): boolean {\n return (this.cell as SimpleRNNCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as SimpleRNNCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as SimpleRNNCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as SimpleRNNCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as SimpleRNNCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as SimpleRNNCell).recurrentDropout;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(SimpleRNN);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface GRUCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Cell class for `GRU`.\n *\n * `GRUCell` is distinct from the `RNN` subclass `GRU` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `GRU` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.gruCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `GRUCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.gruCell({units: 4}),\n * tf.layers.gruCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `gruCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `GRUCell`, use the\n * `tf.layers.gru`.\n */\nexport class GRUCell extends RNNCell {\n static className = 'GRUCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number;\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n readonly DEFAULT_BIAS_INITIALIZER: InitializerIdentifier = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: GRUCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = this.units;\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 3], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 3], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n if (this.useBias) {\n this.bias = this.addWeight(\n 'bias', [this.units * 3], null, this.biasInitializer,\n this.biasRegularizer, true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n if (inputs.length !== 2) {\n throw new ValueError(\n `GRUCell expects 2 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n\n const training = kwargs['training'] == null ? false : kwargs['training'];\n let hTMinus1 = inputs[1]; // Previous memory state.\n inputs = inputs[0];\n\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 3) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 3) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor];\n const recDpMask = this.recurrentDropoutMask as [Tensor, Tensor, Tensor];\n let z: Tensor;\n let r: Tensor;\n let hh: Tensor;\n if (this.implementation === 1) {\n const kernelZ = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelR =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelH = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const recurrentKernelZ =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelR = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelH = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n\n let inputsZ: Tensor, inputsR: Tensor, inputsH: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsZ = tfc.mul(inputs, dpMask[0]);\n inputsR = tfc.mul(inputs, dpMask[1]);\n inputsH = tfc.mul(inputs, dpMask[2]);\n } else {\n inputsZ = inputs;\n inputsR = inputs;\n inputsH = inputs;\n }\n\n let xZ = K.dot(inputsZ, kernelZ);\n let xR = K.dot(inputsR, kernelR);\n let xH = K.dot(inputsH, kernelH);\n if (this.useBias) {\n const biasZ = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasR =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasH = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n xZ = K.biasAdd(xZ, biasZ);\n xR = K.biasAdd(xR, biasR);\n xH = K.biasAdd(xH, biasH);\n }\n\n let hTMinus1Z: Tensor;\n let hTMinus1R: Tensor;\n let hTMinus1H: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1Z = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1R = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1H = tfc.mul(hTMinus1, recDpMask[2]);\n } else {\n hTMinus1Z = hTMinus1;\n hTMinus1R = hTMinus1;\n hTMinus1H = hTMinus1;\n }\n z = this.recurrentActivation.apply(\n tfc.add(xZ, K.dot(hTMinus1Z, recurrentKernelZ)));\n r = this.recurrentActivation.apply(\n tfc.add(xR, K.dot(hTMinus1R, recurrentKernelR)));\n hh = this.activation.apply(\n tfc.add(xH, K.dot(tfc.mul(r, hTMinus1H), recurrentKernelH)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let matrixX = K.dot(inputs, this.kernel.read());\n if (this.useBias) {\n matrixX = K.biasAdd(matrixX, this.bias.read());\n }\n if (0 < this.dropout && this.dropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n const matrixInner = K.dot(\n hTMinus1,\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 0, 2 * this.units));\n\n const xZ = K.sliceAlongLastAxis(matrixX, 0, this.units);\n const xR = K.sliceAlongLastAxis(matrixX, this.units, this.units);\n const recurrentZ = K.sliceAlongLastAxis(matrixInner, 0, this.units);\n const recurrentR =\n K.sliceAlongLastAxis(matrixInner, this.units, this.units);\n\n z = this.recurrentActivation.apply(tfc.add(xZ, recurrentZ));\n r = this.recurrentActivation.apply(tfc.add(xR, recurrentR));\n\n const xH = K.sliceAlongLastAxis(matrixX, 2 * this.units, this.units);\n const recurrentH = K.dot(\n tfc.mul(r, hTMinus1),\n K.sliceAlongLastAxis(\n this.recurrentKernel.read(), 2 * this.units, this.units));\n hh = this.activation.apply(tfc.add(xH, recurrentH));\n }\n\n const h = tfc.add(\n tfc.mul(z, hTMinus1), tfc.mul(tfc.add(getScalar(1), tfc.neg(z)), hh));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(GRUCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface GRULayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: number;\n}\n\n/**\n * Gated Recurrent Unit - Cho et al. 2014.\n *\n * This is an `RNN` layer consisting of one `GRUCell`. However, unlike\n * the underlying `GRUCell`, the `apply` method of `SimpleRNN` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const rnn = tf.layers.gru({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `GRUCell`'s number of units.\n */\nexport class GRU extends RNN {\n static className = 'GRU';\n constructor(config: GRULayerConfig) {\n if (config.implementation === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new GRUCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as GRUCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as GRUCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as GRUCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as GRUCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as GRUCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as GRUCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as GRUCell).biasInitializer;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as GRUCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as GRUCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as GRUCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as GRUCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as GRUCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as GRUCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as GRUCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as GRUCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as GRUCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(GRU);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we extend\n// that interface instead of repeating the fields.\nexport interface LSTMCellLayerConfig extends SimpleRNNCellLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: ActivationIdentifier;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n *\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions.\n *\n * Mode 2 will batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Cell class for `LSTM`.\n *\n * `LSTMCell` is distinct from the `RNN` subclass `LSTM` in that its\n * `apply` method takes the input data of only a single time step and returns\n * the cell's output at the time step, while `LSTM` takes the input data\n * over a number of time steps. For example:\n *\n * ```js\n * const cell = tf.layers.lstmCell({units: 2});\n * const input = tf.input({shape: [10]});\n * const output = cell.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10]: This is the cell's output at a single time step. The 1st\n * // dimension is the unknown batch size.\n * ```\n *\n * Instance(s) of `LSTMCell` can be used to construct `RNN` layers. The\n * most typical use of this workflow is to combine a number of cells into a\n * stacked RNN cell (i.e., `StackedRNNCell` internally) and use it to create an\n * RNN. For example:\n *\n * ```js\n * const cells = [\n * tf.layers.lstmCell({units: 4}),\n * tf.layers.lstmCell({units: 8}),\n * ];\n * const rnn = tf.layers.rnn({cell: cells, returnSequences: true});\n *\n * // Create an input with 10 time steps and a length-20 vector at each step.\n * const input = tf.input({shape: [10, 20]});\n * const output = rnn.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the last `lstmCell`'s number of units.\n * ```\n *\n * To create an `RNN` consisting of only *one* `LSTMCell`, use the\n * `tf.layers.lstm`.\n */\nexport class LSTMCell extends RNNCell {\n static className = 'LSTMCell';\n readonly units: number;\n readonly activation: Activation;\n readonly recurrentActivation: Activation;\n readonly useBias: boolean;\n\n readonly kernelInitializer: Initializer;\n readonly recurrentInitializer: Initializer;\n readonly biasInitializer: Initializer;\n readonly unitForgetBias: boolean;\n\n readonly kernelConstraint: Constraint;\n readonly recurrentConstraint: Constraint;\n readonly biasConstraint: Constraint;\n\n readonly kernelRegularizer: Regularizer;\n readonly recurrentRegularizer: Regularizer;\n readonly biasRegularizer: Regularizer;\n\n readonly dropout: number;\n readonly recurrentDropout: number;\n\n readonly stateSize: number[];\n readonly implementation: number;\n\n readonly DEFAULT_ACTIVATION = 'tanh';\n readonly DEFAULT_RECURRENT_ACTIVATION = 'hardSigmoid';\n readonly DEFAULT_KERNEL_INITIALIZER = 'glorotNormal';\n readonly DEFAULT_RECURRENT_INITIALIZER = 'orthogonal';\n\n readonly DEFAULT_BIAS_INITIALIZER = 'zeros';\n\n kernel: LayerVariable;\n recurrentKernel: LayerVariable;\n bias: LayerVariable;\n\n constructor(config: LSTMCellLayerConfig) {\n super(config);\n\n this.units = config.units;\n this.activation = getActivation(\n config.activation === undefined ? this.DEFAULT_ACTIVATION :\n config.activation);\n this.recurrentActivation = getActivation(\n config.recurrentActivation === undefined ?\n this.DEFAULT_RECURRENT_ACTIVATION :\n config.recurrentActivation);\n this.useBias = config.useBias == null ? true : config.useBias;\n\n this.kernelInitializer = getInitializer(\n config.kernelInitializer || this.DEFAULT_KERNEL_INITIALIZER);\n this.recurrentInitializer = getInitializer(\n config.recurrentInitializer || this.DEFAULT_RECURRENT_INITIALIZER);\n\n this.biasInitializer =\n getInitializer(config.biasInitializer || this.DEFAULT_BIAS_INITIALIZER);\n this.unitForgetBias = config.unitForgetBias;\n\n this.kernelRegularizer = getRegularizer(config.kernelRegularizer);\n this.recurrentRegularizer = getRegularizer(config.recurrentRegularizer);\n this.biasRegularizer = getRegularizer(config.biasRegularizer);\n\n this.kernelConstraint = getConstraint(config.kernelConstraint);\n this.recurrentConstraint = getConstraint(config.recurrentConstraint);\n this.biasConstraint = getConstraint(config.biasConstraint);\n\n this.dropout = math_utils.min(\n [1, math_utils.max([0, config.dropout == null ? 0 : config.dropout])]);\n this.recurrentDropout = math_utils.min([\n 1,\n math_utils.max(\n [0, config.recurrentDropout == null ? 0 : config.recurrentDropout])\n ]);\n this.implementation = config.implementation;\n this.stateSize = [this.units, this.units];\n this.dropoutMask = null;\n this.recurrentDropoutMask = null;\n }\n\n public build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n const inputDim = inputShape[inputShape.length - 1];\n this.kernel = this.addWeight(\n 'kernel', [inputDim, this.units * 4], null, this.kernelInitializer,\n this.kernelRegularizer, true, this.kernelConstraint);\n this.recurrentKernel = this.addWeight(\n 'recurrent_kernel', [this.units, this.units * 4], null,\n this.recurrentInitializer, this.recurrentRegularizer, true,\n this.recurrentConstraint);\n let biasInitializer: Initializer;\n if (this.useBias) {\n if (this.unitForgetBias) {\n const capturedBiasInit = this.biasInitializer;\n const capturedUnits = this.units;\n biasInitializer = new (class CustomInit extends Initializer {\n static className = 'CustomInit';\n\n apply(shape: Shape, dtype?: DataType): Tensor {\n // TODO(cais): More informative variable names?\n const bI = capturedBiasInit.apply([capturedUnits]);\n const bF = (new Ones()).apply([capturedUnits]);\n const bCAndH = capturedBiasInit.apply([capturedUnits * 2]);\n return K.concatAlongFirstAxis(\n K.concatAlongFirstAxis(bI, bF), bCAndH);\n }\n })();\n } else {\n biasInitializer = this.biasInitializer;\n }\n this.bias = this.addWeight(\n 'bias', [this.units * 4], null, biasInitializer, this.biasRegularizer,\n true, this.biasConstraint);\n } else {\n this.bias = null;\n }\n // Porting Notes: Unlike the PyKeras implementation, we perform slicing\n // of the weights and bias in the call() method, at execution time.\n this.built = true;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n const training = kwargs['training'] == null ? false : kwargs['training'];\n inputs = inputs as Tensor[];\n if (inputs.length !== 3) {\n throw new ValueError(\n `LSTMCell expects 3 input Tensors (inputs, h, c), got ` +\n `${inputs.length}.`);\n }\n let hTMinus1 = inputs[1]; // Previous memory state.\n const cTMinus1 = inputs[2]; // Previous carry state.\n inputs = inputs[0];\n if (0 < this.dropout && this.dropout < 1 && this.dropoutMask == null) {\n this.dropoutMask = generateDropoutMask(\n () => tfc.onesLike(inputs as Tensor),\n this.dropout, training, 4) as Tensor[];\n }\n if (0 < this.recurrentDropout && this.recurrentDropout < 1 &&\n this.recurrentDropoutMask == null) {\n this.recurrentDropoutMask =\n generateDropoutMask(\n () => tfc.onesLike(hTMinus1), this.recurrentDropout, training,\n 4) as Tensor[];\n }\n const dpMask = this.dropoutMask as [Tensor, Tensor, Tensor, Tensor];\n const recDpMask =\n this.recurrentDropoutMask as [Tensor, Tensor, Tensor, Tensor];\n\n let i: Tensor;\n let f: Tensor;\n let c: Tensor;\n let o: Tensor;\n if (this.implementation === 1) {\n const kernelI = K.sliceAlongLastAxis(this.kernel.read(), 0, this.units);\n const kernelF =\n K.sliceAlongLastAxis(this.kernel.read(), this.units, this.units);\n const kernelC = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 2, this.units);\n const kernelO = K.sliceAlongLastAxis(\n this.kernel.read(), this.units * 3, this.units);\n const recurrentKernelI =\n K.sliceAlongLastAxis(this.recurrentKernel.read(), 0, this.units);\n const recurrentKernelF = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units, this.units);\n const recurrentKernelC = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 2, this.units);\n const recurrentKernelO = K.sliceAlongLastAxis(\n this.recurrentKernel.read(), this.units * 3, this.units);\n\n let inputsI: Tensor, inputsF: Tensor, inputsC: Tensor, inputsO: Tensor;\n if (0 < this.dropout && this.dropout < 1) {\n inputsI = tfc.mul(inputs, dpMask[0]);\n inputsF = tfc.mul(inputs, dpMask[1]);\n inputsC = tfc.mul(inputs, dpMask[2]);\n inputsO = tfc.mul(inputs, dpMask[3]);\n } else {\n inputsI = inputs;\n inputsF = inputs;\n inputsC = inputs;\n inputsO = inputs;\n }\n\n let xI = K.dot(inputsI, kernelI);\n let xF = K.dot(inputsF, kernelF);\n let xC = K.dot(inputsC, kernelC);\n let xO = K.dot(inputsO, kernelO);\n if (this.useBias) {\n const biasI = K.sliceAlongFirstAxis(this.bias.read(), 0, this.units);\n const biasF =\n K.sliceAlongFirstAxis(this.bias.read(), this.units, this.units);\n const biasC = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 2, this.units);\n const biasO = K.sliceAlongFirstAxis(\n this.bias.read(), this.units * 3, this.units);\n xI = K.biasAdd(xI, biasI);\n xF = K.biasAdd(xF, biasF);\n xC = K.biasAdd(xC, biasC);\n xO = K.biasAdd(xO, biasO);\n }\n\n let hTMinus1I: Tensor, hTMinus1F: Tensor, hTMinus1C: Tensor,\n hTMinus1O: Tensor;\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1I = tfc.mul(hTMinus1, recDpMask[0]);\n hTMinus1F = tfc.mul(hTMinus1, recDpMask[1]);\n hTMinus1C = tfc.mul(hTMinus1, recDpMask[2]);\n hTMinus1O = tfc.mul(hTMinus1, recDpMask[3]);\n } else {\n hTMinus1I = hTMinus1;\n hTMinus1F = hTMinus1;\n hTMinus1C = hTMinus1;\n hTMinus1O = hTMinus1;\n }\n i = this.recurrentActivation.apply(\n tfc.add(xI, K.dot(hTMinus1I, recurrentKernelI)));\n f = this.recurrentActivation.apply(\n tfc.add(xF, K.dot(hTMinus1F, recurrentKernelF)));\n c = tfc.add(\n tfc.mul(f, cTMinus1),\n tfc.mul(\n i,\n this.activation.apply(\n tfc.add(xC, K.dot(hTMinus1C, recurrentKernelC)))));\n o = this.recurrentActivation.apply(\n tfc.add(xO, K.dot(hTMinus1O, recurrentKernelO)));\n } else {\n if (0 < this.dropout && this.dropout < 1) {\n inputs = tfc.mul(inputs, dpMask[0]);\n }\n let z = K.dot(inputs, this.kernel.read());\n if (0 < this.recurrentDropout && this.recurrentDropout < 1) {\n hTMinus1 = tfc.mul(hTMinus1, recDpMask[0]);\n }\n z = tfc.add(z, K.dot(hTMinus1, this.recurrentKernel.read()));\n if (this.useBias) {\n z = K.biasAdd(z, this.bias.read());\n }\n\n const z0 = K.sliceAlongLastAxis(z, 0, this.units);\n const z1 = K.sliceAlongLastAxis(z, this.units, this.units);\n const z2 = K.sliceAlongLastAxis(z, this.units * 2, this.units);\n const z3 = K.sliceAlongLastAxis(z, this.units * 3, this.units);\n\n i = this.recurrentActivation.apply(z0);\n f = this.recurrentActivation.apply(z1);\n c = tfc.add(\n tfc.mul(f, cTMinus1), tfc.mul(i, this.activation.apply(z2)));\n o = this.recurrentActivation.apply(z3);\n }\n\n const h = tfc.mul(o, this.activation.apply(c));\n // TODO(cais): Add use_learning_phase flag properly.\n return [h, h, c];\n });\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n}\nserialization.SerializationMap.register(LSTMCell);\n\n// Porting Note: Since this is a superset of SimpleRNNLayerConfig, we inherit\n// from that interface instead of repeating the fields here.\nexport interface LSTMLayerConfig extends SimpleRNNLayerConfig {\n /**\n * Activation function to use for the recurrent step.\n *\n * Defaults to hard sigmoid (`hardSigomid`).\n *\n * If `null`, no activation is applied.\n */\n recurrentActivation?: string;\n\n /**\n * If `true`, add 1 to the bias of the forget gate at initialization.\n * Setting it to `true` will also force `biasInitializer = 'zeros'`.\n * This is recommended in\n * [Jozefowicz et\n * al.](http://www.jmlr.org/proceedings/papers/v37/jozefowicz15.pdf).\n */\n unitForgetBias?: boolean;\n\n /**\n * Implementation mode, either 1 or 2.\n * Mode 1 will structure its operations as a larger number of\n * smaller dot products and additions, whereas mode 2 will\n * batch them into fewer, larger operations. These modes will\n * have different performance profiles on different hardware and\n * for different applications.\n */\n implementation?: 1|2;\n}\n\n/**\n * Long-Short Term Memory layer - Hochreiter 1997.\n *\n * This is an `RNN` layer consisting of one `LSTMCell`. However, unlike\n * the underlying `LSTMCell`, the `apply` method of `LSTM` operates\n * on a sequence of inputs. The shape of the input (not including the first,\n * batch dimension) needs to be at least 2-D, with the first dimension being\n * time steps. For example:\n *\n * ```js\n * const lstm = tf.layers.lstm({units: 8, returnSequences: true});\n *\n * // Create an input with 10 time steps.\n * const input = tf.input({shape: [10, 20]});\n * const output = lstm.apply(input);\n *\n * console.log(JSON.stringify(output.shape));\n * // [null, 10, 8]: 1st dimension is unknown batch size; 2nd dimension is the\n * // same as the sequence length of `input`, due to `returnSequences`: `true`;\n * // 3rd dimension is the `LSTMCell`'s number of units.\n */\nexport class LSTM extends RNN {\n static className = 'LSTM';\n constructor(config: LSTMLayerConfig) {\n if (config.implementation as number === 0) {\n console.warn(\n '`implementation=0` has been deprecated, and now defaults to ' +\n '`implementation=1`. Please update your layer call.');\n }\n config.cell = new LSTMCell(config);\n super(config as RNNLayerConfig);\n // TODO(cais): Add activityRegularizer.\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (this.cell.dropoutMask != null) {\n tfc.dispose(this.cell.dropoutMask);\n this.cell.dropoutMask = null;\n }\n if (this.cell.recurrentDropoutMask != null) {\n tfc.dispose(this.cell.recurrentDropoutMask);\n this.cell.recurrentDropoutMask = null;\n }\n const mask = kwargs == null ? null : kwargs['mask'];\n const training = kwargs == null ? null : kwargs['training'];\n const initialState: Tensor[] =\n kwargs == null ? null : kwargs['initialState'];\n return super.call(inputs, {mask, training, initialState});\n });\n }\n\n get units(): number {\n return (this.cell as LSTMCell).units;\n }\n\n get activation(): Activation {\n return (this.cell as LSTMCell).activation;\n }\n\n get recurrentActivation(): Activation {\n return (this.cell as LSTMCell).recurrentActivation;\n }\n\n get useBias(): boolean {\n return (this.cell as LSTMCell).useBias;\n }\n\n get kernelInitializer(): Initializer {\n return (this.cell as LSTMCell).kernelInitializer;\n }\n\n get recurrentInitializer(): Initializer {\n return (this.cell as LSTMCell).recurrentInitializer;\n }\n\n get biasInitializer(): Initializer {\n return (this.cell as LSTMCell).biasInitializer;\n }\n\n get unitForgetBias(): boolean {\n return (this.cell as LSTMCell).unitForgetBias;\n }\n\n get kernelRegularizer(): Regularizer {\n return (this.cell as LSTMCell).kernelRegularizer;\n }\n\n get recurrentRegularizer(): Regularizer {\n return (this.cell as LSTMCell).recurrentRegularizer;\n }\n\n get biasRegularizer(): Regularizer {\n return (this.cell as LSTMCell).biasRegularizer;\n }\n\n get kernelConstraint(): Constraint {\n return (this.cell as LSTMCell).kernelConstraint;\n }\n\n get recurrentConstraint(): Constraint {\n return (this.cell as LSTMCell).recurrentConstraint;\n }\n\n get biasConstraint(): Constraint {\n return (this.cell as LSTMCell).biasConstraint;\n }\n\n get dropout(): number {\n return (this.cell as LSTMCell).dropout;\n }\n\n get recurrentDropout(): number {\n return (this.cell as LSTMCell).recurrentDropout;\n }\n\n get implementation(): number {\n return (this.cell as LSTMCell).implementation;\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n units: this.units,\n activation: serializeActivation(this.activation),\n recurrentActivation: serializeActivation(this.recurrentActivation),\n useBias: this.useBias,\n kernelInitializer: serializeInitializer(this.kernelInitializer),\n recurrentInitializer: serializeInitializer(this.recurrentInitializer),\n biasInitializer: serializeInitializer(this.biasInitializer),\n unitForgetBias: this.unitForgetBias,\n kernelRegularizer: serializeRegularizer(this.kernelRegularizer),\n recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer),\n biasRegularizer: serializeRegularizer(this.biasRegularizer),\n activityRegularizer: serializeRegularizer(this.activityRegularizer),\n kernelConstraint: serializeConstraint(this.kernelConstraint),\n recurrentConstraint: serializeConstraint(this.recurrentConstraint),\n biasConstraint: serializeConstraint(this.biasConstraint),\n dropout: this.dropout,\n recurrentDropout: this.recurrentDropout,\n implementation: this.implementation,\n };\n const baseConfig = super.getConfig();\n delete baseConfig['cell'];\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n if (config['implmentation'] === 0) {\n config['implementation'] = 1;\n }\n return new cls(config);\n }\n}\nserialization.SerializationMap.register(LSTM);\n\nexport interface StackedRNNCellsConfig extends LayerConfig {\n /**\n * A `Array` of `RNNCell` instances.\n */\n cells: RNNCell[];\n}\n\n/**\n * Wrapper allowing a stack of RNN cells to behave as a single cell.\n *\n * Used to implement efficient stacked RNNs.\n */\nexport class StackedRNNCells extends RNNCell {\n static className = 'StackedRNNCells';\n protected cells: RNNCell[];\n\n constructor(config: StackedRNNCellsConfig) {\n super(config);\n this.cells = config.cells;\n }\n\n get stateSize(): number[] {\n // States are a flat list in reverse order of the cell stack.\n // This allows perserving the requirement `stack.statesize[0] ===\n // outputDim`. E.g., states of a 2-layer LSTM would be `[h2, c2, h1, c1]`,\n // assuming one LSTM has states `[h, c]`.\n const stateSize: number[] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n stateSize.push(...cell.stateSize);\n } else {\n stateSize.push(cell.stateSize);\n }\n }\n return stateSize;\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n inputs = inputs as Tensor[];\n let states = inputs.slice(1);\n\n // Recover per-cell states.\n const nestedStates: Tensor[][] = [];\n for (const cell of this.cells.slice().reverse()) {\n if (Array.isArray(cell.stateSize)) {\n nestedStates.push(states.splice(0, cell.stateSize.length));\n } else {\n nestedStates.push(states.splice(0, 1));\n }\n }\n nestedStates.reverse();\n\n // Call the cells in order and store the returned states.\n const newNestedStates: Tensor[][] = [];\n let callInputs: Tensor[];\n for (let i = 0; i < this.cells.length; ++i) {\n const cell = this.cells[i];\n states = nestedStates[i];\n // TODO(cais): Take care of constants.\n if (i === 0) {\n callInputs = [inputs[0]].concat(states);\n } else {\n callInputs = [callInputs[0]].concat(states);\n }\n callInputs = cell.call(callInputs, kwargs) as Tensor[];\n newNestedStates.push(callInputs.slice(1));\n }\n\n // Format the new states as a flat list in reverse cell order.\n states = [];\n for (const cellStates of newNestedStates.slice().reverse()) {\n states.push(...cellStates);\n }\n return [callInputs[0]].concat(states);\n });\n }\n\n public build(inputShape: Shape|Shape[]): void {\n if (isArrayOfShapes(inputShape)) {\n // TODO(cais): Take care of input constants.\n // const constantShape = inputShape.slice(1);\n inputShape = (inputShape as Shape[])[0];\n }\n inputShape = inputShape as Shape;\n let outputDim: number;\n for (const cell of this.cells) {\n // TODO(cais): Take care of input constants.\n cell.build(inputShape);\n if (Array.isArray(cell.stateSize)) {\n outputDim = cell.stateSize[0];\n } else {\n outputDim = cell.stateSize;\n }\n inputShape = [inputShape[0], outputDim];\n }\n this.built = true;\n }\n\n getConfig(): serialization.ConfigDict {\n const cellConfigs: serialization.ConfigDict[] = [];\n for (const cell of this.cells) {\n cellConfigs.push({\n 'className': this.getClassName(),\n 'config': cell.getConfig(),\n });\n }\n const config: serialization.ConfigDict = {'cells': cellConfigs};\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const cells: RNNCell[] = [];\n for (const cellConfig of (config['cells'] as serialization.ConfigDict[])) {\n cells.push(deserialize(cellConfig, customObjects) as RNNCell);\n }\n return new cls({cells});\n }\n\n get trainableWeights(): LayerVariable[] {\n if (!this.trainable) {\n return [];\n }\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.trainableWeights);\n }\n return weights;\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.nonTrainableWeights);\n }\n if (!this.trainable) {\n const trainableWeights: LayerVariable[] = [];\n for (const cell of this.cells) {\n trainableWeights.push(...cell.trainableWeights);\n }\n return trainableWeights.concat(weights);\n }\n return weights;\n }\n\n /**\n * Retrieve the weights of a the model.\n *\n * @returns A flat `Array` of `Tensor`s.\n */\n getWeights(): Tensor[] {\n const weights: LayerVariable[] = [];\n for (const cell of this.cells) {\n weights.push(...cell.weights);\n }\n return batchGetValue(weights);\n }\n\n /**\n * Set the weights of the model.\n *\n * @param weights An `Array` of `Tensor`s with shapes and types matching the\n * output of `getWeights()`.\n */\n setWeights(weights: Tensor[]): void {\n const tuples: Array<[LayerVariable, Tensor]> = [];\n for (const cell of this.cells) {\n const numParams = cell.weights.length;\n const inputWeights = weights.splice(numParams);\n for (let i = 0; i < cell.weights.length; ++i) {\n tuples.push([cell.weights[i], inputWeights[i]]);\n }\n }\n batchSetValue(tuples);\n }\n\n // TODO(cais): Maybe implemnt `losses` and `getLossesFor`.\n}\nserialization.SerializationMap.register(StackedRNNCells);\n\nfunction generateDropoutMask(\n ones: () => Tensor, rate: number, training: boolean = null,\n count = 1): Tensor|Tensor[] {\n function droppedInputs(): Tensor {\n return K.dropout(ones(), getScalar(rate));\n }\n if (count > 1) {\n const mask: Tensor[] = [];\n for (let i = 0; i < count; i++) {\n mask.push(K.inTrainPhase(droppedInputs, ones, training));\n }\n mask.forEach(m => tfc.keep(m));\n return mask;\n } else {\n return tfc.keep(K.inTrainPhase(droppedInputs, ones, training));\n }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/**\n * Layers that augment the functionality of a base layer.\n */\n\n// tslint:disable:max-line-length\nimport * as tfc from '@tensorflow/tfjs-core';\nimport {serialization, Tensor, tidy} from '@tensorflow/tfjs-core';\n\nimport {getScalar} from '../backend/state';\nimport * as K from '../backend/tfjs_backend';\nimport {nameScope} from '../common';\nimport {InputSpec, Layer, LayerConfig, SymbolicTensor} from '../engine/topology';\nimport {NotImplementedError, ValueError} from '../errors';\nimport {Kwargs, Shape} from '../types';\nimport {RegularizerFn, RnnStepFunction} from '../types';\nimport * as generic_utils from '../utils/generic_utils';\nimport {getExactlyOneShape, getExactlyOneTensor} from '../utils/types_utils';\nimport {LayerVariable} from '../variables';\n\nimport {rnn, RNN, standardizeArgs} from './recurrent';\nimport {deserialize} from './serialization';\n\n// tslint:enable:max-line-length\n\nexport interface WrapperLayerConfig extends LayerConfig {\n /**\n * The layer to be wrapped.\n */\n layer: Layer;\n}\n\n/**\n * Abstract wrapper base class.\n *\n * Wrappers take another layer and augment it in various ways.\n * Do not use this class as a layer, it is only an abstract base class.\n * Two usable wrappers are the `TimeDistributed` and `Bidirectional` wrappers.\n */\nexport abstract class Wrapper extends Layer {\n readonly layer: Layer;\n\n constructor(config: WrapperLayerConfig) {\n // Porting Note: In PyKeras, `self.layer` is set prior to the calling\n // `super()`. But we can't do that here due to TypeScript's restriction.\n // See: https://github.com/Microsoft/TypeScript/issues/8277\n // As a result, we have to add checks in `get trainable()` and\n // `set trainable()` below in order to prevent using `this.layer` when\n // its value is `undefined`. The super constructor does use the getter\n // and the setter of `this.layer`.\n super(config);\n this.layer = config.layer;\n }\n\n build(inputShape: Shape|Shape[]): void {\n this.built = true;\n }\n\n // TODO(cais): Implement activityRegularizer getter.\n\n get trainable(): boolean {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n return this.layer.trainable;\n } else {\n return false;\n }\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n if (this.layer != null) {\n this.layer.trainable = value;\n }\n }\n\n get trainableWeights(): LayerVariable[] {\n return this.layer.trainableWeights;\n }\n // TODO(cais): Implement setter for trainableWeights.\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.layer.nonTrainableWeights;\n }\n // TODO(cais): Implement setter for nonTrainableWeights.\n\n get updates(): Tensor[] {\n // tslint:disable-next-line:no-any\n return (this.layer as any)._updates;\n }\n\n // TODO(cais): Implement getUpdatesFor().\n\n get losses(): RegularizerFn[] {\n return this.layer.losses;\n }\n\n // TODO(cais): Implement getLossesFor().\n\n getWeights(): Tensor[] {\n return this.layer.getWeights();\n }\n\n setWeights(weights: Tensor[]): void {\n this.layer.setWeights(weights);\n }\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'layer': {\n 'className': this.layer.getClassName(),\n 'config': this.layer.getConfig(),\n }\n };\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict,\n customObjects = {} as serialization.ConfigDict): T {\n const layerConfig = config['layer'] as serialization.ConfigDict;\n const layer = deserialize(layerConfig, customObjects) as Layer;\n delete config['layer'];\n const newConfig = {layer};\n Object.assign(newConfig, config);\n return new cls(newConfig);\n }\n}\n\n/**\n * This wrapper applies a layer to every temporal slice of an input.\n *\n * The input should be at least 3D, and the dimension of the index `1` will be\n * considered to be the temporal dimension.\n *\n * Consider a batch of 32 samples, where each sample is a sequence of 10 vectors\n * of 16 dimensions. The batch input shape of the layer is then `[32, 10,\n * 16]`, and the `inputShape`, not including the sample dimension, is\n * `[10, 16]`.\n *\n * You can then use `TimeDistributed` to apply a `Dense` layer to each of the 10\n * timesteps, independently:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.dense({units: 8}),\n * inputShape: [10, 16],\n * }));\n *\n * // Now model.outputShape = [null, 10, 8].\n * // The output will then have shape `[32, 10, 8]`.\n *\n * // In subsequent layers, there is no need for `inputShape`:\n * model.add(tf.layers.timeDistributed({layer: tf.layers.dense({units: 32})}));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * // Now model.outputShape = [null, 10, 32].\n * ```\n *\n * The output will then have shape `[32, 10, 32]`.\n *\n * `TimeDistributed` can be used with arbitrary layers, not just `Dense`, for\n * instance a `Conv2D` layer.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.timeDistributed({\n * layer: tf.layers.conv2d({filters: 64, kernelSize: [3, 3]}),\n * inputShape: [10, 299, 299, 3],\n * }));\n * console.log(JSON.stringify(model.outputs[0].shape));\n * ```\n */\nexport class TimeDistributed extends Wrapper {\n static className = 'TimeDistributed';\n constructor(config: WrapperLayerConfig) {\n super(config);\n this.supportsMasking = true;\n }\n\n build(inputShape: Shape|Shape[]): void {\n inputShape = getExactlyOneShape(inputShape);\n if (inputShape.length < 3) {\n throw new ValueError(\n `TimeDistributed layer expects an input shape >= 3D, but received ` +\n `input shape ${JSON.stringify(inputShape)}`);\n }\n this.inputSpec = [{shape: inputShape}];\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n if (!this.layer.built) {\n this.layer.build(childInputShape);\n this.layer.built = true;\n }\n super.build(inputShape);\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n inputShape = getExactlyOneShape(inputShape);\n const childInputShape = [inputShape[0]].concat(inputShape.slice(2));\n const childOutputShape =\n this.layer.computeOutputShape(childInputShape) as Shape;\n const timesteps = inputShape[1];\n return [childOutputShape[0], timesteps].concat(childOutputShape.slice(1));\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n // TODO(cais): Add 'training' and 'useLearningPhase' to kwargs.\n inputs = getExactlyOneTensor(inputs);\n // Porting Note: In tfjs-layers, `inputs` are always concrete tensor\n // values. Hence the inputs can't have an undetermined first (batch)\n // dimension, which is why we always use the K.rnn approach here.\n const step: RnnStepFunction = (inputs: Tensor, states: Tensor[]) => {\n // TODO(cais): Add useLearningPhase.\n const output = this.layer.call(inputs, kwargs) as Tensor;\n return [output, []];\n };\n const rnnOutputs =\n rnn(step, inputs, [], false, null, null, false, inputs.shape[1]);\n const y = rnnOutputs[1];\n // TODO(cais): Add activity regularization.\n // TODO(cais): Add useLearningPhase.\n return y;\n });\n }\n}\nserialization.SerializationMap.register(TimeDistributed);\n\nexport type BidirectionalMergeMode = 'sum'|'mul'|'concat'|'ave';\nexport const VALID_BIDIRECTIONAL_MERGE_MODES = ['sum', 'mul', 'concat', 'ave'];\nexport function checkBidirectionalMergeMode(value?: string): void {\n generic_utils.checkStringTypeUnionValue(\n VALID_BIDIRECTIONAL_MERGE_MODES, 'BidirectionalMergeMode', value);\n}\n\nexport interface BidirectionalLayerConfig extends WrapperLayerConfig {\n /**\n * The instance of an `RNN` layer to be wrapped.\n */\n layer: RNN;\n\n /**\n * Mode by which outputs of the forward and backward RNNs are combinied.\n * If `null` or `undefined`, the output will not be combined, they will be\n * returned as an `Array`.\n */\n mergeMode?: BidirectionalMergeMode;\n}\n\nexport class Bidirectional extends Wrapper {\n static className = 'Bidirectional';\n private forwardLayer: RNN;\n private backwardLayer: RNN;\n private mergeMode: BidirectionalMergeMode;\n private returnSequences: boolean;\n private returnState: boolean;\n private numConstants?: number;\n private _trainable: boolean;\n\n constructor(config: BidirectionalLayerConfig) {\n super(config);\n\n // Note: When creating `this.forwardLayer`, the original Layer object\n // (`config.layer`) ought to be cloned. This is why we call `getConfig()`\n // followed by `deserialize()`. Without this cloning, the layer names\n // saved during serialization will incorrectly contain the 'forward_'\n // prefix.\n // In Python Keras, this is done using `copy.copy` (shallow copy), which\n // does not have a simple equivalent in JavaScript. JavaScript's\n // `Object.assign()` does not copy methods.\n const layerConfig = config.layer.getConfig();\n this.forwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n layerConfig['goBackwards'] =\n layerConfig['goBackwards'] === true ? false : true;\n this.backwardLayer =\n deserialize(\n {className: config.layer.getClassName(), config: layerConfig}) as\n RNN;\n this.forwardLayer.name = 'forward_' + this.forwardLayer.name;\n this.backwardLayer.name = 'backward_' + this.backwardLayer.name;\n checkBidirectionalMergeMode(config.mergeMode);\n this.mergeMode = config.mergeMode;\n if (config.weights) {\n throw new NotImplementedError(\n 'weights support is not implemented for Bidirectional layer yet.');\n }\n this._stateful = config.layer.stateful;\n this.returnSequences = config.layer.returnSequences;\n this.returnState = config.layer.returnState;\n this.supportsMasking = true;\n this._trainable = true;\n this.inputSpec = config.layer.inputSpec;\n this.numConstants = null;\n }\n\n get trainable(): boolean {\n return this._trainable;\n }\n\n set trainable(value: boolean) {\n // Porting Note: the check of `this.layer` here is necessary due to the\n // way the `constructor` of this class is written (see Porting Note\n // above).\n this._trainable = value;\n if (this.forwardLayer != null) {\n this.forwardLayer.trainable = value;\n }\n if (this.backwardLayer != null) {\n this.backwardLayer.trainable = value;\n }\n }\n\n getWeights(): Tensor[] {\n return this.forwardLayer.getWeights().concat(\n this.backwardLayer.getWeights());\n }\n\n setWeights(weights: Tensor[]): void {\n const numWeights = weights.length;\n const numeightsOver2 = Math.floor(numWeights / 2);\n this.forwardLayer.setWeights(weights.slice(0, numeightsOver2));\n this.backwardLayer.setWeights(weights.slice(numeightsOver2));\n }\n\n computeOutputShape(inputShape: Shape|Shape[]): Shape|Shape[] {\n let layerShapes: Shape|Shape[] =\n this.forwardLayer.computeOutputShape(inputShape);\n if (!(Array.isArray(layerShapes) && Array.isArray(layerShapes[0]))) {\n layerShapes = [layerShapes as Shape];\n }\n layerShapes = layerShapes as Shape[];\n\n let outputShape: Shape;\n let outputShapes: Shape[];\n let stateShape: Shape[];\n if (this.returnState) {\n stateShape = layerShapes.slice(1);\n outputShape = layerShapes[0];\n } else {\n outputShape = layerShapes[0];\n }\n outputShape = outputShape as Shape;\n if (this.mergeMode === 'concat') {\n outputShape[outputShape.length - 1] *= 2;\n outputShapes = [outputShape];\n } else if (this.mergeMode == null) {\n outputShapes = [outputShape, outputShape.slice()];\n } else {\n outputShapes = [outputShape];\n }\n\n if (this.returnState) {\n if (this.mergeMode == null) {\n return outputShapes.concat(stateShape).concat(stateShape.slice());\n }\n return [outputShape].concat(stateShape).concat(stateShape.slice());\n }\n return generic_utils.singletonOrArray(outputShapes);\n }\n\n apply(\n inputs: Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[],\n kwargs?: Kwargs): Tensor|Tensor[]|SymbolicTensor|SymbolicTensor[] {\n let initialState: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['initialState'];\n let constants: Tensor[]|SymbolicTensor[] =\n kwargs == null ? null : kwargs['constants'];\n if (kwargs == null) {\n kwargs = {};\n }\n const standardized =\n standardizeArgs(inputs, initialState, constants, this.numConstants);\n inputs = standardized.inputs as Tensor | SymbolicTensor;\n initialState = standardized.initialState;\n constants = standardized.constants;\n\n if (Array.isArray(inputs)) {\n initialState = (inputs as Tensor[] | SymbolicTensor[]).slice(1);\n inputs = (inputs as Tensor[] | SymbolicTensor[])[0];\n }\n\n if ((initialState == null || initialState.length === 0) &&\n constants == null) {\n return super.apply(inputs, kwargs);\n }\n const additionalInputs: Array = [];\n const additionalSpecs: InputSpec[] = [];\n if (initialState != null) {\n const numStates = initialState.length;\n if (numStates % 2 > 0) {\n throw new ValueError(\n 'When passing `initialState` to a Bidrectional RNN, ' +\n 'the state should be an Array containing the states of ' +\n 'the underlying RNNs.');\n }\n kwargs['initialState'] = initialState;\n additionalInputs.push(...initialState);\n const stateSpecs = (initialState as Array)\n .map(state => new InputSpec({shape: state.shape}));\n this.forwardLayer.stateSpec = stateSpecs.slice(0, numStates / 2);\n this.backwardLayer.stateSpec = stateSpecs.slice(numStates / 2);\n additionalSpecs.push(...stateSpecs);\n }\n if (constants != null) {\n throw new NotImplementedError(\n 'Support for constants in Bidirectional layers is not ' +\n 'implemented yet.');\n }\n\n const isSymbolicTensor = additionalInputs[0] instanceof SymbolicTensor;\n for (const tensor of additionalInputs) {\n if (tensor instanceof SymbolicTensor !== isSymbolicTensor) {\n throw new ValueError(\n 'The initial state of a Bidirectional layer cannot be ' +\n 'specified as a mix of symbolic and non-symbolic tensors');\n }\n }\n\n if (isSymbolicTensor) {\n // Compute the full input and specs, including the states.\n const fullInput = [inputs].concat(additionalInputs);\n const fullInputSpec = this.inputSpec.concat(additionalSpecs);\n // Perform the call temporarily and replace inputSpec.\n // Note: with initial states symbolic calls and non-symbolic calls to this\n // method differ in how the initial states are passed. For symbolic calls,\n // the initial states are passed in the first arg, as an Array of\n // SymbolicTensors; for non-symbolic calls, they are passed in the second\n // arg as a part of the kwargs. Hence the need to temporarily modify\n // inputSpec here.\n // TODO(cais): Make refactoring so that this hacky code below is no\n // longer needed.\n const originalInputSpec = this.inputSpec;\n this.inputSpec = fullInputSpec;\n const output =\n super.apply(fullInput as Tensor[] | SymbolicTensor[], kwargs);\n this.inputSpec = originalInputSpec;\n return output;\n } else {\n return super.apply(inputs, kwargs);\n }\n }\n\n call(inputs: Tensor|Tensor[], kwargs: Kwargs): Tensor|Tensor[] {\n return tidy(() => {\n if (kwargs['mask'] != null) {\n throw new NotImplementedError(\n 'The support for masking is not implemented for ' +\n 'Bidirectional layers yet.');\n }\n const initialState = kwargs['initialState'];\n\n let y: Tensor|Tensor[];\n let yRev: Tensor|Tensor[];\n if (initialState == null) {\n y = this.forwardLayer.call(inputs, kwargs);\n yRev = this.backwardLayer.call(inputs, kwargs);\n } else {\n const forwardState = initialState.slice(0, initialState.length / 2);\n const backwardState = initialState.slice(initialState.length / 2);\n y = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: forwardState}));\n yRev = this.forwardLayer.call(\n inputs, Object.assign(kwargs, {initialState: backwardState}));\n }\n\n let states: Tensor[];\n if (this.returnState) {\n if (Array.isArray(y)) {\n states = (y as Tensor[]).slice(1).concat((yRev as Tensor[]).slice(1));\n } else {\n }\n y = (y as Tensor[])[0];\n yRev = (yRev as Tensor[])[0];\n }\n\n if (this.returnSequences) {\n yRev = tfc.reverse(yRev as Tensor, 1);\n }\n\n let output: Tensor|Tensor[];\n if (this.mergeMode === 'concat') {\n output = K.concatenate([y as Tensor, yRev as Tensor]);\n } else if (this.mergeMode === 'sum') {\n output = tfc.add(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode === 'ave') {\n output = tfc.mul(getScalar(0.5), tfc.add(y as Tensor, yRev as Tensor));\n } else if (this.mergeMode === 'mul') {\n output = tfc.mul(y as Tensor, yRev as Tensor);\n } else if (this.mergeMode == null) {\n output = [y as Tensor, yRev as Tensor];\n }\n\n // TODO(cais): Properly set learning phase.\n if (this.returnState) {\n if (this.mergeMode == null) {\n return (output as Tensor[]).concat(states);\n }\n return [output as Tensor].concat(states);\n }\n return output;\n });\n }\n\n resetStates(states?: Tensor|Tensor[]): void {\n this.forwardLayer.resetStates();\n this.backwardLayer.resetStates();\n }\n\n build(inputShape: Shape|Shape[]): void {\n nameScope(this.forwardLayer.name, () => {\n this.forwardLayer.build(inputShape);\n });\n nameScope(this.backwardLayer.name, () => {\n this.backwardLayer.build(inputShape);\n });\n this.built = true;\n }\n\n // TODO(cais): Implement computeMask().\n\n get trainableWeights(): LayerVariable[] {\n return this.forwardLayer.trainableWeights.concat(\n this.backwardLayer.trainableWeights);\n }\n\n get nonTrainableWeights(): LayerVariable[] {\n return this.forwardLayer.nonTrainableWeights.concat(\n this.backwardLayer.nonTrainableWeights);\n }\n\n // TODO(cais): Implement constraints().\n\n getConfig(): serialization.ConfigDict {\n const config: serialization.ConfigDict = {\n 'mergeMode': this.mergeMode,\n };\n // TODO(cais): Add logic for `numConstants` once the property is added.\n const baseConfig = super.getConfig();\n Object.assign(config, baseConfig);\n return config;\n }\n\n static fromConfig(\n cls: serialization.SerializableConstructor,\n config: serialization.ConfigDict): T {\n const rnnLayer =\n deserialize(config['layer'] as serialization.ConfigDict) as RNN;\n delete config['layer'];\n // TODO(cais): Add logic for `numConstants` once the property is added.\n if (config['numConstants'] != null) {\n throw new NotImplementedError(\n `Deserialization of a Bidirectional layer with numConstants ` +\n `present is not supported yet.`);\n }\n // tslint:disable-next-line:no-any\n const newConfig: {[key: string]: any} = config;\n newConfig['layer'] = rnnLayer;\n return new cls(newConfig);\n }\n}\nserialization.SerializationMap.register(Bidirectional);\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable:max-line-length\n\nimport {InputLayer, InputLayerConfig} from './engine/input_layer';\nimport {Layer, LayerConfig} from './engine/topology';\nimport {input} from './exports';\nimport {ELU, ELULayerConfig, LeakyReLU, LeakyReLULayerConfig, Softmax, SoftmaxLayerConfig, ThresholdedReLU, ThresholdedReLULayerConfig} from './layers/advanced_activations';\nimport {Conv1D, Conv2D, Conv2DTranspose, ConvLayerConfig, Cropping2D, Cropping2DLayerConfig, SeparableConv2D, SeparableConvLayerConfig, UpSampling2D, UpSampling2DLayerConfig} from './layers/convolutional';\nimport {DepthwiseConv2D, DepthwiseConv2DLayerConfig} from './layers/convolutional_depthwise';\nimport {Activation, ActivationLayerConfig, Dense, DenseLayerConfig, Dropout, DropoutLayerConfig, Flatten, RepeatVector, RepeatVectorLayerConfig, Reshape, ReshapeLayerConfig} from './layers/core';\nimport {Embedding, EmbeddingLayerConfig} from './layers/embeddings';\nimport {Add, Average, Concatenate, ConcatenateLayerConfig, Maximum, Minimum, Multiply} from './layers/merge';\nimport {BatchNormalization, BatchNormalizationLayerConfig} from './layers/normalization';\nimport {ZeroPadding2D, ZeroPadding2DLayerConfig} from './layers/padding';\nimport {AveragePooling1D, AveragePooling2D, GlobalAveragePooling1D, GlobalAveragePooling2D, GlobalMaxPooling1D, GlobalMaxPooling2D, GlobalPooling2DLayerConfig, MaxPooling1D, MaxPooling2D, Pooling1DLayerConfig, Pooling2DLayerConfig} from './layers/pooling';\nimport {GRU, GRUCell, GRUCellLayerConfig, GRULayerConfig, LSTM, LSTMCell, LSTMCellLayerConfig, LSTMLayerConfig, RNN, RNNCell, RNNLayerConfig, SimpleRNN, SimpleRNNCell, SimpleRNNCellLayerConfig, SimpleRNNLayerConfig, StackedRNNCells, StackedRNNCellsConfig} from './layers/recurrent';\nimport {Bidirectional, BidirectionalLayerConfig, TimeDistributed, Wrapper, WrapperLayerConfig} from './layers/wrappers';\n\n\n// tslint:enable:max-line-length\n\n// TODO(cais): Add doc string to all the public static functions in this\n// class; include exectuable JavaScript code snippets where applicable\n// (b/74074458).\n\n// Input Layer.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Inputs',\n * namespace: 'layers',\n * useDocsFrom: 'InputLayer',\n * configParamIndices: [0]\n * }\n */\nexport function inputLayer(config: InputLayerConfig): Layer {\n return new InputLayer(config);\n}\n\n// Advanced Activation Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ELU',\n * configParamIndices: [0]\n * }\n */\nexport function elu(config?: ELULayerConfig): Layer {\n return new ELU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'LeakyReLU',\n * configParamIndices: [0]\n * }\n */\nexport function leakyReLU(config?: LeakyReLULayerConfig): Layer {\n return new LeakyReLU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'Softmax',\n * configParamIndices: [0]\n * }\n */\nexport function softmax(config?: SoftmaxLayerConfig): Layer {\n return new Softmax(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Advanced Activation',\n * namespace: 'layers',\n * useDocsFrom: 'ThresholdedReLU',\n * configParamIndices: [0]\n * }\n */\nexport function thresholdedReLU(config?: ThresholdedReLULayerConfig): Layer {\n return new ThresholdedReLU(config);\n}\n\n// Convolutional Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv1D',\n * configParamIndices: [0]\n * }\n */\nexport function conv1d(config: ConvLayerConfig): Layer {\n return new Conv1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2D',\n * configParamIndices: [0]\n * }\n */\nexport function conv2d(config: ConvLayerConfig): Layer {\n return new Conv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Conv2DTranspose',\n * configParamIndices: [0]\n * }\n */\nexport function conv2dTranspose(config: ConvLayerConfig): Layer {\n return new Conv2DTranspose(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'SeparableConv2D',\n * configParamIndices: [0]\n * }\n */\nexport function separableConv2d(config: SeparableConvLayerConfig): Layer {\n return new SeparableConv2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'Cropping2D',\n * configParamIndices: [0]\n * }\n */\nexport function cropping2D(config: Cropping2DLayerConfig): Layer {\n return new Cropping2D(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'UpSampling2D',\n * configParamIndices: [0]\n * }\n */\nexport function upSampling2d(config: UpSampling2DLayerConfig): Layer {\n return new UpSampling2D(config);\n}\n\n// Convolutional(depthwise) Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Convolutional',\n * namespace: 'layers',\n * useDocsFrom: 'DepthwiseConv2D',\n * configParamIndices: [0]\n * }\n */\n\nexport function depthwiseConv2d(config: DepthwiseConv2DLayerConfig): Layer {\n return new DepthwiseConv2D(config);\n}\n\n// Basic Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Activation',\n * configParamIndices: [0]\n * }\n */\nexport function activation(config: ActivationLayerConfig): Layer {\n return new Activation(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dense',\n * configParamIndices: [0]\n * }\n */\nexport function dense(config: DenseLayerConfig): Layer {\n return new Dense(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Dropout',\n * configParamIndices: [0]\n * }\n */\nexport function dropout(config: DropoutLayerConfig): Layer {\n return new Dropout(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Flatten',\n * configParamIndices: [0]\n * }\n */\nexport function flatten(config?: LayerConfig): Layer {\n return new Flatten(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'RepeatVector',\n * configParamIndices: [0]\n * }\n */\nexport function repeatVector(config: RepeatVectorLayerConfig): Layer {\n return new RepeatVector(config);\n}\n\n/**\n * @doc{\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Reshape',\n * configParamIndices: [0]\n * }\n */\nexport function reshape(config: ReshapeLayerConfig): Layer {\n return new Reshape(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Basic',\n * namespace: 'layers',\n * useDocsFrom: 'Embedding',\n * configParamIndices: [0]\n * }\n */\nexport function embedding(config: EmbeddingLayerConfig): Layer {\n return new Embedding(config);\n}\n\n// Merge Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Add',\n * configParamIndices: [0]\n * }\n */\nexport function add(config?: LayerConfig): Layer {\n return new Add(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Average',\n * configParamIndices: [0]\n * }\n */\nexport function average(config?: LayerConfig): Layer {\n return new Average(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Concatenate',\n * configParamIndices: [0]\n * }\n */\nexport function concatenate(config?: ConcatenateLayerConfig): Layer {\n return new Concatenate(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Maximum',\n * configParamIndices: [0]\n * }\n */\nexport function maximum(config?: LayerConfig): Layer {\n return new Maximum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Minimum',\n * configParamIndices: [0]\n * }\n */\nexport function minimum(config?: LayerConfig): Layer {\n return new Minimum(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Merge',\n * namespace: 'layers',\n * useDocsFrom: 'Multiply',\n * configParamIndices: [0]\n * }\n */\nexport function multiply(config?: LayerConfig): Layer {\n return new Multiply(config);\n}\n\n// Normalization Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Normalization',\n * namespace: 'layers',\n * useDocsFrom: 'BatchNormalization',\n * configParamIndices: [0]\n * }\n */\nexport function batchNormalization(config: BatchNormalizationLayerConfig):\n Layer {\n return new BatchNormalization(config);\n}\n\n// Padding Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Padding',\n * namespace: 'layers',\n * useDocsFrom: 'ZeroPadding2D',\n * configParamIndices: [0]\n * }\n */\nexport function zeroPadding2d(config?: ZeroPadding2DLayerConfig): Layer {\n return new ZeroPadding2D(config);\n}\n\n// Pooling Layers.\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling1d(config: Pooling1DLayerConfig): Layer {\n return new AveragePooling1D(config);\n}\nexport function avgPool1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling1d(config: Pooling1DLayerConfig): Layer {\n return averagePooling1d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'AveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function averagePooling2d(config: Pooling2DLayerConfig): Layer {\n return new AveragePooling2D(config);\n}\nexport function avgPool2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n// For backwards compatibility.\n// See https://github.com/tensorflow/tfjs/issues/152\nexport function avgPooling2d(config: Pooling2DLayerConfig): Layer {\n return averagePooling2d(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling1d(config: LayerConfig): Layer {\n return new GlobalAveragePooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalAveragePooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalAveragePooling2d(config: GlobalPooling2DLayerConfig):\n Layer {\n return new GlobalAveragePooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling1d(config: LayerConfig): Layer {\n return new GlobalMaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'GlobalMaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function globalMaxPooling2d(config: GlobalPooling2DLayerConfig): Layer {\n return new GlobalMaxPooling2D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling1D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling1d(config: Pooling1DLayerConfig): Layer {\n return new MaxPooling1D(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Pooling',\n * namespace: 'layers',\n * useDocsFrom: 'MaxPooling2D',\n * configParamIndices: [0]\n * }\n */\nexport function maxPooling2d(config: Pooling2DLayerConfig): Layer {\n return new MaxPooling2D(config);\n}\n\n// Recurrent Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRU',\n * configParamIndices: [0]\n * }\n */\nexport function gru(config: GRULayerConfig): Layer {\n return new GRU(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'GRUCell',\n * configParamIndices: [0]\n * }\n */\nexport function gruCell(config: GRUCellLayerConfig): RNNCell {\n return new GRUCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTM',\n * configParamIndices: [0]\n * }\n */\nexport function lstm(config: LSTMLayerConfig): Layer {\n return new LSTM(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'LSTMCell',\n * configParamIndices: [0]\n * }\n */\nexport function lstmCell(config: LSTMCellLayerConfig): RNNCell {\n return new LSTMCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNN',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNN(config: SimpleRNNLayerConfig): Layer {\n return new SimpleRNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'SimpleRNNCell',\n * configParamIndices: [0]\n * }\n */\nexport function simpleRNNCell(config: SimpleRNNCellLayerConfig): RNNCell {\n return new SimpleRNNCell(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function rnn(config: RNNLayerConfig): Layer {\n return new RNN(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Recurrent',\n * namespace: 'layers',\n * useDocsFrom: 'RNN',\n * configParamIndices: [0]\n * }\n */\nexport function stackedRNNCells(config: StackedRNNCellsConfig): RNNCell {\n return new StackedRNNCells(config);\n}\n\n// Wrapper Layers.\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'Bidirectional',\n * configParamIndices: [0]\n * }\n */\nexport function bidirectional(config: BidirectionalLayerConfig): Wrapper {\n return new Bidirectional(config);\n}\n\n/**\n * @doc {\n * heading: 'Layers',\n * subheading: 'Wrapper',\n * namespace: 'layers',\n * useDocsFrom: 'TimeDistributed',\n * configParamIndices: [0]\n * }\n */\nexport function timeDistributed(config: WrapperLayerConfig): Layer {\n return new TimeDistributed(config);\n}\n\n// Aliases for pooling.\nexport const globalMaxPool1d = globalMaxPooling1d;\nexport const globalMaxPool2d = globalMaxPooling2d;\nexport const maxPool1d = maxPooling1d;\nexport const maxPool2d = maxPooling2d;\n\nexport {Layer, input /* alias for tf.input */};\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport {Tensor} from '@tensorflow/tfjs-core';\n\nimport * as losses from './losses';\nimport * as metrics from './metrics';\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryAccuracy'\n * }\n */\nexport function binaryAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'binaryCrossentropy'\n * }\n */\nexport function binaryCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.binaryCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalAccuracy'\n * }\n */\nexport function categoricalAccuracy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalAccuracy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'categoricalCrossentropy'\n * }\n */\nexport function categoricalCrossentropy(yTrue: Tensor, yPred: Tensor): Tensor {\n return metrics.categoricalCrossentropy(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'cosineProximity'\n * }\n */\nexport function cosineProximity(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.cosineProximity(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsoluteError'\n * }\n */\nexport function meanAbsoluteError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsoluteError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanAbsolutePercentageError'\n * }\n */\nexport function meanAbsolutePercentageError(\n yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function MAPE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\nexport function mape(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanAbsolutePercentageError(yTrue, yPred);\n}\n\n/**\n * @doc {\n * heading: 'Metrics',\n * namespace: 'metrics',\n * useDocsFrom: 'meanSquaredError'\n * }\n */\nexport function meanSquaredError(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function MSE(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n\nexport function mse(yTrue: Tensor, yPred: Tensor): Tensor {\n return losses.meanSquaredError(yTrue, yPred);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\nimport * as regularizers from './regularizers';\n// tslint:disable-next-line:max-line-length\nimport {L1Config, L1L2, L1L2Config, L2Config, Regularizer} from './regularizers';\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1l2(config?: L1L2Config): Regularizer {\n return new L1L2(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l1(config?: L1Config): Regularizer {\n return regularizers.l1(config);\n}\n\n/**\n * @doc {\n * heading: 'Regularizers',\n * namespace: 'regularizers',\n * useDocsFrom: 'L1L2',\n * configParamIndices: [0]\n * }\n */\nexport function l2(config?: L2Config): Regularizer {\n return regularizers.l2(config);\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n\n/* Original source: keras/callbacks.py */\n\nimport {BaseCallback} from './base_callbacks';\nimport {Container} from './engine/container';\nimport {Model} from './engine/training';\n\nexport abstract class Callback extends BaseCallback {\n /** Instance of `keras.models.Model`. Reference of the model being trained. */\n model: Model = null;\n\n setModel(model: Container): void {\n if (!(model instanceof Model)) {\n throw new Error('model must be a Model, not some other Container');\n }\n this.model = model as Model;\n }\n}\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.7.2';\nexport {version};\n"],"names":["_epsilon","_nextUniqueTensorId","_uidPrefixes","prefix","toString","scalarCache","float32","int32","DEFAULT_DTYPE","value","dtype","undefined","scalar","keep","message","_super","Object","setPrototypeOf","_this","AttributeError","prototype","tslib_1.__extends","Error","RuntimeError","ValueError","NotImplementedError","AssertionError","IndexError","numValues","Array","isArray","newArray","i","concat","fill","val","array","refernce","counter","array_1","_i","xs","length","x","name","insecure","replace","toLowerCase","identifier","indexOf","m","p1","toUpperCase","_GLOBAL_CUSTOM_OBJECTS","instance","className","getClassName","config","getConfig","moduleObjects","customObjects","printableModuleName","functionName","fn","JSON","stringify","cls","fromConfig","_a","_b","_c","customObjectsCombined","_d","keys","key","_f","_e","backupCustomObjects","_h","_g","returnObj","_k","_j","a","b","numberCompare","out","xs_1","push","obj","hasOwnProperty","values","label","expectedType","minLength","maxLength","assert","every","e","w","axis","tidy","tfc.sqrt","tfc.sum","tfc.mulStrict","Constraint","serialization","Serializable","maxValue","defaultMaxValue","defaultAxis","MaxNorm","norms","calcL2Norms","desired","tfc.clipByValue","tfc.mul","tfc.div","tfc.add","getScalar","epsilon","this","SerializationMap","register","UnitNorm","NonNeg","tfc.relu","minValue","defaultMinValue","rate","defaultRate","MinMaxNorm","CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP","maxNorm","minMaxNorm","nonNeg","unitNorm","constraint","serializeKerasObject","deserializeKerasObject","getMap","classNameMap","deserializeConstraint","nameMap","Map","VALID_DATA_FORMAT_VALUES","checkStringTypeUnionValue","VALID_PADDING_MODE_VALUES","VALID_POOL_MODE_VALUES","_nameScopeStack","_nameScopeDivider","pop","tensorName","isValidTensorName","join","scopedName","has","set","index","get","result","tensorNameRegex","RegExp","match","begin","end","prod","Float32Array","tensor1d","tfc.min","toArray1D","dataSync","tfc.max","asType","outShape","shape","slice","splice","reshape","start","size","rank","tfc.slice1d","tfc.slice2d","tfc.slice3d","tfc.slice4d","sliceAlongFirstAxis","sliceAlongLastAxis","tensors","tfc.concat","tfc.concat1d","tfc.concat2d","tfc.concat3d","tfc.concat4d","n","tfc.tile","mean","stddev","seed","tfc.randomNormal","y","tfc.matMul","xShape0","xShape1","xShape2","reference","indices","toInt","tfc.gather","bias","dataFormat","checkDataFormat","biasShape","add","level","noiseShape","util","arraysEqual","multiplier","tfc.step","tfc.neg","tfc.randomUniform","tfc.sub","alt","training","VALID_FAN_MODE_VALUES","VALID_DISTRIBUTION_VALUES","Initializer","Zeros","zeros","Ones","ones","Constant","mul","minval","DEFAULT_MINVAL","maxval","DEFAULT_MAXVAL","RandomUniform","randomUniform","DEFAULT_MEAN","DEFAULT_STDDEV","RandomNormal","K.randomNormal","TruncatedNormal","truncatedNormal","gain","Identity","eye","scale","mode","distribution","checkDistribution","VarianceScaling","fans","fanIn","fanOut","receptiveFieldSize","arrayProd","shapeProd","Math","sqrt","computeFans","max","limit","GlorotUniform","GlorotNormal","HeNormal","LeCunNormal","DEFAULT_GAIN","Orthogonal","console","warn","q","linalg","gramSchmidt","transpose","INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","constant","glorotNormal","glorotUniform","heNormal","identity","leCunNormal","orthogonal","randomNormal","varianceScaling","initializer","deserializeInitializer","shapes","weights","count","weights_1","weight","reduce","DEFAULT_VARIABLE_NAME_PREFIX","trainable","id","getNextUniqueTensorId","originalName","getScopedTensorName","getUniqueTensorName","tfc.variable","LayerVariable","newVal","checkShapesMatch","assign","apply","map","read","variablesAndValues","variableAndValue","write","ndim","maxNDim","minNDim","axes","sourceLayer","inputs","callArgs","outputTensorIndex","_nextNodeID","outboundLayer","inboundLayers","nodeIndices","tensorIndices","inputTensors","outputTensors","inputMasks","outputMasks","inputShapes","outputShapes","layer","outboundNodes","inboundNodes","Node","inboundNames","_nextLayerID","activityRegularizer","inputSpec","supportsMasking","_trainableWeights","_nonTrainableWeights","_losses","_updates","_built","generic_utils.toSnakeCase","getUid","updatable","inputShape","batchInputShape","batchSize","inputDType","initialWeights","Layer","nodeIndex","attrName","generic_utils.singletonOrArray","getNodeAtIndex","losses","lossFn","built","trainableWeights","nonTrainableWeights","_stateful","generic_utils.toList","inputIndex","spec","xShape","Number","xShapeAtAxis","specDim","dim","kwargs","_callHook","callHook","inputsList","allAreSymbolic","inputsList_1","SymbolicTensor","noneAreSymbolic","inputsList_2","nameScope","assertInputCompatibility","xElem","build","setWeights","outputListCopy","outputList_1","output","call","clone","inputTensors_1","collectInputShape","outputShape","computeOutputShape","warnOnIncompatibleInputShape","addInboundNode","dimMismatch_1","forEach","dimension","allOutputShapes","node","shapeString","variable_utils.countParamsInWeights","trainableOnly","batchGetValue","params","weightValueTuples","paramValues","pv","p","batchSetValue","regularizer","_addedWeightNames","addLoss","mask","TypeError","maskElement","inputTensorList","types_utils.normalizeShapeList","inputTensorList_1","tensorIndex","sparse","inputTensor","InputLayer","batchShape","logs","promises","scalarsToDispose","valueScalar","data","Promise","all","dispose","BaseCallback","epoch","batch","model","callbacks","queueLength","CallbackList","callback","setParams","setModel","onEpochBegin","onEpochEnd","onBatchBegin","onBatchEnd","onTrainBegin","onTrainEnd","BaseLogger","seen","totals","this_1","oldTotalsToDispose","this_2","div","History","history","valueArray","trainBegin","trainEnd","epochBegin","epochEnd","batchBegin","batchEnd","CustomCallback","resolveScalarsInLogs","squareSum","K.square","epsilonTensor","tfc.onesLike","norm","tfc.maximum","yTrue","yPred","tfc.mean","tfc.abs","diff","clippedTrue","MAX_VALUE","absResult","one","clippedPred","firstLog","tfc.log","secondLog","zeroTensor","maxResult","pos","neg","log2","log","predictionDiff","logcoshResult","tfc.softplus","target","fromLogits","tfc.softmax","outputSum","toFloat","newShape","flatTarget","tfc.floor","math_utils.arrayProd","categoricalCrossentropy","tfc.oneHot","maxOutput","tfc.zerosLike","outputXTarget","sigmoidOutput","tfc.exp","logPred","trueNormalized","l2Normalize","predNormalized","trueXPred","identifierOrFn","lossesMap","meanSquaredError","meanAbsoluteError","meanAbsolutePercentageError","meanSquaredLogarithmicError","squaredHinge","hinge","categoricalHinge","logcosh","sparseCategoricalCrossentropy","binaryCrossentropy","kullbackLeiblerDivergence","poisson","cosineProximity","threshold","yPredThresholded","K.cast","tfc.greater","tfc.equal","tfc.argMax","lossBinaryCrossentropy","mse","MSE","mae","MAE","mape","MAPE","categoricalCrossentropyLoss","cosine","sparseCategoricalCrossentropyLoss","fields","positions","printFn","line","repeat","err","printRow","countParams","relevantNodes","connections","inboundLayer","inboundLayerIndex","inboundTensorIndex","firstConnection","originalKerasVersion","originalBackend","startsWith","dataType","generic_utils.stringToDType","Tensor","make","flatten","Set","outputs","generic_utils.unique","inputLayers","inputLayersNodeIndices","inputLayersTensorIndices","outputLayers","outputLayersNodeIndices","outputLayersTensorIndices","layers","generic_utils.assert","inputNames","outputNames","feedInputShapes","feedInputNames","feedOutputNames","internalInputShapes","internalOutputShapes","nodesDepths","nodeIDToNode","layersDepths","layerIDToLayer","layerIndices","nodesInDecreasingDepth","buildMapOfGraph","tensor","finishedNodes","nodesInProgress","containerNodes","Container","nodeKey","numInboundLayers","layer_1","nodeIndex_1","tensorIndex_1","reversedNodesInDecreasingDepth_1","reverse","depth","previousDepth","inboundNode","previousDepth_1","nodesByDepth","nodeID","layersByDepth","layerID","depthKeys","parseInt","sort","generic_utils.reverseNumberCompare","depthKeys_1","layersForDepth","aIndex","bIndex","layersForDepth_1","computableTensors","layersWithCompleteInput","depthKeys_2","_l","_o","_m","_q","_p","_s","_r","allNames","name_4","numOccurrences","filter","allNames_1","_t","weightsJSON","skipMismatch","isNamedTensorMap","nameToWeight","totalWeightsCount","layers_2","name_2","unsetNames","name_3","loadWeightsFromNamedTensorMap","layerNames","layers_1","nameToWeights","k","name_1","layerWeights","weightValues","weightEntry","loadTensor","symbolicWeights","preprocessWeightsForLoading","loadWeightsFromJson","theConfig","kerasVersion","backend","unused","returnString","modelConfig","tsConfig","pyArray","arrayLength","item","isArrayItemInputOrOutputName","convertTsToPythonic","pyDict","tsKey","tsValue","pyKey","updatedConfig","masks","generic_utils.pyListRepeat","runInternalGraph","layersToOutputShapes","inputShape_1","shapeKey","depthKeys_3","nodes_1","inputShapes_1","j","nodeIndex_2","inputShape_2","outputShapes_1","outputShapeKeys","tensorMap","depthKeys_4","nodes_2","referenceInputTensors","referenceOutputTensors","computedData","referenceInputTensors_1","computedTensors","computedMasks","outputTensors_1","outputMasks_1","computedTensor","computedMask","computeMask","keptNodes","nodeConversionMap","originalNodeIndex","calculateLosses","buildNodeConversionMap","layerConfigs","layerClassName","layerConfig","filteredInboundNodes","nodeData","newNodeIndex","modelInputs","modelOutputs","createdLayers","unprocessedNodes","nodeData_1","inputData","inboundLayerName","inboundNodeIndex","addUnprocessedNode","layerData","layerName","deserializeLayer","inboundNodesData_1","layersFromConfig","layersFromConfig_1","processLayer","generic_utils.isObjectEmpty","layersFromConfig_2","processNode","inputLayersFromConfig_1","layerOutputTensors","outputLayersFromConfig_1","stateful","ModelLoggingVerbosity","feeds","FeedDict","id2Value","feeds_1","feed","cast","assertFeedCompatibility","fetches","feedDict","arrayFetches","fetchArray","internalFeedDict","fetchArray_1","fetch_1","executeInternal","fetch","hasKey","getValue","inputValues","inputs_1","inputVal","layerOutputs","outputTensor","getOutputAt","getNodeOutputs","outputSymbolicTensors","isDataTensor","isDataArray","names","checkBatchAxis","exceptionPrefix","gotUnexpectedData","isDataDict","arrays","names_1","K.expandDims","refDim","batchStart","stop","K.sliceAlongFirstAxis","tfc.tidy","sliceArraysByIndices","K.gather","Model","lineLength","sequentialLike","nodes","nodesByDepth_1","depthNodes","flag","isModelSequentialLike","toDisplay","floor","trainableCount","printLayerSummary","printLayerSummaryWithConnections","checkTrainableWeightsConsistency","collectedTrainableWeights","countParamsInWeights","nonTrainableCount","printSummary","loss","optimizer","optimizerMap","Adagrad","train","adagrad","Adadelta","adadelta","Adam","adam","Adamax","adamax","RMSProp","rmsprop","SGD","sgd","optimizers.getOptimizer","Optimizer","lossFunctions","theLosses","l","losses.get","lossFunction_1","feedOutputShapes","feedLossFns","name_5","skipTargetIndices","metrics","metricsNames","metricsTensors","weightedLoss","nestedMetrics","outputNames_1","outputMetrics","collectMetrics","metricName","accFn","weightedMetricFn","metric","losses.binaryCrossentropy","Metrics.binaryAccuracy","Metrics.binaryCrossentropy","losses.sparseCategoricalCrossentropy","Metrics.sparseCategoricalAccuracy","Metrics.sparseCategoricalCrossentropy","Metrics.categoricalAccuracy","Metrics.categoricalCrossentropy","suffix","metricFn","metricsMap","binaryAccuracy","categoricalAccuracy","Metrics.get","metricResult","outputIndex","metricTensor","appendMetric","metrics_1","handleMetrics","standardizedOuts","standardizeUserData","ins","makeTestFunction","f","testFunction","singletonOrArray","testLoop","verbose","steps","stepsName","numSamples","outputsIsArray","retrieveSymbolicTensors","input","tensorValue","executeOutputs","execute","symbolicTensorNames","pyListRepeat","outputsRemaining","layerOutputNames","remainingNames_1","checkNumSamples","batches","makeBatches","outs","batchIndex","batchOuts","insBatch","sliceArrays","batchOuts_1","batchOut","K.concatAlongFirstAxis","checkInputData","predictLoop","targets","setX","unique","setY","checkArrayLengths","standardizeInputData","lossFns","keyLosses","losses.meanSquaredError","losses.categoricalCrossentropy","slicedYShape","slicedShape","targetDim","outDim","checkLossAndTargetCompatibility","outLabels","epochs","valF","valIns","shuffle","callbackMetrics","initialEpoch","stepsPerEpoch","validationSteps","doValidation","numTrainSamples","indexArray","range","callbackList","stopTraining","epochLogs","epochIndexArray1D_1","batches_1","batchLogs","batchIds","tfc.keep","valOuts","disposeTensorsInLogs","syncData","dedupedOutLabels","newLabel","totalLoss","valOutputs","lossFunction","meanMetric","needValidationDisposal","validationData","valX","valY","valStandardized","validationSplit","splitAt","originalBatchSize","trainFunction","metricsValues","variables","param","minimize","regularizerLoss","getDedupedMetricsNames","valFunction","callbackConfig","standardizeCallbacks","fitLoop","namedWeights","getWeights","handlerOrURL","handlers","io","getSaveHandlers","save","encodeWeights","getNamedWeights","weightDataAndSpecs","unusedArg","toJSON","modelTopology","weightData","weightSpecs","specs","pathOrIOHandler","getLoadHandlers","browserHTTPRequest","handler","load","artifacts","deserialize","pythonicConfig","generic_utils.toCamelCase","tsArray","convertPythonicToTs","tsDict","pythonicKey","pythonicValue","loadWeights","decodeWeights","loadModelFromIOHandler","_updatable","Sequential","modelLayer","isLayerModelInstance","Input","sourceTensors","previousSources_1","getSourceInputs","x_1","lastLayerIndex","getExactlyOneShape","summary","evaluate","predict","predictOnBatch","compile","fit","Activation","Elu","alpha","tfc.elu","K.elu","Selu","tfc.selu","Relu","Relu6","tfc.minimum","Linear","Sigmoid","tfc.sigmoid","HardSigmoid","K.hardSigmoid","Softplus","Softsign","K.softsign","Tanh","tfc.tanh","Softmax","activation","deserializeActivation","DEFAULT_ALPHA","LeakyReLU","getExactlyOneTensor","leakyRelu","baseConfig","ELU","elu","theta","DEFAULT_THETA","thetaTensor","ThresholdedReLU","greater","softmax","softmaxActivation","DEFAULT_AXIS","l1","l2","hasL1","hasL2","L1L2","regularization","sum","abs","asScalar","Regularizer","REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","l1l2","deserializeRegularizer","singleValue","inputLength","filterSize","padding","stride","dilation","outputLength","dimSize","strideSize","kernelSize","tfc.transpose","BaseConv","verifyConfig","normalizeArray","strides","checkPaddingMode","getActivation","useBias","biasInitializer","getInitializer","DEFAULT_BIAS_INITIALIZER","biasConstraint","getConstraint","biasRegularizer","getRegularizer","dilationRate","generic_utils.checkArrayTypeAndLength","serializeActivation","serializeInitializer","serializeRegularizer","serializeConstraint","Conv","filters","kernelInitializer","DEFAULT_KERNEL_INITIALIZER","kernelConstraint","kernelRegularizer","channelAxis","inputDim","kernelShape","kernel","addWeight","biasValue","tfc.conv1d","K.biasAdd","preprocessConv2DInput","tfc.conv2d","conv2dWithBias","newSpace","space","newDim","convOutputLength","Conv2D","InputSpec","Conv2DTranspose","hAxis","wAxis","height","width","kernelH","kernelW","strideH","strideW","deconvLength","tfc.conv2dTranspose","heightAxis","widthAxis","SeparableConv2D","depthMultiplier","depthwiseInitializer","DEFAULT_DEPTHWISE_INITIALIZER","depthwiseRegularizer","depthwiseConstraint","pointwiseInitializer","DEFAULT_POINTWISE_INITIALIZER","pointwiseRegularizer","pointwiseConstraint","SeparableConv","depthwiseKernelShape","pointwiseKernelShape","depthwiseKernel","pointwiseKernel","tfc.separableConv2d","Conv1D","cropping","Cropping2D","K.sliceAlongAxis","DEFAULT_SIZE","UpSampling2D","resized","resizeNearestNeighbor","DepthwiseConv2D","tfc.depthwiseConv2d","rows","cols","outFilters","outRows","outCols","min","rateScalar","Dropout","invokeCallHook","noiseShape_1","getNoiseShape","K.inTrainPhase","K.dropout","units","Dense","inputLastDim","K.dot","Flatten","K.batchFlatten","RepeatVector","tile","expandDims","targetShape","isUnknown","Reshape","errorMsg","finalShape","known","unknown","originalSize","anyUnknownDims","fixUnknownDimension","outputDim","embeddingsInitializer","DEFAULT_EMBEDDINGS_INITIALIZER","embeddingsRegularizer","embeddingsConstraint","maskZero","Embedding","embeddings","inLens","s1","s2","as1D","Merge","shape1","shape2","computeElementwiseOpOutputShape","batchSizes","allRanks","reshapeRequired","reshapedInputs","inputDims","mathUtils.max","xNDim","mergeFunction","transposed","inputs_2","xTransposed","mathUtils.arrayProd","dims","mathUtils.range","yNDim","yShape","Add","tfc.zeros","inputs_3","Multiply","tfc.ones","inputs_4","Average","inputs_5","Maximum","Minimum","Concatenate","allNoneShape","inputShape_3","shapeSet","shapeWithoutConcatAxis","exists","shapeSet_1","K.concatenate","variance","beta","gamma","tfc.batchNormalization2d","tfc.batchNormalization3d","tfc.batchNormalization4d","reductionAxes","math_utils.range","meanAndVariance","tfc.moments","batchNormalization","regularNormalizeBatchInTraining","broadcastMean","broadcastVariance","broadcastGamma","broadcastBeta","broadcastNormalizeBatchInTraining","momentum","center","betaInitializer","gammaInitializer","movingMeanInitializer","movingVarianceInitializer","betaConstraint","gammaConstraint","betaRegularizer","gammaRegularizer","stepCount","BatchNormalization","movingMean","movingVariance","broadcastShape","sortedReductionAxes","needsBroadcasting","broadcastMovingMean","broadcastMovingVariance","normalizeInference","normedTraining","sampleSize","varianceDebiased","newMovingMean","tfc.movingAverage","newMovingVariance","updateMovingMeanAndVariance","heightPadding","widthPadding","ZeroPadding2D","pattern","tfc.pad","poolSize","poolMode","paddingString","tfc.maxPool","tfc.avgPool","Pooling1D","poolingFunction","tfc.squeeze","MaxPooling1D","pool2d","AveragePooling1D","Pooling2D","MaxPooling2D","AveragePooling2D","GlobalPooling1D","GlobalAveragePooling1D","GlobalMaxPooling1D","GlobalPooling2D","GlobalAveragePooling2D","GlobalMaxPooling2D","initialState","constants","numConstants","toListOrNull","stepFunction","initialStates","goBackwards","unroll","lastOutput","tfc.reverse","states","timeSteps","t","currentInput","stepOutputs","cell","StackedRNNCells","cells","stateSize","returnSequences","returnState","stateSpec","RNN","isArrayOfShapes","stateShape","stateSize_1","stepInputShape","expectedShape","standardized","standardizeArgs","additionalInputs","additionalSpecs","initialState_1","state","fullInput","fullInputSpec","originalInputSpec","getInitialState","numStates","cellCallKwargs","rnnOutputs","rnn","K.tile","cellConfig","DEFAULT_ACTIVATION","recurrentInitializer","DEFAULT_RECURRENT_INITIALIZER","recurrentRegularizer","recurrentConstraint","dropout","math_utils.min","math_utils.max","recurrentDropout","dropoutMask","recurrentDropoutMask","SimpleRNNCell","recurrentKernel","prevOutput","h","generateDropoutMask","dpMask","recDpMask","RNNCell","SimpleRNN","tfc.dispose","recurrentActivation","DEFAULT_RECURRENT_ACTIVATION","implementation","GRUCell","hTMinus1","z","r","hh","kernelZ","K.sliceAlongLastAxis","kernelR","recurrentKernelZ","recurrentKernelR","recurrentKernelH","inputsZ","inputsR","inputsH","xZ","xR","xH","biasZ","biasR","biasH","hTMinus1Z","hTMinus1R","hTMinus1H","matrixX","matrixInner","recurrentZ","recurrentR","recurrentH","GRU","unitForgetBias","LSTMCell","capturedBiasInit_1","capturedUnits_1","CustomInit","bI","bF","bCAndH","cTMinus1","c","o","kernelI","kernelF","kernelC","kernelO","recurrentKernelI","recurrentKernelF","recurrentKernelC","recurrentKernelO","inputsI","inputsF","inputsC","inputsO","xI","xF","xC","xO","biasI","biasF","biasC","biasO","hTMinus1I","hTMinus1F","hTMinus1C","hTMinus1O","z0","z1","z2","z3","LSTM","nestedStates","callInputs","newNestedStates","cellStates","cellConfigs","tuples","numParams","inputWeights","droppedInputs","Wrapper","newConfig","TimeDistributed","childInputShape","childOutputShape","timesteps","VALID_BIDIRECTIONAL_MERGE_MODES","forwardLayer","backwardLayer","mergeMode","generic_utils.checkStringTypeUnionValue","_trainable","Bidirectional","numWeights","numeightsOver2","layerShapes","stateSpecs","isSymbolicTensor","additionalInputs_1","yRev","forwardState","backwardState","resetStates","rnnLayer","globalMaxPool1d","globalMaxPooling1d","globalMaxPool2d","globalMaxPooling2d","maxPool1d","maxPooling1d","maxPool2d","maxPooling2d","averagePooling1d","averagePooling2d","metrics.binaryAccuracy","metrics.binaryCrossentropy","metrics.categoricalAccuracy","metrics.categoricalCrossentropy","losses.cosineProximity","losses.meanAbsoluteError","losses.meanAbsolutePercentageError","regularizers.l1","regularizers.l2","Callback","loadModelInternal"],"mappings":";;;;;;;;;;;;;;;;o8DAYA,IAAIA,EAAW,kBAMb,OAAOA,ECGT,IAAIC,EAAsB,eAGxB,OAAOA,IAGT,IAAMC,gBAOiBC,GAKrB,oBALqBA,MACfA,KAAUD,IACdA,EAAaC,GAAU,GAEzBD,EAAaC,IAAW,EACjBA,EAASD,EAAaC,GAAQC,WAGvC,IAAMC,GACJC,WACAC,UAGIC,EAA0B,qBAKNC,EAAeC,GAQvC,YAPcC,IAAVD,IACFA,EAAQF,GAEuB,MAA7BH,EAAYK,GAAOD,KACrBJ,EAAYK,GAAOD,GAASG,SAAOH,EAAOC,GAC1CG,OAAKR,EAAYK,GAAOD,KAEnBJ,EAAYK,GAAOD,GCpC5B,kBACE,WAAYK,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMC,EAAeC,aAE/C,OANoCC,UAAAC,qBAYlC,WAAYR,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMK,EAAaH,aAE7C,OANkCC,UAAAC,qBAYhC,WAAYR,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMM,EAAWJ,aAE3C,OANgCC,UAAAC,qBAY9B,WAAYR,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMO,EAAoBL,aAEpD,OANyCC,UAAAC,qBAYvC,WAAYR,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMQ,EAAeN,aAE/C,OANoCC,UAAAC,oBAYlC,WAAYR,GAAZ,MACEC,YAAMD,gBAENE,OAAOC,eAAeC,EAAMS,EAAWP,aAJXC,QAAAC,kBCxDHb,EAAYmB,GACvC,GAAIC,MAAMC,QAAQrB,GAAQ,CAGxB,IADA,IAAIsB,KACKC,EAAI,EAAGA,EAAIJ,EAAWI,IAC7BD,EAAWA,EAASE,OAAOxB,GAE7B,OAAOsB,EAIP,OAFMA,EAAW,IAAIF,MAAMD,IAClBM,KAAKzB,GACPsB,aAIYI,EAAcrB,GACnC,IAAKqB,EACH,MAAM,IAAIT,EAAeZ,cAOJsB,EAAYC,GAEnC,IADA,IAAIC,EAAU,MACKC,IAAAC,WAAAA,YACJH,GACXC,IAGJ,OAAOA,aAQ2BG,GAClC,OAAkB,IAAdA,EAAGC,OACED,EAAG,GAELA,aAYcE,GACrB,OAAId,MAAMC,QAAQa,GACTA,GAEDA,cA0BkBC,GAC1B,IACMC,EADeD,EAAKE,QAAQ,uBAAwB,SAEzCA,QAAQ,kBAAmB,SAASC,cAKrD,MAAoB,MAAhBF,EAAS,GACJA,EAEF,UAAYA,aAGOG,GAE1B,OAAIA,EAAWN,QAAU,EAChBM,GAGwB,IAA7BA,EAAWC,QAAQ,KACdD,EAEFA,EAAWF,QAAQ,cAAe,SAACI,EAAGC,GAAO,OAAAA,EAAGC,gBAIzD,IAAIC,gBAEiCC,GAEnC,OAAiB,OAAbA,QAAkC3C,IAAb2C,EAChB,MAEDC,UAAWD,EAASE,eAAgBC,OAAQH,EAASI,wBAa3DV,EACAW,EACAC,EACAC,GAEF,gBAJEF,mBACAC,mBACAC,YAEwB,iBAAfb,EAAyB,CAClC,IAAMc,EAAed,EACjBe,SACJ,GAAID,KAAgBF,EAClBG,EAAKH,EAAcE,QACd,GAAIA,KAAgBT,EACzBU,EAAKV,EAAuBS,QAG5B,GAAU,OADVC,EAAKJ,EAAcG,IAEjB,MAAM,IAAItC,EAAW,WAAWqC,OAAwBb,GAG5D,OAAOe,EAGP,IAAMN,EAAST,EACf,GAAwB,MAApBS,EAAOF,WAAsC,MAAjBE,EAAOA,OACrC,MAAM,IAAIjC,EACHqC,+BACAG,KAAKC,UAAUR,4CAGxB,IAAMF,EAAYE,EAAOF,UACrBW,SAAKC,SAQT,GAPIZ,KAAaK,GACdM,GAADE,eAAMD,QACGZ,KAAaF,GACrBa,GAADG,kBAAMF,QACGZ,KAAaI,IACrBO,GAADI,WAAMH,QAEG,MAAPD,EACF,MAAM,IAAI1C,EAAW,WAAWqC,OAAwBN,GAE1D,GAAkB,MAAdY,EAAoB,CAQtB,IADA,IAAMI,SACYC,EAAAxD,OAAOyD,KAAKpB,GAAZb,WAAAA,KAChB+B,EADSG,QACoBrB,EAAuBqB,GAEtD,IAAkB,QAAAC,EAAA3D,OAAOyD,KAAKb,GAAZgB,WAAAA,KAChBL,EADSG,QACoBd,EAAcc,GAGxBjB,EAAOA,OACfG,cAAgBW,EAG7B,IADA,IAAMM,OAA0BxB,OACdyB,EAAA9D,OAAOyD,KAAKb,GAAZmB,WAAAA,KAAb,IAAML,OACTrB,EAAuBqB,GAAOd,EAAcc,GAE9C,IAAMM,EAAYb,EAAWD,EAAKT,EAAOA,QAGzC,OAFAJ,OAA6BwB,GAEtBG,EAKDH,OAA0BxB,GAChC,IADA,QACkB4B,EAAAjE,OAAOyD,KAAKb,GAAZsB,WAAAA,KAAPR,OACTrB,EAAuBqB,GAAOd,EAAcc,GAK9C,UAAMM,EAAY,IAAId,EAAIT,EAAOA,QAEjC,OADAJ,OAA6BwB,GACtBG,aAmBwBG,EAAWC,GAC9C,OAAQ,WAVoBD,EAAWC,GACvC,OAAQD,EAAIC,GAAM,EAAMD,EAAIC,EAAK,EAAI,EASzBC,CAAcF,EAAGC,cA2CL3C,GACxB,GAAU,MAANA,EACF,OAAOA,EAIT,IAFA,IAAM6C,SAEUC,IAAA/C,WAAAA,KAAX,IAAMG,QACe,IAApB2C,EAAIrC,QAAQN,IACd2C,EAAIE,KAAK7C,GAGb,OAAO2C,aASqBG,GAC5B,GAAW,MAAPA,EACF,MAAM,IAAIjE,EAAW,yBAAyBwC,KAAKC,UAAUwB,IAE/D,IAAK,IAAMf,KAAOe,EAChB,GAAIA,EAAIC,eAAehB,GACrB,OAAO,EAGX,OAAO,aAWLiB,EAAkBC,EAAenF,GACnC,GAAa,MAATA,GAGAkF,EAAO1C,QAAQxC,GAAS,EAC1B,MAAM,IAAIe,EAAcf,qBAAwBmF,yBAC5CD,oCAoBJhD,EAAQkD,EAAsBC,EAC9BC,GAGF,oBAJgCD,kBAC9BC,OACFC,EAAOF,GAAa,GACpBE,EAAOD,GAAaD,GAEhBjE,MAAMC,QAAQa,IAAMA,EAAED,QAAUoD,GAAanD,EAAED,QAAUqD,GACzDpD,EAAEsD,MAAM,SAAAC,GAAK,cAAOA,IAAML,ICzVhC,WAAqBM,EAAWC,GAC9B,OAAOC,OAAK,WAAM,OAAAC,OAASC,MAAQC,YAAcL,EAAGA,GAAIC,GAAM,MAahE,kBAAA,4DAMA,OANyC/E,OAGvCoF,sBAAA,WACE,aAJqCC,gBAAcC,4BAgDrD,WAAYlD,GAAZ,MACE1C,0BAJeG,kBAAkB,EAClBA,cAAc,EAI7BA,EAAK0F,SACkB,MAAnBnD,EAAOmD,SAAmBnD,EAAOmD,SAAW1F,EAAK2F,gBACrD3F,EAAKkF,KAAsB,MAAf3C,EAAO2C,KAAe3C,EAAO2C,KAAOlF,EAAK4F,cAczD,OAzB6BzF,OAc3B0F,kBAAA,SAAMZ,GAAN,WACE,OAAOE,OAAK,WACV,IAAMW,EAAQC,EAAYd,EAAGjF,EAAKkF,MAC5Bc,EAAUC,cAAgBH,EAAO,EAAG9F,EAAK0F,UAC/C,OAAOQ,MAAQjB,EAAGkB,MAAQH,EAASI,MAAQC,EAAUC,KAAYR,QAIrED,sBAAA,WACE,OAAQH,SAAUa,KAAKb,SAAUR,KAAMqB,KAAKrB,OAtB9BW,YAAY,aADDN,mBA0BfiB,iBAAiBC,SAASZ,GAuBxC,kBAIE,WAAYtD,GAAZ,MACE1C,0BAFeG,cAAc,EAG7BA,EAAKkF,KAAsB,MAAf3C,EAAO2C,KAAe3C,EAAO2C,KAAOlF,EAAK4F,cAYzD,OAlB8BzF,OAS5BuG,kBAAA,SAAMzB,GAAN,WACE,OAAOE,OACH,WAAM,OAAAgB,MACFlB,EAAGmB,MAAQC,EAAUC,KAAYP,EAAYd,EAAGjF,EAAKkF,WAG/DwB,sBAAA,WACE,OAAQxB,KAAMqB,KAAKrB,OAfLwB,YAAY,cADAnB,mBAmBhBiB,iBAAiBC,SAASC,GAKxC,kBAAA,4DAMA,OAN4BvG,OAG1BwG,kBAAA,SAAM1B,GACJ,OAAO2B,OAAS3B,IAHF0B,YAAY,YADFpB,mBAOdiB,iBAAiBC,SAASE,GAoCxC,kBAWE,WAAYpE,GAAZ,MACE1C,0BANeG,kBAAkB,EAClBA,kBAAkB,EAClBA,cAAc,EACdA,cAAc,EAI7BA,EAAK6G,SACkB,MAAnBtE,EAAOsE,SAAmBtE,EAAOsE,SAAW7G,EAAK8G,gBACrD9G,EAAK0F,SACkB,MAAnBnD,EAAOmD,SAAmBnD,EAAOmD,SAAW1F,EAAK2F,gBACrD3F,EAAK+G,KAAsB,MAAfxE,EAAOwE,KAAexE,EAAOwE,KAAO/G,EAAKgH,YACrDhH,EAAKkF,KAAsB,MAAf3C,EAAO2C,KAAe3C,EAAO2C,KAAOlF,EAAK4F,cAuBzD,OAzCgCzF,OAqB9B8G,kBAAA,SAAMhC,GAAN,WACE,OAAOE,OAAK,WACV,IAAMW,EAAQC,EAAYd,EAAGjF,EAAKkF,MAC5Bc,EAAUI,MACZF,MACIG,EAAUrG,EAAK+G,MACfd,cAAgBH,EAAO9F,EAAK6G,SAAU7G,EAAK0F,WAC/CQ,MAAQG,EAAU,EAAMrG,EAAK+G,MAAOjB,IACxC,OAAOI,MAAQjB,EAAGkB,MAAQH,EAASI,MAAQC,EAAUC,KAAYR,QAIrEmB,sBAAA,WACE,OACEJ,SAAUN,KAAKM,SACfnB,SAAUa,KAAKb,SACfqB,KAAMR,KAAKQ,KACX7B,KAAMqB,KAAKrB,OArCC+B,YAAY,gBADE1B,mBA0ClBiB,iBAAiBC,SAASQ,GAQjC,IAAMC,GAEPC,QAAW,UACXC,WAAc,aACdC,OAAU,SACVC,SAAY,uBAGkBC,GAElC,OAAOC,EAAqBD,cAI1BhF,EACAG,GACF,oBADEA,MACK+E,EACHlF,EAAQiD,gBAAcgB,iBAAiBkB,SAASC,aAChDjF,EAAe,yBAGSZ,GAE5B,OAAkB,MAAdA,EACK,KAEiB,iBAAfA,EAKF8F,GADSvF,UAHEP,KAAcoF,EAC5BA,EAA0CpF,GAC1CA,EACuBS,YAElBT,aAAsByD,EACxBzD,EAEA8F,EAAsB9F,yCCpQTS,GACtB,OAAO,IAAIsD,EAAQtD,sBAWIA,GACvB,OAAO,IAAImE,EAASnE,sBAWpB,OAAO,IAAIoE,uBAWcpE,GACzB,OAAO,IAAI0E,EAAW1E,MCvClBsF,EAA+B,IAAIC,IAM5BC,GAA4B,gBAAiB,2BAC1BxI,GAC9ByI,EAA0BD,EAA0B,aAAcxI,GAK7D,IAAM0I,GAA6B,QAAS,OAAQ,qBAC1B1I,GAC/ByI,EAA0BC,EAA2B,cAAe1I,GAK/D,IAAM2I,GAA0B,MAAO,OAK9C,IAAMC,KACAC,GAAoB,gBAKG1G,EAAcmB,GACzCsF,EAAgB7D,KAAK5C,GACrB,IACE,IAAMT,EAAS4B,IAEf,OADAsF,EAAgBE,MACTpH,EACP,MAAO+D,GAEP,MADAmD,EAAgBE,MACVrD,eAoB0BsD,GAClC,IAAKC,GAAkBD,GACrB,MAAM,IAAIlI,MAAM,6BAAgCkI,EAAa,KAE/D,OAhB+B,IAA3BH,EAAgB3G,OACX,GAEA2G,EAAgBK,KAAKJ,IAAqBA,IAajBE,cAaAG,GAClC,IAAKF,GAAkBE,GACrB,MAAM,IAAIrI,MAAM,6BAAgCqI,EAAa,KAE1DZ,EAAQa,IAAID,IACfZ,EAAQc,IAAIF,EAAY,GAE1B,IAAMG,EAAQf,EAAQgB,IAAIJ,GAG1B,GAFAZ,EAAQc,IAAIF,EAAYZ,EAAQgB,IAAIJ,GAAc,GAE9CG,EAAQ,EAAG,CACb,IAAME,EAASL,EAAa,IAAMG,EAIlC,OADAf,EAAQc,IAAIG,EAAQ,GACbA,EAEP,OAAOL,EAIX,IAAMM,GAAkB,IAAIC,OAAO,2CAODtH,GAChC,QAAOA,EAAKuH,MAAMF,gBChFhB7H,EAA4BgI,EAAgBC,GACjC,MAATD,IACFA,EAAQ,GAEC,MAAPC,IACFA,EAAMjI,EAAMM,QAId,IADA,IAAI4H,EAAO,EACFtI,EAAIoI,EAAOpI,EAAIqI,IAAOrI,EAC7BsI,GAAQlI,EAAMJ,GAEhB,OAAOsI,EAQT,YAAmBlI,GAEjB,OADAA,EAAQP,MAAMC,QAAQM,GAAS,IAAImI,aAAanI,GAASA,EAClDoI,WAASpI,eAQEA,GAClB,OAAOqI,MAAQC,GAAUtI,IAAQuI,WAAW,eAQ1BvI,GAClB,OAAOwI,MAAQF,GAAUtI,IAAQuI,WAAW,eAsDxBP,EAAeC,GACnC,GAAIA,EAAMD,EACR,MAAM,IAAI5I,EAAW,QAAQ6I,gBAAiBD,qBAGhD,IADA,IAAM9E,KACGtD,EAAIoI,EAAOpI,EAAIqI,IAAOrI,EAC7BsD,EAAIE,KAAKxD,GAEX,OAAOsD,cCrEY3C,EAAWjC,GAC9B,OAAOiC,EAAEkI,OAAOnK,eASSiC,EAAWyD,gBAAAA,GAAQ,GAC5C,IAAM0E,EAAWnI,EAAEoI,MAAMC,QAKzB,OAJI5E,EAAO,IACTA,EAAO0E,EAASpI,OAAS0D,EAAO,GAElC0E,EAASG,OAAO7E,EAAM,EAAG,GAClBzD,EAAEuI,QAAQJ,eA8Df1I,EAAe+I,EAAeC,GAChC,OAAO/E,OAAK,WACV,OAAQjE,EAAMiJ,MACZ,KAAK,EACH,OAAOC,UAAYlJ,EAAmB+I,EAAOC,GAC/C,KAAK,EACH,OAAOG,UACHnJ,GAAoB+I,EAAO,IAAKC,EAAMhJ,EAAM2I,MAAM,KACxD,KAAK,EACH,OAAOS,UACHpJ,GAAoB+I,EAAO,EAAG,IAC7BC,EAAMhJ,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,KACzC,KAAK,EACH,OAAOU,UACHrJ,GAAoB+I,EAAO,EAAG,EAAG,IAChCC,EAAMhJ,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,KACzD,QACE,MAAM,IAAIvJ,EACN,8DACGY,EAAMiJ,qBAcjBjJ,EAAe+I,EAAeC,GAChC,OAAO/E,OAAK,WACV,OAAQjE,EAAMiJ,MACZ,KAAK,EACH,OAAOC,UAAYlJ,EAAmB+I,EAAOC,GAC/C,KAAK,EACH,OAAOG,UACHnJ,GAAoB,EAAG+I,IAAS/I,EAAM2I,MAAM,GAAIK,IACtD,KAAK,EACH,OAAOI,UACHpJ,GAAoB,EAAG,EAAG+I,IACzB/I,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,GAAIK,IACvC,KAAK,EACH,OAAOK,UACHrJ,GAAoB,EAAG,EAAG,EAAG+I,IAC5B/I,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,GAAIK,IACvD,QACE,MAAM,IAAI5J,EACN,6DACGY,EAAMiJ,qBAejBjJ,EAAe+I,EAAeC,EAAchF,GAC9C,OAAOC,OAAK,WACV,OAAQjE,EAAMiJ,MACZ,KAAK,EACH,OAAOC,UAAYlJ,EAAmB+I,EAAOC,GAC/C,KAAK,EACH,OAAQhF,GACN,KAAK,EACH,OAAOsF,GAAoBtJ,EAAO+I,EAAOC,GAC3C,KAAK,EACH,OAAOO,GAAmBvJ,EAAO+I,EAAOC,GAC1C,QACE,MAAM,IAAI5J,EACN,iDACG4E,GAEb,KAAK,EACH,OAAQA,GACN,KAAK,EACH,OAAOsF,GAAoBtJ,EAAO+I,EAAOC,GAC3C,KAAK,EACH,OAAOI,UACHpJ,GAAoB,EAAG+I,EAAO,IAC7B/I,EAAM2I,MAAM,GAAIK,EAAMhJ,EAAM2I,MAAM,KACzC,KAAK,EACH,OAAOY,GAAmBvJ,EAAO+I,EAAOC,GAC1C,QACE,MAAM,IAAI5J,EACN,iDACG4E,GAEb,KAAK,EACH,OAAQA,GACN,KAAK,EACH,OAAOsF,GAAoBtJ,EAAO+I,EAAOC,GAC3C,KAAK,EACH,OAAOK,UACHrJ,GAAoB,EAAG+I,EAAO,EAAG,IAChC/I,EAAM2I,MAAM,GAAIK,EAAMhJ,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,KACzD,KAAK,EACH,OAAOU,UACHrJ,GAAoB,EAAG,EAAG+I,EAAO,IAChC/I,EAAM2I,MAAM,GAAI3I,EAAM2I,MAAM,GAAIK,EAAMhJ,EAAM2I,MAAM,KACzD,KAAK,EACH,OAAOY,GAAmBvJ,EAAO+I,EAAOC,GAC1C,QACE,MAAM,IAAI5J,EACN,iDACG4E,GAEb,QACE,MAAM,IAAI5E,EACN,6DACGY,EAAMiJ,qBAWOO,EAAmBxF,GAC7C,IAAIiF,EAeJ,oBAhB6CjF,GAAQ,GAEjDA,EAAO,IAGPA,EADW,KADbiF,EAAOO,EAAQ,GAAGP,MAETA,EAEA,GAGPjF,IAASwF,EAAQ,GAAGP,OAGtBjF,GAAQ,GAGHyF,SAAWD,EAASxF,eAUQjB,EAAWC,GAC9C,OAAQD,EAAEkG,MACR,KAAK,EACH,OAAOS,YAAc3G,EAAeC,IACtC,KAAK,EACH,OAAO2G,YAAc5G,EAAeC,GAAgB,GACtD,KAAK,EACH,OAAO4G,YAAc7G,EAAeC,GAAgB,GACtD,KAAK,EACH,OAAO6G,YAAc9G,EAAeC,GAAgB,GACtD,QACE,MAAM,IAAI5D,EACN,+DACA2D,EAAEkG,mBAWS1I,EAAWuJ,GAI9B,GAHKrK,MAAMC,QAAQoK,KACjBA,GAAKA,IAEHvJ,EAAE0I,OAASa,EAAExJ,OACf,MAAM,IAAIlB,EACN,0BAA0B0K,EAAExJ,gEACYC,EAAE0I,UAEhD,OAAOc,OAASxJ,EAAGuJ,eAiBjBnB,EAAcqB,EAAYC,EAAc3L,EACxC4L,GACF,oBAFgBF,kBAAYC,KAErBE,eAAiBxB,EAAOqB,EAAMC,EAAQ3L,EAAO4L,eAgBlC3J,EAAW6J,GAC7B,GAAe,IAAXA,EAAEnB,KACJ,MAAM,IAAI5J,EACN,yEACa+K,EAAEzB,OAEnB,GAAe,IAAXpI,EAAE0I,KACJ,OAAOoB,SAAW9J,EAAe6J,GAC5B,GAAe,IAAX7J,EAAE0I,KAAY,CACvB,IAAMqB,EAAU/J,EAAEoI,MAAM,GAClB4B,EAAUhK,EAAEoI,MAAM,GAClB6B,EAAUjK,EAAEoI,MAAM,GAExB,OADApI,EAAIA,EAAEuI,SAASwB,EAAUC,EAASC,IAC3BH,SAAW9J,EAAe6J,GAAetB,SAC9CwB,EAASC,EAASH,EAAEzB,MAAM,KAG5B,MAAM,IAAItJ,EACN,6BAA6BkB,EAAE0I,2CAClB1I,EAAEoI,mBA0DrB8B,EAAmBC,EAA4B1G,GACjD,OAAOC,OAAK,WAMV,OAJEyG,EADEjL,MAAMC,QAAQgL,GACNtC,WAASsC,EAAS,SAElBA,EAAQC,QAEbC,SAAWH,EAAWC,EAAS1G,iBASnBzD,GACrB,OAAO6D,YAAc7D,EAAGA,eAuCtBA,EAAWsK,EAAcC,GAC3B,OAAO7G,OAAK,WAMV,GALkB,MAAd6G,IACFA,ERjeG,gBQmeLC,EAAgBD,GAEE,IAAdD,EAAK5B,MAAc4B,EAAK5B,OAAS1I,EAAE0I,KACrC,MAAM,IAAI7J,EACN,+BAAiCyL,EAAK5B,KACtC,4BAA8B1I,EAAE0I,MAEtC,IAEImB,EAFEY,EAAYH,EAAKlC,MAGvB,GAAe,IAAXpI,EAAE0I,KACe,kBAAf6B,EAEAV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAGkC,EAAU,GAAI,EAAG,EAAG,KAE3CzK,EAAE0K,IAAIJ,EAAK/B,SACV,EAAGkC,EAAU,GAAIA,EAAU,GAAIA,EAAU,GAAIA,EAAU,MAEtC,iBAAfF,IAEPV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAG,EAAG,EAAG,EAAGkC,EAAU,MAE1CzK,EAAE0K,IAAIJ,EAAK/B,SAAS,GAAGjJ,OAAOmL,WAGjC,GAAe,IAAXzK,EAAE0I,KACQ,kBAAf6B,EAEAV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAGkC,EAAU,GAAI,EAAG,KAExCzK,EAAE0K,IACFJ,EAAK/B,SAAS,EAAGkC,EAAU,GAAIA,EAAU,GAAIA,EAAU,MAErC,iBAAfF,IAEPV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAG,EAAG,EAAGkC,EAAU,MAEvCzK,EAAE0K,IAAIJ,EAAK/B,SAAS,GAAGjJ,OAAOmL,WAGjC,GAAe,IAAXzK,EAAE0I,KACQ,kBAAf6B,EAEAV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAGkC,EAAU,GAAI,KAErCzK,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAGkC,EAAU,GAAIA,EAAU,MAE7B,iBAAfF,IAEPV,EADuB,IAArBY,EAAU1K,OACRC,EAAE0K,IAAIJ,EAAK/B,SAAS,EAAG,EAAGkC,EAAU,MAEpCzK,EAAE0K,IAAIJ,EAAK/B,SAAS,GAAGjJ,OAAOmL,UAGjC,CAAA,KAAIzK,EAAE0I,KAAO,GAGlB,MAAM,IAAI7J,EAAW,sCAAsCmB,EAAE0I,MAF7DmB,EAAI7J,EAAE0K,IAAIJ,GAIZ,OAAOT,gBA2CP7J,EAAW2K,EAAeC,EAAuBjB,GACnD,OAAOjG,OAAK,WAGV,GAAkB,MAAdkH,IAAuBC,OAAKC,YAAY9K,EAAEoI,MAAOwC,GACnD,MAAM,IAAI9L,EACN,mDACAuC,KAAKC,UAAUsJ,IAErB,GAAY,MAARjB,EACF,MAAM,IAAI7K,EAAoB,4CAEhC,IAAIiM,EAAaC,OAASrG,MACtBsG,MAAQN,GAAkBO,gBAAkBlL,EAAEoI,MAAO,EAAG,EAAG,aAK/D,OAHA2C,EAAatG,MACTC,MAAQE,EAAU,GAAIuG,MAAQvG,EAAU,GAAI+F,IAC5CI,GACGtG,MAAQzE,EAAG+K,iBAgCU/K,EAAYoL,EAAcC,GACxD,oBADwDA,MACjDA,EAAWrL,IAAMoL,ICpoBnB,IAAME,IAAyB,QAAS,SAAU,UAOlD,IAAMC,IAA6B,SAAU,WAWpD,mBAAA,4DAeA,OAf0C7M,OACjC8M,wCAAP,WACE,OAAO,GAUTA,sBAAA,WACE,aAbsCzH,gBAAcC,6BAoBxD,4DAMA,OAN2BtF,OAGzB+M,kBAAA,SAAMrD,EAAcrK,GAClB,OAAO2N,QAAMtD,EAAOrK,IAHf0N,YAAY,WADMD,oBAObzG,iBAAiBC,SAASyG,IAKxC,mBAAA,4DAMA,OAN0B/M,OAGxBiN,kBAAA,SAAMvD,EAAcrK,GAClB,OAAO6N,OAAKxD,EAAOrK,IAHd4N,YAAY,UADKH,oBAOZzG,iBAAiBC,SAAS2G,IAUxC,mBAGE,WAAY7K,GAAZ,MACE1C,mBACA,GAAsB,iBAAX0C,EACT,MAAM,IAAIjC,EACN,oDAAoDiC,GAE1D,QAAqB9C,IAAjB8C,EAAOhD,MACT,MAAM,IAAIe,EAAW,sCAAsCiC,UAE7DvC,EAAKT,MAAQgD,EAAOhD,QAYxB,OAxB8BY,OAe5BmN,kBAAA,SAAMzD,EAAcrK,GAApB,WACE,OAAO2F,OAAK,WAAM,OAAAoI,MAAI7N,SAAOM,EAAKT,OAAQ8N,OAAKxD,EAAOrK,OAGxD8N,sBAAA,WACE,OACE/N,MAAOgH,KAAKhH,QApBT+N,YAAY,cADSL,oBAyBhBzG,iBAAiBC,SAAS6G,IAkBxC,mBAQE,WAAY/K,GAAZ,MACE1C,0BAPOG,kBAAkB,IAClBA,iBAAiB,IAOxBA,EAAKwN,OAASjL,EAAOiL,QAAUxN,EAAKyN,eACpCzN,EAAK0N,OAASnL,EAAOmL,QAAU1N,EAAK2N,eACpC3N,EAAKoL,KAAO7I,EAAO6I,OAUvB,OAtBmCjL,OAejCyN,kBAAA,SAAM/D,EAAcrK,GAClB,OAAOqO,gBAAchE,EAAOtD,KAAKiH,OAAQjH,KAAKmH,OAAQlO,IAGxDoO,sBAAA,WACE,OAAQJ,OAAQjH,KAAKiH,OAAQE,OAAQnH,KAAKmH,OAAQtC,KAAM7E,KAAK6E,OAnBxDwC,YAAY,mBADcX,oBAuBrBzG,iBAAiBC,SAASmH,IAexC,mBAQE,WAAYrL,GAAZ,MACE1C,0BAPOG,eAAe,EACfA,iBAAiB,IAOxBA,EAAKkL,KAAO3I,EAAO2I,MAAQlL,EAAK8N,aAChC9N,EAAKmL,OAAS5I,EAAO4I,QAAUnL,EAAK+N,eACpC/N,EAAKoL,KAAO7I,EAAO6I,OAcvB,OA1BkCjL,OAehC6N,kBAAA,SAAMnE,EAAcrK,GAClB,GAAc,SAAVA,EACF,MAAM,IAAIe,EACN,6CAEN,OAAO0N,GAAepE,EAAOtD,KAAK2E,KAAM3E,KAAK4E,OAAQ3L,EAAO+G,KAAK6E,OAGnE4C,sBAAA,WACE,OAAQ9C,KAAM3E,KAAK2E,KAAMC,OAAQ5E,KAAK4E,OAAQC,KAAM7E,KAAK6E,OAvBpD4C,YAAY,kBADaf,oBA2BpBzG,iBAAiBC,SAASuH,IAmBxC,mBASE,WAAYzL,GAAZ,MACE1C,0BAPOG,eAAe,EACfA,iBAAiB,IAOxBA,EAAKkL,KAAO3I,EAAO2I,MAAQlL,EAAK8N,aAChC9N,EAAKmL,OAAS5I,EAAO4I,QAAUnL,EAAK+N,eACpC/N,EAAKoL,KAAO7I,EAAO6I,OAcvB,OA3BqCjL,OAgBnC+N,kBAAA,SAAMrE,EAAcrK,GAClB,GAAc,SAAVA,EACF,MAAM,IAAIe,EACN,gDAEN,OAAO4N,kBAAgBtE,EAAOtD,KAAK2E,KAAM3E,KAAK4E,OAAQ3L,EAAO+G,KAAK6E,OAGpE8C,sBAAA,WACE,OAAQhD,KAAM3E,KAAK2E,KAAMC,OAAQ5E,KAAK4E,OAAQC,KAAM7E,KAAK6E,OAxBpD8C,YAAY,qBADgBjB,oBA4BvBzG,iBAAiBC,SAASyH,IAaxC,mBAGE,WAAY3L,GAAZ,MACE1C,0BACAG,EAAKoO,KAAsB,MAAf7L,EAAO6L,KAAe1O,SAAO6C,EAAO6L,MAAQ/H,EAAU,KAkBtE,OAvB8BlG,OAQ5BkO,kBAAA,SAAMxE,EAAcrK,GAApB,WACE,OAAO2F,OAAK,WACV,GAAqB,IAAjB0E,EAAMrI,QAAgBqI,EAAM,KAAOA,EAAM,GAC3C,MAAM,IAAIvJ,EACN,wEAGJ,OAAOiN,MAAIvN,EAAKoO,KAAME,MAAIzE,EAAM,QAKtCwE,sBAAA,WACE,OAAQD,KAAM7H,KAAK6H,KAAKvF,QApBnBwF,YAAY,cADSpB,oBAwBhBzG,iBAAiBC,SAAS4H,IA+DxC,mBAWE,WAAY9L,GAAZ,IA5U2BhD,IA6UzBM,mBACA,GAAI0C,EAAOgM,MAAQ,EACjB,MAAM,IAAIjO,EACN,wCAAwCiC,EAAOgM,cAErDvO,EAAKuO,MAAwB,MAAhBhM,EAAOgM,MAAgB,EAAMhM,EAAOgM,MACjDvO,EAAKwO,KAAOjM,EAAOiM,KAnVMjP,EAoVZS,EAAKwO,KAnVpBxG,EAA0B+E,GAAuB,UAAWxN,GAoV1DS,EAAKyO,aAAelM,EAAOkM,sBA9UGlP,GAChCyI,EAA0BgF,GAA2B,eAAgBzN,GA8UnEmP,CAAkB1O,EAAKyO,cACvBzO,EAAKoL,KAAO7I,EAAO6I,OAqCvB,OA3DqCjL,OAyBnCwO,kBAAA,SAAM9E,EAAcrK,GAClB,IAAMoP,EA/EV,SACI/E,EAAcmC,GAChB,IAAI6C,EACAC,EAEJ,gBAJgB9C,kBAGhBC,EAAgBD,GACK,IAAjBnC,EAAMrI,OACRqN,EAAQhF,EAAM,GACdiF,EAASjF,EAAM,QACV,IAAyC,KAApC,EAAG,EAAG,GAAG9H,QAAQ8H,EAAMrI,QACjC,GAAmB,kBAAfwK,EAAgC,CAClC,IAAM+C,EAAqBC,GAAUnF,EAAO,GAC5CgF,EAAQhF,EAAM,GAAKkF,EACnBD,EAASjF,EAAM,GAAKkF,MACI,iBAAf/C,IACH+C,EAAqBC,GAAUnF,EAAO,EAAGA,EAAMrI,OAAS,GAC9DqN,EAAQhF,EAAMA,EAAMrI,OAAS,GAAKuN,EAClCD,EAASjF,EAAMA,EAAMrI,OAAS,GAAKuN,OAEhC,CACL,IAAME,EAAYD,GAAUnF,GAC5BgF,EAAQK,KAAKC,KAAKF,GAClBH,EAASI,KAAKC,KAAKF,GAGrB,OAAQJ,EAAOC,GAuDAM,CAAYvF,GACnBgF,EAAQD,EAAK,GACbE,EAASF,EAAK,GAChBL,EAAQhI,KAAKgI,MASjB,GARkB,UAAdhI,KAAKiI,KACPD,GAASW,KAAKG,IAAI,EAAGR,GACE,WAAdtI,KAAKiI,KACdD,GAASW,KAAKG,IAAI,EAAGP,GAErBP,GAASW,KAAKG,IAAI,GAAIR,EAAQC,GAAU,GAGhB,WAAtBvI,KAAKkI,aAA2B,CAClC,IAAMtD,EAAS+D,KAAKC,KAAKZ,GACzB,GAAc,SAAV/O,EACF,MAAM,IAAIe,EACHgG,KAAKjE,gDAEd,OAAO6L,kBAAgBtE,EAAO,EAAGsB,EAAQ3L,EAAO+G,KAAK6E,MAErD,IAAMkE,EAAQJ,KAAKC,KAAK,EAAIZ,GAC5B,OAAOV,gBAAchE,GAAQyF,EAAOA,EAAO9P,IAI/CmP,sBAAA,WACE,OACEJ,MAAOhI,KAAKgI,MACZC,KAAMjI,KAAKiI,KACXC,aAAclI,KAAKkI,aACnBrD,KAAM7E,KAAK6E,OAvDRuD,YAAY,qBADgB1B,oBA4DvBzG,iBAAiBC,SAASkI,IAkBxC,mBAQE,WAAYpM,UACV1C,aACE0O,MAAO,EACPC,KAAM,SACNC,aAAc,UACdrD,KAAgB,MAAV7I,EAAiB,KAAOA,EAAO6I,aAU3C,OAvBmCjL,OAiBjCoP,yBAAA,WAIE,OAAOZ,GAAgBtM,cArBQsM,mBA4CjC,WAAYpM,UACV1C,aACE0O,MAAO,EACPC,KAAM,SACNC,aAAc,SACdrD,KAAgB,MAAV7I,EAAiB,KAAOA,EAAO6I,aAU3C,OAvBkCjL,OAiBhCqP,yBAAA,WAIE,OAAOb,GAAgBtM,cArBOsM,mBAoChC,WAAYpM,UACV1C,aACE0O,MAAO,EACPC,KAAM,QACNC,aAAc,SACdrD,KAAgB,MAAV7I,EAAiB,KAAOA,EAAO6I,aAU3C,OAhB8BjL,OAU5BsP,yBAAA,WAIE,OAAOd,GAAgBtM,cAdGsM,mBA8B5B,WAAYpM,UACV1C,aACE0O,MAAO,EACPC,KAAM,QACNC,aAAc,SACdrD,KAAgB,MAAV7I,EAAiB,KAAOA,EAAO6I,aAU3C,OAhBiCjL,OAU/BuP,yBAAA,WAIE,OAAOf,GAAgBtM,cAdMsM,mBAqC/B,WAAYpM,GAAZ,MACE1C,mBAIA,GATOG,eAAe,EAMtBA,EAAKoO,KAAsB,MAAf7L,EAAO6L,KAAepO,EAAK2P,aAAepN,EAAO6L,KAC7DpO,EAAKoL,KAAO7I,EAAO6I,KAEF,MAAbpL,EAAKoL,KACP,MAAM,IAAI7K,EACN,2EAmCV,OAhDgCJ,OAiB9ByP,kBAAA,SAAM/F,EAAcrK,GAApB,WACE,OAAO2F,OAAK,WACV,GAAqB,IAAjB0E,EAAMrI,OACR,MAAM,IAAIjB,EACN,kEAEFsJ,EAAM,GAAKA,EAAM,GAAK,KACxBgG,QAAQC,KACJ,2EACcjG,EAAM,GAAKA,EAAM,uCAKrC,IAEM5F,EAAIgK,GADNpE,EAAM,GAAKA,EAAM,IAAMA,EAAM,GAAIA,EAAM,IAAMA,EACP,EAAG,EAAG,WAC5CkG,EAAIC,SAAOC,YAAYhM,GAI3B,OAHI4F,EAAM,GAAKA,EAAM,KACnBkG,EAAIA,EAAEG,aAED3C,MAAIlH,EAAUrG,EAAKoO,MAAO2B,MAIrCH,sBAAA,WACE,OACExB,KAAM7H,KAAK6H,KACXhD,KAAM7E,KAAK6E,OA5CRwE,YAAY,gBADW3C,oBAiDlBzG,iBAAiBC,SAASmJ,IASjC,IAAMO,IAEPC,SAAY,WACZC,aAAgB,eAChBC,cAAiB,gBACjBC,SAAY,WACZC,SAAY,WACZC,YAAe,cACfpD,KAAQ,OACRqD,WAAc,aACdC,aAAgB,eAChB9C,cAAiB,gBACjBM,gBAAmB,kBACnByC,gBAAmB,kBACnBzD,MAAS,SAGf,YACI5K,EACAG,GACF,oBADEA,MACK+E,EACHlF,EAAQiD,gBAAcgB,iBAAiBkB,SAASC,aAChDjF,EAAe,2BAGgBmO,GAEnC,OAAOrJ,EAAqBqJ,eAGC/O,GAE7B,GAA0B,iBAAfA,EAAyB,CAClC,IAAMO,EAAYP,KAAcqO,GAC5BA,GAA2CrO,GAC3CA,EAIJ,MAAkB,kBAAdO,EACK,IAAIkN,GACY,iBAAdlN,EACF,IAAImN,GACY,aAAdnN,EACF,IAAIoN,GACY,gBAAdpN,EACF,IAAIqN,GAGJoB,IADSzO,YAAWE,YAGxB,OAAIT,aAAsBmL,GACxBnL,EAEAgP,GAAuBhP,0CCxoBhC,OAAO,IAAIoL,oBAWX,OAAO,IAAIE,sBAWY7K,GACvB,OAAO,IAAI+K,GAAS/K,2BAWQA,GAC5B,OAAO,IAAIqL,GAAcrL,0BAWEA,GAC3B,OAAO,IAAIyL,GAAazL,6BAWMA,GAC9B,OAAO,IAAI2L,GAAgB3L,sBAWJA,GACvB,OAAO,IAAI8L,GAAS9L,6BAWUA,GAC9B,OAAO,IAAIoM,GAAgBpM,2BAWCA,GAC5B,OAAO,IAAIgN,GAAchN,0BAWEA,GAC3B,OAAO,IAAIiN,GAAajN,sBAWDA,GACvB,OAAO,IAAIkN,GAASlN,yBAWMA,GAC1B,OAAO,IAAImN,GAAYnN,wBAWEA,GACzB,OAAO,IAAIqN,GAAWrN,kBC7IQd,GAC9B,OAAOd,MAAMC,QAAQa,IAAMd,MAAMC,QAAQa,EAAE,gBASVA,GACjC,OAAiB,IAAbA,EAAED,UAGDb,MAAMC,QAAQa,EAAE,IAGdA,GAFGA,eAWwBF,GAClC,IAAIE,EACJ,GAAId,MAAMC,QAAQW,GAAK,CACrB,GAAkB,IAAdA,EAAGC,OACL,MAAM,IAAIlB,EAAW,uCAAuCiB,EAAGC,QAEjEC,EAAIF,EAAG,QAEPE,EAAIF,EAEN,OAAOE,cAa0BsP,GACjC,GAAIpQ,MAAMC,QAAQmQ,IAAWpQ,MAAMC,QAAQmQ,EAAO,IAAK,CACrD,GAAsB,IAAlBA,EAAOvP,OAET,OADAuP,EAASA,GACK,GAEd,MAAM,IAAIzQ,EAAW,iCAAiCyQ,EAAOvP,QAG/D,OAAOuP,cC7D0BC,GAEnC,IADA,IAAIC,EAAQ,MACSC,IAAA5P,WAAAA,KAAhB,IAAM6P,OACmB,IAAxBA,EAAOtH,MAAMrI,OACfyP,GAAS,EAETA,GAASE,EAAOtH,MAAMuH,OAAO,SAACnN,EAAGC,GAAM,OAAAD,EAAIC,IAG/C,OAAO+M,ECTT,IAAMI,GAA+B,yBAoCnC,WACIpQ,EAAazB,EACbkC,EAAqC4P,EACrC/J,gBAFa/H,0BACbkC,mBAAqC4P,mBACrC/J,QACFhB,KAAK/G,MAAiB,MAATA,EAAgB,UAAYA,EACzC+G,KAAKsD,MAAQ5I,EAAI4I,MACjBtD,KAAKgL,GAAKC,IAEV9P,EAAe,MAARA,EAAe2P,GAA+B3P,EACrD6E,KAAKkL,aAAeC,GAAoBhQ,GACxC6E,KAAK7E,KAAOiQ,GAAoBpL,KAAKkL,cAErClL,KAAK+K,UAAYA,EACjB/K,KAAKgB,WAAaA,EAElBhB,KAAKtF,IAAM2Q,WAAa3Q,EAAKsF,KAAK+K,UAAW/K,KAAK7E,KAAM6E,KAAK/G,OA8BjE,OApBEqS,iBAAA,WACE,OAAOtL,KAAKtF,KAUd4Q,kBAAA,SAAMC,GAOJ,OAIJ,SAA0BrQ,EAAa6J,GACrC,GAAI7J,EAAEoI,MAAM3K,aAAeoM,EAAEzB,MAAM3K,WACjC,MAAM,IAAIkB,MACN,mBAAqB0C,KAAKC,UAAUtB,EAAEoI,OAAS,QAC/C/G,KAAKC,UAAUuI,EAAEzB,QAbrBkI,CAAiBxL,KAAKtF,IAAK6Q,GAC3BvL,KAAKtF,IAAI+Q,OAAOF,GACO,MAAnBvL,KAAKgB,YACPhB,KAAKtF,IAAI+Q,OAAOzL,KAAKgB,WAAW0K,MAAM1L,KAAKtF,MAEtCsF,uBA+LmBhF,GAC5B,OAAOA,EAAG2Q,IAAI,SAAAzQ,GAAK,OAAAA,EAAE0Q,qBAYnBC,GACFA,EAAmBF,IAAI,SAACG,GACUA,EAAiB,GACxCC,MAAMD,EAAiB,MCvPpC,kBA8BA,OAhBE,SAAY9P,GACVgE,KAAK/G,MAAQ+C,EAAO/C,MACpB+G,KAAKsD,MAAQtH,EAAOsH,MAKA,MAAhBtH,EAAOsH,MACTtD,KAAKgM,KAAOhQ,EAAOsH,MAAMrI,OAEzB+E,KAAKgM,KAAOhQ,EAAOgQ,KAErBhM,KAAKiM,QAAUjQ,EAAOiQ,QACtBjM,KAAKkM,QAAUlQ,EAAOkQ,QACtBlM,KAAKmM,KAAOnQ,EAAOmQ,2BA0DvB,OAZE,SACalT,EAA0BqK,EAC5B8I,EAA6BC,EAC3BC,EAAkBnR,EAClBoR,GAHAvM,WAAA/G,EAA0B+G,WAAAsD,EAC5BtD,iBAAAoM,EAA6BpM,YAAAqM,EAC3BrM,cAAAsM,EACAtM,uBAAAuM,EACXvM,KAAKgL,GAAKC,IACE,MAAR9P,IACF6E,KAAKkL,aAAeC,GAAoBhQ,GACxC6E,KAAK7E,KAAOiQ,GAAoBpL,KAAKkL,eAEvClL,KAAK4D,KAAON,EAAMrI,WA8ClBuR,GAAc,gBA8DhB,WACIxQ,EAEOsQ,GAAAtM,cAAAsM,EACTtM,KAAKgL,GAAKwB,KAQVxM,KAAKyM,cAAgBzQ,EAAOyQ,cAU5BzM,KAAK0M,cAAgB1Q,EAAO0Q,cAE5B1M,KAAK2M,YAAc3Q,EAAO2Q,YAE1B3M,KAAK4M,cAAgB5Q,EAAO4Q,cAQ5B5M,KAAK6M,aAAe7Q,EAAO6Q,aAE3B7M,KAAK8M,cAAgB9Q,EAAO8Q,cAM5B9M,KAAK+M,WAAa/Q,EAAO+Q,WAEzB/M,KAAKgN,YAAchR,EAAOgR,YAK1BhN,KAAKiN,YAAcjR,EAAOiR,YAE1BjN,KAAKkN,aAAelR,EAAOkR,aAG3B,IAAoB,QAAAvQ,EAAAX,EAAO0Q,cAAP3R,WAAAA,KAAf,IAAMoS,OACI,MAATA,GACFA,EAAMC,cAAcrP,KAAKiC,MAG7BhE,EAAOyQ,cAAcY,aAAatP,KAAKiC,MAmB3C,OAhBEsN,sBAAA,WAEE,IADA,IAAMC,SACc5Q,EAAAqD,KAAK0M,cAAL3R,WAAAA,KAAf,IAAMoS,OACI,MAATA,EACFI,EAAaxP,KAAKoP,EAAMhS,MAExBoS,EAAaxP,KAAK,MAGtB,OACE0O,cAAezM,KAAKyM,cAAgBzM,KAAKyM,cAActR,KAAO,KAC9DuR,cAAea,EACfZ,YAAa3M,KAAK2M,YAClBC,cAAe5M,KAAK4M,qBAoDtBY,GAAe,iBAqDjB,WAAYxR,GAAZ,MACE1C,mBAbMG,YAAsB,KAEtBA,uBAQEA,aAAY,EAIpBA,EAAKuR,GAAKwC,KAEV/T,EAAKgU,oBAAsB,KAE3BhU,EAAKiU,UAAY,KACjBjU,EAAKkU,iBAAkB,EAGvBlU,EAAKmU,qBACLnU,EAAKoU,wBACLpU,EAAKqU,WACLrU,EAAKsU,YACLtU,EAAKuU,QAAS,EAMdvU,EAAK4T,gBACL5T,EAAK2T,iBAEL,IAAIjS,EAAOa,EAAOb,KAClB,IAAKA,EAAM,CACT,IAAMzC,EAASe,EAAKsC,eACpBZ,EAAO8S,EAA0BvV,GAAU,IAAMwV,EAAOxV,GAO1D,GALAe,EAAK0B,KAAOA,EAEZ1B,EAAKsR,UAAgC,MAApB/O,EAAO+O,WAA2B/O,EAAO+O,UAC1DtR,EAAK0U,UAAgC,MAApBnS,EAAOmS,WAA2BnS,EAAOmS,UAEjC,MAArBnS,EAAOoS,YAAgD,MAA1BpS,EAAOqS,gBAAyB,CAK/D,IAAIA,SACJ,GAA8B,MAA1BrS,EAAOqS,gBACTA,EAAkBrS,EAAOqS,qBACpB,GAAyB,MAArBrS,EAAOoS,WAAoB,CACpC,IAAIE,EAAoB,KACA,MAApBtS,EAAOsS,YACTA,EAAYtS,EAAOsS,WAErBD,GAAmBC,GAAW9T,OAAOwB,EAAOoS,YAE9C3U,EAAK4U,gBAAkBA,EAGvB,IAAIpV,EAAQ+C,EAAO/C,MACN,MAATA,IACFA,EAAQ+C,EAAOuS,YAEJ,MAATtV,IACFA,EAAQ,WAEVQ,EAAKR,MAAQA,SAGO,MAAlB+C,EAAOyO,QACThR,EAAK+U,eAAiBxS,EAAOyO,QAE7BhR,EAAK+U,eAAiB,OAi4B5B,OA5+BoC5U,OAwHjB6U,UAAjB,SAAyBtB,EAAcuB,GACrC,OAAOvB,EAAMhS,KAAO,OAASuT,EAAU/V,YAUjC8V,2BAAR,SAAuBC,EAAmBC,GACxC,GAAiC,IAA7B3O,KAAKqN,aAAapS,OACpB,MAAM,IAAInB,EACN,2DAC2B6U,OAEjC,GAAI3O,KAAKqN,aAAapS,QAAUyT,EAC9B,MAAM,IAAI3U,EACN,gBAAgB4U,cAAoBD,8BACV1O,KAAKqN,aAAapS,0BAElD,OAAO+E,KAAKqN,aAAaqB,IAY3BD,uBAAA,SAAWC,GACT,OAAOE,EACH5O,KAAK6O,eAAeH,EAAW,SAAS7B,eAY9C4B,wBAAA,SAAYC,GACV,OAAOE,EACH5O,KAAK6O,eAAeH,EAAW,UAAU5B,gBAgB/CvT,sBAAIkV,yBAAJ,WACE,GAAIzO,KAAKqN,aAAapS,OAAS,EAC7B,MAAM,IAAIvB,EACN,SAASsG,KAAK7E,KACd,uHAIC,GAAiC,IAA7B6E,KAAKqN,aAAapS,OAC3B,MAAM,IAAIvB,EACN,SAASsG,KAAK7E,KACd,0CAEN,OAAOyT,EACH5O,KAAK6O,eAAe,EAAG,SAAShC,+CActCtT,sBAAIkV,0BAAJ,WACE,GAAiC,IAA7BzO,KAAKqN,aAAapS,OACpB,MAAM,IAAIvB,EACN,SAASsG,KAAK7E,KACd,0BAEN,GAAI6E,KAAKqN,aAAapS,OAAS,EAC7B,MAAM,IAAIvB,EACN,SAASsG,KAAK7E,KACd,yHAKN,OAAOyT,EACH5O,KAAK6O,eAAe,EAAG,UAAU/B,gDAGvCvT,sBAAIkV,0BAAJ,WACE,OAAOzO,KAAK8N,yCAQdW,4BAAA,WAKE,OAAOzO,KAAK8O,OAAOnD,IAAI,SAAAoD,GAAU,OAAAA,OAGnCxV,sBAAIkV,2BAAJ,WACE,OAAOzO,KAAK+N,0CAGdxU,sBAAIkV,yBAAJ,WACE,OAAOzO,KAAKgO,YAGd,SAAUgB,GACRhP,KAAKgO,OAASgB,mCAGhBzV,sBAAIkV,oCAAJ,WACE,OAAIzO,KAAK+K,UACA/K,KAAK4N,0BAMhB,SAAqBnD,GACnBzK,KAAK4N,kBAAoBnD,mCAG3BlR,sBAAIkV,uCAAJ,WACE,OAAKzO,KAAK+K,UAGD/K,KAAK6N,qBAFL7N,KAAK4N,kBAAkBpT,OAAOwF,KAAK6N,2BAM9C,SAAwBpD,GACtBzK,KAAK6N,qBAAuBpD,mCAO9BlR,sBAAIkV,2BAAJ,WACE,OAAOzO,KAAKiP,iBAAiBzU,OAAOwF,KAAKkP,sDAG3C3V,sBAAIkV,4BAAJ,WACE,OAAOzO,KAAKmP,2CAeJV,qCAAV,SAAmCpC,GAGjC,GADAA,EAAS+C,EAAqB/C,GACR,MAAlBrM,KAAK0N,WAA+C,IAA1B1N,KAAK0N,UAAUzS,OAA7C,CAGA,IAAMyS,EAAY0B,EAAqBpP,KAAK0N,WAC5C,GAAIrB,EAAOpR,SAAWyS,EAAUzS,OAC9B,MAAM,IAAIlB,EACN,SAASiG,KAAK7E,iBAAgBuS,EAAUzS,mCACrBoR,EAAOpR,0CACPoR,GAEzB,IAAK,IAAIgD,EAAa,EAAGA,EAAahD,EAAOpR,OAAQoU,IAAc,CACjE,IAAMnU,EAAImR,EAAOgD,GACXC,EAAkB5B,EAAU2B,GAClC,GAAY,MAARC,EAAJ,CAKA,IAAMtD,EAAO9Q,EAAE0I,KACf,GAAiB,MAAb0L,EAAKtD,MACHA,IAASsD,EAAKtD,KAChB,MAAM,IAAIjS,EACN,SAASsV,iCAAyCrP,KAAK7E,wBACtCmU,EAAKtD,qBAAoBA,GAGlD,GAAoB,MAAhBsD,EAAKrD,SACHD,EAAOsD,EAAKrD,QACd,MAAM,IAAIlS,EACN,SAASsV,iCAAyCrP,KAAK7E,KACvD,uBAAuBmU,EAAKrD,wBAAuBD,GAG3D,GAAoB,MAAhBsD,EAAKpD,SACHF,EAAOsD,EAAKpD,QACd,MAAM,IAAInS,EACN,SAASsV,iCAAyCrP,KAAK7E,KACvD,uBAAuBmU,EAAKpD,wBAAuBF,OAK3D,GAAkB,MAAdsD,EAAKrW,OACHiC,EAAEjC,QAAUqW,EAAKrW,MACnB,MAAM,IAAIc,EACN,SAASsV,iCAAyCrP,KAAK7E,0BACnCmU,EAAKrW,uBAAsBiC,EAAEjC,WAKzD,GAAIqW,EAAKnD,KAAM,CACb,IAAMoD,EAASrU,EAAEoI,MACjB,IAAK,IAAMrG,KAAOqS,EAAKnD,KAAM,CAC3B,IAAMxN,EAAO6Q,OAAOvS,GACdjE,EAAQsW,EAAKnD,KAAKlP,GAIlBwS,EACF9Q,GAAQ,EAAI4Q,EAAO5Q,GAAQ4Q,EAAOA,EAAOtU,OAAS0D,GACtD,GAAa,MAAT3F,IAA0D,KAAxCA,EAAO,MAAMwC,QAAQiU,GACzC,MAAM,IAAI1V,EACN,SAASsV,iCACNrP,KAAK7E,wBAAuBwD,mCACjB3F,oBAAuBuW,QAM/C,GAAkB,MAAdD,EAAKhM,MACP,IAAK,IAAI/I,EAAI,EAAGA,EAAI+U,EAAKhM,MAAMrI,SAAUV,EAAG,CAC1C,IAAMmV,EAAUJ,EAAKhM,MAAM/I,GACrBoV,EAAMzU,EAAEoI,MAAM/I,GACpB,GAAe,MAAXmV,GAA0B,MAAPC,GACjBD,IAAYC,EACd,MAAM,IAAI5V,EACN,SAASsV,iCACNrP,KAAK7E,yBAAwBmU,EAAKhM,uCAiBrDmL,iBAAA,SAAKpC,EAAyBuD,GAC5B,OAAOvD,GAGCoC,2BAAV,SAAyBpC,EAAyBuD,GAC1B,MAAlB5P,KAAK6P,WACP7P,KAAK6P,UAAUxD,EAAQuD,IAS3BnB,wBAAA,SAAYqB,GACV9P,KAAK6P,UAAYC,GAOnBrB,0BAAA,WACEzO,KAAK6P,UAAY,MAuEnBpB,kBAAA,SACIpC,EACAuD,GAFJ,WAGEA,EAASA,MAMT,IAHA,IAAMG,EAAaX,EAAqB/C,GAEpC2D,GAAiB,MACDC,IAAAlV,WAAAA,KAClB,oBAAuBmV,IAAiB,CACtCF,GAAiB,EACjB,OAIJ,IADA,IAAIG,GAAkB,MACFC,IAAAzT,WAAAA,KAClB,kBAAqBuT,GAAgB,CACnCC,GAAkB,EAClB,OAIJ,GAAIH,IAAmBG,EACrB,MAAM,IAAIpW,EACN,mEAKN,OAAOsW,GAAUrQ,KAAK7E,KAAM,WAE1B,IAAK1B,EAAKuV,MAAO,CAKfvV,EAAK6W,yBAAyBjE,GAI9B,IADA,IAAMY,SACctQ,EAAAyS,EAAqB/C,GAArBtR,WAAAA,KAAf,IAAMwV,OACTtD,EAAYlP,KAAKwS,EAAMjN,OAEzB7J,EAAK+W,MAAM5B,EAA+B3B,IAC1CxT,EAAKuV,OAAQ,EAGTvV,EAAK+U,gBACP/U,EAAKgX,WAAWhX,EAAK+U,gBAczB,GANA/U,EAAK6W,yBAAyBjE,GAM1B8D,EAAiB,CAUnB,IATA,IAMMO,SAGQC,EAJevB,EALzBwB,EAASnX,EAAKoX,KAAKxE,EAA6BuD,IAStChT,WAAAA,KAAT,IAAI1B,QACwB,IAA3B6U,EAAWvU,QAAQN,KACrBA,EAAIA,EAAE4V,SAERJ,EAAe3S,KAAK7C,GAItB,GAFA0V,EAAShC,EAA+B8B,GAER,MAA5BjX,EAAKgU,oBACP,MAAM,IAAIzT,EACN,qFAKN,OAAO4W,EAEP,IAAMxC,EAsad,SAA2BvB,GAKzB,IADA,IAAMrC,SACUuG,EAHhBlE,EACIuC,EAAqBvC,GAET9R,WAAAA,KAAX,IAAMG,OACTsP,EAAOzM,KAAK7C,EAAEoI,OAEhB,OAAOsL,EAA+BpE,GA9abwG,CAAkB3E,GAC/B4E,EAAcxX,EAAKyX,mBAAmB9C,GACxCwC,SAgCJ,GA9BAnX,EAAK0X,6BACD/W,MAAMC,QAAQgS,GAAU+B,EAAW,GACXA,GAK1BwC,EAHiB,MAAfK,GAAuBA,EAAYhW,OAAS,GAC5Cb,MAAMC,QAAQ4W,EAAY,IAElBA,EACItF,IACG,SAACrI,EAAOjB,GAAU,OAAA,IAAI6N,GA+axC,UA9amC5M,EAAO7J,EACpB2V,EAAqB/C,GAASuD,EAAQnW,EAAK0B,KAC3CkH,KAEZ,IAAI6N,GA0ad,UAzakBe,EAAsBxX,EACnC2V,EAAqB/C,GAASuD,EAAQnW,EAAK0B,MAUjD1B,EAAK2X,eACD/E,EAA6CuE,EAAQ,KAAM,KAC3DxC,EAAY6C,EAAarB,GAEG,MAA5BnW,EAAKgU,oBACP,MAAM,IAAIzT,EACN,qFAIN,OAAO4W,KAYHnC,yCAAV,SAAuCL,GACrC,GAA4B,MAAxBpO,KAAKqO,gBAEF,GAAID,EAAWnT,SAAW+E,KAAKqO,gBAAgBpT,OACpDqO,QAAQC,KACJ,iDACGhN,KAAKC,UAAU4R,oDACE7R,KAAKC,UAAUwD,KAAKqO,mCACxBrO,KAAK7E,UACpB,CACL,IAAIkW,GAAc,EAClBrR,KAAKqO,gBAAgBiD,QAAQ,SAACC,EAAWhX,GACtB,MAAbgX,GAAsC,MAAjBnD,EAAW7T,IAChC6T,EAAW7T,KAAOgX,IACpBF,GAAc,KAGdA,GACF/H,QAAQC,KACJ,kCACIhN,KAAKC,UAAU4R,gDACepO,KAAK7E,UACpCoB,KAAKC,UAAUwD,KAAKqO,oBAejC9U,sBAAIkV,+BAAJ,WACE,GAAyB,MAArBzO,KAAKqN,cAAqD,IAA7BrN,KAAKqN,aAAapS,OACjD,MAAM,IAAIvB,EACN,aAAasG,KAAK7E,qEAIxB,IADA,IAAMqW,SACa7U,EAAAqD,KAAKqN,aAALtS,WAAAA,KAAd,IAAM0W,OACHC,EAAcnV,KAAKC,UAAUiV,EAAKvE,eACM,IAA1CsE,EAAgBhW,QAAQkW,IAC1BF,EAAgBzT,KAAK2T,GAGzB,GAA+B,IAA3BF,EAAgBvW,OAAc,CAChC,IAAMiS,EAAelN,KAAKqN,aAAa,GAAGH,aAC1C,OAAI9S,MAAMC,QAAQ6S,IAAiB9S,MAAMC,QAAQ6S,EAAa,KAClC,IAAxBA,EAAajS,OACPiS,EAAyB,GAE1BA,EAIT,MAAM,IAAIxT,EACN,aAAasG,KAAK7E,mKAe1BsT,wBAAA,WACE,IAAKzO,KAAKgP,MACR,MAAM,IAAIlV,EACN,sCAAsCkG,KAAK7E,4FAIjD,OAAOwW,GAAoC3R,KAAKyK,UAYlDgE,kBAAA,SAAML,GACJpO,KAAKgP,OAAQ,GASfP,uBAAA,SAAWmD,GACT,oBADSA,MACFC,GAAcD,EAAgB5R,KAAKiP,iBAAmBjP,KAAKyK,UAapEgE,uBAAA,SAAWhE,GAAX,WACE7L,OAAK,WACH,IAAMkT,EAASrY,EAAKgR,QACpB,GAAIqH,EAAO7W,SAAWwP,EAAQxP,OAK5B,MAAM,IAAIlB,EACN,4CAA4CN,EAAK0B,uCACjBsP,EAAQxP,wCACT6W,EAAO7W,sCACjBwP,SAE3B,GAAsB,IAAlBqH,EAAO7W,OAAX,CAKA,IAFA,IAAM8W,KACAC,EAAcH,GAAcC,GACzBvX,EAAI,EAAGA,EAAIyX,EAAY/W,SAAUV,EAAG,CAC3C,IAAM0X,EAAKD,EAAYzX,GACjB2X,EAAIJ,EAAOvX,GACXmE,EAAI+L,EAAQlQ,GAClB,IAAKwL,OAAKC,YAAYiM,EAAG3O,MAAO5E,EAAE4E,OAChC,MAAM,IAAIvJ,EACN,sBAAsBkY,EAAG3O,oDACoB5E,EAAE4E,OAErDyO,EAAkBhU,MAAMmU,EAAGxT,IAE7ByT,GAAcJ,OAiBRtD,sBAAV,SACItT,EAAcmI,EAAcrK,EAAkBqR,EAC9C8H,EAA2BrH,EAC3B/J,GAEF,IAA8C,IAA1ChB,KAAKqS,kBAAkB7W,QAAQL,GACjC,MAAM,IAAIpB,EACN,yBAAyBoB,gBAAkB6E,KAAK7E,MAEtD6E,KAAKqS,kBAAkBtU,KAAK5C,GAEf,MAATlC,IACFA,EAAQ,WAEV,IAAM2R,EAAS,IAAIU,GACfhB,EAAYoB,MAAMpI,EAAOrK,GAAQA,EAAOkC,EAAM4P,EAAW/J,GAa7D,OAXmB,MAAfoR,GACFpS,KAAKsS,QAAQ,WAAM,OAAAF,EAAY1G,MAAMd,EAAOgB,UAE7B,MAAbb,IACFA,GAAY,GAEVA,EACF/K,KAAK4N,kBAAkB7P,KAAK6M,GAE5B5K,KAAK6N,qBAAqB9P,KAAK6M,GAE1BA,GAST6D,oBAAA,SAAQK,SACQ,MAAVA,GAAkB1U,MAAMC,QAAQyU,IAA6B,IAAlBA,EAAO7T,SAItD6T,EAASM,EAAqBN,QACT5V,IAAjB8G,KAAK8N,SAA0C,OAAjB9N,KAAK8N,UACrCnR,EAAAqD,KAAK8O,QAAO/Q,aAAQ+Q,KAaxBL,+BAAA,SAAmBL,GACjB,OAAOA,GAYTK,wBAAA,SAAYpC,EAAyBkG,GAArC,WAEE,IAAKvS,KAAK2N,gBAAiB,CACzB,GAAY,MAAR4E,EAAc,CAChB,IAAInY,MAAMC,QAAQkY,GAShB,MAAM,IAAIC,UACN,SAASxS,KAAK7E,+DATlBoX,EAAKjB,QAAQ,SAAAmB,GACX,GAAmB,MAAfA,EACF,MAAM,IAAID,UACN,SAAS/Y,EAAK0B,iEAW1B,OAAO,KAIT,OAAOoX,GAeD9D,2BAAR,SACI5B,EACAC,EACAC,EAA6BC,EAC7BC,EAA4BC,EAC5B0C,gBAAAA,QACF,IAAM8C,EACFtD,EAAqBvC,GACzBC,EAAgBsC,EAAqBtC,GACrCC,EAAaqC,EAAqBrC,GAClCC,EAAcoC,EAAqBpC,GACnCC,EAAc0F,GAA+B1F,GAC7CC,EAAeyF,GAA+BzF,GAM9C,IAHA,IAAMR,KACAC,KACAC,SACUgG,IAAA7X,WAAAA,KAAX,IAAMG,OAKTwR,EAAc3O,KAAK7C,EAAEkR,aACrBO,EAAY5O,KAAK7C,EAAEwT,WACnB9B,EAAc7O,KAAK7C,EAAE2X,aAMvB,IAAIvF,IAEEb,cAAezM,KACf0M,gBACAC,cACAC,gBACAC,aAAc6F,EACd5F,gBACAC,aACAC,cACAC,cACAC,gBAEF0C,GAGJ,IAAK,IAAIrV,EAAI,EAAGA,EAAIuS,EAAc7R,OAAQV,IAExCuS,EAAcvS,GAAG6R,YAAcpM,KAC/B8M,EAAcvS,GAAGmU,UAAY1O,KAAKqN,aAAapS,OAAS,EACxD6R,EAAcvS,GAAGsY,YAActY,GAuBnCkU,sBAAA,WACE,IAAMzS,GAC0Bb,KAAM6E,KAAK7E,KAAM4P,UAAW/K,KAAK+K,WAOjE,OAN4B,MAAxB/K,KAAKqO,kBACPrS,EAAwB,gBAAIgE,KAAKqO,iBAEjB,MAAdrO,KAAK/G,QACP+C,EAAc,MAAIgE,KAAK/G,OAElB+C,MA1+ByBiD,gBAAcC,cCvUlD,mBAGE,WAAYlD,GAAZ,MACE1C,aACEL,MAAO+C,EAAO/C,MACdkC,KAAqB,MAAfa,EAAOb,KAAea,EAAOb,KAAO+S,EAAO,SAASvV,mBAc5D,GAXwB,MAApBqD,EAAOsS,YACTtS,EAAOsS,UAAY,MAEA,MAAjBtS,EAAO8W,SACT9W,EAAO8W,QAAS,GAGlBrZ,EAAKsR,WAAY,EACjBtR,EAAKuV,OAAQ,EACbvV,EAAKqZ,OAAS9W,EAAO8W,OAEI,MAArB9W,EAAOoS,YAAgD,MAA1BpS,EAAOqS,gBACtC,MAAM,IAAItU,EACN,qGAGN,IAAIsU,EAAkBrS,EAAOqS,gBAC7B,GAAuB,MAAnBA,EAAyB,CAC3B,GAAyB,MAArBrS,EAAOoS,WACT,MAAM,IAAIrU,EACN,iFAGJsU,GAAmBrS,EAAOsS,WAAW9T,OAAOwB,EAAOoS,iBAIrD,GAAwB,MAApBpS,EAAOsS,UACT,MAAM,IAAIvU,EACN,wFAKR,IAAMd,EAAQ+C,EAAO/C,OAAS,UAE9BQ,EAAK4U,gBAAkBA,EACvB5U,EAAKR,MAAQA,EAEbQ,EAAKiU,YAAcpK,MAAO+K,IAE1B,IAAM0E,EAAc,IAAI7C,GACpBzW,EAAKR,MAAOQ,EAAK4U,gBAAiB5U,QAAcA,EAAK0B,aACzD4X,EAAYrE,UAAY,EACxBqE,EAAYF,YAAc,EAK1B,IAAIvF,IACFb,cAAehT,EACfiT,iBACAC,eACAC,iBACAC,cAAekG,GACfjG,eAAgBiG,GAChBhG,YAAa,MACbC,aAAc,MACdC,aAAcoB,GACdnB,cAAemB,OAoBrB,OAxFgCzU,OAwE9BoZ,kBAAA,SACI3G,EACAuD,GACF,MAAM,IAAI7V,EACN,6EACiDiG,KAAK7E,OAG5D6X,sBAAA,WACE,OACE3E,gBAAiBrO,KAAKqO,gBACtBpV,MAAO+G,KAAK/G,MACZ6Z,OAAQ9S,KAAK8S,OACb3X,KAAM6E,KAAK7E,OApFC6X,YAAY,gBADEvE,gBAiJVzS,GACpB,GAAyB,MAArBA,EAAOiX,YAAsC,MAAhBjX,EAAOsH,MACtC,MAAM,IAAIzJ,MACN,gIAKN,GAAyB,MAArBmC,EAAOiX,YAAsC,MAAhBjX,EAAOsH,MAEtC,MAAM,IAAIvJ,EACN,oFAGN,IAAIkZ,EAAajX,EAAOiX,WACJ,MAAhBjX,EAAOsH,OAA+B,MAAd2P,IAC1BA,GAAc,MAAMzY,OAAOwB,EAAOsH,QAGpC,IAAIrK,EAAQ+C,EAAO/C,MAanB,OAZa,MAATA,IACFA,EAAQ,WAGS,IAAI+Z,IACrB3E,gBAAiB4E,EACjB9X,KAAMa,EAAOb,KACblC,QACA6Z,OAAQ9W,EAAO8W,SAGUzF,aAAa,GAAGP,cAC5B,eCnN0BoG,+GACzC,GAAY,MAARA,EACF,UAKF,IAAWjW,KAHLkW,KACAnW,KACAoW,KACYF,EAEK,iBADfla,EAAQka,EAAKjW,MAEXoW,EAAcra,EACpBma,EAASpV,KAAKsV,EAAYC,QAC1BtW,EAAKe,KAAKd,GACVmW,EAAiBrV,KAAKsV,IAGX,SAAME,QAAQC,IAAIL,WACjC,IADMjV,EAASvB,SACNpC,EAAI,EAAGA,EAAI2D,EAAOjD,SAAUV,EACnC2Y,EAAKlW,EAAKzC,IAAM2D,EAAO3D,GAAG,UAI5BkZ,UAAQL,4BDqGInT,iBAAiBC,SAAS8S,IE3GxC,kBAAA,aAEEhT,oBAAkC,KA+BpC,OAzBE0T,sBAAA,SAAU5B,GACR9R,KAAK8R,OAASA,GAGV4B,yBAAN,SAAmBC,EAAeT,mFAE5BQ,uBAAN,SAAiBC,EAAeT,mFAE1BQ,yBAAN,SAAmBE,EAAeV,mFAE5BQ,uBAAN,SAAiBE,EAAeV,mFAE1BQ,yBAAN,SAAmBR,mFAEbQ,uBAAN,SAAiBR,mFAQjBQ,qBAAA,SAASG,wBAwBT,WAAYC,EAA4BC,gBAAAA,MAGrB,MAAbD,IACFA,MAEF9T,KAAK8T,UAAYA,EACjB9T,KAAK+T,YAAcA,EAoGvB,OAjGEC,mBAAA,SAAOC,GACLjU,KAAK8T,UAAU/V,KAAKkW,IAGtBD,sBAAA,SAAUlC,GACR,IAAuB,QAAAnV,EAAAqD,KAAK8T,UAAL/Y,WAAAA,UACZmZ,UAAUpC,KAIvBkC,qBAAA,SAASH,GACP,IAAuB,QAAAlX,EAAAqD,KAAK8T,UAAL/Y,WAAAA,UACZoZ,SAASN,KAShBG,yBAAN,SAAmBL,EAAeT,mGACpB,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACNqZ,aAAaT,EAAOT,iBAAnCtW,iCADqB7B,iCAUnBiZ,uBAAN,SAAiBL,EAAeT,mGAClB,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACNsZ,WAAWV,EAAOT,iBAAjCtW,iCADqB7B,iCAUnBiZ,yBAAN,SAAmBJ,EAAeV,mGACpB,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACNuZ,aAAaV,EAAOV,iBAAnCtW,iCADqB7B,iCAUnBiZ,uBAAN,SAAiBJ,EAAeV,mGAClB,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACNwZ,WAAWX,EAAOV,iBAAjCtW,iCADqB7B,iCASnBiZ,yBAAN,SAAmBd,mGACL,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACNyZ,aAAatB,iBAA5BtW,iCADqB7B,iCASnBiZ,uBAAN,SAAiBd,mGACH,MAARA,IACFA,UAEqBvW,EAAAqD,KAAK8T,kCAAL/Y,mBACN0Z,WAAWvB,iBAA1BtW,iCADqB7B,qDAgBzB,oBACEzB,mBA0DJ,OA/DgCM,OAQxB8a,yBAAN,SAAmBf,EAAeT,2EAChClT,KAAK2U,KAAO,EACZ3U,KAAK4U,mBAGDF,uBAAN,SAAiBd,EAAeV,uFAM9B,IAAWjW,KALC,MAARiW,IACFA,MAEI5E,EAA4B,MAAhB4E,EAAW,KAAY,EAAIA,EAAW,KACxDlT,KAAK2U,MAAQrG,aACFrR,GACT,IAAMjE,EAAQka,EAAKjW,GACnB,GAAqB,iBAAVjE,EACJ6b,EAAKD,OAAO3W,eAAehB,KAC9B4X,EAAKD,OAAO3X,GAAO,GAErB4X,EAAKD,OAAO3X,GAAO4X,EAAKD,OAAO3X,GAAiBjE,EAAQsV,MACnD,CACL,IAAIwG,SACA7X,KAAO4X,EAAKD,OACdE,EAAqBD,EAAKD,OAAO3X,GAEjC4X,EAAKD,OAAO3X,GAAO6C,EAAU,GAG/B+U,EAAKD,OAAO3X,GAAO2B,OACf,WAAM,OAAAgH,MAAKnM,EAAKmb,OAAO3X,GACb+J,MAAIhO,EAAO8G,EAAUwO,OACT,MAAtBwG,GACFA,EAAmBrB,mBAnBPP,IAAPjW,kBAyBPyX,uBAAN,SAAiBf,EAAeT,yFAC9B,GAAY,MAARA,EACF,eAAWjW,GACT,GAAwB,MAApB8X,EAAKH,OAAO3X,oBAGgB,iBAArB8X,EAAKH,OAAO3X,GACrBiW,EAAKjW,GAAO8X,EAAKH,OAAO3X,GAAiB8X,EAAKJ,KAE9C/V,OAAK,WACHsU,EAAKjW,GAAO+J,MAAIgO,MAAIlV,EAAU,GAAIA,EAAUrG,EAAKkb,OACjClb,EAAKmb,OAAO3X,IAC3BxD,EAAKmb,OAAO3X,GAAgBwW,UAC7Bra,OAAK8Z,EAAKjW,kBAXEN,EAAAqD,KAAK8R,OAAgB,QAArB/W,WAAAA,IAAPkC,SAAAA,qBA9CeyW,mBAsEhC,4DA+CA,OA/C6B9Z,OAIrBqb,yBAAN,SAAmB/B,2EACjBlT,KAAK2T,SACL3T,KAAKkV,oBAGDD,uBAAN,SAAiBtB,EAAeT,0EAK9B,IAAWjW,KAJC,MAARiW,IACFA,MAEFlT,KAAK2T,MAAM5V,KAAK4V,GACET,EACS,MAArBlT,KAAKkV,QAAQjY,KACf+C,KAAKkV,QAAQjY,OAEf+C,KAAKkV,QAAQjY,GAAKc,KAAKmV,EAAKjW,mBAO1BgY,qBAAN,yHAIE,IAAWhY,KAHLkW,KACAnW,KACAqI,KACYrF,KAAKkV,QAErB,IADMC,EAAanV,KAAKkV,QAAQjY,GACvB1C,EAAI,EAAGA,EAAI4a,EAAWla,SAAUV,EACV,iBAAlB4a,EAAW5a,KACd8Y,EAAc8B,EAAW5a,GAC/B4Y,EAASpV,KAAKsV,EAAYC,QAC1BtW,EAAKe,KAAKd,GACVoI,EAAQtH,KAAKxD,IAIJ,SAAMgZ,QAAQC,IAAIL,WACjC,IADMjV,EAASvB,SACN8H,EAAI,EAAGA,EAAIvG,EAAOjD,SAAUwJ,EACXzE,KAAKkV,QAAQlY,EAAKyH,IAAIY,EAAQZ,IACtCgP,UAChBzT,KAAKkV,QAAQlY,EAAKyH,IAAIY,EAAQZ,IAAMvG,EAAOuG,GAAG,sBA5CvBiP,mBAqE3B,WAAY1X,GAAZ,MACE1C,0BACAG,EAAK2b,WAAapZ,EAAOwY,aACzB/a,EAAK4b,SAAWrZ,EAAOyY,WACvBhb,EAAK6b,WAAatZ,EAAOoY,aACzB3a,EAAK8b,SAAWvZ,EAAOqY,WACvB5a,EAAK+b,WAAaxZ,EAAOsY,aACzB7a,EAAKgc,SAAWzZ,EAAOuY,aA4C3B,OA3DoC3a,OAkB5B8b,yBAAN,SAAmB/B,EAAeT,kGACT,MAAnBlT,KAAKsV,oBACDK,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKsV,WAAW3B,EAAOT,WAA7BvW,0CAIE+Y,uBAAN,SAAiB/B,EAAeT,kGACT,MAAjBlT,KAAKuV,kBACDI,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKuV,SAAS5B,EAAOT,WAA3BvW,0CAIE+Y,yBAAN,SAAmB9B,EAAeV,kGACT,MAAnBlT,KAAKwV,oBACDG,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKwV,WAAW5B,EAAOV,WAA7BvW,0CAIE+Y,uBAAN,SAAiB9B,EAAeV,kGACT,MAAjBlT,KAAKyV,kBACDE,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKyV,SAAS7B,EAAOV,WAA3BvW,0CAIE+Y,yBAAN,SAAmBxC,kGACM,MAAnBlT,KAAKoV,oBACDO,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKoV,WAAWlC,WAAtBvW,0CAIE+Y,uBAAN,SAAiBxC,kGACM,MAAjBlT,KAAKqV,kBACDM,GAAqBzC,WAC3B,OADAvW,YACMqD,KAAKqV,SAASnC,WAApBvW,6CAxD8B+W,gBC5TRxY,EAAWyD,GACrC,OAAOC,OAAK,WACV,IAAMgX,EAAY9W,MAAQ+W,GAAS3a,GAAIyD,GAAM,GACvCmX,EAAgBnW,MAAQxG,SAAO4G,KAAYgW,WAAa7a,IACxD8a,EAAOnX,OAASoX,UAAYL,EAAWE,IAC7C,OAAOlW,MAAQ1E,EAAG8a,iBAoBWE,EAAeC,GAC9C,OAAOvX,OAAK,WAAM,OAAAwX,OAASP,GAASxP,MAAQ8P,EAAOD,KAAU,iBAqB7BA,EAAeC,GAC/C,OAAOvX,OAAK,WAAM,OAAAwX,OAASC,MAAQhQ,MAAQ8P,EAAOD,KAAU,iBAoB1DA,EAAeC,GACjB,OAAOvX,OAAK,WACV,IAAM0X,EAAOjQ,MAAQ6P,EAAOC,GACtBI,EACF7W,cAAgB2W,MAAQH,GAAQnW,IAAWyP,OAAOgH,WAChDC,EAAYJ,MAAQzW,MAAQ0W,EAAMC,IACxC,OAAO5W,MAAQG,EAAU,KAAQsW,OAASK,GAAY,kBAKtDP,EAAeC,GACjB,OAAOvX,OAAK,WACV,IAAM8X,EAAM5W,EAAU,GAEhB6W,EAAcjX,cAAgByW,EAAOpW,IAAWyP,OAAOgH,WACvDI,EAAWC,MAAQhX,MAAQ6W,EAAKC,IAEhCJ,EAAc7W,cAAgBwW,EAAOnW,IAAWyP,OAAOgH,WACvDM,EAAYD,MAAQhX,MAAQ6W,EAAKH,IAEvC,OAAOH,OAASP,GAASxP,MAAQuQ,EAAUE,KAAc,iBAIhCZ,EAAeC,GAC1C,OAAOvX,OAAK,WACV,IAAMmY,EAAajX,EAAU,GACvB4W,EAAM5W,EAAU,GAChBkX,EACFf,UAAYc,EAAY1Q,MAAQqQ,EAAK/W,MAAQuW,EAAOC,KACxD,OAAOC,OAASP,GAASmB,IAAa,iBAIpBd,EAAeC,GACnC,OAAOvX,OAAK,WACV,IAAMmY,EAAajX,EAAU,GACvB4W,EAAM5W,EAAU,GAChBkX,EACFf,UAAYc,EAAY1Q,MAAQqQ,EAAK/W,MAAQuW,EAAOC,KACxD,OAAOC,OAASY,GAAY,iBAICd,EAAeC,GAC9C,OAAOvX,OAAK,WACV,IAAMmY,EAAajX,EAAU,GACvB4W,EAAM5W,EAAU,GAChBmX,EAAMnY,MAAQa,MAAQuW,EAAOC,IAAS,GACtCe,EAAM/T,MAAQxD,MAAQ0G,MAAQqQ,EAAKR,GAAQC,IAAS,GAC1D,OAAOF,UAAYc,EAAYlX,MAAQ6W,EAAKrQ,MAAQ6Q,EAAKD,mBAYrCf,EAAeC,GACrC,OAAOvX,OAAK,WACV,IAAMuY,EAAOrX,EAAU6I,KAAKyO,IAAI,IAC1BC,EAAiBhR,MAAQ8P,EAAOD,GAChCoB,EAAgBjR,MAClBxG,MACIwX,EACAE,WAAa5X,MAAQG,GAAW,GAAMuX,KAC1CF,GACJ,OAAOf,OAASkB,GAAgB,iBAchCE,EAAgB5G,EAAgB6G,GAClC,oBADkCA,MAC3B7Y,OAAK,WACV,GAAI6Y,EACF7G,EAAS8G,UAAY9G,OAChB,CAEL,IAAM+G,EAAY7Y,MAAQ8R,EAAQA,EAAOtN,MAAMrI,OAAS,GAAG,GAC3D2V,EAAShR,MAAQgR,EAAQ+G,GAG3B,OADA/G,EAASlR,cAAgBkR,EAAQ7Q,IAAW,EAAIA,KACzCoG,MAAQrH,MACXa,MAAQ6X,EAAOI,UAAWf,MAAQjG,IAAUA,EAAOtN,MAAMrI,OAAS,kBActEuc,EAAgB5G,EAAgB6G,GAClC,oBADkCA,MAC3B7Y,OAAK,WACV,IVrFoB1D,EAChB2c,EUoFEC,EAAaC,SVrFC7c,EUqFmBsc,EVpFnCK,GAAYG,GAAqB9c,EAAEoI,QAClCpI,EAAEuI,QAAQoU,KUmFiCvS,QAC1C2L,EAAcL,EAAOtN,MAI3B,OAAO2U,GAFHC,SAAWJ,EAAY7G,EAAYA,EAAYhW,OAAS,IACnDwI,QAAQwN,GAC4BL,EAAQ6G,iBAqCtBvB,EAAeC,GAChD,OAAOvX,OAAK,WACV,IAAImG,EAbJyS,EAAgB5G,EAgBhB,OAFA7L,EAAIrF,cAAgByW,EAAOpW,IAAW,EAAIA,KAC1CgF,EAAI8R,MAAQjX,MAAQmF,EAAGsB,MAAQ0P,WAAahR,GAAIA,KACzCqR,QAhBPoB,EAgB8CtB,EAhB9BtF,EAgBqC7L,EAfhDnG,OAAK,WACV,IAAMuZ,EAAYlC,UAAYrF,EAAQwH,YAAcxH,IAC9CyH,EAAgB1Y,MAAQiR,EAAQ4G,GAChCc,EACFzB,MAAQhX,MAAQC,EAAU,GAAIyY,MAAQpS,MAAQkQ,MAAQzF,OAE1D,OADe/Q,MAAQwG,MAAQ8R,EAAWE,GAAgBC,OAUA,iBAK1DpC,EAAeC,GACjB,OAAOvX,OAAK,WACV,IAAM2X,EAAc7W,cAAgBwW,EAAOnW,IAAW,GAChD4W,EAAcjX,cAAgByW,EAAOpW,IAAW,GACtD,OAAOjB,MACHa,MAAQuW,EAAOW,MAAQjX,MAAQ2W,EAAaI,MAAiB,iBAI7CT,EAAeC,GACrC,OAAOvX,OAAK,WACV,IAAM4Z,EAAU3B,MAAQhX,MAAQC,EAAUC,KAAYoW,IACtD,OAAOC,OAAS/P,MAAQ8P,EAAOxW,MAAQuW,EAAOsC,KAAY,iBAuB9BtC,EAAeC,GAC7C,OAAOvX,OAAK,WACV,IAAM6Z,EAAiBC,GAAYxC,GAAQ,GACrCyC,EAAiBD,GAAYvC,GAAQ,GACrCyC,EAAYjZ,MAAQ8Y,EAAgBE,GAC1C,OAAOxS,MAAQrH,MAAQ8Z,GAAY,kBAoBnBC,GAClB,IAAMC,GACJC,oBACAC,qBACAC,+BACAC,+BACAC,gBACAC,SACAC,oBACAC,WACArB,2BACAsB,iCACAC,sBACAC,6BACAC,WACAC,oBAEF,GAA8B,iBAAnBd,EAA6B,CACtC,GAAIA,KAAkBC,EACpB,OAAOA,EAAUD,GAEnB,MAAM,IAAI9e,EAAW,gBAAgB8e,GAErC,OAAOA,cCjSoB3C,EAAeC,GAC5C,OAAOvX,OAAK,WACV,IAAMgb,EAAYja,MAAQG,EAAU,IAAMiW,WAAaI,IACjD0D,EAAmBC,GAAOC,UAAY5D,EAAOyD,GAAY1D,EAAMjd,OACrE,OAAOmd,OAAS4D,QAAU9D,EAAO2D,IAAoB,iBAoBrB3D,EAAeC,GACjD,OAAOvX,OACH,WAAM,OAAAkb,GACFE,QAAUC,SAAW/D,GAAQ,GAAI+D,SAAW9D,GAAQ,IAAK,yBAkBhCD,EAAeC,GAChD,OAAO+D,GAAuBhE,EAAOC,eAInCD,EAAeC,GACjB,MAAM,IAAInc,EAaL,IAAMmgB,GAAMpB,GACNqB,GAAMrB,GACNsB,GAAMrB,GACNsB,GAAMtB,GACNuB,GAAOtB,GACPuB,GAAOvB,GACPhB,GAA0BwC,GAC1BC,GAASf,GACTJ,GAAgCoB,GCO7C,YACIC,EAAkBC,EAElBC,gBAAAA,EAA6DxR,QAAQ8N,KAEvE,IADA,IAAI2D,EAAO,GACFxgB,EAAI,EAAGA,EAAIqgB,EAAO3f,SAAUV,EAC/BA,EAAI,IACNwgB,EAAOA,EAAKxX,MAAM,EAAGwX,EAAK9f,OAAS,GAAK,KAG1C8f,GADAA,GAAQH,EAAOrgB,IACHgJ,MAAM,EAAGsX,EAAUtgB,IAC/BwgB,GAAQ,IAAIC,OAAOH,EAAUtgB,GAAKwgB,EAAK9f,QAEzC6f,EAAQC,GAQV,YACI5N,EAAc0N,EAEdC,GACF,IAAI7J,EACJ,IACEA,EAAc1U,KAAKC,UAAU2Q,EAAM8D,aACnC,MAAOgK,GACPhK,EAAc,WAOhBiK,IAJa/N,EAAMhS,UACDgS,EAAMpR,mBAEOkV,EAAa9D,EAAMgO,cAAcxiB,YAC/CkiB,EAAWC,GAM9B,YACI3N,EAAc0N,EAAqBO,EAEnCN,GACF,IAAI7J,EACJ,IACEA,EAAc1U,KAAKC,UAAU2Q,EAAM8D,aACnC,MAAOgK,GACPhK,EAAc,WAIhB,IADA,IAAMoK,SACa1e,EAAAwQ,EAAME,aAANtS,WAAAA,KAAd,IAAM0W,OACT,KAAqB,MAAjB2J,GAAyBA,EAAcngB,OAAS,IACf,IAAjCmgB,EAAc5f,QAAQiW,IAG1B,IAAK,IAAIlX,EAAI,EAAGA,EAAIkX,EAAK/E,cAAczR,SAAUV,EAAG,CAClD,IAAM+gB,EAAe7J,EAAK/E,cAAcnS,GAAGY,KACrCogB,EAAoB9J,EAAK9E,YAAYpS,GACrCihB,EAAqB/J,EAAK7E,cAAcrS,GAC9C8gB,EAAYtd,KACLud,MAAgBC,OAAsBC,QAGjD,IAAMrgB,EAAOgS,EAAMhS,KACbW,EAAYqR,EAAMpR,eAClB0f,EAAyC,IAAvBJ,EAAYpgB,OAAe,GAAKogB,EAAY,GAMpEH,IAJK/f,OAASW,MAAcmV,EAAa9D,EAAMgO,cAAcxiB,WAC3D8iB,GAGeZ,EAAWC,GAC5B,IAASvgB,EAAI,EAAGA,EAAI8gB,EAAYpgB,SAAUV,EACxC2gB,IAAU,GAAI,GAAI,GAAIG,EAAY9gB,IAAKsgB,EAAWC,eC1LlD9e,EACAG,GAEF,oBAFEA,MAEK+E,EACHlF,EAAQiD,gBAAcgB,iBAAiBkB,SAASC,aAChDjF,EAAe,SCGrB,YACIc,EAAaoF,EAAerJ,GAC9B,OAAgB,iBAARiE,GAAkC,iBAARA,GAClB,gBAARA,IACM,IAAVoF,GAAgC,iBAAVrJ,ECQ5B,YACImU,EAAc1C,EAA0BiR,EACxCC,GACF,IAAKD,EAAqBE,WAAW,MACnC,MAAM,IAAI7hB,EACN,sDACA2hB,GAEN,OAAOjR,EAYT,YAAoBxR,EAAeqK,EAActK,GAC/C,IAAM6iB,WpBsMsB5iB,GAC5B,OAAQA,GACN,IAAK,UACH,MAAO,UACT,QACE,MAAM,IAAIc,EAAW,kBAAkBd,IoB3M1B6iB,CAA4B7iB,GAC7C,OAAO8iB,SAAOC,KACV1Y,GAAQpF,OAAyB,IAAjBoF,EAAMrI,OAAejC,EAAQ+M,OAAKkW,QAAQjjB,IAC1D6iB,GAsJN,mBAkCE,WAAY7f,GAAZ,MAEE1C,sBAEA,GAtBFG,iBAAiB,IAAIyiB,IAqBnBziB,EAAK0B,KAAOa,EAAOb,KACF,MAAb1B,EAAK0B,KAAc,CACrB,IAAMzC,EAASe,EAAKsC,eAAeT,cACnC7B,EAAK0B,KAAO+S,EAAOxV,GAsBrB,GAnBAe,EAAKkU,iBAAkB,EACvBlU,EAAKsR,WAAY,EACjBtR,EAAK0U,WAAY,EAKb/T,MAAMC,QAAQ2B,EAAOqQ,QACvB5S,EAAK4S,OAASrQ,EAAOqQ,OAAO9I,QAE5B9J,EAAK4S,QAAUrQ,EAAOqQ,QAEpBjS,MAAMC,QAAQ2B,EAAOmgB,SACvB1iB,EAAK0iB,QAAUngB,EAAOmgB,QAAQ5Y,QAE9B9J,EAAK0iB,SAAWngB,EAAOmgB,SAIrBC,EAAqB3iB,EAAK4S,QAAQpR,SAAWxB,EAAK4S,OAAOpR,OAC3D,MAAM,IAAIlB,EACN,mGAEAN,EAAK4S,OAAOV,IAAI,SAAAzQ,GAAK,OAAAA,EAAEC,QAIzBihB,EAAqB3iB,EAAK0iB,SAASlhB,SAAWxB,EAAK0iB,QAAQlhB,QAC7DqO,QAAQC,KACJ,qGAEA9P,EAAK0iB,QAAQxQ,IAAI,SAAAzQ,GAAK,OAAAA,EAAEC,QAO9B1B,EAAK4iB,eACL5iB,EAAK6iB,0BACL7iB,EAAK8iB,4BAKL9iB,EAAK+iB,gBACL/iB,EAAKgjB,2BACLhjB,EAAKijB,6BAKLjjB,EAAKkjB,UAeL,IAAgB,QAAAhgB,EAAAlD,EAAK0iB,QAALphB,WAAAA,KAAX,IACGoS,GADGjS,QACOkR,YACVsC,EAAYxT,EAAEwT,UACdmE,EAAc3X,EAAE2X,YACtBpZ,EAAK+iB,aAAaze,KAAKoP,GACvB1T,EAAKgjB,wBAAwB1e,KAAK2Q,GAClCjV,EAAKijB,0BAA0B3e,KAAK8U,GAMtC,IAAgB,QAAAhW,EAAApD,EAAK4S,OAALzP,WAAAA,KACRuQ,GADGjS,QACOkR,YACVsC,EAAYxT,EAAEwT,UACdmE,EAAc3X,EAAE2X,YAKtB+J,EAAmC,IAAdlO,EAAiB,4BACtCkO,EAAqC,IAAhB/J,EAAmB,8BACxCpZ,EAAK4iB,YAAYte,KAAKoP,GACtB1T,EAAK6iB,uBAAuBve,KAAK2Q,GACjCjV,EAAK8iB,yBAAyBxe,KAAK8U,GAIrCpZ,EAAKojB,cACLpjB,EAAKqjB,eACLrjB,EAAKsjB,mBACLtjB,EAAKujB,kBACLvjB,EAAKwjB,mBACL,IAAK,IAAI1iB,EAAI,EAAGA,EAAId,EAAK4iB,YAAYphB,OAAQV,IAAK,CAGhD,MAFM4S,EAAQ1T,EAAK4iB,YAAY9hB,cAERyY,IACrB,MAAM,IAAIR,UACN,wEACoBxW,EAAOqQ,kBAClB9R,2CACU4S,EAAMpR,oBAE/BtC,EAAKojB,WAAW9e,KAAKoP,EAAMhS,MAC3B1B,EAAKsjB,gBAAgBhf,KAAKoP,EAAMkB,iBAEhC5U,EAAKujB,eAAejf,KAAKoP,EAAMhS,MAEjC,IAAoB,QAAAgC,EAAA1D,EAAK+iB,aAALzf,WAAAA,KAAToQ,OACT1T,EAAKqjB,YAAY/e,KAAKoP,EAAMhS,MAG9B1B,EAAKyjB,oBAAsBzjB,EAAK4S,OAAOV,IAAI,SAAAzQ,GAAK,OAAAA,EAAEoI,QAClD7J,EAAK0jB,qBAAuB1jB,EAAK0iB,QAAQxQ,IAAI,SAAAzQ,GAAK,OAAAA,EAAEoI,QAwFpD,IAjFA,IAAM8Z,KAEAC,KACAC,KAEAC,KACAC,KACAC,KAoBAC,EACF,SAACC,EAAwBC,EAAuBC,EAC/C1Q,EAAeuB,EAAoBmE,GACrB,MAAT1F,GAA8B,MAAbuB,GAAoC,MAAfmE,IACxC1F,EAAQwQ,EAAOvR,YACfsC,EAAYiP,EAAOjP,UACnBmE,EAAc8K,EAAO9K,aAEvB,IAAMpB,EAAOtE,EAAME,aAAaqB,GAGhC,IAAuC,IAAnCmP,EAAgBriB,QAAQiW,GAC1B,MAAM,IAAI3X,EACN,cAAc6jB,EAAOxiB,mBAAkBgS,EAAMhS,8BAKnD,IAAqC,IAAjCyiB,EAAcpiB,QAAQiW,GAA1B,CAKAhY,EAAKqkB,eAAelY,IAAImY,EAAUC,QAAQ7Q,EAAOuB,IAG3CvB,EAAMnC,MAAMwS,IAChBA,EAAarQ,EAAMnC,IAAMzR,OAAOyD,KAAKwgB,GAAcviB,SAGd,IAAnC4iB,EAAgBriB,QAAQiW,IAC1BoM,EAAgB9f,KAAK0T,GAKvB,IADA,IAAMwM,EAAmBxM,EAAK/E,cAAczR,OACnCV,EAAI,EAAGA,EAAI0jB,EAAkB1jB,IAAK,CACzC,IAAMW,EAAIuW,EAAK5E,aAAatS,GACtB2jB,EAAQzM,EAAK/E,cAAcnS,GAC3B4jB,EAAY1M,EAAK9E,YAAYpS,GAC7B6jB,EAAc3M,EAAK7E,cAAcrS,GACvCmjB,EACIxiB,EAAG0iB,EAAeC,EAAiBK,EAAOC,EAC1CC,GAGN,IADAR,EAAc7f,KAAK0T,GACZoM,EAAgBriB,QAAQiW,IAAS,GACtCoM,EAAgBra,OAAOqa,EAAgBriB,QAAQiW,GAAO,GAExDgM,EAAuB1f,KAAK0T,KAG5BmM,KACAC,SACUvgB,EAAA7D,EAAK0iB,QAALjf,WAAAA,KAAX,IAAMhC,OACTwiB,EAAgBxiB,EAAG0iB,EAAeC,GAKpC,IAFA,QAEmBQ,EADfZ,EAAuBla,QAAQ+a,UAChBjhB,WAAAA,KACjBggB,GADS5L,SACSzG,IAAMyG,GAElBA,GAAKzG,MAAMoS,IACfA,EAAY3L,GAAKzG,IAAM,GAEzB,IAAIuT,EAAQnB,EAAY3L,GAAKzG,IAGvBwT,EACsC,MAAvClB,EAAa7L,GAAKhF,cAAczB,IAC5B,EACAsS,EAAa7L,GAAKhF,cAAczB,IAOzCuT,EAAQ5V,KAAKG,IAAIyV,EAAOC,GACxBlB,EAAa7L,GAAKhF,cAAczB,IAAMuT,EACtChB,EAAe9L,GAAKhF,cAAczB,IAAMyG,GAAKhF,cAC7C2Q,EAAY3L,GAAKzG,IAAMuT,EAGvB,IAAShkB,EAAI,EAAGA,EAAIkX,GAAK/E,cAAczR,OAAQV,IAAK,CAClD,IAAM+gB,EAAe7J,GAAK/E,cAAcnS,GAElCkkB,GADA/P,EAAY+C,GAAK9E,YAAYpS,GACf+gB,EAAajO,aAAaqB,IACxCgQ,EAC8B,MAA/BtB,EAAYqB,EAAYzT,IAAc,EACAoS,EAAYqB,EAAYzT,IACnEoS,EAAYqB,EAAYzT,IAAMrC,KAAKG,IAAIyV,EAAQ,EAAGG,GAClDrB,EAAaoB,EAAYzT,IAAMyT,GAKnC,IAAME,KACN,IAAK,IAAMC,KAAUxB,EAAa,EAC1BmB,EAAQnB,EAAYwB,MACXD,IACbA,EAAaJ,OAEfI,EAAaJ,GAAOxgB,KAAKsf,EAAauB,IAIxC,IAAMC,KACN,IAAK,IAAMC,KAAWxB,EAAc,EAC5BiB,EAAQjB,EAAawB,MACZD,IACbA,EAAcN,OAEhBM,EAAcN,GAAOxgB,KAAKwf,EAAeuB,IAI3C,IAAIC,EAAYxlB,OAAOyD,KAAK6hB,GACPlT,IAAI,SAAAzQ,GAAK,OAAA8jB,SAAS9jB,EAAG,MACrB+jB,KAAKC,GAG1BzlB,EAAKkjB,UACL,IAAoB,QAAAwC,IAAA1hB,WAAAA,KAAf,IACG2hB,EAAiBP,EADdN,QAITa,EAAeH,KAAK,SAACvhB,EAAGC,GACtB,IAAM0hB,EAAS7B,EAAa9f,EAAEsN,IACxBsU,EAAS9B,EAAa7f,EAAEqN,IAC9B,OAAIqU,EAASC,GACH,EAEND,EAASC,EACJ,EAEF,IAET,IAAoB,QAAAC,IAAA/hB,WAAAA,KAAT2P,OACT1T,EAAKkjB,OAAO5e,KAAKoP,IAGrB1T,EAAKolB,cAAgBA,EAGrBE,EAAYxlB,OAAOyD,KAAK2hB,GACPhT,IAAI,SAAAzQ,GAAK,OAAA8jB,SAAS9jB,EAAG,MACrB+jB,KAAKC,GAStB,IAJA,IAAMM,EAAoB/lB,EAAK4S,OAAO9I,QAGhCkc,SACcC,IAAAC,WAAAA,IAClB,IADG,SACgBC,GAAAjB,EADVJ,QACUsB,aAAAA,MAAd,IAAMpO,GAET,GAAa,OADPtE,GADGsE,WACUhF,eACA,CACjB,IAAgB,SAAAqT,GAAArO,GAAK5E,aAALkT,aAAAA,MAAL7kB,SACT,IAAsC,IAAlCskB,EAAkBhkB,QAAQN,GAC5B,MAAM,IAAIpB,EACN,sDAAsDoB,EACtD,cAAciS,EAAMhS,sEAEVskB,GAGlB,IAAgB,SAAAO,GAAAvO,GAAK3E,cAALmT,aAAAA,MAAL/kB,SACTskB,EAAkBzhB,KAAK7C,GAEzBukB,EAAwB1hB,KAAKoP,EAAMhS,OAMzC1B,EAAKklB,aAAeA,EAKpB,IADA,IAAMuB,GAAWzmB,EAAKkjB,OAAOhR,IAAI,SAAAzQ,GAAK,OAAAA,EAAEC,mBAC7BglB,GACT,IAAMC,EAAiBF,GAASG,OAAO,SAAAnlB,GAAK,OAAAA,IAAMilB,IAAMllB,OACxD,GAAuB,IAAnBmlB,EACF,MAAM,IAAItmB,EACN,aAAaqmB,eAAiBC,yEAE9B7jB,KAAKC,UAAU0jB,WANJI,MAAAC,aAAAA,wBAcnB9mB,EAAK2T,iBAEL3T,EAAK4T,gBAKL,IAAIC,IACFb,cAAehT,EACfiT,iBACAC,eACAC,iBACAC,aAAcpT,EAAK4S,OACnBS,cAAerT,EAAK0iB,QACpBpP,WAAYtT,EAAK4S,OAAOV,IAAI,SAAAzQ,GAAK,OAAA,OACjC8R,YAAavT,EAAK0iB,QAAQxQ,IAAI,SAAAzQ,GAAK,OAAA,OACnC+R,YAAaxT,EAAK4S,OAAOV,IAAI,SAAAzQ,GAAK,OAAAA,EAAEoI,QACpC4J,aAAczT,EAAK0iB,QAAQxQ,IAAI,SAAAzQ,GAAK,OAAAA,EAAEoI,UAExC7J,EAAKuV,OAAQ,IA6tBjB,OA3nCwCpV,OAiatCL,sBAAIwkB,oCAAJ,WAIE,GAAI/d,KAAK4N,kBAAkB3S,OAAS,EAClC,MAAM,IAAIlB,EACN,wNAMN,IAAKiG,KAAK+K,UACR,SAGF,IADA,IAAIN,SACgB9N,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAAf,IAAMoS,OACT1C,EAAUA,EAAQjQ,OAAO2S,EAAM8B,kBAEjC,OAAOxE,mCAGTlR,sBAAIwkB,uCAAJ,WAEE,IADA,IAAMtT,SACc9N,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAAf,IAAMoS,OACT1C,EAAQ1M,WAAR0M,EAAgB0C,EAAM+B,qBAExB,IAAKlP,KAAK+K,UAAW,CAEnB,IADA,IAAMkE,SACcpS,EAAAmD,KAAK2c,OAAL/f,WAAAA,KAATuQ,OACT8B,EAAiBlR,WAAjBkR,EAAyB9B,EAAM8B,kBAEjC,OAAOA,EAAiBzU,OAAOiQ,GAEjC,OAAOA,mCAGTlR,sBAAIwkB,2BAAJ,WACE,OAAO/d,KAAKiP,iBAAiBzU,OAAOwF,KAAKkP,sDAoB3C6O,wBAAA,SACIyC,EAAsCC,EACtCC,gBADsCD,mBACtCC,MAMEA,WAnhBJjW,EAAyBkS,GAI3B,IAFA,IAAMgE,KACFC,EAAoB,MACJC,IAAA9lB,WAAAA,IAClB,IADG,QACkB6B,OAAM6N,QAAN9N,WAAAA,KAAhB,IAAMiO,OACT,GAAyC,MAArC+V,EAAa/V,EAAOM,cACtB,MAAM,IAAInR,EAAW,0BAA0B6Q,EAAOM,cAExDyV,EAAa/V,EAAOM,cAAgBN,EACpCgW,IAIJ,IAAM7O,KACN,IAAK,IAAM+O,KAAQrW,EACjBsH,EAAkBhU,MAAM4iB,EAAaG,GAAOrW,EAAQqW,YAC7CH,EAAaG,GAItB,IAAMC,KACN,IAAK,IAAMC,KAAQL,EACjBI,EAAWhjB,KAAKijB,GAElB,GAAID,EAAW9lB,OAAS,EACtB,MAAM,IAAIlB,EACHgnB,EAAW9lB,cAAa2lB,2BACxBG,GAGT5O,GAAcJ,GAqfVkP,CAA8BT,EAA+BxgB,KAAK2c,iBAxmBpE6D,EAAuB7D,EAAiB8D,gBAAAA,MAO1C,IANA,IAAM/E,EAAuB8E,EAA2B,cAElDU,GADkBV,EAAqB,QAC1B7D,EAAOhR,IAAI,SAAAwB,GAAS,OAAAA,EAAMhS,QAGvCkH,SACc8e,IAAApmB,WAAAA,IACA,OADToS,QACChS,OACiB,MAArBkH,EAAM8K,EAAMhS,QACdkH,EAAM8K,EAAMhS,UAEdkH,EAAM8K,EAAMhS,MAAM4C,KAAKoP,IAO3B,IAFA,IAAMiU,EAAgBZ,EAAqB,QACrCzO,KACGsP,EAAI,EAAGA,EAAIH,EAAWjmB,SAAUomB,EAAG,CAC1C,IAAMC,EAAOJ,EAAWG,GACpBE,EAAeH,EAAcE,GACb,MAAhBC,IACFA,MAIF,IADA,IAAIC,KACK/c,EAAI,EAAGA,EAAI8c,EAAatmB,SAAUwJ,EAAG,CAE5C,IAAMgd,EACFF,EAAa9c,GAEjB+c,EAAazjB,KAAK,IAAIuN,GAAcoW,GAChCD,EAAmB,MAAGA,EAAmB,MACzCA,EAAmB,SAEzB,IAAoB,QAAA7kB,EAAAyF,EAAMif,GAAN3kB,WAAAA,KAAf,IAAMwQ,EACHwU,GADGxU,QACqB1C,QAG9B,IAFA+W,EAAeI,GACXzU,EAAOqU,EAAc9F,IACRzgB,SAAW0mB,EAAgB1mB,OAAQ,CAClD,IAAIwlB,EAMF,MAAM,IAAI1mB,EACN,UAAUsnB,cAAalU,EAAMhS,mBAC1BwmB,EAAgB1mB,iDACXumB,EAAavmB,uBARzBqO,QAAQC,KACJ,wCAAwC4D,EAAMhS,gDACJqmB,EAAavmB,cACjD0mB,EAAgB1mB,aAU9B,IAAK,IAAIV,EAAI,EAAGA,EAAIinB,EAAavmB,SAAUV,GACrCkmB,GACG1a,OAAKC,YACF2b,EAAgBpnB,GAAG+I,MAAOke,EAAajnB,GAAG+I,OAQpDyO,EAAkBhU,MAAM4jB,EAAgBpnB,GAAIinB,EAAajnB,GAAGqR,SAPxDtC,QAAQC,KACJ,yCAAyC4D,EAAMhS,mCACtBwmB,EAAgBpnB,GAAG+I,aACzCke,EAAajnB,GAAG+I,YAQjC6O,GAAcJ,GAoiBV8P,CAAoBrB,EAAyBxgB,KAAK2c,OAAQ8D,IAQtD1C,0BAAR,WACE,IAAM+D,EAAY9hB,KAAK/D,YASvB,OAPEH,UAAWkE,KAAKjE,eAChBC,OAAQ8lB,EACRC,aAAc,oBAGdC,QAAS,kBAiBbjE,mBAAA,SAAOkE,EAAcC,gBAAAA,MACnB,IAAMC,aDtoBNC,EAAyCnlB,GAC3C,GAAiB,OAAbmlB,QAAkClpB,IAAbkpB,EACvB,OAAO,KACF,GAAwB,iBAAbA,EAChB,OAAOnU,EAA0BmU,GAC5B,GACkB,iBAAbA,GAA+C,kBAAbA,EAC5C,OAAOA,EACF,GAAIA,aAAoBhoB,MAAO,CAGpC,IAFA,IAAMioB,KACAC,EAAcF,EAASnnB,OACpBV,EAAI,EAAGA,EAAI+nB,IAAe/nB,EAAG,CACpC,IAAMgoB,EAAOH,EAAS7nB,GAClBioB,GAA6BvlB,EAAK1C,EAAGgoB,GACvCF,EAAQtkB,KAAKwkB,GAEbF,EAAQtkB,KAAK0kB,EAAoBF,EAAMtlB,IAG3C,OAAOolB,EAGP,IADA,IAAMK,SACc/lB,EAAApD,OAAOyD,KAAKolB,GAAZrnB,WAAAA,KAAf,IAAM4nB,OACHC,EAAUR,EAASO,GACnBE,EAAQ5U,EAA0B0U,GAQtCD,EAAOG,GAPM,SAAVF,GAA8B,cAAVA,GACF,iBAAZC,EAMOH,EAAoBG,EAASD,GAF7BC,EAKpB,OAAOF,ECmmBaD,CAAoBziB,KAAK8iB,iBAC7C,OAAOZ,EAAe3lB,KAAKC,UAAU2lB,GAAeA,GAgBtDpE,iBAAA,SAAK1R,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,IAAImkB,EAQJ,OATA1W,EAAS+C,EAAqB/C,GAI5B0W,EADE,SAAUnT,EACJR,EAAqBQ,EAAa,MAElCoT,EAA2B,KAAM3W,EAAOpR,QAG3CxB,EAAKwpB,iBAAiB5W,EAAQ0W,GAAO,MAahDhF,wBAAA,SAAY1R,EAAyBkG,GAArC,WAEE,OAAO3T,OAAK,WAEV,IAAImkB,EAOJ,OARA1W,EAAS+C,EAAqB/C,GAG5B0W,EADU,MAARxQ,EACMyQ,EAA2B,KAAM3W,EAAOpR,QAExCmU,EAAqBmD,GAGxB9Y,EAAKwpB,iBAAiB5W,EAAQ0W,GAAO,MAahDhF,+BAAA,SAAmB3P,GACjB,IAAMnB,EAAc0F,GAA+BvE,GACnD,GAAInB,EAAYhS,SAAW+E,KAAKqc,YAAYphB,OAC1C,MAAM,IAAIlB,EACN,+BAA+BqU,iBAClBpO,KAAKqc,YAAYphB,0BAKpC,IADA,IAAMioB,KACG3oB,EAAI,EAAGA,EAAI0S,EAAYhS,OAAQV,IAAK,CAC3C,IAAM4S,EAAQnN,KAAKqc,YAAY9hB,GACzB4oB,EAAalW,EAAY1S,GAI/B2oB,EADME,EAAWjW,EAAMhS,KAAO,QACGgoB,EAGnC,IAAMpE,EAAYxlB,OAAOyD,KAAKgD,KAAK2e,cACZhT,IAAI,SAAAzQ,GAAK,OAAA8jB,SAAS9jB,EAAG,MACrB+jB,KAAKC,GAE5B,GAAIH,EAAU9jB,OAAS,EACrB,IAAoB,QAAAooB,IAAAtoB,WAAAA,IAElB,IAFG,IAAMwjB,WAEU+E,EADLtjB,KAAK2e,aAAaJ,GACb5hB,WAAAA,KAAd,IAAM8U,OAEHtE,EAAQsE,EAAKhF,cACnB,IAA2D,IAAvDzM,KAAKqc,YAAY1Q,IAAI,SAAAzQ,GAAK,OAAAA,EAAE8P,KAAIxP,QAAQ2R,EAAMnC,IAAlD,CAMA,IADA,IAAMuY,KACGC,EAAI,EAAGA,EAAI/R,EAAK/E,cAAczR,OAAQuoB,IAAK,CAClD,IAAMlI,EAAe7J,EAAK/E,cAAc8W,GAClCC,EAAYhS,EAAK9E,YAAY6W,GAC7B3Q,EAAcpB,EAAK7E,cAAc4W,GAEjCE,EAAaR,EADbE,EAAc9H,EAAangB,SAAQsoB,MAAa5Q,GAEtD0Q,EAAYxlB,KAAK2lB,GAGnB,IAGMC,EAAehR,GAHDxF,EAAM+D,mBACtBtC,EAA+B2U,KAG7B7U,EAAYvB,EAAME,aAAa7R,QAAQiW,GAC7C,IAAS+R,EAAI,EAAGA,EAAIG,EAAa1oB,OAAQuoB,IAAK,CAE5CN,EADME,EAAcjW,EAAMhS,SAAQuT,MAAa8U,GACdG,EAAaH,KAOtD,IAAMtW,KACA0W,KACN,IAASrpB,EAAI,EAAGA,EAAIyF,KAAKwc,aAAavhB,OAAQV,IAAK,CAC3C4S,EAAQnN,KAAKwc,aAAajiB,GAC1BmU,EAAY1O,KAAKyc,wBAAwBliB,GACzCsY,EAAc7S,KAAK0c,0BAA0BniB,GAFnD,IAGM6oB,EAAcjW,EAAMhS,SAAQuT,MAAamE,EAC/C+Q,EAAgB7lB,KAAKqlB,GAGvB,IAAS7oB,EAAI,EAAGA,EAAIqpB,EAAgB3oB,OAAQV,IAAK,CAC/C,IAAM0C,EAAM2mB,EAAgBrpB,GAC5BqiB,EAAqB3f,KAAOimB,GAC5BhW,EAAanP,KAAKmlB,EAAqBjmB,IAIzC,OAAO2R,EAA+B1B,IAa9B6Q,6BAAV,SAA2B1R,EAAkB0W,GAE9B,MAATA,IACFA,EAAQC,EAA2B,KAAM3W,EAAOpR,SASlD,IADA,IAAM4oB,KACGtpB,EAAI,EAAGA,EAAIyF,KAAKqM,OAAOpR,SAAUV,EAAG,CAC3C,IAAMW,EAAI8E,KAAKqM,OAAO9R,GAChBwK,EAAIsH,EAAO9R,GACXgY,EAAOwQ,EAAMxoB,GACnBspB,EAAU3oB,EAAE8P,KAAOjG,EAAGwN,GAMxB,IAHA,QAGoBuR,EAHFvqB,OAAOyD,KAAKgD,KAAK2e,cACZhT,IAAI,SAAAzQ,GAAK,OAAA8jB,SAAS9jB,EAAG,MACrB+jB,KAAKC,GACRnkB,WAAAA,IAElB,IAFG,IAAMwjB,WAEUwF,EADL/jB,KAAK2e,aAAaJ,GACb5hB,WAAAA,KAUjB,IAVG,IAAM8U,OAEHtE,EAAQsE,EAAKhF,cACbuX,EAAwBvS,EAAK5E,aAC7BoX,EAAyBxS,EAAK3E,cAK9BoX,EAAe,IAAI9pB,UACT+pB,IAAAvnB,WAAAA,MAAL1B,QACH8P,MAAM6Y,GACVK,EAAanmB,KAAK8lB,EAAU3oB,EAAE8P,KAGlC,GAAIkZ,EAAajpB,SAAW+oB,EAAsB/oB,OAAQ,CAExD,IAAI2U,KACAwU,SACAC,SACAC,SACAC,SAKJ,GAHqB,MAAjB9S,EAAKnF,WACPsD,EAAS6B,EAAKnF,UAEY,IAAxB4X,EAAajpB,OAAc,CACvB,IAAA4B,OAAC2nB,OAAgBC,OACJ,MAAf7U,EAAO2C,OACT3C,EAAa,KAAI6U,GAEnBH,EACIlV,EAAqBjC,EAAM0D,KAAK2T,EAAgB5U,IACpD2U,EAAcnV,EACVjC,EAAMuX,YAAYF,EAAgBC,IACtCL,GAAmBI,GACnBH,GAAiBI,QAEjBL,EAAkBF,EAAavY,IAAI,SAAAzQ,GAAK,OAAAA,EAAE,KAC1CmpB,EAAgBH,EAAavY,IAAI,SAAAzQ,GAAK,OAAAA,EAAE,KACrB,MAAf0U,EAAO2C,OACT3C,EAAa,KAAIyU,GAEnBC,EACIlV,EAAqBjC,EAAM0D,KAAKuT,EAAiBxU,IACrD2U,EAAcnV,EACVjC,EAAMuX,YAAYN,EAAiBC,IAGzC,GAAIlX,EAAMM,oBACR,MAAM,IAAIzT,EACN,mHAMN,IAASO,EAAI,EAAGA,EAAI0pB,EAAuBhpB,SAAUV,EAAG,CAChDW,EAAI+oB,EAAuB1pB,GAC3BwK,EAAIuf,EAAc/pB,GAClBgY,EAAOgS,EAAYhqB,GACzBspB,EAAU3oB,EAAE8P,KAAOjG,EAAGwN,KAS9B,IAHA,IAAMzF,KACAE,KACAE,SACU/P,EAAA6C,KAAKmc,QAALpf,WAAAA,KACd6f,GADS1hB,QAEH8P,MAAM6Y,EAAW,4BAA4B3oB,EAAEC,WAAUD,EAAE8P,IAC3D,IAAA9N,UAACygB,OAAQpL,OACfrF,EAAanP,KAAK4f,EAAOra,OACzBwJ,EAAc/O,KAAK4f,GACnB3Q,EAAYjP,KAAKwU,GAInB,OAAQzF,EAAeE,EAAaE,IAW9B6Q,mCAAR,SAA+BpB,GAG7B,IAFA,IACIgI,EADEC,SAEcjoB,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAAf,IAAMoS,OACTwX,EAAYxX,aAAiB4Q,EAAY,EAAI,EAC7C,IAAK,IAAI8G,EAAoB,EACxBA,EAAoB1X,EAAME,aAAapS,OAAQ4pB,IAAqB,CACvE,IAAM7G,EAAUD,EAAUC,QAAQ7Q,EAAO0X,GACrC7G,KAAWhe,KAAK8d,iBAElB8G,EAAkB5G,GAAW2G,EAC7BA,GAAa,IAInB,OAAOC,GAuBT7G,qBAAA,SAAS5iB,EAAekH,GACtB,GAAa,MAATA,EAAe,CACjB,GAAIrC,KAAK2c,OAAO1hB,QAAUoH,EACxB,MAAM,IAAItI,EACN,wCAAwCsI,0BACjCrC,KAAK2c,OAAO1hB,qBAEvB,OAAO+E,KAAK2c,OAAOta,GAGrB,GAAY,MAARlH,EACF,MAAM,IAAIpB,EAAW,8CAIzB,IAAoB,QAAA4C,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAAf,IAAMoS,OACT,GAAIA,EAAMhS,OAASA,EACjB,OAAOgS,EAGX,MAAM,IAAIpT,EAAW,kBAAkBoB,IAQzC4iB,4BAAA,WAAA,WAKE,OAAOnf,OAAK,WAEV,IADA,IAAMkQ,SACcnS,EAAAlD,EAAKkjB,OAAL5hB,WAAAA,IAClB,IADG,IAAMoS,OACAuB,EAAY,EAAGA,EAAYvB,EAAME,aAAapS,SAChDyT,EAAW,CAChB,IAAMsP,EAAUD,EAAUC,QAAQ7Q,EAAOuB,GACrCjV,EAAKqkB,eAAe3b,IAAI6b,IAC1BlP,EAAO/Q,WAAP+Q,EAAe3B,EAAM2X,mBAK3B,OAAOhW,KAIXiP,sBAAA,WAWE,IAVA,IAAM/hB,GAAoCb,KAAM6E,KAAK7E,MAK/CypB,EACF5kB,KAAK+kB,uBAAuB/kB,KAAK2c,QAG/BqI,SACcroB,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAIlB,IAJG,IACGkqB,GADG9X,QACoBpR,eACvBmpB,EAAc/X,EAAMlR,YACpBkpB,KACGN,EAAoB,EACxBA,EAAoB1X,EAAME,aAAapS,OAAQ4pB,IAAqB,CACvE,IAAMpT,EAAOtE,EAAME,aAAawX,GAC1B7G,EAAUD,EAAUC,QAAQ7Q,EAAO0X,GACrCjV,KACJ,GAAI5P,KAAK8d,eAAe3b,IAAI6b,GAAU,CAGpC,GAAIvM,EAAKnF,SACP,IACE/P,KAAKC,UAAUiV,EAAKnF,UACpBsD,EAAS6B,EAAKnF,SACd,MAAO2O,GACP3R,QAAQC,KACJ,SAAS4D,EAAMhS,wDAEZsW,EAAKnF,oHAGZsD,KAGJ,GAAI6B,EAAK/E,cAAczR,OAAS,EAAG,CAEjC,IADA,IAAMmqB,KACG7qB,EAAI,EAAGA,EAAIkX,EAAK/E,cAAczR,OAAQV,IAAK,CAClD,IAAM+gB,EAAe7J,EAAK/E,cAAcnS,GAClCmU,EAAY+C,EAAK9E,YAAYpS,GAC7BsY,EAAcpB,EAAK7E,cAAcrS,GAGlB,QADjB8qB,EAAeT,EADH7G,EAAUC,QAAQ1C,EAAc5M,WAEFxV,IAAjBmsB,IAC3BA,EAAe,GAEjBD,EAASrnB,MACJud,EAAangB,KAAMkqB,EAAcxS,EAAajD,IAErDuV,EAAqBpnB,KAAKqnB,KAIhCJ,EAAajnB,MACX5C,KAAMgS,EAAMhS,KACZW,UAAWmpB,EACXjpB,OAAQkpB,EACR7X,aAAc8X,IAGlBnpB,EAAe,OAAIgpB,EAEnB,IAAMM,KACN,IAAS/qB,EAAI,EAAGA,EAAIyF,KAAKqc,YAAYphB,OAAQV,IAAK,CAChD,IAAM4S,EAAQnN,KAAKqc,YAAY9hB,GACzBmU,EAAY1O,KAAKsc,uBAAuB/hB,GAExCyjB,EAAUD,EAAUC,QAAQ7Q,EAAOuB,GACzC,GAAK1O,KAAK8d,eAAe3b,IAAI6b,GAA7B,CAIqB,QADjBqH,EAAeT,EAAkB5G,UACS9kB,IAAjBmsB,IAC3BA,EAAe,GAEXxS,EAAc7S,KAAKuc,yBAAyBhiB,GAClD+qB,EAAYvnB,MAAMoP,EAAMhS,KAAMkqB,EAAcxS,KAE9C7W,EAAoB,YAAIspB,EAExB,IAAMC,KACN,IAAShrB,EAAI,EAAGA,EAAIyF,KAAKwc,aAAavhB,OAAQV,IAAK,CAC3C4S,EAAQnN,KAAKwc,aAAajiB,GAC1BmU,EAAY1O,KAAKyc,wBAAwBliB,GAEzCyjB,EAAUD,EAAUC,QAAQ7Q,EAAOuB,GACzC,GAAK1O,KAAK8d,eAAe3b,IAAI6b,GAA7B,CAGA,IAAIqH,EACiB,QADjBA,EAAeT,EAAkB5G,UACS9kB,IAAjBmsB,IAC3BA,EAAe,GAEXxS,EAAc7S,KAAK0c,0BAA0BniB,GACnDgrB,EAAaxnB,MAAMoP,EAAMhS,KAAMkqB,EAAcxS,KAG/C,OADA7W,EAAqB,aAAIupB,EAClBvpB,GAUF+hB,aAAP,SACIthB,EACAT,GAGF,IAAMwpB,KAOAC,KAEN,WACItY,EAAciY,GACVjY,EAAMhS,QAAQsqB,EAGlBA,EAAiBtY,EAAMhS,MAAM4C,KAAKqnB,GAFlCK,EAAiBtY,EAAMhS,OAASiqB,GAMpC,WAAqBjY,EAAciY,GAGjC,IAFA,IACIxV,EADE/C,SAEkB6Y,IAAA3qB,WAAAA,KAAnB,IAAM4qB,OACHC,EAAmBD,EAAU,GAC7BE,EAAmBF,EAAU,GAC7BnK,EAAqBmK,EAAU,GACrC,GAAyB,IAArBA,EAAU1qB,OACZ2U,SACK,CAAA,GAAyB,IAArB+V,EAAU1qB,OAGnB,MAAM,IAAIlB,EAAW,+CACjBwC,KAAKC,UAAU2Q,QAAW5Q,KAAKC,UAAUmpB,IAH7C/V,EAAS+V,EAAU,GAKrB,KAAMC,KAAoBJ,GAExB,YADAM,EAAmB3Y,EAAOiY,GAG5B,IAAM9J,EAAekK,EAAcI,GACnC,GAAItK,EAAajO,aAAapS,QAAU4qB,EAEtC,YADAC,EAAmB3Y,EAAOiY,GAG5B,IAAM3G,EAAcnD,EAAajO,aAAawY,GAC9ChZ,EAAa9O,KAAK0gB,EAAY3R,cAAc0O,IAK1C3O,EAAa5R,OAAS,GACxBkS,EAAMzB,MACFkD,EAA+B/B,GAC/B+C,GAUR,WAAsBmW,GACpB,IAAMC,EAAYD,EAAU5qB,KAEtBgS,EAAQ8Y,GACIF,EACwB,MAAxB/pB,EAAOG,cACHH,EAAOG,kBAE7BqpB,EAAcQ,GAAa7Y,EAI3B,IAFA,QAEuB+Y,EADnBH,EAAU1Y,aACStS,WAAAA,KAAlB,IAAMqqB,OACT,KAAMA,aAAoBhrB,OACxB,MAAM,IAAIL,EACN,yDACIqrB,GAMVU,EAAmB3Y,EAAOiY,IAO9B,IAFA,IAAMjqB,EAAOa,EAAOb,KACdgrB,EAAmBnqB,EAAO2gB,WACRyJ,IAAArrB,WAAAA,KACtBsrB,EADSN,QAQX,MAAQO,EAA4Bb,IAClC,IAAwB,QAAAc,IAAA5pB,WAAAA,KAAnB,IAAMopB,OAET,IADM5Y,EAAQqY,EAAcO,EAAU5qB,OAC5BA,QAAQsqB,EAAkB,CAClC,IAAuB,QAAA5oB,EAAA4oB,EAAiBtY,EAAMhS,MAAvByB,WAAAA,KACrB4pB,EAAYrZ,eAEPsY,EAAiBtY,EAAMhS,OAQpC,IAJA,IAAM0R,KACAC,SAGkB2Z,EADpBzqB,EAAOqgB,YACatf,WAAAA,KAAnB,IACGipB,GADGD,QACmB,GACtBrX,EAAYqX,EAAU,GACtBlT,EAAckT,EAAU,GAC9BnJ,EAAqBoJ,KAAaR,GAClC,IACMkB,GADAvZ,EAAQqY,EAAcQ,IACK3Y,aAAaqB,GAAW5B,cACzDD,EAAa9O,KAAK2oB,EAAmB7T,IAIvC,IAFA,QAEwB8T,EADpB3qB,EAAOwgB,aACarf,WAAAA,KAChB6oB,GADGD,QACmB,GACtBrX,EAAYqX,EAAU,GACtBlT,EAAckT,EAAU,GAC9BnJ,EAAqBoJ,KAAaR,GAClC,IAAMrY,EACAuZ,GADAvZ,EAAQqY,EAAcQ,IACK3Y,aAAaqB,GAAW5B,cACzDA,EAAc/O,KAAK2oB,EAAmB7T,IAExC,OAAO,IAAIpW,GAAK4P,OAAQQ,EAAcsP,QAASrP,EAAe3R,UAShE5B,sBAAIwkB,4BAAJ,WAGE,GAAI/d,KAAKmP,UACP,MAAM,IAAIpV,EACN,wLAIN,IAAoB,QAAA4C,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAClB,QAAU6rB,SACR,OAAO,EAGX,OAAO,sCAznC6BnY,ICnJxC,ICwYYoY,iBDhYV,WAAYC,GACV,GARM9mB,iBAQF8mB,aAAiBC,EACnB,IAAK,IAAM/b,KAAM8b,EAAME,SACrBhnB,KAAKgnB,SAAShc,GAAM8b,EAAME,SAAShc,OAEhC,CACL,GAAa,MAAT8b,EACF,OAEF,IAAmB,QAAAG,IAAAlsB,WAAAA,KAAd,IAAMmsB,OACTlnB,KAAK4F,IAAIshB,EAAKjqB,IAAKiqB,EAAKluB,SAoDhC,OAvCE+tB,gBAAA,SAAI9pB,EAAqBjE,GACvB,GAA6B,MAAzBgH,KAAKgnB,SAAS/pB,EAAI+N,IAGpB,MAAM,IAAIjR,EAAW,uBAAuBkD,EAAI9B,aAAY8B,EAAI+N,IAElE,OAJEhL,KAAKgnB,SAAS/pB,EAAI+N,IA9ExB,SAAiC/N,EAAqBvC,GAEpD,GAAiB,MAAbuC,EAAIqG,MAAe,CACrB,GAAIrG,EAAIqG,MAAMrI,SAAWP,EAAI4I,MAAMrI,OACjC,MAAM,IAAIlB,EACN,qBAAqBW,EAAI4I,MAAMrI,gDACnBgC,EAAIqG,MAAMrI,aAG5B,IAAK,IAAIV,EAAI,EAAGA,EAAI0C,EAAIqG,MAAMrI,SAAUV,EACtC,GAAoB,MAAhB0C,EAAIqG,MAAM/I,IAAc0C,EAAIqG,MAAM/I,KAAOG,EAAI4I,MAAM/I,GACrD,MAAM,IAAIR,EACN,OAAOQ,gCAA+BG,EAAI4I,MAAM/I,8CACV0C,EAAIqG,MAAM/I,SAK1D,GAAiB,MAAb0C,EAAIhE,OAAiBgE,EAAIhE,QAAUyB,EAAIzB,MAEzC,OAAOyB,EAET,IAEE,OAAOysB,OAAKzsB,EAAKuC,EAAIhE,OACrB,MAAOgiB,GAEP,MAAM,IAAIlhB,EACN,0BAA0BW,EAAIzB,oDACfgE,EAAI9B,WAAU8B,EAAIhE,aAiDXmuB,CAAwBnqB,EAAKjE,GAIhDgH,MAQT+mB,oBAAA,SAAQG,GACNlnB,KAAK4F,IAAIshB,EAAKjqB,IAAKiqB,EAAKluB,QAO1B+tB,mBAAA,SAAO9pB,GACL,OAAgC,MAAzB+C,KAAKgnB,SAAS/pB,EAAI+N,KAS3B+b,qBAAA,SAAS9pB,GACP,GAA6B,MAAzB+C,KAAKgnB,SAAS/pB,EAAI+N,IACpB,MAAM,IAAIjR,EAAW,oBAAoBwC,KAAKC,UAAUS,IAExD,OAAO+C,KAAKgnB,SAAS/pB,EAAI+N,sBAyB3Bqc,EAA0CC,EAC1C1X,GAQF,IAPA,IAAM2X,EAAentB,MAAMC,QAAQgtB,GAC7BG,EACFD,EAAeF,GAA+BA,GAE5ClL,KACAsL,EAAmB,IAAIV,GAASO,OAElBI,IAAA3sB,WAAAA,KAAf,IAAM4sB,OACTxL,EAAQpe,KAAK6pB,GAAgBD,EAAOF,EAAkB7X,IAExD,OAAO2X,EAAepL,EAAUA,EAAQ,GAG1C,YACI0L,EAAuBJ,EACvB7X,GACF,GAAI6X,EAAiBK,OAAOD,GAC1B,OAAOJ,EAAiBM,SAASF,GAEnC,GAAIA,EAAMzb,uBAAuB4G,GAC/B,MAAM,IAAIjZ,EACN,4DACIiZ,GAAW7X,UAKrB,IAFA,IACM6sB,SACcC,EAFLJ,EAAMxb,OAEDtR,WAAAA,KAAf,IAEGmtB,EAAWN,QAAuBH,EAAkB7X,GAC1DoY,EAAYjqB,KAAKmqB,GAGnB,IAAItX,EACAiX,EAAMzb,YAAYV,MAAMsc,EAAapY,GACpCxV,MAAMC,QAAQuW,KACjBA,GAAUA,IAKZ,IAHA,IAAMuX,EAeR,SAAwBN,GAEtB,IAAIM,EACJ,GAA8C,IAA1CN,EAAMzb,YAAYiB,aAAapS,OACjCktB,EAAeN,EAAMzb,YAAYwE,WAC5B,CAEL,IADA,IAAIlC,EAAoB,KACfnU,EAAI,EAAGA,EAAIstB,EAAMzb,YAAYiB,aAAapS,SAAUV,EAC3D,IAA2B,QAAAoC,EAAAkrB,EAAMzb,YAAYiB,aAAa9S,GAChDuS,cADiB/R,WAAAA,KAAtB,IAAMqtB,OAET,GAAIA,EAAapd,KAAO6c,EAAM7c,GAAI,CAChC0D,EAAYnU,EACZ,OAIN4tB,EAAeN,EAAMzb,YAAYic,YAAY3Z,GAE/C,OAAOyZ,EAjCcG,CAAeT,GAC9BU,EACFnuB,MAAMC,QAAQ8tB,GAAgBA,GAAgBA,GACzC5tB,EAAI,EAAGA,EAAIguB,EAAsBttB,SAAUV,EAClDktB,EAAiB7hB,IAAI2iB,EAAsBhuB,GAAIqW,EAAOrW,IAExD,OAAyB,IAAlBqW,EAAO3V,OAAe2V,EAAO,GAAKA,EAAOiX,EAAMtb,+BChK5BrR,GAE1B,OAAOd,MAAMC,QAAQa,eAMIA,GAEzB,gBAlB2BA,GAE3B,OAAOA,aAAa6gB,SAgBZyM,CAAattB,KAAOutB,GAAYvtB,eAetCoY,EAAqDoV,EACrDle,EAAkBme,EAAuBC,GAC3C,gBADoBD,mBAAuBC,MAC9B,MAATF,GAAkC,IAAjBA,EAAMztB,OAAc,CAGvC,GAAY,MAARqY,EAAc,CAChB,IAAIuV,GAAoB,EACxB,GAAIJ,GAAYnV,IAAUA,EAAkBrY,OAAS,EACnD4tB,GAAoB,OACf,GAAIC,GAAWxV,IACpB,IAAK,IAAMrW,KAAOqW,EAChB,GAAIA,EAAKrV,eAAehB,GAAM,CAC5B4rB,GAAoB,EACpB,YAKJA,GAAoB,EAEtB,GAAIA,EACF,MAAM,IAAI9uB,EACN,6BAA6B6uB,gCAClBtV,GAGnB,SAEF,GAAY,MAARA,EACF,OAAOoV,EAAM/c,IAAI,SAAAxQ,GAAQ,OAAA,OAG3B,IAAI4tB,EACJ,GAAID,GAAWxV,GAAO,CACpBA,EAAOA,EACPyV,KACA,IAAmB,QAAAC,IAAAjuB,WAAAA,KAAd,IAAMumB,OACT,GAAkB,MAAdhO,EAAKgO,GACP,MAAM,IAAIvnB,EACN,yBAAyBunB,mCACtBoH,GAETK,EAAOhrB,KAAKuV,EAAKgO,UAEd,GAAImH,GAAYnV,GAAO,CAE5B,IADAA,EAAOA,GACErY,SAAWytB,EAAMztB,OACxB,MAAM,IAAIlB,EACN,6BAA6B6uB,mHAEMF,EAAMztB,uEACOqY,GAEtDyV,EAASzV,MACJ,CAEL,GADAA,EAAOA,EACHoV,EAAMztB,OAAS,EACjB,MAAM,IAAIlB,EACN,aAAa6uB,cAA2BF,EAAMztB,6EAE1CqY,EAAKhQ,OAEfylB,GAAUzV,GAIZ,IAAK,IAAI/Y,EAAI,EAAGA,EAAImuB,EAAMztB,SAAUV,EAAG,CAEV,KADrBI,EAAQouB,EAAOxuB,IACX+I,MAAMrI,SACd8tB,EAAOxuB,GAAK0uB,GAAatuB,EAAO,IAKpC,GAAc,MAAV6P,EACF,IAASjQ,EAAI,EAAGA,EAAImuB,EAAMztB,SAAUV,EAClC,GAAiB,MAAbiQ,EAAOjQ,GAAX,CAGA,IAAMI,EACN,IADMA,EAAQouB,EAAOxuB,IACX+I,MAAMrI,SAAWuP,EAAOjQ,GAAGU,OACnC,MAAM,IAAIlB,EACN,uBAAuB6uB,gBAA6BF,EAAMnuB,eAC/CiQ,EAAOjQ,GAAGU,kDACZN,EAAM2I,OAErB,IAAK,IAAIkgB,EAAI,EAAGA,EAAIhZ,EAAOjQ,GAAGU,SAAUuoB,EACtC,GAAU,IAANA,GAAYmF,EAAhB,CAIA,IAAMhZ,EAAMhV,EAAM2I,MAAMkgB,GAClB0F,EAAS1e,EAAOjQ,GAAGipB,GACzB,GAAc,MAAV0F,GAAkBA,GAAU,GAAKvZ,IAAQuZ,EAC3C,MAAM,IAAInvB,EACN,uBAAuB6uB,gBAA6BF,EAAMnuB,sBACxCiQ,EAAOjQ,mCACrBI,EAAM2I,aAKtB,OAAOylB,cAgGLplB,EAAc2K,GAIhB,IAHA,IAAMsC,KACFuY,EAAa,EACb1T,EAAmB,KAChB0T,EAAaxlB,IAClB8R,EAAW0T,EAAa7a,IACR3K,IACd8R,EAAW9R,GAEbiN,EAAO7S,MAAMorB,EAAY1T,IACzB0T,EAAa1T,EAEf,OAAO7E,EAgBT,YACImY,EAAyBrlB,EAAe0lB,GAC1C,OAAc,MAAVL,GACM,MACC3uB,MAAMC,QAAQ0uB,GAChBA,EAAOpd,IACV,SAAAhR,GAAS,OAAA0uB,GAAsB1uB,EAAO+I,EAAO0lB,EAAO1lB,KAEjD2lB,GAAsBN,EAAQrlB,EAAO0lB,EAAO1lB,eAkBnDqlB,EAAyB1jB,GAC3B,OAAOikB,OAAS,WACd,OAAc,MAAVP,EACK,KACE3uB,MAAMC,QAAQ0uB,GAChBA,EAAOpd,IACV,SAAAhR,GAAS,OAAC4uB,GAAqB5uB,EAAO0K,KAInCmkB,GACHT,EAA0B,UAAlB1jB,EAAQpM,MAAoBoM,EAAUA,EAAQC,WA+BhE,YACIgO,EAAuBoV,EAAiBle,EACxCme,EAAuBC,GACzB,IAAIG,EACJ,gBAFEJ,mBAAuBC,MAErBxuB,MAAMC,QAAQiZ,GAAO,CACvB,GAAIA,EAAKrY,SAAWytB,EAAMztB,OACxB,MAAM,IAAIlB,EACN,6BAA6B6uB,uHAEUF,EAAMztB,sCACzBqY,EAAKrY,uBAE/B8tB,EAASzV,MACJ,CACL,GAAIoV,EAAMztB,OAAS,EACjB,MAAM,IAAIlB,EACN,qBAAqB2uB,EAAMztB,WAAU2tB,qEAElCrsB,KAAKC,UAAU8W,EAAKhQ,YAE7BylB,GAAUzV,GAGZ,GAAc,MAAV9I,EACF,IAAK,IAAIjQ,EAAI,EAAGA,EAAImuB,EAAMztB,SAAUV,EAClC,GAAiB,MAAbiQ,EAAOjQ,GAAX,CAGA,IAAMI,EAAQouB,EAAOxuB,GACrB,GAAII,EAAM2I,MAAMrI,SAAWuP,EAAOjQ,GAAGU,OACnC,MAAM,IAAIlB,EACN,uBAAuB6uB,gBAA6BF,EAAMnuB,eAC/CiQ,EAAOjQ,GAAGU,kDACZsB,KAAKC,UAAU7B,EAAM2I,QAEpC,IAAK,IAAIkgB,EAAI,EAAGA,EAAIhZ,EAAOjQ,GAAGU,SAAUuoB,EACtC,GAAU,IAANA,GAAYmF,EAAhB,CAGA,IAAMhZ,EAAMhV,EAAM2I,MAAMkgB,GAClB0F,EAAS1e,EAAOjQ,GAAGipB,GACzB,GAAc,MAAV0F,GACEA,IAAWvZ,EACb,MAAM,IAAI5V,EACN,uBAAuB6uB,gBACpBF,EAAMnuB,qBAAoBgC,KAAKC,UAAUgO,EAAOjQ,iCAC3BgC,KAAKC,UAAU7B,EAAM2I,eAiD7D,SAAYujB,GACVA,uBACAA,yBAFF,CAAYA,KAAAA,2BAsMV,WAAY7qB,UACV1C,YAAM0C,SA8wCV,OA/yC2BpC,OAsEzB6vB,oBAAA,SACIC,EAAqB7O,EACrBC,GAGF,gBAHEA,EAEoDxR,QAAQ8N,MACzDpX,KAAKgP,MACR,MAAM,IAAIjV,EACN,0LLnqBN8Z,EAAkB6V,EAAqB7O,EAEvCC,gBAAAA,EACIxR,QAAQ8N,KACd,IAkBIgE,EAlBEuO,EA6DR,SAA+B9V,GAC7B,IAAI8V,GAAiB,EACfhL,KACAiL,KACN,IAAK,IAAMrL,KAAS1K,EAAM8K,aACxBA,EAAa5gB,KAAK8V,EAAM8K,aAAaJ,IAEvC,IAAyB,QAAAsL,IAAA9uB,WAAAA,KAApB,IAAM+uB,OACT,GAAIA,EAAW7uB,OAAS,GACE,IAAtB6uB,EAAW7uB,QAAgB6uB,EAAW,GAAGpd,cAAczR,OAAS,EAAG,CACrE0uB,GAAiB,EACjB,MAEFC,EAAM7rB,WAAN6rB,EAAcE,GAEhB,GAAIH,EAEF,IAAoB,QAAA/sB,EAAAiX,EAAM8I,OAANhgB,WAAAA,KAElB,IAFG,IAAMwQ,OACL4c,GAAO,MACQhtB,EAAAoQ,EAAME,aAANxQ,WAAAA,KAAd,IAAM4U,OACT,IAA6B,IAAzBmY,EAAMpuB,QAAQiW,GAAc,CAC9B,GAAIsY,EAAM,CACRJ,GAAiB,EACjB,MAEAI,GAAO,GAIb,IAAKJ,EACH,MAIN,OAAOA,EA/FgBK,CAAsBnW,GAGvCoW,GAAuB,eAAgB,eAAgB,WAgB7D,GAfIN,GACFD,EAAaA,GAAc,GAC3B7O,EAAYA,IAAc,IAAM,IAAM,KAEtC6O,EAAaA,GAAc,GAC3B7O,EAAYA,IAAc,IAAM,IAAM,IAAM,IAI1CA,EAAUA,EAAU5f,OAAS,IAAM,IAErC4f,EAAYA,EAAUlP,IAAI,SAAAuG,GAAK,OAAAvJ,KAAKuhB,MAAMR,EAAaxX,OAIpDyX,EAGH,IAAK,IAAMpL,KAFX0L,EAAUlsB,KAAK,mBACfqd,KACoBvH,EAAM8K,aACxBvD,EAAcrd,WAAdqd,EAAsBvH,EAAM8K,aAAaJ,IAI7CzD,EAAQ,IAAIE,OAAO0O,IACnBxO,GAAS+O,EAAWpP,EAAWC,GAC/BA,EAAQ,IAAIE,OAAO0O,IAGnB,IADA,IAaIS,EAbExN,EAAS9I,EAAM8I,OACZpiB,EAAI,EAAGA,EAAIoiB,EAAO1hB,SAAUV,EAC/BovB,EACFS,GAAkBzN,EAAOpiB,GAAIsgB,EAAWC,GAExCuP,GACI1N,EAAOpiB,GAAIsgB,EAAWO,EAAeN,GAE3CA,GAASvgB,IAAMoiB,EAAO1hB,OAAS,EAAI,IAAM,KAAK+f,OAAO0O,IAItD7V,EAAcyW,mCAIbH,EAD8C,MAA3CtW,EAAc0W,0BAEbC,GAAsB3W,EAAc0W,2BAEvBC,GAAqB3W,EAAM5E,kBAG9C,IAAMwb,EAAoBD,GAAqB3W,EAAM3E,qBAErD4L,EAAQ,kBAAiBqP,EAAiBM,IAC1C3P,EAAQ,qBAAqBqP,GAC7BrP,EAAQ,yBAAyB2P,GACjC3P,EAAQ,IAAIE,OAAO0O,IKymBjBgB,CAAa1qB,KAAM0pB,EAAY7O,EAAWC,IAc5C2O,oBAAA,SAAQztB,GAAR,WAME,GALmB,MAAfA,EAAO2uB,OACT3uB,EAAO2uB,SAET3qB,KAAK2qB,KAAO3uB,EAAO2uB,KAEa,iBAArB3uB,EAAO4uB,UAChB5qB,KAAK4qB,mBChsBkBrvB,GAC3B,IAAMsvB,GACJC,QAAW,WAAM,OAAAC,QAAMC,QAAQ,MAC/BC,SAAY,WAAM,OAAAF,QAAMG,SAAS,EAAG,IAAMnrB,MAC1CorB,KAAQ,WAAM,OAAAJ,QAAMK,KAAK,KAAO,GAAK,KAAOrrB,MAC5CsrB,OAAU,WAAM,OAAAN,QAAMO,OAAO,KAAO,GAAK,KAAOvrB,IAAW,IAC3DwrB,QAAW,WAAM,OAAAR,QAAMS,QAAQ,KAAO,GAAK,EAAGzrB,MAC9C0rB,IAAO,WAAM,OAAAV,QAAMW,IAAI,OASzB,GAPAb,EAAsB,QAAIA,EAAsB,QAChDA,EAAuB,SAAIA,EAAuB,SAClDA,EAAmB,KAAIA,EAAmB,KAC1CA,EAAqB,OAAIA,EAAqB,OAC9CA,EAAsB,QAAIA,EAAsB,QAChDA,EAAkB,IAAIA,EAAkB,IAEpCtvB,KAAcsvB,EAChB,OAAOA,EAAatvB,KAEtB,MAAM,IAAIxB,EAAW,qBAAqBwB,GD6qBrBowB,CAAwB3vB,EAAO4uB,eAC3C,CACL,KAAM5uB,EAAO4uB,qBAAqBgB,aAChC,MAAM,IAAI7xB,EACN,+DAENiG,KAAK4qB,UAAY5uB,EAAO4uB,UAO1B,IAAIiB,KACJ,GAAKzxB,MAAMC,QAAQ2B,EAAO2uB,OAAgC,iBAAhB3uB,EAAO2uB,MACtB,mBAAhB3uB,EAAO2uB,KAkBX,GAAIvwB,MAAMC,QAAQ2B,EAAO2uB,MAAO,CACrC,GAAI3uB,EAAO2uB,KAAK1vB,SAAW+E,KAAKmc,QAAQlhB,OACtC,MAAM,IAAIlB,EACN,2FAC+BiG,KAAKmc,QAAQlhB,0CACrBe,EAAO2uB,UAEpC,IAAMmB,EAAY9vB,EAAO2uB,KACzBkB,EAAgBC,EAAUngB,IAAI,SAAAogB,GAAK,OAAAC,GAAWD,SACzC,CACL,IAAME,EAAeD,GAAWhwB,EAAO2uB,MACvC3qB,KAAKmc,QAAQxQ,IAAI,SAAAwB,GACf0e,EAAc9tB,KAAKkuB,SA9BgB,CAErC,IAAK,IAAMjL,KADXhlB,EAAO2uB,KAAO3uB,EAAO2uB,KACF3uB,EAAO2uB,KACxB,IAAwC,IAApC3qB,KAAK8c,YAAYthB,QAAQwlB,GAC3B,MAAM,IAAIjnB,EACN,sCAAsCinB,wCACnBhhB,KAAK8c,aAGhC,IAAK,IAAMqD,KAAQngB,KAAK8c,YACG,MAArB9gB,EAAO2uB,KAAKxK,IACd7W,QAAQC,KACJ,WAAW4W,8HAEQA,sBAEzB0L,EAAc9tB,KAAKiuB,GAAWhwB,EAAO2uB,KAAKxK,KAkB9CngB,KAAK6rB,cAAgBA,EAErB7rB,KAAKid,mBACLjd,KAAKksB,oBACLlsB,KAAKmsB,eACL,IAAK,IAAI5xB,EAAI,EAAGA,EAAIyF,KAAKmc,QAAQlhB,SAAUV,EAAG,CAE5C,IAAM+I,EAAQtD,KAAKmd,qBAAqB5iB,GAClC6xB,EAAOpsB,KAAK8c,YAAYviB,GAC9ByF,KAAKid,gBAAgBlf,KAAKquB,GAC1BpsB,KAAKksB,iBAAiBnuB,KAAKuF,GAC3BtD,KAAKmsB,YAAYpuB,KAAKiC,KAAK6rB,cAActxB,IAM3C,IAAM8xB,KAGNrsB,KAAKssB,QAAUtwB,EAAOswB,QAEtBtsB,KAAKusB,cAAgB,QACrBvsB,KAAKwsB,kBAMLnc,GAAU,OAAQ,WAChB,IAAK,IAAI9V,EAAI,EAAGA,EAAId,EAAK0iB,QAAQlhB,SAAUV,EACzC,IAAsC,IAAlC8xB,EAAkB7wB,QAAQjB,GAA9B,CAKA,IAAMkyB,EAAehzB,EAAKoyB,cAActxB,GACpCd,EAAK0iB,QAAQlhB,OAAS,IACxBxB,EAAK+yB,eAAezuB,MAAM0uB,EAAclyB,IACxCd,EAAK8yB,aAAaxuB,KAAKtE,EAAKqjB,YAAYviB,GAAK,aAQnD,IAAMmyB,EAzYV,SACIJ,EACAxP,GACF,GAAe,MAAXwP,GAAmBlyB,MAAMC,QAAQiyB,IAA+B,IAAnBA,EAAQrxB,OACvD,OAAO6hB,EAAYnR,IAAI,SAAAxQ,GAAQ,WAEjC,GAAIf,MAAMC,QAAQiyB,GAEhB,OAAOxP,EAAYnR,IAAI,SAAAxQ,GAAQ,OAAAmxB,IAC1B,GAAe,MAAXA,EAAiB,CAG1B,IADA,IAAMI,SACaC,IAAA5xB,WAAAA,KAAd,IAAM+lB,OACL8L,EACAN,EAAQruB,eAAe6iB,GAAQwL,EAAQxL,MACtC1mB,MAAMC,QAAQuyB,KACjBA,GAAiBA,IAEnBF,EAAc3uB,KAAK6uB,GAErB,OAAOF,EAEP,MAAM,IAAIla,UACN,gFACoB8Z,GAiXFO,CAAe7wB,EAAOswB,QAAStsB,KAAK8c,aAgB1DzM,GAAU,SAAU,WAClB,mBAAS9V,GACP,IAAsC,IAAlC8xB,EAAkB7wB,QAAQjB,qBAOR,SAAC+xB,GAOrB,IANA,IACIQ,EACAC,EACAC,aAGOC,GACT,IACK,KADA,WAAY,MAAO,eAAgB,MAAMzxB,QAAQyxB,GAC9C,CACN,IAAMhc,EAAcxX,EAAK0jB,qBAAqB5iB,GAEF,IAAxC0W,EAAYA,EAAYhW,OAAS,IACjCxB,EAAKoyB,cAActxB,KAAO2yB,IAEiB,KAAxC,WAAY,OAAO1xB,QAAQyxB,GAC9BF,EAAQI,IAC6C,KAA3C,eAAgB,MAAM3xB,QAAQyxB,KACxCF,EAAQK,IAGR3zB,EAAKoyB,cAActxB,KACnB8yB,IAG2C,KAAxC,WAAY,OAAO7xB,QAAQyxB,GAC9BF,EAAQO,IAC6C,KAA3C,eAAgB,MAAM9xB,QAAQyxB,KACxCF,EAAQQ,KAImC,KAAxC,WAAY,OAAO/xB,QAAQyxB,GAC9BF,EAAQS,IAC6C,KAA3C,eAAgB,MAAMhyB,QAAQyxB,KACxCF,EAAQU,IAGZ,IAAIC,UACyC,KAAxC,WAAY,OAAOlyB,QAAQyxB,GAC9BS,EAAS,OAC4C,KAA3C,eAAgB,MAAMlyB,QAAQyxB,KACxCS,EAAS,MAGXV,EAAmBD,EACnBD,EA7CqB,GA6CWY,MAC3B,CACL,IAAMC,WNlwBApyB,GAClB,IAAMqyB,GACJC,kBACAC,uBACA7V,2BACAsB,iCACAY,OACAC,OACAC,OACAC,OACAC,QACAC,QACAE,WAEF,GAA0B,iBAAfnf,GAA2BA,KAAcqyB,EAClD,OAAOA,EAAWryB,GACb,GAA0B,iBAAfA,GAAyC,MAAdA,EAC3C,OAAOA,EAEP,MAAM,IAAIxB,EAAW,kBAAkBwB,GM+uBZwyB,CAAYd,GAE7BD,EAAmBW,EACnBb,EAlDqB,GAkDWG,EAIlC,IAAIe,EACJ3d,GAAUyc,EAAY,WACpBkB,EAAehB,IA3ErB,SAACiB,EAAqBnB,EACrBoB,GACKz0B,EAAKqjB,YAAY7hB,OAAS,IAC5B6xB,EAAarzB,EAAKqjB,YAAYmR,GAAe,IAAMnB,GAErDrzB,EAAK8yB,aAAaxuB,KAAK+uB,GACvBrzB,EAAK+yB,eAAezuB,MAAMmwB,EAAcD,IAuEtCE,CAAa5zB,EAAGuyB,EAAYkB,QApDTI,IAAArzB,WAAAA,YAwDvBszB,CAnEsB3B,EAAcnyB,KAJ7BA,EAAI,EAAGA,EAAId,EAAK0iB,QAAQlhB,SAAUV,IAAlCA,KA8EXyF,KAAKuqB,0BAA4BvqB,KAAKiP,kBAYhCwa,6CAAR,WACwC,MAAlCzpB,KAAKuqB,2BAGLvqB,KAAKiP,iBAAiBhU,SACtB+E,KAAKuqB,0BAA0BtvB,QACjCqO,QAAQC,KACJ,sJAsCRkgB,qBAAA,SACIvuB,EAAoB6J,EACpB/I,gBAAAA,MACF,IAAMsS,EAAgC,MAApBtS,EAAOsS,UAAoB,GAAKtS,EAAOsS,UAInDggB,EAAmBtuB,KAAKuuB,oBAAoBrzB,EAAG6J,GAAG,EAAMuJ,GAGxDkgB,EAAMF,EAAiB,GAAG9zB,OAAO8zB,EAAiB,IACxDtuB,KAAKyuB,mBACL,IAAMC,EAAI1uB,KAAK2uB,aAGf,OAAOC,EADH5uB,KAAK6uB,SAASH,EAAGF,EAAKlgB,EAAWtS,EAAO8yB,QAAS9yB,EAAO+yB,SActDtF,4BAAR,SACI+E,EAAsBlgB,EAAoBygB,EAC1CC,GACF,IAAIC,EACJ,gBAFED,WAEW,MAATD,GAEF,GADAE,EAAa,KACI,MAAb3gB,EACF,MAAM,IAAIvU,EACN,MAAMi1B,kEACa1gB,OAEpB,CAAA,GAAW,MAAPkgB,EAOT,MAAM,IAAIz0B,EACN,yDACGi1B,0BAPLC,EADE70B,MAAMC,QAAQm0B,GACHA,EAAI,GAAGlrB,MAAM,GAEbkrB,EAAIlrB,MAAM,GAO3B,OAAO2rB,GAUTxF,oBAAA,SAAQpd,EAAwC8P,GAE9C,GAAI/hB,MAAMC,QAAQ8hB,IAA+B,IAAnBA,EAAQlhB,OACpC,MAAM,IAAIlB,EACN,sDAGN,IAAMm1B,EAAiB90B,MAAMC,QAAQ8hB,GAC/BW,EAAeoS,EAAiB/S,GACCA,GACjCoM,EAAwBvoB,KAAKmvB,wBAAwBrS,GAGrDwK,EAAW,IAAIP,GAIrB,GAHI1a,aAAkB0P,WACpB1P,GAAUA,IAERjS,MAAMC,QAAQgS,GAAS,CACzB,GAAKA,EAAoBpR,SAAW+E,KAAKqM,OAAOpR,OAC9C,MAAM,IAAIlB,EACN,kCAAmCsS,EAAoBpR,+DAEnD+E,KAAKqM,OAAOpR,aAEtB,IAAK,IAAIV,EAAI,EAAGA,EAAIyF,KAAKqM,OAAOpR,SAAUV,EACxC+sB,EAAS1hB,IAAI5F,KAAKqM,OAAO9R,GAAK8R,EAAoB9R,SAGpD,IAAoB,QAAAoC,EAAAqD,KAAKqM,OAALtR,WAAAA,KAAf,IAAMq0B,OACHC,EAAehjB,EAA0B+iB,EAAMj0B,MACrD,GAAmB,MAAfk0B,EACF,MAAM,IAAIt1B,EACN,8CAA8Cq1B,EAAMj0B,MAE1DmsB,EAAS1hB,IAAIwpB,EAAOC,GAKxB,IAAMC,EAAiBC,GAAQhH,EAAuBjB,GACtD,OAAO4H,EAAiBI,EAAiBA,EAAe,IAMlD7F,oCAAR,SAAgC+F,GAK9B,IAHA,IAAMjH,EACFkH,EAAa,KAAMD,EAAoBv0B,QACvCy0B,EAAmBF,EAAoBv0B,WACvB0B,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAKlB,IALG,IAAMoS,OACHgb,EAAiC/tB,MAAMC,QAAQ8S,EAAMyD,QACvDzD,EAAMyD,QACLzD,EAAMyD,QACL+e,EAAmBxH,EAAaxc,IAAI,SAAAiF,GAAU,OAAAA,EAAOzV,OAClDZ,EAAI,EAAGA,EAAIi1B,EAAoBv0B,SAAUV,EAAG,CACnD,IAAM8H,EAAQstB,EAAiBn0B,QAAQg0B,EAAoBj1B,IAK3D,IAJe,IAAX8H,IACFkmB,EAAsBhuB,GAAK4tB,EAAa9lB,GACxCqtB,KAEuB,IAArBA,EACF,MAGJ,GAAyB,IAArBA,EACF,MAIJ,GAAIA,EAAmB,EAAG,CACxB,IAAME,KAMN,MALArH,EAAsBjX,QAAQ,SAACqM,EAAQpjB,GACvB,MAAVojB,GACFiS,EAAe7xB,KAAKyxB,EAAoBj1B,MAGtC,IAAIR,EACN,mDACGwC,KAAKC,UAAUozB,IAExB,OAAOrH,GAgBDkB,wBAAR,SAAoB+E,EAAsBlgB,EAAgBwgB,GAA1D,WAEE,oBAFwCxgB,mBAAgBwgB,MAEjDxF,OAAS,WACd,IAAM2F,EAAax1B,EAAKo2B,gBAAgBrB,GACxC,GAAIM,EACF,MAAM,IAAI90B,EACN,iDAWN,IAHA,IAAM81B,EAAUC,GAAYd,EAAY3gB,GAClC0hB,gBAEGC,GACP,IAAMC,EAAY5G,OAAS,WACzB,IAAMH,EAAa2G,EAAQG,GAAY,GACjCxa,EAAWqa,EAAQG,GAAY,GAG/BE,EAAWC,GAAY5B,EAAKrF,EAAY1T,GAGxCqR,KACN,GAAI1sB,MAAMC,QAAQ81B,GAChB,IAAK,IAAI51B,EAAI,EAAGA,EAAI41B,EAASl1B,SAAUV,EACrCusB,EAAM/oB,MAAMd,IAAKxD,EAAK4S,OAAO9R,GAAIvB,MAAOm3B,EAAS51B,UAGnDusB,EAAM/oB,MAAMd,IAAKxD,EAAK4S,OAAO,GAAIrT,MAAOm3B,IAE1C,IAAM7I,EAAW,IAAIP,GAASD,GAC9B,OAAOyI,GAAQ91B,EAAK0iB,QAASmL,KAE/B,GAAmB,IAAf2I,EAEF,IAAuB,QAAAI,IAAAt1B,WAAAA,KAAlB,IAAMu1B,OACTN,EAAKjyB,KAAKuyB,QAGZ,IAAK,IAAI/1B,EAAI,EAAGA,EAAI21B,EAAUj1B,SAAUV,EACtCy1B,EAAKz1B,GAAKg2B,GAAuBP,EAAKz1B,GAAI21B,EAAU31B,KA3BjD01B,EAAa,EAAGA,EAAaH,EAAQ70B,SAAUg1B,IAA/CA,GA+BT,OAAOrB,EAAiBoB,MAgC5BvG,oBAAA,SAAQvuB,EAAoBc,gBAAAA,MAE1Bw0B,GAAet1B,EAAG8E,KAAK6c,WAAY7c,KAAK+c,iBAAiB,GAKzD,IAAMzO,EAAgC,MAApBtS,EAAOsS,UAAoB,GAAKtS,EAAOsS,UACzD,OAAOtO,KAAKywB,YAAYv1B,EAAGoT,IAgB7Bmb,2BAAA,SAAevuB,GAIb,OAHAs1B,GAAet1B,EAAG8E,KAAK6c,WAAY7c,KAAK+c,iBAAiB,GAGlD/c,KAAKywB,YAAYv1B,EAAGA,EAAEoI,MAAM,KAG3BmmB,gCAAV,SACIvuB,EACA6J,EAAkD4jB,EAClDra,GAEF,gBAHoDqa,MAG9B,MAAlB3oB,KAAK4qB,UACP,MAAM,IAAI9wB,EACN,4FAIN,IADA,IAAMoT,KACG3S,EAAI,EAAGA,EAAIyF,KAAKksB,iBAAiBjxB,SAAUV,EAAG,CACrD,IAAM0W,EAAcjR,KAAKksB,iBAAiB3xB,GAC3ByF,KAAKmsB,YAAY5xB,KACjB8yB,GACbngB,EAAanP,KACTkT,EAAY1N,MAAM,EAAG0N,EAAYhW,OAAS,GAAGT,QAAQ,KAGzD0S,EAAanP,KAAKkT,GAYtB,YApkCA5E,EAAkBqkB,EAAmBjmB,GACvC,IAAMkmB,EAAOC,EAAOvkB,EAAOV,IAAI,SAAAyjB,GAAS,OAAAA,EAAM9rB,MAAM,MACpDqtB,EAAK1R,OACL,IAAM4R,EAAOD,EAAOF,EAAQ/kB,IAAI,SAAA6L,GAAU,OAAAA,EAAOlU,MAAM,MAGvD,GAFAutB,EAAK5R,OAED0R,EAAK11B,OAAS,EAChB,MAAM,IAAIlB,EACN,mFAEGwC,KAAKC,UAAU6P,EAAOV,IAAI,SAAAyjB,GAAS,OAAAA,EAAM9rB,UAElD,GAAIutB,EAAK51B,OAAS,EAChB,MAAM,IAAIlB,EACN,oFAEGwC,KAAKC,UAAUk0B,EAAQ/kB,IAAI,SAAA6L,GAAU,OAAAA,EAAOlU,UAErD,GAAIqtB,EAAK11B,OAAS,GAAK41B,EAAK51B,OAAS,IAAM8K,OAAKC,YAAY2qB,EAAME,GAChE,MAAM,IAAI92B,EACN,iFACkB42B,EAAK,2BAA0BE,EAAK,yBA4iC1DC,CANA51B,EAAI61B,GACI71B,EAAG8E,KAAKgd,eAAgBhd,KAAK+c,iBAAiB,EAAO,SAE7DhY,EAAIgsB,GACIhsB,EAAG/E,KAAKid,gBAAiB/P,GAAc,EAAO,WA5hC1D,SACIwjB,EAAmBM,EAA2B9jB,GAMhD,IAJA,IAAM+jB,GACJC,GAAyBhE,GACzBiE,IAEO52B,EAAI,EAAGA,EAAIm2B,EAAQz1B,SAAUV,EAAG,CACvC,IAAMwK,EAAI2rB,EAAQn2B,GACZowB,EAAOqG,EAAQz2B,GACf+I,EAAQ4J,EAAa3S,GAC3B,GAAY,MAARowB,EAAJ,CAGA,GAAIA,IAASwG,IACyB,IAAhCpsB,EAAEzB,MAAMyB,EAAEzB,MAAMrI,OAAS,GAC3B,MAAM,IAAIlB,EACN,2CAA2CgL,EAAEzB,kKAOrD,IAAiC,IAA7B2tB,EAAUz1B,QAAQmvB,GAGpB,IAFA,IAAMyG,EAAersB,EAAEzB,MAAMC,MAAM,GAC7B8tB,EAAc/tB,EAAMC,MAAM,GACvBigB,EAAI,EAAGA,EAAI4N,EAAan2B,SAAUuoB,EAAG,CAC5C,IAAM8N,EAAYF,EAAa5N,GACzB+N,EAASF,EAAY7N,GAC3B,GAAc,MAAV+N,GAAkBD,IAAcC,EAClC,MAAM,IAAIx3B,EACN,8BAA8BgL,EAAEzB,4CACbA,iGA+/B7BkuB,CAAgCzsB,EAAG/E,KAAKmsB,YAAansB,KAAKksB,kBACtDlsB,KAAK4mB,UAAyB,MAAbtY,GAAqBA,EAAY,GAChDpT,EAAE,GAAGoI,MAAM,GAAKgL,GAAc,EAChC,MAAM,IAAIvU,EACN,mHAEGuU,cAAqBpT,EAAE,GAAGoI,MAAM,kBAI3C,OAAQpI,EAAG6J,EAAG,OA8BF0kB,oBAAd,SACIiF,EAAiCF,EAAeiD,EAChDnjB,EAAoBojB,EAAiB5C,EACrChb,EAA4B6d,EAC5BC,EAAmBC,EAA0BC,EAC7CC,EAAuBC,EACvBC,oHAoBF,GAnBiB,MAAb3jB,IACFA,EAAY,IAEA,MAAVojB,IACFA,EAAS,GAEI,MAAXG,IACFA,GAAU,GAEQ,MAAhBE,IACFA,EAAe,GAIbG,GAAe,EACP,MAARP,GAA0B,MAAVC,IAClBM,GAAe,GAGM,MAAnBD,IACFC,GAAe,EACM,MAAjBF,GACF,MAAM,IAAIj4B,EACN,oGAoBR,GAZuB,OAHjBo4B,EACFnyB,KAAK6vB,gBAAgBrB,EAAKlgB,EAAW0jB,EAAe,sBAGtDI,EAAaC,GAAM,EAAGF,IAGxBnyB,KAAKkV,QAAU,IAAID,GAMnBnB,GAJEA,EADe,MAAbA,GACW,IAAIY,KAEH,IAAIA,IAAiCla,OAAOsZ,IAEtCtZ,QAAQwF,KAAKkV,UAE/B4Z,EAAU,EACZ,MAAM,IAAI90B,EAAoB,wCAehC,OAbMs4B,EAAe,IAAIte,GAAaF,IAIzBK,SAASnU,MACtBsyB,EAAape,WACXwd,SACAK,eACAhD,MAAOiD,EACPlD,UACAoD,eACA5F,QAASwF,OAELQ,EAAa9d,uBAAnB7X,SACAqD,KAAKuyB,cAAe,aAKX5e,kEACP,SAAM2e,EAAale,aAAaT,cAAhChX,SACM61B,KACe,MAAjBR,EAAA,YACF,MAAM,IAAIh4B,EACN,qDAEJ,GAAgB,UAAZ63B,EACF,MAAM,IAAI73B,EACN,0CACK63B,GACT9rB,OAAK8rB,QAAQO,GAITK,EAAoB1vB,WAASqvB,GAE7BM,EAAU3C,GAAYoC,EAAiB7jB,cACpC2hB,0DAEP,OADM0C,QACAL,EAAahe,aAAa2b,EAAY0C,WAsC5C,OAtCAh2B,SAEA2sB,OAAS,WACP,IAAMH,EAAauJ,EAAQzC,GAAY,GACjCxa,EAAWid,EAAQzC,GAAY,GAC/B2C,EAAWvJ,GACIoJ,EAAmBtJ,EACnB1T,EAAW0T,GAChCwJ,EAAiB,MAAI1C,EACrB0C,EAAgB,KAAIld,EAAW0T,EAM/B,IAFA,IAAMgH,EAAW5G,GAAqBiF,EAAKoE,GACrC5C,EAAOtB,EAAEyB,GACN51B,EAAI,EAAGA,EAAIk3B,EAAUx2B,SAAUV,EAAG,CACzC,IAAM4D,EAAQszB,EAAUl3B,GAClBsD,EAAMmyB,EAAKz1B,GACjBo4B,EAAUx0B,GAASN,EACnBg1B,OAASh1B,GAIX,GAAIoyB,IAAeyC,EAAQz3B,OAAS,GAC9Bi3B,EACF,CAAA,IAAMY,EAAUr5B,EAAKo1B,SAAS8C,EAAMC,EAAQtjB,GAE5C,IAAS/T,EAAI,EAAGA,EAAIk3B,EAAUx2B,SAAUV,EAAG,CACnC4D,EAAQszB,EAAUl3B,GAClBsD,EAAMi1B,EAAQv4B,GACpBs4B,OAASh1B,GAET20B,EAAU,OAASr0B,GAASN,SAM9By0B,EAAa/d,WAAW0b,EAAY0C,WAG1C,OAHAh2B,kBT92C2BuW,GACnC,GAAY,MAARA,EAGJ,IAAK,IAAMjW,KAAOiW,EAAM,CACtB,IAAMla,EAAQka,EAAKjW,GACE,iBAAVjE,GACTA,EAAMya,WSw2CFsf,CAAqBJ,GAEjB9d,EAAK0d,iCA3CFtC,EAAa,0BAAGA,EAAayC,EAAQz3B,YAArCg1B,4EAA+CA,eAiDxDwC,EAAkBhf,2BAGpB,SAAM6e,EAAaje,WAAWV,EAAO6e,WACrC,OADA71B,SACIkY,EAAK0d,wCAvEF5e,EAAQoe,0BAAcpe,EAAQ+d,OAA9B/d,4EAAwCA,eA2EjD,SAAM2e,EAAa7d,qBAEnB,OAFA9X,YAEMqD,KAAKkV,QAAQ8d,mBACnB,OADAr2B,YACOqD,KAAKkV,eAaNuU,qBAAR,SACIiF,EAAiCF,EAAelgB,EAChDwgB,EAAaC,GAFjB,WAGE,oBADED,KACKxF,OAAS,WACd,IAAM2F,EAAax1B,EAAKo2B,gBAAgBrB,EAAKlgB,EAAWygB,EAAO,SACzDiB,KACN,GAAgB,IAAZlB,EACF,MAAM,IAAI90B,EAAoB,wCAGhC,GAAa,MAAT+0B,EACF,MAAM,IAAI/0B,EACN,mDAIJ,IAFA,IAAM81B,EAAUC,GAAYd,EAAY3gB,GAClC8jB,EAAarvB,WAASsvB,GAAM,EAAGpD,IAC5BgB,EAAa,EAAGA,EAAaH,EAAQ70B,SAAUg1B,EAAY,CAClE,IAAM9G,EAAa2G,EAAQG,GAAY,GACjCxa,EAAWqa,EAAQG,GAAY,GAC/B2C,EACFvJ,GACI+I,EAAYjJ,EAAY1T,EAAW0T,GAGrCgH,EAAW5G,GAAqBiF,EAAKoE,GACrC1C,EAAYxB,EAAEyB,GACpB,GAAmB,IAAfF,EACF,IAAK,IAAI11B,EAAI,EAAGA,EAAI21B,EAAUj1B,SAAUV,EACtCy1B,EAAKjyB,KAAK+B,EAAU,IAGxB,IAASvF,EAAI,EAAGA,EAAI21B,EAAUj1B,SAAUV,EAAG,CACzC,IAAM+1B,EAAWJ,EAAU31B,GAC3By1B,EAAKz1B,GACDsF,MACImwB,EAAKz1B,GACLoF,MAAQG,EAAU2V,EAAW0T,GAAamH,KAItD,IAAS/1B,EAAI,EAAGA,EAAIy1B,EAAK/0B,SAAUV,EACjCy1B,EAAKz1B,GAAKqF,MAAQowB,EAAKz1B,GAAIuF,EAAUmvB,IAGzC,OAAOe,KAIHvG,mCAAR,WAKE,IAJA,IAAMgI,EAAYzxB,KAAKusB,aAGjB0G,KACG14B,EAAI,EAAGA,EAAIk3B,EAAUx2B,SAAUV,EAAG,CACzC,IAAM4D,EAAQszB,EAAUl3B,GACpB24B,EAAW/0B,EACf,GAAIuM,EAAM+mB,EAAWtzB,GAAS,EAE5B+0B,GAAY,IADKxoB,EAAM+mB,EAAUluB,MAAM,EAAGhJ,GAAI4D,GAGhD80B,EAAiBl1B,KAAKm1B,GAExB,OAAOD,GAGDxJ,6BAAR,WAAA,WACEzpB,KAAK2uB,aAAe,SAACrb,GACnB,OAAOgW,OAAS,WAOd,IANA,IACI6J,EADEC,KAEA/mB,EAASiH,EAAK/P,MAAM,EAAG9J,EAAK4S,OAAOpR,QACnCy1B,EAAUpd,EAAK/P,MACjB9J,EAAK4S,OAAOpR,OAAQxB,EAAK4S,OAAOpR,OAASxB,EAAK0iB,QAAQlhB,QACpD6rB,KACGvsB,EAAI,EAAGA,EAAId,EAAK4S,OAAOpR,SAAUV,EACxCusB,EAAM/oB,MAAMd,IAAKxD,EAAK4S,OAAO9R,GAAIvB,MAAOqT,EAAO9R,KAEjD,IAAM+sB,EAAW,IAAIP,GAASD,GACxB3K,EAAUoT,GAAQ91B,EAAK0iB,QAASmL,GAEtC,IAAS/sB,EAAI,EAAGA,EAAId,EAAKoyB,cAAc5wB,SAAUV,EAAG,CAClD,IAAM84B,EAAe55B,EAAKoyB,cAActxB,GAGlCowB,EAAOvU,OAASid,EAAa3C,EAAQn2B,GAAI4hB,EAAQ5hB,KAErD44B,EADQ,IAAN54B,EACUowB,EAEA9qB,MAAQszB,EAAWxI,GAEjCyI,EAAWr1B,KAAKo1B,GAGlB,IAAS54B,EAAI,EAAGA,EAAId,EAAK+yB,eAAevxB,SAAUV,EAAG,CACnD,IAAM0yB,EAASxzB,EAAK+yB,eAAejyB,GAAG,GAChC0zB,EAAcx0B,EAAK+yB,eAAejyB,GAAG,GAErC+4B,EACFld,OAAS6W,EAAOyD,EAAQzC,GAAc9R,EAAQ8R,KAClDmF,EAAWr1B,KAAKu1B,GAElB,OAAOF,MAuCP3J,gBAAN,SACIvuB,EACA6J,EACA/I,uBAAAA,wIAsBF,GArBMsS,EAAgC,MAApBtS,EAAOsS,UAAoB,GAAKtS,EAAOsS,UAInDggB,EAAmBtuB,KAAKuuB,oBAAoBrzB,EAAG6J,GAAG,EAAOuJ,GAC3DjC,EAASiiB,EAAiB,GAC1BoC,EAAUpC,EAAiB,GAK3B4D,GAAe,EASfqB,GAAyB,EACA,MAAzBv3B,EAAOw3B,gBAA0Bx3B,EAAOw3B,eAAev4B,OAAS,EAAG,CAErE,GADAi3B,GAAe,EACsB,IAAjCl2B,EAAOw3B,eAAev4B,OAInB,MAAqC,IAAjCe,EAAOw3B,eAAev4B,OACzB,IAAIjB,EACN,iEAEE,IAAID,EACN,0GAEGiC,EAAOw3B,+BATdC,EAAOz3B,EAAOw3B,eAAe,GAC7BE,EAAO13B,EAAOw3B,eAAe,GAWzBG,EACF3zB,KAAKuuB,oBAAoBkF,EAAMC,GAAM,EAAMplB,GAC/CmlB,EAAOE,EAAgB,GACvBD,EAAOC,EAAgB,GAGvB/B,EAAS6B,EAAKj5B,OAAOk5B,QAGO,MAA1B13B,EAAO43B,iBAA2B53B,EAAO43B,gBAAkB,GAC3D53B,EAAO43B,gBAAkB,GAC3B1B,GAAe,EAET2B,EACFlrB,KAAKuhB,MAAM7d,EAAO,GAAG/I,MAAM,IAAM,EAAItH,EAAO43B,kBAC1CE,EAAoBznB,EAAO,GAAG/I,MAAM,GAC1CmwB,EAAOrD,GAAY/jB,EAAQwnB,EAASC,GACpCznB,EAAS+jB,GAAY/jB,EAAQ,EAAGwnB,GAChCH,EAAOtD,GAAYM,EAASmD,EAASC,GACrCpD,EAAUN,GAAYM,EAAS,EAAGmD,GAClCN,GAAyB,EAGzB3B,EAAS6B,EAAKj5B,OAAOk5B,IAGc,MAA1B13B,EAAOi2B,kBAChBC,GAAe,GAoHL,OAhHN1D,EAAMniB,EAAO7R,OAAOk2B,GAE1B1wB,KAAKsqB,mCAqBCyJ,EAAgB,SAACzgB,GAIrB,IAAMjH,EAASiH,EAAK/P,MAAM,EAAG9J,EAAK4S,OAAOpR,QACnCy1B,EAAUpd,EAAK/P,MACjB9J,EAAK4S,OAAOpR,OAAQxB,EAAK4S,OAAOpR,OAASxB,EAAK0iB,QAAQlhB,QAEpD+4B,KAwDAC,EAAYx6B,EAAK8wB,0BAA0B5e,IAC7C,SAAAuoB,GAAS,OAAAA,EAAMtoB,SAKnB,OAFInS,EAAKmxB,UAAUuJ,SAxDO,WAExB,IADA,IAAMrN,KACGvsB,EAAI,EAAGA,EAAId,EAAK4S,OAAOpR,SAAUV,EACxCusB,EAAM/oB,MAAMd,IAAKxD,EAAK4S,OAAO9R,GAAIvB,MAAOqT,EAAO9R,KAEjD,IAMI44B,EANE7L,EAAW,IAAIP,GAASD,GACxB3K,EACFoT,GAAQ91B,EAAK0iB,QAASmL,GAAW/gB,UAAY,IAKjD,IAAShM,EAAI,EAAGA,EAAId,EAAKoyB,cAAc5wB,SAAUV,EAAG,CAClD,IACMowB,GAAO0I,EADQ55B,EAAKoyB,cAActxB,IACdm2B,EAAQn2B,GAAI4hB,EAAQ5hB,IAG7B6b,OAASuU,GAIxBwI,EADQ,IAAN54B,EACUowB,EAEA9qB,MAAQszB,EAAWxI,GAOnC,IAASpwB,EAAI,EAAGA,EAAId,EAAK+yB,eAAevxB,SAAUV,EAAG,CACnD,IAAM0yB,EAASxzB,EAAK+yB,eAAejyB,GAAG,GAChC0zB,EAAcx0B,EAAK+yB,eAAejyB,GAAG,GAErC+4B,EACFld,OAAS6W,EAAOyD,EAAQzC,GAAc9R,EAAQ8R,KAElD4E,OAASS,GAETU,EAAcj2B,KAAKu1B,GAUrB,OAPAH,EAAY/c,OAAS+c,GAGrB15B,EAAKqrB,kBAAkBxT,QAAQ,SAAA8iB,GAC7BjB,EAAYtzB,MAAQszB,EAAWiB,KAG1BjB,IAKU,EAEwCc,IAEnCz5B,OAAOw5B,IAG3BvC,EAAYzxB,KAAKq0B,yBAInBnC,GACFlyB,KAAKyuB,mBACL6F,EAAct0B,KAAK2uB,aACnBmD,EACIL,EAAUluB,QAAQ/I,OAAOi3B,EAAU9lB,IAAI,SAAAlH,GAAK,MAAA,OAASA,OAEzD6vB,EAAc,KACd1C,KACAE,EAAkBL,EAAUluB,SAGxBuQ,WRr3C2BA,GAGnC,OAAiB,MAAbA,EACK,KAELA,aAAqBJ,IACfI,GAEN1Z,MAAMC,QAAQyZ,IAAcA,EAAU,aAAcJ,GAC/CI,EAIL1E,EAAqB0E,GACFnI,IACnB,SAAA4oB,GAAkB,OAAA,IAAI7e,GAAe6e,KQq2CrBC,CAAqBx4B,EAAO8X,cAC5B9T,KAAKy0B,QACnBV,EAAevF,EAAKiD,EAAWnjB,EAAWtS,EAAO01B,OAAQ11B,EAAO8yB,QAChEhb,EAAWwgB,EAAa1C,EAAQ51B,EAAO61B,QAASC,EAChD91B,EAAO+1B,aAAc,KAAM,cAM/B,OATMl0B,EAAMlB,SAIR42B,IACF3B,EAAOtgB,QAAQ,SAAAqM,GAAU,OAAAA,EAAOlK,YAChCpH,EAAOiF,QAAQ,SAAAqM,GAAU,OAAAA,EAAOlK,YAChCid,EAAQpf,QAAQ,SAAAqM,GAAU,OAAAA,EAAOlK,gBAE5B5V,SAaC4rB,4BAAV,SAA0BztB,GAMxB,IALA,IAAM04B,KAEA9iB,EAA0B,MAAV5V,GAAkBA,EAAO4V,cACzCnH,EAAUmH,EAAgB5R,KAAKiP,iBAAmBjP,KAAKyK,QACvD+W,EAAexhB,KAAK20B,WAAW/iB,GAC5BrX,EAAI,EAAGA,EAAIkQ,EAAQxP,SAAUV,EAChCqX,IAAkBnH,EAAQlQ,GAAGwQ,YAIjC2pB,EAAajqB,EAAQlQ,GAAG2Q,cAAgBsW,EAAajnB,IAEvD,OAAOm6B,GAmFHjL,iBAAN,SAAWmL,EAAmC54B,yGAE5C,GAA4B,iBAAjB44B,EAA2B,CAEpC,GAAwB,KADlBC,EAAWC,KAAGC,gBAAgBH,IACvB35B,OACX,MAAM,IAAIlB,EACN,0CAA0C66B,OACzC,GAAIC,EAAS55B,OAAS,EAC3B,MAAM,IAAIlB,EACN,wBAAwB86B,EAAS55B,mCACzB25B,OAEdA,EAAeC,EAAS,GAE1B,GAAyB,MAArBD,EAAaI,KACf,MAAM,IAAIj7B,EACN,0GAKF,SAAM+6B,KAAGG,cAAcj1B,KAAKk1B,gBAAgBl5B,YAMhD,OAPMm5B,EACFx4B,SAEEulB,GAAe,EACfkT,EAAgB,KAChBjT,EAAcniB,KAAKq1B,OAAOD,EAAWlT,MAEpC0S,EAAaI,MAClBM,cAAenT,EACfoT,WAAYJ,EAAmB7hB,KAC/BkiB,YAAaL,EAAmBM,eA3yC7BhM,YAAY,WADM1L,gBE3aa2X,0EAEtC,GAA+B,iBAApBA,EAA8B,CAEvC,GAAwB,KADlBb,EAAWC,KAAGa,gBAAgBD,IACvBz6B,OAGX45B,EAAS92B,KAAK+2B,KAAGc,mBAAmBF,SAC/B,GAAIb,EAAS55B,OAAS,EAC3B,MAAM,IAAIlB,EACN,wBAAwB86B,EAAS55B,mCACzBy6B,OAEdA,EAAkBb,EAAS,GAE7B,kBAOEgB,EACA15B,yGACF,GAAoB,MAAhB05B,EAAQC,KACV,MAAM,IAAI/7B,EACN,iHAGY,SAAM87B,EAAQC,eAWhC,GAXMC,EAAYp5B,SAEmB,OADjC24B,EAAgBS,EAAUT,eACE,eAC9BA,EAAgBA,EAA4B,cAExCzhB,EACFmiB,cL/LFC,EAA2Bh5B,GAC7B,GAAuB,OAAnBg5B,EACF,OAAO,KACF,GAA8B,iBAAnBA,EAChB,OAAOC,EAA0BD,GAC5B,GACwB,iBAAnBA,GACmB,kBAAnBA,EACV,OAAOA,EACF,GAAIA,aAA0B77B,MAAO,CAG1C,IAFA,IAAM+7B,KACA7T,EAAc2T,EAAeh7B,OAC1BV,EAAI,EAAGA,EAAI+nB,IAAe/nB,EAAG,CACpC,IAAMgoB,EAAO0T,EAAe17B,GACxBioB,GAA6BvlB,EAAK1C,EAAGgoB,GACvC4T,EAAQp4B,KAAKwkB,GAEb4T,EAAQp4B,KAAKq4B,EAAoB7T,EAAMtlB,IAG3C,OAAOk5B,EAGP,IADA,IAAME,SACoB15B,EAAApD,OAAOyD,KAAKi5B,GAAZl7B,WAAAA,KAArB,IAAMu7B,OACHC,EAAgBN,EAAeK,GACrC,GAAoB,SAAhBA,GAAmD,iBAAlBC,EAInCF,EAAOC,GAAeC,MACjB,CACL,IAAM5T,EAAQuT,EAA0BI,GACxCD,EAAO1T,GAASyT,EAAoBG,EAAe5T,IAGvD,OAAO0T,EK6JDD,CAAoBd,GACpBn5B,GAGoB,MAAxB45B,EAAUR,WAAoB,CAEhC,GAA6B,MAAzBQ,EAAUP,YACZ,MAAM,IAAIz7B,EACN,4GAIA0mB,GAAe,EACfC,GAAmB,EACzB7M,EAAM2iB,YACF1B,KAAG2B,cAAcV,EAAUR,WAAYQ,EAAUP,aACjD/U,EAAcC,GAEpB,SAAO7M,QAvCA6iB,CAAuBhB,wBF6sDlBz1B,iBAAiBC,SAASupB,uBE3nDtC,WAAYztB,GAAZ,MACE1C,aAAO+S,UAAY8P,mBAWnB,GAVAngB,EAASA,MAETvC,EAAKsR,WAAY,EACjBtR,EAAKk9B,YAAa,EAClBl9B,EAAKuV,OAAQ,EAGbvV,EAAK0B,KAAuB,MAAfa,EAAOb,KAAgBa,EAAOb,KAAO+S,EAAO,eAGpC,MAAjBlS,EAAO2gB,OACT,IAAoB,QAAAhgB,EAAAX,EAAO2gB,OAAP5hB,WAAAA,KAAf,IAAMoS,OACT1T,EAAKmM,IAAIuH,YA6cjB,OA/dgCvT,OA2C9Bg9B,gBAAA,SAAIzpB,GACF,IAEI0pB,EAFEC,EACF3pB,aAAiBypB,GAAczpB,aAAiBsc,GAEpD,GAAIqN,EAAsB,CAExB,GAAkC,KADlCD,EAAa1pB,GACEgP,QAAQlhB,OACrB,MAAM,IAAIlB,EACN,yHAKN,GAAiC,IAA7B88B,EAAWxqB,OAAOpR,OACpB,MAAM,IAAIlB,EACN,uHAOR,GAA4B,IAAxBiG,KAAKmc,QAAQlhB,OAAc,CAE7B,GAAkC,IAA9BkS,EAAME,aAAapS,OAAc,CAEnC,GAA6B,MAAzBkS,EAAMkB,gBACR,MAAM,IAAItU,EACN,iGAIN,IAAMmB,EAAI67B,IACR9jB,WAAY9F,EAAMkB,gBAClBpV,MAAOkU,EAAMlU,MACbkC,KAAMgS,EAAMhS,KAAO,WAIrBgS,EAAMzB,MAAMxQ,GAGd,GAAI47B,EACF92B,KAAKmc,QAAU0a,EAAW1a,QAC1Bnc,KAAKqM,OAASwqB,EAAWxqB,WACpB,CACL,GAAkC,IAA9Bc,EAAME,aAAapS,OACrB,MAAM,IAAIlB,EACN,0GACkDoT,EAAMhS,mBAC3CgS,EAAME,aAAapS,6CAItC,GAAmD,IAA/CkS,EAAME,aAAa,GAAGP,cAAc7R,OACtC,MAAM,IAAIlB,EACN,yHAKNiG,KAAKmc,SAAWhP,EAAME,aAAa,GAAGP,cAAc,IACpD9M,KAAKqM,kBbghCTsR,EAAwBxQ,EACxBuB,GAKF,IAJa,MAATvB,GAA+B,MAAbuB,GAAqBA,EAAY,KACrDvB,EAAQwQ,EAAOvR,YACfsC,EAAYiP,EAAOjP,WAEa,IAA9BvB,EAAME,aAAapS,OACrB,OAAQ0iB,GAER,IAAMlM,EAAOtE,EAAME,aAAaqB,GAChC,GAAkC,IAA9B+C,EAAK/E,cAAczR,OACrB,OAAOwW,EAAK5E,aAGZ,IADA,IAAMmqB,KACGz8B,EAAI,EAAGA,EAAIkX,EAAK/E,cAAczR,OAAQV,IAM7C,IALA,QAKgB08B,EAFQC,EAHdzlB,EAAK5E,aAAatS,GACdkX,EAAK/E,cAAcnS,GACfkX,EAAK9E,YAAYpS,IAGnBQ,WAAAA,KAAX,IAAMo8B,QACyB,IAA9BH,EAAcx7B,QAAQ27B,IACxBH,EAAcj5B,KAAKo5B,GAIzB,OAAOH,Ea1iCSE,CAAgBl3B,KAAKmc,QAAQ,IAG7Cnc,KAAKqN,gBAKL,IAAIC,IACFb,cAAezM,KACf0M,iBACAC,eACAC,iBACAC,aAAc7M,KAAKqM,OACnBS,cAAe9M,KAAKmc,QAEpBpP,WAAYiW,EAA2B,KAAMhjB,KAAKqM,OAAOpR,QACzD+R,aAAc,MACdC,YAAajN,KAAKqM,OAAOV,IAAI,SAAAzQ,GAAK,OAAAA,EAAEoI,QACpC4J,aAAclN,KAAKmc,QAAQ,GAAG7Y,YAE3B,CACL,IAAM8kB,EAAejb,EAAMzB,MAAM1L,KAAKmc,QAAQ,IAC9C,GAAI/hB,MAAMC,QAAQ+tB,GAChB,MAAM,IAAI5V,UACN,yHAKNxS,KAAKmc,SAAWiM,GAEhBpoB,KAAKqN,aAAa,GAAGP,cAAgB9M,KAAKmc,QAC1Cnc,KAAKqN,aAAa,GAAGH,cAAgBlN,KAAKmc,QAAQ,GAAG7Y,OAGvDtD,KAAK2c,OAAO5e,KAAKoP,GACjBnN,KAAKgP,OAAQ,GAQf4nB,gBAAA,WACE,GAA2B,IAAvB52B,KAAK2c,OAAO1hB,OACd,MAAM,IAAIuX,UAAU,qCAItB,GADAxS,KAAK2c,OAAO7a,MACe,IAAvB9B,KAAK2c,OAAO1hB,OACd+E,KAAKmc,WACLnc,KAAKqN,gBACLrN,KAAKoN,qBACA,CACL,IAAMgqB,EAAiBp3B,KAAK2c,OAAO1hB,OAAS,EAC5C+E,KAAK2c,OAAOya,GAAgBhqB,iBAC5BpN,KAAKmc,SAAWnc,KAAK2c,OAAOya,GAAgBxmB,QAE5C5Q,KAAKqN,aAAa,GAAGP,cAAgB9M,KAAKmc,QAC1Cnc,KAAKqN,aAAa,GAAGH,cAAgBlN,KAAKmc,QAAQ,GAAG7Y,SAIzDszB,iBAAA,SAAKvqB,EAAyBuD,GAI5B,OAHkB,MAAd5P,KAAK6T,OACP7T,KAAKwQ,QAEAxQ,KAAK6T,MAAMhD,KAAKxE,EAAQuD,IAGjCgnB,kBAAA,SAAMxoB,GAKJ,GAFAipB,GAAmBjpB,GAEQ,IAAvBpO,KAAKqM,OAAOpR,QAAwC,IAAxB+E,KAAKmc,QAAQlhB,OAC3C,MAAM,IAAIuX,UACN,4EAINxS,KAAK6T,MAAQ,IAAI4V,IACfpd,OAAQrM,KAAKqM,OACb8P,QAASnc,KAAKmc,QAAQ,GACtBhhB,KAAM6E,KAAK7E,KAAO,WAEpB6E,KAAK6T,MAAM9I,UAAY/K,KAAK+K,UAC5B/K,KAAK6T,MAAM1F,UAAYnO,KAAKmO,UAG5BnO,KAAK2N,gBAAkB3N,KAAK6T,MAAMlG,gBAElC3N,KAAKqc,YAAcrc,KAAK6T,MAAMwI,YAC9Brc,KAAKsc,uBAAyBtc,KAAK6T,MAAMyI,uBACzCtc,KAAKuc,yBAA2Bvc,KAAK6T,MAAM0I,yBAC3Cvc,KAAKwc,aAAexc,KAAK6T,MAAM2I,aAC/Bxc,KAAKyc,wBAA0Bzc,KAAK6T,MAAM4I,wBAC1Czc,KAAK0c,0BAA4B1c,KAAK6T,MAAM6I,0BAC5C1c,KAAK2e,aAAe3e,KAAK6T,MAAM8K,aAC/B3e,KAAK8d,eAAiB9d,KAAK6T,MAAMiK,eACjC9d,KAAK8c,YAAc9c,KAAK6T,MAAMiJ,YAC9B9c,KAAK6c,WAAa7c,KAAK6T,MAAMgJ,WAG7B7c,KAAKgP,OAAQ,GAGf4nB,wBAAA,WAIE,OAHK52B,KAAKgP,OACRhP,KAAKwQ,QAEAlX,YAAM6hB,wBA+Bfyb,oBAAA,SACIlN,EAAqB7O,EACrBC,gBAAAA,EAEoDxR,QAAQ8N,KACzDpX,KAAKgP,OACRhP,KAAKwQ,QAEPlX,YAAMg+B,kBAAQ5N,EAAY7O,EAAWC,IASvC8b,uBAAA,SAAWnsB,GACS,MAAdzK,KAAK6T,OACP7T,KAAKwQ,QAEPxQ,KAAK6T,MAAMpD,WAAWhG,IAGxBlR,sBAAIq9B,6BAAJ,WACE,OAAO52B,KAAK22B,gBAGd,SAAc39B,GACRgH,KAAKgP,QACPhP,KAAK6T,MAAM1F,UAAYnV,GAEzBgH,KAAK22B,WAAa39B,mCAoCpB49B,qBAAA,SACI17B,EAAoB6J,EACpB/I,GACF,gBADEA,OACGgE,KAAKgP,MACR,MAAM,IAAIlV,EACN,qDAEN,OAAOkG,KAAK6T,MAAM0jB,SAASr8B,EAAG6J,EAAG/I,IA+BnC46B,oBAAA,SAAQ17B,EAAoBc,GAK1B,oBAL0BA,MAER,MAAdgE,KAAK6T,OACP7T,KAAKwQ,QAEAxQ,KAAK6T,MAAM2jB,QAAQt8B,EAAGc,IAU/B46B,2BAAA,SAAe17B,GAIb,OAHkB,MAAd8E,KAAK6T,OACP7T,KAAKwQ,QAEAxQ,KAAK6T,MAAM4jB,eAAev8B,IAQnC07B,oBAAA,SAAQ56B,GACNgE,KAAKwQ,QACLxQ,KAAK6T,MAAM6jB,QAAQ17B,GACnBgE,KAAK4qB,UAAY5qB,KAAK6T,MAAM+W,UAC5B5qB,KAAK2qB,KAAO3qB,KAAK6T,MAAM8W,KACvB3qB,KAAKssB,QAAUtsB,KAAK6T,MAAMyY,QAG1BtsB,KAAKwsB,eAAiBxsB,KAAK6T,MAAM2Y,eACjCxsB,KAAKusB,aAAevsB,KAAK6T,MAAM0Y,cAoC3BqK,gBAAN,SACI17B,EACA6J,EACA/I,uBAAAA,gEACF,IAAKgE,KAAKgP,MACR,MAAM,IAAIlV,EACN,qDAGN,SAAOkG,KAAK6T,MAAM8jB,IAAIz8B,EAAG6J,EAAG/I,SAIvB46B,aAAP,SACIn6B,EACAT,GACF,IAAM6X,EAAQ,IAAIpX,MAClB,KAAMoX,aAAiB+iB,GACrB,MAAM,IAAI78B,EACN,yDAAyD8Z,GAE/D,KAAM7X,aAAkB5B,OACtB,MAAM,IAAIL,EACN,4DAEN,GAA6B,MAAvBiC,EAAO,GAAGF,WAAiD,UAA3BE,EAAO,GAAc,UACzD,MAAM,IAAIjC,EAAW,kDAEvB,IAAmB,QAAA4C,EAAAX,EAAAjB,WAAAA,KAAd,IACGoS,EAAQ6oB,SACdniB,EAAMjO,IAAIuH,GAEZ,OAAO0G,GAMT+iB,sBAAA,WAME,IADA,IAAM56B,SACcW,EAAAqD,KAAK2c,OAAL5hB,WAAAA,KAAf,IAAMoS,OACTnR,EAAO+B,MACLjC,UAAWqR,EAAMpR,eACjBC,OAAQmR,EAAMlR,cAGlB,OAAOD,GA5dF46B,YAAY,gBADWnN,gBCtIVztB,GACpB,OAAO+6B,GAAM/6B,mBDqmBDiE,iBAAiBC,SAAS02B,IE7uBxC,mBAAA,4DAKA,OALyCh9B,OAEvCg+B,sBAAA,WACE,aAHqC34B,gBAAcC,6BAevD,4DAYA,OAZyBtF,OASvBi+B,kBAAA,SAAM38B,EAAW48B,GACf,oBADeA,crBwhBC58B,EAAW48B,GAE7B,gBAF6BA,KAEf,IAAVA,EACF,MAAM,IAAI99B,EACN,0CAA0C89B,+BAGhD,OAAOC,MAAQ78B,GqB9hBN88B,CAAM98B,EAAG48B,IATFD,YAAY,SADLD,oBAaX33B,iBAAiBC,SAAS23B,IASxC,mBAAA,4DAKA,OAL0Bj+B,OAExBq+B,kBAAA,SAAM/8B,GACJ,OAAOg9B,OAASh9B,IAFF+8B,YAAY,UADJL,oBAMZ33B,iBAAiBC,SAAS+3B,IAKxC,mBAAA,4DAKA,OAL0Br+B,OAExBu+B,kBAAA,SAAMj9B,GACJ,OAAOmF,OAASnF,IAFFi9B,YAAY,UADJP,oBAMZ33B,iBAAiBC,SAASi4B,IAKxC,mBAAA,4DAKA,OAL2Bv+B,OAEzBw+B,kBAAA,SAAMl9B,GACJ,OAAO0D,OAAK,WAAM,OAAAy5B,UAAYv4B,EAAU,GAAMO,OAASnF,OAFzCk9B,YAAY,WADHR,oBAMb33B,iBAAiBC,SAASk4B,IAGxC,mBAAA,4DAKA,OAL4Bx+B,OAE1B0+B,kBAAA,SAAMp9B,GACJ,OAAOA,GAFOo9B,YAAY,YADFV,oBAMd33B,iBAAiBC,SAASo4B,IAKxC,mBAAA,4DAKA,OAL6B1+B,OAE3B2+B,kBAAA,SAAMr9B,GACJ,OAAOs9B,UAAYt9B,IAFLq9B,YAAY,aADDX,oBAMf33B,iBAAiBC,SAASq4B,IAKxC,mBAAA,4DAKA,OALiC3+B,OAE/B6+B,kBAAA,SAAMv9B,GACJ,gBrBmhBwBA,GAC1B,OAAO0D,OAAK,WACV,IAAMmG,EAAIlF,MAAQC,EAAU,IAAMH,MAAQG,EAAU,IAAM5E,IAC1D,OAAOwE,cAAgBqF,EAAG,EAAG,KqBthBtB2zB,CAAcx9B,IAFPu9B,YAAY,iBADGb,oBAMnB33B,iBAAiBC,SAASu4B,IAKxC,mBAAA,4DAKA,OAL8B7+B,OAE5B++B,kBAAA,SAAMz9B,GACJ,OAAOqc,WAAarc,IAFNy9B,YAAY,cADAf,oBAMhB33B,iBAAiBC,SAASy4B,IAKxC,mBAAA,4DAKA,OAL8B/+B,OAE5Bg/B,kBAAA,SAAM19B,GACJ,gBrB+cqBA,GACvB,OAAO0D,OAAK,WAAM,OAAAgB,MAAQ1E,EAAG2E,MAAQC,EAAU,GAAIuW,MAAQnb,OqBhdlD29B,CAAW39B,IAFJ09B,YAAY,cADAhB,oBAMhB33B,iBAAiBC,SAAS04B,IAKxC,mBAAA,4DAKA,OAL0Bh/B,OAExBk/B,kBAAA,SAAM59B,GACJ,OAAO69B,OAAS79B,IAFF49B,YAAY,UADJlB,oBAMZ33B,iBAAiBC,SAAS44B,IAKxC,mBAAA,4DAiBA,OAjB6Bl/B,OAc3Bo/B,kBAAA,SAAM99B,EAAWyD,GACf,oBADeA,GAAiB,GACzB+Y,UAAYxc,EAAGyD,IAdRq6B,YAAY,aADDpB,gBAoBOqB,GAClC,OAAOA,EAAWl9B,2BAIhBC,EACAG,GACF,oBADEA,MACK+E,EACHlF,EAAQiD,gBAAcgB,iBAAiBkB,SAASC,aAChDjF,EAAe,0BAGSZ,GAE5B,OAAkB,MAAdA,EAEK29B,IADSp9B,UAAW,SAAUE,YAGb,iBAAfT,EAEF29B,IADSp9B,UAAWP,EAAYS,YAE9BT,aAAsBq8B,GACxBr8B,EAEA29B,GAAsB39B,mBA1BnB0E,iBAAiBC,SAAS84B,ICpIxC,mBAME,WAAYh9B,GAAZ,MACE1C,YAAgB,MAAV0C,KAAsBA,gBAHrBvC,gBAAgB,GAIT,MAAVuC,IACFA,MAGFvC,EAAKq+B,MAAwB,MAAhB97B,EAAO87B,MAAgBr+B,EAAK0/B,cAAgBn9B,EAAO87B,QAkBpE,OA9B+Bl+B,OAe7Bw/B,iBAAA,SAAK/sB,EAAyBuD,GAC5B,IAAM1U,EAAIm+B,GAAoBhtB,GAC9B,OAAOitB,YAAUp+B,EAAG8E,KAAK83B,QAG3BsB,+BAAA,SAAmBhrB,GACjB,OAAOA,GAGTgrB,sBAAA,WACE,IAAMp9B,GAAoC87B,MAAO93B,KAAK83B,OAChDyB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA3BFo9B,YAAY,eADU3qB,oBA+BjBxO,iBAAiBC,SAASk5B,IA6BxC,mBAME,WAAYp9B,GAAZ,MACE1C,YAAgB,MAAV0C,KAAsBA,SAK5B,GAROvC,gBAAgB,EAIT,MAAVuC,IACFA,MAGkB,MAAhBA,EAAO87B,OAAiB97B,EAAO87B,QAAUr+B,EAAK0/B,cAChD,MAAM,IAAIn/B,EACN,4BAA4BgC,EAAO87B,yDAIzCr+B,EAAKq+B,MAAwB,MAAhB97B,EAAO87B,MAAgBr+B,EAAK0/B,cAAgBn9B,EAAO87B,QAkBpE,OApCyBl+B,OAqBvB4/B,iBAAA,SAAKntB,EAAyBuD,GAC5B,IAAM1U,EAAIm+B,GAAoBhtB,GAC9B,OAAOotB,MAAIv+B,IAGbs+B,+BAAA,SAAmBprB,GACjB,OAAOA,GAGTorB,sBAAA,WACE,IAAMx9B,GAAoC87B,MAAO93B,KAAK83B,OAChDyB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAjCFw9B,YAAY,SADI/qB,oBAqCXxO,iBAAiBC,SAASs5B,IA2BxC,mBAOE,WAAYx9B,GAAZ,MACE1C,YAAgB,MAAV0C,KAAsBA,gBAHrBvC,gBAAgB,EAIT,MAAVuC,IACFA,MAGFvC,EAAKigC,MAAwB,MAAhB19B,EAAO09B,MAAgBjgC,EAAKkgC,cAAgB39B,EAAO09B,MAChEjgC,EAAKmgC,YAAc95B,EAAUrG,EAAKigC,SAkBtC,OAhCqC9/B,OAiBnCigC,iBAAA,SAAKxtB,EAAyBuD,GAC5B,IAAM1U,EAAIm+B,GAAoBhtB,GAC9B,OAAOnR,EAAE8L,IAAImgB,GAAKjsB,EAAE4+B,QAAQ95B,KAAK45B,aAAc,aAGjDC,+BAAA,SAAmBzrB,GACjB,OAAOA,GAGTyrB,sBAAA,WACE,IAAM79B,GAAoC09B,MAAO15B,KAAK05B,OAChDH,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA7BF69B,YAAY,qBADgBprB,oBAiCvBxO,iBAAiBC,SAAS25B,IAoBxC,mBAME,WAAY79B,GAAZ,MACE1C,YAAgB,MAAV0C,KAAsBA,gBAHrBvC,eAAe,EAIR,MAAVuC,IACFA,MAEFvC,EAAKsgC,SAAU,IAAIC,IAAoBtuB,MACvCjS,EAAKkF,KAAsB,MAAf3C,EAAO2C,KAAelF,EAAKwgC,aAAej+B,EAAO2C,OAkBjE,OA9B6B/E,OAe3Bo/B,iBAAA,SAAK3sB,EAAyBuD,GAC5B,IAAM1U,EAAIm+B,GAAoBhtB,GAC9B,OAAOrM,KAAK+5B,QAAQ7+B,EAAG8E,KAAKrB,OAG9Bq6B,+BAAA,SAAmB5qB,GACjB,OAAOA,GAGT4qB,sBAAA,WACE,IAAMh9B,GAAoC2C,KAAMqB,KAAKrB,MAC/C46B,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA3BFg9B,YAAY,aADQvqB,oBA+BfxO,iBAAiBC,SAAS84B,ICrOxC,mBAAA,4DAEA,OAF0Cp/B,UAAAqF,gBAAcC,6BAmCtD,WAAYlD,GAAZ,MACE1C,mBAEM4gC,EAAe,MAAVl+B,GAA+B,MAAbA,EAAOk+B,GAAa,IAAOl+B,EAAOk+B,GACzDC,EAAe,MAAVn+B,GAA+B,MAAbA,EAAOm+B,GAAa,IAAOn+B,EAAOm+B,UAC/D1gC,EAAK2gC,MAAe,IAAPF,EACbzgC,EAAK4gC,MAAe,IAAPF,EAEb1gC,EAAKygC,GAAKp6B,EAAUo6B,GACpBzgC,EAAK0gC,GAAKr6B,EAAUq6B,KA8BxB,OA9C0BvgC,OAuBxB0gC,kBAAA,SAAMp/B,GAAN,WACE,OAAO0D,OAAK,WACV,IAAI27B,EAAyB3zB,SAAO,IAQpC,OAPInN,EAAK2gC,QACPG,EAAiB30B,MAAI20B,EAAgBC,MAAI76B,MAAQlG,EAAKygC,GAAIO,MAAIv/B,OAE5DzB,EAAK4gC,QACPE,EACI30B,MAAI20B,EAAgBC,MAAI76B,MAAQlG,EAAK0gC,GAAItkB,GAAS3a,OAEjDq/B,EAAeG,cAI1BJ,sBAAA,WACE,OAAQJ,GAAMl6B,KAAKk6B,GAAGh3B,WAAW,GAAIi3B,GAAMn6B,KAAKm6B,GAAGj3B,WAAW,KAGzDo3B,aAAP,SACI79B,EACAT,GACF,OAAO,IAAIS,GAAKy9B,GAAIl+B,EAAOk+B,GAAcC,GAAIn+B,EAAOm+B,MA3C/CG,YAAY,UADKK,oBA+CZ16B,iBAAiBC,SAASo6B,IA4BjC,IAAMM,IAEPC,KAAQ,oBAGuB75B,GAEnC,OAAOC,EAAqBD,eAI1BhF,EACAG,GACF,oBADEA,MACK+E,EACHlF,EAAQiD,gBAAcgB,iBAAiBkB,SAASC,aAChDjF,EAAe,2BAGUZ,GAG7B,OAAkB,MAAdA,EACK,KAEiB,iBAAfA,EAKFu/B,IADSh/B,UAHEP,KAAcq/B,GAC5BA,GAA2Cr/B,GAC3CA,EACuBS,YAElBT,aAAsBo/B,GACxBp/B,EAEAu/B,GAAuBv/B,eCxI9BvC,EAAwByL,EAAWtJ,GACrC,GAAqB,iBAAVnC,EACT,OAAOy2B,EAAaz2B,EAAOyL,GAE3B,GAAIzL,EAAMiC,SAAWwJ,EACnB,MAAM,IAAI1K,EACN,OAAOoB,kCAAoCsJ,0BACxCzL,EAAMiC,qBAEf,IAAK,IAAIV,EAAI,EAAGA,EAAIkK,IAAKlK,EAAG,CAC1B,IAAMwgC,EAAc/hC,EAAMuB,GAC1B,IzBLoBW,EyBKL6/B,KzBJN/b,SAAS9jB,EAAEvC,WAAY,IyBK9B,MAAM,IAAIoB,EACN,OAAOoB,kCACHsJ,0BACDlI,KAAKC,UAAUxD,sCACf+hC,GAGX,OAAO/hC,MzBbekC,cyB0BtB8/B,EAAqBC,EAAoBC,EACzCC,EAAgBC,GAClB,oBADkBA,KACC,MAAfJ,EACKA,GAKPK,EADc,SAAZH,EACaF,EAEAA,GALSC,GAAcA,EAAa,IAAMG,EAAW,IAKnB,EAE5CzyB,KAAKuhB,OAAOmR,EAAeF,EAAS,GAAKA,IAPhD,IACIE,cAUFC,EAAiBC,EAAoBC,EACrCN,GACF,GAAe,MAAXI,EACF,OAAO,KAGT,GAAgB,UAAZJ,EACFI,EAAUA,EAAUC,EAAazyB,IAAK0yB,EAAaD,EAAY,QAC1D,CAAA,GAAgB,SAAZL,EAGT,MAAM,IAAInhC,EAAW,2BAA2BmhC,OAFhDI,GAAoBC,EAItB,OAAOD,cC7CLpgC,EAAWuK,GAEb,OAAO7G,OAAK,WAEV,OADA8G,EAAgBD,GACG,kBAAfA,EACKg2B,YAAcvgC,GAAI,EAAG,EAAG,EAAG,IAE3BA,IAqQb,mBAwBE,WAAY0I,EAAc5H,GAA1B,MACE1C,YAAM0C,SAGN,GATQvC,OAAsB,KAEvBA,6BAAoD,eACpDA,2BAAkD,QAIzDiiC,EAASC,aAAa3/B,GACtBvC,EAAKmK,KAAOA,EACM,IAAdnK,EAAKmK,MAA4B,IAAdnK,EAAKmK,KAC1B,MAAM,IAAI5J,EACN,iDAAiDP,EAAKmK,kCAqB5D,GAlBAnK,EAAK+hC,WAAaI,GAAe5/B,EAAOw/B,WAAY53B,EAAM,cAC1DnK,EAAKoiC,QAAUD,GACO,MAAlB5/B,EAAO6/B,QAAkB,EAAI7/B,EAAO6/B,QAASj4B,EAAM,WACvDnK,EAAKyhC,QAA4B,MAAlBl/B,EAAOk/B,QAAkB,QAAUl/B,EAAOk/B,QACzDY,EAAiBriC,EAAKyhC,SACtBzhC,EAAKgM,WACoB,MAArBzJ,EAAOyJ,WAAqB,eAAiBzJ,EAAOyJ,WACxDC,EAAgBjM,EAAKgM,YACrBhM,EAAKw/B,WAAa8C,GAAc//B,EAAOi9B,YACvCx/B,EAAKuiC,QAA4B,MAAlBhgC,EAAOggC,SAAyBhgC,EAAOggC,QACtDviC,EAAKwiC,gBACDC,GAAelgC,EAAOigC,iBAAmBxiC,EAAK0iC,0BAClD1iC,EAAK2iC,eAAiBC,EAAcrgC,EAAOogC,gBAC3C3iC,EAAK6iC,gBAAkBC,GAAevgC,EAAOsgC,iBAC7C7iC,EAAKgU,oBAAsB8uB,GAAevgC,EAAOyR,qBACjDhU,EAAK+iC,aAAeZ,GACO,MAAvB5/B,EAAOwgC,aAAuB,EAAIxgC,EAAOwgC,aAAc54B,EACvD,gBACc,IAAdnK,EAAKmK,MACJxJ,MAAMC,QAAQZ,EAAK+iC,eACwB,IAA1C/iC,EAAK+iC,aAA0BvhC,OACnC,MAAM,IAAIlB,EACN,iGAEGwC,KAAKC,UAAU/C,EAAK+iC,eAE7B,GAAkB,IAAd/iC,EAAKmK,KACP,GAAiC,iBAAtBnK,EAAK+iC,aACd/iC,EAAK+iC,cAAgB/iC,EAAK+iC,aAAc/iC,EAAK+iC,mBACxC,GAAiC,IAA7B/iC,EAAK+iC,aAAavhC,OAC3B,MAAM,IAAIlB,EACN,0FAC6BwC,KAAKC,UAAU/C,EAAK+iC,wBAmC7D,OApGuC5iC,OAsEpB8hC,eAAjB,SAA8B1/B,GAI5B,GAFA4gB,EACI,eAAgB5gB,EAAQ,2CACK,iBAAtBA,EAAOw/B,aACbiB,EACGzgC,EAAOw/B,WAAY,SAAU,EAAG,GACtC,MAAM,IAAIzhC,EACN,gGAC+BwC,KAAKC,UAAUR,EAAOw/B,kBAG7DE,sBAAA,WACE,IAAM1/B,GACJw/B,WAAYx7B,KAAKw7B,WACjBK,QAAS77B,KAAK67B,QACdX,QAASl7B,KAAKk7B,QACdz1B,WAAYzF,KAAKyF,WACjB+2B,aAAcx8B,KAAKw8B,aACnBvD,WAAYyD,GAAoB18B,KAAKi5B,YACrC+C,QAASh8B,KAAKg8B,QACdC,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CK,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/C2uB,eAAgBS,EAAoB78B,KAAKo8B,iBAErC7C,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,MAlG4ByS,mBAwHrC,WAAY7K,EAAc5H,GAA1B,MACE1C,YAAMsK,EAAM5H,gBAZJvC,SAAwB,KAahCqjC,EAAKnB,aAAa3/B,GAClBvC,EAAKsjC,QAAU/gC,EAAO+gC,QACtBtjC,EAAKujC,kBAAoBd,GACrBlgC,EAAOghC,mBAAqBvjC,EAAKwjC,4BACrCxjC,EAAKyjC,iBAAmBb,EAAcrgC,EAAOkhC,kBAC7CzjC,EAAK0jC,kBAAoBZ,GAAevgC,EAAOmhC,qBAqGnD,OA1HmCvjC,OAwBjCkjC,kBAAA,SAAM1uB,GACJA,EAAaipB,GAAmBjpB,GAChC,IAAMgvB,EACkB,kBAApBp9B,KAAKyF,WAAiC,EAAI2I,EAAWnT,OAAS,EAClE,GAA+B,MAA3BmT,EAAWgvB,GACb,MAAM,IAAIrjC,EACN,+DACSqU,EAAWgvB,IAE1B,MAAMC,EAAWjvB,EAAWgvB,GAEtBE,EAAct9B,KAAKw7B,WAAWhhC,QAAQ6iC,EAAUr9B,KAAK+8B,UAE3D/8B,KAAKu9B,OAASv9B,KAAKw9B,UACf,SAAUF,EAAa,KAAMt9B,KAAKg9B,kBAClCh9B,KAAKm9B,mBAAmB,EAAMn9B,KAAKk9B,kBACnCl9B,KAAKg8B,UACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASx9B,KAAK+8B,SAAU,KAAM/8B,KAAKi8B,gBACnCj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,iBAGvCp8B,KAAK0N,YAAc1B,KAAMhM,KAAK4D,KAAO,EAAGuI,WAAOxP,EAACygC,GAAcC,OAC9Dr9B,KAAKgP,OAAQ,GAGf8tB,iBAAA,SAAKzwB,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,IAAIud,EADJ9P,EAASgtB,GAAoBhtB,GAE7B,IA/YFnR,EAAWqiC,EAAgB/3B,EAAcq2B,EAAaX,EACtDz1B,EAAyB+2B,EA8YjBiB,EAAyB,MAAbhkC,EAAK+L,KAAe,KAAO/L,EAAK+L,KAAKoG,OAEvD,GAAkB,IAAdnS,EAAKmK,KAjZX1I,EAmZQmR,EAnZGkxB,EAmZK9jC,EAAK8jC,OAAO3xB,OAnZDpG,EAmZSi4B,EAnZK5B,EAmZMpiC,EAAKoiC,QAAQ,GAnZNX,EAoZ9CzhC,EAAKyhC,QAnZbz1B,EAmZsBhM,EAAKgM,WAnZF+2B,EAmZc/iC,EAAK+iC,aAAa,gBApZhBX,kBAAaX,wBAC7BsB,KAiZrBrgB,EAhZCvd,OAAK,WAMV,GALkB,MAAd6G,IACFA,EjCxCG,gBiC0CLC,EAAgBD,GAEO,IAAnBvK,EAAEoI,MAAMrI,OACV,MAAM,IAAIlB,EACN,+DACGmB,EAAEoI,MAAMrI,oBAEjB,GAA4B,IAAxBsiC,EAAOj6B,MAAMrI,OACf,MAAM,IAAIlB,EACN,iEACGwjC,EAAOj6B,MAAMrI,mBAEtB,GAAY,MAARuK,GAAsC,IAAtBA,EAAKlC,MAAMrI,OAC7B,MAAM,IAAIlB,EACN,+DACGwjC,EAAOj6B,MAAMrI,mBAMtB,GAHmB,kBAAfwK,IACFvK,EAAIugC,YAAcvgC,GAAI,EAAG,EAAG,KAEd,WAAZggC,EACF,MAAM,IAAIlhC,EACN,iFAGN,IAAI+K,EAAY24B,SACZxiC,EAA0BqiC,EAAoB1B,EAClC,SAAZX,EAAqB,OAAS,QAAS,MAAOsB,GAIlD,OAHY,MAARh3B,IACFT,EAAI44B,GAAU54B,EAAGS,IAEZT,SA+WE,GAAkB,IAAdtL,EAAKmK,KAEduY,WA7TJjhB,EAAWqiC,EAAgB/3B,EAAcq2B,EACzCX,EAAmBz1B,EACnB+2B,GACF,oBAH2CX,GAAW,EAAG,iBACvDX,WAEKt8B,OAAK,WAKV,GAJkB,MAAd6G,IACFA,EjCnIG,gBiCqILC,EAAgBD,GACD,IAAXvK,EAAE0I,MAAyB,IAAX1I,EAAE0I,KACpB,MAAM,IAAI7J,EACN,mEACGmB,EAAE0I,UAEX,GAAoB,IAAhB25B,EAAO35B,MAA8B,IAAhB25B,EAAO35B,KAC9B,MAAM,IAAI7J,EACN,oEACGmB,EAAE0I,UAEX,IAAImB,EAAI64B,GAAsB1iC,EAAGuK,GACjC,GAAgB,WAAZy1B,EACF,MAAM,IAAIlhC,EACN,iFAaN,OAVA+K,EAAI84B,SACA94B,EAA0Bw4B,EAC1B1B,EAAyC,SAAZX,EAAqB,OAAS,QAC3D,OAAQsB,GACA,MAARh3B,IACFT,EAAI44B,GAAU54B,EAAGS,IAEA,kBAAfC,IACFV,EAAI02B,YAAc12B,GAAI,EAAG,EAAG,EAAG,KAE1BA,IA2RO+4B,CACNzxB,EAAQ5S,EAAK8jC,OAAO3xB,OAAQ6xB,EAAWhkC,EAAKoiC,QAASpiC,EAAKyhC,QAC1DzhC,EAAKgM,WAAYhM,EAAK+iC,mBACrB,GAAkB,IAAd/iC,EAAKmK,KACd,MAAM,IAAI5J,EAAoB,0CAMhC,OAHuB,MAAnBP,EAAKw/B,aACP9c,EAAU1iB,EAAKw/B,WAAWvtB,MAAMyQ,IAE3BA,KAIX2gB,+BAAA,SAAmB1uB,GACjBA,EAAaipB,GAAmBjpB,GAKhC,IAJA,IAAM2vB,KACAC,EAA6B,iBAApBh+B,KAAKyF,WAChB2I,EAAW7K,MAAM,EAAG6K,EAAWnT,OAAS,GACxCmT,EAAW7K,MAAM,GACZhJ,EAAI,EAAGA,EAAIyjC,EAAM/iC,SAAUV,EAAG,CACrC,IAAM0jC,EAASC,GACXF,EAAMzjC,GAAIyF,KAAKw7B,WAAWjhC,GAAIyF,KAAKk7B,QAASl7B,KAAK67B,QAAQthC,GAC5B,iBAAtByF,KAAKw8B,aAA4Bx8B,KAAKw8B,aACLx8B,KAAKw8B,aAAajiC,IAC9DwjC,EAAShgC,KAAKkgC,GAGhB,IAAIhtB,GAAe7C,EAAW,IAQ9B,MAPwB,iBAApBpO,KAAKyF,YACPwL,EAAcA,EAAYzW,OAAOujC,IACrBhgC,KAAKiC,KAAK+8B,UAEtB9rB,EAAYlT,KAAKiC,KAAK+8B,SACtB9rB,EAAcA,EAAYzW,OAAOujC,IAE5B9sB,GAGT6rB,sBAAA,WACE,IAAM9gC,GACJ+gC,QAAS/8B,KAAK+8B,QACdC,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CG,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7CD,iBAAkBL,EAAoB78B,KAAKk9B,mBAEvC3D,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGQ8gC,eAAjB,SAA8B9gC,GAE5B,KAAM,YAAaA,IAAqC,iBAAnBA,EAAO+gC,SACxC/gC,EAAO+gC,QAAU,EACnB,MAAM,IAAIhjC,EACN,0EACWwC,KAAKC,UAAUR,EAAO+gC,cAvHRrB,mBA+IjC,WAAY1/B,GAAZ,MACE1C,YAAM,EAAG0C,gBACTmiC,EAAOxC,aAAa3/B,KAkBxB,OAtB4BpC,OAO1BukC,sBAAA,WACE,IAAMniC,EAAS1C,YAAM2C,qBAErB,cADOD,EAAa,KACbA,GAGQmiC,eAAjB,SAA8BniC,GAE5B,GAAkC,iBAAtBA,EAAOw/B,aACdiB,EACGzgC,EAAOw/B,WAAY,SAAU,EAAG,GACtC,MAAM,IAAIzhC,EACN,8FAC+BwC,KAAKC,UAAUR,EAAOw/B,kBAnBtD2C,YAAY,YADOrB,oBAuBd78B,iBAAiBC,SAASi+B,IAmCxC,mBAIE,WAAYniC,GAAZ,MACE1C,YAAM0C,SAGN,GAFAvC,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,KAElB,SAAjBvS,EAAKyhC,SAAuC,UAAjBzhC,EAAKyhC,QAClC,MAAM,IAAInhC,EACN,uGAC0CN,EAAKyhC,kBAsIzD,OAjJqCthC,OAenCykC,kBAAA,SAAMjwB,GAGJ,GAA0B,KAF1BA,EAAaipB,GAAmBjpB,IAEjBnT,OACb,MAAM,IAAIlB,EACN,mDACAwC,KAAKC,UAAU4R,IAGrB,IAAMgvB,EACkB,kBAApBp9B,KAAKyF,WAAiC,EAAI2I,EAAWnT,OAAS,EAClE,GAA+B,MAA3BmT,EAAWgvB,GACb,MAAM,IAAIrjC,EACN,wEAGN,MAAMsjC,EAAWjvB,EAAWgvB,GACtBE,EAAct9B,KAAKw7B,WAAWhhC,QAAQwF,KAAK+8B,QAASM,IAE1Dr9B,KAAKu9B,OAASv9B,KAAKw9B,UACf,SAAUF,EAAa,UAAWt9B,KAAKg9B,kBACvCh9B,KAAKm9B,mBAAmB,EAAMn9B,KAAKk9B,kBACnCl9B,KAAKg8B,UACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASx9B,KAAK+8B,SAAU,UAAW/8B,KAAKi8B,gBACxCj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,iBAIvCp8B,KAAK0N,WACA,IAAI0wB,IAAWpyB,KAAM,EAAGG,WAAOxP,EAACygC,GAAcC,QACnDr9B,KAAKgP,OAAQ,GAGfqvB,iBAAA,SAAKhyB,EAAyBuD,GAA9B,WACE,OAAO0Z,OAAS,WACd,IAAI8F,EAAQiK,GAAoBhtB,GAChC,GAA2B,IAAvB+iB,EAAM9rB,MAAMrI,OACd,MAAM,IAAIlB,EACN,2FAC6Bq1B,EAAM9rB,MAAMrI,QAG/C,IAGIqjC,EACAC,EAJEnwB,EAAaghB,EAAM9rB,MACnBgL,EAAYF,EAAW,GAIL,kBAApB3U,EAAKgM,YACP64B,EAAQ,EACRC,EAAQ,IAERD,EAAQ,EACRC,EAAQ,GAGV,IAAMC,EAASpwB,EAAWkwB,GACpBG,EAAQrwB,EAAWmwB,GACnBG,EAAUjlC,EAAK+hC,WAAW,GAC1BmD,EAAUllC,EAAK+hC,WAAW,GAC1BoD,EAAUnlC,EAAKoiC,QAAQ,GACvBgD,EAAUplC,EAAKoiC,QAAQ,GAUvB5qB,GACD3C,EARawwB,GAAaN,EAAQI,EAASF,EAASjlC,EAAKyhC,SAC7C4D,GAAaL,EAAOI,EAASF,EAASllC,EAAKyhC,SAOvBzhC,EAAKsjC,SAElB,iBAApBtjC,EAAKgM,aACP2pB,EAAQqM,YAAcrM,GAAQ,EAAG,EAAG,EAAG,KAEzC,IAAIjT,EAAU4iB,kBACV3P,EAAmB31B,EAAK8jC,OAAO3xB,OAAoBqF,EACnDxX,EAAKoiC,QAA6BpiC,EAAKyhC,SAY3C,MAXwB,iBAApBzhC,EAAKgM,aACP0W,EAAUsf,YAActf,GAAU,EAAG,EAAG,EAAG,KAG5B,MAAb1iB,EAAK+L,OACP2W,EACIwhB,GAAUxhB,EAAS1iB,EAAK+L,KAAKoG,OAAQnS,EAAKgM,aAEzB,MAAnBhM,EAAKw/B,aACP9c,EAAU1iB,EAAKw/B,WAAWvtB,MAAMyQ,IAE3BA,KAIXkiB,+BAAA,SAAmBjwB,GAEjB,IAEIgvB,EACA4B,EACAC,EAJEhuB,GADN7C,EAAaipB,GAAmBjpB,IACD7K,QAKP,kBAApBvD,KAAKyF,YACP23B,EAAc,EACd4B,EAAa,EACbC,EAAY,IAEZ7B,EAAc,EACd4B,EAAa,EACbC,EAAY,GAGd,IAAMP,EAAU1+B,KAAKw7B,WAAW,GAC1BmD,EAAU3+B,KAAKw7B,WAAW,GAC1BoD,EAAU5+B,KAAK67B,QAAQ,GACvBgD,EAAU7+B,KAAK67B,QAAQ,GAO7B,OALA5qB,EAAYmsB,GAAep9B,KAAK+8B,QAChC9rB,EAAY+tB,GACRF,GAAa7tB,EAAY+tB,GAAaJ,EAASF,EAAS1+B,KAAKk7B,SACjEjqB,EAAYguB,GACRH,GAAa7tB,EAAYguB,GAAYJ,EAASF,EAAS3+B,KAAKk7B,SACzDjqB,GAGTotB,sBAAA,WACE,IAAMriC,EAAS1C,YAAM2C,qBAErB,cADOD,EAAqB,aACrBA,GA9IFqiC,YAAY,qBADgBF,oBAkJvBl+B,iBAAiBC,SAASm+B,IA4CxC,mBA2LE,WAAYriC,UACV1C,YAAM,EAAG0C,SAEb,OALqCpC,OAC5BslC,YAAY,iCAtKnB,WAAYt7B,EAAc5H,GAA1B,MACE1C,YAAMsK,EAAM5H,SAEZ,GAXOvC,gCACL,gBACKA,gCACL,gBAEMA,kBAAiC,KACjCA,kBAAiC,KAKnB,MAAlBuC,EAAO+gC,QACT,MAAM,IAAIhjC,EACN,uFAGN,GAAgC,MAA5BiC,EAAOghC,mBAAyD,MAA5BhhC,EAAOmhC,mBAChB,MAA3BnhC,EAAOkhC,iBACT,MAAM,IAAInjC,EACN,sPAKN,GAAsB,MAAlBiC,EAAOk/B,SAAsC,SAAnBl/B,EAAOk/B,SACd,UAAnBl/B,EAAOk/B,QACT,MAAM,IAAInhC,EACN,gBAAgBN,EAAKmK,wEACerH,KAAKC,UAAUR,EAAOk/B,iBAGhEzhC,EAAK0lC,gBACyB,MAA1BnjC,EAAOmjC,gBAA0B,EAAInjC,EAAOmjC,gBAChD1lC,EAAK2lC,qBAAuBlD,GACxBlgC,EAAOojC,sBAAwB3lC,EAAK4lC,+BACxC5lC,EAAK6lC,qBAAuB/C,GAAevgC,EAAOsjC,sBAClD7lC,EAAK8lC,oBAAsBlD,EAAcrgC,EAAOujC,qBAChD9lC,EAAK+lC,qBAAuBtD,GACxBlgC,EAAOojC,sBAAwB3lC,EAAKgmC,+BACxChmC,EAAKimC,qBAAuBnD,GAAevgC,EAAO0jC,sBAClDjmC,EAAKkmC,oBAAsBtD,EAAcrgC,EAAO2jC,uBAwGpD,OA5JmC/lC,OAuDjCgmC,kBAAA,SAAMxxB,GAEJ,IADAA,EAAaipB,GAAmBjpB,IACjBnT,OAAS+E,KAAK4D,KAAO,EAClC,MAAM,IAAI7J,EACN,0BAA0BiG,KAAK4D,4BAC5B5D,KAAK4D,KAAO,kCACZrH,KAAKC,UAAU4R,IAExB,IAAMgvB,EACkB,kBAApBp9B,KAAKyF,WAAiC,EAAI2I,EAAWnT,OAAS,EAClE,GAA+B,MAA3BmT,EAAWgvB,IAAwBhvB,EAAWgvB,GAAe,EAC/D,MAAM,IAAIrjC,EACN,oEACawC,KAAKC,UAAU4R,EAAWgvB,KAO7C,IAJA,IAAMC,EAAWjvB,EAAWgvB,GACtByC,EACF7/B,KAAKw7B,WAAWhhC,QAAQ6iC,EAAUr9B,KAAKm/B,kBACrCW,KACGvlC,EAAI,EAAGA,EAAIyF,KAAK4D,OAAQrJ,EAC/BulC,EAAqB/hC,KAAK,GAE5B+hC,EAAqB/hC,KAAKs/B,EAAWr9B,KAAKm/B,gBAAiBn/B,KAAK+8B,SAEhE,MACA/8B,KAAK+/B,gBAAkB//B,KAAKw9B,UACxB,mBAAoBqC,EAAsB,UAC1C7/B,KAAKo/B,qBAAsBp/B,KAAKs/B,sBAHlB,EAIdt/B,KAAKu/B,qBACTv/B,KAAKggC,gBAAkBhgC,KAAKw9B,UACxB,mBAAoBsC,EAAsB,UAC1C9/B,KAAKw/B,qBAAsBx/B,KAAK0/B,sBAPlB,EAQd1/B,KAAK2/B,qBACL3/B,KAAKg8B,QACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASx9B,KAAK+8B,SAAU,UAAW/8B,KAAKi8B,gBACxCj8B,KAAKs8B,iBAZO,EAYqBt8B,KAAKo8B,gBAE1Cp8B,KAAKwF,KAAO,KAGdxF,KAAK0N,WACA,IAAI0wB,IAAWpyB,KAAMhM,KAAK4D,KAAO,EAAGuI,WAAOxP,EAACygC,GAAcC,QAC/Dr9B,KAAKgP,OAAQ,GAGf4wB,iBAAA,SAAKvzB,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAGV,IAAIgS,EACJ,GAHAvE,EAASgtB,GAAoBhtB,GAGX,IAAd5S,EAAKmK,KACP,MAAM,IAAI5J,EACN,oDAuBN,OAtByB,IAAdP,EAAKmK,OACU,kBAApBnK,EAAKgM,aACP4G,EAASovB,YAAcpvB,GAAS,EAAG,EAAG,EAAG,KAG3CuE,EAASqvB,kBACL5zB,EAAoB5S,EAAKsmC,gBAAgBn0B,OACzCnS,EAAKumC,gBAAgBp0B,OACrBnS,EAAKoiC,QAA6BpiC,EAAKyhC,QACvCzhC,EAAK+iC,aAAkC,SAGzC/iC,EAAKuiC,UACPprB,EAAS+sB,GAAU/sB,EAAQnX,EAAK+L,KAAKoG,OAAQnS,EAAKgM,aAE7B,MAAnBhM,EAAKw/B,aACProB,EAASnX,EAAKw/B,WAAWvtB,MAAMkF,IAGT,kBAApBnX,EAAKgM,aACPmL,EAAS6qB,YAAc7qB,GAAS,EAAG,EAAG,EAAG,KAEpCA,KAIXgvB,sBAAA,WACE,IAAM5jC,EAAS1C,YAAM2C,qBAiBrB,cAhBOD,EAAa,YACbA,EAA0B,yBAC1BA,EAA0B,yBAC1BA,EAAyB,iBAChCA,EAA6B,qBACzB2gC,GAAqB38B,KAAKo/B,sBAC9BpjC,EAA6B,qBACzB2gC,GAAqB38B,KAAKw/B,sBAC9BxjC,EAA6B,qBACzB4gC,GAAqB58B,KAAKs/B,sBAC9BtjC,EAA6B,qBACzB4gC,GAAqB58B,KAAK0/B,sBAC9B1jC,EAA4B,oBACxB6gC,EAAoB78B,KAAKu/B,qBAC7BvjC,EAA4B,oBACxB6gC,EAAoB78B,KAAK2/B,qBACtB3jC,GAzJF4jC,YAAY,mBADc9C,qBA+LrB78B,iBAAiBC,SAASg/B,IAoBxC,mBAEE,WAAYljC,GAAZ,MACE1C,YAAM,EAAG0C,gBACTkkC,EAAOvE,aAAa3/B,GACpBvC,EAAKiU,YAAc1B,KAAM,MAmB7B,OAxB4BpS,OAQ1BsmC,sBAAA,WACE,IAAMlkC,EAAS1C,YAAM2C,qBAGrB,cAFOD,EAAa,YACbA,EAAmB,WACnBA,GAGFkkC,eAAP,SAAoBlkC,GAElB,GAAiC,iBAAtBA,EAAOw/B,aACbiB,EACGzgC,EAAOw/B,WAAY,SAAU,EAAG,GACtC,MAAM,IAAIzhC,EACN,yFAC0BwC,KAAKC,UAAUR,EAAOw/B,kBArBjD0E,YAAY,YADOpD,oBAyBd78B,iBAAiBC,SAASggC,IA6DxC,mBAKE,WAAYlkC,GAAZ,MACE1C,YAAM0C,eACyB,iBAApBA,EAAOmkC,SAChB1mC,EAAK0mC,WACFnkC,EAAOmkC,SAAUnkC,EAAOmkC,WAAYnkC,EAAOmkC,SAAUnkC,EAAOmkC,WAE1B,iBAAvBnkC,EAAOmkC,SAAS,GAC9B1mC,EAAK0mC,WACFnkC,EAAOmkC,SAAS,GAAcnkC,EAAOmkC,SAAS,KAC9CnkC,EAAOmkC,SAAS,GAAcnkC,EAAOmkC,SAAS,KAGjD1mC,EAAK0mC,SAAWnkC,EAAOmkC,SACzB1mC,EAAKgM,gBACqBvM,IAAtB8C,EAAOyJ,WAA2B,eAAiBzJ,EAAOyJ,WAC9DhM,EAAKiU,YAAc1B,KAAM,MA8C7B,OAlEgCpS,OAuB9BwmC,+BAAA,SAAmBhyB,GACjB,MAAwB,kBAApBpO,KAAKyF,YAEL2I,EAAW,GAAIA,EAAW,GAC1BA,EAAW,GAAKpO,KAAKmgC,SAAS,GAAG,GAAKngC,KAAKmgC,SAAS,GAAG,GACvD/xB,EAAW,GAAKpO,KAAKmgC,SAAS,GAAG,GAAKngC,KAAKmgC,SAAS,GAAG,KAIvD/xB,EAAW,GACXA,EAAW,GAAKpO,KAAKmgC,SAAS,GAAG,GAAKngC,KAAKmgC,SAAS,GAAG,GACvD/xB,EAAW,GAAKpO,KAAKmgC,SAAS,GAAG,GAAKngC,KAAKmgC,SAAS,GAAG,GAAI/xB,EAAW,KAI5EgyB,iBAAA,SAAK/zB,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAGV,OAFAyN,EAASgtB,GAAoBhtB,GAEL,iBAApB5S,EAAKgM,WAIA46B,GAHSA,GACZh0B,EAAQ5S,EAAK0mC,SAAS,GAAG,GACzB9zB,EAAO/I,MAAM,GAAK7J,EAAK0mC,SAAS,GAAG,GAAK1mC,EAAK0mC,SAAS,GAAG,GAAI,GAEpD1mC,EAAK0mC,SAAS,GAAG,GAC1B9zB,EAAO/I,MAAM,GAAK7J,EAAK0mC,SAAS,GAAG,GAAK1mC,EAAK0mC,SAAS,GAAG,GAAI,GAK1DE,GAHSA,GACZh0B,EAAQ5S,EAAK0mC,SAAS,GAAG,GACzB9zB,EAAO/I,MAAM,GAAK7J,EAAK0mC,SAAS,GAAG,GAAK1mC,EAAK0mC,SAAS,GAAG,GAAI,GAEpD1mC,EAAK0mC,SAAS,GAAG,GAC1B9zB,EAAO/I,MAAM,GAAK7J,EAAK0mC,SAAS,GAAG,GAAK1mC,EAAK0mC,SAAS,GAAG,GAAI,MAKvEC,sBAAA,WACE,IAAMpkC,GAAUmkC,SAAUngC,KAAKmgC,SAAU16B,WAAYzF,KAAKyF,YACpD8zB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA/DFokC,YAAY,gBADW3xB,oBAmElBxO,iBAAiBC,SAASkgC,IA8CxC,mBAME,WAAYpkC,GAAZ,MACE1C,YAAM0C,gBALWvC,gBAAgB,EAAG,GAMpCA,EAAKiU,YAAc1B,KAAM,IACzBvS,EAAKkK,KAAsB,MAAf3H,EAAO2H,KAAelK,EAAK6mC,aAAetkC,EAAO2H,KAC7DlK,EAAKgM,WACoB,MAArBzJ,EAAOyJ,WAAqB,eAAiBzJ,EAAOyJ,aA0C5D,OArDkC7L,OAchC2mC,+BAAA,SAAmBnyB,GACjB,GAAwB,kBAApBpO,KAAKyF,WAAgC,CACvC,IAAM+4B,EACe,MAAjBpwB,EAAW,GAAa,KAAOpO,KAAK2D,KAAK,GAAKyK,EAAW,GACvDqwB,EAAyB,MAAjBrwB,EAAW,GAAa,KAAOpO,KAAK2D,KAAK,GAAKyK,EAAW,GACvE,OAAQA,EAAW,GAAIA,EAAW,GAAIowB,EAAQC,GAExCD,EACe,MAAjBpwB,EAAW,GAAa,KAAOpO,KAAK2D,KAAK,GAAKyK,EAAW,GACvDqwB,EAAyB,MAAjBrwB,EAAW,GAAa,KAAOpO,KAAK2D,KAAK,GAAKyK,EAAW,GACvE,OAAQA,EAAW,GAAIowB,EAAQC,EAAOrwB,EAAW,KAIrDmyB,iBAAA,SAAKl0B,EAAyBuD,GAA9B,WACE,OAAO0Z,OAAS,WACd,IAAI8F,EAAQiK,GAAoBhtB,GAC1B+B,EAAaghB,EAAM9rB,MAEzB,GAAwB,kBAApB7J,EAAKgM,WAAgC,CACvC2pB,EAAQqM,YAAcrM,GAAQ,EAAG,EAAG,EAAG,IACvC,IAAMoP,EAAS/kC,EAAKkK,KAAK,GAAKyK,EAAW,GACnCqwB,EAAQhlC,EAAKkK,KAAK,GAAKyK,EAAW,GAClCoyB,EAAUpR,EAAMqR,uBAAuBjC,EAAQC,IACrD,OAAOhD,YAAc+E,GAAU,EAAG,EAAG,EAAG,IAElChC,EAAS/kC,EAAKkK,KAAK,GAAKyK,EAAW,GACnCqwB,EAAQhlC,EAAKkK,KAAK,GAAKyK,EAAW,GACxC,OAAOghB,EAAMqR,uBAAuBjC,EAAQC,OAKlD8B,sBAAA,WACE,IAAMvkC,GAAU2H,KAAM3D,KAAK2D,KAAM8B,WAAYzF,KAAKyF,YAC5C8zB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAlDFukC,YAAY,kBADa9xB,oBAsDpBxO,iBAAiBC,SAASqgC,IC5nCxC,mBASE,WAAYvkC,GAAZ,MACE1C,YAAM,EAAG0C,gBAHHvC,kBAAiC,KAIvCA,EAAK0lC,gBACyB,MAA1BnjC,EAAOmjC,gBAA0B,EAAInjC,EAAOmjC,gBAChD1lC,EAAK2lC,qBAAuBlD,GACxBlgC,EAAOojC,sBAAwB3lC,EAAKwjC,4BACxCxjC,EAAK8lC,oBAAsBlD,EAAcrgC,EAAOujC,qBAChD9lC,EAAK6lC,qBAAuB/C,GAAevgC,EAAOsjC,wBAoFtD,OApGqC1lC,OAmBnC8mC,kBAAA,SAAMtyB,GAEJ,IADAA,EAAaipB,GAAmBjpB,IACjBnT,OAAS,EACtB,MAAM,IAAIlB,EACN,uEACyBwC,KAAKC,UAAU4R,QAE9C,IAAMgvB,EAAkC,kBAApBp9B,KAAKyF,WAAiC,EAAI,EAC9D,GAA+B,MAA3B2I,EAAWgvB,IAAwBhvB,EAAWgvB,GAAe,EAC/D,MAAM,IAAIrjC,EACN,yFAC2BqU,EAAWgvB,SAE5C,IAAMC,EAAWjvB,EAAWgvB,GACtByC,GACJ7/B,KAAKw7B,WAAW,GAAIx7B,KAAKw7B,WAAW,GAAI6B,EAAUr9B,KAAKm/B,iBAGzDn/B,KAAK+/B,gBAAkB//B,KAAKw9B,UACxB,mBAAoBqC,EAAsB,KAC1C7/B,KAAKo/B,qBAAsBp/B,KAAKs/B,sBAAsB,EACtDt/B,KAAKu/B,qBACLv/B,KAAKg8B,QACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASH,EAAWr9B,KAAKm/B,iBAAkB,KAAMn/B,KAAKi8B,gBACtDj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,gBAErCp8B,KAAKwF,KAAO,KAEdxF,KAAKgP,OAAQ,GAGf0xB,iBAAA,SAAKr0B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVyN,EAASgtB,GAAoBhtB,GAC7B,IA7HFnR,EAAW6kC,EAAyBlE,EACpCX,EAAmBz1B,EACnB+2B,EA2HMrgB,GA7HNjhB,EA8HMmR,EA9HK0zB,EA8HGtmC,EAAKsmC,gBAAgBn0B,OA9HCiwB,EA8HOpiC,EAAKoiC,QA7HhDX,EA8HMzhC,EAAKyhC,QA9HQz1B,EA8HChM,EAAKgM,WA7HzB+2B,EA6HqC,kBA/HDX,GAA6B,EAAG,iBACpEX,WAEKt8B,OAAK,WACQ,MAAd6G,IACFA,ElCpBG,gBkCsBLC,EAAgBD,GAChB,IAAIV,EAAI64B,GAAsB1iC,EAAGuK,GACjC,GAAe,IAAXvK,EAAE0I,KACJ,MAAM,IAAI7J,EACN,mEACGmB,EAAE0I,WAEX,GAA6B,IAAzBm8B,EAAgBn8B,KAClB,MAAM,IAAI7J,EACN,yDACGgmC,EAAgBn8B,WAQzB,OANAmB,EAAI47B,kBACA57B,EAAeg7B,EAA6BlE,EAChC,SAAZX,EAAqB,OAAS,QAAS,OAAQsB,GAChC,kBAAf/2B,IACFV,EAAI02B,YAAc12B,GAAI,EAAG,EAAG,EAAG,KAE1BA,KA8GL,OANItL,EAAKuiC,UACP7f,EAAUwhB,GAAUxhB,EAAS1iB,EAAK+L,KAAKoG,OAAQnS,EAAKgM,aAE/B,MAAnBhM,EAAKw/B,aACP9c,EAAU1iB,EAAKw/B,WAAWvtB,MAAMyQ,IAE3BA,KAIXukB,+BAAA,SAAmBtyB,GACjBA,EAAaipB,GAAmBjpB,GAChC,IAAMwyB,EACkB,kBAApB5gC,KAAKyF,WAAiC2I,EAAW,GAAKA,EAAW,GAC/DyyB,EACkB,kBAApB7gC,KAAKyF,WAAiC2I,EAAW,GAAKA,EAAW,GAC/D0yB,EAAiC,kBAApB9gC,KAAKyF,WACpB2I,EAAW,GAAKpO,KAAKm/B,gBACrB/wB,EAAW,GAAKpO,KAAKm/B,gBACnB4B,EAAU7C,GACZ0C,EAAM5gC,KAAKw7B,WAAW,GAAIx7B,KAAKk7B,QAASl7B,KAAK67B,QAAQ,IACnDmF,EAAU9C,GACZ2C,EAAM7gC,KAAKw7B,WAAW,GAAIx7B,KAAKk7B,QAASl7B,KAAK67B,QAAQ,IACzD,MAAwB,kBAApB77B,KAAKyF,YACC2I,EAAW,GAAI0yB,EAAYC,EAASC,IAGpC5yB,EAAW,GAAI2yB,EAASC,EAASF,IAI7CJ,sBAAA,WACE,IAAM1kC,EAAS1C,YAAM2C,qBAQrB,OAPAD,EAAwB,gBAAIgE,KAAKm/B,gBACjCnjC,EAA6B,qBACzB2gC,GAAqB38B,KAAKo/B,sBAC9BpjC,EAA6B,qBACzB4gC,GAAqB58B,KAAKs/B,sBAC9BtjC,EAA4B,oBACxB6gC,EAAoB78B,KAAKs/B,sBACtBtjC,GAjGF0kC,YAAY,qBADgBhF,oBAqGvBz7B,iBAAiBC,SAASwgC,IClKxC,mBAOE,WAAY1kC,GAAZ,MACE1C,YAAM0C,SAMN,GALAvC,EAAK+G,KAAOmI,KAAKG,IAAIH,KAAKs4B,IAAIjlC,EAAOwE,KAAM,GAAI,GAC/C/G,EAAKynC,WAAaphC,EAAUrG,EAAK+G,MAEjC/G,EAAKqM,WAAa9J,EAAO8J,WACzBrM,EAAKoL,KAAO7I,EAAO6I,KACF,MAAbpL,EAAKoL,KACP,MAAM,IAAI7K,EACN,6DACAP,EAAKoL,aAEXpL,EAAKkU,iBAAkB,IAkD3B,OArE6B/T,OAsBnBunC,0BAAR,SAAsB/R,GACpB,GAAuB,MAAnBpvB,KAAK8F,WACP,OAAO9F,KAAK8F,WAId,IAFA,IAAMsI,EAAaghB,EAAM9rB,MACnBwC,KACGvL,EAAI,EAAGA,EAAIyF,KAAK8F,WAAW7K,SAAUV,EAC5CuL,EAAW/H,KACe,MAAtBiC,KAAK8F,WAAWvL,GAAa6T,EAAW7T,GAAKyF,KAAK8F,WAAWvL,IAEnE,OAAOuL,GAGTq7B,iBAAA,SAAK90B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAC5B,IAAMwf,EAAQiK,GAAoBhtB,GAClC,GAAuB,MAAnB5S,EAAKqM,aACJC,OAAKC,YAAYopB,EAAM9rB,MAAO7J,EAAKqM,YACtC,MAAM,IAAI9L,EACN,oEACgBuC,KAAKC,UAAU/C,EAAKqM,aAE1C,GAAI,EAAIrM,EAAK+G,MAAQ/G,EAAK+G,KAAO,EAAG,CAClC,IAAM+F,EACoB,MAAtBqJ,EAAiB,UAAoBA,EAAiB,SACpDyxB,EAAa5nC,EAAK6nC,cAAclS,GAKtC,OAHImS,GACI,WAAM,OAAAC,GAAUpS,EAAO31B,EAAKynC,WAAYG,EAAY5nC,EAAKoL,OACzD,WAAM,OAAAuqB,GAAO7oB,GAGvB,OAAO8F,KAIX80B,sBAAA,WACE,IAAMnlC,GACJwE,KAAMR,KAAKQ,KACXsF,WAAY9F,KAAK8F,WACjBjB,KAAM7E,KAAK6E,MAEP00B,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAlEFmlC,YAAY,aADQ1yB,oBAsEfxO,iBAAiBC,SAASihC,IAmFxC,mBAkBE,WAAYnlC,GAAZ,MACE1C,YAAM0C,SACN,GAhBMvC,aAA2B,KAC3BA,WAAU,EAGVA,SAAwB,KACxBA,OAAsB,KAErBA,6BAAoD,eACpDA,2BAAkD,QAQ3B,MAA1BuC,EAAOqS,iBAAgD,MAArBrS,EAAOoS,YACtB,MAAnBpS,EAAOqhC,SAAkB,CAG3B,IAAI/uB,EAAoB,KACA,MAApBtS,EAAOsS,YACTA,EAAYtS,EAAOsS,WAErB7U,EAAK4U,iBAAmBC,EAAWtS,EAAOqhC,iBAG5C5jC,EAAKgoC,MAAQzlC,EAAOylC,MACpBhoC,EAAKw/B,WAAa8C,GAAc//B,EAAOi9B,YACjB,MAAlBj9B,EAAOggC,UACTviC,EAAKuiC,QAAUhgC,EAAOggC,SAExBviC,EAAKujC,kBAAoBd,GACrBlgC,EAAOghC,mBAAqBvjC,EAAKwjC,4BACrCxjC,EAAKwiC,gBACDC,GAAelgC,EAAOigC,iBAAmBxiC,EAAK0iC,0BAClD1iC,EAAKyjC,iBAAmBb,EAAcrgC,EAAOkhC,kBAC7CzjC,EAAK2iC,eAAiBC,EAAcrgC,EAAOogC,gBAC3C3iC,EAAK0jC,kBAAoBZ,GAAevgC,EAAOmhC,mBAC/C1jC,EAAK6iC,gBAAkBC,GAAevgC,EAAOsgC,iBAC7C7iC,EAAKgU,oBAAsB8uB,GAAevgC,EAAOyR,qBAEjDhU,EAAKiU,YAAcxB,QAAS,MA6DhC,OA3G2BtS,OAiDlB8nC,kBAAP,SAAatzB,GAEX,MAAMuzB,GADNvzB,EAAaipB,GAAmBjpB,IACAA,EAAWnT,OAAS,GACjC,MAAf+E,KAAKu9B,SACPv9B,KAAKu9B,OAASv9B,KAAKw9B,UACf,UAAWmE,EAAc3hC,KAAKyhC,OAAQ,KAAMzhC,KAAKg9B,kBACjDh9B,KAAKm9B,mBAAmB,EAAMn9B,KAAKk9B,kBACnCl9B,KAAKg8B,UACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASx9B,KAAKyhC,OAAQ,KAAMzhC,KAAKi8B,gBACjCj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,kBAIzCp8B,KAAK0N,YAAcxB,QAAS,EAAGC,WAAOxP,GAAE,GAAIglC,OAC5C3hC,KAAKgP,OAAQ,GAGf0yB,+BAAA,SAAmBtzB,GAEjB,IAAM6C,GADN7C,EAAaipB,GAAmBjpB,IACD7K,QAE/B,OADA0N,EAAYA,EAAYhW,OAAS,GAAK+E,KAAKyhC,MACpCxwB,GAGTywB,iBAAA,SAAKr1B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAE5B,IACIgB,EAASgxB,GADCvI,GAAoBhtB,GACR5S,EAAK8jC,OAAO3xB,QAOtC,OANiB,MAAbnS,EAAK+L,OACPoL,EAAS+sB,GAAU/sB,EAAQnX,EAAK+L,KAAKoG,SAEhB,MAAnBnS,EAAKw/B,aACProB,EAASnX,EAAKw/B,WAAWvtB,MAAMkF,IAE1BA,KAIX8wB,sBAAA,WACE,IAAM1lC,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrC+C,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7Cf,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CkB,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7Cb,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3Cd,eAAgBS,EAAoB78B,KAAKo8B,iBAErC7C,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAxGF0lC,YAAY,WADMjzB,oBA4GbxO,iBAAiBC,SAASwhC,IAmBxC,mBAEE,WAAY1lC,GAAZ,MACE1C,YAAM0C,oBACNvC,EAAKiU,YAAcxB,QAAS,MAuBhC,OA3B6BtS,OAO3BioC,+BAAA,SAAmBzzB,GAEjB,IAAkB,QAAAzR,GADlByR,EAAaipB,GAAmBjpB,IACH7K,MAAM,GAAjBxI,WAAAA,KAChB,GAAW,WACT,MAAM,IAAIhB,EACN,iEACQqU,EAAW7K,MAAM,sHAKjC,OAAQ6K,EAAW,GAAI4J,GAAqB5J,EAAY,KAG1DyzB,iBAAA,SAAKx1B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,OADAnF,EAAK2nC,eAAe/0B,EAAQuD,Y3BlOL1U,GAC3B,GAAIA,EAAE0I,MAAQ,EACZ,MAAM,IAAI7J,EACN,wDAAwDmB,EAAE0I,UAEhE,IAAMiU,GAAY3c,EAAEoI,MAAM,GAAI0U,GAAqB9c,EAAEoI,MAAO,IAC5D,OAAOpI,EAAEuI,QAAQoU,G2B6NNiqB,CAAezI,GAAoBhtB,OAvBvCw1B,YAAY,aADQpzB,oBA4BfxO,iBAAiBC,SAAS2hC,IAuCxC,mBAIE,WAAY7lC,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKkU,iBAAkB,EACvBlU,EAAKw/B,WAAa8C,GAAc//B,EAAOi9B,cAiB3C,OAxBgCr/B,OAU9Bg+B,iBAAA,SAAKvrB,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAC5B,IAAMwf,EAAQiK,GAAoBhtB,GAClC,OAAO5S,EAAKw/B,WAAWvtB,MAAM0jB,MAIjCwI,sBAAA,WACE,IAAM57B,GAAUi9B,WAAYyD,GAAoB18B,KAAKi5B,aAC/CM,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GArBF47B,YAAY,gBADWnpB,oBAyBlBxO,iBAAiBC,SAAS03B,IA0BxC,mBAIE,WAAY57B,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKgL,EAAIzI,EAAOyI,EAChBhL,EAAKiU,YAAc1B,KAAM,MAsB7B,OA7BkCpS,OAUhCmoC,+BAAA,SAAmB3zB,GACjB,OAAQA,EAAW,GAAIpO,KAAKyE,EAAG2J,EAAW,KAG5C2zB,iBAAA,SAAK11B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,OADAyN,EAASgtB,GAAoBhtB,G3B/WZnR,E2BgXDmR,E3BhXY5H,E2BgXJhL,EAAKgL,E3B/W1B7F,OAAK,WACV,GAAuB,IAAnB1D,EAAEoI,MAAMrI,OACV,MAAM,IAAIlB,EACN,yDACQmB,EAAEoI,MAAMrI,mBAGtB,OAAO+mC,GADGC,GAAW/mC,EAAG,IACR,EAAGuJ,EAAG,UARHvJ,EAAWuJ,K2BoXhCs9B,sBAAA,WACE,IAAM/lC,GACJyI,EAAGzE,KAAKyE,GAEJ80B,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA1BF+lC,YAAY,kBADatzB,oBA8BpBxO,iBAAiBC,SAAS6hC,IAsBxC,mBAIE,WAAY/lC,GAAZ,MACE1C,YAAM0C,SACNvC,EAAKyoC,YAAclmC,EAAOkmC,YAG1B,IAAK,IAAI3nC,EAAI,EAAGA,EAAId,EAAKyoC,YAAYjnC,SAAUV,EACzCd,EAAK0oC,UAAU1oC,EAAKyoC,YAAY3nC,MAClCd,EAAKyoC,YAAY3nC,GAAK,eA0F9B,OArG6BX,OAgBnBwoC,sBAAR,SAAkBzyB,GAChB,OAAOA,EAAM,GAAY,MAAPA,GAiBZyyB,gCAAR,SAA4Bh0B,EAAmB6C,GAK7C,IAJA,IAAMoxB,EAAW,6CACXC,EAAarxB,EAAY1N,QAC3Bg/B,EAAQ,EACRC,EAAU,KACLjoC,EAAI,EAAGA,EAAI+nC,EAAWrnC,SAAUV,EAAG,CAC1C,IAAMoV,EAAM2yB,EAAW/nC,GACvB,GAAIyF,KAAKmiC,UAAUxyB,GAAM,CACvB,GAAgB,OAAZ6yB,EAGF,MAAM,IAAIzoC,EAAW,4CAFrByoC,EAAUjoC,OAKZgoC,GAAS5yB,EAIb,IAAM8yB,EAAezqB,GAAqB5J,GAC1C,GAAgB,OAAZo0B,EAAkB,CACpB,GAAc,IAAVD,GAAeE,EAAeF,GAAU,EAC1C,MAAM,IAAIxoC,EAAWsoC,GAEvBC,EAAWE,GAAWC,EAAeF,OAChC,GAAIE,IAAiBF,EAC1B,MAAM,IAAIxoC,EAAWsoC,GAGvB,OAAOC,GAGTF,+BAAA,SAAmBh0B,GAEjB,IADA,IAAIs0B,GAAiB,EACZnoC,EAAI,EAAGA,EAAI6T,EAAWnT,SAAUV,EACvC,GAAIyF,KAAKmiC,UAAU/zB,EAAW7T,IAAK,CACjCmoC,GAAiB,EACjB,MAIJ,OAAIA,EACKt0B,EAAW7K,MAAM,EAAG,GAAG/I,OAAOwF,KAAKkiC,aAEnC9zB,EAAW7K,MAAM,EAAG,GAAG/I,OAC1BwF,KAAK2iC,oBAAoBv0B,EAAW7K,MAAM,GAAIvD,KAAKkiC,eAI3DE,iBAAA,SAAK/1B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAC5B,IAAMwf,EAAQiK,GAAoBhtB,GAC5B+B,EAAaghB,EAAM9rB,MACnB2N,EAAc7C,EAAW7K,MAAM,EAAG,GAAG/I,OACvCf,EAAKkpC,oBAAoBv0B,EAAW7K,MAAM,GAAI9J,EAAKyoC,cACvD,OAAO9S,EAAM3rB,QAAQwN,MAIzBmxB,sBAAA,WACE,IAAMpmC,GACJkmC,YAAaliC,KAAKkiC,aAEd3I,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAlGFomC,YAAY,aADQ3zB,oBAsGfxO,iBAAiBC,SAASkiC,IC5gBxC,mBAeE,WAAYpmC,GAAZ,MACE1C,YAAM0C,SACN,GATMvC,aAA4B,KAE3BA,iCACL,gBAM4B,MAA1BuC,EAAOqS,iBAAgD,MAArBrS,EAAOoS,WAAoB,CAK/D,IAAIE,EAAoB,KACA,MAApBtS,EAAOsS,YACTA,EAAYtS,EAAOsS,WAEK,MAAtBtS,EAAOg/B,YAGTvhC,EAAK4U,iBAAmBC,EAAW,MAInC7U,EAAK4U,iBACAC,GAAW9T,OAAO4U,EAAqBpT,EAAOg/B,qBAGvDvhC,EAAK4jC,SAAWrhC,EAAOqhC,SACvB5jC,EAAKmpC,UAAY5mC,EAAO4mC,UACxBnpC,EAAKopC,sBAAwB3G,GACzBlgC,EAAO6mC,uBAAyBppC,EAAKqpC,gCACzCrpC,EAAKspC,sBAAwBxG,GAAevgC,EAAO+mC,uBACnDtpC,EAAKgU,oBAAsB8uB,GAAevgC,EAAOyR,qBACjDhU,EAAKupC,qBAAuB3G,EAAcrgC,EAAOgnC,sBACjDvpC,EAAKwpC,SAAWjnC,EAAOinC,SACvBxpC,EAAKuhC,YAAch/B,EAAOg/B,cA8E9B,OA3H+BphC,OAgDtBspC,kBAAP,SAAa90B,GACXpO,KAAKmjC,WAAanjC,KAAKw9B,UACnB,cAAex9B,KAAKq9B,SAAUr9B,KAAK4iC,WAAY5iC,KAAK/G,MACpD+G,KAAK6iC,sBAAuB7iC,KAAK+iC,uBAAuB,EACxD/iC,KAAKgjC,sBACThjC,KAAKgP,OAAQ,GAKLk0B,yCAAV,SAAuC90B,KAEvC80B,wBAAA,SAAY72B,EAAyBkG,GACnC,MAAM,IAAIvY,EACN,2DAGNkpC,+BAAA,SAAmB90B,GAEjB,GADAA,EAAaipB,GAAmBjpB,GACR,MAApBpO,KAAKg7B,YACP,OAAW5sB,UAAYpO,KAAK4iC,YAG9B,IAAMQ,EAAmBh0B,EAAqBpP,KAAKg7B,aACnD,GAAIoI,EAAOnoC,SAAWmT,EAAWnT,OAAS,EACxC,MAAM,IAAIlB,EACN,oBAAoBiG,KAAKg7B,oDACA5sB,GAG7B,IADA,IAAI7T,EAAI,EACC8mB,EAAI,EAAGA,EAAI+hB,EAAOnoC,SAAUomB,EAAG,CACtC,IAAMgiB,EAAKD,EAAO/hB,GACZiiB,EAAKl1B,EAAWiT,EAAI,GAC1B,GAAW,MAANgiB,GAAsB,MAANC,GAAgBD,IAAOC,EAC1C,MAAM,IAAIvpC,EACN,oBAAoBiG,KAAKg7B,oDACA5sB,GACd,MAANi1B,IACTD,EAAO7oC,GAAK+oC,GAEd/oC,IAGJ,OAAQ6T,EAAW,WAAOg1B,GAAQpjC,KAAK4iC,aAGzCM,iBAAA,SAAK72B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAE5B,IAAIwf,EAAQiK,GAAoBhtB,GAKhC,MAJoB,UAAhB+iB,EAAMn2B,QACRm2B,EAAQtV,GAAOsV,EAAO,UAET5F,GAAS/vB,EAAK0pC,WAAWv3B,OAAQwjB,EAAMmU,QACxC9/B,QACV4zB,GAAmB59B,EAAKyX,mBAAmBke,EAAM9rB,YAIzD4/B,sBAAA,WACE,IAAMlnC,GACJqhC,SAAUr9B,KAAKq9B,SACfuF,UAAW5iC,KAAK4iC,UAChBC,sBAAuBlG,GAAqB38B,KAAK6iC,uBACjDE,sBAAuBnG,GAAqB58B,KAAK+iC,uBACjDt1B,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/Cu1B,qBAAsBnG,EAAoB78B,KAAKgjC,sBAC/CC,SAAUjjC,KAAKijC,SACfjI,YAAah7B,KAAKg7B,aAEdzB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAxHFknC,YAAY,eADUz0B,oBA6HjBxO,iBAAiBC,SAASgjC,ICpLxC,mBAGE,WAAYlnC,GAAZ,MACE1C,YAAM0C,oBACNvC,EAAKkU,iBAAkB,IAkM3B,OAvMoC/T,OAYxB4pC,0BAAV,SAAwBn3B,GACtB,MAAM,IAAIrS,GAaJwpC,4CAAR,SAAwCC,EAAeC,GACrD,GAAc,MAAVD,GAA4B,MAAVC,EACpB,OAAO,KACF,GAAID,EAAOxoC,OAASyoC,EAAOzoC,OAChC,OAAO+E,KAAK2jC,gCAAgCD,EAAQD,GAC/C,GAAsB,IAAlBC,EAAOzoC,OAChB,OAAOwoC,EAGT,IADA,IAAMxyB,EAAqBwyB,EAAOlgC,MAAM,EAAGkgC,EAAOxoC,OAASyoC,EAAOzoC,QACzDomB,EAAI,EAAGA,EAAIqiB,EAAOzoC,SAAUomB,EAAG,CACtC,IAAM9mB,EAAIkpC,EAAOA,EAAOxoC,OAASyoC,EAAOzoC,OAASomB,GAC3CmC,EAAIkgB,EAAOriB,GACjB,GAAS,MAAL9mB,GAAkB,MAALipB,GAAajpB,EAAI,GAAKipB,EAAI,EACzCvS,EAAYlT,KAAK,WACZ,GAAU,IAANxD,EACT0W,EAAYlT,KAAKylB,QACZ,GAAU,IAANA,EACTvS,EAAYlT,KAAKxD,OACZ,CACL,GAAIA,IAAMipB,EACR,MAAM,IAAIzpB,EACN,wDACAwC,KAAKC,UAAUinC,GAAU,IAAMlnC,KAAKC,UAAUknC,IAEpDzyB,EAAYlT,KAAKxD,IAGrB,OAAO0W,GAGTuyB,kBAAA,SAAMp1B,GAOJ,GALIhU,MAAMC,QAAQ+T,KAAgBhU,MAAMC,QAAQ+T,EAAW,MAEzDA,GAAcipB,GAAmBjpB,MAEnCA,EAAaA,GACEnT,OAAS,EACtB,MAAM,IAAIlB,EACN,wEACQqU,EAAWnT,qBAMzB,IADA,IAAI2oC,SACgBzgB,IAAApoB,WAAAA,KACL,OADJuI,SACyB,OAAbA,EAAM,IACzBsgC,EAAW7lC,KAAKuF,EAAM,IAI1B,IADAsgC,EAAaxnB,EAAqBwnB,IACnB3oC,OAAS,EACtB,MAAM,IAAIlB,EACN,8EAC4BwC,KAAKC,UAAU4R,QAKjD,IAFA,IAAI6C,EACiB,MAAjB7C,EAAW,GAAa,KAAOA,EAAW,GAAG7K,MAAM,GAC9ChJ,EAAI,EAAGA,EAAI6T,EAAWnT,SAAUV,EAAG,CAC1C,IAAM+I,EAAyB,MAAjB8K,EAAW7T,GAAa,KAAO6T,EAAW7T,GAAGgJ,MAAM,GACjE0N,EAAcjR,KAAK2jC,gCAAgC1yB,EAAa3N,GAIlE,IAAMugC,EAAWz1B,EAAWzC,IAAI,SAAArI,GAAS,OAAAA,EAAMrI,UACb,IAA9BmT,EAAW5S,QAAQ,OACuB,IAA1C4gB,EAAqBynB,GAAU5oC,OACjC+E,KAAK8jC,iBAAkB,EAEvB9jC,KAAK8jC,iBAAkB,GAI3BN,iBAAA,SAAKn3B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,GADAyN,EAASA,EACL5S,EAAKqqC,gBAAiB,CACxB,IAAMC,KACAC,EAAY33B,EAAOV,IAAI,SAAAyjB,GAAS,OAAAA,EAAMxrB,OAC5C,IAAiC,IAA7BogC,EAAUxoC,QAAQ,MAAc,CAIlC,IADA,IAAMyQ,EAAUg4B,GAAcD,OAChB/b,IAAAltB,WAAAA,KAEZ,IAFG,IACGmpC,GADChpC,QACS0I,KACPyd,EAAI,EAAGA,EAAIpV,EAAUi4B,IAAS7iB,EACrCnmB,EAAI+tB,GAAa/tB,EAAG,GAEtB6oC,EAAehmC,KAAK7C,GAEtB,OAAOzB,EAAK0qC,cAAcJ,GAK1B,IADA,IAAIK,GAAa,MACDC,IAAA1nC,WAAAA,KAAX,IAAMzB,EAET,GAAa,OADPgpC,GADGhpC,QACO0I,MACG,CACjB,IAAM2L,EAASrU,EAAEoI,MACXgL,EAAYiB,EAAO,GACnBsI,EAAWtI,EAAOhM,MAAM,GAAG/I,QAAQ8T,IACrCg2B,EAAcppC,EAAEuI,SACf6K,GAAW9T,OAAO+pC,GAAoBh1B,EAAOhM,MAAM,MAExD+gC,GADAA,EAAc7I,YAAc6I,GAAc,EAAG,KACnB7gC,QAAQoU,GAClCksB,EAAehmC,KAAKumC,GACpBF,GAAa,OACR,GAAIF,EAAQ,EAAG,CACpB,IAAMM,EAAOC,GAAgB,EAAGP,GAAO1pC,QAAQ,IAC/CupC,EAAehmC,KAAK09B,YAAcvgC,EAAGspC,IACrCJ,GAAa,OAGbL,EAAehmC,KAAK7C,GAGxB,IAAI6J,EAAItL,EAAK0qC,cAAcJ,GACrBW,EAAQ3/B,EAAEnB,KAChB,GAAIwgC,EAGF,GAAa,MAATM,EAAe,CACjB,IAAMC,EAAS5/B,EAAEzB,MAGXuU,GADAvJ,EAAYq2B,EADJA,EAAO1pC,OACY,IAEjBT,OAAOmqC,EAAOphC,MAAM,EAAGohC,EAAO1pC,OAAS,IACvD8J,EAAI02B,YAAc12B,EAAEtB,UAAU,EAAG6K,KAAc,EAAG,IACzC7K,QAAQoU,QACZ,GAAI6sB,EAAQ,EAAG,CACdF,GAAQE,EAAQ,GAAGlqC,OAAOiqC,GAAgB,EAAGC,EAAQ,IAC3D3/B,EAAI02B,YAAc12B,EAAGy/B,GAGzB,OAAOz/B,EAGT,OAAOtL,EAAK0qC,cAAc93B,MAKhCm3B,+BAAA,SAAmBp1B,GAEjB,IAAI6C,EAEFA,EADmB,OAFrB7C,EAAaA,GAEE,GACC,KAEAA,EAAW,GAAG7K,MAAM,GAEpC,IAAK,IAAIhJ,EAAI,EAAGA,EAAI6T,EAAWnT,SAAUV,EAAG,CAC1C,IAAM+I,EAAyB,MAAjB8K,EAAW7T,GAAa,KAAO6T,EAAW7T,GAAGgJ,MAAM,GACjE0N,EAAcjR,KAAK2jC,gCAAgC1yB,EAAa3N,GAIlE,IADA,IAAIsgC,SACgBlgB,IAAA3oB,WAAAA,KACL,OADJuI,SACyB,OAAbA,EAAM,IACzBsgC,EAAW7lC,KAAKuF,EAAM,IAS1B,OAJE2N,EADwB,KAD1B2yB,EAAaxnB,EAAqBwnB,IACnB3oC,OACC2oC,EAAWppC,OAAOyW,IAEjB,MAAMzW,OAAOyW,OAjMExC,mBA6NlC,WAAYzS,UACV1C,YAAM0C,SAYV,OAfyBpC,OAMbgrC,0BAAV,SAAwBv4B,GACtB,OAAOzN,OAAK,WAEV,IADA,IAAIgS,EAASi0B,QAAUx4B,EAAO,GAAG/I,WACbwhC,IAAA/pC,WAAAA,KAAf,IAAMq0B,OACTxe,EAAS/Q,MAAQ+Q,EAAQwe,GAE3B,OAAOxe,KAXJg0B,YAAY,SADIpB,oBAgBXvjC,iBAAiBC,SAAS0kC,IA4ExC,mBAEE,WAAY5oC,UACV1C,YAAM0C,SAYV,OAf8BpC,OAMlBmrC,0BAAV,SAAwB14B,GACtB,OAAOzN,OAAK,WAEV,IADA,IAAIgS,EAASo0B,OAAS34B,EAAO,GAAG/I,WACZ2hC,IAAAlqC,WAAAA,KAAf,IAAMq0B,OACTxe,EAASjR,MAAQiR,EAAQwe,GAE3B,OAAOxe,KAXJm0B,YAAY,cADSvB,oBAgBhBvjC,iBAAiBC,SAAS6kC,IA2ExC,mBAEE,WAAY/oC,UACV1C,YAAM0C,SAYV,OAf6BpC,OAMjBsrC,0BAAV,SAAwB74B,GACtB,OAAOzN,OAAK,WAEV,IADA,IAAIgS,EAASi0B,QAAUx4B,EAAO,GAAG/I,WACb6hC,IAAApqC,WAAAA,KAAf,IAAMq0B,OACTxe,EAAS/Q,MAAQ+Q,EAAQwe,GAE3B,OAAOzvB,MAAQG,EAAU,EAAIuM,EAAOpR,QAAS2V,MAX1Cs0B,YAAY,aADQ1B,oBAgBfvjC,iBAAiBC,SAASglC,IA4ExC,mBAEE,WAAYlpC,UACV1C,YAAM0C,SAYV,OAf6BpC,OAMjBwrC,0BAAV,SAAwB/4B,GACtB,OAAOzN,OAAK,WAEV,IADA,IAAIgS,EAASvE,EAAO,GACX9R,EAAI,EAAGA,EAAI8R,EAAOpR,SAAUV,EACnCqW,EAASqF,UAAYrF,EAAQvE,EAAO9R,IAEtC,OAAOqW,KAXJw0B,YAAY,aADQ5B,oBAgBfvjC,iBAAiBC,SAASklC,IA2ExC,mBAEE,WAAYppC,UACV1C,YAAM0C,SAYV,OAf6BpC,OAMjByrC,0BAAV,SAAwBh5B,GACtB,OAAOzN,OAAK,WAEV,IADA,IAAIgS,EAASvE,EAAO,GACX9R,EAAI,EAAGA,EAAI8R,EAAOpR,SAAUV,EACnCqW,EAASynB,UAAYznB,EAAQvE,EAAO9R,IAEtC,OAAOqW,KAXJy0B,YAAY,aADQ7B,oBAgBfvjC,iBAAiBC,SAASmlC,IAoFxC,mBAKE,WAAYrpC,GAAZ,MACE1C,YAAM0C,gBAJCvC,gBAAgB,EAKT,MAAVuC,IACFA,MAEFvC,EAAKkF,KAAsB,MAAf3C,EAAO2C,KAAelF,EAAKwgC,aAAej+B,EAAO2C,KAC7DlF,EAAKkU,iBAAkB,EACvBlU,EAAKqqC,iBAAkB,IAmF3B,OA/FiClqC,OAe/B0rC,kBAAA,SAAMl3B,GAEJ,IAAMhU,MAAMC,QAAQ+T,KAAehU,MAAMC,QAAQ+T,EAAW,KAClC,IAAtBA,EAAWnT,OACb,MAAM,IAAIlB,EACN,yEAMN,IADA,IAAIwrC,GAAe,MACCC,EAHpBp3B,EAAaA,EAGOrT,WAAAA,KAClB,GAAa,OADJuI,QACU,CACjBiiC,GAAe,EACf,OAGJ,IAAIA,EAAJ,CAKA,IADA,IAAME,KACGlrC,EAAI,EAAGA,EAAI6T,EAAWnT,SAAUV,EAAG,CAC1C,IAAMmrC,EAAyBt3B,EAAW7T,GAAGgJ,QAC7CmiC,EAAuBliC,OAAOxD,KAAKrB,KAAM,GAEzC,IADA,IAAIgnC,GAAS,MACOC,IAAAjpC,WAAAA,KAAf,IAAM2G,OACT,GAAIyC,OAAKC,YAAY1C,EAAOoiC,GAAyB,CACnDC,GAAS,EACT,OAGCA,GACHF,EAAS1nC,KAAK2nC,GAGlB,GAAID,EAASxqC,OAAS,EACpB,MAAM,IAAIlB,EACN,4GAEAwC,KAAKC,UAAU4R,MAIbk3B,0BAAV,SAAwBj5B,GAAxB,WACE,OAAOzN,OAAK,WACV,OAAOinC,GAAcx5B,EAAQ5S,EAAKkF,SAItC2mC,+BAAA,SAAmBl3B,GACjB,IAAMhU,MAAMC,QAAQ+T,KAAehU,MAAMC,QAAQ+T,EAAW,IAC1D,MAAM,IAAIrU,EACN,+DAON,IALA,IAAMkT,EAAcmB,EACd6C,EAAchE,EAAY,GAAG1J,QAC7B5E,EAAOqB,KAAKrB,KAAO,EAAIsS,EAAYhW,OAAS+E,KAAKrB,KAAOqB,KAAKrB,SAG/ChC,EAAAsQ,EAAY1J,MAAM,GAAlBxI,WAAAA,KAAf,IAAMuI,OACT,GAAyB,MAArB2N,EAAYtS,IAAgC,MAAf2E,EAAM3E,GAAe,CACpDsS,EAAYtS,GAAQ,KACpB,MAEFsS,EAAYtS,IAAS2E,EAAM3E,GAE7B,OAAOsS,GAKTq0B,sBAAA,WACE,IAAMtpC,GACJ2C,KAAQqB,KAAKrB,MAET46B,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GA5FFspC,YAAY,iBADY9B,gBC7pB7BtoC,EAAWyJ,EAAcmhC,EAAkBC,EAAeC,EAC1DjmC,GACF,IAAIlC,EACJ,gBAFEkC,QAEa,IAAX7E,EAAE0I,KACJ/F,EAAMooC,uBACF/qC,EAAeyJ,EACfmhC,EAAiC/lC,EAASimC,EAC1CD,QACC,GAAe,IAAX7qC,EAAE0I,KAEX/F,EAAMqoC,uBACFhrC,EAAeyJ,EACfmhC,EAAiC/lC,EAASimC,EAC1CD,OACC,CAAA,GAAe,IAAX7qC,EAAE0I,KAMX,MAAM,IAAI5J,EACN,4DAA4DkB,EAAE0I,aANlE/F,EAAMsoC,uBACFjrC,EAAeyJ,EACfmhC,EAAiC/lC,EAASimC,EAC1CD,GAMN,OAAOloC,cA0FL3C,EAAW8qC,EAAeD,EAAcK,EACxCrmC,GACF,oBADEA,QACEgG,OAAKC,YACDogC,EAAc7iC,QAAQ0b,OAAQonB,GAAiB,EAAGnrC,EAAE0I,KAAO,IAzErE,SACI1I,EAAW8qC,EAAeD,EAAcK,EACxCrmC,GACF,oBADEA,QACKnB,OAAK,WACH,IAAM0nC,EAAkBC,UAAYrrC,EAAGkrC,GACjCzhC,EAAO2hC,EAAgB3hC,KACvBmhC,EAAWQ,EAAgBR,SAGjC,OADIU,GAAmBtrC,EAAGyJ,EAAMmhC,EAAUC,EAAMC,EAAOjmC,GACvC4E,EAAMmhC,KAiEtBW,CACHvrC,EAAG8qC,EAAOD,EAAMK,EAAermC,GA7CvC,SACI7E,EAAW8qC,EAAeD,EAAcK,EACxCrmC,GACF,oBADEA,QACKnB,OAAK,WAKH,IAJA,IAAM0nC,EAAkBC,UAAYrrC,EAAGkrC,GACjCzhC,EAAO2hC,EAAgB3hC,KACvBmhC,EAAWQ,EAAgBR,SAC3B5D,SACavlC,EAAA0pC,GAAiB,EAAGnrC,EAAE0I,MAAtB7I,WAAAA,KAAd,IAAM4D,QAC4B,IAAjCynC,EAAc5qC,QAAQmD,GACxBujC,EAAYnkC,KAAK,GAEjBmkC,EAAYnkC,KAAK7C,EAAEoI,MAAM3E,IAG7B,IAAM+nC,EAAgB/hC,EAAKlB,QAAQy+B,GAC7ByE,EAAoBb,EAASriC,QAAQy+B,GACrC0E,EACO,MAATZ,EAAgB,KAAOA,EAAMviC,QAAQy+B,GACnC2E,EACM,MAARd,EAAe,KAAOA,EAAKtiC,QAAQy+B,GAIvC,OAHesE,GACXtrC,EAAGwrC,EAAeC,EAAmBE,EACrCD,EAAgB7mC,GACJ4E,EAAMmhC,KAuBtBgB,CACH5rC,EAAG8qC,EAAOD,EAAMK,EAAermC,mBDmoBzBE,iBAAiBC,SAASolC,ICzhBxC,mBAqBE,WAAYtpC,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKkU,iBAAkB,EACvBlU,EAAKkF,KAAsB,MAAf3C,EAAO2C,MAAgB,EAAI3C,EAAO2C,KAC9ClF,EAAKstC,SAA8B,MAAnB/qC,EAAO+qC,SAAmB,IAAO/qC,EAAO+qC,SACxDttC,EAAKsG,QAA4B,MAAlB/D,EAAO+D,QAAkB,KAAO/D,EAAO+D,QACtDtG,EAAKutC,OAA0B,MAAjBhrC,EAAOgrC,QAAwBhrC,EAAOgrC,OACpDvtC,EAAKuO,MAAwB,MAAhBhM,EAAOgM,OAAuBhM,EAAOgM,MAClDvO,EAAKwtC,gBAAkB/K,GAAelgC,EAAOirC,iBAAmB,SAChExtC,EAAKytC,iBAAmBhL,GAAelgC,EAAOkrC,kBAAoB,QAClEztC,EAAK0tC,sBACDjL,GAAelgC,EAAOmrC,uBAAyB,SACnD1tC,EAAK2tC,0BACDlL,GAAelgC,EAAOorC,2BAA6B,QACvD3tC,EAAK4tC,eAAiBhL,EAAcrgC,EAAOqrC,gBAC3C5tC,EAAK6tC,gBAAkBjL,EAAcrgC,EAAOsrC,iBAC5C7tC,EAAK8tC,gBAAkBhL,GAAevgC,EAAOurC,iBAC7C9tC,EAAK+tC,iBAAmBjL,GAAevgC,EAAOwrC,kBAC9C/tC,EAAKguC,UAAY,IAiIrB,OAxKwC7tC,OA0C/B8tC,kBAAP,SAAat5B,GACXA,EAAaipB,GAAmBjpB,GAChC,IAAMzP,EAAOqB,KAAKrB,MAAQ,EAAIqB,KAAKrB,KAAQqB,KAAKrB,KAAOyP,EAAWnT,OAC5D0U,EAAMvB,EAAWzP,GACvB,GAAW,MAAPgR,EACF,MAAM,IAAI5V,EACN,QAAQ4E,iGAELpC,KAAKC,UAAU4R,QAExBpO,KAAK0N,WACA,IAAI0wB,IAAWpyB,KAAMoC,EAAWnT,OAAQkR,WAAOxP,EAACgC,GAAOgR,QAC5D,MAAMrM,GAASqM,GACX3P,KAAKgI,QACPhI,KAAKgmC,MAAQhmC,KAAKw9B,UACd,QAASl6B,EAAO,KAAMtD,KAAKknC,iBAAkBlnC,KAAKwnC,kBAClD,EAAMxnC,KAAKsnC,kBAEbtnC,KAAKgnC,SACPhnC,KAAK+lC,KAAO/lC,KAAKw9B,UACb,OAAQl6B,EAAO,KAAMtD,KAAKinC,gBAAiBjnC,KAAKunC,iBAAiB,EACjEvnC,KAAKqnC,iBAEXrnC,KAAK2nC,WAAa3nC,KAAKw9B,UACnB,cAAel6B,EAAO,KAAMtD,KAAKmnC,sBAAuB,MAAM,GAClEnnC,KAAK4nC,eAAiB5nC,KAAKw9B,UACvB,kBAAmBl6B,EAAO,KAAMtD,KAAKonC,0BAA2B,MAChE,GACJpnC,KAAKgP,OAAQ,GAGf04B,iBAAA,SAAKr7B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACV,IAAM2H,EAAiC,MAAtBqJ,EAAiB,UAAoBA,EAAiB,SACjEwf,EAAQiK,GAAoBhtB,GAC5B+B,EAAaghB,EAAM9rB,MACnB0I,EAAOoC,EAAWnT,OAClBmrC,EAAgBC,GAAiB,EAAGr6B,GACpCrN,EAAOlF,EAAKkF,MAAQ,EAAIlF,EAAKkF,KAAQlF,EAAKkF,KAAOqN,EACvDo6B,EAAc5iC,OAAO7E,EAAM,GAC3B,IAAMkpC,EAAiB7kB,EAA2B,EAAGhX,GACrD67B,EAAelpC,GAAQyP,EAAWzP,GAElC,IAAMmpC,EAAsB1B,EAAc7iC,QAC1CukC,EAAoB7oB,OACpB,IAAM8oB,GAAqBhiC,OAAKC,YAC5B8hC,EAAqBzB,GAAiB,EAAGr6B,GAAMzI,MAAM,EAAGyI,EAAO,IAuBnE,IAAKzF,EACH,OAtBuC,WACvC,GAAIwhC,EAAmB,CACrB,IAAMC,EACFvuC,EAAKkuC,WAAW/7B,OAAOnI,QAAQokC,GAC7BI,EACFxuC,EAAKmuC,eAAeh8B,OAAOnI,QAAQokC,GACjChB,EACFptC,EAAKutC,OAASvtC,EAAKssC,KAAKn6B,OAAOnI,QAAQokC,GAAkB,KACvDjB,EACFntC,EAAKuO,MAAQvO,EAAKusC,MAAMp6B,OAAOnI,QAAQokC,GAAkB,KAC7D,OAAOrB,GACHpX,EAAO4Y,EAAqBC,EAC5BpB,EAAeD,EAAgBntC,EAAKsG,SAExC,OAAOymC,GACHpX,EAAO31B,EAAKkuC,WAAW/7B,OAAQnS,EAAKmuC,eAAeh8B,OACtC,MAAbnS,EAAKssC,KAAe,KAAOtsC,EAAKssC,KAAKn6B,OACvB,MAAdnS,EAAKusC,MAAgB,KAAOvsC,EAAKusC,MAAMp6B,OAAQnS,EAAKsG,SAKnDmoC,GAGH,IAAAvrC,iDAACwrC,OAAgBxjC,OAAMmhC,OAKvBsC,EACFpwB,GAAqBouB,EAAcz6B,IAAI,SAAAhN,GAAQ,OAAAywB,EAAM9rB,MAAM3E,MACzD0pC,EAAmBvC,EAAS9+B,IAC9BlH,EAAUsoC,GAAcA,GAAc,EAAI3uC,EAAKsG,YAoBnD,OAZoC,WAClCtG,EAAKguC,YACL,IAAMa,EAAgBC,gBAClB9uC,EAAKkuC,WAAW/7B,OAAQjH,EAAMlL,EAAKstC,SAAUttC,EAAKguC,WACtDhuC,EAAKkuC,WAAW57B,MAAMu8B,GACtB,IAAME,EAAoBD,gBACtB9uC,EAAKmuC,eAAeh8B,OAAQy8B,EAAkB5uC,EAAKstC,SACnDttC,EAAKguC,WACThuC,EAAKmuC,eAAe77B,MAAMy8B,GAE5BC,GAEON,KAIXT,sBAAA,WACE,IAAM1rC,GACJ2C,KAAMqB,KAAKrB,KACXooC,SAAU/mC,KAAK+mC,SACfhnC,QAASC,KAAKD,QACdinC,OAAQhnC,KAAKgnC,OACbh/B,MAAOhI,KAAKgI,MACZi/B,gBAAiBtK,GAAqB38B,KAAKinC,iBAC3CC,iBAAkBvK,GAAqB38B,KAAKknC,kBAC5CC,sBAAuBxK,GAAqB38B,KAAKmnC,uBACjDC,0BACIzK,GAAqB38B,KAAKonC,2BAC9BG,gBAAiB3K,GAAqB58B,KAAKunC,iBAC3CC,iBAAkB5K,GAAqB58B,KAAKwnC,kBAC5CH,eAAgBxK,EAAoB78B,KAAKqnC,gBACzCC,gBAAiBzK,EAAoB78B,KAAKsnC,kBAEtC/N,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GArKF0rC,YAAY,wBADmBj5B,oBAyK1BxO,iBAAiBC,SAASwnC,ICjSxC,mBAKE,WAAY1rC,GAAZ,WAUE,GATc,MAAVA,IACFA,OAEFvC,EAAAH,YAAM0C,UAEDyJ,WACoB,MAArBzJ,EAAOyJ,WvCtIN,euCsI+CzJ,EAAOyJ,WAGrC,MAAlBzJ,EAAOk/B,QACTzhC,EAAKyhC,UAAY,EAAG,IAAK,EAAG,SACvB,GAA8B,iBAAnBl/B,EAAOk/B,QACvBzhC,EAAKyhC,UACCl/B,EAAOk/B,QAASl/B,EAAOk/B,UAAWl/B,EAAOk/B,QAASl/B,EAAOk/B,cAC1D,CAGL,GAFAl/B,EAAOk/B,QAAUl/B,EAAOk/B,QAEM,IAA1Bl/B,EAAOk/B,QAAQjgC,OACjB,MAAM,IAAIlB,EACN,+EACqBiC,EAAOk/B,QAAQjgC,kBAG1C,IAAIytC,SACAC,SACJ,GAAiC,iBAAtB3sC,EAAOk/B,QAAQ,GACxBwN,GACK1sC,EAAOk/B,QAAQ,GAAcl/B,EAAOk/B,QAAQ,IACjDyN,GACK3sC,EAAOk/B,QAAQ,GAAcl/B,EAAOk/B,QAAQ,QAC5C,CAGL,GAFAl/B,EAAOk/B,QAAUl/B,EAAOk/B,QAES,IAA7Bl/B,EAAOk/B,QAAQ,GAAGjgC,OACpB,MAAM,IAAIlB,EACN,sFACyBiC,EAAOk/B,QAAQ,GAAGjgC,kBAIjD,GAFAytC,EAAgB1sC,EAAOk/B,QAAQ,GAEE,IAA7Bl/B,EAAOk/B,QAAQ,GAAGjgC,OACpB,MAAM,IAAIlB,EACN,qFACyBiC,EAAOk/B,QAAQ,GAAGjgC,kBAEjD0tC,EAAe3sC,EAAOk/B,QAAQ,GAEhCzhC,EAAKyhC,SAAWwN,EAAeC,UAEjClvC,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,OAkD3C,OAzGmCpS,OA0DjCgvC,+BAAA,SAAmBx6B,GAGjB,IAAIwyB,EACAC,EACJ,OAJAzyB,EAAaipB,GAAmBjpB,GAIR,kBAApBpO,KAAKyF,YAELm7B,EADmB,MAAjBxyB,EAAW,IAAcA,EAAW,IAAM,EACrCA,EAAW,GAAKpO,KAAKk7B,QAAQ,GAAG,GAAKl7B,KAAKk7B,QAAQ,GAAG,GAErD,KAGP2F,EADmB,MAAjBzyB,EAAW,IAAcA,EAAW,IAAM,EACrCA,EAAW,GAAKpO,KAAKk7B,QAAQ,GAAG,GAAKl7B,KAAKk7B,QAAQ,GAAG,GAErD,MAED9sB,EAAW,GAAIA,EAAW,GAAIwyB,EAAMC,KAG1CD,EADmB,MAAjBxyB,EAAW,IAAcA,EAAW,IAAM,EACrCA,EAAW,GAAKpO,KAAKk7B,QAAQ,GAAG,GAAKl7B,KAAKk7B,QAAQ,GAAG,GAErD,KAGP2F,EADmB,MAAjBzyB,EAAW,IAAcA,EAAW,IAAM,EACrCA,EAAW,GAAKpO,KAAKk7B,QAAQ,GAAG,GAAKl7B,KAAKk7B,QAAQ,GAAG,GAErD,MAED9sB,EAAW,GAAIwyB,EAAMC,EAAMzyB,EAAW,MAIlDw6B,iBAAA,SAAKv8B,EAAyBuD,GAA9B,WACE,OAAOhR,OACH,WAAM,OAhLV1D,EAiLQm+B,GAAoBhtB,GAjLjB6uB,EAiL0BzhC,EAAKyhC,QAhL1Cz1B,EAgLmDhM,EAAKgM,WA/KnD7G,OAAK,WACV,GAAe,IAAX1D,EAAE0I,KACJ,MAAM,IAAI7J,EACN,kEACGmB,EAAE0I,mBAMX,GAHe,MAAXs3B,IACFA,IAAY,EAAG,IAAK,EAAG,KAEF,IAAnBA,EAAQjgC,QAAsC,IAAtBigC,EAAQ,GAAGjgC,QACb,IAAtBigC,EAAQ,GAAGjgC,OACb,MAAM,IAAIlB,EACN,+GAON,GAHkB,MAAd0L,IACFA,EvC1DG,gBuC4Dc,iBAAfA,GAAgD,kBAAfA,EACnC,MAAM,IAAI1L,EACN,wBAAwB0L,qEAI9B,IAAIojC,EAOJ,OALEA,EADiB,kBAAfpjC,IACU,EAAG,IAAK,EAAG,GAAIy1B,EAAQ,GAAIA,EAAQ,MAEnC,EAAG,GAAIA,EAAQ,GAAIA,EAAQ,IAAK,EAAG,IAG1C4N,MAAQ5tC,EAAG2tC,SAnClB3tC,EAAWggC,EACXz1B,KAmLFmjC,sBAAA,WACE,IAAM5sC,GACJk/B,QAASl7B,KAAKk7B,QACdz1B,WAAYzF,KAAKyF,YAEb8zB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAtGF4sC,YAAY,mBADcn6B,gBChH/BvT,EAAW6tC,EAA4BlN,EACvCX,EAAuBz1B,EACvBujC,GACF,OAAOpqC,OAAK,eAoBNmG,EAnBJW,EAAgBD,GlCRlBhE,EAA0BE,EAAwB,WkCSlCqnC,GACdlN,EAAiBZ,GACF,MAAXW,IACFA,GAAW,EAAG,IAED,MAAXX,IACFA,EAAU,SAEM,MAAdz1B,IACFA,ExCxBG,gBwC0BW,MAAZujC,IACFA,EAAW,OAKb9tC,EAAI0iC,GAAsB1iC,EAAGuK,GAE7B,IAAMwjC,EAA6B,SAAZ/N,EAAsB,OAAS,QActD,OAXEn2B,EAFe,QAAbikC,EAEEE,UAAYhuC,EAAe6tC,EAAUlN,EAASoN,GAI9CE,UAEAjuC,EAA0B6tC,EAAUlN,EAASoN,GAEhC,kBAAfxjC,IACFV,EAAI02B,YAAc12B,GAAI,EAAG,EAAG,EAAG,KAE1BA,oBDoLG9E,iBAAiBC,SAAS0oC,IC7JxC,mBAWE,WAAY5sC,GAAZ,WAKE,GAJuB,MAAnBA,EAAO+sC,WACT/sC,EAAO+sC,SAAW,GAEpBtvC,EAAAH,YAAM0C,SACyB,iBAApBA,EAAO+sC,SAChBtvC,EAAKsvC,UAAY/sC,EAAO+sC,cACnB,CAAA,IACH3uC,MAAMC,QAAQ2B,EAAO+sC,WACoB,IAAxC/sC,EAAO+sC,SAAsB9tC,QACc,iBAApCe,EAAO+sC,SAAsB,GAGvC,MAAM,IAAIhvC,EACN,qGAEGwC,KAAKC,UAAUR,EAAO+sC,WAL7BtvC,EAAKsvC,SAAW/sC,EAAO+sC,SAOzB,GAAsB,MAAlB/sC,EAAO6/B,QACTpiC,EAAKoiC,QAAUpiC,EAAKsvC,cAEpB,GAA8B,iBAAnB/sC,EAAO6/B,QAChBpiC,EAAKoiC,SAAW7/B,EAAO6/B,aAClB,CAAA,IACHzhC,MAAMC,QAAQ2B,EAAO6/B,UACmB,IAAvC7/B,EAAO6/B,QAAqB5gC,QACc,iBAAnCe,EAAO6/B,QAAqB,GAGtC,MAAM,IAAI9hC,EACN,oGAEGwC,KAAKC,UAAUR,EAAO6/B,UAL7BpiC,EAAKoiC,QAAU7/B,EAAO6/B,eAS1BpiC,EAAKyhC,QAA4B,MAAlBl/B,EAAOk/B,QAAkB,QAAUl/B,EAAOk/B,QACzDY,EAAiBriC,EAAKyhC,SACtBzhC,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,OAqC3C,OAtFwCpS,OAoDtCwvC,+BAAA,SAAmBh7B,GAEjB,IAAMnT,EAASijC,IADf9vB,EAAaipB,GAAmBjpB,IAEjB,GAAIpO,KAAK+oC,SAAS,GAAI/oC,KAAKk7B,QAASl7B,KAAK67B,QAAQ,IAChE,OAAQztB,EAAW,GAAInT,EAAQmT,EAAW,KAO5Cg7B,iBAAA,SAAK/8B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACVnF,EAAK2nC,eAAe/0B,EAAQuD,GAE5BvD,EAAS4c,GAAaoQ,GAAoBhtB,GAAS,GACnD,IAAMuE,EAASnX,EAAK4vC,gBAChBhQ,GAAoBhtB,IAAU5S,EAAKsvC,SAAS,GAAI,IAC/CtvC,EAAKoiC,QAAQ,GAAI,GAAIpiC,EAAKyhC,QAAS,gBAExC,OAAOoO,UAAY14B,GAAS,OAIhCw4B,sBAAA,WACE,IAAMptC,GACJ+sC,SAAU/oC,KAAK+oC,SACf7N,QAASl7B,KAAKk7B,QACdW,QAAS77B,KAAK67B,SAEVtC,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,MApF6ByS,mBAiGtC,WAAYzS,UACV1C,YAAM0C,SAUV,OAbkCpC,OAMtB2vC,4BAAV,SACIl9B,EAAgB08B,EAA4BlN,EAC5CX,EAAsBz1B,GAGxB,OAFAC,EAAgBD,GAChBq2B,EAAiBZ,GACVsO,GAAOn9B,EAAQ08B,EAAUlN,EAASX,EAASz1B,EAAY,QAVzD8jC,YAAY,kBADaH,oBAcpBnpC,iBAAiBC,SAASqpC,IAWxC,mBAEE,WAAYvtC,UACV1C,YAAM0C,SAUV,OAbsCpC,OAM1B6vC,4BAAV,SACIp9B,EAAgB08B,EAA4BlN,EAC5CX,EAAsBz1B,GAGxB,OAFAC,EAAgBD,GAChBq2B,EAAiBZ,GACVsO,GAAOn9B,EAAQ08B,EAAUlN,EAASX,EAASz1B,EAAY,QAVzDgkC,YAAY,sBADiBL,oBAcxBnpC,iBAAiBC,SAASupC,IA+BxC,mBAME,WAAYztC,GAAZ,WAQE,GAPuB,MAAnBA,EAAO+sC,WACT/sC,EAAO+sC,UAAY,EAAG,KAExBtvC,EAAAH,YAAM0C,UACD+sC,SAAW3uC,MAAMC,QAAQ2B,EAAO+sC,UACjC/sC,EAAO+sC,UACN/sC,EAAO+sC,SAAU/sC,EAAO+sC,UACP,MAAlB/sC,EAAO6/B,QACTpiC,EAAKoiC,QAAUpiC,EAAKsvC,cACf,GAAI3uC,MAAMC,QAAQ2B,EAAO6/B,SAAU,CACxC,GAA8B,IAA1B7/B,EAAO6/B,QAAQ5gC,OACjB,MAAM,IAAIlB,EACN,wHAEGiC,EAAO6/B,QAAQ5gC,YAExBxB,EAAKoiC,QAAU7/B,EAAO6/B,aAGtBpiC,EAAKoiC,SAAW7/B,EAAO6/B,QAAS7/B,EAAO6/B,gBAEzCpiC,EAAKyhC,QAA4B,MAAlBl/B,EAAOk/B,QAAkB,QAAUl/B,EAAOk/B,QACzDzhC,EAAKgM,WACoB,MAArBzJ,EAAOyJ,WAAqB,eAAiBzJ,EAAOyJ,WACxDC,EAAgBjM,EAAKgM,YACrBq2B,EAAiBriC,EAAKyhC,SAEtBzhC,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,OA4C3C,OA9EwCpS,OAqCtC8vC,+BAAA,SAAmBt7B,GACjBA,EAAaipB,GAAmBjpB,GAChC,IAAIwyB,EACoB,kBAApB5gC,KAAKyF,WAAiC2I,EAAW,GAAKA,EAAW,GACjEyyB,EACoB,kBAApB7gC,KAAKyF,WAAiC2I,EAAW,GAAKA,EAAW,GAKrE,OAJAwyB,EACI1C,GAAiB0C,EAAM5gC,KAAK+oC,SAAS,GAAI/oC,KAAKk7B,QAASl7B,KAAK67B,QAAQ,IACxEgF,EACI3C,GAAiB2C,EAAM7gC,KAAK+oC,SAAS,GAAI/oC,KAAKk7B,QAASl7B,KAAK67B,QAAQ,IAChD,kBAApB77B,KAAKyF,YACC2I,EAAW,GAAIA,EAAW,GAAIwyB,EAAMC,IAEpCzyB,EAAW,GAAIwyB,EAAMC,EAAMzyB,EAAW,KAQlDs7B,iBAAA,SAAKr9B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,OADAnF,EAAK2nC,eAAe/0B,EAAQuD,GACrBnW,EAAK4vC,gBACRhQ,GAAoBhtB,GAAS5S,EAAKsvC,SAAUtvC,EAAKoiC,QACjDpiC,EAAKyhC,QAASzhC,EAAKgM,eAI3BikC,sBAAA,WACE,IAAM1tC,GACJ+sC,SAAU/oC,KAAK+oC,SACf7N,QAASl7B,KAAKk7B,QACdW,QAAS77B,KAAK67B,QACdp2B,WAAYzF,KAAKyF,YAEb8zB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,MA5E6ByS,mBAqGtC,WAAYzS,UACV1C,YAAM0C,SAUV,OAbkCpC,OAMtB+vC,4BAAV,SACIt9B,EAAgB08B,EAA4BlN,EAC5CX,EAAsBz1B,GAGxB,OAFAC,EAAgBD,GAChBq2B,EAAiBZ,GACVsO,GAAOn9B,EAAQ08B,EAAUlN,EAASX,EAASz1B,EAAY,QAVzDkkC,YAAY,kBADaD,oBAcpBzpC,iBAAiBC,SAASypC,IAuBxC,mBAEE,WAAY3tC,UACV1C,YAAM0C,SAUV,OAbsCpC,OAM1BgwC,4BAAV,SACIv9B,EAAgB08B,EAA4BlN,EAC5CX,EAAsBz1B,GAGxB,OAFAC,EAAgBD,GAChBq2B,EAAiBZ,GACVsO,GAAOn9B,EAAQ08B,EAAUlN,EAASX,EAASz1B,EAAY,QAVzDmkC,YAAY,sBADiBF,oBAcxBzpC,iBAAiBC,SAAS0pC,IAKxC,mBACE,WAAY5tC,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,OAU3C,OAb8CpS,OAM5CiwC,+BAAA,SAAmBz7B,GACjB,OAAQA,EAAW,GAAIA,EAAW,KAGpCy7B,iBAAA,SAAKx9B,EAAyBuD,GAC5B,MAAM,IAAI5V,MAXgCyU,mBAwB5C,WAAYzS,UACV1C,YAAM0C,SASV,OAZ4CpC,OAM1CkwC,iBAAA,SAAKz9B,EAAyBuD,GAC5B,OAAOhR,OAAK,WACV,IAAMwwB,EAAQiK,GAAoBhtB,GAClC,OAAO+J,OAASgZ,EAAO,MARpB0a,YAAY,4BADuBD,oBAa9B5pC,iBAAiBC,SAAS4pC,IASxC,mBAEE,WAAY9tC,UACV1C,YAAM0C,SASV,OAZwCpC,OAMtCmwC,iBAAA,SAAK19B,EAAyBuD,GAC5B,OAAOhR,OAAK,WACV,IAAMwwB,EAAQiK,GAAoBhtB,GAClC,OAAOlJ,MAAQisB,EAAO,MARnB2a,YAAY,wBADmBF,oBAa1B5pC,iBAAiBC,SAAS6pC,IAiBxC,mBAEE,WAAY/tC,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKgM,WACoB,MAArBzJ,EAAOyJ,WAAqB,eAAiBzJ,EAAOyJ,WACxDC,EAAgBjM,EAAKgM,YACrBhM,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,OAsB3C,OA7B8CpS,OAU5CowC,+BAAA,SAAmB57B,GAEjB,OADAA,EAAaA,EACW,iBAApBpO,KAAKyF,YACC2I,EAAW,GAAIA,EAAW,KAE1BA,EAAW,GAAIA,EAAW,KAItC47B,iBAAA,SAAK39B,EAAyBuD,GAC5B,MAAM,IAAI5V,GAGZgwC,sBAAA,WACE,IAAMhuC,GAAUyJ,WAAYzF,KAAKyF,YAC3B8zB,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,MA3BmCyS,mBA2C9C,4DAaA,OAb4C7U,OAG1CqwC,iBAAA,SAAK59B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACV,IAAMwwB,EAAQiK,GAAoBhtB,GAClC,MAAwB,iBAApB5S,EAAKgM,WACA2Q,OAASgZ,GAAQ,EAAG,IAEpBhZ,OAASgZ,GAAQ,EAAG,OAR1B6a,YAAY,4BADuBD,oBAc9B/pC,iBAAiBC,SAAS+pC,IAcxC,mBAAA,4DAaA,OAbwCrwC,OAGtCswC,iBAAA,SAAK79B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACV,IAAMwwB,EAAQiK,GAAoBhtB,GAClC,MAAwB,iBAApB5S,EAAKgM,WACAtC,MAAQisB,GAAQ,EAAG,IAEnBjsB,MAAQisB,GAAQ,EAAG,OARzB8a,YAAY,wBADmBF,gBC9fpC39B,EACA89B,EACAC,EACAC,GAKF,GAAIjwC,MAAMC,QAAQgS,GAAS,CACzB,GAAoB,MAAhB89B,GAAqC,MAAbC,EAC1B,MAAM,IAAIrwC,EACN,iFAGc,MAAhBswC,IACFD,EAAY/9B,EAAO9I,MAAM8I,EAAOpR,OAASovC,EAAch+B,EAAOpR,QAC9DoR,EAASA,EAAO9I,MAAM,EAAG8I,EAAOpR,OAASovC,IAEvCh+B,EAAOpR,OAAS,IAClBkvC,EAAe99B,EAAO9I,MAAM,EAAG8I,EAAOpR,SAExCoR,EAASA,EAAO,GAGlB,WAAsBnR,GAEpB,OAAS,MAALA,GAAad,MAAMC,QAAQa,GACtBA,GAECA,GAOZ,OAAQmR,SAAQ89B,aAHhBA,EAAeG,EAAaH,GAGEC,UAF9BA,EAAYE,EAAaF,gBA0CvBG,EAA+Bl+B,EAAgBm+B,EAC/CC,EAAqBl4B,EAAe63B,EAAsBM,EAC1D1P,gBADAyP,mBAA0DC,MAE5D,IAAM1+B,EAAOK,EAAO/I,MAAMrI,OAC1B,GAAI+Q,EAAO,EACT,MAAM,IAAIjS,EAAW,uCAAuCiS,QAK9D,IAsCImQ,EACAwuB,EAvCEx+B,GAAQ,EAAG,GAAG3R,OAAO6rC,GAAiB,EAAGr6B,IAG/C,GAFAK,EAASovB,YAAcpvB,EAAQF,GAEnB,MAARoG,EACF,MAAM,IAAIvY,EACN,gFAIN,GAAiB,MAAbowC,EACF,MAAM,IAAIpwC,EACN,kFAKF0wC,GACFphC,QAAQC,KACJ,qGAIFkhC,IACFp+B,EAASu+B,UAAYv+B,EAAQ,IAmB/B,IAFA,IAAIw+B,EAASL,EACPM,EAAYz+B,EAAO/I,MAAM,GACtBynC,EAAI,EAAGA,EAAID,IAAaC,EAAG,CAClC,IAAIC,EAAe3hB,GAAsBhd,EAAQ0+B,EAAG,GAE9CE,EAAcV,EADpBS,EAAeA,EAAavnC,QAAQunC,EAAa1nC,MAAMC,MAAM,IACdsnC,GAC/CF,EAAaM,EAAY,GAEvB9uB,EADQ,IAAN4uB,EACQJ,EAAWlnC,SAAS,GAAGjJ,OAAOmwC,EAAWrnC,QAEzCitB,GACNpU,EAASwuB,EAAWlnC,SAAS,GAAGjJ,OAAOmwC,EAAWrnC,SAIxDunC,EAASI,EAAY,GAGvB,OACEN,EACAlP,YACItf,GAAU,EAAG,GAAG3hB,OAAO6rC,GAAiB,EAAGlqB,EAAQ7Y,MAAMrI,UAC7D4vC,mBDwXU5qC,iBAAiBC,SAASgqC,uBCrNtC,WAAYluC,GAAZ,IAEMkvC,IADJ5xC,YAAM0C,SAEN,GAAmB,MAAfA,EAAOkvC,KACT,MAAM,IAAInxC,EACN,wDAMN,GAAmC,OAJjCmxC,EADS9wC,MAAMC,QAAQ2B,EAAOkvC,MACvB,IAAIC,IAAiBC,MAAOpvC,EAAOkvC,OAEnClvC,EAAOkvC,MAEMG,UACpB,MAAM,IAAItxC,EACN,4GAGNN,EAAKyxC,KAAOA,EACZzxC,EAAK6xC,gBACyB,MAA1BtvC,EAAOsvC,iBAAkCtvC,EAAOsvC,gBACpD7xC,EAAK8xC,YAAoC,MAAtBvvC,EAAOuvC,aAA8BvvC,EAAOuvC,YAC/D9xC,EAAKgxC,YAAoC,MAAtBzuC,EAAOyuC,aAA8BzuC,EAAOyuC,YAC/DhxC,EAAK0V,UAA+B,MAAnBnT,EAAO4qB,UAA2B5qB,EAAO4qB,SAC1DntB,EAAKixC,OAA0B,MAAjB1uC,EAAO0uC,QAAyB1uC,EAAO0uC,OAErDjxC,EAAKkU,iBAAkB,EACvBlU,EAAKiU,WAAa,IAAI0wB,IAAWpyB,KAAM,KACvCvS,EAAK+xC,UAAY,KACjB/xC,EAAKoxC,OAAS,KAEdpxC,EAAK4wC,aAAe,OAiXxB,OA3ZyBzwC,OAiDvB6xC,sBAAA,WACE,OAAmB,MAAfzrC,KAAK6qC,OAGAxE,GAAiB,EADpBjsC,MAAMC,QAAQ2F,KAAKkrC,KAAKG,WAAarrC,KAAKkrC,KAAKG,UAAUpwC,OAAS,GAChC0Q,IAAI,SAAAzQ,GAAK,OAAA,OAExC8E,KAAK6qC,QAMhBY,sBAAA,SAAUZ,GACR7qC,KAAK6qC,OAASA,GAGhBY,+BAAA,SAAmBr9B,GACbs9B,GAAgBt9B,KAClBA,EAAcA,EAAuB,IAEvCA,EAAaA,EAGb,IAAIi9B,EAAYrrC,KAAKkrC,KAAKG,UACrBjxC,MAAMC,QAAQgxC,KACjBA,GAAaA,IAEf,IACIp6B,EADE2xB,EAAYyI,EAAU,GAQ5B,GALEp6B,EADEjR,KAAKsrC,iBACQl9B,EAAW,GAAIA,EAAW,GAAIw0B,IAE9Bx0B,EAAW,GAAIw0B,GAG5B5iC,KAAKurC,YAAa,CAEpB,IADA,IAAMI,SACYC,IAAA7wC,WAAAA,KAAb,IAAM4U,OACTg8B,EAAW5tC,MAAMqQ,EAAW,GAAIuB,IAElC,OAAQsB,GAAazW,OAAOmxC,GAE5B,OAAO16B,GAIXw6B,wBAAA,SAAYp/B,EAAyBkG,GACnC,MAAM,IAAIvY,EACN,qDAGCyxC,kBAAP,SAAar9B,GAIX,GAAyB,MAArBpO,KAAKqqC,aACP,MAAM,IAAIrwC,EACN,oDAGF0xC,GAAgBt9B,KAClBA,EAAcA,EAAuB,IAEvCA,EAAaA,EAEb,IAAME,EAAoBtO,KAAK4mB,SAAWxY,EAAW,GAAK,KACpDivB,EAAWjvB,EAAWA,EAAWnT,OAAS,GAChD+E,KAAK0N,UAAU,GAAK,IAAI0wB,IAAW96B,OAAQgL,EAAW,KAAM+uB,KAI5D,IASIgO,EATEQ,GAAkBz9B,EAAW,IAAI5T,OAAO4T,EAAW7K,MAAM,IAgB/D,GAXEvD,KAAKkrC,KAAK16B,MAAMq7B,GAMhBR,EADEjxC,MAAMC,QAAS2F,KAAKkrC,KAAiBG,WAC3BrrC,KAAKkrC,KAAKG,WAETrrC,KAAKkrC,KAAKG,WAGH,MAAlBrrC,KAAKwrC,WACP,IAAKzlC,OAAKC,YACFhG,KAAKwrC,UAAU7/B,IAAI,SAAA2D,GAAQ,OAAAA,EAAKhM,MAAMgM,EAAKhM,MAAMrI,OAAS,KAC1DowC,GACN,MAAM,IAAItxC,EACN,6FACsCiG,KAAKwrC,yCACdxrC,KAAKkrC,KAAKG,gBAG7CrrC,KAAKwrC,UACDH,EAAU1/B,IAAI,SAAAgE,GAAO,OAAA,IAAIyuB,IAAW96B,OAAQ,KAAMqM,OAExD,GAAI3P,KAAK4mB,SACP,MAAM,IAAI5sB,EACN,8CAORyxC,wBAAA,SAAYZ,GAAZ,WACEjsC,OAAK,WACH,IAAKnF,EAAKmtB,SACR,MAAM,IAAIltB,EACN,kEAEN,IAAM4U,EAAY7U,EAAKiU,UAAU,GAAGpK,MAAM,GAC1C,GAAiB,MAAbgL,EACF,MAAM,IAAIvU,EACN,yUAQN,GAAmB,MAAfN,EAAKoxC,OACHzwC,MAAMC,QAAQZ,EAAKyxC,KAAKG,WAC1B5xC,EAAKoxC,OACDpxC,EAAKyxC,KAAKG,UAAU1/B,IAAI,SAAAgE,GAAO,OAAAk1B,SAAWv2B,EAAWqB,MAEzDlW,EAAKoxC,QAAUhG,SAAWv2B,EAAW7U,EAAKyxC,KAAKG,kBAE5C,GAAc,MAAVR,EACLzwC,MAAMC,QAAQZ,EAAKyxC,KAAKG,WAC1B5xC,EAAKoxC,OACDpxC,EAAKyxC,KAAKG,UAAU1/B,IAAI,SAAAgE,GAAO,OAAAk1B,SAAWv2B,EAAWqB,MAEzDlW,EAAKoxC,OAAO,GAAKhG,SAAWv2B,EAAW7U,EAAKyxC,KAAKG,gBAE9C,CAIL,GAHKjxC,MAAMC,QAAQwwC,KACjBA,GAAUA,IAERA,EAAO5vC,SAAWxB,EAAKoxC,OAAO5vC,OAChC,MAAM,IAAIlB,EACN,SAASN,EAAK0B,iBAAgB1B,EAAKoxC,OAAO5vC,qCACvB4vC,EAAO5vC,2CACb4vC,GAEnB,IAAK,IAAIxoC,EAAQ,EAAGA,EAAQ5I,EAAKoxC,OAAO5vC,SAAUoH,EAAO,CACvD,IAAMrJ,EAAQ6xC,EAAOxoC,GACfsN,EAAMvV,MAAMC,QAAQZ,EAAKyxC,KAAKG,WAChC5xC,EAAKyxC,KAAKG,UAAUhpC,GACpB5I,EAAKyxC,KAAKG,UACRS,GAAiBx9B,EAAWqB,GAClC,IAAK5J,OAAKC,YAAYhN,EAAMsK,MAAOwoC,GACjC,MAAM,IAAI/xC,EACN,SAASsI,iCAAoC5I,EAAK0B,yBAChC2wC,sBACd9yC,EAAMsK,OAEhB7J,EAAKoxC,OAAOxoC,GAASrJ,OAM7ByyC,kBAAA,SACIp/B,EACAuD,GAEF,IAAIu6B,EACU,MAAVv6B,EAAiB,KAAOA,EAAqB,aAC7Cw6B,EACU,MAAVx6B,EAAiB,KAAOA,EAAkB,UAChC,MAAVA,IACFA,MAGF,IAAMm8B,EACFC,GAAgB3/B,EAAQ89B,EAAcC,EAAWpqC,KAAKqqC,cAC1Dh+B,EAAS0/B,EAAa1/B,OACtB89B,EAAe4B,EAAa5B,aAC5BC,EAAY2B,EAAa3B,UAMzB,IAAI6B,KACAC,KACJ,GAAoB,MAAhB/B,EAAsB,CACxBv6B,EAAqB,aAAIu6B,EACzB8B,EAAmBA,EAAiBzxC,OAAO2vC,GAC3CnqC,KAAKwrC,aACL,IAAoB,QAAAW,IAAApxC,WAAAA,KAAf,IAAMqxC,OACTpsC,KAAKwrC,UAAUztC,KAAK,IAAIqgC,IAAW96B,MAAO8oC,EAAM9oC,SAKlD4oC,EAAkBA,EAAgB1xC,OAAOwF,KAAKwrC,WAUhD,GARiB,MAAbpB,IACFx6B,EAAkB,UAAIw6B,EACtB6B,EAAmBA,EAAiBzxC,OAAO4vC,GAE3CpqC,KAAKqqC,aAAeD,EAAUnvC,QAGfgxC,EAAiB,aAAc/7B,GAClC,CAEZ,IAAMm8B,GACDhgC,GAAQ7R,OAAOyxC,GACdK,EAAgBtsC,KAAK0N,UAAUlT,OAAO0xC,GAEtCK,EAAoBvsC,KAAK0N,UAC/B1N,KAAK0N,UAAY4+B,EACjB,IAAM17B,EAAStX,YAAMoS,gBAAM2gC,EAAWz8B,GAEtC,OADA5P,KAAK0N,UAAY6+B,EACV37B,EAEP,OAAOtX,YAAMoS,gBAAMW,EAAQuD,IAK/B67B,iBAAA,SAAKp/B,EAAyBuD,GAA9B,WAIE,OAAOhR,OAAK,WACV,IAAM2T,EAAiB,MAAV3C,EAAiB,KAAOA,EAAa,KAC5CrJ,EAAqB,MAAVqJ,EAAiB,KAAOA,EAAiB,SACtDu6B,EACU,MAAVv6B,EAAiB,KAAOA,EAAqB,aAGjD,GADAvD,EAASgtB,GAAoBhtB,GACT,MAAhB89B,EAAsB,CACxB,GAAI1wC,EAAKmtB,SACP,MAAM,IAAI5sB,EACN,8CAEJmwC,EAAe1wC,EAAK+yC,gBAAgBngC,GAIxC,GAAY,MAARkG,EACF,MAAM,IAAIvY,EAAoB,0CAGhC,IAAMyyC,EACFryC,MAAMC,QAAQZ,EAAKyxC,KAAKG,WAAa5xC,EAAKyxC,KAAKG,UAAUpwC,OAAS,EACtE,GAAIkvC,EAAalvC,SAAWwxC,EAC1B,MAAM,IAAI1yC,EACN,iBAAiB0yC,8BACdtC,EAAalvC,6BAEHoR,EAAO/I,MACG,GACzB7J,EAAKixC,QACPphC,QAAQC,KACJ,oEAGN,IAAMmjC,GAA0BnmC,YAe1BomC,EACFC,GAbS,SAACvgC,EAAgBw+B,GAG5B,IAAM1uB,EACF1iB,EAAKyxC,KAAKr6B,MAAMxE,GAAQ7R,OAAOqwC,GAAS6B,GAE5C,OAAQvwB,EAAQ,GAAIA,EAAQ5Y,MAAM,KAOtB8I,EAAQ89B,EAAc1wC,EAAKgxC,YAAa,KAAM,KACpDhxC,EAAKixC,QACPC,EAAagC,EAAW,GACxBxwB,EAAUwwB,EAAW,GACrB9B,EAAS8B,EAAW,GAE1B,GAAIlzC,EAAKmtB,SACP,MAAM,IAAI5sB,EACN,6CAGN,IAAM4W,EAASnX,EAAK6xC,gBAAkBnvB,EAAUwuB,EAIhD,OAAIlxC,EAAK8xC,aACC36B,GAAQpW,OAAOqwC,GAEhBj6B,KAKb66B,4BAAA,SAAgBp/B,GAAhB,WACE,OAAOzN,OAAK,WAGV,IAAIurC,EAAetF,QAAUx4B,EAAO/I,OAKpC,OAFA6mC,EAAelhB,GADfkhB,EAAerrC,MAAQqrC,GAAe,EAAG,KAGrC/vC,MAAMC,QAAQZ,EAAKyxC,KAAKG,WACnB5xC,EAAKyxC,KAAKG,UAAU1/B,IACvB,SAAAgE,GAAO,OAAAA,EAAM,EAAIk9B,GAAO1C,GAAe,EAAGx6B,IAAQw6B,IAE/C1wC,EAAKyxC,KAAKG,UAAY,GACxBwB,GAAO1C,GAAe,EAAG1wC,EAAKyxC,KAAKG,cACnClB,MAKX5wC,sBAAIkyC,oCAAJ,WACE,OAAKzrC,KAAK+K,UAIH/K,KAAKkrC,KAAKj8B,qDAGnB1V,sBAAIkyC,uCAAJ,WAEE,OAAKzrC,KAAK+K,UAGH/K,KAAKkrC,KAAKh8B,oBAFRlP,KAAKkrC,KAAKzgC,yCAKrBghC,sBAAA,WACE,IAAMzvC,GACJsvC,gBAAiBtrC,KAAKsrC,gBACtBC,YAAavrC,KAAKurC,YAClBd,YAAazqC,KAAKyqC,YAClB7jB,SAAU5mB,KAAK4mB,SACf8jB,OAAQ1qC,KAAK0qC,QAEU,MAArB1qC,KAAKqqC,eACPruC,EAAOquC,aAAerqC,KAAKqqC,cAE7B,IAAMyC,EAAa9sC,KAAKkrC,KAAKjvC,YAC7BD,EAAOkvC,MACLpvC,UAAWkE,KAAKkrC,KAAKnvC,eACrBC,OAAQ8wC,GAEV,IAAMvT,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAxZFyvC,YAAY,SADIh9B,oBA4ZXxO,iBAAiBC,SAASurC,IASxC,mBAAA,4DAQA,OARsC7xC,UAAA6U,mBAmKpC,WAAYzS,GAAZ,MACE1C,YAAM0C,gBANCvC,qBAAqB,OACrBA,6BAA6B,eAC7BA,gCAAgC,aAChCA,2BAAkD,QAIzDA,EAAKgoC,MAAQzlC,EAAOylC,MACpBhoC,EAAKw/B,WAAa8C,GACO,MAArB//B,EAAOi9B,WAAqBx/B,EAAKszC,mBACL/wC,EAAOi9B,YACvCx/B,EAAKuiC,QAA4B,MAAlBhgC,EAAOggC,SAAyBhgC,EAAOggC,QAEtDviC,EAAKujC,kBAAoBd,GACrBlgC,EAAOghC,mBAAqBvjC,EAAKwjC,4BACrCxjC,EAAKuzC,qBAAuB9Q,GACxBlgC,EAAOgxC,sBAAwBvzC,EAAKwzC,+BAExCxzC,EAAKwiC,gBACDC,GAAelgC,EAAOigC,iBAAmBxiC,EAAK0iC,0BAElD1iC,EAAK0jC,kBAAoBZ,GAAevgC,EAAOmhC,mBAC/C1jC,EAAKyzC,qBAAuB3Q,GAAevgC,EAAOkxC,sBAClDzzC,EAAK6iC,gBAAkBC,GAAevgC,EAAOsgC,iBAE7C7iC,EAAKyjC,iBAAmBb,EAAcrgC,EAAOkhC,kBAC7CzjC,EAAK0zC,oBAAsB9Q,EAAcrgC,EAAOmxC,qBAChD1zC,EAAK2iC,eAAiBC,EAAcrgC,EAAOogC,gBAE3C3iC,EAAK2zC,QAAUC,IACV,EAAGC,IAAgB,EAAqB,MAAlBtxC,EAAOoxC,QAAkB,EAAIpxC,EAAOoxC,YAC/D3zC,EAAK8zC,iBAAmBF,IACtB,EACAC,IACK,EAA8B,MAA3BtxC,EAAOuxC,iBAA2B,EAAIvxC,EAAOuxC,qBAEvD9zC,EAAK4xC,UAAY5xC,EAAKgoC,MACtBhoC,EAAK+zC,YAAc,KACnB/zC,EAAKg0C,qBAAuB,OAmGhC,OApKmC7zC,OAoEjC8zC,kBAAA,SAAMt/B,GACJA,EAAaipB,GAAmBjpB,GAEhCpO,KAAKu9B,OAASv9B,KAAKw9B,UACf,UAAWpvB,EAAWA,EAAWnT,OAAS,GAAI+E,KAAKyhC,OAAQ,KAC3DzhC,KAAKg9B,kBAAmBh9B,KAAKm9B,mBAAmB,EAChDn9B,KAAKk9B,kBACTl9B,KAAK2tC,gBAAkB3tC,KAAKw9B,UACxB,oBAAqBx9B,KAAKyhC,MAAOzhC,KAAKyhC,OAAQ,KAC9CzhC,KAAKgtC,qBAAsBhtC,KAAKktC,sBAAsB,EACtDltC,KAAKmtC,qBACLntC,KAAKg8B,QACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAASx9B,KAAKyhC,OAAQ,KAAMzhC,KAAKi8B,gBACjCj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,gBAErCp8B,KAAKwF,KAAO,KAEdxF,KAAKgP,OAAQ,GASf0+B,iBAAA,SAAKrhC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,GAAsB,KADtByN,EAASA,GACEpR,OACT,MAAM,IAAIlB,EACN,8CAA8CsS,EAAOpR,YAE3D,IAAI2yC,EAAavhC,EAAO,GACxBA,EAASA,EAAO,GAChB,IAcIwhC,EAdEtnC,EAAiC,MAAtBqJ,EAAiB,UAAoBA,EAAiB,SAEnE,EAAInW,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,GAAyB,MAApB3zC,EAAK+zC,cAC/C/zC,EAAK+zC,YAAcM,GACI,WAAM,OAAA/3B,WAAa1J,IACnB5S,EAAK2zC,QAAS7mC,IAEnC,EAAI9M,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,GACxB,MAA7B9zC,EAAKg0C,uBACPh0C,EAAKg0C,qBACDK,GACI,WAAM,OAAA/3B,WAAa63B,IAAan0C,EAAK8zC,iBACrChnC,IAGV,IAAMwnC,EAAiBt0C,EAAK+zC,YACtBQ,EAAoBv0C,EAAKg0C,qBAE7BI,EAAIjM,GADQ,MAAVmM,EACQpuC,MAAQ0M,EAAQ0hC,GAEhB1hC,EAFyB5S,EAAK8jC,OAAO3xB,QAIhC,MAAbnS,EAAK+L,OACPqoC,EAAIlQ,GAAUkQ,EAAGp0C,EAAK+L,KAAKoG,SAEZ,MAAboiC,IACFJ,EAAajuC,MAAQiuC,EAAYI,IAEnC,IAAIp9B,EAAS/Q,MAAQguC,EAAGjM,GAAMgM,EAAYn0C,EAAKk0C,gBAAgB/hC,SAM/D,OALuB,MAAnBnS,EAAKw/B,aACProB,EAASnX,EAAKw/B,WAAWvtB,MAAMkF,KAIzBA,EAAQA,MAIpB88B,sBAAA,WACE,IAAM1xC,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrC+C,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CkB,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,kBAEnBhU,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAjKF0xC,YAAY,mBADcO,oBAqKrBhuC,iBAAiBC,SAASwtC,IAwGxC,mBAEE,WAAY1xC,UACVA,EAAOkvC,KAAO,IAAIwC,GAAc1xC,GAChC1C,YAAM0C,SAuGV,OA3G+BpC,OAQ7Bs0C,iBAAA,SAAK7hC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACmB,MAAzBnF,EAAKyxC,KAAKsC,cACZW,UAAY10C,EAAKyxC,KAAKsC,aACtB/zC,EAAKyxC,KAAKsC,YAAc,MAEY,MAAlC/zC,EAAKyxC,KAAKuC,uBACZU,UAAY10C,EAAKyxC,KAAKuC,sBACtBh0C,EAAKyxC,KAAKuC,qBAAuB,MAEnC,IAAMl7B,EAAiB,MAAV3C,EAAiB,KAAOA,EAAa,KAC5CrJ,EAAqB,MAAVqJ,EAAiB,KAAOA,EAAiB,SACpDu6B,EACQ,MAAVv6B,EAAiB,KAAOA,EAAqB,aACjD,OAAOtW,YAAMuX,YAAKxE,GAASkG,OAAMhM,WAAU4jC,oBAM/C5wC,sBAAI20C,yBAAJ,WACE,OAAQluC,KAAKkrC,KAAuBzJ,uCAGtCloC,sBAAI20C,8BAAJ,WACE,OAAQluC,KAAKkrC,KAAuBjS,4CAGtC1/B,sBAAI20C,2BAAJ,WACE,OAAQluC,KAAKkrC,KAAuBlP,yCAGtCziC,sBAAI20C,qCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBlO,mDAGtCzjC,sBAAI20C,wCAAJ,WACE,OAAQluC,KAAKkrC,KAAuB8B,sDAGtCzzC,sBAAI20C,mCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBjP,iDAGtC1iC,sBAAI20C,qCAAJ,WACE,OAAQluC,KAAKkrC,KAAuB/N,mDAGtC5jC,sBAAI20C,wCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBgC,sDAGtC3zC,sBAAI20C,mCAAJ,WACE,OAAQluC,KAAKkrC,KAAuB5O,iDAGtC/iC,sBAAI20C,oCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBhO,kDAGtC3jC,sBAAI20C,uCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBiC,qDAGtC5zC,sBAAI20C,kCAAJ,WACE,OAAQluC,KAAKkrC,KAAuB9O,gDAGtC7iC,sBAAI20C,2BAAJ,WACE,OAAQluC,KAAKkrC,KAAuBkC,yCAGtC7zC,sBAAI20C,oCAAJ,WACE,OAAQluC,KAAKkrC,KAAuBqC,kDAGtCW,sBAAA,WACE,IAAMlyC,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrC+C,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CkB,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,kBAEnBhU,EAAajgC,YAAM2C,qBAGzB,cAFOs9B,EAAiB,KACxBhgC,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAxGFkyC,YAAY,eADUzC,oBA4GjBxrC,iBAAiBC,SAASguC,IAsExC,mBAoCE,WAAYlyC,GAAZ,MACE1C,YAAM0C,gBAZCvC,qBAAqB,OACrBA,+BAA+B,cAE/BA,6BAA6B,eAC7BA,gCAAgC,aAChCA,2BAAkD,QASzDA,EAAKgoC,MAAQzlC,EAAOylC,MACpBhoC,EAAKw/B,WAAa8C,QACQ7iC,IAAtB8C,EAAOi9B,WAA2Bx/B,EAAKszC,mBACL/wC,EAAOi9B,YAC7Cx/B,EAAK20C,oBAAsBrS,QACQ7iC,IAA/B8C,EAAOoyC,oBACH30C,EAAK40C,6BACLryC,EAAOoyC,qBACf30C,EAAKuiC,QAA4B,MAAlBhgC,EAAOggC,SAAyBhgC,EAAOggC,QAEtDviC,EAAKujC,kBAAoBd,GACrBlgC,EAAOghC,mBAAqBvjC,EAAKwjC,4BACrCxjC,EAAKuzC,qBAAuB9Q,GACxBlgC,EAAOgxC,sBAAwBvzC,EAAKwzC,+BAExCxzC,EAAKwiC,gBACDC,GAAelgC,EAAOigC,iBAAmBxiC,EAAK0iC,0BAElD1iC,EAAK0jC,kBAAoBZ,GAAevgC,EAAOmhC,mBAC/C1jC,EAAKyzC,qBAAuB3Q,GAAevgC,EAAOkxC,sBAClDzzC,EAAK6iC,gBAAkBC,GAAevgC,EAAOsgC,iBAE7C7iC,EAAKyjC,iBAAmBb,EAAcrgC,EAAOkhC,kBAC7CzjC,EAAK0zC,oBAAsB9Q,EAAcrgC,EAAOmxC,qBAChD1zC,EAAK2iC,eAAiBC,EAAcrgC,EAAOogC,gBAE3C3iC,EAAK2zC,QAAUC,IACV,EAAGC,IAAgB,EAAqB,MAAlBtxC,EAAOoxC,QAAkB,EAAIpxC,EAAOoxC,YAC/D3zC,EAAK8zC,iBAAmBF,IACtB,EACAC,IACK,EAA8B,MAA3BtxC,EAAOuxC,iBAA2B,EAAIvxC,EAAOuxC,qBAEvD9zC,EAAK60C,eAAiBtyC,EAAOsyC,eAC7B70C,EAAK4xC,UAAY5xC,EAAKgoC,MACtBhoC,EAAK+zC,YAAc,KACnB/zC,EAAKg0C,qBAAuB,OA+KhC,OA1P6B7zC,OA8EpB20C,kBAAP,SAAangC,GAEX,IAAMivB,GADNjvB,EAAaipB,GAAmBjpB,IACJA,EAAWnT,OAAS,GAChD+E,KAAKu9B,OAASv9B,KAAKw9B,UACf,UAAWH,EAAuB,EAAbr9B,KAAKyhC,OAAY,KAAMzhC,KAAKg9B,kBACjDh9B,KAAKm9B,mBAAmB,EAAMn9B,KAAKk9B,kBACvCl9B,KAAK2tC,gBAAkB3tC,KAAKw9B,UACxB,oBAAqBx9B,KAAKyhC,MAAoB,EAAbzhC,KAAKyhC,OAAY,KAClDzhC,KAAKgtC,qBAAsBhtC,KAAKktC,sBAAsB,EACtDltC,KAAKmtC,qBACLntC,KAAKg8B,QACPh8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAAsB,EAAbx9B,KAAKyhC,OAAY,KAAMzhC,KAAKi8B,gBACrCj8B,KAAKs8B,iBAAiB,EAAMt8B,KAAKo8B,gBAErCp8B,KAAKwF,KAAO,KAIdxF,KAAKgP,OAAQ,GAGfu/B,iBAAA,SAAKliC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAEV,GAAsB,KADtByN,EAASA,GACEpR,OACT,MAAM,IAAIlB,EACN,uDACGsS,EAAOpR,YAGhB,IAAMsL,EAAiC,MAAtBqJ,EAAiB,UAAoBA,EAAiB,SACnE4+B,EAAWniC,EAAO,GACtBA,EAASA,EAAO,GAEZ,EAAI5S,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,GAAyB,MAApB3zC,EAAK+zC,cAC/C/zC,EAAK+zC,YAAcM,GACI,WAAM,OAAA/3B,WAAa1J,IACnB5S,EAAK2zC,QAAS7mC,EAAU,IAE7C,EAAI9M,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,GACxB,MAA7B9zC,EAAKg0C,uBACPh0C,EAAKg0C,qBACDK,GACI,WAAM,OAAA/3B,WAAay4B,IAAW/0C,EAAK8zC,iBAAkBhnC,EACrD,IAEV,IAEIkoC,EACAC,EACAC,EAJEZ,EAASt0C,EAAK+zC,YACdQ,EAAYv0C,EAAKg0C,qBAIvB,GAA4B,IAAxBh0C,EAAK60C,eAAsB,CAC7B,IAAMM,EAAUC,GAAqBp1C,EAAK8jC,OAAO3xB,OAAQ,EAAGnS,EAAKgoC,OAC3DqN,EACFD,GAAqBp1C,EAAK8jC,OAAO3xB,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OACxD/C,EAAUmQ,GACZp1C,EAAK8jC,OAAO3xB,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OACvCsN,EACFF,GAAqBp1C,EAAKk0C,gBAAgB/hC,OAAQ,EAAGnS,EAAKgoC,OACxDuN,EAAmBH,GACrBp1C,EAAKk0C,gBAAgB/hC,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OAC5CwN,EAAmBJ,GACrBp1C,EAAKk0C,gBAAgB/hC,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OAElDyN,SAAiBC,SAAiBC,SAClC,EAAI31C,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,GACrC8B,EAAUvvC,MAAQ0M,EAAQ0hC,EAAO,IACjCoB,EAAUxvC,MAAQ0M,EAAQ0hC,EAAO,IACjCqB,EAAUzvC,MAAQ0M,EAAQ0hC,EAAO,MAEjCmB,EAAU7iC,EACV8iC,EAAU9iC,EACV+iC,EAAU/iC,GAGZ,IAAIgjC,EAAKzN,GAAMsN,EAASN,GACpBU,EAAK1N,GAAMuN,EAASL,GACpBS,EAAK3N,GAAMwN,EAAS1Q,GACxB,GAAIjlC,EAAKuiC,QAAS,CAChB,IAAMwT,EAAQnmB,GAAsB5vB,EAAK+L,KAAKoG,OAAQ,EAAGnS,EAAKgoC,OACxDgO,EACFpmB,GAAsB5vB,EAAK+L,KAAKoG,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OACvDiO,EAAQrmB,GACV5vB,EAAK+L,KAAKoG,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OAC3C4N,EAAK1R,GAAU0R,EAAIG,GACnBF,EAAK3R,GAAU2R,EAAIG,GACnBF,EAAK5R,GAAU4R,EAAIG,GAGrB,IAAIC,SACAC,SACAC,SACA,EAAIp2C,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,GACvDoC,EAAYhwC,MAAQ6uC,EAAUR,EAAU,IACxC4B,EAAYjwC,MAAQ6uC,EAAUR,EAAU,IACxC6B,EAAYlwC,MAAQ6uC,EAAUR,EAAU,MAExC2B,EAAYnB,EACZoB,EAAYpB,EACZqB,EAAYrB,GAEdC,EAAIh1C,EAAK20C,oBAAoB1iC,MACzB7L,MAAQwvC,EAAIzN,GAAM+N,EAAWZ,KACjCL,EAAIj1C,EAAK20C,oBAAoB1iC,MACzB7L,MAAQyvC,EAAI1N,GAAMgO,EAAWZ,KACjCL,EAAKl1C,EAAKw/B,WAAWvtB,MACjB7L,MAAQ0vC,EAAI3N,GAAMjiC,MAAQ+uC,EAAGmB,GAAYZ,SACxC,CACD,EAAIx1C,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,IACrC/gC,EAAS1M,MAAQ0M,EAAQ0hC,EAAO,KAElC,IAAI+B,EAAUlO,GAAMv1B,EAAQ5S,EAAK8jC,OAAO3xB,QACpCnS,EAAKuiC,UACP8T,EAAUnS,GAAUmS,EAASr2C,EAAK+L,KAAKoG,SAErC,EAAInS,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,IACrCoB,EAAW7uC,MAAQ6uC,EAAUR,EAAU,KAEzC,IAAM+B,EAAcnO,GAChB4M,EACAK,GACIp1C,EAAKk0C,gBAAgB/hC,OAAQ,EAAG,EAAInS,EAAKgoC,QAI3CuO,GAFAX,EAAKR,GAAqBiB,EAAS,EAAGr2C,EAAKgoC,OAC3C6N,EAAKT,GAAqBiB,EAASr2C,EAAKgoC,MAAOhoC,EAAKgoC,OACvCoN,GAAqBkB,EAAa,EAAGt2C,EAAKgoC,QACvDwO,EACFpB,GAAqBkB,EAAat2C,EAAKgoC,MAAOhoC,EAAKgoC,OAEvDgN,EAAIh1C,EAAK20C,oBAAoB1iC,MAAM7L,MAAQwvC,EAAIW,IAC/CtB,EAAIj1C,EAAK20C,oBAAoB1iC,MAAM7L,MAAQyvC,EAAIW,IAEzCV,EAAKV,GAAqBiB,EAAS,EAAIr2C,EAAKgoC,MAAOhoC,EAAKgoC,OAA9D,IACMyO,EAAatO,GACfjiC,MAAQ+uC,EAAGF,GACXK,GACIp1C,EAAKk0C,gBAAgB/hC,OAAQ,EAAInS,EAAKgoC,MAAOhoC,EAAKgoC,QAC1DkN,EAAKl1C,EAAKw/B,WAAWvtB,MAAM7L,MAAQ0vC,EAAIW,IAGzC,IAAMrC,EAAIhuC,MACNF,MAAQ8uC,EAAGD,GAAW7uC,MAAQE,MAAQC,EAAU,GAAIqG,MAAQsoC,IAAKE,IAErE,OAAQd,EAAGA,MAIfU,sBAAA,WACE,IAAMvyC,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrCmV,oBAAqB1R,GAAoB18B,KAAKouC,qBAC9CpS,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CkB,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,iBACvBe,eAAgBtuC,KAAKsuC,gBAEjB/U,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAvPFuyC,YAAY,aADQN,oBA2PfhuC,iBAAiBC,SAASquC,IAgDxC,mBAEE,WAAYvyC,UACoB,IAA1BA,EAAOsyC,gBACThlC,QAAQC,KACJ,kHAGNvN,EAAOkvC,KAAO,IAAIqD,GAAQvyC,GAC1B1C,YAAM0C,SAwHV,OAjIyBpC,OAavBu2C,iBAAA,SAAK9jC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACmB,MAAzBnF,EAAKyxC,KAAKsC,cACZW,UAAY10C,EAAKyxC,KAAKsC,aACtB/zC,EAAKyxC,KAAKsC,YAAc,MAEY,MAAlC/zC,EAAKyxC,KAAKuC,uBACZU,UAAY10C,EAAKyxC,KAAKuC,sBACtBh0C,EAAKyxC,KAAKuC,qBAAuB,MAEnC,IAAMl7B,EAAiB,MAAV3C,EAAiB,KAAOA,EAAa,KAC5CrJ,EAAqB,MAAVqJ,EAAiB,KAAOA,EAAiB,SACpDu6B,EACQ,MAAVv6B,EAAiB,KAAOA,EAAqB,aACjD,OAAOtW,YAAMuX,YAAKxE,GAASkG,OAAMhM,WAAU4jC,oBAI/C5wC,sBAAI42C,yBAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBzJ,uCAGhCloC,sBAAI42C,8BAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBjS,4CAGhC1/B,sBAAI42C,uCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBkD,qDAGhC70C,sBAAI42C,2BAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBlP,yCAGhCziC,sBAAI42C,qCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBlO,mDAGhCzjC,sBAAI42C,wCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiB8B,sDAGhCzzC,sBAAI42C,mCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBjP,iDAGhC1iC,sBAAI42C,qCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiB/N,mDAGhC5jC,sBAAI42C,wCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBgC,sDAGhC3zC,sBAAI42C,mCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiB5O,iDAGhC/iC,sBAAI42C,oCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBhO,kDAGhC3jC,sBAAI42C,uCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBiC,qDAGhC5zC,sBAAI42C,kCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiB9O,gDAGhC7iC,sBAAI42C,2BAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBkC,yCAGhC7zC,sBAAI42C,oCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBqC,kDAGhCh0C,sBAAI42C,kCAAJ,WACE,OAAQnwC,KAAKkrC,KAAiBoD,gDAGhC6B,sBAAA,WACE,IAAMn0C,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrCmV,oBAAqB1R,GAAoB18B,KAAKouC,qBAC9CpS,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CkB,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,iBACvBe,eAAgBtuC,KAAKsuC,gBAEjB/U,EAAajgC,YAAM2C,qBAGzB,cAFOs9B,EAAiB,KACxBhgC,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGFm0C,aAAP,SACI1zC,EACAT,GAIF,OAHgC,IAA5BA,EAAsB,gBACxBA,EAAuB,eAAI,GAEtB,IAAIS,EAAIT,IA9HVm0C,YAAY,SADI1E,oBAkIXxrC,iBAAiBC,SAASiwC,IA+ExC,mBAqCE,WAAYn0C,GAAZ,MACE1C,YAAM0C,gBAZCvC,qBAAqB,OACrBA,+BAA+B,cAC/BA,6BAA6B,eAC7BA,gCAAgC,aAEhCA,2BAA2B,QASlCA,EAAKgoC,MAAQzlC,EAAOylC,MACpBhoC,EAAKw/B,WAAa8C,QACQ7iC,IAAtB8C,EAAOi9B,WAA2Bx/B,EAAKszC,mBACL/wC,EAAOi9B,YAC7Cx/B,EAAK20C,oBAAsBrS,QACQ7iC,IAA/B8C,EAAOoyC,oBACH30C,EAAK40C,6BACLryC,EAAOoyC,qBACf30C,EAAKuiC,QAA4B,MAAlBhgC,EAAOggC,SAAyBhgC,EAAOggC,QAEtDviC,EAAKujC,kBAAoBd,GACrBlgC,EAAOghC,mBAAqBvjC,EAAKwjC,4BACrCxjC,EAAKuzC,qBAAuB9Q,GACxBlgC,EAAOgxC,sBAAwBvzC,EAAKwzC,+BAExCxzC,EAAKwiC,gBACDC,GAAelgC,EAAOigC,iBAAmBxiC,EAAK0iC,0BAClD1iC,EAAK22C,eAAiBp0C,EAAOo0C,eAE7B32C,EAAK0jC,kBAAoBZ,GAAevgC,EAAOmhC,mBAC/C1jC,EAAKyzC,qBAAuB3Q,GAAevgC,EAAOkxC,sBAClDzzC,EAAK6iC,gBAAkBC,GAAevgC,EAAOsgC,iBAE7C7iC,EAAKyjC,iBAAmBb,EAAcrgC,EAAOkhC,kBAC7CzjC,EAAK0zC,oBAAsB9Q,EAAcrgC,EAAOmxC,qBAChD1zC,EAAK2iC,eAAiBC,EAAcrgC,EAAOogC,gBAE3C3iC,EAAK2zC,QAAUC,IACV,EAAGC,IAAgB,EAAqB,MAAlBtxC,EAAOoxC,QAAkB,EAAIpxC,EAAOoxC,YAC/D3zC,EAAK8zC,iBAAmBF,IACtB,EACAC,IACK,EAA8B,MAA3BtxC,EAAOuxC,iBAA2B,EAAIvxC,EAAOuxC,qBAEvD9zC,EAAK60C,eAAiBtyC,EAAOsyC,eAC7B70C,EAAK4xC,WAAa5xC,EAAKgoC,MAAOhoC,EAAKgoC,OACnChoC,EAAK+zC,YAAc,KACnB/zC,EAAKg0C,qBAAuB,OA6MhC,OA1R8B7zC,OAgFrBy2C,kBAAP,SAAajiC,GAEX,IAQI6tB,IAREoB,GADNjvB,EAAaipB,GAAmBjpB,IACJA,EAAWnT,OAAS,GAShD,GARA+E,KAAKu9B,OAASv9B,KAAKw9B,UACf,UAAWH,EAAuB,EAAbr9B,KAAKyhC,OAAY,KAAMzhC,KAAKg9B,kBACjDh9B,KAAKm9B,mBAAmB,EAAMn9B,KAAKk9B,kBACvCl9B,KAAK2tC,gBAAkB3tC,KAAKw9B,UACxB,oBAAqBx9B,KAAKyhC,MAAoB,EAAbzhC,KAAKyhC,OAAY,KAClDzhC,KAAKgtC,qBAAsBhtC,KAAKktC,sBAAsB,EACtDltC,KAAKmtC,qBAELntC,KAAKg8B,QAAS,CAChB,GAAIh8B,KAAKowC,eAAgB,CACvB,IAAME,EAAmBtwC,KAAKi8B,gBACxBsU,EAAgBvwC,KAAKyhC,MAC3BxF,EAAkB,mBAAK,4DAWvB,OAXgDriC,OAG9C42C,kBAAA,SAAMltC,EAAcrK,GAElB,IAAMw3C,EAAKH,EAAiB5kC,OAAO6kC,IAC7BG,GAAK,IAAK7pC,IAAQ6E,OAAO6kC,IACzBI,EAASL,EAAiB5kC,OAAuB,EAAhB6kC,IACvC,OAAOhgB,GACHA,GAAuBkgB,EAAIC,GAAKC,OATQjqC,eAC3B,qBAYrBu1B,EAAkBj8B,KAAKi8B,gBAEzBj8B,KAAKwF,KAAOxF,KAAKw9B,UACb,QAAsB,EAAbx9B,KAAKyhC,OAAY,KAAMxF,EAAiBj8B,KAAKs8B,iBACtD,EAAMt8B,KAAKo8B,qBAEfp8B,KAAKwF,KAAO,KAIdxF,KAAKgP,OAAQ,GAGfqhC,iBAAA,SAAKhkC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACV,IAAM2H,EAAiC,MAAtBqJ,EAAiB,UAAoBA,EAAiB,SAEvE,GAAsB,KADtBvD,EAASA,GACEpR,OACT,MAAM,IAAIlB,EACN,wDACGsS,EAAOpR,YAEhB,IAAIuzC,EAAWniC,EAAO,GAChBukC,EAAWvkC,EAAO,GACxBA,EAASA,EAAO,GACZ,EAAI5S,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,GAAyB,MAApB3zC,EAAK+zC,cAC/C/zC,EAAK+zC,YAAcM,GACI,WAAM,OAAA/3B,WAAa1J,IACnB5S,EAAK2zC,QAAS7mC,EAAU,IAE7C,EAAI9M,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,GACxB,MAA7B9zC,EAAKg0C,uBACPh0C,EAAKg0C,qBACDK,GACI,WAAM,OAAA/3B,WAAay4B,IAAW/0C,EAAK8zC,iBAAkBhnC,EACrD,IAEV,IAIIhM,EACAm0B,EACAmiB,EACAC,EAPE/C,EAASt0C,EAAK+zC,YACdQ,EACFv0C,EAAKg0C,qBAMT,GAA4B,IAAxBh0C,EAAK60C,eAAsB,CAC7B,IAAMyC,EAAUlC,GAAqBp1C,EAAK8jC,OAAO3xB,OAAQ,EAAGnS,EAAKgoC,OAC3DuP,EACFnC,GAAqBp1C,EAAK8jC,OAAO3xB,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OACxDwP,EAAUpC,GACZp1C,EAAK8jC,OAAO3xB,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OACvCyP,EAAUrC,GACZp1C,EAAK8jC,OAAO3xB,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OACvC0P,EACFtC,GAAqBp1C,EAAKk0C,gBAAgB/hC,OAAQ,EAAGnS,EAAKgoC,OACxD2P,EAAmBvC,GACrBp1C,EAAKk0C,gBAAgB/hC,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OAC5C4P,EAAmBxC,GACrBp1C,EAAKk0C,gBAAgB/hC,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OAChD6P,EAAmBzC,GACrBp1C,EAAKk0C,gBAAgB/hC,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OAElD8P,SAAiBC,SAAiBC,SAAiBC,SACnD,EAAIj4C,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,GACrCmE,EAAU5xC,MAAQ0M,EAAQ0hC,EAAO,IACjCyD,EAAU7xC,MAAQ0M,EAAQ0hC,EAAO,IACjC0D,EAAU9xC,MAAQ0M,EAAQ0hC,EAAO,IACjC2D,EAAU/xC,MAAQ0M,EAAQ0hC,EAAO,MAEjCwD,EAAUllC,EACVmlC,EAAUnlC,EACVolC,EAAUplC,EACVqlC,EAAUrlC,GAGZ,IAAIslC,EAAK/P,GAAM2P,EAASR,GACpBa,EAAKhQ,GAAM4P,EAASR,GACpBa,EAAKjQ,GAAM6P,EAASR,GACpBa,EAAKlQ,GAAM8P,EAASR,GACxB,GAAIz3C,EAAKuiC,QAAS,CAChB,IAAM+V,EAAQ1oB,GAAsB5vB,EAAK+L,KAAKoG,OAAQ,EAAGnS,EAAKgoC,OACxDuQ,EACF3oB,GAAsB5vB,EAAK+L,KAAKoG,OAAQnS,EAAKgoC,MAAOhoC,EAAKgoC,OACvDwQ,EAAQ5oB,GACV5vB,EAAK+L,KAAKoG,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OACrCyQ,EAAQ7oB,GACV5vB,EAAK+L,KAAKoG,OAAqB,EAAbnS,EAAKgoC,MAAWhoC,EAAKgoC,OAC3CkQ,EAAKhU,GAAUgU,EAAII,GACnBH,EAAKjU,GAAUiU,EAAII,GACnBH,EAAKlU,GAAUkU,EAAII,GACnBH,EAAKnU,GAAUmU,EAAII,GAGrB,IAAIC,SAAmBC,SAAmBC,SACtCC,SACA,EAAI74C,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,GACvD4E,EAAYxyC,MAAQ6uC,EAAUR,EAAU,IACxCoE,EAAYzyC,MAAQ6uC,EAAUR,EAAU,IACxCqE,EAAY1yC,MAAQ6uC,EAAUR,EAAU,IACxCsE,EAAY3yC,MAAQ6uC,EAAUR,EAAU,MAExCmE,EAAY3D,EACZ4D,EAAY5D,EACZ6D,EAAY7D,EACZ8D,EAAY9D,GAEdj0C,EAAId,EAAK20C,oBAAoB1iC,MACzB7L,MAAQ8xC,EAAI/P,GAAMuQ,EAAWhB,KACjCziB,EAAIj1B,EAAK20C,oBAAoB1iC,MACzB7L,MAAQ+xC,EAAIhQ,GAAMwQ,EAAWhB,KACjCP,EAAIhxC,MACAF,MAAQ+uB,EAAGkiB,GACXjxC,MACIpF,EACAd,EAAKw/B,WAAWvtB,MACZ7L,MAAQgyC,EAAIjQ,GAAMyQ,EAAWhB,OACzCP,EAAIr3C,EAAK20C,oBAAoB1iC,MACzB7L,MAAQiyC,EAAIlQ,GAAM0Q,EAAWhB,SAC5B,CACD,EAAI73C,EAAK2zC,SAAW3zC,EAAK2zC,QAAU,IACrC/gC,EAAS1M,MAAQ0M,EAAQ0hC,EAAO,KAElC,IAAIU,EAAI7M,GAAMv1B,EAAQ5S,EAAK8jC,OAAO3xB,QAC9B,EAAInS,EAAK8zC,kBAAoB9zC,EAAK8zC,iBAAmB,IACvDiB,EAAW7uC,MAAQ6uC,EAAUR,EAAU,KAEzCS,EAAI5uC,MAAQ4uC,EAAG7M,GAAM4M,EAAU/0C,EAAKk0C,gBAAgB/hC,SAChDnS,EAAKuiC,UACPyS,EAAI9Q,GAAU8Q,EAAGh1C,EAAK+L,KAAKoG,SAG7B,IAAM2mC,EAAK1D,GAAqBJ,EAAG,EAAGh1C,EAAKgoC,OACrC+Q,EAAK3D,GAAqBJ,EAAGh1C,EAAKgoC,MAAOhoC,EAAKgoC,OAC9CgR,EAAK5D,GAAqBJ,EAAgB,EAAbh1C,EAAKgoC,MAAWhoC,EAAKgoC,OAClDiR,EAAK7D,GAAqBJ,EAAgB,EAAbh1C,EAAKgoC,MAAWhoC,EAAKgoC,OAExDlnC,EAAId,EAAK20C,oBAAoB1iC,MAAM6mC,GACnC7jB,EAAIj1B,EAAK20C,oBAAoB1iC,MAAM8mC,GACnC3B,EAAIhxC,MACAF,MAAQ+uB,EAAGkiB,GAAWjxC,MAAQpF,EAAGd,EAAKw/B,WAAWvtB,MAAM+mC,KAC3D3B,EAAIr3C,EAAK20C,oBAAoB1iC,MAAMgnC,GAGrC,IAAM7E,EAAIluC,MAAQmxC,EAAGr3C,EAAKw/B,WAAWvtB,MAAMmlC,IAE3C,OAAQhD,EAAGA,EAAGgD,MAIlBR,sBAAA,WACE,IAAMr0C,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrCmV,oBAAqB1R,GAAoB18B,KAAKouC,qBAC9CpS,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CmU,eAAgBpwC,KAAKowC,eACrBjT,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,iBACvBe,eAAgBtuC,KAAKsuC,gBAEjB/U,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAvRFq0C,YAAY,cADSpC,oBA2RhBhuC,iBAAiBC,SAASmwC,IAuDxC,mBAEE,WAAYr0C,UAC8B,IAApCA,EAAOsyC,gBACThlC,QAAQC,KACJ,kHAGNvN,EAAOkvC,KAAO,IAAImF,GAASr0C,GAC3B1C,YAAM0C,SA6HV,OAtI0BpC,OAaxB+4C,iBAAA,SAAKtmC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACmB,MAAzBnF,EAAKyxC,KAAKsC,cACZW,UAAY10C,EAAKyxC,KAAKsC,aACtB/zC,EAAKyxC,KAAKsC,YAAc,MAEY,MAAlC/zC,EAAKyxC,KAAKuC,uBACZU,UAAY10C,EAAKyxC,KAAKuC,sBACtBh0C,EAAKyxC,KAAKuC,qBAAuB,MAEnC,IAAMl7B,EAAiB,MAAV3C,EAAiB,KAAOA,EAAa,KAC5CrJ,EAAqB,MAAVqJ,EAAiB,KAAOA,EAAiB,SACpDu6B,EACQ,MAAVv6B,EAAiB,KAAOA,EAAqB,aACjD,OAAOtW,YAAMuX,YAAKxE,GAASkG,OAAMhM,WAAU4jC,oBAI/C5wC,sBAAIo5C,yBAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBzJ,uCAGjCloC,sBAAIo5C,8BAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBjS,4CAGjC1/B,sBAAIo5C,uCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBkD,qDAGjC70C,sBAAIo5C,2BAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBlP,yCAGjCziC,sBAAIo5C,qCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBlO,mDAGjCzjC,sBAAIo5C,wCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkB8B,sDAGjCzzC,sBAAIo5C,mCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBjP,iDAGjC1iC,sBAAIo5C,kCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBkF,gDAGjC72C,sBAAIo5C,qCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkB/N,mDAGjC5jC,sBAAIo5C,wCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBgC,sDAGjC3zC,sBAAIo5C,mCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkB5O,iDAGjC/iC,sBAAIo5C,oCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBhO,kDAGjC3jC,sBAAIo5C,uCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBiC,qDAGjC5zC,sBAAIo5C,kCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkB9O,gDAGjC7iC,sBAAIo5C,2BAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBkC,yCAGjC7zC,sBAAIo5C,oCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBqC,kDAGjCh0C,sBAAIo5C,kCAAJ,WACE,OAAQ3yC,KAAKkrC,KAAkBoD,gDAGjCqE,sBAAA,WACE,IAAM32C,GACJylC,MAAOzhC,KAAKyhC,MACZxI,WAAYyD,GAAoB18B,KAAKi5B,YACrCmV,oBAAqB1R,GAAoB18B,KAAKouC,qBAC9CpS,QAASh8B,KAAKg8B,QACdgB,kBAAmBL,GAAqB38B,KAAKg9B,mBAC7CgQ,qBAAsBrQ,GAAqB38B,KAAKgtC,sBAChD/Q,gBAAiBU,GAAqB38B,KAAKi8B,iBAC3CmU,eAAgBpwC,KAAKowC,eACrBjT,kBAAmBP,GAAqB58B,KAAKm9B,mBAC7C+P,qBAAsBtQ,GAAqB58B,KAAKktC,sBAChD5Q,gBAAiBM,GAAqB58B,KAAKs8B,iBAC3C7uB,oBAAqBmvB,GAAqB58B,KAAKyN,qBAC/CyvB,iBAAkBL,EAAoB78B,KAAKk9B,kBAC3CiQ,oBAAqBtQ,EAAoB78B,KAAKmtC,qBAC9C/Q,eAAgBS,EAAoB78B,KAAKo8B,gBACzCgR,QAASptC,KAAKotC,QACdG,iBAAkBvtC,KAAKutC,iBACvBe,eAAgBtuC,KAAKsuC,gBAEjB/U,EAAajgC,YAAM2C,qBAGzB,cAFOs9B,EAAiB,KACxBhgC,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGF22C,aAAP,SACIl2C,EACAT,GAIF,OAHgC,IAA5BA,EAAsB,gBACxBA,EAAuB,eAAI,GAEtB,IAAIS,EAAIT,IAnIV22C,YAAY,UADKlH,oBAuIZxrC,iBAAiBC,SAASyyC,IAcxC,mBAIE,WAAY32C,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAK2xC,MAAQpvC,EAAOovC,QAoKxB,OA1KqCxxC,OASnCL,sBAAI4xC,6BAAJ,WAME,IADA,IAAME,SACa1uC,EAAAqD,KAAKorC,MAAM7nC,QAAQ+a,UAAnBvjB,WAAAA,KAAd,IAAMmwC,OACL9wC,MAAMC,QAAQ6wC,EAAKG,WACrBA,EAAUttC,WAAVstC,EAAkBH,EAAKG,WAEvBA,EAAUttC,KAAKmtC,EAAKG,WAGxB,OAAOA,mCAGTF,iBAAA,SAAK9+B,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAMV,IAJA,IAAIisC,GADJx+B,EAASA,GACW9I,MAAM,GAGpBqvC,SACaj2C,EAAAlD,EAAK2xC,MAAM7nC,QAAQ+a,UAAnBvjB,WAAAA,KAAd,IAAMmwC,OACL9wC,MAAMC,QAAQ6wC,EAAKG,WACrBuH,EAAa70C,KAAK8sC,EAAOrnC,OAAO,EAAG0nC,EAAKG,UAAUpwC,SAElD23C,EAAa70C,KAAK8sC,EAAOrnC,OAAO,EAAG,IAGvCovC,EAAat0B,UAKb,IAFA,IACIu0B,EADEC,KAEGv4C,EAAI,EAAGA,EAAId,EAAK2xC,MAAMnwC,SAAUV,EAAG,CACpC2wC,EAAOzxC,EAAK2xC,MAAM7wC,GACxBswC,EAAS+H,EAAar4C,GAGpBs4C,EADQ,IAANt4C,GACY8R,EAAO,IAAI7R,OAAOqwC,IAElBgI,EAAW,IAAIr4C,OAAOqwC,GAEtCgI,EAAa3H,EAAKr6B,KAAKgiC,EAAYjjC,GACnCkjC,EAAgB/0C,KAAK80C,EAAWtvC,MAAM,IAIxCsnC,KACA,IAAyB,QAAAhuC,EAAAi2C,EAAgBvvC,QAAQ+a,UAAxB1hB,WAAAA,KAApB,IAAMm2C,OACTlI,EAAO9sC,WAAP8sC,EAAekI,GAEjB,OAAQF,EAAW,IAAIr4C,OAAOqwC,MAI3BM,kBAAP,SAAa/8B,GAOX,IAAIw0B,EANA8I,GAAgBt9B,KAGlBA,EAAcA,EAAuB,IAEvCA,EAAaA,EAEb,IAAmB,QAAAzR,EAAAqD,KAAKorC,MAALrwC,WAAAA,KAAd,IAAMmwC,OAETA,EAAK16B,MAAMpC,GAETw0B,EADExoC,MAAMC,QAAQ6wC,EAAKG,WACTH,EAAKG,UAAU,GAEfH,EAAKG,UAEnBj9B,GAAcA,EAAW,GAAIw0B,GAE/B5iC,KAAKgP,OAAQ,GAGfm8B,sBAAA,WAEE,IADA,IAAM6H,SACar2C,EAAAqD,KAAKorC,MAALrwC,WAAAA,KAAd,IAAMmwC,OACT8H,EAAYj1C,MACVjC,UAAakE,KAAKjE,eAClBC,OAAUkvC,EAAKjvC,cAGnB,IAAMD,GAAoCovC,MAAS4H,GAC7CzZ,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGFmvC,aAAP,SACI1uC,EACAT,EACAG,gBAAAA,MAEF,IADA,IAAMivC,SACmBzuC,EAACX,EAAc,MAAfjB,WAAAA,KAApB,IAAM+xC,OACT1B,EAAMrtC,KAAKi4B,GAAY8W,EAAY3wC,IAErC,OAAO,IAAIM,GAAK2uC,WAGlB7xC,sBAAI4xC,oCAAJ,WACE,IAAKnrC,KAAK+K,UACR,SAGF,IADA,IAAMN,SACa9N,EAAAqD,KAAKorC,MAALrwC,WAAAA,KAAd,IAAMmwC,OACTzgC,EAAQ1M,WAAR0M,EAAgBygC,EAAKj8B,kBAEvB,OAAOxE,mCAGTlR,sBAAI4xC,uCAAJ,WAEE,IADA,IAAM1gC,SACa9N,EAAAqD,KAAKorC,MAALrwC,WAAAA,KAAd,IAAMmwC,OACTzgC,EAAQ1M,WAAR0M,EAAgBygC,EAAKh8B,qBAEvB,IAAKlP,KAAK+K,UAAW,CAEnB,IADA,IAAMkE,SACapS,EAAAmD,KAAKorC,MAALxuC,WAAAA,KAARsuC,OACTj8B,EAAiBlR,WAAjBkR,EAAyBi8B,EAAKj8B,kBAEhC,OAAOA,EAAiBzU,OAAOiQ,GAEjC,OAAOA,mCAQT0gC,uBAAA,WAEE,IADA,IAAM1gC,SACa9N,EAAAqD,KAAKorC,MAALrwC,WAAAA,KAAd,IAAMmwC,OACTzgC,EAAQ1M,WAAR0M,EAAgBygC,EAAKzgC,SAEvB,OAAOoH,GAAcpH,IASvB0gC,uBAAA,SAAW1gC,GAET,IADA,IAAMwoC,SACat2C,EAAAqD,KAAKorC,MAALrwC,WAAAA,IAGjB,IAHG,IAAMmwC,OACHgI,EAAYhI,EAAKzgC,QAAQxP,OACzBk4C,EAAe1oC,EAAQjH,OAAO0vC,GAC3B34C,EAAI,EAAGA,EAAI2wC,EAAKzgC,QAAQxP,SAAUV,EACzC04C,EAAOl1C,MAAMmtC,EAAKzgC,QAAQlQ,GAAI44C,EAAa54C,KAG/C4X,GAAc8gC,IArKT9H,YAAY,qBADgB8C,IA6KrC,YACInnC,EAAoBtG,EAAc+F,EAClCmE,GACF,aACE,OAAO82B,GAAU16B,IAAQhH,EAAUU,IAErC,gBALoC+F,qBAClCmE,KAIEA,EAAQ,EAAG,CAEb,IADA,IAAM6H,KACGhY,EAAI,EAAGA,EAAImQ,EAAOnQ,IACzBgY,EAAKxU,KAAKwjC,GAAe6R,EAAetsC,EAAMP,IAGhD,OADAgM,EAAKjB,QAAQ,SAAA7V,GAAK,OAAAo3B,OAASp3B,KACpB8W,EAEP,OAAOsgB,OAAS0O,GAAe6R,EAAetsC,EAAMP,oBAhB1CtG,iBAAiBC,SAASirC,IC16ExC,mBAGE,WAAYnvC,GAAZ,MAQE1C,YAAM0C,gBACNvC,EAAK0T,MAAQnR,EAAOmR,QAmFxB,OA/FsCvT,OAepCy5C,kBAAA,SAAMjlC,GACJpO,KAAKgP,OAAQ,GAKfzV,sBAAI85C,6BAAJ,WAIE,OAAkB,MAAdrzC,KAAKmN,OACAnN,KAAKmN,MAAMpC,eAMtB,SAAc/R,GAIM,MAAdgH,KAAKmN,QACPnN,KAAKmN,MAAMpC,UAAY/R,oCAI3BO,sBAAI85C,oCAAJ,WACE,OAAOrzC,KAAKmN,MAAM8B,kDAIpB1V,sBAAI85C,uCAAJ,WACE,OAAOrzC,KAAKmN,MAAM+B,qDAIpB3V,sBAAI85C,2BAAJ,WAEE,OAAQrzC,KAAKmN,MAAcY,0CAK7BxU,sBAAI85C,0BAAJ,WACE,OAAOrzC,KAAKmN,MAAM2B,wCAKpBukC,uBAAA,WACE,OAAOrzC,KAAKmN,MAAMwnB,cAGpB0e,uBAAA,SAAW5oC,GACTzK,KAAKmN,MAAMsD,WAAWhG,IAGxB4oC,sBAAA,WACE,IAAMr3C,GACJmR,OACErR,UAAakE,KAAKmN,MAAMpR,eACxBC,OAAUgE,KAAKmN,MAAMlR,cAGnBs9B,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGFq3C,aAAP,SACI52C,EACAT,EACAG,gBAAAA,MACF,IACMgR,EAAQ6oB,GADMh6B,EAAc,MACKG,UAChCH,EAAc,MACrB,IAAMs3C,GAAanmC,SAEnB,OADA5T,OAAOkS,OAAO6nC,EAAWt3C,GAClB,IAAIS,EAAI62C,OA7FmB7kC,mBA+IpC,WAAYzS,GAAZ,MACE1C,YAAM0C,gBACNvC,EAAKkU,iBAAkB,IAgD3B,OApDqC/T,OAOnC25C,kBAAA,SAAMnlC,GAEJ,IADAA,EAAaipB,GAAmBjpB,IACjBnT,OAAS,EACtB,MAAM,IAAIlB,EACN,gFACewC,KAAKC,UAAU4R,IAEpCpO,KAAK0N,YAAcpK,MAAO8K,IAC1B,IAAMolC,GAAmBplC,EAAW,IAAI5T,OAAO4T,EAAW7K,MAAM,IAC3DvD,KAAKmN,MAAM6B,QACdhP,KAAKmN,MAAMqD,MAAMgjC,GACjBxzC,KAAKmN,MAAM6B,OAAQ,GAErB1V,YAAMkX,gBAAMpC,IAGdmlC,+BAAA,SAAmBnlC,GAEjB,IAAMolC,IADNplC,EAAaipB,GAAmBjpB,IACI,IAAI5T,OAAO4T,EAAW7K,MAAM,IAC1DkwC,EACFzzC,KAAKmN,MAAM+D,mBAAmBsiC,GAC5BE,EAAYtlC,EAAW,GAC7B,OAAQqlC,EAAiB,GAAIC,GAAWl5C,OAAOi5C,EAAiBlwC,MAAM,KAGxEgwC,iBAAA,SAAKlnC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WAgBV,OAJIguC,GAN0B,SAACvgC,EAAgBw+B,GAG7C,OADepxC,EAAK0T,MAAM0D,KAAKxE,EAAQuD,QANzCvD,EAASgtB,GAAoBhtB,OAUH,EAAO,KAAM,MAAM,EAAOA,EAAO/I,MAAM,IAC5C,MA7ClBiwC,YAAY,qBADgBF,oBAqDvBpzC,iBAAiBC,SAASqzC,IAGjC,IAAMI,IAAmC,MAAO,MAAO,SAAU,OAoBxE,mBAUE,WAAY33C,GAAZ,IA7B0ChD,IA8BxCM,YAAM0C,SAUAkpB,EAAclpB,EAAOmR,MAAMlR,YAejC,GAdAxC,EAAKm6C,aACD5d,IACKl6B,UAAWE,EAAOmR,MAAMpR,eAAgBC,OAAQkpB,IAEzDA,EAAyB,aACU,IAA/BA,EAAyB,YAC7BzrB,EAAKo6C,cACD7d,IACKl6B,UAAWE,EAAOmR,MAAMpR,eAAgBC,OAAQkpB,IAEzDzrB,EAAKm6C,aAAaz4C,KAAO,WAAa1B,EAAKm6C,aAAaz4C,KACxD1B,EAAKo6C,cAAc14C,KAAO,YAAc1B,EAAKo6C,cAAc14C,KApDnBnC,EAqDZgD,EAAO83C,UApDrCC,EACIJ,GAAiC,yBAA0B36C,GAoD7DS,EAAKq6C,UAAY93C,EAAO83C,UACpB93C,EAAOyO,QACT,MAAM,IAAIzQ,EACN,0EAENP,EAAK0V,UAAYnT,EAAOmR,MAAMyZ,SAC9BntB,EAAK6xC,gBAAkBtvC,EAAOmR,MAAMm+B,gBACpC7xC,EAAK8xC,YAAcvvC,EAAOmR,MAAMo+B,YAChC9xC,EAAKkU,iBAAkB,EACvBlU,EAAKu6C,YAAa,EAClBv6C,EAAKiU,UAAY1R,EAAOmR,MAAMO,UAC9BjU,EAAK4wC,aAAe,OA2QxB,OAzTmCzwC,OAiDjCL,sBAAI06C,6BAAJ,WACE,OAAOj0C,KAAKg0C,gBAGd,SAAch7C,GAIZgH,KAAKg0C,WAAah7C,EACO,MAArBgH,KAAK4zC,eACP5zC,KAAK4zC,aAAa7oC,UAAY/R,GAEN,MAAtBgH,KAAK6zC,gBACP7zC,KAAK6zC,cAAc9oC,UAAY/R,oCAInCi7C,uBAAA,WACE,OAAOj0C,KAAK4zC,aAAajf,aAAan6B,OAClCwF,KAAK6zC,cAAclf,eAGzBsf,uBAAA,SAAWxpC,GACT,IAAMypC,EAAazpC,EAAQxP,OACrBk5C,EAAiBxrC,KAAKuhB,MAAMgqB,EAAa,GAC/Cl0C,KAAK4zC,aAAanjC,WAAWhG,EAAQlH,MAAM,EAAG4wC,IAC9Cn0C,KAAK6zC,cAAcpjC,WAAWhG,EAAQlH,MAAM4wC,KAG9CF,+BAAA,SAAmB7lC,GACjB,IAOI6C,EACA/D,EACAy+B,EATAyI,EACAp0C,KAAK4zC,aAAa1iC,mBAAmB9C,GAyBzC,OAxBMhU,MAAMC,QAAQ+5C,IAAgBh6C,MAAMC,QAAQ+5C,EAAY,MAC5DA,GAAeA,IAEjBA,EAAcA,EAKVp0C,KAAKurC,aACPI,EAAayI,EAAY7wC,MAAM,GAC/B0N,EAAcmjC,EAAY,IAE1BnjC,EAAcmjC,EAAY,GAE5BnjC,EAAcA,EACS,WAAnBjR,KAAK8zC,WACP7iC,EAAYA,EAAYhW,OAAS,IAAM,EACvCiS,GAAgB+D,IAEhB/D,EAD2B,MAAlBlN,KAAK8zC,WACE7iC,EAAaA,EAAY1N,UAEzB0N,GAGdjR,KAAKurC,YACe,MAAlBvrC,KAAK8zC,UACA5mC,EAAa1S,OAAOmxC,GAAYnxC,OAAOmxC,EAAWpoC,UAEnD0N,GAAazW,OAAOmxC,GAAYnxC,OAAOmxC,EAAWpoC,SAErDqL,EAA+B1B,IAGxC+mC,kBAAA,SACI5nC,EACAuD,GACF,IAAIu6B,EACU,MAAVv6B,EAAiB,KAAOA,EAAqB,aAC7Cw6B,EACU,MAAVx6B,EAAiB,KAAOA,EAAkB,UAChC,MAAVA,IACFA,MAEF,IAAMm8B,EACFC,GAAgB3/B,EAAQ89B,EAAcC,EAAWpqC,KAAKqqC,cAU1D,GATAh+B,EAAS0/B,EAAa1/B,OACtB89B,EAAe4B,EAAa5B,aAC5BC,EAAY2B,EAAa3B,UAErBhwC,MAAMC,QAAQgS,KAChB89B,EAAgB99B,EAAuC9I,MAAM,GAC7D8I,EAAUA,EAAuC,KAG9B,MAAhB89B,GAAgD,IAAxBA,EAAalvC,SACzB,MAAbmvC,EACF,OAAO9wC,YAAMoS,gBAAMW,EAAQuD,GAE7B,IAAMq8B,KACAC,KACN,GAAoB,MAAhB/B,EAAsB,CACxB,IAAMsC,EAAYtC,EAAalvC,OAC/B,GAAIwxC,EAAY,EAAI,EAClB,MAAM,IAAI1yC,EACN,iIAIN6V,EAAqB,aAAIu6B,EACzB8B,EAAiBluC,WAAjBkuC,EAAyB9B,GACzB,IAAMkK,EAAclK,EACIx+B,IAAI,SAAAygC,GAAS,OAAA,IAAIhO,IAAW96B,MAAO8oC,EAAM9oC,UACjEtD,KAAK4zC,aAAapI,UAAY6I,EAAW9wC,MAAM,EAAGkpC,EAAY,GAC9DzsC,KAAK6zC,cAAcrI,UAAY6I,EAAW9wC,MAAMkpC,EAAY,GAC5DP,EAAgBnuC,WAAhBmuC,EAAwBmI,GAE1B,GAAiB,MAAbjK,EACF,MAAM,IAAIpwC,EACN,yEAKN,IADA,IAAMs6C,EAAmBrI,EAAiB,aAAc/7B,OACnCqkC,IAAAx5C,WAAAA,KACnB,kBAAsBmV,KAAmBokC,EACvC,MAAM,IAAIv6C,EACN,gHAKR,GAAIu6C,EAAkB,CAEpB,IAAMjI,GAAahgC,GAAQ7R,OAAOyxC,GAC5BK,EAAgBtsC,KAAK0N,UAAUlT,OAAO0xC,GAUtCK,EAAoBvsC,KAAK0N,UAC/B1N,KAAK0N,UAAY4+B,EACjB,IAAM17B,EACFtX,YAAMoS,gBAAM2gC,EAA0Cz8B,GAE1D,OADA5P,KAAK0N,UAAY6+B,EACV37B,EAEP,OAAOtX,YAAMoS,gBAAMW,EAAQuD,IAI/BqkC,iBAAA,SAAK5nC,EAAyBuD,GAA9B,WACE,OAAOhR,OAAK,WACV,GAAsB,MAAlBgR,EAAa,KACf,MAAM,IAAI5V,EACN,4EAGN,IAEI+K,EACAyvC,EAaA3J,EAcAj6B,EA9BEu5B,EAAev6B,EAAqB,aAI1C,GAAoB,MAAhBu6B,EACFplC,EAAItL,EAAKm6C,aAAa/iC,KAAKxE,EAAQuD,GACnC4kC,EAAO/6C,EAAKo6C,cAAchjC,KAAKxE,EAAQuD,OAClC,CACL,IAAM6kC,EAAetK,EAAa5mC,MAAM,EAAG4mC,EAAalvC,OAAS,GAC3Dy5C,EAAgBvK,EAAa5mC,MAAM4mC,EAAalvC,OAAS,GAC/D8J,EAAItL,EAAKm6C,aAAa/iC,KAClBxE,EAAQ9S,OAAOkS,OAAOmE,GAASu6B,aAAcsK,KACjDD,EAAO/6C,EAAKm6C,aAAa/iC,KACrBxE,EAAQ9S,OAAOkS,OAAOmE,GAASu6B,aAAcuK,KA+BnD,OA3BIj7C,EAAK8xC,cACHnxC,MAAMC,QAAQ0K,KAChB8lC,EAAU9lC,EAAexB,MAAM,GAAG/I,OAAQg6C,EAAkBjxC,MAAM,KAGpEwB,EAAKA,EAAe,GACpByvC,EAAQA,EAAkB,IAGxB/6C,EAAK6xC,kBACPkJ,EAAO5J,UAAY4J,EAAgB,IAId,WAAnB/6C,EAAKq6C,UACPljC,EAASi1B,IAAe9gC,EAAayvC,IACT,QAAnB/6C,EAAKq6C,UACdljC,EAAS/Q,MAAQkF,EAAayvC,GACF,QAAnB/6C,EAAKq6C,UACdljC,EAASjR,MAAQG,EAAU,IAAMD,MAAQkF,EAAayvC,IAC1B,QAAnB/6C,EAAKq6C,UACdljC,EAASjR,MAAQoF,EAAayvC,GACH,MAAlB/6C,EAAKq6C,YACdljC,GAAU7L,EAAayvC,IAIrB/6C,EAAK8xC,YACe,MAAlB9xC,EAAKq6C,UACCljC,EAAoBpW,OAAOqwC,IAE7Bj6B,GAAkBpW,OAAOqwC,GAE5Bj6B,KAIXqjC,wBAAA,SAAYpJ,GACV7qC,KAAK4zC,aAAae,cAClB30C,KAAK6zC,cAAcc,eAGrBV,kBAAA,SAAM7lC,GAAN,WACEiC,GAAUrQ,KAAK4zC,aAAaz4C,KAAM,WAChC1B,EAAKm6C,aAAapjC,MAAMpC,KAE1BiC,GAAUrQ,KAAK6zC,cAAc14C,KAAM,WACjC1B,EAAKo6C,cAAcrjC,MAAMpC,KAE3BpO,KAAKgP,OAAQ,GAKfzV,sBAAI06C,oCAAJ,WACE,OAAOj0C,KAAK4zC,aAAa3kC,iBAAiBzU,OACtCwF,KAAK6zC,cAAc5kC,mDAGzB1V,sBAAI06C,uCAAJ,WACE,OAAOj0C,KAAK4zC,aAAa1kC,oBAAoB1U,OACzCwF,KAAK6zC,cAAc3kC,sDAKzB+kC,sBAAA,WACE,IAAMj4C,GACJ83C,UAAa9zC,KAAK8zC,WAGdva,EAAajgC,YAAM2C,qBAEzB,OADA1C,OAAOkS,OAAOzP,EAAQu9B,GACfv9B,GAGFi4C,aAAP,SACIx3C,EACAT,GACF,IAAM44C,EACF5e,GAAYh6B,EAAc,OAG9B,UAFOA,EAAc,MAES,MAA1BA,EAAqB,aACvB,MAAM,IAAIhC,EACN,4FAIN,IAAMs5C,EAAkCt3C,EAExC,OADAs3C,EAAiB,MAAIsB,EACd,IAAIn4C,EAAI62C,IAtTVW,YAAY,mBADcZ,gBCkJFr3C,GAC/B,OAAO,IAAIytC,GAAiBztC,eAoBGA,GAC/B,OAAO,IAAI4tC,GAAiB5tC,eA+CKA,GACjC,OAAO,IAAI+tC,GAAmB/tC,eAYGA,GACjC,OAAO,IAAIkuC,GAAmBluC,eAYHA,GAC3B,OAAO,IAAIutC,GAAavtC,eAYGA,GAC3B,OAAO,IAAI2tC,GAAa3tC,mBD2DZiE,iBAAiBC,SAAS+zC,IC+EjC,IAAMY,GAAkBC,GAClBC,GAAkBC,GAClBC,GAAYC,GACZC,GAAYC,yCA1mBEp5C,GACzB,OAAO,IAAIgX,GAAWhX,iBAcJA,GAClB,OAAO,IAAIw9B,GAAIx9B,uBAYSA,GACxB,OAAO,IAAIo9B,GAAUp9B,qBAYCA,GACtB,OAAO,IAAIg9B,GAAQh9B,6BAYWA,GAC9B,OAAO,IAAI69B,GAAgB79B,oBAcNA,GACrB,OAAO,IAAIkkC,GAAOlkC,oBAYGA,GACrB,OAAO,IAAImiC,GAAOniC,6BAYYA,GAC9B,OAAO,IAAIqiC,GAAgBriC,6BAYGA,GAC9B,OAAO,IAAIkjC,GAAgBljC,wBAYFA,GACzB,OAAO,IAAIokC,GAAWpkC,0BAYKA,GAC3B,OAAO,IAAIukC,GAAavkC,6BAeMA,GAC9B,OAAO,IAAI0kC,GAAgB1kC,wBAcFA,GACzB,OAAO,IAAI47B,GAAW57B,mBAYFA,GACpB,OAAO,IAAI0lC,GAAM1lC,qBAYKA,GACtB,OAAO,IAAImlC,GAAQnlC,qBAYGA,GACtB,OAAO,IAAI6lC,GAAQ7lC,0BAYQA,GAC3B,OAAO,IAAI+lC,GAAa/lC,qBAYFA,GACtB,OAAO,IAAIomC,GAAQpmC,uBAYKA,GACxB,OAAO,IAAIknC,GAAUlnC,iBAcHA,GAClB,OAAO,IAAI4oC,GAAI5oC,qBAYOA,GACtB,OAAO,IAAIkpC,GAAQlpC,yBAYOA,GAC1B,OAAO,IAAIspC,GAAYtpC,qBAYDA,GACtB,OAAO,IAAIopC,GAAQppC,qBAYGA,GACtB,OAAO,IAAIqpC,GAAQrpC,sBAYIA,GACvB,OAAO,IAAI+oC,GAAS/oC,gCAcaA,GAEjC,OAAO,IAAI0rC,GAAmB1rC,2BAcFA,GAC5B,OAAO,IAAI4sC,GAAc5sC,2CAgBDA,GACxB,OAAOq5C,GAAiBr5C,0BAIGA,GAC3B,OAAOq5C,GAAiBr5C,2CAeAA,GACxB,OAAOs5C,GAAiBt5C,0BAIGA,GAC3B,OAAOs5C,GAAiBt5C,oCAYaA,GACrC,OAAO,IAAI8tC,GAAuB9tC,oCAYGA,GAErC,OAAO,IAAIiuC,GAAuBjuC,6FAkEhBA,GAClB,OAAO,IAAIm0C,GAAIn0C,qBAYOA,GACtB,OAAO,IAAIuyC,GAAQvyC,kBAYAA,GACnB,OAAO,IAAI22C,GAAK32C,sBAYOA,GACvB,OAAO,IAAIq0C,GAASr0C,uBAYIA,GACxB,OAAO,IAAIkyC,GAAUlyC,2BAYOA,GAC5B,OAAO,IAAI0xC,GAAc1xC,iBAYPA,GAClB,OAAO,IAAIyvC,GAAIzvC,6BAYeA,GAC9B,OAAO,IAAImvC,GAAgBnvC,2BAcCA,GAC5B,OAAO,IAAIi4C,GAAcj4C,6BAYKA,GAC9B,OAAO,IAAIu3C,GAAgBv3C,sICznBEka,EAAeC,GAC5C,OAAOo/B,GAAuBr/B,EAAOC,gCAUJD,EAAeC,GAChD,OAAOq/B,GAA2Bt/B,EAAOC,iCAUPD,EAAeC,GACjD,OAAOs/B,GAA4Bv/B,EAAOC,qCAUJD,EAAeC,GACrD,OAAOu/B,GAAgCx/B,EAAOC,6BAUhBD,EAAeC,GAC7C,OAAOw/B,GAAuBz/B,EAAOC,+BAULD,EAAeC,GAC/C,OAAOy/B,GAAyB1/B,EAAOC,yCAWrCD,EAAeC,GACjB,OAAO0/B,GAAmC3/B,EAAOC,kBAG9BD,EAAeC,GAClC,OAAO0/B,GAAmC3/B,EAAOC,kBAG9BD,EAAeC,GAClC,OAAO0/B,GAAmC3/B,EAAOC,8BAUlBD,EAAeC,GAC9C,OAAO+a,GAAwBhb,EAAOC,iBAGpBD,EAAeC,GACjC,OAAO+a,GAAwBhb,EAAOC,iBAGpBD,EAAeC,GACjC,OAAO+a,GAAwBhb,EAAOC,0CC/FnBna,GACnB,OAAO,IAAIs+B,GAAKt+B,gBAWCA,GACjB,gBd0EiBA,GACjB,OAAO,IAAIs+B,IAAMJ,GAAc,MAAVl+B,EAAiBA,EAAOk+B,GAAK,KAAMC,GAAI,Ic3ErD2b,CAAgB95C,gBAWNA,GACjB,gBdyEiBA,GACjB,OAAO,IAAIs+B,IAAMH,GAAc,MAAVn+B,EAAiBA,EAAOm+B,GAAK,KAAMD,GAAI,Ic1ErD6b,CAAgB/5C,qBC9BzB,aAAA,qDAEEvC,QAAe,OAQjB,OAVuCG,OAIrCo8C,qBAAA,SAASniC,GACP,KAAMA,aAAiB4V,IACrB,MAAM,IAAI5vB,MAAM,mDAElBmG,KAAK6T,MAAQA,MARsBH,oMlBmIbgiB,GAExB,OAAOugB,GAAkBvgB,qBA7EL15B,GACpB,OAAO,IAAIytB,GAAMztB,0BA+DQA,GACzB,OAAO,IAAI46B,GAAW56B,iEmBtIR"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/types.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/types.d.ts new file mode 100644 index 0000000..ef6b29b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/types.d.ts @@ -0,0 +1,20 @@ +import { Scalar, Tensor } from '@tensorflow/tfjs-core'; +export declare type Shape = number[]; +export declare type HasShape = { + shape: Shape; +}; +export declare type LossOrMetricFn = (yTrue: Tensor, yPred: Tensor) => Tensor; +export declare type RegularizerFn = () => Scalar; +export declare type RnnStepFunction = (inputs: Tensor, states: Tensor[]) => [Tensor, Tensor[]]; +export declare type NamedTensorMap = { + [name: string]: Tensor; +}; +export declare type JsonValue = boolean | number | string | null | JsonArray | JsonDict; +export interface JsonDict { + [key: string]: JsonValue; +} +export interface JsonArray extends Array { +} +export declare type Kwargs = { + [key: string]: any; +}; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/types.js b/node_modules/@tensorflow/tfjs-layers/dist/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/types.js.map b/node_modules/@tensorflow/tfjs-layers/dist/types.js.map new file mode 100644 index 0000000..c768b79 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/types_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/types_test.js.map new file mode 100644 index 0000000..72e11c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/types_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types_test.js","sourceRoot":"","sources":["../src/types_test.ts"],"names":[],"mappings":";;AAgBA,8CAAiD;AAOjD,QAAQ,CAAC,qBAAqB,EAAE;IAC9B,EAAE,CAAC,oCAAoC,EAAE;QACvC,IAAM,GAAG,GAAG,IAAI,yBAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAChE,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAM,MAAM,GAAG,IAAI,yBAAc,CAAC,SAAS,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE;QAC1B,IAAM,GAAG,GAAG,IAAI,yBAAc,CAC1B,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,oBAAoB,CAAC,CAAC;QAC3D,IAAM,GAAG,GAAG,IAAI,yBAAc,CAC1B,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,oBAAoB,CAAC,CAAC;QAC3D,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC1D,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAE1D,MAAM,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEhC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE;QACvC,MAAM,CAAC,cAAM,OAAA,IAAI,yBAAc,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAxD,CAAwD,CAAC;aACjE,YAAY,EAAE,CAAC;IACtB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.d.ts new file mode 100644 index 0000000..79154a5 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.d.ts @@ -0,0 +1,4 @@ +import { PaddingMode } from '../common'; +export declare function normalizeArray(value: number | number[], n: number, name: string): number[]; +export declare function convOutputLength(inputLength: number, filterSize: number, padding: PaddingMode, stride: number, dilation?: number): number; +export declare function deconvLength(dimSize: number, strideSize: number, kernelSize: number, padding: PaddingMode): number; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js new file mode 100644 index 0000000..813d399 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js @@ -0,0 +1,59 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var errors_1 = require("../errors"); +var generic_utils_1 = require("./generic_utils"); +var math_utils_1 = require("./math_utils"); +function normalizeArray(value, n, name) { + if (typeof value === 'number') { + return generic_utils_1.pyListRepeat(value, n); + } + else { + if (value.length !== n) { + throw new errors_1.ValueError("The " + name + " argument must be a tuple of " + n + " integers. Received: " + + (value.length + " elements.")); + } + for (var i = 0; i < n; ++i) { + var singleValue = value[i]; + if (!math_utils_1.isInteger(singleValue)) { + throw new errors_1.ValueError("The " + name + " argument must be a tuple of " + n + " integers. Received: " + + (JSON.stringify(value) + " including a non-integer number ") + + ("" + singleValue)); + } + } + return value; + } +} +exports.normalizeArray = normalizeArray; +function convOutputLength(inputLength, filterSize, padding, stride, dilation) { + if (dilation === void 0) { dilation = 1; } + if (inputLength == null) { + return inputLength; + } + var dilatedFilterSize = filterSize + (filterSize - 1) * (dilation - 1); + var outputLength; + if (padding === 'same') { + outputLength = inputLength; + } + else { + outputLength = inputLength - dilatedFilterSize + 1; + } + return Math.floor((outputLength + stride - 1) / stride); +} +exports.convOutputLength = convOutputLength; +function deconvLength(dimSize, strideSize, kernelSize, padding) { + if (dimSize == null) { + return null; + } + if (padding === 'valid') { + dimSize = dimSize * strideSize + math_utils_1.max([kernelSize - strideSize, 0]); + } + else if (padding === 'same') { + dimSize = dimSize * strideSize; + } + else { + throw new errors_1.ValueError("Unsupport padding mode: " + padding + "."); + } + return dimSize; +} +exports.deconvLength = deconvLength; +//# sourceMappingURL=conv_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js.map new file mode 100644 index 0000000..837b5e8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/conv_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"conv_utils.js","sourceRoot":"","sources":["../../src/utils/conv_utils.ts"],"names":[],"mappings":";;AAWA,oCAAqC;AAErC,iDAA6C;AAC7C,2CAA4C;AAS5C,wBACI,KAAsB,EAAE,CAAS,EAAE,IAAY;IACjD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;QAC7B,OAAO,4BAAY,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;KAC/B;SAAM;QACL,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,MAAM,IAAI,mBAAU,CAChB,SAAO,IAAI,qCAAgC,CAAC,0BAAuB;iBAChE,KAAK,CAAC,MAAM,eAAY,CAAA,CAAC,CAAC;SAClC;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;YAC1B,IAAM,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,sBAAS,CAAC,WAAW,CAAC,EAAE;gBAC3B,MAAM,IAAI,mBAAU,CAChB,SAAO,IAAI,qCACP,CAAC,0BAAuB;qBACzB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,qCAAkC,CAAA;qBAC1D,KAAG,WAAa,CAAA,CAAC,CAAC;aACvB;SACF;QACD,OAAO,KAAK,CAAC;KACd;AACH,CAAC;AAtBD,wCAsBC;AAUD,0BACI,WAAmB,EAAE,UAAkB,EAAE,OAAoB,EAC7D,MAAc,EAAE,QAAY;IAAZ,yBAAA,EAAA,YAAY;IAC9B,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,OAAO,WAAW,CAAC;KACpB;IACD,IAAM,iBAAiB,GAAG,UAAU,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;IACzE,IAAI,YAAoB,CAAC;IACzB,IAAI,OAAO,KAAK,MAAM,EAAE;QACtB,YAAY,GAAG,WAAW,CAAC;KAC5B;SAAM;QACL,YAAY,GAAG,WAAW,GAAG,iBAAiB,GAAG,CAAC,CAAC;KACpD;IACD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,YAAY,GAAG,MAAM,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;AAC1D,CAAC;AAdD,4CAcC;AAED,sBACI,OAAe,EAAE,UAAkB,EAAE,UAAkB,EACvD,OAAoB;IACtB,IAAI,OAAO,IAAI,IAAI,EAAE;QACnB,OAAO,IAAI,CAAC;KACb;IAED,IAAI,OAAO,KAAK,OAAO,EAAE;QACvB,OAAO,GAAG,OAAO,GAAG,UAAU,GAAG,gBAAG,CAAC,CAAC,UAAU,GAAG,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;KACpE;SAAM,IAAI,OAAO,KAAK,MAAM,EAAE;QAC7B,OAAO,GAAG,OAAO,GAAG,UAAU,CAAC;KAChC;SAAM;QACL,MAAM,IAAI,mBAAU,CAAC,6BAA2B,OAAO,MAAG,CAAC,CAAC;KAC7D;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAfD,oCAeC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.d.ts new file mode 100644 index 0000000..b1cd358 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.d.ts @@ -0,0 +1,23 @@ +import { DataType, serialization } from '@tensorflow/tfjs-core'; +export declare function pyListRepeat(value: any, numValues: number): any[]; +export declare function assert(val: boolean, message?: string): void; +export declare function count(array: T[], refernce: T): number; +export declare function singletonOrArray(xs: T[]): T | T[]; +export declare function toList(x: any): any[]; +export declare function objectListUid(objs: any | any[]): string; +export declare function toSnakeCase(name: string): string; +export declare function toCamelCase(identifier: string): string; +export declare function serializeKerasObject(instance: serialization.Serializable): serialization.ConfigDictValue; +export declare function deserializeKerasObject(identifier: string | serialization.ConfigDict, moduleObjects?: { + [objName: string]: any; +}, customObjects?: { + [objName: string]: any; +}, printableModuleName?: string): any; +export declare function numberCompare(a: number, b: number): 0 | 1 | -1; +export declare function reverseNumberCompare(a: number, b: number): number; +export declare function stringToDType(dtype: string): DataType; +export declare function stringsEqual(xs: string[], ys: string[]): boolean; +export declare function unique(xs: T[]): T[]; +export declare function isObjectEmpty(obj: {}): boolean; +export declare function checkStringTypeUnionValue(values: string[], label: string, value: string): void; +export declare function checkArrayTypeAndLength(x: any, expectedType: string, minLength?: number, maxLength?: number): boolean; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js new file mode 100644 index 0000000..491fa95 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js @@ -0,0 +1,254 @@ +"use strict"; +var __assign = (this && this.__assign) || Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var errors_1 = require("../errors"); +function pyListRepeat(value, numValues) { + if (Array.isArray(value)) { + var newArray = []; + for (var i = 0; i < numValues; i++) { + newArray = newArray.concat(value); + } + return newArray; + } + else { + var newArray = new Array(numValues); + newArray.fill(value); + return newArray; + } +} +exports.pyListRepeat = pyListRepeat; +function assert(val, message) { + if (!val) { + throw new errors_1.AssertionError(message); + } +} +exports.assert = assert; +function count(array, refernce) { + var counter = 0; + for (var _i = 0, array_1 = array; _i < array_1.length; _i++) { + var item = array_1[_i]; + if (item === refernce) { + counter++; + } + } + return counter; +} +exports.count = count; +function singletonOrArray(xs) { + if (xs.length === 1) { + return xs[0]; + } + return xs; +} +exports.singletonOrArray = singletonOrArray; +function toList(x) { + if (Array.isArray(x)) { + return x; + } + return [x]; +} +exports.toList = toList; +function objectListUid(objs) { + var objectList = toList(objs); + var retVal = ''; + for (var _i = 0, objectList_1 = objectList; _i < objectList_1.length; _i++) { + var obj = objectList_1[_i]; + if (obj.id == null) { + throw new errors_1.ValueError("Object " + obj + " passed to objectListUid without an id"); + } + if (retVal !== '') { + retVal = retVal + ', '; + } + retVal = retVal + Math.abs(obj.id); + } + return retVal; +} +exports.objectListUid = objectListUid; +function toSnakeCase(name) { + var intermediate = name.replace(/(.)([A-Z][a-z0-9]+)/g, '$1_$2'); + var insecure = intermediate.replace(/([a-z])([A-Z])/g, '$1_$2').toLowerCase(); + if (insecure[0] !== '_') { + return insecure; + } + return 'private' + insecure; +} +exports.toSnakeCase = toSnakeCase; +function toCamelCase(identifier) { + if (identifier.length <= 1) { + return identifier; + } + if (identifier.indexOf('_') === -1) { + return identifier; + } + return identifier.replace(/[_]+(\w|$)/g, function (m, p1) { return p1.toUpperCase(); }); +} +exports.toCamelCase = toCamelCase; +var _GLOBAL_CUSTOM_OBJECTS = {}; +function serializeKerasObject(instance) { + if (instance === null || instance === undefined) { + return null; + } + return { className: instance.getClassName(), config: instance.getConfig() }; +} +exports.serializeKerasObject = serializeKerasObject; +function deserializeKerasObject(identifier, moduleObjects, customObjects, printableModuleName) { + if (moduleObjects === void 0) { moduleObjects = {}; } + if (customObjects === void 0) { customObjects = {}; } + if (printableModuleName === void 0) { printableModuleName = 'object'; } + if (typeof identifier === 'string') { + var functionName = identifier; + var fn = void 0; + if (functionName in customObjects) { + fn = customObjects[functionName]; + } + else if (functionName in _GLOBAL_CUSTOM_OBJECTS) { + fn = _GLOBAL_CUSTOM_OBJECTS[functionName]; + } + else { + fn = moduleObjects[functionName]; + if (fn == null) { + throw new errors_1.ValueError("Unknown " + printableModuleName + ": " + identifier); + } + } + return fn; + } + else { + var config = identifier; + if (config.className == null || config.config == null) { + throw new errors_1.ValueError(printableModuleName + ": Improper config format: " + + (JSON.stringify(config) + ".\n") + + "'className' and 'config' must set."); + } + var className = config.className; + var cls = void 0, fromConfig = void 0; + if (className in customObjects) { + _a = customObjects.get(className), cls = _a[0], fromConfig = _a[1]; + } + else if (className in _GLOBAL_CUSTOM_OBJECTS) { + _b = _GLOBAL_CUSTOM_OBJECTS.className, cls = _b[0], fromConfig = _b[1]; + } + else if (className in moduleObjects) { + _c = moduleObjects[className], cls = _c[0], fromConfig = _c[1]; + } + if (cls == null) { + throw new errors_1.ValueError("Unknown " + printableModuleName + ": " + className); + } + if (fromConfig != null) { + var customObjectsCombined = {}; + for (var _i = 0, _d = Object.keys(_GLOBAL_CUSTOM_OBJECTS); _i < _d.length; _i++) { + var key = _d[_i]; + customObjectsCombined[key] = _GLOBAL_CUSTOM_OBJECTS[key]; + } + for (var _e = 0, _f = Object.keys(customObjects); _e < _f.length; _e++) { + var key = _f[_e]; + customObjectsCombined[key] = customObjects[key]; + } + var nestedConfig = config.config; + nestedConfig.customObjects = customObjectsCombined; + var backupCustomObjects = __assign({}, _GLOBAL_CUSTOM_OBJECTS); + for (var _g = 0, _h = Object.keys(customObjects); _g < _h.length; _g++) { + var key = _h[_g]; + _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key]; + } + var returnObj = fromConfig(cls, config.config); + _GLOBAL_CUSTOM_OBJECTS = __assign({}, backupCustomObjects); + return returnObj; + } + else { + var backupCustomObjects = __assign({}, _GLOBAL_CUSTOM_OBJECTS); + for (var _j = 0, _k = Object.keys(customObjects); _j < _k.length; _j++) { + var key = _k[_j]; + _GLOBAL_CUSTOM_OBJECTS[key] = customObjects[key]; + } + var returnObj = new cls(config.config); + _GLOBAL_CUSTOM_OBJECTS = __assign({}, backupCustomObjects); + return returnObj; + } + } + var _a, _b, _c; +} +exports.deserializeKerasObject = deserializeKerasObject; +function numberCompare(a, b) { + return (a < b) ? -1 : ((a > b) ? 1 : 0); +} +exports.numberCompare = numberCompare; +function reverseNumberCompare(a, b) { + return -1 * numberCompare(a, b); +} +exports.reverseNumberCompare = reverseNumberCompare; +function stringToDType(dtype) { + switch (dtype) { + case 'float32': + return 'float32'; + default: + throw new errors_1.ValueError("Invalid dtype: " + dtype); + } +} +exports.stringToDType = stringToDType; +function stringsEqual(xs, ys) { + if (xs == null || ys == null) { + return xs === ys; + } + if (xs.length !== ys.length) { + return false; + } + for (var i = 0; i < xs.length; ++i) { + if (xs[i] !== ys[i]) { + return false; + } + } + return true; +} +exports.stringsEqual = stringsEqual; +function unique(xs) { + if (xs == null) { + return xs; + } + var out = []; + for (var _i = 0, xs_1 = xs; _i < xs_1.length; _i++) { + var x = xs_1[_i]; + if (out.indexOf(x) === -1) { + out.push(x); + } + } + return out; +} +exports.unique = unique; +function isObjectEmpty(obj) { + if (obj == null) { + throw new errors_1.ValueError("Invalid value in obj: " + JSON.stringify(obj)); + } + for (var key in obj) { + if (obj.hasOwnProperty(key)) { + return false; + } + } + return true; +} +exports.isObjectEmpty = isObjectEmpty; +function checkStringTypeUnionValue(values, label, value) { + if (value == null) { + return; + } + if (values.indexOf(value) < 0) { + throw new errors_1.ValueError(value + " is not a valid " + label + ". Valid values are " + values + " or null/undefined."); + } +} +exports.checkStringTypeUnionValue = checkStringTypeUnionValue; +function checkArrayTypeAndLength(x, expectedType, minLength, maxLength) { + if (minLength === void 0) { minLength = 0; } + if (maxLength === void 0) { maxLength = Infinity; } + assert(minLength >= 0); + assert(maxLength >= minLength); + return (Array.isArray(x) && x.length >= minLength && x.length <= maxLength && + x.every(function (e) { return typeof e === expectedType; })); +} +exports.checkArrayTypeAndLength = checkArrayTypeAndLength; +//# sourceMappingURL=generic_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js.map new file mode 100644 index 0000000..17ec9a2 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"generic_utils.js","sourceRoot":"","sources":["../../src/utils/generic_utils.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils_test.js.map new file mode 100644 index 0000000..4f4bfac --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/generic_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"generic_utils_test.js","sourceRoot":"","sources":["../../src/utils/generic_utils_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.d.ts new file mode 100644 index 0000000..fa42483 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.d.ts @@ -0,0 +1,2 @@ +import { Container } from '../engine/container'; +export declare function printSummary(model: Container, lineLength?: number, positions?: number[], printFn?: (message?: any, ...optionalParams: any[]) => void): void; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js new file mode 100644 index 0000000..2ee52cb --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js @@ -0,0 +1,155 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var variable_utils_1 = require("./variable_utils"); +function printSummary(model, lineLength, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + var sequentialLike = isModelSequentialLike(model); + var toDisplay = ['Layer (type)', 'Output shape', 'Param #']; + if (sequentialLike) { + lineLength = lineLength || 65; + positions = positions || [0.45, 0.85, 1]; + } + else { + lineLength = lineLength || 98; + positions = positions || [0.33, 0.55, 0.67, 1]; + } + if (positions[positions.length - 1] <= 1) { + positions = positions.map(function (p) { return Math.floor(lineLength * p); }); + } + var relevantNodes; + if (!sequentialLike) { + toDisplay.push('Receives inputs'); + relevantNodes = []; + for (var depth in model.nodesByDepth) { + relevantNodes.push.apply(relevantNodes, model.nodesByDepth[depth]); + } + } + printFn('_'.repeat(lineLength)); + printRow(toDisplay, positions, printFn); + printFn('='.repeat(lineLength)); + var layers = model.layers; + for (var i = 0; i < layers.length; ++i) { + if (sequentialLike) { + printLayerSummary(layers[i], positions, printFn); + } + else { + printLayerSummaryWithConnections(layers[i], positions, relevantNodes, printFn); + } + printFn((i === layers.length - 1 ? '=' : '_').repeat(lineLength)); + } + model.checkTrainableWeightsConsistency(); + var trainableCount; + if (model.collectedTrainableWeights != null) { + trainableCount = + variable_utils_1.countParamsInWeights(model.collectedTrainableWeights); + } + else { + trainableCount = variable_utils_1.countParamsInWeights(model.trainableWeights); + } + var nonTrainableCount = variable_utils_1.countParamsInWeights(model.nonTrainableWeights); + printFn("Total params: " + (trainableCount + nonTrainableCount)); + printFn("Trainable params: " + trainableCount); + printFn("Non-trainable params: " + nonTrainableCount); + printFn('_'.repeat(lineLength)); +} +exports.printSummary = printSummary; +function isModelSequentialLike(model) { + var sequentialLike = true; + var nodesByDepth = []; + var nodes = []; + for (var depth in model.nodesByDepth) { + nodesByDepth.push(model.nodesByDepth[depth]); + } + for (var _i = 0, nodesByDepth_1 = nodesByDepth; _i < nodesByDepth_1.length; _i++) { + var depthNodes = nodesByDepth_1[_i]; + if (depthNodes.length > 1 || + depthNodes.length === 1 && depthNodes[0].inboundLayers.length > 1) { + sequentialLike = false; + break; + } + nodes.push.apply(nodes, depthNodes); + } + if (sequentialLike) { + for (var _a = 0, _b = model.layers; _a < _b.length; _a++) { + var layer = _b[_a]; + var flag = false; + for (var _c = 0, _d = layer.inboundNodes; _c < _d.length; _c++) { + var node = _d[_c]; + if (nodes.indexOf(node) !== -1) { + if (flag) { + sequentialLike = false; + break; + } + else { + flag = true; + } + } + } + if (!sequentialLike) { + break; + } + } + } + return sequentialLike; +} +function printRow(fields, positions, printFn) { + if (printFn === void 0) { printFn = console.log; } + var line = ''; + for (var i = 0; i < fields.length; ++i) { + if (i > 0) { + line = line.slice(0, line.length - 1) + ' '; + } + line += fields[i]; + line = line.slice(0, positions[i]); + line += ' '.repeat(positions[i] - line.length); + } + printFn(line); +} +function printLayerSummary(layer, positions, printFn) { + var outputShape; + try { + outputShape = JSON.stringify(layer.outputShape); + } + catch (err) { + outputShape = 'multiple'; + } + var name = layer.name; + var className = layer.getClassName(); + var fields = [name + " (" + className + ")", outputShape, layer.countParams().toString()]; + printRow(fields, positions, printFn); +} +function printLayerSummaryWithConnections(layer, positions, relevantNodes, printFn) { + var outputShape; + try { + outputShape = JSON.stringify(layer.outputShape); + } + catch (err) { + outputShape = 'multiple'; + } + var connections = []; + for (var _i = 0, _a = layer.inboundNodes; _i < _a.length; _i++) { + var node = _a[_i]; + if (relevantNodes != null && relevantNodes.length > 0 && + relevantNodes.indexOf(node) === -1) { + continue; + } + for (var i = 0; i < node.inboundLayers.length; ++i) { + var inboundLayer = node.inboundLayers[i].name; + var inboundLayerIndex = node.nodeIndices[i]; + var inboundTensorIndex = node.tensorIndices[i]; + connections.push(inboundLayer + "[" + inboundLayerIndex + "][" + inboundTensorIndex + "]"); + } + } + var name = layer.name; + var className = layer.getClassName(); + var firstConnection = connections.length === 0 ? '' : connections[0]; + var fields = [ + name + " (" + className + ")", outputShape, layer.countParams().toString(), + firstConnection + ]; + printRow(fields, positions, printFn); + for (var i = 1; i < connections.length; ++i) { + printRow(['', '', '', connections[i]], positions, printFn); + } +} +//# sourceMappingURL=layer_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js.map new file mode 100644 index 0000000..eab0d8b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/layer_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"layer_utils.js","sourceRoot":"","sources":["../../src/utils/layer_utils.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.d.ts new file mode 100644 index 0000000..656534c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.d.ts @@ -0,0 +1,10 @@ +export declare type ArrayTypes = Uint8Array | Int32Array | Float32Array; +export declare function isInteger(x: number): boolean; +export declare function arrayProd(array: number[] | ArrayTypes, begin?: number, end?: number): number; +export declare function min(array: number[] | Float32Array): number; +export declare function max(array: number[] | Float32Array): number; +export declare function sum(array: number[] | Float32Array): number; +export declare function mean(array: number[] | Float32Array): number; +export declare function variance(array: number[] | Float32Array): number; +export declare function median(array: number[] | Float32Array): number; +export declare function range(begin: number, end: number): number[]; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js new file mode 100644 index 0000000..75f8e74 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js @@ -0,0 +1,71 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var errors_1 = require("../errors"); +function isInteger(x) { + return x === parseInt(x.toString(), 10); +} +exports.isInteger = isInteger; +function arrayProd(array, begin, end) { + if (begin == null) { + begin = 0; + } + if (end == null) { + end = array.length; + } + var prod = 1; + for (var i = begin; i < end; ++i) { + prod *= array[i]; + } + return prod; +} +exports.arrayProd = arrayProd; +function toArray1D(array) { + array = Array.isArray(array) ? new Float32Array(array) : array; + return tfjs_core_1.tensor1d(array); +} +function min(array) { + return tfc.min(toArray1D(array)).dataSync()[0]; +} +exports.min = min; +function max(array) { + return tfc.max(toArray1D(array)).dataSync()[0]; +} +exports.max = max; +function sum(array) { + return tfc.sum(toArray1D(array)).dataSync()[0]; +} +exports.sum = sum; +function mean(array) { + return sum(array) / array.length; +} +exports.mean = mean; +function variance(array) { + var demeaned = tfc.sub(toArray1D(array), tfjs_core_1.scalar(mean(array))); + var sumSquare = tfc.sum(tfc.mulStrict(demeaned, demeaned)).dataSync()[0]; + return sumSquare / array.length; +} +exports.variance = variance; +function median(array) { + var arraySorted = array.slice().sort(function (a, b) { return a - b; }); + var lowIdx = Math.floor((arraySorted.length - 1) / 2); + var highIdx = Math.ceil((arraySorted.length - 1) / 2); + if (lowIdx === highIdx) { + return arraySorted[lowIdx]; + } + return (arraySorted[lowIdx] + arraySorted[highIdx]) / 2; +} +exports.median = median; +function range(begin, end) { + if (end < begin) { + throw new errors_1.ValueError("end (" + end + ") < begin (" + begin + ") is forbidden."); + } + var out = []; + for (var i = begin; i < end; ++i) { + out.push(i); + } + return out; +} +exports.range = range; +//# sourceMappingURL=math_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js.map new file mode 100644 index 0000000..7c2930b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"math_utils.js","sourceRoot":"","sources":["../../src/utils/math_utils.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils_test.js.map new file mode 100644 index 0000000..ac1cf11 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/math_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"math_utils_test.js","sourceRoot":"","sources":["../../src/utils/math_utils_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.d.ts new file mode 100644 index 0000000..3e9b076 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.d.ts @@ -0,0 +1,4 @@ +import { serialization } from '@tensorflow/tfjs-core'; +import { JsonValue } from '../types'; +export declare function convertPythonicToTs(pythonicConfig: JsonValue, key?: string): serialization.ConfigDictValue; +export declare function convertTsToPythonic(tsConfig: serialization.ConfigDictValue, key?: string): JsonValue; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js new file mode 100644 index 0000000..632a7b4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js @@ -0,0 +1,93 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var generic_utils = require("../utils/generic_utils"); +function isArrayItemInputOrOutputName(key, index, value) { + return (key === 'inboundNodes' || key === 'outputLayers' || + key === 'inputLayers') && + index === 0 && typeof value === 'string'; +} +function convertPythonicToTs(pythonicConfig, key) { + if (pythonicConfig === null) { + return null; + } + else if (typeof pythonicConfig === 'string') { + return generic_utils.toCamelCase(pythonicConfig); + } + else if ((typeof pythonicConfig === 'number') || + (typeof pythonicConfig === 'boolean')) { + return pythonicConfig; + } + else if (pythonicConfig instanceof Array) { + var tsArray = []; + var arrayLength = pythonicConfig.length; + for (var i = 0; i < arrayLength; ++i) { + var item = pythonicConfig[i]; + if (isArrayItemInputOrOutputName(key, i, item)) { + tsArray.push(item); + } + else { + tsArray.push(convertPythonicToTs(item, key)); + } + } + return tsArray; + } + else { + var tsDict = {}; + for (var _i = 0, _a = Object.keys(pythonicConfig); _i < _a.length; _i++) { + var pythonicKey = _a[_i]; + var pythonicValue = pythonicConfig[pythonicKey]; + if (pythonicKey === 'name' && typeof pythonicValue === 'string') { + tsDict[pythonicKey] = pythonicValue; + } + else { + var tsKey = generic_utils.toCamelCase(pythonicKey); + tsDict[tsKey] = convertPythonicToTs(pythonicValue, tsKey); + } + } + return tsDict; + } +} +exports.convertPythonicToTs = convertPythonicToTs; +function convertTsToPythonic(tsConfig, key) { + if (tsConfig === null || tsConfig === undefined) { + return null; + } + else if (typeof tsConfig === 'string') { + return generic_utils.toSnakeCase(tsConfig); + } + else if ((typeof tsConfig === 'number') || (typeof tsConfig === 'boolean')) { + return tsConfig; + } + else if (tsConfig instanceof Array) { + var pyArray = []; + var arrayLength = tsConfig.length; + for (var i = 0; i < arrayLength; ++i) { + var item = tsConfig[i]; + if (isArrayItemInputOrOutputName(key, i, item)) { + pyArray.push(item); + } + else { + pyArray.push(convertTsToPythonic(item, key)); + } + } + return pyArray; + } + else { + var pyDict = {}; + for (var _i = 0, _a = Object.keys(tsConfig); _i < _a.length; _i++) { + var tsKey = _a[_i]; + var tsValue = tsConfig[tsKey]; + var pyKey = generic_utils.toSnakeCase(tsKey); + if ((tsKey === 'name' || tsKey === 'className') && + typeof tsValue === 'string') { + pyDict[pyKey] = tsValue; + } + else { + pyDict[pyKey] = convertTsToPythonic(tsValue, tsKey); + } + } + return pyDict; + } +} +exports.convertTsToPythonic = convertTsToPythonic; +//# sourceMappingURL=serialization_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js.map new file mode 100644 index 0000000..85d6fe4 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"serialization_utils.js","sourceRoot":"","sources":["../../src/utils/serialization_utils.ts"],"names":[],"mappings":";;AAmBA,sDAAwD;AAYxD,sCACI,GAAW,EAAE,KAAa,EAAE,KAAQ;IACtC,OAAO,CAAC,GAAG,KAAK,cAAc,IAAI,GAAG,KAAK,cAAc;QAChD,GAAG,KAAK,aAAa,CAAC;QAC1B,KAAK,KAAK,CAAC,IAAI,OAAO,KAAK,KAAK,QAAQ,CAAC;AAC/C,CAAC;AAQD,6BACI,cAAyB,EAAE,GAAY;IACzC,IAAI,cAAc,KAAK,IAAI,EAAE;QAC3B,OAAO,IAAI,CAAC;KACb;SAAM,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE;QAC7C,OAAO,aAAa,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;KAClD;SAAM,IACH,CAAC,OAAO,cAAc,KAAK,QAAQ,CAAC;QACpC,CAAC,OAAO,cAAc,KAAK,SAAS,CAAC,EAAE;QACzC,OAAO,cAAc,CAAC;KACvB;SAAM,IAAI,cAAc,YAAY,KAAK,EAAE;QAC1C,IAAM,OAAO,GAAG,EAAE,CAAC;QACnB,IAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC;QAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,EAAE,CAAC,EAAE;YACpC,IAAM,IAAI,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;YAC/B,IAAI,4BAA4B,CAAC,GAAG,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE;gBAC9C,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACpB;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;aAC9C;SACF;QACD,OAAO,OAAO,CAAC;KAChB;SAAM;QACL,IAAM,MAAM,GAA6B,EAAE,CAAC;QAC5C,KAA0B,UAA2B,EAA3B,KAAA,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,EAA3B,cAA2B,EAA3B,IAA2B;YAAhD,IAAM,WAAW,SAAA;YACpB,IAAM,aAAa,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC;YAClD,IAAI,WAAW,KAAK,MAAM,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE;gBAI/D,MAAM,CAAC,WAAW,CAAC,GAAG,aAAa,CAAC;aACrC;iBAAM;gBACL,IAAM,KAAK,GAAG,aAAa,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;gBACrD,MAAM,CAAC,KAAK,CAAC,GAAG,mBAAmB,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;aAC3D;SACF;QACD,OAAO,MAAM,CAAC;KACf;AACH,CAAC;AAtCD,kDAsCC;AAQD,6BACI,QAAuC,EAAE,GAAY;IACvD,IAAI,QAAQ,KAAK,IAAI,IAAI,QAAQ,KAAK,SAAS,EAAE;QAC/C,OAAO,IAAI,CAAC;KACb;SAAM,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;QACvC,OAAO,aAAa,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;KAC5C;SAAM,IACH,CAAC,OAAO,QAAQ,KAAK,QAAQ,CAAC,IAAI,CAAC,OAAO,QAAQ,KAAK,SAAS,CAAC,EAAE;QACrE,OAAO,QAAQ,CAAC;KACjB;SAAM,IAAI,QAAQ,YAAY,KAAK,EAAE;QACpC,IAAM,OAAO,GAAG,EAAE,CAAC;QACnB,IAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC;QACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,EAAE,CAAC,EAAE;YACpC,IAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,4BAA4B,CAAC,GAAG,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE;gBAC9C,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACpB;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;aAC9C;SACF;QACD,OAAO,OAAO,CAAC;KAChB;SAAM;QACL,IAAM,MAAM,GAA6B,EAAE,CAAC;QAC5C,KAAoB,UAAqB,EAArB,KAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAArB,cAAqB,EAArB,IAAqB;YAApC,IAAM,KAAK,SAAA;YACd,IAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;YAChC,IAAM,KAAK,GAAG,aAAa,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC/C,IAAI,CAAC,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,WAAW,CAAC;gBAC3C,OAAO,OAAO,KAAK,QAAQ,EAAE;gBAI/B,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC;aACzB;iBAAM;gBACL,MAAM,CAAC,KAAK,CAAC,GAAG,mBAAmB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;aACrD;SACF;QACD,OAAO,MAAM,CAAC;KACf;AACH,CAAC;AAtCD,kDAsCC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils_test.js.map new file mode 100644 index 0000000..252121b --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/serialization_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"serialization_utils_test.js","sourceRoot":"","sources":["../../src/utils/serialization_utils_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.d.ts new file mode 100644 index 0000000..73eff56 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.d.ts @@ -0,0 +1,7 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +export declare function expectTensorsClose(actual: Tensor | number[], expected: Tensor | number[], epsilon?: number): void; +export declare function expectTensorsValuesInRange(actual: Tensor, low: number, high: number): void; +export declare function describeMathCPUAndGPU(testName: string, tests: () => void): void; +export declare function describeMathCPU(testName: string, tests: () => void): void; +export declare function describeMathGPU(testName: string, tests: () => void): void; +export declare function expectNoLeakedTensors(testFunc: () => any, numNewTensors: number): void; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js new file mode 100644 index 0000000..1439838 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js @@ -0,0 +1,64 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var jasmine_util_1 = require("@tensorflow/tfjs-core/dist/jasmine_util"); +var state_1 = require("../backend/state"); +var errors_1 = require("../errors"); +function expectTensorsClose(actual, expected, epsilon) { + if (actual == null) { + throw new errors_1.ValueError('First argument to expectTensorsClose() is not defined.'); + } + if (expected == null) { + throw new errors_1.ValueError('Second argument to expectTensorsClose() is not defined.'); + } + tfjs_core_1.test_util.expectArraysClose(actual, expected, epsilon); +} +exports.expectTensorsClose = expectTensorsClose; +function expectTensorsValuesInRange(actual, low, high) { + if (actual == null) { + throw new errors_1.ValueError('First argument to expectTensorsClose() is not defined.'); + } + tfjs_core_1.test_util.expectValuesInRange(actual.dataSync(), low, high); +} +exports.expectTensorsValuesInRange = expectTensorsValuesInRange; +function describeMathCPUAndGPU(testName, tests) { + jasmine_util_1.describeWithFlags(testName, tfjs_core_1.test_util.ALL_ENVS, function () { + beforeEach(function () { + state_1.disposeScalarCache(); + }); + tests(); + }); +} +exports.describeMathCPUAndGPU = describeMathCPUAndGPU; +function describeMathCPU(testName, tests) { + jasmine_util_1.describeWithFlags(testName, tfjs_core_1.test_util.CPU_ENVS, function () { + beforeEach(function () { + state_1.disposeScalarCache(); + }); + tests(); + }); +} +exports.describeMathCPU = describeMathCPU; +function describeMathGPU(testName, tests) { + jasmine_util_1.describeWithFlags(testName, tfjs_core_1.test_util.WEBGL_ENVS, function () { + beforeEach(function () { + state_1.disposeScalarCache(); + }); + tests(); + }); +} +exports.describeMathGPU = describeMathGPU; +function expectNoLeakedTensors(testFunc, numNewTensors) { + testFunc(); + var numTensorsBefore = tfjs_core_1.memory().numTensors; + testFunc(); + var numTensorsAfter = tfjs_core_1.memory().numTensors; + var actualNewTensors = numTensorsAfter - numTensorsBefore; + if (actualNewTensors !== numNewTensors) { + throw new errors_1.ValueError("Created an unexpected number of new " + + ("Tensors. Expected: " + numNewTensors + ", created : " + actualNewTensors + ". ") + + "Please investigate the discrepency and/or use tidy."); + } +} +exports.expectNoLeakedTensors = expectNoLeakedTensors; +//# sourceMappingURL=test_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js.map new file mode 100644 index 0000000..43e736e --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/test_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"test_utils.js","sourceRoot":"","sources":["../../src/utils/test_utils.ts"],"names":[],"mappings":";;AAeA,mDAAgE;AAChE,wEAA0E;AAE1E,0CAAoD;AACpD,oCAAqC;AASrC,4BACI,MAAuB,EAAE,QAAyB,EAAE,OAAgB;IACtE,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,MAAM,IAAI,mBAAU,CAChB,wDAAwD,CAAC,CAAC;KAC/D;IACD,IAAI,QAAQ,IAAI,IAAI,EAAE;QACpB,MAAM,IAAI,mBAAU,CAChB,yDAAyD,CAAC,CAAC;KAChE;IACD,qBAAS,CAAC,iBAAiB,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;AACzD,CAAC;AAXD,gDAWC;AAOD,oCACI,MAAc,EAAE,GAAW,EAAE,IAAY;IAC3C,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,MAAM,IAAI,mBAAU,CAChB,wDAAwD,CAAC,CAAC;KAC/D;IACD,qBAAS,CAAC,mBAAmB,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;AAC9D,CAAC;AAPD,gEAOC;AAQD,+BAAsC,QAAgB,EAAE,KAAiB;IACvE,gCAAiB,CAAC,QAAQ,EAAE,qBAAS,CAAC,QAAQ,EAAE;QAC9C,UAAU,CAAC;YACT,0BAAkB,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,KAAK,EAAE,CAAC;IACV,CAAC,CAAC,CAAC;AACL,CAAC;AAPD,sDAOC;AAOD,yBAAgC,QAAgB,EAAE,KAAiB;IACjE,gCAAiB,CAAC,QAAQ,EAAE,qBAAS,CAAC,QAAQ,EAAE;QAC9C,UAAU,CAAC;YACT,0BAAkB,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,KAAK,EAAE,CAAC;IACV,CAAC,CAAC,CAAC;AACL,CAAC;AAPD,0CAOC;AAOD,yBAAgC,QAAgB,EAAE,KAAiB;IACjE,gCAAiB,CAAC,QAAQ,EAAE,qBAAS,CAAC,UAAU,EAAE;QAChD,UAAU,CAAC;YACT,0BAAkB,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,KAAK,EAAE,CAAC;IACV,CAAC,CAAC,CAAC;AACL,CAAC;AAPD,0CAOC;AAWD,+BAEI,QAAmB,EAAE,aAAqB;IAC5C,QAAQ,EAAE,CAAC;IACX,IAAM,gBAAgB,GAAG,kBAAM,EAAE,CAAC,UAAU,CAAC;IAC7C,QAAQ,EAAE,CAAC;IACX,IAAM,eAAe,GAAG,kBAAM,EAAE,CAAC,UAAU,CAAC;IAC5C,IAAM,gBAAgB,GAAG,eAAe,GAAG,gBAAgB,CAAC;IAC5D,IAAI,gBAAgB,KAAK,aAAa,EAAE;QACtC,MAAM,IAAI,mBAAU,CAChB,sCAAsC;aACtC,yBAAuB,aAAa,oBAChC,gBAAgB,OAAI,CAAA;YACxB,qDAAqD,CAAC,CAAC;KAC5D;AACH,CAAC;AAfD,sDAeC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.d.ts new file mode 100644 index 0000000..c247e68 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.d.ts @@ -0,0 +1,6 @@ +import { Tensor } from '@tensorflow/tfjs-core'; +import { Shape } from '../types'; +export declare function isArrayOfShapes(x: Shape | Shape[]): boolean; +export declare function normalizeShapeList(x: Shape | Shape[]): Shape[]; +export declare function getExactlyOneTensor(xs: Tensor | Tensor[]): Tensor; +export declare function getExactlyOneShape(shapes: Shape | Shape[]): Shape; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js new file mode 100644 index 0000000..1511fee --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js @@ -0,0 +1,47 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var errors_1 = require("../errors"); +function isArrayOfShapes(x) { + return Array.isArray(x) && Array.isArray(x[0]); +} +exports.isArrayOfShapes = isArrayOfShapes; +function normalizeShapeList(x) { + if (x.length === 0) { + return []; + } + if (!Array.isArray(x[0])) { + return [x]; + } + return x; +} +exports.normalizeShapeList = normalizeShapeList; +function getExactlyOneTensor(xs) { + var x; + if (Array.isArray(xs)) { + if (xs.length !== 1) { + throw new errors_1.ValueError("Expected Tensor length to be 1; got " + xs.length); + } + x = xs[0]; + } + else { + x = xs; + } + return x; +} +exports.getExactlyOneTensor = getExactlyOneTensor; +function getExactlyOneShape(shapes) { + if (Array.isArray(shapes) && Array.isArray(shapes[0])) { + if (shapes.length === 1) { + shapes = shapes; + return shapes[0]; + } + else { + throw new errors_1.ValueError("Expected exactly 1 Shape; got " + shapes.length); + } + } + else { + return shapes; + } +} +exports.getExactlyOneShape = getExactlyOneShape; +//# sourceMappingURL=types_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js.map new file mode 100644 index 0000000..43c648f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types_utils.js","sourceRoot":"","sources":["../../src/utils/types_utils.ts"],"names":[],"mappings":";;AAcA,oCAAqC;AAQrC,yBAAgC,CAAgB;IAC9C,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjD,CAAC;AAFD,0CAEC;AAQD,4BAAmC,CAAgB;IACjD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;QAClB,OAAO,EAAE,CAAC;KACX;IACD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;QACxB,OAAO,CAAC,CAAC,CAAY,CAAC;KACvB;IACD,OAAO,CAAY,CAAC;AACtB,CAAC;AARD,gDAQC;AAQD,6BAAoC,EAAmB;IACrD,IAAI,CAAS,CAAC;IACd,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;QACrB,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,MAAM,IAAI,mBAAU,CAAC,yCAAuC,EAAE,CAAC,MAAQ,CAAC,CAAC;SAC1E;QACD,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;KACX;SAAM;QACL,CAAC,GAAG,EAAY,CAAC;KAClB;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAXD,kDAWC;AAYD,4BAAmC,MAAqB;IACtD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE;QACrD,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;YACvB,MAAM,GAAG,MAAiB,CAAC;YAC3B,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;SAClB;aAAM;YACL,MAAM,IAAI,mBAAU,CAAC,mCAAiC,MAAM,CAAC,MAAQ,CAAC,CAAC;SACxE;KACF;SAAM;QACL,OAAO,MAAe,CAAC;KACxB;AACH,CAAC;AAXD,gDAWC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils_test.js.map new file mode 100644 index 0000000..faba6e1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/types_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types_utils_test.js","sourceRoot":"","sources":["../../src/utils/types_utils_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.d.ts new file mode 100644 index 0000000..9664dbf --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.d.ts @@ -0,0 +1,2 @@ +import { LayerVariable } from '../variables'; +export declare function countParamsInWeights(weights: LayerVariable[]): number; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js new file mode 100644 index 0000000..65222e9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js @@ -0,0 +1,17 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +function countParamsInWeights(weights) { + var count = 0; + for (var _i = 0, weights_1 = weights; _i < weights_1.length; _i++) { + var weight = weights_1[_i]; + if (weight.shape.length === 0) { + count += 1; + } + else { + count += weight.shape.reduce(function (a, b) { return a * b; }); + } + } + return count; +} +exports.countParamsInWeights = countParamsInWeights; +//# sourceMappingURL=variable_utils.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js.map new file mode 100644 index 0000000..bc31be3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils.js.map @@ -0,0 +1 @@ +{"version":3,"file":"variable_utils.js","sourceRoot":"","sources":["../../src/utils/variable_utils.ts"],"names":[],"mappings":";;AAmBA,8BAAqC,OAAwB;IAC3D,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,KAAqB,UAAO,EAAP,mBAAO,EAAP,qBAAO,EAAP,IAAO;QAAvB,IAAM,MAAM,gBAAA;QACf,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,KAAK,IAAI,CAAC,CAAC;SACZ;aAAM;YACL,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,GAAG,CAAC,EAAL,CAAK,CAAC,CAAC;SAC/C;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAVD,oDAUC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils_test.js.map new file mode 100644 index 0000000..d98306a --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/utils/variable_utils_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"variable_utils_test.js","sourceRoot":"","sources":["../../src/utils/variable_utils_test.ts"],"names":[],"mappings":";;AAUA,mDAAoD;AAEpD,0CAA2C;AAE3C,iDAAmD;AAEnD,QAAQ,CAAC,sBAAsB,EAAE;IAC/B,EAAE,CAAC,cAAc,EAAE;QACjB,MAAM,CAAC,cAAc,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE;QACvB,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,kBAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE;QACrB,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC;QACtE,MAAM,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;QACxC,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,kBAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9C,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,IAAM,OAAO,GAAG,IAAI,yBAAa,CAAC,iBAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC;QACtE,MAAM,CAAC,cAAc,CAAC,oBAAoB,CAAC;YACzC,OAAO,EAAE,OAAO,EAAE,OAAO;SAC1B,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/variables.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/variables.d.ts new file mode 100644 index 0000000..cf9988f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/variables.d.ts @@ -0,0 +1,32 @@ +import * as tfc from '@tensorflow/tfjs-core'; +import { DataType, Tensor } from '@tensorflow/tfjs-core'; +import { Constraint } from './constraints'; +import { Shape } from './types'; +export declare class LayerVariable { + readonly dtype: DataType; + readonly shape: Shape; + readonly id: number; + readonly name: string; + readonly originalName: string; + readonly trainable: boolean; + protected readonly val: tfc.Variable; + readonly constraint: Constraint; + constructor(val: Tensor, dtype?: DataType, name?: string, trainable?: boolean, constraint?: Constraint); + read(): Tensor; + write(newVal: Tensor): this; +} +export declare function variable(x: Tensor, dtype?: DataType, name?: string, constraint?: Constraint): LayerVariable; +export declare function zerosVariable(shape: Shape, dtype?: DataType, name?: string): LayerVariable; +export declare function zerosLike(x: Tensor, dtype?: DataType, name?: string): LayerVariable; +export declare function onesVariable(shape: Shape, dtype?: DataType, name?: string): LayerVariable; +export declare function onesLike(x: Tensor, dtype?: DataType, name?: string): LayerVariable; +export declare function eyeVariable(size: number, dtype?: DataType, name?: string): LayerVariable; +export declare function randomUniformVariable(shape: Shape, minval: number, maxval: number, dtype?: DataType, seed?: number, name?: string): LayerVariable; +export declare function truncatedNormalVariable(shape: Shape, mean?: number, stddev?: number, dtype?: DataType, seed?: number, name?: string): LayerVariable; +export declare function randomNormalVariable(shape: Shape, mean?: number, stddev?: number, dtype?: DataType, seed?: number, name?: string): LayerVariable; +export declare function update(x: LayerVariable, xNew: Tensor): LayerVariable; +export declare function updateAdd(x: LayerVariable, increment: Tensor): LayerVariable; +export declare function updateSub(x: LayerVariable, decrement: Tensor): LayerVariable; +export declare function batchGetValue(xs: LayerVariable[]): Tensor[]; +export declare function batchSetValue(variablesAndValues: Array<[LayerVariable, Tensor]>): void; +export declare function gradients(lossFn: () => tfc.Scalar, variables: LayerVariable[]): Tensor[]; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/variables.js b/node_modules/@tensorflow/tfjs-layers/dist/variables.js new file mode 100644 index 0000000..ae64f4c --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/variables.js @@ -0,0 +1,125 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var tfc = require("@tensorflow/tfjs-core"); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var state_1 = require("./backend/state"); +var common_1 = require("./common"); +var errors_1 = require("./errors"); +var DEFAULT_VARIABLE_NAME_PREFIX = 'Variable'; +var LayerVariable = (function () { + function LayerVariable(val, dtype, name, trainable, constraint) { + if (dtype === void 0) { dtype = 'float32'; } + if (name === void 0) { name = DEFAULT_VARIABLE_NAME_PREFIX; } + if (trainable === void 0) { trainable = true; } + if (constraint === void 0) { constraint = null; } + this.dtype = dtype == null ? 'float32' : dtype; + this.shape = val.shape; + this.id = state_1.getNextUniqueTensorId(); + name = name == null ? DEFAULT_VARIABLE_NAME_PREFIX : name; + this.originalName = common_1.getScopedTensorName(name); + this.name = common_1.getUniqueTensorName(this.originalName); + this.trainable = trainable; + this.constraint = constraint; + this.val = tfc.variable(val, this.trainable, this.name, this.dtype); + } + LayerVariable.prototype.read = function () { + return this.val; + }; + LayerVariable.prototype.write = function (newVal) { + checkShapesMatch(this.val, newVal); + this.val.assign(newVal); + if (this.constraint != null) { + this.val.assign(this.constraint.apply(this.val)); + } + return this; + }; + return LayerVariable; +}()); +exports.LayerVariable = LayerVariable; +function checkShapesMatch(x, y) { + if (x.shape.toString() !== y.shape.toString()) { + throw new Error('Shape mismatch: ' + JSON.stringify(x.shape) + ' vs. ' + + JSON.stringify(y.shape)); + } +} +function variable(x, dtype, name, constraint) { + return new LayerVariable(x, dtype, name, true, constraint); +} +exports.variable = variable; +function zerosVariable(shape, dtype, name) { + return new LayerVariable(tfc.zeros(shape), dtype, name); +} +exports.zerosVariable = zerosVariable; +function zerosLike(x, dtype, name) { + return new LayerVariable(tfc.zerosLike(x), dtype, name); +} +exports.zerosLike = zerosLike; +function onesVariable(shape, dtype, name) { + var allocated = tfc.ones(shape); + return new LayerVariable(allocated, dtype, name); +} +exports.onesVariable = onesVariable; +function onesLike(x, dtype, name) { + var allocated = tfc.onesLike(x); + return new LayerVariable(allocated, dtype, name); +} +exports.onesLike = onesLike; +function eyeVariable(size, dtype, name) { + return new LayerVariable(tfc.eye(size), dtype, name); +} +exports.eyeVariable = eyeVariable; +function randomUniformVariable(shape, minval, maxval, dtype, seed, name) { + if (name === void 0) { name = 'randomUniform'; } + return new LayerVariable(tfc.randomUniform(shape, minval, maxval, dtype), dtype, name); +} +exports.randomUniformVariable = randomUniformVariable; +function truncatedNormalVariable(shape, mean, stddev, dtype, seed, name) { + if (mean === void 0) { mean = 0.0; } + if (stddev === void 0) { stddev = 1.0; } + if (name === void 0) { name = 'truncatedNormal'; } + if (dtype === 'bool') { + throw new errors_1.NotImplementedError("randomNormal does not support dType bool."); + } + return new LayerVariable(tfc.truncatedNormal(shape, mean, stddev, dtype, seed), dtype, name); +} +exports.truncatedNormalVariable = truncatedNormalVariable; +function randomNormalVariable(shape, mean, stddev, dtype, seed, name) { + if (mean === void 0) { mean = 0.0; } + if (stddev === void 0) { stddev = 1.0; } + if (name === void 0) { name = 'randomNormal'; } + if (dtype === 'bool') { + throw new errors_1.NotImplementedError("randomNormalVariable does not support dType bool."); + } + return new LayerVariable(tfc.randomNormal(shape, mean, stddev, dtype, seed), dtype, name); +} +exports.randomNormalVariable = randomNormalVariable; +function update(x, xNew) { + return x.write(xNew); +} +exports.update = update; +function updateAdd(x, increment) { + return x.write(tfc.add(x.read(), increment)); +} +exports.updateAdd = updateAdd; +function updateSub(x, decrement) { + return x.write(tfc.sub(x.read(), decrement)); +} +exports.updateSub = updateSub; +function batchGetValue(xs) { + return xs.map(function (x) { return x.read(); }); +} +exports.batchGetValue = batchGetValue; +function batchSetValue(variablesAndValues) { + variablesAndValues.map(function (variableAndValue) { + var variable = variableAndValue[0]; + variable.write(variableAndValue[1]); + }); +} +exports.batchSetValue = batchSetValue; +function gradients(lossFn, variables) { + var variableList = variables.map(function (variable) { return variable.read(); }); + var valudAndGrads = tfjs_core_1.variableGrads(lossFn, variableList); + return variables.map(function (variable) { return valudAndGrads.grads[variable.name]; }); +} +exports.gradients = gradients; +//# sourceMappingURL=variables.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/variables.js.map b/node_modules/@tensorflow/tfjs-layers/dist/variables.js.map new file mode 100644 index 0000000..8b44878 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/variables.js.map @@ -0,0 +1 @@ +{"version":3,"file":"variables.js","sourceRoot":"","sources":["../src/variables.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/variables_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/variables_test.js.map new file mode 100644 index 0000000..21d90a8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/variables_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"variables_test.js","sourceRoot":"","sources":["../src/variables_test.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/version.d.ts b/node_modules/@tensorflow/tfjs-layers/dist/version.d.ts new file mode 100644 index 0000000..0175964 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/version.d.ts @@ -0,0 +1,2 @@ +declare const version = "0.7.2"; +export { version }; diff --git a/node_modules/@tensorflow/tfjs-layers/dist/version.js b/node_modules/@tensorflow/tfjs-layers/dist/version.js new file mode 100644 index 0000000..dc52f77 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/version.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var version = '0.7.2'; +exports.version = version; +//# sourceMappingURL=version.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/version.js.map b/node_modules/@tensorflow/tfjs-layers/dist/version.js.map new file mode 100644 index 0000000..dd346c9 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/version.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version.js","sourceRoot":"","sources":["../src/version.ts"],"names":[],"mappings":";;AAGA,IAAM,OAAO,GAAG,OAAO,CAAC;AAChB,0BAAO"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/dist/version_test.js.map b/node_modules/@tensorflow/tfjs-layers/dist/version_test.js.map new file mode 100644 index 0000000..bfb586d --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/dist/version_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version_test.js","sourceRoot":"","sources":["../src/version_test.ts"],"names":[],"mappings":";;AAWA,IAAM,WAAW,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;AAC/C,iCAAuC;AAEvC,QAAQ,CAAC,+BAA+B,EAAE;IACxC,EAAE,CAAC,gBAAgB,EAAE;QACnB,IAAM,qBAAqB,GACvB,WAAW,CAAC,eAAe,CAAC,uBAAuB,CAAC,CAAC;QACzD,IAAM,sBAAsB,GACxB,WAAW,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;QAC1D,MAAM,CAAC,qBAAqB,CAAC,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE;QAEvC,IAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;QACpD,MAAM,CAAC,sBAAc,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs-layers/package.json b/node_modules/@tensorflow/tfjs-layers/package.json new file mode 100644 index 0000000..3bdd845 --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/package.json @@ -0,0 +1,76 @@ +{ + "_from": "@tensorflow/tfjs-layers@0.7.2", + "_id": "@tensorflow/tfjs-layers@0.7.2", + "_inBundle": false, + "_integrity": "sha512-NwGmyYCrzV8cYycqA9fVfBWaz1zS1hqHP5MsRwU1m92TX/5lEhRClRmVCHJ4K8/GR+tYMl1PR/qCkeRjttwk7A==", + "_location": "/@tensorflow/tfjs-layers", + "_phantomChildren": {}, + "_requested": { + "type": "version", + "registry": true, + "raw": "@tensorflow/tfjs-layers@0.7.2", + "name": "@tensorflow/tfjs-layers", + "escapedName": "@tensorflow%2ftfjs-layers", + "scope": "@tensorflow", + "rawSpec": "0.7.2", + "saveSpec": null, + "fetchSpec": "0.7.2" + }, + "_requiredBy": [ + "/@tensorflow/tfjs" + ], + "_resolved": "https://registry.npmjs.org/@tensorflow/tfjs-layers/-/tfjs-layers-0.7.2.tgz", + "_shasum": "3a8c083255c72da272245ae5b435c66af9573eb8", + "_spec": "@tensorflow/tfjs-layers@0.7.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs", + "bundleDependencies": false, + "deprecated": false, + "description": "TensorFlow layers API in JavaScript", + "devDependencies": { + "@tensorflow/tfjs-core": "~0.12.8", + "@types/jasmine": "~2.5.53", + "clang-format": "~1.2.2", + "http-server": "~0.10.0", + "jasmine-core": "~3.1.0", + "karma": "~2.0.0", + "karma-browserstack-launcher": "~1.3.0", + "karma-chrome-launcher": "~2.2.0", + "karma-firefox-launcher": "~1.1.0", + "karma-jasmine": "~1.1.1", + "karma-typescript": "^3.0.12", + "rimraf": "~2.6.2", + "rollup": "^0.58.2", + "rollup-plugin-commonjs": "9.1.3", + "rollup-plugin-node-resolve": "3.3.0", + "rollup-plugin-typescript2": "0.13.0", + "rollup-plugin-uglify": "~3.0.0", + "tslint": "~5.6.0", + "tslint-no-circular-imports": "^0.5.0", + "typescript": "2.8.3", + "yalc": "~1.0.0-pre.21" + }, + "jsdelivr": "dist/tf-layers.min.js", + "jsnext:main": "dist/tf-layers.esm.js", + "main": "dist/index.js", + "module": "dist/tf-layers.esm.js", + "name": "@tensorflow/tfjs-layers", + "peerDependencies": { + "@tensorflow/tfjs-core": "~0.12.8" + }, + "private": false, + "scripts": { + "build": "tsc", + "build-npm": "./scripts/build-npm.sh", + "format": "./tools/clang_format_ts.sh", + "link-local": "yalc link", + "lint": "tslint -p . --type-check -t verbose", + "publish-local": "yarn build-npm && yalc push", + "publish-npm": "./scripts/publish-npm.sh", + "test": "karma start", + "test-integ": "cd integration_tests/tfjs2keras && ./run-test.sh", + "test-travis": "karma start --browsers='bs_firefox_mac,bs_chrome_mac' --singleRun --reporters='dots,karma-typescript'" + }, + "types": "dist/index.d.ts", + "unpkg": "dist/tf-layers.min.js", + "version": "0.7.2" +} diff --git a/node_modules/@tensorflow/tfjs-layers/tsconfig.json b/node_modules/@tensorflow/tfjs-layers/tsconfig.json new file mode 100644 index 0000000..7709b7f --- /dev/null +++ b/node_modules/@tensorflow/tfjs-layers/tsconfig.json @@ -0,0 +1,23 @@ +{ + "compilerOptions": { + "module": "commonjs", + "moduleResolution": "node", + "noImplicitAny": true, + "sourceMap": true, + "removeComments": true, + "preserveConstEnums": true, + "declaration": true, + "target": "es5", + "lib": ["es2015", "dom"], + "outDir": "./dist", + "noUnusedLocals": true, + "noImplicitReturns": true, + "noImplicitThis": true, + "alwaysStrict": true, + "noUnusedParameters": false, + "pretty": true, + "noFallthroughCasesInSwitch": true, + "allowUnreachableCode": false + }, + "include": ["src/"] +} diff --git a/node_modules/@tensorflow/tfjs/GALLERY.md b/node_modules/@tensorflow/tfjs/GALLERY.md new file mode 100644 index 0000000..8ddf750 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/GALLERY.md @@ -0,0 +1,74 @@ +# Gallery + +Welcome to the TensorFlow.js gallery! This is a collection of TensorFlow.js projects, tutorials, videos, and more. + +Please reach out to us if you'd like to put your project on the list. + +## Demos & Applications + +- [Move Mirror](https://experiments.withgoogle.com/collection/ai/move-mirror/view) - An AI Experiment with Pose Estimation in the Browser using TensorFlow.js +- [Emoji Scavenger Hunt](https://emojiscavengerhunt.withgoogle.com/) - Locate the emoji we show you in the real world with your phone’s camera. +- [Metacar](https://www.metacar-project.com/) - A reinforcement learning environment for self-driving cars in the browser. +- [Evolution Simulator](https://github.com/adityathebe/evolutionSimulator) - Evolution Simulator using NeuroEvolution +- [Play pong with webcam](https://ml4a.github.io/demos/tfjs/regression-pong.html) by Gene Kogan +- [Make music with PoseNet](https://ml4a.github.io/demos/tfjs/posenet-music.html) by Gene Kogan +- [Neural drum machine](https://codepen.io/teropa/pen/JLjXGK) by Tero Parviainen +- [Pose Music](https://codepen.io/teropa/pen/QxLrMp) by Tero Parviainen +- [Neural Arpeggiator](https://codepen.io/teropa/pen/ddqEwj) by Tero Parviainen +- [Neural Melody Autocompletion](https://codepen.io/teropa/pen/gvwwZL) by Tero Parviainen +- [Deep Roll](https://codepen.io/teropa/pen/zpbLOj) by Tero Parviainen +- [Latent Cycles](https://codepen.io/teropa/pen/rdoPbG) by Tero Parviainen +- [PoseNet + Pts.js](https://github.com/williamngan/pts/tree/master/demo/more/tfjs_posenet) - Visualizing pose with pts.js +- [Falling balls + DQN](http://web.sfc.keio.ac.jp/~t15704yn/falling/index.html) - A demo of a DQN agent that learns to dodge falling balls by seann999 +- [Tenori Off](https://tenori-off.glitch.me/) - An ML-powered music sequencer by Monica Dinculescu +- [Hello TensorFlow.js](https://hello-tensorflow.glitch.me/) - Polynomial Regression by Monica Dinculescu +- [Simple MNIST GAN](https://mwdchang.github.io/tfjs-gan/) by Daniel Chang +- [Complementary Color Prediction](http://stelling.cc/complementary-color-prediction/) by Roberto Stelling +- [Mars at Home](https://github.com/MarsAtHome/marsjs) - Mars@Home client for Firefox & Chrome - Labels image from Unsplash in browser +- [Nxt Word](https://github.com/rajveermalviya/language-modeling) - Next Word Predictor - by Rajveer Malviya + +## Tutorials + +These tutorials augment the [official tutorials](https://js.tensorflow.org/tutorials/). + +- [A gentle introduction to TensorFlow.js](https://medium.com/tensorflow/a-gentle-introduction-to-tensorflow-js-dba2e5257702) by Zaid Alyafeai +- [Train a model in tf.keras with Colab, and run it in the browser with TensorFlow.js](https://medium.com/tensorflow/train-on-google-colab-and-run-on-the-browser-a-case-study-8a45f9b1474e) by Zaid Alyafeai +- [Python Programming - Deep learning in the browser with TensorFlow.js](https://pythonprogramming.net/deep-learning-browser-introduction-tensorflowjs/) by Harrison Kinsley +- [Basic Tutorial with TensorFlow.js: Linear Regression](https://medium.com/@tristansokol/basic-tutorial-with-tensorflow-js-linear-regression-aa68b16e5b8e) by Tristan Sokol + +## Video tutorials +- [The Coding Train - TensorFlow.js Introduction](https://www.youtube.com/playlist?list=PLRqwX-V7Uu6YIeVA3dNxbR9PYj4wV31oQ) +- [The Coding Train - TensorFlow.js Color Classifier](https://www.youtube.com/playlist?list=PLRqwX-V7Uu6bmMRCIoTi72aNWHo7epX4L) +- [Siraj Raval - TensorFlow.js Explained](https://www.youtube.com/watch?v=Nc8kZABv-KE) +- [Siraj Raval - Financial Forecasting using TensorFlow.js](https://www.youtube.com/watch?v=5Uw1iSwvHH8) +- [Siraj Raval - Webcam tracking with TensorFlow.js](https://www.youtube.com/watch?v=9KqNk5keyCc) +- [Angular Firebase - TensorFlow.js Quickstart](https://www.youtube.com/watch?v=Y_XM3Bu-4yc) + +## Talks +- [TensorFlow dev summit](https://www.youtube.com/watch?v=YB-kfeNIPCE) - Official TensorFlow.js launch +- [Google I/O, Node.js binding launch](https://www.youtube.com/watch?v=OmofOvMApTU) - Official TensorFlow.js + Node.js launch +- [Deep Learning in JS - Ashi Krishnan - JSConf EU 2018](https://www.youtube.com/watch?v=SV-cgdobtTA) + +## Blog posts +- [Move Mirror](https://medium.com/tensorflow/move-mirror-an-ai-experiment-with-pose-estimation-in-the-browser-using-tensorflow-js-2f7b769f9b23?linkId=54484629) - An AI Experiment with Pose Estimation in the Browser using TensorFlow.js +- [Abstract art with ML](https://janhuenermann.com/blog/abstract-art-with-ml) by Jan Huenermann +- [Deep Overwatch with TensorFlow.js](https://medium.com/@farzatv/deepoverwatch-combining-tensorflow-js-overwatch-computer-vision-and-music-1a84d4598bc0) -  combining TensorFlow.js, Overwatch, Computer Vision, and Music by Farza +- [Real-time Human Pose Estimation in the Browser with TensorFlow.js](https://medium.com/tensorflow/real-time-human-pose-estimation-in-the-browser-with-tensorflow-js-7dd0bc881cd5) by Dan Oved +- [Getting Started with TensorFlow.js](https://medium.com/tensorflow/getting-started-with-tensorflow-js-50f6783489b2) by Laurence Moroney +- [Introducing TensorFlow.js](https://medium.com/tensorflow/introducing-tensorflow-js-machine-learning-in-javascript-bf3eab376db) by Josh Gordon and Sara Robinson +- [Solving the Chrome T-Rex Game with Neural Networks, Genetic Algorithms and TensorFlow.js (Chinese: 前端人工智能?TensorFlow.js 学会游戏通关)](https://zhuanlan.zhihu.com/p/35451395) by [@MagicCube](https://github.com/MagicCube) + +## Notebooks +- [Introduction to TensorFlow.js](https://beta.observablehq.com/@nsthorat/introduction-to-deeplearn-js) by Nikhil Thorat +- [How to build a Teachable Machine](https://beta.observablehq.com/@nsthorat/how-to-build-a-teachable-machine-with-tensorflow-js) by Nikhil Thorat +- [Smoothgrad in TensorFlow.js](https://beta.observablehq.com/@aman-tiwari/smoothgrad-in-tensorflow-js?linkId=53020429) by Aman Tiwari +- [Visualizing training using TensorFlow.js + MLB data](https://beta.observablehq.com/@nkreeger/visualizing-ml-training-using-tensorflow-js-and-baseball-d) by Nick Kreeger +- [Animation CPPNs](https://beta.observablehq.com/@emilyreif/animation-with-cppns) - by Emily Reif + +## Libraries using TensorFlow.js + +- [ML5](https://ml5js.org/) - Friendly machine learning for the web +- [magenta.js](https://magenta.tensorflow.org/js) - Music and Art Generation with Machine Intelligence in the Browser. +- [SeeClarke.js](https://github.com/labofoz/SeeClarke.js) - A library for adding face-controlled pointers to your site. +- [face-api.js](https://github.com/justadudewhohacks/face-api.js) - A JavaScript API for face detection and face recognition in the browser. +- [TensorFlow.js GPU-accelerated t-SNE](https://github.com/tensorflow/tfjs-tsne) - A linear t-SNE for the web. diff --git a/node_modules/@tensorflow/tfjs/LICENSE b/node_modules/@tensorflow/tfjs/LICENSE new file mode 100644 index 0000000..d645695 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/LICENSE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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. diff --git a/node_modules/@tensorflow/tfjs/README.md b/node_modules/@tensorflow/tfjs/README.md new file mode 100644 index 0000000..1249811 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/README.md @@ -0,0 +1,145 @@ +[![Build Status](https://travis-ci.org/tensorflow/tfjs.svg?branch=master)](https://travis-ci.org/tensorflow/tfjs) +# TensorFlow.js + +TensorFlow.js is an open-source hardware-accelerated JavaScript library for +training and deploying machine learning models. + +**Develop ML in the Browser**
+Use flexible and intuitive APIs to build models from scratch using the low-level +JavaScript linear algebra library or the high-level layers API. + +**Run Existing models**
+Use TensorFlow.js model converters to run pre-existing TensorFlow models right +in the browser. + +**Retrain Existing models**
+Retrain pre-existing ML models using sensor data connected to the browser, or +other client-side data. + +## About this repo + +This repository contains the logic and scripts that combine +two packages: +- [TensorFlow.js Core](https://github.com/tensorflow/tfjs-core), + a flexible low-level API, formerly known as *deeplearn.js*. +- [TensorFlow.js Layers](https://github.com/tensorflow/tfjs-layers), + a high-level API which implements functionality similar to + [Keras](https://keras.io/). +- [TensorFlow.js Converter](https://github.com/tensorflow/tfjs-converter), + tools to import a TensorFlow SavedModel to TensorFlow.js + +If you care about bundle size, you can import those packages individually. + +## Examples + +Check out our +[examples repository](https://github.com/tensorflow/tfjs-examples) +and our [tutorials](https://js.tensorflow.org/tutorials/). + +## Gallery + +Be sure to check out [the gallery](GALLERY.md) of all projects related to TensorFlow.js. + +## Pre-trained models + +Be sure to also check out our [models repository](https://github.com/tensorflow/tfjs-models) where we host pretrained models +on NPM. + +## Getting started + +There are two main ways to get TensorFlow.js in your JavaScript project: +via script tags or by installing it from NPM +and using a build tool like Parcel, +WebPack, or Rollup. + +### via Script Tag + +Add the following code to an HTML file: + +```html + + + + + + + + + + + + +``` + +Open up that html file in your browser and the code should run! + +### via NPM + +Add TensorFlow.js to your project using yarn or npm. Note: Because +we use ES2017 syntax (such as `import`), this workflow assumes you are using a modern browser or a bundler/transpiler +to convert your code to something older browsers understand. See our +examples +to see how we use Parcel to build +our code. However you are free to use any build tool that you prefer. + + + +```js +import * as tf from '@tensorflow/tfjs'; + +// Define a model for linear regression. +const model = tf.sequential(); +model.add(tf.layers.dense({units: 1, inputShape: [1]})); + +// Prepare the model for training: Specify the loss and the optimizer. +model.compile({loss: 'meanSquaredError', optimizer: 'sgd'}); + +// Generate some synthetic data for training. +const xs = tf.tensor2d([1, 2, 3, 4], [4, 1]); +const ys = tf.tensor2d([1, 3, 5, 7], [4, 1]); + +// Train the model using the data. +model.fit(xs, ys).then(() => { + // Use the model to do inference on a data point the model hasn't seen before: + model.predict(tf.tensor2d([5], [1, 1])).print(); +}); +``` + +See our tutorials, examples +and documentation for more details. + +## Importing pre-trained models + +We support porting pre-trained models from: +- [TensorFlow SavedModel](https://github.com/tensorflow/tfjs-converter) +- [Keras](https://js.tensorflow.org/tutorials/import-keras.html) + +## Find out more + +[TensorFlow.js](https://js.tensorflow.org) is a part of the +[TensorFlow](https://www.tensorflow.org) ecosystem. For more info: +- [js.tensorflow.org](https://js.tensorflow.org) +- [Tutorials](https://js.tensorflow.org/tutorials) +- [API reference](https://js.tensorflow.org/api/latest/) +- [Help mailing list](https://groups.google.com/a/tensorflow.org/forum/#!forum/tfjs) diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index.d.ts b/node_modules/@tensorflow/tfjs/dist-es6/index.d.ts new file mode 100644 index 0000000..1f8417d --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index.d.ts @@ -0,0 +1,9 @@ +export * from '@tensorflow/tfjs-core'; +export * from '@tensorflow/tfjs-layers'; +export * from '@tensorflow/tfjs-converter'; +export declare const version: { + 'tfjs-core': string; + 'tfjs-layers': string; + 'tfjs-converter': string; + 'tfjs': string; +}; diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index.js b/node_modules/@tensorflow/tfjs/dist-es6/index.js new file mode 100644 index 0000000..fbd9337 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index.js @@ -0,0 +1,14 @@ +export * from '@tensorflow/tfjs-core'; +export * from '@tensorflow/tfjs-layers'; +export * from '@tensorflow/tfjs-converter'; +import { version_core } from '@tensorflow/tfjs-core'; +import { version_layers } from '@tensorflow/tfjs-layers'; +import { version_converter } from '@tensorflow/tfjs-converter'; +import { version as version_union } from './version'; +export var version = { + 'tfjs-core': version_core, + 'tfjs-layers': version_layers, + 'tfjs-converter': version_converter, + 'tfjs': version_union +}; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index.js.map b/node_modules/@tensorflow/tfjs/dist-es6/index.js.map new file mode 100644 index 0000000..807e82b --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAiBA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAG3C,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAC,cAAc,EAAC,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,OAAO,IAAI,aAAa,EAAC,MAAM,WAAW,CAAC;AAEnD,MAAM,CAAC,IAAM,OAAO,GAAG;IACrB,WAAW,EAAE,YAAY;IACzB,aAAa,EAAE,cAAc;IAC7B,gBAAgB,EAAE,iBAAiB;IACnC,MAAM,EAAE,aAAa;CACtB,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index_test.d.ts b/node_modules/@tensorflow/tfjs/dist-es6/index_test.d.ts new file mode 100644 index 0000000..cb0ff5c --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index_test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index_test.js b/node_modules/@tensorflow/tfjs/dist-es6/index_test.js new file mode 100644 index 0000000..5cff938 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index_test.js @@ -0,0 +1,25 @@ +import * as tf from './index'; +describe('Union package', function () { + it('has core ops', function () { + expect(tf.matMul).not.toBeNull(); + expect(tf.tensor).not.toBeNull(); + expect(tf.scalar).not.toBeNull(); + expect(tf.square).not.toBeNull(); + }); + it('has layers', function () { + expect(tf.sequential).not.toBeNull(); + expect(tf.model).not.toBeNull(); + expect(tf.layers.dense).not.toBeNull(); + }); + it('has converter', function () { + expect(tf.FrozenModel).not.toBeNull(); + expect(tf.loadFrozenModel).not.toBeNull(); + }); + it('version', function () { + var expected = require('../package.json').version; + expect(tf.version.tfjs).toBe(expected); + expect(tf.version['tfjs-core']).not.toBeNull(); + expect(tf.version['tfjs-layers']).not.toBeNull(); + }); +}); +//# sourceMappingURL=index_test.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist-es6/index_test.js.map b/node_modules/@tensorflow/tfjs/dist-es6/index_test.js.map new file mode 100644 index 0000000..ab6f051 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/index_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index_test.js","sourceRoot":"","sources":["../src/index_test.ts"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAE9B,QAAQ,CAAC,eAAe,EAAE;IACxB,EAAE,CAAC,cAAc,EAAE;QACjB,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,MAAM,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAChC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE;QAClB,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QAEZ,IAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;QACpD,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC/C,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist-es6/version.d.ts b/node_modules/@tensorflow/tfjs/dist-es6/version.d.ts new file mode 100644 index 0000000..47054b3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/version.d.ts @@ -0,0 +1,2 @@ +declare const version = "0.11.5"; +export { version }; diff --git a/node_modules/@tensorflow/tfjs/dist-es6/version.js b/node_modules/@tensorflow/tfjs/dist-es6/version.js new file mode 100644 index 0000000..380ab1b --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/version.js @@ -0,0 +1,3 @@ +var version = '0.11.5'; +export { version }; +//# sourceMappingURL=version.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist-es6/version.js.map b/node_modules/@tensorflow/tfjs/dist-es6/version.js.map new file mode 100644 index 0000000..cad7e50 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist-es6/version.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version.js","sourceRoot":"","sources":["../src/version.ts"],"names":[],"mappings":"AAGA,IAAM,OAAO,GAAG,QAAQ,CAAC;AACzB,OAAO,EAAC,OAAO,EAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/index.d.ts b/node_modules/@tensorflow/tfjs/dist/index.d.ts new file mode 100644 index 0000000..1f8417d --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/index.d.ts @@ -0,0 +1,9 @@ +export * from '@tensorflow/tfjs-core'; +export * from '@tensorflow/tfjs-layers'; +export * from '@tensorflow/tfjs-converter'; +export declare const version: { + 'tfjs-core': string; + 'tfjs-layers': string; + 'tfjs-converter': string; + 'tfjs': string; +}; diff --git a/node_modules/@tensorflow/tfjs/dist/index.js b/node_modules/@tensorflow/tfjs/dist/index.js new file mode 100644 index 0000000..f06a0c6 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/index.js @@ -0,0 +1,19 @@ +"use strict"; +function __export(m) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} +Object.defineProperty(exports, "__esModule", { value: true }); +__export(require("@tensorflow/tfjs-core")); +__export(require("@tensorflow/tfjs-layers")); +__export(require("@tensorflow/tfjs-converter")); +var tfjs_core_1 = require("@tensorflow/tfjs-core"); +var tfjs_layers_1 = require("@tensorflow/tfjs-layers"); +var tfjs_converter_1 = require("@tensorflow/tfjs-converter"); +var version_1 = require("./version"); +exports.version = { + 'tfjs-core': tfjs_core_1.version_core, + 'tfjs-layers': tfjs_layers_1.version_layers, + 'tfjs-converter': tfjs_converter_1.version_converter, + 'tfjs': version_1.version +}; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/index.js.map b/node_modules/@tensorflow/tfjs/dist/index.js.map new file mode 100644 index 0000000..5979797 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAiBA,2CAAsC;AACtC,6CAAwC;AACxC,gDAA2C;AAG3C,mDAAmD;AACnD,uDAAuD;AACvD,6DAA6D;AAC7D,qCAAmD;AAEtC,QAAA,OAAO,GAAG;IACrB,WAAW,EAAE,wBAAY;IACzB,aAAa,EAAE,4BAAc;IAC7B,gBAAgB,EAAE,kCAAiB;IACnC,MAAM,EAAE,iBAAa;CACtB,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/index_test.js.map b/node_modules/@tensorflow/tfjs/dist/index_test.js.map new file mode 100644 index 0000000..3aac72d --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/index_test.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index_test.js","sourceRoot":"","sources":["../src/index_test.ts"],"names":[],"mappings":";;AAiBA,4BAA8B;AAE9B,QAAQ,CAAC,eAAe,EAAE;IACxB,EAAE,CAAC,cAAc,EAAE;QACjB,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,YAAY,EAAE;QACf,MAAM,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAChC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE;QAClB,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,SAAS,EAAE;QAEZ,IAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;QACpD,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC/C,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/tf.esm.js b/node_modules/@tensorflow/tfjs/dist/tf.esm.js new file mode 100644 index 0000000..f8eb414 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.esm.js @@ -0,0 +1,3 @@ +// @tensorflow/tfjs Copyright 2018 Google +import{version_core}from"@tensorflow/tfjs-core";export*from"@tensorflow/tfjs-core";import{version_layers}from"@tensorflow/tfjs-layers";export*from"@tensorflow/tfjs-layers";import{version_converter}from"@tensorflow/tfjs-converter";export*from"@tensorflow/tfjs-converter";var version="0.12.4",version$1={"tfjs-core":version_core,"tfjs-layers":version_layers,"tfjs-converter":version_converter,tfjs:version};export{version$1 as version}; +//# sourceMappingURL=tf.esm.js.map diff --git a/node_modules/@tensorflow/tfjs/dist/tf.esm.js.map b/node_modules/@tensorflow/tfjs/dist/tf.esm.js.map new file mode 100644 index 0000000..d9ced59 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf.esm.js","sources":["../src/version.ts","../src/index.ts"],"sourcesContent":["/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.4';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport * from '@tensorflow/tfjs-core';\nexport * from '@tensorflow/tfjs-layers';\nexport * from '@tensorflow/tfjs-converter';\n\n// Import versions of all sub-packages.\nimport {version_core} from '@tensorflow/tfjs-core';\nimport {version_layers} from '@tensorflow/tfjs-layers';\nimport {version_converter} from '@tensorflow/tfjs-converter';\nimport {version as version_union} from './version';\n\nexport const version = {\n 'tfjs-core': version_core,\n 'tfjs-layers': version_layers,\n 'tfjs-converter': version_converter,\n 'tfjs': version_union\n};\n"],"names":["version","version_core","version_layers","version_converter","version_union"],"mappings":";8QAGA,IAAMA,QAAU,SCwBHA,uBACEC,2BACEC,gCACGC,uBACVC"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/tf.js b/node_modules/@tensorflow/tfjs/dist/tf.js new file mode 100644 index 0000000..432fd30 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.js @@ -0,0 +1,11468 @@ +// @tensorflow/tfjs Copyright 2018 Google +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (factory((global.tf = global.tf || {}))); +}(this, (function (exports) { 'use strict'; + + /** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ + var extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function (e, t) { + e.__proto__ = t; + } || function (e, t) { + for (var n in t) t.hasOwnProperty(n) && (e[n] = t[n]); + };function __extends(e, t) { + function n() { + this.constructor = e; + }extendStatics(e, t), e.prototype = null === t ? Object.create(t) : (n.prototype = t.prototype, new n()); + }var __assign = Object.assign || function (e) { + for (var t, n = 1, r = arguments.length; n < r; n++) for (var o in t = arguments[n]) Object.prototype.hasOwnProperty.call(t, o) && (e[o] = t[o]);return e; + };function __awaiter(e, t, n, r) { + return new (n || (n = Promise))(function (o, a) { + function i(e) { + try { + u(r.next(e)); + } catch (e) { + a(e); + } + }function s(e) { + try { + u(r.throw(e)); + } catch (e) { + a(e); + } + }function u(e) { + e.done ? o(e.value) : new n(function (t) { + t(e.value); + }).then(i, s); + }u((r = r.apply(e, t || [])).next()); + }); + }function __generator(e, t) { + var n, + r, + o, + a, + i = { label: 0, sent: function () { + if (1 & o[0]) throw o[1];return o[1]; + }, trys: [], ops: [] };return a = { next: s(0), throw: s(1), return: s(2) }, "function" == typeof Symbol && (a[Symbol.iterator] = function () { + return this; + }), a;function s(a) { + return function (s) { + return function (a) { + if (n) throw new TypeError("Generator is already executing.");for (; i;) try { + if (n = 1, r && (o = 2 & a[0] ? r.return : a[0] ? r.throw || ((o = r.return) && o.call(r), 0) : r.next) && !(o = o.call(r, a[1])).done) return o;switch (r = 0, o && (a = [2 & a[0], o.value]), a[0]) {case 0:case 1: + o = a;break;case 4: + return i.label++, { value: a[1], done: !1 };case 5: + i.label++, r = a[1], a = [0];continue;case 7: + a = i.ops.pop(), i.trys.pop();continue;default: + if (!(o = (o = i.trys).length > 0 && o[o.length - 1]) && (6 === a[0] || 2 === a[0])) { + i = 0;continue; + }if (3 === a[0] && (!o || a[1] > o[0] && a[1] < o[3])) { + i.label = a[1];break; + }if (6 === a[0] && i.label < o[1]) { + i.label = o[1], o = a;break; + }if (o && i.label < o[2]) { + i.label = o[2], i.ops.push(a);break; + }o[2] && i.ops.pop(), i.trys.pop();continue;}a = t.call(e, i); + } catch (e) { + a = [6, e], r = 0; + } finally { + n = o = 0; + }if (5 & a[0]) throw a[1];return { value: a[0] ? a[1] : void 0, done: !0 }; + }([a, s]); + }; + } + }function isMobile() { + var e = navigator.userAgent || navigator.vendor || window.opera;return (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(e) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(e.substr(0, 4)) + ); + }function shuffle(e) { + for (var t = e.length, n = 0, r = 0; t > 0;) r = Math.random() * t | 0, n = e[--t], e[t] = e[r], e[r] = n; + }function clamp(e, t, n) { + return Math.max(e, Math.min(t, n)); + }function randUniform(e, t) { + return Math.random() * (t - e) + e; + }function distSquared(e, t) { + for (var n = 0, r = 0; r < e.length; r++) { + var o = Number(e[r]) - Number(t[r]);n += o * o; + }return n; + }function assert(e, t) { + if (!e) throw new Error("string" == typeof t ? t : t()); + }function assertShapesMatch(e, t, n) { + void 0 === n && (n = ""), assert(arraysEqual(e, t), n + " Shapes " + e + " and " + t + " must match"); + }function assertNonNull(e) { + assert(null != e, "The input to the tensor constructor must be a non-null value."); + }function flatten(e, t) { + if (void 0 === t && (t = []), Array.isArray(e)) for (var n = 0; n < e.length; ++n) flatten(e[n], t);else t.push(e);return t; + }function inferShape(e) { + var t = e;if (isTypedArray(e)) return [e.length];if (!Array.isArray(e)) return [];for (var n = []; t instanceof Array;) n.push(t.length), t = t[0];return e instanceof Array && deepAssertShapeConsistency(e, n, []), n; + }function deepAssertShapeConsistency(e, t, n) { + if (n = n || [], e instanceof Array) { + assert(t.length > 0, function () { + return "Element arr[" + n.join("][") + "] should be a primitive, but is an array of " + e.length + " elements"; + }), assert(e.length === t[0], function () { + return "Element arr[" + n.join("][") + "] should have " + t[0] + " elements, but has " + e.length + " elements"; + });for (var r = t.slice(1), o = 0; o < e.length; ++o) deepAssertShapeConsistency(e[o], r, n.concat(o)); + } else assert(0 === t.length, function () { + return "Element arr[" + n.join("][") + "] is a primitive, but should be an array of " + t[0] + " elements"; + }); + }function sizeFromShape(e) { + if (0 === e.length) return 1;for (var t = e[0], n = 1; n < e.length; n++) t *= e[n];return t; + }function isScalarShape(e) { + return 0 === e.length; + }function arraysEqual(e, t) { + if (e.length !== t.length) return !1;for (var n = 0; n < e.length; n++) if (e[n] !== t[n]) return !1;return !0; + }function isInt(e) { + return e % 1 == 0; + }function tanh(e) { + if (null != Math.tanh) return Math.tanh(e);if (e === 1 / 0) return 1;if (e === -1 / 0) return -1;var t = Math.exp(2 * e);return (t - 1) / (t + 1); + }function sizeToSquarishShape(e) { + for (var t = Math.floor(Math.sqrt(e)); t > 1; --t) if (e % t == 0) return [t, e / t];return [1, e]; + }function createShuffledIndices(e) { + for (var t = new Uint32Array(e), n = 0; n < e; ++n) t[n] = n;return shuffle(t), t; + }function rightPad(e, t) { + return t <= e.length ? e : e + " ".repeat(t - e.length); + }function repeatedTry(e, t, n) { + return void 0 === t && (t = function (e) { + return 0; + }), new Promise(function (r, o) { + var a = 0, + i = function () { + if (e()) r();else { + var s = t(++a);null != n && a >= n ? o() : setTimeout(i, s); + } + };i(); + }); + }function inferFromImplicitShape(e, t) { + for (var n = 1, r = -1, o = 0; o < e.length; ++o) if (e[o] > 0) n *= e[o];else if (-1 === e[o]) { + if (-1 !== r) throw Error("Shapes can only have 1 implicit size. Found - 1 at dim " + r + " and dim " + o);r = o; + } else if (e[o] <= 0) throw Error("Shapes can not be <= 0. Found " + e[o] + " at dim " + o);if (-1 === r) { + if (t > 0 && t !== n) throw Error("Size(" + t + ") must match the product of shape " + e);return e; + }if (t % n != 0) throw Error("The implicit shape can't be a fractional number. Got " + t + " / " + n);var a = e.slice();return a[r] = t / n, a; + }function squeezeShape(e, t) { + for (var n = [], r = [], o = 0, a = 0; a < e.length; ++a) { + if (null != t) { + if (t[o] === a && e[a] > 1) throw new Error("Can't squeeze axis " + a + " since its dim '" + e[a] + "' is not 1");(null == t[o] || t[o] > a) && 1 === e[a] && (n.push(e[a]), r.push(a)), t[o] <= a && o++; + }e[a] > 1 && (n.push(e[a]), r.push(a)); + }return { newShape: n, keptDims: r }; + }function getTypedArrayFromDType(e, t) { + var n = null;if (null == e || "float32" === e) n = new Float32Array(t);else if ("int32" === e) n = new Int32Array(t);else { + if ("bool" !== e) throw new Error("Unknown data type " + e);n = new Uint8Array(t); + }return n; + }function checkComputationForNaN(e, t, n) { + if ("float32" === t) for (var r = 0; r < e.length; r++) if (isNaN(e[r])) throw Error("The result of the '" + n + "' has NaNs."); + }function checkConversionForNaN(e, t) { + if ("float32" !== t) for (var n = 0; n < e.length; n++) if (isNaN(e[n])) throw Error("NaN is not a valid value for dtype: '" + t + "'."); + }function hasEncodingLoss(e, t) { + return "float32" !== t && ("int32" !== t || "float32" === e) && ("bool" !== t || "bool" !== e); + }function copyTypedArray(e, t, n) { + if (null == t || "float32" === t) return new Float32Array(e);if ("int32" === t) return n && checkConversionForNaN(e, t), new Int32Array(e);if ("bool" === t) { + for (var r = new Uint8Array(e.length), o = 0; o < r.length; ++o) 0 !== Math.round(e[o]) && (r[o] = 1);return r; + }throw new Error("Unknown data type " + t); + }function isTypedArray(e) { + return e instanceof Float32Array || e instanceof Int32Array || e instanceof Uint8Array; + }function bytesPerElement(e) { + if ("float32" === e || "int32" === e) return 4;if ("bool" === e) return 1;throw new Error("Unknown dtype " + e); + }function isFunction(e) { + return !!(e && e.constructor && e.call && e.apply); + }function nearestDivisor(e, t) { + for (var n = t; n < e; ++n) if (e % n == 0) return n;return e; + }function computeStrides(e) { + var t = e.length;if (t < 2) return [];var n = new Array(t - 1);n[t - 2] = e[t - 1];for (var r = t - 3; r >= 0; --r) n[r] = n[r + 1] * e[r + 1];return n; + }function toTypedArray(e, t, n) { + return noConversionNeeded(e, t) ? e : (Array.isArray(e) && (e = flatten(e)), copyTypedArray(e, t, n)); + }function noConversionNeeded(e, t) { + return e instanceof Float32Array && "float32" === t || e instanceof Int32Array && "int32" === t || e instanceof Uint8Array && "bool" === t; + }function makeOnesTypedArray(e, t) { + for (var n = makeZerosTypedArray(e, t), r = 0; r < n.length; r++) n[r] = 1;return n; + }function makeZerosTypedArray(e, t) { + if (null == t || "float32" === t) return new Float32Array(e);if ("int32" === t) return new Int32Array(e);if ("bool" === t) return new Uint8Array(e);throw new Error("Unknown data type " + t); + }function now() { + if ("undefined" != typeof performance) return performance.now();if ("undefined" != typeof process) { + var e = process.hrtime();return 1e3 * e[0] + e[1] / 1e6; + }throw new Error("Can not measure time in this environment. You should run tf.js in the browser or in Node.js"); + }var util = Object.freeze({ shuffle: shuffle, clamp: clamp, randUniform: randUniform, distSquared: distSquared, assert: assert, assertShapesMatch: assertShapesMatch, assertNonNull: assertNonNull, flatten: flatten, inferShape: inferShape, sizeFromShape: sizeFromShape, isScalarShape: isScalarShape, arraysEqual: arraysEqual, isInt: isInt, tanh: tanh, sizeToSquarishShape: sizeToSquarishShape, createShuffledIndices: createShuffledIndices, rightPad: rightPad, repeatedTry: repeatedTry, inferFromImplicitShape: inferFromImplicitShape, squeezeShape: squeezeShape, getTypedArrayFromDType: getTypedArrayFromDType, checkComputationForNaN: checkComputationForNaN, checkConversionForNaN: checkConversionForNaN, hasEncodingLoss: hasEncodingLoss, isTypedArray: isTypedArray, bytesPerElement: bytesPerElement, isFunction: isFunction, nearestDivisor: nearestDivisor, computeStrides: computeStrides, toTypedArray: toTypedArray, makeOnesTypedArray: makeOnesTypedArray, makeZerosTypedArray: makeZerosTypedArray, now: now }), + Profiler = function () { + function e(e, t) { + this.backendTimer = e, this.logger = t, null == t && (this.logger = new Logger()); + }return e.prototype.profileKernel = function (e, t) { + var n, + r = this, + o = this.backendTimer.time(function () { + n = t(); + });return (Array.isArray(n) ? n : [n]).forEach(function (t) { + var n = t.dataSync();checkComputationForNaN(n, t.dtype, e), o.then(function (o) { + r.logger.logKernelProfile(e, t, n, o.kernelMs); + }); + }), n; + }, e; + }(), + Logger = function () { + function e() {}return e.prototype.logKernelProfile = function (e, t, n, r) { + var o = rightPad(r + "ms", 9), + a = rightPad(e, 25), + i = t.rank, + s = t.size, + u = rightPad(t.shape.toString(), 14);console.log("%c" + a + "\t%c" + o + "\t%c" + i + "D " + u + "\t%c" + s, "font-weight:bold", "color:red", "color:blue", "color: orange"); + }, e; + }();function getFilteredNodesXToY(e, t, n) { + for (var r = {}, o = {}, a = 0; a < t.length; a++) r[t[a].id] = !0;for (a = 0; a < e.length; a++) { + var i = (m = e[a]).inputs;for (var s in i) { + for (var u = i[s], l = !1, c = 0; c < t.length; c++) if (r[u.id]) { + r[m.output.id] = !0, l = !0, o[m.id] = !0;break; + }if (l) break; + } + }var p = {};p[n.id] = !0;var d = {};for (a = e.length - 1; a >= 0; a--) { + i = (m = e[a]).inputs;var h = [];h.push(m.output);for (c = 0; c < h.length; c++) if (p[h[c].id]) { + for (var s in i) p[i[s].id] = !0, d[m.id] = !0;break; + } + }var f = [];for (a = 0; a < e.length; a++) { + var m;if (o[(m = e[a]).id] && d[m.id]) { + var g = {};for (var s in m.inputs) { + var v = m.inputs[s];r[v.id] && (g[s] = v); + }var y = Object.assign({}, m);y.inputs = g, y.output = m.output, f.push(y); + } + }return f; + }function backpropagateGradients(e, t) { + for (var n = t.length - 1; n >= 0; n--) { + var r = t[n], + o = e[r.output.id];if (null == r.gradient) throw new Error("Cannot compute gradient: gradient function not found for " + r.name + ".");var a = r.gradient(o);for (var i in r.inputs) { + if (!(i in a)) throw new Error("Cannot backprop through input " + i + ". Available gradients found: " + Object.keys(a) + ".");var s = a[i](), + u = r.inputs[i];if (!arraysEqual(s.shape, u.shape)) throw new Error("Error in gradient for op " + r.name + ". The gradient of input '" + i + "' has shape '" + s.shape + "', which does not match the shape of the input '" + u.shape + "'");if (null == e[u.id]) e[u.id] = s;else { + var l = e[u.id];e[u.id] = l.add(s), l.dispose(); + } + } + } + }var FORMAT_LIMIT_NUM_VALS = 20, + FORMAT_NUM_FIRST_LAST_VALS = 3, + FORMAT_NUM_SIG_DIGITS = 7;function tensorToString(e, t, n, r) { + var o = computeStrides(t), + a = computeMaxSizePerColumn(e, t, o), + i = t.length, + s = subTensorToString(e, t, o, a), + u = ["Tensor"];return r && (u.push(" dtype: " + n), u.push(" rank: " + i), u.push(" shape: [" + t + "]"), u.push(" values:")), u.push(s.map(function (e) { + return " " + e; + }).join("\n")), u.join("\n"); + }function computeMaxSizePerColumn(e, t, n) { + var r = sizeFromShape(t), + o = n[n.length - 1], + a = new Array(o).fill(0);if (t.length > 1) for (var i = 0; i < r / o; i++) for (var s = i * o, u = 0; u < o; u++) a[u] = Math.max(a[u], valToString(e[s + u], 0).length);return a; + }function valToString(e, t) { + return rightPad(parseFloat(e.toFixed(FORMAT_NUM_SIG_DIGITS)).toString(), t); + }function subTensorToString(e, t, n, r, o) { + void 0 === o && (o = !0);var a = t[0], + i = t.length;if (0 === i) return [e[0].toString()];if (1 === i) { + if (a > FORMAT_LIMIT_NUM_VALS) { + var s = Array.from(e.subarray(0, FORMAT_NUM_FIRST_LAST_VALS)), + u = Array.from(e.subarray(a - FORMAT_NUM_FIRST_LAST_VALS, a));return ["[" + s.map(function (e, t) { + return valToString(e, r[t]); + }).join(", ") + ", ..., " + u.map(function (e, t) { + return valToString(e, r[a - FORMAT_NUM_FIRST_LAST_VALS + t]); + }).join(", ") + "]"]; + }return ["[" + Array.from(e).map(function (e, t) { + return valToString(e, r[t]); + }).join(", ") + "]"]; + }var l = t.slice(1), + c = n.slice(1), + p = n[0], + d = [];if (a > FORMAT_LIMIT_NUM_VALS) { + for (var h = 0; h < FORMAT_NUM_FIRST_LAST_VALS; h++) { + var f = (m = h * p) + p;d.push.apply(d, subTensorToString(e.subarray(m, f), l, c, r, !1)); + }d.push("...");for (h = a - FORMAT_NUM_FIRST_LAST_VALS; h < a; h++) { + f = (m = h * p) + p;d.push.apply(d, subTensorToString(e.subarray(m, f), l, c, r, h === a - 1)); + } + } else for (h = 0; h < a; h++) { + var m;f = (m = h * p) + p;d.push.apply(d, subTensorToString(e.subarray(m, f), l, c, r, h === a - 1)); + }var g = 2 === i ? "," : "";d[0] = "[" + d[0] + g;for (h = 1; h < d.length - 1; h++) d[h] = " " + d[h] + g;var v = ",\n";for (h = 2; h < i; h++) v += "\n";return d[d.length - 1] = " " + d[d.length - 1] + "]" + (o ? "" : v), d; + }var TensorBuffer = function () { + function e(e, t, n) { + if (this.dtype = t, null != n) { + var r = n.length, + o = sizeFromShape(e);assert(r === o, "Length of values '" + r + "' does not match the size inferred by the shape '" + o + "'"); + }this.shape = e.slice(), this.values = n || getTypedArrayFromDType(t, sizeFromShape(e)), this.strides = computeStrides(e), this.size = sizeFromShape(e); + }return e.prototype.set = function (e) { + for (var t = [], n = 1; n < arguments.length; n++) t[n - 1] = arguments[n];0 === t.length && (t = [0]), assert(t.length === this.rank, "The number of provided coordinates (" + t.length + ") must match the rank (" + this.rank + ")");var r = this.locToIndex(t);this.values[r] = e; + }, e.prototype.get = function () { + for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];0 === e.length && (e = [0]);for (var n = e[e.length - 1], r = 0; r < e.length - 1; ++r) n += this.strides[r] * e[r];return this.values[n]; + }, e.prototype.locToIndex = function (e) { + if (0 === this.rank) return 0;if (1 === this.rank) return e[0];for (var t = e[e.length - 1], n = 0; n < e.length - 1; ++n) t += this.strides[n] * e[n];return t; + }, e.prototype.indexToLoc = function (e) { + if (0 === this.rank) return [];if (1 === this.rank) return [e];for (var t = new Array(this.shape.length), n = 0; n < t.length - 1; ++n) t[n] = Math.floor(e / this.strides[n]), e -= t[n] * this.strides[n];return t[t.length - 1] = e, t; + }, Object.defineProperty(e.prototype, "rank", { get: function () { + return this.shape.length; + }, enumerable: !0, configurable: !0 }), e.prototype.toTensor = function () { + return Tensor.make(this.shape, { values: this.values }, this.dtype); + }, e; + }(), + trackerFn = null, + opHandler = null;function setTensorTracker(e) { + trackerFn = e; + }function setOpHandler(e) { + opHandler = e; + }var Tensor = function () { + function e(t, n, r, o) { + this.isDisposedInternal = !1, this.size = sizeFromShape(t), null != r && assert(this.size === r.length, "Constructing tensor of shape (" + this.size + ") should match the length of values (" + r.length + ")"), this.shape = t.slice(), this.dtype = n || "float32", this.strides = computeStrides(t), this.dataId = null != o ? o : {}, this.id = e.nextId++, this.rankType = this.rank < 5 ? this.rank.toString() : "higher", trackerFn().registerTensor(this), null != r && trackerFn().write(this.dataId, r); + }return e.make = function (t, n, r) { + return new e(t, r, n.values, n.dataId); + }, e.prototype.flatten = function () { + return this.throwIfDisposed(), this.as1D(); + }, e.prototype.asScalar = function () { + return this.throwIfDisposed(), assert(1 === this.size, "The array must have only 1 element."), this.reshape([]); + }, e.prototype.as1D = function () { + return this.throwIfDisposed(), this.reshape([this.size]); + }, e.prototype.as2D = function (e, t) { + return this.throwIfDisposed(), this.reshape([e, t]); + }, e.prototype.as3D = function (e, t, n) { + return this.throwIfDisposed(), this.reshape([e, t, n]); + }, e.prototype.as4D = function (e, t, n, r) { + return this.throwIfDisposed(), this.reshape([e, t, n, r]); + }, e.prototype.asType = function (e) { + return this.throwIfDisposed(), opHandler.cast(this, e); + }, Object.defineProperty(e.prototype, "rank", { get: function () { + return this.shape.length; + }, enumerable: !0, configurable: !0 }), e.prototype.get = function () { + for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];assert(e.length === this.rank, "Number of coordinates in get() must match the rank of the tensor"), this.throwIfDisposed(), 0 === e.length && (e = [0]);for (var n = e[e.length - 1], r = 0; r < e.length - 1; ++r) n += this.strides[r] * e[r];return this.dataSync()[n]; + }, e.prototype.buffer = function () { + return opHandler.buffer(this.shape, this.dtype, this.dataSync()); + }, e.prototype.data = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (e) { + return this.throwIfDisposed(), [2, trackerFn().read(this.dataId)]; + }); + }); + }, e.prototype.dataSync = function () { + return this.throwIfDisposed(), trackerFn().readSync(this.dataId); + }, e.prototype.dispose = function () { + this.isDisposed || (trackerFn().disposeTensor(this), this.isDisposedInternal = !0); + }, Object.defineProperty(e.prototype, "isDisposed", { get: function () { + return this.isDisposedInternal; + }, enumerable: !0, configurable: !0 }), e.prototype.throwIfDisposed = function () { + if (this.isDisposed) throw new Error("Tensor is disposed."); + }, e.prototype.toFloat = function () { + return this.asType("float32"); + }, e.prototype.toInt = function () { + return this.asType("int32"); + }, e.prototype.toBool = function () { + return this.asType("bool"); + }, e.prototype.print = function (e) { + return void 0 === e && (e = !1), opHandler.print(this, e); + }, e.prototype.reshape = function (e) { + return this.throwIfDisposed(), opHandler.reshape(this, e); + }, e.prototype.reshapeAs = function (e) { + return this.throwIfDisposed(), this.reshape(e.shape); + }, e.prototype.expandDims = function (e) { + return void 0 === e && (e = 0), opHandler.expandDims(this, e); + }, e.prototype.cumsum = function (e, t, n) { + return void 0 === e && (e = 0), void 0 === t && (t = !1), void 0 === n && (n = !1), opHandler.cumsum(this, e, t, n); + }, e.prototype.squeeze = function (e) { + return this.throwIfDisposed(), opHandler.squeeze(this, e); + }, e.prototype.clone = function () { + return this.throwIfDisposed(), opHandler.clone(this); + }, e.prototype.toString = function (e) { + return void 0 === e && (e = !1), tensorToString(this.dataSync(), this.shape, this.dtype, e); + }, e.prototype.tile = function (e) { + return this.throwIfDisposed(), opHandler.tile(this, e); + }, e.prototype.gather = function (e, t) { + return void 0 === t && (t = 0), this.throwIfDisposed(), opHandler.gather(this, e, t); + }, e.prototype.matMul = function (e, t, n) { + return void 0 === t && (t = !1), void 0 === n && (n = !1), this.throwIfDisposed(), opHandler.matMul(this, e, t, n); + }, e.prototype.dot = function (e) { + return this.throwIfDisposed(), opHandler.dot(this, e); + }, e.prototype.norm = function (e, t, n) { + return void 0 === e && (e = "euclidean"), void 0 === t && (t = null), void 0 === n && (n = !1), this.throwIfDisposed(), opHandler.norm(this, e, t, n); + }, e.prototype.slice = function (e, t) { + return this.throwIfDisposed(), opHandler.slice(this, e, t); + }, e.prototype.reverse = function (e) { + return this.throwIfDisposed(), opHandler.reverse(this, e); + }, e.prototype.concat = function (e, t) { + return void 0 === t && (t = 0), this.throwIfDisposed(), opHandler.concat([this, e], t); + }, e.prototype.stack = function (e, t) { + return void 0 === t && (t = 0), opHandler.stack([this, e], t); + }, e.prototype.unstack = function (e, t) { + return void 0 === t && (t = 0), opHandler.unstack(this, t); + }, e.prototype.pad = function (e, t) { + return void 0 === t && (t = 0), opHandler.pad(this, e, t); + }, e.prototype.batchNormalization = function (e, t, n, r, o) { + return void 0 === n && (n = .001), this.throwIfDisposed(), opHandler.batchNormalization(this, e, t, n, r, o); + }, e.prototype.all = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.all(this, e, t); + }, e.prototype.any = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.any(this, e, t); + }, e.prototype.logSumExp = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.logSumExp(this, e, t); + }, e.prototype.sum = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.sum(this, e, t); + }, e.prototype.mean = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.mean(this, e, t); + }, e.prototype.min = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.min(this, e, t); + }, e.prototype.max = function (e, t) { + return void 0 === e && (e = null), void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.max(this, e, t); + }, e.prototype.argMin = function (e) { + return void 0 === e && (e = null), this.throwIfDisposed(), opHandler.argMin(this, e); + }, e.prototype.argMax = function (e) { + return void 0 === e && (e = null), this.throwIfDisposed(), opHandler.argMax(this, e); + }, e.prototype.cast = function (e) { + return this.throwIfDisposed(), opHandler.cast(this, e); + }, e.prototype.add = function (e) { + return this.throwIfDisposed(), opHandler.add(this, e); + }, e.prototype.addStrict = function (e) { + return this.throwIfDisposed(), opHandler.addStrict(this, e); + }, e.prototype.sub = function (e) { + return this.throwIfDisposed(), opHandler.sub(this, e); + }, e.prototype.subStrict = function (e) { + return this.throwIfDisposed(), opHandler.subStrict(this, e); + }, e.prototype.pow = function (e) { + return this.throwIfDisposed(), opHandler.pow(this, e); + }, e.prototype.powStrict = function (e) { + return this.throwIfDisposed(), opHandler.powStrict(this, e); + }, e.prototype.mul = function (e) { + return this.throwIfDisposed(), opHandler.mul(this, e); + }, e.prototype.mulStrict = function (e) { + return this.throwIfDisposed(), opHandler.mulStrict(this, e); + }, e.prototype.div = function (e) { + return this.throwIfDisposed(), opHandler.div(this, e); + }, e.prototype.floorDiv = function (e) { + return this.throwIfDisposed(), opHandler.floorDiv(this, e); + }, e.prototype.divStrict = function (e) { + return this.throwIfDisposed(), opHandler.divStrict(this, e); + }, e.prototype.minimum = function (e) { + return this.throwIfDisposed(), opHandler.minimum(this, e); + }, e.prototype.minimumStrict = function (e) { + return this.throwIfDisposed(), opHandler.minimumStrict(this, e); + }, e.prototype.maximum = function (e) { + return this.throwIfDisposed(), opHandler.maximum(this, e); + }, e.prototype.maximumStrict = function (e) { + return this.throwIfDisposed(), opHandler.maximumStrict(this, e); + }, e.prototype.mod = function (e) { + return this.throwIfDisposed(), opHandler.mod(this, e); + }, e.prototype.modStrict = function (e) { + return this.throwIfDisposed(), opHandler.modStrict(this, e); + }, e.prototype.squaredDifference = function (e) { + return this.throwIfDisposed(), opHandler.squaredDifference(this, e); + }, e.prototype.squaredDifferenceStrict = function (e) { + return this.throwIfDisposed(), opHandler.squaredDifferenceStrict(this, e); + }, e.prototype.transpose = function (e) { + return this.throwIfDisposed(), opHandler.transpose(this, e); + }, e.prototype.notEqual = function (e) { + return this.throwIfDisposed(), opHandler.notEqual(this, e); + }, e.prototype.notEqualStrict = function (e) { + return this.throwIfDisposed(), opHandler.notEqualStrict(this, e); + }, e.prototype.less = function (e) { + return this.throwIfDisposed(), opHandler.less(this, e); + }, e.prototype.lessStrict = function (e) { + return this.throwIfDisposed(), opHandler.lessStrict(this, e); + }, e.prototype.equal = function (e) { + return this.throwIfDisposed(), opHandler.equal(this, e); + }, e.prototype.equalStrict = function (e) { + return this.throwIfDisposed(), opHandler.equalStrict(this, e); + }, e.prototype.lessEqual = function (e) { + return this.throwIfDisposed(), opHandler.lessEqual(this, e); + }, e.prototype.lessEqualStrict = function (e) { + return this.throwIfDisposed(), opHandler.lessEqualStrict(this, e); + }, e.prototype.greater = function (e) { + return this.throwIfDisposed(), opHandler.greater(this, e); + }, e.prototype.greaterStrict = function (e) { + return this.throwIfDisposed(), opHandler.greaterStrict(this, e); + }, e.prototype.greaterEqual = function (e) { + return this.throwIfDisposed(), opHandler.greaterEqual(this, e); + }, e.prototype.greaterEqualStrict = function (e) { + return this.throwIfDisposed(), opHandler.greaterEqualStrict(this, e); + }, e.prototype.logicalAnd = function (e) { + return this.throwIfDisposed(), opHandler.logicalAnd(this, e); + }, e.prototype.logicalOr = function (e) { + return this.throwIfDisposed(), opHandler.logicalOr(this, e); + }, e.prototype.logicalNot = function () { + return this.throwIfDisposed(), opHandler.logicalNot(this); + }, e.prototype.logicalXor = function (e) { + return this.throwIfDisposed(), opHandler.logicalXor(this, e); + }, e.prototype.where = function (e, t) { + return this.throwIfDisposed(), opHandler.where(e, this, t); + }, e.prototype.neg = function () { + return this.throwIfDisposed(), opHandler.neg(this); + }, e.prototype.ceil = function () { + return this.throwIfDisposed(), opHandler.ceil(this); + }, e.prototype.floor = function () { + return this.throwIfDisposed(), opHandler.floor(this); + }, e.prototype.sign = function () { + return this.throwIfDisposed(), opHandler.sign(this); + }, e.prototype.exp = function () { + return this.throwIfDisposed(), opHandler.exp(this); + }, e.prototype.expm1 = function () { + return this.throwIfDisposed(), opHandler.expm1(this); + }, e.prototype.log = function () { + return this.throwIfDisposed(), opHandler.log(this); + }, e.prototype.log1p = function () { + return this.throwIfDisposed(), opHandler.log1p(this); + }, e.prototype.sqrt = function () { + return this.throwIfDisposed(), opHandler.sqrt(this); + }, e.prototype.rsqrt = function () { + return this.throwIfDisposed(), opHandler.rsqrt(this); + }, e.prototype.square = function () { + return this.throwIfDisposed(), opHandler.square(this); + }, e.prototype.reciprocal = function () { + return this.throwIfDisposed(), opHandler.reciprocal(this); + }, e.prototype.abs = function () { + return this.throwIfDisposed(), opHandler.abs(this); + }, e.prototype.clipByValue = function (e, t) { + return this.throwIfDisposed(), opHandler.clipByValue(this, e, t); + }, e.prototype.relu = function () { + return this.throwIfDisposed(), opHandler.relu(this); + }, e.prototype.elu = function () { + return this.throwIfDisposed(), opHandler.elu(this); + }, e.prototype.selu = function () { + return this.throwIfDisposed(), opHandler.selu(this); + }, e.prototype.leakyRelu = function (e) { + return void 0 === e && (e = .2), this.throwIfDisposed(), opHandler.leakyRelu(this, e); + }, e.prototype.prelu = function (e) { + return this.throwIfDisposed(), opHandler.prelu(this, e); + }, e.prototype.sigmoid = function () { + return this.throwIfDisposed(), opHandler.sigmoid(this); + }, e.prototype.logSigmoid = function () { + return this.throwIfDisposed(), opHandler.logSigmoid(this); + }, e.prototype.softplus = function () { + return this.throwIfDisposed(), opHandler.softplus(this); + }, e.prototype.sin = function () { + return this.throwIfDisposed(), opHandler.sin(this); + }, e.prototype.cos = function () { + return this.throwIfDisposed(), opHandler.cos(this); + }, e.prototype.tan = function () { + return this.throwIfDisposed(), opHandler.tan(this); + }, e.prototype.asin = function () { + return this.throwIfDisposed(), opHandler.asin(this); + }, e.prototype.acos = function () { + return this.throwIfDisposed(), opHandler.acos(this); + }, e.prototype.atan = function () { + return this.throwIfDisposed(), opHandler.atan(this); + }, e.prototype.sinh = function () { + return this.throwIfDisposed(), opHandler.sinh(this); + }, e.prototype.cosh = function () { + return this.throwIfDisposed(), opHandler.cosh(this); + }, e.prototype.tanh = function () { + return this.throwIfDisposed(), opHandler.tanh(this); + }, e.prototype.asinh = function () { + return this.throwIfDisposed(), opHandler.asinh(this); + }, e.prototype.acosh = function () { + return this.throwIfDisposed(), opHandler.acosh(this); + }, e.prototype.atanh = function () { + return this.throwIfDisposed(), opHandler.atanh(this); + }, e.prototype.erf = function () { + return this.throwIfDisposed(), opHandler.erf(this); + }, e.prototype.round = function () { + return this.throwIfDisposed(), opHandler.round(this); + }, e.prototype.step = function (e) { + return void 0 === e && (e = 0), this.throwIfDisposed(), opHandler.step(this, e); + }, e.prototype.softmax = function (e) { + return void 0 === e && (e = -1), this.throwIfDisposed(), opHandler.softmax(this, e); + }, e.prototype.resizeBilinear = function (e, t) { + return void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.image.resizeBilinear(this, e, t); + }, e.prototype.resizeNearestNeighbor = function (e, t) { + return void 0 === t && (t = !1), this.throwIfDisposed(), opHandler.image.resizeNearestNeighbor(this, e, t); + }, e.prototype.conv1d = function (e, t, n, r, o, a) { + return void 0 === r && (r = "NWC"), void 0 === o && (o = 1), this.throwIfDisposed(), opHandler.conv1d(this, e, t, n, r, o, a); + }, e.prototype.conv2d = function (e, t, n, r, o, a) { + return void 0 === r && (r = "NHWC"), void 0 === o && (o = [1, 1]), this.throwIfDisposed(), opHandler.conv2d(this, e, t, n, r, o, a); + }, e.prototype.conv2dTranspose = function (e, t, n, r, o) { + return this.throwIfDisposed(), opHandler.conv2dTranspose(this, e, t, n, r, o); + }, e.prototype.depthwiseConv2D = function (e, t, n, r, o, a) { + return void 0 === r && (r = "NHWC"), void 0 === o && (o = [1, 1]), this.throwIfDisposed(), opHandler.depthwiseConv2d(this, e, t, n, r, o, a); + }, e.prototype.avgPool = function (e, t, n, r) { + return this.throwIfDisposed(), opHandler.avgPool(this, e, t, n, r); + }, e.prototype.maxPool = function (e, t, n, r) { + return this.throwIfDisposed(), opHandler.maxPool(this, e, t, n, r); + }, e.prototype.localResponseNormalization = function (e, t, n, r) { + return void 0 === e && (e = 5), void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = .5), opHandler.localResponseNormalization(this, e, t, n, r); + }, e.prototype.variable = function (e, t, n) { + return void 0 === e && (e = !0), this.throwIfDisposed(), Variable.variable(this, e, t, n); + }, e.prototype.unsortedSegmentSum = function (e, t) { + return this.throwIfDisposed(), opHandler.unsortedSegmentSum(this, e, t); + }, e.prototype.batchToSpaceND = function (e, t) { + return this.throwIfDisposed(), opHandler.batchToSpaceND(this, e, t); + }, e.prototype.spaceToBatchND = function (e, t) { + return this.throwIfDisposed(), opHandler.spaceToBatchND(this, e, t); + }, e.nextId = 0, e; + }();Object.defineProperty(Tensor, Symbol.hasInstance, { value: function (e) { + return !!e && null != e.shape && null != e.dtype; + } });var Variable = function (e) { + function t(n, r, o) { + void 0 === r && (r = !0);var a = e.call(this, n.shape, n.dtype, null, n.dataId) || this;a.trainable = r, a.name = o, null == a.name && (a.name = t.nextVarId.toString(), t.nextVarId++);try { + trackerFn().registerVariable(a); + } catch (e) { + throw trackerFn().disposeTensor(a), e; + }return a; + }return __extends(t, e), t.variable = function (e, n, r, o) { + return void 0 === n && (n = !0), null != o && o !== e.dtype && (e = e.asType(o)), new t(e, n, r); + }, t.prototype.assign = function (e) { + if (e.dtype !== this.dtype) throw new Error("dtype of the new value (" + e.dtype + ") and previous value (" + this.dtype + ") must match");if (!arraysEqual(e.shape, this.shape)) throw new Error("shape of the new value (" + e.shape + ") and previous value (" + this.shape + ") must match");trackerFn().disposeTensor(this), this.dataId = e.dataId, trackerFn().registerTensor(this); + }, t.nextVarId = 0, t; + }(Tensor);Object.defineProperty(Variable, Symbol.hasInstance, { value: function (e) { + return e instanceof Tensor && null != e.assign && e.assign instanceof Function; + } });var variable = Variable.variable;function assertTypesMatch(e, t) { + assert(e.dtype === t.dtype, " The dtypes of the first(" + e.dtype + ") and second(" + t.dtype + ") input must match"); + }function isTensorInList(e, t) { + for (var n = 0; n < t.length; n++) if (t[n].id === e.id) return !0;return !1; + }function getTensorsInContainer(e) { + var t = [];return walkTensorContainer(e, t, new Set()), t; + }function walkTensorContainer(e, t, n) { + if (null != e) if (e instanceof Tensor) t.push(e);else if (isIterable(e)) { + var r = e;for (var o in r) { + var a = r[o];n.has(a) || (n.add(a), walkTensorContainer(a, t, n)); + } + } + }function isIterable(e) { + return Array.isArray(e) || "object" == typeof e; + }var Type, + Engine = function () { + function e(e, t, n) { + this.backend = e, this.safeMode = t, this.debugMode = n, this.registeredVariables = {}, this.refCounter = new WeakMap(), this.nextTapeNodeId = 0, this.numBytes = 0, this.numTensors = 0, this.numDataBuffers = 0, this.gradientScopeCount = 0, this.customGradientDepth = 0, this.keepTensors = new Set(), this.activeScope = { track: [], name: "default scope" }, this.scopeStack = [this.activeScope], this.profiler = new Profiler(e); + }return e.prototype.tidy = function (e, t, n) { + var r = this;void 0 === n && (n = !1);var o, + a = null;if (null == t) { + if ("function" != typeof e) throw new Error("Please provide a function to tidy()");t = e; + } else { + if ("string" != typeof e && !(e instanceof String)) throw new Error("When calling with two arguments, the first argument to tidy() must be a string");if ("function" != typeof t) throw new Error("When calling with two arguments, the 2nd argument to tidy() must be a function");a = e; + }return this.scopedRun(function () { + return r.startScope(a, n); + }, function () { + return r.endScope(o, n); + }, function () { + return (o = t()) instanceof Promise && console.error("Cannot return a Promise inside of tidy."), o; + }); + }, e.prototype.scopedRun = function (e, t, n) { + e();try { + var r = n();return t(), r; + } catch (e) { + throw t(), e; + } + }, e.prototype.runKernel = function (e, t, n) { + var r, + o = this, + a = [], + i = function (e) { + return a.push(e), e; + }, + s = this.activeScope.name;if (this.scopedRun(function () { + return o.customGradientDepth++; + }, function () { + return o.customGradientDepth--; + }, function () { + r = o.debugMode() ? o.profiler.profileKernel(s, function () { + return e(o.backend, i); + }) : e(o.backend, i); + }), this.shouldRecord()) { + var u = { id: this.nextTapeNodeId++, name: s, inputs: t, output: Array.isArray(r) ? r[0] : r };null != n && (u.gradient = function (e) { + return n(e, a); + }), this.activeTape.push(u); + }return r; + }, e.prototype.registerTensor = function (e) { + var t = this.refCounter.has(e.dataId) ? this.refCounter.get(e.dataId) : 0;this.numTensors++, 0 === t && (this.numDataBuffers++, this.numBytes += sizeFromShape(e.shape) * bytesPerElement(e.dtype), this.backend.register(e.dataId, e.shape, e.dtype)), this.refCounter.set(e.dataId, t + 1), e instanceof Variable || this.track(e); + }, e.prototype.registerVariable = function (e) { + if (null != this.registeredVariables[e.name]) throw new Error("Variable with name " + e.name + " was already registered");this.registeredVariables[e.name] = e; + }, e.prototype.disposeTensor = function (e) { + if (this.refCounter.has(e.dataId)) { + this.keepTensors.has(e.id) && this.keepTensors.delete(e.id), this.numTensors--;var t = this.refCounter.get(e.dataId);t <= 1 ? (this.refCounter.delete(e.dataId), this.backend.disposeData(e.dataId), this.numDataBuffers--, this.numBytes -= sizeFromShape(e.shape) * bytesPerElement(e.dtype)) : this.refCounter.set(e.dataId, t - 1); + } + }, e.prototype.disposeVariables = function () { + for (var e in this.registeredVariables) { + var t = this.registeredVariables[e];this.disposeTensor(t), delete this.registeredVariables[e]; + } + }, e.prototype.memory = function () { + var e = this.backend.memory();return e.numTensors = this.numTensors, e.numDataBuffers = this.numDataBuffers, e.numBytes = this.numBytes, e; + }, e.prototype.shouldRecord = function () { + return null != this.activeTape && 0 === this.customGradientDepth; + }, e.prototype.addTapeNode = function (e, t, n) { + var r = {};e.forEach(function (e, t) { + r[t] = e; + });var o = { id: this.nextTapeNodeId++, name: this.activeScope.name, inputs: r, output: t, gradient: function (e) { + var t = {};return n(e).forEach(function (e, n) { + t[n] = function () { + return e; + }; + }), t; + } };this.activeTape.push(o); + }, e.prototype.keep = function (e) { + if (1 === this.scopeStack.length && this.safeMode) throw new Error("Safe mode is ON. Enclose all tensor operations inside tf.tidy(): tf.tidy(() => {...}) to avoid memory leaks.");return this.keepTensors.add(e.id), e; + }, e.prototype.startScope = function (e, t) { + void 0 === t && (t = !1), t && 0 === this.gradientScopeCount && (this.activeTape = []), t && this.gradientScopeCount++;var n = { track: [], name: "unnamed scope" };e && (n.name = e), this.scopeStack.push(n), this.activeScope = n; + }, e.prototype.endScope = function (e, t) { + var n = this;void 0 === t && (t = !1), t && (this.gradientScopeCount--, 0 === this.gradientScopeCount && (this.activeTape = null));var r = new Set(this.keepTensors), + o = getTensorsInContainer(e);o.forEach(function (e) { + return r.add(e.id); + });for (var a = 0; a < this.activeScope.track.length; a++) { + var i = this.activeScope.track[a];r.has(i.id) || (null != this.activeTape ? o.push(i) : i.dispose()); + }var s = this.scopeStack.pop();this.activeScope = 0 === this.scopeStack.length ? { track: [], name: "default scope" } : this.scopeStack[this.scopeStack.length - 1], o.forEach(function (e) { + !n.keepTensors.has(e.id) && isTensorInList(e, s.track) && n.track(e); + }); + }, e.prototype.gradients = function (e, t, n, r) { + var o = this;return void 0 === r && (r = !1), assert(t.length > 0, "gradients() received an empty list of xs."), this.tidy("gradients", function () { + var a = e();assert(a instanceof Tensor, "The result y returned by f() must be a tensor.");var i = getFilteredNodesXToY(o.activeTape, t, a);if (!r && 0 === i.length && t.length > 0) throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");var s = {};return s[a.id] = null == n ? ones(a.shape) : n, backpropagateGradients(s, i), { value: a, grads: t.map(function (e) { + return s[e.id]; + }) }; + }, !0); + }, e.prototype.customGrad = function (e) { + var t = this;return assert(isFunction(e), "The f passed in customGrad(f) must be a function."), function () { + for (var n, r, o = [], a = 0; a < arguments.length; a++) o[a] = arguments[a];if (assert(o.every(function (e) { + return e instanceof Tensor; + }), "The args passed in customGrad(f)(x1, x2,...) must all be tensors"), t.scopedRun(function () { + return t.customGradientDepth++; + }, function () { + return t.customGradientDepth--; + }, function () { + r = t.tidy(e.name, function () { + var t = e.apply(void 0, o), + r = t.value, + a = t.gradFunc;return assert(r instanceof Tensor, "The function f passed in customGrad(f) must return an object where `obj.value` is a tensor"), assert(isFunction(a), "The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function."), n = a, r; + }, !0); + }), t.shouldRecord()) { + t.addTapeNode(o, r, function (e) { + var t = n(e), + r = Array.isArray(t) ? t : [t];return assert(r.length === o.length, "The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns the same number of tensors as inputs passed to f(...)."), assert(r.every(function (e) { + return e instanceof Tensor; + }), "The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns a list of only tensors."), r; + }); + }return r; + }; + }, e.prototype.write = function (e, t) { + this.backend.write(e, t); + }, e.prototype.readSync = function (e) { + return this.backend.readSync(e); + }, e.prototype.read = function (e) { + return this.backend.read(e); + }, e.prototype.fromPixels = function (e, t) { + return this.backend.fromPixels(e, t); + }, e.prototype.time = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n;return __generator(this, function (r) { + switch (r.label) {case 0: + return t = now(), [4, this.backend.time(e)];case 1: + return (n = r.sent()).wallMs = now() - t, [2, n];} + }); + }); + }, e.prototype.track = function (e) { + if (1 === this.scopeStack.length && this.safeMode) throw new Error("Safe mode is ON. Enclose all tensor operations inside tf.tidy(): tf.tidy(() => {op();...}); to avoid memory leaks.");return this.activeScope.track.push(e), e; + }, e; + }();function ones(e) { + var t = makeOnesTypedArray(sizeFromShape(e), "float32");return Tensor.make(e, { values: t }); + }!function (e) { + e[e.NUMBER = 0] = "NUMBER", e[e.BOOLEAN = 1] = "BOOLEAN", e[e.STRING = 2] = "STRING"; + }(Type || (Type = {}));var URL_PROPERTIES = [{ name: "DEBUG", type: Type.BOOLEAN }, { name: "IS_BROWSER", type: Type.BOOLEAN }, { name: "WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION", type: Type.NUMBER }, { name: "WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE", type: Type.BOOLEAN }, { name: "WEBGL_VERSION", type: Type.NUMBER }, { name: "WEBGL_RENDER_FLOAT32_ENABLED", type: Type.BOOLEAN }, { name: "WEBGL_DOWNLOAD_FLOAT_ENABLED", type: Type.BOOLEAN }, { name: "WEBGL_FENCE_API_ENABLED", type: Type.BOOLEAN }, { name: "BACKEND", type: Type.STRING }];function isWebGLVersionEnabled(e, t) { + var n;try { + n = getWebGLRenderingContext(e, t); + } catch (e) { + return !1; + }return null != n && (loseContext(n), !0); + }function getWebGLDisjointQueryTimerVersion(e, t) { + if (0 === e) return 0;var n, + r = getWebGLRenderingContext(e, t);return n = hasExtension(r, "EXT_disjoint_timer_query_webgl2") && 2 === e ? 2 : hasExtension(r, "EXT_disjoint_timer_query") ? 1 : 0, null != r && loseContext(r), n; + }function isRenderToFloatTextureEnabled(e, t) { + if (0 === e) return !1;var n = getWebGLRenderingContext(e, t);if (1 === e) { + if (!hasExtension(n, "OES_texture_float")) return !1; + } else if (!hasExtension(n, "EXT_color_buffer_float")) return !1;createFloatTextureAndBindToFramebuffer(n, e);var r = n.checkFramebufferStatus(n.FRAMEBUFFER) === n.FRAMEBUFFER_COMPLETE;return loseContext(n), r; + }function isDownloadFloatTextureEnabled(e, t) { + if (0 === e) return !1;var n = getWebGLRenderingContext(e, t);if (1 === e) { + if (!hasExtension(n, "OES_texture_float")) return !1; + } else if (!hasExtension(n, "EXT_color_buffer_float")) return !1;createFloatTextureAndBindToFramebuffer(n, e), n.readPixels(0, 0, 1, 1, n.RGBA, n.FLOAT, new Float32Array(4));var r = n.getError() === n.NO_ERROR;return loseContext(n), r; + }function isWebGLFenceEnabled(e, t) { + if (2 !== e) return !1;var n = getWebGLRenderingContext(e, t), + r = null != n.fenceSync;return loseContext(n), r; + }function isChrome() { + return "undefined" != typeof navigator && null != navigator && null != navigator.userAgent && /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor); + }var TENSORFLOWJS_FLAGS_PREFIX = "tfjsflags";function getFeaturesFromURL() { + var e = {};if ("undefined" == typeof window || void 0 === window.location) return e;var t = getQueryParams(window.location.search);if (TENSORFLOWJS_FLAGS_PREFIX in t) { + var n = {};t[TENSORFLOWJS_FLAGS_PREFIX].split(",").forEach(function (e) { + var t = e.split(":"), + r = t[0], + o = t[1];n[r] = o; + }), URL_PROPERTIES.forEach(function (t) { + t.name in n && (console.log("Setting feature override from URL " + t.name + ": " + n[t.name]), t.type === Type.NUMBER ? e[t.name] = +n[t.name] : t.type === Type.BOOLEAN ? e[t.name] = "true" === n[t.name] : t.type === Type.STRING ? e[t.name] = n[t.name] : console.warn("Unknown URL param: " + t.name + ".")); + }); + }return e; + }function hasExtension(e, t) { + return null != e.getExtension(t); + }function getWebGLRenderingContext(e, t) { + if (0 === e || !t) throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");var n = document.createElement("canvas");return 1 === e ? n.getContext("webgl") || n.getContext("experimental-webgl") : n.getContext("webgl2"); + }function loseContext(e) { + if (null != e) { + var t = e.getExtension("WEBGL_lose_context");if (null == t) throw new Error("Extension WEBGL_lose_context not supported on this browser.");t.loseContext(); + } + }function createFloatTextureAndBindToFramebuffer(e, t) { + var n = e.createFramebuffer(), + r = e.createTexture();e.bindTexture(e.TEXTURE_2D, r);var o = 2 === t ? e.RGBA32F : e.RGBA;e.texImage2D(e.TEXTURE_2D, 0, o, 1, 1, 0, e.RGBA, e.FLOAT, null), e.bindFramebuffer(e.FRAMEBUFFER, n), e.framebufferTexture2D(e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, r, 0); + }function getQueryParams(e) { + var t = {};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, function (e) { + for (var n = [], r = 1; r < arguments.length; r++) n[r - 1] = arguments[r];return decodeParam(t, n[0], n[1]), n.join("="); + }), t; + }function decodeParam(e, t, n) { + e[decodeURIComponent(t)] = decodeURIComponent(n || ""); + }var TEST_EPSILON_FLOAT32_ENABLED = .001, + TEST_EPSILON_FLOAT32_DISABLED = .1, + Environment = function () { + function e(e) { + this.features = {}, this.registry = {}, null != e && (this.features = e), this.get("DEBUG") && console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance."); + }return e.setBackend = function (e, t) { + if (void 0 === t && (t = !1), !(e in ENV.registry)) throw new Error("Backend name '" + e + "' not found in registry");ENV.initBackend(e, t); + }, e.getBackend = function () { + return ENV.initDefaultBackend(), ENV.backendName; + }, e.disposeVariables = function () { + ENV.engine.disposeVariables(); + }, e.memory = function () { + return ENV.engine.memory(); + }, e.tidy = function (e, t, n) { + return void 0 === n && (n = !1), ENV.engine.tidy(e, t, n); + }, e.dispose = function (e) { + getTensorsInContainer(e).forEach(function (e) { + return e.dispose(); + }); + }, e.keep = function (e) { + return ENV.engine.keep(e); + }, e.time = function (e) { + return ENV.engine.time(e); + }, e.prototype.get = function (e) { + return e in this.features ? this.features[e] : (this.features[e] = this.evaluateFeature(e), this.features[e]); + }, e.prototype.getFeatures = function () { + return this.features; + }, e.prototype.set = function (e, t) { + this.features[e] = t; + }, e.prototype.getBestBackendName = function () { + var e = this;if (0 === Object.keys(this.registry).length) throw new Error("No backend found in registry.");return Object.keys(this.registry).map(function (t) { + return { name: t, entry: e.registry[t] }; + }).sort(function (e, t) { + return t.entry.priority - e.entry.priority; + })[0].name; + }, e.prototype.evaluateFeature = function (e) { + if ("DEBUG" === e) return !1;if ("IS_BROWSER" === e) return "undefined" != typeof window;if ("IS_NODE" === e) return "undefined" != typeof process && void 0 !== process.versions.node;if ("IS_CHROME" === e) return isChrome();if ("IS_TEST" === e) return !1;if ("BACKEND" === e) return this.getBestBackendName();if ("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION" === e) { + var t = this.get("WEBGL_VERSION");return 0 === t ? 0 : t > 0 ? 0 : getWebGLDisjointQueryTimerVersion(t, this.get("IS_BROWSER")); + }if ("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE" === e) return this.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") > 0 && !isMobile();if ("HAS_WEBGL" === e) return this.get("WEBGL_VERSION") > 0;if ("WEBGL_VERSION" === e) return isWebGLVersionEnabled(2, this.get("IS_BROWSER")) ? 2 : isWebGLVersionEnabled(1, this.get("IS_BROWSER")) ? 1 : 0;if ("WEBGL_RENDER_FLOAT32_ENABLED" === e) return isRenderToFloatTextureEnabled(this.get("WEBGL_VERSION"), this.get("IS_BROWSER"));if ("WEBGL_DOWNLOAD_FLOAT_ENABLED" === e) return isDownloadFloatTextureEnabled(this.get("WEBGL_VERSION"), this.get("IS_BROWSER"));if ("WEBGL_FENCE_API_ENABLED" === e) return isWebGLFenceEnabled(this.get("WEBGL_VERSION"), this.get("IS_BROWSER"));if ("TEST_EPSILON" === e) return this.get("WEBGL_RENDER_FLOAT32_ENABLED") ? TEST_EPSILON_FLOAT32_ENABLED : TEST_EPSILON_FLOAT32_DISABLED;throw new Error("Unknown feature " + e + "."); + }, e.prototype.setFeatures = function (e) { + this.features = Object.assign({}, e); + }, e.prototype.reset = function () { + this.features = getFeaturesFromURL(), null != this.globalEngine && (this.globalEngine = null); + }, e.prototype.initBackend = function (e, t) { + var n = this;void 0 === t && (t = !1), this.backendName = e, this.backend = this.findBackend(e), this.globalEngine = new Engine(this.backend, t, function () { + return n.get("DEBUG"); + }); + }, e.prototype.findBackend = function (e) { + return e in this.registry ? this.registry[e].backend : null; + }, e.prototype.registerBackend = function (e, t, n, r) { + var o = this;if (void 0 === n && (n = 1), e in this.registry) return console.warn(e + " backend was already registered. Reusing existing backend"), null != r && r(function () { + return o.engine; + }), !1;try { + var a = t();return this.registry[e] = { backend: a, priority: n }, !0; + } catch (t) { + return console.warn("Registration of backend " + e + " failed"), console.warn(t.stack || t.message), !1; + } + }, e.prototype.removeBackend = function (e) { + if (!(e in this.registry)) throw new Error(e + " backend not found in registry");this.registry[e].backend.dispose(), delete this.registry[e]; + }, Object.defineProperty(e.prototype, "engine", { get: function () { + return this.initDefaultBackend(), this.globalEngine; + }, enumerable: !0, configurable: !0 }), e.prototype.initDefaultBackend = function () { + null == this.globalEngine && this.initBackend(this.get("BACKEND"), !1); + }, e; + }();function getGlobalNamespace() { + var e;if ("undefined" != typeof window) e = window;else { + if ("undefined" == typeof process) throw new Error("Could not find a global object");e = process; + }return e; + }function getOrMakeEnvironment() { + var e = getGlobalNamespace();return null == e.ENV && (e.ENV = new Environment(getFeaturesFromURL()), setTensorTracker(function () { + return e.ENV.engine; + })), e.ENV; + }var ENV = getOrMakeEnvironment(), + environment = Object.freeze({ Environment: Environment, ENV: ENV });function warn() { + for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];ENV.get("IS_TEST") || console.warn.apply(console, e); + }function getReshaped(e, t, n, r) { + void 0 === r && (r = !0);var o = [];if (r) (o = o.concat(t.slice(0))).push(e[0] / n), o = o.concat(e.slice(1));else { + o = o.concat(e[0]);for (var a = t.length, i = 0; i < a; ++i) o = o.concat([e[i + 1] / t[i], t[i]]);o = o.concat(e.slice(a + 1)); + }return o; + }function getPermuted(e, t, n) { + void 0 === n && (n = !0);var r = [];if (n) { + r.push(t);for (var o = t + 1; o < e; ++o) o <= 2 * t ? (r.push(o), r.push(o - (t + 1))) : r.push(o); + } else { + var a = [], + i = [];for (o = 1; o < e; ++o) o >= 2 * t + 1 || o % 2 == 1 ? i.push(o) : a.push(o);r.push.apply(r, a), r.push(0), r.push.apply(r, i); + }return r; + }function getReshapedPermuted(e, t, n, r) { + void 0 === r && (r = !0);var o = [];r ? o.push(e[0] / n) : o.push(e[0] * n);for (var a = 1; a < e.length; ++a) a <= t.length ? r ? o.push(t[a - 1] * e[a]) : o.push(e[a] / t[a - 1]) : o.push(e[a]);return o; + }function getSliceBeginCoords(e, t) { + for (var n = [0], r = 0; r < t; ++r) n.push(e[r][0]);return n; + }function getSliceSize(e, t, n) { + for (var r = e.slice(0, 1), o = 0; o < n; ++o) r.push(e[o + 1] - t[o][0] - t[o][1]);return r; + }function axesAreInnerMostDims(e, t) { + for (var n = 0; n < e.length; ++n) if (e[e.length - n - 1] !== t - 1 - n) return !1;return !0; + }function combineLocations(e, t, n) { + for (var r = e.length + t.length, o = [], a = 0, i = 0, s = 0; s < r; s++) -1 === n.indexOf(s) ? o.push(e[a++]) : o.push(t[i++]);return o; + }function computeOutAndReduceShapes(e, t) { + for (var n = [], r = e.length, o = 0; o < r; o++) -1 === t.indexOf(o) && n.push(e[o]);return [n, t.map(function (t) { + return e[t]; + })]; + }function expandShapeToKeepDim(e, t) { + return combineLocations(e, t.map(function (e) { + return 1; + }), t); + }function parseAxisParam(e, t) { + var n = t.length;return assert((e = null == e ? t.map(function (e, t) { + return t; + }) : [].concat(e)).every(function (e) { + return e >= -n && e < n; + }), "All values in axis param must be in range [-" + n + ", " + n + ") but got axis " + e), assert(e.every(function (e) { + return isInt(e); + }), "All values in axis param must be integers but got axis " + e), e.map(function (e) { + return e < 0 ? n + e : e; + }); + }function assertAxesAreInnerMostDims(e, t, n) { + assert(axesAreInnerMostDims(t, n), e + " supports only inner-most axes for now. Got axes " + t + " and rank-" + n + " input."); + }function getAxesPermutation(e, t) { + if (axesAreInnerMostDims(e, t)) return null;for (var n = [], r = 0; r < t; ++r) -1 === e.indexOf(r) && n.push(r);return e.forEach(function (e) { + return n.push(e); + }), n; + }function getUndoAxesPermutation(e) { + return e.map(function (e, t) { + return [t, e]; + }).sort(function (e, t) { + return e[1] - t[1]; + }).map(function (e) { + return e[0]; + }); + }function getInnerMostAxes(e, t) { + for (var n = [], r = t - e; r < t; ++r) n.push(r);return n; + }var PARALLELIZE_THRESHOLD = 30;function computeOptimalWindowSize(e) { + return e <= PARALLELIZE_THRESHOLD ? e : nearestDivisor(e, Math.floor(Math.sqrt(e))); + }function segOpComputeOptimalWindowSize(e, t) { + var n, + r = !1;for (e <= PARALLELIZE_THRESHOLD ? (n = e, r = !0) : n = nearestDivisor(e, Math.floor(Math.sqrt(e))); !r;) { + if (n > t || n === e) { + r = !0;break; + }n = nearestDivisor(e, n + 1); + }return n; + }function computeOutShape(e, t, n) { + for (var r = [], o = e.length, a = 0; a < o; a++) a !== t ? r.push(e[a]) : r.push(n);return r; + }function assertParamsValid(e, t, n) { + assert(e.rank === t.length, "Error in slice" + e.rank + "D: Length of begin " + t + " must match the rank of the array (" + e.rank + ")."), assert(e.rank === n.length, "Error in slice" + e.rank + "D: Length of size " + n + " must match the rank of the array (" + e.rank + ").");for (var r = 0; r < e.rank; ++r) assert(t[r] + n[r] <= e.shape[r], "Error in slice" + e.rank + "D: begin[" + r + "] + size[" + r + "] (" + (t[r] + n[r]) + ") would overflow input.shape[" + r + "] (" + e.shape[r] + ")"); + }function getStridedSlicedInfo(e, t, n, r, o, a) { + void 0 === o && (o = 0), void 0 === a && (a = 0);for (var i = [], s = [], u = 0; u < e.length; u++) i[u] = startForAxis(o, t, r, e, u), s[u] = stopForAxis(a, n, r, e, u);var l = new Array(e.length).fill(0);return l = l.map(function (e, t) { + for (var n = 0, o = i[t]; !(r[t] > 0 ? o >= s[t] : o <= s[t]); o += r[t]) n += 1;return n; + }), [i, l]; + }function startForAxis(e, t, n, r, o) { + var a = t[o];e & 1 << o && (a = n[o] > 0 ? Number.MIN_SAFE_INTEGER : Number.MAX_SAFE_INTEGER);var i = r[o];return a < 0 && (a += i), a = clamp(0, a, i - 1); + }function stopForAxis(e, t, n, r, o) { + var a = t[o];e & 1 << o && (a = n[o] > 0 ? Number.MAX_SAFE_INTEGER : Number.MIN_SAFE_INTEGER);var i = r[o];return a < 0 && (a += i), a = n[o] > 0 ? clamp(0, a, i) : clamp(-1, a, i - 1); + }function grad(e) { + return assert(isFunction(e), "The f passed in grad(f) must be a function"), function (t, n) { + return assert(t instanceof Tensor, "The x passed in grad(f)(x) must be a tensor"), assert(null == n || n instanceof Tensor, "The dy passed in grad(f)(x, dy) must be a tensor"), ENV.engine.tidy(function () { + var r = ENV.engine.gradients(function () { + return e(t); + }, [t], n), + o = r.value, + a = r.grads;return null != n && assertShapesMatch(o.shape, n.shape, "The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"), checkGrads(a), a[0]; + }); + }; + }function grads(e) { + return assert(isFunction(e), "The f passed in grads(f) must be a function"), function (t, n) { + return assert(Array.isArray(t) && t.every(function (e) { + return e instanceof Tensor; + }), "The args passed in grads(f)(args) must be an array of tensors"), assert(null == n || n instanceof Tensor, "The dy passed in grads(f)(args, dy) must be a tensor"), ENV.engine.tidy(function () { + var r = ENV.engine.gradients(function () { + return e.apply(void 0, t); + }, t, n), + o = r.value, + a = r.grads;return null != n && assertShapesMatch(o.shape, n.shape, "The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"), checkGrads(a), a; + }); + }; + }function valueAndGrad(e) { + return assert(isFunction(e), "The f passed in valueAndGrad(f) must be a function"), function (t, n) { + assert(t instanceof Tensor, "The x passed in valueAndGrad(f)(x) must be a tensor"), assert(null == n || n instanceof Tensor, "The dy passed in valueAndGrad(f)(x, dy) must be a tensor");var r = ENV.engine.gradients(function () { + return e(t); + }, [t], n), + o = r.grads, + a = r.value;return checkGrads(o), { grad: o[0], value: a }; + }; + }function valueAndGrads(e) { + return assert(isFunction(e), "The f passed in valueAndGrads(f) must be a function"), function (t, n) { + assert(Array.isArray(t) && t.every(function (e) { + return e instanceof Tensor; + }), "The args passed in valueAndGrads(f)(args) must be array of tensors"), assert(null == n || n instanceof Tensor, "The dy passed in valueAndGrads(f)(args, dy) must be a tensor");var r = ENV.engine.gradients(function () { + return e.apply(void 0, t); + }, t, n);return null != n && assertShapesMatch(r.value.shape, n.shape, "The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"), checkGrads(r.grads), r; + }; + }function variableGrads(e, t) { + if (assert(isFunction(e), "The f passed in variableGrads(f) must be a function"), assert(null == t || Array.isArray(t) && t.every(function (e) { + return e instanceof Variable; + }), "The varList passed in variableGrads(f, varList) must be an array of variables"), null == t) for (var n in t = [], ENV.engine.registeredVariables) t.push(ENV.engine.registeredVariables[n]);var r = t.length;assert((t = t.filter(function (e) { + return e.trainable; + })).length > 0, "variableGrads() expects at least one of the input variables to be trainable, but none of the " + r + " variables is trainable.");var o = ENV.engine.gradients(e, t, null, !0), + a = o.value, + i = o.grads;assert(i.some(function (e) { + return null != e; + }), "Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."), assert(0 === a.rank, "The f passed in variableGrads(f) must return a scalar, but it returned a rank-" + a.rank + " tensor");var s = {};return t.forEach(function (e, t) { + null != i[t] && (s[e.name] = i[t]); + }), { value: a, grads: s }; + }function customGrad(e) { + return ENV.engine.customGrad(e); + }function checkGrads(e) { + if (e.filter(function (e) { + return null == e; + }).length > 0) throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y."); + }function convertToTensor(e, t, n, r) { + if (void 0 === r && (r = "float32"), r = r || "float32", e instanceof Tensor) return e;if (!isTypedArray(e) && !Array.isArray(e) && "number" != typeof e && "boolean" != typeof e) throw new Error("Argument '" + t + "' passed to '" + n + "' must be a Tensor or TensorLike, but got " + e.constructor.name);var o = inferShape(e);return isTypedArray(e) || Array.isArray(e) || (e = [e]), Tensor.make(o, { values: toTypedArray(e, r, ENV.get("DEBUG")) }, r); + }function convertToTensorArray(e, t, n) { + if (!Array.isArray(e)) throw new Error("Argument " + t + " passed to " + n + " must be a `Tensor[]` or `TensorLike[]`");return e.map(function (e, r) { + return convertToTensor(e, t + "[" + r + "]", n); + }); + }function op(e) { + var t = Object.keys(e);if (1 !== t.length) throw new Error("Please provide an object with a single key (operation name) mapping to a function. Got an object with " + t.length + " keys.");var n = t[0], + r = e[n];n.endsWith("_") && (n = n.substring(0, n.length - 1));var o = function () { + for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];ENV.engine.startScope(n);try { + var o = r.apply(void 0, e);return o instanceof Promise && console.error("Cannot return a Promise inside of tidy."), ENV.engine.endScope(o), o; + } catch (e) { + throw ENV.engine.endScope(null), e; + } + };return Object.defineProperty(o, "name", { value: n, configurable: !0 }), o; + }function softmax_(e, t) { + void 0 === t && (t = -1);var n = convertToTensor(e, "logits", "softmax");if (-1 === t && (t = n.rank - 1), t !== n.rank - 1) throw Error("Softmax along a non-last dimension is not yet supported. Logits was rank " + n.rank + " and dim was " + t);return customGrad(function (e) { + var n = e.logSumExp([t], !0), + r = e.toFloat().sub(n).exp();return { value: r, gradFunc: function (e) { + var n = e.mul(r);return n.sub(n.sum([t], !0).mul(r)); + } }; + })(n); + }var softmax = op({ softmax_: softmax_ });function tensor(e, t, n) { + if (void 0 === n && (n = "float32"), !isTypedArray(e) && !Array.isArray(e) && "number" != typeof e && "boolean" != typeof e) throw new Error("values passed to tensor(values) must be an array of numbers or booleans, or a TypedArray");var r = inferShape(e);return null != t && 1 !== r.length && assertShapesMatch(t, r, "Error creating a new Tensor. Inferred shape (" + r + ") does not match the provided shape (" + t + "). "), isTypedArray(e) || Array.isArray(e) || (e = [e]), t = t || r, Tensor.make(t, { values: toTypedArray(e, n, ENV.get("DEBUG")) }, n); + }function scalar(e, t) { + if (void 0 === t && (t = "float32"), isTypedArray(e) || Array.isArray(e)) throw new Error("Error creating a new Scalar: value must be a primitive (number|boolean)");return tensor(e, [], t); + }function tensor1d(e, t) { + void 0 === t && (t = "float32"), assertNonNull(e);var n = inferShape(e);if (1 !== n.length) throw new Error("tensor1d() requires values to be a flat/TypedArray");return tensor(e, n, t); + }function tensor2d(e, t, n) { + if (void 0 === n && (n = "float32"), assertNonNull(e), null != t && 2 !== t.length) throw new Error("tensor2d() requires shape to have two numbers");var r = inferShape(e);if (2 !== r.length && 1 !== r.length) throw new Error("tensor2d() requires values to be number[][] or flat/TypedArray");if (1 === r.length && null == t) throw new Error("tensor2d() requires shape to be provided when `values` are a flat/TypedArray");return tensor(e, t = t || r, n); + }function tensor3d(e, t, n) { + if (void 0 === n && (n = "float32"), assertNonNull(e), null != t && 3 !== t.length) throw new Error("tensor3d() requires shape to have three numbers");var r = inferShape(e);if (3 !== r.length && 1 !== r.length) throw new Error("tensor3d() requires values to be number[][][] or flat/TypedArray");if (1 === r.length && null == t) throw new Error("tensor3d() requires shape to be provided when `values` are a flat array");return tensor(e, t = t || r, n); + }function tensor4d(e, t, n) { + if (void 0 === n && (n = "float32"), assertNonNull(e), null != t && 4 !== t.length) throw new Error("tensor4d() requires shape to have four numbers");var r = inferShape(e);if (4 !== r.length && 1 !== r.length) throw new Error("tensor4d() requires values to be number[][][][] or flat/TypedArray");if (1 === r.length && null == t) throw new Error("tensor4d() requires shape to be provided when `values` are a flat array");return tensor(e, t = t || r, n); + }function tensor5d(e, t, n) { + if (void 0 === n && (n = "float32"), assertNonNull(e), null != t && 5 !== t.length) throw new Error("tensor5d() requires shape to have five numbers");var r = inferShape(e);if (5 !== r.length && 1 !== r.length) throw new Error("tensor5d() requires values to be number[][][][][] or flat/TypedArray");if (1 === r.length && null == t) throw new Error("tensor5d() requires shape to be provided when `values` are a flat array");return tensor(e, t = t || r, n); + }function tensor6d(e, t, n) { + if (void 0 === n && (n = "float32"), assertNonNull(e), null != t && 6 !== t.length) throw new Error("tensor6d() requires shape to have six numbers");var r = inferShape(e);if (6 !== r.length && 1 !== r.length) throw new Error("tensor6d() requires values to be number[][][][] or flat/TypedArray");if (1 === r.length && null == t) throw new Error("tensor6d() requires shape to be provided when `values` are a flat array");return tensor(e, t = t || r, n); + }function ones$1(e, t) { + void 0 === t && (t = "float32");var n = makeOnesTypedArray(sizeFromShape(e), t);return Tensor.make(e, { values: n }, t); + }function zeros(e, t) { + void 0 === t && (t = "float32");var n = makeZerosTypedArray(sizeFromShape(e), t);return Tensor.make(e, { values: n }, t); + }function fill(e, t, n) { + void 0 === n && (n = "float32");var r = getTypedArrayFromDType(n, sizeFromShape(e));return r.fill(t), Tensor.make(e, { values: r }, n); + }function onesLike_(e) { + var t = convertToTensor(e, "x", "onesLike");return ones$1(t.shape, t.dtype); + }function zerosLike_(e) { + var t = convertToTensor(e, "x", "zerosLike");return zeros(t.shape, t.dtype); + }function linspace(e, t, n) { + if (0 === n) throw new Error("Cannot request zero samples");var r = (t - e) / (n - 1), + o = makeZerosTypedArray(n, "float32");o[0] = e;for (var a = 1; a < o.length; a++) o[a] = o[a - 1] + r;return tensor1d(o, "float32"); + }function range(e, t, n, r) { + if (void 0 === n && (n = 1), void 0 === r && (r = "float32"), 0 === n) throw new Error("Cannot have a step of zero");if (e === t || e < t && n < 0 || t < e && n > 1) return zeros([0], r);var o = makeZerosTypedArray(Math.abs(Math.ceil((t - e) / n)), r);t < e && 1 === n && (n = -1), o[0] = e;for (var a = 1; a < o.length; a++) o[a] = o[a - 1] + n;return tensor1d(o, r); + }var DType, + UpcastInt32AndMap, + UpcastBoolAndMap, + UpcastFloat32AndMap, + onesLike = op({ onesLike_: onesLike_ }), + zerosLike = op({ zerosLike_: zerosLike_ });!function (e) { + e.float32 = "float32", e.int32 = "int32", e.bool = "bool"; + }(DType || (DType = {})), function (e) { + e.R0 = "R0", e.R1 = "R1", e.R2 = "R2", e.R3 = "R3", e.R4 = "R4", e.R5 = "R5", e.R6 = "R6"; + }(exports.Rank || (exports.Rank = {})), function (e) { + e.float32 = "float32", e.int32 = "int32", e.bool = "int32"; + }(UpcastInt32AndMap || (UpcastInt32AndMap = {})), function (e) { + e.float32 = "float32", e.int32 = "int32", e.bool = "bool"; + }(UpcastBoolAndMap || (UpcastBoolAndMap = {})), function (e) { + e.float32 = "float32", e.int32 = "float32", e.bool = "float32"; + }(UpcastFloat32AndMap || (UpcastFloat32AndMap = {}));var upcastTypeMap = { float32: UpcastFloat32AndMap, int32: UpcastInt32AndMap, bool: UpcastBoolAndMap };function upcastType(e, t) { + return upcastTypeMap[e][t]; + }function sumOutType(e) { + return upcastType(e, "int32"); + }function castTensor(e, t, n) { + if (!hasEncodingLoss(e.dtype, t)) return Tensor.make(e.shape, { dataId: e.dataId }, t);if ("int32" === t) return n.int(e);if ("bool" === t) return n.notEqual(e, scalar(0, e.dtype));throw new Error("Error in Cast: unknown dtype argument (" + t + ")"); + }function reshapeTensor(e, t) { + return Tensor.make(t, { dataId: e.dataId }, e.dtype); + }function nonMaxSuppressionImpl(e, t, n, r, o) { + for (var a = Array.from(t).map(function (e, t) { + return { score: e, boxIndex: t }; + }).filter(function (e) { + return e.score > o; + }).sort(function (e, t) { + return t.score - e.score; + }), i = [], s = 0; s < a.length; s++) { + var u = a[s], + l = u.score, + c = u.boxIndex;if (l < o) break;for (var p = !1, d = i.length - 1; d >= 0; --d) { + if (intersectionOverUnion(e, c, i[d]) >= r) { + p = !0;break; + } + }if (!p && (i.push(c), i.length >= n)) break; + }return tensor1d(i, "int32"); + }function intersectionOverUnion(e, t, n) { + var r = e.subarray(4 * t, 4 * t + 4), + o = e.subarray(4 * n, 4 * n + 4), + a = Math.min(r[0], r[2]), + i = Math.min(r[1], r[3]), + s = Math.max(r[0], r[2]), + u = Math.max(r[1], r[3]), + l = Math.min(o[0], o[2]), + c = Math.min(o[1], o[3]), + p = Math.max(o[0], o[2]), + d = Math.max(o[1], o[3]), + h = (s - a) * (u - i), + f = (p - l) * (d - c);if (h <= 0 || f <= 0) return 0;var m = Math.max(a, l), + g = Math.max(i, c), + v = Math.min(s, p), + y = Math.min(u, d), + x = Math.max(v - m, 0) * Math.max(y - g, 0);return x / (h + f - x); + }function topkImpl(e, t, n, r, o) { + for (var a = t[t.length - 1], i = [e.length / a, a], s = i[0], u = i[1], l = getTypedArrayFromDType(n, s * r), c = getTypedArrayFromDType("int32", s * r), p = 0; p < s; p++) { + for (var d = p * u, h = e.subarray(d, d + u), f = [], m = 0; m < h.length; m++) f.push({ value: h[m], index: m });f.sort(function (e, t) { + return t.value - e.value; + });var g = p * r, + v = l.subarray(g, g + r), + y = c.subarray(g, g + r);for (m = 0; m < r; m++) v[m] = f[m].value, y[m] = f[m].index; + }var x = t.slice();return x[x.length - 1] = r, [tensor(l, x, n), tensor(c, x, "int32")]; + }var ArgMinMaxProgram = function () { + return function (e, t, n) { + this.variableNames = ["A"];var r = e.windowSize, + o = e.batchSize, + a = e.inSize, + i = Math.ceil(a / r);n || this.variableNames.push("bestIndicesA"), this.outputShape = [o, i];var s = "max" === t ? ">" : "<", + u = n ? "inOffset + i;" : "round(getBestIndicesA(batch, inOffset + i));";this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + r + ";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < " + r + "; i++) {\n int inIdx = " + u + ";\n float candidate = getA(batch, inIdx);\n if (candidate " + s + " bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "; + }; + }(), + AvgPool2DBackpropProgram = function () { + return function (e) { + this.variableNames = ["dy"], this.outputShape = e.inShape;var t = e.filterHeight, + n = e.filterWidth, + r = e.strideHeight, + o = e.strideWidth, + a = t - 1 - e.padInfo.top, + i = n - 1 - e.padInfo.left, + s = 1 / (t * n);this.userCode = "\n const ivec2 pads = ivec2(" + a + ", " + i + ");\n const float avgMultiplier = float(" + s + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + t + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + r + ".0;\n\n if (dyR < 0.0 || dyR >= " + e.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + n + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + o + ".0;\n\n if (dyC < 0.0 || dyC >= " + e.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }();function getBroadcastDims(e, t) { + for (var n = e.length, r = [], o = 0; o < n; o++) { + var a = n - 1 - o, + i = e[a] || 1;(t[t.length - 1 - o] || 1) > 1 && 1 === i && r.unshift(a); + }return r; + }function getReductionAxes(e, t) { + for (var n = [], r = 0; r < t.length; r++) { + var o = e[e.length - r - 1], + a = t.length - r - 1, + i = t[a];(null == o || 1 === o && i > 1) && n.unshift(a); + }return n; + }function broadcastDimsAreOuter(e) { + for (var t = 0; t < e.length; t++) if (e[t] !== t) return !1;return !0; + }function assertAndGetBroadcastShape(e, t) { + for (var n = [], r = "Operands could not be broadcast together with shapes " + e + " and " + t + ".", o = Math.max(e.length, t.length), a = 0; a < o; a++) { + var i = e[e.length - a - 1] || 1, + s = t[t.length - a - 1] || 1;if (i > 1 && s > 1 && i !== s) throw Error(r);n.unshift(Math.max(i, s)); + }return n; + }var BatchNormProgram = function () { + return function (e, t, n, r, o, a) { + this.outputShape = [], this.supportsBroadcasting = !0, this.variableNames = ["x", "mean", "variance"], assertAndGetBroadcastShape(e, t), assertAndGetBroadcastShape(e, n);var i = "0.0";null != r && (assertAndGetBroadcastShape(e, r), this.variableNames.push("offset"), i = "getOffsetAtOutCoords()");var s = "1.0";null != o && (assertAndGetBroadcastShape(e, o), this.variableNames.push("scale"), s = "getScaleAtOutCoords()"), this.outputShape = e, this.userCode = "\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = " + i + ";\n float scale = " + s + ";\n float inv = scale * inversesqrt(variance + float(" + a + "));\n setOutput((x - mean) * inv + offset);\n }\n "; + }; + }(), + CHECK_NAN_SNIPPET = "\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n", + ADD = "return a + b;", + SUB = "return a - b;", + MUL = "return a * b;", + DIV = "if (a == b) return 1.0;\n return a / b;", + INT_DIV = "\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n", + POW = "\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n", + SQUARED_DIFFERENCE = "return (a - b) * (a - b);", + EQUAL = "return float(a == b);", + NOT_EQUAL = "return float(a != b);", + LESS = "return float(a < b);", + LESS_EQUAL = "return float(a <= b);", + GREATER = "return float(a > b);", + GREATER_EQUAL = "return float(a >= b);", + LOGICAL_AND = "return float(a >= 1.0 && b >= 1.0);", + LOGICAL_OR = "return float(a >= 1.0 || b >= 1.0);", + MAX = CHECK_NAN_SNIPPET + "\n return max(a, b);\n", + MIN = CHECK_NAN_SNIPPET + "\n return min(a, b);\n", + MOD = "if (b == 0.0) return NAN;\n return mod(a, b);", + ATAN2 = CHECK_NAN_SNIPPET + "\n return atan(a, b);\n", + ELU_DER = "return (b >= 1.0) ? a : a * (b + 1.0);", + BinaryOpProgram = function () { + function e(e, t, n) { + this.variableNames = ["A", "B"], this.supportsBroadcasting = !0, this.outputShape = assertAndGetBroadcastShape(t, n), this.userCode = "\n uniform float NAN;\n float binaryOperation(float a, float b) {\n " + e + "\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "; + }return e.prototype.getCustomSetupFunc = function () { + var e = this;return function (t, n) { + null == e.startLoc && (e.startLoc = t.getUniformLocationNoThrow(n, "NAN"), null == e.startLoc) || t.gl.uniform1f(e.startLoc, NaN); + }; + }, e; + }(), + ClipProgram = function () { + return function (e, t, n) { + this.variableNames = ["A"], this.outputShape = e;var r = t.toFixed(20), + o = n.toFixed(20);this.userCode = "\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, " + r + ", " + o + "));\n }\n "; + }; + }();function assertParams(e, t, n) { + var r = e.length, + o = t.length;assert(e.length === t.length, "Error in concat" + r + "D: rank of x1 (" + r + ") and x2 (" + o + ") must be the same."), assert(n >= 0 && n < r, "Error in concat" + r + "D: axis must be between 0 and " + (r - 1) + ".");for (var a = 0; a < r; a++) assert(a === n || e[a] === t[a], "Error in concat" + r + "D: Shape (" + e + ") does not match (" + t + ") along the non-concatenated axis " + a + "."); + }function computeOutShape$1(e, t, n) { + assert(e.length === t.length, "x1 and x2 should have the same rank.");var r = e.slice();return r[n] += t[n], r; + }function computeGradientSliceShapes(e, t) { + return { aBegin: [0, 0], aSize: e, bBegin: [0, e[1]], bSize: t }; + }var ConcatProgram = function () { + return function (e, t) { + this.variableNames = ["A", "B"], this.outputShape = [], this.outputShape = computeOutShape$1(e, t, 1), this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int yR = coords.x;\n int yC = coords.y;\n\n float value = 0.0;\n if (yC < " + e[1] + ") {\n value = getA(yR, yC);\n } else {\n yC -= " + e[1] + ";\n value = getB(yR, yC);\n }\n\n setOutput(value);\n }\n "; + }; + }(), + Conv2DDerFilterProgram = function () { + return function (e) { + this.variableNames = ["x", "dy"], this.outputShape = e.filterShape;var t = e.strideHeight, + n = e.strideWidth, + r = e.padInfo.top, + o = e.padInfo.left;this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int d2 = coords.w;\n\n // Convolve x(?, ?, d1) with dy(:, :, d2) to get dw(wR, wC, d1, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n\n for (int b = 0; b < " + e.batchSize + "; b++) {\n for (int yR = 0; yR < " + e.outHeight + "; yR++) {\n int xR = wR + yR * " + t + " - " + r + ";\n\n if (xR < 0 || xR >= " + e.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + e.outWidth + "; yC++) {\n int xC = wC + yC * " + n + " - " + o + ";\n\n if (xC < 0 || xC >= " + e.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + Conv2DDerInputProgram = function () { + return function (e) { + this.variableNames = ["dy", "W"], this.outputShape = e.inShape;var t = e.filterHeight, + n = e.filterWidth, + r = e.strideHeight, + o = e.strideWidth, + a = t - 1 - e.padInfo.top, + i = n - 1 - e.padInfo.left;this.userCode = "\n const ivec2 pads = ivec2(" + a + ", " + i + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + t + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + r + ".0;\n\n if (dyR < 0.0 || dyR >= " + e.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + t + " - 1 - wR;\n\n for (int wC = 0; wC < " + n + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + o + ".0;\n\n if (dyC < 0.0 || dyC >= " + e.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + n + " - 1 - wC;\n\n for (int d2 = 0; d2 < " + e.outChannels + "; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + DepthwiseConv2DDerFilterProgram = function () { + return function (e) { + this.variableNames = ["x", "dy"], this.outputShape = e.filterShape;var t = e.strideHeight, + n = e.strideWidth, + r = e.padInfo.top, + o = e.padInfo.left, + a = e.outChannels / e.inChannels;this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * " + a + " + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < " + e.batchSize + "; b++) {\n for (int yR = 0; yR < " + e.outHeight + "; yR++) {\n int xR = wR + yR * " + t + " - " + r + ";\n\n if (xR < 0 || xR >= " + e.inHeight + ") {\n continue;\n }\n\n for (int yC = 0; yC < " + e.outWidth + "; yC++) {\n int xC = wC + yC * " + n + " - " + o + ";\n\n if (xC < 0 || xC >= " + e.inWidth + ") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + DepthwiseConv2DDerInputProgram = function () { + return function (e) { + this.variableNames = ["dy", "W"], this.outputShape = e.inShape;var t = e.filterHeight, + n = e.filterWidth, + r = e.strideHeight, + o = e.strideWidth, + a = t - 1 - e.padInfo.top, + i = n - 1 - e.padInfo.left, + s = e.outChannels / e.inChannels;this.userCode = "\n const ivec2 pads = ivec2(" + a + ", " + i + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < " + t + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + r + ".0;\n\n if (dyR < 0.0 || dyR >= " + e.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = " + t + " - 1 - wR;\n\n for (int wC = 0; wC < " + n + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + o + ".0;\n\n if (dyC < 0.0 || dyC >= " + e.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = " + n + " - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < " + s + "; dm++) {\n int d2 = d1 * " + s + " + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + Conv2DProgram = function () { + return function (e) { + this.variableNames = ["x", "W"], this.outputShape = e.outShape;var t = e.padInfo.top, + n = e.padInfo.left, + r = e.strideHeight, + o = e.strideWidth, + a = e.dilationHeight, + i = e.dilationWidth, + s = e.filterHeight, + u = e.filterWidth, + l = 4 * Math.floor(e.inChannels / 4), + c = e.inChannels % 4;this.userCode = "\n const ivec2 strides = ivec2(" + r + ", " + o + ");\n const ivec2 pads = ivec2(" + t + ", " + n + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + s + "; wR++) {\n int xR = xRCorner + wR * " + a + ";\n\n if (xR < 0 || xR >= " + e.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + u + "; wC++) {\n int xC = xCCorner + wC * " + i + ";\n\n if (xC < 0 || xC >= " + e.inWidth + ") {\n continue;\n }\n\n for (int d1 = 0; d1 < " + l + "; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if (" + (1 === c) + ") {\n dotProd +=\n getX(batch, xR, xC, " + l + ") *\n getW(wR, wC, " + l + ", d2);\n } else if (" + (2 === c) + ") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, " + l + "),\n getX(batch, xR, xC, " + l + " + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, " + l + ", d2),\n getW(wR, wC, " + l + " + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if (" + (3 === c) + ") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, " + l + "),\n getX(batch, xR, xC, " + l + " + 1),\n getX(batch, xR, xC, " + l + " + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, " + l + ", d2),\n getW(wR, wC, " + l + " + 1, d2),\n getW(wR, wC, " + l + " + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + DepthwiseConv2DProgram = function () { + return function (e) { + this.variableNames = ["x", "W"], this.outputShape = e.outShape;var t = e.inHeight, + n = e.inWidth, + r = e.padInfo.top, + o = e.padInfo.left, + a = e.strideHeight, + i = e.strideWidth, + s = e.dilationHeight, + u = e.dilationWidth, + l = e.filterHeight, + c = e.filterWidth, + p = e.outChannels / e.inChannels;this.userCode = "\n const ivec2 strides = ivec2(" + a + ", " + i + ");\n const ivec2 pads = ivec2(" + r + ", " + o + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / " + p + ";\n int q = d2 - d1 * " + p + ";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < " + l + "; wR++) {\n int xR = xRCorner + wR * " + s + ";\n\n if (xR < 0 || xR >= " + t + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + c + "; wC++) {\n int xC = xCCorner + wC * " + u + ";\n\n if (xC < 0 || xC >= " + n + ") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }();function makeShader(e, t, n, r) { + var o = e.map(function (e) { + var t = sizeFromShape(e.shapeInfo.logicalShape);return e.shapeInfo.isUniform ? "uniform float " + e.name + (t > 1 ? "[" + t + "]" : "") + ";" : "uniform sampler2D " + e.name + ";"; + });o = o.join("\n");var a = e.map(function (e) { + return getInputSamplingSnippet(e, t, r); + }).join("\n"), + i = t.texShape, + s = getOutputSamplingSnippet(t.logicalShape, i);return [SHADER_PREFIX, FLOAT_TEXTURE_SAMPLE_SNIPPET, FLOAT_TEXTURE_SETOUTPUT_SNIPPET, o, s, a, n].join("\n"); + }function getSamplerFromInInfo(e) { + var t = e.shapeInfo.logicalShape;switch (t.length) {case 0: + return getSamplerScalar(e);case 1: + return getSampler1D(e);case 2: + return getSampler2D(e);case 3: + return getSampler3D(e);case 4: + return getSampler4D(e);case 5: + return getSampler5D(e);case 6: + return getSampler6D(e);default: + throw new Error(t.length + "-D input sampling is not yet supported");} + }function getInputSamplingSnippet(e, t, n) { + var r = getSamplerFlat(e);return r += getSamplerFromInInfo(e), (n || arraysEqual(e.shapeInfo.logicalShape, t.logicalShape)) && (r += getSamplerAtOutputCoords(e, t, n)), r; + }function getOutputSamplingSnippet(e, t) { + switch (e.length) {case 0: + return getOutputScalarCoords();case 1: + return getOutput1DCoords(e, t);case 2: + return getOutput2DCoords(e, t);case 3: + return getOutput3DCoords(e, t);case 4: + return getOutput4DCoords(e, t);case 5: + return getOutput5DCoords(e, t);case 6: + return getOutput6DCoords(e, t);default: + throw new Error(e.length + "-D output sampling is not yet supported");} + }var SAMPLE_1D_SNIPPET = "\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + SAMPLE_2D_SNIPPET = "\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + SAMPLE_3D_SNIPPET = "\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + SAMPLE_4D_SNIPPET = "\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + SAMPLE_5D_SNIPPET = "\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + SAMPLE_6D_SNIPPET = "\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n", + FLOAT_TEXTURE_SAMPLE_SNIPPET = "\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n", + FLOAT_TEXTURE_SETOUTPUT_SNIPPET = "\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n", + SHADER_PREFIX = "\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n " + SAMPLE_1D_SNIPPET + "\n " + SAMPLE_2D_SNIPPET + "\n " + SAMPLE_3D_SNIPPET + "\n " + SAMPLE_4D_SNIPPET + "\n " + SAMPLE_5D_SNIPPET + "\n " + SAMPLE_6D_SNIPPET + "\n";function getOutputScalarCoords() { + return "\n int getOutputCoords() {\n return 0;\n }\n "; + }function getOutput1DCoords(e, t) { + return 1 === t[0] ? "\n int getOutputCoords() {\n return int(resultUV.x * " + t[1] + ".0);\n }\n " : 1 === t[1] ? "\n int getOutputCoords() {\n return int(resultUV.y * " + t[0] + ".0);\n }\n " : "\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n return resTexRC.x * " + t[1] + " + resTexRC.y;\n }\n "; + }function getOutput3DCoords(e, t) { + var n = e[1] * e[2], + r = e[2];return "\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n int r = index / " + n + ";\n index -= r * " + n + ";\n int c = index / " + r + ";\n int d = index - c * " + r + ";\n return ivec3(r, c, d);\n }\n "; + }function getOutput4DCoords(e, t) { + var n = e[3], + r = e[2] * n, + o = e[1] * r;return "\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n\n int r = index / " + o + ";\n index -= r * " + o + ";\n\n int c = index / " + r + ";\n index -= c * " + r + ";\n\n int d = index / " + n + ";\n int d2 = index - d * " + n + ";\n\n return ivec4(r, c, d, d2);\n }\n "; + }function getOutput5DCoords(e, t) { + var n = e[4], + r = e[3] * n, + o = e[2] * r, + a = e[1] * o;return "\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(" + t[0] + ",\n " + t[1] + "));\n\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n\n int r = index / " + a + ";\n index -= r * " + a + ";\n\n int c = index / " + o + ";\n index -= c * " + o + ";\n\n int d = index / " + r + ";\n index -= d * " + r + ";\n\n int d2 = index / " + n + ";\n int d3 = index - d2 * " + n + ";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "; + }function getOutput6DCoords(e, t) { + var n = e[5], + r = e[4] * n, + o = e[3] * r, + a = e[2] * o, + i = e[1] * a;return "\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n\n int r = index / " + i + ";\n index -= r * " + i + ";\n\n int c = index / " + a + ";\n index -= c * " + a + ";\n\n int d = index / " + o + ";\n index -= d * " + o + ";\n\n int d2 = index / " + r + ";\n index -= d2 * " + r + ";\n\n int d3 = index / " + n + ";\n int d4 = index - d3 * " + n + ";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "; + }function getOutput2DCoords(e, t) { + return arraysEqual(e, t) ? "\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2(" + t[0] + ", " + t[1] + "));\n }\n " : 1 === e[1] ? "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n return ivec2(index, 0);\n }\n " : 1 === e[0] ? "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n return ivec2(0, index);\n }\n " : "\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + t[0] + ", " + t[1] + "));\n int index = resTexRC.x * " + t[1] + " + resTexRC.y;\n int r = index / " + e[1] + ";\n int c = index - r * " + e[1] + ";\n return ivec2(r, c);\n }\n "; + }function getSamplerScalar(e) { + var t = e.name, + n = "get" + t.charAt(0).toUpperCase() + t.slice(1);return e.shapeInfo.isUniform ? "float " + n + "() {return " + t + ";}" : "\n float " + n + "() {\n return sampleTexture(" + t + ", halfCR);\n }\n "; + }function getSampler1D(e) { + var t = e.name, + n = "get" + t.charAt(0).toUpperCase() + t.slice(1);return "\n float " + n + "(int index) {\n return " + n + "Flat(index);\n }\n "; + }function getSampler2D(e) { + var t = e.shapeInfo.logicalShape, + n = e.name, + r = "get" + n.charAt(0).toUpperCase() + n.slice(1), + o = e.shapeInfo.texShape;if (null != o && arraysEqual(t, o)) { + var a = o[0];return "\n float " + r + "(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2(" + o[1] + ".0, " + a + ".0);\n return sampleTexture(" + n + ", uv);\n }\n "; + }var i = squeezeShape(t), + s = i.newShape, + u = i.keptDims, + l = s;if (l.length < t.length) { + return "\n " + getSamplerFromInInfo(squeezeInputInfo(e, l)) + "\n float " + r + "(int row, int col) {\n return " + r + "(" + getSqueezedParams(["row", "col"], u) + ");\n }\n "; + }if (e.shapeInfo.isUniform) return "\n float " + r + "(int row, int col) {\n int index = row * " + t[1] + " + col;\n return " + r + "Flat(index);\n }\n ";var c = o[0], + p = o[1];return 1 === p ? "\n float " + r + "(int row, int col) {\n int index = row * " + t[1] + " + col;\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + c + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : 1 === c ? "\n float " + r + "(int row, int col) {\n int index = row * " + t[1] + " + col;\n vec2 uv = vec2((float(index) + 0.5) / " + p + ".0, 0.5);\n return sampleTexture(" + n + ", uv);\n }\n " : "\n float " + r + "(int row, int col) {\n vec2 uv = UVfrom2D(" + c + ", " + p + ", " + t[1] + ", row, col);\n return sampleTexture(" + n + ", uv);\n }\n"; + }function getSampler3D(e) { + var t = e.shapeInfo.logicalShape, + n = e.name, + r = "get" + n.charAt(0).toUpperCase() + n.slice(1), + o = t[1] * t[2], + a = t[2], + i = squeezeShape(t), + s = i.newShape, + u = i.keptDims, + l = s;if (l.length < t.length) { + return "\n " + getSamplerFromInInfo(squeezeInputInfo(e, l)) + "\n float " + r + "(int row, int col, int depth) {\n return " + r + "(" + getSqueezedParams(["row", "col", "depth"], u) + ");\n }\n "; + }if (e.shapeInfo.isUniform) return "\n float " + r + "(int row, int col, int depth) {\n int index = row * " + o + " + col * " + a + " + depth;\n return " + r + "Flat(index);\n }\n ";var c = e.shapeInfo.texShape, + p = c[0], + d = c[1];return d === o ? "\n float " + r + "(int row, int col, int depth) {\n int texR = row;\n int texC = col * " + a + " + depth;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + d + ".0, " + p + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : d === a ? "\n float " + r + "(int row, int col, int depth) {\n int texR = row * " + t[1] + " + col;\n int texC = depth;\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + d + ".0, " + p + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : "\n float " + r + "(int row, int col, int depth) {\n vec2 uv = UVfrom3D(\n " + p + ", " + d + ", " + o + ", " + a + ", row, col, depth);\n return sampleTexture(" + n + ", uv);\n }\n "; + }function getSampler4D(e) { + var t = e.shapeInfo.logicalShape, + n = e.name, + r = "get" + n.charAt(0).toUpperCase() + n.slice(1), + o = t[3], + a = t[2] * o, + i = t[1] * a, + s = squeezeShape(t), + u = s.newShape, + l = s.keptDims;if (u.length < t.length) { + return "\n " + getSamplerFromInInfo(squeezeInputInfo(e, u)) + "\n float " + r + "(int row, int col, int depth, int depth2) {\n return " + r + "(" + getSqueezedParams(["row", "col", "depth", "depth2"], l) + ");\n }\n "; + }if (e.shapeInfo.isUniform) return "\n float " + r + "(int row, int col, int depth, int depth2) {\n int index = row * " + i + " + col * " + a + " +\n depth * " + o + " + depth2;\n return " + r + "Flat(index);\n }\n ";var c = e.shapeInfo.texShape, + p = c[0], + d = c[1];return d === i ? "\n float " + r + "(int row, int col, int depth, int depth2) {\n int texR = row;\n int texC = col * " + a + " + depth * " + o + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + d + ".0, " + p + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : d === o ? "\n float " + r + "(int row, int col, int depth, int depth2) {\n int texR = row * " + t[1] * t[2] + " + col * " + t[2] + " + depth;\n int texC = depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + d + ".0, " + p + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : "\n float " + r + "(int row, int col, int depth, int depth2) {\n vec2 uv = UVfrom4D(" + p + ", " + d + ", " + i + ", " + a + ",\n " + o + ", row, col, depth, depth2);\n return sampleTexture(" + n + ", uv);\n }\n "; + }function getSampler5D(e) { + var t = e.shapeInfo.logicalShape, + n = e.name, + r = "get" + n.charAt(0).toUpperCase() + n.slice(1), + o = t[4], + a = t[3] * o, + i = t[2] * a, + s = t[1] * i, + u = squeezeShape(t), + l = u.newShape, + c = u.keptDims;if (l.length < t.length) { + return "\n " + getSamplerFromInInfo(squeezeInputInfo(e, l)) + "\n float " + r + "(int row, int col, int depth, int depth2, int depth3) {\n return " + r + "(" + getSqueezedParams(["row", "col", "depth", "depth2", "depth3"], c) + ");\n }\n "; + }if (e.shapeInfo.isUniform) return "\n float " + r + "(int row, int col, int depth, int depth2, int depth3) {\n int index = row * " + s + " + col * " + i + " +\n depth * " + a + " + depth2 * " + o + " + depth3;\n return " + r + "Flat(index);\n }\n ";var p = e.shapeInfo.texShape, + d = p[0], + h = p[1];return h === s ? "\n float " + r + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row;\n int texC = col * " + i + " + depth * " + a + " +\n depth2 * " + o + " + depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + h + ".0, " + d + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : h === o ? "\n float " + r + "(int row, int col, int depth, int depth2, int depth3) {\n int texR = row * " + t[1] * t[2] + " + col * " + t[2] + " +\n depth * " + t[3] + " + depth2;\n int texC = depth3;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + h + ".0, " + d + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : "\n float " + r + "(int row, int col, int depth, int depth2, int depth3) {\n vec2 uv = UVfrom5D(" + d + ", " + h + ", " + s + ", " + i + ",\n " + a + ", " + o + ", row, col, depth, depth2, depth3);\n return sampleTexture(" + n + ", uv);\n }\n "; + }function getSampler6D(e) { + var t = e.shapeInfo.logicalShape, + n = e.name, + r = "get" + n.charAt(0).toUpperCase() + n.slice(1), + o = t[5], + a = t[4] * o, + i = t[3] * a, + s = t[2] * i, + u = t[1] * s, + l = squeezeShape(t), + c = l.newShape, + p = l.keptDims;if (c.length < t.length) { + return "\n " + getSamplerFromInInfo(squeezeInputInfo(e, c)) + "\n float " + r + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n return " + r + "(" + getSqueezedParams(["row", "col", "depth", "depth2", "depth3", "depth4"], p) + ");\n }\n "; + }if (e.shapeInfo.isUniform) return "\n float " + r + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int index = row * " + u + " + col * " + s + " +\n depth * " + i + " + depth2 * " + a + " + depth3 * " + a + "\n + depth4\n return " + r + "Flat(index);\n }\n ";var d = e.shapeInfo.texShape, + h = d[0], + f = d[1];return f === u ? "\n float " + r + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row;\n int texC = col * " + s + " + depth * " + i + " + depth2;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + f + ".0, " + h + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : f === o ? "\n float " + r + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n int texR = row * " + t[1] * t[2] + " + col * " + t[2] + " + depth;\n int texC = depth4;\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + f + ".0, " + h + ".0);\n return sampleTexture(" + n + ", uv);\n }\n " : "\n float " + r + "(int row, int col, int depth,\n int depth2, int depth3, int depth4) {\n vec2 uv = UVfrom6D(" + h + ", " + f + ", " + u + ", " + s + ",\n " + i + ", " + a + ", " + o + "\n ,row, col, depth, depth2, depth3, depth4);\n return sampleTexture(" + n + ", uv);\n }\n "; + }function getSamplerFlat(e) { + var t = e.name, + n = "get" + t.charAt(0).toUpperCase() + t.slice(1) + "Flat", + r = sizeFromShape(e.shapeInfo.logicalShape);if (e.shapeInfo.isUniform) return 1 === r ? "float " + n + "(int index) {return " + t + ";}" : "\n float " + n + "(int index) {\n for (int i = 0; i < " + r + "; i++) {\n if (i == index) {\n return " + t + "[i];\n }\n }\n }\n ";var o = e.shapeInfo.texShape, + a = o[0], + i = o[1];return 1 === i && 1 === a ? "\n float " + n + "(int index) {\n return sampleTexture(" + t + ", halfCR);\n }\n " : 1 === i ? "\n float " + n + "(int index) {\n vec2 uv = vec2(0.5, (float(index) + 0.5) / " + a + ".0);\n return sampleTexture(" + t + ", uv);\n }\n " : 1 === a ? "\n float " + n + "(int index) {\n vec2 uv = vec2((float(index) + 0.5) / " + i + ".0, 0.5);\n return sampleTexture(" + t + ", uv);\n }\n " : "\n float " + n + "(int index) {\n vec2 uv = UVfrom1D(" + a + ", " + i + ", index);\n return sampleTexture(" + t + ", uv);\n }\n "; + }function getBroadcastOutputCoordsSampler(e, t, n, r) { + var o = e.shapeInfo.logicalShape.length, + a = t.logicalShape.length, + i = "int";2 === a ? i = "ivec2" : 3 === a ? i = "ivec3" : 4 === a && (i = "ivec4");var s = getBroadcastDims(e.shapeInfo.logicalShape, t.logicalShape), + u = a - o;return "\n float " + r + "() {\n " + i + " coords = getOutputCoords();\n " + (0 === o ? "" : a < 2 && s.length >= 1 ? "coords = 0;" : s.map(function (e) { + return "coords[" + (e + u) + "] = 0;"; + }).join("\n")) + "\n return get" + n + "(" + (a < 2 && o > 0 ? "coords" : e.shapeInfo.logicalShape.map(function (e, t) { + return "coords[" + (t + u) + "]"; + }).join(", ")) + ");\n }\n "; + }function getSamplerAtOutputCoords(e, t, n) { + var r = e.name, + o = r.charAt(0).toUpperCase() + r.slice(1), + a = "get" + o + "AtOutCoords", + i = getBroadcastDims(e.shapeInfo.logicalShape, t.logicalShape), + s = e.shapeInfo.logicalShape.length, + u = t.logicalShape.length, + l = n && (u > s || i.length > 0), + c = broadcastDimsAreOuter(i), + p = e.shapeInfo.isUniform;if (l && !c) return getBroadcastOutputCoordsSampler(e, t, o, a);var d = sizeFromShape(e.shapeInfo.logicalShape), + h = "";l && c && (h = "\n int mainPart = index / " + d + ";\n index -= mainPart * " + d + ";\n ");var f = t.texShape;if (p) return 1 === d ? "float " + a + "() {return " + r + ";}" : "\n float " + a + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + f[0] + ", " + f[1] + "));\n int index = resTexRC.x * " + f[1] + " + resTexRC.y;\n " + h + "\n return get" + o + "Flat(index);\n }\n ";var m = e.shapeInfo.texShape;return arraysEqual(m, f) ? "\n float " + a + "() {\n return sampleTexture(" + r + ", resultUV);\n }\n " : "\n float " + a + "() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2(" + f[0] + ", " + f[1] + "));\n int index = resTexRC.x * " + f[1] + " + resTexRC.y;\n " + h + "\n int texR = index / " + m[1] + ";\n int texC = index - texR * " + m[1] + ";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2(" + m[1] + ".0, " + m[0] + ".0);\n\n return sampleTexture(" + r + ", uv);\n }\n "; + }function getCoordsDataType(e) { + if (e <= 1) return "int";if (2 === e) return "ivec2";if (3 === e) return "ivec3";if (4 === e) return "ivec4";if (5 === e) return "ivec5";if (6 === e) return "ivec6";throw Error("GPU for rank " + e + " is not yet supported"); + }function squeezeInputInfo(e, t) { + var n = JSON.parse(JSON.stringify(e));return n.shapeInfo.logicalShape = t, n; + }function getSqueezedParams(e, t) { + return t.map(function (t) { + return e[t]; + }).join(", "); + }var CumSumProgram = function () { + return function (e, t, n) { + this.variableNames = ["x"], this.outputShape = e;var r = e.length, + o = e[e.length - 1], + a = n ? "<" : ">";this.userCode = "\n int getIndex(int i) {\n " + (n ? "return " + o + " -i - 1;" : "return i;") + "\n }\n\n void main() {\n " + getCoordsDataType(r) + " coords = getOutputCoords();\n int end = " + getFinalCoord(r, "coords") + ";\n float val = 0.0;\n for (int i = " + o + " - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx " + a + " end) {\n continue;\n }\n if (idx == end && " + t + ") {\n continue;\n }\n " + getFinalCoord(r, "coords") + " = idx;\n val += getX(" + getCoords(r, "coords") + ");\n }\n setOutput(val);\n }\n "; + }; + }();function getCoords(e, t) { + if (1 === e) return "" + t;if (2 === e) return t + ".x, " + t + ".y";if (3 === e) return t + ".x, " + t + ".y, " + t + ".z";if (4 === e) return t + ".x, " + t + ".y, " + t + ".z, " + t + ".w";throw Error("Cumulative sum for rank " + e + " is not yet supported"); + }function getFinalCoord(e, t) { + if (1 === e) return "" + t;if (2 === e) return t + ".y";if (3 === e) return t + ".z";if (4 === e) return t + ".w";throw Error("Cumulative sum for rank " + e + " is not yet supported"); + }var TextureUsage, + PhysicalTextureType, + EncodeFloatProgram = function () { + return function (e) { + this.variableNames = ["A"], this.outputShape = e, this.userCode = "\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "; + }; + }(), + FromPixelsProgram = function () { + return function (e) { + this.variableNames = ["A"];var t = e[0], + n = e[1];this.outputShape = e, this.userCode = "\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(" + n + ".0, " + t + ".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "; + }; + }(), + GatherProgram = function () { + return function (e, t, n) { + this.variableNames = ["A", "indices"];var r = e.slice();r[n] = t, this.outputShape = r, this.rank = r.length;var o = getCoordsDataType(this.rank), + a = getSourceCoords(e, n);this.userCode = "\n void main() {\n " + o + " resRC = getOutputCoords();\n setOutput(getA(" + a + "));\n }\n "; + }; + }();function getSourceCoords(e, t) { + var n = e.length;if (n > 4) throw Error("Gather for rank " + n + " is not yet supported");if (1 === n) return "int(getIndices(resRC))";for (var r = ["resRC.x", "resRC.y", "resRC.z", "resRC.w"], o = [], a = 0; a < e.length; a++) a === t ? o.push("int(getIndices(" + r[a] + "))") : o.push("" + r[a]);return o.join(); + }function getUnpackedMatrixTextureShapeWidthHeight(e, t) { + return [t, e]; + }function getUnpackedArraySizeFromMatrixSize(e, t) { + return e * t; + }function getMatrixSizeFromUnpackedArraySize(e, t) { + if (e % t != 0) throw new Error("unpackedSize (" + e + ") must be a multiple of " + t);return e / t; + }function encodeMatrixToUnpackedArray(e, t, n) { + var r = getUnpackedArraySizeFromMatrixSize(e.length, n);if (t.length < r) throw new Error("unpackedArray length (" + t.length + ") must be >= " + r);for (var o = 0, a = 0; a < e.length; ++a) t[o] = e[a], o += n; + }function decodeMatrixFromUnpackedArray(e, t, n) { + var r = getMatrixSizeFromUnpackedArraySize(e.length, n);if (t.length < r) throw new Error("matrix length (" + t.length + ") must be >= " + r);for (var o = 0, a = 0; a < e.length; a += n) t[o++] = e[a]; + }function getPackedMatrixTextureShapeWidthHeight(e, t) { + return [Math.ceil(t / 2), Math.ceil(e / 2)]; + }function getPackedRGBAArraySizeFromMatrixShape(e, t) { + var n = getPackedMatrixTextureShapeWidthHeight(e, t);return n[0] * n[1] * 4; + }function encodeMatrixToPackedRGBA(e, t, n, r) { + var o = getPackedRGBAArraySizeFromMatrixShape(t, n);if (r.length < o) throw new Error("packedRGBA length (" + r.length + ") must be >= " + o);for (var a = getPackedMatrixTextureShapeWidthHeight(t, n), i = a[0], s = a[1], u = n % 2 == 1, l = t % 2 == 1, c = Math.floor(n / 2), p = Math.floor(t / 2), d = u ? 4 : 0, h = n, f = 0, m = 0; m < p; ++m) { + for (var g = 2 * m * n, v = 0; v < c; ++v) { + var y = g + 2 * v;r[f] = e[y], r[f + 1] = e[y + 1], r[f + 2] = e[y + h], r[f + 3] = e[y + h + 1], f += 4; + }f += d; + }if (u) { + y = n - 1, f = 4 * (i - 1);var x = 2 * n;for (d = 4 * i, m = 0; m < p; ++m) r[f] = e[y], r[f + 2] = e[y + n], y += x, f += d; + }if (l) for (y = (t - 1) * n, f = (s - 1) * i * 4, v = 0; v < c; ++v) r[f++] = e[y++], r[f++] = e[y++], f += 2;return u && l && (r[r.length - 4] = e[e.length - 1]), r; + }function decodeMatrixFromPackedRGBA(e, t, n, r) { + var o = t * n;if (o < r.length) throw new Error("matrix length (" + r.length + ") must be >= " + o);for (var a = n % 2 == 1, i = t % 2 == 1, s = Math.floor(n / 2), u = Math.floor(t / 2), l = getPackedMatrixTextureShapeWidthHeight(t, n), c = l[0], p = l[1], d = a ? 4 : 0, h = n + (a ? 1 : 0), f = 0, m = 0, g = n, v = 0; v < u; ++v) { + for (var y = 0; y < s; ++y) r[m++] = e[f++], r[m++] = e[f++], r[g++] = e[f++], r[g++] = e[f++];f += d, m += h, g += h; + }if (a) { + f = 4 * (c - 1);var x = n - 1;for (d = 4 * c, h = 2 * n, v = 0; v < u; ++v) r[x] = e[f], r[x + n] = e[f + 2], f += d, x += h; + }if (i) for (f = (p - 1) * c * 4, x = (t - 1) * n, y = 0; y < s; ++y) r[x++] = e[f++], r[x++] = e[f++], f += 2;return a && i && (r[r.length - 1] = e[e.length - 4]), r; + }!function (e) { + e[e.RENDER = 0] = "RENDER", e[e.UPLOAD = 1] = "UPLOAD", e[e.PIXELS = 2] = "PIXELS", e[e.DOWNLOAD = 3] = "DOWNLOAD"; + }(TextureUsage || (TextureUsage = {})), function (e) { + e[e.FLOAT16 = 0] = "FLOAT16", e[e.FLOAT32 = 1] = "FLOAT32", e[e.UNSIGNED_BYTE = 2] = "UNSIGNED_BYTE"; + }(PhysicalTextureType || (PhysicalTextureType = {}));var MAX_TEXTURE_SIZE = null;function createWebGLRenderingContext(e) { + var t = document.createElement("canvas");return t.width = 1, t.height = 1, createWebGLRenderingContextFromCanvas(t, e); + }function createWebGLRenderingContextFromCanvas(e, t) { + var n, + r = ENV.get("WEBGL_VERSION");if (2 === r ? n = e.getContext("webgl2", t) : 1 === r && (n = e.getContext("webgl", t) || e.getContext("experimental-webgl", t)), 0 === r || null == n) throw new Error("This browser does not support WebGL.");return n; + }function callAndCheck(e, t) { + var n = t();return checkWebGLError(e), n; + }var webGLDebugErrorCheckingEnabled = !1;function enableDebugWebGLErrorChecking(e) { + webGLDebugErrorCheckingEnabled = e; + }function checkWebGLError(e) { + if (webGLDebugErrorCheckingEnabled) { + var t = e.getError();if (t !== e.NO_ERROR) throw new Error("WebGL Error: " + getWebGLErrorMessage(e, t)); + } + }function getWebGLErrorMessage(e, t) { + switch (t) {case e.NO_ERROR: + return "NO_ERROR";case e.INVALID_ENUM: + return "INVALID_ENUM";case e.INVALID_VALUE: + return "INVALID_VALUE";case e.INVALID_OPERATION: + return "INVALID_OPERATION";case e.INVALID_FRAMEBUFFER_OPERATION: + return "INVALID_FRAMEBUFFER_OPERATION";case e.OUT_OF_MEMORY: + return "OUT_OF_MEMORY";case e.CONTEXT_LOST_WEBGL: + return "CONTEXT_LOST_WEBGL";default: + return "Unknown error code " + t;} + }function getExtensionOrThrow(e, t) { + return throwIfNull(e, function () { + return e.getExtension(t); + }, 'Extension "' + t + '" not supported on this browser.'); + }function createVertexShader(e, t) { + var n = throwIfNull(e, function () { + return e.createShader(e.VERTEX_SHADER); + }, "Unable to create vertex WebGLShader.");if (callAndCheck(e, function () { + return e.shaderSource(n, t); + }), callAndCheck(e, function () { + return e.compileShader(n); + }), !1 === e.getShaderParameter(n, e.COMPILE_STATUS)) throw console.log(e.getShaderInfoLog(n)), new Error("Failed to compile vertex shader.");return n; + }function createFragmentShader(e, t) { + var n = throwIfNull(e, function () { + return e.createShader(e.FRAGMENT_SHADER); + }, "Unable to create fragment WebGLShader.");if (callAndCheck(e, function () { + return e.shaderSource(n, t); + }), callAndCheck(e, function () { + return e.compileShader(n); + }), !1 === e.getShaderParameter(n, e.COMPILE_STATUS)) throw logShaderSourceAndInfoLog(t, e.getShaderInfoLog(n)), new Error("Failed to compile fragment shader.");return n; + }var lineNumberRegex = /ERROR: [0-9]+:([0-9]+):/g;function logShaderSourceAndInfoLog(e, t) { + var n = lineNumberRegex.exec(t);if (null == n) return console.log("Couldn't parse line number in error: " + t), void console.log(e);for (var r = +n[1], o = e.split("\n"), a = o.length.toString().length + 2, i = o.map(function (e, t) { + return rightPad((t + 1).toString(), a) + e; + }), s = 0, u = 0; u < i.length; u++) s = Math.max(i[u].length, s);var l = i.slice(0, r - 1), + c = i.slice(r - 1, r), + p = i.slice(r);console.log(l.join("\n")), console.log(t.split("\n")[0]), console.log("%c " + rightPad(c[0], s), "border:1px solid red; background-color:#e3d2d2; color:#a61717"), console.log(p.join("\n")); + }function createProgram(e) { + return throwIfNull(e, function () { + return e.createProgram(); + }, "Unable to create WebGLProgram."); + }function linkProgram(e, t) { + if (callAndCheck(e, function () { + return e.linkProgram(t); + }), !1 === e.getProgramParameter(t, e.LINK_STATUS)) throw console.log(e.getProgramInfoLog(t)), new Error("Failed to link vertex and fragment shaders."); + }function validateProgram(e, t) { + if (callAndCheck(e, function () { + return e.validateProgram(t); + }), !1 === e.getProgramParameter(t, e.VALIDATE_STATUS)) throw console.log(e.getProgramInfoLog(t)), new Error("Shader program validation failed."); + }function createStaticVertexBuffer(e, t) { + var n = throwIfNull(e, function () { + return e.createBuffer(); + }, "Unable to create WebGLBuffer");return callAndCheck(e, function () { + return e.bindBuffer(e.ARRAY_BUFFER, n); + }), callAndCheck(e, function () { + return e.bufferData(e.ARRAY_BUFFER, t, e.STATIC_DRAW); + }), n; + }function createStaticIndexBuffer(e, t) { + var n = throwIfNull(e, function () { + return e.createBuffer(); + }, "Unable to create WebGLBuffer");return callAndCheck(e, function () { + return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, n); + }), callAndCheck(e, function () { + return e.bufferData(e.ELEMENT_ARRAY_BUFFER, t, e.STATIC_DRAW); + }), n; + }function queryMaxTextureSize(e) { + return null != MAX_TEXTURE_SIZE ? MAX_TEXTURE_SIZE : MAX_TEXTURE_SIZE = callAndCheck(e, function () { + return e.getParameter(e.MAX_TEXTURE_SIZE); + }); + }function getNumChannels() { + return 2 === ENV.get("WEBGL_VERSION") ? 1 : 4; + }function createTexture(e) { + return throwIfNull(e, function () { + return e.createTexture(); + }, "Unable to create WebGLTexture."); + }function validateTextureSize(e, t, n) { + var r = queryMaxTextureSize(e);if (t <= 0 || n <= 0) { + var o = "[" + t + "x" + n + "]";throw new Error("Requested texture size " + o + " is invalid."); + }if (t > r || n > r) { + o = "[" + t + "x" + n + "]";throw new Error("Requested texture size " + o + " greater than WebGL maximum on this browser / GPU " + ("[" + r + "x" + r + "]") + "."); + } + }function createFramebuffer(e) { + return throwIfNull(e, function () { + return e.createFramebuffer(); + }, "Unable to create WebGLFramebuffer."); + }function bindVertexBufferToProgramAttribute(e, t, n, r, o, a, i) { + var s = e.getAttribLocation(t, n);return -1 !== s && (callAndCheck(e, function () { + return e.bindBuffer(e.ARRAY_BUFFER, r); + }), callAndCheck(e, function () { + return e.vertexAttribPointer(s, o, e.FLOAT, !1, a, i); + }), callAndCheck(e, function () { + return e.enableVertexAttribArray(s); + }), !0); + }function bindTextureUnit(e, t, n) { + validateTextureUnit(e, n), callAndCheck(e, function () { + return e.activeTexture(e.TEXTURE0 + n); + }), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, t); + }); + }function unbindTextureUnit(e, t) { + validateTextureUnit(e, t), callAndCheck(e, function () { + return e.activeTexture(e.TEXTURE0 + t); + }), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, null); + }); + }function getProgramUniformLocationOrThrow(e, t, n) { + return throwIfNull(e, function () { + return e.getUniformLocation(t, n); + }, 'uniform "' + n + '" not present in program.'); + }function getProgramUniformLocation(e, t, n) { + return e.getUniformLocation(t, n); + }function bindTextureToProgramUniformSampler(e, t, n, r, o) { + callAndCheck(e, function () { + return bindTextureUnit(e, n, o); + }), callAndCheck(e, function () { + return e.uniform1i(r, o); + }); + }function bindCanvasToFramebuffer(e) { + callAndCheck(e, function () { + return e.bindFramebuffer(e.FRAMEBUFFER, null); + }), callAndCheck(e, function () { + return e.viewport(0, 0, e.canvas.width, e.canvas.height); + }), callAndCheck(e, function () { + return e.scissor(0, 0, e.canvas.width, e.canvas.height); + }); + }function bindColorTextureToFramebuffer(e, t, n) { + callAndCheck(e, function () { + return e.bindFramebuffer(e.FRAMEBUFFER, n); + }), callAndCheck(e, function () { + return e.framebufferTexture2D(e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, t, 0); + }); + }function unbindColorTextureFromFramebuffer(e, t) { + callAndCheck(e, function () { + return e.bindFramebuffer(e.FRAMEBUFFER, t); + }), callAndCheck(e, function () { + return e.framebufferTexture2D(e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, null, 0); + }); + }function validateFramebuffer(e) { + var t = e.checkFramebufferStatus(e.FRAMEBUFFER);if (t !== e.FRAMEBUFFER_COMPLETE) throw new Error("Error binding framebuffer: " + getFramebufferErrorMessage(e, t)); + }function getFramebufferErrorMessage(e, t) { + switch (t) {case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT: + return "FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: + return "FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS: + return "FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case e.FRAMEBUFFER_UNSUPPORTED: + return "FRAMEBUFFER_UNSUPPORTED";default: + return "unknown error " + t;} + }function throwIfNull(e, t, n) { + var r = callAndCheck(e, function () { + return t(); + });if (null == r) throw new Error(n);return r; + }function validateTextureUnit(e, t) { + var n = e.MAX_COMBINED_TEXTURE_IMAGE_UNITS - 1, + r = t + e.TEXTURE0;if (r < e.TEXTURE0 || r > n) throw new Error("textureUnit must be in " + ("[gl.TEXTURE0, gl.TEXTURE" + n + "]") + "."); + }function getTextureShapeFromLogicalShape(e, t) { + 2 !== t.length && (t = squeezeShape(t).newShape);var n = queryMaxTextureSize(e), + r = sizeFromShape(t);return t.length <= 1 && r <= n ? [r, 1] : 2 === t.length && t[0] <= n && t[1] <= n ? t : 3 === t.length && t[0] <= n && t[1] * t[2] <= n ? [t[0], t[1] * t[2]] : 4 === t.length && t[0] <= n && t[1] * t[2] * t[3] <= n ? [t[0], t[1] * t[2] * t[3]] : sizeToSquarishShape(r); + }var webgl_util = Object.freeze({ createWebGLRenderingContext: createWebGLRenderingContext, createWebGLRenderingContextFromCanvas: createWebGLRenderingContextFromCanvas, callAndCheck: callAndCheck, enableDebugWebGLErrorChecking: enableDebugWebGLErrorChecking, checkWebGLError: checkWebGLError, getWebGLErrorMessage: getWebGLErrorMessage, getExtensionOrThrow: getExtensionOrThrow, createVertexShader: createVertexShader, createFragmentShader: createFragmentShader, createProgram: createProgram, linkProgram: linkProgram, validateProgram: validateProgram, createStaticVertexBuffer: createStaticVertexBuffer, createStaticIndexBuffer: createStaticIndexBuffer, queryMaxTextureSize: queryMaxTextureSize, getNumChannels: getNumChannels, createTexture: createTexture, validateTextureSize: validateTextureSize, createFramebuffer: createFramebuffer, bindVertexBufferToProgramAttribute: bindVertexBufferToProgramAttribute, bindTextureUnit: bindTextureUnit, unbindTextureUnit: unbindTextureUnit, getProgramUniformLocationOrThrow: getProgramUniformLocationOrThrow, getProgramUniformLocation: getProgramUniformLocation, bindTextureToProgramUniformSampler: bindTextureToProgramUniformSampler, bindCanvasToFramebuffer: bindCanvasToFramebuffer, bindColorTextureToFramebuffer: bindColorTextureToFramebuffer, unbindColorTextureFromFramebuffer: unbindColorTextureFromFramebuffer, validateFramebuffer: validateFramebuffer, getFramebufferErrorMessage: getFramebufferErrorMessage, getTextureShapeFromLogicalShape: getTextureShapeFromLogicalShape });function getWebGLContextAttributes() { + return { alpha: !1, antialias: !1, premultipliedAlpha: !1, preserveDrawingBuffer: !1, depth: !1, stencil: !1, failIfMajorPerformanceCaveat: !0 }; + }function createWebGLContext(e) { + var t, + n = getWebGLContextAttributes();return callAndCheck(t = null != e ? createWebGLRenderingContextFromCanvas(e, n) : createWebGLRenderingContext(n), function () { + return t.disable(t.DEPTH_TEST); + }), callAndCheck(t, function () { + return t.disable(t.STENCIL_TEST); + }), callAndCheck(t, function () { + return t.disable(t.BLEND); + }), callAndCheck(t, function () { + return t.disable(t.DITHER); + }), callAndCheck(t, function () { + return t.disable(t.POLYGON_OFFSET_FILL); + }), callAndCheck(t, function () { + return t.disable(t.SAMPLE_COVERAGE); + }), callAndCheck(t, function () { + return t.enable(t.SCISSOR_TEST); + }), callAndCheck(t, function () { + return t.enable(t.CULL_FACE); + }), callAndCheck(t, function () { + return t.cullFace(t.BACK); + }), t; + }function createVertexShader$1(e) { + return createVertexShader(e, "\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }"); + }function createVertexBuffer(e) { + return createStaticVertexBuffer(e, new Float32Array([-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0])); + }function createIndexBuffer(e) { + return createStaticIndexBuffer(e, new Uint16Array([0, 1, 2, 2, 1, 3])); + }function getTextureConfig(e, t) { + var n, + r, + o, + a, + i, + s, + u, + l = e;return 2 === ENV.get("WEBGL_VERSION") ? (n = l.R32F, r = l.R16F, o = l.RGBA32F, a = l.RED, i = 4, s = 1, u = l.HALF_FLOAT) : (n = e.RGBA, r = e.RGBA, o = l.RGBA, a = e.RGBA, i = 4, s = 4, u = null != t ? t.HALF_FLOAT_OES : null), { internalFormatFloat: n, internalFormatHalfFloat: r, internalFormatPackedFloat: o, textureFormatFloat: a, downloadTextureFormat: e.RGBA, downloadUnpackNumChannels: i, defaultNumChannels: s, textureTypeHalfFloat: u }; + }function createAndConfigureTexture(e, t, n, r, o, a) { + validateTextureSize(e, t, n);var i = createTexture(e), + s = e.TEXTURE_2D;return callAndCheck(e, function () { + return e.bindTexture(s, i); + }), callAndCheck(e, function () { + return e.texParameteri(s, e.TEXTURE_WRAP_S, e.CLAMP_TO_EDGE); + }), callAndCheck(e, function () { + return e.texParameteri(s, e.TEXTURE_WRAP_T, e.CLAMP_TO_EDGE); + }), callAndCheck(e, function () { + return e.texParameteri(s, e.TEXTURE_MIN_FILTER, e.NEAREST); + }), callAndCheck(e, function () { + return e.texParameteri(s, e.TEXTURE_MAG_FILTER, e.NEAREST); + }), callAndCheck(e, function () { + return e.texImage2D(s, 0, r, t, n, 0, o, a, null); + }), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, null); + }), i; + }function createFloat32MatrixTexture(e, t, n, r) { + var o = getUnpackedMatrixTextureShapeWidthHeight(t, n);return createAndConfigureTexture(e, o[0], o[1], r.internalFormatFloat, r.textureFormatFloat, e.FLOAT); + }function createFloat16MatrixTexture(e, t, n, r) { + var o = getUnpackedMatrixTextureShapeWidthHeight(t, n);return createAndConfigureTexture(e, o[0], o[1], r.internalFormatFloat, r.textureFormatFloat, r.textureTypeHalfFloat); + }function createUnsignedBytesMatrixTexture(e, t, n, r) { + var o = getUnpackedMatrixTextureShapeWidthHeight(t, n);return createAndConfigureTexture(e, o[0], o[1], e.RGBA, e.RGBA, e.UNSIGNED_BYTE); + }function createPackedMatrixTexture(e, t, n, r) { + var o = getPackedMatrixTextureShapeWidthHeight(t, n);return createAndConfigureTexture(e, o[0], o[1], r.internalFormatPackedFloat, e.RGBA, e.FLOAT); + }function bindVertexProgramAttributeStreams(e, t, n) { + return callAndCheck(e, function () { + return e.bindBuffer(e.ARRAY_BUFFER, n); + }), bindVertexBufferToProgramAttribute(e, t, "clipSpacePos", n, 3, 20, 0) && bindVertexBufferToProgramAttribute(e, t, "uv", n, 2, 20, 12); + }function uploadPixelDataToTexture(e, t, n) { + callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, t); + }), callAndCheck(e, function () { + return e.texImage2D(e.TEXTURE_2D, 0, e.RGBA, e.RGBA, e.UNSIGNED_BYTE, n); + }), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, null); + }); + }function uploadDataToTexture(e, t, n, r, o, a) { + validateTextureSize(e, n, r), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, t); + }), callAndCheck(e, function () { + return e.texSubImage2D(e.TEXTURE_2D, 0, 0, 0, n, r, a, e.FLOAT, o); + }), callAndCheck(e, function () { + return e.bindTexture(e.TEXTURE_2D, null); + }); + }function uploadMatrixToTexture(e, t, n, r, o, a, i) { + var s, + u = getUnpackedMatrixTextureShapeWidthHeight(n, r), + l = u[0], + c = u[1];1 === i.defaultNumChannels ? s = o : encodeMatrixToUnpackedArray(o, s = new Float32Array(getUnpackedArraySizeFromMatrixSize(o.length, a)), a), uploadDataToTexture(e, t, l, c, s, i.textureFormatFloat); + }function uploadMatrixToPackedTexture(e, t, n, r, o, a) { + var i = getPackedMatrixTextureShapeWidthHeight(n, r), + s = i[0], + u = i[1], + l = new Float32Array(getPackedRGBAArraySizeFromMatrixShape(n, r));encodeMatrixToPackedRGBA(o, n, r, l), uploadDataToTexture(e, t, s, u, l, e.RGBA); + }function maybeCreateBufferFromOutputTexture(e, t, n, r, o) { + var a = t;if (2 === ENV.get("WEBGL_VERSION")) { + var i = e, + s = i.createBuffer();callAndCheck(e, function () { + return e.bindBuffer(i.PIXEL_PACK_BUFFER, s); + });var u = 4 * getUnpackedArraySizeFromMatrixSize(n * r, o.downloadUnpackNumChannels);callAndCheck(e, function () { + return e.bufferData(i.PIXEL_PACK_BUFFER, u, e.STATIC_DRAW); + }), callAndCheck(e, function () { + return i.readPixels(0, 0, r, n, e.RGBA, e.FLOAT, 0); + }), callAndCheck(e, function () { + return e.bindBuffer(i.PIXEL_PACK_BUFFER, null); + }), a = s; + }return a; + }function downloadFloat32MatrixFromBuffer(e, t, n, r, o) { + var a = e, + i = new Float32Array(getUnpackedArraySizeFromMatrixSize(n * r, o.downloadUnpackNumChannels));a.bindBuffer(e.ARRAY_BUFFER, t), a.getBufferSubData(e.ARRAY_BUFFER, 0, i), a.bindBuffer(e.ARRAY_BUFFER, null);var s = new Float32Array(n * r);return decodeMatrixFromUnpackedArray(i, s, o.downloadUnpackNumChannels), s; + }function downloadFloat32MatrixFromOutputTexture(e, t, n, r) { + var o = getUnpackedMatrixTextureShapeWidthHeight(t, n), + a = o[0], + i = o[1], + s = new Float32Array(getUnpackedArraySizeFromMatrixSize(t * n, r.downloadUnpackNumChannels));callAndCheck(e, function () { + return e.readPixels(0, 0, a, i, r.downloadTextureFormat, e.FLOAT, s); + });var u = new Float32Array(t * n);return decodeMatrixFromUnpackedArray(s, u, r.downloadUnpackNumChannels), u; + }function downloadByteEncodedFloatMatrixFromOutputTexture(e, t, n, r) { + var o = getUnpackedMatrixTextureShapeWidthHeight(t, n), + a = o[0], + i = o[1], + s = new Uint8Array(getUnpackedArraySizeFromMatrixSize(t * n, 4));return callAndCheck(e, function () { + return e.readPixels(0, 0, a, i, r.downloadTextureFormat, e.UNSIGNED_BYTE, s); + }), new Float32Array(s.buffer); + }function downloadMatrixFromPackedOutputTexture(e, t, n, r) { + var o = getPackedMatrixTextureShapeWidthHeight(t, n), + a = o[0], + i = o[1], + s = new Float32Array(getPackedRGBAArraySizeFromMatrixShape(t, n));callAndCheck(e, function () { + return e.readPixels(0, 0, a, i, e.RGBA, e.FLOAT, s); + });var u = new Float32Array(t * n);return decodeMatrixFromPackedRGBA(s, t, n, u); + }var gpgpu_util = Object.freeze({ getWebGLContextAttributes: getWebGLContextAttributes, createWebGLContext: createWebGLContext, createVertexShader: createVertexShader$1, createVertexBuffer: createVertexBuffer, createIndexBuffer: createIndexBuffer, getTextureConfig: getTextureConfig, createFloat32MatrixTexture: createFloat32MatrixTexture, createFloat16MatrixTexture: createFloat16MatrixTexture, createUnsignedBytesMatrixTexture: createUnsignedBytesMatrixTexture, createPackedMatrixTexture: createPackedMatrixTexture, bindVertexProgramAttributeStreams: bindVertexProgramAttributeStreams, uploadPixelDataToTexture: uploadPixelDataToTexture, uploadMatrixToTexture: uploadMatrixToTexture, uploadMatrixToPackedTexture: uploadMatrixToPackedTexture, maybeCreateBufferFromOutputTexture: maybeCreateBufferFromOutputTexture, downloadFloat32MatrixFromBuffer: downloadFloat32MatrixFromBuffer, downloadFloat32MatrixFromOutputTexture: downloadFloat32MatrixFromOutputTexture, downloadByteEncodedFloatMatrixFromOutputTexture: downloadByteEncodedFloatMatrixFromOutputTexture, downloadMatrixFromPackedOutputTexture: downloadMatrixFromPackedOutputTexture }), + GPGPUContext = function () { + function e(e) { + this.outputTexture = null, this.program = null, this.disposed = !1, this.autoDebugValidate = !1, this.vertexAttrsAreBound = !1, this.itemsToPoll = [], this.gl = null != e ? e : createWebGLContext(), 1 === ENV.get("WEBGL_VERSION") ? (this.textureFloatExtension = getExtensionOrThrow(this.gl, "OES_texture_float"), this.colorBufferFloatExtension = this.gl.getExtension("WEBGL_color_buffer_float"), ENV.get("WEBGL_RENDER_FLOAT32_ENABLED") || (this.textureHalfFloatExtension = getExtensionOrThrow(this.gl, "OES_texture_half_float"), this.colorBufferHalfFloatExtension = this.gl.getExtension("EXT_color_buffer_half_float"))) : this.colorBufferFloatExtension = getExtensionOrThrow(this.gl, "EXT_color_buffer_float"), this.loseContextExtension = getExtensionOrThrow(this.gl, "WEBGL_lose_context"), this.vertexBuffer = createVertexBuffer(this.gl), this.indexBuffer = createIndexBuffer(this.gl), this.framebuffer = createFramebuffer(this.gl), this.textureConfig = getTextureConfig(this.gl, this.textureHalfFloatExtension); + }return e.prototype.dispose = function () { + var e = this;if (!this.disposed) { + null != this.program && console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."), null != this.outputTexture && console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");var t = this.gl;callAndCheck(t, function () { + return t.finish(); + }), callAndCheck(t, function () { + return t.bindFramebuffer(t.FRAMEBUFFER, null); + }), callAndCheck(t, function () { + return t.deleteFramebuffer(e.framebuffer); + }), callAndCheck(t, function () { + return t.bindBuffer(t.ARRAY_BUFFER, null); + }), callAndCheck(t, function () { + return t.deleteBuffer(e.vertexBuffer); + }), callAndCheck(t, function () { + return t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, null); + }), callAndCheck(t, function () { + return t.deleteBuffer(e.indexBuffer); + }), this.loseContextExtension.loseContext(), this.disposed = !0; + } + }, e.prototype.enableAutomaticDebugValidation = function (e) { + this.autoDebugValidate = e, enableDebugWebGLErrorChecking(e); + }, e.prototype.createFloat32MatrixTexture = function (e, t) { + return this.throwIfDisposed(), createFloat32MatrixTexture(this.gl, e, t, this.textureConfig); + }, e.prototype.createFloat16MatrixTexture = function (e, t) { + return this.throwIfDisposed(), createFloat16MatrixTexture(this.gl, e, t, this.textureConfig); + }, e.prototype.createUnsignedBytesMatrixTexture = function (e, t) { + return this.throwIfDisposed(), createUnsignedBytesMatrixTexture(this.gl, e, t, this.textureConfig); + }, e.prototype.uploadPixelDataToTexture = function (e, t) { + this.throwIfDisposed(), uploadPixelDataToTexture(this.gl, e, t); + }, e.prototype.createPackedMatrixTexture = function (e, t) { + return this.throwIfDisposed(), createPackedMatrixTexture(this.gl, e, t, this.textureConfig); + }, e.prototype.deleteMatrixTexture = function (e) { + var t = this;this.throwIfDisposed(), this.outputTexture === e && (unbindColorTextureFromFramebuffer(this.gl, this.framebuffer), this.outputTexture = null), callAndCheck(this.gl, function () { + return t.gl.deleteTexture(e); + }); + }, e.prototype.uploadMatrixToTexture = function (e, t, n, r) { + this.throwIfDisposed();var o = getNumChannels();return uploadMatrixToTexture(this.gl, e, t, n, r, o, this.textureConfig); + }, e.prototype.uploadMatrixToPackedTexture = function (e, t, n, r) { + return this.throwIfDisposed(), uploadMatrixToPackedTexture(this.gl, e, t, n, r, this.textureConfig); + }, e.prototype.downloadFloat32MatrixFromOutputTexture = function (e, t, n) { + var r = this;return this.downloadMatrixDriver(e, function () { + return downloadFloat32MatrixFromOutputTexture(r.gl, t, n, r.textureConfig); + }); + }, e.prototype.downloadByteEncodedFloatMatrixFromOutputTexture = function (e, t, n) { + var r = this;return this.downloadMatrixDriver(e, function () { + return downloadByteEncodedFloatMatrixFromOutputTexture(r.gl, t, n, r.textureConfig); + }); + }, e.prototype.downloadFloat32MatrixFromBuffer = function (e, t, n) { + return downloadFloat32MatrixFromBuffer(this.gl, e, t, n, this.textureConfig); + }, e.prototype.maybeCreateBufferFromTexture = function (e, t, n) { + this.bindTextureToFrameBuffer(e);var r = maybeCreateBufferFromOutputTexture(this.gl, e, t, n, this.textureConfig);return this.unbindTextureToFrameBuffer(), r; + }, e.prototype.createAndWaitForFence = function () { + var e = this.createFence(this.gl);return this.pollFence(e); + }, e.prototype.createFence = function (e) { + var t, + n, + r = this;if (ENV.get("WEBGL_FENCE_API_ENABLED")) { + var o = e, + a = o.fenceSync(o.SYNC_GPU_COMMANDS_COMPLETE, 0);e.flush(), n = function () { + var e = o.clientWaitSync(a, 0, 0);return e === o.ALREADY_SIGNALED || e === o.CONDITION_SATISFIED; + }, t = a; + } else ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") > 0 ? (t = this.beginQuery(), this.endQuery(), n = function () { + return r.isQueryAvailable(t, ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")); + }) : n = function () { + return !0; + };return { query: t, isFencePassed: n }; + }, e.prototype.downloadMatrixFromPackedTexture = function (e, t, n) { + var r = this;return this.downloadMatrixDriver(e, function () { + return downloadMatrixFromPackedOutputTexture(r.gl, t, n, r.textureConfig); + }); + }, e.prototype.createProgram = function (e) { + this.throwIfDisposed();var t = this.gl, + n = createFragmentShader(t, e), + r = createVertexShader$1(t), + o = createProgram(t);return callAndCheck(t, function () { + return t.attachShader(o, r); + }), callAndCheck(t, function () { + return t.attachShader(o, n); + }), linkProgram(t, o), this.autoDebugValidate && validateProgram(t, o), this.vertexAttrsAreBound || (this.setProgram(o), this.vertexAttrsAreBound = bindVertexProgramAttributeStreams(t, this.program, this.vertexBuffer)), o; + }, e.prototype.deleteProgram = function (e) { + var t = this;this.throwIfDisposed(), e === this.program && (this.program = null), null != e && callAndCheck(this.gl, function () { + return t.gl.deleteProgram(e); + }); + }, e.prototype.setProgram = function (e) { + var t = this;this.throwIfDisposed(), this.program = e, null != this.program && this.autoDebugValidate && validateProgram(this.gl, this.program), callAndCheck(this.gl, function () { + return t.gl.useProgram(e); + }); + }, e.prototype.getUniformLocation = function (e, t, n) { + return void 0 === n && (n = !0), this.throwIfDisposed(), n ? getProgramUniformLocationOrThrow(this.gl, e, t) : getProgramUniformLocation(this.gl, e, t); + }, e.prototype.getAttributeLocation = function (e, t) { + var n = this;return this.throwIfDisposed(), callAndCheck(this.gl, function () { + return n.gl.getAttribLocation(e, t); + }); + }, e.prototype.getUniformLocationNoThrow = function (e, t) { + return this.throwIfDisposed(), this.gl.getUniformLocation(e, t); + }, e.prototype.setInputMatrixTexture = function (e, t, n) { + this.throwIfDisposed(), this.throwIfNoProgram(), bindTextureToProgramUniformSampler(this.gl, this.program, e, t, n); + }, e.prototype.setOutputMatrixTexture = function (e, t, n) { + this.setOutputMatrixTextureDriver(e, n, t); + }, e.prototype.setOutputPackedMatrixTexture = function (e, t, n) { + this.throwIfDisposed();var r = getPackedMatrixTextureShapeWidthHeight(t, n), + o = r[0], + a = r[1];this.setOutputMatrixTextureDriver(e, o, a); + }, e.prototype.setOutputMatrixWriteRegion = function (e, t, n, r) { + this.setOutputMatrixWriteRegionDriver(n, e, r, t); + }, e.prototype.setOutputPackedMatrixWriteRegion = function (e, t, n, r) { + throw new Error("setOutputPackedMatrixWriteRegion not implemented."); + }, e.prototype.debugValidate = function () { + null != this.program && validateProgram(this.gl, this.program), validateFramebuffer(this.gl); + }, e.prototype.executeProgram = function () { + this.throwIfDisposed(), this.throwIfNoProgram();var e = this.gl;this.autoDebugValidate && this.debugValidate(), callAndCheck(e, function () { + return e.drawElements(e.TRIANGLES, 6, e.UNSIGNED_SHORT, 0); + }); + }, e.prototype.blockUntilAllProgramsCompleted = function () { + var e = this;this.throwIfDisposed(), callAndCheck(this.gl, function () { + return e.gl.finish(); + }); + }, e.prototype.getQueryTimerExtension = function () { + return null == this.disjointQueryTimerExtension && (this.disjointQueryTimerExtension = getExtensionOrThrow(this.gl, 2 === ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") ? "EXT_disjoint_timer_query_webgl2" : "EXT_disjoint_timer_query")), this.disjointQueryTimerExtension; + }, e.prototype.getQueryTimerExtensionWebGL2 = function () { + return this.getQueryTimerExtension(); + }, e.prototype.getQueryTimerExtensionWebGL1 = function () { + return this.getQueryTimerExtension(); + }, e.prototype.beginQuery = function () { + if (2 === ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")) { + var e = this.gl, + t = this.getQueryTimerExtensionWebGL2(), + n = e.createQuery();return e.beginQuery(t.TIME_ELAPSED_EXT, n), n; + }var r = this.getQueryTimerExtensionWebGL1(), + o = r.createQueryEXT();return r.beginQueryEXT(r.TIME_ELAPSED_EXT, o), o; + }, e.prototype.endQuery = function () { + if (2 !== ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")) { + var e = this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT); + } else { + var t = this.gl, + n = this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT); + } + }, e.prototype.waitForQueryAndGetTime = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t = this;return __generator(this, function (n) { + switch (n.label) {case 0: + return [4, repeatedTry(function () { + return t.isQueryAvailable(e, ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")); + })];case 1: + return n.sent(), [2, this.getQueryTime(e, ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))];} + }); + }); + }, e.prototype.getQueryTime = function (e, t) { + if (0 === t) return null;if (2 === t) { + var n = this.gl;return n.getQueryParameter(e, n.QUERY_RESULT) / 1e6; + }var r = this.getQueryTimerExtensionWebGL1();return r.getQueryObjectEXT(e, r.QUERY_RESULT_EXT) / 1e6; + }, e.prototype.isQueryAvailable = function (e, t) { + if (0 === t) return !0;if (2 === t) { + var n = this.gl, + r = this.getQueryTimerExtensionWebGL2(), + o = n.getQueryParameter(e, n.QUERY_RESULT_AVAILABLE);return null == this.disjoint && (this.disjoint = this.gl.getParameter(r.GPU_DISJOINT_EXT)), o && !this.disjoint; + }o = (r = this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(e, r.QUERY_RESULT_AVAILABLE_EXT);return null == this.disjoint && (this.disjoint = this.gl.getParameter(r.GPU_DISJOINT_EXT)), o && !this.disjoint; + }, e.prototype.pollFence = function (e) { + var t = this;return new Promise(function (n) { + t.addItemToPoll(function () { + return e.isFencePassed(); + }, function () { + return n(); + }); + }); + }, e.prototype.pollItems = function () { + for (var e = binSearchLastTrue(this.itemsToPoll.map(function (e) { + return e.isDoneFn; + })), t = 0; t <= e; ++t) { + (0, this.itemsToPoll[t].resolveFn)(); + }this.itemsToPoll = this.itemsToPoll.slice(e + 1); + }, e.prototype.addItemToPoll = function (e, t) { + var n = this;this.itemsToPoll.push({ isDoneFn: e, resolveFn: t }), this.itemsToPoll.length > 1 || repeatedTry(function () { + return n.pollItems(), 0 === n.itemsToPoll.length; + }); + }, e.prototype.bindTextureToFrameBuffer = function (e) { + this.throwIfDisposed(), bindColorTextureToFramebuffer(this.gl, e, this.framebuffer), this.autoDebugValidate && validateFramebuffer(this.gl); + }, e.prototype.unbindTextureToFrameBuffer = function () { + null != this.outputTexture ? (bindColorTextureToFramebuffer(this.gl, this.outputTexture, this.framebuffer), this.autoDebugValidate && validateFramebuffer(this.gl)) : unbindColorTextureFromFramebuffer(this.gl, this.framebuffer); + }, e.prototype.downloadMatrixDriver = function (e, t) { + this.bindTextureToFrameBuffer(e);var n = t();return this.unbindTextureToFrameBuffer(), n; + }, e.prototype.setOutputMatrixTextureDriver = function (e, t, n) { + this.throwIfDisposed();var r = this.gl;bindColorTextureToFramebuffer(r, e, this.framebuffer), this.autoDebugValidate && validateFramebuffer(r), this.outputTexture = e, callAndCheck(r, function () { + return r.viewport(0, 0, t, n); + }), callAndCheck(r, function () { + return r.scissor(0, 0, t, n); + }); + }, e.prototype.setOutputMatrixWriteRegionDriver = function (e, t, n, r) { + var o = this;this.throwIfDisposed(), callAndCheck(this.gl, function () { + return o.gl.scissor(e, t, n, r); + }); + }, e.prototype.throwIfDisposed = function () { + if (this.disposed) throw new Error("Attempted to use disposed GPGPUContext."); + }, e.prototype.throwIfNoProgram = function () { + if (null == this.program) throw new Error("No GPU program is currently set."); + }, e; + }();function binSearchLastTrue(e) { + for (var t = 0, n = e.length - 1, r = -1; t <= n;) { + var o = t + n >> 1;e[o]() ? (r = o, t = o + 1) : n = o - 1; + }return r; + }function compileProgram(e, t, n, r) { + for (var o = t.userCode, a = n.map(function (e, n) { + var r = { logicalShape: e.tensor.shape, texShape: e.isUniform ? null : e.texData.texShape, isUniform: e.isUniform };return { name: t.variableNames[n], shapeInfo: r }; + }), i = a.map(function (e) { + return e.shapeInfo; + }), s = { logicalShape: r.tensor.shape, texShape: r.texData.texShape, isUniform: !1 }, u = makeShader(a, s, o, !0 === t.supportsBroadcasting), l = e.createProgram(u), c = {}, p = 0; p < t.variableNames.length; p++) { + var d = t.variableNames[p];c[d] = e.getUniformLocation(l, d, !1); + }return { program: t, source: u, webGLProgram: l, uniformLocations: c, gpgpu: e, inShapeInfos: i, outShapeInfo: s }; + }function validateBinaryAndProgram(e, t) { + if (e.length !== t.length) throw Error("Binary was compiled with " + e.length + " inputs, but was executed with " + t.length + " inputs");e.forEach(function (e, n) { + var r = e.logicalShape, + o = t[n], + a = o.tensor.shape;if (!arraysEqual(r, a)) throw Error("Binary was compiled with different shapes than the current args. Shapes " + r + " and " + a + " must match");if (!e.isUniform || !o.isUniform) { + var i = e.texShape, + s = o.isUniform ? null : o.texData.texShape;if (!arraysEqual(i, s)) throw Error("Binary was compiled with different texture shapes than the current args. Shape " + i + " and " + s + " must match"); + } + }); + }function runProgram(e, t, n, r) { + validateBinaryAndProgram(e.inShapeInfos, t), validateBinaryAndProgram([e.outShapeInfo], [n]);var o = n.texData.texture, + a = n.texData.texShape, + i = e.gpgpu;i.setOutputMatrixTexture(o, a[0], a[1]), i.setProgram(e.webGLProgram), t.forEach(function (t, n) { + var r = e.program.variableNames[n], + o = e.uniformLocations[r];if (null != o) { + if (t.isUniform) { + if (1 === t.tensor.size) i.gl.uniform1f(o, t.tensor.dataSync()[0]);else { + var a = t.tensor.dataSync();a instanceof Float32Array || (a = new Float32Array(a)), i.gl.uniform1fv(o, a); + }return; + }var s = t.texData.texture;i.setInputMatrixTexture(s, o, n); + } + }), null != r && r(i, e.webGLProgram), i.executeProgram(); + }function makeShaderKey(e, t, n) { + var r = "";t.concat(n).forEach(function (e) { + r += e.tensor.shape + "_" + (e.isUniform ? "uniform" : e.texData.texShape); + });var o = e.userCode, + a = (!0 === e.supportsBroadcasting).toString(), + i = e.constructor.name;return i += "_" + a + "_" + r + "_" + o; + }var LRNProgram = function () { + return function (e, t, n, r, o) { + this.variableNames = ["x"], this.outputShape = [];var a, + i = t, + s = e[3] - 1;this.outputShape = e;var u = "float(" + n + ") + float(" + r + ") * sum";a = .5 === o ? "inversesqrt(" + u + ")" : 1 === o ? "1.0/(" + u + ")" : "exp(log(" + u + ") * float(-" + o + "));", this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n int d = coords[3];\n float x = getX(b, r, c, d);\n float sum = 0.0;\n for (int j = -" + i + "; j <= " + i + "; j++) {\n int idx = d + j;\n if (idx >= 0 && idx <= " + s + ") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * " + a + ";\n setOutput(val);\n }\n "; + }; + }(), + LRNGradProgram = function () { + return function (e, t, n, r, o) { + this.variableNames = ["inputImage", "outputImage", "dy"], this.outputShape = [], this.outputShape = e, this.depth = e[3], this.depthRadius = t, this.bias = n, this.alpha = r, this.beta = o, this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < " + this.depth + "; ++d) {\n int depthBegin = int(max(0.0, float(d - " + t + ")));\n int depthEnd = int(min(float(" + this.depth + "),\n float(d + " + t + " + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = " + this.depth + ";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float(" + r + ") * norm + float(" + n + ");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float(" + r + ")\n * float(" + o + ")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * " + o + ");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "; + }; + }(), + MaxPool2DBackpropProgram = function () { + return function (e) { + this.variableNames = ["dy", "maxPos"], this.outputShape = e.inShape;var t = e.filterHeight, + n = e.filterWidth, + r = e.strideHeight, + o = e.strideWidth, + a = t - 1 - e.padInfo.top, + i = n - 1 - e.padInfo.left, + s = t * n - 1;this.userCode = "\n const ivec2 pads = ivec2(" + a + ", " + i + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < " + t + "; wR++) {\n float dyR = float(dyRCorner + wR) / " + r + ".0;\n\n if (dyR < 0.0 || dyR >= " + e.outHeight + ".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < " + n + "; wC++) {\n float dyC = float(dyCCorner + wC) / " + o + ".0;\n\n if (dyC < 0.0 || dyC >= " + e.outWidth + ".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = " + s + " - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * " + n + " + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "; + }; + }(), + MatMulProgram = function () { + return function (e, t, n, r) { + void 0 === n && (n = !1), void 0 === r && (r = !1), this.variableNames = ["matrixA", "matrixB"];var o = n ? e[1] : e[0], + a = r ? t[0] : t[1], + i = n ? e[0] : e[1];this.outputShape = [o, a];var s = function (e, t) { + return n ? t + " + " + e + ", aRow" : "aRow, " + t + " + " + e; + }, + u = function (e, t) { + return r ? "bCol, " + t + " + " + e : t + " + " + e + ", bCol"; + }, + l = 4 * Math.floor(i / 4), + c = i % 4;this.userCode = " float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < " + l + "; i += 4) {\n vec4 a = vec4(\n getMatrixA(" + s(0, "i") + "),\n getMatrixA(" + s(1, "i") + "),\n getMatrixA(" + s(2, "i") + "),\n getMatrixA(" + s(3, "i") + ")\n );\n vec4 b = vec4(\n getMatrixB(" + u(0, "i") + "),\n getMatrixB(" + u(1, "i") + "),\n getMatrixB(" + u(2, "i") + "),\n getMatrixB(" + u(3, "i") + ")\n );\n\n result += dot(a, b);\n }\n\n if (" + (1 === c) + ") {\n result += getMatrixA(" + s(0, l) + ") *\n getMatrixB(" + u(0, l) + ");\n } else if (" + (2 === c) + ") {\n vec2 a = vec2(\n getMatrixA(" + s(0, l) + "),\n getMatrixA(" + s(1, l) + ")\n );\n vec2 b = vec2(\n getMatrixB(" + u(0, l) + "),\n getMatrixB(" + u(1, l) + ")\n );\n result += dot(a, b);\n } else if (" + (3 === c) + ") {\n vec3 a = vec3(\n getMatrixA(" + s(0, l) + "),\n getMatrixA(" + s(1, l) + "),\n getMatrixA(" + s(2, l) + ")\n );\n vec3 b = vec3(\n getMatrixB(" + u(0, l) + "),\n getMatrixB(" + u(1, l) + "),\n getMatrixB(" + u(2, l) + ")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "; + }; + }(), + MultinomialProgram = function () { + function e(e, t, n) { + this.variableNames = ["probs"], this.outputShape = [e, n], this.userCode = "\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < " + (t - 1) + "; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float(" + (t - 1) + "));\n }\n "; + }return e.prototype.getCustomSetupFunc = function (e) { + var t = this;return function (n, r) { + null == t.seedLoc && (t.seedLoc = n.getUniformLocation(r, "seed")), n.gl.uniform1f(t.seedLoc, e); + }; + }, e; + }(), + OneHotProgram = function () { + return function (e, t, n, r) { + this.variableNames = ["indices"], this.outputShape = [e, t], this.userCode = "\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float(" + r + "), float(" + n + "),\n float(index == coords.y)));\n }\n "; + }; + }(), + PadProgram = function () { + return function (e, t, n) { + this.variableNames = ["x"], this.outputShape = t.map(function (t, n) { + return t[0] + e[n] + t[1]; + });var r = e.length, + o = getCoordsDataType(r), + a = t.map(function (e) { + return e[0]; + }).join(","), + i = t.map(function (t, n) { + return t[0] + e[n]; + }).join(","), + s = ["coords[0]", "coords[1]", "coords[2]", "coords[3]"].slice(0, r);this.userCode = 1 !== r ? "\n " + o + " start = " + o + "(" + a + ");\n " + o + " end = " + o + "(" + i + ");\n\n void main() {\n " + o + " outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float(" + n + "));\n } else {\n " + o + " coords = outC - start;\n setOutput(getX(" + s + "));\n }\n }\n " : "\n int start = " + a + ";\n int end = " + i + ";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float(" + n + "));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "; + }; + }(), + Pool2DProgram = function () { + return function (e, t, n) { + if (this.variableNames = ["x"], "avg" === t && n) throw new Error("Cannot compute positions for average pool.");var r = e.filterHeight, + o = e.filterWidth, + a = e.strideHeight, + i = e.strideWidth, + s = e.padInfo.top, + u = e.padInfo.left;this.outputShape = e.outShape;var l = "avg" === t, + c = "0.0";if (l || (c = "-1.0 / 0.0"), n) this.userCode = "\n const ivec2 strides = ivec2(" + a + ", " + i + ");\n const ivec2 pads = ivec2(" + s + ", " + u + ");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < " + r + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + e.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + o + "; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= " + e.inWidth + ") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value >= currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * " + o + " + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n ";else { + var p = t + "(" + t + "(" + t + "(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"avg" === t && (p = "avgValue / count");var d = 4 * Math.floor(o / 4), + h = o % 4, + f = "\n if (" + l + ") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = max(values, minMaxValue);\n }\n ";this.userCode = "\n const ivec2 strides = ivec2(" + a + ", " + i + ");\n const ivec2 pads = ivec2(" + s + ", " + u + ");\n const float initializationValue = " + c + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= " + e.inWidth + ") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4(" + c + ");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < " + r + "; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= " + e.inHeight + ") {\n continue;\n }\n\n for (int wC = 0; wC < " + d + "; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n " + f + "\n }\n\n int xC = xCCorner + " + d + ";\n if (" + (1 === h) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + f + "\n } else if (" + (2 === h) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n " + f + "\n } else if (" + (3 === h) + ") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n " + f + "\n }\n }\n setOutput(" + p + ");\n }\n "; + } + }; + }(), + ReduceProgram = function () { + return function (e, t) { + this.variableNames = ["x"];var n = e.windowSize, + r = e.batchSize, + o = e.inSize, + a = Math.ceil(o / n);this.outputShape = [r, a];var i = "0.0", + s = "";"min" === t ? (i = "1.0 / 0.0", s = "min") : "max" === t && (i = "-1.0 / 0.0", s = "max");var u = t + "(" + t + "(" + t + "(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"sum" === t ? u = "sumValue" : "all" === t ? u = "allValue" : "any" === t && (u = "anyValue");var l = 4 * Math.floor(n / 4), + c = n % 4, + p = "\n if (" + ("sum" === t) + ") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = " + s + "(values, minMaxValue);\n }\n ", + d = "vec4";"all" === t ? (i = "1.0", p = "\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n ", d = "bvec4") : "any" === t && (i = "0.0", p = "\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n ", d = "bvec4");var h = "";o % n > 0 && (h = "\n if (inIdx < 0 || inIdx >= " + o + ") {\n return initializationValue;\n }\n "), this.userCode = "\n const float initializationValue = " + i + ";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n " + h + "\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * " + n + ";\n\n vec4 minMaxValue = vec4(" + i + ");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < " + l + "; i += 4) {\n int inIdx = inOffset + i;\n " + d + " values = " + d + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n " + p + "\n }\n\n int inIdx = inOffset + " + l + ";\n if (" + (1 === c) + ") {\n " + d + " values = " + d + "(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n " + p + "\n } else if (" + (2 === c) + ") {\n " + d + " values = " + d + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n " + p + "\n } else if (" + (3 === c) + ") {\n " + d + " values = " + d + "(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n " + p + "\n }\n setOutput(" + u + ");\n }\n "; + }; + }(), + ResizeBilinearBackpropProgram = function () { + return function (e, t, n) { + this.variableNames = ["dy"], this.outputShape = [], this.outputShape = t.shape;var r = t.shape, + o = r[1], + a = r[2], + i = e.shape, + s = i[1], + u = i[2], + l = [n && s > 1 ? o - 1 : o, n && u > 1 ? a - 1 : a], + c = [n && s > 1 ? s - 1 : s, n && u > 1 ? u - 1 : u], + p = l[0] / c[0], + d = l[1] / c[1], + h = 1 / p, + f = 1 / d, + m = 2 * Math.ceil(h) + 2, + g = 2 * Math.ceil(f) + 2;this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + p + ");\n const float widthScale = float(" + d + ");\n\n const float invHeightScale = float(" + h + ");\n const float invWidthScale = float(" + f + ");\n\n const int winHeight = int(" + m + ");\n const int winWidth = int(" + g + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + s + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + u + ") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), " + (o - 1) + ".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), " + (a - 1) + ".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + }; + }(), + ResizeBilinearProgram = function () { + return function (e, t, n, r) { + this.variableNames = ["A"], this.outputShape = [];var o = e[0], + a = e[1], + i = e[2], + s = e[3];this.outputShape = [o, t, n, s];var u = [r && t > 1 ? a - 1 : a, r && n > 1 ? i - 1 : i], + l = [r && t > 1 ? t - 1 : t, r && n > 1 ? n - 1 : n];this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + u[0] / l[0] + ",\n " + u[1] / l[1] + ");\n const vec2 inputShapeRC = vec2(" + a + ".0, " + i + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "; + }; + }(), + ResizeNearestNeigborBackpropProgram = function () { + return function (e, t, n) { + this.variableNames = ["dy"], this.outputShape = [], this.outputShape = t.shape;var r = t.shape, + o = r[1], + a = r[2], + i = e.shape, + s = i[1], + u = i[2], + l = [n && s > 1 ? o - 1 : o, n && u > 1 ? a - 1 : a], + c = [n && s > 1 ? s - 1 : s, n && u > 1 ? u - 1 : u], + p = l[0] / c[0], + d = l[1] / c[1], + h = 1 / p, + f = 1 / d, + m = 2 * Math.ceil(h) + 2, + g = 2 * Math.ceil(f) + 2;this.userCode = "\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float(" + p + ");\n const float widthScale = float(" + d + ");\n\n const float invHeightScale = float(" + h + ");\n const float invWidthScale = float(" + f + ");\n\n const int winHeight = int(" + m + ");\n const int winWidth = int(" + g + ");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= " + s + ") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= " + u + ") {\n continue;\n }\n\n float sourceFracRow =\n float(" + l[0] + ") *\n (float(dyR) / float(" + c[0] + "));\n\n float sourceFracCol =\n float(" + l[1] + ") *\n (float(dyC) / float(" + c[1] + "));\n\n int sourceNearestRow = int(min(\n float(int(" + o + ") - 1),\n " + n + " ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int(" + a + ") - 1),\n " + n + " ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "; + }; + }(), + ResizeNearestNeighborProgram = function () { + return function (e, t, n, r) { + this.variableNames = ["A"], this.outputShape = [];var o = e[0], + a = e[1], + i = e[2], + s = e[3];this.outputShape = [o, t, n, s];var u = [r && t > 1 ? a - 1 : a, r && n > 1 ? i - 1 : i], + l = [r && t > 1 ? t - 1 : t, r && n > 1 ? n - 1 : n], + c = r ? "0.5" : "0.0";this.userCode = "\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n " + u[0] / l[0] + ",\n " + u[1] / l[1] + ");\n const vec2 inputShapeRC = vec2(" + a + ".0, " + i + ".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + " + c + ")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "; + }; + }(), + ReverseProgram = function () { + return function (e, t) { + this.variableNames = ["x"];var n = e.length;if (n > 4) throw new Error("WebGL backend: Reverse of rank-" + n + " tensor is not yet supported");if (this.outputShape = e, 1 !== n) { + var r = e.map(function (n, r) { + return function (n) { + return -1 !== t.indexOf(n) && 1 !== e[n] ? e[n] + " - coords[" + n + "] - 1" : "coords[" + n + "]"; + }(r); + }).join(","), + o = getCoordsDataType(n);this.userCode = "\n void main() {\n " + o + " coords = getOutputCoords();\n setOutput(getX(" + r + "));\n }\n "; + } else this.userCode = "\n void main() {\n int coord = getOutputCoords();\n setOutput(getX(" + e[0] + " - coord - 1));\n }\n "; + }; + }(), + SegmentOpProgram = function () { + return function (e, t) { + this.variableNames = ["x", "segmentIds"];var n = e.windowSize, + r = e.batchSize, + o = e.inSize, + a = e.numSegments, + i = a * Math.ceil(o / n);this.outputShape = [r, i];var s = 4 * Math.floor(n / 4), + u = n % 4, + l = "\n sumValue += dot(values, filter);\n ", + c = "";o % n > 0 && (c = "\n if (inIdx < 0 || inIdx >= " + o + ") {\n return initializationValue;\n }\n ");var p = "";o % n > 0 && (p = "\n if (inIdx < 0 || inIdx >= " + o + ") {\n return -1.0;\n }\n "), this.userCode = "\n const float initializationValue = 0.0;\n\n float getValue(int batch, int inIdx) {\n " + c + "\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n " + p + "\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n " + a + ")) * float(" + n + "));\n int currentSeg = int(mod(float(outIdx), float(" + a + ")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < " + s + "; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n " + l + "\n }\n\n int inIdx = inOffset + " + s + ";\n if (" + (1 === u) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n " + l + "\n } else if (" + (2 === u) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n " + l + "\n } else if (" + (3 === u) + ") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n " + l + "\n }\n setOutput(sumValue);\n }\n "; + }; + }(), + SelectProgram = function () { + return function (e, t, n) { + var r, o;if (this.variableNames = ["c", "a", "b"], this.outputShape = t, n > 4) throw Error("Where for rank " + n + " is not yet supported");if (1 === n) o = "resRC", r = "resRC";else { + for (var a = ["resRC.x", "resRC.y", "resRC.z", "resRC.w"], i = [], s = [], u = 0; u < t.length; u++) s.push("" + a[u]), u < e && i.push("" + a[u]);r = i.join(), o = s.join(); + }var l = getCoordsDataType(n);this.userCode = "\n void main() {\n " + l + " resRC = getOutputCoords();\n float cVal = getC(" + r + ");\n if (cVal >= 1.0) {\n setOutput(getA(" + o + "));\n } else {\n setOutput(getB(" + o + "));\n }\n }\n "; + }; + }(), + SliceProgram = function () { + function e(e) { + this.variableNames = ["source"], this.outputShape = e, this.rank = e.length;var t = getCoordsDataType(this.rank), + n = getCoords$1(this.rank);this.userCode = "\n uniform " + t + " start;\n\n void main() {\n " + t + " sourceLoc = start + getOutputCoords();\n setOutput(getSource(" + n + "));\n }\n "; + }return e.prototype.getCustomSetupFunc = function (e) { + var t = this;if (e.length !== this.rank) throw Error("The rank (" + this.rank + ") of the program must match the length of start (" + e.length + ")");return function (n, r) { + if (null != t.startLoc || (t.startLoc = n.getUniformLocationNoThrow(r, "start"), null != t.startLoc)) if (1 === t.rank) n.gl.uniform1i(t.startLoc, e[0]);else if (2 === t.rank) n.gl.uniform2i(t.startLoc, e[0], e[1]);else if (3 === t.rank) n.gl.uniform3i(t.startLoc, e[0], e[1], e[2]);else { + if (4 !== t.rank) throw Error("Slicing for rank " + t.rank + " is not yet supported");n.gl.uniform4i(t.startLoc, e[0], e[1], e[2], e[3]); + } + }; + }, e; + }();function getCoords$1(e) { + if (1 === e) return "sourceLoc";if (2 === e) return "sourceLoc.x, sourceLoc.y";if (3 === e) return "sourceLoc.x, sourceLoc.y, sourceLoc.z";if (4 === e) return "sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w";throw Error("Slicing for rank " + e + " is not yet supported"); + }var StridedSliceProgram = function () { + return function (e, t, n) { + this.variableNames = ["x"], this.outputShape = n, this.rank = n.length;var r = getCoordsDataType(this.rank), + o = "";o = 1 === this.rank ? "coords * strides + begin" : n.map(function (e, t) { + return "coords[" + t + "] * strides[" + t + "] + begin[" + t + "]"; + }).join(","), this.userCode = "\n " + r + " begin = " + r + "(" + e + ");\n " + r + " strides = " + r + "(" + t + ");\n\n void main() {\n " + r + " coords = getOutputCoords();\n setOutput(getX(" + o + "));\n }\n "; + }; + }(), + TextureManager = function () { + function e(e) { + this.gpgpu = e, this.numUsedTextures = 0, this.numFreeTextures = 0, this.freeTextures = {}, this.logEnabled = !1, this.usedTextures = {}; + }return e.prototype.acquireTexture = function (e, t) { + var n, + r = getPhysicalFromLogicalTextureType(t), + o = getKeyFromTextureShape(e, r);if (o in this.freeTextures || (this.freeTextures[o] = []), o in this.usedTextures || (this.usedTextures[o] = []), this.freeTextures[o].length > 0) { + this.numFreeTextures--, this.numUsedTextures++, this.log();var a = this.freeTextures[o].shift();return this.usedTextures[o].push(a), a; + }return this.numUsedTextures++, this.log(), r === PhysicalTextureType.FLOAT32 ? n = this.gpgpu.createFloat32MatrixTexture(e[0], e[1]) : r === PhysicalTextureType.FLOAT16 ? n = this.gpgpu.createFloat16MatrixTexture(e[0], e[1]) : r === PhysicalTextureType.UNSIGNED_BYTE && (n = this.gpgpu.createUnsignedBytesMatrixTexture(e[0], e[1])), this.usedTextures[o].push(n), n; + }, e.prototype.releaseTexture = function (e, t, n) { + var r = getKeyFromTextureShape(t, getPhysicalFromLogicalTextureType(n));r in this.freeTextures || (this.freeTextures[r] = []), this.freeTextures[r].push(e), this.numFreeTextures++, this.numUsedTextures--;var o = this.usedTextures[r], + a = o.indexOf(e);if (a < 0) throw new Error("Cannot release a texture that was never provided by this texture manager");o.splice(a, 1), this.log(); + }, e.prototype.log = function () { + if (this.logEnabled) { + var e = this.numFreeTextures + this.numUsedTextures;console.log("Free/Used", this.numFreeTextures + " / " + this.numUsedTextures, "(" + e + ")"); + } + }, e.prototype.getNumUsedTextures = function () { + return this.numUsedTextures; + }, e.prototype.getNumFreeTextures = function () { + return this.numFreeTextures; + }, e.prototype.dispose = function () { + var e = this;if (null != this.freeTextures) { + for (var t in this.freeTextures) this.freeTextures[t].forEach(function (t) { + e.gpgpu.deleteMatrixTexture(t); + });for (var t in this.usedTextures) this.usedTextures[t].forEach(function (t) { + e.gpgpu.deleteMatrixTexture(t); + });this.freeTextures = null, this.usedTextures = null, this.numUsedTextures = 0, this.numFreeTextures = 0; + } + }, e; + }();function getPhysicalFromLogicalTextureType(e) { + if (e === TextureUsage.DOWNLOAD || e === TextureUsage.PIXELS) return PhysicalTextureType.UNSIGNED_BYTE;if (e === TextureUsage.UPLOAD) return PhysicalTextureType.FLOAT32;if (e === TextureUsage.RENDER) return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED") ? PhysicalTextureType.FLOAT32 : PhysicalTextureType.FLOAT16;throw new Error("Unknown logical texture type " + e); + }function getKeyFromTextureShape(e, t) { + return e[0] + "_" + e[1] + "_" + t; + }var TileProgram = function () { + return function (e, t) { + this.variableNames = ["A"];for (var n = new Array(e.length), r = 0; r < n.length; r++) n[r] = e[r] * t[r];this.outputShape = n, this.rank = n.length;var o = getCoordsDataType(this.rank), + a = getSourceCoords$1(e);this.userCode = "\n void main() {\n " + o + " resRC = getOutputCoords();\n setOutput(getA(" + a + "));\n }\n "; + }; + }();function getSourceCoords$1(e) { + var t = e.length;if (t > 5) throw Error("Tile for rank " + t + " is not yet supported");if (1 === t) return "imod(resRC, " + e[0] + ")";for (var n = ["resRC.x", "resRC.y", "resRC.z", "resRC.w", "resRC.u"], r = [], o = 0; o < e.length; o++) r.push("imod(" + n[o] + ", " + e[o] + ")");return r.join(); + }var TransposeProgram = function () { + return function (e, t) { + this.variableNames = ["A"];for (var n = new Array(e.length), r = 0; r < n.length; r++) n[r] = e[t[r]];this.outputShape = n, this.rank = n.length;var o = getCoordsDataType(this.rank), + a = getSwitchedCoords(t);this.userCode = "\n void main() {\n " + o + " resRC = getOutputCoords();\n setOutput(getA(" + a + "));\n }\n "; + }; + }();function getSwitchedCoords(e) { + var t = e.length;if (t > 6) throw Error("Transpose for rank " + t + " is not yet supported");for (var n = ["resRC.x", "resRC.y", "resRC.z", "resRC.w", "resRC.u", "resRC.v"], r = new Array(t), o = 0; o < e.length; o++) r[e[o]] = n[o];return r.join(); + }var ERF_P = .3275911, + ERF_A1 = .254829592, + ERF_A2 = -.284496736, + ERF_A3 = 1.421413741, + ERF_A4 = -1.453152027, + ERF_A5 = 1.061405429, + SELU_SCALEALPHA = 1.7580993408473768, + SELU_SCALE = 1.0507009873554805, + UnaryOpProgram = function () { + function e(e, t) { + this.variableNames = ["A"], this.outputShape = e, this.userCode = "\n uniform float NAN;\n float unaryOperation(float x) {\n " + t + "\n }\n\n void main() {\n float x = getAAtOutCoords();\n float y = unaryOperation(x);\n\n setOutput(y);\n }\n "; + }return e.prototype.getCustomSetupFunc = function () { + var e = this;return function (t, n) { + null == e.startLoc && (e.startLoc = t.getUniformLocationNoThrow(n, "NAN"), null == e.startLoc) || t.gl.uniform1f(e.startLoc, NaN); + }; + }, e; + }(), + CHECK_NAN_SNIPPET$1 = "if (isNaN(x)) return x;", + ABS = "return abs(x);", + RELU = CHECK_NAN_SNIPPET$1 + "\n return (x < 0.0) ? 0.0 : x;\n", + ELU = "return (x >= 0.0) ? x : (exp(x) - 1.0);", + SELU = "\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\n // see: https://arxiv.org/abs/1706.02515\n float scaleAlpha = " + SELU_SCALEALPHA + ";\n float scale = " + SELU_SCALE + ";\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n";function STEP(e) { + return void 0 === e && (e = 0), CHECK_NAN_SNIPPET$1 + "\n return x > 0.0 ? 1.0 : float(" + e + ");\n "; + }var NEG = "return -x;", + CEIL = "return ceil(x);", + FLOOR = "return floor(x);", + SIGN = "\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n", + ROUND = "\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n", + EXP = "return exp(x);", + EXPM1 = "return exp(x) - 1.0;", + LOG = "if (x < 0.0) return NAN;\n return log(x);", + LOG1P = "return log(1.0 + x);", + SQRT = "return sqrt(x);", + RSQRT = "return inversesqrt(x);", + SIGMOID = "return 1.0 / (1.0 + exp(-1.0 * x));", + SOFTPLUS = "\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n", + SIN = CHECK_NAN_SNIPPET$1 + "\n return sin(x);\n", + COS = CHECK_NAN_SNIPPET$1 + "\n return cos(x);\n", + TAN = "return tan(x);", + ASIN = "return asin(x);", + ACOS = "return acos(x);", + ATAN = CHECK_NAN_SNIPPET$1 + "\n return atan(x);\n", + SINH = "\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n", + COSH = "\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n", + TANH = "\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n", + ASINH = "return log(x + sqrt(x * x + 1.0));", + ACOSH = CHECK_NAN_SNIPPET$1 + "\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));", + ATANH = CHECK_NAN_SNIPPET$1 + "\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;", + ERF = '\n // Error function is calculated approximately with elementary function.\n // See "Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables", Abramowitz and Stegun.\n float p = ' + ERF_P + ";\n float a1 = " + ERF_A1 + ";\n float a2 = " + ERF_A2 + ";\n float a3 = " + ERF_A3 + ";\n float a4 = " + ERF_A4 + ";\n float a5 = " + ERF_A5 + ";\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n", + SQUARE = "return x * x;", + RECIPROCAL = "return 1.0 / x;", + LOGICAL_NOT = "return float(!(x >= 1.0));", + TO_INT = "return float(int(x));";function concat1d_(e) { + return concat(e, 0); + }function concat2d_(e, t) { + return concat(e, t); + }function concat3d_(e, t) { + return concat(e, t); + }function concat4d_(e, t) { + return concat(e, t); + }function concat_(e, t) { + void 0 === t && (t = 0), assert(e.length >= 1, "Pass at least one tensor to concat");var n = convertToTensorArray(e, "tensors", "concat"), + r = n[0];if (1 === n.length) return r;for (var o = parseAxisParam(t, r.shape), a = 1; a < n.length; ++a) r = concat2Tensors(r, n[a], o[0]);return r; + }function concat2Tensors(e, t, n) { + assertParams(e.shape, t.shape, n);var r = computeOutShape$1(e.shape, t.shape, n), + o = e.as2D(-1, sizeFromShape(e.shape.slice(n))), + a = t.as2D(-1, sizeFromShape(t.shape.slice(n))), + i = computeGradientSliceShapes(o.shape, a.shape), + s = i.aBegin, + u = i.aSize, + l = i.bBegin, + c = i.bSize;return ENV.engine.runKernel(function (e) { + return e.concat(o, a); + }, { a: o, b: a }, function (e) { + return { a: function () { + return e.slice(s, u); + }, b: function () { + return e.slice(l, c); + } }; + }).reshape(r); + }var concat = op({ concat_: concat_ }), + concat1d = op({ concat1d_: concat1d_ }), + concat2d = op({ concat2d_: concat2d_ }), + concat3d = op({ concat3d_: concat3d_ }), + concat4d = op({ concat4d_: concat4d_ }); + function createCommonjsModule(e, t) { + return e(t = { exports: {} }, t.exports), t.exports; + }var alea = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.c = e.c, t.s0 = e.s0, t.s1 = e.s1, t.s2 = e.s2, t; + }function o(e, t) { + var n = new function (e) { + var t, + n = this, + r = (t = 4022871197, function (e) { + e = e.toString();for (var n = 0; n < e.length; n++) { + var r = .02519603282416938 * (t += e.charCodeAt(n));r -= t = r >>> 0, t = (r *= t) >>> 0, t += 4294967296 * (r -= t); + }return 2.3283064365386963e-10 * (t >>> 0); + });n.next = function () { + var e = 2091639 * n.s0 + 2.3283064365386963e-10 * n.c;return n.s0 = n.s1, n.s1 = n.s2, n.s2 = e - (n.c = 0 | e); + }, n.c = 1, n.s0 = r(" "), n.s1 = r(" "), n.s2 = r(" "), n.s0 -= r(e), n.s0 < 0 && (n.s0 += 1), n.s1 -= r(e), n.s1 < 0 && (n.s1 += 1), n.s2 -= r(e), n.s2 < 0 && (n.s2 += 1), r = null; + }(e), + o = t && t.state, + a = n.next;return a.int32 = function () { + return 4294967296 * n.next() | 0; + }, a.double = function () { + return a() + 1.1102230246251565e-16 * (2097152 * a() | 0); + }, a.quick = a, o && ("object" == typeof o && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.alea = o; + }(0, e, !1); + }), + xor128 = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.x = e.x, t.y = e.y, t.z = e.z, t.w = e.w, t; + }function o(e, t) { + var n = new function (e) { + var t = this, + n = "";t.x = 0, t.y = 0, t.z = 0, t.w = 0, t.next = function () { + var e = t.x ^ t.x << 11;return t.x = t.y, t.y = t.z, t.z = t.w, t.w ^= t.w >>> 19 ^ e ^ e >>> 8; + }, e === (0 | e) ? t.x = e : n += e;for (var r = 0; r < n.length + 64; r++) t.x ^= 0 | n.charCodeAt(r), t.next(); + }(e), + o = t && t.state, + a = function () { + return (n.next() >>> 0) / 4294967296; + };return a.double = function () { + do { + var e = ((n.next() >>> 11) + (n.next() >>> 0) / 4294967296) / (1 << 21); + } while (0 === e);return e; + }, a.int32 = n.next, a.quick = a, o && ("object" == typeof o && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.xor128 = o; + }(0, e, !1); + }), + xorwow = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.x = e.x, t.y = e.y, t.z = e.z, t.w = e.w, t.v = e.v, t.d = e.d, t; + }function o(e, t) { + var n = new function (e) { + var t = this, + n = "";t.next = function () { + var e = t.x ^ t.x >>> 2;return t.x = t.y, t.y = t.z, t.z = t.w, t.w = t.v, (t.d = t.d + 362437 | 0) + (t.v = t.v ^ t.v << 4 ^ e ^ e << 1) | 0; + }, t.x = 0, t.y = 0, t.z = 0, t.w = 0, t.v = 0, e === (0 | e) ? t.x = e : n += e;for (var r = 0; r < n.length + 64; r++) t.x ^= 0 | n.charCodeAt(r), r == n.length && (t.d = t.x << 10 ^ t.x >>> 4), t.next(); + }(e), + o = t && t.state, + a = function () { + return (n.next() >>> 0) / 4294967296; + };return a.double = function () { + do { + var e = ((n.next() >>> 11) + (n.next() >>> 0) / 4294967296) / (1 << 21); + } while (0 === e);return e; + }, a.int32 = n.next, a.quick = a, o && ("object" == typeof o && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.xorwow = o; + }(0, e, !1); + }), + xorshift7 = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.x = e.x.slice(), t.i = e.i, t; + }function o(e, t) { + null == e && (e = +new Date());var n = new function (e) { + var t = this;t.next = function () { + var e, + n, + r = t.x, + o = t.i;return e = r[o], n = (e ^= e >>> 7) ^ e << 24, n ^= (e = r[o + 1 & 7]) ^ e >>> 10, n ^= (e = r[o + 3 & 7]) ^ e >>> 3, n ^= (e = r[o + 4 & 7]) ^ e << 7, e = r[o + 7 & 7], n ^= (e ^= e << 13) ^ e << 9, r[o] = n, t.i = o + 1 & 7, n; + }, function (e, t) { + var n, + r = [];if (t === (0 | t)) r[0] = t;else for (t = "" + t, n = 0; n < t.length; ++n) r[7 & n] = r[7 & n] << 15 ^ t.charCodeAt(n) + r[n + 1 & 7] << 13;for (; r.length < 8;) r.push(0);for (n = 0; n < 8 && 0 === r[n]; ++n);for (8 == n ? r[7] = -1 : r[n], e.x = r, e.i = 0, n = 256; n > 0; --n) e.next(); + }(t, e); + }(e), + o = t && t.state, + a = function () { + return (n.next() >>> 0) / 4294967296; + };return a.double = function () { + do { + var e = ((n.next() >>> 11) + (n.next() >>> 0) / 4294967296) / (1 << 21); + } while (0 === e);return e; + }, a.int32 = n.next, a.quick = a, o && (o.x && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.xorshift7 = o; + }(0, e, !1); + }), + xor4096 = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.i = e.i, t.w = e.w, t.X = e.X.slice(), t; + }function o(e, t) { + null == e && (e = +new Date());var n = new function (e) { + var t = this;t.next = function () { + var e, + n, + r = t.w, + o = t.X, + a = t.i;return t.w = r = r + 1640531527 | 0, n = o[a + 34 & 127], e = o[a = a + 1 & 127], n ^= n << 13, e ^= e << 17, n ^= n >>> 15, e ^= e >>> 12, n = o[a] = n ^ e, t.i = a, n + (r ^ r >>> 16) | 0; + }, function (e, t) { + var n, + r, + o, + a, + i, + s = [], + u = 128;for (t === (0 | t) ? (r = t, t = null) : (t += "\0", r = 0, u = Math.max(u, t.length)), o = 0, a = -32; a < u; ++a) t && (r ^= t.charCodeAt((a + 32) % t.length)), 0 === a && (i = r), r ^= r << 10, r ^= r >>> 15, r ^= r << 4, r ^= r >>> 13, a >= 0 && (i = i + 1640531527 | 0, o = 0 == (n = s[127 & a] ^= r + i) ? o + 1 : 0);for (o >= 128 && (s[127 & (t && t.length || 0)] = -1), o = 127, a = 512; a > 0; --a) r = s[o + 34 & 127], n = s[o = o + 1 & 127], r ^= r << 13, n ^= n << 17, r ^= r >>> 15, n ^= n >>> 12, s[o] = r ^ n;e.w = i, e.X = s, e.i = o; + }(t, e); + }(e), + o = t && t.state, + a = function () { + return (n.next() >>> 0) / 4294967296; + };return a.double = function () { + do { + var e = ((n.next() >>> 11) + (n.next() >>> 0) / 4294967296) / (1 << 21); + } while (0 === e);return e; + }, a.int32 = n.next, a.quick = a, o && (o.X && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.xor4096 = o; + }(0, e, !1); + }), + tychei = createCommonjsModule(function (e) { + !function (e, t, n) { + function r(e, t) { + return t.a = e.a, t.b = e.b, t.c = e.c, t.d = e.d, t; + }function o(e, t) { + var n = new function (e) { + var t = this, + n = "";t.next = function () { + var e = t.b, + n = t.c, + r = t.d, + o = t.a;return e = e << 25 ^ e >>> 7 ^ n, n = n - r | 0, r = r << 24 ^ r >>> 8 ^ o, o = o - e | 0, t.b = e = e << 20 ^ e >>> 12 ^ n, t.c = n = n - r | 0, t.d = r << 16 ^ n >>> 16 ^ o, t.a = o - e | 0; + }, t.a = 0, t.b = 0, t.c = -1640531527, t.d = 1367130551, e === Math.floor(e) ? (t.a = e / 4294967296 | 0, t.b = 0 | e) : n += e;for (var r = 0; r < n.length + 20; r++) t.b ^= 0 | n.charCodeAt(r), t.next(); + }(e), + o = t && t.state, + a = function () { + return (n.next() >>> 0) / 4294967296; + };return a.double = function () { + do { + var e = ((n.next() >>> 11) + (n.next() >>> 0) / 4294967296) / (1 << 21); + } while (0 === e);return e; + }, a.int32 = n.next, a.quick = a, o && ("object" == typeof o && r(o, n), a.state = function () { + return r(n, {}); + }), a; + }t && t.exports ? t.exports = o : n && n.amd ? n(function () { + return o; + }) : this.tychei = o; + }(0, e, !1); + }), + seedrandom = createCommonjsModule(function (e) { + !function (t, n) { + var r, + o = this, + a = 256, + i = 6, + s = "random", + u = n.pow(a, i), + l = n.pow(2, 52), + c = 2 * l, + p = a - 1;function d(e, d, g) { + var v = [], + y = f(function e(t, n) { + var r, + o = [], + a = typeof t;if (n && "object" == a) for (r in t) try { + o.push(e(t[r], n - 1)); + } catch (e) {}return o.length ? o : "string" == a ? t : t + "\0"; + }((d = 1 == d ? { entropy: !0 } : d || {}).entropy ? [e, m(t)] : null == e ? function () { + try { + var e;return r && (e = r.randomBytes) ? e = e(a) : (e = new Uint8Array(a), (o.crypto || o.msCrypto).getRandomValues(e)), m(e); + } catch (e) { + var n = o.navigator, + i = n && n.plugins;return [+new Date(), o, i, o.screen, m(t)]; + } + }() : e, 3), v), + x = new function (e) { + var t, + n = e.length, + r = this, + o = 0, + i = r.i = r.j = 0, + s = r.S = [];n || (e = [n++]);for (; o < a;) s[o] = o++;for (o = 0; o < a; o++) s[o] = s[i = p & i + e[o % n] + (t = s[o])], s[i] = t;(r.g = function (e) { + for (var t, n = 0, o = r.i, i = r.j, s = r.S; e--;) t = s[o = p & o + 1], n = n * a + s[p & (s[o] = s[i = p & i + t]) + (s[i] = t)];return r.i = o, r.j = i, n; + })(a); + }(v), + T = function () { + for (var e = x.g(i), t = u, n = 0; e < l;) e = (e + n) * a, t *= a, n = x.g(1);for (; e >= c;) e /= 2, t /= 2, n >>>= 1;return (e + n) / t; + };return T.int32 = function () { + return 0 | x.g(4); + }, T.quick = function () { + return x.g(4) / 4294967296; + }, T.double = T, f(m(x.S), t), (d.pass || g || function (e, t, r, o) { + return o && (o.S && h(o, x), e.state = function () { + return h(x, {}); + }), r ? (n[s] = e, t) : e; + })(T, y, "global" in d ? d.global : this == n, d.state); + }function h(e, t) { + return t.i = e.i, t.j = e.j, t.S = e.S.slice(), t; + }function f(e, t) { + for (var n, r = e + "", o = 0; o < r.length;) t[p & o] = p & (n ^= 19 * t[p & o]) + r.charCodeAt(o++);return m(t); + }function m(e) { + return String.fromCharCode.apply(0, e); + }if (n["seed" + s] = d, f(n.random(), t), e.exports) { + e.exports = d;try { + r = require("crypto"); + } catch (e) {} + } + }([], Math); + });seedrandom.alea = alea, seedrandom.xor128 = xor128, seedrandom.xorwow = xorwow, seedrandom.xorshift7 = xorshift7, seedrandom.xor4096 = xor4096, seedrandom.tychei = tychei;var seedrandom$1 = seedrandom, + seedrandom_1 = seedrandom$1.alea, + MPRandGauss = function () { + function e(e, t, n, r, o) { + this.mean = e, this.stdDev = t, this.dtype = n, this.nextVal = NaN, this.truncated = r, this.truncated && (this.upper = this.mean + 2 * this.stdDev, this.lower = this.mean - 2 * this.stdDev);var a = o || Math.random();this.random = seedrandom_1(a.toString()); + }return e.prototype.nextValue = function () { + if (!isNaN(this.nextVal)) { + var e = this.nextVal;return this.nextVal = NaN, e; + }for (var t, n, r = !1; !r;) { + var o = void 0, + a = void 0, + i = void 0;do { + i = (o = 2 * this.random() - 1) * o + (a = 2 * this.random() - 1) * a; + } while (i >= 1 || 0 === i);var s = Math.sqrt(-2 * Math.log(i) / i);t = this.mean + this.stdDev * o * s, n = this.mean + this.stdDev * a * s, this.truncated && !this.isValidTruncated(t) || (r = !0); + }return this.truncated && !this.isValidTruncated(n) || (this.nextVal = this.convertValue(n)), this.convertValue(t); + }, e.prototype.convertValue = function (e) { + return null == this.dtype || "float32" === this.dtype ? e : Math.round(e); + }, e.prototype.isValidTruncated = function (e) { + return e <= this.upper && e >= this.lower; + }, e; + }();function clone_(e) { + var t = convertToTensor(e, "x", "clone");return ENV.engine.runKernel(function (e) { + return Tensor.make(t.shape, { dataId: t.dataId }, t.dtype); + }, { $x: t }, function (e) { + return { $x: function () { + return e.toFloat(); + } }; + }); + }function eye_(e, t, n, r) { + void 0 === r && (r = "float32"), null == t && (t = e);for (var o = buffer([e, t], r), a = e <= t ? e : t, i = 0; i < a; ++i) o.set(1, i, i);var s = o.toTensor().as2D(e, t);if (null == n) return s;if (1 === n.length) return tile(expandDims(s, 0), [n[0], 1, 1]);if (2 === n.length) return tile(expandDims(expandDims(s, 0), 0), [n[0], n[1], 1, 1]);if (3 === n.length) return tile(expandDims(expandDims(expandDims(s, 0), 0), 0), [n[0], n[1], n[2], 1, 1]);throw new Error("eye() currently supports only 1D and 2D batchShapes, but received " + n.length + "D."); + }function randomNormal_(e, t, n, r, o) { + if (void 0 === t && (t = 0), void 0 === n && (n = 1), null != r && "bool" === r) throw new Error("Unsupported data type " + r);for (var a = new MPRandGauss(t, n, r, !1, o), i = buffer(e, r), s = 0; s < i.values.length; s++) i.values[s] = a.nextValue();return i.toTensor(); + }function truncatedNormal_(e, t, n, r, o) { + if (void 0 === t && (t = 0), void 0 === n && (n = 1), null != r && "bool" === r) throw new Error("Unsupported data type " + r);for (var a = new MPRandGauss(t, n, r, !0, o), i = buffer(e, r), s = 0; s < i.values.length; s++) i.values[s] = a.nextValue();return i.toTensor(); + }function randomUniform_(e, t, n, r) { + void 0 === t && (t = 0), void 0 === n && (n = 1), void 0 === r && (r = "float32");for (var o = buffer(e, r), a = 0; a < o.values.length; a++) o.values[a] = randUniform(t, n);return o.toTensor(); + }function rand_(e, t, n) { + var r = sizeFromShape(e), + o = null;if (null == n || "float32" === n) o = new Float32Array(r);else if ("int32" === n) o = new Int32Array(r);else { + if ("bool" !== n) throw new Error("Unknown data type " + n);o = new Uint8Array(r); + }for (var a = 0; a < r; a++) o[a] = t();return Tensor.make(e, { values: o }, n); + }function multinomial_(e, t, n, r) { + void 0 === r && (r = !1);var o = convertToTensor(e, "logits", "multinomial"), + a = o.size, + i = o.rank;if (a < 2) throw new Error("Error in multinomial: you need at least 2 outcomes, but got " + a + ".");if (i > 2) throw new Error("Rank of probabilities must be 1 or 2, but is " + i);n = n || Math.random();var s = 1 === i ? o.as2D(1, -1) : o, + u = ENV.engine.runKernel(function (e) { + return e.multinomial(s, r, t, n); + }, { logits2D: s });return 1 === i ? u.as1D() : u; + }function oneHot_(e, t, n, r) { + void 0 === n && (n = 1), void 0 === r && (r = 0);var o = convertToTensor(e, "indices", "oneHot", "int32");if (assert("int32" === o.dtype, "Indices must be of dtype `int32`"), t < 2) throw new Error("Error in oneHot: depth must be >=2, but it is " + t);return ENV.engine.runKernel(function (e) { + return e.oneHot(o, t, n, r); + }, { $indices: o }); + }function fromPixels_(e, t) { + if (void 0 === t && (t = 3), t > 4) throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");return ENV.engine.fromPixels(e, t); + }function toPixels(e, t) { + return __awaiter(this, void 0, void 0, function () { + var n, r, o, a, i, s, u, l, c, p, d, h, f, m, g, v, y, x, T, S;return __generator(this, function (b) { + switch (b.label) {case 0: + if (2 !== (n = convertToTensor(e, "img", "toPixels", "int32")).rank && 3 !== n.rank) throw new Error("toPixels only supports rank 2 or 3 tensors, got rank " + n.rank + ".");if (r = n.shape.slice(0, 2), o = r[0], a = r[1], (i = 2 === n.rank ? 1 : n.shape[2]) > 4 || 2 === i) throw new Error("toPixels only supports depth of size 1, 3 or 4 but got " + i);return s = n.min(), u = n.max(), [4, s.data()];case 1: + return l = b.sent()[0], [4, u.data()];case 2: + if (c = b.sent()[0], s.dispose(), u.dispose(), "float32" === n.dtype) { + if (l < 0 || c > 1) throw new Error("Tensor values for a float32 Tensor must be in the range [0 - 1] but got range [" + l + " - " + c + "]."); + } else { + if ("int32" !== n.dtype) throw new Error("Unsupported type for toPixels: " + n.dtype + ". Please use float32 or int32 tensors.");if (l < 0 || c > 255) throw new Error("Tensor values for a int32 Tensor must be in the range [0 - 255] but got range [" + l + " - " + c + "]."); + }return [4, n.data()];case 3: + for (p = b.sent(), d = "float32" === n.dtype ? 255 : 1, h = new Uint8ClampedArray(a * o * 4), f = 0; f < o * a; ++f) m = void 0, g = void 0, v = void 0, y = void 0, 1 === i ? (m = p[f] * d, g = p[f] * d, v = p[f] * d, y = 255) : 3 === i ? (m = p[3 * f] * d, g = p[3 * f + 1] * d, v = p[3 * f + 2] * d, y = 255) : 4 === i && (m = p[4 * f] * d, g = p[4 * f + 1] * d, v = p[4 * f + 2] * d, y = p[4 * f + 3] * d), h[(x = 4 * f) + 0] = Math.round(m), h[x + 1] = Math.round(g), h[x + 2] = Math.round(v), h[x + 3] = Math.round(y);return null != t && (t.width = a, t.height = o, T = t.getContext("2d"), S = new ImageData(h, a, o), T.putImageData(S, 0, 0)), n !== e && n.dispose(), [2, h];} + }); + }); + }function reshape_(e, t) { + var n = convertToTensor(e, "x", "reshape");t = inferFromImplicitShape(t, n.size), assert(n.size === sizeFromShape(t), "new shape and old shape must have the same number of elements.");return ENV.engine.runKernel(function (e) { + return e.reshape(n, t); + }, { $x: n }, function (e) { + return { $x: function () { + return e.reshape(n.shape); + } }; + }); + }function squeeze_(e, t) { + var n = convertToTensor(e, "x", "squeeze");return reshape(n, squeezeShape(n.shape, t).newShape); + }function cast_(e, t) { + var n = convertToTensor(e, "x", "cast");return ENV.engine.runKernel(function (e) { + return e.cast(n, t); + }, { $x: n }, function (e) { + return { $x: function () { + return e.clone(); + } }; + }); + }function tile_(e, t) { + var n = convertToTensor(e, "x", "tile");assert(n.rank === t.length, "Error in transpose: rank of input " + n.rank + " must match length of reps " + t + ".");return ENV.engine.runKernel(function (e) { + return e.tile(n, t); + }, { $x: n }, function (e) { + return { $x: function () { + var r = zerosLike(n);if (1 === n.rank) for (var o = 0; o < t[0]; ++o) r = r.add(e.slice([o * n.shape[0]], [n.shape[0]]));else if (2 === n.rank) for (o = 0; o < t[0]; ++o) for (var a = 0; a < t[1]; ++a) r = r.add(e.slice([o * n.shape[0], a * n.shape[1]], [n.shape[0], n.shape[1]]));else if (3 === n.rank) for (o = 0; o < t[0]; ++o) for (a = 0; a < t[1]; ++a) for (var i = 0; i < t[2]; ++i) r = r.add(e.slice([o * n.shape[0], a * n.shape[1], i * n.shape[2]], [n.shape[0], n.shape[1], n.shape[2]]));else { + if (4 !== n.rank) throw new Error("Gradient for tile operation is not implemented for rank-" + n.rank + " tensors yet.");for (o = 0; o < t[0]; ++o) for (a = 0; a < t[1]; ++a) for (i = 0; i < t[2]; ++i) for (var s = 0; s < t[3]; ++s) r = r.add(e.slice([o * n.shape[0], a * n.shape[1], i * n.shape[2], s * n.shape[3]], [n.shape[0], n.shape[1], n.shape[2], n.shape[3]])); + }return r; + } }; + }); + }function pad1d_(e, t, n) { + return void 0 === n && (n = 0), assert(2 === t.length, "Invalid number of paddings. Must be length of 2."), pad(e, [t], n); + }function pad2d_(e, t, n) { + return void 0 === n && (n = 0), assert(2 === t.length && 2 === t[0].length && 2 === t[1].length, "Invalid number of paddings. Must be length of 2 each."), pad(e, t, n); + }function pad3d_(e, t, n) { + return void 0 === n && (n = 0), assert(3 === t.length && 2 === t[0].length && 2 === t[1].length && 2 === t[2].length, "Invalid number of paddings. Must be length of 2 each."), pad(e, t, n); + }function pad4d_(e, t, n) { + return void 0 === n && (n = 0), assert(4 === t.length && 2 === t[0].length && 2 === t[1].length && 2 === t[2].length && 2 === t[3].length, "Invalid number of paddings. Must be length of 2 each."), pad(e, t, n); + }function pad_(e, t, n) { + void 0 === n && (n = 0);var r = convertToTensor(e, "x", "pad");if (0 === r.rank) throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");var o = t.map(function (e) { + return e[0]; + });return ENV.engine.runKernel(function (e) { + return e.pad(r, t, n); + }, { $x: r }, function (e) { + return { $x: function () { + return e.slice(o, r.shape); + } }; + }); + }function stack_(e, t) { + void 0 === t && (t = 0);var n = convertToTensorArray(e, "tensors", "stack");if (assert(n.length >= 1, "Pass at least one tensor to tf.stack"), 1 === n.length) return n[0].expandDims(t);var r = n[0].rank, + o = n[0].shape, + a = n[0].dtype;assert(t <= r, "Axis must be <= rank of the tensor"), n.forEach(function (e) { + assertShapesMatch(o, e.shape, "All tensors passed to stack must have matching shapes"); + }), n.forEach(function (e) { + assert(a === e.dtype, "All tensors passed to stack must have matching dtypes"); + });var i = n.map(function (e) { + return e.expandDims(t); + });return concat(i, t); + }function batchToSpaceND_(e, t, n) { + var r = convertToTensor(e, "x", "batchToSpaceND"), + o = t.reduce(function (e, t) { + return e * t; + });return assert(r.rank >= 1 + t.length, "input rank should be > than [blockShape] but got " + r.rank), assert(n.length === t.length, "crops.shape[0] must be equal to [blockShape] but got " + n.length), assert(r.shape[0] % o == 0, "input tensor batch must be divisible by prod( blockShape )"), ENV.engine.runKernel(function (e) { + return e.batchToSpaceND(r, t, n); + }, {}); + }function spaceToBatchND_(e, t, n) { + var r = convertToTensor(e, "x", "spaceToBatchND");return assert(r.rank >= 1 + t.length, "input rank should be > than [blockShape] but got " + r.rank), assert(n.length === t.length, "paddings.shape[0] must be equal to [blockShape], got " + n.length), assert(r.shape.reduce(function (e, n, r) { + return r > 0 && r <= t.length ? e && n % t[r - 1] == 0 : e; + }, !0), "input spatial dimensions must be divisible by blockShapes"), ENV.engine.runKernel(function (e) { + return e.spaceToBatchND(r, t, n); + }, {}); + }function unstack_(e, t) { + void 0 === t && (t = 0);for (var n, r = convertToTensor(e, "x", "unstack"), o = r.shape[t], a = Array(r.rank - 1).fill(0), i = 0, s = 0; s < r.rank; s++) s !== t && (a[i] = r.shape[s], i++);n = Array(o).fill(1);var u = Array(r.rank).fill(0), + l = r.shape.slice();return n.map(function (e) { + l[t] = e;var n = r.slice(u, l);return u[t] += e, n.reshape(a); + }); + }function split_(e, t, n) { + void 0 === n && (n = 0);var r, + o = convertToTensor(e, "x", "split");n = parseAxisParam(n, o.shape)[0], "number" == typeof t ? (assert(o.shape[n] % t == 0, "Number of splits must evenly divide the axis."), r = Array(t).fill(o.shape[n] / t)) : (assert(o.shape[n] === t.reduce(function (e, t) { + return e + t; + }), "The sum of sizes must match the size of the axis dimension."), r = t);var a = Array(o.rank).fill(0), + i = o.shape.slice();return r.map(function (e) { + i[n] = e;var t = o.slice(a, i);return a[n] += e, t; + }); + }function cumsum_(e, t, n, r) { + void 0 === t && (t = 0), void 0 === n && (n = !1), void 0 === r && (r = !1);var o = convertToTensor(e, "x", "cumsum"), + a = getAxesPermutation([t |= 0], o.rank), + i = o;null != a && (i = o.transpose(a));var s = getInnerMostAxes(1, o.rank)[0], + u = ENV.engine.runKernel(function (e) { + return e.cumsum(i, s, n, r); + }, { permutedX: i }, function (e) { + return { permutedX: function () { + return e.cumsum(t, n, !r); + } }; + });return null != a && (u = u.transpose(a)), u; + }function expandDims_(e, t) { + void 0 === t && (t = 0);var n = convertToTensor(e, "x", "expandDims");assert(t <= n.rank, "Axis must be <= rank of the tensor");var r = n.shape.slice();return t < 0 && (assert(-(n.rank + 1) <= t, "Axis must be in the interval [" + -(n.rank + 1) + ", " + n.rank + "]"), t = n.rank + t + 1), r.splice(t, 0, 1), reshape(n, r); + }function buffer(e, t, n) { + return void 0 === t && (t = "float32"), new TensorBuffer(e, t, n); + }function print(e, t) { + void 0 === t && (t = !1), console.log(e.toString(t)); + }var cast = op({ cast_: cast_ }), + clone = op({ clone_: clone_ }), + cumsum = op({ cumsum_: cumsum_ }), + expandDims = op({ expandDims_: expandDims_ }), + eye = op({ eye_: eye_ }), + fromPixels = op({ fromPixels_: fromPixels_ }), + multinomial = op({ multinomial_: multinomial_ }), + oneHot = op({ oneHot_: oneHot_ }), + pad = op({ pad_: pad_ }), + pad1d = op({ pad1d_: pad1d_ }), + pad2d = op({ pad2d_: pad2d_ }), + pad3d = op({ pad3d_: pad3d_ }), + pad4d = op({ pad4d_: pad4d_ }), + rand = op({ rand_: rand_ }), + randomNormal = op({ randomNormal_: randomNormal_ }), + randomUniform = op({ randomUniform_: randomUniform_ }), + reshape = op({ reshape_: reshape_ }), + split = op({ split_: split_ }), + squeeze = op({ squeeze_: squeeze_ }), + stack = op({ stack_: stack_ }), + tile = op({ tile_: tile_ }), + truncatedNormal = op({ truncatedNormal_: truncatedNormal_ }), + unstack = op({ unstack_: unstack_ }), + batchToSpaceND = op({ batchToSpaceND_: batchToSpaceND_ }), + spaceToBatchND = op({ spaceToBatchND_: spaceToBatchND_ });function whereImpl(e, t) { + for (var n = [], r = 0; r < t.length; r++) t[r] && n.push(r);var o = buffer(e, "int32"), + a = buffer([n.length, e.length], "int32");for (r = 0; r < n.length; r++) { + var i = o.indexToLoc(n[r]), + s = r * e.length;a.values.set(i, s); + }return a.toTensor(); + }var BEFORE_PAGING_CONSTANT = 300, + SIZE_UPLOAD_UNIFORM = 32, + MathBackendWebGL = function () { + function e(e, t) { + if (void 0 === t && (t = !0), this.gpgpu = e, this.delayedStorage = t, this.texData = new WeakMap(), this.pendingRead = new WeakMap(), this.pendingDisposal = new WeakSet(), this.lruDataGPU = [], this.numBytesInGPU = 0, this.uploadWaitMs = 0, this.downloadWaitMs = 0, this.binaryCache = {}, this.disposed = !1, ENV.get("WEBGL_VERSION") < 1) throw new Error("WebGL is not supported on this device");ENV.get("IS_BROWSER") && (this.canvas = document.createElement("canvas")), null == e ? (this.gpgpu = new GPGPUContext(createWebGLContext(this.canvas)), this.gpgpuCreatedLocally = !0) : this.gpgpuCreatedLocally = !1, this.NUM_BYTES_BEFORE_PAGING = window.screen.height * window.screen.width * window.devicePixelRatio * BEFORE_PAGING_CONSTANT, this.textureManager = new TextureManager(this.gpgpu); + }return e.prototype.register = function (e, t, n) { + if (this.texData.has(e)) throw new Error("Data buffer is already registered");this.texData.set(e, { shape: t, dtype: n, values: null, texture: null, texShape: null, usage: TextureUsage.RENDER }); + }, e.prototype.fromPixels = function (e, t) { + if (null == e) throw new Error("pixels passed to tf.fromPixels() can not be null");var n = [e.height, e.width], + r = [e.height, e.width, t];if (!(e instanceof HTMLVideoElement || e instanceof HTMLImageElement || e instanceof HTMLCanvasElement || e instanceof ImageData)) throw new Error("pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was " + e.constructor.name);if (e instanceof HTMLVideoElement) { + if (null == this.fromPixelsCanvas) { + if (!ENV.get("IS_BROWSER")) throw new Error("Can't read pixels from HTMLImageElement outside the browser.");if ("complete" !== document.readyState) throw new Error("The DOM is not ready yet. Please call tf.fromPixels() once the DOM is ready. One way to do that is to add an event listener for `DOMContentLoaded` on the document object");this.fromPixelsCanvas = document.createElement("canvas"); + }this.fromPixelsCanvas.width = e.width, this.fromPixelsCanvas.height = e.height, this.fromPixelsCanvas.getContext("2d").drawImage(e, 0, 0, e.width, e.height), e = this.fromPixelsCanvas; + }var o = Tensor.make(n, {}, "int32");this.texData.get(o.dataId).usage = TextureUsage.PIXELS, this.gpgpu.uploadPixelDataToTexture(this.getTexture(o.dataId), e);var a = new FromPixelsProgram(r), + i = this.compileAndRun(a, [o]);return o.dispose(), i; + }, e.prototype.write = function (e, t) { + if (null == t) throw new Error("MathBackendWebGL.write(): values can not be null");this.throwIfNoData(e);var n = this.texData.get(e), + r = n.texture, + o = n.texShape, + a = n.usage;null != r && (this.releaseTexture(e, r, o, a), n.texture = null, n.texShape = null), n.usage = TextureUsage.UPLOAD, n.values = t, this.delayedStorage || this.uploadToGPU(e); + }, e.prototype.readSync = function (e) { + this.throwIfNoData(e);var t = this.texData.get(e), + n = t.shape, + r = t.texture, + o = t.values, + a = t.texShape, + i = t.dtype;if (null != o) return this.cacheOnCPU(e), o;var s, + u = null != this.activeTimers;u && (s = performance.now());var l = this.getValuesFromTexture(r, e, i, a, n);return u && (this.downloadWaitMs += performance.now() - s), this.cacheOnCPU(e, l), t.values; + }, e.prototype.read = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o, a, i, s, u, l, c;return __generator(this, function (p) { + switch (p.label) {case 0: + if (this.pendingRead.has(e)) return t = this.pendingRead.get(e), [2, new Promise(function (e) { + return t.push(e); + })];if (this.throwIfNoData(e), n = this.texData.get(e), r = n.shape, o = n.texture, a = n.values, i = n.texShape, s = n.dtype, null != a) return this.cacheOnCPU(e), [2, a];if (this.pendingRead.set(e, []), !ENV.get("WEBGL_DOWNLOAD_FLOAT_ENABLED") && 2 === ENV.get("WEBGL_VERSION")) throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and WEBGL_VERSION=2 not yet supported.");return u = this.gpgpu.maybeCreateBufferFromTexture(o, i[0], i[1]), [4, this.gpgpu.createAndWaitForFence()];case 1: + return p.sent(), l = u instanceof WebGLTexture ? this.getValuesFromTexture(o, e, s, i, r) : this.gpgpu.downloadFloat32MatrixFromBuffer(u, i[0], i[1]), this.cacheOnCPU(e, l), c = this.pendingRead.get(e), this.pendingRead.delete(e), c.forEach(function (e) { + return e(l); + }), this.pendingDisposal.has(e) && (this.pendingDisposal.delete(e), this.disposeData(e)), [2, l];} + }); + }); + }, e.prototype.getValuesFromTexture = function (e, t, n, r, o) { + if (ENV.get("WEBGL_DOWNLOAD_FLOAT_ENABLED")) return this.gpgpu.downloadFloat32MatrixFromOutputTexture(e, r[0], r[1]);var a = Tensor.make(o, {});this.texData.get(a.dataId).usage = TextureUsage.DOWNLOAD;var i = Tensor.make(o, { dataId: t }, n), + s = new EncodeFloatProgram(o);this.compileAndRun(s, [i], a, null, !1);var u = this.texData.get(a.dataId), + l = this.gpgpu.downloadByteEncodedFloatMatrixFromOutputTexture(u.texture, u.texShape[0], u.texShape[1]);return i.dispose(), a.dispose(), l; + }, e.prototype.time = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o, a, i;return __generator(this, function (s) { + switch (s.label) {case 0: + return t = this.activeTimers, n = [], r = !1, null == this.programTimersStack ? (this.programTimersStack = n, r = !0) : this.activeTimers.push(n), this.activeTimers = n, e(), o = flatten(this.activeTimers), this.activeTimers = t, r && (this.programTimersStack = null), [4, Promise.all(o).then(function (e) { + var t = 0;return e.forEach(function (e) { + return t += e; + }), t; + })];case 1: + return a = s.sent(), i = { uploadWaitMs: this.uploadWaitMs, downloadWaitMs: this.downloadWaitMs, kernelMs: a, wallMs: null }, this.uploadWaitMs = 0, this.downloadWaitMs = 0, [2, i];} + }); + }); + }, e.prototype.memory = function () { + return { unreliable: !1, numBytesInGPU: this.numBytesInGPU }; + }, e.prototype.startTimer = function () { + return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") > 0 ? this.gpgpu.beginQuery() : { startMs: performance.now(), endMs: null }; + }, e.prototype.endTimer = function (e) { + return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") > 0 ? (this.gpgpu.endQuery(), e) : (e.endMs = performance.now(), e); + }, e.prototype.getQueryTime = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t;return __generator(this, function (n) { + return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION") > 0 ? [2, this.gpgpu.waitForQueryAndGetTime(e)] : [2, (t = e).endMs - t.startMs]; + }); + }); + }, e.prototype.disposeData = function (e) { + if (!this.pendingDisposal.has(e)) if (this.pendingRead.has(e)) this.pendingDisposal.add(e);else if (this.texData.has(e)) { + var t = this.texData.get(e), + n = t.texture, + r = t.texShape, + o = t.usage;null != n && this.releaseTexture(e, n, r, o), this.texData.delete(e); + } + }, e.prototype.getTexture = function (e) { + return this.uploadToGPU(e), this.texData.get(e).texture; + }, e.prototype.getGPGPUContext = function () { + return this.gpgpu; + }, e.prototype.getCanvas = function () { + return this.canvas; + }, e.prototype.slice = function (e, t, n) { + var r = new SliceProgram(n), + o = r.getCustomSetupFunc(t);return this.compileAndRun(r, [e], null, o); + }, e.prototype.stridedSlice = function (e, t, n, r, o, a) { + var i = getStridedSlicedInfo(e.shape, t, n, r, o, a), + s = i[0], + u = i[1];if (u.some(function (e) { + return 0 === e; + })) return tensor([], u);var l = new StridedSliceProgram(s, r, u);return this.compileAndRun(l, [e]); + }, e.prototype.reverse = function (e, t) { + var n = new ReverseProgram(e.shape, t);return this.compileAndRun(n, [e]); + }, e.prototype.concat = function (e, t) { + var n = new ConcatProgram(e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.neg = function (e) { + var t = new UnaryOpProgram(e.shape, NEG);return this.compileAndRun(t, [e]); + }, e.prototype.matMul = function (e, t, n, r) { + var o = new MatMulProgram(e.shape, t.shape, n, r);return this.compileAndRun(o, [e, t]); + }, e.prototype.multiply = function (e, t) { + var n = new BinaryOpProgram(MUL, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, upcastType(e.dtype, t.dtype));return this.compileAndRun(n, [e, t], r); + }, e.prototype.batchNormalization = function (e, t, n, r, o, a) { + var i = [e, t, n], + s = null;null != a && (s = a.shape, i.push(a));var u = null;null != o && (u = o.shape, i.push(o));var l = new BatchNormProgram(e.shape, t.shape, n.shape, s, u, r);return this.compileAndRun(l, i); + }, e.prototype.localResponseNormalization4D = function (e, t, n, r, o) { + var a = new LRNProgram(e.shape, t, n, r, o);return this.compileAndRun(a, [e]); + }, e.prototype.LRNGrad = function (e, t, n, r, o, a, i) { + var s = new LRNGradProgram(t.shape, r, o, a, i);return this.compileAndRun(s, [t, n, e]); + }, e.prototype.tile = function (e, t) { + var n = new TileProgram(e.shape, t);return this.compileAndRun(n, [e]); + }, e.prototype.pad = function (e, t, n) { + var r = new PadProgram(e.shape, t, n);return this.compileAndRun(r, [e]); + }, e.prototype.transpose = function (e, t) { + var n = new TransposeProgram(e.shape, t);return this.compileAndRun(n, [e]); + }, e.prototype.gather = function (e, t, n) { + var r = new GatherProgram(e.shape, t.size, n);return this.compileAndRun(r, [e, t]); + }, e.prototype.batchToSpaceND = function (e, t, n) { + assert(e.rank <= 4, "batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");var r = t.reduce(function (e, t) { + return e * t; + }), + o = getReshaped(e.shape, t, r), + a = getPermuted(o.length, t.length), + i = getReshapedPermuted(e.shape, t, r), + s = getSliceBeginCoords(n, t.length), + u = getSliceSize(i, n, t.length);return e.reshape(o).transpose(a).reshape(i).slice(s, u); + }, e.prototype.spaceToBatchND = function (e, t, n) { + assert(e.rank <= 4, "spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");var r = t.reduce(function (e, t) { + return e * t; + }), + o = [[0, 0]];o.push.apply(o, n);for (var a = 1 + t.length; a < e.shape.length; ++a) o.push([0, 0]);var i = e.pad(o), + s = getReshaped(i.shape, t, r, !1), + u = getPermuted(s.length, t.length, !1), + l = getReshapedPermuted(i.shape, t, r, !1);return i.reshape(s).transpose(u).reshape(l); + }, e.prototype.reduce = function (e, t, n) { + var r = e.shape[0], + o = e.shape[1], + a = computeOptimalWindowSize(o), + i = new ReduceProgram({ windowSize: a, inSize: o, batchSize: r }, t), + s = i.outputShape, + u = s[0], + l = s[1], + c = this.makeOutputArray([u, l], n);return this.compileAndRun(i, [e], c), 1 === c.shape[1] ? c : this.reduce(c, t, n); + }, e.prototype.argReduce = function (e, t, n) { + void 0 === n && (n = null);var r = e.shape[0], + o = e.shape[1];null != n && (r = n.shape[0], o = n.shape[1]);var a = computeOptimalWindowSize(o), + i = new ArgMinMaxProgram({ windowSize: a, inSize: o, batchSize: r }, t, null == n), + s = i.outputShape, + u = s[0], + l = s[1], + c = this.makeOutputArray([u, l], "int32"), + p = [e];return null != n && p.push(n), this.compileAndRun(i, p, c), 1 === c.shape[1] ? c : this.argReduce(e, t, c); + }, e.prototype.sum = function (e, t) { + assertAxesAreInnerMostDims("sum", t, e.rank);var n = computeOutAndReduceShapes(e.shape, t), + r = n[0], + o = sizeFromShape(n[1]), + a = e.as2D(-1, o), + i = sumOutType(e.dtype);return this.reduce(a, "sum", i).reshape(r); + }, e.prototype.unsortedSegmentSum = function (e, t, n) { + var r = 0, + o = getAxesPermutation([r], e.rank), + a = e;null != o && (a = e.transpose(o), r = getInnerMostAxes(1, e.rank)[0]);var i = computeOutShape(a.shape, r, n), + s = sizeFromShape([a.shape[r]]), + u = a.as2D(-1, s), + l = sumOutType(e.dtype), + c = this.segOpCompute(u, "unsortedSegmentSum", t, l, n).reshape(i);return null != o && (c = c.transpose(getUndoAxesPermutation(o))), c; + }, e.prototype.segOpCompute = function (e, t, n, r, o) { + var a = e.shape[0], + i = e.shape[1], + s = segOpComputeOptimalWindowSize(i, o), + u = new SegmentOpProgram({ windowSize: s, inSize: i, batchSize: a, numSegments: o }, t), + l = u.outputShape, + c = l[0], + p = l[1], + d = this.makeOutputArray([c, p], r);return this.compileAndRun(u, [e, n], d), d.shape[1] === o ? d : (n = range(0, o).tile([i / s]), this.segOpCompute(d, t, n, r, o)); + }, e.prototype.argMin = function (e, t) { + var n = [t];assertAxesAreInnerMostDims("argMin", n, e.rank);var r = computeOutAndReduceShapes(e.shape, n), + o = r[0], + a = sizeFromShape(r[1]), + i = e.as2D(-1, a);return this.argReduce(i, "min").reshape(o); + }, e.prototype.argMax = function (e, t) { + var n = [t];assertAxesAreInnerMostDims("argMax", n, e.rank);var r = computeOutAndReduceShapes(e.shape, n), + o = r[0], + a = sizeFromShape(r[1]), + i = e.as2D(-1, a);return this.argReduce(i, "max").reshape(o); + }, e.prototype.cumsum = function (e, t, n, r) { + if (t !== e.rank - 1) throw new Error("WebGL cumsum shader expects an inner-most axis=" + (e.rank - 1) + " but got axis=" + t);var o = new CumSumProgram(e.shape, n, r);return this.compileAndRun(o, [e]); + }, e.prototype.equal = function (e, t) { + var n = new BinaryOpProgram(EQUAL, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.notEqual = function (e, t) { + var n = new BinaryOpProgram(NOT_EQUAL, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.less = function (e, t) { + var n = new BinaryOpProgram(LESS, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.lessEqual = function (e, t) { + var n = new BinaryOpProgram(LESS_EQUAL, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.greater = function (e, t) { + var n = new BinaryOpProgram(GREATER, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.greaterEqual = function (e, t) { + var n = new BinaryOpProgram(GREATER_EQUAL, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.logicalNot = function (e) { + var t = new UnaryOpProgram(e.shape, LOGICAL_NOT);return this.compileAndRun(t, [e]); + }, e.prototype.logicalAnd = function (e, t) { + var n = new BinaryOpProgram(LOGICAL_AND, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.logicalOr = function (e, t) { + var n = new BinaryOpProgram(LOGICAL_OR, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "bool");return this.compileAndRun(n, [e, t], r); + }, e.prototype.select = function (e, t, n) { + var r = new SelectProgram(e.rank, t.shape, t.rank), + o = this.makeOutputArray(r.outputShape, upcastType(t.dtype, n.dtype));return this.compileAndRun(r, [e, t, n], o); + }, e.prototype.where = function (e) { + warn("tf.where() in webgl locks the UI thread. Call tf.whereAsync() instead");var t = e.dataSync();return whereImpl(e.shape, t); + }, e.prototype.topk = function (e, t, n) { + return topkImpl(e.dataSync(), e.shape, e.dtype, t, n); + }, e.prototype.min = function (e, t) { + assertAxesAreInnerMostDims("min", t, e.rank);var n = computeOutAndReduceShapes(e.shape, t), + r = n[0], + o = sizeFromShape(n[1]), + a = e.as2D(-1, o);return this.reduce(a, "min", a.dtype).reshape(r); + }, e.prototype.minimum = function (e, t) { + var n = new BinaryOpProgram(MIN, e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.mod = function (e, t) { + var n = new BinaryOpProgram(MOD, e.shape, t.shape), + r = n.getCustomSetupFunc();return this.compileAndRun(n, [e, t], null, r); + }, e.prototype.max = function (e, t) { + assertAxesAreInnerMostDims("max", t, e.rank);var n = computeOutAndReduceShapes(e.shape, t), + r = n[0], + o = sizeFromShape(n[1]), + a = e.as2D(-1, o);return this.reduce(a, "max", a.dtype).reshape(r); + }, e.prototype.maximum = function (e, t) { + var n = new BinaryOpProgram(MAX, e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.all = function (e, t) { + assertAxesAreInnerMostDims("all", t, e.rank);var n = computeOutAndReduceShapes(e.shape, t), + r = n[0], + o = sizeFromShape(n[1]), + a = e.as2D(-1, o);return this.reduce(a, "all", a.dtype).reshape(r); + }, e.prototype.any = function (e, t) { + assertAxesAreInnerMostDims("any", t, e.rank);var n = computeOutAndReduceShapes(e.shape, t), + r = n[0], + o = sizeFromShape(n[1]), + a = e.as2D(-1, o);return this.reduce(a, "any", a.dtype).reshape(r); + }, e.prototype.squaredDifference = function (e, t) { + var n = new BinaryOpProgram(SQUARED_DIFFERENCE, e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.realDivide = function (e, t) { + var n = new BinaryOpProgram(DIV, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "float32");return this.compileAndRun(n, [e, t], r); + }, e.prototype.floorDiv = function (e, t) { + var n = new BinaryOpProgram(INT_DIV, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, "int32");return this.compileAndRun(n, [e, t], r); + }, e.prototype.add = function (e, t) { + var n = new BinaryOpProgram(ADD, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, upcastType(e.dtype, t.dtype));return this.compileAndRun(n, [e, t], r); + }, e.prototype.addN = function (e) { + for (var t = e[0], n = 1; n < e.length; n++) t = this.add(t, e[n]);return t; + }, e.prototype.subtract = function (e, t) { + var n = new BinaryOpProgram(SUB, e.shape, t.shape), + r = this.makeOutputArray(n.outputShape, upcastType(e.dtype, t.dtype));return this.compileAndRun(n, [e, t], r); + }, e.prototype.pow = function (e, t) { + var n = new BinaryOpProgram(POW, e.shape, t.shape), + r = n.getCustomSetupFunc(), + o = this.makeOutputArray(n.outputShape, upcastType(e.dtype, t.dtype));return this.compileAndRun(n, [e, t], o, r); + }, e.prototype.ceil = function (e) { + var t = new UnaryOpProgram(e.shape, CEIL);return this.compileAndRun(t, [e]); + }, e.prototype.floor = function (e) { + var t = new UnaryOpProgram(e.shape, FLOOR);return this.compileAndRun(t, [e]); + }, e.prototype.sign = function (e) { + var t = new UnaryOpProgram(e.shape, SIGN);return this.compileAndRun(t, [e]); + }, e.prototype.round = function (e) { + var t = new UnaryOpProgram(e.shape, ROUND);return this.compileAndRun(t, [e]); + }, e.prototype.exp = function (e) { + var t = new UnaryOpProgram(e.shape, EXP);return this.compileAndRun(t, [e]); + }, e.prototype.expm1 = function (e) { + var t = new UnaryOpProgram(e.shape, EXPM1);return this.compileAndRun(t, [e]); + }, e.prototype.log = function (e) { + var t = new UnaryOpProgram(e.shape, LOG), + n = t.getCustomSetupFunc();return this.compileAndRun(t, [e], null, n); + }, e.prototype.log1p = function (e) { + var t = new UnaryOpProgram(e.shape, LOG1P);return this.compileAndRun(t, [e]); + }, e.prototype.sqrt = function (e) { + var t = new UnaryOpProgram(e.shape, SQRT);return this.compileAndRun(t, [e]); + }, e.prototype.rsqrt = function (e) { + var t = new UnaryOpProgram(e.shape, RSQRT);return this.compileAndRun(t, [e]); + }, e.prototype.square = function (e) { + var t = new UnaryOpProgram(e.shape, SQUARE);return this.compileAndRun(t, [e]); + }, e.prototype.reciprocal = function (e) { + var t = new UnaryOpProgram(e.shape, RECIPROCAL);return this.compileAndRun(t, [e]); + }, e.prototype.relu = function (e) { + var t = new UnaryOpProgram(e.shape, RELU);return this.compileAndRun(t, [e]); + }, e.prototype.elu = function (e) { + var t = new UnaryOpProgram(e.shape, ELU);return this.compileAndRun(t, [e]); + }, e.prototype.eluDer = function (e, t) { + var n = new BinaryOpProgram(ELU_DER, e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.selu = function (e) { + var t = new UnaryOpProgram(e.shape, SELU);return this.compileAndRun(t, [e]); + }, e.prototype.int = function (e) { + var t = new UnaryOpProgram(e.shape, TO_INT), + n = this.makeOutputArray(t.outputShape, "int32");return this.compileAndRun(t, [e], n); + }, e.prototype.clip = function (e, t, n) { + var r = new ClipProgram(e.shape, t, n);return this.compileAndRun(r, [e]); + }, e.prototype.abs = function (e) { + var t = new UnaryOpProgram(e.shape, ABS);return this.compileAndRun(t, [e]); + }, e.prototype.sigmoid = function (e) { + var t = new UnaryOpProgram(e.shape, SIGMOID);return this.compileAndRun(t, [e]); + }, e.prototype.softplus = function (e) { + var t = new UnaryOpProgram(e.shape, SOFTPLUS);return this.compileAndRun(t, [e]); + }, e.prototype.sin = function (e) { + var t = new UnaryOpProgram(e.shape, SIN);return this.compileAndRun(t, [e]); + }, e.prototype.cos = function (e) { + var t = new UnaryOpProgram(e.shape, COS);return this.compileAndRun(t, [e]); + }, e.prototype.tan = function (e) { + var t = new UnaryOpProgram(e.shape, TAN);return this.compileAndRun(t, [e]); + }, e.prototype.asin = function (e) { + var t = new UnaryOpProgram(e.shape, ASIN);return this.compileAndRun(t, [e]); + }, e.prototype.acos = function (e) { + var t = new UnaryOpProgram(e.shape, ACOS);return this.compileAndRun(t, [e]); + }, e.prototype.atan = function (e) { + var t = new UnaryOpProgram(e.shape, ATAN);return this.compileAndRun(t, [e]); + }, e.prototype.atan2 = function (e, t) { + var n = new BinaryOpProgram(ATAN2, e.shape, t.shape);return this.compileAndRun(n, [e, t]); + }, e.prototype.sinh = function (e) { + var t = new UnaryOpProgram(e.shape, SINH);return this.compileAndRun(t, [e]); + }, e.prototype.cosh = function (e) { + var t = new UnaryOpProgram(e.shape, COSH);return this.compileAndRun(t, [e]); + }, e.prototype.tanh = function (e) { + var t = new UnaryOpProgram(e.shape, TANH);return this.compileAndRun(t, [e]); + }, e.prototype.asinh = function (e) { + var t = new UnaryOpProgram(e.shape, ASINH);return this.compileAndRun(t, [e]); + }, e.prototype.acosh = function (e) { + var t = new UnaryOpProgram(e.shape, ACOSH), + n = t.getCustomSetupFunc();return this.compileAndRun(t, [e], null, n); + }, e.prototype.atanh = function (e) { + var t = new UnaryOpProgram(e.shape, ATANH), + n = t.getCustomSetupFunc();return this.compileAndRun(t, [e], null, n); + }, e.prototype.erf = function (e) { + var t = new UnaryOpProgram(e.shape, ERF);return this.compileAndRun(t, [e]); + }, e.prototype.step = function (e, t) { + var n = new UnaryOpProgram(e.shape, STEP(t));return this.compileAndRun(n, [e]); + }, e.prototype.conv2d = function (e, t, n) { + var r = new Conv2DProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.conv2dDerInput = function (e, t, n) { + var r = new Conv2DDerInputProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.conv2dDerFilter = function (e, t, n) { + var r = new Conv2DDerFilterProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.depthwiseConv2D = function (e, t, n) { + var r = new DepthwiseConv2DProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.depthwiseConv2DDerInput = function (e, t, n) { + var r = new DepthwiseConv2DDerInputProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.depthwiseConv2DDerFilter = function (e, t, n) { + var r = new DepthwiseConv2DDerFilterProgram(n);return this.compileAndRun(r, [e, t]); + }, e.prototype.maxPool = function (e, t) { + var n = new Pool2DProgram(t, "max", !1), + r = this.makeOutputArray(n.outputShape, e.dtype);return this.compileAndRun(n, [e], r); + }, e.prototype.avgPool = function (e, t) { + var n = new Pool2DProgram(t, "avg", !1), + r = this.makeOutputArray(n.outputShape, "float32");return this.compileAndRun(n, [e], r); + }, e.prototype.maxPoolBackprop = function (e, t, n, r) { + var o = new Pool2DProgram(r, "max", !0), + a = this.compileAndRun(o, [t]), + i = new MaxPool2DBackpropProgram(r), + s = this.makeOutputArray(i.outputShape, t.dtype), + u = this.compileAndRun(i, [e, a], s);return a.dispose(), u; + }, e.prototype.avgPoolBackprop = function (e, t, n) { + var r = new AvgPool2DBackpropProgram(n), + o = this.makeOutputArray(r.outputShape, t.dtype);return this.compileAndRun(r, [e], o); + }, e.prototype.cast = function (e, t) { + return castTensor(e, t, this); + }, e.prototype.reshape = function (e, t) { + return reshapeTensor(e, t); + }, e.prototype.resizeBilinear = function (e, t, n, r) { + var o = new ResizeBilinearProgram(e.shape, t, n, r);return this.compileAndRun(o, [e]); + }, e.prototype.resizeBilinearBackprop = function (e, t, n) { + var r = new ResizeBilinearBackpropProgram(e, t, n);return this.compileAndRun(r, [e]); + }, e.prototype.resizeNearestNeighbor = function (e, t, n, r) { + var o = new ResizeNearestNeighborProgram(e.shape, t, n, r);return this.compileAndRun(o, [e]); + }, e.prototype.resizeNearestNeighborBackprop = function (e, t, n) { + var r = new ResizeNearestNeigborBackpropProgram(e, t, n);return this.compileAndRun(r, [e]); + }, e.prototype.multinomial = function (e, t, n, r) { + var o = t ? e : softmax(e), + a = o.shape[0], + i = o.shape[1], + s = new MultinomialProgram(a, i, n), + u = this.makeOutputArray(s.outputShape, "int32"), + l = s.getCustomSetupFunc(r);return this.compileAndRun(s, [o], u, l); + }, e.prototype.oneHot = function (e, t, n, r) { + var o = new OneHotProgram(e.size, t, n, r);return this.compileAndRun(o, [e]); + }, e.prototype.nonMaxSuppression = function (e, t, n, r, o) { + return warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead"), nonMaxSuppressionImpl(e.dataSync(), t.dataSync(), n, r, o); + }, e.prototype.makeOutputArray = function (e, t) { + return Tensor.make(e, {}, t); + }, e.prototype.compileAndRun = function (e, t, n, r, o) { + var a = this;void 0 === o && (o = !0), null == n && (n = this.makeOutputArray(e.outputShape, t[0].dtype));var i = t.map(function (e) { + var t = a.texData.get(e.dataId);return null == t.texture && e.size <= SIZE_UPLOAD_UNIFORM ? { tensor: e, texData: null, isUniform: !0 } : (a.uploadToGPU(e.dataId), { tensor: e, texData: t, isUniform: !1 }); + });this.uploadToGPU(n.dataId);var s, + u = { tensor: n, texData: this.texData.get(n.dataId), isUniform: !1 }, + l = makeShaderKey(e, i, u), + c = this.getAndSaveBinary(l, function () { + return compileProgram(a.gpgpu, e, i, u); + }), + p = null != this.activeTimers;if (p && (s = this.startTimer()), runProgram(c, i, u, r), o && this.numBytesInGPU > this.NUM_BYTES_BEFORE_PAGING) for (var d = this.numBytesInGPU - this.NUM_BYTES_BEFORE_PAGING; d > 0 && this.lruDataGPU.length > 0;) { + var h = this.lruDataGPU.shift(), + f = this.texData.get(h), + m = f.shape, + g = f.dtype;d -= this.computeBytes(m, g), this.read(h); + }return p && (s = this.endTimer(s), this.activeTimers.push(this.getQueryTime(s))), n; + }, e.prototype.getAndSaveBinary = function (e, t) { + return e in this.binaryCache || (this.binaryCache[e] = t()), this.binaryCache[e]; + }, e.prototype.getTextureManager = function () { + return this.textureManager; + }, e.prototype.dispose = function () { + if (!this.disposed) { + for (var e in this.binaryCache) this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram);this.textureManager.dispose(), this.canvas.remove(), null != this.fromPixelsCanvas && this.fromPixelsCanvas.remove(), this.gpgpuCreatedLocally && this.gpgpu.dispose(), this.disposed = !0; + } + }, e.prototype.throwIfNoData = function (e) { + if (!this.texData.has(e)) throw new Error("WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends"); + }, e.prototype.uploadToGPU = function (e) { + this.throwIfNoData(e);var t = this.texData.get(e), + n = t.shape, + r = t.values, + o = t.texture, + a = t.dtype, + i = t.usage;if (null == o) { + var s, + u = null != this.activeTimers;u && (s = performance.now());var l = getTextureShapeFromLogicalShape(this.gpgpu.gl, n);t.texShape = l;var c = this.acquireTexture(e, l, i);t.texture = c, null != r && (this.gpgpu.uploadMatrixToTexture(c, l[0], l[1], typedArrayToFloat32(r, a)), t.values = null, u && (this.uploadWaitMs += performance.now() - s)); + } else { + this.lruDataGPU.indexOf(e) >= 0 && (this.lruDataGPU.splice(this.lruDataGPU.indexOf(e), 1), this.lruDataGPU.push(e)); + } + }, e.prototype.cacheOnCPU = function (e, t) { + var n = this.delayedStorage, + r = this.texData.get(e), + o = r.texture, + a = r.texShape, + i = r.dtype, + s = r.usage;n && null != o && (this.releaseTexture(e, o, a, s), r.texture = null, r.texShape = null), null != t && (r.values = float32ToTypedArray(t, i)); + }, e.prototype.releaseTexture = function (e, t, n, r) { + var o = this.texData.get(e), + a = o.shape, + i = o.dtype, + s = this.lruDataGPU.indexOf(e);s >= 0 && this.lruDataGPU.splice(s, 1), this.numBytesInGPU -= this.computeBytes(a, i), this.textureManager.releaseTexture(t, n, r); + }, e.prototype.acquireTexture = function (e, t, n) { + var r = this.texData.get(e), + o = r.shape, + a = r.dtype;return this.lruDataGPU.push(e), this.numBytesInGPU += this.computeBytes(o, a), this.textureManager.acquireTexture(t, n); + }, e.prototype.computeBytes = function (e, t) { + return sizeFromShape(e) * bytesPerElement(t); + }, e; + }();function float32ToTypedArray(e, t) { + if ("float32" === t) return e;if ("int32" === t || "bool" === t) { + for (var n = "int32" === t ? new Int32Array(e.length) : new Uint8Array(e.length), r = 0; r < n.length; ++r) n[r] = Math.round(e[r]);return n; + }throw new Error("Unknown dtype " + t); + }function typedArrayToFloat32(e, t) { + return e instanceof Float32Array ? e : new Float32Array(e); + }function neg_(e) { + var t = convertToTensor(e, "x", "neg");return ENV.engine.runKernel(function (e) { + return e.neg(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.neg(); + } }; + }); + }function ceil_(e) { + var t = convertToTensor(e, "x", "ceil");return ENV.engine.runKernel(function (e) { + return e.ceil(t); + }, { $x: t }, function (e) { + return { $x: function () { + return zerosLike(e); + } }; + }); + }function floor_(e) { + var t = convertToTensor(e, "x", "floor");return ENV.engine.runKernel(function (e) { + return e.floor(t); + }, { $x: t }, function (e) { + return { $x: function () { + return zerosLike(e); + } }; + }); + }function sign_(e) { + var t = convertToTensor(e, "x", "sign");return ENV.engine.runKernel(function (e) { + return e.sign(t); + }, { $x: t }, function (e) { + return { $x: function () { + return zerosLike(e); + } }; + }); + }function round_(e) { + var t = convertToTensor(e, "x", "round");return ENV.engine.runKernel(function (e) { + return e.round(t); + }, { $x: t }, function (e) { + return { $x: function () { + return zerosLike(e); + } }; + }); + }function exp_(e) { + var t = convertToTensor(e, "x", "exp");return ENV.engine.runKernel(function (e, n) { + return n(e.exp(t)); + }, { $x: t }, function (e, t) { + var n = t[0];return { $x: function () { + return e.mulStrict(n); + } }; + }); + }function expm1_(e) { + var t = convertToTensor(e, "x", "expm1");return ENV.engine.runKernel(function (e) { + return e.expm1(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(t.exp()); + } }; + }); + }function log_(e) { + var t = convertToTensor(e, "x", "log");return ENV.engine.runKernel(function (e) { + return e.log(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.toFloat()); + } }; + }); + }function log1p_(e) { + var t = convertToTensor(e, "x", "log1p");return ENV.engine.runKernel(function (e) { + return e.log1p(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.add(scalar(1))); + } }; + }); + }function sqrt_(e) { + var t = convertToTensor(e, "x", "sqrt");return ENV.engine.runKernel(function (e) { + return e.sqrt(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.toFloat().sqrt().mul(scalar(2))); + } }; + }); + }function rsqrt_(e) { + var t = convertToTensor(e, "x", "rsqrt");return ENV.engine.runKernel(function (e) { + return e.rsqrt(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.pow(scalar(1.5)).mul(scalar(2))).neg(); + } }; + }); + }function square_(e) { + var t = convertToTensor(e, "x", "square");return ENV.engine.runKernel(function (e) { + return e.square(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(t.toFloat().mul(scalar(2))); + } }; + }); + }function reciprocal_(e) { + var t = convertToTensor(e, "x", "reciprocal");return ENV.engine.runKernel(function (e) { + return e.reciprocal(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.square().neg()); + } }; + }); + }function abs_(e) { + var t = convertToTensor(e, "x", "abs");return ENV.engine.runKernel(function (e) { + return e.abs(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(t.toFloat().step(-1)); + } }; + }); + }function clipByValue_(e, t, n) { + var r = convertToTensor(e, "x", "clipByValue");assert(t <= n, "Error in clip: min (" + t + ") must be less than or equal to max (" + n + ").");return ENV.engine.runKernel(function (e) { + return e.clip(r, t, n); + }, { $x: r }, function (e) { + return { $x: function () { + return e.where(r.greaterEqual(scalar(t)).logicalAnd(r.lessEqual(scalar(n))), zerosLike(e)); + } }; + }); + }function sigmoid_(e) { + var t = convertToTensor(e, "x", "sigmoid");return ENV.engine.runKernel(function (e, n) { + return n(e.sigmoid(t)); + }, { $x: t }, function (e, t) { + var n = t[0];return { $x: function () { + return e.mulStrict(n.mul(scalar(1).sub(n))); + } }; + }); + }function logSigmoid_(e) { + var t = convertToTensor(e, "x", "logSigmoid");return ENV.engine.runKernel(function (e) { + return e.softplus(t.neg()).neg(); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(t.neg().sigmoid()); + } }; + }); + }function softplus_(e) { + var t = convertToTensor(e, "x", "softplus");return ENV.engine.runKernel(function (e) { + return e.softplus(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(t.sigmoid()); + } }; + }); + }function sin_(e) { + var t = convertToTensor(e, "x", "sin");return ENV.engine.runKernel(function (e) { + return e.sin(t); + }, { $x: t }, function (e) { + return { $x: function () { + return t.toFloat().cos().mulStrict(e); + } }; + }); + }function cos_(e) { + var t = convertToTensor(e, "x", "cos");return ENV.engine.runKernel(function (e) { + return e.cos(t); + }, { $x: t }, function (e) { + return { $x: function () { + return t.toFloat().sin().neg().mulStrict(e); + } }; + }); + }function tan_(e) { + var t = convertToTensor(e, "x", "tan");return ENV.engine.runKernel(function (e) { + return e.tan(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.cos().square()); + } }; + }); + }function asin_(e) { + var t = convertToTensor(e, "x", "asin");return ENV.engine.runKernel(function (e) { + return e.asin(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(scalar(1).sub(t.toFloat().square()).sqrt()); + } }; + }); + }function acos_(e) { + var t = convertToTensor(e, "x", "acos");return ENV.engine.runKernel(function (e) { + return e.acos(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(scalar(1).sub(t.toFloat().square()).sqrt()).neg(); + } }; + }); + }function atan_(e) { + var t = convertToTensor(e, "x", "atan");return ENV.engine.runKernel(function (e) { + return e.atan(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(scalar(1).add(t.toFloat().square())); + } }; + }); + }function sinh_(e) { + var t = convertToTensor(e, "x", "sinh");return ENV.engine.runKernel(function (e) { + return e.sinh(t); + }, { $x: t }, function (e) { + return { $x: function () { + return t.toFloat().cosh().mulStrict(e); + } }; + }); + }function cosh_(e) { + var t = convertToTensor(e, "x", "cosh");return ENV.engine.runKernel(function (e) { + return e.cosh(t); + }, { $x: t }, function (e) { + return { $x: function () { + return t.toFloat().sinh().mulStrict(e); + } }; + }); + }function tanh_(e) { + var t = convertToTensor(e, "x", "tanh");return ENV.engine.runKernel(function (e, n) { + return n(e.tanh(t)); + }, { $x: t }, function (e, t) { + var n = t[0];return { $x: function () { + return scalar(1).sub(n.square()).mulStrict(e); + } }; + }); + }function asinh_(e) { + var t = convertToTensor(e, "x", "asinh");return ENV.engine.runKernel(function (e) { + return e.asinh(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(scalar(1).add(t.toFloat().square()).sqrt()); + } }; + }); + }function acosh_(e) { + var t = convertToTensor(e, "x", "acosh");return ENV.engine.runKernel(function (e) { + return e.acosh(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(t.toFloat().square().sub(scalar(1)).sqrt()); + } }; + }); + }function atanh_(e) { + var t = convertToTensor(e, "x", "atanh");return ENV.engine.runKernel(function (e) { + return e.atanh(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.divStrict(scalar(1).sub(t.toFloat().square())); + } }; + }); + }function erf_(e) { + var t = convertToTensor(e, "x", "erf");assert("int32" === t.dtype || "float32" === t.dtype, "Input dtype must be `int32` or `float32`."), "int32" === t.dtype && (t = t.toFloat());return ENV.engine.runKernel(function (e) { + return e.erf(t); + }, { $x: t }, function (e) { + return { $x: function () { + return e.mulStrict(scalar(2 / Math.sqrt(Math.PI)).mul(t.square().neg().exp())); + } }; + }); + }function step_(e, t) { + void 0 === t && (t = 0);var n = convertToTensor(e, "x", "step");return ENV.engine.runKernel(function (e) { + return e.step(n, t); + }, { $x: n }, function (e) { + return { $x: function () { + return zerosLike(e); + } }; + }); + }ENV.get("IS_BROWSER") && ENV.registerBackend("webgl", function () { + return new MathBackendWebGL(); + }, 2, setTensorTracker);var abs = op({ abs_: abs_ }), + acos = op({ acos_: acos_ }), + acosh = op({ acosh_: acosh_ }), + asin = op({ asin_: asin_ }), + asinh = op({ asinh_: asinh_ }), + atan = op({ atan_: atan_ }), + atanh = op({ atanh_: atanh_ }), + ceil = op({ ceil_: ceil_ }), + clipByValue = op({ clipByValue_: clipByValue_ }), + cos = op({ cos_: cos_ }), + cosh = op({ cosh_: cosh_ }), + erf = op({ erf_: erf_ }), + exp = op({ exp_: exp_ }), + expm1 = op({ expm1_: expm1_ }), + floor = op({ floor_: floor_ }), + log$1 = op({ log_: log_ }), + log1p = op({ log1p_: log1p_ }), + logSigmoid = op({ logSigmoid_: logSigmoid_ }), + neg = op({ neg_: neg_ }), + reciprocal = op({ reciprocal_: reciprocal_ }), + round = op({ round_: round_ }), + rsqrt = op({ rsqrt_: rsqrt_ }), + sigmoid = op({ sigmoid_: sigmoid_ }), + sign = op({ sign_: sign_ }), + sin = op({ sin_: sin_ }), + sinh = op({ sinh_: sinh_ }), + softplus = op({ softplus_: softplus_ }), + sqrt = op({ sqrt_: sqrt_ }), + square = op({ square_: square_ }), + step = op({ step_: step_ }), + tan = op({ tan_: tan_ }), + tanh$1 = op({ tanh_: tanh_ });function batchNormalization2d_(e, t, n, r, o, a) { + void 0 === r && (r = .001);var i, + s, + u = convertToTensor(e, "x", "batchNormalization"), + l = convertToTensor(t, "mean", "batchNormalization"), + c = convertToTensor(n, "variance", "batchNormalization");return null != o && (i = convertToTensor(o, "scale", "batchNormalization")), null != a && (s = convertToTensor(a, "offset", "batchNormalization")), assert(2 === u.rank, "Error in batchNormalization3D: x must be rank 3 but got rank " + u.rank + "."), assert(2 === l.rank || 1 === l.rank, "Error in batchNormalization2D: mean must be rank 2 or rank 1 but got rank " + l.rank + "."), assert(2 === c.rank || 1 === c.rank, "Error in batchNormalization2D: variance must be rank 2 or rank 1 but got rank " + c.rank + "."), null != i && assert(2 === i.rank || 1 === i.rank, "Error in batchNormalization2D: scale must be rank 2 or rank 1 but got rank " + i.rank + "."), null != s && assert(2 === s.rank || 1 === s.rank, "Error in batchNormalization2D: offset must be rank 2 or rank 1 but got rank " + s.rank + "."), batchNormalization(u, l, c, r, i, s); + }function batchNormalization3d_(e, t, n, r, o, a) { + void 0 === r && (r = .001);var i, + s, + u = convertToTensor(e, "x", "batchNormalization"), + l = convertToTensor(t, "mean", "batchNormalization"), + c = convertToTensor(n, "variance", "batchNormalization");return null != o && (i = convertToTensor(o, "scale", "batchNormalization")), null != a && (s = convertToTensor(a, "offset", "batchNormalization")), assert(3 === u.rank, "Error in batchNormalization3D: x must be rank 3 but got rank " + u.rank + "."), assert(3 === l.rank || 1 === l.rank, "Error in batchNormalization3D: mean must be rank 3 or rank 1 but got rank " + l.rank + "."), assert(3 === c.rank || 1 === c.rank, "Error in batchNormalization3D: variance must be rank 3 or rank 1 but got rank " + c.rank + "."), null != i && assert(3 === i.rank || 1 === i.rank, "Error in batchNormalization3D: scale must be rank 3 or rank 1 but got rank " + i.rank + "."), null != s && assert(3 === s.rank || 1 === s.rank, "Error in batchNormalization3D: offset must be rank 3 or rank 1 but got rank " + s.rank + "."), batchNormalization(u, l, c, r, i, s); + }function batchNormalization4d_(e, t, n, r, o, a) { + void 0 === r && (r = .001);var i, + s, + u = convertToTensor(e, "x", "batchNormalization"), + l = convertToTensor(t, "mean", "batchNormalization"), + c = convertToTensor(n, "variance", "batchNormalization");return null != o && (i = convertToTensor(o, "scale", "batchNormalization")), null != a && (s = convertToTensor(a, "offset", "batchNormalization")), assert(4 === u.rank, "Error in batchNormalization4D: x must be rank 4 but got rank " + u.rank + "."), assert(4 === l.rank || 1 === l.rank, "Error in batchNormalization4D: mean must be rank 4 or rank 1 but got rank " + l.rank + "."), assert(4 === c.rank || 1 === c.rank, "Error in batchNormalization4D: variance must be rank 4 or rank 1 but got rank " + c.rank + "."), null != i && assert(4 === i.rank || 1 === i.rank, "Error in batchNormalization4D: scale must be rank 4 or rank 1 but got rank " + i.rank + "."), null != s && assert(4 === s.rank || 1 === s.rank, "Error in batchNormalization4D: offset must be rank 4 or rank 1 but got rank " + s.rank + "."), batchNormalization(u, l, c, r, i, s); + }function batchNormalization_(e, t, n, r, o, a) { + void 0 === r && (r = .001);var i, + s, + u, + l = convertToTensor(e, "x", "batchNormalization"), + c = convertToTensor(t, "mean", "batchNormalization"), + p = convertToTensor(n, "variance", "batchNormalization");null != o && (i = convertToTensor(o, "scale", "batchNormalization")), null != a && (s = convertToTensor(a, "offset", "batchNormalization")), assert(c.rank === p.rank, "Batch normalization gradient requires mean and variance to have equal ranks."), assert(null == s || c.rank === s.rank, "Batch normalization gradient requires mean and offset to have equal ranks."), assert(null == i || c.rank === i.rank, "Batch normalization gradient requires mean and scale to have equal ranks."), u = 0 === l.rank || 1 === l.rank ? l.as4D(1, 1, 1, l.size) : 2 === l.rank ? l.as4D(1, 1, l.shape[0], l.shape[1]) : 3 === l.rank ? l.as4D(1, l.shape[0], l.shape[1], l.shape[2]) : l;return ENV.engine.runKernel(function (e) { + return e.batchNormalization(u, batchnormReshape4D(c), batchnormReshape4D(p), r, batchnormReshape4D(i), batchnormReshape4D(s)); + }, { $x: l, $mean: c, $variance: p, $scale: i, $offset: s }, function (e) { + var t = null == i ? scalar(1) : i, + n = getReductionAxes(c.shape, u.shape), + o = [];if (1 === c.rank) { + for (var a = 0; a < u.shape.length - 1; ++a) o.push(u.shape[a]);o.push(1); + }var s = l.sub(c), + d = e.mul(t), + h = rsqrt(p.add(scalar(r))), + f = h.mul(h).mul(h).mul(scalar(-.5));return { $x: function () { + return 1 === c.rank ? e.mul(tile(h.as4D(1, 1, 1, c.shape[0]), o)).mul(t).reshape(l.shape) : e.mul(h).mul(t).reshape(l.shape); + }, $mean: function () { + var e = h.mul(scalar(-1)).mul(d);return 1 === c.rank && (e = e.sum(n)), e.reshape(c.shape); + }, $variance: function () { + var e = f.mul(s).mul(d);return 1 === c.rank && (e = e.sum(n)), e.reshape(c.shape); + }, $scale: function () { + var t = s.mul(h), + r = e.mul(t);return 1 === c.rank && (r = r.sum(n)), r.reshape(c.shape); + }, $offset: function () { + var t = e;return 1 === c.rank && (t = t.sum(n)), t.reshape(c.shape); + } }; + }).reshape(l.shape); + }function batchnormReshape4D(e) { + return null == e ? null : 0 === e.rank ? e.as1D() : 1 === e.rank ? e : 2 === e.rank ? e.as4D(1, 1, e.shape[0], e.shape[1]) : 3 === e.rank ? e.as4D(1, e.shape[0], e.shape[1], e.shape[2]) : e; + }var batchNormalization2d = op({ batchNormalization2d_: batchNormalization2d_ }), + batchNormalization3d = op({ batchNormalization3d_: batchNormalization3d_ }), + batchNormalization4d = op({ batchNormalization4d_: batchNormalization4d_ }), + batchNormalization = op({ batchNormalization_: batchNormalization_ });function computePool2DInfo(e, t, n, r, o, a) { + void 0 === a && (a = "channelsLast");var i, + s = parseTupleParam(t), + u = s[0], + l = s[1];if ("channelsLast" === a) i = [u, l, e[3], e[3]];else { + if ("channelsFirst" !== a) throw new Error("Unknown dataFormat " + a);i = [u, l, e[1], e[1]]; + }return computeConv2DInfo(e, i, n, 1, r, o, !1, a); + }function computeConv2DInfo(e, t, n, r, o, a, i, s) { + void 0 === i && (i = !1), void 0 === s && (s = "channelsLast");var u = [-1, -1, -1, -1], + l = u[0], + c = u[1], + p = u[2], + d = u[3];if ("channelsLast" === s) l = e[0], c = e[1], p = e[2], d = e[3];else { + if ("channelsFirst" !== s) throw new Error("Unknown dataFormat " + s);l = e[0], d = e[1], c = e[2], p = e[3]; + }var h, + f = t[0], + m = t[1], + g = t[3], + v = parseTupleParam(n), + y = v[0], + x = v[1], + T = parseTupleParam(r), + S = T[0], + b = T[1], + E = getPadAndOutInfo(o, c, p, y, x, getEffectiveFilterSize(f, S), getEffectiveFilterSize(m, b), a), + w = E.padInfo, + _ = E.outHeight, + A = E.outWidth, + R = i ? g * d : g;return "channelsFirst" === s ? h = [l, R, _, A] : "channelsLast" === s && (h = [l, _, A, R]), { batchSize: l, dataFormat: s, inHeight: c, inWidth: p, inChannels: d, outHeight: _, outWidth: A, outChannels: R, padInfo: w, strideHeight: y, strideWidth: x, filterHeight: f, filterWidth: m, dilationHeight: S, dilationWidth: b, inShape: e, outShape: h, filterShape: t }; + }function computeOutputShape3D(e, t, n, r, o, a) { + null == o && (o = computeDefaultPad(e, t, r));var i = e[0], + s = e[1], + u = conditionalRound((i - t + 2 * o) / r + 1, a);assert(isInt(u), "The output # of rows (" + u + ") must be an integer. Change the stride and/or zero pad parameters");var l = conditionalRound((s - t + 2 * o) / r + 1, a);return assert(isInt(l), "The output # of columns (" + l + ") must be an integer. Change the stride and/or zero pad parameters"), [u, l, n]; + }function computeDefaultPad(e, t, n, r) { + void 0 === r && (r = 1);var o = getEffectiveFilterSize(t, r);return Math.floor((e[0] * (n - 1) - n + o) / 2); + }function parseTupleParam(e) { + return "number" == typeof e ? [e, e] : e; + }function getEffectiveFilterSize(e, t) { + return t <= 1 ? e : e + (e - 1) * (t - 1); + }function getPadAndOutInfo(e, t, n, r, o, a, i, s) { + var u, l, c;if ("number" == typeof e) { + u = { top: e, bottom: e, left: e, right: e, type: 0 === e ? "VALID" : "NUMBER" };var p = computeOutputShape3D([t, n, 1], a, 1, r, e, s);l = p[0], c = p[1]; + } else if ("same" === e) { + var d = ((l = Math.ceil(t / r)) - 1) * r + a - t, + h = ((c = Math.ceil(n / o)) - 1) * o + i - n, + f = Math.floor(d / 2), + m = d - f, + g = Math.floor(h / 2);u = { top: f, bottom: m, left: g, right: h - g, type: "SAME" }; + } else { + if ("valid" !== e) throw Error("Unknown padding parameter: " + e);u = { top: 0, bottom: 0, left: 0, right: 0, type: "VALID" }, l = Math.ceil((t - a + 1) / r), c = Math.ceil((n - i + 1) / o); + }return { padInfo: u, outHeight: l, outWidth: c }; + }function conditionalRound(e, t) { + if (!t) return e;switch (t) {case "round": + return Math.round(e);case "ceil": + return Math.ceil(e);case "floor": + return Math.floor(e);default: + throw new Error("Unknown roundingMode " + t);} + }function conv1d_(e, t, n, r, o, a, i) { + void 0 === o && (o = "NWC"), void 0 === a && (a = 1);var s = convertToTensor(e, "x", "conv1d"), + u = convertToTensor(t, "filter", "conv1d"), + l = s, + c = !1;2 === s.rank && (c = !0, l = s.as3D(1, s.shape[0], s.shape[1])), assert(3 === l.rank, "Error in conv1d: input must be rank 3, but got rank " + l.rank + "."), assert(3 === u.rank, "Error in conv1d: filter must be rank 3, but got rank " + u.rank + "."), null != i && assert(isInt(r), "Error in conv1d: pad must be an integer when using, dimRoundingMode " + i + " but got pad " + r + "."), assert(l.shape[2] === u.shape[1], "Error in conv1d: depth of input (" + l.shape[2] + ") must match input depth for filter " + u.shape[1] + "."), assert(eitherStridesOrDilationsAreOne(n, a), "Error in conv1D: Either stride or dilation must be 1. Got stride " + n + " and dilation '" + a + "'"), assert("NWC" === o, "Error in conv1d: got dataFormat of " + o + " but only NWC is currently supported.");var p = u.as4D(1, u.shape[0], u.shape[1], u.shape[2]), + d = l.as4D(l.shape[0], 1, l.shape[1], l.shape[2]), + h = conv2d(d, p, [1, n], r, "NHWC", [1, a], i);return c ? h.as2D(h.shape[2], h.shape[3]) : h.as3D(h.shape[0], h.shape[2], h.shape[3]); + }function conv2d_(e, t, n, r, o, a, i) { + void 0 === o && (o = "NHWC"), void 0 === a && (a = [1, 1]);var s = convertToTensor(e, "x", "conv2d"), + u = convertToTensor(t, "filter", "conv2d"), + l = s, + c = !1;3 === s.rank && (c = !0, l = s.as4D(1, s.shape[0], s.shape[1], s.shape[2])), assert(4 === l.rank, "Error in conv2d: input must be rank 4, but got rank " + l.rank + "."), assert(4 === u.rank, "Error in conv2d: filter must be rank 4, but got rank " + u.rank + "."), null != i && assert(isInt(r), "Error in conv2d: pad must be an integer when using, dimRoundingMode " + i + " but got pad " + r + "."), assert(l.shape[3] === u.shape[2], "Error in conv2d: depth of input (" + l.shape[3] + ") must match input depth for filter " + u.shape[2] + "."), assert(eitherStridesOrDilationsAreOne(n, a), "Error in conv2D: Either strides or dilations must be 1. Got strides " + n + " and dilations '" + a + "'"), assert("NHWC" === o, "Error in conv2d: got dataFormat of " + o + " but only NHWC is currently supported.");var p = computeConv2DInfo(l.shape, u.shape, n, a, r, i), + d = ENV.engine.runKernel(function (e) { + return e.conv2d(l, u, p); + }, { x: l, $filter: u }, function (e) { + return assert(tupleValuesAreOne(a), "Error in gradient of conv2D: dilation rates greater than 1 are notyet supported in gradients. Got dilations '" + a + "'"), { x: function () { + return conv2dDerInput_(l.shape, e, u, n, r); + }, $filter: function () { + return conv2dDerFilter_(l, e, u.shape, n, r); + } }; + });return c ? d.as3D(d.shape[1], d.shape[2], d.shape[3]) : d; + }function conv2dDerInput_(e, t, n, r, o, a) { + assert(e.length === t.rank, "Length of inShape (" + e.length + ") and rank of dy (" + t.rank + ") must match");var i = e, + s = t, + u = !1;3 === t.rank && (u = !0, s = t.as4D(1, t.shape[0], t.shape[1], t.shape[2]), i = [1, e[0], e[1], e[2]]);var l = i[3], + c = s.shape[3];assert(4 === i.length, "Error in conv2dDerInput: inShape must be length 4, but got length " + i.length + "."), assert(4 === s.rank, "Error in conv2dDerInput: dy must be rank 4, but got rank " + s.rank), assert(4 === n.rank, "Error in conv2dDerInput: filter must be rank 4, but got rank " + n.rank), assert(l === n.shape[2], "Error in conv2dDerInput: depth of input (" + l + ") must match input depth for filter " + n.shape[2] + "."), assert(c === n.shape[3], "Error in conv2dDerInput: depth of output (" + c + ") must match output depth for filter " + n.shape[3] + "."), null != a && assert(isInt(o), "Error in conv2dDerInput: pad must be an integer when using, dimRoundingMode " + a + " but got pad " + o + ".");var p = computeConv2DInfo(i, n.shape, r, 1, o, a), + d = ENV.engine.runKernel(function (e) { + return e.conv2dDerInput(s, n, p); + }, { dy4D: s });return u ? d.as3D(d.shape[1], d.shape[2], d.shape[3]) : d; + }function conv2dDerFilter_(e, t, n, r, o, a) { + var i = e;3 === e.rank && (i = e.as4D(1, e.shape[0], e.shape[1], e.shape[2]));var s = t;3 === s.rank && (s = t.as4D(1, t.shape[0], t.shape[1], t.shape[2])), assert(4 === i.rank, "Error in conv2dDerFilter: input must be rank 4, but got shape " + i.shape + "."), assert(4 === s.rank, "Error in conv2dDerFilter: dy must be rank 4, but got shape " + s.shape + "."), assert(4 === n.length, "Error in conv2dDerFilter: filterShape must be length 4, but got " + n + "."), assert(i.shape[3] === n[2], "Error in conv2dDerFilter: depth of input " + i.shape[3] + ") must match input depth in filter (" + n[2] + "."), assert(s.shape[3] === n[3], "Error in conv2dDerFilter: depth of dy (" + s.shape[3] + ") must match output depth for filter (" + n[3] + ")."), null != a && assert(isInt(o), "Error in conv2dDerFilter: pad must be an integer when using, dimRoundingMode " + a + " but got pad " + o + ".");var u = computeConv2DInfo(i.shape, n, r, 1, o, a);return ENV.engine.runKernel(function (e) { + return e.conv2dDerFilter(i, s, u); + }, { x4D: i, dy4D: s }); + }function conv2dTranspose_(e, t, n, r, o, a) { + return conv2dDerInput_(n, convertToTensor(e, "x", "conv2dTranspose"), convertToTensor(t, "filter", "conv2dTranspose"), r, o, a); + }function depthwiseConv2d_(e, t, n, r, o, a, i) { + void 0 === o && (o = "NHWC"), void 0 === a && (a = [1, 1]);var s = convertToTensor(e, "x", "depthwiseConv2d"), + u = convertToTensor(t, "filter", "depthwiseConv2d"), + l = s, + c = !1;3 === s.rank && (c = !0, l = s.as4D(1, s.shape[0], s.shape[1], s.shape[2])), assert(4 === l.rank, "Error in depthwiseConv2d: input must be rank 4, but got rank " + l.rank + "."), assert(4 === u.rank, "Error in depthwiseConv2d: filter must be rank 4, but got rank " + u.rank + "."), assert(l.shape[3] === u.shape[2], "Error in depthwiseConv2d: number of input channels (" + l.shape[3] + ") must match the inChannels dimension in filter " + u.shape[2] + "."), null == a && (a = [1, 1]), assert(eitherStridesOrDilationsAreOne(n, a), "Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides " + n + " and dilations '" + a + "'"), null != i && assert(isInt(r), "Error in depthwiseConv2d: pad must be an integer when using, dimRoundingMode " + i + " but got pad " + r + ".");var p = computeConv2DInfo(l.shape, u.shape, n, a, r, i, !0), + d = ENV.engine.runKernel(function (e) { + return e.depthwiseConv2D(l, u, p); + }, { x: l, $filter: u }, function (e) { + return assert(tupleValuesAreOne(a), "Error in gradient of depthwiseConv2d: dilation rates greater than 1 are not yet supported. Got dilations '" + a + "'"), { x: function () { + return depthwiseConv2dDerInput(l.shape, e, u, p); + }, $filter: function () { + return depthwiseConv2dDerFilter(l, e, u.shape, p); + } }; + });return c ? d.as3D(d.shape[1], d.shape[2], d.shape[3]) : d; + }function separableConv2d_(e, t, n, r, o, a, i) { + void 0 === a && (a = [1, 1]), void 0 === i && (i = "NHWC");var s = convertToTensor(e, "x", "separableConv2d"), + u = convertToTensor(t, "depthwiseFilter", "separableConv2d"), + l = convertToTensor(n, "pointwiseFilter", "separableConv2d"), + c = s, + p = !1;if (3 === s.rank && (p = !0, c = s.as4D(1, s.shape[0], s.shape[1], s.shape[2])), "NCHW" === i) throw new Error("separableConv2d currently does not support dataFormat NCHW; only NHWC is supported");assert(4 === c.rank, "Error in separableConv2d: input must be rank 4, but got rank " + c.rank + "."), assert(4 === u.rank, "Error in separableConv2d: depthwise filter must be rank 4, but got rank " + u.rank + "."), assert(4 === l.rank, "Error in separableConv2d: pointwise filter must be rank 4, but got rank " + u.rank + "."), assert(1 === l.shape[0], "Error in separableConv2d: the first dimension of pointwise filter must be 1, but got " + l.shape[0] + "."), assert(1 === l.shape[1], "Error in separableConv2d: the second dimension of pointwise filter must be 1, but got " + l.shape[1] + ".");var d = u.shape[2], + h = u.shape[3];assert(l.shape[2] === d * h, "Error in separableConv2d: the third dimension of pointwise filter must be " + d * h + ", but got " + l.shape[2] + ".");var f = depthwiseConv2d(c, u, r, o, i, a), + m = conv2d(f, l, 1, "valid", i);return p ? m.as3D(m.shape[1], m.shape[2], m.shape[3]) : m; + }function parseTupleParam$1(e) { + return "number" == typeof e ? [e, e] : e; + }function tupleValuesAreOne(e) { + var t = parseTupleParam$1(e), + n = t[0], + r = t[1];return 1 === n && 1 === r; + }function eitherStridesOrDilationsAreOne(e, t) { + return tupleValuesAreOne(e) || tupleValuesAreOne(t); + }function depthwiseConv2dDerInput(e, t, n, r) { + var o = t, + a = !1;3 === t.rank && (a = !0, o = t.as4D(1, t.shape[0], t.shape[1], t.shape[2]));var i = ENV.engine.runKernel(function (e) { + return e.depthwiseConv2DDerInput(o, n, r); + }, { dy4D: o });return a ? i.as3D(i.shape[1], i.shape[2], i.shape[3]) : i; + }function depthwiseConv2dDerFilter(e, t, n, r) { + var o = e;3 === e.rank && (o = e.as4D(1, e.shape[0], e.shape[1], e.shape[2]));var a = t;return 3 === a.rank && (a = t.as4D(1, t.shape[0], t.shape[1], t.shape[2])), ENV.engine.runKernel(function (e) { + return e.depthwiseConv2DDerFilter(o, a, r); + }, { x4D: o, dy4D: a }); + }var conv1d = op({ conv1d_: conv1d_ }), + conv2d = op({ conv2d_: conv2d_ }), + depthwiseConv2d = op({ depthwiseConv2d_: depthwiseConv2d_ }), + separableConv2d = op({ separableConv2d_: separableConv2d_ }), + conv2dTranspose = op({ conv2dTranspose_: conv2dTranspose_ });function matMul_(e, t, n, r) { + void 0 === n && (n = !1), void 0 === r && (r = !1);var o = convertToTensor(e, "a", "matMul"), + a = convertToTensor(t, "b", "matMul"), + i = n ? o.shape[0] : o.shape[1], + s = r ? a.shape[1] : a.shape[0];assert(2 === o.rank && 2 === a.rank, "Error in matMul: inputs must be rank 2, got ranks " + o.rank + " and " + a.rank + "."), assert(i === s, "Error in matMul: inner shapes (" + i + ") and (" + s + ") of Tensors with shapes " + o.shape + " and " + a.shape + " and transposeA=" + n + " and transposeB=" + r + " must match.");return ENV.engine.runKernel(function (e) { + return e.matMul(o, a, n, r); + }, { $a: o, $b: a }, function (e) { + return n || r ? !n && r ? { $a: function () { + return e.matMul(a.toFloat(), !1, !1); + }, $b: function () { + return e.matMul(o.toFloat(), !0, !1); + } } : n && !r ? { $a: function () { + return a.toFloat().matMul(e, !1, !0); + }, $b: function () { + return o.toFloat().matMul(e, !1, !1); + } } : { $a: function () { + return a.toFloat().matMul(e, !0, !0); + }, $b: function () { + return e.matMul(o.toFloat(), !0, !0); + } } : { $a: function () { + return e.matMul(a.toFloat(), !1, !0); + }, $b: function () { + return o.toFloat().matMul(e, !0, !1); + } }; + }); + }function outerProduct_(e, t) { + var n = convertToTensor(e, "v1", "outerProduct"), + r = convertToTensor(t, "v2", "outerProduct");return assert(1 === n.rank && 1 === r.rank, "Error in outerProduct: inputs must be rank 1, but got ranks " + n.rank + " and " + r.rank + "."), n.as2D(-1, 1).matMul(r.as2D(1, -1)); + }function dot_(e, t) { + var n = convertToTensor(e, "t1", "dot"), + r = convertToTensor(t, "t2", "dot");assert(!(1 !== n.rank && 2 !== n.rank || 1 !== r.rank && 2 !== r.rank), "Error in dot: inputs must all be rank 1 or 2, but got ranks " + n.rank + " and " + r.rank + ".");var o = 1 === n.rank ? n.size : n.shape[1], + a = 1 === r.rank ? r.size : r.shape[0];return assert(o === a, "Error in dot: inner dimensions of inputs must match, but got " + o + " and " + a + "."), 1 === n.rank && 1 === r.rank ? n.as2D(1, -1).matMul(r.as2D(-1, 1)).asScalar() : 1 === n.rank && 2 === r.rank ? n.as2D(1, -1).matMul(r.as2D(r.shape[0], r.shape[1])).as1D() : 2 === n.rank && 1 === r.rank ? n.matMul(r.as2D(-1, 1)).as1D() : n.matMul(r.as2D(r.shape[0], r.shape[1])); + }var matMul = op({ matMul_: matMul_ }), + dot = op({ dot_: dot_ }), + outerProduct = op({ outerProduct_: outerProduct_ });function reverse1d_(e) { + var t = convertToTensor(e, "x", "reverse");return assert(1 === t.rank, "Error in reverse1D: x must be rank 1 but got\n rank " + t.rank + "."), reverse(t, 0); + }function reverse2d_(e, t) { + var n = convertToTensor(e, "x", "reverse");return assert(2 === n.rank, "Error in reverse2D: x must be rank 2 but got\n rank " + n.rank + "."), reverse(n, t); + }function reverse3d_(e, t) { + var n = convertToTensor(e, "x", "reverse");return assert(3 === n.rank, "Error in reverse3D: x must be rank 3 but got\n rank " + n.rank + "."), reverse(n, t); + }function reverse4d_(e, t) { + var n = convertToTensor(e, "x", "reverse");return assert(4 === n.rank, "Error in reverse4D: x must be rank 4 but got\n rank " + n.rank + "."), reverse(n, t); + }function reverse_(e, t) { + var n = convertToTensor(e, "x", "reverse");if (0 === n.rank) return n.clone();var r = parseAxisParam(t, n.shape);return ENV.engine.runKernel(function (e) { + return e.reverse(n, r); + }, { $x: n }, function (e) { + return { $x: function () { + return e.reverse(r); + } }; + }).reshapeAs(n); + }var reverse = op({ reverse_: reverse_ }), + reverse1d = op({ reverse1d_: reverse1d_ }), + reverse2d = op({ reverse2d_: reverse2d_ }), + reverse3d = op({ reverse3d_: reverse3d_ }), + reverse4d = op({ reverse4d_: reverse4d_ });function maxPool_(e, t, n, r, o) { + var a = convertToTensor(e, "x", "maxPool"), + i = a, + s = !1;3 === a.rank && (s = !0, i = a.as4D(1, a.shape[0], a.shape[1], a.shape[2])), assert(4 === i.rank, "Error in maxPool: input must be rank 4 but got rank " + i.rank + "."), null != o && assert(isInt(r), "Error in maxPool: pad must be an integer when using, dimRoundingMode " + o + " but got pad " + r + ".");var u = computePool2DInfo(i.shape, t, n, r, o), + l = ENV.engine.runKernel(function (e, t) { + return t(e.maxPool(i, u)); + }, { x: i }, function (e, o) { + var a = o[0];return { x: function () { + return maxPoolBackprop(e, i, a, t, n, r); + } }; + });return s ? l.as3D(l.shape[1], l.shape[2], l.shape[3]) : l; + }function avgPool_(e, t, n, r, o) { + var a = convertToTensor(e, "x", "avgPool");assert("float32" === a.dtype, "The input dtype to avgPool must be float32");var i = a, + s = !1;3 === a.rank && (s = !0, i = a.as4D(1, a.shape[0], a.shape[1], a.shape[2])), assert(4 === i.rank, "Error in avgPool: x must be rank 4 but got rank " + i.rank + "."), null != o && assert(isInt(r), "Error in avgPool: pad must be an integer when using, dimRoundingMode " + o + " but got pad " + r + ".");var u = computePool2DInfo(i.shape, t, n, r), + l = ENV.engine.runKernel(function (e) { + return e.avgPool(i, u); + }, { x: i }, function (e) { + return { x: function () { + return avgPoolBackprop(e, i, t, n, r); + } }; + });return l = l.cast(a.dtype), s ? l.as3D(l.shape[1], l.shape[2], l.shape[3]) : l; + }function maxPoolBackprop(e, t, n, r, o, a, i) { + var s = convertToTensor(e, "dy", "maxPoolBackprop"), + u = convertToTensor(t, "input", "maxPoolBackprop"), + l = convertToTensor(n, "output", "maxPoolBackprop");assert(u.rank === s.rank, "Rank of input (" + u.rank + ") does not match rank of dy (" + s.rank + ")"), assert(4 === s.rank, "Error in maxPoolBackprop: dy must be rank 4 but got rank " + s.rank + "."), assert(4 === u.rank, "Error in maxPoolBackprop: input must be rank 4 but got rank " + u.rank + "."), null != i && assert(isInt(a), "Error in maxPoolBackprop: pad must be an integer when using, dimRoundingMode " + i + " but got pad " + a + ".");var c = computePool2DInfo(u.shape, r, o, a, i);return ENV.engine.runKernel(function (e) { + return e.maxPoolBackprop(s, u, l, c); + }, { $dy: s, $input: u }); + }function avgPoolBackprop(e, t, n, r, o) { + var a = convertToTensor(e, "dy", "avgPoolBackprop"), + i = convertToTensor(t, "input", "avgPoolBackprop");assert(i.rank === a.rank, "Rank of input (" + i.rank + ") does not match rank of dy (" + a.rank + ")");var s = i, + u = a, + l = !1;3 === i.rank && (l = !0, s = i.as4D(1, i.shape[0], i.shape[1], i.shape[2]), u = a.as4D(1, a.shape[0], a.shape[1], a.shape[2])), assert(4 === u.rank, "Error in avgPoolBackprop: dy must be rank 4 but got rank " + u.rank + "."), assert(4 === s.rank, "Error in avgPoolBackprop: input must be rank 4 but got rank " + s.rank + ".");var c = computePool2DInfo(s.shape, n, r, o), + p = ENV.engine.runKernel(function (e) { + return e.avgPoolBackprop(u, s, c); + }, { dy4D: u, input4D: s });return l ? p.as3D(p.shape[1], p.shape[2], p.shape[3]) : p; + }var maxPool = op({ maxPool_: maxPool_ }), + avgPool = op({ avgPool_: avgPool_ });function slice1d_(e, t, n) { + var r = convertToTensor(e, "x", "slice1d");return assert(1 === r.rank, "slice1d expects a rank-1 tensor, but got a rank-" + r.rank + " tensor"), slice(r, [t], [n]); + }function slice2d_(e, t, n) { + var r = convertToTensor(e, "x", "slice2d");return assert(2 === r.rank, "slice1d expects a rank-2 tensor, but got a rank-" + r.rank + " tensor"), slice(r, t, n); + }function slice3d_(e, t, n) { + var r = convertToTensor(e, "x", "slice3d");return assert(3 === r.rank, "slice1d expects a rank-3 tensor, but got a rank-" + r.rank + " tensor"), slice(r, t, n); + }function slice4d_(e, t, n) { + var r = convertToTensor(e, "x", "slice4d");return assert(4 === r.rank, "slice1d expects a rank-4 tensor, but got a rank-" + r.rank + " tensor"), slice(r, t, n); + }function slice_(e, t, n) { + var r, + o, + a = convertToTensor(e, "x", "slice");if (0 === a.rank) throw new Error("Slicing scalar is not possible");r = "number" == typeof t ? [t].concat(new Array(a.rank - 1).fill(0)) : t.length < a.rank ? t.concat(new Array(a.rank - t.length).fill(0)) : t, o = (o = null == n ? new Array(a.rank).fill(-1) : "number" == typeof n ? [n].concat(new Array(a.rank - 1).fill(-1)) : n.length < a.rank ? n.concat(new Array(a.rank - n.length).fill(-1)) : n).map(function (e, t) { + return e >= 0 ? e : (assert(-1 === e, "Bad value in size"), a.shape[t] - r[t]); + }), assertParamsValid(a, r, o);var i = a.shape;return ENV.engine.runKernel(function (e) { + return e.slice(a, r, o); + }, { $x: a }, function (e) { + for (var t = [], n = 0; n < e.rank; n++) t.push([r[n], i[n] - r[n] - o[n]]);return { $x: function () { + return e.pad(t); + } }; + }); + }var slice = op({ slice_: slice_ }), + slice1d = op({ slice1d_: slice1d_ }), + slice2d = op({ slice2d_: slice2d_ }), + slice3d = op({ slice3d_: slice3d_ }), + slice4d = op({ slice4d_: slice4d_ }), + tidy = Environment.tidy, + keep = Environment.keep, + dispose = Environment.dispose, + time = Environment.time;function logSumExp_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "logSumExp"), + o = parseAxisParam(t, r.shape), + a = r.max(o, !0), + i = r.sub(a).exp().sum(o).log(), + s = a.reshape(i.shape).add(i);if (n) { + var u = expandShapeToKeepDim(s.shape, o);return s.reshape(u); + }return s; + }function sum_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "sum");"bool" === r.dtype && (r = r.toInt());var o = parseAxisParam(t, r.shape);return customGrad(function (e) { + var t = getAxesPermutation(o, e.rank), + r = o, + a = e;null != t && (a = e.transpose(t), r = getInnerMostAxes(r.length, e.rank));var i = ENV.engine.runKernel(function (e) { + return e.sum(a, r); + }, { permutedX: a });if (n) { + var s = expandShapeToKeepDim(i.shape, o);i = i.reshape(s); + }return { value: i, gradFunc: function (t) { + var n = e.shape.slice();return o.forEach(function (e) { + n[e] = 1; + }), t.reshape(n).mul(ones$1(e.shape, "float32")); + } }; + })(r); + }function mean_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "mean"), + o = parseAxisParam(t, r.shape), + a = sizeFromShape(computeOutAndReduceShapes(r.shape, o)[1]);return customGrad(function (e) { + var r = scalar(a);return { value: (r.dtype === e.dtype ? e : e.cast(r.dtype)).div(r).sum(t, n), gradFunc: function (t) { + var n = e.shape.slice();return o.forEach(function (e) { + n[e] = 1; + }), t.reshape(n).mul(ones$1(e.shape, "float32")).div(r); + } }; + })(r); + }function min_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "min"), + o = parseAxisParam(t, r.shape), + a = o, + i = getAxesPermutation(a, r.rank);null != i && (r = r.transpose(i), a = getInnerMostAxes(a.length, r.rank));var s = ENV.engine.runKernel(function (e) { + return e.min(r, a); + }, { $x: r });if (n) { + var u = expandShapeToKeepDim(s.shape, o);return s.reshape(u); + }return s; + }function max_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "max"), + o = parseAxisParam(t, r.shape), + a = o, + i = getAxesPermutation(a, r.rank);null != i && (r = r.transpose(i), a = getInnerMostAxes(a.length, r.rank));var s = ENV.engine.runKernel(function (e) { + return e.max(r, a); + }, { $x: r });if (n) { + var u = expandShapeToKeepDim(s.shape, o);return s.reshape(u); + }return s; + }function argMin_(e, t) { + void 0 === t && (t = 0);var n = convertToTensor(e, "x", "argMin");null == t && (t = 0);var r = parseAxisParam(t, n.shape), + o = getAxesPermutation(r, n.rank);return null != o && (n = n.transpose(o), r = getInnerMostAxes(r.length, n.rank)), ENV.engine.runKernel(function (e) { + return e.argMin(n, r[0]); + }, { $x: n }); + }function argMax_(e, t) { + void 0 === t && (t = 0);var n = convertToTensor(e, "x", "argMax");null == t && (t = 0);var r = parseAxisParam(t, n.shape), + o = getAxesPermutation(r, n.rank);return null != o && (n = n.transpose(o), r = getInnerMostAxes(r.length, n.rank)), ENV.engine.runKernel(function (e) { + return e.argMax(n, r[0]); + }, { $x: n }); + }function all_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "all", "bool");assert("bool" === r.dtype, "Error Tensor must be of type bool. Got: " + r.dtype);var o = parseAxisParam(t, r.shape), + a = o, + i = getAxesPermutation(a, r.rank);null != i && (r = r.transpose(i), a = getInnerMostAxes(a.length, r.rank));var s = ENV.engine.runKernel(function (e) { + return e.all(r, a); + }, { $x: r });if (n) { + var u = expandShapeToKeepDim(s.shape, o);return s.reshape(u); + }return s; + }function any_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = convertToTensor(e, "x", "any", "bool");assert("bool" === r.dtype, "Error Tensor must be of type bool. Got: " + r.dtype);var o = parseAxisParam(t, r.shape), + a = o, + i = getAxesPermutation(a, r.rank);null != i && (r = r.transpose(i), a = getInnerMostAxes(a.length, r.rank));var s = ENV.engine.runKernel(function (e) { + return e.any(r, a); + }, { $x: r });if (n) { + var u = expandShapeToKeepDim(s.shape, o);return s.reshape(u); + }return s; + }function moments_(e, t, n) { + void 0 === t && (t = null), void 0 === n && (n = !1);var r = parseAxisParam(t, (e = convertToTensor(e, "x", "moments")).shape), + o = e.mean(r, n), + a = o.shape;return n || (a = expandShapeToKeepDim(o.shape, r)), { mean: o, variance: e.toFloat().sub(o.reshape(a)).square().mean(r, n) }; + }var all = op({ all_: all_ }), + any = op({ any_: any_ }), + argMax = op({ argMax_: argMax_ }), + argMin = op({ argMin_: argMin_ }), + logSumExp = op({ logSumExp_: logSumExp_ }), + max = op({ max_: max_ }), + mean = op({ mean_: mean_ }), + min = op({ min_: min_ }), + moments = op({ moments_: moments_ }), + sum = op({ sum_: sum_ });function notEqual_(e, t) { + var n = convertToTensor(e, "a", "notEqual"), + r = convertToTensor(t, "b", "notEqual");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.notEqual(n, r); + }, { $a: n, $b: r }); + }function notEqualStrict_(e, t) { + var n = convertToTensor(e, "a", "notEqualStrict"), + r = convertToTensor(t, "b", "notEqualStrict");return assertShapesMatch(n.shape, r.shape, "Error in notEqualStrict: "), n.notEqual(r); + }function less_(e, t) { + var n = convertToTensor(e, "a", "less"), + r = convertToTensor(t, "b", "less");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.less(n, r); + }, { $a: n, $b: r }); + }function lessStrict_(e, t) { + var n = convertToTensor(e, "a", "lessStrict"), + r = convertToTensor(t, "b", "lessStrict");return assertShapesMatch(n.shape, r.shape, "Error in lessStrict: "), n.less(r); + }function equal_(e, t) { + var n = convertToTensor(e, "a", "equal"), + r = convertToTensor(t, "b", "equal");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.equal(n, r); + }, { $a: n, $b: r }); + }function equalStrict_(e, t) { + var n = convertToTensor(e, "a", "equalStrict"), + r = convertToTensor(t, "b", "equalStrict");return assertShapesMatch(n.shape, r.shape, "Error in equalStrict: "), n.equal(r); + }function lessEqual_(e, t) { + var n = convertToTensor(e, "a", "lessEqual"), + r = convertToTensor(t, "b", "lessEqual");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.lessEqual(n, r); + }, { $a: n, $b: r }); + }function lessEqualStrict_(e, t) { + var n = convertToTensor(e, "a", "lessEqualStrict"), + r = convertToTensor(t, "b", "lessEqualStrict");return assertShapesMatch(n.shape, r.shape, "Error in lessEqualStrict: "), n.lessEqual(r); + }function greater_(e, t) { + var n = convertToTensor(e, "a", "greater"), + r = convertToTensor(t, "b", "greater");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.greater(n, r); + }, { $a: n, $b: r }); + }function greaterStrict_(e, t) { + var n = convertToTensor(e, "a", "greaterStrict"), + r = convertToTensor(t, "b", "greaterStrict");return assertShapesMatch(n.shape, r.shape, "Error in greaterStrict: "), n.greater(r); + }function greaterEqual_(e, t) { + var n = convertToTensor(e, "a", "greaterEqual"), + r = convertToTensor(t, "b", "greaterEqual");return assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.greaterEqual(n, r); + }, { $a: n, $b: r }); + }function greaterEqualStrict_(e, t) { + var n = convertToTensor(e, "a", "greaterEqualStrict"), + r = convertToTensor(t, "b", "greaterEqualStrict");return assertShapesMatch(n.shape, r.shape, "Error in greaterEqualStrict: "), n.greaterEqual(r); + }var equal = op({ equal_: equal_ }), + equalStrict = op({ equalStrict_: equalStrict_ }), + greater = op({ greater_: greater_ }), + greaterEqual = op({ greaterEqual_: greaterEqual_ }), + greaterEqualStrict = op({ greaterEqualStrict_: greaterEqualStrict_ }), + greaterStrict = op({ greaterStrict_: greaterStrict_ }), + less = op({ less_: less_ }), + lessEqual = op({ lessEqual_: lessEqual_ }), + lessEqualStrict = op({ lessEqualStrict_: lessEqualStrict_ }), + lessStrict = op({ lessStrict_: lessStrict_ }), + notEqual = op({ notEqual_: notEqual_ }), + notEqualStrict = op({ notEqualStrict_: notEqualStrict_ });function add_(e, t) { + var n = convertToTensor(e, "a", "add"), + r = convertToTensor(t, "b", "add");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.add(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = e, + r = getReductionAxes(n.shape, o);return r.length > 0 && (t = t.sum(r)), t.reshape(n.shape); + }, $b: function () { + var t = e, + n = getReductionAxes(r.shape, o);return n.length > 0 && (t = t.sum(n)), t.reshape(r.shape); + } }; + }); + }function addN_(e) { + assert(Array.isArray(e), function () { + return "The param passed to tf.addN() must be a list of tensors"; + }), assert(e.length >= 1, function () { + return "Must pass at least one tensor to tf.addN(), but got " + e.length; + });var t = e.map(function (e, t) { + return convertToTensor(e, "tensors" + t, "addN"); + }), + n = t[0];t.forEach(function (e) { + if (e.dtype !== n.dtype) throw new Error("All tensors passed to tf.addN() must have the same dtype"); + }), t.forEach(function (e) { + if (!arraysEqual(e.shape, n.shape)) throw new Error("All tensors passed to tf.addN() must have the same shape"); + });var r = t;return ENV.engine.runKernel(function (e) { + return e.addN(t); + }, r, function (e) { + var n = {};return t.forEach(function (t, r) { + n[r] = function () { + return e.clone(); + }; + }), n; + }); + }function addStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in addStrict: "), e.add(t); + }function sub_(e, t) { + var n = convertToTensor(e, "a", "sub"), + r = convertToTensor(t, "b", "sub");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.subtract(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = e, + r = getReductionAxes(n.shape, o);return r.length > 0 && (t = t.sum(r)), t.reshape(n.shape); + }, $b: function () { + var t = e, + n = getReductionAxes(r.shape, o);return n.length > 0 && (t = t.sum(n)), t.neg().reshape(r.shape); + } }; + }); + }function subStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in subStrict: "), e.sub(t); + }function pow_(e, t) { + var n = convertToTensor(e, "base", "pow"), + r = convertToTensor(t, "exp", "pow"), + o = assertAndGetBroadcastShape(n.shape, r.shape);e = n.cast(upcastType(n.dtype, r.dtype)), t = r.cast(upcastType(n.dtype, r.dtype));return ENV.engine.runKernel(function (e, t) { + return t(e.pow(n, r)); + }, { $base: n, $exp: r }, function (e, t) { + var a = t[0];return { $base: function () { + var t = e.mul(r.toFloat().mul(a.div(n))), + i = getReductionAxes(n.shape, o);return i.length > 0 && (t = t.sum(i)), t.reshape(n.shape); + }, $exp: function () { + var t = e.mul(a.mul(n.log()).toFloat()), + i = getReductionAxes(r.shape, o);return i.length > 0 && (t = t.sum(i)), t.reshape(r.shape); + } }; + }); + }function powStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in powStrict: "), e.pow(t); + }function mul_(e, t) { + var n = convertToTensor(e, "a", "mul"), + r = convertToTensor(t, "b", "mul");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.multiply(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = e.mul(r.toFloat()), + a = getReductionAxes(n.shape, o);return a.length > 0 ? t.sum(a).reshape(n.shape) : t; + }, $b: function () { + var t = e.mul(n.toFloat()), + a = getReductionAxes(r.shape, o);return a.length > 0 ? t.sum(a).reshape(r.shape) : t; + } }; + }); + }function mulStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in multiplyStrict: "), e.mul(t); + }function div_(e, t) { + var n, + r = convertToTensor(e, "a", "div"), + o = convertToTensor(t, "b", "div");if (assertTypesMatch(r, o), "int32" === r.dtype && "int32" === o.dtype) return floorDiv(r, o);n = function (e) { + return e.realDivide(r, o); + };var a = assertAndGetBroadcastShape(r.shape, o.shape);return ENV.engine.runKernel(n, { $a: r, $b: o }, function (e) { + return { $a: function () { + var t = e.div(o.toFloat()), + n = getReductionAxes(r.shape, a);return n.length > 0 ? t.sum(n).reshape(r.shape) : t; + }, $b: function () { + var t = e.mul(r.toFloat()), + n = getReductionAxes(o.shape, a);n.length > 0 && (t = t.sum(n).reshape(o.shape));var i = o.square();return t.div(i.toFloat()).neg(); + } }; + }); + }function floorDiv_(e, t) { + var n = convertToTensor(e, "a", "floorDiv"), + r = convertToTensor(t, "b", "floorDiv");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.floorDiv(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = e.div(r.toFloat()), + a = getReductionAxes(n.shape, o);return a.length > 0 ? t.sum(a).reshape(n.shape) : t; + }, $b: function () { + var t = e.mul(n.toFloat()), + a = getReductionAxes(r.shape, o);a.length > 0 && (t = t.sum(a).reshape(r.shape));var i = r.square();return t.div(i.toFloat()).neg(); + } }; + }); + }function divStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in divideStrict: "), e.div(t); + }function mod_(e, t) { + var n = convertToTensor(e, "a", "mod"), + r = convertToTensor(t, "b", "mod");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.mod(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = getReductionAxes(n.shape, o);return t.length > 0 ? e.sum(t).reshape(n.shape) : e; + }, $b: function () { + var t = e.mul(n.div(r).floor().neg()), + a = getReductionAxes(r.shape, o);return a.length > 0 ? t.sum(a).reshape(r.shape) : t; + } }; + }); + }function modStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in modStrict: "), e.mod(t); + }function minimum_(e, t) { + var n = convertToTensor(e, "a", "minimum"), + r = convertToTensor(t, "b", "minimum");assertTypesMatch(n, r), "bool" === n.dtype && (n = n.toInt()), "bool" === r.dtype && (r = r.toInt()), assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.minimum(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + return e.mul(n.lessEqual(r).toFloat()); + }, $b: function () { + return e.mul(n.greater(r).toFloat()); + } }; + }); + }function minimumStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in minimumStrict: "), e.minimum(t); + }function maximum_(e, t) { + var n = convertToTensor(e, "a", "maximum"), + r = convertToTensor(t, "b", "maximum");assertTypesMatch(n, r), "bool" === n.dtype && (n = n.toInt()), "bool" === r.dtype && (r = r.toInt()), assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.maximum(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + return e.mul(n.greaterEqual(r).toFloat()); + }, $b: function () { + return e.mul(n.less(r).toFloat()); + } }; + }); + }function maximumStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in minimumStrict: "), e.maximum(t); + }function squaredDifference_(e, t) { + var n = convertToTensor(e, "a", "squaredDifference"), + r = convertToTensor(t, "b", "squaredDifference");assertTypesMatch(n, r), assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.squaredDifference(n, r); + }, { $a: n, $b: r }, function (e) { + var t = scalar(2);return { $a: function () { + return e.mul(n.sub(r).mul(t)); + }, $b: function () { + return e.mul(r.sub(n).mul(t)); + } }; + }); + }function squaredDifferenceStrict_(e, t) { + return assertShapesMatch(e.shape, t.shape, "Error in squaredDifferenceStrict: "), e.squaredDifference(t); + }function atan2_(e, t) { + var n = convertToTensor(e, "a", "atan2"), + r = convertToTensor(t, "b", "atan2");assertTypesMatch(n, r);var o = assertAndGetBroadcastShape(n.shape, r.shape);return ENV.engine.runKernel(function (e) { + return e.atan2(n, r); + }, { $a: n, $b: r }, function (e) { + return { $a: function () { + var t = add(n.square(), r.square()), + a = e.mul(r.div(t)), + i = getReductionAxes(n.shape, o);return i.length > 0 && (a = a.sum(i)), a.reshape(n.shape); + }, $b: function () { + var t = add(n.square(), r.square()), + a = neg(e.mul(n.div(t))), + i = getReductionAxes(r.shape, o);return i.length > 0 && (a = a.sum(i)), a.reshape(r.shape); + } }; + }); + }var add = op({ add_: add_ }), + addN = op({ addN_: addN_ }), + addStrict = op({ addStrict_: addStrict_ }), + atan2 = op({ atan2_: atan2_ }), + div = op({ div_: div_ }), + divStrict = op({ divStrict_: divStrict_ }), + floorDiv = op({ floorDiv_: floorDiv_ }), + maximum = op({ maximum_: maximum_ }), + maximumStrict = op({ maximumStrict_: maximumStrict_ }), + minimum = op({ minimum_: minimum_ }), + minimumStrict = op({ minimumStrict_: minimumStrict_ }), + mod = op({ mod_: mod_ }), + modStrict = op({ modStrict_: modStrict_ }), + mul = op({ mul_: mul_ }), + mulStrict = op({ mulStrict_: mulStrict_ }), + pow = op({ pow_: pow_ }), + powStrict = op({ powStrict_: powStrict_ }), + squaredDifference = op({ squaredDifference_: squaredDifference_ }), + squaredDifferenceStrict = op({ squaredDifferenceStrict_: squaredDifferenceStrict_ }), + sub = op({ sub_: sub_ }), + subStrict = op({ subStrict_: subStrict_ });function logicalNot_(e) { + var t = convertToTensor(e, "x", "logicalNot", "bool");return assert("bool" === t.dtype, "Error Array must be of type bool."), ENV.engine.runKernel(function (e) { + return e.logicalNot(t); + }, { $x: t }); + }function logicalAnd_(e, t) { + var n = convertToTensor(e, "a", "logicalAnd", "bool"), + r = convertToTensor(t, "b", "logicalAnd", "bool");return assert("bool" === n.dtype && "bool" === r.dtype, "Error Array must be of type bool."), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.logicalAnd(n, r); + }, { $a: n, $b: r }); + }function logicalOr_(e, t) { + var n = convertToTensor(e, "a", "logicalOr", "bool"), + r = convertToTensor(t, "b", "logicalOr", "bool");return assert("bool" === n.dtype && "bool" === r.dtype, "Error Array must be of type bool."), assertAndGetBroadcastShape(n.shape, r.shape), ENV.engine.runKernel(function (e) { + return e.logicalOr(n, r); + }, { $a: n, $b: r }); + }function logicalXor_(e, t) { + var n = convertToTensor(e, "a", "logicalXor", "bool"), + r = convertToTensor(t, "b", "logicalXor", "bool");return assert("bool" === n.dtype && "bool" === r.dtype, "Error Array must be of type bool."), assertAndGetBroadcastShape(n.shape, r.shape), logicalOr(e, t).logicalAnd(logicalAnd(e, t).logicalNot()); + }function where_(e, t, n) { + var r = convertToTensor(t, "a", "where"), + o = convertToTensor(n, "b", "where"), + a = convertToTensor(e, "condition", "where", "bool");assert("bool" === a.dtype, "Error Condition must be of type bool."), assertShapesMatch(r.shape, o.shape, "Error in where: "), 1 === a.rank ? assert(a.shape[0] === r.shape[0], "The first dimension of `a` must match the size of `condition`.") : assertShapesMatch(a.shape, o.shape, "Error in where: ");return ENV.engine.runKernel(function (e) { + return e.select(a, r, o); + }, { $condition: a, $a: r, $b: o }, function (e) { + return { $condition: function () { + return zerosLike(a); + }, $a: function () { + return e.mul(a.cast(r.dtype)); + }, $b: function () { + return e.mul(a.logicalNot().cast(o.dtype)); + } }; + }); + }function whereAsync_(e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r;return __generator(this, function (o) { + switch (o.label) {case 0: + return assert("bool" === (t = convertToTensor(e, "condition", "where", "bool")).dtype, "Condition must be of type bool."), [4, t.data()];case 1: + return n = o.sent(), r = whereImpl(t.shape, n), e !== t && t.dispose(), [2, r];} + }); + }); + }var logicalAnd = op({ logicalAnd_: logicalAnd_ }), + logicalNot = op({ logicalNot_: logicalNot_ }), + logicalOr = op({ logicalOr_: logicalOr_ }), + logicalXor = op({ logicalXor_: logicalXor_ }), + where = op({ where_: where_ }), + whereAsync = whereAsync_;function relu_(e) { + var t = convertToTensor(e, "x", "relu");if ("bool" === t.dtype) return t.toInt();return ENV.engine.runKernel(function (e) { + return e.relu(t); + }, { $x: t }, function (e) { + var n = t.step();return { $x: function () { + return e.mulStrict(n.toFloat()); + } }; + }); + }function elu_(e) { + var t = convertToTensor(e, "x", "elu");return ENV.engine.runKernel(function (e, n) { + return n(e.elu(t)); + }, { $x: t }, function (e, t) { + var n = t[0];return { $x: function () { + return ENV.engine.runKernel(function (t) { + return t.eluDer(e, n); + }, { dy: e, y: n }); + } }; + }); + }function selu_(e) { + var t = convertToTensor(e, "x", "selu");return ENV.engine.runKernel(function (e) { + return e.selu(t); + }, { $x: t }, function (e) { + return { $x: function () { + var n = t.greater(scalar(0)), + r = scalar(SELU_SCALEALPHA), + o = scalar(SELU_SCALE), + a = e.mul(o), + i = e.mul(r).mul(t.toFloat().exp());return where(n, a, i); + } }; + }); + }function leakyRelu_(e, t) { + void 0 === t && (t = .2);var n = convertToTensor(e, "x", "leakyRelu");return maximum(scalar(t).mul(n), n); + }function prelu_(e, t) { + var n = convertToTensor(e, "x", "prelu"), + r = convertToTensor(t, "alpha", "prelu"), + o = scalar(0);return maximum(o, n).add(r.mul(minimum(o, n))); + }var elu = op({ elu_: elu_ }), + leakyRelu = op({ leakyRelu_: leakyRelu_ }), + prelu = op({ prelu_: prelu_ }), + relu = op({ relu_: relu_ }), + selu = op({ selu_: selu_ });function transpose_(e, t) { + var n = convertToTensor(e, "x", "transpose");if (null == t && (t = n.shape.map(function (e, t) { + return t; + }).reverse()), assert(n.rank === t.length, "Error in transpose: rank of input " + n.rank + " must match length of perm " + t + "."), t.forEach(function (e) { + assert(e >= 0 && e < n.rank, "All entries in 'perm' must be between 0 and " + (n.rank - 1) + " but got " + t); + }), n.rank <= 1) return n.clone();return ENV.engine.runKernel(function (e) { + return e.transpose(n, t); + }, { $x: n }, function (e) { + var n = getUndoAxesPermutation(t);return { $x: function () { + return e.transpose(n); + } }; + }); + }var transpose = op({ transpose_: transpose_ });function localResponseNormalization_(e, t, n, r, o) { + void 0 === t && (t = 5), void 0 === n && (n = 1), void 0 === r && (r = 1), void 0 === o && (o = .5);var a = convertToTensor(e, "x", "localResponseNormalization");assert(4 === a.rank || 3 === a.rank, "Error in localResponseNormalization: x must be rank 3 or 4 but got\n rank " + a.rank + "."), assert(isInt(t), "Error in localResponseNormalization: depthRadius must be an integer\n but got depthRadius " + t + ".");var i = a, + s = !1;3 === a.rank && (s = !0, i = a.as4D(1, a.shape[0], a.shape[1], a.shape[2]));var u = ENV.engine.runKernel(function (e, a) { + return a(e.localResponseNormalization4D(i, t, n, r, o)); + }, { x4D: i }, function (e, a) { + var s = a[0];return { x4D: function () { + return ENV.engine.runKernel(function (a) { + return a.LRNGrad(e, i, s, t, n, r, o); + }, {}); + } }; + });return s ? u.as3D(u.shape[1], u.shape[2], u.shape[3]) : u; + }var localResponseNormalization = op({ localResponseNormalization_: localResponseNormalization_ });function norm_(e, t, n, r) { + void 0 === t && (t = "euclidean"), void 0 === n && (n = null), void 0 === r && (r = !1);var o = normImpl(e = convertToTensor(e, "x", "norm"), t, n), + a = o.shape;if (r) { + var i = parseAxisParam(n, e.shape);a = expandShapeToKeepDim(o.shape, i); + }return o.reshape(a); + }function normImpl(e, t, n) { + if (void 0 === n && (n = null), 0 === e.rank) return e.abs();if (1 !== e.rank && null === n) return normImpl(e.reshape([-1]), t, n);if (1 === e.rank || "number" == typeof n || n instanceof Array && 1 === n.length) { + if (1 === t) return e.abs().sum(n);if (t === 1 / 0) return e.abs().max(n);if (t === -1 / 0) return e.abs().min(n);if ("euclidean" === t || 2 === t) return e.abs().pow(scalar(2, "int32")).sum(n).sqrt();throw new Error("Error in norm: invalid ord value: " + t); + }if (n instanceof Array && 2 === n.length) { + if (1 === t) return e.abs().sum(n[0]).max(n[1] - 1);if (t === 1 / 0) return e.abs().sum(n[1]).max(n[0]);if (t === -1 / 0) return e.abs().sum(n[1]).min(n[0]);if ("fro" === t || "euclidean" === t) return e.square().sum(n).sqrt();throw new Error("Error in norm: invalid ord value: " + t); + }throw new Error("Error in norm: invalid axis: " + n); + }var norm = op({ norm_: norm_ });function unsortedSegmentSum_(e, t, n) { + var r = convertToTensor(e, "x", "unsortedSegmentSum"), + o = convertToTensor(t, "segmentIds", "unsortedSegmentSum", "int32");assert("int32" === o.dtype, "segmentIds must be of dtype `int32`"), assert(isInt(n), "numSegments must be of dtype int");return ENV.engine.runKernel(function (e) { + return e.unsortedSegmentSum(r, o, n); + }, { $x: r }, function (e) { + return { $x: function () { + return gatherDropNegatives(e, o); + } }; + }); + }function gather_(e, t, n) { + void 0 === n && (n = 0);var r = convertToTensor(e, "x", "gather"), + o = convertToTensor(t, "indices", "gather", "int32");assert("int32" === o.dtype, "Indices must be of dtype `int32`"), n = parseAxisParam(n, r.shape)[0];return ENV.engine.runKernel(function (e) { + return e.gather(r, o, n); + }, { $x: r }, function (e) { + return { $x: function () { + if (0 === n) return unsortedSegmentSum(e, o, r.shape[n]);var t = r.shape, + a = o.size, + i = t.slice(0, n), + s = i.length, + u = t.slice(n, t.length).slice(1), + l = u.length, + c = arrayRange(0, s), + p = arrayRange(s + 1, s + 1 + l), + d = arrayConcat([i, [a], u]), + h = e.reshape(d), + f = o.reshape([a]), + m = arrayConcat([[s], c, p]), + g = h.transpose(m), + v = unsortedSegmentSum(g, f, r.shape[n]), + y = getUndoAxesPermutation(m);return v = v.transpose(y); + } }; + }); + }function arrayRange(e, t) { + for (var n = [], r = e; r < t; ++r) n.push(r);return n; + }function arrayConcat(e) { + for (var t = [], n = 0; n < e.length; ++n) for (var r = 0; r < e[n].length; ++r) t.push(e[n][r]);return t; + }function gatherDropNegatives(e, t) { + for (var n = maximum(t, zerosLike(t)), r = gather(e, n), o = greaterEqual(t, scalar(0, "int32")), a = r.rank - o.rank, i = 0; i < a; ++i) o = expandDims(o, i + 1);o = logicalAnd(o, ones$1(r.shape, "bool"));var s = zerosLike(r);return where(o, r, s); + }var gather = op({ gather_: gather_ }), + unsortedSegmentSum = op({ unsortedSegmentSum_: unsortedSegmentSum_ });function multiRNNCell_(e, t, n, r) { + for (var o = convertToTensor(t, "data", "multiRNNCell"), a = convertToTensorArray(n, "c", "multiRNNCell"), i = convertToTensorArray(r, "h", "multiRNNCell"), s = o, u = [], l = 0; l < e.length; l++) { + var c = e[l](s, a[l], i[l]);u.push(c[0]), u.push(c[1]), s = c[1]; + }var p = [], + d = [];for (l = 0; l < u.length; l += 2) p.push(u[l]), d.push(u[l + 1]);return [p, d]; + }function basicLSTMCell_(e, t, n, r, o, a) { + var i = convertToTensor(e, "forgetBias", "basicLSTMCell"), + s = convertToTensor(t, "lstmKernel", "basicLSTMCell"), + u = convertToTensor(n, "lstmBias", "basicLSTMCell"), + l = convertToTensor(r, "data", "basicLSTMCell"), + c = convertToTensor(o, "c", "basicLSTMCell"), + p = convertToTensor(a, "h", "basicLSTMCell"), + d = l.concat(p, 1).matMul(s).add(u), + h = d.shape[0], + f = d.shape[1] / 4, + m = [h, f], + g = d.slice([0, 0], m), + v = d.slice([0, f], m), + y = d.slice([0, 2 * f], m), + x = d.slice([0, 3 * f], m), + T = g.sigmoid().mulStrict(v.tanh()).addStrict(c.mulStrict(i.add(y).sigmoid()));return [T, T.tanh().mulStrict(x.sigmoid())]; + }var basicLSTMCell = op({ basicLSTMCell_: basicLSTMCell_ }), + multiRNNCell = op({ multiRNNCell_: multiRNNCell_ });function movingAverage_(e, t, n, r, o) { + void 0 === o && (o = !0);var a = convertToTensor(e, "v", "movingAverage"), + i = convertToTensor(t, "x", "movingAverage"), + s = convertToTensor(n, "decay", "movingAverage");assertTypesMatch(a, i), assert(arraysEqual(a.shape, i.shape), "Shape mismatch in v and x");var u = scalar(1), + l = u.sub(s), + c = i.sub(a).mul(l);if (o) { + assert(null != r, "When using zeroDebias: true, step is required.");var p = convertToTensor(r, "step", "movingAverage");c = c.div(u.sub(pow(s, p))); + }return a.add(c); + }var movingAverage = op({ movingAverage_: movingAverage_ });function stridedSlice_(e, t, n, r, o, a) { + void 0 === o && (o = 0), void 0 === a && (a = 0);var i = convertToTensor(e, "x", "stridedSlice");return ENV.engine.runKernel(function (e) { + return e.stridedSlice(i, t, n, r, o, a); + }, { $x: i }); + }var stridedSlice = op({ stridedSlice_: stridedSlice_ });function topk_(e, t, n) { + void 0 === t && (t = 1), void 0 === n && (n = !0);var r = convertToTensor(e, "x", "topk");if (0 === r.rank) throw new Error("topk() expects the input to be of rank 1 or higher");var o = r.shape[r.shape.length - 1];if (t > o) throw new Error("'k' passed to topk() must be <= the last dimension (" + o + ") but got " + t);var a = ENV.engine.runKernel(function (e) { + return e.topk(r, t, n); + }, { $x: r });return { values: a[0], indices: a[1] }; + }var topk = op({ topk_: topk_ });function computeWeightedLoss_(e, t, n) { + void 0 === n && (n = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var r = convertToTensor(e, "losses", "computeWeightedLoss"), + o = null;null != t && (o = convertToTensor(t, "weights", "computeWeightedLoss"));var a = null == o ? r : r.mul(o);if (n === exports.Reduction.NONE) return a;if (n === exports.Reduction.SUM) return a.sum();if (n === exports.Reduction.MEAN) { + if (null == o) return a.mean();var i = sizeFromShape(r.shape) / sizeFromShape(o.shape), + s = a.sum().div(o.sum());return i > 1 ? s.div(scalar(i)) : s; + }if (n === exports.Reduction.SUM_BY_NONZERO_WEIGHTS) { + if (null == o) return a.sum().div(scalar(r.size));var u = o.mul(ones$1(r.shape)).notEqual(scalar(0)).sum().toFloat();return a.sum().div(u); + }throw Error("Unknown reduction: " + n); + }function absoluteDifference_(e, t, n, r) { + void 0 === r && (r = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o = convertToTensor(e, "labels", "absoluteDifference"), + a = convertToTensor(t, "predictions", "absoluteDifference"), + i = null;null != n && (i = convertToTensor(n, "weights", "absoluteDifference")), assertShapesMatch(o.shape, a.shape, "Error in absoluteDifference: ");var s = o.sub(a).abs();return computeWeightedLoss(s, i, r); + }function meanSquaredError_(e, t, n, r) { + void 0 === r && (r = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o = convertToTensor(e, "labels", "meanSquaredError"), + a = convertToTensor(t, "predictions", "meanSquaredError"), + i = null;null != n && (i = convertToTensor(n, "weights", "meanSquaredError")), assertShapesMatch(o.shape, a.shape, "Error in meanSquaredError: ");var s = o.squaredDifference(a);return computeWeightedLoss(s, i, r); + }function cosineDistance_(e, t, n, r, o) { + void 0 === o && (o = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a = convertToTensor(e, "labels", "cosineDistance"), + i = convertToTensor(t, "predictions", "cosineDistance"), + s = null;null != r && (s = convertToTensor(r, "weights", "cosineDistance")), assertShapesMatch(a.shape, i.shape, "Error in cosineDistance: ");var u = scalar(1).sub(a.mul(i).sum(n, !0));return computeWeightedLoss(u, s, o); + }function hingeLoss_(e, t, n, r) { + void 0 === r && (r = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o = convertToTensor(e, "labels", "hingeLoss"), + a = convertToTensor(t, "predictions", "hingeLoss"), + i = null;null != n && (i = convertToTensor(n, "weights", "hingeLoss")), assertShapesMatch(o.shape, a.shape, "Error in hingeLoss: ");var s = scalar(1);o = scalar(2).mul(o).sub(s);var u = s.sub(o.mul(a)).relu();return computeWeightedLoss(u, i, r); + }function logLoss_(e, t, n, r, o) { + void 0 === r && (r = 1e-7), void 0 === o && (o = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a = convertToTensor(e, "labels", "logLoss"), + i = convertToTensor(t, "predictions", "logLoss"), + s = null;null != n && (s = convertToTensor(n, "weights", "logLoss")), assertShapesMatch(a.shape, i.shape, "Error in logLoss: ");var u = scalar(1), + l = scalar(r), + c = a.mul(i.add(l).log()).neg().sub(u.sub(a).mul(u.sub(i).add(l).log()));return computeWeightedLoss(c, s, o); + }function sigmoidCrossEntropyWithLogits_(e, t) { + var n = convertToTensor(e, "labels", "sigmoidCrossEntropyWithLogits"), + r = convertToTensor(t, "logits", "sigmoidCrossEntropyWithLogits");assertShapesMatch(n.shape, r.shape, "Error in sigmoidCrossEntropyWithLogits: ");var o = r.relu(), + a = r.mul(n), + i = r.abs().neg().exp().log1p();return o.sub(a).add(i); + }function sigmoidCrossEntropy_(e, t, n, r, o) { + void 0 === r && (r = 0), void 0 === o && (o = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a = convertToTensor(e, "multiClassLabels", "sigmoidCrossEntropy"), + i = convertToTensor(t, "logits", "sigmoidCrossEntropy"), + s = null;if (null != n && (s = convertToTensor(n, "weights", "sigmoidCrossEntropy")), assertShapesMatch(a.shape, i.shape, "Error in sigmoidCrossEntropy: "), r > 0) { + var u = scalar(r), + l = scalar(1), + c = scalar(.5);a = a.mul(l.sub(u)).add(c.mul(u)); + }var p = sigmoidCrossEntropyWithLogits_(a, i);return computeWeightedLoss(p, s, o); + }function huberLoss_(e, t, n, r, o) { + void 0 === r && (r = 1), void 0 === o && (o = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a = convertToTensor(e, "labels", "huberLoss"), + i = convertToTensor(t, "predictions", "huberLoss"), + s = null;null != n && (s = convertToTensor(n, "weights", "huberLoss")), assertShapesMatch(a.shape, i.shape, "Error in huberLoss: ");var u = scalar(r), + l = i.sub(a).abs(), + c = minimum(l, u), + p = l.sub(c), + d = scalar(.5).mul(c.square()).add(u.mul(p));return computeWeightedLoss(d, s, o); + }function softmaxCrossEntropyWithLogits_(e, t, n) { + if (void 0 === n && (n = -1), -1 === n && (n = t.rank - 1), n !== t.rank - 1) throw Error("Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank " + t.rank + " and dim was " + n);return customGrad(function (e, t) { + var r = t.logSumExp([n], !0), + o = t.toFloat().sub(r);return { value: o.mul(e).neg().sum([n]), gradFunc: function (t) { + var r = expandShapeToKeepDim(t.shape, [n]);return [t.reshape(r).mul(e.toFloat().sub(o.exp())), t.reshape(r).mul(o.exp().sub(e.toFloat()))]; + } }; + })(e, t); + }function softmaxCrossEntropy_(e, t, n, r, o) { + void 0 === r && (r = 0), void 0 === o && (o = exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a = convertToTensor(e, "onehotLabels", "softmaxCrossEntropy"), + i = convertToTensor(t, "logits", "softmaxCrossEntropy"), + s = null;if (null != n && (s = convertToTensor(n, "weights", "softmaxCrossEntropy")), assertShapesMatch(a.shape, i.shape, "Error in softmaxCrossEntropy: "), r > 0) { + var u = scalar(r), + l = scalar(1), + c = scalar(a.shape[1]);a = a.mul(l.sub(u)).add(u.div(c)); + }var p = softmaxCrossEntropyWithLogits_(a, i);return computeWeightedLoss(p, s, o); + }!function (e) { + e[e.NONE = 0] = "NONE", e[e.MEAN = 1] = "MEAN", e[e.SUM = 2] = "SUM", e[e.SUM_BY_NONZERO_WEIGHTS = 3] = "SUM_BY_NONZERO_WEIGHTS"; + }(exports.Reduction || (exports.Reduction = {}));var absoluteDifference = op({ absoluteDifference_: absoluteDifference_ }), + computeWeightedLoss = op({ computeWeightedLoss_: computeWeightedLoss_ }), + cosineDistance = op({ cosineDistance_: cosineDistance_ }), + hingeLoss = op({ hingeLoss_: hingeLoss_ }), + huberLoss = op({ huberLoss_: huberLoss_ }), + logLoss = op({ logLoss_: logLoss_ }), + meanSquaredError = op({ meanSquaredError_: meanSquaredError_ }), + sigmoidCrossEntropy = op({ sigmoidCrossEntropy_: sigmoidCrossEntropy_ }), + softmaxCrossEntropy = op({ softmaxCrossEntropy_: softmaxCrossEntropy_ }), + loss_ops = Object.freeze({ get Reduction() { + return exports.Reduction; + }, absoluteDifference: absoluteDifference, computeWeightedLoss: computeWeightedLoss, cosineDistance: cosineDistance, hingeLoss: hingeLoss, huberLoss: huberLoss, logLoss: logLoss, meanSquaredError: meanSquaredError, sigmoidCrossEntropy: sigmoidCrossEntropy, softmaxCrossEntropy: softmaxCrossEntropy });function gramSchmidt_(e) { + var t;if (Array.isArray(e)) { + t = !1, assert(null != e && e.length > 0, "Gram-Schmidt process: input must not be null, undefined, or empty");for (var n = e[0].shape[0], r = 1; r < e.length; ++r) assert(e[r].shape[0] === n, "Gram-Schmidt: Non-unique lengths found in the input vectors: (" + e[r].shape[0] + " vs. " + n + ")"); + } else t = !0, e = split(e, e.shape[0], 0).map(function (e) { + return squeeze(e, [0]); + });assert(e.length <= e[0].shape[0], "Gram-Schmidt: Number of vectors (" + e.length + ") exceeds number of dimensions (" + e[0].shape[0] + ").");var o = [], + a = e, + i = function (e) { + o.push(ENV.engine.tidy(function () { + var t = a[e];if (e > 0) for (var n = 0; n < e; ++n) { + var r = sum(o[n].mulStrict(t)).mul(o[n]);t = t.sub(r); + }return t.div(norm(t, "euclidean")); + })); + };for (r = 0; r < e.length; ++r) i(r);return t ? stack(o, 0) : o; + }function qr_(e, t) { + if (void 0 === t && (t = !1), e.rank < 2) throw new Error("qr() requires input tensor to have a rank >= 2, but got rank " + e.rank);if (2 === e.rank) return qr2d(e, t);var n = e.shape.slice(0, e.shape.length - 2).reduce(function (e, t) { + return e * t; + }), + r = [], + o = [];return unstack(e.reshape([n, e.shape[e.shape.length - 2], e.shape[e.shape.length - 1]]), 0).forEach(function (e) { + var n = qr2d(e, t), + a = n[0], + i = n[1];r.push(a), o.push(i); + }), [stack(r, 0).reshape(e.shape), stack(o, 0).reshape(e.shape)]; + }function qr2d(e, t) { + return void 0 === t && (t = !1), ENV.engine.tidy(function () { + if (2 !== e.shape.length) throw new Error("qr2d() requires a 2D Tensor, but got a " + e.shape.length + "D Tensor.");for (var n = e.shape[0], r = e.shape[1], o = eye(n), a = e.clone(), i = tensor2d([[1]], [1, 1]), s = i.clone(), u = n >= r ? r : n, l = function (e) { + var t, + u = a, + l = s, + c = o;t = ENV.engine.tidy(function () { + var t = a.slice([e, e], [n - e, 1]), + u = t.norm(), + l = a.slice([e, e], [1, 1]), + c = l.sign().neg(), + p = l.sub(c.mul(u)), + d = t.div(p);s = 1 === d.shape[0] ? i.clone() : i.concat(d.slice([1, 0], [d.shape[0] - 1, d.shape[1]]), 0);var h = c.matMul(p).div(u).neg(), + f = a.slice([e, 0], [n - e, r]), + m = h.mul(s);a = 0 === e ? f.sub(m.matMul(s.transpose().matMul(f))) : a.slice([0, 0], [e, r]).concat(f.sub(m.matMul(s.transpose().matMul(f))), 0);var g = o.slice([0, e], [n, o.shape[1] - e]);return o = 0 === e ? g.sub(g.matMul(s).matMul(m.transpose())) : o.slice([0, 0], [n, e]).concat(g.sub(g.matMul(s).matMul(m.transpose())), 1), [s, a, o]; + }), s = t[0], a = t[1], o = t[2], dispose([u, l, c]); + }, c = 0; c < u; ++c) l(c);return !t && n > r && (o = o.slice([0, 0], [n, r]), a = a.slice([0, 0], [r, r])), [o, a]; + }); + }var gramSchmidt = op({ gramSchmidt_: gramSchmidt_ }), + qr = op({ qr_: qr_ }), + linalg_ops = Object.freeze({ gramSchmidt: gramSchmidt, qr: qr });function resizeBilinear_(e, t, n) { + void 0 === n && (n = !1);var r = convertToTensor(e, "images", "resizeBilinear");assert(3 === r.rank || 4 === r.rank, "Error in resizeBilinear: x must be rank 3 or 4, but got rank " + r.rank + "."), assert(2 === t.length, "Error in resizeBilinear: new shape must 2D, but got shape " + t + ".");var o = r, + a = !1;3 === r.rank && (a = !0, o = r.as4D(1, r.shape[0], r.shape[1], r.shape[2]));var i = t[0], + s = t[1], + u = ENV.engine.runKernel(function (e, t) { + return e.resizeBilinear(o, i, s, n); + }, { batchImages: o }, function (e, t) { + return { batchImages: function () { + return ENV.engine.runKernel(function (t) { + return t.resizeBilinearBackprop(e, o, n); + }, {}); + } }; + });return a ? u.as3D(u.shape[1], u.shape[2], u.shape[3]) : u; + }function resizeNearestNeighbor_(e, t, n) { + void 0 === n && (n = !1);var r = convertToTensor(e, "images", "resizeNearestNeighbor");assert(3 === r.rank || 4 === r.rank, "Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank " + r.rank + "."), assert(2 === t.length, "Error in resizeNearestNeighbor: new shape must 2D, but got shape " + t + "."), assert("float32" === r.dtype || "int32" === r.dtype, "`images` must have `int32` or `float32` as dtype");var o = r, + a = !1;3 === r.rank && (a = !0, o = r.as4D(1, r.shape[0], r.shape[1], r.shape[2]));var i = t[0], + s = t[1], + u = ENV.engine.runKernel(function (e, t) { + return e.resizeNearestNeighbor(o, i, s, n); + }, { batchImages: o }, function (e, t) { + return { batchImages: function () { + return ENV.engine.runKernel(function (t) { + return t.resizeNearestNeighborBackprop(e, o, n); + }, {}); + } }; + });return a ? u.as3D(u.shape[1], u.shape[2], u.shape[3]) : u; + }function nonMaxSuppression_(e, t, n, r, o) { + void 0 === r && (r = .5), void 0 === o && (o = Number.NEGATIVE_INFINITY);var a = convertToTensor(e, "boxes", "nonMaxSuppression"), + i = convertToTensor(t, "scores", "nonMaxSuppression"), + s = nonMaxSuppSanityCheck(a, i, n, r, o);return n = s.maxOutputSize, r = s.iouThreshold, o = s.scoreThreshold, ENV.engine.runKernel(function (e) { + return e.nonMaxSuppression(a, i, n, r, o); + }, { $boxes: a }); + }function nonMaxSuppressionAsync_(e, t, n, r, o) { + return void 0 === r && (r = .5), void 0 === o && (o = Number.NEGATIVE_INFINITY), __awaiter(this, void 0, void 0, function () { + var a, i, s, u, l, c;return __generator(this, function (p) { + switch (p.label) {case 0: + return a = convertToTensor(e, "boxes", "nonMaxSuppressionAsync"), i = convertToTensor(t, "scores", "nonMaxSuppressionAsync"), s = nonMaxSuppSanityCheck(a, i, n, r, o), n = s.maxOutputSize, r = s.iouThreshold, o = s.scoreThreshold, [4, a.data()];case 1: + return u = p.sent(), [4, i.data()];case 2: + return l = p.sent(), c = nonMaxSuppressionImpl(u, l, n, r, o), a !== e && a.dispose(), i !== t && i.dispose(), [2, c];} + }); + }); + }function nonMaxSuppSanityCheck(e, t, n, r, o) { + null == r && (r = .5), null == o && (o = Number.NEGATIVE_INFINITY);var a = e.shape[0];return n = Math.min(n, a), assert(0 <= r && r <= 1, "iouThreshold must be in [0, 1], but was '" + r + "'"), assert(2 === e.rank, "boxes must be a 2D tensor, but was of rank '" + e.rank + "'"), assert(4 === e.shape[1], "boxes must have 4 columns, but 2nd dimension was " + e.shape[1]), assert(1 === t.rank, "scores must be a 1D tensor"), assert(t.shape[0] === a, "scores has incompatible shape with boxes. Expected " + a + ", but was " + t.shape[0]), { maxOutputSize: n, iouThreshold: r, scoreThreshold: o }; + }var resizeBilinear = op({ resizeBilinear_: resizeBilinear_ }), + resizeNearestNeighbor = op({ resizeNearestNeighbor_: resizeNearestNeighbor_ }), + nonMaxSuppression = op({ nonMaxSuppression_: nonMaxSuppression_ }), + nonMaxSuppressionAsync = nonMaxSuppressionAsync_, + image_ops = Object.freeze({ resizeBilinear: resizeBilinear, resizeNearestNeighbor: resizeNearestNeighbor, nonMaxSuppression: nonMaxSuppression, nonMaxSuppressionAsync: nonMaxSuppressionAsync }), + ops = Object.freeze({ image: image_ops, linalg: linalg_ops, losses: loss_ops, op: op, batchNormalization2d: batchNormalization2d, batchNormalization3d: batchNormalization3d, batchNormalization4d: batchNormalization4d, batchNormalization: batchNormalization, concat: concat, concat1d: concat1d, concat2d: concat2d, concat3d: concat3d, concat4d: concat4d, conv1d: conv1d, conv2d: conv2d, depthwiseConv2d: depthwiseConv2d, separableConv2d: separableConv2d, conv2dTranspose: conv2dTranspose, matMul: matMul, dot: dot, outerProduct: outerProduct, reverse: reverse, reverse1d: reverse1d, reverse2d: reverse2d, reverse3d: reverse3d, reverse4d: reverse4d, maxPool: maxPool, avgPool: avgPool, slice: slice, slice1d: slice1d, slice2d: slice2d, slice3d: slice3d, slice4d: slice4d, abs: abs, acos: acos, acosh: acosh, asin: asin, asinh: asinh, atan: atan, atanh: atanh, ceil: ceil, clipByValue: clipByValue, cos: cos, cosh: cosh, erf: erf, exp: exp, expm1: expm1, floor: floor, log: log$1, log1p: log1p, logSigmoid: logSigmoid, neg: neg, reciprocal: reciprocal, round: round, rsqrt: rsqrt, sigmoid: sigmoid, sign: sign, sin: sin, sinh: sinh, softplus: softplus, sqrt: sqrt, square: square, step: step, tan: tan, tanh: tanh$1, all: all, any: any, argMax: argMax, argMin: argMin, logSumExp: logSumExp, max: max, mean: mean, min: min, moments: moments, sum: sum, equal: equal, equalStrict: equalStrict, greater: greater, greaterEqual: greaterEqual, greaterEqualStrict: greaterEqualStrict, greaterStrict: greaterStrict, less: less, lessEqual: lessEqual, lessEqualStrict: lessEqualStrict, lessStrict: lessStrict, notEqual: notEqual, notEqualStrict: notEqualStrict, add: add, addN: addN, addStrict: addStrict, atan2: atan2, div: div, divStrict: divStrict, floorDiv: floorDiv, maximum: maximum, maximumStrict: maximumStrict, minimum: minimum, minimumStrict: minimumStrict, mod: mod, modStrict: modStrict, mul: mul, mulStrict: mulStrict, pow: pow, powStrict: powStrict, squaredDifference: squaredDifference, squaredDifferenceStrict: squaredDifferenceStrict, sub: sub, subStrict: subStrict, elu: elu, leakyRelu: leakyRelu, prelu: prelu, relu: relu, selu: selu, logicalAnd: logicalAnd, logicalNot: logicalNot, logicalOr: logicalOr, logicalXor: logicalXor, where: where, whereAsync: whereAsync, buffer: buffer, toPixels: toPixels, print: print, cast: cast, clone: clone, cumsum: cumsum, expandDims: expandDims, eye: eye, fromPixels: fromPixels, multinomial: multinomial, oneHot: oneHot, pad: pad, pad1d: pad1d, pad2d: pad2d, pad3d: pad3d, pad4d: pad4d, rand: rand, randomNormal: randomNormal, randomUniform: randomUniform, reshape: reshape, split: split, squeeze: squeeze, stack: stack, tile: tile, truncatedNormal: truncatedNormal, unstack: unstack, batchToSpaceND: batchToSpaceND, spaceToBatchND: spaceToBatchND, fill: fill, linspace: linspace, ones: ones$1, range: range, scalar: scalar, tensor: tensor, tensor1d: tensor1d, tensor2d: tensor2d, tensor3d: tensor3d, tensor4d: tensor4d, tensor5d: tensor5d, tensor6d: tensor6d, zeros: zeros, onesLike: onesLike, zerosLike: zerosLike, transpose: transpose, softmax: softmax, localResponseNormalization: localResponseNormalization, norm: norm, gather: gather, unsortedSegmentSum: unsortedSegmentSum, basicLSTMCell: basicLSTMCell, multiRNNCell: multiRNNCell, movingAverage: movingAverage, stridedSlice: stridedSlice, topk: topk }), + MathBackendCPU = function () { + function e() { + this.data = new WeakMap(), this.firstUse = !0, ENV.get("IS_BROWSER") && (this.canvas = document.createElement("canvas")); + }return e.prototype.register = function (e, t, n) { + if (this.firstUse && (this.firstUse = !1, ENV.get("IS_NODE") && warn("\n============================\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\n============================\n")), this.data.has(e)) throw new Error("Data buffer is already registered");this.data.set(e, null); + }, e.prototype.write = function (e, t) { + if (null == t) throw new Error("MathBackendCPU.write(): values can not be null");this.throwIfNoData(e), this.data.set(e, t); + }, e.prototype.fromPixels = function (e, t) { + if (null == e) throw new Error("pixels passed to tf.fromPixels() can not be null");var n, r;if (ENV.get("IS_NODE") && null == e.getContext) throw new Error("When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package");if (null != e.getContext) n = e.getContext("2d").getImageData(0, 0, e.width, e.height).data;else if (e instanceof ImageData) n = e.data;else { + if (!(e instanceof HTMLImageElement || e instanceof HTMLVideoElement)) throw new Error("pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was " + e.constructor.name);if (null == this.canvas) throw new Error("Can't read pixels from HTMLImageElement outside the browser.");this.canvas.width = e.width, this.canvas.height = e.height, this.canvas.getContext("2d").drawImage(e, 0, 0, e.width, e.height), n = this.canvas.getContext("2d").getImageData(0, 0, e.width, e.height).data; + }if (4 === t) r = new Int32Array(n);else { + var o = e.width * e.height;r = new Int32Array(o * t);for (var a = 0; a < o; a++) for (var i = 0; i < t; ++i) r[a * t + i] = n[4 * a + i]; + }return tensor3d(r, [e.height, e.width, t], "int32"); + }, e.prototype.read = function (e) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (t) { + return [2, this.readSync(e)]; + }); + }); + }, e.prototype.readSync = function (e) { + return this.throwIfNoData(e), this.data.get(e); + }, e.prototype.disposeData = function (e) { + this.data.has(e) && this.data.delete(e); + }, e.prototype.time = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t;return __generator(this, function (n) { + return t = now(), e(), [2, { kernelMs: now() - t }]; + }); + }); + }, e.prototype.memory = function () { + return { unreliable: !0 }; + }, e.prototype.throwIfNoData = function (e) { + if (!this.data.has(e)) throw new Error("CPU backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends"); + }, e.prototype.slice = function (e, t, n) { + for (var r = buffer(n, e.dtype), o = 0; o < r.size; ++o) { + var a = r.indexToLoc(o), + i = a.map(function (e, n) { + return e + t[n]; + });r.set.apply(r, [e.get.apply(e, i)].concat(a)); + }return r.toTensor(); + }, e.prototype.stridedSlice = function (e, t, n, r, o, a) { + var i = getStridedSlicedInfo(e.shape, t, n, r, o, a), + s = i[0], + u = i[1];if (u.some(function (e) { + return 0 === e; + })) return tensor([], u);for (var l = buffer(u, e.dtype), c = 0; c < l.size; c++) { + for (var p = l.indexToLoc(c), d = new Array(p.length), h = 0; h < d.length; h++) d[h] = p[h] * r[h] + s[h];l.set.apply(l, [e.get.apply(e, d)].concat(p)); + }return l.toTensor(); + }, e.prototype.reverse = function (e, t) { + for (var n = buffer(e.shape, e.dtype), r = e.buffer(), o = function (o) { + var a = n.indexToLoc(o), + i = a.slice();t.forEach(function (t) { + return i[t] = e.shape[t] - 1 - i[t]; + }), n.set.apply(n, [r.get.apply(r, i)].concat(a)); + }, a = 0; a < n.size; a++) o(a);return n.toTensor(); + }, e.prototype.concat = function (e, t) { + var n = computeOutShape$1(e.shape, t.shape, 1), + r = buffer(n, e.dtype);if (1 === e.shape[0] && 1 === t.shape[0]) { + var o = e.dataSync(), + a = t.dataSync(), + i = r.values;return i.set(o, 0), i.set(a, e.size), r.toTensor(); + }for (var s = 0; s < n[0]; ++s) { + for (var u = 0; u < e.shape[1]; ++u) r.set(e.get(s, u), s, u);for (u = 0; u < t.shape[1]; ++u) r.set(t.get(s, u), s, u + e.shape[1]); + }return r.toTensor(); + }, e.prototype.neg = function (e) { + return this.multiply(scalar(-1), e); + }, e.prototype.add = function (e, t) { + return this.broadcastedBinaryOp(e, t, upcastType(e.dtype, t.dtype), function (e, t) { + return e + t; + }); + }, e.prototype.addN = function (e) { + for (var t = e.map(function (e) { + return e.dataSync(); + }), n = buffer(e[0].shape, e[0].dtype), r = n.values, o = 0; o < e.length; o++) for (var a = t[o], i = 0; i < r.length; i++) r[i] += a[i];return n.toTensor(); + }, e.prototype.subtract = function (e, t) { + return this.broadcastedBinaryOp(e, t, upcastType(e.dtype, t.dtype), function (e, t) { + return e - t; + }); + }, e.prototype.pow = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + return Math.pow(e, t); + }); + }, e.prototype.matMul = function (e, t, n, r) { + for (var o = n ? e.shape[0] : e.shape[1], a = n ? e.shape[1] : e.shape[0], i = r ? t.shape[0] : t.shape[1], s = e.dataSync(), u = t.dataSync(), l = n ? [1, e.strides[0]] : [e.strides[0], 1], c = l[0], p = l[1], d = r ? [t.strides[0], 1] : [1, t.strides[0]], h = d[0], f = d[1], m = a * c, g = i * h, v = new Float32Array(a * i), y = 0, x = 0; x < m; x += c) for (var T = 0; T < g; T += h) { + for (var S = x, b = T, E = 0, w = 0; w < o; ++w) E += s[S] * u[b], S += p, b += f;v[y++] = E; + }return tensor2d(v, [a, i]); + }, e.prototype.multiply = function (e, t) { + return this.broadcastedBinaryOp(e, t, upcastType(e.dtype, t.dtype), function (e, t) { + return e * t; + }); + }, e.prototype.realDivide = function (e, t) { + return this.broadcastedBinaryOp(e, t, "float32", function (e, t) { + return e / t; + }); + }, e.prototype.floorDiv = function (e, t) { + return this.broadcastedBinaryOp(e, t, "int32", function (e, t) { + return Math.floor(e / t); + }); + }, e.prototype.sum = function (e, t) { + assertAxesAreInnerMostDims("sum", t, e.rank);for (var n = computeOutAndReduceShapes(e.shape, t), r = n[0], o = n[1], a = zeros(r, upcastType(e.dtype, "int32")), i = sizeFromShape(o), s = a.dataSync(), u = e.dataSync(), l = 0; l < s.length; ++l) { + for (var c = l * i, p = 0, d = 0; d < i; ++d) p += u[c + d];s[l] = p; + }return a; + }, e.prototype.unsortedSegmentSum = function (e, t, n) { + for (var r = [], o = e.rank - t.rank, a = 0; a < o; ++a) t = t.expandDims(a + 1);for (a = 0; a < n; ++a) { + var i = scalar(a, "int32"), + s = equal(i, t).asType("float32").mul(e).sum(0);r.push(s); + }return stack(r); + }, e.prototype.argMin = function (e, t) { + var n = [t];assertAxesAreInnerMostDims("argMin", n, e.rank);for (var r = computeOutAndReduceShapes(e.shape, n), o = r[0], a = r[1], i = zeros(o, "int32"), s = sizeFromShape(a), u = i.dataSync(), l = e.dataSync(), c = 0; c < u.length; ++c) { + for (var p = c * s, d = l[p], h = 0, f = 0; f < s; ++f) { + var m = l[p + f];m < d && (d = m, h = f); + }u[c] = h; + }return i; + }, e.prototype.argMax = function (e, t) { + var n = [t];assertAxesAreInnerMostDims("argMax", n, e.rank);for (var r = computeOutAndReduceShapes(e.shape, n), o = r[0], a = r[1], i = zeros(o, "int32"), s = sizeFromShape(a), u = i.dataSync(), l = e.dataSync(), c = 0; c < u.length; ++c) { + for (var p = c * s, d = l[p], h = 0, f = 0; f < s; ++f) { + var m = l[p + f];m > d && (d = m, h = f); + }u[c] = h; + }return i; + }, e.prototype.cumsum = function (e, t, n, r) { + if (t !== e.rank - 1) throw new Error("backend.cumsum in CPU expects an inner-most axis=" + (e.rank - 1) + " but got axis=" + t);for (var o = upcastType(e.dtype, "int32"), a = zeros(e.shape, o), i = a.dataSync(), s = e.dataSync(), u = e.shape[e.rank - 1], l = r ? function (e, t) { + return e + u - t - 1; + } : function (e, t) { + return e + t; + }, c = 0; c < s.length; c += u) for (var p = 0; p < u; p++) { + var d = l(c, p);if (0 === p) i[d] = n ? 0 : s[d];else { + var h = l(c, p - 1);i[d] = n ? s[h] + i[h] : s[d] + i[h]; + } + }return a; + }, e.prototype.equal = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e === t ? 1 : 0; + }); + }, e.prototype.notEqual = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e !== t ? 1 : 0; + }); + }, e.prototype.less = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e < t ? 1 : 0; + }); + }, e.prototype.lessEqual = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e <= t ? 1 : 0; + }); + }, e.prototype.greater = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e > t ? 1 : 0; + }); + }, e.prototype.greaterEqual = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e >= t ? 1 : 0; + }); + }, e.prototype.logicalNot = function (e) { + for (var t = e.dataSync(), n = new Int32Array(t.length), r = 0; r < t.length; ++r) n[r] = t[r] ? 0 : 1;return Tensor.make(e.shape, { values: n }, "bool"); + }, e.prototype.logicalAnd = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e && t; + }); + }, e.prototype.logicalOr = function (e, t) { + return this.broadcastedBinaryOp(e, t, "bool", function (e, t) { + return e || t; + }); + }, e.prototype.select = function (e, t, n) { + for (var r = e.dataSync(), o = t.dataSync(), a = n.dataSync(), i = zeros(t.shape, upcastType(t.dtype, n.dtype)), s = i.dataSync(), u = 0, l = 0 === e.rank || e.rank > 1 || 1 === t.rank ? 1 : t.shape[1], c = 0; c < r.length; c++) for (var p = 0; p < l; p++) 1 === r[c] ? s[u++] = o[c] : s[u++] = a[c];return i; + }, e.prototype.where = function (e) { + var t = e.dataSync();return whereImpl(e.shape, t); + }, e.prototype.topk = function (e, t, n) { + return topkImpl(e.dataSync(), e.shape, e.dtype, t, n); + }, e.prototype.min = function (e, t) { + assertAxesAreInnerMostDims("min", t, e.rank);for (var n = computeOutAndReduceShapes(e.shape, t), r = n[0], o = n[1], a = zeros(r, e.dtype), i = sizeFromShape(o), s = a.dataSync(), u = e.dataSync(), l = 0; l < s.length; ++l) { + for (var c = l * i, p = u[c], d = 0; d < i; ++d) { + var h = u[c + d];h < p && (p = h); + }s[l] = p; + }return a; + }, e.prototype.minimum = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + return Math.min(e, t); + }); + }, e.prototype.mod = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + var n = e % t;return e < 0 && t < 0 || e >= 0 && t >= 0 ? n : (n + t) % t; + }); + }, e.prototype.max = function (e, t) { + assertAxesAreInnerMostDims("max", t, e.rank);for (var n = computeOutAndReduceShapes(e.shape, t), r = n[0], o = n[1], a = zeros(r, e.dtype), i = sizeFromShape(o), s = a.dataSync(), u = e.dataSync(), l = 0; l < s.length; ++l) { + for (var c = l * i, p = u[c], d = 0; d < i; ++d) { + var h = u[c + d];h > p && (p = h); + }s[l] = p; + }return a; + }, e.prototype.maximum = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + return Math.max(e, t); + }); + }, e.prototype.all = function (e, t) { + assertAxesAreInnerMostDims("all", t, e.rank);for (var n = computeOutAndReduceShapes(e.shape, t), r = n[0], o = n[1], a = zeros(r, e.dtype), i = sizeFromShape(o), s = a.dataSync(), u = e.dataSync(), l = 0; l < s.length; ++l) { + for (var c = l * i, p = u[c], d = 0; d < i; ++d) { + var h = u[c + d];p = p && h; + }s[l] = p; + }return a; + }, e.prototype.any = function (e, t) { + assertAxesAreInnerMostDims("any", t, e.rank);for (var n = computeOutAndReduceShapes(e.shape, t), r = n[0], o = n[1], a = zeros(r, e.dtype), i = sizeFromShape(o), s = a.dataSync(), u = e.dataSync(), l = 0; l < s.length; ++l) { + for (var c = l * i, p = u[c], d = 0; d < i; ++d) { + var h = u[c + d];p = p || h; + }s[l] = p; + }return a; + }, e.prototype.squaredDifference = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + var n = e - t;return n * n; + }); + }, e.prototype.ceil = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) n[r] = Math.ceil(t[r]);return Tensor.make(e.shape, { values: n }); + }, e.prototype.floor = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) n[r] = Math.floor(t[r]);return Tensor.make(e.shape, { values: n }); + }, e.prototype.sign = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) t[r] < 0 ? n[r] = -1 : t[r] > 0 ? n[r] = 1 : n[r] = 0;return Tensor.make(e.shape, { values: n }); + }, e.prototype.round = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = Math.floor(t[r]);t[r] - o < .5 ? n[r] = Math.floor(t[r]) : t[r] - o > .5 ? n[r] = Math.ceil(t[r]) : n[r] = o % 2 == 0 ? o : o + 1; + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.exp = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) n[r] = Math.exp(t[r]);return Tensor.make(e.shape, { values: n }); + }, e.prototype.expm1 = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) n[r] = Math.expm1(t[r]);return Tensor.make(e.shape, { values: n }); + }, e.prototype.log = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = t[r];n[r] = Math.log(o); + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.log1p = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = t[r];n[r] = Math.log1p(o); + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.sqrt = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = t[r];n[r] = Math.sqrt(o); + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.rsqrt = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = t[r];n[r] = 1 / Math.sqrt(o); + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.square = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) { + var o = t[r];n[r] = o * o; + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.reciprocal = function (e) { + for (var t = e.dataSync(), n = new Float32Array(t.length), r = 0; r < t.length; ++r) n[r] = 1 / t[r];return Tensor.make(e.shape, { values: n }); + }, e.prototype.relu = function (e) { + for (var t = zeros(e.shape, e.dtype), n = t.dataSync(), r = e.dataSync(), o = 0; o < r.length; ++o) n[o] = Math.max(0, r[o]);return t; + }, e.prototype.elu = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) { + var o = n[r];t[r] = o >= 0 ? o : Math.exp(o) - 1; + }return Tensor.make(e.shape, { values: t }); + }, e.prototype.eluDer = function (e, t) { + for (var n = new Float32Array(t.size), r = t.dataSync(), o = e.dataSync(), a = 0; a < r.length; ++a) { + var i = r[a];n[a] = i >= 1 ? o[a] : o[a] * (i + 1); + }return Tensor.make(t.shape, { values: n }); + }, e.prototype.selu = function (e) { + for (var t = SELU_SCALEALPHA, n = SELU_SCALE, r = new Float32Array(e.size), o = e.dataSync(), a = 0; a < o.length; ++a) { + var i = o[a];r[a] = i >= 0 ? n * i : t * (Math.exp(i) - 1); + }return Tensor.make(e.shape, { values: r }); + }, e.prototype.clip = function (e, t, n) { + for (var r = new Float32Array(e.size), o = e.dataSync(), a = 0; a < o.length; ++a) r[a] = Math.min(n, Math.max(t, o[a]));return Tensor.make(e.shape, { values: r }); + }, e.prototype.abs = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.abs(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.int = function (e) { + for (var t = new Int32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = n[r];return Tensor.make(e.shape, { values: t }, "int32"); + }, e.prototype.sigmoid = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = 1 / (1 + Math.exp(-n[r]));return Tensor.make(e.shape, { values: t }); + }, e.prototype.softplus = function (e) { + for (var t = Math.log(1.1920928955078125e-7) + 2, n = new Float32Array(e.size), r = e.dataSync(), o = 0; o < r.length; ++o) { + var a = r[o] > -t, + i = r[o] < t, + s = Math.exp(r[o]), + u = void 0;u = i ? s : a ? r[o] : Math.log(1 + s), n[o] = u; + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.sin = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.sin(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.cos = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.cos(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.tan = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.tan(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.asin = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.asin(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.acos = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.acos(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.atan = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.atan(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.atan2 = function (e, t) { + return this.broadcastedBinaryOp(e, t, e.dtype, function (e, t) { + return Math.atan2(e, t); + }); + }, e.prototype.sinh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.sinh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.cosh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.cosh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.tanh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = tanh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.asinh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.asinh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.acosh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.acosh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.atanh = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = 0; r < n.length; ++r) t[r] = Math.atanh(n[r]);return Tensor.make(e.shape, { values: t }); + }, e.prototype.erf = function (e) { + for (var t = new Float32Array(e.size), n = e.dataSync(), r = ERF_P, o = ERF_A1, a = ERF_A2, i = ERF_A3, s = ERF_A4, u = ERF_A5, l = 0; l < n.length; ++l) { + var c = n[l], + p = 1 / (1 + r * c);t[l] = 1 - ((((u * p + s) * p + i) * p + a) * p + o) * p * Math.exp(-c * c); + }return Tensor.make(e.shape, { values: t }); + }, e.prototype.step = function (e, t) { + void 0 === t && (t = 0);for (var n = new Float32Array(e.size), r = e.dataSync(), o = 0; o < r.length; ++o) { + var a = r[o];isNaN(a) ? n[o] = NaN : n[o] = a > 0 ? 1 : t; + }return Tensor.make(e.shape, { values: n }); + }, e.prototype.conv2d = function (e, t, n) { + for (var r = n.filterHeight, o = n.filterWidth, a = n.dilationHeight, i = n.dilationWidth, s = n.padInfo.left, u = n.padInfo.top, l = buffer(n.outShape, e.dtype), c = 0; c < n.batchSize; ++c) for (var p = 0; p < n.outChannels; ++p) for (var d = 0; d < n.outHeight; ++d) for (var h = d * n.strideHeight - s, f = 0; f < n.outWidth; ++f) { + for (var m = f * n.strideWidth - u, g = 0, v = 0; v < r; v++) { + var y = h + v * a;if (!(y < 0 || y >= n.inHeight)) for (var x = 0; x < o; x++) { + var T = m + x * i;if (!(T < 0 || T >= n.inWidth)) for (var S = 0; S < n.inChannels; ++S) { + g += e.get(c, y, T, S) * t.get(v, x, S, p); + } + } + }l.set(g, c, d, f, p); + }return l.toTensor(); + }, e.prototype.conv2dDerInput = function (e, t, n) { + for (var r = buffer(n.inShape, "float32"), o = r.values, a = r.strides, i = a[0], s = a[1], u = a[2], l = e.dataSync(), c = e.strides, p = c[0], d = c[1], h = c[2], f = t.dataSync(), m = t.strides, g = m[0], v = m[1], y = m[2], x = n.batchSize, T = n.filterHeight, S = n.filterWidth, b = n.inChannels, E = n.inHeight, w = n.inWidth, _ = n.outChannels, A = n.outHeight, R = n.outWidth, C = n.strideHeight, N = n.strideWidth, k = T - 1 - n.padInfo.top, I = S - 1 - n.padInfo.left, D = 0; D < x; ++D) for (var M = 0; M < b; ++M) for (var O = 0; O < E; ++O) for (var F = O - k, P = Math.max(0, Math.ceil(F / C)), L = Math.min(A, (T + F) / C), B = 0; B < w; ++B) { + for (var U = B - I, V = Math.max(0, Math.ceil(U / N)), z = Math.min(R, (S + U) / N), G = 0, H = P; H < L; ++H) for (var W = H * C - F, q = V; q < z; ++q) for (var $ = p * D + d * H + h * q, X = g * (T - 1 - W) + v * (S - 1 - (q * N - U)) + y * M, j = 0; j < _; ++j) { + G += l[$ + j] * f[X + j]; + }o[i * D + s * O + u * B + M] = G; + }return r.toTensor(); + }, e.prototype.conv2dDerFilter = function (e, t, n) { + for (var r = n.strideHeight, o = n.strideWidth, a = n.filterHeight, i = n.filterWidth, s = buffer(n.filterShape, "float32"), u = n.padInfo.left, l = n.padInfo.top, c = 0; c < a; ++c) for (var p = Math.max(0, Math.ceil((l - c) / r)), d = Math.min(n.outHeight, (n.inHeight + l - c) / r), h = 0; h < i; ++h) for (var f = Math.max(0, Math.ceil((u - h) / o)), m = Math.min(n.outWidth, (n.inWidth + u - h) / o), g = 0; g < n.inChannels; ++g) for (var v = 0; v < n.outChannels; ++v) { + for (var y = 0, x = 0; x < n.batchSize; ++x) for (var T = p; T < d; ++T) for (var S = c + T * r - l, b = f; b < m; ++b) { + var E = h + b * o - u;y += e.get(x, S, E, g) * t.get(x, T, b, v); + }s.set(y, c, h, g, v); + }return s.toTensor(); + }, e.prototype.depthwiseConv2D = function (e, t, n) { + for (var r = n.filterHeight, o = n.filterWidth, a = n.dilationHeight, i = n.dilationWidth, s = n.padInfo.left, u = n.padInfo.top, l = n.outChannels / n.inChannels, c = buffer(n.outShape, e.dtype), p = 0; p < n.batchSize; ++p) for (var d = 0; d < n.inChannels; ++d) for (var h = 0; h < n.outHeight; ++h) for (var f = h * n.strideHeight - s, m = 0; m < n.outWidth; ++m) for (var g = m * n.strideWidth - u, v = 0; v < l; ++v) { + for (var y = 0, x = 0; x < r; ++x) { + var T = f + x * a;if (!(T < 0 || T >= n.inHeight)) for (var S = 0; S < o; ++S) { + var b = g + S * i;if (!(b < 0 || b >= n.inWidth)) y += e.get(p, T, b, d) * t.get(x, S, d, v); + } + }c.set(y, p, h, m, d * l + v); + }return c.toTensor(); + }, e.prototype.depthwiseConv2DDerInput = function (e, t, n) { + for (var r = buffer(n.inShape, "float32"), o = r.values, a = r.strides, i = a[0], s = a[1], u = a[2], l = e.dataSync(), c = e.strides, p = c[0], d = c[1], h = c[2], f = t.dataSync(), m = t.strides, g = m[0], v = m[1], y = m[2], x = n.batchSize, T = n.filterHeight, S = n.filterWidth, b = n.inChannels, E = n.inHeight, w = n.inWidth, _ = n.outChannels, A = n.outHeight, R = n.outWidth, C = n.strideHeight, N = n.strideWidth, k = T - 1 - n.padInfo.top, I = S - 1 - n.padInfo.left, D = _ / b, M = 0; M < x; ++M) for (var O = 0; O < b; ++O) for (var F = 0; F < E; ++F) for (var P = F - k, L = Math.max(0, Math.ceil(P / C)), B = Math.min(A, (T + P) / C), U = 0; U < w; ++U) { + for (var V = U - I, z = Math.max(0, Math.ceil(V / N)), G = Math.min(R, (S + V) / N), H = 0, W = L; W < B; ++W) for (var q = W * C - P, $ = z; $ < G; ++$) for (var X = p * M + d * W + h * $, j = g * (T - 1 - q) + v * (S - 1 - ($ * N - V)) + y * O, K = 0; K < D; ++K) { + H += l[X + (O * D + K)] * f[j + K]; + }o[i * M + s * F + u * U + O] = H; + }return r.toTensor(); + }, e.prototype.depthwiseConv2DDerFilter = function (e, t, n) { + for (var r = n.strideHeight, o = n.strideWidth, a = n.filterHeight, i = n.filterWidth, s = buffer(n.filterShape, "float32"), u = n.padInfo.left, l = n.padInfo.top, c = n.outChannels / n.inChannels, p = 0; p < a; ++p) for (var d = Math.max(0, Math.ceil((l - p) / r)), h = Math.min(n.outHeight, (n.inHeight + l - p) / r), f = 0; f < i; ++f) for (var m = Math.max(0, Math.ceil((u - f) / o)), g = Math.min(n.outWidth, (n.inWidth + u - f) / o), v = 0; v < n.outChannels; ++v) { + for (var y = Math.trunc(v / c), x = v % c, T = 0, S = 0; S < n.batchSize; ++S) for (var b = d; b < h; ++b) for (var E = p + b * r - l, w = m; w < g; ++w) { + var _ = f + w * o - u;T += e.get(S, E, _, y) * t.get(S, b, w, v); + }s.set(T, p, f, y, x); + }return s.toTensor(); + }, e.prototype.tile = function (e, t) { + for (var n = new Array(e.rank), r = 0; r < n.length; r++) n[r] = e.shape[r] * t[r];var o = buffer(n, e.dtype), + a = e.buffer();for (r = 0; r < o.values.length; ++r) { + for (var i = o.indexToLoc(r), s = new Array(e.rank), u = 0; u < s.length; u++) s[u] = i[u] % e.shape[u];var l = a.locToIndex(s);o.values[r] = a.values[l]; + }return o.toTensor(); + }, e.prototype.pad = function (e, t, n) { + var r = t.map(function (t, n) { + return t[0] + e.shape[n] + t[1]; + }), + o = t.map(function (e) { + return e[0]; + }), + a = e.buffer(), + i = buffer(r, e.dtype);0 !== n && i.values.fill(n);for (var s = 0; s < e.size; s++) { + var u = a.indexToLoc(s), + l = u.map(function (e, t) { + return e + o[t]; + });i.set.apply(i, [e.get.apply(e, u)].concat(l)); + }return i.toTensor(); + }, e.prototype.transpose = function (e, t) { + for (var n = new Array(e.rank), r = 0; r < n.length; r++) n[r] = e.shape[t[r]];var o = e.dataSync(), + a = buffer(n, e.dtype), + i = e.buffer();for (r = 0; r < e.size; ++r) { + for (var s = i.indexToLoc(r), u = new Array(s.length), l = 0; l < u.length; l++) u[l] = s[t[l]];var c = a.locToIndex(u);a.values[c] = o[r]; + }return a.toTensor(); + }, e.prototype.gather = function (e, t, n) { + var r = e.shape.slice(), + o = t.dataSync();r[n] = o.length;for (var a = buffer(r, e.dtype), i = e.buffer(), s = 0; s < a.size; ++s) { + var u = a.indexToLoc(s), + l = u.slice();l[n] = o[u[n]];var c = i.locToIndex(l);a.values[s] = i.values[c]; + }return a.toTensor(); + }, e.prototype.batchToSpaceND = function (e, t, n) { + var r = t.reduce(function (e, t) { + return e * t; + }), + o = getReshaped(e.shape, t, r), + a = getPermuted(o.length, t.length), + i = getReshapedPermuted(e.shape, t, r), + s = getSliceBeginCoords(n, t.length), + u = getSliceSize(i, n, t.length);return e.reshape(o).transpose(a).reshape(i).slice(s, u); + }, e.prototype.spaceToBatchND = function (e, t, n) { + var r = t.reduce(function (e, t) { + return e * t; + }), + o = [[0, 0]];o.push.apply(o, n);for (var a = 1 + t.length; a < e.shape.length; ++a) o.push([0, 0]);var i = e.pad(o), + s = getReshaped(i.shape, t, r, !1), + u = getPermuted(s.length, t.length, !1), + l = getReshapedPermuted(i.shape, t, r, !1);return i.reshape(s).transpose(u).reshape(l); + }, e.prototype.pool = function (e, t, n) { + for (var r = t.strideHeight, o = t.strideWidth, a = t.filterHeight, i = t.filterWidth, s = buffer(t.outShape, "float32"), u = t.padInfo.top, l = t.padInfo.left, c = 0; c < t.batchSize; ++c) for (var p = 0; p < t.inChannels; ++p) for (var d = 0; d < t.outHeight; ++d) for (var h = d * r - u, f = Math.max(0, h), m = Math.min(t.inHeight, a + h), g = 0; g < t.outWidth; ++g) { + for (var v = g * o - l, y = Math.max(0, v), x = Math.min(t.inWidth, i + v), T = "max" === n ? Number.NEGATIVE_INFINITY : Number.POSITIVE_INFINITY, S = 0, b = 0, E = f; E < m; ++E) { + for (var w = y; w < x; ++w) { + var _ = e.get(c, E, w, p);"max" === n && _ > T ? T = _ : "avg" === n && (S += _, b++); + }if (isNaN(T)) break; + }s.set("avg" === n ? S / b : T, c, d, g, p); + }return s.toTensor(); + }, e.prototype.maxPool = function (e, t) { + return this.pool(e, t, "max"); + }, e.prototype.maxPoolPositions = function (e, t) { + for (var n = buffer(t.outShape, "int32"), r = t.strideHeight, o = t.strideWidth, a = t.filterHeight, i = t.filterWidth, s = t.padInfo.top, u = t.padInfo.left, l = 0; l < t.batchSize; ++l) for (var c = 0; c < t.inChannels; ++c) for (var p = 0; p < t.outHeight; ++p) for (var d = p * r - s, h = Math.max(0, d), f = Math.min(t.inHeight, a + d), m = 0; m < t.outWidth; ++m) { + for (var g = m * o - u, v = Math.max(0, g), y = Math.min(t.inWidth, i + g), x = Number.NEGATIVE_INFINITY, T = -1, S = h; S < f; ++S) for (var b = S - d, E = v; E < y; ++E) { + var w = E - g, + _ = e.get(l, S, E, c);_ > x && (x = _, T = b * i + w); + }n.set(T, l, p, m, c); + }return n.toTensor(); + }, e.prototype.maxPoolBackprop = function (e, t, n, r) { + for (var o = this.maxPoolPositions(t, r), a = r.strideHeight, i = r.strideWidth, s = r.filterHeight, u = r.filterWidth, l = u - 1 - r.padInfo.left, c = s - 1 - r.padInfo.top, p = buffer(t.shape, "float32"), d = 0; d < r.batchSize; ++d) for (var h = 0; h < r.inChannels; ++h) for (var f = 0; f < r.inHeight; ++f) for (var m = 0; m < r.inWidth; ++m) { + for (var g = f - c, v = m - l, y = 0, x = 0; x < s; ++x) { + var T = (g + x) / a;if (!(T < 0 || T >= r.outHeight || Math.floor(T) !== T)) for (var S = 0; S < u; ++S) { + var b = (v + S) / i;if (!(b < 0 || b >= r.outWidth || Math.floor(b) !== b)) { + var E = s * u - 1 - o.get(d, T, b, h) === x * u + S ? 1 : 0;if (0 !== E) y += e.get(d, T, b, h) * E; + } + } + }p.set(y, d, f, m, h); + }return p.toTensor(); + }, e.prototype.avgPoolBackprop = function (e, t, n) { + for (var r = n.strideHeight, o = n.strideWidth, a = n.filterHeight, i = n.filterWidth, s = i - 1 - n.padInfo.left, u = a - 1 - n.padInfo.top, l = buffer(t.shape, "float32"), c = 1 / (a * i), p = 0; p < n.batchSize; ++p) for (var d = 0; d < n.inChannels; ++d) for (var h = 0; h < n.inHeight; ++h) for (var f = 0; f < n.inWidth; ++f) { + for (var m = h - u, g = f - s, v = 0, y = 0; y < a; ++y) { + var x = (m + y) / r;if (!(x < 0 || x >= n.outHeight || Math.floor(x) !== x)) for (var T = 0; T < i; ++T) { + var S = (g + T) / o;if (!(S < 0 || S >= n.outWidth || Math.floor(S) !== S)) v += e.get(p, x, S, d); + } + }l.set(v * c, p, h, f, d); + }return l.toTensor(); + }, e.prototype.cast = function (e, t) { + return castTensor(e, t, this); + }, e.prototype.reshape = function (e, t) { + return reshapeTensor(e, t); + }, e.prototype.avgPool = function (e, t) { + return this.pool(e, t, "avg").toFloat(); + }, e.prototype.resizeBilinear = function (e, t, n, r) { + for (var o = e.shape, a = o[0], i = o[1], s = o[2], u = o[3], l = buffer([a, t, n, u], e.dtype), c = [r && t > 1 ? i - 1 : i, r && n > 1 ? s - 1 : s], p = [r && t > 1 ? t - 1 : t, r && n > 1 ? n - 1 : n], d = 0; d < a; d++) for (var h = 0; h < t; h++) for (var f = 0; f < n; f++) for (var m = 0; m < u; m++) { + var g = c[0] * h / p[0], + v = c[1] * f / p[1], + y = Math.floor(g), + x = Math.min(i - 1, Math.ceil(g)), + T = Math.floor(v), + S = Math.min(s - 1, Math.ceil(v)), + b = e.get(d, y, T, m), + E = e.get(d, x, T, m), + w = v - T, + _ = b + (e.get(d, y, S, m) - b) * w, + A = _ + (E + (e.get(d, x, S, m) - E) * w - _) * (g - y);l.set(A, d, h, f, m); + }return l.toTensor(); + }, e.prototype.resizeBilinearBackprop = function (e, t, n) { + for (var r = t.shape, o = r[0], a = r[1], i = r[2], s = r[3], u = e.shape, l = u[1], c = u[2], p = buffer([o, a, i, s], t.dtype), d = [n && l > 1 ? a - 1 : a, n && c > 1 ? i - 1 : i], h = [n && l > 1 ? l - 1 : l, n && c > 1 ? c - 1 : c], f = d[0] / h[0], m = d[1] / h[1], g = 0; g < o; g++) for (var v = 0; v < l; v++) for (var y = v * f, x = Math.floor(y), T = Math.min(Math.ceil(y), a - 1), S = y - x, b = 1 - S, E = 0; E < c; E++) for (var w = E * m, _ = Math.floor(w), A = Math.min(Math.ceil(w), i - 1), R = w - _, C = 1 - R, N = 0; N < s; N++) { + var k = e.get(g, v, E, N), + I = p.get(g, x, _, N);I += k * b * C, p.set(I, g, x, _, N);var D = p.get(g, x, A, N);D += k * b * R, p.set(D, g, x, A, N);var M = p.get(g, T, _, N);M += k * S * C, p.set(M, g, T, _, N);var O = p.get(g, T, A, N);O += k * S * R, p.set(O, g, T, A, N); + }return p.toTensor(); + }, e.prototype.resizeNearestNeighbor = function (e, t, n, r) { + for (var o = e.shape, a = o[0], i = o[1], s = o[2], u = o[3], l = buffer([a, t, n, u], e.dtype), c = [r && t > 1 ? i - 1 : i, r && n > 1 ? s - 1 : s], p = [r && t > 1 ? t - 1 : t, r && n > 1 ? n - 1 : n], d = 0; d < a; d++) for (var h = 0; h < t; h++) for (var f = 0; f < n; f++) for (var m = 0; m < u; m++) { + var g = c[0] * h / p[0], + v = c[1] * f / p[1], + y = Math.min(i - 1, r ? Math.round(g) : Math.floor(g)), + x = Math.min(s - 1, r ? Math.round(v) : Math.floor(v)), + T = e.get(d, y, x, m);l.set(T, d, h, f, m); + }return l.toTensor(); + }, e.prototype.resizeNearestNeighborBackprop = function (e, t, n) { + for (var r = t.shape, o = r[0], a = r[1], i = r[2], s = r[3], u = e.shape, l = u[1], c = u[2], p = buffer([o, a, i, s], t.dtype), d = [n && l > 1 ? a - 1 : a, n && c > 1 ? i - 1 : i], h = [n && l > 1 ? l - 1 : l, n && c > 1 ? c - 1 : c], f = 1 / (d[0] / h[0]), m = 1 / (d[1] / h[1]), g = 2 * Math.ceil(f) + 2, v = 2 * Math.ceil(m) + 2, y = 0; y < o; y++) for (var x = 0; x < a; x++) for (var T = 0; T < i; T++) for (var S = Math.floor(x * f), b = Math.floor(S - g / 2), E = Math.floor(T * m), w = Math.floor(E - v / 2), _ = 0; _ < s; _++) { + for (var A = 0, R = 0; R < g; R++) { + var C = R + b;if (!(C < 0 || C >= l)) for (var N = 0; N < v; N++) { + var k = N + w;if (!(k < 0 || k >= c)) { + var I = d[0] * (C / h[0]), + D = d[1] * (k / h[1]), + M = Math.min(a - 1, n ? Math.round(I) : Math.floor(I)), + O = Math.min(i - 1, n ? Math.round(D) : Math.floor(D));x === M && T === O && (A += e.get(y, C, k, _)); + } + } + }p.set(A, y, x, T, _); + }return p.toTensor(); + }, e.prototype.batchNormalization = function (e, t, n, r, o, a) { + for (var i = e.dataSync(), s = t.dataSync(), u = n.dataSync(), l = o ? o.dataSync() : new Float32Array([1]), c = a ? a.dataSync() : new Float32Array([0]), p = new Float32Array(i.length), d = 0; d < i.length; d++) p[d] = c[d % c.length] + (i[d] - s[d % s.length]) * l[d % l.length] / Math.sqrt(u[d % u.length] + r);return tensor4d(p, e.shape); + }, e.prototype.localResponseNormalization4D = function (e, t, n, r, o) { + var a = buffer(e.shape, "float32"), + i = t, + s = a.shape[3] - 1;function u(t, n, r, o) { + for (var a = 0, u = Math.max(0, o - i); u <= Math.min(o + i, s); u++) { + var l = e.get(t, n, r, u);a += l * l; + }return a; + }for (var l = 0; l < a.shape[0]; l++) for (var c = 0; c <= a.shape[1]; c++) for (var p = 0; p < a.shape[2]; p++) for (var d = 0; d < a.shape[3]; d++) { + var h = u(l, c, p, d), + f = e.get(l, c, p, d) * Math.pow(n + r * h, -o);a.set(f, l, c, p, d); + }return a.toTensor(); + }, e.prototype.LRNGrad = function (e, t, n, r, o, a, i) { + for (var s = e.shape[0], u = e.shape[1], l = e.shape[2], c = e.shape[3], p = buffer([s, u, l, c], "float32"), d = 0; d < s; ++d) for (var h = 0; h < u; ++h) for (var f = 0; f < l; ++f) for (var m = 0; m < c; ++m) { + for (var g = Math.max(0, m - r), v = Math.min(c, m + r + 1), y = 0, x = g; x < v; ++x) y += t.get(d, h, f, x) * t.get(d, h, f, x);y = a * y + o;for (x = g; x < v; ++x) { + var T = -2 * a * i * t.get(d, h, f, x) * n.get(d, h, f, m) / y;m === x && (T += Math.pow(y, -i)), T *= e.get(d, h, f, m), p.set(T + p.get(d, h, f, x), d, h, f, x); + } + }return p.toTensor(); + }, e.prototype.multinomial = function (e, t, n, r) { + for (var o = t ? e : softmax(e), a = o.shape[0], i = o.shape[1], s = zeros([a, n], "int32"), u = s.dataSync(), l = o.dataSync(), c = 0; c < a; ++c) { + var p = c * i, + d = new Float32Array(i - 1);d[0] = l[p];for (var h = 1; h < d.length; ++h) d[h] = d[h - 1] + l[p + h];for (var f = seedrandom_1(r.toString()), m = c * n, g = 0; g < n; ++g) { + var v = f();u[m + g] = d.length;for (var y = 0; y < d.length; y++) if (v < d[y]) { + u[m + g] = y;break; + } + } + }return s; + }, e.prototype.oneHot = function (e, t, n, r) { + var o = new Float32Array(e.size * t);o.fill(r);for (var a = 0; a < e.size; ++a) e.get(a) >= 0 && e.get(a) < t && (o[a * t + e.get(a)] = n);return tensor2d(o, [e.size, t], "int32"); + }, e.prototype.nonMaxSuppression = function (e, t, n, r, o) { + return nonMaxSuppressionImpl(e.dataSync(), t.dataSync(), n, r, o); + }, e.prototype.broadcastedBinaryOp = function (e, t, n, r) { + for (var o = assertAndGetBroadcastShape(e.shape, t.shape), a = buffer(o, n), i = e.dataSync(), s = t.dataSync(), u = getBroadcastDims(e.shape, o), l = getBroadcastDims(t.shape, o), c = e.buffer(), p = t.buffer(), d = function (n) { + var o = a.indexToLoc(n), + d = o.slice(-e.rank);u.forEach(function (e) { + return d[e] = 0; + });var h = c.locToIndex(d), + f = o.slice(-t.rank);l.forEach(function (e) { + return f[e] = 0; + });var m = p.locToIndex(f);a.values[n] = r(i[h], s[m]); + }, h = 0; h < a.values.length; ++h) d(h);return a.toTensor(); + }, e.prototype.dispose = function () {}, e; + }();ENV.registerBackend("cpu", function () { + return new MathBackendCPU(); + }, 1, setTensorTracker);var delayCallback = "undefined" != typeof requestAnimationFrame ? requestAnimationFrame : setImmediate;function nextFrame() { + return new Promise(function (e) { + return delayCallback(function () { + return e(); + }); + }); + }var DTYPE_VALUE_SIZE_MAP = { float32: 4, int32: 4, uint16: 2, uint8: 1, bool: 1 };function encodeWeights(e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o;return __generator(this, function (a) { + switch (a.label) {case 0: + for (r in t = [], n = [], e) { + if ("float32" !== (o = e[r]).dtype && "int32" !== o.dtype && "bool" !== o.dtype) throw new Error("Unsupported dtype in weight '" + r + "': " + o.dtype);t.push({ name: r, shape: o.shape, dtype: o.dtype }), n.push(o.data()); + }return [4, Promise.all(n)];case 1: + return [2, { data: concatenateTypedArrays(a.sent()), specs: t }];} + }); + }); + }function decodeWeights(e, t) { + for (var n = {}, r = 0, o = 0, a = t; o < a.length; o++) { + var i = a[o], + s = i.name, + u = i.dtype, + l = i.shape;if (null != i.quantization) throw new Error("decodeWeights does not support quantization yet, but encountered weight '" + s + " with quantization.'");var c = sizeFromShape(l), + p = void 0;if ("float32" === u) p = tensor(new Float32Array(e, r, c), l, "float32");else if ("int32" === u) p = tensor(new Int32Array(e, r, c), l, "int32");else { + if ("bool" !== u) throw new Error("Unsupported dtype in weight '" + s + "': " + u);p = tensor(new Uint8Array(e, r, c), l, "bool"); + }n[s] = p, r += c * DTYPE_VALUE_SIZE_MAP[u]; + }return n; + }function concatenateTypedArrays(e) { + if (null === e) throw new Error("Invalid input value: " + JSON.stringify(e));var t = 0, + n = [];e.forEach(function (e) { + if (t += e.byteLength, n.push(e.byteLength === e.buffer.byteLength ? e : new e.constructor(e)), !(e instanceof Float32Array || e instanceof Int32Array || e instanceof Uint8Array)) throw new Error("Unsupported TypedArray subtype: " + e.constructor.name); + });var r = new Uint8Array(t), + o = 0;return n.forEach(function (e) { + r.set(new Uint8Array(e.buffer), o), o += e.byteLength; + }), r.buffer; + }var useNodeBuffer = "undefined" != typeof Buffer && ("undefined" == typeof Blob || "undefined" == typeof atob || "undefined" == typeof btoa);function stringByteLength(e) { + return useNodeBuffer ? Buffer.byteLength(e) : new Blob([e]).size; + }function arrayBufferToBase64String(e) { + return useNodeBuffer ? Buffer.from(e).toString("base64") : btoa(String.fromCharCode.apply(null, new Uint8Array(e))); + }function base64StringToArrayBuffer(e) { + if (useNodeBuffer) { + var t = Buffer.from(e, "base64");return t.buffer.slice(t.byteOffset, t.byteOffset + t.byteLength); + }for (var n = atob(e), r = new Uint8Array(n.length), o = 0; o < n.length; ++o) r.set([n.charCodeAt(o)], o);return r.buffer; + }function concatenateArrayBuffers(e) { + var t = 0;e.forEach(function (e) { + t += e.byteLength; + });var n = new Uint8Array(t), + r = 0;return e.forEach(function (e) { + n.set(new Uint8Array(e), r), r += e.byteLength; + }), n.buffer; + }function basename(e) { + for (e = e.trim(); e.endsWith("/");) e = e.slice(0, e.length - 1);var t = e.split("/");return t[t.length - 1]; + }function getModelArtifactsInfoForJSON(e) { + if (e.modelTopology instanceof ArrayBuffer) throw new Error("Expected JSON model topology, received ArrayBuffer.");return { dateSaved: new Date(), modelTopologyType: "JSON", modelTopologyBytes: null == e.modelTopology ? 0 : stringByteLength(JSON.stringify(e.modelTopology)), weightSpecsBytes: null == e.weightSpecs ? 0 : stringByteLength(JSON.stringify(e.weightSpecs)), weightDataBytes: null == e.weightData ? 0 : e.weightData.byteLength }; + }var IORouterRegistry = function () { + function e() { + this.saveRouters = [], this.loadRouters = []; + }return e.getInstance = function () { + return null == e.instance && (e.instance = new e()), e.instance; + }, e.registerSaveRouter = function (t) { + e.getInstance().saveRouters.push(t); + }, e.registerLoadRouter = function (t) { + e.getInstance().loadRouters.push(t); + }, e.getSaveHandlers = function (t) { + return e.getHandlers(t, "save"); + }, e.getLoadHandlers = function (t) { + return e.getHandlers(t, "load"); + }, e.getHandlers = function (e, t) { + var n = [];return ("load" === t ? this.getInstance().loadRouters : this.getInstance().saveRouters).forEach(function (t) { + var r = t(e);null !== r && n.push(r); + }), n; + }, e; + }(), + URL_SCHEME_SUFFIX = "://", + ModelStoreManagerRegistry = function () { + function e() { + this.managers = {}; + }return e.getInstance = function () { + return null == e.instance && (e.instance = new e()), e.instance; + }, e.registerManager = function (t, n) { + assert(null != t, "scheme must not be undefined or null."), t.endsWith(URL_SCHEME_SUFFIX) && (t = t.slice(0, t.indexOf(URL_SCHEME_SUFFIX))), assert(t.length > 0, "scheme must not be an empty string.");var r = e.getInstance();assert(null == r.managers[t], "A model store manager is already registered for scheme '" + t + "'."), r.managers[t] = n; + }, e.getManager = function (e) { + var t = this.getInstance().managers[e];if (null == t) throw new Error("Cannot find model manager for scheme '" + e + "'");return t; + }, e.getSchemes = function () { + return Object.keys(this.getInstance().managers); + }, e; + }();function parseURL(e) { + if (-1 === e.indexOf(URL_SCHEME_SUFFIX)) throw new Error("The url string provided does not contain a scheme. Supported schemes are: " + ModelStoreManagerRegistry.getSchemes().join(","));return { scheme: e.split(URL_SCHEME_SUFFIX)[0], path: e.split(URL_SCHEME_SUFFIX)[1] }; + }function cloneModelInternal(e, t, n) { + return void 0 === n && (n = !1), __awaiter(this, void 0, void 0, function () { + var r, o, a, i, s, u, l, c, p;return __generator(this, function (d) { + switch (d.label) {case 0: + return assert(e !== t, "Old path and new path are the same: '" + e + "'"), assert((r = IORouterRegistry.getLoadHandlers(e)).length > 0, "Copying failed because no load handler is found for source URL " + e + "."), assert(r.length < 2, "Copying failed because more than one (" + r.length + ") load handlers for source URL " + e + "."), o = r[0], assert((a = IORouterRegistry.getSaveHandlers(t)).length > 0, "Copying failed because no save handler is found for destination URL " + t + "."), assert(a.length < 2, "Copying failed because more than one (" + r.length + ") save handlers for destination URL " + t + "."), i = a[0], s = parseURL(e).scheme, u = parseURL(e).path, l = s === parseURL(e).scheme, [4, o.load()];case 1: + return c = d.sent(), n && l ? [4, ModelStoreManagerRegistry.getManager(s).removeModel(u)] : [3, 3];case 2: + d.sent(), d.label = 3;case 3: + return [4, i.save(c)];case 4: + return p = d.sent(), !n || l ? [3, 6] : [4, ModelStoreManagerRegistry.getManager(s).removeModel(u)];case 5: + d.sent(), d.label = 6;case 6: + return [2, p.modelArtifactsInfo];} + }); + }); + }function listModels() { + return __awaiter(this, void 0, void 0, function () { + var e, t, n, r, o, a, i;return __generator(this, function (s) { + switch (s.label) {case 0: + e = ModelStoreManagerRegistry.getSchemes(), t = {}, n = 0, r = e, s.label = 1;case 1: + return n < r.length ? (o = r[n], [4, ModelStoreManagerRegistry.getManager(o).listModels()]) : [3, 4];case 2: + for (i in a = s.sent()) t[o + URL_SCHEME_SUFFIX + i] = a[i];s.label = 3;case 3: + return n++, [3, 1];case 4: + return [2, t];} + }); + }); + }function removeModel(e) { + return __awaiter(this, void 0, void 0, function () { + var t;return __generator(this, function (n) { + switch (n.label) {case 0: + return t = parseURL(e), [4, ModelStoreManagerRegistry.getManager(t.scheme).removeModel(t.path)];case 1: + return [2, n.sent()];} + }); + }); + }function copyModel(e, t) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (n) { + switch (n.label) {case 0: + return [4, cloneModelInternal(e, t, !1)];case 1: + return [2, n.sent()];} + }); + }); + }function moveModel(e, t) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (n) { + switch (n.label) {case 0: + return [4, cloneModelInternal(e, t, !0)];case 1: + return [2, n.sent()];} + }); + }); + }var DATABASE_NAME = "tensorflowjs", + DATABASE_VERSION = 1, + MODEL_STORE_NAME = "models_store", + INFO_STORE_NAME = "model_info_store";function getIndexedDBFactory() { + if (!ENV.get("IS_BROWSER")) throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");var e = window, + t = e.indexedDB || e.mozIndexedDB || e.webkitIndexedDB || e.msIndexedDB || e.shimIndexedDB;if (null == t) throw new Error("The current browser does not appear to support IndexedDB.");return t; + }function setUpDatabase(e) { + var t = e.result;t.createObjectStore(MODEL_STORE_NAME, { keyPath: "modelPath" }), t.createObjectStore(INFO_STORE_NAME, { keyPath: "modelPath" }); + }var BrowserIndexedDB = function () { + function e(e) { + if (this.indexedDB = getIndexedDBFactory(), null == e || !e) throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath = e; + }return e.prototype.save = function (e) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (t) { + if (e.modelTopology instanceof ArrayBuffer) throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return [2, this.databaseAction(this.modelPath, e)]; + }); + }); + }, e.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (e) { + return [2, this.databaseAction(this.modelPath)]; + }); + }); + }, e.prototype.databaseAction = function (e, t) { + var n = this;return new Promise(function (e, r) { + var o = n.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);o.onupgradeneeded = function () { + return setUpDatabase(o); + }, o.onsuccess = function () { + var a = o.result;if (null == t) { + var i = a.transaction(MODEL_STORE_NAME, "readonly"), + s = i.objectStore(MODEL_STORE_NAME).get(n.modelPath);s.onsuccess = function () { + if (null == s.result) return a.close(), r(new Error("Cannot find model with path '" + n.modelPath + "' in IndexedDB."));e(s.result.modelArtifacts); + }, s.onerror = function (e) { + return a.close(), r(s.error); + }, i.oncomplete = function () { + return a.close(); + }; + } else { + var u, + l = getModelArtifactsInfoForJSON(t), + c = a.transaction(INFO_STORE_NAME, "readwrite"), + p = c.objectStore(INFO_STORE_NAME), + d = p.put({ modelPath: n.modelPath, modelArtifactsInfo: l });d.onsuccess = function () { + var o = (u = a.transaction(MODEL_STORE_NAME, "readwrite")).objectStore(MODEL_STORE_NAME).put({ modelPath: n.modelPath, modelArtifacts: t, modelArtifactsInfo: l });o.onsuccess = function () { + return e({ modelArtifactsInfo: l }); + }, o.onerror = function (e) { + var t = (p = c.objectStore(INFO_STORE_NAME)).delete(n.modelPath);t.onsuccess = function () { + return a.close(), r(o.error); + }, t.onerror = function (e) { + return a.close(), r(o.error); + }; + }; + }, d.onerror = function (e) { + return a.close(), r(d.error); + }, c.oncomplete = function () { + null == u ? a.close() : u.oncomplete = function () { + return a.close(); + }; + }; + } + }, o.onerror = function (e) { + return r(o.error); + }; + }); + }, e.URL_SCHEME = "indexeddb://", e; + }(), + indexedDBRouter = function (e) { + return ENV.get("IS_BROWSER") && e.startsWith(BrowserIndexedDB.URL_SCHEME) ? browserIndexedDB(e.slice(BrowserIndexedDB.URL_SCHEME.length)) : null; + };function browserIndexedDB(e) { + return new BrowserIndexedDB(e); + }function maybeStripScheme(e) { + return e.startsWith(BrowserIndexedDB.URL_SCHEME) ? e.slice(BrowserIndexedDB.URL_SCHEME.length) : e; + }IORouterRegistry.registerSaveRouter(indexedDBRouter), IORouterRegistry.registerLoadRouter(indexedDBRouter);var BrowserIndexedDBManager = function () { + function e() { + this.indexedDB = getIndexedDBFactory(); + }return e.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var e = this;return __generator(this, function (t) { + return [2, new Promise(function (t, n) { + var r = e.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);r.onupgradeneeded = function () { + return setUpDatabase(r); + }, r.onsuccess = function () { + var e = r.result, + o = e.transaction(INFO_STORE_NAME, "readonly"), + a = o.objectStore(INFO_STORE_NAME).getAll();a.onsuccess = function () { + for (var e = {}, n = 0, r = a.result; n < r.length; n++) { + var o = r[n];e[o.modelPath] = o.modelArtifactsInfo; + }t(e); + }, a.onerror = function (t) { + return e.close(), n(a.error); + }, o.oncomplete = function () { + return e.close(); + }; + }, r.onerror = function (e) { + return n(r.error); + }; + })]; + }); + }); + }, e.prototype.removeModel = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t = this;return __generator(this, function (n) { + return e = maybeStripScheme(e), [2, new Promise(function (n, r) { + var o = t.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);o.onupgradeneeded = function () { + return setUpDatabase(o); + }, o.onsuccess = function () { + var t, + a = o.result, + i = a.transaction(INFO_STORE_NAME, "readwrite"), + s = i.objectStore(INFO_STORE_NAME), + u = s.get(e);u.onsuccess = function () { + if (null == u.result) return a.close(), r(new Error("Cannot find model with path '" + e + "' in IndexedDB."));var o = s.delete(e), + i = function () { + var o = (t = a.transaction(MODEL_STORE_NAME, "readwrite")).objectStore(MODEL_STORE_NAME).delete(e);o.onsuccess = function () { + return n(u.result.modelArtifactsInfo); + }, o.onerror = function (e) { + return r(u.error); + }; + };o.onsuccess = i, o.onerror = function (e) { + return i(), a.close(), r(u.error); + }; + }, u.onerror = function (e) { + return a.close(), r(u.error); + }, i.oncomplete = function () { + null == t ? a.close() : t.oncomplete = function () { + return a.close(); + }; + }; + }, o.onerror = function (e) { + return r(o.error); + }; + })]; + }); + }); + }, e; + }();if (ENV.get("IS_BROWSER")) try { + ModelStoreManagerRegistry.registerManager(BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager()); + } catch (e) {}var PATH_SEPARATOR = "/", + PATH_PREFIX = "tensorflowjs_models", + INFO_SUFFIX = "info", + MODEL_TOPOLOGY_SUFFIX = "model_topology", + WEIGHT_SPECS_SUFFIX = "weight_specs", + WEIGHT_DATA_SUFFIX = "weight_data";function getModelKeys(e) { + return { info: [PATH_PREFIX, e, INFO_SUFFIX].join(PATH_SEPARATOR), topology: [PATH_PREFIX, e, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR), weightSpecs: [PATH_PREFIX, e, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR), weightData: [PATH_PREFIX, e, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR) }; + }function getModelPathFromKey(e) { + var t = e.split(PATH_SEPARATOR);if (t.length < 3) throw new Error("Invalid key format: " + e);return t.slice(1, t.length - 1).join(PATH_SEPARATOR); + }function maybeStripScheme$1(e) { + return e.startsWith(BrowserLocalStorage.URL_SCHEME) ? e.slice(BrowserLocalStorage.URL_SCHEME.length) : e; + }var BrowserLocalStorage = function () { + function e(e) { + if (!ENV.get("IS_BROWSER") || void 0 === window.localStorage) throw new Error("The current environment does not support local storage.");if (this.LS = window.localStorage, null == e || !e) throw new Error("For local storage, modelPath must not be null, undefined or empty.");this.modelPath = e, this.keys = getModelKeys(this.modelPath); + }return e.prototype.save = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o;return __generator(this, function (a) { + if (e.modelTopology instanceof ArrayBuffer) throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");t = JSON.stringify(e.modelTopology), n = JSON.stringify(e.weightSpecs), r = getModelArtifactsInfoForJSON(e);try { + return this.LS.setItem(this.keys.info, JSON.stringify(r)), this.LS.setItem(this.keys.topology, t), this.LS.setItem(this.keys.weightSpecs, n), this.LS.setItem(this.keys.weightData, arrayBufferToBase64String(e.weightData)), [2, { modelArtifactsInfo: r }]; + } catch (e) { + for (o in this.keys) this.LS.removeItem(this.keys[o]);throw new Error("Failed to save model '" + this.modelPath + "' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=" + r.modelTopologyBytes + ", weightSpecsBytes=" + r.weightSpecsBytes + ", weightDataBytes=" + r.weightDataBytes + "."); + }return [2]; + }); + }); + }, e.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var e, t, n, r, o;return __generator(this, function (a) { + if (null == (e = JSON.parse(this.LS.getItem(this.keys.info)))) throw new Error("In local storage, there is no model with name '" + this.modelPath + "'");if ("JSON" !== e.modelTopologyType) throw new Error("BrowserLocalStorage does not support loading non-JSON model topology yet.");if (t = {}, null == (n = JSON.parse(this.LS.getItem(this.keys.topology)))) throw new Error("In local storage, the topology of model '" + this.modelPath + "' is missing.");if (t.modelTopology = n, null == (r = JSON.parse(this.LS.getItem(this.keys.weightSpecs)))) throw new Error("In local storage, the weight specs of model '" + this.modelPath + "' are missing.");if (t.weightSpecs = r, null == (o = this.LS.getItem(this.keys.weightData))) throw new Error("In local storage, the binary weight values of model '" + this.modelPath + "' are missing.");return t.weightData = base64StringToArrayBuffer(o), [2, t]; + }); + }); + }, e.URL_SCHEME = "localstorage://", e; + }(), + localStorageRouter = function (e) { + return ENV.get("IS_BROWSER") && e.startsWith(BrowserLocalStorage.URL_SCHEME) ? browserLocalStorage(e.slice(BrowserLocalStorage.URL_SCHEME.length)) : null; + };function browserLocalStorage(e) { + return new BrowserLocalStorage(e); + }IORouterRegistry.registerSaveRouter(localStorageRouter), IORouterRegistry.registerLoadRouter(localStorageRouter);var BrowserLocalStorageManager = function () { + function e() { + assert(ENV.get("IS_BROWSER"), "Current environment is not a web browser"), assert(void 0 !== window.localStorage, "Current browser does not appear to support localStorage"), this.LS = window.localStorage; + }return e.prototype.listModels = function () { + return __awaiter(this, void 0, void 0, function () { + var e, t, n, r, o, a;return __generator(this, function (i) { + for (e = {}, t = PATH_PREFIX + PATH_SEPARATOR, n = PATH_SEPARATOR + INFO_SUFFIX, r = 0; r < this.LS.length; ++r) (o = this.LS.key(r)).startsWith(t) && o.endsWith(n) && (a = getModelPathFromKey(o), e[a] = JSON.parse(this.LS.getItem(o)));return [2, e]; + }); + }); + }, e.prototype.removeModel = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n;return __generator(this, function (r) { + if (e = maybeStripScheme$1(e), t = getModelKeys(e), null == this.LS.getItem(t.info)) throw new Error("Cannot find model at path '" + e + "'");return n = JSON.parse(this.LS.getItem(t.info)), this.LS.removeItem(t.info), this.LS.removeItem(t.topology), this.LS.removeItem(t.weightSpecs), this.LS.removeItem(t.weightData), [2, n]; + }); + }); + }, e; + }();if (ENV.get("IS_BROWSER")) try { + ModelStoreManagerRegistry.registerManager(BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager()); + } catch (e) {}var DEFAULT_FILE_NAME_PREFIX = "model", + DEFAULT_JSON_EXTENSION_NAME = ".json", + DEFAULT_WEIGHT_DATA_EXTENSION_NAME = ".weights.bin", + BrowserDownloads = function () { + function e(t) { + if (!ENV.get("IS_BROWSER")) throw new Error("triggerDownloads() cannot proceed because the current environment is not a browser.");t.startsWith(e.URL_SCHEME) && (t = t.slice(e.URL_SCHEME.length)), null != t && 0 !== t.length || (t = DEFAULT_FILE_NAME_PREFIX), this.modelTopologyFileName = t + DEFAULT_JSON_EXTENSION_NAME, this.weightDataFileName = t + DEFAULT_WEIGHT_DATA_EXTENSION_NAME; + }return e.prototype.save = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o, a, i;return __generator(this, function (s) { + if (t = window.URL.createObjectURL(new Blob([e.weightData], { type: "application/octet-stream" })), e.modelTopology instanceof ArrayBuffer) throw new Error("DownloadTrigger.save() does not support saving model topology in binary formats yet.");return n = [{ paths: ["./" + this.weightDataFileName], weights: e.weightSpecs }], r = { modelTopology: e.modelTopology, weightsManifest: n }, o = window.URL.createObjectURL(new Blob([JSON.stringify(r)], { type: "application/json" })), (a = null == this.jsonAnchor ? document.createElement("a") : this.jsonAnchor).download = this.modelTopologyFileName, a.href = o, a.click(), null != e.weightData && ((i = null == this.weightDataAnchor ? document.createElement("a") : this.weightDataAnchor).download = this.weightDataFileName, i.href = t, i.click()), [2, { modelArtifactsInfo: getModelArtifactsInfoForJSON(e) }]; + }); + }); + }, e.URL_SCHEME = "downloads://", e; + }(), + BrowserFiles = function () { + function e(e) { + if (null == e || e.length < 1) throw new Error("When calling browserFiles, at least 1 file is required, but received " + e);this.files = e; + }return e.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var e, + t, + n = this;return __generator(this, function (r) { + return e = this.files[0], t = this.files.slice(1), [2, new Promise(function (r, o) { + var a = new FileReader();a.onload = function (a) { + var i = JSON.parse(a.target.result), + s = i.modelTopology;if (null != s) { + 0 === t.length && r({ modelTopology: s });var u = i.weightsManifest;if (null != u) { + var l;try { + l = n.checkManifestAndWeightFiles(u, t); + } catch (e) { + return void o(e); + }var c = [], + p = [], + d = [];u.forEach(function (e) { + e.paths.forEach(function (e) { + p.push(e), d.push(null); + }), c.push.apply(c, e.weights); + }), u.forEach(function (e) { + e.paths.forEach(function (e) { + var t = new FileReader();t.onload = function (t) { + var n = t.target.result, + o = p.indexOf(e);d[o] = n, -1 === d.indexOf(null) && r({ modelTopology: s, weightSpecs: c, weightData: concatenateArrayBuffers(d) }); + }, t.onerror = function (t) { + o("Failed to weights data from file of path '" + e + "'."); + }, t.readAsArrayBuffer(l[e]); + }); + }); + } else o(new Error("weightManifest field is missing from file " + e.name)); + } else o(new Error("modelTopology field is missing from file " + e.name)); + }, a.onerror = function (t) { + o("Failed to read model topology and weights manifest JSON from file '" + e.name + "'. BrowserFiles supports loading Keras-style tf.Model artifacts only."); + }, a.readAsText(e); + })]; + }); + }); + }, e.prototype.checkManifestAndWeightFiles = function (e, t) { + for (var n = [], r = t.map(function (e) { + return basename(e.name); + }), o = {}, a = 0, i = e; a < i.length; a++) { + i[a].paths.forEach(function (e) { + var a = basename(e);if (-1 !== n.indexOf(a)) throw new Error("Duplicate file basename found in weights manifest: '" + a + "'");if (n.push(a), -1 === r.indexOf(a)) throw new Error("Weight file with basename '" + a + "' is not provided.");o[e] = t[r.indexOf(a)]; + }); + }if (n.length !== t.length) throw new Error("Mismatch in the number of files in weights manifest (" + n.length + ") and the number of weight files provided (" + t.length + ").");return o; + }, e; + }(), + browserDownloadsRouter = function (e) { + return ENV.get("IS_BROWSER") && e.startsWith(BrowserDownloads.URL_SCHEME) ? browserDownloads(e.slice(BrowserDownloads.URL_SCHEME.length)) : null; + };function browserDownloads(e) { + return void 0 === e && (e = "model"), new BrowserDownloads(e); + }function browserFiles(e) { + return new BrowserFiles(e); + }function loadWeightsAsArrayBuffer(e, t) { + return __awaiter(this, void 0, void 0, function () { + var n, r;return __generator(this, function (o) { + switch (o.label) {case 0: + return n = e.map(function (e) { + return fetch(e, t); + }), [4, Promise.all(n)];case 1: + return r = o.sent(), [4, Promise.all(r.map(function (e) { + return e.arrayBuffer(); + }))];case 2: + return [2, o.sent()];} + }); + }); + }function loadWeights(e, t, n, r) { + return void 0 === t && (t = ""), __awaiter(this, void 0, void 0, function () { + var o, a, i, s, u, l, c, p, d, h;return __generator(this, function (f) { + switch (f.label) {case 0: + if (o = e.map(function () { + return !1; + }), a = {}, i = null != n ? n.map(function () { + return !1; + }) : [], s = [], e.forEach(function (e, t) { + var r = 0;e.weights.forEach(function (e) { + var u = "quantization" in e ? e.quantization.dtype : e.dtype, + l = DTYPE_VALUE_SIZE_MAP[u] * sizeFromShape(e.shape), + c = function () { + o[t] = !0, null == a[t] && (a[t] = []), a[t].push({ manifestEntry: e, groupOffset: r, sizeBytes: l }); + };null != n ? n.forEach(function (t, n) { + t === e.name && (c(), i[n] = !0); + }) : c(), s.push(e.name), r += l; + }); + }), !i.every(function (e) { + return e; + })) throw u = n.filter(function (e, t) { + return !i[t]; + }), new Error("Could not find weights in manifest with names: " + u.join(", ") + ". \nManifest JSON has weights with names: " + s.join(", ") + ".");return l = o.reduce(function (e, t, n) { + return t && e.push(n), e; + }, []), c = [], l.forEach(function (n) { + e[n].paths.forEach(function (e) { + var n = t + (t.endsWith("/") ? "" : "/") + e;c.push(n); + }); + }), [4, loadWeightsAsArrayBuffer(c, r)];case 1: + return p = f.sent(), d = {}, h = 0, l.forEach(function (t) { + for (var n = e[t].paths.length, r = 0, o = 0; o < n; o++) r += p[h + o].byteLength;for (var i = new ArrayBuffer(r), s = new Uint8Array(i), u = 0, l = 0; l < n; l++) { + var c = new Uint8Array(p[h + l]);s.set(c, u), u += c.byteLength; + }a[t].forEach(function (e) { + var t, + n = i.slice(e.groupOffset, e.groupOffset + e.sizeBytes), + r = e.manifestEntry.dtype;if ("quantization" in e.manifestEntry) { + var o = e.manifestEntry.quantization;if ("uint8" !== o.dtype && "uint16" !== o.dtype) throw new Error("Weight " + e.manifestEntry.name + " has unknown quantization dtype " + o.dtype + ".");var a = "uint8" === o.dtype ? new Uint8Array(n) : new Uint16Array(n);if ("float32" === r) t = Float32Array.from(a, function (e) { + return e * o.scale + o.min; + });else { + if ("int32" !== r) throw new Error("Weight " + e.manifestEntry.name + " has a dtype not supported by quantization: " + r);t = Int32Array.from(a, function (e) { + return Math.round(e * o.scale + o.min); + }); + } + } else if ("float32" === r) t = new Float32Array(n);else if ("int32" === r) t = new Int32Array(n);else { + if ("bool" !== r) throw new Error("Weight " + e.manifestEntry.name + " has unknown dtype " + r + ".");t = new Uint8Array(n); + }var s = e.manifestEntry.name;if (null != d[s]) throw new Error("Duplicate weight with name " + s + ". Please make sure weights names are unique in the manifest JSON.");d[s] = tensor(t, e.manifestEntry.shape, e.manifestEntry.dtype); + }), h += n; + }), [2, d];} + }); + }); + }IORouterRegistry.registerSaveRouter(browserDownloadsRouter);var BrowserHTTPRequest = function () { + function e(e, t) { + if (this.DEFAULT_METHOD = "POST", "undefined" == typeof fetch) throw new Error("browserHTTPRequest is not supported outside the web browser without a fetch polyfill.");if (assert(null != e && e.length > 0, "URL path for browserHTTPRequest must not be null, undefined or empty."), this.path = e, null != t && null != t.body) throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit = t || {}; + }return e.prototype.save = function (e) { + return __awaiter(this, void 0, void 0, function () { + var t, n, r, o;return __generator(this, function (a) { + switch (a.label) {case 0: + if (e.modelTopology instanceof ArrayBuffer) throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");return (t = Object.assign({ method: this.DEFAULT_METHOD }, this.requestInit)).body = new FormData(), n = [{ paths: ["./model.weights.bin"], weights: e.weightSpecs }], r = { modelTopology: e.modelTopology, weightsManifest: n }, t.body.append("model.json", new Blob([JSON.stringify(r)], { type: "application/json" }), "model.json"), null != e.weightData && t.body.append("model.weights.bin", new Blob([e.weightData], { type: "application/octet-stream" }), "model.weights.bin"), [4, fetch(this.path, t)];case 1: + if (200 === (o = a.sent()).status) return [2, { modelArtifactsInfo: getModelArtifactsInfoForJSON(e), responses: [o] }];throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status " + o.status + ".");} + }); + }); + }, e.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var e, t, n, r, o, a, i, s, u, l, c, p;return __generator(this, function (d) { + switch (d.label) {case 0: + return [4, fetch(this.path, this.requestInit)];case 1: + return [4, d.sent().json()];case 2: + if (e = d.sent(), t = e.modelTopology, n = e.weightsManifest, null == t && null == n) throw new Error("The JSON from HTTP path " + this.path + " contains neither model topology or manifest for weights.");if (null == n) return [3, 4];for (a = e.weightsManifest, r = [], i = 0, s = a; i < s.length; i++) u = s[i], r.push.apply(r, u.weights);return (l = this.path.substring(0, this.path.lastIndexOf("/"))).endsWith("/") || (l += "/"), c = [], a.forEach(function (e) { + e.paths.forEach(function (e) { + c.push(l + e); + }); + }), p = concatenateArrayBuffers, [4, loadWeightsAsArrayBuffer(c, this.requestInit)];case 3: + o = p.apply(void 0, [d.sent()]), d.label = 4;case 4: + return [2, { modelTopology: t, weightSpecs: r, weightData: o }];} + }); + }); + }, e.URL_SCHEMES = ["http://", "https://"], e; + }(), + httpRequestRouter = function (e) { + if ("undefined" == typeof fetch) return null;for (var t = 0, n = BrowserHTTPRequest.URL_SCHEMES; t < n.length; t++) { + var r = n[t];if (e.startsWith(r)) return browserHTTPRequest(e); + }return null; + };function browserHTTPRequest(e, t) { + return new BrowserHTTPRequest(e, t); + }IORouterRegistry.registerSaveRouter(httpRequestRouter), IORouterRegistry.registerLoadRouter(httpRequestRouter);var PassthroughLoader = function () { + function e(e, t, n) { + this.modelTopology = e, this.weightSpecs = t, this.weightData = n; + }return e.prototype.load = function () { + return __awaiter(this, void 0, void 0, function () { + var e;return __generator(this, function (t) { + return e = {}, null != this.modelTopology && (e = __assign({ modelTopology: this.modelTopology }, e)), null != this.weightSpecs && this.weightSpecs.length > 0 && (e = __assign({ weightSpecs: this.weightSpecs }, e)), null != this.weightData && this.weightData.byteLength > 0 && (e = __assign({ weightData: this.weightData }, e)), [2, e]; + }); + }); + }, e; + }(), + PassthroughSaver = function () { + function e(e) { + this.saveHandler = e; + }return e.prototype.save = function (e) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (t) { + return [2, this.saveHandler(e)]; + }); + }); + }, e; + }();function fromMemory(e, t, n) { + return new PassthroughLoader(e, t, n); + }function withSaveHandler(e) { + return new PassthroughSaver(e); + }var registerSaveRouter = IORouterRegistry.registerSaveRouter, + registerLoadRouter = IORouterRegistry.registerLoadRouter, + getSaveHandlers = IORouterRegistry.getSaveHandlers, + getLoadHandlers = IORouterRegistry.getLoadHandlers, + io = Object.freeze({ browserFiles: browserFiles, browserHTTPRequest: browserHTTPRequest, concatenateArrayBuffers: concatenateArrayBuffers, decodeWeights: decodeWeights, encodeWeights: encodeWeights, fromMemory: fromMemory, getLoadHandlers: getLoadHandlers, getModelArtifactsInfoForJSON: getModelArtifactsInfoForJSON, getSaveHandlers: getSaveHandlers, loadWeights: loadWeights, registerLoadRouter: registerLoadRouter, registerSaveRouter: registerSaveRouter, withSaveHandler: withSaveHandler, copyModel: copyModel, listModels: listModels, moveModel: moveModel, removeModel: removeModel }), + Serializable = function () { + function e() {}return e.prototype.getClassName = function () { + return this.constructor.className; + }, e.fromConfig = function (e, t) { + return new e(t); + }, e; + }(), + SerializationMap = function () { + function e() { + this.classNameMap = {}; + }return e.getMap = function () { + return null == e.instance && (e.instance = new e()), e.instance; + }, e.register = function (t) { + e.getMap().classNameMap[t.className] = [t, t.fromConfig]; + }, e; + }(), + serialization = Object.freeze({ Serializable: Serializable, SerializationMap: SerializationMap }), + WEBGL_ENVS = { HAS_WEBGL: !0 }, + NODE_ENVS = { IS_NODE: !0 }, + CHROME_ENVS = { IS_CHROME: !0 }, + BROWSER_ENVS = { IS_BROWSER: !0 }, + CPU_ENVS = { HAS_WEBGL: !1 }, + ALL_ENVS = {};function expectArraysClose(e, t, n) { + if (null == n && (n = ENV.get("TEST_EPSILON")), e instanceof Tensor || t instanceof Tensor) { + if (e instanceof Tensor && t instanceof Tensor) { + if (e.dtype !== t.dtype) throw new Error("Arrays are of different type actual: " + e.dtype + " vs expected: " + t.dtype + ".");if (!arraysEqual(e.shape, t.shape)) throw new Error("Arrays are of different shape actual: " + e.shape + " vs expected: " + t.shape + "."); + } + } else { + var r = e.constructor.name, + o = t.constructor.name;if (r !== o) throw new Error("Arrays are of different type actual: " + r + " vs expected: " + o); + }var a, i;if (a = e instanceof Tensor ? e.dataSync() : e, i = t instanceof Tensor ? t.dataSync() : t, a.length !== i.length) throw new Error("Arrays have different lengths actual: " + a.length + " vs expected: " + i.length + ".\nActual: " + a + ".\nExpected: " + i + ".");for (var s = 0; s < i.length; ++s) { + var u = a[s], + l = i[s];if (!areClose(u, Number(l), n)) throw new Error("Arrays differ: actual[" + s + "] = " + u + ", expected[" + s + "] = " + l + ".\nActual: " + a + ".\nExpected: " + i + "."); + } + }function expectPromiseToFail(e, t) { + e().then(function () { + return t.fail(); + }, function () { + return t(); + }); + }function expectArraysEqual(e, t) { + return expectArraysClose(e, t, 0); + }function expectNumbersClose(e, t, n) { + if (null == n && (n = ENV.get("TEST_EPSILON")), !areClose(e, t, n)) throw new Error("Numbers differ: actual === " + e + ", expected === " + t); + }function areClose(e, t, n) { + return !(!isNaN(e) || !isNaN(t)) || !(isNaN(e) || isNaN(t) || Math.abs(e - t) > n); + }function expectValuesInRange(e, t, n) { + var r;r = e instanceof Tensor ? e.dataSync() : e;for (var o = 0; o < r.length; o++) if (r[o] < t || r[o] > n) throw new Error("Value out of range:" + r[o] + " low: " + t + ", high: " + n); + }function expectArrayBuffersEqual(e, t) { + expect(new Float32Array(e)).toEqual(new Float32Array(t)); + }var test_util = Object.freeze({ WEBGL_ENVS: WEBGL_ENVS, NODE_ENVS: NODE_ENVS, CHROME_ENVS: CHROME_ENVS, BROWSER_ENVS: BROWSER_ENVS, CPU_ENVS: CPU_ENVS, ALL_ENVS: ALL_ENVS, expectArraysClose: expectArraysClose, expectPromiseToFail: expectPromiseToFail, expectArraysEqual: expectArraysEqual, expectNumbersClose: expectNumbersClose, expectValuesInRange: expectValuesInRange, expectArrayBuffersEqual: expectArrayBuffersEqual }), + version = "0.12.8", + webgl = Object.freeze({ gpgpu_util: gpgpu_util, webgl_util: webgl_util, MathBackendWebGL: MathBackendWebGL, GPGPUContext: GPGPUContext }), + Optimizer = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends(t, e), t.prototype.minimize = function (e, t, n) { + void 0 === t && (t = !1);var r = this.computeGradients(e, n), + o = r.value, + a = r.grads;return this.applyGradients(a), Object.keys(a).forEach(function (e) { + return a[e].dispose(); + }), t ? o : (o.dispose(), null); + }, t.prototype.computeGradients = function (e, t) { + return variableGrads(e, t); + }, t; + }(Serializable), + DEFAULT_FLOAT32_EPSILON = 1e-8, + DEFAULT_FLOAT16_EPSILON = 1e-4;function getOptimizerDefaultEpsilonValue() { + return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED") ? DEFAULT_FLOAT32_EPSILON : DEFAULT_FLOAT16_EPSILON; + }var AdadeltaOptimizer = function (e) { + function t(t, n, r) { + void 0 === r && (r = null);var o = e.call(this) || this;return o.learningRate = t, o.rho = n, o.epsilon = r, o.accumulatedGrads = {}, o.accumulatedUpdates = {}, o.c = keep(scalar(-t)), o.rhoScalar = keep(scalar(n)), o.oneMinusRho = keep(scalar(1 - n)), null === r && (r = getOptimizerDefaultEpsilonValue()), o.epsilonScalar = keep(scalar(r)), o; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this, + n = function (n) { + var o = ENV.engine.registeredVariables[n];if (null == r.accumulatedGrads[n]) { + tidy(function () { + t.accumulatedGrads[n] = zerosLike(o).variable(!1); + }); + }if (null == r.accumulatedUpdates[n]) { + tidy(function () { + t.accumulatedUpdates[n] = zerosLike(o).variable(!1); + }); + }var a = e[n], + i = r.accumulatedGrads[n], + s = r.accumulatedUpdates[n];tidy(function () { + var e = t.rhoScalar.mul(i).add(t.oneMinusRho.mul(a.square())), + r = s.add(t.epsilonScalar).sqrt().div(i.add(t.epsilonScalar).sqrt()).mul(a), + u = t.rhoScalar.mul(s).add(t.oneMinusRho.mul(r.square()));t.accumulatedGrads[n].assign(e), t.accumulatedUpdates[n].assign(u);var l = t.c.mul(r).add(o);o.assign(l); + }); + }, + r = this;for (var o in e) n(o); + }, t.prototype.dispose = function () { + var e = this;this.c.dispose(), this.epsilonScalar.dispose(), this.rhoScalar.dispose(), this.oneMinusRho.dispose(), null != this.accumulatedUpdates && (Object.keys(this.accumulatedUpdates).forEach(function (t) { + return e.accumulatedUpdates[t].dispose(); + }), Object.keys(this.accumulatedGrads).forEach(function (t) { + return e.accumulatedGrads[t].dispose(); + })); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, rho: this.rho, epsilon: this.epsilon }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.rho, t.epsilon); + }, t.className = "AdadeltaOptimizer", t; + }(Optimizer);SerializationMap.register(AdadeltaOptimizer);var AdagradOptimizer = function (e) { + function t(t, n) { + void 0 === n && (n = .1);var r = e.call(this) || this;r.learningRate = t, r.initialAccumulatorValue = n, r.accumulatedGrads = {}, r.c = keep(scalar(-t));var o = getOptimizerDefaultEpsilonValue();return r.epsilon = keep(scalar(o)), r; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this, + n = function (n) { + var o = ENV.engine.registeredVariables[n];if (null == r.accumulatedGrads[n]) { + tidy(function () { + t.accumulatedGrads[n] = fill(o.shape, t.initialAccumulatorValue).variable(!1); + }); + }var a = e[n], + i = r.accumulatedGrads[n];tidy(function () { + var e = i.add(a.square());t.accumulatedGrads[n].assign(e);var r = t.c.mul(a.div(e.add(t.epsilon).sqrt())).add(o);o.assign(r); + }); + }, + r = this;for (var o in e) n(o); + }, t.prototype.dispose = function () { + var e = this;this.epsilon.dispose(), this.c.dispose(), null != this.accumulatedGrads && Object.keys(this.accumulatedGrads).forEach(function (t) { + return e.accumulatedGrads[t].dispose(); + }); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, initialAccumulatorValue: this.initialAccumulatorValue }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.initialAccumulatorValue); + }, t.className = "AdagradOptimizer", t; + }(Optimizer);SerializationMap.register(AdagradOptimizer);var AdamOptimizer = function (e) { + function t(t, n, r, o) { + void 0 === o && (o = null);var a = e.call(this) || this;return a.learningRate = t, a.beta1 = n, a.beta2 = r, a.epsilon = o, a.accumulatedFirstMoment = {}, a.accumulatedSecondMoment = {}, a.c = keep(scalar(-t)), a.beta1Scalar = keep(scalar(n)), a.beta2Scalar = keep(scalar(r)), tidy(function () { + a.accBeta1 = scalar(n).variable(), a.accBeta2 = scalar(r).variable(); + }), a.oneMinusBeta1 = keep(scalar(1 - n)), a.oneMinusBeta2 = keep(scalar(1 - r)), a.one = keep(scalar(1)), null === o && (o = getOptimizerDefaultEpsilonValue()), a.epsScalar = keep(scalar(o)), a; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this;tidy(function () { + var n = t.one.sub(t.accBeta1), + r = t.one.sub(t.accBeta2);for (var o in e) { + var a = ENV.engine.registeredVariables[o];if (null == t.accumulatedFirstMoment[o]) { + var i = !1;t.accumulatedFirstMoment[o] = zerosLike(a).variable(i); + }if (null == t.accumulatedSecondMoment[o]) { + i = !1;t.accumulatedSecondMoment[o] = zerosLike(a).variable(i); + }var s = e[o], + u = t.accumulatedFirstMoment[o], + l = t.accumulatedSecondMoment[o], + c = t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)), + p = t.beta2Scalar.mul(l).add(t.oneMinusBeta2.mul(s.square())), + d = c.div(n), + h = p.div(r);t.accumulatedFirstMoment[o].assign(c), t.accumulatedSecondMoment[o].assign(p);var f = t.c.mul(d.div(t.epsScalar.add(h.sqrt()))).add(a);a.assign(f); + }t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)), t.accBeta2.assign(t.accBeta2.mul(t.beta2Scalar)); + }); + }, t.prototype.dispose = function () { + var e = this;this.c.dispose(), this.epsScalar.dispose(), this.beta1Scalar.dispose(), this.beta2Scalar.dispose(), this.accBeta1.dispose(), this.accBeta2.dispose(), this.oneMinusBeta1.dispose(), this.oneMinusBeta2.dispose(), this.one.dispose(), null != this.accumulatedFirstMoment && Object.keys(this.accumulatedFirstMoment).forEach(function (t) { + return e.accumulatedFirstMoment[t].dispose(); + }), null != this.accumulatedSecondMoment && Object.keys(this.accumulatedSecondMoment).forEach(function (t) { + return e.accumulatedSecondMoment[t].dispose(); + }); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, beta1: this.beta1, beta2: this.beta2, epsilon: this.epsilon }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.beta1, t.beta2, t.epsilon); + }, t.className = "AdamOptimizer", t; + }(Optimizer);SerializationMap.register(AdamOptimizer);var AdamaxOptimizer = function (e) { + function t(t, n, r, o, a) { + void 0 === o && (o = null), void 0 === a && (a = 0);var i = e.call(this) || this;return i.learningRate = t, i.beta1 = n, i.beta2 = r, i.epsilon = o, i.decay = a, i.accumulatedFirstMoment = {}, i.accumulatedWeightedInfNorm = {}, i.c = keep(scalar(-t)), i.beta1Scalar = keep(scalar(n)), i.beta2Scalar = keep(scalar(r)), i.decayScalar = keep(scalar(a)), tidy(function () { + i.iteration = scalar(0).variable(), i.accBeta1 = scalar(n).variable(); + }), i.oneMinusBeta1 = keep(scalar(1 - n)), i.one = keep(scalar(1)), null === o && (o = getOptimizerDefaultEpsilonValue()), i.epsScalar = keep(scalar(o)), i; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this;tidy(function () { + var n = t.one.sub(t.accBeta1), + r = t.c.div(t.one.add(t.decayScalar.mul(t.iteration)));for (var o in e) { + var a = ENV.engine.registeredVariables[o];if (null == t.accumulatedFirstMoment[o]) { + var i = !1;t.accumulatedFirstMoment[o] = zerosLike(a).variable(i); + }if (null == t.accumulatedWeightedInfNorm[o]) { + i = !1;t.accumulatedWeightedInfNorm[o] = zerosLike(a).variable(i); + }var s = e[o], + u = t.accumulatedFirstMoment[o], + l = t.accumulatedWeightedInfNorm[o], + c = t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)), + p = t.beta2Scalar.mul(l), + d = s.abs(), + h = p.maximum(d);t.accumulatedFirstMoment[o].assign(c), t.accumulatedWeightedInfNorm[o].assign(h);var f = r.div(n).mul(c.div(t.epsScalar.add(h))).add(a);a.assign(f); + }t.iteration.assign(t.iteration.add(t.one)), t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)); + }); + }, t.prototype.dispose = function () { + var e = this;this.c.dispose(), this.epsScalar.dispose(), this.accBeta1.dispose(), this.beta1Scalar.dispose(), this.beta2Scalar.dispose(), this.oneMinusBeta1.dispose(), this.decayScalar.dispose(), this.iteration.dispose(), this.one.dispose(), null != this.accumulatedFirstMoment && Object.keys(this.accumulatedFirstMoment).forEach(function (t) { + return e.accumulatedFirstMoment[t].dispose(); + }), null != this.accumulatedWeightedInfNorm && Object.keys(this.accumulatedWeightedInfNorm).forEach(function (t) { + return e.accumulatedWeightedInfNorm[t].dispose(); + }); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, beta1: this.beta1, beta2: this.beta2, epsilon: this.epsilon, decay: this.decay }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.beta1, t.beta2, t.epsilon, t.decay); + }, t.className = "AdamaxOptimizer", t; + }(Optimizer);SerializationMap.register(AdamaxOptimizer);var SGDOptimizer = function (e) { + function t(t) { + var n = e.call(this) || this;return n.learningRate = t, n.setLearningRate(t), n; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this;Object.keys(e).forEach(function (n) { + var r = e[n], + o = ENV.engine.registeredVariables[n];tidy(function () { + var e = t.c.mul(r).add(o);o.assign(e); + }); + }); + }, t.prototype.setLearningRate = function (e) { + this.learningRate = e, null != this.c && this.c.dispose(), this.c = keep(scalar(-e)); + }, t.prototype.dispose = function () { + this.c.dispose(); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate); + }, t.className = "SGDOptimizer", t; + }(Optimizer);SerializationMap.register(SGDOptimizer);var MomentumOptimizer = function (e) { + function t(t, n, r) { + void 0 === r && (r = !1);var o = e.call(this, t) || this;return o.learningRate = t, o.momentum = n, o.useNesterov = r, o.m = scalar(o.momentum), o.accumulations = {}, o; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this, + n = function (n) { + var o = ENV.engine.registeredVariables[n];if (null == r.accumulations[n]) { + tidy(function () { + t.accumulations[n] = zerosLike(o).variable(!1); + }); + }var a = r.accumulations[n], + i = e[n];tidy(function () { + var e, + r = t.m.mul(a).add(i);e = t.useNesterov ? t.c.mul(i.add(r.mul(t.m))).add(o) : t.c.mul(r).add(o), t.accumulations[n].assign(r), o.assign(e); + }); + }, + r = this;for (var o in e) n(o); + }, t.prototype.dispose = function () { + if (e.prototype.dispose.call(this), this.m.dispose(), null != this.accumulations) for (var t in this.accumulations) this.accumulations[t].dispose(); + }, t.prototype.setMomentum = function (e) { + this.momentum = e; + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, momentum: this.momentum, useNesterov: this.useNesterov }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.momentum, t.useNesterov); + }, t.className = "MomentumOptimizer", t; + }(SGDOptimizer);SerializationMap.register(MomentumOptimizer);var RMSPropOptimizer = function (e) { + function t(t, n, r, o, a) { + void 0 === n && (n = .9), void 0 === r && (r = 0), void 0 === o && (o = null), void 0 === a && (a = !1);var i = e.call(this) || this;return i.learningRate = t, i.decay = n, i.momentum = r, i.epsilon = o, i.accumulatedMeanSquares = {}, i.accumulatedMeanGrads = {}, i.accumulatedMoments = {}, i.c = keep(scalar(t)), i.decayScalar = keep(scalar(n)), i.momentumScalar = keep(scalar(r)), i.oneMinusDecay = keep(scalar(1 - n)), i.centered = a, null === o && (o = getOptimizerDefaultEpsilonValue()), i.epsilonScalar = keep(scalar(o)), i; + }return __extends(t, e), t.prototype.applyGradients = function (e) { + var t = this, + n = function (n) { + var o = ENV.engine.registeredVariables[n];if (null == r.accumulatedMeanSquares[n]) { + tidy(function () { + t.accumulatedMeanSquares[n] = zerosLike(o).variable(!1); + }); + }if (null == r.accumulatedMeanGrads[n] && r.centered) { + tidy(function () { + t.accumulatedMeanGrads[n] = zerosLike(o).variable(!1); + }); + }if (null == r.accumulatedMoments[n]) { + tidy(function () { + t.accumulatedMoments[n] = zerosLike(o).variable(!1); + }); + }var a = r.accumulatedMeanSquares[n], + i = r.accumulatedMeanGrads[n], + s = r.accumulatedMoments[n], + u = e[n];tidy(function () { + var e = t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));if (t.centered) { + var r = t.decayScalar.mul(i).add(t.oneMinusDecay.mul(u)), + l = t.momentumScalar.mul(s).add(t.c.mul(u).div(e.sub(r.square().add(t.epsilonScalar)).sqrt()));t.accumulatedMeanSquares[n].assign(e), t.accumulatedMeanGrads[n].assign(r), t.accumulatedMoments[n].assign(l);var c = o.sub(l);o.assign(c); + } else { + var p = t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));l = t.momentumScalar.mul(s).add(t.c.mul(u).div(p.add(t.epsilonScalar).sqrt()));t.accumulatedMeanSquares[n].assign(p), t.accumulatedMoments[n].assign(l);c = o.sub(l);o.assign(c); + } + }); + }, + r = this;for (var o in e) n(o); + }, t.prototype.dispose = function () { + var e = this;this.c.dispose(), this.epsilonScalar.dispose(), this.decayScalar.dispose(), this.momentumScalar.dispose(), this.oneMinusDecay.dispose(), null != this.accumulatedMeanSquares && Object.keys(this.accumulatedMeanSquares).forEach(function (t) { + return e.accumulatedMeanSquares[t].dispose(); + }), null != this.accumulatedMeanGrads && this.centered && Object.keys(this.accumulatedMeanGrads).forEach(function (t) { + return e.accumulatedMeanGrads[t].dispose(); + }), null != this.accumulatedMoments && Object.keys(this.accumulatedMoments).forEach(function (t) { + return e.accumulatedMoments[t].dispose(); + }); + }, t.prototype.getConfig = function () { + return { learningRate: this.learningRate, decay: this.decay, momentum: this.momentum, epsilon: this.epsilon, centered: this.centered }; + }, t.fromConfig = function (e, t) { + return new e(t.learningRate, t.decay, t.momentum, t.epsilon, t.centered); + }, t.className = "RMSPropOptimizer", t; + }(Optimizer);SerializationMap.register(RMSPropOptimizer);var OptimizerConstructors = function () { + function e() {}return e.sgd = function (e) { + return new SGDOptimizer(e); + }, e.momentum = function (e, t, n) { + return void 0 === n && (n = !1), new MomentumOptimizer(e, t, n); + }, e.rmsprop = function (e, t, n, r, o) { + return void 0 === t && (t = .9), void 0 === n && (n = 0), void 0 === r && (r = null), void 0 === o && (o = !1), new RMSPropOptimizer(e, t, n, r, o); + }, e.adam = function (e, t, n, r) { + return void 0 === e && (e = .001), void 0 === t && (t = .9), void 0 === n && (n = .999), void 0 === r && (r = null), new AdamOptimizer(e, t, n, r); + }, e.adadelta = function (e, t, n) { + return void 0 === e && (e = .001), void 0 === t && (t = .95), void 0 === n && (n = null), new AdadeltaOptimizer(e, t, n); + }, e.adamax = function (e, t, n, r, o) { + return void 0 === e && (e = .002), void 0 === t && (t = .9), void 0 === n && (n = .999), void 0 === r && (r = null), void 0 === o && (o = 0), new AdamaxOptimizer(e, t, n, r, o); + }, e.adagrad = function (e, t) { + return void 0 === t && (t = .1), new AdagradOptimizer(e, t); + }, e; + }(), + train = { sgd: OptimizerConstructors.sgd, momentum: OptimizerConstructors.momentum, adadelta: OptimizerConstructors.adadelta, adagrad: OptimizerConstructors.adagrad, rmsprop: OptimizerConstructors.rmsprop, adamax: OptimizerConstructors.adamax, adam: OptimizerConstructors.adam }, + setBackend = Environment.setBackend, + getBackend = Environment.getBackend, + disposeVariables = Environment.disposeVariables, + memory = Environment.memory;setOpHandler(ops); + + /** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ + var extendStatics$1 = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function (e, t) { + e.__proto__ = t; + } || function (e, t) { + for (var n in t) t.hasOwnProperty(n) && (e[n] = t[n]); + };function __extends$1(e, t) { + function n() { + this.constructor = e; + }extendStatics$1(e, t), e.prototype = null === t ? Object.create(t) : (n.prototype = t.prototype, new n()); + }var __assign$1 = Object.assign || function (e) { + for (var t, n = 1, r = arguments.length; n < r; n++) for (var i in t = arguments[n]) Object.prototype.hasOwnProperty.call(t, i) && (e[i] = t[i]);return e; + };function __awaiter$1(e, t, n, r) { + return new (n || (n = Promise))(function (i, a) { + function o(e) { + try { + l(r.next(e)); + } catch (e) { + a(e); + } + }function s(e) { + try { + l(r.throw(e)); + } catch (e) { + a(e); + } + }function l(e) { + e.done ? i(e.value) : new n(function (t) { + t(e.value); + }).then(o, s); + }l((r = r.apply(e, t || [])).next()); + }); + }function __generator$1(e, t) { + var n, + r, + i, + a, + o = { label: 0, sent: function () { + if (1 & i[0]) throw i[1];return i[1]; + }, trys: [], ops: [] };return a = { next: s(0), throw: s(1), return: s(2) }, "function" == typeof Symbol && (a[Symbol.iterator] = function () { + return this; + }), a;function s(a) { + return function (s) { + return function (a) { + if (n) throw new TypeError("Generator is already executing.");for (; o;) try { + if (n = 1, r && (i = r[2 & a[0] ? "return" : a[0] ? "throw" : "next"]) && !(i = i.call(r, a[1])).done) return i;switch (r = 0, i && (a = [0, i.value]), a[0]) {case 0:case 1: + i = a;break;case 4: + return o.label++, { value: a[1], done: !1 };case 5: + o.label++, r = a[1], a = [0];continue;case 7: + a = o.ops.pop(), o.trys.pop();continue;default: + if (!(i = (i = o.trys).length > 0 && i[i.length - 1]) && (6 === a[0] || 2 === a[0])) { + o = 0;continue; + }if (3 === a[0] && (!i || a[1] > i[0] && a[1] < i[3])) { + o.label = a[1];break; + }if (6 === a[0] && o.label < i[1]) { + o.label = i[1], i = a;break; + }if (i && o.label < i[2]) { + o.label = i[2], o.ops.push(a);break; + }i[2] && o.ops.pop(), o.trys.pop();continue;}a = t.call(e, o); + } catch (e) { + a = [6, e], r = 0; + } finally { + n = i = 0; + }if (5 & a[0]) throw a[1];return { value: a[0] ? a[1] : void 0, done: !0 }; + }([a, s]); + }; + } + }var _epsilon = 1e-7;function epsilon() { + return _epsilon; + }function imageDataFormat() { + return "channelsLast"; + }var _nextUniqueTensorId = 0;function getNextUniqueTensorId() { + return _nextUniqueTensorId++; + }var _uidPrefixes = {};function getUid(e) { + return void 0 === e && (e = ""), e in _uidPrefixes || (_uidPrefixes[e] = 0), _uidPrefixes[e] += 1, e + _uidPrefixes[e].toString(); + }var scalarCache = { float32: {}, int32: {} }, + DEFAULT_DTYPE = "float32";function getScalar(e, t) { + return void 0 === t && (t = DEFAULT_DTYPE), null == scalarCache[t][e] && (scalarCache[t][e] = scalar(e, t), keep(scalarCache[t][e])), scalarCache[t][e]; + }var AttributeError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error), + RuntimeError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error), + ValueError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error), + NotImplementedError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error), + AssertionError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error), + IndexError = function (e) { + function t(n) { + var r = e.call(this, n) || this;return Object.setPrototypeOf(r, t.prototype), r; + }return __extends$1(t, e), t; + }(Error);function pyListRepeat(e, t) { + if (Array.isArray(e)) { + for (var n = [], r = 0; r < t; r++) n = n.concat(e);return n; + }return (n = new Array(t)).fill(e), n; + }function assert$1(e, t) { + if (!e) throw new AssertionError(t); + }function count(e, t) { + for (var n = 0, r = 0, i = e; r < i.length; r++) { + i[r] === t && n++; + }return n; + }function singletonOrArray(e) { + return 1 === e.length ? e[0] : e; + }function toList(e) { + return Array.isArray(e) ? e : [e]; + }function toSnakeCase(e) { + var t = e.replace(/(.)([A-Z][a-z0-9]+)/g, "$1_$2").replace(/([a-z])([A-Z])/g, "$1_$2").toLowerCase();return "_" !== t[0] ? t : "private" + t; + }function toCamelCase(e) { + return e.length <= 1 ? e : -1 === e.indexOf("_") ? e : e.replace(/[_]+(\w|$)/g, function (e, t) { + return t.toUpperCase(); + }); + }var _GLOBAL_CUSTOM_OBJECTS = {};function serializeKerasObject(e) { + return null === e || void 0 === e ? null : { className: e.getClassName(), config: e.getConfig() }; + }function deserializeKerasObject(e, t, n, r) { + if (void 0 === t && (t = {}), void 0 === n && (n = {}), void 0 === r && (r = "object"), "string" == typeof e) { + var i = e, + a = void 0;if (i in n) a = n[i];else if (i in _GLOBAL_CUSTOM_OBJECTS) a = _GLOBAL_CUSTOM_OBJECTS[i];else if (null == (a = t[i])) throw new ValueError("Unknown " + r + ": " + e);return a; + }var o = e;if (null == o.className || null == o.config) throw new ValueError(r + ": Improper config format: " + JSON.stringify(o) + ".\n'className' and 'config' must set.");var s = o.className, + l = void 0, + u = void 0;if (s in n ? (l = (S = n.get(s))[0], u = S[1]) : s in _GLOBAL_CUSTOM_OBJECTS ? (l = (A = _GLOBAL_CUSTOM_OBJECTS.className)[0], u = A[1]) : s in t && (l = (I = t[s])[0], u = I[1]), null == l) throw new ValueError("Unknown " + r + ": " + s);if (null != u) { + for (var c = {}, p = 0, h = Object.keys(_GLOBAL_CUSTOM_OBJECTS); p < h.length; p++) { + c[v = h[p]] = _GLOBAL_CUSTOM_OBJECTS[v]; + }for (var d = 0, g = Object.keys(n); d < g.length; d++) { + c[v = g[d]] = n[v]; + }o.config.customObjects = c;for (var f = __assign$1({}, _GLOBAL_CUSTOM_OBJECTS), m = 0, y = Object.keys(n); m < y.length; m++) { + var v = y[m];_GLOBAL_CUSTOM_OBJECTS[v] = n[v]; + }var b = u(l, o.config);return _GLOBAL_CUSTOM_OBJECTS = __assign$1({}, f), b; + }f = __assign$1({}, _GLOBAL_CUSTOM_OBJECTS);for (var z = 0, w = Object.keys(n); z < w.length; z++) { + v = w[z];_GLOBAL_CUSTOM_OBJECTS[v] = n[v]; + }var S, A, I;b = new l(o.config);return _GLOBAL_CUSTOM_OBJECTS = __assign$1({}, f), b; + }function numberCompare(e, t) { + return e < t ? -1 : e > t ? 1 : 0; + }function reverseNumberCompare(e, t) { + return -1 * numberCompare(e, t); + }function stringToDType(e) { + switch (e) {case "float32": + return "float32";default: + throw new ValueError("Invalid dtype: " + e);} + }function unique(e) { + if (null == e) return e;for (var t = [], n = 0, r = e; n < r.length; n++) { + var i = r[n];-1 === t.indexOf(i) && t.push(i); + }return t; + }function isObjectEmpty(e) { + if (null == e) throw new ValueError("Invalid value in obj: " + JSON.stringify(e));for (var t in e) if (e.hasOwnProperty(t)) return !1;return !0; + }function checkStringTypeUnionValue(e, t, n) { + if (null != n && e.indexOf(n) < 0) throw new ValueError(n + " is not a valid " + t + ". Valid values are " + e + " or null/undefined."); + }function checkArrayTypeAndLength(e, t, n, r) { + return void 0 === n && (n = 0), void 0 === r && (r = 1 / 0), assert$1(n >= 0), assert$1(r >= n), Array.isArray(e) && e.length >= n && e.length <= r && e.every(function (e) { + return typeof e === t; + }); + }function calcL2Norms(e, t) { + return tidy(function () { + return sqrt(sum(mulStrict(e, e), t, !0)); + }); + }var Constraint = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.getConfig = function () { + return {}; + }, t; + }(serialization.Serializable), + MaxNorm = function (e) { + function t(t) { + var n = e.call(this) || this;return n.defaultMaxValue = 2, n.defaultAxis = 0, n.maxValue = null != t.maxValue ? t.maxValue : n.defaultMaxValue, n.axis = null != t.axis ? t.axis : n.defaultAxis, n; + }return __extends$1(t, e), t.prototype.apply = function (e) { + var t = this;return tidy(function () { + var n = calcL2Norms(e, t.axis), + r = clipByValue(n, 0, t.maxValue);return mul(e, div(r, add(getScalar(epsilon()), n))); + }); + }, t.prototype.getConfig = function () { + return { maxValue: this.maxValue, axis: this.axis }; + }, t.className = "MaxNorm", t; + }(Constraint);serialization.SerializationMap.register(MaxNorm);var UnitNorm = function (e) { + function t(t) { + var n = e.call(this) || this;return n.defaultAxis = 0, n.axis = null != t.axis ? t.axis : n.defaultAxis, n; + }return __extends$1(t, e), t.prototype.apply = function (e) { + var t = this;return tidy(function () { + return div(e, add(getScalar(epsilon()), calcL2Norms(e, t.axis))); + }); + }, t.prototype.getConfig = function () { + return { axis: this.axis }; + }, t.className = "UnitNorm", t; + }(Constraint);serialization.SerializationMap.register(UnitNorm);var NonNeg = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return relu(e); + }, t.className = "NonNeg", t; + }(Constraint);serialization.SerializationMap.register(NonNeg);var MinMaxNorm = function (e) { + function t(t) { + var n = e.call(this) || this;return n.defaultMinValue = 0, n.defaultMaxValue = 1, n.defaultRate = 1, n.defaultAxis = 0, n.minValue = null != t.minValue ? t.minValue : n.defaultMinValue, n.maxValue = null != t.maxValue ? t.maxValue : n.defaultMaxValue, n.rate = null != t.rate ? t.rate : n.defaultRate, n.axis = null != t.axis ? t.axis : n.defaultAxis, n; + }return __extends$1(t, e), t.prototype.apply = function (e) { + var t = this;return tidy(function () { + var n = calcL2Norms(e, t.axis), + r = add(mul(getScalar(t.rate), clipByValue(n, t.minValue, t.maxValue)), mul(getScalar(1 - t.rate), n));return mul(e, div(r, add(getScalar(epsilon()), n))); + }); + }, t.prototype.getConfig = function () { + return { minValue: this.minValue, maxValue: this.maxValue, rate: this.rate, axis: this.axis }; + }, t.className = "MinMaxNorm", t; + }(Constraint);serialization.SerializationMap.register(MinMaxNorm);var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP = { maxNorm: "MaxNorm", minMaxNorm: "MinMaxNorm", nonNeg: "NonNeg", unitNorm: "UnitNorm" };function serializeConstraint(e) { + return serializeKerasObject(e); + }function deserializeConstraint(e, t) { + return void 0 === t && (t = {}), deserializeKerasObject(e, serialization.SerializationMap.getMap().classNameMap, t, "constraint"); + }function getConstraint(e) { + return null == e ? null : "string" == typeof e ? deserializeConstraint({ className: e in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP ? CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[e] : e, config: {} }) : e instanceof Constraint ? e : deserializeConstraint(e); + }function maxNorm(e) { + return new MaxNorm(e); + }function unitNorm(e) { + return new UnitNorm(e); + }function nonNeg() { + return new NonNeg(); + }function minMaxNorm(e) { + return new MinMaxNorm(e); + }var exports_constraints = Object.freeze({ maxNorm: maxNorm, unitNorm: unitNorm, nonNeg: nonNeg, minMaxNorm: minMaxNorm }), + nameMap = new Map(), + VALID_DATA_FORMAT_VALUES = ["channelsFirst", "channelsLast"];function checkDataFormat(e) { + checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES, "DataFormat", e); + }var VALID_PADDING_MODE_VALUES = ["valid", "same", "causal"];function checkPaddingMode(e) { + checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES, "PaddingMode", e); + }var VALID_POOL_MODE_VALUES = ["max", "avg"];function checkPoolMode(e) { + checkStringTypeUnionValue(VALID_POOL_MODE_VALUES, "PoolMode", e); + }var _nameScopeStack = [], + _nameScopeDivider = "/";function nameScope(e, t) { + _nameScopeStack.push(e);try { + var n = t();return _nameScopeStack.pop(), n; + } catch (e) { + throw _nameScopeStack.pop(), e; + } + }function currentNameScopePrefix() { + return 0 === _nameScopeStack.length ? "" : _nameScopeStack.join(_nameScopeDivider) + _nameScopeDivider; + }function getScopedTensorName(e) { + if (!isValidTensorName(e)) throw new Error("Not a valid tensor name: '" + e + "'");return currentNameScopePrefix() + e; + }function getUniqueTensorName(e) { + if (!isValidTensorName(e)) throw new Error("Not a valid tensor name: '" + e + "'");nameMap.has(e) || nameMap.set(e, 0);var t = nameMap.get(e);if (nameMap.set(e, nameMap.get(e) + 1), t > 0) { + var n = e + "_" + t;return nameMap.set(n, 1), n; + }return e; + }var tensorNameRegex = new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/);function isValidTensorName(e) { + return !!e.match(tensorNameRegex); + }function isInteger(e) { + return e === parseInt(e.toString(), 10); + }function arrayProd(e, t, n) { + null == t && (t = 0), null == n && (n = e.length);for (var r = 1, i = t; i < n; ++i) r *= e[i];return r; + }function toArray1D(e) { + return e = Array.isArray(e) ? new Float32Array(e) : e, tensor1d(e); + }function min$1(e) { + return min(toArray1D(e)).dataSync()[0]; + }function max$1(e) { + return max(toArray1D(e)).dataSync()[0]; + }function range$1(e, t) { + if (t < e) throw new ValueError("end (" + t + ") < begin (" + e + ") is forbidden.");for (var n = [], r = e; r < t; ++r) n.push(r);return n; + }function cast$1(e, t) { + return e.asType(t); + }function expandDims$1(e, t) { + void 0 === t && (t = -1);var n = e.shape.slice();return t < 0 && (t = n.length + t + 1), n.splice(t, 0, 1), e.reshape(n); + }function repeat(e, t) { + return tidy(function () { + if (2 !== e.shape.length) throw new ValueError("repeat() expects a rank-2 tensor, but received a rank-" + e.shape.length + " tensor.");return tile$1(expandDims$1(e, 1), [1, t, 1]); + }); + }function flatten$1(e) { + var t = [arrayProd(e.shape)];return e.reshape(t); + }function batchFlatten(e) { + if (e.rank <= 1) throw new ValueError("batchFlatten requires a minimum rank of 2. Got rank: " + e.rank + ".");var t = [e.shape[0], arrayProd(e.shape, 1)];return e.reshape(t); + }function sliceAlongFirstAxis(e, t, n) { + return tidy(function () { + switch (e.rank) {case 1: + return slice1d(e, t, n);case 2: + return slice2d(e, [t, 0], [n, e.shape[1]]);case 3: + return slice3d(e, [t, 0, 0], [n, e.shape[1], e.shape[2]]);case 4: + return slice4d(e, [t, 0, 0, 0], [n, e.shape[1], e.shape[2], e.shape[3]]);default: + throw new ValueError("sliceAlongFirstAxis() received an unsupported tensor rank: " + e.rank);} + }); + }function sliceAlongLastAxis(e, t, n) { + return tidy(function () { + switch (e.rank) {case 1: + return slice1d(e, t, n);case 2: + return slice2d(e, [0, t], [e.shape[0], n]);case 3: + return slice3d(e, [0, 0, t], [e.shape[0], e.shape[1], n]);case 4: + return slice4d(e, [0, 0, 0, t], [e.shape[0], e.shape[1], e.shape[2], n]);default: + throw new ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + e.rank);} + }); + }function sliceAlongAxis(e, t, n, r) { + return tidy(function () { + switch (e.rank) {case 1: + return slice1d(e, t, n);case 2: + switch (r) {case 1: + return sliceAlongFirstAxis(e, t, n);case 2: + return sliceAlongLastAxis(e, t, n);default: + throw new ValueError("The axis is not within the rank of the tensor " + r);}case 3: + switch (r) {case 1: + return sliceAlongFirstAxis(e, t, n);case 2: + return slice3d(e, [0, t, 0], [e.shape[0], n, e.shape[2]]);case 3: + return sliceAlongLastAxis(e, t, n);default: + throw new ValueError("The axis is not within the rank of the tensor " + r);}case 4: + switch (r) {case 1: + return sliceAlongFirstAxis(e, t, n);case 2: + return slice4d(e, [0, t, 0, 0], [e.shape[0], n, e.shape[2], e.shape[3]]);case 3: + return slice4d(e, [0, 0, t, 0], [e.shape[0], e.shape[1], n, e.shape[3]]);case 4: + return sliceAlongLastAxis(e, t, n);default: + throw new ValueError("The axis is not within the rank of the tensor " + r);}default: + throw new ValueError("sliceAlongLastAxis() received an unsupported tensor rank: " + e.rank);} + }); + }function concatenate(e, t) { + var n;return void 0 === t && (t = -1), t < 0 && (t = 0 !== (n = e[0].rank) ? n : 0), t === e[0].rank && (t = -1), concat(e, t); + }function concatAlongFirstAxis(e, t) { + switch (e.rank) {case 1: + return concat1d([e, t]);case 2: + return concat2d([e, t], 0);case 3: + return concat3d([e, t], 0);case 4: + return concat4d([e, t], 0);default: + throw new ValueError("concatAlongFirstAxis() received an unsupported tensor rank: " + e.rank);} + }function tile$1(e, t) { + if (Array.isArray(t) || (t = [t]), e.rank !== t.length) throw new ValueError("The length of input n (" + t.length + ") does not match the number of dimensions in input x (" + e.rank + ")");return tile(e, t); + }function randomNormal$1(e, t, n, r, i) { + return void 0 === t && (t = 0), void 0 === n && (n = 1), randomNormal(e, t, n, r, i); + }function dot$1(e, t) { + if (2 !== t.rank) throw new NotImplementedError("dot support for y other than rank 2 is not yet implemented: y shape = " + t.shape);if (2 === e.rank) return matMul(e, t);if (3 === e.rank) { + var n = e.shape[0], + r = e.shape[1], + i = e.shape[2];return e = e.reshape([n * r, i]), matMul(e, t).reshape([n, r, t.shape[1]]); + }throw new NotImplementedError("dot support for x of rank " + e.rank + " is not yet implemented: x shape = " + e.shape); + }function gather$1(e, t, n) { + return tidy(function () { + return t = Array.isArray(t) ? tensor1d(t, "int32") : t.toInt(), gather(e, t, n); + }); + }function square$1(e) { + return mulStrict(e, e); + }function biasAdd(e, t, n) { + return tidy(function () { + if (null == n && (n = imageDataFormat()), checkDataFormat(n), 1 !== t.rank && t.rank !== e.rank) throw new ValueError("Unexpected bias dimensions: " + t.rank + "; expected it to be 1 or " + e.rank);var r, + i = t.shape;if (5 === e.rank) "channelsFirst" === n ? r = 1 === i.length ? e.add(t.reshape([1, i[0], 1, 1, 1])) : e.add(t.reshape([1, i[3], i[0], i[1], i[2]])) : "channelsLast" === n && (r = 1 === i.length ? e.add(t.reshape([1, 1, 1, 1, i[0]])) : e.add(t.reshape([1].concat(i))));else if (4 === e.rank) "channelsFirst" === n ? r = 1 === i.length ? e.add(t.reshape([1, i[0], 1, 1])) : e.add(t.reshape([1, i[2], i[0], i[1]])) : "channelsLast" === n && (r = 1 === i.length ? e.add(t.reshape([1, 1, 1, i[0]])) : e.add(t.reshape([1].concat(i))));else if (3 === e.rank) "channelsFirst" === n ? r = 1 === i.length ? e.add(t.reshape([1, i[0], 1])) : e.add(t.reshape([1, i[1], i[0]])) : "channelsLast" === n && (r = 1 === i.length ? e.add(t.reshape([1, 1, i[0]])) : e.add(t.reshape([1].concat(i))));else { + if (!(e.rank < 3)) throw new ValueError("Unsupported input rank by biasAdd: " + e.rank);r = e.add(t); + }return r; + }); + }function elu$1(e, t) { + if (void 0 === t && (t = 1), 1 !== t) throw new NotImplementedError("Support for alpha values other than 1 (" + t + ") is not implemented yet.");return elu(e); + }function softsign(e) { + return tidy(function () { + return div(e, add(getScalar(1), abs(e))); + }); + }function dropout(e, t, n, r) { + return tidy(function () { + if (null != n && !util.arraysEqual(e.shape, n)) throw new NotImplementedError("Non-default noise shape is not implemented yet: " + JSON.stringify(n));if (null != r) throw new NotImplementedError("seed is not implemented for dropout yet.");var i = step(add(neg(t), randomUniform(e.shape, 0, 1, "float32")));return i = mul(div(getScalar(1), sub(getScalar(1), t)), i), mul(e, i); + }); + }function hardSigmoid(e) { + return tidy(function () { + var t = add(getScalar(.5), mul(getScalar(.2), e));return clipByValue(t, 0, 1); + }); + }function inTrainPhase(e, t, n) { + return void 0 === n && (n = !1), n ? e() : t(); + }var VALID_FAN_MODE_VALUES = ["fanIn", "fanOut", "fanAvg"];function checkFanMode(e) { + checkStringTypeUnionValue(VALID_FAN_MODE_VALUES, "FanMode", e); + }var VALID_DISTRIBUTION_VALUES = ["normal", "uniform"];function checkDistribution(e) { + checkStringTypeUnionValue(VALID_DISTRIBUTION_VALUES, "Distribution", e); + }var Initializer = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.fromConfigUsesCustomObjects = function () { + return !1; + }, t.prototype.getConfig = function () { + return {}; + }, t; + }(serialization.Serializable), + Zeros = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + return zeros(e, t); + }, t.className = "Zeros", t; + }(Initializer);serialization.SerializationMap.register(Zeros);var Ones = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + return ones$1(e, t); + }, t.className = "Ones", t; + }(Initializer);serialization.SerializationMap.register(Ones);var Constant = function (e) { + function t(t) { + var n = e.call(this) || this;if ("object" != typeof t) throw new ValueError("Expected argument of type ConstantConfig but got " + t);if (void 0 === t.value) throw new ValueError("config must have value set but got " + t);return n.value = t.value, n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + var n = this;return tidy(function () { + return mul(scalar(n.value), ones$1(e, t)); + }); + }, t.prototype.getConfig = function () { + return { value: this.value }; + }, t.className = "Constant", t; + }(Initializer);serialization.SerializationMap.register(Constant);var RandomUniform = function (e) { + function t(t) { + var n = e.call(this) || this;return n.DEFAULT_MINVAL = -.05, n.DEFAULT_MAXVAL = .05, n.minval = t.minval || n.DEFAULT_MINVAL, n.maxval = t.maxval || n.DEFAULT_MAXVAL, n.seed = t.seed, n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + return randomUniform(e, this.minval, this.maxval, t); + }, t.prototype.getConfig = function () { + return { minval: this.minval, maxval: this.maxval, seed: this.seed }; + }, t.className = "RandomUniform", t; + }(Initializer);serialization.SerializationMap.register(RandomUniform);var RandomNormal = function (e) { + function t(t) { + var n = e.call(this) || this;return n.DEFAULT_MEAN = 0, n.DEFAULT_STDDEV = .05, n.mean = t.mean || n.DEFAULT_MEAN, n.stddev = t.stddev || n.DEFAULT_STDDEV, n.seed = t.seed, n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + if ("bool" === t) throw new NotImplementedError("randomNormal does not support dType bool.");return randomNormal$1(e, this.mean, this.stddev, t, this.seed); + }, t.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }, t.className = "RandomNormal", t; + }(Initializer);serialization.SerializationMap.register(RandomNormal);var TruncatedNormal = function (e) { + function t(t) { + var n = e.call(this) || this;return n.DEFAULT_MEAN = 0, n.DEFAULT_STDDEV = .05, n.mean = t.mean || n.DEFAULT_MEAN, n.stddev = t.stddev || n.DEFAULT_STDDEV, n.seed = t.seed, n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + if ("bool" === t) throw new NotImplementedError("truncatedNormal does not support dType bool.");return truncatedNormal(e, this.mean, this.stddev, t, this.seed); + }, t.prototype.getConfig = function () { + return { mean: this.mean, stddev: this.stddev, seed: this.seed }; + }, t.className = "TruncatedNormal", t; + }(Initializer);serialization.SerializationMap.register(TruncatedNormal);var Identity = function (e) { + function t(t) { + var n = e.call(this) || this;return n.gain = null != t.gain ? scalar(t.gain) : getScalar(1), n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + var n = this;return tidy(function () { + if (2 !== e.length || e[0] !== e[1]) throw new ValueError("Identity matrix initializer can only be used for 2D square matrices.");return mul(n.gain, eye(e[0])); + }); + }, t.prototype.getConfig = function () { + return { gain: this.gain.get() }; + }, t.className = "Identity", t; + }(Initializer);function computeFans(e, t) { + var n, r;if (void 0 === t && (t = "channelsLast"), checkDataFormat(t), 2 === e.length) n = e[0], r = e[1];else if (-1 !== [3, 4, 5].indexOf(e.length)) { + if ("channelsFirst" === t) { + var i = arrayProd(e, 2);n = e[1] * i, r = e[0] * i; + } else if ("channelsLast" === t) { + i = arrayProd(e, 0, e.length - 2);n = e[e.length - 2] * i, r = e[e.length - 1] * i; + } + } else { + var a = arrayProd(e);n = Math.sqrt(a), r = Math.sqrt(a); + }return [n, r]; + }serialization.SerializationMap.register(Identity);var VarianceScaling = function (e) { + function t(t) { + var n = e.call(this) || this;if (t.scale < 0) throw new ValueError("scale must be a positive float. Got: " + t.scale);return n.scale = null == t.scale ? 1 : t.scale, n.mode = t.mode, checkFanMode(n.mode), n.distribution = t.distribution, checkDistribution(n.distribution), n.seed = t.seed, n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + var n = computeFans(e), + r = n[0], + i = n[1], + a = this.scale;if ("fanIn" === this.mode ? a /= Math.max(1, r) : "fanOut" === this.mode ? a /= Math.max(1, i) : a /= Math.max(1, (r + i) / 2), "normal" === this.distribution) { + var o = Math.sqrt(a);if ("bool" === t) throw new NotImplementedError(this.getClassName() + " does not support dType bool.");return truncatedNormal(e, 0, o, t, this.seed); + }var s = Math.sqrt(3 * a);return randomUniform(e, -s, s, t); + }, t.prototype.getConfig = function () { + return { scale: this.scale, mode: this.mode, distribution: this.distribution, seed: this.seed }; + }, t.className = "VarianceScaling", t; + }(Initializer);serialization.SerializationMap.register(VarianceScaling);var GlorotUniform = function (e) { + function t(t) { + return e.call(this, { scale: 1, mode: "fanAvg", distribution: "uniform", seed: null == t ? null : t.seed }) || this; + }return __extends$1(t, e), t.prototype.getClassName = function () { + return VarianceScaling.className; + }, t; + }(VarianceScaling), + GlorotNormal = function (e) { + function t(t) { + return e.call(this, { scale: 1, mode: "fanAvg", distribution: "normal", seed: null == t ? null : t.seed }) || this; + }return __extends$1(t, e), t.prototype.getClassName = function () { + return VarianceScaling.className; + }, t; + }(VarianceScaling), + HeNormal = function (e) { + function t(t) { + return e.call(this, { scale: 2, mode: "fanIn", distribution: "normal", seed: null == t ? null : t.seed }) || this; + }return __extends$1(t, e), t.prototype.getClassName = function () { + return VarianceScaling.className; + }, t; + }(VarianceScaling), + LeCunNormal = function (e) { + function t(t) { + return e.call(this, { scale: 1, mode: "fanIn", distribution: "normal", seed: null == t ? null : t.seed }) || this; + }return __extends$1(t, e), t.prototype.getClassName = function () { + return VarianceScaling.className; + }, t; + }(VarianceScaling), + Orthogonal = function (e) { + function t(t) { + var n = e.call(this) || this;if (n.DEFAULT_GAIN = 1, n.gain = null == t.gain ? n.DEFAULT_GAIN : t.gain, n.seed = t.seed, null != n.seed) throw new NotImplementedError("Random seed is not implemented for Orthogonal Initializer yet.");return n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + var n = this;return tidy(function () { + if (2 !== e.length) throw new NotImplementedError("The Orthogonal Initializer does not support non-2D shapes yet.");e[0] * e[1] > 2e3 && console.warn("Orthogonal initializer is being called on a matrix with more than 2000 (" + e[0] * e[1] + ") elements: Slowness may result.");var t = randomNormal$1(e[0] > e[1] ? [e[1], e[0]] : e, 0, 1, "float32"), + r = linalg_ops.gramSchmidt(t);return e[0] > e[1] && (r = r.transpose()), mul(getScalar(n.gain), r); + }); + }, t.prototype.getConfig = function () { + return { gain: this.gain, seed: this.seed }; + }, t.className = "Orthogonal", t; + }(Initializer);serialization.SerializationMap.register(Orthogonal);var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { constant: "Constant", glorotNormal: "GlorotNormal", glorotUniform: "GlorotUniform", heNormal: "HeNormal", identity: "Identity", leCunNormal: "LeCunNormal", ones: "Ones", orthogonal: "Orthogonal", randomNormal: "RandomNormal", randomUniform: "RandomUniform", truncatedNormal: "TruncatedNormal", varianceScaling: "VarianceScaling", zeros: "Zeros" };function deserializeInitializer(e, t) { + return void 0 === t && (t = {}), deserializeKerasObject(e, serialization.SerializationMap.getMap().classNameMap, t, "initializer"); + }function serializeInitializer(e) { + return serializeKerasObject(e); + }function getInitializer(e) { + if ("string" == typeof e) { + var t = e in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e] : e;return "GlorotUniform" === t ? new GlorotUniform() : "GlorotNormal" === t ? new GlorotNormal() : "HeNormal" === t ? new HeNormal() : "LeCunNormal" === t ? new LeCunNormal() : deserializeInitializer({ className: t, config: {} }); + }return e instanceof Initializer ? e : deserializeInitializer(e); + }function zeros$1() { + return new Zeros(); + }function ones$1$1() { + return new Ones(); + }function constant(e) { + return new Constant(e); + }function randomUniform$1(e) { + return new RandomUniform(e); + }function randomNormal$2(e) { + return new RandomNormal(e); + }function truncatedNormal$1(e) { + return new TruncatedNormal(e); + }function identity(e) { + return new Identity(e); + }function varianceScaling(e) { + return new VarianceScaling(e); + }function glorotUniform(e) { + return new GlorotUniform(e); + }function glorotNormal(e) { + return new GlorotNormal(e); + }function heNormal(e) { + return new HeNormal(e); + }function leCunNormal(e) { + return new LeCunNormal(e); + }function orthogonal(e) { + return new Orthogonal(e); + }var exports_initializers = Object.freeze({ zeros: zeros$1, ones: ones$1$1, constant: constant, randomUniform: randomUniform$1, randomNormal: randomNormal$2, truncatedNormal: truncatedNormal$1, identity: identity, varianceScaling: varianceScaling, glorotUniform: glorotUniform, glorotNormal: glorotNormal, heNormal: heNormal, leCunNormal: leCunNormal, orthogonal: orthogonal });function isArrayOfShapes(e) { + return Array.isArray(e) && Array.isArray(e[0]); + }function normalizeShapeList(e) { + return 0 === e.length ? [] : Array.isArray(e[0]) ? e : [e]; + }function getExactlyOneTensor(e) { + var t;if (Array.isArray(e)) { + if (1 !== e.length) throw new ValueError("Expected Tensor length to be 1; got " + e.length);t = e[0]; + } else t = e;return t; + }function getExactlyOneShape(e) { + if (Array.isArray(e) && Array.isArray(e[0])) { + if (1 === e.length) return (e = e)[0];throw new ValueError("Expected exactly 1 Shape; got " + e.length); + }return e; + }function countParamsInWeights(e) { + for (var t = 0, n = 0, r = e; n < r.length; n++) { + var i = r[n];0 === i.shape.length ? t += 1 : t += i.shape.reduce(function (e, t) { + return e * t; + }); + }return t; + }var DEFAULT_VARIABLE_NAME_PREFIX = "Variable", + LayerVariable = function () { + function e(e, t, n, r, i) { + void 0 === t && (t = "float32"), void 0 === n && (n = DEFAULT_VARIABLE_NAME_PREFIX), void 0 === r && (r = !0), void 0 === i && (i = null), this.dtype = null == t ? "float32" : t, this.shape = e.shape, this.id = getNextUniqueTensorId(), n = null == n ? DEFAULT_VARIABLE_NAME_PREFIX : n, this.originalName = getScopedTensorName(n), this.name = getUniqueTensorName(this.originalName), this.trainable = r, this.constraint = i, this.val = variable(e, this.trainable, this.name, this.dtype); + }return e.prototype.read = function () { + return this.val; + }, e.prototype.write = function (e) { + return checkShapesMatch(this.val, e), this.val.assign(e), null != this.constraint && this.val.assign(this.constraint.apply(this.val)), this; + }, e; + }();function checkShapesMatch(e, t) { + if (e.shape.toString() !== t.shape.toString()) throw new Error("Shape mismatch: " + JSON.stringify(e.shape) + " vs. " + JSON.stringify(t.shape)); + }function batchGetValue(e) { + return e.map(function (e) { + return e.read(); + }); + }function batchSetValue(e) { + e.map(function (e) { + e[0].write(e[1]); + }); + }var InputSpec = function () { + return function (e) { + this.dtype = e.dtype, this.shape = e.shape, null != e.shape ? this.ndim = e.shape.length : this.ndim = e.ndim, this.maxNDim = e.maxNDim, this.minNDim = e.minNDim, this.axes = e.axes || {}; + }; + }(), + SymbolicTensor = function () { + return function (e, t, n, r, i, a, o) { + this.dtype = e, this.shape = t, this.sourceLayer = n, this.inputs = r, this.callArgs = i, this.outputTensorIndex = o, this.id = getNextUniqueTensorId(), null != a && (this.originalName = getScopedTensorName(a), this.name = getUniqueTensorName(this.originalName)), this.rank = t.length; + }; + }(), + _nextNodeID = 0, + Node = function () { + function e(e, t) { + this.callArgs = t, this.id = _nextNodeID++, this.outboundLayer = e.outboundLayer, this.inboundLayers = e.inboundLayers, this.nodeIndices = e.nodeIndices, this.tensorIndices = e.tensorIndices, this.inputTensors = e.inputTensors, this.outputTensors = e.outputTensors, this.inputMasks = e.inputMasks, this.outputMasks = e.outputMasks, this.inputShapes = e.inputShapes, this.outputShapes = e.outputShapes;for (var n = 0, r = e.inboundLayers; n < r.length; n++) { + var i = r[n];null != i && i.outboundNodes.push(this); + }e.outboundLayer.inboundNodes.push(this); + }return e.prototype.getConfig = function () { + for (var e = [], t = 0, n = this.inboundLayers; t < n.length; t++) { + var r = n[t];null != r ? e.push(r.name) : e.push(null); + }return { outboundLayer: this.outboundLayer ? this.outboundLayer.name : null, inboundLayers: e, nodeIndices: this.nodeIndices, tensorIndices: this.tensorIndices }; + }, e; + }(), + _nextLayerID = 0, + Layer = function (e) { + function t(t) { + var n = e.call(this) || this;n._callHook = null, n._addedWeightNames = [], n._stateful = !1, n.id = _nextLayerID++, n.activityRegularizer = null, n.inputSpec = null, n.supportsMasking = !1, n._trainableWeights = [], n._nonTrainableWeights = [], n._losses = [], n._updates = [], n._built = !1, n.inboundNodes = [], n.outboundNodes = [];var r = t.name;if (!r) { + var i = n.getClassName();r = toSnakeCase(i) + "_" + getUid(i); + }if (n.name = r, n.trainable = null == t.trainable || t.trainable, n.updatable = null == t.updatable || t.updatable, null != t.inputShape || null != t.batchInputShape) { + var a = void 0;if (null != t.batchInputShape) a = t.batchInputShape;else if (null != t.inputShape) { + var o = null;null != t.batchSize && (o = t.batchSize), a = [o].concat(t.inputShape); + }n.batchInputShape = a;var s = t.dtype;null == s && (s = t.inputDType), null == s && (s = "float32"), n.dtype = s; + }return null != t.weights ? n.initialWeights = t.weights : n.initialWeights = null, n; + }return __extends$1(t, e), t.nodeKey = function (e, t) { + return e.name + "_ib-" + t.toString(); + }, t.prototype.getNodeAtIndex = function (e, t) { + if (0 === this.inboundNodes.length) throw new RuntimeError("The layer has never been called and thus has no defined " + t + ".");if (this.inboundNodes.length <= e) throw new ValueError("Asked to get " + t + " at node " + e + ", but the layer has only " + this.inboundNodes.length + " inbound nodes.");return this.inboundNodes[e]; + }, t.prototype.getInputAt = function (e) { + return singletonOrArray(this.getNodeAtIndex(e, "input").inputTensors); + }, t.prototype.getOutputAt = function (e) { + return singletonOrArray(this.getNodeAtIndex(e, "output").outputTensors); + }, Object.defineProperty(t.prototype, "input", { get: function () { + if (this.inboundNodes.length > 1) throw new AttributeError("Layer " + this.name + ' has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if (0 === this.inboundNodes.length) throw new AttributeError("Layer " + this.name + " is not connected, no input to return.");return singletonOrArray(this.getNodeAtIndex(0, "input").inputTensors); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "output", { get: function () { + if (0 === this.inboundNodes.length) throw new AttributeError("Layer " + this.name + " has no inbound nodes.");if (this.inboundNodes.length > 1) throw new AttributeError("Layer " + this.name + ' has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return singletonOrArray(this.getNodeAtIndex(0, "output").outputTensors); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "losses", { get: function () { + return this._losses; + }, enumerable: !0, configurable: !0 }), t.prototype.calculateLosses = function () { + return this.losses.map(function (e) { + return e(); + }); + }, Object.defineProperty(t.prototype, "updates", { get: function () { + return this._updates; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "built", { get: function () { + return this._built; + }, set: function (e) { + this._built = e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + return this.trainable ? this._trainableWeights : []; + }, set: function (e) { + this._trainableWeights = e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + return this.trainable ? this._nonTrainableWeights : this._trainableWeights.concat(this._nonTrainableWeights); + }, set: function (e) { + this._nonTrainableWeights = e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "weights", { get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "stateful", { get: function () { + return this._stateful; + }, enumerable: !0, configurable: !0 }), t.prototype.assertInputCompatibility = function (e) { + if (e = toList(e), null != this.inputSpec && 0 !== this.inputSpec.length) { + var t = toList(this.inputSpec);if (e.length !== t.length) throw new ValueError("Layer " + this.name + " expects " + t.length + " inputs, but it received " + e.length + " input tensors. Input received: " + e);for (var n = 0; n < e.length; n++) { + var r = e[n], + i = t[n];if (null != i) { + var a = r.rank;if (null != i.ndim && a !== i.ndim) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + ": expected ndim=" + i.ndim + ", found ndim=" + a);if (null != i.maxNDim && a > i.maxNDim) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + ": expected max_ndim=" + i.maxNDim + ", found ndim=" + a);if (null != i.minNDim && a < i.minNDim) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + ": expected min_ndim=" + i.minNDim + ", found ndim=" + a + ".");if (null != i.dtype && r.dtype !== i.dtype) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + " : expected dtype=" + i.dtype + ", found dtype=" + r.dtype + ".");if (i.axes) { + var o = r.shape;for (var s in i.axes) { + var l = Number(s), + u = i.axes[s], + c = l >= 0 ? o[l] : o[o.length + l];if (null != u && -1 === [u, null].indexOf(c)) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + ": expected axis " + l + " of input shape to have value " + u + " but got shape " + o + "."); + } + }if (null != i.shape) for (var p = 0; p < i.shape.length; ++p) { + var h = i.shape[p], + d = r.shape[p];if (null != h && null != d && h !== d) throw new ValueError("Input " + n + " is incompatible with layer " + this.name + ": expected shape=" + i.shape + ", found shape=${xShape}."); + } + } + } + } + }, t.prototype.call = function (e, t) { + return e; + }, t.prototype.invokeCallHook = function (e, t) { + null != this._callHook && this._callHook(e, t); + }, t.prototype.setCallHook = function (e) { + this._callHook = e; + }, t.prototype.clearCallHook = function () { + this._callHook = null; + }, t.prototype.apply = function (e, t) { + var n = this;t = t || {};for (var r = toList(e), i = !0, a = 0, o = r; a < o.length; a++) { + if (!(o[a] instanceof SymbolicTensor)) { + i = !1;break; + } + }for (var s = !0, l = 0, u = r; l < u.length; l++) { + if (u[l] instanceof SymbolicTensor) { + s = !1;break; + } + }if (i === s) throw new ValueError("Arguments to apply() must be all SymbolicTensors or all Tensors");return nameScope(this.name, function () { + if (!n.built) { + n.assertInputCompatibility(e);for (var i = [], a = 0, o = toList(e); a < o.length; a++) { + var l = o[a];i.push(l.shape); + }n.build(singletonOrArray(i)), n.built = !0, n.initialWeights && n.setWeights(n.initialWeights); + }if (n.assertInputCompatibility(e), s) { + for (var u = [], c = 0, p = toList(f = n.call(e, t)); c < p.length; c++) { + var h = p[c];-1 !== r.indexOf(h) && (h = h.clone()), u.push(h); + }if (f = singletonOrArray(u), null != n.activityRegularizer) throw new NotImplementedError("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return f; + }var d = collectInputShape(e), + g = n.computeOutputShape(d), + f = void 0, + m = guessOutputDType(e);if (n.warnOnIncompatibleInputShape(Array.isArray(e) ? d[0] : d), f = null != g && g.length > 0 && Array.isArray(g[0]) ? g.map(function (r, i) { + return new SymbolicTensor(m, r, n, toList(e), t, n.name, i); + }) : new SymbolicTensor(m, g, n, toList(e), t, n.name), n.addInboundNode(e, f, null, null, d, g, t), null != n.activityRegularizer) throw new NotImplementedError("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return f; + }); + }, t.prototype.warnOnIncompatibleInputShape = function (e) { + if (null != this.batchInputShape) if (e.length !== this.batchInputShape.length) console.warn("The rank of the input tensor provided (shape: " + JSON.stringify(e) + ") does not match that of the batchInputShape (" + JSON.stringify(this.batchInputShape) + ") of the layer " + this.name);else { + var t = !1;this.batchInputShape.forEach(function (n, r) { + null != n && null != e[r] && e[r] !== n && (t = !0); + }), t && console.warn("The shape of the input tensor (" + JSON.stringify(e) + ") does not match the expectation of layer " + this.name + ": " + JSON.stringify(this.batchInputShape)); + } + }, Object.defineProperty(t.prototype, "outputShape", { get: function () { + if (null == this.inboundNodes || 0 === this.inboundNodes.length) throw new AttributeError("The layer " + this.name + " has never been called and thus has no defined output shape.");for (var e = [], t = 0, n = this.inboundNodes; t < n.length; t++) { + var r = n[t], + i = JSON.stringify(r.outputShapes);-1 === e.indexOf(i) && e.push(i); + }if (1 === e.length) { + var a = this.inboundNodes[0].outputShapes;return Array.isArray(a) && Array.isArray(a[0]) && 1 === a.length ? a[0] : a; + }throw new AttributeError("The layer " + this.name + ' has multiple inbound nodes with different output shapes. Hence the notion of "outut shape" is ill-defined for the layer.'); + }, enumerable: !0, configurable: !0 }), t.prototype.countParams = function () { + if (!this.built) throw new RuntimeError("You tried to call countParams() on " + this.name + ", but the layer is not built yet. Build it first by calling build(batchInputShape).");return countParamsInWeights(this.weights); + }, t.prototype.build = function (e) { + this.built = !0; + }, t.prototype.getWeights = function (e) { + return void 0 === e && (e = !1), batchGetValue(e ? this.trainableWeights : this.weights); + }, t.prototype.setWeights = function (e) { + var t = this;tidy(function () { + var n = t.weights;if (n.length !== e.length) throw new ValueError('You called setWeights(weights) on layer "' + t.name + '" with a weight list of length ' + e.length + ", but the layer was expecting " + n.length + " weights. Provided weights: " + e + "...");if (0 !== n.length) { + for (var r = [], i = batchGetValue(n), a = 0; a < i.length; ++a) { + var o = i[a], + s = n[a], + l = e[a];if (!util.arraysEqual(o.shape, l.shape)) throw new ValueError("Layer weight shape " + o.shape + " not compatible with provided weight shape " + l.shape);r.push([s, l]); + }batchSetValue(r); + } + }); + }, t.prototype.addWeight = function (e, t, n, r, i, a, o) { + if (-1 !== this._addedWeightNames.indexOf(e)) throw new ValueError("Duplicate weight name " + e + " for layer " + this.name);this._addedWeightNames.push(e), null == n && (n = "float32");var s = new LayerVariable(r.apply(t, n), n, e, a, o);return null != i && this.addLoss(function () { + return i.apply(s.read()); + }), null == a && (a = !0), a ? this._trainableWeights.push(s) : this._nonTrainableWeights.push(s), s; + }, t.prototype.addLoss = function (e) { + var t;null == e || Array.isArray(e) && 0 === e.length || (e = toList(e), void 0 !== this._losses && null !== this._losses && (t = this.losses).push.apply(t, e)); + }, t.prototype.computeOutputShape = function (e) { + return e; + }, t.prototype.computeMask = function (e, t) { + var n = this;if (!this.supportsMasking) { + if (null != t) { + if (!Array.isArray(t)) throw new TypeError("Layer " + this.name + " does not support masking,but was passed an inputMask.");t.forEach(function (e) { + if (null != e) throw new TypeError("Layer " + n.name + " does not support masking,but was passed an inputMask."); + }); + }return null; + }return t; + }, t.prototype.addInboundNode = function (e, t, n, r, i, a, o) { + void 0 === o && (o = null);var s = toList(e);t = toList(t), n = toList(n), r = toList(r), i = normalizeShapeList(i), a = normalizeShapeList(a);for (var l = [], u = [], c = [], p = 0, h = s; p < h.length; p++) { + var d = h[p];l.push(d.sourceLayer), u.push(d.nodeIndex), c.push(d.tensorIndex); + }new Node({ outboundLayer: this, inboundLayers: l, nodeIndices: u, tensorIndices: c, inputTensors: s, outputTensors: t, inputMasks: n, outputMasks: r, inputShapes: i, outputShapes: a }, o);for (var g = 0; g < t.length; g++) t[g].sourceLayer = this, t[g].nodeIndex = this.inboundNodes.length - 1, t[g].tensorIndex = g; + }, t.prototype.getConfig = function () { + var e = { name: this.name, trainable: this.trainable };return null != this.batchInputShape && (e.batchInputShape = this.batchInputShape), null != this.dtype && (e.dtype = this.dtype), e; + }, t; + }(serialization.Serializable);function collectInputShape(e) { + for (var t = [], n = 0, r = e = toList(e); n < r.length; n++) { + var i = r[n];t.push(i.shape); + }return singletonOrArray(t); + }function guessOutputDType(e) { + return "float32"; + }function getSourceInputs(e, t, n) { + if ((null == t || null != n && n > 0) && (t = e.sourceLayer, n = e.nodeIndex), 0 === t.inboundNodes.length) return [e];var r = t.inboundNodes[n];if (0 === r.inboundLayers.length) return r.inputTensors;for (var i = [], a = 0; a < r.inboundLayers.length; a++) for (var o = 0, s = getSourceInputs(r.inputTensors[a], r.inboundLayers[a], r.nodeIndices[a]); o < s.length; o++) { + var l = s[o];-1 === i.indexOf(l) && i.push(l); + }return i; + }var InputLayer = function (e) { + function t(t) { + var n = e.call(this, { dtype: t.dtype, name: null != t.name ? t.name : getUid("input").toString() }) || this;if (null == t.batchSize && (t.batchSize = null), null == t.sparse && (t.sparse = !1), n.trainable = !1, n.built = !0, n.sparse = t.sparse, null != t.inputShape && null != t.batchInputShape) throw new ValueError("Only provide the inputShape OR batchInputShape argument to inputLayer, not both at the same time.");var r = t.batchInputShape;if (null == r) { + if (null == t.inputShape) throw new ValueError("An InputLayer should be passed either a `batchInputShape` or an `inputShape`.");r = [t.batchSize].concat(t.inputShape); + } else if (null != t.batchSize) throw new ValueError("Cannot specify batchSize if batchInputShape isspecified when creating an InputLayer.");var i = t.dtype || "float32";n.batchInputShape = r, n.dtype = i, n.inputSpec = [{ shape: r }];var a = new SymbolicTensor(n.dtype, n.batchInputShape, n, [], {}, n.name);return a.nodeIndex = 0, a.tensorIndex = 0, new Node({ outboundLayer: n, inboundLayers: [], nodeIndices: [], tensorIndices: [], inputTensors: [a], outputTensors: [a], inputMasks: [null], outputMasks: [null], inputShapes: [r], outputShapes: [r] }), n; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + throw new ValueError("Cannot pass any input to an InputLayer's apply() method. InputLayer name: " + this.name); + }, t.prototype.getConfig = function () { + return { batchInputShape: this.batchInputShape, dtype: this.dtype, sparse: this.sparse, name: this.name }; + }, t.className = "InputLayer", t; + }(Layer);function Input(e) { + if (null == e.batchShape && null == e.shape) throw new Error("Please provide to Input either a `shape` or a `batchShape` argument. Note that `shape` does not include the batch dimension.");if (null != e.batchShape && null != e.shape) throw new ValueError("Please provide either a `shape` or `batchShape` argument to Input, but not both.");var t = e.batchShape;null != e.shape && null == t && (t = [null].concat(e.shape));var n = e.dtype;return null == n && (n = "float32"), new InputLayer({ batchInputShape: t, name: e.name, dtype: n, sparse: e.sparse }).inboundNodes[0].outputTensors[0]; + }function resolveScalarsInLogs(e) { + return __awaiter$1(this, void 0, void 0, function () { + var t, n, r, i, a, o, s, l;return __generator$1(this, function (u) { + switch (u.label) {case 0: + if (null == e) return [2];for (i in t = [], n = [], r = [], e) "number" != typeof (a = e[i]) && (o = a, t.push(o.data()), n.push(i), r.push(o));return [4, Promise.all(t)];case 1: + for (s = u.sent(), l = 0; l < s.length; ++l) e[n[l]] = s[l][0];return dispose(r), [2];} + }); + }); + }function disposeTensorsInLogs(e) { + if (null != e) for (var t in e) { + var n = e[t];"number" != typeof n && n.dispose(); + } + }serialization.SerializationMap.register(InputLayer);var BaseCallback = function () { + function e() { + this.validationData = null; + }return e.prototype.setParams = function (e) { + this.params = e; + }, e.prototype.onEpochBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.onEpochEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.onBatchBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.onBatchEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.onTrainBegin = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.onTrainEnd = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return [2]; + }); + }); + }, e.prototype.setModel = function (e) {}, e; + }(), + CallbackList = function () { + function e(e, t) { + void 0 === t && (t = 10), null == e && (e = []), this.callbacks = e, this.queueLength = t; + }return e.prototype.append = function (e) { + this.callbacks.push(e); + }, e.prototype.setParams = function (e) { + for (var t = 0, n = this.callbacks; t < n.length; t++) { + n[t].setParams(e); + } + }, e.prototype.setModel = function (e) { + for (var t = 0, n = this.callbacks; t < n.length; t++) { + n[t].setModel(e); + } + }, e.prototype.onEpochBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r;return __generator$1(this, function (i) { + switch (i.label) {case 0: + null == t && (t = {}), n = 0, r = this.callbacks, i.label = 1;case 1: + return n < r.length ? [4, r[n].onEpochBegin(e, t)] : [3, 4];case 2: + i.sent(), i.label = 3;case 3: + return n++, [3, 1];case 4: + return [2];} + }); + }); + }, e.prototype.onEpochEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r;return __generator$1(this, function (i) { + switch (i.label) {case 0: + null == t && (t = {}), n = 0, r = this.callbacks, i.label = 1;case 1: + return n < r.length ? [4, r[n].onEpochEnd(e, t)] : [3, 4];case 2: + i.sent(), i.label = 3;case 3: + return n++, [3, 1];case 4: + return [2];} + }); + }); + }, e.prototype.onBatchBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r;return __generator$1(this, function (i) { + switch (i.label) {case 0: + null == t && (t = {}), n = 0, r = this.callbacks, i.label = 1;case 1: + return n < r.length ? [4, r[n].onBatchBegin(e, t)] : [3, 4];case 2: + i.sent(), i.label = 3;case 3: + return n++, [3, 1];case 4: + return [2];} + }); + }); + }, e.prototype.onBatchEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r;return __generator$1(this, function (i) { + switch (i.label) {case 0: + null == t && (t = {}), n = 0, r = this.callbacks, i.label = 1;case 1: + return n < r.length ? [4, r[n].onBatchEnd(e, t)] : [3, 4];case 2: + i.sent(), i.label = 3;case 3: + return n++, [3, 1];case 4: + return [2];} + }); + }); + }, e.prototype.onTrainBegin = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + var t, n;return __generator$1(this, function (r) { + switch (r.label) {case 0: + null == e && (e = {}), t = 0, n = this.callbacks, r.label = 1;case 1: + return t < n.length ? [4, n[t].onTrainBegin(e)] : [3, 4];case 2: + r.sent(), r.label = 3;case 3: + return t++, [3, 1];case 4: + return [2];} + }); + }); + }, e.prototype.onTrainEnd = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + var t, n;return __generator$1(this, function (r) { + switch (r.label) {case 0: + null == e && (e = {}), t = 0, n = this.callbacks, r.label = 1;case 1: + return t < n.length ? [4, n[t].onTrainEnd(e)] : [3, 4];case 2: + r.sent(), r.label = 3;case 3: + return t++, [3, 1];case 4: + return [2];} + }); + }); + }, e; + }(), + BaseLogger = function (e) { + function t() { + return e.call(this) || this; + }return __extends$1(t, e), t.prototype.onEpochBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return this.seen = 0, this.totals = {}, [2]; + }); + }); + }, t.prototype.onBatchEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var e, + n, + r, + i, + a = this;return __generator$1(this, function (o) { + for (i in null == t && (t = {}), e = null == t.size ? 0 : t.size, this.seen += e, n = function (n) { + var i = t[n];if ("number" == typeof i) r.totals.hasOwnProperty(n) || (r.totals[n] = 0), r.totals[n] = r.totals[n] + i * e;else { + var o = void 0;n in r.totals ? o = r.totals[n] : r.totals[n] = getScalar(0), r.totals[n] = tidy(function () { + return add(a.totals[n], mul(i, getScalar(e))); + }), null != o && o.dispose(); + } + }, r = this, t) n(i);return [2]; + }); + }); + }, t.prototype.onEpochEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var e, + n, + r, + i, + a, + o = this;return __generator$1(this, function (s) { + if (null != t) for (e = function (e) { + if (null == n.totals[e]) return "continue";"number" == typeof n.totals[e] ? t[e] = n.totals[e] / n.seen : tidy(function () { + t[e] = mul(div(getScalar(1), getScalar(o.seen)), o.totals[e]), o.totals[e].dispose(), keep(t[e]); + }); + }, n = this, r = 0, i = this.params.metrics; r < i.length; r++) a = i[r], e(a);return [2]; + }); + }); + }, t; + }(BaseCallback), + History = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.onTrainBegin = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (e) { + return this.epoch = [], this.history = {}, [2]; + }); + }); + }, t.prototype.onEpochEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n;return __generator$1(this, function (r) { + for (n in null == t && (t = {}), this.epoch.push(e), t) null == this.history[n] && (this.history[n] = []), this.history[n].push(t[n]);return [2]; + }); + }); + }, t.prototype.syncData = function () { + return __awaiter$1(this, void 0, void 0, function () { + var e, t, n, r, i, a, o, s, l;return __generator$1(this, function (u) { + switch (u.label) {case 0: + for (r in e = [], t = [], n = [], this.history) for (i = this.history[r], a = 0; a < i.length; ++a) "number" != typeof i[a] && (o = i[a], e.push(o.data()), t.push(r), n.push(a));return [4, Promise.all(e)];case 1: + for (s = u.sent(), l = 0; l < s.length; ++l) this.history[t[l]][n[l]].dispose(), this.history[t[l]][n[l]] = s[l][0];return [2];} + }); + }); + }, t; + }(BaseCallback), + CustomCallback = function (e) { + function t(t) { + var n = e.call(this) || this;return n.trainBegin = t.onTrainBegin, n.trainEnd = t.onTrainEnd, n.epochBegin = t.onEpochBegin, n.epochEnd = t.onEpochEnd, n.batchBegin = t.onBatchBegin, n.batchEnd = t.onBatchEnd, n; + }return __extends$1(t, e), t.prototype.onEpochBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (n) { + switch (n.label) {case 0: + return null == this.epochBegin ? [3, 3] : [4, resolveScalarsInLogs(t)];case 1: + return n.sent(), [4, this.epochBegin(e, t)];case 2: + n.sent(), n.label = 3;case 3: + return [2];} + }); + }); + }, t.prototype.onEpochEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (n) { + switch (n.label) {case 0: + return null == this.epochEnd ? [3, 3] : [4, resolveScalarsInLogs(t)];case 1: + return n.sent(), [4, this.epochEnd(e, t)];case 2: + n.sent(), n.label = 3;case 3: + return [2];} + }); + }); + }, t.prototype.onBatchBegin = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (n) { + switch (n.label) {case 0: + return null == this.batchBegin ? [3, 3] : [4, resolveScalarsInLogs(t)];case 1: + return n.sent(), [4, this.batchBegin(e, t)];case 2: + n.sent(), n.label = 3;case 3: + return [2];} + }); + }); + }, t.prototype.onBatchEnd = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (n) { + switch (n.label) {case 0: + return null == this.batchEnd ? [3, 3] : [4, resolveScalarsInLogs(t)];case 1: + return n.sent(), [4, this.batchEnd(e, t)];case 2: + n.sent(), n.label = 3;case 3: + return [2];} + }); + }); + }, t.prototype.onTrainBegin = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (t) { + switch (t.label) {case 0: + return null == this.trainBegin ? [3, 3] : [4, resolveScalarsInLogs(e)];case 1: + return t.sent(), [4, this.trainBegin(e)];case 2: + t.sent(), t.label = 3;case 3: + return [2];} + }); + }); + }, t.prototype.onTrainEnd = function (e) { + return __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (t) { + switch (t.label) {case 0: + return null == this.trainEnd ? [3, 3] : [4, resolveScalarsInLogs(e)];case 1: + return t.sent(), [4, this.trainEnd(e)];case 2: + t.sent(), t.label = 3;case 3: + return [2];} + }); + }); + }, t; + }(BaseCallback);function standardizeCallbacks(e) { + return null == e ? null : e instanceof BaseCallback ? [e] : Array.isArray(e) && e[0] instanceof BaseCallback ? e : toList(e).map(function (e) { + return new CustomCallback(e); + }); + }function l2Normalize(e, t) { + return tidy(function () { + var n = sum(square$1(e), t, !0), + r = mul(scalar(epsilon()), onesLike(e)), + i = sqrt(maximum(n, r));return div(e, i); + }); + }function meanSquaredError$1(e, t) { + return tidy(function () { + return mean(square$1(sub(t, e)), -1); + }); + }function meanAbsoluteError(e, t) { + return tidy(function () { + return mean(abs(sub(t, e)), -1); + }); + }function meanAbsolutePercentageError(e, t) { + return tidy(function () { + var n = sub(e, t), + r = clipByValue(abs(e), epsilon(), Number.MAX_VALUE), + i = abs(div(n, r));return mul(getScalar(100), mean(i, -1)); + }); + }function meanSquaredLogarithmicError(e, t) { + return tidy(function () { + var n = getScalar(1), + r = clipByValue(t, epsilon(), Number.MAX_VALUE), + i = log$1(add(n, r)), + a = clipByValue(e, epsilon(), Number.MAX_VALUE), + o = log$1(add(n, a));return mean(square$1(sub(i, o)), -1); + }); + }function squaredHinge(e, t) { + return tidy(function () { + var n = getScalar(0), + r = getScalar(1), + i = maximum(n, sub(r, mul(e, t)));return mean(square$1(i), -1); + }); + }function hinge(e, t) { + return tidy(function () { + var n = getScalar(0), + r = getScalar(1), + i = maximum(n, sub(r, mul(e, t)));return mean(i, -1); + }); + }function categoricalHinge(e, t) { + return tidy(function () { + var n = getScalar(0), + r = getScalar(1), + i = sum(mul(e, t), -1), + a = max(mul(sub(r, e), t), -1);return maximum(n, add(r, sub(a, i))); + }); + }function logcosh(e, t) { + return tidy(function () { + var n = getScalar(Math.log(2)), + r = sub(t, e), + i = sub(add(r, softplus(mul(getScalar(-2), r))), n);return mean(i, -1); + }); + }function categoricalCrossentropy(e, t, n) { + return void 0 === n && (n = !1), tidy(function () { + if (n) t = softmax(t);else { + var r = sum(t, t.shape.length - 1, !0);t = div(t, r); + }return t = clipByValue(t, epsilon(), 1 - epsilon()), neg(sum(mul(e.toFloat(), log$1(t)), t.shape.length - 1)); + }); + }function sparseCategoricalCrossentropy(e, t, n) { + return void 0 === n && (n = !1), tidy(function () { + var r = floor(flatten$1(e)).toInt(), + i = t.shape;return categoricalCrossentropy(oneHot(r, i[i.length - 1]).reshape(i), t, n); + }); + }function sigmoidCrossEntropyWithLogits(e, t) { + return tidy(function () { + var n = maximum(t, zerosLike(t)), + r = mul(t, e), + i = log$1(add(getScalar(1), exp(neg(abs(t)))));return add(sub(n, r), i); + }); + }function binaryCrossentropy(e, t) { + return tidy(function () { + var n;return n = clipByValue(t, epsilon(), 1 - epsilon()), n = log$1(div(n, sub(onesLike(n), n))), mean(sigmoidCrossEntropyWithLogits(e, n), -1); + }); + }function kullbackLeiblerDivergence(e, t) { + return tidy(function () { + var n = clipByValue(e, epsilon(), 1), + r = clipByValue(t, epsilon(), 1);return sum(mul(e, log$1(div(n, r))), -1); + }); + }function poisson(e, t) { + return tidy(function () { + var n = log$1(add(getScalar(epsilon()), t));return mean(sub(t, mul(e, n)), -1); + }); + }function cosineProximity(e, t) { + return tidy(function () { + var n = l2Normalize(e, -1), + r = l2Normalize(t, -1), + i = mul(n, r);return neg(sum(i, -1)); + }); + }function get(e) { + var t = { meanSquaredError: meanSquaredError$1, meanAbsoluteError: meanAbsoluteError, meanAbsolutePercentageError: meanAbsolutePercentageError, meanSquaredLogarithmicError: meanSquaredLogarithmicError, squaredHinge: squaredHinge, hinge: hinge, categoricalHinge: categoricalHinge, logcosh: logcosh, categoricalCrossentropy: categoricalCrossentropy, sparseCategoricalCrossentropy: sparseCategoricalCrossentropy, binaryCrossentropy: binaryCrossentropy, kullbackLeiblerDivergence: kullbackLeiblerDivergence, poisson: poisson, cosineProximity: cosineProximity };if ("string" == typeof e) { + if (e in t) return t[e];throw new ValueError("Unknown loss " + e); + }return e; + }function binaryAccuracy(e, t) { + return tidy(function () { + var n = mul(getScalar(.5), onesLike(t)), + r = cast$1(greater(t, n), e.dtype);return mean(equal(e, r), -1); + }); + }function categoricalAccuracy(e, t) { + return tidy(function () { + return cast$1(equal(argMax(e, -1), argMax(t, -1)), "float32"); + }); + }function binaryCrossentropy$1(e, t) { + return binaryCrossentropy(e, t); + }function sparseCategoricalAccuracy(e, t) { + throw new NotImplementedError(); + }var mse$1 = meanSquaredError$1, + MSE$1 = meanSquaredError$1, + mae$1 = meanAbsoluteError, + MAE$1 = meanAbsoluteError, + mape$1 = meanAbsolutePercentageError, + MAPE$1 = meanAbsolutePercentageError, + categoricalCrossentropy$1 = categoricalCrossentropy, + cosine$1 = cosineProximity, + sparseCategoricalCrossentropy$1 = sparseCategoricalCrossentropy;function get$1(e) { + var t = { binaryAccuracy: binaryAccuracy, categoricalAccuracy: categoricalAccuracy, categoricalCrossentropy: categoricalCrossentropy$1, sparseCategoricalCrossentropy: sparseCategoricalCrossentropy$1, mse: mse$1, MSE: MSE$1, mae: mae$1, MAE: MAE$1, mape: mape$1, MAPE: MAPE$1, cosine: cosine$1 };if ("string" == typeof e && e in t) return t[e];if ("string" != typeof e && null != e) return e;throw new ValueError("Unknown metric " + e); + }function getOptimizer(e) { + var t = { Adagrad: function () { + return train.adagrad(.01); + }, Adadelta: function () { + return train.adadelta(1, .95, epsilon()); + }, Adam: function () { + return train.adam(.001, .9, .999, epsilon()); + }, Adamax: function () { + return train.adamax(.002, .9, .999, epsilon(), 0); + }, RMSProp: function () { + return train.rmsprop(.001, .9, 0, epsilon()); + }, SGD: function () { + return train.sgd(.01); + } };if (t.adagrad = t.Adagrad, t.adadelta = t.Adadelta, t.adam = t.Adam, t.adamax = t.Adamax, t.rmsprop = t.RMSProp, t.sgd = t.SGD, e in t) return t[e]();throw new ValueError("Unknown Optimizer " + e); + }function printSummary(e, t, n, r) { + void 0 === r && (r = console.log);var i, + a = isModelSequentialLike(e), + o = ["Layer (type)", "Output shape", "Param #"];if (a ? (t = t || 65, n = n || [.45, .85, 1]) : (t = t || 98, n = n || [.33, .55, .67, 1]), n[n.length - 1] <= 1 && (n = n.map(function (e) { + return Math.floor(t * e); + })), !a) for (var s in o.push("Receives inputs"), i = [], e.nodesByDepth) i.push.apply(i, e.nodesByDepth[s]);r("_".repeat(t)), printRow(o, n, r), r("=".repeat(t));for (var l, u = e.layers, c = 0; c < u.length; ++c) a ? printLayerSummary(u[c], n, r) : printLayerSummaryWithConnections(u[c], n, i, r), r((c === u.length - 1 ? "=" : "_").repeat(t));e.checkTrainableWeightsConsistency(), l = null != e.collectedTrainableWeights ? countParamsInWeights(e.collectedTrainableWeights) : countParamsInWeights(e.trainableWeights);var p = countParamsInWeights(e.nonTrainableWeights);r("Total params: " + (l + p)), r("Trainable params: " + l), r("Non-trainable params: " + p), r("_".repeat(t)); + }function isModelSequentialLike(e) { + var t = !0, + n = [], + r = [];for (var i in e.nodesByDepth) n.push(e.nodesByDepth[i]);for (var a = 0, o = n; a < o.length; a++) { + var s = o[a];if (s.length > 1 || 1 === s.length && s[0].inboundLayers.length > 1) { + t = !1;break; + }r.push.apply(r, s); + }if (t) for (var l = 0, u = e.layers; l < u.length; l++) { + for (var c = !1, p = 0, h = u[l].inboundNodes; p < h.length; p++) { + var d = h[p];if (-1 !== r.indexOf(d)) { + if (c) { + t = !1;break; + }c = !0; + } + }if (!t) break; + }return t; + }function printRow(e, t, n) { + void 0 === n && (n = console.log);for (var r = "", i = 0; i < e.length; ++i) i > 0 && (r = r.slice(0, r.length - 1) + " "), r = (r += e[i]).slice(0, t[i]), r += " ".repeat(t[i] - r.length);n(r); + }function printLayerSummary(e, t, n) { + var r;try { + r = JSON.stringify(e.outputShape); + } catch (e) { + r = "multiple"; + }printRow([e.name + " (" + e.getClassName() + ")", r, e.countParams().toString()], t, n); + }function printLayerSummaryWithConnections(e, t, n, r) { + var i;try { + i = JSON.stringify(e.outputShape); + } catch (e) { + i = "multiple"; + }for (var a = [], o = 0, s = e.inboundNodes; o < s.length; o++) { + var l = s[o];if (!(null != n && n.length > 0 && -1 === n.indexOf(l))) for (var u = 0; u < l.inboundLayers.length; ++u) { + var c = l.inboundLayers[u].name, + p = l.nodeIndices[u], + h = l.tensorIndices[u];a.push(c + "[" + p + "][" + h + "]"); + } + }var d = e.name, + g = e.getClassName(), + f = 0 === a.length ? "" : a[0];printRow([d + " (" + g + ")", i, e.countParams().toString(), f], t, r);for (u = 1; u < a.length; ++u) printRow(["", "", "", a[u]], t, r); + }function deserialize(e, t) { + return void 0 === t && (t = {}), deserializeKerasObject(e, serialization.SerializationMap.getMap().classNameMap, t, "layer"); + }function isArrayItemInputOrOutputName(e, t, n) { + return ("inboundNodes" === e || "outputLayers" === e || "inputLayers" === e) && 0 === t && "string" == typeof n; + }function convertPythonicToTs(e, t) { + if (null === e) return null;if ("string" == typeof e) return toCamelCase(e);if ("number" == typeof e || "boolean" == typeof e) return e;if (e instanceof Array) { + for (var n = [], r = e.length, i = 0; i < r; ++i) { + var a = e[i];isArrayItemInputOrOutputName(t, i, a) ? n.push(a) : n.push(convertPythonicToTs(a, t)); + }return n; + }for (var o = {}, s = 0, l = Object.keys(e); s < l.length; s++) { + var u = l[s], + c = e[u];if ("name" === u && "string" == typeof c) o[u] = c;else { + var p = toCamelCase(u);o[p] = convertPythonicToTs(c, p); + } + }return o; + }function convertTsToPythonic(e, t) { + if (null === e || void 0 === e) return null;if ("string" == typeof e) return toSnakeCase(e);if ("number" == typeof e || "boolean" == typeof e) return e;if (e instanceof Array) { + for (var n = [], r = e.length, i = 0; i < r; ++i) { + var a = e[i];isArrayItemInputOrOutputName(t, i, a) ? n.push(a) : n.push(convertTsToPythonic(a, t)); + }return n; + }for (var o = {}, s = 0, l = Object.keys(e); s < l.length; s++) { + var u = l[s], + c = e[u], + p = toSnakeCase(u);o[p] = "name" !== u && "className" !== u || "string" != typeof c ? convertTsToPythonic(c, u) : c; + }return o; + }var version$1 = "0.7.2";function preprocessWeightsForLoading(e, t, n, r) { + if (!n.startsWith("2.")) throw new ValueError("Unsupported Keras version in weights being loaded: " + n);return t; + }function loadTensor(e, t, n) { + var r = stringToDType(e);return Tensor.make(t, { values: 0 === t.length ? n : util.flatten(n) }, r); + }function loadWeightsFromJson(e, t, n) { + void 0 === n && (n = !1);for (var r = e.keras_version, i = e.backend, a = t.map(function (e) { + return e.name; + }), o = {}, s = 0, l = t; s < l.length; s++) { + null != (b = l[s]).name && (null == o[b.name] && (o[b.name] = []), o[b.name].push(b)); + }for (var u = e.weights, c = [], p = 0; p < a.length; ++p) { + var h = a[p], + d = u[h];null == d && (d = []);for (var g = [], f = 0; f < d.length; ++f) { + var m = d[f];g.push(new LayerVariable(loadTensor(m.dtype, m.shape, m.value))); + }for (var y = 0, v = o[h]; y < v.length; y++) { + var b, + z = (b = v[y]).weights;if ((g = preprocessWeightsForLoading(b, g, r, i)).length !== z.length) { + if (!n) throw new ValueError("Layer #" + p + ' (named "' + b.name + '") expects ' + z.length + " weight(s), but the saved weights have " + g.length + " element(s).");console.warn("Skipping loading of weights of layer " + b.name + " due to mismatch in number of weights: (" + g.length + " vs " + z.length + ")."); + }for (var w = 0; w < g.length; ++w) !n || util.arraysEqual(z[w].shape, g[w].shape) ? c.push([z[w], g[w].read()]) : console.warn("Skipping loading of weights for layer " + b.name + " due to mismatch in shape (" + z[w].shape + " vs " + g[w].shape + ")"); + } + }batchSetValue(c); + }function loadWeightsFromNamedTensorMap(e, t) { + for (var n = {}, r = 0, i = 0, a = t; i < a.length; i++) for (var o = 0, s = a[i].weights; o < s.length; o++) { + var l = s[o];if (null != n[l.originalName]) throw new ValueError("Duplicate weight name: " + l.originalName);n[l.originalName] = l, r++; + }var u = [];for (var c in e) u.push([n[c], e[c]]), delete n[c];var p = [];for (var h in n) p.push(h);if (p.length > 0) throw new ValueError(p.length + " of " + r + " weights are not set: " + p);batchSetValue(u); + }var Container = function (e) { + function t(n) { + var r = e.call(this, {}) || this;if (r.containerNodes = new Set(), r.name = n.name, null == r.name) { + var i = r.getClassName().toLowerCase();r.name = getUid(i); + }if (r.supportsMasking = !1, r.trainable = !0, r.updatable = !0, Array.isArray(n.inputs) ? r.inputs = n.inputs.slice() : r.inputs = [n.inputs], Array.isArray(n.outputs) ? r.outputs = n.outputs.slice() : r.outputs = [n.outputs], unique(r.inputs).length !== r.inputs.length) throw new ValueError("The list of inputs passed to the model is redundant. All inputs should only appear once. Found: " + r.inputs.map(function (e) { + return e.name; + }));unique(r.outputs).length !== r.outputs.length && console.warn("The list of outputs passed to the model is redundant. All outputs should only appear once. Found: " + r.outputs.map(function (e) { + return e.name; + })), r.inputLayers = [], r.inputLayersNodeIndices = [], r.inputLayersTensorIndices = [], r.outputLayers = [], r.outputLayersNodeIndices = [], r.outputLayersTensorIndices = [], r.layers = [];for (var a = 0, o = r.outputs; a < o.length; a++) { + var s = (E = o[a]).sourceLayer, + l = E.nodeIndex, + u = E.tensorIndex;r.outputLayers.push(s), r.outputLayersNodeIndices.push(l), r.outputLayersTensorIndices.push(u); + }for (var c = 0, p = r.inputs; c < p.length; c++) { + s = (E = p[c]).sourceLayer, l = E.nodeIndex, u = E.tensorIndex;assert$1(0 === l, "input layer has >1 nodes"), assert$1(0 === u, "input layer has >1 tensors"), r.inputLayers.push(s), r.inputLayersNodeIndices.push(l), r.inputLayersTensorIndices.push(u); + }r.inputNames = [], r.outputNames = [], r.feedInputShapes = [], r.feedInputNames = [], r.feedOutputNames = [];for (var h = 0; h < r.inputLayers.length; h++) { + if (!((s = r.inputLayers[h]) instanceof InputLayer)) throw new TypeError("Input layers to a Model must be InputLayer objects. Received inputs: " + n.inputs + ". Input " + h + " (0-based) originates from layer type " + s.getClassName() + ".");r.inputNames.push(s.name), r.feedInputShapes.push(s.batchInputShape), r.feedInputNames.push(s.name); + }for (var d = 0, g = r.outputLayers; d < g.length; d++) { + s = g[d];r.outputNames.push(s.name); + }r.internalInputShapes = r.inputs.map(function (e) { + return e.shape; + }), r.internalOutputShapes = r.outputs.map(function (e) { + return e.shape; + });for (var f = {}, m = {}, y = {}, v = {}, b = {}, z = [], w = function (e, n, i, a, o, s) { + null != a && null != o && null != s || (a = e.sourceLayer, o = e.nodeIndex, s = e.tensorIndex);var l = a.inboundNodes[o];if (-1 !== i.indexOf(l)) throw new RuntimeError("The tensor " + e.name + ' at layer "' + a.name + '" is part of a cycle.');if (-1 === n.indexOf(l)) { + r.containerNodes.add(t.nodeKey(a, o)), (a.id in b) || (b[a.id] = Object.keys(b).length), -1 === i.indexOf(l) && i.push(l);for (var u = l.inboundLayers.length, c = 0; c < u; c++) { + var p = l.inputTensors[c], + h = l.inboundLayers[c], + d = l.nodeIndices[c], + g = l.tensorIndices[c];w(p, n, i, h, d, g); + }for (n.push(l); i.indexOf(l) >= 0;) i.splice(i.indexOf(l), 1);z.push(l); + } + }, S = [], A = [], I = 0, N = r.outputs; I < N.length; I++) { + var E = N[I];w(E, S, A); + }for (var _ = 0, k = z.slice().reverse(); _ < k.length; _++) { + m[(H = k[_]).id] = H, H.id in f || (f[H.id] = 0);var C = f[H.id], + L = null == y[H.outboundLayer.id] ? 0 : y[H.outboundLayer.id];C = Math.max(C, L), y[H.outboundLayer.id] = C, v[H.outboundLayer.id] = H.outboundLayer, f[H.id] = C;for (h = 0; h < H.inboundLayers.length; h++) { + var x = H.inboundLayers[h], + T = (l = H.nodeIndices[h], x.inboundNodes[l]), + R = null == f[T.id] ? 0 : f[T.id];f[T.id] = Math.max(C + 1, R), m[T.id] = T; + } + }var O = {};for (var D in f) { + (C = f[D]) in O || (O[C] = []), O[C].push(m[D]); + }var M = {};for (var P in y) { + (C = y[P]) in M || (M[C] = []), M[C].push(v[P]); + }var F = Object.keys(M).map(function (e) { + return parseInt(e, 10); + }).sort(reverseNumberCompare);r.layers = [];for (var V = 0, B = F; V < B.length; V++) { + var U = M[C = B[V]];U.sort(function (e, t) { + var n = b[e.id], + r = b[t.id];return n < r ? -1 : n > r ? 1 : 0; + });for (var j = 0, W = U; j < W.length; j++) { + s = W[j];r.layers.push(s); + } + }r.layersByDepth = M, F = Object.keys(O).map(function (e) { + return parseInt(e, 10); + }).sort(reverseNumberCompare);for (var $ = r.inputs.slice(), q = [], G = 0, J = F; G < J.length; G++) for (var Z = 0, K = O[C = J[G]]; Z < K.length; Z++) { + var H;if (null != (s = (H = K[Z]).outboundLayer)) { + for (var Y = 0, X = H.inputTensors; Y < X.length; Y++) { + E = X[Y];if (-1 === $.indexOf(E)) throw new RuntimeError("Graph disconnected: cannot obtain value for tensor " + E + ' at layer "' + s.name + '". The following previous layers were accessed without issue: ' + q); + }for (var Q = 0, ee = H.outputTensors; Q < ee.length; Q++) { + E = ee[Q];$.push(E); + }q.push(s.name); + } + }r.nodesByDepth = O;for (var te = r.layers.map(function (e) { + return e.name; + }), ne = function (e) { + var t = te.filter(function (t) { + return t === e; + }).length;if (1 !== t) throw new RuntimeError('The name "' + e + '" is used ' + t + " times in the model. All layer names should be unique. Layer names: " + JSON.stringify(te)); + }, re = 0, ie = te; re < ie.length; re++) { + ne(ie[re]); + }return r.outboundNodes = [], r.inboundNodes = [], new Node({ outboundLayer: r, inboundLayers: [], nodeIndices: [], tensorIndices: [], inputTensors: r.inputs, outputTensors: r.outputs, inputMasks: r.inputs.map(function (e) { + return null; + }), outputMasks: r.outputs.map(function (e) { + return null; + }), inputShapes: r.inputs.map(function (e) { + return e.shape; + }), outputShapes: r.outputs.map(function (e) { + return e.shape; + }) }), r.built = !0, r; + }return __extends$1(t, e), Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + if (this._trainableWeights.length > 0) throw new ValueError("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if (!this.trainable) return [];for (var e = [], t = 0, n = this.layers; t < n.length; t++) { + var r = n[t];e = e.concat(r.trainableWeights); + }return e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + for (var e = [], t = 0, n = this.layers; t < n.length; t++) { + var r = n[t];e.push.apply(e, r.nonTrainableWeights); + }if (!this.trainable) { + for (var i = [], a = 0, o = this.layers; a < o.length; a++) { + r = o[a];i.push.apply(i, r.trainableWeights); + }return i.concat(e); + }return e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "weights", { get: function () { + return this.trainableWeights.concat(this.nonTrainableWeights); + }, enumerable: !0, configurable: !0 }), t.prototype.loadWeights = function (e, t, n) { + void 0 === t && (t = !1), void 0 === n && (n = !1), n ? loadWeightsFromNamedTensorMap(e, this.layers) : loadWeightsFromJson(e, this.layers, t); + }, t.prototype.updatedConfig = function () { + var e = this.getConfig();return { className: this.getClassName(), config: e, kerasVersion: "tfjs-layers " + version$1, backend: "TensorFlow.js" }; + }, t.prototype.toJSON = function (e, t) { + void 0 === t && (t = !0);var n = convertTsToPythonic(this.updatedConfig());return t ? JSON.stringify(n) : n; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var r;return e = toList(e), r = "mask" in t ? toList(t.mask) : pyListRepeat(null, e.length), n.runInternalGraph(e, r)[0]; + }); + }, t.prototype.computeMask = function (e, t) { + var n = this;return tidy(function () { + var r;return e = toList(e), r = null == t ? pyListRepeat(null, e.length) : toList(t), n.runInternalGraph(e, r)[1]; + }); + }, t.prototype.computeOutputShape = function (e) { + var t = normalizeShapeList(e);if (t.length !== this.inputLayers.length) throw new ValueError("Invalid inputShape argument " + e + ": model has " + this.inputLayers.length + " tensor inputs.");for (var n = {}, r = 0; r < t.length; r++) { + var i = this.inputLayers[r], + a = t[r];n[A = i.name + "_0_0"] = a; + }var o = Object.keys(this.nodesByDepth).map(function (e) { + return parseInt(e, 10); + }).sort(reverseNumberCompare);if (o.length > 1) for (var s = 0, l = o; s < l.length; s++) for (var u = l[s], c = 0, p = this.nodesByDepth[u]; c < p.length; c++) { + var h = p[c];i = h.outboundLayer;if (-1 === this.inputLayers.map(function (e) { + return e.id; + }).indexOf(i.id)) { + for (var d = [], g = 0; g < h.inboundLayers.length; g++) { + var f = h.inboundLayers[g], + m = h.nodeIndices[g], + y = h.tensorIndices[g], + v = n[A = f.name + "_" + m + "_" + y];d.push(v); + }var b = normalizeShapeList(i.computeOutputShape(singletonOrArray(d))), + z = i.inboundNodes.indexOf(h);for (g = 0; g < b.length; g++) { + n[A = i.name + "_" + z + "_" + g] = b[g]; + } + } + }var w = [], + S = [];for (r = 0; r < this.outputLayers.length; r++) { + i = this.outputLayers[r], z = this.outputLayersNodeIndices[r], y = this.outputLayersTensorIndices[r];var A = i.name + "_" + z + "_" + y;S.push(A); + }for (r = 0; r < S.length; r++) { + var I = S[r];assert$1(I in n), w.push(n[I]); + }return singletonOrArray(w); + }, t.prototype.runInternalGraph = function (e, t) { + null == t && (t = pyListRepeat(null, e.length));for (var n = {}, r = 0; r < this.inputs.length; ++r) { + var i = this.inputs[r], + a = e[r], + o = t[r];n[i.id] = [a, o]; + }for (var s = 0, l = Object.keys(this.nodesByDepth).map(function (e) { + return parseInt(e, 10); + }).sort(reverseNumberCompare); s < l.length; s++) for (var u = l[s], c = 0, p = this.nodesByDepth[u]; c < p.length; c++) { + for (var h = p[c], d = h.outboundLayer, g = h.inputTensors, f = h.outputTensors, m = new Array(), y = 0, v = g; y < v.length; y++) { + (i = v[y]).id in n && m.push(n[i.id]); + }if (m.length === g.length) { + var b = {}, + z = void 0, + w = void 0, + S = void 0, + A = void 0;if (null != h.callArgs && (b = h.callArgs), 1 === m.length) { + var I = m[0], + N = I[0], + E = I[1];null == b.mask && (b.mask = E), S = toList(d.call(N, b)), A = toList(d.computeMask(N, E)), z = [N], w = [E]; + } else z = m.map(function (e) { + return e[0]; + }), w = m.map(function (e) { + return e[1]; + }), null == b.mask && (b.mask = w), S = toList(d.call(z, b)), A = toList(d.computeMask(z, w));if (d.activityRegularizer) throw new NotImplementedError("Model invocation with concrete Tensor value(s) in the presence of activity regularizer(s) is not supported yet.");for (r = 0; r < f.length; ++r) { + i = f[r], a = S[r], o = A[r];n[i.id] = [a, o]; + } + } + }for (var _ = [], k = [], C = [], L = 0, x = this.outputs; L < x.length; L++) { + assert$1((i = x[L]).id in n, "Could not compute output " + i.name + " : " + i.id);var T = n[i.id], + R = T[0];o = T[1];C.push(R.shape), _.push(R), k.push(o); + }return [_, k, C]; + }, t.prototype.buildNodeConversionMap = function (e) { + for (var n, r = {}, i = 0, a = this.layers; i < a.length; i++) { + var o = a[i];n = o instanceof t ? 1 : 0;for (var s = 0; s < o.inboundNodes.length; s++) { + var l = t.nodeKey(o, s);l in this.containerNodes && (r[l] = n, n += 1); + } + }return r; + }, t.prototype.getLayer = function (e, t) { + if (null != t) { + if (this.layers.length <= t) throw new ValueError("Was asked to retrieve layer at index " + t + ", but model only has " + this.layers.length + " layer(s).");return this.layers[t]; + }if (null == e) throw new ValueError("Provide either a layer name or layer index");for (var n = 0, r = this.layers; n < r.length; n++) { + var i = r[n];if (i.name === e) return i; + }throw new ValueError("No such layer: " + e); + }, t.prototype.calculateLosses = function () { + var e = this;return tidy(function () { + for (var n = [], r = 0, i = e.layers; r < i.length; r++) for (var a = i[r], o = 0; o < a.inboundNodes.length; ++o) { + var s = t.nodeKey(a, o);e.containerNodes.has(s) && n.push.apply(n, a.calculateLosses()); + }return n; + }); + }, t.prototype.getConfig = function () { + for (var e = { name: this.name }, n = this.buildNodeConversionMap(this.layers), r = [], i = 0, a = this.layers; i < a.length; i++) { + for (var o = (b = a[i]).getClassName(), s = b.getConfig(), l = [], u = 0; u < b.inboundNodes.length; u++) { + var c = b.inboundNodes[u], + p = t.nodeKey(b, u), + h = {};if (this.containerNodes.has(p)) { + if (c.callArgs) try { + JSON.stringify(c.callArgs), h = c.callArgs; + } catch (e) { + console.warn("Layer " + b.name + " was passed non-serializable keyword arguments: " + c.callArgs + ". They will not be included in the serialized model (and thus will be missing at deserialization time)."), h = {}; + }if (c.inboundLayers.length > 0) { + for (var d = [], g = 0; g < c.inboundLayers.length; g++) { + var f = c.inboundLayers[g], + m = c.nodeIndices[g], + y = c.tensorIndices[g];null !== (w = n[t.nodeKey(f, m)]) && void 0 !== w || (w = 0), d.push([f.name, w, y, h]); + }l.push(d); + } + } + }r.push({ name: b.name, className: o, config: s, inboundNodes: l }); + }e.layers = r;var v = [];for (g = 0; g < this.inputLayers.length; g++) { + var b = this.inputLayers[g];m = this.inputLayersNodeIndices[g], p = t.nodeKey(b, m);if (this.containerNodes.has(p)) { + null !== (w = n[p]) && void 0 !== w || (w = 0);y = this.inputLayersTensorIndices[g];v.push([b.name, w, y]); + } + }e.inputLayers = v;var z = [];for (g = 0; g < this.outputLayers.length; g++) { + b = this.outputLayers[g], m = this.outputLayersNodeIndices[g], p = t.nodeKey(b, m);if (this.containerNodes.has(p)) { + var w;null !== (w = n[p]) && void 0 !== w || (w = 0);y = this.outputLayersTensorIndices[g];z.push([b.name, w, y]); + } + }return e.outputLayers = z, e; + }, t.fromConfig = function (e, t) { + var n = {}, + r = {};function i(e, t) { + e.name in r ? r[e.name].push(t) : r[e.name] = [t]; + }function a(e, t) { + for (var r, a = [], o = 0, s = t; o < s.length; o++) { + var l = s[o], + u = l[0], + c = l[1], + p = l[2];if (3 === l.length) r = {};else { + if (4 !== l.length) throw new ValueError("Improperly formatted model config for layer " + JSON.stringify(e) + ": " + JSON.stringify(l));r = l[3]; + }if (!(u in n)) return void i(e, t);var h = n[u];if (h.inboundNodes.length <= c) return void i(e, t);var d = h.inboundNodes[c];a.push(d.outputTensors[p]); + }a.length > 0 && e.apply(singletonOrArray(a), r); + }function o(e) { + var r = e.name, + a = deserialize(e, null != t.customObjects ? t.customObjects : {});n[r] = a;for (var o = 0, s = e.inboundNodes; o < s.length; o++) { + var l = s[o];if (!(l instanceof Array)) throw new ValueError("Corrupted configuration, expected array for nodeData: " + l);i(a, l); + } + }for (var s = t.name, l = t.layers, u = 0, c = l; u < c.length; u++) { + o(d = c[u]); + }for (; !isObjectEmpty(r);) for (var p = 0, h = l; p < h.length; p++) { + var d = h[p];if ((E = n[d.name]).name in r) { + for (var g = 0, f = r[E.name]; g < f.length; g++) { + a(E, f[g]); + }delete r[E.name]; + } + }for (var m = [], y = [], v = 0, b = t.inputLayers; v < b.length; v++) { + var z = (d = b[v])[0], + w = d[1], + S = d[2];assert$1(z in n);var A = (E = n[z]).inboundNodes[w].outputTensors;m.push(A[S]); + }for (var I = 0, N = t.outputLayers; I < N.length; I++) { + z = (d = N[I])[0], w = d[1], S = d[2];assert$1(z in n);var E;A = (E = n[z]).inboundNodes[w].outputTensors;y.push(A[S]); + }return new e({ inputs: m, outputs: y, name: s }); + }, Object.defineProperty(t.prototype, "stateful", { get: function () { + if (this._stateful) throw new ValueError("Container instance unexpectedly has _stateful = true. The statefulness of a Container is determined by the Layers it contains. Its _stateful property must remain the default false.");for (var e = 0, t = this.layers; e < t.length; e++) { + if (t[e].stateful) return !0; + }return !1; + }, enumerable: !0, configurable: !0 }), t; + }(Layer);function assertFeedCompatibility(e, t) { + if (null != e.shape) { + if (e.shape.length !== t.shape.length) throw new ValueError("The rank of feed (" + t.shape.length + ") does not match the rank of the key (" + e.shape.length + ").");for (var n = 0; n < e.shape.length; ++n) if (null != e.shape[n] && e.shape[n] !== t.shape[n]) throw new ValueError("The " + n + "-th dimension of the feed (" + t.shape[n] + ") is incompatible with that of the key (" + e.shape[n] + ")."); + }if (null == e.dtype || e.dtype === t.dtype) return t;try { + return cast(t, e.dtype); + } catch (n) { + throw new ValueError("The dtype of the feed (" + t.dtype + ") can not be cast to the dtype of the key '" + e.name + "' (" + e.dtype + ")."); + } + }var ModelLoggingVerbosity, + FeedDict = function () { + function e(t) { + if (this.id2Value = {}, t instanceof e) for (var n in t.id2Value) this.id2Value[n] = t.id2Value[n];else { + if (null == t) return;for (var r = 0, i = t; r < i.length; r++) { + var a = i[r];this.add(a.key, a.value); + } + } + }return e.prototype.add = function (e, t) { + if (null != this.id2Value[e.id]) throw new ValueError("Duplicate key: name=" + e.name + ", id=" + e.id);return this.id2Value[e.id] = assertFeedCompatibility(e, t), this; + }, e.prototype.addFeed = function (e) { + this.add(e.key, e.value); + }, e.prototype.hasKey = function (e) { + return null != this.id2Value[e.id]; + }, e.prototype.getValue = function (e) { + if (null == this.id2Value[e.id]) throw new ValueError("Nonexistent key: " + JSON.stringify(e));return this.id2Value[e.id]; + }, e; + }();function execute(e, t, n) { + for (var r = Array.isArray(e), i = r ? e : [e], a = [], o = new FeedDict(t), s = 0, l = i; s < l.length; s++) { + var u = l[s];a.push(executeInternal(u, o, n)); + }return r ? a : a[0]; + }function executeInternal(e, t, n) { + if (t.hasKey(e)) return t.getValue(e);if (e.sourceLayer instanceof InputLayer) throw new ValueError("Missing a feed value for SymbolicTensor from InputLayer '" + InputLayer.name + "'");for (var r = [], i = 0, a = e.inputs; i < a.length; i++) { + var o = executeInternal(a[i], t, n);r.push(o); + }var s = e.sourceLayer.apply(r, n);Array.isArray(s) || (s = [s]);for (var l = getNodeOutputs(e), u = Array.isArray(l) ? l : [l], c = 0; c < u.length; ++c) t.add(u[c], s[c]);return 1 === s.length ? s[0] : s[e.outputTensorIndex]; + }function getNodeOutputs(e) { + var t;if (1 === e.sourceLayer.inboundNodes.length) t = e.sourceLayer.output;else { + for (var n = null, r = 0; r < e.sourceLayer.inboundNodes.length; ++r) for (var i = 0, a = e.sourceLayer.inboundNodes[r].outputTensors; i < a.length; i++) { + if (a[i].id === e.id) { + n = r;break; + } + }t = e.sourceLayer.getOutputAt(n); + }return t; + }function isDataTensor(e) { + return e instanceof Tensor; + }function isDataArray(e) { + return Array.isArray(e); + }function isDataDict(e) { + return !isDataTensor(e) && !isDataArray(e); + }function standardizeInputData(e, t, n, r, i) { + if (void 0 === r && (r = !0), void 0 === i && (i = ""), null == t || 0 === t.length) { + if (null != e) { + var a = !1;if (isDataArray(e) && e.length > 0) a = !0;else if (isDataDict(e)) { + for (var o in e) if (e.hasOwnProperty(o)) { + a = !0;break; + } + } else a = !0;if (a) throw new ValueError("Error when checking model " + i + " expected no data, but got " + e); + }return []; + }if (null == e) return t.map(function (e) { + return null; + });var s;if (isDataDict(e)) { + e = e, s = [];for (var l = 0, u = t; l < u.length; l++) { + var c = u[l];if (null == e[c]) throw new ValueError('No data provided for "' + c + '". Need data for each key in: ' + t);s.push(e[c]); + } + } else if (isDataArray(e)) { + if ((e = e).length !== t.length) throw new ValueError("Error when checking model " + i + ": the Array of Tensors that you are passing to your model is not the size the model expected. Expected to see " + t.length + " Tensor(s), but instead got the following list of Tensor(s): " + e);s = e; + } else { + if (e = e, t.length > 1) throw new ValueError("The model " + i + " expects " + t.length + " Tensor(s), but only received one Tensor. Found: Tensor with shape " + e.shape);s = [e]; + }for (var p = 0; p < t.length; ++p) { + 1 === (h = s[p]).shape.length && (s[p] = expandDims$1(h, 1)); + }if (null != n) for (p = 0; p < t.length; ++p) if (null != n[p]) { + var h;if ((h = s[p]).shape.length !== n[p].length) throw new ValueError("Error when checking " + i + ": expected " + t[p] + " to have " + n[p].length + " dimension(s). but got array with shape " + h.shape);for (var d = 0; d < n[p].length; ++d) if (0 !== d || r) { + var g = h.shape[d], + f = n[p][d];if (null != f && f >= 0 && g !== f) throw new ValueError("Error when checking " + i + ": expected " + t[p] + " to have shape [" + n[p] + "], but got array with shape [" + h.shape + "]."); + } + }return s; + }function checkArrayLengths(e, t, n) { + var r = unique(e.map(function (e) { + return e.shape[0]; + }));r.sort();var i = unique(t.map(function (e) { + return e.shape[0]; + }));if (i.sort(), r.length > 1) throw new ValueError("All input Tensors (x) should have the same number of samples. Got array shapes: " + JSON.stringify(e.map(function (e) { + return e.shape; + })));if (i.length > 1) throw new ValueError("All target Tensors (y) should have the same number of samples. Got array shapes: " + JSON.stringify(t.map(function (e) { + return e.shape; + })));if (r.length > 0 && i.length > 0 && !util.arraysEqual(r, i)) throw new ValueError("Input Tensors should have the same number of samples as target Tensors. Found " + r[0] + " input sample(s) and " + i[0] + " target sample(s)."); + }function checkLossAndTargetCompatibility(e, t, n) { + for (var r = [meanSquaredError$1, binaryCrossentropy, categoricalCrossentropy], i = 0; i < e.length; ++i) { + var a = e[i], + o = t[i], + s = n[i];if (null != o) { + if (o === categoricalCrossentropy && 1 === a.shape[a.shape.length - 1]) throw new ValueError("You are passing a target array of shape " + a.shape + " while using a loss 'categorical_crossentropy'. 'categorical_crossentropy'expects targets to be binary matrices (1s and 0s) of shape [samples, classes].");if (-1 !== r.indexOf(o)) for (var l = a.shape.slice(1), u = s.slice(1), c = 0; c < l.length; ++c) { + var p = l[c], + h = u[c];if (null != h && p !== h) throw new ValueError("A target Tensor with shape " + a.shape + " was passed for an output of shape " + s + ", while using a loss function that expects targets to have the same shape as the output."); + } + } + } + }function makeBatches(e, t) { + for (var n = [], r = 0, i = null; r < e;) (i = r + t) >= e && (i = e), n.push([r, i]), r = i;return n; + }function sliceArrays(e, t, n) { + return null == e ? [null] : Array.isArray(e) ? e.map(function (e) { + return sliceAlongFirstAxis(e, t, n - t); + }) : sliceAlongFirstAxis(e, t, n - t); + }function sliceArraysByIndices(e, t) { + return tidy(function () { + return null == e ? null : Array.isArray(e) ? e.map(function (e) { + return sliceArraysByIndices(e, t); + }) : gather$1(e, "int32" === t.dtype ? t : t.toInt()); + }); + }function checkInputData(e, t, n, r, i) { + var a;if (void 0 === r && (r = !0), void 0 === i && (i = ""), Array.isArray(e)) { + if (e.length !== t.length) throw new ValueError("Error when checking model " + i + ": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see " + t.length + " Tensor(s), but instead got " + e.length + " Tensors(s).");a = e; + } else { + if (t.length > 1) throw new ValueError("The model expects " + t.length + " " + i + " Tensors, but only received one Tensor. Found: array with shape " + JSON.stringify(e.shape) + ".");a = [e]; + }if (null != n) for (var o = 0; o < t.length; ++o) if (null != n[o]) { + var s = a[o];if (s.shape.length !== n[o].length) throw new ValueError("Error when checking " + i + ": expected " + t[o] + " to have " + n[o].length + " dimension(s), but got array with shape " + JSON.stringify(s.shape));for (var l = 0; l < n[o].length; ++l) if (0 !== l || r) { + var u = s.shape[l], + c = n[o][l];if (null != c && c !== u) throw new ValueError("Error when checking " + i + ": expected " + t[o] + " to have shape " + JSON.stringify(n[o]) + " but got array with shape " + JSON.stringify(s.shape) + "."); + } + } + }function collectMetrics(e, t) { + if (null == e || Array.isArray(e) && 0 === e.length) return t.map(function (e) { + return []; + });if (Array.isArray(e)) return t.map(function (t) { + return e; + });if (null != e) { + for (var n = [], r = 0, i = t; r < i.length; r++) { + var a = i[r], + o = e.hasOwnProperty(a) ? e[a] : [];Array.isArray(o) || (o = [o]), n.push(o); + }return n; + }throw new TypeError("Type of metrics argument not understood. Expected an Array or Object, found: " + e); + }!function (e) { + e[e.SILENT = 0] = "SILENT", e[e.VERBOSE = 1] = "VERBOSE"; + }(ModelLoggingVerbosity || (ModelLoggingVerbosity = {}));var Model = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.summary = function (e, t, n) { + if (void 0 === n && (n = console.log), !this.built) throw new ValueError("This model has never been called, thus its weights have not been created yet. So no summary can be displayed. Build the model first (e.g., by calling it on some test data).");printSummary(this, e, t, n); + }, t.prototype.compile = function (e) { + var t = this;if (null == e.loss && (e.loss = []), this.loss = e.loss, "string" == typeof e.optimizer) this.optimizer = getOptimizer(e.optimizer);else { + if (!(e.optimizer instanceof Optimizer)) throw new ValueError("User-defined optimizer must be an instance of tf.Optimizer.");this.optimizer = e.optimizer; + }var n = [];if (Array.isArray(e.loss) || "string" == typeof e.loss || "function" == typeof e.loss) { + if (Array.isArray(e.loss)) { + if (e.loss.length !== this.outputs.length) throw new ValueError("When passing an Array as loss, it should have one entry per model output. The model has " + this.outputs.length + " output(s), but you passed loss=" + e.loss + ".");var r = e.loss;n = r.map(function (e) { + return get(e); + }); + } else { + var i = get(e.loss);this.outputs.map(function (e) { + n.push(i); + }); + } + } else { + for (var a in e.loss = e.loss, e.loss) if (-1 === this.outputNames.indexOf(a)) throw new ValueError('Unknown entry in loss dictionary: "' + a + '". Only expect the following keys: ' + this.outputNames);for (var o in this.outputNames) null == e.loss[o] && console.warn('Output "' + o + '" is missing from loss dictionary. We assume this was done on purpose, and we will not be expecting data to be passed to ' + o + " during training"), n.push(get(e.loss[o])); + }this.lossFunctions = n, this.feedOutputNames = [], this.feedOutputShapes = [], this.feedLossFns = [];for (var s = 0; s < this.outputs.length; ++s) { + var l = this.internalOutputShapes[s], + u = this.outputNames[s];this.feedOutputNames.push(u), this.feedOutputShapes.push(l), this.feedLossFns.push(this.lossFunctions[s]); + }var c = [];this.metrics = e.metrics, this.metricsNames = ["loss"], this.metricsTensors = [], nameScope("loss", function () { + for (var e = 0; e < t.outputs.length; ++e) if (-1 === c.indexOf(e)) { + var n = t.lossFunctions[e];t.outputs.length > 1 && (t.metricsTensors.push([n, e]), t.metricsNames.push(t.outputNames[e] + "_loss")); + } + });var p = collectMetrics(e.metrics, this.outputNames);nameScope("metric", function () { + for (var e = function (e) { + if (-1 !== c.indexOf(e)) return "continue";!function (n) { + for (var r, i, a, o = function (n) { + if (-1 !== ["accuracy", "acc", "crossentropy", "ce"].indexOf(n)) { + var o = t.internalOutputShapes[e];1 === o[o.length - 1] || t.lossFunctions[e] === binaryCrossentropy ? -1 !== ["accuracy", "acc"].indexOf(n) ? i = binaryAccuracy : -1 !== ["crossentropy", "ce"].indexOf(n) && (i = binaryCrossentropy$1) : t.lossFunctions[e] === sparseCategoricalCrossentropy ? -1 !== ["accuracy", "acc"].indexOf(n) ? i = sparseCategoricalAccuracy : -1 !== ["crossentropy", "ce"].indexOf(n) && (i = sparseCategoricalCrossentropy$1) : -1 !== ["accuracy", "acc"].indexOf(n) ? i = categoricalAccuracy : -1 !== ["crossentropy", "ce"].indexOf(n) && (i = categoricalCrossentropy$1);var s = void 0;-1 !== ["accuracy", "acc"].indexOf(n) ? s = "acc" : -1 !== ["crossentropy", "ce"].indexOf(n) && (s = "ce"), a = i, r = "" + s; + } else { + var l = get$1(n);a = l, r = "" + n; + }var u;nameScope(r, function () { + u = a; + }), function (e, n, r) { + t.outputNames.length > 1 && (n = t.outputNames[e] + "_" + n), t.metricsNames.push(n), t.metricsTensors.push([r, e]); + }(e, r, u); + }, s = 0, l = n; s < l.length; s++) o(l[s]); + }(p[e]); + }, n = 0; n < t.outputs.length; ++n) e(n); + }), this.collectedTrainableWeights = this.trainableWeights; + }, t.prototype.checkTrainableWeightsConsistency = function () { + null != this.collectedTrainableWeights && this.trainableWeights.length !== this.collectedTrainableWeights.length && console.warn("Discrepancy between trainableweights and collected trainable weights. Did you set `model.trainable` without calling `model.compile()` afterwards?"); + }, t.prototype.evaluate = function (e, t, n) { + void 0 === n && (n = {});var r = null == n.batchSize ? 32 : n.batchSize, + i = this.standardizeUserData(e, t, !0, r), + a = i[0].concat(i[1]);this.makeTestFunction();var o = this.testFunction;return singletonOrArray(this.testLoop(o, a, r, n.verbose, n.steps)); + }, t.prototype.checkNumSamples = function (e, t, n, r) { + var i;if (void 0 === r && (r = "steps"), null != n) { + if (i = null, null != t) throw new ValueError("If " + r + " is set, batchSize must be null or undefined.Got batchSize = " + t); + } else { + if (null == e) throw new ValueError("Either the input data should have a defined shape, or " + r + " shoud be specified.");i = Array.isArray(e) ? e[0].shape[0] : e.shape[0]; + }return i; + }, t.prototype.execute = function (e, t) { + if (Array.isArray(t) && 0 === t.length) throw new ValueError("`outputs` is an empty Array, which is not allowed.");var n = Array.isArray(t), + r = n ? t : [t], + i = this.retrieveSymbolicTensors(r), + a = new FeedDict();if (e instanceof Tensor && (e = [e]), Array.isArray(e)) { + if (e.length !== this.inputs.length) throw new ValueError("The number of inputs provided (" + e.length + ") does not match the number of inputs of this model (" + this.inputs.length + ").");for (var o = 0; o < this.inputs.length; ++o) a.add(this.inputs[o], e[o]); + } else for (var s = 0, l = this.inputs; s < l.length; s++) { + var u = l[s], + c = e[u.name];if (null == c) throw new ValueError("No value is provided for the model's input " + u.name);a.add(u, c); + }var p = execute(i, a);return n ? p : p[0]; + }, t.prototype.retrieveSymbolicTensors = function (e) { + for (var t = pyListRepeat(null, e.length), n = e.length, r = 0, i = this.layers; r < i.length; r++) { + for (var a = i[r], o = Array.isArray(a.output) ? a.output : [a.output], s = o.map(function (e) { + return e.name; + }), l = 0; l < e.length; ++l) { + var u = s.indexOf(e[l]);if (-1 !== u && (t[l] = o[u], n--), 0 === n) break; + }if (0 === n) break; + }if (n > 0) { + var c = [];throw t.forEach(function (t, n) { + null == t && c.push(e[n]); + }), new ValueError("Cannot find SymbolicTensors for output name(s): " + JSON.stringify(c)); + }return t; + }, t.prototype.predictLoop = function (e, t, n) { + var r = this;return void 0 === t && (t = 32), void 0 === n && (n = !1), tidy(function () { + var i = r.checkNumSamples(e);if (n) throw new NotImplementedError("Verbose predictLoop() is not implemented yet.");for (var a = makeBatches(i, t), o = [], s = function (t) { + var n = tidy(function () { + var n = a[t][0], + i = a[t][1], + o = sliceArrays(e, n, i), + s = [];if (Array.isArray(o)) for (var l = 0; l < o.length; ++l) s.push({ key: r.inputs[l], value: o[l] });else s.push({ key: r.inputs[0], value: o });var u = new FeedDict(s);return execute(r.outputs, u); + });if (0 === t) for (var i = 0, s = n; i < s.length; i++) { + var l = s[i];o.push(l); + } else for (var u = 0; u < n.length; ++u) o[u] = concatAlongFirstAxis(o[u], n[u]); + }, l = 0; l < a.length; ++l) s(l);return singletonOrArray(o); + }); + }, t.prototype.predict = function (e, t) { + void 0 === t && (t = {}), checkInputData(e, this.inputNames, this.feedInputShapes, !1);var n = null == t.batchSize ? 32 : t.batchSize;return this.predictLoop(e, n); + }, t.prototype.predictOnBatch = function (e) { + return checkInputData(e, this.inputNames, this.feedInputShapes, !0), this.predictLoop(e, e.shape[0]); + }, t.prototype.standardizeUserData = function (e, t, n, r) { + if (void 0 === n && (n = !0), null == this.optimizer) throw new RuntimeError("You must compile a model before training/testing. Use Model.compile(modelCompileConfig).");for (var i = [], a = 0; a < this.feedOutputShapes.length; ++a) { + var o = this.feedOutputShapes[a];this.feedLossFns[a] === sparseCategoricalCrossentropy ? i.push(o.slice(0, o.length - 1).concat([1])) : i.push(o); + }if (checkArrayLengths(e = standardizeInputData(e, this.feedInputNames, this.feedInputShapes, !1, "input"), t = standardizeInputData(t, this.feedOutputNames, i, !1, "target"), null), checkLossAndTargetCompatibility(t, this.feedLossFns, this.feedOutputShapes), this.stateful && null != r && r > 0 && e[0].shape[0] % r != 0) throw new ValueError("In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size " + r + ". Found: " + e[0].shape[0] + " sample(s).");return [e, t, null]; + }, t.prototype.fitLoop = function (e, t, n, r, i, a, o, s, l, u, c, p, h, d) { + return __awaiter$1(this, void 0, void 0, function () { + var g, + f, + m, + y, + v, + b, + z, + w = this;return __generator$1(this, function (S) { + switch (S.label) {case 0: + if (null == r && (r = 32), null == i && (i = 1), null == u && (u = !0), null == p && (p = 0), g = !1, null != s && null != l && (g = !0), null != d && (g = !0, null == h)) throw new ValueError("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");if (null != (f = this.checkNumSamples(t, r, h, "steps_per_epoch")) && (m = range$1(0, f)), this.history = new History(), o = (o = null == o ? [new BaseLogger()] : [new BaseLogger()].concat(o)).concat([this.history]), a > 0) throw new NotImplementedError("Verbose mode is not implemented yet.");return (y = new CallbackList(o)).setModel(this), y.setParams({ epochs: i, initialEpoch: p, steps: h, verbose: a, doValidation: g, metrics: c }), [4, y.onTrainBegin()];case 1: + S.sent(), this.stopTraining = !1, v = function (i) { + var a, o, c, p, d;return __generator$1(this, function (v) { + switch (v.label) {case 0: + return [4, y.onEpochBegin(i)];case 1: + if (v.sent(), a = {}, null == h) return [3, 2];throw new NotImplementedError("stepsPerEpoch mode is not implemented yet.");case 2: + if ("batch" === u) throw new NotImplementedError("batch shuffling is not implemneted yet");u && util.shuffle(m), o = tensor1d(m), c = makeBatches(f, r), p = function (i) { + var u;return __generator$1(this, function (p) { + switch (p.label) {case 0: + return u = {}, [4, y.onBatchBegin(i, u)];case 1: + return p.sent(), tidy(function () { + var p = c[i][0], + h = c[i][1], + d = sliceAlongFirstAxis(o, p, h - p);u.batch = i, u.size = h - p;for (var f = sliceArraysByIndices(t, d), m = e(f), y = 0; y < n.length; ++y) { + var v = n[y], + b = m[y];u[v] = b, keep(b); + }if (i === c.length - 1 && g) { + var z = w.testLoop(s, l, r);for (y = 0; y < n.length; ++y) { + v = n[y], b = z[y];keep(b), a["val_" + v] = b; + } + } + }), [4, y.onBatchEnd(i, u)];case 2: + return p.sent(), disposeTensorsInLogs(u), b.stopTraining ? [2, "break"] : [2];} + }); + }, d = 0, v.label = 3;case 3: + return d < c.length ? [5, p(d)] : [3, 6];case 4: + if ("break" === v.sent()) return [3, 6];v.label = 5;case 5: + return ++d, [3, 3];case 6: + o.dispose(), v.label = 7;case 7: + return [4, y.onEpochEnd(i, a)];case 8: + return v.sent(), b.stopTraining ? [2, "break"] : [2];} + }); + }, b = this, z = p, S.label = 2;case 2: + return z < i ? [5, v(z)] : [3, 5];case 3: + if ("break" === S.sent()) return [3, 5];S.label = 4;case 4: + return ++z, [3, 2];case 5: + return [4, y.onTrainEnd()];case 6: + return S.sent(), [4, this.history.syncData()];case 7: + return S.sent(), [2, this.history];} + }); + }); + }, t.prototype.testLoop = function (e, t, n, r, i) { + var a = this;return void 0 === r && (r = 0), tidy(function () { + var o = a.checkNumSamples(t, n, i, "steps"), + s = [];if (1 === r) throw new NotImplementedError("Verbose mode is not implemented yet.");if (null != i) throw new NotImplementedError("steps mode in testLoop() is not implemented yet");for (var l = makeBatches(o, n), u = tensor1d(range$1(0, o)), c = 0; c < l.length; ++c) { + var p = l[c][0], + h = l[c][1], + d = sliceAlongFirstAxis(u, p, h - p), + g = sliceArraysByIndices(t, d), + f = e(g);if (0 === c) for (var m = 0; m < f.length; ++m) s.push(getScalar(0));for (m = 0; m < f.length; ++m) { + var y = f[m];s[m] = add(s[m], mul(getScalar(h - p), y)); + } + }for (m = 0; m < s.length; ++m) s[m] = div(s[m], getScalar(o));return s; + }); + }, t.prototype.getDedupedMetricsNames = function () { + for (var e = this.metricsNames, t = [], n = 0; n < e.length; ++n) { + var r = e[n], + i = r;if (count(e, r) > 1) i += "_" + count(e.slice(0, n), r);t.push(i); + }return t; + }, t.prototype.makeTestFunction = function () { + var e = this;this.testFunction = function (t) { + return tidy(function () { + for (var n, r = [], i = t.slice(0, e.inputs.length), a = t.slice(e.inputs.length, e.inputs.length + e.outputs.length), o = [], s = 0; s < e.inputs.length; ++s) o.push({ key: e.inputs[s], value: i[s] });var l = new FeedDict(o), + u = execute(e.outputs, l);for (s = 0; s < e.lossFunctions.length; ++s) { + var c = e.lossFunctions[s], + p = mean(c(a[s], u[s]));n = 0 === s ? p : add(n, p), r.push(n); + }for (s = 0; s < e.metricsTensors.length; ++s) { + var h = e.metricsTensors[s][0], + d = e.metricsTensors[s][1], + g = mean(h(a[d], u[d]));r.push(g); + }return r; + }); + }; + }, t.prototype.fit = function (e, t, n) { + return void 0 === n && (n = {}), __awaiter$1(this, void 0, void 0, function () { + var r, + i, + a, + o, + s, + l, + u, + c, + p, + h, + d, + g, + f, + m, + y, + v, + b, + z, + w, + S = this;return __generator$1(this, function (A) { + switch (A.label) {case 0: + if (r = null == n.batchSize ? 32 : n.batchSize, i = this.standardizeUserData(e, t, !1, r), a = i[0], o = i[1], s = !1, p = !1, null != n.validationData && n.validationData.length > 0) { + if (s = !0, 2 !== n.validationData.length) throw 3 === n.validationData.length ? new NotImplementedError("validationData including sample weights is not supported yet.") : new ValueError("When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; " + n.validationData + " is invalid.");l = n.validationData[0], u = n.validationData[1], h = this.standardizeUserData(l, u, !0, r), l = h[0], u = h[1], c = l.concat(u); + } else null != n.validationSplit && n.validationSplit > 0 && n.validationSplit < 1 ? (s = !0, d = Math.floor(a[0].shape[0] * (1 - n.validationSplit)), g = a[0].shape[0], l = sliceArrays(a, d, g), a = sliceArrays(a, 0, d), u = sliceArrays(o, d, g), o = sliceArrays(o, 0, d), p = !0, c = l.concat(u)) : null != n.validationSteps && (s = !0);return f = a.concat(o), this.checkTrainableWeightsConsistency(), m = function (e) { + var t = e.slice(0, S.inputs.length), + n = e.slice(S.inputs.length, S.inputs.length + S.outputs.length), + r = [], + i = S.collectedTrainableWeights.map(function (e) { + return e.read(); + });return [S.optimizer.minimize(function () { + for (var e = [], i = 0; i < S.inputs.length; ++i) e.push({ key: S.inputs[i], value: t[i] });var a, + o = new FeedDict(e), + s = execute(S.outputs, o, { training: !0 });for (i = 0; i < S.lossFunctions.length; ++i) { + var l = (0, S.lossFunctions[i])(n[i], s[i]);mean(l), a = 0 === i ? l : add(a, l); + }for (i = 0; i < S.metricsTensors.length; ++i) { + var u = S.metricsTensors[i][0], + c = S.metricsTensors[i][1], + p = mean(u(n[c], s[c]));keep(p), r.push(p); + }return a = mean(a), S.calculateLosses().forEach(function (e) { + a = add(a, e); + }), a; + }, !0, i)].concat(r); + }, y = this.getDedupedMetricsNames(), s ? (this.makeTestFunction(), v = this.testFunction, b = y.slice().concat(y.map(function (e) { + return "val_" + e; + }))) : (v = null, c = [], b = y.slice()), z = standardizeCallbacks(n.callbacks), [4, this.fitLoop(m, f, y, r, n.epochs, n.verbose, z, v, c, n.shuffle, b, n.initialEpoch, null, null)];case 1: + return w = A.sent(), p && (c.forEach(function (e) { + return e.dispose(); + }), a.forEach(function (e) { + return e.dispose(); + }), o.forEach(function (e) { + return e.dispose(); + })), [2, w];} + }); + }); + }, t.prototype.getNamedWeights = function (e) { + for (var t = {}, n = null != e && e.trainableOnly, r = n ? this.trainableWeights : this.weights, i = this.getWeights(n), a = 0; a < r.length; ++a) n && !r[a].trainable || (t[r[a].originalName] = i[a]);return t; + }, t.prototype.save = function (e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r, i, a, o;return __generator$1(this, function (s) { + switch (s.label) {case 0: + if ("string" == typeof e) { + if (0 === (n = io.getSaveHandlers(e)).length) throw new ValueError("Cannot find any save handlers for URL '" + e + "'");if (n.length > 1) throw new ValueError("Found more than one (" + n.length + ") save handlers for URL '" + e + "'");e = n[0]; + }if (null == e.save) throw new ValueError("Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return [4, io.encodeWeights(this.getNamedWeights(t))];case 1: + return r = s.sent(), i = !1, a = null, o = this.toJSON(a, i), [2, e.save({ modelTopology: o, weightData: r.data, weightSpecs: r.specs })];} + }); + }); + }, t.className = "Model", t; + }(Container);function loadModelInternal(e) { + return __awaiter$1(this, void 0, void 0, function () { + var t;return __generator$1(this, function (n) { + if ("string" == typeof e) { + if (0 === (t = io.getLoadHandlers(e)).length) t.push(io.browserHTTPRequest(e));else if (t.length > 1) throw new ValueError("Found more than one (" + t.length + ") load handlers for URL '" + e + "'");e = t[0]; + }return [2, loadModelFromIOHandler(e)]; + }); + }); + }function loadModelFromIOHandler(e, t) { + return __awaiter$1(this, void 0, void 0, function () { + var n, r, i, a, o;return __generator$1(this, function (s) { + switch (s.label) {case 0: + if (null == e.load) throw new ValueError("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");return [4, e.load()];case 1: + if (n = s.sent(), null != (r = n.modelTopology).model_config && (r = r.model_config), i = deserialize(convertPythonicToTs(r), t), null != n.weightData) { + if (null == n.weightSpecs) throw new ValueError("Model artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");a = !1, o = !0, i.loadWeights(io.decodeWeights(n.weightData, n.weightSpecs), a, o); + }return [2, i];} + }); + }); + }serialization.SerializationMap.register(Model);var Sequential = function (e) { + function t(t) { + var n = e.call(this, { inputs: [], outputs: [] }) || this;if (t = t || {}, n.trainable = !0, n._updatable = !0, n.built = !1, n.name = null != t.name ? t.name : getUid("sequential_"), null != t.layers) for (var r = 0, i = t.layers; r < i.length; r++) { + var a = i[r];n.add(a); + }return n; + }return __extends$1(t, e), t.prototype.add = function (e) { + var n, + r = e instanceof t || e instanceof Model;if (r) { + if (1 !== (n = e).outputs.length) throw new ValueError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");if (1 !== n.inputs.length) throw new ValueError("All layers in a Sequential model should have a single input tensor. For multi-input layers, use the functional API."); + }if (0 === this.outputs.length) { + if (0 === e.inboundNodes.length) { + if (null == e.batchInputShape) throw new ValueError("The first layer in a Sequential model must get an `inputShape` or `batchInputShape` argument.");var i = Input({ batchShape: e.batchInputShape, dtype: e.dtype, name: e.name + "_input" });e.apply(i); + }if (r) this.outputs = n.outputs, this.inputs = n.inputs;else { + if (1 !== e.inboundNodes.length) throw new ValueError("A layer added to a Sequential model must not already be connected somewhere else. Model received layer " + e.name + " which has " + e.inboundNodes.length + " pre-existing inbound connections.");if (1 !== e.inboundNodes[0].outputTensors.length) throw new ValueError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.outputs = [e.inboundNodes[0].outputTensors[0]], this.inputs = getSourceInputs(this.outputs[0]); + }this.inboundNodes = [], new Node({ outboundLayer: this, inboundLayers: [], nodeIndices: [], tensorIndices: [], inputTensors: this.inputs, outputTensors: this.outputs, inputMasks: pyListRepeat(null, this.inputs.length), outputMasks: [null], inputShapes: this.inputs.map(function (e) { + return e.shape; + }), outputShapes: this.outputs[0].shape }); + } else { + var a = e.apply(this.outputs[0]);if (Array.isArray(a)) throw new TypeError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.outputs = [a], this.inboundNodes[0].outputTensors = this.outputs, this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + }this.layers.push(e), this.built = !1; + }, t.prototype.pop = function () { + if (0 === this.layers.length) throw new TypeError("There are no layers in the model.");if (this.layers.pop(), 0 === this.layers.length) this.outputs = [], this.inboundNodes = [], this.outboundNodes = [];else { + var e = this.layers.length - 1;this.layers[e].outboundNodes = [], this.outputs = [this.layers[e].output], this.inboundNodes[0].outputTensors = this.outputs, this.inboundNodes[0].outputShapes = [this.outputs[0].shape]; + } + }, t.prototype.call = function (e, t) { + return null == this.model && this.build(), this.model.call(e, t); + }, t.prototype.build = function (e) { + if (getExactlyOneShape(e), 0 === this.inputs.length || 0 === this.outputs.length) throw new TypeError("Sequential model cannot be built: model is empty. Add some layers first.");this.model = new Model({ inputs: this.inputs, outputs: this.outputs[0], name: this.name + "_model" }), this.model.trainable = this.trainable, this.model.updatable = this.updatable, this.supportsMasking = this.model.supportsMasking, this.inputLayers = this.model.inputLayers, this.inputLayersNodeIndices = this.model.inputLayersNodeIndices, this.inputLayersTensorIndices = this.model.inputLayersTensorIndices, this.outputLayers = this.model.outputLayers, this.outputLayersNodeIndices = this.model.outputLayersNodeIndices, this.outputLayersTensorIndices = this.model.outputLayersTensorIndices, this.nodesByDepth = this.model.nodesByDepth, this.containerNodes = this.model.containerNodes, this.outputNames = this.model.outputNames, this.inputNames = this.model.inputNames, this.built = !0; + }, t.prototype.countParams = function () { + return this.built || this.build(), e.prototype.countParams.call(this); + }, t.prototype.summary = function (t, n, r) { + void 0 === r && (r = console.log), this.built || this.build(), e.prototype.summary.call(this, t, n, r); + }, t.prototype.setWeights = function (e) { + null == this.model && this.build(), this.model.setWeights(e); + }, Object.defineProperty(t.prototype, "updatable", { get: function () { + return this._updatable; + }, set: function (e) { + this.built && (this.model.updatable = e), this._updatable = e; + }, enumerable: !0, configurable: !0 }), t.prototype.evaluate = function (e, t, n) { + if (void 0 === n && (n = {}), !this.built) throw new RuntimeError("The model needs to be compiled before being used.");return this.model.evaluate(e, t, n); + }, t.prototype.predict = function (e, t) { + return void 0 === t && (t = {}), null == this.model && this.build(), this.model.predict(e, t); + }, t.prototype.predictOnBatch = function (e) { + return null == this.model && this.build(), this.model.predictOnBatch(e); + }, t.prototype.compile = function (e) { + this.build(), this.model.compile(e), this.optimizer = this.model.optimizer, this.loss = this.model.loss, this.metrics = this.model.metrics, this.metricsTensors = this.model.metricsTensors, this.metricsNames = this.model.metricsNames; + }, t.prototype.fit = function (e, t, n) { + return void 0 === n && (n = {}), __awaiter$1(this, void 0, void 0, function () { + return __generator$1(this, function (r) { + if (!this.built) throw new RuntimeError("The model needs to be compiled before being used.");return [2, this.model.fit(e, t, n)]; + }); + }); + }, t.fromConfig = function (e, n) { + var r = new e({});if (!(r instanceof t)) throw new ValueError("Sequential.fromConfig called on non-Sequential input: " + r);if (!(n instanceof Array)) throw new ValueError("Sequential.fromConfig called without an array of configs");if (null == n[0].className || "Merge" === n[0].className) throw new ValueError("Legacy serialization format not supported yet.");for (var i = 0, a = n; i < a.length; i++) { + var o = deserialize(a[i]);r.add(o); + }return r; + }, t.prototype.getConfig = function () { + for (var e = [], t = 0, n = this.layers; t < n.length; t++) { + var r = n[t];e.push({ className: r.getClassName(), config: r.getConfig() }); + }return e; + }, t.className = "Sequential", t; + }(Model);function model(e) { + return new Model(e); + }function sequential(e) { + return new Sequential(e); + }function loadModel(e) { + return loadModelInternal(e); + }function input(e) { + return Input(e); + }serialization.SerializationMap.register(Sequential);var Activation = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.getConfig = function () { + return {}; + }, t; + }(serialization.Serializable), + Elu = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + return void 0 === t && (t = 1), elu$1(e, t); + }, t.className = "elu", t; + }(Activation);serialization.SerializationMap.register(Elu);var Selu = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return selu(e); + }, t.className = "selu", t; + }(Activation);serialization.SerializationMap.register(Selu);var Relu = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return relu(e); + }, t.className = "relu", t; + }(Activation);serialization.SerializationMap.register(Relu);var Relu6 = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return tidy(function () { + return minimum(getScalar(6), relu(e)); + }); + }, t.className = "relu6", t; + }(Activation);serialization.SerializationMap.register(Relu6);var Linear = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return e; + }, t.className = "linear", t; + }(Activation);serialization.SerializationMap.register(Linear);var Sigmoid = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return sigmoid(e); + }, t.className = "sigmoid", t; + }(Activation);serialization.SerializationMap.register(Sigmoid);var HardSigmoid = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return hardSigmoid(e); + }, t.className = "hardSigmoid", t; + }(Activation);serialization.SerializationMap.register(HardSigmoid);var Softplus = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return softplus(e); + }, t.className = "softplus", t; + }(Activation);serialization.SerializationMap.register(Softplus);var Softsign = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return softsign(e); + }, t.className = "softsign", t; + }(Activation);serialization.SerializationMap.register(Softsign);var Tanh = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e) { + return tanh$1(e); + }, t.className = "tanh", t; + }(Activation);serialization.SerializationMap.register(Tanh);var Softmax = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + return void 0 === t && (t = -1), softmax(e, t); + }, t.className = "softmax", t; + }(Activation);function serializeActivation(e) { + return e.getClassName(); + }function deserializeActivation(e, t) { + return void 0 === t && (t = {}), deserializeKerasObject(e, serialization.SerializationMap.getMap().classNameMap, t, "activation"); + }function getActivation(e) { + return null == e ? deserializeActivation({ className: "linear", config: {} }) : "string" == typeof e ? deserializeActivation({ className: e, config: {} }) : e instanceof Activation ? e : deserializeActivation(e); + }serialization.SerializationMap.register(Softmax);var LeakyReLU = function (e) { + function t(t) { + var n = e.call(this, null == t ? {} : t) || this;return n.DEFAULT_ALPHA = .3, null == t && (t = {}), n.alpha = null == t.alpha ? n.DEFAULT_ALPHA : t.alpha, n; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = getExactlyOneTensor(e);return leakyRelu(n, this.alpha); + }, t.prototype.computeOutputShape = function (e) { + return e; + }, t.prototype.getConfig = function () { + var t = { alpha: this.alpha }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "LeakyReLU", t; + }(Layer);serialization.SerializationMap.register(LeakyReLU);var ELU$1 = function (e) { + function t(t) { + var n = e.call(this, null == t ? {} : t) || this;if (n.DEFAULT_ALPHA = 1, null == t && (t = {}), null != t.alpha && t.alpha !== n.DEFAULT_ALPHA) throw new NotImplementedError("Non-default alpha value (" + t.alpha + ") is not supported by the ELU layer yet.");return n.alpha = null == t.alpha ? n.DEFAULT_ALPHA : t.alpha, n; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = getExactlyOneTensor(e);return elu(n); + }, t.prototype.computeOutputShape = function (e) { + return e; + }, t.prototype.getConfig = function () { + var t = { alpha: this.alpha }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "ELU", t; + }(Layer);serialization.SerializationMap.register(ELU$1);var ThresholdedReLU = function (e) { + function t(t) { + var n = e.call(this, null == t ? {} : t) || this;return n.DEFAULT_THETA = 1, null == t && (t = {}), n.theta = null == t.theta ? n.DEFAULT_THETA : t.theta, n.thetaTensor = getScalar(n.theta), n; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = getExactlyOneTensor(e);return n.mul(cast$1(n.greater(this.thetaTensor), "float32")); + }, t.prototype.computeOutputShape = function (e) { + return e; + }, t.prototype.getConfig = function () { + var t = { theta: this.theta }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "ThresholdedReLU", t; + }(Layer);serialization.SerializationMap.register(ThresholdedReLU);var Softmax$1 = function (e) { + function t(t) { + var n = e.call(this, null == t ? {} : t) || this;return n.DEFAULT_AXIS = 1, null == t && (t = {}), n.softmax = new Softmax().apply, n.axis = null == t.axis ? n.DEFAULT_AXIS : t.axis, n; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = getExactlyOneTensor(e);return this.softmax(n, this.axis); + }, t.prototype.computeOutputShape = function (e) { + return e; + }, t.prototype.getConfig = function () { + var t = { axis: this.axis }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Softmax", t; + }(Layer);serialization.SerializationMap.register(Softmax$1);var Regularizer = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t; + }(serialization.Serializable), + L1L2 = function (e) { + function t(t) { + var n = e.call(this) || this, + r = null == t || null == t.l1 ? .01 : t.l1, + i = null == t || null == t.l2 ? .01 : t.l2;return n.hasL1 = 0 !== r, n.hasL2 = 0 !== i, n.l1 = getScalar(r), n.l2 = getScalar(i), n; + }return __extends$1(t, e), t.prototype.apply = function (e) { + var t = this;return tidy(function () { + var n = zeros([1]);return t.hasL1 && (n = add(n, sum(mul(t.l1, abs(e))))), t.hasL2 && (n = add(n, sum(mul(t.l2, square$1(e))))), n.asScalar(); + }); + }, t.prototype.getConfig = function () { + return { l1: this.l1.dataSync()[0], l2: this.l2.dataSync()[0] }; + }, t.fromConfig = function (e, t) { + return new e({ l1: t.l1, l2: t.l2 }); + }, t.className = "L1L2", t; + }(Regularizer);function l1(e) { + return new L1L2({ l1: null != e ? e.l1 : null, l2: 0 }); + }function l2(e) { + return new L1L2({ l2: null != e ? e.l2 : null, l1: 0 }); + }serialization.SerializationMap.register(L1L2);var REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP = { l1l2: "L1L2" };function serializeRegularizer(e) { + return serializeKerasObject(e); + }function deserializeRegularizer(e, t) { + return void 0 === t && (t = {}), deserializeKerasObject(e, serialization.SerializationMap.getMap().classNameMap, t, "regularizer"); + }function getRegularizer(e) { + return null == e ? null : "string" == typeof e ? deserializeRegularizer({ className: e in REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP ? REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e] : e, config: {} }) : e instanceof Regularizer ? e : deserializeRegularizer(e); + }function normalizeArray(e, t, n) { + if ("number" == typeof e) return pyListRepeat(e, t);if (e.length !== t) throw new ValueError("The " + n + " argument must be a tuple of " + t + " integers. Received: " + e.length + " elements.");for (var r = 0; r < t; ++r) { + var i = e[r];if (!isInteger(i)) throw new ValueError("The " + n + " argument must be a tuple of " + t + " integers. Received: " + JSON.stringify(e) + " including a non-integer number " + i); + }return e; + }function convOutputLength(e, t, n, r, i) { + return void 0 === i && (i = 1), null == e ? e : (a = "same" === n ? e : e - (t + (t - 1) * (i - 1)) + 1, Math.floor((a + r - 1) / r));var a; + }function deconvLength(e, t, n, r) { + if (null == e) return null;if ("valid" === r) e = e * t + max$1([n - t, 0]);else { + if ("same" !== r) throw new ValueError("Unsupport padding mode: " + r + ".");e *= t; + }return e; + }function preprocessConv2DInput(e, t) { + return tidy(function () { + return checkDataFormat(t), "channelsFirst" === t ? transpose(e, [0, 2, 3, 1]) : e; + }); + }function conv1dWithBias(e, t, n, r, i, a, o) { + return void 0 === r && (r = 1), void 0 === i && (i = "valid"), void 0 === o && (o = 1), tidy(function () { + if (null == a && (a = imageDataFormat()), checkDataFormat(a), 3 !== e.shape.length) throw new ValueError("The input of a conv1dWithBias operation should be 3, but is " + e.shape.length + " instead.");if (3 !== t.shape.length) throw new ValueError("The kernel for a conv1dWithBias operation should be 3, but is " + t.shape.length + " instead");if (null != n && 1 !== n.shape.length) throw new ValueError("The bias for a conv1dWithBias operation should be 1, but is " + t.shape.length + " instead");if ("channelsFirst" === a && (e = transpose(e, [0, 2, 1])), "causal" === i) throw new NotImplementedError("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");var s = conv1d(e, t, r, "same" === i ? "same" : "valid", "NWC", o);return null != n && (s = biasAdd(s, n)), s; + }); + }function conv2dWithBias(e, t, n, r, i, a, o) { + return void 0 === r && (r = [1, 1]), void 0 === i && (i = "valid"), tidy(function () { + if (null == a && (a = imageDataFormat()), checkDataFormat(a), 3 !== e.rank && 4 !== e.rank) throw new ValueError("conv2dWithBias expects input to be of rank 3 or 4, but received " + e.rank + ".");if (3 !== t.rank && 4 !== t.rank) throw new ValueError("conv2dWithBias expects kernel to be of rank 3 or 4, but received " + e.rank + ".");var s = preprocessConv2DInput(e, a);if ("causal" === i) throw new NotImplementedError("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");return s = conv2d(s, t, r, "same" === i ? "same" : "valid", "NHWC", o), null != n && (s = biasAdd(s, n)), "channelsFirst" === a && (s = transpose(s, [0, 3, 1, 2])), s; + }); + }var BaseConv = function (e) { + function t(n, r) { + var i = e.call(this, r) || this;if (i.bias = null, i.DEFAULT_KERNEL_INITIALIZER = "glorotNormal", i.DEFAULT_BIAS_INITIALIZER = "zeros", t.verifyConfig(r), i.rank = n, 1 !== i.rank && 2 !== i.rank) throw new NotImplementedError("Convolution layer for rank other than 1 or 2 (" + i.rank + ") is not implemented yet.");if (i.kernelSize = normalizeArray(r.kernelSize, n, "kernelSize"), i.strides = normalizeArray(null == r.strides ? 1 : r.strides, n, "strides"), i.padding = null == r.padding ? "valid" : r.padding, checkPaddingMode(i.padding), i.dataFormat = null == r.dataFormat ? "channelsLast" : r.dataFormat, checkDataFormat(i.dataFormat), i.activation = getActivation(r.activation), i.useBias = null == r.useBias || r.useBias, i.biasInitializer = getInitializer(r.biasInitializer || i.DEFAULT_BIAS_INITIALIZER), i.biasConstraint = getConstraint(r.biasConstraint), i.biasRegularizer = getRegularizer(r.biasRegularizer), i.activityRegularizer = getRegularizer(r.activityRegularizer), i.dilationRate = normalizeArray(null == r.dilationRate ? 1 : r.dilationRate, n, "dilationRate"), 1 === i.rank && Array.isArray(i.dilationRate) && 1 !== i.dilationRate.length) throw new ValueError("dilationRate must be a number or an array of a single number for 1D convolution, but received " + JSON.stringify(i.dilationRate));if (2 === i.rank) if ("number" == typeof i.dilationRate) i.dilationRate = [i.dilationRate, i.dilationRate];else if (2 !== i.dilationRate.length) throw new ValueError("dilationRate must be a number or array of two numbers for 2D convolution, but received " + JSON.stringify(i.dilationRate));return i; + }return __extends$1(t, e), t.verifyConfig = function (e) { + if (assert$1("kernelSize" in e, "required key 'kernelSize' not in config"), "number" != typeof e.kernelSize && !checkArrayTypeAndLength(e.kernelSize, "number", 1, 2)) throw new ValueError("BaseConv expects config.kernelSize to be number or number[] with length 1 or 2, but received " + JSON.stringify(e.kernelSize) + "."); + }, t.prototype.getConfig = function () { + var t = { kernelSize: this.kernelSize, strides: this.strides, padding: this.padding, dataFormat: this.dataFormat, dilationRate: this.dilationRate, activation: serializeActivation(this.activation), useBias: this.useBias, biasInitializer: serializeInitializer(this.biasInitializer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), biasConstraint: serializeConstraint(this.biasConstraint) }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t; + }(Layer), + Conv = function (e) { + function t(n, r) { + var i = e.call(this, n, r) || this;return i.kernel = null, t.verifyConfig(r), i.filters = r.filters, i.kernelInitializer = getInitializer(r.kernelInitializer || i.DEFAULT_KERNEL_INITIALIZER), i.kernelConstraint = getConstraint(r.kernelConstraint), i.kernelRegularizer = getRegularizer(r.kernelRegularizer), i; + }return __extends$1(t, e), t.prototype.build = function (e) { + e = getExactlyOneShape(e);var t = "channelsFirst" === this.dataFormat ? 1 : e.length - 1;if (null == e[t]) throw new ValueError("The channel dimension of the input should be defined. Found " + e[t]);var n, + r = e[t], + i = this.kernelSize.concat([r, this.filters]);this.kernel = this.addWeight("kernel", i, null, this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.useBias && (this.bias = this.addWeight("bias", [this.filters], null, this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint)), this.inputSpec = [{ ndim: this.rank + 2, axes: (n = {}, n[t] = r, n) }], this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t;e = getExactlyOneTensor(e);var r = null == n.bias ? null : n.bias.read();if (1 === n.rank) t = conv1dWithBias(e, n.kernel.read(), r, n.strides[0], n.padding, n.dataFormat, n.dilationRate[0]);else if (2 === n.rank) t = conv2dWithBias(e, n.kernel.read(), r, n.strides, n.padding, n.dataFormat, n.dilationRate);else if (3 === n.rank) throw new NotImplementedError("3D convolution is not implemented yet.");return null != n.activation && (t = n.activation.apply(t)), t; + }); + }, t.prototype.computeOutputShape = function (e) { + e = getExactlyOneShape(e);for (var t = [], n = "channelsLast" === this.dataFormat ? e.slice(1, e.length - 1) : e.slice(2), r = 0; r < n.length; ++r) { + var i = convOutputLength(n[r], this.kernelSize[r], this.padding, this.strides[r], "number" == typeof this.dilationRate ? this.dilationRate : this.dilationRate[r]);t.push(i); + }var a = [e[0]];return "channelsLast" === this.dataFormat ? (a = a.concat(t)).push(this.filters) : (a.push(this.filters), a = a.concat(t)), a; + }, t.prototype.getConfig = function () { + var t = { filters: this.filters, kernelInitializer: serializeInitializer(this.kernelInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint) }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.verifyConfig = function (e) { + if (!("filters" in e) || "number" != typeof e.filters || e.filters < 1) throw new ValueError("Convolution layer expected config.filters to be a 'number' > 0 but got " + JSON.stringify(e.filters)); + }, t; + }(BaseConv), + Conv2D = function (e) { + function t(n) { + var r = e.call(this, 2, n) || this;return t.verifyConfig(n), r; + }return __extends$1(t, e), t.prototype.getConfig = function () { + var t = e.prototype.getConfig.call(this);return delete t.rank, t; + }, t.verifyConfig = function (e) { + if ("number" != typeof e.kernelSize && !checkArrayTypeAndLength(e.kernelSize, "number", 1, 2)) throw new ValueError("Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received " + JSON.stringify(e.kernelSize) + "."); + }, t.className = "Conv2D", t; + }(Conv);serialization.SerializationMap.register(Conv2D);var Conv2DTranspose = function (e) { + function t(t) { + var n = e.call(this, t) || this;if (n.inputSpec = [new InputSpec({ ndim: 4 })], "same" !== n.padding && "valid" !== n.padding) throw new ValueError("Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode " + n.padding);return n; + }return __extends$1(t, e), t.prototype.build = function (e) { + if (4 !== (e = getExactlyOneShape(e)).length) throw new ValueError("Input should have rank 4; Received input shape: " + JSON.stringify(e));var t = "channelsFirst" === this.dataFormat ? 1 : e.length - 1;if (null == e[t]) throw new ValueError("The channel dimension of the inputs should be defined. Found `None`.");var n, + r = e[t], + i = this.kernelSize.concat([this.filters, r]);this.kernel = this.addWeight("kernel", i, "float32", this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.useBias && (this.bias = this.addWeight("bias", [this.filters], "float32", this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint)), this.inputSpec = [new InputSpec({ ndim: 4, axes: (n = {}, n[t] = r, n) })], this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t = getExactlyOneTensor(e);if (4 !== t.shape.length) throw new ValueError("Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-" + t.shape.length);var r, + i, + a = t.shape, + o = a[0];"channelsFirst" === n.dataFormat ? (r = 2, i = 3) : (r = 1, i = 2);var s = a[r], + l = a[i], + u = n.kernelSize[0], + c = n.kernelSize[1], + p = n.strides[0], + h = n.strides[1], + d = [o, deconvLength(s, p, u, n.padding), deconvLength(l, h, c, n.padding), n.filters];"channelsLast" !== n.dataFormat && (t = transpose(t, [0, 2, 3, 1]));var g = conv2dTranspose(t, n.kernel.read(), d, n.strides, n.padding);return "channelsLast" !== n.dataFormat && (g = transpose(g, [0, 3, 1, 2])), null != n.bias && (g = biasAdd(g, n.bias.read(), n.dataFormat)), null != n.activation && (g = n.activation.apply(g)), g; + }); + }, t.prototype.computeOutputShape = function (e) { + var t, + n, + r, + i = (e = getExactlyOneShape(e)).slice();"channelsFirst" === this.dataFormat ? (t = 1, n = 2, r = 3) : (t = 3, n = 1, r = 2);var a = this.kernelSize[0], + o = this.kernelSize[1], + s = this.strides[0], + l = this.strides[1];return i[t] = this.filters, i[n] = deconvLength(i[n], s, a, this.padding), i[r] = deconvLength(i[r], l, o, this.padding), i; + }, t.prototype.getConfig = function () { + var t = e.prototype.getConfig.call(this);return delete t.dilationRate, t; + }, t.className = "Conv2DTranspose", t; + }(Conv2D);serialization.SerializationMap.register(Conv2DTranspose);var SeparableConv = function (e) { + function t(t, n) { + var r = e.call(this, t, n) || this;if (r.DEFAULT_DEPTHWISE_INITIALIZER = "glorotUniform", r.DEFAULT_POINTWISE_INITIALIZER = "glorotUniform", r.depthwiseKernel = null, r.pointwiseKernel = null, null == n.filters) throw new ValueError("The `filters` configuration field is required by SeparableConv, but is unspecified.");if (null != n.kernelInitializer || null != n.kernelRegularizer || null != n.kernelConstraint) throw new ValueError("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if (null != n.padding && "same" !== n.padding && "valid" !== n.padding) throw new ValueError("SeparableConv" + r.rank + "D supports only padding modes: 'same' and 'valid', but received " + JSON.stringify(n.padding));return r.depthMultiplier = null == n.depthMultiplier ? 1 : n.depthMultiplier, r.depthwiseInitializer = getInitializer(n.depthwiseInitializer || r.DEFAULT_DEPTHWISE_INITIALIZER), r.depthwiseRegularizer = getRegularizer(n.depthwiseRegularizer), r.depthwiseConstraint = getConstraint(n.depthwiseConstraint), r.pointwiseInitializer = getInitializer(n.depthwiseInitializer || r.DEFAULT_POINTWISE_INITIALIZER), r.pointwiseRegularizer = getRegularizer(n.pointwiseRegularizer), r.pointwiseConstraint = getConstraint(n.pointwiseConstraint), r; + }return __extends$1(t, e), t.prototype.build = function (e) { + if ((e = getExactlyOneShape(e)).length < this.rank + 2) throw new ValueError("Inputs to SeparableConv" + this.rank + "D should have rank " + (this.rank + 2) + ", but received input shape: " + JSON.stringify(e));var t = "channelsFirst" === this.dataFormat ? 1 : e.length - 1;if (null == e[t] || e[t] < 0) throw new ValueError("The channel dimension of the inputs should be defined, but found " + JSON.stringify(e[t]));for (var n = e[t], r = this.kernelSize.concat([n, this.depthMultiplier]), i = [], a = 0; a < this.rank; ++a) i.push(1);i.push(n * this.depthMultiplier, this.filters);var o;this.depthwiseKernel = this.addWeight("depthwise_kernel", r, "float32", this.depthwiseInitializer, this.depthwiseRegularizer, !0, this.depthwiseConstraint), this.pointwiseKernel = this.addWeight("pointwise_kernel", i, "float32", this.pointwiseInitializer, this.pointwiseRegularizer, !0, this.pointwiseConstraint), this.useBias ? this.bias = this.addWeight("bias", [this.filters], "float32", this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint) : this.bias = null, this.inputSpec = [new InputSpec({ ndim: this.rank + 2, axes: (o = {}, o[t] = n, o) })], this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t;if (e = getExactlyOneTensor(e), 1 === n.rank) throw new NotImplementedError("1D separable convolution is not implemented yet.");return 2 === n.rank && ("channelsFirst" === n.dataFormat && (e = transpose(e, [0, 2, 3, 1])), t = separableConv2d(e, n.depthwiseKernel.read(), n.pointwiseKernel.read(), n.strides, n.padding, n.dilationRate, "NHWC")), n.useBias && (t = biasAdd(t, n.bias.read(), n.dataFormat)), null != n.activation && (t = n.activation.apply(t)), "channelsFirst" === n.dataFormat && (t = transpose(t, [0, 3, 1, 2])), t; + }); + }, t.prototype.getConfig = function () { + var t = e.prototype.getConfig.call(this);return delete t.rank, delete t.kernelInitializer, delete t.kernelRegularizer, delete t.kernelConstraint, t.depthwiseInitializer = serializeInitializer(this.depthwiseInitializer), t.pointwiseInitializer = serializeInitializer(this.pointwiseInitializer), t.depthwiseRegularizer = serializeRegularizer(this.depthwiseRegularizer), t.pointwiseRegularizer = serializeRegularizer(this.pointwiseRegularizer), t.depthwiseConstraint = serializeConstraint(this.depthwiseConstraint), t.pointwiseConstraint = serializeConstraint(this.pointwiseConstraint), t; + }, t.className = "SeparableConv", t; + }(Conv), + SeparableConv2D = function (e) { + function t(t) { + return e.call(this, 2, t) || this; + }return __extends$1(t, e), t.className = "SeparableConv2D", t; + }(SeparableConv);serialization.SerializationMap.register(SeparableConv2D);var Conv1D = function (e) { + function t(n) { + var r = e.call(this, 1, n) || this;return t.verifyConfig(n), r.inputSpec = [{ ndim: 3 }], r; + }return __extends$1(t, e), t.prototype.getConfig = function () { + var t = e.prototype.getConfig.call(this);return delete t.rank, delete t.dataFormat, t; + }, t.verifyConfig = function (e) { + if ("number" != typeof e.kernelSize && !checkArrayTypeAndLength(e.kernelSize, "number", 1, 1)) throw new ValueError("Conv1D expects config.kernelSize to be number or number[] with length 1, but received " + JSON.stringify(e.kernelSize) + "."); + }, t.className = "Conv1D", t; + }(Conv);serialization.SerializationMap.register(Conv1D);var Cropping2D = function (e) { + function t(t) { + var n = e.call(this, t) || this;return "number" == typeof t.cropping ? n.cropping = [[t.cropping, t.cropping], [t.cropping, t.cropping]] : "number" == typeof t.cropping[0] ? n.cropping = [[t.cropping[0], t.cropping[0]], [t.cropping[1], t.cropping[1]]] : n.cropping = t.cropping, n.dataFormat = void 0 === t.dataFormat ? "channelsLast" : t.dataFormat, n.inputSpec = [{ ndim: 4 }], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + return "channelsFirst" === this.dataFormat ? [e[0], e[1], e[2] - this.cropping[0][0] - this.cropping[0][1], e[2] - this.cropping[1][0] - this.cropping[1][1]] : [e[0], e[1] - this.cropping[0][0] - this.cropping[0][1], e[2] - this.cropping[1][0] - this.cropping[1][1], e[3]]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return e = getExactlyOneTensor(e), "channelsLast" === n.dataFormat ? sliceAlongAxis(sliceAlongAxis(e, n.cropping[0][0], e.shape[1] - n.cropping[0][0] - n.cropping[0][1], 2), n.cropping[1][0], e.shape[2] - n.cropping[1][1] - n.cropping[1][0], 3) : sliceAlongAxis(sliceAlongAxis(e, n.cropping[0][0], e.shape[2] - n.cropping[0][0] - n.cropping[0][1], 3), n.cropping[1][0], e.shape[3] - n.cropping[1][1] - n.cropping[1][0], 4); + }); + }, t.prototype.getConfig = function () { + var t = { cropping: this.cropping, dataFormat: this.dataFormat }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Cropping2D", t; + }(Layer);serialization.SerializationMap.register(Cropping2D);var UpSampling2D = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.DEFAULT_SIZE = [2, 2], n.inputSpec = [{ ndim: 4 }], n.size = null == t.size ? n.DEFAULT_SIZE : t.size, n.dataFormat = null == t.dataFormat ? "channelsLast" : t.dataFormat, n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + if ("channelsFirst" === this.dataFormat) { + var t = null == e[2] ? null : this.size[0] * e[2], + n = null == e[3] ? null : this.size[1] * e[3];return [e[0], e[1], t, n]; + }t = null == e[1] ? null : this.size[0] * e[1], n = null == e[2] ? null : this.size[1] * e[2];return [e[0], t, n, e[3]]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t = getExactlyOneTensor(e), + r = t.shape;if ("channelsFirst" === n.dataFormat) { + t = transpose(t, [0, 2, 3, 1]);var i = n.size[0] * r[2], + a = n.size[1] * r[3], + o = t.resizeNearestNeighbor([i, a]);return transpose(o, [0, 3, 1, 2]); + }i = n.size[0] * r[1], a = n.size[1] * r[2];return t.resizeNearestNeighbor([i, a]); + }); + }, t.prototype.getConfig = function () { + var t = { size: this.size, dataFormat: this.dataFormat }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "UpSampling2D", t; + }(Layer);function depthwiseConv2d$1(e, t, n, r, i, a) { + return void 0 === n && (n = [1, 1]), void 0 === r && (r = "valid"), tidy(function () { + null == i && (i = imageDataFormat()), checkDataFormat(i);var o = preprocessConv2DInput(e, i);if (4 !== e.rank) throw new ValueError("Input for depthwiseConv2d is required to be 4-D, but is instead " + e.rank + "-D");if (4 !== t.rank) throw new ValueError("depthwiseKernel is required to be 4-D, but is instead " + t.rank + "-D");return o = depthwiseConv2d(o, t, n, "same" === r ? "same" : "valid", "NHWC", a), "channelsFirst" === i && (o = transpose(o, [0, 3, 1, 2])), o; + }); + }serialization.SerializationMap.register(UpSampling2D);var DepthwiseConv2D = function (e) { + function t(t) { + var n = e.call(this, 2, t) || this;return n.depthwiseKernel = null, n.depthMultiplier = null == t.depthMultiplier ? 1 : t.depthMultiplier, n.depthwiseInitializer = getInitializer(t.depthwiseInitializer || n.DEFAULT_KERNEL_INITIALIZER), n.depthwiseConstraint = getConstraint(t.depthwiseConstraint), n.depthwiseRegularizer = getRegularizer(t.depthwiseRegularizer), n; + }return __extends$1(t, e), t.prototype.build = function (e) { + if ((e = getExactlyOneShape(e)).length < 4) throw new ValueError("Inputs to DepthwiseConv2D should have rank 4. Received input shape: " + JSON.stringify(e) + ".");var t = "channelsFirst" === this.dataFormat ? 1 : 3;if (null == e[t] || e[t] < 0) throw new ValueError("The channel dimension of the inputs to DepthwiseConv2D should be defined, but is not (" + e[t] + ").");var n = e[t], + r = [this.kernelSize[0], this.kernelSize[1], n, this.depthMultiplier];this.depthwiseKernel = this.addWeight("depthwise_kernel", r, null, this.depthwiseInitializer, this.depthwiseRegularizer, !0, this.depthwiseConstraint), this.useBias ? this.bias = this.addWeight("bias", [n * this.depthMultiplier], null, this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint) : this.bias = null, this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t = depthwiseConv2d$1(e = getExactlyOneTensor(e), n.depthwiseKernel.read(), n.strides, n.padding, n.dataFormat, null);return n.useBias && (t = biasAdd(t, n.bias.read(), n.dataFormat)), null != n.activation && (t = n.activation.apply(t)), t; + }); + }, t.prototype.computeOutputShape = function (e) { + e = getExactlyOneShape(e);var t = "channelsFirst" === this.dataFormat ? e[2] : e[1], + n = "channelsFirst" === this.dataFormat ? e[3] : e[2], + r = "channelsFirst" === this.dataFormat ? e[1] * this.depthMultiplier : e[3] * this.depthMultiplier, + i = convOutputLength(t, this.kernelSize[0], this.padding, this.strides[0]), + a = convOutputLength(n, this.kernelSize[1], this.padding, this.strides[1]);return "channelsFirst" === this.dataFormat ? [e[0], r, i, a] : [e[0], i, a, r]; + }, t.prototype.getConfig = function () { + var t = e.prototype.getConfig.call(this);return t.depthMultiplier = this.depthMultiplier, t.depthwiseInitializer = serializeInitializer(this.depthwiseInitializer), t.depthwiseRegularizer = serializeRegularizer(this.depthwiseRegularizer), t.depthwiseConstraint = serializeConstraint(this.depthwiseRegularizer), t; + }, t.className = "DepthwiseConv2D", t; + }(BaseConv);serialization.SerializationMap.register(DepthwiseConv2D);var Dropout = function (e) { + function t(t) { + var n = e.call(this, t) || this;if (n.rate = Math.max(Math.min(t.rate, 1), 0), n.rateScalar = getScalar(n.rate), n.noiseShape = t.noiseShape, n.seed = t.seed, null != n.seed) throw new NotImplementedError("Non-default seed is not implemented in Dropout layer yet: " + n.seed);return n.supportsMasking = !0, n; + }return __extends$1(t, e), t.prototype.getNoiseShape = function (e) { + if (null == this.noiseShape) return this.noiseShape;for (var t = e.shape, n = [], r = 0; r < this.noiseShape.length; ++r) n.push(null == this.noiseShape[r] ? t[r] : this.noiseShape[r]);return n; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t);var r = getExactlyOneTensor(e);if (null != n.noiseShape && !util.arraysEqual(r.shape, n.noiseShape)) throw new NotImplementedError("Non-default noise shape is not implemented in Dropout layer yet: " + JSON.stringify(n.noiseShape));if (0 < n.rate && n.rate < 1) { + var i = null != t.training && t.training, + a = n.getNoiseShape(r);return inTrainPhase(function () { + return dropout(r, n.rateScalar, a, n.seed); + }, function () { + return r; + }, i); + }return e; + }); + }, t.prototype.getConfig = function () { + var t = { rate: this.rate, noiseShape: this.noiseShape, seed: this.seed }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Dropout", t; + }(Layer);serialization.SerializationMap.register(Dropout);var Dense = function (e) { + function t(t) { + var n = e.call(this, t) || this;if (n.activation = null, n.useBias = !0, n.kernel = null, n.bias = null, n.DEFAULT_KERNEL_INITIALIZER = "glorotNormal", n.DEFAULT_BIAS_INITIALIZER = "zeros", null == t.batchInputShape && null == t.inputShape && null != t.inputDim) { + var r = null;null != t.batchSize && (r = t.batchSize), n.batchInputShape = [r, t.inputDim]; + }return n.units = t.units, n.activation = getActivation(t.activation), null != t.useBias && (n.useBias = t.useBias), n.kernelInitializer = getInitializer(t.kernelInitializer || n.DEFAULT_KERNEL_INITIALIZER), n.biasInitializer = getInitializer(t.biasInitializer || n.DEFAULT_BIAS_INITIALIZER), n.kernelConstraint = getConstraint(t.kernelConstraint), n.biasConstraint = getConstraint(t.biasConstraint), n.kernelRegularizer = getRegularizer(t.kernelRegularizer), n.biasRegularizer = getRegularizer(t.biasRegularizer), n.activityRegularizer = getRegularizer(t.activityRegularizer), n.inputSpec = [{ minNDim: 2 }], n; + }return __extends$1(t, e), t.prototype.build = function (e) { + var t, + n = (e = getExactlyOneShape(e))[e.length - 1];null == this.kernel && (this.kernel = this.addWeight("kernel", [n, this.units], null, this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.useBias && (this.bias = this.addWeight("bias", [this.units], null, this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint))), this.inputSpec = [{ minNDim: 2, axes: (t = {}, t[-1] = n, t) }], this.built = !0; + }, t.prototype.computeOutputShape = function (e) { + var t = (e = getExactlyOneShape(e)).slice();return t[t.length - 1] = this.units, t; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t);var r = dot$1(getExactlyOneTensor(e), n.kernel.read());return null != n.bias && (r = biasAdd(r, n.bias.read())), null != n.activation && (r = n.activation.apply(r)), r; + }); + }, t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), biasInitializer: serializeInitializer(this.biasInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), biasConstraint: serializeConstraint(this.biasConstraint) }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Dense", t; + }(Layer);serialization.SerializationMap.register(Dense);var Flatten = function (e) { + function t(t) { + var n = e.call(this, t || {}) || this;return n.inputSpec = [{ minNDim: 3 }], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + for (var t = 0, n = (e = getExactlyOneShape(e)).slice(1); t < n.length; t++) { + if (null == n[t]) throw new ValueError('The shape of the input to "Flatten" is not fully defined (got ' + e.slice(1) + '). Make sure to pass a complete "input_shape" or "batch_input_shape" argument to the first layer in your model.'); + }return [e[0], arrayProd(e, 1)]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return n.invokeCallHook(e, t), batchFlatten(getExactlyOneTensor(e)); + }); + }, t.className = "Flatten", t; + }(Layer);serialization.SerializationMap.register(Flatten);var Activation$1 = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.supportsMasking = !0, n.activation = getActivation(t.activation), n; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t);var r = getExactlyOneTensor(e);return n.activation.apply(r); + }); + }, t.prototype.getConfig = function () { + var t = { activation: serializeActivation(this.activation) }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Activation", t; + }(Layer);serialization.SerializationMap.register(Activation$1);var RepeatVector = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.n = t.n, n.inputSpec = [{ ndim: 2 }], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + return [e[0], this.n, e[1]]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return repeat(e = getExactlyOneTensor(e), n.n); + }); + }, t.prototype.getConfig = function () { + var t = { n: this.n }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "RepeatVector", t; + }(Layer);serialization.SerializationMap.register(RepeatVector);var Reshape = function (e) { + function t(t) { + var n = e.call(this, t) || this;n.targetShape = t.targetShape;for (var r = 0; r < n.targetShape.length; ++r) n.isUnknown(n.targetShape[r]) && (n.targetShape[r] = null);return n; + }return __extends$1(t, e), t.prototype.isUnknown = function (e) { + return e < 0 || null == e; + }, t.prototype.fixUnknownDimension = function (e, t) { + for (var n = "Total size of new array must be unchanged.", r = t.slice(), i = 1, a = null, o = 0; o < r.length; ++o) { + var s = r[o];if (this.isUnknown(s)) { + if (null !== a) throw new ValueError("Can only specifiy one unknown dimension.");a = o; + } else i *= s; + }var l = arrayProd(e);if (null !== a) { + if (0 === i || l % i != 0) throw new ValueError(n);r[a] = l / i; + } else if (l !== i) throw new ValueError(n);return r; + }, t.prototype.computeOutputShape = function (e) { + for (var t = !1, n = 0; n < e.length; ++n) if (this.isUnknown(e[n])) { + t = !0;break; + }return t ? e.slice(0, 1).concat(this.targetShape) : e.slice(0, 1).concat(this.fixUnknownDimension(e.slice(1), this.targetShape)); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t);var r = getExactlyOneTensor(e), + i = r.shape, + a = i.slice(0, 1).concat(n.fixUnknownDimension(i.slice(1), n.targetShape));return r.reshape(a); + }); + }, t.prototype.getConfig = function () { + var t = { targetShape: this.targetShape }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Reshape", t; + }(Layer);serialization.SerializationMap.register(Reshape);var Embedding = function (e) { + function t(t) { + var n = e.call(this, t) || this;if (n.embeddings = null, n.DEFAULT_EMBEDDINGS_INITIALIZER = "randomUniform", null == t.batchInputShape && null == t.inputShape) { + var r = null;null != t.batchSize && (r = t.batchSize), null == t.inputLength ? n.batchInputShape = [r, null] : n.batchInputShape = [r].concat(toList(t.inputLength)); + }return n.inputDim = t.inputDim, n.outputDim = t.outputDim, n.embeddingsInitializer = getInitializer(t.embeddingsInitializer || n.DEFAULT_EMBEDDINGS_INITIALIZER), n.embeddingsRegularizer = getRegularizer(t.embeddingsRegularizer), n.activityRegularizer = getRegularizer(t.activityRegularizer), n.embeddingsConstraint = getConstraint(t.embeddingsConstraint), n.maskZero = t.maskZero, n.inputLength = t.inputLength, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + this.embeddings = this.addWeight("embeddings", [this.inputDim, this.outputDim], this.dtype, this.embeddingsInitializer, this.embeddingsRegularizer, !0, this.embeddingsConstraint), this.built = !0; + }, t.prototype.warnOnIncompatibleInputShape = function (e) {}, t.prototype.computeMask = function (e, t) { + throw new NotImplementedError("computeMask has not been implemented for Embedding yet"); + }, t.prototype.computeOutputShape = function (e) { + if (e = getExactlyOneShape(e), null == this.inputLength) return e.concat([this.outputDim]);var t = toList(this.inputLength);if (t.length !== e.length - 1) throw new ValueError('"inputLength" is ' + this.inputLength + ", but received input shape has shape " + e);for (var n = 0, r = 0; r < t.length; ++r) { + var i = t[r], + a = e[r + 1];if (null != i && null != a && i !== a) throw new ValueError('"inputLength" is ' + this.inputLength + ", but received input shape has shape " + e);null == i && (t[n] = a), n++; + }return [e[0]].concat(t, [this.outputDim]); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t);var r = getExactlyOneTensor(e);return "int32" !== r.dtype && (r = cast$1(r, "int32")), gather$1(n.embeddings.read(), r.as1D()).reshape(getExactlyOneShape(n.computeOutputShape(r.shape))); + }); + }, t.prototype.getConfig = function () { + var t = { inputDim: this.inputDim, outputDim: this.outputDim, embeddingsInitializer: serializeInitializer(this.embeddingsInitializer), embeddingsRegularizer: serializeRegularizer(this.embeddingsRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), embeddingsConstraint: serializeConstraint(this.embeddingsConstraint), maskZero: this.maskZero, inputLength: this.inputLength }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Embedding", t; + }(Layer);serialization.SerializationMap.register(Embedding);var Merge = function (e) { + function t(t) { + var n = e.call(this, t || {}) || this;return n.supportsMasking = !0, n; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + throw new NotImplementedError(); + }, t.prototype.computeElementwiseOpOutputShape = function (e, t) { + if (null == e || null == t) return null;if (e.length < t.length) return this.computeElementwiseOpOutputShape(t, e);if (0 === t.length) return e;for (var n = e.slice(0, e.length - t.length), r = 0; r < t.length; ++r) { + var i = e[e.length - t.length + r], + a = t[r];if (null == i || null == a || i < 0 || a < 0) n.push(null);else if (1 === i) n.push(a);else if (1 === a) n.push(i);else { + if (i !== a) throw new ValueError("Operands could not be broadcast together with shapes " + JSON.stringify(e) + " " + JSON.stringify(t));n.push(i); + } + }return n; + }, t.prototype.build = function (e) { + if (Array.isArray(e) && !Array.isArray(e[0]) && (e = [getExactlyOneShape(e)]), (e = e).length < 2) throw new ValueError("A merge layer should be called on an Array of at least 2 inputs. Got " + e.length + " input(s).");for (var t = [], n = 0, r = e; n < r.length; n++) { + null != (o = r[n]) && null !== o[0] && t.push(o[0]); + }if ((t = unique(t)).length > 1) throw new ValueError("Can not merge tensors with different batch sizes. Got tensors with shapes: " + JSON.stringify(e) + ".");for (var i = null == e[0] ? null : e[0].slice(1), a = 1; a < e.length; ++a) { + var o = null == e[a] ? null : e[a].slice(1);i = this.computeElementwiseOpOutputShape(i, o); + }var s = e.map(function (e) { + return e.length; + });-1 === e.indexOf(null) && 1 === unique(s).length ? this.reshapeRequired = !1 : this.reshapeRequired = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + if (e = e, n.reshapeRequired) { + var t = [], + r = e.map(function (e) { + return e.rank; + });if (-1 === r.indexOf(null)) { + for (var i = max$1(r), a = 0, o = e; a < o.length; a++) { + for (var s = (h = o[a]).rank, l = 0; l < i - s; ++l) h = expandDims$1(h, 1);t.push(h); + }return n.mergeFunction(t); + }for (var u = !1, c = 0, p = e; c < p.length; c++) { + var h;if (null == (s = (h = p[c]).rank)) { + var d = h.shape, + g = d[0], + f = d.slice(1).concat([g]), + m = h.reshape([g].concat(arrayProd(d.slice(1))));m = (m = transpose(m, [1, 0])).reshape(f), t.push(m), u = !0; + } else if (s > 1) { + var y = range$1(1, s).concat([0]);t.push(transpose(h, y)), u = !0; + } else t.push(h); + }var v = n.mergeFunction(t), + b = v.rank;if (u) if (null == b) { + var z = v.shape;f = [g = z[z.length - 1]].concat(z.slice(0, z.length - 1));v = transpose(v.reshape([-1, g]), [1, 0]).reshape(f); + } else if (b > 1) { + y = [b - 1].concat(range$1(0, b - 1));v = transpose(v, y); + }return v; + }return n.mergeFunction(e); + }); + }, t.prototype.computeOutputShape = function (e) { + var t;t = null == (e = e)[0] ? null : e[0].slice(1);for (var n = 1; n < e.length; ++n) { + var r = null == e[n] ? null : e[n].slice(1);t = this.computeElementwiseOpOutputShape(t, r); + }for (var i = [], a = 0, o = e; a < o.length; a++) { + null != (r = o[a]) && null !== r[0] && i.push(r[0]); + }return t = 1 === (i = unique(i)).length ? i.concat(t) : [null].concat(t); + }, t; + }(Layer), + Add = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + return tidy(function () { + for (var t = zeros(e[0].shape), n = 0, r = e; n < r.length; n++) { + var i = r[n];t = add(t, i); + }return t; + }); + }, t.className = "Add", t; + }(Merge);serialization.SerializationMap.register(Add);var Multiply = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + return tidy(function () { + for (var t = ones$1(e[0].shape), n = 0, r = e; n < r.length; n++) { + var i = r[n];t = mul(t, i); + }return t; + }); + }, t.className = "Multiply", t; + }(Merge);serialization.SerializationMap.register(Multiply);var Average = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + return tidy(function () { + for (var t = zeros(e[0].shape), n = 0, r = e; n < r.length; n++) { + var i = r[n];t = add(t, i); + }return mul(getScalar(1 / e.length), t); + }); + }, t.className = "Average", t; + }(Merge);serialization.SerializationMap.register(Average);var Maximum = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + return tidy(function () { + for (var t = e[0], n = 1; n < e.length; ++n) t = maximum(t, e[n]);return t; + }); + }, t.className = "Maximum", t; + }(Merge);serialization.SerializationMap.register(Maximum);var Minimum = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.mergeFunction = function (e) { + return tidy(function () { + for (var t = e[0], n = 1; n < e.length; ++n) t = minimum(t, e[n]);return t; + }); + }, t.className = "Minimum", t; + }(Merge);serialization.SerializationMap.register(Minimum);var Concatenate = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.DEFAULT_AXIS = -1, null == t && (t = {}), n.axis = null == t.axis ? n.DEFAULT_AXIS : t.axis, n.supportsMasking = !0, n.reshapeRequired = !1, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + if (!Array.isArray(e) || !Array.isArray(e[0]) || 1 === e.length) throw new ValueError("A `Concatenate` layer should be called on a list of at least 2 inputs");for (var t = !0, n = 0, r = e = e; n < r.length; n++) { + if (null != (c = r[n])) { + t = !1;break; + } + }if (!t) { + for (var i = [], a = 0; a < e.length; ++a) { + var o = e[a].slice();o.splice(this.axis, 1);for (var s = !1, l = 0, u = i; l < u.length; l++) { + var c = u[l];if (util.arraysEqual(c, o)) { + s = !0;break; + } + }s || i.push(o); + }if (i.length > 1) throw new ValueError("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: " + JSON.stringify(e)); + } + }, t.prototype.mergeFunction = function (e) { + var t = this;return tidy(function () { + return concatenate(e, t.axis); + }); + }, t.prototype.computeOutputShape = function (e) { + if (!Array.isArray(e) || !Array.isArray(e[0])) throw new ValueError("A `Concatenate` layer should be called on a list of inputs.");for (var t = e, n = t[0].slice(), r = this.axis < 0 ? n.length + this.axis : this.axis, i = 0, a = t.slice(1); i < a.length; i++) { + var o = a[i];if (null == n[r] || null == o[r]) { + n[r] = null;break; + }n[r] += o[r]; + }return n; + }, t.prototype.getConfig = function () { + var t = { axis: this.axis }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "Concatenate", t; + }(Merge);function batchNormalization$1(e, t, n, r, i, a) { + var o;if (void 0 === a && (a = .001), 2 === e.rank) o = batchNormalization2d(e, t, n, a, i, r);else if (3 === e.rank) o = batchNormalization3d(e, t, n, a, i, r);else { + if (4 !== e.rank) throw new NotImplementedError("batchNormalization is not implememnted for array of rank " + e.rank + " yet");o = batchNormalization4d(e, t, n, a, i, r); + }return o; + }function regularNormalizeBatchInTraining(e, t, n, r, i) { + return void 0 === i && (i = .001), tidy(function () { + var a = moments(e, r), + o = a.mean, + s = a.variance;return [batchNormalization$1(e, o, s, n, t, i), o, s]; + }); + }function broadcastNormalizeBatchInTraining(e, t, n, r, i) { + return void 0 === i && (i = .001), tidy(function () { + for (var a = moments(e, r), o = a.mean, s = a.variance, l = [], u = 0, c = range$1(0, e.rank); u < c.length; u++) { + var p = c[u];-1 !== r.indexOf(p) ? l.push(1) : l.push(e.shape[p]); + }var h = o.reshape(l), + d = s.reshape(l), + g = null == t ? null : t.reshape(l), + f = null == n ? null : n.reshape(l);return [batchNormalization$1(e, h, d, f, g, i), o, s]; + }); + }function normalizeBatchInTraining(e, t, n, r, i) { + return void 0 === i && (i = .001), util.arraysEqual(r.slice().sort(), range$1(0, e.rank - 1)) ? regularNormalizeBatchInTraining(e, t, n, r, i) : broadcastNormalizeBatchInTraining(e, t, n, r, i); + }serialization.SerializationMap.register(Concatenate);var BatchNormalization = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.supportsMasking = !0, n.axis = null == t.axis ? -1 : t.axis, n.momentum = null == t.momentum ? .99 : t.momentum, n.epsilon = null == t.epsilon ? .001 : t.epsilon, n.center = null == t.center || t.center, n.scale = null == t.scale || t.scale, n.betaInitializer = getInitializer(t.betaInitializer || "zeros"), n.gammaInitializer = getInitializer(t.gammaInitializer || "ones"), n.movingMeanInitializer = getInitializer(t.movingMeanInitializer || "zeros"), n.movingVarianceInitializer = getInitializer(t.movingVarianceInitializer || "ones"), n.betaConstraint = getConstraint(t.betaConstraint), n.gammaConstraint = getConstraint(t.gammaConstraint), n.betaRegularizer = getRegularizer(t.betaRegularizer), n.gammaRegularizer = getRegularizer(t.gammaRegularizer), n.stepCount = 0, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + e = getExactlyOneShape(e);var t = this.axis >= 0 ? this.axis : this.axis + e.length, + n = e[t];if (null == n) throw new ValueError("Axis " + t + " of input tensor should have a defined dimension but the layer received an input with shape " + JSON.stringify(e) + ".");this.inputSpec = [new InputSpec({ ndim: e.length, axes: (r = {}, r[t] = n, r) })];var r, + i = [n];this.scale && (this.gamma = this.addWeight("gamma", i, null, this.gammaInitializer, this.gammaRegularizer, !0, this.gammaConstraint)), this.center && (this.beta = this.addWeight("beta", i, null, this.betaInitializer, this.betaRegularizer, !0, this.betaConstraint)), this.movingMean = this.addWeight("moving_mean", i, null, this.movingMeanInitializer, null, !1), this.movingVariance = this.addWeight("moving_variance", i, null, this.movingVarianceInitializer, null, !1), this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var r = null != t.training && t.training, + i = getExactlyOneTensor(e), + a = i.shape, + o = a.length, + s = range$1(0, o), + l = n.axis >= 0 ? n.axis : n.axis + o;s.splice(l, 1);var u = pyListRepeat(1, o);u[l] = a[l];var c = s.slice();c.sort();var p = !util.arraysEqual(c, range$1(0, o).slice(0, o - 1));if (!r) return function () { + if (p) { + var e = n.movingMean.read().reshape(u), + t = n.movingVariance.read().reshape(u), + r = n.center ? n.beta.read().reshape(u) : null, + a = n.scale ? n.gamma.read().reshape(u) : null;return batchNormalization$1(i, e, t, r, a, n.epsilon); + }return batchNormalization$1(i, n.movingMean.read(), n.movingVariance.read(), null == n.beta ? null : n.beta.read(), null == n.gamma ? null : n.gamma.read(), n.epsilon); + }();var h = normalizeBatchInTraining(i, n.gamma.read(), n.beta.read(), s, n.epsilon), + d = h[0], + g = h[1], + f = h[2], + m = arrayProd(s.map(function (e) { + return i.shape[e]; + })), + y = f.mul(getScalar(m / (m - (1 + n.epsilon))));return function () { + n.stepCount++;var e = movingAverage(n.movingMean.read(), g, n.momentum, n.stepCount);n.movingMean.write(e);var t = movingAverage(n.movingVariance.read(), y, n.momentum, n.stepCount);n.movingVariance.write(t); + }(), d; + }); + }, t.prototype.getConfig = function () { + var t = { axis: this.axis, momentum: this.momentum, epsilon: this.epsilon, center: this.center, scale: this.scale, betaInitializer: serializeInitializer(this.betaInitializer), gammaInitializer: serializeInitializer(this.gammaInitializer), movingMeanInitializer: serializeInitializer(this.movingMeanInitializer), movingVarianceInitializer: serializeInitializer(this.movingVarianceInitializer), betaRegularizer: serializeRegularizer(this.betaRegularizer), gammaRegularizer: serializeRegularizer(this.gammaRegularizer), betaConstraint: serializeConstraint(this.betaConstraint), gammaConstraint: serializeConstraint(this.gammaConstraint) }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "BatchNormalization", t; + }(Layer);function spatial2dPadding(e, t, n) { + return tidy(function () { + if (4 !== e.rank) throw new ValueError("temporalPadding expects input tensor to be 4-D, but received a " + e.rank + "-D tensor.");if (null == t && (t = [[1, 1], [1, 1]]), 2 !== t.length || 2 !== t[0].length || 2 !== t[1].length) throw new ValueError("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if (null == n && (n = imageDataFormat()), "channelsLast" !== n && "channelsFirst" !== n) throw new ValueError("Unknown data format: " + n + ". Supported data formats are 'channelsLast' and 'channelsFirst.");var r;return r = "channelsFirst" === n ? [[0, 0], [0, 0], t[0], t[1]] : [[0, 0], t[0], t[1], [0, 0]], pad(e, r); + }); + }serialization.SerializationMap.register(BatchNormalization);var ZeroPadding2D = function (e) { + function t(t) { + var n = this;if (null == t && (t = {}), (n = e.call(this, t) || this).dataFormat = null == t.dataFormat ? imageDataFormat() : t.dataFormat, null == t.padding) n.padding = [[1, 1], [1, 1]];else if ("number" == typeof t.padding) n.padding = [[t.padding, t.padding], [t.padding, t.padding]];else { + if (t.padding = t.padding, 2 !== t.padding.length) throw new ValueError("ZeroPadding2D expects padding to be a length-2 array, but received a length-" + t.padding.length + " array.");var r = void 0, + i = void 0;if ("number" == typeof t.padding[0]) r = [t.padding[0], t.padding[0]], i = [t.padding[1], t.padding[1]];else { + if (t.padding = t.padding, 2 !== t.padding[0].length) throw new ValueError("ZeroPadding2D expects height padding to be a length-2 array, but received a length-" + t.padding[0].length + " array.");if (r = t.padding[0], 2 !== t.padding[1].length) throw new ValueError("ZeroPadding2D expects width padding to be a length-2 array, but received a length-" + t.padding[1].length + " array.");i = t.padding[1]; + }n.padding = [r, i]; + }return n.inputSpec = [new InputSpec({ ndim: 4 })], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + var t, n;return e = getExactlyOneShape(e), "channelsFirst" === this.dataFormat ? (t = null != e[2] && e[2] >= 0 ? e[2] + this.padding[0][0] + this.padding[0][1] : null, n = null != e[3] && e[3] >= 0 ? e[3] + this.padding[1][0] + this.padding[1][1] : null, [e[0], e[1], t, n]) : (t = null != e[1] && e[1] >= 0 ? e[1] + this.padding[0][0] + this.padding[0][1] : null, n = null != e[2] && e[2] >= 0 ? e[2] + this.padding[1][0] + this.padding[1][1] : null, [e[0], t, n, e[3]]); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return spatial2dPadding(getExactlyOneTensor(e), n.padding, n.dataFormat); + }); + }, t.prototype.getConfig = function () { + var t = { padding: this.padding, dataFormat: this.dataFormat }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "ZeroPadding2D", t; + }(Layer);function pool2d(e, t, n, r, i, a) { + return tidy(function () { + var o;checkDataFormat(i), checkPoolMode(a), checkPaddingMode(r), null == n && (n = [1, 1]), null == r && (r = "valid"), null == i && (i = imageDataFormat()), null == a && (a = "max"), e = preprocessConv2DInput(e, i);var s = "same" === r ? "same" : "valid";return o = "max" === a ? maxPool(e, t, n, s) : avgPool(e, t, n, s), "channelsFirst" === i && (o = transpose(o, [0, 3, 1, 2])), o; + }); + }serialization.SerializationMap.register(ZeroPadding2D);var Pooling1D = function (e) { + function t(t) { + var n = this;if (null == t.poolSize && (t.poolSize = 2), n = e.call(this, t) || this, "number" == typeof t.poolSize) n.poolSize = [t.poolSize];else { + if (!Array.isArray(t.poolSize) || 1 !== t.poolSize.length || "number" != typeof t.poolSize[0]) throw new ValueError("poolSize for 1D convolutional layer must be a number or an Array of a single number, but received " + JSON.stringify(t.poolSize));n.poolSize = t.poolSize; + }if (null == t.strides) n.strides = n.poolSize;else if ("number" == typeof t.strides) n.strides = [t.strides];else { + if (!Array.isArray(t.strides) || 1 !== t.strides.length || "number" != typeof t.strides[0]) throw new ValueError("strides for 1D convolutional layer must be a number or an Array of a single number, but received " + JSON.stringify(t.strides));n.strides = t.strides; + }return n.padding = null == t.padding ? "valid" : t.padding, checkPaddingMode(n.padding), n.inputSpec = [new InputSpec({ ndim: 3 })], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + var t = convOutputLength((e = getExactlyOneShape(e))[1], this.poolSize[0], this.padding, this.strides[0]);return [e[0], t, e[2]]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + n.invokeCallHook(e, t), e = expandDims$1(getExactlyOneTensor(e), 2);var r = n.poolingFunction(getExactlyOneTensor(e), [n.poolSize[0], 1], [n.strides[0], 1], n.padding, "channelsLast");return squeeze(r, [2]); + }); + }, t.prototype.getConfig = function () { + var t = { poolSize: this.poolSize, padding: this.padding, strides: this.strides }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t; + }(Layer), + MaxPooling1D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.poolingFunction = function (e, t, n, r, i) { + return checkDataFormat(i), checkPaddingMode(r), pool2d(e, t, n, r, i, "max"); + }, t.className = "MaxPooling1D", t; + }(Pooling1D);serialization.SerializationMap.register(MaxPooling1D);var AveragePooling1D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.poolingFunction = function (e, t, n, r, i) { + return checkDataFormat(i), checkPaddingMode(r), pool2d(e, t, n, r, i, "avg"); + }, t.className = "AveragePooling1D", t; + }(Pooling1D);serialization.SerializationMap.register(AveragePooling1D);var Pooling2D = function (e) { + function t(t) { + var n = this;if (null == t.poolSize && (t.poolSize = [2, 2]), (n = e.call(this, t) || this).poolSize = Array.isArray(t.poolSize) ? t.poolSize : [t.poolSize, t.poolSize], null == t.strides) n.strides = n.poolSize;else if (Array.isArray(t.strides)) { + if (2 !== t.strides.length) throw new ValueError("If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length " + t.strides.length + ".");n.strides = t.strides; + } else n.strides = [t.strides, t.strides];return n.padding = null == t.padding ? "valid" : t.padding, n.dataFormat = null == t.dataFormat ? "channelsLast" : t.dataFormat, checkDataFormat(n.dataFormat), checkPaddingMode(n.padding), n.inputSpec = [new InputSpec({ ndim: 4 })], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + e = getExactlyOneShape(e);var t = "channelsFirst" === this.dataFormat ? e[2] : e[1], + n = "channelsFirst" === this.dataFormat ? e[3] : e[2];return t = convOutputLength(t, this.poolSize[0], this.padding, this.strides[0]), n = convOutputLength(n, this.poolSize[1], this.padding, this.strides[1]), "channelsFirst" === this.dataFormat ? [e[0], e[1], t, n] : [e[0], t, n, e[3]]; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return n.invokeCallHook(e, t), n.poolingFunction(getExactlyOneTensor(e), n.poolSize, n.strides, n.padding, n.dataFormat); + }); + }, t.prototype.getConfig = function () { + var t = { poolSize: this.poolSize, padding: this.padding, strides: this.strides, dataFormat: this.dataFormat }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t; + }(Layer), + MaxPooling2D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.poolingFunction = function (e, t, n, r, i) { + return checkDataFormat(i), checkPaddingMode(r), pool2d(e, t, n, r, i, "max"); + }, t.className = "MaxPooling2D", t; + }(Pooling2D);serialization.SerializationMap.register(MaxPooling2D);var AveragePooling2D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.poolingFunction = function (e, t, n, r, i) { + return checkDataFormat(i), checkPaddingMode(r), pool2d(e, t, n, r, i, "avg"); + }, t.className = "AveragePooling2D", t; + }(Pooling2D);serialization.SerializationMap.register(AveragePooling2D);var GlobalPooling1D = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.inputSpec = [new InputSpec({ ndim: 3 })], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + return [e[0], e[2]]; + }, t.prototype.call = function (e, t) { + throw new NotImplementedError(); + }, t; + }(Layer), + GlobalAveragePooling1D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + return tidy(function () { + var t = getExactlyOneTensor(e);return mean(t, 1); + }); + }, t.className = "GlobalAveragePooling1D", t; + }(GlobalPooling1D);serialization.SerializationMap.register(GlobalAveragePooling1D);var GlobalMaxPooling1D = function (e) { + function t(t) { + return e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + return tidy(function () { + var t = getExactlyOneTensor(e);return max(t, 1); + }); + }, t.className = "GlobalMaxPooling1D", t; + }(GlobalPooling1D);serialization.SerializationMap.register(GlobalMaxPooling1D);var GlobalPooling2D = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.dataFormat = null == t.dataFormat ? "channelsLast" : t.dataFormat, checkDataFormat(n.dataFormat), n.inputSpec = [new InputSpec({ ndim: 4 })], n; + }return __extends$1(t, e), t.prototype.computeOutputShape = function (e) { + return e = e, "channelsLast" === this.dataFormat ? [e[0], e[3]] : [e[0], e[1]]; + }, t.prototype.call = function (e, t) { + throw new NotImplementedError(); + }, t.prototype.getConfig = function () { + var t = { dataFormat: this.dataFormat }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t; + }(Layer), + GlobalAveragePooling2D = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t = getExactlyOneTensor(e);return "channelsLast" === n.dataFormat ? mean(t, [1, 2]) : mean(t, [2, 3]); + }); + }, t.className = "GlobalAveragePooling2D", t; + }(GlobalPooling2D);serialization.SerializationMap.register(GlobalAveragePooling2D);var GlobalMaxPooling2D = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var t = getExactlyOneTensor(e);return "channelsLast" === n.dataFormat ? max(t, [1, 2]) : max(t, [2, 3]); + }); + }, t.className = "GlobalMaxPooling2D", t; + }(GlobalPooling2D);function standardizeArgs(e, t, n, r) { + if (Array.isArray(e)) { + if (null != t || null != n) throw new ValueError("When inputs is an array, neither initialState or constants should be provided");null != r && (n = e.slice(e.length - r, e.length), e = e.slice(0, e.length - r)), e.length > 1 && (t = e.slice(1, e.length)), e = e[0]; + }function i(e) { + return null == e || Array.isArray(e) ? e : [e]; + }return { inputs: e, initialState: t = i(t), constants: n = i(n) }; + }function rnn(e, t, n, r, i, a, o, s) { + void 0 === r && (r = !1), void 0 === o && (o = !1);var l = t.shape.length;if (l < 3) throw new ValueError("Input should be at least 3D, but is " + l + "D.");var u, + c, + p = [1, 0].concat(range$1(2, l));if (t = transpose(t, p), null != i) throw new NotImplementedError("The rnn() function of the deeplearn.js backend does not support masking yet.");if (null != a) throw new NotImplementedError("The rnn() functoin of the deeplearn.js backend does not support constants yet.");o && console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."), r && (t = reverse(t, 0));for (var h = n, d = t.shape[0], g = 0; g < d; ++g) { + var f = sliceAlongFirstAxis(t, g, 1), + m = e(f = f.reshape(f.shape.slice(1)), h);c = m[0], u = 0 === g ? c.reshape([1].concat(c.shape)) : concatAlongFirstAxis(u, c.reshape([1].concat(c.shape))), h = m[1]; + }return [c, transpose(u, [1, 0].concat(range$1(2, u.shape.length))), h]; + }serialization.SerializationMap.register(GlobalMaxPooling2D);var RNN = function (e) { + function t(t) { + var n, + r = e.call(this, t) || this;if (null == t.cell) throw new ValueError("cell property is missing for the constructor of RNN.");if (null == (n = Array.isArray(t.cell) ? new StackedRNNCells({ cells: t.cell }) : t.cell).stateSize) throw new ValueError("The RNN cell should have an attribute `stateSize` (tuple of integers, one integer per RNN state).");return r.cell = n, r.returnSequences = null != t.returnSequences && t.returnSequences, r.returnState = null != t.returnState && t.returnState, r.goBackwards = null != t.goBackwards && t.goBackwards, r._stateful = null != t.stateful && t.stateful, r.unroll = null != t.unroll && t.unroll, r.supportsMasking = !0, r.inputSpec = [new InputSpec({ ndim: 3 })], r.stateSpec = null, r.states = null, r.numConstants = null, r; + }return __extends$1(t, e), t.prototype.getStates = function () { + return null == this.states ? range$1(0, Array.isArray(this.cell.stateSize) ? this.cell.stateSize.length : 1).map(function (e) { + return null; + }) : this.states; + }, t.prototype.setStates = function (e) { + this.states = e; + }, t.prototype.computeOutputShape = function (e) { + isArrayOfShapes(e) && (e = e[0]), e = e;var t = this.cell.stateSize;Array.isArray(t) || (t = [t]);var n, + r = t[0];if (n = this.returnSequences ? [e[0], e[1], r] : [e[0], r], this.returnState) { + for (var i = [], a = 0, o = t; a < o.length; a++) { + var s = o[a];i.push([e[0], s]); + }return [n].concat(i); + }return n; + }, t.prototype.computeMask = function (e, t) { + throw new NotImplementedError("computeMask has not been implemented for RNN yet"); + }, t.prototype.build = function (e) { + if (null != this.numConstants) throw new NotImplementedError("Constants support is not implemented in RNN yet.");isArrayOfShapes(e) && (e = e[0]), e = e;var t = this.stateful ? e[0] : null, + n = e[e.length - 1];this.inputSpec[0] = new InputSpec({ shape: [t, null, n] });var r, + i = [e[0]].concat(e.slice(2));if (this.cell.build(i), r = Array.isArray(this.cell.stateSize) ? this.cell.stateSize : [this.cell.stateSize], null != this.stateSpec) { + if (!util.arraysEqual(this.stateSpec.map(function (e) { + return e.shape[e.shape.length - 1]; + }), r)) throw new ValueError("An initialState was passed that is not compatible with cell.stateSize. Received stateSpec=" + this.stateSpec + "; However cell.stateSize is " + this.cell.stateSize); + } else this.stateSpec = r.map(function (e) { + return new InputSpec({ shape: [null, e] }); + });if (this.stateful) throw new NotImplementedError("stateful RNN layer is not implemented yet"); + }, t.prototype.resetStates = function (e) { + var t = this;tidy(function () { + if (!t.stateful) throw new AttributeError("Cannot call resetState() on an RNN Layer that is not stateful.");var n = t.inputSpec[0].shape[0];if (null == n) throw new ValueError("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if (null == t.states) Array.isArray(t.cell.stateSize) ? t.states = t.cell.stateSize.map(function (e) { + return zeros([n, e]); + }) : t.states = [zeros([n, t.cell.stateSize])];else if (null == e) Array.isArray(t.cell.stateSize) ? t.states = t.cell.stateSize.map(function (e) { + return zeros([n, e]); + }) : t.states[0] = zeros([n, t.cell.stateSize]);else { + if (Array.isArray(e) || (e = [e]), e.length !== t.states.length) throw new ValueError("Layer " + t.name + " expects " + t.states.length + " state(s), but it received " + e.length + " state value(s). Input received: " + e);for (var r = 0; r < t.states.length; ++r) { + var i = e[r], + a = Array.isArray(t.cell.stateSize) ? t.cell.stateSize[r] : t.cell.stateSize, + o = [n, a];if (!util.arraysEqual(i.shape, o)) throw new ValueError("State " + r + " is incompatible with layer " + t.name + ": expected shape=" + o + ", received shape=" + i.shape);t.states[r] = i; + } + } + }); + }, t.prototype.apply = function (t, n) { + var r = null == n ? null : n.initialState, + i = null == n ? null : n.constants;null == n && (n = {});var a = standardizeArgs(t, r, i, this.numConstants);t = a.inputs, r = a.initialState, i = a.constants;var o = [], + s = [];if (null != r) { + n.initialState = r, o = o.concat(r), this.stateSpec = [];for (var l = 0, u = r; l < u.length; l++) { + var c = u[l];this.stateSpec.push(new InputSpec({ shape: c.shape })); + }s = s.concat(this.stateSpec); + }if (null != i && (n.constants = i, o = o.concat(i), this.numConstants = i.length), o[0] instanceof SymbolicTensor) { + var p = [t].concat(o), + h = this.inputSpec.concat(s), + d = this.inputSpec;this.inputSpec = h;var g = e.prototype.apply.call(this, p, n);return this.inputSpec = d, g; + }return e.prototype.apply.call(this, t, n); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var r = null == t ? null : t.mask, + i = null == t ? null : t.training, + a = null == t ? null : t.initialState;if (e = getExactlyOneTensor(e), null == a) { + if (n.stateful) throw new NotImplementedError("stateful RNN layer is not implemented yet.");a = n.getInitialState(e); + }if (null != r) throw new NotImplementedError("Masking is not implemented for RNN yet");var o = Array.isArray(n.cell.stateSize) ? n.cell.stateSize.length : 1;if (a.length !== o) throw new ValueError("RNN Layer has " + o + " state(s) but was passed " + a.length + " initial state(s).");var s = e.shape[1];n.unroll && console.warn("Ignoring unroll = true for RNN layer, due to imperative backend.");var l = { training: i }, + u = rnn(function (e, t) { + var r = n.cell.call([e].concat(t), l);return [r[0], r.slice(1)]; + }, e, a, n.goBackwards, null, null, n.unroll, s), + c = u[0], + p = u[1], + h = u[2];if (n.stateful) throw new NotImplementedError("stateful RNN layer is not implemented yet");var d = n.returnSequences ? p : c;return n.returnState ? [d].concat(h) : d; + }); + }, t.prototype.getInitialState = function (e) { + var t = this;return tidy(function () { + var n = zeros(e.shape);return n = expandDims$1(n = sum(n, [1, 2])), Array.isArray(t.cell.stateSize) ? t.cell.stateSize.map(function (e) { + return e > 1 ? tile$1(n, [1, e]) : n; + }) : t.cell.stateSize > 1 ? [tile$1(n, [1, t.cell.stateSize])] : [n]; + }); + }, Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + return this.trainable ? this.cell.trainableWeights : []; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + return this.trainable ? this.cell.nonTrainableWeights : this.cell.weights; + }, enumerable: !0, configurable: !0 }), t.prototype.getConfig = function () { + var t = { returnSequences: this.returnSequences, returnState: this.returnState, goBackwards: this.goBackwards, stateful: this.stateful, unroll: this.unroll };null != this.numConstants && (t.numConstants = this.numConstants);var n = this.cell.getConfig();t.cell = { className: this.cell.getClassName(), config: n };var r = e.prototype.getConfig.call(this);return Object.assign(t, r), t; + }, t.className = "RNN", t; + }(Layer);serialization.SerializationMap.register(RNN);var RNNCell = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t; + }(Layer), + SimpleRNNCell = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.DEFAULT_ACTIVATION = "tanh", n.DEFAULT_KERNEL_INITIALIZER = "glorotNormal", n.DEFAULT_RECURRENT_INITIALIZER = "orthogonal", n.DEFAULT_BIAS_INITIALIZER = "zeros", n.units = t.units, n.activation = getActivation(null == t.activation ? n.DEFAULT_ACTIVATION : t.activation), n.useBias = null == t.useBias || t.useBias, n.kernelInitializer = getInitializer(t.kernelInitializer || n.DEFAULT_KERNEL_INITIALIZER), n.recurrentInitializer = getInitializer(t.recurrentInitializer || n.DEFAULT_RECURRENT_INITIALIZER), n.biasInitializer = getInitializer(t.biasInitializer || n.DEFAULT_BIAS_INITIALIZER), n.kernelRegularizer = getRegularizer(t.kernelRegularizer), n.recurrentRegularizer = getRegularizer(t.recurrentRegularizer), n.biasRegularizer = getRegularizer(t.biasRegularizer), n.kernelConstraint = getConstraint(t.kernelConstraint), n.recurrentConstraint = getConstraint(t.recurrentConstraint), n.biasConstraint = getConstraint(t.biasConstraint), n.dropout = min$1([1, max$1([0, null == t.dropout ? 0 : t.dropout])]), n.recurrentDropout = min$1([1, max$1([0, null == t.recurrentDropout ? 0 : t.recurrentDropout])]), n.stateSize = n.units, n.dropoutMask = null, n.recurrentDropoutMask = null, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + e = getExactlyOneShape(e), this.kernel = this.addWeight("kernel", [e[e.length - 1], this.units], null, this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.recurrentKernel = this.addWeight("recurrent_kernel", [this.units, this.units], null, this.recurrentInitializer, this.recurrentRegularizer, !0, this.recurrentConstraint), this.useBias ? this.bias = this.addWeight("bias", [this.units], null, this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint) : this.bias = null, this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + if (2 !== (e = e).length) throw new ValueError("SimpleRNNCell expects 2 input Tensors, got " + e.length + ".");var r = e[1];e = e[0];var i, + a = null != t.training && t.training;0 < n.dropout && n.dropout < 1 && null == n.dropoutMask && (n.dropoutMask = generateDropoutMask(function () { + return onesLike(e); + }, n.dropout, a)), 0 < n.recurrentDropout && n.recurrentDropout < 1 && null == n.recurrentDropoutMask && (n.recurrentDropoutMask = generateDropoutMask(function () { + return onesLike(r); + }, n.recurrentDropout, a));var o = n.dropoutMask, + s = n.recurrentDropoutMask;i = dot$1(null != o ? mul(e, o) : e, n.kernel.read()), null != n.bias && (i = biasAdd(i, n.bias.read())), null != s && (r = mul(r, s));var l = add(i, dot$1(r, n.recurrentKernel.read()));return null != n.activation && (l = n.activation.apply(l)), [l, l]; + }); + }, t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "SimpleRNNCell", t; + }(RNNCell);serialization.SerializationMap.register(SimpleRNNCell);var SimpleRNN = function (e) { + function t(t) { + return t.cell = new SimpleRNNCell(t), e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.call = function (t, n) { + var r = this;return tidy(function () { + null != r.cell.dropoutMask && (dispose(r.cell.dropoutMask), r.cell.dropoutMask = null), null != r.cell.recurrentDropoutMask && (dispose(r.cell.recurrentDropoutMask), r.cell.recurrentDropoutMask = null);var i = null == n ? null : n.mask, + a = null == n ? null : n.training, + o = null == n ? null : n.initialState;return e.prototype.call.call(r, t, { mask: i, training: a, initialState: o }); + }); + }, Object.defineProperty(t.prototype, "units", { get: function () { + return this.cell.units; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "activation", { get: function () { + return this.cell.activation; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "useBias", { get: function () { + return this.cell.useBias; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelInitializer", { get: function () { + return this.cell.kernelInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentInitializer", { get: function () { + return this.cell.recurrentInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasInitializer", { get: function () { + return this.cell.biasInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelRegularizer", { get: function () { + return this.cell.kernelRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentRegularizer", { get: function () { + return this.cell.recurrentRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasRegularizer", { get: function () { + return this.cell.biasRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelConstraint", { get: function () { + return this.cell.kernelConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentConstraint", { get: function () { + return this.cell.recurrentConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasConstraint", { get: function () { + return this.cell.biasConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "dropout", { get: function () { + return this.cell.dropout; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentDropout", { get: function () { + return this.cell.recurrentDropout; + }, enumerable: !0, configurable: !0 }), t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout }, + n = e.prototype.getConfig.call(this);return delete n.cell, Object.assign(t, n), t; + }, t.className = "SimpleRNN", t; + }(RNN);serialization.SerializationMap.register(SimpleRNN);var GRUCell = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.DEFAULT_ACTIVATION = "tanh", n.DEFAULT_RECURRENT_ACTIVATION = "hardSigmoid", n.DEFAULT_KERNEL_INITIALIZER = "glorotNormal", n.DEFAULT_RECURRENT_INITIALIZER = "orthogonal", n.DEFAULT_BIAS_INITIALIZER = "zeros", n.units = t.units, n.activation = getActivation(void 0 === t.activation ? n.DEFAULT_ACTIVATION : t.activation), n.recurrentActivation = getActivation(void 0 === t.recurrentActivation ? n.DEFAULT_RECURRENT_ACTIVATION : t.recurrentActivation), n.useBias = null == t.useBias || t.useBias, n.kernelInitializer = getInitializer(t.kernelInitializer || n.DEFAULT_KERNEL_INITIALIZER), n.recurrentInitializer = getInitializer(t.recurrentInitializer || n.DEFAULT_RECURRENT_INITIALIZER), n.biasInitializer = getInitializer(t.biasInitializer || n.DEFAULT_BIAS_INITIALIZER), n.kernelRegularizer = getRegularizer(t.kernelRegularizer), n.recurrentRegularizer = getRegularizer(t.recurrentRegularizer), n.biasRegularizer = getRegularizer(t.biasRegularizer), n.kernelConstraint = getConstraint(t.kernelConstraint), n.recurrentConstraint = getConstraint(t.recurrentConstraint), n.biasConstraint = getConstraint(t.biasConstraint), n.dropout = min$1([1, max$1([0, null == t.dropout ? 0 : t.dropout])]), n.recurrentDropout = min$1([1, max$1([0, null == t.recurrentDropout ? 0 : t.recurrentDropout])]), n.implementation = t.implementation, n.stateSize = n.units, n.dropoutMask = null, n.recurrentDropoutMask = null, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + var t = (e = getExactlyOneShape(e))[e.length - 1];this.kernel = this.addWeight("kernel", [t, 3 * this.units], null, this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.recurrentKernel = this.addWeight("recurrent_kernel", [this.units, 3 * this.units], null, this.recurrentInitializer, this.recurrentRegularizer, !0, this.recurrentConstraint), this.useBias ? this.bias = this.addWeight("bias", [3 * this.units], null, this.biasInitializer, this.biasRegularizer, !0, this.biasConstraint) : this.bias = null, this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + if (2 !== (e = e).length) throw new ValueError("GRUCell expects 2 input Tensors (inputs, h, c), got " + e.length + ".");var r = null != t.training && t.training, + i = e[1];e = e[0], 0 < n.dropout && n.dropout < 1 && null == n.dropoutMask && (n.dropoutMask = generateDropoutMask(function () { + return onesLike(e); + }, n.dropout, r, 3)), 0 < n.recurrentDropout && n.recurrentDropout < 1 && null == n.recurrentDropoutMask && (n.recurrentDropoutMask = generateDropoutMask(function () { + return onesLike(i); + }, n.recurrentDropout, r, 3));var a, + o, + s, + l = n.dropoutMask, + u = n.recurrentDropoutMask;if (1 === n.implementation) { + var c = sliceAlongLastAxis(n.kernel.read(), 0, n.units), + p = sliceAlongLastAxis(n.kernel.read(), n.units, n.units), + h = sliceAlongLastAxis(n.kernel.read(), 2 * n.units, n.units), + d = sliceAlongLastAxis(n.recurrentKernel.read(), 0, n.units), + g = sliceAlongLastAxis(n.recurrentKernel.read(), n.units, n.units), + f = sliceAlongLastAxis(n.recurrentKernel.read(), 2 * n.units, n.units), + m = void 0, + y = void 0, + v = void 0;0 < n.dropout && n.dropout < 1 ? (m = mul(e, l[0]), y = mul(e, l[1]), v = mul(e, l[2])) : (m = e, y = e, v = e);var b = dot$1(m, c), + z = dot$1(y, p), + w = dot$1(v, h);if (n.useBias) { + var S = sliceAlongFirstAxis(n.bias.read(), 0, n.units), + A = sliceAlongFirstAxis(n.bias.read(), n.units, n.units), + I = sliceAlongFirstAxis(n.bias.read(), 2 * n.units, n.units);b = biasAdd(b, S), z = biasAdd(z, A), w = biasAdd(w, I); + }var N = void 0, + E = void 0, + _ = void 0;0 < n.recurrentDropout && n.recurrentDropout < 1 ? (N = mul(i, u[0]), E = mul(i, u[1]), _ = mul(i, u[2])) : (N = i, E = i, _ = i), a = n.recurrentActivation.apply(add(b, dot$1(N, d))), o = n.recurrentActivation.apply(add(z, dot$1(E, g))), s = n.activation.apply(add(w, dot$1(mul(o, _), f))); + } else { + 0 < n.dropout && n.dropout < 1 && (e = mul(e, l[0]));var k = dot$1(e, n.kernel.read());n.useBias && (k = biasAdd(k, n.bias.read())), 0 < n.dropout && n.dropout < 1 && (i = mul(i, u[0]));var C = dot$1(i, sliceAlongLastAxis(n.recurrentKernel.read(), 0, 2 * n.units)), + L = (b = sliceAlongLastAxis(k, 0, n.units), z = sliceAlongLastAxis(k, n.units, n.units), sliceAlongLastAxis(C, 0, n.units)), + x = sliceAlongLastAxis(C, n.units, n.units);a = n.recurrentActivation.apply(add(b, L)), o = n.recurrentActivation.apply(add(z, x));w = sliceAlongLastAxis(k, 2 * n.units, n.units);var T = dot$1(mul(o, i), sliceAlongLastAxis(n.recurrentKernel.read(), 2 * n.units, n.units));s = n.activation.apply(add(w, T)); + }var R = add(mul(a, i), mul(add(getScalar(1), neg(a)), s));return [R, R]; + }); + }, t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), recurrentActivation: serializeActivation(this.recurrentActivation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout, implementation: this.implementation }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "GRUCell", t; + }(RNNCell);serialization.SerializationMap.register(GRUCell);var GRU = function (e) { + function t(t) { + return 0 === t.implementation && console.warn("`implementation=0` has been deprecated, and now defaults to `implementation=1`. Please update your layer call."), t.cell = new GRUCell(t), e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.call = function (t, n) { + var r = this;return tidy(function () { + null != r.cell.dropoutMask && (dispose(r.cell.dropoutMask), r.cell.dropoutMask = null), null != r.cell.recurrentDropoutMask && (dispose(r.cell.recurrentDropoutMask), r.cell.recurrentDropoutMask = null);var i = null == n ? null : n.mask, + a = null == n ? null : n.training, + o = null == n ? null : n.initialState;return e.prototype.call.call(r, t, { mask: i, training: a, initialState: o }); + }); + }, Object.defineProperty(t.prototype, "units", { get: function () { + return this.cell.units; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "activation", { get: function () { + return this.cell.activation; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentActivation", { get: function () { + return this.cell.recurrentActivation; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "useBias", { get: function () { + return this.cell.useBias; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelInitializer", { get: function () { + return this.cell.kernelInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentInitializer", { get: function () { + return this.cell.recurrentInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasInitializer", { get: function () { + return this.cell.biasInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelRegularizer", { get: function () { + return this.cell.kernelRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentRegularizer", { get: function () { + return this.cell.recurrentRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasRegularizer", { get: function () { + return this.cell.biasRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelConstraint", { get: function () { + return this.cell.kernelConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentConstraint", { get: function () { + return this.cell.recurrentConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasConstraint", { get: function () { + return this.cell.biasConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "dropout", { get: function () { + return this.cell.dropout; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentDropout", { get: function () { + return this.cell.recurrentDropout; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "implementation", { get: function () { + return this.cell.implementation; + }, enumerable: !0, configurable: !0 }), t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), recurrentActivation: serializeActivation(this.recurrentActivation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout, implementation: this.implementation }, + n = e.prototype.getConfig.call(this);return delete n.cell, Object.assign(t, n), t; + }, t.fromConfig = function (e, t) { + return 0 === t.implmentation && (t.implementation = 1), new e(t); + }, t.className = "GRU", t; + }(RNN);serialization.SerializationMap.register(GRU);var LSTMCell = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.DEFAULT_ACTIVATION = "tanh", n.DEFAULT_RECURRENT_ACTIVATION = "hardSigmoid", n.DEFAULT_KERNEL_INITIALIZER = "glorotNormal", n.DEFAULT_RECURRENT_INITIALIZER = "orthogonal", n.DEFAULT_BIAS_INITIALIZER = "zeros", n.units = t.units, n.activation = getActivation(void 0 === t.activation ? n.DEFAULT_ACTIVATION : t.activation), n.recurrentActivation = getActivation(void 0 === t.recurrentActivation ? n.DEFAULT_RECURRENT_ACTIVATION : t.recurrentActivation), n.useBias = null == t.useBias || t.useBias, n.kernelInitializer = getInitializer(t.kernelInitializer || n.DEFAULT_KERNEL_INITIALIZER), n.recurrentInitializer = getInitializer(t.recurrentInitializer || n.DEFAULT_RECURRENT_INITIALIZER), n.biasInitializer = getInitializer(t.biasInitializer || n.DEFAULT_BIAS_INITIALIZER), n.unitForgetBias = t.unitForgetBias, n.kernelRegularizer = getRegularizer(t.kernelRegularizer), n.recurrentRegularizer = getRegularizer(t.recurrentRegularizer), n.biasRegularizer = getRegularizer(t.biasRegularizer), n.kernelConstraint = getConstraint(t.kernelConstraint), n.recurrentConstraint = getConstraint(t.recurrentConstraint), n.biasConstraint = getConstraint(t.biasConstraint), n.dropout = min$1([1, max$1([0, null == t.dropout ? 0 : t.dropout])]), n.recurrentDropout = min$1([1, max$1([0, null == t.recurrentDropout ? 0 : t.recurrentDropout])]), n.implementation = t.implementation, n.stateSize = [n.units, n.units], n.dropoutMask = null, n.recurrentDropoutMask = null, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + var t, + n, + r = (e = getExactlyOneShape(e))[e.length - 1];if (this.kernel = this.addWeight("kernel", [r, 4 * this.units], null, this.kernelInitializer, this.kernelRegularizer, !0, this.kernelConstraint), this.recurrentKernel = this.addWeight("recurrent_kernel", [this.units, 4 * this.units], null, this.recurrentInitializer, this.recurrentRegularizer, !0, this.recurrentConstraint), this.useBias) { + if (this.unitForgetBias) { + var i = this.biasInitializer, + a = this.units;t = new ((n = function (e) { + function t() { + return null !== e && e.apply(this, arguments) || this; + }return __extends$1(t, e), t.prototype.apply = function (e, t) { + var n = i.apply([a]), + r = new Ones().apply([a]), + o = i.apply([2 * a]);return concatAlongFirstAxis(concatAlongFirstAxis(n, r), o); + }, t; + }(Initializer)).className = "CustomInit", n)(); + } else t = this.biasInitializer;this.bias = this.addWeight("bias", [4 * this.units], null, t, this.biasRegularizer, !0, this.biasConstraint); + } else this.bias = null;this.built = !0; + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + var r = null != t.training && t.training;if (3 !== (e = e).length) throw new ValueError("LSTMCell expects 3 input Tensors (inputs, h, c), got " + e.length + ".");var i = e[1], + a = e[2];e = e[0], 0 < n.dropout && n.dropout < 1 && null == n.dropoutMask && (n.dropoutMask = generateDropoutMask(function () { + return onesLike(e); + }, n.dropout, r, 4)), 0 < n.recurrentDropout && n.recurrentDropout < 1 && null == n.recurrentDropoutMask && (n.recurrentDropoutMask = generateDropoutMask(function () { + return onesLike(i); + }, n.recurrentDropout, r, 4));var o, + s, + l, + u, + c = n.dropoutMask, + p = n.recurrentDropoutMask;if (1 === n.implementation) { + var h = sliceAlongLastAxis(n.kernel.read(), 0, n.units), + d = sliceAlongLastAxis(n.kernel.read(), n.units, n.units), + g = sliceAlongLastAxis(n.kernel.read(), 2 * n.units, n.units), + f = sliceAlongLastAxis(n.kernel.read(), 3 * n.units, n.units), + m = sliceAlongLastAxis(n.recurrentKernel.read(), 0, n.units), + y = sliceAlongLastAxis(n.recurrentKernel.read(), n.units, n.units), + v = sliceAlongLastAxis(n.recurrentKernel.read(), 2 * n.units, n.units), + b = sliceAlongLastAxis(n.recurrentKernel.read(), 3 * n.units, n.units), + z = void 0, + w = void 0, + S = void 0, + A = void 0;0 < n.dropout && n.dropout < 1 ? (z = mul(e, c[0]), w = mul(e, c[1]), S = mul(e, c[2]), A = mul(e, c[3])) : (z = e, w = e, S = e, A = e);var I = dot$1(z, h), + N = dot$1(w, d), + E = dot$1(S, g), + _ = dot$1(A, f);if (n.useBias) { + var k = sliceAlongFirstAxis(n.bias.read(), 0, n.units), + C = sliceAlongFirstAxis(n.bias.read(), n.units, n.units), + L = sliceAlongFirstAxis(n.bias.read(), 2 * n.units, n.units), + x = sliceAlongFirstAxis(n.bias.read(), 3 * n.units, n.units);I = biasAdd(I, k), N = biasAdd(N, C), E = biasAdd(E, L), _ = biasAdd(_, x); + }var T = void 0, + R = void 0, + O = void 0, + D = void 0;0 < n.recurrentDropout && n.recurrentDropout < 1 ? (T = mul(i, p[0]), R = mul(i, p[1]), O = mul(i, p[2]), D = mul(i, p[3])) : (T = i, R = i, O = i, D = i), o = n.recurrentActivation.apply(add(I, dot$1(T, m))), s = n.recurrentActivation.apply(add(N, dot$1(R, y))), l = add(mul(s, a), mul(o, n.activation.apply(add(E, dot$1(O, v))))), u = n.recurrentActivation.apply(add(_, dot$1(D, b))); + } else { + 0 < n.dropout && n.dropout < 1 && (e = mul(e, c[0]));var M = dot$1(e, n.kernel.read());0 < n.recurrentDropout && n.recurrentDropout < 1 && (i = mul(i, p[0])), M = add(M, dot$1(i, n.recurrentKernel.read())), n.useBias && (M = biasAdd(M, n.bias.read()));var P = sliceAlongLastAxis(M, 0, n.units), + F = sliceAlongLastAxis(M, n.units, n.units), + V = sliceAlongLastAxis(M, 2 * n.units, n.units), + B = sliceAlongLastAxis(M, 3 * n.units, n.units);o = n.recurrentActivation.apply(P), s = n.recurrentActivation.apply(F), l = add(mul(s, a), mul(o, n.activation.apply(V))), u = n.recurrentActivation.apply(B); + }var U = mul(u, n.activation.apply(l));return [U, U, l]; + }); + }, t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), recurrentActivation: serializeActivation(this.recurrentActivation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), unitForgetBias: this.unitForgetBias, kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout, implementation: this.implementation }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.className = "LSTMCell", t; + }(RNNCell);serialization.SerializationMap.register(LSTMCell);var LSTM = function (e) { + function t(t) { + return 0 === t.implementation && console.warn("`implementation=0` has been deprecated, and now defaults to `implementation=1`. Please update your layer call."), t.cell = new LSTMCell(t), e.call(this, t) || this; + }return __extends$1(t, e), t.prototype.call = function (t, n) { + var r = this;return tidy(function () { + null != r.cell.dropoutMask && (dispose(r.cell.dropoutMask), r.cell.dropoutMask = null), null != r.cell.recurrentDropoutMask && (dispose(r.cell.recurrentDropoutMask), r.cell.recurrentDropoutMask = null);var i = null == n ? null : n.mask, + a = null == n ? null : n.training, + o = null == n ? null : n.initialState;return e.prototype.call.call(r, t, { mask: i, training: a, initialState: o }); + }); + }, Object.defineProperty(t.prototype, "units", { get: function () { + return this.cell.units; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "activation", { get: function () { + return this.cell.activation; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentActivation", { get: function () { + return this.cell.recurrentActivation; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "useBias", { get: function () { + return this.cell.useBias; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelInitializer", { get: function () { + return this.cell.kernelInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentInitializer", { get: function () { + return this.cell.recurrentInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasInitializer", { get: function () { + return this.cell.biasInitializer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "unitForgetBias", { get: function () { + return this.cell.unitForgetBias; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelRegularizer", { get: function () { + return this.cell.kernelRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentRegularizer", { get: function () { + return this.cell.recurrentRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasRegularizer", { get: function () { + return this.cell.biasRegularizer; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "kernelConstraint", { get: function () { + return this.cell.kernelConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentConstraint", { get: function () { + return this.cell.recurrentConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "biasConstraint", { get: function () { + return this.cell.biasConstraint; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "dropout", { get: function () { + return this.cell.dropout; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "recurrentDropout", { get: function () { + return this.cell.recurrentDropout; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "implementation", { get: function () { + return this.cell.implementation; + }, enumerable: !0, configurable: !0 }), t.prototype.getConfig = function () { + var t = { units: this.units, activation: serializeActivation(this.activation), recurrentActivation: serializeActivation(this.recurrentActivation), useBias: this.useBias, kernelInitializer: serializeInitializer(this.kernelInitializer), recurrentInitializer: serializeInitializer(this.recurrentInitializer), biasInitializer: serializeInitializer(this.biasInitializer), unitForgetBias: this.unitForgetBias, kernelRegularizer: serializeRegularizer(this.kernelRegularizer), recurrentRegularizer: serializeRegularizer(this.recurrentRegularizer), biasRegularizer: serializeRegularizer(this.biasRegularizer), activityRegularizer: serializeRegularizer(this.activityRegularizer), kernelConstraint: serializeConstraint(this.kernelConstraint), recurrentConstraint: serializeConstraint(this.recurrentConstraint), biasConstraint: serializeConstraint(this.biasConstraint), dropout: this.dropout, recurrentDropout: this.recurrentDropout, implementation: this.implementation }, + n = e.prototype.getConfig.call(this);return delete n.cell, Object.assign(t, n), t; + }, t.fromConfig = function (e, t) { + return 0 === t.implmentation && (t.implementation = 1), new e(t); + }, t.className = "LSTM", t; + }(RNN);serialization.SerializationMap.register(LSTM);var StackedRNNCells = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.cells = t.cells, n; + }return __extends$1(t, e), Object.defineProperty(t.prototype, "stateSize", { get: function () { + for (var e = [], t = 0, n = this.cells.slice().reverse(); t < n.length; t++) { + var r = n[t];Array.isArray(r.stateSize) ? e.push.apply(e, r.stateSize) : e.push(r.stateSize); + }return e; + }, enumerable: !0, configurable: !0 }), t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + for (var r = (e = e).slice(1), i = [], a = 0, o = n.cells.slice().reverse(); a < o.length; a++) { + var s = o[a];Array.isArray(s.stateSize) ? i.push(r.splice(0, s.stateSize.length)) : i.push(r.splice(0, 1)); + }i.reverse();for (var l, u = [], c = 0; c < n.cells.length; ++c) { + s = n.cells[c];r = i[c], l = 0 === c ? [e[0]].concat(r) : [l[0]].concat(r), l = s.call(l, t), u.push(l.slice(1)); + }r = [];for (var p = 0, h = u.slice().reverse(); p < h.length; p++) { + var d = h[p];r.push.apply(r, d); + }return [l[0]].concat(r); + }); + }, t.prototype.build = function (e) { + var t;isArrayOfShapes(e) && (e = e[0]), e = e;for (var n = 0, r = this.cells; n < r.length; n++) { + var i = r[n];i.build(e), t = Array.isArray(i.stateSize) ? i.stateSize[0] : i.stateSize, e = [e[0], t]; + }this.built = !0; + }, t.prototype.getConfig = function () { + for (var t = [], n = 0, r = this.cells; n < r.length; n++) { + var i = r[n];t.push({ className: this.getClassName(), config: i.getConfig() }); + }var a = { cells: t }, + o = e.prototype.getConfig.call(this);return Object.assign(a, o), a; + }, t.fromConfig = function (e, t, n) { + void 0 === n && (n = {});for (var r = [], i = 0, a = t.cells; i < a.length; i++) { + var o = a[i];r.push(deserialize(o, n)); + }return new e({ cells: r }); + }, Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + if (!this.trainable) return [];for (var e = [], t = 0, n = this.cells; t < n.length; t++) { + var r = n[t];e.push.apply(e, r.trainableWeights); + }return e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + for (var e = [], t = 0, n = this.cells; t < n.length; t++) { + var r = n[t];e.push.apply(e, r.nonTrainableWeights); + }if (!this.trainable) { + for (var i = [], a = 0, o = this.cells; a < o.length; a++) { + r = o[a];i.push.apply(i, r.trainableWeights); + }return i.concat(e); + }return e; + }, enumerable: !0, configurable: !0 }), t.prototype.getWeights = function () { + for (var e = [], t = 0, n = this.cells; t < n.length; t++) { + var r = n[t];e.push.apply(e, r.weights); + }return batchGetValue(e); + }, t.prototype.setWeights = function (e) { + for (var t = [], n = 0, r = this.cells; n < r.length; n++) for (var i = r[n], a = i.weights.length, o = e.splice(a), s = 0; s < i.weights.length; ++s) t.push([i.weights[s], o[s]]);batchSetValue(t); + }, t.className = "StackedRNNCells", t; + }(RNNCell);function generateDropoutMask(e, t, n, r) { + function i() { + return dropout(e(), getScalar(t)); + }if (void 0 === n && (n = null), void 0 === r && (r = 1), r > 1) { + for (var a = [], o = 0; o < r; o++) a.push(inTrainPhase(i, e, n));return a.forEach(function (e) { + return keep(e); + }), a; + }return keep(inTrainPhase(i, e, n)); + }serialization.SerializationMap.register(StackedRNNCells);var Wrapper = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.layer = t.layer, n; + }return __extends$1(t, e), t.prototype.build = function (e) { + this.built = !0; + }, Object.defineProperty(t.prototype, "trainable", { get: function () { + return null != this.layer && this.layer.trainable; + }, set: function (e) { + null != this.layer && (this.layer.trainable = e); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + return this.layer.trainableWeights; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + return this.layer.nonTrainableWeights; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "updates", { get: function () { + return this.layer._updates; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "losses", { get: function () { + return this.layer.losses; + }, enumerable: !0, configurable: !0 }), t.prototype.getWeights = function () { + return this.layer.getWeights(); + }, t.prototype.setWeights = function (e) { + this.layer.setWeights(e); + }, t.prototype.getConfig = function () { + var t = { layer: { className: this.layer.getClassName(), config: this.layer.getConfig() } }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.fromConfig = function (e, t, n) { + void 0 === n && (n = {});var r = deserialize(t.layer, n);delete t.layer;var i = { layer: r };return Object.assign(i, t), new e(i); + }, t; + }(Layer), + TimeDistributed = function (e) { + function t(t) { + var n = e.call(this, t) || this;return n.supportsMasking = !0, n; + }return __extends$1(t, e), t.prototype.build = function (t) { + if ((t = getExactlyOneShape(t)).length < 3) throw new ValueError("TimeDistributed layer expects an input shape >= 3D, but received input shape " + JSON.stringify(t));this.inputSpec = [{ shape: t }];var n = [t[0]].concat(t.slice(2));this.layer.built || (this.layer.build(n), this.layer.built = !0), e.prototype.build.call(this, t); + }, t.prototype.computeOutputShape = function (e) { + var t = [(e = getExactlyOneShape(e))[0]].concat(e.slice(2)), + n = this.layer.computeOutputShape(t), + r = e[1];return [n[0], r].concat(n.slice(1)); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + return rnn(function (e, r) { + return [n.layer.call(e, t), []]; + }, e = getExactlyOneTensor(e), [], !1, null, null, !1, e.shape[1])[1]; + }); + }, t.className = "TimeDistributed", t; + }(Wrapper);serialization.SerializationMap.register(TimeDistributed);var VALID_BIDIRECTIONAL_MERGE_MODES = ["sum", "mul", "concat", "ave"];function checkBidirectionalMergeMode(e) { + checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES, "BidirectionalMergeMode", e); + }var Bidirectional = function (e) { + function t(t) { + var n = e.call(this, t) || this, + r = t.layer.getConfig();if (n.forwardLayer = deserialize({ className: t.layer.getClassName(), config: r }), r.goBackwards = !0 !== r.goBackwards, n.backwardLayer = deserialize({ className: t.layer.getClassName(), config: r }), n.forwardLayer.name = "forward_" + n.forwardLayer.name, n.backwardLayer.name = "backward_" + n.backwardLayer.name, checkBidirectionalMergeMode(t.mergeMode), n.mergeMode = t.mergeMode, t.weights) throw new NotImplementedError("weights support is not implemented for Bidirectional layer yet.");return n._stateful = t.layer.stateful, n.returnSequences = t.layer.returnSequences, n.returnState = t.layer.returnState, n.supportsMasking = !0, n._trainable = !0, n.inputSpec = t.layer.inputSpec, n.numConstants = null, n; + }return __extends$1(t, e), Object.defineProperty(t.prototype, "trainable", { get: function () { + return this._trainable; + }, set: function (e) { + this._trainable = e, null != this.forwardLayer && (this.forwardLayer.trainable = e), null != this.backwardLayer && (this.backwardLayer.trainable = e); + }, enumerable: !0, configurable: !0 }), t.prototype.getWeights = function () { + return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights()); + }, t.prototype.setWeights = function (e) { + var t = e.length, + n = Math.floor(t / 2);this.forwardLayer.setWeights(e.slice(0, n)), this.backwardLayer.setWeights(e.slice(n)); + }, t.prototype.computeOutputShape = function (e) { + var t, + n, + r, + i = this.forwardLayer.computeOutputShape(e);return Array.isArray(i) && Array.isArray(i[0]) || (i = [i]), i = i, this.returnState ? (r = i.slice(1), t = i[0]) : t = i[0], t = t, "concat" === this.mergeMode ? (t[t.length - 1] *= 2, n = [t]) : n = null == this.mergeMode ? [t, t.slice()] : [t], this.returnState ? null == this.mergeMode ? n.concat(r).concat(r.slice()) : [t].concat(r).concat(r.slice()) : singletonOrArray(n); + }, t.prototype.apply = function (t, n) { + var r = null == n ? null : n.initialState, + i = null == n ? null : n.constants;null == n && (n = {});var a = standardizeArgs(t, r, i, this.numConstants);if (t = a.inputs, r = a.initialState, i = a.constants, Array.isArray(t) && (r = t.slice(1), t = t[0]), (null == r || 0 === r.length) && null == i) return e.prototype.apply.call(this, t, n);var o = [], + s = [];if (null != r) { + var l = r.length;if (l % 2 > 0) throw new ValueError("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");n.initialState = r, o.push.apply(o, r);var u = r.map(function (e) { + return new InputSpec({ shape: e.shape }); + });this.forwardLayer.stateSpec = u.slice(0, l / 2), this.backwardLayer.stateSpec = u.slice(l / 2), s.push.apply(s, u); + }if (null != i) throw new NotImplementedError("Support for constants in Bidirectional layers is not implemented yet.");for (var c = o[0] instanceof SymbolicTensor, p = 0, h = o; p < h.length; p++) { + if (h[p] instanceof SymbolicTensor !== c) throw new ValueError("The initial state of a Bidirectional layer cannot be specified as a mix of symbolic and non-symbolic tensors"); + }if (c) { + var d = [t].concat(o), + g = this.inputSpec.concat(s), + f = this.inputSpec;this.inputSpec = g;var m = e.prototype.apply.call(this, d, n);return this.inputSpec = f, m; + }return e.prototype.apply.call(this, t, n); + }, t.prototype.call = function (e, t) { + var n = this;return tidy(function () { + if (null != t.mask) throw new NotImplementedError("The support for masking is not implemented for Bidirectional layers yet.");var r, + i, + a, + o, + s = t.initialState;if (null == s) r = n.forwardLayer.call(e, t), i = n.backwardLayer.call(e, t);else { + var l = s.slice(0, s.length / 2), + u = s.slice(s.length / 2);r = n.forwardLayer.call(e, Object.assign(t, { initialState: l })), i = n.forwardLayer.call(e, Object.assign(t, { initialState: u })); + }return n.returnState && (Array.isArray(r) && (a = r.slice(1).concat(i.slice(1))), r = r[0], i = i[0]), n.returnSequences && (i = reverse(i, 1)), "concat" === n.mergeMode ? o = concatenate([r, i]) : "sum" === n.mergeMode ? o = add(r, i) : "ave" === n.mergeMode ? o = mul(getScalar(.5), add(r, i)) : "mul" === n.mergeMode ? o = mul(r, i) : null == n.mergeMode && (o = [r, i]), n.returnState ? null == n.mergeMode ? o.concat(a) : [o].concat(a) : o; + }); + }, t.prototype.resetStates = function (e) { + this.forwardLayer.resetStates(), this.backwardLayer.resetStates(); + }, t.prototype.build = function (e) { + var t = this;nameScope(this.forwardLayer.name, function () { + t.forwardLayer.build(e); + }), nameScope(this.backwardLayer.name, function () { + t.backwardLayer.build(e); + }), this.built = !0; + }, Object.defineProperty(t.prototype, "trainableWeights", { get: function () { + return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(t.prototype, "nonTrainableWeights", { get: function () { + return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights); + }, enumerable: !0, configurable: !0 }), t.prototype.getConfig = function () { + var t = { mergeMode: this.mergeMode }, + n = e.prototype.getConfig.call(this);return Object.assign(t, n), t; + }, t.fromConfig = function (e, t) { + var n = deserialize(t.layer);if (delete t.layer, null != t.numConstants) throw new NotImplementedError("Deserialization of a Bidirectional layer with numConstants present is not supported yet.");var r = t;return r.layer = n, new e(r); + }, t.className = "Bidirectional", t; + }(Wrapper);function inputLayer(e) { + return new InputLayer(e); + }function elu$2(e) { + return new ELU$1(e); + }function leakyReLU(e) { + return new LeakyReLU(e); + }function softmax$1(e) { + return new Softmax$1(e); + }function thresholdedReLU(e) { + return new ThresholdedReLU(e); + }function conv1d$2(e) { + return new Conv1D(e); + }function conv2d$2(e) { + return new Conv2D(e); + }function conv2dTranspose$1(e) { + return new Conv2DTranspose(e); + }function separableConv2d$1(e) { + return new SeparableConv2D(e); + }function cropping2D(e) { + return new Cropping2D(e); + }function upSampling2d(e) { + return new UpSampling2D(e); + }function depthwiseConv2d$2(e) { + return new DepthwiseConv2D(e); + }function activation(e) { + return new Activation$1(e); + }function dense(e) { + return new Dense(e); + }function dropout$1(e) { + return new Dropout(e); + }function flatten$1$1(e) { + return new Flatten(e); + }function repeatVector(e) { + return new RepeatVector(e); + }function reshape$1(e) { + return new Reshape(e); + }function embedding(e) { + return new Embedding(e); + }function add$2(e) { + return new Add(e); + }function average$1(e) { + return new Average(e); + }function concatenate$2(e) { + return new Concatenate(e); + }function maximum$2(e) { + return new Maximum(e); + }function minimum$2(e) { + return new Minimum(e); + }function multiply$1(e) { + return new Multiply(e); + }function batchNormalization$1$1(e) { + return new BatchNormalization(e); + }function zeroPadding2d(e) { + return new ZeroPadding2D(e); + }function averagePooling1d(e) { + return new AveragePooling1D(e); + }function avgPool1d(e) { + return averagePooling1d(e); + }function avgPooling1d(e) { + return averagePooling1d(e); + }function averagePooling2d(e) { + return new AveragePooling2D(e); + }function avgPool2d(e) { + return averagePooling2d(e); + }function avgPooling2d(e) { + return averagePooling2d(e); + }function globalAveragePooling1d(e) { + return new GlobalAveragePooling1D(e); + }function globalAveragePooling2d(e) { + return new GlobalAveragePooling2D(e); + }function globalMaxPooling1d(e) { + return new GlobalMaxPooling1D(e); + }function globalMaxPooling2d(e) { + return new GlobalMaxPooling2D(e); + }function maxPooling1d(e) { + return new MaxPooling1D(e); + }function maxPooling2d(e) { + return new MaxPooling2D(e); + }function gru(e) { + return new GRU(e); + }function gruCell(e) { + return new GRUCell(e); + }function lstm(e) { + return new LSTM(e); + }function lstmCell(e) { + return new LSTMCell(e); + }function simpleRNN(e) { + return new SimpleRNN(e); + }function simpleRNNCell(e) { + return new SimpleRNNCell(e); + }function rnn$1(e) { + return new RNN(e); + }function stackedRNNCells(e) { + return new StackedRNNCells(e); + }function bidirectional(e) { + return new Bidirectional(e); + }function timeDistributed(e) { + return new TimeDistributed(e); + }serialization.SerializationMap.register(Bidirectional);var globalMaxPool1d = globalMaxPooling1d, + globalMaxPool2d = globalMaxPooling2d, + maxPool1d = maxPooling1d, + maxPool2d = maxPooling2d, + exports_layers = Object.freeze({ inputLayer: inputLayer, elu: elu$2, leakyReLU: leakyReLU, softmax: softmax$1, thresholdedReLU: thresholdedReLU, conv1d: conv1d$2, conv2d: conv2d$2, conv2dTranspose: conv2dTranspose$1, separableConv2d: separableConv2d$1, cropping2D: cropping2D, upSampling2d: upSampling2d, depthwiseConv2d: depthwiseConv2d$2, activation: activation, dense: dense, dropout: dropout$1, flatten: flatten$1$1, repeatVector: repeatVector, reshape: reshape$1, embedding: embedding, add: add$2, average: average$1, concatenate: concatenate$2, maximum: maximum$2, minimum: minimum$2, multiply: multiply$1, batchNormalization: batchNormalization$1$1, zeroPadding2d: zeroPadding2d, averagePooling1d: averagePooling1d, avgPool1d: avgPool1d, avgPooling1d: avgPooling1d, averagePooling2d: averagePooling2d, avgPool2d: avgPool2d, avgPooling2d: avgPooling2d, globalAveragePooling1d: globalAveragePooling1d, globalAveragePooling2d: globalAveragePooling2d, globalMaxPooling1d: globalMaxPooling1d, globalMaxPooling2d: globalMaxPooling2d, maxPooling1d: maxPooling1d, maxPooling2d: maxPooling2d, gru: gru, gruCell: gruCell, lstm: lstm, lstmCell: lstmCell, simpleRNN: simpleRNN, simpleRNNCell: simpleRNNCell, rnn: rnn$1, stackedRNNCells: stackedRNNCells, bidirectional: bidirectional, timeDistributed: timeDistributed, globalMaxPool1d: globalMaxPool1d, globalMaxPool2d: globalMaxPool2d, maxPool1d: maxPool1d, maxPool2d: maxPool2d, Layer: Layer, input: input });function binaryAccuracy$1(e, t) { + return binaryAccuracy(e, t); + }function binaryCrossentropy$2(e, t) { + return binaryCrossentropy$1(e, t); + }function categoricalAccuracy$1(e, t) { + return categoricalAccuracy(e, t); + }function categoricalCrossentropy$2(e, t) { + return categoricalCrossentropy$1(e, t); + }function cosineProximity$1(e, t) { + return cosineProximity(e, t); + }function meanAbsoluteError$1(e, t) { + return meanAbsoluteError(e, t); + }function meanAbsolutePercentageError$1(e, t) { + return meanAbsolutePercentageError(e, t); + }function MAPE$2(e, t) { + return meanAbsolutePercentageError(e, t); + }function mape$2(e, t) { + return meanAbsolutePercentageError(e, t); + }function meanSquaredError$1$1(e, t) { + return meanSquaredError$1(e, t); + }function MSE$2(e, t) { + return meanSquaredError$1(e, t); + }function mse$2(e, t) { + return meanSquaredError$1(e, t); + }var exports_metrics = Object.freeze({ binaryAccuracy: binaryAccuracy$1, binaryCrossentropy: binaryCrossentropy$2, categoricalAccuracy: categoricalAccuracy$1, categoricalCrossentropy: categoricalCrossentropy$2, cosineProximity: cosineProximity$1, meanAbsoluteError: meanAbsoluteError$1, meanAbsolutePercentageError: meanAbsolutePercentageError$1, MAPE: MAPE$2, mape: mape$2, meanSquaredError: meanSquaredError$1$1, MSE: MSE$2, mse: mse$2 });function l1l2(e) { + return new L1L2(e); + }function l1$1(e) { + return l1(e); + }function l2$1(e) { + return l2(e); + }var exports_regularizers = Object.freeze({ l1l2: l1l2, l1: l1$1, l2: l2$1 }), + Callback = function (e) { + function t() { + var t = null !== e && e.apply(this, arguments) || this;return t.model = null, t; + }return __extends$1(t, e), t.prototype.setModel = function (e) { + if (!(e instanceof Model)) throw new Error("model must be a Model, not some other Container");this.model = e; + }, t; + }(BaseCallback); + + /** + * @license + * Copyright 2018 Google LLC. 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. + * ============================================================================= + */ + var __assign$2 = Object.assign || function (e) { + for (var t, a = 1, r = arguments.length; a < r; a++) for (var n in t = arguments[a]) Object.prototype.hasOwnProperty.call(t, n) && (e[n] = t[n]);return e; + };function __awaiter$2(e, t, a, r) { + return new (a || (a = Promise))(function (n, o) { + function s(e) { + try { + p(r.next(e)); + } catch (e) { + o(e); + } + }function i(e) { + try { + p(r.throw(e)); + } catch (e) { + o(e); + } + }function p(e) { + e.done ? n(e.value) : new a(function (t) { + t(e.value); + }).then(s, i); + }p((r = r.apply(e, t || [])).next()); + }); + }function __generator$2(e, t) { + var a, + r, + n, + o, + s = { label: 0, sent: function () { + if (1 & n[0]) throw n[1];return n[1]; + }, trys: [], ops: [] };return o = { next: i(0), throw: i(1), return: i(2) }, "function" == typeof Symbol && (o[Symbol.iterator] = function () { + return this; + }), o;function i(o) { + return function (i) { + return function (o) { + if (a) throw new TypeError("Generator is already executing.");for (; s;) try { + if (a = 1, r && (n = r[2 & o[0] ? "return" : o[0] ? "throw" : "next"]) && !(n = n.call(r, o[1])).done) return n;switch (r = 0, n && (o = [0, n.value]), o[0]) {case 0:case 1: + n = o;break;case 4: + return s.label++, { value: o[1], done: !1 };case 5: + s.label++, r = o[1], o = [0];continue;case 7: + o = s.ops.pop(), s.trys.pop();continue;default: + if (!(n = (n = s.trys).length > 0 && n[n.length - 1]) && (6 === o[0] || 2 === o[0])) { + s = 0;continue; + }if (3 === o[0] && (!n || o[1] > n[0] && o[1] < n[3])) { + s.label = o[1];break; + }if (6 === o[0] && s.label < n[1]) { + s.label = n[1], n = o;break; + }if (n && s.label < n[2]) { + s.label = n[2], s.ops.push(o);break; + }n[2] && s.ops.pop(), s.trys.pop();continue;}o = t.call(e, s); + } catch (e) { + o = [6, e], r = 0; + } finally { + a = n = 0; + }if (5 & o[0]) throw o[1];return { value: o[0] ? o[1] : void 0, done: !0 }; + }([o, i]); + }; + } + }var commonjsGlobal$1 = "undefined" != typeof window ? window : "undefined" != typeof global ? global : "undefined" != typeof self ? self : {};function createCommonjsModule$1(e, t) { + return e(t = { exports: {} }, t.exports), t.exports; + }var punycode = createCommonjsModule$1(function (e, t) { + !function (a) { + var r = t && !t.nodeType && t, + n = e && !e.nodeType && e, + o = "object" == typeof commonjsGlobal$1 && commonjsGlobal$1;o.global !== o && o.window !== o && o.self !== o || (a = o);var s, + i, + p = 2147483647, + u = 36, + m = 1, + l = 26, + d = 38, + c = 700, + f = 72, + h = 128, + y = "-", + g = /^xn--/, + N = /[^\x20-\x7E]/, + P = /[\x2E\u3002\uFF0E\uFF61]/g, + b = { overflow: "Overflow: input needs wider integers to process", "not-basic": "Illegal input >= 0x80 (not a basic code point)", "invalid-input": "Invalid input" }, + x = u - m, + v = Math.floor, + I = String.fromCharCode;function O(e) { + throw RangeError(b[e]); + }function w(e, t) { + for (var a = e.length, r = []; a--;) r[a] = t(e[a]);return r; + }function V(e, t) { + var a = e.split("@"), + r = "";return a.length > 1 && (r = a[0] + "@", e = a[1]), r + w((e = e.replace(P, ".")).split("."), t).join("."); + }function T(e) { + for (var t, a, r = [], n = 0, o = e.length; n < o;) (t = e.charCodeAt(n++)) >= 55296 && t <= 56319 && n < o ? 56320 == (64512 & (a = e.charCodeAt(n++))) ? r.push(((1023 & t) << 10) + (1023 & a) + 65536) : (r.push(t), n--) : r.push(t);return r; + }function k(e) { + return w(e, function (e) { + var t = "";return e > 65535 && (t += I((e -= 65536) >>> 10 & 1023 | 55296), e = 56320 | 1023 & e), t += I(e); + }).join(""); + }function $(e, t) { + return e + 22 + 75 * (e < 26) - ((0 != t) << 5); + }function _(e, t, a) { + var r = 0;for (e = a ? v(e / c) : e >> 1, e += v(e / t); e > x * l >> 1; r += u) e = v(e / x);return v(r + (x + 1) * e / (e + d)); + }function A(e) { + var t, + a, + r, + n, + o, + s, + i, + d, + c, + g, + N, + P = [], + b = e.length, + x = 0, + I = h, + w = f;for ((a = e.lastIndexOf(y)) < 0 && (a = 0), r = 0; r < a; ++r) e.charCodeAt(r) >= 128 && O("not-basic"), P.push(e.charCodeAt(r));for (n = a > 0 ? a + 1 : 0; n < b;) { + for (o = x, s = 1, i = u; n >= b && O("invalid-input"), ((d = (N = e.charCodeAt(n++)) - 48 < 10 ? N - 22 : N - 65 < 26 ? N - 65 : N - 97 < 26 ? N - 97 : u) >= u || d > v((p - x) / s)) && O("overflow"), x += d * s, !(d < (c = i <= w ? m : i >= w + l ? l : i - w)); i += u) s > v(p / (g = u - c)) && O("overflow"), s *= g;w = _(x - o, t = P.length + 1, 0 == o), v(x / t) > p - I && O("overflow"), I += v(x / t), x %= t, P.splice(x++, 0, I); + }return k(P); + }function S(e) { + var t, + a, + r, + n, + o, + s, + i, + d, + c, + g, + N, + P, + b, + x, + w, + V = [];for (P = (e = T(e)).length, t = h, a = 0, o = f, s = 0; s < P; ++s) (N = e[s]) < 128 && V.push(I(N));for (r = n = V.length, n && V.push(y); r < P;) { + for (i = p, s = 0; s < P; ++s) (N = e[s]) >= t && N < i && (i = N);for (i - t > v((p - a) / (b = r + 1)) && O("overflow"), a += (i - t) * b, t = i, s = 0; s < P; ++s) if ((N = e[s]) < t && ++a > p && O("overflow"), N == t) { + for (d = a, c = u; !(d < (g = c <= o ? m : c >= o + l ? l : c - o)); c += u) w = d - g, x = u - g, V.push(I($(g + w % x, 0))), d = v(w / x);V.push(I($(d, 0))), o = _(a, b, r == n), a = 0, ++r; + }++a, ++t; + }return V.join(""); + }if (s = { version: "1.3.2", ucs2: { decode: T, encode: k }, decode: A, encode: S, toASCII: function (e) { + return V(e, function (e) { + return N.test(e) ? "xn--" + S(e) : e; + }); + }, toUnicode: function (e) { + return V(e, function (e) { + return g.test(e) ? A(e.slice(4).toLowerCase()) : e; + }); + } }, r && n) { + if (e.exports == r) n.exports = s;else for (i in s) s.hasOwnProperty(i) && (r[i] = s[i]); + } else a.punycode = s; + }(commonjsGlobal$1); + }), + util$1 = { isString: function (e) { + return "string" == typeof e; + }, isObject: function (e) { + return "object" == typeof e && null !== e; + }, isNull: function (e) { + return null === e; + }, isNullOrUndefined: function (e) { + return null == e; + } };function hasOwnProperty(e, t) { + return Object.prototype.hasOwnProperty.call(e, t); + }var decode = function (e, t, a, r) { + t = t || "&", a = a || "=";var n = {};if ("string" != typeof e || 0 === e.length) return n;var o = /\+/g;e = e.split(t);var s = 1e3;r && "number" == typeof r.maxKeys && (s = r.maxKeys);var i = e.length;s > 0 && i > s && (i = s);for (var p = 0; p < i; ++p) { + var u, + m, + l, + d, + c = e[p].replace(o, "%20"), + f = c.indexOf(a);f >= 0 ? (u = c.substr(0, f), m = c.substr(f + 1)) : (u = c, m = ""), l = decodeURIComponent(u), d = decodeURIComponent(m), hasOwnProperty(n, l) ? Array.isArray(n[l]) ? n[l].push(d) : n[l] = [n[l], d] : n[l] = d; + }return n; + }, + stringifyPrimitive = function (e) { + switch (typeof e) {case "string": + return e;case "boolean": + return e ? "true" : "false";case "number": + return isFinite(e) ? e : "";default: + return "";} + }, + encode = function (e, t, a, r) { + return t = t || "&", a = a || "=", null === e && (e = void 0), "object" == typeof e ? Object.keys(e).map(function (r) { + var n = encodeURIComponent(stringifyPrimitive(r)) + a;return Array.isArray(e[r]) ? e[r].map(function (e) { + return n + encodeURIComponent(stringifyPrimitive(e)); + }).join(t) : n + encodeURIComponent(stringifyPrimitive(e[r])); + }).join(t) : r ? encodeURIComponent(stringifyPrimitive(r)) + a + encodeURIComponent(stringifyPrimitive(e)) : ""; + }, + querystring = createCommonjsModule$1(function (e, t) { + t.decode = t.parse = decode, t.encode = t.stringify = encode; + }), + querystring_1 = querystring.decode, + querystring_2 = querystring.parse, + querystring_3 = querystring.encode, + querystring_4 = querystring.stringify, + parse = urlParse, + format = urlFormat;function Url() { + this.protocol = null, this.slashes = null, this.auth = null, this.host = null, this.port = null, this.hostname = null, this.hash = null, this.search = null, this.query = null, this.pathname = null, this.path = null, this.href = null; + }var protocolPattern = /^([a-z0-9.+-]+:)/i, + portPattern = /:[0-9]*$/, + simplePathPattern = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/, + delims = ["<", ">", '"', "`", " ", "\r", "\n", "\t"], + unwise = ["{", "}", "|", "\\", "^", "`"].concat(delims), + autoEscape = ["'"].concat(unwise), + nonHostChars = ["%", "/", "?", ";", "#"].concat(autoEscape), + hostEndingChars = ["/", "?", "#"], + hostnameMaxLen = 255, + hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/, + hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/, + unsafeProtocol = { javascript: !0, "javascript:": !0 }, + hostlessProtocol = { javascript: !0, "javascript:": !0 }, + slashedProtocol = { http: !0, https: !0, ftp: !0, gopher: !0, file: !0, "http:": !0, "https:": !0, "ftp:": !0, "gopher:": !0, "file:": !0 };function urlParse(e, t, a) { + if (e && util$1.isObject(e) && e instanceof Url) return e;var r = new Url();return r.parse(e, t, a), r; + }function urlFormat(e) { + return util$1.isString(e) && (e = urlParse(e)), e instanceof Url ? e.format() : Url.prototype.format.call(e); + }Url.prototype.parse = function (e, t, a) { + if (!util$1.isString(e)) throw new TypeError("Parameter 'url' must be a string, not " + typeof e);var r = e.indexOf("?"), + n = -1 !== r && r < e.indexOf("#") ? "?" : "#", + o = e.split(n);o[0] = o[0].replace(/\\/g, "/");var s = e = o.join(n);if (s = s.trim(), !a && 1 === e.split("#").length) { + var i = simplePathPattern.exec(s);if (i) return this.path = s, this.href = s, this.pathname = i[1], i[2] ? (this.search = i[2], this.query = t ? querystring.parse(this.search.substr(1)) : this.search.substr(1)) : t && (this.search = "", this.query = {}), this; + }var p = protocolPattern.exec(s);if (p) { + var u = (p = p[0]).toLowerCase();this.protocol = u, s = s.substr(p.length); + }if (a || p || s.match(/^\/\/[^@\/]+@[^@\/]+/)) { + var m = "//" === s.substr(0, 2);!m || p && hostlessProtocol[p] || (s = s.substr(2), this.slashes = !0); + }if (!hostlessProtocol[p] && (m || p && !slashedProtocol[p])) { + for (var l, d, c = -1, f = 0; f < hostEndingChars.length; f++) { + -1 !== (h = s.indexOf(hostEndingChars[f])) && (-1 === c || h < c) && (c = h); + }-1 !== (d = -1 === c ? s.lastIndexOf("@") : s.lastIndexOf("@", c)) && (l = s.slice(0, d), s = s.slice(d + 1), this.auth = decodeURIComponent(l)), c = -1;for (f = 0; f < nonHostChars.length; f++) { + var h;-1 !== (h = s.indexOf(nonHostChars[f])) && (-1 === c || h < c) && (c = h); + }-1 === c && (c = s.length), this.host = s.slice(0, c), s = s.slice(c), this.parseHost(), this.hostname = this.hostname || "";var y = "[" === this.hostname[0] && "]" === this.hostname[this.hostname.length - 1];if (!y) for (var g = this.hostname.split(/\./), N = (f = 0, g.length); f < N; f++) { + var P = g[f];if (P && !P.match(hostnamePartPattern)) { + for (var b = "", x = 0, v = P.length; x < v; x++) P.charCodeAt(x) > 127 ? b += "x" : b += P[x];if (!b.match(hostnamePartPattern)) { + var I = g.slice(0, f), + O = g.slice(f + 1), + w = P.match(hostnamePartStart);w && (I.push(w[1]), O.unshift(w[2])), O.length && (s = "/" + O.join(".") + s), this.hostname = I.join(".");break; + } + } + }this.hostname.length > hostnameMaxLen ? this.hostname = "" : this.hostname = this.hostname.toLowerCase(), y || (this.hostname = punycode.toASCII(this.hostname));var V = this.port ? ":" + this.port : "", + T = this.hostname || "";this.host = T + V, this.href += this.host, y && (this.hostname = this.hostname.substr(1, this.hostname.length - 2), "/" !== s[0] && (s = "/" + s)); + }if (!unsafeProtocol[u]) for (f = 0, N = autoEscape.length; f < N; f++) { + var k = autoEscape[f];if (-1 !== s.indexOf(k)) { + var $ = encodeURIComponent(k);$ === k && ($ = escape(k)), s = s.split(k).join($); + } + }var _ = s.indexOf("#");-1 !== _ && (this.hash = s.substr(_), s = s.slice(0, _));var A = s.indexOf("?");if (-1 !== A ? (this.search = s.substr(A), this.query = s.substr(A + 1), t && (this.query = querystring.parse(this.query)), s = s.slice(0, A)) : t && (this.search = "", this.query = {}), s && (this.pathname = s), slashedProtocol[u] && this.hostname && !this.pathname && (this.pathname = "/"), this.pathname || this.search) { + V = this.pathname || "";var S = this.search || "";this.path = V + S; + }return this.href = this.format(), this; + }, Url.prototype.format = function () { + var e = this.auth || "";e && (e = (e = encodeURIComponent(e)).replace(/%3A/i, ":"), e += "@");var t = this.protocol || "", + a = this.pathname || "", + r = this.hash || "", + n = !1, + o = "";this.host ? n = e + this.host : this.hostname && (n = e + (-1 === this.hostname.indexOf(":") ? this.hostname : "[" + this.hostname + "]"), this.port && (n += ":" + this.port)), this.query && util$1.isObject(this.query) && Object.keys(this.query).length && (o = querystring.stringify(this.query));var s = this.search || o && "?" + o || "";return t && ":" !== t.substr(-1) && (t += ":"), this.slashes || (!t || slashedProtocol[t]) && !1 !== n ? (n = "//" + (n || ""), a && "/" !== a.charAt(0) && (a = "/" + a)) : n || (n = ""), r && "#" !== r.charAt(0) && (r = "#" + r), s && "?" !== s.charAt(0) && (s = "?" + s), t + n + (a = a.replace(/[?#]/g, function (e) { + return encodeURIComponent(e); + })) + (s = s.replace("#", "%23")) + r; + }, Url.prototype.resolve = function (e) { + return this.resolveObject(urlParse(e, !1, !0)).format(); + }, Url.prototype.resolveObject = function (e) { + if (util$1.isString(e)) { + var t = new Url();t.parse(e, !1, !0), e = t; + }for (var a = new Url(), r = Object.keys(this), n = 0; n < r.length; n++) { + var o = r[n];a[o] = this[o]; + }if (a.hash = e.hash, "" === e.href) return a.href = a.format(), a;if (e.slashes && !e.protocol) { + for (var s = Object.keys(e), i = 0; i < s.length; i++) { + var p = s[i];"protocol" !== p && (a[p] = e[p]); + }return slashedProtocol[a.protocol] && a.hostname && !a.pathname && (a.path = a.pathname = "/"), a.href = a.format(), a; + }if (e.protocol && e.protocol !== a.protocol) { + if (!slashedProtocol[e.protocol]) { + for (var u = Object.keys(e), m = 0; m < u.length; m++) { + var l = u[m];a[l] = e[l]; + }return a.href = a.format(), a; + }if (a.protocol = e.protocol, e.host || hostlessProtocol[e.protocol]) a.pathname = e.pathname;else { + for (var d = (e.pathname || "").split("/"); d.length && !(e.host = d.shift()););e.host || (e.host = ""), e.hostname || (e.hostname = ""), "" !== d[0] && d.unshift(""), d.length < 2 && d.unshift(""), a.pathname = d.join("/"); + }if (a.search = e.search, a.query = e.query, a.host = e.host || "", a.auth = e.auth, a.hostname = e.hostname || e.host, a.port = e.port, a.pathname || a.search) { + var c = a.pathname || "", + f = a.search || "";a.path = c + f; + }return a.slashes = a.slashes || e.slashes, a.href = a.format(), a; + }var h = a.pathname && "/" === a.pathname.charAt(0), + y = e.host || e.pathname && "/" === e.pathname.charAt(0), + g = y || h || a.host && e.pathname, + N = g, + P = a.pathname && a.pathname.split("/") || [], + b = (d = e.pathname && e.pathname.split("/") || [], a.protocol && !slashedProtocol[a.protocol]);if (b && (a.hostname = "", a.port = null, a.host && ("" === P[0] ? P[0] = a.host : P.unshift(a.host)), a.host = "", e.protocol && (e.hostname = null, e.port = null, e.host && ("" === d[0] ? d[0] = e.host : d.unshift(e.host)), e.host = null), g = g && ("" === d[0] || "" === P[0])), y) a.host = e.host || "" === e.host ? e.host : a.host, a.hostname = e.hostname || "" === e.hostname ? e.hostname : a.hostname, a.search = e.search, a.query = e.query, P = d;else if (d.length) P || (P = []), P.pop(), P = P.concat(d), a.search = e.search, a.query = e.query;else if (!util$1.isNullOrUndefined(e.search)) { + if (b) a.hostname = a.host = P.shift(), (w = !!(a.host && a.host.indexOf("@") > 0) && a.host.split("@")) && (a.auth = w.shift(), a.host = a.hostname = w.shift());return a.search = e.search, a.query = e.query, util$1.isNull(a.pathname) && util$1.isNull(a.search) || (a.path = (a.pathname ? a.pathname : "") + (a.search ? a.search : "")), a.href = a.format(), a; + }if (!P.length) return a.pathname = null, a.search ? a.path = "/" + a.search : a.path = null, a.href = a.format(), a;for (var x = P.slice(-1)[0], v = (a.host || e.host || P.length > 1) && ("." === x || ".." === x) || "" === x, I = 0, O = P.length; O >= 0; O--) "." === (x = P[O]) ? P.splice(O, 1) : ".." === x ? (P.splice(O, 1), I++) : I && (P.splice(O, 1), I--);if (!g && !N) for (; I--; I) P.unshift("..");!g || "" === P[0] || P[0] && "/" === P[0].charAt(0) || P.unshift(""), v && "/" !== P.join("/").substr(-1) && P.push("");var w, + V = "" === P[0] || P[0] && "/" === P[0].charAt(0);b && (a.hostname = a.host = V ? "" : P.length ? P.shift() : "", (w = !!(a.host && a.host.indexOf("@") > 0) && a.host.split("@")) && (a.auth = w.shift(), a.host = a.hostname = w.shift()));return (g = g || a.host && P.length) && !V && P.unshift(""), P.length ? a.pathname = P.join("/") : (a.pathname = null, a.path = null), util$1.isNull(a.pathname) && util$1.isNull(a.search) || (a.path = (a.pathname ? a.pathname : "") + (a.search ? a.search : "")), a.auth = e.auth || a.auth, a.slashes = a.slashes || e.slashes, a.href = a.format(), a; + }, Url.prototype.parseHost = function () { + var e = this.host, + t = portPattern.exec(e);t && (":" !== (t = t[0]) && (this.port = t.substr(1)), e = e.substr(0, e.length - t.length)), e && (this.hostname = e); + };var aspromise = asPromise;function asPromise(e, t) { + for (var a = new Array(arguments.length - 1), r = 0, n = 2, o = !0; n < arguments.length;) a[r++] = arguments[n++];return new Promise(function (n, s) { + a[r] = function (e) { + if (o) if (o = !1, e) s(e);else { + for (var t = new Array(arguments.length - 1), a = 0; a < t.length;) t[a++] = arguments[a];n.apply(null, t); + } + };try { + e.apply(t || null, a); + } catch (e) { + o && (o = !1, s(e)); + } + }); + }var base64_1 = createCommonjsModule$1(function (e, t) { + var a = t;a.length = function (e) { + var t = e.length;if (!t) return 0;for (var a = 0; --t % 4 > 1 && "=" === e.charAt(t);) ++a;return Math.ceil(3 * e.length) / 4 - a; + };for (var r = new Array(64), n = new Array(123), o = 0; o < 64;) n[r[o] = o < 26 ? o + 65 : o < 52 ? o + 71 : o < 62 ? o - 4 : o - 59 | 43] = o++;a.encode = function (e, t, a) { + for (var n, o = null, s = [], i = 0, p = 0; t < a;) { + var u = e[t++];switch (p) {case 0: + s[i++] = r[u >> 2], n = (3 & u) << 4, p = 1;break;case 1: + s[i++] = r[n | u >> 4], n = (15 & u) << 2, p = 2;break;case 2: + s[i++] = r[n | u >> 6], s[i++] = r[63 & u], p = 0;}i > 8191 && ((o || (o = [])).push(String.fromCharCode.apply(String, s)), i = 0); + }return p && (s[i++] = r[n], s[i++] = 61, 1 === p && (s[i++] = 61)), o ? (i && o.push(String.fromCharCode.apply(String, s.slice(0, i))), o.join("")) : String.fromCharCode.apply(String, s.slice(0, i)); + };a.decode = function (e, t, a) { + for (var r, o = a, s = 0, i = 0; i < e.length;) { + var p = e.charCodeAt(i++);if (61 === p && s > 1) break;if (void 0 === (p = n[p])) throw Error("invalid encoding");switch (s) {case 0: + r = p, s = 1;break;case 1: + t[a++] = r << 2 | (48 & p) >> 4, r = p, s = 2;break;case 2: + t[a++] = (15 & r) << 4 | (60 & p) >> 2, r = p, s = 3;break;case 3: + t[a++] = (3 & r) << 6 | p, s = 0;} + }if (1 === s) throw Error("invalid encoding");return a - o; + }, a.test = function (e) { + return (/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e) + ); + }; + }), + eventemitter = EventEmitter;function EventEmitter() { + this._listeners = {}; + }EventEmitter.prototype.on = function (e, t, a) { + return (this._listeners[e] || (this._listeners[e] = [])).push({ fn: t, ctx: a || this }), this; + }, EventEmitter.prototype.off = function (e, t) { + if (void 0 === e) this._listeners = {};else if (void 0 === t) this._listeners[e] = [];else for (var a = this._listeners[e], r = 0; r < a.length;) a[r].fn === t ? a.splice(r, 1) : ++r;return this; + }, EventEmitter.prototype.emit = function (e) { + var t = this._listeners[e];if (t) { + for (var a = [], r = 1; r < arguments.length;) a.push(arguments[r++]);for (r = 0; r < t.length;) t[r].fn.apply(t[r++].ctx, a); + }return this; + };var float_1 = factory(factory);function factory(e) { + return "undefined" != typeof Float32Array ? function () { + var t = new Float32Array([-0]), + a = new Uint8Array(t.buffer), + r = 128 === a[3];function n(e, r, n) { + t[0] = e, r[n] = a[0], r[n + 1] = a[1], r[n + 2] = a[2], r[n + 3] = a[3]; + }function o(e, r, n) { + t[0] = e, r[n] = a[3], r[n + 1] = a[2], r[n + 2] = a[1], r[n + 3] = a[0]; + }function s(e, r) { + return a[0] = e[r], a[1] = e[r + 1], a[2] = e[r + 2], a[3] = e[r + 3], t[0]; + }function i(e, r) { + return a[3] = e[r], a[2] = e[r + 1], a[1] = e[r + 2], a[0] = e[r + 3], t[0]; + }e.writeFloatLE = r ? n : o, e.writeFloatBE = r ? o : n, e.readFloatLE = r ? s : i, e.readFloatBE = r ? i : s; + }() : function () { + function t(e, t, a, r) { + var n = t < 0 ? 1 : 0;if (n && (t = -t), 0 === t) e(1 / t > 0 ? 0 : 2147483648, a, r);else if (isNaN(t)) e(2143289344, a, r);else if (t > 3.4028234663852886e38) e((n << 31 | 2139095040) >>> 0, a, r);else if (t < 1.1754943508222875e-38) e((n << 31 | Math.round(t / 1.401298464324817e-45)) >>> 0, a, r);else { + var o = Math.floor(Math.log(t) / Math.LN2);e((n << 31 | o + 127 << 23 | 8388607 & Math.round(t * Math.pow(2, -o) * 8388608)) >>> 0, a, r); + } + }function a(e, t, a) { + var r = e(t, a), + n = 2 * (r >> 31) + 1, + o = r >>> 23 & 255, + s = 8388607 & r;return 255 === o ? s ? NaN : n * (1 / 0) : 0 === o ? 1.401298464324817e-45 * n * s : n * Math.pow(2, o - 150) * (s + 8388608); + }e.writeFloatLE = t.bind(null, writeUintLE), e.writeFloatBE = t.bind(null, writeUintBE), e.readFloatLE = a.bind(null, readUintLE), e.readFloatBE = a.bind(null, readUintBE); + }(), "undefined" != typeof Float64Array ? function () { + var t = new Float64Array([-0]), + a = new Uint8Array(t.buffer), + r = 128 === a[7];function n(e, r, n) { + t[0] = e, r[n] = a[0], r[n + 1] = a[1], r[n + 2] = a[2], r[n + 3] = a[3], r[n + 4] = a[4], r[n + 5] = a[5], r[n + 6] = a[6], r[n + 7] = a[7]; + }function o(e, r, n) { + t[0] = e, r[n] = a[7], r[n + 1] = a[6], r[n + 2] = a[5], r[n + 3] = a[4], r[n + 4] = a[3], r[n + 5] = a[2], r[n + 6] = a[1], r[n + 7] = a[0]; + }function s(e, r) { + return a[0] = e[r], a[1] = e[r + 1], a[2] = e[r + 2], a[3] = e[r + 3], a[4] = e[r + 4], a[5] = e[r + 5], a[6] = e[r + 6], a[7] = e[r + 7], t[0]; + }function i(e, r) { + return a[7] = e[r], a[6] = e[r + 1], a[5] = e[r + 2], a[4] = e[r + 3], a[3] = e[r + 4], a[2] = e[r + 5], a[1] = e[r + 6], a[0] = e[r + 7], t[0]; + }e.writeDoubleLE = r ? n : o, e.writeDoubleBE = r ? o : n, e.readDoubleLE = r ? s : i, e.readDoubleBE = r ? i : s; + }() : function () { + function t(e, t, a, r, n, o) { + var s = r < 0 ? 1 : 0;if (s && (r = -r), 0 === r) e(0, n, o + t), e(1 / r > 0 ? 0 : 2147483648, n, o + a);else if (isNaN(r)) e(0, n, o + t), e(2146959360, n, o + a);else if (r > 1.7976931348623157e308) e(0, n, o + t), e((s << 31 | 2146435072) >>> 0, n, o + a);else { + var i;if (r < 2.2250738585072014e-308) e((i = r / 5e-324) >>> 0, n, o + t), e((s << 31 | i / 4294967296) >>> 0, n, o + a);else { + var p = Math.floor(Math.log(r) / Math.LN2);1024 === p && (p = 1023), e(4503599627370496 * (i = r * Math.pow(2, -p)) >>> 0, n, o + t), e((s << 31 | p + 1023 << 20 | 1048576 * i & 1048575) >>> 0, n, o + a); + } + } + }function a(e, t, a, r, n) { + var o = e(r, n + t), + s = e(r, n + a), + i = 2 * (s >> 31) + 1, + p = s >>> 20 & 2047, + u = 4294967296 * (1048575 & s) + o;return 2047 === p ? u ? NaN : i * (1 / 0) : 0 === p ? 5e-324 * i * u : i * Math.pow(2, p - 1075) * (u + 4503599627370496); + }e.writeDoubleLE = t.bind(null, writeUintLE, 0, 4), e.writeDoubleBE = t.bind(null, writeUintBE, 4, 0), e.readDoubleLE = a.bind(null, readUintLE, 0, 4), e.readDoubleBE = a.bind(null, readUintBE, 4, 0); + }(), e; + }function writeUintLE(e, t, a) { + t[a] = 255 & e, t[a + 1] = e >>> 8 & 255, t[a + 2] = e >>> 16 & 255, t[a + 3] = e >>> 24; + }function writeUintBE(e, t, a) { + t[a] = e >>> 24, t[a + 1] = e >>> 16 & 255, t[a + 2] = e >>> 8 & 255, t[a + 3] = 255 & e; + }function readUintLE(e, t) { + return (e[t] | e[t + 1] << 8 | e[t + 2] << 16 | e[t + 3] << 24) >>> 0; + }function readUintBE(e, t) { + return (e[t] << 24 | e[t + 1] << 16 | e[t + 2] << 8 | e[t + 3]) >>> 0; + }var inquire_1 = inquire;function inquire(moduleName) { + try { + var mod$$1 = eval("quire".replace(/^/, "re"))(moduleName);if (mod$$1 && (mod$$1.length || Object.keys(mod$$1).length)) return mod$$1; + } catch (e) {}return null; + }var utf8_1 = createCommonjsModule$1(function (e, t) { + var a = t;a.length = function (e) { + for (var t = 0, a = 0, r = 0; r < e.length; ++r) (a = e.charCodeAt(r)) < 128 ? t += 1 : a < 2048 ? t += 2 : 55296 == (64512 & a) && 56320 == (64512 & e.charCodeAt(r + 1)) ? (++r, t += 4) : t += 3;return t; + }, a.read = function (e, t, a) { + if (a - t < 1) return "";for (var r, n = null, o = [], s = 0; t < a;) (r = e[t++]) < 128 ? o[s++] = r : r > 191 && r < 224 ? o[s++] = (31 & r) << 6 | 63 & e[t++] : r > 239 && r < 365 ? (r = ((7 & r) << 18 | (63 & e[t++]) << 12 | (63 & e[t++]) << 6 | 63 & e[t++]) - 65536, o[s++] = 55296 + (r >> 10), o[s++] = 56320 + (1023 & r)) : o[s++] = (15 & r) << 12 | (63 & e[t++]) << 6 | 63 & e[t++], s > 8191 && ((n || (n = [])).push(String.fromCharCode.apply(String, o)), s = 0);return n ? (s && n.push(String.fromCharCode.apply(String, o.slice(0, s))), n.join("")) : String.fromCharCode.apply(String, o.slice(0, s)); + }, a.write = function (e, t, a) { + for (var r, n, o = a, s = 0; s < e.length; ++s) (r = e.charCodeAt(s)) < 128 ? t[a++] = r : r < 2048 ? (t[a++] = r >> 6 | 192, t[a++] = 63 & r | 128) : 55296 == (64512 & r) && 56320 == (64512 & (n = e.charCodeAt(s + 1))) ? (r = 65536 + ((1023 & r) << 10) + (1023 & n), ++s, t[a++] = r >> 18 | 240, t[a++] = r >> 12 & 63 | 128, t[a++] = r >> 6 & 63 | 128, t[a++] = 63 & r | 128) : (t[a++] = r >> 12 | 224, t[a++] = r >> 6 & 63 | 128, t[a++] = 63 & r | 128);return a - o; + }; + }), + pool_1 = pool;function pool(e, t, a) { + var r = a || 8192, + n = r >>> 1, + o = null, + s = r;return function (a) { + if (a < 1 || a > n) return e(a);s + a > r && (o = e(r), s = 0);var i = t.call(o, s, s += a);return 7 & s && (s = 1 + (7 | s)), i; + }; + }var longbits = LongBits;function LongBits(e, t) { + this.lo = e >>> 0, this.hi = t >>> 0; + }var zero = LongBits.zero = new LongBits(0, 0);zero.toNumber = function () { + return 0; + }, zero.zzEncode = zero.zzDecode = function () { + return this; + }, zero.length = function () { + return 1; + };var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0";LongBits.fromNumber = function (e) { + if (0 === e) return zero;var t = e < 0;t && (e = -e);var a = e >>> 0, + r = (e - a) / 4294967296 >>> 0;return t && (r = ~r >>> 0, a = ~a >>> 0, ++a > 4294967295 && (a = 0, ++r > 4294967295 && (r = 0))), new LongBits(a, r); + }, LongBits.from = function (e) { + if ("number" == typeof e) return LongBits.fromNumber(e);if (minimal.isString(e)) { + if (!minimal.Long) return LongBits.fromNumber(parseInt(e, 10));e = minimal.Long.fromString(e); + }return e.low || e.high ? new LongBits(e.low >>> 0, e.high >>> 0) : zero; + }, LongBits.prototype.toNumber = function (e) { + if (!e && this.hi >>> 31) { + var t = 1 + ~this.lo >>> 0, + a = ~this.hi >>> 0;return t || (a = a + 1 >>> 0), -(t + 4294967296 * a); + }return this.lo + 4294967296 * this.hi; + }, LongBits.prototype.toLong = function (e) { + return minimal.Long ? new minimal.Long(0 | this.lo, 0 | this.hi, Boolean(e)) : { low: 0 | this.lo, high: 0 | this.hi, unsigned: Boolean(e) }; + };var charCodeAt = String.prototype.charCodeAt;LongBits.fromHash = function (e) { + return e === zeroHash ? zero : new LongBits((charCodeAt.call(e, 0) | charCodeAt.call(e, 1) << 8 | charCodeAt.call(e, 2) << 16 | charCodeAt.call(e, 3) << 24) >>> 0, (charCodeAt.call(e, 4) | charCodeAt.call(e, 5) << 8 | charCodeAt.call(e, 6) << 16 | charCodeAt.call(e, 7) << 24) >>> 0); + }, LongBits.prototype.toHash = function () { + return String.fromCharCode(255 & this.lo, this.lo >>> 8 & 255, this.lo >>> 16 & 255, this.lo >>> 24, 255 & this.hi, this.hi >>> 8 & 255, this.hi >>> 16 & 255, this.hi >>> 24); + }, LongBits.prototype.zzEncode = function () { + var e = this.hi >> 31;return this.hi = ((this.hi << 1 | this.lo >>> 31) ^ e) >>> 0, this.lo = (this.lo << 1 ^ e) >>> 0, this; + }, LongBits.prototype.zzDecode = function () { + var e = -(1 & this.lo);return this.lo = ((this.lo >>> 1 | this.hi << 31) ^ e) >>> 0, this.hi = (this.hi >>> 1 ^ e) >>> 0, this; + }, LongBits.prototype.length = function () { + var e = this.lo, + t = (this.lo >>> 28 | this.hi << 4) >>> 0, + a = this.hi >>> 24;return 0 === a ? 0 === t ? e < 16384 ? e < 128 ? 1 : 2 : e < 2097152 ? 3 : 4 : t < 16384 ? t < 128 ? 5 : 6 : t < 2097152 ? 7 : 8 : a < 128 ? 9 : 10; + };var minimal = createCommonjsModule$1(function (e, t) { + var a = t;function r(e, t, a) { + for (var r = Object.keys(t), n = 0; n < r.length; ++n) void 0 !== e[r[n]] && a || (e[r[n]] = t[r[n]]);return e; + }function n(e) { + function t(e, a) { + if (!(this instanceof t)) return new t(e, a);Object.defineProperty(this, "message", { get: function () { + return e; + } }), Error.captureStackTrace ? Error.captureStackTrace(this, t) : Object.defineProperty(this, "stack", { value: new Error().stack || "" }), a && r(this, a); + }return (t.prototype = Object.create(Error.prototype)).constructor = t, Object.defineProperty(t.prototype, "name", { get: function () { + return e; + } }), t.prototype.toString = function () { + return this.name + ": " + this.message; + }, t; + }a.asPromise = aspromise, a.base64 = base64_1, a.EventEmitter = eventemitter, a.float = float_1, a.inquire = inquire_1, a.utf8 = utf8_1, a.pool = pool_1, a.LongBits = longbits, a.emptyArray = Object.freeze ? Object.freeze([]) : [], a.emptyObject = Object.freeze ? Object.freeze({}) : {}, a.isNode = Boolean(commonjsGlobal$1.process && commonjsGlobal$1.process.versions && commonjsGlobal$1.process.versions.node), a.isInteger = Number.isInteger || function (e) { + return "number" == typeof e && isFinite(e) && Math.floor(e) === e; + }, a.isString = function (e) { + return "string" == typeof e || e instanceof String; + }, a.isObject = function (e) { + return e && "object" == typeof e; + }, a.isset = a.isSet = function (e, t) { + var a = e[t];return !(null == a || !e.hasOwnProperty(t)) && ("object" != typeof a || (Array.isArray(a) ? a.length : Object.keys(a).length) > 0); + }, a.Buffer = function () { + try { + var e = a.inquire("buffer").Buffer;return e.prototype.utf8Write ? e : null; + } catch (e) { + return null; + } + }(), a._Buffer_from = null, a._Buffer_allocUnsafe = null, a.newBuffer = function (e) { + return "number" == typeof e ? a.Buffer ? a._Buffer_allocUnsafe(e) : new a.Array(e) : a.Buffer ? a._Buffer_from(e) : "undefined" == typeof Uint8Array ? e : new Uint8Array(e); + }, a.Array = "undefined" != typeof Uint8Array ? Uint8Array : Array, a.Long = commonjsGlobal$1.dcodeIO && commonjsGlobal$1.dcodeIO.Long || a.inquire("long"), a.key2Re = /^true|false|0|1$/, a.key32Re = /^-?(?:0|[1-9][0-9]*)$/, a.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/, a.longToHash = function (e) { + return e ? a.LongBits.from(e).toHash() : a.LongBits.zeroHash; + }, a.longFromHash = function (e, t) { + var r = a.LongBits.fromHash(e);return a.Long ? a.Long.fromBits(r.lo, r.hi, t) : r.toNumber(Boolean(t)); + }, a.merge = r, a.lcFirst = function (e) { + return e.charAt(0).toLowerCase() + e.substring(1); + }, a.newError = n, a.ProtocolError = n("ProtocolError"), a.oneOfGetter = function (e) { + for (var t = {}, a = 0; a < e.length; ++a) t[e[a]] = 1;return function () { + for (var e = Object.keys(this), a = e.length - 1; a > -1; --a) if (1 === t[e[a]] && void 0 !== this[e[a]] && null !== this[e[a]]) return e[a]; + }; + }, a.oneOfSetter = function (e) { + return function (t) { + for (var a = 0; a < e.length; ++a) e[a] !== t && delete this[e[a]]; + }; + }, a.toJSONOptions = { longs: String, enums: String, bytes: String, json: !0 }, a._configure = function () { + var e = a.Buffer;e ? (a._Buffer_from = e.from !== Uint8Array.from && e.from || function (t, a) { + return new e(t, a); + }, a._Buffer_allocUnsafe = e.allocUnsafe || function (t) { + return new e(t); + }) : a._Buffer_from = a._Buffer_allocUnsafe = null; + }; + }), + writer = Writer, + BufferWriter, + LongBits$1 = minimal.LongBits, + base64 = minimal.base64, + utf8 = minimal.utf8;function Op(e, t, a) { + this.fn = e, this.len = t, this.next = void 0, this.val = a; + }function noop() {}function State(e) { + this.head = e.head, this.tail = e.tail, this.len = e.len, this.next = e.states; + }function Writer() { + this.len = 0, this.head = new Op(noop, 0, 0), this.tail = this.head, this.states = null; + }function writeByte(e, t, a) { + t[a] = 255 & e; + }function writeVarint32(e, t, a) { + for (; e > 127;) t[a++] = 127 & e | 128, e >>>= 7;t[a] = e; + }function VarintOp(e, t) { + this.len = e, this.next = void 0, this.val = t; + }function writeVarint64(e, t, a) { + for (; e.hi;) t[a++] = 127 & e.lo | 128, e.lo = (e.lo >>> 7 | e.hi << 25) >>> 0, e.hi >>>= 7;for (; e.lo > 127;) t[a++] = 127 & e.lo | 128, e.lo = e.lo >>> 7;t[a++] = e.lo; + }function writeFixed32(e, t, a) { + t[a] = 255 & e, t[a + 1] = e >>> 8 & 255, t[a + 2] = e >>> 16 & 255, t[a + 3] = e >>> 24; + }Writer.create = minimal.Buffer ? function () { + return (Writer.create = function () { + return new BufferWriter(); + })(); + } : function () { + return new Writer(); + }, Writer.alloc = function (e) { + return new minimal.Array(e); + }, minimal.Array !== Array && (Writer.alloc = minimal.pool(Writer.alloc, minimal.Array.prototype.subarray)), Writer.prototype._push = function (e, t, a) { + return this.tail = this.tail.next = new Op(e, t, a), this.len += t, this; + }, VarintOp.prototype = Object.create(Op.prototype), VarintOp.prototype.fn = writeVarint32, Writer.prototype.uint32 = function (e) { + return this.len += (this.tail = this.tail.next = new VarintOp((e >>>= 0) < 128 ? 1 : e < 16384 ? 2 : e < 2097152 ? 3 : e < 268435456 ? 4 : 5, e)).len, this; + }, Writer.prototype.int32 = function (e) { + return e < 0 ? this._push(writeVarint64, 10, LongBits$1.fromNumber(e)) : this.uint32(e); + }, Writer.prototype.sint32 = function (e) { + return this.uint32((e << 1 ^ e >> 31) >>> 0); + }, Writer.prototype.uint64 = function (e) { + var t = LongBits$1.from(e);return this._push(writeVarint64, t.length(), t); + }, Writer.prototype.int64 = Writer.prototype.uint64, Writer.prototype.sint64 = function (e) { + var t = LongBits$1.from(e).zzEncode();return this._push(writeVarint64, t.length(), t); + }, Writer.prototype.bool = function (e) { + return this._push(writeByte, 1, e ? 1 : 0); + }, Writer.prototype.fixed32 = function (e) { + return this._push(writeFixed32, 4, e >>> 0); + }, Writer.prototype.sfixed32 = Writer.prototype.fixed32, Writer.prototype.fixed64 = function (e) { + var t = LongBits$1.from(e);return this._push(writeFixed32, 4, t.lo)._push(writeFixed32, 4, t.hi); + }, Writer.prototype.sfixed64 = Writer.prototype.fixed64, Writer.prototype.float = function (e) { + return this._push(minimal.float.writeFloatLE, 4, e); + }, Writer.prototype.double = function (e) { + return this._push(minimal.float.writeDoubleLE, 8, e); + };var writeBytes = minimal.Array.prototype.set ? function (e, t, a) { + t.set(e, a); + } : function (e, t, a) { + for (var r = 0; r < e.length; ++r) t[a + r] = e[r]; + };Writer.prototype.bytes = function (e) { + var t = e.length >>> 0;if (!t) return this._push(writeByte, 1, 0);if (minimal.isString(e)) { + var a = Writer.alloc(t = base64.length(e));base64.decode(e, a, 0), e = a; + }return this.uint32(t)._push(writeBytes, t, e); + }, Writer.prototype.string = function (e) { + var t = utf8.length(e);return t ? this.uint32(t)._push(utf8.write, t, e) : this._push(writeByte, 1, 0); + }, Writer.prototype.fork = function () { + return this.states = new State(this), this.head = this.tail = new Op(noop, 0, 0), this.len = 0, this; + }, Writer.prototype.reset = function () { + return this.states ? (this.head = this.states.head, this.tail = this.states.tail, this.len = this.states.len, this.states = this.states.next) : (this.head = this.tail = new Op(noop, 0, 0), this.len = 0), this; + }, Writer.prototype.ldelim = function () { + var e = this.head, + t = this.tail, + a = this.len;return this.reset().uint32(a), a && (this.tail.next = e.next, this.tail = t, this.len += a), this; + }, Writer.prototype.finish = function () { + for (var e = this.head.next, t = this.constructor.alloc(this.len), a = 0; e;) e.fn(e.val, t, a), a += e.len, e = e.next;return t; + }, Writer._configure = function (e) { + BufferWriter = e; + };var writer_buffer = BufferWriter$1;(BufferWriter$1.prototype = Object.create(writer.prototype)).constructor = BufferWriter$1;var Buffer$1 = minimal.Buffer;function BufferWriter$1() { + writer.call(this); + }BufferWriter$1.alloc = function (e) { + return (BufferWriter$1.alloc = minimal._Buffer_allocUnsafe)(e); + };var writeBytesBuffer = Buffer$1 && Buffer$1.prototype instanceof Uint8Array && "set" === Buffer$1.prototype.set.name ? function (e, t, a) { + t.set(e, a); + } : function (e, t, a) { + if (e.copy) e.copy(t, a, 0, e.length);else for (var r = 0; r < e.length;) t[a++] = e[r++]; + };function writeStringBuffer(e, t, a) { + e.length < 40 ? minimal.utf8.write(e, t, a) : t.utf8Write(e, a); + }BufferWriter$1.prototype.bytes = function (e) { + minimal.isString(e) && (e = minimal._Buffer_from(e, "base64"));var t = e.length >>> 0;return this.uint32(t), t && this._push(writeBytesBuffer, t, e), this; + }, BufferWriter$1.prototype.string = function (e) { + var t = Buffer$1.byteLength(e);return this.uint32(t), t && this._push(writeStringBuffer, t, e), this; + };var reader = Reader, + BufferReader, + LongBits$2 = minimal.LongBits, + utf8$1 = minimal.utf8;function indexOutOfRange(e, t) { + return RangeError("index out of range: " + e.pos + " + " + (t || 1) + " > " + e.len); + }function Reader(e) { + this.buf = e, this.pos = 0, this.len = e.length; + }var create_array = "undefined" != typeof Uint8Array ? function (e) { + if (e instanceof Uint8Array || Array.isArray(e)) return new Reader(e);throw Error("illegal buffer"); + } : function (e) { + if (Array.isArray(e)) return new Reader(e);throw Error("illegal buffer"); + };function readLongVarint() { + var e = new LongBits$2(0, 0), + t = 0;if (!(this.len - this.pos > 4)) { + for (; t < 3; ++t) { + if (this.pos >= this.len) throw indexOutOfRange(this);if (e.lo = (e.lo | (127 & this.buf[this.pos]) << 7 * t) >>> 0, this.buf[this.pos++] < 128) return e; + }return e.lo = (e.lo | (127 & this.buf[this.pos++]) << 7 * t) >>> 0, e; + }for (; t < 4; ++t) if (e.lo = (e.lo | (127 & this.buf[this.pos]) << 7 * t) >>> 0, this.buf[this.pos++] < 128) return e;if (e.lo = (e.lo | (127 & this.buf[this.pos]) << 28) >>> 0, e.hi = (e.hi | (127 & this.buf[this.pos]) >> 4) >>> 0, this.buf[this.pos++] < 128) return e;if (t = 0, this.len - this.pos > 4) { + for (; t < 5; ++t) if (e.hi = (e.hi | (127 & this.buf[this.pos]) << 7 * t + 3) >>> 0, this.buf[this.pos++] < 128) return e; + } else for (; t < 5; ++t) { + if (this.pos >= this.len) throw indexOutOfRange(this);if (e.hi = (e.hi | (127 & this.buf[this.pos]) << 7 * t + 3) >>> 0, this.buf[this.pos++] < 128) return e; + }throw Error("invalid varint encoding"); + }function readFixed32_end(e, t) { + return (e[t - 4] | e[t - 3] << 8 | e[t - 2] << 16 | e[t - 1] << 24) >>> 0; + }function readFixed64() { + if (this.pos + 8 > this.len) throw indexOutOfRange(this, 8);return new LongBits$2(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); + }Reader.create = minimal.Buffer ? function (e) { + return (Reader.create = function (e) { + return minimal.Buffer.isBuffer(e) ? new BufferReader(e) : create_array(e); + })(e); + } : create_array, Reader.prototype._slice = minimal.Array.prototype.subarray || minimal.Array.prototype.slice, Reader.prototype.uint32 = function () { + var e = 4294967295;return function () { + if (e = (127 & this.buf[this.pos]) >>> 0, this.buf[this.pos++] < 128) return e;if (e = (e | (127 & this.buf[this.pos]) << 7) >>> 0, this.buf[this.pos++] < 128) return e;if (e = (e | (127 & this.buf[this.pos]) << 14) >>> 0, this.buf[this.pos++] < 128) return e;if (e = (e | (127 & this.buf[this.pos]) << 21) >>> 0, this.buf[this.pos++] < 128) return e;if (e = (e | (15 & this.buf[this.pos]) << 28) >>> 0, this.buf[this.pos++] < 128) return e;if ((this.pos += 5) > this.len) throw this.pos = this.len, indexOutOfRange(this, 10);return e; + }; + }(), Reader.prototype.int32 = function () { + return 0 | this.uint32(); + }, Reader.prototype.sint32 = function () { + var e = this.uint32();return e >>> 1 ^ -(1 & e) | 0; + }, Reader.prototype.bool = function () { + return 0 !== this.uint32(); + }, Reader.prototype.fixed32 = function () { + if (this.pos + 4 > this.len) throw indexOutOfRange(this, 4);return readFixed32_end(this.buf, this.pos += 4); + }, Reader.prototype.sfixed32 = function () { + if (this.pos + 4 > this.len) throw indexOutOfRange(this, 4);return 0 | readFixed32_end(this.buf, this.pos += 4); + }, Reader.prototype.float = function () { + if (this.pos + 4 > this.len) throw indexOutOfRange(this, 4);var e = minimal.float.readFloatLE(this.buf, this.pos);return this.pos += 4, e; + }, Reader.prototype.double = function () { + if (this.pos + 8 > this.len) throw indexOutOfRange(this, 4);var e = minimal.float.readDoubleLE(this.buf, this.pos);return this.pos += 8, e; + }, Reader.prototype.bytes = function () { + var e = this.uint32(), + t = this.pos, + a = this.pos + e;if (a > this.len) throw indexOutOfRange(this, e);return this.pos += e, Array.isArray(this.buf) ? this.buf.slice(t, a) : t === a ? new this.buf.constructor(0) : this._slice.call(this.buf, t, a); + }, Reader.prototype.string = function () { + var e = this.bytes();return utf8$1.read(e, 0, e.length); + }, Reader.prototype.skip = function (e) { + if ("number" == typeof e) { + if (this.pos + e > this.len) throw indexOutOfRange(this, e);this.pos += e; + } else do { + if (this.pos >= this.len) throw indexOutOfRange(this); + } while (128 & this.buf[this.pos++]);return this; + }, Reader.prototype.skipType = function (e) { + switch (e) {case 0: + this.skip();break;case 1: + this.skip(8);break;case 2: + this.skip(this.uint32());break;case 3: + for (;;) { + if (4 == (e = 7 & this.uint32())) break;this.skipType(e); + }break;case 5: + this.skip(4);break;default: + throw Error("invalid wire type " + e + " at offset " + this.pos);}return this; + }, Reader._configure = function (e) { + BufferReader = e;var t = minimal.Long ? "toLong" : "toNumber";minimal.merge(Reader.prototype, { int64: function () { + return readLongVarint.call(this)[t](!1); + }, uint64: function () { + return readLongVarint.call(this)[t](!0); + }, sint64: function () { + return readLongVarint.call(this).zzDecode()[t](!1); + }, fixed64: function () { + return readFixed64.call(this)[t](!0); + }, sfixed64: function () { + return readFixed64.call(this)[t](!1); + } }); + };var reader_buffer = BufferReader$1;function BufferReader$1(e) { + reader.call(this, e); + }(BufferReader$1.prototype = Object.create(reader.prototype)).constructor = BufferReader$1, minimal.Buffer && (BufferReader$1.prototype._slice = minimal.Buffer.prototype.slice), BufferReader$1.prototype.string = function () { + var e = this.uint32();return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + e, this.len)); + };var service = Service;function Service(e, t, a) { + if ("function" != typeof e) throw TypeError("rpcImpl must be a function");minimal.EventEmitter.call(this), this.rpcImpl = e, this.requestDelimited = Boolean(t), this.responseDelimited = Boolean(a); + }(Service.prototype = Object.create(minimal.EventEmitter.prototype)).constructor = Service, Service.prototype.rpcCall = function e(t, a, r, n, o) { + if (!n) throw TypeError("request must be specified");var s = this;if (!o) return minimal.asPromise(e, s, t, a, r, n);if (s.rpcImpl) try { + return s.rpcImpl(t, a[s.requestDelimited ? "encodeDelimited" : "encode"](n).finish(), function (e, a) { + if (e) return s.emit("error", e, t), o(e);if (null !== a) { + if (!(a instanceof r)) try { + a = r[s.responseDelimited ? "decodeDelimited" : "decode"](a); + } catch (e) { + return s.emit("error", e, t), o(e); + }return s.emit("data", a, t), o(null, a); + }s.end(!0); + }); + } catch (e) { + return s.emit("error", e, t), void setTimeout(function () { + o(e); + }, 0); + } else setTimeout(function () { + o(Error("already ended")); + }, 0); + }, Service.prototype.end = function (e) { + return this.rpcImpl && (e || this.rpcImpl(null, null, null), this.rpcImpl = null, this.emit("end").off()), this; + };var rpc_1 = createCommonjsModule$1(function (e, t) { + t.Service = service; + }), + roots = {}, + indexMinimal = createCommonjsModule$1(function (e, t) { + var a = t;function r() { + a.Reader._configure(a.BufferReader), a.util._configure(); + }a.build = "minimal", a.Writer = writer, a.BufferWriter = writer_buffer, a.Reader = reader, a.BufferReader = reader_buffer, a.util = minimal, a.rpc = rpc_1, a.roots = roots, a.configure = r, a.Writer._configure(a.BufferWriter), r(); + }), + minimal$1 = indexMinimal, + minimal_1 = minimal$1.roots, + minimal_2 = minimal$1.Reader, + minimal_3 = minimal$1.util, + $Reader = minimal$1.Reader, + $util = minimal$1.util, + $root = minimal$1.roots.default || (minimal$1.roots.default = {});$root.tensorflow = function () { + var e, + t, + a = {};return a.Any = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.typeUrl = "", e.prototype.value = $util.newBuffer([]), e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.Any(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.typeUrl = e.string();break;case 2: + r.value = e.bytes();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.DataType = (e = {}, (t = Object.create(e))[e[0] = "DT_INVALID"] = 0, t[e[1] = "DT_FLOAT"] = 1, t[e[2] = "DT_DOUBLE"] = 2, t[e[3] = "DT_INT32"] = 3, t[e[4] = "DT_UINT8"] = 4, t[e[5] = "DT_INT16"] = 5, t[e[6] = "DT_INT8"] = 6, t[e[7] = "DT_STRING"] = 7, t[e[8] = "DT_COMPLEX64"] = 8, t[e[9] = "DT_INT64"] = 9, t[e[10] = "DT_BOOL"] = 10, t[e[11] = "DT_QINT8"] = 11, t[e[12] = "DT_QUINT8"] = 12, t[e[13] = "DT_QINT32"] = 13, t[e[14] = "DT_BFLOAT16"] = 14, t[e[101] = "DT_FLOAT_REF"] = 101, t[e[102] = "DT_DOUBLE_REF"] = 102, t[e[103] = "DT_INT32_REF"] = 103, t[e[104] = "DT_UINT8_REF"] = 104, t[e[105] = "DT_INT16_REF"] = 105, t[e[106] = "DT_INT8_REF"] = 106, t[e[107] = "DT_STRING_REF"] = 107, t[e[108] = "DT_COMPLEX64_REF"] = 108, t[e[109] = "DT_INT64_REF"] = 109, t[e[110] = "DT_BOOL_REF"] = 110, t[e[111] = "DT_QINT8_REF"] = 111, t[e[112] = "DT_QUINT8_REF"] = 112, t[e[113] = "DT_QINT32_REF"] = 113, t[e[114] = "DT_BFLOAT16_REF"] = 114, t), a.TensorShape = function () { + function e(e) { + if (this.dim = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.dim = $util.emptyArray, e.prototype.unknownRank = !1, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.TensorShape(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 2: + r.dim && r.dim.length || (r.dim = []), r.dim.push($root.tensorflow.TensorShape.Dim.decode(e, e.uint32()));break;case 3: + r.unknownRank = e.bool();break;default: + e.skipType(7 & n);} + }return r; + }, e.Dim = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.size = $util.Long ? $util.Long.fromBits(0, 0, !1) : 0, e.prototype.name = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.TensorShape.Dim(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.size = e.int64();break;case 2: + r.name = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.Tensor = function () { + function e(e) { + if (this.floatVal = [], this.doubleVal = [], this.intVal = [], this.stringVal = [], this.scomplexVal = [], this.int64Val = [], this.boolVal = [], this.uint32Val = [], this.uint64Val = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.dtype = 0, e.prototype.tensorShape = null, e.prototype.versionNumber = 0, e.prototype.tensorContent = $util.newBuffer([]), e.prototype.floatVal = $util.emptyArray, e.prototype.doubleVal = $util.emptyArray, e.prototype.intVal = $util.emptyArray, e.prototype.stringVal = $util.emptyArray, e.prototype.scomplexVal = $util.emptyArray, e.prototype.int64Val = $util.emptyArray, e.prototype.boolVal = $util.emptyArray, e.prototype.uint32Val = $util.emptyArray, e.prototype.uint64Val = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.Tensor(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.dtype = e.int32();break;case 2: + r.tensorShape = $root.tensorflow.TensorShape.decode(e, e.uint32());break;case 3: + r.versionNumber = e.int32();break;case 4: + r.tensorContent = e.bytes();break;case 5: + if (r.floatVal && r.floatVal.length || (r.floatVal = []), 2 == (7 & n)) for (var o = e.uint32() + e.pos; e.pos < o;) r.floatVal.push(e.float());else r.floatVal.push(e.float());break;case 6: + if (r.doubleVal && r.doubleVal.length || (r.doubleVal = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.doubleVal.push(e.double());else r.doubleVal.push(e.double());break;case 7: + if (r.intVal && r.intVal.length || (r.intVal = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.intVal.push(e.int32());else r.intVal.push(e.int32());break;case 8: + r.stringVal && r.stringVal.length || (r.stringVal = []), r.stringVal.push(e.bytes());break;case 9: + if (r.scomplexVal && r.scomplexVal.length || (r.scomplexVal = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.scomplexVal.push(e.float());else r.scomplexVal.push(e.float());break;case 10: + if (r.int64Val && r.int64Val.length || (r.int64Val = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.int64Val.push(e.int64());else r.int64Val.push(e.int64());break;case 11: + if (r.boolVal && r.boolVal.length || (r.boolVal = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.boolVal.push(e.bool());else r.boolVal.push(e.bool());break;case 16: + if (r.uint32Val && r.uint32Val.length || (r.uint32Val = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.uint32Val.push(e.uint32());else r.uint32Val.push(e.uint32());break;case 17: + if (r.uint64Val && r.uint64Val.length || (r.uint64Val = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.uint64Val.push(e.uint64());else r.uint64Val.push(e.uint64());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.AttrValue = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }var t;return e.prototype.list = null, e.prototype.s = $util.newBuffer([]), e.prototype.i = $util.Long ? $util.Long.fromBits(0, 0, !1) : 0, e.prototype.f = 0, e.prototype.b = !1, e.prototype.type = 0, e.prototype.shape = null, e.prototype.tensor = null, e.prototype.placeholder = "", e.prototype.func = null, Object.defineProperty(e.prototype, "value", { get: $util.oneOfGetter(t = ["list", "s", "i", "f", "b", "type", "shape", "tensor", "placeholder", "func"]), set: $util.oneOfSetter(t) }), e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.AttrValue(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.list = $root.tensorflow.AttrValue.ListValue.decode(e, e.uint32());break;case 2: + r.s = e.bytes();break;case 3: + r.i = e.int64();break;case 4: + r.f = e.float();break;case 5: + r.b = e.bool();break;case 6: + r.type = e.int32();break;case 7: + r.shape = $root.tensorflow.TensorShape.decode(e, e.uint32());break;case 8: + r.tensor = $root.tensorflow.Tensor.decode(e, e.uint32());break;case 9: + r.placeholder = e.string();break;case 10: + r.func = $root.tensorflow.NameAttrList.decode(e, e.uint32());break;default: + e.skipType(7 & n);} + }return r; + }, e.ListValue = function () { + function e(e) { + if (this.s = [], this.i = [], this.f = [], this.b = [], this.type = [], this.shape = [], this.tensor = [], this.func = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.s = $util.emptyArray, e.prototype.i = $util.emptyArray, e.prototype.f = $util.emptyArray, e.prototype.b = $util.emptyArray, e.prototype.type = $util.emptyArray, e.prototype.shape = $util.emptyArray, e.prototype.tensor = $util.emptyArray, e.prototype.func = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.AttrValue.ListValue(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 2: + r.s && r.s.length || (r.s = []), r.s.push(e.bytes());break;case 3: + if (r.i && r.i.length || (r.i = []), 2 == (7 & n)) for (var o = e.uint32() + e.pos; e.pos < o;) r.i.push(e.int64());else r.i.push(e.int64());break;case 4: + if (r.f && r.f.length || (r.f = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.f.push(e.float());else r.f.push(e.float());break;case 5: + if (r.b && r.b.length || (r.b = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.b.push(e.bool());else r.b.push(e.bool());break;case 6: + if (r.type && r.type.length || (r.type = []), 2 == (7 & n)) for (o = e.uint32() + e.pos; e.pos < o;) r.type.push(e.int32());else r.type.push(e.int32());break;case 7: + r.shape && r.shape.length || (r.shape = []), r.shape.push($root.tensorflow.TensorShape.decode(e, e.uint32()));break;case 8: + r.tensor && r.tensor.length || (r.tensor = []), r.tensor.push($root.tensorflow.Tensor.decode(e, e.uint32()));break;case 9: + r.func && r.func.length || (r.func = []), r.func.push($root.tensorflow.NameAttrList.decode(e, e.uint32()));break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.NameAttrList = function () { + function e(e) { + if (this.attr = {}, e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.name = "", e.prototype.attr = $util.emptyObject, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a, r = void 0 === t ? e.len : e.pos + t, n = new $root.tensorflow.NameAttrList(); e.pos < r;) { + var o = e.uint32();switch (o >>> 3) {case 1: + n.name = e.string();break;case 2: + e.skip().pos++, n.attr === $util.emptyObject && (n.attr = {}), a = e.string(), e.pos++, n.attr[a] = $root.tensorflow.AttrValue.decode(e, e.uint32());break;default: + e.skipType(7 & o);} + }return n; + }, e; + }(), a.NodeDef = function () { + function e(e) { + if (this.input = [], this.attr = {}, e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.name = "", e.prototype.op = "", e.prototype.input = $util.emptyArray, e.prototype.device = "", e.prototype.attr = $util.emptyObject, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a, r = void 0 === t ? e.len : e.pos + t, n = new $root.tensorflow.NodeDef(); e.pos < r;) { + var o = e.uint32();switch (o >>> 3) {case 1: + n.name = e.string();break;case 2: + n.op = e.string();break;case 3: + n.input && n.input.length || (n.input = []), n.input.push(e.string());break;case 4: + n.device = e.string();break;case 5: + e.skip().pos++, n.attr === $util.emptyObject && (n.attr = {}), a = e.string(), e.pos++, n.attr[a] = $root.tensorflow.AttrValue.decode(e, e.uint32());break;default: + e.skipType(7 & o);} + }return n; + }, e; + }(), a.VersionDef = function () { + function e(e) { + if (this.badConsumers = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.producer = 0, e.prototype.minConsumer = 0, e.prototype.badConsumers = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.VersionDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.producer = e.int32();break;case 2: + r.minConsumer = e.int32();break;case 3: + if (r.badConsumers && r.badConsumers.length || (r.badConsumers = []), 2 == (7 & n)) for (var o = e.uint32() + e.pos; e.pos < o;) r.badConsumers.push(e.int32());else r.badConsumers.push(e.int32());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.GraphDef = function () { + function e(e) { + if (this.node = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.node = $util.emptyArray, e.prototype.versions = null, e.prototype.library = null, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.GraphDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.node && r.node.length || (r.node = []), r.node.push($root.tensorflow.NodeDef.decode(e, e.uint32()));break;case 4: + r.versions = $root.tensorflow.VersionDef.decode(e, e.uint32());break;case 2: + r.library = $root.tensorflow.FunctionDefLibrary.decode(e, e.uint32());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.CollectionDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }var t;return e.prototype.nodeList = null, e.prototype.bytesList = null, e.prototype.int64List = null, e.prototype.floatList = null, e.prototype.anyList = null, Object.defineProperty(e.prototype, "kind", { get: $util.oneOfGetter(t = ["nodeList", "bytesList", "int64List", "floatList", "anyList"]), set: $util.oneOfSetter(t) }), e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.nodeList = $root.tensorflow.CollectionDef.NodeList.decode(e, e.uint32());break;case 2: + r.bytesList = $root.tensorflow.CollectionDef.BytesList.decode(e, e.uint32());break;case 3: + r.int64List = $root.tensorflow.CollectionDef.Int64List.decode(e, e.uint32());break;case 4: + r.floatList = $root.tensorflow.CollectionDef.FloatList.decode(e, e.uint32());break;case 5: + r.anyList = $root.tensorflow.CollectionDef.AnyList.decode(e, e.uint32());break;default: + e.skipType(7 & n);} + }return r; + }, e.NodeList = function () { + function e(e) { + if (this.value = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.value = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef.NodeList(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.value && r.value.length || (r.value = []), r.value.push(e.string());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.BytesList = function () { + function e(e) { + if (this.value = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.value = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef.BytesList(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.value && r.value.length || (r.value = []), r.value.push(e.bytes());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.Int64List = function () { + function e(e) { + if (this.value = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.value = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef.Int64List(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + if (r.value && r.value.length || (r.value = []), 2 == (7 & n)) for (var o = e.uint32() + e.pos; e.pos < o;) r.value.push(e.int64());else r.value.push(e.int64());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.FloatList = function () { + function e(e) { + if (this.value = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.value = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef.FloatList(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + if (r.value && r.value.length || (r.value = []), 2 == (7 & n)) for (var o = e.uint32() + e.pos; e.pos < o;) r.value.push(e.float());else r.value.push(e.float());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.AnyList = function () { + function e(e) { + if (this.value = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.value = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.CollectionDef.AnyList(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.value && r.value.length || (r.value = []), r.value.push($root.tensorflow.Any.decode(e, e.uint32()));break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.SaverDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }var t, a;return e.prototype.filenameTensorName = "", e.prototype.saveTensorName = "", e.prototype.restoreOpName = "", e.prototype.maxToKeep = 0, e.prototype.sharded = !1, e.prototype.keepCheckpointEveryNHours = 0, e.prototype.version = 0, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.SaverDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.filenameTensorName = e.string();break;case 2: + r.saveTensorName = e.string();break;case 3: + r.restoreOpName = e.string();break;case 4: + r.maxToKeep = e.int32();break;case 5: + r.sharded = e.bool();break;case 6: + r.keepCheckpointEveryNHours = e.float();break;case 7: + r.version = e.int32();break;default: + e.skipType(7 & n);} + }return r; + }, e.CheckpointFormatVersion = (t = {}, (a = Object.create(t))[t[0] = "LEGACY"] = 0, a[t[1] = "V1"] = 1, a[t[2] = "V2"] = 2, a), e; + }(), a.TensorInfo = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }var t;return e.prototype.name = "", e.prototype.cooSparse = null, e.prototype.dtype = 0, e.prototype.tensorShape = null, Object.defineProperty(e.prototype, "encoding", { get: $util.oneOfGetter(t = ["name", "cooSparse"]), set: $util.oneOfSetter(t) }), e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.TensorInfo(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.name = e.string();break;case 4: + r.cooSparse = $root.tensorflow.TensorInfo.CooSparse.decode(e, e.uint32());break;case 2: + r.dtype = e.int32();break;case 3: + r.tensorShape = $root.tensorflow.TensorShape.decode(e, e.uint32());break;default: + e.skipType(7 & n);} + }return r; + }, e.CooSparse = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.valuesTensorName = "", e.prototype.indicesTensorName = "", e.prototype.denseShapeTensorName = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.TensorInfo.CooSparse(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.valuesTensorName = e.string();break;case 2: + r.indicesTensorName = e.string();break;case 3: + r.denseShapeTensorName = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.SignatureDef = function () { + function e(e) { + if (this.inputs = {}, this.outputs = {}, e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.inputs = $util.emptyObject, e.prototype.outputs = $util.emptyObject, e.prototype.methodName = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a, r = void 0 === t ? e.len : e.pos + t, n = new $root.tensorflow.SignatureDef(); e.pos < r;) { + var o = e.uint32();switch (o >>> 3) {case 1: + e.skip().pos++, n.inputs === $util.emptyObject && (n.inputs = {}), a = e.string(), e.pos++, n.inputs[a] = $root.tensorflow.TensorInfo.decode(e, e.uint32());break;case 2: + e.skip().pos++, n.outputs === $util.emptyObject && (n.outputs = {}), a = e.string(), e.pos++, n.outputs[a] = $root.tensorflow.TensorInfo.decode(e, e.uint32());break;case 3: + n.methodName = e.string();break;default: + e.skipType(7 & o);} + }return n; + }, e; + }(), a.AssetFileDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.tensorInfo = null, e.prototype.filename = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.AssetFileDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.tensorInfo = $root.tensorflow.TensorInfo.decode(e, e.uint32());break;case 2: + r.filename = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.OpDef = function () { + function e(e) { + if (this.inputArg = [], this.outputArg = [], this.attr = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.name = "", e.prototype.inputArg = $util.emptyArray, e.prototype.outputArg = $util.emptyArray, e.prototype.attr = $util.emptyArray, e.prototype.deprecation = null, e.prototype.summary = "", e.prototype.description = "", e.prototype.isCommutative = !1, e.prototype.isAggregate = !1, e.prototype.isStateful = !1, e.prototype.allowsUninitializedInput = !1, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.OpDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.name = e.string();break;case 2: + r.inputArg && r.inputArg.length || (r.inputArg = []), r.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e, e.uint32()));break;case 3: + r.outputArg && r.outputArg.length || (r.outputArg = []), r.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e, e.uint32()));break;case 4: + r.attr && r.attr.length || (r.attr = []), r.attr.push($root.tensorflow.OpDef.AttrDef.decode(e, e.uint32()));break;case 8: + r.deprecation = $root.tensorflow.OpDef.OpDeprecation.decode(e, e.uint32());break;case 5: + r.summary = e.string();break;case 6: + r.description = e.string();break;case 18: + r.isCommutative = e.bool();break;case 16: + r.isAggregate = e.bool();break;case 17: + r.isStateful = e.bool();break;case 19: + r.allowsUninitializedInput = e.bool();break;default: + e.skipType(7 & n);} + }return r; + }, e.ArgDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.name = "", e.prototype.description = "", e.prototype.type = 0, e.prototype.typeAttr = "", e.prototype.numberAttr = "", e.prototype.typeListAttr = "", e.prototype.isRef = !1, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.OpDef.ArgDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.name = e.string();break;case 2: + r.description = e.string();break;case 3: + r.type = e.int32();break;case 4: + r.typeAttr = e.string();break;case 5: + r.numberAttr = e.string();break;case 6: + r.typeListAttr = e.string();break;case 16: + r.isRef = e.bool();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.AttrDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.name = "", e.prototype.type = "", e.prototype.defaultValue = null, e.prototype.description = "", e.prototype.hasMinimum = !1, e.prototype.minimum = $util.Long ? $util.Long.fromBits(0, 0, !1) : 0, e.prototype.allowedValues = null, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.OpDef.AttrDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.name = e.string();break;case 2: + r.type = e.string();break;case 3: + r.defaultValue = $root.tensorflow.AttrValue.decode(e, e.uint32());break;case 4: + r.description = e.string();break;case 5: + r.hasMinimum = e.bool();break;case 6: + r.minimum = e.int64();break;case 7: + r.allowedValues = $root.tensorflow.AttrValue.decode(e, e.uint32());break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e.OpDeprecation = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.version = 0, e.prototype.explanation = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.OpDef.OpDeprecation(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.version = e.int32();break;case 2: + r.explanation = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.OpList = function () { + function e(e) { + if (this.op = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.op = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.OpList(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.op && r.op.length || (r.op = []), r.op.push($root.tensorflow.OpDef.decode(e, e.uint32()));break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.MetaGraphDef = function () { + function e(e) { + if (this.collectionDef = {}, this.signatureDef = {}, this.assetFileDef = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.metaInfoDef = null, e.prototype.graphDef = null, e.prototype.saverDef = null, e.prototype.collectionDef = $util.emptyObject, e.prototype.signatureDef = $util.emptyObject, e.prototype.assetFileDef = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a, r = void 0 === t ? e.len : e.pos + t, n = new $root.tensorflow.MetaGraphDef(); e.pos < r;) { + var o = e.uint32();switch (o >>> 3) {case 1: + n.metaInfoDef = $root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e, e.uint32());break;case 2: + n.graphDef = $root.tensorflow.GraphDef.decode(e, e.uint32());break;case 3: + n.saverDef = $root.tensorflow.SaverDef.decode(e, e.uint32());break;case 4: + e.skip().pos++, n.collectionDef === $util.emptyObject && (n.collectionDef = {}), a = e.string(), e.pos++, n.collectionDef[a] = $root.tensorflow.CollectionDef.decode(e, e.uint32());break;case 5: + e.skip().pos++, n.signatureDef === $util.emptyObject && (n.signatureDef = {}), a = e.string(), e.pos++, n.signatureDef[a] = $root.tensorflow.SignatureDef.decode(e, e.uint32());break;case 6: + n.assetFileDef && n.assetFileDef.length || (n.assetFileDef = []), n.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e, e.uint32()));break;default: + e.skipType(7 & o);} + }return n; + }, e.MetaInfoDef = function () { + function e(e) { + if (this.tags = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.metaGraphVersion = "", e.prototype.strippedOpList = null, e.prototype.anyInfo = null, e.prototype.tags = $util.emptyArray, e.prototype.tensorflowVersion = "", e.prototype.tensorflowGitVersion = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.MetaGraphDef.MetaInfoDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.metaGraphVersion = e.string();break;case 2: + r.strippedOpList = $root.tensorflow.OpList.decode(e, e.uint32());break;case 3: + r.anyInfo = $root.tensorflow.Any.decode(e, e.uint32());break;case 4: + r.tags && r.tags.length || (r.tags = []), r.tags.push(e.string());break;case 5: + r.tensorflowVersion = e.string();break;case 6: + r.tensorflowGitVersion = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), e; + }(), a.SavedModel = function () { + function e(e) { + if (this.metaGraphs = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.savedModelSchemaVersion = $util.Long ? $util.Long.fromBits(0, 0, !1) : 0, e.prototype.metaGraphs = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.SavedModel(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.savedModelSchemaVersion = e.int64();break;case 2: + r.metaGraphs && r.metaGraphs.length || (r.metaGraphs = []), r.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e, e.uint32()));break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.FunctionDefLibrary = function () { + function e(e) { + if (this.function = [], this.gradient = [], e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.function = $util.emptyArray, e.prototype.gradient = $util.emptyArray, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.FunctionDefLibrary(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.function && r.function.length || (r.function = []), r.function.push($root.tensorflow.FunctionDef.decode(e, e.uint32()));break;case 2: + r.gradient && r.gradient.length || (r.gradient = []), r.gradient.push($root.tensorflow.GradientDef.decode(e, e.uint32()));break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a.FunctionDef = function () { + function e(e) { + if (this.attr = {}, this.nodeDef = [], this.ret = {}, e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.signature = null, e.prototype.attr = $util.emptyObject, e.prototype.nodeDef = $util.emptyArray, e.prototype.ret = $util.emptyObject, e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a, r = void 0 === t ? e.len : e.pos + t, n = new $root.tensorflow.FunctionDef(); e.pos < r;) { + var o = e.uint32();switch (o >>> 3) {case 1: + n.signature = $root.tensorflow.OpDef.decode(e, e.uint32());break;case 5: + e.skip().pos++, n.attr === $util.emptyObject && (n.attr = {}), a = e.string(), e.pos++, n.attr[a] = $root.tensorflow.AttrValue.decode(e, e.uint32());break;case 3: + n.nodeDef && n.nodeDef.length || (n.nodeDef = []), n.nodeDef.push($root.tensorflow.NodeDef.decode(e, e.uint32()));break;case 4: + e.skip().pos++, n.ret === $util.emptyObject && (n.ret = {}), a = e.string(), e.pos++, n.ret[a] = e.string();break;default: + e.skipType(7 & o);} + }return n; + }, e; + }(), a.GradientDef = function () { + function e(e) { + if (e) for (var t = Object.keys(e), a = 0; a < t.length; ++a) null != e[t[a]] && (this[t[a]] = e[t[a]]); + }return e.prototype.functionName = "", e.prototype.gradientFunc = "", e.decode = function (e, t) { + e instanceof $Reader || (e = $Reader.create(e));for (var a = void 0 === t ? e.len : e.pos + t, r = new $root.tensorflow.GradientDef(); e.pos < a;) { + var n = e.uint32();switch (n >>> 3) {case 1: + r.functionName = e.string();break;case 2: + r.gradientFunc = e.string();break;default: + e.skipType(7 & n);} + }return r; + }, e; + }(), a; + }();var compiled_api = $root, + compiled_api_1 = compiled_api.tensorflow;function getParamValue(e, t, a, r) { + var n = t.params[e];if (n && void 0 !== n.inputIndex) { + if ("tensor" === n.type) return getTensor(t.inputNames[n.inputIndex], a, r);if ("tensors" === n.type) return (0 === n.inputIndex ? 0 === n.inputParamLength ? t.inputNames : t.inputNames.slice(n.inputIndex, -n.inputParamLength) : t.inputNames.splice(n.inputIndex)).map(function (e) { + return getTensor(e, a, r); + });var o = Array.prototype.slice.call(getTensor(t.inputNames.slice(n.inputIndex)[0], a, r).dataSync());return "number" === n.type ? o[0] : o; + }return n && n.value; + }function getTensor(e, t, a) { + var r = parseNodeName(e), + n = r[0], + o = r[1], + s = a.currentContextIds.find(function (e) { + return !!t[getNodeNameWithContextId(n, e)]; + });return void 0 !== s ? t[getNodeNameWithContextId(n, s)][o] : void 0; + }function getNodeNameAndIndex(e, t) { + var a = parseNodeName(e), + r = a[0], + n = a[1];return [getNodeNameWithContextId(r, t && t.currentContextId), n]; + }function getNodeNameWithContextId(e, t) { + return t ? e + "-" + t : e; + }function parseNodeName(e) { + var t = e.lastIndexOf(":");return -1 === t ? [e, 0] : [e.substring(0, t), Number(e.substring(t + 1))]; + }function split$1(e, t) { + for (var a = [], r = 0; r < e.length; r += t) a.push(e.slice(r, r + t));return a; + }var arithmetic = [{ tfOpName: "Add", dlOpName: "add", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "BiasAdd", dlOpName: "add", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sub", dlOpName: "sub", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "RealDiv", dlOpName: "div", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Div", dlOpName: "div", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "FloorDiv", dlOpName: "floorDiv", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Mul", dlOpName: "mul", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Maximum", dlOpName: "maximum", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }] }, { tfOpName: "Minimum", dlOpName: "minimum", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }] }, { tfOpName: "Pow", dlOpName: "pow", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "SquaredDifference", dlOpName: "squaredDifference", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Mod", dlOpName: "mod", category: "arithmetic", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }], + arithmetic$1 = Object.freeze({ default: arithmetic }), + basic_math = [{ tfOpName: "Abs", dlOpName: "abs", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Acos", dlOpName: "acos", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Asin", dlOpName: "asin", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "atan", dlOpName: "atan", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Ceil", dlOpName: "ceil", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "ClipByValue", dlOpName: "clipByValue", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "clip_value_min", dlParamName: "clipValueMin", type: "number" }, { tfParamName: "clip_value_max", dlParamName: "clipValueMax", type: "number" }] }, { tfOpName: "Cos", dlOpName: "cos", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Cosh", dlOpName: "cosh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Elu", dlOpName: "elu", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Exp", dlOpName: "exp", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Floor", dlOpName: "floor", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Log", dlOpName: "log", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Neg", dlOpName: "neg", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Relu", dlOpName: "relu", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Relu6", dlOpName: "clipByValue", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }, { dlParamName: "clipValueMin", type: "number", defaultValue: 0 }, { dlParamName: "clipValueMax", type: "number", defaultValue: 6 }] }, { tfOpName: "Selu", dlOpName: "selu", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sigmoid", dlOpName: "sigmoid", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sin", dlOpName: "sin", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sinh", dlOpName: "sinh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sqrt", dlOpName: "sqrt", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Rsqrt", dlOpName: "rsqrt", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Square", dlOpName: "square", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Tan", dlOpName: "tan", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Tanh", dlOpName: "tanh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Sign", dlOpName: "sign", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Round", dlOpName: "round", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Expm1", dlOpName: "expm1", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Log1p", dlOpName: "log1p", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Reciprocal", dlOpName: "reciprocal", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Reciprocal", dlOpName: "reciprocal", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Softplus", dlOpName: "softplus", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Asinh", dlOpName: "asinh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Acosh", dlOpName: "acosh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Atanh", dlOpName: "atanh", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Erf", dlOpName: "erf", category: "basic_math", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }], + basicMath = Object.freeze({ default: basic_math }), + control = [{ tfOpName: "LoopCond", dlOpName: "loopCond", category: "control", params: [{ tfInputIndex: 0, dlParamName: "pred", type: "tensor" }] }, { tfOpName: "Switch", dlOpName: "switch", category: "control", params: [{ tfInputIndex: 0, dlParamName: "data", type: "tensor" }, { tfInputIndex: 1, dlParamName: "pred", type: "tensor" }] }, { tfOpName: "Merge", dlOpName: "merge", category: "control", params: [{ tfInputIndex: 0, tfInputParamLength: 0, dlParamName: "tensors", type: "tensors" }] }, { tfOpName: "Enter", dlOpName: "enter", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensor", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }, { tfParamName: "frame_name", dlParamName: "frameName", type: "string" }, { tfParamName: "is_constant", dlParamName: "isConstant", type: "bool" }] }, { tfOpName: "Exit", dlOpName: "exit", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensor", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "NextIteration", dlOpName: "nextIteration", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensor", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "TensorArrayV3", dlOpName: "tensorArray", category: "control", params: [{ tfInputIndex: 0, dlParamName: "size", type: "number" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }, { tfParamName: "element_shape", dlParamName: "elementShape", type: "shape" }, { tfParamName: "dynamic_size", dlParamName: "dynamicSize", type: "bool" }, { tfParamName: "clear_after_read", dlParamName: "clearAfterRead", type: "bool" }, { tfParamName: "identical_element_shapes", dlParamName: "identicalElementShapes", type: "bool" }, { tfParamName: "tensor_array_name", dlParamName: "name", type: "string" }] }, { tfOpName: "TensorArrayWriteV3", dlOpName: "tensorArrayWrite", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "index", type: "number" }, { tfInputIndex: 2, dlParamName: "tensor", type: "tensor" }, { tfInputIndex: 3, dlParamName: "flowIn", type: "number" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "TensorArrayReadV3", dlOpName: "tensorArrayRead", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "index", type: "number" }, { tfInputIndex: 2, dlParamName: "flowIn", type: "number" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "TensorArrayGatherV3", dlOpName: "tensorArrayGather", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "indices", type: "number[]" }, { tfInputIndex: 2, dlParamName: "flowIn", type: "number" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }, { tfParamName: "element_shape", dlParamName: "elementShape", type: "shape" }] }, { tfOpName: "TensorArrayScatterV3", dlOpName: "tensorArrayScatter", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "indices", type: "number[]" }, { tfInputIndex: 2, dlParamName: "tensor", type: "number[]" }, { tfInputIndex: 3, dlParamName: "flowIn", type: "number" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "TensorArrayConcatV3", dlOpName: "tensorArrayConcat", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "flowIn", type: "number" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }, { tfParamName: "element_shape_except0", dlParamName: "elementShapeExcept0", type: "shape", notSupported: !0 }] }, { tfOpName: "TensorArraySplitV3", dlOpName: "tensorArraySplit", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "tensor", type: "tensor" }, { tfInputIndex: 2, dlParamName: "lengths", type: "number[]" }, { tfInputIndex: 3, dlParamName: "flowIn", type: "number" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "TensorArraySizeV3", dlOpName: "tensorArraySize", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }, { tfInputIndex: 1, dlParamName: "flowIn", type: "number" }] }, { tfOpName: "TensorArrayCloseV3", dlOpName: "tensorArrayClose", category: "control", params: [{ tfInputIndex: 0, dlParamName: "tensorArrayId", type: "number" }] }], + control$1 = Object.freeze({ default: control }), + convolution = [{ tfOpName: "AvgPool", dlOpName: "avgPool", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", notSupported: !0 }, { tfParamName: "ksize", dlParamName: "kernelSize", type: "number[]" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "MaxPool", dlOpName: "maxPool", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", notSupported: !0 }, { tfParamName: "ksize", dlParamName: "kernelSize", type: "number[]" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Conv1D", dlOpName: "conv1d", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "filter", type: "tensor" }, { tfParamName: "stride", dlParamName: "stride", type: "number" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", defaultValue: "NWC" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }, { tfParamName: "dilation", dlParamName: "dilation", type: "number", defaultValue: 1 }] }, { tfOpName: "Conv2D", dlOpName: "conv2d", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "filter", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "useCudnnOnGpu", dlParamName: "useCudnnOnGpu", type: "bool" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", defaultValue: "NHWC" }, { tfParamName: "dilations", dlParamName: "dilations", type: "number[]" }] }, { tfOpName: "Conv2DBackpropInput", dlOpName: "conv2dTranspose", category: "convolution", params: [{ tfInputIndex: 2, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "filter", type: "tensor" }, { tfInputIndex: 0, dlParamName: "outputShape", type: "number[]" }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", notSupported: !0 }] }, { tfOpName: "DepthwiseConv2d", dlOpName: "depthwiseConv2d", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "input", type: "tensor" }, { tfInputIndex: 1, dlParamName: "filter", type: "tensor" }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", defaultValue: "NHWC" }, { tfParamName: "dilations", dlParamName: "dilations", type: "number[]" }] }, { tfOpName: "DepthwiseConv2dNative", dlOpName: "depthwiseConv2d", category: "convolution", params: [{ tfInputIndex: 0, dlParamName: "input", type: "tensor" }, { tfInputIndex: 1, dlParamName: "filter", type: "tensor" }, { tfParamName: "strides", dlParamName: "strides", type: "number[]" }, { tfParamName: "padding", dlParamName: "pad", type: "string" }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", defaultValue: "NHWC" }, { tfParamName: "dilations", dlParamName: "dilations", type: "number[]" }] }], + convolution$1 = Object.freeze({ default: convolution }), + creation = [{ tfOpName: "Fill", dlOpName: "fill", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "shape", type: "number[]" }, { tfInputIndex: 1, dlParamName: "value", type: "number" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "LinSpace", dlOpName: "linspace", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "start", type: "number" }, { tfInputIndex: 1, dlParamName: "stop", type: "number" }, { tfInputIndex: 2, dlParamName: "num", type: "number" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "OneHot", dlOpName: "oneHot", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "indices", type: "tensor" }, { tfInputIndex: 1, dlParamName: "depth", type: "number" }, { tfInputIndex: 2, dlParamName: "onValue", type: "number", defaultValue: 1 }, { tfInputIndex: 3, dlParamName: "offValue", type: "number", defaultValue: 0 }, { tfParamName: "axis", dlParamName: "axis", type: "number", notSupported: !0 }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Ones", dlOpName: "ones", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "shape", type: "number[]" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "OnesLike", dlOpName: "onesLike", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "RandomUniform", dlOpName: "randomUniform", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "shape", type: "number[]" }, { tfParamName: "minval", dlParamName: "minval", type: "number", defaultValue: 0 }, { tfParamName: "maxval", dlParamName: "maxval", type: "number", defaultValue: 1 }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }, { tfParamName: "seed", dlParamName: "seed", type: "number", defaultValue: 0 }, { tfParamName: "seed2", dlParamName: "seed2", type: "number", defaultValue: 0, notSupported: !0 }, { tfParamName: "T", dlParamName: "T", type: "number", notSupported: !0 }] }, { tfOpName: "Range", dlOpName: "range", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "start", type: "number" }, { tfInputIndex: 1, dlParamName: "stop", type: "number" }, { tfInputIndex: 2, dlParamName: "step", type: "number", defaultValue: 0 }, { tfParamName: "Tidx", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "truncatedNormal", dlOpName: "truncatedNormal", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "shape", type: "number[]" }, { tfParamName: "means", dlParamName: "mean", type: "number", defaultValue: 0 }, { tfParamName: "stddev", dlParamName: "stdDev", type: "number", defaultValue: 1 }, { tfParamName: "seed", dlParamName: "seed", type: "number" }, { tfParamName: "seed2", dlParamName: "seed2", type: "number", defaultValue: 0, notSupported: !0 }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }, { tfParamName: "T", dlParamName: "T", type: "number", notSupported: !0 }] }, { tfOpName: "Zeros", dlOpName: "zeros", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "shape", type: "number[]" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "ZerosLike", dlOpName: "zerosLike", category: "creation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype" }] }], + creation$1 = Object.freeze({ default: creation }), + dynamic = [{ tfOpName: "NonMaxSuppressionV2", dlOpName: "nonMaxSuppression", category: "dynamic", params: [{ tfInputIndex: 0, dlParamName: "boxes", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scores", type: "tensor" }, { tfInputIndex: 2, dlParamName: "maxOutputSize", type: "number" }, { tfInputIndex: 3, dlParamName: "iouThreshold", type: "number" }] }, { tfOpName: "NonMaxSuppressionV3", dlOpName: "nonMaxSuppression", category: "dynamic", params: [{ tfInputIndex: 0, dlParamName: "boxes", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scores", type: "tensor" }, { tfInputIndex: 2, dlParamName: "maxOutputSize", type: "number" }, { tfInputIndex: 3, dlParamName: "iouThreshold", type: "number" }, { tfInputIndex: 4, dlParamName: "scoreThreshold", type: "number" }] }, { tfOpName: "Where", dlOpName: "whereAsync", category: "dynamic", params: [{ tfInputIndex: 0, dlParamName: "condition", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }], + dynamic$1 = Object.freeze({ default: dynamic }), + evaluation = [{ tfOpName: "TopKV2", dlOpName: "topK", category: "evaluation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "k", type: "number" }, { tfParamName: "sorted", dlParamName: "sorted", type: "bool" }] }], + evaluation$1 = Object.freeze({ default: evaluation }), + graph = [{ tfOpName: "PlaceholderWithDefault", dlOpName: "placeholder", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "default", type: "tensor" }, { tfParamName: "shape", dlParamName: "shape", type: "shape" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "Placeholder", dlOpName: "placeholder", category: "graph", params: [{ tfParamName: "shape", dlParamName: "shape", type: "shape" }, { tfParamName: "dtype", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "Const", dlOpName: "const", category: "graph" }, { tfOpName: "Identity", dlOpName: "identity", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "Snapshot", dlOpName: "snapshot", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "Rank", dlOpName: "rank", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "Size", dlOpName: "size", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "Shape", dlOpName: "shape", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "Print", dlOpName: "print", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, tfInputParamLength: 1, dlParamName: "data", type: "tensors" }, { tfParamName: "message", dlParamName: "message", type: "string" }, { tfParamName: "first_n", dlParamName: "firstN", type: "number", notSupprted: !0 }, { tfParamName: "summarize", dlParamName: "summarize", type: "number", defaultValue: 3 }] }, { tfOpName: "NoOp", dlOpName: "noop", category: "graph", params: [] }, { tfOpName: "StopGradient", dlOpName: "stopGradient", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }, { tfOpName: "FakeQuantWithMinMaxVars", dlOpName: "fakeQuantWithMinMaxVars", category: "graph", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "min", dlParamName: "min", type: "number" }, { tfParamName: "max", dlParamName: "max", type: "number" }] }], + graph$1 = Object.freeze({ default: graph }), + image$1 = [{ tfOpName: "ResizeBilinear", dlOpName: "resizeBilinear", category: "image", params: [{ tfInputIndex: 0, dlParamName: "images", type: "tensor" }, { tfInputIndex: 1, dlParamName: "size", type: "number[]" }, { tfParamName: "align_corners", dlParamName: "alignCorners", type: "bool" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "ResizeNearestNeighbor", dlOpName: "resizeNearestNeighbor", category: "image", params: [{ tfInputIndex: 0, dlParamName: "images", type: "tensor" }, { tfInputIndex: 1, dlParamName: "size", type: "number[]" }, { tfParamName: "align_corners", dlParamName: "alignCorners", type: "bool" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "NonMaxSuppressionV2", dlOpName: "nonMaxSuppression", category: "image", params: [{ tfInputIndex: 0, dlParamName: "boxes", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scores", type: "tensor" }, { tfInputIndex: 2, dlParamName: "maxOutputSize", type: "number" }, { tfInputIndex: 3, dlParamName: "iouThreshold", type: "number" }] }, { tfOpName: "NonMaxSuppressionV3", dlOpName: "nonMaxSuppression", category: "image", params: [{ tfInputIndex: 0, dlParamName: "boxes", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scores", type: "tensor" }, { tfInputIndex: 2, dlParamName: "maxOutputSize", type: "number" }, { tfInputIndex: 3, dlParamName: "iouThreshold", type: "number" }, { tfInputIndex: 4, dlParamName: "scoreThreshold", type: "number" }] }], + image$2 = Object.freeze({ default: image$1 }), + logical = [{ tfOpName: "Equal", dlOpName: "equal", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "NotEqual", dlOpName: "notEqual", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Greater", dlOpName: "greater", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "GreaterEqual", dlOpName: "greaterEqual", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Less", dlOpName: "less", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "LessEqual", dlOpName: "lessEqual", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "LogicalAnd", dlOpName: "logicalAnd", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "LogicalNot", dlOpName: "logicalNot", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "LogicalOr", dlOpName: "logicalOr", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Select", dlOpName: "where", category: "logical", params: [{ tfInputIndex: 0, dlParamName: "condition", type: "tensor" }, { tfInputIndex: 1, dlParamName: "a", type: "tensor" }, { tfInputIndex: 2, dlParamName: "b", type: "tensor" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }], + logical$1 = Object.freeze({ default: logical }), + matrices = [{ tfOpName: "MatMul", dlOpName: "matMul", category: "matrices", params: [{ tfInputIndex: 0, dlParamName: "a", type: "tensor" }, { tfInputIndex: 1, dlParamName: "b", type: "tensor" }, { tfParamName: "transpose_a", dlParamName: "transposeA", type: "bool", defaultValue: !1 }, { tfParamName: "transpose_b", dlParamName: "transposeB", type: "bool", defaultValue: !1 }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }, { tfOpName: "Transpose", dlOpName: "transpose", category: "matrices", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "perm", dlParamName: "perm", type: "number[]" }, { tfParamName: "T", dlParamName: "dtype", type: "dtype", notSupported: !0 }] }], + matrices$1 = Object.freeze({ default: matrices }), + normalization = [{ tfOpName: "FusedBatchNorm", dlOpName: "batchNormalization", category: "normalization", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scale", type: "tensor" }, { tfInputIndex: 2, dlParamName: "offset", type: "tensor" }, { tfInputIndex: 3, dlParamName: "mean", type: "tensor" }, { tfInputIndex: 4, dlParamName: "variance", type: "tensor" }, { tfParamName: "epsilon", dlParamName: "epsilon", type: "number", defaultValue: .001 }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", notSupported: !0 }] }, { tfOpName: "FusedBatchNormV2", dlOpName: "batchNormalization", category: "normalization", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "scale", type: "tensor" }, { tfInputIndex: 2, dlParamName: "offset", type: "tensor" }, { tfInputIndex: 3, dlParamName: "mean", type: "tensor" }, { tfInputIndex: 4, dlParamName: "variance", type: "tensor" }, { tfParamName: "epsilon", dlParamName: "epsilon", type: "number", defaultValue: .001 }, { tfParamName: "data_format", dlParamName: "dataFormat", type: "string", notSupported: !0 }] }, { tfOpName: "LRN", dlOpName: "localResponseNormalization", category: "normalization", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "depth_radius", dlParamName: "radius", type: "number", defaultValue: 5 }, { tfParamName: "bias", dlParamName: "bias", type: "number", defaultValue: 1 }, { tfParamName: "alpha", dlParamName: "alpha", type: "number", defaultValue: 1 }, { tfParamName: "beta", dlParamName: "beta", type: "number", defaultValue: .5 }] }, { tfOpName: "Softmax", dlOpName: "softmax", category: "normalization", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }] }], + normalization$1 = Object.freeze({ default: normalization }), + reduction = [{ tfOpName: "Max", dlOpName: "max", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "Mean", dlOpName: "mean", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "Min", dlOpName: "min", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "Sum", dlOpName: "sum", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "All", dlOpName: "all", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "Any", dlOpName: "any", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number[]" }, { tfParamName: "keep_dims", dlParamName: "keepDims", type: "bool" }] }, { tfOpName: "ArgMax", dlOpName: "argMax", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number" }] }, { tfOpName: "ArgMin", dlOpName: "argMin", category: "reduction", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number" }] }], + reduction$1 = Object.freeze({ default: reduction }), + slice_join = [{ tfOpName: "ConcatV2", dlOpName: "concat", category: "slice_join", params: [{ tfInputIndex: 0, tfInputParamLength: 1, dlParamName: "tensors", type: "tensors" }, { tfInputIndex: -1, dlParamName: "axis", type: "number" }] }, { tfOpName: "Concat", dlOpName: "concat", category: "slice_join", params: [{ tfInputIndex: 1, tfInputParamLength: 1, dlParamName: "tensors", type: "tensors" }, { tfInputIndex: 0, dlParamName: "axis", type: "number" }] }, { tfOpName: "GatherV2", dlOpName: "gather", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "indices", type: "tensor" }, { tfParamName: "axis", dlParamName: "axis", type: "number", defaultValue: 0 }] }, { tfOpName: "Gather", dlOpName: "gather", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "indices", type: "tensor" }, { tfParamName: "axis", dlParamName: "axis", type: "number", defaultValue: 0 }, { tfParamName: "validate_indices", dlParamName: "validateIndices", type: "bool", notSupported: !0 }] }, { tfOpName: "Reverse", dlOpName: "reverse", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number" }] }, { tfOpName: "ReverseV2", dlOpName: "reverse", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "axis", type: "number" }] }, { tfOpName: "Slice", dlOpName: "slice", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "begin", type: "number[]" }, { tfInputIndex: 2, dlParamName: "size", type: "number[]" }] }, { tfOpName: "StridedSlice", dlOpName: "stridedSlice", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "begin", type: "number[]" }, { tfInputIndex: 2, dlParamName: "end", type: "number[]" }, { tfInputIndex: 3, dlParamName: "strides", type: "number[]" }, { tfParamName: "begin_mask", dlParamName: "beginMask", type: "number", defaultValue: 0 }, { tfParamName: "end_mask", dlParamName: "endMask", type: "number", defaultValue: 0 }] }, { tfOpName: "Pack", dlOpName: "stack", category: "slice_join", params: [{ tfInputIndex: 0, tfInputParamLength: 0, dlParamName: "tensors", type: "tensors" }, { tfParamName: "axis", dlParamName: "axis", type: "number", defaultValue: 0 }] }, { tfOpName: "Unpack", dlOpName: "unstack", category: "slice_join", params: [{ tfInputIndex: 0, tfInputParamLength: 0, dlParamName: "tensor", type: "tensor" }, { tfParamName: "axis", dlParamName: "axis", type: "number", defaultValue: 0 }, { tfParamName: "num", dlParamName: "num", type: "number", defaultValue: 0, notSupported: !0 }] }, { tfOpName: "Tile", dlOpName: "tile", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "reps", type: "number[]" }] }, { tfOpName: "Split", dlOpName: "split", category: "slice_join", params: [{ tfInputIndex: 0, dlParamName: "axis", type: "number", defaultValue: 0 }, { tfInputIndex: 1, dlParamName: "x", type: "tensor" }, { tfParamName: "num_split", dlParamName: "numOrSizeSplits", type: "number", defaultValue: 1 }] }], + sliceJoin = Object.freeze({ default: slice_join }), + transformation = [{ tfOpName: "Cast", dlOpName: "cast", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "SrcT", dlParamName: "sdtype", type: "dtype", notSupported: !0 }, { tfParamName: "DstT", dlParamName: "dtype", type: "dtype" }] }, { tfOpName: "ExpandDims", dlOpName: "expandDims", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, tfParamNameDeprecated: "dim", dlParamName: "axis", type: "number" }] }, { tfOpName: "Pad", dlOpName: "pad", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "padding", type: "number[]" }, { tfParamName: "constant_value", dlParamName: "constantValue", type: "number", defaultValue: 0 }] }, { tfOpName: "PadV2", dlOpName: "pad", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "padding", type: "number[]" }, { tfInputIndex: 2, dlParamName: "constantValue", type: "number", defaultValue: 0 }] }, { tfOpName: "Reshape", dlOpName: "reshape", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "shape", type: "number[]" }] }, { tfOpName: "Squeeze", dlOpName: "squeeze", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfParamName: "axis", tfParamNameDeprecated: "squeeze_dims", dlParamName: "axis", type: "number[]" }] }, { tfOpName: "SpaceToBatchND", dlOpName: "spaceToBatchND", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "blockShape", type: "number[]" }, { tfInputIndex: 2, dlParamName: "paddings", type: "number[]" }] }, { tfOpName: "BatchToSpaceND", dlOpName: "batchToSpaceND", category: "transformation", params: [{ tfInputIndex: 0, dlParamName: "x", type: "tensor" }, { tfInputIndex: 1, dlParamName: "blockShape", type: "number[]" }, { tfInputIndex: 2, dlParamName: "crops", type: "number[]" }] }], + transformation$1 = Object.freeze({ default: transformation }), + CONTROL_FLOW_OPS = ["Switch", "Merge", "Enter", "Exit", "NextIteration"], + DYNAMIC_SHAPE_OPS = ["NonMaxSuppressionV2", "NonMaxSuppressionV3", "Where"], + OperationMapper = function () { + function e() { + var e = [arithmetic$1, basicMath, control$1, convolution$1, creation$1, dynamic$1, evaluation$1, logical$1, image$2, graph$1, matrices$1, normalization$1, reduction$1, sliceJoin, transformation$1], + t = [].concat.apply([], e.map(function (e) { + return e.default ? e.default : e; + }));this.opMappers = t.reduce(function (e, t) { + return e[t.tfOpName] = t, e; + }, {}); + }return Object.defineProperty(e, "Instance", { get: function () { + return this._instance || (this._instance = new this()); + }, enumerable: !0, configurable: !0 }), e.prototype.isControlFlow = function (e) { + return CONTROL_FLOW_OPS.some(function (t) { + return t === e.op; + }); + }, e.prototype.isDynamicShape = function (e) { + return DYNAMIC_SHAPE_OPS.some(function (t) { + return t === e.op; + }); + }, e.prototype.transformGraph = function (e) { + var t = this, + a = !1, + r = !1, + n = [], + o = e.node.reduce(function (e, o) { + return e[o.name] = t.mapNode(o), t.isControlFlow(o) && (a = !0), t.isDynamicShape(o) && (r = !0), "Placeholder" === o.op && n.push(e[o.name]), e; + }, {}), + s = [], + i = [];return Object.keys(o).forEach(function (e) { + var t = o[e];t.inputNames.forEach(function (e) { + var a = getNodeNameAndIndex(e)[0];t.inputs.push(o[a]), o[a].children.push(t); + }), 0 === t.inputs.length && s.push(t); + }), Object.keys(o).forEach(function (e) { + var t = o[e];0 === t.children.length && i.push(t); + }), { nodes: o, inputs: s, outputs: i, placeholders: n, withControlFlow: a, withDynamicShape: r }; + }, e.prototype.mapNode = function (e) { + var t = this, + a = this.opMappers[e.op];if (void 0 === a) throw new Error("Tensorflow Op is not supported: " + e.op);var r = { name: e.name, op: a.dlOpName, category: a.category, inputNames: (e.input || []).map(function (e) { + return e.startsWith("^") ? e.substr(1) : e; + }), inputs: [], children: [], params: {} };return a.params && (r.params = a.params.reduce(function (a, r) { + var n = r.tfInputIndex, + o = r.tfInputParamLength, + s = r.type, + i = void 0;if (void 0 === n) switch (r.type) {case "string": + void 0 === (i = t.getStringParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getStringParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "number": + void 0 === (i = t.getNumberParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getNumberParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "number[]": + void 0 === (i = t.getNumericArrayParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getNumericArrayParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "bool": + void 0 === (i = t.getBoolParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getBoolParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "shape": + void 0 === (i = t.getTensorShapeParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getTensorShapeParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "dtype": + void 0 === (i = t.getDtypeParam(e.attr, r.tfParamName, r.defaultValue)) && r.tfParamNameDeprecated && (i = t.getDtypeParam(e.attr, r.tfParamNameDeprecated, r.defaultValue));break;case "tensor":case "tensors": + break;default: + throw new Error("Unsupported param type: " + r.type + " for op: " + e.op);}return a[r.dlParamName] = { value: i, inputIndex: n, type: s, inputParamLength: o }, a; + }, {})), r; + }, e.prototype.getStringParam = function (e, t, a, r) { + void 0 === r && (r = !1);var n = e[t];if (void 0 !== n) { + var o = String.fromCharCode.apply(null, n.s);return r ? o : o.toLowerCase(); + }return a; + }, e.prototype.getBoolParam = function (e, t, a) { + var r = e[t];return r ? r.b : a; + }, e.prototype.getNumberParam = function (e, t, a) { + var r = e[t], + n = r ? void 0 !== r.f ? r.f : r.i : a;return "number" == typeof n ? n : n.toInt(); + }, e.prototype.getDtypeParam = function (e, t, a) { + var r = e[t];if (r && r.type) switch (r.type) {case compiled_api_1.DataType.DT_FLOAT: + return "float32";case compiled_api_1.DataType.DT_INT32: + return "int32";case compiled_api_1.DataType.DT_BOOL: + return "bool";default: + return a;}return a; + }, e.prototype.getTensorShapeParam = function (e, t, a) { + var r = e[t];return r && r.shape ? r.shape.dim.map(function (e) { + return "number" == typeof e.size ? e.size : e.size.toInt(); + }) : a; + }, e.prototype.getNumericArrayParam = function (e, t, a) { + var r = e[t];return r ? (r.list.f && r.list.f.length ? r.list.f : r.list.i).map(function (e) { + return "number" == typeof e ? e : e.toInt(); + }) : a; + }, e; + }(), + executeOp = function (e, t, a) { + switch (e.op) {case "add": + return [add(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "mod": + return [mod(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "mul": + return [mul(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "div": + return [div(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "floorDiv": + return [floorDiv(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "sub": + return [sub(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "minimum": + return [minimum(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "maximum": + return [maximum(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "pow": + return [pow(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "squaredDifference": + return [squaredDifference(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$1 = function (e, t, a) { + switch (e.op) {case "abs": + return [abs(getParamValue("x", e, t, a))];case "acos": + return [acos(getParamValue("x", e, t, a))];case "acosh": + return [acosh(getParamValue("x", e, t, a))];case "asin": + return [asin(getParamValue("x", e, t, a))];case "asinh": + return [asinh(getParamValue("x", e, t, a))];case "atan": + return [atan(getParamValue("x", e, t, a))];case "atanh": + return [atanh(getParamValue("x", e, t, a))];case "ceil": + return [ceil(getParamValue("x", e, t, a))];case "cos": + return [cos(getParamValue("x", e, t, a))];case "cosh": + return [cosh(getParamValue("x", e, t, a))];case "elu": + return [elu(getParamValue("x", e, t, a))];case "erf": + return [erf(getParamValue("x", e, t, a))];case "exp": + return [exp(getParamValue("x", e, t, a))];case "expm1": + return [expm1(getParamValue("x", e, t, a))];case "floor": + return [floor(getParamValue("x", e, t, a))];case "log": + return [log$1(getParamValue("x", e, t, a))];case "log1p": + return [log1p(getParamValue("x", e, t, a))];case "neg": + return [neg(getParamValue("x", e, t, a))];case "reciprocal": + return [reciprocal(getParamValue("x", e, t, a))];case "relu": + return [relu(getParamValue("x", e, t, a))];case "round": + return [round(getParamValue("x", e, t, a))];case "selu": + return [selu(getParamValue("x", e, t, a))];case "sigmoid": + return [sigmoid(getParamValue("x", e, t, a))];case "sin": + return [sin(getParamValue("x", e, t, a))];case "sign": + return [sign(getParamValue("x", e, t, a))];case "sinh": + return [sinh(getParamValue("x", e, t, a))];case "softplus": + return [softplus(getParamValue("x", e, t, a))];case "sqrt": + return [sqrt(getParamValue("x", e, t, a))];case "square": + return [square(getParamValue("x", e, t, a))];case "tanh": + return [tanh$1(getParamValue("x", e, t, a))];case "tan": + return [tan(getParamValue("x", e, t, a))];case "clipByValue": + return [clipByValue(getParamValue("x", e, t, a), getParamValue("clipValueMin", e, t, a), getParamValue("clipValueMax", e, t, a))];case "rsqrt": + return [div(scalar(1, "float32"), sqrt(getTensor(e.inputNames[0], t, a)))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + TensorArray = function () { + function e(t, a, r, n, o, s, i) { + this.name = t, this.dtype = a, this.maxSize = r, this.elementShape = n, this.identicalElementShapes = o, this.dynamicSize = s, this.clearAfterRead = i, this.tensors = [], this.closed_ = !1, this.id = e.nextId++; + }return Object.defineProperty(e.prototype, "closed", { get: function () { + return this.closed_; + }, enumerable: !0, configurable: !0 }), e.prototype.clearAndClose = function () { + this.tensors.forEach(function (e) { + return e.tensor.dispose(); + }), this.tensors = [], this.closed_ = !0; + }, e.prototype.size = function () { + return this.tensors.length; + }, e.prototype.read = function (e) { + if (this.closed_) throw new Error("TensorArray " + this.name + " has already been closed.");if (e < 0 || e >= this.tensors.length) throw new Error("Tried to read from index " + e + ", but array size is: " + this.tensors.length);var t = this.tensors[e];if (t.cleared) throw new Error("TensorArray " + this.name + ": Could not read index " + e + " twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).");return this.clearAfterRead && (t.cleared = !0), t.read = !0, t.tensor; + }, e.prototype.readMany = function (e) { + var t = this;return e.map(function (e) { + return t.read(e); + }); + }, e.prototype.write = function (e, t) { + if (this.closed_) throw new Error("TensorArray " + this.name + " has already been closed.");if (e < 0 || !this.dynamicSize && e >= this.maxSize) throw new Error("Tried to write to index " + e + ", but array is not resizeable and size is: " + this.maxSize);var a = this.tensors[e] || {};if (t.dtype !== this.dtype) throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + e + ",\n because the value dtype is " + t.dtype + ", but TensorArray dtype is " + this.dtype + ".");if (0 === this.size() && 0 === this.elementShape.length && (this.elementShape = t.shape), util.assertShapesMatch(this.elementShape, t.shape, "TensorArray " + this.name + ": Could not write to TensorArray index " + e + "."), a && a.read) throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + e + ", because it has already been read.");if (a && a.written) throw new Error("TensorArray " + this.name + ": Could not write to TensorArray index " + e + ", because it has already been written.");a.tensor = t, a.written = !0, this.tensors[e] = a; + }, e.prototype.writeMany = function (e, t) { + var a = this;if (e.length !== t.length) throw new Error("TensorArray " + this.name + ": could not write multiple tensors,because the index size: " + e.length + " is not the same as tensors size: " + t.length + ".");e.map(function (e, r) { + return a.write(e, t[r]); + }); + }, e.prototype.gather = function (e, t) { + if (t && t !== this.dtype) throw new Error("TensorArray dtype is " + this.dtype + " but gather requested dtype " + t);if (!e) { + e = [];for (var a = 0; a < this.size(); a++) e.push(a); + }if (0 === e.length) return tensor([], [0].concat(this.elementShape));var r = this.readMany(e);return util.assertShapesMatch(this.elementShape, r[0].shape, "TensorArray shape mismatch: "), stack(r, 0); + }, e.prototype.concat = function (e) { + if (e && e !== this.dtype) throw new Error("TensorArray dtype is " + this.dtype + " but concat requested dtype " + e);if (0 === this.size()) return tensor([], [0].concat(this.elementShape));for (var t = [], a = 0; a < this.size(); a++) t.push(a);var r = this.readMany(t);return util.assertShapesMatch(this.elementShape, r[0].shape, "TensorArray shape mismatch: tensor array shape (" + this.elementShape + ") vs first tensor shape (" + r[0].shape + ")"), concat(r, 0); + }, e.prototype.scatter = function (e, t) { + if (t.dtype !== this.dtype) throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + t.dtype);if (e.length !== t.shape[0]) throw new Error("Expected len(indices) == tensor.shape[0], but saw: " + e.length + " vs. " + t.shape[0]);var a = Math.max.apply(Math, e);if (!this.dynamicSize && a >= this.maxSize) throw new Error("Max index must be < array size (" + a + " vs. " + this.maxSize + ")");this.writeMany(e, unstack(t, 0)); + }, e.prototype.split = function (e, t) { + var a = this;if (t.dtype !== this.dtype) throw new Error("TensorArray dtype is " + this.dtype + " but tensor has dtype " + t.dtype);var r = 0, + n = e.map(function (e) { + return r += e; + });if (r !== t.shape[0]) throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n " + r + ", and tensor's shape is: " + t.shape);if (!this.dynamicSize && e.length !== this.maxSize) throw new Error("TensorArray's size is not equal to the size of lengths (" + this.maxSize + " vs. " + e.length + "), and the TensorArray is not marked as dynamically resizeable");var o = 0 === r ? 0 : t.size / r, + s = [];tidy(function () { + t = t.reshape([1, r, o]);for (var i = 0; i < e.length; ++i) { + var p = [0, 0 === i ? 0 : n[i - 1], 0], + u = [1, e[i], o];s[i] = slice(t, p, u).reshape(a.elementShape); + }return s; + });for (var i = [], p = 0; p < e.length; p++) i[p] = p;this.writeMany(i, s); + }, e.nextId = 0, e; + }();function executeOp$2(e, t, a) { + return __awaiter$2(this, void 0, void 0, function () { + var r, n, o, s, i, p, u, m, l, d, c, f, h, y, g, N, P, b, x, v, I, O, w, V, T, k, $, _, A, S, D, C, E, j, R;return __generator$2(this, function (L) { + switch (L.label) {case 0: + switch (e.op) {case "loopCond": + return [3, 1];case "switch": + return [3, 2];case "merge": + return [3, 4];case "enter": + return [3, 5];case "exit": + return [3, 6];case "nextIteration": + return [3, 7];case "tensorArray": + return [3, 8];case "tensorArrayWrite": + return [3, 9];case "tensorArrayRead": + return [3, 10];case "tensorArrayGather": + return [3, 11];case "tensorArrayScatter": + return [3, 12];case "tensorArrayConcat": + return [3, 13];case "tensorArraySplit": + return [3, 14];case "tensorArraySize": + return [3, 15];case "tensorArrayClose": + return [3, 16];}return [3, 17];case 1: + return [2, [getParamValue("pred", e, t, a)]];case 2: + return r = getParamValue("pred", e, t, a), n = getParamValue("data", e, t, a), [4, r.data()];case 3: + return [2, L.sent()[0] ? [void 0, n] : [n, void 0]];case 4: + return [2, (o = e.inputNames.find(function (e) { + return void 0 !== getTensor(e, t, a); + })) ? [getTensor(o, t, a)] : void 0];case 5: + return s = getParamValue("frameName", e, t, a), i = getParamValue("tensor", e, t, a), a.enterFrame(s), [2, [i]];case 6: + return p = getParamValue("tensor", e, t, a), a.exitFrame(), [2, [p]];case 7: + return u = getParamValue("tensor", e, t, a), a.nextIteration(), [2, [u]];case 8: + return m = getParamValue("size", e, t, a), l = getParamValue("dtype", e, t, a), d = getParamValue("elementShape", e, t, a), c = getParamValue("dynamicSize", e, t, a), f = getParamValue("clearAfterRead", e, t, a), h = getParamValue("identicalElementShapes", e, t, a), y = getParamValue("name", e, t, a), g = new TensorArray(y, l, m, d, h, c, f), a.addTensorArray(g), [2, [scalar(g.id), scalar(1)]];case 9: + return N = getParamValue("tensorArrayId", e, t, a), P = getParamValue("index", e, t, a), b = getParamValue("tensor", e, t, a), a.getTensorArray(N).write(P, b), [2, [scalar(1)]];case 10: + return x = getParamValue("tensorArrayId", e, t, a), v = getParamValue("index", e, t, a), [2, [a.getTensorArray(x).read(v)]];case 11: + return I = getParamValue("tensorArrayId", e, t, a), O = getParamValue("indices", e, t, a), w = getParamValue("dtype", e, t, a), [2, [a.getTensorArray(I).gather(O, w)]];case 12: + return V = getParamValue("tensorArrayId", e, t, a), T = getParamValue("indices", e, t, a), k = getParamValue("tensor", e, t, a), a.getTensorArray(V).scatter(T, k), [2, [scalar(1)]];case 13: + return $ = getParamValue("tensorArrayId", e, t, a), _ = a.getTensorArray($), A = getParamValue("dtype", e, t, a), [2, [_.concat(A)]];case 14: + return S = getParamValue("tensorArrayId", e, t, a), D = getParamValue("tensor", e, t, a), C = getParamValue("lengths", e, t, a), a.getTensorArray(S).split(C, D), [2, [scalar(1)]];case 15: + return E = getParamValue("tensorArrayId", e, t, a), j = a.getTensorArray(E), [2, [scalar(j.size(), "int32")]];case 16: + return R = getParamValue("tensorArrayId", e, t, a), a.getTensorArray(R).clearAndClose(), [2, []];case 17: + throw TypeError("Node type " + e.op + " is not implemented");} + }); + }); + }var executeOp$3 = function (e, t, a) { + switch (e.op) {case "conv1d": + var r = getParamValue("stride", e, t, a), + n = getParamValue("pad", e, t, a), + o = getParamValue("dataFormat", e, t, a).toUpperCase(), + s = getParamValue("dilation", e, t, a);return [conv1d(getParamValue("x", e, t, a), getParamValue("filter", e, t, a), r, n, o, s)];case "conv2d": + r = getParamValue("strides", e, t, a), n = getParamValue("pad", e, t, a), o = getParamValue("dataFormat", e, t, a).toUpperCase();var i = getParamValue("dilations", e, t, a);return [conv2d(getParamValue("x", e, t, a), getParamValue("filter", e, t, a), [r[1], r[2]], n, o, [i[0], i[1]])];case "conv2dTranspose": + var p = getParamValue("outputShape", e, t, a);r = getParamValue("strides", e, t, a), n = getParamValue("pad", e, t, a);return [conv2dTranspose(getParamValue("x", e, t, a), getParamValue("filter", e, t, a), p, [r[1], r[2]], n)];case "depthwiseConv2d": + r = getParamValue("strides", e, t, a), n = getParamValue("pad", e, t, a), i = getParamValue("dilations", e, t, a), o = getParamValue("dataFormat", e, t, a).toUpperCase();return [depthwiseConv2d(getParamValue("input", e, t, a), getParamValue("filter", e, t, a), [r[1], r[2]], n, o, [i[0], i[1]])];case "avgPool": + r = getParamValue("strides", e, t, a), n = getParamValue("pad", e, t, a);var u = getParamValue("kernelSize", e, t, a);return [avgPool(getParamValue("x", e, t, a), [u[1], u[2]], [r[1], r[2]], n)];case "maxPool": + r = getParamValue("strides", e, t, a), n = getParamValue("pad", e, t, a), u = getParamValue("kernelSize", e, t, a);return [maxPool(getParamValue("x", e, t, a), [u[1], u[2]], [r[1], r[2]], n)];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$4 = function (e, t, a) { + switch (e.op) {case "fill": + var r = getParamValue("shape", e, t, a), + n = getParamValue("value", e, t, a);return [fill(r, n)];case "linspace": + var o = getParamValue("start", e, t, a), + s = getParamValue("stop", e, t, a), + i = getParamValue("num", e, t, a);return [linspace(o, s, i)];case "oneHot": + var p = getParamValue("indices", e, t, a), + u = getParamValue("depth", e, t, a), + m = getParamValue("onValue", e, t, a), + l = getParamValue("offValue", e, t, a);return [oneHot(p, u, m, l)];case "ones": + return [ones$1(getParamValue("shape", e, t, a), getParamValue("dtype", e, t, a))];case "onesLike": + return [onesLike(getParamValue("x", e, t, a))];case "randomUniform": + return [randomUniform(getParamValue("shape", e, t, a), getParamValue("minval", e, t, a), getParamValue("maxval", e, t, a), getParamValue("dtype", e, t, a))];case "range": + o = getParamValue("start", e, t, a);var d = getParamValue("stop", e, t, a), + c = getParamValue("step", e, t, a);return [range(o, d, c, getParamValue("dtype", e, t, a))];case "truncatedNormal": + r = getParamValue("shape", e, t, a);var f = getParamValue("mean", e, t, a), + h = getParamValue("stdDev", e, t, a), + y = getParamValue("seed", e, t, a);return [truncatedNormal(r, f, h, getParamValue("dtype", e, t, a), y)];case "zeros": + return [zeros(getParamValue("shape", e, t, a), getParamValue("dtype", e, t, a))];case "zerosLike": + return [zerosLike(getParamValue("x", e, t, a))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + _this = void 0, + executeOp$5 = function (e, t, a) { + return __awaiter$2(_this, void 0, void 0, function () { + var r, n, o, s, i;return __generator$2(this, function (p) { + switch (p.label) {case 0: + switch (e.op) {case "nonMaxSuppression": + return [3, 1];case "whereAsync": + return [3, 3];}return [3, 5];case 1: + return r = getParamValue("boxes", e, t, a), n = getParamValue("scores", e, t, a), o = getParamValue("maxOutputSize", e, t, a), s = getParamValue("iouThreshold", e, t, a), i = getParamValue("scoreThreshold", e, t, a), [4, image_ops.nonMaxSuppressionAsync(r, n, o, s, i)];case 2: + return [2, [p.sent()]];case 3: + return [4, whereAsync(getParamValue("condition", e, t, a))];case 4: + return [2, [p.sent()]];case 5: + throw TypeError("Node type " + e.op + " is not implemented");} + }); + }); + }, + executeOp$6 = function (e, t, a) { + switch (e.op) {case "topK": + var r = getParamValue("x", e, t, a), + n = getParamValue("k", e, t, a), + o = getParamValue("sorted", e, t, a), + s = topk(r, n, o);return [s.values, s.indices];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$7 = function (e, t, a) { + switch (e.op) {case "const": + return t[e.name];case "placeholder": + var r = getParamValue("default", e, t, a);return [getTensor(e.name, t, a) || r];case "identity":case "stopGradient":case "fakeQuantWithMinMaxVars": + return [getParamValue("x", e, t, a)];case "snapshot": + return [getParamValue("x", e, t, a).clone()];case "shape": + return [tensor1d(getParamValue("x", e, t, a).shape, "int32")];case "size": + return [scalar(getParamValue("x", e, t, a).size, "int32")];case "rank": + return [scalar(getParamValue("x", e, t, a).rank, "int32")];case "noop": + return [];case "print": + var n = getParamValue("x", e, t, a), + o = getParamValue("data", e, t, a), + s = getParamValue("message", e, t, a), + i = getParamValue("summarize", e, t, a);console.warn("The graph has a tf.print() operation,usually used for debugging, which slows down performance."), console.log(s);for (var p = 0; p < o.length; p++) console.log(Array.prototype.slice.call(o[0].dataSync()).slice(0, i));return [n];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$8 = function (e, t, a) { + switch (e.op) {case "resizeBilinear": + var r = getParamValue("images", e, t, a), + n = getParamValue("size", e, t, a), + o = getParamValue("alignCorners", e, t, a);return [image_ops.resizeBilinear(r, [n[0], n[1]], o)];case "resizeNearestNeighbor": + r = getParamValue("images", e, t, a), n = getParamValue("size", e, t, a), o = getParamValue("alignCorners", e, t, a);return [image_ops.resizeNearestNeighbor(r, [n[0], n[1]], o)];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$9 = function (e, t, a) { + switch (e.op) {case "equal": + return [equal(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "notEqual": + return [notEqual(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "greater": + return [greater(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "greaterEqual": + return [greaterEqual(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "less": + return [less(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "lessEqual": + return [lessEqual(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "logicalAnd": + return [logicalAnd(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "logicalNot": + return [logicalNot(getParamValue("a", e, t, a))];case "logicalOr": + return [logicalOr(getParamValue("a", e, t, a), getParamValue("b", e, t, a))];case "where": + return [where(getParamValue("condition", e, t, a), getParamValue("a", e, t, a), getParamValue("b", e, t, a))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$10 = function (e, t, a) { + switch (e.op) {case "matMul": + return [matMul(getParamValue("a", e, t, a), getParamValue("b", e, t, a), getParamValue("transposeA", e, t, a), getParamValue("transposeB", e, t, a))];case "transpose": + return [transpose(getParamValue("x", e, t, a), getParamValue("perm", e, t, a))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$11 = function (e, t, a) { + switch (e.op) {case "batchNormalization": + return [batchNormalization(getParamValue("x", e, t, a), getParamValue("mean", e, t, a), getParamValue("variance", e, t, a), getParamValue("epsilon", e, t, a), getParamValue("scale", e, t, a), getParamValue("offset", e, t, a))];case "localResponseNormalization": + return [localResponseNormalization(getParamValue("x", e, t, a), getParamValue("radius", e, t, a), getParamValue("bias", e, t, a), getParamValue("alpha", e, t, a), getParamValue("beta", e, t, a))];case "softmax": + return [softmax(getParamValue("x", e, t, a))];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$12 = function (e, t, a) { + switch (e.op) {case "max": + var r = getParamValue("axis", e, t, a), + n = getParamValue("keepDims", e, t, a);return [max(getParamValue("x", e, t, a), r, n)];case "mean": + r = getParamValue("axis", e, t, a), n = getParamValue("keepDims", e, t, a);return [mean(getParamValue("x", e, t, a), r, n)];case "min": + r = getParamValue("axis", e, t, a), n = getParamValue("keepDims", e, t, a);return [min(getParamValue("x", e, t, a), r, n)];case "sum": + r = getParamValue("axis", e, t, a), n = getParamValue("keepDims", e, t, a);return [sum(getParamValue("x", e, t, a), r, n)];case "all": + r = getParamValue("axis", e, t, a), n = getParamValue("keepDims", e, t, a);return [all(getParamValue("x", e, t, a), r, n)];case "any": + r = getParamValue("axis", e, t, a), n = getParamValue("keepDims", e, t, a);return [any(getParamValue("x", e, t, a), r, n)];case "argMax": + r = getParamValue("axis", e, t, a);return [argMax(getParamValue("x", e, t, a), r)];case "argMin": + r = getParamValue("axis", e, t, a);return [argMin(getParamValue("x", e, t, a), r)];default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$13 = function (e, t, a) { + switch (e.op) {case "concat": + var r = getParamValue("axis", e, t, a), + n = getParamValue("tensors", e, t, a);return [concat(n, r)];case "gather": + r = getParamValue("axis", e, t, a);var o = getParamValue("x", e, t, a), + s = getParamValue("indices", e, t, a);return [gather(o, s, r)];case "reverse": + r = getParamValue("axis", e, t, a), o = getParamValue("x", e, t, a);return [reverse(o, r)];case "slice": + var i = getParamValue("begin", e, t, a), + p = getParamValue("size", e, t, a);return [slice(getParamValue("x", e, t, a), i, p)];case "stridedSlice": + i = getParamValue("begin", e, t, a);var u = getParamValue("end", e, t, a), + m = getParamValue("strides", e, t, a), + l = getParamValue("beginMask", e, t, a), + d = getParamValue("endMask", e, t, a), + c = getParamValue("x", e, t, a);if (1 === i.length && c.shape.length > 1) for (var f = 1; f < c.shape.length; f++) i.push(0), u.push(c.shape[f]), m.push(m[0]);return [stridedSlice(c, i, u, m, l, d)];case "stack": + return tidy(function () { + var r = getParamValue("axis", e, t, a), + n = getParamValue("tensors", e, t, a), + o = n[0].shape, + s = n[0].squeeze().shape, + i = n.map(function (e) { + var t = util.arraysEqual(e.shape, o);if (!t && !util.arraysEqual(e.squeeze().shape, s)) throw new Error("the input tensors shape does not match");return t ? e : e.reshape(o); + });return [stack(i, r)]; + });case "unstack": + return tidy(function () { + var r = getParamValue("axis", e, t, a), + n = getParamValue("tensor", e, t, a);return unstack(n, r); + });case "tile": + var h = getParamValue("reps", e, t, a);return [tile(getParamValue("x", e, t, a), h)];case "split": + r = getParamValue("axis", e, t, a);var y = getParamValue("numOrSizeSplits", e, t, a);return split(getParamValue("x", e, t, a), y, r);default: + throw TypeError("Node type " + e.op + " is not implemented");} + }, + executeOp$14 = function (e, t, a) { + switch (e.op) {case "cast": + return [cast(getParamValue("x", e, t, a), getParamValue("dtype", e, t, a))];case "expandDims": + var r = e.params.axis.value;return [expandDims(getParamValue("x", e, t, a), r)];case "squeeze": + r = e.params.axis.value;return [squeeze(getParamValue("x", e, t, a), r)];case "reshape": + return [reshape(getParamValue("x", e, t, a), getParamValue("shape", e, t, a))];case "pad": + return [pad(getParamValue("x", e, t, a), split$1(getParamValue("padding", e, t, a), 2), getParamValue("constantValue", e, t, a))];case "spaceToBatchND": + var n = getParamValue("blockShape", e, t, a), + o = split$1(getParamValue("paddings", e, t, a), 2);return [spaceToBatchND(getParamValue("x", e, t, a), n, o)];case "batchToSpaceND": + n = getParamValue("blockShape", e, t, a);var s = split$1(getParamValue("crops", e, t, a), 2);return [batchToSpaceND(getParamValue("x", e, t, a), n, s)];default: + throw TypeError("Node type " + e.op + " is not implemented");} + };function executeOp$15(e, t, a) { + switch (e.category) {case "arithmetic": + return executeOp(e, t, a);case "basic_math": + return executeOp$1(e, t, a);case "control": + return executeOp$2(e, t, a);case "convolution": + return executeOp$3(e, t, a);case "creation": + return executeOp$4(e, t, a);case "dynamic": + return executeOp$5(e, t, a);case "evaluation": + return executeOp$6(e, t, a);case "image": + return executeOp$8(e, t, a);case "graph": + return executeOp$7(e, t, a);case "logical": + return executeOp$9(e, t, a);case "matrices": + return executeOp$10(e, t, a);case "normalization": + return executeOp$11(e, t, a);case "reduction": + return executeOp$12(e, t, a);case "slice_join": + return executeOp$13(e, t, a);case "transformation": + return executeOp$14(e, t, a);default: + throw TypeError("Node type " + e.op + " is not implemented");} + }var ExecutionContext = function () { + function e(e, t) { + this.weightMap = e, this.tensorArrayMap = t, this.rootContext = { id: 0, frameName: "", iterationId: 0 }, this.contexts = [this.rootContext], this.lastId = 0, this.generateCurrentContextIds(); + }return e.prototype.newFrame = function (e, t) { + return { id: e, frameName: t, iterationId: 0 }; + }, Object.defineProperty(e.prototype, "currentContext", { get: function () { + return this.contexts; + }, set: function (e) { + this.contexts !== e && (this.contexts = e, this.generateCurrentContextIds()); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "currentContextId", { get: function () { + return this._currentContextIds[0]; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "currentContextIds", { get: function () { + return this._currentContextIds; + }, enumerable: !0, configurable: !0 }), e.prototype.generateCurrentContextIds = function () { + for (var e = [], t = 0; t < this.contexts.length - 1; t++) { + var a = this.contexts.slice(0, this.contexts.length - t);e.push(this.contextIdforContexts(a)); + }e.push(""), this._currentContextIds = e; + }, e.prototype.contextIdforContexts = function (e) { + return e ? e.map(function (e) { + return 0 === e.id && 0 === e.iterationId ? "" : e.frameName + "-" + e.iterationId; + }).join("/") : ""; + }, e.prototype.enterFrame = function (e) { + this.contexts && (this.lastId++, this.contexts = this.contexts.slice(), this.contexts.push(this.newFrame(this.lastId, e)), this._currentContextIds.unshift(this.contextIdforContexts(this.contexts))); + }, e.prototype.exitFrame = function () { + if (!(this.contexts && this.contexts.length > 1)) throw new Error("Cannot exit frame, the context is empty");this.contexts = this.contexts.slice(), this.contexts.splice(-1), this.currentContextIds.shift(); + }, e.prototype.nextIteration = function () { + if (!(this.contexts && this.contexts.length > 0)) throw new Error("Cannot increase frame iteration, the context is empty");this.contexts = this.contexts.slice(), this.lastId++;var e = Object.assign({}, this.contexts[this.contexts.length - 1]);e.iterationId += 1, e.id = this.lastId, this.contexts.splice(-1, 1, e), this._currentContextIds.splice(0, 1, this.contextIdforContexts(this.contexts)); + }, e.prototype.getWeight = function (e) { + return this.weightMap[e]; + }, e.prototype.addTensorArray = function (e) { + this.tensorArrayMap[e.id] = e; + }, e.prototype.getTensorArray = function (e) { + return this.tensorArrayMap[e]; + }, e; + }(), + GraphExecutor = function () { + function e(e) { + this.graph = e, this.compiledOrder = [], this._weightMap = {}, this.placeholders = e.placeholders, this._outputs = e.outputs, this.compile(); + }return Object.defineProperty(e.prototype, "weightMap", { get: function () { + return this._weightMap; + }, set: function (e) { + var t = Object.keys(e).map(function (t) { + return e[t].map(function (e) { + return e.id; + }); + });this.weightIds = [].concat.apply([], t), this._weightMap = e; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "inputs", { get: function () { + return this.placeholders.map(function (e) { + return { name: e.name, shape: e.params.shape ? e.params.shape.value : void 0, dtype: e.params.dtype ? e.params.dtype.value : void 0 }; + }); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "outputs", { get: function () { + return this._outputs.map(function (e) { + return { name: e.name, shape: e.params.shape ? e.params.shape.value : void 0, dtype: e.params.dtype ? e.params.dtype.value : void 0 }; + }); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "inputNodes", { get: function () { + return this.placeholders.map(function (e) { + return e.name; + }); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "outputNodes", { get: function () { + return this.outputs.map(function (e) { + return e.name; + }); + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "isControlFlowModel", { get: function () { + return this.graph.withControlFlow; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "isDynamicShapeModel", { get: function () { + return this.graph.withDynamicShape; + }, enumerable: !0, configurable: !0 }), e.prototype.compile = function () { + if (!this.graph.withControlFlow && !this.graph.withDynamicShape) for (var e = this.graph.inputs.slice(), t = {}; e.length > 0;) { + var a = e.pop();t[a.name] = !0, this.compiledOrder.push(a), a.children.forEach(function (a) { + !t[a.name] && a.inputNames.every(function (e) { + var a = getNodeNameAndIndex(e)[0];return t[a]; + }) && e.push(a); + }); + } + }, e.prototype.execute = function (e, t) { + var a = this;this.checkInput(e), this.checkInputShapeAndType(e);var r = {};return tidy(function () { + var n = new ExecutionContext(a._weightMap, r), + o = a.compiledOrder.reduce(function (e, t) { + return e[t.name] = executeOp$15(t, e, n), e; + }, __assign$2({}, a.weightMap, e));return a.findOutputs(o, n, t); + }); + }, e.prototype.executeAsync = function (e, t) { + return __awaiter$2(this, void 0, void 0, function () { + var a, + r, + n, + o, + s, + i, + p, + u = this;return __generator$2(this, function (m) { + switch (m.label) {case 0: + return this.checkInput(e), this.checkInputShapeAndType(e), a = {}, r = new ExecutionContext(this._weightMap, a), [4, this.executeWithControlFlow(e, r)];case 1: + return n = m.sent(), o = this.findOutputs(n, r, t), s = Object.keys(o).map(function (e) { + return o[e].id; + }), i = Object.keys(e).map(function (t) { + return e[t].map(function (e) { + return e.id; + }); + }), p = [].concat.apply([], i), Object.keys(n).forEach(function (e) { + n[e].forEach(function (e) { + e && -1 === s.indexOf(e.id) && -1 === p.indexOf(e.id) && -1 === u.weightIds.indexOf(e.id) && e.dispose(); + }); + }), [2, o];} + }); + }); + }, e.prototype.executeWithControlFlow = function (e, t) { + return __awaiter$2(this, void 0, void 0, function () { + var a, r, n, o, s, i, p, u;return __generator$2(this, function (m) { + switch (m.label) {case 0: + a = this.graph.inputs.map(function (e) { + return { node: e, contexts: t.currentContext }; + }), r = __assign$2({}, this.weightMap, e), n = {}, m.label = 1;case 1: + return a.length > 0 ? (o = a.pop(), t.currentContext = o.contexts, s = "", "enter" === o.node.op && getParamValue("isConstant", o.node, r, t) && (s = getNodeNameAndIndex(o.node.name, t)[0]), i = executeOp$15(o.node, r, t), s || (s = getNodeNameAndIndex(o.node.name, t)[0]), p = r, u = s, [4, i]) : [3, 3];case 2: + return p[u] = m.sent(), o.node.children.forEach(function (e) { + var o = getNodeNameAndIndex(e.name, t)[0];n[o] || ("merge" === e.op ? e.inputNames.some(function (e) { + return !!getTensor(e, r, t); + }) && (n[o] = !0, a.push({ contexts: t.currentContext, node: e })) : e.inputNames.every(function (e) { + return !!getTensor(e, r, t); + }) && (n[o] = !0, a.push({ contexts: t.currentContext, node: e }))); + }), [3, 1];case 3: + return [2, r];} + }); + }); + }, e.prototype.findOutputs = function (e, t, a) { + return !a || a instanceof Array || (a = [a]), (a || this.graph.outputs.map(function (e) { + return e.name; + })).reduce(function (a, r) { + return a[r] = getTensor(r, e, t), a; + }, {}); + }, e.prototype.dispose = function () { + var e = this;Object.keys(this.weightMap).forEach(function (t) { + return e.weightMap[t].forEach(function (e) { + return e.dispose(); + }); + }); + }, e.prototype.checkInputShapeAndType = function (e) { + this.placeholders.forEach(function (t) { + var a = e[t.name][0];if (t.params.shape && t.params.shape.value) { + var r = t.params.shape.value, + n = r.length === a.shape.length && a.shape.every(function (e, t) { + return -1 === r[t] || r[t] === e; + });util.assert(n, "The shape of dict['" + t.name + "'] provided in model.execute(dict) must be [" + r + "], but was [" + a.shape + "]"); + }t.params.dtype && t.params.dtype.value && util.assert(a.dtype === t.params.dtype.value, "The dtype of dict['" + t.name + "'] provided in model.execute(dict) must be " + t.params.dtype.value + ", but was " + a.dtype); + }); + }, e.prototype.checkInput = function (e) { + var t = this, + a = Object.keys(e), + r = [], + n = [];if (this.inputNodes.forEach(function (e) { + -1 === a.indexOf(e) && r.push(e); + }), a.forEach(function (e) { + -1 === t.inputNodes.indexOf(e) && n.push(e); + }), r.length > 0) throw new Error("The dict provided in model.execute(dict) has the keys [" + a + "], but is missing the required keys: [" + r + "].");if (n.length > 0) throw new Error("The dict provided in model.execute(dict) has unused keys: [" + n + "]. Please provide only the following keys: [" + this.inputNodes + "]."); + }, e; + }(), + FrozenModel = function () { + function e(e, t, a) { + this.modelUrl = e, this.weightManifestUrl = t, this.requestOption = a, this.version = "n/a", this.pathPrefix = this.getPathPrefix(); + }return Object.defineProperty(e.prototype, "modelVersion", { get: function () { + return this.version; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "inputNodes", { get: function () { + return this.executor.inputNodes; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "outputNodes", { get: function () { + return this.executor.outputNodes; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "inputs", { get: function () { + return this.executor.inputs; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "outputs", { get: function () { + return this.executor.outputs; + }, enumerable: !0, configurable: !0 }), Object.defineProperty(e.prototype, "weights", { get: function () { + return this.executor.weightMap; + }, enumerable: !0, configurable: !0 }), e.prototype.getPathPrefix = function () { + var e = parse(this.weightManifestUrl), + t = e.pathname.split("/");return t.splice(-1), e.pathname = t.join("/"), format(e) + "/"; + }, e.prototype.loadRemoteProtoFile = function () { + return __awaiter$2(this, void 0, void 0, function () { + var e, t, a, r, n;return __generator$2(this, function (o) { + switch (o.label) {case 0: + return o.trys.push([0, 3,, 4]), [4, fetch(this.modelUrl, this.requestOption)];case 1: + return e = o.sent(), a = (t = compiled_api_1.GraphDef).decode, r = Uint8Array.bind, [4, e.arrayBuffer()];case 2: + return [2, a.apply(t, [new (r.apply(Uint8Array, [void 0, o.sent()]))()])];case 3: + throw n = o.sent(), new Error(this.modelUrl + " not found. " + n);case 4: + return [2];} + }); + }); + }, e.prototype.loadWeightManifest = function () { + return __awaiter$2(this, void 0, void 0, function () { + var e, t, a;return __generator$2(this, function (r) { + switch (r.label) {case 0: + return r.trys.push([0, 3,, 4]), [4, fetch(this.weightManifestUrl, this.requestOption)];case 1: + return e = r.sent(), t = this, [4, e.clone().json()];case 2: + return t.weightManifest = r.sent(), [3, 4];case 3: + throw a = r.sent(), new Error(this.weightManifestUrl + " not found. " + a);case 4: + return [2];} + }); + }); + }, e.prototype.load = function () { + return __awaiter$2(this, void 0, void 0, function () { + var e, t, a, r;return __generator$2(this, function (n) { + switch (n.label) {case 0: + return e = this.loadRemoteProtoFile(), t = this.loadWeightManifest(), [4, Promise.all([e, t])];case 1: + return a = n.sent()[0], this.version = a.versions.producer + "." + a.versions.minConsumer, [4, io.loadWeights(this.weightManifest, this.pathPrefix, void 0, this.requestOption)];case 2: + return r = n.sent(), this.executor = new GraphExecutor(OperationMapper.Instance.transformGraph(a)), this.executor.weightMap = this.convertTensorMapToTensorsMap(r), [2, !0];} + }); + }); + }, e.prototype.predict = function (e, t) { + return this.execute(e, this.outputNodes); + }, e.prototype.constructTensorMap = function (e) { + var t = e instanceof Tensor ? [e] : e;if (t.length !== this.inputNodes.length) throw new Error("Input tensor count mismatch,the frozen model has " + this.inputNodes.length + " placeholders, while there are " + t.length + " input tensors.");return this.inputNodes.reduce(function (e, a, r) { + return e[a] = t[r], e; + }, {}); + }, e.prototype.execute = function (e, t) { + if (t = t || this.outputNodes, (e instanceof Tensor || Array.isArray(e)) && (e = this.constructTensorMap(e)), this.executor.isControlFlowModel || this.executor.isDynamicShapeModel) throw new Error("The model contains control flow or dynamic shape ops, please use executeAsync method");var a = this.executor.execute(this.convertTensorMapToTensorsMap(e), t), + r = Object.keys(a);return Array.isArray(t) && t.length > 1 ? t.map(function (e) { + return a[e]; + }) : a[r[0]]; + }, e.prototype.executeAsync = function (e, t) { + return __awaiter$2(this, void 0, void 0, function () { + var a, r;return __generator$2(this, function (n) { + switch (n.label) {case 0: + if (!this.executor.isControlFlowModel || !this.executor.isDynamicShapeModel) throw new Error("The model does not contain control flow or dynamic shape ops, please use execute method for better performance.");return t = t || this.outputNodes, (e instanceof Tensor || Array.isArray(e)) && (e = this.constructTensorMap(e)), [4, this.executor.executeAsync(this.convertTensorMapToTensorsMap(e), t)];case 1: + return a = n.sent(), r = Object.keys(a), [2, Array.isArray(t) && t.length > 1 ? t.map(function (e) { + return a[e]; + }) : a[r[0]]];} + }); + }); + }, e.prototype.convertTensorMapToTensorsMap = function (e) { + return Object.keys(e).reduce(function (t, a) { + return t[a] = [e[a]], t; + }, {}); + }, e.prototype.dispose = function () { + this.executor.dispose(); + }, e; + }();function loadFrozenModel(e, t, a) { + return __awaiter$2(this, void 0, void 0, function () { + var r;return __generator$2(this, function (n) { + switch (n.label) {case 0: + return [4, (r = new FrozenModel(e, t, a)).load()];case 1: + return n.sent(), [2, r];} + }); + }); + }var version$2 = "0.5.5"; + + var version$3 = '0.12.4'; + + var version$4 = { + 'tfjs-core': version, + 'tfjs-layers': version$1, + 'tfjs-converter': version$2, + 'tfjs': version$3 + }; + + exports.version = version$4; + exports.setBackend = setBackend; + exports.getBackend = getBackend; + exports.disposeVariables = disposeVariables; + exports.memory = memory; + exports.version_core = version; + exports.nextFrame = nextFrame; + exports.environment = environment; + exports.io = io; + exports.serialization = serialization; + exports.test_util = test_util; + exports.util = util; + exports.webgl = webgl; + exports.AdadeltaOptimizer = AdadeltaOptimizer; + exports.AdagradOptimizer = AdagradOptimizer; + exports.AdamOptimizer = AdamOptimizer; + exports.AdamaxOptimizer = AdamaxOptimizer; + exports.MomentumOptimizer = MomentumOptimizer; + exports.Optimizer = Optimizer; + exports.RMSPropOptimizer = RMSPropOptimizer; + exports.SGDOptimizer = SGDOptimizer; + exports.Tensor = Tensor; + exports.TensorBuffer = TensorBuffer; + exports.variable = variable; + exports.Variable = Variable; + exports.ENV = ENV; + exports.Environment = Environment; + exports.image = image_ops; + exports.linalg = linalg_ops; + exports.losses = loss_ops; + exports.op = op; + exports.batchNormalization2d = batchNormalization2d; + exports.batchNormalization3d = batchNormalization3d; + exports.batchNormalization4d = batchNormalization4d; + exports.batchNormalization = batchNormalization; + exports.concat = concat; + exports.concat1d = concat1d; + exports.concat2d = concat2d; + exports.concat3d = concat3d; + exports.concat4d = concat4d; + exports.conv1d = conv1d; + exports.conv2d = conv2d; + exports.depthwiseConv2d = depthwiseConv2d; + exports.separableConv2d = separableConv2d; + exports.conv2dTranspose = conv2dTranspose; + exports.matMul = matMul; + exports.dot = dot; + exports.outerProduct = outerProduct; + exports.reverse = reverse; + exports.reverse1d = reverse1d; + exports.reverse2d = reverse2d; + exports.reverse3d = reverse3d; + exports.reverse4d = reverse4d; + exports.maxPool = maxPool; + exports.avgPool = avgPool; + exports.slice = slice; + exports.slice1d = slice1d; + exports.slice2d = slice2d; + exports.slice3d = slice3d; + exports.slice4d = slice4d; + exports.abs = abs; + exports.acos = acos; + exports.acosh = acosh; + exports.asin = asin; + exports.asinh = asinh; + exports.atan = atan; + exports.atanh = atanh; + exports.ceil = ceil; + exports.clipByValue = clipByValue; + exports.cos = cos; + exports.cosh = cosh; + exports.erf = erf; + exports.exp = exp; + exports.expm1 = expm1; + exports.floor = floor; + exports.log = log$1; + exports.log1p = log1p; + exports.logSigmoid = logSigmoid; + exports.neg = neg; + exports.reciprocal = reciprocal; + exports.round = round; + exports.rsqrt = rsqrt; + exports.sigmoid = sigmoid; + exports.sign = sign; + exports.sin = sin; + exports.sinh = sinh; + exports.softplus = softplus; + exports.sqrt = sqrt; + exports.square = square; + exports.step = step; + exports.tan = tan; + exports.tanh = tanh$1; + exports.all = all; + exports.any = any; + exports.argMax = argMax; + exports.argMin = argMin; + exports.logSumExp = logSumExp; + exports.max = max; + exports.mean = mean; + exports.min = min; + exports.moments = moments; + exports.sum = sum; + exports.equal = equal; + exports.equalStrict = equalStrict; + exports.greater = greater; + exports.greaterEqual = greaterEqual; + exports.greaterEqualStrict = greaterEqualStrict; + exports.greaterStrict = greaterStrict; + exports.less = less; + exports.lessEqual = lessEqual; + exports.lessEqualStrict = lessEqualStrict; + exports.lessStrict = lessStrict; + exports.notEqual = notEqual; + exports.notEqualStrict = notEqualStrict; + exports.add = add; + exports.addN = addN; + exports.addStrict = addStrict; + exports.atan2 = atan2; + exports.div = div; + exports.divStrict = divStrict; + exports.floorDiv = floorDiv; + exports.maximum = maximum; + exports.maximumStrict = maximumStrict; + exports.minimum = minimum; + exports.minimumStrict = minimumStrict; + exports.mod = mod; + exports.modStrict = modStrict; + exports.mul = mul; + exports.mulStrict = mulStrict; + exports.pow = pow; + exports.powStrict = powStrict; + exports.squaredDifference = squaredDifference; + exports.squaredDifferenceStrict = squaredDifferenceStrict; + exports.sub = sub; + exports.subStrict = subStrict; + exports.elu = elu; + exports.leakyRelu = leakyRelu; + exports.prelu = prelu; + exports.relu = relu; + exports.selu = selu; + exports.logicalAnd = logicalAnd; + exports.logicalNot = logicalNot; + exports.logicalOr = logicalOr; + exports.logicalXor = logicalXor; + exports.where = where; + exports.whereAsync = whereAsync; + exports.buffer = buffer; + exports.toPixels = toPixels; + exports.print = print; + exports.cast = cast; + exports.clone = clone; + exports.cumsum = cumsum; + exports.expandDims = expandDims; + exports.eye = eye; + exports.fromPixels = fromPixels; + exports.multinomial = multinomial; + exports.oneHot = oneHot; + exports.pad = pad; + exports.pad1d = pad1d; + exports.pad2d = pad2d; + exports.pad3d = pad3d; + exports.pad4d = pad4d; + exports.rand = rand; + exports.randomNormal = randomNormal; + exports.randomUniform = randomUniform; + exports.reshape = reshape; + exports.split = split; + exports.squeeze = squeeze; + exports.stack = stack; + exports.tile = tile; + exports.truncatedNormal = truncatedNormal; + exports.unstack = unstack; + exports.batchToSpaceND = batchToSpaceND; + exports.spaceToBatchND = spaceToBatchND; + exports.fill = fill; + exports.linspace = linspace; + exports.ones = ones$1; + exports.range = range; + exports.scalar = scalar; + exports.tensor = tensor; + exports.tensor1d = tensor1d; + exports.tensor2d = tensor2d; + exports.tensor3d = tensor3d; + exports.tensor4d = tensor4d; + exports.tensor5d = tensor5d; + exports.tensor6d = tensor6d; + exports.zeros = zeros; + exports.onesLike = onesLike; + exports.zerosLike = zerosLike; + exports.transpose = transpose; + exports.softmax = softmax; + exports.localResponseNormalization = localResponseNormalization; + exports.norm = norm; + exports.gather = gather; + exports.unsortedSegmentSum = unsortedSegmentSum; + exports.basicLSTMCell = basicLSTMCell; + exports.multiRNNCell = multiRNNCell; + exports.movingAverage = movingAverage; + exports.stridedSlice = stridedSlice; + exports.topk = topk; + exports.train = train; + exports.tidy = tidy; + exports.keep = keep; + exports.dispose = dispose; + exports.time = time; + exports.customGrad = customGrad; + exports.grad = grad; + exports.grads = grads; + exports.valueAndGrad = valueAndGrad; + exports.valueAndGrads = valueAndGrads; + exports.variableGrads = variableGrads; + exports.constraints = exports_constraints; + exports.initializers = exports_initializers; + exports.layers = exports_layers; + exports.metrics = exports_metrics; + exports.regularizers = exports_regularizers; + exports.CallbackList = CallbackList; + exports.CustomCallback = CustomCallback; + exports.Callback = Callback; + exports.SymbolicTensor = SymbolicTensor; + exports.Model = Model; + exports.input = input; + exports.loadModel = loadModel; + exports.model = model; + exports.sequential = sequential; + exports.RNN = RNN; + exports.Sequential = Sequential; + exports.LayerVariable = LayerVariable; + exports.version_layers = version$1; + exports.FrozenModel = FrozenModel; + exports.loadFrozenModel = loadFrozenModel; + exports.version_converter = version$2; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); +//# sourceMappingURL=tf.js.map diff --git a/node_modules/@tensorflow/tfjs/dist/tf.js.map b/node_modules/@tensorflow/tfjs/dist/tf.js.map new file mode 100644 index 0000000..d7bb1c8 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf.js","sources":["../node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js","../node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js","../node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js","../src/version.ts","../src/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nvar extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])&&(6===a[0]||2===a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]0;)r=Math.random()*t|0,n=e[--t],e[t]=e[r],e[r]=n}function clamp(e,t,n){return Math.max(e,Math.min(t,n))}function randUniform(e,t){return Math.random()*(t-e)+e}function distSquared(e,t){for(var n=0,r=0;r0,function(){return\"Element arr[\"+n.join(\"][\")+\"] should be a primitive, but is an array of \"+e.length+\" elements\"}),assert(e.length===t[0],function(){return\"Element arr[\"+n.join(\"][\")+\"] should have \"+t[0]+\" elements, but has \"+e.length+\" elements\"});for(var r=t.slice(1),o=0;o1;--t)if(e%t==0)return[t,e/t];return[1,e]}function createShuffledIndices(e){for(var t=new Uint32Array(e),n=0;n=n?o():setTimeout(i,s)}};i()})}function inferFromImplicitShape(e,t){for(var n=1,r=-1,o=0;o0)n*=e[o];else if(-1===e[o]){if(-1!==r)throw Error(\"Shapes can only have 1 implicit size. Found - 1 at dim \"+r+\" and dim \"+o);r=o}else if(e[o]<=0)throw Error(\"Shapes can not be <= 0. Found \"+e[o]+\" at dim \"+o);if(-1===r){if(t>0&&t!==n)throw Error(\"Size(\"+t+\") must match the product of shape \"+e);return e}if(t%n!=0)throw Error(\"The implicit shape can't be a fractional number. Got \"+t+\" / \"+n);var a=e.slice();return a[r]=t/n,a}function squeezeShape(e,t){for(var n=[],r=[],o=0,a=0;a1)throw new Error(\"Can't squeeze axis \"+a+\" since its dim '\"+e[a]+\"' is not 1\");(null==t[o]||t[o]>a)&&1===e[a]&&(n.push(e[a]),r.push(a)),t[o]<=a&&o++}e[a]>1&&(n.push(e[a]),r.push(a))}return{newShape:n,keptDims:r}}function getTypedArrayFromDType(e,t){var n=null;if(null==e||\"float32\"===e)n=new Float32Array(t);else if(\"int32\"===e)n=new Int32Array(t);else{if(\"bool\"!==e)throw new Error(\"Unknown data type \"+e);n=new Uint8Array(t)}return n}function checkComputationForNaN(e,t,n){if(\"float32\"===t)for(var r=0;r=0;--r)n[r]=n[r+1]*e[r+1];return n}function toTypedArray(e,t,n){return noConversionNeeded(e,t)?e:(Array.isArray(e)&&(e=flatten(e)),copyTypedArray(e,t,n))}function noConversionNeeded(e,t){return e instanceof Float32Array&&\"float32\"===t||e instanceof Int32Array&&\"int32\"===t||e instanceof Uint8Array&&\"bool\"===t}function makeOnesTypedArray(e,t){for(var n=makeZerosTypedArray(e,t),r=0;r=0;a--){i=(m=e[a]).inputs;var h=[];h.push(m.output);for(c=0;c=0;n--){var r=t[n],o=e[r.output.id];if(null==r.gradient)throw new Error(\"Cannot compute gradient: gradient function not found for \"+r.name+\".\");var a=r.gradient(o);for(var i in r.inputs){if(!(i in a))throw new Error(\"Cannot backprop through input \"+i+\". Available gradients found: \"+Object.keys(a)+\".\");var s=a[i](),u=r.inputs[i];if(!arraysEqual(s.shape,u.shape))throw new Error(\"Error in gradient for op \"+r.name+\". The gradient of input '\"+i+\"' has shape '\"+s.shape+\"', which does not match the shape of the input '\"+u.shape+\"'\");if(null==e[u.id])e[u.id]=s;else{var l=e[u.id];e[u.id]=l.add(s),l.dispose()}}}}var FORMAT_LIMIT_NUM_VALS=20,FORMAT_NUM_FIRST_LAST_VALS=3,FORMAT_NUM_SIG_DIGITS=7;function tensorToString(e,t,n,r){var o=computeStrides(t),a=computeMaxSizePerColumn(e,t,o),i=t.length,s=subTensorToString(e,t,o,a),u=[\"Tensor\"];return r&&(u.push(\" dtype: \"+n),u.push(\" rank: \"+i),u.push(\" shape: [\"+t+\"]\"),u.push(\" values:\")),u.push(s.map(function(e){return\" \"+e}).join(\"\\n\")),u.join(\"\\n\")}function computeMaxSizePerColumn(e,t,n){var r=sizeFromShape(t),o=n[n.length-1],a=new Array(o).fill(0);if(t.length>1)for(var i=0;iFORMAT_LIMIT_NUM_VALS){var s=Array.from(e.subarray(0,FORMAT_NUM_FIRST_LAST_VALS)),u=Array.from(e.subarray(a-FORMAT_NUM_FIRST_LAST_VALS,a));return[\"[\"+s.map(function(e,t){return valToString(e,r[t])}).join(\", \")+\", ..., \"+u.map(function(e,t){return valToString(e,r[a-FORMAT_NUM_FIRST_LAST_VALS+t])}).join(\", \")+\"]\"]}return[\"[\"+Array.from(e).map(function(e,t){return valToString(e,r[t])}).join(\", \")+\"]\"]}var l=t.slice(1),c=n.slice(1),p=n[0],d=[];if(a>FORMAT_LIMIT_NUM_VALS){for(var h=0;h {...}) to avoid memory leaks.\");return this.keepTensors.add(e.id),e},e.prototype.startScope=function(e,t){void 0===t&&(t=!1),t&&0===this.gradientScopeCount&&(this.activeTape=[]),t&&this.gradientScopeCount++;var n={track:[],name:\"unnamed scope\"};e&&(n.name=e),this.scopeStack.push(n),this.activeScope=n},e.prototype.endScope=function(e,t){var n=this;void 0===t&&(t=!1),t&&(this.gradientScopeCount--,0===this.gradientScopeCount&&(this.activeTape=null));var r=new Set(this.keepTensors),o=getTensorsInContainer(e);o.forEach(function(e){return r.add(e.id)});for(var a=0;a0,\"gradients() received an empty list of xs.\"),this.tidy(\"gradients\",function(){var a=e();assert(a instanceof Tensor,\"The result y returned by f() must be a tensor.\");var i=getFilteredNodesXToY(o.activeTape,t,a);if(!r&&0===i.length&&t.length>0)throw new Error(\"Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.\");var s={};return s[a.id]=null==n?ones(a.shape):n,backpropagateGradients(s,i),{value:a,grads:t.map(function(e){return s[e.id]})}},!0)},e.prototype.customGrad=function(e){var t=this;return assert(isFunction(e),\"The f passed in customGrad(f) must be a function.\"),function(){for(var n,r,o=[],a=0;a {op();...}); to avoid memory leaks.\");return this.activeScope.track.push(e),e},e}();function ones(e){var t=makeOnesTypedArray(sizeFromShape(e),\"float32\");return Tensor.make(e,{values:t})}!function(e){e[e.NUMBER=0]=\"NUMBER\",e[e.BOOLEAN=1]=\"BOOLEAN\",e[e.STRING=2]=\"STRING\"}(Type||(Type={}));var URL_PROPERTIES=[{name:\"DEBUG\",type:Type.BOOLEAN},{name:\"IS_BROWSER\",type:Type.BOOLEAN},{name:\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\",type:Type.NUMBER},{name:\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE\",type:Type.BOOLEAN},{name:\"WEBGL_VERSION\",type:Type.NUMBER},{name:\"WEBGL_RENDER_FLOAT32_ENABLED\",type:Type.BOOLEAN},{name:\"WEBGL_DOWNLOAD_FLOAT_ENABLED\",type:Type.BOOLEAN},{name:\"WEBGL_FENCE_API_ENABLED\",type:Type.BOOLEAN},{name:\"BACKEND\",type:Type.STRING}];function isWebGLVersionEnabled(e,t){var n;try{n=getWebGLRenderingContext(e,t)}catch(e){return!1}return null!=n&&(loseContext(n),!0)}function getWebGLDisjointQueryTimerVersion(e,t){if(0===e)return 0;var n,r=getWebGLRenderingContext(e,t);return n=hasExtension(r,\"EXT_disjoint_timer_query_webgl2\")&&2===e?2:hasExtension(r,\"EXT_disjoint_timer_query\")?1:0,null!=r&&loseContext(r),n}function isRenderToFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,\"OES_texture_float\"))return!1}else if(!hasExtension(n,\"EXT_color_buffer_float\"))return!1;createFloatTextureAndBindToFramebuffer(n,e);var r=n.checkFramebufferStatus(n.FRAMEBUFFER)===n.FRAMEBUFFER_COMPLETE;return loseContext(n),r}function isDownloadFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,\"OES_texture_float\"))return!1}else if(!hasExtension(n,\"EXT_color_buffer_float\"))return!1;createFloatTextureAndBindToFramebuffer(n,e),n.readPixels(0,0,1,1,n.RGBA,n.FLOAT,new Float32Array(4));var r=n.getError()===n.NO_ERROR;return loseContext(n),r}function isWebGLFenceEnabled(e,t){if(2!==e)return!1;var n=getWebGLRenderingContext(e,t),r=null!=n.fenceSync;return loseContext(n),r}function isChrome(){return\"undefined\"!=typeof navigator&&null!=navigator&&null!=navigator.userAgent&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}var TENSORFLOWJS_FLAGS_PREFIX=\"tfjsflags\";function getFeaturesFromURL(){var e={};if(\"undefined\"==typeof window||void 0===window.location)return e;var t=getQueryParams(window.location.search);if(TENSORFLOWJS_FLAGS_PREFIX in t){var n={};t[TENSORFLOWJS_FLAGS_PREFIX].split(\",\").forEach(function(e){var t=e.split(\":\"),r=t[0],o=t[1];n[r]=o}),URL_PROPERTIES.forEach(function(t){t.name in n&&(console.log(\"Setting feature override from URL \"+t.name+\": \"+n[t.name]),t.type===Type.NUMBER?e[t.name]=+n[t.name]:t.type===Type.BOOLEAN?e[t.name]=\"true\"===n[t.name]:t.type===Type.STRING?e[t.name]=n[t.name]:console.warn(\"Unknown URL param: \"+t.name+\".\"))})}return e}function hasExtension(e,t){return null!=e.getExtension(t)}function getWebGLRenderingContext(e,t){if(0===e||!t)throw new Error(\"Cannot get WebGL rendering context, WebGL is disabled.\");var n=document.createElement(\"canvas\");return 1===e?n.getContext(\"webgl\")||n.getContext(\"experimental-webgl\"):n.getContext(\"webgl2\")}function loseContext(e){if(null!=e){var t=e.getExtension(\"WEBGL_lose_context\");if(null==t)throw new Error(\"Extension WEBGL_lose_context not supported on this browser.\");t.loseContext()}}function createFloatTextureAndBindToFramebuffer(e,t){var n=e.createFramebuffer(),r=e.createTexture();e.bindTexture(e.TEXTURE_2D,r);var o=2===t?e.RGBA32F:e.RGBA;e.texImage2D(e.TEXTURE_2D,0,o,1,1,0,e.RGBA,e.FLOAT,null),e.bindFramebuffer(e.FRAMEBUFFER,n),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,r,0)}function getQueryParams(e){var t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,function(e){for(var n=[],r=1;r0?0:getWebGLDisjointQueryTimerVersion(t,this.get(\"IS_BROWSER\"))}if(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE\"===e)return this.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0&&!isMobile();if(\"HAS_WEBGL\"===e)return this.get(\"WEBGL_VERSION\")>0;if(\"WEBGL_VERSION\"===e)return isWebGLVersionEnabled(2,this.get(\"IS_BROWSER\"))?2:isWebGLVersionEnabled(1,this.get(\"IS_BROWSER\"))?1:0;if(\"WEBGL_RENDER_FLOAT32_ENABLED\"===e)return isRenderToFloatTextureEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"WEBGL_DOWNLOAD_FLOAT_ENABLED\"===e)return isDownloadFloatTextureEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"WEBGL_FENCE_API_ENABLED\"===e)return isWebGLFenceEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"TEST_EPSILON\"===e)return this.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?TEST_EPSILON_FLOAT32_ENABLED:TEST_EPSILON_FLOAT32_DISABLED;throw new Error(\"Unknown feature \"+e+\".\")},e.prototype.setFeatures=function(e){this.features=Object.assign({},e)},e.prototype.reset=function(){this.features=getFeaturesFromURL(),null!=this.globalEngine&&(this.globalEngine=null)},e.prototype.initBackend=function(e,t){var n=this;void 0===t&&(t=!1),this.backendName=e,this.backend=this.findBackend(e),this.globalEngine=new Engine(this.backend,t,function(){return n.get(\"DEBUG\")})},e.prototype.findBackend=function(e){return e in this.registry?this.registry[e].backend:null},e.prototype.registerBackend=function(e,t,n,r){var o=this;if(void 0===n&&(n=1),e in this.registry)return console.warn(e+\" backend was already registered. Reusing existing backend\"),null!=r&&r(function(){return o.engine}),!1;try{var a=t();return this.registry[e]={backend:a,priority:n},!0}catch(t){return console.warn(\"Registration of backend \"+e+\" failed\"),console.warn(t.stack||t.message),!1}},e.prototype.removeBackend=function(e){if(!(e in this.registry))throw new Error(e+\" backend not found in registry\");this.registry[e].backend.dispose(),delete this.registry[e]},Object.defineProperty(e.prototype,\"engine\",{get:function(){return this.initDefaultBackend(),this.globalEngine},enumerable:!0,configurable:!0}),e.prototype.initDefaultBackend=function(){null==this.globalEngine&&this.initBackend(this.get(\"BACKEND\"),!1)},e}();function getGlobalNamespace(){var e;if(\"undefined\"!=typeof window)e=window;else{if(\"undefined\"==typeof process)throw new Error(\"Could not find a global object\");e=process}return e}function getOrMakeEnvironment(){var e=getGlobalNamespace();return null==e.ENV&&(e.ENV=new Environment(getFeaturesFromURL()),setTensorTracker(function(){return e.ENV.engine})),e.ENV}var ENV=getOrMakeEnvironment(),environment=Object.freeze({Environment:Environment,ENV:ENV});function warn(){for(var e=[],t=0;t=2*t+1||o%2==1?i.push(o):a.push(o);r.push.apply(r,a),r.push(0),r.push.apply(r,i)}return r}function getReshapedPermuted(e,t,n,r){void 0===r&&(r=!0);var o=[];r?o.push(e[0]/n):o.push(e[0]*n);for(var a=1;a=-n&&et||n===e){r=!0;break}n=nearestDivisor(e,n+1)}return n}function computeOutShape(e,t,n){for(var r=[],o=e.length,a=0;a0?o>=s[t]:o<=s[t]);o+=r[t])n+=1;return n}),[i,l]}function startForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MIN_SAFE_INTEGER:Number.MAX_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=clamp(0,a,i-1)}function stopForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MAX_SAFE_INTEGER:Number.MIN_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=n[o]>0?clamp(0,a,i):clamp(-1,a,i-1)}function grad(e){return assert(isFunction(e),\"The f passed in grad(f) must be a function\"),function(t,n){return assert(t instanceof Tensor,\"The x passed in grad(f)(x) must be a tensor\"),assert(null==n||n instanceof Tensor,\"The dy passed in grad(f)(x, dy) must be a tensor\"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,\"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)\"),checkGrads(a),a[0]})}}function grads(e){return assert(isFunction(e),\"The f passed in grads(f) must be a function\"),function(t,n){return assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),\"The args passed in grads(f)(args) must be an array of tensors\"),assert(null==n||n instanceof Tensor,\"The dy passed in grads(f)(args, dy) must be a tensor\"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,\"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])\"),checkGrads(a),a})}}function valueAndGrad(e){return assert(isFunction(e),\"The f passed in valueAndGrad(f) must be a function\"),function(t,n){assert(t instanceof Tensor,\"The x passed in valueAndGrad(f)(x) must be a tensor\"),assert(null==n||n instanceof Tensor,\"The dy passed in valueAndGrad(f)(x, dy) must be a tensor\");var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.grads,a=r.value;return checkGrads(o),{grad:o[0],value:a}}}function valueAndGrads(e){return assert(isFunction(e),\"The f passed in valueAndGrads(f) must be a function\"),function(t,n){assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),\"The args passed in valueAndGrads(f)(args) must be array of tensors\"),assert(null==n||n instanceof Tensor,\"The dy passed in valueAndGrads(f)(args, dy) must be a tensor\");var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n);return null!=n&&assertShapesMatch(r.value.shape,n.shape,\"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])\"),checkGrads(r.grads),r}}function variableGrads(e,t){if(assert(isFunction(e),\"The f passed in variableGrads(f) must be a function\"),assert(null==t||Array.isArray(t)&&t.every(function(e){return e instanceof Variable}),\"The varList passed in variableGrads(f, varList) must be an array of variables\"),null==t)for(var n in t=[],ENV.engine.registeredVariables)t.push(ENV.engine.registeredVariables[n]);var r=t.length;assert((t=t.filter(function(e){return e.trainable})).length>0,\"variableGrads() expects at least one of the input variables to be trainable, but none of the \"+r+\" variables is trainable.\");var o=ENV.engine.gradients(e,t,null,!0),a=o.value,i=o.grads;assert(i.some(function(e){return null!=e}),\"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize().\"),assert(0===a.rank,\"The f passed in variableGrads(f) must return a scalar, but it returned a rank-\"+a.rank+\" tensor\");var s={};return t.forEach(function(e,t){null!=i[t]&&(s[e.name]=i[t])}),{value:a,grads:s}}function customGrad(e){return ENV.engine.customGrad(e)}function checkGrads(e){if(e.filter(function(e){return null==e}).length>0)throw new Error(\"Cannot compute gradient of y=f(x) with respect to x. Make sure that\\n the f you passed encloses all operations that lead from x to y.\")}function convertToTensor(e,t,n,r){if(void 0===r&&(r=\"float32\"),r=r||\"float32\",e instanceof Tensor)return e;if(!isTypedArray(e)&&!Array.isArray(e)&&\"number\"!=typeof e&&\"boolean\"!=typeof e)throw new Error(\"Argument '\"+t+\"' passed to '\"+n+\"' must be a Tensor or TensorLike, but got \"+e.constructor.name);var o=inferShape(e);return isTypedArray(e)||Array.isArray(e)||(e=[e]),Tensor.make(o,{values:toTypedArray(e,r,ENV.get(\"DEBUG\"))},r)}function convertToTensorArray(e,t,n){if(!Array.isArray(e))throw new Error(\"Argument \"+t+\" passed to \"+n+\" must be a `Tensor[]` or `TensorLike[]`\");return e.map(function(e,r){return convertToTensor(e,t+\"[\"+r+\"]\",n)})}function op(e){var t=Object.keys(e);if(1!==t.length)throw new Error(\"Please provide an object with a single key (operation name) mapping to a function. Got an object with \"+t.length+\" keys.\");var n=t[0],r=e[n];n.endsWith(\"_\")&&(n=n.substring(0,n.length-1));var o=function(){for(var e=[],t=0;t1)return zeros([0],r);var o=makeZerosTypedArray(Math.abs(Math.ceil((t-e)/n)),r);to}).sort(function(e,t){return t.score-e.score}),i=[],s=0;s=0;--d){if(intersectionOverUnion(e,c,i[d])>=r){p=!0;break}}if(!p&&(i.push(c),i.length>=n))break}return tensor1d(i,\"int32\")}function intersectionOverUnion(e,t,n){var r=e.subarray(4*t,4*t+4),o=e.subarray(4*n,4*n+4),a=Math.min(r[0],r[2]),i=Math.min(r[1],r[3]),s=Math.max(r[0],r[2]),u=Math.max(r[1],r[3]),l=Math.min(o[0],o[2]),c=Math.min(o[1],o[3]),p=Math.max(o[0],o[2]),d=Math.max(o[1],o[3]),h=(s-a)*(u-i),f=(p-l)*(d-c);if(h<=0||f<=0)return 0;var m=Math.max(a,l),g=Math.max(i,c),v=Math.min(s,p),y=Math.min(u,d),x=Math.max(v-m,0)*Math.max(y-g,0);return x/(h+f-x)}function topkImpl(e,t,n,r,o){for(var a=t[t.length-1],i=[e.length/a,a],s=i[0],u=i[1],l=getTypedArrayFromDType(n,s*r),c=getTypedArrayFromDType(\"int32\",s*r),p=0;p\":\"<\",u=n?\"inOffset + i;\":\"round(getBestIndicesA(batch, inOffset + i));\";this.userCode=\"\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = outIdx * \"+r+\";\\n\\n int bestIndex = 0;\\n float bestValue = getA(batch, inOffset);\\n\\n for (int i = 0; i < \"+r+\"; i++) {\\n int inIdx = \"+u+\";\\n float candidate = getA(batch, inIdx);\\n if (candidate \"+s+\" bestValue) {\\n bestValue = candidate;\\n bestIndex = inIdx;\\n }\\n }\\n setOutput(float(bestIndex));\\n }\\n \"}}(),AvgPool2DBackpropProgram=function(){return function(e){this.variableNames=[\"dy\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=1/(t*n);this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n const float avgMultiplier = float(\"+s+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n\\n ivec2 dyRCCorner = coords.yz - pads;\\n int dyRCorner = dyRCCorner.x;\\n int dyCCorner = dyRCCorner.y;\\n\\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n float dyValue = getDy(b, idyR, idyC, d);\\n\\n dotProd += dyValue * avgMultiplier;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}();function getBroadcastDims(e,t){for(var n=e.length,r=[],o=0;o1&&1===i&&r.unshift(a)}return r}function getReductionAxes(e,t){for(var n=[],r=0;r1)&&n.unshift(a)}return n}function broadcastDimsAreOuter(e){for(var t=0;t1&&s>1&&i!==s)throw Error(r);n.unshift(Math.max(i,s))}return n}var BatchNormProgram=function(){return function(e,t,n,r,o,a){this.outputShape=[],this.supportsBroadcasting=!0,this.variableNames=[\"x\",\"mean\",\"variance\"],assertAndGetBroadcastShape(e,t),assertAndGetBroadcastShape(e,n);var i=\"0.0\";null!=r&&(assertAndGetBroadcastShape(e,r),this.variableNames.push(\"offset\"),i=\"getOffsetAtOutCoords()\");var s=\"1.0\";null!=o&&(assertAndGetBroadcastShape(e,o),this.variableNames.push(\"scale\"),s=\"getScaleAtOutCoords()\"),this.outputShape=e,this.userCode=\"\\n void main() {\\n float x = getXAtOutCoords();\\n float mean = getMeanAtOutCoords();\\n float variance = getVarianceAtOutCoords();\\n float offset = \"+i+\";\\n float scale = \"+s+\";\\n float inv = scale * inversesqrt(variance + float(\"+a+\"));\\n setOutput((x - mean) * inv + offset);\\n }\\n \"}}(),CHECK_NAN_SNIPPET=\"\\n if (isNaN(a)) return a;\\n if (isNaN(b)) return b;\\n\",ADD=\"return a + b;\",SUB=\"return a - b;\",MUL=\"return a * b;\",DIV=\"if (a == b) return 1.0;\\n return a / b;\",INT_DIV=\"\\n float resultSign = sign(a) * sign(b);\\n int ia = round(a);\\n int ib = round(b);\\n int result = ia / ib;\\n int amodb = ia - ib * result;\\n\\n if (resultSign < 0.0 && amodb != 0) {\\n result -= 1;\\n }\\n return float(result);\\n\",POW=\"\\nif(a < 0.0 && floor(b) < b){\\n return NAN;\\n}\\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\\n\",SQUARED_DIFFERENCE=\"return (a - b) * (a - b);\",EQUAL=\"return float(a == b);\",NOT_EQUAL=\"return float(a != b);\",LESS=\"return float(a < b);\",LESS_EQUAL=\"return float(a <= b);\",GREATER=\"return float(a > b);\",GREATER_EQUAL=\"return float(a >= b);\",LOGICAL_AND=\"return float(a >= 1.0 && b >= 1.0);\",LOGICAL_OR=\"return float(a >= 1.0 || b >= 1.0);\",MAX=CHECK_NAN_SNIPPET+\"\\n return max(a, b);\\n\",MIN=CHECK_NAN_SNIPPET+\"\\n return min(a, b);\\n\",MOD=\"if (b == 0.0) return NAN;\\n return mod(a, b);\",ATAN2=CHECK_NAN_SNIPPET+\"\\n return atan(a, b);\\n\",ELU_DER=\"return (b >= 1.0) ? a : a * (b + 1.0);\",BinaryOpProgram=function(){function e(e,t,n){this.variableNames=[\"A\",\"B\"],this.supportsBroadcasting=!0,this.outputShape=assertAndGetBroadcastShape(t,n),this.userCode=\"\\n uniform float NAN;\\n float binaryOperation(float a, float b) {\\n \"+e+\"\\n }\\n\\n void main() {\\n float a = getAAtOutCoords();\\n float b = getBAtOutCoords();\\n setOutput(binaryOperation(a, b));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(){var e=this;return function(t,n){null==e.startLoc&&(e.startLoc=t.getUniformLocationNoThrow(n,\"NAN\"),null==e.startLoc)||t.gl.uniform1f(e.startLoc,NaN)}},e}(),ClipProgram=function(){return function(e,t,n){this.variableNames=[\"A\"],this.outputShape=e;var r=t.toFixed(20),o=n.toFixed(20);this.userCode=\"\\n void main() {\\n float value = getAAtOutCoords();\\n if (isNaN(value)) {\\n setOutput(value);\\n return;\\n }\\n\\n setOutput(clamp(value, \"+r+\", \"+o+\"));\\n }\\n \"}}();function assertParams(e,t,n){var r=e.length,o=t.length;assert(e.length===t.length,\"Error in concat\"+r+\"D: rank of x1 (\"+r+\") and x2 (\"+o+\") must be the same.\"),assert(n>=0&&n= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int yC = 0; yC < \"+e.outWidth+\"; yC++) {\\n int xC = wC + yC * \"+n+\" - \"+o+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float dyValue = getDy(b, yR, yC, d2);\\n float xValue = getX(b, xR, xC, d1);\\n dotProd += (xValue * dyValue);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),Conv2DDerInputProgram=function(){return function(e){this.variableNames=[\"dy\",\"W\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d1 = coords[3];\\n\\n ivec2 dyCorner = coords.yz - pads;\\n int dyRCorner = dyCorner.x;\\n int dyCCorner = dyCorner.y;\\n\\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n int wRPerm = \"+t+\" - 1 - wR;\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n int wCPerm = \"+n+\" - 1 - wC;\\n\\n for (int d2 = 0; d2 < \"+e.outChannels+\"; d2++) {\\n float xValue = getDy(batch, idyR, idyC, d2);\\n float wValue = getW(wRPerm, wCPerm, d1, d2);\\n dotProd += xValue * wValue;\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DDerFilterProgram=function(){return function(e){this.variableNames=[\"x\",\"dy\"],this.outputShape=e.filterShape;var t=e.strideHeight,n=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.outChannels/e.inChannels;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int wR = coords.x;\\n int wC = coords.y;\\n int d1 = coords.z;\\n int dm = coords.w;\\n int d2 = d1 * \"+a+\" + dm;\\n\\n float dotProd = 0.0;\\n\\n // TODO: Vec4 over the batch size\\n for (int b = 0; b < \"+e.batchSize+\"; b++) {\\n for (int yR = 0; yR < \"+e.outHeight+\"; yR++) {\\n int xR = wR + yR * \"+t+\" - \"+r+\";\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int yC = 0; yC < \"+e.outWidth+\"; yC++) {\\n int xC = wC + yC * \"+n+\" - \"+o+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float dyValue = getDy(b, yR, yC, d2);\\n float xValue = getX(b, xR, xC, d1);\\n dotProd += (xValue * dyValue);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DDerInputProgram=function(){return function(e){this.variableNames=[\"dy\",\"W\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d1 = coords[3];\\n ivec2 dyCorner = coords.yz - pads;\\n int dyRCorner = dyCorner.x;\\n int dyCCorner = dyCorner.y;\\n\\n float dotProd = 0.0;\\n\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n int wRPerm = \"+t+\" - 1 - wR;\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n int wCPerm = \"+n+\" - 1 - wC;\\n\\n // TODO: Vec4 over the channelMul\\n for (int dm = 0; dm < \"+s+\"; dm++) {\\n int d2 = d1 * \"+s+\" + dm;\\n float xValue = getDy(batch, idyR, idyC, d2);\\n float wValue = getW(wRPerm, wCPerm, d1, dm);\\n dotProd += xValue * wValue;\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),Conv2DProgram=function(){return function(e){this.variableNames=[\"x\",\"W\"],this.outputShape=e.outShape;var t=e.padInfo.top,n=e.padInfo.left,r=e.strideHeight,o=e.strideWidth,a=e.dilationHeight,i=e.dilationWidth,s=e.filterHeight,u=e.filterWidth,l=4*Math.floor(e.inChannels/4),c=e.inChannels%4;this.userCode=\"\\n const ivec2 strides = ivec2(\"+r+\", \"+o+\");\\n const ivec2 pads = ivec2(\"+t+\", \"+n+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d2 = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+s+\"; wR++) {\\n int xR = xRCorner + wR * \"+a+\";\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+u+\"; wC++) {\\n int xC = xCCorner + wC * \"+i+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n for (int d1 = 0; d1 < \"+l+\"; d1 += 4) {\\n vec4 xValues = vec4(\\n getX(batch, xR, xC, d1),\\n getX(batch, xR, xC, d1 + 1),\\n getX(batch, xR, xC, d1 + 2),\\n getX(batch, xR, xC, d1 + 3)\\n );\\n vec4 wValues = vec4(\\n getW(wR, wC, d1, d2),\\n getW(wR, wC, d1 + 1, d2),\\n getW(wR, wC, d1 + 2, d2),\\n getW(wR, wC, d1 + 3, d2)\\n );\\n\\n dotProd += dot(xValues, wValues);\\n }\\n\\n if (\"+(1===c)+\") {\\n dotProd +=\\n getX(batch, xR, xC, \"+l+\") *\\n getW(wR, wC, \"+l+\", d2);\\n } else if (\"+(2===c)+\") {\\n vec2 xValues = vec2(\\n getX(batch, xR, xC, \"+l+\"),\\n getX(batch, xR, xC, \"+l+\" + 1)\\n );\\n vec2 wValues = vec2(\\n getW(wR, wC, \"+l+\", d2),\\n getW(wR, wC, \"+l+\" + 1, d2)\\n );\\n dotProd += dot(xValues, wValues);\\n } else if (\"+(3===c)+\") {\\n vec3 xValues = vec3(\\n getX(batch, xR, xC, \"+l+\"),\\n getX(batch, xR, xC, \"+l+\" + 1),\\n getX(batch, xR, xC, \"+l+\" + 2)\\n );\\n vec3 wValues = vec3(\\n getW(wR, wC, \"+l+\", d2),\\n getW(wR, wC, \"+l+\" + 1, d2),\\n getW(wR, wC, \"+l+\" + 2, d2)\\n );\\n dotProd += dot(xValues, wValues);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DProgram=function(){return function(e){this.variableNames=[\"x\",\"W\"],this.outputShape=e.outShape;var t=e.inHeight,n=e.inWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.strideHeight,i=e.strideWidth,s=e.dilationHeight,u=e.dilationWidth,l=e.filterHeight,c=e.filterWidth,p=e.outChannels/e.inChannels;this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+r+\", \"+o+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords.x;\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int d2 = coords.w;\\n int d1 = d2 / \"+p+\";\\n int q = d2 - d1 * \"+p+\";\\n\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\\n for (int wR = 0; wR < \"+l+\"; wR++) {\\n int xR = xRCorner + wR * \"+s+\";\\n\\n if (xR < 0 || xR >= \"+t+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+c+\"; wC++) {\\n int xC = xCCorner + wC * \"+u+\";\\n\\n if (xC < 0 || xC >= \"+n+\") {\\n continue;\\n }\\n\\n float xVal = getX(batch, xR, xC, d1);\\n float wVal = getW(wR, wC, d1, q);\\n dotProd += xVal * wVal;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}();function makeShader(e,t,n,r){var o=e.map(function(e){var t=sizeFromShape(e.shapeInfo.logicalShape);return e.shapeInfo.isUniform?\"uniform float \"+e.name+(t>1?\"[\"+t+\"]\":\"\")+\";\":\"uniform sampler2D \"+e.name+\";\"});o=o.join(\"\\n\");var a=e.map(function(e){return getInputSamplingSnippet(e,t,r)}).join(\"\\n\"),i=t.texShape,s=getOutputSamplingSnippet(t.logicalShape,i);return[SHADER_PREFIX,FLOAT_TEXTURE_SAMPLE_SNIPPET,FLOAT_TEXTURE_SETOUTPUT_SNIPPET,o,s,a,n].join(\"\\n\")}function getSamplerFromInInfo(e){var t=e.shapeInfo.logicalShape;switch(t.length){case 0:return getSamplerScalar(e);case 1:return getSampler1D(e);case 2:return getSampler2D(e);case 3:return getSampler3D(e);case 4:return getSampler4D(e);case 5:return getSampler5D(e);case 6:return getSampler6D(e);default:throw new Error(t.length+\"-D input sampling is not yet supported\")}}function getInputSamplingSnippet(e,t,n){var r=getSamplerFlat(e);return r+=getSamplerFromInInfo(e),(n||arraysEqual(e.shapeInfo.logicalShape,t.logicalShape))&&(r+=getSamplerAtOutputCoords(e,t,n)),r}function getOutputSamplingSnippet(e,t){switch(e.length){case 0:return getOutputScalarCoords();case 1:return getOutput1DCoords(e,t);case 2:return getOutput2DCoords(e,t);case 3:return getOutput3DCoords(e,t);case 4:return getOutput4DCoords(e,t);case 5:return getOutput5DCoords(e,t);case 6:return getOutput6DCoords(e,t);default:throw new Error(e.length+\"-D output sampling is not yet supported\")}}var SAMPLE_1D_SNIPPET=\"\\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_2D_SNIPPET=\"\\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\\n int index = row * numC + col;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_3D_SNIPPET=\"\\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\\n int stride1, int row, int col, int depth) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_4D_SNIPPET=\"\\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int row, int col, int depth,\\n int depth2) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_5D_SNIPPET=\"\\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int stride3, int row, int col, int depth,\\n int depth2, int depth3) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 +\\n depth * stride2 + depth2 * stride3 + depth3;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_6D_SNIPPET=\"\\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int stride3, int stride4,\\n int row, int col, int depth, int depth2, int depth3, int depth4) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\\n stride3 + depth3 * stride4 + depth4;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",FLOAT_TEXTURE_SAMPLE_SNIPPET=\"\\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\\n return texture2D(textureSampler, uv).r;\\n }\\n\",FLOAT_TEXTURE_SETOUTPUT_SNIPPET=\"\\n void setOutput(float val) {\\n gl_FragColor = vec4(val, 0, 0, 0);\\n }\\n\",SHADER_PREFIX=\"\\n precision highp float;\\n precision highp int;\\n varying vec2 resultUV;\\n const vec2 halfCR = vec2(0.5, 0.5);\\n\\n struct ivec5\\n {\\n int x;\\n int y;\\n int z;\\n int w;\\n int u;\\n };\\n\\n struct ivec6\\n {\\n int x;\\n int y;\\n int z;\\n int w;\\n int u;\\n int v;\\n };\\n\\n bool isNaN(float val) {\\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\\n }\\n\\n bool hasNaN(vec4 values) {\\n vec4 v1 = values * values;\\n vec4 v2 = values * values;\\n return any(notEqual(v1, v2));\\n }\\n\\n float getNaN(vec4 values) {\\n return dot(vec4(1), values);\\n }\\n\\n int round(float value) {\\n return int(floor(value + 0.5));\\n }\\n\\n int imod(int x, int y) {\\n return x - y * (x / y);\\n }\\n\\n //Based on the work of Dave Hoskins\\n //https://www.shadertoy.com/view/4djSRW\\n #define HASHSCALE1 443.8975\\n float random(float seed){\\n vec2 p = resultUV * seed;\\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n }\\n\\n \"+SAMPLE_1D_SNIPPET+\"\\n \"+SAMPLE_2D_SNIPPET+\"\\n \"+SAMPLE_3D_SNIPPET+\"\\n \"+SAMPLE_4D_SNIPPET+\"\\n \"+SAMPLE_5D_SNIPPET+\"\\n \"+SAMPLE_6D_SNIPPET+\"\\n\";function getOutputScalarCoords(){return\"\\n int getOutputCoords() {\\n return 0;\\n }\\n \"}function getOutput1DCoords(e,t){return 1===t[0]?\"\\n int getOutputCoords() {\\n return int(resultUV.x * \"+t[1]+\".0);\\n }\\n \":1===t[1]?\"\\n int getOutputCoords() {\\n return int(resultUV.y * \"+t[0]+\".0);\\n }\\n \":\"\\n int getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n return resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n }\\n \"}function getOutput3DCoords(e,t){var n=e[1]*e[2],r=e[2];return\"\\n ivec3 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n int r = index / \"+n+\";\\n index -= r * \"+n+\";\\n int c = index / \"+r+\";\\n int d = index - c * \"+r+\";\\n return ivec3(r, c, d);\\n }\\n \"}function getOutput4DCoords(e,t){var n=e[3],r=e[2]*n,o=e[1]*r;return\"\\n ivec4 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+o+\";\\n index -= r * \"+o+\";\\n\\n int c = index / \"+r+\";\\n index -= c * \"+r+\";\\n\\n int d = index / \"+n+\";\\n int d2 = index - d * \"+n+\";\\n\\n return ivec4(r, c, d, d2);\\n }\\n \"}function getOutput5DCoords(e,t){var n=e[4],r=e[3]*n,o=e[2]*r,a=e[1]*o;return\"\\n ivec5 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(\"+t[0]+\",\\n \"+t[1]+\"));\\n\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+a+\";\\n index -= r * \"+a+\";\\n\\n int c = index / \"+o+\";\\n index -= c * \"+o+\";\\n\\n int d = index / \"+r+\";\\n index -= d * \"+r+\";\\n\\n int d2 = index / \"+n+\";\\n int d3 = index - d2 * \"+n+\";\\n\\n ivec5 outShape = ivec5(r, c, d, d2, d3);\\n return outShape;\\n }\\n \"}function getOutput6DCoords(e,t){var n=e[5],r=e[4]*n,o=e[3]*r,a=e[2]*o,i=e[1]*a;return\"\\n ivec6 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+i+\";\\n index -= r * \"+i+\";\\n\\n int c = index / \"+a+\";\\n index -= c * \"+a+\";\\n\\n int d = index / \"+o+\";\\n index -= d * \"+o+\";\\n\\n int d2 = index / \"+r+\";\\n index -= d2 * \"+r+\";\\n\\n int d3 = index / \"+n+\";\\n int d4 = index - d3 * \"+n+\";\\n\\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\\n return result;\\n }\\n \"}function getOutput2DCoords(e,t){return arraysEqual(e,t)?\"\\n ivec2 getOutputCoords() {\\n return ivec2(resultUV.yx * vec2(\"+t[0]+\", \"+t[1]+\"));\\n }\\n \":1===e[1]?\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n return ivec2(index, 0);\\n }\\n \":1===e[0]?\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n return ivec2(0, index);\\n }\\n \":\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n int r = index / \"+e[1]+\";\\n int c = index - r * \"+e[1]+\";\\n return ivec2(r, c);\\n }\\n \"}function getSamplerScalar(e){var t=e.name,n=\"get\"+t.charAt(0).toUpperCase()+t.slice(1);return e.shapeInfo.isUniform?\"float \"+n+\"() {return \"+t+\";}\":\"\\n float \"+n+\"() {\\n return sampleTexture(\"+t+\", halfCR);\\n }\\n \"}function getSampler1D(e){var t=e.name,n=\"get\"+t.charAt(0).toUpperCase()+t.slice(1);return\"\\n float \"+n+\"(int index) {\\n return \"+n+\"Flat(index);\\n }\\n \"}function getSampler2D(e){var t=e.shapeInfo.logicalShape,n=e.name,r=\"get\"+n.charAt(0).toUpperCase()+n.slice(1),o=e.shapeInfo.texShape;if(null!=o&&arraysEqual(t,o)){var a=o[0];return\"\\n float \"+r+\"(int row, int col) {\\n vec2 uv = (vec2(col, row) + halfCR) / vec2(\"+o[1]+\".0, \"+a+\".0);\\n return sampleTexture(\"+n+\", uv);\\n }\\n \"}var i=squeezeShape(t),s=i.newShape,u=i.keptDims,l=s;if(l.length=1?\"coords = 0;\":s.map(function(e){return\"coords[\"+(e+u)+\"] = 0;\"}).join(\"\\n\"))+\"\\n return get\"+n+\"(\"+(a<2&&o>0?\"coords\":e.shapeInfo.logicalShape.map(function(e,t){return\"coords[\"+(t+u)+\"]\"}).join(\", \"))+\");\\n }\\n \"}function getSamplerAtOutputCoords(e,t,n){var r=e.name,o=r.charAt(0).toUpperCase()+r.slice(1),a=\"get\"+o+\"AtOutCoords\",i=getBroadcastDims(e.shapeInfo.logicalShape,t.logicalShape),s=e.shapeInfo.logicalShape.length,u=t.logicalShape.length,l=n&&(u>s||i.length>0),c=broadcastDimsAreOuter(i),p=e.shapeInfo.isUniform;if(l&&!c)return getBroadcastOutputCoordsSampler(e,t,o,a);var d=sizeFromShape(e.shapeInfo.logicalShape),h=\"\";l&&c&&(h=\"\\n int mainPart = index / \"+d+\";\\n index -= mainPart * \"+d+\";\\n \");var f=t.texShape;if(p)return 1===d?\"float \"+a+\"() {return \"+r+\";}\":\"\\n float \"+a+\"() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+f[0]+\", \"+f[1]+\"));\\n int index = resTexRC.x * \"+f[1]+\" + resTexRC.y;\\n \"+h+\"\\n return get\"+o+\"Flat(index);\\n }\\n \";var m=e.shapeInfo.texShape;return arraysEqual(m,f)?\"\\n float \"+a+\"() {\\n return sampleTexture(\"+r+\", resultUV);\\n }\\n \":\"\\n float \"+a+\"() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+f[0]+\", \"+f[1]+\"));\\n int index = resTexRC.x * \"+f[1]+\" + resTexRC.y;\\n \"+h+\"\\n int texR = index / \"+m[1]+\";\\n int texC = index - texR * \"+m[1]+\";\\n vec2 uv = (vec2(texC, texR) + halfCR) /\\n vec2(\"+m[1]+\".0, \"+m[0]+\".0);\\n\\n return sampleTexture(\"+r+\", uv);\\n }\\n \"}function getCoordsDataType(e){if(e<=1)return\"int\";if(2===e)return\"ivec2\";if(3===e)return\"ivec3\";if(4===e)return\"ivec4\";if(5===e)return\"ivec5\";if(6===e)return\"ivec6\";throw Error(\"GPU for rank \"+e+\" is not yet supported\")}function squeezeInputInfo(e,t){var n=JSON.parse(JSON.stringify(e));return n.shapeInfo.logicalShape=t,n}function getSqueezedParams(e,t){return t.map(function(t){return e[t]}).join(\", \")}var CumSumProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=e;var r=e.length,o=e[e.length-1],a=n?\"<\":\">\";this.userCode=\"\\n int getIndex(int i) {\\n \"+(n?\"return \"+o+\" -i - 1;\":\"return i;\")+\"\\n }\\n\\n void main() {\\n \"+getCoordsDataType(r)+\" coords = getOutputCoords();\\n int end = \"+getFinalCoord(r,\"coords\")+\";\\n float val = 0.0;\\n for (int i = \"+o+\" - 1; i >= 0; i -= 1) {\\n int idx = getIndex(i);\\n if (idx \"+a+\" end) {\\n continue;\\n }\\n if (idx == end && \"+t+\") {\\n continue;\\n }\\n \"+getFinalCoord(r,\"coords\")+\" = idx;\\n val += getX(\"+getCoords(r,\"coords\")+\");\\n }\\n setOutput(val);\\n }\\n \"}}();function getCoords(e,t){if(1===e)return\"\"+t;if(2===e)return t+\".x, \"+t+\".y\";if(3===e)return t+\".x, \"+t+\".y, \"+t+\".z\";if(4===e)return t+\".x, \"+t+\".y, \"+t+\".z, \"+t+\".w\";throw Error(\"Cumulative sum for rank \"+e+\" is not yet supported\")}function getFinalCoord(e,t){if(1===e)return\"\"+t;if(2===e)return t+\".y\";if(3===e)return t+\".z\";if(4===e)return t+\".w\";throw Error(\"Cumulative sum for rank \"+e+\" is not yet supported\")}var TextureUsage,PhysicalTextureType,EncodeFloatProgram=function(){return function(e){this.variableNames=[\"A\"],this.outputShape=e,this.userCode=\"\\n const float FLOAT_MAX = 1.70141184e38;\\n const float FLOAT_MIN = 1.17549435e-38;\\n\\n lowp vec4 encode_float(highp float v) {\\n if (isNaN(v)) {\\n return vec4(255, 255, 255, 255);\\n }\\n\\n highp float av = abs(v);\\n\\n if(av < FLOAT_MIN) {\\n return vec4(0.0, 0.0, 0.0, 0.0);\\n } else if(v > FLOAT_MAX) {\\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\\n } else if(v < -FLOAT_MAX) {\\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\\n }\\n\\n highp vec4 c = vec4(0,0,0,0);\\n\\n highp float e = floor(log2(av));\\n highp float m = exp2(fract(log2(av))) - 1.0;\\n\\n c[2] = floor(128.0 * m);\\n m -= c[2] / 128.0;\\n c[1] = floor(32768.0 * m);\\n m -= c[1] / 32768.0;\\n c[0] = floor(8388608.0 * m);\\n\\n highp float ebias = e + 127.0;\\n c[3] = floor(ebias / 2.0);\\n ebias -= c[3] * 2.0;\\n c[2] += floor(ebias) * 128.0;\\n\\n c[3] += 128.0 * step(0.0, -v);\\n\\n return c / 255.0;\\n }\\n\\n void main() {\\n float x = getAAtOutCoords();\\n gl_FragColor = encode_float(x);\\n }\\n \"}}(),FromPixelsProgram=function(){return function(e){this.variableNames=[\"A\"];var t=e[0],n=e[1];this.outputShape=e,this.userCode=\"\\n void main() {\\n ivec3 coords = getOutputCoords();\\n int texR = coords[0];\\n int texC = coords[1];\\n int depth = coords[2];\\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(\"+n+\".0, \"+t+\".0);\\n\\n vec4 values = texture2D(A, uv);\\n float value;\\n if (depth == 0) {\\n value = values.r;\\n } else if (depth == 1) {\\n value = values.g;\\n } else if (depth == 2) {\\n value = values.b;\\n } else if (depth == 3) {\\n value = values.a;\\n }\\n\\n setOutput(floor(value * 255.0 + 0.5));\\n }\\n \"}}(),GatherProgram=function(){return function(e,t,n){this.variableNames=[\"A\",\"indices\"];var r=e.slice();r[n]=t,this.outputShape=r,this.rank=r.length;var o=getCoordsDataType(this.rank),a=getSourceCoords(e,n);this.userCode=\"\\n void main() {\\n \"+o+\" resRC = getOutputCoords();\\n setOutput(getA(\"+a+\"));\\n }\\n \"}}();function getSourceCoords(e,t){var n=e.length;if(n>4)throw Error(\"Gather for rank \"+n+\" is not yet supported\");if(1===n)return\"int(getIndices(resRC))\";for(var r=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\"],o=[],a=0;a= \"+r);for(var o=0,a=0;a= \"+r);for(var o=0,a=0;a= \"+o);for(var a=getPackedMatrixTextureShapeWidthHeight(t,n),i=a[0],s=a[1],u=n%2==1,l=t%2==1,c=Math.floor(n/2),p=Math.floor(t/2),d=u?4:0,h=n,f=0,m=0;m= \"+o);for(var a=n%2==1,i=t%2==1,s=Math.floor(n/2),u=Math.floor(t/2),l=getPackedMatrixTextureShapeWidthHeight(t,n),c=l[0],p=l[1],d=a?4:0,h=n+(a?1:0),f=0,m=0,g=n,v=0;vr||n>r){o=\"[\"+t+\"x\"+n+\"]\";throw new Error(\"Requested texture size \"+o+\" greater than WebGL maximum on this browser / GPU \"+(\"[\"+r+\"x\"+r+\"]\")+\".\")}}function createFramebuffer(e){return throwIfNull(e,function(){return e.createFramebuffer()},\"Unable to create WebGLFramebuffer.\")}function bindVertexBufferToProgramAttribute(e,t,n,r,o,a,i){var s=e.getAttribLocation(t,n);return-1!==s&&(callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,r)}),callAndCheck(e,function(){return e.vertexAttribPointer(s,o,e.FLOAT,!1,a,i)}),callAndCheck(e,function(){return e.enableVertexAttribArray(s)}),!0)}function bindTextureUnit(e,t,n){validateTextureUnit(e,n),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)})}function unbindTextureUnit(e,t){validateTextureUnit(e,t),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+t)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function getProgramUniformLocationOrThrow(e,t,n){return throwIfNull(e,function(){return e.getUniformLocation(t,n)},'uniform \"'+n+'\" not present in program.')}function getProgramUniformLocation(e,t,n){return e.getUniformLocation(t,n)}function bindTextureToProgramUniformSampler(e,t,n,r,o){callAndCheck(e,function(){return bindTextureUnit(e,n,o)}),callAndCheck(e,function(){return e.uniform1i(r,o)})}function bindCanvasToFramebuffer(e){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,null)}),callAndCheck(e,function(){return e.viewport(0,0,e.canvas.width,e.canvas.height)}),callAndCheck(e,function(){return e.scissor(0,0,e.canvas.width,e.canvas.height)})}function bindColorTextureToFramebuffer(e,t,n){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,n)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0)})}function unbindColorTextureFromFramebuffer(e,t){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,t)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0)})}function validateFramebuffer(e){var t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error(\"Error binding framebuffer: \"+getFramebufferErrorMessage(e,t))}function getFramebufferErrorMessage(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return\"FRAMEBUFFER_INCOMPLETE_ATTACHMENT\";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return\"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return\"FRAMEBUFFER_INCOMPLETE_DIMENSIONS\";case e.FRAMEBUFFER_UNSUPPORTED:return\"FRAMEBUFFER_UNSUPPORTED\";default:return\"unknown error \"+t}}function throwIfNull(e,t,n){var r=callAndCheck(e,function(){return t()});if(null==r)throw new Error(n);return r}function validateTextureUnit(e,t){var n=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,r=t+e.TEXTURE0;if(rn)throw new Error(\"textureUnit must be in \"+(\"[gl.TEXTURE0, gl.TEXTURE\"+n+\"]\")+\".\")}function getTextureShapeFromLogicalShape(e,t){2!==t.length&&(t=squeezeShape(t).newShape);var n=queryMaxTextureSize(e),r=sizeFromShape(t);return t.length<=1&&r<=n?[r,1]:2===t.length&&t[0]<=n&&t[1]<=n?t:3===t.length&&t[0]<=n&&t[1]*t[2]<=n?[t[0],t[1]*t[2]]:4===t.length&&t[0]<=n&&t[1]*t[2]*t[3]<=n?[t[0],t[1]*t[2]*t[3]]:sizeToSquarishShape(r)}var webgl_util=Object.freeze({createWebGLRenderingContext:createWebGLRenderingContext,createWebGLRenderingContextFromCanvas:createWebGLRenderingContextFromCanvas,callAndCheck:callAndCheck,enableDebugWebGLErrorChecking:enableDebugWebGLErrorChecking,checkWebGLError:checkWebGLError,getWebGLErrorMessage:getWebGLErrorMessage,getExtensionOrThrow:getExtensionOrThrow,createVertexShader:createVertexShader,createFragmentShader:createFragmentShader,createProgram:createProgram,linkProgram:linkProgram,validateProgram:validateProgram,createStaticVertexBuffer:createStaticVertexBuffer,createStaticIndexBuffer:createStaticIndexBuffer,queryMaxTextureSize:queryMaxTextureSize,getNumChannels:getNumChannels,createTexture:createTexture,validateTextureSize:validateTextureSize,createFramebuffer:createFramebuffer,bindVertexBufferToProgramAttribute:bindVertexBufferToProgramAttribute,bindTextureUnit:bindTextureUnit,unbindTextureUnit:unbindTextureUnit,getProgramUniformLocationOrThrow:getProgramUniformLocationOrThrow,getProgramUniformLocation:getProgramUniformLocation,bindTextureToProgramUniformSampler:bindTextureToProgramUniformSampler,bindCanvasToFramebuffer:bindCanvasToFramebuffer,bindColorTextureToFramebuffer:bindColorTextureToFramebuffer,unbindColorTextureFromFramebuffer:unbindColorTextureFromFramebuffer,validateFramebuffer:validateFramebuffer,getFramebufferErrorMessage:getFramebufferErrorMessage,getTextureShapeFromLogicalShape:getTextureShapeFromLogicalShape});function getWebGLContextAttributes(){return{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0}}function createWebGLContext(e){var t,n=getWebGLContextAttributes();return callAndCheck(t=null!=e?createWebGLRenderingContextFromCanvas(e,n):createWebGLRenderingContext(n),function(){return t.disable(t.DEPTH_TEST)}),callAndCheck(t,function(){return t.disable(t.STENCIL_TEST)}),callAndCheck(t,function(){return t.disable(t.BLEND)}),callAndCheck(t,function(){return t.disable(t.DITHER)}),callAndCheck(t,function(){return t.disable(t.POLYGON_OFFSET_FILL)}),callAndCheck(t,function(){return t.disable(t.SAMPLE_COVERAGE)}),callAndCheck(t,function(){return t.enable(t.SCISSOR_TEST)}),callAndCheck(t,function(){return t.enable(t.CULL_FACE)}),callAndCheck(t,function(){return t.cullFace(t.BACK)}),t}function createVertexShader$1(e){return createVertexShader(e,\"\\n precision highp float;\\n attribute vec3 clipSpacePos;\\n attribute vec2 uv;\\n varying vec2 resultUV;\\n\\n void main() {\\n gl_Position = vec4(clipSpacePos, 1);\\n resultUV = uv;\\n }\")}function createVertexBuffer(e){return createStaticVertexBuffer(e,new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]))}function createIndexBuffer(e){return createStaticIndexBuffer(e,new Uint16Array([0,1,2,2,1,3]))}function getTextureConfig(e,t){var n,r,o,a,i,s,u,l=e;return 2===ENV.get(\"WEBGL_VERSION\")?(n=l.R32F,r=l.R16F,o=l.RGBA32F,a=l.RED,i=4,s=1,u=l.HALF_FLOAT):(n=e.RGBA,r=e.RGBA,o=l.RGBA,a=e.RGBA,i=4,s=4,u=null!=t?t.HALF_FLOAT_OES:null),{internalFormatFloat:n,internalFormatHalfFloat:r,internalFormatPackedFloat:o,textureFormatFloat:a,downloadTextureFormat:e.RGBA,downloadUnpackNumChannels:i,defaultNumChannels:s,textureTypeHalfFloat:u}}function createAndConfigureTexture(e,t,n,r,o,a){validateTextureSize(e,t,n);var i=createTexture(e),s=e.TEXTURE_2D;return callAndCheck(e,function(){return e.bindTexture(s,i)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MIN_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MAG_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texImage2D(s,0,r,t,n,0,o,a,null)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)}),i}function createFloat32MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,e.FLOAT)}function createFloat16MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,r.textureTypeHalfFloat)}function createUnsignedBytesMatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],e.RGBA,e.RGBA,e.UNSIGNED_BYTE)}function createPackedMatrixTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatPackedFloat,e.RGBA,e.FLOAT)}function bindVertexProgramAttributeStreams(e,t,n){return callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,n)}),bindVertexBufferToProgramAttribute(e,t,\"clipSpacePos\",n,3,20,0)&&bindVertexBufferToProgramAttribute(e,t,\"uv\",n,2,20,12)}function uploadPixelDataToTexture(e,t,n){callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadDataToTexture(e,t,n,r,o,a){validateTextureSize(e,n,r),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texSubImage2D(e.TEXTURE_2D,0,0,0,n,r,a,e.FLOAT,o)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadMatrixToTexture(e,t,n,r,o,a,i){var s,u=getUnpackedMatrixTextureShapeWidthHeight(n,r),l=u[0],c=u[1];1===i.defaultNumChannels?s=o:encodeMatrixToUnpackedArray(o,s=new Float32Array(getUnpackedArraySizeFromMatrixSize(o.length,a)),a),uploadDataToTexture(e,t,l,c,s,i.textureFormatFloat)}function uploadMatrixToPackedTexture(e,t,n,r,o,a){var i=getPackedMatrixTextureShapeWidthHeight(n,r),s=i[0],u=i[1],l=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(n,r));encodeMatrixToPackedRGBA(o,n,r,l),uploadDataToTexture(e,t,s,u,l,e.RGBA)}function maybeCreateBufferFromOutputTexture(e,t,n,r,o){var a=t;if(2===ENV.get(\"WEBGL_VERSION\")){var i=e,s=i.createBuffer();callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,s)});var u=4*getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels);callAndCheck(e,function(){return e.bufferData(i.PIXEL_PACK_BUFFER,u,e.STATIC_DRAW)}),callAndCheck(e,function(){return i.readPixels(0,0,r,n,e.RGBA,e.FLOAT,0)}),callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,null)}),a=s}return a}function downloadFloat32MatrixFromBuffer(e,t,n,r,o){var a=e,i=new Float32Array(getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels));a.bindBuffer(e.ARRAY_BUFFER,t),a.getBufferSubData(e.ARRAY_BUFFER,0,i),a.bindBuffer(e.ARRAY_BUFFER,null);var s=new Float32Array(n*r);return decodeMatrixFromUnpackedArray(i,s,o.downloadUnpackNumChannels),s}function downloadFloat32MatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getUnpackedArraySizeFromMatrixSize(t*n,r.downloadUnpackNumChannels));callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromUnpackedArray(s,u,r.downloadUnpackNumChannels),u}function downloadByteEncodedFloatMatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Uint8Array(getUnpackedArraySizeFromMatrixSize(t*n,4));return callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.UNSIGNED_BYTE,s)}),new Float32Array(s.buffer)}function downloadMatrixFromPackedOutputTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(t,n));callAndCheck(e,function(){return e.readPixels(0,0,a,i,e.RGBA,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromPackedRGBA(s,t,n,u)}var gpgpu_util=Object.freeze({getWebGLContextAttributes:getWebGLContextAttributes,createWebGLContext:createWebGLContext,createVertexShader:createVertexShader$1,createVertexBuffer:createVertexBuffer,createIndexBuffer:createIndexBuffer,getTextureConfig:getTextureConfig,createFloat32MatrixTexture:createFloat32MatrixTexture,createFloat16MatrixTexture:createFloat16MatrixTexture,createUnsignedBytesMatrixTexture:createUnsignedBytesMatrixTexture,createPackedMatrixTexture:createPackedMatrixTexture,bindVertexProgramAttributeStreams:bindVertexProgramAttributeStreams,uploadPixelDataToTexture:uploadPixelDataToTexture,uploadMatrixToTexture:uploadMatrixToTexture,uploadMatrixToPackedTexture:uploadMatrixToPackedTexture,maybeCreateBufferFromOutputTexture:maybeCreateBufferFromOutputTexture,downloadFloat32MatrixFromBuffer:downloadFloat32MatrixFromBuffer,downloadFloat32MatrixFromOutputTexture:downloadFloat32MatrixFromOutputTexture,downloadByteEncodedFloatMatrixFromOutputTexture:downloadByteEncodedFloatMatrixFromOutputTexture,downloadMatrixFromPackedOutputTexture:downloadMatrixFromPackedOutputTexture}),GPGPUContext=function(){function e(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.autoDebugValidate=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[],this.gl=null!=e?e:createWebGLContext(),1===ENV.get(\"WEBGL_VERSION\")?(this.textureFloatExtension=getExtensionOrThrow(this.gl,\"OES_texture_float\"),this.colorBufferFloatExtension=this.gl.getExtension(\"WEBGL_color_buffer_float\"),ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")||(this.textureHalfFloatExtension=getExtensionOrThrow(this.gl,\"OES_texture_half_float\"),this.colorBufferHalfFloatExtension=this.gl.getExtension(\"EXT_color_buffer_half_float\"))):this.colorBufferFloatExtension=getExtensionOrThrow(this.gl,\"EXT_color_buffer_float\"),this.loseContextExtension=getExtensionOrThrow(this.gl,\"WEBGL_lose_context\"),this.vertexBuffer=createVertexBuffer(this.gl),this.indexBuffer=createIndexBuffer(this.gl),this.framebuffer=createFramebuffer(this.gl),this.textureConfig=getTextureConfig(this.gl,this.textureHalfFloatExtension)}return e.prototype.dispose=function(){var e=this;if(!this.disposed){null!=this.program&&console.warn(\"Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing.\"),null!=this.outputTexture&&console.warn(\"Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.\");var t=this.gl;callAndCheck(t,function(){return t.finish()}),callAndCheck(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,null)}),callAndCheck(t,function(){return t.deleteFramebuffer(e.framebuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.vertexBuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.indexBuffer)}),this.loseContextExtension.loseContext(),this.disposed=!0}},e.prototype.enableAutomaticDebugValidation=function(e){this.autoDebugValidate=e,enableDebugWebGLErrorChecking(e)},e.prototype.createFloat32MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat32MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createFloat16MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat16MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createUnsignedBytesMatrixTexture=function(e,t){return this.throwIfDisposed(),createUnsignedBytesMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.uploadPixelDataToTexture=function(e,t){this.throwIfDisposed(),uploadPixelDataToTexture(this.gl,e,t)},e.prototype.createPackedMatrixTexture=function(e,t){return this.throwIfDisposed(),createPackedMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.deleteMatrixTexture=function(e){var t=this;this.throwIfDisposed(),this.outputTexture===e&&(unbindColorTextureFromFramebuffer(this.gl,this.framebuffer),this.outputTexture=null),callAndCheck(this.gl,function(){return t.gl.deleteTexture(e)})},e.prototype.uploadMatrixToTexture=function(e,t,n,r){this.throwIfDisposed();var o=getNumChannels();return uploadMatrixToTexture(this.gl,e,t,n,r,o,this.textureConfig)},e.prototype.uploadMatrixToPackedTexture=function(e,t,n,r){return this.throwIfDisposed(),uploadMatrixToPackedTexture(this.gl,e,t,n,r,this.textureConfig)},e.prototype.downloadFloat32MatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadFloat32MatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadByteEncodedFloatMatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadByteEncodedFloatMatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadFloat32MatrixFromBuffer=function(e,t,n){return downloadFloat32MatrixFromBuffer(this.gl,e,t,n,this.textureConfig)},e.prototype.maybeCreateBufferFromTexture=function(e,t,n){this.bindTextureToFrameBuffer(e);var r=maybeCreateBufferFromOutputTexture(this.gl,e,t,n,this.textureConfig);return this.unbindTextureToFrameBuffer(),r},e.prototype.createAndWaitForFence=function(){var e=this.createFence(this.gl);return this.pollFence(e)},e.prototype.createFence=function(e){var t,n,r=this;if(ENV.get(\"WEBGL_FENCE_API_ENABLED\")){var o=e,a=o.fenceSync(o.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),n=function(){var e=o.clientWaitSync(a,0,0);return e===o.ALREADY_SIGNALED||e===o.CONDITION_SATISFIED},t=a}else ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?(t=this.beginQuery(),this.endQuery(),n=function(){return r.isQueryAvailable(t,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))}):n=function(){return!0};return{query:t,isFencePassed:n}},e.prototype.downloadMatrixFromPackedTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadMatrixFromPackedOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.createProgram=function(e){this.throwIfDisposed();var t=this.gl,n=createFragmentShader(t,e),r=createVertexShader$1(t),o=createProgram(t);return callAndCheck(t,function(){return t.attachShader(o,r)}),callAndCheck(t,function(){return t.attachShader(o,n)}),linkProgram(t,o),this.autoDebugValidate&&validateProgram(t,o),this.vertexAttrsAreBound||(this.setProgram(o),this.vertexAttrsAreBound=bindVertexProgramAttributeStreams(t,this.program,this.vertexBuffer)),o},e.prototype.deleteProgram=function(e){var t=this;this.throwIfDisposed(),e===this.program&&(this.program=null),null!=e&&callAndCheck(this.gl,function(){return t.gl.deleteProgram(e)})},e.prototype.setProgram=function(e){var t=this;this.throwIfDisposed(),this.program=e,null!=this.program&&this.autoDebugValidate&&validateProgram(this.gl,this.program),callAndCheck(this.gl,function(){return t.gl.useProgram(e)})},e.prototype.getUniformLocation=function(e,t,n){return void 0===n&&(n=!0),this.throwIfDisposed(),n?getProgramUniformLocationOrThrow(this.gl,e,t):getProgramUniformLocation(this.gl,e,t)},e.prototype.getAttributeLocation=function(e,t){var n=this;return this.throwIfDisposed(),callAndCheck(this.gl,function(){return n.gl.getAttribLocation(e,t)})},e.prototype.getUniformLocationNoThrow=function(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)},e.prototype.setInputMatrixTexture=function(e,t,n){this.throwIfDisposed(),this.throwIfNoProgram(),bindTextureToProgramUniformSampler(this.gl,this.program,e,t,n)},e.prototype.setOutputMatrixTexture=function(e,t,n){this.setOutputMatrixTextureDriver(e,n,t)},e.prototype.setOutputPackedMatrixTexture=function(e,t,n){this.throwIfDisposed();var r=getPackedMatrixTextureShapeWidthHeight(t,n),o=r[0],a=r[1];this.setOutputMatrixTextureDriver(e,o,a)},e.prototype.setOutputMatrixWriteRegion=function(e,t,n,r){this.setOutputMatrixWriteRegionDriver(n,e,r,t)},e.prototype.setOutputPackedMatrixWriteRegion=function(e,t,n,r){throw new Error(\"setOutputPackedMatrixWriteRegion not implemented.\")},e.prototype.debugValidate=function(){null!=this.program&&validateProgram(this.gl,this.program),validateFramebuffer(this.gl)},e.prototype.executeProgram=function(){this.throwIfDisposed(),this.throwIfNoProgram();var e=this.gl;this.autoDebugValidate&&this.debugValidate(),callAndCheck(e,function(){return e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)})},e.prototype.blockUntilAllProgramsCompleted=function(){var e=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return e.gl.finish()})},e.prototype.getQueryTimerExtension=function(){return null==this.disjointQueryTimerExtension&&(this.disjointQueryTimerExtension=getExtensionOrThrow(this.gl,2===ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")?\"EXT_disjoint_timer_query_webgl2\":\"EXT_disjoint_timer_query\")),this.disjointQueryTimerExtension},e.prototype.getQueryTimerExtensionWebGL2=function(){return this.getQueryTimerExtension()},e.prototype.getQueryTimerExtensionWebGL1=function(){return this.getQueryTimerExtension()},e.prototype.beginQuery=function(){if(2===ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")){var e=this.gl,t=this.getQueryTimerExtensionWebGL2(),n=e.createQuery();return e.beginQuery(t.TIME_ELAPSED_EXT,n),n}var r=this.getQueryTimerExtensionWebGL1(),o=r.createQueryEXT();return r.beginQueryEXT(r.TIME_ELAPSED_EXT,o),o},e.prototype.endQuery=function(){if(2!==ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")){var e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}else{var t=this.gl,n=this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT)}},e.prototype.waitForQueryAndGetTime=function(e){return __awaiter(this,void 0,void 0,function(){var t=this;return __generator(this,function(n){switch(n.label){case 0:return[4,repeatedTry(function(){return t.isQueryAvailable(e,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))})];case 1:return n.sent(),[2,this.getQueryTime(e,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))]}})})},e.prototype.getQueryTime=function(e,t){if(0===t)return null;if(2===t){var n=this.gl;return n.getQueryParameter(e,n.QUERY_RESULT)/1e6}var r=this.getQueryTimerExtensionWebGL1();return r.getQueryObjectEXT(e,r.QUERY_RESULT_EXT)/1e6},e.prototype.isQueryAvailable=function(e,t){if(0===t)return!0;if(2===t){var n=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=n.getQueryParameter(e,n.QUERY_RESULT_AVAILABLE);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}o=(r=this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(e,r.QUERY_RESULT_AVAILABLE_EXT);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint},e.prototype.pollFence=function(e){var t=this;return new Promise(function(n){t.addItemToPoll(function(){return e.isFencePassed()},function(){return n()})})},e.prototype.pollItems=function(){for(var e=binSearchLastTrue(this.itemsToPoll.map(function(e){return e.isDoneFn})),t=0;t<=e;++t){(0,this.itemsToPoll[t].resolveFn)()}this.itemsToPoll=this.itemsToPoll.slice(e+1)},e.prototype.addItemToPoll=function(e,t){var n=this;this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),this.itemsToPoll.length>1||repeatedTry(function(){return n.pollItems(),0===n.itemsToPoll.length})},e.prototype.bindTextureToFrameBuffer=function(e){this.throwIfDisposed(),bindColorTextureToFramebuffer(this.gl,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)},e.prototype.unbindTextureToFrameBuffer=function(){null!=this.outputTexture?(bindColorTextureToFramebuffer(this.gl,this.outputTexture,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)):unbindColorTextureFromFramebuffer(this.gl,this.framebuffer)},e.prototype.downloadMatrixDriver=function(e,t){this.bindTextureToFrameBuffer(e);var n=t();return this.unbindTextureToFrameBuffer(),n},e.prototype.setOutputMatrixTextureDriver=function(e,t,n){this.throwIfDisposed();var r=this.gl;bindColorTextureToFramebuffer(r,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(r),this.outputTexture=e,callAndCheck(r,function(){return r.viewport(0,0,t,n)}),callAndCheck(r,function(){return r.scissor(0,0,t,n)})},e.prototype.setOutputMatrixWriteRegionDriver=function(e,t,n,r){var o=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return o.gl.scissor(e,t,n,r)})},e.prototype.throwIfDisposed=function(){if(this.disposed)throw new Error(\"Attempted to use disposed GPGPUContext.\")},e.prototype.throwIfNoProgram=function(){if(null==this.program)throw new Error(\"No GPU program is currently set.\")},e}();function binSearchLastTrue(e){for(var t=0,n=e.length-1,r=-1;t<=n;){var o=t+n>>1;e[o]()?(r=o,t=o+1):n=o-1}return r}function compileProgram(e,t,n,r){for(var o=t.userCode,a=n.map(function(e,n){var r={logicalShape:e.tensor.shape,texShape:e.isUniform?null:e.texData.texShape,isUniform:e.isUniform};return{name:t.variableNames[n],shapeInfo:r}}),i=a.map(function(e){return e.shapeInfo}),s={logicalShape:r.tensor.shape,texShape:r.texData.texShape,isUniform:!1},u=makeShader(a,s,o,!0===t.supportsBroadcasting),l=e.createProgram(u),c={},p=0;p= 0 && idx <= \"+s+\") {\\n float z = getX(b, r, c, idx);\\n sum += z * z;\\n }\\n }\\n float val = x * \"+a+\";\\n setOutput(val);\\n }\\n \"}}(),LRNGradProgram=function(){return function(e,t,n,r,o){this.variableNames=[\"inputImage\",\"outputImage\",\"dy\"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=t,this.bias=n,this.alpha=r,this.beta=o,this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float result = 0.0;\\n for (int d = 0; d < \"+this.depth+\"; ++d) {\\n int depthBegin = int(max(0.0, float(d - \"+t+\")));\\n int depthEnd = int(min(float(\"+this.depth+\"),\\n float(d + \"+t+\" + 1)));\\n\\n const int MIN_DEPTH_BEGIN = 0;\\n const int MAX_DEPTH_END = \"+this.depth+\";\\n\\n float norm = 0.0;\\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\\n if (k < depthBegin){\\n continue;\\n }\\n else if (k >= depthBegin && k < depthEnd) {\\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\\n }\\n else {\\n break;\\n }\\n }\\n\\n norm = float(\"+r+\") * norm + float(\"+n+\");\\n\\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\\n if (k < depthBegin){\\n continue;\\n }\\n else if (k >= depthBegin && k < depthEnd){\\n float dyi = -2.0 * float(\"+r+\")\\n * float(\"+o+\")\\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\\n / norm;\\n if (k == d) {\\n dyi += pow(norm, -1.0 * \"+o+\");\\n }\\n if (k == coords[3]) {\\n dyi *= getDy(b, r, c, d);\\n result += dyi;\\n }\\n }\\n else {\\n break;\\n }\\n }\\n }\\n setOutput(result);\\n }\\n \"}}(),MaxPool2DBackpropProgram=function(){return function(e){this.variableNames=[\"dy\",\"maxPos\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=t*n-1;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n\\n ivec2 dyRCCorner = coords.yz - pads;\\n int dyRCorner = dyRCCorner.x;\\n int dyCCorner = dyRCCorner.y;\\n\\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n float dyValue = getDy(b, idyR, idyC, d);\\n int maxPosValue = \"+s+\" - int(getMaxPos(b, idyR, idyC, d));\\n\\n // Get the current value, check it against the value from the\\n // position matrix.\\n int curPosValue = wR * \"+n+\" + wC;\\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\\n\\n dotProd += dyValue * mask;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),MatMulProgram=function(){return function(e,t,n,r){void 0===n&&(n=!1),void 0===r&&(r=!1),this.variableNames=[\"matrixA\",\"matrixB\"];var o=n?e[1]:e[0],a=r?t[0]:t[1],i=n?e[0]:e[1];this.outputShape=[o,a];var s=function(e,t){return n?t+\" + \"+e+\", aRow\":\"aRow, \"+t+\" + \"+e},u=function(e,t){return r?\"bCol, \"+t+\" + \"+e:t+\" + \"+e+\", bCol\"},l=4*Math.floor(i/4),c=i%4;this.userCode=\" float dotARowBCol(int aRow, int bCol) {\\n float result = 0.0;\\n for (int i = 0; i < \"+l+\"; i += 4) {\\n vec4 a = vec4(\\n getMatrixA(\"+s(0,\"i\")+\"),\\n getMatrixA(\"+s(1,\"i\")+\"),\\n getMatrixA(\"+s(2,\"i\")+\"),\\n getMatrixA(\"+s(3,\"i\")+\")\\n );\\n vec4 b = vec4(\\n getMatrixB(\"+u(0,\"i\")+\"),\\n getMatrixB(\"+u(1,\"i\")+\"),\\n getMatrixB(\"+u(2,\"i\")+\"),\\n getMatrixB(\"+u(3,\"i\")+\")\\n );\\n\\n result += dot(a, b);\\n }\\n\\n if (\"+(1===c)+\") {\\n result += getMatrixA(\"+s(0,l)+\") *\\n getMatrixB(\"+u(0,l)+\");\\n } else if (\"+(2===c)+\") {\\n vec2 a = vec2(\\n getMatrixA(\"+s(0,l)+\"),\\n getMatrixA(\"+s(1,l)+\")\\n );\\n vec2 b = vec2(\\n getMatrixB(\"+u(0,l)+\"),\\n getMatrixB(\"+u(1,l)+\")\\n );\\n result += dot(a, b);\\n } else if (\"+(3===c)+\") {\\n vec3 a = vec3(\\n getMatrixA(\"+s(0,l)+\"),\\n getMatrixA(\"+s(1,l)+\"),\\n getMatrixA(\"+s(2,l)+\")\\n );\\n vec3 b = vec3(\\n getMatrixB(\"+u(0,l)+\"),\\n getMatrixB(\"+u(1,l)+\"),\\n getMatrixB(\"+u(2,l)+\")\\n );\\n result += dot(a, b);\\n }\\n\\n return result;\\n }\\n\\n void main() {\\n ivec2 resRC = getOutputCoords();\\n setOutput(dotARowBCol(resRC.x, resRC.y));\\n }\\n \"}}(),MultinomialProgram=function(){function e(e,t,n){this.variableNames=[\"probs\"],this.outputShape=[e,n],this.userCode=\"\\n uniform float seed;\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n\\n float r = random(seed);\\n float cdf = 0.0;\\n\\n for (int i = 0; i < \"+(t-1)+\"; i++) {\\n cdf += getProbs(batch, i);\\n\\n if (r < cdf) {\\n setOutput(float(i));\\n return;\\n }\\n }\\n\\n // If no other event happened, last event happened.\\n setOutput(float(\"+(t-1)+\"));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(e){var t=this;return function(n,r){null==t.seedLoc&&(t.seedLoc=n.getUniformLocation(r,\"seed\")),n.gl.uniform1f(t.seedLoc,e)}},e}(),OneHotProgram=function(){return function(e,t,n,r){this.variableNames=[\"indices\"],this.outputShape=[e,t],this.userCode=\"\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int index = round(getIndices(coords.x));\\n setOutput(mix(float(\"+r+\"), float(\"+n+\"),\\n float(index == coords.y)));\\n }\\n \"}}(),PadProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=t.map(function(t,n){return t[0]+e[n]+t[1]});var r=e.length,o=getCoordsDataType(r),a=t.map(function(e){return e[0]}).join(\",\"),i=t.map(function(t,n){return t[0]+e[n]}).join(\",\"),s=[\"coords[0]\",\"coords[1]\",\"coords[2]\",\"coords[3]\"].slice(0,r);this.userCode=1!==r?\"\\n \"+o+\" start = \"+o+\"(\"+a+\");\\n \"+o+\" end = \"+o+\"(\"+i+\");\\n\\n void main() {\\n \"+o+\" outC = getOutputCoords();\\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\\n setOutput(float(\"+n+\"));\\n } else {\\n \"+o+\" coords = outC - start;\\n setOutput(getX(\"+s+\"));\\n }\\n }\\n \":\"\\n int start = \"+a+\";\\n int end = \"+i+\";\\n\\n void main() {\\n int outC = getOutputCoords();\\n if (outC < start || outC >= end) {\\n setOutput(float(\"+n+\"));\\n } else {\\n setOutput(getX(outC - start));\\n }\\n }\\n \"}}(),Pool2DProgram=function(){return function(e,t,n){if(this.variableNames=[\"x\"],\"avg\"===t&&n)throw new Error(\"Cannot compute positions for average pool.\");var r=e.filterHeight,o=e.filterWidth,a=e.strideHeight,i=e.strideWidth,s=e.padInfo.top,u=e.padInfo.left;this.outputShape=e.outShape;var l=\"avg\"===t,c=\"0.0\";if(l||(c=\"-1.0 / 0.0\"),n)this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+s+\", \"+u+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // max/min x(?, ?, d) to get y(yR, yC, d).\\n // ? = to be determined\\n float minMaxValue = 0.0;\\n float minMaxValueFound = 0.0;\\n int minMaxPosition = 0;\\n float avgValue = 0.0;\\n\\n for (int wR = 0; wR < \"+r+\"; wR++) {\\n int xR = xRCorner + wR;\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+o+\"; wC++) {\\n int xC = xCCorner + wC;\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float value = getX(batch, xR, xC, d);\\n\\n // If a min / max value has already been found, use it. If not,\\n // use the current value.\\n float currMinMaxValue = mix(\\n value, minMaxValue, minMaxValueFound);\\n if (value >= currMinMaxValue) {\\n minMaxValue = value;\\n minMaxValueFound = 1.0;\\n minMaxPosition = wR * \"+o+\" + wC;\\n }\\n }\\n }\\n setOutput(float(minMaxPosition));\\n }\\n \";else{var p=t+\"(\"+t+\"(\"+t+\"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])\";\"avg\"===t&&(p=\"avgValue / count\");var d=4*Math.floor(o/4),h=o%4,f=\"\\n if (\"+l+\") {\\n avgValue += dot(values, ones);\\n } else {\\n minMaxValue = max(values, minMaxValue);\\n }\\n \";this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+s+\", \"+u+\");\\n const float initializationValue = \"+c+\";\\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\\n\\n float count = 0.0;\\n\\n float getValue(int batch, int xR, int xC, int d) {\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n return initializationValue;\\n }\\n count += 1.0;\\n return getX(batch, xR, xC, d);\\n }\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // max/min x(?, ?, d) to get y(yR, yC, d).\\n // ? = to be determined\\n vec4 minMaxValue = vec4(\"+c+\");\\n float avgValue = 0.0;\\n count = 0.0;\\n\\n for (int wR = 0; wR < \"+r+\"; wR++) {\\n int xR = xRCorner + wR;\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+d+\"; wC += 4) {\\n int xC = xCCorner + wC;\\n\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n getValue(batch, xR, xC + 2, d),\\n getValue(batch, xR, xC + 3, d)\\n );\\n\\n \"+f+\"\\n }\\n\\n int xC = xCCorner + \"+d+\";\\n if (\"+(1===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+f+\"\\n } else if (\"+(2===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+f+\"\\n } else if (\"+(3===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n getValue(batch, xR, xC + 2, d),\\n initializationValue\\n );\\n\\n \"+f+\"\\n }\\n }\\n setOutput(\"+p+\");\\n }\\n \"}}}(),ReduceProgram=function(){return function(e,t){this.variableNames=[\"x\"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=Math.ceil(o/n);this.outputShape=[r,a];var i=\"0.0\",s=\"\";\"min\"===t?(i=\"1.0 / 0.0\",s=\"min\"):\"max\"===t&&(i=\"-1.0 / 0.0\",s=\"max\");var u=t+\"(\"+t+\"(\"+t+\"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])\";\"sum\"===t?u=\"sumValue\":\"all\"===t?u=\"allValue\":\"any\"===t&&(u=\"anyValue\");var l=4*Math.floor(n/4),c=n%4,p=\"\\n if (\"+(\"sum\"===t)+\") {\\n sumValue += dot(values, ones);\\n } else {\\n minMaxValue = \"+s+\"(values, minMaxValue);\\n }\\n \",d=\"vec4\";\"all\"===t?(i=\"1.0\",p=\"\\n bool reducedAllValue = all(values);\\n float floatedReducedAllValue = float(reducedAllValue);\\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\\n \",d=\"bvec4\"):\"any\"===t&&(i=\"0.0\",p=\"\\n bool reducedAnyValue = any(values);\\n float floatedReducedAnyValue = float(reducedAnyValue);\\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\\n \",d=\"bvec4\");var h=\"\";o%n>0&&(h=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return initializationValue;\\n }\\n \"),this.userCode=\"\\n const float initializationValue = \"+i+\";\\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\\n\\n float getValue(int batch, int inIdx) {\\n \"+h+\"\\n return getX(batch, inIdx);\\n }\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = outIdx * \"+n+\";\\n\\n vec4 minMaxValue = vec4(\"+i+\");\\n float sumValue = 0.0;\\n float allValue = 1.0;\\n float anyValue = 0.0;\\n\\n for (int i = 0; i < \"+l+\"; i += 4) {\\n int inIdx = inOffset + i;\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n getValue(batch, inIdx + 3)\\n );\\n\\n \"+p+\"\\n }\\n\\n int inIdx = inOffset + \"+l+\";\\n if (\"+(1===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+p+\"\\n } else if (\"+(2===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+p+\"\\n } else if (\"+(3===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n initializationValue\\n );\\n\\n \"+p+\"\\n }\\n setOutput(\"+u+\");\\n }\\n \"}}(),ResizeBilinearBackpropProgram=function(){return function(e,t,n){this.variableNames=[\"dy\"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float accumulator = 0.0;\\n\\n const float heightScale = float(\"+p+\");\\n const float widthScale = float(\"+d+\");\\n\\n const float invHeightScale = float(\"+h+\");\\n const float invWidthScale = float(\"+f+\");\\n\\n const int winHeight = int(\"+m+\");\\n const int winWidth = int(\"+g+\");\\n\\n // Compute bounds for where in dy we will look\\n float startRLerp = floor(float(r) * invHeightScale);\\n int startDyR = int(startRLerp - float(winHeight / 2));\\n\\n float startCLerp = floor(float(c) * invWidthScale);\\n int startDyC = int(startCLerp - float(winWidth / 2));\\n\\n // Loop over dy\\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\\n int dyR = dyROffset + startDyR;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyR < 0 || dyR >= \"+s+\") {\\n continue;\\n }\\n\\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\\n int dyC = dyCOffset + startDyC;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyC < 0 || dyC >= \"+u+\") {\\n continue;\\n }\\n\\n float dxR = float(dyR) * heightScale;\\n int topDxRIndex = int(floor(dxR));\\n int bottomDxRIndex = int(min(ceil(dxR), \"+(o-1)+\".0));\\n float dxRLerp = dxR - float(topDxRIndex);\\n float inverseDxRLerp = 1.0 - dxRLerp;\\n\\n float dxC = float(dyC) * widthScale;\\n int leftDxCIndex = int(floor(dxC));\\n int rightDxCIndex = int(min(ceil(dxC), \"+(a-1)+\".0));\\n float dxCLerp = dxC - float(leftDxCIndex);\\n float inverseDxCLerp = 1.0 - dxCLerp;\\n\\n if (r == topDxRIndex && c == leftDxCIndex) {\\n // topLeft\\n accumulator +=\\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\\n }\\n\\n if (r == topDxRIndex && c == rightDxCIndex) {\\n // topRight\\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\\n }\\n\\n if (r == bottomDxRIndex && c == leftDxCIndex) {\\n // bottomLeft\\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\\n }\\n\\n if (r == bottomDxRIndex && c == rightDxCIndex) {\\n // bottomRight\\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\\n }\\n }\\n }\\n // End loop over dy\\n\\n setOutput(accumulator);\\n }\\n \"}}(),ResizeBilinearProgram=function(){return function(e,t,n,r){this.variableNames=[\"A\"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n];this.userCode=\"\\n const vec2 effectiveInputOverOutputRatioRC = vec2(\\n \"+u[0]/l[0]+\",\\n \"+u[1]/l[1]+\");\\n const vec2 inputShapeRC = vec2(\"+a+\".0, \"+i+\".0);\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n ivec2 yRC = coords.yz;\\n\\n // Fractional source index.\\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\\n\\n // Compute the four integer indices.\\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\\n ivec2 sourceCeilRC = ivec2(\\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\\n\\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\\n\\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\\n\\n float top = topLeft + (topRight - topLeft) * fracRC.y;\\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\\n float newValue = top + (bottom - top) * fracRC.x;\\n\\n setOutput(newValue);\\n }\\n \"}}(),ResizeNearestNeigborBackpropProgram=function(){return function(e,t,n){this.variableNames=[\"dy\"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float accumulator = 0.0;\\n\\n const float heightScale = float(\"+p+\");\\n const float widthScale = float(\"+d+\");\\n\\n const float invHeightScale = float(\"+h+\");\\n const float invWidthScale = float(\"+f+\");\\n\\n const int winHeight = int(\"+m+\");\\n const int winWidth = int(\"+g+\");\\n\\n // Compute bounds for where in dy we will look\\n float startRLerp = floor(float(r) * invHeightScale);\\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\\n\\n float startCLerp = floor(float(c) * invWidthScale);\\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\\n\\n // Loop over dy\\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\\n int dyR = dyROffset + startDyR;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyR < 0 || dyR >= \"+s+\") {\\n continue;\\n }\\n\\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\\n int dyC = dyCOffset + startDyC;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyC < 0 || dyC >= \"+u+\") {\\n continue;\\n }\\n\\n float sourceFracRow =\\n float(\"+l[0]+\") *\\n (float(dyR) / float(\"+c[0]+\"));\\n\\n float sourceFracCol =\\n float(\"+l[1]+\") *\\n (float(dyC) / float(\"+c[1]+\"));\\n\\n int sourceNearestRow = int(min(\\n float(int(\"+o+\") - 1),\\n \"+n+\" ? float(round(sourceFracRow)) :\\n float(floor(sourceFracRow))));\\n\\n int sourceNearestCol = int(min(\\n float(int(\"+a+\") - 1),\\n \"+n+\" ? float(round(sourceFracCol)) :\\n float(floor(sourceFracCol))));\\n\\n if (r == sourceNearestRow && c == sourceNearestCol) {\\n accumulator += getDy(b, dyR, dyC, d);\\n }\\n }\\n }\\n // End loop over dy\\n\\n setOutput(accumulator);\\n }\\n \"}}(),ResizeNearestNeighborProgram=function(){return function(e,t,n,r){this.variableNames=[\"A\"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n],c=r?\"0.5\":\"0.0\";this.userCode=\"\\n const vec2 effectiveInputOverOutputRatioRC = vec2(\\n \"+u[0]/l[0]+\",\\n \"+u[1]/l[1]+\");\\n const vec2 inputShapeRC = vec2(\"+a+\".0, \"+i+\".0);\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n ivec2 yRC = coords.yz;\\n\\n // Fractional source index.\\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\\n\\n // Compute the coordinators of nearest neighbor point.\\n ivec2 sourceNearestRC = ivec2(\\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + \"+c+\")));\\n\\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\\n\\n setOutput(newValue);\\n }\\n \"}}(),ReverseProgram=function(){return function(e,t){this.variableNames=[\"x\"];var n=e.length;if(n>4)throw new Error(\"WebGL backend: Reverse of rank-\"+n+\" tensor is not yet supported\");if(this.outputShape=e,1!==n){var r=e.map(function(n,r){return function(n){return-1!==t.indexOf(n)&&1!==e[n]?e[n]+\" - coords[\"+n+\"] - 1\":\"coords[\"+n+\"]\"}(r)}).join(\",\"),o=getCoordsDataType(n);this.userCode=\"\\n void main() {\\n \"+o+\" coords = getOutputCoords();\\n setOutput(getX(\"+r+\"));\\n }\\n \"}else this.userCode=\"\\n void main() {\\n int coord = getOutputCoords();\\n setOutput(getX(\"+e[0]+\" - coord - 1));\\n }\\n \"}}(),SegmentOpProgram=function(){return function(e,t){this.variableNames=[\"x\",\"segmentIds\"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=e.numSegments,i=a*Math.ceil(o/n);this.outputShape=[r,i];var s=4*Math.floor(n/4),u=n%4,l=\"\\n sumValue += dot(values, filter);\\n \",c=\"\";o%n>0&&(c=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return initializationValue;\\n }\\n \");var p=\"\";o%n>0&&(p=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return -1.0;\\n }\\n \"),this.userCode=\"\\n const float initializationValue = 0.0;\\n\\n float getValue(int batch, int inIdx) {\\n \"+c+\"\\n return getX(batch, inIdx);\\n }\\n\\n float getSegmentIdAtIndex(int inIdx) {\\n \"+p+\"\\n return getSegmentIds(inIdx);\\n }\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = int(floor(float(outIdx) / float(\\n \"+a+\")) * float(\"+n+\"));\\n int currentSeg = int(mod(float(outIdx), float(\"+a+\")));\\n\\n float sumValue = 0.0;\\n\\n for (int i = 0; i < \"+s+\"; i += 4) {\\n int inIdx = inOffset + i;\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n getValue(batch, inIdx + 3)\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\\n );\\n\\n \"+l+\"\\n }\\n\\n int inIdx = inOffset + \"+s+\";\\n if (\"+(1===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n 0,\\n 0,\\n 0\\n );\\n\\n \"+l+\"\\n } else if (\"+(2===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n initializationValue,\\n initializationValue\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n 0,\\n 0\\n );\\n\\n \"+l+\"\\n } else if (\"+(3===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n initializationValue\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\\n 0\\n );\\n\\n \"+l+\"\\n }\\n setOutput(sumValue);\\n }\\n \"}}(),SelectProgram=function(){return function(e,t,n){var r,o;if(this.variableNames=[\"c\",\"a\",\"b\"],this.outputShape=t,n>4)throw Error(\"Where for rank \"+n+\" is not yet supported\");if(1===n)o=\"resRC\",r=\"resRC\";else{for(var a=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\"],i=[],s=[],u=0;u= 1.0) {\\n setOutput(getA(\"+o+\"));\\n } else {\\n setOutput(getB(\"+o+\"));\\n }\\n }\\n \"}}(),SliceProgram=function(){function e(e){this.variableNames=[\"source\"],this.outputShape=e,this.rank=e.length;var t=getCoordsDataType(this.rank),n=getCoords$1(this.rank);this.userCode=\"\\n uniform \"+t+\" start;\\n\\n void main() {\\n \"+t+\" sourceLoc = start + getOutputCoords();\\n setOutput(getSource(\"+n+\"));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(e){var t=this;if(e.length!==this.rank)throw Error(\"The rank (\"+this.rank+\") of the program must match the length of start (\"+e.length+\")\");return function(n,r){if(null!=t.startLoc||(t.startLoc=n.getUniformLocationNoThrow(r,\"start\"),null!=t.startLoc))if(1===t.rank)n.gl.uniform1i(t.startLoc,e[0]);else if(2===t.rank)n.gl.uniform2i(t.startLoc,e[0],e[1]);else if(3===t.rank)n.gl.uniform3i(t.startLoc,e[0],e[1],e[2]);else{if(4!==t.rank)throw Error(\"Slicing for rank \"+t.rank+\" is not yet supported\");n.gl.uniform4i(t.startLoc,e[0],e[1],e[2],e[3])}}},e}();function getCoords$1(e){if(1===e)return\"sourceLoc\";if(2===e)return\"sourceLoc.x, sourceLoc.y\";if(3===e)return\"sourceLoc.x, sourceLoc.y, sourceLoc.z\";if(4===e)return\"sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w\";throw Error(\"Slicing for rank \"+e+\" is not yet supported\")}var StridedSliceProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=n,this.rank=n.length;var r=getCoordsDataType(this.rank),o=\"\";o=1===this.rank?\"coords * strides + begin\":n.map(function(e,t){return\"coords[\"+t+\"] * strides[\"+t+\"] + begin[\"+t+\"]\"}).join(\",\"),this.userCode=\"\\n \"+r+\" begin = \"+r+\"(\"+e+\");\\n \"+r+\" strides = \"+r+\"(\"+t+\");\\n\\n void main() {\\n \"+r+\" coords = getOutputCoords();\\n setOutput(getX(\"+o+\"));\\n }\\n \"}}(),TextureManager=function(){function e(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}return e.prototype.acquireTexture=function(e,t){var n,r=getPhysicalFromLogicalTextureType(t),o=getKeyFromTextureShape(e,r);if(o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]),this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this.log();var a=this.freeTextures[o].shift();return this.usedTextures[o].push(a),a}return this.numUsedTextures++,this.log(),r===PhysicalTextureType.FLOAT32?n=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):r===PhysicalTextureType.FLOAT16?n=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):r===PhysicalTextureType.UNSIGNED_BYTE&&(n=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[o].push(n),n},e.prototype.releaseTexture=function(e,t,n){var r=getKeyFromTextureShape(t,getPhysicalFromLogicalTextureType(n));r in this.freeTextures||(this.freeTextures[r]=[]),this.freeTextures[r].push(e),this.numFreeTextures++,this.numUsedTextures--;var o=this.usedTextures[r],a=o.indexOf(e);if(a<0)throw new Error(\"Cannot release a texture that was never provided by this texture manager\");o.splice(a,1),this.log()},e.prototype.log=function(){if(this.logEnabled){var e=this.numFreeTextures+this.numUsedTextures;console.log(\"Free/Used\",this.numFreeTextures+\" / \"+this.numUsedTextures,\"(\"+e+\")\")}},e.prototype.getNumUsedTextures=function(){return this.numUsedTextures},e.prototype.getNumFreeTextures=function(){return this.numFreeTextures},e.prototype.dispose=function(){var e=this;if(null!=this.freeTextures){for(var t in this.freeTextures)this.freeTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});for(var t in this.usedTextures)this.usedTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0}},e}();function getPhysicalFromLogicalTextureType(e){if(e===TextureUsage.DOWNLOAD||e===TextureUsage.PIXELS)return PhysicalTextureType.UNSIGNED_BYTE;if(e===TextureUsage.UPLOAD)return PhysicalTextureType.FLOAT32;if(e===TextureUsage.RENDER)return ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?PhysicalTextureType.FLOAT32:PhysicalTextureType.FLOAT16;throw new Error(\"Unknown logical texture type \"+e)}function getKeyFromTextureShape(e,t){return e[0]+\"_\"+e[1]+\"_\"+t}var TileProgram=function(){return function(e,t){this.variableNames=[\"A\"];for(var n=new Array(e.length),r=0;r5)throw Error(\"Tile for rank \"+t+\" is not yet supported\");if(1===t)return\"imod(resRC, \"+e[0]+\")\";for(var n=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\",\"resRC.u\"],r=[],o=0;o6)throw Error(\"Transpose for rank \"+t+\" is not yet supported\");for(var n=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\",\"resRC.u\",\"resRC.v\"],r=new Array(t),o=0;o= 0.0) ? x : (exp(x) - 1.0);\",SELU=\"\\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\\n // see: https://arxiv.org/abs/1706.02515\\n float scaleAlpha = \"+SELU_SCALEALPHA+\";\\n float scale = \"+SELU_SCALE+\";\\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\\n\";function STEP(e){return void 0===e&&(e=0),CHECK_NAN_SNIPPET$1+\"\\n return x > 0.0 ? 1.0 : float(\"+e+\");\\n \"}var NEG=\"return -x;\",CEIL=\"return ceil(x);\",FLOOR=\"return floor(x);\",SIGN=\"\\n if (isNaN(x)) { return 0.0; }\\n return sign(x);\\n\",ROUND=\"\\n // OpenGL ES does not support round function.\\n // The algorithm is based on banker's rounding.\\n float base = floor(x);\\n if ((x - base) < 0.5) {\\n return floor(x);\\n } else if ((x - base) > 0.5) {\\n return ceil(x);\\n } else {\\n if (mod(base, 2.0) == 0.0) {\\n return base;\\n } else {\\n return base + 1.0;\\n }\\n }\\n\",EXP=\"return exp(x);\",EXPM1=\"return exp(x) - 1.0;\",LOG=\"if (x < 0.0) return NAN;\\n return log(x);\",LOG1P=\"return log(1.0 + x);\",SQRT=\"return sqrt(x);\",RSQRT=\"return inversesqrt(x);\",SIGMOID=\"return 1.0 / (1.0 + exp(-1.0 * x));\",SOFTPLUS=\"\\n float epsilon = 1.1920928955078125e-7;\\n float threshold = log(epsilon) + 2.0;\\n\\n bool too_large = x > -threshold;\\n bool too_small = x < threshold;\\n\\n float result;\\n float exp_x = exp(x);\\n\\n if (too_large){\\n result = x;\\n }\\n else if (too_small){\\n result = exp_x;\\n }\\n else{\\n result = log(exp_x + 1.0);\\n }\\n return result;\\n\",SIN=CHECK_NAN_SNIPPET$1+\"\\n return sin(x);\\n\",COS=CHECK_NAN_SNIPPET$1+\"\\n return cos(x);\\n\",TAN=\"return tan(x);\",ASIN=\"return asin(x);\",ACOS=\"return acos(x);\",ATAN=CHECK_NAN_SNIPPET$1+\"\\n return atan(x);\\n\",SINH=\"\\n float e2x = exp(x);\\n return (e2x - 1.0 / e2x) / 2.0;\\n\",COSH=\"\\n float e2x = exp(-x);\\n return (e2x + 1.0 / e2x) / 2.0;\\n\",TANH=\"\\n float e2x = exp(-2.0 * abs(x));\\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\\n\",ASINH=\"return log(x + sqrt(x * x + 1.0));\",ACOSH=CHECK_NAN_SNIPPET$1+\"\\n if (x < 1.0) return NAN;\\n return log(x + sqrt(x * x - 1.0));\",ATANH=CHECK_NAN_SNIPPET$1+\"\\n if ((x < -1.0) || (x > 1.0)) return NAN;\\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;\",ERF='\\n // Error function is calculated approximately with elementary function.\\n // See \"Handbook of Mathematical Functions with Formulas,\\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\\n float p = '+ERF_P+\";\\n float a1 = \"+ERF_A1+\";\\n float a2 = \"+ERF_A2+\";\\n float a3 = \"+ERF_A3+\";\\n float a4 = \"+ERF_A4+\";\\n float a5 = \"+ERF_A5+\";\\n\\n float t = 1.0 / (1.0 + p * x);\\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\\n\",SQUARE=\"return x * x;\",RECIPROCAL=\"return 1.0 / x;\",LOGICAL_NOT=\"return float(!(x >= 1.0));\",TO_INT=\"return float(int(x));\";function concat1d_(e){return concat(e,0)}function concat2d_(e,t){return concat(e,t)}function concat3d_(e,t){return concat(e,t)}function concat4d_(e,t){return concat(e,t)}function concat_(e,t){void 0===t&&(t=0),assert(e.length>=1,\"Pass at least one tensor to concat\");var n=convertToTensorArray(e,\"tensors\",\"concat\"),r=n[0];if(1===n.length)return r;for(var o=parseAxisParam(t,r.shape),a=1;a>>0,t=(r*=t)>>>0,t+=4294967296*(r-=t)}return 2.3283064365386963e-10*(t>>>0)});n.next=function(){var e=2091639*n.s0+2.3283064365386963e-10*n.c;return n.s0=n.s1,n.s1=n.s2,n.s2=e-(n.c=0|e)},n.c=1,n.s0=r(\" \"),n.s1=r(\" \"),n.s2=r(\" \"),n.s0-=r(e),n.s0<0&&(n.s0+=1),n.s1-=r(e),n.s1<0&&(n.s1+=1),n.s2-=r(e),n.s2<0&&(n.s2+=1),r=null}(e),o=t&&t.state,a=n.next;return a.int32=function(){return 4294967296*n.next()|0},a.double=function(){return a()+1.1102230246251565e-16*(2097152*a()|0)},a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.alea=o}(0,e,!1)}),xor128=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor128=o}(0,e,!1)}),xorwow=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,t.v=0,e===(0|e)?t.x=e:n+=e;for(var r=0;r>>4),t.next()}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorwow=o}(0,e,!1)}),xorshift7=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x.slice(),t.i=e.i,t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.x,o=t.i;return e=r[o],n=(e^=e>>>7)^e<<24,n^=(e=r[o+1&7])^e>>>10,n^=(e=r[o+3&7])^e>>>3,n^=(e=r[o+4&7])^e<<7,e=r[o+7&7],n^=(e^=e<<13)^e<<9,r[o]=n,t.i=o+1&7,n},function(e,t){var n,r=[];if(t===(0|t))r[0]=t;else for(t=\"\"+t,n=0;n0;--n)e.next()}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.x&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorshift7=o}(0,e,!1)}),xor4096=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.w,o=t.X,a=t.i;return t.w=r=r+1640531527|0,n=o[a+34&127],e=o[a=a+1&127],n^=n<<13,e^=e<<17,n^=n>>>15,e^=e>>>12,n=o[a]=n^e,t.i=a,n+(r^r>>>16)|0},function(e,t){var n,r,o,a,i,s=[],u=128;for(t===(0|t)?(r=t,t=null):(t+=\"\\0\",r=0,u=Math.max(u,t.length)),o=0,a=-32;a>>15,r^=r<<4,r^=r>>>13,a>=0&&(i=i+1640531527|0,o=0==(n=s[127&a]^=r+i)?o+1:0);for(o>=128&&(s[127&(t&&t.length||0)]=-1),o=127,a=512;a>0;--a)r=s[o+34&127],n=s[o=o+1&127],r^=r<<13,n^=n<<17,r^=r>>>15,n^=n>>>12,s[o]=r^n;e.w=i,e.X=s,e.i=o}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.X&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor4096=o}(0,e,!1)}),tychei=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.next=function(){var e=t.b,n=t.c,r=t.d,o=t.a;return e=e<<25^e>>>7^n,n=n-r|0,r=r<<24^r>>>8^o,o=o-e|0,t.b=e=e<<20^e>>>12^n,t.c=n=n-r|0,t.d=r<<16^n>>>16^o,t.a=o-e|0},t.a=0,t.b=0,t.c=-1640531527,t.d=1367130551,e===Math.floor(e)?(t.a=e/4294967296|0,t.b=0|e):n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.tychei=o}(0,e,!1)}),seedrandom=createCommonjsModule(function(e){!function(t,n){var r,o=this,a=256,i=6,s=\"random\",u=n.pow(a,i),l=n.pow(2,52),c=2*l,p=a-1;function d(e,d,g){var v=[],y=f(function e(t,n){var r,o=[],a=typeof t;if(n&&\"object\"==a)for(r in t)try{o.push(e(t[r],n-1))}catch(e){}return o.length?o:\"string\"==a?t:t+\"\\0\"}((d=1==d?{entropy:!0}:d||{}).entropy?[e,m(t)]:null==e?function(){try{var e;return r&&(e=r.randomBytes)?e=e(a):(e=new Uint8Array(a),(o.crypto||o.msCrypto).getRandomValues(e)),m(e)}catch(e){var n=o.navigator,i=n&&n.plugins;return[+new Date,o,i,o.screen,m(t)]}}():e,3),v),x=new function(e){var t,n=e.length,r=this,o=0,i=r.i=r.j=0,s=r.S=[];n||(e=[n++]);for(;o=c;)e/=2,t/=2,n>>>=1;return(e+n)/t};return T.int32=function(){return 0|x.g(4)},T.quick=function(){return x.g(4)/4294967296},T.double=T,f(m(x.S),t),(d.pass||g||function(e,t,r,o){return o&&(o.S&&h(o,x),e.state=function(){return h(x,{})}),r?(n[s]=e,t):e})(T,y,\"global\"in d?d.global:this==n,d.state)}function h(e,t){return t.i=e.i,t.j=e.j,t.S=e.S.slice(),t}function f(e,t){for(var n,r=e+\"\",o=0;o=1||0===i);var s=Math.sqrt(-2*Math.log(i)/i);t=this.mean+this.stdDev*o*s,n=this.mean+this.stdDev*a*s,this.truncated&&!this.isValidTruncated(t)||(r=!0)}return this.truncated&&!this.isValidTruncated(n)||(this.nextVal=this.convertValue(n)),this.convertValue(t)},e.prototype.convertValue=function(e){return null==this.dtype||\"float32\"===this.dtype?e:Math.round(e)},e.prototype.isValidTruncated=function(e){return e<=this.upper&&e>=this.lower},e}();function clone_(e){var t=convertToTensor(e,\"x\",\"clone\");return ENV.engine.runKernel(function(e){return Tensor.make(t.shape,{dataId:t.dataId},t.dtype)},{$x:t},function(e){return{$x:function(){return e.toFloat()}}})}function eye_(e,t,n,r){void 0===r&&(r=\"float32\"),null==t&&(t=e);for(var o=buffer([e,t],r),a=e<=t?e:t,i=0;i2)throw new Error(\"Rank of probabilities must be 1 or 2, but is \"+i);n=n||Math.random();var s=1===i?o.as2D(1,-1):o,u=ENV.engine.runKernel(function(e){return e.multinomial(s,r,t,n)},{logits2D:s});return 1===i?u.as1D():u}function oneHot_(e,t,n,r){void 0===n&&(n=1),void 0===r&&(r=0);var o=convertToTensor(e,\"indices\",\"oneHot\",\"int32\");if(assert(\"int32\"===o.dtype,\"Indices must be of dtype `int32`\"),t<2)throw new Error(\"Error in oneHot: depth must be >=2, but it is \"+t);return ENV.engine.runKernel(function(e){return e.oneHot(o,t,n,r)},{$indices:o})}function fromPixels_(e,t){if(void 0===t&&(t=3),t>4)throw new Error(\"Cannot construct Tensor with more than 4 channels from pixels.\");return ENV.engine.fromPixels(e,t)}function toPixels(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,o,a,i,s,u,l,c,p,d,h,f,m,g,v,y,x,T,S;return __generator(this,function(b){switch(b.label){case 0:if(2!==(n=convertToTensor(e,\"img\",\"toPixels\",\"int32\")).rank&&3!==n.rank)throw new Error(\"toPixels only supports rank 2 or 3 tensors, got rank \"+n.rank+\".\");if(r=n.shape.slice(0,2),o=r[0],a=r[1],(i=2===n.rank?1:n.shape[2])>4||2===i)throw new Error(\"toPixels only supports depth of size 1, 3 or 4 but got \"+i);return s=n.min(),u=n.max(),[4,s.data()];case 1:return l=b.sent()[0],[4,u.data()];case 2:if(c=b.sent()[0],s.dispose(),u.dispose(),\"float32\"===n.dtype){if(l<0||c>1)throw new Error(\"Tensor values for a float32 Tensor must be in the range [0 - 1] but got range [\"+l+\" - \"+c+\"].\")}else{if(\"int32\"!==n.dtype)throw new Error(\"Unsupported type for toPixels: \"+n.dtype+\". Please use float32 or int32 tensors.\");if(l<0||c>255)throw new Error(\"Tensor values for a int32 Tensor must be in the range [0 - 255] but got range [\"+l+\" - \"+c+\"].\")}return[4,n.data()];case 3:for(p=b.sent(),d=\"float32\"===n.dtype?255:1,h=new Uint8ClampedArray(a*o*4),f=0;f=1,\"Pass at least one tensor to tf.stack\"),1===n.length)return n[0].expandDims(t);var r=n[0].rank,o=n[0].shape,a=n[0].dtype;assert(t<=r,\"Axis must be <= rank of the tensor\"),n.forEach(function(e){assertShapesMatch(o,e.shape,\"All tensors passed to stack must have matching shapes\")}),n.forEach(function(e){assert(a===e.dtype,\"All tensors passed to stack must have matching dtypes\")});var i=n.map(function(e){return e.expandDims(t)});return concat(i,t)}function batchToSpaceND_(e,t,n){var r=convertToTensor(e,\"x\",\"batchToSpaceND\"),o=t.reduce(function(e,t){return e*t});return assert(r.rank>=1+t.length,\"input rank should be > than [blockShape] but got \"+r.rank),assert(n.length===t.length,\"crops.shape[0] must be equal to [blockShape] but got \"+n.length),assert(r.shape[0]%o==0,\"input tensor batch must be divisible by prod( blockShape )\"),ENV.engine.runKernel(function(e){return e.batchToSpaceND(r,t,n)},{})}function spaceToBatchND_(e,t,n){var r=convertToTensor(e,\"x\",\"spaceToBatchND\");return assert(r.rank>=1+t.length,\"input rank should be > than [blockShape] but got \"+r.rank),assert(n.length===t.length,\"paddings.shape[0] must be equal to [blockShape], got \"+n.length),assert(r.shape.reduce(function(e,n,r){return r>0&&r<=t.length?e&&n%t[r-1]==0:e},!0),\"input spatial dimensions must be divisible by blockShapes\"),ENV.engine.runKernel(function(e){return e.spaceToBatchND(r,t,n)},{})}function unstack_(e,t){void 0===t&&(t=0);for(var n,r=convertToTensor(e,\"x\",\"unstack\"),o=r.shape[t],a=Array(r.rank-1).fill(0),i=0,s=0;s0?this.gpgpu.beginQuery():{startMs:performance.now(),endMs:null}},e.prototype.endTimer=function(e){return ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?(this.gpgpu.endQuery(),e):(e.endMs=performance.now(),e)},e.prototype.getQueryTime=function(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){return ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?[2,this.gpgpu.waitForQueryAndGetTime(e)]:[2,(t=e).endMs-t.startMs]})})},e.prototype.disposeData=function(e){if(!this.pendingDisposal.has(e))if(this.pendingRead.has(e))this.pendingDisposal.add(e);else if(this.texData.has(e)){var t=this.texData.get(e),n=t.texture,r=t.texShape,o=t.usage;null!=n&&this.releaseTexture(e,n,r,o),this.texData.delete(e)}},e.prototype.getTexture=function(e){return this.uploadToGPU(e),this.texData.get(e).texture},e.prototype.getGPGPUContext=function(){return this.gpgpu},e.prototype.getCanvas=function(){return this.canvas},e.prototype.slice=function(e,t,n){var r=new SliceProgram(n),o=r.getCustomSetupFunc(t);return this.compileAndRun(r,[e],null,o)},e.prototype.stridedSlice=function(e,t,n,r,o,a){var i=getStridedSlicedInfo(e.shape,t,n,r,o,a),s=i[0],u=i[1];if(u.some(function(e){return 0===e}))return tensor([],u);var l=new StridedSliceProgram(s,r,u);return this.compileAndRun(l,[e])},e.prototype.reverse=function(e,t){var n=new ReverseProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.concat=function(e,t){var n=new ConcatProgram(e.shape,t.shape);return this.compileAndRun(n,[e,t])},e.prototype.neg=function(e){var t=new UnaryOpProgram(e.shape,NEG);return this.compileAndRun(t,[e])},e.prototype.matMul=function(e,t,n,r){var o=new MatMulProgram(e.shape,t.shape,n,r);return this.compileAndRun(o,[e,t])},e.prototype.multiply=function(e,t){var n=new BinaryOpProgram(MUL,e.shape,t.shape),r=this.makeOutputArray(n.outputShape,upcastType(e.dtype,t.dtype));return this.compileAndRun(n,[e,t],r)},e.prototype.batchNormalization=function(e,t,n,r,o,a){var i=[e,t,n],s=null;null!=a&&(s=a.shape,i.push(a));var u=null;null!=o&&(u=o.shape,i.push(o));var l=new BatchNormProgram(e.shape,t.shape,n.shape,s,u,r);return this.compileAndRun(l,i)},e.prototype.localResponseNormalization4D=function(e,t,n,r,o){var a=new LRNProgram(e.shape,t,n,r,o);return this.compileAndRun(a,[e])},e.prototype.LRNGrad=function(e,t,n,r,o,a,i){var s=new LRNGradProgram(t.shape,r,o,a,i);return this.compileAndRun(s,[t,n,e])},e.prototype.tile=function(e,t){var n=new TileProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.pad=function(e,t,n){var r=new PadProgram(e.shape,t,n);return this.compileAndRun(r,[e])},e.prototype.transpose=function(e,t){var n=new TransposeProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.gather=function(e,t,n){var r=new GatherProgram(e.shape,t.size,n);return this.compileAndRun(r,[e,t])},e.prototype.batchToSpaceND=function(e,t,n){assert(e.rank<=4,\"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet\");var r=t.reduce(function(e,t){return e*t}),o=getReshaped(e.shape,t,r),a=getPermuted(o.length,t.length),i=getReshapedPermuted(e.shape,t,r),s=getSliceBeginCoords(n,t.length),u=getSliceSize(i,n,t.length);return e.reshape(o).transpose(a).reshape(i).slice(s,u)},e.prototype.spaceToBatchND=function(e,t,n){assert(e.rank<=4,\"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet\");var r=t.reduce(function(e,t){return e*t}),o=[[0,0]];o.push.apply(o,n);for(var a=1+t.length;athis.NUM_BYTES_BEFORE_PAGING)for(var d=this.numBytesInGPU-this.NUM_BYTES_BEFORE_PAGING;d>0&&this.lruDataGPU.length>0;){var h=this.lruDataGPU.shift(),f=this.texData.get(h),m=f.shape,g=f.dtype;d-=this.computeBytes(m,g),this.read(h)}return p&&(s=this.endTimer(s),this.activeTimers.push(this.getQueryTime(s))),n},e.prototype.getAndSaveBinary=function(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]},e.prototype.getTextureManager=function(){return this.textureManager},e.prototype.dispose=function(){if(!this.disposed){for(var e in this.binaryCache)this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram);this.textureManager.dispose(),this.canvas.remove(),null!=this.fromPixelsCanvas&&this.fromPixelsCanvas.remove(),this.gpgpuCreatedLocally&&this.gpgpu.dispose(),this.disposed=!0}},e.prototype.throwIfNoData=function(e){if(!this.texData.has(e))throw new Error(\"WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends\")},e.prototype.uploadToGPU=function(e){this.throwIfNoData(e);var t=this.texData.get(e),n=t.shape,r=t.values,o=t.texture,a=t.dtype,i=t.usage;if(null==o){var s,u=null!=this.activeTimers;u&&(s=performance.now());var l=getTextureShapeFromLogicalShape(this.gpgpu.gl,n);t.texShape=l;var c=this.acquireTexture(e,l,i);t.texture=c,null!=r&&(this.gpgpu.uploadMatrixToTexture(c,l[0],l[1],typedArrayToFloat32(r,a)),t.values=null,u&&(this.uploadWaitMs+=performance.now()-s))}else{this.lruDataGPU.indexOf(e)>=0&&(this.lruDataGPU.splice(this.lruDataGPU.indexOf(e),1),this.lruDataGPU.push(e))}},e.prototype.cacheOnCPU=function(e,t){var n=this.delayedStorage,r=this.texData.get(e),o=r.texture,a=r.texShape,i=r.dtype,s=r.usage;n&&null!=o&&(this.releaseTexture(e,o,a,s),r.texture=null,r.texShape=null),null!=t&&(r.values=float32ToTypedArray(t,i))},e.prototype.releaseTexture=function(e,t,n,r){var o=this.texData.get(e),a=o.shape,i=o.dtype,s=this.lruDataGPU.indexOf(e);s>=0&&this.lruDataGPU.splice(s,1),this.numBytesInGPU-=this.computeBytes(a,i),this.textureManager.releaseTexture(t,n,r)},e.prototype.acquireTexture=function(e,t,n){var r=this.texData.get(e),o=r.shape,a=r.dtype;return this.lruDataGPU.push(e),this.numBytesInGPU+=this.computeBytes(o,a),this.textureManager.acquireTexture(t,n)},e.prototype.computeBytes=function(e,t){return sizeFromShape(e)*bytesPerElement(t)},e}();function float32ToTypedArray(e,t){if(\"float32\"===t)return e;if(\"int32\"===t||\"bool\"===t){for(var n=\"int32\"===t?new Int32Array(e.length):new Uint8Array(e.length),r=0;r=0?e:(assert(-1===e,\"Bad value in size\"),a.shape[t]-r[t])}),assertParamsValid(a,r,o);var i=a.shape;return ENV.engine.runKernel(function(e){return e.slice(a,r,o)},{$x:a},function(e){for(var t=[],n=0;n0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.reshape(r.shape)}}})}function addN_(e){assert(Array.isArray(e),function(){return\"The param passed to tf.addN() must be a list of tensors\"}),assert(e.length>=1,function(){return\"Must pass at least one tensor to tf.addN(), but got \"+e.length});var t=e.map(function(e,t){return convertToTensor(e,\"tensors\"+t,\"addN\")}),n=t[0];t.forEach(function(e){if(e.dtype!==n.dtype)throw new Error(\"All tensors passed to tf.addN() must have the same dtype\")}),t.forEach(function(e){if(!arraysEqual(e.shape,n.shape))throw new Error(\"All tensors passed to tf.addN() must have the same shape\")});var r=t;return ENV.engine.runKernel(function(e){return e.addN(t)},r,function(e){var n={};return t.forEach(function(t,r){n[r]=function(){return e.clone()}}),n})}function addStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in addStrict: \"),e.add(t)}function sub_(e,t){var n=convertToTensor(e,\"a\",\"sub\"),r=convertToTensor(t,\"b\",\"sub\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.subtract(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e,r=getReductionAxes(n.shape,o);return r.length>0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.neg().reshape(r.shape)}}})}function subStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in subStrict: \"),e.sub(t)}function pow_(e,t){var n=convertToTensor(e,\"base\",\"pow\"),r=convertToTensor(t,\"exp\",\"pow\"),o=assertAndGetBroadcastShape(n.shape,r.shape);e=n.cast(upcastType(n.dtype,r.dtype)),t=r.cast(upcastType(n.dtype,r.dtype));return ENV.engine.runKernel(function(e,t){return t(e.pow(n,r))},{$base:n,$exp:r},function(e,t){var a=t[0];return{$base:function(){var t=e.mul(r.toFloat().mul(a.div(n))),i=getReductionAxes(n.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(n.shape)},$exp:function(){var t=e.mul(a.mul(n.log()).toFloat()),i=getReductionAxes(r.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(r.shape)}}})}function powStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in powStrict: \"),e.pow(t)}function mul_(e,t){var n=convertToTensor(e,\"a\",\"mul\"),r=convertToTensor(t,\"b\",\"mul\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.multiply(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.mul(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function mulStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in multiplyStrict: \"),e.mul(t)}function div_(e,t){var n,r=convertToTensor(e,\"a\",\"div\"),o=convertToTensor(t,\"b\",\"div\");if(assertTypesMatch(r,o),\"int32\"===r.dtype&&\"int32\"===o.dtype)return floorDiv(r,o);n=function(e){return e.realDivide(r,o)};var a=assertAndGetBroadcastShape(r.shape,o.shape);return ENV.engine.runKernel(n,{$a:r,$b:o},function(e){return{$a:function(){var t=e.div(o.toFloat()),n=getReductionAxes(r.shape,a);return n.length>0?t.sum(n).reshape(r.shape):t},$b:function(){var t=e.mul(r.toFloat()),n=getReductionAxes(o.shape,a);n.length>0&&(t=t.sum(n).reshape(o.shape));var i=o.square();return t.div(i.toFloat()).neg()}}})}function floorDiv_(e,t){var n=convertToTensor(e,\"a\",\"floorDiv\"),r=convertToTensor(t,\"b\",\"floorDiv\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.floorDiv(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.div(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);a.length>0&&(t=t.sum(a).reshape(r.shape));var i=r.square();return t.div(i.toFloat()).neg()}}})}function divStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in divideStrict: \"),e.div(t)}function mod_(e,t){var n=convertToTensor(e,\"a\",\"mod\"),r=convertToTensor(t,\"b\",\"mod\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.mod(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=getReductionAxes(n.shape,o);return t.length>0?e.sum(t).reshape(n.shape):e},$b:function(){var t=e.mul(n.div(r).floor().neg()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function modStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in modStrict: \"),e.mod(t)}function minimum_(e,t){var n=convertToTensor(e,\"a\",\"minimum\"),r=convertToTensor(t,\"b\",\"minimum\");assertTypesMatch(n,r),\"bool\"===n.dtype&&(n=n.toInt()),\"bool\"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.minimum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.lessEqual(r).toFloat())},$b:function(){return e.mul(n.greater(r).toFloat())}}})}function minimumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in minimumStrict: \"),e.minimum(t)}function maximum_(e,t){var n=convertToTensor(e,\"a\",\"maximum\"),r=convertToTensor(t,\"b\",\"maximum\");assertTypesMatch(n,r),\"bool\"===n.dtype&&(n=n.toInt()),\"bool\"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.maximum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.greaterEqual(r).toFloat())},$b:function(){return e.mul(n.less(r).toFloat())}}})}function maximumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in minimumStrict: \"),e.maximum(t)}function squaredDifference_(e,t){var n=convertToTensor(e,\"a\",\"squaredDifference\"),r=convertToTensor(t,\"b\",\"squaredDifference\");assertTypesMatch(n,r),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.squaredDifference(n,r)},{$a:n,$b:r},function(e){var t=scalar(2);return{$a:function(){return e.mul(n.sub(r).mul(t))},$b:function(){return e.mul(r.sub(n).mul(t))}}})}function squaredDifferenceStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in squaredDifferenceStrict: \"),e.squaredDifference(t)}function atan2_(e,t){var n=convertToTensor(e,\"a\",\"atan2\"),r=convertToTensor(t,\"b\",\"atan2\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.atan2(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=add(n.square(),r.square()),a=e.mul(r.div(t)),i=getReductionAxes(n.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(n.shape)},$b:function(){var t=add(n.square(),r.square()),a=neg(e.mul(n.div(t))),i=getReductionAxes(r.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(r.shape)}}})}var add=op({add_:add_}),addN=op({addN_:addN_}),addStrict=op({addStrict_:addStrict_}),atan2=op({atan2_:atan2_}),div=op({div_:div_}),divStrict=op({divStrict_:divStrict_}),floorDiv=op({floorDiv_:floorDiv_}),maximum=op({maximum_:maximum_}),maximumStrict=op({maximumStrict_:maximumStrict_}),minimum=op({minimum_:minimum_}),minimumStrict=op({minimumStrict_:minimumStrict_}),mod=op({mod_:mod_}),modStrict=op({modStrict_:modStrict_}),mul=op({mul_:mul_}),mulStrict=op({mulStrict_:mulStrict_}),pow=op({pow_:pow_}),powStrict=op({powStrict_:powStrict_}),squaredDifference=op({squaredDifference_:squaredDifference_}),squaredDifferenceStrict=op({squaredDifferenceStrict_:squaredDifferenceStrict_}),sub=op({sub_:sub_}),subStrict=op({subStrict_:subStrict_});function logicalNot_(e){var t=convertToTensor(e,\"x\",\"logicalNot\",\"bool\");return assert(\"bool\"===t.dtype,\"Error Array must be of type bool.\"),ENV.engine.runKernel(function(e){return e.logicalNot(t)},{$x:t})}function logicalAnd_(e,t){var n=convertToTensor(e,\"a\",\"logicalAnd\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalAnd\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalAnd(n,r)},{$a:n,$b:r})}function logicalOr_(e,t){var n=convertToTensor(e,\"a\",\"logicalOr\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalOr\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalOr(n,r)},{$a:n,$b:r})}function logicalXor_(e,t){var n=convertToTensor(e,\"a\",\"logicalXor\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalXor\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),logicalOr(e,t).logicalAnd(logicalAnd(e,t).logicalNot())}function where_(e,t,n){var r=convertToTensor(t,\"a\",\"where\"),o=convertToTensor(n,\"b\",\"where\"),a=convertToTensor(e,\"condition\",\"where\",\"bool\");assert(\"bool\"===a.dtype,\"Error Condition must be of type bool.\"),assertShapesMatch(r.shape,o.shape,\"Error in where: \"),1===a.rank?assert(a.shape[0]===r.shape[0],\"The first dimension of `a` must match the size of `condition`.\"):assertShapesMatch(a.shape,o.shape,\"Error in where: \");return ENV.engine.runKernel(function(e){return e.select(a,r,o)},{$condition:a,$a:r,$b:o},function(e){return{$condition:function(){return zerosLike(a)},$a:function(){return e.mul(a.cast(r.dtype))},$b:function(){return e.mul(a.logicalNot().cast(o.dtype))}}})}function whereAsync_(e){return __awaiter(this,void 0,void 0,function(){var t,n,r;return __generator(this,function(o){switch(o.label){case 0:return assert(\"bool\"===(t=convertToTensor(e,\"condition\",\"where\",\"bool\")).dtype,\"Condition must be of type bool.\"),[4,t.data()];case 1:return n=o.sent(),r=whereImpl(t.shape,n),e!==t&&t.dispose(),[2,r]}})})}var logicalAnd=op({logicalAnd_:logicalAnd_}),logicalNot=op({logicalNot_:logicalNot_}),logicalOr=op({logicalOr_:logicalOr_}),logicalXor=op({logicalXor_:logicalXor_}),where=op({where_:where_}),whereAsync=whereAsync_;function relu_(e){var t=convertToTensor(e,\"x\",\"relu\");if(\"bool\"===t.dtype)return t.toInt();return ENV.engine.runKernel(function(e){return e.relu(t)},{$x:t},function(e){var n=t.step();return{$x:function(){return e.mulStrict(n.toFloat())}}})}function elu_(e){var t=convertToTensor(e,\"x\",\"elu\");return ENV.engine.runKernel(function(e,n){return n(e.elu(t))},{$x:t},function(e,t){var n=t[0];return{$x:function(){return ENV.engine.runKernel(function(t){return t.eluDer(e,n)},{dy:e,y:n})}}})}function selu_(e){var t=convertToTensor(e,\"x\",\"selu\");return ENV.engine.runKernel(function(e){return e.selu(t)},{$x:t},function(e){return{$x:function(){var n=t.greater(scalar(0)),r=scalar(SELU_SCALEALPHA),o=scalar(SELU_SCALE),a=e.mul(o),i=e.mul(r).mul(t.toFloat().exp());return where(n,a,i)}}})}function leakyRelu_(e,t){void 0===t&&(t=.2);var n=convertToTensor(e,\"x\",\"leakyRelu\");return maximum(scalar(t).mul(n),n)}function prelu_(e,t){var n=convertToTensor(e,\"x\",\"prelu\"),r=convertToTensor(t,\"alpha\",\"prelu\"),o=scalar(0);return maximum(o,n).add(r.mul(minimum(o,n)))}var elu=op({elu_:elu_}),leakyRelu=op({leakyRelu_:leakyRelu_}),prelu=op({prelu_:prelu_}),relu=op({relu_:relu_}),selu=op({selu_:selu_});function transpose_(e,t){var n=convertToTensor(e,\"x\",\"transpose\");if(null==t&&(t=n.shape.map(function(e,t){return t}).reverse()),assert(n.rank===t.length,\"Error in transpose: rank of input \"+n.rank+\" must match length of perm \"+t+\".\"),t.forEach(function(e){assert(e>=0&&eo)throw new Error(\"'k' passed to topk() must be <= the last dimension (\"+o+\") but got \"+t);var a=ENV.engine.runKernel(function(e){return e.topk(r,t,n)},{$x:r});return{values:a[0],indices:a[1]}}var Reduction,topk=op({topk_:topk_});function computeWeightedLoss_(e,t,n){void 0===n&&(n=Reduction.SUM_BY_NONZERO_WEIGHTS);var r=convertToTensor(e,\"losses\",\"computeWeightedLoss\"),o=null;null!=t&&(o=convertToTensor(t,\"weights\",\"computeWeightedLoss\"));var a=null==o?r:r.mul(o);if(n===Reduction.NONE)return a;if(n===Reduction.SUM)return a.sum();if(n===Reduction.MEAN){if(null==o)return a.mean();var i=sizeFromShape(r.shape)/sizeFromShape(o.shape),s=a.sum().div(o.sum());return i>1?s.div(scalar(i)):s}if(n===Reduction.SUM_BY_NONZERO_WEIGHTS){if(null==o)return a.sum().div(scalar(r.size));var u=o.mul(ones$1(r.shape)).notEqual(scalar(0)).sum().toFloat();return a.sum().div(u)}throw Error(\"Unknown reduction: \"+n)}function absoluteDifference_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"absoluteDifference\"),a=convertToTensor(t,\"predictions\",\"absoluteDifference\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"absoluteDifference\")),assertShapesMatch(o.shape,a.shape,\"Error in absoluteDifference: \");var s=o.sub(a).abs();return computeWeightedLoss(s,i,r)}function meanSquaredError_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"meanSquaredError\"),a=convertToTensor(t,\"predictions\",\"meanSquaredError\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"meanSquaredError\")),assertShapesMatch(o.shape,a.shape,\"Error in meanSquaredError: \");var s=o.squaredDifference(a);return computeWeightedLoss(s,i,r)}function cosineDistance_(e,t,n,r,o){void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"cosineDistance\"),i=convertToTensor(t,\"predictions\",\"cosineDistance\"),s=null;null!=r&&(s=convertToTensor(r,\"weights\",\"cosineDistance\")),assertShapesMatch(a.shape,i.shape,\"Error in cosineDistance: \");var u=scalar(1).sub(a.mul(i).sum(n,!0));return computeWeightedLoss(u,s,o)}function hingeLoss_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"hingeLoss\"),a=convertToTensor(t,\"predictions\",\"hingeLoss\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"hingeLoss\")),assertShapesMatch(o.shape,a.shape,\"Error in hingeLoss: \");var s=scalar(1);o=scalar(2).mul(o).sub(s);var u=s.sub(o.mul(a)).relu();return computeWeightedLoss(u,i,r)}function logLoss_(e,t,n,r,o){void 0===r&&(r=1e-7),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"logLoss\"),i=convertToTensor(t,\"predictions\",\"logLoss\"),s=null;null!=n&&(s=convertToTensor(n,\"weights\",\"logLoss\")),assertShapesMatch(a.shape,i.shape,\"Error in logLoss: \");var u=scalar(1),l=scalar(r),c=a.mul(i.add(l).log()).neg().sub(u.sub(a).mul(u.sub(i).add(l).log()));return computeWeightedLoss(c,s,o)}function sigmoidCrossEntropyWithLogits_(e,t){var n=convertToTensor(e,\"labels\",\"sigmoidCrossEntropyWithLogits\"),r=convertToTensor(t,\"logits\",\"sigmoidCrossEntropyWithLogits\");assertShapesMatch(n.shape,r.shape,\"Error in sigmoidCrossEntropyWithLogits: \");var o=r.relu(),a=r.mul(n),i=r.abs().neg().exp().log1p();return o.sub(a).add(i)}function sigmoidCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"multiClassLabels\",\"sigmoidCrossEntropy\"),i=convertToTensor(t,\"logits\",\"sigmoidCrossEntropy\"),s=null;if(null!=n&&(s=convertToTensor(n,\"weights\",\"sigmoidCrossEntropy\")),assertShapesMatch(a.shape,i.shape,\"Error in sigmoidCrossEntropy: \"),r>0){var u=scalar(r),l=scalar(1),c=scalar(.5);a=a.mul(l.sub(u)).add(c.mul(u))}var p=sigmoidCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}function huberLoss_(e,t,n,r,o){void 0===r&&(r=1),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"huberLoss\"),i=convertToTensor(t,\"predictions\",\"huberLoss\"),s=null;null!=n&&(s=convertToTensor(n,\"weights\",\"huberLoss\")),assertShapesMatch(a.shape,i.shape,\"Error in huberLoss: \");var u=scalar(r),l=i.sub(a).abs(),c=minimum(l,u),p=l.sub(c),d=scalar(.5).mul(c.square()).add(u.mul(p));return computeWeightedLoss(d,s,o)}function softmaxCrossEntropyWithLogits_(e,t,n){if(void 0===n&&(n=-1),-1===n&&(n=t.rank-1),n!==t.rank-1)throw Error(\"Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank \"+t.rank+\" and dim was \"+n);return customGrad(function(e,t){var r=t.logSumExp([n],!0),o=t.toFloat().sub(r);return{value:o.mul(e).neg().sum([n]),gradFunc:function(t){var r=expandShapeToKeepDim(t.shape,[n]);return[t.reshape(r).mul(e.toFloat().sub(o.exp())),t.reshape(r).mul(o.exp().sub(e.toFloat()))]}}})(e,t)}function softmaxCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"onehotLabels\",\"softmaxCrossEntropy\"),i=convertToTensor(t,\"logits\",\"softmaxCrossEntropy\"),s=null;if(null!=n&&(s=convertToTensor(n,\"weights\",\"softmaxCrossEntropy\")),assertShapesMatch(a.shape,i.shape,\"Error in softmaxCrossEntropy: \"),r>0){var u=scalar(r),l=scalar(1),c=scalar(a.shape[1]);a=a.mul(l.sub(u)).add(u.div(c))}var p=softmaxCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}!function(e){e[e.NONE=0]=\"NONE\",e[e.MEAN=1]=\"MEAN\",e[e.SUM=2]=\"SUM\",e[e.SUM_BY_NONZERO_WEIGHTS=3]=\"SUM_BY_NONZERO_WEIGHTS\"}(Reduction||(Reduction={}));var absoluteDifference=op({absoluteDifference_:absoluteDifference_}),computeWeightedLoss=op({computeWeightedLoss_:computeWeightedLoss_}),cosineDistance=op({cosineDistance_:cosineDistance_}),hingeLoss=op({hingeLoss_:hingeLoss_}),huberLoss=op({huberLoss_:huberLoss_}),logLoss=op({logLoss_:logLoss_}),meanSquaredError=op({meanSquaredError_:meanSquaredError_}),sigmoidCrossEntropy=op({sigmoidCrossEntropy_:sigmoidCrossEntropy_}),softmaxCrossEntropy=op({softmaxCrossEntropy_:softmaxCrossEntropy_}),loss_ops=Object.freeze({get Reduction(){return Reduction},absoluteDifference:absoluteDifference,computeWeightedLoss:computeWeightedLoss,cosineDistance:cosineDistance,hingeLoss:hingeLoss,huberLoss:huberLoss,logLoss:logLoss,meanSquaredError:meanSquaredError,sigmoidCrossEntropy:sigmoidCrossEntropy,softmaxCrossEntropy:softmaxCrossEntropy});function gramSchmidt_(e){var t;if(Array.isArray(e)){t=!1,assert(null!=e&&e.length>0,\"Gram-Schmidt process: input must not be null, undefined, or empty\");for(var n=e[0].shape[0],r=1;r0)for(var n=0;n= 2, but got rank \"+e.rank);if(2===e.rank)return qr2d(e,t);var n=e.shape.slice(0,e.shape.length-2).reduce(function(e,t){return e*t}),r=[],o=[];return unstack(e.reshape([n,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0).forEach(function(e){var n=qr2d(e,t),a=n[0],i=n[1];r.push(a),o.push(i)}),[stack(r,0).reshape(e.shape),stack(o,0).reshape(e.shape)]}function qr2d(e,t){return void 0===t&&(t=!1),ENV.engine.tidy(function(){if(2!==e.shape.length)throw new Error(\"qr2d() requires a 2D Tensor, but got a \"+e.shape.length+\"D Tensor.\");for(var n=e.shape[0],r=e.shape[1],o=eye(n),a=e.clone(),i=tensor2d([[1]],[1,1]),s=i.clone(),u=n>=r?r:n,l=function(e){var t,u=a,l=s,c=o;t=ENV.engine.tidy(function(){var t=a.slice([e,e],[n-e,1]),u=t.norm(),l=a.slice([e,e],[1,1]),c=l.sign().neg(),p=l.sub(c.mul(u)),d=t.div(p);s=1===d.shape[0]?i.clone():i.concat(d.slice([1,0],[d.shape[0]-1,d.shape[1]]),0);var h=c.matMul(p).div(u).neg(),f=a.slice([e,0],[n-e,r]),m=h.mul(s);a=0===e?f.sub(m.matMul(s.transpose().matMul(f))):a.slice([0,0],[e,r]).concat(f.sub(m.matMul(s.transpose().matMul(f))),0);var g=o.slice([0,e],[n,o.shape[1]-e]);return o=0===e?g.sub(g.matMul(s).matMul(m.transpose())):o.slice([0,0],[n,e]).concat(g.sub(g.matMul(s).matMul(m.transpose())),1),[s,a,o]}),s=t[0],a=t[1],o=t[2],dispose([u,l,c])},c=0;cr&&(o=o.slice([0,0],[n,r]),a=a.slice([0,0],[r,r])),[o,a]})}var gramSchmidt=op({gramSchmidt_:gramSchmidt_}),qr=op({qr_:qr_}),linalg_ops=Object.freeze({gramSchmidt:gramSchmidt,qr:qr});function resizeBilinear_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,\"images\",\"resizeBilinear\");assert(3===r.rank||4===r.rank,\"Error in resizeBilinear: x must be rank 3 or 4, but got rank \"+r.rank+\".\"),assert(2===t.length,\"Error in resizeBilinear: new shape must 2D, but got shape \"+t+\".\");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeBilinear(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeBilinearBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function resizeNearestNeighbor_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,\"images\",\"resizeNearestNeighbor\");assert(3===r.rank||4===r.rank,\"Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank \"+r.rank+\".\"),assert(2===t.length,\"Error in resizeNearestNeighbor: new shape must 2D, but got shape \"+t+\".\"),assert(\"float32\"===r.dtype||\"int32\"===r.dtype,\"`images` must have `int32` or `float32` as dtype\");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeNearestNeighbor(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeNearestNeighborBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function nonMaxSuppression_(e,t,n,r,o){void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY);var a=convertToTensor(e,\"boxes\",\"nonMaxSuppression\"),i=convertToTensor(t,\"scores\",\"nonMaxSuppression\"),s=nonMaxSuppSanityCheck(a,i,n,r,o);return n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,ENV.engine.runKernel(function(e){return e.nonMaxSuppression(a,i,n,r,o)},{$boxes:a})}function nonMaxSuppressionAsync_(e,t,n,r,o){return void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY),__awaiter(this,void 0,void 0,function(){var a,i,s,u,l,c;return __generator(this,function(p){switch(p.label){case 0:return a=convertToTensor(e,\"boxes\",\"nonMaxSuppressionAsync\"),i=convertToTensor(t,\"scores\",\"nonMaxSuppressionAsync\"),s=nonMaxSuppSanityCheck(a,i,n,r,o),n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,[4,a.data()];case 1:return u=p.sent(),[4,i.data()];case 2:return l=p.sent(),c=nonMaxSuppressionImpl(u,l,n,r,o),a!==e&&a.dispose(),i!==t&&i.dispose(),[2,c]}})})}function nonMaxSuppSanityCheck(e,t,n,r,o){null==r&&(r=.5),null==o&&(o=Number.NEGATIVE_INFINITY);var a=e.shape[0];return n=Math.min(n,a),assert(0<=r&&r<=1,\"iouThreshold must be in [0, 1], but was '\"+r+\"'\"),assert(2===e.rank,\"boxes must be a 2D tensor, but was of rank '\"+e.rank+\"'\"),assert(4===e.shape[1],\"boxes must have 4 columns, but 2nd dimension was \"+e.shape[1]),assert(1===t.rank,\"scores must be a 1D tensor\"),assert(t.shape[0]===a,\"scores has incompatible shape with boxes. Expected \"+a+\", but was \"+t.shape[0]),{maxOutputSize:n,iouThreshold:r,scoreThreshold:o}}var resizeBilinear=op({resizeBilinear_:resizeBilinear_}),resizeNearestNeighbor=op({resizeNearestNeighbor_:resizeNearestNeighbor_}),nonMaxSuppression=op({nonMaxSuppression_:nonMaxSuppression_}),nonMaxSuppressionAsync=nonMaxSuppressionAsync_,image_ops=Object.freeze({resizeBilinear:resizeBilinear,resizeNearestNeighbor:resizeNearestNeighbor,nonMaxSuppression:nonMaxSuppression,nonMaxSuppressionAsync:nonMaxSuppressionAsync}),ops=Object.freeze({image:image_ops,linalg:linalg_ops,losses:loss_ops,op:op,batchNormalization2d:batchNormalization2d,batchNormalization3d:batchNormalization3d,batchNormalization4d:batchNormalization4d,batchNormalization:batchNormalization,concat:concat,concat1d:concat1d,concat2d:concat2d,concat3d:concat3d,concat4d:concat4d,conv1d:conv1d,conv2d:conv2d,depthwiseConv2d:depthwiseConv2d,separableConv2d:separableConv2d,conv2dTranspose:conv2dTranspose,matMul:matMul,dot:dot,outerProduct:outerProduct,reverse:reverse,reverse1d:reverse1d,reverse2d:reverse2d,reverse3d:reverse3d,reverse4d:reverse4d,maxPool:maxPool,avgPool:avgPool,slice:slice,slice1d:slice1d,slice2d:slice2d,slice3d:slice3d,slice4d:slice4d,abs:abs,acos:acos,acosh:acosh,asin:asin,asinh:asinh,atan:atan,atanh:atanh,ceil:ceil,clipByValue:clipByValue,cos:cos,cosh:cosh,erf:erf,exp:exp,expm1:expm1,floor:floor,log:log$1,log1p:log1p,logSigmoid:logSigmoid,neg:neg,reciprocal:reciprocal,round:round,rsqrt:rsqrt,sigmoid:sigmoid,sign:sign,sin:sin,sinh:sinh,softplus:softplus,sqrt:sqrt,square:square,step:step,tan:tan,tanh:tanh$1,all:all,any:any,argMax:argMax,argMin:argMin,logSumExp:logSumExp,max:max,mean:mean,min:min,moments:moments,sum:sum,equal:equal,equalStrict:equalStrict,greater:greater,greaterEqual:greaterEqual,greaterEqualStrict:greaterEqualStrict,greaterStrict:greaterStrict,less:less,lessEqual:lessEqual,lessEqualStrict:lessEqualStrict,lessStrict:lessStrict,notEqual:notEqual,notEqualStrict:notEqualStrict,add:add,addN:addN,addStrict:addStrict,atan2:atan2,div:div,divStrict:divStrict,floorDiv:floorDiv,maximum:maximum,maximumStrict:maximumStrict,minimum:minimum,minimumStrict:minimumStrict,mod:mod,modStrict:modStrict,mul:mul,mulStrict:mulStrict,pow:pow,powStrict:powStrict,squaredDifference:squaredDifference,squaredDifferenceStrict:squaredDifferenceStrict,sub:sub,subStrict:subStrict,elu:elu,leakyRelu:leakyRelu,prelu:prelu,relu:relu,selu:selu,logicalAnd:logicalAnd,logicalNot:logicalNot,logicalOr:logicalOr,logicalXor:logicalXor,where:where,whereAsync:whereAsync,buffer:buffer,toPixels:toPixels,print:print,cast:cast,clone:clone,cumsum:cumsum,expandDims:expandDims,eye:eye,fromPixels:fromPixels,multinomial:multinomial,oneHot:oneHot,pad:pad,pad1d:pad1d,pad2d:pad2d,pad3d:pad3d,pad4d:pad4d,rand:rand,randomNormal:randomNormal,randomUniform:randomUniform,reshape:reshape,split:split,squeeze:squeeze,stack:stack,tile:tile,truncatedNormal:truncatedNormal,unstack:unstack,batchToSpaceND:batchToSpaceND,spaceToBatchND:spaceToBatchND,fill:fill,linspace:linspace,ones:ones$1,range:range,scalar:scalar,tensor:tensor,tensor1d:tensor1d,tensor2d:tensor2d,tensor3d:tensor3d,tensor4d:tensor4d,tensor5d:tensor5d,tensor6d:tensor6d,zeros:zeros,onesLike:onesLike,zerosLike:zerosLike,transpose:transpose,softmax:softmax,localResponseNormalization:localResponseNormalization,norm:norm,gather:gather,unsortedSegmentSum:unsortedSegmentSum,basicLSTMCell:basicLSTMCell,multiRNNCell:multiRNNCell,movingAverage:movingAverage,stridedSlice:stridedSlice,topk:topk}),MathBackendCPU=function(){function e(){this.data=new WeakMap,this.firstUse=!0,ENV.get(\"IS_BROWSER\")&&(this.canvas=document.createElement(\"canvas\"))}return e.prototype.register=function(e,t,n){if(this.firstUse&&(this.firstUse=!1,ENV.get(\"IS_NODE\")&&warn(\"\\n============================\\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\\n============================\\n\")),this.data.has(e))throw new Error(\"Data buffer is already registered\");this.data.set(e,null)},e.prototype.write=function(e,t){if(null==t)throw new Error(\"MathBackendCPU.write(): values can not be null\");this.throwIfNoData(e),this.data.set(e,t)},e.prototype.fromPixels=function(e,t){if(null==e)throw new Error(\"pixels passed to tf.fromPixels() can not be null\");var n,r;if(ENV.get(\"IS_NODE\")&&null==e.getContext)throw new Error(\"When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package\");if(null!=e.getContext)n=e.getContext(\"2d\").getImageData(0,0,e.width,e.height).data;else if(e instanceof ImageData)n=e.data;else{if(!(e instanceof HTMLImageElement||e instanceof HTMLVideoElement))throw new Error(\"pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was \"+e.constructor.name);if(null==this.canvas)throw new Error(\"Can't read pixels from HTMLImageElement outside the browser.\");this.canvas.width=e.width,this.canvas.height=e.height,this.canvas.getContext(\"2d\").drawImage(e,0,0,e.width,e.height),n=this.canvas.getContext(\"2d\").getImageData(0,0,e.width,e.height).data}if(4===t)r=new Int32Array(n);else{var o=e.width*e.height;r=new Int32Array(o*t);for(var a=0;ad&&(d=m,h=f)}u[c]=h}return i},e.prototype.cumsum=function(e,t,n,r){if(t!==e.rank-1)throw new Error(\"backend.cumsum in CPU expects an inner-most axis=\"+(e.rank-1)+\" but got axis=\"+t);for(var o=upcastType(e.dtype,\"int32\"),a=zeros(e.shape,o),i=a.dataSync(),s=e.dataSync(),u=e.shape[e.rank-1],l=r?function(e,t){return e+u-t-1}:function(e,t){return e+t},c=0;ct?1:0})},e.prototype.greaterEqual=function(e,t){return this.broadcastedBinaryOp(e,t,\"bool\",function(e,t){return e>=t?1:0})},e.prototype.logicalNot=function(e){for(var t=e.dataSync(),n=new Int32Array(t.length),r=0;r1||1===t.rank?1:t.shape[1],c=0;c=0&&t>=0?n:(n+t)%t})},e.prototype.max=function(e,t){assertAxesAreInnerMostDims(\"max\",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;lp&&(p=h)}s[l]=p}return a},e.prototype.maximum=function(e,t){return this.broadcastedBinaryOp(e,t,e.dtype,function(e,t){return Math.max(e,t)})},e.prototype.all=function(e,t){assertAxesAreInnerMostDims(\"all\",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;l0?n[r]=1:n[r]=0;return Tensor.make(e.shape,{values:n})},e.prototype.round=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r.5?n[r]=Math.ceil(t[r]):n[r]=o%2==0?o:o+1}return Tensor.make(e.shape,{values:n})},e.prototype.exp=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r=0?o:Math.exp(o)-1}return Tensor.make(e.shape,{values:t})},e.prototype.eluDer=function(e,t){for(var n=new Float32Array(t.size),r=t.dataSync(),o=e.dataSync(),a=0;a=1?o[a]:o[a]*(i+1)}return Tensor.make(t.shape,{values:n})},e.prototype.selu=function(e){for(var t=SELU_SCALEALPHA,n=SELU_SCALE,r=new Float32Array(e.size),o=e.dataSync(),a=0;a=0?n*i:t*(Math.exp(i)-1)}return Tensor.make(e.shape,{values:r})},e.prototype.clip=function(e,t,n){for(var r=new Float32Array(e.size),o=e.dataSync(),a=0;a-t,i=r[o]0?1:t}return Tensor.make(e.shape,{values:n})},e.prototype.conv2d=function(e,t,n){for(var r=n.filterHeight,o=n.filterWidth,a=n.dilationHeight,i=n.dilationWidth,s=n.padInfo.left,u=n.padInfo.top,l=buffer(n.outShape,e.dtype),c=0;c=n.inHeight))for(var x=0;x=n.inWidth))for(var S=0;S=n.inHeight))for(var S=0;S=n.inWidth))y+=e.get(p,T,b,d)*t.get(x,S,d,v)}}c.set(y,p,h,m,d*l+v)}return c.toTensor()},e.prototype.depthwiseConv2DDerInput=function(e,t,n){for(var r=buffer(n.inShape,\"float32\"),o=r.values,a=r.strides,i=a[0],s=a[1],u=a[2],l=e.dataSync(),c=e.strides,p=c[0],d=c[1],h=c[2],f=t.dataSync(),m=t.strides,g=m[0],v=m[1],y=m[2],x=n.batchSize,T=n.filterHeight,S=n.filterWidth,b=n.inChannels,E=n.inHeight,w=n.inWidth,_=n.outChannels,A=n.outHeight,R=n.outWidth,C=n.strideHeight,N=n.strideWidth,k=T-1-n.padInfo.top,I=S-1-n.padInfo.left,D=_/b,M=0;MT?T=_:\"avg\"===n&&(S+=_,b++)}if(isNaN(T))break}s.set(\"avg\"===n?S/b:T,c,d,g,p)}return s.toTensor()},e.prototype.maxPool=function(e,t){return this.pool(e,t,\"max\")},e.prototype.maxPoolPositions=function(e,t){for(var n=buffer(t.outShape,\"int32\"),r=t.strideHeight,o=t.strideWidth,a=t.filterHeight,i=t.filterWidth,s=t.padInfo.top,u=t.padInfo.left,l=0;lx&&(x=_,T=b*i+w)}n.set(T,l,p,m,c)}return n.toTensor()},e.prototype.maxPoolBackprop=function(e,t,n,r){for(var o=this.maxPoolPositions(t,r),a=r.strideHeight,i=r.strideWidth,s=r.filterHeight,u=r.filterWidth,l=u-1-r.padInfo.left,c=s-1-r.padInfo.top,p=buffer(t.shape,\"float32\"),d=0;d=r.outHeight||Math.floor(T)!==T))for(var S=0;S=r.outWidth||Math.floor(b)!==b)){var E=s*u-1-o.get(d,T,b,h)===x*u+S?1:0;if(0!==E)y+=e.get(d,T,b,h)*E}}}p.set(y,d,f,m,h)}return p.toTensor()},e.prototype.avgPoolBackprop=function(e,t,n){for(var r=n.strideHeight,o=n.strideWidth,a=n.filterHeight,i=n.filterWidth,s=i-1-n.padInfo.left,u=a-1-n.padInfo.top,l=buffer(t.shape,\"float32\"),c=1/(a*i),p=0;p=n.outHeight||Math.floor(x)!==x))for(var T=0;T=n.outWidth||Math.floor(S)!==S))v+=e.get(p,x,S,d)}}l.set(v*c,p,h,f,d)}return l.toTensor()},e.prototype.cast=function(e,t){return castTensor(e,t,this)},e.prototype.reshape=function(e,t){return reshapeTensor(e,t)},e.prototype.avgPool=function(e,t){return this.pool(e,t,\"avg\").toFloat()},e.prototype.resizeBilinear=function(e,t,n,r){for(var o=e.shape,a=o[0],i=o[1],s=o[2],u=o[3],l=buffer([a,t,n,u],e.dtype),c=[r&&t>1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=d[0]/h[0],m=d[1]/h[1],g=0;g1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=1/(d[0]/h[0]),m=1/(d[1]/h[1]),g=2*Math.ceil(f)+2,v=2*Math.ceil(m)+2,y=0;y=l))for(var N=0;N=c)){var I=d[0]*(C/h[0]),D=d[1]*(k/h[1]),M=Math.min(a-1,n?Math.round(I):Math.floor(I)),O=Math.min(i-1,n?Math.round(D):Math.floor(D));x===M&&T===O&&(A+=e.get(y,C,k,_))}}}p.set(A,y,x,T,_)}return p.toTensor()},e.prototype.batchNormalization=function(e,t,n,r,o,a){for(var i=e.dataSync(),s=t.dataSync(),u=n.dataSync(),l=o?o.dataSync():new Float32Array([1]),c=a?a.dataSync():new Float32Array([0]),p=new Float32Array(i.length),d=0;d=0&&e.get(a)0,\"scheme must not be an empty string.\");var r=e.getInstance();assert(null==r.managers[t],\"A model store manager is already registered for scheme '\"+t+\"'.\"),r.managers[t]=n},e.getManager=function(e){var t=this.getInstance().managers[e];if(null==t)throw new Error(\"Cannot find model manager for scheme '\"+e+\"'\");return t},e.getSchemes=function(){return Object.keys(this.getInstance().managers)},e}();function parseURL(e){if(-1===e.indexOf(URL_SCHEME_SUFFIX))throw new Error(\"The url string provided does not contain a scheme. Supported schemes are: \"+ModelStoreManagerRegistry.getSchemes().join(\",\"));return{scheme:e.split(URL_SCHEME_SUFFIX)[0],path:e.split(URL_SCHEME_SUFFIX)[1]}}function cloneModelInternal(e,t,n){return void 0===n&&(n=!1),__awaiter(this,void 0,void 0,function(){var r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return assert(e!==t,\"Old path and new path are the same: '\"+e+\"'\"),assert((r=IORouterRegistry.getLoadHandlers(e)).length>0,\"Copying failed because no load handler is found for source URL \"+e+\".\"),assert(r.length<2,\"Copying failed because more than one (\"+r.length+\") load handlers for source URL \"+e+\".\"),o=r[0],assert((a=IORouterRegistry.getSaveHandlers(t)).length>0,\"Copying failed because no save handler is found for destination URL \"+t+\".\"),assert(a.length<2,\"Copying failed because more than one (\"+r.length+\") save handlers for destination URL \"+t+\".\"),i=a[0],s=parseURL(e).scheme,u=parseURL(e).path,l=s===parseURL(e).scheme,[4,o.load()];case 1:return c=d.sent(),n&&l?[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)]:[3,3];case 2:d.sent(),d.label=3;case 3:return[4,i.save(c)];case 4:return p=d.sent(),!n||l?[3,6]:[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)];case 5:d.sent(),d.label=6;case 6:return[2,p.modelArtifactsInfo]}})})}function listModels(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i;return __generator(this,function(s){switch(s.label){case 0:e=ModelStoreManagerRegistry.getSchemes(),t={},n=0,r=e,s.label=1;case 1:return n0,\"URL path for browserHTTPRequest must not be null, undefined or empty.\"),this.path=e,null!=t&&null!=t.body)throw new Error(\"requestInit is expected to have no pre-existing body, but has one.\");this.requestInit=t||{}}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){var t,n,r,o;return __generator(this,function(a){switch(a.label){case 0:if(e.modelTopology instanceof ArrayBuffer)throw new Error(\"BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.\");return(t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit)).body=new FormData,n=[{paths:[\"./model.weights.bin\"],weights:e.weightSpecs}],r={modelTopology:e.modelTopology,weightsManifest:n},t.body.append(\"model.json\",new Blob([JSON.stringify(r)],{type:\"application/json\"}),\"model.json\"),null!=e.weightData&&t.body.append(\"model.weights.bin\",new Blob([e.weightData],{type:\"application/octet-stream\"}),\"model.weights.bin\"),[4,fetch(this.path,t)];case 1:if(200===(o=a.sent()).status)return[2,{modelArtifactsInfo:getModelArtifactsInfoForJSON(e),responses:[o]}];throw new Error(\"BrowserHTTPRequest.save() failed due to HTTP response status \"+o.status+\".\")}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return[4,fetch(this.path,this.requestInit)];case 1:return[4,d.sent().json()];case 2:if(e=d.sent(),t=e.modelTopology,n=e.weightsManifest,null==t&&null==n)throw new Error(\"The JSON from HTTP path \"+this.path+\" contains neither model topology or manifest for weights.\");if(null==n)return[3,4];for(a=e.weightsManifest,r=[],i=0,s=a;i0&&(e=__assign({weightSpecs:this.weightSpecs},e)),null!=this.weightData&&this.weightData.byteLength>0&&(e=__assign({weightData:this.weightData},e)),[2,e]})})},e}(),PassthroughSaver=function(){function e(e){this.saveHandler=e}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(t){return[2,this.saveHandler(e)]})})},e}();function fromMemory(e,t,n){return new PassthroughLoader(e,t,n)}function withSaveHandler(e){return new PassthroughSaver(e)}var registerSaveRouter=IORouterRegistry.registerSaveRouter,registerLoadRouter=IORouterRegistry.registerLoadRouter,getSaveHandlers=IORouterRegistry.getSaveHandlers,getLoadHandlers=IORouterRegistry.getLoadHandlers,io=Object.freeze({browserFiles:browserFiles,browserHTTPRequest:browserHTTPRequest,concatenateArrayBuffers:concatenateArrayBuffers,decodeWeights:decodeWeights,encodeWeights:encodeWeights,fromMemory:fromMemory,getLoadHandlers:getLoadHandlers,getModelArtifactsInfoForJSON:getModelArtifactsInfoForJSON,getSaveHandlers:getSaveHandlers,loadWeights:loadWeights,registerLoadRouter:registerLoadRouter,registerSaveRouter:registerSaveRouter,withSaveHandler:withSaveHandler,copyModel:copyModel,listModels:listModels,moveModel:moveModel,removeModel:removeModel}),Serializable=function(){function e(){}return e.prototype.getClassName=function(){return this.constructor.className},e.fromConfig=function(e,t){return new e(t)},e}(),SerializationMap=function(){function e(){this.classNameMap={}}return e.getMap=function(){return null==e.instance&&(e.instance=new e),e.instance},e.register=function(t){e.getMap().classNameMap[t.className]=[t,t.fromConfig]},e}(),serialization=Object.freeze({Serializable:Serializable,SerializationMap:SerializationMap}),WEBGL_ENVS={HAS_WEBGL:!0},NODE_ENVS={IS_NODE:!0},CHROME_ENVS={IS_CHROME:!0},BROWSER_ENVS={IS_BROWSER:!0},CPU_ENVS={HAS_WEBGL:!1},ALL_ENVS={};function expectArraysClose(e,t,n){if(null==n&&(n=ENV.get(\"TEST_EPSILON\")),e instanceof Tensor||t instanceof Tensor){if(e instanceof Tensor&&t instanceof Tensor){if(e.dtype!==t.dtype)throw new Error(\"Arrays are of different type actual: \"+e.dtype+\" vs expected: \"+t.dtype+\".\");if(!arraysEqual(e.shape,t.shape))throw new Error(\"Arrays are of different shape actual: \"+e.shape+\" vs expected: \"+t.shape+\".\")}}else{var r=e.constructor.name,o=t.constructor.name;if(r!==o)throw new Error(\"Arrays are of different type actual: \"+r+\" vs expected: \"+o)}var a,i;if(a=e instanceof Tensor?e.dataSync():e,i=t instanceof Tensor?t.dataSync():t,a.length!==i.length)throw new Error(\"Arrays have different lengths actual: \"+a.length+\" vs expected: \"+i.length+\".\\nActual: \"+a+\".\\nExpected: \"+i+\".\");for(var s=0;sn)}function expectValuesInRange(e,t,n){var r;r=e instanceof Tensor?e.dataSync():e;for(var o=0;on)throw new Error(\"Value out of range:\"+r[o]+\" low: \"+t+\", high: \"+n)}function expectArrayBuffersEqual(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}var test_util=Object.freeze({WEBGL_ENVS:WEBGL_ENVS,NODE_ENVS:NODE_ENVS,CHROME_ENVS:CHROME_ENVS,BROWSER_ENVS:BROWSER_ENVS,CPU_ENVS:CPU_ENVS,ALL_ENVS:ALL_ENVS,expectArraysClose:expectArraysClose,expectPromiseToFail:expectPromiseToFail,expectArraysEqual:expectArraysEqual,expectNumbersClose:expectNumbersClose,expectValuesInRange:expectValuesInRange,expectArrayBuffersEqual:expectArrayBuffersEqual}),version=\"0.12.8\",webgl=Object.freeze({gpgpu_util:gpgpu_util,webgl_util:webgl_util,MathBackendWebGL:MathBackendWebGL,GPGPUContext:GPGPUContext}),Optimizer=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.minimize=function(e,t,n){void 0===t&&(t=!1);var r=this.computeGradients(e,n),o=r.value,a=r.grads;return this.applyGradients(a),Object.keys(a).forEach(function(e){return a[e].dispose()}),t?o:(o.dispose(),null)},t.prototype.computeGradients=function(e,t){return variableGrads(e,t)},t}(Serializable),DEFAULT_FLOAT32_EPSILON=1e-8,DEFAULT_FLOAT16_EPSILON=1e-4;function getOptimizerDefaultEpsilonValue(){return ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?DEFAULT_FLOAT32_EPSILON:DEFAULT_FLOAT16_EPSILON}var AdadeltaOptimizer=function(e){function t(t,n,r){void 0===r&&(r=null);var o=e.call(this)||this;return o.learningRate=t,o.rho=n,o.epsilon=r,o.accumulatedGrads={},o.accumulatedUpdates={},o.c=keep(scalar(-t)),o.rhoScalar=keep(scalar(n)),o.oneMinusRho=keep(scalar(1-n)),null===r&&(r=getOptimizerDefaultEpsilonValue()),o.epsilonScalar=keep(scalar(r)),o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedUpdates[n]){tidy(function(){t.accumulatedUpdates[n]=zerosLike(o).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n],s=r.accumulatedUpdates[n];tidy(function(){var e=t.rhoScalar.mul(i).add(t.oneMinusRho.mul(a.square())),r=s.add(t.epsilonScalar).sqrt().div(i.add(t.epsilonScalar).sqrt()).mul(a),u=t.rhoScalar.mul(s).add(t.oneMinusRho.mul(r.square()));t.accumulatedGrads[n].assign(e),t.accumulatedUpdates[n].assign(u);var l=t.c.mul(r).add(o);o.assign(l)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.rhoScalar.dispose(),this.oneMinusRho.dispose(),null!=this.accumulatedUpdates&&(Object.keys(this.accumulatedUpdates).forEach(function(t){return e.accumulatedUpdates[t].dispose()}),Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()}))},t.prototype.getConfig=function(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.rho,t.epsilon)},t.className=\"AdadeltaOptimizer\",t}(Optimizer);SerializationMap.register(AdadeltaOptimizer);var AdagradOptimizer=function(e){function t(t,n){void 0===n&&(n=.1);var r=e.call(this)||this;r.learningRate=t,r.initialAccumulatorValue=n,r.accumulatedGrads={},r.c=keep(scalar(-t));var o=getOptimizerDefaultEpsilonValue();return r.epsilon=keep(scalar(o)),r}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=fill(o.shape,t.initialAccumulatorValue).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n];tidy(function(){var e=i.add(a.square());t.accumulatedGrads[n].assign(e);var r=t.c.mul(a.div(e.add(t.epsilon).sqrt())).add(o);o.assign(r)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.epsilon.dispose(),this.c.dispose(),null!=this.accumulatedGrads&&Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}},t.fromConfig=function(e,t){return new e(t.learningRate,t.initialAccumulatorValue)},t.className=\"AdagradOptimizer\",t}(Optimizer);SerializationMap.register(AdagradOptimizer);var AdamOptimizer=function(e){function t(t,n,r,o){void 0===o&&(o=null);var a=e.call(this)||this;return a.learningRate=t,a.beta1=n,a.beta2=r,a.epsilon=o,a.accumulatedFirstMoment={},a.accumulatedSecondMoment={},a.c=keep(scalar(-t)),a.beta1Scalar=keep(scalar(n)),a.beta2Scalar=keep(scalar(r)),tidy(function(){a.accBeta1=scalar(n).variable(),a.accBeta2=scalar(r).variable()}),a.oneMinusBeta1=keep(scalar(1-n)),a.oneMinusBeta2=keep(scalar(1-r)),a.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),a.epsScalar=keep(scalar(o)),a}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.one.sub(t.accBeta2);for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedSecondMoment[o]){i=!1;t.accumulatedSecondMoment[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedSecondMoment[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l).add(t.oneMinusBeta2.mul(s.square())),d=c.div(n),h=p.div(r);t.accumulatedFirstMoment[o].assign(c),t.accumulatedSecondMoment[o].assign(p);var f=t.c.mul(d.div(t.epsScalar.add(h.sqrt()))).add(a);a.assign(f)}t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)),t.accBeta2.assign(t.accBeta2.mul(t.beta2Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.accBeta1.dispose(),this.accBeta2.dispose(),this.oneMinusBeta1.dispose(),this.oneMinusBeta2.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedSecondMoment&&Object.keys(this.accumulatedSecondMoment).forEach(function(t){return e.accumulatedSecondMoment[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)},t.className=\"AdamOptimizer\",t}(Optimizer);SerializationMap.register(AdamOptimizer);var AdamaxOptimizer=function(e){function t(t,n,r,o,a){void 0===o&&(o=null),void 0===a&&(a=0);var i=e.call(this)||this;return i.learningRate=t,i.beta1=n,i.beta2=r,i.epsilon=o,i.decay=a,i.accumulatedFirstMoment={},i.accumulatedWeightedInfNorm={},i.c=keep(scalar(-t)),i.beta1Scalar=keep(scalar(n)),i.beta2Scalar=keep(scalar(r)),i.decayScalar=keep(scalar(a)),tidy(function(){i.iteration=scalar(0).variable(),i.accBeta1=scalar(n).variable()}),i.oneMinusBeta1=keep(scalar(1-n)),i.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.c.div(t.one.add(t.decayScalar.mul(t.iteration)));for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedWeightedInfNorm[o]){i=!1;t.accumulatedWeightedInfNorm[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedWeightedInfNorm[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l),d=s.abs(),h=p.maximum(d);t.accumulatedFirstMoment[o].assign(c),t.accumulatedWeightedInfNorm[o].assign(h);var f=r.div(n).mul(c.div(t.epsScalar.add(h))).add(a);a.assign(f)}t.iteration.assign(t.iteration.add(t.one)),t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.accBeta1.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.oneMinusBeta1.dispose(),this.decayScalar.dispose(),this.iteration.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedWeightedInfNorm&&Object.keys(this.accumulatedWeightedInfNorm).forEach(function(t){return e.accumulatedWeightedInfNorm[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)},t.className=\"AdamaxOptimizer\",t}(Optimizer);SerializationMap.register(AdamaxOptimizer);var SGDOptimizer=function(e){function t(t){var n=e.call(this)||this;return n.learningRate=t,n.setLearningRate(t),n}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;Object.keys(e).forEach(function(n){var r=e[n],o=ENV.engine.registeredVariables[n];tidy(function(){var e=t.c.mul(r).add(o);o.assign(e)})})},t.prototype.setLearningRate=function(e){this.learningRate=e,null!=this.c&&this.c.dispose(),this.c=keep(scalar(-e))},t.prototype.dispose=function(){this.c.dispose()},t.prototype.getConfig=function(){return{learningRate:this.learningRate}},t.fromConfig=function(e,t){return new e(t.learningRate)},t.className=\"SGDOptimizer\",t}(Optimizer);SerializationMap.register(SGDOptimizer);var MomentumOptimizer=function(e){function t(t,n,r){void 0===r&&(r=!1);var o=e.call(this,t)||this;return o.learningRate=t,o.momentum=n,o.useNesterov=r,o.m=scalar(o.momentum),o.accumulations={},o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulations[n]){tidy(function(){t.accumulations[n]=zerosLike(o).variable(!1)})}var a=r.accumulations[n],i=e[n];tidy(function(){var e,r=t.m.mul(a).add(i);e=t.useNesterov?t.c.mul(i.add(r.mul(t.m))).add(o):t.c.mul(r).add(o),t.accumulations[n].assign(r),o.assign(e)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){if(e.prototype.dispose.call(this),this.m.dispose(),null!=this.accumulations)for(var t in this.accumulations)this.accumulations[t].dispose()},t.prototype.setMomentum=function(e){this.momentum=e},t.prototype.getConfig=function(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}},t.fromConfig=function(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)},t.className=\"MomentumOptimizer\",t}(SGDOptimizer);SerializationMap.register(MomentumOptimizer);var RMSPropOptimizer=function(e){function t(t,n,r,o,a){void 0===n&&(n=.9),void 0===r&&(r=0),void 0===o&&(o=null),void 0===a&&(a=!1);var i=e.call(this)||this;return i.learningRate=t,i.decay=n,i.momentum=r,i.epsilon=o,i.accumulatedMeanSquares={},i.accumulatedMeanGrads={},i.accumulatedMoments={},i.c=keep(scalar(t)),i.decayScalar=keep(scalar(n)),i.momentumScalar=keep(scalar(r)),i.oneMinusDecay=keep(scalar(1-n)),i.centered=a,null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsilonScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedMeanSquares[n]){tidy(function(){t.accumulatedMeanSquares[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMeanGrads[n]&&r.centered){tidy(function(){t.accumulatedMeanGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMoments[n]){tidy(function(){t.accumulatedMoments[n]=zerosLike(o).variable(!1)})}var a=r.accumulatedMeanSquares[n],i=r.accumulatedMeanGrads[n],s=r.accumulatedMoments[n],u=e[n];tidy(function(){var e=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));if(t.centered){var r=t.decayScalar.mul(i).add(t.oneMinusDecay.mul(u)),l=t.momentumScalar.mul(s).add(t.c.mul(u).div(e.sub(r.square().add(t.epsilonScalar)).sqrt()));t.accumulatedMeanSquares[n].assign(e),t.accumulatedMeanGrads[n].assign(r),t.accumulatedMoments[n].assign(l);var c=o.sub(l);o.assign(c)}else{var p=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));l=t.momentumScalar.mul(s).add(t.c.mul(u).div(p.add(t.epsilonScalar).sqrt()));t.accumulatedMeanSquares[n].assign(p),t.accumulatedMoments[n].assign(l);c=o.sub(l);o.assign(c)}})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.decayScalar.dispose(),this.momentumScalar.dispose(),this.oneMinusDecay.dispose(),null!=this.accumulatedMeanSquares&&Object.keys(this.accumulatedMeanSquares).forEach(function(t){return e.accumulatedMeanSquares[t].dispose()}),null!=this.accumulatedMeanGrads&&this.centered&&Object.keys(this.accumulatedMeanGrads).forEach(function(t){return e.accumulatedMeanGrads[t].dispose()}),null!=this.accumulatedMoments&&Object.keys(this.accumulatedMoments).forEach(function(t){return e.accumulatedMoments[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}},t.fromConfig=function(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)},t.className=\"RMSPropOptimizer\",t}(Optimizer);SerializationMap.register(RMSPropOptimizer);var OptimizerConstructors=function(){function e(){}return e.sgd=function(e){return new SGDOptimizer(e)},e.momentum=function(e,t,n){return void 0===n&&(n=!1),new MomentumOptimizer(e,t,n)},e.rmsprop=function(e,t,n,r,o){return void 0===t&&(t=.9),void 0===n&&(n=0),void 0===r&&(r=null),void 0===o&&(o=!1),new RMSPropOptimizer(e,t,n,r,o)},e.adam=function(e,t,n,r){return void 0===e&&(e=.001),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),new AdamOptimizer(e,t,n,r)},e.adadelta=function(e,t,n){return void 0===e&&(e=.001),void 0===t&&(t=.95),void 0===n&&(n=null),new AdadeltaOptimizer(e,t,n)},e.adamax=function(e,t,n,r,o){return void 0===e&&(e=.002),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),void 0===o&&(o=0),new AdamaxOptimizer(e,t,n,r,o)},e.adagrad=function(e,t){return void 0===t&&(t=.1),new AdagradOptimizer(e,t)},e}(),train={sgd:OptimizerConstructors.sgd,momentum:OptimizerConstructors.momentum,adadelta:OptimizerConstructors.adadelta,adagrad:OptimizerConstructors.adagrad,rmsprop:OptimizerConstructors.rmsprop,adamax:OptimizerConstructors.adamax,adam:OptimizerConstructors.adam},setBackend=Environment.setBackend,getBackend=Environment.getBackend,disposeVariables=Environment.disposeVariables,memory=Environment.memory;setOpHandler(ops);export{setBackend,getBackend,disposeVariables,memory,version as version_core,nextFrame,environment,io,serialization,test_util,util,webgl,AdadeltaOptimizer,AdagradOptimizer,AdamOptimizer,AdamaxOptimizer,MomentumOptimizer,Optimizer,RMSPropOptimizer,SGDOptimizer,Tensor,TensorBuffer,variable,Variable,Rank,Reduction,ENV,Environment,image_ops as image,linalg_ops as linalg,loss_ops as losses,op,batchNormalization2d,batchNormalization3d,batchNormalization4d,batchNormalization,concat,concat1d,concat2d,concat3d,concat4d,conv1d,conv2d,depthwiseConv2d,separableConv2d,conv2dTranspose,matMul,dot,outerProduct,reverse,reverse1d,reverse2d,reverse3d,reverse4d,maxPool,avgPool,slice,slice1d,slice2d,slice3d,slice4d,abs,acos,acosh,asin,asinh,atan,atanh,ceil,clipByValue,cos,cosh,erf,exp,expm1,floor,log$1 as log,log1p,logSigmoid,neg,reciprocal,round,rsqrt,sigmoid,sign,sin,sinh,softplus,sqrt,square,step,tan,tanh$1 as tanh,all,any,argMax,argMin,logSumExp,max,mean,min,moments,sum,equal,equalStrict,greater,greaterEqual,greaterEqualStrict,greaterStrict,less,lessEqual,lessEqualStrict,lessStrict,notEqual,notEqualStrict,add,addN,addStrict,atan2,div,divStrict,floorDiv,maximum,maximumStrict,minimum,minimumStrict,mod,modStrict,mul,mulStrict,pow,powStrict,squaredDifference,squaredDifferenceStrict,sub,subStrict,elu,leakyRelu,prelu,relu,selu,logicalAnd,logicalNot,logicalOr,logicalXor,where,whereAsync,buffer,toPixels,print,cast,clone,cumsum,expandDims,eye,fromPixels,multinomial,oneHot,pad,pad1d,pad2d,pad3d,pad4d,rand,randomNormal,randomUniform,reshape,split,squeeze,stack,tile,truncatedNormal,unstack,batchToSpaceND,spaceToBatchND,fill,linspace,ones$1 as ones,range,scalar,tensor,tensor1d,tensor2d,tensor3d,tensor4d,tensor5d,tensor6d,zeros,onesLike,zerosLike,transpose,softmax,localResponseNormalization,norm,gather,unsortedSegmentSum,basicLSTMCell,multiRNNCell,movingAverage,stridedSlice,topk,train,tidy,keep,dispose,time,customGrad,grad,grads,valueAndGrad,valueAndGrads,variableGrads};\n//# sourceMappingURL=tf-core.esm.js.map\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport{keep,scalar,tidy,onesLike,tensor1d,util,zerosLike,train,cast,serialization,add,mul,div,Tensor,Optimizer,mean,io,transpose,reverse,zeros,sum,dispose,neg,variable,ones,eye,randomUniform,truncatedNormal,randomNormal,sub,sqrt,mulStrict,clipByValue,relu,linalg,leakyRelu,elu,conv1d,conv2d,conv2dTranspose,separableConv2d,depthwiseConv2d,maximum,minimum,batchNormalization2d,batchNormalization3d,batchNormalization4d,moments,movingAverage,pad,maxPool,avgPool,squeeze,max,abs,log,softplus,softmax,floor,oneHot,exp,greater,equal,argMax,slice1d,slice2d,slice3d,slice4d,concat,concat1d,concat2d,concat3d,concat4d,tile,matMul,gather,step,min,selu,sigmoid,tanh}from\"@tensorflow/tfjs-core\";var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])&&(6===a[0]||2===a[0])){o=0;continue}if(3===a[0]&&(!i||a[1]>i[0]&&a[1]t?1:0}function reverseNumberCompare(e,t){return-1*numberCompare(e,t)}function stringToDType(e){switch(e){case\"float32\":return\"float32\";default:throw new ValueError(\"Invalid dtype: \"+e)}}function unique(e){if(null==e)return e;for(var t=[],n=0,r=e;n=0),assert(r>=n),Array.isArray(e)&&e.length>=n&&e.length<=r&&e.every(function(e){return typeof e===t})}function calcL2Norms(e,t){return tidy(function(){return sqrt(sum(mulStrict(e,e),t,!0))})}var Constraint=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.getConfig=function(){return{}},t}(serialization.Serializable),MaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMaxValue=2,n.defaultAxis=0,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=clipByValue(n,0,t.maxValue);return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{maxValue:this.maxValue,axis:this.axis}},t.className=\"MaxNorm\",t}(Constraint);serialization.SerializationMap.register(MaxNorm);var UnitNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultAxis=0,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){return div(e,add(getScalar(epsilon()),calcL2Norms(e,t.axis)))})},t.prototype.getConfig=function(){return{axis:this.axis}},t.className=\"UnitNorm\",t}(Constraint);serialization.SerializationMap.register(UnitNorm);var NonNeg=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.apply=function(e){return relu(e)},t.className=\"NonNeg\",t}(Constraint);serialization.SerializationMap.register(NonNeg);var MinMaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMinValue=0,n.defaultMaxValue=1,n.defaultRate=1,n.defaultAxis=0,n.minValue=null!=t.minValue?t.minValue:n.defaultMinValue,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.rate=null!=t.rate?t.rate:n.defaultRate,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=add(mul(getScalar(t.rate),clipByValue(n,t.minValue,t.maxValue)),mul(getScalar(1-t.rate),n));return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}},t.className=\"MinMaxNorm\",t}(Constraint);serialization.SerializationMap.register(MinMaxNorm);var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP={maxNorm:\"MaxNorm\",minMaxNorm:\"MinMaxNorm\",nonNeg:\"NonNeg\",unitNorm:\"UnitNorm\"};function serializeConstraint(e){return serializeKerasObject(e)}function deserializeConstraint(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,\"constraint\")}function getConstraint(e){return null==e?null:\"string\"==typeof e?deserializeConstraint({className:e in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP?CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e,config:{}}):e instanceof Constraint?e:deserializeConstraint(e)}function maxNorm(e){return new MaxNorm(e)}function unitNorm(e){return new UnitNorm(e)}function nonNeg(){return new NonNeg}function minMaxNorm(e){return new MinMaxNorm(e)}var exports_constraints=Object.freeze({maxNorm:maxNorm,unitNorm:unitNorm,nonNeg:nonNeg,minMaxNorm:minMaxNorm}),nameMap=new Map,VALID_DATA_FORMAT_VALUES=[\"channelsFirst\",\"channelsLast\"];function checkDataFormat(e){checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES,\"DataFormat\",e)}var VALID_PADDING_MODE_VALUES=[\"valid\",\"same\",\"causal\"];function checkPaddingMode(e){checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES,\"PaddingMode\",e)}var VALID_POOL_MODE_VALUES=[\"max\",\"avg\"];function checkPoolMode(e){checkStringTypeUnionValue(VALID_POOL_MODE_VALUES,\"PoolMode\",e)}var _nameScopeStack=[],_nameScopeDivider=\"/\";function nameScope(e,t){_nameScopeStack.push(e);try{var n=t();return _nameScopeStack.pop(),n}catch(e){throw _nameScopeStack.pop(),e}}function currentNameScopePrefix(){return 0===_nameScopeStack.length?\"\":_nameScopeStack.join(_nameScopeDivider)+_nameScopeDivider}function getScopedTensorName(e){if(!isValidTensorName(e))throw new Error(\"Not a valid tensor name: '\"+e+\"'\");return currentNameScopePrefix()+e}function getUniqueTensorName(e){if(!isValidTensorName(e))throw new Error(\"Not a valid tensor name: '\"+e+\"'\");nameMap.has(e)||nameMap.set(e,0);var t=nameMap.get(e);if(nameMap.set(e,nameMap.get(e)+1),t>0){var n=e+\"_\"+t;return nameMap.set(n,1),n}return e}var tensorNameRegex=new RegExp(/^[A-Za-z][A-Za-z0-9\\._\\/]*$/);function isValidTensorName(e){return!!e.match(tensorNameRegex)}function isInteger(e){return e===parseInt(e.toString(),10)}function arrayProd(e,t,n){null==t&&(t=0),null==n&&(n=e.length);for(var r=1,i=t;i2e3&&console.warn(\"Orthogonal initializer is being called on a matrix with more than 2000 (\"+e[0]*e[1]+\") elements: Slowness may result.\");var t=randomNormal$1(e[0]>e[1]?[e[1],e[0]]:e,0,1,\"float32\"),r=linalg.gramSchmidt(t);return e[0]>e[1]&&(r=r.transpose()),mul(getScalar(n.gain),r)})},t.prototype.getConfig=function(){return{gain:this.gain,seed:this.seed}},t.className=\"Orthogonal\",t}(Initializer);serialization.SerializationMap.register(Orthogonal);var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP={constant:\"Constant\",glorotNormal:\"GlorotNormal\",glorotUniform:\"GlorotUniform\",heNormal:\"HeNormal\",identity:\"Identity\",leCunNormal:\"LeCunNormal\",ones:\"Ones\",orthogonal:\"Orthogonal\",randomNormal:\"RandomNormal\",randomUniform:\"RandomUniform\",truncatedNormal:\"TruncatedNormal\",varianceScaling:\"VarianceScaling\",zeros:\"Zeros\"};function deserializeInitializer(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,\"initializer\")}function serializeInitializer(e){return serializeKerasObject(e)}function getInitializer(e){if(\"string\"==typeof e){var t=e in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP?INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e;return\"GlorotUniform\"===t?new GlorotUniform:\"GlorotNormal\"===t?new GlorotNormal:\"HeNormal\"===t?new HeNormal:\"LeCunNormal\"===t?new LeCunNormal:deserializeInitializer({className:t,config:{}})}return e instanceof Initializer?e:deserializeInitializer(e)}function zeros$1(){return new Zeros}function ones$1(){return new Ones}function constant(e){return new Constant(e)}function randomUniform$1(e){return new RandomUniform(e)}function randomNormal$2(e){return new RandomNormal(e)}function truncatedNormal$1(e){return new TruncatedNormal(e)}function identity(e){return new Identity(e)}function varianceScaling(e){return new VarianceScaling(e)}function glorotUniform(e){return new GlorotUniform(e)}function glorotNormal(e){return new GlorotNormal(e)}function heNormal(e){return new HeNormal(e)}function leCunNormal(e){return new LeCunNormal(e)}function orthogonal(e){return new Orthogonal(e)}var exports_initializers=Object.freeze({zeros:zeros$1,ones:ones$1,constant:constant,randomUniform:randomUniform$1,randomNormal:randomNormal$2,truncatedNormal:truncatedNormal$1,identity:identity,varianceScaling:varianceScaling,glorotUniform:glorotUniform,glorotNormal:glorotNormal,heNormal:heNormal,leCunNormal:leCunNormal,orthogonal:orthogonal});function isArrayOfShapes(e){return Array.isArray(e)&&Array.isArray(e[0])}function normalizeShapeList(e){return 0===e.length?[]:Array.isArray(e[0])?e:[e]}function getExactlyOneTensor(e){var t;if(Array.isArray(e)){if(1!==e.length)throw new ValueError(\"Expected Tensor length to be 1; got \"+e.length);t=e[0]}else t=e;return t}function getExactlyOneShape(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(1===e.length)return(e=e)[0];throw new ValueError(\"Expected exactly 1 Shape; got \"+e.length)}return e}function countParamsInWeights(e){for(var t=0,n=0,r=e;n1)throw new AttributeError(\"Layer \"+this.name+' has multiple inbound nodes, hence the notion of \"layer input\" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if(0===this.inboundNodes.length)throw new AttributeError(\"Layer \"+this.name+\" is not connected, no input to return.\");return singletonOrArray(this.getNodeAtIndex(0,\"input\").inputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"output\",{get:function(){if(0===this.inboundNodes.length)throw new AttributeError(\"Layer \"+this.name+\" has no inbound nodes.\");if(this.inboundNodes.length>1)throw new AttributeError(\"Layer \"+this.name+' has multiple inbound nodes, hence the notion of \"layer output\" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return singletonOrArray(this.getNodeAtIndex(0,\"output\").outputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"losses\",{get:function(){return this._losses},enumerable:!0,configurable:!0}),t.prototype.calculateLosses=function(){return this.losses.map(function(e){return e()})},Object.defineProperty(t.prototype,\"updates\",{get:function(){return this._updates},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"built\",{get:function(){return this._built},set:function(e){this._built=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"trainableWeights\",{get:function(){return this.trainable?this._trainableWeights:[]},set:function(e){this._trainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"nonTrainableWeights\",{get:function(){return this.trainable?this._nonTrainableWeights:this._trainableWeights.concat(this._nonTrainableWeights)},set:function(e){this._nonTrainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"weights\",{get:function(){return this.trainableWeights.concat(this.nonTrainableWeights)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"stateful\",{get:function(){return this._stateful},enumerable:!0,configurable:!0}),t.prototype.assertInputCompatibility=function(e){if(e=toList(e),null!=this.inputSpec&&0!==this.inputSpec.length){var t=toList(this.inputSpec);if(e.length!==t.length)throw new ValueError(\"Layer \"+this.name+\" expects \"+t.length+\" inputs, but it received \"+e.length+\" input tensors. Input received: \"+e);for(var n=0;ni.maxNDim)throw new ValueError(\"Input \"+n+\" is incompatible with layer \"+this.name+\": expected max_ndim=\"+i.maxNDim+\", found ndim=\"+a);if(null!=i.minNDim&&a=0?o[l]:o[o.length+l];if(null!=u&&-1===[u,null].indexOf(c))throw new ValueError(\"Input \"+n+\" is incompatible with layer \"+this.name+\": expected axis \"+l+\" of input shape to have value \"+u+\" but got shape \"+o+\".\")}}if(null!=i.shape)for(var p=0;p0&&Array.isArray(g[0])?g.map(function(r,i){return new SymbolicTensor(m,r,n,toList(e),t,n.name,i)}):new SymbolicTensor(m,g,n,toList(e),t,n.name),n.addInboundNode(e,f,null,null,d,g,t),null!=n.activityRegularizer)throw new NotImplementedError(\"Layer invocation in the presence of activity regularizer(s) is not supported yet.\");return f})},t.prototype.warnOnIncompatibleInputShape=function(e){if(null!=this.batchInputShape)if(e.length!==this.batchInputShape.length)console.warn(\"The rank of the input tensor provided (shape: \"+JSON.stringify(e)+\") does not match that of the batchInputShape (\"+JSON.stringify(this.batchInputShape)+\") of the layer \"+this.name);else{var t=!1;this.batchInputShape.forEach(function(n,r){null!=n&&null!=e[r]&&e[r]!==n&&(t=!0)}),t&&console.warn(\"The shape of the input tensor (\"+JSON.stringify(e)+\") does not match the expectation of layer \"+this.name+\": \"+JSON.stringify(this.batchInputShape))}},Object.defineProperty(t.prototype,\"outputShape\",{get:function(){if(null==this.inboundNodes||0===this.inboundNodes.length)throw new AttributeError(\"The layer \"+this.name+\" has never been called and thus has no defined output shape.\");for(var e=[],t=0,n=this.inboundNodes;t0)&&(t=e.sourceLayer,n=e.nodeIndex),0===t.inboundNodes.length)return[e];var r=t.inboundNodes[n];if(0===r.inboundLayers.length)return r.inputTensors;for(var i=[],a=0;a1||1===s.length&&s[0].inboundLayers.length>1){t=!1;break}r.push.apply(r,s)}if(t)for(var l=0,u=e.layers;l0&&(r=r.slice(0,r.length-1)+\" \"),r=(r+=e[i]).slice(0,t[i]),r+=\" \".repeat(t[i]-r.length);n(r)}function printLayerSummary(e,t,n){var r;try{r=JSON.stringify(e.outputShape)}catch(e){r=\"multiple\"}printRow([e.name+\" (\"+e.getClassName()+\")\",r,e.countParams().toString()],t,n)}function printLayerSummaryWithConnections(e,t,n,r){var i;try{i=JSON.stringify(e.outputShape)}catch(e){i=\"multiple\"}for(var a=[],o=0,s=e.inboundNodes;o0&&-1===n.indexOf(l)))for(var u=0;u0)throw new ValueError(p.length+\" of \"+r+\" weights are not set: \"+p);batchSetValue(u)}var Container=function(e){function t(n){var r=e.call(this,{})||this;if(r.containerNodes=new Set,r.name=n.name,null==r.name){var i=r.getClassName().toLowerCase();r.name=getUid(i)}if(r.supportsMasking=!1,r.trainable=!0,r.updatable=!0,Array.isArray(n.inputs)?r.inputs=n.inputs.slice():r.inputs=[n.inputs],Array.isArray(n.outputs)?r.outputs=n.outputs.slice():r.outputs=[n.outputs],unique(r.inputs).length!==r.inputs.length)throw new ValueError(\"The list of inputs passed to the model is redundant. All inputs should only appear once. Found: \"+r.inputs.map(function(e){return e.name}));unique(r.outputs).length!==r.outputs.length&&console.warn(\"The list of outputs passed to the model is redundant. All outputs should only appear once. Found: \"+r.outputs.map(function(e){return e.name})),r.inputLayers=[],r.inputLayersNodeIndices=[],r.inputLayersTensorIndices=[],r.outputLayers=[],r.outputLayersNodeIndices=[],r.outputLayersTensorIndices=[],r.layers=[];for(var a=0,o=r.outputs;a1 nodes\"),assert(0===u,\"input layer has >1 tensors\"),r.inputLayers.push(s),r.inputLayersNodeIndices.push(l),r.inputLayersTensorIndices.push(u)}r.inputNames=[],r.outputNames=[],r.feedInputShapes=[],r.feedInputNames=[],r.feedOutputNames=[];for(var h=0;h=0;)i.splice(i.indexOf(l),1);z.push(l)}},S=[],A=[],I=0,N=r.outputs;Ir?1:0});for(var j=0,W=U;j0)throw new ValueError(\"Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.\");if(!this.trainable)return[];for(var e=[],t=0,n=this.layers;t1)for(var s=0,l=o;s0){for(var d=[],g=0;g0&&e.apply(singletonOrArray(a),r)}function o(e){var r=e.name,a=deserialize(e,null!=t.customObjects?t.customObjects:{});n[r]=a;for(var o=0,s=e.inboundNodes;o0)a=!0;else if(isDataDict(e)){for(var o in e)if(e.hasOwnProperty(o)){a=!0;break}}else a=!0;if(a)throw new ValueError(\"Error when checking model \"+i+\" expected no data, but got \"+e)}return[]}if(null==e)return t.map(function(e){return null});var s;if(isDataDict(e)){e=e,s=[];for(var l=0,u=t;l1)throw new ValueError(\"The model \"+i+\" expects \"+t.length+\" Tensor(s), but only received one Tensor. Found: Tensor with shape \"+e.shape);s=[e]}for(var p=0;p=0&&g!==f)throw new ValueError(\"Error when checking \"+i+\": expected \"+t[p]+\" to have shape [\"+n[p]+\"], but got array with shape [\"+h.shape+\"].\")}}return s}function checkArrayLengths(e,t,n){var r=unique(e.map(function(e){return e.shape[0]}));r.sort();var i=unique(t.map(function(e){return e.shape[0]}));if(i.sort(),r.length>1)throw new ValueError(\"All input Tensors (x) should have the same number of samples. Got array shapes: \"+JSON.stringify(e.map(function(e){return e.shape})));if(i.length>1)throw new ValueError(\"All target Tensors (y) should have the same number of samples. Got array shapes: \"+JSON.stringify(t.map(function(e){return e.shape})));if(r.length>0&&i.length>0&&!util.arraysEqual(r,i))throw new ValueError(\"Input Tensors should have the same number of samples as target Tensors. Found \"+r[0]+\" input sample(s) and \"+i[0]+\" target sample(s).\")}function checkLossAndTargetCompatibility(e,t,n){for(var r=[meanSquaredError,binaryCrossentropy,categoricalCrossentropy],i=0;i=e&&(i=e),n.push([r,i]),r=i;return n}function sliceArrays(e,t,n){return null==e?[null]:Array.isArray(e)?e.map(function(e){return sliceAlongFirstAxis(e,t,n-t)}):sliceAlongFirstAxis(e,t,n-t)}function sliceArraysByIndices(e,t){return tidy(function(){return null==e?null:Array.isArray(e)?e.map(function(e){return sliceArraysByIndices(e,t)}):gather$1(e,\"int32\"===t.dtype?t:t.toInt())})}function checkInputData(e,t,n,r,i){var a;if(void 0===r&&(r=!0),void 0===i&&(i=\"\"),Array.isArray(e)){if(e.length!==t.length)throw new ValueError(\"Error when checking model \"+i+\": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see \"+t.length+\" Tensor(s), but instead got \"+e.length+\" Tensors(s).\");a=e}else{if(t.length>1)throw new ValueError(\"The model expects \"+t.length+\" \"+i+\" Tensors, but only received one Tensor. Found: array with shape \"+JSON.stringify(e.shape)+\".\");a=[e]}if(null!=n)for(var o=0;o1&&(t.metricsTensors.push([n,e]),t.metricsNames.push(t.outputNames[e]+\"_loss\"))}});var p=collectMetrics(e.metrics,this.outputNames);nameScope(\"metric\",function(){for(var e=function(e){if(-1!==c.indexOf(e))return\"continue\";!function(n){for(var r,i,a,o=function(n){if(-1!==[\"accuracy\",\"acc\",\"crossentropy\",\"ce\"].indexOf(n)){var o=t.internalOutputShapes[e];1===o[o.length-1]||t.lossFunctions[e]===binaryCrossentropy?-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=binaryAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=binaryCrossentropy$1):t.lossFunctions[e]===sparseCategoricalCrossentropy?-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=sparseCategoricalAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=sparseCategoricalCrossentropy$1):-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=categoricalAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=categoricalCrossentropy$1);var s=void 0;-1!==[\"accuracy\",\"acc\"].indexOf(n)?s=\"acc\":-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(s=\"ce\"),a=i,r=\"\"+s}else{var l=get$1(n);a=l,r=\"\"+n}var u;nameScope(r,function(){u=a}),function(e,n,r){t.outputNames.length>1&&(n=t.outputNames[e]+\"_\"+n),t.metricsNames.push(n),t.metricsTensors.push([r,e])}(e,r,u)},s=0,l=n;s0){var c=[];throw t.forEach(function(t,n){null==t&&c.push(e[n])}),new ValueError(\"Cannot find SymbolicTensors for output name(s): \"+JSON.stringify(c))}return t},t.prototype.predictLoop=function(e,t,n){var r=this;return void 0===t&&(t=32),void 0===n&&(n=!1),tidy(function(){var i=r.checkNumSamples(e);if(n)throw new NotImplementedError(\"Verbose predictLoop() is not implemented yet.\");for(var a=makeBatches(i,t),o=[],s=function(t){var n=tidy(function(){var n=a[t][0],i=a[t][1],o=sliceArrays(e,n,i),s=[];if(Array.isArray(o))for(var l=0;l0&&e[0].shape[0]%r!=0)throw new ValueError(\"In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size \"+r+\". Found: \"+e[0].shape[0]+\" sample(s).\");return[e,t,null]},t.prototype.fitLoop=function(e,t,n,r,i,a,o,s,l,u,c,p,h,d){return __awaiter(this,void 0,void 0,function(){var g,f,m,y,v,b,z,w=this;return __generator(this,function(S){switch(S.label){case 0:if(null==r&&(r=32),null==i&&(i=1),null==u&&(u=!0),null==p&&(p=0),g=!1,null!=s&&null!=l&&(g=!0),null!=d&&(g=!0,null==h))throw new ValueError(\"Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.\");if(null!=(f=this.checkNumSamples(t,r,h,\"steps_per_epoch\"))&&(m=range(0,f)),this.history=new History,o=(o=null==o?[new BaseLogger]:[new BaseLogger].concat(o)).concat([this.history]),a>0)throw new NotImplementedError(\"Verbose mode is not implemented yet.\");return(y=new CallbackList(o)).setModel(this),y.setParams({epochs:i,initialEpoch:p,steps:h,verbose:a,doValidation:g,metrics:c}),[4,y.onTrainBegin()];case 1:S.sent(),this.stopTraining=!1,v=function(i){var a,o,c,p,d;return __generator(this,function(v){switch(v.label){case 0:return[4,y.onEpochBegin(i)];case 1:if(v.sent(),a={},null==h)return[3,2];throw new NotImplementedError(\"stepsPerEpoch mode is not implemented yet.\");case 2:if(\"batch\"===u)throw new NotImplementedError(\"batch shuffling is not implemneted yet\");u&&util.shuffle(m),o=tensor1d(m),c=makeBatches(f,r),p=function(i){var u;return __generator(this,function(p){switch(p.label){case 0:return u={},[4,y.onBatchBegin(i,u)];case 1:return p.sent(),tidy(function(){var p=c[i][0],h=c[i][1],d=sliceAlongFirstAxis(o,p,h-p);u.batch=i,u.size=h-p;for(var f=sliceArraysByIndices(t,d),m=e(f),y=0;y1)i+=\"_\"+count(e.slice(0,n),r);t.push(i)}return t},t.prototype.makeTestFunction=function(){var e=this;this.testFunction=function(t){return tidy(function(){for(var n,r=[],i=t.slice(0,e.inputs.length),a=t.slice(e.inputs.length,e.inputs.length+e.outputs.length),o=[],s=0;s0){if(s=!0,2!==n.validationData.length)throw 3===n.validationData.length?new NotImplementedError(\"validationData including sample weights is not supported yet.\"):new ValueError(\"When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; \"+n.validationData+\" is invalid.\");l=n.validationData[0],u=n.validationData[1],h=this.standardizeUserData(l,u,!0,r),l=h[0],u=h[1],c=l.concat(u)}else null!=n.validationSplit&&n.validationSplit>0&&n.validationSplit<1?(s=!0,d=Math.floor(a[0].shape[0]*(1-n.validationSplit)),g=a[0].shape[0],l=sliceArrays(a,d,g),a=sliceArrays(a,0,d),u=sliceArrays(o,d,g),o=sliceArrays(o,0,d),p=!0,c=l.concat(u)):null!=n.validationSteps&&(s=!0);return f=a.concat(o),this.checkTrainableWeightsConsistency(),m=function(e){var t=e.slice(0,S.inputs.length),n=e.slice(S.inputs.length,S.inputs.length+S.outputs.length),r=[],i=S.collectedTrainableWeights.map(function(e){return e.read()});return[S.optimizer.minimize(function(){for(var e=[],i=0;i1)throw new ValueError(\"Found more than one (\"+n.length+\") save handlers for URL '\"+e+\"'\");e=n[0]}if(null==e.save)throw new ValueError(\"Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.\");return[4,io.encodeWeights(this.getNamedWeights(t))];case 1:return r=s.sent(),i=!1,a=null,o=this.toJSON(a,i),[2,e.save({modelTopology:o,weightData:r.data,weightSpecs:r.specs})]}})})},t.className=\"Model\",t}(Container);function loadModelInternal(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){if(\"string\"==typeof e){if(0===(t=io.getLoadHandlers(e)).length)t.push(io.browserHTTPRequest(e));else if(t.length>1)throw new ValueError(\"Found more than one (\"+t.length+\") load handlers for URL '\"+e+\"'\");e=t[0]}return[2,loadModelFromIOHandler(e)]})})}function loadModelFromIOHandler(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,i,a,o;return __generator(this,function(s){switch(s.label){case 0:if(null==e.load)throw new ValueError(\"Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.\");return[4,e.load()];case 1:if(n=s.sent(),null!=(r=n.modelTopology).model_config&&(r=r.model_config),i=deserialize(convertPythonicToTs(r),t),null!=n.weightData){if(null==n.weightSpecs)throw new ValueError(\"Model artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.\");a=!1,o=!0,i.loadWeights(io.decodeWeights(n.weightData,n.weightSpecs),a,o)}return[2,i]}})})}serialization.SerializationMap.register(Model);var Sequential=function(e){function t(t){var n=e.call(this,{inputs:[],outputs:[]})||this;if(t=t||{},n.trainable=!0,n._updatable=!0,n.built=!1,n.name=null!=t.name?t.name:getUid(\"sequential_\"),null!=t.layers)for(var r=0,i=t.layers;r 0 but got \"+JSON.stringify(e.filters))},t}(BaseConv),Conv2D=function(e){function t(n){var r=e.call(this,2,n)||this;return t.verifyConfig(n),r}return __extends(t,e),t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.rank,t},t.verifyConfig=function(e){if(\"number\"!=typeof e.kernelSize&&!checkArrayTypeAndLength(e.kernelSize,\"number\",1,2))throw new ValueError(\"Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received \"+JSON.stringify(e.kernelSize)+\".\")},t.className=\"Conv2D\",t}(Conv);serialization.SerializationMap.register(Conv2D);var Conv2DTranspose=function(e){function t(t){var n=e.call(this,t)||this;if(n.inputSpec=[new InputSpec({ndim:4})],\"same\"!==n.padding&&\"valid\"!==n.padding)throw new ValueError(\"Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode \"+n.padding);return n}return __extends(t,e),t.prototype.build=function(e){if(4!==(e=getExactlyOneShape(e)).length)throw new ValueError(\"Input should have rank 4; Received input shape: \"+JSON.stringify(e));var t=\"channelsFirst\"===this.dataFormat?1:e.length-1;if(null==e[t])throw new ValueError(\"The channel dimension of the inputs should be defined. Found `None`.\");var n,r=e[t],i=this.kernelSize.concat([this.filters,r]);this.kernel=this.addWeight(\"kernel\",i,\"float32\",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight(\"bias\",[this.filters],\"float32\",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new InputSpec({ndim:4,axes:(n={},n[t]=r,n)})],this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);if(4!==t.shape.length)throw new ValueError(\"Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-\"+t.shape.length);var r,i,a=t.shape,o=a[0];\"channelsFirst\"===n.dataFormat?(r=2,i=3):(r=1,i=2);var s=a[r],l=a[i],u=n.kernelSize[0],c=n.kernelSize[1],p=n.strides[0],h=n.strides[1],d=[o,deconvLength(s,p,u,n.padding),deconvLength(l,h,c,n.padding),n.filters];\"channelsLast\"!==n.dataFormat&&(t=transpose(t,[0,2,3,1]));var g=conv2dTranspose(t,n.kernel.read(),d,n.strides,n.padding);return\"channelsLast\"!==n.dataFormat&&(g=transpose(g,[0,3,1,2])),null!=n.bias&&(g=biasAdd(g,n.bias.read(),n.dataFormat)),null!=n.activation&&(g=n.activation.apply(g)),g})},t.prototype.computeOutputShape=function(e){var t,n,r,i=(e=getExactlyOneShape(e)).slice();\"channelsFirst\"===this.dataFormat?(t=1,n=2,r=3):(t=3,n=1,r=2);var a=this.kernelSize[0],o=this.kernelSize[1],s=this.strides[0],l=this.strides[1];return i[t]=this.filters,i[n]=deconvLength(i[n],s,a,this.padding),i[r]=deconvLength(i[r],l,o,this.padding),i},t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.dilationRate,t},t.className=\"Conv2DTranspose\",t}(Conv2D);serialization.SerializationMap.register(Conv2DTranspose);var SeparableConv=function(e){function t(t,n){var r=e.call(this,t,n)||this;if(r.DEFAULT_DEPTHWISE_INITIALIZER=\"glorotUniform\",r.DEFAULT_POINTWISE_INITIALIZER=\"glorotUniform\",r.depthwiseKernel=null,r.pointwiseKernel=null,null==n.filters)throw new ValueError(\"The `filters` configuration field is required by SeparableConv, but is unspecified.\");if(null!=n.kernelInitializer||null!=n.kernelRegularizer||null!=n.kernelConstraint)throw new ValueError(\"Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.\");if(null!=n.padding&&\"same\"!==n.padding&&\"valid\"!==n.padding)throw new ValueError(\"SeparableConv\"+r.rank+\"D supports only padding modes: 'same' and 'valid', but received \"+JSON.stringify(n.padding));return r.depthMultiplier=null==n.depthMultiplier?1:n.depthMultiplier,r.depthwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_DEPTHWISE_INITIALIZER),r.depthwiseRegularizer=getRegularizer(n.depthwiseRegularizer),r.depthwiseConstraint=getConstraint(n.depthwiseConstraint),r.pointwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_POINTWISE_INITIALIZER),r.pointwiseRegularizer=getRegularizer(n.pointwiseRegularizer),r.pointwiseConstraint=getConstraint(n.pointwiseConstraint),r}return __extends(t,e),t.prototype.build=function(e){if((e=getExactlyOneShape(e)).length1)throw new ValueError(\"Can not merge tensors with different batch sizes. Got tensors with shapes: \"+JSON.stringify(e)+\".\");for(var i=null==e[0]?null:e[0].slice(1),a=1;a1){var y=range(1,s).concat([0]);t.push(transpose(h,y)),u=!0}else t.push(h)}var v=n.mergeFunction(t),b=v.rank;if(u)if(null==b){var z=v.shape;f=[g=z[z.length-1]].concat(z.slice(0,z.length-1));v=transpose(v.reshape([-1,g]),[1,0]).reshape(f)}else if(b>1){y=[b-1].concat(range(0,b-1));v=transpose(v,y)}return v}return n.mergeFunction(e)})},t.prototype.computeOutputShape=function(e){var t;t=null==(e=e)[0]?null:e[0].slice(1);for(var n=1;n1)throw new ValueError(\"A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: \"+JSON.stringify(e))}},t.prototype.mergeFunction=function(e){var t=this;return tidy(function(){return concatenate(e,t.axis)})},t.prototype.computeOutputShape=function(e){if(!Array.isArray(e)||!Array.isArray(e[0]))throw new ValueError(\"A `Concatenate` layer should be called on a list of inputs.\");for(var t=e,n=t[0].slice(),r=this.axis<0?n.length+this.axis:this.axis,i=0,a=t.slice(1);i=0?this.axis:this.axis+e.length,n=e[t];if(null==n)throw new ValueError(\"Axis \"+t+\" of input tensor should have a defined dimension but the layer received an input with shape \"+JSON.stringify(e)+\".\");this.inputSpec=[new InputSpec({ndim:e.length,axes:(r={},r[t]=n,r)})];var r,i=[n];this.scale&&(this.gamma=this.addWeight(\"gamma\",i,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight(\"beta\",i,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight(\"moving_mean\",i,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight(\"moving_variance\",i,null,this.movingVarianceInitializer,null,!1),this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var r=null!=t.training&&t.training,i=getExactlyOneTensor(e),a=i.shape,o=a.length,s=range(0,o),l=n.axis>=0?n.axis:n.axis+o;s.splice(l,1);var u=pyListRepeat(1,o);u[l]=a[l];var c=s.slice();c.sort();var p=!util.arraysEqual(c,range(0,o).slice(0,o-1));if(!r)return function(){if(p){var e=n.movingMean.read().reshape(u),t=n.movingVariance.read().reshape(u),r=n.center?n.beta.read().reshape(u):null,a=n.scale?n.gamma.read().reshape(u):null;return batchNormalization(i,e,t,r,a,n.epsilon)}return batchNormalization(i,n.movingMean.read(),n.movingVariance.read(),null==n.beta?null:n.beta.read(),null==n.gamma?null:n.gamma.read(),n.epsilon)}();var h=normalizeBatchInTraining(i,n.gamma.read(),n.beta.read(),s,n.epsilon),d=h[0],g=h[1],f=h[2],m=arrayProd(s.map(function(e){return i.shape[e]})),y=f.mul(getScalar(m/(m-(1+n.epsilon))));return function(){n.stepCount++;var e=movingAverage(n.movingMean.read(),g,n.momentum,n.stepCount);n.movingMean.write(e);var t=movingAverage(n.movingVariance.read(),y,n.momentum,n.stepCount);n.movingVariance.write(t)}(),d})},t.prototype.getConfig=function(){var t={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:serializeInitializer(this.betaInitializer),gammaInitializer:serializeInitializer(this.gammaInitializer),movingMeanInitializer:serializeInitializer(this.movingMeanInitializer),movingVarianceInitializer:serializeInitializer(this.movingVarianceInitializer),betaRegularizer:serializeRegularizer(this.betaRegularizer),gammaRegularizer:serializeRegularizer(this.gammaRegularizer),betaConstraint:serializeConstraint(this.betaConstraint),gammaConstraint:serializeConstraint(this.gammaConstraint)},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className=\"BatchNormalization\",t}(Layer);function spatial2dPadding(e,t,n){return tidy(function(){if(4!==e.rank)throw new ValueError(\"temporalPadding expects input tensor to be 4-D, but received a \"+e.rank+\"-D tensor.\");if(null==t&&(t=[[1,1],[1,1]]),2!==t.length||2!==t[0].length||2!==t[1].length)throw new ValueError(\"spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.\");if(null==n&&(n=imageDataFormat()),\"channelsLast\"!==n&&\"channelsFirst\"!==n)throw new ValueError(\"Unknown data format: \"+n+\". Supported data formats are 'channelsLast' and 'channelsFirst.\");var r;return r=\"channelsFirst\"===n?[[0,0],[0,0],t[0],t[1]]:[[0,0],t[0],t[1],[0,0]],pad(e,r)})}serialization.SerializationMap.register(BatchNormalization);var ZeroPadding2D=function(e){function t(t){var n=this;if(null==t&&(t={}),(n=e.call(this,t)||this).dataFormat=null==t.dataFormat?imageDataFormat():t.dataFormat,null==t.padding)n.padding=[[1,1],[1,1]];else if(\"number\"==typeof t.padding)n.padding=[[t.padding,t.padding],[t.padding,t.padding]];else{if(t.padding=t.padding,2!==t.padding.length)throw new ValueError(\"ZeroPadding2D expects padding to be a length-2 array, but received a length-\"+t.padding.length+\" array.\");var r=void 0,i=void 0;if(\"number\"==typeof t.padding[0])r=[t.padding[0],t.padding[0]],i=[t.padding[1],t.padding[1]];else{if(t.padding=t.padding,2!==t.padding[0].length)throw new ValueError(\"ZeroPadding2D expects height padding to be a length-2 array, but received a length-\"+t.padding[0].length+\" array.\");if(r=t.padding[0],2!==t.padding[1].length)throw new ValueError(\"ZeroPadding2D expects width padding to be a length-2 array, but received a length-\"+t.padding[1].length+\" array.\");i=t.padding[1]}n.padding=[r,i]}return n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t,n;return e=getExactlyOneShape(e),\"channelsFirst\"===this.dataFormat?(t=null!=e[2]&&e[2]>=0?e[2]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[3]&&e[3]>=0?e[3]+this.padding[1][0]+this.padding[1][1]:null,[e[0],e[1],t,n]):(t=null!=e[1]&&e[1]>=0?e[1]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[2]&&e[2]>=0?e[2]+this.padding[1][0]+this.padding[1][1]:null,[e[0],t,n,e[3]])},t.prototype.call=function(e,t){var n=this;return tidy(function(){return spatial2dPadding(getExactlyOneTensor(e),n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={padding:this.padding,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className=\"ZeroPadding2D\",t}(Layer);function pool2d(e,t,n,r,i,a){return tidy(function(){var o;checkDataFormat(i),checkPoolMode(a),checkPaddingMode(r),null==n&&(n=[1,1]),null==r&&(r=\"valid\"),null==i&&(i=imageDataFormat()),null==a&&(a=\"max\"),e=preprocessConv2DInput(e,i);var s=\"same\"===r?\"same\":\"valid\";return o=\"max\"===a?maxPool(e,t,n,s):avgPool(e,t,n,s),\"channelsFirst\"===i&&(o=transpose(o,[0,3,1,2])),o})}serialization.SerializationMap.register(ZeroPadding2D);var Pooling1D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=2),n=e.call(this,t)||this,\"number\"==typeof t.poolSize)n.poolSize=[t.poolSize];else{if(!Array.isArray(t.poolSize)||1!==t.poolSize.length||\"number\"!=typeof t.poolSize[0])throw new ValueError(\"poolSize for 1D convolutional layer must be a number or an Array of a single number, but received \"+JSON.stringify(t.poolSize));n.poolSize=t.poolSize}if(null==t.strides)n.strides=n.poolSize;else if(\"number\"==typeof t.strides)n.strides=[t.strides];else{if(!Array.isArray(t.strides)||1!==t.strides.length||\"number\"!=typeof t.strides[0])throw new ValueError(\"strides for 1D convolutional layer must be a number or an Array of a single number, but received \"+JSON.stringify(t.strides));n.strides=t.strides}return n.padding=null==t.padding?\"valid\":t.padding,checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t=convOutputLength((e=getExactlyOneShape(e))[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){n.invokeCallHook(e,t),e=expandDims(getExactlyOneTensor(e),2);var r=n.poolingFunction(getExactlyOneTensor(e),[n.poolSize[0],1],[n.strides[0],1],n.padding,\"channelsLast\");return squeeze(r,[2])})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"max\")},t.className=\"MaxPooling1D\",t}(Pooling1D);serialization.SerializationMap.register(MaxPooling1D);var AveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"avg\")},t.className=\"AveragePooling1D\",t}(Pooling1D);serialization.SerializationMap.register(AveragePooling1D);var Pooling2D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=[2,2]),(n=e.call(this,t)||this).poolSize=Array.isArray(t.poolSize)?t.poolSize:[t.poolSize,t.poolSize],null==t.strides)n.strides=n.poolSize;else if(Array.isArray(t.strides)){if(2!==t.strides.length)throw new ValueError(\"If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length \"+t.strides.length+\".\");n.strides=t.strides}else n.strides=[t.strides,t.strides];return n.padding=null==t.padding?\"valid\":t.padding,n.dataFormat=null==t.dataFormat?\"channelsLast\":t.dataFormat,checkDataFormat(n.dataFormat),checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){e=getExactlyOneShape(e);var t=\"channelsFirst\"===this.dataFormat?e[2]:e[1],n=\"channelsFirst\"===this.dataFormat?e[3]:e[2];return t=convOutputLength(t,this.poolSize[0],this.padding,this.strides[0]),n=convOutputLength(n,this.poolSize[1],this.padding,this.strides[1]),\"channelsFirst\"===this.dataFormat?[e[0],e[1],t,n]:[e[0],t,n,e[3]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){return n.invokeCallHook(e,t),n.poolingFunction(getExactlyOneTensor(e),n.poolSize,n.strides,n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"max\")},t.className=\"MaxPooling2D\",t}(Pooling2D);serialization.SerializationMap.register(MaxPooling2D);var AveragePooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"avg\")},t.className=\"AveragePooling2D\",t}(Pooling2D);serialization.SerializationMap.register(AveragePooling2D);var GlobalPooling1D=function(e){function t(t){var n=e.call(this,t)||this;return n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return[e[0],e[2]]},t.prototype.call=function(e,t){throw new NotImplementedError},t}(Layer),GlobalAveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return mean(t,1)})},t.className=\"GlobalAveragePooling1D\",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalAveragePooling1D);var GlobalMaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return max(t,1)})},t.className=\"GlobalMaxPooling1D\",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalMaxPooling1D);var GlobalPooling2D=function(e){function t(t){var n=e.call(this,t)||this;return n.dataFormat=null==t.dataFormat?\"channelsLast\":t.dataFormat,checkDataFormat(n.dataFormat),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return e=e,\"channelsLast\"===this.dataFormat?[e[0],e[3]]:[e[0],e[1]]},t.prototype.call=function(e,t){throw new NotImplementedError},t.prototype.getConfig=function(){var t={dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),GlobalAveragePooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return\"channelsLast\"===n.dataFormat?mean(t,[1,2]):mean(t,[2,3])})},t.className=\"GlobalAveragePooling2D\",t}(GlobalPooling2D);serialization.SerializationMap.register(GlobalAveragePooling2D);var GlobalMaxPooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return\"channelsLast\"===n.dataFormat?max(t,[1,2]):max(t,[2,3])})},t.className=\"GlobalMaxPooling2D\",t}(GlobalPooling2D);function standardizeArgs(e,t,n,r){if(Array.isArray(e)){if(null!=t||null!=n)throw new ValueError(\"When inputs is an array, neither initialState or constants should be provided\");null!=r&&(n=e.slice(e.length-r,e.length),e=e.slice(0,e.length-r)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function i(e){return null==e||Array.isArray(e)?e:[e]}return{inputs:e,initialState:t=i(t),constants:n=i(n)}}function rnn(e,t,n,r,i,a,o,s){void 0===r&&(r=!1),void 0===o&&(o=!1);var l=t.shape.length;if(l<3)throw new ValueError(\"Input should be at least 3D, but is \"+l+\"D.\");var u,c,p=[1,0].concat(range(2,l));if(t=transpose(t,p),null!=i)throw new NotImplementedError(\"The rnn() function of the deeplearn.js backend does not support masking yet.\");if(null!=a)throw new NotImplementedError(\"The rnn() functoin of the deeplearn.js backend does not support constants yet.\");o&&console.warn(\"Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend.\"),r&&(t=reverse(t,0));for(var h=n,d=t.shape[0],g=0;g1?tile$1(n,[1,e]):n}):t.cell.stateSize>1?[tile$1(n,[1,t.cell.stateSize])]:[n]})},Object.defineProperty(t.prototype,\"trainableWeights\",{get:function(){return this.trainable?this.cell.trainableWeights:[]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"nonTrainableWeights\",{get:function(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights},enumerable:!0,configurable:!0}),t.prototype.getConfig=function(){var t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};null!=this.numConstants&&(t.numConstants=this.numConstants);var n=this.cell.getConfig();t.cell={className:this.cell.getClassName(),config:n};var r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t.className=\"RNN\",t}(Layer);serialization.SerializationMap.register(RNN);var RNNCell=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t}(Layer),SimpleRNNCell=function(e){function t(t){var n=e.call(this,t)||this;return n.DEFAULT_ACTIVATION=\"tanh\",n.DEFAULT_KERNEL_INITIALIZER=\"glorotNormal\",n.DEFAULT_RECURRENT_INITIALIZER=\"orthogonal\",n.DEFAULT_BIAS_INITIALIZER=\"zeros\",n.units=t.units,n.activation=getActivation(null==t.activation?n.DEFAULT_ACTIVATION:t.activation),n.useBias=null==t.useBias||t.useBias,n.kernelInitializer=getInitializer(t.kernelInitializer||n.DEFAULT_KERNEL_INITIALIZER),n.recurrentInitializer=getInitializer(t.recurrentInitializer||n.DEFAULT_RECURRENT_INITIALIZER),n.biasInitializer=getInitializer(t.biasInitializer||n.DEFAULT_BIAS_INITIALIZER),n.kernelRegularizer=getRegularizer(t.kernelRegularizer),n.recurrentRegularizer=getRegularizer(t.recurrentRegularizer),n.biasRegularizer=getRegularizer(t.biasRegularizer),n.kernelConstraint=getConstraint(t.kernelConstraint),n.recurrentConstraint=getConstraint(t.recurrentConstraint),n.biasConstraint=getConstraint(t.biasConstraint),n.dropout=min$1([1,max$1([0,null==t.dropout?0:t.dropout])]),n.recurrentDropout=min$1([1,max$1([0,null==t.recurrentDropout?0:t.recurrentDropout])]),n.stateSize=n.units,n.dropoutMask=null,n.recurrentDropoutMask=null,n}return __extends(t,e),t.prototype.build=function(e){e=getExactlyOneShape(e),this.kernel=this.addWeight(\"kernel\",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight(\"recurrent_kernel\",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight(\"bias\",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){if(2!==(e=e).length)throw new ValueError(\"SimpleRNNCell expects 2 input Tensors, got \"+e.length+\".\");var r=e[1];e=e[0];var i,a=null!=t.training&&t.training;01){for(var a=[],o=0;o= 3D, but received input shape \"+JSON.stringify(t));this.inputSpec=[{shape:t}];var n=[t[0]].concat(t.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),e.prototype.build.call(this,t)},t.prototype.computeOutputShape=function(e){var t=[(e=getExactlyOneShape(e))[0]].concat(e.slice(2)),n=this.layer.computeOutputShape(t),r=e[1];return[n[0],r].concat(n.slice(1))},t.prototype.call=function(e,t){var n=this;return tidy(function(){return rnn(function(e,r){return[n.layer.call(e,t),[]]},e=getExactlyOneTensor(e),[],!1,null,null,!1,e.shape[1])[1]})},t.className=\"TimeDistributed\",t}(Wrapper);serialization.SerializationMap.register(TimeDistributed);var VALID_BIDIRECTIONAL_MERGE_MODES=[\"sum\",\"mul\",\"concat\",\"ave\"];function checkBidirectionalMergeMode(e){checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES,\"BidirectionalMergeMode\",e)}var Bidirectional=function(e){function t(t){var n=e.call(this,t)||this,r=t.layer.getConfig();if(n.forwardLayer=deserialize({className:t.layer.getClassName(),config:r}),r.goBackwards=!0!==r.goBackwards,n.backwardLayer=deserialize({className:t.layer.getClassName(),config:r}),n.forwardLayer.name=\"forward_\"+n.forwardLayer.name,n.backwardLayer.name=\"backward_\"+n.backwardLayer.name,checkBidirectionalMergeMode(t.mergeMode),n.mergeMode=t.mergeMode,t.weights)throw new NotImplementedError(\"weights support is not implemented for Bidirectional layer yet.\");return n._stateful=t.layer.stateful,n.returnSequences=t.layer.returnSequences,n.returnState=t.layer.returnState,n.supportsMasking=!0,n._trainable=!0,n.inputSpec=t.layer.inputSpec,n.numConstants=null,n}return __extends(t,e),Object.defineProperty(t.prototype,\"trainable\",{get:function(){return this._trainable},set:function(e){this._trainable=e,null!=this.forwardLayer&&(this.forwardLayer.trainable=e),null!=this.backwardLayer&&(this.backwardLayer.trainable=e)},enumerable:!0,configurable:!0}),t.prototype.getWeights=function(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())},t.prototype.setWeights=function(e){var t=e.length,n=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,n)),this.backwardLayer.setWeights(e.slice(n))},t.prototype.computeOutputShape=function(e){var t,n,r,i=this.forwardLayer.computeOutputShape(e);return Array.isArray(i)&&Array.isArray(i[0])||(i=[i]),i=i,this.returnState?(r=i.slice(1),t=i[0]):t=i[0],t=t,\"concat\"===this.mergeMode?(t[t.length-1]*=2,n=[t]):n=null==this.mergeMode?[t,t.slice()]:[t],this.returnState?null==this.mergeMode?n.concat(r).concat(r.slice()):[t].concat(r).concat(r.slice()):singletonOrArray(n)},t.prototype.apply=function(t,n){var r=null==n?null:n.initialState,i=null==n?null:n.constants;null==n&&(n={});var a=standardizeArgs(t,r,i,this.numConstants);if(t=a.inputs,r=a.initialState,i=a.constants,Array.isArray(t)&&(r=t.slice(1),t=t[0]),(null==r||0===r.length)&&null==i)return e.prototype.apply.call(this,t,n);var o=[],s=[];if(null!=r){var l=r.length;if(l%2>0)throw new ValueError(\"When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.\");n.initialState=r,o.push.apply(o,r);var u=r.map(function(e){return new InputSpec({shape:e.shape})});this.forwardLayer.stateSpec=u.slice(0,l/2),this.backwardLayer.stateSpec=u.slice(l/2),s.push.apply(s,u)}if(null!=i)throw new NotImplementedError(\"Support for constants in Bidirectional layers is not implemented yet.\");for(var c=o[0]instanceof SymbolicTensor,p=0,h=o;p0&&n[n.length-1])&&(6===o[0]||2===o[0])){s=0;continue}if(3===o[0]&&(!n||o[1]>n[0]&&o[1]= 0x80 (not a basic code point)\",\"invalid-input\":\"Invalid input\"},x=u-m,v=Math.floor,I=String.fromCharCode;function O(e){throw RangeError(b[e])}function w(e,t){for(var a=e.length,r=[];a--;)r[a]=t(e[a]);return r}function V(e,t){var a=e.split(\"@\"),r=\"\";return a.length>1&&(r=a[0]+\"@\",e=a[1]),r+w((e=e.replace(P,\".\")).split(\".\"),t).join(\".\")}function T(e){for(var t,a,r=[],n=0,o=e.length;n=55296&&t<=56319&&n65535&&(t+=I((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+=I(e)}).join(\"\")}function $(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function _(e,t,a){var r=0;for(e=a?v(e/c):e>>1,e+=v(e/t);e>x*l>>1;r+=u)e=v(e/x);return v(r+(x+1)*e/(e+d))}function A(e){var t,a,r,n,o,s,i,d,c,g,N,P=[],b=e.length,x=0,I=h,w=f;for((a=e.lastIndexOf(y))<0&&(a=0),r=0;r=128&&O(\"not-basic\"),P.push(e.charCodeAt(r));for(n=a>0?a+1:0;n=b&&O(\"invalid-input\"),((d=(N=e.charCodeAt(n++))-48<10?N-22:N-65<26?N-65:N-97<26?N-97:u)>=u||d>v((p-x)/s))&&O(\"overflow\"),x+=d*s,!(d<(c=i<=w?m:i>=w+l?l:i-w));i+=u)s>v(p/(g=u-c))&&O(\"overflow\"),s*=g;w=_(x-o,t=P.length+1,0==o),v(x/t)>p-I&&O(\"overflow\"),I+=v(x/t),x%=t,P.splice(x++,0,I)}return k(P)}function S(e){var t,a,r,n,o,s,i,d,c,g,N,P,b,x,w,V=[];for(P=(e=T(e)).length,t=h,a=0,o=f,s=0;s=t&&Nv((p-a)/(b=r+1))&&O(\"overflow\"),a+=(i-t)*b,t=i,s=0;sp&&O(\"overflow\"),N==t){for(d=a,c=u;!(d<(g=c<=o?m:c>=o+l?l:c-o));c+=u)w=d-g,x=u-g,V.push(I($(g+w%x,0))),d=v(w/x);V.push(I($(d,0))),o=_(a,b,r==n),a=0,++r}++a,++t}return V.join(\"\")}if(s={version:\"1.3.2\",ucs2:{decode:T,encode:k},decode:A,encode:S,toASCII:function(e){return V(e,function(e){return N.test(e)?\"xn--\"+S(e):e})},toUnicode:function(e){return V(e,function(e){return g.test(e)?A(e.slice(4).toLowerCase()):e})}},r&&n)if(e.exports==r)n.exports=s;else for(i in s)s.hasOwnProperty(i)&&(r[i]=s[i]);else a.punycode=s}(commonjsGlobal)}),util$1={isString:function(e){return\"string\"==typeof e},isObject:function(e){return\"object\"==typeof e&&null!==e},isNull:function(e){return null===e},isNullOrUndefined:function(e){return null==e}};function hasOwnProperty(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var decode=function(e,t,a,r){t=t||\"&\",a=a||\"=\";var n={};if(\"string\"!=typeof e||0===e.length)return n;var o=/\\+/g;e=e.split(t);var s=1e3;r&&\"number\"==typeof r.maxKeys&&(s=r.maxKeys);var i=e.length;s>0&&i>s&&(i=s);for(var p=0;p=0?(u=c.substr(0,f),m=c.substr(f+1)):(u=c,m=\"\"),l=decodeURIComponent(u),d=decodeURIComponent(m),hasOwnProperty(n,l)?Array.isArray(n[l])?n[l].push(d):n[l]=[n[l],d]:n[l]=d}return n},stringifyPrimitive=function(e){switch(typeof e){case\"string\":return e;case\"boolean\":return e?\"true\":\"false\";case\"number\":return isFinite(e)?e:\"\";default:return\"\"}},encode=function(e,t,a,r){return t=t||\"&\",a=a||\"=\",null===e&&(e=void 0),\"object\"==typeof e?Object.keys(e).map(function(r){var n=encodeURIComponent(stringifyPrimitive(r))+a;return Array.isArray(e[r])?e[r].map(function(e){return n+encodeURIComponent(stringifyPrimitive(e))}).join(t):n+encodeURIComponent(stringifyPrimitive(e[r]))}).join(t):r?encodeURIComponent(stringifyPrimitive(r))+a+encodeURIComponent(stringifyPrimitive(e)):\"\"},querystring=createCommonjsModule(function(e,t){t.decode=t.parse=decode,t.encode=t.stringify=encode}),querystring_1=querystring.decode,querystring_2=querystring.parse,querystring_3=querystring.encode,querystring_4=querystring.stringify,parse=urlParse,format=urlFormat;function Url(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}var protocolPattern=/^([a-z0-9.+-]+:)/i,portPattern=/:[0-9]*$/,simplePathPattern=/^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/,delims=[\"<\",\">\",'\"',\"`\",\" \",\"\\r\",\"\\n\",\"\\t\"],unwise=[\"{\",\"}\",\"|\",\"\\\\\",\"^\",\"`\"].concat(delims),autoEscape=[\"'\"].concat(unwise),nonHostChars=[\"%\",\"/\",\"?\",\";\",\"#\"].concat(autoEscape),hostEndingChars=[\"/\",\"?\",\"#\"],hostnameMaxLen=255,hostnamePartPattern=/^[+a-z0-9A-Z_-]{0,63}$/,hostnamePartStart=/^([+a-z0-9A-Z_-]{0,63})(.*)$/,unsafeProtocol={javascript:!0,\"javascript:\":!0},hostlessProtocol={javascript:!0,\"javascript:\":!0},slashedProtocol={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,\"http:\":!0,\"https:\":!0,\"ftp:\":!0,\"gopher:\":!0,\"file:\":!0};function urlParse(e,t,a){if(e&&util$1.isObject(e)&&e instanceof Url)return e;var r=new Url;return r.parse(e,t,a),r}function urlFormat(e){return util$1.isString(e)&&(e=urlParse(e)),e instanceof Url?e.format():Url.prototype.format.call(e)}Url.prototype.parse=function(e,t,a){if(!util$1.isString(e))throw new TypeError(\"Parameter 'url' must be a string, not \"+typeof e);var r=e.indexOf(\"?\"),n=-1!==r&&r127?b+=\"x\":b+=P[x];if(!b.match(hostnamePartPattern)){var I=g.slice(0,f),O=g.slice(f+1),w=P.match(hostnamePartStart);w&&(I.push(w[1]),O.unshift(w[2])),O.length&&(s=\"/\"+O.join(\".\")+s),this.hostname=I.join(\".\");break}}}this.hostname.length>hostnameMaxLen?this.hostname=\"\":this.hostname=this.hostname.toLowerCase(),y||(this.hostname=punycode.toASCII(this.hostname));var V=this.port?\":\"+this.port:\"\",T=this.hostname||\"\";this.host=T+V,this.href+=this.host,y&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),\"/\"!==s[0]&&(s=\"/\"+s))}if(!unsafeProtocol[u])for(f=0,N=autoEscape.length;f0)&&a.host.split(\"@\"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift());return a.search=e.search,a.query=e.query,util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:\"\")+(a.search?a.search:\"\")),a.href=a.format(),a}if(!P.length)return a.pathname=null,a.search?a.path=\"/\"+a.search:a.path=null,a.href=a.format(),a;for(var x=P.slice(-1)[0],v=(a.host||e.host||P.length>1)&&(\".\"===x||\"..\"===x)||\"\"===x,I=0,O=P.length;O>=0;O--)\".\"===(x=P[O])?P.splice(O,1):\"..\"===x?(P.splice(O,1),I++):I&&(P.splice(O,1),I--);if(!g&&!N)for(;I--;I)P.unshift(\"..\");!g||\"\"===P[0]||P[0]&&\"/\"===P[0].charAt(0)||P.unshift(\"\"),v&&\"/\"!==P.join(\"/\").substr(-1)&&P.push(\"\");var w,V=\"\"===P[0]||P[0]&&\"/\"===P[0].charAt(0);b&&(a.hostname=a.host=V?\"\":P.length?P.shift():\"\",(w=!!(a.host&&a.host.indexOf(\"@\")>0)&&a.host.split(\"@\"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift()));return(g=g||a.host&&P.length)&&!V&&P.unshift(\"\"),P.length?a.pathname=P.join(\"/\"):(a.pathname=null,a.path=null),util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:\"\")+(a.search?a.search:\"\")),a.auth=e.auth||a.auth,a.slashes=a.slashes||e.slashes,a.href=a.format(),a},Url.prototype.parseHost=function(){var e=this.host,t=portPattern.exec(e);t&&(\":\"!==(t=t[0])&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)};var aspromise=asPromise;function asPromise(e,t){for(var a=new Array(arguments.length-1),r=0,n=2,o=!0;n1&&\"=\"===e.charAt(t);)++a;return Math.ceil(3*e.length)/4-a};for(var r=new Array(64),n=new Array(123),o=0;o<64;)n[r[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;a.encode=function(e,t,a){for(var n,o=null,s=[],i=0,p=0;t>2],n=(3&u)<<4,p=1;break;case 1:s[i++]=r[n|u>>4],n=(15&u)<<2,p=2;break;case 2:s[i++]=r[n|u>>6],s[i++]=r[63&u],p=0}i>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,s)),i=0)}return p&&(s[i++]=r[n],s[i++]=61,1===p&&(s[i++]=61)),o?(i&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join(\"\")):String.fromCharCode.apply(String,s.slice(0,i))};a.decode=function(e,t,a){for(var r,o=a,s=0,i=0;i1)break;if(void 0===(p=n[p]))throw Error(\"invalid encoding\");switch(s){case 0:r=p,s=1;break;case 1:t[a++]=r<<2|(48&p)>>4,r=p,s=2;break;case 2:t[a++]=(15&r)<<4|(60&p)>>2,r=p,s=3;break;case 3:t[a++]=(3&r)<<6|p,s=0}}if(1===s)throw Error(\"invalid encoding\");return a-o},a.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}}),eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(e,t,a){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:a||this}),this},EventEmitter.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var a=this._listeners[e],r=0;r0?0:2147483648,a,r);else if(isNaN(t))e(2143289344,a,r);else if(t>3.4028234663852886e38)e((n<<31|2139095040)>>>0,a,r);else if(t<1.1754943508222875e-38)e((n<<31|Math.round(t/1.401298464324817e-45))>>>0,a,r);else{var o=Math.floor(Math.log(t)/Math.LN2);e((n<<31|o+127<<23|8388607&Math.round(t*Math.pow(2,-o)*8388608))>>>0,a,r)}}function a(e,t,a){var r=e(t,a),n=2*(r>>31)+1,o=r>>>23&255,s=8388607&r;return 255===o?s?NaN:n*(1/0):0===o?1.401298464324817e-45*n*s:n*Math.pow(2,o-150)*(s+8388608)}e.writeFloatLE=t.bind(null,writeUintLE),e.writeFloatBE=t.bind(null,writeUintBE),e.readFloatLE=a.bind(null,readUintLE),e.readFloatBE=a.bind(null,readUintBE)}(),\"undefined\"!=typeof Float64Array?function(){var t=new Float64Array([-0]),a=new Uint8Array(t.buffer),r=128===a[7];function n(e,r,n){t[0]=e,r[n]=a[0],r[n+1]=a[1],r[n+2]=a[2],r[n+3]=a[3],r[n+4]=a[4],r[n+5]=a[5],r[n+6]=a[6],r[n+7]=a[7]}function o(e,r,n){t[0]=e,r[n]=a[7],r[n+1]=a[6],r[n+2]=a[5],r[n+3]=a[4],r[n+4]=a[3],r[n+5]=a[2],r[n+6]=a[1],r[n+7]=a[0]}function s(e,r){return a[0]=e[r],a[1]=e[r+1],a[2]=e[r+2],a[3]=e[r+3],a[4]=e[r+4],a[5]=e[r+5],a[6]=e[r+6],a[7]=e[r+7],t[0]}function i(e,r){return a[7]=e[r],a[6]=e[r+1],a[5]=e[r+2],a[4]=e[r+3],a[3]=e[r+4],a[2]=e[r+5],a[1]=e[r+6],a[0]=e[r+7],t[0]}e.writeDoubleLE=r?n:o,e.writeDoubleBE=r?o:n,e.readDoubleLE=r?s:i,e.readDoubleBE=r?i:s}():function(){function t(e,t,a,r,n,o){var s=r<0?1:0;if(s&&(r=-r),0===r)e(0,n,o+t),e(1/r>0?0:2147483648,n,o+a);else if(isNaN(r))e(0,n,o+t),e(2146959360,n,o+a);else if(r>1.7976931348623157e308)e(0,n,o+t),e((s<<31|2146435072)>>>0,n,o+a);else{var i;if(r<2.2250738585072014e-308)e((i=r/5e-324)>>>0,n,o+t),e((s<<31|i/4294967296)>>>0,n,o+a);else{var p=Math.floor(Math.log(r)/Math.LN2);1024===p&&(p=1023),e(4503599627370496*(i=r*Math.pow(2,-p))>>>0,n,o+t),e((s<<31|p+1023<<20|1048576*i&1048575)>>>0,n,o+a)}}}function a(e,t,a,r,n){var o=e(r,n+t),s=e(r,n+a),i=2*(s>>31)+1,p=s>>>20&2047,u=4294967296*(1048575&s)+o;return 2047===p?u?NaN:i*(1/0):0===p?5e-324*i*u:i*Math.pow(2,p-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,writeUintLE,0,4),e.writeDoubleBE=t.bind(null,writeUintBE,4,0),e.readDoubleLE=a.bind(null,readUintLE,0,4),e.readDoubleBE=a.bind(null,readUintBE,4,0)}(),e}function writeUintLE(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}function writeUintBE(e,t,a){t[a]=e>>>24,t[a+1]=e>>>16&255,t[a+2]=e>>>8&255,t[a+3]=255&e}function readUintLE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function readUintBE(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod$$1=eval(\"quire\".replace(/^/,\"re\"))(moduleName);if(mod$$1&&(mod$$1.length||Object.keys(mod$$1).length))return mod$$1}catch(e){}return null}var utf8_1=createCommonjsModule(function(e,t){var a=t;a.length=function(e){for(var t=0,a=0,r=0;r191&&r<224?o[s++]=(31&r)<<6|63&e[t++]:r>239&&r<365?(r=((7&r)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,o[s++]=55296+(r>>10),o[s++]=56320+(1023&r)):o[s++]=(15&r)<<12|(63&e[t++])<<6|63&e[t++],s>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,o)),s=0);return n?(s&&n.push(String.fromCharCode.apply(String,o.slice(0,s))),n.join(\"\")):String.fromCharCode.apply(String,o.slice(0,s))},a.write=function(e,t,a){for(var r,n,o=a,s=0;s>6|192,t[a++]=63&r|128):55296==(64512&r)&&56320==(64512&(n=e.charCodeAt(s+1)))?(r=65536+((1023&r)<<10)+(1023&n),++s,t[a++]=r>>18|240,t[a++]=r>>12&63|128,t[a++]=r>>6&63|128,t[a++]=63&r|128):(t[a++]=r>>12|224,t[a++]=r>>6&63|128,t[a++]=63&r|128);return a-o}}),pool_1=pool;function pool(e,t,a){var r=a||8192,n=r>>>1,o=null,s=r;return function(a){if(a<1||a>n)return e(a);s+a>r&&(o=e(r),s=0);var i=t.call(o,s,s+=a);return 7&s&&(s=1+(7|s)),i}}var longbits=LongBits;function LongBits(e,t){this.lo=e>>>0,this.hi=t>>>0}var zero=LongBits.zero=new LongBits(0,0);zero.toNumber=function(){return 0},zero.zzEncode=zero.zzDecode=function(){return this},zero.length=function(){return 1};var zeroHash=LongBits.zeroHash=\"\\0\\0\\0\\0\\0\\0\\0\\0\";LongBits.fromNumber=function(e){if(0===e)return zero;var t=e<0;t&&(e=-e);var a=e>>>0,r=(e-a)/4294967296>>>0;return t&&(r=~r>>>0,a=~a>>>0,++a>4294967295&&(a=0,++r>4294967295&&(r=0))),new LongBits(a,r)},LongBits.from=function(e){if(\"number\"==typeof e)return LongBits.fromNumber(e);if(minimal.isString(e)){if(!minimal.Long)return LongBits.fromNumber(parseInt(e,10));e=minimal.Long.fromString(e)}return e.low||e.high?new LongBits(e.low>>>0,e.high>>>0):zero},LongBits.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,a=~this.hi>>>0;return t||(a=a+1>>>0),-(t+4294967296*a)}return this.lo+4294967296*this.hi},LongBits.prototype.toLong=function(e){return minimal.Long?new minimal.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var charCodeAt=String.prototype.charCodeAt;LongBits.fromHash=function(e){return e===zeroHash?zero:new LongBits((charCodeAt.call(e,0)|charCodeAt.call(e,1)<<8|charCodeAt.call(e,2)<<16|charCodeAt.call(e,3)<<24)>>>0,(charCodeAt.call(e,4)|charCodeAt.call(e,5)<<8|charCodeAt.call(e,6)<<16|charCodeAt.call(e,7)<<24)>>>0)},LongBits.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},LongBits.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},LongBits.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},LongBits.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,a=this.hi>>>24;return 0===a?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:a<128?9:10};var minimal=createCommonjsModule(function(e,t){var a=t;function r(e,t,a){for(var r=Object.keys(t),n=0;n0)},a.Buffer=function(){try{var e=a.inquire(\"buffer\").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),a._Buffer_from=null,a._Buffer_allocUnsafe=null,a.newBuffer=function(e){return\"number\"==typeof e?a.Buffer?a._Buffer_allocUnsafe(e):new a.Array(e):a.Buffer?a._Buffer_from(e):\"undefined\"==typeof Uint8Array?e:new Uint8Array(e)},a.Array=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,a.Long=commonjsGlobal.dcodeIO&&commonjsGlobal.dcodeIO.Long||a.inquire(\"long\"),a.key2Re=/^true|false|0|1$/,a.key32Re=/^-?(?:0|[1-9][0-9]*)$/,a.key64Re=/^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,a.longToHash=function(e){return e?a.LongBits.from(e).toHash():a.LongBits.zeroHash},a.longFromHash=function(e,t){var r=a.LongBits.fromHash(e);return a.Long?a.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},a.merge=r,a.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},a.newError=n,a.ProtocolError=n(\"ProtocolError\"),a.oneOfGetter=function(e){for(var t={},a=0;a-1;--a)if(1===t[e[a]]&&void 0!==this[e[a]]&&null!==this[e[a]])return e[a]}},a.oneOfSetter=function(e){return function(t){for(var a=0;a127;)t[a++]=127&e|128,e>>>=7;t[a]=e}function VarintOp(e,t){this.len=e,this.next=void 0,this.val=t}function writeVarint64(e,t,a){for(;e.hi;)t[a++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[a++]=127&e.lo|128,e.lo=e.lo>>>7;t[a++]=e.lo}function writeFixed32(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}Writer.create=minimal.Buffer?function(){return(Writer.create=function(){return new BufferWriter})()}:function(){return new Writer},Writer.alloc=function(e){return new minimal.Array(e)},minimal.Array!==Array&&(Writer.alloc=minimal.pool(Writer.alloc,minimal.Array.prototype.subarray)),Writer.prototype._push=function(e,t,a){return this.tail=this.tail.next=new Op(e,t,a),this.len+=t,this},VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new VarintOp((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},Writer.prototype.int32=function(e){return e<0?this._push(writeVarint64,10,LongBits$1.fromNumber(e)):this.uint32(e)},Writer.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},Writer.prototype.uint64=function(e){var t=LongBits$1.from(e);return this._push(writeVarint64,t.length(),t)},Writer.prototype.int64=Writer.prototype.uint64,Writer.prototype.sint64=function(e){var t=LongBits$1.from(e).zzEncode();return this._push(writeVarint64,t.length(),t)},Writer.prototype.bool=function(e){return this._push(writeByte,1,e?1:0)},Writer.prototype.fixed32=function(e){return this._push(writeFixed32,4,e>>>0)},Writer.prototype.sfixed32=Writer.prototype.fixed32,Writer.prototype.fixed64=function(e){var t=LongBits$1.from(e);return this._push(writeFixed32,4,t.lo)._push(writeFixed32,4,t.hi)},Writer.prototype.sfixed64=Writer.prototype.fixed64,Writer.prototype.float=function(e){return this._push(minimal.float.writeFloatLE,4,e)},Writer.prototype.double=function(e){return this._push(minimal.float.writeDoubleLE,8,e)};var writeBytes=minimal.Array.prototype.set?function(e,t,a){t.set(e,a)}:function(e,t,a){for(var r=0;r>>0;if(!t)return this._push(writeByte,1,0);if(minimal.isString(e)){var a=Writer.alloc(t=base64.length(e));base64.decode(e,a,0),e=a}return this.uint32(t)._push(writeBytes,t,e)},Writer.prototype.string=function(e){var t=utf8.length(e);return t?this.uint32(t)._push(utf8.write,t,e):this._push(writeByte,1,0)},Writer.prototype.fork=function(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer.prototype.ldelim=function(){var e=this.head,t=this.tail,a=this.len;return this.reset().uint32(a),a&&(this.tail.next=e.next,this.tail=t,this.len+=a),this},Writer.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),a=0;e;)e.fn(e.val,t,a),a+=e.len,e=e.next;return t},Writer._configure=function(e){BufferWriter=e};var writer_buffer=BufferWriter$1;(BufferWriter$1.prototype=Object.create(writer.prototype)).constructor=BufferWriter$1;var Buffer=minimal.Buffer;function BufferWriter$1(){writer.call(this)}BufferWriter$1.alloc=function(e){return(BufferWriter$1.alloc=minimal._Buffer_allocUnsafe)(e)};var writeBytesBuffer=Buffer&&Buffer.prototype instanceof Uint8Array&&\"set\"===Buffer.prototype.set.name?function(e,t,a){t.set(e,a)}:function(e,t,a){if(e.copy)e.copy(t,a,0,e.length);else for(var r=0;r>>0;return this.uint32(t),t&&this._push(writeBytesBuffer,t,e),this},BufferWriter$1.prototype.string=function(e){var t=Buffer.byteLength(e);return this.uint32(t),t&&this._push(writeStringBuffer,t,e),this};var reader=Reader,BufferReader,LongBits$2=minimal.LongBits,utf8$1=minimal.utf8;function indexOutOfRange(e,t){return RangeError(\"index out of range: \"+e.pos+\" + \"+(t||1)+\" > \"+e.len)}function Reader(e){this.buf=e,this.pos=0,this.len=e.length}var create_array=\"undefined\"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new Reader(e);throw Error(\"illegal buffer\")}:function(e){if(Array.isArray(e))return new Reader(e);throw Error(\"illegal buffer\")};function readLongVarint(){var e=new LongBits$2(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error(\"invalid varint encoding\")}function readFixed32_end(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits$2(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader.create=minimal.Buffer?function(e){return(Reader.create=function(e){return minimal.Buffer.isBuffer(e)?new BufferReader(e):create_array(e)})(e)}:create_array,Reader.prototype._slice=minimal.Array.prototype.subarray||minimal.Array.prototype.slice,Reader.prototype.uint32=function(){var e=4294967295;return function(){if(e=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return e;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return e}}(),Reader.prototype.int32=function(){return 0|this.uint32()},Reader.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},Reader.prototype.bool=function(){return 0!==this.uint32()},Reader.prototype.fixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.sfixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return 0|readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.float=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},Reader.prototype.double=function(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},Reader.prototype.bytes=function(){var e=this.uint32(),t=this.pos,a=this.pos+e;if(a>this.len)throw indexOutOfRange(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,a):t===a?new this.buf.constructor(0):this._slice.call(this.buf,t,a)},Reader.prototype.string=function(){var e=this.bytes();return utf8$1.read(e,0,e.length)},Reader.prototype.skip=function(e){if(\"number\"==typeof e){if(this.pos+e>this.len)throw indexOutOfRange(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw indexOutOfRange(this)}while(128&this.buf[this.pos++]);return this},Reader.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;;){if(4==(e=7&this.uint32()))break;this.skipType(e)}break;case 5:this.skip(4);break;default:throw Error(\"invalid wire type \"+e+\" at offset \"+this.pos)}return this},Reader._configure=function(e){BufferReader=e;var t=minimal.Long?\"toLong\":\"toNumber\";minimal.merge(Reader.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader$1;function BufferReader$1(e){reader.call(this,e)}(BufferReader$1.prototype=Object.create(reader.prototype)).constructor=BufferReader$1,minimal.Buffer&&(BufferReader$1.prototype._slice=minimal.Buffer.prototype.slice),BufferReader$1.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len))};var service=Service;function Service(e,t,a){if(\"function\"!=typeof e)throw TypeError(\"rpcImpl must be a function\");minimal.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(a)}(Service.prototype=Object.create(minimal.EventEmitter.prototype)).constructor=Service,Service.prototype.rpcCall=function e(t,a,r,n,o){if(!n)throw TypeError(\"request must be specified\");var s=this;if(!o)return minimal.asPromise(e,s,t,a,r,n);if(s.rpcImpl)try{return s.rpcImpl(t,a[s.requestDelimited?\"encodeDelimited\":\"encode\"](n).finish(),function(e,a){if(e)return s.emit(\"error\",e,t),o(e);if(null!==a){if(!(a instanceof r))try{a=r[s.responseDelimited?\"decodeDelimited\":\"decode\"](a)}catch(e){return s.emit(\"error\",e,t),o(e)}return s.emit(\"data\",a,t),o(null,a)}s.end(!0)})}catch(e){return s.emit(\"error\",e,t),void setTimeout(function(){o(e)},0)}else setTimeout(function(){o(Error(\"already ended\"))},0)},Service.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit(\"end\").off()),this};var rpc_1=createCommonjsModule(function(e,t){t.Service=service}),roots={},indexMinimal=createCommonjsModule(function(e,t){var a=t;function r(){a.Reader._configure(a.BufferReader),a.util._configure()}a.build=\"minimal\",a.Writer=writer,a.BufferWriter=writer_buffer,a.Reader=reader,a.BufferReader=reader_buffer,a.util=minimal,a.rpc=rpc_1,a.roots=roots,a.configure=r,a.Writer._configure(a.BufferWriter),r()}),minimal$1=indexMinimal,minimal_1=minimal$1.roots,minimal_2=minimal$1.Reader,minimal_3=minimal$1.util,$Reader=minimal$1.Reader,$util=minimal$1.util,$root=minimal$1.roots.default||(minimal$1.roots.default={});$root.tensorflow=function(){var e,t,a={};return a.Any=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.typeUrl=e.string();break;case 2:r.value=e.bytes();break;default:e.skipType(7&n)}}return r},e}(),a.DataType=(e={},(t=Object.create(e))[e[0]=\"DT_INVALID\"]=0,t[e[1]=\"DT_FLOAT\"]=1,t[e[2]=\"DT_DOUBLE\"]=2,t[e[3]=\"DT_INT32\"]=3,t[e[4]=\"DT_UINT8\"]=4,t[e[5]=\"DT_INT16\"]=5,t[e[6]=\"DT_INT8\"]=6,t[e[7]=\"DT_STRING\"]=7,t[e[8]=\"DT_COMPLEX64\"]=8,t[e[9]=\"DT_INT64\"]=9,t[e[10]=\"DT_BOOL\"]=10,t[e[11]=\"DT_QINT8\"]=11,t[e[12]=\"DT_QUINT8\"]=12,t[e[13]=\"DT_QINT32\"]=13,t[e[14]=\"DT_BFLOAT16\"]=14,t[e[101]=\"DT_FLOAT_REF\"]=101,t[e[102]=\"DT_DOUBLE_REF\"]=102,t[e[103]=\"DT_INT32_REF\"]=103,t[e[104]=\"DT_UINT8_REF\"]=104,t[e[105]=\"DT_INT16_REF\"]=105,t[e[106]=\"DT_INT8_REF\"]=106,t[e[107]=\"DT_STRING_REF\"]=107,t[e[108]=\"DT_COMPLEX64_REF\"]=108,t[e[109]=\"DT_INT64_REF\"]=109,t[e[110]=\"DT_BOOL_REF\"]=110,t[e[111]=\"DT_QINT8_REF\"]=111,t[e[112]=\"DT_QUINT8_REF\"]=112,t[e[113]=\"DT_QINT32_REF\"]=113,t[e[114]=\"DT_BFLOAT16_REF\"]=114,t),a.TensorShape=function(){function e(e){if(this.dim=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.dim&&r.dim.length||(r.dim=[]),r.dim.push($root.tensorflow.TensorShape.Dim.decode(e,e.uint32()));break;case 3:r.unknownRank=e.bool();break;default:e.skipType(7&n)}}return r},e.Dim=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.size=e.int64();break;case 2:r.name=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.Tensor=function(){function e(e){if(this.floatVal=[],this.doubleVal=[],this.intVal=[],this.stringVal=[],this.scomplexVal=[],this.int64Val=[],this.boolVal=[],this.uint32Val=[],this.uint64Val=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.dtype=e.int32();break;case 2:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 3:r.versionNumber=e.int32();break;case 4:r.tensorContent=e.bytes();break;case 5:if(r.floatVal&&r.floatVal.length||(r.floatVal=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.list=$root.tensorflow.AttrValue.ListValue.decode(e,e.uint32());break;case 2:r.s=e.bytes();break;case 3:r.i=e.int64();break;case 4:r.f=e.float();break;case 5:r.b=e.bool();break;case 6:r.type=e.int32();break;case 7:r.shape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 8:r.tensor=$root.tensorflow.Tensor.decode(e,e.uint32());break;case 9:r.placeholder=e.string();break;case 10:r.func=$root.tensorflow.NameAttrList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.ListValue=function(){function e(e){if(this.s=[],this.i=[],this.f=[],this.b=[],this.type=[],this.shape=[],this.tensor=[],this.func=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.s&&r.s.length||(r.s=[]),r.s.push(e.bytes());break;case 3:if(r.i&&r.i.length||(r.i=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.name=e.string();break;case 2:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.NodeDef=function(){function e(e){if(this.input=[],this.attr={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.name=e.string();break;case 2:n.op=e.string();break;case 3:n.input&&n.input.length||(n.input=[]),n.input.push(e.string());break;case 4:n.device=e.string();break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.VersionDef=function(){function e(e){if(this.badConsumers=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.producer=e.int32();break;case 2:r.minConsumer=e.int32();break;case 3:if(r.badConsumers&&r.badConsumers.length||(r.badConsumers=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.node&&r.node.length||(r.node=[]),r.node.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:r.versions=$root.tensorflow.VersionDef.decode(e,e.uint32());break;case 2:r.library=$root.tensorflow.FunctionDefLibrary.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),a.CollectionDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.nodeList=$root.tensorflow.CollectionDef.NodeList.decode(e,e.uint32());break;case 2:r.bytesList=$root.tensorflow.CollectionDef.BytesList.decode(e,e.uint32());break;case 3:r.int64List=$root.tensorflow.CollectionDef.Int64List.decode(e,e.uint32());break;case 4:r.floatList=$root.tensorflow.CollectionDef.FloatList.decode(e,e.uint32());break;case 5:r.anyList=$root.tensorflow.CollectionDef.AnyList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.NodeList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.string());break;default:e.skipType(7&n)}}return r},e}(),e.BytesList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.bytes());break;default:e.skipType(7&n)}}return r},e}(),e.Int64List=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push($root.tensorflow.Any.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SaverDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.filenameTensorName=e.string();break;case 2:r.saveTensorName=e.string();break;case 3:r.restoreOpName=e.string();break;case 4:r.maxToKeep=e.int32();break;case 5:r.sharded=e.bool();break;case 6:r.keepCheckpointEveryNHours=e.float();break;case 7:r.version=e.int32();break;default:e.skipType(7&n)}}return r},e.CheckpointFormatVersion=(t={},(a=Object.create(t))[t[0]=\"LEGACY\"]=0,a[t[1]=\"V1\"]=1,a[t[2]=\"V2\"]=2,a),e}(),a.TensorInfo=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 4:r.cooSparse=$root.tensorflow.TensorInfo.CooSparse.decode(e,e.uint32());break;case 2:r.dtype=e.int32();break;case 3:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.CooSparse=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.valuesTensorName=e.string();break;case 2:r.indicesTensorName=e.string();break;case 3:r.denseShapeTensorName=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SignatureDef=function(){function e(e){if(this.inputs={},this.outputs={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:e.skip().pos++,n.inputs===$util.emptyObject&&(n.inputs={}),a=e.string(),e.pos++,n.inputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:e.skip().pos++,n.outputs===$util.emptyObject&&(n.outputs={}),a=e.string(),e.pos++,n.outputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 3:n.methodName=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.AssetFileDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.tensorInfo=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:r.filename=e.string();break;default:e.skipType(7&n)}}return r},e}(),a.OpDef=function(){function e(e){if(this.inputArg=[],this.outputArg=[],this.attr=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.inputArg&&r.inputArg.length||(r.inputArg=[]),r.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 3:r.outputArg&&r.outputArg.length||(r.outputArg=[]),r.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 4:r.attr&&r.attr.length||(r.attr=[]),r.attr.push($root.tensorflow.OpDef.AttrDef.decode(e,e.uint32()));break;case 8:r.deprecation=$root.tensorflow.OpDef.OpDeprecation.decode(e,e.uint32());break;case 5:r.summary=e.string();break;case 6:r.description=e.string();break;case 18:r.isCommutative=e.bool();break;case 16:r.isAggregate=e.bool();break;case 17:r.isStateful=e.bool();break;case 19:r.allowsUninitializedInput=e.bool();break;default:e.skipType(7&n)}}return r},e.ArgDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.description=e.string();break;case 3:r.type=e.int32();break;case 4:r.typeAttr=e.string();break;case 5:r.numberAttr=e.string();break;case 6:r.typeListAttr=e.string();break;case 16:r.isRef=e.bool();break;default:e.skipType(7&n)}}return r},e}(),e.AttrDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.type=e.string();break;case 3:r.defaultValue=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 4:r.description=e.string();break;case 5:r.hasMinimum=e.bool();break;case 6:r.minimum=e.int64();break;case 7:r.allowedValues=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),e.OpDeprecation=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.version=e.int32();break;case 2:r.explanation=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.OpList=function(){function e(e){if(this.op=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.op&&r.op.length||(r.op=[]),r.op.push($root.tensorflow.OpDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.MetaGraphDef=function(){function e(e){if(this.collectionDef={},this.signatureDef={},this.assetFileDef=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.metaInfoDef=$root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e,e.uint32());break;case 2:n.graphDef=$root.tensorflow.GraphDef.decode(e,e.uint32());break;case 3:n.saverDef=$root.tensorflow.SaverDef.decode(e,e.uint32());break;case 4:e.skip().pos++,n.collectionDef===$util.emptyObject&&(n.collectionDef={}),a=e.string(),e.pos++,n.collectionDef[a]=$root.tensorflow.CollectionDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.signatureDef===$util.emptyObject&&(n.signatureDef={}),a=e.string(),e.pos++,n.signatureDef[a]=$root.tensorflow.SignatureDef.decode(e,e.uint32());break;case 6:n.assetFileDef&&n.assetFileDef.length||(n.assetFileDef=[]),n.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return n},e.MetaInfoDef=function(){function e(e){if(this.tags=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.metaGraphVersion=e.string();break;case 2:r.strippedOpList=$root.tensorflow.OpList.decode(e,e.uint32());break;case 3:r.anyInfo=$root.tensorflow.Any.decode(e,e.uint32());break;case 4:r.tags&&r.tags.length||(r.tags=[]),r.tags.push(e.string());break;case 5:r.tensorflowVersion=e.string();break;case 6:r.tensorflowGitVersion=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SavedModel=function(){function e(e){if(this.metaGraphs=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.savedModelSchemaVersion=e.int64();break;case 2:r.metaGraphs&&r.metaGraphs.length||(r.metaGraphs=[]),r.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDefLibrary=function(){function e(e){if(this.function=[],this.gradient=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.function&&r.function.length||(r.function=[]),r.function.push($root.tensorflow.FunctionDef.decode(e,e.uint32()));break;case 2:r.gradient&&r.gradient.length||(r.gradient=[]),r.gradient.push($root.tensorflow.GradientDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDef=function(){function e(e){if(this.attr={},this.nodeDef=[],this.ret={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.signature=$root.tensorflow.OpDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 3:n.nodeDef&&n.nodeDef.length||(n.nodeDef=[]),n.nodeDef.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:e.skip().pos++,n.ret===$util.emptyObject&&(n.ret={}),a=e.string(),e.pos++,n.ret[a]=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.GradientDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.functionName=e.string();break;case 2:r.gradientFunc=e.string();break;default:e.skipType(7&n)}}return r},e}(),a}();var compiled_api=$root,compiled_api_1=compiled_api.tensorflow;function getParamValue(e,t,a,r){var n=t.params[e];if(n&&void 0!==n.inputIndex){if(\"tensor\"===n.type)return getTensor(t.inputNames[n.inputIndex],a,r);if(\"tensors\"===n.type)return(0===n.inputIndex?0===n.inputParamLength?t.inputNames:t.inputNames.slice(n.inputIndex,-n.inputParamLength):t.inputNames.splice(n.inputIndex)).map(function(e){return getTensor(e,a,r)});var o=Array.prototype.slice.call(getTensor(t.inputNames.slice(n.inputIndex)[0],a,r).dataSync());return\"number\"===n.type?o[0]:o}return n&&n.value}function getTensor(e,t,a){var r=parseNodeName(e),n=r[0],o=r[1],s=a.currentContextIds.find(function(e){return!!t[getNodeNameWithContextId(n,e)]});return void 0!==s?t[getNodeNameWithContextId(n,s)][o]:void 0}function getNodeNameAndIndex(e,t){var a=parseNodeName(e),r=a[0],n=a[1];return[getNodeNameWithContextId(r,t&&t.currentContextId),n]}function getNodeNameWithContextId(e,t){return t?e+\"-\"+t:e}function parseNodeName(e){var t=e.lastIndexOf(\":\");return-1===t?[e,0]:[e.substring(0,t),Number(e.substring(t+1))]}function split$1(e,t){for(var a=[],r=0;r=this.tensors.length)throw new Error(\"Tried to read from index \"+e+\", but array size is: \"+this.tensors.length);var t=this.tensors[e];if(t.cleared)throw new Error(\"TensorArray \"+this.name+\": Could not read index \"+e+\" twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).\");return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor},e.prototype.readMany=function(e){var t=this;return e.map(function(e){return t.read(e)})},e.prototype.write=function(e,t){if(this.closed_)throw new Error(\"TensorArray \"+this.name+\" has already been closed.\");if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error(\"Tried to write to index \"+e+\", but array is not resizeable and size is: \"+this.maxSize);var a=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\",\\n because the value dtype is \"+t.dtype+\", but TensorArray dtype is \"+this.dtype+\".\");if(0===this.size()&&0===this.elementShape.length&&(this.elementShape=t.shape),util.assertShapesMatch(this.elementShape,t.shape,\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\".\"),a&&a.read)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\", because it has already been read.\");if(a&&a.written)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\", because it has already been written.\");a.tensor=t,a.written=!0,this.tensors[e]=a},e.prototype.writeMany=function(e,t){var a=this;if(e.length!==t.length)throw new Error(\"TensorArray \"+this.name+\": could not write multiple tensors,because the index size: \"+e.length+\" is not the same as tensors size: \"+t.length+\".\");e.map(function(e,r){return a.write(e,t[r])})},e.prototype.gather=function(e,t){if(t&&t!==this.dtype)throw new Error(\"TensorArray dtype is \"+this.dtype+\" but gather requested dtype \"+t);if(!e){e=[];for(var a=0;a=this.maxSize)throw new Error(\"Max index must be < array size (\"+a+\" vs. \"+this.maxSize+\")\");this.writeMany(e,unstack(t,0))},e.prototype.split=function(e,t){var a=this;if(t.dtype!==this.dtype)throw new Error(\"TensorArray dtype is \"+this.dtype+\" but tensor has dtype \"+t.dtype);var r=0,n=e.map(function(e){return r+=e});if(r!==t.shape[0])throw new Error(\"Expected sum of lengths to be equal to\\n tensor.shape[0], but sum of lengths is\\n \"+r+\", and tensor's shape is: \"+t.shape);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error(\"TensorArray's size is not equal to the size of lengths (\"+this.maxSize+\" vs. \"+e.length+\"), and the TensorArray is not marked as dynamically resizeable\");var o=0===r?0:t.size/r,s=[];tidy(function(){t=t.reshape([1,r,o]);for(var i=0;i1)for(var f=1;f1))throw new Error(\"Cannot exit frame, the context is empty\");this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift()},e.prototype.nextIteration=function(){if(!(this.contexts&&this.contexts.length>0))throw new Error(\"Cannot increase frame iteration, the context is empty\");this.contexts=this.contexts.slice(),this.lastId++;var e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))},e.prototype.getWeight=function(e){return this.weightMap[e]},e.prototype.addTensorArray=function(e){this.tensorArrayMap[e.id]=e},e.prototype.getTensorArray=function(e){return this.tensorArrayMap[e]},e}(),GraphExecutor=function(){function e(e){this.graph=e,this.compiledOrder=[],this._weightMap={},this.placeholders=e.placeholders,this._outputs=e.outputs,this.compile()}return Object.defineProperty(e.prototype,\"weightMap\",{get:function(){return this._weightMap},set:function(e){var t=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})});this.weightIds=[].concat.apply([],t),this._weightMap=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputs\",{get:function(){return this.placeholders.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputs\",{get:function(){return this._outputs.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputNodes\",{get:function(){return this.placeholders.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputNodes\",{get:function(){return this.outputs.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"isControlFlowModel\",{get:function(){return this.graph.withControlFlow},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"isDynamicShapeModel\",{get:function(){return this.graph.withDynamicShape},enumerable:!0,configurable:!0}),e.prototype.compile=function(){if(!this.graph.withControlFlow&&!this.graph.withDynamicShape)for(var e=this.graph.inputs.slice(),t={};e.length>0;){var a=e.pop();t[a.name]=!0,this.compiledOrder.push(a),a.children.forEach(function(a){!t[a.name]&&a.inputNames.every(function(e){var a=getNodeNameAndIndex(e)[0];return t[a]})&&e.push(a)})}},e.prototype.execute=function(e,t){var a=this;this.checkInput(e),this.checkInputShapeAndType(e);var r={};return tidy(function(){var n=new ExecutionContext(a._weightMap,r),o=a.compiledOrder.reduce(function(e,t){return e[t.name]=executeOp$15(t,e,n),e},__assign({},a.weightMap,e));return a.findOutputs(o,n,t)})},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u=this;return __generator(this,function(m){switch(m.label){case 0:return this.checkInput(e),this.checkInputShapeAndType(e),a={},r=new ExecutionContext(this._weightMap,a),[4,this.executeWithControlFlow(e,r)];case 1:return n=m.sent(),o=this.findOutputs(n,r,t),s=Object.keys(o).map(function(e){return o[e].id}),i=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})}),p=[].concat.apply([],i),Object.keys(n).forEach(function(e){n[e].forEach(function(e){e&&-1===s.indexOf(e.id)&&-1===p.indexOf(e.id)&&-1===u.weightIds.indexOf(e.id)&&e.dispose()})}),[2,o]}})})},e.prototype.executeWithControlFlow=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u;return __generator(this,function(m){switch(m.label){case 0:a=this.graph.inputs.map(function(e){return{node:e,contexts:t.currentContext}}),r=__assign({},this.weightMap,e),n={},m.label=1;case 1:return a.length>0?(o=a.pop(),t.currentContext=o.contexts,s=\"\",\"enter\"===o.node.op&&getParamValue(\"isConstant\",o.node,r,t)&&(s=getNodeNameAndIndex(o.node.name,t)[0]),i=executeOp$15(o.node,r,t),s||(s=getNodeNameAndIndex(o.node.name,t)[0]),p=r,u=s,[4,i]):[3,3];case 2:return p[u]=m.sent(),o.node.children.forEach(function(e){var o=getNodeNameAndIndex(e.name,t)[0];n[o]||(\"merge\"===e.op?e.inputNames.some(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})):e.inputNames.every(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})))}),[3,1];case 3:return[2,r]}})})},e.prototype.findOutputs=function(e,t,a){return!a||a instanceof Array||(a=[a]),(a||this.graph.outputs.map(function(e){return e.name})).reduce(function(a,r){return a[r]=getTensor(r,e,t),a},{})},e.prototype.dispose=function(){var e=this;Object.keys(this.weightMap).forEach(function(t){return e.weightMap[t].forEach(function(e){return e.dispose()})})},e.prototype.checkInputShapeAndType=function(e){this.placeholders.forEach(function(t){var a=e[t.name][0];if(t.params.shape&&t.params.shape.value){var r=t.params.shape.value,n=r.length===a.shape.length&&a.shape.every(function(e,t){return-1===r[t]||r[t]===e});util.assert(n,\"The shape of dict['\"+t.name+\"'] provided in model.execute(dict) must be [\"+r+\"], but was [\"+a.shape+\"]\")}t.params.dtype&&t.params.dtype.value&&util.assert(a.dtype===t.params.dtype.value,\"The dtype of dict['\"+t.name+\"'] provided in model.execute(dict) must be \"+t.params.dtype.value+\", but was \"+a.dtype)})},e.prototype.checkInput=function(e){var t=this,a=Object.keys(e),r=[],n=[];if(this.inputNodes.forEach(function(e){-1===a.indexOf(e)&&r.push(e)}),a.forEach(function(e){-1===t.inputNodes.indexOf(e)&&n.push(e)}),r.length>0)throw new Error(\"The dict provided in model.execute(dict) has the keys [\"+a+\"], but is missing the required keys: [\"+r+\"].\");if(n.length>0)throw new Error(\"The dict provided in model.execute(dict) has unused keys: [\"+n+\"]. Please provide only the following keys: [\"+this.inputNodes+\"].\")},e}(),FrozenModel=function(){function e(e,t,a){this.modelUrl=e,this.weightManifestUrl=t,this.requestOption=a,this.version=\"n/a\",this.pathPrefix=this.getPathPrefix()}return Object.defineProperty(e.prototype,\"modelVersion\",{get:function(){return this.version},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputNodes\",{get:function(){return this.executor.inputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputNodes\",{get:function(){return this.executor.outputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputs\",{get:function(){return this.executor.inputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputs\",{get:function(){return this.executor.outputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"weights\",{get:function(){return this.executor.weightMap},enumerable:!0,configurable:!0}),e.prototype.getPathPrefix=function(){var e=parse(this.weightManifestUrl),t=e.pathname.split(\"/\");return t.splice(-1),e.pathname=t.join(\"/\"),format(e)+\"/\"},e.prototype.loadRemoteProtoFile=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r,n;return __generator(this,function(o){switch(o.label){case 0:return o.trys.push([0,3,,4]),[4,fetch(this.modelUrl,this.requestOption)];case 1:return e=o.sent(),a=(t=compiled_api_1.GraphDef).decode,r=Uint8Array.bind,[4,e.arrayBuffer()];case 2:return[2,a.apply(t,[new(r.apply(Uint8Array,[void 0,o.sent()]))])];case 3:throw n=o.sent(),new Error(this.modelUrl+\" not found. \"+n);case 4:return[2]}})})},e.prototype.loadWeightManifest=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a;return __generator(this,function(r){switch(r.label){case 0:return r.trys.push([0,3,,4]),[4,fetch(this.weightManifestUrl,this.requestOption)];case 1:return e=r.sent(),t=this,[4,e.clone().json()];case 2:return t.weightManifest=r.sent(),[3,4];case 3:throw a=r.sent(),new Error(this.weightManifestUrl+\" not found. \"+a);case 4:return[2]}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r;return __generator(this,function(n){switch(n.label){case 0:return e=this.loadRemoteProtoFile(),t=this.loadWeightManifest(),[4,Promise.all([e,t])];case 1:return a=n.sent()[0],this.version=a.versions.producer+\".\"+a.versions.minConsumer,[4,io.loadWeights(this.weightManifest,this.pathPrefix,void 0,this.requestOption)];case 2:return r=n.sent(),this.executor=new GraphExecutor(OperationMapper.Instance.transformGraph(a)),this.executor.weightMap=this.convertTensorMapToTensorsMap(r),[2,!0]}})})},e.prototype.predict=function(e,t){return this.execute(e,this.outputNodes)},e.prototype.constructTensorMap=function(e){var t=e instanceof Tensor?[e]:e;if(t.length!==this.inputNodes.length)throw new Error(\"Input tensor count mismatch,the frozen model has \"+this.inputNodes.length+\" placeholders, while there are \"+t.length+\" input tensors.\");return this.inputNodes.reduce(function(e,a,r){return e[a]=t[r],e},{})},e.prototype.execute=function(e,t){if(t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),this.executor.isControlFlowModel||this.executor.isDynamicShapeModel)throw new Error(\"The model contains control flow or dynamic shape ops, please use executeAsync method\");var a=this.executor.execute(this.convertTensorMapToTensorsMap(e),t),r=Object.keys(a);return Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r;return __generator(this,function(n){switch(n.label){case 0:if(!this.executor.isControlFlowModel||!this.executor.isDynamicShapeModel)throw new Error(\"The model does not contain control flow or dynamic shape ops, please use execute method for better performance.\");return t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),[4,this.executor.executeAsync(this.convertTensorMapToTensorsMap(e),t)];case 1:return a=n.sent(),r=Object.keys(a),[2,Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]]}})})},e.prototype.convertTensorMapToTensorsMap=function(e){return Object.keys(e).reduce(function(t,a){return t[a]=[e[a]],t},{})},e.prototype.dispose=function(){this.executor.dispose()},e}();function loadFrozenModel(e,t,a){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(n){switch(n.label){case 0:return[4,(r=new FrozenModel(e,t,a)).load()];case 1:return n.sent(),[2,r]}})})}var version=\"0.5.5\";export{FrozenModel,loadFrozenModel,version as version_converter};\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.4';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport * from '@tensorflow/tfjs-core';\nexport * from '@tensorflow/tfjs-layers';\nexport * from '@tensorflow/tfjs-converter';\n\n// Import versions of all sub-packages.\nimport {version_core} from '@tensorflow/tfjs-core';\nimport {version_layers} from '@tensorflow/tfjs-layers';\nimport {version_converter} from '@tensorflow/tfjs-converter';\nimport {version as version_union} from './version';\n\nexport const version = {\n 'tfjs-core': version_core,\n 'tfjs-layers': version_layers,\n 'tfjs-converter': version_converter,\n 'tfjs': version_union\n};\n"],"names":["extendStatics","Object","setPrototypeOf","__proto__","Array","e","t","n","hasOwnProperty","__extends","constructor","prototype","create","__assign","assign","r","arguments","length","o","call","__awaiter","Promise","a","i","u","next","s","throw","done","value","then","apply","__generator","label","sent","trys","ops","return","Symbol","iterator","TypeError","pop","push","isMobile","navigator","userAgent","vendor","window","opera","test","substr","shuffle","Math","random","clamp","max","min","randUniform","distSquared","Number","assert","Error","assertShapesMatch","arraysEqual","assertNonNull","flatten","isArray","inferShape","isTypedArray","deepAssertShapeConsistency","join","slice","concat","sizeFromShape","isScalarShape","isInt","tanh","exp","sizeToSquarishShape","floor","sqrt","createShuffledIndices","Uint32Array","rightPad","repeat","repeatedTry","setTimeout","inferFromImplicitShape","squeezeShape","newShape","keptDims","getTypedArrayFromDType","Float32Array","Int32Array","Uint8Array","checkComputationForNaN","isNaN","checkConversionForNaN","hasEncodingLoss","copyTypedArray","round","bytesPerElement","isFunction","nearestDivisor","computeStrides","toTypedArray","noConversionNeeded","makeOnesTypedArray","makeZerosTypedArray","now","performance","process","hrtime","util","freeze","Profiler","backendTimer","logger","Logger","profileKernel","time","forEach","dataSync","dtype","logKernelProfile","kernelMs","rank","size","shape","toString","console","log","getFilteredNodesXToY","id","m","inputs","l","c","output","p","d","h","f","g","v","y","backpropagateGradients","gradient","name","keys","add","dispose","FORMAT_LIMIT_NUM_VALS","FORMAT_NUM_FIRST_LAST_VALS","FORMAT_NUM_SIG_DIGITS","tensorToString","computeMaxSizePerColumn","subTensorToString","map","fill","valToString","parseFloat","toFixed","from","subarray","TensorBuffer","values","strides","set","locToIndex","get","indexToLoc","defineProperty","enumerable","configurable","toTensor","Tensor","make","trackerFn","opHandler","setTensorTracker","setOpHandler","isDisposedInternal","dataId","nextId","rankType","registerTensor","write","throwIfDisposed","as1D","asScalar","reshape","as2D","as3D","as4D","asType","cast","buffer","data","read","readSync","isDisposed","disposeTensor","toFloat","toInt","toBool","print","reshapeAs","expandDims","cumsum","squeeze","clone","tile","gather","matMul","dot","norm","reverse","stack","unstack","pad","batchNormalization","all","any","logSumExp","sum","mean","argMin","argMax","addStrict","sub","subStrict","pow","powStrict","mul","mulStrict","div","floorDiv","divStrict","minimum","minimumStrict","maximum","maximumStrict","mod","modStrict","squaredDifference","squaredDifferenceStrict","transpose","notEqual","notEqualStrict","less","lessStrict","equal","equalStrict","lessEqual","lessEqualStrict","greater","greaterStrict","greaterEqual","greaterEqualStrict","logicalAnd","logicalOr","logicalNot","logicalXor","where","neg","ceil","sign","expm1","log1p","rsqrt","square","reciprocal","abs","clipByValue","relu","elu","selu","leakyRelu","prelu","sigmoid","logSigmoid","softplus","sin","cos","tan","asin","acos","atan","sinh","cosh","asinh","acosh","atanh","erf","step","softmax","resizeBilinear","image","resizeNearestNeighbor","conv1d","conv2d","conv2dTranspose","depthwiseConv2D","depthwiseConv2d","avgPool","maxPool","localResponseNormalization","variable","Variable","unsortedSegmentSum","batchToSpaceND","spaceToBatchND","hasInstance","trainable","nextVarId","registerVariable","Function","assertTypesMatch","isTensorInList","getTensorsInContainer","walkTensorContainer","Set","isIterable","has","Type","Engine","backend","safeMode","debugMode","registeredVariables","refCounter","WeakMap","nextTapeNodeId","numBytes","numTensors","numDataBuffers","gradientScopeCount","customGradientDepth","keepTensors","activeScope","track","scopeStack","profiler","tidy","String","scopedRun","startScope","endScope","error","runKernel","shouldRecord","activeTape","register","delete","disposeData","disposeVariables","memory","addTapeNode","keep","gradients","ones","grads","customGrad","every","gradFunc","fromPixels","wallMs","NUMBER","BOOLEAN","STRING","URL_PROPERTIES","type","isWebGLVersionEnabled","getWebGLRenderingContext","loseContext","getWebGLDisjointQueryTimerVersion","hasExtension","isRenderToFloatTextureEnabled","createFloatTextureAndBindToFramebuffer","checkFramebufferStatus","FRAMEBUFFER","FRAMEBUFFER_COMPLETE","isDownloadFloatTextureEnabled","readPixels","RGBA","FLOAT","getError","NO_ERROR","isWebGLFenceEnabled","fenceSync","isChrome","TENSORFLOWJS_FLAGS_PREFIX","getFeaturesFromURL","location","getQueryParams","search","split","warn","getExtension","document","createElement","getContext","createFramebuffer","createTexture","bindTexture","TEXTURE_2D","RGBA32F","texImage2D","bindFramebuffer","framebufferTexture2D","COLOR_ATTACHMENT0","replace","decodeParam","decodeURIComponent","TEST_EPSILON_FLOAT32_ENABLED","TEST_EPSILON_FLOAT32_DISABLED","Environment","features","registry","setBackend","ENV","initBackend","getBackend","initDefaultBackend","backendName","engine","evaluateFeature","getFeatures","getBestBackendName","entry","sort","priority","versions","node","setFeatures","reset","globalEngine","findBackend","registerBackend","message","removeBackend","getGlobalNamespace","getOrMakeEnvironment","environment","getReshaped","getPermuted","getReshapedPermuted","getSliceBeginCoords","getSliceSize","axesAreInnerMostDims","combineLocations","indexOf","computeOutAndReduceShapes","expandShapeToKeepDim","parseAxisParam","assertAxesAreInnerMostDims","getAxesPermutation","getUndoAxesPermutation","getInnerMostAxes","PARALLELIZE_THRESHOLD","computeOptimalWindowSize","segOpComputeOptimalWindowSize","computeOutShape","assertParamsValid","getStridedSlicedInfo","startForAxis","stopForAxis","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","grad","checkGrads","valueAndGrad","valueAndGrads","variableGrads","filter","some","convertToTensor","convertToTensorArray","op","endsWith","substring","softmax_","tensor","scalar","tensor1d","tensor2d","tensor3d","tensor4d","tensor5d","tensor6d","ones$1","zeros","onesLike_","zerosLike_","linspace","range","DType","Rank","UpcastInt32AndMap","UpcastBoolAndMap","UpcastFloat32AndMap","onesLike","zerosLike","float32","int32","bool","R0","R1","R2","R3","R4","R5","R6","upcastTypeMap","upcastType","sumOutType","castTensor","int","reshapeTensor","nonMaxSuppressionImpl","score","boxIndex","intersectionOverUnion","x","topkImpl","index","ArgMinMaxProgram","variableNames","windowSize","batchSize","inSize","outputShape","userCode","AvgPool2DBackpropProgram","inShape","filterHeight","filterWidth","strideHeight","strideWidth","padInfo","top","left","outHeight","outWidth","getBroadcastDims","unshift","getReductionAxes","broadcastDimsAreOuter","assertAndGetBroadcastShape","BatchNormProgram","supportsBroadcasting","CHECK_NAN_SNIPPET","ADD","SUB","MUL","DIV","INT_DIV","POW","SQUARED_DIFFERENCE","EQUAL","NOT_EQUAL","LESS","LESS_EQUAL","GREATER","GREATER_EQUAL","LOGICAL_AND","LOGICAL_OR","MAX","MIN","MOD","ATAN2","ELU_DER","BinaryOpProgram","getCustomSetupFunc","startLoc","getUniformLocationNoThrow","gl","uniform1f","NaN","ClipProgram","assertParams","computeOutShape$1","computeGradientSliceShapes","aBegin","aSize","bBegin","bSize","ConcatProgram","Conv2DDerFilterProgram","filterShape","inHeight","inWidth","Conv2DDerInputProgram","outChannels","DepthwiseConv2DDerFilterProgram","inChannels","DepthwiseConv2DDerInputProgram","Conv2DProgram","outShape","dilationHeight","dilationWidth","DepthwiseConv2DProgram","makeShader","shapeInfo","logicalShape","isUniform","getInputSamplingSnippet","texShape","getOutputSamplingSnippet","SHADER_PREFIX","FLOAT_TEXTURE_SAMPLE_SNIPPET","FLOAT_TEXTURE_SETOUTPUT_SNIPPET","getSamplerFromInInfo","getSamplerScalar","getSampler1D","getSampler2D","getSampler3D","getSampler4D","getSampler5D","getSampler6D","getSamplerFlat","getSamplerAtOutputCoords","getOutputScalarCoords","getOutput1DCoords","getOutput2DCoords","getOutput3DCoords","getOutput4DCoords","getOutput5DCoords","getOutput6DCoords","SAMPLE_1D_SNIPPET","SAMPLE_2D_SNIPPET","SAMPLE_3D_SNIPPET","SAMPLE_4D_SNIPPET","SAMPLE_5D_SNIPPET","SAMPLE_6D_SNIPPET","charAt","toUpperCase","squeezeInputInfo","getSqueezedParams","getBroadcastOutputCoordsSampler","getCoordsDataType","JSON","parse","stringify","CumSumProgram","getFinalCoord","getCoords","TextureUsage","PhysicalTextureType","EncodeFloatProgram","FromPixelsProgram","GatherProgram","getSourceCoords","getUnpackedMatrixTextureShapeWidthHeight","getUnpackedArraySizeFromMatrixSize","getMatrixSizeFromUnpackedArraySize","encodeMatrixToUnpackedArray","decodeMatrixFromUnpackedArray","getPackedMatrixTextureShapeWidthHeight","getPackedRGBAArraySizeFromMatrixShape","encodeMatrixToPackedRGBA","decodeMatrixFromPackedRGBA","RENDER","UPLOAD","PIXELS","DOWNLOAD","FLOAT16","FLOAT32","UNSIGNED_BYTE","MAX_TEXTURE_SIZE","createWebGLRenderingContext","width","height","createWebGLRenderingContextFromCanvas","callAndCheck","checkWebGLError","webGLDebugErrorCheckingEnabled","enableDebugWebGLErrorChecking","getWebGLErrorMessage","INVALID_ENUM","INVALID_VALUE","INVALID_OPERATION","INVALID_FRAMEBUFFER_OPERATION","OUT_OF_MEMORY","CONTEXT_LOST_WEBGL","getExtensionOrThrow","throwIfNull","createVertexShader","createShader","VERTEX_SHADER","shaderSource","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","createFragmentShader","FRAGMENT_SHADER","logShaderSourceAndInfoLog","lineNumberRegex","exec","createProgram","linkProgram","getProgramParameter","LINK_STATUS","getProgramInfoLog","validateProgram","VALIDATE_STATUS","createStaticVertexBuffer","createBuffer","bindBuffer","ARRAY_BUFFER","bufferData","STATIC_DRAW","createStaticIndexBuffer","ELEMENT_ARRAY_BUFFER","queryMaxTextureSize","getParameter","getNumChannels","validateTextureSize","bindVertexBufferToProgramAttribute","getAttribLocation","vertexAttribPointer","enableVertexAttribArray","bindTextureUnit","validateTextureUnit","activeTexture","TEXTURE0","unbindTextureUnit","getProgramUniformLocationOrThrow","getUniformLocation","getProgramUniformLocation","bindTextureToProgramUniformSampler","uniform1i","bindCanvasToFramebuffer","viewport","canvas","scissor","bindColorTextureToFramebuffer","unbindColorTextureFromFramebuffer","validateFramebuffer","getFramebufferErrorMessage","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_UNSUPPORTED","MAX_COMBINED_TEXTURE_IMAGE_UNITS","getTextureShapeFromLogicalShape","webgl_util","getWebGLContextAttributes","alpha","antialias","premultipliedAlpha","preserveDrawingBuffer","depth","stencil","failIfMajorPerformanceCaveat","createWebGLContext","disable","DEPTH_TEST","STENCIL_TEST","BLEND","DITHER","POLYGON_OFFSET_FILL","SAMPLE_COVERAGE","enable","SCISSOR_TEST","CULL_FACE","cullFace","BACK","createVertexShader$1","createVertexBuffer","createIndexBuffer","Uint16Array","getTextureConfig","R32F","R16F","RED","HALF_FLOAT","HALF_FLOAT_OES","internalFormatFloat","internalFormatHalfFloat","internalFormatPackedFloat","textureFormatFloat","downloadTextureFormat","downloadUnpackNumChannels","defaultNumChannels","textureTypeHalfFloat","createAndConfigureTexture","texParameteri","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","createFloat32MatrixTexture","createFloat16MatrixTexture","createUnsignedBytesMatrixTexture","createPackedMatrixTexture","bindVertexProgramAttributeStreams","uploadPixelDataToTexture","uploadDataToTexture","texSubImage2D","uploadMatrixToTexture","uploadMatrixToPackedTexture","maybeCreateBufferFromOutputTexture","PIXEL_PACK_BUFFER","downloadFloat32MatrixFromBuffer","getBufferSubData","downloadFloat32MatrixFromOutputTexture","downloadByteEncodedFloatMatrixFromOutputTexture","downloadMatrixFromPackedOutputTexture","gpgpu_util","GPGPUContext","outputTexture","program","disposed","autoDebugValidate","vertexAttrsAreBound","itemsToPoll","textureFloatExtension","colorBufferFloatExtension","textureHalfFloatExtension","colorBufferHalfFloatExtension","loseContextExtension","vertexBuffer","indexBuffer","framebuffer","textureConfig","finish","deleteFramebuffer","deleteBuffer","enableAutomaticDebugValidation","deleteMatrixTexture","deleteTexture","downloadMatrixDriver","maybeCreateBufferFromTexture","bindTextureToFrameBuffer","unbindTextureToFrameBuffer","createAndWaitForFence","createFence","pollFence","SYNC_GPU_COMMANDS_COMPLETE","flush","clientWaitSync","ALREADY_SIGNALED","CONDITION_SATISFIED","beginQuery","endQuery","isQueryAvailable","query","isFencePassed","downloadMatrixFromPackedTexture","attachShader","setProgram","deleteProgram","useProgram","getAttributeLocation","setInputMatrixTexture","throwIfNoProgram","setOutputMatrixTexture","setOutputMatrixTextureDriver","setOutputPackedMatrixTexture","setOutputMatrixWriteRegion","setOutputMatrixWriteRegionDriver","setOutputPackedMatrixWriteRegion","debugValidate","executeProgram","drawElements","TRIANGLES","UNSIGNED_SHORT","blockUntilAllProgramsCompleted","getQueryTimerExtension","disjointQueryTimerExtension","getQueryTimerExtensionWebGL2","getQueryTimerExtensionWebGL1","createQuery","TIME_ELAPSED_EXT","createQueryEXT","beginQueryEXT","endQueryEXT","waitForQueryAndGetTime","getQueryTime","getQueryParameter","QUERY_RESULT","getQueryObjectEXT","QUERY_RESULT_EXT","QUERY_RESULT_AVAILABLE","disjoint","GPU_DISJOINT_EXT","QUERY_RESULT_AVAILABLE_EXT","addItemToPoll","pollItems","binSearchLastTrue","isDoneFn","resolveFn","compileProgram","texData","source","webGLProgram","uniformLocations","gpgpu","inShapeInfos","outShapeInfo","validateBinaryAndProgram","runProgram","texture","uniform1fv","makeShaderKey","LRNProgram","LRNGradProgram","depthRadius","bias","beta","MaxPool2DBackpropProgram","MatMulProgram","MultinomialProgram","seedLoc","OneHotProgram","PadProgram","Pool2DProgram","ReduceProgram","ResizeBilinearBackpropProgram","ResizeBilinearProgram","ResizeNearestNeigborBackpropProgram","ResizeNearestNeighborProgram","ReverseProgram","SegmentOpProgram","numSegments","SelectProgram","SliceProgram","getCoords$1","uniform2i","uniform3i","uniform4i","StridedSliceProgram","TextureManager","numUsedTextures","numFreeTextures","freeTextures","logEnabled","usedTextures","acquireTexture","getPhysicalFromLogicalTextureType","getKeyFromTextureShape","shift","releaseTexture","splice","getNumUsedTextures","getNumFreeTextures","TileProgram","getSourceCoords$1","TransposeProgram","getSwitchedCoords","ERF_P","ERF_A1","ERF_A2","ERF_A3","ERF_A4","ERF_A5","SELU_SCALEALPHA","SELU_SCALE","UnaryOpProgram","CHECK_NAN_SNIPPET$1","ABS","RELU","ELU","SELU","STEP","NEG","CEIL","FLOOR","SIGN","ROUND","EXP","EXPM1","LOG","LOG1P","SQRT","RSQRT","SIGMOID","SOFTPLUS","SIN","COS","TAN","ASIN","ACOS","ATAN","SINH","COSH","TANH","ASINH","ACOSH","ATANH","ERF","SQUARE","RECIPROCAL","LOGICAL_NOT","TO_INT","concat1d_","concat2d_","concat3d_","concat4d_","concat_","concat2Tensors","b","concat1d","concat2d","concat3d","concat4d","createCommonjsModule","exports","alea","s0","s1","s2","charCodeAt","state","double","quick","amd","xor128","z","w","xorwow","xorshift7","Date","xor4096","X","tychei","seedrandom","entropy","randomBytes","crypto","msCrypto","getRandomValues","plugins","screen","j","S","T","pass","global","fromCharCode","require","seedrandom$1","seedrandom_1","MPRandGauss","stdDev","nextVal","truncated","upper","lower","nextValue","isValidTruncated","convertValue","clone_","$x","eye_","randomNormal_","truncatedNormal_","randomUniform_","rand_","multinomial_","multinomial","logits2D","oneHot_","oneHot","$indices","fromPixels_","toPixels","Uint8ClampedArray","ImageData","putImageData","reshape_","squeeze_","cast_","tile_","pad1d_","pad2d_","pad3d_","pad4d_","pad_","stack_","batchToSpaceND_","reduce","spaceToBatchND_","unstack_","split_","cumsum_","permutedX","expandDims_","eye","pad1d","pad2d","pad3d","pad4d","rand","randomNormal","randomUniform","truncatedNormal","whereImpl","BEFORE_PAGING_CONSTANT","SIZE_UPLOAD_UNIFORM","MathBackendWebGL","delayedStorage","pendingRead","pendingDisposal","WeakSet","lruDataGPU","numBytesInGPU","uploadWaitMs","downloadWaitMs","binaryCache","gpgpuCreatedLocally","NUM_BYTES_BEFORE_PAGING","devicePixelRatio","textureManager","usage","HTMLVideoElement","HTMLImageElement","HTMLCanvasElement","fromPixelsCanvas","readyState","drawImage","getTexture","compileAndRun","throwIfNoData","uploadToGPU","cacheOnCPU","activeTimers","getValuesFromTexture","WebGLTexture","programTimersStack","unreliable","startTimer","startMs","endMs","endTimer","getGPGPUContext","getCanvas","stridedSlice","multiply","makeOutputArray","localResponseNormalization4D","LRNGrad","argReduce","segOpCompute","select","topk","realDivide","addN","subtract","eluDer","clip","atan2","conv2dDerInput","conv2dDerFilter","depthwiseConv2DDerInput","depthwiseConv2DDerFilter","maxPoolBackprop","avgPoolBackprop","resizeBilinearBackprop","resizeNearestNeighborBackprop","nonMaxSuppression","getAndSaveBinary","computeBytes","getTextureManager","remove","typedArrayToFloat32","float32ToTypedArray","neg_","ceil_","floor_","sign_","round_","exp_","expm1_","log_","log1p_","sqrt_","rsqrt_","square_","reciprocal_","abs_","clipByValue_","sigmoid_","logSigmoid_","softplus_","sin_","cos_","tan_","asin_","acos_","atan_","sinh_","cosh_","tanh_","asinh_","acosh_","atanh_","erf_","PI","step_","log$1","tanh$1","batchNormalization2d_","batchNormalization3d_","batchNormalization4d_","batchNormalization_","batchnormReshape4D","$mean","$variance","$scale","$offset","batchNormalization2d","batchNormalization3d","batchNormalization4d","computePool2DInfo","parseTupleParam","computeConv2DInfo","E","getPadAndOutInfo","getEffectiveFilterSize","_","A","R","dataFormat","computeOutputShape3D","computeDefaultPad","conditionalRound","bottom","right","conv1d_","eitherStridesOrDilationsAreOne","conv2d_","$filter","tupleValuesAreOne","conv2dDerInput_","conv2dDerFilter_","dy4D","x4D","conv2dTranspose_","depthwiseConv2d_","depthwiseConv2dDerInput","depthwiseConv2dDerFilter","separableConv2d_","parseTupleParam$1","separableConv2d","matMul_","$a","$b","outerProduct_","dot_","outerProduct","reverse1d_","reverse2d_","reverse3d_","reverse4d_","reverse_","reverse1d","reverse2d","reverse3d","reverse4d","maxPool_","avgPool_","$dy","$input","input4D","slice1d_","slice2d_","slice3d_","slice4d_","slice_","slice1d","slice2d","slice3d","slice4d","logSumExp_","sum_","mean_","min_","max_","argMin_","argMax_","all_","any_","moments_","variance","moments","notEqual_","notEqualStrict_","less_","lessStrict_","equal_","equalStrict_","lessEqual_","lessEqualStrict_","greater_","greaterStrict_","greaterEqual_","greaterEqualStrict_","add_","addN_","addStrict_","sub_","subStrict_","pow_","$base","$exp","powStrict_","mul_","mulStrict_","div_","floorDiv_","divStrict_","mod_","modStrict_","minimum_","minimumStrict_","maximum_","maximumStrict_","squaredDifference_","squaredDifferenceStrict_","atan2_","logicalNot_","logicalAnd_","logicalOr_","logicalXor_","where_","$condition","whereAsync_","whereAsync","relu_","elu_","dy","selu_","leakyRelu_","prelu_","transpose_","localResponseNormalization_","norm_","normImpl","unsortedSegmentSum_","gatherDropNegatives","gather_","arrayRange","arrayConcat","multiRNNCell_","basicLSTMCell_","basicLSTMCell","multiRNNCell","movingAverage_","movingAverage","stridedSlice_","topk_","indices","computeWeightedLoss_","Reduction","SUM_BY_NONZERO_WEIGHTS","NONE","SUM","MEAN","absoluteDifference_","computeWeightedLoss","meanSquaredError_","cosineDistance_","hingeLoss_","logLoss_","sigmoidCrossEntropyWithLogits_","sigmoidCrossEntropy_","huberLoss_","softmaxCrossEntropyWithLogits_","softmaxCrossEntropy_","absoluteDifference","cosineDistance","hingeLoss","huberLoss","logLoss","meanSquaredError","sigmoidCrossEntropy","softmaxCrossEntropy","loss_ops","gramSchmidt_","qr_","qr2d","gramSchmidt","qr","linalg_ops","resizeBilinear_","batchImages","resizeNearestNeighbor_","nonMaxSuppression_","NEGATIVE_INFINITY","nonMaxSuppSanityCheck","maxOutputSize","iouThreshold","scoreThreshold","$boxes","nonMaxSuppressionAsync_","nonMaxSuppressionAsync","image_ops","linalg","losses","MathBackendCPU","firstUse","getImageData","broadcastedBinaryOp","C","N","k","I","D","M","O","F","P","L","B","U","V","G","H","W","q","$","K","trunc","pool","POSITIVE_INFINITY","maxPoolPositions","delayCallback","requestAnimationFrame","setImmediate","nextFrame","DTYPE_VALUE_SIZE_MAP","uint16","uint8","encodeWeights","concatenateTypedArrays","specs","decodeWeights","quantization","byteLength","useNodeBuffer","Buffer","Blob","atob","btoa","stringByteLength","arrayBufferToBase64String","base64StringToArrayBuffer","byteOffset","concatenateArrayBuffers","basename","trim","getModelArtifactsInfoForJSON","modelTopology","ArrayBuffer","dateSaved","modelTopologyType","modelTopologyBytes","weightSpecsBytes","weightSpecs","weightDataBytes","weightData","IORouterRegistry","saveRouters","loadRouters","getInstance","instance","registerSaveRouter","registerLoadRouter","getSaveHandlers","getHandlers","getLoadHandlers","URL_SCHEME_SUFFIX","ModelStoreManagerRegistry","managers","registerManager","getManager","getSchemes","parseURL","scheme","path","cloneModelInternal","load","removeModel","save","modelArtifactsInfo","listModels","copyModel","moveModel","DATABASE_NAME","DATABASE_VERSION","MODEL_STORE_NAME","INFO_STORE_NAME","getIndexedDBFactory","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","shimIndexedDB","setUpDatabase","result","createObjectStore","keyPath","BrowserIndexedDB","modelPath","databaseAction","open","onupgradeneeded","onsuccess","transaction","objectStore","close","modelArtifacts","onerror","oncomplete","put","URL_SCHEME","indexedDBRouter","startsWith","browserIndexedDB","maybeStripScheme","BrowserIndexedDBManager","getAll","PATH_SEPARATOR","PATH_PREFIX","INFO_SUFFIX","MODEL_TOPOLOGY_SUFFIX","WEIGHT_SPECS_SUFFIX","WEIGHT_DATA_SUFFIX","getModelKeys","info","topology","getModelPathFromKey","maybeStripScheme$1","BrowserLocalStorage","localStorage","LS","setItem","removeItem","getItem","localStorageRouter","browserLocalStorage","BrowserLocalStorageManager","key","DEFAULT_FILE_NAME_PREFIX","DEFAULT_JSON_EXTENSION_NAME","DEFAULT_WEIGHT_DATA_EXTENSION_NAME","BrowserDownloads","modelTopologyFileName","weightDataFileName","URL","createObjectURL","paths","weights","weightsManifest","jsonAnchor","download","href","click","weightDataAnchor","BrowserFiles","files","FileReader","onload","target","checkManifestAndWeightFiles","readAsArrayBuffer","readAsText","browserDownloadsRouter","browserDownloads","browserFiles","loadWeightsAsArrayBuffer","fetch","arrayBuffer","loadWeights","manifestEntry","groupOffset","sizeBytes","scale","BrowserHTTPRequest","DEFAULT_METHOD","body","requestInit","method","FormData","append","status","responses","json","lastIndexOf","URL_SCHEMES","httpRequestRouter","browserHTTPRequest","PassthroughLoader","PassthroughSaver","saveHandler","fromMemory","withSaveHandler","io","Serializable","getClassName","className","fromConfig","SerializationMap","classNameMap","getMap","serialization","WEBGL_ENVS","HAS_WEBGL","NODE_ENVS","IS_NODE","CHROME_ENVS","IS_CHROME","BROWSER_ENVS","IS_BROWSER","CPU_ENVS","ALL_ENVS","expectArraysClose","areClose","expectPromiseToFail","fail","expectArraysEqual","expectNumbersClose","expectValuesInRange","expectArrayBuffersEqual","expect","toEqual","test_util","version","webgl","Optimizer","minimize","computeGradients","applyGradients","DEFAULT_FLOAT32_EPSILON","DEFAULT_FLOAT16_EPSILON","getOptimizerDefaultEpsilonValue","AdadeltaOptimizer","learningRate","rho","epsilon","accumulatedGrads","accumulatedUpdates","rhoScalar","oneMinusRho","epsilonScalar","getConfig","AdagradOptimizer","initialAccumulatorValue","AdamOptimizer","beta1","beta2","accumulatedFirstMoment","accumulatedSecondMoment","beta1Scalar","beta2Scalar","accBeta1","accBeta2","oneMinusBeta1","oneMinusBeta2","one","epsScalar","AdamaxOptimizer","decay","accumulatedWeightedInfNorm","decayScalar","iteration","SGDOptimizer","setLearningRate","MomentumOptimizer","momentum","useNesterov","accumulations","setMomentum","RMSPropOptimizer","accumulatedMeanSquares","accumulatedMeanGrads","accumulatedMoments","momentumScalar","oneMinusDecay","centered","OptimizerConstructors","sgd","rmsprop","adam","adadelta","adamax","adagrad","train","_epsilon","imageDataFormat","_nextUniqueTensorId","getNextUniqueTensorId","_uidPrefixes","getUid","scalarCache","DEFAULT_DTYPE","getScalar","AttributeError","RuntimeError","ValueError","NotImplementedError","AssertionError","IndexError","pyListRepeat","count","singletonOrArray","toList","toSnakeCase","toLowerCase","toCamelCase","_GLOBAL_CUSTOM_OBJECTS","serializeKerasObject","config","deserializeKerasObject","customObjects","numberCompare","reverseNumberCompare","stringToDType","unique","isObjectEmpty","checkStringTypeUnionValue","checkArrayTypeAndLength","calcL2Norms","Constraint","MaxNorm","defaultMaxValue","defaultAxis","maxValue","axis","UnitNorm","NonNeg","MinMaxNorm","defaultMinValue","defaultRate","minValue","rate","CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP","maxNorm","minMaxNorm","nonNeg","unitNorm","serializeConstraint","deserializeConstraint","getConstraint","exports_constraints","nameMap","Map","VALID_DATA_FORMAT_VALUES","checkDataFormat","VALID_PADDING_MODE_VALUES","checkPaddingMode","VALID_POOL_MODE_VALUES","checkPoolMode","_nameScopeStack","_nameScopeDivider","nameScope","currentNameScopePrefix","getScopedTensorName","isValidTensorName","getUniqueTensorName","tensorNameRegex","RegExp","match","isInteger","parseInt","arrayProd","toArray1D","min$1","max$1","cast$1","tile$1","batchFlatten","sliceAlongFirstAxis","sliceAlongLastAxis","sliceAlongAxis","concatenate","concatAlongFirstAxis","randomNormal$1","gather$1","biasAdd","elu$1","softsign","dropout","hardSigmoid","inTrainPhase","VALID_FAN_MODE_VALUES","checkFanMode","VALID_DISTRIBUTION_VALUES","checkDistribution","Initializer","fromConfigUsesCustomObjects","Zeros","Ones","Constant","RandomUniform","DEFAULT_MINVAL","DEFAULT_MAXVAL","minval","maxval","seed","RandomNormal","DEFAULT_MEAN","DEFAULT_STDDEV","stddev","TruncatedNormal","Identity","gain","computeFans","VarianceScaling","mode","distribution","GlorotUniform","GlorotNormal","HeNormal","LeCunNormal","Orthogonal","DEFAULT_GAIN","INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","constant","glorotNormal","glorotUniform","heNormal","identity","leCunNormal","orthogonal","varianceScaling","deserializeInitializer","serializeInitializer","getInitializer","zeros$1","randomUniform$1","randomNormal$2","truncatedNormal$1","exports_initializers","isArrayOfShapes","normalizeShapeList","getExactlyOneTensor","getExactlyOneShape","countParamsInWeights","DEFAULT_VARIABLE_NAME_PREFIX","LayerVariable","originalName","constraint","val","checkShapesMatch","batchGetValue","batchSetValue","InputSpec","ndim","maxNDim","minNDim","axes","SymbolicTensor","sourceLayer","callArgs","outputTensorIndex","_nextNodeID","Node","outboundLayer","inboundLayers","nodeIndices","tensorIndices","inputTensors","outputTensors","inputMasks","outputMasks","inputShapes","outputShapes","outboundNodes","inboundNodes","_nextLayerID","Layer","_callHook","_addedWeightNames","_stateful","activityRegularizer","inputSpec","supportsMasking","_trainableWeights","_nonTrainableWeights","_losses","_updates","_built","updatable","inputShape","batchInputShape","inputDType","initialWeights","nodeKey","getNodeAtIndex","getInputAt","getOutputAt","calculateLosses","trainableWeights","nonTrainableWeights","assertInputCompatibility","invokeCallHook","setCallHook","clearCallHook","built","build","setWeights","collectInputShape","computeOutputShape","guessOutputDType","warnOnIncompatibleInputShape","addInboundNode","countParams","getWeights","addWeight","addLoss","computeMask","nodeIndex","tensorIndex","getSourceInputs","InputLayer","sparse","Input","batchShape","resolveScalarsInLogs","disposeTensorsInLogs","BaseCallback","validationData","setParams","params","onEpochBegin","onEpochEnd","onBatchBegin","onBatchEnd","onTrainBegin","onTrainEnd","setModel","CallbackList","callbacks","queueLength","BaseLogger","seen","totals","metrics","History","epoch","history","syncData","CustomCallback","trainBegin","trainEnd","epochBegin","epochEnd","batchBegin","batchEnd","standardizeCallbacks","l2Normalize","meanAbsoluteError","meanAbsolutePercentageError","MAX_VALUE","meanSquaredLogarithmicError","squaredHinge","hinge","categoricalHinge","logcosh","categoricalCrossentropy","sparseCategoricalCrossentropy","sigmoidCrossEntropyWithLogits","binaryCrossentropy","kullbackLeiblerDivergence","poisson","cosineProximity","binaryAccuracy","categoricalAccuracy","binaryCrossentropy$1","sparseCategoricalAccuracy","mse$1","MSE$1","mae$1","MAE$1","mape$1","MAPE$1","categoricalCrossentropy$1","cosine$1","sparseCategoricalCrossentropy$1","get$1","mse","MSE","mae","MAE","mape","MAPE","cosine","getOptimizer","Adagrad","Adadelta","Adam","Adamax","RMSProp","SGD","printSummary","isModelSequentialLike","nodesByDepth","printRow","layers","printLayerSummary","printLayerSummaryWithConnections","checkTrainableWeightsConsistency","collectedTrainableWeights","deserialize","isArrayItemInputOrOutputName","convertPythonicToTs","convertTsToPythonic","preprocessWeightsForLoading","loadTensor","loadWeightsFromJson","keras_version","loadWeightsFromNamedTensorMap","Container","containerNodes","outputs","inputLayers","inputLayersNodeIndices","inputLayersTensorIndices","outputLayers","outputLayersNodeIndices","outputLayersTensorIndices","inputNames","outputNames","feedInputShapes","feedInputNames","feedOutputNames","internalInputShapes","internalOutputShapes","layersByDepth","J","Z","Y","Q","ee","te","ne","re","ie","updatedConfig","kerasVersion","toJSON","mask","runInternalGraph","buildNodeConversionMap","getLayer","stateful","assertFeedCompatibility","ModelLoggingVerbosity","FeedDict","id2Value","addFeed","hasKey","getValue","execute","executeInternal","getNodeOutputs","isDataTensor","isDataArray","isDataDict","standardizeInputData","checkArrayLengths","checkLossAndTargetCompatibility","makeBatches","sliceArrays","sliceArraysByIndices","checkInputData","collectMetrics","SILENT","VERBOSE","Model","summary","compile","loss","optimizer","lossFunctions","feedOutputShapes","feedLossFns","metricsNames","metricsTensors","evaluate","standardizeUserData","makeTestFunction","testFunction","testLoop","verbose","steps","checkNumSamples","retrieveSymbolicTensors","predictLoop","predict","predictOnBatch","fitLoop","epochs","initialEpoch","doValidation","stopTraining","batch","getDedupedMetricsNames","fit","validationSplit","validationSteps","training","getNamedWeights","trainableOnly","loadModelInternal","loadModelFromIOHandler","model_config","Sequential","_updatable","model","sequential","loadModel","input","Activation","Elu","Selu","Relu","Relu6","Linear","Sigmoid","HardSigmoid","Softplus","Softsign","Tanh","Softmax","serializeActivation","deserializeActivation","getActivation","LeakyReLU","DEFAULT_ALPHA","ThresholdedReLU","DEFAULT_THETA","theta","thetaTensor","Softmax$1","DEFAULT_AXIS","Regularizer","L1L2","l1","l2","hasL1","hasL2","REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","l1l2","serializeRegularizer","deserializeRegularizer","getRegularizer","normalizeArray","convOutputLength","deconvLength","preprocessConv2DInput","conv1dWithBias","conv2dWithBias","BaseConv","DEFAULT_KERNEL_INITIALIZER","DEFAULT_BIAS_INITIALIZER","verifyConfig","kernelSize","padding","activation","useBias","biasInitializer","biasConstraint","biasRegularizer","dilationRate","Conv","kernel","filters","kernelInitializer","kernelConstraint","kernelRegularizer","Conv2D","Conv2DTranspose","SeparableConv","DEFAULT_DEPTHWISE_INITIALIZER","DEFAULT_POINTWISE_INITIALIZER","depthwiseKernel","pointwiseKernel","depthMultiplier","depthwiseInitializer","depthwiseRegularizer","depthwiseConstraint","pointwiseInitializer","pointwiseRegularizer","pointwiseConstraint","SeparableConv2D","Conv1D","Cropping2D","cropping","UpSampling2D","DEFAULT_SIZE","depthwiseConv2d$1","DepthwiseConv2D","Dropout","rateScalar","noiseShape","getNoiseShape","Dense","inputDim","units","Flatten","Activation$1","RepeatVector","Reshape","targetShape","isUnknown","fixUnknownDimension","Embedding","embeddings","DEFAULT_EMBEDDINGS_INITIALIZER","inputLength","outputDim","embeddingsInitializer","embeddingsRegularizer","embeddingsConstraint","maskZero","Merge","mergeFunction","computeElementwiseOpOutputShape","reshapeRequired","Add","Multiply","Average","Maximum","Minimum","Concatenate","regularNormalizeBatchInTraining","broadcastNormalizeBatchInTraining","normalizeBatchInTraining","BatchNormalization","center","betaInitializer","gammaInitializer","movingMeanInitializer","movingVarianceInitializer","betaConstraint","gammaConstraint","betaRegularizer","gammaRegularizer","stepCount","gamma","movingMean","movingVariance","spatial2dPadding","ZeroPadding2D","pool2d","Pooling1D","poolSize","poolingFunction","MaxPooling1D","AveragePooling1D","Pooling2D","MaxPooling2D","AveragePooling2D","GlobalPooling1D","GlobalAveragePooling1D","GlobalMaxPooling1D","GlobalPooling2D","GlobalAveragePooling2D","GlobalMaxPooling2D","standardizeArgs","initialState","constants","rnn","RNN","cell","StackedRNNCells","cells","stateSize","returnSequences","returnState","goBackwards","unroll","stateSpec","states","numConstants","getStates","setStates","resetStates","getInitialState","RNNCell","SimpleRNNCell","DEFAULT_ACTIVATION","DEFAULT_RECURRENT_INITIALIZER","recurrentInitializer","recurrentRegularizer","recurrentConstraint","recurrentDropout","dropoutMask","recurrentDropoutMask","recurrentKernel","generateDropoutMask","SimpleRNN","GRUCell","DEFAULT_RECURRENT_ACTIVATION","recurrentActivation","implementation","GRU","implmentation","LSTMCell","unitForgetBias","LSTM","Wrapper","layer","TimeDistributed","VALID_BIDIRECTIONAL_MERGE_MODES","checkBidirectionalMergeMode","Bidirectional","forwardLayer","backwardLayer","mergeMode","_trainable","inputLayer","elu$2","leakyReLU","softmax$1","thresholdedReLU","conv1d$2","conv2d$2","conv2dTranspose$1","separableConv2d$1","cropping2D","upSampling2d","depthwiseConv2d$2","dense","dropout$1","flatten$1","repeatVector","embedding","add$2","average$1","concatenate$2","maximum$2","minimum$2","multiply$1","batchNormalization$1","zeroPadding2d","averagePooling1d","avgPool1d","avgPooling1d","averagePooling2d","avgPool2d","avgPooling2d","globalAveragePooling1d","globalAveragePooling2d","globalMaxPooling1d","globalMaxPooling2d","maxPooling1d","maxPooling2d","gru","gruCell","lstm","lstmCell","simpleRNN","simpleRNNCell","rnn$1","stackedRNNCells","bidirectional","timeDistributed","globalMaxPool1d","globalMaxPool2d","maxPool1d","maxPool2d","exports_layers","average","binaryAccuracy$1","binaryCrossentropy$2","categoricalAccuracy$1","categoricalCrossentropy$2","cosineProximity$1","meanAbsoluteError$1","meanAbsolutePercentageError$1","MAPE$2","mape$2","meanSquaredError$1","MSE$2","mse$2","exports_metrics","l1$1","l2$1","exports_regularizers","Callback","commonjsGlobal","self","punycode","nodeType","overflow","RangeError","ucs2","decode","encode","toASCII","toUnicode","util$1","isString","isObject","isNull","isNullOrUndefined","maxKeys","stringifyPrimitive","isFinite","encodeURIComponent","querystring","querystring_1","querystring_2","querystring_3","querystring_4","urlParse","format","urlFormat","Url","protocol","slashes","auth","host","port","hostname","hash","pathname","protocolPattern","portPattern","simplePathPattern","delims","unwise","autoEscape","nonHostChars","hostEndingChars","hostnameMaxLen","hostnamePartPattern","hostnamePartStart","unsafeProtocol","javascript","hostlessProtocol","slashedProtocol","http","https","ftp","gopher","file","parseHost","escape","resolve","resolveObject","aspromise","asPromise","base64_1","eventemitter","EventEmitter","_listeners","on","fn","ctx","off","emit","float_1","factory","writeFloatLE","writeFloatBE","readFloatLE","readFloatBE","LN2","bind","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","writeDoubleLE","writeDoubleBE","readDoubleLE","readDoubleBE","inquire_1","inquire","moduleName","mod$$1","eval","utf8_1","pool_1","longbits","LongBits","lo","hi","zero","toNumber","zzEncode","zzDecode","zeroHash","fromNumber","minimal","Long","fromString","low","high","toLong","Boolean","unsigned","fromHash","toHash","captureStackTrace","base64","float","utf8","emptyArray","emptyObject","isNode","isset","isSet","utf8Write","_Buffer_from","_Buffer_allocUnsafe","newBuffer","dcodeIO","key2Re","key32Re","key64Re","longToHash","longFromHash","fromBits","merge","lcFirst","newError","ProtocolError","oneOfGetter","oneOfSetter","toJSONOptions","longs","enums","bytes","_configure","allocUnsafe","writer","Writer","BufferWriter","LongBits$1","Op","len","noop","State","head","tail","writeByte","writeVarint32","VarintOp","writeVarint64","writeFixed32","alloc","_push","uint32","sint32","uint64","int64","sint64","fixed32","sfixed32","fixed64","sfixed64","writeBytes","string","fork","ldelim","writer_buffer","BufferWriter$1","writeBytesBuffer","copy","writeStringBuffer","reader","Reader","BufferReader","LongBits$2","utf8$1","indexOutOfRange","pos","buf","create_array","readLongVarint","readFixed32_end","readFixed64","isBuffer","_slice","skip","skipType","reader_buffer","BufferReader$1","utf8Slice","service","Service","rpcImpl","requestDelimited","responseDelimited","rpcCall","end","rpc_1","roots","indexMinimal","rpc","configure","minimal$1","minimal_1","minimal_2","minimal_3","$Reader","$util","$root","default","tensorflow","Any","typeUrl","DataType","TensorShape","dim","unknownRank","Dim","floatVal","doubleVal","intVal","stringVal","scomplexVal","int64Val","boolVal","uint32Val","uint64Val","tensorShape","versionNumber","tensorContent","AttrValue","list","placeholder","func","ListValue","NameAttrList","attr","NodeDef","device","VersionDef","badConsumers","producer","minConsumer","GraphDef","library","FunctionDefLibrary","CollectionDef","nodeList","bytesList","int64List","floatList","anyList","NodeList","BytesList","Int64List","FloatList","AnyList","SaverDef","filenameTensorName","saveTensorName","restoreOpName","maxToKeep","sharded","keepCheckpointEveryNHours","CheckpointFormatVersion","TensorInfo","cooSparse","CooSparse","valuesTensorName","indicesTensorName","denseShapeTensorName","SignatureDef","methodName","AssetFileDef","tensorInfo","filename","OpDef","inputArg","outputArg","deprecation","description","isCommutative","isAggregate","isStateful","allowsUninitializedInput","ArgDef","AttrDef","OpDeprecation","typeAttr","numberAttr","typeListAttr","isRef","defaultValue","hasMinimum","allowedValues","explanation","OpList","MetaGraphDef","collectionDef","signatureDef","assetFileDef","metaInfoDef","graphDef","saverDef","MetaInfoDef","tags","metaGraphVersion","strippedOpList","anyInfo","tensorflowVersion","tensorflowGitVersion","SavedModel","metaGraphs","savedModelSchemaVersion","function","FunctionDef","GradientDef","nodeDef","ret","signature","functionName","gradientFunc","compiled_api","compiled_api_1","getParamValue","inputIndex","getTensor","inputParamLength","parseNodeName","currentContextIds","find","getNodeNameWithContextId","getNodeNameAndIndex","currentContextId","split$1","arithmetic","tfOpName","dlOpName","category","tfInputIndex","dlParamName","tfParamName","notSupported","arithmetic$1","basic_math","basicMath","control","tfInputParamLength","control$1","convolution","convolution$1","creation","creation$1","dynamic","dynamic$1","evaluation","evaluation$1","graph","notSupprted","graph$1","image$1","image$2","logical","logical$1","matrices","matrices$1","normalization","normalization$1","reduction","reduction$1","slice_join","sliceJoin","transformation","tfParamNameDeprecated","transformation$1","CONTROL_FLOW_OPS","DYNAMIC_SHAPE_OPS","OperationMapper","opMappers","_instance","isControlFlow","isDynamicShape","transformGraph","mapNode","children","nodes","placeholders","withControlFlow","withDynamicShape","getStringParam","getNumberParam","getNumericArrayParam","getBoolParam","getTensorShapeParam","getDtypeParam","DT_FLOAT","DT_INT32","DT_BOOL","executeOp","executeOp$1","TensorArray","maxSize","elementShape","identicalElementShapes","dynamicSize","clearAfterRead","tensors","closed_","clearAndClose","cleared","readMany","written","writeMany","scatter","executeOp$2","enterFrame","exitFrame","nextIteration","addTensorArray","getTensorArray","executeOp$3","executeOp$4","_this","executeOp$5","executeOp$6","executeOp$7","executeOp$8","executeOp$9","executeOp$10","executeOp$11","executeOp$12","executeOp$13","executeOp$14","executeOp$15","ExecutionContext","weightMap","tensorArrayMap","rootContext","frameName","iterationId","contexts","lastId","generateCurrentContextIds","newFrame","_currentContextIds","contextIdforContexts","getWeight","GraphExecutor","compiledOrder","_weightMap","_outputs","weightIds","checkInput","checkInputShapeAndType","findOutputs","executeAsync","executeWithControlFlow","currentContext","inputNodes","FrozenModel","modelUrl","weightManifestUrl","requestOption","pathPrefix","getPathPrefix","executor","outputNodes","loadRemoteProtoFile","loadWeightManifest","weightManifest","Instance","convertTensorMapToTensorsMap","constructTensorMap","isControlFlowModel","isDynamicShapeModel","loadFrozenModel","version_core","version_layers","version_converter","version_union"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/tf.min.js b/node_modules/@tensorflow/tfjs/dist/tf.min.js new file mode 100644 index 0000000..7c8dff1 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.min.js @@ -0,0 +1,3 @@ +// @tensorflow/tfjs Copyright 2018 Google +!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t(e.tf=e.tf||{})}(this,function(exports){"use strict";var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])};function __extends(e,t){function r(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}var __assign=Object.assign||function(e){for(var t,r=1,n=arguments.length;r0&&a[a.length-1])&&(6===o[0]||2===o[0])){i=0;continue}if(3===o[0]&&(!a||o[1]>a[0]&&o[1]0;)n=Math.random()*t|0,r=e[--t],e[t]=e[n],e[n]=r}function clamp(e,t,r){return Math.max(e,Math.min(t,r))}function randUniform(e,t){return Math.random()*(t-e)+e}function distSquared(e,t){for(var r=0,n=0;n0,function(){return"Element arr["+r.join("][")+"] should be a primitive, but is an array of "+e.length+" elements"}),assert(e.length===t[0],function(){return"Element arr["+r.join("][")+"] should have "+t[0]+" elements, but has "+e.length+" elements"});for(var n=t.slice(1),a=0;a1;--t)if(e%t==0)return[t,e/t];return[1,e]}function createShuffledIndices(e){for(var t=new Uint32Array(e),r=0;r=r?a():setTimeout(i,s)}};i()})}function inferFromImplicitShape(e,t){for(var r=1,n=-1,a=0;a0)r*=e[a];else if(-1===e[a]){if(-1!==n)throw Error("Shapes can only have 1 implicit size. Found - 1 at dim "+n+" and dim "+a);n=a}else if(e[a]<=0)throw Error("Shapes can not be <= 0. Found "+e[a]+" at dim "+a);if(-1===n){if(t>0&&t!==r)throw Error("Size("+t+") must match the product of shape "+e);return e}if(t%r!=0)throw Error("The implicit shape can't be a fractional number. Got "+t+" / "+r);var o=e.slice();return o[n]=t/r,o}function squeezeShape(e,t){for(var r=[],n=[],a=0,o=0;o1)throw new Error("Can't squeeze axis "+o+" since its dim '"+e[o]+"' is not 1");(null==t[a]||t[a]>o)&&1===e[o]&&(r.push(e[o]),n.push(o)),t[a]<=o&&a++}e[o]>1&&(r.push(e[o]),n.push(o))}return{newShape:r,keptDims:n}}function getTypedArrayFromDType(e,t){var r=null;if(null==e||"float32"===e)r=new Float32Array(t);else if("int32"===e)r=new Int32Array(t);else{if("bool"!==e)throw new Error("Unknown data type "+e);r=new Uint8Array(t)}return r}function checkComputationForNaN(e,t,r){if("float32"===t)for(var n=0;n=0;--n)r[n]=r[n+1]*e[n+1];return r}function toTypedArray(e,t,r){return noConversionNeeded(e,t)?e:(Array.isArray(e)&&(e=flatten(e)),copyTypedArray(e,t,r))}function noConversionNeeded(e,t){return e instanceof Float32Array&&"float32"===t||e instanceof Int32Array&&"int32"===t||e instanceof Uint8Array&&"bool"===t}function makeOnesTypedArray(e,t){for(var r=makeZerosTypedArray(e,t),n=0;n=0;o--){i=(m=e[o]).inputs;var h=[];for(h.push(m.output),p=0;p=0;r--){var n=t[r],a=e[n.output.id];if(null==n.gradient)throw new Error("Cannot compute gradient: gradient function not found for "+n.name+".");var o=n.gradient(a);for(var i in n.inputs){if(!(i in o))throw new Error("Cannot backprop through input "+i+". Available gradients found: "+Object.keys(o)+".");var s=o[i](),u=n.inputs[i];if(!arraysEqual(s.shape,u.shape))throw new Error("Error in gradient for op "+n.name+". The gradient of input '"+i+"' has shape '"+s.shape+"', which does not match the shape of the input '"+u.shape+"'");if(null==e[u.id])e[u.id]=s;else{var l=e[u.id];e[u.id]=l.add(s),l.dispose()}}}}var FORMAT_LIMIT_NUM_VALS=20,FORMAT_NUM_FIRST_LAST_VALS=3,FORMAT_NUM_SIG_DIGITS=7;function tensorToString(e,t,r,n){var a=computeStrides(t),o=computeMaxSizePerColumn(e,t,a),i=t.length,s=subTensorToString(e,t,a,o),u=["Tensor"];return n&&(u.push(" dtype: "+r),u.push(" rank: "+i),u.push(" shape: ["+t+"]"),u.push(" values:")),u.push(s.map(function(e){return" "+e}).join("\n")),u.join("\n")}function computeMaxSizePerColumn(e,t,r){var n=sizeFromShape(t),a=r[r.length-1],o=new Array(a).fill(0);if(t.length>1)for(var i=0;iFORMAT_LIMIT_NUM_VALS){var s=Array.from(e.subarray(0,FORMAT_NUM_FIRST_LAST_VALS)),u=Array.from(e.subarray(o-FORMAT_NUM_FIRST_LAST_VALS,o));return["["+s.map(function(e,t){return valToString(e,n[t])}).join(", ")+", ..., "+u.map(function(e,t){return valToString(e,n[o-FORMAT_NUM_FIRST_LAST_VALS+t])}).join(", ")+"]"]}return["["+Array.from(e).map(function(e,t){return valToString(e,n[t])}).join(", ")+"]"]}var l=t.slice(1),p=r.slice(1),c=r[0],d=[];if(o>FORMAT_LIMIT_NUM_VALS){for(var h=0;h {...}) to avoid memory leaks.");return this.keepTensors.add(e.id),e},e.prototype.startScope=function(e,t){void 0===t&&(t=!1),t&&0===this.gradientScopeCount&&(this.activeTape=[]),t&&this.gradientScopeCount++;var r={track:[],name:"unnamed scope"};e&&(r.name=e),this.scopeStack.push(r),this.activeScope=r},e.prototype.endScope=function(e,t){var r=this;void 0===t&&(t=!1),t&&(this.gradientScopeCount--,0===this.gradientScopeCount&&(this.activeTape=null));var n=new Set(this.keepTensors),a=getTensorsInContainer(e);a.forEach(function(e){return n.add(e.id)});for(var o=0;o0,"gradients() received an empty list of xs."),this.tidy("gradients",function(){var o=e();assert(o instanceof Tensor,"The result y returned by f() must be a tensor.");var i=getFilteredNodesXToY(a.activeTape,t,o);if(!n&&0===i.length&&t.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");var s={};return s[o.id]=null==r?ones(o.shape):r,backpropagateGradients(s,i),{value:o,grads:t.map(function(e){return s[e.id]})}},!0)},e.prototype.customGrad=function(e){var t=this;return assert(isFunction(e),"The f passed in customGrad(f) must be a function."),function(){for(var r,n,a=[],o=0;o {op();...}); to avoid memory leaks.");return this.activeScope.track.push(e),e},e}(),e;function ones(e){var t=makeOnesTypedArray(sizeFromShape(e),"float32");return Tensor.make(e,{values:t})}e=Type||(Type={}),e[e.NUMBER=0]="NUMBER",e[e.BOOLEAN=1]="BOOLEAN",e[e.STRING=2]="STRING";var URL_PROPERTIES=[{name:"DEBUG",type:Type.BOOLEAN},{name:"IS_BROWSER",type:Type.BOOLEAN},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",type:Type.NUMBER},{name:"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",type:Type.BOOLEAN},{name:"WEBGL_VERSION",type:Type.NUMBER},{name:"WEBGL_RENDER_FLOAT32_ENABLED",type:Type.BOOLEAN},{name:"WEBGL_DOWNLOAD_FLOAT_ENABLED",type:Type.BOOLEAN},{name:"WEBGL_FENCE_API_ENABLED",type:Type.BOOLEAN},{name:"BACKEND",type:Type.STRING}];function isWebGLVersionEnabled(e,t){var r;try{r=getWebGLRenderingContext(e,t)}catch(e){return!1}return null!=r&&(loseContext(r),!0)}function getWebGLDisjointQueryTimerVersion(e,t){if(0===e)return 0;var r,n=getWebGLRenderingContext(e,t);return r=hasExtension(n,"EXT_disjoint_timer_query_webgl2")&&2===e?2:hasExtension(n,"EXT_disjoint_timer_query")?1:0,null!=n&&loseContext(n),r}function isRenderToFloatTextureEnabled(e,t){if(0===e)return!1;var r=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(r,"OES_texture_float"))return!1}else if(!hasExtension(r,"EXT_color_buffer_float"))return!1;createFloatTextureAndBindToFramebuffer(r,e);var n=r.checkFramebufferStatus(r.FRAMEBUFFER)===r.FRAMEBUFFER_COMPLETE;return loseContext(r),n}function isDownloadFloatTextureEnabled(e,t){if(0===e)return!1;var r=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(r,"OES_texture_float"))return!1}else if(!hasExtension(r,"EXT_color_buffer_float"))return!1;createFloatTextureAndBindToFramebuffer(r,e),r.readPixels(0,0,1,1,r.RGBA,r.FLOAT,new Float32Array(4));var n=r.getError()===r.NO_ERROR;return loseContext(r),n}function isWebGLFenceEnabled(e,t){if(2!==e)return!1;var r=getWebGLRenderingContext(e,t),n=null!=r.fenceSync;return loseContext(r),n}function isChrome(){return"undefined"!=typeof navigator&&null!=navigator&&null!=navigator.userAgent&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}var TENSORFLOWJS_FLAGS_PREFIX="tfjsflags";function getFeaturesFromURL(){var e={};if("undefined"==typeof window||void 0===window.location)return e;var t=getQueryParams(window.location.search);if(TENSORFLOWJS_FLAGS_PREFIX in t){var r={};t[TENSORFLOWJS_FLAGS_PREFIX].split(",").forEach(function(e){var t=e.split(":"),n=t[0],a=t[1];r[n]=a}),URL_PROPERTIES.forEach(function(t){t.name in r&&(console.log("Setting feature override from URL "+t.name+": "+r[t.name]),t.type===Type.NUMBER?e[t.name]=+r[t.name]:t.type===Type.BOOLEAN?e[t.name]="true"===r[t.name]:t.type===Type.STRING?e[t.name]=r[t.name]:console.warn("Unknown URL param: "+t.name+"."))})}return e}function hasExtension(e,t){return null!=e.getExtension(t)}function getWebGLRenderingContext(e,t){if(0===e||!t)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");var r=document.createElement("canvas");return 1===e?r.getContext("webgl")||r.getContext("experimental-webgl"):r.getContext("webgl2")}function loseContext(e){if(null!=e){var t=e.getExtension("WEBGL_lose_context");if(null==t)throw new Error("Extension WEBGL_lose_context not supported on this browser.");t.loseContext()}}function createFloatTextureAndBindToFramebuffer(e,t){var r=e.createFramebuffer(),n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n);var a=2===t?e.RGBA32F:e.RGBA;e.texImage2D(e.TEXTURE_2D,0,a,1,1,0,e.RGBA,e.FLOAT,null),e.bindFramebuffer(e.FRAMEBUFFER,r),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,n,0)}function getQueryParams(e){var t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,function(e){for(var r=[],n=1;n0?0:getWebGLDisjointQueryTimerVersion(t,this.get("IS_BROWSER"))}if("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE"===e)return this.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!isMobile();if("HAS_WEBGL"===e)return this.get("WEBGL_VERSION")>0;if("WEBGL_VERSION"===e)return isWebGLVersionEnabled(2,this.get("IS_BROWSER"))?2:isWebGLVersionEnabled(1,this.get("IS_BROWSER"))?1:0;if("WEBGL_RENDER_FLOAT32_ENABLED"===e)return isRenderToFloatTextureEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_DOWNLOAD_FLOAT_ENABLED"===e)return isDownloadFloatTextureEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("WEBGL_FENCE_API_ENABLED"===e)return isWebGLFenceEnabled(this.get("WEBGL_VERSION"),this.get("IS_BROWSER"));if("TEST_EPSILON"===e)return this.get("WEBGL_RENDER_FLOAT32_ENABLED")?TEST_EPSILON_FLOAT32_ENABLED:TEST_EPSILON_FLOAT32_DISABLED;throw new Error("Unknown feature "+e+".")},e.prototype.setFeatures=function(e){this.features=Object.assign({},e)},e.prototype.reset=function(){this.features=getFeaturesFromURL(),null!=this.globalEngine&&(this.globalEngine=null)},e.prototype.initBackend=function(e,t){var r=this;void 0===t&&(t=!1),this.backendName=e,this.backend=this.findBackend(e),this.globalEngine=new Engine(this.backend,t,function(){return r.get("DEBUG")})},e.prototype.findBackend=function(e){return e in this.registry?this.registry[e].backend:null},e.prototype.registerBackend=function(e,t,r,n){var a=this;if(void 0===r&&(r=1),e in this.registry)return console.warn(e+" backend was already registered. Reusing existing backend"),null!=n&&n(function(){return a.engine}),!1;try{var o=t();return this.registry[e]={backend:o,priority:r},!0}catch(t){return console.warn("Registration of backend "+e+" failed"),console.warn(t.stack||t.message),!1}},e.prototype.removeBackend=function(e){if(!(e in this.registry))throw new Error(e+" backend not found in registry");this.registry[e].backend.dispose(),delete this.registry[e]},Object.defineProperty(e.prototype,"engine",{get:function(){return this.initDefaultBackend(),this.globalEngine},enumerable:!0,configurable:!0}),e.prototype.initDefaultBackend=function(){null==this.globalEngine&&this.initBackend(this.get("BACKEND"),!1)},e}();function getGlobalNamespace(){var e;if("undefined"!=typeof window)e=window;else{if("undefined"==typeof process)throw new Error("Could not find a global object");e=process}return e}function getOrMakeEnvironment(){var e=getGlobalNamespace();return null==e.ENV&&(e.ENV=new Environment(getFeaturesFromURL()),setTensorTracker(function(){return e.ENV.engine})),e.ENV}var ENV=getOrMakeEnvironment(),environment=Object.freeze({Environment:Environment,ENV:ENV});function warn(){for(var e=[],t=0;t=2*t+1||a%2==1?i.push(a):o.push(a);n.push.apply(n,o),n.push(0),n.push.apply(n,i)}return n}function getReshapedPermuted(e,t,r,n){void 0===n&&(n=!0);var a=[];n?a.push(e[0]/r):a.push(e[0]*r);for(var o=1;o=-r&&et||r===e){n=!0;break}r=nearestDivisor(e,r+1)}return r}function computeOutShape(e,t,r){for(var n=[],a=e.length,o=0;o0?a>=s[t]:a<=s[t]);a+=n[t])r+=1;return r}),[i,l]}function startForAxis(e,t,r,n,a){var o=t[a];e&1<0?Number.MIN_SAFE_INTEGER:Number.MAX_SAFE_INTEGER);var i=n[a];return o<0&&(o+=i),clamp(0,o,i-1)}function stopForAxis(e,t,r,n,a){var o=t[a];e&1<0?Number.MAX_SAFE_INTEGER:Number.MIN_SAFE_INTEGER);var i=n[a];return o<0&&(o+=i),r[a]>0?clamp(0,o,i):clamp(-1,o,i-1)}function grad(e){return assert(isFunction(e),"The f passed in grad(f) must be a function"),function(t,r){return assert(t instanceof Tensor,"The x passed in grad(f)(x) must be a tensor"),assert(null==r||r instanceof Tensor,"The dy passed in grad(f)(x, dy) must be a tensor"),ENV.engine.tidy(function(){var n=ENV.engine.gradients(function(){return e(t)},[t],r),a=n.value,o=n.grads;return null!=r&&assertShapesMatch(a.shape,r.shape,"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"),checkGrads(o),o[0]})}}function grads(e){return assert(isFunction(e),"The f passed in grads(f) must be a function"),function(t,r){return assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),"The args passed in grads(f)(args) must be an array of tensors"),assert(null==r||r instanceof Tensor,"The dy passed in grads(f)(args, dy) must be a tensor"),ENV.engine.tidy(function(){var n=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,r),a=n.value,o=n.grads;return null!=r&&assertShapesMatch(a.shape,r.shape,"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),checkGrads(o),o})}}function valueAndGrad(e){return assert(isFunction(e),"The f passed in valueAndGrad(f) must be a function"),function(t,r){assert(t instanceof Tensor,"The x passed in valueAndGrad(f)(x) must be a tensor"),assert(null==r||r instanceof Tensor,"The dy passed in valueAndGrad(f)(x, dy) must be a tensor");var n=ENV.engine.gradients(function(){return e(t)},[t],r),a=n.grads,o=n.value;return checkGrads(a),{grad:a[0],value:o}}}function valueAndGrads(e){return assert(isFunction(e),"The f passed in valueAndGrads(f) must be a function"),function(t,r){assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),"The args passed in valueAndGrads(f)(args) must be array of tensors"),assert(null==r||r instanceof Tensor,"The dy passed in valueAndGrads(f)(args, dy) must be a tensor");var n=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,r);return null!=r&&assertShapesMatch(n.value.shape,r.shape,"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),checkGrads(n.grads),n}}function variableGrads(e,t){if(assert(isFunction(e),"The f passed in variableGrads(f) must be a function"),assert(null==t||Array.isArray(t)&&t.every(function(e){return e instanceof Variable}),"The varList passed in variableGrads(f, varList) must be an array of variables"),null==t)for(var r in t=[],ENV.engine.registeredVariables)t.push(ENV.engine.registeredVariables[r]);var n=t.length;assert((t=t.filter(function(e){return e.trainable})).length>0,"variableGrads() expects at least one of the input variables to be trainable, but none of the "+n+" variables is trainable.");var a=ENV.engine.gradients(e,t,null,!0),o=a.value,i=a.grads;assert(i.some(function(e){return null!=e}),"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),assert(0===o.rank,"The f passed in variableGrads(f) must return a scalar, but it returned a rank-"+o.rank+" tensor");var s={};return t.forEach(function(e,t){null!=i[t]&&(s[e.name]=i[t])}),{value:o,grads:s}}function customGrad(e){return ENV.engine.customGrad(e)}function checkGrads(e){if(e.filter(function(e){return null==e}).length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that\n the f you passed encloses all operations that lead from x to y.")}function convertToTensor(e,t,r,n){if(void 0===n&&(n="float32"),n=n||"float32",e instanceof Tensor)return e;if(!isTypedArray(e)&&!Array.isArray(e)&&"number"!=typeof e&&"boolean"!=typeof e)throw new Error("Argument '"+t+"' passed to '"+r+"' must be a Tensor or TensorLike, but got "+e.constructor.name);var a=inferShape(e);return isTypedArray(e)||Array.isArray(e)||(e=[e]),Tensor.make(a,{values:toTypedArray(e,n,ENV.get("DEBUG"))},n)}function convertToTensorArray(e,t,r){if(!Array.isArray(e))throw new Error("Argument "+t+" passed to "+r+" must be a `Tensor[]` or `TensorLike[]`");return e.map(function(e,n){return convertToTensor(e,t+"["+n+"]",r)})}function op(e){var t=Object.keys(e);if(1!==t.length)throw new Error("Please provide an object with a single key (operation name) mapping to a function. Got an object with "+t.length+" keys.");var r=t[0],n=e[r];r.endsWith("_")&&(r=r.substring(0,r.length-1));var a=function(){for(var e=[],t=0;t1)return zeros([0],n);var a=makeZerosTypedArray(Math.abs(Math.ceil((t-e)/r)),n);ta}).sort(function(e,t){return t.score-e.score}),i=[],s=0;s=0;--d)if(intersectionOverUnion(e,p,i[d])>=n){c=!0;break}if(!c&&(i.push(p),i.length>=r))break}return tensor1d(i,"int32")}function intersectionOverUnion(e,t,r){var n=e.subarray(4*t,4*t+4),a=e.subarray(4*r,4*r+4),o=Math.min(n[0],n[2]),i=Math.min(n[1],n[3]),s=Math.max(n[0],n[2]),u=Math.max(n[1],n[3]),l=Math.min(a[0],a[2]),p=Math.min(a[1],a[3]),c=Math.max(a[0],a[2]),d=Math.max(a[1],a[3]),h=(s-o)*(u-i),f=(c-l)*(d-p);if(h<=0||f<=0)return 0;var m=Math.max(o,l),g=Math.max(i,p),y=Math.min(s,c),v=Math.min(u,d),b=Math.max(y-m,0)*Math.max(v-g,0);return b/(h+f-b)}function topkImpl(e,t,r,n,a){for(var o=t[t.length-1],i=[e.length/o,o],s=i[0],u=i[1],l=getTypedArrayFromDType(r,s*n),p=getTypedArrayFromDType("int32",s*n),c=0;c":"<",u=r?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+n+";\n\n int bestIndex = 0;\n float bestValue = getA(batch, inOffset);\n\n for (int i = 0; i < "+n+"; i++) {\n int inIdx = "+u+";\n float candidate = getA(batch, inIdx);\n if (candidate "+s+" bestValue) {\n bestValue = candidate;\n bestIndex = inIdx;\n }\n }\n setOutput(float(bestIndex));\n }\n "},AvgPool2DBackpropProgram=function(e){this.variableNames=["dy"],this.outputShape=e.inShape;var t=e.filterHeight,r=e.filterWidth,n=e.strideHeight,a=e.strideWidth,o=t-1-e.padInfo.top,i=r-1-e.padInfo.left,s=1/(t*r);this.userCode="\n const ivec2 pads = ivec2("+o+", "+i+");\n const float avgMultiplier = float("+s+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+n+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+r+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+a+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n\n dotProd += dyValue * avgMultiplier;\n }\n }\n setOutput(dotProd);\n }\n "};function getBroadcastDims(e,t){for(var r=e.length,n=[],a=0;a1&&1===i&&n.unshift(o)}return n}function getReductionAxes(e,t){for(var r=[],n=0;n1)&&r.unshift(o)}return r}function broadcastDimsAreOuter(e){for(var t=0;t1&&s>1&&i!==s)throw Error(n);r.unshift(Math.max(i,s))}return r}var BatchNormProgram=function(e,t,r,n,a,o){this.outputShape=[],this.supportsBroadcasting=!0,this.variableNames=["x","mean","variance"],assertAndGetBroadcastShape(e,t),assertAndGetBroadcastShape(e,r);var i="0.0";null!=n&&(assertAndGetBroadcastShape(e,n),this.variableNames.push("offset"),i="getOffsetAtOutCoords()");var s="1.0";null!=a&&(assertAndGetBroadcastShape(e,a),this.variableNames.push("scale"),s="getScaleAtOutCoords()"),this.outputShape=e,this.userCode="\n void main() {\n float x = getXAtOutCoords();\n float mean = getMeanAtOutCoords();\n float variance = getVarianceAtOutCoords();\n float offset = "+i+";\n float scale = "+s+";\n float inv = scale * inversesqrt(variance + float("+o+"));\n setOutput((x - mean) * inv + offset);\n }\n "},CHECK_NAN_SNIPPET="\n if (isNaN(a)) return a;\n if (isNaN(b)) return b;\n",ADD="return a + b;",SUB="return a - b;",MUL="return a * b;",DIV="if (a == b) return 1.0;\n return a / b;",INT_DIV="\n float resultSign = sign(a) * sign(b);\n int ia = round(a);\n int ib = round(b);\n int result = ia / ib;\n int amodb = ia - ib * result;\n\n if (resultSign < 0.0 && amodb != 0) {\n result -= 1;\n }\n return float(result);\n",POW="\nif(a < 0.0 && floor(b) < b){\n return NAN;\n}\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\n",SQUARED_DIFFERENCE="return (a - b) * (a - b);",EQUAL="return float(a == b);",NOT_EQUAL="return float(a != b);",LESS="return float(a < b);",LESS_EQUAL="return float(a <= b);",GREATER="return float(a > b);",GREATER_EQUAL="return float(a >= b);",LOGICAL_AND="return float(a >= 1.0 && b >= 1.0);",LOGICAL_OR="return float(a >= 1.0 || b >= 1.0);",MAX=CHECK_NAN_SNIPPET+"\n return max(a, b);\n",MIN=CHECK_NAN_SNIPPET+"\n return min(a, b);\n",MOD="if (b == 0.0) return NAN;\n return mod(a, b);",ATAN2=CHECK_NAN_SNIPPET+"\n return atan(a, b);\n",ELU_DER="return (b >= 1.0) ? a : a * (b + 1.0);",BinaryOpProgram=function(){function e(e,t,r){this.variableNames=["A","B"],this.supportsBroadcasting=!0,this.outputShape=assertAndGetBroadcastShape(t,r),this.userCode="\n uniform float NAN;\n float binaryOperation(float a, float b) {\n "+e+"\n }\n\n void main() {\n float a = getAAtOutCoords();\n float b = getBAtOutCoords();\n setOutput(binaryOperation(a, b));\n }\n "}return e.prototype.getCustomSetupFunc=function(){var e=this;return function(t,r){null==e.startLoc&&(e.startLoc=t.getUniformLocationNoThrow(r,"NAN"),null==e.startLoc)||t.gl.uniform1f(e.startLoc,NaN)}},e}(),ClipProgram=function(e,t,r){this.variableNames=["A"],this.outputShape=e;var n=t.toFixed(20),a=r.toFixed(20);this.userCode="\n void main() {\n float value = getAAtOutCoords();\n if (isNaN(value)) {\n setOutput(value);\n return;\n }\n\n setOutput(clamp(value, "+n+", "+a+"));\n }\n "};function assertParams(e,t,r){var n=e.length,a=t.length;assert(e.length===t.length,"Error in concat"+n+"D: rank of x1 ("+n+") and x2 ("+a+") must be the same."),assert(r>=0&&r= "+e.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+e.outWidth+"; yC++) {\n int xC = wC + yC * "+r+" - "+a+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "},Conv2DDerInputProgram=function(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;var t=e.filterHeight,r=e.filterWidth,n=e.strideHeight,a=e.strideWidth,o=t-1-e.padInfo.top,i=r-1-e.padInfo.left;this.userCode="\n const ivec2 pads = ivec2("+o+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+n+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+t+" - 1 - wR;\n\n for (int wC = 0; wC < "+r+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+a+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+r+" - 1 - wC;\n\n for (int d2 = 0; d2 < "+e.outChannels+"; d2++) {\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, d2);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "},DepthwiseConv2DDerFilterProgram=function(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;var t=e.strideHeight,r=e.strideWidth,n=e.padInfo.top,a=e.padInfo.left,o=e.outChannels/e.inChannels;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int wR = coords.x;\n int wC = coords.y;\n int d1 = coords.z;\n int dm = coords.w;\n int d2 = d1 * "+o+" + dm;\n\n float dotProd = 0.0;\n\n // TODO: Vec4 over the batch size\n for (int b = 0; b < "+e.batchSize+"; b++) {\n for (int yR = 0; yR < "+e.outHeight+"; yR++) {\n int xR = wR + yR * "+t+" - "+n+";\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int yC = 0; yC < "+e.outWidth+"; yC++) {\n int xC = wC + yC * "+r+" - "+a+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float dyValue = getDy(b, yR, yC, d2);\n float xValue = getX(b, xR, xC, d1);\n dotProd += (xValue * dyValue);\n }\n }\n }\n setOutput(dotProd);\n }\n "},DepthwiseConv2DDerInputProgram=function(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;var t=e.filterHeight,r=e.filterWidth,n=e.strideHeight,a=e.strideWidth,o=t-1-e.padInfo.top,i=r-1-e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode="\n const ivec2 pads = ivec2("+o+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d1 = coords[3];\n ivec2 dyCorner = coords.yz - pads;\n int dyRCorner = dyCorner.x;\n int dyCCorner = dyCorner.y;\n\n float dotProd = 0.0;\n\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+n+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n int wRPerm = "+t+" - 1 - wR;\n\n for (int wC = 0; wC < "+r+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+a+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n int wCPerm = "+r+" - 1 - wC;\n\n // TODO: Vec4 over the channelMul\n for (int dm = 0; dm < "+s+"; dm++) {\n int d2 = d1 * "+s+" + dm;\n float xValue = getDy(batch, idyR, idyC, d2);\n float wValue = getW(wRPerm, wCPerm, d1, dm);\n dotProd += xValue * wValue;\n }\n }\n }\n setOutput(dotProd);\n }\n "},Conv2DProgram=function(e){this.variableNames=["x","W"],this.outputShape=e.outShape;var t=e.padInfo.top,r=e.padInfo.left,n=e.strideHeight,a=e.strideWidth,o=e.dilationHeight,i=e.dilationWidth,s=e.filterHeight,u=e.filterWidth,l=4*Math.floor(e.inChannels/4),p=e.inChannels%4;this.userCode="\n const ivec2 strides = ivec2("+n+", "+a+");\n const ivec2 pads = ivec2("+t+", "+r+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d2 = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+s+"; wR++) {\n int xR = xRCorner + wR * "+o+";\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+u+"; wC++) {\n int xC = xCCorner + wC * "+i+";\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n for (int d1 = 0; d1 < "+l+"; d1 += 4) {\n vec4 xValues = vec4(\n getX(batch, xR, xC, d1),\n getX(batch, xR, xC, d1 + 1),\n getX(batch, xR, xC, d1 + 2),\n getX(batch, xR, xC, d1 + 3)\n );\n vec4 wValues = vec4(\n getW(wR, wC, d1, d2),\n getW(wR, wC, d1 + 1, d2),\n getW(wR, wC, d1 + 2, d2),\n getW(wR, wC, d1 + 3, d2)\n );\n\n dotProd += dot(xValues, wValues);\n }\n\n if ("+(1===p)+") {\n dotProd +=\n getX(batch, xR, xC, "+l+") *\n getW(wR, wC, "+l+", d2);\n } else if ("+(2===p)+") {\n vec2 xValues = vec2(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1)\n );\n vec2 wValues = vec2(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2)\n );\n dotProd += dot(xValues, wValues);\n } else if ("+(3===p)+") {\n vec3 xValues = vec3(\n getX(batch, xR, xC, "+l+"),\n getX(batch, xR, xC, "+l+" + 1),\n getX(batch, xR, xC, "+l+" + 2)\n );\n vec3 wValues = vec3(\n getW(wR, wC, "+l+", d2),\n getW(wR, wC, "+l+" + 1, d2),\n getW(wR, wC, "+l+" + 2, d2)\n );\n dotProd += dot(xValues, wValues);\n }\n }\n }\n setOutput(dotProd);\n }\n "},DepthwiseConv2DProgram=function(e){this.variableNames=["x","W"],this.outputShape=e.outShape;var t=e.inHeight,r=e.inWidth,n=e.padInfo.top,a=e.padInfo.left,o=e.strideHeight,i=e.strideWidth,s=e.dilationHeight,u=e.dilationWidth,l=e.filterHeight,p=e.filterWidth,c=e.outChannels/e.inChannels;this.userCode="\n const ivec2 strides = ivec2("+o+", "+i+");\n const ivec2 pads = ivec2("+n+", "+a+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords.x;\n ivec2 xRCCorner = coords.yz * strides - pads;\n int d2 = coords.w;\n int d1 = d2 / "+c+";\n int q = d2 - d1 * "+c+";\n\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\n for (int wR = 0; wR < "+l+"; wR++) {\n int xR = xRCorner + wR * "+s+";\n\n if (xR < 0 || xR >= "+t+") {\n continue;\n }\n\n for (int wC = 0; wC < "+p+"; wC++) {\n int xC = xCCorner + wC * "+u+";\n\n if (xC < 0 || xC >= "+r+") {\n continue;\n }\n\n float xVal = getX(batch, xR, xC, d1);\n float wVal = getW(wR, wC, d1, q);\n dotProd += xVal * wVal;\n }\n }\n setOutput(dotProd);\n }\n "};function makeShader(e,t,r,n){var a=e.map(function(e){var t=sizeFromShape(e.shapeInfo.logicalShape);return e.shapeInfo.isUniform?"uniform float "+e.name+(t>1?"["+t+"]":"")+";":"uniform sampler2D "+e.name+";"});a=a.join("\n");var o=e.map(function(e){return getInputSamplingSnippet(e,t,n)}).join("\n"),i=t.texShape,s=getOutputSamplingSnippet(t.logicalShape,i);return[SHADER_PREFIX,FLOAT_TEXTURE_SAMPLE_SNIPPET,FLOAT_TEXTURE_SETOUTPUT_SNIPPET,a,s,o,r].join("\n")}function getSamplerFromInInfo(e){var t=e.shapeInfo.logicalShape;switch(t.length){case 0:return getSamplerScalar(e);case 1:return getSampler1D(e);case 2:return getSampler2D(e);case 3:return getSampler3D(e);case 4:return getSampler4D(e);case 5:return getSampler5D(e);case 6:return getSampler6D(e);default:throw new Error(t.length+"-D input sampling is not yet supported")}}function getInputSamplingSnippet(e,t,r){var n=getSamplerFlat(e);return n+=getSamplerFromInInfo(e),(r||arraysEqual(e.shapeInfo.logicalShape,t.logicalShape))&&(n+=getSamplerAtOutputCoords(e,t,r)),n}function getOutputSamplingSnippet(e,t){switch(e.length){case 0:return getOutputScalarCoords();case 1:return getOutput1DCoords(e,t);case 2:return getOutput2DCoords(e,t);case 3:return getOutput3DCoords(e,t);case 4:return getOutput4DCoords(e,t);case 5:return getOutput5DCoords(e,t);case 6:return getOutput6DCoords(e,t);default:throw new Error(e.length+"-D output sampling is not yet supported")}}var SAMPLE_1D_SNIPPET="\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_2D_SNIPPET="\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\n int index = row * numC + col;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_3D_SNIPPET="\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\n int stride1, int row, int col, int depth) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_4D_SNIPPET="\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int row, int col, int depth,\n int depth2) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_5D_SNIPPET="\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int row, int col, int depth,\n int depth2, int depth3) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 +\n depth * stride2 + depth2 * stride3 + depth3;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",SAMPLE_6D_SNIPPET="\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\n int stride1, int stride2, int stride3, int stride4,\n int row, int col, int depth, int depth2, int depth3, int depth4) {\n // Explicitly use integer operations as dot() only works on floats.\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\n stride3 + depth3 * stride4 + depth4;\n int texR = index / texNumC;\n int texC = index - texR * texNumC;\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\n}\n",FLOAT_TEXTURE_SAMPLE_SNIPPET="\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\n return texture2D(textureSampler, uv).r;\n }\n",FLOAT_TEXTURE_SETOUTPUT_SNIPPET="\n void setOutput(float val) {\n gl_FragColor = vec4(val, 0, 0, 0);\n }\n",SHADER_PREFIX="\n precision highp float;\n precision highp int;\n varying vec2 resultUV;\n const vec2 halfCR = vec2(0.5, 0.5);\n\n struct ivec5\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n };\n\n struct ivec6\n {\n int x;\n int y;\n int z;\n int w;\n int u;\n int v;\n };\n\n bool isNaN(float val) {\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\n }\n\n bool hasNaN(vec4 values) {\n vec4 v1 = values * values;\n vec4 v2 = values * values;\n return any(notEqual(v1, v2));\n }\n\n float getNaN(vec4 values) {\n return dot(vec4(1), values);\n }\n\n int round(float value) {\n return int(floor(value + 0.5));\n }\n\n int imod(int x, int y) {\n return x - y * (x / y);\n }\n\n //Based on the work of Dave Hoskins\n //https://www.shadertoy.com/view/4djSRW\n #define HASHSCALE1 443.8975\n float random(float seed){\n vec2 p = resultUV * seed;\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n }\n\n "+SAMPLE_1D_SNIPPET+"\n "+SAMPLE_2D_SNIPPET+"\n "+SAMPLE_3D_SNIPPET+"\n "+SAMPLE_4D_SNIPPET+"\n "+SAMPLE_5D_SNIPPET+"\n "+SAMPLE_6D_SNIPPET+"\n";function getOutputScalarCoords(){return"\n int getOutputCoords() {\n return 0;\n }\n "}function getOutput1DCoords(e,t){return 1===t[0]?"\n int getOutputCoords() {\n return int(resultUV.x * "+t[1]+".0);\n }\n ":1===t[1]?"\n int getOutputCoords() {\n return int(resultUV.y * "+t[0]+".0);\n }\n ":"\n int getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n return resTexRC.x * "+t[1]+" + resTexRC.y;\n }\n "}function getOutput3DCoords(e,t){var r=e[1]*e[2],n=e[2];return"\n ivec3 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n int r = index / "+r+";\n index -= r * "+r+";\n int c = index / "+n+";\n int d = index - c * "+n+";\n return ivec3(r, c, d);\n }\n "}function getOutput4DCoords(e,t){var r=e[3],n=e[2]*r,a=e[1]*n;return"\n ivec4 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+a+";\n index -= r * "+a+";\n\n int c = index / "+n+";\n index -= c * "+n+";\n\n int d = index / "+r+";\n int d2 = index - d * "+r+";\n\n return ivec4(r, c, d, d2);\n }\n "}function getOutput5DCoords(e,t){var r=e[4],n=e[3]*r,a=e[2]*n,o=e[1]*a;return"\n ivec5 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx * vec2("+t[0]+",\n "+t[1]+"));\n\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+o+";\n index -= r * "+o+";\n\n int c = index / "+a+";\n index -= c * "+a+";\n\n int d = index / "+n+";\n index -= d * "+n+";\n\n int d2 = index / "+r+";\n int d3 = index - d2 * "+r+";\n\n ivec5 outShape = ivec5(r, c, d, d2, d3);\n return outShape;\n }\n "}function getOutput6DCoords(e,t){var r=e[5],n=e[4]*r,a=e[3]*n,o=e[2]*a,i=e[1]*o;return"\n ivec6 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n\n int r = index / "+i+";\n index -= r * "+i+";\n\n int c = index / "+o+";\n index -= c * "+o+";\n\n int d = index / "+a+";\n index -= d * "+a+";\n\n int d2 = index / "+n+";\n index -= d2 * "+n+";\n\n int d3 = index / "+r+";\n int d4 = index - d3 * "+r+";\n\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\n return result;\n }\n "}function getOutput2DCoords(e,t){return arraysEqual(e,t)?"\n ivec2 getOutputCoords() {\n return ivec2(resultUV.yx * vec2("+t[0]+", "+t[1]+"));\n }\n ":1===e[1]?"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n return ivec2(index, 0);\n }\n ":1===e[0]?"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n return ivec2(0, index);\n }\n ":"\n ivec2 getOutputCoords() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+t[0]+", "+t[1]+"));\n int index = resTexRC.x * "+t[1]+" + resTexRC.y;\n int r = index / "+e[1]+";\n int c = index - r * "+e[1]+";\n return ivec2(r, c);\n }\n "}function getSamplerScalar(e){var t=e.name,r="get"+t.charAt(0).toUpperCase()+t.slice(1);return e.shapeInfo.isUniform?"float "+r+"() {return "+t+";}":"\n float "+r+"() {\n return sampleTexture("+t+", halfCR);\n }\n "}function getSampler1D(e){var t=e.name,r="get"+t.charAt(0).toUpperCase()+t.slice(1);return"\n float "+r+"(int index) {\n return "+r+"Flat(index);\n }\n "}function getSampler2D(e){var t=e.shapeInfo.logicalShape,r=e.name,n="get"+r.charAt(0).toUpperCase()+r.slice(1),a=e.shapeInfo.texShape;if(null!=a&&arraysEqual(t,a)){var o=a[0];return"\n float "+n+"(int row, int col) {\n vec2 uv = (vec2(col, row) + halfCR) / vec2("+a[1]+".0, "+o+".0);\n return sampleTexture("+r+", uv);\n }\n "}var i=squeezeShape(t),s=i.newShape,u=i.keptDims,l=s;if(l.length=1?"coords = 0;":s.map(function(e){return"coords["+(e+u)+"] = 0;"}).join("\n"))+"\n return get"+r+"("+(o<2&&a>0?"coords":e.shapeInfo.logicalShape.map(function(e,t){return"coords["+(t+u)+"]"}).join(", "))+");\n }\n "}function getSamplerAtOutputCoords(e,t,r){var n=e.name,a=n.charAt(0).toUpperCase()+n.slice(1),o="get"+a+"AtOutCoords",i=getBroadcastDims(e.shapeInfo.logicalShape,t.logicalShape),s=e.shapeInfo.logicalShape.length,u=t.logicalShape.length,l=r&&(u>s||i.length>0),p=broadcastDimsAreOuter(i),c=e.shapeInfo.isUniform;if(l&&!p)return getBroadcastOutputCoordsSampler(e,t,a,o);var d=sizeFromShape(e.shapeInfo.logicalShape),h="";l&&p&&(h="\n int mainPart = index / "+d+";\n index -= mainPart * "+d+";\n ");var f=t.texShape;if(c)return 1===d?"float "+o+"() {return "+n+";}":"\n float "+o+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+f[0]+", "+f[1]+"));\n int index = resTexRC.x * "+f[1]+" + resTexRC.y;\n "+h+"\n return get"+a+"Flat(index);\n }\n ";var m=e.shapeInfo.texShape;return arraysEqual(m,f)?"\n float "+o+"() {\n return sampleTexture("+n+", resultUV);\n }\n ":"\n float "+o+"() {\n ivec2 resTexRC = ivec2(resultUV.yx *\n vec2("+f[0]+", "+f[1]+"));\n int index = resTexRC.x * "+f[1]+" + resTexRC.y;\n "+h+"\n int texR = index / "+m[1]+";\n int texC = index - texR * "+m[1]+";\n vec2 uv = (vec2(texC, texR) + halfCR) /\n vec2("+m[1]+".0, "+m[0]+".0);\n\n return sampleTexture("+n+", uv);\n }\n "}function getCoordsDataType(e){if(e<=1)return"int";if(2===e)return"ivec2";if(3===e)return"ivec3";if(4===e)return"ivec4";if(5===e)return"ivec5";if(6===e)return"ivec6";throw Error("GPU for rank "+e+" is not yet supported")}function squeezeInputInfo(e,t){var r=JSON.parse(JSON.stringify(e));return r.shapeInfo.logicalShape=t,r}function getSqueezedParams(e,t){return t.map(function(t){return e[t]}).join(", ")}var CumSumProgram=function(e,t,r){this.variableNames=["x"],this.outputShape=e;var n=e.length,a=e[e.length-1],o=r?"<":">";this.userCode="\n int getIndex(int i) {\n "+(r?"return "+a+" -i - 1;":"return i;")+"\n }\n\n void main() {\n "+getCoordsDataType(n)+" coords = getOutputCoords();\n int end = "+getFinalCoord(n,"coords")+";\n float val = 0.0;\n for (int i = "+a+" - 1; i >= 0; i -= 1) {\n int idx = getIndex(i);\n if (idx "+o+" end) {\n continue;\n }\n if (idx == end && "+t+") {\n continue;\n }\n "+getFinalCoord(n,"coords")+" = idx;\n val += getX("+getCoords(n,"coords")+");\n }\n setOutput(val);\n }\n "};function getCoords(e,t){if(1===e)return""+t;if(2===e)return t+".x, "+t+".y";if(3===e)return t+".x, "+t+".y, "+t+".z";if(4===e)return t+".x, "+t+".y, "+t+".z, "+t+".w";throw Error("Cumulative sum for rank "+e+" is not yet supported")}function getFinalCoord(e,t){if(1===e)return""+t;if(2===e)return t+".y";if(3===e)return t+".z";if(4===e)return t+".w";throw Error("Cumulative sum for rank "+e+" is not yet supported")}var TextureUsage,PhysicalTextureType,EncodeFloatProgram=function(e){this.variableNames=["A"],this.outputShape=e,this.userCode="\n const float FLOAT_MAX = 1.70141184e38;\n const float FLOAT_MIN = 1.17549435e-38;\n\n lowp vec4 encode_float(highp float v) {\n if (isNaN(v)) {\n return vec4(255, 255, 255, 255);\n }\n\n highp float av = abs(v);\n\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\n }\n\n highp vec4 c = vec4(0,0,0,0);\n\n highp float e = floor(log2(av));\n highp float m = exp2(fract(log2(av))) - 1.0;\n\n c[2] = floor(128.0 * m);\n m -= c[2] / 128.0;\n c[1] = floor(32768.0 * m);\n m -= c[1] / 32768.0;\n c[0] = floor(8388608.0 * m);\n\n highp float ebias = e + 127.0;\n c[3] = floor(ebias / 2.0);\n ebias -= c[3] * 2.0;\n c[2] += floor(ebias) * 128.0;\n\n c[3] += 128.0 * step(0.0, -v);\n\n return c / 255.0;\n }\n\n void main() {\n float x = getAAtOutCoords();\n gl_FragColor = encode_float(x);\n }\n "},FromPixelsProgram=function(e){this.variableNames=["A"];var t=e[0],r=e[1];this.outputShape=e,this.userCode="\n void main() {\n ivec3 coords = getOutputCoords();\n int texR = coords[0];\n int texC = coords[1];\n int depth = coords[2];\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2("+r+".0, "+t+".0);\n\n vec4 values = texture2D(A, uv);\n float value;\n if (depth == 0) {\n value = values.r;\n } else if (depth == 1) {\n value = values.g;\n } else if (depth == 2) {\n value = values.b;\n } else if (depth == 3) {\n value = values.a;\n }\n\n setOutput(floor(value * 255.0 + 0.5));\n }\n "},GatherProgram=function(e,t,r){this.variableNames=["A","indices"];var n=e.slice();n[r]=t,this.outputShape=n,this.rank=n.length;var a=getCoordsDataType(this.rank),o=getSourceCoords(e,r);this.userCode="\n void main() {\n "+a+" resRC = getOutputCoords();\n setOutput(getA("+o+"));\n }\n "};function getSourceCoords(e,t){var r=e.length;if(r>4)throw Error("Gather for rank "+r+" is not yet supported");if(1===r)return"int(getIndices(resRC))";for(var n=["resRC.x","resRC.y","resRC.z","resRC.w"],a=[],o=0;o= "+n);for(var a=0,o=0;o= "+n);for(var a=0,o=0;o= "+a);for(var o=getPackedMatrixTextureShapeWidthHeight(t,r),i=o[0],s=o[1],u=r%2==1,l=t%2==1,p=Math.floor(r/2),c=Math.floor(t/2),d=u?4:0,h=r,f=0,m=0;m= "+a);for(var o=r%2==1,i=t%2==1,s=Math.floor(r/2),u=Math.floor(t/2),l=getPackedMatrixTextureShapeWidthHeight(t,r),p=l[0],c=l[1],d=o?4:0,h=r+(o?1:0),f=0,m=0,g=r,y=0;yn||r>n)throw a="["+t+"x"+r+"]",new Error("Requested texture size "+a+" greater than WebGL maximum on this browser / GPU ["+n+"x"+n+"].")}function createFramebuffer(e){return throwIfNull(e,function(){return e.createFramebuffer()},"Unable to create WebGLFramebuffer.")}function bindVertexBufferToProgramAttribute(e,t,r,n,a,o,i){var s=e.getAttribLocation(t,r);return-1!==s&&(callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,n)}),callAndCheck(e,function(){return e.vertexAttribPointer(s,a,e.FLOAT,!1,o,i)}),callAndCheck(e,function(){return e.enableVertexAttribArray(s)}),!0)}function bindTextureUnit(e,t,r){validateTextureUnit(e,r),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+r)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)})}function unbindTextureUnit(e,t){validateTextureUnit(e,t),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+t)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function getProgramUniformLocationOrThrow(e,t,r){return throwIfNull(e,function(){return e.getUniformLocation(t,r)},'uniform "'+r+'" not present in program.')}function getProgramUniformLocation(e,t,r){return e.getUniformLocation(t,r)}function bindTextureToProgramUniformSampler(e,t,r,n,a){callAndCheck(e,function(){return bindTextureUnit(e,r,a)}),callAndCheck(e,function(){return e.uniform1i(n,a)})}function bindCanvasToFramebuffer(e){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,null)}),callAndCheck(e,function(){return e.viewport(0,0,e.canvas.width,e.canvas.height)}),callAndCheck(e,function(){return e.scissor(0,0,e.canvas.width,e.canvas.height)})}function bindColorTextureToFramebuffer(e,t,r){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,r)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0)})}function unbindColorTextureFromFramebuffer(e,t){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,t)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0)})}function validateFramebuffer(e){var t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+getFramebufferErrorMessage(e,t))}function getFramebufferErrorMessage(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case e.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return"unknown error "+t}}function throwIfNull(e,t,r){var n=callAndCheck(e,function(){return t()});if(null==n)throw new Error(r);return n}function validateTextureUnit(e,t){var r=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,n=t+e.TEXTURE0;if(nr)throw new Error("textureUnit must be in [gl.TEXTURE0, gl.TEXTURE"+r+"].")}function getTextureShapeFromLogicalShape(e,t){2!==t.length&&(t=squeezeShape(t).newShape);var r=queryMaxTextureSize(e),n=sizeFromShape(t);return t.length<=1&&n<=r?[n,1]:2===t.length&&t[0]<=r&&t[1]<=r?t:3===t.length&&t[0]<=r&&t[1]*t[2]<=r?[t[0],t[1]*t[2]]:4===t.length&&t[0]<=r&&t[1]*t[2]*t[3]<=r?[t[0],t[1]*t[2]*t[3]]:sizeToSquarishShape(n)}var webgl_util=Object.freeze({createWebGLRenderingContext:createWebGLRenderingContext,createWebGLRenderingContextFromCanvas:createWebGLRenderingContextFromCanvas,callAndCheck:callAndCheck,enableDebugWebGLErrorChecking:enableDebugWebGLErrorChecking,checkWebGLError:checkWebGLError,getWebGLErrorMessage:getWebGLErrorMessage,getExtensionOrThrow:getExtensionOrThrow,createVertexShader:createVertexShader,createFragmentShader:createFragmentShader,createProgram:createProgram,linkProgram:linkProgram,validateProgram:validateProgram,createStaticVertexBuffer:createStaticVertexBuffer,createStaticIndexBuffer:createStaticIndexBuffer,queryMaxTextureSize:queryMaxTextureSize,getNumChannels:getNumChannels,createTexture:createTexture,validateTextureSize:validateTextureSize,createFramebuffer:createFramebuffer,bindVertexBufferToProgramAttribute:bindVertexBufferToProgramAttribute,bindTextureUnit:bindTextureUnit,unbindTextureUnit:unbindTextureUnit,getProgramUniformLocationOrThrow:getProgramUniformLocationOrThrow,getProgramUniformLocation:getProgramUniformLocation,bindTextureToProgramUniformSampler:bindTextureToProgramUniformSampler,bindCanvasToFramebuffer:bindCanvasToFramebuffer,bindColorTextureToFramebuffer:bindColorTextureToFramebuffer,unbindColorTextureFromFramebuffer:unbindColorTextureFromFramebuffer,validateFramebuffer:validateFramebuffer,getFramebufferErrorMessage:getFramebufferErrorMessage,getTextureShapeFromLogicalShape:getTextureShapeFromLogicalShape});function getWebGLContextAttributes(){return{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0}}function createWebGLContext(e){var t,r=getWebGLContextAttributes();return callAndCheck(t=null!=e?createWebGLRenderingContextFromCanvas(e,r):createWebGLRenderingContext(r),function(){return t.disable(t.DEPTH_TEST)}),callAndCheck(t,function(){return t.disable(t.STENCIL_TEST)}),callAndCheck(t,function(){return t.disable(t.BLEND)}),callAndCheck(t,function(){return t.disable(t.DITHER)}),callAndCheck(t,function(){return t.disable(t.POLYGON_OFFSET_FILL)}),callAndCheck(t,function(){return t.disable(t.SAMPLE_COVERAGE)}),callAndCheck(t,function(){return t.enable(t.SCISSOR_TEST)}),callAndCheck(t,function(){return t.enable(t.CULL_FACE)}),callAndCheck(t,function(){return t.cullFace(t.BACK)}),t}function createVertexShader$1(e){return createVertexShader(e,"\n precision highp float;\n attribute vec3 clipSpacePos;\n attribute vec2 uv;\n varying vec2 resultUV;\n\n void main() {\n gl_Position = vec4(clipSpacePos, 1);\n resultUV = uv;\n }")}function createVertexBuffer(e){return createStaticVertexBuffer(e,new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]))}function createIndexBuffer(e){return createStaticIndexBuffer(e,new Uint16Array([0,1,2,2,1,3]))}function getTextureConfig(e,t){var r,n,a,o,i,s,u,l=e;return 2===ENV.get("WEBGL_VERSION")?(r=l.R32F,n=l.R16F,a=l.RGBA32F,o=l.RED,i=4,s=1,u=l.HALF_FLOAT):(r=e.RGBA,n=e.RGBA,a=l.RGBA,o=e.RGBA,i=4,s=4,u=null!=t?t.HALF_FLOAT_OES:null),{internalFormatFloat:r,internalFormatHalfFloat:n,internalFormatPackedFloat:a,textureFormatFloat:o,downloadTextureFormat:e.RGBA,downloadUnpackNumChannels:i,defaultNumChannels:s,textureTypeHalfFloat:u}}function createAndConfigureTexture(e,t,r,n,a,o){validateTextureSize(e,t,r);var i=createTexture(e),s=e.TEXTURE_2D;return callAndCheck(e,function(){return e.bindTexture(s,i)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MIN_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MAG_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texImage2D(s,0,n,t,r,0,a,o,null)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)}),i}function createFloat32MatrixTexture(e,t,r,n){var a=getUnpackedMatrixTextureShapeWidthHeight(t,r);return createAndConfigureTexture(e,a[0],a[1],n.internalFormatFloat,n.textureFormatFloat,e.FLOAT)}function createFloat16MatrixTexture(e,t,r,n){var a=getUnpackedMatrixTextureShapeWidthHeight(t,r);return createAndConfigureTexture(e,a[0],a[1],n.internalFormatFloat,n.textureFormatFloat,n.textureTypeHalfFloat)}function createUnsignedBytesMatrixTexture(e,t,r,n){var a=getUnpackedMatrixTextureShapeWidthHeight(t,r);return createAndConfigureTexture(e,a[0],a[1],e.RGBA,e.RGBA,e.UNSIGNED_BYTE)}function createPackedMatrixTexture(e,t,r,n){var a=getPackedMatrixTextureShapeWidthHeight(t,r);return createAndConfigureTexture(e,a[0],a[1],n.internalFormatPackedFloat,e.RGBA,e.FLOAT)}function bindVertexProgramAttributeStreams(e,t,r){return callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,r)}),bindVertexBufferToProgramAttribute(e,t,"clipSpacePos",r,3,20,0)&&bindVertexBufferToProgramAttribute(e,t,"uv",r,2,20,12)}function uploadPixelDataToTexture(e,t,r){callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,r)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadDataToTexture(e,t,r,n,a,o){validateTextureSize(e,r,n),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texSubImage2D(e.TEXTURE_2D,0,0,0,r,n,o,e.FLOAT,a)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadMatrixToTexture(e,t,r,n,a,o,i){var s,u=getUnpackedMatrixTextureShapeWidthHeight(r,n),l=u[0],p=u[1];1===i.defaultNumChannels?s=a:encodeMatrixToUnpackedArray(a,s=new Float32Array(getUnpackedArraySizeFromMatrixSize(a.length,o)),o),uploadDataToTexture(e,t,l,p,s,i.textureFormatFloat)}function uploadMatrixToPackedTexture(e,t,r,n,a,o){var i=getPackedMatrixTextureShapeWidthHeight(r,n),s=i[0],u=i[1],l=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(r,n));encodeMatrixToPackedRGBA(a,r,n,l),uploadDataToTexture(e,t,s,u,l,e.RGBA)}function maybeCreateBufferFromOutputTexture(e,t,r,n,a){var o=t;if(2===ENV.get("WEBGL_VERSION")){var i=e,s=i.createBuffer();callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,s)});var u=4*getUnpackedArraySizeFromMatrixSize(r*n,a.downloadUnpackNumChannels);callAndCheck(e,function(){return e.bufferData(i.PIXEL_PACK_BUFFER,u,e.STATIC_DRAW)}),callAndCheck(e,function(){return i.readPixels(0,0,n,r,e.RGBA,e.FLOAT,0)}),callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,null)}),o=s}return o}function downloadFloat32MatrixFromBuffer(e,t,r,n,a){var o=e,i=new Float32Array(getUnpackedArraySizeFromMatrixSize(r*n,a.downloadUnpackNumChannels));o.bindBuffer(e.ARRAY_BUFFER,t),o.getBufferSubData(e.ARRAY_BUFFER,0,i),o.bindBuffer(e.ARRAY_BUFFER,null);var s=new Float32Array(r*n);return decodeMatrixFromUnpackedArray(i,s,a.downloadUnpackNumChannels),s}function downloadFloat32MatrixFromOutputTexture(e,t,r,n){var a=getUnpackedMatrixTextureShapeWidthHeight(t,r),o=a[0],i=a[1],s=new Float32Array(getUnpackedArraySizeFromMatrixSize(t*r,n.downloadUnpackNumChannels));callAndCheck(e,function(){return e.readPixels(0,0,o,i,n.downloadTextureFormat,e.FLOAT,s)});var u=new Float32Array(t*r);return decodeMatrixFromUnpackedArray(s,u,n.downloadUnpackNumChannels),u}function downloadByteEncodedFloatMatrixFromOutputTexture(e,t,r,n){var a=getUnpackedMatrixTextureShapeWidthHeight(t,r),o=a[0],i=a[1],s=new Uint8Array(getUnpackedArraySizeFromMatrixSize(t*r,4));return callAndCheck(e,function(){return e.readPixels(0,0,o,i,n.downloadTextureFormat,e.UNSIGNED_BYTE,s)}),new Float32Array(s.buffer)}function downloadMatrixFromPackedOutputTexture(e,t,r,n){var a=getPackedMatrixTextureShapeWidthHeight(t,r),o=a[0],i=a[1],s=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(t,r));callAndCheck(e,function(){return e.readPixels(0,0,o,i,e.RGBA,e.FLOAT,s)});var u=new Float32Array(t*r);return decodeMatrixFromPackedRGBA(s,t,r,u)}var gpgpu_util=Object.freeze({getWebGLContextAttributes:getWebGLContextAttributes,createWebGLContext:createWebGLContext,createVertexShader:createVertexShader$1,createVertexBuffer:createVertexBuffer,createIndexBuffer:createIndexBuffer,getTextureConfig:getTextureConfig,createFloat32MatrixTexture:createFloat32MatrixTexture,createFloat16MatrixTexture:createFloat16MatrixTexture,createUnsignedBytesMatrixTexture:createUnsignedBytesMatrixTexture,createPackedMatrixTexture:createPackedMatrixTexture,bindVertexProgramAttributeStreams:bindVertexProgramAttributeStreams,uploadPixelDataToTexture:uploadPixelDataToTexture,uploadMatrixToTexture:uploadMatrixToTexture,uploadMatrixToPackedTexture:uploadMatrixToPackedTexture,maybeCreateBufferFromOutputTexture:maybeCreateBufferFromOutputTexture,downloadFloat32MatrixFromBuffer:downloadFloat32MatrixFromBuffer,downloadFloat32MatrixFromOutputTexture:downloadFloat32MatrixFromOutputTexture,downloadByteEncodedFloatMatrixFromOutputTexture:downloadByteEncodedFloatMatrixFromOutputTexture,downloadMatrixFromPackedOutputTexture:downloadMatrixFromPackedOutputTexture}),GPGPUContext=function(){function e(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.autoDebugValidate=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[],this.gl=null!=e?e:createWebGLContext(),1===ENV.get("WEBGL_VERSION")?(this.textureFloatExtension=getExtensionOrThrow(this.gl,"OES_texture_float"),this.colorBufferFloatExtension=this.gl.getExtension("WEBGL_color_buffer_float"),ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")||(this.textureHalfFloatExtension=getExtensionOrThrow(this.gl,"OES_texture_half_float"),this.colorBufferHalfFloatExtension=this.gl.getExtension("EXT_color_buffer_half_float"))):this.colorBufferFloatExtension=getExtensionOrThrow(this.gl,"EXT_color_buffer_float"),this.loseContextExtension=getExtensionOrThrow(this.gl,"WEBGL_lose_context"),this.vertexBuffer=createVertexBuffer(this.gl),this.indexBuffer=createIndexBuffer(this.gl),this.framebuffer=createFramebuffer(this.gl),this.textureConfig=getTextureConfig(this.gl,this.textureHalfFloatExtension)}return e.prototype.dispose=function(){var e=this;if(!this.disposed){null!=this.program&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),null!=this.outputTexture&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");var t=this.gl;callAndCheck(t,function(){return t.finish()}),callAndCheck(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,null)}),callAndCheck(t,function(){return t.deleteFramebuffer(e.framebuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.vertexBuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.indexBuffer)}),this.loseContextExtension.loseContext(),this.disposed=!0}},e.prototype.enableAutomaticDebugValidation=function(e){this.autoDebugValidate=e,enableDebugWebGLErrorChecking(e)},e.prototype.createFloat32MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat32MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createFloat16MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat16MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createUnsignedBytesMatrixTexture=function(e,t){return this.throwIfDisposed(),createUnsignedBytesMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.uploadPixelDataToTexture=function(e,t){this.throwIfDisposed(),uploadPixelDataToTexture(this.gl,e,t)},e.prototype.createPackedMatrixTexture=function(e,t){return this.throwIfDisposed(),createPackedMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.deleteMatrixTexture=function(e){var t=this;this.throwIfDisposed(),this.outputTexture===e&&(unbindColorTextureFromFramebuffer(this.gl,this.framebuffer),this.outputTexture=null),callAndCheck(this.gl,function(){return t.gl.deleteTexture(e)})},e.prototype.uploadMatrixToTexture=function(e,t,r,n){this.throwIfDisposed();var a=getNumChannels();return uploadMatrixToTexture(this.gl,e,t,r,n,a,this.textureConfig)},e.prototype.uploadMatrixToPackedTexture=function(e,t,r,n){return this.throwIfDisposed(),uploadMatrixToPackedTexture(this.gl,e,t,r,n,this.textureConfig)},e.prototype.downloadFloat32MatrixFromOutputTexture=function(e,t,r){var n=this;return this.downloadMatrixDriver(e,function(){return downloadFloat32MatrixFromOutputTexture(n.gl,t,r,n.textureConfig)})},e.prototype.downloadByteEncodedFloatMatrixFromOutputTexture=function(e,t,r){var n=this;return this.downloadMatrixDriver(e,function(){return downloadByteEncodedFloatMatrixFromOutputTexture(n.gl,t,r,n.textureConfig)})},e.prototype.downloadFloat32MatrixFromBuffer=function(e,t,r){return downloadFloat32MatrixFromBuffer(this.gl,e,t,r,this.textureConfig)},e.prototype.maybeCreateBufferFromTexture=function(e,t,r){this.bindTextureToFrameBuffer(e);var n=maybeCreateBufferFromOutputTexture(this.gl,e,t,r,this.textureConfig);return this.unbindTextureToFrameBuffer(),n},e.prototype.createAndWaitForFence=function(){var e=this.createFence(this.gl);return this.pollFence(e)},e.prototype.createFence=function(e){var t,r,n=this;if(ENV.get("WEBGL_FENCE_API_ENABLED")){var a=e,o=a.fenceSync(a.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),r=function(){var e=a.clientWaitSync(o,0,0);return e===a.ALREADY_SIGNALED||e===a.CONDITION_SATISFIED},t=o}else ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(t=this.beginQuery(),this.endQuery(),r=function(){return n.isQueryAvailable(t,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}):r=function(){return!0};return{query:t,isFencePassed:r}},e.prototype.downloadMatrixFromPackedTexture=function(e,t,r){var n=this;return this.downloadMatrixDriver(e,function(){return downloadMatrixFromPackedOutputTexture(n.gl,t,r,n.textureConfig)})},e.prototype.createProgram=function(e){this.throwIfDisposed();var t=this.gl,r=createFragmentShader(t,e),n=createVertexShader$1(t),a=createProgram(t);return callAndCheck(t,function(){return t.attachShader(a,n)}),callAndCheck(t,function(){return t.attachShader(a,r)}),linkProgram(t,a),this.autoDebugValidate&&validateProgram(t,a),this.vertexAttrsAreBound||(this.setProgram(a),this.vertexAttrsAreBound=bindVertexProgramAttributeStreams(t,this.program,this.vertexBuffer)),a},e.prototype.deleteProgram=function(e){var t=this;this.throwIfDisposed(),e===this.program&&(this.program=null),null!=e&&callAndCheck(this.gl,function(){return t.gl.deleteProgram(e)})},e.prototype.setProgram=function(e){var t=this;this.throwIfDisposed(),this.program=e,null!=this.program&&this.autoDebugValidate&&validateProgram(this.gl,this.program),callAndCheck(this.gl,function(){return t.gl.useProgram(e)})},e.prototype.getUniformLocation=function(e,t,r){return void 0===r&&(r=!0),this.throwIfDisposed(),r?getProgramUniformLocationOrThrow(this.gl,e,t):getProgramUniformLocation(this.gl,e,t)},e.prototype.getAttributeLocation=function(e,t){var r=this;return this.throwIfDisposed(),callAndCheck(this.gl,function(){return r.gl.getAttribLocation(e,t)})},e.prototype.getUniformLocationNoThrow=function(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)},e.prototype.setInputMatrixTexture=function(e,t,r){this.throwIfDisposed(),this.throwIfNoProgram(),bindTextureToProgramUniformSampler(this.gl,this.program,e,t,r)},e.prototype.setOutputMatrixTexture=function(e,t,r){this.setOutputMatrixTextureDriver(e,r,t)},e.prototype.setOutputPackedMatrixTexture=function(e,t,r){this.throwIfDisposed();var n=getPackedMatrixTextureShapeWidthHeight(t,r),a=n[0],o=n[1];this.setOutputMatrixTextureDriver(e,a,o)},e.prototype.setOutputMatrixWriteRegion=function(e,t,r,n){this.setOutputMatrixWriteRegionDriver(r,e,n,t)},e.prototype.setOutputPackedMatrixWriteRegion=function(e,t,r,n){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")},e.prototype.debugValidate=function(){null!=this.program&&validateProgram(this.gl,this.program),validateFramebuffer(this.gl)},e.prototype.executeProgram=function(){this.throwIfDisposed(),this.throwIfNoProgram();var e=this.gl;this.autoDebugValidate&&this.debugValidate(),callAndCheck(e,function(){return e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)})},e.prototype.blockUntilAllProgramsCompleted=function(){var e=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return e.gl.finish()})},e.prototype.getQueryTimerExtension=function(){return null==this.disjointQueryTimerExtension&&(this.disjointQueryTimerExtension=getExtensionOrThrow(this.gl,2===ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension},e.prototype.getQueryTimerExtensionWebGL2=function(){return this.getQueryTimerExtension()},e.prototype.getQueryTimerExtensionWebGL1=function(){return this.getQueryTimerExtension()},e.prototype.beginQuery=function(){if(2===ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var e=this.gl,t=this.getQueryTimerExtensionWebGL2(),r=e.createQuery();return e.beginQuery(t.TIME_ELAPSED_EXT,r),r}var n=this.getQueryTimerExtensionWebGL1(),a=n.createQueryEXT();return n.beginQueryEXT(n.TIME_ELAPSED_EXT,a),a},e.prototype.endQuery=function(){if(2!==ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")){var e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}else{var t=this.gl,r=this.getQueryTimerExtensionWebGL2();t.endQuery(r.TIME_ELAPSED_EXT)}},e.prototype.waitForQueryAndGetTime=function(e){return __awaiter(this,void 0,void 0,function(){var t=this;return __generator(this,function(r){switch(r.label){case 0:return[4,repeatedTry(function(){return t.isQueryAvailable(e,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))})];case 1:return r.sent(),[2,this.getQueryTime(e,ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))]}})})},e.prototype.getQueryTime=function(e,t){if(0===t)return null;if(2===t){var r=this.gl;return r.getQueryParameter(e,r.QUERY_RESULT)/1e6}var n=this.getQueryTimerExtensionWebGL1();return n.getQueryObjectEXT(e,n.QUERY_RESULT_EXT)/1e6},e.prototype.isQueryAvailable=function(e,t){if(0===t)return!0;if(2===t){var r=this.gl,n=this.getQueryTimerExtensionWebGL2(),a=r.getQueryParameter(e,r.QUERY_RESULT_AVAILABLE);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(n.GPU_DISJOINT_EXT)),a&&!this.disjoint}return a=(n=this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(e,n.QUERY_RESULT_AVAILABLE_EXT),null==this.disjoint&&(this.disjoint=this.gl.getParameter(n.GPU_DISJOINT_EXT)),a&&!this.disjoint},e.prototype.pollFence=function(e){var t=this;return new Promise(function(r){t.addItemToPoll(function(){return e.isFencePassed()},function(){return r()})})},e.prototype.pollItems=function(){for(var e=binSearchLastTrue(this.itemsToPoll.map(function(e){return e.isDoneFn})),t=0;t<=e;++t)(0,this.itemsToPoll[t].resolveFn)();this.itemsToPoll=this.itemsToPoll.slice(e+1)},e.prototype.addItemToPoll=function(e,t){var r=this;this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),this.itemsToPoll.length>1||repeatedTry(function(){return r.pollItems(),0===r.itemsToPoll.length})},e.prototype.bindTextureToFrameBuffer=function(e){this.throwIfDisposed(),bindColorTextureToFramebuffer(this.gl,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)},e.prototype.unbindTextureToFrameBuffer=function(){null!=this.outputTexture?(bindColorTextureToFramebuffer(this.gl,this.outputTexture,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)):unbindColorTextureFromFramebuffer(this.gl,this.framebuffer)},e.prototype.downloadMatrixDriver=function(e,t){this.bindTextureToFrameBuffer(e);var r=t();return this.unbindTextureToFrameBuffer(),r},e.prototype.setOutputMatrixTextureDriver=function(e,t,r){this.throwIfDisposed();var n=this.gl;bindColorTextureToFramebuffer(n,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(n),this.outputTexture=e,callAndCheck(n,function(){return n.viewport(0,0,t,r)}),callAndCheck(n,function(){return n.scissor(0,0,t,r)})},e.prototype.setOutputMatrixWriteRegionDriver=function(e,t,r,n){var a=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return a.gl.scissor(e,t,r,n)})},e.prototype.throwIfDisposed=function(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")},e.prototype.throwIfNoProgram=function(){if(null==this.program)throw new Error("No GPU program is currently set.")},e}();function binSearchLastTrue(e){for(var t=0,r=e.length-1,n=-1;t<=r;){var a=t+r>>1;e[a]()?(n=a,t=a+1):r=a-1}return n}function compileProgram(e,t,r,n){for(var a=t.userCode,o=r.map(function(e,r){var n={logicalShape:e.tensor.shape,texShape:e.isUniform?null:e.texData.texShape,isUniform:e.isUniform};return{name:t.variableNames[r],shapeInfo:n}}),i=o.map(function(e){return e.shapeInfo}),s={logicalShape:n.tensor.shape,texShape:n.texData.texShape,isUniform:!1},u=makeShader(o,s,a,!0===t.supportsBroadcasting),l=e.createProgram(u),p={},c=0;c= 0 && idx <= "+s+") {\n float z = getX(b, r, c, idx);\n sum += z * z;\n }\n }\n float val = x * "+o+";\n setOutput(val);\n }\n "},LRNGradProgram=function(e,t,r,n,a){this.variableNames=["inputImage","outputImage","dy"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=t,this.bias=r,this.alpha=n,this.beta=a,this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int r = coords[1];\n int c = coords[2];\n\n float result = 0.0;\n for (int d = 0; d < "+this.depth+"; ++d) {\n int depthBegin = int(max(0.0, float(d - "+t+")));\n int depthEnd = int(min(float("+this.depth+"),\n float(d + "+t+" + 1)));\n\n const int MIN_DEPTH_BEGIN = 0;\n const int MAX_DEPTH_END = "+this.depth+";\n\n float norm = 0.0;\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd) {\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\n }\n else {\n break;\n }\n }\n\n norm = float("+n+") * norm + float("+r+");\n\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\n if (k < depthBegin){\n continue;\n }\n else if (k >= depthBegin && k < depthEnd){\n float dyi = -2.0 * float("+n+")\n * float("+a+")\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\n / norm;\n if (k == d) {\n dyi += pow(norm, -1.0 * "+a+");\n }\n if (k == coords[3]) {\n dyi *= getDy(b, r, c, d);\n result += dyi;\n }\n }\n else {\n break;\n }\n }\n }\n setOutput(result);\n }\n "},MaxPool2DBackpropProgram=function(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;var t=e.filterHeight,r=e.filterWidth,n=e.strideHeight,a=e.strideWidth,o=t-1-e.padInfo.top,i=r-1-e.padInfo.left,s=t*r-1;this.userCode="\n const ivec2 pads = ivec2("+o+", "+i+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n\n ivec2 dyRCCorner = coords.yz - pads;\n int dyRCorner = dyRCCorner.x;\n int dyCCorner = dyRCCorner.y;\n\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\n // ? = to be determined. : = across all values in that axis.\n float dotProd = 0.0;\n for (int wR = 0; wR < "+t+"; wR++) {\n float dyR = float(dyRCorner + wR) / "+n+".0;\n\n if (dyR < 0.0 || dyR >= "+e.outHeight+".0 || fract(dyR) > 0.0) {\n continue;\n }\n int idyR = int(dyR);\n\n for (int wC = 0; wC < "+r+"; wC++) {\n float dyC = float(dyCCorner + wC) / "+a+".0;\n\n if (dyC < 0.0 || dyC >= "+e.outWidth+".0 ||\n fract(dyC) > 0.0) {\n continue;\n }\n int idyC = int(dyC);\n\n float dyValue = getDy(b, idyR, idyC, d);\n int maxPosValue = "+s+" - int(getMaxPos(b, idyR, idyC, d));\n\n // Get the current value, check it against the value from the\n // position matrix.\n int curPosValue = wR * "+r+" + wC;\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\n\n dotProd += dyValue * mask;\n }\n }\n setOutput(dotProd);\n }\n "},MatMulProgram=function(e,t,r,n){void 0===r&&(r=!1),void 0===n&&(n=!1),this.variableNames=["matrixA","matrixB"];var a=r?e[1]:e[0],o=n?t[0]:t[1],i=r?e[0]:e[1];this.outputShape=[a,o];var s=function(e,t){return r?t+" + "+e+", aRow":"aRow, "+t+" + "+e},u=function(e,t){return n?"bCol, "+t+" + "+e:t+" + "+e+", bCol"},l=4*Math.floor(i/4),p=i%4;this.userCode=" float dotARowBCol(int aRow, int bCol) {\n float result = 0.0;\n for (int i = 0; i < "+l+"; i += 4) {\n vec4 a = vec4(\n getMatrixA("+s(0,"i")+"),\n getMatrixA("+s(1,"i")+"),\n getMatrixA("+s(2,"i")+"),\n getMatrixA("+s(3,"i")+")\n );\n vec4 b = vec4(\n getMatrixB("+u(0,"i")+"),\n getMatrixB("+u(1,"i")+"),\n getMatrixB("+u(2,"i")+"),\n getMatrixB("+u(3,"i")+")\n );\n\n result += dot(a, b);\n }\n\n if ("+(1===p)+") {\n result += getMatrixA("+s(0,l)+") *\n getMatrixB("+u(0,l)+");\n } else if ("+(2===p)+") {\n vec2 a = vec2(\n getMatrixA("+s(0,l)+"),\n getMatrixA("+s(1,l)+")\n );\n vec2 b = vec2(\n getMatrixB("+u(0,l)+"),\n getMatrixB("+u(1,l)+")\n );\n result += dot(a, b);\n } else if ("+(3===p)+") {\n vec3 a = vec3(\n getMatrixA("+s(0,l)+"),\n getMatrixA("+s(1,l)+"),\n getMatrixA("+s(2,l)+")\n );\n vec3 b = vec3(\n getMatrixB("+u(0,l)+"),\n getMatrixB("+u(1,l)+"),\n getMatrixB("+u(2,l)+")\n );\n result += dot(a, b);\n }\n\n return result;\n }\n\n void main() {\n ivec2 resRC = getOutputCoords();\n setOutput(dotARowBCol(resRC.x, resRC.y));\n }\n "},MultinomialProgram=function(){function e(e,t,r){this.variableNames=["probs"],this.outputShape=[e,r],this.userCode="\n uniform float seed;\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n\n float r = random(seed);\n float cdf = 0.0;\n\n for (int i = 0; i < "+(t-1)+"; i++) {\n cdf += getProbs(batch, i);\n\n if (r < cdf) {\n setOutput(float(i));\n return;\n }\n }\n\n // If no other event happened, last event happened.\n setOutput(float("+(t-1)+"));\n }\n "}return e.prototype.getCustomSetupFunc=function(e){var t=this;return function(r,n){null==t.seedLoc&&(t.seedLoc=r.getUniformLocation(n,"seed")),r.gl.uniform1f(t.seedLoc,e)}},e}(),OneHotProgram=function(e,t,r,n){this.variableNames=["indices"],this.outputShape=[e,t],this.userCode="\n void main() {\n ivec2 coords = getOutputCoords();\n int index = round(getIndices(coords.x));\n setOutput(mix(float("+n+"), float("+r+"),\n float(index == coords.y)));\n }\n "},PadProgram=function(e,t,r){this.variableNames=["x"],this.outputShape=t.map(function(t,r){return t[0]+e[r]+t[1]});var n=e.length,a=getCoordsDataType(n),o=t.map(function(e){return e[0]}).join(","),i=t.map(function(t,r){return t[0]+e[r]}).join(","),s=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,n);this.userCode=1!==n?"\n "+a+" start = "+a+"("+o+");\n "+a+" end = "+a+"("+i+");\n\n void main() {\n "+a+" outC = getOutputCoords();\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\n setOutput(float("+r+"));\n } else {\n "+a+" coords = outC - start;\n setOutput(getX("+s+"));\n }\n }\n ":"\n int start = "+o+";\n int end = "+i+";\n\n void main() {\n int outC = getOutputCoords();\n if (outC < start || outC >= end) {\n setOutput(float("+r+"));\n } else {\n setOutput(getX(outC - start));\n }\n }\n "},Pool2DProgram=function(e,t,r){if(this.variableNames=["x"],"avg"===t&&r)throw new Error("Cannot compute positions for average pool.");var n=e.filterHeight,a=e.filterWidth,o=e.strideHeight,i=e.strideWidth,s=e.padInfo.top,u=e.padInfo.left;this.outputShape=e.outShape;var l="avg"===t,p="0.0";if(l||(p="-1.0 / 0.0"),r)this.userCode="\n const ivec2 strides = ivec2("+o+", "+i+");\n const ivec2 pads = ivec2("+s+", "+u+");\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n float minMaxValue = 0.0;\n float minMaxValueFound = 0.0;\n int minMaxPosition = 0;\n float avgValue = 0.0;\n\n for (int wR = 0; wR < "+n+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+a+"; wC++) {\n int xC = xCCorner + wC;\n\n if (xC < 0 || xC >= "+e.inWidth+") {\n continue;\n }\n\n float value = getX(batch, xR, xC, d);\n\n // If a min / max value has already been found, use it. If not,\n // use the current value.\n float currMinMaxValue = mix(\n value, minMaxValue, minMaxValueFound);\n if (value >= currMinMaxValue) {\n minMaxValue = value;\n minMaxValueFound = 1.0;\n minMaxPosition = wR * "+a+" + wC;\n }\n }\n }\n setOutput(float(minMaxPosition));\n }\n ";else{var c=t+"("+t+"("+t+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"avg"===t&&(c="avgValue / count");var d=4*Math.floor(a/4),h=a%4,f="\n if ("+l+") {\n avgValue += dot(values, ones);\n } else {\n minMaxValue = max(values, minMaxValue);\n }\n ";this.userCode="\n const ivec2 strides = ivec2("+o+", "+i+");\n const ivec2 pads = ivec2("+s+", "+u+");\n const float initializationValue = "+p+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float count = 0.0;\n\n float getValue(int batch, int xR, int xC, int d) {\n if (xC < 0 || xC >= "+e.inWidth+") {\n return initializationValue;\n }\n count += 1.0;\n return getX(batch, xR, xC, d);\n }\n\n void main() {\n ivec4 coords = getOutputCoords();\n int batch = coords[0];\n int d = coords[3];\n\n ivec2 xRCCorner = coords.yz * strides - pads;\n int xRCorner = xRCCorner.x;\n int xCCorner = xRCCorner.y;\n\n // max/min x(?, ?, d) to get y(yR, yC, d).\n // ? = to be determined\n vec4 minMaxValue = vec4("+p+");\n float avgValue = 0.0;\n count = 0.0;\n\n for (int wR = 0; wR < "+n+"; wR++) {\n int xR = xRCorner + wR;\n\n if (xR < 0 || xR >= "+e.inHeight+") {\n continue;\n }\n\n for (int wC = 0; wC < "+d+"; wC += 4) {\n int xC = xCCorner + wC;\n\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n getValue(batch, xR, xC + 3, d)\n );\n\n "+f+"\n }\n\n int xC = xCCorner + "+d+";\n if ("+(1===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+f+"\n } else if ("+(2===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n initializationValue,\n initializationValue\n );\n\n "+f+"\n } else if ("+(3===h)+") {\n vec4 values = vec4(\n getValue(batch, xR, xC, d),\n getValue(batch, xR, xC + 1, d),\n getValue(batch, xR, xC + 2, d),\n initializationValue\n );\n\n "+f+"\n }\n }\n setOutput("+c+");\n }\n "}},ReduceProgram=function(e,t){this.variableNames=["x"];var r=e.windowSize,n=e.batchSize,a=e.inSize,o=Math.ceil(a/r);this.outputShape=[n,o];var i="0.0",s="";"min"===t?(i="1.0 / 0.0",s="min"):"max"===t&&(i="-1.0 / 0.0",s="max");var u=t+"("+t+"("+t+"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])";"sum"===t?u="sumValue":"all"===t?u="allValue":"any"===t&&(u="anyValue");var l=4*Math.floor(r/4),p=r%4,c="\n if ("+("sum"===t)+") {\n sumValue += dot(values, ones);\n } else {\n minMaxValue = "+s+"(values, minMaxValue);\n }\n ",d="vec4";"all"===t?(i="1.0",c="\n bool reducedAllValue = all(values);\n float floatedReducedAllValue = float(reducedAllValue);\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\n ",d="bvec4"):"any"===t&&(i="0.0",c="\n bool reducedAnyValue = any(values);\n float floatedReducedAnyValue = float(reducedAnyValue);\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\n ",d="bvec4");var h="";a%r>0&&(h="\n if (inIdx < 0 || inIdx >= "+a+") {\n return initializationValue;\n }\n "),this.userCode="\n const float initializationValue = "+i+";\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\n\n float getValue(int batch, int inIdx) {\n "+h+"\n return getX(batch, inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = outIdx * "+r+";\n\n vec4 minMaxValue = vec4("+i+");\n float sumValue = 0.0;\n float allValue = 1.0;\n float anyValue = 0.0;\n\n for (int i = 0; i < "+l+"; i += 4) {\n int inIdx = inOffset + i;\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n "+c+"\n }\n\n int inIdx = inOffset + "+l+";\n if ("+(1===p)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n "+c+"\n } else if ("+(2===p)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n "+c+"\n } else if ("+(3===p)+") {\n "+d+" values = "+d+"(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n "+c+"\n }\n setOutput("+u+");\n }\n "},ResizeBilinearBackpropProgram=function(e,t,r){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t.shape;var n=t.shape,a=n[1],o=n[2],i=e.shape,s=i[1],u=i[2],l=[r&&s>1?a-1:a,r&&u>1?o-1:o],p=[r&&s>1?s-1:s,r&&u>1?u-1:u],c=l[0]/p[0],d=l[1]/p[1],h=1/c,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+c+");\n const float widthScale = float("+d+");\n\n const float invHeightScale = float("+h+");\n const float invWidthScale = float("+f+");\n\n const int winHeight = int("+m+");\n const int winWidth = int("+g+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(startRLerp - float(winHeight / 2));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(startCLerp - float(winWidth / 2));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+s+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+u+") {\n continue;\n }\n\n float dxR = float(dyR) * heightScale;\n int topDxRIndex = int(floor(dxR));\n int bottomDxRIndex = int(min(ceil(dxR), "+(a-1)+".0));\n float dxRLerp = dxR - float(topDxRIndex);\n float inverseDxRLerp = 1.0 - dxRLerp;\n\n float dxC = float(dyC) * widthScale;\n int leftDxCIndex = int(floor(dxC));\n int rightDxCIndex = int(min(ceil(dxC), "+(o-1)+".0));\n float dxCLerp = dxC - float(leftDxCIndex);\n float inverseDxCLerp = 1.0 - dxCLerp;\n\n if (r == topDxRIndex && c == leftDxCIndex) {\n // topLeft\n accumulator +=\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\n }\n\n if (r == topDxRIndex && c == rightDxCIndex) {\n // topRight\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\n }\n\n if (r == bottomDxRIndex && c == leftDxCIndex) {\n // bottomLeft\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\n }\n\n if (r == bottomDxRIndex && c == rightDxCIndex) {\n // bottomRight\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "},ResizeBilinearProgram=function(e,t,r,n){this.variableNames=["A"],this.outputShape=[];var a=e[0],o=e[1],i=e[2],s=e[3];this.outputShape=[a,t,r,s];var u=[n&&t>1?o-1:o,n&&r>1?i-1:i],l=[n&&t>1?t-1:t,n&&r>1?r-1:r];this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+u[0]/l[0]+",\n "+u[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+o+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the four integer indices.\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\n ivec2 sourceCeilRC = ivec2(\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\n\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\n\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\n\n float top = topLeft + (topRight - topLeft) * fracRC.y;\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\n float newValue = top + (bottom - top) * fracRC.x;\n\n setOutput(newValue);\n }\n "},ResizeNearestNeigborBackpropProgram=function(e,t,r){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t.shape;var n=t.shape,a=n[1],o=n[2],i=e.shape,s=i[1],u=i[2],l=[r&&s>1?a-1:a,r&&u>1?o-1:o],p=[r&&s>1?s-1:s,r&&u>1?u-1:u],c=l[0]/p[0],d=l[1]/p[1],h=1/c,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode="\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n int r = coords[1];\n int c = coords[2];\n\n float accumulator = 0.0;\n\n const float heightScale = float("+c+");\n const float widthScale = float("+d+");\n\n const float invHeightScale = float("+h+");\n const float invWidthScale = float("+f+");\n\n const int winHeight = int("+m+");\n const int winWidth = int("+g+");\n\n // Compute bounds for where in dy we will look\n float startRLerp = floor(float(r) * invHeightScale);\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\n\n float startCLerp = floor(float(c) * invWidthScale);\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\n\n // Loop over dy\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\n int dyR = dyROffset + startDyR;\n\n // Guard against the window exceeding the bounds of dy\n if (dyR < 0 || dyR >= "+s+") {\n continue;\n }\n\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\n int dyC = dyCOffset + startDyC;\n\n // Guard against the window exceeding the bounds of dy\n if (dyC < 0 || dyC >= "+u+") {\n continue;\n }\n\n float sourceFracRow =\n float("+l[0]+") *\n (float(dyR) / float("+p[0]+"));\n\n float sourceFracCol =\n float("+l[1]+") *\n (float(dyC) / float("+p[1]+"));\n\n int sourceNearestRow = int(min(\n float(int("+a+") - 1),\n "+r+" ? float(round(sourceFracRow)) :\n float(floor(sourceFracRow))));\n\n int sourceNearestCol = int(min(\n float(int("+o+") - 1),\n "+r+" ? float(round(sourceFracCol)) :\n float(floor(sourceFracCol))));\n\n if (r == sourceNearestRow && c == sourceNearestCol) {\n accumulator += getDy(b, dyR, dyC, d);\n }\n }\n }\n // End loop over dy\n\n setOutput(accumulator);\n }\n "},ResizeNearestNeighborProgram=function(e,t,r,n){this.variableNames=["A"],this.outputShape=[];var a=e[0],o=e[1],i=e[2],s=e[3];this.outputShape=[a,t,r,s];var u=[n&&t>1?o-1:o,n&&r>1?i-1:i],l=[n&&t>1?t-1:t,n&&r>1?r-1:r],p=n?"0.5":"0.0";this.userCode="\n const vec2 effectiveInputOverOutputRatioRC = vec2(\n "+u[0]/l[0]+",\n "+u[1]/l[1]+");\n const vec2 inputShapeRC = vec2("+o+".0, "+i+".0);\n\n void main() {\n ivec4 coords = getOutputCoords();\n int b = coords[0];\n int d = coords[3];\n ivec2 yRC = coords.yz;\n\n // Fractional source index.\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\n\n // Compute the coordinators of nearest neighbor point.\n ivec2 sourceNearestRC = ivec2(\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + "+p+")));\n\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\n\n setOutput(newValue);\n }\n "},ReverseProgram=function(e,t){this.variableNames=["x"];var r=e.length;if(r>4)throw new Error("WebGL backend: Reverse of rank-"+r+" tensor is not yet supported");if(this.outputShape=e,1!==r){var n=e.map(function(r,n){return function(r){return-1!==t.indexOf(r)&&1!==e[r]?e[r]+" - coords["+r+"] - 1":"coords["+r+"]"}(n)}).join(","),a=getCoordsDataType(r);this.userCode="\n void main() {\n "+a+" coords = getOutputCoords();\n setOutput(getX("+n+"));\n }\n "}else this.userCode="\n void main() {\n int coord = getOutputCoords();\n setOutput(getX("+e[0]+" - coord - 1));\n }\n "},SegmentOpProgram=function(e,t){this.variableNames=["x","segmentIds"];var r=e.windowSize,n=e.batchSize,a=e.inSize,o=e.numSegments,i=o*Math.ceil(a/r);this.outputShape=[n,i];var s=4*Math.floor(r/4),u=r%4,l="\n sumValue += dot(values, filter);\n ",p="";a%r>0&&(p="\n if (inIdx < 0 || inIdx >= "+a+") {\n return initializationValue;\n }\n ");var c="";a%r>0&&(c="\n if (inIdx < 0 || inIdx >= "+a+") {\n return -1.0;\n }\n "),this.userCode="\n const float initializationValue = 0.0;\n\n float getValue(int batch, int inIdx) {\n "+p+"\n return getX(batch, inIdx);\n }\n\n float getSegmentIdAtIndex(int inIdx) {\n "+c+"\n return getSegmentIds(inIdx);\n }\n\n void main() {\n ivec2 coords = getOutputCoords();\n int batch = coords[0];\n int outIdx = coords[1];\n int inOffset = int(floor(float(outIdx) / float(\n "+o+")) * float("+r+"));\n int currentSeg = int(mod(float(outIdx), float("+o+")));\n\n float sumValue = 0.0;\n\n for (int i = 0; i < "+s+"; i += 4) {\n int inIdx = inOffset + i;\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n getValue(batch, inIdx + 3)\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\n );\n\n "+l+"\n }\n\n int inIdx = inOffset + "+s+";\n if ("+(1===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n initializationValue,\n initializationValue,\n initializationValue\n );\n\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(2===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n initializationValue,\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n 0,\n 0\n );\n\n "+l+"\n } else if ("+(3===u)+") {\n vec4 values = vec4(\n getValue(batch, inIdx),\n getValue(batch, inIdx + 1),\n getValue(batch, inIdx + 2),\n initializationValue\n );\n\n vec4 filter = vec4(\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\n 0\n );\n\n "+l+"\n }\n setOutput(sumValue);\n }\n "},SelectProgram=function(e,t,r){var n,a;if(this.variableNames=["c","a","b"],this.outputShape=t,r>4)throw Error("Where for rank "+r+" is not yet supported");if(1===r)a="resRC",n="resRC";else{for(var o=["resRC.x","resRC.y","resRC.z","resRC.w"],i=[],s=[],u=0;u= 1.0) {\n setOutput(getA("+a+"));\n } else {\n setOutput(getB("+a+"));\n }\n }\n "},SliceProgram=function(){function e(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;var t=getCoordsDataType(this.rank),r=getCoords$1(this.rank);this.userCode="\n uniform "+t+" start;\n\n void main() {\n "+t+" sourceLoc = start + getOutputCoords();\n setOutput(getSource("+r+"));\n }\n "}return e.prototype.getCustomSetupFunc=function(e){var t=this;if(e.length!==this.rank)throw Error("The rank ("+this.rank+") of the program must match the length of start ("+e.length+")");return function(r,n){if(null!=t.startLoc||(t.startLoc=r.getUniformLocationNoThrow(n,"start"),null!=t.startLoc))if(1===t.rank)r.gl.uniform1i(t.startLoc,e[0]);else if(2===t.rank)r.gl.uniform2i(t.startLoc,e[0],e[1]);else if(3===t.rank)r.gl.uniform3i(t.startLoc,e[0],e[1],e[2]);else{if(4!==t.rank)throw Error("Slicing for rank "+t.rank+" is not yet supported");r.gl.uniform4i(t.startLoc,e[0],e[1],e[2],e[3])}}},e}();function getCoords$1(e){if(1===e)return"sourceLoc";if(2===e)return"sourceLoc.x, sourceLoc.y";if(3===e)return"sourceLoc.x, sourceLoc.y, sourceLoc.z";if(4===e)return"sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w";throw Error("Slicing for rank "+e+" is not yet supported")}var StridedSliceProgram=function(e,t,r){this.variableNames=["x"],this.outputShape=r,this.rank=r.length;var n,a=getCoordsDataType(this.rank);n=1===this.rank?"coords * strides + begin":r.map(function(e,t){return"coords["+t+"] * strides["+t+"] + begin["+t+"]"}).join(","),this.userCode="\n "+a+" begin = "+a+"("+e+");\n "+a+" strides = "+a+"("+t+");\n\n void main() {\n "+a+" coords = getOutputCoords();\n setOutput(getX("+n+"));\n }\n "},TextureManager=function(){function e(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}return e.prototype.acquireTexture=function(e,t){var r,n=getPhysicalFromLogicalTextureType(t),a=getKeyFromTextureShape(e,n);if(a in this.freeTextures||(this.freeTextures[a]=[]),a in this.usedTextures||(this.usedTextures[a]=[]),this.freeTextures[a].length>0){this.numFreeTextures--,this.numUsedTextures++,this.log();var o=this.freeTextures[a].shift();return this.usedTextures[a].push(o),o}return this.numUsedTextures++,this.log(),n===PhysicalTextureType.FLOAT32?r=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):n===PhysicalTextureType.FLOAT16?r=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):n===PhysicalTextureType.UNSIGNED_BYTE&&(r=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[a].push(r),r},e.prototype.releaseTexture=function(e,t,r){var n=getKeyFromTextureShape(t,getPhysicalFromLogicalTextureType(r));n in this.freeTextures||(this.freeTextures[n]=[]),this.freeTextures[n].push(e),this.numFreeTextures++,this.numUsedTextures--;var a=this.usedTextures[n],o=a.indexOf(e);if(o<0)throw new Error("Cannot release a texture that was never provided by this texture manager");a.splice(o,1),this.log()},e.prototype.log=function(){if(this.logEnabled){var e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",this.numFreeTextures+" / "+this.numUsedTextures,"("+e+")")}},e.prototype.getNumUsedTextures=function(){return this.numUsedTextures},e.prototype.getNumFreeTextures=function(){return this.numFreeTextures},e.prototype.dispose=function(){var e=this;if(null!=this.freeTextures){for(var t in this.freeTextures)this.freeTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});for(var t in this.usedTextures)this.usedTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0}},e}();function getPhysicalFromLogicalTextureType(e){if(e===TextureUsage.DOWNLOAD||e===TextureUsage.PIXELS)return PhysicalTextureType.UNSIGNED_BYTE;if(e===TextureUsage.UPLOAD)return PhysicalTextureType.FLOAT32;if(e===TextureUsage.RENDER)return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")?PhysicalTextureType.FLOAT32:PhysicalTextureType.FLOAT16;throw new Error("Unknown logical texture type "+e)}function getKeyFromTextureShape(e,t){return e[0]+"_"+e[1]+"_"+t}var TileProgram=function(e,t){this.variableNames=["A"];for(var r=new Array(e.length),n=0;n5)throw Error("Tile for rank "+t+" is not yet supported");if(1===t)return"imod(resRC, "+e[0]+")";for(var r=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],n=[],a=0;a6)throw Error("Transpose for rank "+t+" is not yet supported");for(var r=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u","resRC.v"],n=new Array(t),a=0;a= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\n";function STEP(e){return void 0===e&&(e=0),CHECK_NAN_SNIPPET$1+"\n return x > 0.0 ? 1.0 : float("+e+");\n "}var NEG="return -x;",CEIL="return ceil(x);",FLOOR="return floor(x);",SIGN="\n if (isNaN(x)) { return 0.0; }\n return sign(x);\n",ROUND="\n // OpenGL ES does not support round function.\n // The algorithm is based on banker's rounding.\n float base = floor(x);\n if ((x - base) < 0.5) {\n return floor(x);\n } else if ((x - base) > 0.5) {\n return ceil(x);\n } else {\n if (mod(base, 2.0) == 0.0) {\n return base;\n } else {\n return base + 1.0;\n }\n }\n",EXP="return exp(x);",EXPM1="return exp(x) - 1.0;",LOG="if (x < 0.0) return NAN;\n return log(x);",LOG1P="return log(1.0 + x);",SQRT="return sqrt(x);",RSQRT="return inversesqrt(x);",SIGMOID="return 1.0 / (1.0 + exp(-1.0 * x));",SOFTPLUS="\n float epsilon = 1.1920928955078125e-7;\n float threshold = log(epsilon) + 2.0;\n\n bool too_large = x > -threshold;\n bool too_small = x < threshold;\n\n float result;\n float exp_x = exp(x);\n\n if (too_large){\n result = x;\n }\n else if (too_small){\n result = exp_x;\n }\n else{\n result = log(exp_x + 1.0);\n }\n return result;\n",SIN=CHECK_NAN_SNIPPET$1+"\n return sin(x);\n",COS=CHECK_NAN_SNIPPET$1+"\n return cos(x);\n",TAN="return tan(x);",ASIN="return asin(x);",ACOS="return acos(x);",ATAN=CHECK_NAN_SNIPPET$1+"\n return atan(x);\n",SINH="\n float e2x = exp(x);\n return (e2x - 1.0 / e2x) / 2.0;\n",COSH="\n float e2x = exp(-x);\n return (e2x + 1.0 / e2x) / 2.0;\n",TANH="\n float e2x = exp(-2.0 * abs(x));\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\n",ASINH="return log(x + sqrt(x * x + 1.0));",ACOSH=CHECK_NAN_SNIPPET$1+"\n if (x < 1.0) return NAN;\n return log(x + sqrt(x * x - 1.0));",ATANH=CHECK_NAN_SNIPPET$1+"\n if ((x < -1.0) || (x > 1.0)) return NAN;\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;",ERF='\n // Error function is calculated approximately with elementary function.\n // See "Handbook of Mathematical Functions with Formulas,\n // Graphs, and Mathematical Tables", Abramowitz and Stegun.\n float p = '+ERF_P+";\n float a1 = "+ERF_A1+";\n float a2 = "+ERF_A2+";\n float a3 = "+ERF_A3+";\n float a4 = "+ERF_A4+";\n float a5 = "+ERF_A5+";\n\n float t = 1.0 / (1.0 + p * x);\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\n",SQUARE="return x * x;",RECIPROCAL="return 1.0 / x;",LOGICAL_NOT="return float(!(x >= 1.0));",TO_INT="return float(int(x));";function concat1d_(e){return concat(e,0)}function concat2d_(e,t){return concat(e,t)}function concat3d_(e,t){return concat(e,t)}function concat4d_(e,t){return concat(e,t)}function concat_(e,t){void 0===t&&(t=0),assert(e.length>=1,"Pass at least one tensor to concat");var r=convertToTensorArray(e,"tensors","concat"),n=r[0];if(1===r.length)return n;for(var a=parseAxisParam(t,n.shape),o=1;o>>0,t=(n*=t)>>>0,t+=4294967296*(n-=t)}return 2.3283064365386963e-10*(t>>>0)});r.next=function(){var e=2091639*r.s0+2.3283064365386963e-10*r.c;return r.s0=r.s1,r.s1=r.s2,r.s2=e-(r.c=0|e)},r.c=1,r.s0=n(" "),r.s1=n(" "),r.s2=n(" "),r.s0-=n(e),r.s0<0&&(r.s0+=1),r.s1-=n(e),r.s1<0&&(r.s1+=1),r.s2-=n(e),r.s2<0&&(r.s2+=1),n=null}(e),a=t&&t.state,o=r.next;return o.int32=function(){return 4294967296*r.next()|0},o.double=function(){return o()+1.1102230246251565e-16*(2097152*o()|0)},o.quick=o,a&&("object"==typeof a&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.alea=a}(0,e)}),xor128=createCommonjsModule(function(e){!function(e,t,r){function n(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t}function a(e,t){var r=new function(e){var t=this,r="";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:r+=e;for(var n=0;n>>0)/4294967296};return o.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},o.int32=r.next,o.quick=o,a&&("object"==typeof a&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.xor128=a}(0,e)}),xorwow=createCommonjsModule(function(e){!function(e,t,r){function n(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function a(e,t){var r=new function(e){var t=this,r="";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,t.v=0,e===(0|e)?t.x=e:r+=e;for(var n=0;n>>4),t.next()}(e),a=t&&t.state,o=function(){return(r.next()>>>0)/4294967296};return o.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},o.int32=r.next,o.quick=o,a&&("object"==typeof a&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.xorwow=a}(0,e)}),xorshift7=createCommonjsModule(function(e){!function(e,t,r){function n(e,t){return t.x=e.x.slice(),t.i=e.i,t}function a(e,t){null==e&&(e=+new Date);var r=new function(e){var t=this;t.next=function(){var e,r,n=t.x,a=t.i;return e=n[a],r=(e^=e>>>7)^e<<24,r^=(e=n[a+1&7])^e>>>10,r^=(e=n[a+3&7])^e>>>3,r^=(e=n[a+4&7])^e<<7,e=n[a+7&7],r^=(e^=e<<13)^e<<9,n[a]=r,t.i=a+1&7,r},function(e,t){var r,n=[];if(t===(0|t))n[0]=t;else for(t=""+t,r=0;r0;--r)e.next()}(t,e)}(e),a=t&&t.state,o=function(){return(r.next()>>>0)/4294967296};return o.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},o.int32=r.next,o.quick=o,a&&(a.x&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.xorshift7=a}(0,e)}),xor4096=createCommonjsModule(function(e){!function(e,t,r){function n(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function a(e,t){null==e&&(e=+new Date);var r=new function(e){var t=this;t.next=function(){var e,r,n=t.w,a=t.X,o=t.i;return t.w=n=n+1640531527|0,r=a[o+34&127],e=a[o=o+1&127],r^=r<<13,e^=e<<17,r^=r>>>15,e^=e>>>12,r=a[o]=r^e,t.i=o,r+(n^n>>>16)|0},function(e,t){var r,n,a,o,i,s=[],u=128;for(t===(0|t)?(n=t,t=null):(t+="\0",n=0,u=Math.max(u,t.length)),a=0,o=-32;o>>15,n^=n<<4,n^=n>>>13,o>=0&&(i=i+1640531527|0,a=0==(r=s[127&o]^=n+i)?a+1:0);for(a>=128&&(s[127&(t&&t.length||0)]=-1),a=127,o=512;o>0;--o)n=s[a+34&127],r=s[a=a+1&127],n^=n<<13,r^=r<<17,n^=n>>>15,r^=r>>>12,s[a]=n^r;e.w=i,e.X=s,e.i=a}(t,e)}(e),a=t&&t.state,o=function(){return(r.next()>>>0)/4294967296};return o.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},o.int32=r.next,o.quick=o,a&&(a.X&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.xor4096=a}(0,e)}),tychei=createCommonjsModule(function(e){!function(e,t,r){function n(e,t){return t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t}function a(e,t){var r=new function(e){var t=this,r="";t.next=function(){var e=t.b,r=t.c,n=t.d,a=t.a;return e=e<<25^e>>>7^r,r=r-n|0,n=n<<24^n>>>8^a,a=a-e|0,t.b=e=e<<20^e>>>12^r,t.c=r=r-n|0,t.d=n<<16^r>>>16^a,t.a=a-e|0},t.a=0,t.b=0,t.c=-1640531527,t.d=1367130551,e===Math.floor(e)?(t.a=e/4294967296|0,t.b=0|e):r+=e;for(var n=0;n>>0)/4294967296};return o.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},o.int32=r.next,o.quick=o,a&&("object"==typeof a&&n(a,r),o.state=function(){return n(r,{})}),o}t&&t.exports?t.exports=a:this.tychei=a}(0,e)}),seedrandom=createCommonjsModule(function(e){!function(t,r){var n,a=this,o=256,i=6,s="random",u=r.pow(o,i),l=r.pow(2,52),p=2*l,c=o-1;function d(e,d,g){var y=[],v=f(function e(t,r){var n,a=[],o=typeof t;if(r&&"object"==o)for(n in t)try{a.push(e(t[n],r-1))}catch(e){}return a.length?a:"string"==o?t:t+"\0"}((d=1==d?{entropy:!0}:d||{}).entropy?[e,m(t)]:null==e?function(){try{var e;return n&&(e=n.randomBytes)?e=e(o):(e=new Uint8Array(o),(a.crypto||a.msCrypto).getRandomValues(e)),m(e)}catch(e){var r=a.navigator,i=r&&r.plugins;return[+new Date,a,i,a.screen,m(t)]}}():e,3),y),b=new function(e){var t,r=e.length,n=this,a=0,i=n.i=n.j=0,s=n.S=[];for(r||(e=[r++]);a=p;)e/=2,t/=2,r>>>=1;return(e+r)/t};return x.int32=function(){return 0|b.g(4)},x.quick=function(){return b.g(4)/4294967296},x.double=x,f(m(b.S),t),(d.pass||g||function(e,t,n,a){return a&&(a.S&&h(a,b),e.state=function(){return h(b,{})}),n?(r[s]=e,t):e})(x,v,"global"in d?d.global:this==r,d.state)}function h(e,t){return t.i=e.i,t.j=e.j,t.S=e.S.slice(),t}function f(e,t){for(var r,n=e+"",a=0;a=1||0===i);var s=Math.sqrt(-2*Math.log(i)/i);t=this.mean+this.stdDev*a*s,r=this.mean+this.stdDev*o*s,this.truncated&&!this.isValidTruncated(t)||(n=!0)}return this.truncated&&!this.isValidTruncated(r)||(this.nextVal=this.convertValue(r)),this.convertValue(t)},e.prototype.convertValue=function(e){return null==this.dtype||"float32"===this.dtype?e:Math.round(e)},e.prototype.isValidTruncated=function(e){return e<=this.upper&&e>=this.lower},e}();function clone_(e){var t=convertToTensor(e,"x","clone");return ENV.engine.runKernel(function(e){return Tensor.make(t.shape,{dataId:t.dataId},t.dtype)},{$x:t},function(e){return{$x:function(){return e.toFloat()}}})}function eye_(e,t,r,n){void 0===n&&(n="float32"),null==t&&(t=e);for(var a=buffer([e,t],n),o=e<=t?e:t,i=0;i2)throw new Error("Rank of probabilities must be 1 or 2, but is "+i);r=r||Math.random();var s=1===i?a.as2D(1,-1):a,u=ENV.engine.runKernel(function(e){return e.multinomial(s,n,t,r)},{logits2D:s});return 1===i?u.as1D():u}function oneHot_(e,t,r,n){void 0===r&&(r=1),void 0===n&&(n=0);var a=convertToTensor(e,"indices","oneHot","int32");if(assert("int32"===a.dtype,"Indices must be of dtype `int32`"),t<2)throw new Error("Error in oneHot: depth must be >=2, but it is "+t);return ENV.engine.runKernel(function(e){return e.oneHot(a,t,r,n)},{$indices:a})}function fromPixels_(e,t){if(void 0===t&&(t=3),t>4)throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");return ENV.engine.fromPixels(e,t)}function toPixels(e,t){return __awaiter(this,void 0,void 0,function(){var r,n,a,o,i,s,u,l,p,c,d,h,f,m,g,y,v,b,x,w;return __generator(this,function(S){switch(S.label){case 0:if(2!==(r=convertToTensor(e,"img","toPixels","int32")).rank&&3!==r.rank)throw new Error("toPixels only supports rank 2 or 3 tensors, got rank "+r.rank+".");if(n=r.shape.slice(0,2),a=n[0],o=n[1],(i=2===r.rank?1:r.shape[2])>4||2===i)throw new Error("toPixels only supports depth of size 1, 3 or 4 but got "+i);return s=r.min(),u=r.max(),[4,s.data()];case 1:return l=S.sent()[0],[4,u.data()];case 2:if(p=S.sent()[0],s.dispose(),u.dispose(),"float32"===r.dtype){if(l<0||p>1)throw new Error("Tensor values for a float32 Tensor must be in the range [0 - 1] but got range ["+l+" - "+p+"].")}else{if("int32"!==r.dtype)throw new Error("Unsupported type for toPixels: "+r.dtype+". Please use float32 or int32 tensors.");if(l<0||p>255)throw new Error("Tensor values for a int32 Tensor must be in the range [0 - 255] but got range ["+l+" - "+p+"].")}return[4,r.data()];case 3:for(c=S.sent(),d="float32"===r.dtype?255:1,h=new Uint8ClampedArray(o*a*4),f=0;f=1,"Pass at least one tensor to tf.stack"),1===r.length)return r[0].expandDims(t);var n=r[0].rank,a=r[0].shape,o=r[0].dtype;assert(t<=n,"Axis must be <= rank of the tensor"),r.forEach(function(e){assertShapesMatch(a,e.shape,"All tensors passed to stack must have matching shapes")}),r.forEach(function(e){assert(o===e.dtype,"All tensors passed to stack must have matching dtypes")});var i=r.map(function(e){return e.expandDims(t)});return concat(i,t)}function batchToSpaceND_(e,t,r){var n=convertToTensor(e,"x","batchToSpaceND"),a=t.reduce(function(e,t){return e*t});return assert(n.rank>=1+t.length,"input rank should be > than [blockShape] but got "+n.rank),assert(r.length===t.length,"crops.shape[0] must be equal to [blockShape] but got "+r.length),assert(n.shape[0]%a==0,"input tensor batch must be divisible by prod( blockShape )"),ENV.engine.runKernel(function(e){return e.batchToSpaceND(n,t,r)},{})}function spaceToBatchND_(e,t,r){var n=convertToTensor(e,"x","spaceToBatchND");return assert(n.rank>=1+t.length,"input rank should be > than [blockShape] but got "+n.rank),assert(r.length===t.length,"paddings.shape[0] must be equal to [blockShape], got "+r.length),assert(n.shape.reduce(function(e,r,n){return n>0&&n<=t.length?e&&r%t[n-1]==0:e},!0),"input spatial dimensions must be divisible by blockShapes"),ENV.engine.runKernel(function(e){return e.spaceToBatchND(n,t,r)},{})}function unstack_(e,t){void 0===t&&(t=0);for(var r,n=convertToTensor(e,"x","unstack"),a=n.shape[t],o=Array(n.rank-1).fill(0),i=0,s=0;s0?this.gpgpu.beginQuery():{startMs:performance.now(),endMs:null}},e.prototype.endTimer=function(e){return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(this.gpgpu.endQuery(),e):(e.endMs=performance.now(),e)},e.prototype.getQueryTime=function(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(r){return ENV.get("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?[2,this.gpgpu.waitForQueryAndGetTime(e)]:[2,(t=e).endMs-t.startMs]})})},e.prototype.disposeData=function(e){if(!this.pendingDisposal.has(e))if(this.pendingRead.has(e))this.pendingDisposal.add(e);else if(this.texData.has(e)){var t=this.texData.get(e),r=t.texture,n=t.texShape,a=t.usage;null!=r&&this.releaseTexture(e,r,n,a),this.texData.delete(e)}},e.prototype.getTexture=function(e){return this.uploadToGPU(e),this.texData.get(e).texture},e.prototype.getGPGPUContext=function(){return this.gpgpu},e.prototype.getCanvas=function(){return this.canvas},e.prototype.slice=function(e,t,r){var n=new SliceProgram(r),a=n.getCustomSetupFunc(t);return this.compileAndRun(n,[e],null,a)},e.prototype.stridedSlice=function(e,t,r,n,a,o){var i=getStridedSlicedInfo(e.shape,t,r,n,a,o),s=i[0],u=i[1];if(u.some(function(e){return 0===e}))return tensor([],u);var l=new StridedSliceProgram(s,n,u);return this.compileAndRun(l,[e])},e.prototype.reverse=function(e,t){var r=new ReverseProgram(e.shape,t);return this.compileAndRun(r,[e])},e.prototype.concat=function(e,t){var r=new ConcatProgram(e.shape,t.shape);return this.compileAndRun(r,[e,t])},e.prototype.neg=function(e){var t=new UnaryOpProgram(e.shape,NEG);return this.compileAndRun(t,[e])},e.prototype.matMul=function(e,t,r,n){var a=new MatMulProgram(e.shape,t.shape,r,n);return this.compileAndRun(a,[e,t])},e.prototype.multiply=function(e,t){var r=new BinaryOpProgram(MUL,e.shape,t.shape),n=this.makeOutputArray(r.outputShape,upcastType(e.dtype,t.dtype));return this.compileAndRun(r,[e,t],n)},e.prototype.batchNormalization=function(e,t,r,n,a,o){var i=[e,t,r],s=null;null!=o&&(s=o.shape,i.push(o));var u=null;null!=a&&(u=a.shape,i.push(a));var l=new BatchNormProgram(e.shape,t.shape,r.shape,s,u,n);return this.compileAndRun(l,i)},e.prototype.localResponseNormalization4D=function(e,t,r,n,a){var o=new LRNProgram(e.shape,t,r,n,a);return this.compileAndRun(o,[e])},e.prototype.LRNGrad=function(e,t,r,n,a,o,i){var s=new LRNGradProgram(t.shape,n,a,o,i);return this.compileAndRun(s,[t,r,e])},e.prototype.tile=function(e,t){var r=new TileProgram(e.shape,t);return this.compileAndRun(r,[e])},e.prototype.pad=function(e,t,r){var n=new PadProgram(e.shape,t,r);return this.compileAndRun(n,[e])},e.prototype.transpose=function(e,t){var r=new TransposeProgram(e.shape,t);return this.compileAndRun(r,[e])},e.prototype.gather=function(e,t,r){var n=new GatherProgram(e.shape,t.size,r);return this.compileAndRun(n,[e,t])},e.prototype.batchToSpaceND=function(e,t,r){assert(e.rank<=4,"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");var n=t.reduce(function(e,t){return e*t}),a=getReshaped(e.shape,t,n),o=getPermuted(a.length,t.length),i=getReshapedPermuted(e.shape,t,n),s=getSliceBeginCoords(r,t.length),u=getSliceSize(i,r,t.length);return e.reshape(a).transpose(o).reshape(i).slice(s,u)},e.prototype.spaceToBatchND=function(e,t,r){assert(e.rank<=4,"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");var n=t.reduce(function(e,t){return e*t}),a=[[0,0]];a.push.apply(a,r);for(var o=1+t.length;othis.NUM_BYTES_BEFORE_PAGING)for(var d=this.numBytesInGPU-this.NUM_BYTES_BEFORE_PAGING;d>0&&this.lruDataGPU.length>0;){var h=this.lruDataGPU.shift(),f=this.texData.get(h),m=f.shape,g=f.dtype;d-=this.computeBytes(m,g),this.read(h)}return c&&(s=this.endTimer(s),this.activeTimers.push(this.getQueryTime(s))),r},e.prototype.getAndSaveBinary=function(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]},e.prototype.getTextureManager=function(){return this.textureManager},e.prototype.dispose=function(){if(!this.disposed){for(var e in this.binaryCache)this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram);this.textureManager.dispose(),this.canvas.remove(),null!=this.fromPixelsCanvas&&this.fromPixelsCanvas.remove(),this.gpgpuCreatedLocally&&this.gpgpu.dispose(),this.disposed=!0}},e.prototype.throwIfNoData=function(e){if(!this.texData.has(e))throw new Error("WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends")},e.prototype.uploadToGPU=function(e){this.throwIfNoData(e);var t=this.texData.get(e),r=t.shape,n=t.values,a=t.texture,o=t.dtype,i=t.usage;if(null==a){var s,u=null!=this.activeTimers;u&&(s=performance.now());var l=getTextureShapeFromLogicalShape(this.gpgpu.gl,r);t.texShape=l;var p=this.acquireTexture(e,l,i);t.texture=p,null!=n&&(this.gpgpu.uploadMatrixToTexture(p,l[0],l[1],typedArrayToFloat32(n,o)),t.values=null,u&&(this.uploadWaitMs+=performance.now()-s))}else this.lruDataGPU.indexOf(e)>=0&&(this.lruDataGPU.splice(this.lruDataGPU.indexOf(e),1),this.lruDataGPU.push(e))},e.prototype.cacheOnCPU=function(e,t){var r=this.delayedStorage,n=this.texData.get(e),a=n.texture,o=n.texShape,i=n.dtype,s=n.usage;r&&null!=a&&(this.releaseTexture(e,a,o,s),n.texture=null,n.texShape=null),null!=t&&(n.values=float32ToTypedArray(t,i))},e.prototype.releaseTexture=function(e,t,r,n){var a=this.texData.get(e),o=a.shape,i=a.dtype,s=this.lruDataGPU.indexOf(e);s>=0&&this.lruDataGPU.splice(s,1),this.numBytesInGPU-=this.computeBytes(o,i),this.textureManager.releaseTexture(t,r,n)},e.prototype.acquireTexture=function(e,t,r){var n=this.texData.get(e),a=n.shape,o=n.dtype;return this.lruDataGPU.push(e),this.numBytesInGPU+=this.computeBytes(a,o),this.textureManager.acquireTexture(t,r)},e.prototype.computeBytes=function(e,t){return sizeFromShape(e)*bytesPerElement(t)},e}();function float32ToTypedArray(e,t){if("float32"===t)return e;if("int32"===t||"bool"===t){for(var r="int32"===t?new Int32Array(e.length):new Uint8Array(e.length),n=0;n=0?e:(assert(-1===e,"Bad value in size"),o.shape[t]-n[t])}),assertParamsValid(o,n,a);var i=o.shape;return ENV.engine.runKernel(function(e){return e.slice(o,n,a)},{$x:o},function(e){for(var t=[],r=0;r0&&(t=t.sum(n)),t.reshape(r.shape)},$b:function(){var t=e,r=getReductionAxes(n.shape,a);return r.length>0&&(t=t.sum(r)),t.reshape(n.shape)}}})}function addN_(e){assert(Array.isArray(e),function(){return"The param passed to tf.addN() must be a list of tensors"}),assert(e.length>=1,function(){return"Must pass at least one tensor to tf.addN(), but got "+e.length});var t=e.map(function(e,t){return convertToTensor(e,"tensors"+t,"addN")}),r=t[0];t.forEach(function(e){if(e.dtype!==r.dtype)throw new Error("All tensors passed to tf.addN() must have the same dtype")}),t.forEach(function(e){if(!arraysEqual(e.shape,r.shape))throw new Error("All tensors passed to tf.addN() must have the same shape")});var n=t;return ENV.engine.runKernel(function(e){return e.addN(t)},n,function(e){var r={};return t.forEach(function(t,n){r[n]=function(){return e.clone()}}),r})}function addStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in addStrict: "),e.add(t)}function sub_(e,t){var r=convertToTensor(e,"a","sub"),n=convertToTensor(t,"b","sub");assertTypesMatch(r,n);var a=assertAndGetBroadcastShape(r.shape,n.shape);return ENV.engine.runKernel(function(e){return e.subtract(r,n)},{$a:r,$b:n},function(e){return{$a:function(){var t=e,n=getReductionAxes(r.shape,a);return n.length>0&&(t=t.sum(n)),t.reshape(r.shape)},$b:function(){var t=e,r=getReductionAxes(n.shape,a);return r.length>0&&(t=t.sum(r)),t.neg().reshape(n.shape)}}})}function subStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in subStrict: "),e.sub(t)}function pow_(e,t){var r=convertToTensor(e,"base","pow"),n=convertToTensor(t,"exp","pow"),a=assertAndGetBroadcastShape(r.shape,n.shape);return e=r.cast(upcastType(r.dtype,n.dtype)),t=n.cast(upcastType(r.dtype,n.dtype)),ENV.engine.runKernel(function(e,t){return t(e.pow(r,n))},{$base:r,$exp:n},function(e,t){var o=t[0];return{$base:function(){var t=e.mul(n.toFloat().mul(o.div(r))),i=getReductionAxes(r.shape,a);return i.length>0&&(t=t.sum(i)),t.reshape(r.shape)},$exp:function(){var t=e.mul(o.mul(r.log()).toFloat()),i=getReductionAxes(n.shape,a);return i.length>0&&(t=t.sum(i)),t.reshape(n.shape)}}})}function powStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in powStrict: "),e.pow(t)}function mul_(e,t){var r=convertToTensor(e,"a","mul"),n=convertToTensor(t,"b","mul");assertTypesMatch(r,n);var a=assertAndGetBroadcastShape(r.shape,n.shape);return ENV.engine.runKernel(function(e){return e.multiply(r,n)},{$a:r,$b:n},function(e){return{$a:function(){var t=e.mul(n.toFloat()),o=getReductionAxes(r.shape,a);return o.length>0?t.sum(o).reshape(r.shape):t},$b:function(){var t=e.mul(r.toFloat()),o=getReductionAxes(n.shape,a);return o.length>0?t.sum(o).reshape(n.shape):t}}})}function mulStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in multiplyStrict: "),e.mul(t)}function div_(e,t){var r,n=convertToTensor(e,"a","div"),a=convertToTensor(t,"b","div");if(assertTypesMatch(n,a),"int32"===n.dtype&&"int32"===a.dtype)return floorDiv(n,a);r=function(e){return e.realDivide(n,a)};var o=assertAndGetBroadcastShape(n.shape,a.shape);return ENV.engine.runKernel(r,{$a:n,$b:a},function(e){return{$a:function(){var t=e.div(a.toFloat()),r=getReductionAxes(n.shape,o);return r.length>0?t.sum(r).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),r=getReductionAxes(a.shape,o);r.length>0&&(t=t.sum(r).reshape(a.shape));var i=a.square();return t.div(i.toFloat()).neg()}}})}function floorDiv_(e,t){var r=convertToTensor(e,"a","floorDiv"),n=convertToTensor(t,"b","floorDiv");assertTypesMatch(r,n);var a=assertAndGetBroadcastShape(r.shape,n.shape);return ENV.engine.runKernel(function(e){return e.floorDiv(r,n)},{$a:r,$b:n},function(e){return{$a:function(){var t=e.div(n.toFloat()),o=getReductionAxes(r.shape,a);return o.length>0?t.sum(o).reshape(r.shape):t},$b:function(){var t=e.mul(r.toFloat()),o=getReductionAxes(n.shape,a);o.length>0&&(t=t.sum(o).reshape(n.shape));var i=n.square();return t.div(i.toFloat()).neg()}}})}function divStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in divideStrict: "),e.div(t)}function mod_(e,t){var r=convertToTensor(e,"a","mod"),n=convertToTensor(t,"b","mod");assertTypesMatch(r,n);var a=assertAndGetBroadcastShape(r.shape,n.shape);return ENV.engine.runKernel(function(e){return e.mod(r,n)},{$a:r,$b:n},function(e){return{$a:function(){var t=getReductionAxes(r.shape,a);return t.length>0?e.sum(t).reshape(r.shape):e},$b:function(){var t=e.mul(r.div(n).floor().neg()),o=getReductionAxes(n.shape,a);return o.length>0?t.sum(o).reshape(n.shape):t}}})}function modStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in modStrict: "),e.mod(t)}function minimum_(e,t){var r=convertToTensor(e,"a","minimum"),n=convertToTensor(t,"b","minimum");return assertTypesMatch(r,n),"bool"===r.dtype&&(r=r.toInt()),"bool"===n.dtype&&(n=n.toInt()),assertAndGetBroadcastShape(r.shape,n.shape),ENV.engine.runKernel(function(e){return e.minimum(r,n)},{$a:r,$b:n},function(e){return{$a:function(){return e.mul(r.lessEqual(n).toFloat())},$b:function(){return e.mul(r.greater(n).toFloat())}}})}function minimumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in minimumStrict: "),e.minimum(t)}function maximum_(e,t){var r=convertToTensor(e,"a","maximum"),n=convertToTensor(t,"b","maximum");return assertTypesMatch(r,n),"bool"===r.dtype&&(r=r.toInt()),"bool"===n.dtype&&(n=n.toInt()),assertAndGetBroadcastShape(r.shape,n.shape),ENV.engine.runKernel(function(e){return e.maximum(r,n)},{$a:r,$b:n},function(e){return{$a:function(){return e.mul(r.greaterEqual(n).toFloat())},$b:function(){return e.mul(r.less(n).toFloat())}}})}function maximumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in minimumStrict: "),e.maximum(t)}function squaredDifference_(e,t){var r=convertToTensor(e,"a","squaredDifference"),n=convertToTensor(t,"b","squaredDifference");return assertTypesMatch(r,n),assertAndGetBroadcastShape(r.shape,n.shape),ENV.engine.runKernel(function(e){return e.squaredDifference(r,n)},{$a:r,$b:n},function(e){var t=scalar(2);return{$a:function(){return e.mul(r.sub(n).mul(t))},$b:function(){return e.mul(n.sub(r).mul(t))}}})}function squaredDifferenceStrict_(e,t){return assertShapesMatch(e.shape,t.shape,"Error in squaredDifferenceStrict: "),e.squaredDifference(t)}function atan2_(e,t){var r=convertToTensor(e,"a","atan2"),n=convertToTensor(t,"b","atan2");assertTypesMatch(r,n);var a=assertAndGetBroadcastShape(r.shape,n.shape);return ENV.engine.runKernel(function(e){return e.atan2(r,n)},{$a:r,$b:n},function(e){return{$a:function(){var t=add(r.square(),n.square()),o=e.mul(n.div(t)),i=getReductionAxes(r.shape,a);return i.length>0&&(o=o.sum(i)),o.reshape(r.shape)},$b:function(){var t=add(r.square(),n.square()),o=neg(e.mul(r.div(t))),i=getReductionAxes(n.shape,a);return i.length>0&&(o=o.sum(i)),o.reshape(n.shape)}}})}var add=op({add_:add_}),addN=op({addN_:addN_}),addStrict=op({addStrict_:addStrict_}),atan2=op({atan2_:atan2_}),div=op({div_:div_}),divStrict=op({divStrict_:divStrict_}),floorDiv=op({floorDiv_:floorDiv_}),maximum=op({maximum_:maximum_}),maximumStrict=op({maximumStrict_:maximumStrict_}),minimum=op({minimum_:minimum_}),minimumStrict=op({minimumStrict_:minimumStrict_}),mod=op({mod_:mod_}),modStrict=op({modStrict_:modStrict_}),mul=op({mul_:mul_}),mulStrict=op({mulStrict_:mulStrict_}),pow=op({pow_:pow_}),powStrict=op({powStrict_:powStrict_}),squaredDifference=op({squaredDifference_:squaredDifference_}),squaredDifferenceStrict=op({squaredDifferenceStrict_:squaredDifferenceStrict_}),sub=op({sub_:sub_}),subStrict=op({subStrict_:subStrict_});function logicalNot_(e){var t=convertToTensor(e,"x","logicalNot","bool");return assert("bool"===t.dtype,"Error Array must be of type bool."),ENV.engine.runKernel(function(e){return e.logicalNot(t)},{$x:t})}function logicalAnd_(e,t){var r=convertToTensor(e,"a","logicalAnd","bool"),n=convertToTensor(t,"b","logicalAnd","bool");return assert("bool"===r.dtype&&"bool"===n.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(r.shape,n.shape),ENV.engine.runKernel(function(e){return e.logicalAnd(r,n)},{$a:r,$b:n})}function logicalOr_(e,t){var r=convertToTensor(e,"a","logicalOr","bool"),n=convertToTensor(t,"b","logicalOr","bool");return assert("bool"===r.dtype&&"bool"===n.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(r.shape,n.shape),ENV.engine.runKernel(function(e){return e.logicalOr(r,n)},{$a:r,$b:n})}function logicalXor_(e,t){var r=convertToTensor(e,"a","logicalXor","bool"),n=convertToTensor(t,"b","logicalXor","bool");return assert("bool"===r.dtype&&"bool"===n.dtype,"Error Array must be of type bool."),assertAndGetBroadcastShape(r.shape,n.shape),logicalOr(e,t).logicalAnd(logicalAnd(e,t).logicalNot())}function where_(e,t,r){var n=convertToTensor(t,"a","where"),a=convertToTensor(r,"b","where"),o=convertToTensor(e,"condition","where","bool");return assert("bool"===o.dtype,"Error Condition must be of type bool."),assertShapesMatch(n.shape,a.shape,"Error in where: "),1===o.rank?assert(o.shape[0]===n.shape[0],"The first dimension of `a` must match the size of `condition`."):assertShapesMatch(o.shape,a.shape,"Error in where: "),ENV.engine.runKernel(function(e){return e.select(o,n,a)},{$condition:o,$a:n,$b:a},function(e){return{$condition:function(){return zerosLike(o)},$a:function(){return e.mul(o.cast(n.dtype))},$b:function(){return e.mul(o.logicalNot().cast(a.dtype))}}})}function whereAsync_(e){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(a){switch(a.label){case 0:return assert("bool"===(t=convertToTensor(e,"condition","where","bool")).dtype,"Condition must be of type bool."),[4,t.data()];case 1:return r=a.sent(),n=whereImpl(t.shape,r),e!==t&&t.dispose(),[2,n]}})})}var logicalAnd=op({logicalAnd_:logicalAnd_}),logicalNot=op({logicalNot_:logicalNot_}),logicalOr=op({logicalOr_:logicalOr_}),logicalXor=op({logicalXor_:logicalXor_}),where=op({where_:where_}),whereAsync=whereAsync_;function relu_(e){var t=convertToTensor(e,"x","relu");return"bool"===t.dtype?t.toInt():ENV.engine.runKernel(function(e){return e.relu(t)},{$x:t},function(e){var r=t.step();return{$x:function(){return e.mulStrict(r.toFloat())}}})}function elu_(e){var t=convertToTensor(e,"x","elu");return ENV.engine.runKernel(function(e,r){return r(e.elu(t))},{$x:t},function(e,t){var r=t[0];return{$x:function(){return ENV.engine.runKernel(function(t){return t.eluDer(e,r)},{dy:e,y:r})}}})}function selu_(e){var t=convertToTensor(e,"x","selu");return ENV.engine.runKernel(function(e){return e.selu(t)},{$x:t},function(e){return{$x:function(){var r=t.greater(scalar(0)),n=scalar(SELU_SCALEALPHA),a=scalar(SELU_SCALE),o=e.mul(a),i=e.mul(n).mul(t.toFloat().exp());return where(r,o,i)}}})}function leakyRelu_(e,t){void 0===t&&(t=.2);var r=convertToTensor(e,"x","leakyRelu");return maximum(scalar(t).mul(r),r)}function prelu_(e,t){var r=convertToTensor(e,"x","prelu"),n=convertToTensor(t,"alpha","prelu"),a=scalar(0);return maximum(a,r).add(n.mul(minimum(a,r)))}var elu=op({elu_:elu_}),leakyRelu=op({leakyRelu_:leakyRelu_}),prelu=op({prelu_:prelu_}),relu=op({relu_:relu_}),selu=op({selu_:selu_});function transpose_(e,t){var r=convertToTensor(e,"x","transpose");return null==t&&(t=r.shape.map(function(e,t){return t}).reverse()),assert(r.rank===t.length,"Error in transpose: rank of input "+r.rank+" must match length of perm "+t+"."),t.forEach(function(e){assert(e>=0&&ea)throw new Error("'k' passed to topk() must be <= the last dimension ("+a+") but got "+t);var o=ENV.engine.runKernel(function(e){return e.topk(n,t,r)},{$x:n});return{values:o[0],indices:o[1]}}var topk=op({topk_:topk_});function computeWeightedLoss_(e,t,r){void 0===r&&(r=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var n=convertToTensor(e,"losses","computeWeightedLoss"),a=null;null!=t&&(a=convertToTensor(t,"weights","computeWeightedLoss"));var o=null==a?n:n.mul(a);if(r===exports.Reduction.NONE)return o;if(r===exports.Reduction.SUM)return o.sum();if(r===exports.Reduction.MEAN){if(null==a)return o.mean();var i=sizeFromShape(n.shape)/sizeFromShape(a.shape),s=o.sum().div(a.sum());return i>1?s.div(scalar(i)):s}if(r===exports.Reduction.SUM_BY_NONZERO_WEIGHTS){if(null==a)return o.sum().div(scalar(n.size));var u=a.mul(ones$1(n.shape)).notEqual(scalar(0)).sum().toFloat();return o.sum().div(u)}throw Error("Unknown reduction: "+r)}function absoluteDifference_(e,t,r,n){void 0===n&&(n=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","absoluteDifference"),o=convertToTensor(t,"predictions","absoluteDifference"),i=null;null!=r&&(i=convertToTensor(r,"weights","absoluteDifference")),assertShapesMatch(a.shape,o.shape,"Error in absoluteDifference: ");var s=a.sub(o).abs();return computeWeightedLoss(s,i,n)}function meanSquaredError_(e,t,r,n){void 0===n&&(n=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","meanSquaredError"),o=convertToTensor(t,"predictions","meanSquaredError"),i=null;null!=r&&(i=convertToTensor(r,"weights","meanSquaredError")),assertShapesMatch(a.shape,o.shape,"Error in meanSquaredError: ");var s=a.squaredDifference(o);return computeWeightedLoss(s,i,n)}function cosineDistance_(e,t,r,n,a){void 0===a&&(a=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","cosineDistance"),i=convertToTensor(t,"predictions","cosineDistance"),s=null;null!=n&&(s=convertToTensor(n,"weights","cosineDistance")),assertShapesMatch(o.shape,i.shape,"Error in cosineDistance: ");var u=scalar(1).sub(o.mul(i).sum(r,!0));return computeWeightedLoss(u,s,a)}function hingeLoss_(e,t,r,n){void 0===n&&(n=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,"labels","hingeLoss"),o=convertToTensor(t,"predictions","hingeLoss"),i=null;null!=r&&(i=convertToTensor(r,"weights","hingeLoss")),assertShapesMatch(a.shape,o.shape,"Error in hingeLoss: ");var s=scalar(1);a=scalar(2).mul(a).sub(s);var u=s.sub(a.mul(o)).relu();return computeWeightedLoss(u,i,n)}function logLoss_(e,t,r,n,a){void 0===n&&(n=1e-7),void 0===a&&(a=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","logLoss"),i=convertToTensor(t,"predictions","logLoss"),s=null;null!=r&&(s=convertToTensor(r,"weights","logLoss")),assertShapesMatch(o.shape,i.shape,"Error in logLoss: ");var u=scalar(1),l=scalar(n),p=o.mul(i.add(l).log()).neg().sub(u.sub(o).mul(u.sub(i).add(l).log()));return computeWeightedLoss(p,s,a)}function sigmoidCrossEntropyWithLogits_(e,t){var r=convertToTensor(e,"labels","sigmoidCrossEntropyWithLogits"),n=convertToTensor(t,"logits","sigmoidCrossEntropyWithLogits");assertShapesMatch(r.shape,n.shape,"Error in sigmoidCrossEntropyWithLogits: ");var a=n.relu(),o=n.mul(r),i=n.abs().neg().exp().log1p();return a.sub(o).add(i)}function sigmoidCrossEntropy_(e,t,r,n,a){void 0===n&&(n=0),void 0===a&&(a=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"multiClassLabels","sigmoidCrossEntropy"),i=convertToTensor(t,"logits","sigmoidCrossEntropy"),s=null;if(null!=r&&(s=convertToTensor(r,"weights","sigmoidCrossEntropy")),assertShapesMatch(o.shape,i.shape,"Error in sigmoidCrossEntropy: "),n>0){var u=scalar(n),l=scalar(1),p=scalar(.5);o=o.mul(l.sub(u)).add(p.mul(u))}var c=sigmoidCrossEntropyWithLogits_(o,i);return computeWeightedLoss(c,s,a)}function huberLoss_(e,t,r,n,a){void 0===n&&(n=1),void 0===a&&(a=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"labels","huberLoss"),i=convertToTensor(t,"predictions","huberLoss"),s=null;null!=r&&(s=convertToTensor(r,"weights","huberLoss")),assertShapesMatch(o.shape,i.shape,"Error in huberLoss: ");var u=scalar(n),l=i.sub(o).abs(),p=minimum(l,u),c=l.sub(p),d=scalar(.5).mul(p.square()).add(u.mul(c));return computeWeightedLoss(d,s,a)}function softmaxCrossEntropyWithLogits_(e,t,r){if(void 0===r&&(r=-1),-1===r&&(r=t.rank-1),r!==t.rank-1)throw Error("Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank "+t.rank+" and dim was "+r);return customGrad(function(e,t){var n=t.logSumExp([r],!0),a=t.toFloat().sub(n);return{value:a.mul(e).neg().sum([r]),gradFunc:function(t){var n=expandShapeToKeepDim(t.shape,[r]);return[t.reshape(n).mul(e.toFloat().sub(a.exp())),t.reshape(n).mul(a.exp().sub(e.toFloat()))]}}})(e,t)}function softmaxCrossEntropy_(e,t,r,n,a){void 0===n&&(n=0),void 0===a&&(a=exports.Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,"onehotLabels","softmaxCrossEntropy"),i=convertToTensor(t,"logits","softmaxCrossEntropy"),s=null;if(null!=r&&(s=convertToTensor(r,"weights","softmaxCrossEntropy")),assertShapesMatch(o.shape,i.shape,"Error in softmaxCrossEntropy: "),n>0){var u=scalar(n),l=scalar(1),p=scalar(o.shape[1]);o=o.mul(l.sub(u)).add(u.div(p))}var c=softmaxCrossEntropyWithLogits_(o,i);return computeWeightedLoss(c,s,a)}!function(e){e[e.NONE=0]="NONE",e[e.MEAN=1]="MEAN",e[e.SUM=2]="SUM",e[e.SUM_BY_NONZERO_WEIGHTS=3]="SUM_BY_NONZERO_WEIGHTS"}(exports.Reduction||(exports.Reduction={}));var absoluteDifference=op({absoluteDifference_:absoluteDifference_}),computeWeightedLoss=op({computeWeightedLoss_:computeWeightedLoss_}),cosineDistance=op({cosineDistance_:cosineDistance_}),hingeLoss=op({hingeLoss_:hingeLoss_}),huberLoss=op({huberLoss_:huberLoss_}),logLoss=op({logLoss_:logLoss_}),meanSquaredError=op({meanSquaredError_:meanSquaredError_}),sigmoidCrossEntropy=op({sigmoidCrossEntropy_:sigmoidCrossEntropy_}),softmaxCrossEntropy=op({softmaxCrossEntropy_:softmaxCrossEntropy_}),loss_ops=Object.freeze({get Reduction(){return exports.Reduction},absoluteDifference:absoluteDifference,computeWeightedLoss:computeWeightedLoss,cosineDistance:cosineDistance,hingeLoss:hingeLoss,huberLoss:huberLoss,logLoss:logLoss,meanSquaredError:meanSquaredError,sigmoidCrossEntropy:sigmoidCrossEntropy,softmaxCrossEntropy:softmaxCrossEntropy});function gramSchmidt_(e){var t;if(Array.isArray(e)){t=!1,assert(null!=e&&e.length>0,"Gram-Schmidt process: input must not be null, undefined, or empty");for(var r=e[0].shape[0],n=1;n0)for(var r=0;r= 2, but got rank "+e.rank);if(2===e.rank)return qr2d(e,t);var r=e.shape.slice(0,e.shape.length-2).reduce(function(e,t){return e*t}),n=[],a=[];return unstack(e.reshape([r,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0).forEach(function(e){var r=qr2d(e,t),o=r[0],i=r[1];n.push(o),a.push(i)}),[stack(n,0).reshape(e.shape),stack(a,0).reshape(e.shape)]}function qr2d(e,t){return void 0===t&&(t=!1),ENV.engine.tidy(function(){if(2!==e.shape.length)throw new Error("qr2d() requires a 2D Tensor, but got a "+e.shape.length+"D Tensor.");for(var r=e.shape[0],n=e.shape[1],a=eye(r),o=e.clone(),i=tensor2d([[1]],[1,1]),s=i.clone(),u=r>=n?n:r,l=function(e){var t,u=o,l=s,p=a;t=ENV.engine.tidy(function(){var t=o.slice([e,e],[r-e,1]),u=t.norm(),l=o.slice([e,e],[1,1]),p=l.sign().neg(),c=l.sub(p.mul(u)),d=t.div(c);s=1===d.shape[0]?i.clone():i.concat(d.slice([1,0],[d.shape[0]-1,d.shape[1]]),0);var h=p.matMul(c).div(u).neg(),f=o.slice([e,0],[r-e,n]),m=h.mul(s);o=0===e?f.sub(m.matMul(s.transpose().matMul(f))):o.slice([0,0],[e,n]).concat(f.sub(m.matMul(s.transpose().matMul(f))),0);var g=a.slice([0,e],[r,a.shape[1]-e]);return a=0===e?g.sub(g.matMul(s).matMul(m.transpose())):a.slice([0,0],[r,e]).concat(g.sub(g.matMul(s).matMul(m.transpose())),1),[s,o,a]}),s=t[0],o=t[1],a=t[2],dispose([u,l,p])},p=0;pn&&(a=a.slice([0,0],[r,n]),o=o.slice([0,0],[n,n])),[a,o]})}var gramSchmidt=op({gramSchmidt_:gramSchmidt_}),qr=op({qr_:qr_}),linalg_ops=Object.freeze({gramSchmidt:gramSchmidt,qr:qr});function resizeBilinear_(e,t,r){void 0===r&&(r=!1);var n=convertToTensor(e,"images","resizeBilinear");assert(3===n.rank||4===n.rank,"Error in resizeBilinear: x must be rank 3 or 4, but got rank "+n.rank+"."),assert(2===t.length,"Error in resizeBilinear: new shape must 2D, but got shape "+t+".");var a=n,o=!1;3===n.rank&&(o=!0,a=n.as4D(1,n.shape[0],n.shape[1],n.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeBilinear(a,i,s,r)},{batchImages:a},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeBilinearBackprop(e,a,r)},{})}}});return o?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function resizeNearestNeighbor_(e,t,r){void 0===r&&(r=!1);var n=convertToTensor(e,"images","resizeNearestNeighbor");assert(3===n.rank||4===n.rank,"Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank "+n.rank+"."),assert(2===t.length,"Error in resizeNearestNeighbor: new shape must 2D, but got shape "+t+"."),assert("float32"===n.dtype||"int32"===n.dtype,"`images` must have `int32` or `float32` as dtype");var a=n,o=!1;3===n.rank&&(o=!0,a=n.as4D(1,n.shape[0],n.shape[1],n.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeNearestNeighbor(a,i,s,r)},{batchImages:a},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeNearestNeighborBackprop(e,a,r)},{})}}});return o?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function nonMaxSuppression_(e,t,r,n,a){void 0===n&&(n=.5),void 0===a&&(a=Number.NEGATIVE_INFINITY);var o=convertToTensor(e,"boxes","nonMaxSuppression"),i=convertToTensor(t,"scores","nonMaxSuppression"),s=nonMaxSuppSanityCheck(o,i,r,n,a);return r=s.maxOutputSize,n=s.iouThreshold,a=s.scoreThreshold,ENV.engine.runKernel(function(e){return e.nonMaxSuppression(o,i,r,n,a)},{$boxes:o})}function nonMaxSuppressionAsync_(e,t,r,n,a){return void 0===n&&(n=.5),void 0===a&&(a=Number.NEGATIVE_INFINITY),__awaiter(this,void 0,void 0,function(){var o,i,s,u,l,p;return __generator(this,function(c){switch(c.label){case 0:return o=convertToTensor(e,"boxes","nonMaxSuppressionAsync"),i=convertToTensor(t,"scores","nonMaxSuppressionAsync"),s=nonMaxSuppSanityCheck(o,i,r,n,a),r=s.maxOutputSize,n=s.iouThreshold,a=s.scoreThreshold,[4,o.data()];case 1:return u=c.sent(),[4,i.data()];case 2:return l=c.sent(),p=nonMaxSuppressionImpl(u,l,r,n,a),o!==e&&o.dispose(),i!==t&&i.dispose(),[2,p]}})})}function nonMaxSuppSanityCheck(e,t,r,n,a){null==n&&(n=.5),null==a&&(a=Number.NEGATIVE_INFINITY);var o=e.shape[0];return r=Math.min(r,o),assert(0<=n&&n<=1,"iouThreshold must be in [0, 1], but was '"+n+"'"),assert(2===e.rank,"boxes must be a 2D tensor, but was of rank '"+e.rank+"'"),assert(4===e.shape[1],"boxes must have 4 columns, but 2nd dimension was "+e.shape[1]),assert(1===t.rank,"scores must be a 1D tensor"),assert(t.shape[0]===o,"scores has incompatible shape with boxes. Expected "+o+", but was "+t.shape[0]),{maxOutputSize:r,iouThreshold:n,scoreThreshold:a}}var resizeBilinear=op({resizeBilinear_:resizeBilinear_}),resizeNearestNeighbor=op({resizeNearestNeighbor_:resizeNearestNeighbor_}),nonMaxSuppression=op({nonMaxSuppression_:nonMaxSuppression_}),nonMaxSuppressionAsync=nonMaxSuppressionAsync_,image_ops=Object.freeze({resizeBilinear:resizeBilinear,resizeNearestNeighbor:resizeNearestNeighbor,nonMaxSuppression:nonMaxSuppression,nonMaxSuppressionAsync:nonMaxSuppressionAsync}),ops=Object.freeze({image:image_ops,linalg:linalg_ops,losses:loss_ops,op:op,batchNormalization2d:batchNormalization2d,batchNormalization3d:batchNormalization3d,batchNormalization4d:batchNormalization4d,batchNormalization:batchNormalization,concat:concat,concat1d:concat1d,concat2d:concat2d,concat3d:concat3d,concat4d:concat4d,conv1d:conv1d,conv2d:conv2d,depthwiseConv2d:depthwiseConv2d,separableConv2d:separableConv2d,conv2dTranspose:conv2dTranspose,matMul:matMul,dot:dot,outerProduct:outerProduct,reverse:reverse,reverse1d:reverse1d,reverse2d:reverse2d,reverse3d:reverse3d,reverse4d:reverse4d,maxPool:maxPool,avgPool:avgPool,slice:slice,slice1d:slice1d,slice2d:slice2d,slice3d:slice3d,slice4d:slice4d,abs:abs,acos:acos,acosh:acosh,asin:asin,asinh:asinh,atan:atan,atanh:atanh,ceil:ceil,clipByValue:clipByValue,cos:cos,cosh:cosh,erf:erf,exp:exp,expm1:expm1,floor:floor,log:log$1,log1p:log1p,logSigmoid:logSigmoid,neg:neg,reciprocal:reciprocal,round:round,rsqrt:rsqrt,sigmoid:sigmoid,sign:sign,sin:sin,sinh:sinh,softplus:softplus,sqrt:sqrt,square:square,step:step,tan:tan,tanh:tanh$1,all:all,any:any,argMax:argMax,argMin:argMin,logSumExp:logSumExp,max:max,mean:mean,min:min,moments:moments,sum:sum,equal:equal,equalStrict:equalStrict,greater:greater,greaterEqual:greaterEqual,greaterEqualStrict:greaterEqualStrict,greaterStrict:greaterStrict,less:less,lessEqual:lessEqual,lessEqualStrict:lessEqualStrict,lessStrict:lessStrict,notEqual:notEqual,notEqualStrict:notEqualStrict,add:add,addN:addN,addStrict:addStrict,atan2:atan2,div:div,divStrict:divStrict,floorDiv:floorDiv,maximum:maximum,maximumStrict:maximumStrict,minimum:minimum,minimumStrict:minimumStrict,mod:mod,modStrict:modStrict,mul:mul,mulStrict:mulStrict,pow:pow,powStrict:powStrict,squaredDifference:squaredDifference,squaredDifferenceStrict:squaredDifferenceStrict,sub:sub,subStrict:subStrict,elu:elu,leakyRelu:leakyRelu,prelu:prelu,relu:relu,selu:selu,logicalAnd:logicalAnd,logicalNot:logicalNot,logicalOr:logicalOr,logicalXor:logicalXor,where:where,whereAsync:whereAsync,buffer:buffer,toPixels:toPixels,print:print,cast:cast,clone:clone,cumsum:cumsum,expandDims:expandDims,eye:eye,fromPixels:fromPixels,multinomial:multinomial,oneHot:oneHot,pad:pad,pad1d:pad1d,pad2d:pad2d,pad3d:pad3d,pad4d:pad4d,rand:rand,randomNormal:randomNormal,randomUniform:randomUniform,reshape:reshape,split:split,squeeze:squeeze,stack:stack,tile:tile,truncatedNormal:truncatedNormal,unstack:unstack,batchToSpaceND:batchToSpaceND,spaceToBatchND:spaceToBatchND,fill:fill,linspace:linspace,ones:ones$1,range:range,scalar:scalar,tensor:tensor,tensor1d:tensor1d,tensor2d:tensor2d,tensor3d:tensor3d,tensor4d:tensor4d,tensor5d:tensor5d,tensor6d:tensor6d,zeros:zeros,onesLike:onesLike,zerosLike:zerosLike,transpose:transpose,softmax:softmax,localResponseNormalization:localResponseNormalization,norm:norm,gather:gather,unsortedSegmentSum:unsortedSegmentSum,basicLSTMCell:basicLSTMCell,multiRNNCell:multiRNNCell,movingAverage:movingAverage,stridedSlice:stridedSlice,topk:topk}),MathBackendCPU=function(){function e(){this.data=new WeakMap,this.firstUse=!0,ENV.get("IS_BROWSER")&&(this.canvas=document.createElement("canvas"))}return e.prototype.register=function(e,t,r){if(this.firstUse&&(this.firstUse=!1,ENV.get("IS_NODE")&&warn("\n============================\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\n============================\n")),this.data.has(e))throw new Error("Data buffer is already registered");this.data.set(e,null)},e.prototype.write=function(e,t){if(null==t)throw new Error("MathBackendCPU.write(): values can not be null");this.throwIfNoData(e),this.data.set(e,t)},e.prototype.fromPixels=function(e,t){if(null==e)throw new Error("pixels passed to tf.fromPixels() can not be null");var r,n;if(ENV.get("IS_NODE")&&null==e.getContext)throw new Error("When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package");if(null!=e.getContext)r=e.getContext("2d").getImageData(0,0,e.width,e.height).data;else if(e instanceof ImageData)r=e.data;else{if(!(e instanceof HTMLImageElement||e instanceof HTMLVideoElement))throw new Error("pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was "+e.constructor.name);if(null==this.canvas)throw new Error("Can't read pixels from HTMLImageElement outside the browser.");this.canvas.width=e.width,this.canvas.height=e.height,this.canvas.getContext("2d").drawImage(e,0,0,e.width,e.height),r=this.canvas.getContext("2d").getImageData(0,0,e.width,e.height).data}if(4===t)n=new Int32Array(r);else{var a=e.width*e.height;n=new Int32Array(a*t);for(var o=0;od&&(d=m,h=f)}u[p]=h}return i},e.prototype.cumsum=function(e,t,r,n){if(t!==e.rank-1)throw new Error("backend.cumsum in CPU expects an inner-most axis="+(e.rank-1)+" but got axis="+t);for(var a=upcastType(e.dtype,"int32"),o=zeros(e.shape,a),i=o.dataSync(),s=e.dataSync(),u=e.shape[e.rank-1],l=n?function(e,t){return e+u-t-1}:function(e,t){return e+t},p=0;pt?1:0})},e.prototype.greaterEqual=function(e,t){return this.broadcastedBinaryOp(e,t,"bool",function(e,t){return e>=t?1:0})},e.prototype.logicalNot=function(e){for(var t=e.dataSync(),r=new Int32Array(t.length),n=0;n1||1===t.rank?1:t.shape[1],p=0;p=0&&t>=0?r:(r+t)%t})},e.prototype.max=function(e,t){assertAxesAreInnerMostDims("max",t,e.rank);for(var r=computeOutAndReduceShapes(e.shape,t),n=r[0],a=r[1],o=zeros(n,e.dtype),i=sizeFromShape(a),s=o.dataSync(),u=e.dataSync(),l=0;lc&&(c=h)}s[l]=c}return o},e.prototype.maximum=function(e,t){return this.broadcastedBinaryOp(e,t,e.dtype,function(e,t){return Math.max(e,t)})},e.prototype.all=function(e,t){assertAxesAreInnerMostDims("all",t,e.rank);for(var r=computeOutAndReduceShapes(e.shape,t),n=r[0],a=r[1],o=zeros(n,e.dtype),i=sizeFromShape(a),s=o.dataSync(),u=e.dataSync(),l=0;l0?r[n]=1:r[n]=0;return Tensor.make(e.shape,{values:r})},e.prototype.round=function(e){for(var t=e.dataSync(),r=new Float32Array(t.length),n=0;n.5?r[n]=Math.ceil(t[n]):r[n]=a%2==0?a:a+1}return Tensor.make(e.shape,{values:r})},e.prototype.exp=function(e){for(var t=e.dataSync(),r=new Float32Array(t.length),n=0;n=0?a:Math.exp(a)-1}return Tensor.make(e.shape,{values:t})},e.prototype.eluDer=function(e,t){for(var r=new Float32Array(t.size),n=t.dataSync(),a=e.dataSync(),o=0;o=1?a[o]:a[o]*(i+1)}return Tensor.make(t.shape,{values:r})},e.prototype.selu=function(e){for(var t=SELU_SCALEALPHA,r=SELU_SCALE,n=new Float32Array(e.size),a=e.dataSync(),o=0;o=0?r*i:t*(Math.exp(i)-1)}return Tensor.make(e.shape,{values:n})},e.prototype.clip=function(e,t,r){for(var n=new Float32Array(e.size),a=e.dataSync(),o=0;o-t,s=n[a]0?1:t}return Tensor.make(e.shape,{values:r})},e.prototype.conv2d=function(e,t,r){for(var n=r.filterHeight,a=r.filterWidth,o=r.dilationHeight,i=r.dilationWidth,s=r.padInfo.left,u=r.padInfo.top,l=buffer(r.outShape,e.dtype),p=0;p=r.inHeight))for(var b=0;b=r.inWidth))for(var w=0;w=r.inHeight))for(var w=0;w=r.inWidth||(v+=e.get(c,x,S,d)*t.get(b,w,d,y))}}p.set(v,c,h,m,d*l+y)}return p.toTensor()},e.prototype.depthwiseConv2DDerInput=function(e,t,r){for(var n=buffer(r.inShape,"float32"),a=n.values,o=n.strides,i=o[0],s=o[1],u=o[2],l=e.dataSync(),p=e.strides,c=p[0],d=p[1],h=p[2],f=t.dataSync(),m=t.strides,g=m[0],y=m[1],v=m[2],b=r.batchSize,x=r.filterHeight,w=r.filterWidth,S=r.inChannels,N=r.inHeight,T=r.inWidth,E=r.outChannels,I=r.outHeight,A=r.outWidth,_=r.strideHeight,P=r.strideWidth,C=x-1-r.padInfo.top,k=w-1-r.padInfo.left,O=E/S,R=0;Rx?x=E:"avg"===r&&(w+=E,S++)}if(isNaN(x))break}s.set("avg"===r?w/S:x,p,d,g,c)}return s.toTensor()},e.prototype.maxPool=function(e,t){return this.pool(e,t,"max")},e.prototype.maxPoolPositions=function(e,t){for(var r=buffer(t.outShape,"int32"),n=t.strideHeight,a=t.strideWidth,o=t.filterHeight,i=t.filterWidth,s=t.padInfo.top,u=t.padInfo.left,l=0;lb&&(b=E,x=S*i+T)}r.set(x,l,c,m,p)}return r.toTensor()},e.prototype.maxPoolBackprop=function(e,t,r,n){for(var a=this.maxPoolPositions(t,n),o=n.strideHeight,i=n.strideWidth,s=n.filterHeight,u=n.filterWidth,l=u-1-n.padInfo.left,p=s-1-n.padInfo.top,c=buffer(t.shape,"float32"),d=0;d=n.outHeight||Math.floor(x)!==x))for(var w=0;w=n.outWidth||Math.floor(S)!==S)){var N=s*u-1-a.get(d,x,S,h)===b*u+w?1:0;0!==N&&(v+=e.get(d,x,S,h)*N)}}}c.set(v,d,f,m,h)}return c.toTensor()},e.prototype.avgPoolBackprop=function(e,t,r){for(var n=r.strideHeight,a=r.strideWidth,o=r.filterHeight,i=r.filterWidth,s=i-1-r.padInfo.left,u=o-1-r.padInfo.top,l=buffer(t.shape,"float32"),p=1/(o*i),c=0;c=r.outHeight||Math.floor(b)!==b))for(var x=0;x=r.outWidth||Math.floor(w)!==w||(y+=e.get(c,b,w,d))}}l.set(y*p,c,h,f,d)}return l.toTensor()},e.prototype.cast=function(e,t){return castTensor(e,t,this)},e.prototype.reshape=function(e,t){return reshapeTensor(e,t)},e.prototype.avgPool=function(e,t){return this.pool(e,t,"avg").toFloat()},e.prototype.resizeBilinear=function(e,t,r,n){for(var a=e.shape,o=a[0],i=a[1],s=a[2],u=a[3],l=buffer([o,t,r,u],e.dtype),p=[n&&t>1?i-1:i,n&&r>1?s-1:s],c=[n&&t>1?t-1:t,n&&r>1?r-1:r],d=0;d1?o-1:o,r&&p>1?i-1:i],h=[r&&l>1?l-1:l,r&&p>1?p-1:p],f=d[0]/h[0],m=d[1]/h[1],g=0;g1?i-1:i,n&&r>1?s-1:s],c=[n&&t>1?t-1:t,n&&r>1?r-1:r],d=0;d1?o-1:o,r&&p>1?i-1:i],h=[r&&l>1?l-1:l,r&&p>1?p-1:p],f=1/(d[0]/h[0]),m=1/(d[1]/h[1]),g=2*Math.ceil(f)+2,y=2*Math.ceil(m)+2,v=0;v=l))for(var P=0;P=p)){var k=d[0]*(_/h[0]),O=d[1]*(C/h[1]),R=Math.min(o-1,r?Math.round(k):Math.floor(k)),D=Math.min(i-1,r?Math.round(O):Math.floor(O));b===R&&x===D&&(I+=e.get(v,_,C,E))}}}c.set(I,v,b,x,E)}return c.toTensor()},e.prototype.batchNormalization=function(e,t,r,n,a,o){for(var i=e.dataSync(),s=t.dataSync(),u=r.dataSync(),l=a?a.dataSync():new Float32Array([1]),p=o?o.dataSync():new Float32Array([0]),c=new Float32Array(i.length),d=0;d=0&&e.get(o)0,"scheme must not be an empty string.");var n=e.getInstance();assert(null==n.managers[t],"A model store manager is already registered for scheme '"+t+"'."),n.managers[t]=r},e.getManager=function(e){var t=this.getInstance().managers[e];if(null==t)throw new Error("Cannot find model manager for scheme '"+e+"'");return t},e.getSchemes=function(){return Object.keys(this.getInstance().managers)},e}();function parseURL(e){if(-1===e.indexOf(URL_SCHEME_SUFFIX))throw new Error("The url string provided does not contain a scheme. Supported schemes are: "+ModelStoreManagerRegistry.getSchemes().join(","));return{scheme:e.split(URL_SCHEME_SUFFIX)[0],path:e.split(URL_SCHEME_SUFFIX)[1]}}function cloneModelInternal(e,t,r){return void 0===r&&(r=!1),__awaiter(this,void 0,void 0,function(){var n,a,o,i,s,u,l,p,c;return __generator(this,function(d){switch(d.label){case 0:return assert(e!==t,"Old path and new path are the same: '"+e+"'"),assert((n=IORouterRegistry.getLoadHandlers(e)).length>0,"Copying failed because no load handler is found for source URL "+e+"."),assert(n.length<2,"Copying failed because more than one ("+n.length+") load handlers for source URL "+e+"."),a=n[0],assert((o=IORouterRegistry.getSaveHandlers(t)).length>0,"Copying failed because no save handler is found for destination URL "+t+"."),assert(o.length<2,"Copying failed because more than one ("+n.length+") save handlers for destination URL "+t+"."),i=o[0],s=parseURL(e).scheme,u=parseURL(e).path,l=s===parseURL(e).scheme,[4,a.load()];case 1:return p=d.sent(),r&&l?[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)]:[3,3];case 2:d.sent(),d.label=3;case 3:return[4,i.save(p)];case 4:return c=d.sent(),!r||l?[3,6]:[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)];case 5:d.sent(),d.label=6;case 6:return[2,c.modelArtifactsInfo]}})})}function listModels(){return __awaiter(this,void 0,void 0,function(){var e,t,r,n,a,o,i;return __generator(this,function(s){switch(s.label){case 0:e=ModelStoreManagerRegistry.getSchemes(),t={},r=0,n=e,s.label=1;case 1:return r0,"URL path for browserHTTPRequest must not be null, undefined or empty."),this.path=e,null!=t&&null!=t.body)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=t||{}}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){var t,r,n,a;return __generator(this,function(o){switch(o.label){case 0:if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");return(t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit)).body=new FormData,r=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],n={modelTopology:e.modelTopology,weightsManifest:r},t.body.append("model.json",new Blob([JSON.stringify(n)],{type:"application/json"}),"model.json"),null!=e.weightData&&t.body.append("model.weights.bin",new Blob([e.weightData],{type:"application/octet-stream"}),"model.weights.bin"),[4,fetch(this.path,t)];case 1:if(200===(a=o.sent()).status)return[2,{modelArtifactsInfo:getModelArtifactsInfoForJSON(e),responses:[a]}];throw new Error("BrowserHTTPRequest.save() failed due to HTTP response status "+a.status+".")}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,r,n,a,o,i,s,u,l,p,c;return __generator(this,function(d){switch(d.label){case 0:return[4,fetch(this.path,this.requestInit)];case 1:return[4,d.sent().json()];case 2:if(e=d.sent(),t=e.modelTopology,r=e.weightsManifest,null==t&&null==r)throw new Error("The JSON from HTTP path "+this.path+" contains neither model topology or manifest for weights.");if(null==r)return[3,4];for(o=e.weightsManifest,n=[],i=0,s=o;i0&&(e=__assign({weightSpecs:this.weightSpecs},e)),null!=this.weightData&&this.weightData.byteLength>0&&(e=__assign({weightData:this.weightData},e)),[2,e]})})},e}(),PassthroughSaver=function(){function e(e){this.saveHandler=e}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(t){return[2,this.saveHandler(e)]})})},e}();function fromMemory(e,t,r){return new PassthroughLoader(e,t,r)}function withSaveHandler(e){return new PassthroughSaver(e)}var registerSaveRouter=IORouterRegistry.registerSaveRouter,registerLoadRouter=IORouterRegistry.registerLoadRouter,getSaveHandlers=IORouterRegistry.getSaveHandlers,getLoadHandlers=IORouterRegistry.getLoadHandlers,io=Object.freeze({browserFiles:browserFiles,browserHTTPRequest:browserHTTPRequest,concatenateArrayBuffers:concatenateArrayBuffers,decodeWeights:decodeWeights,encodeWeights:encodeWeights,fromMemory:fromMemory,getLoadHandlers:getLoadHandlers,getModelArtifactsInfoForJSON:getModelArtifactsInfoForJSON,getSaveHandlers:getSaveHandlers,loadWeights:loadWeights,registerLoadRouter:registerLoadRouter,registerSaveRouter:registerSaveRouter,withSaveHandler:withSaveHandler,copyModel:copyModel,listModels:listModels,moveModel:moveModel,removeModel:removeModel}),Serializable=function(){function e(){}return e.prototype.getClassName=function(){return this.constructor.className},e.fromConfig=function(e,t){return new e(t)},e}(),SerializationMap=function(){function e(){this.classNameMap={}}return e.getMap=function(){return null==e.instance&&(e.instance=new e),e.instance},e.register=function(t){e.getMap().classNameMap[t.className]=[t,t.fromConfig]},e}(),serialization=Object.freeze({Serializable:Serializable,SerializationMap:SerializationMap}),WEBGL_ENVS={HAS_WEBGL:!0},NODE_ENVS={IS_NODE:!0},CHROME_ENVS={IS_CHROME:!0},BROWSER_ENVS={IS_BROWSER:!0},CPU_ENVS={HAS_WEBGL:!1},ALL_ENVS={};function expectArraysClose(e,t,r){if(null==r&&(r=ENV.get("TEST_EPSILON")),e instanceof Tensor||t instanceof Tensor){if(e instanceof Tensor&&t instanceof Tensor){if(e.dtype!==t.dtype)throw new Error("Arrays are of different type actual: "+e.dtype+" vs expected: "+t.dtype+".");if(!arraysEqual(e.shape,t.shape))throw new Error("Arrays are of different shape actual: "+e.shape+" vs expected: "+t.shape+".")}}else{var n=e.constructor.name,a=t.constructor.name;if(n!==a)throw new Error("Arrays are of different type actual: "+n+" vs expected: "+a)}var o,i;if(o=e instanceof Tensor?e.dataSync():e,i=t instanceof Tensor?t.dataSync():t,o.length!==i.length)throw new Error("Arrays have different lengths actual: "+o.length+" vs expected: "+i.length+".\nActual: "+o+".\nExpected: "+i+".");for(var s=0;sr)}function expectValuesInRange(e,t,r){var n;n=e instanceof Tensor?e.dataSync():e;for(var a=0;ar)throw new Error("Value out of range:"+n[a]+" low: "+t+", high: "+r)}function expectArrayBuffersEqual(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}var test_util=Object.freeze({WEBGL_ENVS:WEBGL_ENVS,NODE_ENVS:NODE_ENVS,CHROME_ENVS:CHROME_ENVS,BROWSER_ENVS:BROWSER_ENVS,CPU_ENVS:CPU_ENVS,ALL_ENVS:ALL_ENVS,expectArraysClose:expectArraysClose,expectPromiseToFail:expectPromiseToFail,expectArraysEqual:expectArraysEqual,expectNumbersClose:expectNumbersClose,expectValuesInRange:expectValuesInRange,expectArrayBuffersEqual:expectArrayBuffersEqual}),version="0.12.8",webgl=Object.freeze({gpgpu_util:gpgpu_util,webgl_util:webgl_util,MathBackendWebGL:MathBackendWebGL,GPGPUContext:GPGPUContext}),Optimizer=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.minimize=function(e,t,r){void 0===t&&(t=!1);var n=this.computeGradients(e,r),a=n.value,o=n.grads;return this.applyGradients(o),Object.keys(o).forEach(function(e){return o[e].dispose()}),t?a:(a.dispose(),null)},t.prototype.computeGradients=function(e,t){return variableGrads(e,t)},t}(Serializable),DEFAULT_FLOAT32_EPSILON=1e-8,DEFAULT_FLOAT16_EPSILON=1e-4;function getOptimizerDefaultEpsilonValue(){return ENV.get("WEBGL_RENDER_FLOAT32_ENABLED")?DEFAULT_FLOAT32_EPSILON:DEFAULT_FLOAT16_EPSILON}var AdadeltaOptimizer=function(e){function t(t,r,n){void 0===n&&(n=null);var a=e.call(this)||this;return a.learningRate=t,a.rho=r,a.epsilon=n,a.accumulatedGrads={},a.accumulatedUpdates={},a.c=keep(scalar(-t)),a.rhoScalar=keep(scalar(r)),a.oneMinusRho=keep(scalar(1-r)),null===n&&(n=getOptimizerDefaultEpsilonValue()),a.epsilonScalar=keep(scalar(n)),a}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,r=function(r){var a=ENV.engine.registeredVariables[r];null==n.accumulatedGrads[r]&&tidy(function(){t.accumulatedGrads[r]=zerosLike(a).variable(!1)}),null==n.accumulatedUpdates[r]&&tidy(function(){t.accumulatedUpdates[r]=zerosLike(a).variable(!1)});var o=e[r],i=n.accumulatedGrads[r],s=n.accumulatedUpdates[r];tidy(function(){var e=t.rhoScalar.mul(i).add(t.oneMinusRho.mul(o.square())),n=s.add(t.epsilonScalar).sqrt().div(i.add(t.epsilonScalar).sqrt()).mul(o),u=t.rhoScalar.mul(s).add(t.oneMinusRho.mul(n.square()));t.accumulatedGrads[r].assign(e),t.accumulatedUpdates[r].assign(u);var l=t.c.mul(n).add(a);a.assign(l)})},n=this;for(var a in e)r(a)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.rhoScalar.dispose(),this.oneMinusRho.dispose(),null!=this.accumulatedUpdates&&(Object.keys(this.accumulatedUpdates).forEach(function(t){return e.accumulatedUpdates[t].dispose()}),Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()}))},t.prototype.getConfig=function(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.rho,t.epsilon)},t.className="AdadeltaOptimizer",t}(Optimizer);SerializationMap.register(AdadeltaOptimizer);var AdagradOptimizer=function(e){function t(t,r){void 0===r&&(r=.1);var n=e.call(this)||this;n.learningRate=t,n.initialAccumulatorValue=r,n.accumulatedGrads={},n.c=keep(scalar(-t));var a=getOptimizerDefaultEpsilonValue();return n.epsilon=keep(scalar(a)),n}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,r=function(r){var a=ENV.engine.registeredVariables[r];null==n.accumulatedGrads[r]&&tidy(function(){t.accumulatedGrads[r]=fill(a.shape,t.initialAccumulatorValue).variable(!1)});var o=e[r],i=n.accumulatedGrads[r];tidy(function(){var e=i.add(o.square());t.accumulatedGrads[r].assign(e);var n=t.c.mul(o.div(e.add(t.epsilon).sqrt())).add(a);a.assign(n)})},n=this;for(var a in e)r(a)},t.prototype.dispose=function(){var e=this;this.epsilon.dispose(),this.c.dispose(),null!=this.accumulatedGrads&&Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}},t.fromConfig=function(e,t){return new e(t.learningRate,t.initialAccumulatorValue)},t.className="AdagradOptimizer",t}(Optimizer);SerializationMap.register(AdagradOptimizer);var AdamOptimizer=function(e){function t(t,r,n,a){void 0===a&&(a=null);var o=e.call(this)||this;return o.learningRate=t,o.beta1=r,o.beta2=n,o.epsilon=a,o.accumulatedFirstMoment={},o.accumulatedSecondMoment={},o.c=keep(scalar(-t)),o.beta1Scalar=keep(scalar(r)),o.beta2Scalar=keep(scalar(n)),tidy(function(){o.accBeta1=scalar(r).variable(),o.accBeta2=scalar(n).variable()}),o.oneMinusBeta1=keep(scalar(1-r)),o.oneMinusBeta2=keep(scalar(1-n)),o.one=keep(scalar(1)),null===a&&(a=getOptimizerDefaultEpsilonValue()),o.epsScalar=keep(scalar(a)),o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var r=t.one.sub(t.accBeta1),n=t.one.sub(t.accBeta2);for(var a in e){var o=ENV.engine.registeredVariables[a];if(null==t.accumulatedFirstMoment[a]){var i=!1;t.accumulatedFirstMoment[a]=zerosLike(o).variable(i)}null==t.accumulatedSecondMoment[a]&&(i=!1,t.accumulatedSecondMoment[a]=zerosLike(o).variable(i));var s=e[a],u=t.accumulatedFirstMoment[a],l=t.accumulatedSecondMoment[a],p=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),c=t.beta2Scalar.mul(l).add(t.oneMinusBeta2.mul(s.square())),d=p.div(r),h=c.div(n);t.accumulatedFirstMoment[a].assign(p),t.accumulatedSecondMoment[a].assign(c);var f=t.c.mul(d.div(t.epsScalar.add(h.sqrt()))).add(o);o.assign(f)}t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)),t.accBeta2.assign(t.accBeta2.mul(t.beta2Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.accBeta1.dispose(),this.accBeta2.dispose(),this.oneMinusBeta1.dispose(),this.oneMinusBeta2.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedSecondMoment&&Object.keys(this.accumulatedSecondMoment).forEach(function(t){return e.accumulatedSecondMoment[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)},t.className="AdamOptimizer",t}(Optimizer);SerializationMap.register(AdamOptimizer);var AdamaxOptimizer=function(e){function t(t,r,n,a,o){void 0===a&&(a=null),void 0===o&&(o=0);var i=e.call(this)||this;return i.learningRate=t,i.beta1=r,i.beta2=n,i.epsilon=a,i.decay=o,i.accumulatedFirstMoment={},i.accumulatedWeightedInfNorm={},i.c=keep(scalar(-t)),i.beta1Scalar=keep(scalar(r)),i.beta2Scalar=keep(scalar(n)),i.decayScalar=keep(scalar(o)),tidy(function(){i.iteration=scalar(0).variable(),i.accBeta1=scalar(r).variable()}),i.oneMinusBeta1=keep(scalar(1-r)),i.one=keep(scalar(1)),null===a&&(a=getOptimizerDefaultEpsilonValue()),i.epsScalar=keep(scalar(a)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var r=t.one.sub(t.accBeta1),n=t.c.div(t.one.add(t.decayScalar.mul(t.iteration)));for(var a in e){var o=ENV.engine.registeredVariables[a];if(null==t.accumulatedFirstMoment[a]){var i=!1;t.accumulatedFirstMoment[a]=zerosLike(o).variable(i)}null==t.accumulatedWeightedInfNorm[a]&&(i=!1,t.accumulatedWeightedInfNorm[a]=zerosLike(o).variable(i));var s=e[a],u=t.accumulatedFirstMoment[a],l=t.accumulatedWeightedInfNorm[a],p=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),c=t.beta2Scalar.mul(l),d=s.abs(),h=c.maximum(d);t.accumulatedFirstMoment[a].assign(p),t.accumulatedWeightedInfNorm[a].assign(h);var f=n.div(r).mul(p.div(t.epsScalar.add(h))).add(o);o.assign(f)}t.iteration.assign(t.iteration.add(t.one)),t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.accBeta1.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.oneMinusBeta1.dispose(),this.decayScalar.dispose(),this.iteration.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedWeightedInfNorm&&Object.keys(this.accumulatedWeightedInfNorm).forEach(function(t){return e.accumulatedWeightedInfNorm[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)},t.className="AdamaxOptimizer",t}(Optimizer);SerializationMap.register(AdamaxOptimizer);var SGDOptimizer=function(e){function t(t){var r=e.call(this)||this;return r.learningRate=t,r.setLearningRate(t),r}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;Object.keys(e).forEach(function(r){var n=e[r],a=ENV.engine.registeredVariables[r];tidy(function(){var e=t.c.mul(n).add(a);a.assign(e)})})},t.prototype.setLearningRate=function(e){this.learningRate=e,null!=this.c&&this.c.dispose(),this.c=keep(scalar(-e))},t.prototype.dispose=function(){this.c.dispose()},t.prototype.getConfig=function(){return{learningRate:this.learningRate}},t.fromConfig=function(e,t){return new e(t.learningRate)},t.className="SGDOptimizer",t}(Optimizer);SerializationMap.register(SGDOptimizer);var MomentumOptimizer=function(e){function t(t,r,n){void 0===n&&(n=!1);var a=e.call(this,t)||this;return a.learningRate=t,a.momentum=r,a.useNesterov=n,a.m=scalar(a.momentum),a.accumulations={},a}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,r=function(r){var a=ENV.engine.registeredVariables[r];null==n.accumulations[r]&&tidy(function(){t.accumulations[r]=zerosLike(a).variable(!1)});var o=n.accumulations[r],i=e[r];tidy(function(){var e,n=t.m.mul(o).add(i);e=t.useNesterov?t.c.mul(i.add(n.mul(t.m))).add(a):t.c.mul(n).add(a),t.accumulations[r].assign(n),a.assign(e)})},n=this;for(var a in e)r(a)},t.prototype.dispose=function(){if(e.prototype.dispose.call(this),this.m.dispose(),null!=this.accumulations)for(var t in this.accumulations)this.accumulations[t].dispose()},t.prototype.setMomentum=function(e){this.momentum=e},t.prototype.getConfig=function(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}},t.fromConfig=function(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)},t.className="MomentumOptimizer",t}(SGDOptimizer);SerializationMap.register(MomentumOptimizer);var RMSPropOptimizer=function(e){function t(t,r,n,a,o){void 0===r&&(r=.9),void 0===n&&(n=0),void 0===a&&(a=null),void 0===o&&(o=!1);var i=e.call(this)||this;return i.learningRate=t,i.decay=r,i.momentum=n,i.epsilon=a,i.accumulatedMeanSquares={},i.accumulatedMeanGrads={},i.accumulatedMoments={},i.c=keep(scalar(t)),i.decayScalar=keep(scalar(r)),i.momentumScalar=keep(scalar(n)),i.oneMinusDecay=keep(scalar(1-r)),i.centered=o,null===a&&(a=getOptimizerDefaultEpsilonValue()),i.epsilonScalar=keep(scalar(a)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,r=function(r){var a=ENV.engine.registeredVariables[r];null==n.accumulatedMeanSquares[r]&&tidy(function(){t.accumulatedMeanSquares[r]=zerosLike(a).variable(!1)}),null==n.accumulatedMeanGrads[r]&&n.centered&&tidy(function(){t.accumulatedMeanGrads[r]=zerosLike(a).variable(!1)}),null==n.accumulatedMoments[r]&&tidy(function(){t.accumulatedMoments[r]=zerosLike(a).variable(!1)});var o=n.accumulatedMeanSquares[r],i=n.accumulatedMeanGrads[r],s=n.accumulatedMoments[r],u=e[r];tidy(function(){var e=t.decayScalar.mul(o).add(t.oneMinusDecay.mul(u.square()));if(t.centered){var n=t.decayScalar.mul(i).add(t.oneMinusDecay.mul(u)),l=t.momentumScalar.mul(s).add(t.c.mul(u).div(e.sub(n.square().add(t.epsilonScalar)).sqrt()));t.accumulatedMeanSquares[r].assign(e),t.accumulatedMeanGrads[r].assign(n),t.accumulatedMoments[r].assign(l);var p=a.sub(l);a.assign(p)}else{var c=t.decayScalar.mul(o).add(t.oneMinusDecay.mul(u.square()));l=t.momentumScalar.mul(s).add(t.c.mul(u).div(c.add(t.epsilonScalar).sqrt())),t.accumulatedMeanSquares[r].assign(c),t.accumulatedMoments[r].assign(l),p=a.sub(l),a.assign(p)}})},n=this;for(var a in e)r(a)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.decayScalar.dispose(),this.momentumScalar.dispose(),this.oneMinusDecay.dispose(),null!=this.accumulatedMeanSquares&&Object.keys(this.accumulatedMeanSquares).forEach(function(t){return e.accumulatedMeanSquares[t].dispose()}),null!=this.accumulatedMeanGrads&&this.centered&&Object.keys(this.accumulatedMeanGrads).forEach(function(t){return e.accumulatedMeanGrads[t].dispose()}),null!=this.accumulatedMoments&&Object.keys(this.accumulatedMoments).forEach(function(t){return e.accumulatedMoments[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}},t.fromConfig=function(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)},t.className="RMSPropOptimizer",t}(Optimizer);SerializationMap.register(RMSPropOptimizer);var OptimizerConstructors=function(){function e(){}return e.sgd=function(e){return new SGDOptimizer(e)},e.momentum=function(e,t,r){return void 0===r&&(r=!1),new MomentumOptimizer(e,t,r)},e.rmsprop=function(e,t,r,n,a){return void 0===t&&(t=.9),void 0===r&&(r=0),void 0===n&&(n=null),void 0===a&&(a=!1),new RMSPropOptimizer(e,t,r,n,a)},e.adam=function(e,t,r,n){return void 0===e&&(e=.001),void 0===t&&(t=.9),void 0===r&&(r=.999),void 0===n&&(n=null),new AdamOptimizer(e,t,r,n)},e.adadelta=function(e,t,r){return void 0===e&&(e=.001),void 0===t&&(t=.95),void 0===r&&(r=null),new AdadeltaOptimizer(e,t,r)},e.adamax=function(e,t,r,n,a){return void 0===e&&(e=.002),void 0===t&&(t=.9),void 0===r&&(r=.999),void 0===n&&(n=null),void 0===a&&(a=0),new AdamaxOptimizer(e,t,r,n,a)},e.adagrad=function(e,t){return void 0===t&&(t=.1),new AdagradOptimizer(e,t)},e}(),train={sgd:OptimizerConstructors.sgd,momentum:OptimizerConstructors.momentum,adadelta:OptimizerConstructors.adadelta,adagrad:OptimizerConstructors.adagrad,rmsprop:OptimizerConstructors.rmsprop,adamax:OptimizerConstructors.adamax,adam:OptimizerConstructors.adam},setBackend=Environment.setBackend,getBackend=Environment.getBackend,disposeVariables=Environment.disposeVariables,memory=Environment.memory;setOpHandler(ops);var extendStatics$1=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])};function __extends$1(e,t){function r(){this.constructor=e}extendStatics$1(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}var __assign$1=Object.assign||function(e){for(var t,r=1,n=arguments.length;r0&&a[a.length-1])&&(6===o[0]||2===o[0])){i=0;continue}if(3===o[0]&&(!a||o[1]>a[0]&&o[1]t?1:0}function reverseNumberCompare(e,t){return-1*numberCompare(e,t)}function stringToDType(e){switch(e){case"float32":return"float32";default:throw new ValueError("Invalid dtype: "+e)}}function unique(e){if(null==e)return e;for(var t=[],r=0,n=e;r=0),assert$1(n>=r),Array.isArray(e)&&e.length>=r&&e.length<=n&&e.every(function(e){return typeof e===t})}function calcL2Norms(e,t){return tidy(function(){return sqrt(sum(mulStrict(e,e),t,!0))})}var Constraint=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends$1(t,e),t.prototype.getConfig=function(){return{}},t}(serialization.Serializable),MaxNorm=function(e){function t(t){var r=e.call(this)||this;return r.defaultMaxValue=2,r.defaultAxis=0,r.maxValue=null!=t.maxValue?t.maxValue:r.defaultMaxValue,r.axis=null!=t.axis?t.axis:r.defaultAxis,r}return __extends$1(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var r=calcL2Norms(e,t.axis),n=clipByValue(r,0,t.maxValue);return mul(e,div(n,add(getScalar(epsilon()),r)))})},t.prototype.getConfig=function(){return{maxValue:this.maxValue,axis:this.axis}},t.className="MaxNorm",t}(Constraint);serialization.SerializationMap.register(MaxNorm);var UnitNorm=function(e){function t(t){var r=e.call(this)||this;return r.defaultAxis=0,r.axis=null!=t.axis?t.axis:r.defaultAxis,r}return __extends$1(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){return div(e,add(getScalar(epsilon()),calcL2Norms(e,t.axis)))})},t.prototype.getConfig=function(){return{axis:this.axis}},t.className="UnitNorm",t}(Constraint);serialization.SerializationMap.register(UnitNorm);var NonNeg=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends$1(t,e),t.prototype.apply=function(e){return relu(e)},t.className="NonNeg",t}(Constraint);serialization.SerializationMap.register(NonNeg);var MinMaxNorm=function(e){function t(t){var r=e.call(this)||this;return r.defaultMinValue=0,r.defaultMaxValue=1,r.defaultRate=1,r.defaultAxis=0,r.minValue=null!=t.minValue?t.minValue:r.defaultMinValue,r.maxValue=null!=t.maxValue?t.maxValue:r.defaultMaxValue,r.rate=null!=t.rate?t.rate:r.defaultRate,r.axis=null!=t.axis?t.axis:r.defaultAxis,r}return __extends$1(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var r=calcL2Norms(e,t.axis),n=add(mul(getScalar(t.rate),clipByValue(r,t.minValue,t.maxValue)),mul(getScalar(1-t.rate),r));return mul(e,div(n,add(getScalar(epsilon()),r)))})},t.prototype.getConfig=function(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}},t.className="MinMaxNorm",t}(Constraint);serialization.SerializationMap.register(MinMaxNorm);var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function serializeConstraint(e){return serializeKerasObject(e)}function deserializeConstraint(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,"constraint")}function getConstraint(e){return null==e?null:"string"==typeof e?deserializeConstraint({className:e in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP?CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e,config:{}}):e instanceof Constraint?e:deserializeConstraint(e)}function maxNorm(e){return new MaxNorm(e)}function unitNorm(e){return new UnitNorm(e)}function nonNeg(){return new NonNeg}function minMaxNorm(e){return new MinMaxNorm(e)}var exports_constraints=Object.freeze({maxNorm:maxNorm,unitNorm:unitNorm,nonNeg:nonNeg,minMaxNorm:minMaxNorm}),nameMap=new Map,VALID_DATA_FORMAT_VALUES=["channelsFirst","channelsLast"];function checkDataFormat(e){checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES,"DataFormat",e)}var VALID_PADDING_MODE_VALUES=["valid","same","causal"];function checkPaddingMode(e){checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES,"PaddingMode",e)}var VALID_POOL_MODE_VALUES=["max","avg"];function checkPoolMode(e){checkStringTypeUnionValue(VALID_POOL_MODE_VALUES,"PoolMode",e)}var _nameScopeStack=[],_nameScopeDivider="/";function nameScope(e,t){_nameScopeStack.push(e);try{var r=t();return _nameScopeStack.pop(),r}catch(e){throw _nameScopeStack.pop(),e}}function currentNameScopePrefix(){return 0===_nameScopeStack.length?"":_nameScopeStack.join(_nameScopeDivider)+_nameScopeDivider}function getScopedTensorName(e){if(!isValidTensorName(e))throw new Error("Not a valid tensor name: '"+e+"'");return currentNameScopePrefix()+e}function getUniqueTensorName(e){if(!isValidTensorName(e))throw new Error("Not a valid tensor name: '"+e+"'");nameMap.has(e)||nameMap.set(e,0);var t=nameMap.get(e);if(nameMap.set(e,nameMap.get(e)+1),t>0){var r=e+"_"+t;return nameMap.set(r,1),r}return e}var tensorNameRegex=new RegExp(/^[A-Za-z][A-Za-z0-9\._\/]*$/);function isValidTensorName(e){return!!e.match(tensorNameRegex)}function isInteger(e){return e===parseInt(e.toString(),10)}function arrayProd(e,t,r){null==t&&(t=0),null==r&&(r=e.length);for(var n=1,a=t;a2e3&&console.warn("Orthogonal initializer is being called on a matrix with more than 2000 ("+e[0]*e[1]+") elements: Slowness may result.");var t=randomNormal$1(e[0]>e[1]?[e[1],e[0]]:e,0,1,"float32"),n=linalg_ops.gramSchmidt(t);return e[0]>e[1]&&(n=n.transpose()),mul(getScalar(r.gain),n)})},t.prototype.getConfig=function(){return{gain:this.gain,seed:this.seed}},t.className="Orthogonal",t}(Initializer);serialization.SerializationMap.register(Orthogonal);var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP={constant:"Constant",glorotNormal:"GlorotNormal",glorotUniform:"GlorotUniform",heNormal:"HeNormal",identity:"Identity",leCunNormal:"LeCunNormal",ones:"Ones",orthogonal:"Orthogonal",randomNormal:"RandomNormal",randomUniform:"RandomUniform",truncatedNormal:"TruncatedNormal",varianceScaling:"VarianceScaling",zeros:"Zeros"};function deserializeInitializer(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,"initializer")}function serializeInitializer(e){return serializeKerasObject(e)}function getInitializer(e){if("string"==typeof e){var t=e in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP?INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e;return"GlorotUniform"===t?new GlorotUniform:"GlorotNormal"===t?new GlorotNormal:"HeNormal"===t?new HeNormal:"LeCunNormal"===t?new LeCunNormal:deserializeInitializer({className:t,config:{}})}return e instanceof Initializer?e:deserializeInitializer(e)}function zeros$1(){return new Zeros}function ones$1$1(){return new Ones}function constant(e){return new Constant(e)}function randomUniform$1(e){return new RandomUniform(e)}function randomNormal$2(e){return new RandomNormal(e)}function truncatedNormal$1(e){return new TruncatedNormal(e)}function identity(e){return new Identity(e)}function varianceScaling(e){return new VarianceScaling(e)}function glorotUniform(e){return new GlorotUniform(e)}function glorotNormal(e){return new GlorotNormal(e)}function heNormal(e){return new HeNormal(e)}function leCunNormal(e){return new LeCunNormal(e)}function orthogonal(e){return new Orthogonal(e)}var exports_initializers=Object.freeze({zeros:zeros$1,ones:ones$1$1,constant:constant,randomUniform:randomUniform$1,randomNormal:randomNormal$2,truncatedNormal:truncatedNormal$1,identity:identity,varianceScaling:varianceScaling,glorotUniform:glorotUniform,glorotNormal:glorotNormal,heNormal:heNormal,leCunNormal:leCunNormal,orthogonal:orthogonal});function isArrayOfShapes(e){return Array.isArray(e)&&Array.isArray(e[0])}function normalizeShapeList(e){return 0===e.length?[]:Array.isArray(e[0])?e:[e]}function getExactlyOneTensor(e){var t;if(Array.isArray(e)){if(1!==e.length)throw new ValueError("Expected Tensor length to be 1; got "+e.length);t=e[0]}else t=e;return t}function getExactlyOneShape(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(1===e.length)return(e=e)[0];throw new ValueError("Expected exactly 1 Shape; got "+e.length)}return e}function countParamsInWeights(e){for(var t=0,r=0,n=e;r1)throw new AttributeError("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if(0===this.inboundNodes.length)throw new AttributeError("Layer "+this.name+" is not connected, no input to return.");return singletonOrArray(this.getNodeAtIndex(0,"input").inputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"output",{get:function(){if(0===this.inboundNodes.length)throw new AttributeError("Layer "+this.name+" has no inbound nodes.");if(this.inboundNodes.length>1)throw new AttributeError("Layer "+this.name+' has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return singletonOrArray(this.getNodeAtIndex(0,"output").outputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"losses",{get:function(){return this._losses},enumerable:!0,configurable:!0}),t.prototype.calculateLosses=function(){return this.losses.map(function(e){return e()})},Object.defineProperty(t.prototype,"updates",{get:function(){return this._updates},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"built",{get:function(){return this._built},set:function(e){this._built=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"trainableWeights",{get:function(){return this.trainable?this._trainableWeights:[]},set:function(e){this._trainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this._nonTrainableWeights:this._trainableWeights.concat(this._nonTrainableWeights)},set:function(e){this._nonTrainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"weights",{get:function(){return this.trainableWeights.concat(this.nonTrainableWeights)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"stateful",{get:function(){return this._stateful},enumerable:!0,configurable:!0}),t.prototype.assertInputCompatibility=function(e){if(e=toList(e),null!=this.inputSpec&&0!==this.inputSpec.length){var t=toList(this.inputSpec);if(e.length!==t.length)throw new ValueError("Layer "+this.name+" expects "+t.length+" inputs, but it received "+e.length+" input tensors. Input received: "+e);for(var r=0;r=0?i[u]:i[i.length+u];if(null!=l&&-1===[l,null].indexOf(p))throw new ValueError("Input "+r+" is incompatible with layer "+this.name+": expected axis "+u+" of input shape to have value "+l+" but got shape "+i+".")}}if(null!=a.shape)for(var c=0;c0&&Array.isArray(f[0])?f.map(function(n,a){return new SymbolicTensor(g,n,r,toList(e),t,r.name,a)}):new SymbolicTensor(g,f,r,toList(e),t,r.name),r.addInboundNode(e,m,null,null,h,f,t),null!=r.activityRegularizer)throw new NotImplementedError("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return m})},t.prototype.warnOnIncompatibleInputShape=function(e){if(null!=this.batchInputShape)if(e.length!==this.batchInputShape.length)console.warn("The rank of the input tensor provided (shape: "+JSON.stringify(e)+") does not match that of the batchInputShape ("+JSON.stringify(this.batchInputShape)+") of the layer "+this.name);else{var t=!1;this.batchInputShape.forEach(function(r,n){null!=r&&null!=e[n]&&e[n]!==r&&(t=!0)}),t&&console.warn("The shape of the input tensor ("+JSON.stringify(e)+") does not match the expectation of layer "+this.name+": "+JSON.stringify(this.batchInputShape))}},Object.defineProperty(t.prototype,"outputShape",{get:function(){if(null==this.inboundNodes||0===this.inboundNodes.length)throw new AttributeError("The layer "+this.name+" has never been called and thus has no defined output shape.");for(var e=[],t=0,r=this.inboundNodes;t0)&&(t=e.sourceLayer,r=e.nodeIndex),0===t.inboundNodes.length)return[e];var n=t.inboundNodes[r];if(0===n.inboundLayers.length)return n.inputTensors;for(var a=[],o=0;o1||1===s.length&&s[0].inboundLayers.length>1){t=!1;break}n.push.apply(n,s)}if(t)for(var u=0,l=e.layers;u0&&(n=n.slice(0,n.length-1)+" "),n=(n+=e[a]).slice(0,t[a]),n+=" ".repeat(t[a]-n.length);r(n)}function printLayerSummary(e,t,r){var n;try{n=JSON.stringify(e.outputShape)}catch(e){n="multiple"}printRow([e.name+" ("+e.getClassName()+")",n,e.countParams().toString()],t,r)}function printLayerSummaryWithConnections(e,t,r,n){var a;try{a=JSON.stringify(e.outputShape)}catch(e){a="multiple"}for(var o=[],i=0,s=e.inboundNodes;i0&&-1===r.indexOf(u)))for(var l=0;l0)throw new ValueError(c.length+" of "+n+" weights are not set: "+c);batchSetValue(l)}var Container=function(e){function t(r){var n=e.call(this,{})||this;if(n.containerNodes=new Set,n.name=r.name,null==n.name){var a=n.getClassName().toLowerCase();n.name=getUid(a)}if(n.supportsMasking=!1,n.trainable=!0,n.updatable=!0,Array.isArray(r.inputs)?n.inputs=r.inputs.slice():n.inputs=[r.inputs],Array.isArray(r.outputs)?n.outputs=r.outputs.slice():n.outputs=[r.outputs],unique(n.inputs).length!==n.inputs.length)throw new ValueError("The list of inputs passed to the model is redundant. All inputs should only appear once. Found: "+n.inputs.map(function(e){return e.name}));unique(n.outputs).length!==n.outputs.length&&console.warn("The list of outputs passed to the model is redundant. All outputs should only appear once. Found: "+n.outputs.map(function(e){return e.name})),n.inputLayers=[],n.inputLayersNodeIndices=[],n.inputLayersTensorIndices=[],n.outputLayers=[],n.outputLayersNodeIndices=[],n.outputLayersTensorIndices=[],n.layers=[];for(var o=0,i=n.outputs;o1 nodes"),assert$1(0===l,"input layer has >1 tensors"),n.inputLayers.push(s),n.inputLayersNodeIndices.push(u),n.inputLayersTensorIndices.push(l);n.inputNames=[],n.outputNames=[],n.feedInputShapes=[],n.feedInputNames=[],n.feedOutputNames=[];for(var d=0;d=0;)a.splice(a.indexOf(u),1);x.push(u)}},S=[],N=[],T=0,E=n.outputs;Tn?1:0});for(var U=0,W=$;U0)throw new ValueError("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];for(var e=[],t=0,r=this.layers;t1)for(var s=0,u=i;s0){for(var h=[],f=0;f0&&e.apply(singletonOrArray(o),n)}function i(e){var n=e.name,o=deserialize(e,null!=t.customObjects?t.customObjects:{});r[n]=o;for(var i=0,s=e.inboundNodes;i0)o=!0;else if(isDataDict(e)){for(var i in e)if(e.hasOwnProperty(i)){o=!0;break}}else o=!0;if(o)throw new ValueError("Error when checking model "+a+" expected no data, but got "+e)}return[]}if(null==e)return t.map(function(e){return null});var s;if(isDataDict(e)){e=e,s=[];for(var u=0,l=t;u1)throw new ValueError("The model "+a+" expects "+t.length+" Tensor(s), but only received one Tensor. Found: Tensor with shape "+e.shape);s=[e]}for(var c=0;c=0&&f!==m)throw new ValueError("Error when checking "+a+": expected "+t[c]+" to have shape ["+r[c]+"], but got array with shape ["+d.shape+"].")}}return s}function checkArrayLengths(e,t,r){var n=unique(e.map(function(e){return e.shape[0]}));n.sort();var a=unique(t.map(function(e){return e.shape[0]}));if(a.sort(),n.length>1)throw new ValueError("All input Tensors (x) should have the same number of samples. Got array shapes: "+JSON.stringify(e.map(function(e){return e.shape})));if(a.length>1)throw new ValueError("All target Tensors (y) should have the same number of samples. Got array shapes: "+JSON.stringify(t.map(function(e){return e.shape})));if(n.length>0&&a.length>0&&!util.arraysEqual(n,a))throw new ValueError("Input Tensors should have the same number of samples as target Tensors. Found "+n[0]+" input sample(s) and "+a[0]+" target sample(s).")}function checkLossAndTargetCompatibility(e,t,r){for(var n=[meanSquaredError$1,binaryCrossentropy,categoricalCrossentropy],a=0;a=e&&(a=e),r.push([n,a]),n=a;return r}function sliceArrays(e,t,r){return null==e?[null]:Array.isArray(e)?e.map(function(e){return sliceAlongFirstAxis(e,t,r-t)}):sliceAlongFirstAxis(e,t,r-t)}function sliceArraysByIndices(e,t){return tidy(function(){return null==e?null:Array.isArray(e)?e.map(function(e){return sliceArraysByIndices(e,t)}):gather$1(e,"int32"===t.dtype?t:t.toInt())})}function checkInputData(e,t,r,n,a){var o;if(void 0===n&&(n=!0),void 0===a&&(a=""),Array.isArray(e)){if(e.length!==t.length)throw new ValueError("Error when checking model "+a+": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see "+t.length+" Tensor(s), but instead got "+e.length+" Tensors(s).");o=e}else{if(t.length>1)throw new ValueError("The model expects "+t.length+" "+a+" Tensors, but only received one Tensor. Found: array with shape "+JSON.stringify(e.shape)+".");o=[e]}if(null!=r)for(var i=0;i1&&(t.metricsTensors.push([r,e]),t.metricsNames.push(t.outputNames[e]+"_loss"))}});var c=collectMetrics(e.metrics,this.outputNames);nameScope("metric",function(){for(var e=function(e){if(-1!==p.indexOf(e))return"continue";!function(r){for(var n,a,o,i=function(r){if(-1!==["accuracy","acc","crossentropy","ce"].indexOf(r)){var i=t.internalOutputShapes[e];1===i[i.length-1]||t.lossFunctions[e]===binaryCrossentropy?-1!==["accuracy","acc"].indexOf(r)?a=binaryAccuracy:-1!==["crossentropy","ce"].indexOf(r)&&(a=binaryCrossentropy$1):t.lossFunctions[e]===sparseCategoricalCrossentropy?-1!==["accuracy","acc"].indexOf(r)?a=sparseCategoricalAccuracy:-1!==["crossentropy","ce"].indexOf(r)&&(a=sparseCategoricalCrossentropy$1):-1!==["accuracy","acc"].indexOf(r)?a=categoricalAccuracy:-1!==["crossentropy","ce"].indexOf(r)&&(a=categoricalCrossentropy$1);var s=void 0;-1!==["accuracy","acc"].indexOf(r)?s="acc":-1!==["crossentropy","ce"].indexOf(r)&&(s="ce"),o=a,n=""+s}else{var u=get$1(r);o=u,n=""+r}var l;nameScope(n,function(){l=o}),function(e,r,n){t.outputNames.length>1&&(r=t.outputNames[e]+"_"+r),t.metricsNames.push(r),t.metricsTensors.push([n,e])}(e,n,l)},s=0,u=c[e];s0){var p=[];throw t.forEach(function(t,r){null==t&&p.push(e[r])}),new ValueError("Cannot find SymbolicTensors for output name(s): "+JSON.stringify(p))}return t},t.prototype.predictLoop=function(e,t,r){var n=this;return void 0===t&&(t=32),void 0===r&&(r=!1),tidy(function(){var a=n.checkNumSamples(e);if(r)throw new NotImplementedError("Verbose predictLoop() is not implemented yet.");for(var o=makeBatches(a,t),i=[],s=function(t){var r=tidy(function(){var r=o[t][0],a=o[t][1],i=sliceArrays(e,r,a),s=[];if(Array.isArray(i))for(var u=0;u0&&e[0].shape[0]%n!=0)throw new ValueError("In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size "+n+". Found: "+e[0].shape[0]+" sample(s).");return[e,t,null]},t.prototype.fitLoop=function(e,t,r,n,a,o,i,s,u,l,p,c,d,h){return __awaiter$1(this,void 0,void 0,function(){var f,m,g,y,v,b,x,w=this;return __generator$1(this,function(S){switch(S.label){case 0:if(null==n&&(n=32),null==a&&(a=1),null==l&&(l=!0),null==c&&(c=0),f=!1,null!=s&&null!=u&&(f=!0),null!=h&&(f=!0,null==d))throw new ValueError("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");if(null!=(m=this.checkNumSamples(t,n,d,"steps_per_epoch"))&&(g=range$1(0,m)),this.history=new History,i=(i=null==i?[new BaseLogger]:[new BaseLogger].concat(i)).concat([this.history]),o>0)throw new NotImplementedError("Verbose mode is not implemented yet.");return(y=new CallbackList(i)).setModel(this),y.setParams({epochs:a,initialEpoch:c,steps:d,verbose:o,doValidation:f,metrics:p}),[4,y.onTrainBegin()];case 1:S.sent(),this.stopTraining=!1,v=function(a){var o,i,p,c,h;return __generator$1(this,function(v){switch(v.label){case 0:return[4,y.onEpochBegin(a)];case 1:if(v.sent(),o={},null==d)return[3,2];throw new NotImplementedError("stepsPerEpoch mode is not implemented yet.");case 2:if("batch"===l)throw new NotImplementedError("batch shuffling is not implemneted yet");l&&util.shuffle(g),i=tensor1d(g),p=makeBatches(m,n),c=function(a){var l;return __generator$1(this,function(c){switch(c.label){case 0:return l={},[4,y.onBatchBegin(a,l)];case 1:return c.sent(),tidy(function(){var c=p[a][0],d=p[a][1],h=sliceAlongFirstAxis(i,c,d-c);l.batch=a,l.size=d-c;for(var m=sliceArraysByIndices(t,h),g=e(m),y=0;y1&&(a+="_"+count(e.slice(0,r),n)),t.push(a)}return t},t.prototype.makeTestFunction=function(){var e=this;this.testFunction=function(t){return tidy(function(){for(var r,n=[],a=t.slice(0,e.inputs.length),o=t.slice(e.inputs.length,e.inputs.length+e.outputs.length),i=[],s=0;s0){if(s=!0,2!==r.validationData.length)throw 3===r.validationData.length?new NotImplementedError("validationData including sample weights is not supported yet."):new ValueError("When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; "+r.validationData+" is invalid.");u=r.validationData[0],l=r.validationData[1],d=this.standardizeUserData(u,l,!0,n),u=d[0],l=d[1],p=u.concat(l)}else null!=r.validationSplit&&r.validationSplit>0&&r.validationSplit<1?(s=!0,h=Math.floor(o[0].shape[0]*(1-r.validationSplit)),f=o[0].shape[0],u=sliceArrays(o,h,f),o=sliceArrays(o,0,h),l=sliceArrays(i,h,f),i=sliceArrays(i,0,h),c=!0,p=u.concat(l)):null!=r.validationSteps&&(s=!0);return m=o.concat(i),this.checkTrainableWeightsConsistency(),g=function(e){var t=e.slice(0,S.inputs.length),r=e.slice(S.inputs.length,S.inputs.length+S.outputs.length),n=[],a=S.collectedTrainableWeights.map(function(e){return e.read()});return[S.optimizer.minimize(function(){for(var e=[],a=0;a1)throw new ValueError("Found more than one ("+r.length+") save handlers for URL '"+e+"'");e=r[0]}if(null==e.save)throw new ValueError("Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return[4,io.encodeWeights(this.getNamedWeights(t))];case 1:return n=s.sent(),a=!1,o=null,i=this.toJSON(o,a),[2,e.save({modelTopology:i,weightData:n.data,weightSpecs:n.specs})]}})})},t.className="Model",t}(Container);function loadModelInternal(e){return __awaiter$1(this,void 0,void 0,function(){var t;return __generator$1(this,function(r){if("string"==typeof e){if(0===(t=io.getLoadHandlers(e)).length)t.push(io.browserHTTPRequest(e));else if(t.length>1)throw new ValueError("Found more than one ("+t.length+") load handlers for URL '"+e+"'");e=t[0]}return[2,loadModelFromIOHandler(e)]})})}function loadModelFromIOHandler(e,t){return __awaiter$1(this,void 0,void 0,function(){var r,n,a,o,i;return __generator$1(this,function(s){switch(s.label){case 0:if(null==e.load)throw new ValueError("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");return[4,e.load()];case 1:if(r=s.sent(),null!=(n=r.modelTopology).model_config&&(n=n.model_config),a=deserialize(convertPythonicToTs(n),t),null!=r.weightData){if(null==r.weightSpecs)throw new ValueError("Model artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");o=!1,i=!0,a.loadWeights(io.decodeWeights(r.weightData,r.weightSpecs),o,i)}return[2,a]}})})}serialization.SerializationMap.register(Model);var Sequential=function(e){function t(t){var r=e.call(this,{inputs:[],outputs:[]})||this;if(t=t||{},r.trainable=!0,r._updatable=!0,r.built=!1,r.name=null!=t.name?t.name:getUid("sequential_"),null!=t.layers)for(var n=0,a=t.layers;n 0 but got "+JSON.stringify(e.filters))},t}(BaseConv),Conv2D=function(e){function t(r){var n=e.call(this,2,r)||this;return t.verifyConfig(r),n}return __extends$1(t,e),t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.rank,t},t.verifyConfig=function(e){if("number"!=typeof e.kernelSize&&!checkArrayTypeAndLength(e.kernelSize,"number",1,2))throw new ValueError("Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received "+JSON.stringify(e.kernelSize)+".")},t.className="Conv2D",t}(Conv);serialization.SerializationMap.register(Conv2D);var Conv2DTranspose=function(e){function t(t){var r=e.call(this,t)||this;if(r.inputSpec=[new InputSpec({ndim:4})],"same"!==r.padding&&"valid"!==r.padding)throw new ValueError("Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode "+r.padding);return r}return __extends$1(t,e),t.prototype.build=function(e){if(4!==(e=getExactlyOneShape(e)).length)throw new ValueError("Input should have rank 4; Received input shape: "+JSON.stringify(e));var t="channelsFirst"===this.dataFormat?1:e.length-1;if(null==e[t])throw new ValueError("The channel dimension of the inputs should be defined. Found `None`.");var r,n=e[t],a=this.kernelSize.concat([this.filters,n]);this.kernel=this.addWeight("kernel",a,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new InputSpec({ndim:4,axes:(r={},r[t]=n,r)})],this.built=!0},t.prototype.call=function(e,t){var r=this;return tidy(function(){var t=getExactlyOneTensor(e);if(4!==t.shape.length)throw new ValueError("Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-"+t.shape.length);var n,a,o=t.shape,i=o[0];"channelsFirst"===r.dataFormat?(n=2,a=3):(n=1,a=2);var s=o[n],u=o[a],l=r.kernelSize[0],p=r.kernelSize[1],c=r.strides[0],d=r.strides[1],h=[i,deconvLength(s,c,l,r.padding),deconvLength(u,d,p,r.padding),r.filters];"channelsLast"!==r.dataFormat&&(t=transpose(t,[0,2,3,1]));var f=conv2dTranspose(t,r.kernel.read(),h,r.strides,r.padding);return"channelsLast"!==r.dataFormat&&(f=transpose(f,[0,3,1,2])),null!=r.bias&&(f=biasAdd(f,r.bias.read(),r.dataFormat)),null!=r.activation&&(f=r.activation.apply(f)),f})},t.prototype.computeOutputShape=function(e){var t,r,n,a=(e=getExactlyOneShape(e)).slice();"channelsFirst"===this.dataFormat?(t=1,r=2,n=3):(t=3,r=1,n=2);var o=this.kernelSize[0],i=this.kernelSize[1],s=this.strides[0],u=this.strides[1];return a[t]=this.filters,a[r]=deconvLength(a[r],s,o,this.padding),a[n]=deconvLength(a[n],u,i,this.padding),a},t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.dilationRate,t},t.className="Conv2DTranspose",t}(Conv2D);serialization.SerializationMap.register(Conv2DTranspose);var SeparableConv=function(e){function t(t,r){var n=e.call(this,t,r)||this;if(n.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",n.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",n.depthwiseKernel=null,n.pointwiseKernel=null,null==r.filters)throw new ValueError("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(null!=r.kernelInitializer||null!=r.kernelRegularizer||null!=r.kernelConstraint)throw new ValueError("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(null!=r.padding&&"same"!==r.padding&&"valid"!==r.padding)throw new ValueError("SeparableConv"+n.rank+"D supports only padding modes: 'same' and 'valid', but received "+JSON.stringify(r.padding));return n.depthMultiplier=null==r.depthMultiplier?1:r.depthMultiplier,n.depthwiseInitializer=getInitializer(r.depthwiseInitializer||n.DEFAULT_DEPTHWISE_INITIALIZER),n.depthwiseRegularizer=getRegularizer(r.depthwiseRegularizer),n.depthwiseConstraint=getConstraint(r.depthwiseConstraint),n.pointwiseInitializer=getInitializer(r.depthwiseInitializer||n.DEFAULT_POINTWISE_INITIALIZER),n.pointwiseRegularizer=getRegularizer(r.pointwiseRegularizer),n.pointwiseConstraint=getConstraint(r.pointwiseConstraint),n}return __extends$1(t,e),t.prototype.build=function(e){if((e=getExactlyOneShape(e)).length1)throw new ValueError("Can not merge tensors with different batch sizes. Got tensors with shapes: "+JSON.stringify(e)+".");for(var a=null==e[0]?null:e[0].slice(1),o=1;o1){var y=range$1(1,s).concat([0]);t.push(transpose(d,y)),l=!0}else t.push(d)}var v=r.mergeFunction(t),b=v.rank;if(l)if(null==b){var x=v.shape;m=[f=x[x.length-1]].concat(x.slice(0,x.length-1)),v=transpose(v.reshape([-1,f]),[1,0]).reshape(m)}else b>1&&(y=[b-1].concat(range$1(0,b-1)),v=transpose(v,y));return v}return r.mergeFunction(e)})},t.prototype.computeOutputShape=function(e){var t;t=null==(e=e)[0]?null:e[0].slice(1);for(var r=1;r1)throw new ValueError("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}},t.prototype.mergeFunction=function(e){var t=this;return tidy(function(){return concatenate(e,t.axis)})},t.prototype.computeOutputShape=function(e){if(!Array.isArray(e)||!Array.isArray(e[0]))throw new ValueError("A `Concatenate` layer should be called on a list of inputs.");for(var t=e,r=t[0].slice(),n=this.axis<0?r.length+this.axis:this.axis,a=0,o=t.slice(1);a=0?this.axis:this.axis+e.length,r=e[t];if(null==r)throw new ValueError("Axis "+t+" of input tensor should have a defined dimension but the layer received an input with shape "+JSON.stringify(e)+".");this.inputSpec=[new InputSpec({ndim:e.length,axes:(n={},n[t]=r,n)})];var n,a=[r];this.scale&&(this.gamma=this.addWeight("gamma",a,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",a,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",a,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",a,null,this.movingVarianceInitializer,null,!1),this.built=!0},t.prototype.call=function(e,t){var r=this;return tidy(function(){var n=null!=t.training&&t.training,a=getExactlyOneTensor(e),o=a.shape,i=o.length,s=range$1(0,i),u=r.axis>=0?r.axis:r.axis+i;s.splice(u,1);var l=pyListRepeat(1,i);l[u]=o[u];var p=s.slice();p.sort();var c=!util.arraysEqual(p,range$1(0,i).slice(0,i-1));if(!n)return function(){if(c){var e=r.movingMean.read().reshape(l),t=r.movingVariance.read().reshape(l),n=r.center?r.beta.read().reshape(l):null,o=r.scale?r.gamma.read().reshape(l):null;return batchNormalization$1(a,e,t,n,o,r.epsilon)}return batchNormalization$1(a,r.movingMean.read(),r.movingVariance.read(),null==r.beta?null:r.beta.read(),null==r.gamma?null:r.gamma.read(),r.epsilon)}();var d=normalizeBatchInTraining(a,r.gamma.read(),r.beta.read(),s,r.epsilon),h=d[0],f=d[1],m=d[2],g=arrayProd(s.map(function(e){return a.shape[e]})),y=m.mul(getScalar(g/(g-(1+r.epsilon))));return function(){r.stepCount++;var e=movingAverage(r.movingMean.read(),f,r.momentum,r.stepCount);r.movingMean.write(e);var t=movingAverage(r.movingVariance.read(),y,r.momentum,r.stepCount);r.movingVariance.write(t)}(),h})},t.prototype.getConfig=function(){var t={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:serializeInitializer(this.betaInitializer),gammaInitializer:serializeInitializer(this.gammaInitializer),movingMeanInitializer:serializeInitializer(this.movingMeanInitializer),movingVarianceInitializer:serializeInitializer(this.movingVarianceInitializer),betaRegularizer:serializeRegularizer(this.betaRegularizer),gammaRegularizer:serializeRegularizer(this.gammaRegularizer),betaConstraint:serializeConstraint(this.betaConstraint),gammaConstraint:serializeConstraint(this.gammaConstraint)},r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t.className="BatchNormalization",t}(Layer);function spatial2dPadding(e,t,r){return tidy(function(){if(4!==e.rank)throw new ValueError("temporalPadding expects input tensor to be 4-D, but received a "+e.rank+"-D tensor.");if(null==t&&(t=[[1,1],[1,1]]),2!==t.length||2!==t[0].length||2!==t[1].length)throw new ValueError("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(null==r&&(r=imageDataFormat()),"channelsLast"!==r&&"channelsFirst"!==r)throw new ValueError("Unknown data format: "+r+". Supported data formats are 'channelsLast' and 'channelsFirst.");var n;return n="channelsFirst"===r?[[0,0],[0,0],t[0],t[1]]:[[0,0],t[0],t[1],[0,0]],pad(e,n)})}serialization.SerializationMap.register(BatchNormalization);var ZeroPadding2D=function(e){function t(t){var r=this;if(null==t&&(t={}),(r=e.call(this,t)||this).dataFormat=null==t.dataFormat?imageDataFormat():t.dataFormat,null==t.padding)r.padding=[[1,1],[1,1]];else if("number"==typeof t.padding)r.padding=[[t.padding,t.padding],[t.padding,t.padding]];else{if(t.padding=t.padding,2!==t.padding.length)throw new ValueError("ZeroPadding2D expects padding to be a length-2 array, but received a length-"+t.padding.length+" array.");var n=void 0,a=void 0;if("number"==typeof t.padding[0])n=[t.padding[0],t.padding[0]],a=[t.padding[1],t.padding[1]];else{if(t.padding=t.padding,2!==t.padding[0].length)throw new ValueError("ZeroPadding2D expects height padding to be a length-2 array, but received a length-"+t.padding[0].length+" array.");if(n=t.padding[0],2!==t.padding[1].length)throw new ValueError("ZeroPadding2D expects width padding to be a length-2 array, but received a length-"+t.padding[1].length+" array.");a=t.padding[1]}r.padding=[n,a]}return r.inputSpec=[new InputSpec({ndim:4})],r}return __extends$1(t,e),t.prototype.computeOutputShape=function(e){var t,r;return e=getExactlyOneShape(e),"channelsFirst"===this.dataFormat?(t=null!=e[2]&&e[2]>=0?e[2]+this.padding[0][0]+this.padding[0][1]:null,r=null!=e[3]&&e[3]>=0?e[3]+this.padding[1][0]+this.padding[1][1]:null,[e[0],e[1],t,r]):(t=null!=e[1]&&e[1]>=0?e[1]+this.padding[0][0]+this.padding[0][1]:null,r=null!=e[2]&&e[2]>=0?e[2]+this.padding[1][0]+this.padding[1][1]:null,[e[0],t,r,e[3]])},t.prototype.call=function(e,t){var r=this;return tidy(function(){return spatial2dPadding(getExactlyOneTensor(e),r.padding,r.dataFormat)})},t.prototype.getConfig=function(){var t={padding:this.padding,dataFormat:this.dataFormat},r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t.className="ZeroPadding2D",t}(Layer);function pool2d(e,t,r,n,a,o){return tidy(function(){var i;checkDataFormat(a),checkPoolMode(o),checkPaddingMode(n),null==r&&(r=[1,1]),null==n&&(n="valid"),null==a&&(a=imageDataFormat()),null==o&&(o="max"),e=preprocessConv2DInput(e,a);var s="same"===n?"same":"valid";return i="max"===o?maxPool(e,t,r,s):avgPool(e,t,r,s),"channelsFirst"===a&&(i=transpose(i,[0,3,1,2])),i})}serialization.SerializationMap.register(ZeroPadding2D);var Pooling1D=function(e){function t(t){var r=this;if(null==t.poolSize&&(t.poolSize=2),r=e.call(this,t)||this,"number"==typeof t.poolSize)r.poolSize=[t.poolSize];else{if(!Array.isArray(t.poolSize)||1!==t.poolSize.length||"number"!=typeof t.poolSize[0])throw new ValueError("poolSize for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(t.poolSize));r.poolSize=t.poolSize}if(null==t.strides)r.strides=r.poolSize;else if("number"==typeof t.strides)r.strides=[t.strides];else{if(!Array.isArray(t.strides)||1!==t.strides.length||"number"!=typeof t.strides[0])throw new ValueError("strides for 1D convolutional layer must be a number or an Array of a single number, but received "+JSON.stringify(t.strides));r.strides=t.strides}return r.padding=null==t.padding?"valid":t.padding,checkPaddingMode(r.padding),r.inputSpec=[new InputSpec({ndim:3})],r}return __extends$1(t,e),t.prototype.computeOutputShape=function(e){var t=convOutputLength((e=getExactlyOneShape(e))[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]},t.prototype.call=function(e,t){var r=this;return tidy(function(){r.invokeCallHook(e,t),e=expandDims$1(getExactlyOneTensor(e),2);var n=r.poolingFunction(getExactlyOneTensor(e),[r.poolSize[0],1],[r.strides[0],1],r.padding,"channelsLast");return squeeze(n,[2])})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides},r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t}(Layer),MaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.poolingFunction=function(e,t,r,n,a){return checkDataFormat(a),checkPaddingMode(n),pool2d(e,t,r,n,a,"max")},t.className="MaxPooling1D",t}(Pooling1D);serialization.SerializationMap.register(MaxPooling1D);var AveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.poolingFunction=function(e,t,r,n,a){return checkDataFormat(a),checkPaddingMode(n),pool2d(e,t,r,n,a,"avg")},t.className="AveragePooling1D",t}(Pooling1D);serialization.SerializationMap.register(AveragePooling1D);var Pooling2D=function(e){function t(t){var r=this;if(null==t.poolSize&&(t.poolSize=[2,2]),(r=e.call(this,t)||this).poolSize=Array.isArray(t.poolSize)?t.poolSize:[t.poolSize,t.poolSize],null==t.strides)r.strides=r.poolSize;else if(Array.isArray(t.strides)){if(2!==t.strides.length)throw new ValueError("If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length "+t.strides.length+".");r.strides=t.strides}else r.strides=[t.strides,t.strides];return r.padding=null==t.padding?"valid":t.padding,r.dataFormat=null==t.dataFormat?"channelsLast":t.dataFormat,checkDataFormat(r.dataFormat),checkPaddingMode(r.padding),r.inputSpec=[new InputSpec({ndim:4})],r}return __extends$1(t,e),t.prototype.computeOutputShape=function(e){e=getExactlyOneShape(e);var t="channelsFirst"===this.dataFormat?e[2]:e[1],r="channelsFirst"===this.dataFormat?e[3]:e[2];return t=convOutputLength(t,this.poolSize[0],this.padding,this.strides[0]),r=convOutputLength(r,this.poolSize[1],this.padding,this.strides[1]),"channelsFirst"===this.dataFormat?[e[0],e[1],t,r]:[e[0],t,r,e[3]]},t.prototype.call=function(e,t){var r=this;return tidy(function(){return r.invokeCallHook(e,t),r.poolingFunction(getExactlyOneTensor(e),r.poolSize,r.strides,r.padding,r.dataFormat)})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t}(Layer),MaxPooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.poolingFunction=function(e,t,r,n,a){return checkDataFormat(a),checkPaddingMode(n),pool2d(e,t,r,n,a,"max")},t.className="MaxPooling2D",t}(Pooling2D);serialization.SerializationMap.register(MaxPooling2D);var AveragePooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.poolingFunction=function(e,t,r,n,a){return checkDataFormat(a),checkPaddingMode(n),pool2d(e,t,r,n,a,"avg")},t.className="AveragePooling2D",t}(Pooling2D);serialization.SerializationMap.register(AveragePooling2D);var GlobalPooling1D=function(e){function t(t){var r=e.call(this,t)||this;return r.inputSpec=[new InputSpec({ndim:3})],r}return __extends$1(t,e),t.prototype.computeOutputShape=function(e){return[e[0],e[2]]},t.prototype.call=function(e,t){throw new NotImplementedError},t}(Layer),GlobalAveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return mean(t,1)})},t.className="GlobalAveragePooling1D",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalAveragePooling1D);var GlobalMaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends$1(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return max(t,1)})},t.className="GlobalMaxPooling1D",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalMaxPooling1D);var GlobalPooling2D=function(e){function t(t){var r=e.call(this,t)||this;return r.dataFormat=null==t.dataFormat?"channelsLast":t.dataFormat,checkDataFormat(r.dataFormat),r.inputSpec=[new InputSpec({ndim:4})],r}return __extends$1(t,e),t.prototype.computeOutputShape=function(e){return e=e,"channelsLast"===this.dataFormat?[e[0],e[3]]:[e[0],e[1]]},t.prototype.call=function(e,t){throw new NotImplementedError},t.prototype.getConfig=function(){var t={dataFormat:this.dataFormat},r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t}(Layer),GlobalAveragePooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends$1(t,e),t.prototype.call=function(e,t){var r=this;return tidy(function(){var t=getExactlyOneTensor(e);return"channelsLast"===r.dataFormat?mean(t,[1,2]):mean(t,[2,3])})},t.className="GlobalAveragePooling2D",t}(GlobalPooling2D);serialization.SerializationMap.register(GlobalAveragePooling2D);var GlobalMaxPooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends$1(t,e),t.prototype.call=function(e,t){var r=this;return tidy(function(){var t=getExactlyOneTensor(e);return"channelsLast"===r.dataFormat?max(t,[1,2]):max(t,[2,3])})},t.className="GlobalMaxPooling2D",t}(GlobalPooling2D);function standardizeArgs(e,t,r,n){if(Array.isArray(e)){if(null!=t||null!=r)throw new ValueError("When inputs is an array, neither initialState or constants should be provided");null!=n&&(r=e.slice(e.length-n,e.length),e=e.slice(0,e.length-n)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function a(e){return null==e||Array.isArray(e)?e:[e]}return{inputs:e,initialState:t=a(t),constants:r=a(r)}}function rnn(e,t,r,n,a,o,i,s){void 0===n&&(n=!1),void 0===i&&(i=!1);var u=t.shape.length;if(u<3)throw new ValueError("Input should be at least 3D, but is "+u+"D.");var l,p,c=[1,0].concat(range$1(2,u));if(t=transpose(t,c),null!=a)throw new NotImplementedError("The rnn() function of the deeplearn.js backend does not support masking yet.");if(null!=o)throw new NotImplementedError("The rnn() functoin of the deeplearn.js backend does not support constants yet.");i&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),n&&(t=reverse(t,0));for(var d=r,h=t.shape[0],f=0;f1?tile$1(r,[1,e]):r}):t.cell.stateSize>1?[tile$1(r,[1,t.cell.stateSize])]:[r]})},Object.defineProperty(t.prototype,"trainableWeights",{get:function(){return this.trainable?this.cell.trainableWeights:[]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"nonTrainableWeights",{get:function(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights},enumerable:!0,configurable:!0}),t.prototype.getConfig=function(){var t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};null!=this.numConstants&&(t.numConstants=this.numConstants);var r=this.cell.getConfig();t.cell={className:this.cell.getClassName(),config:r};var n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className="RNN",t}(Layer);serialization.SerializationMap.register(RNN);var RNNCell=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends$1(t,e),t}(Layer),SimpleRNNCell=function(e){function t(t){var r=e.call(this,t)||this;return r.DEFAULT_ACTIVATION="tanh",r.DEFAULT_KERNEL_INITIALIZER="glorotNormal",r.DEFAULT_RECURRENT_INITIALIZER="orthogonal",r.DEFAULT_BIAS_INITIALIZER="zeros",r.units=t.units,r.activation=getActivation(null==t.activation?r.DEFAULT_ACTIVATION:t.activation),r.useBias=null==t.useBias||t.useBias,r.kernelInitializer=getInitializer(t.kernelInitializer||r.DEFAULT_KERNEL_INITIALIZER),r.recurrentInitializer=getInitializer(t.recurrentInitializer||r.DEFAULT_RECURRENT_INITIALIZER),r.biasInitializer=getInitializer(t.biasInitializer||r.DEFAULT_BIAS_INITIALIZER),r.kernelRegularizer=getRegularizer(t.kernelRegularizer),r.recurrentRegularizer=getRegularizer(t.recurrentRegularizer),r.biasRegularizer=getRegularizer(t.biasRegularizer),r.kernelConstraint=getConstraint(t.kernelConstraint),r.recurrentConstraint=getConstraint(t.recurrentConstraint),r.biasConstraint=getConstraint(t.biasConstraint),r.dropout=min$1([1,max$1([0,null==t.dropout?0:t.dropout])]),r.recurrentDropout=min$1([1,max$1([0,null==t.recurrentDropout?0:t.recurrentDropout])]),r.stateSize=r.units,r.dropoutMask=null,r.recurrentDropoutMask=null,r}return __extends$1(t,e),t.prototype.build=function(e){e=getExactlyOneShape(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0},t.prototype.call=function(e,t){var r=this;return tidy(function(){if(2!==(e=e).length)throw new ValueError("SimpleRNNCell expects 2 input Tensors, got "+e.length+".");var n=e[1];e=e[0];var a,o=null!=t.training&&t.training;01){for(var o=[],i=0;i= 3D, but received input shape "+JSON.stringify(t));this.inputSpec=[{shape:t}];var r=[t[0]].concat(t.slice(2));this.layer.built||(this.layer.build(r),this.layer.built=!0),e.prototype.build.call(this,t)},t.prototype.computeOutputShape=function(e){var t=[(e=getExactlyOneShape(e))[0]].concat(e.slice(2)),r=this.layer.computeOutputShape(t),n=e[1];return[r[0],n].concat(r.slice(1))},t.prototype.call=function(e,t){var r=this;return tidy(function(){return rnn(function(e,n){return[r.layer.call(e,t),[]]},e=getExactlyOneTensor(e),[],!1,null,null,!1,e.shape[1])[1]})},t.className="TimeDistributed",t}(Wrapper);serialization.SerializationMap.register(TimeDistributed);var VALID_BIDIRECTIONAL_MERGE_MODES=["sum","mul","concat","ave"];function checkBidirectionalMergeMode(e){checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES,"BidirectionalMergeMode",e)}var Bidirectional=function(e){function t(t){var r=e.call(this,t)||this,n=t.layer.getConfig();if(r.forwardLayer=deserialize({className:t.layer.getClassName(),config:n}),n.goBackwards=!0!==n.goBackwards,r.backwardLayer=deserialize({className:t.layer.getClassName(),config:n}),r.forwardLayer.name="forward_"+r.forwardLayer.name,r.backwardLayer.name="backward_"+r.backwardLayer.name,checkBidirectionalMergeMode(t.mergeMode),r.mergeMode=t.mergeMode,t.weights)throw new NotImplementedError("weights support is not implemented for Bidirectional layer yet.");return r._stateful=t.layer.stateful,r.returnSequences=t.layer.returnSequences,r.returnState=t.layer.returnState,r.supportsMasking=!0,r._trainable=!0,r.inputSpec=t.layer.inputSpec,r.numConstants=null,r}return __extends$1(t,e),Object.defineProperty(t.prototype,"trainable",{get:function(){return this._trainable},set:function(e){this._trainable=e,null!=this.forwardLayer&&(this.forwardLayer.trainable=e),null!=this.backwardLayer&&(this.backwardLayer.trainable=e)},enumerable:!0,configurable:!0}),t.prototype.getWeights=function(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())},t.prototype.setWeights=function(e){var t=e.length,r=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,r)),this.backwardLayer.setWeights(e.slice(r))},t.prototype.computeOutputShape=function(e){var t,r,n,a=this.forwardLayer.computeOutputShape(e);return Array.isArray(a)&&Array.isArray(a[0])||(a=[a]),a=a,this.returnState?(n=a.slice(1),t=a[0]):t=a[0],t=t,"concat"===this.mergeMode?(t[t.length-1]*=2,r=[t]):r=null==this.mergeMode?[t,t.slice()]:[t],this.returnState?null==this.mergeMode?r.concat(n).concat(n.slice()):[t].concat(n).concat(n.slice()):singletonOrArray(r)},t.prototype.apply=function(t,r){var n=null==r?null:r.initialState,a=null==r?null:r.constants;null==r&&(r={});var o=standardizeArgs(t,n,a,this.numConstants);if(t=o.inputs,n=o.initialState,a=o.constants,Array.isArray(t)&&(n=t.slice(1),t=t[0]),(null==n||0===n.length)&&null==a)return e.prototype.apply.call(this,t,r);var i=[],s=[];if(null!=n){var u=n.length;if(u%2>0)throw new ValueError("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");r.initialState=n,i.push.apply(i,n);var l=n.map(function(e){return new InputSpec({shape:e.shape})});this.forwardLayer.stateSpec=l.slice(0,u/2),this.backwardLayer.stateSpec=l.slice(u/2),s.push.apply(s,l)}if(null!=a)throw new NotImplementedError("Support for constants in Bidirectional layers is not implemented yet.");for(var p=i[0]instanceof SymbolicTensor,c=0,d=i;c0&&a[a.length-1])&&(6===o[0]||2===o[0])){i=0;continue}if(3===o[0]&&(!a||o[1]>a[0]&&o[1]= 0x80 (not a basic code point)","invalid-input":"Invalid input"},w=l-p,S=Math.floor,N=String.fromCharCode;function T(e){throw RangeError(x[e])}function E(e,t){for(var r=e.length,n=[];r--;)n[r]=t(e[r]);return n}function I(e,t){var r=e.split("@"),n="";return r.length>1&&(n=r[0]+"@",e=r[1]),n+E((e=e.replace(b,".")).split("."),t).join(".")}function A(e){for(var t,r,n=[],a=0,o=e.length;a=55296&&t<=56319&&a65535&&(t+=N((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+N(e)}).join("")}function P(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function C(e,t,r){var n=0;for(e=r?S(e/h):e>>1,e+=S(e/t);e>w*c>>1;n+=l)e=S(e/w);return S(n+(w+1)*e/(e+d))}function k(e){var t,r,n,a,o,i,s,d,h,y,v,b=[],x=e.length,w=0,N=m,E=f;for((r=e.lastIndexOf(g))<0&&(r=0),n=0;n=128&&T("not-basic"),b.push(e.charCodeAt(n));for(a=r>0?r+1:0;a=x&&T("invalid-input"),((d=(v=e.charCodeAt(a++))-48<10?v-22:v-65<26?v-65:v-97<26?v-97:l)>=l||d>S((u-w)/i))&&T("overflow"),w+=d*i,!(d<(h=s<=E?p:s>=E+c?c:s-E));s+=l)i>S(u/(y=l-h))&&T("overflow"),i*=y;E=C(w-o,t=b.length+1,0==o),S(w/t)>u-N&&T("overflow"),N+=S(w/t),w%=t,b.splice(w++,0,N)}return _(b)}function O(e){var t,r,n,a,o,i,s,d,h,y,v,b,x,w,E,I=[];for(b=(e=A(e)).length,t=m,r=0,o=f,i=0;i=t&&vS((u-r)/(x=n+1))&&T("overflow"),r+=(s-t)*x,t=s,i=0;iu&&T("overflow"),v==t){for(d=r,h=l;!(d<(y=h<=o?p:h>=o+c?c:h-o));h+=l)E=d-y,w=l-y,I.push(N(P(y+E%w,0))),d=S(E/w);I.push(N(P(d,0))),o=C(r,x,n==a),r=0,++n}++r,++t}return I.join("")}if(i={version:"1.3.2",ucs2:{decode:A,encode:_},decode:k,encode:O,toASCII:function(e){return I(e,function(e){return v.test(e)?"xn--"+O(e):e})},toUnicode:function(e){return I(e,function(e){return y.test(e)?k(e.slice(4).toLowerCase()):e})}},n&&a)if(e.exports==n)a.exports=i;else for(s in i)i.hasOwnProperty(s)&&(n[s]=i[s]);else r.punycode=i}(commonjsGlobal$1)}),util$1={isString:function(e){return"string"==typeof e},isObject:function(e){return"object"==typeof e&&null!==e},isNull:function(e){return null===e},isNullOrUndefined:function(e){return null==e}};function hasOwnProperty(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var decode=function(e,t,r,n){t=t||"&",r=r||"=";var a={};if("string"!=typeof e||0===e.length)return a;var o=/\+/g;e=e.split(t);var i=1e3;n&&"number"==typeof n.maxKeys&&(i=n.maxKeys);var s=e.length;i>0&&s>i&&(s=i);for(var u=0;u=0?(l=h.substr(0,f),p=h.substr(f+1)):(l=h,p=""),c=decodeURIComponent(l),d=decodeURIComponent(p),hasOwnProperty(a,c)?Array.isArray(a[c])?a[c].push(d):a[c]=[a[c],d]:a[c]=d}return a},stringifyPrimitive=function(e){switch(typeof e){case"string":return e;case"boolean":return e?"true":"false";case"number":return isFinite(e)?e:"";default:return""}},encode=function(e,t,r,n){return t=t||"&",r=r||"=",null===e&&(e=void 0),"object"==typeof e?Object.keys(e).map(function(n){var a=encodeURIComponent(stringifyPrimitive(n))+r;return Array.isArray(e[n])?e[n].map(function(e){return a+encodeURIComponent(stringifyPrimitive(e))}).join(t):a+encodeURIComponent(stringifyPrimitive(e[n]))}).join(t):n?encodeURIComponent(stringifyPrimitive(n))+r+encodeURIComponent(stringifyPrimitive(e)):""},querystring=createCommonjsModule$1(function(e,t){t.decode=t.parse=decode,t.encode=t.stringify=encode}),querystring_1=querystring.decode,querystring_2=querystring.parse,querystring_3=querystring.encode,querystring_4=querystring.stringify,parse=urlParse,format=urlFormat;function Url(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}var protocolPattern=/^([a-z0-9.+-]+:)/i,portPattern=/:[0-9]*$/,simplePathPattern=/^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/,delims=["<",">",'"',"`"," ","\r","\n","\t"],unwise=["{","}","|","\\","^","`"].concat(delims),autoEscape=["'"].concat(unwise),nonHostChars=["%","/","?",";","#"].concat(autoEscape),hostEndingChars=["/","?","#"],hostnameMaxLen=255,hostnamePartPattern=/^[+a-z0-9A-Z_-]{0,63}$/,hostnamePartStart=/^([+a-z0-9A-Z_-]{0,63})(.*)$/,unsafeProtocol={javascript:!0,"javascript:":!0},hostlessProtocol={javascript:!0,"javascript:":!0},slashedProtocol={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,"http:":!0,"https:":!0,"ftp:":!0,"gopher:":!0,"file:":!0};function urlParse(e,t,r){if(e&&util$1.isObject(e)&&e instanceof Url)return e;var n=new Url;return n.parse(e,t,r),n}function urlFormat(e){return util$1.isString(e)&&(e=urlParse(e)),e instanceof Url?e.format():Url.prototype.format.call(e)}Url.prototype.parse=function(e,t,r){if(!util$1.isString(e))throw new TypeError("Parameter 'url' must be a string, not "+typeof e);var n=e.indexOf("?"),a=-1!==n&&n127?x+="x":x+=b[w];if(!x.match(hostnamePartPattern)){var N=y.slice(0,f),T=y.slice(f+1),E=b.match(hostnamePartStart);E&&(N.push(E[1]),T.unshift(E[2])),T.length&&(i="/"+T.join(".")+i),this.hostname=N.join(".");break}}}this.hostname.length>hostnameMaxLen?this.hostname="":this.hostname=this.hostname.toLowerCase(),g||(this.hostname=punycode.toASCII(this.hostname));var I=this.port?":"+this.port:"",A=this.hostname||"";this.host=A+I,this.href+=this.host,g&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),"/"!==i[0]&&(i="/"+i))}if(!unsafeProtocol[l])for(f=0,v=autoEscape.length;f0)&&r.host.split("@"))&&(r.auth=E.shift(),r.host=r.hostname=E.shift())),r.search=e.search,r.query=e.query,util$1.isNull(r.pathname)&&util$1.isNull(r.search)||(r.path=(r.pathname?r.pathname:"")+(r.search?r.search:"")),r.href=r.format(),r;if(!b.length)return r.pathname=null,r.search?r.path="/"+r.search:r.path=null,r.href=r.format(),r;for(var w=b.slice(-1)[0],S=(r.host||e.host||b.length>1)&&("."===w||".."===w)||""===w,N=0,T=b.length;T>=0;T--)"."===(w=b[T])?b.splice(T,1):".."===w?(b.splice(T,1),N++):N&&(b.splice(T,1),N--);if(!y&&!v)for(;N--;N)b.unshift("..");!y||""===b[0]||b[0]&&"/"===b[0].charAt(0)||b.unshift(""),S&&"/"!==b.join("/").substr(-1)&&b.push("");var E,I=""===b[0]||b[0]&&"/"===b[0].charAt(0);return x&&(r.hostname=r.host=I?"":b.length?b.shift():"",(E=!!(r.host&&r.host.indexOf("@")>0)&&r.host.split("@"))&&(r.auth=E.shift(),r.host=r.hostname=E.shift())),(y=y||r.host&&b.length)&&!I&&b.unshift(""),b.length?r.pathname=b.join("/"):(r.pathname=null,r.path=null),util$1.isNull(r.pathname)&&util$1.isNull(r.search)||(r.path=(r.pathname?r.pathname:"")+(r.search?r.search:"")),r.auth=e.auth||r.auth,r.slashes=r.slashes||e.slashes,r.href=r.format(),r},Url.prototype.parseHost=function(){var e=this.host,t=portPattern.exec(e);t&&(":"!==(t=t[0])&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)};var aspromise=asPromise;function asPromise(e,t){for(var r=new Array(arguments.length-1),n=0,a=2,o=!0;a1&&"="===e.charAt(t);)++r;return Math.ceil(3*e.length)/4-r};for(var n=new Array(64),a=new Array(123),o=0;o<64;)a[n[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;r.encode=function(e,t,r){for(var a,o=null,i=[],s=0,u=0;t>2],a=(3&l)<<4,u=1;break;case 1:i[s++]=n[a|l>>4],a=(15&l)<<2,u=2;break;case 2:i[s++]=n[a|l>>6],i[s++]=n[63&l],u=0}s>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,i)),s=0)}return u&&(i[s++]=n[a],i[s++]=61,1===u&&(i[s++]=61)),o?(s&&o.push(String.fromCharCode.apply(String,i.slice(0,s))),o.join("")):String.fromCharCode.apply(String,i.slice(0,s))},r.decode=function(e,t,r){for(var n,o=r,i=0,s=0;s1)break;if(void 0===(u=a[u]))throw Error("invalid encoding");switch(i){case 0:n=u,i=1;break;case 1:t[r++]=n<<2|(48&u)>>4,n=u,i=2;break;case 2:t[r++]=(15&n)<<4|(60&u)>>2,n=u,i=3;break;case 3:t[r++]=(3&n)<<6|u,i=0}}if(1===i)throw Error("invalid encoding");return r-o},r.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}}),eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(e,t,r){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:r||this}),this},EventEmitter.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var r=this._listeners[e],n=0;n0?0:2147483648,r,n);else if(isNaN(t))e(2143289344,r,n);else if(t>3.4028234663852886e38)e((a<<31|2139095040)>>>0,r,n);else if(t<1.1754943508222875e-38)e((a<<31|Math.round(t/1.401298464324817e-45))>>>0,r,n);else{var o=Math.floor(Math.log(t)/Math.LN2);e((a<<31|o+127<<23|8388607&Math.round(t*Math.pow(2,-o)*8388608))>>>0,r,n)}}function r(e,t,r){var n=e(t,r),a=2*(n>>31)+1,o=n>>>23&255,i=8388607&n;return 255===o?i?NaN:a*(1/0):0===o?1.401298464324817e-45*a*i:a*Math.pow(2,o-150)*(i+8388608)}e.writeFloatLE=t.bind(null,writeUintLE),e.writeFloatBE=t.bind(null,writeUintBE),e.readFloatLE=r.bind(null,readUintLE),e.readFloatBE=r.bind(null,readUintBE)}(),"undefined"!=typeof Float64Array?function(){var t=new Float64Array([-0]),r=new Uint8Array(t.buffer),n=128===r[7];function a(e,n,a){t[0]=e,n[a]=r[0],n[a+1]=r[1],n[a+2]=r[2],n[a+3]=r[3],n[a+4]=r[4],n[a+5]=r[5],n[a+6]=r[6],n[a+7]=r[7]}function o(e,n,a){t[0]=e,n[a]=r[7],n[a+1]=r[6],n[a+2]=r[5],n[a+3]=r[4],n[a+4]=r[3],n[a+5]=r[2],n[a+6]=r[1],n[a+7]=r[0]}function i(e,n){return r[0]=e[n],r[1]=e[n+1],r[2]=e[n+2],r[3]=e[n+3],r[4]=e[n+4],r[5]=e[n+5],r[6]=e[n+6],r[7]=e[n+7],t[0]}function s(e,n){return r[7]=e[n],r[6]=e[n+1],r[5]=e[n+2],r[4]=e[n+3],r[3]=e[n+4],r[2]=e[n+5],r[1]=e[n+6],r[0]=e[n+7],t[0]}e.writeDoubleLE=n?a:o,e.writeDoubleBE=n?o:a,e.readDoubleLE=n?i:s,e.readDoubleBE=n?s:i}():function(){function t(e,t,r,n,a,o){var i=n<0?1:0;if(i&&(n=-n),0===n)e(0,a,o+t),e(1/n>0?0:2147483648,a,o+r);else if(isNaN(n))e(0,a,o+t),e(2146959360,a,o+r);else if(n>1.7976931348623157e308)e(0,a,o+t),e((i<<31|2146435072)>>>0,a,o+r);else{var s;if(n<2.2250738585072014e-308)e((s=n/5e-324)>>>0,a,o+t),e((i<<31|s/4294967296)>>>0,a,o+r);else{var u=Math.floor(Math.log(n)/Math.LN2);1024===u&&(u=1023),e(4503599627370496*(s=n*Math.pow(2,-u))>>>0,a,o+t),e((i<<31|u+1023<<20|1048576*s&1048575)>>>0,a,o+r)}}}function r(e,t,r,n,a){var o=e(n,a+t),i=e(n,a+r),s=2*(i>>31)+1,u=i>>>20&2047,l=4294967296*(1048575&i)+o;return 2047===u?l?NaN:s*(1/0):0===u?5e-324*s*l:s*Math.pow(2,u-1075)*(l+4503599627370496)}e.writeDoubleLE=t.bind(null,writeUintLE,0,4),e.writeDoubleBE=t.bind(null,writeUintBE,4,0),e.readDoubleLE=r.bind(null,readUintLE,0,4),e.readDoubleBE=r.bind(null,readUintBE,4,0)}(),e}function writeUintLE(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function writeUintBE(e,t,r){t[r]=e>>>24,t[r+1]=e>>>16&255,t[r+2]=e>>>8&255,t[r+3]=255&e}function readUintLE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function readUintBE(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod$$1=eval("quire".replace(/^/,"re"))(moduleName);if(mod$$1&&(mod$$1.length||Object.keys(mod$$1).length))return mod$$1}catch(e){}return null}var utf8_1=createCommonjsModule$1(function(e,t){var r=t;r.length=function(e){for(var t=0,r=0,n=0;n191&&n<224?o[i++]=(31&n)<<6|63&e[t++]:n>239&&n<365?(n=((7&n)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,o[i++]=55296+(n>>10),o[i++]=56320+(1023&n)):o[i++]=(15&n)<<12|(63&e[t++])<<6|63&e[t++],i>8191&&((a||(a=[])).push(String.fromCharCode.apply(String,o)),i=0);return a?(i&&a.push(String.fromCharCode.apply(String,o.slice(0,i))),a.join("")):String.fromCharCode.apply(String,o.slice(0,i))},r.write=function(e,t,r){for(var n,a,o=r,i=0;i>6|192,t[r++]=63&n|128):55296==(64512&n)&&56320==(64512&(a=e.charCodeAt(i+1)))?(n=65536+((1023&n)<<10)+(1023&a),++i,t[r++]=n>>18|240,t[r++]=n>>12&63|128,t[r++]=n>>6&63|128,t[r++]=63&n|128):(t[r++]=n>>12|224,t[r++]=n>>6&63|128,t[r++]=63&n|128);return r-o}}),pool_1=pool;function pool(e,t,r){var n=r||8192,a=n>>>1,o=null,i=n;return function(r){if(r<1||r>a)return e(r);i+r>n&&(o=e(n),i=0);var s=t.call(o,i,i+=r);return 7&i&&(i=1+(7|i)),s}}var longbits=LongBits;function LongBits(e,t){this.lo=e>>>0,this.hi=t>>>0}var zero=LongBits.zero=new LongBits(0,0);zero.toNumber=function(){return 0},zero.zzEncode=zero.zzDecode=function(){return this},zero.length=function(){return 1};var zeroHash=LongBits.zeroHash="\0\0\0\0\0\0\0\0";LongBits.fromNumber=function(e){if(0===e)return zero;var t=e<0;t&&(e=-e);var r=e>>>0,n=(e-r)/4294967296>>>0;return t&&(n=~n>>>0,r=~r>>>0,++r>4294967295&&(r=0,++n>4294967295&&(n=0))),new LongBits(r,n)},LongBits.from=function(e){if("number"==typeof e)return LongBits.fromNumber(e);if(minimal.isString(e)){if(!minimal.Long)return LongBits.fromNumber(parseInt(e,10));e=minimal.Long.fromString(e)}return e.low||e.high?new LongBits(e.low>>>0,e.high>>>0):zero},LongBits.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,r=~this.hi>>>0;return t||(r=r+1>>>0),-(t+4294967296*r)}return this.lo+4294967296*this.hi},LongBits.prototype.toLong=function(e){return minimal.Long?new minimal.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var charCodeAt=String.prototype.charCodeAt;LongBits.fromHash=function(e){return e===zeroHash?zero:new LongBits((charCodeAt.call(e,0)|charCodeAt.call(e,1)<<8|charCodeAt.call(e,2)<<16|charCodeAt.call(e,3)<<24)>>>0,(charCodeAt.call(e,4)|charCodeAt.call(e,5)<<8|charCodeAt.call(e,6)<<16|charCodeAt.call(e,7)<<24)>>>0)},LongBits.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},LongBits.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},LongBits.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},LongBits.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,r=this.hi>>>24;return 0===r?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:r<128?9:10};var minimal=createCommonjsModule$1(function(e,t){var r=t;function n(e,t,r){for(var n=Object.keys(t),a=0;a0)},r.Buffer=function(){try{var e=r.inquire("buffer").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),r._Buffer_from=null,r._Buffer_allocUnsafe=null,r.newBuffer=function(e){return"number"==typeof e?r.Buffer?r._Buffer_allocUnsafe(e):new r.Array(e):r.Buffer?r._Buffer_from(e):"undefined"==typeof Uint8Array?e:new Uint8Array(e)},r.Array="undefined"!=typeof Uint8Array?Uint8Array:Array,r.Long=commonjsGlobal$1.dcodeIO&&commonjsGlobal$1.dcodeIO.Long||r.inquire("long"),r.key2Re=/^true|false|0|1$/,r.key32Re=/^-?(?:0|[1-9][0-9]*)$/,r.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,r.longToHash=function(e){return e?r.LongBits.from(e).toHash():r.LongBits.zeroHash},r.longFromHash=function(e,t){var n=r.LongBits.fromHash(e);return r.Long?r.Long.fromBits(n.lo,n.hi,t):n.toNumber(Boolean(t))},r.merge=n,r.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},r.newError=a,r.ProtocolError=a("ProtocolError"),r.oneOfGetter=function(e){for(var t={},r=0;r-1;--r)if(1===t[e[r]]&&void 0!==this[e[r]]&&null!==this[e[r]])return e[r]}},r.oneOfSetter=function(e){return function(t){for(var r=0;r127;)t[r++]=127&e|128,e>>>=7;t[r]=e}function VarintOp(e,t){this.len=e,this.next=void 0,this.val=t}function writeVarint64(e,t,r){for(;e.hi;)t[r++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=127&e.lo|128,e.lo=e.lo>>>7;t[r++]=e.lo}function writeFixed32(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}Writer.create=minimal.Buffer?function(){return(Writer.create=function(){return new BufferWriter})()}:function(){return new Writer},Writer.alloc=function(e){return new minimal.Array(e)},minimal.Array!==Array&&(Writer.alloc=minimal.pool(Writer.alloc,minimal.Array.prototype.subarray)),Writer.prototype._push=function(e,t,r){return this.tail=this.tail.next=new Op(e,t,r),this.len+=t,this},VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new VarintOp((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},Writer.prototype.int32=function(e){return e<0?this._push(writeVarint64,10,LongBits$1.fromNumber(e)):this.uint32(e)},Writer.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},Writer.prototype.uint64=function(e){var t=LongBits$1.from(e);return this._push(writeVarint64,t.length(),t)},Writer.prototype.int64=Writer.prototype.uint64,Writer.prototype.sint64=function(e){var t=LongBits$1.from(e).zzEncode();return this._push(writeVarint64,t.length(),t)},Writer.prototype.bool=function(e){return this._push(writeByte,1,e?1:0)},Writer.prototype.fixed32=function(e){return this._push(writeFixed32,4,e>>>0)},Writer.prototype.sfixed32=Writer.prototype.fixed32,Writer.prototype.fixed64=function(e){var t=LongBits$1.from(e);return this._push(writeFixed32,4,t.lo)._push(writeFixed32,4,t.hi)},Writer.prototype.sfixed64=Writer.prototype.fixed64,Writer.prototype.float=function(e){return this._push(minimal.float.writeFloatLE,4,e)},Writer.prototype.double=function(e){return this._push(minimal.float.writeDoubleLE,8,e)};var writeBytes=minimal.Array.prototype.set?function(e,t,r){t.set(e,r)}:function(e,t,r){for(var n=0;n>>0;if(!t)return this._push(writeByte,1,0);if(minimal.isString(e)){var r=Writer.alloc(t=base64.length(e));base64.decode(e,r,0),e=r}return this.uint32(t)._push(writeBytes,t,e)},Writer.prototype.string=function(e){var t=utf8.length(e);return t?this.uint32(t)._push(utf8.write,t,e):this._push(writeByte,1,0)},Writer.prototype.fork=function(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer.prototype.ldelim=function(){var e=this.head,t=this.tail,r=this.len;return this.reset().uint32(r),r&&(this.tail.next=e.next,this.tail=t,this.len+=r),this},Writer.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),r=0;e;)e.fn(e.val,t,r),r+=e.len,e=e.next;return t},Writer._configure=function(e){BufferWriter=e};var writer_buffer=BufferWriter$1;(BufferWriter$1.prototype=Object.create(writer.prototype)).constructor=BufferWriter$1;var Buffer$1=minimal.Buffer;function BufferWriter$1(){writer.call(this)}BufferWriter$1.alloc=function(e){return(BufferWriter$1.alloc=minimal._Buffer_allocUnsafe)(e)};var writeBytesBuffer=Buffer$1&&Buffer$1.prototype instanceof Uint8Array&&"set"===Buffer$1.prototype.set.name?function(e,t,r){t.set(e,r)}:function(e,t,r){if(e.copy)e.copy(t,r,0,e.length);else for(var n=0;n>>0;return this.uint32(t),t&&this._push(writeBytesBuffer,t,e),this},BufferWriter$1.prototype.string=function(e){var t=Buffer$1.byteLength(e);return this.uint32(t),t&&this._push(writeStringBuffer,t,e),this};var reader=Reader,BufferReader,LongBits$2=minimal.LongBits,utf8$1=minimal.utf8;function indexOutOfRange(e,t){return RangeError("index out of range: "+e.pos+" + "+(t||1)+" > "+e.len)}function Reader(e){this.buf=e,this.pos=0,this.len=e.length}var create_array="undefined"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new Reader(e);throw Error("illegal buffer")}:function(e){if(Array.isArray(e))return new Reader(e);throw Error("illegal buffer")};function readLongVarint(){var e=new LongBits$2(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}function readFixed32_end(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits$2(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader.create=minimal.Buffer?function(e){return(Reader.create=function(e){return minimal.Buffer.isBuffer(e)?new BufferReader(e):create_array(e)})(e)}:create_array,Reader.prototype._slice=minimal.Array.prototype.subarray||minimal.Array.prototype.slice,Reader.prototype.uint32=function(){var e=4294967295;return function(){if(e=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return e;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return e}}(),Reader.prototype.int32=function(){return 0|this.uint32()},Reader.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},Reader.prototype.bool=function(){return 0!==this.uint32()},Reader.prototype.fixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.sfixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return 0|readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.float=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},Reader.prototype.double=function(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},Reader.prototype.bytes=function(){var e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw indexOutOfRange(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,r):t===r?new this.buf.constructor(0):this._slice.call(this.buf,t,r)},Reader.prototype.string=function(){var e=this.bytes();return utf8$1.read(e,0,e.length)},Reader.prototype.skip=function(e){if("number"==typeof e){if(this.pos+e>this.len)throw indexOutOfRange(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw indexOutOfRange(this)}while(128&this.buf[this.pos++]);return this},Reader.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(e=7&this.uint32());)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+e+" at offset "+this.pos)}return this},Reader._configure=function(e){BufferReader=e;var t=minimal.Long?"toLong":"toNumber";minimal.merge(Reader.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader$1;function BufferReader$1(e){reader.call(this,e)}(BufferReader$1.prototype=Object.create(reader.prototype)).constructor=BufferReader$1,minimal.Buffer&&(BufferReader$1.prototype._slice=minimal.Buffer.prototype.slice),BufferReader$1.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len))};var service=Service;function Service(e,t,r){if("function"!=typeof e)throw TypeError("rpcImpl must be a function");minimal.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(r)}(Service.prototype=Object.create(minimal.EventEmitter.prototype)).constructor=Service,Service.prototype.rpcCall=function e(t,r,n,a,o){if(!a)throw TypeError("request must be specified");var i=this;if(!o)return minimal.asPromise(e,i,t,r,n,a);if(i.rpcImpl)try{return i.rpcImpl(t,r[i.requestDelimited?"encodeDelimited":"encode"](a).finish(),function(e,r){if(e)return i.emit("error",e,t),o(e);if(null!==r){if(!(r instanceof n))try{r=n[i.responseDelimited?"decodeDelimited":"decode"](r)}catch(e){return i.emit("error",e,t),o(e)}return i.emit("data",r,t),o(null,r)}i.end(!0)})}catch(e){return i.emit("error",e,t),void setTimeout(function(){o(e)},0)}else setTimeout(function(){o(Error("already ended"))},0)},Service.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this};var rpc_1=createCommonjsModule$1(function(e,t){t.Service=service}),roots={},indexMinimal=createCommonjsModule$1(function(e,t){var r=t;function n(){r.Reader._configure(r.BufferReader),r.util._configure()}r.build="minimal",r.Writer=writer,r.BufferWriter=writer_buffer,r.Reader=reader,r.BufferReader=reader_buffer,r.util=minimal,r.rpc=rpc_1,r.roots=roots,r.configure=n,r.Writer._configure(r.BufferWriter),n()}),minimal$1=indexMinimal,minimal_1=minimal$1.roots,minimal_2=minimal$1.Reader,minimal_3=minimal$1.util,$Reader=minimal$1.Reader,$util=minimal$1.util,$root=minimal$1.roots.default||(minimal$1.roots.default={});$root.tensorflow=function(){var e,t,r={};return r.Any=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.typeUrl=e.string();break;case 2:n.value=e.bytes();break;default:e.skipType(7&a)}}return n},e}(),r.DataType=(e={},(t=Object.create(e))[e[0]="DT_INVALID"]=0,t[e[1]="DT_FLOAT"]=1,t[e[2]="DT_DOUBLE"]=2,t[e[3]="DT_INT32"]=3,t[e[4]="DT_UINT8"]=4,t[e[5]="DT_INT16"]=5,t[e[6]="DT_INT8"]=6,t[e[7]="DT_STRING"]=7,t[e[8]="DT_COMPLEX64"]=8,t[e[9]="DT_INT64"]=9,t[e[10]="DT_BOOL"]=10,t[e[11]="DT_QINT8"]=11,t[e[12]="DT_QUINT8"]=12,t[e[13]="DT_QINT32"]=13,t[e[14]="DT_BFLOAT16"]=14,t[e[101]="DT_FLOAT_REF"]=101,t[e[102]="DT_DOUBLE_REF"]=102,t[e[103]="DT_INT32_REF"]=103,t[e[104]="DT_UINT8_REF"]=104,t[e[105]="DT_INT16_REF"]=105,t[e[106]="DT_INT8_REF"]=106,t[e[107]="DT_STRING_REF"]=107,t[e[108]="DT_COMPLEX64_REF"]=108,t[e[109]="DT_INT64_REF"]=109,t[e[110]="DT_BOOL_REF"]=110,t[e[111]="DT_QINT8_REF"]=111,t[e[112]="DT_QUINT8_REF"]=112,t[e[113]="DT_QINT32_REF"]=113,t[e[114]="DT_BFLOAT16_REF"]=114,t),r.TensorShape=function(){function e(e){if(this.dim=[],e)for(var t=Object.keys(e),r=0;r>>3){case 2:n.dim&&n.dim.length||(n.dim=[]),n.dim.push($root.tensorflow.TensorShape.Dim.decode(e,e.uint32()));break;case 3:n.unknownRank=e.bool();break;default:e.skipType(7&a)}}return n},e.Dim=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.size=e.int64();break;case 2:n.name=e.string();break;default:e.skipType(7&a)}}return n},e}(),e}(),r.Tensor=function(){function e(e){if(this.floatVal=[],this.doubleVal=[],this.intVal=[],this.stringVal=[],this.scomplexVal=[],this.int64Val=[],this.boolVal=[],this.uint32Val=[],this.uint64Val=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.dtype=e.int32();break;case 2:n.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 3:n.versionNumber=e.int32();break;case 4:n.tensorContent=e.bytes();break;case 5:if(n.floatVal&&n.floatVal.length||(n.floatVal=[]),2==(7&a))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.list=$root.tensorflow.AttrValue.ListValue.decode(e,e.uint32());break;case 2:n.s=e.bytes();break;case 3:n.i=e.int64();break;case 4:n.f=e.float();break;case 5:n.b=e.bool();break;case 6:n.type=e.int32();break;case 7:n.shape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 8:n.tensor=$root.tensorflow.Tensor.decode(e,e.uint32());break;case 9:n.placeholder=e.string();break;case 10:n.func=$root.tensorflow.NameAttrList.decode(e,e.uint32());break;default:e.skipType(7&a)}}return n},e.ListValue=function(){function e(e){if(this.s=[],this.i=[],this.f=[],this.b=[],this.type=[],this.shape=[],this.tensor=[],this.func=[],e)for(var t=Object.keys(e),r=0;r>>3){case 2:n.s&&n.s.length||(n.s=[]),n.s.push(e.bytes());break;case 3:if(n.i&&n.i.length||(n.i=[]),2==(7&a))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:a.name=e.string();break;case 2:e.skip().pos++,a.attr===$util.emptyObject&&(a.attr={}),r=e.string(),e.pos++,a.attr[r]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return a},e}(),r.NodeDef=function(){function e(e){if(this.input=[],this.attr={},e)for(var t=Object.keys(e),r=0;r>>3){case 1:a.name=e.string();break;case 2:a.op=e.string();break;case 3:a.input&&a.input.length||(a.input=[]),a.input.push(e.string());break;case 4:a.device=e.string();break;case 5:e.skip().pos++,a.attr===$util.emptyObject&&(a.attr={}),r=e.string(),e.pos++,a.attr[r]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return a},e}(),r.VersionDef=function(){function e(e){if(this.badConsumers=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.producer=e.int32();break;case 2:n.minConsumer=e.int32();break;case 3:if(n.badConsumers&&n.badConsumers.length||(n.badConsumers=[]),2==(7&a))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.node&&n.node.length||(n.node=[]),n.node.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:n.versions=$root.tensorflow.VersionDef.decode(e,e.uint32());break;case 2:n.library=$root.tensorflow.FunctionDefLibrary.decode(e,e.uint32());break;default:e.skipType(7&a)}}return n},e}(),r.CollectionDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.nodeList=$root.tensorflow.CollectionDef.NodeList.decode(e,e.uint32());break;case 2:n.bytesList=$root.tensorflow.CollectionDef.BytesList.decode(e,e.uint32());break;case 3:n.int64List=$root.tensorflow.CollectionDef.Int64List.decode(e,e.uint32());break;case 4:n.floatList=$root.tensorflow.CollectionDef.FloatList.decode(e,e.uint32());break;case 5:n.anyList=$root.tensorflow.CollectionDef.AnyList.decode(e,e.uint32());break;default:e.skipType(7&a)}}return n},e.NodeList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.value&&n.value.length||(n.value=[]),n.value.push(e.string());break;default:e.skipType(7&a)}}return n},e}(),e.BytesList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.value&&n.value.length||(n.value=[]),n.value.push(e.bytes());break;default:e.skipType(7&a)}}return n},e}(),e.Int64List=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:if(n.value&&n.value.length||(n.value=[]),2==(7&a))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:if(n.value&&n.value.length||(n.value=[]),2==(7&a))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.value&&n.value.length||(n.value=[]),n.value.push($root.tensorflow.Any.decode(e,e.uint32()));break;default:e.skipType(7&a)}}return n},e}(),e}(),r.SaverDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.filenameTensorName=e.string();break;case 2:n.saveTensorName=e.string();break;case 3:n.restoreOpName=e.string();break;case 4:n.maxToKeep=e.int32();break;case 5:n.sharded=e.bool();break;case 6:n.keepCheckpointEveryNHours=e.float();break;case 7:n.version=e.int32();break;default:e.skipType(7&a)}}return n},e.CheckpointFormatVersion=(t={},(r=Object.create(t))[t[0]="LEGACY"]=0,r[t[1]="V1"]=1,r[t[2]="V2"]=2,r),e}(),r.TensorInfo=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.name=e.string();break;case 4:n.cooSparse=$root.tensorflow.TensorInfo.CooSparse.decode(e,e.uint32());break;case 2:n.dtype=e.int32();break;case 3:n.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;default:e.skipType(7&a)}}return n},e.CooSparse=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.valuesTensorName=e.string();break;case 2:n.indicesTensorName=e.string();break;case 3:n.denseShapeTensorName=e.string();break;default:e.skipType(7&a)}}return n},e}(),e}(),r.SignatureDef=function(){function e(e){if(this.inputs={},this.outputs={},e)for(var t=Object.keys(e),r=0;r>>3){case 1:e.skip().pos++,a.inputs===$util.emptyObject&&(a.inputs={}),r=e.string(),e.pos++,a.inputs[r]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:e.skip().pos++,a.outputs===$util.emptyObject&&(a.outputs={}),r=e.string(),e.pos++,a.outputs[r]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 3:a.methodName=e.string();break;default:e.skipType(7&o)}}return a},e}(),r.AssetFileDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.tensorInfo=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:n.filename=e.string();break;default:e.skipType(7&a)}}return n},e}(),r.OpDef=function(){function e(e){if(this.inputArg=[],this.outputArg=[],this.attr=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.name=e.string();break;case 2:n.inputArg&&n.inputArg.length||(n.inputArg=[]),n.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 3:n.outputArg&&n.outputArg.length||(n.outputArg=[]),n.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 4:n.attr&&n.attr.length||(n.attr=[]),n.attr.push($root.tensorflow.OpDef.AttrDef.decode(e,e.uint32()));break;case 8:n.deprecation=$root.tensorflow.OpDef.OpDeprecation.decode(e,e.uint32());break;case 5:n.summary=e.string();break;case 6:n.description=e.string();break;case 18:n.isCommutative=e.bool();break;case 16:n.isAggregate=e.bool();break;case 17:n.isStateful=e.bool();break;case 19:n.allowsUninitializedInput=e.bool();break;default:e.skipType(7&a)}}return n},e.ArgDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.name=e.string();break;case 2:n.description=e.string();break;case 3:n.type=e.int32();break;case 4:n.typeAttr=e.string();break;case 5:n.numberAttr=e.string();break;case 6:n.typeListAttr=e.string();break;case 16:n.isRef=e.bool();break;default:e.skipType(7&a)}}return n},e}(),e.AttrDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.name=e.string();break;case 2:n.type=e.string();break;case 3:n.defaultValue=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 4:n.description=e.string();break;case 5:n.hasMinimum=e.bool();break;case 6:n.minimum=e.int64();break;case 7:n.allowedValues=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&a)}}return n},e}(),e.OpDeprecation=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.version=e.int32();break;case 2:n.explanation=e.string();break;default:e.skipType(7&a)}}return n},e}(),e}(),r.OpList=function(){function e(e){if(this.op=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.op&&n.op.length||(n.op=[]),n.op.push($root.tensorflow.OpDef.decode(e,e.uint32()));break;default:e.skipType(7&a)}}return n},e}(),r.MetaGraphDef=function(){function e(e){if(this.collectionDef={},this.signatureDef={},this.assetFileDef=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:a.metaInfoDef=$root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e,e.uint32());break;case 2:a.graphDef=$root.tensorflow.GraphDef.decode(e,e.uint32());break;case 3:a.saverDef=$root.tensorflow.SaverDef.decode(e,e.uint32());break;case 4:e.skip().pos++,a.collectionDef===$util.emptyObject&&(a.collectionDef={}),r=e.string(),e.pos++,a.collectionDef[r]=$root.tensorflow.CollectionDef.decode(e,e.uint32());break;case 5:e.skip().pos++,a.signatureDef===$util.emptyObject&&(a.signatureDef={}),r=e.string(),e.pos++,a.signatureDef[r]=$root.tensorflow.SignatureDef.decode(e,e.uint32());break;case 6:a.assetFileDef&&a.assetFileDef.length||(a.assetFileDef=[]),a.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return a},e.MetaInfoDef=function(){function e(e){if(this.tags=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.metaGraphVersion=e.string();break;case 2:n.strippedOpList=$root.tensorflow.OpList.decode(e,e.uint32());break;case 3:n.anyInfo=$root.tensorflow.Any.decode(e,e.uint32());break;case 4:n.tags&&n.tags.length||(n.tags=[]),n.tags.push(e.string());break;case 5:n.tensorflowVersion=e.string();break;case 6:n.tensorflowGitVersion=e.string();break;default:e.skipType(7&a)}}return n},e}(),e}(),r.SavedModel=function(){function e(e){if(this.metaGraphs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.savedModelSchemaVersion=e.int64();break;case 2:n.metaGraphs&&n.metaGraphs.length||(n.metaGraphs=[]),n.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e,e.uint32()));break;default:e.skipType(7&a)}}return n},e}(),r.FunctionDefLibrary=function(){function e(e){if(this.function=[],this.gradient=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.function&&n.function.length||(n.function=[]),n.function.push($root.tensorflow.FunctionDef.decode(e,e.uint32()));break;case 2:n.gradient&&n.gradient.length||(n.gradient=[]),n.gradient.push($root.tensorflow.GradientDef.decode(e,e.uint32()));break;default:e.skipType(7&a)}}return n},e}(),r.FunctionDef=function(){function e(e){if(this.attr={},this.nodeDef=[],this.ret={},e)for(var t=Object.keys(e),r=0;r>>3){case 1:a.signature=$root.tensorflow.OpDef.decode(e,e.uint32());break;case 5:e.skip().pos++,a.attr===$util.emptyObject&&(a.attr={}),r=e.string(),e.pos++,a.attr[r]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 3:a.nodeDef&&a.nodeDef.length||(a.nodeDef=[]),a.nodeDef.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:e.skip().pos++,a.ret===$util.emptyObject&&(a.ret={}),r=e.string(),e.pos++,a.ret[r]=e.string();break;default:e.skipType(7&o)}}return a},e}(),r.GradientDef=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.functionName=e.string();break;case 2:n.gradientFunc=e.string();break;default:e.skipType(7&a)}}return n},e}(),r}();var compiled_api=$root,compiled_api_1=compiled_api.tensorflow;function getParamValue(e,t,r,n){var a=t.params[e];if(a&&void 0!==a.inputIndex){if("tensor"===a.type)return getTensor(t.inputNames[a.inputIndex],r,n);if("tensors"===a.type)return(0===a.inputIndex?0===a.inputParamLength?t.inputNames:t.inputNames.slice(a.inputIndex,-a.inputParamLength):t.inputNames.splice(a.inputIndex)).map(function(e){return getTensor(e,r,n)});var o=Array.prototype.slice.call(getTensor(t.inputNames.slice(a.inputIndex)[0],r,n).dataSync());return"number"===a.type?o[0]:o}return a&&a.value}function getTensor(e,t,r){var n=parseNodeName(e),a=n[0],o=n[1],i=r.currentContextIds.find(function(e){return!!t[getNodeNameWithContextId(a,e)]});return void 0!==i?t[getNodeNameWithContextId(a,i)][o]:void 0}function getNodeNameAndIndex(e,t){var r=parseNodeName(e),n=r[0],a=r[1];return[getNodeNameWithContextId(n,t&&t.currentContextId),a]}function getNodeNameWithContextId(e,t){return t?e+"-"+t:e}function parseNodeName(e){var t=e.lastIndexOf(":");return-1===t?[e,0]:[e.substring(0,t),Number(e.substring(t+1))]}function split$1(e,t){for(var r=[],n=0;n=this.tensors.length)throw new Error("Tried to read from index "+e+", but array size is: "+this.tensors.length);var t=this.tensors[e];if(t.cleared)throw new Error("TensorArray "+this.name+": Could not read index "+e+" twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).");return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor},e.prototype.readMany=function(e){var t=this;return e.map(function(e){return t.read(e)})},e.prototype.write=function(e,t){if(this.closed_)throw new Error("TensorArray "+this.name+" has already been closed.");if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error("Tried to write to index "+e+", but array is not resizeable and size is: "+this.maxSize);var r=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+",\n because the value dtype is "+t.dtype+", but TensorArray dtype is "+this.dtype+".");if(0===this.size()&&0===this.elementShape.length&&(this.elementShape=t.shape),util.assertShapesMatch(this.elementShape,t.shape,"TensorArray "+this.name+": Could not write to TensorArray index "+e+"."),r&&r.read)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been read.");if(r&&r.written)throw new Error("TensorArray "+this.name+": Could not write to TensorArray index "+e+", because it has already been written.");r.tensor=t,r.written=!0,this.tensors[e]=r},e.prototype.writeMany=function(e,t){var r=this;if(e.length!==t.length)throw new Error("TensorArray "+this.name+": could not write multiple tensors,because the index size: "+e.length+" is not the same as tensors size: "+t.length+".");e.map(function(e,n){return r.write(e,t[n])})},e.prototype.gather=function(e,t){if(t&&t!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but gather requested dtype "+t);if(!e){e=[];for(var r=0;r=this.maxSize)throw new Error("Max index must be < array size ("+r+" vs. "+this.maxSize+")");this.writeMany(e,unstack(t,0))},e.prototype.split=function(e,t){var r=this;if(t.dtype!==this.dtype)throw new Error("TensorArray dtype is "+this.dtype+" but tensor has dtype "+t.dtype);var n=0,a=e.map(function(e){return n+=e});if(n!==t.shape[0])throw new Error("Expected sum of lengths to be equal to\n tensor.shape[0], but sum of lengths is\n "+n+", and tensor's shape is: "+t.shape);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error("TensorArray's size is not equal to the size of lengths ("+this.maxSize+" vs. "+e.length+"), and the TensorArray is not marked as dynamically resizeable");var o=0===n?0:t.size/n,i=[];tidy(function(){t=t.reshape([1,n,o]);for(var s=0;s1)for(var f=1;f1))throw new Error("Cannot exit frame, the context is empty");this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift()},e.prototype.nextIteration=function(){if(!(this.contexts&&this.contexts.length>0))throw new Error("Cannot increase frame iteration, the context is empty");this.contexts=this.contexts.slice(),this.lastId++;var e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))},e.prototype.getWeight=function(e){return this.weightMap[e]},e.prototype.addTensorArray=function(e){this.tensorArrayMap[e.id]=e},e.prototype.getTensorArray=function(e){return this.tensorArrayMap[e]},e}(),GraphExecutor=function(){function e(e){this.graph=e,this.compiledOrder=[],this._weightMap={},this.placeholders=e.placeholders,this._outputs=e.outputs,this.compile()}return Object.defineProperty(e.prototype,"weightMap",{get:function(){return this._weightMap},set:function(e){var t=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})});this.weightIds=[].concat.apply([],t),this._weightMap=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.placeholders.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this._outputs.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.placeholders.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.outputs.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isControlFlowModel",{get:function(){return this.graph.withControlFlow},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isDynamicShapeModel",{get:function(){return this.graph.withDynamicShape},enumerable:!0,configurable:!0}),e.prototype.compile=function(){if(!this.graph.withControlFlow&&!this.graph.withDynamicShape)for(var e=this.graph.inputs.slice(),t={};e.length>0;){var r=e.pop();t[r.name]=!0,this.compiledOrder.push(r),r.children.forEach(function(r){!t[r.name]&&r.inputNames.every(function(e){var r=getNodeNameAndIndex(e)[0];return t[r]})&&e.push(r)})}},e.prototype.execute=function(e,t){var r=this;this.checkInput(e),this.checkInputShapeAndType(e);var n={};return tidy(function(){var a=new ExecutionContext(r._weightMap,n),o=r.compiledOrder.reduce(function(e,t){return e[t.name]=executeOp$15(t,e,a),e},__assign$2({},r.weightMap,e));return r.findOutputs(o,a,t)})},e.prototype.executeAsync=function(e,t){return __awaiter$2(this,void 0,void 0,function(){var r,n,a,o,i,s,u,l=this;return __generator$2(this,function(p){switch(p.label){case 0:return this.checkInput(e),this.checkInputShapeAndType(e),r={},n=new ExecutionContext(this._weightMap,r),[4,this.executeWithControlFlow(e,n)];case 1:return a=p.sent(),o=this.findOutputs(a,n,t),i=Object.keys(o).map(function(e){return o[e].id}),s=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})}),u=[].concat.apply([],s),Object.keys(a).forEach(function(e){a[e].forEach(function(e){e&&-1===i.indexOf(e.id)&&-1===u.indexOf(e.id)&&-1===l.weightIds.indexOf(e.id)&&e.dispose()})}),[2,o]}})})},e.prototype.executeWithControlFlow=function(e,t){return __awaiter$2(this,void 0,void 0,function(){var r,n,a,o,i,s,u,l;return __generator$2(this,function(p){switch(p.label){case 0:r=this.graph.inputs.map(function(e){return{node:e,contexts:t.currentContext}}),n=__assign$2({},this.weightMap,e),a={},p.label=1;case 1:return r.length>0?(o=r.pop(),t.currentContext=o.contexts,i="","enter"===o.node.op&&getParamValue("isConstant",o.node,n,t)&&(i=getNodeNameAndIndex(o.node.name,t)[0]),s=executeOp$15(o.node,n,t),i||(i=getNodeNameAndIndex(o.node.name,t)[0]),u=n,l=i,[4,s]):[3,3];case 2:return u[l]=p.sent(),o.node.children.forEach(function(e){var o=getNodeNameAndIndex(e.name,t)[0];a[o]||("merge"===e.op?e.inputNames.some(function(e){return!!getTensor(e,n,t)})&&(a[o]=!0,r.push({contexts:t.currentContext,node:e})):e.inputNames.every(function(e){return!!getTensor(e,n,t)})&&(a[o]=!0,r.push({contexts:t.currentContext,node:e})))}),[3,1];case 3:return[2,n]}})})},e.prototype.findOutputs=function(e,t,r){return!r||r instanceof Array||(r=[r]),(r||this.graph.outputs.map(function(e){return e.name})).reduce(function(r,n){return r[n]=getTensor(n,e,t),r},{})},e.prototype.dispose=function(){var e=this;Object.keys(this.weightMap).forEach(function(t){return e.weightMap[t].forEach(function(e){return e.dispose()})})},e.prototype.checkInputShapeAndType=function(e){this.placeholders.forEach(function(t){var r=e[t.name][0];if(t.params.shape&&t.params.shape.value){var n=t.params.shape.value,a=n.length===r.shape.length&&r.shape.every(function(e,t){return-1===n[t]||n[t]===e});util.assert(a,"The shape of dict['"+t.name+"'] provided in model.execute(dict) must be ["+n+"], but was ["+r.shape+"]")}t.params.dtype&&t.params.dtype.value&&util.assert(r.dtype===t.params.dtype.value,"The dtype of dict['"+t.name+"'] provided in model.execute(dict) must be "+t.params.dtype.value+", but was "+r.dtype)})},e.prototype.checkInput=function(e){var t=this,r=Object.keys(e),n=[],a=[];if(this.inputNodes.forEach(function(e){-1===r.indexOf(e)&&n.push(e)}),r.forEach(function(e){-1===t.inputNodes.indexOf(e)&&a.push(e)}),n.length>0)throw new Error("The dict provided in model.execute(dict) has the keys ["+r+"], but is missing the required keys: ["+n+"].");if(a.length>0)throw new Error("The dict provided in model.execute(dict) has unused keys: ["+a+"]. Please provide only the following keys: ["+this.inputNodes+"].")},e}(),FrozenModel=function(){function e(e,t,r){this.modelUrl=e,this.weightManifestUrl=t,this.requestOption=r,this.version="n/a",this.pathPrefix=this.getPathPrefix()}return Object.defineProperty(e.prototype,"modelVersion",{get:function(){return this.version},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputNodes",{get:function(){return this.executor.inputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputNodes",{get:function(){return this.executor.outputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputs",{get:function(){return this.executor.inputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"outputs",{get:function(){return this.executor.outputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"weights",{get:function(){return this.executor.weightMap},enumerable:!0,configurable:!0}),e.prototype.getPathPrefix=function(){var e=parse(this.weightManifestUrl),t=e.pathname.split("/");return t.splice(-1),e.pathname=t.join("/"),format(e)+"/"},e.prototype.loadRemoteProtoFile=function(){return __awaiter$2(this,void 0,void 0,function(){var e,t,r,n,a;return __generator$2(this,function(o){switch(o.label){case 0:return o.trys.push([0,3,,4]),[4,fetch(this.modelUrl,this.requestOption)];case 1:return e=o.sent(),r=(t=compiled_api_1.GraphDef).decode,n=Uint8Array.bind,[4,e.arrayBuffer()];case 2:return[2,r.apply(t,[new(n.apply(Uint8Array,[void 0,o.sent()]))])];case 3:throw a=o.sent(),new Error(this.modelUrl+" not found. "+a);case 4:return[2]}})})},e.prototype.loadWeightManifest=function(){return __awaiter$2(this,void 0,void 0,function(){var e,t,r;return __generator$2(this,function(n){switch(n.label){case 0:return n.trys.push([0,3,,4]),[4,fetch(this.weightManifestUrl,this.requestOption)];case 1:return e=n.sent(),t=this,[4,e.clone().json()];case 2:return t.weightManifest=n.sent(),[3,4];case 3:throw r=n.sent(),new Error(this.weightManifestUrl+" not found. "+r);case 4:return[2]}})})},e.prototype.load=function(){return __awaiter$2(this,void 0,void 0,function(){var e,t,r,n;return __generator$2(this,function(a){switch(a.label){case 0:return e=this.loadRemoteProtoFile(),t=this.loadWeightManifest(),[4,Promise.all([e,t])];case 1:return r=a.sent()[0],this.version=r.versions.producer+"."+r.versions.minConsumer,[4,io.loadWeights(this.weightManifest,this.pathPrefix,void 0,this.requestOption)];case 2:return n=a.sent(),this.executor=new GraphExecutor(OperationMapper.Instance.transformGraph(r)),this.executor.weightMap=this.convertTensorMapToTensorsMap(n),[2,!0]}})})},e.prototype.predict=function(e,t){return this.execute(e,this.outputNodes)},e.prototype.constructTensorMap=function(e){var t=e instanceof Tensor?[e]:e;if(t.length!==this.inputNodes.length)throw new Error("Input tensor count mismatch,the frozen model has "+this.inputNodes.length+" placeholders, while there are "+t.length+" input tensors.");return this.inputNodes.reduce(function(e,r,n){return e[r]=t[n],e},{})},e.prototype.execute=function(e,t){if(t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),this.executor.isControlFlowModel||this.executor.isDynamicShapeModel)throw new Error("The model contains control flow or dynamic shape ops, please use executeAsync method");var r=this.executor.execute(this.convertTensorMapToTensorsMap(e),t),n=Object.keys(r);return Array.isArray(t)&&t.length>1?t.map(function(e){return r[e]}):r[n[0]]},e.prototype.executeAsync=function(e,t){return __awaiter$2(this,void 0,void 0,function(){var r,n;return __generator$2(this,function(a){switch(a.label){case 0:if(!this.executor.isControlFlowModel||!this.executor.isDynamicShapeModel)throw new Error("The model does not contain control flow or dynamic shape ops, please use execute method for better performance.");return t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),[4,this.executor.executeAsync(this.convertTensorMapToTensorsMap(e),t)];case 1:return r=a.sent(),n=Object.keys(r),[2,Array.isArray(t)&&t.length>1?t.map(function(e){return r[e]}):r[n[0]]]}})})},e.prototype.convertTensorMapToTensorsMap=function(e){return Object.keys(e).reduce(function(t,r){return t[r]=[e[r]],t},{})},e.prototype.dispose=function(){this.executor.dispose()},e}();function loadFrozenModel(e,t,r){return __awaiter$2(this,void 0,void 0,function(){var n;return __generator$2(this,function(a){switch(a.label){case 0:return[4,(n=new FrozenModel(e,t,r)).load()];case 1:return a.sent(),[2,n]}})})}var version$2="0.5.5",version$3="0.12.4",version$4={"tfjs-core":version,"tfjs-layers":version$1,"tfjs-converter":version$2,tfjs:version$3};exports.version=version$4,exports.setBackend=setBackend,exports.getBackend=getBackend,exports.disposeVariables=disposeVariables,exports.memory=memory,exports.version_core=version,exports.nextFrame=nextFrame,exports.environment=environment,exports.io=io,exports.serialization=serialization,exports.test_util=test_util,exports.util=util,exports.webgl=webgl,exports.AdadeltaOptimizer=AdadeltaOptimizer,exports.AdagradOptimizer=AdagradOptimizer,exports.AdamOptimizer=AdamOptimizer,exports.AdamaxOptimizer=AdamaxOptimizer,exports.MomentumOptimizer=MomentumOptimizer,exports.Optimizer=Optimizer,exports.RMSPropOptimizer=RMSPropOptimizer,exports.SGDOptimizer=SGDOptimizer,exports.Tensor=Tensor,exports.TensorBuffer=TensorBuffer,exports.variable=variable,exports.Variable=Variable,exports.ENV=ENV,exports.Environment=Environment,exports.image=image_ops,exports.linalg=linalg_ops,exports.losses=loss_ops,exports.op=op,exports.batchNormalization2d=batchNormalization2d,exports.batchNormalization3d=batchNormalization3d,exports.batchNormalization4d=batchNormalization4d,exports.batchNormalization=batchNormalization,exports.concat=concat,exports.concat1d=concat1d,exports.concat2d=concat2d,exports.concat3d=concat3d,exports.concat4d=concat4d,exports.conv1d=conv1d,exports.conv2d=conv2d,exports.depthwiseConv2d=depthwiseConv2d,exports.separableConv2d=separableConv2d,exports.conv2dTranspose=conv2dTranspose,exports.matMul=matMul,exports.dot=dot,exports.outerProduct=outerProduct,exports.reverse=reverse,exports.reverse1d=reverse1d,exports.reverse2d=reverse2d,exports.reverse3d=reverse3d,exports.reverse4d=reverse4d,exports.maxPool=maxPool,exports.avgPool=avgPool,exports.slice=slice,exports.slice1d=slice1d,exports.slice2d=slice2d,exports.slice3d=slice3d,exports.slice4d=slice4d,exports.abs=abs,exports.acos=acos,exports.acosh=acosh,exports.asin=asin,exports.asinh=asinh,exports.atan=atan,exports.atanh=atanh,exports.ceil=ceil,exports.clipByValue=clipByValue,exports.cos=cos,exports.cosh=cosh,exports.erf=erf,exports.exp=exp,exports.expm1=expm1,exports.floor=floor,exports.log=log$1,exports.log1p=log1p,exports.logSigmoid=logSigmoid,exports.neg=neg,exports.reciprocal=reciprocal,exports.round=round,exports.rsqrt=rsqrt,exports.sigmoid=sigmoid,exports.sign=sign,exports.sin=sin,exports.sinh=sinh,exports.softplus=softplus,exports.sqrt=sqrt,exports.square=square,exports.step=step,exports.tan=tan,exports.tanh=tanh$1,exports.all=all,exports.any=any,exports.argMax=argMax,exports.argMin=argMin,exports.logSumExp=logSumExp,exports.max=max,exports.mean=mean,exports.min=min,exports.moments=moments,exports.sum=sum,exports.equal=equal,exports.equalStrict=equalStrict,exports.greater=greater,exports.greaterEqual=greaterEqual,exports.greaterEqualStrict=greaterEqualStrict,exports.greaterStrict=greaterStrict,exports.less=less,exports.lessEqual=lessEqual,exports.lessEqualStrict=lessEqualStrict,exports.lessStrict=lessStrict,exports.notEqual=notEqual,exports.notEqualStrict=notEqualStrict,exports.add=add,exports.addN=addN,exports.addStrict=addStrict,exports.atan2=atan2,exports.div=div,exports.divStrict=divStrict,exports.floorDiv=floorDiv,exports.maximum=maximum,exports.maximumStrict=maximumStrict,exports.minimum=minimum,exports.minimumStrict=minimumStrict,exports.mod=mod,exports.modStrict=modStrict,exports.mul=mul,exports.mulStrict=mulStrict,exports.pow=pow,exports.powStrict=powStrict,exports.squaredDifference=squaredDifference,exports.squaredDifferenceStrict=squaredDifferenceStrict,exports.sub=sub,exports.subStrict=subStrict,exports.elu=elu,exports.leakyRelu=leakyRelu,exports.prelu=prelu,exports.relu=relu,exports.selu=selu,exports.logicalAnd=logicalAnd,exports.logicalNot=logicalNot,exports.logicalOr=logicalOr,exports.logicalXor=logicalXor,exports.where=where,exports.whereAsync=whereAsync,exports.buffer=buffer,exports.toPixels=toPixels,exports.print=print,exports.cast=cast,exports.clone=clone,exports.cumsum=cumsum,exports.expandDims=expandDims,exports.eye=eye,exports.fromPixels=fromPixels,exports.multinomial=multinomial,exports.oneHot=oneHot,exports.pad=pad,exports.pad1d=pad1d,exports.pad2d=pad2d,exports.pad3d=pad3d,exports.pad4d=pad4d,exports.rand=rand,exports.randomNormal=randomNormal,exports.randomUniform=randomUniform,exports.reshape=reshape,exports.split=split,exports.squeeze=squeeze,exports.stack=stack,exports.tile=tile,exports.truncatedNormal=truncatedNormal,exports.unstack=unstack,exports.batchToSpaceND=batchToSpaceND,exports.spaceToBatchND=spaceToBatchND,exports.fill=fill,exports.linspace=linspace,exports.ones=ones$1,exports.range=range,exports.scalar=scalar,exports.tensor=tensor,exports.tensor1d=tensor1d,exports.tensor2d=tensor2d,exports.tensor3d=tensor3d,exports.tensor4d=tensor4d,exports.tensor5d=tensor5d,exports.tensor6d=tensor6d,exports.zeros=zeros,exports.onesLike=onesLike,exports.zerosLike=zerosLike,exports.transpose=transpose,exports.softmax=softmax,exports.localResponseNormalization=localResponseNormalization,exports.norm=norm,exports.gather=gather,exports.unsortedSegmentSum=unsortedSegmentSum,exports.basicLSTMCell=basicLSTMCell,exports.multiRNNCell=multiRNNCell,exports.movingAverage=movingAverage,exports.stridedSlice=stridedSlice,exports.topk=topk,exports.train=train,exports.tidy=tidy,exports.keep=keep,exports.dispose=dispose,exports.time=time,exports.customGrad=customGrad,exports.grad=grad,exports.grads=grads,exports.valueAndGrad=valueAndGrad,exports.valueAndGrads=valueAndGrads,exports.variableGrads=variableGrads,exports.constraints=exports_constraints,exports.initializers=exports_initializers,exports.layers=exports_layers,exports.metrics=exports_metrics,exports.regularizers=exports_regularizers,exports.CallbackList=CallbackList,exports.CustomCallback=CustomCallback,exports.Callback=Callback,exports.SymbolicTensor=SymbolicTensor,exports.Model=Model,exports.input=input,exports.loadModel=loadModel,exports.model=model,exports.sequential=sequential,exports.RNN=RNN,exports.Sequential=Sequential,exports.LayerVariable=LayerVariable,exports.version_layers=version$1,exports.FrozenModel=FrozenModel,exports.loadFrozenModel=loadFrozenModel,exports.version_converter=version$2,Object.defineProperty(exports,"__esModule",{value:!0})}); +//# sourceMappingURL=tf.min.js.map diff --git a/node_modules/@tensorflow/tfjs/dist/tf.min.js.map b/node_modules/@tensorflow/tfjs/dist/tf.min.js.map new file mode 100644 index 0000000..3893c32 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/tf.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tf.min.js","sources":["../node_modules/@tensorflow/tfjs-core/dist/tf-core.esm.js","../node_modules/@tensorflow/tfjs-layers/dist/tf-layers.esm.js","../node_modules/@tensorflow/tfjs-converter/dist/tf-converter.esm.js","../src/version.ts","../src/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nvar extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])&&(6===a[0]||2===a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]0;)r=Math.random()*t|0,n=e[--t],e[t]=e[r],e[r]=n}function clamp(e,t,n){return Math.max(e,Math.min(t,n))}function randUniform(e,t){return Math.random()*(t-e)+e}function distSquared(e,t){for(var n=0,r=0;r0,function(){return\"Element arr[\"+n.join(\"][\")+\"] should be a primitive, but is an array of \"+e.length+\" elements\"}),assert(e.length===t[0],function(){return\"Element arr[\"+n.join(\"][\")+\"] should have \"+t[0]+\" elements, but has \"+e.length+\" elements\"});for(var r=t.slice(1),o=0;o1;--t)if(e%t==0)return[t,e/t];return[1,e]}function createShuffledIndices(e){for(var t=new Uint32Array(e),n=0;n=n?o():setTimeout(i,s)}};i()})}function inferFromImplicitShape(e,t){for(var n=1,r=-1,o=0;o0)n*=e[o];else if(-1===e[o]){if(-1!==r)throw Error(\"Shapes can only have 1 implicit size. Found - 1 at dim \"+r+\" and dim \"+o);r=o}else if(e[o]<=0)throw Error(\"Shapes can not be <= 0. Found \"+e[o]+\" at dim \"+o);if(-1===r){if(t>0&&t!==n)throw Error(\"Size(\"+t+\") must match the product of shape \"+e);return e}if(t%n!=0)throw Error(\"The implicit shape can't be a fractional number. Got \"+t+\" / \"+n);var a=e.slice();return a[r]=t/n,a}function squeezeShape(e,t){for(var n=[],r=[],o=0,a=0;a1)throw new Error(\"Can't squeeze axis \"+a+\" since its dim '\"+e[a]+\"' is not 1\");(null==t[o]||t[o]>a)&&1===e[a]&&(n.push(e[a]),r.push(a)),t[o]<=a&&o++}e[a]>1&&(n.push(e[a]),r.push(a))}return{newShape:n,keptDims:r}}function getTypedArrayFromDType(e,t){var n=null;if(null==e||\"float32\"===e)n=new Float32Array(t);else if(\"int32\"===e)n=new Int32Array(t);else{if(\"bool\"!==e)throw new Error(\"Unknown data type \"+e);n=new Uint8Array(t)}return n}function checkComputationForNaN(e,t,n){if(\"float32\"===t)for(var r=0;r=0;--r)n[r]=n[r+1]*e[r+1];return n}function toTypedArray(e,t,n){return noConversionNeeded(e,t)?e:(Array.isArray(e)&&(e=flatten(e)),copyTypedArray(e,t,n))}function noConversionNeeded(e,t){return e instanceof Float32Array&&\"float32\"===t||e instanceof Int32Array&&\"int32\"===t||e instanceof Uint8Array&&\"bool\"===t}function makeOnesTypedArray(e,t){for(var n=makeZerosTypedArray(e,t),r=0;r=0;a--){i=(m=e[a]).inputs;var h=[];h.push(m.output);for(c=0;c=0;n--){var r=t[n],o=e[r.output.id];if(null==r.gradient)throw new Error(\"Cannot compute gradient: gradient function not found for \"+r.name+\".\");var a=r.gradient(o);for(var i in r.inputs){if(!(i in a))throw new Error(\"Cannot backprop through input \"+i+\". Available gradients found: \"+Object.keys(a)+\".\");var s=a[i](),u=r.inputs[i];if(!arraysEqual(s.shape,u.shape))throw new Error(\"Error in gradient for op \"+r.name+\". The gradient of input '\"+i+\"' has shape '\"+s.shape+\"', which does not match the shape of the input '\"+u.shape+\"'\");if(null==e[u.id])e[u.id]=s;else{var l=e[u.id];e[u.id]=l.add(s),l.dispose()}}}}var FORMAT_LIMIT_NUM_VALS=20,FORMAT_NUM_FIRST_LAST_VALS=3,FORMAT_NUM_SIG_DIGITS=7;function tensorToString(e,t,n,r){var o=computeStrides(t),a=computeMaxSizePerColumn(e,t,o),i=t.length,s=subTensorToString(e,t,o,a),u=[\"Tensor\"];return r&&(u.push(\" dtype: \"+n),u.push(\" rank: \"+i),u.push(\" shape: [\"+t+\"]\"),u.push(\" values:\")),u.push(s.map(function(e){return\" \"+e}).join(\"\\n\")),u.join(\"\\n\")}function computeMaxSizePerColumn(e,t,n){var r=sizeFromShape(t),o=n[n.length-1],a=new Array(o).fill(0);if(t.length>1)for(var i=0;iFORMAT_LIMIT_NUM_VALS){var s=Array.from(e.subarray(0,FORMAT_NUM_FIRST_LAST_VALS)),u=Array.from(e.subarray(a-FORMAT_NUM_FIRST_LAST_VALS,a));return[\"[\"+s.map(function(e,t){return valToString(e,r[t])}).join(\", \")+\", ..., \"+u.map(function(e,t){return valToString(e,r[a-FORMAT_NUM_FIRST_LAST_VALS+t])}).join(\", \")+\"]\"]}return[\"[\"+Array.from(e).map(function(e,t){return valToString(e,r[t])}).join(\", \")+\"]\"]}var l=t.slice(1),c=n.slice(1),p=n[0],d=[];if(a>FORMAT_LIMIT_NUM_VALS){for(var h=0;h {...}) to avoid memory leaks.\");return this.keepTensors.add(e.id),e},e.prototype.startScope=function(e,t){void 0===t&&(t=!1),t&&0===this.gradientScopeCount&&(this.activeTape=[]),t&&this.gradientScopeCount++;var n={track:[],name:\"unnamed scope\"};e&&(n.name=e),this.scopeStack.push(n),this.activeScope=n},e.prototype.endScope=function(e,t){var n=this;void 0===t&&(t=!1),t&&(this.gradientScopeCount--,0===this.gradientScopeCount&&(this.activeTape=null));var r=new Set(this.keepTensors),o=getTensorsInContainer(e);o.forEach(function(e){return r.add(e.id)});for(var a=0;a0,\"gradients() received an empty list of xs.\"),this.tidy(\"gradients\",function(){var a=e();assert(a instanceof Tensor,\"The result y returned by f() must be a tensor.\");var i=getFilteredNodesXToY(o.activeTape,t,a);if(!r&&0===i.length&&t.length>0)throw new Error(\"Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.\");var s={};return s[a.id]=null==n?ones(a.shape):n,backpropagateGradients(s,i),{value:a,grads:t.map(function(e){return s[e.id]})}},!0)},e.prototype.customGrad=function(e){var t=this;return assert(isFunction(e),\"The f passed in customGrad(f) must be a function.\"),function(){for(var n,r,o=[],a=0;a {op();...}); to avoid memory leaks.\");return this.activeScope.track.push(e),e},e}();function ones(e){var t=makeOnesTypedArray(sizeFromShape(e),\"float32\");return Tensor.make(e,{values:t})}!function(e){e[e.NUMBER=0]=\"NUMBER\",e[e.BOOLEAN=1]=\"BOOLEAN\",e[e.STRING=2]=\"STRING\"}(Type||(Type={}));var URL_PROPERTIES=[{name:\"DEBUG\",type:Type.BOOLEAN},{name:\"IS_BROWSER\",type:Type.BOOLEAN},{name:\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\",type:Type.NUMBER},{name:\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE\",type:Type.BOOLEAN},{name:\"WEBGL_VERSION\",type:Type.NUMBER},{name:\"WEBGL_RENDER_FLOAT32_ENABLED\",type:Type.BOOLEAN},{name:\"WEBGL_DOWNLOAD_FLOAT_ENABLED\",type:Type.BOOLEAN},{name:\"WEBGL_FENCE_API_ENABLED\",type:Type.BOOLEAN},{name:\"BACKEND\",type:Type.STRING}];function isWebGLVersionEnabled(e,t){var n;try{n=getWebGLRenderingContext(e,t)}catch(e){return!1}return null!=n&&(loseContext(n),!0)}function getWebGLDisjointQueryTimerVersion(e,t){if(0===e)return 0;var n,r=getWebGLRenderingContext(e,t);return n=hasExtension(r,\"EXT_disjoint_timer_query_webgl2\")&&2===e?2:hasExtension(r,\"EXT_disjoint_timer_query\")?1:0,null!=r&&loseContext(r),n}function isRenderToFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,\"OES_texture_float\"))return!1}else if(!hasExtension(n,\"EXT_color_buffer_float\"))return!1;createFloatTextureAndBindToFramebuffer(n,e);var r=n.checkFramebufferStatus(n.FRAMEBUFFER)===n.FRAMEBUFFER_COMPLETE;return loseContext(n),r}function isDownloadFloatTextureEnabled(e,t){if(0===e)return!1;var n=getWebGLRenderingContext(e,t);if(1===e){if(!hasExtension(n,\"OES_texture_float\"))return!1}else if(!hasExtension(n,\"EXT_color_buffer_float\"))return!1;createFloatTextureAndBindToFramebuffer(n,e),n.readPixels(0,0,1,1,n.RGBA,n.FLOAT,new Float32Array(4));var r=n.getError()===n.NO_ERROR;return loseContext(n),r}function isWebGLFenceEnabled(e,t){if(2!==e)return!1;var n=getWebGLRenderingContext(e,t),r=null!=n.fenceSync;return loseContext(n),r}function isChrome(){return\"undefined\"!=typeof navigator&&null!=navigator&&null!=navigator.userAgent&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor)}var TENSORFLOWJS_FLAGS_PREFIX=\"tfjsflags\";function getFeaturesFromURL(){var e={};if(\"undefined\"==typeof window||void 0===window.location)return e;var t=getQueryParams(window.location.search);if(TENSORFLOWJS_FLAGS_PREFIX in t){var n={};t[TENSORFLOWJS_FLAGS_PREFIX].split(\",\").forEach(function(e){var t=e.split(\":\"),r=t[0],o=t[1];n[r]=o}),URL_PROPERTIES.forEach(function(t){t.name in n&&(console.log(\"Setting feature override from URL \"+t.name+\": \"+n[t.name]),t.type===Type.NUMBER?e[t.name]=+n[t.name]:t.type===Type.BOOLEAN?e[t.name]=\"true\"===n[t.name]:t.type===Type.STRING?e[t.name]=n[t.name]:console.warn(\"Unknown URL param: \"+t.name+\".\"))})}return e}function hasExtension(e,t){return null!=e.getExtension(t)}function getWebGLRenderingContext(e,t){if(0===e||!t)throw new Error(\"Cannot get WebGL rendering context, WebGL is disabled.\");var n=document.createElement(\"canvas\");return 1===e?n.getContext(\"webgl\")||n.getContext(\"experimental-webgl\"):n.getContext(\"webgl2\")}function loseContext(e){if(null!=e){var t=e.getExtension(\"WEBGL_lose_context\");if(null==t)throw new Error(\"Extension WEBGL_lose_context not supported on this browser.\");t.loseContext()}}function createFloatTextureAndBindToFramebuffer(e,t){var n=e.createFramebuffer(),r=e.createTexture();e.bindTexture(e.TEXTURE_2D,r);var o=2===t?e.RGBA32F:e.RGBA;e.texImage2D(e.TEXTURE_2D,0,o,1,1,0,e.RGBA,e.FLOAT,null),e.bindFramebuffer(e.FRAMEBUFFER,n),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,r,0)}function getQueryParams(e){var t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,function(e){for(var n=[],r=1;r0?0:getWebGLDisjointQueryTimerVersion(t,this.get(\"IS_BROWSER\"))}if(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE\"===e)return this.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0&&!isMobile();if(\"HAS_WEBGL\"===e)return this.get(\"WEBGL_VERSION\")>0;if(\"WEBGL_VERSION\"===e)return isWebGLVersionEnabled(2,this.get(\"IS_BROWSER\"))?2:isWebGLVersionEnabled(1,this.get(\"IS_BROWSER\"))?1:0;if(\"WEBGL_RENDER_FLOAT32_ENABLED\"===e)return isRenderToFloatTextureEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"WEBGL_DOWNLOAD_FLOAT_ENABLED\"===e)return isDownloadFloatTextureEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"WEBGL_FENCE_API_ENABLED\"===e)return isWebGLFenceEnabled(this.get(\"WEBGL_VERSION\"),this.get(\"IS_BROWSER\"));if(\"TEST_EPSILON\"===e)return this.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?TEST_EPSILON_FLOAT32_ENABLED:TEST_EPSILON_FLOAT32_DISABLED;throw new Error(\"Unknown feature \"+e+\".\")},e.prototype.setFeatures=function(e){this.features=Object.assign({},e)},e.prototype.reset=function(){this.features=getFeaturesFromURL(),null!=this.globalEngine&&(this.globalEngine=null)},e.prototype.initBackend=function(e,t){var n=this;void 0===t&&(t=!1),this.backendName=e,this.backend=this.findBackend(e),this.globalEngine=new Engine(this.backend,t,function(){return n.get(\"DEBUG\")})},e.prototype.findBackend=function(e){return e in this.registry?this.registry[e].backend:null},e.prototype.registerBackend=function(e,t,n,r){var o=this;if(void 0===n&&(n=1),e in this.registry)return console.warn(e+\" backend was already registered. Reusing existing backend\"),null!=r&&r(function(){return o.engine}),!1;try{var a=t();return this.registry[e]={backend:a,priority:n},!0}catch(t){return console.warn(\"Registration of backend \"+e+\" failed\"),console.warn(t.stack||t.message),!1}},e.prototype.removeBackend=function(e){if(!(e in this.registry))throw new Error(e+\" backend not found in registry\");this.registry[e].backend.dispose(),delete this.registry[e]},Object.defineProperty(e.prototype,\"engine\",{get:function(){return this.initDefaultBackend(),this.globalEngine},enumerable:!0,configurable:!0}),e.prototype.initDefaultBackend=function(){null==this.globalEngine&&this.initBackend(this.get(\"BACKEND\"),!1)},e}();function getGlobalNamespace(){var e;if(\"undefined\"!=typeof window)e=window;else{if(\"undefined\"==typeof process)throw new Error(\"Could not find a global object\");e=process}return e}function getOrMakeEnvironment(){var e=getGlobalNamespace();return null==e.ENV&&(e.ENV=new Environment(getFeaturesFromURL()),setTensorTracker(function(){return e.ENV.engine})),e.ENV}var ENV=getOrMakeEnvironment(),environment=Object.freeze({Environment:Environment,ENV:ENV});function warn(){for(var e=[],t=0;t=2*t+1||o%2==1?i.push(o):a.push(o);r.push.apply(r,a),r.push(0),r.push.apply(r,i)}return r}function getReshapedPermuted(e,t,n,r){void 0===r&&(r=!0);var o=[];r?o.push(e[0]/n):o.push(e[0]*n);for(var a=1;a=-n&&et||n===e){r=!0;break}n=nearestDivisor(e,n+1)}return n}function computeOutShape(e,t,n){for(var r=[],o=e.length,a=0;a0?o>=s[t]:o<=s[t]);o+=r[t])n+=1;return n}),[i,l]}function startForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MIN_SAFE_INTEGER:Number.MAX_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=clamp(0,a,i-1)}function stopForAxis(e,t,n,r,o){var a=t[o];e&1<0?Number.MAX_SAFE_INTEGER:Number.MIN_SAFE_INTEGER);var i=r[o];return a<0&&(a+=i),a=n[o]>0?clamp(0,a,i):clamp(-1,a,i-1)}function grad(e){return assert(isFunction(e),\"The f passed in grad(f) must be a function\"),function(t,n){return assert(t instanceof Tensor,\"The x passed in grad(f)(x) must be a tensor\"),assert(null==n||n instanceof Tensor,\"The dy passed in grad(f)(x, dy) must be a tensor\"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,\"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)\"),checkGrads(a),a[0]})}}function grads(e){return assert(isFunction(e),\"The f passed in grads(f) must be a function\"),function(t,n){return assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),\"The args passed in grads(f)(args) must be an array of tensors\"),assert(null==n||n instanceof Tensor,\"The dy passed in grads(f)(args, dy) must be a tensor\"),ENV.engine.tidy(function(){var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n),o=r.value,a=r.grads;return null!=n&&assertShapesMatch(o.shape,n.shape,\"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])\"),checkGrads(a),a})}}function valueAndGrad(e){return assert(isFunction(e),\"The f passed in valueAndGrad(f) must be a function\"),function(t,n){assert(t instanceof Tensor,\"The x passed in valueAndGrad(f)(x) must be a tensor\"),assert(null==n||n instanceof Tensor,\"The dy passed in valueAndGrad(f)(x, dy) must be a tensor\");var r=ENV.engine.gradients(function(){return e(t)},[t],n),o=r.grads,a=r.value;return checkGrads(o),{grad:o[0],value:a}}}function valueAndGrads(e){return assert(isFunction(e),\"The f passed in valueAndGrads(f) must be a function\"),function(t,n){assert(Array.isArray(t)&&t.every(function(e){return e instanceof Tensor}),\"The args passed in valueAndGrads(f)(args) must be array of tensors\"),assert(null==n||n instanceof Tensor,\"The dy passed in valueAndGrads(f)(args, dy) must be a tensor\");var r=ENV.engine.gradients(function(){return e.apply(void 0,t)},t,n);return null!=n&&assertShapesMatch(r.value.shape,n.shape,\"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])\"),checkGrads(r.grads),r}}function variableGrads(e,t){if(assert(isFunction(e),\"The f passed in variableGrads(f) must be a function\"),assert(null==t||Array.isArray(t)&&t.every(function(e){return e instanceof Variable}),\"The varList passed in variableGrads(f, varList) must be an array of variables\"),null==t)for(var n in t=[],ENV.engine.registeredVariables)t.push(ENV.engine.registeredVariables[n]);var r=t.length;assert((t=t.filter(function(e){return e.trainable})).length>0,\"variableGrads() expects at least one of the input variables to be trainable, but none of the \"+r+\" variables is trainable.\");var o=ENV.engine.gradients(e,t,null,!0),a=o.value,i=o.grads;assert(i.some(function(e){return null!=e}),\"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize().\"),assert(0===a.rank,\"The f passed in variableGrads(f) must return a scalar, but it returned a rank-\"+a.rank+\" tensor\");var s={};return t.forEach(function(e,t){null!=i[t]&&(s[e.name]=i[t])}),{value:a,grads:s}}function customGrad(e){return ENV.engine.customGrad(e)}function checkGrads(e){if(e.filter(function(e){return null==e}).length>0)throw new Error(\"Cannot compute gradient of y=f(x) with respect to x. Make sure that\\n the f you passed encloses all operations that lead from x to y.\")}function convertToTensor(e,t,n,r){if(void 0===r&&(r=\"float32\"),r=r||\"float32\",e instanceof Tensor)return e;if(!isTypedArray(e)&&!Array.isArray(e)&&\"number\"!=typeof e&&\"boolean\"!=typeof e)throw new Error(\"Argument '\"+t+\"' passed to '\"+n+\"' must be a Tensor or TensorLike, but got \"+e.constructor.name);var o=inferShape(e);return isTypedArray(e)||Array.isArray(e)||(e=[e]),Tensor.make(o,{values:toTypedArray(e,r,ENV.get(\"DEBUG\"))},r)}function convertToTensorArray(e,t,n){if(!Array.isArray(e))throw new Error(\"Argument \"+t+\" passed to \"+n+\" must be a `Tensor[]` or `TensorLike[]`\");return e.map(function(e,r){return convertToTensor(e,t+\"[\"+r+\"]\",n)})}function op(e){var t=Object.keys(e);if(1!==t.length)throw new Error(\"Please provide an object with a single key (operation name) mapping to a function. Got an object with \"+t.length+\" keys.\");var n=t[0],r=e[n];n.endsWith(\"_\")&&(n=n.substring(0,n.length-1));var o=function(){for(var e=[],t=0;t1)return zeros([0],r);var o=makeZerosTypedArray(Math.abs(Math.ceil((t-e)/n)),r);to}).sort(function(e,t){return t.score-e.score}),i=[],s=0;s=0;--d){if(intersectionOverUnion(e,c,i[d])>=r){p=!0;break}}if(!p&&(i.push(c),i.length>=n))break}return tensor1d(i,\"int32\")}function intersectionOverUnion(e,t,n){var r=e.subarray(4*t,4*t+4),o=e.subarray(4*n,4*n+4),a=Math.min(r[0],r[2]),i=Math.min(r[1],r[3]),s=Math.max(r[0],r[2]),u=Math.max(r[1],r[3]),l=Math.min(o[0],o[2]),c=Math.min(o[1],o[3]),p=Math.max(o[0],o[2]),d=Math.max(o[1],o[3]),h=(s-a)*(u-i),f=(p-l)*(d-c);if(h<=0||f<=0)return 0;var m=Math.max(a,l),g=Math.max(i,c),v=Math.min(s,p),y=Math.min(u,d),x=Math.max(v-m,0)*Math.max(y-g,0);return x/(h+f-x)}function topkImpl(e,t,n,r,o){for(var a=t[t.length-1],i=[e.length/a,a],s=i[0],u=i[1],l=getTypedArrayFromDType(n,s*r),c=getTypedArrayFromDType(\"int32\",s*r),p=0;p\":\"<\",u=n?\"inOffset + i;\":\"round(getBestIndicesA(batch, inOffset + i));\";this.userCode=\"\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = outIdx * \"+r+\";\\n\\n int bestIndex = 0;\\n float bestValue = getA(batch, inOffset);\\n\\n for (int i = 0; i < \"+r+\"; i++) {\\n int inIdx = \"+u+\";\\n float candidate = getA(batch, inIdx);\\n if (candidate \"+s+\" bestValue) {\\n bestValue = candidate;\\n bestIndex = inIdx;\\n }\\n }\\n setOutput(float(bestIndex));\\n }\\n \"}}(),AvgPool2DBackpropProgram=function(){return function(e){this.variableNames=[\"dy\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=1/(t*n);this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n const float avgMultiplier = float(\"+s+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n\\n ivec2 dyRCCorner = coords.yz - pads;\\n int dyRCorner = dyRCCorner.x;\\n int dyCCorner = dyRCCorner.y;\\n\\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n float dyValue = getDy(b, idyR, idyC, d);\\n\\n dotProd += dyValue * avgMultiplier;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}();function getBroadcastDims(e,t){for(var n=e.length,r=[],o=0;o1&&1===i&&r.unshift(a)}return r}function getReductionAxes(e,t){for(var n=[],r=0;r1)&&n.unshift(a)}return n}function broadcastDimsAreOuter(e){for(var t=0;t1&&s>1&&i!==s)throw Error(r);n.unshift(Math.max(i,s))}return n}var BatchNormProgram=function(){return function(e,t,n,r,o,a){this.outputShape=[],this.supportsBroadcasting=!0,this.variableNames=[\"x\",\"mean\",\"variance\"],assertAndGetBroadcastShape(e,t),assertAndGetBroadcastShape(e,n);var i=\"0.0\";null!=r&&(assertAndGetBroadcastShape(e,r),this.variableNames.push(\"offset\"),i=\"getOffsetAtOutCoords()\");var s=\"1.0\";null!=o&&(assertAndGetBroadcastShape(e,o),this.variableNames.push(\"scale\"),s=\"getScaleAtOutCoords()\"),this.outputShape=e,this.userCode=\"\\n void main() {\\n float x = getXAtOutCoords();\\n float mean = getMeanAtOutCoords();\\n float variance = getVarianceAtOutCoords();\\n float offset = \"+i+\";\\n float scale = \"+s+\";\\n float inv = scale * inversesqrt(variance + float(\"+a+\"));\\n setOutput((x - mean) * inv + offset);\\n }\\n \"}}(),CHECK_NAN_SNIPPET=\"\\n if (isNaN(a)) return a;\\n if (isNaN(b)) return b;\\n\",ADD=\"return a + b;\",SUB=\"return a - b;\",MUL=\"return a * b;\",DIV=\"if (a == b) return 1.0;\\n return a / b;\",INT_DIV=\"\\n float resultSign = sign(a) * sign(b);\\n int ia = round(a);\\n int ib = round(b);\\n int result = ia / ib;\\n int amodb = ia - ib * result;\\n\\n if (resultSign < 0.0 && amodb != 0) {\\n result -= 1;\\n }\\n return float(result);\\n\",POW=\"\\nif(a < 0.0 && floor(b) < b){\\n return NAN;\\n}\\nreturn (round(mod(b, 2.0)) == 0 || round(mod(b, 2.0)) == 2) ?\\n pow(abs(a), b) : sign(a) * pow(abs(a), b);\\n\",SQUARED_DIFFERENCE=\"return (a - b) * (a - b);\",EQUAL=\"return float(a == b);\",NOT_EQUAL=\"return float(a != b);\",LESS=\"return float(a < b);\",LESS_EQUAL=\"return float(a <= b);\",GREATER=\"return float(a > b);\",GREATER_EQUAL=\"return float(a >= b);\",LOGICAL_AND=\"return float(a >= 1.0 && b >= 1.0);\",LOGICAL_OR=\"return float(a >= 1.0 || b >= 1.0);\",MAX=CHECK_NAN_SNIPPET+\"\\n return max(a, b);\\n\",MIN=CHECK_NAN_SNIPPET+\"\\n return min(a, b);\\n\",MOD=\"if (b == 0.0) return NAN;\\n return mod(a, b);\",ATAN2=CHECK_NAN_SNIPPET+\"\\n return atan(a, b);\\n\",ELU_DER=\"return (b >= 1.0) ? a : a * (b + 1.0);\",BinaryOpProgram=function(){function e(e,t,n){this.variableNames=[\"A\",\"B\"],this.supportsBroadcasting=!0,this.outputShape=assertAndGetBroadcastShape(t,n),this.userCode=\"\\n uniform float NAN;\\n float binaryOperation(float a, float b) {\\n \"+e+\"\\n }\\n\\n void main() {\\n float a = getAAtOutCoords();\\n float b = getBAtOutCoords();\\n setOutput(binaryOperation(a, b));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(){var e=this;return function(t,n){null==e.startLoc&&(e.startLoc=t.getUniformLocationNoThrow(n,\"NAN\"),null==e.startLoc)||t.gl.uniform1f(e.startLoc,NaN)}},e}(),ClipProgram=function(){return function(e,t,n){this.variableNames=[\"A\"],this.outputShape=e;var r=t.toFixed(20),o=n.toFixed(20);this.userCode=\"\\n void main() {\\n float value = getAAtOutCoords();\\n if (isNaN(value)) {\\n setOutput(value);\\n return;\\n }\\n\\n setOutput(clamp(value, \"+r+\", \"+o+\"));\\n }\\n \"}}();function assertParams(e,t,n){var r=e.length,o=t.length;assert(e.length===t.length,\"Error in concat\"+r+\"D: rank of x1 (\"+r+\") and x2 (\"+o+\") must be the same.\"),assert(n>=0&&n= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int yC = 0; yC < \"+e.outWidth+\"; yC++) {\\n int xC = wC + yC * \"+n+\" - \"+o+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float dyValue = getDy(b, yR, yC, d2);\\n float xValue = getX(b, xR, xC, d1);\\n dotProd += (xValue * dyValue);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),Conv2DDerInputProgram=function(){return function(e){this.variableNames=[\"dy\",\"W\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d1 = coords[3];\\n\\n ivec2 dyCorner = coords.yz - pads;\\n int dyRCorner = dyCorner.x;\\n int dyCCorner = dyCorner.y;\\n\\n // Convolve dy(?, ?, d2) with w(:, :, d1, d2) to compute dx(xR, xC, d1).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n int wRPerm = \"+t+\" - 1 - wR;\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n int wCPerm = \"+n+\" - 1 - wC;\\n\\n for (int d2 = 0; d2 < \"+e.outChannels+\"; d2++) {\\n float xValue = getDy(batch, idyR, idyC, d2);\\n float wValue = getW(wRPerm, wCPerm, d1, d2);\\n dotProd += xValue * wValue;\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DDerFilterProgram=function(){return function(e){this.variableNames=[\"x\",\"dy\"],this.outputShape=e.filterShape;var t=e.strideHeight,n=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.outChannels/e.inChannels;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int wR = coords.x;\\n int wC = coords.y;\\n int d1 = coords.z;\\n int dm = coords.w;\\n int d2 = d1 * \"+a+\" + dm;\\n\\n float dotProd = 0.0;\\n\\n // TODO: Vec4 over the batch size\\n for (int b = 0; b < \"+e.batchSize+\"; b++) {\\n for (int yR = 0; yR < \"+e.outHeight+\"; yR++) {\\n int xR = wR + yR * \"+t+\" - \"+r+\";\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int yC = 0; yC < \"+e.outWidth+\"; yC++) {\\n int xC = wC + yC * \"+n+\" - \"+o+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float dyValue = getDy(b, yR, yC, d2);\\n float xValue = getX(b, xR, xC, d1);\\n dotProd += (xValue * dyValue);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DDerInputProgram=function(){return function(e){this.variableNames=[\"dy\",\"W\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d1 = coords[3];\\n ivec2 dyCorner = coords.yz - pads;\\n int dyRCorner = dyCorner.x;\\n int dyCCorner = dyCorner.y;\\n\\n float dotProd = 0.0;\\n\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n int wRPerm = \"+t+\" - 1 - wR;\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n int wCPerm = \"+n+\" - 1 - wC;\\n\\n // TODO: Vec4 over the channelMul\\n for (int dm = 0; dm < \"+s+\"; dm++) {\\n int d2 = d1 * \"+s+\" + dm;\\n float xValue = getDy(batch, idyR, idyC, d2);\\n float wValue = getW(wRPerm, wCPerm, d1, dm);\\n dotProd += xValue * wValue;\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),Conv2DProgram=function(){return function(e){this.variableNames=[\"x\",\"W\"],this.outputShape=e.outShape;var t=e.padInfo.top,n=e.padInfo.left,r=e.strideHeight,o=e.strideWidth,a=e.dilationHeight,i=e.dilationWidth,s=e.filterHeight,u=e.filterWidth,l=4*Math.floor(e.inChannels/4),c=e.inChannels%4;this.userCode=\"\\n const ivec2 strides = ivec2(\"+r+\", \"+o+\");\\n const ivec2 pads = ivec2(\"+t+\", \"+n+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d2 = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+s+\"; wR++) {\\n int xR = xRCorner + wR * \"+a+\";\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+u+\"; wC++) {\\n int xC = xCCorner + wC * \"+i+\";\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n for (int d1 = 0; d1 < \"+l+\"; d1 += 4) {\\n vec4 xValues = vec4(\\n getX(batch, xR, xC, d1),\\n getX(batch, xR, xC, d1 + 1),\\n getX(batch, xR, xC, d1 + 2),\\n getX(batch, xR, xC, d1 + 3)\\n );\\n vec4 wValues = vec4(\\n getW(wR, wC, d1, d2),\\n getW(wR, wC, d1 + 1, d2),\\n getW(wR, wC, d1 + 2, d2),\\n getW(wR, wC, d1 + 3, d2)\\n );\\n\\n dotProd += dot(xValues, wValues);\\n }\\n\\n if (\"+(1===c)+\") {\\n dotProd +=\\n getX(batch, xR, xC, \"+l+\") *\\n getW(wR, wC, \"+l+\", d2);\\n } else if (\"+(2===c)+\") {\\n vec2 xValues = vec2(\\n getX(batch, xR, xC, \"+l+\"),\\n getX(batch, xR, xC, \"+l+\" + 1)\\n );\\n vec2 wValues = vec2(\\n getW(wR, wC, \"+l+\", d2),\\n getW(wR, wC, \"+l+\" + 1, d2)\\n );\\n dotProd += dot(xValues, wValues);\\n } else if (\"+(3===c)+\") {\\n vec3 xValues = vec3(\\n getX(batch, xR, xC, \"+l+\"),\\n getX(batch, xR, xC, \"+l+\" + 1),\\n getX(batch, xR, xC, \"+l+\" + 2)\\n );\\n vec3 wValues = vec3(\\n getW(wR, wC, \"+l+\", d2),\\n getW(wR, wC, \"+l+\" + 1, d2),\\n getW(wR, wC, \"+l+\" + 2, d2)\\n );\\n dotProd += dot(xValues, wValues);\\n }\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),DepthwiseConv2DProgram=function(){return function(e){this.variableNames=[\"x\",\"W\"],this.outputShape=e.outShape;var t=e.inHeight,n=e.inWidth,r=e.padInfo.top,o=e.padInfo.left,a=e.strideHeight,i=e.strideWidth,s=e.dilationHeight,u=e.dilationWidth,l=e.filterHeight,c=e.filterWidth,p=e.outChannels/e.inChannels;this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+r+\", \"+o+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords.x;\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int d2 = coords.w;\\n int d1 = d2 / \"+p+\";\\n int q = d2 - d1 * \"+p+\";\\n\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // Convolve x(?, ?, d1) with w(:, :, d1, q) to get y(yR, yC, d2).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n // TODO(dsmilkov): Flatten the two for loops and vec4 the operations.\\n for (int wR = 0; wR < \"+l+\"; wR++) {\\n int xR = xRCorner + wR * \"+s+\";\\n\\n if (xR < 0 || xR >= \"+t+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+c+\"; wC++) {\\n int xC = xCCorner + wC * \"+u+\";\\n\\n if (xC < 0 || xC >= \"+n+\") {\\n continue;\\n }\\n\\n float xVal = getX(batch, xR, xC, d1);\\n float wVal = getW(wR, wC, d1, q);\\n dotProd += xVal * wVal;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}();function makeShader(e,t,n,r){var o=e.map(function(e){var t=sizeFromShape(e.shapeInfo.logicalShape);return e.shapeInfo.isUniform?\"uniform float \"+e.name+(t>1?\"[\"+t+\"]\":\"\")+\";\":\"uniform sampler2D \"+e.name+\";\"});o=o.join(\"\\n\");var a=e.map(function(e){return getInputSamplingSnippet(e,t,r)}).join(\"\\n\"),i=t.texShape,s=getOutputSamplingSnippet(t.logicalShape,i);return[SHADER_PREFIX,FLOAT_TEXTURE_SAMPLE_SNIPPET,FLOAT_TEXTURE_SETOUTPUT_SNIPPET,o,s,a,n].join(\"\\n\")}function getSamplerFromInInfo(e){var t=e.shapeInfo.logicalShape;switch(t.length){case 0:return getSamplerScalar(e);case 1:return getSampler1D(e);case 2:return getSampler2D(e);case 3:return getSampler3D(e);case 4:return getSampler4D(e);case 5:return getSampler5D(e);case 6:return getSampler6D(e);default:throw new Error(t.length+\"-D input sampling is not yet supported\")}}function getInputSamplingSnippet(e,t,n){var r=getSamplerFlat(e);return r+=getSamplerFromInInfo(e),(n||arraysEqual(e.shapeInfo.logicalShape,t.logicalShape))&&(r+=getSamplerAtOutputCoords(e,t,n)),r}function getOutputSamplingSnippet(e,t){switch(e.length){case 0:return getOutputScalarCoords();case 1:return getOutput1DCoords(e,t);case 2:return getOutput2DCoords(e,t);case 3:return getOutput3DCoords(e,t);case 4:return getOutput4DCoords(e,t);case 5:return getOutput5DCoords(e,t);case 6:return getOutput6DCoords(e,t);default:throw new Error(e.length+\"-D output sampling is not yet supported\")}}var SAMPLE_1D_SNIPPET=\"\\nvec2 UVfrom1D(int texNumR, int texNumC, int index) {\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_2D_SNIPPET=\"\\nvec2 UVfrom2D(int texNumR, int texNumC, int numC, int row, int col) {\\n int index = row * numC + col;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_3D_SNIPPET=\"\\nvec2 UVfrom3D(int texNumR, int texNumC, int stride0,\\n int stride1, int row, int col, int depth) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_4D_SNIPPET=\"\\nvec2 UVfrom4D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int row, int col, int depth,\\n int depth2) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_5D_SNIPPET=\"\\nvec2 UVfrom5D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int stride3, int row, int col, int depth,\\n int depth2, int depth3) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 +\\n depth * stride2 + depth2 * stride3 + depth3;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",SAMPLE_6D_SNIPPET=\"\\nvec2 UVfrom6D(int texNumR, int texNumC, int stride0,\\n int stride1, int stride2, int stride3, int stride4,\\n int row, int col, int depth, int depth2, int depth3, int depth4) {\\n // Explicitly use integer operations as dot() only works on floats.\\n int index = row * stride0 + col * stride1 + depth * stride2 + depth2 *\\n stride3 + depth3 * stride4 + depth4;\\n int texR = index / texNumC;\\n int texC = index - texR * texNumC;\\n return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);\\n}\\n\",FLOAT_TEXTURE_SAMPLE_SNIPPET=\"\\n float sampleTexture(sampler2D textureSampler, vec2 uv) {\\n return texture2D(textureSampler, uv).r;\\n }\\n\",FLOAT_TEXTURE_SETOUTPUT_SNIPPET=\"\\n void setOutput(float val) {\\n gl_FragColor = vec4(val, 0, 0, 0);\\n }\\n\",SHADER_PREFIX=\"\\n precision highp float;\\n precision highp int;\\n varying vec2 resultUV;\\n const vec2 halfCR = vec2(0.5, 0.5);\\n\\n struct ivec5\\n {\\n int x;\\n int y;\\n int z;\\n int w;\\n int u;\\n };\\n\\n struct ivec6\\n {\\n int x;\\n int y;\\n int z;\\n int w;\\n int u;\\n int v;\\n };\\n\\n bool isNaN(float val) {\\n return (val < 0.0 || 0.0 < val || val == 0.0) ? false : true;\\n }\\n\\n bool hasNaN(vec4 values) {\\n vec4 v1 = values * values;\\n vec4 v2 = values * values;\\n return any(notEqual(v1, v2));\\n }\\n\\n float getNaN(vec4 values) {\\n return dot(vec4(1), values);\\n }\\n\\n int round(float value) {\\n return int(floor(value + 0.5));\\n }\\n\\n int imod(int x, int y) {\\n return x - y * (x / y);\\n }\\n\\n //Based on the work of Dave Hoskins\\n //https://www.shadertoy.com/view/4djSRW\\n #define HASHSCALE1 443.8975\\n float random(float seed){\\n vec2 p = resultUV * seed;\\n vec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n }\\n\\n \"+SAMPLE_1D_SNIPPET+\"\\n \"+SAMPLE_2D_SNIPPET+\"\\n \"+SAMPLE_3D_SNIPPET+\"\\n \"+SAMPLE_4D_SNIPPET+\"\\n \"+SAMPLE_5D_SNIPPET+\"\\n \"+SAMPLE_6D_SNIPPET+\"\\n\";function getOutputScalarCoords(){return\"\\n int getOutputCoords() {\\n return 0;\\n }\\n \"}function getOutput1DCoords(e,t){return 1===t[0]?\"\\n int getOutputCoords() {\\n return int(resultUV.x * \"+t[1]+\".0);\\n }\\n \":1===t[1]?\"\\n int getOutputCoords() {\\n return int(resultUV.y * \"+t[0]+\".0);\\n }\\n \":\"\\n int getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n return resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n }\\n \"}function getOutput3DCoords(e,t){var n=e[1]*e[2],r=e[2];return\"\\n ivec3 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n int r = index / \"+n+\";\\n index -= r * \"+n+\";\\n int c = index / \"+r+\";\\n int d = index - c * \"+r+\";\\n return ivec3(r, c, d);\\n }\\n \"}function getOutput4DCoords(e,t){var n=e[3],r=e[2]*n,o=e[1]*r;return\"\\n ivec4 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+o+\";\\n index -= r * \"+o+\";\\n\\n int c = index / \"+r+\";\\n index -= c * \"+r+\";\\n\\n int d = index / \"+n+\";\\n int d2 = index - d * \"+n+\";\\n\\n return ivec4(r, c, d, d2);\\n }\\n \"}function getOutput5DCoords(e,t){var n=e[4],r=e[3]*n,o=e[2]*r,a=e[1]*o;return\"\\n ivec5 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx * vec2(\"+t[0]+\",\\n \"+t[1]+\"));\\n\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+a+\";\\n index -= r * \"+a+\";\\n\\n int c = index / \"+o+\";\\n index -= c * \"+o+\";\\n\\n int d = index / \"+r+\";\\n index -= d * \"+r+\";\\n\\n int d2 = index / \"+n+\";\\n int d3 = index - d2 * \"+n+\";\\n\\n ivec5 outShape = ivec5(r, c, d, d2, d3);\\n return outShape;\\n }\\n \"}function getOutput6DCoords(e,t){var n=e[5],r=e[4]*n,o=e[3]*r,a=e[2]*o,i=e[1]*a;return\"\\n ivec6 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n\\n int r = index / \"+i+\";\\n index -= r * \"+i+\";\\n\\n int c = index / \"+a+\";\\n index -= c * \"+a+\";\\n\\n int d = index / \"+o+\";\\n index -= d * \"+o+\";\\n\\n int d2 = index / \"+r+\";\\n index -= d2 * \"+r+\";\\n\\n int d3 = index / \"+n+\";\\n int d4 = index - d3 * \"+n+\";\\n\\n ivec6 result = ivec6(r, c, d, d2, d3, d4);\\n return result;\\n }\\n \"}function getOutput2DCoords(e,t){return arraysEqual(e,t)?\"\\n ivec2 getOutputCoords() {\\n return ivec2(resultUV.yx * vec2(\"+t[0]+\", \"+t[1]+\"));\\n }\\n \":1===e[1]?\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n return ivec2(index, 0);\\n }\\n \":1===e[0]?\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n return ivec2(0, index);\\n }\\n \":\"\\n ivec2 getOutputCoords() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+t[0]+\", \"+t[1]+\"));\\n int index = resTexRC.x * \"+t[1]+\" + resTexRC.y;\\n int r = index / \"+e[1]+\";\\n int c = index - r * \"+e[1]+\";\\n return ivec2(r, c);\\n }\\n \"}function getSamplerScalar(e){var t=e.name,n=\"get\"+t.charAt(0).toUpperCase()+t.slice(1);return e.shapeInfo.isUniform?\"float \"+n+\"() {return \"+t+\";}\":\"\\n float \"+n+\"() {\\n return sampleTexture(\"+t+\", halfCR);\\n }\\n \"}function getSampler1D(e){var t=e.name,n=\"get\"+t.charAt(0).toUpperCase()+t.slice(1);return\"\\n float \"+n+\"(int index) {\\n return \"+n+\"Flat(index);\\n }\\n \"}function getSampler2D(e){var t=e.shapeInfo.logicalShape,n=e.name,r=\"get\"+n.charAt(0).toUpperCase()+n.slice(1),o=e.shapeInfo.texShape;if(null!=o&&arraysEqual(t,o)){var a=o[0];return\"\\n float \"+r+\"(int row, int col) {\\n vec2 uv = (vec2(col, row) + halfCR) / vec2(\"+o[1]+\".0, \"+a+\".0);\\n return sampleTexture(\"+n+\", uv);\\n }\\n \"}var i=squeezeShape(t),s=i.newShape,u=i.keptDims,l=s;if(l.length=1?\"coords = 0;\":s.map(function(e){return\"coords[\"+(e+u)+\"] = 0;\"}).join(\"\\n\"))+\"\\n return get\"+n+\"(\"+(a<2&&o>0?\"coords\":e.shapeInfo.logicalShape.map(function(e,t){return\"coords[\"+(t+u)+\"]\"}).join(\", \"))+\");\\n }\\n \"}function getSamplerAtOutputCoords(e,t,n){var r=e.name,o=r.charAt(0).toUpperCase()+r.slice(1),a=\"get\"+o+\"AtOutCoords\",i=getBroadcastDims(e.shapeInfo.logicalShape,t.logicalShape),s=e.shapeInfo.logicalShape.length,u=t.logicalShape.length,l=n&&(u>s||i.length>0),c=broadcastDimsAreOuter(i),p=e.shapeInfo.isUniform;if(l&&!c)return getBroadcastOutputCoordsSampler(e,t,o,a);var d=sizeFromShape(e.shapeInfo.logicalShape),h=\"\";l&&c&&(h=\"\\n int mainPart = index / \"+d+\";\\n index -= mainPart * \"+d+\";\\n \");var f=t.texShape;if(p)return 1===d?\"float \"+a+\"() {return \"+r+\";}\":\"\\n float \"+a+\"() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+f[0]+\", \"+f[1]+\"));\\n int index = resTexRC.x * \"+f[1]+\" + resTexRC.y;\\n \"+h+\"\\n return get\"+o+\"Flat(index);\\n }\\n \";var m=e.shapeInfo.texShape;return arraysEqual(m,f)?\"\\n float \"+a+\"() {\\n return sampleTexture(\"+r+\", resultUV);\\n }\\n \":\"\\n float \"+a+\"() {\\n ivec2 resTexRC = ivec2(resultUV.yx *\\n vec2(\"+f[0]+\", \"+f[1]+\"));\\n int index = resTexRC.x * \"+f[1]+\" + resTexRC.y;\\n \"+h+\"\\n int texR = index / \"+m[1]+\";\\n int texC = index - texR * \"+m[1]+\";\\n vec2 uv = (vec2(texC, texR) + halfCR) /\\n vec2(\"+m[1]+\".0, \"+m[0]+\".0);\\n\\n return sampleTexture(\"+r+\", uv);\\n }\\n \"}function getCoordsDataType(e){if(e<=1)return\"int\";if(2===e)return\"ivec2\";if(3===e)return\"ivec3\";if(4===e)return\"ivec4\";if(5===e)return\"ivec5\";if(6===e)return\"ivec6\";throw Error(\"GPU for rank \"+e+\" is not yet supported\")}function squeezeInputInfo(e,t){var n=JSON.parse(JSON.stringify(e));return n.shapeInfo.logicalShape=t,n}function getSqueezedParams(e,t){return t.map(function(t){return e[t]}).join(\", \")}var CumSumProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=e;var r=e.length,o=e[e.length-1],a=n?\"<\":\">\";this.userCode=\"\\n int getIndex(int i) {\\n \"+(n?\"return \"+o+\" -i - 1;\":\"return i;\")+\"\\n }\\n\\n void main() {\\n \"+getCoordsDataType(r)+\" coords = getOutputCoords();\\n int end = \"+getFinalCoord(r,\"coords\")+\";\\n float val = 0.0;\\n for (int i = \"+o+\" - 1; i >= 0; i -= 1) {\\n int idx = getIndex(i);\\n if (idx \"+a+\" end) {\\n continue;\\n }\\n if (idx == end && \"+t+\") {\\n continue;\\n }\\n \"+getFinalCoord(r,\"coords\")+\" = idx;\\n val += getX(\"+getCoords(r,\"coords\")+\");\\n }\\n setOutput(val);\\n }\\n \"}}();function getCoords(e,t){if(1===e)return\"\"+t;if(2===e)return t+\".x, \"+t+\".y\";if(3===e)return t+\".x, \"+t+\".y, \"+t+\".z\";if(4===e)return t+\".x, \"+t+\".y, \"+t+\".z, \"+t+\".w\";throw Error(\"Cumulative sum for rank \"+e+\" is not yet supported\")}function getFinalCoord(e,t){if(1===e)return\"\"+t;if(2===e)return t+\".y\";if(3===e)return t+\".z\";if(4===e)return t+\".w\";throw Error(\"Cumulative sum for rank \"+e+\" is not yet supported\")}var TextureUsage,PhysicalTextureType,EncodeFloatProgram=function(){return function(e){this.variableNames=[\"A\"],this.outputShape=e,this.userCode=\"\\n const float FLOAT_MAX = 1.70141184e38;\\n const float FLOAT_MIN = 1.17549435e-38;\\n\\n lowp vec4 encode_float(highp float v) {\\n if (isNaN(v)) {\\n return vec4(255, 255, 255, 255);\\n }\\n\\n highp float av = abs(v);\\n\\n if(av < FLOAT_MIN) {\\n return vec4(0.0, 0.0, 0.0, 0.0);\\n } else if(v > FLOAT_MAX) {\\n return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;\\n } else if(v < -FLOAT_MAX) {\\n return vec4(0.0, 0.0, 128.0, 255.0) / 255.0;\\n }\\n\\n highp vec4 c = vec4(0,0,0,0);\\n\\n highp float e = floor(log2(av));\\n highp float m = exp2(fract(log2(av))) - 1.0;\\n\\n c[2] = floor(128.0 * m);\\n m -= c[2] / 128.0;\\n c[1] = floor(32768.0 * m);\\n m -= c[1] / 32768.0;\\n c[0] = floor(8388608.0 * m);\\n\\n highp float ebias = e + 127.0;\\n c[3] = floor(ebias / 2.0);\\n ebias -= c[3] * 2.0;\\n c[2] += floor(ebias) * 128.0;\\n\\n c[3] += 128.0 * step(0.0, -v);\\n\\n return c / 255.0;\\n }\\n\\n void main() {\\n float x = getAAtOutCoords();\\n gl_FragColor = encode_float(x);\\n }\\n \"}}(),FromPixelsProgram=function(){return function(e){this.variableNames=[\"A\"];var t=e[0],n=e[1];this.outputShape=e,this.userCode=\"\\n void main() {\\n ivec3 coords = getOutputCoords();\\n int texR = coords[0];\\n int texC = coords[1];\\n int depth = coords[2];\\n vec2 uv = (vec2(texC, texR) + halfCR) / vec2(\"+n+\".0, \"+t+\".0);\\n\\n vec4 values = texture2D(A, uv);\\n float value;\\n if (depth == 0) {\\n value = values.r;\\n } else if (depth == 1) {\\n value = values.g;\\n } else if (depth == 2) {\\n value = values.b;\\n } else if (depth == 3) {\\n value = values.a;\\n }\\n\\n setOutput(floor(value * 255.0 + 0.5));\\n }\\n \"}}(),GatherProgram=function(){return function(e,t,n){this.variableNames=[\"A\",\"indices\"];var r=e.slice();r[n]=t,this.outputShape=r,this.rank=r.length;var o=getCoordsDataType(this.rank),a=getSourceCoords(e,n);this.userCode=\"\\n void main() {\\n \"+o+\" resRC = getOutputCoords();\\n setOutput(getA(\"+a+\"));\\n }\\n \"}}();function getSourceCoords(e,t){var n=e.length;if(n>4)throw Error(\"Gather for rank \"+n+\" is not yet supported\");if(1===n)return\"int(getIndices(resRC))\";for(var r=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\"],o=[],a=0;a= \"+r);for(var o=0,a=0;a= \"+r);for(var o=0,a=0;a= \"+o);for(var a=getPackedMatrixTextureShapeWidthHeight(t,n),i=a[0],s=a[1],u=n%2==1,l=t%2==1,c=Math.floor(n/2),p=Math.floor(t/2),d=u?4:0,h=n,f=0,m=0;m= \"+o);for(var a=n%2==1,i=t%2==1,s=Math.floor(n/2),u=Math.floor(t/2),l=getPackedMatrixTextureShapeWidthHeight(t,n),c=l[0],p=l[1],d=a?4:0,h=n+(a?1:0),f=0,m=0,g=n,v=0;vr||n>r){o=\"[\"+t+\"x\"+n+\"]\";throw new Error(\"Requested texture size \"+o+\" greater than WebGL maximum on this browser / GPU \"+(\"[\"+r+\"x\"+r+\"]\")+\".\")}}function createFramebuffer(e){return throwIfNull(e,function(){return e.createFramebuffer()},\"Unable to create WebGLFramebuffer.\")}function bindVertexBufferToProgramAttribute(e,t,n,r,o,a,i){var s=e.getAttribLocation(t,n);return-1!==s&&(callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,r)}),callAndCheck(e,function(){return e.vertexAttribPointer(s,o,e.FLOAT,!1,a,i)}),callAndCheck(e,function(){return e.enableVertexAttribArray(s)}),!0)}function bindTextureUnit(e,t,n){validateTextureUnit(e,n),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)})}function unbindTextureUnit(e,t){validateTextureUnit(e,t),callAndCheck(e,function(){return e.activeTexture(e.TEXTURE0+t)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function getProgramUniformLocationOrThrow(e,t,n){return throwIfNull(e,function(){return e.getUniformLocation(t,n)},'uniform \"'+n+'\" not present in program.')}function getProgramUniformLocation(e,t,n){return e.getUniformLocation(t,n)}function bindTextureToProgramUniformSampler(e,t,n,r,o){callAndCheck(e,function(){return bindTextureUnit(e,n,o)}),callAndCheck(e,function(){return e.uniform1i(r,o)})}function bindCanvasToFramebuffer(e){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,null)}),callAndCheck(e,function(){return e.viewport(0,0,e.canvas.width,e.canvas.height)}),callAndCheck(e,function(){return e.scissor(0,0,e.canvas.width,e.canvas.height)})}function bindColorTextureToFramebuffer(e,t,n){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,n)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0)})}function unbindColorTextureFromFramebuffer(e,t){callAndCheck(e,function(){return e.bindFramebuffer(e.FRAMEBUFFER,t)}),callAndCheck(e,function(){return e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0)})}function validateFramebuffer(e){var t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error(\"Error binding framebuffer: \"+getFramebufferErrorMessage(e,t))}function getFramebufferErrorMessage(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return\"FRAMEBUFFER_INCOMPLETE_ATTACHMENT\";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return\"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return\"FRAMEBUFFER_INCOMPLETE_DIMENSIONS\";case e.FRAMEBUFFER_UNSUPPORTED:return\"FRAMEBUFFER_UNSUPPORTED\";default:return\"unknown error \"+t}}function throwIfNull(e,t,n){var r=callAndCheck(e,function(){return t()});if(null==r)throw new Error(n);return r}function validateTextureUnit(e,t){var n=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,r=t+e.TEXTURE0;if(rn)throw new Error(\"textureUnit must be in \"+(\"[gl.TEXTURE0, gl.TEXTURE\"+n+\"]\")+\".\")}function getTextureShapeFromLogicalShape(e,t){2!==t.length&&(t=squeezeShape(t).newShape);var n=queryMaxTextureSize(e),r=sizeFromShape(t);return t.length<=1&&r<=n?[r,1]:2===t.length&&t[0]<=n&&t[1]<=n?t:3===t.length&&t[0]<=n&&t[1]*t[2]<=n?[t[0],t[1]*t[2]]:4===t.length&&t[0]<=n&&t[1]*t[2]*t[3]<=n?[t[0],t[1]*t[2]*t[3]]:sizeToSquarishShape(r)}var webgl_util=Object.freeze({createWebGLRenderingContext:createWebGLRenderingContext,createWebGLRenderingContextFromCanvas:createWebGLRenderingContextFromCanvas,callAndCheck:callAndCheck,enableDebugWebGLErrorChecking:enableDebugWebGLErrorChecking,checkWebGLError:checkWebGLError,getWebGLErrorMessage:getWebGLErrorMessage,getExtensionOrThrow:getExtensionOrThrow,createVertexShader:createVertexShader,createFragmentShader:createFragmentShader,createProgram:createProgram,linkProgram:linkProgram,validateProgram:validateProgram,createStaticVertexBuffer:createStaticVertexBuffer,createStaticIndexBuffer:createStaticIndexBuffer,queryMaxTextureSize:queryMaxTextureSize,getNumChannels:getNumChannels,createTexture:createTexture,validateTextureSize:validateTextureSize,createFramebuffer:createFramebuffer,bindVertexBufferToProgramAttribute:bindVertexBufferToProgramAttribute,bindTextureUnit:bindTextureUnit,unbindTextureUnit:unbindTextureUnit,getProgramUniformLocationOrThrow:getProgramUniformLocationOrThrow,getProgramUniformLocation:getProgramUniformLocation,bindTextureToProgramUniformSampler:bindTextureToProgramUniformSampler,bindCanvasToFramebuffer:bindCanvasToFramebuffer,bindColorTextureToFramebuffer:bindColorTextureToFramebuffer,unbindColorTextureFromFramebuffer:unbindColorTextureFromFramebuffer,validateFramebuffer:validateFramebuffer,getFramebufferErrorMessage:getFramebufferErrorMessage,getTextureShapeFromLogicalShape:getTextureShapeFromLogicalShape});function getWebGLContextAttributes(){return{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0}}function createWebGLContext(e){var t,n=getWebGLContextAttributes();return callAndCheck(t=null!=e?createWebGLRenderingContextFromCanvas(e,n):createWebGLRenderingContext(n),function(){return t.disable(t.DEPTH_TEST)}),callAndCheck(t,function(){return t.disable(t.STENCIL_TEST)}),callAndCheck(t,function(){return t.disable(t.BLEND)}),callAndCheck(t,function(){return t.disable(t.DITHER)}),callAndCheck(t,function(){return t.disable(t.POLYGON_OFFSET_FILL)}),callAndCheck(t,function(){return t.disable(t.SAMPLE_COVERAGE)}),callAndCheck(t,function(){return t.enable(t.SCISSOR_TEST)}),callAndCheck(t,function(){return t.enable(t.CULL_FACE)}),callAndCheck(t,function(){return t.cullFace(t.BACK)}),t}function createVertexShader$1(e){return createVertexShader(e,\"\\n precision highp float;\\n attribute vec3 clipSpacePos;\\n attribute vec2 uv;\\n varying vec2 resultUV;\\n\\n void main() {\\n gl_Position = vec4(clipSpacePos, 1);\\n resultUV = uv;\\n }\")}function createVertexBuffer(e){return createStaticVertexBuffer(e,new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]))}function createIndexBuffer(e){return createStaticIndexBuffer(e,new Uint16Array([0,1,2,2,1,3]))}function getTextureConfig(e,t){var n,r,o,a,i,s,u,l=e;return 2===ENV.get(\"WEBGL_VERSION\")?(n=l.R32F,r=l.R16F,o=l.RGBA32F,a=l.RED,i=4,s=1,u=l.HALF_FLOAT):(n=e.RGBA,r=e.RGBA,o=l.RGBA,a=e.RGBA,i=4,s=4,u=null!=t?t.HALF_FLOAT_OES:null),{internalFormatFloat:n,internalFormatHalfFloat:r,internalFormatPackedFloat:o,textureFormatFloat:a,downloadTextureFormat:e.RGBA,downloadUnpackNumChannels:i,defaultNumChannels:s,textureTypeHalfFloat:u}}function createAndConfigureTexture(e,t,n,r,o,a){validateTextureSize(e,t,n);var i=createTexture(e),s=e.TEXTURE_2D;return callAndCheck(e,function(){return e.bindTexture(s,i)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MIN_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texParameteri(s,e.TEXTURE_MAG_FILTER,e.NEAREST)}),callAndCheck(e,function(){return e.texImage2D(s,0,r,t,n,0,o,a,null)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)}),i}function createFloat32MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,e.FLOAT)}function createFloat16MatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatFloat,r.textureFormatFloat,r.textureTypeHalfFloat)}function createUnsignedBytesMatrixTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],e.RGBA,e.RGBA,e.UNSIGNED_BYTE)}function createPackedMatrixTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n);return createAndConfigureTexture(e,o[0],o[1],r.internalFormatPackedFloat,e.RGBA,e.FLOAT)}function bindVertexProgramAttributeStreams(e,t,n){return callAndCheck(e,function(){return e.bindBuffer(e.ARRAY_BUFFER,n)}),bindVertexBufferToProgramAttribute(e,t,\"clipSpacePos\",n,3,20,0)&&bindVertexBufferToProgramAttribute(e,t,\"uv\",n,2,20,12)}function uploadPixelDataToTexture(e,t,n){callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,n)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadDataToTexture(e,t,n,r,o,a){validateTextureSize(e,n,r),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,t)}),callAndCheck(e,function(){return e.texSubImage2D(e.TEXTURE_2D,0,0,0,n,r,a,e.FLOAT,o)}),callAndCheck(e,function(){return e.bindTexture(e.TEXTURE_2D,null)})}function uploadMatrixToTexture(e,t,n,r,o,a,i){var s,u=getUnpackedMatrixTextureShapeWidthHeight(n,r),l=u[0],c=u[1];1===i.defaultNumChannels?s=o:encodeMatrixToUnpackedArray(o,s=new Float32Array(getUnpackedArraySizeFromMatrixSize(o.length,a)),a),uploadDataToTexture(e,t,l,c,s,i.textureFormatFloat)}function uploadMatrixToPackedTexture(e,t,n,r,o,a){var i=getPackedMatrixTextureShapeWidthHeight(n,r),s=i[0],u=i[1],l=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(n,r));encodeMatrixToPackedRGBA(o,n,r,l),uploadDataToTexture(e,t,s,u,l,e.RGBA)}function maybeCreateBufferFromOutputTexture(e,t,n,r,o){var a=t;if(2===ENV.get(\"WEBGL_VERSION\")){var i=e,s=i.createBuffer();callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,s)});var u=4*getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels);callAndCheck(e,function(){return e.bufferData(i.PIXEL_PACK_BUFFER,u,e.STATIC_DRAW)}),callAndCheck(e,function(){return i.readPixels(0,0,r,n,e.RGBA,e.FLOAT,0)}),callAndCheck(e,function(){return e.bindBuffer(i.PIXEL_PACK_BUFFER,null)}),a=s}return a}function downloadFloat32MatrixFromBuffer(e,t,n,r,o){var a=e,i=new Float32Array(getUnpackedArraySizeFromMatrixSize(n*r,o.downloadUnpackNumChannels));a.bindBuffer(e.ARRAY_BUFFER,t),a.getBufferSubData(e.ARRAY_BUFFER,0,i),a.bindBuffer(e.ARRAY_BUFFER,null);var s=new Float32Array(n*r);return decodeMatrixFromUnpackedArray(i,s,o.downloadUnpackNumChannels),s}function downloadFloat32MatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getUnpackedArraySizeFromMatrixSize(t*n,r.downloadUnpackNumChannels));callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromUnpackedArray(s,u,r.downloadUnpackNumChannels),u}function downloadByteEncodedFloatMatrixFromOutputTexture(e,t,n,r){var o=getUnpackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Uint8Array(getUnpackedArraySizeFromMatrixSize(t*n,4));return callAndCheck(e,function(){return e.readPixels(0,0,a,i,r.downloadTextureFormat,e.UNSIGNED_BYTE,s)}),new Float32Array(s.buffer)}function downloadMatrixFromPackedOutputTexture(e,t,n,r){var o=getPackedMatrixTextureShapeWidthHeight(t,n),a=o[0],i=o[1],s=new Float32Array(getPackedRGBAArraySizeFromMatrixShape(t,n));callAndCheck(e,function(){return e.readPixels(0,0,a,i,e.RGBA,e.FLOAT,s)});var u=new Float32Array(t*n);return decodeMatrixFromPackedRGBA(s,t,n,u)}var gpgpu_util=Object.freeze({getWebGLContextAttributes:getWebGLContextAttributes,createWebGLContext:createWebGLContext,createVertexShader:createVertexShader$1,createVertexBuffer:createVertexBuffer,createIndexBuffer:createIndexBuffer,getTextureConfig:getTextureConfig,createFloat32MatrixTexture:createFloat32MatrixTexture,createFloat16MatrixTexture:createFloat16MatrixTexture,createUnsignedBytesMatrixTexture:createUnsignedBytesMatrixTexture,createPackedMatrixTexture:createPackedMatrixTexture,bindVertexProgramAttributeStreams:bindVertexProgramAttributeStreams,uploadPixelDataToTexture:uploadPixelDataToTexture,uploadMatrixToTexture:uploadMatrixToTexture,uploadMatrixToPackedTexture:uploadMatrixToPackedTexture,maybeCreateBufferFromOutputTexture:maybeCreateBufferFromOutputTexture,downloadFloat32MatrixFromBuffer:downloadFloat32MatrixFromBuffer,downloadFloat32MatrixFromOutputTexture:downloadFloat32MatrixFromOutputTexture,downloadByteEncodedFloatMatrixFromOutputTexture:downloadByteEncodedFloatMatrixFromOutputTexture,downloadMatrixFromPackedOutputTexture:downloadMatrixFromPackedOutputTexture}),GPGPUContext=function(){function e(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.autoDebugValidate=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[],this.gl=null!=e?e:createWebGLContext(),1===ENV.get(\"WEBGL_VERSION\")?(this.textureFloatExtension=getExtensionOrThrow(this.gl,\"OES_texture_float\"),this.colorBufferFloatExtension=this.gl.getExtension(\"WEBGL_color_buffer_float\"),ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")||(this.textureHalfFloatExtension=getExtensionOrThrow(this.gl,\"OES_texture_half_float\"),this.colorBufferHalfFloatExtension=this.gl.getExtension(\"EXT_color_buffer_half_float\"))):this.colorBufferFloatExtension=getExtensionOrThrow(this.gl,\"EXT_color_buffer_float\"),this.loseContextExtension=getExtensionOrThrow(this.gl,\"WEBGL_lose_context\"),this.vertexBuffer=createVertexBuffer(this.gl),this.indexBuffer=createIndexBuffer(this.gl),this.framebuffer=createFramebuffer(this.gl),this.textureConfig=getTextureConfig(this.gl,this.textureHalfFloatExtension)}return e.prototype.dispose=function(){var e=this;if(!this.disposed){null!=this.program&&console.warn(\"Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing.\"),null!=this.outputTexture&&console.warn(\"Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.\");var t=this.gl;callAndCheck(t,function(){return t.finish()}),callAndCheck(t,function(){return t.bindFramebuffer(t.FRAMEBUFFER,null)}),callAndCheck(t,function(){return t.deleteFramebuffer(e.framebuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.vertexBuffer)}),callAndCheck(t,function(){return t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}),callAndCheck(t,function(){return t.deleteBuffer(e.indexBuffer)}),this.loseContextExtension.loseContext(),this.disposed=!0}},e.prototype.enableAutomaticDebugValidation=function(e){this.autoDebugValidate=e,enableDebugWebGLErrorChecking(e)},e.prototype.createFloat32MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat32MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createFloat16MatrixTexture=function(e,t){return this.throwIfDisposed(),createFloat16MatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.createUnsignedBytesMatrixTexture=function(e,t){return this.throwIfDisposed(),createUnsignedBytesMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.uploadPixelDataToTexture=function(e,t){this.throwIfDisposed(),uploadPixelDataToTexture(this.gl,e,t)},e.prototype.createPackedMatrixTexture=function(e,t){return this.throwIfDisposed(),createPackedMatrixTexture(this.gl,e,t,this.textureConfig)},e.prototype.deleteMatrixTexture=function(e){var t=this;this.throwIfDisposed(),this.outputTexture===e&&(unbindColorTextureFromFramebuffer(this.gl,this.framebuffer),this.outputTexture=null),callAndCheck(this.gl,function(){return t.gl.deleteTexture(e)})},e.prototype.uploadMatrixToTexture=function(e,t,n,r){this.throwIfDisposed();var o=getNumChannels();return uploadMatrixToTexture(this.gl,e,t,n,r,o,this.textureConfig)},e.prototype.uploadMatrixToPackedTexture=function(e,t,n,r){return this.throwIfDisposed(),uploadMatrixToPackedTexture(this.gl,e,t,n,r,this.textureConfig)},e.prototype.downloadFloat32MatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadFloat32MatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadByteEncodedFloatMatrixFromOutputTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadByteEncodedFloatMatrixFromOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.downloadFloat32MatrixFromBuffer=function(e,t,n){return downloadFloat32MatrixFromBuffer(this.gl,e,t,n,this.textureConfig)},e.prototype.maybeCreateBufferFromTexture=function(e,t,n){this.bindTextureToFrameBuffer(e);var r=maybeCreateBufferFromOutputTexture(this.gl,e,t,n,this.textureConfig);return this.unbindTextureToFrameBuffer(),r},e.prototype.createAndWaitForFence=function(){var e=this.createFence(this.gl);return this.pollFence(e)},e.prototype.createFence=function(e){var t,n,r=this;if(ENV.get(\"WEBGL_FENCE_API_ENABLED\")){var o=e,a=o.fenceSync(o.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),n=function(){var e=o.clientWaitSync(a,0,0);return e===o.ALREADY_SIGNALED||e===o.CONDITION_SATISFIED},t=a}else ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?(t=this.beginQuery(),this.endQuery(),n=function(){return r.isQueryAvailable(t,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))}):n=function(){return!0};return{query:t,isFencePassed:n}},e.prototype.downloadMatrixFromPackedTexture=function(e,t,n){var r=this;return this.downloadMatrixDriver(e,function(){return downloadMatrixFromPackedOutputTexture(r.gl,t,n,r.textureConfig)})},e.prototype.createProgram=function(e){this.throwIfDisposed();var t=this.gl,n=createFragmentShader(t,e),r=createVertexShader$1(t),o=createProgram(t);return callAndCheck(t,function(){return t.attachShader(o,r)}),callAndCheck(t,function(){return t.attachShader(o,n)}),linkProgram(t,o),this.autoDebugValidate&&validateProgram(t,o),this.vertexAttrsAreBound||(this.setProgram(o),this.vertexAttrsAreBound=bindVertexProgramAttributeStreams(t,this.program,this.vertexBuffer)),o},e.prototype.deleteProgram=function(e){var t=this;this.throwIfDisposed(),e===this.program&&(this.program=null),null!=e&&callAndCheck(this.gl,function(){return t.gl.deleteProgram(e)})},e.prototype.setProgram=function(e){var t=this;this.throwIfDisposed(),this.program=e,null!=this.program&&this.autoDebugValidate&&validateProgram(this.gl,this.program),callAndCheck(this.gl,function(){return t.gl.useProgram(e)})},e.prototype.getUniformLocation=function(e,t,n){return void 0===n&&(n=!0),this.throwIfDisposed(),n?getProgramUniformLocationOrThrow(this.gl,e,t):getProgramUniformLocation(this.gl,e,t)},e.prototype.getAttributeLocation=function(e,t){var n=this;return this.throwIfDisposed(),callAndCheck(this.gl,function(){return n.gl.getAttribLocation(e,t)})},e.prototype.getUniformLocationNoThrow=function(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)},e.prototype.setInputMatrixTexture=function(e,t,n){this.throwIfDisposed(),this.throwIfNoProgram(),bindTextureToProgramUniformSampler(this.gl,this.program,e,t,n)},e.prototype.setOutputMatrixTexture=function(e,t,n){this.setOutputMatrixTextureDriver(e,n,t)},e.prototype.setOutputPackedMatrixTexture=function(e,t,n){this.throwIfDisposed();var r=getPackedMatrixTextureShapeWidthHeight(t,n),o=r[0],a=r[1];this.setOutputMatrixTextureDriver(e,o,a)},e.prototype.setOutputMatrixWriteRegion=function(e,t,n,r){this.setOutputMatrixWriteRegionDriver(n,e,r,t)},e.prototype.setOutputPackedMatrixWriteRegion=function(e,t,n,r){throw new Error(\"setOutputPackedMatrixWriteRegion not implemented.\")},e.prototype.debugValidate=function(){null!=this.program&&validateProgram(this.gl,this.program),validateFramebuffer(this.gl)},e.prototype.executeProgram=function(){this.throwIfDisposed(),this.throwIfNoProgram();var e=this.gl;this.autoDebugValidate&&this.debugValidate(),callAndCheck(e,function(){return e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)})},e.prototype.blockUntilAllProgramsCompleted=function(){var e=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return e.gl.finish()})},e.prototype.getQueryTimerExtension=function(){return null==this.disjointQueryTimerExtension&&(this.disjointQueryTimerExtension=getExtensionOrThrow(this.gl,2===ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")?\"EXT_disjoint_timer_query_webgl2\":\"EXT_disjoint_timer_query\")),this.disjointQueryTimerExtension},e.prototype.getQueryTimerExtensionWebGL2=function(){return this.getQueryTimerExtension()},e.prototype.getQueryTimerExtensionWebGL1=function(){return this.getQueryTimerExtension()},e.prototype.beginQuery=function(){if(2===ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")){var e=this.gl,t=this.getQueryTimerExtensionWebGL2(),n=e.createQuery();return e.beginQuery(t.TIME_ELAPSED_EXT,n),n}var r=this.getQueryTimerExtensionWebGL1(),o=r.createQueryEXT();return r.beginQueryEXT(r.TIME_ELAPSED_EXT,o),o},e.prototype.endQuery=function(){if(2!==ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")){var e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}else{var t=this.gl,n=this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT)}},e.prototype.waitForQueryAndGetTime=function(e){return __awaiter(this,void 0,void 0,function(){var t=this;return __generator(this,function(n){switch(n.label){case 0:return[4,repeatedTry(function(){return t.isQueryAvailable(e,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))})];case 1:return n.sent(),[2,this.getQueryTime(e,ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\"))]}})})},e.prototype.getQueryTime=function(e,t){if(0===t)return null;if(2===t){var n=this.gl;return n.getQueryParameter(e,n.QUERY_RESULT)/1e6}var r=this.getQueryTimerExtensionWebGL1();return r.getQueryObjectEXT(e,r.QUERY_RESULT_EXT)/1e6},e.prototype.isQueryAvailable=function(e,t){if(0===t)return!0;if(2===t){var n=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=n.getQueryParameter(e,n.QUERY_RESULT_AVAILABLE);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}o=(r=this.getQueryTimerExtensionWebGL1()).getQueryObjectEXT(e,r.QUERY_RESULT_AVAILABLE_EXT);return null==this.disjoint&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint},e.prototype.pollFence=function(e){var t=this;return new Promise(function(n){t.addItemToPoll(function(){return e.isFencePassed()},function(){return n()})})},e.prototype.pollItems=function(){for(var e=binSearchLastTrue(this.itemsToPoll.map(function(e){return e.isDoneFn})),t=0;t<=e;++t){(0,this.itemsToPoll[t].resolveFn)()}this.itemsToPoll=this.itemsToPoll.slice(e+1)},e.prototype.addItemToPoll=function(e,t){var n=this;this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),this.itemsToPoll.length>1||repeatedTry(function(){return n.pollItems(),0===n.itemsToPoll.length})},e.prototype.bindTextureToFrameBuffer=function(e){this.throwIfDisposed(),bindColorTextureToFramebuffer(this.gl,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)},e.prototype.unbindTextureToFrameBuffer=function(){null!=this.outputTexture?(bindColorTextureToFramebuffer(this.gl,this.outputTexture,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(this.gl)):unbindColorTextureFromFramebuffer(this.gl,this.framebuffer)},e.prototype.downloadMatrixDriver=function(e,t){this.bindTextureToFrameBuffer(e);var n=t();return this.unbindTextureToFrameBuffer(),n},e.prototype.setOutputMatrixTextureDriver=function(e,t,n){this.throwIfDisposed();var r=this.gl;bindColorTextureToFramebuffer(r,e,this.framebuffer),this.autoDebugValidate&&validateFramebuffer(r),this.outputTexture=e,callAndCheck(r,function(){return r.viewport(0,0,t,n)}),callAndCheck(r,function(){return r.scissor(0,0,t,n)})},e.prototype.setOutputMatrixWriteRegionDriver=function(e,t,n,r){var o=this;this.throwIfDisposed(),callAndCheck(this.gl,function(){return o.gl.scissor(e,t,n,r)})},e.prototype.throwIfDisposed=function(){if(this.disposed)throw new Error(\"Attempted to use disposed GPGPUContext.\")},e.prototype.throwIfNoProgram=function(){if(null==this.program)throw new Error(\"No GPU program is currently set.\")},e}();function binSearchLastTrue(e){for(var t=0,n=e.length-1,r=-1;t<=n;){var o=t+n>>1;e[o]()?(r=o,t=o+1):n=o-1}return r}function compileProgram(e,t,n,r){for(var o=t.userCode,a=n.map(function(e,n){var r={logicalShape:e.tensor.shape,texShape:e.isUniform?null:e.texData.texShape,isUniform:e.isUniform};return{name:t.variableNames[n],shapeInfo:r}}),i=a.map(function(e){return e.shapeInfo}),s={logicalShape:r.tensor.shape,texShape:r.texData.texShape,isUniform:!1},u=makeShader(a,s,o,!0===t.supportsBroadcasting),l=e.createProgram(u),c={},p=0;p= 0 && idx <= \"+s+\") {\\n float z = getX(b, r, c, idx);\\n sum += z * z;\\n }\\n }\\n float val = x * \"+a+\";\\n setOutput(val);\\n }\\n \"}}(),LRNGradProgram=function(){return function(e,t,n,r,o){this.variableNames=[\"inputImage\",\"outputImage\",\"dy\"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=t,this.bias=n,this.alpha=r,this.beta=o,this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float result = 0.0;\\n for (int d = 0; d < \"+this.depth+\"; ++d) {\\n int depthBegin = int(max(0.0, float(d - \"+t+\")));\\n int depthEnd = int(min(float(\"+this.depth+\"),\\n float(d + \"+t+\" + 1)));\\n\\n const int MIN_DEPTH_BEGIN = 0;\\n const int MAX_DEPTH_END = \"+this.depth+\";\\n\\n float norm = 0.0;\\n for (int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k) {\\n if (k < depthBegin){\\n continue;\\n }\\n else if (k >= depthBegin && k < depthEnd) {\\n norm += getInputImage(b, r, c, k) * getInputImage(b, r, c, k);\\n }\\n else {\\n break;\\n }\\n }\\n\\n norm = float(\"+r+\") * norm + float(\"+n+\");\\n\\n for(int k = MIN_DEPTH_BEGIN; k < MAX_DEPTH_END; ++k){\\n if (k < depthBegin){\\n continue;\\n }\\n else if (k >= depthBegin && k < depthEnd){\\n float dyi = -2.0 * float(\"+r+\")\\n * float(\"+o+\")\\n * getInputImage(b ,r ,c, k) * getOutputImage(b, r, c, d)\\n / norm;\\n if (k == d) {\\n dyi += pow(norm, -1.0 * \"+o+\");\\n }\\n if (k == coords[3]) {\\n dyi *= getDy(b, r, c, d);\\n result += dyi;\\n }\\n }\\n else {\\n break;\\n }\\n }\\n }\\n setOutput(result);\\n }\\n \"}}(),MaxPool2DBackpropProgram=function(){return function(e){this.variableNames=[\"dy\",\"maxPos\"],this.outputShape=e.inShape;var t=e.filterHeight,n=e.filterWidth,r=e.strideHeight,o=e.strideWidth,a=t-1-e.padInfo.top,i=n-1-e.padInfo.left,s=t*n-1;this.userCode=\"\\n const ivec2 pads = ivec2(\"+a+\", \"+i+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n\\n ivec2 dyRCCorner = coords.yz - pads;\\n int dyRCorner = dyRCCorner.x;\\n int dyCCorner = dyRCCorner.y;\\n\\n // Convolve dy(?, ?, d) with pos mask(:, :, d) to get dx(xR, xC, d).\\n // ? = to be determined. : = across all values in that axis.\\n float dotProd = 0.0;\\n for (int wR = 0; wR < \"+t+\"; wR++) {\\n float dyR = float(dyRCorner + wR) / \"+r+\".0;\\n\\n if (dyR < 0.0 || dyR >= \"+e.outHeight+\".0 || fract(dyR) > 0.0) {\\n continue;\\n }\\n int idyR = int(dyR);\\n\\n for (int wC = 0; wC < \"+n+\"; wC++) {\\n float dyC = float(dyCCorner + wC) / \"+o+\".0;\\n\\n if (dyC < 0.0 || dyC >= \"+e.outWidth+\".0 ||\\n fract(dyC) > 0.0) {\\n continue;\\n }\\n int idyC = int(dyC);\\n\\n float dyValue = getDy(b, idyR, idyC, d);\\n int maxPosValue = \"+s+\" - int(getMaxPos(b, idyR, idyC, d));\\n\\n // Get the current value, check it against the value from the\\n // position matrix.\\n int curPosValue = wR * \"+n+\" + wC;\\n float mask = float(maxPosValue == curPosValue ? 1.0 : 0.0);\\n\\n dotProd += dyValue * mask;\\n }\\n }\\n setOutput(dotProd);\\n }\\n \"}}(),MatMulProgram=function(){return function(e,t,n,r){void 0===n&&(n=!1),void 0===r&&(r=!1),this.variableNames=[\"matrixA\",\"matrixB\"];var o=n?e[1]:e[0],a=r?t[0]:t[1],i=n?e[0]:e[1];this.outputShape=[o,a];var s=function(e,t){return n?t+\" + \"+e+\", aRow\":\"aRow, \"+t+\" + \"+e},u=function(e,t){return r?\"bCol, \"+t+\" + \"+e:t+\" + \"+e+\", bCol\"},l=4*Math.floor(i/4),c=i%4;this.userCode=\" float dotARowBCol(int aRow, int bCol) {\\n float result = 0.0;\\n for (int i = 0; i < \"+l+\"; i += 4) {\\n vec4 a = vec4(\\n getMatrixA(\"+s(0,\"i\")+\"),\\n getMatrixA(\"+s(1,\"i\")+\"),\\n getMatrixA(\"+s(2,\"i\")+\"),\\n getMatrixA(\"+s(3,\"i\")+\")\\n );\\n vec4 b = vec4(\\n getMatrixB(\"+u(0,\"i\")+\"),\\n getMatrixB(\"+u(1,\"i\")+\"),\\n getMatrixB(\"+u(2,\"i\")+\"),\\n getMatrixB(\"+u(3,\"i\")+\")\\n );\\n\\n result += dot(a, b);\\n }\\n\\n if (\"+(1===c)+\") {\\n result += getMatrixA(\"+s(0,l)+\") *\\n getMatrixB(\"+u(0,l)+\");\\n } else if (\"+(2===c)+\") {\\n vec2 a = vec2(\\n getMatrixA(\"+s(0,l)+\"),\\n getMatrixA(\"+s(1,l)+\")\\n );\\n vec2 b = vec2(\\n getMatrixB(\"+u(0,l)+\"),\\n getMatrixB(\"+u(1,l)+\")\\n );\\n result += dot(a, b);\\n } else if (\"+(3===c)+\") {\\n vec3 a = vec3(\\n getMatrixA(\"+s(0,l)+\"),\\n getMatrixA(\"+s(1,l)+\"),\\n getMatrixA(\"+s(2,l)+\")\\n );\\n vec3 b = vec3(\\n getMatrixB(\"+u(0,l)+\"),\\n getMatrixB(\"+u(1,l)+\"),\\n getMatrixB(\"+u(2,l)+\")\\n );\\n result += dot(a, b);\\n }\\n\\n return result;\\n }\\n\\n void main() {\\n ivec2 resRC = getOutputCoords();\\n setOutput(dotARowBCol(resRC.x, resRC.y));\\n }\\n \"}}(),MultinomialProgram=function(){function e(e,t,n){this.variableNames=[\"probs\"],this.outputShape=[e,n],this.userCode=\"\\n uniform float seed;\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n\\n float r = random(seed);\\n float cdf = 0.0;\\n\\n for (int i = 0; i < \"+(t-1)+\"; i++) {\\n cdf += getProbs(batch, i);\\n\\n if (r < cdf) {\\n setOutput(float(i));\\n return;\\n }\\n }\\n\\n // If no other event happened, last event happened.\\n setOutput(float(\"+(t-1)+\"));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(e){var t=this;return function(n,r){null==t.seedLoc&&(t.seedLoc=n.getUniformLocation(r,\"seed\")),n.gl.uniform1f(t.seedLoc,e)}},e}(),OneHotProgram=function(){return function(e,t,n,r){this.variableNames=[\"indices\"],this.outputShape=[e,t],this.userCode=\"\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int index = round(getIndices(coords.x));\\n setOutput(mix(float(\"+r+\"), float(\"+n+\"),\\n float(index == coords.y)));\\n }\\n \"}}(),PadProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=t.map(function(t,n){return t[0]+e[n]+t[1]});var r=e.length,o=getCoordsDataType(r),a=t.map(function(e){return e[0]}).join(\",\"),i=t.map(function(t,n){return t[0]+e[n]}).join(\",\"),s=[\"coords[0]\",\"coords[1]\",\"coords[2]\",\"coords[3]\"].slice(0,r);this.userCode=1!==r?\"\\n \"+o+\" start = \"+o+\"(\"+a+\");\\n \"+o+\" end = \"+o+\"(\"+i+\");\\n\\n void main() {\\n \"+o+\" outC = getOutputCoords();\\n if (any(lessThan(outC, start)) || any(greaterThanEqual(outC, end))) {\\n setOutput(float(\"+n+\"));\\n } else {\\n \"+o+\" coords = outC - start;\\n setOutput(getX(\"+s+\"));\\n }\\n }\\n \":\"\\n int start = \"+a+\";\\n int end = \"+i+\";\\n\\n void main() {\\n int outC = getOutputCoords();\\n if (outC < start || outC >= end) {\\n setOutput(float(\"+n+\"));\\n } else {\\n setOutput(getX(outC - start));\\n }\\n }\\n \"}}(),Pool2DProgram=function(){return function(e,t,n){if(this.variableNames=[\"x\"],\"avg\"===t&&n)throw new Error(\"Cannot compute positions for average pool.\");var r=e.filterHeight,o=e.filterWidth,a=e.strideHeight,i=e.strideWidth,s=e.padInfo.top,u=e.padInfo.left;this.outputShape=e.outShape;var l=\"avg\"===t,c=\"0.0\";if(l||(c=\"-1.0 / 0.0\"),n)this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+s+\", \"+u+\");\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // max/min x(?, ?, d) to get y(yR, yC, d).\\n // ? = to be determined\\n float minMaxValue = 0.0;\\n float minMaxValueFound = 0.0;\\n int minMaxPosition = 0;\\n float avgValue = 0.0;\\n\\n for (int wR = 0; wR < \"+r+\"; wR++) {\\n int xR = xRCorner + wR;\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+o+\"; wC++) {\\n int xC = xCCorner + wC;\\n\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n continue;\\n }\\n\\n float value = getX(batch, xR, xC, d);\\n\\n // If a min / max value has already been found, use it. If not,\\n // use the current value.\\n float currMinMaxValue = mix(\\n value, minMaxValue, minMaxValueFound);\\n if (value >= currMinMaxValue) {\\n minMaxValue = value;\\n minMaxValueFound = 1.0;\\n minMaxPosition = wR * \"+o+\" + wC;\\n }\\n }\\n }\\n setOutput(float(minMaxPosition));\\n }\\n \";else{var p=t+\"(\"+t+\"(\"+t+\"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])\";\"avg\"===t&&(p=\"avgValue / count\");var d=4*Math.floor(o/4),h=o%4,f=\"\\n if (\"+l+\") {\\n avgValue += dot(values, ones);\\n } else {\\n minMaxValue = max(values, minMaxValue);\\n }\\n \";this.userCode=\"\\n const ivec2 strides = ivec2(\"+a+\", \"+i+\");\\n const ivec2 pads = ivec2(\"+s+\", \"+u+\");\\n const float initializationValue = \"+c+\";\\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\\n\\n float count = 0.0;\\n\\n float getValue(int batch, int xR, int xC, int d) {\\n if (xC < 0 || xC >= \"+e.inWidth+\") {\\n return initializationValue;\\n }\\n count += 1.0;\\n return getX(batch, xR, xC, d);\\n }\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int batch = coords[0];\\n int d = coords[3];\\n\\n ivec2 xRCCorner = coords.yz * strides - pads;\\n int xRCorner = xRCCorner.x;\\n int xCCorner = xRCCorner.y;\\n\\n // max/min x(?, ?, d) to get y(yR, yC, d).\\n // ? = to be determined\\n vec4 minMaxValue = vec4(\"+c+\");\\n float avgValue = 0.0;\\n count = 0.0;\\n\\n for (int wR = 0; wR < \"+r+\"; wR++) {\\n int xR = xRCorner + wR;\\n\\n if (xR < 0 || xR >= \"+e.inHeight+\") {\\n continue;\\n }\\n\\n for (int wC = 0; wC < \"+d+\"; wC += 4) {\\n int xC = xCCorner + wC;\\n\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n getValue(batch, xR, xC + 2, d),\\n getValue(batch, xR, xC + 3, d)\\n );\\n\\n \"+f+\"\\n }\\n\\n int xC = xCCorner + \"+d+\";\\n if (\"+(1===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+f+\"\\n } else if (\"+(2===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+f+\"\\n } else if (\"+(3===h)+\") {\\n vec4 values = vec4(\\n getValue(batch, xR, xC, d),\\n getValue(batch, xR, xC + 1, d),\\n getValue(batch, xR, xC + 2, d),\\n initializationValue\\n );\\n\\n \"+f+\"\\n }\\n }\\n setOutput(\"+p+\");\\n }\\n \"}}}(),ReduceProgram=function(){return function(e,t){this.variableNames=[\"x\"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=Math.ceil(o/n);this.outputShape=[r,a];var i=\"0.0\",s=\"\";\"min\"===t?(i=\"1.0 / 0.0\",s=\"min\"):\"max\"===t&&(i=\"-1.0 / 0.0\",s=\"max\");var u=t+\"(\"+t+\"(\"+t+\"(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])\";\"sum\"===t?u=\"sumValue\":\"all\"===t?u=\"allValue\":\"any\"===t&&(u=\"anyValue\");var l=4*Math.floor(n/4),c=n%4,p=\"\\n if (\"+(\"sum\"===t)+\") {\\n sumValue += dot(values, ones);\\n } else {\\n minMaxValue = \"+s+\"(values, minMaxValue);\\n }\\n \",d=\"vec4\";\"all\"===t?(i=\"1.0\",p=\"\\n bool reducedAllValue = all(values);\\n float floatedReducedAllValue = float(reducedAllValue);\\n allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0);\\n \",d=\"bvec4\"):\"any\"===t&&(i=\"0.0\",p=\"\\n bool reducedAnyValue = any(values);\\n float floatedReducedAnyValue = float(reducedAnyValue);\\n anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0);\\n \",d=\"bvec4\");var h=\"\";o%n>0&&(h=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return initializationValue;\\n }\\n \"),this.userCode=\"\\n const float initializationValue = \"+i+\";\\n const vec4 ones = vec4(1.0, 1.0, 1.0, 1.0);\\n\\n float getValue(int batch, int inIdx) {\\n \"+h+\"\\n return getX(batch, inIdx);\\n }\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = outIdx * \"+n+\";\\n\\n vec4 minMaxValue = vec4(\"+i+\");\\n float sumValue = 0.0;\\n float allValue = 1.0;\\n float anyValue = 0.0;\\n\\n for (int i = 0; i < \"+l+\"; i += 4) {\\n int inIdx = inOffset + i;\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n getValue(batch, inIdx + 3)\\n );\\n\\n \"+p+\"\\n }\\n\\n int inIdx = inOffset + \"+l+\";\\n if (\"+(1===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+p+\"\\n } else if (\"+(2===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n initializationValue,\\n initializationValue\\n );\\n\\n \"+p+\"\\n } else if (\"+(3===c)+\") {\\n \"+d+\" values = \"+d+\"(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n initializationValue\\n );\\n\\n \"+p+\"\\n }\\n setOutput(\"+u+\");\\n }\\n \"}}(),ResizeBilinearBackpropProgram=function(){return function(e,t,n){this.variableNames=[\"dy\"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float accumulator = 0.0;\\n\\n const float heightScale = float(\"+p+\");\\n const float widthScale = float(\"+d+\");\\n\\n const float invHeightScale = float(\"+h+\");\\n const float invWidthScale = float(\"+f+\");\\n\\n const int winHeight = int(\"+m+\");\\n const int winWidth = int(\"+g+\");\\n\\n // Compute bounds for where in dy we will look\\n float startRLerp = floor(float(r) * invHeightScale);\\n int startDyR = int(startRLerp - float(winHeight / 2));\\n\\n float startCLerp = floor(float(c) * invWidthScale);\\n int startDyC = int(startCLerp - float(winWidth / 2));\\n\\n // Loop over dy\\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\\n int dyR = dyROffset + startDyR;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyR < 0 || dyR >= \"+s+\") {\\n continue;\\n }\\n\\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\\n int dyC = dyCOffset + startDyC;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyC < 0 || dyC >= \"+u+\") {\\n continue;\\n }\\n\\n float dxR = float(dyR) * heightScale;\\n int topDxRIndex = int(floor(dxR));\\n int bottomDxRIndex = int(min(ceil(dxR), \"+(o-1)+\".0));\\n float dxRLerp = dxR - float(topDxRIndex);\\n float inverseDxRLerp = 1.0 - dxRLerp;\\n\\n float dxC = float(dyC) * widthScale;\\n int leftDxCIndex = int(floor(dxC));\\n int rightDxCIndex = int(min(ceil(dxC), \"+(a-1)+\".0));\\n float dxCLerp = dxC - float(leftDxCIndex);\\n float inverseDxCLerp = 1.0 - dxCLerp;\\n\\n if (r == topDxRIndex && c == leftDxCIndex) {\\n // topLeft\\n accumulator +=\\n getDy(b, dyR, dyC, d) * inverseDxRLerp * inverseDxCLerp;\\n }\\n\\n if (r == topDxRIndex && c == rightDxCIndex) {\\n // topRight\\n accumulator += getDy(b, dyR, dyC, d) * inverseDxRLerp * dxCLerp;\\n }\\n\\n if (r == bottomDxRIndex && c == leftDxCIndex) {\\n // bottomLeft\\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * inverseDxCLerp;\\n }\\n\\n if (r == bottomDxRIndex && c == rightDxCIndex) {\\n // bottomRight\\n accumulator += getDy(b, dyR, dyC, d) * dxRLerp * dxCLerp;\\n }\\n }\\n }\\n // End loop over dy\\n\\n setOutput(accumulator);\\n }\\n \"}}(),ResizeBilinearProgram=function(){return function(e,t,n,r){this.variableNames=[\"A\"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n];this.userCode=\"\\n const vec2 effectiveInputOverOutputRatioRC = vec2(\\n \"+u[0]/l[0]+\",\\n \"+u[1]/l[1]+\");\\n const vec2 inputShapeRC = vec2(\"+a+\".0, \"+i+\".0);\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n ivec2 yRC = coords.yz;\\n\\n // Fractional source index.\\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\\n\\n // Compute the four integer indices.\\n ivec2 sourceFloorRC = ivec2(sourceFracIndexRC);\\n ivec2 sourceCeilRC = ivec2(\\n min(inputShapeRC - 1.0, ceil(sourceFracIndexRC)));\\n\\n float topLeft = getA(b, sourceFloorRC.x, sourceFloorRC.y, d);\\n float bottomLeft = getA(b, sourceCeilRC.x, sourceFloorRC.y, d);\\n float topRight = getA(b, sourceFloorRC.x, sourceCeilRC.y, d);\\n float bottomRight = getA(b, sourceCeilRC.x, sourceCeilRC.y, d);\\n\\n vec2 fracRC = sourceFracIndexRC - vec2(sourceFloorRC);\\n\\n float top = topLeft + (topRight - topLeft) * fracRC.y;\\n float bottom = bottomLeft + (bottomRight - bottomLeft) * fracRC.y;\\n float newValue = top + (bottom - top) * fracRC.x;\\n\\n setOutput(newValue);\\n }\\n \"}}(),ResizeNearestNeigborBackpropProgram=function(){return function(e,t,n){this.variableNames=[\"dy\"],this.outputShape=[],this.outputShape=t.shape;var r=t.shape,o=r[1],a=r[2],i=e.shape,s=i[1],u=i[2],l=[n&&s>1?o-1:o,n&&u>1?a-1:a],c=[n&&s>1?s-1:s,n&&u>1?u-1:u],p=l[0]/c[0],d=l[1]/c[1],h=1/p,f=1/d,m=2*Math.ceil(h)+2,g=2*Math.ceil(f)+2;this.userCode=\"\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n int r = coords[1];\\n int c = coords[2];\\n\\n float accumulator = 0.0;\\n\\n const float heightScale = float(\"+p+\");\\n const float widthScale = float(\"+d+\");\\n\\n const float invHeightScale = float(\"+h+\");\\n const float invWidthScale = float(\"+f+\");\\n\\n const int winHeight = int(\"+m+\");\\n const int winWidth = int(\"+g+\");\\n\\n // Compute bounds for where in dy we will look\\n float startRLerp = floor(float(r) * invHeightScale);\\n int startDyR = int(floor(startRLerp - float(winHeight / 2)));\\n\\n float startCLerp = floor(float(c) * invWidthScale);\\n int startDyC = int(floor(startCLerp - float(winWidth / 2)));\\n\\n // Loop over dy\\n for (int dyROffset = 0; dyROffset < winHeight; dyROffset++) {\\n int dyR = dyROffset + startDyR;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyR < 0 || dyR >= \"+s+\") {\\n continue;\\n }\\n\\n for (int dyCOffset = 0; dyCOffset < winWidth; dyCOffset++) {\\n int dyC = dyCOffset + startDyC;\\n\\n // Guard against the window exceeding the bounds of dy\\n if (dyC < 0 || dyC >= \"+u+\") {\\n continue;\\n }\\n\\n float sourceFracRow =\\n float(\"+l[0]+\") *\\n (float(dyR) / float(\"+c[0]+\"));\\n\\n float sourceFracCol =\\n float(\"+l[1]+\") *\\n (float(dyC) / float(\"+c[1]+\"));\\n\\n int sourceNearestRow = int(min(\\n float(int(\"+o+\") - 1),\\n \"+n+\" ? float(round(sourceFracRow)) :\\n float(floor(sourceFracRow))));\\n\\n int sourceNearestCol = int(min(\\n float(int(\"+a+\") - 1),\\n \"+n+\" ? float(round(sourceFracCol)) :\\n float(floor(sourceFracCol))));\\n\\n if (r == sourceNearestRow && c == sourceNearestCol) {\\n accumulator += getDy(b, dyR, dyC, d);\\n }\\n }\\n }\\n // End loop over dy\\n\\n setOutput(accumulator);\\n }\\n \"}}(),ResizeNearestNeighborProgram=function(){return function(e,t,n,r){this.variableNames=[\"A\"],this.outputShape=[];var o=e[0],a=e[1],i=e[2],s=e[3];this.outputShape=[o,t,n,s];var u=[r&&t>1?a-1:a,r&&n>1?i-1:i],l=[r&&t>1?t-1:t,r&&n>1?n-1:n],c=r?\"0.5\":\"0.0\";this.userCode=\"\\n const vec2 effectiveInputOverOutputRatioRC = vec2(\\n \"+u[0]/l[0]+\",\\n \"+u[1]/l[1]+\");\\n const vec2 inputShapeRC = vec2(\"+a+\".0, \"+i+\".0);\\n\\n void main() {\\n ivec4 coords = getOutputCoords();\\n int b = coords[0];\\n int d = coords[3];\\n ivec2 yRC = coords.yz;\\n\\n // Fractional source index.\\n vec2 sourceFracIndexRC = vec2(yRC) * effectiveInputOverOutputRatioRC;\\n\\n // Compute the coordinators of nearest neighbor point.\\n ivec2 sourceNearestRC = ivec2(\\n min(inputShapeRC - 1.0, floor(sourceFracIndexRC + \"+c+\")));\\n\\n float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d);\\n\\n setOutput(newValue);\\n }\\n \"}}(),ReverseProgram=function(){return function(e,t){this.variableNames=[\"x\"];var n=e.length;if(n>4)throw new Error(\"WebGL backend: Reverse of rank-\"+n+\" tensor is not yet supported\");if(this.outputShape=e,1!==n){var r=e.map(function(n,r){return function(n){return-1!==t.indexOf(n)&&1!==e[n]?e[n]+\" - coords[\"+n+\"] - 1\":\"coords[\"+n+\"]\"}(r)}).join(\",\"),o=getCoordsDataType(n);this.userCode=\"\\n void main() {\\n \"+o+\" coords = getOutputCoords();\\n setOutput(getX(\"+r+\"));\\n }\\n \"}else this.userCode=\"\\n void main() {\\n int coord = getOutputCoords();\\n setOutput(getX(\"+e[0]+\" - coord - 1));\\n }\\n \"}}(),SegmentOpProgram=function(){return function(e,t){this.variableNames=[\"x\",\"segmentIds\"];var n=e.windowSize,r=e.batchSize,o=e.inSize,a=e.numSegments,i=a*Math.ceil(o/n);this.outputShape=[r,i];var s=4*Math.floor(n/4),u=n%4,l=\"\\n sumValue += dot(values, filter);\\n \",c=\"\";o%n>0&&(c=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return initializationValue;\\n }\\n \");var p=\"\";o%n>0&&(p=\"\\n if (inIdx < 0 || inIdx >= \"+o+\") {\\n return -1.0;\\n }\\n \"),this.userCode=\"\\n const float initializationValue = 0.0;\\n\\n float getValue(int batch, int inIdx) {\\n \"+c+\"\\n return getX(batch, inIdx);\\n }\\n\\n float getSegmentIdAtIndex(int inIdx) {\\n \"+p+\"\\n return getSegmentIds(inIdx);\\n }\\n\\n void main() {\\n ivec2 coords = getOutputCoords();\\n int batch = coords[0];\\n int outIdx = coords[1];\\n int inOffset = int(floor(float(outIdx) / float(\\n \"+a+\")) * float(\"+n+\"));\\n int currentSeg = int(mod(float(outIdx), float(\"+a+\")));\\n\\n float sumValue = 0.0;\\n\\n for (int i = 0; i < \"+s+\"; i += 4) {\\n int inIdx = inOffset + i;\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n getValue(batch, inIdx + 3)\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0\\n );\\n\\n \"+l+\"\\n }\\n\\n int inIdx = inOffset + \"+s+\";\\n if (\"+(1===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n initializationValue,\\n initializationValue,\\n initializationValue\\n );\\n\\n int inIdxSeg = int(getSegmentIdAtIndex(inIdx));\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n 0,\\n 0,\\n 0\\n );\\n\\n \"+l+\"\\n } else if (\"+(2===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n initializationValue,\\n initializationValue\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n 0,\\n 0\\n );\\n\\n \"+l+\"\\n } else if (\"+(3===u)+\") {\\n vec4 values = vec4(\\n getValue(batch, inIdx),\\n getValue(batch, inIdx + 1),\\n getValue(batch, inIdx + 2),\\n initializationValue\\n );\\n\\n vec4 filter = vec4(\\n int(getSegmentIdAtIndex(inIdx)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 1)) == currentSeg ? 1 : 0,\\n int(getSegmentIdAtIndex(inIdx + 2)) == currentSeg ? 1 : 0,\\n 0\\n );\\n\\n \"+l+\"\\n }\\n setOutput(sumValue);\\n }\\n \"}}(),SelectProgram=function(){return function(e,t,n){var r,o;if(this.variableNames=[\"c\",\"a\",\"b\"],this.outputShape=t,n>4)throw Error(\"Where for rank \"+n+\" is not yet supported\");if(1===n)o=\"resRC\",r=\"resRC\";else{for(var a=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\"],i=[],s=[],u=0;u= 1.0) {\\n setOutput(getA(\"+o+\"));\\n } else {\\n setOutput(getB(\"+o+\"));\\n }\\n }\\n \"}}(),SliceProgram=function(){function e(e){this.variableNames=[\"source\"],this.outputShape=e,this.rank=e.length;var t=getCoordsDataType(this.rank),n=getCoords$1(this.rank);this.userCode=\"\\n uniform \"+t+\" start;\\n\\n void main() {\\n \"+t+\" sourceLoc = start + getOutputCoords();\\n setOutput(getSource(\"+n+\"));\\n }\\n \"}return e.prototype.getCustomSetupFunc=function(e){var t=this;if(e.length!==this.rank)throw Error(\"The rank (\"+this.rank+\") of the program must match the length of start (\"+e.length+\")\");return function(n,r){if(null!=t.startLoc||(t.startLoc=n.getUniformLocationNoThrow(r,\"start\"),null!=t.startLoc))if(1===t.rank)n.gl.uniform1i(t.startLoc,e[0]);else if(2===t.rank)n.gl.uniform2i(t.startLoc,e[0],e[1]);else if(3===t.rank)n.gl.uniform3i(t.startLoc,e[0],e[1],e[2]);else{if(4!==t.rank)throw Error(\"Slicing for rank \"+t.rank+\" is not yet supported\");n.gl.uniform4i(t.startLoc,e[0],e[1],e[2],e[3])}}},e}();function getCoords$1(e){if(1===e)return\"sourceLoc\";if(2===e)return\"sourceLoc.x, sourceLoc.y\";if(3===e)return\"sourceLoc.x, sourceLoc.y, sourceLoc.z\";if(4===e)return\"sourceLoc.x, sourceLoc.y, sourceLoc.z, sourceLoc.w\";throw Error(\"Slicing for rank \"+e+\" is not yet supported\")}var StridedSliceProgram=function(){return function(e,t,n){this.variableNames=[\"x\"],this.outputShape=n,this.rank=n.length;var r=getCoordsDataType(this.rank),o=\"\";o=1===this.rank?\"coords * strides + begin\":n.map(function(e,t){return\"coords[\"+t+\"] * strides[\"+t+\"] + begin[\"+t+\"]\"}).join(\",\"),this.userCode=\"\\n \"+r+\" begin = \"+r+\"(\"+e+\");\\n \"+r+\" strides = \"+r+\"(\"+t+\");\\n\\n void main() {\\n \"+r+\" coords = getOutputCoords();\\n setOutput(getX(\"+o+\"));\\n }\\n \"}}(),TextureManager=function(){function e(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}return e.prototype.acquireTexture=function(e,t){var n,r=getPhysicalFromLogicalTextureType(t),o=getKeyFromTextureShape(e,r);if(o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]),this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this.log();var a=this.freeTextures[o].shift();return this.usedTextures[o].push(a),a}return this.numUsedTextures++,this.log(),r===PhysicalTextureType.FLOAT32?n=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):r===PhysicalTextureType.FLOAT16?n=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):r===PhysicalTextureType.UNSIGNED_BYTE&&(n=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[o].push(n),n},e.prototype.releaseTexture=function(e,t,n){var r=getKeyFromTextureShape(t,getPhysicalFromLogicalTextureType(n));r in this.freeTextures||(this.freeTextures[r]=[]),this.freeTextures[r].push(e),this.numFreeTextures++,this.numUsedTextures--;var o=this.usedTextures[r],a=o.indexOf(e);if(a<0)throw new Error(\"Cannot release a texture that was never provided by this texture manager\");o.splice(a,1),this.log()},e.prototype.log=function(){if(this.logEnabled){var e=this.numFreeTextures+this.numUsedTextures;console.log(\"Free/Used\",this.numFreeTextures+\" / \"+this.numUsedTextures,\"(\"+e+\")\")}},e.prototype.getNumUsedTextures=function(){return this.numUsedTextures},e.prototype.getNumFreeTextures=function(){return this.numFreeTextures},e.prototype.dispose=function(){var e=this;if(null!=this.freeTextures){for(var t in this.freeTextures)this.freeTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});for(var t in this.usedTextures)this.usedTextures[t].forEach(function(t){e.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0}},e}();function getPhysicalFromLogicalTextureType(e){if(e===TextureUsage.DOWNLOAD||e===TextureUsage.PIXELS)return PhysicalTextureType.UNSIGNED_BYTE;if(e===TextureUsage.UPLOAD)return PhysicalTextureType.FLOAT32;if(e===TextureUsage.RENDER)return ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?PhysicalTextureType.FLOAT32:PhysicalTextureType.FLOAT16;throw new Error(\"Unknown logical texture type \"+e)}function getKeyFromTextureShape(e,t){return e[0]+\"_\"+e[1]+\"_\"+t}var TileProgram=function(){return function(e,t){this.variableNames=[\"A\"];for(var n=new Array(e.length),r=0;r5)throw Error(\"Tile for rank \"+t+\" is not yet supported\");if(1===t)return\"imod(resRC, \"+e[0]+\")\";for(var n=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\",\"resRC.u\"],r=[],o=0;o6)throw Error(\"Transpose for rank \"+t+\" is not yet supported\");for(var n=[\"resRC.x\",\"resRC.y\",\"resRC.z\",\"resRC.w\",\"resRC.u\",\"resRC.v\"],r=new Array(t),o=0;o= 0.0) ? x : (exp(x) - 1.0);\",SELU=\"\\n // Stable and Attracting Fixed Point (0, 1) for Normalized Weights.\\n // see: https://arxiv.org/abs/1706.02515\\n float scaleAlpha = \"+SELU_SCALEALPHA+\";\\n float scale = \"+SELU_SCALE+\";\\n return (x >= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0);\\n\";function STEP(e){return void 0===e&&(e=0),CHECK_NAN_SNIPPET$1+\"\\n return x > 0.0 ? 1.0 : float(\"+e+\");\\n \"}var NEG=\"return -x;\",CEIL=\"return ceil(x);\",FLOOR=\"return floor(x);\",SIGN=\"\\n if (isNaN(x)) { return 0.0; }\\n return sign(x);\\n\",ROUND=\"\\n // OpenGL ES does not support round function.\\n // The algorithm is based on banker's rounding.\\n float base = floor(x);\\n if ((x - base) < 0.5) {\\n return floor(x);\\n } else if ((x - base) > 0.5) {\\n return ceil(x);\\n } else {\\n if (mod(base, 2.0) == 0.0) {\\n return base;\\n } else {\\n return base + 1.0;\\n }\\n }\\n\",EXP=\"return exp(x);\",EXPM1=\"return exp(x) - 1.0;\",LOG=\"if (x < 0.0) return NAN;\\n return log(x);\",LOG1P=\"return log(1.0 + x);\",SQRT=\"return sqrt(x);\",RSQRT=\"return inversesqrt(x);\",SIGMOID=\"return 1.0 / (1.0 + exp(-1.0 * x));\",SOFTPLUS=\"\\n float epsilon = 1.1920928955078125e-7;\\n float threshold = log(epsilon) + 2.0;\\n\\n bool too_large = x > -threshold;\\n bool too_small = x < threshold;\\n\\n float result;\\n float exp_x = exp(x);\\n\\n if (too_large){\\n result = x;\\n }\\n else if (too_small){\\n result = exp_x;\\n }\\n else{\\n result = log(exp_x + 1.0);\\n }\\n return result;\\n\",SIN=CHECK_NAN_SNIPPET$1+\"\\n return sin(x);\\n\",COS=CHECK_NAN_SNIPPET$1+\"\\n return cos(x);\\n\",TAN=\"return tan(x);\",ASIN=\"return asin(x);\",ACOS=\"return acos(x);\",ATAN=CHECK_NAN_SNIPPET$1+\"\\n return atan(x);\\n\",SINH=\"\\n float e2x = exp(x);\\n return (e2x - 1.0 / e2x) / 2.0;\\n\",COSH=\"\\n float e2x = exp(-x);\\n return (e2x + 1.0 / e2x) / 2.0;\\n\",TANH=\"\\n float e2x = exp(-2.0 * abs(x));\\n return sign(x) * (1.0 - e2x) / (1.0 + e2x);\\n\",ASINH=\"return log(x + sqrt(x * x + 1.0));\",ACOSH=CHECK_NAN_SNIPPET$1+\"\\n if (x < 1.0) return NAN;\\n return log(x + sqrt(x * x - 1.0));\",ATANH=CHECK_NAN_SNIPPET$1+\"\\n if ((x < -1.0) || (x > 1.0)) return NAN;\\n return (log(1.0 + x) - log(1.0 - x)) / 2.0;\",ERF='\\n // Error function is calculated approximately with elementary function.\\n // See \"Handbook of Mathematical Functions with Formulas,\\n // Graphs, and Mathematical Tables\", Abramowitz and Stegun.\\n float p = '+ERF_P+\";\\n float a1 = \"+ERF_A1+\";\\n float a2 = \"+ERF_A2+\";\\n float a3 = \"+ERF_A3+\";\\n float a4 = \"+ERF_A4+\";\\n float a5 = \"+ERF_A5+\";\\n\\n float t = 1.0 / (1.0 + p * x);\\n return 1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x);\\n\",SQUARE=\"return x * x;\",RECIPROCAL=\"return 1.0 / x;\",LOGICAL_NOT=\"return float(!(x >= 1.0));\",TO_INT=\"return float(int(x));\";function concat1d_(e){return concat(e,0)}function concat2d_(e,t){return concat(e,t)}function concat3d_(e,t){return concat(e,t)}function concat4d_(e,t){return concat(e,t)}function concat_(e,t){void 0===t&&(t=0),assert(e.length>=1,\"Pass at least one tensor to concat\");var n=convertToTensorArray(e,\"tensors\",\"concat\"),r=n[0];if(1===n.length)return r;for(var o=parseAxisParam(t,r.shape),a=1;a>>0,t=(r*=t)>>>0,t+=4294967296*(r-=t)}return 2.3283064365386963e-10*(t>>>0)});n.next=function(){var e=2091639*n.s0+2.3283064365386963e-10*n.c;return n.s0=n.s1,n.s1=n.s2,n.s2=e-(n.c=0|e)},n.c=1,n.s0=r(\" \"),n.s1=r(\" \"),n.s2=r(\" \"),n.s0-=r(e),n.s0<0&&(n.s0+=1),n.s1-=r(e),n.s1<0&&(n.s1+=1),n.s2-=r(e),n.s2<0&&(n.s2+=1),r=null}(e),o=t&&t.state,a=n.next;return a.int32=function(){return 4294967296*n.next()|0},a.double=function(){return a()+1.1102230246251565e-16*(2097152*a()|0)},a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.alea=o}(0,e,!1)}),xor128=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor128=o}(0,e,!1)}),xorwow=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,t.v=0,e===(0|e)?t.x=e:n+=e;for(var r=0;r>>4),t.next()}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorwow=o}(0,e,!1)}),xorshift7=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.x=e.x.slice(),t.i=e.i,t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.x,o=t.i;return e=r[o],n=(e^=e>>>7)^e<<24,n^=(e=r[o+1&7])^e>>>10,n^=(e=r[o+3&7])^e>>>3,n^=(e=r[o+4&7])^e<<7,e=r[o+7&7],n^=(e^=e<<13)^e<<9,r[o]=n,t.i=o+1&7,n},function(e,t){var n,r=[];if(t===(0|t))r[0]=t;else for(t=\"\"+t,n=0;n0;--n)e.next()}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.x&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xorshift7=o}(0,e,!1)}),xor4096=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function o(e,t){null==e&&(e=+new Date);var n=new function(e){var t=this;t.next=function(){var e,n,r=t.w,o=t.X,a=t.i;return t.w=r=r+1640531527|0,n=o[a+34&127],e=o[a=a+1&127],n^=n<<13,e^=e<<17,n^=n>>>15,e^=e>>>12,n=o[a]=n^e,t.i=a,n+(r^r>>>16)|0},function(e,t){var n,r,o,a,i,s=[],u=128;for(t===(0|t)?(r=t,t=null):(t+=\"\\0\",r=0,u=Math.max(u,t.length)),o=0,a=-32;a>>15,r^=r<<4,r^=r>>>13,a>=0&&(i=i+1640531527|0,o=0==(n=s[127&a]^=r+i)?o+1:0);for(o>=128&&(s[127&(t&&t.length||0)]=-1),o=127,a=512;a>0;--a)r=s[o+34&127],n=s[o=o+1&127],r^=r<<13,n^=n<<17,r^=r>>>15,n^=n>>>12,s[o]=r^n;e.w=i,e.X=s,e.i=o}(t,e)}(e),o=t&&t.state,a=function(){return(n.next()>>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(o.X&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.xor4096=o}(0,e,!1)}),tychei=createCommonjsModule(function(e){!function(e,t,n){function r(e,t){return t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t}function o(e,t){var n=new function(e){var t=this,n=\"\";t.next=function(){var e=t.b,n=t.c,r=t.d,o=t.a;return e=e<<25^e>>>7^n,n=n-r|0,r=r<<24^r>>>8^o,o=o-e|0,t.b=e=e<<20^e>>>12^n,t.c=n=n-r|0,t.d=r<<16^n>>>16^o,t.a=o-e|0},t.a=0,t.b=0,t.c=-1640531527,t.d=1367130551,e===Math.floor(e)?(t.a=e/4294967296|0,t.b=0|e):n+=e;for(var r=0;r>>0)/4294967296};return a.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},a.int32=n.next,a.quick=a,o&&(\"object\"==typeof o&&r(o,n),a.state=function(){return r(n,{})}),a}t&&t.exports?t.exports=o:n&&n.amd?n(function(){return o}):this.tychei=o}(0,e,!1)}),seedrandom=createCommonjsModule(function(e){!function(t,n){var r,o=this,a=256,i=6,s=\"random\",u=n.pow(a,i),l=n.pow(2,52),c=2*l,p=a-1;function d(e,d,g){var v=[],y=f(function e(t,n){var r,o=[],a=typeof t;if(n&&\"object\"==a)for(r in t)try{o.push(e(t[r],n-1))}catch(e){}return o.length?o:\"string\"==a?t:t+\"\\0\"}((d=1==d?{entropy:!0}:d||{}).entropy?[e,m(t)]:null==e?function(){try{var e;return r&&(e=r.randomBytes)?e=e(a):(e=new Uint8Array(a),(o.crypto||o.msCrypto).getRandomValues(e)),m(e)}catch(e){var n=o.navigator,i=n&&n.plugins;return[+new Date,o,i,o.screen,m(t)]}}():e,3),v),x=new function(e){var t,n=e.length,r=this,o=0,i=r.i=r.j=0,s=r.S=[];n||(e=[n++]);for(;o=c;)e/=2,t/=2,n>>>=1;return(e+n)/t};return T.int32=function(){return 0|x.g(4)},T.quick=function(){return x.g(4)/4294967296},T.double=T,f(m(x.S),t),(d.pass||g||function(e,t,r,o){return o&&(o.S&&h(o,x),e.state=function(){return h(x,{})}),r?(n[s]=e,t):e})(T,y,\"global\"in d?d.global:this==n,d.state)}function h(e,t){return t.i=e.i,t.j=e.j,t.S=e.S.slice(),t}function f(e,t){for(var n,r=e+\"\",o=0;o=1||0===i);var s=Math.sqrt(-2*Math.log(i)/i);t=this.mean+this.stdDev*o*s,n=this.mean+this.stdDev*a*s,this.truncated&&!this.isValidTruncated(t)||(r=!0)}return this.truncated&&!this.isValidTruncated(n)||(this.nextVal=this.convertValue(n)),this.convertValue(t)},e.prototype.convertValue=function(e){return null==this.dtype||\"float32\"===this.dtype?e:Math.round(e)},e.prototype.isValidTruncated=function(e){return e<=this.upper&&e>=this.lower},e}();function clone_(e){var t=convertToTensor(e,\"x\",\"clone\");return ENV.engine.runKernel(function(e){return Tensor.make(t.shape,{dataId:t.dataId},t.dtype)},{$x:t},function(e){return{$x:function(){return e.toFloat()}}})}function eye_(e,t,n,r){void 0===r&&(r=\"float32\"),null==t&&(t=e);for(var o=buffer([e,t],r),a=e<=t?e:t,i=0;i2)throw new Error(\"Rank of probabilities must be 1 or 2, but is \"+i);n=n||Math.random();var s=1===i?o.as2D(1,-1):o,u=ENV.engine.runKernel(function(e){return e.multinomial(s,r,t,n)},{logits2D:s});return 1===i?u.as1D():u}function oneHot_(e,t,n,r){void 0===n&&(n=1),void 0===r&&(r=0);var o=convertToTensor(e,\"indices\",\"oneHot\",\"int32\");if(assert(\"int32\"===o.dtype,\"Indices must be of dtype `int32`\"),t<2)throw new Error(\"Error in oneHot: depth must be >=2, but it is \"+t);return ENV.engine.runKernel(function(e){return e.oneHot(o,t,n,r)},{$indices:o})}function fromPixels_(e,t){if(void 0===t&&(t=3),t>4)throw new Error(\"Cannot construct Tensor with more than 4 channels from pixels.\");return ENV.engine.fromPixels(e,t)}function toPixels(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,o,a,i,s,u,l,c,p,d,h,f,m,g,v,y,x,T,S;return __generator(this,function(b){switch(b.label){case 0:if(2!==(n=convertToTensor(e,\"img\",\"toPixels\",\"int32\")).rank&&3!==n.rank)throw new Error(\"toPixels only supports rank 2 or 3 tensors, got rank \"+n.rank+\".\");if(r=n.shape.slice(0,2),o=r[0],a=r[1],(i=2===n.rank?1:n.shape[2])>4||2===i)throw new Error(\"toPixels only supports depth of size 1, 3 or 4 but got \"+i);return s=n.min(),u=n.max(),[4,s.data()];case 1:return l=b.sent()[0],[4,u.data()];case 2:if(c=b.sent()[0],s.dispose(),u.dispose(),\"float32\"===n.dtype){if(l<0||c>1)throw new Error(\"Tensor values for a float32 Tensor must be in the range [0 - 1] but got range [\"+l+\" - \"+c+\"].\")}else{if(\"int32\"!==n.dtype)throw new Error(\"Unsupported type for toPixels: \"+n.dtype+\". Please use float32 or int32 tensors.\");if(l<0||c>255)throw new Error(\"Tensor values for a int32 Tensor must be in the range [0 - 255] but got range [\"+l+\" - \"+c+\"].\")}return[4,n.data()];case 3:for(p=b.sent(),d=\"float32\"===n.dtype?255:1,h=new Uint8ClampedArray(a*o*4),f=0;f=1,\"Pass at least one tensor to tf.stack\"),1===n.length)return n[0].expandDims(t);var r=n[0].rank,o=n[0].shape,a=n[0].dtype;assert(t<=r,\"Axis must be <= rank of the tensor\"),n.forEach(function(e){assertShapesMatch(o,e.shape,\"All tensors passed to stack must have matching shapes\")}),n.forEach(function(e){assert(a===e.dtype,\"All tensors passed to stack must have matching dtypes\")});var i=n.map(function(e){return e.expandDims(t)});return concat(i,t)}function batchToSpaceND_(e,t,n){var r=convertToTensor(e,\"x\",\"batchToSpaceND\"),o=t.reduce(function(e,t){return e*t});return assert(r.rank>=1+t.length,\"input rank should be > than [blockShape] but got \"+r.rank),assert(n.length===t.length,\"crops.shape[0] must be equal to [blockShape] but got \"+n.length),assert(r.shape[0]%o==0,\"input tensor batch must be divisible by prod( blockShape )\"),ENV.engine.runKernel(function(e){return e.batchToSpaceND(r,t,n)},{})}function spaceToBatchND_(e,t,n){var r=convertToTensor(e,\"x\",\"spaceToBatchND\");return assert(r.rank>=1+t.length,\"input rank should be > than [blockShape] but got \"+r.rank),assert(n.length===t.length,\"paddings.shape[0] must be equal to [blockShape], got \"+n.length),assert(r.shape.reduce(function(e,n,r){return r>0&&r<=t.length?e&&n%t[r-1]==0:e},!0),\"input spatial dimensions must be divisible by blockShapes\"),ENV.engine.runKernel(function(e){return e.spaceToBatchND(r,t,n)},{})}function unstack_(e,t){void 0===t&&(t=0);for(var n,r=convertToTensor(e,\"x\",\"unstack\"),o=r.shape[t],a=Array(r.rank-1).fill(0),i=0,s=0;s0?this.gpgpu.beginQuery():{startMs:performance.now(),endMs:null}},e.prototype.endTimer=function(e){return ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?(this.gpgpu.endQuery(),e):(e.endMs=performance.now(),e)},e.prototype.getQueryTime=function(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){return ENV.get(\"WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION\")>0?[2,this.gpgpu.waitForQueryAndGetTime(e)]:[2,(t=e).endMs-t.startMs]})})},e.prototype.disposeData=function(e){if(!this.pendingDisposal.has(e))if(this.pendingRead.has(e))this.pendingDisposal.add(e);else if(this.texData.has(e)){var t=this.texData.get(e),n=t.texture,r=t.texShape,o=t.usage;null!=n&&this.releaseTexture(e,n,r,o),this.texData.delete(e)}},e.prototype.getTexture=function(e){return this.uploadToGPU(e),this.texData.get(e).texture},e.prototype.getGPGPUContext=function(){return this.gpgpu},e.prototype.getCanvas=function(){return this.canvas},e.prototype.slice=function(e,t,n){var r=new SliceProgram(n),o=r.getCustomSetupFunc(t);return this.compileAndRun(r,[e],null,o)},e.prototype.stridedSlice=function(e,t,n,r,o,a){var i=getStridedSlicedInfo(e.shape,t,n,r,o,a),s=i[0],u=i[1];if(u.some(function(e){return 0===e}))return tensor([],u);var l=new StridedSliceProgram(s,r,u);return this.compileAndRun(l,[e])},e.prototype.reverse=function(e,t){var n=new ReverseProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.concat=function(e,t){var n=new ConcatProgram(e.shape,t.shape);return this.compileAndRun(n,[e,t])},e.prototype.neg=function(e){var t=new UnaryOpProgram(e.shape,NEG);return this.compileAndRun(t,[e])},e.prototype.matMul=function(e,t,n,r){var o=new MatMulProgram(e.shape,t.shape,n,r);return this.compileAndRun(o,[e,t])},e.prototype.multiply=function(e,t){var n=new BinaryOpProgram(MUL,e.shape,t.shape),r=this.makeOutputArray(n.outputShape,upcastType(e.dtype,t.dtype));return this.compileAndRun(n,[e,t],r)},e.prototype.batchNormalization=function(e,t,n,r,o,a){var i=[e,t,n],s=null;null!=a&&(s=a.shape,i.push(a));var u=null;null!=o&&(u=o.shape,i.push(o));var l=new BatchNormProgram(e.shape,t.shape,n.shape,s,u,r);return this.compileAndRun(l,i)},e.prototype.localResponseNormalization4D=function(e,t,n,r,o){var a=new LRNProgram(e.shape,t,n,r,o);return this.compileAndRun(a,[e])},e.prototype.LRNGrad=function(e,t,n,r,o,a,i){var s=new LRNGradProgram(t.shape,r,o,a,i);return this.compileAndRun(s,[t,n,e])},e.prototype.tile=function(e,t){var n=new TileProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.pad=function(e,t,n){var r=new PadProgram(e.shape,t,n);return this.compileAndRun(r,[e])},e.prototype.transpose=function(e,t){var n=new TransposeProgram(e.shape,t);return this.compileAndRun(n,[e])},e.prototype.gather=function(e,t,n){var r=new GatherProgram(e.shape,t.size,n);return this.compileAndRun(r,[e,t])},e.prototype.batchToSpaceND=function(e,t,n){assert(e.rank<=4,\"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet\");var r=t.reduce(function(e,t){return e*t}),o=getReshaped(e.shape,t,r),a=getPermuted(o.length,t.length),i=getReshapedPermuted(e.shape,t,r),s=getSliceBeginCoords(n,t.length),u=getSliceSize(i,n,t.length);return e.reshape(o).transpose(a).reshape(i).slice(s,u)},e.prototype.spaceToBatchND=function(e,t,n){assert(e.rank<=4,\"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet\");var r=t.reduce(function(e,t){return e*t}),o=[[0,0]];o.push.apply(o,n);for(var a=1+t.length;athis.NUM_BYTES_BEFORE_PAGING)for(var d=this.numBytesInGPU-this.NUM_BYTES_BEFORE_PAGING;d>0&&this.lruDataGPU.length>0;){var h=this.lruDataGPU.shift(),f=this.texData.get(h),m=f.shape,g=f.dtype;d-=this.computeBytes(m,g),this.read(h)}return p&&(s=this.endTimer(s),this.activeTimers.push(this.getQueryTime(s))),n},e.prototype.getAndSaveBinary=function(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]},e.prototype.getTextureManager=function(){return this.textureManager},e.prototype.dispose=function(){if(!this.disposed){for(var e in this.binaryCache)this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram);this.textureManager.dispose(),this.canvas.remove(),null!=this.fromPixelsCanvas&&this.fromPixelsCanvas.remove(),this.gpgpuCreatedLocally&&this.gpgpu.dispose(),this.disposed=!0}},e.prototype.throwIfNoData=function(e){if(!this.texData.has(e))throw new Error(\"WebGL backend: No data found for this tensor. Did you change your backend in the middle of the program? New backends can't use Tensors created with previous backends\")},e.prototype.uploadToGPU=function(e){this.throwIfNoData(e);var t=this.texData.get(e),n=t.shape,r=t.values,o=t.texture,a=t.dtype,i=t.usage;if(null==o){var s,u=null!=this.activeTimers;u&&(s=performance.now());var l=getTextureShapeFromLogicalShape(this.gpgpu.gl,n);t.texShape=l;var c=this.acquireTexture(e,l,i);t.texture=c,null!=r&&(this.gpgpu.uploadMatrixToTexture(c,l[0],l[1],typedArrayToFloat32(r,a)),t.values=null,u&&(this.uploadWaitMs+=performance.now()-s))}else{this.lruDataGPU.indexOf(e)>=0&&(this.lruDataGPU.splice(this.lruDataGPU.indexOf(e),1),this.lruDataGPU.push(e))}},e.prototype.cacheOnCPU=function(e,t){var n=this.delayedStorage,r=this.texData.get(e),o=r.texture,a=r.texShape,i=r.dtype,s=r.usage;n&&null!=o&&(this.releaseTexture(e,o,a,s),r.texture=null,r.texShape=null),null!=t&&(r.values=float32ToTypedArray(t,i))},e.prototype.releaseTexture=function(e,t,n,r){var o=this.texData.get(e),a=o.shape,i=o.dtype,s=this.lruDataGPU.indexOf(e);s>=0&&this.lruDataGPU.splice(s,1),this.numBytesInGPU-=this.computeBytes(a,i),this.textureManager.releaseTexture(t,n,r)},e.prototype.acquireTexture=function(e,t,n){var r=this.texData.get(e),o=r.shape,a=r.dtype;return this.lruDataGPU.push(e),this.numBytesInGPU+=this.computeBytes(o,a),this.textureManager.acquireTexture(t,n)},e.prototype.computeBytes=function(e,t){return sizeFromShape(e)*bytesPerElement(t)},e}();function float32ToTypedArray(e,t){if(\"float32\"===t)return e;if(\"int32\"===t||\"bool\"===t){for(var n=\"int32\"===t?new Int32Array(e.length):new Uint8Array(e.length),r=0;r=0?e:(assert(-1===e,\"Bad value in size\"),a.shape[t]-r[t])}),assertParamsValid(a,r,o);var i=a.shape;return ENV.engine.runKernel(function(e){return e.slice(a,r,o)},{$x:a},function(e){for(var t=[],n=0;n0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.reshape(r.shape)}}})}function addN_(e){assert(Array.isArray(e),function(){return\"The param passed to tf.addN() must be a list of tensors\"}),assert(e.length>=1,function(){return\"Must pass at least one tensor to tf.addN(), but got \"+e.length});var t=e.map(function(e,t){return convertToTensor(e,\"tensors\"+t,\"addN\")}),n=t[0];t.forEach(function(e){if(e.dtype!==n.dtype)throw new Error(\"All tensors passed to tf.addN() must have the same dtype\")}),t.forEach(function(e){if(!arraysEqual(e.shape,n.shape))throw new Error(\"All tensors passed to tf.addN() must have the same shape\")});var r=t;return ENV.engine.runKernel(function(e){return e.addN(t)},r,function(e){var n={};return t.forEach(function(t,r){n[r]=function(){return e.clone()}}),n})}function addStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in addStrict: \"),e.add(t)}function sub_(e,t){var n=convertToTensor(e,\"a\",\"sub\"),r=convertToTensor(t,\"b\",\"sub\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.subtract(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e,r=getReductionAxes(n.shape,o);return r.length>0&&(t=t.sum(r)),t.reshape(n.shape)},$b:function(){var t=e,n=getReductionAxes(r.shape,o);return n.length>0&&(t=t.sum(n)),t.neg().reshape(r.shape)}}})}function subStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in subStrict: \"),e.sub(t)}function pow_(e,t){var n=convertToTensor(e,\"base\",\"pow\"),r=convertToTensor(t,\"exp\",\"pow\"),o=assertAndGetBroadcastShape(n.shape,r.shape);e=n.cast(upcastType(n.dtype,r.dtype)),t=r.cast(upcastType(n.dtype,r.dtype));return ENV.engine.runKernel(function(e,t){return t(e.pow(n,r))},{$base:n,$exp:r},function(e,t){var a=t[0];return{$base:function(){var t=e.mul(r.toFloat().mul(a.div(n))),i=getReductionAxes(n.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(n.shape)},$exp:function(){var t=e.mul(a.mul(n.log()).toFloat()),i=getReductionAxes(r.shape,o);return i.length>0&&(t=t.sum(i)),t.reshape(r.shape)}}})}function powStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in powStrict: \"),e.pow(t)}function mul_(e,t){var n=convertToTensor(e,\"a\",\"mul\"),r=convertToTensor(t,\"b\",\"mul\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.multiply(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.mul(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function mulStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in multiplyStrict: \"),e.mul(t)}function div_(e,t){var n,r=convertToTensor(e,\"a\",\"div\"),o=convertToTensor(t,\"b\",\"div\");if(assertTypesMatch(r,o),\"int32\"===r.dtype&&\"int32\"===o.dtype)return floorDiv(r,o);n=function(e){return e.realDivide(r,o)};var a=assertAndGetBroadcastShape(r.shape,o.shape);return ENV.engine.runKernel(n,{$a:r,$b:o},function(e){return{$a:function(){var t=e.div(o.toFloat()),n=getReductionAxes(r.shape,a);return n.length>0?t.sum(n).reshape(r.shape):t},$b:function(){var t=e.mul(r.toFloat()),n=getReductionAxes(o.shape,a);n.length>0&&(t=t.sum(n).reshape(o.shape));var i=o.square();return t.div(i.toFloat()).neg()}}})}function floorDiv_(e,t){var n=convertToTensor(e,\"a\",\"floorDiv\"),r=convertToTensor(t,\"b\",\"floorDiv\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.floorDiv(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=e.div(r.toFloat()),a=getReductionAxes(n.shape,o);return a.length>0?t.sum(a).reshape(n.shape):t},$b:function(){var t=e.mul(n.toFloat()),a=getReductionAxes(r.shape,o);a.length>0&&(t=t.sum(a).reshape(r.shape));var i=r.square();return t.div(i.toFloat()).neg()}}})}function divStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in divideStrict: \"),e.div(t)}function mod_(e,t){var n=convertToTensor(e,\"a\",\"mod\"),r=convertToTensor(t,\"b\",\"mod\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.mod(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=getReductionAxes(n.shape,o);return t.length>0?e.sum(t).reshape(n.shape):e},$b:function(){var t=e.mul(n.div(r).floor().neg()),a=getReductionAxes(r.shape,o);return a.length>0?t.sum(a).reshape(r.shape):t}}})}function modStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in modStrict: \"),e.mod(t)}function minimum_(e,t){var n=convertToTensor(e,\"a\",\"minimum\"),r=convertToTensor(t,\"b\",\"minimum\");assertTypesMatch(n,r),\"bool\"===n.dtype&&(n=n.toInt()),\"bool\"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.minimum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.lessEqual(r).toFloat())},$b:function(){return e.mul(n.greater(r).toFloat())}}})}function minimumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in minimumStrict: \"),e.minimum(t)}function maximum_(e,t){var n=convertToTensor(e,\"a\",\"maximum\"),r=convertToTensor(t,\"b\",\"maximum\");assertTypesMatch(n,r),\"bool\"===n.dtype&&(n=n.toInt()),\"bool\"===r.dtype&&(r=r.toInt()),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.maximum(n,r)},{$a:n,$b:r},function(e){return{$a:function(){return e.mul(n.greaterEqual(r).toFloat())},$b:function(){return e.mul(n.less(r).toFloat())}}})}function maximumStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in minimumStrict: \"),e.maximum(t)}function squaredDifference_(e,t){var n=convertToTensor(e,\"a\",\"squaredDifference\"),r=convertToTensor(t,\"b\",\"squaredDifference\");assertTypesMatch(n,r),assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.squaredDifference(n,r)},{$a:n,$b:r},function(e){var t=scalar(2);return{$a:function(){return e.mul(n.sub(r).mul(t))},$b:function(){return e.mul(r.sub(n).mul(t))}}})}function squaredDifferenceStrict_(e,t){return assertShapesMatch(e.shape,t.shape,\"Error in squaredDifferenceStrict: \"),e.squaredDifference(t)}function atan2_(e,t){var n=convertToTensor(e,\"a\",\"atan2\"),r=convertToTensor(t,\"b\",\"atan2\");assertTypesMatch(n,r);var o=assertAndGetBroadcastShape(n.shape,r.shape);return ENV.engine.runKernel(function(e){return e.atan2(n,r)},{$a:n,$b:r},function(e){return{$a:function(){var t=add(n.square(),r.square()),a=e.mul(r.div(t)),i=getReductionAxes(n.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(n.shape)},$b:function(){var t=add(n.square(),r.square()),a=neg(e.mul(n.div(t))),i=getReductionAxes(r.shape,o);return i.length>0&&(a=a.sum(i)),a.reshape(r.shape)}}})}var add=op({add_:add_}),addN=op({addN_:addN_}),addStrict=op({addStrict_:addStrict_}),atan2=op({atan2_:atan2_}),div=op({div_:div_}),divStrict=op({divStrict_:divStrict_}),floorDiv=op({floorDiv_:floorDiv_}),maximum=op({maximum_:maximum_}),maximumStrict=op({maximumStrict_:maximumStrict_}),minimum=op({minimum_:minimum_}),minimumStrict=op({minimumStrict_:minimumStrict_}),mod=op({mod_:mod_}),modStrict=op({modStrict_:modStrict_}),mul=op({mul_:mul_}),mulStrict=op({mulStrict_:mulStrict_}),pow=op({pow_:pow_}),powStrict=op({powStrict_:powStrict_}),squaredDifference=op({squaredDifference_:squaredDifference_}),squaredDifferenceStrict=op({squaredDifferenceStrict_:squaredDifferenceStrict_}),sub=op({sub_:sub_}),subStrict=op({subStrict_:subStrict_});function logicalNot_(e){var t=convertToTensor(e,\"x\",\"logicalNot\",\"bool\");return assert(\"bool\"===t.dtype,\"Error Array must be of type bool.\"),ENV.engine.runKernel(function(e){return e.logicalNot(t)},{$x:t})}function logicalAnd_(e,t){var n=convertToTensor(e,\"a\",\"logicalAnd\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalAnd\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalAnd(n,r)},{$a:n,$b:r})}function logicalOr_(e,t){var n=convertToTensor(e,\"a\",\"logicalOr\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalOr\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),ENV.engine.runKernel(function(e){return e.logicalOr(n,r)},{$a:n,$b:r})}function logicalXor_(e,t){var n=convertToTensor(e,\"a\",\"logicalXor\",\"bool\"),r=convertToTensor(t,\"b\",\"logicalXor\",\"bool\");return assert(\"bool\"===n.dtype&&\"bool\"===r.dtype,\"Error Array must be of type bool.\"),assertAndGetBroadcastShape(n.shape,r.shape),logicalOr(e,t).logicalAnd(logicalAnd(e,t).logicalNot())}function where_(e,t,n){var r=convertToTensor(t,\"a\",\"where\"),o=convertToTensor(n,\"b\",\"where\"),a=convertToTensor(e,\"condition\",\"where\",\"bool\");assert(\"bool\"===a.dtype,\"Error Condition must be of type bool.\"),assertShapesMatch(r.shape,o.shape,\"Error in where: \"),1===a.rank?assert(a.shape[0]===r.shape[0],\"The first dimension of `a` must match the size of `condition`.\"):assertShapesMatch(a.shape,o.shape,\"Error in where: \");return ENV.engine.runKernel(function(e){return e.select(a,r,o)},{$condition:a,$a:r,$b:o},function(e){return{$condition:function(){return zerosLike(a)},$a:function(){return e.mul(a.cast(r.dtype))},$b:function(){return e.mul(a.logicalNot().cast(o.dtype))}}})}function whereAsync_(e){return __awaiter(this,void 0,void 0,function(){var t,n,r;return __generator(this,function(o){switch(o.label){case 0:return assert(\"bool\"===(t=convertToTensor(e,\"condition\",\"where\",\"bool\")).dtype,\"Condition must be of type bool.\"),[4,t.data()];case 1:return n=o.sent(),r=whereImpl(t.shape,n),e!==t&&t.dispose(),[2,r]}})})}var logicalAnd=op({logicalAnd_:logicalAnd_}),logicalNot=op({logicalNot_:logicalNot_}),logicalOr=op({logicalOr_:logicalOr_}),logicalXor=op({logicalXor_:logicalXor_}),where=op({where_:where_}),whereAsync=whereAsync_;function relu_(e){var t=convertToTensor(e,\"x\",\"relu\");if(\"bool\"===t.dtype)return t.toInt();return ENV.engine.runKernel(function(e){return e.relu(t)},{$x:t},function(e){var n=t.step();return{$x:function(){return e.mulStrict(n.toFloat())}}})}function elu_(e){var t=convertToTensor(e,\"x\",\"elu\");return ENV.engine.runKernel(function(e,n){return n(e.elu(t))},{$x:t},function(e,t){var n=t[0];return{$x:function(){return ENV.engine.runKernel(function(t){return t.eluDer(e,n)},{dy:e,y:n})}}})}function selu_(e){var t=convertToTensor(e,\"x\",\"selu\");return ENV.engine.runKernel(function(e){return e.selu(t)},{$x:t},function(e){return{$x:function(){var n=t.greater(scalar(0)),r=scalar(SELU_SCALEALPHA),o=scalar(SELU_SCALE),a=e.mul(o),i=e.mul(r).mul(t.toFloat().exp());return where(n,a,i)}}})}function leakyRelu_(e,t){void 0===t&&(t=.2);var n=convertToTensor(e,\"x\",\"leakyRelu\");return maximum(scalar(t).mul(n),n)}function prelu_(e,t){var n=convertToTensor(e,\"x\",\"prelu\"),r=convertToTensor(t,\"alpha\",\"prelu\"),o=scalar(0);return maximum(o,n).add(r.mul(minimum(o,n)))}var elu=op({elu_:elu_}),leakyRelu=op({leakyRelu_:leakyRelu_}),prelu=op({prelu_:prelu_}),relu=op({relu_:relu_}),selu=op({selu_:selu_});function transpose_(e,t){var n=convertToTensor(e,\"x\",\"transpose\");if(null==t&&(t=n.shape.map(function(e,t){return t}).reverse()),assert(n.rank===t.length,\"Error in transpose: rank of input \"+n.rank+\" must match length of perm \"+t+\".\"),t.forEach(function(e){assert(e>=0&&eo)throw new Error(\"'k' passed to topk() must be <= the last dimension (\"+o+\") but got \"+t);var a=ENV.engine.runKernel(function(e){return e.topk(r,t,n)},{$x:r});return{values:a[0],indices:a[1]}}var Reduction,topk=op({topk_:topk_});function computeWeightedLoss_(e,t,n){void 0===n&&(n=Reduction.SUM_BY_NONZERO_WEIGHTS);var r=convertToTensor(e,\"losses\",\"computeWeightedLoss\"),o=null;null!=t&&(o=convertToTensor(t,\"weights\",\"computeWeightedLoss\"));var a=null==o?r:r.mul(o);if(n===Reduction.NONE)return a;if(n===Reduction.SUM)return a.sum();if(n===Reduction.MEAN){if(null==o)return a.mean();var i=sizeFromShape(r.shape)/sizeFromShape(o.shape),s=a.sum().div(o.sum());return i>1?s.div(scalar(i)):s}if(n===Reduction.SUM_BY_NONZERO_WEIGHTS){if(null==o)return a.sum().div(scalar(r.size));var u=o.mul(ones$1(r.shape)).notEqual(scalar(0)).sum().toFloat();return a.sum().div(u)}throw Error(\"Unknown reduction: \"+n)}function absoluteDifference_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"absoluteDifference\"),a=convertToTensor(t,\"predictions\",\"absoluteDifference\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"absoluteDifference\")),assertShapesMatch(o.shape,a.shape,\"Error in absoluteDifference: \");var s=o.sub(a).abs();return computeWeightedLoss(s,i,r)}function meanSquaredError_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"meanSquaredError\"),a=convertToTensor(t,\"predictions\",\"meanSquaredError\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"meanSquaredError\")),assertShapesMatch(o.shape,a.shape,\"Error in meanSquaredError: \");var s=o.squaredDifference(a);return computeWeightedLoss(s,i,r)}function cosineDistance_(e,t,n,r,o){void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"cosineDistance\"),i=convertToTensor(t,\"predictions\",\"cosineDistance\"),s=null;null!=r&&(s=convertToTensor(r,\"weights\",\"cosineDistance\")),assertShapesMatch(a.shape,i.shape,\"Error in cosineDistance: \");var u=scalar(1).sub(a.mul(i).sum(n,!0));return computeWeightedLoss(u,s,o)}function hingeLoss_(e,t,n,r){void 0===r&&(r=Reduction.SUM_BY_NONZERO_WEIGHTS);var o=convertToTensor(e,\"labels\",\"hingeLoss\"),a=convertToTensor(t,\"predictions\",\"hingeLoss\"),i=null;null!=n&&(i=convertToTensor(n,\"weights\",\"hingeLoss\")),assertShapesMatch(o.shape,a.shape,\"Error in hingeLoss: \");var s=scalar(1);o=scalar(2).mul(o).sub(s);var u=s.sub(o.mul(a)).relu();return computeWeightedLoss(u,i,r)}function logLoss_(e,t,n,r,o){void 0===r&&(r=1e-7),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"logLoss\"),i=convertToTensor(t,\"predictions\",\"logLoss\"),s=null;null!=n&&(s=convertToTensor(n,\"weights\",\"logLoss\")),assertShapesMatch(a.shape,i.shape,\"Error in logLoss: \");var u=scalar(1),l=scalar(r),c=a.mul(i.add(l).log()).neg().sub(u.sub(a).mul(u.sub(i).add(l).log()));return computeWeightedLoss(c,s,o)}function sigmoidCrossEntropyWithLogits_(e,t){var n=convertToTensor(e,\"labels\",\"sigmoidCrossEntropyWithLogits\"),r=convertToTensor(t,\"logits\",\"sigmoidCrossEntropyWithLogits\");assertShapesMatch(n.shape,r.shape,\"Error in sigmoidCrossEntropyWithLogits: \");var o=r.relu(),a=r.mul(n),i=r.abs().neg().exp().log1p();return o.sub(a).add(i)}function sigmoidCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"multiClassLabels\",\"sigmoidCrossEntropy\"),i=convertToTensor(t,\"logits\",\"sigmoidCrossEntropy\"),s=null;if(null!=n&&(s=convertToTensor(n,\"weights\",\"sigmoidCrossEntropy\")),assertShapesMatch(a.shape,i.shape,\"Error in sigmoidCrossEntropy: \"),r>0){var u=scalar(r),l=scalar(1),c=scalar(.5);a=a.mul(l.sub(u)).add(c.mul(u))}var p=sigmoidCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}function huberLoss_(e,t,n,r,o){void 0===r&&(r=1),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"labels\",\"huberLoss\"),i=convertToTensor(t,\"predictions\",\"huberLoss\"),s=null;null!=n&&(s=convertToTensor(n,\"weights\",\"huberLoss\")),assertShapesMatch(a.shape,i.shape,\"Error in huberLoss: \");var u=scalar(r),l=i.sub(a).abs(),c=minimum(l,u),p=l.sub(c),d=scalar(.5).mul(c.square()).add(u.mul(p));return computeWeightedLoss(d,s,o)}function softmaxCrossEntropyWithLogits_(e,t,n){if(void 0===n&&(n=-1),-1===n&&(n=t.rank-1),n!==t.rank-1)throw Error(\"Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank \"+t.rank+\" and dim was \"+n);return customGrad(function(e,t){var r=t.logSumExp([n],!0),o=t.toFloat().sub(r);return{value:o.mul(e).neg().sum([n]),gradFunc:function(t){var r=expandShapeToKeepDim(t.shape,[n]);return[t.reshape(r).mul(e.toFloat().sub(o.exp())),t.reshape(r).mul(o.exp().sub(e.toFloat()))]}}})(e,t)}function softmaxCrossEntropy_(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=Reduction.SUM_BY_NONZERO_WEIGHTS);var a=convertToTensor(e,\"onehotLabels\",\"softmaxCrossEntropy\"),i=convertToTensor(t,\"logits\",\"softmaxCrossEntropy\"),s=null;if(null!=n&&(s=convertToTensor(n,\"weights\",\"softmaxCrossEntropy\")),assertShapesMatch(a.shape,i.shape,\"Error in softmaxCrossEntropy: \"),r>0){var u=scalar(r),l=scalar(1),c=scalar(a.shape[1]);a=a.mul(l.sub(u)).add(u.div(c))}var p=softmaxCrossEntropyWithLogits_(a,i);return computeWeightedLoss(p,s,o)}!function(e){e[e.NONE=0]=\"NONE\",e[e.MEAN=1]=\"MEAN\",e[e.SUM=2]=\"SUM\",e[e.SUM_BY_NONZERO_WEIGHTS=3]=\"SUM_BY_NONZERO_WEIGHTS\"}(Reduction||(Reduction={}));var absoluteDifference=op({absoluteDifference_:absoluteDifference_}),computeWeightedLoss=op({computeWeightedLoss_:computeWeightedLoss_}),cosineDistance=op({cosineDistance_:cosineDistance_}),hingeLoss=op({hingeLoss_:hingeLoss_}),huberLoss=op({huberLoss_:huberLoss_}),logLoss=op({logLoss_:logLoss_}),meanSquaredError=op({meanSquaredError_:meanSquaredError_}),sigmoidCrossEntropy=op({sigmoidCrossEntropy_:sigmoidCrossEntropy_}),softmaxCrossEntropy=op({softmaxCrossEntropy_:softmaxCrossEntropy_}),loss_ops=Object.freeze({get Reduction(){return Reduction},absoluteDifference:absoluteDifference,computeWeightedLoss:computeWeightedLoss,cosineDistance:cosineDistance,hingeLoss:hingeLoss,huberLoss:huberLoss,logLoss:logLoss,meanSquaredError:meanSquaredError,sigmoidCrossEntropy:sigmoidCrossEntropy,softmaxCrossEntropy:softmaxCrossEntropy});function gramSchmidt_(e){var t;if(Array.isArray(e)){t=!1,assert(null!=e&&e.length>0,\"Gram-Schmidt process: input must not be null, undefined, or empty\");for(var n=e[0].shape[0],r=1;r0)for(var n=0;n= 2, but got rank \"+e.rank);if(2===e.rank)return qr2d(e,t);var n=e.shape.slice(0,e.shape.length-2).reduce(function(e,t){return e*t}),r=[],o=[];return unstack(e.reshape([n,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0).forEach(function(e){var n=qr2d(e,t),a=n[0],i=n[1];r.push(a),o.push(i)}),[stack(r,0).reshape(e.shape),stack(o,0).reshape(e.shape)]}function qr2d(e,t){return void 0===t&&(t=!1),ENV.engine.tidy(function(){if(2!==e.shape.length)throw new Error(\"qr2d() requires a 2D Tensor, but got a \"+e.shape.length+\"D Tensor.\");for(var n=e.shape[0],r=e.shape[1],o=eye(n),a=e.clone(),i=tensor2d([[1]],[1,1]),s=i.clone(),u=n>=r?r:n,l=function(e){var t,u=a,l=s,c=o;t=ENV.engine.tidy(function(){var t=a.slice([e,e],[n-e,1]),u=t.norm(),l=a.slice([e,e],[1,1]),c=l.sign().neg(),p=l.sub(c.mul(u)),d=t.div(p);s=1===d.shape[0]?i.clone():i.concat(d.slice([1,0],[d.shape[0]-1,d.shape[1]]),0);var h=c.matMul(p).div(u).neg(),f=a.slice([e,0],[n-e,r]),m=h.mul(s);a=0===e?f.sub(m.matMul(s.transpose().matMul(f))):a.slice([0,0],[e,r]).concat(f.sub(m.matMul(s.transpose().matMul(f))),0);var g=o.slice([0,e],[n,o.shape[1]-e]);return o=0===e?g.sub(g.matMul(s).matMul(m.transpose())):o.slice([0,0],[n,e]).concat(g.sub(g.matMul(s).matMul(m.transpose())),1),[s,a,o]}),s=t[0],a=t[1],o=t[2],dispose([u,l,c])},c=0;cr&&(o=o.slice([0,0],[n,r]),a=a.slice([0,0],[r,r])),[o,a]})}var gramSchmidt=op({gramSchmidt_:gramSchmidt_}),qr=op({qr_:qr_}),linalg_ops=Object.freeze({gramSchmidt:gramSchmidt,qr:qr});function resizeBilinear_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,\"images\",\"resizeBilinear\");assert(3===r.rank||4===r.rank,\"Error in resizeBilinear: x must be rank 3 or 4, but got rank \"+r.rank+\".\"),assert(2===t.length,\"Error in resizeBilinear: new shape must 2D, but got shape \"+t+\".\");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeBilinear(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeBilinearBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function resizeNearestNeighbor_(e,t,n){void 0===n&&(n=!1);var r=convertToTensor(e,\"images\",\"resizeNearestNeighbor\");assert(3===r.rank||4===r.rank,\"Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank \"+r.rank+\".\"),assert(2===t.length,\"Error in resizeNearestNeighbor: new shape must 2D, but got shape \"+t+\".\"),assert(\"float32\"===r.dtype||\"int32\"===r.dtype,\"`images` must have `int32` or `float32` as dtype\");var o=r,a=!1;3===r.rank&&(a=!0,o=r.as4D(1,r.shape[0],r.shape[1],r.shape[2]));var i=t[0],s=t[1],u=ENV.engine.runKernel(function(e,t){return e.resizeNearestNeighbor(o,i,s,n)},{batchImages:o},function(e,t){return{batchImages:function(){return ENV.engine.runKernel(function(t){return t.resizeNearestNeighborBackprop(e,o,n)},{})}}});return a?u.as3D(u.shape[1],u.shape[2],u.shape[3]):u}function nonMaxSuppression_(e,t,n,r,o){void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY);var a=convertToTensor(e,\"boxes\",\"nonMaxSuppression\"),i=convertToTensor(t,\"scores\",\"nonMaxSuppression\"),s=nonMaxSuppSanityCheck(a,i,n,r,o);return n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,ENV.engine.runKernel(function(e){return e.nonMaxSuppression(a,i,n,r,o)},{$boxes:a})}function nonMaxSuppressionAsync_(e,t,n,r,o){return void 0===r&&(r=.5),void 0===o&&(o=Number.NEGATIVE_INFINITY),__awaiter(this,void 0,void 0,function(){var a,i,s,u,l,c;return __generator(this,function(p){switch(p.label){case 0:return a=convertToTensor(e,\"boxes\",\"nonMaxSuppressionAsync\"),i=convertToTensor(t,\"scores\",\"nonMaxSuppressionAsync\"),s=nonMaxSuppSanityCheck(a,i,n,r,o),n=s.maxOutputSize,r=s.iouThreshold,o=s.scoreThreshold,[4,a.data()];case 1:return u=p.sent(),[4,i.data()];case 2:return l=p.sent(),c=nonMaxSuppressionImpl(u,l,n,r,o),a!==e&&a.dispose(),i!==t&&i.dispose(),[2,c]}})})}function nonMaxSuppSanityCheck(e,t,n,r,o){null==r&&(r=.5),null==o&&(o=Number.NEGATIVE_INFINITY);var a=e.shape[0];return n=Math.min(n,a),assert(0<=r&&r<=1,\"iouThreshold must be in [0, 1], but was '\"+r+\"'\"),assert(2===e.rank,\"boxes must be a 2D tensor, but was of rank '\"+e.rank+\"'\"),assert(4===e.shape[1],\"boxes must have 4 columns, but 2nd dimension was \"+e.shape[1]),assert(1===t.rank,\"scores must be a 1D tensor\"),assert(t.shape[0]===a,\"scores has incompatible shape with boxes. Expected \"+a+\", but was \"+t.shape[0]),{maxOutputSize:n,iouThreshold:r,scoreThreshold:o}}var resizeBilinear=op({resizeBilinear_:resizeBilinear_}),resizeNearestNeighbor=op({resizeNearestNeighbor_:resizeNearestNeighbor_}),nonMaxSuppression=op({nonMaxSuppression_:nonMaxSuppression_}),nonMaxSuppressionAsync=nonMaxSuppressionAsync_,image_ops=Object.freeze({resizeBilinear:resizeBilinear,resizeNearestNeighbor:resizeNearestNeighbor,nonMaxSuppression:nonMaxSuppression,nonMaxSuppressionAsync:nonMaxSuppressionAsync}),ops=Object.freeze({image:image_ops,linalg:linalg_ops,losses:loss_ops,op:op,batchNormalization2d:batchNormalization2d,batchNormalization3d:batchNormalization3d,batchNormalization4d:batchNormalization4d,batchNormalization:batchNormalization,concat:concat,concat1d:concat1d,concat2d:concat2d,concat3d:concat3d,concat4d:concat4d,conv1d:conv1d,conv2d:conv2d,depthwiseConv2d:depthwiseConv2d,separableConv2d:separableConv2d,conv2dTranspose:conv2dTranspose,matMul:matMul,dot:dot,outerProduct:outerProduct,reverse:reverse,reverse1d:reverse1d,reverse2d:reverse2d,reverse3d:reverse3d,reverse4d:reverse4d,maxPool:maxPool,avgPool:avgPool,slice:slice,slice1d:slice1d,slice2d:slice2d,slice3d:slice3d,slice4d:slice4d,abs:abs,acos:acos,acosh:acosh,asin:asin,asinh:asinh,atan:atan,atanh:atanh,ceil:ceil,clipByValue:clipByValue,cos:cos,cosh:cosh,erf:erf,exp:exp,expm1:expm1,floor:floor,log:log$1,log1p:log1p,logSigmoid:logSigmoid,neg:neg,reciprocal:reciprocal,round:round,rsqrt:rsqrt,sigmoid:sigmoid,sign:sign,sin:sin,sinh:sinh,softplus:softplus,sqrt:sqrt,square:square,step:step,tan:tan,tanh:tanh$1,all:all,any:any,argMax:argMax,argMin:argMin,logSumExp:logSumExp,max:max,mean:mean,min:min,moments:moments,sum:sum,equal:equal,equalStrict:equalStrict,greater:greater,greaterEqual:greaterEqual,greaterEqualStrict:greaterEqualStrict,greaterStrict:greaterStrict,less:less,lessEqual:lessEqual,lessEqualStrict:lessEqualStrict,lessStrict:lessStrict,notEqual:notEqual,notEqualStrict:notEqualStrict,add:add,addN:addN,addStrict:addStrict,atan2:atan2,div:div,divStrict:divStrict,floorDiv:floorDiv,maximum:maximum,maximumStrict:maximumStrict,minimum:minimum,minimumStrict:minimumStrict,mod:mod,modStrict:modStrict,mul:mul,mulStrict:mulStrict,pow:pow,powStrict:powStrict,squaredDifference:squaredDifference,squaredDifferenceStrict:squaredDifferenceStrict,sub:sub,subStrict:subStrict,elu:elu,leakyRelu:leakyRelu,prelu:prelu,relu:relu,selu:selu,logicalAnd:logicalAnd,logicalNot:logicalNot,logicalOr:logicalOr,logicalXor:logicalXor,where:where,whereAsync:whereAsync,buffer:buffer,toPixels:toPixels,print:print,cast:cast,clone:clone,cumsum:cumsum,expandDims:expandDims,eye:eye,fromPixels:fromPixels,multinomial:multinomial,oneHot:oneHot,pad:pad,pad1d:pad1d,pad2d:pad2d,pad3d:pad3d,pad4d:pad4d,rand:rand,randomNormal:randomNormal,randomUniform:randomUniform,reshape:reshape,split:split,squeeze:squeeze,stack:stack,tile:tile,truncatedNormal:truncatedNormal,unstack:unstack,batchToSpaceND:batchToSpaceND,spaceToBatchND:spaceToBatchND,fill:fill,linspace:linspace,ones:ones$1,range:range,scalar:scalar,tensor:tensor,tensor1d:tensor1d,tensor2d:tensor2d,tensor3d:tensor3d,tensor4d:tensor4d,tensor5d:tensor5d,tensor6d:tensor6d,zeros:zeros,onesLike:onesLike,zerosLike:zerosLike,transpose:transpose,softmax:softmax,localResponseNormalization:localResponseNormalization,norm:norm,gather:gather,unsortedSegmentSum:unsortedSegmentSum,basicLSTMCell:basicLSTMCell,multiRNNCell:multiRNNCell,movingAverage:movingAverage,stridedSlice:stridedSlice,topk:topk}),MathBackendCPU=function(){function e(){this.data=new WeakMap,this.firstUse=!0,ENV.get(\"IS_BROWSER\")&&(this.canvas=document.createElement(\"canvas\"))}return e.prototype.register=function(e,t,n){if(this.firstUse&&(this.firstUse=!1,ENV.get(\"IS_NODE\")&&warn(\"\\n============================\\nHi there 👋. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details.\\n============================\\n\")),this.data.has(e))throw new Error(\"Data buffer is already registered\");this.data.set(e,null)},e.prototype.write=function(e,t){if(null==t)throw new Error(\"MathBackendCPU.write(): values can not be null\");this.throwIfNoData(e),this.data.set(e,t)},e.prototype.fromPixels=function(e,t){if(null==e)throw new Error(\"pixels passed to tf.fromPixels() can not be null\");var n,r;if(ENV.get(\"IS_NODE\")&&null==e.getContext)throw new Error(\"When running in node, pixels must be an HTMLCanvasElement like the one returned by the `canvas` npm package\");if(null!=e.getContext)n=e.getContext(\"2d\").getImageData(0,0,e.width,e.height).data;else if(e instanceof ImageData)n=e.data;else{if(!(e instanceof HTMLImageElement||e instanceof HTMLVideoElement))throw new Error(\"pixels passed to tf.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement or ImageData, but was \"+e.constructor.name);if(null==this.canvas)throw new Error(\"Can't read pixels from HTMLImageElement outside the browser.\");this.canvas.width=e.width,this.canvas.height=e.height,this.canvas.getContext(\"2d\").drawImage(e,0,0,e.width,e.height),n=this.canvas.getContext(\"2d\").getImageData(0,0,e.width,e.height).data}if(4===t)r=new Int32Array(n);else{var o=e.width*e.height;r=new Int32Array(o*t);for(var a=0;ad&&(d=m,h=f)}u[c]=h}return i},e.prototype.cumsum=function(e,t,n,r){if(t!==e.rank-1)throw new Error(\"backend.cumsum in CPU expects an inner-most axis=\"+(e.rank-1)+\" but got axis=\"+t);for(var o=upcastType(e.dtype,\"int32\"),a=zeros(e.shape,o),i=a.dataSync(),s=e.dataSync(),u=e.shape[e.rank-1],l=r?function(e,t){return e+u-t-1}:function(e,t){return e+t},c=0;ct?1:0})},e.prototype.greaterEqual=function(e,t){return this.broadcastedBinaryOp(e,t,\"bool\",function(e,t){return e>=t?1:0})},e.prototype.logicalNot=function(e){for(var t=e.dataSync(),n=new Int32Array(t.length),r=0;r1||1===t.rank?1:t.shape[1],c=0;c=0&&t>=0?n:(n+t)%t})},e.prototype.max=function(e,t){assertAxesAreInnerMostDims(\"max\",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;lp&&(p=h)}s[l]=p}return a},e.prototype.maximum=function(e,t){return this.broadcastedBinaryOp(e,t,e.dtype,function(e,t){return Math.max(e,t)})},e.prototype.all=function(e,t){assertAxesAreInnerMostDims(\"all\",t,e.rank);for(var n=computeOutAndReduceShapes(e.shape,t),r=n[0],o=n[1],a=zeros(r,e.dtype),i=sizeFromShape(o),s=a.dataSync(),u=e.dataSync(),l=0;l0?n[r]=1:n[r]=0;return Tensor.make(e.shape,{values:n})},e.prototype.round=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r.5?n[r]=Math.ceil(t[r]):n[r]=o%2==0?o:o+1}return Tensor.make(e.shape,{values:n})},e.prototype.exp=function(e){for(var t=e.dataSync(),n=new Float32Array(t.length),r=0;r=0?o:Math.exp(o)-1}return Tensor.make(e.shape,{values:t})},e.prototype.eluDer=function(e,t){for(var n=new Float32Array(t.size),r=t.dataSync(),o=e.dataSync(),a=0;a=1?o[a]:o[a]*(i+1)}return Tensor.make(t.shape,{values:n})},e.prototype.selu=function(e){for(var t=SELU_SCALEALPHA,n=SELU_SCALE,r=new Float32Array(e.size),o=e.dataSync(),a=0;a=0?n*i:t*(Math.exp(i)-1)}return Tensor.make(e.shape,{values:r})},e.prototype.clip=function(e,t,n){for(var r=new Float32Array(e.size),o=e.dataSync(),a=0;a-t,i=r[o]0?1:t}return Tensor.make(e.shape,{values:n})},e.prototype.conv2d=function(e,t,n){for(var r=n.filterHeight,o=n.filterWidth,a=n.dilationHeight,i=n.dilationWidth,s=n.padInfo.left,u=n.padInfo.top,l=buffer(n.outShape,e.dtype),c=0;c=n.inHeight))for(var x=0;x=n.inWidth))for(var S=0;S=n.inHeight))for(var S=0;S=n.inWidth))y+=e.get(p,T,b,d)*t.get(x,S,d,v)}}c.set(y,p,h,m,d*l+v)}return c.toTensor()},e.prototype.depthwiseConv2DDerInput=function(e,t,n){for(var r=buffer(n.inShape,\"float32\"),o=r.values,a=r.strides,i=a[0],s=a[1],u=a[2],l=e.dataSync(),c=e.strides,p=c[0],d=c[1],h=c[2],f=t.dataSync(),m=t.strides,g=m[0],v=m[1],y=m[2],x=n.batchSize,T=n.filterHeight,S=n.filterWidth,b=n.inChannels,E=n.inHeight,w=n.inWidth,_=n.outChannels,A=n.outHeight,R=n.outWidth,C=n.strideHeight,N=n.strideWidth,k=T-1-n.padInfo.top,I=S-1-n.padInfo.left,D=_/b,M=0;MT?T=_:\"avg\"===n&&(S+=_,b++)}if(isNaN(T))break}s.set(\"avg\"===n?S/b:T,c,d,g,p)}return s.toTensor()},e.prototype.maxPool=function(e,t){return this.pool(e,t,\"max\")},e.prototype.maxPoolPositions=function(e,t){for(var n=buffer(t.outShape,\"int32\"),r=t.strideHeight,o=t.strideWidth,a=t.filterHeight,i=t.filterWidth,s=t.padInfo.top,u=t.padInfo.left,l=0;lx&&(x=_,T=b*i+w)}n.set(T,l,p,m,c)}return n.toTensor()},e.prototype.maxPoolBackprop=function(e,t,n,r){for(var o=this.maxPoolPositions(t,r),a=r.strideHeight,i=r.strideWidth,s=r.filterHeight,u=r.filterWidth,l=u-1-r.padInfo.left,c=s-1-r.padInfo.top,p=buffer(t.shape,\"float32\"),d=0;d=r.outHeight||Math.floor(T)!==T))for(var S=0;S=r.outWidth||Math.floor(b)!==b)){var E=s*u-1-o.get(d,T,b,h)===x*u+S?1:0;if(0!==E)y+=e.get(d,T,b,h)*E}}}p.set(y,d,f,m,h)}return p.toTensor()},e.prototype.avgPoolBackprop=function(e,t,n){for(var r=n.strideHeight,o=n.strideWidth,a=n.filterHeight,i=n.filterWidth,s=i-1-n.padInfo.left,u=a-1-n.padInfo.top,l=buffer(t.shape,\"float32\"),c=1/(a*i),p=0;p=n.outHeight||Math.floor(x)!==x))for(var T=0;T=n.outWidth||Math.floor(S)!==S))v+=e.get(p,x,S,d)}}l.set(v*c,p,h,f,d)}return l.toTensor()},e.prototype.cast=function(e,t){return castTensor(e,t,this)},e.prototype.reshape=function(e,t){return reshapeTensor(e,t)},e.prototype.avgPool=function(e,t){return this.pool(e,t,\"avg\").toFloat()},e.prototype.resizeBilinear=function(e,t,n,r){for(var o=e.shape,a=o[0],i=o[1],s=o[2],u=o[3],l=buffer([a,t,n,u],e.dtype),c=[r&&t>1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=d[0]/h[0],m=d[1]/h[1],g=0;g1?i-1:i,r&&n>1?s-1:s],p=[r&&t>1?t-1:t,r&&n>1?n-1:n],d=0;d1?a-1:a,n&&c>1?i-1:i],h=[n&&l>1?l-1:l,n&&c>1?c-1:c],f=1/(d[0]/h[0]),m=1/(d[1]/h[1]),g=2*Math.ceil(f)+2,v=2*Math.ceil(m)+2,y=0;y=l))for(var N=0;N=c)){var I=d[0]*(C/h[0]),D=d[1]*(k/h[1]),M=Math.min(a-1,n?Math.round(I):Math.floor(I)),O=Math.min(i-1,n?Math.round(D):Math.floor(D));x===M&&T===O&&(A+=e.get(y,C,k,_))}}}p.set(A,y,x,T,_)}return p.toTensor()},e.prototype.batchNormalization=function(e,t,n,r,o,a){for(var i=e.dataSync(),s=t.dataSync(),u=n.dataSync(),l=o?o.dataSync():new Float32Array([1]),c=a?a.dataSync():new Float32Array([0]),p=new Float32Array(i.length),d=0;d=0&&e.get(a)0,\"scheme must not be an empty string.\");var r=e.getInstance();assert(null==r.managers[t],\"A model store manager is already registered for scheme '\"+t+\"'.\"),r.managers[t]=n},e.getManager=function(e){var t=this.getInstance().managers[e];if(null==t)throw new Error(\"Cannot find model manager for scheme '\"+e+\"'\");return t},e.getSchemes=function(){return Object.keys(this.getInstance().managers)},e}();function parseURL(e){if(-1===e.indexOf(URL_SCHEME_SUFFIX))throw new Error(\"The url string provided does not contain a scheme. Supported schemes are: \"+ModelStoreManagerRegistry.getSchemes().join(\",\"));return{scheme:e.split(URL_SCHEME_SUFFIX)[0],path:e.split(URL_SCHEME_SUFFIX)[1]}}function cloneModelInternal(e,t,n){return void 0===n&&(n=!1),__awaiter(this,void 0,void 0,function(){var r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return assert(e!==t,\"Old path and new path are the same: '\"+e+\"'\"),assert((r=IORouterRegistry.getLoadHandlers(e)).length>0,\"Copying failed because no load handler is found for source URL \"+e+\".\"),assert(r.length<2,\"Copying failed because more than one (\"+r.length+\") load handlers for source URL \"+e+\".\"),o=r[0],assert((a=IORouterRegistry.getSaveHandlers(t)).length>0,\"Copying failed because no save handler is found for destination URL \"+t+\".\"),assert(a.length<2,\"Copying failed because more than one (\"+r.length+\") save handlers for destination URL \"+t+\".\"),i=a[0],s=parseURL(e).scheme,u=parseURL(e).path,l=s===parseURL(e).scheme,[4,o.load()];case 1:return c=d.sent(),n&&l?[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)]:[3,3];case 2:d.sent(),d.label=3;case 3:return[4,i.save(c)];case 4:return p=d.sent(),!n||l?[3,6]:[4,ModelStoreManagerRegistry.getManager(s).removeModel(u)];case 5:d.sent(),d.label=6;case 6:return[2,p.modelArtifactsInfo]}})})}function listModels(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i;return __generator(this,function(s){switch(s.label){case 0:e=ModelStoreManagerRegistry.getSchemes(),t={},n=0,r=e,s.label=1;case 1:return n0,\"URL path for browserHTTPRequest must not be null, undefined or empty.\"),this.path=e,null!=t&&null!=t.body)throw new Error(\"requestInit is expected to have no pre-existing body, but has one.\");this.requestInit=t||{}}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){var t,n,r,o;return __generator(this,function(a){switch(a.label){case 0:if(e.modelTopology instanceof ArrayBuffer)throw new Error(\"BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.\");return(t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit)).body=new FormData,n=[{paths:[\"./model.weights.bin\"],weights:e.weightSpecs}],r={modelTopology:e.modelTopology,weightsManifest:n},t.body.append(\"model.json\",new Blob([JSON.stringify(r)],{type:\"application/json\"}),\"model.json\"),null!=e.weightData&&t.body.append(\"model.weights.bin\",new Blob([e.weightData],{type:\"application/octet-stream\"}),\"model.weights.bin\"),[4,fetch(this.path,t)];case 1:if(200===(o=a.sent()).status)return[2,{modelArtifactsInfo:getModelArtifactsInfoForJSON(e),responses:[o]}];throw new Error(\"BrowserHTTPRequest.save() failed due to HTTP response status \"+o.status+\".\")}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,n,r,o,a,i,s,u,l,c,p;return __generator(this,function(d){switch(d.label){case 0:return[4,fetch(this.path,this.requestInit)];case 1:return[4,d.sent().json()];case 2:if(e=d.sent(),t=e.modelTopology,n=e.weightsManifest,null==t&&null==n)throw new Error(\"The JSON from HTTP path \"+this.path+\" contains neither model topology or manifest for weights.\");if(null==n)return[3,4];for(a=e.weightsManifest,r=[],i=0,s=a;i0&&(e=__assign({weightSpecs:this.weightSpecs},e)),null!=this.weightData&&this.weightData.byteLength>0&&(e=__assign({weightData:this.weightData},e)),[2,e]})})},e}(),PassthroughSaver=function(){function e(e){this.saveHandler=e}return e.prototype.save=function(e){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(t){return[2,this.saveHandler(e)]})})},e}();function fromMemory(e,t,n){return new PassthroughLoader(e,t,n)}function withSaveHandler(e){return new PassthroughSaver(e)}var registerSaveRouter=IORouterRegistry.registerSaveRouter,registerLoadRouter=IORouterRegistry.registerLoadRouter,getSaveHandlers=IORouterRegistry.getSaveHandlers,getLoadHandlers=IORouterRegistry.getLoadHandlers,io=Object.freeze({browserFiles:browserFiles,browserHTTPRequest:browserHTTPRequest,concatenateArrayBuffers:concatenateArrayBuffers,decodeWeights:decodeWeights,encodeWeights:encodeWeights,fromMemory:fromMemory,getLoadHandlers:getLoadHandlers,getModelArtifactsInfoForJSON:getModelArtifactsInfoForJSON,getSaveHandlers:getSaveHandlers,loadWeights:loadWeights,registerLoadRouter:registerLoadRouter,registerSaveRouter:registerSaveRouter,withSaveHandler:withSaveHandler,copyModel:copyModel,listModels:listModels,moveModel:moveModel,removeModel:removeModel}),Serializable=function(){function e(){}return e.prototype.getClassName=function(){return this.constructor.className},e.fromConfig=function(e,t){return new e(t)},e}(),SerializationMap=function(){function e(){this.classNameMap={}}return e.getMap=function(){return null==e.instance&&(e.instance=new e),e.instance},e.register=function(t){e.getMap().classNameMap[t.className]=[t,t.fromConfig]},e}(),serialization=Object.freeze({Serializable:Serializable,SerializationMap:SerializationMap}),WEBGL_ENVS={HAS_WEBGL:!0},NODE_ENVS={IS_NODE:!0},CHROME_ENVS={IS_CHROME:!0},BROWSER_ENVS={IS_BROWSER:!0},CPU_ENVS={HAS_WEBGL:!1},ALL_ENVS={};function expectArraysClose(e,t,n){if(null==n&&(n=ENV.get(\"TEST_EPSILON\")),e instanceof Tensor||t instanceof Tensor){if(e instanceof Tensor&&t instanceof Tensor){if(e.dtype!==t.dtype)throw new Error(\"Arrays are of different type actual: \"+e.dtype+\" vs expected: \"+t.dtype+\".\");if(!arraysEqual(e.shape,t.shape))throw new Error(\"Arrays are of different shape actual: \"+e.shape+\" vs expected: \"+t.shape+\".\")}}else{var r=e.constructor.name,o=t.constructor.name;if(r!==o)throw new Error(\"Arrays are of different type actual: \"+r+\" vs expected: \"+o)}var a,i;if(a=e instanceof Tensor?e.dataSync():e,i=t instanceof Tensor?t.dataSync():t,a.length!==i.length)throw new Error(\"Arrays have different lengths actual: \"+a.length+\" vs expected: \"+i.length+\".\\nActual: \"+a+\".\\nExpected: \"+i+\".\");for(var s=0;sn)}function expectValuesInRange(e,t,n){var r;r=e instanceof Tensor?e.dataSync():e;for(var o=0;on)throw new Error(\"Value out of range:\"+r[o]+\" low: \"+t+\", high: \"+n)}function expectArrayBuffersEqual(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}var test_util=Object.freeze({WEBGL_ENVS:WEBGL_ENVS,NODE_ENVS:NODE_ENVS,CHROME_ENVS:CHROME_ENVS,BROWSER_ENVS:BROWSER_ENVS,CPU_ENVS:CPU_ENVS,ALL_ENVS:ALL_ENVS,expectArraysClose:expectArraysClose,expectPromiseToFail:expectPromiseToFail,expectArraysEqual:expectArraysEqual,expectNumbersClose:expectNumbersClose,expectValuesInRange:expectValuesInRange,expectArrayBuffersEqual:expectArrayBuffersEqual}),version=\"0.12.8\",webgl=Object.freeze({gpgpu_util:gpgpu_util,webgl_util:webgl_util,MathBackendWebGL:MathBackendWebGL,GPGPUContext:GPGPUContext}),Optimizer=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.minimize=function(e,t,n){void 0===t&&(t=!1);var r=this.computeGradients(e,n),o=r.value,a=r.grads;return this.applyGradients(a),Object.keys(a).forEach(function(e){return a[e].dispose()}),t?o:(o.dispose(),null)},t.prototype.computeGradients=function(e,t){return variableGrads(e,t)},t}(Serializable),DEFAULT_FLOAT32_EPSILON=1e-8,DEFAULT_FLOAT16_EPSILON=1e-4;function getOptimizerDefaultEpsilonValue(){return ENV.get(\"WEBGL_RENDER_FLOAT32_ENABLED\")?DEFAULT_FLOAT32_EPSILON:DEFAULT_FLOAT16_EPSILON}var AdadeltaOptimizer=function(e){function t(t,n,r){void 0===r&&(r=null);var o=e.call(this)||this;return o.learningRate=t,o.rho=n,o.epsilon=r,o.accumulatedGrads={},o.accumulatedUpdates={},o.c=keep(scalar(-t)),o.rhoScalar=keep(scalar(n)),o.oneMinusRho=keep(scalar(1-n)),null===r&&(r=getOptimizerDefaultEpsilonValue()),o.epsilonScalar=keep(scalar(r)),o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedUpdates[n]){tidy(function(){t.accumulatedUpdates[n]=zerosLike(o).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n],s=r.accumulatedUpdates[n];tidy(function(){var e=t.rhoScalar.mul(i).add(t.oneMinusRho.mul(a.square())),r=s.add(t.epsilonScalar).sqrt().div(i.add(t.epsilonScalar).sqrt()).mul(a),u=t.rhoScalar.mul(s).add(t.oneMinusRho.mul(r.square()));t.accumulatedGrads[n].assign(e),t.accumulatedUpdates[n].assign(u);var l=t.c.mul(r).add(o);o.assign(l)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.rhoScalar.dispose(),this.oneMinusRho.dispose(),null!=this.accumulatedUpdates&&(Object.keys(this.accumulatedUpdates).forEach(function(t){return e.accumulatedUpdates[t].dispose()}),Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()}))},t.prototype.getConfig=function(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.rho,t.epsilon)},t.className=\"AdadeltaOptimizer\",t}(Optimizer);SerializationMap.register(AdadeltaOptimizer);var AdagradOptimizer=function(e){function t(t,n){void 0===n&&(n=.1);var r=e.call(this)||this;r.learningRate=t,r.initialAccumulatorValue=n,r.accumulatedGrads={},r.c=keep(scalar(-t));var o=getOptimizerDefaultEpsilonValue();return r.epsilon=keep(scalar(o)),r}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedGrads[n]){tidy(function(){t.accumulatedGrads[n]=fill(o.shape,t.initialAccumulatorValue).variable(!1)})}var a=e[n],i=r.accumulatedGrads[n];tidy(function(){var e=i.add(a.square());t.accumulatedGrads[n].assign(e);var r=t.c.mul(a.div(e.add(t.epsilon).sqrt())).add(o);o.assign(r)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.epsilon.dispose(),this.c.dispose(),null!=this.accumulatedGrads&&Object.keys(this.accumulatedGrads).forEach(function(t){return e.accumulatedGrads[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}},t.fromConfig=function(e,t){return new e(t.learningRate,t.initialAccumulatorValue)},t.className=\"AdagradOptimizer\",t}(Optimizer);SerializationMap.register(AdagradOptimizer);var AdamOptimizer=function(e){function t(t,n,r,o){void 0===o&&(o=null);var a=e.call(this)||this;return a.learningRate=t,a.beta1=n,a.beta2=r,a.epsilon=o,a.accumulatedFirstMoment={},a.accumulatedSecondMoment={},a.c=keep(scalar(-t)),a.beta1Scalar=keep(scalar(n)),a.beta2Scalar=keep(scalar(r)),tidy(function(){a.accBeta1=scalar(n).variable(),a.accBeta2=scalar(r).variable()}),a.oneMinusBeta1=keep(scalar(1-n)),a.oneMinusBeta2=keep(scalar(1-r)),a.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),a.epsScalar=keep(scalar(o)),a}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.one.sub(t.accBeta2);for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedSecondMoment[o]){i=!1;t.accumulatedSecondMoment[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedSecondMoment[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l).add(t.oneMinusBeta2.mul(s.square())),d=c.div(n),h=p.div(r);t.accumulatedFirstMoment[o].assign(c),t.accumulatedSecondMoment[o].assign(p);var f=t.c.mul(d.div(t.epsScalar.add(h.sqrt()))).add(a);a.assign(f)}t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar)),t.accBeta2.assign(t.accBeta2.mul(t.beta2Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.accBeta1.dispose(),this.accBeta2.dispose(),this.oneMinusBeta1.dispose(),this.oneMinusBeta2.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedSecondMoment&&Object.keys(this.accumulatedSecondMoment).forEach(function(t){return e.accumulatedSecondMoment[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)},t.className=\"AdamOptimizer\",t}(Optimizer);SerializationMap.register(AdamOptimizer);var AdamaxOptimizer=function(e){function t(t,n,r,o,a){void 0===o&&(o=null),void 0===a&&(a=0);var i=e.call(this)||this;return i.learningRate=t,i.beta1=n,i.beta2=r,i.epsilon=o,i.decay=a,i.accumulatedFirstMoment={},i.accumulatedWeightedInfNorm={},i.c=keep(scalar(-t)),i.beta1Scalar=keep(scalar(n)),i.beta2Scalar=keep(scalar(r)),i.decayScalar=keep(scalar(a)),tidy(function(){i.iteration=scalar(0).variable(),i.accBeta1=scalar(n).variable()}),i.oneMinusBeta1=keep(scalar(1-n)),i.one=keep(scalar(1)),null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;tidy(function(){var n=t.one.sub(t.accBeta1),r=t.c.div(t.one.add(t.decayScalar.mul(t.iteration)));for(var o in e){var a=ENV.engine.registeredVariables[o];if(null==t.accumulatedFirstMoment[o]){var i=!1;t.accumulatedFirstMoment[o]=zerosLike(a).variable(i)}if(null==t.accumulatedWeightedInfNorm[o]){i=!1;t.accumulatedWeightedInfNorm[o]=zerosLike(a).variable(i)}var s=e[o],u=t.accumulatedFirstMoment[o],l=t.accumulatedWeightedInfNorm[o],c=t.beta1Scalar.mul(u).add(t.oneMinusBeta1.mul(s)),p=t.beta2Scalar.mul(l),d=s.abs(),h=p.maximum(d);t.accumulatedFirstMoment[o].assign(c),t.accumulatedWeightedInfNorm[o].assign(h);var f=r.div(n).mul(c.div(t.epsScalar.add(h))).add(a);a.assign(f)}t.iteration.assign(t.iteration.add(t.one)),t.accBeta1.assign(t.accBeta1.mul(t.beta1Scalar))})},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsScalar.dispose(),this.accBeta1.dispose(),this.beta1Scalar.dispose(),this.beta2Scalar.dispose(),this.oneMinusBeta1.dispose(),this.decayScalar.dispose(),this.iteration.dispose(),this.one.dispose(),null!=this.accumulatedFirstMoment&&Object.keys(this.accumulatedFirstMoment).forEach(function(t){return e.accumulatedFirstMoment[t].dispose()}),null!=this.accumulatedWeightedInfNorm&&Object.keys(this.accumulatedWeightedInfNorm).forEach(function(t){return e.accumulatedWeightedInfNorm[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}},t.fromConfig=function(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)},t.className=\"AdamaxOptimizer\",t}(Optimizer);SerializationMap.register(AdamaxOptimizer);var SGDOptimizer=function(e){function t(t){var n=e.call(this)||this;return n.learningRate=t,n.setLearningRate(t),n}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this;Object.keys(e).forEach(function(n){var r=e[n],o=ENV.engine.registeredVariables[n];tidy(function(){var e=t.c.mul(r).add(o);o.assign(e)})})},t.prototype.setLearningRate=function(e){this.learningRate=e,null!=this.c&&this.c.dispose(),this.c=keep(scalar(-e))},t.prototype.dispose=function(){this.c.dispose()},t.prototype.getConfig=function(){return{learningRate:this.learningRate}},t.fromConfig=function(e,t){return new e(t.learningRate)},t.className=\"SGDOptimizer\",t}(Optimizer);SerializationMap.register(SGDOptimizer);var MomentumOptimizer=function(e){function t(t,n,r){void 0===r&&(r=!1);var o=e.call(this,t)||this;return o.learningRate=t,o.momentum=n,o.useNesterov=r,o.m=scalar(o.momentum),o.accumulations={},o}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulations[n]){tidy(function(){t.accumulations[n]=zerosLike(o).variable(!1)})}var a=r.accumulations[n],i=e[n];tidy(function(){var e,r=t.m.mul(a).add(i);e=t.useNesterov?t.c.mul(i.add(r.mul(t.m))).add(o):t.c.mul(r).add(o),t.accumulations[n].assign(r),o.assign(e)})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){if(e.prototype.dispose.call(this),this.m.dispose(),null!=this.accumulations)for(var t in this.accumulations)this.accumulations[t].dispose()},t.prototype.setMomentum=function(e){this.momentum=e},t.prototype.getConfig=function(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}},t.fromConfig=function(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)},t.className=\"MomentumOptimizer\",t}(SGDOptimizer);SerializationMap.register(MomentumOptimizer);var RMSPropOptimizer=function(e){function t(t,n,r,o,a){void 0===n&&(n=.9),void 0===r&&(r=0),void 0===o&&(o=null),void 0===a&&(a=!1);var i=e.call(this)||this;return i.learningRate=t,i.decay=n,i.momentum=r,i.epsilon=o,i.accumulatedMeanSquares={},i.accumulatedMeanGrads={},i.accumulatedMoments={},i.c=keep(scalar(t)),i.decayScalar=keep(scalar(n)),i.momentumScalar=keep(scalar(r)),i.oneMinusDecay=keep(scalar(1-n)),i.centered=a,null===o&&(o=getOptimizerDefaultEpsilonValue()),i.epsilonScalar=keep(scalar(o)),i}return __extends(t,e),t.prototype.applyGradients=function(e){var t=this,n=function(n){var o=ENV.engine.registeredVariables[n];if(null==r.accumulatedMeanSquares[n]){tidy(function(){t.accumulatedMeanSquares[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMeanGrads[n]&&r.centered){tidy(function(){t.accumulatedMeanGrads[n]=zerosLike(o).variable(!1)})}if(null==r.accumulatedMoments[n]){tidy(function(){t.accumulatedMoments[n]=zerosLike(o).variable(!1)})}var a=r.accumulatedMeanSquares[n],i=r.accumulatedMeanGrads[n],s=r.accumulatedMoments[n],u=e[n];tidy(function(){var e=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));if(t.centered){var r=t.decayScalar.mul(i).add(t.oneMinusDecay.mul(u)),l=t.momentumScalar.mul(s).add(t.c.mul(u).div(e.sub(r.square().add(t.epsilonScalar)).sqrt()));t.accumulatedMeanSquares[n].assign(e),t.accumulatedMeanGrads[n].assign(r),t.accumulatedMoments[n].assign(l);var c=o.sub(l);o.assign(c)}else{var p=t.decayScalar.mul(a).add(t.oneMinusDecay.mul(u.square()));l=t.momentumScalar.mul(s).add(t.c.mul(u).div(p.add(t.epsilonScalar).sqrt()));t.accumulatedMeanSquares[n].assign(p),t.accumulatedMoments[n].assign(l);c=o.sub(l);o.assign(c)}})},r=this;for(var o in e)n(o)},t.prototype.dispose=function(){var e=this;this.c.dispose(),this.epsilonScalar.dispose(),this.decayScalar.dispose(),this.momentumScalar.dispose(),this.oneMinusDecay.dispose(),null!=this.accumulatedMeanSquares&&Object.keys(this.accumulatedMeanSquares).forEach(function(t){return e.accumulatedMeanSquares[t].dispose()}),null!=this.accumulatedMeanGrads&&this.centered&&Object.keys(this.accumulatedMeanGrads).forEach(function(t){return e.accumulatedMeanGrads[t].dispose()}),null!=this.accumulatedMoments&&Object.keys(this.accumulatedMoments).forEach(function(t){return e.accumulatedMoments[t].dispose()})},t.prototype.getConfig=function(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}},t.fromConfig=function(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)},t.className=\"RMSPropOptimizer\",t}(Optimizer);SerializationMap.register(RMSPropOptimizer);var OptimizerConstructors=function(){function e(){}return e.sgd=function(e){return new SGDOptimizer(e)},e.momentum=function(e,t,n){return void 0===n&&(n=!1),new MomentumOptimizer(e,t,n)},e.rmsprop=function(e,t,n,r,o){return void 0===t&&(t=.9),void 0===n&&(n=0),void 0===r&&(r=null),void 0===o&&(o=!1),new RMSPropOptimizer(e,t,n,r,o)},e.adam=function(e,t,n,r){return void 0===e&&(e=.001),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),new AdamOptimizer(e,t,n,r)},e.adadelta=function(e,t,n){return void 0===e&&(e=.001),void 0===t&&(t=.95),void 0===n&&(n=null),new AdadeltaOptimizer(e,t,n)},e.adamax=function(e,t,n,r,o){return void 0===e&&(e=.002),void 0===t&&(t=.9),void 0===n&&(n=.999),void 0===r&&(r=null),void 0===o&&(o=0),new AdamaxOptimizer(e,t,n,r,o)},e.adagrad=function(e,t){return void 0===t&&(t=.1),new AdagradOptimizer(e,t)},e}(),train={sgd:OptimizerConstructors.sgd,momentum:OptimizerConstructors.momentum,adadelta:OptimizerConstructors.adadelta,adagrad:OptimizerConstructors.adagrad,rmsprop:OptimizerConstructors.rmsprop,adamax:OptimizerConstructors.adamax,adam:OptimizerConstructors.adam},setBackend=Environment.setBackend,getBackend=Environment.getBackend,disposeVariables=Environment.disposeVariables,memory=Environment.memory;setOpHandler(ops);export{setBackend,getBackend,disposeVariables,memory,version as version_core,nextFrame,environment,io,serialization,test_util,util,webgl,AdadeltaOptimizer,AdagradOptimizer,AdamOptimizer,AdamaxOptimizer,MomentumOptimizer,Optimizer,RMSPropOptimizer,SGDOptimizer,Tensor,TensorBuffer,variable,Variable,Rank,Reduction,ENV,Environment,image_ops as image,linalg_ops as linalg,loss_ops as losses,op,batchNormalization2d,batchNormalization3d,batchNormalization4d,batchNormalization,concat,concat1d,concat2d,concat3d,concat4d,conv1d,conv2d,depthwiseConv2d,separableConv2d,conv2dTranspose,matMul,dot,outerProduct,reverse,reverse1d,reverse2d,reverse3d,reverse4d,maxPool,avgPool,slice,slice1d,slice2d,slice3d,slice4d,abs,acos,acosh,asin,asinh,atan,atanh,ceil,clipByValue,cos,cosh,erf,exp,expm1,floor,log$1 as log,log1p,logSigmoid,neg,reciprocal,round,rsqrt,sigmoid,sign,sin,sinh,softplus,sqrt,square,step,tan,tanh$1 as tanh,all,any,argMax,argMin,logSumExp,max,mean,min,moments,sum,equal,equalStrict,greater,greaterEqual,greaterEqualStrict,greaterStrict,less,lessEqual,lessEqualStrict,lessStrict,notEqual,notEqualStrict,add,addN,addStrict,atan2,div,divStrict,floorDiv,maximum,maximumStrict,minimum,minimumStrict,mod,modStrict,mul,mulStrict,pow,powStrict,squaredDifference,squaredDifferenceStrict,sub,subStrict,elu,leakyRelu,prelu,relu,selu,logicalAnd,logicalNot,logicalOr,logicalXor,where,whereAsync,buffer,toPixels,print,cast,clone,cumsum,expandDims,eye,fromPixels,multinomial,oneHot,pad,pad1d,pad2d,pad3d,pad4d,rand,randomNormal,randomUniform,reshape,split,squeeze,stack,tile,truncatedNormal,unstack,batchToSpaceND,spaceToBatchND,fill,linspace,ones$1 as ones,range,scalar,tensor,tensor1d,tensor2d,tensor3d,tensor4d,tensor5d,tensor6d,zeros,onesLike,zerosLike,transpose,softmax,localResponseNormalization,norm,gather,unsortedSegmentSum,basicLSTMCell,multiRNNCell,movingAverage,stridedSlice,topk,train,tidy,keep,dispose,time,customGrad,grad,grads,valueAndGrad,valueAndGrads,variableGrads};\n//# sourceMappingURL=tf-core.esm.js.map\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport{keep,scalar,tidy,onesLike,tensor1d,util,zerosLike,train,cast,serialization,add,mul,div,Tensor,Optimizer,mean,io,transpose,reverse,zeros,sum,dispose,neg,variable,ones,eye,randomUniform,truncatedNormal,randomNormal,sub,sqrt,mulStrict,clipByValue,relu,linalg,leakyRelu,elu,conv1d,conv2d,conv2dTranspose,separableConv2d,depthwiseConv2d,maximum,minimum,batchNormalization2d,batchNormalization3d,batchNormalization4d,moments,movingAverage,pad,maxPool,avgPool,squeeze,max,abs,log,softplus,softmax,floor,oneHot,exp,greater,equal,argMax,slice1d,slice2d,slice3d,slice4d,concat,concat1d,concat2d,concat3d,concat4d,tile,matMul,gather,step,min,selu,sigmoid,tanh}from\"@tensorflow/tfjs-core\";var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function __extends(e,t){function n(){this.constructor=e}extendStatics(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}var __assign=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])&&(6===a[0]||2===a[0])){o=0;continue}if(3===a[0]&&(!i||a[1]>i[0]&&a[1]t?1:0}function reverseNumberCompare(e,t){return-1*numberCompare(e,t)}function stringToDType(e){switch(e){case\"float32\":return\"float32\";default:throw new ValueError(\"Invalid dtype: \"+e)}}function unique(e){if(null==e)return e;for(var t=[],n=0,r=e;n=0),assert(r>=n),Array.isArray(e)&&e.length>=n&&e.length<=r&&e.every(function(e){return typeof e===t})}function calcL2Norms(e,t){return tidy(function(){return sqrt(sum(mulStrict(e,e),t,!0))})}var Constraint=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.getConfig=function(){return{}},t}(serialization.Serializable),MaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMaxValue=2,n.defaultAxis=0,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=clipByValue(n,0,t.maxValue);return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{maxValue:this.maxValue,axis:this.axis}},t.className=\"MaxNorm\",t}(Constraint);serialization.SerializationMap.register(MaxNorm);var UnitNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultAxis=0,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){return div(e,add(getScalar(epsilon()),calcL2Norms(e,t.axis)))})},t.prototype.getConfig=function(){return{axis:this.axis}},t.className=\"UnitNorm\",t}(Constraint);serialization.SerializationMap.register(UnitNorm);var NonNeg=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.apply=function(e){return relu(e)},t.className=\"NonNeg\",t}(Constraint);serialization.SerializationMap.register(NonNeg);var MinMaxNorm=function(e){function t(t){var n=e.call(this)||this;return n.defaultMinValue=0,n.defaultMaxValue=1,n.defaultRate=1,n.defaultAxis=0,n.minValue=null!=t.minValue?t.minValue:n.defaultMinValue,n.maxValue=null!=t.maxValue?t.maxValue:n.defaultMaxValue,n.rate=null!=t.rate?t.rate:n.defaultRate,n.axis=null!=t.axis?t.axis:n.defaultAxis,n}return __extends(t,e),t.prototype.apply=function(e){var t=this;return tidy(function(){var n=calcL2Norms(e,t.axis),r=add(mul(getScalar(t.rate),clipByValue(n,t.minValue,t.maxValue)),mul(getScalar(1-t.rate),n));return mul(e,div(r,add(getScalar(epsilon()),n)))})},t.prototype.getConfig=function(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}},t.className=\"MinMaxNorm\",t}(Constraint);serialization.SerializationMap.register(MinMaxNorm);var CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP={maxNorm:\"MaxNorm\",minMaxNorm:\"MinMaxNorm\",nonNeg:\"NonNeg\",unitNorm:\"UnitNorm\"};function serializeConstraint(e){return serializeKerasObject(e)}function deserializeConstraint(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,\"constraint\")}function getConstraint(e){return null==e?null:\"string\"==typeof e?deserializeConstraint({className:e in CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP?CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e,config:{}}):e instanceof Constraint?e:deserializeConstraint(e)}function maxNorm(e){return new MaxNorm(e)}function unitNorm(e){return new UnitNorm(e)}function nonNeg(){return new NonNeg}function minMaxNorm(e){return new MinMaxNorm(e)}var exports_constraints=Object.freeze({maxNorm:maxNorm,unitNorm:unitNorm,nonNeg:nonNeg,minMaxNorm:minMaxNorm}),nameMap=new Map,VALID_DATA_FORMAT_VALUES=[\"channelsFirst\",\"channelsLast\"];function checkDataFormat(e){checkStringTypeUnionValue(VALID_DATA_FORMAT_VALUES,\"DataFormat\",e)}var VALID_PADDING_MODE_VALUES=[\"valid\",\"same\",\"causal\"];function checkPaddingMode(e){checkStringTypeUnionValue(VALID_PADDING_MODE_VALUES,\"PaddingMode\",e)}var VALID_POOL_MODE_VALUES=[\"max\",\"avg\"];function checkPoolMode(e){checkStringTypeUnionValue(VALID_POOL_MODE_VALUES,\"PoolMode\",e)}var _nameScopeStack=[],_nameScopeDivider=\"/\";function nameScope(e,t){_nameScopeStack.push(e);try{var n=t();return _nameScopeStack.pop(),n}catch(e){throw _nameScopeStack.pop(),e}}function currentNameScopePrefix(){return 0===_nameScopeStack.length?\"\":_nameScopeStack.join(_nameScopeDivider)+_nameScopeDivider}function getScopedTensorName(e){if(!isValidTensorName(e))throw new Error(\"Not a valid tensor name: '\"+e+\"'\");return currentNameScopePrefix()+e}function getUniqueTensorName(e){if(!isValidTensorName(e))throw new Error(\"Not a valid tensor name: '\"+e+\"'\");nameMap.has(e)||nameMap.set(e,0);var t=nameMap.get(e);if(nameMap.set(e,nameMap.get(e)+1),t>0){var n=e+\"_\"+t;return nameMap.set(n,1),n}return e}var tensorNameRegex=new RegExp(/^[A-Za-z][A-Za-z0-9\\._\\/]*$/);function isValidTensorName(e){return!!e.match(tensorNameRegex)}function isInteger(e){return e===parseInt(e.toString(),10)}function arrayProd(e,t,n){null==t&&(t=0),null==n&&(n=e.length);for(var r=1,i=t;i2e3&&console.warn(\"Orthogonal initializer is being called on a matrix with more than 2000 (\"+e[0]*e[1]+\") elements: Slowness may result.\");var t=randomNormal$1(e[0]>e[1]?[e[1],e[0]]:e,0,1,\"float32\"),r=linalg.gramSchmidt(t);return e[0]>e[1]&&(r=r.transpose()),mul(getScalar(n.gain),r)})},t.prototype.getConfig=function(){return{gain:this.gain,seed:this.seed}},t.className=\"Orthogonal\",t}(Initializer);serialization.SerializationMap.register(Orthogonal);var INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP={constant:\"Constant\",glorotNormal:\"GlorotNormal\",glorotUniform:\"GlorotUniform\",heNormal:\"HeNormal\",identity:\"Identity\",leCunNormal:\"LeCunNormal\",ones:\"Ones\",orthogonal:\"Orthogonal\",randomNormal:\"RandomNormal\",randomUniform:\"RandomUniform\",truncatedNormal:\"TruncatedNormal\",varianceScaling:\"VarianceScaling\",zeros:\"Zeros\"};function deserializeInitializer(e,t){return void 0===t&&(t={}),deserializeKerasObject(e,serialization.SerializationMap.getMap().classNameMap,t,\"initializer\")}function serializeInitializer(e){return serializeKerasObject(e)}function getInitializer(e){if(\"string\"==typeof e){var t=e in INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP?INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP[e]:e;return\"GlorotUniform\"===t?new GlorotUniform:\"GlorotNormal\"===t?new GlorotNormal:\"HeNormal\"===t?new HeNormal:\"LeCunNormal\"===t?new LeCunNormal:deserializeInitializer({className:t,config:{}})}return e instanceof Initializer?e:deserializeInitializer(e)}function zeros$1(){return new Zeros}function ones$1(){return new Ones}function constant(e){return new Constant(e)}function randomUniform$1(e){return new RandomUniform(e)}function randomNormal$2(e){return new RandomNormal(e)}function truncatedNormal$1(e){return new TruncatedNormal(e)}function identity(e){return new Identity(e)}function varianceScaling(e){return new VarianceScaling(e)}function glorotUniform(e){return new GlorotUniform(e)}function glorotNormal(e){return new GlorotNormal(e)}function heNormal(e){return new HeNormal(e)}function leCunNormal(e){return new LeCunNormal(e)}function orthogonal(e){return new Orthogonal(e)}var exports_initializers=Object.freeze({zeros:zeros$1,ones:ones$1,constant:constant,randomUniform:randomUniform$1,randomNormal:randomNormal$2,truncatedNormal:truncatedNormal$1,identity:identity,varianceScaling:varianceScaling,glorotUniform:glorotUniform,glorotNormal:glorotNormal,heNormal:heNormal,leCunNormal:leCunNormal,orthogonal:orthogonal});function isArrayOfShapes(e){return Array.isArray(e)&&Array.isArray(e[0])}function normalizeShapeList(e){return 0===e.length?[]:Array.isArray(e[0])?e:[e]}function getExactlyOneTensor(e){var t;if(Array.isArray(e)){if(1!==e.length)throw new ValueError(\"Expected Tensor length to be 1; got \"+e.length);t=e[0]}else t=e;return t}function getExactlyOneShape(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(1===e.length)return(e=e)[0];throw new ValueError(\"Expected exactly 1 Shape; got \"+e.length)}return e}function countParamsInWeights(e){for(var t=0,n=0,r=e;n1)throw new AttributeError(\"Layer \"+this.name+' has multiple inbound nodes, hence the notion of \"layer input\" is ill-defined. Use `getInputAt(nodeIndex)` instead.');if(0===this.inboundNodes.length)throw new AttributeError(\"Layer \"+this.name+\" is not connected, no input to return.\");return singletonOrArray(this.getNodeAtIndex(0,\"input\").inputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"output\",{get:function(){if(0===this.inboundNodes.length)throw new AttributeError(\"Layer \"+this.name+\" has no inbound nodes.\");if(this.inboundNodes.length>1)throw new AttributeError(\"Layer \"+this.name+' has multiple inbound nodes, hence the notion of \"layer output\" is ill-defined. Use `getOutputAt(nodeIndex)` instead.');return singletonOrArray(this.getNodeAtIndex(0,\"output\").outputTensors)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"losses\",{get:function(){return this._losses},enumerable:!0,configurable:!0}),t.prototype.calculateLosses=function(){return this.losses.map(function(e){return e()})},Object.defineProperty(t.prototype,\"updates\",{get:function(){return this._updates},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"built\",{get:function(){return this._built},set:function(e){this._built=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"trainableWeights\",{get:function(){return this.trainable?this._trainableWeights:[]},set:function(e){this._trainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"nonTrainableWeights\",{get:function(){return this.trainable?this._nonTrainableWeights:this._trainableWeights.concat(this._nonTrainableWeights)},set:function(e){this._nonTrainableWeights=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"weights\",{get:function(){return this.trainableWeights.concat(this.nonTrainableWeights)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"stateful\",{get:function(){return this._stateful},enumerable:!0,configurable:!0}),t.prototype.assertInputCompatibility=function(e){if(e=toList(e),null!=this.inputSpec&&0!==this.inputSpec.length){var t=toList(this.inputSpec);if(e.length!==t.length)throw new ValueError(\"Layer \"+this.name+\" expects \"+t.length+\" inputs, but it received \"+e.length+\" input tensors. Input received: \"+e);for(var n=0;ni.maxNDim)throw new ValueError(\"Input \"+n+\" is incompatible with layer \"+this.name+\": expected max_ndim=\"+i.maxNDim+\", found ndim=\"+a);if(null!=i.minNDim&&a=0?o[l]:o[o.length+l];if(null!=u&&-1===[u,null].indexOf(c))throw new ValueError(\"Input \"+n+\" is incompatible with layer \"+this.name+\": expected axis \"+l+\" of input shape to have value \"+u+\" but got shape \"+o+\".\")}}if(null!=i.shape)for(var p=0;p0&&Array.isArray(g[0])?g.map(function(r,i){return new SymbolicTensor(m,r,n,toList(e),t,n.name,i)}):new SymbolicTensor(m,g,n,toList(e),t,n.name),n.addInboundNode(e,f,null,null,d,g,t),null!=n.activityRegularizer)throw new NotImplementedError(\"Layer invocation in the presence of activity regularizer(s) is not supported yet.\");return f})},t.prototype.warnOnIncompatibleInputShape=function(e){if(null!=this.batchInputShape)if(e.length!==this.batchInputShape.length)console.warn(\"The rank of the input tensor provided (shape: \"+JSON.stringify(e)+\") does not match that of the batchInputShape (\"+JSON.stringify(this.batchInputShape)+\") of the layer \"+this.name);else{var t=!1;this.batchInputShape.forEach(function(n,r){null!=n&&null!=e[r]&&e[r]!==n&&(t=!0)}),t&&console.warn(\"The shape of the input tensor (\"+JSON.stringify(e)+\") does not match the expectation of layer \"+this.name+\": \"+JSON.stringify(this.batchInputShape))}},Object.defineProperty(t.prototype,\"outputShape\",{get:function(){if(null==this.inboundNodes||0===this.inboundNodes.length)throw new AttributeError(\"The layer \"+this.name+\" has never been called and thus has no defined output shape.\");for(var e=[],t=0,n=this.inboundNodes;t0)&&(t=e.sourceLayer,n=e.nodeIndex),0===t.inboundNodes.length)return[e];var r=t.inboundNodes[n];if(0===r.inboundLayers.length)return r.inputTensors;for(var i=[],a=0;a1||1===s.length&&s[0].inboundLayers.length>1){t=!1;break}r.push.apply(r,s)}if(t)for(var l=0,u=e.layers;l0&&(r=r.slice(0,r.length-1)+\" \"),r=(r+=e[i]).slice(0,t[i]),r+=\" \".repeat(t[i]-r.length);n(r)}function printLayerSummary(e,t,n){var r;try{r=JSON.stringify(e.outputShape)}catch(e){r=\"multiple\"}printRow([e.name+\" (\"+e.getClassName()+\")\",r,e.countParams().toString()],t,n)}function printLayerSummaryWithConnections(e,t,n,r){var i;try{i=JSON.stringify(e.outputShape)}catch(e){i=\"multiple\"}for(var a=[],o=0,s=e.inboundNodes;o0&&-1===n.indexOf(l)))for(var u=0;u0)throw new ValueError(p.length+\" of \"+r+\" weights are not set: \"+p);batchSetValue(u)}var Container=function(e){function t(n){var r=e.call(this,{})||this;if(r.containerNodes=new Set,r.name=n.name,null==r.name){var i=r.getClassName().toLowerCase();r.name=getUid(i)}if(r.supportsMasking=!1,r.trainable=!0,r.updatable=!0,Array.isArray(n.inputs)?r.inputs=n.inputs.slice():r.inputs=[n.inputs],Array.isArray(n.outputs)?r.outputs=n.outputs.slice():r.outputs=[n.outputs],unique(r.inputs).length!==r.inputs.length)throw new ValueError(\"The list of inputs passed to the model is redundant. All inputs should only appear once. Found: \"+r.inputs.map(function(e){return e.name}));unique(r.outputs).length!==r.outputs.length&&console.warn(\"The list of outputs passed to the model is redundant. All outputs should only appear once. Found: \"+r.outputs.map(function(e){return e.name})),r.inputLayers=[],r.inputLayersNodeIndices=[],r.inputLayersTensorIndices=[],r.outputLayers=[],r.outputLayersNodeIndices=[],r.outputLayersTensorIndices=[],r.layers=[];for(var a=0,o=r.outputs;a1 nodes\"),assert(0===u,\"input layer has >1 tensors\"),r.inputLayers.push(s),r.inputLayersNodeIndices.push(l),r.inputLayersTensorIndices.push(u)}r.inputNames=[],r.outputNames=[],r.feedInputShapes=[],r.feedInputNames=[],r.feedOutputNames=[];for(var h=0;h=0;)i.splice(i.indexOf(l),1);z.push(l)}},S=[],A=[],I=0,N=r.outputs;Ir?1:0});for(var j=0,W=U;j0)throw new ValueError(\"Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.\");if(!this.trainable)return[];for(var e=[],t=0,n=this.layers;t1)for(var s=0,l=o;s0){for(var d=[],g=0;g0&&e.apply(singletonOrArray(a),r)}function o(e){var r=e.name,a=deserialize(e,null!=t.customObjects?t.customObjects:{});n[r]=a;for(var o=0,s=e.inboundNodes;o0)a=!0;else if(isDataDict(e)){for(var o in e)if(e.hasOwnProperty(o)){a=!0;break}}else a=!0;if(a)throw new ValueError(\"Error when checking model \"+i+\" expected no data, but got \"+e)}return[]}if(null==e)return t.map(function(e){return null});var s;if(isDataDict(e)){e=e,s=[];for(var l=0,u=t;l1)throw new ValueError(\"The model \"+i+\" expects \"+t.length+\" Tensor(s), but only received one Tensor. Found: Tensor with shape \"+e.shape);s=[e]}for(var p=0;p=0&&g!==f)throw new ValueError(\"Error when checking \"+i+\": expected \"+t[p]+\" to have shape [\"+n[p]+\"], but got array with shape [\"+h.shape+\"].\")}}return s}function checkArrayLengths(e,t,n){var r=unique(e.map(function(e){return e.shape[0]}));r.sort();var i=unique(t.map(function(e){return e.shape[0]}));if(i.sort(),r.length>1)throw new ValueError(\"All input Tensors (x) should have the same number of samples. Got array shapes: \"+JSON.stringify(e.map(function(e){return e.shape})));if(i.length>1)throw new ValueError(\"All target Tensors (y) should have the same number of samples. Got array shapes: \"+JSON.stringify(t.map(function(e){return e.shape})));if(r.length>0&&i.length>0&&!util.arraysEqual(r,i))throw new ValueError(\"Input Tensors should have the same number of samples as target Tensors. Found \"+r[0]+\" input sample(s) and \"+i[0]+\" target sample(s).\")}function checkLossAndTargetCompatibility(e,t,n){for(var r=[meanSquaredError,binaryCrossentropy,categoricalCrossentropy],i=0;i=e&&(i=e),n.push([r,i]),r=i;return n}function sliceArrays(e,t,n){return null==e?[null]:Array.isArray(e)?e.map(function(e){return sliceAlongFirstAxis(e,t,n-t)}):sliceAlongFirstAxis(e,t,n-t)}function sliceArraysByIndices(e,t){return tidy(function(){return null==e?null:Array.isArray(e)?e.map(function(e){return sliceArraysByIndices(e,t)}):gather$1(e,\"int32\"===t.dtype?t:t.toInt())})}function checkInputData(e,t,n,r,i){var a;if(void 0===r&&(r=!0),void 0===i&&(i=\"\"),Array.isArray(e)){if(e.length!==t.length)throw new ValueError(\"Error when checking model \"+i+\": the Array of Tensors that you are passing to your model is not the size the the model expected. Expected to see \"+t.length+\" Tensor(s), but instead got \"+e.length+\" Tensors(s).\");a=e}else{if(t.length>1)throw new ValueError(\"The model expects \"+t.length+\" \"+i+\" Tensors, but only received one Tensor. Found: array with shape \"+JSON.stringify(e.shape)+\".\");a=[e]}if(null!=n)for(var o=0;o1&&(t.metricsTensors.push([n,e]),t.metricsNames.push(t.outputNames[e]+\"_loss\"))}});var p=collectMetrics(e.metrics,this.outputNames);nameScope(\"metric\",function(){for(var e=function(e){if(-1!==c.indexOf(e))return\"continue\";!function(n){for(var r,i,a,o=function(n){if(-1!==[\"accuracy\",\"acc\",\"crossentropy\",\"ce\"].indexOf(n)){var o=t.internalOutputShapes[e];1===o[o.length-1]||t.lossFunctions[e]===binaryCrossentropy?-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=binaryAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=binaryCrossentropy$1):t.lossFunctions[e]===sparseCategoricalCrossentropy?-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=sparseCategoricalAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=sparseCategoricalCrossentropy$1):-1!==[\"accuracy\",\"acc\"].indexOf(n)?i=categoricalAccuracy:-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(i=categoricalCrossentropy$1);var s=void 0;-1!==[\"accuracy\",\"acc\"].indexOf(n)?s=\"acc\":-1!==[\"crossentropy\",\"ce\"].indexOf(n)&&(s=\"ce\"),a=i,r=\"\"+s}else{var l=get$1(n);a=l,r=\"\"+n}var u;nameScope(r,function(){u=a}),function(e,n,r){t.outputNames.length>1&&(n=t.outputNames[e]+\"_\"+n),t.metricsNames.push(n),t.metricsTensors.push([r,e])}(e,r,u)},s=0,l=n;s0){var c=[];throw t.forEach(function(t,n){null==t&&c.push(e[n])}),new ValueError(\"Cannot find SymbolicTensors for output name(s): \"+JSON.stringify(c))}return t},t.prototype.predictLoop=function(e,t,n){var r=this;return void 0===t&&(t=32),void 0===n&&(n=!1),tidy(function(){var i=r.checkNumSamples(e);if(n)throw new NotImplementedError(\"Verbose predictLoop() is not implemented yet.\");for(var a=makeBatches(i,t),o=[],s=function(t){var n=tidy(function(){var n=a[t][0],i=a[t][1],o=sliceArrays(e,n,i),s=[];if(Array.isArray(o))for(var l=0;l0&&e[0].shape[0]%r!=0)throw new ValueError(\"In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size \"+r+\". Found: \"+e[0].shape[0]+\" sample(s).\");return[e,t,null]},t.prototype.fitLoop=function(e,t,n,r,i,a,o,s,l,u,c,p,h,d){return __awaiter(this,void 0,void 0,function(){var g,f,m,y,v,b,z,w=this;return __generator(this,function(S){switch(S.label){case 0:if(null==r&&(r=32),null==i&&(i=1),null==u&&(u=!0),null==p&&(p=0),g=!1,null!=s&&null!=l&&(g=!0),null!=d&&(g=!0,null==h))throw new ValueError(\"Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.\");if(null!=(f=this.checkNumSamples(t,r,h,\"steps_per_epoch\"))&&(m=range(0,f)),this.history=new History,o=(o=null==o?[new BaseLogger]:[new BaseLogger].concat(o)).concat([this.history]),a>0)throw new NotImplementedError(\"Verbose mode is not implemented yet.\");return(y=new CallbackList(o)).setModel(this),y.setParams({epochs:i,initialEpoch:p,steps:h,verbose:a,doValidation:g,metrics:c}),[4,y.onTrainBegin()];case 1:S.sent(),this.stopTraining=!1,v=function(i){var a,o,c,p,d;return __generator(this,function(v){switch(v.label){case 0:return[4,y.onEpochBegin(i)];case 1:if(v.sent(),a={},null==h)return[3,2];throw new NotImplementedError(\"stepsPerEpoch mode is not implemented yet.\");case 2:if(\"batch\"===u)throw new NotImplementedError(\"batch shuffling is not implemneted yet\");u&&util.shuffle(m),o=tensor1d(m),c=makeBatches(f,r),p=function(i){var u;return __generator(this,function(p){switch(p.label){case 0:return u={},[4,y.onBatchBegin(i,u)];case 1:return p.sent(),tidy(function(){var p=c[i][0],h=c[i][1],d=sliceAlongFirstAxis(o,p,h-p);u.batch=i,u.size=h-p;for(var f=sliceArraysByIndices(t,d),m=e(f),y=0;y1)i+=\"_\"+count(e.slice(0,n),r);t.push(i)}return t},t.prototype.makeTestFunction=function(){var e=this;this.testFunction=function(t){return tidy(function(){for(var n,r=[],i=t.slice(0,e.inputs.length),a=t.slice(e.inputs.length,e.inputs.length+e.outputs.length),o=[],s=0;s0){if(s=!0,2!==n.validationData.length)throw 3===n.validationData.length?new NotImplementedError(\"validationData including sample weights is not supported yet.\"):new ValueError(\"When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; \"+n.validationData+\" is invalid.\");l=n.validationData[0],u=n.validationData[1],h=this.standardizeUserData(l,u,!0,r),l=h[0],u=h[1],c=l.concat(u)}else null!=n.validationSplit&&n.validationSplit>0&&n.validationSplit<1?(s=!0,d=Math.floor(a[0].shape[0]*(1-n.validationSplit)),g=a[0].shape[0],l=sliceArrays(a,d,g),a=sliceArrays(a,0,d),u=sliceArrays(o,d,g),o=sliceArrays(o,0,d),p=!0,c=l.concat(u)):null!=n.validationSteps&&(s=!0);return f=a.concat(o),this.checkTrainableWeightsConsistency(),m=function(e){var t=e.slice(0,S.inputs.length),n=e.slice(S.inputs.length,S.inputs.length+S.outputs.length),r=[],i=S.collectedTrainableWeights.map(function(e){return e.read()});return[S.optimizer.minimize(function(){for(var e=[],i=0;i1)throw new ValueError(\"Found more than one (\"+n.length+\") save handlers for URL '\"+e+\"'\");e=n[0]}if(null==e.save)throw new ValueError(\"Model.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.\");return[4,io.encodeWeights(this.getNamedWeights(t))];case 1:return r=s.sent(),i=!1,a=null,o=this.toJSON(a,i),[2,e.save({modelTopology:o,weightData:r.data,weightSpecs:r.specs})]}})})},t.className=\"Model\",t}(Container);function loadModelInternal(e){return __awaiter(this,void 0,void 0,function(){var t;return __generator(this,function(n){if(\"string\"==typeof e){if(0===(t=io.getLoadHandlers(e)).length)t.push(io.browserHTTPRequest(e));else if(t.length>1)throw new ValueError(\"Found more than one (\"+t.length+\") load handlers for URL '\"+e+\"'\");e=t[0]}return[2,loadModelFromIOHandler(e)]})})}function loadModelFromIOHandler(e,t){return __awaiter(this,void 0,void 0,function(){var n,r,i,a,o;return __generator(this,function(s){switch(s.label){case 0:if(null==e.load)throw new ValueError(\"Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.\");return[4,e.load()];case 1:if(n=s.sent(),null!=(r=n.modelTopology).model_config&&(r=r.model_config),i=deserialize(convertPythonicToTs(r),t),null!=n.weightData){if(null==n.weightSpecs)throw new ValueError(\"Model artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.\");a=!1,o=!0,i.loadWeights(io.decodeWeights(n.weightData,n.weightSpecs),a,o)}return[2,i]}})})}serialization.SerializationMap.register(Model);var Sequential=function(e){function t(t){var n=e.call(this,{inputs:[],outputs:[]})||this;if(t=t||{},n.trainable=!0,n._updatable=!0,n.built=!1,n.name=null!=t.name?t.name:getUid(\"sequential_\"),null!=t.layers)for(var r=0,i=t.layers;r 0 but got \"+JSON.stringify(e.filters))},t}(BaseConv),Conv2D=function(e){function t(n){var r=e.call(this,2,n)||this;return t.verifyConfig(n),r}return __extends(t,e),t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.rank,t},t.verifyConfig=function(e){if(\"number\"!=typeof e.kernelSize&&!checkArrayTypeAndLength(e.kernelSize,\"number\",1,2))throw new ValueError(\"Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received \"+JSON.stringify(e.kernelSize)+\".\")},t.className=\"Conv2D\",t}(Conv);serialization.SerializationMap.register(Conv2D);var Conv2DTranspose=function(e){function t(t){var n=e.call(this,t)||this;if(n.inputSpec=[new InputSpec({ndim:4})],\"same\"!==n.padding&&\"valid\"!==n.padding)throw new ValueError(\"Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode \"+n.padding);return n}return __extends(t,e),t.prototype.build=function(e){if(4!==(e=getExactlyOneShape(e)).length)throw new ValueError(\"Input should have rank 4; Received input shape: \"+JSON.stringify(e));var t=\"channelsFirst\"===this.dataFormat?1:e.length-1;if(null==e[t])throw new ValueError(\"The channel dimension of the inputs should be defined. Found `None`.\");var n,r=e[t],i=this.kernelSize.concat([this.filters,r]);this.kernel=this.addWeight(\"kernel\",i,\"float32\",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight(\"bias\",[this.filters],\"float32\",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new InputSpec({ndim:4,axes:(n={},n[t]=r,n)})],this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);if(4!==t.shape.length)throw new ValueError(\"Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-\"+t.shape.length);var r,i,a=t.shape,o=a[0];\"channelsFirst\"===n.dataFormat?(r=2,i=3):(r=1,i=2);var s=a[r],l=a[i],u=n.kernelSize[0],c=n.kernelSize[1],p=n.strides[0],h=n.strides[1],d=[o,deconvLength(s,p,u,n.padding),deconvLength(l,h,c,n.padding),n.filters];\"channelsLast\"!==n.dataFormat&&(t=transpose(t,[0,2,3,1]));var g=conv2dTranspose(t,n.kernel.read(),d,n.strides,n.padding);return\"channelsLast\"!==n.dataFormat&&(g=transpose(g,[0,3,1,2])),null!=n.bias&&(g=biasAdd(g,n.bias.read(),n.dataFormat)),null!=n.activation&&(g=n.activation.apply(g)),g})},t.prototype.computeOutputShape=function(e){var t,n,r,i=(e=getExactlyOneShape(e)).slice();\"channelsFirst\"===this.dataFormat?(t=1,n=2,r=3):(t=3,n=1,r=2);var a=this.kernelSize[0],o=this.kernelSize[1],s=this.strides[0],l=this.strides[1];return i[t]=this.filters,i[n]=deconvLength(i[n],s,a,this.padding),i[r]=deconvLength(i[r],l,o,this.padding),i},t.prototype.getConfig=function(){var t=e.prototype.getConfig.call(this);return delete t.dilationRate,t},t.className=\"Conv2DTranspose\",t}(Conv2D);serialization.SerializationMap.register(Conv2DTranspose);var SeparableConv=function(e){function t(t,n){var r=e.call(this,t,n)||this;if(r.DEFAULT_DEPTHWISE_INITIALIZER=\"glorotUniform\",r.DEFAULT_POINTWISE_INITIALIZER=\"glorotUniform\",r.depthwiseKernel=null,r.pointwiseKernel=null,null==n.filters)throw new ValueError(\"The `filters` configuration field is required by SeparableConv, but is unspecified.\");if(null!=n.kernelInitializer||null!=n.kernelRegularizer||null!=n.kernelConstraint)throw new ValueError(\"Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.\");if(null!=n.padding&&\"same\"!==n.padding&&\"valid\"!==n.padding)throw new ValueError(\"SeparableConv\"+r.rank+\"D supports only padding modes: 'same' and 'valid', but received \"+JSON.stringify(n.padding));return r.depthMultiplier=null==n.depthMultiplier?1:n.depthMultiplier,r.depthwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_DEPTHWISE_INITIALIZER),r.depthwiseRegularizer=getRegularizer(n.depthwiseRegularizer),r.depthwiseConstraint=getConstraint(n.depthwiseConstraint),r.pointwiseInitializer=getInitializer(n.depthwiseInitializer||r.DEFAULT_POINTWISE_INITIALIZER),r.pointwiseRegularizer=getRegularizer(n.pointwiseRegularizer),r.pointwiseConstraint=getConstraint(n.pointwiseConstraint),r}return __extends(t,e),t.prototype.build=function(e){if((e=getExactlyOneShape(e)).length1)throw new ValueError(\"Can not merge tensors with different batch sizes. Got tensors with shapes: \"+JSON.stringify(e)+\".\");for(var i=null==e[0]?null:e[0].slice(1),a=1;a1){var y=range(1,s).concat([0]);t.push(transpose(h,y)),u=!0}else t.push(h)}var v=n.mergeFunction(t),b=v.rank;if(u)if(null==b){var z=v.shape;f=[g=z[z.length-1]].concat(z.slice(0,z.length-1));v=transpose(v.reshape([-1,g]),[1,0]).reshape(f)}else if(b>1){y=[b-1].concat(range(0,b-1));v=transpose(v,y)}return v}return n.mergeFunction(e)})},t.prototype.computeOutputShape=function(e){var t;t=null==(e=e)[0]?null:e[0].slice(1);for(var n=1;n1)throw new ValueError(\"A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: \"+JSON.stringify(e))}},t.prototype.mergeFunction=function(e){var t=this;return tidy(function(){return concatenate(e,t.axis)})},t.prototype.computeOutputShape=function(e){if(!Array.isArray(e)||!Array.isArray(e[0]))throw new ValueError(\"A `Concatenate` layer should be called on a list of inputs.\");for(var t=e,n=t[0].slice(),r=this.axis<0?n.length+this.axis:this.axis,i=0,a=t.slice(1);i=0?this.axis:this.axis+e.length,n=e[t];if(null==n)throw new ValueError(\"Axis \"+t+\" of input tensor should have a defined dimension but the layer received an input with shape \"+JSON.stringify(e)+\".\");this.inputSpec=[new InputSpec({ndim:e.length,axes:(r={},r[t]=n,r)})];var r,i=[n];this.scale&&(this.gamma=this.addWeight(\"gamma\",i,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight(\"beta\",i,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight(\"moving_mean\",i,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight(\"moving_variance\",i,null,this.movingVarianceInitializer,null,!1),this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){var r=null!=t.training&&t.training,i=getExactlyOneTensor(e),a=i.shape,o=a.length,s=range(0,o),l=n.axis>=0?n.axis:n.axis+o;s.splice(l,1);var u=pyListRepeat(1,o);u[l]=a[l];var c=s.slice();c.sort();var p=!util.arraysEqual(c,range(0,o).slice(0,o-1));if(!r)return function(){if(p){var e=n.movingMean.read().reshape(u),t=n.movingVariance.read().reshape(u),r=n.center?n.beta.read().reshape(u):null,a=n.scale?n.gamma.read().reshape(u):null;return batchNormalization(i,e,t,r,a,n.epsilon)}return batchNormalization(i,n.movingMean.read(),n.movingVariance.read(),null==n.beta?null:n.beta.read(),null==n.gamma?null:n.gamma.read(),n.epsilon)}();var h=normalizeBatchInTraining(i,n.gamma.read(),n.beta.read(),s,n.epsilon),d=h[0],g=h[1],f=h[2],m=arrayProd(s.map(function(e){return i.shape[e]})),y=f.mul(getScalar(m/(m-(1+n.epsilon))));return function(){n.stepCount++;var e=movingAverage(n.movingMean.read(),g,n.momentum,n.stepCount);n.movingMean.write(e);var t=movingAverage(n.movingVariance.read(),y,n.momentum,n.stepCount);n.movingVariance.write(t)}(),d})},t.prototype.getConfig=function(){var t={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:serializeInitializer(this.betaInitializer),gammaInitializer:serializeInitializer(this.gammaInitializer),movingMeanInitializer:serializeInitializer(this.movingMeanInitializer),movingVarianceInitializer:serializeInitializer(this.movingVarianceInitializer),betaRegularizer:serializeRegularizer(this.betaRegularizer),gammaRegularizer:serializeRegularizer(this.gammaRegularizer),betaConstraint:serializeConstraint(this.betaConstraint),gammaConstraint:serializeConstraint(this.gammaConstraint)},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className=\"BatchNormalization\",t}(Layer);function spatial2dPadding(e,t,n){return tidy(function(){if(4!==e.rank)throw new ValueError(\"temporalPadding expects input tensor to be 4-D, but received a \"+e.rank+\"-D tensor.\");if(null==t&&(t=[[1,1],[1,1]]),2!==t.length||2!==t[0].length||2!==t[1].length)throw new ValueError(\"spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.\");if(null==n&&(n=imageDataFormat()),\"channelsLast\"!==n&&\"channelsFirst\"!==n)throw new ValueError(\"Unknown data format: \"+n+\". Supported data formats are 'channelsLast' and 'channelsFirst.\");var r;return r=\"channelsFirst\"===n?[[0,0],[0,0],t[0],t[1]]:[[0,0],t[0],t[1],[0,0]],pad(e,r)})}serialization.SerializationMap.register(BatchNormalization);var ZeroPadding2D=function(e){function t(t){var n=this;if(null==t&&(t={}),(n=e.call(this,t)||this).dataFormat=null==t.dataFormat?imageDataFormat():t.dataFormat,null==t.padding)n.padding=[[1,1],[1,1]];else if(\"number\"==typeof t.padding)n.padding=[[t.padding,t.padding],[t.padding,t.padding]];else{if(t.padding=t.padding,2!==t.padding.length)throw new ValueError(\"ZeroPadding2D expects padding to be a length-2 array, but received a length-\"+t.padding.length+\" array.\");var r=void 0,i=void 0;if(\"number\"==typeof t.padding[0])r=[t.padding[0],t.padding[0]],i=[t.padding[1],t.padding[1]];else{if(t.padding=t.padding,2!==t.padding[0].length)throw new ValueError(\"ZeroPadding2D expects height padding to be a length-2 array, but received a length-\"+t.padding[0].length+\" array.\");if(r=t.padding[0],2!==t.padding[1].length)throw new ValueError(\"ZeroPadding2D expects width padding to be a length-2 array, but received a length-\"+t.padding[1].length+\" array.\");i=t.padding[1]}n.padding=[r,i]}return n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t,n;return e=getExactlyOneShape(e),\"channelsFirst\"===this.dataFormat?(t=null!=e[2]&&e[2]>=0?e[2]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[3]&&e[3]>=0?e[3]+this.padding[1][0]+this.padding[1][1]:null,[e[0],e[1],t,n]):(t=null!=e[1]&&e[1]>=0?e[1]+this.padding[0][0]+this.padding[0][1]:null,n=null!=e[2]&&e[2]>=0?e[2]+this.padding[1][0]+this.padding[1][1]:null,[e[0],t,n,e[3]])},t.prototype.call=function(e,t){var n=this;return tidy(function(){return spatial2dPadding(getExactlyOneTensor(e),n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={padding:this.padding,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t.className=\"ZeroPadding2D\",t}(Layer);function pool2d(e,t,n,r,i,a){return tidy(function(){var o;checkDataFormat(i),checkPoolMode(a),checkPaddingMode(r),null==n&&(n=[1,1]),null==r&&(r=\"valid\"),null==i&&(i=imageDataFormat()),null==a&&(a=\"max\"),e=preprocessConv2DInput(e,i);var s=\"same\"===r?\"same\":\"valid\";return o=\"max\"===a?maxPool(e,t,n,s):avgPool(e,t,n,s),\"channelsFirst\"===i&&(o=transpose(o,[0,3,1,2])),o})}serialization.SerializationMap.register(ZeroPadding2D);var Pooling1D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=2),n=e.call(this,t)||this,\"number\"==typeof t.poolSize)n.poolSize=[t.poolSize];else{if(!Array.isArray(t.poolSize)||1!==t.poolSize.length||\"number\"!=typeof t.poolSize[0])throw new ValueError(\"poolSize for 1D convolutional layer must be a number or an Array of a single number, but received \"+JSON.stringify(t.poolSize));n.poolSize=t.poolSize}if(null==t.strides)n.strides=n.poolSize;else if(\"number\"==typeof t.strides)n.strides=[t.strides];else{if(!Array.isArray(t.strides)||1!==t.strides.length||\"number\"!=typeof t.strides[0])throw new ValueError(\"strides for 1D convolutional layer must be a number or an Array of a single number, but received \"+JSON.stringify(t.strides));n.strides=t.strides}return n.padding=null==t.padding?\"valid\":t.padding,checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){var t=convOutputLength((e=getExactlyOneShape(e))[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){n.invokeCallHook(e,t),e=expandDims(getExactlyOneTensor(e),2);var r=n.poolingFunction(getExactlyOneTensor(e),[n.poolSize[0],1],[n.strides[0],1],n.padding,\"channelsLast\");return squeeze(r,[2])})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"max\")},t.className=\"MaxPooling1D\",t}(Pooling1D);serialization.SerializationMap.register(MaxPooling1D);var AveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"avg\")},t.className=\"AveragePooling1D\",t}(Pooling1D);serialization.SerializationMap.register(AveragePooling1D);var Pooling2D=function(e){function t(t){var n=this;if(null==t.poolSize&&(t.poolSize=[2,2]),(n=e.call(this,t)||this).poolSize=Array.isArray(t.poolSize)?t.poolSize:[t.poolSize,t.poolSize],null==t.strides)n.strides=n.poolSize;else if(Array.isArray(t.strides)){if(2!==t.strides.length)throw new ValueError(\"If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length \"+t.strides.length+\".\");n.strides=t.strides}else n.strides=[t.strides,t.strides];return n.padding=null==t.padding?\"valid\":t.padding,n.dataFormat=null==t.dataFormat?\"channelsLast\":t.dataFormat,checkDataFormat(n.dataFormat),checkPaddingMode(n.padding),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){e=getExactlyOneShape(e);var t=\"channelsFirst\"===this.dataFormat?e[2]:e[1],n=\"channelsFirst\"===this.dataFormat?e[3]:e[2];return t=convOutputLength(t,this.poolSize[0],this.padding,this.strides[0]),n=convOutputLength(n,this.poolSize[1],this.padding,this.strides[1]),\"channelsFirst\"===this.dataFormat?[e[0],e[1],t,n]:[e[0],t,n,e[3]]},t.prototype.call=function(e,t){var n=this;return tidy(function(){return n.invokeCallHook(e,t),n.poolingFunction(getExactlyOneTensor(e),n.poolSize,n.strides,n.padding,n.dataFormat)})},t.prototype.getConfig=function(){var t={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),MaxPooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"max\")},t.className=\"MaxPooling2D\",t}(Pooling2D);serialization.SerializationMap.register(MaxPooling2D);var AveragePooling2D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.poolingFunction=function(e,t,n,r,i){return checkDataFormat(i),checkPaddingMode(r),pool2d(e,t,n,r,i,\"avg\")},t.className=\"AveragePooling2D\",t}(Pooling2D);serialization.SerializationMap.register(AveragePooling2D);var GlobalPooling1D=function(e){function t(t){var n=e.call(this,t)||this;return n.inputSpec=[new InputSpec({ndim:3})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return[e[0],e[2]]},t.prototype.call=function(e,t){throw new NotImplementedError},t}(Layer),GlobalAveragePooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return mean(t,1)})},t.className=\"GlobalAveragePooling1D\",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalAveragePooling1D);var GlobalMaxPooling1D=function(e){function t(t){return e.call(this,t)||this}return __extends(t,e),t.prototype.call=function(e,t){return tidy(function(){var t=getExactlyOneTensor(e);return max(t,1)})},t.className=\"GlobalMaxPooling1D\",t}(GlobalPooling1D);serialization.SerializationMap.register(GlobalMaxPooling1D);var GlobalPooling2D=function(e){function t(t){var n=e.call(this,t)||this;return n.dataFormat=null==t.dataFormat?\"channelsLast\":t.dataFormat,checkDataFormat(n.dataFormat),n.inputSpec=[new InputSpec({ndim:4})],n}return __extends(t,e),t.prototype.computeOutputShape=function(e){return e=e,\"channelsLast\"===this.dataFormat?[e[0],e[3]]:[e[0],e[1]]},t.prototype.call=function(e,t){throw new NotImplementedError},t.prototype.getConfig=function(){var t={dataFormat:this.dataFormat},n=e.prototype.getConfig.call(this);return Object.assign(t,n),t},t}(Layer),GlobalAveragePooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return\"channelsLast\"===n.dataFormat?mean(t,[1,2]):mean(t,[2,3])})},t.className=\"GlobalAveragePooling2D\",t}(GlobalPooling2D);serialization.SerializationMap.register(GlobalAveragePooling2D);var GlobalMaxPooling2D=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t.prototype.call=function(e,t){var n=this;return tidy(function(){var t=getExactlyOneTensor(e);return\"channelsLast\"===n.dataFormat?max(t,[1,2]):max(t,[2,3])})},t.className=\"GlobalMaxPooling2D\",t}(GlobalPooling2D);function standardizeArgs(e,t,n,r){if(Array.isArray(e)){if(null!=t||null!=n)throw new ValueError(\"When inputs is an array, neither initialState or constants should be provided\");null!=r&&(n=e.slice(e.length-r,e.length),e=e.slice(0,e.length-r)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function i(e){return null==e||Array.isArray(e)?e:[e]}return{inputs:e,initialState:t=i(t),constants:n=i(n)}}function rnn(e,t,n,r,i,a,o,s){void 0===r&&(r=!1),void 0===o&&(o=!1);var l=t.shape.length;if(l<3)throw new ValueError(\"Input should be at least 3D, but is \"+l+\"D.\");var u,c,p=[1,0].concat(range(2,l));if(t=transpose(t,p),null!=i)throw new NotImplementedError(\"The rnn() function of the deeplearn.js backend does not support masking yet.\");if(null!=a)throw new NotImplementedError(\"The rnn() functoin of the deeplearn.js backend does not support constants yet.\");o&&console.warn(\"Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend.\"),r&&(t=reverse(t,0));for(var h=n,d=t.shape[0],g=0;g1?tile$1(n,[1,e]):n}):t.cell.stateSize>1?[tile$1(n,[1,t.cell.stateSize])]:[n]})},Object.defineProperty(t.prototype,\"trainableWeights\",{get:function(){return this.trainable?this.cell.trainableWeights:[]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,\"nonTrainableWeights\",{get:function(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights},enumerable:!0,configurable:!0}),t.prototype.getConfig=function(){var t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};null!=this.numConstants&&(t.numConstants=this.numConstants);var n=this.cell.getConfig();t.cell={className:this.cell.getClassName(),config:n};var r=e.prototype.getConfig.call(this);return Object.assign(t,r),t},t.className=\"RNN\",t}(Layer);serialization.SerializationMap.register(RNN);var RNNCell=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return __extends(t,e),t}(Layer),SimpleRNNCell=function(e){function t(t){var n=e.call(this,t)||this;return n.DEFAULT_ACTIVATION=\"tanh\",n.DEFAULT_KERNEL_INITIALIZER=\"glorotNormal\",n.DEFAULT_RECURRENT_INITIALIZER=\"orthogonal\",n.DEFAULT_BIAS_INITIALIZER=\"zeros\",n.units=t.units,n.activation=getActivation(null==t.activation?n.DEFAULT_ACTIVATION:t.activation),n.useBias=null==t.useBias||t.useBias,n.kernelInitializer=getInitializer(t.kernelInitializer||n.DEFAULT_KERNEL_INITIALIZER),n.recurrentInitializer=getInitializer(t.recurrentInitializer||n.DEFAULT_RECURRENT_INITIALIZER),n.biasInitializer=getInitializer(t.biasInitializer||n.DEFAULT_BIAS_INITIALIZER),n.kernelRegularizer=getRegularizer(t.kernelRegularizer),n.recurrentRegularizer=getRegularizer(t.recurrentRegularizer),n.biasRegularizer=getRegularizer(t.biasRegularizer),n.kernelConstraint=getConstraint(t.kernelConstraint),n.recurrentConstraint=getConstraint(t.recurrentConstraint),n.biasConstraint=getConstraint(t.biasConstraint),n.dropout=min$1([1,max$1([0,null==t.dropout?0:t.dropout])]),n.recurrentDropout=min$1([1,max$1([0,null==t.recurrentDropout?0:t.recurrentDropout])]),n.stateSize=n.units,n.dropoutMask=null,n.recurrentDropoutMask=null,n}return __extends(t,e),t.prototype.build=function(e){e=getExactlyOneShape(e),this.kernel=this.addWeight(\"kernel\",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight(\"recurrent_kernel\",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight(\"bias\",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0},t.prototype.call=function(e,t){var n=this;return tidy(function(){if(2!==(e=e).length)throw new ValueError(\"SimpleRNNCell expects 2 input Tensors, got \"+e.length+\".\");var r=e[1];e=e[0];var i,a=null!=t.training&&t.training;01){for(var a=[],o=0;o= 3D, but received input shape \"+JSON.stringify(t));this.inputSpec=[{shape:t}];var n=[t[0]].concat(t.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),e.prototype.build.call(this,t)},t.prototype.computeOutputShape=function(e){var t=[(e=getExactlyOneShape(e))[0]].concat(e.slice(2)),n=this.layer.computeOutputShape(t),r=e[1];return[n[0],r].concat(n.slice(1))},t.prototype.call=function(e,t){var n=this;return tidy(function(){return rnn(function(e,r){return[n.layer.call(e,t),[]]},e=getExactlyOneTensor(e),[],!1,null,null,!1,e.shape[1])[1]})},t.className=\"TimeDistributed\",t}(Wrapper);serialization.SerializationMap.register(TimeDistributed);var VALID_BIDIRECTIONAL_MERGE_MODES=[\"sum\",\"mul\",\"concat\",\"ave\"];function checkBidirectionalMergeMode(e){checkStringTypeUnionValue(VALID_BIDIRECTIONAL_MERGE_MODES,\"BidirectionalMergeMode\",e)}var Bidirectional=function(e){function t(t){var n=e.call(this,t)||this,r=t.layer.getConfig();if(n.forwardLayer=deserialize({className:t.layer.getClassName(),config:r}),r.goBackwards=!0!==r.goBackwards,n.backwardLayer=deserialize({className:t.layer.getClassName(),config:r}),n.forwardLayer.name=\"forward_\"+n.forwardLayer.name,n.backwardLayer.name=\"backward_\"+n.backwardLayer.name,checkBidirectionalMergeMode(t.mergeMode),n.mergeMode=t.mergeMode,t.weights)throw new NotImplementedError(\"weights support is not implemented for Bidirectional layer yet.\");return n._stateful=t.layer.stateful,n.returnSequences=t.layer.returnSequences,n.returnState=t.layer.returnState,n.supportsMasking=!0,n._trainable=!0,n.inputSpec=t.layer.inputSpec,n.numConstants=null,n}return __extends(t,e),Object.defineProperty(t.prototype,\"trainable\",{get:function(){return this._trainable},set:function(e){this._trainable=e,null!=this.forwardLayer&&(this.forwardLayer.trainable=e),null!=this.backwardLayer&&(this.backwardLayer.trainable=e)},enumerable:!0,configurable:!0}),t.prototype.getWeights=function(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())},t.prototype.setWeights=function(e){var t=e.length,n=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,n)),this.backwardLayer.setWeights(e.slice(n))},t.prototype.computeOutputShape=function(e){var t,n,r,i=this.forwardLayer.computeOutputShape(e);return Array.isArray(i)&&Array.isArray(i[0])||(i=[i]),i=i,this.returnState?(r=i.slice(1),t=i[0]):t=i[0],t=t,\"concat\"===this.mergeMode?(t[t.length-1]*=2,n=[t]):n=null==this.mergeMode?[t,t.slice()]:[t],this.returnState?null==this.mergeMode?n.concat(r).concat(r.slice()):[t].concat(r).concat(r.slice()):singletonOrArray(n)},t.prototype.apply=function(t,n){var r=null==n?null:n.initialState,i=null==n?null:n.constants;null==n&&(n={});var a=standardizeArgs(t,r,i,this.numConstants);if(t=a.inputs,r=a.initialState,i=a.constants,Array.isArray(t)&&(r=t.slice(1),t=t[0]),(null==r||0===r.length)&&null==i)return e.prototype.apply.call(this,t,n);var o=[],s=[];if(null!=r){var l=r.length;if(l%2>0)throw new ValueError(\"When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.\");n.initialState=r,o.push.apply(o,r);var u=r.map(function(e){return new InputSpec({shape:e.shape})});this.forwardLayer.stateSpec=u.slice(0,l/2),this.backwardLayer.stateSpec=u.slice(l/2),s.push.apply(s,u)}if(null!=i)throw new NotImplementedError(\"Support for constants in Bidirectional layers is not implemented yet.\");for(var c=o[0]instanceof SymbolicTensor,p=0,h=o;p0&&n[n.length-1])&&(6===o[0]||2===o[0])){s=0;continue}if(3===o[0]&&(!n||o[1]>n[0]&&o[1]= 0x80 (not a basic code point)\",\"invalid-input\":\"Invalid input\"},x=u-m,v=Math.floor,I=String.fromCharCode;function O(e){throw RangeError(b[e])}function w(e,t){for(var a=e.length,r=[];a--;)r[a]=t(e[a]);return r}function V(e,t){var a=e.split(\"@\"),r=\"\";return a.length>1&&(r=a[0]+\"@\",e=a[1]),r+w((e=e.replace(P,\".\")).split(\".\"),t).join(\".\")}function T(e){for(var t,a,r=[],n=0,o=e.length;n=55296&&t<=56319&&n65535&&(t+=I((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+=I(e)}).join(\"\")}function $(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function _(e,t,a){var r=0;for(e=a?v(e/c):e>>1,e+=v(e/t);e>x*l>>1;r+=u)e=v(e/x);return v(r+(x+1)*e/(e+d))}function A(e){var t,a,r,n,o,s,i,d,c,g,N,P=[],b=e.length,x=0,I=h,w=f;for((a=e.lastIndexOf(y))<0&&(a=0),r=0;r=128&&O(\"not-basic\"),P.push(e.charCodeAt(r));for(n=a>0?a+1:0;n=b&&O(\"invalid-input\"),((d=(N=e.charCodeAt(n++))-48<10?N-22:N-65<26?N-65:N-97<26?N-97:u)>=u||d>v((p-x)/s))&&O(\"overflow\"),x+=d*s,!(d<(c=i<=w?m:i>=w+l?l:i-w));i+=u)s>v(p/(g=u-c))&&O(\"overflow\"),s*=g;w=_(x-o,t=P.length+1,0==o),v(x/t)>p-I&&O(\"overflow\"),I+=v(x/t),x%=t,P.splice(x++,0,I)}return k(P)}function S(e){var t,a,r,n,o,s,i,d,c,g,N,P,b,x,w,V=[];for(P=(e=T(e)).length,t=h,a=0,o=f,s=0;s=t&&Nv((p-a)/(b=r+1))&&O(\"overflow\"),a+=(i-t)*b,t=i,s=0;sp&&O(\"overflow\"),N==t){for(d=a,c=u;!(d<(g=c<=o?m:c>=o+l?l:c-o));c+=u)w=d-g,x=u-g,V.push(I($(g+w%x,0))),d=v(w/x);V.push(I($(d,0))),o=_(a,b,r==n),a=0,++r}++a,++t}return V.join(\"\")}if(s={version:\"1.3.2\",ucs2:{decode:T,encode:k},decode:A,encode:S,toASCII:function(e){return V(e,function(e){return N.test(e)?\"xn--\"+S(e):e})},toUnicode:function(e){return V(e,function(e){return g.test(e)?A(e.slice(4).toLowerCase()):e})}},r&&n)if(e.exports==r)n.exports=s;else for(i in s)s.hasOwnProperty(i)&&(r[i]=s[i]);else a.punycode=s}(commonjsGlobal)}),util$1={isString:function(e){return\"string\"==typeof e},isObject:function(e){return\"object\"==typeof e&&null!==e},isNull:function(e){return null===e},isNullOrUndefined:function(e){return null==e}};function hasOwnProperty(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var decode=function(e,t,a,r){t=t||\"&\",a=a||\"=\";var n={};if(\"string\"!=typeof e||0===e.length)return n;var o=/\\+/g;e=e.split(t);var s=1e3;r&&\"number\"==typeof r.maxKeys&&(s=r.maxKeys);var i=e.length;s>0&&i>s&&(i=s);for(var p=0;p=0?(u=c.substr(0,f),m=c.substr(f+1)):(u=c,m=\"\"),l=decodeURIComponent(u),d=decodeURIComponent(m),hasOwnProperty(n,l)?Array.isArray(n[l])?n[l].push(d):n[l]=[n[l],d]:n[l]=d}return n},stringifyPrimitive=function(e){switch(typeof e){case\"string\":return e;case\"boolean\":return e?\"true\":\"false\";case\"number\":return isFinite(e)?e:\"\";default:return\"\"}},encode=function(e,t,a,r){return t=t||\"&\",a=a||\"=\",null===e&&(e=void 0),\"object\"==typeof e?Object.keys(e).map(function(r){var n=encodeURIComponent(stringifyPrimitive(r))+a;return Array.isArray(e[r])?e[r].map(function(e){return n+encodeURIComponent(stringifyPrimitive(e))}).join(t):n+encodeURIComponent(stringifyPrimitive(e[r]))}).join(t):r?encodeURIComponent(stringifyPrimitive(r))+a+encodeURIComponent(stringifyPrimitive(e)):\"\"},querystring=createCommonjsModule(function(e,t){t.decode=t.parse=decode,t.encode=t.stringify=encode}),querystring_1=querystring.decode,querystring_2=querystring.parse,querystring_3=querystring.encode,querystring_4=querystring.stringify,parse=urlParse,format=urlFormat;function Url(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}var protocolPattern=/^([a-z0-9.+-]+:)/i,portPattern=/:[0-9]*$/,simplePathPattern=/^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/,delims=[\"<\",\">\",'\"',\"`\",\" \",\"\\r\",\"\\n\",\"\\t\"],unwise=[\"{\",\"}\",\"|\",\"\\\\\",\"^\",\"`\"].concat(delims),autoEscape=[\"'\"].concat(unwise),nonHostChars=[\"%\",\"/\",\"?\",\";\",\"#\"].concat(autoEscape),hostEndingChars=[\"/\",\"?\",\"#\"],hostnameMaxLen=255,hostnamePartPattern=/^[+a-z0-9A-Z_-]{0,63}$/,hostnamePartStart=/^([+a-z0-9A-Z_-]{0,63})(.*)$/,unsafeProtocol={javascript:!0,\"javascript:\":!0},hostlessProtocol={javascript:!0,\"javascript:\":!0},slashedProtocol={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,\"http:\":!0,\"https:\":!0,\"ftp:\":!0,\"gopher:\":!0,\"file:\":!0};function urlParse(e,t,a){if(e&&util$1.isObject(e)&&e instanceof Url)return e;var r=new Url;return r.parse(e,t,a),r}function urlFormat(e){return util$1.isString(e)&&(e=urlParse(e)),e instanceof Url?e.format():Url.prototype.format.call(e)}Url.prototype.parse=function(e,t,a){if(!util$1.isString(e))throw new TypeError(\"Parameter 'url' must be a string, not \"+typeof e);var r=e.indexOf(\"?\"),n=-1!==r&&r127?b+=\"x\":b+=P[x];if(!b.match(hostnamePartPattern)){var I=g.slice(0,f),O=g.slice(f+1),w=P.match(hostnamePartStart);w&&(I.push(w[1]),O.unshift(w[2])),O.length&&(s=\"/\"+O.join(\".\")+s),this.hostname=I.join(\".\");break}}}this.hostname.length>hostnameMaxLen?this.hostname=\"\":this.hostname=this.hostname.toLowerCase(),y||(this.hostname=punycode.toASCII(this.hostname));var V=this.port?\":\"+this.port:\"\",T=this.hostname||\"\";this.host=T+V,this.href+=this.host,y&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),\"/\"!==s[0]&&(s=\"/\"+s))}if(!unsafeProtocol[u])for(f=0,N=autoEscape.length;f0)&&a.host.split(\"@\"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift());return a.search=e.search,a.query=e.query,util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:\"\")+(a.search?a.search:\"\")),a.href=a.format(),a}if(!P.length)return a.pathname=null,a.search?a.path=\"/\"+a.search:a.path=null,a.href=a.format(),a;for(var x=P.slice(-1)[0],v=(a.host||e.host||P.length>1)&&(\".\"===x||\"..\"===x)||\"\"===x,I=0,O=P.length;O>=0;O--)\".\"===(x=P[O])?P.splice(O,1):\"..\"===x?(P.splice(O,1),I++):I&&(P.splice(O,1),I--);if(!g&&!N)for(;I--;I)P.unshift(\"..\");!g||\"\"===P[0]||P[0]&&\"/\"===P[0].charAt(0)||P.unshift(\"\"),v&&\"/\"!==P.join(\"/\").substr(-1)&&P.push(\"\");var w,V=\"\"===P[0]||P[0]&&\"/\"===P[0].charAt(0);b&&(a.hostname=a.host=V?\"\":P.length?P.shift():\"\",(w=!!(a.host&&a.host.indexOf(\"@\")>0)&&a.host.split(\"@\"))&&(a.auth=w.shift(),a.host=a.hostname=w.shift()));return(g=g||a.host&&P.length)&&!V&&P.unshift(\"\"),P.length?a.pathname=P.join(\"/\"):(a.pathname=null,a.path=null),util$1.isNull(a.pathname)&&util$1.isNull(a.search)||(a.path=(a.pathname?a.pathname:\"\")+(a.search?a.search:\"\")),a.auth=e.auth||a.auth,a.slashes=a.slashes||e.slashes,a.href=a.format(),a},Url.prototype.parseHost=function(){var e=this.host,t=portPattern.exec(e);t&&(\":\"!==(t=t[0])&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)};var aspromise=asPromise;function asPromise(e,t){for(var a=new Array(arguments.length-1),r=0,n=2,o=!0;n1&&\"=\"===e.charAt(t);)++a;return Math.ceil(3*e.length)/4-a};for(var r=new Array(64),n=new Array(123),o=0;o<64;)n[r[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;a.encode=function(e,t,a){for(var n,o=null,s=[],i=0,p=0;t>2],n=(3&u)<<4,p=1;break;case 1:s[i++]=r[n|u>>4],n=(15&u)<<2,p=2;break;case 2:s[i++]=r[n|u>>6],s[i++]=r[63&u],p=0}i>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,s)),i=0)}return p&&(s[i++]=r[n],s[i++]=61,1===p&&(s[i++]=61)),o?(i&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join(\"\")):String.fromCharCode.apply(String,s.slice(0,i))};a.decode=function(e,t,a){for(var r,o=a,s=0,i=0;i1)break;if(void 0===(p=n[p]))throw Error(\"invalid encoding\");switch(s){case 0:r=p,s=1;break;case 1:t[a++]=r<<2|(48&p)>>4,r=p,s=2;break;case 2:t[a++]=(15&r)<<4|(60&p)>>2,r=p,s=3;break;case 3:t[a++]=(3&r)<<6|p,s=0}}if(1===s)throw Error(\"invalid encoding\");return a-o},a.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}}),eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(e,t,a){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:a||this}),this},EventEmitter.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var a=this._listeners[e],r=0;r0?0:2147483648,a,r);else if(isNaN(t))e(2143289344,a,r);else if(t>3.4028234663852886e38)e((n<<31|2139095040)>>>0,a,r);else if(t<1.1754943508222875e-38)e((n<<31|Math.round(t/1.401298464324817e-45))>>>0,a,r);else{var o=Math.floor(Math.log(t)/Math.LN2);e((n<<31|o+127<<23|8388607&Math.round(t*Math.pow(2,-o)*8388608))>>>0,a,r)}}function a(e,t,a){var r=e(t,a),n=2*(r>>31)+1,o=r>>>23&255,s=8388607&r;return 255===o?s?NaN:n*(1/0):0===o?1.401298464324817e-45*n*s:n*Math.pow(2,o-150)*(s+8388608)}e.writeFloatLE=t.bind(null,writeUintLE),e.writeFloatBE=t.bind(null,writeUintBE),e.readFloatLE=a.bind(null,readUintLE),e.readFloatBE=a.bind(null,readUintBE)}(),\"undefined\"!=typeof Float64Array?function(){var t=new Float64Array([-0]),a=new Uint8Array(t.buffer),r=128===a[7];function n(e,r,n){t[0]=e,r[n]=a[0],r[n+1]=a[1],r[n+2]=a[2],r[n+3]=a[3],r[n+4]=a[4],r[n+5]=a[5],r[n+6]=a[6],r[n+7]=a[7]}function o(e,r,n){t[0]=e,r[n]=a[7],r[n+1]=a[6],r[n+2]=a[5],r[n+3]=a[4],r[n+4]=a[3],r[n+5]=a[2],r[n+6]=a[1],r[n+7]=a[0]}function s(e,r){return a[0]=e[r],a[1]=e[r+1],a[2]=e[r+2],a[3]=e[r+3],a[4]=e[r+4],a[5]=e[r+5],a[6]=e[r+6],a[7]=e[r+7],t[0]}function i(e,r){return a[7]=e[r],a[6]=e[r+1],a[5]=e[r+2],a[4]=e[r+3],a[3]=e[r+4],a[2]=e[r+5],a[1]=e[r+6],a[0]=e[r+7],t[0]}e.writeDoubleLE=r?n:o,e.writeDoubleBE=r?o:n,e.readDoubleLE=r?s:i,e.readDoubleBE=r?i:s}():function(){function t(e,t,a,r,n,o){var s=r<0?1:0;if(s&&(r=-r),0===r)e(0,n,o+t),e(1/r>0?0:2147483648,n,o+a);else if(isNaN(r))e(0,n,o+t),e(2146959360,n,o+a);else if(r>1.7976931348623157e308)e(0,n,o+t),e((s<<31|2146435072)>>>0,n,o+a);else{var i;if(r<2.2250738585072014e-308)e((i=r/5e-324)>>>0,n,o+t),e((s<<31|i/4294967296)>>>0,n,o+a);else{var p=Math.floor(Math.log(r)/Math.LN2);1024===p&&(p=1023),e(4503599627370496*(i=r*Math.pow(2,-p))>>>0,n,o+t),e((s<<31|p+1023<<20|1048576*i&1048575)>>>0,n,o+a)}}}function a(e,t,a,r,n){var o=e(r,n+t),s=e(r,n+a),i=2*(s>>31)+1,p=s>>>20&2047,u=4294967296*(1048575&s)+o;return 2047===p?u?NaN:i*(1/0):0===p?5e-324*i*u:i*Math.pow(2,p-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,writeUintLE,0,4),e.writeDoubleBE=t.bind(null,writeUintBE,4,0),e.readDoubleLE=a.bind(null,readUintLE,0,4),e.readDoubleBE=a.bind(null,readUintBE,4,0)}(),e}function writeUintLE(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}function writeUintBE(e,t,a){t[a]=e>>>24,t[a+1]=e>>>16&255,t[a+2]=e>>>8&255,t[a+3]=255&e}function readUintLE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function readUintBE(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod$$1=eval(\"quire\".replace(/^/,\"re\"))(moduleName);if(mod$$1&&(mod$$1.length||Object.keys(mod$$1).length))return mod$$1}catch(e){}return null}var utf8_1=createCommonjsModule(function(e,t){var a=t;a.length=function(e){for(var t=0,a=0,r=0;r191&&r<224?o[s++]=(31&r)<<6|63&e[t++]:r>239&&r<365?(r=((7&r)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,o[s++]=55296+(r>>10),o[s++]=56320+(1023&r)):o[s++]=(15&r)<<12|(63&e[t++])<<6|63&e[t++],s>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,o)),s=0);return n?(s&&n.push(String.fromCharCode.apply(String,o.slice(0,s))),n.join(\"\")):String.fromCharCode.apply(String,o.slice(0,s))},a.write=function(e,t,a){for(var r,n,o=a,s=0;s>6|192,t[a++]=63&r|128):55296==(64512&r)&&56320==(64512&(n=e.charCodeAt(s+1)))?(r=65536+((1023&r)<<10)+(1023&n),++s,t[a++]=r>>18|240,t[a++]=r>>12&63|128,t[a++]=r>>6&63|128,t[a++]=63&r|128):(t[a++]=r>>12|224,t[a++]=r>>6&63|128,t[a++]=63&r|128);return a-o}}),pool_1=pool;function pool(e,t,a){var r=a||8192,n=r>>>1,o=null,s=r;return function(a){if(a<1||a>n)return e(a);s+a>r&&(o=e(r),s=0);var i=t.call(o,s,s+=a);return 7&s&&(s=1+(7|s)),i}}var longbits=LongBits;function LongBits(e,t){this.lo=e>>>0,this.hi=t>>>0}var zero=LongBits.zero=new LongBits(0,0);zero.toNumber=function(){return 0},zero.zzEncode=zero.zzDecode=function(){return this},zero.length=function(){return 1};var zeroHash=LongBits.zeroHash=\"\\0\\0\\0\\0\\0\\0\\0\\0\";LongBits.fromNumber=function(e){if(0===e)return zero;var t=e<0;t&&(e=-e);var a=e>>>0,r=(e-a)/4294967296>>>0;return t&&(r=~r>>>0,a=~a>>>0,++a>4294967295&&(a=0,++r>4294967295&&(r=0))),new LongBits(a,r)},LongBits.from=function(e){if(\"number\"==typeof e)return LongBits.fromNumber(e);if(minimal.isString(e)){if(!minimal.Long)return LongBits.fromNumber(parseInt(e,10));e=minimal.Long.fromString(e)}return e.low||e.high?new LongBits(e.low>>>0,e.high>>>0):zero},LongBits.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,a=~this.hi>>>0;return t||(a=a+1>>>0),-(t+4294967296*a)}return this.lo+4294967296*this.hi},LongBits.prototype.toLong=function(e){return minimal.Long?new minimal.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var charCodeAt=String.prototype.charCodeAt;LongBits.fromHash=function(e){return e===zeroHash?zero:new LongBits((charCodeAt.call(e,0)|charCodeAt.call(e,1)<<8|charCodeAt.call(e,2)<<16|charCodeAt.call(e,3)<<24)>>>0,(charCodeAt.call(e,4)|charCodeAt.call(e,5)<<8|charCodeAt.call(e,6)<<16|charCodeAt.call(e,7)<<24)>>>0)},LongBits.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},LongBits.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},LongBits.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},LongBits.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,a=this.hi>>>24;return 0===a?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:a<128?9:10};var minimal=createCommonjsModule(function(e,t){var a=t;function r(e,t,a){for(var r=Object.keys(t),n=0;n0)},a.Buffer=function(){try{var e=a.inquire(\"buffer\").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),a._Buffer_from=null,a._Buffer_allocUnsafe=null,a.newBuffer=function(e){return\"number\"==typeof e?a.Buffer?a._Buffer_allocUnsafe(e):new a.Array(e):a.Buffer?a._Buffer_from(e):\"undefined\"==typeof Uint8Array?e:new Uint8Array(e)},a.Array=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,a.Long=commonjsGlobal.dcodeIO&&commonjsGlobal.dcodeIO.Long||a.inquire(\"long\"),a.key2Re=/^true|false|0|1$/,a.key32Re=/^-?(?:0|[1-9][0-9]*)$/,a.key64Re=/^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,a.longToHash=function(e){return e?a.LongBits.from(e).toHash():a.LongBits.zeroHash},a.longFromHash=function(e,t){var r=a.LongBits.fromHash(e);return a.Long?a.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},a.merge=r,a.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},a.newError=n,a.ProtocolError=n(\"ProtocolError\"),a.oneOfGetter=function(e){for(var t={},a=0;a-1;--a)if(1===t[e[a]]&&void 0!==this[e[a]]&&null!==this[e[a]])return e[a]}},a.oneOfSetter=function(e){return function(t){for(var a=0;a127;)t[a++]=127&e|128,e>>>=7;t[a]=e}function VarintOp(e,t){this.len=e,this.next=void 0,this.val=t}function writeVarint64(e,t,a){for(;e.hi;)t[a++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[a++]=127&e.lo|128,e.lo=e.lo>>>7;t[a++]=e.lo}function writeFixed32(e,t,a){t[a]=255&e,t[a+1]=e>>>8&255,t[a+2]=e>>>16&255,t[a+3]=e>>>24}Writer.create=minimal.Buffer?function(){return(Writer.create=function(){return new BufferWriter})()}:function(){return new Writer},Writer.alloc=function(e){return new minimal.Array(e)},minimal.Array!==Array&&(Writer.alloc=minimal.pool(Writer.alloc,minimal.Array.prototype.subarray)),Writer.prototype._push=function(e,t,a){return this.tail=this.tail.next=new Op(e,t,a),this.len+=t,this},VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new VarintOp((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},Writer.prototype.int32=function(e){return e<0?this._push(writeVarint64,10,LongBits$1.fromNumber(e)):this.uint32(e)},Writer.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},Writer.prototype.uint64=function(e){var t=LongBits$1.from(e);return this._push(writeVarint64,t.length(),t)},Writer.prototype.int64=Writer.prototype.uint64,Writer.prototype.sint64=function(e){var t=LongBits$1.from(e).zzEncode();return this._push(writeVarint64,t.length(),t)},Writer.prototype.bool=function(e){return this._push(writeByte,1,e?1:0)},Writer.prototype.fixed32=function(e){return this._push(writeFixed32,4,e>>>0)},Writer.prototype.sfixed32=Writer.prototype.fixed32,Writer.prototype.fixed64=function(e){var t=LongBits$1.from(e);return this._push(writeFixed32,4,t.lo)._push(writeFixed32,4,t.hi)},Writer.prototype.sfixed64=Writer.prototype.fixed64,Writer.prototype.float=function(e){return this._push(minimal.float.writeFloatLE,4,e)},Writer.prototype.double=function(e){return this._push(minimal.float.writeDoubleLE,8,e)};var writeBytes=minimal.Array.prototype.set?function(e,t,a){t.set(e,a)}:function(e,t,a){for(var r=0;r>>0;if(!t)return this._push(writeByte,1,0);if(minimal.isString(e)){var a=Writer.alloc(t=base64.length(e));base64.decode(e,a,0),e=a}return this.uint32(t)._push(writeBytes,t,e)},Writer.prototype.string=function(e){var t=utf8.length(e);return t?this.uint32(t)._push(utf8.write,t,e):this._push(writeByte,1,0)},Writer.prototype.fork=function(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer.prototype.ldelim=function(){var e=this.head,t=this.tail,a=this.len;return this.reset().uint32(a),a&&(this.tail.next=e.next,this.tail=t,this.len+=a),this},Writer.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),a=0;e;)e.fn(e.val,t,a),a+=e.len,e=e.next;return t},Writer._configure=function(e){BufferWriter=e};var writer_buffer=BufferWriter$1;(BufferWriter$1.prototype=Object.create(writer.prototype)).constructor=BufferWriter$1;var Buffer=minimal.Buffer;function BufferWriter$1(){writer.call(this)}BufferWriter$1.alloc=function(e){return(BufferWriter$1.alloc=minimal._Buffer_allocUnsafe)(e)};var writeBytesBuffer=Buffer&&Buffer.prototype instanceof Uint8Array&&\"set\"===Buffer.prototype.set.name?function(e,t,a){t.set(e,a)}:function(e,t,a){if(e.copy)e.copy(t,a,0,e.length);else for(var r=0;r>>0;return this.uint32(t),t&&this._push(writeBytesBuffer,t,e),this},BufferWriter$1.prototype.string=function(e){var t=Buffer.byteLength(e);return this.uint32(t),t&&this._push(writeStringBuffer,t,e),this};var reader=Reader,BufferReader,LongBits$2=minimal.LongBits,utf8$1=minimal.utf8;function indexOutOfRange(e,t){return RangeError(\"index out of range: \"+e.pos+\" + \"+(t||1)+\" > \"+e.len)}function Reader(e){this.buf=e,this.pos=0,this.len=e.length}var create_array=\"undefined\"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new Reader(e);throw Error(\"illegal buffer\")}:function(e){if(Array.isArray(e))return new Reader(e);throw Error(\"illegal buffer\")};function readLongVarint(){var e=new LongBits$2(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error(\"invalid varint encoding\")}function readFixed32_end(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits$2(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader.create=minimal.Buffer?function(e){return(Reader.create=function(e){return minimal.Buffer.isBuffer(e)?new BufferReader(e):create_array(e)})(e)}:create_array,Reader.prototype._slice=minimal.Array.prototype.subarray||minimal.Array.prototype.slice,Reader.prototype.uint32=function(){var e=4294967295;return function(){if(e=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return e;if(e=(e|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return e;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return e}}(),Reader.prototype.int32=function(){return 0|this.uint32()},Reader.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},Reader.prototype.bool=function(){return 0!==this.uint32()},Reader.prototype.fixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.sfixed32=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return 0|readFixed32_end(this.buf,this.pos+=4)},Reader.prototype.float=function(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},Reader.prototype.double=function(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var e=minimal.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},Reader.prototype.bytes=function(){var e=this.uint32(),t=this.pos,a=this.pos+e;if(a>this.len)throw indexOutOfRange(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,a):t===a?new this.buf.constructor(0):this._slice.call(this.buf,t,a)},Reader.prototype.string=function(){var e=this.bytes();return utf8$1.read(e,0,e.length)},Reader.prototype.skip=function(e){if(\"number\"==typeof e){if(this.pos+e>this.len)throw indexOutOfRange(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw indexOutOfRange(this)}while(128&this.buf[this.pos++]);return this},Reader.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;;){if(4==(e=7&this.uint32()))break;this.skipType(e)}break;case 5:this.skip(4);break;default:throw Error(\"invalid wire type \"+e+\" at offset \"+this.pos)}return this},Reader._configure=function(e){BufferReader=e;var t=minimal.Long?\"toLong\":\"toNumber\";minimal.merge(Reader.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader$1;function BufferReader$1(e){reader.call(this,e)}(BufferReader$1.prototype=Object.create(reader.prototype)).constructor=BufferReader$1,minimal.Buffer&&(BufferReader$1.prototype._slice=minimal.Buffer.prototype.slice),BufferReader$1.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len))};var service=Service;function Service(e,t,a){if(\"function\"!=typeof e)throw TypeError(\"rpcImpl must be a function\");minimal.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(a)}(Service.prototype=Object.create(minimal.EventEmitter.prototype)).constructor=Service,Service.prototype.rpcCall=function e(t,a,r,n,o){if(!n)throw TypeError(\"request must be specified\");var s=this;if(!o)return minimal.asPromise(e,s,t,a,r,n);if(s.rpcImpl)try{return s.rpcImpl(t,a[s.requestDelimited?\"encodeDelimited\":\"encode\"](n).finish(),function(e,a){if(e)return s.emit(\"error\",e,t),o(e);if(null!==a){if(!(a instanceof r))try{a=r[s.responseDelimited?\"decodeDelimited\":\"decode\"](a)}catch(e){return s.emit(\"error\",e,t),o(e)}return s.emit(\"data\",a,t),o(null,a)}s.end(!0)})}catch(e){return s.emit(\"error\",e,t),void setTimeout(function(){o(e)},0)}else setTimeout(function(){o(Error(\"already ended\"))},0)},Service.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit(\"end\").off()),this};var rpc_1=createCommonjsModule(function(e,t){t.Service=service}),roots={},indexMinimal=createCommonjsModule(function(e,t){var a=t;function r(){a.Reader._configure(a.BufferReader),a.util._configure()}a.build=\"minimal\",a.Writer=writer,a.BufferWriter=writer_buffer,a.Reader=reader,a.BufferReader=reader_buffer,a.util=minimal,a.rpc=rpc_1,a.roots=roots,a.configure=r,a.Writer._configure(a.BufferWriter),r()}),minimal$1=indexMinimal,minimal_1=minimal$1.roots,minimal_2=minimal$1.Reader,minimal_3=minimal$1.util,$Reader=minimal$1.Reader,$util=minimal$1.util,$root=minimal$1.roots.default||(minimal$1.roots.default={});$root.tensorflow=function(){var e,t,a={};return a.Any=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.typeUrl=e.string();break;case 2:r.value=e.bytes();break;default:e.skipType(7&n)}}return r},e}(),a.DataType=(e={},(t=Object.create(e))[e[0]=\"DT_INVALID\"]=0,t[e[1]=\"DT_FLOAT\"]=1,t[e[2]=\"DT_DOUBLE\"]=2,t[e[3]=\"DT_INT32\"]=3,t[e[4]=\"DT_UINT8\"]=4,t[e[5]=\"DT_INT16\"]=5,t[e[6]=\"DT_INT8\"]=6,t[e[7]=\"DT_STRING\"]=7,t[e[8]=\"DT_COMPLEX64\"]=8,t[e[9]=\"DT_INT64\"]=9,t[e[10]=\"DT_BOOL\"]=10,t[e[11]=\"DT_QINT8\"]=11,t[e[12]=\"DT_QUINT8\"]=12,t[e[13]=\"DT_QINT32\"]=13,t[e[14]=\"DT_BFLOAT16\"]=14,t[e[101]=\"DT_FLOAT_REF\"]=101,t[e[102]=\"DT_DOUBLE_REF\"]=102,t[e[103]=\"DT_INT32_REF\"]=103,t[e[104]=\"DT_UINT8_REF\"]=104,t[e[105]=\"DT_INT16_REF\"]=105,t[e[106]=\"DT_INT8_REF\"]=106,t[e[107]=\"DT_STRING_REF\"]=107,t[e[108]=\"DT_COMPLEX64_REF\"]=108,t[e[109]=\"DT_INT64_REF\"]=109,t[e[110]=\"DT_BOOL_REF\"]=110,t[e[111]=\"DT_QINT8_REF\"]=111,t[e[112]=\"DT_QUINT8_REF\"]=112,t[e[113]=\"DT_QINT32_REF\"]=113,t[e[114]=\"DT_BFLOAT16_REF\"]=114,t),a.TensorShape=function(){function e(e){if(this.dim=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.dim&&r.dim.length||(r.dim=[]),r.dim.push($root.tensorflow.TensorShape.Dim.decode(e,e.uint32()));break;case 3:r.unknownRank=e.bool();break;default:e.skipType(7&n)}}return r},e.Dim=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.size=e.int64();break;case 2:r.name=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.Tensor=function(){function e(e){if(this.floatVal=[],this.doubleVal=[],this.intVal=[],this.stringVal=[],this.scomplexVal=[],this.int64Val=[],this.boolVal=[],this.uint32Val=[],this.uint64Val=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.dtype=e.int32();break;case 2:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 3:r.versionNumber=e.int32();break;case 4:r.tensorContent=e.bytes();break;case 5:if(r.floatVal&&r.floatVal.length||(r.floatVal=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.list=$root.tensorflow.AttrValue.ListValue.decode(e,e.uint32());break;case 2:r.s=e.bytes();break;case 3:r.i=e.int64();break;case 4:r.f=e.float();break;case 5:r.b=e.bool();break;case 6:r.type=e.int32();break;case 7:r.shape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;case 8:r.tensor=$root.tensorflow.Tensor.decode(e,e.uint32());break;case 9:r.placeholder=e.string();break;case 10:r.func=$root.tensorflow.NameAttrList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.ListValue=function(){function e(e){if(this.s=[],this.i=[],this.f=[],this.b=[],this.type=[],this.shape=[],this.tensor=[],this.func=[],e)for(var t=Object.keys(e),a=0;a>>3){case 2:r.s&&r.s.length||(r.s=[]),r.s.push(e.bytes());break;case 3:if(r.i&&r.i.length||(r.i=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:n.name=e.string();break;case 2:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.NodeDef=function(){function e(e){if(this.input=[],this.attr={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.name=e.string();break;case 2:n.op=e.string();break;case 3:n.input&&n.input.length||(n.input=[]),n.input.push(e.string());break;case 4:n.device=e.string();break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&o)}}return n},e}(),a.VersionDef=function(){function e(e){if(this.badConsumers=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.producer=e.int32();break;case 2:r.minConsumer=e.int32();break;case 3:if(r.badConsumers&&r.badConsumers.length||(r.badConsumers=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.node&&r.node.length||(r.node=[]),r.node.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:r.versions=$root.tensorflow.VersionDef.decode(e,e.uint32());break;case 2:r.library=$root.tensorflow.FunctionDefLibrary.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),a.CollectionDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.nodeList=$root.tensorflow.CollectionDef.NodeList.decode(e,e.uint32());break;case 2:r.bytesList=$root.tensorflow.CollectionDef.BytesList.decode(e,e.uint32());break;case 3:r.int64List=$root.tensorflow.CollectionDef.Int64List.decode(e,e.uint32());break;case 4:r.floatList=$root.tensorflow.CollectionDef.FloatList.decode(e,e.uint32());break;case 5:r.anyList=$root.tensorflow.CollectionDef.AnyList.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.NodeList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.string());break;default:e.skipType(7&n)}}return r},e}(),e.BytesList=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push(e.bytes());break;default:e.skipType(7&n)}}return r},e}(),e.Int64List=function(){function e(e){if(this.value=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:if(r.value&&r.value.length||(r.value=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>3){case 1:r.value&&r.value.length||(r.value=[]),r.value.push($root.tensorflow.Any.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SaverDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.filenameTensorName=e.string();break;case 2:r.saveTensorName=e.string();break;case 3:r.restoreOpName=e.string();break;case 4:r.maxToKeep=e.int32();break;case 5:r.sharded=e.bool();break;case 6:r.keepCheckpointEveryNHours=e.float();break;case 7:r.version=e.int32();break;default:e.skipType(7&n)}}return r},e.CheckpointFormatVersion=(t={},(a=Object.create(t))[t[0]=\"LEGACY\"]=0,a[t[1]=\"V1\"]=1,a[t[2]=\"V2\"]=2,a),e}(),a.TensorInfo=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 4:r.cooSparse=$root.tensorflow.TensorInfo.CooSparse.decode(e,e.uint32());break;case 2:r.dtype=e.int32();break;case 3:r.tensorShape=$root.tensorflow.TensorShape.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e.CooSparse=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.valuesTensorName=e.string();break;case 2:r.indicesTensorName=e.string();break;case 3:r.denseShapeTensorName=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SignatureDef=function(){function e(e){if(this.inputs={},this.outputs={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:e.skip().pos++,n.inputs===$util.emptyObject&&(n.inputs={}),a=e.string(),e.pos++,n.inputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:e.skip().pos++,n.outputs===$util.emptyObject&&(n.outputs={}),a=e.string(),e.pos++,n.outputs[a]=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 3:n.methodName=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.AssetFileDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.tensorInfo=$root.tensorflow.TensorInfo.decode(e,e.uint32());break;case 2:r.filename=e.string();break;default:e.skipType(7&n)}}return r},e}(),a.OpDef=function(){function e(e){if(this.inputArg=[],this.outputArg=[],this.attr=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.inputArg&&r.inputArg.length||(r.inputArg=[]),r.inputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 3:r.outputArg&&r.outputArg.length||(r.outputArg=[]),r.outputArg.push($root.tensorflow.OpDef.ArgDef.decode(e,e.uint32()));break;case 4:r.attr&&r.attr.length||(r.attr=[]),r.attr.push($root.tensorflow.OpDef.AttrDef.decode(e,e.uint32()));break;case 8:r.deprecation=$root.tensorflow.OpDef.OpDeprecation.decode(e,e.uint32());break;case 5:r.summary=e.string();break;case 6:r.description=e.string();break;case 18:r.isCommutative=e.bool();break;case 16:r.isAggregate=e.bool();break;case 17:r.isStateful=e.bool();break;case 19:r.allowsUninitializedInput=e.bool();break;default:e.skipType(7&n)}}return r},e.ArgDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.description=e.string();break;case 3:r.type=e.int32();break;case 4:r.typeAttr=e.string();break;case 5:r.numberAttr=e.string();break;case 6:r.typeListAttr=e.string();break;case 16:r.isRef=e.bool();break;default:e.skipType(7&n)}}return r},e}(),e.AttrDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.name=e.string();break;case 2:r.type=e.string();break;case 3:r.defaultValue=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 4:r.description=e.string();break;case 5:r.hasMinimum=e.bool();break;case 6:r.minimum=e.int64();break;case 7:r.allowedValues=$root.tensorflow.AttrValue.decode(e,e.uint32());break;default:e.skipType(7&n)}}return r},e}(),e.OpDeprecation=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.version=e.int32();break;case 2:r.explanation=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.OpList=function(){function e(e){if(this.op=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.op&&r.op.length||(r.op=[]),r.op.push($root.tensorflow.OpDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.MetaGraphDef=function(){function e(e){if(this.collectionDef={},this.signatureDef={},this.assetFileDef=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.metaInfoDef=$root.tensorflow.MetaGraphDef.MetaInfoDef.decode(e,e.uint32());break;case 2:n.graphDef=$root.tensorflow.GraphDef.decode(e,e.uint32());break;case 3:n.saverDef=$root.tensorflow.SaverDef.decode(e,e.uint32());break;case 4:e.skip().pos++,n.collectionDef===$util.emptyObject&&(n.collectionDef={}),a=e.string(),e.pos++,n.collectionDef[a]=$root.tensorflow.CollectionDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.signatureDef===$util.emptyObject&&(n.signatureDef={}),a=e.string(),e.pos++,n.signatureDef[a]=$root.tensorflow.SignatureDef.decode(e,e.uint32());break;case 6:n.assetFileDef&&n.assetFileDef.length||(n.assetFileDef=[]),n.assetFileDef.push($root.tensorflow.AssetFileDef.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return n},e.MetaInfoDef=function(){function e(e){if(this.tags=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.metaGraphVersion=e.string();break;case 2:r.strippedOpList=$root.tensorflow.OpList.decode(e,e.uint32());break;case 3:r.anyInfo=$root.tensorflow.Any.decode(e,e.uint32());break;case 4:r.tags&&r.tags.length||(r.tags=[]),r.tags.push(e.string());break;case 5:r.tensorflowVersion=e.string();break;case 6:r.tensorflowGitVersion=e.string();break;default:e.skipType(7&n)}}return r},e}(),e}(),a.SavedModel=function(){function e(e){if(this.metaGraphs=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.savedModelSchemaVersion=e.int64();break;case 2:r.metaGraphs&&r.metaGraphs.length||(r.metaGraphs=[]),r.metaGraphs.push($root.tensorflow.MetaGraphDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDefLibrary=function(){function e(e){if(this.function=[],this.gradient=[],e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.function&&r.function.length||(r.function=[]),r.function.push($root.tensorflow.FunctionDef.decode(e,e.uint32()));break;case 2:r.gradient&&r.gradient.length||(r.gradient=[]),r.gradient.push($root.tensorflow.GradientDef.decode(e,e.uint32()));break;default:e.skipType(7&n)}}return r},e}(),a.FunctionDef=function(){function e(e){if(this.attr={},this.nodeDef=[],this.ret={},e)for(var t=Object.keys(e),a=0;a>>3){case 1:n.signature=$root.tensorflow.OpDef.decode(e,e.uint32());break;case 5:e.skip().pos++,n.attr===$util.emptyObject&&(n.attr={}),a=e.string(),e.pos++,n.attr[a]=$root.tensorflow.AttrValue.decode(e,e.uint32());break;case 3:n.nodeDef&&n.nodeDef.length||(n.nodeDef=[]),n.nodeDef.push($root.tensorflow.NodeDef.decode(e,e.uint32()));break;case 4:e.skip().pos++,n.ret===$util.emptyObject&&(n.ret={}),a=e.string(),e.pos++,n.ret[a]=e.string();break;default:e.skipType(7&o)}}return n},e}(),a.GradientDef=function(){function e(e){if(e)for(var t=Object.keys(e),a=0;a>>3){case 1:r.functionName=e.string();break;case 2:r.gradientFunc=e.string();break;default:e.skipType(7&n)}}return r},e}(),a}();var compiled_api=$root,compiled_api_1=compiled_api.tensorflow;function getParamValue(e,t,a,r){var n=t.params[e];if(n&&void 0!==n.inputIndex){if(\"tensor\"===n.type)return getTensor(t.inputNames[n.inputIndex],a,r);if(\"tensors\"===n.type)return(0===n.inputIndex?0===n.inputParamLength?t.inputNames:t.inputNames.slice(n.inputIndex,-n.inputParamLength):t.inputNames.splice(n.inputIndex)).map(function(e){return getTensor(e,a,r)});var o=Array.prototype.slice.call(getTensor(t.inputNames.slice(n.inputIndex)[0],a,r).dataSync());return\"number\"===n.type?o[0]:o}return n&&n.value}function getTensor(e,t,a){var r=parseNodeName(e),n=r[0],o=r[1],s=a.currentContextIds.find(function(e){return!!t[getNodeNameWithContextId(n,e)]});return void 0!==s?t[getNodeNameWithContextId(n,s)][o]:void 0}function getNodeNameAndIndex(e,t){var a=parseNodeName(e),r=a[0],n=a[1];return[getNodeNameWithContextId(r,t&&t.currentContextId),n]}function getNodeNameWithContextId(e,t){return t?e+\"-\"+t:e}function parseNodeName(e){var t=e.lastIndexOf(\":\");return-1===t?[e,0]:[e.substring(0,t),Number(e.substring(t+1))]}function split$1(e,t){for(var a=[],r=0;r=this.tensors.length)throw new Error(\"Tried to read from index \"+e+\", but array size is: \"+this.tensors.length);var t=this.tensors[e];if(t.cleared)throw new Error(\"TensorArray \"+this.name+\": Could not read index \"+e+\" twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).\");return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor},e.prototype.readMany=function(e){var t=this;return e.map(function(e){return t.read(e)})},e.prototype.write=function(e,t){if(this.closed_)throw new Error(\"TensorArray \"+this.name+\" has already been closed.\");if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error(\"Tried to write to index \"+e+\", but array is not resizeable and size is: \"+this.maxSize);var a=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\",\\n because the value dtype is \"+t.dtype+\", but TensorArray dtype is \"+this.dtype+\".\");if(0===this.size()&&0===this.elementShape.length&&(this.elementShape=t.shape),util.assertShapesMatch(this.elementShape,t.shape,\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\".\"),a&&a.read)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\", because it has already been read.\");if(a&&a.written)throw new Error(\"TensorArray \"+this.name+\": Could not write to TensorArray index \"+e+\", because it has already been written.\");a.tensor=t,a.written=!0,this.tensors[e]=a},e.prototype.writeMany=function(e,t){var a=this;if(e.length!==t.length)throw new Error(\"TensorArray \"+this.name+\": could not write multiple tensors,because the index size: \"+e.length+\" is not the same as tensors size: \"+t.length+\".\");e.map(function(e,r){return a.write(e,t[r])})},e.prototype.gather=function(e,t){if(t&&t!==this.dtype)throw new Error(\"TensorArray dtype is \"+this.dtype+\" but gather requested dtype \"+t);if(!e){e=[];for(var a=0;a=this.maxSize)throw new Error(\"Max index must be < array size (\"+a+\" vs. \"+this.maxSize+\")\");this.writeMany(e,unstack(t,0))},e.prototype.split=function(e,t){var a=this;if(t.dtype!==this.dtype)throw new Error(\"TensorArray dtype is \"+this.dtype+\" but tensor has dtype \"+t.dtype);var r=0,n=e.map(function(e){return r+=e});if(r!==t.shape[0])throw new Error(\"Expected sum of lengths to be equal to\\n tensor.shape[0], but sum of lengths is\\n \"+r+\", and tensor's shape is: \"+t.shape);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error(\"TensorArray's size is not equal to the size of lengths (\"+this.maxSize+\" vs. \"+e.length+\"), and the TensorArray is not marked as dynamically resizeable\");var o=0===r?0:t.size/r,s=[];tidy(function(){t=t.reshape([1,r,o]);for(var i=0;i1)for(var f=1;f1))throw new Error(\"Cannot exit frame, the context is empty\");this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift()},e.prototype.nextIteration=function(){if(!(this.contexts&&this.contexts.length>0))throw new Error(\"Cannot increase frame iteration, the context is empty\");this.contexts=this.contexts.slice(),this.lastId++;var e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))},e.prototype.getWeight=function(e){return this.weightMap[e]},e.prototype.addTensorArray=function(e){this.tensorArrayMap[e.id]=e},e.prototype.getTensorArray=function(e){return this.tensorArrayMap[e]},e}(),GraphExecutor=function(){function e(e){this.graph=e,this.compiledOrder=[],this._weightMap={},this.placeholders=e.placeholders,this._outputs=e.outputs,this.compile()}return Object.defineProperty(e.prototype,\"weightMap\",{get:function(){return this._weightMap},set:function(e){var t=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})});this.weightIds=[].concat.apply([],t),this._weightMap=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputs\",{get:function(){return this.placeholders.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputs\",{get:function(){return this._outputs.map(function(e){return{name:e.name,shape:e.params.shape?e.params.shape.value:void 0,dtype:e.params.dtype?e.params.dtype.value:void 0}})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputNodes\",{get:function(){return this.placeholders.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputNodes\",{get:function(){return this.outputs.map(function(e){return e.name})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"isControlFlowModel\",{get:function(){return this.graph.withControlFlow},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"isDynamicShapeModel\",{get:function(){return this.graph.withDynamicShape},enumerable:!0,configurable:!0}),e.prototype.compile=function(){if(!this.graph.withControlFlow&&!this.graph.withDynamicShape)for(var e=this.graph.inputs.slice(),t={};e.length>0;){var a=e.pop();t[a.name]=!0,this.compiledOrder.push(a),a.children.forEach(function(a){!t[a.name]&&a.inputNames.every(function(e){var a=getNodeNameAndIndex(e)[0];return t[a]})&&e.push(a)})}},e.prototype.execute=function(e,t){var a=this;this.checkInput(e),this.checkInputShapeAndType(e);var r={};return tidy(function(){var n=new ExecutionContext(a._weightMap,r),o=a.compiledOrder.reduce(function(e,t){return e[t.name]=executeOp$15(t,e,n),e},__assign({},a.weightMap,e));return a.findOutputs(o,n,t)})},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u=this;return __generator(this,function(m){switch(m.label){case 0:return this.checkInput(e),this.checkInputShapeAndType(e),a={},r=new ExecutionContext(this._weightMap,a),[4,this.executeWithControlFlow(e,r)];case 1:return n=m.sent(),o=this.findOutputs(n,r,t),s=Object.keys(o).map(function(e){return o[e].id}),i=Object.keys(e).map(function(t){return e[t].map(function(e){return e.id})}),p=[].concat.apply([],i),Object.keys(n).forEach(function(e){n[e].forEach(function(e){e&&-1===s.indexOf(e.id)&&-1===p.indexOf(e.id)&&-1===u.weightIds.indexOf(e.id)&&e.dispose()})}),[2,o]}})})},e.prototype.executeWithControlFlow=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r,n,o,s,i,p,u;return __generator(this,function(m){switch(m.label){case 0:a=this.graph.inputs.map(function(e){return{node:e,contexts:t.currentContext}}),r=__assign({},this.weightMap,e),n={},m.label=1;case 1:return a.length>0?(o=a.pop(),t.currentContext=o.contexts,s=\"\",\"enter\"===o.node.op&&getParamValue(\"isConstant\",o.node,r,t)&&(s=getNodeNameAndIndex(o.node.name,t)[0]),i=executeOp$15(o.node,r,t),s||(s=getNodeNameAndIndex(o.node.name,t)[0]),p=r,u=s,[4,i]):[3,3];case 2:return p[u]=m.sent(),o.node.children.forEach(function(e){var o=getNodeNameAndIndex(e.name,t)[0];n[o]||(\"merge\"===e.op?e.inputNames.some(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})):e.inputNames.every(function(e){return!!getTensor(e,r,t)})&&(n[o]=!0,a.push({contexts:t.currentContext,node:e})))}),[3,1];case 3:return[2,r]}})})},e.prototype.findOutputs=function(e,t,a){return!a||a instanceof Array||(a=[a]),(a||this.graph.outputs.map(function(e){return e.name})).reduce(function(a,r){return a[r]=getTensor(r,e,t),a},{})},e.prototype.dispose=function(){var e=this;Object.keys(this.weightMap).forEach(function(t){return e.weightMap[t].forEach(function(e){return e.dispose()})})},e.prototype.checkInputShapeAndType=function(e){this.placeholders.forEach(function(t){var a=e[t.name][0];if(t.params.shape&&t.params.shape.value){var r=t.params.shape.value,n=r.length===a.shape.length&&a.shape.every(function(e,t){return-1===r[t]||r[t]===e});util.assert(n,\"The shape of dict['\"+t.name+\"'] provided in model.execute(dict) must be [\"+r+\"], but was [\"+a.shape+\"]\")}t.params.dtype&&t.params.dtype.value&&util.assert(a.dtype===t.params.dtype.value,\"The dtype of dict['\"+t.name+\"'] provided in model.execute(dict) must be \"+t.params.dtype.value+\", but was \"+a.dtype)})},e.prototype.checkInput=function(e){var t=this,a=Object.keys(e),r=[],n=[];if(this.inputNodes.forEach(function(e){-1===a.indexOf(e)&&r.push(e)}),a.forEach(function(e){-1===t.inputNodes.indexOf(e)&&n.push(e)}),r.length>0)throw new Error(\"The dict provided in model.execute(dict) has the keys [\"+a+\"], but is missing the required keys: [\"+r+\"].\");if(n.length>0)throw new Error(\"The dict provided in model.execute(dict) has unused keys: [\"+n+\"]. Please provide only the following keys: [\"+this.inputNodes+\"].\")},e}(),FrozenModel=function(){function e(e,t,a){this.modelUrl=e,this.weightManifestUrl=t,this.requestOption=a,this.version=\"n/a\",this.pathPrefix=this.getPathPrefix()}return Object.defineProperty(e.prototype,\"modelVersion\",{get:function(){return this.version},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputNodes\",{get:function(){return this.executor.inputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputNodes\",{get:function(){return this.executor.outputNodes},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"inputs\",{get:function(){return this.executor.inputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"outputs\",{get:function(){return this.executor.outputs},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,\"weights\",{get:function(){return this.executor.weightMap},enumerable:!0,configurable:!0}),e.prototype.getPathPrefix=function(){var e=parse(this.weightManifestUrl),t=e.pathname.split(\"/\");return t.splice(-1),e.pathname=t.join(\"/\"),format(e)+\"/\"},e.prototype.loadRemoteProtoFile=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r,n;return __generator(this,function(o){switch(o.label){case 0:return o.trys.push([0,3,,4]),[4,fetch(this.modelUrl,this.requestOption)];case 1:return e=o.sent(),a=(t=compiled_api_1.GraphDef).decode,r=Uint8Array.bind,[4,e.arrayBuffer()];case 2:return[2,a.apply(t,[new(r.apply(Uint8Array,[void 0,o.sent()]))])];case 3:throw n=o.sent(),new Error(this.modelUrl+\" not found. \"+n);case 4:return[2]}})})},e.prototype.loadWeightManifest=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a;return __generator(this,function(r){switch(r.label){case 0:return r.trys.push([0,3,,4]),[4,fetch(this.weightManifestUrl,this.requestOption)];case 1:return e=r.sent(),t=this,[4,e.clone().json()];case 2:return t.weightManifest=r.sent(),[3,4];case 3:throw a=r.sent(),new Error(this.weightManifestUrl+\" not found. \"+a);case 4:return[2]}})})},e.prototype.load=function(){return __awaiter(this,void 0,void 0,function(){var e,t,a,r;return __generator(this,function(n){switch(n.label){case 0:return e=this.loadRemoteProtoFile(),t=this.loadWeightManifest(),[4,Promise.all([e,t])];case 1:return a=n.sent()[0],this.version=a.versions.producer+\".\"+a.versions.minConsumer,[4,io.loadWeights(this.weightManifest,this.pathPrefix,void 0,this.requestOption)];case 2:return r=n.sent(),this.executor=new GraphExecutor(OperationMapper.Instance.transformGraph(a)),this.executor.weightMap=this.convertTensorMapToTensorsMap(r),[2,!0]}})})},e.prototype.predict=function(e,t){return this.execute(e,this.outputNodes)},e.prototype.constructTensorMap=function(e){var t=e instanceof Tensor?[e]:e;if(t.length!==this.inputNodes.length)throw new Error(\"Input tensor count mismatch,the frozen model has \"+this.inputNodes.length+\" placeholders, while there are \"+t.length+\" input tensors.\");return this.inputNodes.reduce(function(e,a,r){return e[a]=t[r],e},{})},e.prototype.execute=function(e,t){if(t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),this.executor.isControlFlowModel||this.executor.isDynamicShapeModel)throw new Error(\"The model contains control flow or dynamic shape ops, please use executeAsync method\");var a=this.executor.execute(this.convertTensorMapToTensorsMap(e),t),r=Object.keys(a);return Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]},e.prototype.executeAsync=function(e,t){return __awaiter(this,void 0,void 0,function(){var a,r;return __generator(this,function(n){switch(n.label){case 0:if(!this.executor.isControlFlowModel||!this.executor.isDynamicShapeModel)throw new Error(\"The model does not contain control flow or dynamic shape ops, please use execute method for better performance.\");return t=t||this.outputNodes,(e instanceof Tensor||Array.isArray(e))&&(e=this.constructTensorMap(e)),[4,this.executor.executeAsync(this.convertTensorMapToTensorsMap(e),t)];case 1:return a=n.sent(),r=Object.keys(a),[2,Array.isArray(t)&&t.length>1?t.map(function(e){return a[e]}):a[r[0]]]}})})},e.prototype.convertTensorMapToTensorsMap=function(e){return Object.keys(e).reduce(function(t,a){return t[a]=[e[a]],t},{})},e.prototype.dispose=function(){this.executor.dispose()},e}();function loadFrozenModel(e,t,a){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(n){switch(n.label){case 0:return[4,(r=new FrozenModel(e,t,a)).load()];case 1:return n.sent(),[2,r]}})})}var version=\"0.5.5\";export{FrozenModel,loadFrozenModel,version as version_converter};\n","/** @license See the LICENSE file. */\n\n// This code is auto-generated, do not modify this file!\nconst version = '0.12.4';\nexport {version};\n","/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nexport * from '@tensorflow/tfjs-core';\nexport * from '@tensorflow/tfjs-layers';\nexport * from '@tensorflow/tfjs-converter';\n\n// Import versions of all sub-packages.\nimport {version_core} from '@tensorflow/tfjs-core';\nimport {version_layers} from '@tensorflow/tfjs-layers';\nimport {version_converter} from '@tensorflow/tfjs-converter';\nimport {version as version_union} from './version';\n\nexport const version = {\n 'tfjs-core': version_core,\n 'tfjs-layers': version_layers,\n 'tfjs-converter': version_converter,\n 'tfjs': version_union\n};\n"],"names":["extendStatics","Object","setPrototypeOf","__proto__","Array","e","t","n","hasOwnProperty","__extends","constructor","prototype","create","__assign","assign","r","arguments","length","o","call","__awaiter","Promise","a","i","next","s","throw","u","done","value","then","apply","__generator","label","sent","trys","ops","return","Symbol","iterator","this","TypeError","pop","push","isMobile","navigator","userAgent","vendor","window","opera","test","substr","shuffle","Math","random","clamp","max","min","randUniform","distSquared","Number","assert","Error","assertShapesMatch","arraysEqual","assertNonNull","flatten","isArray","inferShape","isTypedArray","deepAssertShapeConsistency","join","slice","concat","sizeFromShape","isScalarShape","isInt","tanh","exp","sizeToSquarishShape","floor","sqrt","createShuffledIndices","Uint32Array","rightPad","repeat","repeatedTry","setTimeout","inferFromImplicitShape","squeezeShape","newShape","keptDims","getTypedArrayFromDType","Float32Array","Int32Array","Uint8Array","checkComputationForNaN","isNaN","checkConversionForNaN","hasEncodingLoss","copyTypedArray","round","bytesPerElement","isFunction","nearestDivisor","computeStrides","toTypedArray","noConversionNeeded","makeOnesTypedArray","makeZerosTypedArray","now","performance","process","hrtime","util","freeze","Profiler","backendTimer","logger","Logger","profileKernel","time","forEach","dataSync","dtype","logKernelProfile","kernelMs","rank","size","shape","toString","console","log","getFilteredNodesXToY","id","m","inputs","l","c","output","p","d","h","f","g","v","y","backpropagateGradients","gradient","name","keys","add","dispose","FORMAT_LIMIT_NUM_VALS","FORMAT_NUM_FIRST_LAST_VALS","FORMAT_NUM_SIG_DIGITS","tensorToString","computeMaxSizePerColumn","subTensorToString","map","fill","valToString","parseFloat","toFixed","from","subarray","TensorBuffer","values","strides","set","locToIndex","get","indexToLoc","defineProperty","enumerable","configurable","toTensor","Tensor","make","trackerFn","opHandler","setTensorTracker","setOpHandler","isDisposedInternal","dataId","nextId","rankType","registerTensor","write","throwIfDisposed","as1D","asScalar","reshape","as2D","as3D","as4D","asType","cast","buffer","data","read","readSync","isDisposed","disposeTensor","toFloat","toInt","toBool","print","reshapeAs","expandDims","cumsum","squeeze","clone","tile","gather","matMul","dot","norm","reverse","stack","unstack","pad","batchNormalization","all","any","logSumExp","sum","mean","argMin","argMax","addStrict","sub","subStrict","pow","powStrict","mul","mulStrict","div","floorDiv","divStrict","minimum","minimumStrict","maximum","maximumStrict","mod","modStrict","squaredDifference","squaredDifferenceStrict","transpose","notEqual","notEqualStrict","less","lessStrict","equal","equalStrict","lessEqual","lessEqualStrict","greater","greaterStrict","greaterEqual","greaterEqualStrict","logicalAnd","logicalOr","logicalNot","logicalXor","where","neg","ceil","sign","expm1","log1p","rsqrt","square","reciprocal","abs","clipByValue","relu","elu","selu","leakyRelu","prelu","sigmoid","logSigmoid","softplus","sin","cos","tan","asin","acos","atan","sinh","cosh","asinh","acosh","atanh","erf","step","softmax","resizeBilinear","image","resizeNearestNeighbor","conv1d","conv2d","conv2dTranspose","depthwiseConv2D","depthwiseConv2d","avgPool","maxPool","localResponseNormalization","variable","Variable","unsortedSegmentSum","batchToSpaceND","spaceToBatchND","hasInstance","trainable","nextVarId","registerVariable","Function","assertTypesMatch","isTensorInList","getTensorsInContainer","walkTensorContainer","Set","isIterable","has","Type","Engine","backend","safeMode","debugMode","registeredVariables","refCounter","WeakMap","nextTapeNodeId","numBytes","numTensors","numDataBuffers","gradientScopeCount","customGradientDepth","keepTensors","activeScope","track","scopeStack","profiler","tidy","String","scopedRun","startScope","endScope","error","runKernel","shouldRecord","activeTape","register","delete","disposeData","disposeVariables","memory","addTapeNode","keep","gradients","ones","grads","customGrad","every","gradFunc","fromPixels","wallMs","NUMBER","BOOLEAN","STRING","URL_PROPERTIES","type","isWebGLVersionEnabled","getWebGLRenderingContext","loseContext","getWebGLDisjointQueryTimerVersion","hasExtension","isRenderToFloatTextureEnabled","createFloatTextureAndBindToFramebuffer","checkFramebufferStatus","FRAMEBUFFER","FRAMEBUFFER_COMPLETE","isDownloadFloatTextureEnabled","readPixels","RGBA","FLOAT","getError","NO_ERROR","isWebGLFenceEnabled","fenceSync","isChrome","TENSORFLOWJS_FLAGS_PREFIX","getFeaturesFromURL","location","getQueryParams","search","split","warn","getExtension","document","createElement","getContext","createFramebuffer","createTexture","bindTexture","TEXTURE_2D","RGBA32F","texImage2D","bindFramebuffer","framebufferTexture2D","COLOR_ATTACHMENT0","replace","decodeParam","decodeURIComponent","TEST_EPSILON_FLOAT32_ENABLED","TEST_EPSILON_FLOAT32_DISABLED","Environment","features","registry","setBackend","ENV","initBackend","getBackend","initDefaultBackend","backendName","engine","evaluateFeature","getFeatures","getBestBackendName","entry","sort","priority","versions","node","setFeatures","reset","globalEngine","findBackend","registerBackend","message","removeBackend","getGlobalNamespace","getOrMakeEnvironment","environment","getReshaped","getPermuted","getReshapedPermuted","getSliceBeginCoords","getSliceSize","axesAreInnerMostDims","combineLocations","indexOf","computeOutAndReduceShapes","expandShapeToKeepDim","parseAxisParam","assertAxesAreInnerMostDims","getAxesPermutation","getUndoAxesPermutation","getInnerMostAxes","PARALLELIZE_THRESHOLD","computeOptimalWindowSize","segOpComputeOptimalWindowSize","computeOutShape","assertParamsValid","getStridedSlicedInfo","startForAxis","stopForAxis","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","grad","checkGrads","valueAndGrad","valueAndGrads","variableGrads","filter","some","convertToTensor","convertToTensorArray","op","endsWith","substring","softmax_","tensor","scalar","tensor1d","tensor2d","tensor3d","tensor4d","tensor5d","tensor6d","ones$1","zeros","onesLike_","zerosLike_","linspace","range","DType","Rank","UpcastBoolAndMap","UpcastFloat32AndMap","onesLike","zerosLike","float32","int32","bool","R0","R1","R2","R3","R4","R5","R6","UpcastInt32AndMap","upcastTypeMap","upcastType","sumOutType","castTensor","int","reshapeTensor","nonMaxSuppressionImpl","score","boxIndex","intersectionOverUnion","x","topkImpl","index","ArgMinMaxProgram","variableNames","windowSize","batchSize","inSize","outputShape","userCode","AvgPool2DBackpropProgram","inShape","filterHeight","filterWidth","strideHeight","strideWidth","padInfo","top","left","outHeight","outWidth","getBroadcastDims","unshift","getReductionAxes","broadcastDimsAreOuter","assertAndGetBroadcastShape","BatchNormProgram","supportsBroadcasting","CHECK_NAN_SNIPPET","ADD","SUB","MUL","DIV","INT_DIV","POW","SQUARED_DIFFERENCE","EQUAL","NOT_EQUAL","LESS","LESS_EQUAL","GREATER","GREATER_EQUAL","LOGICAL_AND","LOGICAL_OR","MAX","MIN","MOD","ATAN2","ELU_DER","BinaryOpProgram","getCustomSetupFunc","startLoc","getUniformLocationNoThrow","gl","uniform1f","NaN","ClipProgram","assertParams","computeOutShape$1","computeGradientSliceShapes","aBegin","aSize","bBegin","bSize","ConcatProgram","Conv2DDerFilterProgram","filterShape","inHeight","inWidth","Conv2DDerInputProgram","outChannels","DepthwiseConv2DDerFilterProgram","inChannels","DepthwiseConv2DDerInputProgram","Conv2DProgram","outShape","dilationHeight","dilationWidth","DepthwiseConv2DProgram","makeShader","shapeInfo","logicalShape","isUniform","getInputSamplingSnippet","texShape","getOutputSamplingSnippet","SHADER_PREFIX","FLOAT_TEXTURE_SAMPLE_SNIPPET","FLOAT_TEXTURE_SETOUTPUT_SNIPPET","getSamplerFromInInfo","getSamplerScalar","getSampler1D","getSampler2D","getSampler3D","getSampler4D","getSampler5D","getSampler6D","getSamplerFlat","getSamplerAtOutputCoords","getOutputScalarCoords","getOutput1DCoords","getOutput2DCoords","getOutput3DCoords","getOutput4DCoords","getOutput5DCoords","getOutput6DCoords","SAMPLE_1D_SNIPPET","SAMPLE_2D_SNIPPET","SAMPLE_3D_SNIPPET","SAMPLE_4D_SNIPPET","SAMPLE_5D_SNIPPET","SAMPLE_6D_SNIPPET","charAt","toUpperCase","squeezeInputInfo","getSqueezedParams","getBroadcastOutputCoordsSampler","getCoordsDataType","JSON","parse","stringify","CumSumProgram","getFinalCoord","getCoords","TextureUsage","PhysicalTextureType","EncodeFloatProgram","FromPixelsProgram","GatherProgram","getSourceCoords","getUnpackedMatrixTextureShapeWidthHeight","getUnpackedArraySizeFromMatrixSize","getMatrixSizeFromUnpackedArraySize","encodeMatrixToUnpackedArray","decodeMatrixFromUnpackedArray","getPackedMatrixTextureShapeWidthHeight","getPackedRGBAArraySizeFromMatrixShape","encodeMatrixToPackedRGBA","decodeMatrixFromPackedRGBA","RENDER","UPLOAD","PIXELS","DOWNLOAD","FLOAT16","FLOAT32","UNSIGNED_BYTE","MAX_TEXTURE_SIZE","createWebGLRenderingContext","width","height","createWebGLRenderingContextFromCanvas","callAndCheck","checkWebGLError","webGLDebugErrorCheckingEnabled","enableDebugWebGLErrorChecking","getWebGLErrorMessage","INVALID_ENUM","INVALID_VALUE","INVALID_OPERATION","INVALID_FRAMEBUFFER_OPERATION","OUT_OF_MEMORY","CONTEXT_LOST_WEBGL","getExtensionOrThrow","throwIfNull","createVertexShader","createShader","VERTEX_SHADER","shaderSource","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","createFragmentShader","FRAGMENT_SHADER","logShaderSourceAndInfoLog","lineNumberRegex","exec","createProgram","linkProgram","getProgramParameter","LINK_STATUS","getProgramInfoLog","validateProgram","VALIDATE_STATUS","createStaticVertexBuffer","createBuffer","bindBuffer","ARRAY_BUFFER","bufferData","STATIC_DRAW","createStaticIndexBuffer","ELEMENT_ARRAY_BUFFER","queryMaxTextureSize","getParameter","getNumChannels","validateTextureSize","bindVertexBufferToProgramAttribute","getAttribLocation","vertexAttribPointer","enableVertexAttribArray","bindTextureUnit","activeTexture","TEXTURE0","unbindTextureUnit","getProgramUniformLocationOrThrow","getUniformLocation","getProgramUniformLocation","bindTextureToProgramUniformSampler","uniform1i","bindCanvasToFramebuffer","viewport","canvas","scissor","bindColorTextureToFramebuffer","unbindColorTextureFromFramebuffer","validateFramebuffer","getFramebufferErrorMessage","FRAMEBUFFER_INCOMPLETE_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT","FRAMEBUFFER_INCOMPLETE_DIMENSIONS","FRAMEBUFFER_UNSUPPORTED","validateTextureUnit","MAX_COMBINED_TEXTURE_IMAGE_UNITS","getTextureShapeFromLogicalShape","webgl_util","getWebGLContextAttributes","alpha","antialias","premultipliedAlpha","preserveDrawingBuffer","depth","stencil","failIfMajorPerformanceCaveat","createWebGLContext","disable","DEPTH_TEST","STENCIL_TEST","BLEND","DITHER","POLYGON_OFFSET_FILL","SAMPLE_COVERAGE","enable","SCISSOR_TEST","CULL_FACE","cullFace","BACK","createVertexShader$1","createVertexBuffer","createIndexBuffer","Uint16Array","getTextureConfig","R32F","R16F","RED","HALF_FLOAT","HALF_FLOAT_OES","internalFormatFloat","internalFormatHalfFloat","internalFormatPackedFloat","textureFormatFloat","downloadTextureFormat","downloadUnpackNumChannels","defaultNumChannels","textureTypeHalfFloat","createAndConfigureTexture","texParameteri","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","createFloat32MatrixTexture","createFloat16MatrixTexture","createUnsignedBytesMatrixTexture","createPackedMatrixTexture","bindVertexProgramAttributeStreams","uploadPixelDataToTexture","uploadDataToTexture","texSubImage2D","uploadMatrixToTexture","uploadMatrixToPackedTexture","maybeCreateBufferFromOutputTexture","PIXEL_PACK_BUFFER","downloadFloat32MatrixFromBuffer","getBufferSubData","downloadFloat32MatrixFromOutputTexture","downloadByteEncodedFloatMatrixFromOutputTexture","downloadMatrixFromPackedOutputTexture","gpgpu_util","GPGPUContext","outputTexture","program","disposed","autoDebugValidate","vertexAttrsAreBound","itemsToPoll","textureFloatExtension","colorBufferFloatExtension","textureHalfFloatExtension","colorBufferHalfFloatExtension","loseContextExtension","vertexBuffer","indexBuffer","framebuffer","textureConfig","finish","deleteFramebuffer","deleteBuffer","enableAutomaticDebugValidation","deleteMatrixTexture","deleteTexture","downloadMatrixDriver","maybeCreateBufferFromTexture","bindTextureToFrameBuffer","unbindTextureToFrameBuffer","createAndWaitForFence","createFence","pollFence","SYNC_GPU_COMMANDS_COMPLETE","flush","clientWaitSync","ALREADY_SIGNALED","CONDITION_SATISFIED","beginQuery","endQuery","isQueryAvailable","query","isFencePassed","downloadMatrixFromPackedTexture","attachShader","setProgram","deleteProgram","useProgram","getAttributeLocation","setInputMatrixTexture","throwIfNoProgram","setOutputMatrixTexture","setOutputMatrixTextureDriver","setOutputPackedMatrixTexture","setOutputMatrixWriteRegion","setOutputMatrixWriteRegionDriver","setOutputPackedMatrixWriteRegion","debugValidate","executeProgram","drawElements","TRIANGLES","UNSIGNED_SHORT","blockUntilAllProgramsCompleted","getQueryTimerExtension","disjointQueryTimerExtension","getQueryTimerExtensionWebGL2","getQueryTimerExtensionWebGL1","createQuery","TIME_ELAPSED_EXT","createQueryEXT","beginQueryEXT","endQueryEXT","waitForQueryAndGetTime","getQueryTime","getQueryParameter","QUERY_RESULT","getQueryObjectEXT","QUERY_RESULT_EXT","QUERY_RESULT_AVAILABLE","disjoint","GPU_DISJOINT_EXT","QUERY_RESULT_AVAILABLE_EXT","addItemToPoll","pollItems","binSearchLastTrue","isDoneFn","resolveFn","compileProgram","texData","source","webGLProgram","uniformLocations","gpgpu","inShapeInfos","outShapeInfo","validateBinaryAndProgram","runProgram","texture","uniform1fv","makeShaderKey","LRNProgram","LRNGradProgram","depthRadius","bias","beta","MaxPool2DBackpropProgram","MatMulProgram","MultinomialProgram","seedLoc","OneHotProgram","PadProgram","Pool2DProgram","ReduceProgram","ResizeBilinearBackpropProgram","ResizeBilinearProgram","ResizeNearestNeigborBackpropProgram","ResizeNearestNeighborProgram","ReverseProgram","SegmentOpProgram","numSegments","SelectProgram","SliceProgram","getCoords$1","uniform2i","uniform3i","uniform4i","StridedSliceProgram","TextureManager","numUsedTextures","numFreeTextures","freeTextures","logEnabled","usedTextures","acquireTexture","getPhysicalFromLogicalTextureType","getKeyFromTextureShape","shift","releaseTexture","splice","getNumUsedTextures","getNumFreeTextures","TileProgram","getSourceCoords$1","TransposeProgram","getSwitchedCoords","ERF_P","ERF_A1","ERF_A2","ERF_A3","ERF_A4","ERF_A5","SELU_SCALEALPHA","SELU_SCALE","UnaryOpProgram","CHECK_NAN_SNIPPET$1","ABS","RELU","ELU","SELU","STEP","NEG","CEIL","FLOOR","SIGN","ROUND","EXP","EXPM1","LOG","LOG1P","SQRT","RSQRT","SIGMOID","SOFTPLUS","SIN","COS","TAN","ASIN","ACOS","ATAN","SINH","COSH","TANH","ASINH","ACOSH","ATANH","ERF","SQUARE","RECIPROCAL","LOGICAL_NOT","TO_INT","concat1d_","concat2d_","concat3d_","concat4d_","concat_","concat2Tensors","b","concat1d","concat2d","concat3d","concat4d","createCommonjsModule","exports","alea","s0","s1","s2","charCodeAt","state","double","quick","xor128","z","w","xorwow","xorshift7","Date","xor4096","X","tychei","seedrandom","entropy","randomBytes","crypto","msCrypto","getRandomValues","plugins","screen","j","S","T","pass","global","fromCharCode","require","seedrandom$1","seedrandom_1","MPRandGauss","stdDev","nextVal","truncated","upper","lower","nextValue","isValidTruncated","convertValue","clone_","$x","eye_","randomNormal_","truncatedNormal_","randomUniform_","rand_","multinomial_","multinomial","logits2D","oneHot_","oneHot","$indices","fromPixels_","toPixels","Uint8ClampedArray","ImageData","putImageData","reshape_","squeeze_","cast_","tile_","pad1d_","pad2d_","pad3d_","pad4d_","pad_","stack_","batchToSpaceND_","reduce","spaceToBatchND_","unstack_","split_","cumsum_","permutedX","expandDims_","eye","pad1d","pad2d","pad3d","pad4d","rand","randomNormal","randomUniform","truncatedNormal","whereImpl","BEFORE_PAGING_CONSTANT","SIZE_UPLOAD_UNIFORM","MathBackendWebGL","delayedStorage","pendingRead","pendingDisposal","WeakSet","lruDataGPU","numBytesInGPU","uploadWaitMs","downloadWaitMs","binaryCache","gpgpuCreatedLocally","NUM_BYTES_BEFORE_PAGING","devicePixelRatio","textureManager","usage","HTMLVideoElement","HTMLImageElement","HTMLCanvasElement","fromPixelsCanvas","readyState","drawImage","getTexture","compileAndRun","throwIfNoData","uploadToGPU","cacheOnCPU","activeTimers","getValuesFromTexture","WebGLTexture","programTimersStack","unreliable","startTimer","startMs","endMs","endTimer","getGPGPUContext","getCanvas","stridedSlice","multiply","makeOutputArray","localResponseNormalization4D","LRNGrad","argReduce","segOpCompute","select","topk","realDivide","addN","subtract","eluDer","clip","atan2","conv2dDerInput","conv2dDerFilter","depthwiseConv2DDerInput","depthwiseConv2DDerFilter","maxPoolBackprop","avgPoolBackprop","resizeBilinearBackprop","resizeNearestNeighborBackprop","nonMaxSuppression","getAndSaveBinary","computeBytes","getTextureManager","remove","typedArrayToFloat32","float32ToTypedArray","neg_","ceil_","floor_","sign_","round_","exp_","expm1_","log_","log1p_","sqrt_","rsqrt_","square_","reciprocal_","abs_","clipByValue_","sigmoid_","logSigmoid_","softplus_","sin_","cos_","tan_","asin_","acos_","atan_","sinh_","cosh_","tanh_","asinh_","acosh_","atanh_","erf_","PI","step_","log$1","tanh$1","batchNormalization2d_","batchNormalization3d_","batchNormalization4d_","batchNormalization_","batchnormReshape4D","$mean","$variance","$scale","$offset","batchNormalization2d","batchNormalization3d","batchNormalization4d","computePool2DInfo","parseTupleParam","computeConv2DInfo","E","getPadAndOutInfo","getEffectiveFilterSize","_","A","R","dataFormat","computeOutputShape3D","computeDefaultPad","conditionalRound","bottom","right","conv1d_","eitherStridesOrDilationsAreOne","conv2d_","$filter","tupleValuesAreOne","conv2dDerInput_","conv2dDerFilter_","dy4D","x4D","conv2dTranspose_","depthwiseConv2d_","depthwiseConv2dDerInput","depthwiseConv2dDerFilter","separableConv2d_","parseTupleParam$1","separableConv2d","matMul_","$a","$b","outerProduct_","dot_","outerProduct","reverse1d_","reverse2d_","reverse3d_","reverse4d_","reverse_","reverse1d","reverse2d","reverse3d","reverse4d","maxPool_","avgPool_","$dy","$input","input4D","slice1d_","slice2d_","slice3d_","slice4d_","slice_","slice1d","slice2d","slice3d","slice4d","logSumExp_","sum_","mean_","min_","max_","argMin_","argMax_","all_","any_","moments_","variance","moments","notEqual_","notEqualStrict_","less_","lessStrict_","equal_","equalStrict_","lessEqual_","lessEqualStrict_","greater_","greaterStrict_","greaterEqual_","greaterEqualStrict_","add_","addN_","addStrict_","sub_","subStrict_","pow_","$base","$exp","powStrict_","mul_","mulStrict_","div_","floorDiv_","divStrict_","mod_","modStrict_","minimum_","minimumStrict_","maximum_","maximumStrict_","squaredDifference_","squaredDifferenceStrict_","atan2_","logicalNot_","logicalAnd_","logicalOr_","logicalXor_","where_","$condition","whereAsync_","whereAsync","relu_","elu_","dy","selu_","leakyRelu_","prelu_","transpose_","localResponseNormalization_","norm_","normImpl","unsortedSegmentSum_","gatherDropNegatives","gather_","arrayRange","arrayConcat","multiRNNCell_","basicLSTMCell_","basicLSTMCell","multiRNNCell","movingAverage_","movingAverage","stridedSlice_","topk_","indices","computeWeightedLoss_","Reduction","SUM_BY_NONZERO_WEIGHTS","NONE","SUM","MEAN","absoluteDifference_","computeWeightedLoss","meanSquaredError_","cosineDistance_","hingeLoss_","logLoss_","sigmoidCrossEntropyWithLogits_","sigmoidCrossEntropy_","huberLoss_","softmaxCrossEntropyWithLogits_","softmaxCrossEntropy_","absoluteDifference","cosineDistance","hingeLoss","huberLoss","logLoss","meanSquaredError","sigmoidCrossEntropy","softmaxCrossEntropy","loss_ops","gramSchmidt_","qr_","qr2d","gramSchmidt","qr","linalg_ops","resizeBilinear_","batchImages","resizeNearestNeighbor_","nonMaxSuppression_","NEGATIVE_INFINITY","nonMaxSuppSanityCheck","maxOutputSize","iouThreshold","scoreThreshold","$boxes","nonMaxSuppressionAsync_","nonMaxSuppressionAsync","image_ops","linalg","losses","MathBackendCPU","firstUse","getImageData","broadcastedBinaryOp","C","N","k","I","D","M","O","F","P","L","B","U","V","G","H","W","q","$","K","trunc","pool","POSITIVE_INFINITY","maxPoolPositions","delayCallback","requestAnimationFrame","setImmediate","nextFrame","DTYPE_VALUE_SIZE_MAP","uint16","uint8","encodeWeights","concatenateTypedArrays","specs","decodeWeights","quantization","byteLength","useNodeBuffer","Buffer","Blob","atob","btoa","stringByteLength","arrayBufferToBase64String","base64StringToArrayBuffer","byteOffset","concatenateArrayBuffers","basename","trim","getModelArtifactsInfoForJSON","modelTopology","ArrayBuffer","dateSaved","modelTopologyType","modelTopologyBytes","weightSpecsBytes","weightSpecs","weightDataBytes","weightData","IORouterRegistry","saveRouters","loadRouters","getInstance","instance","registerSaveRouter","registerLoadRouter","getSaveHandlers","getHandlers","getLoadHandlers","URL_SCHEME_SUFFIX","ModelStoreManagerRegistry","managers","registerManager","getManager","getSchemes","parseURL","scheme","path","cloneModelInternal","load","removeModel","save","modelArtifactsInfo","listModels","copyModel","moveModel","DATABASE_NAME","DATABASE_VERSION","MODEL_STORE_NAME","INFO_STORE_NAME","getIndexedDBFactory","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","shimIndexedDB","setUpDatabase","result","createObjectStore","keyPath","BrowserIndexedDB","modelPath","databaseAction","open","onupgradeneeded","onsuccess","transaction","objectStore","close","modelArtifacts","onerror","oncomplete","put","URL_SCHEME","indexedDBRouter","startsWith","browserIndexedDB","maybeStripScheme","BrowserIndexedDBManager","getAll","PATH_SEPARATOR","PATH_PREFIX","INFO_SUFFIX","MODEL_TOPOLOGY_SUFFIX","WEIGHT_SPECS_SUFFIX","WEIGHT_DATA_SUFFIX","getModelKeys","info","topology","getModelPathFromKey","maybeStripScheme$1","BrowserLocalStorage","localStorage","LS","setItem","removeItem","getItem","localStorageRouter","browserLocalStorage","BrowserLocalStorageManager","key","DEFAULT_FILE_NAME_PREFIX","DEFAULT_JSON_EXTENSION_NAME","DEFAULT_WEIGHT_DATA_EXTENSION_NAME","BrowserDownloads","modelTopologyFileName","weightDataFileName","URL","createObjectURL","paths","weights","weightsManifest","jsonAnchor","download","href","click","weightDataAnchor","BrowserFiles","files","FileReader","onload","target","checkManifestAndWeightFiles","readAsArrayBuffer","readAsText","browserDownloadsRouter","browserDownloads","browserFiles","loadWeightsAsArrayBuffer","fetch","arrayBuffer","loadWeights","manifestEntry","groupOffset","sizeBytes","scale","BrowserHTTPRequest","DEFAULT_METHOD","body","requestInit","method","FormData","append","status","responses","json","lastIndexOf","URL_SCHEMES","httpRequestRouter","browserHTTPRequest","PassthroughLoader","PassthroughSaver","saveHandler","fromMemory","withSaveHandler","io","Serializable","getClassName","className","fromConfig","SerializationMap","classNameMap","getMap","serialization","WEBGL_ENVS","HAS_WEBGL","NODE_ENVS","IS_NODE","CHROME_ENVS","IS_CHROME","BROWSER_ENVS","IS_BROWSER","CPU_ENVS","ALL_ENVS","expectArraysClose","areClose","expectPromiseToFail","fail","expectArraysEqual","expectNumbersClose","expectValuesInRange","expectArrayBuffersEqual","toEqual","test_util","version","webgl","Optimizer","minimize","computeGradients","applyGradients","DEFAULT_FLOAT32_EPSILON","DEFAULT_FLOAT16_EPSILON","getOptimizerDefaultEpsilonValue","AdadeltaOptimizer","learningRate","rho","epsilon","accumulatedGrads","accumulatedUpdates","rhoScalar","oneMinusRho","epsilonScalar","getConfig","AdagradOptimizer","initialAccumulatorValue","AdamOptimizer","beta1","beta2","accumulatedFirstMoment","accumulatedSecondMoment","beta1Scalar","beta2Scalar","accBeta1","accBeta2","oneMinusBeta1","oneMinusBeta2","one","epsScalar","AdamaxOptimizer","decay","accumulatedWeightedInfNorm","decayScalar","iteration","SGDOptimizer","setLearningRate","MomentumOptimizer","momentum","useNesterov","accumulations","setMomentum","RMSPropOptimizer","accumulatedMeanSquares","accumulatedMeanGrads","accumulatedMoments","momentumScalar","oneMinusDecay","centered","OptimizerConstructors","sgd","rmsprop","adam","adadelta","adamax","adagrad","train","_epsilon","imageDataFormat","_nextUniqueTensorId","getNextUniqueTensorId","_uidPrefixes","getUid","scalarCache","DEFAULT_DTYPE","getScalar","AttributeError","RuntimeError","ValueError","NotImplementedError","AssertionError","IndexError","pyListRepeat","count","singletonOrArray","toList","toSnakeCase","toLowerCase","toCamelCase","_GLOBAL_CUSTOM_OBJECTS","serializeKerasObject","config","deserializeKerasObject","customObjects","numberCompare","reverseNumberCompare","stringToDType","unique","isObjectEmpty","checkStringTypeUnionValue","checkArrayTypeAndLength","calcL2Norms","Constraint","MaxNorm","defaultMaxValue","defaultAxis","maxValue","axis","UnitNorm","NonNeg","MinMaxNorm","defaultMinValue","defaultRate","minValue","rate","CONSTRAINT_IDENTIFIER_REGISTRY_SYMBOL_MAP","maxNorm","minMaxNorm","nonNeg","unitNorm","serializeConstraint","deserializeConstraint","getConstraint","exports_constraints","nameMap","Map","VALID_DATA_FORMAT_VALUES","checkDataFormat","VALID_PADDING_MODE_VALUES","checkPaddingMode","VALID_POOL_MODE_VALUES","checkPoolMode","_nameScopeStack","_nameScopeDivider","nameScope","currentNameScopePrefix","getScopedTensorName","isValidTensorName","getUniqueTensorName","tensorNameRegex","RegExp","match","isInteger","parseInt","arrayProd","toArray1D","min$1","max$1","cast$1","tile$1","batchFlatten","sliceAlongFirstAxis","sliceAlongLastAxis","sliceAlongAxis","concatenate","concatAlongFirstAxis","randomNormal$1","gather$1","biasAdd","elu$1","softsign","dropout","hardSigmoid","inTrainPhase","VALID_FAN_MODE_VALUES","checkFanMode","VALID_DISTRIBUTION_VALUES","checkDistribution","Initializer","fromConfigUsesCustomObjects","Zeros","Ones","Constant","RandomUniform","DEFAULT_MINVAL","DEFAULT_MAXVAL","minval","maxval","seed","RandomNormal","DEFAULT_MEAN","DEFAULT_STDDEV","stddev","TruncatedNormal","Identity","gain","computeFans","VarianceScaling","mode","distribution","GlorotUniform","GlorotNormal","HeNormal","LeCunNormal","Orthogonal","DEFAULT_GAIN","INITIALIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","constant","glorotNormal","glorotUniform","heNormal","identity","leCunNormal","orthogonal","varianceScaling","deserializeInitializer","serializeInitializer","getInitializer","zeros$1","randomUniform$1","randomNormal$2","truncatedNormal$1","exports_initializers","isArrayOfShapes","normalizeShapeList","getExactlyOneTensor","getExactlyOneShape","countParamsInWeights","DEFAULT_VARIABLE_NAME_PREFIX","LayerVariable","originalName","constraint","val","checkShapesMatch","batchGetValue","batchSetValue","InputSpec","ndim","maxNDim","minNDim","axes","SymbolicTensor","sourceLayer","callArgs","outputTensorIndex","_nextNodeID","Node","outboundLayer","inboundLayers","nodeIndices","tensorIndices","inputTensors","outputTensors","inputMasks","outputMasks","inputShapes","outputShapes","outboundNodes","inboundNodes","_nextLayerID","Layer","_callHook","_addedWeightNames","_stateful","activityRegularizer","inputSpec","supportsMasking","_trainableWeights","_nonTrainableWeights","_losses","_updates","_built","updatable","inputShape","batchInputShape","inputDType","initialWeights","nodeKey","getNodeAtIndex","getInputAt","getOutputAt","calculateLosses","trainableWeights","nonTrainableWeights","assertInputCompatibility","invokeCallHook","setCallHook","clearCallHook","built","build","setWeights","collectInputShape","computeOutputShape","guessOutputDType","warnOnIncompatibleInputShape","addInboundNode","countParams","getWeights","addWeight","addLoss","computeMask","nodeIndex","tensorIndex","getSourceInputs","InputLayer","sparse","Input","batchShape","resolveScalarsInLogs","disposeTensorsInLogs","BaseCallback","validationData","setParams","params","onEpochBegin","onEpochEnd","onBatchBegin","onBatchEnd","onTrainBegin","onTrainEnd","setModel","CallbackList","callbacks","queueLength","BaseLogger","seen","totals","metrics","History","epoch","history","syncData","CustomCallback","trainBegin","trainEnd","epochBegin","epochEnd","batchBegin","batchEnd","standardizeCallbacks","l2Normalize","meanAbsoluteError","meanAbsolutePercentageError","MAX_VALUE","meanSquaredLogarithmicError","squaredHinge","hinge","categoricalHinge","logcosh","categoricalCrossentropy","sparseCategoricalCrossentropy","sigmoidCrossEntropyWithLogits","binaryCrossentropy","kullbackLeiblerDivergence","poisson","cosineProximity","binaryAccuracy","categoricalAccuracy","binaryCrossentropy$1","sparseCategoricalAccuracy","mse$1","MSE$1","mae$1","MAE$1","mape$1","MAPE$1","categoricalCrossentropy$1","cosine$1","sparseCategoricalCrossentropy$1","get$1","mse","MSE","mae","MAE","mape","MAPE","cosine","getOptimizer","Adagrad","Adadelta","Adam","Adamax","RMSProp","SGD","printSummary","isModelSequentialLike","nodesByDepth","printRow","layers","printLayerSummary","printLayerSummaryWithConnections","checkTrainableWeightsConsistency","collectedTrainableWeights","deserialize","isArrayItemInputOrOutputName","convertPythonicToTs","convertTsToPythonic","preprocessWeightsForLoading","loadTensor","loadWeightsFromJson","keras_version","loadWeightsFromNamedTensorMap","Container","containerNodes","outputs","inputLayers","inputLayersNodeIndices","inputLayersTensorIndices","outputLayers","outputLayersNodeIndices","outputLayersTensorIndices","inputNames","outputNames","feedInputShapes","feedInputNames","feedOutputNames","internalInputShapes","internalOutputShapes","layersByDepth","J","Z","Y","Q","ee","te","ne","re","ie","updatedConfig","kerasVersion","toJSON","mask","runInternalGraph","buildNodeConversionMap","getLayer","stateful","assertFeedCompatibility","ModelLoggingVerbosity","FeedDict","id2Value","addFeed","hasKey","getValue","execute","executeInternal","getNodeOutputs","isDataTensor","isDataArray","isDataDict","standardizeInputData","checkArrayLengths","checkLossAndTargetCompatibility","makeBatches","sliceArrays","sliceArraysByIndices","checkInputData","collectMetrics","SILENT","VERBOSE","Model","summary","compile","loss","optimizer","lossFunctions","feedOutputShapes","feedLossFns","metricsNames","metricsTensors","evaluate","standardizeUserData","makeTestFunction","testFunction","testLoop","verbose","steps","checkNumSamples","retrieveSymbolicTensors","predictLoop","predict","predictOnBatch","fitLoop","epochs","initialEpoch","doValidation","stopTraining","batch","getDedupedMetricsNames","fit","validationSplit","validationSteps","training","getNamedWeights","trainableOnly","loadModelInternal","loadModelFromIOHandler","model_config","Sequential","_updatable","model","sequential","loadModel","input","Activation","Elu","Selu","Relu","Relu6","Linear","Sigmoid","HardSigmoid","Softplus","Softsign","Tanh","Softmax","serializeActivation","deserializeActivation","getActivation","LeakyReLU","DEFAULT_ALPHA","ThresholdedReLU","DEFAULT_THETA","theta","thetaTensor","Softmax$1","DEFAULT_AXIS","Regularizer","L1L2","l1","l2","hasL1","hasL2","REGULARIZER_IDENTIFIER_REGISTRY_SYMBOL_MAP","l1l2","serializeRegularizer","deserializeRegularizer","getRegularizer","normalizeArray","convOutputLength","deconvLength","preprocessConv2DInput","conv1dWithBias","conv2dWithBias","BaseConv","DEFAULT_KERNEL_INITIALIZER","DEFAULT_BIAS_INITIALIZER","verifyConfig","kernelSize","padding","activation","useBias","biasInitializer","biasConstraint","biasRegularizer","dilationRate","Conv","kernel","filters","kernelInitializer","kernelConstraint","kernelRegularizer","Conv2D","Conv2DTranspose","SeparableConv","DEFAULT_DEPTHWISE_INITIALIZER","DEFAULT_POINTWISE_INITIALIZER","depthwiseKernel","pointwiseKernel","depthMultiplier","depthwiseInitializer","depthwiseRegularizer","depthwiseConstraint","pointwiseInitializer","pointwiseRegularizer","pointwiseConstraint","SeparableConv2D","Conv1D","Cropping2D","cropping","UpSampling2D","DEFAULT_SIZE","depthwiseConv2d$1","DepthwiseConv2D","Dropout","rateScalar","noiseShape","getNoiseShape","Dense","inputDim","units","Flatten","Activation$1","RepeatVector","Reshape","targetShape","isUnknown","fixUnknownDimension","Embedding","embeddings","DEFAULT_EMBEDDINGS_INITIALIZER","inputLength","outputDim","embeddingsInitializer","embeddingsRegularizer","embeddingsConstraint","maskZero","Merge","mergeFunction","computeElementwiseOpOutputShape","reshapeRequired","Add","Multiply","Average","Maximum","Minimum","Concatenate","regularNormalizeBatchInTraining","broadcastNormalizeBatchInTraining","normalizeBatchInTraining","BatchNormalization","center","betaInitializer","gammaInitializer","movingMeanInitializer","movingVarianceInitializer","betaConstraint","gammaConstraint","betaRegularizer","gammaRegularizer","stepCount","gamma","movingMean","movingVariance","spatial2dPadding","ZeroPadding2D","pool2d","Pooling1D","poolSize","poolingFunction","MaxPooling1D","AveragePooling1D","Pooling2D","MaxPooling2D","AveragePooling2D","GlobalPooling1D","GlobalAveragePooling1D","GlobalMaxPooling1D","GlobalPooling2D","GlobalAveragePooling2D","GlobalMaxPooling2D","standardizeArgs","initialState","constants","rnn","RNN","cell","StackedRNNCells","cells","stateSize","returnSequences","returnState","goBackwards","unroll","stateSpec","states","numConstants","getStates","setStates","resetStates","getInitialState","RNNCell","SimpleRNNCell","DEFAULT_ACTIVATION","DEFAULT_RECURRENT_INITIALIZER","recurrentInitializer","recurrentRegularizer","recurrentConstraint","recurrentDropout","dropoutMask","recurrentDropoutMask","recurrentKernel","generateDropoutMask","SimpleRNN","GRUCell","DEFAULT_RECURRENT_ACTIVATION","recurrentActivation","implementation","GRU","implmentation","LSTMCell","unitForgetBias","LSTM","Wrapper","layer","TimeDistributed","VALID_BIDIRECTIONAL_MERGE_MODES","checkBidirectionalMergeMode","Bidirectional","forwardLayer","backwardLayer","mergeMode","_trainable","inputLayer","elu$2","leakyReLU","softmax$1","thresholdedReLU","conv1d$2","conv2d$2","conv2dTranspose$1","separableConv2d$1","cropping2D","upSampling2d","depthwiseConv2d$2","dense","dropout$1","flatten$1","repeatVector","embedding","add$2","average$1","concatenate$2","maximum$2","minimum$2","multiply$1","batchNormalization$1","zeroPadding2d","averagePooling1d","avgPool1d","avgPooling1d","averagePooling2d","avgPool2d","avgPooling2d","globalAveragePooling1d","globalAveragePooling2d","globalMaxPooling1d","globalMaxPooling2d","maxPooling1d","maxPooling2d","gru","gruCell","lstm","lstmCell","simpleRNN","simpleRNNCell","rnn$1","stackedRNNCells","bidirectional","timeDistributed","globalMaxPool1d","globalMaxPool2d","maxPool1d","maxPool2d","exports_layers","average","binaryAccuracy$1","binaryCrossentropy$2","categoricalAccuracy$1","categoricalCrossentropy$2","cosineProximity$1","meanAbsoluteError$1","meanAbsolutePercentageError$1","MAPE$2","mape$2","meanSquaredError$1","MSE$2","mse$2","exports_metrics","l1$1","l2$1","exports_regularizers","Callback","commonjsGlobal","self","punycode","nodeType","overflow","not-basic","invalid-input","RangeError","ucs2","decode","encode","toASCII","toUnicode","util$1","isString","isObject","isNull","isNullOrUndefined","maxKeys","stringifyPrimitive","isFinite","encodeURIComponent","querystring","querystring_1","querystring_2","querystring_3","querystring_4","urlParse","format","urlFormat","Url","protocol","slashes","auth","host","port","hostname","hash","pathname","protocolPattern","portPattern","simplePathPattern","delims","unwise","autoEscape","nonHostChars","hostEndingChars","hostnameMaxLen","hostnamePartPattern","hostnamePartStart","unsafeProtocol","javascript","javascript:","hostlessProtocol","slashedProtocol","http","https","ftp","gopher","file","http:","https:","ftp:","gopher:","file:","parseHost","escape","resolve","resolveObject","aspromise","asPromise","base64_1","eventemitter","EventEmitter","_listeners","on","fn","ctx","off","emit","float_1","factory","writeFloatLE","writeFloatBE","readFloatLE","readFloatBE","LN2","bind","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","writeDoubleLE","writeDoubleBE","readDoubleLE","readDoubleBE","inquire_1","inquire","moduleName","mod$$1","eval","utf8_1","pool_1","longbits","LongBits","lo","hi","zero","toNumber","zzEncode","zzDecode","zeroHash","fromNumber","minimal","Long","fromString","low","high","toLong","Boolean","unsigned","fromHash","toHash","captureStackTrace","base64","float","utf8","emptyArray","emptyObject","isNode","isset","isSet","utf8Write","_Buffer_from","_Buffer_allocUnsafe","newBuffer","dcodeIO","key2Re","key32Re","key64Re","longToHash","longFromHash","fromBits","merge","lcFirst","newError","ProtocolError","oneOfGetter","oneOfSetter","toJSONOptions","longs","enums","bytes","_configure","allocUnsafe","writer","Writer","BufferWriter","LongBits$1","Op","len","noop","State","head","tail","writeByte","writeVarint32","VarintOp","writeVarint64","writeFixed32","alloc","_push","uint32","sint32","uint64","int64","sint64","fixed32","sfixed32","fixed64","sfixed64","writeBytes","string","fork","ldelim","writer_buffer","BufferWriter$1","writeBytesBuffer","copy","writeStringBuffer","reader","Reader","BufferReader","LongBits$2","utf8$1","indexOutOfRange","pos","buf","create_array","readLongVarint","readFixed32_end","readFixed64","isBuffer","_slice","skip","skipType","reader_buffer","BufferReader$1","utf8Slice","service","Service","rpcImpl","requestDelimited","responseDelimited","rpcCall","end","rpc_1","roots","indexMinimal","rpc","configure","minimal$1","minimal_1","minimal_2","minimal_3","$Reader","$util","$root","default","tensorflow","Any","typeUrl","DataType","TensorShape","dim","unknownRank","Dim","floatVal","doubleVal","intVal","stringVal","scomplexVal","int64Val","boolVal","uint32Val","uint64Val","tensorShape","versionNumber","tensorContent","AttrValue","list","placeholder","func","ListValue","NameAttrList","attr","NodeDef","device","VersionDef","badConsumers","producer","minConsumer","GraphDef","library","FunctionDefLibrary","CollectionDef","nodeList","bytesList","int64List","floatList","anyList","NodeList","BytesList","Int64List","FloatList","AnyList","SaverDef","filenameTensorName","saveTensorName","restoreOpName","maxToKeep","sharded","keepCheckpointEveryNHours","CheckpointFormatVersion","TensorInfo","cooSparse","CooSparse","valuesTensorName","indicesTensorName","denseShapeTensorName","SignatureDef","methodName","AssetFileDef","tensorInfo","filename","OpDef","inputArg","outputArg","deprecation","description","isCommutative","isAggregate","isStateful","allowsUninitializedInput","ArgDef","AttrDef","OpDeprecation","typeAttr","numberAttr","typeListAttr","isRef","defaultValue","hasMinimum","allowedValues","explanation","OpList","MetaGraphDef","collectionDef","signatureDef","assetFileDef","metaInfoDef","graphDef","saverDef","MetaInfoDef","tags","metaGraphVersion","strippedOpList","anyInfo","tensorflowVersion","tensorflowGitVersion","SavedModel","metaGraphs","savedModelSchemaVersion","function","FunctionDef","GradientDef","nodeDef","ret","signature","functionName","gradientFunc","compiled_api","compiled_api_1","getParamValue","inputIndex","getTensor","inputParamLength","parseNodeName","currentContextIds","find","getNodeNameWithContextId","getNodeNameAndIndex","currentContextId","split$1","arithmetic","tfOpName","dlOpName","category","tfInputIndex","dlParamName","tfParamName","notSupported","arithmetic$1","basic_math","basicMath","control","tfInputParamLength","control$1","convolution","convolution$1","creation","creation$1","dynamic","dynamic$1","evaluation","evaluation$1","graph","notSupprted","graph$1","image$1","image$2","logical","logical$1","matrices","matrices$1","normalization","normalization$1","reduction","reduction$1","slice_join","sliceJoin","transformation","tfParamNameDeprecated","transformation$1","CONTROL_FLOW_OPS","DYNAMIC_SHAPE_OPS","OperationMapper","opMappers","_instance","isControlFlow","isDynamicShape","transformGraph","mapNode","children","nodes","placeholders","withControlFlow","withDynamicShape","getStringParam","getNumberParam","getNumericArrayParam","getBoolParam","getTensorShapeParam","getDtypeParam","DT_FLOAT","DT_INT32","DT_BOOL","executeOp","executeOp$1","TensorArray","maxSize","elementShape","identicalElementShapes","dynamicSize","clearAfterRead","tensors","closed_","clearAndClose","cleared","readMany","written","writeMany","scatter","executeOp$2","enterFrame","exitFrame","nextIteration","addTensorArray","getTensorArray","executeOp$3","executeOp$4","_this","executeOp$5","executeOp$6","executeOp$7","executeOp$8","executeOp$9","executeOp$10","executeOp$11","executeOp$12","executeOp$13","executeOp$14","executeOp$15","ExecutionContext","weightMap","tensorArrayMap","rootContext","frameName","iterationId","contexts","lastId","generateCurrentContextIds","newFrame","_currentContextIds","contextIdforContexts","getWeight","GraphExecutor","compiledOrder","_weightMap","_outputs","weightIds","checkInput","checkInputShapeAndType","findOutputs","executeAsync","executeWithControlFlow","currentContext","inputNodes","FrozenModel","modelUrl","weightManifestUrl","requestOption","pathPrefix","getPathPrefix","executor","outputNodes","loadRemoteProtoFile","loadWeightManifest","weightManifest","Instance","convertTensorMapToTensorsMap","constructTensorMap","isControlFlowModel","isDynamicShapeModel","loadFrozenModel","version_core","version_layers","version_converter","version_union"],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/version.d.ts b/node_modules/@tensorflow/tfjs/dist/version.d.ts new file mode 100644 index 0000000..617cee3 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/version.d.ts @@ -0,0 +1,2 @@ +declare const version = "0.12.4"; +export { version }; diff --git a/node_modules/@tensorflow/tfjs/dist/version.js b/node_modules/@tensorflow/tfjs/dist/version.js new file mode 100644 index 0000000..fb2497a --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/version.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var version = '0.12.4'; +exports.version = version; +//# sourceMappingURL=version.js.map \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/dist/version.js.map b/node_modules/@tensorflow/tfjs/dist/version.js.map new file mode 100644 index 0000000..71e4f86 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/dist/version.js.map @@ -0,0 +1 @@ +{"version":3,"file":"version.js","sourceRoot":"","sources":["../src/version.ts"],"names":[],"mappings":";;AAGA,IAAM,OAAO,GAAG,QAAQ,CAAC;AACjB,0BAAO"} \ No newline at end of file diff --git a/node_modules/@tensorflow/tfjs/package.json b/node_modules/@tensorflow/tfjs/package.json new file mode 100644 index 0000000..46c9873 --- /dev/null +++ b/node_modules/@tensorflow/tfjs/package.json @@ -0,0 +1,96 @@ +{ + "_from": "@tensorflow/tfjs", + "_id": "@tensorflow/tfjs@0.12.4", + "_inBundle": false, + "_integrity": "sha512-K/UZ0QyRqs36HWJcrddYz0AGpFtTJgWoIwUjG5041CixoEb3uyKS4ejEjECRdPy6TPFpjnIyYuO4hZMc3ny/Vg==", + "_location": "/@tensorflow/tfjs", + "_phantomChildren": {}, + "_requested": { + "type": "tag", + "registry": true, + "raw": "@tensorflow/tfjs", + "name": "@tensorflow/tfjs", + "escapedName": "@tensorflow%2ftfjs", + "scope": "@tensorflow", + "rawSpec": "", + "saveSpec": null, + "fetchSpec": "latest" + }, + "_requiredBy": [ + "#USER", + "/" + ], + "_resolved": "https://registry.npmjs.org/@tensorflow/tfjs/-/tfjs-0.12.4.tgz", + "_shasum": "dbdcd0389eb68a0974b2b52472ff97e21e664017", + "_spec": "@tensorflow/tfjs", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot", + "bugs": { + "url": "https://github.com/tensorflow/tfjs/issues" + }, + "bundleDependencies": false, + "dependencies": { + "@tensorflow/tfjs-converter": "0.5.5", + "@tensorflow/tfjs-core": "0.12.8", + "@tensorflow/tfjs-layers": "0.7.2" + }, + "deprecated": false, + "description": "An open-source machine learning framework.", + "devDependencies": { + "@octokit/rest": "15.2.6", + "@types/jasmine": "~2.8.6", + "@types/node": "~9.6.1", + "babel-core": "~6.26.3", + "babel-plugin-external-helpers": "~6.22.0", + "babel-preset-env": "~1.7.0", + "clang-format": "~1.2.2", + "commander": "~2.14.1", + "jasmine": "3.1.0", + "jasmine-core": "~3.1.0", + "karma": "~2.0.0", + "karma-browserstack-launcher": "~1.3.0", + "karma-chrome-launcher": "~2.2.0", + "karma-firefox-launcher": "~1.1.0", + "karma-jasmine": "~1.1.1", + "karma-typescript": "~3.0.12", + "mkdirp": "~0.5.1", + "nodemon": "1.17.3", + "rimraf": "~2.6.2", + "rollup": "~0.58.2", + "rollup-plugin-babel": "~3.0.4", + "rollup-plugin-commonjs": "9.1.3", + "rollup-plugin-json": "~3.0.0", + "rollup-plugin-node-resolve": "3.3.0", + "rollup-plugin-typescript2": "0.13.0", + "rollup-plugin-uglify": "~3.0.0", + "shelljs": "~0.8.1", + "ts-node": "~4.1.0", + "tslint": "~5.9.1", + "typescript": "2.7.2", + "yalc": "~1.0.0-pre.21" + }, + "homepage": "https://github.com/tensorflow/tfjs#readme", + "jsdelivr": "dist/tf.min.js", + "jsnext:main": "dist/tf.esm.js", + "license": "Apache-2.0", + "main": "dist/index", + "module": "dist/tf.esm.js", + "name": "@tensorflow/tfjs", + "private": false, + "repository": { + "type": "git", + "url": "git+https://github.com/tensorflow/tfjs.git" + }, + "scripts": { + "build": "tsc", + "build-npm": "./scripts/build-npm.sh", + "link-local": "yalc link", + "lint": "tslint -p . -t verbose", + "publish-local": "yarn build-npm && yalc push", + "release-notes": "ts-node ./scripts/release_notes/release_notes.ts", + "test": "ts-node ./scripts/release_notes/run_tests.ts && karma start", + "test-travis": "ts-node ./scripts/release_notes/run_tests.ts && karma start --browsers='bs_firefox_mac,bs_chrome_mac' --singleRun" + }, + "types": "dist/index.d.ts", + "unpkg": "dist/tf.min.js", + "version": "0.12.4" +} diff --git a/node_modules/@tensorflow/tfjs/yalc.lock b/node_modules/@tensorflow/tfjs/yalc.lock new file mode 100644 index 0000000..21b9ada --- /dev/null +++ b/node_modules/@tensorflow/tfjs/yalc.lock @@ -0,0 +1,4 @@ +{ + "version": "v1", + "packages": {} +} \ No newline at end of file diff --git a/node_modules/@types/long/LICENSE b/node_modules/@types/long/LICENSE new file mode 100644 index 0000000..2107107 --- /dev/null +++ b/node_modules/@types/long/LICENSE @@ -0,0 +1,21 @@ + MIT License + + Copyright (c) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE diff --git a/node_modules/@types/long/README.md b/node_modules/@types/long/README.md new file mode 100644 index 0000000..28c1a1d --- /dev/null +++ b/node_modules/@types/long/README.md @@ -0,0 +1,16 @@ +# Installation +> `npm install --save @types/long` + +# Summary +This package contains type definitions for long.js (https://github.com/dcodeIO/long.js). + +# Details +Files were exported from https://www.github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/long + +Additional Details + * Last updated: Mon, 21 Aug 2017 21:55:03 GMT + * Dependencies: none + * Global values: Long + +# Credits +These definitions were written by Peter Kooijmans . diff --git a/node_modules/@types/long/index.d.ts b/node_modules/@types/long/index.d.ts new file mode 100644 index 0000000..3fbc027 --- /dev/null +++ b/node_modules/@types/long/index.d.ts @@ -0,0 +1,352 @@ +// Type definitions for long.js 3.0.2 +// Project: https://github.com/dcodeIO/long.js +// Definitions by: Peter Kooijmans +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped +// Definitions by: Denis Cappellin + +export = Long; +export as namespace Long; + +declare namespace Long {} +declare class Long +{ + /** + * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as signed integers. See the from* functions below for more convenient ways of constructing Longs. + */ + constructor( low: number, high?: number, unsigned?: boolean ); + + /** + * Maximum unsigned value. + */ + static MAX_UNSIGNED_VALUE: Long; + + /** + * Maximum signed value. + */ + static MAX_VALUE: Long; + + /** + * Minimum signed value. + */ + static MIN_VALUE: Long; + + /** + * Signed negative one. + */ + static NEG_ONE: Long; + + /** + * Signed one. + */ + static ONE: Long; + + /** + * Unsigned one. + */ + static UONE: Long; + + /** + * Unsigned zero. + */ + static UZERO: Long; + + /** + * Signed zero + */ + static ZERO: Long; + + /** + * The high 32 bits as a signed value. + */ + high: number; + + /** + * The low 32 bits as a signed value. + */ + low: number; + + /** + * Whether unsigned or not. + */ + unsigned: boolean; + + /** + * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is assumed to use 32 bits. + */ + static fromBits( lowBits:number, highBits:number, unsigned?:boolean ): Long; + + /** + * Returns a Long representing the given 32 bit integer value. + */ + static fromInt( value: number, unsigned?: boolean ): Long; + + /** + * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned. + */ + static fromNumber( value: number, unsigned?: boolean ): Long; + + /** + * Returns a Long representation of the given string, written using the specified radix. + */ + static fromString( str: string, unsigned?: boolean | number, radix?: number ): Long; + + /** + * Tests if the specified object is a Long. + */ + static isLong( obj: any ): boolean; + + /** + * Converts the specified value to a Long. + */ + static fromValue( val: Long | number | string | {low: number, high: number, unsigned: boolean} ): Long; + + /** + * Returns the sum of this and the specified Long. + */ + add( addend: number | Long | string ): Long; + + /** + * Returns the bitwise AND of this Long and the specified. + */ + and( other: Long | number | string ): Long; + + /** + * Compares this Long's value with the specified's. + */ + compare( other: Long | number | string ): number; + + /** + * Compares this Long's value with the specified's. + */ + comp( other: Long | number | string ): number; + + /** + * Returns this Long divided by the specified. + */ + divide( divisor: Long | number | string ): Long; + + /** + * Returns this Long divided by the specified. + */ + div( divisor: Long | number | string ): Long; + + /** + * Tests if this Long's value equals the specified's. + */ + equals( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value equals the specified's. + */ + eq( other: Long | number | string ): boolean; + + /** + * Gets the high 32 bits as a signed integer. + */ + getHighBits(): number; + + /** + * Gets the high 32 bits as an unsigned integer. + */ + getHighBitsUnsigned(): number; + + /** + * Gets the low 32 bits as a signed integer. + */ + getLowBits(): number; + + /** + * Gets the low 32 bits as an unsigned integer. + */ + getLowBitsUnsigned(): number; + + /** + * Gets the number of bits needed to represent the absolute value of this Long. + */ + getNumBitsAbs(): number; + + /** + * Tests if this Long's value is greater than the specified's. + */ + greaterThan( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than the specified's. + */ + gt( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than or equal the specified's. + */ + greaterThanOrEqual( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than or equal the specified's. + */ + gte( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is even. + */ + isEven(): boolean; + + /** + * Tests if this Long's value is negative. + */ + isNegative(): boolean; + + /** + * Tests if this Long's value is odd. + */ + isOdd(): boolean; + + /** + * Tests if this Long's value is positive. + */ + isPositive(): boolean; + + /** + * Tests if this Long's value equals zero. + */ + isZero(): boolean; + + /** + * Tests if this Long's value is less than the specified's. + */ + lessThan( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than the specified's. + */ + lt( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than or equal the specified's. + */ + lessThanOrEqual( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than or equal the specified's. + */ + lte( other: Long | number | string ): boolean; + + /** + * Returns this Long modulo the specified. + */ + modulo( other: Long | number | string ): Long; + + /** + * Returns this Long modulo the specified. + */ + mod( other: Long | number | string ): Long; + + /** + * Returns the product of this and the specified Long. + */ + multiply( multiplier: Long | number | string ): Long; + + /** + * Returns the product of this and the specified Long. + */ + mul( multiplier: Long | number | string ): Long; + + /** + * Negates this Long's value. + */ + negate(): Long; + + /** + * Negates this Long's value. + */ + neg(): Long; + + /** + * Returns the bitwise NOT of this Long. + */ + not(): Long; + + /** + * Tests if this Long's value differs from the specified's. + */ + notEquals( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value differs from the specified's. + */ + neq( other: Long | number | string ): boolean; + + /** + * Returns the bitwise OR of this Long and the specified. + */ + or( other: Long | number | string ): Long; + + /** + * Returns this Long with bits shifted to the left by the given amount. + */ + shiftLeft( numBits: number | Long ): Long; + + /** + * Returns this Long with bits shifted to the left by the given amount. + */ + shl( numBits: number | Long ): Long; + + /** + * Returns this Long with bits arithmetically shifted to the right by the given amount. + */ + shiftRight( numBits: number | Long ): Long; + + /** + * Returns this Long with bits arithmetically shifted to the right by the given amount. + */ + shr( numBits: number | Long ): Long; + + /** + * Returns this Long with bits logically shifted to the right by the given amount. + */ + shiftRightUnsigned( numBits: number | Long ): Long; + + /** + * Returns this Long with bits logically shifted to the right by the given amount. + */ + shru( numBits: number | Long ): Long; + + /** + * Returns the difference of this and the specified Long. + */ + subtract( subtrahend: number | Long | string ): Long; + + /** + * Returns the difference of this and the specified Long. + */ + sub( subtrahend: number | Long |string ): Long; + + /** + * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer. + */ + toInt(): number; + + /** + * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa). + */ + toNumber(): number; + + /** + * Converts this Long to signed. + */ + toSigned(): Long; + + /** + * Converts the Long to a string written in the specified radix. + */ + toString( radix?: number ): string; + + /** + * Converts this Long to unsigned. + */ + toUnsigned(): Long; + + /** + * Returns the bitwise XOR of this Long and the given one. + */ + xor( other: Long | number | string ): Long; +} diff --git a/node_modules/@types/long/package.json b/node_modules/@types/long/package.json new file mode 100644 index 0000000..8bf25df --- /dev/null +++ b/node_modules/@types/long/package.json @@ -0,0 +1,47 @@ +{ + "_from": "@types/long@~3.0.32", + "_id": "@types/long@3.0.32", + "_inBundle": false, + "_integrity": "sha512-ZXyOOm83p7X8p3s0IYM3VeueNmHpkk/yMlP8CLeOnEcu6hIwPH7YjZBvhQkR0ZFS2DqZAxKtJ/M5fcuv3OU5BA==", + "_location": "/@types/long", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/long@~3.0.32", + "name": "@types/long", + "escapedName": "@types%2flong", + "scope": "@types", + "rawSpec": "~3.0.32", + "saveSpec": null, + "fetchSpec": "~3.0.32" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-converter" + ], + "_resolved": "https://registry.npmjs.org/@types/long/-/long-3.0.32.tgz", + "_shasum": "f4e5af31e9e9b196d8e5fca8a5e2e20aa3d60b69", + "_spec": "@types/long@~3.0.32", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-converter", + "bundleDependencies": false, + "contributors": [ + { + "name": "Peter Kooijmans", + "url": "https://github.com/peterkooijmans" + } + ], + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for long.js", + "license": "MIT", + "main": "", + "name": "@types/long", + "repository": { + "type": "git", + "url": "https://www.github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typeScriptVersion": "2.0", + "typesPublisherContentHash": "26c346715f4bbe747a7eddec4134408618814ef4340646fcbac955fcdb491a4c", + "version": "3.0.32" +} diff --git a/node_modules/@types/seedrandom/README.md b/node_modules/@types/seedrandom/README.md new file mode 100644 index 0000000..a572b31 --- /dev/null +++ b/node_modules/@types/seedrandom/README.md @@ -0,0 +1,18 @@ +# Installation +> `npm install --save @types/seedrandom` + +# Summary +This package contains type definitions for seedrandom 2.4.2 (https://github.com/davidbau/seedrandom). + +# Details +Files were exported from https://www.github.com/DefinitelyTyped/DefinitelyTyped/tree/types-2.0/seedrandom + +Additional Details + * Last updated: Mon, 19 Sep 2016 17:28:59 GMT + * File structure: UMD + * Library Dependencies: none + * Module Dependencies: none + * Global values: seedrandom + +# Credits +These definitions were written by Kern Handa . diff --git a/node_modules/@types/seedrandom/index.d.ts b/node_modules/@types/seedrandom/index.d.ts new file mode 100644 index 0000000..4db5005 --- /dev/null +++ b/node_modules/@types/seedrandom/index.d.ts @@ -0,0 +1,45 @@ +// Type definitions for seedrandom 2.4.2 +// Project: https://github.com/davidbau/seedrandom +// Definitions by: Kern Handa +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped + +declare namespace seedrandom { + + export type seedrandomStateType = boolean | (() => prng); + + interface prng { + new (seed?: string, options?: seedRandomOptions, callback?: any): prng; + (): number; + quick(): number; + int32(): number; + double(): number; + state(): () => prng; + } + + interface seedrandom_prng { + (seed?: string, options?: seedRandomOptions, callback?: any): prng; + alea: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + xor128: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + tychei: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + xorwow: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + xor4096: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + xorshift7: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + quick: (seed?: string, options?: seedRandomOptions, callback?: seedrandomCallback) => prng; + } + + interface seedrandomCallback { + (prng?: prng, shortseed?: string, global?: boolean, state?: seedrandomStateType): prng; + } + + interface seedRandomOptions { + entropy?: boolean; + 'global'?: boolean; + state?: seedrandomStateType; + pass?: seedrandomCallback; + } +} + +declare var seedrandom: seedrandom.seedrandom_prng; + +export = seedrandom; +export as namespace seedrandom; diff --git a/node_modules/@types/seedrandom/package.json b/node_modules/@types/seedrandom/package.json new file mode 100644 index 0000000..6e0c98b --- /dev/null +++ b/node_modules/@types/seedrandom/package.json @@ -0,0 +1,45 @@ +{ + "_from": "@types/seedrandom@~2.4.27", + "_id": "@types/seedrandom@2.4.27", + "_inBundle": false, + "_integrity": "sha1-nbVjk33YaRX2kJK8QyWdL0hXjkE=", + "_location": "/@types/seedrandom", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/seedrandom@~2.4.27", + "name": "@types/seedrandom", + "escapedName": "@types%2fseedrandom", + "scope": "@types", + "rawSpec": "~2.4.27", + "saveSpec": null, + "fetchSpec": "~2.4.27" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-core" + ], + "_resolved": "https://registry.npmjs.org/@types/seedrandom/-/seedrandom-2.4.27.tgz", + "_shasum": "9db563937dd86915f69092bc43259d2f48578e41", + "_spec": "@types/seedrandom@~2.4.27", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-core", + "author": { + "name": "Kern Handa", + "email": "https://github.com/kernhanda" + }, + "bundleDependencies": false, + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for seedrandom 2.4.2", + "license": "MIT", + "main": "", + "name": "@types/seedrandom", + "repository": { + "type": "git", + "url": "https://www.github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typesPublisherContentHash": "6ad69483683964e97254f65e374a17f845154a74df41e5bf3ea0d53ec1b70e19", + "typings": "index.d.ts", + "version": "2.4.27" +} diff --git a/node_modules/@types/seedrandom/types-metadata.json b/node_modules/@types/seedrandom/types-metadata.json new file mode 100644 index 0000000..22b3620 --- /dev/null +++ b/node_modules/@types/seedrandom/types-metadata.json @@ -0,0 +1,23 @@ +{ + "authors": "Kern Handa ", + "definitionFilename": "index.d.ts", + "libraryDependencies": [], + "moduleDependencies": [], + "libraryMajorVersion": "2", + "libraryMinorVersion": "4", + "libraryName": "seedrandom 2.4.2", + "typingsPackageName": "seedrandom", + "projectName": "https://github.com/davidbau/seedrandom", + "sourceRepoURL": "https://www.github.com/DefinitelyTyped/DefinitelyTyped", + "sourceBranch": "types-2.0", + "kind": "UMD", + "globals": [ + "seedrandom" + ], + "declaredModules": [], + "files": [ + "index.d.ts" + ], + "hasPackageJson": false, + "contentHash": "6ad69483683964e97254f65e374a17f845154a74df41e5bf3ea0d53ec1b70e19" +} \ No newline at end of file diff --git a/node_modules/@types/webgl-ext/LICENSE b/node_modules/@types/webgl-ext/LICENSE new file mode 100644 index 0000000..2107107 --- /dev/null +++ b/node_modules/@types/webgl-ext/LICENSE @@ -0,0 +1,21 @@ + MIT License + + Copyright (c) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE diff --git a/node_modules/@types/webgl-ext/README.md b/node_modules/@types/webgl-ext/README.md new file mode 100644 index 0000000..0f4b46f --- /dev/null +++ b/node_modules/@types/webgl-ext/README.md @@ -0,0 +1,16 @@ +# Installation +> `npm install --save @types/webgl-ext` + +# Summary +This package contains type definitions for WebGL Extensions (http://webgl.org/). + +# Details +Files were exported from https://www.github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/webgl-ext + +Additional Details + * Last updated: Mon, 21 Aug 2017 22:03:22 GMT + * Dependencies: none + * Global values: none + +# Credits +These definitions were written by Arthur Langereis . diff --git a/node_modules/@types/webgl-ext/index.d.ts b/node_modules/@types/webgl-ext/index.d.ts new file mode 100644 index 0000000..3f0da0c --- /dev/null +++ b/node_modules/@types/webgl-ext/index.d.ts @@ -0,0 +1,214 @@ +// Type definitions for WebGL Extensions +// Project: http://webgl.org/ +// Definitions by: Arthur Langereis +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped/webgl-ext + +// These definitions go beyond those already defined in TS 1.6.2 stdlib +// All non-draft WebGL 1.0 extensions and prefixed extension names are +// covered. + +interface HTMLCanvasElement { + getContext(contextId: "webgl"): WebGLRenderingContext; +} + +interface WebGLRenderingContext { + getExtension(name: "ANGLE_instanced_arrays"): ANGLEInstancedArrays; + + getExtension(name: "EXT_blend_minmax"): EXTBlendMinMax; + getExtension(name: "EXT_color_buffer_half_float"): EXTColorBufferHalfFloat; + getExtension(name: "EXT_frag_depth"): EXTFragDepth; + getExtension(name: "EXT_sRGB"): EXTsRGB; + getExtension(name: "EXT_shader_texture_lod"): EXTShaderTextureLOD; + getExtension(name: "EXT_texture_filter_anisotropic"): EXTTextureFilterAnisotropic; + + getExtension(name: "OES_element_index_uint"): OESElementIndexUint; + getExtension(name: "OES_standard_derivatives"): OESStandardDerivatives; + getExtension(name: "OES_texture_float"): OESTextureFloat; + getExtension(name: "OES_texture_float_linear"): OESTextureFloatLinear; + getExtension(name: "OES_texture_half_float"): OESTextureHalfFloat; + getExtension(name: "OES_texture_half_float_linear"): OESTextureHalfFloatLinear; + getExtension(name: "OES_vertex_array_object"): OESVertexArrayObject; + + getExtension(name: "WEBGL_color_buffer_float"): WebGLColorBufferFloat; + getExtension(name: "WEBGL_compressed_texture_atc"): WebGLCompressedTextureATC; + getExtension(name: "WEBGL_compressed_texture_etc1"): WebGLCompressedTextureETC1; + getExtension(name: "WEBGL_compressed_texture_pvrtc"): WebGLCompressedTexturePVRTC; + getExtension(name: "WEBGL_compressed_texture_s3tc"): WebGLCompressedTextureS3TC; + getExtension(name: "WEBGL_debug_renderer_info"): WebGLDebugRendererInfo; + getExtension(name: "WEBGL_debug_shaders"): WebGLDebugShaders; + getExtension(name: "WEBGL_depth_texture"): WebGLDepthTexture; + getExtension(name: "WEBGL_draw_buffers"): WebGLDrawBuffers; + getExtension(name: "WEBGL_lose_context"): WebGLLoseContext; + + // Prefixed versions appearing in the wild as per September 2015 + + getExtension(name: "WEBKIT_EXT_texture_filter_anisotropic"): EXTTextureFilterAnisotropic; + getExtension(name: "WEBKIT_WEBGL_compressed_texture_atc"): WebGLCompressedTextureATC; + getExtension(name: "WEBKIT_WEBGL_compressed_texture_pvrtc"): WebGLCompressedTexturePVRTC; + getExtension(name: "WEBKIT_WEBGL_compressed_texture_s3tc"): WebGLCompressedTextureS3TC; + getExtension(name: "WEBKIT_WEBGL_depth_texture"): WebGLDepthTexture; + getExtension(name: "WEBKIT_WEBGL_lose_context"): WebGLLoseContext; + + getExtension(name: "MOZ_WEBGL_compressed_texture_s3tc"): WebGLCompressedTextureS3TC; + getExtension(name: "MOZ_WEBGL_depth_texture"): WebGLDepthTexture; + getExtension(name: "MOZ_WEBGL_lose_context"): WebGLLoseContext; +} + +interface ANGLEInstancedArrays { + VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE: number; + + drawArraysInstancedANGLE(mode: number, first: number, count: number, primcount: number): void; + drawElementsInstancedANGLE(mode: number, count: number, type: number, offset: number, primcount: number): void; + vertexAttribDivisorANGLE(index: number, divisor: number): void; +} + +interface EXTBlendMinMax { + MIN_EXT: number; + MAX_EXT: number; +} + +interface EXTColorBufferHalfFloat { + RGBA16F_EXT: number; + RGB16F_EXT: number; + FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE_EXT: number; + UNSIGNED_NORMALIZED_EXT: number; +} + +interface EXTFragDepth { +} + +interface EXTsRGB { + SRGB_EXT: number; + SRGB_ALPHA_EXT: number; + SRGB8_ALPHA8_EXT: number; + FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING_EXT: number; +} + +interface EXTShaderTextureLOD { +} + +interface EXTTextureFilterAnisotropic { + TEXTURE_MAX_ANISOTROPY_EXT: number; + MAX_TEXTURE_MAX_ANISOTROPY_EXT: number; +} + +interface OESElementIndexUint { +} + +interface OESStandardDerivatives { + FRAGMENT_SHADER_DERIVATIVE_HINT_OES: number; +} + +interface OESTextureFloat { +} + +interface OESTextureFloatLinear { +} + +interface OESTextureHalfFloat { + HALF_FLOAT_OES: number; +} + +interface OESTextureHalfFloatLinear { +} + +interface WebGLVertexArrayObjectOES extends WebGLObject { +} + +interface OESVertexArrayObject { + VERTEX_ARRAY_BINDING_OES: number; + + createVertexArrayOES(): WebGLVertexArrayObjectOES | null; + deleteVertexArrayOES(arrayObject: WebGLVertexArrayObjectOES | null): void; + isVertexArrayOES(arrayObject: WebGLVertexArrayObjectOES | null): boolean; + bindVertexArrayOES(arrayObject: WebGLVertexArrayObjectOES | null): void; +} + +interface WebGLColorBufferFloat { + RGBA32F_EXT: number; + FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE_EXT: number; + UNSIGNED_NORMALIZED_EXT: number; +} + +interface WebGLCompressedTextureATC { + COMPRESSED_RGB_ATC_WEBGL: number; + COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL: number; + COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL: number; +} + +interface WebGLCompressedTextureETC1 { + COMPRESSED_RGB_ETC1_WEBGL: number; +} + +interface WebGLCompressedTexturePVRTC { + COMPRESSED_RGB_PVRTC_4BPPV1_IMG: number; + COMPRESSED_RGB_PVRTC_2BPPV1_IMG: number; + COMPRESSED_RGBA_PVRTC_4BPPV1_IMG: number; + COMPRESSED_RGBA_PVRTC_2BPPV1_IMG: number; +} + +interface WebGLCompressedTextureS3TC { + COMPRESSED_RGB_S3TC_DXT1_EXT: number; + COMPRESSED_RGBA_S3TC_DXT1_EXT: number; + COMPRESSED_RGBA_S3TC_DXT3_EXT: number; + COMPRESSED_RGBA_S3TC_DXT5_EXT: number; +} + +interface WebGLDebugRendererInfo { + UNMASKED_VENDOR_WEBGL: number; + UNMASKED_RENDERER_WEBGL: number; +} + +interface WebGLDebugShaders { + getTranslatedShaderSource(shader: WebGLShader): string; +} + +interface WebGLDepthTexture { + UNSIGNED_INT_24_8_WEBGL: number; +} + +interface WebGLDrawBuffers { + COLOR_ATTACHMENT0_WEBGL: number; + COLOR_ATTACHMENT1_WEBGL: number; + COLOR_ATTACHMENT2_WEBGL: number; + COLOR_ATTACHMENT3_WEBGL: number; + COLOR_ATTACHMENT4_WEBGL: number; + COLOR_ATTACHMENT5_WEBGL: number; + COLOR_ATTACHMENT6_WEBGL: number; + COLOR_ATTACHMENT7_WEBGL: number; + COLOR_ATTACHMENT8_WEBGL: number; + COLOR_ATTACHMENT9_WEBGL: number; + COLOR_ATTACHMENT10_WEBGL: number; + COLOR_ATTACHMENT11_WEBGL: number; + COLOR_ATTACHMENT12_WEBGL: number; + COLOR_ATTACHMENT13_WEBGL: number; + COLOR_ATTACHMENT14_WEBGL: number; + COLOR_ATTACHMENT15_WEBGL: number; + + DRAW_BUFFER0_WEBGL: number; + DRAW_BUFFER1_WEBGL: number; + DRAW_BUFFER2_WEBGL: number; + DRAW_BUFFER3_WEBGL: number; + DRAW_BUFFER4_WEBGL: number; + DRAW_BUFFER5_WEBGL: number; + DRAW_BUFFER6_WEBGL: number; + DRAW_BUFFER7_WEBGL: number; + DRAW_BUFFER8_WEBGL: number; + DRAW_BUFFER9_WEBGL: number; + DRAW_BUFFER10_WEBGL: number; + DRAW_BUFFER11_WEBGL: number; + DRAW_BUFFER12_WEBGL: number; + DRAW_BUFFER13_WEBGL: number; + DRAW_BUFFER14_WEBGL: number; + DRAW_BUFFER15_WEBGL: number; + + MAX_COLOR_ATTACHMENTS_WEBGL: number; + MAX_DRAW_BUFFERS_WEBGL: number; + + drawBuffersWEBGL(buffers: number[]): void; +} + +interface WebGLLoseContext { + loseContext(): void; + restoreContext(): void; +} diff --git a/node_modules/@types/webgl-ext/package.json b/node_modules/@types/webgl-ext/package.json new file mode 100644 index 0000000..5bdd20c --- /dev/null +++ b/node_modules/@types/webgl-ext/package.json @@ -0,0 +1,47 @@ +{ + "_from": "@types/webgl-ext@~0.0.29", + "_id": "@types/webgl-ext@0.0.29", + "_inBundle": false, + "_integrity": "sha512-ZlVjDQU5Vlc9hF4LGdDldujZUf0amwlwGv1RI2bfvdrEHIl6X/7MZVpemJUjS7NxD9XaKfE8SlFrxsfXpUkt/A==", + "_location": "/@types/webgl-ext", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/webgl-ext@~0.0.29", + "name": "@types/webgl-ext", + "escapedName": "@types%2fwebgl-ext", + "scope": "@types", + "rawSpec": "~0.0.29", + "saveSpec": null, + "fetchSpec": "~0.0.29" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-core" + ], + "_resolved": "https://registry.npmjs.org/@types/webgl-ext/-/webgl-ext-0.0.29.tgz", + "_shasum": "4d479baf1124795f53d54bdc85b386e0f194d90a", + "_spec": "@types/webgl-ext@~0.0.29", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-core", + "bundleDependencies": false, + "contributors": [ + { + "name": "Arthur Langereis", + "url": "https://github.com/zenmumbler" + } + ], + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for WebGL Extensions", + "license": "MIT", + "main": "", + "name": "@types/webgl-ext", + "repository": { + "type": "git", + "url": "https://www.github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typeScriptVersion": "2.0", + "typesPublisherContentHash": "afb36c8f21fbfaba3c3ee3d8f36d359b5bd35095ad28dac7c3ae77940da351ae", + "version": "0.0.29" +} diff --git a/node_modules/@types/webgl2/LICENSE b/node_modules/@types/webgl2/LICENSE new file mode 100644 index 0000000..2107107 --- /dev/null +++ b/node_modules/@types/webgl2/LICENSE @@ -0,0 +1,21 @@ + MIT License + + Copyright (c) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE diff --git a/node_modules/@types/webgl2/README.md b/node_modules/@types/webgl2/README.md new file mode 100644 index 0000000..b632484 --- /dev/null +++ b/node_modules/@types/webgl2/README.md @@ -0,0 +1,16 @@ +# Installation +> `npm install --save @types/webgl2` + +# Summary +This package contains type definitions for WebGL 2, Editor's Draft Fri Feb 24 16:10:18 2017 -0800 (https://www.khronos.org/registry/webgl/specs/latest/2.0/). + +# Details +Files were exported from https://www.github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/webgl2 + +Additional Details + * Last updated: Thu, 26 Apr 2018 22:15:55 GMT + * Dependencies: none + * Global values: WebGL2RenderingContext, WebGLQuery, WebGLSampler, WebGLSync, WebGLTransformFeedback, WebGLVertexArrayObject + +# Credits +These definitions were written by Nico Kemnitz , Adrian Blumer . diff --git a/node_modules/@types/webgl2/index.d.ts b/node_modules/@types/webgl2/index.d.ts new file mode 100644 index 0000000..a18d509 --- /dev/null +++ b/node_modules/@types/webgl2/index.d.ts @@ -0,0 +1,1194 @@ +// Type definitions for WebGL 2, Editor's Draft Fri Feb 24 16:10:18 2017 -0800 +// Project: https://www.khronos.org/registry/webgl/specs/latest/2.0/ +// Definitions by: Nico Kemnitz +// Adrian Blumer +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped + +interface HTMLCanvasElement extends HTMLElement { + getContext(contextId: "webgl2" | "experimental-webgl2", contextAttributes?: WebGLContextAttributes): WebGL2RenderingContext | null; +} + +interface ImageBitmap { + readonly width: number; + readonly height: number; + close(): void; +} + +interface WebGL2RenderingContext extends WebGLRenderingContext { + readonly READ_BUFFER: number; // 0x0C02 + readonly UNPACK_ROW_LENGTH: number; // 0x0CF2 + readonly UNPACK_SKIP_ROWS: number; // 0x0CF3 + readonly UNPACK_SKIP_PIXELS: number; // 0x0CF4 + readonly PACK_ROW_LENGTH: number; // 0x0D02 + readonly PACK_SKIP_ROWS: number; // 0x0D03 + readonly PACK_SKIP_PIXELS: number; // 0x0D04 + readonly COLOR: number; // 0x1800 + readonly DEPTH: number; // 0x1801 + readonly STENCIL: number; // 0x1802 + readonly RED: number; // 0x1903 + readonly RGB8: number; // 0x8051 + readonly RGBA8: number; // 0x8058 + readonly RGB10_A2: number; // 0x8059 + readonly TEXTURE_BINDING_3D: number; // 0x806A + readonly UNPACK_SKIP_IMAGES: number; // 0x806D + readonly UNPACK_IMAGE_HEIGHT: number; // 0x806E + readonly TEXTURE_3D: number; // 0x806F + readonly TEXTURE_WRAP_R: number; // 0x8072 + readonly MAX_3D_TEXTURE_SIZE: number; // 0x8073 + readonly UNSIGNED_INT_2_10_10_10_REV: number; // 0x8368 + readonly MAX_ELEMENTS_VERTICES: number; // 0x80E8 + readonly MAX_ELEMENTS_INDICES: number; // 0x80E9 + readonly TEXTURE_MIN_LOD: number; // 0x813A + readonly TEXTURE_MAX_LOD: number; // 0x813B + readonly TEXTURE_BASE_LEVEL: number; // 0x813C + readonly TEXTURE_MAX_LEVEL: number; // 0x813D + readonly MIN: number; // 0x8007 + readonly MAX: number; // 0x8008 + readonly DEPTH_COMPONENT24: number; // 0x81A6 + readonly MAX_TEXTURE_LOD_BIAS: number; // 0x84FD + readonly TEXTURE_COMPARE_MODE: number; // 0x884C + readonly TEXTURE_COMPARE_FUNC: number; // 0x884D + readonly CURRENT_QUERY: number; // 0x8865 + readonly QUERY_RESULT: number; // 0x8866 + readonly QUERY_RESULT_AVAILABLE: number; // 0x8867 + readonly STREAM_READ: number; // 0x88E1 + readonly STREAM_COPY: number; // 0x88E2 + readonly STATIC_READ: number; // 0x88E5 + readonly STATIC_COPY: number; // 0x88E6 + readonly DYNAMIC_READ: number; // 0x88E9 + readonly DYNAMIC_COPY: number; // 0x88EA + readonly MAX_DRAW_BUFFERS: number; // 0x8824 + readonly DRAW_BUFFER0: number; // 0x8825 + readonly DRAW_BUFFER1: number; // 0x8826 + readonly DRAW_BUFFER2: number; // 0x8827 + readonly DRAW_BUFFER3: number; // 0x8828 + readonly DRAW_BUFFER4: number; // 0x8829 + readonly DRAW_BUFFER5: number; // 0x882A + readonly DRAW_BUFFER6: number; // 0x882B + readonly DRAW_BUFFER7: number; // 0x882C + readonly DRAW_BUFFER8: number; // 0x882D + readonly DRAW_BUFFER9: number; // 0x882E + readonly DRAW_BUFFER10: number; // 0x882F + readonly DRAW_BUFFER11: number; // 0x8830 + readonly DRAW_BUFFER12: number; // 0x8831 + readonly DRAW_BUFFER13: number; // 0x8832 + readonly DRAW_BUFFER14: number; // 0x8833 + readonly DRAW_BUFFER15: number; // 0x8834 + readonly MAX_FRAGMENT_UNIFORM_COMPONENTS: number; // 0x8B49 + readonly MAX_VERTEX_UNIFORM_COMPONENTS: number; // 0x8B4A + readonly SAMPLER_3D: number; // 0x8B5F + readonly SAMPLER_2D_SHADOW: number; // 0x8B62 + readonly FRAGMENT_SHADER_DERIVATIVE_HINT: number; // 0x8B8B + readonly PIXEL_PACK_BUFFER: number; // 0x88EB + readonly PIXEL_UNPACK_BUFFER: number; // 0x88EC + readonly PIXEL_PACK_BUFFER_BINDING: number; // 0x88ED + readonly PIXEL_UNPACK_BUFFER_BINDING: number; // 0x88EF + readonly FLOAT_MAT2x3: number; // 0x8B65 + readonly FLOAT_MAT2x4: number; // 0x8B66 + readonly FLOAT_MAT3x2: number; // 0x8B67 + readonly FLOAT_MAT3x4: number; // 0x8B68 + readonly FLOAT_MAT4x2: number; // 0x8B69 + readonly FLOAT_MAT4x3: number; // 0x8B6A + readonly SRGB: number; // 0x8C40 + readonly SRGB8: number; // 0x8C41 + readonly SRGB8_ALPHA8: number; // 0x8C43 + readonly COMPARE_REF_TO_TEXTURE: number; // 0x884E + readonly RGBA32F: number; // 0x8814 + readonly RGB32F: number; // 0x8815 + readonly RGBA16F: number; // 0x881A + readonly RGB16F: number; // 0x881B + readonly VERTEX_ATTRIB_ARRAY_INTEGER: number; // 0x88FD + readonly MAX_ARRAY_TEXTURE_LAYERS: number; // 0x88FF + readonly MIN_PROGRAM_TEXEL_OFFSET: number; // 0x8904 + readonly MAX_PROGRAM_TEXEL_OFFSET: number; // 0x8905 + readonly MAX_VARYING_COMPONENTS: number; // 0x8B4B + readonly TEXTURE_2D_ARRAY: number; // 0x8C1A + readonly TEXTURE_BINDING_2D_ARRAY: number; // 0x8C1D + readonly R11F_G11F_B10F: number; // 0x8C3A + readonly UNSIGNED_INT_10F_11F_11F_REV: number; // 0x8C3B + readonly RGB9_E5: number; // 0x8C3D + readonly UNSIGNED_INT_5_9_9_9_REV: number; // 0x8C3E + readonly TRANSFORM_FEEDBACK_BUFFER_MODE: number; // 0x8C7F + readonly MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS: number; // 0x8C80 + readonly TRANSFORM_FEEDBACK_VARYINGS: number; // 0x8C83 + readonly TRANSFORM_FEEDBACK_BUFFER_START: number; // 0x8C84 + readonly TRANSFORM_FEEDBACK_BUFFER_SIZE: number; // 0x8C85 + readonly TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN: number; // 0x8C88 + readonly RASTERIZER_DISCARD: number; // 0x8C89 + readonly MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS: number; // 0x8C8A + readonly MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS: number; // 0x8C8B + readonly INTERLEAVED_ATTRIBS: number; // 0x8C8C + readonly SEPARATE_ATTRIBS: number; // 0x8C8D + readonly TRANSFORM_FEEDBACK_BUFFER: number; // 0x8C8E + readonly TRANSFORM_FEEDBACK_BUFFER_BINDING: number; // 0x8C8F + readonly RGBA32UI: number; // 0x8D70 + readonly RGB32UI: number; // 0x8D71 + readonly RGBA16UI: number; // 0x8D76 + readonly RGB16UI: number; // 0x8D77 + readonly RGBA8UI: number; // 0x8D7C + readonly RGB8UI: number; // 0x8D7D + readonly RGBA32I: number; // 0x8D82 + readonly RGB32I: number; // 0x8D83 + readonly RGBA16I: number; // 0x8D88 + readonly RGB16I: number; // 0x8D89 + readonly RGBA8I: number; // 0x8D8E + readonly RGB8I: number; // 0x8D8F + readonly RED_INTEGER: number; // 0x8D94 + readonly RGB_INTEGER: number; // 0x8D98 + readonly RGBA_INTEGER: number; // 0x8D99 + readonly SAMPLER_2D_ARRAY: number; // 0x8DC1 + readonly SAMPLER_2D_ARRAY_SHADOW: number; // 0x8DC4 + readonly SAMPLER_CUBE_SHADOW: number; // 0x8DC5 + readonly UNSIGNED_INT_VEC2: number; // 0x8DC6 + readonly UNSIGNED_INT_VEC3: number; // 0x8DC7 + readonly UNSIGNED_INT_VEC4: number; // 0x8DC8 + readonly INT_SAMPLER_2D: number; // 0x8DCA + readonly INT_SAMPLER_3D: number; // 0x8DCB + readonly INT_SAMPLER_CUBE: number; // 0x8DCC + readonly INT_SAMPLER_2D_ARRAY: number; // 0x8DCF + readonly UNSIGNED_INT_SAMPLER_2D: number; // 0x8DD2 + readonly UNSIGNED_INT_SAMPLER_3D: number; // 0x8DD3 + readonly UNSIGNED_INT_SAMPLER_CUBE: number; // 0x8DD4 + readonly UNSIGNED_INT_SAMPLER_2D_ARRAY: number; // 0x8DD7 + readonly DEPTH_COMPONENT32F: number; // 0x8CAC + readonly DEPTH32F_STENCIL8: number; // 0x8CAD + readonly FLOAT_32_UNSIGNED_INT_24_8_REV: number; // 0x8DAD + readonly FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING: number; // 0x8210 + readonly FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE: number; // 0x8211 + readonly FRAMEBUFFER_ATTACHMENT_RED_SIZE: number; // 0x8212 + readonly FRAMEBUFFER_ATTACHMENT_GREEN_SIZE: number; // 0x8213 + readonly FRAMEBUFFER_ATTACHMENT_BLUE_SIZE: number; // 0x8214 + readonly FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE: number; // 0x8215 + readonly FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE: number; // 0x8216 + readonly FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE: number; // 0x8217 + readonly FRAMEBUFFER_DEFAULT: number; // 0x8218 + //readonly DEPTH_STENCIL_ATTACHMENT: number; // 0x821A /* Already defined in WebGL1 constants */ + //readonly DEPTH_STENCIL: number; // 0x84F9 /* Already defined in WebGL1 constants */ + readonly UNSIGNED_INT_24_8: number; // 0x84FA + readonly DEPTH24_STENCIL8: number; // 0x88F0 + readonly UNSIGNED_NORMALIZED: number; // 0x8C17 + readonly DRAW_FRAMEBUFFER_BINDING: number; // 0x8CA6 /* Same as FRAMEBUFFER_BINDING */ + readonly READ_FRAMEBUFFER: number; // 0x8CA8 + readonly DRAW_FRAMEBUFFER: number; // 0x8CA9 + readonly READ_FRAMEBUFFER_BINDING: number; // 0x8CAA + readonly RENDERBUFFER_SAMPLES: number; // 0x8CAB + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER: number; // 0x8CD4 + readonly MAX_COLOR_ATTACHMENTS: number; // 0x8CDF + readonly COLOR_ATTACHMENT1: number; // 0x8CE1 + readonly COLOR_ATTACHMENT2: number; // 0x8CE2 + readonly COLOR_ATTACHMENT3: number; // 0x8CE3 + readonly COLOR_ATTACHMENT4: number; // 0x8CE4 + readonly COLOR_ATTACHMENT5: number; // 0x8CE5 + readonly COLOR_ATTACHMENT6: number; // 0x8CE6 + readonly COLOR_ATTACHMENT7: number; // 0x8CE7 + readonly COLOR_ATTACHMENT8: number; // 0x8CE8 + readonly COLOR_ATTACHMENT9: number; // 0x8CE9 + readonly COLOR_ATTACHMENT10: number; // 0x8CEA + readonly COLOR_ATTACHMENT11: number; // 0x8CEB + readonly COLOR_ATTACHMENT12: number; // 0x8CEC + readonly COLOR_ATTACHMENT13: number; // 0x8CED + readonly COLOR_ATTACHMENT14: number; // 0x8CEE + readonly COLOR_ATTACHMENT15: number; // 0x8CEF + readonly FRAMEBUFFER_INCOMPLETE_MULTISAMPLE: number; // 0x8D56 + readonly MAX_SAMPLES: number; // 0x8D57 + readonly HALF_FLOAT: number; // 0x140B + readonly RG: number; // 0x8227 + readonly RG_INTEGER: number; // 0x8228 + readonly R8: number; // 0x8229 + readonly RG8: number; // 0x822B + readonly R16F: number; // 0x822D + readonly R32F: number; // 0x822E + readonly RG16F: number; // 0x822F + readonly RG32F: number; // 0x8230 + readonly R8I: number; // 0x8231 + readonly R8UI: number; // 0x8232 + readonly R16I: number; // 0x8233 + readonly R16UI: number; // 0x8234 + readonly R32I: number; // 0x8235 + readonly R32UI: number; // 0x8236 + readonly RG8I: number; // 0x8237 + readonly RG8UI: number; // 0x8238 + readonly RG16I: number; // 0x8239 + readonly RG16UI: number; // 0x823A + readonly RG32I: number; // 0x823B + readonly RG32UI: number; // 0x823C + readonly VERTEX_ARRAY_BINDING: number; // 0x85B5 + readonly R8_SNORM: number; // 0x8F94 + readonly RG8_SNORM: number; // 0x8F95 + readonly RGB8_SNORM: number; // 0x8F96 + readonly RGBA8_SNORM: number; // 0x8F97 + readonly SIGNED_NORMALIZED: number; // 0x8F9C + readonly COPY_READ_BUFFER: number; // 0x8F36 + readonly COPY_WRITE_BUFFER: number; // 0x8F37 + readonly COPY_READ_BUFFER_BINDING: number; // 0x8F36 /* Same as COPY_READ_BUFFER */ + readonly COPY_WRITE_BUFFER_BINDING: number; // 0x8F37 /* Same as COPY_WRITE_BUFFER */ + readonly UNIFORM_BUFFER: number; // 0x8A11 + readonly UNIFORM_BUFFER_BINDING: number; // 0x8A28 + readonly UNIFORM_BUFFER_START: number; // 0x8A29 + readonly UNIFORM_BUFFER_SIZE: number; // 0x8A2A + readonly MAX_VERTEX_UNIFORM_BLOCKS: number; // 0x8A2B + readonly MAX_FRAGMENT_UNIFORM_BLOCKS: number; // 0x8A2D + readonly MAX_COMBINED_UNIFORM_BLOCKS: number; // 0x8A2E + readonly MAX_UNIFORM_BUFFER_BINDINGS: number; // 0x8A2F + readonly MAX_UNIFORM_BLOCK_SIZE: number; // 0x8A30 + readonly MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS: number; // 0x8A31 + readonly MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS: number; // 0x8A33 + readonly UNIFORM_BUFFER_OFFSET_ALIGNMENT: number; // 0x8A34 + readonly ACTIVE_UNIFORM_BLOCKS: number; // 0x8A36 + readonly UNIFORM_TYPE: number; // 0x8A37 + readonly UNIFORM_SIZE: number; // 0x8A38 + readonly UNIFORM_BLOCK_INDEX: number; // 0x8A3A + readonly UNIFORM_OFFSET: number; // 0x8A3B + readonly UNIFORM_ARRAY_STRIDE: number; // 0x8A3C + readonly UNIFORM_MATRIX_STRIDE: number; // 0x8A3D + readonly UNIFORM_IS_ROW_MAJOR: number; // 0x8A3E + readonly UNIFORM_BLOCK_BINDING: number; // 0x8A3F + readonly UNIFORM_BLOCK_DATA_SIZE: number; // 0x8A40 + readonly UNIFORM_BLOCK_ACTIVE_UNIFORMS: number; // 0x8A42 + readonly UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES: number; // 0x8A43 + readonly UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER: number; // 0x8A44 + readonly UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER: number; // 0x8A46 + readonly INVALID_INDEX: number; // 0xFFFFFFFF + readonly MAX_VERTEX_OUTPUT_COMPONENTS: number; // 0x9122 + readonly MAX_FRAGMENT_INPUT_COMPONENTS: number; // 0x9125 + readonly MAX_SERVER_WAIT_TIMEOUT: number; // 0x9111 + readonly OBJECT_TYPE: number; // 0x9112 + readonly SYNC_CONDITION: number; // 0x9113 + readonly SYNC_STATUS: number; // 0x9114 + readonly SYNC_FLAGS: number; // 0x9115 + readonly SYNC_FENCE: number; // 0x9116 + readonly SYNC_GPU_COMMANDS_COMPLETE: number; // 0x9117 + readonly UNSIGNALED: number; // 0x9118 + readonly SIGNALED: number; // 0x9119 + readonly ALREADY_SIGNALED: number; // 0x911A + readonly TIMEOUT_EXPIRED: number; // 0x911B + readonly CONDITION_SATISFIED: number; // 0x911C + readonly WAIT_FAILED: number; // 0x911D + readonly SYNC_FLUSH_COMMANDS_BIT: number; // 0x00000001 + readonly VERTEX_ATTRIB_ARRAY_DIVISOR: number; // 0x88FE + readonly ANY_SAMPLES_PASSED: number; // 0x8C2F + readonly ANY_SAMPLES_PASSED_CONSERVATIVE: number; // 0x8D6A + readonly SAMPLER_BINDING: number; // 0x8919 + readonly RGB10_A2UI: number; // 0x906F + readonly INT_2_10_10_10_REV: number; // 0x8D9F + readonly TRANSFORM_FEEDBACK: number; // 0x8E22 + readonly TRANSFORM_FEEDBACK_PAUSED: number; // 0x8E23 + readonly TRANSFORM_FEEDBACK_ACTIVE: number; // 0x8E24 + readonly TRANSFORM_FEEDBACK_BINDING: number; // 0x8E25 + readonly TEXTURE_IMMUTABLE_FORMAT: number; // 0x912F + readonly MAX_ELEMENT_INDEX: number; // 0x8D6B + readonly TEXTURE_IMMUTABLE_LEVELS: number; // 0x82DF + + readonly TIMEOUT_IGNORED: number; // -1 + + /* WebGL-specific enums */ + readonly MAX_CLIENT_WAIT_TIMEOUT_WEBGL: number; // 0x9247 + + + /* Buffer objects */ + // WebGL1: + bufferData(target: number, sizeOrData: number | Int8Array | Int16Array | Int32Array | Uint8Array | Uint16Array | + Uint32Array | Uint8ClampedArray | Float32Array | Float64Array | DataView | ArrayBuffer | null, usage: number): void; + bufferSubData(target: number, dstByteOffset: number, srcData: Int8Array | Int16Array | Int32Array | Uint8Array | + Uint16Array | Uint32Array | Uint8ClampedArray | Float32Array | Float64Array | DataView | ArrayBuffer | null): void; + // For compatibility with WebGL 1 context in older Typescript versions. + bufferData(target: number, data: ArrayBufferView, usage: number): void; + bufferSubData(target: number, dstByteOffset: number, srcData: ArrayBufferView): void; + // WebGL2: + bufferData(target: number, srcData: Int8Array | Int16Array | Int32Array | Uint8Array | Uint16Array | Uint32Array | + Uint8ClampedArray | Float32Array | Float64Array | DataView | ArrayBuffer | null, usage: number, srcOffset: number, length?: number): void; + bufferSubData(target: number, dstByteOffset: number, srcData: ArrayBufferView, + srcOffset: number, length?: number): void; + + copyBufferSubData(readTarget: number, writeTarget: number, readOffset: number, + writeOffset: number, size: number): void; + // MapBufferRange, in particular its read-only and write-only modes, + // can not be exposed safely to JavaScript. GetBufferSubData + // replaces it for the purpose of fetching data back from the GPU. + getBufferSubData(target: number, srcByteOffset: number, dstBuffer: ArrayBufferView, + dstOffset?: number, length?: number): void; + + /* Framebuffer objects */ + blitFramebuffer(srcX0: number, srcY0: number, srcX1: number, srcY1: number, dstX0: number, dstY0: number, + dstX1: number, dstY1: number, mask: number, filter: number): void; + framebufferTextureLayer(target: number, attachment: number, texture: WebGLTexture | null, level: number, + layer: number): void; + invalidateFramebuffer(target: number, attachments: number[]): void; + invalidateSubFramebuffer(target: number, attachments: number[], + x: number, y: number, width: number, height: number): void; + readBuffer(src: number): void; + + /* Renderbuffer objects */ + getInternalformatParameter(target: number, internalformat: number, pname: number): any; + renderbufferStorageMultisample(target: number, samples: number, internalformat: number, + width: number, height: number): void; + + /* Texture objects */ + texStorage2D(target: number, levels: number, internalformat: number, width: number, + height: number): void; + texStorage3D(target: number, levels: number, internalformat: number, width: number, + height: number, depth: number): void; + + // WebGL1 legacy entrypoints: + texImage2D(target: number, level: number, internalformat: number, + width: number, height: number, border: number, format: number, + type: number, pixels?: ArrayBufferView | null): void; + texImage2D(target: number, level: number, internalformat: number, + format: number, type: number, source: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texImage2D(target: number, level: number, internalformat: number, + format: number, type: number, source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + width: number, height: number, + format: number, type: number, pixels?: ArrayBufferView | null): void; + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + format: number, type: number, source: ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + format: number, type: number, source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + + // WebGL2 entrypoints: + texImage2D(target: number, level: number, internalformat: number, width: number, height: number, + border: number, format: number, type: number, pboOffset: number): void; + texImage2D(target: number, level: number, internalformat: number, width: number, height: number, + border: number, format: number, type: number, + source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texImage2D(target: number, level: number, internalformat: number, width: number, height: number, + border: number, format: number, type: number, srcData: ArrayBufferView, + srcOffset: number): void; + + texImage3D(target: number, level: number, internalformat: number, width: number, height: number, + depth: number, border: number, format: number, type: number, pboOffset: number): void; + texImage3D(target: number, level: number, internalformat: number, width: number, height: number, + depth: number, border: number, format: number, type: number, + source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texImage3D(target: number, level: number, internalformat: number, width: number, height: number, + depth: number, border: number, format: number, type: number, srcData: ArrayBufferView | null): void; + texImage3D(target: number, level: number, internalformat: number, width: number, height: number, + depth: number, border: number, format: number, type: number, srcData: ArrayBufferView, + srcOffset: number): void; + + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, width: number, + height: number, format: number, type: number, pboOffset: number): void; + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, width: number, + height: number, format: number, type: number, + source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, width: number, + height: number, format: number, type: number, srcData: ArrayBufferView, + srcOffset: number): void; + + texSubImage3D(target: number, level: number, xoffset: number, yoffset: number, zoffset: number, + width: number, height: number, depth: number, format: number, type: number, + pboOffset: number): void; + texSubImage3D(target: number, level: number, xoffset: number, yoffset: number, zoffset: number, + width: number, height: number, depth: number, format: number, type: number, + source: ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement): void; // May throw DOMException + texSubImage3D(target: number, level: number, xoffset: number, yoffset: number, zoffset: number, + width: number, height: number, depth: number, format: number, type: number, + srcData: ArrayBufferView | null, srcOffset?: number): void; + + copyTexSubImage3D(target: number, level: number, xoffset: number, yoffset: number, zoffset: number, + x: number, y: number, width: number, height: number): void; + + compressedTexImage2D(target: number, level: number, internalformat: number, width: number, + height: number, border: number, imageSize: number, offset: number): void; + compressedTexImage2D(target: number, level: number, internalformat: number, width: number, + height: number, border: number, srcData: Int8Array | Int16Array | Int32Array | Uint8Array | Uint16Array | Uint32Array | + Uint8ClampedArray | Float32Array | Float64Array | DataView | null, srcOffset?: number, srcLengthOverride?: number): void; + // For compatibility with WebGL 1 context in older Typescript versions. + compressedTexImage2D(target: number, level: number, internalformat: number, width: number, + height: number, border: number, srcData: ArrayBufferView, + srcOffset?: number, srcLengthOverride?: number): void; + + compressedTexImage3D(target: number, level: number, internalformat: number, width: number, + height: number, depth: number, border: number, imageSize: number, offset: number): void; + compressedTexImage3D(target: number, level: number, internalformat: number, width: number, + height: number, depth: number, border: number, srcData: ArrayBufferView, + srcOffset?: number, srcLengthOverride?: number): void; + + compressedTexSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + width: number, height: number, format: number, imageSize: number, offset: number): void; + compressedTexSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + width: number, height: number, format: number, + srcData: Int8Array | Int16Array | Int32Array | Uint8Array | Uint16Array | Uint32Array | + Uint8ClampedArray | Float32Array | Float64Array | DataView | null, srcOffset?: number, srcLengthOverride?: number): void; + // For compatibility with WebGL 1 context in older Typescript versions. + compressedTexSubImage2D(target: number, level: number, xoffset: number, yoffset: number, + width: number, height: number, format: number, + srcData: ArrayBufferView | null, + srcOffset?: number, + srcLengthOverride?: number): void; + + compressedTexSubImage3D(target: number, level: number, xoffset: number, yoffset: number, + zoffset: number, width: number, height: number, depth: number, + format: number, imageSize: number, offset: number): void; + compressedTexSubImage3D(target: number, level: number, xoffset: number, yoffset: number, + zoffset: number, width: number, height: number, depth: number, + format: number, srcData: ArrayBufferView, + srcOffset?: number, + srcLengthOverride?: number): void; + + /* Programs and shaders */ + getFragDataLocation(program: WebGLProgram, name: string): number; + + /* Uniforms */ + uniform1ui(location: WebGLUniformLocation | null, v0: number): void; + uniform2ui(location: WebGLUniformLocation | null, v0: number, v1: number): void; + uniform3ui(location: WebGLUniformLocation | null, v0: number, v1: number, v2: number): void; + uniform4ui(location: WebGLUniformLocation | null, v0: number, v1: number, v2: number, v3: number): void; + + uniform1fv(location: WebGLUniformLocation | null, data: Float32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform2fv(location: WebGLUniformLocation | null, data: Float32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform3fv(location: WebGLUniformLocation | null, data: Float32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform4fv(location: WebGLUniformLocation | null, data: Float32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + + uniform1iv(location: WebGLUniformLocation | null, data: Int32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform2iv(location: WebGLUniformLocation | null, data: Int32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform3iv(location: WebGLUniformLocation | null, data: Int32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform4iv(location: WebGLUniformLocation | null, data: Int32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + + uniform1uiv(location: WebGLUniformLocation | null, data: Uint32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform2uiv(location: WebGLUniformLocation | null, data: Uint32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform3uiv(location: WebGLUniformLocation | null, data: Uint32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + uniform4uiv(location: WebGLUniformLocation | null, data: Uint32Array | ArrayLike, srcOffset?: number, + srcLength?: number): void; + + uniformMatrix2fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix3x2fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix4x2fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + + uniformMatrix2x3fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix3fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix4x3fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + + uniformMatrix2x4fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix3x4fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + uniformMatrix4fv(location: WebGLUniformLocation | null, transpose: boolean, data: Float32Array | ArrayLike, + srcOffset?: number, srcLength?: number): void; + + /* Vertex attribs */ + vertexAttribI4i(index: number, x: number, y: number, z: number, w: number): void; + vertexAttribI4iv(index: number, values: Int32Array | ArrayLike): void; + vertexAttribI4ui(index: number, x: number, y: number, z: number, w: number): void; + vertexAttribI4uiv(index: number, values: Uint32Array | ArrayLike): void; + vertexAttribIPointer(index: number, size: number, type: number, stride: number, offset: number): void; + + /* Writing to the drawing buffer */ + vertexAttribDivisor(index: number, divisor: number): void; + drawArraysInstanced(mode: number, first: number, count: number, instanceCount: number): void; + drawElementsInstanced(mode: number, count: number, type: number, offset: number, instanceCount: number): void; + drawRangeElements(mode: number, start: number, end: number, count: number, type: number, offset: number): void; + + /* Reading back pixels */ + // WebGL1: + readPixels(x: number, y: number, width: number, height: number, format: number, type: number, + dstData: Int8Array | Int16Array | Int32Array | Uint8Array | Uint16Array | Uint32Array | Uint8ClampedArray | + Float32Array | Float64Array | DataView | null): void; + // For compatibility with WebGL 1 context in older Typescript versions. + readPixels(x: number, y: number, width: number, height: number, format: number, type: number, + dstData: ArrayBufferView | null): void; + // WebGL2: + readPixels(x: number, y: number, width: number, height: number, format: number, type: number, + offset: number): void; + readPixels(x: number, y: number, width: number, height: number, format: number, type: number, + dstData: ArrayBufferView, dstOffset: number): void; + + /* Multiple Render Targets */ + drawBuffers(buffers: number[]): void; + + clearBufferfv(buffer: number, drawbuffer: number, values: Float32Array | ArrayLike, + srcOffset?: number): void; + clearBufferiv(buffer: number, drawbuffer: number, values: Int32Array | ArrayLike, + srcOffset?: number): void; + clearBufferuiv(buffer: number, drawbuffer: number, values: Uint32Array | ArrayLike, + srcOffset?: number): void; + + clearBufferfi(buffer: number, drawbuffer: number, depth: number, stencil: number): void; + + /* Query Objects */ + createQuery(): WebGLQuery | null; + deleteQuery(query: WebGLQuery | null): void; + isQuery(query: WebGLQuery | null): boolean; //[WebGLHandlesContextLoss] + beginQuery(target: number, query: WebGLQuery): void; + endQuery(target: number): void; + getQuery(target: number, pname: number): WebGLQuery | null; + getQueryParameter(query: WebGLQuery, pname: number): any; + + /* Sampler Objects */ + createSampler(): WebGLSampler | null; + deleteSampler(sampler: WebGLSampler | null): void; + isSampler(sampler: WebGLSampler | null): boolean; //[WebGLHandlesContextLoss] + bindSampler(unit: number, sampler: WebGLSampler | null): void; + samplerParameteri(sampler: WebGLSampler, pname: number, param: number): void; + samplerParameterf(sampler: WebGLSampler, pname: number, param: number): void; + getSamplerParameter(sampler: WebGLSampler, pname: number): any; + + /* Sync objects */ + fenceSync(condition: number, flags: number): WebGLSync | null; + isSync(sync: WebGLSync | null): boolean; //[WebGLHandlesContextLoss] + deleteSync(sync: WebGLSync | null): void; + clientWaitSync(sync: WebGLSync, flags: number, timeout: number): number; + waitSync(sync: WebGLSync, flags: number, timeout: number): void; + getSyncParameter(sync: WebGLSync, pname: number): any; + + /* Transform Feedback */ + createTransformFeedback(): WebGLTransformFeedback | null; + deleteTransformFeedback(tf: WebGLTransformFeedback | null): void; + isTransformFeedback(tf: WebGLTransformFeedback | null): boolean; //[WebGLHandlesContextLoss] + bindTransformFeedback(target: number, tf: WebGLTransformFeedback | null): void; + beginTransformFeedback(primitiveMode: number): void; + endTransformFeedback(): void; + transformFeedbackVaryings(program: WebGLProgram, varyings: string[], bufferMode: number): void; + getTransformFeedbackVarying(program: WebGLProgram, index: number): WebGLActiveInfo | null; + pauseTransformFeedback(): void; + resumeTransformFeedback(): void; + + /* Uniform Buffer Objects and Transform Feedback Buffers */ + bindBufferBase(target: number, index: number, buffer: WebGLBuffer | null): void; + bindBufferRange(target: number, index: number, buffer: WebGLBuffer | null, offset: number, size: number): void; + getIndexedParameter(target: number, index: number): any; + getUniformIndices(program: WebGLProgram, uniformNames: string[]): number[] | null; + getActiveUniforms(program: WebGLProgram, uniformIndices: number[], pname: number): any; + getUniformBlockIndex(program: WebGLProgram, uniformBlockName: string): number; + getActiveUniformBlockParameter(program: WebGLProgram, uniformBlockIndex: number, pname: number): any; + getActiveUniformBlockName(program: WebGLProgram, uniformBlockIndex: number): string | null; + uniformBlockBinding(program: WebGLProgram, uniformBlockIndex: number, uniformBlockBinding: number): void; + + /* Vertex Array Objects */ + createVertexArray(): WebGLVertexArrayObject | null; + deleteVertexArray(vertexArray: WebGLVertexArrayObject | null): void; + isVertexArray(vertexArray: WebGLVertexArrayObject | null): boolean; //[WebGLHandlesContextLoss] + bindVertexArray(array: WebGLVertexArrayObject | null): void; +} + +declare var WebGL2RenderingContext: { + prototype: WebGL2RenderingContext; + new (): WebGL2RenderingContext; + + /* WebGL1 constants */ + readonly ACTIVE_ATTRIBUTES: number; + readonly ACTIVE_TEXTURE: number; + readonly ACTIVE_UNIFORMS: number; + readonly ALIASED_LINE_WIDTH_RANGE: number; + readonly ALIASED_POINT_SIZE_RANGE: number; + readonly ALPHA: number; + readonly ALPHA_BITS: number; + readonly ALWAYS: number; + readonly ARRAY_BUFFER: number; + readonly ARRAY_BUFFER_BINDING: number; + readonly ATTACHED_SHADERS: number; + readonly BACK: number; + readonly BLEND: number; + readonly BLEND_COLOR: number; + readonly BLEND_DST_ALPHA: number; + readonly BLEND_DST_RGB: number; + readonly BLEND_EQUATION: number; + readonly BLEND_EQUATION_ALPHA: number; + readonly BLEND_EQUATION_RGB: number; + readonly BLEND_SRC_ALPHA: number; + readonly BLEND_SRC_RGB: number; + readonly BLUE_BITS: number; + readonly BOOL: number; + readonly BOOL_VEC2: number; + readonly BOOL_VEC3: number; + readonly BOOL_VEC4: number; + readonly BROWSER_DEFAULT_WEBGL: number; + readonly BUFFER_SIZE: number; + readonly BUFFER_USAGE: number; + readonly BYTE: number; + readonly CCW: number; + readonly CLAMP_TO_EDGE: number; + readonly COLOR_ATTACHMENT0: number; + readonly COLOR_BUFFER_BIT: number; + readonly COLOR_CLEAR_VALUE: number; + readonly COLOR_WRITEMASK: number; + readonly COMPILE_STATUS: number; + readonly COMPRESSED_TEXTURE_FORMATS: number; + readonly CONSTANT_ALPHA: number; + readonly CONSTANT_COLOR: number; + readonly CONTEXT_LOST_WEBGL: number; + readonly CULL_FACE: number; + readonly CULL_FACE_MODE: number; + readonly CURRENT_PROGRAM: number; + readonly CURRENT_VERTEX_ATTRIB: number; + readonly CW: number; + readonly DECR: number; + readonly DECR_WRAP: number; + readonly DELETE_STATUS: number; + readonly DEPTH_ATTACHMENT: number; + readonly DEPTH_BITS: number; + readonly DEPTH_BUFFER_BIT: number; + readonly DEPTH_CLEAR_VALUE: number; + readonly DEPTH_COMPONENT: number; + readonly DEPTH_COMPONENT16: number; + readonly DEPTH_FUNC: number; + readonly DEPTH_RANGE: number; + readonly DEPTH_STENCIL: number; + readonly DEPTH_STENCIL_ATTACHMENT: number; + readonly DEPTH_TEST: number; + readonly DEPTH_WRITEMASK: number; + readonly DITHER: number; + readonly DONT_CARE: number; + readonly DST_ALPHA: number; + readonly DST_COLOR: number; + readonly DYNAMIC_DRAW: number; + readonly ELEMENT_ARRAY_BUFFER: number; + readonly ELEMENT_ARRAY_BUFFER_BINDING: number; + readonly EQUAL: number; + readonly FASTEST: number; + readonly FLOAT: number; + readonly FLOAT_MAT2: number; + readonly FLOAT_MAT3: number; + readonly FLOAT_MAT4: number; + readonly FLOAT_VEC2: number; + readonly FLOAT_VEC3: number; + readonly FLOAT_VEC4: number; + readonly FRAGMENT_SHADER: number; + readonly FRAMEBUFFER: number; + readonly FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: number; + readonly FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: number; + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: number; + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: number; + readonly FRAMEBUFFER_BINDING: number; + readonly FRAMEBUFFER_COMPLETE: number; + readonly FRAMEBUFFER_INCOMPLETE_ATTACHMENT: number; + readonly FRAMEBUFFER_INCOMPLETE_DIMENSIONS: number; + readonly FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: number; + readonly FRAMEBUFFER_UNSUPPORTED: number; + readonly FRONT: number; + readonly FRONT_AND_BACK: number; + readonly FRONT_FACE: number; + readonly FUNC_ADD: number; + readonly FUNC_REVERSE_SUBTRACT: number; + readonly FUNC_SUBTRACT: number; + readonly GENERATE_MIPMAP_HINT: number; + readonly GEQUAL: number; + readonly GREATER: number; + readonly GREEN_BITS: number; + readonly HIGH_FLOAT: number; + readonly HIGH_INT: number; + readonly IMPLEMENTATION_COLOR_READ_FORMAT: number; + readonly IMPLEMENTATION_COLOR_READ_TYPE: number; + readonly INCR: number; + readonly INCR_WRAP: number; + readonly INT: number; + readonly INT_VEC2: number; + readonly INT_VEC3: number; + readonly INT_VEC4: number; + readonly INVALID_ENUM: number; + readonly INVALID_FRAMEBUFFER_OPERATION: number; + readonly INVALID_OPERATION: number; + readonly INVALID_VALUE: number; + readonly INVERT: number; + readonly KEEP: number; + readonly LEQUAL: number; + readonly LESS: number; + readonly LINEAR: number; + readonly LINEAR_MIPMAP_LINEAR: number; + readonly LINEAR_MIPMAP_NEAREST: number; + readonly LINES: number; + readonly LINE_LOOP: number; + readonly LINE_STRIP: number; + readonly LINE_WIDTH: number; + readonly LINK_STATUS: number; + readonly LOW_FLOAT: number; + readonly LOW_INT: number; + readonly LUMINANCE: number; + readonly LUMINANCE_ALPHA: number; + readonly MAX_COMBINED_TEXTURE_IMAGE_UNITS: number; + readonly MAX_CUBE_MAP_TEXTURE_SIZE: number; + readonly MAX_FRAGMENT_UNIFORM_VECTORS: number; + readonly MAX_RENDERBUFFER_SIZE: number; + readonly MAX_TEXTURE_IMAGE_UNITS: number; + readonly MAX_TEXTURE_SIZE: number; + readonly MAX_VARYING_VECTORS: number; + readonly MAX_VERTEX_ATTRIBS: number; + readonly MAX_VERTEX_TEXTURE_IMAGE_UNITS: number; + readonly MAX_VERTEX_UNIFORM_VECTORS: number; + readonly MAX_VIEWPORT_DIMS: number; + readonly MEDIUM_FLOAT: number; + readonly MEDIUM_INT: number; + readonly MIRRORED_REPEAT: number; + readonly NEAREST: number; + readonly NEAREST_MIPMAP_LINEAR: number; + readonly NEAREST_MIPMAP_NEAREST: number; + readonly NEVER: number; + readonly NICEST: number; + readonly NONE: number; + readonly NOTEQUAL: number; + readonly NO_ERROR: number; + readonly ONE: number; + readonly ONE_MINUS_CONSTANT_ALPHA: number; + readonly ONE_MINUS_CONSTANT_COLOR: number; + readonly ONE_MINUS_DST_ALPHA: number; + readonly ONE_MINUS_DST_COLOR: number; + readonly ONE_MINUS_SRC_ALPHA: number; + readonly ONE_MINUS_SRC_COLOR: number; + readonly OUT_OF_MEMORY: number; + readonly PACK_ALIGNMENT: number; + readonly POINTS: number; + readonly POLYGON_OFFSET_FACTOR: number; + readonly POLYGON_OFFSET_FILL: number; + readonly POLYGON_OFFSET_UNITS: number; + readonly RED_BITS: number; + readonly RENDERBUFFER: number; + readonly RENDERBUFFER_ALPHA_SIZE: number; + readonly RENDERBUFFER_BINDING: number; + readonly RENDERBUFFER_BLUE_SIZE: number; + readonly RENDERBUFFER_DEPTH_SIZE: number; + readonly RENDERBUFFER_GREEN_SIZE: number; + readonly RENDERBUFFER_HEIGHT: number; + readonly RENDERBUFFER_INTERNAL_FORMAT: number; + readonly RENDERBUFFER_RED_SIZE: number; + readonly RENDERBUFFER_STENCIL_SIZE: number; + readonly RENDERBUFFER_WIDTH: number; + readonly RENDERER: number; + readonly REPEAT: number; + readonly REPLACE: number; + readonly RGB: number; + readonly RGB565: number; + readonly RGB5_A1: number; + readonly RGBA: number; + readonly RGBA4: number; + readonly SAMPLER_2D: number; + readonly SAMPLER_CUBE: number; + readonly SAMPLES: number; + readonly SAMPLE_ALPHA_TO_COVERAGE: number; + readonly SAMPLE_BUFFERS: number; + readonly SAMPLE_COVERAGE: number; + readonly SAMPLE_COVERAGE_INVERT: number; + readonly SAMPLE_COVERAGE_VALUE: number; + readonly SCISSOR_BOX: number; + readonly SCISSOR_TEST: number; + readonly SHADER_TYPE: number; + readonly SHADING_LANGUAGE_VERSION: number; + readonly SHORT: number; + readonly SRC_ALPHA: number; + readonly SRC_ALPHA_SATURATE: number; + readonly SRC_COLOR: number; + readonly STATIC_DRAW: number; + readonly STENCIL_ATTACHMENT: number; + readonly STENCIL_BACK_FAIL: number; + readonly STENCIL_BACK_FUNC: number; + readonly STENCIL_BACK_PASS_DEPTH_FAIL: number; + readonly STENCIL_BACK_PASS_DEPTH_PASS: number; + readonly STENCIL_BACK_REF: number; + readonly STENCIL_BACK_VALUE_MASK: number; + readonly STENCIL_BACK_WRITEMASK: number; + readonly STENCIL_BITS: number; + readonly STENCIL_BUFFER_BIT: number; + readonly STENCIL_CLEAR_VALUE: number; + readonly STENCIL_FAIL: number; + readonly STENCIL_FUNC: number; + readonly STENCIL_INDEX: number; + readonly STENCIL_INDEX8: number; + readonly STENCIL_PASS_DEPTH_FAIL: number; + readonly STENCIL_PASS_DEPTH_PASS: number; + readonly STENCIL_REF: number; + readonly STENCIL_TEST: number; + readonly STENCIL_VALUE_MASK: number; + readonly STENCIL_WRITEMASK: number; + readonly STREAM_DRAW: number; + readonly SUBPIXEL_BITS: number; + readonly TEXTURE: number; + readonly TEXTURE0: number; + readonly TEXTURE1: number; + readonly TEXTURE10: number; + readonly TEXTURE11: number; + readonly TEXTURE12: number; + readonly TEXTURE13: number; + readonly TEXTURE14: number; + readonly TEXTURE15: number; + readonly TEXTURE16: number; + readonly TEXTURE17: number; + readonly TEXTURE18: number; + readonly TEXTURE19: number; + readonly TEXTURE2: number; + readonly TEXTURE20: number; + readonly TEXTURE21: number; + readonly TEXTURE22: number; + readonly TEXTURE23: number; + readonly TEXTURE24: number; + readonly TEXTURE25: number; + readonly TEXTURE26: number; + readonly TEXTURE27: number; + readonly TEXTURE28: number; + readonly TEXTURE29: number; + readonly TEXTURE3: number; + readonly TEXTURE30: number; + readonly TEXTURE31: number; + readonly TEXTURE4: number; + readonly TEXTURE5: number; + readonly TEXTURE6: number; + readonly TEXTURE7: number; + readonly TEXTURE8: number; + readonly TEXTURE9: number; + readonly TEXTURE_2D: number; + readonly TEXTURE_BINDING_2D: number; + readonly TEXTURE_BINDING_CUBE_MAP: number; + readonly TEXTURE_CUBE_MAP: number; + readonly TEXTURE_CUBE_MAP_NEGATIVE_X: number; + readonly TEXTURE_CUBE_MAP_NEGATIVE_Y: number; + readonly TEXTURE_CUBE_MAP_NEGATIVE_Z: number; + readonly TEXTURE_CUBE_MAP_POSITIVE_X: number; + readonly TEXTURE_CUBE_MAP_POSITIVE_Y: number; + readonly TEXTURE_CUBE_MAP_POSITIVE_Z: number; + readonly TEXTURE_MAG_FILTER: number; + readonly TEXTURE_MIN_FILTER: number; + readonly TEXTURE_WRAP_S: number; + readonly TEXTURE_WRAP_T: number; + readonly TRIANGLES: number; + readonly TRIANGLE_FAN: number; + readonly TRIANGLE_STRIP: number; + readonly UNPACK_ALIGNMENT: number; + readonly UNPACK_COLORSPACE_CONVERSION_WEBGL: number; + readonly UNPACK_FLIP_Y_WEBGL: number; + readonly UNPACK_PREMULTIPLY_ALPHA_WEBGL: number; + readonly UNSIGNED_BYTE: number; + readonly UNSIGNED_INT: number; + readonly UNSIGNED_SHORT: number; + readonly UNSIGNED_SHORT_4_4_4_4: number; + readonly UNSIGNED_SHORT_5_5_5_1: number; + readonly UNSIGNED_SHORT_5_6_5: number; + readonly VALIDATE_STATUS: number; + readonly VENDOR: number; + readonly VERSION: number; + readonly VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: number; + readonly VERTEX_ATTRIB_ARRAY_ENABLED: number; + readonly VERTEX_ATTRIB_ARRAY_NORMALIZED: number; + readonly VERTEX_ATTRIB_ARRAY_POINTER: number; + readonly VERTEX_ATTRIB_ARRAY_SIZE: number; + readonly VERTEX_ATTRIB_ARRAY_STRIDE: number; + readonly VERTEX_ATTRIB_ARRAY_TYPE: number; + readonly VERTEX_SHADER: number; + readonly VIEWPORT: number; + readonly ZERO: number; + + /* WebGL2 constants */ + readonly READ_BUFFER: number; // 0x0C02 + readonly UNPACK_ROW_LENGTH: number; // 0x0CF2 + readonly UNPACK_SKIP_ROWS: number; // 0x0CF3 + readonly UNPACK_SKIP_PIXELS: number; // 0x0CF4 + readonly PACK_ROW_LENGTH: number; // 0x0D02 + readonly PACK_SKIP_ROWS: number; // 0x0D03 + readonly PACK_SKIP_PIXELS: number; // 0x0D04 + readonly COLOR: number; // 0x1800 + readonly DEPTH: number; // 0x1801 + readonly STENCIL: number; // 0x1802 + readonly RED: number; // 0x1903 + readonly RGB8: number; // 0x8051 + readonly RGBA8: number; // 0x8058 + readonly RGB10_A2: number; // 0x8059 + readonly TEXTURE_BINDING_3D: number; // 0x806A + readonly UNPACK_SKIP_IMAGES: number; // 0x806D + readonly UNPACK_IMAGE_HEIGHT: number; // 0x806E + readonly TEXTURE_3D: number; // 0x806F + readonly TEXTURE_WRAP_R: number; // 0x8072 + readonly MAX_3D_TEXTURE_SIZE: number; // 0x8073 + readonly UNSIGNED_INT_2_10_10_10_REV: number; // 0x8368 + readonly MAX_ELEMENTS_VERTICES: number; // 0x80E8 + readonly MAX_ELEMENTS_INDICES: number; // 0x80E9 + readonly TEXTURE_MIN_LOD: number; // 0x813A + readonly TEXTURE_MAX_LOD: number; // 0x813B + readonly TEXTURE_BASE_LEVEL: number; // 0x813C + readonly TEXTURE_MAX_LEVEL: number; // 0x813D + readonly MIN: number; // 0x8007 + readonly MAX: number; // 0x8008 + readonly DEPTH_COMPONENT24: number; // 0x81A6 + readonly MAX_TEXTURE_LOD_BIAS: number; // 0x84FD + readonly TEXTURE_COMPARE_MODE: number; // 0x884C + readonly TEXTURE_COMPARE_FUNC: number; // 0x884D + readonly CURRENT_QUERY: number; // 0x8865 + readonly QUERY_RESULT: number; // 0x8866 + readonly QUERY_RESULT_AVAILABLE: number; // 0x8867 + readonly STREAM_READ: number; // 0x88E1 + readonly STREAM_COPY: number; // 0x88E2 + readonly STATIC_READ: number; // 0x88E5 + readonly STATIC_COPY: number; // 0x88E6 + readonly DYNAMIC_READ: number; // 0x88E9 + readonly DYNAMIC_COPY: number; // 0x88EA + readonly MAX_DRAW_BUFFERS: number; // 0x8824 + readonly DRAW_BUFFER0: number; // 0x8825 + readonly DRAW_BUFFER1: number; // 0x8826 + readonly DRAW_BUFFER2: number; // 0x8827 + readonly DRAW_BUFFER3: number; // 0x8828 + readonly DRAW_BUFFER4: number; // 0x8829 + readonly DRAW_BUFFER5: number; // 0x882A + readonly DRAW_BUFFER6: number; // 0x882B + readonly DRAW_BUFFER7: number; // 0x882C + readonly DRAW_BUFFER8: number; // 0x882D + readonly DRAW_BUFFER9: number; // 0x882E + readonly DRAW_BUFFER10: number; // 0x882F + readonly DRAW_BUFFER11: number; // 0x8830 + readonly DRAW_BUFFER12: number; // 0x8831 + readonly DRAW_BUFFER13: number; // 0x8832 + readonly DRAW_BUFFER14: number; // 0x8833 + readonly DRAW_BUFFER15: number; // 0x8834 + readonly MAX_FRAGMENT_UNIFORM_COMPONENTS: number; // 0x8B49 + readonly MAX_VERTEX_UNIFORM_COMPONENTS: number; // 0x8B4A + readonly SAMPLER_3D: number; // 0x8B5F + readonly SAMPLER_2D_SHADOW: number; // 0x8B62 + readonly FRAGMENT_SHADER_DERIVATIVE_HINT: number; // 0x8B8B + readonly PIXEL_PACK_BUFFER: number; // 0x88EB + readonly PIXEL_UNPACK_BUFFER: number; // 0x88EC + readonly PIXEL_PACK_BUFFER_BINDING: number; // 0x88ED + readonly PIXEL_UNPACK_BUFFER_BINDING: number; // 0x88EF + readonly FLOAT_MAT2x3: number; // 0x8B65 + readonly FLOAT_MAT2x4: number; // 0x8B66 + readonly FLOAT_MAT3x2: number; // 0x8B67 + readonly FLOAT_MAT3x4: number; // 0x8B68 + readonly FLOAT_MAT4x2: number; // 0x8B69 + readonly FLOAT_MAT4x3: number; // 0x8B6A + readonly SRGB: number; // 0x8C40 + readonly SRGB8: number; // 0x8C41 + readonly SRGB8_ALPHA8: number; // 0x8C43 + readonly COMPARE_REF_TO_TEXTURE: number; // 0x884E + readonly RGBA32F: number; // 0x8814 + readonly RGB32F: number; // 0x8815 + readonly RGBA16F: number; // 0x881A + readonly RGB16F: number; // 0x881B + readonly VERTEX_ATTRIB_ARRAY_INTEGER: number; // 0x88FD + readonly MAX_ARRAY_TEXTURE_LAYERS: number; // 0x88FF + readonly MIN_PROGRAM_TEXEL_OFFSET: number; // 0x8904 + readonly MAX_PROGRAM_TEXEL_OFFSET: number; // 0x8905 + readonly MAX_VARYING_COMPONENTS: number; // 0x8B4B + readonly TEXTURE_2D_ARRAY: number; // 0x8C1A + readonly TEXTURE_BINDING_2D_ARRAY: number; // 0x8C1D + readonly R11F_G11F_B10F: number; // 0x8C3A + readonly UNSIGNED_INT_10F_11F_11F_REV: number; // 0x8C3B + readonly RGB9_E5: number; // 0x8C3D + readonly UNSIGNED_INT_5_9_9_9_REV: number; // 0x8C3E + readonly TRANSFORM_FEEDBACK_BUFFER_MODE: number; // 0x8C7F + readonly MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS: number; // 0x8C80 + readonly TRANSFORM_FEEDBACK_VARYINGS: number; // 0x8C83 + readonly TRANSFORM_FEEDBACK_BUFFER_START: number; // 0x8C84 + readonly TRANSFORM_FEEDBACK_BUFFER_SIZE: number; // 0x8C85 + readonly TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN: number; // 0x8C88 + readonly RASTERIZER_DISCARD: number; // 0x8C89 + readonly MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS: number; // 0x8C8A + readonly MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS: number; // 0x8C8B + readonly INTERLEAVED_ATTRIBS: number; // 0x8C8C + readonly SEPARATE_ATTRIBS: number; // 0x8C8D + readonly TRANSFORM_FEEDBACK_BUFFER: number; // 0x8C8E + readonly TRANSFORM_FEEDBACK_BUFFER_BINDING: number; // 0x8C8F + readonly RGBA32UI: number; // 0x8D70 + readonly RGB32UI: number; // 0x8D71 + readonly RGBA16UI: number; // 0x8D76 + readonly RGB16UI: number; // 0x8D77 + readonly RGBA8UI: number; // 0x8D7C + readonly RGB8UI: number; // 0x8D7D + readonly RGBA32I: number; // 0x8D82 + readonly RGB32I: number; // 0x8D83 + readonly RGBA16I: number; // 0x8D88 + readonly RGB16I: number; // 0x8D89 + readonly RGBA8I: number; // 0x8D8E + readonly RGB8I: number; // 0x8D8F + readonly RED_INTEGER: number; // 0x8D94 + readonly RGB_INTEGER: number; // 0x8D98 + readonly RGBA_INTEGER: number; // 0x8D99 + readonly SAMPLER_2D_ARRAY: number; // 0x8DC1 + readonly SAMPLER_2D_ARRAY_SHADOW: number; // 0x8DC4 + readonly SAMPLER_CUBE_SHADOW: number; // 0x8DC5 + readonly UNSIGNED_INT_VEC2: number; // 0x8DC6 + readonly UNSIGNED_INT_VEC3: number; // 0x8DC7 + readonly UNSIGNED_INT_VEC4: number; // 0x8DC8 + readonly INT_SAMPLER_2D: number; // 0x8DCA + readonly INT_SAMPLER_3D: number; // 0x8DCB + readonly INT_SAMPLER_CUBE: number; // 0x8DCC + readonly INT_SAMPLER_2D_ARRAY: number; // 0x8DCF + readonly UNSIGNED_INT_SAMPLER_2D: number; // 0x8DD2 + readonly UNSIGNED_INT_SAMPLER_3D: number; // 0x8DD3 + readonly UNSIGNED_INT_SAMPLER_CUBE: number; // 0x8DD4 + readonly UNSIGNED_INT_SAMPLER_2D_ARRAY: number; // 0x8DD7 + readonly DEPTH_COMPONENT32F: number; // 0x8CAC + readonly DEPTH32F_STENCIL8: number; // 0x8CAD + readonly FLOAT_32_UNSIGNED_INT_24_8_REV: number; // 0x8DAD + readonly FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING: number; // 0x8210 + readonly FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE: number; // 0x8211 + readonly FRAMEBUFFER_ATTACHMENT_RED_SIZE: number; // 0x8212 + readonly FRAMEBUFFER_ATTACHMENT_GREEN_SIZE: number; // 0x8213 + readonly FRAMEBUFFER_ATTACHMENT_BLUE_SIZE: number; // 0x8214 + readonly FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE: number; // 0x8215 + readonly FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE: number; // 0x8216 + readonly FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE: number; // 0x8217 + readonly FRAMEBUFFER_DEFAULT: number; // 0x8218 + //readonly DEPTH_STENCIL_ATTACHMENT: number; // 0x821A /* Already defined in WebGL1 constants */ + //readonly DEPTH_STENCIL: number; // 0x84F9 /* Already defined in WebGL1 constants */ + readonly UNSIGNED_INT_24_8: number; // 0x84FA + readonly DEPTH24_STENCIL8: number; // 0x88F0 + readonly UNSIGNED_NORMALIZED: number; // 0x8C17 + readonly DRAW_FRAMEBUFFER_BINDING: number; // 0x8CA6 /* Same as FRAMEBUFFER_BINDING */ + readonly READ_FRAMEBUFFER: number; // 0x8CA8 + readonly DRAW_FRAMEBUFFER: number; // 0x8CA9 + readonly READ_FRAMEBUFFER_BINDING: number; // 0x8CAA + readonly RENDERBUFFER_SAMPLES: number; // 0x8CAB + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER: number; // 0x8CD4 + readonly MAX_COLOR_ATTACHMENTS: number; // 0x8CDF + readonly COLOR_ATTACHMENT1: number; // 0x8CE1 + readonly COLOR_ATTACHMENT2: number; // 0x8CE2 + readonly COLOR_ATTACHMENT3: number; // 0x8CE3 + readonly COLOR_ATTACHMENT4: number; // 0x8CE4 + readonly COLOR_ATTACHMENT5: number; // 0x8CE5 + readonly COLOR_ATTACHMENT6: number; // 0x8CE6 + readonly COLOR_ATTACHMENT7: number; // 0x8CE7 + readonly COLOR_ATTACHMENT8: number; // 0x8CE8 + readonly COLOR_ATTACHMENT9: number; // 0x8CE9 + readonly COLOR_ATTACHMENT10: number; // 0x8CEA + readonly COLOR_ATTACHMENT11: number; // 0x8CEB + readonly COLOR_ATTACHMENT12: number; // 0x8CEC + readonly COLOR_ATTACHMENT13: number; // 0x8CED + readonly COLOR_ATTACHMENT14: number; // 0x8CEE + readonly COLOR_ATTACHMENT15: number; // 0x8CEF + readonly FRAMEBUFFER_INCOMPLETE_MULTISAMPLE: number; // 0x8D56 + readonly MAX_SAMPLES: number; // 0x8D57 + readonly HALF_FLOAT: number; // 0x140B + readonly RG: number; // 0x8227 + readonly RG_INTEGER: number; // 0x8228 + readonly R8: number; // 0x8229 + readonly RG8: number; // 0x822B + readonly R16F: number; // 0x822D + readonly R32F: number; // 0x822E + readonly RG16F: number; // 0x822F + readonly RG32F: number; // 0x8230 + readonly R8I: number; // 0x8231 + readonly R8UI: number; // 0x8232 + readonly R16I: number; // 0x8233 + readonly R16UI: number; // 0x8234 + readonly R32I: number; // 0x8235 + readonly R32UI: number; // 0x8236 + readonly RG8I: number; // 0x8237 + readonly RG8UI: number; // 0x8238 + readonly RG16I: number; // 0x8239 + readonly RG16UI: number; // 0x823A + readonly RG32I: number; // 0x823B + readonly RG32UI: number; // 0x823C + readonly VERTEX_ARRAY_BINDING: number; // 0x85B5 + readonly R8_SNORM: number; // 0x8F94 + readonly RG8_SNORM: number; // 0x8F95 + readonly RGB8_SNORM: number; // 0x8F96 + readonly RGBA8_SNORM: number; // 0x8F97 + readonly SIGNED_NORMALIZED: number; // 0x8F9C + readonly COPY_READ_BUFFER: number; // 0x8F36 + readonly COPY_WRITE_BUFFER: number; // 0x8F37 + readonly COPY_READ_BUFFER_BINDING: number; // 0x8F36 /* Same as COPY_READ_BUFFER */ + readonly COPY_WRITE_BUFFER_BINDING: number; // 0x8F37 /* Same as COPY_WRITE_BUFFER */ + readonly UNIFORM_BUFFER: number; // 0x8A11 + readonly UNIFORM_BUFFER_BINDING: number; // 0x8A28 + readonly UNIFORM_BUFFER_START: number; // 0x8A29 + readonly UNIFORM_BUFFER_SIZE: number; // 0x8A2A + readonly MAX_VERTEX_UNIFORM_BLOCKS: number; // 0x8A2B + readonly MAX_FRAGMENT_UNIFORM_BLOCKS: number; // 0x8A2D + readonly MAX_COMBINED_UNIFORM_BLOCKS: number; // 0x8A2E + readonly MAX_UNIFORM_BUFFER_BINDINGS: number; // 0x8A2F + readonly MAX_UNIFORM_BLOCK_SIZE: number; // 0x8A30 + readonly MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS: number; // 0x8A31 + readonly MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS: number; // 0x8A33 + readonly UNIFORM_BUFFER_OFFSET_ALIGNMENT: number; // 0x8A34 + readonly ACTIVE_UNIFORM_BLOCKS: number; // 0x8A36 + readonly UNIFORM_TYPE: number; // 0x8A37 + readonly UNIFORM_SIZE: number; // 0x8A38 + readonly UNIFORM_BLOCK_INDEX: number; // 0x8A3A + readonly UNIFORM_OFFSET: number; // 0x8A3B + readonly UNIFORM_ARRAY_STRIDE: number; // 0x8A3C + readonly UNIFORM_MATRIX_STRIDE: number; // 0x8A3D + readonly UNIFORM_IS_ROW_MAJOR: number; // 0x8A3E + readonly UNIFORM_BLOCK_BINDING: number; // 0x8A3F + readonly UNIFORM_BLOCK_DATA_SIZE: number; // 0x8A40 + readonly UNIFORM_BLOCK_ACTIVE_UNIFORMS: number; // 0x8A42 + readonly UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES: number; // 0x8A43 + readonly UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER: number; // 0x8A44 + readonly UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER: number; // 0x8A46 + readonly INVALID_INDEX: number; // 0xFFFFFFFF + readonly MAX_VERTEX_OUTPUT_COMPONENTS: number; // 0x9122 + readonly MAX_FRAGMENT_INPUT_COMPONENTS: number; // 0x9125 + readonly MAX_SERVER_WAIT_TIMEOUT: number; // 0x9111 + readonly OBJECT_TYPE: number; // 0x9112 + readonly SYNC_CONDITION: number; // 0x9113 + readonly SYNC_STATUS: number; // 0x9114 + readonly SYNC_FLAGS: number; // 0x9115 + readonly SYNC_FENCE: number; // 0x9116 + readonly SYNC_GPU_COMMANDS_COMPLETE: number; // 0x9117 + readonly UNSIGNALED: number; // 0x9118 + readonly SIGNALED: number; // 0x9119 + readonly ALREADY_SIGNALED: number; // 0x911A + readonly TIMEOUT_EXPIRED: number; // 0x911B + readonly CONDITION_SATISFIED: number; // 0x911C + readonly WAIT_FAILED: number; // 0x911D + readonly SYNC_FLUSH_COMMANDS_BIT: number; // 0x00000001 + readonly VERTEX_ATTRIB_ARRAY_DIVISOR: number; // 0x88FE + readonly ANY_SAMPLES_PASSED: number; // 0x8C2F + readonly ANY_SAMPLES_PASSED_CONSERVATIVE: number; // 0x8D6A + readonly SAMPLER_BINDING: number; // 0x8919 + readonly RGB10_A2UI: number; // 0x906F + readonly INT_2_10_10_10_REV: number; // 0x8D9F + readonly TRANSFORM_FEEDBACK: number; // 0x8E22 + readonly TRANSFORM_FEEDBACK_PAUSED: number; // 0x8E23 + readonly TRANSFORM_FEEDBACK_ACTIVE: number; // 0x8E24 + readonly TRANSFORM_FEEDBACK_BINDING: number; // 0x8E25 + readonly TEXTURE_IMMUTABLE_FORMAT: number; // 0x912F + readonly MAX_ELEMENT_INDEX: number; // 0x8D6B + readonly TEXTURE_IMMUTABLE_LEVELS: number; // 0x82DF + + readonly TIMEOUT_IGNORED: number; // -1 + + /* WebGL-specific enums */ + readonly MAX_CLIENT_WAIT_TIMEOUT_WEBGL: number; // 0x9247 +}; + +interface WebGLQuery extends WebGLObject { +} + +declare var WebGLQuery: { + prototype: WebGLQuery; + new (): WebGLQuery; +}; + +interface WebGLSampler extends WebGLObject { +} + +declare var WebGLSampler: { + prototype: WebGLSampler; + new (): WebGLSampler; +}; + +interface WebGLSync extends WebGLObject { +} + +declare var WebGLSync: { + prototype: WebGLSync; + new (): WebGLSync; +}; + +interface WebGLTransformFeedback extends WebGLObject { +} + +declare var WebGLTransformFeedback: { + prototype: WebGLTransformFeedback; + new (): WebGLTransformFeedback; +}; + +interface WebGLVertexArrayObject extends WebGLObject { +} + +declare var WebGLVertexArrayObject: { + prototype: WebGLVertexArrayObject; + new (): WebGLVertexArrayObject; +}; diff --git a/node_modules/@types/webgl2/package.json b/node_modules/@types/webgl2/package.json new file mode 100644 index 0000000..7cc91f5 --- /dev/null +++ b/node_modules/@types/webgl2/package.json @@ -0,0 +1,51 @@ +{ + "_from": "@types/webgl2@~0.0.4", + "_id": "@types/webgl2@0.0.4", + "_inBundle": false, + "_integrity": "sha512-PACt1xdErJbMUOUweSrbVM7gSIYm1vTncW2hF6Os/EeWi6TXYAYMPp+8v6rzHmypE5gHrxaxZNXgMkJVIdZpHw==", + "_location": "/@types/webgl2", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/webgl2@~0.0.4", + "name": "@types/webgl2", + "escapedName": "@types%2fwebgl2", + "scope": "@types", + "rawSpec": "~0.0.4", + "saveSpec": null, + "fetchSpec": "~0.0.4" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-core" + ], + "_resolved": "https://registry.npmjs.org/@types/webgl2/-/webgl2-0.0.4.tgz", + "_shasum": "c3b0f9d6b465c66138e84e64cb3bdf8373c2c279", + "_spec": "@types/webgl2@~0.0.4", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-core", + "bundleDependencies": false, + "contributors": [ + { + "name": "Nico Kemnitz", + "url": "https://github.com/nkemnitz" + }, + { + "name": "Adrian Blumer", + "url": "https://github.com/karhu" + } + ], + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for WebGL 2, Editor's Draft Fri Feb 24 16:10:18 2017 -0800", + "license": "MIT", + "main": "", + "name": "@types/webgl2", + "repository": { + "type": "git", + "url": "https://www.github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typeScriptVersion": "2.0", + "typesPublisherContentHash": "4b06a12ad7c8229a033ac12d69a54d58274e48369d24481a61e344c8605d3d2f", + "version": "0.0.4" +} diff --git a/node_modules/coffeescript/LICENSE b/node_modules/coffeescript/LICENSE new file mode 100644 index 0000000..0393a55 --- /dev/null +++ b/node_modules/coffeescript/LICENSE @@ -0,0 +1,22 @@ +Copyright (c) 2009-2018 Jeremy Ashkenas + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/coffeescript/README.md b/node_modules/coffeescript/README.md new file mode 100644 index 0000000..f495879 --- /dev/null +++ b/node_modules/coffeescript/README.md @@ -0,0 +1,66 @@ +``` + @@@@@@@ @@@@ @@@@@ + @@@@@@@@@@ @@@ @@@ { + @@@@ @@ @@@ @@@ } } { + @@@@ @@@@@@@ @@@ @@@ @@@@@@ @@@@@@ { { } } + @@@@ @@@ @@ @@@@@ @@@@@@ @@@ @@ @@@@ @@ } }{ { + @@@@ @@@@ @@ @@@ @@@ @@@ @@@ @@@ @@@ { }{ } } + @@@@ @@@@ @@ @@@ @@@ @@@@@@@@ @@@@@@@@ { }{ }{ { } + @@@@@ @@@@ @@ @@@ @@@ @@@ @@@ { { } { } { } } + @@@@@@@@@@ @@@@@@@@ @@@ @@@ @@@@@@@@ @@@@@@@@ { } { } { } + @@@@@ @@@ @@@ @@@@@ @@@@@ @@@@@@ { } { } @@@@@@@ + @@@ @@@ @@@@@@@@@@@@@@@@@@@@@@@@@@@@ + @@@@@@ @@@ @@@ @@ @@@@@@@@@@@@@@@@@@@@@@@@@@ + @@@@ @@ @@@ @@@@ @@ @@@@@@@@@@@@@@@@@@@@@@@@ + @@@@ @@@ @@ @@@@ @@@ @@@@@@@@@@@@@@@@@@@@@ + @@@@@ @@@@@ @@ @@ @@@ @@@@@@@ @@@@@ @@@ @@@@@@@@@@@@@@@@@@ + @@@@@ @@@ @@@ @@@@@@@@ @@@@ @@@@ @@@@@@@ @@@ @@@@@@@@@@@@@@@@ + @@@@@ @@@ @@@@ @@@@ @@@ @@@ @@@ @@@@@@@@@@@@@@ + @@@@@ @@@@ @@@@ @@@@ @@@@ @@@@ @@@@ @@@@ +@@@ @@@@ @@@ @@@@ @@@@ @@@ @@@@ @@@@ +@@@ @@@@ @@@@ @@@@ @@@@ @@@@ @@@@ @@@@ + @@@@@@@@@ @@@@@@ @@@@ @@@@ @@@@@@@@@ @@@@ + @@@ @@@@ + @@@ + @@@ +``` + +CoffeeScript is a little language that compiles into JavaScript. + +## Installation + +Once you have Node.js installed: + +```shell +# Install locally for a project: +npm install --save-dev coffeescript + +# Install globally to execute .coffee files anywhere: +npm install --global coffeescript +``` + +## Getting Started + +Execute a script: + +```shell +coffee /path/to/script.coffee +``` + +Compile a script: + +```shell +coffee -c /path/to/script.coffee +``` + +For documentation, usage, and examples, see: https://coffeescript.org/ + +To suggest a feature or report a bug: https://github.com/jashkenas/coffeescript/issues + +If you’d like to chat, drop by #coffeescript on Freenode IRC. + +The source repository: https://github.com/jashkenas/coffeescript.git + +Changelog: https://coffeescript.org/#changelog + +Our lovely and talented contributors are listed here: https://github.com/jashkenas/coffeescript/contributors diff --git a/node_modules/coffeescript/bin/cake b/node_modules/coffeescript/bin/cake new file mode 100644 index 0000000..067cabb --- /dev/null +++ b/node_modules/coffeescript/bin/cake @@ -0,0 +1,25 @@ +#!/usr/bin/env node + +try { + new Function('var {a} = {a: 1}')(); +} catch (error) { + console.error('Your JavaScript runtime does not support some features used by the cake command. Please use Node 6 or later.'); + process.exit(1); +} + +var path = require('path'); +var fs = require('fs'); + +var potentialPaths = [ + path.join(process.cwd(), 'node_modules/coffeescript/lib/coffeescript'), + path.join(process.cwd(), 'node_modules/coffeescript/lib/coffee-script'), + path.join(process.cwd(), 'node_modules/coffee-script/lib/coffee-script'), + path.join(__dirname, '../lib/coffeescript') +]; + +for (var i = 0, len = potentialPaths.length; i < len; i++) { + if (fs.existsSync(potentialPaths[i])) { + require(potentialPaths[i] + '/cake').run(); + break; + } +} diff --git a/node_modules/coffeescript/bin/coffee b/node_modules/coffeescript/bin/coffee new file mode 100644 index 0000000..9ebc45e --- /dev/null +++ b/node_modules/coffeescript/bin/coffee @@ -0,0 +1,25 @@ +#!/usr/bin/env node + +try { + new Function('var {a} = {a: 1}')(); +} catch (error) { + console.error('Your JavaScript runtime does not support some features used by the coffee command. Please use Node 6 or later.'); + process.exit(1); +} + +var path = require('path'); +var fs = require('fs'); + +var potentialPaths = [ + path.join(process.cwd(), 'node_modules/coffeescript/lib/coffeescript'), + path.join(process.cwd(), 'node_modules/coffeescript/lib/coffee-script'), + path.join(process.cwd(), 'node_modules/coffee-script/lib/coffee-script'), + path.join(__dirname, '../lib/coffeescript') +]; + +for (var i = 0, len = potentialPaths.length; i < len; i++) { + if (fs.existsSync(potentialPaths[i])) { + require(potentialPaths[i] + '/command').run(); + break; + } +} diff --git a/node_modules/coffeescript/lib/.DS_Store b/node_modules/coffeescript/lib/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..ebe65296dedf1222979d714c81651433c08960af GIT binary patch literal 6148 zcmeHK%}N6?5T3MEx2V{Ipm^Ggw;r}C{v3p*)`K@;MGq?Nu3hay-IVUuqP4Q`p>N~^ z_&UxcX|YsqB2s3;1y=DcV1OOH)VXlbPH$wfSQ<5_tLZQY8A%p~O zpbODdG&}wy1GINbxMLD-v3%XX4x~Xp=>%;VV9a~aX-7%wI3FUHFU-v^SVb($*0tA? zeJ}OXUQ+eDm()7-(^g>YGb!6++Yip8uwO5&9?3ZMqd4rU2Fw9xEzZn}cp=OHGw@ps(D`7a61oO6 zjq2#Yihdudzd%TWHoYYXZG*1COe6N72%U= 0) { + results.push(s); + } + } + return results; + })(); + index = 0; + execute = function() { + var param; + param = coffees[index]; + if (param instanceof Array) { + CoffeeScript.run(...param); + index++; + return execute(); + } + }; + for (i = j = 0, len = coffees.length; j < len; i = ++j) { + script = coffees[i]; + (function(script, i) { + var options, source; + options = { + literate: script.type === coffeetypes[1] + }; + source = script.src || script.getAttribute('data-src'); + if (source) { + options.filename = source; + return CoffeeScript.load(source, function(param) { + coffees[i] = param; + return execute(); + }, options, true); + } else { + // `options.filename` defines the filename the source map appears as + // in Developer Tools. If a script tag has an `id`, use that as the + // filename; otherwise use `coffeescript`, or `coffeescript1` etc., + // leaving the first one unnumbered for the common case that there’s + // only one CoffeeScript script block to parse. + options.filename = script.id && script.id !== '' ? script.id : `coffeescript${(i !== 0 ? i : '')}`; + options.sourceFiles = ['embedded']; + return coffees[i] = [script.innerHTML, options]; + } + })(script, i); + } + return execute(); + }; + + // Listen for window load, both in decent browsers and in IE. + if (window.addEventListener) { + window.addEventListener('DOMContentLoaded', runScripts, false); + } else { + window.attachEvent('onload', runScripts); + } + +}).call(this); diff --git a/node_modules/coffeescript/lib/coffeescript/cake.js b/node_modules/coffeescript/lib/coffeescript/cake.js new file mode 100644 index 0000000..b1afffd --- /dev/null +++ b/node_modules/coffeescript/lib/coffeescript/cake.js @@ -0,0 +1,135 @@ +// Generated by CoffeeScript 2.3.1 +(function() { + // `cake` is a simplified version of [Make](http://www.gnu.org/software/make/) + // ([Rake](http://rake.rubyforge.org/), [Jake](https://github.com/280north/jake)) + // for CoffeeScript. You define tasks with names and descriptions in a Cakefile, + // and can call them from the command line, or invoke them from other tasks. + + // Running `cake` with no arguments will print out a list of all the tasks in the + // current directory's Cakefile. + + // External dependencies. + var CoffeeScript, cakefileDirectory, fatalError, fs, helpers, missingTask, oparse, options, optparse, path, printTasks, switches, tasks; + + fs = require('fs'); + + path = require('path'); + + helpers = require('./helpers'); + + optparse = require('./optparse'); + + CoffeeScript = require('./'); + + // Register .coffee extension + CoffeeScript.register(); + + // Keep track of the list of defined tasks, the accepted options, and so on. + tasks = {}; + + options = {}; + + switches = []; + + oparse = null; + + // Mixin the top-level Cake functions for Cakefiles to use directly. + helpers.extend(global, { + // Define a Cake task with a short name, an optional sentence description, + // and the function to run as the action itself. + task: function(name, description, action) { + if (!action) { + [action, description] = [description, action]; + } + return tasks[name] = {name, description, action}; + }, + // Define an option that the Cakefile accepts. The parsed options hash, + // containing all of the command-line options passed, will be made available + // as the first argument to the action. + option: function(letter, flag, description) { + return switches.push([letter, flag, description]); + }, + // Invoke another task in the current Cakefile. + invoke: function(name) { + if (!tasks[name]) { + missingTask(name); + } + return tasks[name].action(options); + } + }); + + // Run `cake`. Executes all of the tasks you pass, in order. Note that Node's + // asynchrony may cause tasks to execute in a different order than you'd expect. + // If no tasks are passed, print the help screen. Keep a reference to the + // original directory name, when running Cake tasks from subdirectories. + exports.run = function() { + var arg, args, e, i, len, ref, results; + global.__originalDirname = fs.realpathSync('.'); + process.chdir(cakefileDirectory(__originalDirname)); + args = process.argv.slice(2); + CoffeeScript.run(fs.readFileSync('Cakefile').toString(), { + filename: 'Cakefile' + }); + oparse = new optparse.OptionParser(switches); + if (!args.length) { + return printTasks(); + } + try { + options = oparse.parse(args); + } catch (error) { + e = error; + return fatalError(`${e}`); + } + ref = options.arguments; + results = []; + for (i = 0, len = ref.length; i < len; i++) { + arg = ref[i]; + results.push(invoke(arg)); + } + return results; + }; + + // Display the list of Cake tasks in a format similar to `rake -T` + printTasks = function() { + var cakefilePath, desc, name, relative, spaces, task; + relative = path.relative || path.resolve; + cakefilePath = path.join(relative(__originalDirname, process.cwd()), 'Cakefile'); + console.log(`${cakefilePath} defines the following tasks:\n`); + for (name in tasks) { + task = tasks[name]; + spaces = 20 - name.length; + spaces = spaces > 0 ? Array(spaces + 1).join(' ') : ''; + desc = task.description ? `# ${task.description}` : ''; + console.log(`cake ${name}${spaces} ${desc}`); + } + if (switches.length) { + return console.log(oparse.help()); + } + }; + + // Print an error and exit when attempting to use an invalid task/option. + fatalError = function(message) { + console.error(message + '\n'); + console.log('To see a list of all tasks/options, run "cake"'); + return process.exit(1); + }; + + missingTask = function(task) { + return fatalError(`No such task: ${task}`); + }; + + // When `cake` is invoked, search in the current and all parent directories + // to find the relevant Cakefile. + cakefileDirectory = function(dir) { + var parent; + if (fs.existsSync(path.join(dir, 'Cakefile'))) { + return dir; + } + parent = path.normalize(path.join(dir, '..')); + if (parent !== dir) { + return cakefileDirectory(parent); + } + throw new Error(`Cakefile not found in ${process.cwd()}`); + }; + +}).call(this); diff --git a/node_modules/coffeescript/lib/coffeescript/coffeescript.js b/node_modules/coffeescript/lib/coffeescript/coffeescript.js new file mode 100644 index 0000000..4fb7883 --- /dev/null +++ b/node_modules/coffeescript/lib/coffeescript/coffeescript.js @@ -0,0 +1,438 @@ +// Generated by CoffeeScript 2.3.1 +(function() { + // CoffeeScript can be used both on the server, as a command-line compiler based + // on Node.js/V8, or to run CoffeeScript directly in the browser. This module + // contains the main entry functions for tokenizing, parsing, and compiling + // source CoffeeScript into JavaScript. + var FILE_EXTENSIONS, Lexer, SourceMap, base64encode, checkShebangLine, compile, formatSourcePosition, getSourceMap, helpers, lexer, packageJson, parser, sourceMaps, sources, withPrettyErrors, + indexOf = [].indexOf; + + ({Lexer} = require('./lexer')); + + ({parser} = require('./parser')); + + helpers = require('./helpers'); + + SourceMap = require('./sourcemap'); + + // Require `package.json`, which is two levels above this file, as this file is + // evaluated from `lib/coffeescript`. + packageJson = require('../../package.json'); + + // The current CoffeeScript version number. + exports.VERSION = packageJson.version; + + exports.FILE_EXTENSIONS = FILE_EXTENSIONS = ['.coffee', '.litcoffee', '.coffee.md']; + + // Expose helpers for testing. + exports.helpers = helpers; + + // Function that allows for btoa in both nodejs and the browser. + base64encode = function(src) { + switch (false) { + case typeof Buffer !== 'function': + return Buffer.from(src).toString('base64'); + case typeof btoa !== 'function': + // The contents of a ` +``` + +Production: + +``` + +``` + +**Remember** to replace the version tag with the exact [release](https://github.com/dcodeIO/protobuf.js/tags) your project depends upon. + +The library supports CommonJS and AMD loaders and also exports globally as `protobuf`. + +### Distributions + +Where bundle size is a factor, there are additional stripped-down versions of the [full library][dist-full] (~19kb gzipped) available that exclude certain functionality: + +* When working with JSON descriptors (i.e. generated by [pbjs](#pbjs-for-javascript)) and/or reflection only, see the [light library][dist-light] (~16kb gzipped) that excludes the parser. CommonJS entry point is: + + ```js + var protobuf = require("protobufjs/light"); + ``` + +* When working with statically generated code only, see the [minimal library][dist-minimal] (~6.5kb gzipped) that also excludes reflection. CommonJS entry point is: + + ```js + var protobuf = require("protobufjs/minimal"); + ``` + +[dist-full]: https://github.com/dcodeIO/protobuf.js/tree/master/dist +[dist-light]: https://github.com/dcodeIO/protobuf.js/tree/master/dist/light +[dist-minimal]: https://github.com/dcodeIO/protobuf.js/tree/master/dist/minimal + +Usage +----- + +Because JavaScript is a dynamically typed language, protobuf.js introduces the concept of a **valid message** in order to provide the best possible [performance](#performance) (and, as a side product, proper typings): + +### Valid message + +> A valid message is an object (1) not missing any required fields and (2) exclusively composed of JS types understood by the wire format writer. + +There are two possible types of valid messages and the encoder is able to work with both of these for convenience: + +* **Message instances** (explicit instances of message classes with default values on their prototype) always (have to) satisfy the requirements of a valid message by design and +* **Plain JavaScript objects** that just so happen to be composed in a way satisfying the requirements of a valid message as well. + +In a nutshell, the wire format writer understands the following types: + +| Field type | Expected JS type (create, encode) | Conversion (fromObject) +|------------|-----------------------------------|------------------------ +| s-/u-/int32
s-/fixed32 | `number` (32 bit integer) | value | 0 if signed
`value >>> 0` if unsigned +| s-/u-/int64
s-/fixed64 | `Long`-like (optimal)
`number` (53 bit integer) | `Long.fromValue(value)` with long.js
`parseInt(value, 10)` otherwise +| float
double | `number` | `Number(value)` +| bool | `boolean` | `Boolean(value)` +| string | `string` | `String(value)` +| bytes | `Uint8Array` (optimal)
`Buffer` (optimal under node)
`Array.` (8 bit integers) | `base64.decode(value)` if a `string`
`Object` with non-zero `.length` is assumed to be buffer-like +| enum | `number` (32 bit integer) | Looks up the numeric id if a `string` +| message | Valid message | `Message.fromObject(value)` + +* Explicit `undefined` and `null` are considered as not set if the field is optional. +* Repeated fields are `Array.`. +* Map fields are `Object.` with the key being the string representation of the respective value or an 8 characters long binary hash string for `Long`-likes. +* Types marked as *optimal* provide the best performance because no conversion step (i.e. number to low and high bits or base64 string to buffer) is required. + +### Toolset + +With that in mind and again for performance reasons, each message class provides a distinct set of methods with each method doing just one thing. This avoids unnecessary assertions / redundant operations where performance is a concern but also forces a user to perform verification (of plain JavaScript objects that *might* just so happen to be a valid message) explicitly where necessary - for example when dealing with user input. + +**Note** that `Message` below refers to any message class. + +* **Message.verify**(message: `Object`): `null|string`
+ verifies that a **plain JavaScript object** satisfies the requirements of a valid message and thus can be encoded without issues. Instead of throwing, it returns the error message as a string, if any. + + ```js + var payload = "invalid (not an object)"; + var err = AwesomeMessage.verify(payload); + if (err) + throw Error(err); + ``` + +* **Message.encode**(message: `Message|Object` [, writer: `Writer`]): `Writer`
+ encodes a **message instance** or valid **plain JavaScript object**. This method does not implicitly verify the message and it's up to the user to make sure that the payload is a valid message. + + ```js + var buffer = AwesomeMessage.encode(message).finish(); + ``` + +* **Message.encodeDelimited**(message: `Message|Object` [, writer: `Writer`]): `Writer`
+ works like `Message.encode` but additionally prepends the length of the message as a varint. + +* **Message.decode**(reader: `Reader|Uint8Array`): `Message`
+ decodes a buffer to a **message instance**. If required fields are missing, it throws a `util.ProtocolError` with an `instance` property set to the so far decoded message. If the wire format is invalid, it throws an `Error`. + + ```js + try { + var decodedMessage = AwesomeMessage.decode(buffer); + } catch (e) { + if (e instanceof protobuf.util.ProtocolError) { + // e.instance holds the so far decoded message with missing required fields + } else { + // wire format is invalid + } + } + ``` + +* **Message.decodeDelimited**(reader: `Reader|Uint8Array`): `Message`
+ works like `Message.decode` but additionally reads the length of the message prepended as a varint. + +* **Message.create**(properties: `Object`): `Message`
+ creates a new **message instance** from a set of properties that satisfy the requirements of a valid message. Where applicable, it is recommended to prefer `Message.create` over `Message.fromObject` because it doesn't perform possibly redundant conversion. + + ```js + var message = AwesomeMessage.create({ awesomeField: "AwesomeString" }); + ``` + +* **Message.fromObject**(object: `Object`): `Message`
+ converts any non-valid **plain JavaScript object** to a **message instance** using the conversion steps outlined within the table above. + + ```js + var message = AwesomeMessage.fromObject({ awesomeField: 42 }); + // converts awesomeField to a string + ``` + +* **Message.toObject**(message: `Message` [, options: `ConversionOptions`]): `Object`
+ converts a **message instance** to an arbitrary **plain JavaScript object** for interoperability with other libraries or storage. The resulting plain JavaScript object *might* still satisfy the requirements of a valid message depending on the actual conversion options specified, but most of the time it does not. + + ```js + var object = AwesomeMessage.toObject(message, { + enums: String, // enums as string names + longs: String, // longs as strings (requires long.js) + bytes: String, // bytes as base64 encoded strings + defaults: true, // includes default values + arrays: true, // populates empty arrays (repeated fields) even if defaults=false + objects: true, // populates empty objects (map fields) even if defaults=false + oneofs: true // includes virtual oneof fields set to the present field's name + }); + ``` + +For reference, the following diagram aims to display relationships between the different methods and the concept of a valid message: + +

Toolset Diagram

+ +> In other words: `verify` indicates that calling `create` or `encode` directly on the plain object will [result in a valid message respectively] succeed. `fromObject`, on the other hand, does conversion from a broader range of plain objects to create valid messages. ([ref](https://github.com/dcodeIO/protobuf.js/issues/748#issuecomment-291925749)) + +Examples +-------- + +### Using .proto files + +It is possible to load existing .proto files using the full library, which parses and compiles the definitions to ready to use (reflection-based) message classes: + +```protobuf +// awesome.proto +package awesomepackage; +syntax = "proto3"; + +message AwesomeMessage { + string awesome_field = 1; // becomes awesomeField +} +``` + +```js +protobuf.load("awesome.proto", function(err, root) { + if (err) + throw err; + + // Obtain a message type + var AwesomeMessage = root.lookupType("awesomepackage.AwesomeMessage"); + + // Exemplary payload + var payload = { awesomeField: "AwesomeString" }; + + // Verify the payload if necessary (i.e. when possibly incomplete or invalid) + var errMsg = AwesomeMessage.verify(payload); + if (errMsg) + throw Error(errMsg); + + // Create a new message + var message = AwesomeMessage.create(payload); // or use .fromObject if conversion is necessary + + // Encode a message to an Uint8Array (browser) or Buffer (node) + var buffer = AwesomeMessage.encode(message).finish(); + // ... do something with buffer + + // Decode an Uint8Array (browser) or Buffer (node) to a message + var message = AwesomeMessage.decode(buffer); + // ... do something with message + + // If the application uses length-delimited buffers, there is also encodeDelimited and decodeDelimited. + + // Maybe convert the message back to a plain object + var object = AwesomeMessage.toObject(message, { + longs: String, + enums: String, + bytes: String, + // see ConversionOptions + }); +}); +``` + +Additionally, promise syntax can be used by omitting the callback, if preferred: + +```js +protobuf.load("awesome.proto") + .then(function(root) { + ... + }); +``` + +### Using JSON descriptors + +The library utilizes JSON descriptors that are equivalent to a .proto definition. For example, the following is identical to the .proto definition seen above: + +```json +// awesome.json +{ + "nested": { + "AwesomeMessage": { + "fields": { + "awesomeField": { + "type": "string", + "id": 1 + } + } + } + } +} +``` + +JSON descriptors closely resemble the internal reflection structure: + +| Type (T) | Extends | Type-specific properties +|--------------------|--------------------|------------------------- +| *ReflectionObject* | | options +| *Namespace* | *ReflectionObject* | nested +| Root | *Namespace* | **nested** +| Type | *Namespace* | **fields** +| Enum | *ReflectionObject* | **values** +| Field | *ReflectionObject* | rule, **type**, **id** +| MapField | Field | **keyType** +| OneOf | *ReflectionObject* | **oneof** (array of field names) +| Service | *Namespace* | **methods** +| Method | *ReflectionObject* | type, **requestType**, **responseType**, requestStream, responseStream + +* **Bold properties** are required. *Italic types* are abstract. +* `T.fromJSON(name, json)` creates the respective reflection object from a JSON descriptor +* `T#toJSON()` creates a JSON descriptor from the respective reflection object (its name is used as the key within the parent) + +Exclusively using JSON descriptors instead of .proto files enables the use of just the light library (the parser isn't required in this case). + +A JSON descriptor can either be loaded the usual way: + +```js +protobuf.load("awesome.json", function(err, root) { + if (err) throw err; + + // Continue at "Obtain a message type" above +}); +``` + +Or it can be loaded inline: + +```js +var jsonDescriptor = require("./awesome.json"); // exemplary for node + +var root = protobuf.Root.fromJSON(jsonDescriptor); + +// Continue at "Obtain a message type" above +``` + +### Using reflection only + +Both the full and the light library include full reflection support. One could, for example, define the .proto definitions seen in the examples above using just reflection: + +```js +... +var Root = protobuf.Root, + Type = protobuf.Type, + Field = protobuf.Field; + +var AwesomeMessage = new Type("AwesomeMessage").add(new Field("awesomeField", 1, "string")); + +var root = new Root().define("awesomepackage").add(AwesomeMessage); + +// Continue at "Create a new message" above +... +``` + +Detailed information on the reflection structure is available within the [API documentation](#additional-documentation). + +### Using custom classes + +Message classes can also be extended with custom functionality and it is also possible to register a custom constructor with a reflected message type: + +```js +... + +// Define a custom constructor +function AwesomeMessage(properties) { + // custom initialization code + ... +} + +// Register the custom constructor with its reflected type (*) +root.lookupType("awesomepackage.AwesomeMessage").ctor = AwesomeMessage; + +// Define custom functionality +AwesomeMessage.customStaticMethod = function() { ... }; +AwesomeMessage.prototype.customInstanceMethod = function() { ... }; + +// Continue at "Create a new message" above +``` + +(*) Besides referencing its reflected type through `AwesomeMessage.$type` and `AwesomeMesage#$type`, the respective custom class is automatically populated with: + +* `AwesomeMessage.create` +* `AwesomeMessage.encode` and `AwesomeMessage.encodeDelimited` +* `AwesomeMessage.decode` and `AwesomeMessage.decodeDelimited` +* `AwesomeMessage.verify` +* `AwesomeMessage.fromObject`, `AwesomeMessage.toObject`, `AwesomeMessage#toObject` and `AwesomeMessage#toJSON` + +Afterwards, decoded messages of this type are `instanceof AwesomeMessage`. + +Alternatively, it is also possible to reuse and extend the internal constructor if custom initialization code is not required: + +```js +... + +// Reuse the internal constructor +var AwesomeMessage = root.lookupType("awesomepackage.AwesomeMessage").ctor; + +// Define custom functionality +AwesomeMessage.customStaticMethod = function() { ... }; +AwesomeMessage.prototype.customInstanceMethod = function() { ... }; + +// Continue at "Create a new message" above +``` + +### Using services + +The library also supports consuming services but it doesn't make any assumptions about the actual transport channel. Instead, a user must provide a suitable RPC implementation, which is an asynchronous function that takes the reflected service method, the binary request and a node-style callback as its parameters: + +```js +function rpcImpl(method, requestData, callback) { + // perform the request using an HTTP request or a WebSocket for example + var responseData = ...; + // and call the callback with the binary response afterwards: + callback(null, responseData); +} +``` + +Example: + +```protobuf +// greeter.proto +syntax = "proto3"; + +service Greeter { + rpc SayHello (HelloRequest) returns (HelloReply) {} +} + +message HelloRequest { + string name = 1; +} + +message HelloReply { + string message = 1; +} +``` + +```js +... +var Greeter = root.lookup("Greeter"); +var greeter = Greeter.create(/* see above */ rpcImpl, /* request delimited? */ false, /* response delimited? */ false); + +greeter.sayHello({ name: 'you' }, function(err, response) { + console.log('Greeting:', response.message); +}); +``` + +Services also support promises: + +```js +greeter.sayHello({ name: 'you' }) + .then(function(response) { + console.log('Greeting:', response.message); + }); +``` + +There is also an [example for streaming RPC](https://github.com/dcodeIO/protobuf.js/blob/master/examples/streaming-rpc.js). + +Note that the service API is meant for clients. Implementing a server-side endpoint pretty much always requires transport channel (i.e. http, websocket, etc.) specific code with the only common denominator being that it decodes and encodes messages. + +### Usage with TypeScript + +The library ships with its own [type definitions](https://github.com/dcodeIO/protobuf.js/blob/master/index.d.ts) and modern editors like [Visual Studio Code](https://code.visualstudio.com/) will automatically detect and use them for code completion. + +The npm package depends on [@types/node](https://www.npmjs.com/package/@types/node) because of `Buffer` and [@types/long](https://www.npmjs.com/package/@types/long) because of `Long`. If you are not building for node and/or not using long.js, it should be safe to exclude them manually. + +#### Using the JS API + +The API shown above works pretty much the same with TypeScript. However, because everything is typed, accessing fields on instances of dynamically generated message classes requires either using bracket-notation (i.e. `message["awesomeField"]`) or explicit casts. Alternatively, it is possible to use a [typings file generated for its static counterpart](#pbts-for-typescript). + +```ts +import { load } from "protobufjs"; // respectively "./node_modules/protobufjs" + +load("awesome.proto", function(err, root) { + if (err) + throw err; + + // example code + const AwesomeMessage = root.lookupType("awesomepackage.AwesomeMessage"); + + let message = AwesomeMessage.create({ awesomeField: "hello" }); + console.log(`message = ${JSON.stringify(message)}`); + + let buffer = AwesomeMessage.encode(message).finish(); + console.log(`buffer = ${Array.prototype.toString.call(buffer)}`); + + let decoded = AwesomeMessage.decode(buffer); + console.log(`decoded = ${JSON.stringify(decoded)}`); +}); +``` + +#### Using generated static code + +If you generated static code to `bundle.js` using the CLI and its type definitions to `bundle.d.ts`, then you can just do: + +```ts +import { AwesomeMessage } from "./bundle.js"; + +// example code +let message = AwesomeMessage.create({ awesomeField: "hello" }); +let buffer = AwesomeMessage.encode(message).finish(); +let decoded = AwesomeMessage.decode(buffer); +``` + +#### Using decorators + +The library also includes an early implementation of [decorators](https://www.typescriptlang.org/docs/handbook/decorators.html). + +**Note** that decorators are an experimental feature in TypeScript and that declaration order is important depending on the JS target. For example, `@Field.d(2, AwesomeArrayMessage)` requires that `AwesomeArrayMessage` has been defined earlier when targeting `ES5`. + +```ts +import { Message, Type, Field, OneOf } from "protobufjs/light"; // respectively "./node_modules/protobufjs/light.js" + +export class AwesomeSubMessage extends Message { + + @Field.d(1, "string") + public awesomeString: string; + +} + +export enum AwesomeEnum { + ONE = 1, + TWO = 2 +} + +@Type.d("SuperAwesomeMessage") +export class AwesomeMessage extends Message { + + @Field.d(1, "string", "optional", "awesome default string") + public awesomeField: string; + + @Field.d(2, AwesomeSubMessage) + public awesomeSubMessage: AwesomeSubMessage; + + @Field.d(3, AwesomeEnum, "optional", AwesomeEnum.ONE) + public awesomeEnum: AwesomeEnum; + + @OneOf.d("awesomeSubMessage", "awesomeEnum") + public which: string; + +} + +// example code +let message = new AwesomeMessage({ awesomeField: "hello" }); +let buffer = AwesomeMessage.encode(message).finish(); +let decoded = AwesomeMessage.decode(buffer); +``` + +Supported decorators are: + +* **Type.d(typeName?: `string`)**   *(optional)*
+ annotates a class as a protobuf message type. If `typeName` is not specified, the constructor's runtime function name is used for the reflected type. + +* **Field.d<T>(fieldId: `number`, fieldType: `string | Constructor`, fieldRule?: `"optional" | "required" | "repeated"`, defaultValue?: `T`)**
+ annotates a property as a protobuf field with the specified id and protobuf type. + +* **MapField.d<T extends { [key: string]: any }>(fieldId: `number`, fieldKeyType: `string`, fieldValueType. `string | Constructor<{}>`)**
+ annotates a property as a protobuf map field with the specified id, protobuf key and value type. + +* **OneOf.d<T extends string>(...fieldNames: `string[]`)**
+ annotates a property as a protobuf oneof covering the specified fields. + +Other notes: + +* Decorated types reside in `protobuf.roots["decorated"]` using a flat structure, so no duplicate names. +* Enums are copied to a reflected enum with a generic name on decorator evaluation because referenced enum objects have no runtime name the decorator could use. +* Default values must be specified as arguments to the decorator instead of using a property initializer for proper prototype behavior. +* Property names on decorated classes must not be renamed on compile time (i.e. by a minifier) because decorators just receive the original field name as a string. + +**ProTip!** Not as pretty, but you can [use decorators in plain JavaScript](https://github.com/dcodeIO/protobuf.js/blob/master/examples/js-decorators.js) as well. + +Command line +------------ + +**Note** that moving the CLI to [its own package](./cli) is a work in progress. At the moment, it's still part of the main package. + +The command line interface (CLI) can be used to translate between file formats and to generate static code as well as TypeScript definitions. + +### pbjs for JavaScript + +``` +Translates between file formats and generates static code. + + -t, --target Specifies the target format. Also accepts a path to require a custom target. + + json JSON representation + json-module JSON representation as a module + proto2 Protocol Buffers, Version 2 + proto3 Protocol Buffers, Version 3 + static Static code without reflection (non-functional on its own) + static-module Static code without reflection as a module + + -p, --path Adds a directory to the include path. + + -o, --out Saves to a file instead of writing to stdout. + + --sparse Exports only those types referenced from a main file (experimental). + + Module targets only: + + -w, --wrap Specifies the wrapper to use. Also accepts a path to require a custom wrapper. + + default Default wrapper supporting both CommonJS and AMD + commonjs CommonJS wrapper + amd AMD wrapper + es6 ES6 wrapper (implies --es6) + closure A closure adding to protobuf.roots where protobuf is a global + + -r, --root Specifies an alternative protobuf.roots name. + + -l, --lint Linter configuration. Defaults to protobuf.js-compatible rules: + + eslint-disable block-scoped-var, no-redeclare, no-control-regex, no-prototype-builtins + + --es6 Enables ES6 syntax (const/let instead of var) + + Proto sources only: + + --keep-case Keeps field casing instead of converting to camel case. + + Static targets only: + + --no-create Does not generate create functions used for reflection compatibility. + --no-encode Does not generate encode functions. + --no-decode Does not generate decode functions. + --no-verify Does not generate verify functions. + --no-convert Does not generate convert functions like from/toObject + --no-delimited Does not generate delimited encode/decode functions. + --no-beautify Does not beautify generated code. + --no-comments Does not output any JSDoc comments. + + --force-long Enfores the use of 'Long' for s-/u-/int64 and s-/fixed64 fields. + --force-message Enfores the use of message instances instead of plain objects. + +usage: pbjs [options] file1.proto file2.json ... (or pipe) other | pbjs [options] - +``` + +For production environments it is recommended to bundle all your .proto files to a single .json file, which minimizes the number of network requests and avoids any parser overhead (hint: works with just the **light** library): + +``` +$> pbjs -t json file1.proto file2.proto > bundle.json +``` + +Now, either include this file in your final bundle: + +```js +var root = protobuf.Root.fromJSON(require("./bundle.json")); +``` + +or load it the usual way: + +```js +protobuf.load("bundle.json", function(err, root) { + ... +}); +``` + +Generated static code, on the other hand, works with just the **minimal** library. For example + +``` +$> pbjs -t static-module -w commonjs -o compiled.js file1.proto file2.proto +``` + +will generate static code for definitions within `file1.proto` and `file2.proto` to a CommonJS module `compiled.js`. + +**ProTip!** Documenting your .proto files with `/** ... */`-blocks or (trailing) `/// ...` lines translates to generated static code. + + +### pbts for TypeScript + +``` +Generates TypeScript definitions from annotated JavaScript files. + + -o, --out Saves to a file instead of writing to stdout. + + -g, --global Name of the global object in browser environments, if any. + + --no-comments Does not output any JSDoc comments. + + Internal flags: + + -n, --name Wraps everything in a module of the specified name. + + -m, --main Whether building the main library without any imports. + +usage: pbts [options] file1.js file2.js ... (or) other | pbts [options] - +``` + +Picking up on the example above, the following not only generates static code to a CommonJS module `compiled.js` but also its respective TypeScript definitions to `compiled.d.ts`: + +``` +$> pbjs -t static-module -w commonjs -o compiled.js file1.proto file2.proto +$> pbts -o compiled.d.ts compiled.js +``` + +Additionally, TypeScript definitions of static modules are compatible with their reflection-based counterparts (i.e. as exported by JSON modules), as long as the following conditions are met: + +1. Instead of using `new SomeMessage(...)`, always use `SomeMessage.create(...)` because reflection objects do not provide a constructor. +2. Types, services and enums must start with an uppercase letter to become available as properties of the reflected types as well (i.e. to be able to use `MyMessage.MyEnum` instead of `root.lookup("MyMessage.MyEnum")`). + +For example, the following generates a JSON module `bundle.js` and a `bundle.d.ts`, but no static code: + +``` +$> pbjs -t json-module -w commonjs -o bundle.js file1.proto file2.proto +$> pbjs -t static-module file1.proto file2.proto | pbts -o bundle.d.ts - +``` + +### Reflection vs. static code + +While using .proto files directly requires the full library respectively pure reflection/JSON the light library, pretty much all code but the relatively short descriptors is shared. + +Static code, on the other hand, requires just the minimal library, but generates additional source code without any reflection features. This also implies that there is a break-even point where statically generated code becomes larger than descriptor-based code once the amount of code generated exceeds the size of the full respectively light library. + +There is no significant difference performance-wise as the code generated statically is pretty much the same as generated at runtime and both are largely interchangeable as seen in the previous section. + +| Source | Library | Advantages | Tradeoffs +|--------|---------|------------|----------- +| .proto | full | Easily editable
Interoperability with other libraries
No compile step | Some parsing and possibly network overhead +| JSON | light | Easily editable
No parsing overhead
Single bundle (no network overhead) | protobuf.js specific
Has a compile step +| static | minimal | Works where `eval` access is restricted
Fully documented
Small footprint for small protos | Can be hard to edit
No reflection
Has a compile step + +### Command line API + +Both utilities can be used programmatically by providing command line arguments and a callback to their respective `main` functions: + +```js +var pbjs = require("protobufjs/cli/pbjs"); // or require("protobufjs/cli").pbjs / .pbts + +pbjs.main([ "--target", "json-module", "path/to/myproto.proto" ], function(err, output) { + if (err) + throw err; + // do something with output +}); +``` + +Additional documentation +------------------------ + +#### Protocol Buffers +* [Google's Developer Guide](https://developers.google.com/protocol-buffers/docs/overview) + +#### protobuf.js +* [API Documentation](http://dcode.io/protobuf.js) +* [CHANGELOG](https://github.com/dcodeIO/protobuf.js/blob/master/CHANGELOG.md) +* [Frequently asked questions](https://github.com/dcodeIO/protobuf.js/wiki) on our wiki + +#### Community +* [Questions and answers](http://stackoverflow.com/search?tab=newest&q=protobuf.js) on StackOverflow + +Performance +----------- +The package includes a benchmark that compares protobuf.js performance to native JSON (as far as this is possible) and [Google's JS implementation](https://github.com/google/protobuf/tree/master/js). On an i7-2600K running node 6.9.1 it yields: + +``` +benchmarking encoding performance ... + +protobuf.js (reflect) x 541,707 ops/sec ±1.13% (87 runs sampled) +protobuf.js (static) x 548,134 ops/sec ±1.38% (89 runs sampled) +JSON (string) x 318,076 ops/sec ±0.63% (93 runs sampled) +JSON (buffer) x 179,165 ops/sec ±2.26% (91 runs sampled) +google-protobuf x 74,406 ops/sec ±0.85% (86 runs sampled) + + protobuf.js (static) was fastest + protobuf.js (reflect) was 0.9% ops/sec slower (factor 1.0) + JSON (string) was 41.5% ops/sec slower (factor 1.7) + JSON (buffer) was 67.6% ops/sec slower (factor 3.1) + google-protobuf was 86.4% ops/sec slower (factor 7.3) + +benchmarking decoding performance ... + +protobuf.js (reflect) x 1,383,981 ops/sec ±0.88% (93 runs sampled) +protobuf.js (static) x 1,378,925 ops/sec ±0.81% (93 runs sampled) +JSON (string) x 302,444 ops/sec ±0.81% (93 runs sampled) +JSON (buffer) x 264,882 ops/sec ±0.81% (93 runs sampled) +google-protobuf x 179,180 ops/sec ±0.64% (94 runs sampled) + + protobuf.js (reflect) was fastest + protobuf.js (static) was 0.3% ops/sec slower (factor 1.0) + JSON (string) was 78.1% ops/sec slower (factor 4.6) + JSON (buffer) was 80.8% ops/sec slower (factor 5.2) + google-protobuf was 87.0% ops/sec slower (factor 7.7) + +benchmarking combined performance ... + +protobuf.js (reflect) x 275,900 ops/sec ±0.78% (90 runs sampled) +protobuf.js (static) x 290,096 ops/sec ±0.96% (90 runs sampled) +JSON (string) x 129,381 ops/sec ±0.77% (90 runs sampled) +JSON (buffer) x 91,051 ops/sec ±0.94% (90 runs sampled) +google-protobuf x 42,050 ops/sec ±0.85% (91 runs sampled) + + protobuf.js (static) was fastest + protobuf.js (reflect) was 4.7% ops/sec slower (factor 1.0) + JSON (string) was 55.3% ops/sec slower (factor 2.2) + JSON (buffer) was 68.6% ops/sec slower (factor 3.2) + google-protobuf was 85.5% ops/sec slower (factor 6.9) +``` + +These results are achieved by + +* generating type-specific encoders, decoders, verifiers and converters at runtime +* configuring the reader/writer interface according to the environment +* using node-specific functionality where beneficial and, of course +* avoiding unnecessary operations through splitting up [the toolset](#toolset). + +You can also run [the benchmark](https://github.com/dcodeIO/protobuf.js/blob/master/bench/index.js) ... + +``` +$> npm run bench +``` + +and [the profiler](https://github.com/dcodeIO/protobuf.js/blob/master/bench/prof.js) yourself (the latter requires a recent version of node): + +``` +$> npm run prof [iterations=10000000] +``` + +Note that as of this writing, the benchmark suite performs significantly slower on node 7.2.0 compared to 6.9.1 because moths. + +Compatibility +------------- + +* Works in all modern and not-so-modern browsers except IE8. +* Because the internals of this package do not rely on `google/protobuf/descriptor.proto`, options are parsed and presented literally. +* If typed arrays are not supported by the environment, plain arrays will be used instead. +* Support for pre-ES5 environments (except IE8) can be achieved by [using a polyfill](https://github.com/dcodeIO/protobuf.js/blob/master/scripts/polyfill.js). +* Support for [Content Security Policy](https://w3c.github.io/webappsec-csp/)-restricted environments (like Chrome extensions without [unsafe-eval](https://developer.chrome.com/extensions/contentSecurityPolicy#relaxing-eval)) can be achieved by generating and using static code instead. +* If a proper way to work with 64 bit values (uint64, int64 etc.) is required, just install [long.js](https://github.com/dcodeIO/long.js) alongside this library. All 64 bit numbers will then be returned as a `Long` instance instead of a possibly unsafe JavaScript number ([see](https://github.com/dcodeIO/long.js)). +* For descriptor.proto interoperability, see [ext/descriptor](https://github.com/dcodeIO/protobuf.js/tree/master/ext/descriptor) + +Building +-------- + +To build the library or its components yourself, clone it from GitHub and install the development dependencies: + +``` +$> git clone https://github.com/dcodeIO/protobuf.js.git +$> cd protobuf.js +$> npm install +``` + +Building the respective development and production versions with their respective source maps to `dist/`: + +``` +$> npm run build +``` + +Building the documentation to `docs/`: + +``` +$> npm run docs +``` + +Building the TypeScript definition to `index.d.ts`: + +``` +$> npm run types +``` + +### Browserify integration + +By default, protobuf.js integrates into any browserify build-process without requiring any optional modules. Hence: + +* If int64 support is required, explicitly require the `long` module somewhere in your project as it will be excluded otherwise. This assumes that a global `require` function is present that protobuf.js can call to obtain the long module. + + If there is no global `require` function present after bundling, it's also possible to assign the long module programmatically: + + ```js + var Long = ...; + + protobuf.util.Long = Long; + protobuf.configure(); + ``` + +* If you have any special requirements, there is [the bundler](https://github.com/dcodeIO/protobuf.js/blob/master/scripts/bundle.js) for reference. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/protobufjs/bin/pbjs b/node_modules/protobufjs/bin/pbjs new file mode 100644 index 0000000..6a5d49a --- /dev/null +++ b/node_modules/protobufjs/bin/pbjs @@ -0,0 +1,6 @@ +#!/usr/bin/env node +var path = require("path"), + cli = require(path.join(__dirname, "..", "cli", "pbjs.js")); +var ret = cli.main(process.argv.slice(2)); +if (typeof ret === 'number') + process.exit(ret); diff --git a/node_modules/protobufjs/bin/pbts b/node_modules/protobufjs/bin/pbts new file mode 100644 index 0000000..cb1cdaf --- /dev/null +++ b/node_modules/protobufjs/bin/pbts @@ -0,0 +1,6 @@ +#!/usr/bin/env node +var path = require("path"), + cli = require(path.join(__dirname, "..", "cli", "pbts.js")); +var ret = cli.main(process.argv.slice(2)); +if (typeof ret === 'number') + process.exit(ret); diff --git a/node_modules/protobufjs/cli/LICENSE b/node_modules/protobufjs/cli/LICENSE new file mode 100644 index 0000000..e5f7a5c --- /dev/null +++ b/node_modules/protobufjs/cli/LICENSE @@ -0,0 +1,33 @@ +Copyright (c) 2016, Daniel Wirtz All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of its author, nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +--- + +Code generated by the command line utilities is owned by the owner +of the input file used when generating it. This code is not +standalone and requires a support library to be linked with it. This +support library is itself covered by the above license. diff --git a/node_modules/protobufjs/cli/README.md b/node_modules/protobufjs/cli/README.md new file mode 100644 index 0000000..1eb4c86 --- /dev/null +++ b/node_modules/protobufjs/cli/README.md @@ -0,0 +1,11 @@ +protobufjs-cli +============== +[![npm](https://img.shields.io/npm/v/protobufjscli.svg)](https://www.npmjs.com/package/protobufjs-cli) + +Command line interface (CLI) for [protobuf.js](https://github.com/dcodeIO/protobuf.js). Translates between file formats and generates static code as well as TypeScript definitions. + +* [CLI Documentation](https://github.com/dcodeIO/protobuf.js#command-line) + +**Note** that moving the CLI to its own package is a work in progress. At the moment, it's still part of the main package. + +**License:** [BSD 3-Clause License](https://opensource.org/licenses/BSD-3-Clause) diff --git a/node_modules/protobufjs/cli/bin/pbjs b/node_modules/protobufjs/cli/bin/pbjs new file mode 100644 index 0000000..9bfedb3 --- /dev/null +++ b/node_modules/protobufjs/cli/bin/pbjs @@ -0,0 +1,6 @@ +#!/usr/bin/env node +var path = require("path"), + cli = require(path.join(__dirname, "..", "pbjs.js")); +var ret = cli.main(process.argv.slice(2)); +if (typeof ret === 'number') + process.exit(ret); diff --git a/node_modules/protobufjs/cli/bin/pbts b/node_modules/protobufjs/cli/bin/pbts new file mode 100644 index 0000000..48d392c --- /dev/null +++ b/node_modules/protobufjs/cli/bin/pbts @@ -0,0 +1,6 @@ +#!/usr/bin/env node +var path = require("path"), + cli = require(path.join(__dirname, "..", "pbts.js")); +var ret = cli.main(process.argv.slice(2)); +if (typeof ret === 'number') + process.exit(ret); diff --git a/node_modules/protobufjs/cli/index.d.ts b/node_modules/protobufjs/cli/index.d.ts new file mode 100644 index 0000000..09c2026 --- /dev/null +++ b/node_modules/protobufjs/cli/index.d.ts @@ -0,0 +1,3 @@ +import * as pbjs from "./pbjs.js"; +import * as pbts from "./pbts.js"; +export { pbjs, pbts }; diff --git a/node_modules/protobufjs/cli/index.js b/node_modules/protobufjs/cli/index.js new file mode 100644 index 0000000..c565aa6 --- /dev/null +++ b/node_modules/protobufjs/cli/index.js @@ -0,0 +1,3 @@ +"use strict"; +exports.pbjs = require("./pbjs"); +exports.pbts = require("./pbts"); diff --git a/node_modules/protobufjs/cli/lib/tsd-jsdoc.json b/node_modules/protobufjs/cli/lib/tsd-jsdoc.json new file mode 100644 index 0000000..b5fe1d9 --- /dev/null +++ b/node_modules/protobufjs/cli/lib/tsd-jsdoc.json @@ -0,0 +1,18 @@ +{ + "tags": { + "allowUnknownTags": false + }, + "plugins": [ + "./tsd-jsdoc/plugin" + ], + "opts": { + "encoding" : "utf8", + "recurse" : true, + "lenient" : true, + "template" : "./tsd-jsdoc", + + "private" : false, + "comments" : true, + "destination" : false + } +} diff --git a/node_modules/protobufjs/cli/lib/tsd-jsdoc/LICENSE b/node_modules/protobufjs/cli/lib/tsd-jsdoc/LICENSE new file mode 100644 index 0000000..e5aebc9 --- /dev/null +++ b/node_modules/protobufjs/cli/lib/tsd-jsdoc/LICENSE @@ -0,0 +1,21 @@ +The MIT License + +Copyright (c) 2016 Chad Engler + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/protobufjs/cli/lib/tsd-jsdoc/README.md b/node_modules/protobufjs/cli/lib/tsd-jsdoc/README.md new file mode 100644 index 0000000..beed748 --- /dev/null +++ b/node_modules/protobufjs/cli/lib/tsd-jsdoc/README.md @@ -0,0 +1,23 @@ +protobuf.js fork of tsd-jsdoc +============================= + +This is a modified version of [tsd-jsdoc](https://github.com/englercj/tsd-jsdoc) v1.0.1 for use with protobuf.js, parked here so we can process issues and pull requests. The ultimate goal is to switch back to the a recent version of tsd-jsdoc once it meets our needs. + +Options +------- + +* **module: `string`**
+ Wraps everything in a module of the specified name. + +* **private: `boolean`**
+ Includes private members when set to `true`. + +* **comments: `boolean`**
+ Skips comments when explicitly set to `false`. + +* **destination: `string|boolean`**
+ Saves to the specified destination file or to console when set to `false`. + +Setting options on the command line +----------------------------------- +Providing `-q, --query ` on the command line will set respectively override existing options. Example: `-q module=protobufjs` diff --git a/node_modules/protobufjs/cli/lib/tsd-jsdoc/plugin.js b/node_modules/protobufjs/cli/lib/tsd-jsdoc/plugin.js new file mode 100644 index 0000000..1bf4f42 --- /dev/null +++ b/node_modules/protobufjs/cli/lib/tsd-jsdoc/plugin.js @@ -0,0 +1,21 @@ +"use strict"; +exports.defineTags = function(dictionary) { + + dictionary.defineTag("template", { + mustHaveValue: true, + canHaveType: false, + canHaveName: false, + onTagged: function(doclet, tag) { + (doclet.templates || (doclet.templates = [])).push(tag.text); + } + }); + + dictionary.defineTag("tstype", { + mustHaveValue: true, + canHaveType: false, + canHaveName: false, + onTagged: function(doclet, tag) { + doclet.tsType = tag.text; + } + }); +}; diff --git a/node_modules/protobufjs/cli/lib/tsd-jsdoc/publish.js b/node_modules/protobufjs/cli/lib/tsd-jsdoc/publish.js new file mode 100644 index 0000000..47be4e5 --- /dev/null +++ b/node_modules/protobufjs/cli/lib/tsd-jsdoc/publish.js @@ -0,0 +1,693 @@ +"use strict"; + +var fs = require("fs"); + +// output stream +var out = null; + +// documentation data +var data = null; + +// already handled objects, by name +var seen = {}; + +// indentation level +var indent = 0; + +// whether indent has been written for the current line yet +var indentWritten = false; + +// provided options +var options = {}; + +// queued interfaces +var queuedInterfaces = []; + +// whether writing the first line +var firstLine = true; + +// JSDoc hook +exports.publish = function publish(taffy, opts) { + options = opts || {}; + + // query overrides options + if (options.query) + Object.keys(options.query).forEach(function(key) { + if (key !== "query") + switch (options[key] = options.query[key]) { + case "true": + options[key] = true; + break; + case "false": + options[key] = false; + break; + case "null": + options[key] = null; + break; + } + }); + + // remove undocumented + taffy({ undocumented: true }).remove(); + taffy({ ignore: true }).remove(); + taffy({ inherited: true }).remove(); + + // remove private + if (!options.private) + taffy({ access: "private" }).remove(); + + // setup output + out = options.destination + ? fs.createWriteStream(options.destination) + : process.stdout; + + try { + // setup environment + data = taffy().get(); + indent = 0; + indentWritten = false; + firstLine = true; + + // wrap everything in a module if configured + if (options.module) { + writeln("export = ", options.module, ";"); + writeln(); + writeln("declare namespace ", options.module, " {"); + writeln(); + ++indent; + } + + // handle all + getChildrenOf(undefined).forEach(function(child) { + handleElement(child, null); + }); + + // process queued + while (queuedInterfaces.length) { + var element = queuedInterfaces.shift(); + begin(element); + writeInterface(element); + writeln(";"); + } + + // end wrap + if (options.module) { + --indent; + writeln("}"); + } + + // close file output + if (out !== process.stdout) + out.end(); + + } finally { + // gc environment objects + out = data = null; + seen = options = {}; + queuedInterfaces = []; + } +}; + +// +// Utility +// + +// writes one or multiple strings +function write() { + var s = Array.prototype.slice.call(arguments).join(""); + if (!indentWritten) { + for (var i = 0; i < indent; ++i) + s = " " + s; + indentWritten = true; + } + out.write(s); + firstLine = false; +} + +// writes zero or multiple strings, followed by a new line +function writeln() { + var s = Array.prototype.slice.call(arguments).join(""); + if (s.length) + write(s, "\n"); + else if (!firstLine) + out.write("\n"); + indentWritten = false; +} + +var keepTags = [ + "param", + "returns", + "throws", + "see" +]; + +// parses a comment into text and tags +function parseComment(comment) { + var lines = comment.replace(/^ *\/\*\* *|^ *\*\/| *\*\/ *$|^ *\* */mg, "").trim().split(/\r?\n|\r/g); // property.description has just "\r" ?! + var desc; + var text = []; + var tags = null; + for (var i = 0; i < lines.length; ++i) { + var match = /^@(\w+)\b/.exec(lines[i]); + if (match) { + if (!tags) { + tags = []; + desc = text; + } + text = []; + tags.push({ name: match[1], text: text }); + lines[i] = lines[i].substring(match[1].length + 1).trim(); + } + if (lines[i].length || text.length) + text.push(lines[i]); + } + return { + text: desc || text, + tags: tags || [] + }; +} + +// writes a comment +function writeComment(comment, otherwiseNewline) { + if (!comment || options.comments === false) { + if (otherwiseNewline) + writeln(); + return; + } + if (typeof comment !== "object") + comment = parseComment(comment); + comment.tags = comment.tags.filter(function(tag) { + return keepTags.indexOf(tag.name) > -1 && (tag.name !== "returns" || tag.text[0] !== "{undefined}"); + }); + writeln(); + if (!comment.tags.length && comment.text.length < 2) { + writeln("/** " + comment.text[0] + " */"); + return; + } + writeln("/**"); + comment.text.forEach(function(line) { + if (line.length) + writeln(" * ", line); + else + writeln(" *"); + }); + comment.tags.forEach(function(tag) { + var started = false; + if (tag.text.length) { + tag.text.forEach(function(line, i) { + if (i > 0) + write(" * "); + else if (tag.name !== "throws") + line = line.replace(/^\{[^\s]*} ?/, ""); + if (!line.length) + return; + if (!started) { + write(" * @", tag.name, " "); + started = true; + } + writeln(line); + }); + } + }); + writeln(" */"); +} + +// recursively replaces all occurencies of re's match +function replaceRecursive(name, re, fn) { + var found; + + function replacer() { + found = true; + return fn.apply(null, arguments); + } + + do { + found = false; + name = name.replace(re, replacer); + } while (found); + return name; +} + +// tests if an element is considered to be a class or class-like +function isClassLike(element) { + return isClass(element) || isInterface(element); +} + +// tests if an element is considered to be a class +function isClass(element) { + return element && element.kind === "class"; +} + +// tests if an element is considered to be an interface +function isInterface(element) { + return element && (element.kind === "interface" || element.kind === "mixin"); +} + +// tests if an element is considered to be a namespace +function isNamespace(element) { + return element && (element.kind === "namespace" || element.kind === "module"); +} + +// gets all children of the specified parent +function getChildrenOf(parent) { + var memberof = parent ? parent.longname : undefined; + return data.filter(function(element) { + return element.memberof === memberof; + }); +} + +// gets the literal type of an element +function getTypeOf(element) { + if (element.tsType) + return element.tsType.replace(/\r?\n|\r/g, "\n"); + var name = "any"; + var type = element.type; + if (type && type.names && type.names.length) { + if (type.names.length === 1) + name = element.type.names[0].trim(); + else + name = "(" + element.type.names.join("|") + ")"; + } else + return name; + + // Replace catchalls with any + name = name.replace(/\*|\bmixed\b/g, "any"); + + // Ensure upper case Object for map expressions below + name = name.replace(/\bobject\b/g, "Object"); + + // Correct Something. to Something + name = replaceRecursive(name, /\b(?!Object|Array)([\w$]+)\.<([^>]*)>/gi, function($0, $1, $2) { + return $1 + "<" + $2 + ">"; + }); + + // Replace Array. with string[] + name = replaceRecursive(name, /\bArray\.?<([^>]*)>/gi, function($0, $1) { + return $1 + "[]"; + }); + + // Replace Object. with { [k: string]: number } + name = replaceRecursive(name, /\bObject\.?<([^,]*), *([^>]*)>/gi, function($0, $1, $2) { + return "{ [k: " + $1 + "]: " + $2 + " }"; + }); + + // Replace functions (there are no signatures) with Function + name = name.replace(/\bfunction(?:\(\))?\b/g, "Function"); + + // Convert plain Object back to just object + name = name.replace(/\b(Object\b(?!\.))/g, function($0, $1) { + return $1.toLowerCase(); + }); + + return name; +} + +// begins writing the definition of the specified element +function begin(element, is_interface) { + if (!seen[element.longname]) { + if (isClass(element)) { + var comment = parseComment(element.comment); + var classdesc = comment.tags.find(function(tag) { return tag.name === "classdesc"; }); + if (classdesc) { + comment.text = classdesc.text; + comment.tags = []; + } + writeComment(comment, true); + } else + writeComment(element.comment, is_interface || isClassLike(element) || isNamespace(element) || element.isEnum || element.scope === "global"); + seen[element.longname] = element; + } else + writeln(); + if (element.scope !== "global" || options.module) + return; + write("export "); +} + +// writes the function signature describing element +function writeFunctionSignature(element, isConstructor, isTypeDef) { + write("("); + + var params = {}; + + // this type + if (element.this) + params["this"] = { + type: element.this.replace(/^{|}$/g, ""), + optional: false + }; + + // parameter types + if (element.params) + element.params.forEach(function(param) { + var path = param.name.split(/\./g); + if (path.length === 1) + params[param.name] = { + type: getTypeOf(param), + variable: param.variable === true, + optional: param.optional === true, + defaultValue: param.defaultvalue // Not used yet (TODO) + }; + else // Property syntax (TODO) + params[path[0]].type = "{ [k: string]: any }"; + }); + + var paramNames = Object.keys(params); + paramNames.forEach(function(name, i) { + var param = params[name]; + var type = param.type; + if (param.variable) { + name = "..." + name; + type = param.type.charAt(0) === "(" ? "any[]" : param.type + "[]"; + } + write(name, !param.variable && param.optional ? "?: " : ": ", type); + if (i < paramNames.length - 1) + write(", "); + }); + + write(")"); + + // return type + if (!isConstructor) { + write(isTypeDef ? " => " : ": "); + var typeName; + if (element.returns && element.returns.length && (typeName = getTypeOf(element.returns[0])) !== "undefined") + write(typeName); + else + write("void"); + } +} + +// writes (a typedef as) an interface +function writeInterface(element) { + write("interface ", element.name); + writeInterfaceBody(element); + writeln(); +} + +function writeInterfaceBody(element) { + writeln("{"); + ++indent; + if (element.tsType) + writeln(element.tsType.replace(/\r?\n|\r/g, "\n")); + else if (element.properties && element.properties.length) + element.properties.forEach(writeProperty); + --indent; + write("}"); +} + +function writeProperty(property, declare) { + writeComment(property.description); + if (declare) + write("let "); + write(property.name); + if (property.optional) + write("?"); + writeln(": ", getTypeOf(property), ";"); +} + +// +// Handlers +// + +// handles a single element of any understood type +function handleElement(element, parent) { + if (element.scope === "inner") + return false; + + if (element.optional !== true && element.type && element.type.names && element.type.names.length) { + for (var i = 0; i < element.type.names.length; i++) { + if (element.type.names[i].toLowerCase() === "undefined") { + // This element is actually optional. Set optional to true and + // remove the 'undefined' type + element.optional = true; + element.type.names.splice(i, 1); + i--; + } + } + } + + if (seen[element.longname]) + return true; + if (isClassLike(element)) + handleClass(element, parent); + else switch (element.kind) { + case "module": + case "namespace": + handleNamespace(element, parent); + break; + case "constant": + case "member": + handleMember(element, parent); + break; + case "function": + handleFunction(element, parent); + break; + case "typedef": + handleTypeDef(element, parent); + break; + case "package": + break; + } + seen[element.longname] = element; + return true; +} + +// handles (just) a namespace +function handleNamespace(element/*, parent*/) { + var children = getChildrenOf(element); + if (!children.length) + return; + var first = true; + if (element.properties) + element.properties.forEach(function(property) { + if (!/^[$\w]+$/.test(property.name)) // incompatible in namespace + return; + if (first) { + begin(element); + writeln("namespace ", element.name, " {"); + ++indent; + first = false; + } + writeProperty(property, true); + }); + children.forEach(function(child) { + if (child.scope === "inner" || seen[child.longname]) + return; + if (first) { + begin(element); + writeln("namespace ", element.name, " {"); + ++indent; + first = false; + } + handleElement(child, element); + }); + if (!first) { + --indent; + writeln("}"); + } +} + +// a filter function to remove any module references +function notAModuleReference(ref) { + return ref.indexOf("module:") === -1; +} + +// handles a class or class-like +function handleClass(element, parent) { + var is_interface = isInterface(element); + begin(element, is_interface); + if (is_interface) + write("interface "); + else { + if (element.virtual) + write("abstract "); + write("class "); + } + write(element.name); + if (element.templates && element.templates.length) + write("<", element.templates.join(", "), ">"); + write(" "); + + // extended classes + if (element.augments) { + var augments = element.augments.filter(notAModuleReference); + if (augments.length) + write("extends ", augments[0], " "); + } + + // implemented interfaces + var impls = []; + if (element.implements) + Array.prototype.push.apply(impls, element.implements); + if (element.mixes) + Array.prototype.push.apply(impls, element.mixes); + impls = impls.filter(notAModuleReference); + if (impls.length) + write("implements ", impls.join(", "), " "); + + writeln("{"); + ++indent; + + if (element.tsType) + writeln(element.tsType.replace(/\r?\n|\r/g, "\n")); + + // constructor + if (!is_interface && !element.virtual) + handleFunction(element, parent, true); + + // properties + if (is_interface && element.properties) + element.properties.forEach(function(property) { + writeProperty(property); + }); + + // class-compatible members + var incompatible = []; + getChildrenOf(element).forEach(function(child) { + if (isClassLike(child) || child.kind === "module" || child.kind === "typedef" || child.isEnum) { + incompatible.push(child); + return; + } + handleElement(child, element); + }); + + --indent; + writeln("}"); + + // class-incompatible members + if (incompatible.length) { + writeln(); + if (element.scope === "global" && !options.module) + write("export "); + writeln("namespace ", element.name, " {"); + ++indent; + incompatible.forEach(function(child) { + handleElement(child, element); + }); + --indent; + writeln("}"); + } +} + +// handles a namespace or class member +function handleMember(element, parent) { + begin(element); + + if (element.isEnum) { + var stringEnum = false; + element.properties.forEach(function(property) { + if (isNaN(property.defaultvalue)) { + stringEnum = true; + } + }); + if (stringEnum) { + writeln("type ", element.name, " ="); + ++indent; + element.properties.forEach(function(property, i) { + write(i === 0 ? "" : "| ", JSON.stringify(property.defaultvalue)); + }); + --indent; + writeln(";"); + } else { + writeln("enum ", element.name, " {"); + ++indent; + element.properties.forEach(function(property, i) { + write(property.name); + if (property.defaultvalue !== undefined) + write(" = ", JSON.stringify(property.defaultvalue)); + if (i < element.properties.length - 1) + writeln(","); + else + writeln(); + }); + --indent; + writeln("}"); + } + + } else { + + var inClass = isClassLike(parent); + if (inClass) { + write(element.access || "public", " "); + if (element.scope === "static") + write("static "); + if (element.readonly) + write("readonly "); + } else + write(element.kind === "constant" ? "const " : "let "); + + write(element.name); + if (element.optional) + write("?"); + write(": "); + + if (element.type && element.type.names && /^Object\b/i.test(element.type.names[0]) && element.properties) { + writeln("{"); + ++indent; + element.properties.forEach(function(property, i) { + writeln(JSON.stringify(property.name), ": ", getTypeOf(property), i < element.properties.length - 1 ? "," : ""); + }); + --indent; + writeln("};"); + } else + writeln(getTypeOf(element), ";"); + } +} + +// handles a function or method +function handleFunction(element, parent, isConstructor) { + var insideClass = true; + if (isConstructor) { + writeComment(element.comment); + write("constructor"); + } else { + begin(element); + insideClass = isClassLike(parent); + if (insideClass) { + write(element.access || "public", " "); + if (element.scope === "static") + write("static "); + } else + write("function "); + write(element.name); + if (element.templates && element.templates.length) + write("<", element.templates.join(", "), ">"); + } + writeFunctionSignature(element, isConstructor, false); + writeln(";"); + if (!insideClass) + handleNamespace(element); +} + +// handles a type definition (not a real type) +function handleTypeDef(element, parent) { + if (isInterface(element)) { + if (isClassLike(parent)) + queuedInterfaces.push(element); + else { + begin(element); + writeInterface(element); + } + } else { + writeComment(element.comment, true); + write("type ", element.name); + if (element.templates && element.templates.length) + write("<", element.templates.join(", "), ">"); + write(" = "); + if (element.tsType) + write(element.tsType.replace(/\r?\n|\r/g, "\n")); + else { + var type = getTypeOf(element); + if (element.type && element.type.names.length === 1 && element.type.names[0] === "function") + writeFunctionSignature(element, false, true); + else if (type === "object") { + if (element.properties && element.properties.length) + writeInterfaceBody(element); + else + write("{}"); + } else + write(type); + } + writeln(";"); + } +} diff --git a/node_modules/protobufjs/cli/node_modules/os-tmpdir/index.js b/node_modules/protobufjs/cli/node_modules/os-tmpdir/index.js new file mode 100644 index 0000000..2077b1c --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/os-tmpdir/index.js @@ -0,0 +1,25 @@ +'use strict'; +var isWindows = process.platform === 'win32'; +var trailingSlashRe = isWindows ? /[^:]\\$/ : /.\/$/; + +// https://github.com/nodejs/node/blob/3e7a14381497a3b73dda68d05b5130563cdab420/lib/os.js#L25-L43 +module.exports = function () { + var path; + + if (isWindows) { + path = process.env.TEMP || + process.env.TMP || + (process.env.SystemRoot || process.env.windir) + '\\temp'; + } else { + path = process.env.TMPDIR || + process.env.TMP || + process.env.TEMP || + '/tmp'; + } + + if (trailingSlashRe.test(path)) { + path = path.slice(0, -1); + } + + return path; +}; diff --git a/node_modules/protobufjs/cli/node_modules/os-tmpdir/license b/node_modules/protobufjs/cli/node_modules/os-tmpdir/license new file mode 100644 index 0000000..654d0bf --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/os-tmpdir/license @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/protobufjs/cli/node_modules/os-tmpdir/readme.md b/node_modules/protobufjs/cli/node_modules/os-tmpdir/readme.md new file mode 100644 index 0000000..c09f7ed --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/os-tmpdir/readme.md @@ -0,0 +1,32 @@ +# os-tmpdir [![Build Status](https://travis-ci.org/sindresorhus/os-tmpdir.svg?branch=master)](https://travis-ci.org/sindresorhus/os-tmpdir) + +> Node.js [`os.tmpdir()`](https://nodejs.org/api/os.html#os_os_tmpdir) [ponyfill](https://ponyfill.com) + +Use this instead of `require('os').tmpdir()` to get a consistent behavior on different Node.js versions (even 0.8). + + +## Install + +``` +$ npm install --save os-tmpdir +``` + + +## Usage + +```js +const osTmpdir = require('os-tmpdir'); + +osTmpdir(); +//=> '/var/folders/m3/5574nnhn0yj488ccryqr7tc80000gn/T' +``` + + +## API + +See the [`os.tmpdir()` docs](https://nodejs.org/api/os.html#os_os_tmpdir). + + +## License + +MIT © [Sindre Sorhus](https://sindresorhus.com) diff --git a/node_modules/protobufjs/cli/node_modules/tmp/LICENSE b/node_modules/protobufjs/cli/node_modules/tmp/LICENSE new file mode 100644 index 0000000..72418bd --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/tmp/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 KARASZI István + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/protobufjs/cli/node_modules/tmp/README.md b/node_modules/protobufjs/cli/node_modules/tmp/README.md new file mode 100644 index 0000000..810b048 --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/tmp/README.md @@ -0,0 +1,314 @@ +# Tmp + +A simple temporary file and directory creator for [node.js.][1] + +[![Build Status](https://travis-ci.org/raszi/node-tmp.svg?branch=master)](https://travis-ci.org/raszi/node-tmp) +[![Dependencies](https://david-dm.org/raszi/node-tmp.svg)](https://david-dm.org/raszi/node-tmp) +[![npm version](https://badge.fury.io/js/tmp.svg)](https://badge.fury.io/js/tmp) +[![API documented](https://img.shields.io/badge/API-documented-brightgreen.svg)](https://raszi.github.io/node-tmp/) +[![Known Vulnerabilities](https://snyk.io/test/npm/tmp/badge.svg)](https://snyk.io/test/npm/tmp) + +## About + +This is a [widely used library][2] to create temporary files and directories +in a [node.js][1] environment. + +Tmp offers both an asynchronous and a synchronous API. For all API calls, all +the parameters are optional. There also exists a promisified version of the +API, see (5) under references below. + +Tmp uses crypto for determining random file names, or, when using templates, +a six letter random identifier. And just in case that you do not have that much +entropy left on your system, Tmp will fall back to pseudo random numbers. + +You can set whether you want to remove the temporary file on process exit or +not, and the destination directory can also be set. + +## How to install + +```bash +npm install tmp +``` + +## Usage + +Please also check [API docs][4]. + +### Asynchronous file creation + +Simple temporary file creation, the file will be closed and unlinked on process exit. + +```javascript +var tmp = require('tmp'); + +tmp.file(function _tempFileCreated(err, path, fd, cleanupCallback) { + if (err) throw err; + + console.log('File: ', path); + console.log('Filedescriptor: ', fd); + + // If we don't need the file anymore we could manually call the cleanupCallback + // But that is not necessary if we didn't pass the keep option because the library + // will clean after itself. + cleanupCallback(); +}); +``` + +### Synchronous file creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.fileSync(); +console.log('File: ', tmpobj.name); +console.log('Filedescriptor: ', tmpobj.fd); + +// If we don't need the file anymore we could manually call the removeCallback +// But that is not necessary if we didn't pass the keep option because the library +// will clean after itself. +tmpobj.removeCallback(); +``` + +Note that this might throw an exception if either the maximum limit of retries +for creating a temporary name fails, or, in case that you do not have the permission +to write to the directory where the temporary file should be created in. + +### Asynchronous directory creation + +Simple temporary directory creation, it will be removed on process exit. + +If the directory still contains items on process exit, then it won't be removed. + +```javascript +var tmp = require('tmp'); + +tmp.dir(function _tempDirCreated(err, path, cleanupCallback) { + if (err) throw err; + + console.log('Dir: ', path); + + // Manual cleanup + cleanupCallback(); +}); +``` + +If you want to cleanup the directory even when there are entries in it, then +you can pass the `unsafeCleanup` option when creating it. + +### Synchronous directory creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync(); +console.log('Dir: ', tmpobj.name); +// Manual cleanup +tmpobj.removeCallback(); +``` + +Note that this might throw an exception if either the maximum limit of retries +for creating a temporary name fails, or, in case that you do not have the permission +to write to the directory where the temporary directory should be created in. + +### Asynchronous filename generation + +It is possible with this library to generate a unique filename in the specified +directory. + +```javascript +var tmp = require('tmp'); + +tmp.tmpName(function _tempNameGenerated(err, path) { + if (err) throw err; + + console.log('Created temporary filename: ', path); +}); +``` + +### Synchronous filename generation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var name = tmp.tmpNameSync(); +console.log('Created temporary filename: ', name); +``` + +## Advanced usage + +### Asynchronous file creation + +Creates a file with mode `0644`, prefix will be `prefix-` and postfix will be `.txt`. + +```javascript +var tmp = require('tmp'); + +tmp.file({ mode: 0644, prefix: 'prefix-', postfix: '.txt' }, function _tempFileCreated(err, path, fd) { + if (err) throw err; + + console.log('File: ', path); + console.log('Filedescriptor: ', fd); +}); +``` + +### Synchronous file creation + +A synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.fileSync({ mode: 0644, prefix: 'prefix-', postfix: '.txt' }); +console.log('File: ', tmpobj.name); +console.log('Filedescriptor: ', tmpobj.fd); +``` + +### Controlling the Descriptor + +As a side effect of creating a unique file `tmp` gets a file descriptor that is +returned to the user as the `fd` parameter. The descriptor may be used by the +application and is closed when the `removeCallback` is invoked. + +In some use cases the application does not need the descriptor, needs to close it +without removing the file, or needs to remove the file without closing the +descriptor. Two options control how the descriptor is managed: + +* `discardDescriptor` - if `true` causes `tmp` to close the descriptor after the file + is created. In this case the `fd` parameter is undefined. +* `detachDescriptor` - if `true` causes `tmp` to return the descriptor in the `fd` + parameter, but it is the application's responsibility to close it when it is no + longer needed. + +```javascript +var tmp = require('tmp'); + +tmp.file({ discardDescriptor: true }, function _tempFileCreated(err, path, fd, cleanupCallback) { + if (err) throw err; + // fd will be undefined, allowing application to use fs.createReadStream(path) + // without holding an unused descriptor open. +}); +``` + +```javascript +var tmp = require('tmp'); + +tmp.file({ detachDescriptor: true }, function _tempFileCreated(err, path, fd, cleanupCallback) { + if (err) throw err; + + cleanupCallback(); + // Application can store data through fd here; the space used will automatically + // be reclaimed by the operating system when the descriptor is closed or program + // terminates. +}); +``` + +### Asynchronous directory creation + +Creates a directory with mode `0755`, prefix will be `myTmpDir_`. + +```javascript +var tmp = require('tmp'); + +tmp.dir({ mode: 0750, prefix: 'myTmpDir_' }, function _tempDirCreated(err, path) { + if (err) throw err; + + console.log('Dir: ', path); +}); +``` + +### Synchronous directory creation + +Again, a synchronous version of the above. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync({ mode: 0750, prefix: 'myTmpDir_' }); +console.log('Dir: ', tmpobj.name); +``` + +### mkstemp like, asynchronously + +Creates a new temporary directory with mode `0700` and filename like `/tmp/tmp-nk2J1u`. + +```javascript +var tmp = require('tmp'); + +tmp.dir({ template: '/tmp/tmp-XXXXXX' }, function _tempDirCreated(err, path) { + if (err) throw err; + + console.log('Dir: ', path); +}); +``` + +### mkstemp like, synchronously + +This will behave similarly to the asynchronous version. + +```javascript +var tmp = require('tmp'); + +var tmpobj = tmp.dirSync({ template: '/tmp/tmp-XXXXXX' }); +console.log('Dir: ', tmpobj.name); +``` + +### Asynchronous filename generation + +The `tmpName()` function accepts the `prefix`, `postfix`, `dir`, etc. parameters also: + +```javascript +var tmp = require('tmp'); + +tmp.tmpName({ template: '/tmp/tmp-XXXXXX' }, function _tempNameGenerated(err, path) { + if (err) throw err; + + console.log('Created temporary filename: ', path); +}); +``` + +### Synchronous filename generation + +The `tmpNameSync()` function works similarly to `tmpName()`. + +```javascript +var tmp = require('tmp'); +var tmpname = tmp.tmpNameSync({ template: '/tmp/tmp-XXXXXX' }); +console.log('Created temporary filename: ', tmpname); +``` + +## Graceful cleanup + +One may want to cleanup the temporary files even when an uncaught exception +occurs. To enforce this, you can call the `setGracefulCleanup()` method: + +```javascript +var tmp = require('tmp'); + +tmp.setGracefulCleanup(); +``` + +## Options + +All options are optional :) + + * `mode`: the file mode to create with, it fallbacks to `0600` on file creation and `0700` on directory creation + * `prefix`: the optional prefix, fallbacks to `tmp-` if not provided + * `postfix`: the optional postfix, fallbacks to `.tmp` on file creation + * `template`: [`mkstemp`][3] like filename template, no default + * `dir`: the optional temporary directory, fallbacks to system default (guesses from environment) + * `tries`: how many times should the function try to get a unique filename before giving up, default `3` + * `keep`: signals that the temporary file or directory should not be deleted on exit, default is `false`, means delete + * Please keep in mind that it is recommended in this case to call the provided `cleanupCallback` function manually. + * `unsafeCleanup`: recursively removes the created temporary directory, even when it's not empty. default is `false` + +[1]: http://nodejs.org/ +[2]: https://www.npmjs.com/browse/depended/tmp +[3]: http://www.kernel.org/doc/man-pages/online/pages/man3/mkstemp.3.html +[4]: https://raszi.github.io/node-tmp/ +[5]: https://github.com/benjamingr/tmp-promise diff --git a/node_modules/protobufjs/cli/node_modules/tmp/lib/tmp.js b/node_modules/protobufjs/cli/node_modules/tmp/lib/tmp.js new file mode 100644 index 0000000..41b83db --- /dev/null +++ b/node_modules/protobufjs/cli/node_modules/tmp/lib/tmp.js @@ -0,0 +1,611 @@ +/*! + * Tmp + * + * Copyright (c) 2011-2017 KARASZI Istvan + * + * MIT Licensed + */ + +/* + * Module dependencies. + */ +const fs = require('fs'); +const path = require('path'); +const crypto = require('crypto'); +const osTmpDir = require('os-tmpdir'); +const _c = process.binding('constants'); + +/* + * The working inner variables. + */ +const + /** + * The temporary directory. + * @type {string} + */ + tmpDir = osTmpDir(), + + // the random characters to choose from + RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', + + TEMPLATE_PATTERN = /XXXXXX/, + + DEFAULT_TRIES = 3, + + CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR), + + EBADF = _c.EBADF || _c.os.errno.EBADF, + ENOENT = _c.ENOENT || _c.os.errno.ENOENT, + + DIR_MODE = 448 /* 0o700 */, + FILE_MODE = 384 /* 0o600 */, + + // this will hold the objects need to be removed on exit + _removeObjects = []; + +var + _gracefulCleanup = false, + _uncaughtException = false; + +/** + * Random name generator based on crypto. + * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript + * + * @param {number} howMany + * @returns {string} the generated random name + * @private + */ +function _randomChars(howMany) { + var + value = [], + rnd = null; + + // make sure that we do not fail because we ran out of entropy + try { + rnd = crypto.randomBytes(howMany); + } catch (e) { + rnd = crypto.pseudoRandomBytes(howMany); + } + + for (var i = 0; i < howMany; i++) { + value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]); + } + + return value.join(''); +} + +/** + * Checks whether the `obj` parameter is defined or not. + * + * @param {Object} obj + * @returns {boolean} true if the object is undefined + * @private + */ +function _isUndefined(obj) { + return typeof obj === 'undefined'; +} + +/** + * Parses the function arguments. + * + * This function helps to have optional arguments. + * + * @param {(Options|Function)} options + * @param {Function} callback + * @returns {Array} parsed arguments + * @private + */ +function _parseArguments(options, callback) { + if (typeof options == 'function') { + return [callback || {}, options]; + } + + if (_isUndefined(options)) { + return [{}, callback]; + } + + return [options, callback]; +} + +/** + * Generates a new temporary name. + * + * @param {Object} opts + * @returns {string} the new random name according to opts + * @private + */ +function _generateTmpName(opts) { + if (opts.name) { + return path.join(opts.dir || tmpDir, opts.name); + } + + // mkstemps like template + if (opts.template) { + return opts.template.replace(TEMPLATE_PATTERN, _randomChars(6)); + } + + // prefix and postfix + const name = [ + opts.prefix || 'tmp-', + process.pid, + _randomChars(12), + opts.postfix || '' + ].join(''); + + return path.join(opts.dir || tmpDir, name); +} + +/** + * Gets a temporary file name. + * + * @param {(Options|tmpNameCallback)} options options or callback + * @param {?tmpNameCallback} callback the callback function + */ +function tmpName(options, callback) { + var + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1], + tries = opts.name ? 1 : opts.tries || DEFAULT_TRIES; + + if (isNaN(tries) || tries < 0) + return cb(new Error('Invalid tries')); + + if (opts.template && !opts.template.match(TEMPLATE_PATTERN)) + return cb(new Error('Invalid template provided')); + + (function _getUniqueName() { + const name = _generateTmpName(opts); + + // check whether the path exists then retry if needed + fs.stat(name, function (err) { + if (!err) { + if (tries-- > 0) return _getUniqueName(); + + return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name)); + } + + cb(null, name); + }); + }()); +} + +/** + * Synchronous version of tmpName. + * + * @param {Object} options + * @returns {string} the generated random name + * @throws {Error} if the options are invalid or could not generate a filename + */ +function tmpNameSync(options) { + var + args = _parseArguments(options), + opts = args[0], + tries = opts.name ? 1 : opts.tries || DEFAULT_TRIES; + + if (isNaN(tries) || tries < 0) + throw new Error('Invalid tries'); + + if (opts.template && !opts.template.match(TEMPLATE_PATTERN)) + throw new Error('Invalid template provided'); + + do { + const name = _generateTmpName(opts); + try { + fs.statSync(name); + } catch (e) { + return name; + } + } while (tries-- > 0); + + throw new Error('Could not get a unique tmp filename, max tries reached'); +} + +/** + * Creates and opens a temporary file. + * + * @param {(Options|fileCallback)} options the config options or the callback function + * @param {?fileCallback} callback + */ +function file(options, callback) { + var + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1]; + + opts.postfix = (_isUndefined(opts.postfix)) ? '.tmp' : opts.postfix; + + // gets a temporary filename + tmpName(opts, function _tmpNameCreated(err, name) { + if (err) return cb(err); + + // create and open the file + fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) { + if (err) return cb(err); + + if (opts.discardDescriptor) { + return fs.close(fd, function _discardCallback(err) { + if (err) { + // Low probability, and the file exists, so this could be + // ignored. If it isn't we certainly need to unlink the + // file, and if that fails too its error is more + // important. + try { + fs.unlinkSync(name); + } catch (e) { + if (!isENOENT(e)) { + err = e; + } + } + return cb(err); + } + cb(null, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts)); + }); + } + if (opts.detachDescriptor) { + return cb(null, name, fd, _prepareTmpFileRemoveCallback(name, -1, opts)); + } + cb(null, name, fd, _prepareTmpFileRemoveCallback(name, fd, opts)); + }); + }); +} + +/** + * Synchronous version of file. + * + * @param {Options} options + * @returns {FileSyncObject} object consists of name, fd and removeCallback + * @throws {Error} if cannot create a file + */ +function fileSync(options) { + var + args = _parseArguments(options), + opts = args[0]; + + opts.postfix = opts.postfix || '.tmp'; + + const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; + const name = tmpNameSync(opts); + var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE); + if (opts.discardDescriptor) { + fs.closeSync(fd); + fd = undefined; + } + + return { + name: name, + fd: fd, + removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts) + }; +} + +/** + * Removes files and folders in a directory recursively. + * + * @param {string} root + * @private + */ +function _rmdirRecursiveSync(root) { + const dirs = [root]; + + do { + var + dir = dirs.pop(), + deferred = false, + files = fs.readdirSync(dir); + + for (var i = 0, length = files.length; i < length; i++) { + var + file = path.join(dir, files[i]), + stat = fs.lstatSync(file); // lstat so we don't recurse into symlinked directories + + if (stat.isDirectory()) { + if (!deferred) { + deferred = true; + dirs.push(dir); + } + dirs.push(file); + } else { + fs.unlinkSync(file); + } + } + + if (!deferred) { + fs.rmdirSync(dir); + } + } while (dirs.length !== 0); +} + +/** + * Creates a temporary directory. + * + * @param {(Options|dirCallback)} options the options or the callback function + * @param {?dirCallback} callback + */ +function dir(options, callback) { + var + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1]; + + // gets a temporary filename + tmpName(opts, function _tmpNameCreated(err, name) { + if (err) return cb(err); + + // create the directory + fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) { + if (err) return cb(err); + + cb(null, name, _prepareTmpDirRemoveCallback(name, opts)); + }); + }); +} + +/** + * Synchronous version of dir. + * + * @param {Options} options + * @returns {DirSyncObject} object consists of name and removeCallback + * @throws {Error} if it cannot create a directory + */ +function dirSync(options) { + var + args = _parseArguments(options), + opts = args[0]; + + const name = tmpNameSync(opts); + fs.mkdirSync(name, opts.mode || DIR_MODE); + + return { + name: name, + removeCallback: _prepareTmpDirRemoveCallback(name, opts) + }; +} + +/** + * Prepares the callback for removal of the temporary file. + * + * @param {string} name the path of the file + * @param {number} fd file descriptor + * @param {Object} opts + * @returns {fileCallback} + * @private + */ +function _prepareTmpFileRemoveCallback(name, fd, opts) { + const removeCallback = _prepareRemoveCallback(function _removeCallback(fdPath) { + try { + if (0 <= fdPath[0]) { + fs.closeSync(fdPath[0]); + } + } + catch (e) { + // under some node/windows related circumstances, a temporary file + // may have not be created as expected or the file was already closed + // by the user, in which case we will simply ignore the error + if (!isEBADF(e) && !isENOENT(e)) { + // reraise any unanticipated error + throw e; + } + } + try { + fs.unlinkSync(fdPath[1]); + } + catch (e) { + if (!isENOENT(e)) { + // reraise any unanticipated error + throw e; + } + } + }, [fd, name]); + + if (!opts.keep) { + _removeObjects.unshift(removeCallback); + } + + return removeCallback; +} + +/** + * Prepares the callback for removal of the temporary directory. + * + * @param {string} name + * @param {Object} opts + * @returns {Function} the callback + * @private + */ +function _prepareTmpDirRemoveCallback(name, opts) { + const removeFunction = opts.unsafeCleanup ? _rmdirRecursiveSync : fs.rmdirSync.bind(fs); + const removeCallback = _prepareRemoveCallback(removeFunction, name); + + if (!opts.keep) { + _removeObjects.unshift(removeCallback); + } + + return removeCallback; +} + +/** + * Creates a guarded function wrapping the removeFunction call. + * + * @param {Function} removeFunction + * @param {Object} arg + * @returns {Function} + * @private + */ +function _prepareRemoveCallback(removeFunction, arg) { + var called = false; + + return function _cleanupCallback(next) { + if (!called) { + const index = _removeObjects.indexOf(_cleanupCallback); + if (index >= 0) { + _removeObjects.splice(index, 1); + } + + called = true; + removeFunction(arg); + } + + if (next) next(null); + }; +} + +/** + * The garbage collector. + * + * @private + */ +function _garbageCollector() { + if (_uncaughtException && !_gracefulCleanup) { + return; + } + + // the function being called removes itself from _removeObjects, + // loop until _removeObjects is empty + while (_removeObjects.length) { + try { + _removeObjects[0].call(null); + } catch (e) { + // already removed? + } + } +} + +/** + * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows. + */ +function isEBADF(error) { + return isExpectedError(error, -EBADF, 'EBADF'); +} + +/** + * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows. + */ +function isENOENT(error) { + return isExpectedError(error, -ENOENT, 'ENOENT'); +} + +/** + * Helper to determine whether the expected error code matches the actual code and errno, + * which will differ between the supported node versions. + * + * - Node >= 7.0: + * error.code {String} + * error.errno {String|Number} any numerical value will be negated + * + * - Node >= 6.0 < 7.0: + * error.code {String} + * error.errno {Number} negated + * + * - Node >= 4.0 < 6.0: introduces SystemError + * error.code {String} + * error.errno {Number} negated + * + * - Node >= 0.10 < 4.0: + * error.code {Number} negated + * error.errno n/a + */ +function isExpectedError(error, code, errno) { + return error.code == code || error.code == errno; +} + +/** + * Sets the graceful cleanup. + * + * Also removes the created files and directories when an uncaught exception occurs. + */ +function setGracefulCleanup() { + _gracefulCleanup = true; +} + +const version = process.versions.node.split('.').map(function (value) { + return parseInt(value, 10); +}); + +if (version[0] === 0 && (version[1] < 9 || version[1] === 9 && version[2] < 5)) { + process.addListener('uncaughtException', function _uncaughtExceptionThrown(err) { + _uncaughtException = true; + _garbageCollector(); + + throw err; + }); +} + +process.addListener('exit', function _exit(code) { + if (code) _uncaughtException = true; + _garbageCollector(); +}); + +/** + * Configuration options. + * + * @typedef {Object} Options + * @property {?number} tries the number of tries before give up the name generation + * @property {?string} template the "mkstemp" like filename template + * @property {?string} name fix name + * @property {?string} dir the tmp directory to use + * @property {?string} prefix prefix for the generated name + * @property {?string} postfix postfix for the generated name + */ + +/** + * @typedef {Object} FileSyncObject + * @property {string} name the name of the file + * @property {string} fd the file descriptor + * @property {fileCallback} removeCallback the callback function to remove the file + */ + +/** + * @typedef {Object} DirSyncObject + * @property {string} name the name of the directory + * @property {fileCallback} removeCallback the callback function to remove the directory + */ + +/** + * @callback tmpNameCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + */ + +/** + * @callback fileCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {number} fd the file descriptor + * @param {cleanupCallback} fn the cleanup callback function + */ + +/** + * @callback dirCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {cleanupCallback} fn the cleanup callback function + */ + +/** + * Removes the temporary created file or directory. + * + * @callback cleanupCallback + * @param {simpleCallback} [next] function to call after entry was removed + */ + +/** + * Callback function for function composition. + * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57} + * + * @callback simpleCallback + */ + +// exporting all the needed methods +module.exports.tmpdir = tmpDir; + +module.exports.dir = dir; +module.exports.dirSync = dirSync; + +module.exports.file = file; +module.exports.fileSync = fileSync; + +module.exports.tmpName = tmpName; +module.exports.tmpNameSync = tmpNameSync; + +module.exports.setGracefulCleanup = setGracefulCleanup; diff --git a/node_modules/protobufjs/cli/package-lock.json b/node_modules/protobufjs/cli/package-lock.json new file mode 100644 index 0000000..5c63603 --- /dev/null +++ b/node_modules/protobufjs/cli/package-lock.json @@ -0,0 +1,20 @@ +{ + "version": "6.7.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "requires": { + "os-tmpdir": "1.0.2" + } + } + } +} diff --git a/node_modules/protobufjs/cli/package.json b/node_modules/protobufjs/cli/package.json new file mode 100644 index 0000000..6b17b00 --- /dev/null +++ b/node_modules/protobufjs/cli/package.json @@ -0,0 +1 @@ +{"version": "6.7.0"} \ No newline at end of file diff --git a/node_modules/protobufjs/cli/package.standalone.json b/node_modules/protobufjs/cli/package.standalone.json new file mode 100644 index 0000000..aacd040 --- /dev/null +++ b/node_modules/protobufjs/cli/package.standalone.json @@ -0,0 +1,32 @@ +{ + "name": "protobufjs-cli", + "description": "Translates between file formats and generates static code as well as TypeScript definitions.", + "version": "6.7.0", + "author": "Daniel Wirtz ", + "repository": { + "type": "git", + "url": "https://github.com/dcodeIO/protobuf.js.git" + }, + "license": "BSD-3-Clause", + "main": "index.js", + "types": "index.d.ts", + "bin": { + "pbjs": "bin/pbjs", + "pbts": "bin/pbts" + }, + "peerDependencies": { + "protobufjs": "~6.7.0" + }, + "dependencies": { + "chalk": "^1.1.3", + "escodegen": "^1.8.1", + "espree": "^3.1.3", + "estraverse": "^4.2.0", + "glob": "^7.1.1", + "jsdoc": "^3.4.2", + "minimist": "^1.2.0", + "semver": "^5.3.0", + "tmp": "0.0.31", + "uglify-js": "^2.8.15" + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/cli/pbjs.d.ts b/node_modules/protobufjs/cli/pbjs.d.ts new file mode 100644 index 0000000..ead1f3c --- /dev/null +++ b/node_modules/protobufjs/cli/pbjs.d.ts @@ -0,0 +1,9 @@ +type pbjsCallback = (err: Error|null, output?: string) => void; + +/** + * Runs pbjs programmatically. + * @param {string[]} args Command line arguments + * @param {function(?Error, string=)} [callback] Optional completion callback + * @returns {number|undefined} Exit code, if known + */ +export function main(args: string[], callback?: pbjsCallback): number|undefined; diff --git a/node_modules/protobufjs/cli/pbjs.js b/node_modules/protobufjs/cli/pbjs.js new file mode 100644 index 0000000..ede8cb0 --- /dev/null +++ b/node_modules/protobufjs/cli/pbjs.js @@ -0,0 +1,329 @@ +"use strict"; +var path = require("path"), + fs = require("fs"), + pkg = require("./package.json"), + util = require("./util"); + +util.setup(); + +var protobuf = require(util.pathToProtobufJs), + minimist = require("minimist"), + chalk = require("chalk"), + glob = require("glob"); + +var targets = util.requireAll("./targets"); + +/** + * Runs pbjs programmatically. + * @param {string[]} args Command line arguments + * @param {function(?Error, string=)} [callback] Optional completion callback + * @returns {number|undefined} Exit code, if known + */ +exports.main = function main(args, callback) { + var lintDefault = "eslint-disable " + [ + "block-scoped-var", + "id-length", + "no-control-regex", + "no-magic-numbers", + "no-prototype-builtins", + "no-redeclare", + "no-shadow", + "no-var", + "sort-vars" + ].join(", "); + var argv = minimist(args, { + alias: { + target: "t", + out: "o", + path: "p", + wrap: "w", + root: "r", + lint: "l", + // backward compatibility: + "force-long": "strict-long", + "force-message": "strict-message" + }, + string: [ "target", "out", "path", "wrap", "dependency", "root", "lint" ], + boolean: [ "create", "encode", "decode", "verify", "convert", "delimited", "beautify", "comments", "es6", "sparse", "keep-case", "force-long", "force-number", "force-enum-string", "force-message" ], + default: { + target: "json", + create: true, + encode: true, + decode: true, + verify: true, + convert: true, + delimited: true, + beautify: true, + comments: true, + es6: null, + lint: lintDefault, + "keep-case": false, + "force-long": false, + "force-number": false, + "force-enum-string": false, + "force-message": false + } + }); + + var target = targets[argv.target], + files = argv._, + paths = typeof argv.path === "string" ? [ argv.path ] : argv.path || []; + + // alias hyphen args in camel case + Object.keys(argv).forEach(function(key) { + var camelKey = key.replace(/-([a-z])/g, function($0, $1) { return $1.toUpperCase(); }); + if (camelKey !== key) + argv[camelKey] = argv[key]; + }); + + // protobuf.js package directory contains additional, otherwise non-bundled google types + paths.push(path.relative(process.cwd(), path.join(__dirname, "..")) || "."); + + if (!files.length) { + var descs = Object.keys(targets).filter(function(key) { return !targets[key].private; }).map(function(key) { + return " " + util.pad(key, 14, true) + targets[key].description; + }); + if (callback) + callback(Error("usage")); // eslint-disable-line callback-return + else + process.stderr.write([ + "protobuf.js v" + pkg.version + " CLI for JavaScript", + "", + chalk.bold.white("Translates between file formats and generates static code."), + "", + " -t, --target Specifies the target format. Also accepts a path to require a custom target.", + "", + descs.join("\n"), + "", + " -p, --path Adds a directory to the include path.", + "", + " -o, --out Saves to a file instead of writing to stdout.", + "", + " --sparse Exports only those types referenced from a main file (experimental).", + "", + chalk.bold.gray(" Module targets only:"), + "", + " -w, --wrap Specifies the wrapper to use. Also accepts a path to require a custom wrapper.", + "", + " default Default wrapper supporting both CommonJS and AMD", + " commonjs CommonJS wrapper", + " amd AMD wrapper", + " es6 ES6 wrapper (implies --es6)", + " closure A closure adding to protobuf.roots where protobuf is a global", + "", + " --dependency Specifies which version of protobuf to require. Accepts any valid module id", + "", + " -r, --root Specifies an alternative protobuf.roots name.", + "", + " -l, --lint Linter configuration. Defaults to protobuf.js-compatible rules:", + "", + " " + lintDefault, + "", + " --es6 Enables ES6 syntax (const/let instead of var)", + "", + chalk.bold.gray(" Proto sources only:"), + "", + " --keep-case Keeps field casing instead of converting to camel case.", + "", + chalk.bold.gray(" Static targets only:"), + "", + " --no-create Does not generate create functions used for reflection compatibility.", + " --no-encode Does not generate encode functions.", + " --no-decode Does not generate decode functions.", + " --no-verify Does not generate verify functions.", + " --no-convert Does not generate convert functions like from/toObject", + " --no-delimited Does not generate delimited encode/decode functions.", + " --no-beautify Does not beautify generated code.", + " --no-comments Does not output any JSDoc comments.", + "", + " --force-long Enfores the use of 'Long' for s-/u-/int64 and s-/fixed64 fields.", + " --force-number Enfores the use of 'number' for s-/u-/int64 and s-/fixed64 fields.", + " --force-message Enfores the use of message instances instead of plain objects.", + "", + "usage: " + chalk.bold.green("pbjs") + " [options] file1.proto file2.json ..." + chalk.gray(" (or pipe) ") + "other | " + chalk.bold.green("pbjs") + " [options] -", + "" + ].join("\n")); + return 1; + } + + if (typeof argv["strict-long"] === "boolean") + argv["force-long"] = argv["strict-long"]; + + // Resolve glob expressions + for (var i = 0; i < files.length;) { + if (glob.hasMagic(files[i])) { + var matches = glob.sync(files[i]); + Array.prototype.splice.apply(files, [i, 1].concat(matches)); + i += matches.length; + } else + ++i; + } + + // Require custom target + if (!target) + target = require(path.resolve(process.cwd(), argv.target)); + + var root = new protobuf.Root(); + + var mainFiles = []; + + // Search include paths when resolving imports + root.resolvePath = function pbjsResolvePath(origin, target) { + var normOrigin = protobuf.util.path.normalize(origin), + normTarget = protobuf.util.path.normalize(target); + if (!normOrigin) + mainFiles.push(normTarget); + + var resolved = protobuf.util.path.resolve(normOrigin, normTarget, true); + var idx = resolved.lastIndexOf("google/protobuf/"); + if (idx > -1) { + var altname = resolved.substring(idx); + if (altname in protobuf.common) + resolved = altname; + } + + if (fs.existsSync(resolved)) + return resolved; + + for (var i = 0; i < paths.length; ++i) { + var iresolved = protobuf.util.path.resolve(paths[i] + "/", target); + if (fs.existsSync(iresolved)) + return iresolved; + } + + return resolved; + }; + + // Use es6 syntax if not explicitly specified on the command line and the es6 wrapper is used + if (argv.wrap === "es6" || argv.es6) { + argv.wrap = "es6"; + argv.es6 = true; + } + + var parseOptions = { + "keepCase": argv["keep-case"] || false + }; + + // Read from stdin + if (files.length === 1 && files[0] === "-") { + var data = []; + process.stdin.on("data", function(chunk) { + data.push(chunk); + }); + process.stdin.on("end", function() { + var source = Buffer.concat(data).toString("utf8"); + try { + if (source.charAt(0) !== "{") { + protobuf.parse.filename = "-"; + protobuf.parse(source, root, parseOptions); + } else { + var json = JSON.parse(source); + root.setOptions(json.options).addJSON(json); + } + callTarget(); + } catch (err) { + if (callback) { + callback(err); + return; + } + throw err; + } + }); + + // Load from disk + } else { + try { + root.loadSync(files, parseOptions).resolveAll(); // sync is deterministic while async is not + if (argv.sparse) + sparsify(root); + callTarget(); + } catch (err) { + if (callback) { + callback(err); + return undefined; + } + throw err; + } + } + + function markReferenced(tobj) { + tobj.referenced = true; + // also mark a type's fields and oneofs + if (tobj.fieldsArray) + tobj.fieldsArray.forEach(function(fobj) { + fobj.referenced = true; + }); + if (tobj.oneofsArray) + tobj.oneofsArray.forEach(function(oobj) { + oobj.referenced = true; + }); + // also mark an extension field's extended type, but not its (other) fields + if (tobj.extensionField) + tobj.extensionField.parent.referenced = true; + } + + function sparsify(root) { + + // 1. mark directly or indirectly referenced objects + util.traverse(root, function(obj) { + if (!obj.filename) + return; + if (mainFiles.indexOf(obj.filename) > -1) + util.traverseResolved(obj, markReferenced); + }); + + // 2. empty unreferenced objects + util.traverse(root, function(obj) { + var parent = obj.parent; + if (!parent || obj.referenced) // root or referenced + return; + // remove unreferenced namespaces + if (obj instanceof protobuf.Namespace) { + var hasReferenced = false; + util.traverse(obj, function(iobj) { + if (iobj.referenced) + hasReferenced = true; + }); + if (hasReferenced) { // replace with plain namespace if a namespace subclass + if (obj instanceof protobuf.Type || obj instanceof protobuf.Service) { + var robj = new protobuf.Namespace(obj.name, obj.options); + robj.nested = obj.nested; + parent.add(robj); + } + } else // remove completely if nothing inside is referenced + parent.remove(obj); + + // remove everything else unreferenced + } else if (!(obj instanceof protobuf.Namespace)) + parent.remove(obj); + }); + + // 3. validate that everything is fine + root.resolveAll(); + } + + function callTarget() { + target(root, argv, function targetCallback(err, output) { + if (err) { + if (callback) + return callback(err); + throw err; + } + try { + if (argv.out) + fs.writeFileSync(argv.out, output, { encoding: "utf8" }); + else if (!callback) + process.stdout.write(output, "utf8"); + return callback + ? callback(null, output) + : undefined; + } catch (err) { + if (callback) + return callback(err); + throw err; + } + }); + } + + return undefined; +}; diff --git a/node_modules/protobufjs/cli/pbts.d.ts b/node_modules/protobufjs/cli/pbts.d.ts new file mode 100644 index 0000000..35db28c --- /dev/null +++ b/node_modules/protobufjs/cli/pbts.d.ts @@ -0,0 +1,9 @@ +type pbtsCallback = (err: Error|null, output?: string) => void; + +/** + * Runs pbts programmatically. + * @param {string[]} args Command line arguments + * @param {function(?Error, string=)} [callback] Optional completion callback + * @returns {number|undefined} Exit code, if known + */ +export function main(args: string[], callback?: pbtsCallback): number|undefined; diff --git a/node_modules/protobufjs/cli/pbts.js b/node_modules/protobufjs/cli/pbts.js new file mode 100644 index 0000000..f066964 --- /dev/null +++ b/node_modules/protobufjs/cli/pbts.js @@ -0,0 +1,197 @@ +"use strict"; +var child_process = require("child_process"), + path = require("path"), + fs = require("fs"), + pkg = require("./package.json"), + util = require("./util"); + +util.setup(); + +var minimist = require("minimist"), + chalk = require("chalk"), + glob = require("glob"), + tmp = require("tmp"); + +/** + * Runs pbts programmatically. + * @param {string[]} args Command line arguments + * @param {function(?Error, string=)} [callback] Optional completion callback + * @returns {number|undefined} Exit code, if known + */ +exports.main = function(args, callback) { + var argv = minimist(args, { + alias: { + name: "n", + out : "o", + main: "m", + global: "g", + import: "i" + }, + string: [ "name", "out", "global", "import" ], + boolean: [ "comments", "main" ], + default: { + comments: true, + main: false + } + }); + + var files = argv._; + + if (!files.length) { + if (callback) + callback(Error("usage")); // eslint-disable-line callback-return + else + process.stderr.write([ + "protobuf.js v" + pkg.version + " CLI for TypeScript", + "", + chalk.bold.white("Generates TypeScript definitions from annotated JavaScript files."), + "", + " -o, --out Saves to a file instead of writing to stdout.", + "", + " -g, --global Name of the global object in browser environments, if any.", + "", + " -i, --import Comma delimited list of imports. Local names will equal camelCase of the basename.", + "", + " --no-comments Does not output any JSDoc comments.", + "", + chalk.bold.gray(" Internal flags:"), + "", + " -n, --name Wraps everything in a module of the specified name.", + "", + " -m, --main Whether building the main library without any imports.", + "", + "usage: " + chalk.bold.green("pbts") + " [options] file1.js file2.js ..." + chalk.bold.gray(" (or) ") + "other | " + chalk.bold.green("pbts") + " [options] -", + "" + ].join("\n")); + return 1; + } + + // Resolve glob expressions + for (var i = 0; i < files.length;) { + if (glob.hasMagic(files[i])) { + var matches = glob.sync(files[i]); + Array.prototype.splice.apply(files, [i, 1].concat(matches)); + i += matches.length; + } else + ++i; + } + + var cleanup = []; + + // Read from stdin (to a temporary file) + if (files.length === 1 && files[0] === "-") { + var data = []; + process.stdin.on("data", function(chunk) { + data.push(chunk); + }); + process.stdin.on("end", function() { + files[0] = tmp.tmpNameSync() + ".js"; + fs.writeFileSync(files[0], Buffer.concat(data)); + cleanup.push(files[0]); + callJsdoc(); + }); + + // Load from disk + } else { + callJsdoc(); + } + + function callJsdoc() { + + // There is no proper API for jsdoc, so this executes the CLI and pipes the output + var basedir = path.join(__dirname, "."); + var moduleName = argv.name || "null"; + var nodePath = process.execPath; + var cmd = "\"" + nodePath + "\" \"" + require.resolve("jsdoc/jsdoc.js") + "\" -c \"" + path.join(basedir, "lib", "tsd-jsdoc.json") + "\" -q \"module=" + encodeURIComponent(moduleName) + "&comments=" + Boolean(argv.comments) + "\" " + files.map(function(file) { return "\"" + file + "\""; }).join(" "); + var child = child_process.exec(cmd, { + cwd: process.cwd(), + argv0: "node", + stdio: "pipe", + maxBuffer: 1 << 24 // 16mb + }); + var out = []; + var ended = false; + var closed = false; + child.stdout.on("data", function(data) { + out.push(data); + }); + child.stdout.on("end", function() { + if (closed) finish(); + else ended = true; + }); + child.stderr.pipe(process.stderr); + child.on("close", function(code) { + // clean up temporary files, no matter what + try { cleanup.forEach(fs.unlinkSync); } catch(e) {/**/} cleanup = []; + + if (code) { + out = out.join("").replace(/\s*JSDoc \d+\.\d+\.\d+ [^$]+/, ""); + process.stderr.write(out); + var err = Error("code " + code); + if (callback) + return callback(err); + throw err; + } + + if (ended) return finish(); + closed = true; + return undefined; + }); + + function getImportName(importItem) { + return path.basename(importItem, ".js").replace(/([-_~.+]\w)/g, function(match) { + return match[1].toUpperCase(); + }); + } + + function finish() { + var output = []; + if (argv.main) + output.push( + "// DO NOT EDIT! This is a generated file. Edit the JSDoc in src/*.js instead and run 'npm run types'.", + "" + ); + if (argv.global) + output.push( + "export as namespace " + argv.global + ";", + "" + ); + + if (!argv.main) { + // Ensure we have a usable array of imports + var importArray = typeof argv.import === "string" ? argv.import.split(",") : argv.import || []; + + // Build an object of imports and paths + var imports = { + $protobuf: "protobufjs" + }; + importArray.forEach(function(importItem) { + imports[getImportName(importItem)] = importItem; + }); + + // Write out the imports + Object.keys(imports).forEach(function(key) { + output.push("import * as " + key + " from \"" + imports[key] + "\";"); + }); + } + + output = output.join("\n") + "\n" + out.join(""); + + try { + if (argv.out) + fs.writeFileSync(argv.out, output, { encoding: "utf8" }); + else if (!callback) + process.stdout.write(output, "utf8"); + return callback + ? callback(null, output) + : undefined; + } catch (err) { + if (callback) + return callback(err); + throw err; + } + } + } + + return undefined; +}; diff --git a/node_modules/protobufjs/cli/targets/json-module.js b/node_modules/protobufjs/cli/targets/json-module.js new file mode 100644 index 0000000..5255cd9 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/json-module.js @@ -0,0 +1,38 @@ +"use strict"; +module.exports = json_module; + +var util = require("../util"); + +var protobuf = require("../.."); + +json_module.description = "JSON representation as a module"; + +function jsonSafeProp(json) { + return json.replace(/^( +)"(\w+)":/mg, function($0, $1, $2) { + return protobuf.util.safeProp($2).charAt(0) === "." + ? $1 + $2 + ":" + : $0; + }); +} + +function json_module(root, options, callback) { + try { + var rootProp = protobuf.util.safeProp(options.root || "default"); + var output = [ + (options.es6 ? "const" : "var") + " $root = ($protobuf.roots" + rootProp + " || ($protobuf.roots" + rootProp + " = new $protobuf.Root()))\n" + ]; + if (root.options) { + var optionsJson = jsonSafeProp(JSON.stringify(root.options, null, 2)); + output.push(".setOptions(" + optionsJson + ")\n"); + } + var json = jsonSafeProp(JSON.stringify(root.nested, null, 2).trim()); + output.push(".addJSON(" + json + ");"); + output = util.wrap(output.join(""), protobuf.util.merge({ dependency: "protobufjs/light" }, options)); + process.nextTick(function() { + callback(null, output); + }); + } catch (e) { + return callback(e); + } + return undefined; +} diff --git a/node_modules/protobufjs/cli/targets/json.js b/node_modules/protobufjs/cli/targets/json.js new file mode 100644 index 0000000..7025372 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/json.js @@ -0,0 +1,8 @@ +"use strict"; +module.exports = json_target; + +json_target.description = "JSON representation"; + +function json_target(root, options, callback) { + callback(null, JSON.stringify(root, null, 2)); +} diff --git a/node_modules/protobufjs/cli/targets/proto.js b/node_modules/protobufjs/cli/targets/proto.js new file mode 100644 index 0000000..d633f16 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/proto.js @@ -0,0 +1,326 @@ +"use strict"; +module.exports = proto_target; + +proto_target.private = true; + +var protobuf = require("../.."); + +var Namespace = protobuf.Namespace, + Enum = protobuf.Enum, + Type = protobuf.Type, + Field = protobuf.Field, + OneOf = protobuf.OneOf, + Service = protobuf.Service, + Method = protobuf.Method, + types = protobuf.types, + util = protobuf.util; + +function underScore(str) { + return str.substring(0,1) + + str.substring(1) + .replace(/([A-Z])(?=[a-z]|$)/g, function($0, $1) { return "_" + $1.toLowerCase(); }); +} + +var out = []; +var indent = 0; +var first = false; +var syntax = 3; + +function proto_target(root, options, callback) { + if (options) { + switch (options.syntax) { + case undefined: + case "proto3": + case "3": + syntax = 3; + break; + case "proto2": + case "2": + syntax = 2; + break; + default: + return callback(Error("invalid syntax: " + options.syntax)); + } + } + indent = 0; + first = false; + try { + buildRoot(root); + return callback(null, out.join("\n")); + } catch (err) { + return callback(err); + } finally { + out = []; + syntax = 3; + } +} + +function push(line) { + if (line === "") + out.push(""); + else { + var ind = ""; + for (var i = 0; i < indent; ++i) + ind += " "; + out.push(ind + line); + } +} + +function escape(str) { + return str.replace(/[\\"']/g, "\\$&") + .replace(/\r/g, "\\r") + .replace(/\n/g, "\\n") + .replace(/\u0000/g, "\\0"); // eslint-disable-line no-control-regex +} + +function value(v) { + switch (typeof v) { + case "boolean": + return v ? "true" : "false"; + case "number": + return v.toString(); + default: + return "\"" + escape(String(v)) + "\""; + } +} + +function buildRoot(root) { + root.resolveAll(); + var pkg = []; + var ptr = root; + var repeat = true; + do { + var nested = ptr.nestedArray; + if (nested.length === 1 && nested[0] instanceof Namespace && !(nested[0] instanceof Type || nested[0] instanceof Service)) { + ptr = nested[0]; + if (ptr !== root) + pkg.push(ptr.name); + } else + repeat = false; + } while (repeat); + out.push("syntax = \"proto" + syntax + "\";"); + if (pkg.length) + out.push("", "package " + pkg.join(".") + ";"); + + buildOptions(ptr); + ptr.nestedArray.forEach(build); +} + +function build(object) { + if (object instanceof Enum) + buildEnum(object); + else if (object instanceof Type) + buildType(object); + else if (object instanceof Field) + buildField(object); + else if (object instanceof OneOf) + buildOneOf(object); + else if (object instanceof Service) + buildService(object); + else if (object instanceof Method) + buildMethod(object); + else + buildNamespace(object); +} + +function buildNamespace(namespace) { // just a namespace, not a type etc. + push(""); + push("message " + namespace.name + " {"); + ++indent; + buildOptions(namespace); + consolidateExtends(namespace.nestedArray).remaining.forEach(build); + --indent; + push("}"); +} + +function buildEnum(enm) { + push(""); + push("enum " + enm.name + " {"); + buildOptions(enm); + ++indent; first = true; + Object.keys(enm.values).forEach(function(name) { + var val = enm.values[name]; + if (first) { + push(""); + first = false; + } + push(name + " = " + val + ";"); + }); + --indent; first = false; + push("}"); +} + +function buildRanges(keyword, ranges) { + if (ranges && ranges.length) { + var parts = []; + ranges.forEach(function(range) { + if (typeof range === "string") + parts.push("\"" + escape(range) + "\""); + else if (range[0] === range[1]) + parts.push(range[0]); + else + parts.push(range[0] + " to " + (range[1] === 0x1FFFFFFF ? "max" : range[1])); + }); + push(""); + push(keyword + " " + parts.join(", ") + ";"); + } +} + +function buildType(type) { + if (type.group) + return; // built with the sister-field + push(""); + push("message " + type.name + " {"); + ++indent; + buildOptions(type); + type.oneofsArray.forEach(build); + first = true; + type.fieldsArray.forEach(build); + consolidateExtends(type.nestedArray).remaining.forEach(build); + buildRanges("extensions", type.extensions); + buildRanges("reserved", type.reserved); + --indent; + push("}"); +} + +function buildField(field, passExtend) { + if (field.partOf || field.declaringField || field.extend !== undefined && !passExtend) + return; + if (first) { + first = false; + push(""); + } + if (field.resolvedType && field.resolvedType.group) { + buildGroup(field); + return; + } + var sb = []; + if (field.map) + sb.push("map<" + field.keyType + ", " + field.type + ">"); + else if (field.repeated) + sb.push("repeated", field.type); + else if (syntax === 2 || field.parent.group) + sb.push(field.required ? "required" : "optional", field.type); + else + sb.push(field.type); + sb.push(underScore(field.name), "=", field.id); + var opts = buildFieldOptions(field); + if (opts) + sb.push(opts); + push(sb.join(" ") + ";"); +} + +function buildGroup(field) { + push(field.rule + " group " + field.resolvedType.name + " = " + field.id + " {"); + ++indent; + buildOptions(field.resolvedType); + first = true; + field.resolvedType.fieldsArray.forEach(function(field) { + buildField(field); + }); + --indent; + push("}"); +} + +function buildFieldOptions(field) { + var keys; + if (!field.options || !(keys = Object.keys(field.options)).length) + return null; + var sb = []; + keys.forEach(function(key) { + var val = field.options[key]; + var wireType = types.packed[field.resolvedType instanceof Enum ? "int32" : field.type]; + switch (key) { + case "packed": + val = Boolean(val); + // skip when not packable or syntax default + if (wireType === undefined || syntax === 3 === val) + return; + break; + case "default": + if (syntax === 3) + return; + // skip default (resolved) default values + if (field.long && !util.longNeq(field.defaultValue, types.defaults[field.type]) || !field.long && field.defaultValue === types.defaults[field.type]) + return; + // enum defaults specified as strings are type references and not enclosed in quotes + if (field.resolvedType instanceof Enum) + break; + // otherwise fallthrough + default: + val = value(val); + break; + } + sb.push(key + "=" + val); + }); + return sb.length + ? "[" + sb.join(", ") + "]" + : null; +} + +function consolidateExtends(nested) { + var ext = {}; + nested = nested.filter(function(obj) { + if (!(obj instanceof Field) || obj.extend === undefined) + return true; + (ext[obj.extend] || (ext[obj.extend] = [])).push(obj); + return false; + }); + Object.keys(ext).forEach(function(extend) { + push(""); + push("extend " + extend + " {"); + ++indent; first = true; + ext[extend].forEach(function(field) { + buildField(field, true); + }); + --indent; + push("}"); + }); + return { + remaining: nested + }; +} + +function buildOneOf(oneof) { + push(""); + push("oneof " + underScore(oneof.name) + " {"); + ++indent; first = true; + oneof.oneof.forEach(function(fieldName) { + var field = oneof.parent.get(fieldName); + if (first) { + first = false; + push(""); + } + var opts = buildFieldOptions(field); + push(field.type + " " + underScore(field.name) + " = " + field.id + (opts ? " " + opts : "") + ";"); + }); + --indent; + push("}"); +} + +function buildService(service) { + push("service " + service.name + " {"); + ++indent; + service.methodsArray.forEach(build); + consolidateExtends(service.nestedArray).remaining.forEach(build); + --indent; + push("}"); +} + +function buildMethod(method) { + push(method.type + " " + method.name + " (" + (method.requestStream ? "stream " : "") + method.requestType + ") returns (" + (method.responseStream ? "stream " : "") + method.responseType + ");"); +} + +function buildOptions(object) { + if (!object.options) + return; + first = true; + Object.keys(object.options).forEach(function(key) { + if (first) { + first = false; + push(""); + } + var val = object.options[key]; + push("option " + key + " = " + JSON.stringify(val) + ";"); + }); +} diff --git a/node_modules/protobufjs/cli/targets/proto2.js b/node_modules/protobufjs/cli/targets/proto2.js new file mode 100644 index 0000000..09521e0 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/proto2.js @@ -0,0 +1,10 @@ +"use strict"; +module.exports = proto2_target; + +var protobuf = require("../.."); + +proto2_target.description = "Protocol Buffers, Version 2"; + +function proto2_target(root, options, callback) { + require("./proto")(root, protobuf.util.merge(options, { syntax: "proto2" }), callback); +} diff --git a/node_modules/protobufjs/cli/targets/proto3.js b/node_modules/protobufjs/cli/targets/proto3.js new file mode 100644 index 0000000..661c916 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/proto3.js @@ -0,0 +1,10 @@ +"use strict"; +module.exports = proto3_target; + +var protobuf = require("../.."); + +proto3_target.description = "Protocol Buffers, Version 3"; + +function proto3_target(root, options, callback) { + require("./proto")(root, protobuf.util.merge(options, { syntax: "proto3" }), callback); +} diff --git a/node_modules/protobufjs/cli/targets/static-module.js b/node_modules/protobufjs/cli/targets/static-module.js new file mode 100644 index 0000000..b561947 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/static-module.js @@ -0,0 +1,29 @@ +"use strict"; +module.exports = static_module_target; + +// - The default wrapper supports AMD, CommonJS and the global scope (as window.root), in this order. +// - You can specify a custom wrapper with the --wrap argument. +// - CommonJS modules depend on the minimal build for reduced package size with browserify. +// - AMD and global scope depend on the full library for now. + +var util = require("../util"); + +var protobuf = require("../.."); + +static_module_target.description = "Static code without reflection as a module"; + +function static_module_target(root, options, callback) { + require("./static")(root, options, function(err, output) { + if (err) { + callback(err); + return; + } + try { + output = util.wrap(output, protobuf.util.merge({ dependency: "protobufjs/minimal" }, options)); + } catch (e) { + callback(e); + return; + } + callback(null, output); + }); +} diff --git a/node_modules/protobufjs/cli/targets/static.js b/node_modules/protobufjs/cli/targets/static.js new file mode 100644 index 0000000..0c938b0 --- /dev/null +++ b/node_modules/protobufjs/cli/targets/static.js @@ -0,0 +1,702 @@ +"use strict"; +module.exports = static_target; + +var protobuf = require("../.."), + UglifyJS = require("uglify-js"), + espree = require("espree"), + escodegen = require("escodegen"), + estraverse = require("estraverse"); + +var Type = protobuf.Type, + Service = protobuf.Service, + Enum = protobuf.Enum, + Namespace = protobuf.Namespace, + util = protobuf.util; + +var out = []; +var indent = 0; +var config = {}; + +static_target.description = "Static code without reflection (non-functional on its own)"; + +function static_target(root, options, callback) { + config = options; + try { + var aliases = []; + if (config.decode) + aliases.push("Reader"); + if (config.encode) + aliases.push("Writer"); + aliases.push("util"); + if (aliases.length) { + if (config.comments) + push("// Common aliases"); + push((config.es6 ? "const " : "var ") + aliases.map(function(name) { return "$" + name + " = $protobuf." + name; }).join(", ") + ";"); + push(""); + } + if (config.comments) { + if (root.comment) { + pushComment("@fileoverview " + root.comment); + push(""); + } + push("// Exported root namespace"); + } + var rootProp = util.safeProp(config.root || "default"); + push((config.es6 ? "const" : "var") + " $root = $protobuf.roots" + rootProp + " || ($protobuf.roots" + rootProp + " = {});"); + buildNamespace(null, root); + return callback(null, out.join("\n")); + } catch (err) { + return callback(err); + } finally { + out = []; + indent = 0; + config = {}; + } +} + +function push(line) { + if (line === "") + return out.push(""); + var ind = ""; + for (var i = 0; i < indent; ++i) + ind += " "; + return out.push(ind + line); +} + +function pushComment(lines) { + if (!config.comments) + return; + var split = []; + for (var i = 0; i < lines.length; ++i) + if (lines[i] != null && lines[i].substring(0, 8) !== "@exclude") + Array.prototype.push.apply(split, lines[i].split(/\r?\n/g)); + push("/**"); + split.forEach(function(line) { + if (line === null) + return; + push(" * " + line.replace(/\*\//g, "* /")); + }); + push(" */"); +} + +function exportName(object, asInterface) { + if (asInterface) { + if (object.__interfaceName) + return object.__interfaceName; + } else if (object.__exportName) + return object.__exportName; + var parts = object.fullName.substring(1).split("."), + i = 0; + while (i < parts.length) + parts[i] = escapeName(parts[i++]); + if (asInterface) + parts[i - 1] = "I" + parts[i - 1]; + return object[asInterface ? "__interfaceName" : "__exportName"] = parts.join("."); +} + +function escapeName(name) { + if (!name) + return "$root"; + return util.isReserved(name) ? name + "_" : name; +} + +function aOrAn(name) { + return ((/^[hH](?:ou|on|ei)/.test(name) || /^[aeiouAEIOU][a-z]/.test(name)) && !/^us/i.test(name) + ? "an " + : "a ") + name; +} + +function buildNamespace(ref, ns) { + if (!ns) + return; + if (ns.name !== "") { + push(""); + if (!ref && config.es6) + push("export const " + escapeName(ns.name) + " = " + escapeName(ref) + "." + escapeName(ns.name) + " = (() => {"); + else + push(escapeName(ref) + "." + escapeName(ns.name) + " = (function() {"); + ++indent; + } + + if (ns instanceof Type) { + buildType(undefined, ns); + } else if (ns instanceof Service) + buildService(undefined, ns); + else if (ns.name !== "") { + push(""); + pushComment([ + ns.comment || "Namespace " + ns.name + ".", + ns.parent instanceof protobuf.Root ? "@exports " + escapeName(ns.name) : "@memberof " + exportName(ns.parent), + "@namespace" + ]); + push((config.es6 ? "const" : "var") + " " + escapeName(ns.name) + " = {};"); + } + + ns.nestedArray.forEach(function(nested) { + if (nested instanceof Enum) + buildEnum(ns.name, nested); + else if (nested instanceof Namespace) + buildNamespace(ns.name, nested); + }); + if (ns.name !== "") { + push(""); + push("return " + escapeName(ns.name) + ";"); + --indent; + push("})();"); + } +} + +var reduceableBlockStatements = { + IfStatement: true, + ForStatement: true, + WhileStatement: true +}; + +var shortVars = { + "r": "reader", + "w": "writer", + "m": "message", + "t": "tag", + "l": "length", + "c": "end", "c2": "end2", + "k": "key", + "ks": "keys", "ks2": "keys2", + "e": "error", + "f": "impl", + "o": "options", + "d": "object", + "n": "long", + "p": "properties" +}; + +function beautifyCode(code) { + // Add semicolons + code = UglifyJS.minify(code, { + compress: false, + mangle: false, + output: { beautify: true } + }).code; + // Properly beautify + var ast = espree.parse(code); + estraverse.replace(ast, { + enter: function(node, parent) { + // rename short vars + if (node.type === "Identifier" && (parent.property !== node || parent.computed) && shortVars[node.name]) + return { + "type": "Identifier", + "name": shortVars[node.name] + }; + // replace var with let if es6 + if (config.es6 && node.type === "VariableDeclaration" && node.kind === "var") { + node.kind = "let"; + return undefined; + } + // remove braces around block statements with a single child + if (node.type === "BlockStatement" && reduceableBlockStatements[parent.type] && node.body.length === 1) + return node.body[0]; + return undefined; + } + }); + code = escodegen.generate(ast, { + format: { + newline: "\n", + quotes: "double" + } + }); + // Add id, wireType comments + if (config.comments) + code = code.replace(/\.uint32\((\d+)\)/g, function($0, $1) { + var id = $1 >>> 3, + wireType = $1 & 7; + return ".uint32(/* id " + id + ", wireType " + wireType + " =*/" + $1 + ")"; + }); + return code; +} + +var renameVars = { + "Writer": "$Writer", + "Reader": "$Reader", + "util": "$util" +}; + +function buildFunction(type, functionName, gen, scope) { + var code = gen.toString(functionName) + .replace(/((?!\.)types\[\d+])(\.values)/g, "$1"); // enums: use types[N] instead of reflected types[N].values + + var ast = espree.parse(code); + /* eslint-disable no-extra-parens */ + estraverse.replace(ast, { + enter: function(node, parent) { + // rename vars + if ( + node.type === "Identifier" && renameVars[node.name] + && ( + (parent.type === "MemberExpression" && parent.object === node) + || (parent.type === "BinaryExpression" && parent.right === node) + ) + ) + return { + "type": "Identifier", + "name": renameVars[node.name] + }; + // replace this.ctor with the actual ctor + if ( + node.type === "MemberExpression" + && node.object.type === "ThisExpression" + && node.property.type === "Identifier" && node.property.name === "ctor" + ) + return { + "type": "Identifier", + "name": "$root" + type.fullName + }; + // replace types[N] with the field's actual type + if ( + node.type === "MemberExpression" + && node.object.type === "Identifier" && node.object.name === "types" + && node.property.type === "Literal" + ) + return { + "type": "Identifier", + "name": "$root" + type.fieldsArray[node.property.value].resolvedType.fullName + }; + return undefined; + } + }); + /* eslint-enable no-extra-parens */ + code = escodegen.generate(ast, { + format: { + newline: "\n", + quotes: "double" + } + }); + + if (config.beautify) + code = beautifyCode(code); + + code = code.replace(/ {4}/g, "\t"); + + var hasScope = scope && Object.keys(scope).length, + isCtor = functionName === type.name; + + if (hasScope) // remove unused scope vars + Object.keys(scope).forEach(function(key) { + if (!new RegExp("\\b(" + key + ")\\b", "g").test(code)) + delete scope[key]; + }); + + var lines = code.split(/\n/g); + if (isCtor) // constructor + push(lines[0]); + else if (hasScope) // enclose in an iife + push(escapeName(type.name) + "." + escapeName(functionName) + " = (function(" + Object.keys(scope).map(escapeName).join(", ") + ") { return " + lines[0]); + else + push(escapeName(type.name) + "." + escapeName(functionName) + " = " + lines[0]); + lines.slice(1, lines.length - 1).forEach(function(line) { + var prev = indent; + var i = 0; + while (line.charAt(i++) === "\t") + ++indent; + push(line.trim()); + indent = prev; + }); + if (isCtor) + push("}"); + else if (hasScope) + push("};})(" + Object.keys(scope).map(function(key) { return scope[key]; }).join(", ") + ");"); + else + push("};"); +} + +function toJsType(field) { + var type; + + switch (field.type) { + case "double": + case "float": + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": + type = "number"; + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": + type = config.forceLong ? "Long" : config.forceNumber ? "number" : "number|Long"; + break; + case "bool": + type = "boolean"; + break; + case "string": + type = "string"; + break; + case "bytes": + type = "Uint8Array"; + break; + default: + if (field.resolve().resolvedType) + type = exportName(field.resolvedType, !(field.resolvedType instanceof protobuf.Enum || config.forceMessage)); + else + type = "*"; // should not happen + break; + } + if (field.map) + return "Object."; + if (field.repeated) + return "Array.<" + type + ">"; + return type; +} + +function buildType(ref, type) { + + if (config.comments) { + var typeDef = [ + "Properties of " + aOrAn(type.name) + ".", + type.parent instanceof protobuf.Root ? "@exports " + escapeName("I" + type.name) : "@memberof " + exportName(type.parent), + "@interface " + escapeName("I" + type.name) + ]; + type.fieldsArray.forEach(function(field) { + var prop = util.safeProp(field.name); // either .name or ["name"] + prop = prop.substring(1, prop.charAt(0) === "[" ? prop.length - 1 : prop.length); + var jsType = toJsType(field); + if (field.optional) + jsType = jsType + "|null"; + typeDef.push("@property {" + jsType + "} " + (field.optional ? "[" + prop + "]" : prop) + " " + (field.comment || type.name + " " + field.name)); + }); + push(""); + pushComment(typeDef); + } + + // constructor + push(""); + pushComment([ + "Constructs a new " + type.name + ".", + type.parent instanceof protobuf.Root ? "@exports " + escapeName(type.name) : "@memberof " + exportName(type.parent), + "@classdesc " + (type.comment || "Represents " + aOrAn(type.name) + "."), + config.comments ? "@implements " + escapeName("I" + type.name) : null, + "@constructor", + "@param {" + exportName(type, true) + "=} [" + (config.beautify ? "properties" : "p") + "] Properties to set" + ]); + buildFunction(type, type.name, Type.generateConstructor(type)); + + // default values + var firstField = true; + type.fieldsArray.forEach(function(field) { + field.resolve(); + var prop = util.safeProp(field.name); + if (config.comments) { + push(""); + var jsType = toJsType(field); + if (field.optional && !field.map && !field.repeated && field.resolvedType instanceof Type) + jsType = jsType + "|null|undefined"; + pushComment([ + field.comment || type.name + " " + field.name + ".", + "@member {" + jsType + "} " + field.name, + "@memberof " + exportName(type), + "@instance" + ]); + } else if (firstField) { + push(""); + firstField = false; + } + if (field.repeated) + push(escapeName(type.name) + ".prototype" + prop + " = $util.emptyArray;"); // overwritten in constructor + else if (field.map) + push(escapeName(type.name) + ".prototype" + prop + " = $util.emptyObject;"); // overwritten in constructor + else if (field.long) + push(escapeName(type.name) + ".prototype" + prop + " = $util.Long ? $util.Long.fromBits(" + + JSON.stringify(field.typeDefault.low) + "," + + JSON.stringify(field.typeDefault.high) + "," + + JSON.stringify(field.typeDefault.unsigned) + + ") : " + field.typeDefault.toNumber(field.type.charAt(0) === "u") + ";"); + else if (field.bytes) { + push(escapeName(type.name) + ".prototype" + prop + " = $util.newBuffer(" + JSON.stringify(Array.prototype.slice.call(field.typeDefault)) + ");"); + } else + push(escapeName(type.name) + ".prototype" + prop + " = " + JSON.stringify(field.typeDefault) + ";"); + }); + + // virtual oneof fields + var firstOneOf = true; + type.oneofsArray.forEach(function(oneof) { + if (firstOneOf) { + firstOneOf = false; + push(""); + if (config.comments) + push("// OneOf field names bound to virtual getters and setters"); + push((config.es6 ? "let" : "var") + " $oneOfFields;"); + } + oneof.resolve(); + push(""); + pushComment([ + oneof.comment || type.name + " " + oneof.name + ".", + "@member {" + oneof.oneof.map(JSON.stringify).join("|") + "|undefined} " + escapeName(oneof.name), + "@memberof " + exportName(type), + "@instance" + ]); + push("Object.defineProperty(" + escapeName(type.name) + ".prototype, " + JSON.stringify(oneof.name) +", {"); + ++indent; + push("get: $util.oneOfGetter($oneOfFields = [" + oneof.oneof.map(JSON.stringify).join(", ") + "]),"); + push("set: $util.oneOfSetter($oneOfFields)"); + --indent; + push("});"); + }); + + if (config.create) { + push(""); + pushComment([ + "Creates a new " + type.name + " instance using the specified properties.", + "@function create", + "@memberof " + exportName(type), + "@static", + "@param {" + exportName(type, true) + "=} [properties] Properties to set", + "@returns {" + exportName(type) + "} " + type.name + " instance" + ]); + push(escapeName(type.name) + ".create = function create(properties) {"); + ++indent; + push("return new " + escapeName(type.name) + "(properties);"); + --indent; + push("};"); + } + + if (config.encode) { + push(""); + pushComment([ + "Encodes the specified " + type.name + " message. Does not implicitly {@link " + exportName(type) + ".verify|verify} messages.", + "@function encode", + "@memberof " + exportName(type), + "@static", + "@param {" + exportName(type, !config.forceMessage) + "} " + (config.beautify ? "message" : "m") + " " + type.name + " message or plain object to encode", + "@param {$protobuf.Writer} [" + (config.beautify ? "writer" : "w") + "] Writer to encode to", + "@returns {$protobuf.Writer} Writer" + ]); + buildFunction(type, "encode", protobuf.encoder(type)); + + if (config.delimited) { + push(""); + pushComment([ + "Encodes the specified " + type.name + " message, length delimited. Does not implicitly {@link " + exportName(type) + ".verify|verify} messages.", + "@function encodeDelimited", + "@memberof " + exportName(type), + "@static", + "@param {" + exportName(type, !config.forceMessage) + "} message " + type.name + " message or plain object to encode", + "@param {$protobuf.Writer} [writer] Writer to encode to", + "@returns {$protobuf.Writer} Writer" + ]); + push(escapeName(type.name) + ".encodeDelimited = function encodeDelimited(message, writer) {"); + ++indent; + push("return this.encode(message, writer).ldelim();"); + --indent; + push("};"); + } + } + + if (config.decode) { + push(""); + pushComment([ + "Decodes " + aOrAn(type.name) + " message from the specified reader or buffer.", + "@function decode", + "@memberof " + exportName(type), + "@static", + "@param {$protobuf.Reader|Uint8Array} " + (config.beautify ? "reader" : "r") + " Reader or buffer to decode from", + "@param {number} [" + (config.beautify ? "length" : "l") + "] Message length if known beforehand", + "@returns {" + exportName(type) + "} " + type.name, + "@throws {Error} If the payload is not a reader or valid buffer", + "@throws {$protobuf.util.ProtocolError} If required fields are missing" + ]); + buildFunction(type, "decode", protobuf.decoder(type)); + + if (config.delimited) { + push(""); + pushComment([ + "Decodes " + aOrAn(type.name) + " message from the specified reader or buffer, length delimited.", + "@function decodeDelimited", + "@memberof " + exportName(type), + "@static", + "@param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from", + "@returns {" + exportName(type) + "} " + type.name, + "@throws {Error} If the payload is not a reader or valid buffer", + "@throws {$protobuf.util.ProtocolError} If required fields are missing" + ]); + push(escapeName(type.name) + ".decodeDelimited = function decodeDelimited(reader) {"); + ++indent; + push("if (!(reader instanceof $Reader))"); + ++indent; + push("reader = new $Reader(reader);"); + --indent; + push("return this.decode(reader, reader.uint32());"); + --indent; + push("};"); + } + } + + if (config.verify) { + push(""); + pushComment([ + "Verifies " + aOrAn(type.name) + " message.", + "@function verify", + "@memberof " + exportName(type), + "@static", + "@param {Object.} " + (config.beautify ? "message" : "m") + " Plain object to verify", + "@returns {string|null} `null` if valid, otherwise the reason why it is not" + ]); + buildFunction(type, "verify", protobuf.verifier(type)); + } + + if (config.convert) { + push(""); + pushComment([ + "Creates " + aOrAn(type.name) + " message from a plain object. Also converts values to their respective internal types.", + "@function fromObject", + "@memberof " + exportName(type), + "@static", + "@param {Object.} " + (config.beautify ? "object" : "d") + " Plain object", + "@returns {" + exportName(type) + "} " + type.name + ]); + buildFunction(type, "fromObject", protobuf.converter.fromObject(type)); + + push(""); + pushComment([ + "Creates a plain object from " + aOrAn(type.name) + " message. Also converts values to other types if specified.", + "@function toObject", + "@memberof " + exportName(type), + "@static", + "@param {" + exportName(type) + "} " + (config.beautify ? "message" : "m") + " " + type.name, + "@param {$protobuf.IConversionOptions} [" + (config.beautify ? "options" : "o") + "] Conversion options", + "@returns {Object.} Plain object" + ]); + buildFunction(type, "toObject", protobuf.converter.toObject(type)); + + push(""); + pushComment([ + "Converts this " + type.name + " to JSON.", + "@function toJSON", + "@memberof " + exportName(type), + "@instance", + "@returns {Object.} JSON object" + ]); + push(escapeName(type.name) + ".prototype.toJSON = function toJSON() {"); + ++indent; + push("return this.constructor.toObject(this, $protobuf.util.toJSONOptions);"); + --indent; + push("};"); + } +} + +function buildService(ref, service) { + + push(""); + pushComment([ + "Constructs a new " + service.name + " service.", + service.parent instanceof protobuf.Root ? "@exports " + escapeName(service.name) : "@memberof " + exportName(service.parent), + "@classdesc " + (service.comment || "Represents " + aOrAn(service.name)), + "@extends $protobuf.rpc.Service", + "@constructor", + "@param {$protobuf.RPCImpl} rpcImpl RPC implementation", + "@param {boolean} [requestDelimited=false] Whether requests are length-delimited", + "@param {boolean} [responseDelimited=false] Whether responses are length-delimited" + ]); + push("function " + escapeName(service.name) + "(rpcImpl, requestDelimited, responseDelimited) {"); + ++indent; + push("$protobuf.rpc.Service.call(this, rpcImpl, requestDelimited, responseDelimited);"); + --indent; + push("}"); + push(""); + push("(" + escapeName(service.name) + ".prototype = Object.create($protobuf.rpc.Service.prototype)).constructor = " + escapeName(service.name) + ";"); + + if (config.create) { + push(""); + pushComment([ + "Creates new " + service.name + " service using the specified rpc implementation.", + "@function create", + "@memberof " + exportName(service), + "@static", + "@param {$protobuf.RPCImpl} rpcImpl RPC implementation", + "@param {boolean} [requestDelimited=false] Whether requests are length-delimited", + "@param {boolean} [responseDelimited=false] Whether responses are length-delimited", + "@returns {" + escapeName(service.name) + "} RPC service. Useful where requests and/or responses are streamed." + ]); + push(escapeName(service.name) + ".create = function create(rpcImpl, requestDelimited, responseDelimited) {"); + ++indent; + push("return new this(rpcImpl, requestDelimited, responseDelimited);"); + --indent; + push("};"); + } + + service.methodsArray.forEach(function(method) { + method.resolve(); + var lcName = protobuf.util.lcFirst(method.name), + cbName = escapeName(method.name + "Callback"); + push(""); + pushComment([ + "Callback as used by {@link " + exportName(service) + "#" + escapeName(lcName) + "}.", + // This is a more specialized version of protobuf.rpc.ServiceCallback + "@memberof " + exportName(service), + "@typedef " + cbName, + "@type {function}", + "@param {Error|null} error Error, if any", + "@param {" + exportName(method.resolvedResponseType) + "} [response] " + method.resolvedResponseType.name + ]); + push(""); + pushComment([ + method.comment || "Calls " + method.name + ".", + "@function " + lcName, + "@memberof " + exportName(service), + "@instance", + "@param {" + exportName(method.resolvedRequestType, !config.forceMessage) + "} request " + method.resolvedRequestType.name + " message or plain object", + "@param {" + exportName(service) + "." + cbName + "} callback Node-style callback called with the error, if any, and " + method.resolvedResponseType.name, + "@returns {undefined}", + "@variation 1" + ]); + push("Object.defineProperty(" + escapeName(service.name) + ".prototype" + util.safeProp(lcName) + " = function " + escapeName(lcName) + "(request, callback) {"); + ++indent; + push("return this.rpcCall(" + escapeName(lcName) + ", $root." + exportName(method.resolvedRequestType) + ", $root." + exportName(method.resolvedResponseType) + ", request, callback);"); + --indent; + push("}, \"name\", { value: " + JSON.stringify(method.name) + " });"); + if (config.comments) + push(""); + pushComment([ + method.comment || "Calls " + method.name + ".", + "@function " + lcName, + "@memberof " + exportName(service), + "@instance", + "@param {" + exportName(method.resolvedRequestType, !config.forceMessage) + "} request " + method.resolvedRequestType.name + " message or plain object", + "@returns {Promise<" + exportName(method.resolvedResponseType) + ">} Promise", + "@variation 2" + ]); + }); +} + +function buildEnum(ref, enm) { + + push(""); + var comment = [ + enm.comment || enm.name + " enum.", + enm.parent instanceof protobuf.Root ? "@exports " + escapeName(enm.name) : "@name " + exportName(enm), + config.forceEnumString ? "@enum {number}" : "@enum {string}", + ]; + Object.keys(enm.values).forEach(function(key) { + var val = config.forceEnumString ? key : enm.values[key]; + comment.push((config.forceEnumString ? "@property {string} " : "@property {number} ") + key + "=" + val + " " + (enm.comments[key] || key + " value")); + }); + pushComment(comment); + push(escapeName(ref) + "." + escapeName(enm.name) + " = (function() {"); + ++indent; + push((config.es6 ? "const" : "var") + " valuesById = {}, values = Object.create(valuesById);"); + var aliased = []; + Object.keys(enm.values).forEach(function(key) { + var valueId = enm.values[key]; + var val = config.forceEnumString ? JSON.stringify(key) : valueId; + if (aliased.indexOf(valueId) > -1) + push("values[" + JSON.stringify(key) + "] = " + val + ";"); + else { + push("values[valuesById[" + valueId + "] = " + JSON.stringify(key) + "] = " + val + ";"); + aliased.push(valueId); + } + }); + push("return values;"); + --indent; + push("})();"); +} diff --git a/node_modules/protobufjs/cli/util.js b/node_modules/protobufjs/cli/util.js new file mode 100644 index 0000000..ffce1ed --- /dev/null +++ b/node_modules/protobufjs/cli/util.js @@ -0,0 +1,183 @@ +"use strict"; +var fs = require("fs"), + path = require("path"), + child_process = require("child_process"); + +var semver; + +try { + // installed as a peer dependency + require.resolve("protobufjs"); + exports.pathToProtobufJs = "protobufjs"; +} catch (e) { + // local development, i.e. forked from github + exports.pathToProtobufJs = ".."; +} + +var protobuf = require(exports.pathToProtobufJs); + +function basenameCompare(a, b) { + var aa = String(a).replace(/\.\w+$/, "").split(/(-?\d*\.?\d+)/g), + bb = String(b).replace(/\.\w+$/, "").split(/(-?\d*\.?\d+)/g); + for (var i = 0, k = Math.min(aa.length, bb.length); i < k; i++) { + var x = parseFloat(aa[i]) || aa[i].toLowerCase(), + y = parseFloat(bb[i]) || bb[i].toLowerCase(); + if (x < y) + return -1; + if (x > y) + return 1; + } + return a.length < b.length ? -1 : 0; +} + +exports.requireAll = function requireAll(dirname) { + dirname = path.join(__dirname, dirname); + var files = fs.readdirSync(dirname).sort(basenameCompare), + all = {}; + files.forEach(function(file) { + var basename = path.basename(file, ".js"), + extname = path.extname(file); + if (extname === ".js") + all[basename] = require(path.join(dirname, file)); + }); + return all; +}; + +exports.traverse = function traverse(current, fn) { + fn(current); + if (current.fieldsArray) + current.fieldsArray.forEach(function(field) { + traverse(field, fn); + }); + if (current.oneofsArray) + current.oneofsArray.forEach(function(oneof) { + traverse(oneof, fn); + }); + if (current.methodsArray) + current.methodsArray.forEach(function(method) { + traverse(method, fn); + }); + if (current.nestedArray) + current.nestedArray.forEach(function(nested) { + traverse(nested, fn); + }); +}; + +exports.traverseResolved = function traverseResolved(current, fn) { + fn(current); + if (current.resolvedType) + traverseResolved(current.resolvedType, fn); + if (current.resolvedKeyType) + traverseResolved(current.resolvedKeyType, fn); + if (current.resolvedRequestType) + traverseResolved(current.resolvedRequestType, fn); + if (current.resolvedResponseType) + traverseResolved(current.resolvedResponseType, fn); +}; + +exports.inspect = function inspect(object, indent) { + if (!object) + return ""; + var chalk = require("chalk"); + var sb = []; + if (!indent) + indent = ""; + var ind = indent ? indent.substring(0, indent.length - 2) + "└ " : ""; + sb.push( + ind + chalk.bold(object.toString()) + (object.visible ? " (visible)" : ""), + indent + chalk.gray("parent: ") + object.parent + ); + if (object instanceof protobuf.Field) { + if (object.extend !== undefined) + sb.push(indent + chalk.gray("extend: ") + object.extend); + if (object.partOf) + sb.push(indent + chalk.gray("oneof : ") + object.oneof); + } + sb.push(""); + if (object.fieldsArray) + object.fieldsArray.forEach(function(field) { + sb.push(inspect(field, indent + " ")); + }); + if (object.oneofsArray) + object.oneofsArray.forEach(function(oneof) { + sb.push(inspect(oneof, indent + " ")); + }); + if (object.methodsArray) + object.methodsArray.forEach(function(service) { + sb.push(inspect(service, indent + " ")); + }); + if (object.nestedArray) + object.nestedArray.forEach(function(nested) { + sb.push(inspect(nested, indent + " ")); + }); + return sb.join("\n"); +}; + +function modExists(name, version) { + for (var i = 0; i < module.paths.length; ++i) { + try { + var pkg = JSON.parse(fs.readFileSync(path.join(module.paths[i], name, "package.json"))); + return semver + ? semver.satisfies(pkg.version, version) + : parseInt(pkg.version, 10) === parseInt(version.replace(/^[\^~]/, ""), 10); // used for semver only + } catch (e) {/**/} + } + return false; +} + +function modInstall(install) { + child_process.execSync("npm --silent install " + (typeof install === "string" ? install : install.join(" ")), { + cwd: __dirname, + stdio: "ignore" + }); +} + +exports.setup = function() { + var pkg = require(path.join(__dirname, "..", "package.json")); + var version = pkg.dependencies["semver"] || pkg.devDependencies["semver"]; + if (!modExists("semver", version)) { + process.stderr.write("installing semver@" + version + "\n"); + modInstall("semver@" + version); + } + semver = require("semver"); // used from now on for version comparison + var install = []; + pkg.cliDependencies.forEach(function(name) { + if (name === "semver") + return; + version = pkg.dependencies[name] || pkg.devDependencies[name]; + if (!modExists(name, version)) { + process.stderr.write("installing " + name + "@" + version + "\n"); + install.push(name + "@" + version); + } + }); + require("../scripts/postinstall"); // emit postinstall warning, if any + if (!install.length) + return; + modInstall(install); +}; + +exports.wrap = function(OUTPUT, options) { + var name = options.wrap || "default"; + var wrap; + try { + // try built-in wrappers first + wrap = fs.readFileSync(path.join(__dirname, "wrappers", name + ".js")).toString("utf8"); + } catch (e) { + // otherwise fetch the custom one + wrap = fs.readFileSync(path.resolve(process.cwd(), name)).toString("utf8"); + } + wrap = wrap.replace(/\$DEPENDENCY/g, JSON.stringify(options.dependency || "protobufjs")); + wrap = wrap.replace(/( *)\$OUTPUT;/, function($0, $1) { + return $1.length ? OUTPUT.replace(/^/mg, $1) : OUTPUT; + }); + if (options.lint !== "") + wrap = "/*" + options.lint + "*/\n" + wrap; + return wrap.replace(/\r?\n/g, "\n"); +}; + +exports.pad = function(str, len, l) { + while (str.length < len) + str = l ? str + " " : " " + str; + return str; +}; + diff --git a/node_modules/protobufjs/cli/wrappers/amd.js b/node_modules/protobufjs/cli/wrappers/amd.js new file mode 100644 index 0000000..c43dd73 --- /dev/null +++ b/node_modules/protobufjs/cli/wrappers/amd.js @@ -0,0 +1,7 @@ +define([$DEPENDENCY], function($protobuf) { + "use strict"; + + $OUTPUT; + + return $root; +}); diff --git a/node_modules/protobufjs/cli/wrappers/closure.js b/node_modules/protobufjs/cli/wrappers/closure.js new file mode 100644 index 0000000..c94327c --- /dev/null +++ b/node_modules/protobufjs/cli/wrappers/closure.js @@ -0,0 +1,7 @@ +(function($protobuf) { + "use strict"; + + $OUTPUT; + + return $root; +})(protobuf); diff --git a/node_modules/protobufjs/cli/wrappers/commonjs.js b/node_modules/protobufjs/cli/wrappers/commonjs.js new file mode 100644 index 0000000..6dc9168 --- /dev/null +++ b/node_modules/protobufjs/cli/wrappers/commonjs.js @@ -0,0 +1,7 @@ +"use strict"; + +var $protobuf = require($DEPENDENCY); + +$OUTPUT; + +module.exports = $root; diff --git a/node_modules/protobufjs/cli/wrappers/default.js b/node_modules/protobufjs/cli/wrappers/default.js new file mode 100644 index 0000000..34b29ec --- /dev/null +++ b/node_modules/protobufjs/cli/wrappers/default.js @@ -0,0 +1,15 @@ +(function(global, factory) { /* global define, require, module */ + + /* AMD */ if (typeof define === 'function' && define.amd) + define([$DEPENDENCY], factory); + + /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports) + module.exports = factory(require($DEPENDENCY)); + +})(this, function($protobuf) { + "use strict"; + + $OUTPUT; + + return $root; +}); diff --git a/node_modules/protobufjs/cli/wrappers/es6.js b/node_modules/protobufjs/cli/wrappers/es6.js new file mode 100644 index 0000000..5bdc43c --- /dev/null +++ b/node_modules/protobufjs/cli/wrappers/es6.js @@ -0,0 +1,5 @@ +import * as $protobuf from $DEPENDENCY; + +$OUTPUT; + +export { $root as default }; diff --git a/node_modules/protobufjs/dist/README.md b/node_modules/protobufjs/dist/README.md new file mode 100644 index 0000000..93a54cc --- /dev/null +++ b/node_modules/protobufjs/dist/README.md @@ -0,0 +1,31 @@ +This folder contains prebuilt browser versions of the full library. When sending pull requests, it is not required to update these. + +Prebuilt files are in source control to enable pain-free frontend respectively CDN usage: + +CDN usage +--------- + +Development: +``` + +``` + +Production: +``` + +``` + +**NOTE:** Remember to replace the version tag with the exact [release](https://github.com/dcodeIO/protobuf.js/tags) your project depends upon. + +Frontend usage +-------------- + +Development: +``` + +``` + +Production: +``` + +``` diff --git a/node_modules/protobufjs/dist/light/README.md b/node_modules/protobufjs/dist/light/README.md new file mode 100644 index 0000000..2122c3f --- /dev/null +++ b/node_modules/protobufjs/dist/light/README.md @@ -0,0 +1,31 @@ +This folder contains prebuilt browser versions of the light library suitable for use with reflection, static code and JSON descriptors / modules. When sending pull requests, it is not required to update these. + +Prebuilt files are in source control to enable pain-free frontend respectively CDN usage: + +CDN usage +--------- + +Development: +``` + +``` + +Production: +``` + +``` + +**NOTE:** Remember to replace the version tag with the exact [release](https://github.com/dcodeIO/protobuf.js/tags) your project depends upon. + +Frontend usage +-------------- + +Development: +``` + +``` + +Production: +``` + +``` diff --git a/node_modules/protobufjs/dist/light/protobuf.js b/node_modules/protobufjs/dist/light/protobuf.js new file mode 100644 index 0000000..a2ff125 --- /dev/null +++ b/node_modules/protobufjs/dist/light/protobuf.js @@ -0,0 +1,7152 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:25 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +(function(undefined){"use strict";(function prelude(modules, cache, entries) { + + // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS + // sources through a conflict-free require shim and is again wrapped within an iife that + // provides a minification-friendly `undefined` var plus a global "use strict" directive + // so that minification can remove the directives of each module. + + function $require(name) { + var $module = cache[name]; + if (!$module) + modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports); + return $module.exports; + } + + var protobuf = $require(entries[0]); + + // Expose globally + protobuf.util.global.protobuf = protobuf; + + // Be nice to AMD + if (typeof define === "function" && define.amd) + define(["long"], function(Long) { + if (Long && Long.isLong) { + protobuf.util.Long = Long; + protobuf.configure(); + } + return protobuf; + }); + + // Be nice to CommonJS + if (typeof module === "object" && module && module.exports) + module.exports = protobuf; + +})/* end of prelude */({1:[function(require,module,exports){ +"use strict"; +module.exports = asPromise; + +/** + * Callback as used by {@link util.asPromise}. + * @typedef asPromiseCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {...*} params Additional arguments + * @returns {undefined} + */ + +/** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ +function asPromise(fn, ctx/*, varargs */) { + var params = new Array(arguments.length - 1), + offset = 0, + index = 2, + pending = true; + while (index < arguments.length) + params[offset++] = arguments[index++]; + return new Promise(function executor(resolve, reject) { + params[offset] = function callback(err/*, varargs */) { + if (pending) { + pending = false; + if (err) + reject(err); + else { + var params = new Array(arguments.length - 1), + offset = 0; + while (offset < params.length) + params[offset++] = arguments[offset]; + resolve.apply(null, params); + } + } + }; + try { + fn.apply(ctx || null, params); + } catch (err) { + if (pending) { + pending = false; + reject(err); + } + } + }); +} + +},{}],2:[function(require,module,exports){ +"use strict"; + +/** + * A minimal base64 implementation for number arrays. + * @memberof util + * @namespace + */ +var base64 = exports; + +/** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ +base64.length = function length(string) { + var p = string.length; + if (!p) + return 0; + var n = 0; + while (--p % 4 > 1 && string.charAt(p) === "=") + ++n; + return Math.ceil(string.length * 3) / 4 - n; +}; + +// Base64 encoding table +var b64 = new Array(64); + +// Base64 decoding table +var s64 = new Array(123); + +// 65..90, 97..122, 48..57, 43, 47 +for (var i = 0; i < 64;) + s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++; + +/** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ +base64.encode = function encode(buffer, start, end) { + var parts = null, + chunk = []; + var i = 0, // output index + j = 0, // goto index + t; // temporary + while (start < end) { + var b = buffer[start++]; + switch (j) { + case 0: + chunk[i++] = b64[b >> 2]; + t = (b & 3) << 4; + j = 1; + break; + case 1: + chunk[i++] = b64[t | b >> 4]; + t = (b & 15) << 2; + j = 2; + break; + case 2: + chunk[i++] = b64[t | b >> 6]; + chunk[i++] = b64[b & 63]; + j = 0; + break; + } + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (j) { + chunk[i++] = b64[t]; + chunk[i++] = 61; + if (j === 1) + chunk[i++] = 61; + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +var invalidEncoding = "invalid encoding"; + +/** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ +base64.decode = function decode(string, buffer, offset) { + var start = offset; + var j = 0, // goto index + t; // temporary + for (var i = 0; i < string.length;) { + var c = string.charCodeAt(i++); + if (c === 61 && j > 1) + break; + if ((c = s64[c]) === undefined) + throw Error(invalidEncoding); + switch (j) { + case 0: + t = c; + j = 1; + break; + case 1: + buffer[offset++] = t << 2 | (c & 48) >> 4; + t = c; + j = 2; + break; + case 2: + buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2; + t = c; + j = 3; + break; + case 3: + buffer[offset++] = (t & 3) << 6 | c; + j = 0; + break; + } + } + if (j === 1) + throw Error(invalidEncoding); + return offset - start; +}; + +/** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if probably base64 encoded, otherwise false + */ +base64.test = function test(string) { + return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string); +}; + +},{}],3:[function(require,module,exports){ +"use strict"; +module.exports = codegen; + +/** + * Begins generating a function. + * @memberof util + * @param {string[]} functionParams Function parameter names + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + */ +function codegen(functionParams, functionName) { + + /* istanbul ignore if */ + if (typeof functionParams === "string") { + functionName = functionParams; + functionParams = undefined; + } + + var body = []; + + /** + * Appends code to the function's body or finishes generation. + * @typedef Codegen + * @type {function} + * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any + * @param {...*} [formatParams] Format parameters + * @returns {Codegen|Function} Itself or the generated function if finished + * @throws {Error} If format parameter counts do not match + */ + + function Codegen(formatStringOrScope) { + // note that explicit array handling below makes this ~50% faster + + // finish the function + if (typeof formatStringOrScope !== "string") { + var source = toString(); + if (codegen.verbose) + console.log("codegen: " + source); // eslint-disable-line no-console + source = "return " + source; + if (formatStringOrScope) { + var scopeKeys = Object.keys(formatStringOrScope), + scopeParams = new Array(scopeKeys.length + 1), + scopeValues = new Array(scopeKeys.length), + scopeOffset = 0; + while (scopeOffset < scopeKeys.length) { + scopeParams[scopeOffset] = scopeKeys[scopeOffset]; + scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]]; + } + scopeParams[scopeOffset] = source; + return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func + } + return Function(source)(); // eslint-disable-line no-new-func + } + + // otherwise append to body + var formatParams = new Array(arguments.length - 1), + formatOffset = 0; + while (formatOffset < formatParams.length) + formatParams[formatOffset] = arguments[++formatOffset]; + formatOffset = 0; + formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) { + var value = formatParams[formatOffset++]; + switch ($1) { + case "d": case "f": return String(Number(value)); + case "i": return String(Math.floor(value)); + case "j": return JSON.stringify(value); + case "s": return String(value); + } + return "%"; + }); + if (formatOffset !== formatParams.length) + throw Error("parameter count mismatch"); + body.push(formatStringOrScope); + return Codegen; + } + + function toString(functionNameOverride) { + return "function " + (functionNameOverride || functionName || "") + "(" + (functionParams && functionParams.join(",") || "") + "){\n " + body.join("\n ") + "\n}"; + } + + Codegen.toString = toString; + return Codegen; +} + +/** + * Begins generating a function. + * @memberof util + * @function codegen + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + * @variation 2 + */ + +/** + * When set to `true`, codegen will log generated code to console. Useful for debugging. + * @name util.codegen.verbose + * @type {boolean} + */ +codegen.verbose = false; + +},{}],4:[function(require,module,exports){ +"use strict"; +module.exports = EventEmitter; + +/** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ +function EventEmitter() { + + /** + * Registered listeners. + * @type {Object.} + * @private + */ + this._listeners = {}; +} + +/** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.on = function on(evt, fn, ctx) { + (this._listeners[evt] || (this._listeners[evt] = [])).push({ + fn : fn, + ctx : ctx || this + }); + return this; +}; + +/** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.off = function off(evt, fn) { + if (evt === undefined) + this._listeners = {}; + else { + if (fn === undefined) + this._listeners[evt] = []; + else { + var listeners = this._listeners[evt]; + for (var i = 0; i < listeners.length;) + if (listeners[i].fn === fn) + listeners.splice(i, 1); + else + ++i; + } + } + return this; +}; + +/** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.emit = function emit(evt) { + var listeners = this._listeners[evt]; + if (listeners) { + var args = [], + i = 1; + for (; i < arguments.length;) + args.push(arguments[i++]); + for (i = 0; i < listeners.length;) + listeners[i].fn.apply(listeners[i++].ctx, args); + } + return this; +}; + +},{}],5:[function(require,module,exports){ +"use strict"; +module.exports = fetch; + +var asPromise = require(1), + inquire = require(7); + +var fs = inquire("fs"); + +/** + * Node-style callback as used by {@link util.fetch}. + * @typedef FetchCallback + * @type {function} + * @param {?Error} error Error, if any, otherwise `null` + * @param {string} [contents] File contents, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Options as used by {@link util.fetch}. + * @typedef FetchOptions + * @type {Object} + * @property {boolean} [binary=false] Whether expecting a binary response + * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest + */ + +/** + * Fetches the contents of a file. + * @memberof util + * @param {string} filename File path or url + * @param {FetchOptions} options Fetch options + * @param {FetchCallback} callback Callback function + * @returns {undefined} + */ +function fetch(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = {}; + } else if (!options) + options = {}; + + if (!callback) + return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this + + // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found. + if (!options.xhr && fs && fs.readFile) + return fs.readFile(filename, function fetchReadFileCallback(err, contents) { + return err && typeof XMLHttpRequest !== "undefined" + ? fetch.xhr(filename, options, callback) + : err + ? callback(err) + : callback(null, options.binary ? contents : contents.toString("utf8")); + }); + + // use the XHR version otherwise. + return fetch.xhr(filename, options, callback); +} + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchOptions} [options] Fetch options + * @returns {Promise} Promise + * @variation 3 + */ + +/**/ +fetch.xhr = function fetch_xhr(filename, options, callback) { + var xhr = new XMLHttpRequest(); + xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() { + + if (xhr.readyState !== 4) + return undefined; + + // local cors security errors return status 0 / empty string, too. afaik this cannot be + // reliably distinguished from an actually empty file for security reasons. feel free + // to send a pull request if you are aware of a solution. + if (xhr.status !== 0 && xhr.status !== 200) + return callback(Error("status " + xhr.status)); + + // if binary data is expected, make sure that some sort of array is returned, even if + // ArrayBuffers are not supported. the binary string fallback, however, is unsafe. + if (options.binary) { + var buffer = xhr.response; + if (!buffer) { + buffer = []; + for (var i = 0; i < xhr.responseText.length; ++i) + buffer.push(xhr.responseText.charCodeAt(i) & 255); + } + return callback(null, typeof Uint8Array !== "undefined" ? new Uint8Array(buffer) : buffer); + } + return callback(null, xhr.responseText); + }; + + if (options.binary) { + // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers + if ("overrideMimeType" in xhr) + xhr.overrideMimeType("text/plain; charset=x-user-defined"); + xhr.responseType = "arraybuffer"; + } + + xhr.open("GET", filename); + xhr.send(); +}; + +},{"1":1,"7":7}],6:[function(require,module,exports){ +"use strict"; + +module.exports = factory(factory); + +/** + * Reads / writes floats / doubles from / to buffers. + * @name util.float + * @namespace + */ + +/** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name util.float.writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name util.float.writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name util.float.readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name util.float.readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name util.float.writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name util.float.writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name util.float.readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name util.float.readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +// Factory function for the purpose of node-based testing in modified global environments +function factory(exports) { + + // float: typed array + if (typeof Float32Array !== "undefined") (function() { + + var f32 = new Float32Array([ -0 ]), + f8b = new Uint8Array(f32.buffer), + le = f8b[3] === 128; + + function writeFloat_f32_cpy(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + } + + function writeFloat_f32_rev(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[3]; + buf[pos + 1] = f8b[2]; + buf[pos + 2] = f8b[1]; + buf[pos + 3] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev; + /* istanbul ignore next */ + exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy; + + function readFloat_f32_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + return f32[0]; + } + + function readFloat_f32_rev(buf, pos) { + f8b[3] = buf[pos ]; + f8b[2] = buf[pos + 1]; + f8b[1] = buf[pos + 2]; + f8b[0] = buf[pos + 3]; + return f32[0]; + } + + /* istanbul ignore next */ + exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev; + /* istanbul ignore next */ + exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy; + + // float: ieee754 + })(); else (function() { + + function writeFloat_ieee754(writeUint, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos); + else if (isNaN(val)) + writeUint(2143289344, buf, pos); + else if (val > 3.4028234663852886e+38) // +-Infinity + writeUint((sign << 31 | 2139095040) >>> 0, buf, pos); + else if (val < 1.1754943508222875e-38) // denormal + writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos); + else { + var exponent = Math.floor(Math.log(val) / Math.LN2), + mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607; + writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos); + } + } + + exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE); + exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE); + + function readFloat_ieee754(readUint, buf, pos) { + var uint = readUint(buf, pos), + sign = (uint >> 31) * 2 + 1, + exponent = uint >>> 23 & 255, + mantissa = uint & 8388607; + return exponent === 255 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 1.401298464324817e-45 * mantissa + : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608); + } + + exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE); + exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE); + + })(); + + // double: typed array + if (typeof Float64Array !== "undefined") (function() { + + var f64 = new Float64Array([-0]), + f8b = new Uint8Array(f64.buffer), + le = f8b[7] === 128; + + function writeDouble_f64_cpy(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + buf[pos + 4] = f8b[4]; + buf[pos + 5] = f8b[5]; + buf[pos + 6] = f8b[6]; + buf[pos + 7] = f8b[7]; + } + + function writeDouble_f64_rev(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[7]; + buf[pos + 1] = f8b[6]; + buf[pos + 2] = f8b[5]; + buf[pos + 3] = f8b[4]; + buf[pos + 4] = f8b[3]; + buf[pos + 5] = f8b[2]; + buf[pos + 6] = f8b[1]; + buf[pos + 7] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev; + /* istanbul ignore next */ + exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy; + + function readDouble_f64_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + f8b[4] = buf[pos + 4]; + f8b[5] = buf[pos + 5]; + f8b[6] = buf[pos + 6]; + f8b[7] = buf[pos + 7]; + return f64[0]; + } + + function readDouble_f64_rev(buf, pos) { + f8b[7] = buf[pos ]; + f8b[6] = buf[pos + 1]; + f8b[5] = buf[pos + 2]; + f8b[4] = buf[pos + 3]; + f8b[3] = buf[pos + 4]; + f8b[2] = buf[pos + 5]; + f8b[1] = buf[pos + 6]; + f8b[0] = buf[pos + 7]; + return f64[0]; + } + + /* istanbul ignore next */ + exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev; + /* istanbul ignore next */ + exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy; + + // double: ieee754 + })(); else (function() { + + function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) { + writeUint(0, buf, pos + off0); + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1); + } else if (isNaN(val)) { + writeUint(0, buf, pos + off0); + writeUint(2146959360, buf, pos + off1); + } else if (val > 1.7976931348623157e+308) { // +-Infinity + writeUint(0, buf, pos + off0); + writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1); + } else { + var mantissa; + if (val < 2.2250738585072014e-308) { // denormal + mantissa = val / 5e-324; + writeUint(mantissa >>> 0, buf, pos + off0); + writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1); + } else { + var exponent = Math.floor(Math.log(val) / Math.LN2); + if (exponent === 1024) + exponent = 1023; + mantissa = val * Math.pow(2, -exponent); + writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0); + writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1); + } + } + } + + exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4); + exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0); + + function readDouble_ieee754(readUint, off0, off1, buf, pos) { + var lo = readUint(buf, pos + off0), + hi = readUint(buf, pos + off1); + var sign = (hi >> 31) * 2 + 1, + exponent = hi >>> 20 & 2047, + mantissa = 4294967296 * (hi & 1048575) + lo; + return exponent === 2047 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 5e-324 * mantissa + : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496); + } + + exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4); + exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0); + + })(); + + return exports; +} + +// uint helpers + +function writeUintLE(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +function writeUintBE(val, buf, pos) { + buf[pos ] = val >>> 24; + buf[pos + 1] = val >>> 16 & 255; + buf[pos + 2] = val >>> 8 & 255; + buf[pos + 3] = val & 255; +} + +function readUintLE(buf, pos) { + return (buf[pos ] + | buf[pos + 1] << 8 + | buf[pos + 2] << 16 + | buf[pos + 3] << 24) >>> 0; +} + +function readUintBE(buf, pos) { + return (buf[pos ] << 24 + | buf[pos + 1] << 16 + | buf[pos + 2] << 8 + | buf[pos + 3]) >>> 0; +} + +},{}],7:[function(require,module,exports){ +"use strict"; +module.exports = inquire; + +/** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ +function inquire(moduleName) { + try { + var mod = eval("quire".replace(/^/,"re"))(moduleName); // eslint-disable-line no-eval + if (mod && (mod.length || Object.keys(mod).length)) + return mod; + } catch (e) {} // eslint-disable-line no-empty + return null; +} + +},{}],8:[function(require,module,exports){ +"use strict"; + +/** + * A minimal path module to resolve Unix, Windows and URL paths alike. + * @memberof util + * @namespace + */ +var path = exports; + +var isAbsolute = +/** + * Tests if the specified path is absolute. + * @param {string} path Path to test + * @returns {boolean} `true` if path is absolute + */ +path.isAbsolute = function isAbsolute(path) { + return /^(?:\/|\w+:)/.test(path); +}; + +var normalize = +/** + * Normalizes the specified path. + * @param {string} path Path to normalize + * @returns {string} Normalized path + */ +path.normalize = function normalize(path) { + path = path.replace(/\\/g, "/") + .replace(/\/{2,}/g, "/"); + var parts = path.split("/"), + absolute = isAbsolute(path), + prefix = ""; + if (absolute) + prefix = parts.shift() + "/"; + for (var i = 0; i < parts.length;) { + if (parts[i] === "..") { + if (i > 0 && parts[i - 1] !== "..") + parts.splice(--i, 2); + else if (absolute) + parts.splice(i, 1); + else + ++i; + } else if (parts[i] === ".") + parts.splice(i, 1); + else + ++i; + } + return prefix + parts.join("/"); +}; + +/** + * Resolves the specified include path against the specified origin path. + * @param {string} originPath Path to the origin file + * @param {string} includePath Include path relative to origin path + * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized + * @returns {string} Path to the include file + */ +path.resolve = function resolve(originPath, includePath, alreadyNormalized) { + if (!alreadyNormalized) + includePath = normalize(includePath); + if (isAbsolute(includePath)) + return includePath; + if (!alreadyNormalized) + originPath = normalize(originPath); + return (originPath = originPath.replace(/(?:\/|^)[^/]+$/, "")).length ? normalize(originPath + "/" + includePath) : includePath; +}; + +},{}],9:[function(require,module,exports){ +"use strict"; +module.exports = pool; + +/** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + +/** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ + +/** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ +function pool(alloc, slice, size) { + var SIZE = size || 8192; + var MAX = SIZE >>> 1; + var slab = null; + var offset = SIZE; + return function pool_alloc(size) { + if (size < 1 || size > MAX) + return alloc(size); + if (offset + size > SIZE) { + slab = alloc(SIZE); + offset = 0; + } + var buf = slice.call(slab, offset, offset += size); + if (offset & 7) // align to 32 bit + offset = (offset | 7) + 1; + return buf; + }; +} + +},{}],10:[function(require,module,exports){ +"use strict"; + +/** + * A minimal UTF8 implementation for number arrays. + * @memberof util + * @namespace + */ +var utf8 = exports; + +/** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ +utf8.length = function utf8_length(string) { + var len = 0, + c = 0; + for (var i = 0; i < string.length; ++i) { + c = string.charCodeAt(i); + if (c < 128) + len += 1; + else if (c < 2048) + len += 2; + else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) { + ++i; + len += 4; + } else + len += 3; + } + return len; +}; + +/** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ +utf8.read = function utf8_read(buffer, start, end) { + var len = end - start; + if (len < 1) + return ""; + var parts = null, + chunk = [], + i = 0, // char offset + t; // temporary + while (start < end) { + t = buffer[start++]; + if (t < 128) + chunk[i++] = t; + else if (t > 191 && t < 224) + chunk[i++] = (t & 31) << 6 | buffer[start++] & 63; + else if (t > 239 && t < 365) { + t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000; + chunk[i++] = 0xD800 + (t >> 10); + chunk[i++] = 0xDC00 + (t & 1023); + } else + chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63; + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +/** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ +utf8.write = function utf8_write(string, buffer, offset) { + var start = offset, + c1, // character 1 + c2; // character 2 + for (var i = 0; i < string.length; ++i) { + c1 = string.charCodeAt(i); + if (c1 < 128) { + buffer[offset++] = c1; + } else if (c1 < 2048) { + buffer[offset++] = c1 >> 6 | 192; + buffer[offset++] = c1 & 63 | 128; + } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) { + c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF); + ++i; + buffer[offset++] = c1 >> 18 | 240; + buffer[offset++] = c1 >> 12 & 63 | 128; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } else { + buffer[offset++] = c1 >> 12 | 224; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } + } + return offset - start; +}; + +},{}],11:[function(require,module,exports){ +"use strict"; +/** + * Runtime message from/to plain object converters. + * @namespace + */ +var converter = exports; + +var Enum = require(14), + util = require(33); + +/** + * Generates a partial value fromObject conveter. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} prop Property reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genValuePartial_fromObject(gen, field, fieldIndex, prop) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(d%s){", prop); + for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) { + if (field.repeated && values[keys[i]] === field.typeDefault) gen + ("default:"); + gen + ("case%j:", keys[i]) + ("case %i:", values[keys[i]]) + ("m%s=%j", prop, values[keys[i]]) + ("break"); + } gen + ("}"); + } else gen + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s=types[%i].fromObject(d%s)", prop, fieldIndex, prop); + } else { + var isUnsigned = false; + switch (field.type) { + case "double": + case "float": gen + ("m%s=Number(d%s)", prop, prop); // also catches "NaN", "Infinity" + break; + case "uint32": + case "fixed32": gen + ("m%s=d%s>>>0", prop, prop); + break; + case "int32": + case "sint32": + case "sfixed32": gen + ("m%s=d%s|0", prop, prop); + break; + case "uint64": + isUnsigned = true; + // eslint-disable-line no-fallthrough + case "int64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(util.Long)") + ("(m%s=util.Long.fromValue(d%s)).unsigned=%j", prop, prop, isUnsigned) + ("else if(typeof d%s===\"string\")", prop) + ("m%s=parseInt(d%s,10)", prop, prop) + ("else if(typeof d%s===\"number\")", prop) + ("m%s=d%s", prop, prop) + ("else if(typeof d%s===\"object\")", prop) + ("m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)", prop, prop, prop, isUnsigned ? "true" : ""); + break; + case "bytes": gen + ("if(typeof d%s===\"string\")", prop) + ("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)", prop, prop, prop) + ("else if(d%s.length)", prop) + ("m%s=d%s", prop, prop); + break; + case "string": gen + ("m%s=String(d%s)", prop, prop); + break; + case "bool": gen + ("m%s=Boolean(d%s)", prop, prop); + break; + /* default: gen + ("m%s=d%s", prop, prop); + break; */ + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a plain object to runtime message converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.fromObject = function fromObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray; + var gen = util.codegen(["d"], mtype.name + "$fromObject") + ("if(d instanceof this.ctor)") + ("return d"); + if (!fields.length) return gen + ("return new this.ctor"); + gen + ("var m=new this.ctor"); + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + prop = util.safeProp(field.name); + + // Map fields + if (field.map) { gen + ("if(d%s){", prop) + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s={}", prop) + ("for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s", prop, prop, prop, prop, isUnsigned ? "true": "", prop); + break; + case "bytes": gen + ("d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s", prop, prop, prop, prop, prop); + break; + default: gen + ("d%s=m%s", prop, prop); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a runtime message to plain object converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.toObject = function toObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById); + if (!fields.length) + return util.codegen()("return {}"); + var gen = util.codegen(["m", "o"], mtype.name + "$toObject") + ("if(!o)") + ("o={}") + ("var d={}"); + + var repeatedFields = [], + mapFields = [], + normalFields = [], + i = 0; + for (; i < fields.length; ++i) + if (!fields[i].partOf) + ( fields[i].resolve().repeated ? repeatedFields + : fields[i].map ? mapFields + : normalFields).push(fields[i]); + + if (repeatedFields.length) { gen + ("if(o.arrays||o.defaults){"); + for (i = 0; i < repeatedFields.length; ++i) gen + ("d%s=[]", util.safeProp(repeatedFields[i].name)); + gen + ("}"); + } + + if (mapFields.length) { gen + ("if(o.objects||o.defaults){"); + for (i = 0; i < mapFields.length; ++i) gen + ("d%s={}", util.safeProp(mapFields[i].name)); + gen + ("}"); + } + + if (normalFields.length) { gen + ("if(o.defaults){"); + for (i = 0; i < normalFields.length; ++i) { + var field = normalFields[i], + prop = util.safeProp(field.name); + if (field.resolvedType instanceof Enum) gen + ("d%s=o.enums===String?%j:%j", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault); + else if (field.long) gen + ("if(util.Long){") + ("var n=new util.Long(%i,%i,%j)", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned) + ("d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n", prop) + ("}else") + ("d%s=o.longs===String?%j:%i", prop, field.typeDefault.toString(), field.typeDefault.toNumber()); + else if (field.bytes) { + var arrayDefault = "[" + Array.prototype.slice.call(field.typeDefault).join(",") + "]"; + gen + ("if(o.bytes===String)d%s=%j", prop, String.fromCharCode.apply(String, field.typeDefault)) + ("else{") + ("d%s=%s", prop, arrayDefault) + ("if(o.bytes!==Array)d%s=util.newBuffer(d%s)", prop, prop) + ("}"); + } else gen + ("d%s=%j", prop, field.typeDefault); // also messages (=null) + } gen + ("}"); + } + var hasKs2 = false; + for (i = 0; i < fields.length; ++i) { + var field = fields[i], + index = mtype._fieldsArray.indexOf(field), + prop = util.safeProp(field.name); + if (field.map) { + if (!hasKs2) { hasKs2 = true; gen + ("var ks2"); + } gen + ("if(m%s&&(ks2=Object.keys(m%s)).length){", prop, prop) + ("d%s={}", prop) + ("for(var j=0;j>>3){"); + + var i = 0; + for (; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + ref = "m" + util.safeProp(field.name); gen + ("case %i:", field.id); + + // Map fields + if (field.map) { gen + ("r.skip().pos++") // assumes id 1 + key wireType + ("if(%s===util.emptyObject)", ref) + ("%s={}", ref) + ("k=r.%s()", field.keyType) + ("r.pos++"); // assumes id 2 + value wireType + if (types.long[field.keyType] !== undefined) { + if (types.basic[type] === undefined) gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=r.%s()", ref, type); + } else { + if (types.basic[type] === undefined) gen + ("%s[k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[k]=r.%s()", ref, type); + } + + // Repeated fields + } else if (field.repeated) { gen + + ("if(!(%s&&%s.length))", ref, ref) + ("%s=[]", ref); + + // Packable (always check for forward and backward compatiblity) + if (types.packed[type] !== undefined) gen + ("if((t&7)===2){") + ("var c2=r.uint32()+r.pos") + ("while(r.pos>> 0, (field.id << 3 | 4) >>> 0) + : gen("types[%i].encode(%s,w.uint32(%i).fork()).ldelim()", fieldIndex, ref, (field.id << 3 | 2) >>> 0); +} + +/** + * Generates an encoder specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function encoder(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var gen = util.codegen(["m", "w"], mtype.name + "$encode") + ("if(!w)") + ("w=Writer.create()"); + + var i, ref; + + // "when a message is serialized its known fields should be written sequentially by field number" + var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById); + + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + index = mtype._fieldsArray.indexOf(field), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + wireType = types.basic[type]; + ref = "m" + util.safeProp(field.name); + + // Map fields + if (field.map) { + gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name) // !== undefined && !== null + ("for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType); + if (wireType === undefined) gen + ("types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()", index, ref); // can't be groups + else gen + (".uint32(%i).%s(%s[ks[i]]).ldelim()", 16 | wireType, type, ref); + gen + ("}") + ("}"); + + // Repeated fields + } else if (field.repeated) { gen + ("if(%s!=null&&%s.length){", ref, ref); // !== undefined && !== null + + // Packed repeated + if (field.packed && types.packed[type] !== undefined) { gen + + ("w.uint32(%i).fork()", (field.id << 3 | 2) >>> 0) + ("for(var i=0;i<%s.length;++i)", ref) + ("w.%s(%s[i])", type, ref) + ("w.ldelim()"); + + // Non-packed + } else { gen + + ("for(var i=0;i<%s.length;++i)", ref); + if (wireType === undefined) + genTypePartial(gen, field, index, ref + "[i]"); + else gen + ("w.uint32(%i).%s(%s[i])", (field.id << 3 | wireType) >>> 0, type, ref); + + } gen + ("}"); + + // Non-repeated + } else { + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j))", ref, field.name); // !== undefined && !== null + + if (wireType === undefined) + genTypePartial(gen, field, index, ref); + else gen + ("w.uint32(%i).%s(%s)", (field.id << 3 | wireType) >>> 0, type, ref); + + } + } + + return gen + ("return w"); + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} +},{"14":14,"32":32,"33":33}],14:[function(require,module,exports){ +"use strict"; +module.exports = Enum; + +// extends ReflectionObject +var ReflectionObject = require(22); +((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = "Enum"; + +var Namespace = require(21), + util = require(33); + +/** + * Constructs a new enum instance. + * @classdesc Reflected enum. + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {Object.} [values] Enum values as an object, by name + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this enum + * @param {Object.} [comments] The value comments for this enum + */ +function Enum(name, values, options, comment, comments) { + ReflectionObject.call(this, name, options); + + if (values && typeof values !== "object") + throw TypeError("values must be an object"); + + /** + * Enum values by id. + * @type {Object.} + */ + this.valuesById = {}; + + /** + * Enum values by name. + * @type {Object.} + */ + this.values = Object.create(this.valuesById); // toJSON, marker + + /** + * Enum comment text. + * @type {string|null} + */ + this.comment = comment; + + /** + * Value comment texts, if any. + * @type {Object.} + */ + this.comments = comments || {}; + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + // Note that values inherit valuesById on their prototype which makes them a TypeScript- + // compatible enum. This is used by pbts to write actual enum definitions that work for + // static and reflection code alike instead of emitting generic object definitions. + + if (values) + for (var keys = Object.keys(values), i = 0; i < keys.length; ++i) + if (typeof values[keys[i]] === "number") // use forward entries only + this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i]; +} + +/** + * Enum descriptor. + * @interface IEnum + * @property {Object.} values Enum values + * @property {Object.} [options] Enum options + */ + +/** + * Constructs an enum from an enum descriptor. + * @param {string} name Enum name + * @param {IEnum} json Enum descriptor + * @returns {Enum} Created enum + * @throws {TypeError} If arguments are invalid + */ +Enum.fromJSON = function fromJSON(name, json) { + var enm = new Enum(name, json.values, json.options, json.comment, json.comments); + enm.reserved = json.reserved; + return enm; +}; + +/** + * Converts this enum to an enum descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IEnum} Enum descriptor + */ +Enum.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "values" , this.values, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "comment" , keepComments ? this.comment : undefined, + "comments" , keepComments ? this.comments : undefined + ]); +}; + +/** + * Adds a value to this enum. + * @param {string} name Value name + * @param {number} id Value id + * @param {string} [comment] Comment, if any + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a value with this name or id + */ +Enum.prototype.add = function add(name, id, comment) { + // utilized by the parser but not by .fromJSON + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (!util.isInteger(id)) + throw TypeError("id must be an integer"); + + if (this.values[name] !== undefined) + throw Error("duplicate name '" + name + "' in " + this); + + if (this.isReservedId(id)) + throw Error("id " + id + " is reserved in " + this); + + if (this.isReservedName(name)) + throw Error("name '" + name + "' is reserved in " + this); + + if (this.valuesById[id] !== undefined) { + if (!(this.options && this.options.allow_alias)) + throw Error("duplicate id " + id + " in " + this); + this.values[name] = id; + } else + this.valuesById[this.values[name] = id] = name; + + this.comments[name] = comment || null; + return this; +}; + +/** + * Removes a value from this enum + * @param {string} name Value name + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `name` is not a name of this enum + */ +Enum.prototype.remove = function remove(name) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + var val = this.values[name]; + if (val == null) + throw Error("name '" + name + "' does not exist in " + this); + + delete this.valuesById[val]; + delete this.values[name]; + delete this.comments[name]; + + return this; +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; + +},{"21":21,"22":22,"33":33}],15:[function(require,module,exports){ +"use strict"; +module.exports = Field; + +// extends ReflectionObject +var ReflectionObject = require(22); +((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = "Field"; + +var Enum = require(14), + types = require(32), + util = require(33); + +var Type; // cyclic + +var ruleRe = /^required|optional|repeated$/; + +/** + * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class. + * @name Field + * @classdesc Reflected message field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a field from a field descriptor. + * @param {string} name Field name + * @param {IField} json Field descriptor + * @returns {Field} Created field + * @throws {TypeError} If arguments are invalid + */ +Field.fromJSON = function fromJSON(name, json) { + return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment); +}; + +/** + * Not an actual constructor. Use {@link Field} instead. + * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions. + * @exports FieldBase + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function Field(name, id, type, rule, extend, options, comment) { + + if (util.isObject(rule)) { + comment = extend; + options = rule; + rule = extend = undefined; + } else if (util.isObject(extend)) { + comment = options; + options = extend; + extend = undefined; + } + + ReflectionObject.call(this, name, options); + + if (!util.isInteger(id) || id < 0) + throw TypeError("id must be a non-negative integer"); + + if (!util.isString(type)) + throw TypeError("type must be a string"); + + if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase())) + throw TypeError("rule must be a string rule"); + + if (extend !== undefined && !util.isString(extend)) + throw TypeError("extend must be a string"); + + /** + * Field rule, if any. + * @type {string|undefined} + */ + this.rule = rule && rule !== "optional" ? rule : undefined; // toJSON + + /** + * Field type. + * @type {string} + */ + this.type = type; // toJSON + + /** + * Unique field id. + * @type {number} + */ + this.id = id; // toJSON, marker + + /** + * Extended type if different from parent. + * @type {string|undefined} + */ + this.extend = extend || undefined; // toJSON + + /** + * Whether this field is required. + * @type {boolean} + */ + this.required = rule === "required"; + + /** + * Whether this field is optional. + * @type {boolean} + */ + this.optional = !this.required; + + /** + * Whether this field is repeated. + * @type {boolean} + */ + this.repeated = rule === "repeated"; + + /** + * Whether this field is a map or not. + * @type {boolean} + */ + this.map = false; + + /** + * Message this field belongs to. + * @type {Type|null} + */ + this.message = null; + + /** + * OneOf this field belongs to, if any, + * @type {OneOf|null} + */ + this.partOf = null; + + /** + * The field type's default value. + * @type {*} + */ + this.typeDefault = null; + + /** + * The field's default value on prototypes. + * @type {*} + */ + this.defaultValue = null; + + /** + * Whether this field's value should be treated as a long. + * @type {boolean} + */ + this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false; + + /** + * Whether this field's value is a buffer. + * @type {boolean} + */ + this.bytes = type === "bytes"; + + /** + * Resolved type if not a basic type. + * @type {Type|Enum|null} + */ + this.resolvedType = null; + + /** + * Sister-field within the extended type if a declaring extension field. + * @type {Field|null} + */ + this.extensionField = null; + + /** + * Sister-field within the declaring namespace if an extended field. + * @type {Field|null} + */ + this.declaringField = null; + + /** + * Internally remembers whether this field is packed. + * @type {boolean|null} + * @private + */ + this._packed = null; + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Determines whether this field is packed. Only relevant when repeated and working with proto2. + * @name Field#packed + * @type {boolean} + * @readonly + */ +Object.defineProperty(Field.prototype, "packed", { + get: function() { + // defaults to packed=true if not explicity set to false + if (this._packed === null) + this._packed = this.getOption("packed") !== false; + return this._packed; + } +}); + +/** + * @override + */ +Field.prototype.setOption = function setOption(name, value, ifNotSet) { + if (name === "packed") // clear cached before setting + this._packed = null; + return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet); +}; + +/** + * Field descriptor. + * @interface IField + * @property {string} [rule="optional"] Field rule + * @property {string} type Field type + * @property {number} id Field id + * @property {Object.} [options] Field options + */ + +/** + * Extension field descriptor. + * @interface IExtensionField + * @extends IField + * @property {string} extend Extended type + */ + +/** + * Converts this field to a field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IField} Field descriptor + */ +Field.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "rule" , this.rule !== "optional" && this.rule || undefined, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Resolves this field's type references. + * @returns {Field} `this` + * @throws {Error} If any reference cannot be resolved + */ +Field.prototype.resolve = function resolve() { + + if (this.resolved) + return this; + + if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it + this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type); + if (this.resolvedType instanceof Type) + this.typeDefault = null; + else // instanceof Enum + this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined + } + + // use explicitly set default value if present + if (this.options && this.options["default"] != null) { + this.typeDefault = this.options["default"]; + if (this.resolvedType instanceof Enum && typeof this.typeDefault === "string") + this.typeDefault = this.resolvedType.values[this.typeDefault]; + } + + // remove unnecessary options + if (this.options) { + if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum)) + delete this.options.packed; + if (!Object.keys(this.options).length) + this.options = undefined; + } + + // convert to internal data type if necesssary + if (this.long) { + this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === "u"); + + /* istanbul ignore else */ + if (Object.freeze) + Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it) + + } else if (this.bytes && typeof this.typeDefault === "string") { + var buf; + if (util.base64.test(this.typeDefault)) + util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0); + else + util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0); + this.typeDefault = buf; + } + + // take special care of maps and repeated fields + if (this.map) + this.defaultValue = util.emptyObject; + else if (this.repeated) + this.defaultValue = util.emptyArray; + else + this.defaultValue = this.typeDefault; + + // ensure proper value on prototype + if (this.parent instanceof Type) + this.parent.ctor.prototype[this.name] = this.defaultValue; + + return ReflectionObject.prototype.resolve.call(this); +}; + +/** + * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript). + * @typedef FieldDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} fieldName Field name + * @returns {undefined} + */ + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|Object} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @param {T} [defaultValue] Default value + * @returns {FieldDecorator} Decorator function + * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[] + */ +Field.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) { + + // submessage: decorate the submessage and use its name as the type + if (typeof fieldType === "function") + fieldType = util.decorateType(fieldType).name; + + // enum reference: create a reflected copy of the enum and keep reuseing it + else if (fieldType && typeof fieldType === "object") + fieldType = util.decorateEnum(fieldType).name; + + return function fieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new Field(fieldName, fieldId, fieldType, fieldRule, { "default": defaultValue })); + }; +}; + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {Constructor|string} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @returns {FieldDecorator} Decorator function + * @template T extends Message + * @variation 2 + */ +// like Field.d but without a default value + +// Sets up cyclic dependencies (called in index-light) +Field._configure = function configure(Type_) { + Type = Type_; +}; + +},{"14":14,"22":22,"32":32,"33":33}],16:[function(require,module,exports){ +"use strict"; +var protobuf = module.exports = require(17); + +protobuf.build = "light"; + +/** + * A node-style callback as used by {@link load} and {@link Root#load}. + * @typedef LoadCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Root} [root] Root, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @param {string|string[]} filename One or multiple files to load + * @param {Root} root Root namespace, defaults to create a new one if omitted. + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + */ +function load(filename, root, callback) { + if (typeof root === "function") { + callback = root; + root = new protobuf.Root(); + } else if (!root) + root = new protobuf.Root(); + return root.load(filename, callback); +} + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Promise} Promise + * @see {@link Root#load} + * @variation 3 + */ +// function load(filename:string, [root:Root]):Promise + +protobuf.load = load; + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only). + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + * @see {@link Root#loadSync} + */ +function loadSync(filename, root) { + if (!root) + root = new protobuf.Root(); + return root.loadSync(filename); +} + +protobuf.loadSync = loadSync; + +// Serialization +protobuf.encoder = require(13); +protobuf.decoder = require(12); +protobuf.verifier = require(36); +protobuf.converter = require(11); + +// Reflection +protobuf.ReflectionObject = require(22); +protobuf.Namespace = require(21); +protobuf.Root = require(26); +protobuf.Enum = require(14); +protobuf.Type = require(31); +protobuf.Field = require(15); +protobuf.OneOf = require(23); +protobuf.MapField = require(18); +protobuf.Service = require(30); +protobuf.Method = require(20); + +// Runtime +protobuf.Message = require(19); +protobuf.wrappers = require(37); + +// Utility +protobuf.types = require(32); +protobuf.util = require(33); + +// Set up possibly cyclic reflection dependencies +protobuf.ReflectionObject._configure(protobuf.Root); +protobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum); +protobuf.Root._configure(protobuf.Type); +protobuf.Field._configure(protobuf.Type); + +},{"11":11,"12":12,"13":13,"14":14,"15":15,"17":17,"18":18,"19":19,"20":20,"21":21,"22":22,"23":23,"26":26,"30":30,"31":31,"32":32,"33":33,"36":36,"37":37}],17:[function(require,module,exports){ +"use strict"; +var protobuf = exports; + +/** + * Build type, one of `"full"`, `"light"` or `"minimal"`. + * @name build + * @type {string} + * @const + */ +protobuf.build = "minimal"; + +// Serialization +protobuf.Writer = require(38); +protobuf.BufferWriter = require(39); +protobuf.Reader = require(24); +protobuf.BufferReader = require(25); + +// Utility +protobuf.util = require(35); +protobuf.rpc = require(28); +protobuf.roots = require(27); +protobuf.configure = configure; + +/* istanbul ignore next */ +/** + * Reconfigures the library according to the environment. + * @returns {undefined} + */ +function configure() { + protobuf.Reader._configure(protobuf.BufferReader); + protobuf.util._configure(); +} + +// Set up buffer utility according to the environment +protobuf.Writer._configure(protobuf.BufferWriter); +configure(); + +},{"24":24,"25":25,"27":27,"28":28,"35":35,"38":38,"39":39}],18:[function(require,module,exports){ +"use strict"; +module.exports = MapField; + +// extends Field +var Field = require(15); +((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = "MapField"; + +var types = require(32), + util = require(33); + +/** + * Constructs a new map field instance. + * @classdesc Reflected map field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} keyType Key type + * @param {string} type Value type + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function MapField(name, id, keyType, type, options, comment) { + Field.call(this, name, id, type, undefined, undefined, options, comment); + + /* istanbul ignore if */ + if (!util.isString(keyType)) + throw TypeError("keyType must be a string"); + + /** + * Key type. + * @type {string} + */ + this.keyType = keyType; // toJSON, marker + + /** + * Resolved key type if not a basic type. + * @type {ReflectionObject|null} + */ + this.resolvedKeyType = null; + + // Overrides Field#map + this.map = true; +} + +/** + * Map field descriptor. + * @interface IMapField + * @extends {IField} + * @property {string} keyType Key type + */ + +/** + * Extension map field descriptor. + * @interface IExtensionMapField + * @extends IMapField + * @property {string} extend Extended type + */ + +/** + * Constructs a map field from a map field descriptor. + * @param {string} name Field name + * @param {IMapField} json Map field descriptor + * @returns {MapField} Created map field + * @throws {TypeError} If arguments are invalid + */ +MapField.fromJSON = function fromJSON(name, json) { + return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment); +}; + +/** + * Converts this map field to a map field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMapField} Map field descriptor + */ +MapField.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "keyType" , this.keyType, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +MapField.prototype.resolve = function resolve() { + if (this.resolved) + return this; + + // Besides a value type, map fields have a key type that may be "any scalar type except for floating point types and bytes" + if (types.mapKey[this.keyType] === undefined) + throw Error("invalid key type: " + this.keyType); + + return Field.prototype.resolve.call(this); +}; + +/** + * Map field decorator (TypeScript). + * @name MapField.d + * @function + * @param {number} fieldId Field id + * @param {"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"} fieldKeyType Field key type + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"|"bytes"|Object|Constructor<{}>} fieldValueType Field value type + * @returns {FieldDecorator} Decorator function + * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> } + */ +MapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) { + + // submessage value: decorate the submessage and use its name as the type + if (typeof fieldValueType === "function") + fieldValueType = util.decorateType(fieldValueType).name; + + // enum reference value: create a reflected copy of the enum and keep reuseing it + else if (fieldValueType && typeof fieldValueType === "object") + fieldValueType = util.decorateEnum(fieldValueType).name; + + return function mapFieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType)); + }; +}; + +},{"15":15,"32":32,"33":33}],19:[function(require,module,exports){ +"use strict"; +module.exports = Message; + +var util = require(35); + +/** + * Constructs a new message instance. + * @classdesc Abstract runtime message. + * @constructor + * @param {Properties} [properties] Properties to set + * @template T extends object = object + */ +function Message(properties) { + // not used internally + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + this[keys[i]] = properties[keys[i]]; +} + +/** + * Reference to the reflected type. + * @name Message.$type + * @type {Type} + * @readonly + */ + +/** + * Reference to the reflected type. + * @name Message#$type + * @type {Type} + * @readonly + */ + +/*eslint-disable valid-jsdoc*/ + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message} Message instance + * @template T extends Message + * @this Constructor + */ +Message.create = function create(properties) { + return this.$type.create(properties); +}; + +/** + * Encodes a message of this type. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encode = function encode(message, writer) { + return this.$type.encode(message, writer); +}; + +/** + * Encodes a message of this type preceeded by its length as a varint. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encodeDelimited = function encodeDelimited(message, writer) { + return this.$type.encodeDelimited(message, writer); +}; + +/** + * Decodes a message of this type. + * @name Message.decode + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decode = function decode(reader) { + return this.$type.decode(reader); +}; + +/** + * Decodes a message of this type preceeded by its length as a varint. + * @name Message.decodeDelimited + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decodeDelimited = function decodeDelimited(reader) { + return this.$type.decodeDelimited(reader); +}; + +/** + * Verifies a message of this type. + * @name Message.verify + * @function + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ +Message.verify = function verify(message) { + return this.$type.verify(message); +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object + * @returns {T} Message instance + * @template T extends Message + * @this Constructor + */ +Message.fromObject = function fromObject(object) { + return this.$type.fromObject(object); +}; + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {T} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @template T extends Message + * @this Constructor + */ +Message.toObject = function toObject(message, options) { + return this.$type.toObject(message, options); +}; + +/** + * Converts this message to JSON. + * @returns {Object.} JSON object + */ +Message.prototype.toJSON = function toJSON() { + return this.$type.toObject(this, util.toJSONOptions); +}; + +/*eslint-enable valid-jsdoc*/ +},{"35":35}],20:[function(require,module,exports){ +"use strict"; +module.exports = Method; + +// extends ReflectionObject +var ReflectionObject = require(22); +((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = "Method"; + +var util = require(33); + +/** + * Constructs a new service method instance. + * @classdesc Reflected service method. + * @extends ReflectionObject + * @constructor + * @param {string} name Method name + * @param {string|undefined} type Method type, usually `"rpc"` + * @param {string} requestType Request message type + * @param {string} responseType Response message type + * @param {boolean|Object.} [requestStream] Whether the request is streamed + * @param {boolean|Object.} [responseStream] Whether the response is streamed + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this method + */ +function Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) { + + /* istanbul ignore next */ + if (util.isObject(requestStream)) { + options = requestStream; + requestStream = responseStream = undefined; + } else if (util.isObject(responseStream)) { + options = responseStream; + responseStream = undefined; + } + + /* istanbul ignore if */ + if (!(type === undefined || util.isString(type))) + throw TypeError("type must be a string"); + + /* istanbul ignore if */ + if (!util.isString(requestType)) + throw TypeError("requestType must be a string"); + + /* istanbul ignore if */ + if (!util.isString(responseType)) + throw TypeError("responseType must be a string"); + + ReflectionObject.call(this, name, options); + + /** + * Method type. + * @type {string} + */ + this.type = type || "rpc"; // toJSON + + /** + * Request type. + * @type {string} + */ + this.requestType = requestType; // toJSON, marker + + /** + * Whether requests are streamed or not. + * @type {boolean|undefined} + */ + this.requestStream = requestStream ? true : undefined; // toJSON + + /** + * Response type. + * @type {string} + */ + this.responseType = responseType; // toJSON + + /** + * Whether responses are streamed or not. + * @type {boolean|undefined} + */ + this.responseStream = responseStream ? true : undefined; // toJSON + + /** + * Resolved request type. + * @type {Type|null} + */ + this.resolvedRequestType = null; + + /** + * Resolved response type. + * @type {Type|null} + */ + this.resolvedResponseType = null; + + /** + * Comment for this method + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Method descriptor. + * @interface IMethod + * @property {string} [type="rpc"] Method type + * @property {string} requestType Request type + * @property {string} responseType Response type + * @property {boolean} [requestStream=false] Whether requests are streamed + * @property {boolean} [responseStream=false] Whether responses are streamed + * @property {Object.} [options] Method options + */ + +/** + * Constructs a method from a method descriptor. + * @param {string} name Method name + * @param {IMethod} json Method descriptor + * @returns {Method} Created method + * @throws {TypeError} If arguments are invalid + */ +Method.fromJSON = function fromJSON(name, json) { + return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment); +}; + +/** + * Converts this method to a method descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMethod} Method descriptor + */ +Method.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "type" , this.type !== "rpc" && /* istanbul ignore next */ this.type || undefined, + "requestType" , this.requestType, + "requestStream" , this.requestStream, + "responseType" , this.responseType, + "responseStream" , this.responseStream, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Method.prototype.resolve = function resolve() { + + /* istanbul ignore if */ + if (this.resolved) + return this; + + this.resolvedRequestType = this.parent.lookupType(this.requestType); + this.resolvedResponseType = this.parent.lookupType(this.responseType); + + return ReflectionObject.prototype.resolve.call(this); +}; + +},{"22":22,"33":33}],21:[function(require,module,exports){ +"use strict"; +module.exports = Namespace; + +// extends ReflectionObject +var ReflectionObject = require(22); +((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = "Namespace"; + +var Field = require(15), + util = require(33); + +var Type, // cyclic + Service, + Enum; + +/** + * Constructs a new namespace instance. + * @name Namespace + * @classdesc Reflected namespace. + * @extends NamespaceBase + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a namespace from JSON. + * @memberof Namespace + * @function + * @param {string} name Namespace name + * @param {Object.} json JSON object + * @returns {Namespace} Created namespace + * @throws {TypeError} If arguments are invalid + */ +Namespace.fromJSON = function fromJSON(name, json) { + return new Namespace(name, json.options).addJSON(json.nested); +}; + +/** + * Converts an array of reflection objects to JSON. + * @memberof Namespace + * @param {ReflectionObject[]} array Object array + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {Object.|undefined} JSON object or `undefined` when array is empty + */ +function arrayToJSON(array, toJSONOptions) { + if (!(array && array.length)) + return undefined; + var obj = {}; + for (var i = 0; i < array.length; ++i) + obj[array[i].name] = array[i].toJSON(toJSONOptions); + return obj; +} + +Namespace.arrayToJSON = arrayToJSON; + +/** + * Tests if the specified id is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedId = function isReservedId(reserved, id) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (typeof reserved[i] !== "string" && reserved[i][0] <= id && reserved[i][1] >= id) + return true; + return false; +}; + +/** + * Tests if the specified name is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedName = function isReservedName(reserved, name) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (reserved[i] === name) + return true; + return false; +}; + +/** + * Not an actual constructor. Use {@link Namespace} instead. + * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions. + * @exports NamespaceBase + * @extends ReflectionObject + * @abstract + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + * @see {@link Namespace} + */ +function Namespace(name, options) { + ReflectionObject.call(this, name, options); + + /** + * Nested objects by name. + * @type {Object.|undefined} + */ + this.nested = undefined; // toJSON + + /** + * Cached nested objects as an array. + * @type {ReflectionObject[]|null} + * @private + */ + this._nestedArray = null; +} + +function clearCache(namespace) { + namespace._nestedArray = null; + return namespace; +} + +/** + * Nested objects of this namespace as an array for iteration. + * @name NamespaceBase#nestedArray + * @type {ReflectionObject[]} + * @readonly + */ +Object.defineProperty(Namespace.prototype, "nestedArray", { + get: function() { + return this._nestedArray || (this._nestedArray = util.toArray(this.nested)); + } +}); + +/** + * Namespace descriptor. + * @interface INamespace + * @property {Object.} [options] Namespace options + * @property {Object.} [nested] Nested object descriptors + */ + +/** + * Any extension field descriptor. + * @typedef AnyExtensionField + * @type {IExtensionField|IExtensionMapField} + */ + +/** + * Any nested object descriptor. + * @typedef AnyNestedObject + * @type {IEnum|IType|IService|AnyExtensionField|INamespace} + */ +// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place) + +/** + * Converts this namespace to a namespace descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {INamespace} Namespace descriptor + */ +Namespace.prototype.toJSON = function toJSON(toJSONOptions) { + return util.toObject([ + "options" , this.options, + "nested" , arrayToJSON(this.nestedArray, toJSONOptions) + ]); +}; + +/** + * Adds nested objects to this namespace from nested object descriptors. + * @param {Object.} nestedJson Any nested object descriptors + * @returns {Namespace} `this` + */ +Namespace.prototype.addJSON = function addJSON(nestedJson) { + var ns = this; + /* istanbul ignore else */ + if (nestedJson) { + for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) { + nested = nestedJson[names[i]]; + ns.add( // most to least likely + ( nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : nested.id !== undefined + ? Field.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + } + return this; +}; + +/** + * Gets the nested object of the specified name. + * @param {string} name Nested object name + * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist + */ +Namespace.prototype.get = function get(name) { + return this.nested && this.nested[name] + || null; +}; + +/** + * Gets the values of the nested {@link Enum|enum} of the specified name. + * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`. + * @param {string} name Nested enum name + * @returns {Object.} Enum values + * @throws {Error} If there is no such enum + */ +Namespace.prototype.getEnum = function getEnum(name) { + if (this.nested && this.nested[name] instanceof Enum) + return this.nested[name].values; + throw Error("no such enum: " + name); +}; + +/** + * Adds a nested object to this namespace. + * @param {ReflectionObject} object Nested object to add + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name + */ +Namespace.prototype.add = function add(object) { + + if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace)) + throw TypeError("object must be a valid nested object"); + + if (!this.nested) + this.nested = {}; + else { + var prev = this.get(object.name); + if (prev) { + if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) { + // replace plain namespace but keep existing nested elements and options + var nested = prev.nestedArray; + for (var i = 0; i < nested.length; ++i) + object.add(nested[i]); + this.remove(prev); + if (!this.nested) + this.nested = {}; + object.setOptions(prev.options, true); + + } else + throw Error("duplicate name '" + object.name + "' in " + this); + } + } + this.nested[object.name] = object; + object.onAdd(this); + return clearCache(this); +}; + +/** + * Removes a nested object from this namespace. + * @param {ReflectionObject} object Nested object to remove + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this namespace + */ +Namespace.prototype.remove = function remove(object) { + + if (!(object instanceof ReflectionObject)) + throw TypeError("object must be a ReflectionObject"); + if (object.parent !== this) + throw Error(object + " is not a member of " + this); + + delete this.nested[object.name]; + if (!Object.keys(this.nested).length) + this.nested = undefined; + + object.onRemove(this); + return clearCache(this); +}; + +/** + * Defines additial namespaces within this one if not yet existing. + * @param {string|string[]} path Path to create + * @param {*} [json] Nested types to create from JSON + * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty + */ +Namespace.prototype.define = function define(path, json) { + + if (util.isString(path)) + path = path.split("."); + else if (!Array.isArray(path)) + throw TypeError("illegal path"); + if (path && path.length && path[0] === "") + throw Error("path must be relative"); + + var ptr = this; + while (path.length > 0) { + var part = path.shift(); + if (ptr.nested && ptr.nested[part]) { + ptr = ptr.nested[part]; + if (!(ptr instanceof Namespace)) + throw Error("path conflicts with non-namespace objects"); + } else + ptr.add(ptr = new Namespace(part)); + } + if (json) + ptr.addJSON(json); + return ptr; +}; + +/** + * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost. + * @returns {Namespace} `this` + */ +Namespace.prototype.resolveAll = function resolveAll() { + var nested = this.nestedArray, i = 0; + while (i < nested.length) + if (nested[i] instanceof Namespace) + nested[i++].resolveAll(); + else + nested[i++].resolve(); + return this.resolve(); +}; + +/** + * Recursively looks up the reflection object matching the specified path in the scope of this namespace. + * @param {string|string[]} path Path to look up + * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc. + * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + */ +Namespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) { + + /* istanbul ignore next */ + if (typeof filterTypes === "boolean") { + parentAlreadyChecked = filterTypes; + filterTypes = undefined; + } else if (filterTypes && !Array.isArray(filterTypes)) + filterTypes = [ filterTypes ]; + + if (util.isString(path) && path.length) { + if (path === ".") + return this.root; + path = path.split("."); + } else if (!path.length) + return this; + + // Start at root if path is absolute + if (path[0] === "") + return this.root.lookup(path.slice(1), filterTypes); + + // Test if the first part matches any nested object, and if so, traverse if path contains more + var found = this.get(path[0]); + if (found) { + if (path.length === 1) { + if (!filterTypes || filterTypes.indexOf(found.constructor) > -1) + return found; + } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true))) + return found; + + // Otherwise try each nested namespace + } else + for (var i = 0; i < this.nestedArray.length; ++i) + if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true))) + return found; + + // If there hasn't been a match, try again at the parent + if (this.parent === null || parentAlreadyChecked) + return null; + return this.parent.lookup(path, filterTypes); +}; + +/** + * Looks up the reflection object at the specified path, relative to this namespace. + * @name NamespaceBase#lookup + * @function + * @param {string|string[]} path Path to look up + * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + * @variation 2 + */ +// lookup(path: string, [parentAlreadyChecked: boolean]) + +/** + * Looks up the {@link Type|type} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type + * @throws {Error} If `path` does not point to a type + */ +Namespace.prototype.lookupType = function lookupType(path) { + var found = this.lookup(path, [ Type ]); + if (!found) + throw Error("no such type: " + path); + return found; +}; + +/** + * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Enum} Looked up enum + * @throws {Error} If `path` does not point to an enum + */ +Namespace.prototype.lookupEnum = function lookupEnum(path) { + var found = this.lookup(path, [ Enum ]); + if (!found) + throw Error("no such Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type or enum + * @throws {Error} If `path` does not point to a type or enum + */ +Namespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) { + var found = this.lookup(path, [ Type, Enum ]); + if (!found) + throw Error("no such Type or Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Service|service} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Service} Looked up service + * @throws {Error} If `path` does not point to a service + */ +Namespace.prototype.lookupService = function lookupService(path) { + var found = this.lookup(path, [ Service ]); + if (!found) + throw Error("no such Service '" + path + "' in " + this); + return found; +}; + +// Sets up cyclic dependencies (called in index-light) +Namespace._configure = function(Type_, Service_, Enum_) { + Type = Type_; + Service = Service_; + Enum = Enum_; +}; + +},{"15":15,"22":22,"33":33}],22:[function(require,module,exports){ +"use strict"; +module.exports = ReflectionObject; + +ReflectionObject.className = "ReflectionObject"; + +var util = require(33); + +var Root; // cyclic + +/** + * Constructs a new reflection object instance. + * @classdesc Base class of all reflection objects. + * @constructor + * @param {string} name Object name + * @param {Object.} [options] Declared options + * @abstract + */ +function ReflectionObject(name, options) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (options && !util.isObject(options)) + throw TypeError("options must be an object"); + + /** + * Options. + * @type {Object.|undefined} + */ + this.options = options; // toJSON + + /** + * Unique name within its namespace. + * @type {string} + */ + this.name = name; + + /** + * Parent namespace. + * @type {Namespace|null} + */ + this.parent = null; + + /** + * Whether already resolved or not. + * @type {boolean} + */ + this.resolved = false; + + /** + * Comment text, if any. + * @type {string|null} + */ + this.comment = null; + + /** + * Defining file name. + * @type {string|null} + */ + this.filename = null; +} + +Object.defineProperties(ReflectionObject.prototype, { + + /** + * Reference to the root namespace. + * @name ReflectionObject#root + * @type {Root} + * @readonly + */ + root: { + get: function() { + var ptr = this; + while (ptr.parent !== null) + ptr = ptr.parent; + return ptr; + } + }, + + /** + * Full name including leading dot. + * @name ReflectionObject#fullName + * @type {string} + * @readonly + */ + fullName: { + get: function() { + var path = [ this.name ], + ptr = this.parent; + while (ptr) { + path.unshift(ptr.name); + ptr = ptr.parent; + } + return path.join("."); + } + } +}); + +/** + * Converts this reflection object to its descriptor representation. + * @returns {Object.} Descriptor + * @abstract + */ +ReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() { + throw Error(); // not implemented, shouldn't happen +}; + +/** + * Called when this object is added to a parent. + * @param {ReflectionObject} parent Parent added to + * @returns {undefined} + */ +ReflectionObject.prototype.onAdd = function onAdd(parent) { + if (this.parent && this.parent !== parent) + this.parent.remove(this); + this.parent = parent; + this.resolved = false; + var root = parent.root; + if (root instanceof Root) + root._handleAdd(this); +}; + +/** + * Called when this object is removed from a parent. + * @param {ReflectionObject} parent Parent removed from + * @returns {undefined} + */ +ReflectionObject.prototype.onRemove = function onRemove(parent) { + var root = parent.root; + if (root instanceof Root) + root._handleRemove(this); + this.parent = null; + this.resolved = false; +}; + +/** + * Resolves this objects type references. + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.resolve = function resolve() { + if (this.resolved) + return this; + if (this.root instanceof Root) + this.resolved = true; // only if part of a root + return this; +}; + +/** + * Gets an option value. + * @param {string} name Option name + * @returns {*} Option value or `undefined` if not set + */ +ReflectionObject.prototype.getOption = function getOption(name) { + if (this.options) + return this.options[name]; + return undefined; +}; + +/** + * Sets an option. + * @param {string} name Option name + * @param {*} value Option value + * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) { + if (!ifNotSet || !this.options || this.options[name] === undefined) + (this.options || (this.options = {}))[name] = value; + return this; +}; + +/** + * Sets multiple options. + * @param {Object.} options Options to set + * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) { + if (options) + for (var keys = Object.keys(options), i = 0; i < keys.length; ++i) + this.setOption(keys[i], options[keys[i]], ifNotSet); + return this; +}; + +/** + * Converts this instance to its string representation. + * @returns {string} Class name[, space, full name] + */ +ReflectionObject.prototype.toString = function toString() { + var className = this.constructor.className, + fullName = this.fullName; + if (fullName.length) + return className + " " + fullName; + return className; +}; + +// Sets up cyclic dependencies (called in index-light) +ReflectionObject._configure = function(Root_) { + Root = Root_; +}; + +},{"33":33}],23:[function(require,module,exports){ +"use strict"; +module.exports = OneOf; + +// extends ReflectionObject +var ReflectionObject = require(22); +((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = "OneOf"; + +var Field = require(15), + util = require(33); + +/** + * Constructs a new oneof instance. + * @classdesc Reflected oneof. + * @extends ReflectionObject + * @constructor + * @param {string} name Oneof name + * @param {string[]|Object.} [fieldNames] Field names + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function OneOf(name, fieldNames, options, comment) { + if (!Array.isArray(fieldNames)) { + options = fieldNames; + fieldNames = undefined; + } + ReflectionObject.call(this, name, options); + + /* istanbul ignore if */ + if (!(fieldNames === undefined || Array.isArray(fieldNames))) + throw TypeError("fieldNames must be an Array"); + + /** + * Field names that belong to this oneof. + * @type {string[]} + */ + this.oneof = fieldNames || []; // toJSON, marker + + /** + * Fields that belong to this oneof as an array for iteration. + * @type {Field[]} + * @readonly + */ + this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Oneof descriptor. + * @interface IOneOf + * @property {Array.} oneof Oneof field names + * @property {Object.} [options] Oneof options + */ + +/** + * Constructs a oneof from a oneof descriptor. + * @param {string} name Oneof name + * @param {IOneOf} json Oneof descriptor + * @returns {OneOf} Created oneof + * @throws {TypeError} If arguments are invalid + */ +OneOf.fromJSON = function fromJSON(name, json) { + return new OneOf(name, json.oneof, json.options, json.comment); +}; + +/** + * Converts this oneof to a oneof descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IOneOf} Oneof descriptor + */ +OneOf.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "oneof" , this.oneof, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Adds the fields of the specified oneof to the parent if not already done so. + * @param {OneOf} oneof The oneof + * @returns {undefined} + * @inner + * @ignore + */ +function addFieldsToParent(oneof) { + if (oneof.parent) + for (var i = 0; i < oneof.fieldsArray.length; ++i) + if (!oneof.fieldsArray[i].parent) + oneof.parent.add(oneof.fieldsArray[i]); +} + +/** + * Adds a field to this oneof and removes it from its current parent, if any. + * @param {Field} field Field to add + * @returns {OneOf} `this` + */ +OneOf.prototype.add = function add(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + if (field.parent && field.parent !== this.parent) + field.parent.remove(field); + this.oneof.push(field.name); + this.fieldsArray.push(field); + field.partOf = this; // field.parent remains null + addFieldsToParent(this); + return this; +}; + +/** + * Removes a field from this oneof and puts it back to the oneof's parent. + * @param {Field} field Field to remove + * @returns {OneOf} `this` + */ +OneOf.prototype.remove = function remove(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + var index = this.fieldsArray.indexOf(field); + + /* istanbul ignore if */ + if (index < 0) + throw Error(field + " is not a member of " + this); + + this.fieldsArray.splice(index, 1); + index = this.oneof.indexOf(field.name); + + /* istanbul ignore else */ + if (index > -1) // theoretical + this.oneof.splice(index, 1); + + field.partOf = null; + return this; +}; + +/** + * @override + */ +OneOf.prototype.onAdd = function onAdd(parent) { + ReflectionObject.prototype.onAdd.call(this, parent); + var self = this; + // Collect present fields + for (var i = 0; i < this.oneof.length; ++i) { + var field = parent.get(this.oneof[i]); + if (field && !field.partOf) { + field.partOf = self; + self.fieldsArray.push(field); + } + } + // Add not yet present fields + addFieldsToParent(this); +}; + +/** + * @override + */ +OneOf.prototype.onRemove = function onRemove(parent) { + for (var i = 0, field; i < this.fieldsArray.length; ++i) + if ((field = this.fieldsArray[i]).parent) + field.parent.remove(field); + ReflectionObject.prototype.onRemove.call(this, parent); +}; + +/** + * Decorator function as returned by {@link OneOf.d} (TypeScript). + * @typedef OneOfDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} oneofName OneOf name + * @returns {undefined} + */ + +/** + * OneOf decorator (TypeScript). + * @function + * @param {...string} fieldNames Field names + * @returns {OneOfDecorator} Decorator function + * @template T extends string + */ +OneOf.d = function decorateOneOf() { + var fieldNames = new Array(arguments.length), + index = 0; + while (index < arguments.length) + fieldNames[index] = arguments[index++]; + return function oneOfDecorator(prototype, oneofName) { + util.decorateType(prototype.constructor) + .add(new OneOf(oneofName, fieldNames)); + Object.defineProperty(prototype, oneofName, { + get: util.oneOfGetter(fieldNames), + set: util.oneOfSetter(fieldNames) + }); + }; +}; + +},{"15":15,"22":22,"33":33}],24:[function(require,module,exports){ +"use strict"; +module.exports = Reader; + +var util = require(35); + +var BufferReader; // cyclic + +var LongBits = util.LongBits, + utf8 = util.utf8; + +/* istanbul ignore next */ +function indexOutOfRange(reader, writeLength) { + return RangeError("index out of range: " + reader.pos + " + " + (writeLength || 1) + " > " + reader.len); +} + +/** + * Constructs a new reader instance using the specified buffer. + * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`. + * @constructor + * @param {Uint8Array} buffer Buffer to read from + */ +function Reader(buffer) { + + /** + * Read buffer. + * @type {Uint8Array} + */ + this.buf = buffer; + + /** + * Read buffer position. + * @type {number} + */ + this.pos = 0; + + /** + * Read buffer length. + * @type {number} + */ + this.len = buffer.length; +} + +var create_array = typeof Uint8Array !== "undefined" + ? function create_typed_array(buffer) { + if (buffer instanceof Uint8Array || Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + } + /* istanbul ignore next */ + : function create_array(buffer) { + if (Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + }; + +/** + * Creates a new reader using the specified buffer. + * @function + * @param {Uint8Array|Buffer} buffer Buffer to read from + * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ +Reader.create = util.Buffer + ? function create_buffer_setup(buffer) { + return (Reader.create = function create_buffer(buffer) { + return util.Buffer.isBuffer(buffer) + ? new BufferReader(buffer) + /* istanbul ignore next */ + : create_array(buffer); + })(buffer); + } + /* istanbul ignore next */ + : create_array; + +Reader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice; + +/** + * Reads a varint as an unsigned 32 bit value. + * @function + * @returns {number} Value read + */ +Reader.prototype.uint32 = (function read_uint32_setup() { + var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!) + return function read_uint32() { + value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value; + + /* istanbul ignore if */ + if ((this.pos += 5) > this.len) { + this.pos = this.len; + throw indexOutOfRange(this, 10); + } + return value; + }; +})(); + +/** + * Reads a varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.int32 = function read_int32() { + return this.uint32() | 0; +}; + +/** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.sint32 = function read_sint32() { + var value = this.uint32(); + return value >>> 1 ^ -(value & 1) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readLongVarint() { + // tends to deopt with local vars for octet etc. + var bits = new LongBits(0, 0); + var i = 0; + if (this.len - this.pos > 4) { // fast route (lo) + for (; i < 4; ++i) { + // 1st..4th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 5th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0; + bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + i = 0; + } else { + for (; i < 3; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 1st..3th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 4th + bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0; + return bits; + } + if (this.len - this.pos > 4) { // fast route (hi) + for (; i < 5; ++i) { + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } else { + for (; i < 5; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } + /* istanbul ignore next */ + throw Error("invalid varint encoding"); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads a varint as a signed 64 bit value. + * @name Reader#int64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as an unsigned 64 bit value. + * @name Reader#uint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @name Reader#sint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as a boolean. + * @returns {boolean} Value read + */ +Reader.prototype.bool = function read_bool() { + return this.uint32() !== 0; +}; + +function readFixed32_end(buf, end) { // note that this uses `end`, not `pos` + return (buf[end - 4] + | buf[end - 3] << 8 + | buf[end - 2] << 16 + | buf[end - 1] << 24) >>> 0; +} + +/** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.fixed32 = function read_fixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4); +}; + +/** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.sfixed32 = function read_sfixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readFixed64(/* this: Reader */) { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 8); + + return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads fixed 64 bits. + * @name Reader#fixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads zig-zag encoded fixed 64 bits. + * @name Reader#sfixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a float (32 bit) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.float = function read_float() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readFloatLE(this.buf, this.pos); + this.pos += 4; + return value; +}; + +/** + * Reads a double (64 bit float) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.double = function read_double() { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readDoubleLE(this.buf, this.pos); + this.pos += 8; + return value; +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns {Uint8Array} Value read + */ +Reader.prototype.bytes = function read_bytes() { + var length = this.uint32(), + start = this.pos, + end = this.pos + length; + + /* istanbul ignore if */ + if (end > this.len) + throw indexOutOfRange(this, length); + + this.pos += length; + if (Array.isArray(this.buf)) // plain array + return this.buf.slice(start, end); + return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1 + ? new this.buf.constructor(0) + : this._slice.call(this.buf, start, end); +}; + +/** + * Reads a string preceeded by its byte length as a varint. + * @returns {string} Value read + */ +Reader.prototype.string = function read_string() { + var bytes = this.bytes(); + return utf8.read(bytes, 0, bytes.length); +}; + +/** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param {number} [length] Length if known, otherwise a varint is assumed + * @returns {Reader} `this` + */ +Reader.prototype.skip = function skip(length) { + if (typeof length === "number") { + /* istanbul ignore if */ + if (this.pos + length > this.len) + throw indexOutOfRange(this, length); + this.pos += length; + } else { + do { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + } while (this.buf[this.pos++] & 128); + } + return this; +}; + +/** + * Skips the next element of the specified wire type. + * @param {number} wireType Wire type received + * @returns {Reader} `this` + */ +Reader.prototype.skipType = function(wireType) { + switch (wireType) { + case 0: + this.skip(); + break; + case 1: + this.skip(8); + break; + case 2: + this.skip(this.uint32()); + break; + case 3: + while ((wireType = this.uint32() & 7) !== 4) { + this.skipType(wireType); + } + break; + case 5: + this.skip(4); + break; + + /* istanbul ignore next */ + default: + throw Error("invalid wire type " + wireType + " at offset " + this.pos); + } + return this; +}; + +Reader._configure = function(BufferReader_) { + BufferReader = BufferReader_; + + var fn = util.Long ? "toLong" : /* istanbul ignore next */ "toNumber"; + util.merge(Reader.prototype, { + + int64: function read_int64() { + return readLongVarint.call(this)[fn](false); + }, + + uint64: function read_uint64() { + return readLongVarint.call(this)[fn](true); + }, + + sint64: function read_sint64() { + return readLongVarint.call(this).zzDecode()[fn](false); + }, + + fixed64: function read_fixed64() { + return readFixed64.call(this)[fn](true); + }, + + sfixed64: function read_sfixed64() { + return readFixed64.call(this)[fn](false); + } + + }); +}; + +},{"35":35}],25:[function(require,module,exports){ +"use strict"; +module.exports = BufferReader; + +// extends Reader +var Reader = require(24); +(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader; + +var util = require(35); + +/** + * Constructs a new buffer reader instance. + * @classdesc Wire format reader using node buffers. + * @extends Reader + * @constructor + * @param {Buffer} buffer Buffer to read from + */ +function BufferReader(buffer) { + Reader.call(this, buffer); + + /** + * Read buffer. + * @name BufferReader#buf + * @type {Buffer} + */ +} + +/* istanbul ignore else */ +if (util.Buffer) + BufferReader.prototype._slice = util.Buffer.prototype.slice; + +/** + * @override + */ +BufferReader.prototype.string = function read_string_buffer() { + var len = this.uint32(); // modifies pos + return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len)); +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @name BufferReader#bytes + * @function + * @returns {Buffer} Value read + */ + +},{"24":24,"35":35}],26:[function(require,module,exports){ +"use strict"; +module.exports = Root; + +// extends Namespace +var Namespace = require(21); +((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = "Root"; + +var Field = require(15), + Enum = require(14), + OneOf = require(23), + util = require(33); + +var Type, // cyclic + parse, // might be excluded + common; // " + +/** + * Constructs a new root namespace instance. + * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together. + * @extends NamespaceBase + * @constructor + * @param {Object.} [options] Top level options + */ +function Root(options) { + Namespace.call(this, "", options); + + /** + * Deferred extension fields. + * @type {Field[]} + */ + this.deferred = []; + + /** + * Resolved file names of loaded files. + * @type {string[]} + */ + this.files = []; +} + +/** + * Loads a namespace descriptor into a root namespace. + * @param {INamespace} json Nameespace descriptor + * @param {Root} [root] Root namespace, defaults to create a new one if omitted + * @returns {Root} Root namespace + */ +Root.fromJSON = function fromJSON(json, root) { + if (!root) + root = new Root(); + if (json.options) + root.setOptions(json.options); + return root.addJSON(json.nested); +}; + +/** + * Resolves the path of an imported file, relative to the importing origin. + * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories. + * @function + * @param {string} origin The file name of the importing file + * @param {string} target The file name being imported + * @returns {string|null} Resolved path to `target` or `null` to skip the file + */ +Root.prototype.resolvePath = util.path.resolve; + +// A symbol-like function to safely signal synchronous loading +/* istanbul ignore next */ +function SYNC() {} // eslint-disable-line no-empty-function + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} options Parse options + * @param {LoadCallback} callback Callback function + * @returns {undefined} + */ +Root.prototype.load = function load(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = undefined; + } + var self = this; + if (!callback) + return util.asPromise(load, self, filename, options); + + var sync = callback === SYNC; // undocumented + + // Finishes loading by calling the callback (exactly once) + function finish(err, root) { + /* istanbul ignore if */ + if (!callback) + return; + var cb = callback; + callback = null; + if (sync) + throw err; + cb(err, root); + } + + // Processes a single file + function process(filename, source) { + try { + if (util.isString(source) && source.charAt(0) === "{") + source = JSON.parse(source); + if (!util.isString(source)) + self.setOptions(source.options).addJSON(source.nested); + else { + parse.filename = filename; + var parsed = parse(source, self, options), + resolved, + i = 0; + if (parsed.imports) + for (; i < parsed.imports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.imports[i])) + fetch(resolved); + if (parsed.weakImports) + for (i = 0; i < parsed.weakImports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.weakImports[i])) + fetch(resolved, true); + } + } catch (err) { + finish(err); + } + if (!sync && !queued) + finish(null, self); // only once anyway + } + + // Fetches a single file + function fetch(filename, weak) { + + // Strip path if this file references a bundled definition + var idx = filename.lastIndexOf("google/protobuf/"); + if (idx > -1) { + var altname = filename.substring(idx); + if (altname in common) + filename = altname; + } + + // Skip if already loaded / attempted + if (self.files.indexOf(filename) > -1) + return; + self.files.push(filename); + + // Shortcut bundled definitions + if (filename in common) { + if (sync) + process(filename, common[filename]); + else { + ++queued; + setTimeout(function() { + --queued; + process(filename, common[filename]); + }); + } + return; + } + + // Otherwise fetch from disk or network + if (sync) { + var source; + try { + source = util.fs.readFileSync(filename).toString("utf8"); + } catch (err) { + if (!weak) + finish(err); + return; + } + process(filename, source); + } else { + ++queued; + util.fetch(filename, function(err, source) { + --queued; + /* istanbul ignore if */ + if (!callback) + return; // terminated meanwhile + if (err) { + /* istanbul ignore else */ + if (!weak) + finish(err); + else if (!queued) // can't be covered reliably + finish(null, self); + return; + } + process(filename, source); + }); + } + } + var queued = 0; + + // Assembling the root namespace doesn't require working type + // references anymore, so we can load everything in parallel + if (util.isString(filename)) + filename = [ filename ]; + for (var i = 0, resolved; i < filename.length; ++i) + if (resolved = self.resolvePath("", filename[i])) + fetch(resolved); + + if (sync) + return self; + if (!queued) + finish(null, self); + return undefined; +}; +// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Promise} Promise + * @variation 3 + */ +// function load(filename:string, [options:IParseOptions]):Promise + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only). + * @function Root#loadSync + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + */ +Root.prototype.loadSync = function loadSync(filename, options) { + if (!util.isNode) + throw Error("not supported"); + return this.load(filename, options, SYNC); +}; + +/** + * @override + */ +Root.prototype.resolveAll = function resolveAll() { + if (this.deferred.length) + throw Error("unresolvable extensions: " + this.deferred.map(function(field) { + return "'extend " + field.extend + "' in " + field.parent.fullName; + }).join(", ")); + return Namespace.prototype.resolveAll.call(this); +}; + +// only uppercased (and thus conflict-free) children are exposed, see below +var exposeRe = /^[A-Z]/; + +/** + * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type. + * @param {Root} root Root instance + * @param {Field} field Declaring extension field witin the declaring type + * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise + * @inner + * @ignore + */ +function tryHandleExtension(root, field) { + var extendedType = field.parent.lookup(field.extend); + if (extendedType) { + var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options); + sisterField.declaringField = field; + field.extensionField = sisterField; + extendedType.add(sisterField); + return true; + } + return false; +} + +/** + * Called when any object is added to this root or its sub-namespaces. + * @param {ReflectionObject} object Object added + * @returns {undefined} + * @private + */ +Root.prototype._handleAdd = function _handleAdd(object) { + if (object instanceof Field) { + + if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField) + if (!tryHandleExtension(this, object)) + this.deferred.push(object); + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + object.parent[object.name] = object.values; // expose enum values as property of its parent + + } else if (!(object instanceof OneOf)) /* everything else is a namespace */ { + + if (object instanceof Type) // Try to handle any deferred extensions + for (var i = 0; i < this.deferred.length;) + if (tryHandleExtension(this, this.deferred[i])) + this.deferred.splice(i, 1); + else + ++i; + for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace + this._handleAdd(object._nestedArray[j]); + if (exposeRe.test(object.name)) + object.parent[object.name] = object; // expose namespace as property of its parent + } + + // The above also adds uppercased (and thus conflict-free) nested types, services and enums as + // properties of namespaces just like static code does. This allows using a .d.ts generated for + // a static module with reflection-based solutions where the condition is met. +}; + +/** + * Called when any object is removed from this root or its sub-namespaces. + * @param {ReflectionObject} object Object removed + * @returns {undefined} + * @private + */ +Root.prototype._handleRemove = function _handleRemove(object) { + if (object instanceof Field) { + + if (/* an extension field */ object.extend !== undefined) { + if (/* already handled */ object.extensionField) { // remove its sister field + object.extensionField.parent.remove(object.extensionField); + object.extensionField = null; + } else { // cancel the extension + var index = this.deferred.indexOf(object); + /* istanbul ignore else */ + if (index > -1) + this.deferred.splice(index, 1); + } + } + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose enum values + + } else if (object instanceof Namespace) { + + for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace + this._handleRemove(object._nestedArray[i]); + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose namespaces + + } +}; + +// Sets up cyclic dependencies (called in index-light) +Root._configure = function(Type_, parse_, common_) { + Type = Type_; + parse = parse_; + common = common_; +}; + +},{"14":14,"15":15,"21":21,"23":23,"33":33}],27:[function(require,module,exports){ +"use strict"; +module.exports = {}; + +/** + * Named roots. + * This is where pbjs stores generated structures (the option `-r, --root` specifies a name). + * Can also be used manually to make roots available accross modules. + * @name roots + * @type {Object.} + * @example + * // pbjs -r myroot -o compiled.js ... + * + * // in another module: + * require("./compiled.js"); + * + * // in any subsequent module: + * var root = protobuf.roots["myroot"]; + */ + +},{}],28:[function(require,module,exports){ +"use strict"; + +/** + * Streaming RPC helpers. + * @namespace + */ +var rpc = exports; + +/** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @typedef RPCImpl + * @type {function} + * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called + * @param {Uint8Array} requestData Request data + * @param {RPCImplCallback} callback Callback function + * @returns {undefined} + * @example + * function rpcImpl(method, requestData, callback) { + * if (protobuf.util.lcFirst(method.name) !== "myMethod") // compatible with static code + * throw Error("no such method"); + * asynchronouslyObtainAResponse(requestData, function(err, responseData) { + * callback(err, responseData); + * }); + * } + */ + +/** + * Node-style callback as used by {@link RPCImpl}. + * @typedef RPCImplCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error + * @returns {undefined} + */ + +rpc.Service = require(29); + +},{"29":29}],29:[function(require,module,exports){ +"use strict"; +module.exports = Service; + +var util = require(35); + +// Extends EventEmitter +(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service; + +/** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @typedef rpc.ServiceMethodCallback + * @template TRes extends Message + * @type {function} + * @param {Error|null} error Error, if any + * @param {TRes} [response] Response message + * @returns {undefined} + */ + +/** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @typedef rpc.ServiceMethod + * @template TReq extends Message + * @template TRes extends Message + * @type {function} + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message + * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined` + */ + +/** + * Constructs a new RPC service instance. + * @classdesc An RPC service as returned by {@link Service#create}. + * @exports rpc.Service + * @extends util.EventEmitter + * @constructor + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ +function Service(rpcImpl, requestDelimited, responseDelimited) { + + if (typeof rpcImpl !== "function") + throw TypeError("rpcImpl must be a function"); + + util.EventEmitter.call(this); + + /** + * RPC implementation. Becomes `null` once the service is ended. + * @type {RPCImpl|null} + */ + this.rpcImpl = rpcImpl; + + /** + * Whether requests are length-delimited. + * @type {boolean} + */ + this.requestDelimited = Boolean(requestDelimited); + + /** + * Whether responses are length-delimited. + * @type {boolean} + */ + this.responseDelimited = Boolean(responseDelimited); +} + +/** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param {Method|rpc.ServiceMethod} method Reflected or static method + * @param {Constructor} requestCtor Request constructor + * @param {Constructor} responseCtor Response constructor + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} callback Service callback + * @returns {undefined} + * @template TReq extends Message + * @template TRes extends Message + */ +Service.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) { + + if (!request) + throw TypeError("request must be specified"); + + var self = this; + if (!callback) + return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request); + + if (!self.rpcImpl) { + setTimeout(function() { callback(Error("already ended")); }, 0); + return undefined; + } + + try { + return self.rpcImpl( + method, + requestCtor[self.requestDelimited ? "encodeDelimited" : "encode"](request).finish(), + function rpcCallback(err, response) { + + if (err) { + self.emit("error", err, method); + return callback(err); + } + + if (response === null) { + self.end(/* endedByRPC */ true); + return undefined; + } + + if (!(response instanceof responseCtor)) { + try { + response = responseCtor[self.responseDelimited ? "decodeDelimited" : "decode"](response); + } catch (err) { + self.emit("error", err, method); + return callback(err); + } + } + + self.emit("data", response, method); + return callback(null, response); + } + ); + } catch (err) { + self.emit("error", err, method); + setTimeout(function() { callback(err); }, 0); + return undefined; + } +}; + +/** + * Ends this service and emits the `end` event. + * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns {rpc.Service} `this` + */ +Service.prototype.end = function end(endedByRPC) { + if (this.rpcImpl) { + if (!endedByRPC) // signal end to rpcImpl + this.rpcImpl(null, null, null); + this.rpcImpl = null; + this.emit("end").off(); + } + return this; +}; + +},{"35":35}],30:[function(require,module,exports){ +"use strict"; +module.exports = Service; + +// extends Namespace +var Namespace = require(21); +((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = "Service"; + +var Method = require(20), + util = require(33), + rpc = require(28); + +/** + * Constructs a new service instance. + * @classdesc Reflected service. + * @extends NamespaceBase + * @constructor + * @param {string} name Service name + * @param {Object.} [options] Service options + * @throws {TypeError} If arguments are invalid + */ +function Service(name, options) { + Namespace.call(this, name, options); + + /** + * Service methods. + * @type {Object.} + */ + this.methods = {}; // toJSON, marker + + /** + * Cached methods as an array. + * @type {Method[]|null} + * @private + */ + this._methodsArray = null; +} + +/** + * Service descriptor. + * @interface IService + * @extends INamespace + * @property {Object.} methods Method descriptors + */ + +/** + * Constructs a service from a service descriptor. + * @param {string} name Service name + * @param {IService} json Service descriptor + * @returns {Service} Created service + * @throws {TypeError} If arguments are invalid + */ +Service.fromJSON = function fromJSON(name, json) { + var service = new Service(name, json.options); + /* istanbul ignore else */ + if (json.methods) + for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i) + service.add(Method.fromJSON(names[i], json.methods[names[i]])); + if (json.nested) + service.addJSON(json.nested); + service.comment = json.comment; + return service; +}; + +/** + * Converts this service to a service descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IService} Service descriptor + */ +Service.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "methods" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {}, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Methods of this service as an array for iteration. + * @name Service#methodsArray + * @type {Method[]} + * @readonly + */ +Object.defineProperty(Service.prototype, "methodsArray", { + get: function() { + return this._methodsArray || (this._methodsArray = util.toArray(this.methods)); + } +}); + +function clearCache(service) { + service._methodsArray = null; + return service; +} + +/** + * @override + */ +Service.prototype.get = function get(name) { + return this.methods[name] + || Namespace.prototype.get.call(this, name); +}; + +/** + * @override + */ +Service.prototype.resolveAll = function resolveAll() { + var methods = this.methodsArray; + for (var i = 0; i < methods.length; ++i) + methods[i].resolve(); + return Namespace.prototype.resolve.call(this); +}; + +/** + * @override + */ +Service.prototype.add = function add(object) { + + /* istanbul ignore if */ + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Method) { + this.methods[object.name] = object; + object.parent = this; + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * @override + */ +Service.prototype.remove = function remove(object) { + if (object instanceof Method) { + + /* istanbul ignore if */ + if (this.methods[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.methods[object.name]; + object.parent = null; + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Creates a runtime service using the specified rpc implementation. + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed. + */ +Service.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) { + var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited); + for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) { + var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\w_]/g, ""); + rpcService[methodName] = util.codegen(["r","c"], util.isReserved(methodName) ? methodName + "_" : methodName)("return this.rpcCall(m,q,s,r,c)")({ + m: method, + q: method.resolvedRequestType.ctor, + s: method.resolvedResponseType.ctor + }); + } + return rpcService; +}; + +},{"20":20,"21":21,"28":28,"33":33}],31:[function(require,module,exports){ +"use strict"; +module.exports = Type; + +// extends Namespace +var Namespace = require(21); +((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = "Type"; + +var Enum = require(14), + OneOf = require(23), + Field = require(15), + MapField = require(18), + Service = require(30), + Message = require(19), + Reader = require(24), + Writer = require(38), + util = require(33), + encoder = require(13), + decoder = require(12), + verifier = require(36), + converter = require(11), + wrappers = require(37); + +/** + * Constructs a new reflected message type instance. + * @classdesc Reflected message type. + * @extends NamespaceBase + * @constructor + * @param {string} name Message name + * @param {Object.} [options] Declared options + */ +function Type(name, options) { + Namespace.call(this, name, options); + + /** + * Message fields. + * @type {Object.} + */ + this.fields = {}; // toJSON, marker + + /** + * Oneofs declared within this namespace, if any. + * @type {Object.} + */ + this.oneofs = undefined; // toJSON + + /** + * Extension ranges, if any. + * @type {number[][]} + */ + this.extensions = undefined; // toJSON + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + /*? + * Whether this type is a legacy group. + * @type {boolean|undefined} + */ + this.group = undefined; // toJSON + + /** + * Cached fields by id. + * @type {Object.|null} + * @private + */ + this._fieldsById = null; + + /** + * Cached fields as an array. + * @type {Field[]|null} + * @private + */ + this._fieldsArray = null; + + /** + * Cached oneofs as an array. + * @type {OneOf[]|null} + * @private + */ + this._oneofsArray = null; + + /** + * Cached constructor. + * @type {Constructor<{}>} + * @private + */ + this._ctor = null; +} + +Object.defineProperties(Type.prototype, { + + /** + * Message fields by id. + * @name Type#fieldsById + * @type {Object.} + * @readonly + */ + fieldsById: { + get: function() { + + /* istanbul ignore if */ + if (this._fieldsById) + return this._fieldsById; + + this._fieldsById = {}; + for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) { + var field = this.fields[names[i]], + id = field.id; + + /* istanbul ignore if */ + if (this._fieldsById[id]) + throw Error("duplicate id " + id + " in " + this); + + this._fieldsById[id] = field; + } + return this._fieldsById; + } + }, + + /** + * Fields of this message as an array for iteration. + * @name Type#fieldsArray + * @type {Field[]} + * @readonly + */ + fieldsArray: { + get: function() { + return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields)); + } + }, + + /** + * Oneofs of this message as an array for iteration. + * @name Type#oneofsArray + * @type {OneOf[]} + * @readonly + */ + oneofsArray: { + get: function() { + return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs)); + } + }, + + /** + * The registered constructor, if any registered, otherwise a generic constructor. + * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor. + * @name Type#ctor + * @type {Constructor<{}>} + */ + ctor: { + get: function() { + return this._ctor || (this.ctor = Type.generateConstructor(this)()); + }, + set: function(ctor) { + + // Ensure proper prototype + var prototype = ctor.prototype; + if (!(prototype instanceof Message)) { + (ctor.prototype = new Message()).constructor = ctor; + util.merge(ctor.prototype, prototype); + } + + // Classes and messages reference their reflected type + ctor.$type = ctor.prototype.$type = this; + + // Mix in static methods + util.merge(ctor, Message, true); + + this._ctor = ctor; + + // Messages have non-enumerable default values on their prototype + var i = 0; + for (; i < /* initializes */ this.fieldsArray.length; ++i) + this._fieldsArray[i].resolve(); // ensures a proper value + + // Messages have non-enumerable getters and setters for each virtual oneof field + var ctorProperties = {}; + for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i) + ctorProperties[this._oneofsArray[i].resolve().name] = { + get: util.oneOfGetter(this._oneofsArray[i].oneof), + set: util.oneOfSetter(this._oneofsArray[i].oneof) + }; + if (i) + Object.defineProperties(ctor.prototype, ctorProperties); + } + } +}); + +/** + * Generates a constructor function for the specified type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +Type.generateConstructor = function generateConstructor(mtype) { + /* eslint-disable no-unexpected-multiline */ + var gen = util.codegen(["p"], mtype.name); + // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype + for (var i = 0, field; i < mtype.fieldsArray.length; ++i) + if ((field = mtype._fieldsArray[i]).map) gen + ("this%s={}", util.safeProp(field.name)); + else if (field.repeated) gen + ("this%s=[]", util.safeProp(field.name)); + return gen + ("if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors + * @property {Object.} fields Field descriptors + * @property {number[][]} [extensions] Extension ranges + * @property {number[][]} [reserved] Reserved ranges + * @property {boolean} [group=false] Whether a legacy group or not + */ + +/** + * Creates a message type from a message type descriptor. + * @param {string} name Message name + * @param {IType} json Message type descriptor + * @returns {Type} Created message type + */ +Type.fromJSON = function fromJSON(name, json) { + var type = new Type(name, json.options); + type.extensions = json.extensions; + type.reserved = json.reserved; + var names = Object.keys(json.fields), + i = 0; + for (; i < names.length; ++i) + type.add( + ( typeof json.fields[names[i]].keyType !== "undefined" + ? MapField.fromJSON + : Field.fromJSON )(names[i], json.fields[names[i]]) + ); + if (json.oneofs) + for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i) + type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]])); + if (json.nested) + for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) { + var nested = json.nested[names[i]]; + type.add( // most to least likely + ( nested.id !== undefined + ? Field.fromJSON + : nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + if (json.extensions && json.extensions.length) + type.extensions = json.extensions; + if (json.reserved && json.reserved.length) + type.reserved = json.reserved; + if (json.group) + type.group = true; + if (json.comment) + type.comment = json.comment; + return type; +}; + +/** + * Converts this message type to a message type descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IType} Message type descriptor + */ +Type.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "oneofs" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions), + "fields" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {}, + "extensions" , this.extensions && this.extensions.length ? this.extensions : undefined, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "group" , this.group || undefined, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Type.prototype.resolveAll = function resolveAll() { + var fields = this.fieldsArray, i = 0; + while (i < fields.length) + fields[i++].resolve(); + var oneofs = this.oneofsArray; i = 0; + while (i < oneofs.length) + oneofs[i++].resolve(); + return Namespace.prototype.resolveAll.call(this); +}; + +/** + * @override + */ +Type.prototype.get = function get(name) { + return this.fields[name] + || this.oneofs && this.oneofs[name] + || this.nested && this.nested[name] + || null; +}; + +/** + * Adds a nested object to this type. + * @param {ReflectionObject} object Nested object to add + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id + */ +Type.prototype.add = function add(object) { + + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Field && object.extend === undefined) { + // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects. + // The root object takes care of adding distinct sister-fields to the respective extended + // type instead. + + // avoids calling the getter if not absolutely necessary because it's called quite frequently + if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id]) + throw Error("duplicate id " + object.id + " in " + this); + if (this.isReservedId(object.id)) + throw Error("id " + object.id + " is reserved in " + this); + if (this.isReservedName(object.name)) + throw Error("name '" + object.name + "' is reserved in " + this); + + if (object.parent) + object.parent.remove(object); + this.fields[object.name] = object; + object.message = this; + object.onAdd(this); + return clearCache(this); + } + if (object instanceof OneOf) { + if (!this.oneofs) + this.oneofs = {}; + this.oneofs[object.name] = object; + object.onAdd(this); + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * Removes a nested object from this type. + * @param {ReflectionObject} object Nested object to remove + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this type + */ +Type.prototype.remove = function remove(object) { + if (object instanceof Field && object.extend === undefined) { + // See Type#add for the reason why extension fields are excluded here. + + /* istanbul ignore if */ + if (!this.fields || this.fields[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.fields[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + if (object instanceof OneOf) { + + /* istanbul ignore if */ + if (!this.oneofs || this.oneofs[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.oneofs[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message<{}>} Message instance + */ +Type.prototype.create = function create(properties) { + return new this.ctor(properties); +}; + +/** + * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}. + * @returns {Type} `this` + */ +Type.prototype.setup = function setup() { + // Sets up everything at once so that the prototype chain does not have to be re-evaluated + // multiple times (V8, soft-deopt prototype-check). + + var fullName = this.fullName, + types = []; + for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i) + types.push(this._fieldsArray[i].resolve().resolvedType); + + // Replace setup methods with type-specific generated functions + this.encode = encoder(this)({ + Writer : Writer, + types : types, + util : util + }); + this.decode = decoder(this)({ + Reader : Reader, + types : types, + util : util + }); + this.verify = verifier(this)({ + types : types, + util : util + }); + this.fromObject = converter.fromObject(this)({ + types : types, + util : util + }); + this.toObject = converter.toObject(this)({ + types : types, + util : util + }); + + // Inject custom wrappers for common types + var wrapper = wrappers[fullName]; + if (wrapper) { + var originalThis = Object.create(this); + // if (wrapper.fromObject) { + originalThis.fromObject = this.fromObject; + this.fromObject = wrapper.fromObject.bind(originalThis); + // } + // if (wrapper.toObject) { + originalThis.toObject = this.toObject; + this.toObject = wrapper.toObject.bind(originalThis); + // } + } + + return this; +}; + +/** + * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encode = function encode_setup(message, writer) { + return this.setup().encode(message, writer); // overrides this method +}; + +/** + * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim(); +}; + +/** + * Decodes a message of this type. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Length of the message, if known beforehand + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError<{}>} If required fields are missing + */ +Type.prototype.decode = function decode_setup(reader, length) { + return this.setup().decode(reader, length); // overrides this method +}; + +/** + * Decodes a message of this type preceeded by its byte length as a varint. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError} If required fields are missing + */ +Type.prototype.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof Reader)) + reader = Reader.create(reader); + return this.decode(reader, reader.uint32()); +}; + +/** + * Verifies that field values are valid and that required fields are present. + * @param {Object.} message Plain object to verify + * @returns {null|string} `null` if valid, otherwise the reason why it is not + */ +Type.prototype.verify = function verify_setup(message) { + return this.setup().verify(message); // overrides this method +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object to convert + * @returns {Message<{}>} Message instance + */ +Type.prototype.fromObject = function fromObject(object) { + return this.setup().fromObject(object); +}; + +/** + * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}. + * @interface IConversionOptions + * @property {Function} [longs] Long conversion type. + * Valid values are `String` and `Number` (the global types). + * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library. + * @property {Function} [enums] Enum value conversion type. + * Only valid value is `String` (the global type). + * Defaults to copy the present value, which is the numeric id. + * @property {Function} [bytes] Bytes value conversion type. + * Valid values are `Array` and (a base64 encoded) `String` (the global types). + * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser. + * @property {boolean} [defaults=false] Also sets default values on the resulting object + * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false` + * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false` + * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any + * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings + */ + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ +Type.prototype.toObject = function toObject(message, options) { + return this.setup().toObject(message, options); +}; + +/** + * Decorator function as returned by {@link Type.d} (TypeScript). + * @typedef TypeDecorator + * @type {function} + * @param {Constructor} target Target constructor + * @returns {undefined} + * @template T extends Message + */ + +/** + * Type decorator (TypeScript). + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {TypeDecorator} Decorator function + * @template T extends Message + */ +Type.d = function decorateType(typeName) { + return function typeDecorator(target) { + util.decorateType(target, typeName); + }; +}; + +},{"11":11,"12":12,"13":13,"14":14,"15":15,"18":18,"19":19,"21":21,"23":23,"24":24,"30":30,"33":33,"36":36,"37":37,"38":38}],32:[function(require,module,exports){ +"use strict"; + +/** + * Common type constants. + * @namespace + */ +var types = exports; + +var util = require(33); + +var s = [ + "double", // 0 + "float", // 1 + "int32", // 2 + "uint32", // 3 + "sint32", // 4 + "fixed32", // 5 + "sfixed32", // 6 + "int64", // 7 + "uint64", // 8 + "sint64", // 9 + "fixed64", // 10 + "sfixed64", // 11 + "bool", // 12 + "string", // 13 + "bytes" // 14 +]; + +function bake(values, offset) { + var i = 0, o = {}; + offset |= 0; + while (i < values.length) o[s[i + offset]] = values[i++]; + return o; +} + +/** + * Basic type wire types. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + * @property {number} bytes=2 Ldelim wire type + */ +types.basic = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2, + /* bytes */ 2 +]); + +/** + * Basic type defaults. + * @type {Object.} + * @const + * @property {number} double=0 Double default + * @property {number} float=0 Float default + * @property {number} int32=0 Int32 default + * @property {number} uint32=0 Uint32 default + * @property {number} sint32=0 Sint32 default + * @property {number} fixed32=0 Fixed32 default + * @property {number} sfixed32=0 Sfixed32 default + * @property {number} int64=0 Int64 default + * @property {number} uint64=0 Uint64 default + * @property {number} sint64=0 Sint32 default + * @property {number} fixed64=0 Fixed64 default + * @property {number} sfixed64=0 Sfixed64 default + * @property {boolean} bool=false Bool default + * @property {string} string="" String default + * @property {Array.} bytes=Array(0) Bytes default + * @property {null} message=null Message default + */ +types.defaults = bake([ + /* double */ 0, + /* float */ 0, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 0, + /* sfixed32 */ 0, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 0, + /* sfixed64 */ 0, + /* bool */ false, + /* string */ "", + /* bytes */ util.emptyArray, + /* message */ null +]); + +/** + * Basic long type wire types. + * @type {Object.} + * @const + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + */ +types.long = bake([ + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1 +], 7); + +/** + * Allowed types for map keys with their associated wire type. + * @type {Object.} + * @const + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + */ +types.mapKey = bake([ + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2 +], 2); + +/** + * Allowed types for packed repeated fields with their associated wire type. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + */ +types.packed = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0 +]); + +},{"33":33}],33:[function(require,module,exports){ +"use strict"; + +/** + * Various utility functions. + * @namespace + */ +var util = module.exports = require(35); + +var roots = require(27); + +var Type, // cyclic + Enum; + +util.codegen = require(3); +util.fetch = require(5); +util.path = require(8); + +/** + * Node's fs module if available. + * @type {Object.} + */ +util.fs = util.inquire("fs"); + +/** + * Converts an object's values to an array. + * @param {Object.} object Object to convert + * @returns {Array.<*>} Converted array + */ +util.toArray = function toArray(object) { + if (object) { + var keys = Object.keys(object), + array = new Array(keys.length), + index = 0; + while (index < keys.length) + array[index] = object[keys[index++]]; + return array; + } + return []; +}; + +/** + * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values. + * @param {Array.<*>} array Array to convert + * @returns {Object.} Converted object + */ +util.toObject = function toObject(array) { + var object = {}, + index = 0; + while (index < array.length) { + var key = array[index++], + val = array[index++]; + if (val !== undefined) + object[key] = val; + } + return object; +}; + +var safePropBackslashRe = /\\/g, + safePropQuoteRe = /"/g; + +/** + * Tests whether the specified name is a reserved word in JS. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +util.isReserved = function isReserved(name) { + return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name); +}; + +/** + * Returns a safe property accessor for the specified property name. + * @param {string} prop Property name + * @returns {string} Safe accessor + */ +util.safeProp = function safeProp(prop) { + if (!/^[$\w_]+$/.test(prop) || util.isReserved(prop)) + return "[\"" + prop.replace(safePropBackslashRe, "\\\\").replace(safePropQuoteRe, "\\\"") + "\"]"; + return "." + prop; +}; + +/** + * Converts the first character of a string to upper case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.ucFirst = function ucFirst(str) { + return str.charAt(0).toUpperCase() + str.substring(1); +}; + +var camelCaseRe = /_([a-z])/g; + +/** + * Converts a string to camel case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.camelCase = function camelCase(str) { + return str.substring(0, 1) + + str.substring(1) + .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); }); +}; + +/** + * Compares reflected fields by id. + * @param {Field} a First field + * @param {Field} b Second field + * @returns {number} Comparison value + */ +util.compareFieldsById = function compareFieldsById(a, b) { + return a.id - b.id; +}; + +/** + * Decorator helper for types (TypeScript). + * @param {Constructor} ctor Constructor function + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {Type} Reflected type + * @template T extends Message + * @property {Root} root Decorators root + */ +util.decorateType = function decorateType(ctor, typeName) { + + /* istanbul ignore if */ + if (ctor.$type) { + if (typeName && ctor.$type.name !== typeName) { + util.decorateRoot.remove(ctor.$type); + ctor.$type.name = typeName; + util.decorateRoot.add(ctor.$type); + } + return ctor.$type; + } + + /* istanbul ignore next */ + if (!Type) + Type = require(31); + + var type = new Type(typeName || ctor.name); + util.decorateRoot.add(type); + type.ctor = ctor; // sets up .encode, .decode etc. + Object.defineProperty(ctor, "$type", { value: type, enumerable: false }); + Object.defineProperty(ctor.prototype, "$type", { value: type, enumerable: false }); + return type; +}; + +var decorateEnumIndex = 0; + +/** + * Decorator helper for enums (TypeScript). + * @param {Object} object Enum object + * @returns {Enum} Reflected enum + */ +util.decorateEnum = function decorateEnum(object) { + + /* istanbul ignore if */ + if (object.$type) + return object.$type; + + /* istanbul ignore next */ + if (!Enum) + Enum = require(14); + + var enm = new Enum("Enum" + decorateEnumIndex++, object); + util.decorateRoot.add(enm); + Object.defineProperty(object, "$type", { value: enm, enumerable: false }); + return enm; +}; + +/** + * Decorator root (TypeScript). + * @name util.decorateRoot + * @type {Root} + * @readonly + */ +Object.defineProperty(util, "decorateRoot", { + get: function() { + return roots["decorated"] || (roots["decorated"] = new (require(26))()); + } +}); + +},{"14":14,"26":26,"27":27,"3":3,"31":31,"35":35,"5":5,"8":8}],34:[function(require,module,exports){ +"use strict"; +module.exports = LongBits; + +var util = require(35); + +/** + * Constructs new long bits. + * @classdesc Helper class for working with the low and high bits of a 64 bit value. + * @memberof util + * @constructor + * @param {number} lo Low 32 bits, unsigned + * @param {number} hi High 32 bits, unsigned + */ +function LongBits(lo, hi) { + + // note that the casts below are theoretically unnecessary as of today, but older statically + // generated converter code might still call the ctor with signed 32bits. kept for compat. + + /** + * Low bits. + * @type {number} + */ + this.lo = lo >>> 0; + + /** + * High bits. + * @type {number} + */ + this.hi = hi >>> 0; +} + +/** + * Zero bits. + * @memberof util.LongBits + * @type {util.LongBits} + */ +var zero = LongBits.zero = new LongBits(0, 0); + +zero.toNumber = function() { return 0; }; +zero.zzEncode = zero.zzDecode = function() { return this; }; +zero.length = function() { return 1; }; + +/** + * Zero hash. + * @memberof util.LongBits + * @type {string} + */ +var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0"; + +/** + * Constructs new long bits from the specified number. + * @param {number} value Value + * @returns {util.LongBits} Instance + */ +LongBits.fromNumber = function fromNumber(value) { + if (value === 0) + return zero; + var sign = value < 0; + if (sign) + value = -value; + var lo = value >>> 0, + hi = (value - lo) / 4294967296 >>> 0; + if (sign) { + hi = ~hi >>> 0; + lo = ~lo >>> 0; + if (++lo > 4294967295) { + lo = 0; + if (++hi > 4294967295) + hi = 0; + } + } + return new LongBits(lo, hi); +}; + +/** + * Constructs new long bits from a number, long or string. + * @param {Long|number|string} value Value + * @returns {util.LongBits} Instance + */ +LongBits.from = function from(value) { + if (typeof value === "number") + return LongBits.fromNumber(value); + if (util.isString(value)) { + /* istanbul ignore else */ + if (util.Long) + value = util.Long.fromString(value); + else + return LongBits.fromNumber(parseInt(value, 10)); + } + return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero; +}; + +/** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {number} Possibly unsafe number + */ +LongBits.prototype.toNumber = function toNumber(unsigned) { + if (!unsigned && this.hi >>> 31) { + var lo = ~this.lo + 1 >>> 0, + hi = ~this.hi >>> 0; + if (!lo) + hi = hi + 1 >>> 0; + return -(lo + hi * 4294967296); + } + return this.lo + this.hi * 4294967296; +}; + +/** + * Converts this long bits to a long. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long} Long + */ +LongBits.prototype.toLong = function toLong(unsigned) { + return util.Long + ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned)) + /* istanbul ignore next */ + : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) }; +}; + +var charCodeAt = String.prototype.charCodeAt; + +/** + * Constructs new long bits from the specified 8 characters long hash. + * @param {string} hash Hash + * @returns {util.LongBits} Bits + */ +LongBits.fromHash = function fromHash(hash) { + if (hash === zeroHash) + return zero; + return new LongBits( + ( charCodeAt.call(hash, 0) + | charCodeAt.call(hash, 1) << 8 + | charCodeAt.call(hash, 2) << 16 + | charCodeAt.call(hash, 3) << 24) >>> 0 + , + ( charCodeAt.call(hash, 4) + | charCodeAt.call(hash, 5) << 8 + | charCodeAt.call(hash, 6) << 16 + | charCodeAt.call(hash, 7) << 24) >>> 0 + ); +}; + +/** + * Converts this long bits to a 8 characters long hash. + * @returns {string} Hash + */ +LongBits.prototype.toHash = function toHash() { + return String.fromCharCode( + this.lo & 255, + this.lo >>> 8 & 255, + this.lo >>> 16 & 255, + this.lo >>> 24 , + this.hi & 255, + this.hi >>> 8 & 255, + this.hi >>> 16 & 255, + this.hi >>> 24 + ); +}; + +/** + * Zig-zag encodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzEncode = function zzEncode() { + var mask = this.hi >> 31; + this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0; + this.lo = ( this.lo << 1 ^ mask) >>> 0; + return this; +}; + +/** + * Zig-zag decodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzDecode = function zzDecode() { + var mask = -(this.lo & 1); + this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0; + this.hi = ( this.hi >>> 1 ^ mask) >>> 0; + return this; +}; + +/** + * Calculates the length of this longbits when encoded as a varint. + * @returns {number} Length + */ +LongBits.prototype.length = function length() { + var part0 = this.lo, + part1 = (this.lo >>> 28 | this.hi << 4) >>> 0, + part2 = this.hi >>> 24; + return part2 === 0 + ? part1 === 0 + ? part0 < 16384 + ? part0 < 128 ? 1 : 2 + : part0 < 2097152 ? 3 : 4 + : part1 < 16384 + ? part1 < 128 ? 5 : 6 + : part1 < 2097152 ? 7 : 8 + : part2 < 128 ? 9 : 10; +}; + +},{"35":35}],35:[function(require,module,exports){ +"use strict"; +var util = exports; + +// used to return a Promise where callback is omitted +util.asPromise = require(1); + +// converts to / from base64 encoded strings +util.base64 = require(2); + +// base class of rpc.Service +util.EventEmitter = require(4); + +// float handling accross browsers +util.float = require(6); + +// requires modules optionally and hides the call from bundlers +util.inquire = require(7); + +// converts to / from utf8 encoded strings +util.utf8 = require(10); + +// provides a node-like buffer pool in the browser +util.pool = require(9); + +// utility to work with the low and high bits of a 64 bit value +util.LongBits = require(34); + +// global object reference +util.global = typeof window !== "undefined" && window + || typeof global !== "undefined" && global + || typeof self !== "undefined" && self + || this; // eslint-disable-line no-invalid-this + +/** + * An immuable empty array. + * @memberof util + * @type {Array.<*>} + * @const + */ +util.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes + +/** + * An immutable empty object. + * @type {Object} + * @const + */ +util.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes + +/** + * Whether running within node or not. + * @memberof util + * @type {boolean} + * @const + */ +util.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node); + +/** + * Tests if the specified value is an integer. + * @function + * @param {*} value Value to test + * @returns {boolean} `true` if the value is an integer + */ +util.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) { + return typeof value === "number" && isFinite(value) && Math.floor(value) === value; +}; + +/** + * Tests if the specified value is a string. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a string + */ +util.isString = function isString(value) { + return typeof value === "string" || value instanceof String; +}; + +/** + * Tests if the specified value is a non-null object. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a non-null object + */ +util.isObject = function isObject(value) { + return value && typeof value === "object"; +}; + +/** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @function + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isset = + +/** + * Checks if a property on a message is considered to be present. + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isSet = function isSet(obj, prop) { + var value = obj[prop]; + if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins + return typeof value !== "object" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0; + return false; +}; + +/** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + * @interface Buffer + * @extends Uint8Array + */ + +/** + * Node's Buffer class if available. + * @type {Constructor} + */ +util.Buffer = (function() { + try { + var Buffer = util.inquire("buffer").Buffer; + // refuse to use non-node buffers if not explicitly assigned (perf reasons): + return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null; + } catch (e) { + /* istanbul ignore next */ + return null; + } +})(); + +// Internal alias of or polyfull for Buffer.from. +util._Buffer_from = null; + +// Internal alias of or polyfill for Buffer.allocUnsafe. +util._Buffer_allocUnsafe = null; + +/** + * Creates a new buffer of whatever type supported by the environment. + * @param {number|number[]} [sizeOrArray=0] Buffer size or number array + * @returns {Uint8Array|Buffer} Buffer + */ +util.newBuffer = function newBuffer(sizeOrArray) { + /* istanbul ignore next */ + return typeof sizeOrArray === "number" + ? util.Buffer + ? util._Buffer_allocUnsafe(sizeOrArray) + : new util.Array(sizeOrArray) + : util.Buffer + ? util._Buffer_from(sizeOrArray) + : typeof Uint8Array === "undefined" + ? sizeOrArray + : new Uint8Array(sizeOrArray); +}; + +/** + * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. + * @type {Constructor} + */ +util.Array = typeof Uint8Array !== "undefined" ? Uint8Array /* istanbul ignore next */ : Array; + +/** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + * @interface Long + * @property {number} low Low bits + * @property {number} high High bits + * @property {boolean} unsigned Whether unsigned or not + */ + +/** + * Long.js's Long class if available. + * @type {Constructor} + */ +util.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long + || /* istanbul ignore next */ util.global.Long + || util.inquire("long"); + +/** + * Regular expression used to verify 2 bit (`bool`) map keys. + * @type {RegExp} + * @const + */ +util.key2Re = /^true|false|0|1$/; + +/** + * Regular expression used to verify 32 bit (`int32` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key32Re = /^-?(?:0|[1-9][0-9]*)$/; + +/** + * Regular expression used to verify 64 bit (`int64` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/; + +/** + * Converts a number or long to an 8 characters long hash string. + * @param {Long|number} value Value to convert + * @returns {string} Hash + */ +util.longToHash = function longToHash(value) { + return value + ? util.LongBits.from(value).toHash() + : util.LongBits.zeroHash; +}; + +/** + * Converts an 8 characters long hash string to a long or number. + * @param {string} hash Hash + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long|number} Original value + */ +util.longFromHash = function longFromHash(hash, unsigned) { + var bits = util.LongBits.fromHash(hash); + if (util.Long) + return util.Long.fromBits(bits.lo, bits.hi, unsigned); + return bits.toNumber(Boolean(unsigned)); +}; + +/** + * Merges the properties of the source object into the destination object. + * @memberof util + * @param {Object.} dst Destination object + * @param {Object.} src Source object + * @param {boolean} [ifNotSet=false] Merges only if the key is not already set + * @returns {Object.} Destination object + */ +function merge(dst, src, ifNotSet) { // used by converters + for (var keys = Object.keys(src), i = 0; i < keys.length; ++i) + if (dst[keys[i]] === undefined || !ifNotSet) + dst[keys[i]] = src[keys[i]]; + return dst; +} + +util.merge = merge; + +/** + * Converts the first character of a string to lower case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.lcFirst = function lcFirst(str) { + return str.charAt(0).toLowerCase() + str.substring(1); +}; + +/** + * Creates a custom error constructor. + * @memberof util + * @param {string} name Error name + * @returns {Constructor} Custom error constructor + */ +function newError(name) { + + function CustomError(message, properties) { + + if (!(this instanceof CustomError)) + return new CustomError(message, properties); + + // Error.call(this, message); + // ^ just returns a new error instance because the ctor can be called as a function + + Object.defineProperty(this, "message", { get: function() { return message; } }); + + /* istanbul ignore next */ + if (Error.captureStackTrace) // node + Error.captureStackTrace(this, CustomError); + else + Object.defineProperty(this, "stack", { value: (new Error()).stack || "" }); + + if (properties) + merge(this, properties); + } + + (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError; + + Object.defineProperty(CustomError.prototype, "name", { get: function() { return name; } }); + + CustomError.prototype.toString = function toString() { + return this.name + ": " + this.message; + }; + + return CustomError; +} + +util.newError = newError; + +/** + * Constructs a new protocol error. + * @classdesc Error subclass indicating a protocol specifc error. + * @memberof util + * @extends Error + * @template T extends Message + * @constructor + * @param {string} message Error message + * @param {Object.} [properties] Additional properties + * @example + * try { + * MyMessage.decode(someBuffer); // throws if required fields are missing + * } catch (e) { + * if (e instanceof ProtocolError && e.instance) + * console.log("decoded so far: " + JSON.stringify(e.instance)); + * } + */ +util.ProtocolError = newError("ProtocolError"); + +/** + * So far decoded message instance. + * @name util.ProtocolError#instance + * @type {Message} + */ + +/** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @typedef OneOfGetter + * @type {function} + * @returns {string|undefined} Set field name, if any + */ + +/** + * Builds a getter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfGetter} Unbound getter + */ +util.oneOfGetter = function getOneOf(fieldNames) { + var fieldMap = {}; + for (var i = 0; i < fieldNames.length; ++i) + fieldMap[fieldNames[i]] = 1; + + /** + * @returns {string|undefined} Set field name, if any + * @this Object + * @ignore + */ + return function() { // eslint-disable-line consistent-return + for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i) + if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null) + return keys[i]; + }; +}; + +/** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @typedef OneOfSetter + * @type {function} + * @param {string|undefined} value Field name + * @returns {undefined} + */ + +/** + * Builds a setter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfSetter} Unbound setter + */ +util.oneOfSetter = function setOneOf(fieldNames) { + + /** + * @param {string} name Field name + * @returns {undefined} + * @this Object + * @ignore + */ + return function(name) { + for (var i = 0; i < fieldNames.length; ++i) + if (fieldNames[i] !== name) + delete this[fieldNames[i]]; + }; +}; + +/** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @type {IConversionOptions} + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ +util.toJSONOptions = { + longs: String, + enums: String, + bytes: String, + json: true +}; + +// Sets up buffer utility according to the environment (called in index-minimal) +util._configure = function() { + var Buffer = util.Buffer; + /* istanbul ignore if */ + if (!Buffer) { + util._Buffer_from = util._Buffer_allocUnsafe = null; + return; + } + // because node 4.x buffers are incompatible & immutable + // see: https://github.com/dcodeIO/protobuf.js/pull/665 + util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from || + /* istanbul ignore next */ + function Buffer_from(value, encoding) { + return new Buffer(value, encoding); + }; + util._Buffer_allocUnsafe = Buffer.allocUnsafe || + /* istanbul ignore next */ + function Buffer_allocUnsafe(size) { + return new Buffer(size); + }; +}; + +},{"1":1,"10":10,"2":2,"34":34,"4":4,"6":6,"7":7,"9":9}],36:[function(require,module,exports){ +"use strict"; +module.exports = verifier; + +var Enum = require(14), + util = require(33); + +function invalid(field, expected) { + return field.name + ": " + expected + (field.repeated && expected !== "array" ? "[]" : field.map && expected !== "object" ? "{k:"+field.keyType+"}" : "") + " expected"; +} + +/** + * Generates a partial value verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyValue(gen, field, fieldIndex, ref) { + /* eslint-disable no-unexpected-multiline */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(%s){", ref) + ("default:") + ("return%j", invalid(field, "enum value")); + for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen + ("case %i:", field.resolvedType.values[keys[j]]); + gen + ("break") + ("}"); + } else { + gen + ("{") + ("var e=types[%i].verify(%s);", fieldIndex, ref) + ("if(e)") + ("return%j+e", field.name + ".") + ("}"); + } + } else { + switch (field.type) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.isInteger(%s))", ref) + ("return%j", invalid(field, "integer")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))", ref, ref, ref, ref) + ("return%j", invalid(field, "integer|Long")); + break; + case "float": + case "double": gen + ("if(typeof %s!==\"number\")", ref) + ("return%j", invalid(field, "number")); + break; + case "bool": gen + ("if(typeof %s!==\"boolean\")", ref) + ("return%j", invalid(field, "boolean")); + break; + case "string": gen + ("if(!util.isString(%s))", ref) + ("return%j", invalid(field, "string")); + break; + case "bytes": gen + ("if(!(%s&&typeof %s.length===\"number\"||util.isString(%s)))", ref, ref, ref) + ("return%j", invalid(field, "buffer")); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a partial key verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyKey(gen, field, ref) { + /* eslint-disable no-unexpected-multiline */ + switch (field.keyType) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.key32Re.test(%s))", ref) + ("return%j", invalid(field, "integer key")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.key64Re.test(%s))", ref) // see comment above: x is ok, d is not + ("return%j", invalid(field, "integer|Long key")); + break; + case "bool": gen + ("if(!util.key2Re.test(%s))", ref) + ("return%j", invalid(field, "boolean key")); + break; + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a verifier specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function verifier(mtype) { + /* eslint-disable no-unexpected-multiline */ + + var gen = util.codegen(["m"], mtype.name + "$verify") + ("if(typeof m!==\"object\"||m===null)") + ("return%j", "object expected"); + var oneofs = mtype.oneofsArray, + seenFirstField = {}; + if (oneofs.length) gen + ("var p={}"); + + for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + ref = "m" + util.safeProp(field.name); + + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name); // !== undefined && !== null + + // map fields + if (field.map) { gen + ("if(!util.isObject(%s))", ref) + ("return%j", invalid(field, "object")) + ("var k=Object.keys(%s)", ref) + ("for(var i=0;i} + * @const + */ +var wrappers = exports; + +var Message = require(19); + +/** + * From object converter part of an {@link IWrapper}. + * @typedef WrapperFromObjectConverter + * @type {function} + * @param {Object.} object Plain object + * @returns {Message<{}>} Message instance + * @this Type + */ + +/** + * To object converter part of an {@link IWrapper}. + * @typedef WrapperToObjectConverter + * @type {function} + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @this Type + */ + +/** + * Common type wrapper part of {@link wrappers}. + * @interface IWrapper + * @property {WrapperFromObjectConverter} [fromObject] From object converter + * @property {WrapperToObjectConverter} [toObject] To object converter + */ + +// Custom wrapper for Any +wrappers[".google.protobuf.Any"] = { + + fromObject: function(object) { + + // unwrap value type if mapped + if (object && object["@type"]) { + var type = this.lookup(object["@type"]); + /* istanbul ignore else */ + if (type) { + // type_url does not accept leading "." + var type_url = object["@type"].charAt(0) === "." ? + object["@type"].substr(1) : object["@type"]; + // type_url prefix is optional, but path seperator is required + return this.create({ + type_url: "/" + type_url, + value: type.encode(type.fromObject(object)).finish() + }); + } + } + + return this.fromObject(object); + }, + + toObject: function(message, options) { + + // decode value if requested and unmapped + if (options && options.json && message.type_url && message.value) { + // Only use fully qualified type name after the last '/' + var name = message.type_url.substring(message.type_url.lastIndexOf("/") + 1); + var type = this.lookup(name); + /* istanbul ignore else */ + if (type) + message = type.decode(message.value); + } + + // wrap value if unmapped + if (!(message instanceof this.ctor) && message instanceof Message) { + var object = message.$type.toObject(message, options); + object["@type"] = message.$type.fullName; + return object; + } + + return this.toObject(message, options); + } +}; + +},{"19":19}],38:[function(require,module,exports){ +"use strict"; +module.exports = Writer; + +var util = require(35); + +var BufferWriter; // cyclic + +var LongBits = util.LongBits, + base64 = util.base64, + utf8 = util.utf8; + +/** + * Constructs a new writer operation instance. + * @classdesc Scheduled writer operation. + * @constructor + * @param {function(*, Uint8Array, number)} fn Function to call + * @param {number} len Value byte length + * @param {*} val Value to write + * @ignore + */ +function Op(fn, len, val) { + + /** + * Function to call. + * @type {function(Uint8Array, number, *)} + */ + this.fn = fn; + + /** + * Value byte length. + * @type {number} + */ + this.len = len; + + /** + * Next operation. + * @type {Writer.Op|undefined} + */ + this.next = undefined; + + /** + * Value to write. + * @type {*} + */ + this.val = val; // type varies +} + +/* istanbul ignore next */ +function noop() {} // eslint-disable-line no-empty-function + +/** + * Constructs a new writer state instance. + * @classdesc Copied writer state. + * @memberof Writer + * @constructor + * @param {Writer} writer Writer to copy state from + * @ignore + */ +function State(writer) { + + /** + * Current head. + * @type {Writer.Op} + */ + this.head = writer.head; + + /** + * Current tail. + * @type {Writer.Op} + */ + this.tail = writer.tail; + + /** + * Current buffer length. + * @type {number} + */ + this.len = writer.len; + + /** + * Next state. + * @type {State|null} + */ + this.next = writer.states; +} + +/** + * Constructs a new writer instance. + * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`. + * @constructor + */ +function Writer() { + + /** + * Current length. + * @type {number} + */ + this.len = 0; + + /** + * Operations head. + * @type {Object} + */ + this.head = new Op(noop, 0, 0); + + /** + * Operations tail + * @type {Object} + */ + this.tail = this.head; + + /** + * Linked forked states. + * @type {Object|null} + */ + this.states = null; + + // When a value is written, the writer calculates its byte length and puts it into a linked + // list of operations to perform when finish() is called. This both allows us to allocate + // buffers of the exact required size and reduces the amount of work we have to do compared + // to first calculating over objects and then encoding over objects. In our case, the encoding + // part is just a linked list walk calling operations with already prepared values. +} + +/** + * Creates a new writer. + * @function + * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ +Writer.create = util.Buffer + ? function create_buffer_setup() { + return (Writer.create = function create_buffer() { + return new BufferWriter(); + })(); + } + /* istanbul ignore next */ + : function create_array() { + return new Writer(); + }; + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ +Writer.alloc = function alloc(size) { + return new util.Array(size); +}; + +// Use Uint8Array buffer pool in the browser, just like node does with buffers +/* istanbul ignore else */ +if (util.Array !== Array) + Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray); + +/** + * Pushes a new operation to the queue. + * @param {function(Uint8Array, number, *)} fn Function to call + * @param {number} len Value byte length + * @param {number} val Value to write + * @returns {Writer} `this` + * @private + */ +Writer.prototype._push = function push(fn, len, val) { + this.tail = this.tail.next = new Op(fn, len, val); + this.len += len; + return this; +}; + +function writeByte(val, buf, pos) { + buf[pos] = val & 255; +} + +function writeVarint32(val, buf, pos) { + while (val > 127) { + buf[pos++] = val & 127 | 128; + val >>>= 7; + } + buf[pos] = val; +} + +/** + * Constructs a new varint writer operation instance. + * @classdesc Scheduled varint writer operation. + * @extends Op + * @constructor + * @param {number} len Value byte length + * @param {number} val Value to write + * @ignore + */ +function VarintOp(len, val) { + this.len = len; + this.next = undefined; + this.val = val; +} + +VarintOp.prototype = Object.create(Op.prototype); +VarintOp.prototype.fn = writeVarint32; + +/** + * Writes an unsigned 32 bit value as a varint. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.uint32 = function write_uint32(value) { + // here, the call to this.push has been inlined and a varint specific Op subclass is used. + // uint32 is by far the most frequently used operation and benefits significantly from this. + this.len += (this.tail = this.tail.next = new VarintOp( + (value = value >>> 0) + < 128 ? 1 + : value < 16384 ? 2 + : value < 2097152 ? 3 + : value < 268435456 ? 4 + : 5, + value)).len; + return this; +}; + +/** + * Writes a signed 32 bit value as a varint. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.int32 = function write_int32(value) { + return value < 0 + ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec + : this.uint32(value); +}; + +/** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sint32 = function write_sint32(value) { + return this.uint32((value << 1 ^ value >> 31) >>> 0); +}; + +function writeVarint64(val, buf, pos) { + while (val.hi) { + buf[pos++] = val.lo & 127 | 128; + val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0; + val.hi >>>= 7; + } + while (val.lo > 127) { + buf[pos++] = val.lo & 127 | 128; + val.lo = val.lo >>> 7; + } + buf[pos++] = val.lo; +} + +/** + * Writes an unsigned 64 bit value as a varint. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.uint64 = function write_uint64(value) { + var bits = LongBits.from(value); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a signed 64 bit value as a varint. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.int64 = Writer.prototype.uint64; + +/** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sint64 = function write_sint64(value) { + var bits = LongBits.from(value).zzEncode(); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a boolish value as a varint. + * @param {boolean} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.bool = function write_bool(value) { + return this._push(writeByte, 1, value ? 1 : 0); +}; + +function writeFixed32(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +/** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.fixed32 = function write_fixed32(value) { + return this._push(writeFixed32, 4, value >>> 0); +}; + +/** + * Writes a signed 32 bit value as fixed 32 bits. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sfixed32 = Writer.prototype.fixed32; + +/** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.fixed64 = function write_fixed64(value) { + var bits = LongBits.from(value); + return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi); +}; + +/** + * Writes a signed 64 bit value as fixed 64 bits. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sfixed64 = Writer.prototype.fixed64; + +/** + * Writes a float (32 bit). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.float = function write_float(value) { + return this._push(util.float.writeFloatLE, 4, value); +}; + +/** + * Writes a double (64 bit float). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.double = function write_double(value) { + return this._push(util.float.writeDoubleLE, 8, value); +}; + +var writeBytes = util.Array.prototype.set + ? function writeBytes_set(val, buf, pos) { + buf.set(val, pos); // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytes_for(val, buf, pos) { + for (var i = 0; i < val.length; ++i) + buf[pos + i] = val[i]; + }; + +/** + * Writes a sequence of bytes. + * @param {Uint8Array|string} value Buffer or base64 encoded string to write + * @returns {Writer} `this` + */ +Writer.prototype.bytes = function write_bytes(value) { + var len = value.length >>> 0; + if (!len) + return this._push(writeByte, 1, 0); + if (util.isString(value)) { + var buf = Writer.alloc(len = base64.length(value)); + base64.decode(value, buf, 0); + value = buf; + } + return this.uint32(len)._push(writeBytes, len, value); +}; + +/** + * Writes a string. + * @param {string} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.string = function write_string(value) { + var len = utf8.length(value); + return len + ? this.uint32(len)._push(utf8.write, len, value) + : this._push(writeByte, 1, 0); +}; + +/** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns {Writer} `this` + */ +Writer.prototype.fork = function fork() { + this.states = new State(this); + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + return this; +}; + +/** + * Resets this instance to the last state. + * @returns {Writer} `this` + */ +Writer.prototype.reset = function reset() { + if (this.states) { + this.head = this.states.head; + this.tail = this.states.tail; + this.len = this.states.len; + this.states = this.states.next; + } else { + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + } + return this; +}; + +/** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns {Writer} `this` + */ +Writer.prototype.ldelim = function ldelim() { + var head = this.head, + tail = this.tail, + len = this.len; + this.reset().uint32(len); + if (len) { + this.tail.next = head.next; // skip noop + this.tail = tail; + this.len += len; + } + return this; +}; + +/** + * Finishes the write operation. + * @returns {Uint8Array} Finished buffer + */ +Writer.prototype.finish = function finish() { + var head = this.head.next, // skip noop + buf = this.constructor.alloc(this.len), + pos = 0; + while (head) { + head.fn(head.val, buf, pos); + pos += head.len; + head = head.next; + } + // this.head = this.tail = null; + return buf; +}; + +Writer._configure = function(BufferWriter_) { + BufferWriter = BufferWriter_; +}; + +},{"35":35}],39:[function(require,module,exports){ +"use strict"; +module.exports = BufferWriter; + +// extends Writer +var Writer = require(38); +(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter; + +var util = require(35); + +var Buffer = util.Buffer; + +/** + * Constructs a new buffer writer instance. + * @classdesc Wire format writer using node buffers. + * @extends Writer + * @constructor + */ +function BufferWriter() { + Writer.call(this); +} + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Buffer} Buffer + */ +BufferWriter.alloc = function alloc_buffer(size) { + return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size); +}; + +var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set" + ? function writeBytesBuffer_set(val, buf, pos) { + buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited) + // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytesBuffer_copy(val, buf, pos) { + if (val.copy) // Buffer values + val.copy(buf, pos, 0, val.length); + else for (var i = 0; i < val.length;) // plain array values + buf[pos++] = val[i++]; + }; + +/** + * @override + */ +BufferWriter.prototype.bytes = function write_bytes_buffer(value) { + if (util.isString(value)) + value = util._Buffer_from(value, "base64"); + var len = value.length >>> 0; + this.uint32(len); + if (len) + this._push(writeBytesBuffer, len, value); + return this; +}; + +function writeStringBuffer(val, buf, pos) { + if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions) + util.utf8.write(val, buf, pos); + else + buf.utf8Write(val, pos); +} + +/** + * @override + */ +BufferWriter.prototype.string = function write_string_buffer(value) { + var len = Buffer.byteLength(value); + this.uint32(len); + if (len) + this._push(writeStringBuffer, len, value); + return this; +}; + + +/** + * Finishes the write operation. + * @name BufferWriter#finish + * @function + * @returns {Buffer} Finished buffer + */ + +},{"35":35,"38":38}]},{},[16]) + +})(); +//# sourceMappingURL=protobuf.js.map diff --git a/node_modules/protobufjs/dist/light/protobuf.js.map b/node_modules/protobufjs/dist/light/protobuf.js.map new file mode 100644 index 0000000..d8b0ebc --- /dev/null +++ b/node_modules/protobufjs/dist/light/protobuf.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/codegen/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/fetch/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/path/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/converter.js","../src/decoder.js","../src/encoder.js","../src/enum.js","../src/field.js","../src/index-light","../src/index-minimal.js","../src/mapfield.js","../src/message.js","../src/method.js","../src/namespace.js","../src/object.js","../src/oneof.js","../src/reader.js","../src/reader_buffer.js","../src/root.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/service.js","../src/type.js","../src/types.js","../src/util.js","../src/util/longbits.js","../src/util/minimal.js","../src/verifier.js","../src/wrappers.js","../src/writer.js","../src/writer_buffer.js"],"names":[],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3cA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"protobuf.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = codegen;\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @param {string[]} functionParams Function parameter names\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n */\r\nfunction codegen(functionParams, functionName) {\r\n\r\n /* istanbul ignore if */\r\n if (typeof functionParams === \"string\") {\r\n functionName = functionParams;\r\n functionParams = undefined;\r\n }\r\n\r\n var body = [];\r\n\r\n /**\r\n * Appends code to the function's body or finishes generation.\r\n * @typedef Codegen\r\n * @type {function}\r\n * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any\r\n * @param {...*} [formatParams] Format parameters\r\n * @returns {Codegen|Function} Itself or the generated function if finished\r\n * @throws {Error} If format parameter counts do not match\r\n */\r\n\r\n function Codegen(formatStringOrScope) {\r\n // note that explicit array handling below makes this ~50% faster\r\n\r\n // finish the function\r\n if (typeof formatStringOrScope !== \"string\") {\r\n var source = toString();\r\n if (codegen.verbose)\r\n console.log(\"codegen: \" + source); // eslint-disable-line no-console\r\n source = \"return \" + source;\r\n if (formatStringOrScope) {\r\n var scopeKeys = Object.keys(formatStringOrScope),\r\n scopeParams = new Array(scopeKeys.length + 1),\r\n scopeValues = new Array(scopeKeys.length),\r\n scopeOffset = 0;\r\n while (scopeOffset < scopeKeys.length) {\r\n scopeParams[scopeOffset] = scopeKeys[scopeOffset];\r\n scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]];\r\n }\r\n scopeParams[scopeOffset] = source;\r\n return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func\r\n }\r\n return Function(source)(); // eslint-disable-line no-new-func\r\n }\r\n\r\n // otherwise append to body\r\n var formatParams = new Array(arguments.length - 1),\r\n formatOffset = 0;\r\n while (formatOffset < formatParams.length)\r\n formatParams[formatOffset] = arguments[++formatOffset];\r\n formatOffset = 0;\r\n formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) {\r\n var value = formatParams[formatOffset++];\r\n switch ($1) {\r\n case \"d\": case \"f\": return String(Number(value));\r\n case \"i\": return String(Math.floor(value));\r\n case \"j\": return JSON.stringify(value);\r\n case \"s\": return String(value);\r\n }\r\n return \"%\";\r\n });\r\n if (formatOffset !== formatParams.length)\r\n throw Error(\"parameter count mismatch\");\r\n body.push(formatStringOrScope);\r\n return Codegen;\r\n }\r\n\r\n function toString(functionNameOverride) {\r\n return \"function \" + (functionNameOverride || functionName || \"\") + \"(\" + (functionParams && functionParams.join(\",\") || \"\") + \"){\\n \" + body.join(\"\\n \") + \"\\n}\";\r\n }\r\n\r\n Codegen.toString = toString;\r\n return Codegen;\r\n}\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @function codegen\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * When set to `true`, codegen will log generated code to console. Useful for debugging.\r\n * @name util.codegen.verbose\r\n * @type {boolean}\r\n */\r\ncodegen.verbose = false;\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = fetch;\r\n\r\nvar asPromise = require(1),\r\n inquire = require(7);\r\n\r\nvar fs = inquire(\"fs\");\r\n\r\n/**\r\n * Node-style callback as used by {@link util.fetch}.\r\n * @typedef FetchCallback\r\n * @type {function}\r\n * @param {?Error} error Error, if any, otherwise `null`\r\n * @param {string} [contents] File contents, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Options as used by {@link util.fetch}.\r\n * @typedef FetchOptions\r\n * @type {Object}\r\n * @property {boolean} [binary=false] Whether expecting a binary response\r\n * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @memberof util\r\n * @param {string} filename File path or url\r\n * @param {FetchOptions} options Fetch options\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nfunction fetch(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = {};\r\n } else if (!options)\r\n options = {};\r\n\r\n if (!callback)\r\n return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this\r\n\r\n // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found.\r\n if (!options.xhr && fs && fs.readFile)\r\n return fs.readFile(filename, function fetchReadFileCallback(err, contents) {\r\n return err && typeof XMLHttpRequest !== \"undefined\"\r\n ? fetch.xhr(filename, options, callback)\r\n : err\r\n ? callback(err)\r\n : callback(null, options.binary ? contents : contents.toString(\"utf8\"));\r\n });\r\n\r\n // use the XHR version otherwise.\r\n return fetch.xhr(filename, options, callback);\r\n}\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchOptions} [options] Fetch options\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n\r\n/**/\r\nfetch.xhr = function fetch_xhr(filename, options, callback) {\r\n var xhr = new XMLHttpRequest();\r\n xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() {\r\n\r\n if (xhr.readyState !== 4)\r\n return undefined;\r\n\r\n // local cors security errors return status 0 / empty string, too. afaik this cannot be\r\n // reliably distinguished from an actually empty file for security reasons. feel free\r\n // to send a pull request if you are aware of a solution.\r\n if (xhr.status !== 0 && xhr.status !== 200)\r\n return callback(Error(\"status \" + xhr.status));\r\n\r\n // if binary data is expected, make sure that some sort of array is returned, even if\r\n // ArrayBuffers are not supported. the binary string fallback, however, is unsafe.\r\n if (options.binary) {\r\n var buffer = xhr.response;\r\n if (!buffer) {\r\n buffer = [];\r\n for (var i = 0; i < xhr.responseText.length; ++i)\r\n buffer.push(xhr.responseText.charCodeAt(i) & 255);\r\n }\r\n return callback(null, typeof Uint8Array !== \"undefined\" ? new Uint8Array(buffer) : buffer);\r\n }\r\n return callback(null, xhr.responseText);\r\n };\r\n\r\n if (options.binary) {\r\n // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers\r\n if (\"overrideMimeType\" in xhr)\r\n xhr.overrideMimeType(\"text/plain; charset=x-user-defined\");\r\n xhr.responseType = \"arraybuffer\";\r\n }\r\n\r\n xhr.open(\"GET\", filename);\r\n xhr.send();\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal path module to resolve Unix, Windows and URL paths alike.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar path = exports;\r\n\r\nvar isAbsolute =\r\n/**\r\n * Tests if the specified path is absolute.\r\n * @param {string} path Path to test\r\n * @returns {boolean} `true` if path is absolute\r\n */\r\npath.isAbsolute = function isAbsolute(path) {\r\n return /^(?:\\/|\\w+:)/.test(path);\r\n};\r\n\r\nvar normalize =\r\n/**\r\n * Normalizes the specified path.\r\n * @param {string} path Path to normalize\r\n * @returns {string} Normalized path\r\n */\r\npath.normalize = function normalize(path) {\r\n path = path.replace(/\\\\/g, \"/\")\r\n .replace(/\\/{2,}/g, \"/\");\r\n var parts = path.split(\"/\"),\r\n absolute = isAbsolute(path),\r\n prefix = \"\";\r\n if (absolute)\r\n prefix = parts.shift() + \"/\";\r\n for (var i = 0; i < parts.length;) {\r\n if (parts[i] === \"..\") {\r\n if (i > 0 && parts[i - 1] !== \"..\")\r\n parts.splice(--i, 2);\r\n else if (absolute)\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n } else if (parts[i] === \".\")\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n return prefix + parts.join(\"/\");\r\n};\r\n\r\n/**\r\n * Resolves the specified include path against the specified origin path.\r\n * @param {string} originPath Path to the origin file\r\n * @param {string} includePath Include path relative to origin path\r\n * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized\r\n * @returns {string} Path to the include file\r\n */\r\npath.resolve = function resolve(originPath, includePath, alreadyNormalized) {\r\n if (!alreadyNormalized)\r\n includePath = normalize(includePath);\r\n if (isAbsolute(includePath))\r\n return includePath;\r\n if (!alreadyNormalized)\r\n originPath = normalize(originPath);\r\n return (originPath = originPath.replace(/(?:\\/|^)[^/]+$/, \"\")).length ? normalize(originPath + \"/\" + includePath) : includePath;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\n/**\r\n * Runtime message from/to plain object converters.\r\n * @namespace\r\n */\r\nvar converter = exports;\r\n\r\nvar Enum = require(14),\r\n util = require(33);\r\n\r\n/**\r\n * Generates a partial value fromObject conveter.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} prop Property reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genValuePartial_fromObject(gen, field, fieldIndex, prop) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(d%s){\", prop);\r\n for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) {\r\n if (field.repeated && values[keys[i]] === field.typeDefault) gen\r\n (\"default:\");\r\n gen\r\n (\"case%j:\", keys[i])\r\n (\"case %i:\", values[keys[i]])\r\n (\"m%s=%j\", prop, values[keys[i]])\r\n (\"break\");\r\n } gen\r\n (\"}\");\r\n } else gen\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s=types[%i].fromObject(d%s)\", prop, fieldIndex, prop);\r\n } else {\r\n var isUnsigned = false;\r\n switch (field.type) {\r\n case \"double\":\r\n case \"float\": gen\r\n (\"m%s=Number(d%s)\", prop, prop); // also catches \"NaN\", \"Infinity\"\r\n break;\r\n case \"uint32\":\r\n case \"fixed32\": gen\r\n (\"m%s=d%s>>>0\", prop, prop);\r\n break;\r\n case \"int32\":\r\n case \"sint32\":\r\n case \"sfixed32\": gen\r\n (\"m%s=d%s|0\", prop, prop);\r\n break;\r\n case \"uint64\":\r\n isUnsigned = true;\r\n // eslint-disable-line no-fallthrough\r\n case \"int64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(util.Long)\")\r\n (\"(m%s=util.Long.fromValue(d%s)).unsigned=%j\", prop, prop, isUnsigned)\r\n (\"else if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"m%s=parseInt(d%s,10)\", prop, prop)\r\n (\"else if(typeof d%s===\\\"number\\\")\", prop)\r\n (\"m%s=d%s\", prop, prop)\r\n (\"else if(typeof d%s===\\\"object\\\")\", prop)\r\n (\"m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)\", prop, prop, prop, isUnsigned ? \"true\" : \"\");\r\n break;\r\n case \"bytes\": gen\r\n (\"if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)\", prop, prop, prop)\r\n (\"else if(d%s.length)\", prop)\r\n (\"m%s=d%s\", prop, prop);\r\n break;\r\n case \"string\": gen\r\n (\"m%s=String(d%s)\", prop, prop);\r\n break;\r\n case \"bool\": gen\r\n (\"m%s=Boolean(d%s)\", prop, prop);\r\n break;\r\n /* default: gen\r\n (\"m%s=d%s\", prop, prop);\r\n break; */\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a plain object to runtime message converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.fromObject = function fromObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray;\r\n var gen = util.codegen([\"d\"], mtype.name + \"$fromObject\")\r\n (\"if(d instanceof this.ctor)\")\r\n (\"return d\");\r\n if (!fields.length) return gen\r\n (\"return new this.ctor\");\r\n gen\r\n (\"var m=new this.ctor\");\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n prop = util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"if(d%s){\", prop)\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s={}\", prop)\r\n (\"for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s\", prop, prop, prop, prop, isUnsigned ? \"true\": \"\", prop);\r\n break;\r\n case \"bytes\": gen\r\n (\"d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s\", prop, prop, prop, prop, prop);\r\n break;\r\n default: gen\r\n (\"d%s=m%s\", prop, prop);\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a runtime message to plain object converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.toObject = function toObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n if (!fields.length)\r\n return util.codegen()(\"return {}\");\r\n var gen = util.codegen([\"m\", \"o\"], mtype.name + \"$toObject\")\r\n (\"if(!o)\")\r\n (\"o={}\")\r\n (\"var d={}\");\r\n\r\n var repeatedFields = [],\r\n mapFields = [],\r\n normalFields = [],\r\n i = 0;\r\n for (; i < fields.length; ++i)\r\n if (!fields[i].partOf)\r\n ( fields[i].resolve().repeated ? repeatedFields\r\n : fields[i].map ? mapFields\r\n : normalFields).push(fields[i]);\r\n\r\n if (repeatedFields.length) { gen\r\n (\"if(o.arrays||o.defaults){\");\r\n for (i = 0; i < repeatedFields.length; ++i) gen\r\n (\"d%s=[]\", util.safeProp(repeatedFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (mapFields.length) { gen\r\n (\"if(o.objects||o.defaults){\");\r\n for (i = 0; i < mapFields.length; ++i) gen\r\n (\"d%s={}\", util.safeProp(mapFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (normalFields.length) { gen\r\n (\"if(o.defaults){\");\r\n for (i = 0; i < normalFields.length; ++i) {\r\n var field = normalFields[i],\r\n prop = util.safeProp(field.name);\r\n if (field.resolvedType instanceof Enum) gen\r\n (\"d%s=o.enums===String?%j:%j\", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault);\r\n else if (field.long) gen\r\n (\"if(util.Long){\")\r\n (\"var n=new util.Long(%i,%i,%j)\", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned)\r\n (\"d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n\", prop)\r\n (\"}else\")\r\n (\"d%s=o.longs===String?%j:%i\", prop, field.typeDefault.toString(), field.typeDefault.toNumber());\r\n else if (field.bytes) {\r\n var arrayDefault = \"[\" + Array.prototype.slice.call(field.typeDefault).join(\",\") + \"]\";\r\n gen\r\n (\"if(o.bytes===String)d%s=%j\", prop, String.fromCharCode.apply(String, field.typeDefault))\r\n (\"else{\")\r\n (\"d%s=%s\", prop, arrayDefault)\r\n (\"if(o.bytes!==Array)d%s=util.newBuffer(d%s)\", prop, prop)\r\n (\"}\");\r\n } else gen\r\n (\"d%s=%j\", prop, field.typeDefault); // also messages (=null)\r\n } gen\r\n (\"}\");\r\n }\r\n var hasKs2 = false;\r\n for (i = 0; i < fields.length; ++i) {\r\n var field = fields[i],\r\n index = mtype._fieldsArray.indexOf(field),\r\n prop = util.safeProp(field.name);\r\n if (field.map) {\r\n if (!hasKs2) { hasKs2 = true; gen\r\n (\"var ks2\");\r\n } gen\r\n (\"if(m%s&&(ks2=Object.keys(m%s)).length){\", prop, prop)\r\n (\"d%s={}\", prop)\r\n (\"for(var j=0;j>>3){\");\r\n\r\n var i = 0;\r\n for (; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n ref = \"m\" + util.safeProp(field.name); gen\r\n (\"case %i:\", field.id);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"r.skip().pos++\") // assumes id 1 + key wireType\r\n (\"if(%s===util.emptyObject)\", ref)\r\n (\"%s={}\", ref)\r\n (\"k=r.%s()\", field.keyType)\r\n (\"r.pos++\"); // assumes id 2 + value wireType\r\n if (types.long[field.keyType] !== undefined) {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=r.%s()\", ref, type);\r\n } else {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[k]=r.%s()\", ref, type);\r\n }\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n\r\n (\"if(!(%s&&%s.length))\", ref, ref)\r\n (\"%s=[]\", ref);\r\n\r\n // Packable (always check for forward and backward compatiblity)\r\n if (types.packed[type] !== undefined) gen\r\n (\"if((t&7)===2){\")\r\n (\"var c2=r.uint32()+r.pos\")\r\n (\"while(r.pos>> 0, (field.id << 3 | 4) >>> 0)\r\n : gen(\"types[%i].encode(%s,w.uint32(%i).fork()).ldelim()\", fieldIndex, ref, (field.id << 3 | 2) >>> 0);\r\n}\r\n\r\n/**\r\n * Generates an encoder specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction encoder(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var gen = util.codegen([\"m\", \"w\"], mtype.name + \"$encode\")\r\n (\"if(!w)\")\r\n (\"w=Writer.create()\");\r\n\r\n var i, ref;\r\n\r\n // \"when a message is serialized its known fields should be written sequentially by field number\"\r\n var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n index = mtype._fieldsArray.indexOf(field),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n wireType = types.basic[type];\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) {\r\n gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name) // !== undefined && !== null\r\n (\"for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType);\r\n if (wireType === undefined) gen\r\n (\"types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()\", index, ref); // can't be groups\r\n else gen\r\n (\".uint32(%i).%s(%s[ks[i]]).ldelim()\", 16 | wireType, type, ref);\r\n gen\r\n (\"}\")\r\n (\"}\");\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n (\"if(%s!=null&&%s.length){\", ref, ref); // !== undefined && !== null\r\n\r\n // Packed repeated\r\n if (field.packed && types.packed[type] !== undefined) { gen\r\n\r\n (\"w.uint32(%i).fork()\", (field.id << 3 | 2) >>> 0)\r\n (\"for(var i=0;i<%s.length;++i)\", ref)\r\n (\"w.%s(%s[i])\", type, ref)\r\n (\"w.ldelim()\");\r\n\r\n // Non-packed\r\n } else { gen\r\n\r\n (\"for(var i=0;i<%s.length;++i)\", ref);\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref + \"[i]\");\r\n else gen\r\n (\"w.uint32(%i).%s(%s[i])\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n } gen\r\n (\"}\");\r\n\r\n // Non-repeated\r\n } else {\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j))\", ref, field.name); // !== undefined && !== null\r\n\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref);\r\n else gen\r\n (\"w.uint32(%i).%s(%s)\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n }\r\n }\r\n\r\n return gen\r\n (\"return w\");\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}","\"use strict\";\r\nmodule.exports = Enum;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = \"Enum\";\r\n\r\nvar Namespace = require(21),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new enum instance.\r\n * @classdesc Reflected enum.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {Object.} [values] Enum values as an object, by name\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this enum\r\n * @param {Object.} [comments] The value comments for this enum\r\n */\r\nfunction Enum(name, values, options, comment, comments) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (values && typeof values !== \"object\")\r\n throw TypeError(\"values must be an object\");\r\n\r\n /**\r\n * Enum values by id.\r\n * @type {Object.}\r\n */\r\n this.valuesById = {};\r\n\r\n /**\r\n * Enum values by name.\r\n * @type {Object.}\r\n */\r\n this.values = Object.create(this.valuesById); // toJSON, marker\r\n\r\n /**\r\n * Enum comment text.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n\r\n /**\r\n * Value comment texts, if any.\r\n * @type {Object.}\r\n */\r\n this.comments = comments || {};\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n // Note that values inherit valuesById on their prototype which makes them a TypeScript-\r\n // compatible enum. This is used by pbts to write actual enum definitions that work for\r\n // static and reflection code alike instead of emitting generic object definitions.\r\n\r\n if (values)\r\n for (var keys = Object.keys(values), i = 0; i < keys.length; ++i)\r\n if (typeof values[keys[i]] === \"number\") // use forward entries only\r\n this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i];\r\n}\r\n\r\n/**\r\n * Enum descriptor.\r\n * @interface IEnum\r\n * @property {Object.} values Enum values\r\n * @property {Object.} [options] Enum options\r\n */\r\n\r\n/**\r\n * Constructs an enum from an enum descriptor.\r\n * @param {string} name Enum name\r\n * @param {IEnum} json Enum descriptor\r\n * @returns {Enum} Created enum\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nEnum.fromJSON = function fromJSON(name, json) {\r\n var enm = new Enum(name, json.values, json.options, json.comment, json.comments);\r\n enm.reserved = json.reserved;\r\n return enm;\r\n};\r\n\r\n/**\r\n * Converts this enum to an enum descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IEnum} Enum descriptor\r\n */\r\nEnum.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"values\" , this.values,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"comment\" , keepComments ? this.comment : undefined,\r\n \"comments\" , keepComments ? this.comments : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds a value to this enum.\r\n * @param {string} name Value name\r\n * @param {number} id Value id\r\n * @param {string} [comment] Comment, if any\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a value with this name or id\r\n */\r\nEnum.prototype.add = function add(name, id, comment) {\r\n // utilized by the parser but not by .fromJSON\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (!util.isInteger(id))\r\n throw TypeError(\"id must be an integer\");\r\n\r\n if (this.values[name] !== undefined)\r\n throw Error(\"duplicate name '\" + name + \"' in \" + this);\r\n\r\n if (this.isReservedId(id))\r\n throw Error(\"id \" + id + \" is reserved in \" + this);\r\n\r\n if (this.isReservedName(name))\r\n throw Error(\"name '\" + name + \"' is reserved in \" + this);\r\n\r\n if (this.valuesById[id] !== undefined) {\r\n if (!(this.options && this.options.allow_alias))\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n this.values[name] = id;\r\n } else\r\n this.valuesById[this.values[name] = id] = name;\r\n\r\n this.comments[name] = comment || null;\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a value from this enum\r\n * @param {string} name Value name\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `name` is not a name of this enum\r\n */\r\nEnum.prototype.remove = function remove(name) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n var val = this.values[name];\r\n if (val == null)\r\n throw Error(\"name '\" + name + \"' does not exist in \" + this);\r\n\r\n delete this.valuesById[val];\r\n delete this.values[name];\r\n delete this.comments[name];\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Field;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = \"Field\";\r\n\r\nvar Enum = require(14),\r\n types = require(32),\r\n util = require(33);\r\n\r\nvar Type; // cyclic\r\n\r\nvar ruleRe = /^required|optional|repeated$/;\r\n\r\n/**\r\n * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.\r\n * @name Field\r\n * @classdesc Reflected message field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a field from a field descriptor.\r\n * @param {string} name Field name\r\n * @param {IField} json Field descriptor\r\n * @returns {Field} Created field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nField.fromJSON = function fromJSON(name, json) {\r\n return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Field} instead.\r\n * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports FieldBase\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction Field(name, id, type, rule, extend, options, comment) {\r\n\r\n if (util.isObject(rule)) {\r\n comment = extend;\r\n options = rule;\r\n rule = extend = undefined;\r\n } else if (util.isObject(extend)) {\r\n comment = options;\r\n options = extend;\r\n extend = undefined;\r\n }\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (!util.isInteger(id) || id < 0)\r\n throw TypeError(\"id must be a non-negative integer\");\r\n\r\n if (!util.isString(type))\r\n throw TypeError(\"type must be a string\");\r\n\r\n if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))\r\n throw TypeError(\"rule must be a string rule\");\r\n\r\n if (extend !== undefined && !util.isString(extend))\r\n throw TypeError(\"extend must be a string\");\r\n\r\n /**\r\n * Field rule, if any.\r\n * @type {string|undefined}\r\n */\r\n this.rule = rule && rule !== \"optional\" ? rule : undefined; // toJSON\r\n\r\n /**\r\n * Field type.\r\n * @type {string}\r\n */\r\n this.type = type; // toJSON\r\n\r\n /**\r\n * Unique field id.\r\n * @type {number}\r\n */\r\n this.id = id; // toJSON, marker\r\n\r\n /**\r\n * Extended type if different from parent.\r\n * @type {string|undefined}\r\n */\r\n this.extend = extend || undefined; // toJSON\r\n\r\n /**\r\n * Whether this field is required.\r\n * @type {boolean}\r\n */\r\n this.required = rule === \"required\";\r\n\r\n /**\r\n * Whether this field is optional.\r\n * @type {boolean}\r\n */\r\n this.optional = !this.required;\r\n\r\n /**\r\n * Whether this field is repeated.\r\n * @type {boolean}\r\n */\r\n this.repeated = rule === \"repeated\";\r\n\r\n /**\r\n * Whether this field is a map or not.\r\n * @type {boolean}\r\n */\r\n this.map = false;\r\n\r\n /**\r\n * Message this field belongs to.\r\n * @type {Type|null}\r\n */\r\n this.message = null;\r\n\r\n /**\r\n * OneOf this field belongs to, if any,\r\n * @type {OneOf|null}\r\n */\r\n this.partOf = null;\r\n\r\n /**\r\n * The field type's default value.\r\n * @type {*}\r\n */\r\n this.typeDefault = null;\r\n\r\n /**\r\n * The field's default value on prototypes.\r\n * @type {*}\r\n */\r\n this.defaultValue = null;\r\n\r\n /**\r\n * Whether this field's value should be treated as a long.\r\n * @type {boolean}\r\n */\r\n this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;\r\n\r\n /**\r\n * Whether this field's value is a buffer.\r\n * @type {boolean}\r\n */\r\n this.bytes = type === \"bytes\";\r\n\r\n /**\r\n * Resolved type if not a basic type.\r\n * @type {Type|Enum|null}\r\n */\r\n this.resolvedType = null;\r\n\r\n /**\r\n * Sister-field within the extended type if a declaring extension field.\r\n * @type {Field|null}\r\n */\r\n this.extensionField = null;\r\n\r\n /**\r\n * Sister-field within the declaring namespace if an extended field.\r\n * @type {Field|null}\r\n */\r\n this.declaringField = null;\r\n\r\n /**\r\n * Internally remembers whether this field is packed.\r\n * @type {boolean|null}\r\n * @private\r\n */\r\n this._packed = null;\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Determines whether this field is packed. Only relevant when repeated and working with proto2.\r\n * @name Field#packed\r\n * @type {boolean}\r\n * @readonly\r\n */\r\nObject.defineProperty(Field.prototype, \"packed\", {\r\n get: function() {\r\n // defaults to packed=true if not explicity set to false\r\n if (this._packed === null)\r\n this._packed = this.getOption(\"packed\") !== false;\r\n return this._packed;\r\n }\r\n});\r\n\r\n/**\r\n * @override\r\n */\r\nField.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (name === \"packed\") // clear cached before setting\r\n this._packed = null;\r\n return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);\r\n};\r\n\r\n/**\r\n * Field descriptor.\r\n * @interface IField\r\n * @property {string} [rule=\"optional\"] Field rule\r\n * @property {string} type Field type\r\n * @property {number} id Field id\r\n * @property {Object.} [options] Field options\r\n */\r\n\r\n/**\r\n * Extension field descriptor.\r\n * @interface IExtensionField\r\n * @extends IField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Converts this field to a field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IField} Field descriptor\r\n */\r\nField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"rule\" , this.rule !== \"optional\" && this.rule || undefined,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Resolves this field's type references.\r\n * @returns {Field} `this`\r\n * @throws {Error} If any reference cannot be resolved\r\n */\r\nField.prototype.resolve = function resolve() {\r\n\r\n if (this.resolved)\r\n return this;\r\n\r\n if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it\r\n this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);\r\n if (this.resolvedType instanceof Type)\r\n this.typeDefault = null;\r\n else // instanceof Enum\r\n this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined\r\n }\r\n\r\n // use explicitly set default value if present\r\n if (this.options && this.options[\"default\"] != null) {\r\n this.typeDefault = this.options[\"default\"];\r\n if (this.resolvedType instanceof Enum && typeof this.typeDefault === \"string\")\r\n this.typeDefault = this.resolvedType.values[this.typeDefault];\r\n }\r\n\r\n // remove unnecessary options\r\n if (this.options) {\r\n if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))\r\n delete this.options.packed;\r\n if (!Object.keys(this.options).length)\r\n this.options = undefined;\r\n }\r\n\r\n // convert to internal data type if necesssary\r\n if (this.long) {\r\n this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === \"u\");\r\n\r\n /* istanbul ignore else */\r\n if (Object.freeze)\r\n Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)\r\n\r\n } else if (this.bytes && typeof this.typeDefault === \"string\") {\r\n var buf;\r\n if (util.base64.test(this.typeDefault))\r\n util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);\r\n else\r\n util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);\r\n this.typeDefault = buf;\r\n }\r\n\r\n // take special care of maps and repeated fields\r\n if (this.map)\r\n this.defaultValue = util.emptyObject;\r\n else if (this.repeated)\r\n this.defaultValue = util.emptyArray;\r\n else\r\n this.defaultValue = this.typeDefault;\r\n\r\n // ensure proper value on prototype\r\n if (this.parent instanceof Type)\r\n this.parent.ctor.prototype[this.name] = this.defaultValue;\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).\r\n * @typedef FieldDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} fieldName Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"string\"|\"bool\"|\"bytes\"|Object} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @param {T} [defaultValue] Default value\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]\r\n */\r\nField.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {\r\n\r\n // submessage: decorate the submessage and use its name as the type\r\n if (typeof fieldType === \"function\")\r\n fieldType = util.decorateType(fieldType).name;\r\n\r\n // enum reference: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldType && typeof fieldType === \"object\")\r\n fieldType = util.decorateEnum(fieldType).name;\r\n\r\n return function fieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new Field(fieldName, fieldId, fieldType, fieldRule, { \"default\": defaultValue }));\r\n };\r\n};\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {Constructor|string} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends Message\r\n * @variation 2\r\n */\r\n// like Field.d but without a default value\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nField._configure = function configure(Type_) {\r\n Type = Type_;\r\n};\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(17);\r\n\r\nprotobuf.build = \"light\";\r\n\r\n/**\r\n * A node-style callback as used by {@link load} and {@link Root#load}.\r\n * @typedef LoadCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Root} [root] Root, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} root Root namespace, defaults to create a new one if omitted.\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n */\r\nfunction load(filename, root, callback) {\r\n if (typeof root === \"function\") {\r\n callback = root;\r\n root = new protobuf.Root();\r\n } else if (!root)\r\n root = new protobuf.Root();\r\n return root.load(filename, callback);\r\n}\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Promise} Promise\r\n * @see {@link Root#load}\r\n * @variation 3\r\n */\r\n// function load(filename:string, [root:Root]):Promise\r\n\r\nprotobuf.load = load;\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only).\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n * @see {@link Root#loadSync}\r\n */\r\nfunction loadSync(filename, root) {\r\n if (!root)\r\n root = new protobuf.Root();\r\n return root.loadSync(filename);\r\n}\r\n\r\nprotobuf.loadSync = loadSync;\r\n\r\n// Serialization\r\nprotobuf.encoder = require(13);\r\nprotobuf.decoder = require(12);\r\nprotobuf.verifier = require(36);\r\nprotobuf.converter = require(11);\r\n\r\n// Reflection\r\nprotobuf.ReflectionObject = require(22);\r\nprotobuf.Namespace = require(21);\r\nprotobuf.Root = require(26);\r\nprotobuf.Enum = require(14);\r\nprotobuf.Type = require(31);\r\nprotobuf.Field = require(15);\r\nprotobuf.OneOf = require(23);\r\nprotobuf.MapField = require(18);\r\nprotobuf.Service = require(30);\r\nprotobuf.Method = require(20);\r\n\r\n// Runtime\r\nprotobuf.Message = require(19);\r\nprotobuf.wrappers = require(37);\r\n\r\n// Utility\r\nprotobuf.types = require(32);\r\nprotobuf.util = require(33);\r\n\r\n// Set up possibly cyclic reflection dependencies\r\nprotobuf.ReflectionObject._configure(protobuf.Root);\r\nprotobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum);\r\nprotobuf.Root._configure(protobuf.Type);\r\nprotobuf.Field._configure(protobuf.Type);\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(38);\r\nprotobuf.BufferWriter = require(39);\r\nprotobuf.Reader = require(24);\r\nprotobuf.BufferReader = require(25);\r\n\r\n// Utility\r\nprotobuf.util = require(35);\r\nprotobuf.rpc = require(28);\r\nprotobuf.roots = require(27);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nmodule.exports = MapField;\r\n\r\n// extends Field\r\nvar Field = require(15);\r\n((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = \"MapField\";\r\n\r\nvar types = require(32),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new map field instance.\r\n * @classdesc Reflected map field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} keyType Key type\r\n * @param {string} type Value type\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction MapField(name, id, keyType, type, options, comment) {\r\n Field.call(this, name, id, type, undefined, undefined, options, comment);\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(keyType))\r\n throw TypeError(\"keyType must be a string\");\r\n\r\n /**\r\n * Key type.\r\n * @type {string}\r\n */\r\n this.keyType = keyType; // toJSON, marker\r\n\r\n /**\r\n * Resolved key type if not a basic type.\r\n * @type {ReflectionObject|null}\r\n */\r\n this.resolvedKeyType = null;\r\n\r\n // Overrides Field#map\r\n this.map = true;\r\n}\r\n\r\n/**\r\n * Map field descriptor.\r\n * @interface IMapField\r\n * @extends {IField}\r\n * @property {string} keyType Key type\r\n */\r\n\r\n/**\r\n * Extension map field descriptor.\r\n * @interface IExtensionMapField\r\n * @extends IMapField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Constructs a map field from a map field descriptor.\r\n * @param {string} name Field name\r\n * @param {IMapField} json Map field descriptor\r\n * @returns {MapField} Created map field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMapField.fromJSON = function fromJSON(name, json) {\r\n return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this map field to a map field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMapField} Map field descriptor\r\n */\r\nMapField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"keyType\" , this.keyType,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMapField.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n\r\n // Besides a value type, map fields have a key type that may be \"any scalar type except for floating point types and bytes\"\r\n if (types.mapKey[this.keyType] === undefined)\r\n throw Error(\"invalid key type: \" + this.keyType);\r\n\r\n return Field.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Map field decorator (TypeScript).\r\n * @name MapField.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"} fieldKeyType Field key type\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"|\"bytes\"|Object|Constructor<{}>} fieldValueType Field value type\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> }\r\n */\r\nMapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) {\r\n\r\n // submessage value: decorate the submessage and use its name as the type\r\n if (typeof fieldValueType === \"function\")\r\n fieldValueType = util.decorateType(fieldValueType).name;\r\n\r\n // enum reference value: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldValueType && typeof fieldValueType === \"object\")\r\n fieldValueType = util.decorateEnum(fieldValueType).name;\r\n\r\n return function mapFieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType));\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Message;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs a new message instance.\r\n * @classdesc Abstract runtime message.\r\n * @constructor\r\n * @param {Properties} [properties] Properties to set\r\n * @template T extends object = object\r\n */\r\nfunction Message(properties) {\r\n // not used internally\r\n if (properties)\r\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\r\n this[keys[i]] = properties[keys[i]];\r\n}\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message.$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message#$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/*eslint-disable valid-jsdoc*/\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.create = function create(properties) {\r\n return this.$type.create(properties);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encode = function encode(message, writer) {\r\n return this.$type.encode(message, writer);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its length as a varint.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.$type.encodeDelimited(message, writer);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @name Message.decode\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decode = function decode(reader) {\r\n return this.$type.decode(reader);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its length as a varint.\r\n * @name Message.decodeDelimited\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decodeDelimited = function decodeDelimited(reader) {\r\n return this.$type.decodeDelimited(reader);\r\n};\r\n\r\n/**\r\n * Verifies a message of this type.\r\n * @name Message.verify\r\n * @function\r\n * @param {Object.} message Plain object to verify\r\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\r\n */\r\nMessage.verify = function verify(message) {\r\n return this.$type.verify(message);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object\r\n * @returns {T} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.fromObject = function fromObject(object) {\r\n return this.$type.fromObject(object);\r\n};\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {T} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.toObject = function toObject(message, options) {\r\n return this.$type.toObject(message, options);\r\n};\r\n\r\n/**\r\n * Converts this message to JSON.\r\n * @returns {Object.} JSON object\r\n */\r\nMessage.prototype.toJSON = function toJSON() {\r\n return this.$type.toObject(this, util.toJSONOptions);\r\n};\r\n\r\n/*eslint-enable valid-jsdoc*/","\"use strict\";\r\nmodule.exports = Method;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = \"Method\";\r\n\r\nvar util = require(33);\r\n\r\n/**\r\n * Constructs a new service method instance.\r\n * @classdesc Reflected service method.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Method name\r\n * @param {string|undefined} type Method type, usually `\"rpc\"`\r\n * @param {string} requestType Request message type\r\n * @param {string} responseType Response message type\r\n * @param {boolean|Object.} [requestStream] Whether the request is streamed\r\n * @param {boolean|Object.} [responseStream] Whether the response is streamed\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this method\r\n */\r\nfunction Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) {\r\n\r\n /* istanbul ignore next */\r\n if (util.isObject(requestStream)) {\r\n options = requestStream;\r\n requestStream = responseStream = undefined;\r\n } else if (util.isObject(responseStream)) {\r\n options = responseStream;\r\n responseStream = undefined;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!(type === undefined || util.isString(type)))\r\n throw TypeError(\"type must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(requestType))\r\n throw TypeError(\"requestType must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(responseType))\r\n throw TypeError(\"responseType must be a string\");\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Method type.\r\n * @type {string}\r\n */\r\n this.type = type || \"rpc\"; // toJSON\r\n\r\n /**\r\n * Request type.\r\n * @type {string}\r\n */\r\n this.requestType = requestType; // toJSON, marker\r\n\r\n /**\r\n * Whether requests are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.requestStream = requestStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Response type.\r\n * @type {string}\r\n */\r\n this.responseType = responseType; // toJSON\r\n\r\n /**\r\n * Whether responses are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.responseStream = responseStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Resolved request type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedRequestType = null;\r\n\r\n /**\r\n * Resolved response type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedResponseType = null;\r\n\r\n /**\r\n * Comment for this method\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Method descriptor.\r\n * @interface IMethod\r\n * @property {string} [type=\"rpc\"] Method type\r\n * @property {string} requestType Request type\r\n * @property {string} responseType Response type\r\n * @property {boolean} [requestStream=false] Whether requests are streamed\r\n * @property {boolean} [responseStream=false] Whether responses are streamed\r\n * @property {Object.} [options] Method options\r\n */\r\n\r\n/**\r\n * Constructs a method from a method descriptor.\r\n * @param {string} name Method name\r\n * @param {IMethod} json Method descriptor\r\n * @returns {Method} Created method\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMethod.fromJSON = function fromJSON(name, json) {\r\n return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this method to a method descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMethod} Method descriptor\r\n */\r\nMethod.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"type\" , this.type !== \"rpc\" && /* istanbul ignore next */ this.type || undefined,\r\n \"requestType\" , this.requestType,\r\n \"requestStream\" , this.requestStream,\r\n \"responseType\" , this.responseType,\r\n \"responseStream\" , this.responseStream,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMethod.prototype.resolve = function resolve() {\r\n\r\n /* istanbul ignore if */\r\n if (this.resolved)\r\n return this;\r\n\r\n this.resolvedRequestType = this.parent.lookupType(this.requestType);\r\n this.resolvedResponseType = this.parent.lookupType(this.responseType);\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Namespace;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = \"Namespace\";\r\n\r\nvar Field = require(15),\r\n util = require(33);\r\n\r\nvar Type, // cyclic\r\n Service,\r\n Enum;\r\n\r\n/**\r\n * Constructs a new namespace instance.\r\n * @name Namespace\r\n * @classdesc Reflected namespace.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a namespace from JSON.\r\n * @memberof Namespace\r\n * @function\r\n * @param {string} name Namespace name\r\n * @param {Object.} json JSON object\r\n * @returns {Namespace} Created namespace\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nNamespace.fromJSON = function fromJSON(name, json) {\r\n return new Namespace(name, json.options).addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Converts an array of reflection objects to JSON.\r\n * @memberof Namespace\r\n * @param {ReflectionObject[]} array Object array\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {Object.|undefined} JSON object or `undefined` when array is empty\r\n */\r\nfunction arrayToJSON(array, toJSONOptions) {\r\n if (!(array && array.length))\r\n return undefined;\r\n var obj = {};\r\n for (var i = 0; i < array.length; ++i)\r\n obj[array[i].name] = array[i].toJSON(toJSONOptions);\r\n return obj;\r\n}\r\n\r\nNamespace.arrayToJSON = arrayToJSON;\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedId = function isReservedId(reserved, id) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (typeof reserved[i] !== \"string\" && reserved[i][0] <= id && reserved[i][1] >= id)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedName = function isReservedName(reserved, name) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (reserved[i] === name)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Namespace} instead.\r\n * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports NamespaceBase\r\n * @extends ReflectionObject\r\n * @abstract\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n * @see {@link Namespace}\r\n */\r\nfunction Namespace(name, options) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Nested objects by name.\r\n * @type {Object.|undefined}\r\n */\r\n this.nested = undefined; // toJSON\r\n\r\n /**\r\n * Cached nested objects as an array.\r\n * @type {ReflectionObject[]|null}\r\n * @private\r\n */\r\n this._nestedArray = null;\r\n}\r\n\r\nfunction clearCache(namespace) {\r\n namespace._nestedArray = null;\r\n return namespace;\r\n}\r\n\r\n/**\r\n * Nested objects of this namespace as an array for iteration.\r\n * @name NamespaceBase#nestedArray\r\n * @type {ReflectionObject[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Namespace.prototype, \"nestedArray\", {\r\n get: function() {\r\n return this._nestedArray || (this._nestedArray = util.toArray(this.nested));\r\n }\r\n});\r\n\r\n/**\r\n * Namespace descriptor.\r\n * @interface INamespace\r\n * @property {Object.} [options] Namespace options\r\n * @property {Object.} [nested] Nested object descriptors\r\n */\r\n\r\n/**\r\n * Any extension field descriptor.\r\n * @typedef AnyExtensionField\r\n * @type {IExtensionField|IExtensionMapField}\r\n */\r\n\r\n/**\r\n * Any nested object descriptor.\r\n * @typedef AnyNestedObject\r\n * @type {IEnum|IType|IService|AnyExtensionField|INamespace}\r\n */\r\n// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place)\r\n\r\n/**\r\n * Converts this namespace to a namespace descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {INamespace} Namespace descriptor\r\n */\r\nNamespace.prototype.toJSON = function toJSON(toJSONOptions) {\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"nested\" , arrayToJSON(this.nestedArray, toJSONOptions)\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds nested objects to this namespace from nested object descriptors.\r\n * @param {Object.} nestedJson Any nested object descriptors\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.addJSON = function addJSON(nestedJson) {\r\n var ns = this;\r\n /* istanbul ignore else */\r\n if (nestedJson) {\r\n for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) {\r\n nested = nestedJson[names[i]];\r\n ns.add( // most to least likely\r\n ( nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : nested.id !== undefined\r\n ? Field.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets the nested object of the specified name.\r\n * @param {string} name Nested object name\r\n * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist\r\n */\r\nNamespace.prototype.get = function get(name) {\r\n return this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Gets the values of the nested {@link Enum|enum} of the specified name.\r\n * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`.\r\n * @param {string} name Nested enum name\r\n * @returns {Object.} Enum values\r\n * @throws {Error} If there is no such enum\r\n */\r\nNamespace.prototype.getEnum = function getEnum(name) {\r\n if (this.nested && this.nested[name] instanceof Enum)\r\n return this.nested[name].values;\r\n throw Error(\"no such enum: \" + name);\r\n};\r\n\r\n/**\r\n * Adds a nested object to this namespace.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name\r\n */\r\nNamespace.prototype.add = function add(object) {\r\n\r\n if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace))\r\n throw TypeError(\"object must be a valid nested object\");\r\n\r\n if (!this.nested)\r\n this.nested = {};\r\n else {\r\n var prev = this.get(object.name);\r\n if (prev) {\r\n if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) {\r\n // replace plain namespace but keep existing nested elements and options\r\n var nested = prev.nestedArray;\r\n for (var i = 0; i < nested.length; ++i)\r\n object.add(nested[i]);\r\n this.remove(prev);\r\n if (!this.nested)\r\n this.nested = {};\r\n object.setOptions(prev.options, true);\r\n\r\n } else\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n }\r\n }\r\n this.nested[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this namespace.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this namespace\r\n */\r\nNamespace.prototype.remove = function remove(object) {\r\n\r\n if (!(object instanceof ReflectionObject))\r\n throw TypeError(\"object must be a ReflectionObject\");\r\n if (object.parent !== this)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.nested[object.name];\r\n if (!Object.keys(this.nested).length)\r\n this.nested = undefined;\r\n\r\n object.onRemove(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Defines additial namespaces within this one if not yet existing.\r\n * @param {string|string[]} path Path to create\r\n * @param {*} [json] Nested types to create from JSON\r\n * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty\r\n */\r\nNamespace.prototype.define = function define(path, json) {\r\n\r\n if (util.isString(path))\r\n path = path.split(\".\");\r\n else if (!Array.isArray(path))\r\n throw TypeError(\"illegal path\");\r\n if (path && path.length && path[0] === \"\")\r\n throw Error(\"path must be relative\");\r\n\r\n var ptr = this;\r\n while (path.length > 0) {\r\n var part = path.shift();\r\n if (ptr.nested && ptr.nested[part]) {\r\n ptr = ptr.nested[part];\r\n if (!(ptr instanceof Namespace))\r\n throw Error(\"path conflicts with non-namespace objects\");\r\n } else\r\n ptr.add(ptr = new Namespace(part));\r\n }\r\n if (json)\r\n ptr.addJSON(json);\r\n return ptr;\r\n};\r\n\r\n/**\r\n * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost.\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.resolveAll = function resolveAll() {\r\n var nested = this.nestedArray, i = 0;\r\n while (i < nested.length)\r\n if (nested[i] instanceof Namespace)\r\n nested[i++].resolveAll();\r\n else\r\n nested[i++].resolve();\r\n return this.resolve();\r\n};\r\n\r\n/**\r\n * Recursively looks up the reflection object matching the specified path in the scope of this namespace.\r\n * @param {string|string[]} path Path to look up\r\n * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc.\r\n * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n */\r\nNamespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) {\r\n\r\n /* istanbul ignore next */\r\n if (typeof filterTypes === \"boolean\") {\r\n parentAlreadyChecked = filterTypes;\r\n filterTypes = undefined;\r\n } else if (filterTypes && !Array.isArray(filterTypes))\r\n filterTypes = [ filterTypes ];\r\n\r\n if (util.isString(path) && path.length) {\r\n if (path === \".\")\r\n return this.root;\r\n path = path.split(\".\");\r\n } else if (!path.length)\r\n return this;\r\n\r\n // Start at root if path is absolute\r\n if (path[0] === \"\")\r\n return this.root.lookup(path.slice(1), filterTypes);\r\n\r\n // Test if the first part matches any nested object, and if so, traverse if path contains more\r\n var found = this.get(path[0]);\r\n if (found) {\r\n if (path.length === 1) {\r\n if (!filterTypes || filterTypes.indexOf(found.constructor) > -1)\r\n return found;\r\n } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true)))\r\n return found;\r\n\r\n // Otherwise try each nested namespace\r\n } else\r\n for (var i = 0; i < this.nestedArray.length; ++i)\r\n if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true)))\r\n return found;\r\n\r\n // If there hasn't been a match, try again at the parent\r\n if (this.parent === null || parentAlreadyChecked)\r\n return null;\r\n return this.parent.lookup(path, filterTypes);\r\n};\r\n\r\n/**\r\n * Looks up the reflection object at the specified path, relative to this namespace.\r\n * @name NamespaceBase#lookup\r\n * @function\r\n * @param {string|string[]} path Path to look up\r\n * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n * @variation 2\r\n */\r\n// lookup(path: string, [parentAlreadyChecked: boolean])\r\n\r\n/**\r\n * Looks up the {@link Type|type} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type\r\n * @throws {Error} If `path` does not point to a type\r\n */\r\nNamespace.prototype.lookupType = function lookupType(path) {\r\n var found = this.lookup(path, [ Type ]);\r\n if (!found)\r\n throw Error(\"no such type: \" + path);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Enum} Looked up enum\r\n * @throws {Error} If `path` does not point to an enum\r\n */\r\nNamespace.prototype.lookupEnum = function lookupEnum(path) {\r\n var found = this.lookup(path, [ Enum ]);\r\n if (!found)\r\n throw Error(\"no such Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type or enum\r\n * @throws {Error} If `path` does not point to a type or enum\r\n */\r\nNamespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) {\r\n var found = this.lookup(path, [ Type, Enum ]);\r\n if (!found)\r\n throw Error(\"no such Type or Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Service|service} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Service} Looked up service\r\n * @throws {Error} If `path` does not point to a service\r\n */\r\nNamespace.prototype.lookupService = function lookupService(path) {\r\n var found = this.lookup(path, [ Service ]);\r\n if (!found)\r\n throw Error(\"no such Service '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nNamespace._configure = function(Type_, Service_, Enum_) {\r\n Type = Type_;\r\n Service = Service_;\r\n Enum = Enum_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = ReflectionObject;\r\n\r\nReflectionObject.className = \"ReflectionObject\";\r\n\r\nvar util = require(33);\r\n\r\nvar Root; // cyclic\r\n\r\n/**\r\n * Constructs a new reflection object instance.\r\n * @classdesc Base class of all reflection objects.\r\n * @constructor\r\n * @param {string} name Object name\r\n * @param {Object.} [options] Declared options\r\n * @abstract\r\n */\r\nfunction ReflectionObject(name, options) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (options && !util.isObject(options))\r\n throw TypeError(\"options must be an object\");\r\n\r\n /**\r\n * Options.\r\n * @type {Object.|undefined}\r\n */\r\n this.options = options; // toJSON\r\n\r\n /**\r\n * Unique name within its namespace.\r\n * @type {string}\r\n */\r\n this.name = name;\r\n\r\n /**\r\n * Parent namespace.\r\n * @type {Namespace|null}\r\n */\r\n this.parent = null;\r\n\r\n /**\r\n * Whether already resolved or not.\r\n * @type {boolean}\r\n */\r\n this.resolved = false;\r\n\r\n /**\r\n * Comment text, if any.\r\n * @type {string|null}\r\n */\r\n this.comment = null;\r\n\r\n /**\r\n * Defining file name.\r\n * @type {string|null}\r\n */\r\n this.filename = null;\r\n}\r\n\r\nObject.defineProperties(ReflectionObject.prototype, {\r\n\r\n /**\r\n * Reference to the root namespace.\r\n * @name ReflectionObject#root\r\n * @type {Root}\r\n * @readonly\r\n */\r\n root: {\r\n get: function() {\r\n var ptr = this;\r\n while (ptr.parent !== null)\r\n ptr = ptr.parent;\r\n return ptr;\r\n }\r\n },\r\n\r\n /**\r\n * Full name including leading dot.\r\n * @name ReflectionObject#fullName\r\n * @type {string}\r\n * @readonly\r\n */\r\n fullName: {\r\n get: function() {\r\n var path = [ this.name ],\r\n ptr = this.parent;\r\n while (ptr) {\r\n path.unshift(ptr.name);\r\n ptr = ptr.parent;\r\n }\r\n return path.join(\".\");\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Converts this reflection object to its descriptor representation.\r\n * @returns {Object.} Descriptor\r\n * @abstract\r\n */\r\nReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() {\r\n throw Error(); // not implemented, shouldn't happen\r\n};\r\n\r\n/**\r\n * Called when this object is added to a parent.\r\n * @param {ReflectionObject} parent Parent added to\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onAdd = function onAdd(parent) {\r\n if (this.parent && this.parent !== parent)\r\n this.parent.remove(this);\r\n this.parent = parent;\r\n this.resolved = false;\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleAdd(this);\r\n};\r\n\r\n/**\r\n * Called when this object is removed from a parent.\r\n * @param {ReflectionObject} parent Parent removed from\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onRemove = function onRemove(parent) {\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleRemove(this);\r\n this.parent = null;\r\n this.resolved = false;\r\n};\r\n\r\n/**\r\n * Resolves this objects type references.\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n if (this.root instanceof Root)\r\n this.resolved = true; // only if part of a root\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets an option value.\r\n * @param {string} name Option name\r\n * @returns {*} Option value or `undefined` if not set\r\n */\r\nReflectionObject.prototype.getOption = function getOption(name) {\r\n if (this.options)\r\n return this.options[name];\r\n return undefined;\r\n};\r\n\r\n/**\r\n * Sets an option.\r\n * @param {string} name Option name\r\n * @param {*} value Option value\r\n * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (!ifNotSet || !this.options || this.options[name] === undefined)\r\n (this.options || (this.options = {}))[name] = value;\r\n return this;\r\n};\r\n\r\n/**\r\n * Sets multiple options.\r\n * @param {Object.} options Options to set\r\n * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) {\r\n if (options)\r\n for (var keys = Object.keys(options), i = 0; i < keys.length; ++i)\r\n this.setOption(keys[i], options[keys[i]], ifNotSet);\r\n return this;\r\n};\r\n\r\n/**\r\n * Converts this instance to its string representation.\r\n * @returns {string} Class name[, space, full name]\r\n */\r\nReflectionObject.prototype.toString = function toString() {\r\n var className = this.constructor.className,\r\n fullName = this.fullName;\r\n if (fullName.length)\r\n return className + \" \" + fullName;\r\n return className;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nReflectionObject._configure = function(Root_) {\r\n Root = Root_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = OneOf;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = \"OneOf\";\r\n\r\nvar Field = require(15),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new oneof instance.\r\n * @classdesc Reflected oneof.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Oneof name\r\n * @param {string[]|Object.} [fieldNames] Field names\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction OneOf(name, fieldNames, options, comment) {\r\n if (!Array.isArray(fieldNames)) {\r\n options = fieldNames;\r\n fieldNames = undefined;\r\n }\r\n ReflectionObject.call(this, name, options);\r\n\r\n /* istanbul ignore if */\r\n if (!(fieldNames === undefined || Array.isArray(fieldNames)))\r\n throw TypeError(\"fieldNames must be an Array\");\r\n\r\n /**\r\n * Field names that belong to this oneof.\r\n * @type {string[]}\r\n */\r\n this.oneof = fieldNames || []; // toJSON, marker\r\n\r\n /**\r\n * Fields that belong to this oneof as an array for iteration.\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Oneof descriptor.\r\n * @interface IOneOf\r\n * @property {Array.} oneof Oneof field names\r\n * @property {Object.} [options] Oneof options\r\n */\r\n\r\n/**\r\n * Constructs a oneof from a oneof descriptor.\r\n * @param {string} name Oneof name\r\n * @param {IOneOf} json Oneof descriptor\r\n * @returns {OneOf} Created oneof\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nOneOf.fromJSON = function fromJSON(name, json) {\r\n return new OneOf(name, json.oneof, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this oneof to a oneof descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IOneOf} Oneof descriptor\r\n */\r\nOneOf.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"oneof\" , this.oneof,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds the fields of the specified oneof to the parent if not already done so.\r\n * @param {OneOf} oneof The oneof\r\n * @returns {undefined}\r\n * @inner\r\n * @ignore\r\n */\r\nfunction addFieldsToParent(oneof) {\r\n if (oneof.parent)\r\n for (var i = 0; i < oneof.fieldsArray.length; ++i)\r\n if (!oneof.fieldsArray[i].parent)\r\n oneof.parent.add(oneof.fieldsArray[i]);\r\n}\r\n\r\n/**\r\n * Adds a field to this oneof and removes it from its current parent, if any.\r\n * @param {Field} field Field to add\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.add = function add(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n if (field.parent && field.parent !== this.parent)\r\n field.parent.remove(field);\r\n this.oneof.push(field.name);\r\n this.fieldsArray.push(field);\r\n field.partOf = this; // field.parent remains null\r\n addFieldsToParent(this);\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a field from this oneof and puts it back to the oneof's parent.\r\n * @param {Field} field Field to remove\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.remove = function remove(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n var index = this.fieldsArray.indexOf(field);\r\n\r\n /* istanbul ignore if */\r\n if (index < 0)\r\n throw Error(field + \" is not a member of \" + this);\r\n\r\n this.fieldsArray.splice(index, 1);\r\n index = this.oneof.indexOf(field.name);\r\n\r\n /* istanbul ignore else */\r\n if (index > -1) // theoretical\r\n this.oneof.splice(index, 1);\r\n\r\n field.partOf = null;\r\n return this;\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onAdd = function onAdd(parent) {\r\n ReflectionObject.prototype.onAdd.call(this, parent);\r\n var self = this;\r\n // Collect present fields\r\n for (var i = 0; i < this.oneof.length; ++i) {\r\n var field = parent.get(this.oneof[i]);\r\n if (field && !field.partOf) {\r\n field.partOf = self;\r\n self.fieldsArray.push(field);\r\n }\r\n }\r\n // Add not yet present fields\r\n addFieldsToParent(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onRemove = function onRemove(parent) {\r\n for (var i = 0, field; i < this.fieldsArray.length; ++i)\r\n if ((field = this.fieldsArray[i]).parent)\r\n field.parent.remove(field);\r\n ReflectionObject.prototype.onRemove.call(this, parent);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link OneOf.d} (TypeScript).\r\n * @typedef OneOfDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} oneofName OneOf name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * OneOf decorator (TypeScript).\r\n * @function\r\n * @param {...string} fieldNames Field names\r\n * @returns {OneOfDecorator} Decorator function\r\n * @template T extends string\r\n */\r\nOneOf.d = function decorateOneOf() {\r\n var fieldNames = new Array(arguments.length),\r\n index = 0;\r\n while (index < arguments.length)\r\n fieldNames[index] = arguments[index++];\r\n return function oneOfDecorator(prototype, oneofName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new OneOf(oneofName, fieldNames));\r\n Object.defineProperty(prototype, oneofName, {\r\n get: util.oneOfGetter(fieldNames),\r\n set: util.oneOfSetter(fieldNames)\r\n });\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(35);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(24);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = Root;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = \"Root\";\r\n\r\nvar Field = require(15),\r\n Enum = require(14),\r\n OneOf = require(23),\r\n util = require(33);\r\n\r\nvar Type, // cyclic\r\n parse, // might be excluded\r\n common; // \"\r\n\r\n/**\r\n * Constructs a new root namespace instance.\r\n * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {Object.} [options] Top level options\r\n */\r\nfunction Root(options) {\r\n Namespace.call(this, \"\", options);\r\n\r\n /**\r\n * Deferred extension fields.\r\n * @type {Field[]}\r\n */\r\n this.deferred = [];\r\n\r\n /**\r\n * Resolved file names of loaded files.\r\n * @type {string[]}\r\n */\r\n this.files = [];\r\n}\r\n\r\n/**\r\n * Loads a namespace descriptor into a root namespace.\r\n * @param {INamespace} json Nameespace descriptor\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted\r\n * @returns {Root} Root namespace\r\n */\r\nRoot.fromJSON = function fromJSON(json, root) {\r\n if (!root)\r\n root = new Root();\r\n if (json.options)\r\n root.setOptions(json.options);\r\n return root.addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Resolves the path of an imported file, relative to the importing origin.\r\n * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories.\r\n * @function\r\n * @param {string} origin The file name of the importing file\r\n * @param {string} target The file name being imported\r\n * @returns {string|null} Resolved path to `target` or `null` to skip the file\r\n */\r\nRoot.prototype.resolvePath = util.path.resolve;\r\n\r\n// A symbol-like function to safely signal synchronous loading\r\n/* istanbul ignore next */\r\nfunction SYNC() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} options Parse options\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nRoot.prototype.load = function load(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = undefined;\r\n }\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(load, self, filename, options);\r\n\r\n var sync = callback === SYNC; // undocumented\r\n\r\n // Finishes loading by calling the callback (exactly once)\r\n function finish(err, root) {\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return;\r\n var cb = callback;\r\n callback = null;\r\n if (sync)\r\n throw err;\r\n cb(err, root);\r\n }\r\n\r\n // Processes a single file\r\n function process(filename, source) {\r\n try {\r\n if (util.isString(source) && source.charAt(0) === \"{\")\r\n source = JSON.parse(source);\r\n if (!util.isString(source))\r\n self.setOptions(source.options).addJSON(source.nested);\r\n else {\r\n parse.filename = filename;\r\n var parsed = parse(source, self, options),\r\n resolved,\r\n i = 0;\r\n if (parsed.imports)\r\n for (; i < parsed.imports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.imports[i]))\r\n fetch(resolved);\r\n if (parsed.weakImports)\r\n for (i = 0; i < parsed.weakImports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.weakImports[i]))\r\n fetch(resolved, true);\r\n }\r\n } catch (err) {\r\n finish(err);\r\n }\r\n if (!sync && !queued)\r\n finish(null, self); // only once anyway\r\n }\r\n\r\n // Fetches a single file\r\n function fetch(filename, weak) {\r\n\r\n // Strip path if this file references a bundled definition\r\n var idx = filename.lastIndexOf(\"google/protobuf/\");\r\n if (idx > -1) {\r\n var altname = filename.substring(idx);\r\n if (altname in common)\r\n filename = altname;\r\n }\r\n\r\n // Skip if already loaded / attempted\r\n if (self.files.indexOf(filename) > -1)\r\n return;\r\n self.files.push(filename);\r\n\r\n // Shortcut bundled definitions\r\n if (filename in common) {\r\n if (sync)\r\n process(filename, common[filename]);\r\n else {\r\n ++queued;\r\n setTimeout(function() {\r\n --queued;\r\n process(filename, common[filename]);\r\n });\r\n }\r\n return;\r\n }\r\n\r\n // Otherwise fetch from disk or network\r\n if (sync) {\r\n var source;\r\n try {\r\n source = util.fs.readFileSync(filename).toString(\"utf8\");\r\n } catch (err) {\r\n if (!weak)\r\n finish(err);\r\n return;\r\n }\r\n process(filename, source);\r\n } else {\r\n ++queued;\r\n util.fetch(filename, function(err, source) {\r\n --queued;\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return; // terminated meanwhile\r\n if (err) {\r\n /* istanbul ignore else */\r\n if (!weak)\r\n finish(err);\r\n else if (!queued) // can't be covered reliably\r\n finish(null, self);\r\n return;\r\n }\r\n process(filename, source);\r\n });\r\n }\r\n }\r\n var queued = 0;\r\n\r\n // Assembling the root namespace doesn't require working type\r\n // references anymore, so we can load everything in parallel\r\n if (util.isString(filename))\r\n filename = [ filename ];\r\n for (var i = 0, resolved; i < filename.length; ++i)\r\n if (resolved = self.resolvePath(\"\", filename[i]))\r\n fetch(resolved);\r\n\r\n if (sync)\r\n return self;\r\n if (!queued)\r\n finish(null, self);\r\n return undefined;\r\n};\r\n// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n// function load(filename:string, [options:IParseOptions]):Promise\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only).\r\n * @function Root#loadSync\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n */\r\nRoot.prototype.loadSync = function loadSync(filename, options) {\r\n if (!util.isNode)\r\n throw Error(\"not supported\");\r\n return this.load(filename, options, SYNC);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nRoot.prototype.resolveAll = function resolveAll() {\r\n if (this.deferred.length)\r\n throw Error(\"unresolvable extensions: \" + this.deferred.map(function(field) {\r\n return \"'extend \" + field.extend + \"' in \" + field.parent.fullName;\r\n }).join(\", \"));\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n// only uppercased (and thus conflict-free) children are exposed, see below\r\nvar exposeRe = /^[A-Z]/;\r\n\r\n/**\r\n * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type.\r\n * @param {Root} root Root instance\r\n * @param {Field} field Declaring extension field witin the declaring type\r\n * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise\r\n * @inner\r\n * @ignore\r\n */\r\nfunction tryHandleExtension(root, field) {\r\n var extendedType = field.parent.lookup(field.extend);\r\n if (extendedType) {\r\n var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options);\r\n sisterField.declaringField = field;\r\n field.extensionField = sisterField;\r\n extendedType.add(sisterField);\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * Called when any object is added to this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object added\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleAdd = function _handleAdd(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField)\r\n if (!tryHandleExtension(this, object))\r\n this.deferred.push(object);\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object.values; // expose enum values as property of its parent\r\n\r\n } else if (!(object instanceof OneOf)) /* everything else is a namespace */ {\r\n\r\n if (object instanceof Type) // Try to handle any deferred extensions\r\n for (var i = 0; i < this.deferred.length;)\r\n if (tryHandleExtension(this, this.deferred[i]))\r\n this.deferred.splice(i, 1);\r\n else\r\n ++i;\r\n for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace\r\n this._handleAdd(object._nestedArray[j]);\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object; // expose namespace as property of its parent\r\n }\r\n\r\n // The above also adds uppercased (and thus conflict-free) nested types, services and enums as\r\n // properties of namespaces just like static code does. This allows using a .d.ts generated for\r\n // a static module with reflection-based solutions where the condition is met.\r\n};\r\n\r\n/**\r\n * Called when any object is removed from this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object removed\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleRemove = function _handleRemove(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field */ object.extend !== undefined) {\r\n if (/* already handled */ object.extensionField) { // remove its sister field\r\n object.extensionField.parent.remove(object.extensionField);\r\n object.extensionField = null;\r\n } else { // cancel the extension\r\n var index = this.deferred.indexOf(object);\r\n /* istanbul ignore else */\r\n if (index > -1)\r\n this.deferred.splice(index, 1);\r\n }\r\n }\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose enum values\r\n\r\n } else if (object instanceof Namespace) {\r\n\r\n for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace\r\n this._handleRemove(object._nestedArray[i]);\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose namespaces\r\n\r\n }\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nRoot._configure = function(Type_, parse_, common_) {\r\n Type = Type_;\r\n parse = parse_;\r\n common = common_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(29);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(35);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = \"Service\";\r\n\r\nvar Method = require(20),\r\n util = require(33),\r\n rpc = require(28);\r\n\r\n/**\r\n * Constructs a new service instance.\r\n * @classdesc Reflected service.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Service name\r\n * @param {Object.} [options] Service options\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nfunction Service(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Service methods.\r\n * @type {Object.}\r\n */\r\n this.methods = {}; // toJSON, marker\r\n\r\n /**\r\n * Cached methods as an array.\r\n * @type {Method[]|null}\r\n * @private\r\n */\r\n this._methodsArray = null;\r\n}\r\n\r\n/**\r\n * Service descriptor.\r\n * @interface IService\r\n * @extends INamespace\r\n * @property {Object.} methods Method descriptors\r\n */\r\n\r\n/**\r\n * Constructs a service from a service descriptor.\r\n * @param {string} name Service name\r\n * @param {IService} json Service descriptor\r\n * @returns {Service} Created service\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nService.fromJSON = function fromJSON(name, json) {\r\n var service = new Service(name, json.options);\r\n /* istanbul ignore else */\r\n if (json.methods)\r\n for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i)\r\n service.add(Method.fromJSON(names[i], json.methods[names[i]]));\r\n if (json.nested)\r\n service.addJSON(json.nested);\r\n service.comment = json.comment;\r\n return service;\r\n};\r\n\r\n/**\r\n * Converts this service to a service descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IService} Service descriptor\r\n */\r\nService.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"methods\" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {},\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Methods of this service as an array for iteration.\r\n * @name Service#methodsArray\r\n * @type {Method[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Service.prototype, \"methodsArray\", {\r\n get: function() {\r\n return this._methodsArray || (this._methodsArray = util.toArray(this.methods));\r\n }\r\n});\r\n\r\nfunction clearCache(service) {\r\n service._methodsArray = null;\r\n return service;\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.get = function get(name) {\r\n return this.methods[name]\r\n || Namespace.prototype.get.call(this, name);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.resolveAll = function resolveAll() {\r\n var methods = this.methodsArray;\r\n for (var i = 0; i < methods.length; ++i)\r\n methods[i].resolve();\r\n return Namespace.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.add = function add(object) {\r\n\r\n /* istanbul ignore if */\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Method) {\r\n this.methods[object.name] = object;\r\n object.parent = this;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.remove = function remove(object) {\r\n if (object instanceof Method) {\r\n\r\n /* istanbul ignore if */\r\n if (this.methods[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.methods[object.name];\r\n object.parent = null;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Creates a runtime service using the specified rpc implementation.\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed.\r\n */\r\nService.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) {\r\n var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited);\r\n for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) {\r\n var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\\w_]/g, \"\");\r\n rpcService[methodName] = util.codegen([\"r\",\"c\"], util.isReserved(methodName) ? methodName + \"_\" : methodName)(\"return this.rpcCall(m,q,s,r,c)\")({\r\n m: method,\r\n q: method.resolvedRequestType.ctor,\r\n s: method.resolvedResponseType.ctor\r\n });\r\n }\r\n return rpcService;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Type;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = \"Type\";\r\n\r\nvar Enum = require(14),\r\n OneOf = require(23),\r\n Field = require(15),\r\n MapField = require(18),\r\n Service = require(30),\r\n Message = require(19),\r\n Reader = require(24),\r\n Writer = require(38),\r\n util = require(33),\r\n encoder = require(13),\r\n decoder = require(12),\r\n verifier = require(36),\r\n converter = require(11),\r\n wrappers = require(37);\r\n\r\n/**\r\n * Constructs a new reflected message type instance.\r\n * @classdesc Reflected message type.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Message name\r\n * @param {Object.} [options] Declared options\r\n */\r\nfunction Type(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Message fields.\r\n * @type {Object.}\r\n */\r\n this.fields = {}; // toJSON, marker\r\n\r\n /**\r\n * Oneofs declared within this namespace, if any.\r\n * @type {Object.}\r\n */\r\n this.oneofs = undefined; // toJSON\r\n\r\n /**\r\n * Extension ranges, if any.\r\n * @type {number[][]}\r\n */\r\n this.extensions = undefined; // toJSON\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n /*?\r\n * Whether this type is a legacy group.\r\n * @type {boolean|undefined}\r\n */\r\n this.group = undefined; // toJSON\r\n\r\n /**\r\n * Cached fields by id.\r\n * @type {Object.|null}\r\n * @private\r\n */\r\n this._fieldsById = null;\r\n\r\n /**\r\n * Cached fields as an array.\r\n * @type {Field[]|null}\r\n * @private\r\n */\r\n this._fieldsArray = null;\r\n\r\n /**\r\n * Cached oneofs as an array.\r\n * @type {OneOf[]|null}\r\n * @private\r\n */\r\n this._oneofsArray = null;\r\n\r\n /**\r\n * Cached constructor.\r\n * @type {Constructor<{}>}\r\n * @private\r\n */\r\n this._ctor = null;\r\n}\r\n\r\nObject.defineProperties(Type.prototype, {\r\n\r\n /**\r\n * Message fields by id.\r\n * @name Type#fieldsById\r\n * @type {Object.}\r\n * @readonly\r\n */\r\n fieldsById: {\r\n get: function() {\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById)\r\n return this._fieldsById;\r\n\r\n this._fieldsById = {};\r\n for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) {\r\n var field = this.fields[names[i]],\r\n id = field.id;\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById[id])\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n\r\n this._fieldsById[id] = field;\r\n }\r\n return this._fieldsById;\r\n }\r\n },\r\n\r\n /**\r\n * Fields of this message as an array for iteration.\r\n * @name Type#fieldsArray\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n fieldsArray: {\r\n get: function() {\r\n return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields));\r\n }\r\n },\r\n\r\n /**\r\n * Oneofs of this message as an array for iteration.\r\n * @name Type#oneofsArray\r\n * @type {OneOf[]}\r\n * @readonly\r\n */\r\n oneofsArray: {\r\n get: function() {\r\n return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs));\r\n }\r\n },\r\n\r\n /**\r\n * The registered constructor, if any registered, otherwise a generic constructor.\r\n * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor.\r\n * @name Type#ctor\r\n * @type {Constructor<{}>}\r\n */\r\n ctor: {\r\n get: function() {\r\n return this._ctor || (this.ctor = Type.generateConstructor(this)());\r\n },\r\n set: function(ctor) {\r\n\r\n // Ensure proper prototype\r\n var prototype = ctor.prototype;\r\n if (!(prototype instanceof Message)) {\r\n (ctor.prototype = new Message()).constructor = ctor;\r\n util.merge(ctor.prototype, prototype);\r\n }\r\n\r\n // Classes and messages reference their reflected type\r\n ctor.$type = ctor.prototype.$type = this;\r\n\r\n // Mix in static methods\r\n util.merge(ctor, Message, true);\r\n\r\n this._ctor = ctor;\r\n\r\n // Messages have non-enumerable default values on their prototype\r\n var i = 0;\r\n for (; i < /* initializes */ this.fieldsArray.length; ++i)\r\n this._fieldsArray[i].resolve(); // ensures a proper value\r\n\r\n // Messages have non-enumerable getters and setters for each virtual oneof field\r\n var ctorProperties = {};\r\n for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i)\r\n ctorProperties[this._oneofsArray[i].resolve().name] = {\r\n get: util.oneOfGetter(this._oneofsArray[i].oneof),\r\n set: util.oneOfSetter(this._oneofsArray[i].oneof)\r\n };\r\n if (i)\r\n Object.defineProperties(ctor.prototype, ctorProperties);\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Generates a constructor function for the specified type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nType.generateConstructor = function generateConstructor(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n var gen = util.codegen([\"p\"], mtype.name);\r\n // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype\r\n for (var i = 0, field; i < mtype.fieldsArray.length; ++i)\r\n if ((field = mtype._fieldsArray[i]).map) gen\r\n (\"this%s={}\", util.safeProp(field.name));\r\n else if (field.repeated) gen\r\n (\"this%s=[]\", util.safeProp(field.name));\r\n return gen\r\n (\"if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors\r\n * @property {Object.} fields Field descriptors\r\n * @property {number[][]} [extensions] Extension ranges\r\n * @property {number[][]} [reserved] Reserved ranges\r\n * @property {boolean} [group=false] Whether a legacy group or not\r\n */\r\n\r\n/**\r\n * Creates a message type from a message type descriptor.\r\n * @param {string} name Message name\r\n * @param {IType} json Message type descriptor\r\n * @returns {Type} Created message type\r\n */\r\nType.fromJSON = function fromJSON(name, json) {\r\n var type = new Type(name, json.options);\r\n type.extensions = json.extensions;\r\n type.reserved = json.reserved;\r\n var names = Object.keys(json.fields),\r\n i = 0;\r\n for (; i < names.length; ++i)\r\n type.add(\r\n ( typeof json.fields[names[i]].keyType !== \"undefined\"\r\n ? MapField.fromJSON\r\n : Field.fromJSON )(names[i], json.fields[names[i]])\r\n );\r\n if (json.oneofs)\r\n for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i)\r\n type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]]));\r\n if (json.nested)\r\n for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) {\r\n var nested = json.nested[names[i]];\r\n type.add( // most to least likely\r\n ( nested.id !== undefined\r\n ? Field.fromJSON\r\n : nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n if (json.extensions && json.extensions.length)\r\n type.extensions = json.extensions;\r\n if (json.reserved && json.reserved.length)\r\n type.reserved = json.reserved;\r\n if (json.group)\r\n type.group = true;\r\n if (json.comment)\r\n type.comment = json.comment;\r\n return type;\r\n};\r\n\r\n/**\r\n * Converts this message type to a message type descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IType} Message type descriptor\r\n */\r\nType.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"oneofs\" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions),\r\n \"fields\" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {},\r\n \"extensions\" , this.extensions && this.extensions.length ? this.extensions : undefined,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"group\" , this.group || undefined,\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.resolveAll = function resolveAll() {\r\n var fields = this.fieldsArray, i = 0;\r\n while (i < fields.length)\r\n fields[i++].resolve();\r\n var oneofs = this.oneofsArray; i = 0;\r\n while (i < oneofs.length)\r\n oneofs[i++].resolve();\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.get = function get(name) {\r\n return this.fields[name]\r\n || this.oneofs && this.oneofs[name]\r\n || this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Adds a nested object to this type.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id\r\n */\r\nType.prototype.add = function add(object) {\r\n\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Field && object.extend === undefined) {\r\n // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects.\r\n // The root object takes care of adding distinct sister-fields to the respective extended\r\n // type instead.\r\n\r\n // avoids calling the getter if not absolutely necessary because it's called quite frequently\r\n if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id])\r\n throw Error(\"duplicate id \" + object.id + \" in \" + this);\r\n if (this.isReservedId(object.id))\r\n throw Error(\"id \" + object.id + \" is reserved in \" + this);\r\n if (this.isReservedName(object.name))\r\n throw Error(\"name '\" + object.name + \"' is reserved in \" + this);\r\n\r\n if (object.parent)\r\n object.parent.remove(object);\r\n this.fields[object.name] = object;\r\n object.message = this;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n if (!this.oneofs)\r\n this.oneofs = {};\r\n this.oneofs[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this type.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this type\r\n */\r\nType.prototype.remove = function remove(object) {\r\n if (object instanceof Field && object.extend === undefined) {\r\n // See Type#add for the reason why extension fields are excluded here.\r\n\r\n /* istanbul ignore if */\r\n if (!this.fields || this.fields[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.fields[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n\r\n /* istanbul ignore if */\r\n if (!this.oneofs || this.oneofs[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.oneofs[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.create = function create(properties) {\r\n return new this.ctor(properties);\r\n};\r\n\r\n/**\r\n * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}.\r\n * @returns {Type} `this`\r\n */\r\nType.prototype.setup = function setup() {\r\n // Sets up everything at once so that the prototype chain does not have to be re-evaluated\r\n // multiple times (V8, soft-deopt prototype-check).\r\n\r\n var fullName = this.fullName,\r\n types = [];\r\n for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i)\r\n types.push(this._fieldsArray[i].resolve().resolvedType);\r\n\r\n // Replace setup methods with type-specific generated functions\r\n this.encode = encoder(this)({\r\n Writer : Writer,\r\n types : types,\r\n util : util\r\n });\r\n this.decode = decoder(this)({\r\n Reader : Reader,\r\n types : types,\r\n util : util\r\n });\r\n this.verify = verifier(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.fromObject = converter.fromObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.toObject = converter.toObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n\r\n // Inject custom wrappers for common types\r\n var wrapper = wrappers[fullName];\r\n if (wrapper) {\r\n var originalThis = Object.create(this);\r\n // if (wrapper.fromObject) {\r\n originalThis.fromObject = this.fromObject;\r\n this.fromObject = wrapper.fromObject.bind(originalThis);\r\n // }\r\n // if (wrapper.toObject) {\r\n originalThis.toObject = this.toObject;\r\n this.toObject = wrapper.toObject.bind(originalThis);\r\n // }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encode = function encode_setup(message, writer) {\r\n return this.setup().encode(message, writer); // overrides this method\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim();\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @param {number} [length] Length of the message, if known beforehand\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError<{}>} If required fields are missing\r\n */\r\nType.prototype.decode = function decode_setup(reader, length) {\r\n return this.setup().decode(reader, length); // overrides this method\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its byte length as a varint.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError} If required fields are missing\r\n */\r\nType.prototype.decodeDelimited = function decodeDelimited(reader) {\r\n if (!(reader instanceof Reader))\r\n reader = Reader.create(reader);\r\n return this.decode(reader, reader.uint32());\r\n};\r\n\r\n/**\r\n * Verifies that field values are valid and that required fields are present.\r\n * @param {Object.} message Plain object to verify\r\n * @returns {null|string} `null` if valid, otherwise the reason why it is not\r\n */\r\nType.prototype.verify = function verify_setup(message) {\r\n return this.setup().verify(message); // overrides this method\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object to convert\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.fromObject = function fromObject(object) {\r\n return this.setup().fromObject(object);\r\n};\r\n\r\n/**\r\n * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}.\r\n * @interface IConversionOptions\r\n * @property {Function} [longs] Long conversion type.\r\n * Valid values are `String` and `Number` (the global types).\r\n * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library.\r\n * @property {Function} [enums] Enum value conversion type.\r\n * Only valid value is `String` (the global type).\r\n * Defaults to copy the present value, which is the numeric id.\r\n * @property {Function} [bytes] Bytes value conversion type.\r\n * Valid values are `Array` and (a base64 encoded) `String` (the global types).\r\n * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser.\r\n * @property {boolean} [defaults=false] Also sets default values on the resulting object\r\n * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false`\r\n * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false`\r\n * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any\r\n * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings\r\n */\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n */\r\nType.prototype.toObject = function toObject(message, options) {\r\n return this.setup().toObject(message, options);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Type.d} (TypeScript).\r\n * @typedef TypeDecorator\r\n * @type {function}\r\n * @param {Constructor} target Target constructor\r\n * @returns {undefined}\r\n * @template T extends Message\r\n */\r\n\r\n/**\r\n * Type decorator (TypeScript).\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {TypeDecorator} Decorator function\r\n * @template T extends Message\r\n */\r\nType.d = function decorateType(typeName) {\r\n return function typeDecorator(target) {\r\n util.decorateType(target, typeName);\r\n };\r\n};\r\n","\"use strict\";\r\n\r\n/**\r\n * Common type constants.\r\n * @namespace\r\n */\r\nvar types = exports;\r\n\r\nvar util = require(33);\r\n\r\nvar s = [\r\n \"double\", // 0\r\n \"float\", // 1\r\n \"int32\", // 2\r\n \"uint32\", // 3\r\n \"sint32\", // 4\r\n \"fixed32\", // 5\r\n \"sfixed32\", // 6\r\n \"int64\", // 7\r\n \"uint64\", // 8\r\n \"sint64\", // 9\r\n \"fixed64\", // 10\r\n \"sfixed64\", // 11\r\n \"bool\", // 12\r\n \"string\", // 13\r\n \"bytes\" // 14\r\n];\r\n\r\nfunction bake(values, offset) {\r\n var i = 0, o = {};\r\n offset |= 0;\r\n while (i < values.length) o[s[i + offset]] = values[i++];\r\n return o;\r\n}\r\n\r\n/**\r\n * Basic type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n * @property {number} bytes=2 Ldelim wire type\r\n */\r\ntypes.basic = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2,\r\n /* bytes */ 2\r\n]);\r\n\r\n/**\r\n * Basic type defaults.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=0 Double default\r\n * @property {number} float=0 Float default\r\n * @property {number} int32=0 Int32 default\r\n * @property {number} uint32=0 Uint32 default\r\n * @property {number} sint32=0 Sint32 default\r\n * @property {number} fixed32=0 Fixed32 default\r\n * @property {number} sfixed32=0 Sfixed32 default\r\n * @property {number} int64=0 Int64 default\r\n * @property {number} uint64=0 Uint64 default\r\n * @property {number} sint64=0 Sint32 default\r\n * @property {number} fixed64=0 Fixed64 default\r\n * @property {number} sfixed64=0 Sfixed64 default\r\n * @property {boolean} bool=false Bool default\r\n * @property {string} string=\"\" String default\r\n * @property {Array.} bytes=Array(0) Bytes default\r\n * @property {null} message=null Message default\r\n */\r\ntypes.defaults = bake([\r\n /* double */ 0,\r\n /* float */ 0,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 0,\r\n /* sfixed32 */ 0,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 0,\r\n /* sfixed64 */ 0,\r\n /* bool */ false,\r\n /* string */ \"\",\r\n /* bytes */ util.emptyArray,\r\n /* message */ null\r\n]);\r\n\r\n/**\r\n * Basic long type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n */\r\ntypes.long = bake([\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1\r\n], 7);\r\n\r\n/**\r\n * Allowed types for map keys with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n */\r\ntypes.mapKey = bake([\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2\r\n], 2);\r\n\r\n/**\r\n * Allowed types for packed repeated fields with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n */\r\ntypes.packed = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0\r\n]);\r\n","\"use strict\";\r\n\r\n/**\r\n * Various utility functions.\r\n * @namespace\r\n */\r\nvar util = module.exports = require(35);\r\n\r\nvar roots = require(27);\r\n\r\nvar Type, // cyclic\r\n Enum;\r\n\r\nutil.codegen = require(3);\r\nutil.fetch = require(5);\r\nutil.path = require(8);\r\n\r\n/**\r\n * Node's fs module if available.\r\n * @type {Object.}\r\n */\r\nutil.fs = util.inquire(\"fs\");\r\n\r\n/**\r\n * Converts an object's values to an array.\r\n * @param {Object.} object Object to convert\r\n * @returns {Array.<*>} Converted array\r\n */\r\nutil.toArray = function toArray(object) {\r\n if (object) {\r\n var keys = Object.keys(object),\r\n array = new Array(keys.length),\r\n index = 0;\r\n while (index < keys.length)\r\n array[index] = object[keys[index++]];\r\n return array;\r\n }\r\n return [];\r\n};\r\n\r\n/**\r\n * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values.\r\n * @param {Array.<*>} array Array to convert\r\n * @returns {Object.} Converted object\r\n */\r\nutil.toObject = function toObject(array) {\r\n var object = {},\r\n index = 0;\r\n while (index < array.length) {\r\n var key = array[index++],\r\n val = array[index++];\r\n if (val !== undefined)\r\n object[key] = val;\r\n }\r\n return object;\r\n};\r\n\r\nvar safePropBackslashRe = /\\\\/g,\r\n safePropQuoteRe = /\"/g;\r\n\r\n/**\r\n * Tests whether the specified name is a reserved word in JS.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nutil.isReserved = function isReserved(name) {\r\n return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name);\r\n};\r\n\r\n/**\r\n * Returns a safe property accessor for the specified property name.\r\n * @param {string} prop Property name\r\n * @returns {string} Safe accessor\r\n */\r\nutil.safeProp = function safeProp(prop) {\r\n if (!/^[$\\w_]+$/.test(prop) || util.isReserved(prop))\r\n return \"[\\\"\" + prop.replace(safePropBackslashRe, \"\\\\\\\\\").replace(safePropQuoteRe, \"\\\\\\\"\") + \"\\\"]\";\r\n return \".\" + prop;\r\n};\r\n\r\n/**\r\n * Converts the first character of a string to upper case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.ucFirst = function ucFirst(str) {\r\n return str.charAt(0).toUpperCase() + str.substring(1);\r\n};\r\n\r\nvar camelCaseRe = /_([a-z])/g;\r\n\r\n/**\r\n * Converts a string to camel case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.camelCase = function camelCase(str) {\r\n return str.substring(0, 1)\r\n + str.substring(1)\r\n .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); });\r\n};\r\n\r\n/**\r\n * Compares reflected fields by id.\r\n * @param {Field} a First field\r\n * @param {Field} b Second field\r\n * @returns {number} Comparison value\r\n */\r\nutil.compareFieldsById = function compareFieldsById(a, b) {\r\n return a.id - b.id;\r\n};\r\n\r\n/**\r\n * Decorator helper for types (TypeScript).\r\n * @param {Constructor} ctor Constructor function\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {Type} Reflected type\r\n * @template T extends Message\r\n * @property {Root} root Decorators root\r\n */\r\nutil.decorateType = function decorateType(ctor, typeName) {\r\n\r\n /* istanbul ignore if */\r\n if (ctor.$type) {\r\n if (typeName && ctor.$type.name !== typeName) {\r\n util.decorateRoot.remove(ctor.$type);\r\n ctor.$type.name = typeName;\r\n util.decorateRoot.add(ctor.$type);\r\n }\r\n return ctor.$type;\r\n }\r\n\r\n /* istanbul ignore next */\r\n if (!Type)\r\n Type = require(31);\r\n\r\n var type = new Type(typeName || ctor.name);\r\n util.decorateRoot.add(type);\r\n type.ctor = ctor; // sets up .encode, .decode etc.\r\n Object.defineProperty(ctor, \"$type\", { value: type, enumerable: false });\r\n Object.defineProperty(ctor.prototype, \"$type\", { value: type, enumerable: false });\r\n return type;\r\n};\r\n\r\nvar decorateEnumIndex = 0;\r\n\r\n/**\r\n * Decorator helper for enums (TypeScript).\r\n * @param {Object} object Enum object\r\n * @returns {Enum} Reflected enum\r\n */\r\nutil.decorateEnum = function decorateEnum(object) {\r\n\r\n /* istanbul ignore if */\r\n if (object.$type)\r\n return object.$type;\r\n\r\n /* istanbul ignore next */\r\n if (!Enum)\r\n Enum = require(14);\r\n\r\n var enm = new Enum(\"Enum\" + decorateEnumIndex++, object);\r\n util.decorateRoot.add(enm);\r\n Object.defineProperty(object, \"$type\", { value: enm, enumerable: false });\r\n return enm;\r\n};\r\n\r\n/**\r\n * Decorator root (TypeScript).\r\n * @name util.decorateRoot\r\n * @type {Root}\r\n * @readonly\r\n */\r\nObject.defineProperty(util, \"decorateRoot\", {\r\n get: function() {\r\n return roots[\"decorated\"] || (roots[\"decorated\"] = new (require(26))());\r\n }\r\n});\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(4);\r\n\r\n// float handling accross browsers\r\nutil.float = require(6);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(7);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(10);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(9);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(34);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = verifier;\r\n\r\nvar Enum = require(14),\r\n util = require(33);\r\n\r\nfunction invalid(field, expected) {\r\n return field.name + \": \" + expected + (field.repeated && expected !== \"array\" ? \"[]\" : field.map && expected !== \"object\" ? \"{k:\"+field.keyType+\"}\" : \"\") + \" expected\";\r\n}\r\n\r\n/**\r\n * Generates a partial value verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyValue(gen, field, fieldIndex, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(%s){\", ref)\r\n (\"default:\")\r\n (\"return%j\", invalid(field, \"enum value\"));\r\n for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen\r\n (\"case %i:\", field.resolvedType.values[keys[j]]);\r\n gen\r\n (\"break\")\r\n (\"}\");\r\n } else {\r\n gen\r\n (\"{\")\r\n (\"var e=types[%i].verify(%s);\", fieldIndex, ref)\r\n (\"if(e)\")\r\n (\"return%j+e\", field.name + \".\")\r\n (\"}\");\r\n }\r\n } else {\r\n switch (field.type) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.isInteger(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))\", ref, ref, ref, ref)\r\n (\"return%j\", invalid(field, \"integer|Long\"));\r\n break;\r\n case \"float\":\r\n case \"double\": gen\r\n (\"if(typeof %s!==\\\"number\\\")\", ref)\r\n (\"return%j\", invalid(field, \"number\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(typeof %s!==\\\"boolean\\\")\", ref)\r\n (\"return%j\", invalid(field, \"boolean\"));\r\n break;\r\n case \"string\": gen\r\n (\"if(!util.isString(%s))\", ref)\r\n (\"return%j\", invalid(field, \"string\"));\r\n break;\r\n case \"bytes\": gen\r\n (\"if(!(%s&&typeof %s.length===\\\"number\\\"||util.isString(%s)))\", ref, ref, ref)\r\n (\"return%j\", invalid(field, \"buffer\"));\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a partial key verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyKey(gen, field, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n switch (field.keyType) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.key32Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer key\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.key64Re.test(%s))\", ref) // see comment above: x is ok, d is not\r\n (\"return%j\", invalid(field, \"integer|Long key\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(!util.key2Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"boolean key\"));\r\n break;\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a verifier specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction verifier(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n\r\n var gen = util.codegen([\"m\"], mtype.name + \"$verify\")\r\n (\"if(typeof m!==\\\"object\\\"||m===null)\")\r\n (\"return%j\", \"object expected\");\r\n var oneofs = mtype.oneofsArray,\r\n seenFirstField = {};\r\n if (oneofs.length) gen\r\n (\"var p={}\");\r\n\r\n for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name); // !== undefined && !== null\r\n\r\n // map fields\r\n if (field.map) { gen\r\n (\"if(!util.isObject(%s))\", ref)\r\n (\"return%j\", invalid(field, \"object\"))\r\n (\"var k=Object.keys(%s)\", ref)\r\n (\"for(var i=0;i}\r\n * @const\r\n */\r\nvar wrappers = exports;\r\n\r\nvar Message = require(19);\r\n\r\n/**\r\n * From object converter part of an {@link IWrapper}.\r\n * @typedef WrapperFromObjectConverter\r\n * @type {function}\r\n * @param {Object.} object Plain object\r\n * @returns {Message<{}>} Message instance\r\n * @this Type\r\n */\r\n\r\n/**\r\n * To object converter part of an {@link IWrapper}.\r\n * @typedef WrapperToObjectConverter\r\n * @type {function}\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @this Type\r\n */\r\n\r\n/**\r\n * Common type wrapper part of {@link wrappers}.\r\n * @interface IWrapper\r\n * @property {WrapperFromObjectConverter} [fromObject] From object converter\r\n * @property {WrapperToObjectConverter} [toObject] To object converter\r\n */\r\n\r\n// Custom wrapper for Any\r\nwrappers[\".google.protobuf.Any\"] = {\r\n\r\n fromObject: function(object) {\r\n\r\n // unwrap value type if mapped\r\n if (object && object[\"@type\"]) {\r\n var type = this.lookup(object[\"@type\"]);\r\n /* istanbul ignore else */\r\n if (type) {\r\n // type_url does not accept leading \".\"\r\n var type_url = object[\"@type\"].charAt(0) === \".\" ?\r\n object[\"@type\"].substr(1) : object[\"@type\"];\r\n // type_url prefix is optional, but path seperator is required\r\n return this.create({\r\n type_url: \"/\" + type_url,\r\n value: type.encode(type.fromObject(object)).finish()\r\n });\r\n }\r\n }\r\n\r\n return this.fromObject(object);\r\n },\r\n\r\n toObject: function(message, options) {\r\n\r\n // decode value if requested and unmapped\r\n if (options && options.json && message.type_url && message.value) {\r\n // Only use fully qualified type name after the last '/'\r\n var name = message.type_url.substring(message.type_url.lastIndexOf(\"/\") + 1);\r\n var type = this.lookup(name);\r\n /* istanbul ignore else */\r\n if (type)\r\n message = type.decode(message.value);\r\n }\r\n\r\n // wrap value if unmapped\r\n if (!(message instanceof this.ctor) && message instanceof Message) {\r\n var object = message.$type.toObject(message, options);\r\n object[\"@type\"] = message.$type.fullName;\r\n return object;\r\n }\r\n\r\n return this.toObject(message, options);\r\n }\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(35);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(38);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(35);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/dist/light/protobuf.min.js b/node_modules/protobufjs/dist/light/protobuf.min.js new file mode 100644 index 0000000..3a09f75 --- /dev/null +++ b/node_modules/protobufjs/dist/light/protobuf.min.js @@ -0,0 +1,8 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:26 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +!function(g){"use strict";var r,e,t,i;r={1:[function(t,i){i.exports=function(t,i){var n=Array(arguments.length-1),s=0,r=2,u=!0;for(;r>2],r=(3&f)<<4,o=1;break;case 1:s[u++]=h[r|f>>4],r=(15&f)<<2,o=2;break;case 2:s[u++]=h[r|f>>6],s[u++]=h[63&f],o=0}8191>4,r=o,s=2;break;case 2:i[n++]=(15&r)<<4|(60&o)>>2,r=o,s=3;break;case 3:i[n++]=(3&r)<<6|o,s=0}}if(1===s)throw Error(c);return n-e},r.test=function(t){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(t)}},{}],3:[function(t,i){function a(i,n){"string"==typeof i&&(n=i,i=g);var f=[];function h(t){if("string"!=typeof t){var i=c();if(a.verbose&&console.log("codegen: "+i),i="return "+i,t){for(var n=Object.keys(t),r=Array(n.length+1),e=Array(n.length),s=0;s>>0,n,r);else if(i<11754943508222875e-54)t((e<<31|Math.round(i/1401298464324817e-60))>>>0,n,r);else{var s=Math.floor(Math.log(i)/Math.LN2);t((e<<31|s+127<<23|8388607&Math.round(i*Math.pow(2,-s)*8388608))>>>0,n,r)}}function i(t,i,n){var r=t(i,n),e=2*(r>>31)+1,s=r>>>23&255,u=8388607&r;return 255===s?u?NaN:e*(1/0):0===s?1401298464324817e-60*e*u:e*Math.pow(2,s-150)*(u+8388608)}o.writeFloatLE=t.bind(null,r),o.writeFloatBE=t.bind(null,e),o.readFloatLE=i.bind(null,s),o.readFloatBE=i.bind(null,u)}(),"undefined"!=typeof Float64Array?function(){var r=new Float64Array([-0]),e=new Uint8Array(r.buffer),t=128===e[7];function i(t,i,n){r[0]=t,i[n]=e[0],i[n+1]=e[1],i[n+2]=e[2],i[n+3]=e[3],i[n+4]=e[4],i[n+5]=e[5],i[n+6]=e[6],i[n+7]=e[7]}function n(t,i,n){r[0]=t,i[n]=e[7],i[n+1]=e[6],i[n+2]=e[5],i[n+3]=e[4],i[n+4]=e[3],i[n+5]=e[2],i[n+6]=e[1],i[n+7]=e[0]}function s(t,i){return e[0]=t[i],e[1]=t[i+1],e[2]=t[i+2],e[3]=t[i+3],e[4]=t[i+4],e[5]=t[i+5],e[6]=t[i+6],e[7]=t[i+7],r[0]}function u(t,i){return e[7]=t[i],e[6]=t[i+1],e[5]=t[i+2],e[4]=t[i+3],e[3]=t[i+4],e[2]=t[i+5],e[1]=t[i+6],e[0]=t[i+7],r[0]}o.writeDoubleLE=t?i:n,o.writeDoubleBE=t?n:i,o.readDoubleLE=t?s:u,o.readDoubleBE=t?u:s}():function(){function t(t,i,n,r,e,s){var u=r<0?1:0;if(u&&(r=-r),0===r)t(0,e,s+i),t(0<1/r?0:2147483648,e,s+n);else if(isNaN(r))t(0,e,s+i),t(2146959360,e,s+n);else if(17976931348623157e292>>0,e,s+n);else{var o;if(r<22250738585072014e-324)t((o=r/5e-324)>>>0,e,s+i),t((u<<31|o/4294967296)>>>0,e,s+n);else{var f=Math.floor(Math.log(r)/Math.LN2);1024===f&&(f=1023),t(4503599627370496*(o=r*Math.pow(2,-f))>>>0,e,s+i),t((u<<31|f+1023<<20|1048576*o&1048575)>>>0,e,s+n)}}}function i(t,i,n,r,e){var s=t(r,e+i),u=t(r,e+n),o=2*(u>>31)+1,f=u>>>20&2047,h=4294967296*(1048575&u)+s;return 2047===f?h?NaN:o*(1/0):0===f?5e-324*o*h:o*Math.pow(2,f-1075)*(h+4503599627370496)}o.writeDoubleLE=t.bind(null,r,0,4),o.writeDoubleBE=t.bind(null,e,4,0),o.readDoubleLE=i.bind(null,s,0,4),o.readDoubleBE=i.bind(null,u,4,0)}(),o}function r(t,i,n){i[n]=255&t,i[n+1]=t>>>8&255,i[n+2]=t>>>16&255,i[n+3]=t>>>24}function e(t,i,n){i[n]=t>>>24,i[n+1]=t>>>16&255,i[n+2]=t>>>8&255,i[n+3]=255&t}function s(t,i){return(t[i]|t[i+1]<<8|t[i+2]<<16|t[i+3]<<24)>>>0}function u(t,i){return(t[i]<<24|t[i+1]<<16|t[i+2]<<8|t[i+3])>>>0}i.exports=n(n)},{}],7:[function(t,i,n){function r(t){try{var i=eval("require")(t);if(i&&(i.length||Object.keys(i).length))return i}catch(t){}return null}i.exports=r},{}],8:[function(t,i,n){var r=n,s=r.isAbsolute=function(t){return/^(?:\/|\w+:)/.test(t)},e=r.normalize=function(t){var i=(t=t.replace(/\\/g,"/").replace(/\/{2,}/g,"/")).split("/"),n=s(t),r="";n&&(r=i.shift()+"/");for(var e=0;e>>1,u=null,o=e;return function(t){if(t<1||s>10),s[u++]=56320+(1023&r)):s[u++]=(15&r)<<12|(63&t[i++])<<6|63&t[i++],8191>6|192:(55296==(64512&r)&&56320==(64512&(e=t.charCodeAt(u+1)))?(r=65536+((1023&r)<<10)+(1023&e),++u,i[n++]=r>>18|240,i[n++]=r>>12&63|128):i[n++]=r>>12|224,i[n++]=r>>6&63|128),i[n++]=63&r|128);return n-s}},{}],11:[function(t,i,n){var r=n,l=t(14),v=t(33);function u(t,i,n,r){if(i.resolvedType)if(i.resolvedType instanceof l){t("switch(d%s){",r);for(var e=i.resolvedType.values,s=Object.keys(e),u=0;u>>0",r,r);break;case"int32":case"sint32":case"sfixed32":t("m%s=d%s|0",r,r);break;case"uint64":o=!0;case"int64":case"sint64":case"fixed64":case"sfixed64":t("if(util.Long)")("(m%s=util.Long.fromValue(d%s)).unsigned=%j",r,r,o)('else if(typeof d%s==="string")',r)("m%s=parseInt(d%s,10)",r,r)('else if(typeof d%s==="number")',r)("m%s=d%s",r,r)('else if(typeof d%s==="object")',r)("m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)",r,r,r,o?"true":"");break;case"bytes":t('if(typeof d%s==="string")',r)("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)",r,r,r)("else if(d%s.length)",r)("m%s=d%s",r,r);break;case"string":t("m%s=String(d%s)",r,r);break;case"bool":t("m%s=Boolean(d%s)",r,r)}}return t}function d(t,i,n,r){if(i.resolvedType)i.resolvedType instanceof l?t("d%s=o.enums===String?types[%i].values[m%s]:m%s",r,n,r,r):t("d%s=types[%i].toObject(m%s,o)",r,n,r);else{var e=!1;switch(i.type){case"double":case"float":t("d%s=o.json&&!isFinite(m%s)?String(m%s):m%s",r,r,r,r);break;case"uint64":e=!0;case"int64":case"sint64":case"fixed64":case"sfixed64":t('if(typeof m%s==="number")',r)("d%s=o.longs===String?String(m%s):m%s",r,r,r)("else")("d%s=o.longs===String?util.Long.prototype.toString.call(m%s):o.longs===Number?new util.LongBits(m%s.low>>>0,m%s.high>>>0).toNumber(%s):m%s",r,r,r,r,e?"true":"",r);break;case"bytes":t("d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s",r,r,r,r,r);break;default:t("d%s=m%s",r,r)}}return t}r.fromObject=function(t){var i=t.fieldsArray,n=v.codegen(["d"],t.name+"$fromObject")("if(d instanceof this.ctor)")("return d");if(!i.length)return n("return new this.ctor");n("var m=new this.ctor");for(var r=0;r>>3){");for(var n=0;n>>0,8|c.mapKey[s.keyType],s.keyType),f===g?n("types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()",u,i):n(".uint32(%i).%s(%s[ks[i]]).ldelim()",16|f,o,i),n("}")("}")):s.repeated?(n("if(%s!=null&&%s.length){",i,i),s.packed&&c.packed[o]!==g?n("w.uint32(%i).fork()",(s.id<<3|2)>>>0)("for(var i=0;i<%s.length;++i)",i)("w.%s(%s[i])",o,i)("w.ldelim()"):(n("for(var i=0;i<%s.length;++i)",i),f===g?l(n,s,u,i+"[i]"):n("w.uint32(%i).%s(%s[i])",(s.id<<3|f)>>>0,o,i)),n("}")):(s.optional&&n("if(%s!=null&&m.hasOwnProperty(%j))",i,s.name),f===g?l(n,s,u,i):n("w.uint32(%i).%s(%s)",(s.id<<3|f)>>>0,o,i))}return n("return w")};var h=t(14),c=t(32),a=t(33);function l(t,i,n,r){return i.resolvedType.group?t("types[%i].encode(%s,w.uint32(%i)).uint32(%i)",n,r,(i.id<<3|3)>>>0,(i.id<<3|4)>>>0):t("types[%i].encode(%s,w.uint32(%i).fork()).ldelim()",n,r,(i.id<<3|2)>>>0)}},{14:14,32:32,33:33}],14:[function(t,i){i.exports=e;var o=t(22);((e.prototype=Object.create(o.prototype)).constructor=e).className="Enum";var n=t(21),r=t(33);function e(t,i,n,r,e){if(o.call(this,t,n),i&&"object"!=typeof i)throw TypeError("values must be an object");if(this.valuesById={},this.values=Object.create(this.valuesById),this.comment=r,this.comments=e||{},this.reserved=g,i)for(var s=Object.keys(i),u=0;u=i)return!0;return!1},h.isReservedName=function(t,i){if(t)for(var n=0;n "+t.len)}function o(t){this.buf=t,this.pos=0,this.len=t.length}var f,h="undefined"!=typeof Uint8Array?function(t){if(t instanceof Uint8Array||Array.isArray(t))return new o(t);throw Error("illegal buffer")}:function(t){if(Array.isArray(t))return new o(t);throw Error("illegal buffer")};function c(){var t=new e(0,0),i=0;if(!(4=this.len)throw u(this);if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*i)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(127&this.buf[this.pos++])<<7*i)>>>0,t}for(;i<4;++i)if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*i)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(127&this.buf[this.pos])<<28)>>>0,t.hi=(t.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return t;if(i=0,4>>0,this.buf[this.pos++]<128)return t}else for(;i<5;++i){if(this.pos>=this.len)throw u(this);if(t.hi=(t.hi|(127&this.buf[this.pos])<<7*i+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}function a(t,i){return(t[i-4]|t[i-3]<<8|t[i-2]<<16|t[i-1]<<24)>>>0}function l(){if(this.pos+8>this.len)throw u(this,8);return new e(a(this.buf,this.pos+=4),a(this.buf,this.pos+=4))}o.create=r.Buffer?function(t){return(o.create=function(t){return r.Buffer.isBuffer(t)?new n(t):h(t)})(t)}:h,o.prototype.f=r.Array.prototype.subarray||r.Array.prototype.slice,o.prototype.uint32=(f=4294967295,function(){if(f=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return f;if((this.pos+=5)>this.len)throw this.pos=this.len,u(this,10);return f}),o.prototype.int32=function(){return 0|this.uint32()},o.prototype.sint32=function(){var t=this.uint32();return t>>>1^-(1&t)|0},o.prototype.bool=function(){return 0!==this.uint32()},o.prototype.fixed32=function(){if(this.pos+4>this.len)throw u(this,4);return a(this.buf,this.pos+=4)},o.prototype.sfixed32=function(){if(this.pos+4>this.len)throw u(this,4);return 0|a(this.buf,this.pos+=4)},o.prototype.float=function(){if(this.pos+4>this.len)throw u(this,4);var t=r.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t},o.prototype.double=function(){if(this.pos+8>this.len)throw u(this,4);var t=r.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t},o.prototype.bytes=function(){var t=this.uint32(),i=this.pos,n=this.pos+t;if(n>this.len)throw u(this,t);return this.pos+=t,Array.isArray(this.buf)?this.buf.slice(i,n):i===n?new this.buf.constructor(0):this.f.call(this.buf,i,n)},o.prototype.string=function(){var t=this.bytes();return s.read(t,0,t.length)},o.prototype.skip=function(t){if("number"==typeof t){if(this.pos+t>this.len)throw u(this,t);this.pos+=t}else do{if(this.pos>=this.len)throw u(this)}while(128&this.buf[this.pos++]);return this},o.prototype.skipType=function(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(t=7&this.uint32());)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+t+" at offset "+this.pos)}return this},o.r=function(t){n=t;var i=r.Long?"toLong":"toNumber";r.merge(o.prototype,{int64:function(){return c.call(this)[i](!1)},uint64:function(){return c.call(this)[i](!0)},sint64:function(){return c.call(this).zzDecode()[i](!1)},fixed64:function(){return l.call(this)[i](!0)},sfixed64:function(){return l.call(this)[i](!1)}})}},{35:35}],25:[function(t,i){i.exports=e;var n=t(24);(e.prototype=Object.create(n.prototype)).constructor=e;var r=t(35);function e(t){n.call(this,t)}r.Buffer&&(e.prototype.f=r.Buffer.prototype.slice),e.prototype.string=function(){var t=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len))}},{24:24,35:35}],26:[function(t,i){i.exports=n;var r=t(21);((n.prototype=Object.create(r.prototype)).constructor=n).className="Root";var e,v,d,s=t(15),u=t(14),o=t(23),b=t(33);function n(t){r.call(this,"",t),this.deferred=[],this.files=[]}function y(){}n.fromJSON=function(t,i){return i||(i=new n),t.options&&i.setOptions(t.options),i.addJSON(t.nested)},n.prototype.resolvePath=b.path.resolve,n.prototype.load=function t(i,s,u){"function"==typeof s&&(u=s,s=g);var o=this;if(!u)return b.asPromise(t,o,i,s);var f=u===y;function h(t,i){if(u){var n=u;if(u=null,f)throw t;n(t,i)}}function c(t,i){try{if(b.isString(i)&&"{"===i.charAt(0)&&(i=JSON.parse(i)),b.isString(i)){v.filename=t;var n,r=v(i,o,s),e=0;if(r.imports)for(;e>>0,this.hi=i>>>0}var s=e.zero=new e(0,0);s.toNumber=function(){return 0},s.zzEncode=s.zzDecode=function(){return this},s.length=function(){return 1};var r=e.zeroHash="\0\0\0\0\0\0\0\0";e.fromNumber=function(t){if(0===t)return s;var i=t<0;i&&(t=-t);var n=t>>>0,r=(t-n)/4294967296>>>0;return i&&(r=~r>>>0,n=~n>>>0,4294967295<++n&&(n=0,4294967295<++r&&(r=0))),new e(n,r)},e.from=function(t){if("number"==typeof t)return e.fromNumber(t);if(n.isString(t)){if(!n.Long)return e.fromNumber(parseInt(t,10));t=n.Long.fromString(t)}return t.low||t.high?new e(t.low>>>0,t.high>>>0):s},e.prototype.toNumber=function(t){if(!t&&this.hi>>>31){var i=1+~this.lo>>>0,n=~this.hi>>>0;return i||(n=n+1>>>0),-(i+4294967296*n)}return this.lo+4294967296*this.hi},e.prototype.toLong=function(t){return n.Long?new n.Long(0|this.lo,0|this.hi,!!t):{low:0|this.lo,high:0|this.hi,unsigned:!!t}};var u=String.prototype.charCodeAt;e.fromHash=function(t){return t===r?s:new e((u.call(t,0)|u.call(t,1)<<8|u.call(t,2)<<16|u.call(t,3)<<24)>>>0,(u.call(t,4)|u.call(t,5)<<8|u.call(t,6)<<16|u.call(t,7)<<24)>>>0)},e.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},e.prototype.zzEncode=function(){var t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this},e.prototype.zzDecode=function(){var t=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this},e.prototype.length=function(){var t=this.lo,i=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return 0===n?0===i?t<16384?t<128?1:2:t<2097152?3:4:i<16384?i<128?5:6:i<2097152?7:8:n<128?9:10}},{35:35}],35:[function(t,i,n){var r=n;function e(t,i,n){for(var r=Object.keys(i),e=0;e>>7|t.hi<<25)>>>0,t.hi>>>=7;for(;127>>7;i[n++]=t.lo}function d(t,i,n){i[n]=255&t,i[n+1]=t>>>8&255,i[n+2]=t>>>16&255,i[n+3]=t>>>24}c.create=r.Buffer?function(){return(c.create=function(){return new n})()}:function(){return new c},c.alloc=function(t){return new r.Array(t)},r.Array!==Array&&(c.alloc=r.pool(c.alloc,r.Array.prototype.subarray)),c.prototype.y=function(t,i,n){return this.tail=this.tail.next=new o(t,i,n),this.len+=i,this},(l.prototype=Object.create(o.prototype)).fn=function(t,i,n){for(;127>>=7;i[n]=t},c.prototype.uint32=function(t){return this.len+=(this.tail=this.tail.next=new l((t>>>=0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this},c.prototype.int32=function(t){return t<0?this.y(v,10,e.fromNumber(t)):this.uint32(t)},c.prototype.sint32=function(t){return this.uint32((t<<1^t>>31)>>>0)},c.prototype.int64=c.prototype.uint64=function(t){var i=e.from(t);return this.y(v,i.length(),i)},c.prototype.sint64=function(t){var i=e.from(t).zzEncode();return this.y(v,i.length(),i)},c.prototype.bool=function(t){return this.y(a,1,t?1:0)},c.prototype.sfixed32=c.prototype.fixed32=function(t){return this.y(d,4,t>>>0)},c.prototype.sfixed64=c.prototype.fixed64=function(t){var i=e.from(t);return this.y(d,4,i.lo).y(d,4,i.hi)},c.prototype.float=function(t){return this.y(r.float.writeFloatLE,4,t)},c.prototype.double=function(t){return this.y(r.float.writeDoubleLE,8,t)};var b=r.Array.prototype.set?function(t,i,n){i.set(t,n)}:function(t,i,n){for(var r=0;r>>0;if(!i)return this.y(a,1,0);if(r.isString(t)){var n=c.alloc(i=s.length(t));s.decode(t,n,0),t=n}return this.uint32(i).y(b,i,t)},c.prototype.string=function(t){var i=u.length(t);return i?this.uint32(i).y(u.write,i,t):this.y(a,1,0)},c.prototype.fork=function(){return this.states=new h(this),this.head=this.tail=new o(f,0,0),this.len=0,this},c.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new o(f,0,0),this.len=0),this},c.prototype.ldelim=function(){var t=this.head,i=this.tail,n=this.len;return this.reset().uint32(n),n&&(this.tail.next=t.next,this.tail=i,this.len+=n),this},c.prototype.finish=function(){for(var t=this.head.next,i=this.constructor.alloc(this.len),n=0;t;)t.fn(t.val,i,n),n+=t.len,t=t.next;return i},c.r=function(t){n=t}},{35:35}],39:[function(t,i){i.exports=s;var n=t(38);(s.prototype=Object.create(n.prototype)).constructor=s;var r=t(35),e=r.Buffer;function s(){n.call(this)}s.alloc=function(t){return(s.alloc=r.b)(t)};var u=e&&e.prototype instanceof Uint8Array&&"set"===e.prototype.set.name?function(t,i,n){i.set(t,n)}:function(t,i,n){if(t.copy)t.copy(i,n,0,t.length);else for(var r=0;r>>0;return this.uint32(i),i&&this.y(u,i,t),this},s.prototype.string=function(t){var i=e.byteLength(t);return this.uint32(i),i&&this.y(o,i,t),this}},{35:35,38:38}]},e={},t=[16],i=function t(i){var n=e[i];return n||r[i][0].call(n=e[i]={exports:{}},t,n,n.exports),n.exports}(t[0]),i.util.global.protobuf=i,"function"==typeof define&&define.amd&&define(["long"],function(t){return t&&t.isLong&&(i.util.Long=t,i.configure()),i}),"object"==typeof module&&module&&module.exports&&(module.exports=i)}(); +//# sourceMappingURL=protobuf.min.js.map diff --git a/node_modules/protobufjs/dist/light/protobuf.min.js.map b/node_modules/protobufjs/dist/light/protobuf.min.js.map new file mode 100644 index 0000000..b99218f --- /dev/null +++ b/node_modules/protobufjs/dist/light/protobuf.min.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/codegen/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/fetch/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/path/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/converter.js","../src/decoder.js","../src/encoder.js","../src/enum.js","../src/field.js","../src/index-light","../src/index-minimal.js","../src/mapfield.js","../src/message.js","../src/method.js","../src/namespace.js","../src/object.js","../src/oneof.js","../src/reader.js","../src/reader_buffer.js","../src/root.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/service.js","../src/type.js","../src/types.js","../src/util.js","../src/util/longbits.js","../src/util/minimal.js","../src/verifier.js","../src/wrappers.js","../src/writer.js","../src/writer_buffer.js"],"names":["undefined","modules","cache","entries","protobuf","1","require","module","exports","fn","ctx","params","Array","arguments","length","offset","index","pending","Promise","resolve","reject","err","apply","base64","string","p","n","charAt","Math","ceil","b64","s64","i","encode","buffer","start","end","t","parts","chunk","j","b","push","String","fromCharCode","slice","join","invalidEncoding","decode","c","charCodeAt","Error","test","codegen","functionParams","functionName","body","Codegen","formatStringOrScope","source","toString","verbose","console","log","scopeKeys","Object","keys","scopeParams","scopeValues","scopeOffset","Function","formatParams","formatOffset","replace","$0","$1","value","floor","JSON","stringify","functionNameOverride","EventEmitter","this","_listeners","prototype","on","evt","off","listeners","splice","emit","args","fetch","asPromise","fs","inquire","filename","options","callback","xhr","readFile","contents","XMLHttpRequest","binary","onreadystatechange","readyState","status","response","responseText","Uint8Array","overrideMimeType","responseType","open","send","factory","Float32Array","f32","f8b","le","writeFloat_f32_cpy","val","buf","pos","writeFloat_f32_rev","readFloat_f32_cpy","readFloat_f32_rev","writeFloatLE","writeFloatBE","readFloatLE","readFloatBE","writeFloat_ieee754","writeUint","sign","isNaN","round","exponent","LN2","pow","readFloat_ieee754","readUint","uint","mantissa","NaN","Infinity","bind","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","f64","writeDouble_f64_cpy","writeDouble_f64_rev","readDouble_f64_cpy","readDouble_f64_rev","writeDoubleLE","writeDoubleBE","readDoubleLE","readDoubleBE","writeDouble_ieee754","off0","off1","readDouble_ieee754","lo","hi","moduleName","mod","eval","e","path","isAbsolute","normalize","split","absolute","prefix","shift","originPath","includePath","alreadyNormalized","alloc","size","SIZE","MAX","slab","call","utf8","len","read","write","c1","c2","converter","Enum","util","genValuePartial_fromObject","gen","field","fieldIndex","prop","resolvedType","values","repeated","typeDefault","fullName","isUnsigned","type","genValuePartial_toObject","fromObject","mtype","fields","fieldsArray","name","safeProp","map","toObject","sort","compareFieldsById","repeatedFields","mapFields","normalFields","partOf","valuesById","long","low","high","unsigned","toNumber","bytes","arrayDefault","hasKs2","_fieldsArray","indexOf","filter","group","ref","id","keyType","types","basic","packed","rfield","required","wireType","mapKey","genTypePartial","optional","ReflectionObject","create","constructor","className","Namespace","comment","comments","TypeError","reserved","fromJSON","json","enm","toJSON","toJSONOptions","keepComments","add","isString","isInteger","isReservedId","isReservedName","allow_alias","remove","Field","Type","ruleRe","rule","extend","isObject","toLowerCase","message","defaultValue","Long","extensionField","declaringField","_packed","defineProperty","get","getOption","setOption","ifNotSet","resolved","defaults","parent","lookupTypeOrEnum","fromNumber","freeze","newBuffer","emptyObject","emptyArray","ctor","d","fieldId","fieldType","fieldRule","decorateType","decorateEnum","fieldName","default","_configure","Type_","build","load","root","Root","loadSync","encoder","decoder","verifier","OneOf","MapField","Service","Method","Message","wrappers","configure","Reader","BufferReader","Writer","BufferWriter","rpc","roots","resolvedKeyType","fieldKeyType","fieldValueType","properties","$type","writer","encodeDelimited","reader","decodeDelimited","verify","object","requestType","requestStream","responseStream","resolvedRequestType","resolvedResponseType","lookupType","arrayToJSON","array","obj","nested","_nestedArray","clearCache","namespace","addJSON","toArray","nestedArray","nestedJson","names","methods","getEnum","prev","setOptions","onAdd","onRemove","define","isArray","ptr","part","resolveAll","lookup","filterTypes","parentAlreadyChecked","found","lookupEnum","lookupService","Service_","Enum_","defineProperties","unshift","_handleAdd","_handleRemove","Root_","fieldNames","oneof","addFieldsToParent","oneofName","oneOfGetter","set","oneOfSetter","LongBits","indexOutOfRange","writeLength","RangeError","create_array","readLongVarint","bits","readFixed32_end","readFixed64","Buffer","isBuffer","_slice","subarray","uint32","int32","sint32","bool","fixed32","sfixed32","float","double","skip","skipType","BufferReader_","merge","int64","uint64","sint64","zzDecode","fixed64","sfixed64","utf8Slice","min","parse","common","deferred","files","SYNC","resolvePath","self","sync","finish","cb","process","parsed","imports","weakImports","queued","weak","idx","lastIndexOf","altname","substring","setTimeout","readFileSync","isNode","exposeRe","tryHandleExtension","extendedType","sisterField","parse_","common_","rpcImpl","requestDelimited","responseDelimited","rpcCall","method","requestCtor","responseCtor","request","endedByRPC","_methodsArray","service","inherited","methodsArray","rpcService","methodName","lcFirst","isReserved","m","q","s","oneofs","extensions","_fieldsById","_oneofsArray","_ctor","fieldsById","oneofsArray","generateConstructor","ctorProperties","setup","wrapper","originalThis","fork","ldelim","typeName","target","bake","o","key","safePropBackslashRe","safePropQuoteRe","ucFirst","str","toUpperCase","camelCaseRe","camelCase","a","decorateRoot","enumerable","decorateEnumIndex","zero","zzEncode","zeroHash","from","parseInt","fromString","toLong","fromHash","hash","toHash","mask","part0","part1","part2","dst","src","newError","CustomError","captureStackTrace","stack","pool","global","window","versions","node","Number","isFinite","isset","isSet","hasOwnProperty","utf8Write","_Buffer_from","_Buffer_allocUnsafe","sizeOrArray","dcodeIO","key2Re","key32Re","key64Re","longToHash","longFromHash","fromBits","ProtocolError","fieldMap","longs","enums","encoding","allocUnsafe","seenFirstField","invalid","genVerifyKey","genVerifyValue","oneofProp","expected","type_url","substr","Op","next","noop","State","head","tail","states","writeByte","VarintOp","writeVarint64","writeFixed32","_push","writeBytes","reset","BufferWriter_","writeBytesBuffer","copy","writeStringBuffer","byteLength","$require","$module","amd","isLong"],"mappings":"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","file":"protobuf.min.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = codegen;\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @param {string[]} functionParams Function parameter names\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n */\r\nfunction codegen(functionParams, functionName) {\r\n\r\n /* istanbul ignore if */\r\n if (typeof functionParams === \"string\") {\r\n functionName = functionParams;\r\n functionParams = undefined;\r\n }\r\n\r\n var body = [];\r\n\r\n /**\r\n * Appends code to the function's body or finishes generation.\r\n * @typedef Codegen\r\n * @type {function}\r\n * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any\r\n * @param {...*} [formatParams] Format parameters\r\n * @returns {Codegen|Function} Itself or the generated function if finished\r\n * @throws {Error} If format parameter counts do not match\r\n */\r\n\r\n function Codegen(formatStringOrScope) {\r\n // note that explicit array handling below makes this ~50% faster\r\n\r\n // finish the function\r\n if (typeof formatStringOrScope !== \"string\") {\r\n var source = toString();\r\n if (codegen.verbose)\r\n console.log(\"codegen: \" + source); // eslint-disable-line no-console\r\n source = \"return \" + source;\r\n if (formatStringOrScope) {\r\n var scopeKeys = Object.keys(formatStringOrScope),\r\n scopeParams = new Array(scopeKeys.length + 1),\r\n scopeValues = new Array(scopeKeys.length),\r\n scopeOffset = 0;\r\n while (scopeOffset < scopeKeys.length) {\r\n scopeParams[scopeOffset] = scopeKeys[scopeOffset];\r\n scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]];\r\n }\r\n scopeParams[scopeOffset] = source;\r\n return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func\r\n }\r\n return Function(source)(); // eslint-disable-line no-new-func\r\n }\r\n\r\n // otherwise append to body\r\n var formatParams = new Array(arguments.length - 1),\r\n formatOffset = 0;\r\n while (formatOffset < formatParams.length)\r\n formatParams[formatOffset] = arguments[++formatOffset];\r\n formatOffset = 0;\r\n formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) {\r\n var value = formatParams[formatOffset++];\r\n switch ($1) {\r\n case \"d\": case \"f\": return String(Number(value));\r\n case \"i\": return String(Math.floor(value));\r\n case \"j\": return JSON.stringify(value);\r\n case \"s\": return String(value);\r\n }\r\n return \"%\";\r\n });\r\n if (formatOffset !== formatParams.length)\r\n throw Error(\"parameter count mismatch\");\r\n body.push(formatStringOrScope);\r\n return Codegen;\r\n }\r\n\r\n function toString(functionNameOverride) {\r\n return \"function \" + (functionNameOverride || functionName || \"\") + \"(\" + (functionParams && functionParams.join(\",\") || \"\") + \"){\\n \" + body.join(\"\\n \") + \"\\n}\";\r\n }\r\n\r\n Codegen.toString = toString;\r\n return Codegen;\r\n}\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @function codegen\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * When set to `true`, codegen will log generated code to console. Useful for debugging.\r\n * @name util.codegen.verbose\r\n * @type {boolean}\r\n */\r\ncodegen.verbose = false;\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = fetch;\r\n\r\nvar asPromise = require(1),\r\n inquire = require(7);\r\n\r\nvar fs = inquire(\"fs\");\r\n\r\n/**\r\n * Node-style callback as used by {@link util.fetch}.\r\n * @typedef FetchCallback\r\n * @type {function}\r\n * @param {?Error} error Error, if any, otherwise `null`\r\n * @param {string} [contents] File contents, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Options as used by {@link util.fetch}.\r\n * @typedef FetchOptions\r\n * @type {Object}\r\n * @property {boolean} [binary=false] Whether expecting a binary response\r\n * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @memberof util\r\n * @param {string} filename File path or url\r\n * @param {FetchOptions} options Fetch options\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nfunction fetch(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = {};\r\n } else if (!options)\r\n options = {};\r\n\r\n if (!callback)\r\n return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this\r\n\r\n // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found.\r\n if (!options.xhr && fs && fs.readFile)\r\n return fs.readFile(filename, function fetchReadFileCallback(err, contents) {\r\n return err && typeof XMLHttpRequest !== \"undefined\"\r\n ? fetch.xhr(filename, options, callback)\r\n : err\r\n ? callback(err)\r\n : callback(null, options.binary ? contents : contents.toString(\"utf8\"));\r\n });\r\n\r\n // use the XHR version otherwise.\r\n return fetch.xhr(filename, options, callback);\r\n}\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchOptions} [options] Fetch options\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n\r\n/**/\r\nfetch.xhr = function fetch_xhr(filename, options, callback) {\r\n var xhr = new XMLHttpRequest();\r\n xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() {\r\n\r\n if (xhr.readyState !== 4)\r\n return undefined;\r\n\r\n // local cors security errors return status 0 / empty string, too. afaik this cannot be\r\n // reliably distinguished from an actually empty file for security reasons. feel free\r\n // to send a pull request if you are aware of a solution.\r\n if (xhr.status !== 0 && xhr.status !== 200)\r\n return callback(Error(\"status \" + xhr.status));\r\n\r\n // if binary data is expected, make sure that some sort of array is returned, even if\r\n // ArrayBuffers are not supported. the binary string fallback, however, is unsafe.\r\n if (options.binary) {\r\n var buffer = xhr.response;\r\n if (!buffer) {\r\n buffer = [];\r\n for (var i = 0; i < xhr.responseText.length; ++i)\r\n buffer.push(xhr.responseText.charCodeAt(i) & 255);\r\n }\r\n return callback(null, typeof Uint8Array !== \"undefined\" ? new Uint8Array(buffer) : buffer);\r\n }\r\n return callback(null, xhr.responseText);\r\n };\r\n\r\n if (options.binary) {\r\n // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers\r\n if (\"overrideMimeType\" in xhr)\r\n xhr.overrideMimeType(\"text/plain; charset=x-user-defined\");\r\n xhr.responseType = \"arraybuffer\";\r\n }\r\n\r\n xhr.open(\"GET\", filename);\r\n xhr.send();\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal path module to resolve Unix, Windows and URL paths alike.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar path = exports;\r\n\r\nvar isAbsolute =\r\n/**\r\n * Tests if the specified path is absolute.\r\n * @param {string} path Path to test\r\n * @returns {boolean} `true` if path is absolute\r\n */\r\npath.isAbsolute = function isAbsolute(path) {\r\n return /^(?:\\/|\\w+:)/.test(path);\r\n};\r\n\r\nvar normalize =\r\n/**\r\n * Normalizes the specified path.\r\n * @param {string} path Path to normalize\r\n * @returns {string} Normalized path\r\n */\r\npath.normalize = function normalize(path) {\r\n path = path.replace(/\\\\/g, \"/\")\r\n .replace(/\\/{2,}/g, \"/\");\r\n var parts = path.split(\"/\"),\r\n absolute = isAbsolute(path),\r\n prefix = \"\";\r\n if (absolute)\r\n prefix = parts.shift() + \"/\";\r\n for (var i = 0; i < parts.length;) {\r\n if (parts[i] === \"..\") {\r\n if (i > 0 && parts[i - 1] !== \"..\")\r\n parts.splice(--i, 2);\r\n else if (absolute)\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n } else if (parts[i] === \".\")\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n return prefix + parts.join(\"/\");\r\n};\r\n\r\n/**\r\n * Resolves the specified include path against the specified origin path.\r\n * @param {string} originPath Path to the origin file\r\n * @param {string} includePath Include path relative to origin path\r\n * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized\r\n * @returns {string} Path to the include file\r\n */\r\npath.resolve = function resolve(originPath, includePath, alreadyNormalized) {\r\n if (!alreadyNormalized)\r\n includePath = normalize(includePath);\r\n if (isAbsolute(includePath))\r\n return includePath;\r\n if (!alreadyNormalized)\r\n originPath = normalize(originPath);\r\n return (originPath = originPath.replace(/(?:\\/|^)[^/]+$/, \"\")).length ? normalize(originPath + \"/\" + includePath) : includePath;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\n/**\r\n * Runtime message from/to plain object converters.\r\n * @namespace\r\n */\r\nvar converter = exports;\r\n\r\nvar Enum = require(14),\r\n util = require(33);\r\n\r\n/**\r\n * Generates a partial value fromObject conveter.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} prop Property reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genValuePartial_fromObject(gen, field, fieldIndex, prop) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(d%s){\", prop);\r\n for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) {\r\n if (field.repeated && values[keys[i]] === field.typeDefault) gen\r\n (\"default:\");\r\n gen\r\n (\"case%j:\", keys[i])\r\n (\"case %i:\", values[keys[i]])\r\n (\"m%s=%j\", prop, values[keys[i]])\r\n (\"break\");\r\n } gen\r\n (\"}\");\r\n } else gen\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s=types[%i].fromObject(d%s)\", prop, fieldIndex, prop);\r\n } else {\r\n var isUnsigned = false;\r\n switch (field.type) {\r\n case \"double\":\r\n case \"float\": gen\r\n (\"m%s=Number(d%s)\", prop, prop); // also catches \"NaN\", \"Infinity\"\r\n break;\r\n case \"uint32\":\r\n case \"fixed32\": gen\r\n (\"m%s=d%s>>>0\", prop, prop);\r\n break;\r\n case \"int32\":\r\n case \"sint32\":\r\n case \"sfixed32\": gen\r\n (\"m%s=d%s|0\", prop, prop);\r\n break;\r\n case \"uint64\":\r\n isUnsigned = true;\r\n // eslint-disable-line no-fallthrough\r\n case \"int64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(util.Long)\")\r\n (\"(m%s=util.Long.fromValue(d%s)).unsigned=%j\", prop, prop, isUnsigned)\r\n (\"else if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"m%s=parseInt(d%s,10)\", prop, prop)\r\n (\"else if(typeof d%s===\\\"number\\\")\", prop)\r\n (\"m%s=d%s\", prop, prop)\r\n (\"else if(typeof d%s===\\\"object\\\")\", prop)\r\n (\"m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)\", prop, prop, prop, isUnsigned ? \"true\" : \"\");\r\n break;\r\n case \"bytes\": gen\r\n (\"if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)\", prop, prop, prop)\r\n (\"else if(d%s.length)\", prop)\r\n (\"m%s=d%s\", prop, prop);\r\n break;\r\n case \"string\": gen\r\n (\"m%s=String(d%s)\", prop, prop);\r\n break;\r\n case \"bool\": gen\r\n (\"m%s=Boolean(d%s)\", prop, prop);\r\n break;\r\n /* default: gen\r\n (\"m%s=d%s\", prop, prop);\r\n break; */\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a plain object to runtime message converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.fromObject = function fromObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray;\r\n var gen = util.codegen([\"d\"], mtype.name + \"$fromObject\")\r\n (\"if(d instanceof this.ctor)\")\r\n (\"return d\");\r\n if (!fields.length) return gen\r\n (\"return new this.ctor\");\r\n gen\r\n (\"var m=new this.ctor\");\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n prop = util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"if(d%s){\", prop)\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s={}\", prop)\r\n (\"for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s\", prop, prop, prop, prop, isUnsigned ? \"true\": \"\", prop);\r\n break;\r\n case \"bytes\": gen\r\n (\"d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s\", prop, prop, prop, prop, prop);\r\n break;\r\n default: gen\r\n (\"d%s=m%s\", prop, prop);\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a runtime message to plain object converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.toObject = function toObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n if (!fields.length)\r\n return util.codegen()(\"return {}\");\r\n var gen = util.codegen([\"m\", \"o\"], mtype.name + \"$toObject\")\r\n (\"if(!o)\")\r\n (\"o={}\")\r\n (\"var d={}\");\r\n\r\n var repeatedFields = [],\r\n mapFields = [],\r\n normalFields = [],\r\n i = 0;\r\n for (; i < fields.length; ++i)\r\n if (!fields[i].partOf)\r\n ( fields[i].resolve().repeated ? repeatedFields\r\n : fields[i].map ? mapFields\r\n : normalFields).push(fields[i]);\r\n\r\n if (repeatedFields.length) { gen\r\n (\"if(o.arrays||o.defaults){\");\r\n for (i = 0; i < repeatedFields.length; ++i) gen\r\n (\"d%s=[]\", util.safeProp(repeatedFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (mapFields.length) { gen\r\n (\"if(o.objects||o.defaults){\");\r\n for (i = 0; i < mapFields.length; ++i) gen\r\n (\"d%s={}\", util.safeProp(mapFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (normalFields.length) { gen\r\n (\"if(o.defaults){\");\r\n for (i = 0; i < normalFields.length; ++i) {\r\n var field = normalFields[i],\r\n prop = util.safeProp(field.name);\r\n if (field.resolvedType instanceof Enum) gen\r\n (\"d%s=o.enums===String?%j:%j\", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault);\r\n else if (field.long) gen\r\n (\"if(util.Long){\")\r\n (\"var n=new util.Long(%i,%i,%j)\", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned)\r\n (\"d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n\", prop)\r\n (\"}else\")\r\n (\"d%s=o.longs===String?%j:%i\", prop, field.typeDefault.toString(), field.typeDefault.toNumber());\r\n else if (field.bytes) {\r\n var arrayDefault = \"[\" + Array.prototype.slice.call(field.typeDefault).join(\",\") + \"]\";\r\n gen\r\n (\"if(o.bytes===String)d%s=%j\", prop, String.fromCharCode.apply(String, field.typeDefault))\r\n (\"else{\")\r\n (\"d%s=%s\", prop, arrayDefault)\r\n (\"if(o.bytes!==Array)d%s=util.newBuffer(d%s)\", prop, prop)\r\n (\"}\");\r\n } else gen\r\n (\"d%s=%j\", prop, field.typeDefault); // also messages (=null)\r\n } gen\r\n (\"}\");\r\n }\r\n var hasKs2 = false;\r\n for (i = 0; i < fields.length; ++i) {\r\n var field = fields[i],\r\n index = mtype._fieldsArray.indexOf(field),\r\n prop = util.safeProp(field.name);\r\n if (field.map) {\r\n if (!hasKs2) { hasKs2 = true; gen\r\n (\"var ks2\");\r\n } gen\r\n (\"if(m%s&&(ks2=Object.keys(m%s)).length){\", prop, prop)\r\n (\"d%s={}\", prop)\r\n (\"for(var j=0;j>>3){\");\r\n\r\n var i = 0;\r\n for (; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n ref = \"m\" + util.safeProp(field.name); gen\r\n (\"case %i:\", field.id);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"r.skip().pos++\") // assumes id 1 + key wireType\r\n (\"if(%s===util.emptyObject)\", ref)\r\n (\"%s={}\", ref)\r\n (\"k=r.%s()\", field.keyType)\r\n (\"r.pos++\"); // assumes id 2 + value wireType\r\n if (types.long[field.keyType] !== undefined) {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=r.%s()\", ref, type);\r\n } else {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[k]=r.%s()\", ref, type);\r\n }\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n\r\n (\"if(!(%s&&%s.length))\", ref, ref)\r\n (\"%s=[]\", ref);\r\n\r\n // Packable (always check for forward and backward compatiblity)\r\n if (types.packed[type] !== undefined) gen\r\n (\"if((t&7)===2){\")\r\n (\"var c2=r.uint32()+r.pos\")\r\n (\"while(r.pos>> 0, (field.id << 3 | 4) >>> 0)\r\n : gen(\"types[%i].encode(%s,w.uint32(%i).fork()).ldelim()\", fieldIndex, ref, (field.id << 3 | 2) >>> 0);\r\n}\r\n\r\n/**\r\n * Generates an encoder specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction encoder(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var gen = util.codegen([\"m\", \"w\"], mtype.name + \"$encode\")\r\n (\"if(!w)\")\r\n (\"w=Writer.create()\");\r\n\r\n var i, ref;\r\n\r\n // \"when a message is serialized its known fields should be written sequentially by field number\"\r\n var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n index = mtype._fieldsArray.indexOf(field),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n wireType = types.basic[type];\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) {\r\n gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name) // !== undefined && !== null\r\n (\"for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType);\r\n if (wireType === undefined) gen\r\n (\"types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()\", index, ref); // can't be groups\r\n else gen\r\n (\".uint32(%i).%s(%s[ks[i]]).ldelim()\", 16 | wireType, type, ref);\r\n gen\r\n (\"}\")\r\n (\"}\");\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n (\"if(%s!=null&&%s.length){\", ref, ref); // !== undefined && !== null\r\n\r\n // Packed repeated\r\n if (field.packed && types.packed[type] !== undefined) { gen\r\n\r\n (\"w.uint32(%i).fork()\", (field.id << 3 | 2) >>> 0)\r\n (\"for(var i=0;i<%s.length;++i)\", ref)\r\n (\"w.%s(%s[i])\", type, ref)\r\n (\"w.ldelim()\");\r\n\r\n // Non-packed\r\n } else { gen\r\n\r\n (\"for(var i=0;i<%s.length;++i)\", ref);\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref + \"[i]\");\r\n else gen\r\n (\"w.uint32(%i).%s(%s[i])\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n } gen\r\n (\"}\");\r\n\r\n // Non-repeated\r\n } else {\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j))\", ref, field.name); // !== undefined && !== null\r\n\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref);\r\n else gen\r\n (\"w.uint32(%i).%s(%s)\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n }\r\n }\r\n\r\n return gen\r\n (\"return w\");\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}","\"use strict\";\r\nmodule.exports = Enum;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = \"Enum\";\r\n\r\nvar Namespace = require(21),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new enum instance.\r\n * @classdesc Reflected enum.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {Object.} [values] Enum values as an object, by name\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this enum\r\n * @param {Object.} [comments] The value comments for this enum\r\n */\r\nfunction Enum(name, values, options, comment, comments) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (values && typeof values !== \"object\")\r\n throw TypeError(\"values must be an object\");\r\n\r\n /**\r\n * Enum values by id.\r\n * @type {Object.}\r\n */\r\n this.valuesById = {};\r\n\r\n /**\r\n * Enum values by name.\r\n * @type {Object.}\r\n */\r\n this.values = Object.create(this.valuesById); // toJSON, marker\r\n\r\n /**\r\n * Enum comment text.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n\r\n /**\r\n * Value comment texts, if any.\r\n * @type {Object.}\r\n */\r\n this.comments = comments || {};\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n // Note that values inherit valuesById on their prototype which makes them a TypeScript-\r\n // compatible enum. This is used by pbts to write actual enum definitions that work for\r\n // static and reflection code alike instead of emitting generic object definitions.\r\n\r\n if (values)\r\n for (var keys = Object.keys(values), i = 0; i < keys.length; ++i)\r\n if (typeof values[keys[i]] === \"number\") // use forward entries only\r\n this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i];\r\n}\r\n\r\n/**\r\n * Enum descriptor.\r\n * @interface IEnum\r\n * @property {Object.} values Enum values\r\n * @property {Object.} [options] Enum options\r\n */\r\n\r\n/**\r\n * Constructs an enum from an enum descriptor.\r\n * @param {string} name Enum name\r\n * @param {IEnum} json Enum descriptor\r\n * @returns {Enum} Created enum\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nEnum.fromJSON = function fromJSON(name, json) {\r\n var enm = new Enum(name, json.values, json.options, json.comment, json.comments);\r\n enm.reserved = json.reserved;\r\n return enm;\r\n};\r\n\r\n/**\r\n * Converts this enum to an enum descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IEnum} Enum descriptor\r\n */\r\nEnum.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"values\" , this.values,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"comment\" , keepComments ? this.comment : undefined,\r\n \"comments\" , keepComments ? this.comments : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds a value to this enum.\r\n * @param {string} name Value name\r\n * @param {number} id Value id\r\n * @param {string} [comment] Comment, if any\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a value with this name or id\r\n */\r\nEnum.prototype.add = function add(name, id, comment) {\r\n // utilized by the parser but not by .fromJSON\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (!util.isInteger(id))\r\n throw TypeError(\"id must be an integer\");\r\n\r\n if (this.values[name] !== undefined)\r\n throw Error(\"duplicate name '\" + name + \"' in \" + this);\r\n\r\n if (this.isReservedId(id))\r\n throw Error(\"id \" + id + \" is reserved in \" + this);\r\n\r\n if (this.isReservedName(name))\r\n throw Error(\"name '\" + name + \"' is reserved in \" + this);\r\n\r\n if (this.valuesById[id] !== undefined) {\r\n if (!(this.options && this.options.allow_alias))\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n this.values[name] = id;\r\n } else\r\n this.valuesById[this.values[name] = id] = name;\r\n\r\n this.comments[name] = comment || null;\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a value from this enum\r\n * @param {string} name Value name\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `name` is not a name of this enum\r\n */\r\nEnum.prototype.remove = function remove(name) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n var val = this.values[name];\r\n if (val == null)\r\n throw Error(\"name '\" + name + \"' does not exist in \" + this);\r\n\r\n delete this.valuesById[val];\r\n delete this.values[name];\r\n delete this.comments[name];\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Field;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = \"Field\";\r\n\r\nvar Enum = require(14),\r\n types = require(32),\r\n util = require(33);\r\n\r\nvar Type; // cyclic\r\n\r\nvar ruleRe = /^required|optional|repeated$/;\r\n\r\n/**\r\n * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.\r\n * @name Field\r\n * @classdesc Reflected message field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a field from a field descriptor.\r\n * @param {string} name Field name\r\n * @param {IField} json Field descriptor\r\n * @returns {Field} Created field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nField.fromJSON = function fromJSON(name, json) {\r\n return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Field} instead.\r\n * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports FieldBase\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction Field(name, id, type, rule, extend, options, comment) {\r\n\r\n if (util.isObject(rule)) {\r\n comment = extend;\r\n options = rule;\r\n rule = extend = undefined;\r\n } else if (util.isObject(extend)) {\r\n comment = options;\r\n options = extend;\r\n extend = undefined;\r\n }\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (!util.isInteger(id) || id < 0)\r\n throw TypeError(\"id must be a non-negative integer\");\r\n\r\n if (!util.isString(type))\r\n throw TypeError(\"type must be a string\");\r\n\r\n if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))\r\n throw TypeError(\"rule must be a string rule\");\r\n\r\n if (extend !== undefined && !util.isString(extend))\r\n throw TypeError(\"extend must be a string\");\r\n\r\n /**\r\n * Field rule, if any.\r\n * @type {string|undefined}\r\n */\r\n this.rule = rule && rule !== \"optional\" ? rule : undefined; // toJSON\r\n\r\n /**\r\n * Field type.\r\n * @type {string}\r\n */\r\n this.type = type; // toJSON\r\n\r\n /**\r\n * Unique field id.\r\n * @type {number}\r\n */\r\n this.id = id; // toJSON, marker\r\n\r\n /**\r\n * Extended type if different from parent.\r\n * @type {string|undefined}\r\n */\r\n this.extend = extend || undefined; // toJSON\r\n\r\n /**\r\n * Whether this field is required.\r\n * @type {boolean}\r\n */\r\n this.required = rule === \"required\";\r\n\r\n /**\r\n * Whether this field is optional.\r\n * @type {boolean}\r\n */\r\n this.optional = !this.required;\r\n\r\n /**\r\n * Whether this field is repeated.\r\n * @type {boolean}\r\n */\r\n this.repeated = rule === \"repeated\";\r\n\r\n /**\r\n * Whether this field is a map or not.\r\n * @type {boolean}\r\n */\r\n this.map = false;\r\n\r\n /**\r\n * Message this field belongs to.\r\n * @type {Type|null}\r\n */\r\n this.message = null;\r\n\r\n /**\r\n * OneOf this field belongs to, if any,\r\n * @type {OneOf|null}\r\n */\r\n this.partOf = null;\r\n\r\n /**\r\n * The field type's default value.\r\n * @type {*}\r\n */\r\n this.typeDefault = null;\r\n\r\n /**\r\n * The field's default value on prototypes.\r\n * @type {*}\r\n */\r\n this.defaultValue = null;\r\n\r\n /**\r\n * Whether this field's value should be treated as a long.\r\n * @type {boolean}\r\n */\r\n this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;\r\n\r\n /**\r\n * Whether this field's value is a buffer.\r\n * @type {boolean}\r\n */\r\n this.bytes = type === \"bytes\";\r\n\r\n /**\r\n * Resolved type if not a basic type.\r\n * @type {Type|Enum|null}\r\n */\r\n this.resolvedType = null;\r\n\r\n /**\r\n * Sister-field within the extended type if a declaring extension field.\r\n * @type {Field|null}\r\n */\r\n this.extensionField = null;\r\n\r\n /**\r\n * Sister-field within the declaring namespace if an extended field.\r\n * @type {Field|null}\r\n */\r\n this.declaringField = null;\r\n\r\n /**\r\n * Internally remembers whether this field is packed.\r\n * @type {boolean|null}\r\n * @private\r\n */\r\n this._packed = null;\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Determines whether this field is packed. Only relevant when repeated and working with proto2.\r\n * @name Field#packed\r\n * @type {boolean}\r\n * @readonly\r\n */\r\nObject.defineProperty(Field.prototype, \"packed\", {\r\n get: function() {\r\n // defaults to packed=true if not explicity set to false\r\n if (this._packed === null)\r\n this._packed = this.getOption(\"packed\") !== false;\r\n return this._packed;\r\n }\r\n});\r\n\r\n/**\r\n * @override\r\n */\r\nField.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (name === \"packed\") // clear cached before setting\r\n this._packed = null;\r\n return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);\r\n};\r\n\r\n/**\r\n * Field descriptor.\r\n * @interface IField\r\n * @property {string} [rule=\"optional\"] Field rule\r\n * @property {string} type Field type\r\n * @property {number} id Field id\r\n * @property {Object.} [options] Field options\r\n */\r\n\r\n/**\r\n * Extension field descriptor.\r\n * @interface IExtensionField\r\n * @extends IField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Converts this field to a field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IField} Field descriptor\r\n */\r\nField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"rule\" , this.rule !== \"optional\" && this.rule || undefined,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Resolves this field's type references.\r\n * @returns {Field} `this`\r\n * @throws {Error} If any reference cannot be resolved\r\n */\r\nField.prototype.resolve = function resolve() {\r\n\r\n if (this.resolved)\r\n return this;\r\n\r\n if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it\r\n this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);\r\n if (this.resolvedType instanceof Type)\r\n this.typeDefault = null;\r\n else // instanceof Enum\r\n this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined\r\n }\r\n\r\n // use explicitly set default value if present\r\n if (this.options && this.options[\"default\"] != null) {\r\n this.typeDefault = this.options[\"default\"];\r\n if (this.resolvedType instanceof Enum && typeof this.typeDefault === \"string\")\r\n this.typeDefault = this.resolvedType.values[this.typeDefault];\r\n }\r\n\r\n // remove unnecessary options\r\n if (this.options) {\r\n if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))\r\n delete this.options.packed;\r\n if (!Object.keys(this.options).length)\r\n this.options = undefined;\r\n }\r\n\r\n // convert to internal data type if necesssary\r\n if (this.long) {\r\n this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === \"u\");\r\n\r\n /* istanbul ignore else */\r\n if (Object.freeze)\r\n Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)\r\n\r\n } else if (this.bytes && typeof this.typeDefault === \"string\") {\r\n var buf;\r\n if (util.base64.test(this.typeDefault))\r\n util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);\r\n else\r\n util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);\r\n this.typeDefault = buf;\r\n }\r\n\r\n // take special care of maps and repeated fields\r\n if (this.map)\r\n this.defaultValue = util.emptyObject;\r\n else if (this.repeated)\r\n this.defaultValue = util.emptyArray;\r\n else\r\n this.defaultValue = this.typeDefault;\r\n\r\n // ensure proper value on prototype\r\n if (this.parent instanceof Type)\r\n this.parent.ctor.prototype[this.name] = this.defaultValue;\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).\r\n * @typedef FieldDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} fieldName Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"string\"|\"bool\"|\"bytes\"|Object} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @param {T} [defaultValue] Default value\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]\r\n */\r\nField.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {\r\n\r\n // submessage: decorate the submessage and use its name as the type\r\n if (typeof fieldType === \"function\")\r\n fieldType = util.decorateType(fieldType).name;\r\n\r\n // enum reference: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldType && typeof fieldType === \"object\")\r\n fieldType = util.decorateEnum(fieldType).name;\r\n\r\n return function fieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new Field(fieldName, fieldId, fieldType, fieldRule, { \"default\": defaultValue }));\r\n };\r\n};\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {Constructor|string} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends Message\r\n * @variation 2\r\n */\r\n// like Field.d but without a default value\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nField._configure = function configure(Type_) {\r\n Type = Type_;\r\n};\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(17);\r\n\r\nprotobuf.build = \"light\";\r\n\r\n/**\r\n * A node-style callback as used by {@link load} and {@link Root#load}.\r\n * @typedef LoadCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Root} [root] Root, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} root Root namespace, defaults to create a new one if omitted.\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n */\r\nfunction load(filename, root, callback) {\r\n if (typeof root === \"function\") {\r\n callback = root;\r\n root = new protobuf.Root();\r\n } else if (!root)\r\n root = new protobuf.Root();\r\n return root.load(filename, callback);\r\n}\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Promise} Promise\r\n * @see {@link Root#load}\r\n * @variation 3\r\n */\r\n// function load(filename:string, [root:Root]):Promise\r\n\r\nprotobuf.load = load;\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only).\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n * @see {@link Root#loadSync}\r\n */\r\nfunction loadSync(filename, root) {\r\n if (!root)\r\n root = new protobuf.Root();\r\n return root.loadSync(filename);\r\n}\r\n\r\nprotobuf.loadSync = loadSync;\r\n\r\n// Serialization\r\nprotobuf.encoder = require(13);\r\nprotobuf.decoder = require(12);\r\nprotobuf.verifier = require(36);\r\nprotobuf.converter = require(11);\r\n\r\n// Reflection\r\nprotobuf.ReflectionObject = require(22);\r\nprotobuf.Namespace = require(21);\r\nprotobuf.Root = require(26);\r\nprotobuf.Enum = require(14);\r\nprotobuf.Type = require(31);\r\nprotobuf.Field = require(15);\r\nprotobuf.OneOf = require(23);\r\nprotobuf.MapField = require(18);\r\nprotobuf.Service = require(30);\r\nprotobuf.Method = require(20);\r\n\r\n// Runtime\r\nprotobuf.Message = require(19);\r\nprotobuf.wrappers = require(37);\r\n\r\n// Utility\r\nprotobuf.types = require(32);\r\nprotobuf.util = require(33);\r\n\r\n// Set up possibly cyclic reflection dependencies\r\nprotobuf.ReflectionObject._configure(protobuf.Root);\r\nprotobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum);\r\nprotobuf.Root._configure(protobuf.Type);\r\nprotobuf.Field._configure(protobuf.Type);\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(38);\r\nprotobuf.BufferWriter = require(39);\r\nprotobuf.Reader = require(24);\r\nprotobuf.BufferReader = require(25);\r\n\r\n// Utility\r\nprotobuf.util = require(35);\r\nprotobuf.rpc = require(28);\r\nprotobuf.roots = require(27);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nmodule.exports = MapField;\r\n\r\n// extends Field\r\nvar Field = require(15);\r\n((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = \"MapField\";\r\n\r\nvar types = require(32),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new map field instance.\r\n * @classdesc Reflected map field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} keyType Key type\r\n * @param {string} type Value type\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction MapField(name, id, keyType, type, options, comment) {\r\n Field.call(this, name, id, type, undefined, undefined, options, comment);\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(keyType))\r\n throw TypeError(\"keyType must be a string\");\r\n\r\n /**\r\n * Key type.\r\n * @type {string}\r\n */\r\n this.keyType = keyType; // toJSON, marker\r\n\r\n /**\r\n * Resolved key type if not a basic type.\r\n * @type {ReflectionObject|null}\r\n */\r\n this.resolvedKeyType = null;\r\n\r\n // Overrides Field#map\r\n this.map = true;\r\n}\r\n\r\n/**\r\n * Map field descriptor.\r\n * @interface IMapField\r\n * @extends {IField}\r\n * @property {string} keyType Key type\r\n */\r\n\r\n/**\r\n * Extension map field descriptor.\r\n * @interface IExtensionMapField\r\n * @extends IMapField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Constructs a map field from a map field descriptor.\r\n * @param {string} name Field name\r\n * @param {IMapField} json Map field descriptor\r\n * @returns {MapField} Created map field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMapField.fromJSON = function fromJSON(name, json) {\r\n return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this map field to a map field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMapField} Map field descriptor\r\n */\r\nMapField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"keyType\" , this.keyType,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMapField.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n\r\n // Besides a value type, map fields have a key type that may be \"any scalar type except for floating point types and bytes\"\r\n if (types.mapKey[this.keyType] === undefined)\r\n throw Error(\"invalid key type: \" + this.keyType);\r\n\r\n return Field.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Map field decorator (TypeScript).\r\n * @name MapField.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"} fieldKeyType Field key type\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"|\"bytes\"|Object|Constructor<{}>} fieldValueType Field value type\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> }\r\n */\r\nMapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) {\r\n\r\n // submessage value: decorate the submessage and use its name as the type\r\n if (typeof fieldValueType === \"function\")\r\n fieldValueType = util.decorateType(fieldValueType).name;\r\n\r\n // enum reference value: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldValueType && typeof fieldValueType === \"object\")\r\n fieldValueType = util.decorateEnum(fieldValueType).name;\r\n\r\n return function mapFieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType));\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Message;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs a new message instance.\r\n * @classdesc Abstract runtime message.\r\n * @constructor\r\n * @param {Properties} [properties] Properties to set\r\n * @template T extends object = object\r\n */\r\nfunction Message(properties) {\r\n // not used internally\r\n if (properties)\r\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\r\n this[keys[i]] = properties[keys[i]];\r\n}\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message.$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message#$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/*eslint-disable valid-jsdoc*/\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.create = function create(properties) {\r\n return this.$type.create(properties);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encode = function encode(message, writer) {\r\n return this.$type.encode(message, writer);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its length as a varint.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.$type.encodeDelimited(message, writer);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @name Message.decode\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decode = function decode(reader) {\r\n return this.$type.decode(reader);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its length as a varint.\r\n * @name Message.decodeDelimited\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decodeDelimited = function decodeDelimited(reader) {\r\n return this.$type.decodeDelimited(reader);\r\n};\r\n\r\n/**\r\n * Verifies a message of this type.\r\n * @name Message.verify\r\n * @function\r\n * @param {Object.} message Plain object to verify\r\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\r\n */\r\nMessage.verify = function verify(message) {\r\n return this.$type.verify(message);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object\r\n * @returns {T} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.fromObject = function fromObject(object) {\r\n return this.$type.fromObject(object);\r\n};\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {T} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.toObject = function toObject(message, options) {\r\n return this.$type.toObject(message, options);\r\n};\r\n\r\n/**\r\n * Converts this message to JSON.\r\n * @returns {Object.} JSON object\r\n */\r\nMessage.prototype.toJSON = function toJSON() {\r\n return this.$type.toObject(this, util.toJSONOptions);\r\n};\r\n\r\n/*eslint-enable valid-jsdoc*/","\"use strict\";\r\nmodule.exports = Method;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = \"Method\";\r\n\r\nvar util = require(33);\r\n\r\n/**\r\n * Constructs a new service method instance.\r\n * @classdesc Reflected service method.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Method name\r\n * @param {string|undefined} type Method type, usually `\"rpc\"`\r\n * @param {string} requestType Request message type\r\n * @param {string} responseType Response message type\r\n * @param {boolean|Object.} [requestStream] Whether the request is streamed\r\n * @param {boolean|Object.} [responseStream] Whether the response is streamed\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this method\r\n */\r\nfunction Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) {\r\n\r\n /* istanbul ignore next */\r\n if (util.isObject(requestStream)) {\r\n options = requestStream;\r\n requestStream = responseStream = undefined;\r\n } else if (util.isObject(responseStream)) {\r\n options = responseStream;\r\n responseStream = undefined;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!(type === undefined || util.isString(type)))\r\n throw TypeError(\"type must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(requestType))\r\n throw TypeError(\"requestType must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(responseType))\r\n throw TypeError(\"responseType must be a string\");\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Method type.\r\n * @type {string}\r\n */\r\n this.type = type || \"rpc\"; // toJSON\r\n\r\n /**\r\n * Request type.\r\n * @type {string}\r\n */\r\n this.requestType = requestType; // toJSON, marker\r\n\r\n /**\r\n * Whether requests are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.requestStream = requestStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Response type.\r\n * @type {string}\r\n */\r\n this.responseType = responseType; // toJSON\r\n\r\n /**\r\n * Whether responses are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.responseStream = responseStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Resolved request type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedRequestType = null;\r\n\r\n /**\r\n * Resolved response type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedResponseType = null;\r\n\r\n /**\r\n * Comment for this method\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Method descriptor.\r\n * @interface IMethod\r\n * @property {string} [type=\"rpc\"] Method type\r\n * @property {string} requestType Request type\r\n * @property {string} responseType Response type\r\n * @property {boolean} [requestStream=false] Whether requests are streamed\r\n * @property {boolean} [responseStream=false] Whether responses are streamed\r\n * @property {Object.} [options] Method options\r\n */\r\n\r\n/**\r\n * Constructs a method from a method descriptor.\r\n * @param {string} name Method name\r\n * @param {IMethod} json Method descriptor\r\n * @returns {Method} Created method\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMethod.fromJSON = function fromJSON(name, json) {\r\n return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this method to a method descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMethod} Method descriptor\r\n */\r\nMethod.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"type\" , this.type !== \"rpc\" && /* istanbul ignore next */ this.type || undefined,\r\n \"requestType\" , this.requestType,\r\n \"requestStream\" , this.requestStream,\r\n \"responseType\" , this.responseType,\r\n \"responseStream\" , this.responseStream,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMethod.prototype.resolve = function resolve() {\r\n\r\n /* istanbul ignore if */\r\n if (this.resolved)\r\n return this;\r\n\r\n this.resolvedRequestType = this.parent.lookupType(this.requestType);\r\n this.resolvedResponseType = this.parent.lookupType(this.responseType);\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Namespace;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = \"Namespace\";\r\n\r\nvar Field = require(15),\r\n util = require(33);\r\n\r\nvar Type, // cyclic\r\n Service,\r\n Enum;\r\n\r\n/**\r\n * Constructs a new namespace instance.\r\n * @name Namespace\r\n * @classdesc Reflected namespace.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a namespace from JSON.\r\n * @memberof Namespace\r\n * @function\r\n * @param {string} name Namespace name\r\n * @param {Object.} json JSON object\r\n * @returns {Namespace} Created namespace\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nNamespace.fromJSON = function fromJSON(name, json) {\r\n return new Namespace(name, json.options).addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Converts an array of reflection objects to JSON.\r\n * @memberof Namespace\r\n * @param {ReflectionObject[]} array Object array\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {Object.|undefined} JSON object or `undefined` when array is empty\r\n */\r\nfunction arrayToJSON(array, toJSONOptions) {\r\n if (!(array && array.length))\r\n return undefined;\r\n var obj = {};\r\n for (var i = 0; i < array.length; ++i)\r\n obj[array[i].name] = array[i].toJSON(toJSONOptions);\r\n return obj;\r\n}\r\n\r\nNamespace.arrayToJSON = arrayToJSON;\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedId = function isReservedId(reserved, id) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (typeof reserved[i] !== \"string\" && reserved[i][0] <= id && reserved[i][1] >= id)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedName = function isReservedName(reserved, name) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (reserved[i] === name)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Namespace} instead.\r\n * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports NamespaceBase\r\n * @extends ReflectionObject\r\n * @abstract\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n * @see {@link Namespace}\r\n */\r\nfunction Namespace(name, options) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Nested objects by name.\r\n * @type {Object.|undefined}\r\n */\r\n this.nested = undefined; // toJSON\r\n\r\n /**\r\n * Cached nested objects as an array.\r\n * @type {ReflectionObject[]|null}\r\n * @private\r\n */\r\n this._nestedArray = null;\r\n}\r\n\r\nfunction clearCache(namespace) {\r\n namespace._nestedArray = null;\r\n return namespace;\r\n}\r\n\r\n/**\r\n * Nested objects of this namespace as an array for iteration.\r\n * @name NamespaceBase#nestedArray\r\n * @type {ReflectionObject[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Namespace.prototype, \"nestedArray\", {\r\n get: function() {\r\n return this._nestedArray || (this._nestedArray = util.toArray(this.nested));\r\n }\r\n});\r\n\r\n/**\r\n * Namespace descriptor.\r\n * @interface INamespace\r\n * @property {Object.} [options] Namespace options\r\n * @property {Object.} [nested] Nested object descriptors\r\n */\r\n\r\n/**\r\n * Any extension field descriptor.\r\n * @typedef AnyExtensionField\r\n * @type {IExtensionField|IExtensionMapField}\r\n */\r\n\r\n/**\r\n * Any nested object descriptor.\r\n * @typedef AnyNestedObject\r\n * @type {IEnum|IType|IService|AnyExtensionField|INamespace}\r\n */\r\n// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place)\r\n\r\n/**\r\n * Converts this namespace to a namespace descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {INamespace} Namespace descriptor\r\n */\r\nNamespace.prototype.toJSON = function toJSON(toJSONOptions) {\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"nested\" , arrayToJSON(this.nestedArray, toJSONOptions)\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds nested objects to this namespace from nested object descriptors.\r\n * @param {Object.} nestedJson Any nested object descriptors\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.addJSON = function addJSON(nestedJson) {\r\n var ns = this;\r\n /* istanbul ignore else */\r\n if (nestedJson) {\r\n for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) {\r\n nested = nestedJson[names[i]];\r\n ns.add( // most to least likely\r\n ( nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : nested.id !== undefined\r\n ? Field.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets the nested object of the specified name.\r\n * @param {string} name Nested object name\r\n * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist\r\n */\r\nNamespace.prototype.get = function get(name) {\r\n return this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Gets the values of the nested {@link Enum|enum} of the specified name.\r\n * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`.\r\n * @param {string} name Nested enum name\r\n * @returns {Object.} Enum values\r\n * @throws {Error} If there is no such enum\r\n */\r\nNamespace.prototype.getEnum = function getEnum(name) {\r\n if (this.nested && this.nested[name] instanceof Enum)\r\n return this.nested[name].values;\r\n throw Error(\"no such enum: \" + name);\r\n};\r\n\r\n/**\r\n * Adds a nested object to this namespace.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name\r\n */\r\nNamespace.prototype.add = function add(object) {\r\n\r\n if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace))\r\n throw TypeError(\"object must be a valid nested object\");\r\n\r\n if (!this.nested)\r\n this.nested = {};\r\n else {\r\n var prev = this.get(object.name);\r\n if (prev) {\r\n if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) {\r\n // replace plain namespace but keep existing nested elements and options\r\n var nested = prev.nestedArray;\r\n for (var i = 0; i < nested.length; ++i)\r\n object.add(nested[i]);\r\n this.remove(prev);\r\n if (!this.nested)\r\n this.nested = {};\r\n object.setOptions(prev.options, true);\r\n\r\n } else\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n }\r\n }\r\n this.nested[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this namespace.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this namespace\r\n */\r\nNamespace.prototype.remove = function remove(object) {\r\n\r\n if (!(object instanceof ReflectionObject))\r\n throw TypeError(\"object must be a ReflectionObject\");\r\n if (object.parent !== this)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.nested[object.name];\r\n if (!Object.keys(this.nested).length)\r\n this.nested = undefined;\r\n\r\n object.onRemove(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Defines additial namespaces within this one if not yet existing.\r\n * @param {string|string[]} path Path to create\r\n * @param {*} [json] Nested types to create from JSON\r\n * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty\r\n */\r\nNamespace.prototype.define = function define(path, json) {\r\n\r\n if (util.isString(path))\r\n path = path.split(\".\");\r\n else if (!Array.isArray(path))\r\n throw TypeError(\"illegal path\");\r\n if (path && path.length && path[0] === \"\")\r\n throw Error(\"path must be relative\");\r\n\r\n var ptr = this;\r\n while (path.length > 0) {\r\n var part = path.shift();\r\n if (ptr.nested && ptr.nested[part]) {\r\n ptr = ptr.nested[part];\r\n if (!(ptr instanceof Namespace))\r\n throw Error(\"path conflicts with non-namespace objects\");\r\n } else\r\n ptr.add(ptr = new Namespace(part));\r\n }\r\n if (json)\r\n ptr.addJSON(json);\r\n return ptr;\r\n};\r\n\r\n/**\r\n * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost.\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.resolveAll = function resolveAll() {\r\n var nested = this.nestedArray, i = 0;\r\n while (i < nested.length)\r\n if (nested[i] instanceof Namespace)\r\n nested[i++].resolveAll();\r\n else\r\n nested[i++].resolve();\r\n return this.resolve();\r\n};\r\n\r\n/**\r\n * Recursively looks up the reflection object matching the specified path in the scope of this namespace.\r\n * @param {string|string[]} path Path to look up\r\n * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc.\r\n * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n */\r\nNamespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) {\r\n\r\n /* istanbul ignore next */\r\n if (typeof filterTypes === \"boolean\") {\r\n parentAlreadyChecked = filterTypes;\r\n filterTypes = undefined;\r\n } else if (filterTypes && !Array.isArray(filterTypes))\r\n filterTypes = [ filterTypes ];\r\n\r\n if (util.isString(path) && path.length) {\r\n if (path === \".\")\r\n return this.root;\r\n path = path.split(\".\");\r\n } else if (!path.length)\r\n return this;\r\n\r\n // Start at root if path is absolute\r\n if (path[0] === \"\")\r\n return this.root.lookup(path.slice(1), filterTypes);\r\n\r\n // Test if the first part matches any nested object, and if so, traverse if path contains more\r\n var found = this.get(path[0]);\r\n if (found) {\r\n if (path.length === 1) {\r\n if (!filterTypes || filterTypes.indexOf(found.constructor) > -1)\r\n return found;\r\n } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true)))\r\n return found;\r\n\r\n // Otherwise try each nested namespace\r\n } else\r\n for (var i = 0; i < this.nestedArray.length; ++i)\r\n if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true)))\r\n return found;\r\n\r\n // If there hasn't been a match, try again at the parent\r\n if (this.parent === null || parentAlreadyChecked)\r\n return null;\r\n return this.parent.lookup(path, filterTypes);\r\n};\r\n\r\n/**\r\n * Looks up the reflection object at the specified path, relative to this namespace.\r\n * @name NamespaceBase#lookup\r\n * @function\r\n * @param {string|string[]} path Path to look up\r\n * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n * @variation 2\r\n */\r\n// lookup(path: string, [parentAlreadyChecked: boolean])\r\n\r\n/**\r\n * Looks up the {@link Type|type} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type\r\n * @throws {Error} If `path` does not point to a type\r\n */\r\nNamespace.prototype.lookupType = function lookupType(path) {\r\n var found = this.lookup(path, [ Type ]);\r\n if (!found)\r\n throw Error(\"no such type: \" + path);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Enum} Looked up enum\r\n * @throws {Error} If `path` does not point to an enum\r\n */\r\nNamespace.prototype.lookupEnum = function lookupEnum(path) {\r\n var found = this.lookup(path, [ Enum ]);\r\n if (!found)\r\n throw Error(\"no such Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type or enum\r\n * @throws {Error} If `path` does not point to a type or enum\r\n */\r\nNamespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) {\r\n var found = this.lookup(path, [ Type, Enum ]);\r\n if (!found)\r\n throw Error(\"no such Type or Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Service|service} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Service} Looked up service\r\n * @throws {Error} If `path` does not point to a service\r\n */\r\nNamespace.prototype.lookupService = function lookupService(path) {\r\n var found = this.lookup(path, [ Service ]);\r\n if (!found)\r\n throw Error(\"no such Service '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nNamespace._configure = function(Type_, Service_, Enum_) {\r\n Type = Type_;\r\n Service = Service_;\r\n Enum = Enum_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = ReflectionObject;\r\n\r\nReflectionObject.className = \"ReflectionObject\";\r\n\r\nvar util = require(33);\r\n\r\nvar Root; // cyclic\r\n\r\n/**\r\n * Constructs a new reflection object instance.\r\n * @classdesc Base class of all reflection objects.\r\n * @constructor\r\n * @param {string} name Object name\r\n * @param {Object.} [options] Declared options\r\n * @abstract\r\n */\r\nfunction ReflectionObject(name, options) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (options && !util.isObject(options))\r\n throw TypeError(\"options must be an object\");\r\n\r\n /**\r\n * Options.\r\n * @type {Object.|undefined}\r\n */\r\n this.options = options; // toJSON\r\n\r\n /**\r\n * Unique name within its namespace.\r\n * @type {string}\r\n */\r\n this.name = name;\r\n\r\n /**\r\n * Parent namespace.\r\n * @type {Namespace|null}\r\n */\r\n this.parent = null;\r\n\r\n /**\r\n * Whether already resolved or not.\r\n * @type {boolean}\r\n */\r\n this.resolved = false;\r\n\r\n /**\r\n * Comment text, if any.\r\n * @type {string|null}\r\n */\r\n this.comment = null;\r\n\r\n /**\r\n * Defining file name.\r\n * @type {string|null}\r\n */\r\n this.filename = null;\r\n}\r\n\r\nObject.defineProperties(ReflectionObject.prototype, {\r\n\r\n /**\r\n * Reference to the root namespace.\r\n * @name ReflectionObject#root\r\n * @type {Root}\r\n * @readonly\r\n */\r\n root: {\r\n get: function() {\r\n var ptr = this;\r\n while (ptr.parent !== null)\r\n ptr = ptr.parent;\r\n return ptr;\r\n }\r\n },\r\n\r\n /**\r\n * Full name including leading dot.\r\n * @name ReflectionObject#fullName\r\n * @type {string}\r\n * @readonly\r\n */\r\n fullName: {\r\n get: function() {\r\n var path = [ this.name ],\r\n ptr = this.parent;\r\n while (ptr) {\r\n path.unshift(ptr.name);\r\n ptr = ptr.parent;\r\n }\r\n return path.join(\".\");\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Converts this reflection object to its descriptor representation.\r\n * @returns {Object.} Descriptor\r\n * @abstract\r\n */\r\nReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() {\r\n throw Error(); // not implemented, shouldn't happen\r\n};\r\n\r\n/**\r\n * Called when this object is added to a parent.\r\n * @param {ReflectionObject} parent Parent added to\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onAdd = function onAdd(parent) {\r\n if (this.parent && this.parent !== parent)\r\n this.parent.remove(this);\r\n this.parent = parent;\r\n this.resolved = false;\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleAdd(this);\r\n};\r\n\r\n/**\r\n * Called when this object is removed from a parent.\r\n * @param {ReflectionObject} parent Parent removed from\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onRemove = function onRemove(parent) {\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleRemove(this);\r\n this.parent = null;\r\n this.resolved = false;\r\n};\r\n\r\n/**\r\n * Resolves this objects type references.\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n if (this.root instanceof Root)\r\n this.resolved = true; // only if part of a root\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets an option value.\r\n * @param {string} name Option name\r\n * @returns {*} Option value or `undefined` if not set\r\n */\r\nReflectionObject.prototype.getOption = function getOption(name) {\r\n if (this.options)\r\n return this.options[name];\r\n return undefined;\r\n};\r\n\r\n/**\r\n * Sets an option.\r\n * @param {string} name Option name\r\n * @param {*} value Option value\r\n * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (!ifNotSet || !this.options || this.options[name] === undefined)\r\n (this.options || (this.options = {}))[name] = value;\r\n return this;\r\n};\r\n\r\n/**\r\n * Sets multiple options.\r\n * @param {Object.} options Options to set\r\n * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) {\r\n if (options)\r\n for (var keys = Object.keys(options), i = 0; i < keys.length; ++i)\r\n this.setOption(keys[i], options[keys[i]], ifNotSet);\r\n return this;\r\n};\r\n\r\n/**\r\n * Converts this instance to its string representation.\r\n * @returns {string} Class name[, space, full name]\r\n */\r\nReflectionObject.prototype.toString = function toString() {\r\n var className = this.constructor.className,\r\n fullName = this.fullName;\r\n if (fullName.length)\r\n return className + \" \" + fullName;\r\n return className;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nReflectionObject._configure = function(Root_) {\r\n Root = Root_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = OneOf;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(22);\r\n((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = \"OneOf\";\r\n\r\nvar Field = require(15),\r\n util = require(33);\r\n\r\n/**\r\n * Constructs a new oneof instance.\r\n * @classdesc Reflected oneof.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Oneof name\r\n * @param {string[]|Object.} [fieldNames] Field names\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction OneOf(name, fieldNames, options, comment) {\r\n if (!Array.isArray(fieldNames)) {\r\n options = fieldNames;\r\n fieldNames = undefined;\r\n }\r\n ReflectionObject.call(this, name, options);\r\n\r\n /* istanbul ignore if */\r\n if (!(fieldNames === undefined || Array.isArray(fieldNames)))\r\n throw TypeError(\"fieldNames must be an Array\");\r\n\r\n /**\r\n * Field names that belong to this oneof.\r\n * @type {string[]}\r\n */\r\n this.oneof = fieldNames || []; // toJSON, marker\r\n\r\n /**\r\n * Fields that belong to this oneof as an array for iteration.\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Oneof descriptor.\r\n * @interface IOneOf\r\n * @property {Array.} oneof Oneof field names\r\n * @property {Object.} [options] Oneof options\r\n */\r\n\r\n/**\r\n * Constructs a oneof from a oneof descriptor.\r\n * @param {string} name Oneof name\r\n * @param {IOneOf} json Oneof descriptor\r\n * @returns {OneOf} Created oneof\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nOneOf.fromJSON = function fromJSON(name, json) {\r\n return new OneOf(name, json.oneof, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this oneof to a oneof descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IOneOf} Oneof descriptor\r\n */\r\nOneOf.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"oneof\" , this.oneof,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds the fields of the specified oneof to the parent if not already done so.\r\n * @param {OneOf} oneof The oneof\r\n * @returns {undefined}\r\n * @inner\r\n * @ignore\r\n */\r\nfunction addFieldsToParent(oneof) {\r\n if (oneof.parent)\r\n for (var i = 0; i < oneof.fieldsArray.length; ++i)\r\n if (!oneof.fieldsArray[i].parent)\r\n oneof.parent.add(oneof.fieldsArray[i]);\r\n}\r\n\r\n/**\r\n * Adds a field to this oneof and removes it from its current parent, if any.\r\n * @param {Field} field Field to add\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.add = function add(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n if (field.parent && field.parent !== this.parent)\r\n field.parent.remove(field);\r\n this.oneof.push(field.name);\r\n this.fieldsArray.push(field);\r\n field.partOf = this; // field.parent remains null\r\n addFieldsToParent(this);\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a field from this oneof and puts it back to the oneof's parent.\r\n * @param {Field} field Field to remove\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.remove = function remove(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n var index = this.fieldsArray.indexOf(field);\r\n\r\n /* istanbul ignore if */\r\n if (index < 0)\r\n throw Error(field + \" is not a member of \" + this);\r\n\r\n this.fieldsArray.splice(index, 1);\r\n index = this.oneof.indexOf(field.name);\r\n\r\n /* istanbul ignore else */\r\n if (index > -1) // theoretical\r\n this.oneof.splice(index, 1);\r\n\r\n field.partOf = null;\r\n return this;\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onAdd = function onAdd(parent) {\r\n ReflectionObject.prototype.onAdd.call(this, parent);\r\n var self = this;\r\n // Collect present fields\r\n for (var i = 0; i < this.oneof.length; ++i) {\r\n var field = parent.get(this.oneof[i]);\r\n if (field && !field.partOf) {\r\n field.partOf = self;\r\n self.fieldsArray.push(field);\r\n }\r\n }\r\n // Add not yet present fields\r\n addFieldsToParent(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onRemove = function onRemove(parent) {\r\n for (var i = 0, field; i < this.fieldsArray.length; ++i)\r\n if ((field = this.fieldsArray[i]).parent)\r\n field.parent.remove(field);\r\n ReflectionObject.prototype.onRemove.call(this, parent);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link OneOf.d} (TypeScript).\r\n * @typedef OneOfDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} oneofName OneOf name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * OneOf decorator (TypeScript).\r\n * @function\r\n * @param {...string} fieldNames Field names\r\n * @returns {OneOfDecorator} Decorator function\r\n * @template T extends string\r\n */\r\nOneOf.d = function decorateOneOf() {\r\n var fieldNames = new Array(arguments.length),\r\n index = 0;\r\n while (index < arguments.length)\r\n fieldNames[index] = arguments[index++];\r\n return function oneOfDecorator(prototype, oneofName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new OneOf(oneofName, fieldNames));\r\n Object.defineProperty(prototype, oneofName, {\r\n get: util.oneOfGetter(fieldNames),\r\n set: util.oneOfSetter(fieldNames)\r\n });\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(35);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(24);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = Root;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = \"Root\";\r\n\r\nvar Field = require(15),\r\n Enum = require(14),\r\n OneOf = require(23),\r\n util = require(33);\r\n\r\nvar Type, // cyclic\r\n parse, // might be excluded\r\n common; // \"\r\n\r\n/**\r\n * Constructs a new root namespace instance.\r\n * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {Object.} [options] Top level options\r\n */\r\nfunction Root(options) {\r\n Namespace.call(this, \"\", options);\r\n\r\n /**\r\n * Deferred extension fields.\r\n * @type {Field[]}\r\n */\r\n this.deferred = [];\r\n\r\n /**\r\n * Resolved file names of loaded files.\r\n * @type {string[]}\r\n */\r\n this.files = [];\r\n}\r\n\r\n/**\r\n * Loads a namespace descriptor into a root namespace.\r\n * @param {INamespace} json Nameespace descriptor\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted\r\n * @returns {Root} Root namespace\r\n */\r\nRoot.fromJSON = function fromJSON(json, root) {\r\n if (!root)\r\n root = new Root();\r\n if (json.options)\r\n root.setOptions(json.options);\r\n return root.addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Resolves the path of an imported file, relative to the importing origin.\r\n * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories.\r\n * @function\r\n * @param {string} origin The file name of the importing file\r\n * @param {string} target The file name being imported\r\n * @returns {string|null} Resolved path to `target` or `null` to skip the file\r\n */\r\nRoot.prototype.resolvePath = util.path.resolve;\r\n\r\n// A symbol-like function to safely signal synchronous loading\r\n/* istanbul ignore next */\r\nfunction SYNC() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} options Parse options\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nRoot.prototype.load = function load(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = undefined;\r\n }\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(load, self, filename, options);\r\n\r\n var sync = callback === SYNC; // undocumented\r\n\r\n // Finishes loading by calling the callback (exactly once)\r\n function finish(err, root) {\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return;\r\n var cb = callback;\r\n callback = null;\r\n if (sync)\r\n throw err;\r\n cb(err, root);\r\n }\r\n\r\n // Processes a single file\r\n function process(filename, source) {\r\n try {\r\n if (util.isString(source) && source.charAt(0) === \"{\")\r\n source = JSON.parse(source);\r\n if (!util.isString(source))\r\n self.setOptions(source.options).addJSON(source.nested);\r\n else {\r\n parse.filename = filename;\r\n var parsed = parse(source, self, options),\r\n resolved,\r\n i = 0;\r\n if (parsed.imports)\r\n for (; i < parsed.imports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.imports[i]))\r\n fetch(resolved);\r\n if (parsed.weakImports)\r\n for (i = 0; i < parsed.weakImports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.weakImports[i]))\r\n fetch(resolved, true);\r\n }\r\n } catch (err) {\r\n finish(err);\r\n }\r\n if (!sync && !queued)\r\n finish(null, self); // only once anyway\r\n }\r\n\r\n // Fetches a single file\r\n function fetch(filename, weak) {\r\n\r\n // Strip path if this file references a bundled definition\r\n var idx = filename.lastIndexOf(\"google/protobuf/\");\r\n if (idx > -1) {\r\n var altname = filename.substring(idx);\r\n if (altname in common)\r\n filename = altname;\r\n }\r\n\r\n // Skip if already loaded / attempted\r\n if (self.files.indexOf(filename) > -1)\r\n return;\r\n self.files.push(filename);\r\n\r\n // Shortcut bundled definitions\r\n if (filename in common) {\r\n if (sync)\r\n process(filename, common[filename]);\r\n else {\r\n ++queued;\r\n setTimeout(function() {\r\n --queued;\r\n process(filename, common[filename]);\r\n });\r\n }\r\n return;\r\n }\r\n\r\n // Otherwise fetch from disk or network\r\n if (sync) {\r\n var source;\r\n try {\r\n source = util.fs.readFileSync(filename).toString(\"utf8\");\r\n } catch (err) {\r\n if (!weak)\r\n finish(err);\r\n return;\r\n }\r\n process(filename, source);\r\n } else {\r\n ++queued;\r\n util.fetch(filename, function(err, source) {\r\n --queued;\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return; // terminated meanwhile\r\n if (err) {\r\n /* istanbul ignore else */\r\n if (!weak)\r\n finish(err);\r\n else if (!queued) // can't be covered reliably\r\n finish(null, self);\r\n return;\r\n }\r\n process(filename, source);\r\n });\r\n }\r\n }\r\n var queued = 0;\r\n\r\n // Assembling the root namespace doesn't require working type\r\n // references anymore, so we can load everything in parallel\r\n if (util.isString(filename))\r\n filename = [ filename ];\r\n for (var i = 0, resolved; i < filename.length; ++i)\r\n if (resolved = self.resolvePath(\"\", filename[i]))\r\n fetch(resolved);\r\n\r\n if (sync)\r\n return self;\r\n if (!queued)\r\n finish(null, self);\r\n return undefined;\r\n};\r\n// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n// function load(filename:string, [options:IParseOptions]):Promise\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only).\r\n * @function Root#loadSync\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n */\r\nRoot.prototype.loadSync = function loadSync(filename, options) {\r\n if (!util.isNode)\r\n throw Error(\"not supported\");\r\n return this.load(filename, options, SYNC);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nRoot.prototype.resolveAll = function resolveAll() {\r\n if (this.deferred.length)\r\n throw Error(\"unresolvable extensions: \" + this.deferred.map(function(field) {\r\n return \"'extend \" + field.extend + \"' in \" + field.parent.fullName;\r\n }).join(\", \"));\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n// only uppercased (and thus conflict-free) children are exposed, see below\r\nvar exposeRe = /^[A-Z]/;\r\n\r\n/**\r\n * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type.\r\n * @param {Root} root Root instance\r\n * @param {Field} field Declaring extension field witin the declaring type\r\n * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise\r\n * @inner\r\n * @ignore\r\n */\r\nfunction tryHandleExtension(root, field) {\r\n var extendedType = field.parent.lookup(field.extend);\r\n if (extendedType) {\r\n var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options);\r\n sisterField.declaringField = field;\r\n field.extensionField = sisterField;\r\n extendedType.add(sisterField);\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * Called when any object is added to this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object added\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleAdd = function _handleAdd(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField)\r\n if (!tryHandleExtension(this, object))\r\n this.deferred.push(object);\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object.values; // expose enum values as property of its parent\r\n\r\n } else if (!(object instanceof OneOf)) /* everything else is a namespace */ {\r\n\r\n if (object instanceof Type) // Try to handle any deferred extensions\r\n for (var i = 0; i < this.deferred.length;)\r\n if (tryHandleExtension(this, this.deferred[i]))\r\n this.deferred.splice(i, 1);\r\n else\r\n ++i;\r\n for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace\r\n this._handleAdd(object._nestedArray[j]);\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object; // expose namespace as property of its parent\r\n }\r\n\r\n // The above also adds uppercased (and thus conflict-free) nested types, services and enums as\r\n // properties of namespaces just like static code does. This allows using a .d.ts generated for\r\n // a static module with reflection-based solutions where the condition is met.\r\n};\r\n\r\n/**\r\n * Called when any object is removed from this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object removed\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleRemove = function _handleRemove(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field */ object.extend !== undefined) {\r\n if (/* already handled */ object.extensionField) { // remove its sister field\r\n object.extensionField.parent.remove(object.extensionField);\r\n object.extensionField = null;\r\n } else { // cancel the extension\r\n var index = this.deferred.indexOf(object);\r\n /* istanbul ignore else */\r\n if (index > -1)\r\n this.deferred.splice(index, 1);\r\n }\r\n }\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose enum values\r\n\r\n } else if (object instanceof Namespace) {\r\n\r\n for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace\r\n this._handleRemove(object._nestedArray[i]);\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose namespaces\r\n\r\n }\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nRoot._configure = function(Type_, parse_, common_) {\r\n Type = Type_;\r\n parse = parse_;\r\n common = common_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(29);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(35);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = \"Service\";\r\n\r\nvar Method = require(20),\r\n util = require(33),\r\n rpc = require(28);\r\n\r\n/**\r\n * Constructs a new service instance.\r\n * @classdesc Reflected service.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Service name\r\n * @param {Object.} [options] Service options\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nfunction Service(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Service methods.\r\n * @type {Object.}\r\n */\r\n this.methods = {}; // toJSON, marker\r\n\r\n /**\r\n * Cached methods as an array.\r\n * @type {Method[]|null}\r\n * @private\r\n */\r\n this._methodsArray = null;\r\n}\r\n\r\n/**\r\n * Service descriptor.\r\n * @interface IService\r\n * @extends INamespace\r\n * @property {Object.} methods Method descriptors\r\n */\r\n\r\n/**\r\n * Constructs a service from a service descriptor.\r\n * @param {string} name Service name\r\n * @param {IService} json Service descriptor\r\n * @returns {Service} Created service\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nService.fromJSON = function fromJSON(name, json) {\r\n var service = new Service(name, json.options);\r\n /* istanbul ignore else */\r\n if (json.methods)\r\n for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i)\r\n service.add(Method.fromJSON(names[i], json.methods[names[i]]));\r\n if (json.nested)\r\n service.addJSON(json.nested);\r\n service.comment = json.comment;\r\n return service;\r\n};\r\n\r\n/**\r\n * Converts this service to a service descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IService} Service descriptor\r\n */\r\nService.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"methods\" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {},\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Methods of this service as an array for iteration.\r\n * @name Service#methodsArray\r\n * @type {Method[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Service.prototype, \"methodsArray\", {\r\n get: function() {\r\n return this._methodsArray || (this._methodsArray = util.toArray(this.methods));\r\n }\r\n});\r\n\r\nfunction clearCache(service) {\r\n service._methodsArray = null;\r\n return service;\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.get = function get(name) {\r\n return this.methods[name]\r\n || Namespace.prototype.get.call(this, name);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.resolveAll = function resolveAll() {\r\n var methods = this.methodsArray;\r\n for (var i = 0; i < methods.length; ++i)\r\n methods[i].resolve();\r\n return Namespace.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.add = function add(object) {\r\n\r\n /* istanbul ignore if */\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Method) {\r\n this.methods[object.name] = object;\r\n object.parent = this;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.remove = function remove(object) {\r\n if (object instanceof Method) {\r\n\r\n /* istanbul ignore if */\r\n if (this.methods[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.methods[object.name];\r\n object.parent = null;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Creates a runtime service using the specified rpc implementation.\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed.\r\n */\r\nService.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) {\r\n var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited);\r\n for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) {\r\n var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\\w_]/g, \"\");\r\n rpcService[methodName] = util.codegen([\"r\",\"c\"], util.isReserved(methodName) ? methodName + \"_\" : methodName)(\"return this.rpcCall(m,q,s,r,c)\")({\r\n m: method,\r\n q: method.resolvedRequestType.ctor,\r\n s: method.resolvedResponseType.ctor\r\n });\r\n }\r\n return rpcService;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Type;\r\n\r\n// extends Namespace\r\nvar Namespace = require(21);\r\n((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = \"Type\";\r\n\r\nvar Enum = require(14),\r\n OneOf = require(23),\r\n Field = require(15),\r\n MapField = require(18),\r\n Service = require(30),\r\n Message = require(19),\r\n Reader = require(24),\r\n Writer = require(38),\r\n util = require(33),\r\n encoder = require(13),\r\n decoder = require(12),\r\n verifier = require(36),\r\n converter = require(11),\r\n wrappers = require(37);\r\n\r\n/**\r\n * Constructs a new reflected message type instance.\r\n * @classdesc Reflected message type.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Message name\r\n * @param {Object.} [options] Declared options\r\n */\r\nfunction Type(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Message fields.\r\n * @type {Object.}\r\n */\r\n this.fields = {}; // toJSON, marker\r\n\r\n /**\r\n * Oneofs declared within this namespace, if any.\r\n * @type {Object.}\r\n */\r\n this.oneofs = undefined; // toJSON\r\n\r\n /**\r\n * Extension ranges, if any.\r\n * @type {number[][]}\r\n */\r\n this.extensions = undefined; // toJSON\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n /*?\r\n * Whether this type is a legacy group.\r\n * @type {boolean|undefined}\r\n */\r\n this.group = undefined; // toJSON\r\n\r\n /**\r\n * Cached fields by id.\r\n * @type {Object.|null}\r\n * @private\r\n */\r\n this._fieldsById = null;\r\n\r\n /**\r\n * Cached fields as an array.\r\n * @type {Field[]|null}\r\n * @private\r\n */\r\n this._fieldsArray = null;\r\n\r\n /**\r\n * Cached oneofs as an array.\r\n * @type {OneOf[]|null}\r\n * @private\r\n */\r\n this._oneofsArray = null;\r\n\r\n /**\r\n * Cached constructor.\r\n * @type {Constructor<{}>}\r\n * @private\r\n */\r\n this._ctor = null;\r\n}\r\n\r\nObject.defineProperties(Type.prototype, {\r\n\r\n /**\r\n * Message fields by id.\r\n * @name Type#fieldsById\r\n * @type {Object.}\r\n * @readonly\r\n */\r\n fieldsById: {\r\n get: function() {\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById)\r\n return this._fieldsById;\r\n\r\n this._fieldsById = {};\r\n for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) {\r\n var field = this.fields[names[i]],\r\n id = field.id;\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById[id])\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n\r\n this._fieldsById[id] = field;\r\n }\r\n return this._fieldsById;\r\n }\r\n },\r\n\r\n /**\r\n * Fields of this message as an array for iteration.\r\n * @name Type#fieldsArray\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n fieldsArray: {\r\n get: function() {\r\n return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields));\r\n }\r\n },\r\n\r\n /**\r\n * Oneofs of this message as an array for iteration.\r\n * @name Type#oneofsArray\r\n * @type {OneOf[]}\r\n * @readonly\r\n */\r\n oneofsArray: {\r\n get: function() {\r\n return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs));\r\n }\r\n },\r\n\r\n /**\r\n * The registered constructor, if any registered, otherwise a generic constructor.\r\n * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor.\r\n * @name Type#ctor\r\n * @type {Constructor<{}>}\r\n */\r\n ctor: {\r\n get: function() {\r\n return this._ctor || (this.ctor = Type.generateConstructor(this)());\r\n },\r\n set: function(ctor) {\r\n\r\n // Ensure proper prototype\r\n var prototype = ctor.prototype;\r\n if (!(prototype instanceof Message)) {\r\n (ctor.prototype = new Message()).constructor = ctor;\r\n util.merge(ctor.prototype, prototype);\r\n }\r\n\r\n // Classes and messages reference their reflected type\r\n ctor.$type = ctor.prototype.$type = this;\r\n\r\n // Mix in static methods\r\n util.merge(ctor, Message, true);\r\n\r\n this._ctor = ctor;\r\n\r\n // Messages have non-enumerable default values on their prototype\r\n var i = 0;\r\n for (; i < /* initializes */ this.fieldsArray.length; ++i)\r\n this._fieldsArray[i].resolve(); // ensures a proper value\r\n\r\n // Messages have non-enumerable getters and setters for each virtual oneof field\r\n var ctorProperties = {};\r\n for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i)\r\n ctorProperties[this._oneofsArray[i].resolve().name] = {\r\n get: util.oneOfGetter(this._oneofsArray[i].oneof),\r\n set: util.oneOfSetter(this._oneofsArray[i].oneof)\r\n };\r\n if (i)\r\n Object.defineProperties(ctor.prototype, ctorProperties);\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Generates a constructor function for the specified type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nType.generateConstructor = function generateConstructor(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n var gen = util.codegen([\"p\"], mtype.name);\r\n // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype\r\n for (var i = 0, field; i < mtype.fieldsArray.length; ++i)\r\n if ((field = mtype._fieldsArray[i]).map) gen\r\n (\"this%s={}\", util.safeProp(field.name));\r\n else if (field.repeated) gen\r\n (\"this%s=[]\", util.safeProp(field.name));\r\n return gen\r\n (\"if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors\r\n * @property {Object.} fields Field descriptors\r\n * @property {number[][]} [extensions] Extension ranges\r\n * @property {number[][]} [reserved] Reserved ranges\r\n * @property {boolean} [group=false] Whether a legacy group or not\r\n */\r\n\r\n/**\r\n * Creates a message type from a message type descriptor.\r\n * @param {string} name Message name\r\n * @param {IType} json Message type descriptor\r\n * @returns {Type} Created message type\r\n */\r\nType.fromJSON = function fromJSON(name, json) {\r\n var type = new Type(name, json.options);\r\n type.extensions = json.extensions;\r\n type.reserved = json.reserved;\r\n var names = Object.keys(json.fields),\r\n i = 0;\r\n for (; i < names.length; ++i)\r\n type.add(\r\n ( typeof json.fields[names[i]].keyType !== \"undefined\"\r\n ? MapField.fromJSON\r\n : Field.fromJSON )(names[i], json.fields[names[i]])\r\n );\r\n if (json.oneofs)\r\n for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i)\r\n type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]]));\r\n if (json.nested)\r\n for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) {\r\n var nested = json.nested[names[i]];\r\n type.add( // most to least likely\r\n ( nested.id !== undefined\r\n ? Field.fromJSON\r\n : nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n if (json.extensions && json.extensions.length)\r\n type.extensions = json.extensions;\r\n if (json.reserved && json.reserved.length)\r\n type.reserved = json.reserved;\r\n if (json.group)\r\n type.group = true;\r\n if (json.comment)\r\n type.comment = json.comment;\r\n return type;\r\n};\r\n\r\n/**\r\n * Converts this message type to a message type descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IType} Message type descriptor\r\n */\r\nType.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"oneofs\" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions),\r\n \"fields\" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {},\r\n \"extensions\" , this.extensions && this.extensions.length ? this.extensions : undefined,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"group\" , this.group || undefined,\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.resolveAll = function resolveAll() {\r\n var fields = this.fieldsArray, i = 0;\r\n while (i < fields.length)\r\n fields[i++].resolve();\r\n var oneofs = this.oneofsArray; i = 0;\r\n while (i < oneofs.length)\r\n oneofs[i++].resolve();\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.get = function get(name) {\r\n return this.fields[name]\r\n || this.oneofs && this.oneofs[name]\r\n || this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Adds a nested object to this type.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id\r\n */\r\nType.prototype.add = function add(object) {\r\n\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Field && object.extend === undefined) {\r\n // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects.\r\n // The root object takes care of adding distinct sister-fields to the respective extended\r\n // type instead.\r\n\r\n // avoids calling the getter if not absolutely necessary because it's called quite frequently\r\n if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id])\r\n throw Error(\"duplicate id \" + object.id + \" in \" + this);\r\n if (this.isReservedId(object.id))\r\n throw Error(\"id \" + object.id + \" is reserved in \" + this);\r\n if (this.isReservedName(object.name))\r\n throw Error(\"name '\" + object.name + \"' is reserved in \" + this);\r\n\r\n if (object.parent)\r\n object.parent.remove(object);\r\n this.fields[object.name] = object;\r\n object.message = this;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n if (!this.oneofs)\r\n this.oneofs = {};\r\n this.oneofs[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this type.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this type\r\n */\r\nType.prototype.remove = function remove(object) {\r\n if (object instanceof Field && object.extend === undefined) {\r\n // See Type#add for the reason why extension fields are excluded here.\r\n\r\n /* istanbul ignore if */\r\n if (!this.fields || this.fields[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.fields[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n\r\n /* istanbul ignore if */\r\n if (!this.oneofs || this.oneofs[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.oneofs[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.create = function create(properties) {\r\n return new this.ctor(properties);\r\n};\r\n\r\n/**\r\n * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}.\r\n * @returns {Type} `this`\r\n */\r\nType.prototype.setup = function setup() {\r\n // Sets up everything at once so that the prototype chain does not have to be re-evaluated\r\n // multiple times (V8, soft-deopt prototype-check).\r\n\r\n var fullName = this.fullName,\r\n types = [];\r\n for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i)\r\n types.push(this._fieldsArray[i].resolve().resolvedType);\r\n\r\n // Replace setup methods with type-specific generated functions\r\n this.encode = encoder(this)({\r\n Writer : Writer,\r\n types : types,\r\n util : util\r\n });\r\n this.decode = decoder(this)({\r\n Reader : Reader,\r\n types : types,\r\n util : util\r\n });\r\n this.verify = verifier(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.fromObject = converter.fromObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.toObject = converter.toObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n\r\n // Inject custom wrappers for common types\r\n var wrapper = wrappers[fullName];\r\n if (wrapper) {\r\n var originalThis = Object.create(this);\r\n // if (wrapper.fromObject) {\r\n originalThis.fromObject = this.fromObject;\r\n this.fromObject = wrapper.fromObject.bind(originalThis);\r\n // }\r\n // if (wrapper.toObject) {\r\n originalThis.toObject = this.toObject;\r\n this.toObject = wrapper.toObject.bind(originalThis);\r\n // }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encode = function encode_setup(message, writer) {\r\n return this.setup().encode(message, writer); // overrides this method\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim();\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @param {number} [length] Length of the message, if known beforehand\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError<{}>} If required fields are missing\r\n */\r\nType.prototype.decode = function decode_setup(reader, length) {\r\n return this.setup().decode(reader, length); // overrides this method\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its byte length as a varint.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError} If required fields are missing\r\n */\r\nType.prototype.decodeDelimited = function decodeDelimited(reader) {\r\n if (!(reader instanceof Reader))\r\n reader = Reader.create(reader);\r\n return this.decode(reader, reader.uint32());\r\n};\r\n\r\n/**\r\n * Verifies that field values are valid and that required fields are present.\r\n * @param {Object.} message Plain object to verify\r\n * @returns {null|string} `null` if valid, otherwise the reason why it is not\r\n */\r\nType.prototype.verify = function verify_setup(message) {\r\n return this.setup().verify(message); // overrides this method\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object to convert\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.fromObject = function fromObject(object) {\r\n return this.setup().fromObject(object);\r\n};\r\n\r\n/**\r\n * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}.\r\n * @interface IConversionOptions\r\n * @property {Function} [longs] Long conversion type.\r\n * Valid values are `String` and `Number` (the global types).\r\n * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library.\r\n * @property {Function} [enums] Enum value conversion type.\r\n * Only valid value is `String` (the global type).\r\n * Defaults to copy the present value, which is the numeric id.\r\n * @property {Function} [bytes] Bytes value conversion type.\r\n * Valid values are `Array` and (a base64 encoded) `String` (the global types).\r\n * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser.\r\n * @property {boolean} [defaults=false] Also sets default values on the resulting object\r\n * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false`\r\n * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false`\r\n * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any\r\n * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings\r\n */\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n */\r\nType.prototype.toObject = function toObject(message, options) {\r\n return this.setup().toObject(message, options);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Type.d} (TypeScript).\r\n * @typedef TypeDecorator\r\n * @type {function}\r\n * @param {Constructor} target Target constructor\r\n * @returns {undefined}\r\n * @template T extends Message\r\n */\r\n\r\n/**\r\n * Type decorator (TypeScript).\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {TypeDecorator} Decorator function\r\n * @template T extends Message\r\n */\r\nType.d = function decorateType(typeName) {\r\n return function typeDecorator(target) {\r\n util.decorateType(target, typeName);\r\n };\r\n};\r\n","\"use strict\";\r\n\r\n/**\r\n * Common type constants.\r\n * @namespace\r\n */\r\nvar types = exports;\r\n\r\nvar util = require(33);\r\n\r\nvar s = [\r\n \"double\", // 0\r\n \"float\", // 1\r\n \"int32\", // 2\r\n \"uint32\", // 3\r\n \"sint32\", // 4\r\n \"fixed32\", // 5\r\n \"sfixed32\", // 6\r\n \"int64\", // 7\r\n \"uint64\", // 8\r\n \"sint64\", // 9\r\n \"fixed64\", // 10\r\n \"sfixed64\", // 11\r\n \"bool\", // 12\r\n \"string\", // 13\r\n \"bytes\" // 14\r\n];\r\n\r\nfunction bake(values, offset) {\r\n var i = 0, o = {};\r\n offset |= 0;\r\n while (i < values.length) o[s[i + offset]] = values[i++];\r\n return o;\r\n}\r\n\r\n/**\r\n * Basic type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n * @property {number} bytes=2 Ldelim wire type\r\n */\r\ntypes.basic = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2,\r\n /* bytes */ 2\r\n]);\r\n\r\n/**\r\n * Basic type defaults.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=0 Double default\r\n * @property {number} float=0 Float default\r\n * @property {number} int32=0 Int32 default\r\n * @property {number} uint32=0 Uint32 default\r\n * @property {number} sint32=0 Sint32 default\r\n * @property {number} fixed32=0 Fixed32 default\r\n * @property {number} sfixed32=0 Sfixed32 default\r\n * @property {number} int64=0 Int64 default\r\n * @property {number} uint64=0 Uint64 default\r\n * @property {number} sint64=0 Sint32 default\r\n * @property {number} fixed64=0 Fixed64 default\r\n * @property {number} sfixed64=0 Sfixed64 default\r\n * @property {boolean} bool=false Bool default\r\n * @property {string} string=\"\" String default\r\n * @property {Array.} bytes=Array(0) Bytes default\r\n * @property {null} message=null Message default\r\n */\r\ntypes.defaults = bake([\r\n /* double */ 0,\r\n /* float */ 0,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 0,\r\n /* sfixed32 */ 0,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 0,\r\n /* sfixed64 */ 0,\r\n /* bool */ false,\r\n /* string */ \"\",\r\n /* bytes */ util.emptyArray,\r\n /* message */ null\r\n]);\r\n\r\n/**\r\n * Basic long type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n */\r\ntypes.long = bake([\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1\r\n], 7);\r\n\r\n/**\r\n * Allowed types for map keys with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n */\r\ntypes.mapKey = bake([\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2\r\n], 2);\r\n\r\n/**\r\n * Allowed types for packed repeated fields with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n */\r\ntypes.packed = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0\r\n]);\r\n","\"use strict\";\r\n\r\n/**\r\n * Various utility functions.\r\n * @namespace\r\n */\r\nvar util = module.exports = require(35);\r\n\r\nvar roots = require(27);\r\n\r\nvar Type, // cyclic\r\n Enum;\r\n\r\nutil.codegen = require(3);\r\nutil.fetch = require(5);\r\nutil.path = require(8);\r\n\r\n/**\r\n * Node's fs module if available.\r\n * @type {Object.}\r\n */\r\nutil.fs = util.inquire(\"fs\");\r\n\r\n/**\r\n * Converts an object's values to an array.\r\n * @param {Object.} object Object to convert\r\n * @returns {Array.<*>} Converted array\r\n */\r\nutil.toArray = function toArray(object) {\r\n if (object) {\r\n var keys = Object.keys(object),\r\n array = new Array(keys.length),\r\n index = 0;\r\n while (index < keys.length)\r\n array[index] = object[keys[index++]];\r\n return array;\r\n }\r\n return [];\r\n};\r\n\r\n/**\r\n * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values.\r\n * @param {Array.<*>} array Array to convert\r\n * @returns {Object.} Converted object\r\n */\r\nutil.toObject = function toObject(array) {\r\n var object = {},\r\n index = 0;\r\n while (index < array.length) {\r\n var key = array[index++],\r\n val = array[index++];\r\n if (val !== undefined)\r\n object[key] = val;\r\n }\r\n return object;\r\n};\r\n\r\nvar safePropBackslashRe = /\\\\/g,\r\n safePropQuoteRe = /\"/g;\r\n\r\n/**\r\n * Tests whether the specified name is a reserved word in JS.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nutil.isReserved = function isReserved(name) {\r\n return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name);\r\n};\r\n\r\n/**\r\n * Returns a safe property accessor for the specified property name.\r\n * @param {string} prop Property name\r\n * @returns {string} Safe accessor\r\n */\r\nutil.safeProp = function safeProp(prop) {\r\n if (!/^[$\\w_]+$/.test(prop) || util.isReserved(prop))\r\n return \"[\\\"\" + prop.replace(safePropBackslashRe, \"\\\\\\\\\").replace(safePropQuoteRe, \"\\\\\\\"\") + \"\\\"]\";\r\n return \".\" + prop;\r\n};\r\n\r\n/**\r\n * Converts the first character of a string to upper case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.ucFirst = function ucFirst(str) {\r\n return str.charAt(0).toUpperCase() + str.substring(1);\r\n};\r\n\r\nvar camelCaseRe = /_([a-z])/g;\r\n\r\n/**\r\n * Converts a string to camel case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.camelCase = function camelCase(str) {\r\n return str.substring(0, 1)\r\n + str.substring(1)\r\n .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); });\r\n};\r\n\r\n/**\r\n * Compares reflected fields by id.\r\n * @param {Field} a First field\r\n * @param {Field} b Second field\r\n * @returns {number} Comparison value\r\n */\r\nutil.compareFieldsById = function compareFieldsById(a, b) {\r\n return a.id - b.id;\r\n};\r\n\r\n/**\r\n * Decorator helper for types (TypeScript).\r\n * @param {Constructor} ctor Constructor function\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {Type} Reflected type\r\n * @template T extends Message\r\n * @property {Root} root Decorators root\r\n */\r\nutil.decorateType = function decorateType(ctor, typeName) {\r\n\r\n /* istanbul ignore if */\r\n if (ctor.$type) {\r\n if (typeName && ctor.$type.name !== typeName) {\r\n util.decorateRoot.remove(ctor.$type);\r\n ctor.$type.name = typeName;\r\n util.decorateRoot.add(ctor.$type);\r\n }\r\n return ctor.$type;\r\n }\r\n\r\n /* istanbul ignore next */\r\n if (!Type)\r\n Type = require(31);\r\n\r\n var type = new Type(typeName || ctor.name);\r\n util.decorateRoot.add(type);\r\n type.ctor = ctor; // sets up .encode, .decode etc.\r\n Object.defineProperty(ctor, \"$type\", { value: type, enumerable: false });\r\n Object.defineProperty(ctor.prototype, \"$type\", { value: type, enumerable: false });\r\n return type;\r\n};\r\n\r\nvar decorateEnumIndex = 0;\r\n\r\n/**\r\n * Decorator helper for enums (TypeScript).\r\n * @param {Object} object Enum object\r\n * @returns {Enum} Reflected enum\r\n */\r\nutil.decorateEnum = function decorateEnum(object) {\r\n\r\n /* istanbul ignore if */\r\n if (object.$type)\r\n return object.$type;\r\n\r\n /* istanbul ignore next */\r\n if (!Enum)\r\n Enum = require(14);\r\n\r\n var enm = new Enum(\"Enum\" + decorateEnumIndex++, object);\r\n util.decorateRoot.add(enm);\r\n Object.defineProperty(object, \"$type\", { value: enm, enumerable: false });\r\n return enm;\r\n};\r\n\r\n/**\r\n * Decorator root (TypeScript).\r\n * @name util.decorateRoot\r\n * @type {Root}\r\n * @readonly\r\n */\r\nObject.defineProperty(util, \"decorateRoot\", {\r\n get: function() {\r\n return roots[\"decorated\"] || (roots[\"decorated\"] = new (require(26))());\r\n }\r\n});\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(35);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(4);\r\n\r\n// float handling accross browsers\r\nutil.float = require(6);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(7);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(10);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(9);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(34);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = verifier;\r\n\r\nvar Enum = require(14),\r\n util = require(33);\r\n\r\nfunction invalid(field, expected) {\r\n return field.name + \": \" + expected + (field.repeated && expected !== \"array\" ? \"[]\" : field.map && expected !== \"object\" ? \"{k:\"+field.keyType+\"}\" : \"\") + \" expected\";\r\n}\r\n\r\n/**\r\n * Generates a partial value verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyValue(gen, field, fieldIndex, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(%s){\", ref)\r\n (\"default:\")\r\n (\"return%j\", invalid(field, \"enum value\"));\r\n for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen\r\n (\"case %i:\", field.resolvedType.values[keys[j]]);\r\n gen\r\n (\"break\")\r\n (\"}\");\r\n } else {\r\n gen\r\n (\"{\")\r\n (\"var e=types[%i].verify(%s);\", fieldIndex, ref)\r\n (\"if(e)\")\r\n (\"return%j+e\", field.name + \".\")\r\n (\"}\");\r\n }\r\n } else {\r\n switch (field.type) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.isInteger(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))\", ref, ref, ref, ref)\r\n (\"return%j\", invalid(field, \"integer|Long\"));\r\n break;\r\n case \"float\":\r\n case \"double\": gen\r\n (\"if(typeof %s!==\\\"number\\\")\", ref)\r\n (\"return%j\", invalid(field, \"number\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(typeof %s!==\\\"boolean\\\")\", ref)\r\n (\"return%j\", invalid(field, \"boolean\"));\r\n break;\r\n case \"string\": gen\r\n (\"if(!util.isString(%s))\", ref)\r\n (\"return%j\", invalid(field, \"string\"));\r\n break;\r\n case \"bytes\": gen\r\n (\"if(!(%s&&typeof %s.length===\\\"number\\\"||util.isString(%s)))\", ref, ref, ref)\r\n (\"return%j\", invalid(field, \"buffer\"));\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a partial key verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyKey(gen, field, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n switch (field.keyType) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.key32Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer key\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.key64Re.test(%s))\", ref) // see comment above: x is ok, d is not\r\n (\"return%j\", invalid(field, \"integer|Long key\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(!util.key2Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"boolean key\"));\r\n break;\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a verifier specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction verifier(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n\r\n var gen = util.codegen([\"m\"], mtype.name + \"$verify\")\r\n (\"if(typeof m!==\\\"object\\\"||m===null)\")\r\n (\"return%j\", \"object expected\");\r\n var oneofs = mtype.oneofsArray,\r\n seenFirstField = {};\r\n if (oneofs.length) gen\r\n (\"var p={}\");\r\n\r\n for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name); // !== undefined && !== null\r\n\r\n // map fields\r\n if (field.map) { gen\r\n (\"if(!util.isObject(%s))\", ref)\r\n (\"return%j\", invalid(field, \"object\"))\r\n (\"var k=Object.keys(%s)\", ref)\r\n (\"for(var i=0;i}\r\n * @const\r\n */\r\nvar wrappers = exports;\r\n\r\nvar Message = require(19);\r\n\r\n/**\r\n * From object converter part of an {@link IWrapper}.\r\n * @typedef WrapperFromObjectConverter\r\n * @type {function}\r\n * @param {Object.} object Plain object\r\n * @returns {Message<{}>} Message instance\r\n * @this Type\r\n */\r\n\r\n/**\r\n * To object converter part of an {@link IWrapper}.\r\n * @typedef WrapperToObjectConverter\r\n * @type {function}\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @this Type\r\n */\r\n\r\n/**\r\n * Common type wrapper part of {@link wrappers}.\r\n * @interface IWrapper\r\n * @property {WrapperFromObjectConverter} [fromObject] From object converter\r\n * @property {WrapperToObjectConverter} [toObject] To object converter\r\n */\r\n\r\n// Custom wrapper for Any\r\nwrappers[\".google.protobuf.Any\"] = {\r\n\r\n fromObject: function(object) {\r\n\r\n // unwrap value type if mapped\r\n if (object && object[\"@type\"]) {\r\n var type = this.lookup(object[\"@type\"]);\r\n /* istanbul ignore else */\r\n if (type) {\r\n // type_url does not accept leading \".\"\r\n var type_url = object[\"@type\"].charAt(0) === \".\" ?\r\n object[\"@type\"].substr(1) : object[\"@type\"];\r\n // type_url prefix is optional, but path seperator is required\r\n return this.create({\r\n type_url: \"/\" + type_url,\r\n value: type.encode(type.fromObject(object)).finish()\r\n });\r\n }\r\n }\r\n\r\n return this.fromObject(object);\r\n },\r\n\r\n toObject: function(message, options) {\r\n\r\n // decode value if requested and unmapped\r\n if (options && options.json && message.type_url && message.value) {\r\n // Only use fully qualified type name after the last '/'\r\n var name = message.type_url.substring(message.type_url.lastIndexOf(\"/\") + 1);\r\n var type = this.lookup(name);\r\n /* istanbul ignore else */\r\n if (type)\r\n message = type.decode(message.value);\r\n }\r\n\r\n // wrap value if unmapped\r\n if (!(message instanceof this.ctor) && message instanceof Message) {\r\n var object = message.$type.toObject(message, options);\r\n object[\"@type\"] = message.$type.fullName;\r\n return object;\r\n }\r\n\r\n return this.toObject(message, options);\r\n }\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(35);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(38);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(35);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/dist/minimal/README.md b/node_modules/protobufjs/dist/minimal/README.md new file mode 100644 index 0000000..5eeb571 --- /dev/null +++ b/node_modules/protobufjs/dist/minimal/README.md @@ -0,0 +1,31 @@ +This folder contains prebuilt browser versions of the minimal library suitable for use with statically generated code only. When sending pull requests, it is not required to update these. + +Prebuilt files are in source control to enable pain-free frontend respectively CDN usage: + +CDN usage +--------- + +Development: +``` + +``` + +Production: +``` + +``` + +**NOTE:** Remember to replace the version tag with the exact [release](https://github.com/dcodeIO/protobuf.js/tags) your project depends upon. + +Frontend usage +-------------- + +Development: +``` + +``` + +Production: +``` + +``` diff --git a/node_modules/protobufjs/dist/minimal/protobuf.js b/node_modules/protobufjs/dist/minimal/protobuf.js new file mode 100644 index 0000000..8cda8ce --- /dev/null +++ b/node_modules/protobufjs/dist/minimal/protobuf.js @@ -0,0 +1,2684 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:25 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +(function(undefined){"use strict";(function prelude(modules, cache, entries) { + + // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS + // sources through a conflict-free require shim and is again wrapped within an iife that + // provides a minification-friendly `undefined` var plus a global "use strict" directive + // so that minification can remove the directives of each module. + + function $require(name) { + var $module = cache[name]; + if (!$module) + modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports); + return $module.exports; + } + + var protobuf = $require(entries[0]); + + // Expose globally + protobuf.util.global.protobuf = protobuf; + + // Be nice to AMD + if (typeof define === "function" && define.amd) + define(["long"], function(Long) { + if (Long && Long.isLong) { + protobuf.util.Long = Long; + protobuf.configure(); + } + return protobuf; + }); + + // Be nice to CommonJS + if (typeof module === "object" && module && module.exports) + module.exports = protobuf; + +})/* end of prelude */({1:[function(require,module,exports){ +"use strict"; +module.exports = asPromise; + +/** + * Callback as used by {@link util.asPromise}. + * @typedef asPromiseCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {...*} params Additional arguments + * @returns {undefined} + */ + +/** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ +function asPromise(fn, ctx/*, varargs */) { + var params = new Array(arguments.length - 1), + offset = 0, + index = 2, + pending = true; + while (index < arguments.length) + params[offset++] = arguments[index++]; + return new Promise(function executor(resolve, reject) { + params[offset] = function callback(err/*, varargs */) { + if (pending) { + pending = false; + if (err) + reject(err); + else { + var params = new Array(arguments.length - 1), + offset = 0; + while (offset < params.length) + params[offset++] = arguments[offset]; + resolve.apply(null, params); + } + } + }; + try { + fn.apply(ctx || null, params); + } catch (err) { + if (pending) { + pending = false; + reject(err); + } + } + }); +} + +},{}],2:[function(require,module,exports){ +"use strict"; + +/** + * A minimal base64 implementation for number arrays. + * @memberof util + * @namespace + */ +var base64 = exports; + +/** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ +base64.length = function length(string) { + var p = string.length; + if (!p) + return 0; + var n = 0; + while (--p % 4 > 1 && string.charAt(p) === "=") + ++n; + return Math.ceil(string.length * 3) / 4 - n; +}; + +// Base64 encoding table +var b64 = new Array(64); + +// Base64 decoding table +var s64 = new Array(123); + +// 65..90, 97..122, 48..57, 43, 47 +for (var i = 0; i < 64;) + s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++; + +/** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ +base64.encode = function encode(buffer, start, end) { + var parts = null, + chunk = []; + var i = 0, // output index + j = 0, // goto index + t; // temporary + while (start < end) { + var b = buffer[start++]; + switch (j) { + case 0: + chunk[i++] = b64[b >> 2]; + t = (b & 3) << 4; + j = 1; + break; + case 1: + chunk[i++] = b64[t | b >> 4]; + t = (b & 15) << 2; + j = 2; + break; + case 2: + chunk[i++] = b64[t | b >> 6]; + chunk[i++] = b64[b & 63]; + j = 0; + break; + } + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (j) { + chunk[i++] = b64[t]; + chunk[i++] = 61; + if (j === 1) + chunk[i++] = 61; + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +var invalidEncoding = "invalid encoding"; + +/** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ +base64.decode = function decode(string, buffer, offset) { + var start = offset; + var j = 0, // goto index + t; // temporary + for (var i = 0; i < string.length;) { + var c = string.charCodeAt(i++); + if (c === 61 && j > 1) + break; + if ((c = s64[c]) === undefined) + throw Error(invalidEncoding); + switch (j) { + case 0: + t = c; + j = 1; + break; + case 1: + buffer[offset++] = t << 2 | (c & 48) >> 4; + t = c; + j = 2; + break; + case 2: + buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2; + t = c; + j = 3; + break; + case 3: + buffer[offset++] = (t & 3) << 6 | c; + j = 0; + break; + } + } + if (j === 1) + throw Error(invalidEncoding); + return offset - start; +}; + +/** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if probably base64 encoded, otherwise false + */ +base64.test = function test(string) { + return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string); +}; + +},{}],3:[function(require,module,exports){ +"use strict"; +module.exports = EventEmitter; + +/** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ +function EventEmitter() { + + /** + * Registered listeners. + * @type {Object.} + * @private + */ + this._listeners = {}; +} + +/** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.on = function on(evt, fn, ctx) { + (this._listeners[evt] || (this._listeners[evt] = [])).push({ + fn : fn, + ctx : ctx || this + }); + return this; +}; + +/** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.off = function off(evt, fn) { + if (evt === undefined) + this._listeners = {}; + else { + if (fn === undefined) + this._listeners[evt] = []; + else { + var listeners = this._listeners[evt]; + for (var i = 0; i < listeners.length;) + if (listeners[i].fn === fn) + listeners.splice(i, 1); + else + ++i; + } + } + return this; +}; + +/** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.emit = function emit(evt) { + var listeners = this._listeners[evt]; + if (listeners) { + var args = [], + i = 1; + for (; i < arguments.length;) + args.push(arguments[i++]); + for (i = 0; i < listeners.length;) + listeners[i].fn.apply(listeners[i++].ctx, args); + } + return this; +}; + +},{}],4:[function(require,module,exports){ +"use strict"; + +module.exports = factory(factory); + +/** + * Reads / writes floats / doubles from / to buffers. + * @name util.float + * @namespace + */ + +/** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name util.float.writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name util.float.writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name util.float.readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name util.float.readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name util.float.writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name util.float.writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name util.float.readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name util.float.readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +// Factory function for the purpose of node-based testing in modified global environments +function factory(exports) { + + // float: typed array + if (typeof Float32Array !== "undefined") (function() { + + var f32 = new Float32Array([ -0 ]), + f8b = new Uint8Array(f32.buffer), + le = f8b[3] === 128; + + function writeFloat_f32_cpy(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + } + + function writeFloat_f32_rev(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[3]; + buf[pos + 1] = f8b[2]; + buf[pos + 2] = f8b[1]; + buf[pos + 3] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev; + /* istanbul ignore next */ + exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy; + + function readFloat_f32_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + return f32[0]; + } + + function readFloat_f32_rev(buf, pos) { + f8b[3] = buf[pos ]; + f8b[2] = buf[pos + 1]; + f8b[1] = buf[pos + 2]; + f8b[0] = buf[pos + 3]; + return f32[0]; + } + + /* istanbul ignore next */ + exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev; + /* istanbul ignore next */ + exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy; + + // float: ieee754 + })(); else (function() { + + function writeFloat_ieee754(writeUint, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos); + else if (isNaN(val)) + writeUint(2143289344, buf, pos); + else if (val > 3.4028234663852886e+38) // +-Infinity + writeUint((sign << 31 | 2139095040) >>> 0, buf, pos); + else if (val < 1.1754943508222875e-38) // denormal + writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos); + else { + var exponent = Math.floor(Math.log(val) / Math.LN2), + mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607; + writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos); + } + } + + exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE); + exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE); + + function readFloat_ieee754(readUint, buf, pos) { + var uint = readUint(buf, pos), + sign = (uint >> 31) * 2 + 1, + exponent = uint >>> 23 & 255, + mantissa = uint & 8388607; + return exponent === 255 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 1.401298464324817e-45 * mantissa + : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608); + } + + exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE); + exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE); + + })(); + + // double: typed array + if (typeof Float64Array !== "undefined") (function() { + + var f64 = new Float64Array([-0]), + f8b = new Uint8Array(f64.buffer), + le = f8b[7] === 128; + + function writeDouble_f64_cpy(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + buf[pos + 4] = f8b[4]; + buf[pos + 5] = f8b[5]; + buf[pos + 6] = f8b[6]; + buf[pos + 7] = f8b[7]; + } + + function writeDouble_f64_rev(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[7]; + buf[pos + 1] = f8b[6]; + buf[pos + 2] = f8b[5]; + buf[pos + 3] = f8b[4]; + buf[pos + 4] = f8b[3]; + buf[pos + 5] = f8b[2]; + buf[pos + 6] = f8b[1]; + buf[pos + 7] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev; + /* istanbul ignore next */ + exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy; + + function readDouble_f64_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + f8b[4] = buf[pos + 4]; + f8b[5] = buf[pos + 5]; + f8b[6] = buf[pos + 6]; + f8b[7] = buf[pos + 7]; + return f64[0]; + } + + function readDouble_f64_rev(buf, pos) { + f8b[7] = buf[pos ]; + f8b[6] = buf[pos + 1]; + f8b[5] = buf[pos + 2]; + f8b[4] = buf[pos + 3]; + f8b[3] = buf[pos + 4]; + f8b[2] = buf[pos + 5]; + f8b[1] = buf[pos + 6]; + f8b[0] = buf[pos + 7]; + return f64[0]; + } + + /* istanbul ignore next */ + exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev; + /* istanbul ignore next */ + exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy; + + // double: ieee754 + })(); else (function() { + + function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) { + writeUint(0, buf, pos + off0); + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1); + } else if (isNaN(val)) { + writeUint(0, buf, pos + off0); + writeUint(2146959360, buf, pos + off1); + } else if (val > 1.7976931348623157e+308) { // +-Infinity + writeUint(0, buf, pos + off0); + writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1); + } else { + var mantissa; + if (val < 2.2250738585072014e-308) { // denormal + mantissa = val / 5e-324; + writeUint(mantissa >>> 0, buf, pos + off0); + writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1); + } else { + var exponent = Math.floor(Math.log(val) / Math.LN2); + if (exponent === 1024) + exponent = 1023; + mantissa = val * Math.pow(2, -exponent); + writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0); + writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1); + } + } + } + + exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4); + exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0); + + function readDouble_ieee754(readUint, off0, off1, buf, pos) { + var lo = readUint(buf, pos + off0), + hi = readUint(buf, pos + off1); + var sign = (hi >> 31) * 2 + 1, + exponent = hi >>> 20 & 2047, + mantissa = 4294967296 * (hi & 1048575) + lo; + return exponent === 2047 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 5e-324 * mantissa + : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496); + } + + exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4); + exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0); + + })(); + + return exports; +} + +// uint helpers + +function writeUintLE(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +function writeUintBE(val, buf, pos) { + buf[pos ] = val >>> 24; + buf[pos + 1] = val >>> 16 & 255; + buf[pos + 2] = val >>> 8 & 255; + buf[pos + 3] = val & 255; +} + +function readUintLE(buf, pos) { + return (buf[pos ] + | buf[pos + 1] << 8 + | buf[pos + 2] << 16 + | buf[pos + 3] << 24) >>> 0; +} + +function readUintBE(buf, pos) { + return (buf[pos ] << 24 + | buf[pos + 1] << 16 + | buf[pos + 2] << 8 + | buf[pos + 3]) >>> 0; +} + +},{}],5:[function(require,module,exports){ +"use strict"; +module.exports = inquire; + +/** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ +function inquire(moduleName) { + try { + var mod = eval("quire".replace(/^/,"re"))(moduleName); // eslint-disable-line no-eval + if (mod && (mod.length || Object.keys(mod).length)) + return mod; + } catch (e) {} // eslint-disable-line no-empty + return null; +} + +},{}],6:[function(require,module,exports){ +"use strict"; +module.exports = pool; + +/** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + +/** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ + +/** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ +function pool(alloc, slice, size) { + var SIZE = size || 8192; + var MAX = SIZE >>> 1; + var slab = null; + var offset = SIZE; + return function pool_alloc(size) { + if (size < 1 || size > MAX) + return alloc(size); + if (offset + size > SIZE) { + slab = alloc(SIZE); + offset = 0; + } + var buf = slice.call(slab, offset, offset += size); + if (offset & 7) // align to 32 bit + offset = (offset | 7) + 1; + return buf; + }; +} + +},{}],7:[function(require,module,exports){ +"use strict"; + +/** + * A minimal UTF8 implementation for number arrays. + * @memberof util + * @namespace + */ +var utf8 = exports; + +/** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ +utf8.length = function utf8_length(string) { + var len = 0, + c = 0; + for (var i = 0; i < string.length; ++i) { + c = string.charCodeAt(i); + if (c < 128) + len += 1; + else if (c < 2048) + len += 2; + else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) { + ++i; + len += 4; + } else + len += 3; + } + return len; +}; + +/** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ +utf8.read = function utf8_read(buffer, start, end) { + var len = end - start; + if (len < 1) + return ""; + var parts = null, + chunk = [], + i = 0, // char offset + t; // temporary + while (start < end) { + t = buffer[start++]; + if (t < 128) + chunk[i++] = t; + else if (t > 191 && t < 224) + chunk[i++] = (t & 31) << 6 | buffer[start++] & 63; + else if (t > 239 && t < 365) { + t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000; + chunk[i++] = 0xD800 + (t >> 10); + chunk[i++] = 0xDC00 + (t & 1023); + } else + chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63; + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +/** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ +utf8.write = function utf8_write(string, buffer, offset) { + var start = offset, + c1, // character 1 + c2; // character 2 + for (var i = 0; i < string.length; ++i) { + c1 = string.charCodeAt(i); + if (c1 < 128) { + buffer[offset++] = c1; + } else if (c1 < 2048) { + buffer[offset++] = c1 >> 6 | 192; + buffer[offset++] = c1 & 63 | 128; + } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) { + c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF); + ++i; + buffer[offset++] = c1 >> 18 | 240; + buffer[offset++] = c1 >> 12 & 63 | 128; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } else { + buffer[offset++] = c1 >> 12 | 224; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } + } + return offset - start; +}; + +},{}],8:[function(require,module,exports){ +"use strict"; +var protobuf = exports; + +/** + * Build type, one of `"full"`, `"light"` or `"minimal"`. + * @name build + * @type {string} + * @const + */ +protobuf.build = "minimal"; + +// Serialization +protobuf.Writer = require(16); +protobuf.BufferWriter = require(17); +protobuf.Reader = require(9); +protobuf.BufferReader = require(10); + +// Utility +protobuf.util = require(15); +protobuf.rpc = require(12); +protobuf.roots = require(11); +protobuf.configure = configure; + +/* istanbul ignore next */ +/** + * Reconfigures the library according to the environment. + * @returns {undefined} + */ +function configure() { + protobuf.Reader._configure(protobuf.BufferReader); + protobuf.util._configure(); +} + +// Set up buffer utility according to the environment +protobuf.Writer._configure(protobuf.BufferWriter); +configure(); + +},{"10":10,"11":11,"12":12,"15":15,"16":16,"17":17,"9":9}],9:[function(require,module,exports){ +"use strict"; +module.exports = Reader; + +var util = require(15); + +var BufferReader; // cyclic + +var LongBits = util.LongBits, + utf8 = util.utf8; + +/* istanbul ignore next */ +function indexOutOfRange(reader, writeLength) { + return RangeError("index out of range: " + reader.pos + " + " + (writeLength || 1) + " > " + reader.len); +} + +/** + * Constructs a new reader instance using the specified buffer. + * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`. + * @constructor + * @param {Uint8Array} buffer Buffer to read from + */ +function Reader(buffer) { + + /** + * Read buffer. + * @type {Uint8Array} + */ + this.buf = buffer; + + /** + * Read buffer position. + * @type {number} + */ + this.pos = 0; + + /** + * Read buffer length. + * @type {number} + */ + this.len = buffer.length; +} + +var create_array = typeof Uint8Array !== "undefined" + ? function create_typed_array(buffer) { + if (buffer instanceof Uint8Array || Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + } + /* istanbul ignore next */ + : function create_array(buffer) { + if (Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + }; + +/** + * Creates a new reader using the specified buffer. + * @function + * @param {Uint8Array|Buffer} buffer Buffer to read from + * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ +Reader.create = util.Buffer + ? function create_buffer_setup(buffer) { + return (Reader.create = function create_buffer(buffer) { + return util.Buffer.isBuffer(buffer) + ? new BufferReader(buffer) + /* istanbul ignore next */ + : create_array(buffer); + })(buffer); + } + /* istanbul ignore next */ + : create_array; + +Reader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice; + +/** + * Reads a varint as an unsigned 32 bit value. + * @function + * @returns {number} Value read + */ +Reader.prototype.uint32 = (function read_uint32_setup() { + var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!) + return function read_uint32() { + value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value; + + /* istanbul ignore if */ + if ((this.pos += 5) > this.len) { + this.pos = this.len; + throw indexOutOfRange(this, 10); + } + return value; + }; +})(); + +/** + * Reads a varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.int32 = function read_int32() { + return this.uint32() | 0; +}; + +/** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.sint32 = function read_sint32() { + var value = this.uint32(); + return value >>> 1 ^ -(value & 1) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readLongVarint() { + // tends to deopt with local vars for octet etc. + var bits = new LongBits(0, 0); + var i = 0; + if (this.len - this.pos > 4) { // fast route (lo) + for (; i < 4; ++i) { + // 1st..4th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 5th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0; + bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + i = 0; + } else { + for (; i < 3; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 1st..3th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 4th + bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0; + return bits; + } + if (this.len - this.pos > 4) { // fast route (hi) + for (; i < 5; ++i) { + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } else { + for (; i < 5; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } + /* istanbul ignore next */ + throw Error("invalid varint encoding"); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads a varint as a signed 64 bit value. + * @name Reader#int64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as an unsigned 64 bit value. + * @name Reader#uint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @name Reader#sint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as a boolean. + * @returns {boolean} Value read + */ +Reader.prototype.bool = function read_bool() { + return this.uint32() !== 0; +}; + +function readFixed32_end(buf, end) { // note that this uses `end`, not `pos` + return (buf[end - 4] + | buf[end - 3] << 8 + | buf[end - 2] << 16 + | buf[end - 1] << 24) >>> 0; +} + +/** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.fixed32 = function read_fixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4); +}; + +/** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.sfixed32 = function read_sfixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readFixed64(/* this: Reader */) { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 8); + + return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads fixed 64 bits. + * @name Reader#fixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads zig-zag encoded fixed 64 bits. + * @name Reader#sfixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a float (32 bit) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.float = function read_float() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readFloatLE(this.buf, this.pos); + this.pos += 4; + return value; +}; + +/** + * Reads a double (64 bit float) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.double = function read_double() { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readDoubleLE(this.buf, this.pos); + this.pos += 8; + return value; +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns {Uint8Array} Value read + */ +Reader.prototype.bytes = function read_bytes() { + var length = this.uint32(), + start = this.pos, + end = this.pos + length; + + /* istanbul ignore if */ + if (end > this.len) + throw indexOutOfRange(this, length); + + this.pos += length; + if (Array.isArray(this.buf)) // plain array + return this.buf.slice(start, end); + return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1 + ? new this.buf.constructor(0) + : this._slice.call(this.buf, start, end); +}; + +/** + * Reads a string preceeded by its byte length as a varint. + * @returns {string} Value read + */ +Reader.prototype.string = function read_string() { + var bytes = this.bytes(); + return utf8.read(bytes, 0, bytes.length); +}; + +/** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param {number} [length] Length if known, otherwise a varint is assumed + * @returns {Reader} `this` + */ +Reader.prototype.skip = function skip(length) { + if (typeof length === "number") { + /* istanbul ignore if */ + if (this.pos + length > this.len) + throw indexOutOfRange(this, length); + this.pos += length; + } else { + do { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + } while (this.buf[this.pos++] & 128); + } + return this; +}; + +/** + * Skips the next element of the specified wire type. + * @param {number} wireType Wire type received + * @returns {Reader} `this` + */ +Reader.prototype.skipType = function(wireType) { + switch (wireType) { + case 0: + this.skip(); + break; + case 1: + this.skip(8); + break; + case 2: + this.skip(this.uint32()); + break; + case 3: + while ((wireType = this.uint32() & 7) !== 4) { + this.skipType(wireType); + } + break; + case 5: + this.skip(4); + break; + + /* istanbul ignore next */ + default: + throw Error("invalid wire type " + wireType + " at offset " + this.pos); + } + return this; +}; + +Reader._configure = function(BufferReader_) { + BufferReader = BufferReader_; + + var fn = util.Long ? "toLong" : /* istanbul ignore next */ "toNumber"; + util.merge(Reader.prototype, { + + int64: function read_int64() { + return readLongVarint.call(this)[fn](false); + }, + + uint64: function read_uint64() { + return readLongVarint.call(this)[fn](true); + }, + + sint64: function read_sint64() { + return readLongVarint.call(this).zzDecode()[fn](false); + }, + + fixed64: function read_fixed64() { + return readFixed64.call(this)[fn](true); + }, + + sfixed64: function read_sfixed64() { + return readFixed64.call(this)[fn](false); + } + + }); +}; + +},{"15":15}],10:[function(require,module,exports){ +"use strict"; +module.exports = BufferReader; + +// extends Reader +var Reader = require(9); +(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader; + +var util = require(15); + +/** + * Constructs a new buffer reader instance. + * @classdesc Wire format reader using node buffers. + * @extends Reader + * @constructor + * @param {Buffer} buffer Buffer to read from + */ +function BufferReader(buffer) { + Reader.call(this, buffer); + + /** + * Read buffer. + * @name BufferReader#buf + * @type {Buffer} + */ +} + +/* istanbul ignore else */ +if (util.Buffer) + BufferReader.prototype._slice = util.Buffer.prototype.slice; + +/** + * @override + */ +BufferReader.prototype.string = function read_string_buffer() { + var len = this.uint32(); // modifies pos + return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len)); +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @name BufferReader#bytes + * @function + * @returns {Buffer} Value read + */ + +},{"15":15,"9":9}],11:[function(require,module,exports){ +"use strict"; +module.exports = {}; + +/** + * Named roots. + * This is where pbjs stores generated structures (the option `-r, --root` specifies a name). + * Can also be used manually to make roots available accross modules. + * @name roots + * @type {Object.} + * @example + * // pbjs -r myroot -o compiled.js ... + * + * // in another module: + * require("./compiled.js"); + * + * // in any subsequent module: + * var root = protobuf.roots["myroot"]; + */ + +},{}],12:[function(require,module,exports){ +"use strict"; + +/** + * Streaming RPC helpers. + * @namespace + */ +var rpc = exports; + +/** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @typedef RPCImpl + * @type {function} + * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called + * @param {Uint8Array} requestData Request data + * @param {RPCImplCallback} callback Callback function + * @returns {undefined} + * @example + * function rpcImpl(method, requestData, callback) { + * if (protobuf.util.lcFirst(method.name) !== "myMethod") // compatible with static code + * throw Error("no such method"); + * asynchronouslyObtainAResponse(requestData, function(err, responseData) { + * callback(err, responseData); + * }); + * } + */ + +/** + * Node-style callback as used by {@link RPCImpl}. + * @typedef RPCImplCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error + * @returns {undefined} + */ + +rpc.Service = require(13); + +},{"13":13}],13:[function(require,module,exports){ +"use strict"; +module.exports = Service; + +var util = require(15); + +// Extends EventEmitter +(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service; + +/** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @typedef rpc.ServiceMethodCallback + * @template TRes extends Message + * @type {function} + * @param {Error|null} error Error, if any + * @param {TRes} [response] Response message + * @returns {undefined} + */ + +/** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @typedef rpc.ServiceMethod + * @template TReq extends Message + * @template TRes extends Message + * @type {function} + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message + * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined` + */ + +/** + * Constructs a new RPC service instance. + * @classdesc An RPC service as returned by {@link Service#create}. + * @exports rpc.Service + * @extends util.EventEmitter + * @constructor + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ +function Service(rpcImpl, requestDelimited, responseDelimited) { + + if (typeof rpcImpl !== "function") + throw TypeError("rpcImpl must be a function"); + + util.EventEmitter.call(this); + + /** + * RPC implementation. Becomes `null` once the service is ended. + * @type {RPCImpl|null} + */ + this.rpcImpl = rpcImpl; + + /** + * Whether requests are length-delimited. + * @type {boolean} + */ + this.requestDelimited = Boolean(requestDelimited); + + /** + * Whether responses are length-delimited. + * @type {boolean} + */ + this.responseDelimited = Boolean(responseDelimited); +} + +/** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param {Method|rpc.ServiceMethod} method Reflected or static method + * @param {Constructor} requestCtor Request constructor + * @param {Constructor} responseCtor Response constructor + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} callback Service callback + * @returns {undefined} + * @template TReq extends Message + * @template TRes extends Message + */ +Service.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) { + + if (!request) + throw TypeError("request must be specified"); + + var self = this; + if (!callback) + return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request); + + if (!self.rpcImpl) { + setTimeout(function() { callback(Error("already ended")); }, 0); + return undefined; + } + + try { + return self.rpcImpl( + method, + requestCtor[self.requestDelimited ? "encodeDelimited" : "encode"](request).finish(), + function rpcCallback(err, response) { + + if (err) { + self.emit("error", err, method); + return callback(err); + } + + if (response === null) { + self.end(/* endedByRPC */ true); + return undefined; + } + + if (!(response instanceof responseCtor)) { + try { + response = responseCtor[self.responseDelimited ? "decodeDelimited" : "decode"](response); + } catch (err) { + self.emit("error", err, method); + return callback(err); + } + } + + self.emit("data", response, method); + return callback(null, response); + } + ); + } catch (err) { + self.emit("error", err, method); + setTimeout(function() { callback(err); }, 0); + return undefined; + } +}; + +/** + * Ends this service and emits the `end` event. + * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns {rpc.Service} `this` + */ +Service.prototype.end = function end(endedByRPC) { + if (this.rpcImpl) { + if (!endedByRPC) // signal end to rpcImpl + this.rpcImpl(null, null, null); + this.rpcImpl = null; + this.emit("end").off(); + } + return this; +}; + +},{"15":15}],14:[function(require,module,exports){ +"use strict"; +module.exports = LongBits; + +var util = require(15); + +/** + * Constructs new long bits. + * @classdesc Helper class for working with the low and high bits of a 64 bit value. + * @memberof util + * @constructor + * @param {number} lo Low 32 bits, unsigned + * @param {number} hi High 32 bits, unsigned + */ +function LongBits(lo, hi) { + + // note that the casts below are theoretically unnecessary as of today, but older statically + // generated converter code might still call the ctor with signed 32bits. kept for compat. + + /** + * Low bits. + * @type {number} + */ + this.lo = lo >>> 0; + + /** + * High bits. + * @type {number} + */ + this.hi = hi >>> 0; +} + +/** + * Zero bits. + * @memberof util.LongBits + * @type {util.LongBits} + */ +var zero = LongBits.zero = new LongBits(0, 0); + +zero.toNumber = function() { return 0; }; +zero.zzEncode = zero.zzDecode = function() { return this; }; +zero.length = function() { return 1; }; + +/** + * Zero hash. + * @memberof util.LongBits + * @type {string} + */ +var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0"; + +/** + * Constructs new long bits from the specified number. + * @param {number} value Value + * @returns {util.LongBits} Instance + */ +LongBits.fromNumber = function fromNumber(value) { + if (value === 0) + return zero; + var sign = value < 0; + if (sign) + value = -value; + var lo = value >>> 0, + hi = (value - lo) / 4294967296 >>> 0; + if (sign) { + hi = ~hi >>> 0; + lo = ~lo >>> 0; + if (++lo > 4294967295) { + lo = 0; + if (++hi > 4294967295) + hi = 0; + } + } + return new LongBits(lo, hi); +}; + +/** + * Constructs new long bits from a number, long or string. + * @param {Long|number|string} value Value + * @returns {util.LongBits} Instance + */ +LongBits.from = function from(value) { + if (typeof value === "number") + return LongBits.fromNumber(value); + if (util.isString(value)) { + /* istanbul ignore else */ + if (util.Long) + value = util.Long.fromString(value); + else + return LongBits.fromNumber(parseInt(value, 10)); + } + return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero; +}; + +/** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {number} Possibly unsafe number + */ +LongBits.prototype.toNumber = function toNumber(unsigned) { + if (!unsigned && this.hi >>> 31) { + var lo = ~this.lo + 1 >>> 0, + hi = ~this.hi >>> 0; + if (!lo) + hi = hi + 1 >>> 0; + return -(lo + hi * 4294967296); + } + return this.lo + this.hi * 4294967296; +}; + +/** + * Converts this long bits to a long. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long} Long + */ +LongBits.prototype.toLong = function toLong(unsigned) { + return util.Long + ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned)) + /* istanbul ignore next */ + : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) }; +}; + +var charCodeAt = String.prototype.charCodeAt; + +/** + * Constructs new long bits from the specified 8 characters long hash. + * @param {string} hash Hash + * @returns {util.LongBits} Bits + */ +LongBits.fromHash = function fromHash(hash) { + if (hash === zeroHash) + return zero; + return new LongBits( + ( charCodeAt.call(hash, 0) + | charCodeAt.call(hash, 1) << 8 + | charCodeAt.call(hash, 2) << 16 + | charCodeAt.call(hash, 3) << 24) >>> 0 + , + ( charCodeAt.call(hash, 4) + | charCodeAt.call(hash, 5) << 8 + | charCodeAt.call(hash, 6) << 16 + | charCodeAt.call(hash, 7) << 24) >>> 0 + ); +}; + +/** + * Converts this long bits to a 8 characters long hash. + * @returns {string} Hash + */ +LongBits.prototype.toHash = function toHash() { + return String.fromCharCode( + this.lo & 255, + this.lo >>> 8 & 255, + this.lo >>> 16 & 255, + this.lo >>> 24 , + this.hi & 255, + this.hi >>> 8 & 255, + this.hi >>> 16 & 255, + this.hi >>> 24 + ); +}; + +/** + * Zig-zag encodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzEncode = function zzEncode() { + var mask = this.hi >> 31; + this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0; + this.lo = ( this.lo << 1 ^ mask) >>> 0; + return this; +}; + +/** + * Zig-zag decodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzDecode = function zzDecode() { + var mask = -(this.lo & 1); + this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0; + this.hi = ( this.hi >>> 1 ^ mask) >>> 0; + return this; +}; + +/** + * Calculates the length of this longbits when encoded as a varint. + * @returns {number} Length + */ +LongBits.prototype.length = function length() { + var part0 = this.lo, + part1 = (this.lo >>> 28 | this.hi << 4) >>> 0, + part2 = this.hi >>> 24; + return part2 === 0 + ? part1 === 0 + ? part0 < 16384 + ? part0 < 128 ? 1 : 2 + : part0 < 2097152 ? 3 : 4 + : part1 < 16384 + ? part1 < 128 ? 5 : 6 + : part1 < 2097152 ? 7 : 8 + : part2 < 128 ? 9 : 10; +}; + +},{"15":15}],15:[function(require,module,exports){ +"use strict"; +var util = exports; + +// used to return a Promise where callback is omitted +util.asPromise = require(1); + +// converts to / from base64 encoded strings +util.base64 = require(2); + +// base class of rpc.Service +util.EventEmitter = require(3); + +// float handling accross browsers +util.float = require(4); + +// requires modules optionally and hides the call from bundlers +util.inquire = require(5); + +// converts to / from utf8 encoded strings +util.utf8 = require(7); + +// provides a node-like buffer pool in the browser +util.pool = require(6); + +// utility to work with the low and high bits of a 64 bit value +util.LongBits = require(14); + +// global object reference +util.global = typeof window !== "undefined" && window + || typeof global !== "undefined" && global + || typeof self !== "undefined" && self + || this; // eslint-disable-line no-invalid-this + +/** + * An immuable empty array. + * @memberof util + * @type {Array.<*>} + * @const + */ +util.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes + +/** + * An immutable empty object. + * @type {Object} + * @const + */ +util.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes + +/** + * Whether running within node or not. + * @memberof util + * @type {boolean} + * @const + */ +util.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node); + +/** + * Tests if the specified value is an integer. + * @function + * @param {*} value Value to test + * @returns {boolean} `true` if the value is an integer + */ +util.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) { + return typeof value === "number" && isFinite(value) && Math.floor(value) === value; +}; + +/** + * Tests if the specified value is a string. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a string + */ +util.isString = function isString(value) { + return typeof value === "string" || value instanceof String; +}; + +/** + * Tests if the specified value is a non-null object. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a non-null object + */ +util.isObject = function isObject(value) { + return value && typeof value === "object"; +}; + +/** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @function + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isset = + +/** + * Checks if a property on a message is considered to be present. + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isSet = function isSet(obj, prop) { + var value = obj[prop]; + if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins + return typeof value !== "object" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0; + return false; +}; + +/** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + * @interface Buffer + * @extends Uint8Array + */ + +/** + * Node's Buffer class if available. + * @type {Constructor} + */ +util.Buffer = (function() { + try { + var Buffer = util.inquire("buffer").Buffer; + // refuse to use non-node buffers if not explicitly assigned (perf reasons): + return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null; + } catch (e) { + /* istanbul ignore next */ + return null; + } +})(); + +// Internal alias of or polyfull for Buffer.from. +util._Buffer_from = null; + +// Internal alias of or polyfill for Buffer.allocUnsafe. +util._Buffer_allocUnsafe = null; + +/** + * Creates a new buffer of whatever type supported by the environment. + * @param {number|number[]} [sizeOrArray=0] Buffer size or number array + * @returns {Uint8Array|Buffer} Buffer + */ +util.newBuffer = function newBuffer(sizeOrArray) { + /* istanbul ignore next */ + return typeof sizeOrArray === "number" + ? util.Buffer + ? util._Buffer_allocUnsafe(sizeOrArray) + : new util.Array(sizeOrArray) + : util.Buffer + ? util._Buffer_from(sizeOrArray) + : typeof Uint8Array === "undefined" + ? sizeOrArray + : new Uint8Array(sizeOrArray); +}; + +/** + * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. + * @type {Constructor} + */ +util.Array = typeof Uint8Array !== "undefined" ? Uint8Array /* istanbul ignore next */ : Array; + +/** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + * @interface Long + * @property {number} low Low bits + * @property {number} high High bits + * @property {boolean} unsigned Whether unsigned or not + */ + +/** + * Long.js's Long class if available. + * @type {Constructor} + */ +util.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long + || /* istanbul ignore next */ util.global.Long + || util.inquire("long"); + +/** + * Regular expression used to verify 2 bit (`bool`) map keys. + * @type {RegExp} + * @const + */ +util.key2Re = /^true|false|0|1$/; + +/** + * Regular expression used to verify 32 bit (`int32` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key32Re = /^-?(?:0|[1-9][0-9]*)$/; + +/** + * Regular expression used to verify 64 bit (`int64` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/; + +/** + * Converts a number or long to an 8 characters long hash string. + * @param {Long|number} value Value to convert + * @returns {string} Hash + */ +util.longToHash = function longToHash(value) { + return value + ? util.LongBits.from(value).toHash() + : util.LongBits.zeroHash; +}; + +/** + * Converts an 8 characters long hash string to a long or number. + * @param {string} hash Hash + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long|number} Original value + */ +util.longFromHash = function longFromHash(hash, unsigned) { + var bits = util.LongBits.fromHash(hash); + if (util.Long) + return util.Long.fromBits(bits.lo, bits.hi, unsigned); + return bits.toNumber(Boolean(unsigned)); +}; + +/** + * Merges the properties of the source object into the destination object. + * @memberof util + * @param {Object.} dst Destination object + * @param {Object.} src Source object + * @param {boolean} [ifNotSet=false] Merges only if the key is not already set + * @returns {Object.} Destination object + */ +function merge(dst, src, ifNotSet) { // used by converters + for (var keys = Object.keys(src), i = 0; i < keys.length; ++i) + if (dst[keys[i]] === undefined || !ifNotSet) + dst[keys[i]] = src[keys[i]]; + return dst; +} + +util.merge = merge; + +/** + * Converts the first character of a string to lower case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.lcFirst = function lcFirst(str) { + return str.charAt(0).toLowerCase() + str.substring(1); +}; + +/** + * Creates a custom error constructor. + * @memberof util + * @param {string} name Error name + * @returns {Constructor} Custom error constructor + */ +function newError(name) { + + function CustomError(message, properties) { + + if (!(this instanceof CustomError)) + return new CustomError(message, properties); + + // Error.call(this, message); + // ^ just returns a new error instance because the ctor can be called as a function + + Object.defineProperty(this, "message", { get: function() { return message; } }); + + /* istanbul ignore next */ + if (Error.captureStackTrace) // node + Error.captureStackTrace(this, CustomError); + else + Object.defineProperty(this, "stack", { value: (new Error()).stack || "" }); + + if (properties) + merge(this, properties); + } + + (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError; + + Object.defineProperty(CustomError.prototype, "name", { get: function() { return name; } }); + + CustomError.prototype.toString = function toString() { + return this.name + ": " + this.message; + }; + + return CustomError; +} + +util.newError = newError; + +/** + * Constructs a new protocol error. + * @classdesc Error subclass indicating a protocol specifc error. + * @memberof util + * @extends Error + * @template T extends Message + * @constructor + * @param {string} message Error message + * @param {Object.} [properties] Additional properties + * @example + * try { + * MyMessage.decode(someBuffer); // throws if required fields are missing + * } catch (e) { + * if (e instanceof ProtocolError && e.instance) + * console.log("decoded so far: " + JSON.stringify(e.instance)); + * } + */ +util.ProtocolError = newError("ProtocolError"); + +/** + * So far decoded message instance. + * @name util.ProtocolError#instance + * @type {Message} + */ + +/** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @typedef OneOfGetter + * @type {function} + * @returns {string|undefined} Set field name, if any + */ + +/** + * Builds a getter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfGetter} Unbound getter + */ +util.oneOfGetter = function getOneOf(fieldNames) { + var fieldMap = {}; + for (var i = 0; i < fieldNames.length; ++i) + fieldMap[fieldNames[i]] = 1; + + /** + * @returns {string|undefined} Set field name, if any + * @this Object + * @ignore + */ + return function() { // eslint-disable-line consistent-return + for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i) + if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null) + return keys[i]; + }; +}; + +/** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @typedef OneOfSetter + * @type {function} + * @param {string|undefined} value Field name + * @returns {undefined} + */ + +/** + * Builds a setter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfSetter} Unbound setter + */ +util.oneOfSetter = function setOneOf(fieldNames) { + + /** + * @param {string} name Field name + * @returns {undefined} + * @this Object + * @ignore + */ + return function(name) { + for (var i = 0; i < fieldNames.length; ++i) + if (fieldNames[i] !== name) + delete this[fieldNames[i]]; + }; +}; + +/** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @type {IConversionOptions} + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ +util.toJSONOptions = { + longs: String, + enums: String, + bytes: String, + json: true +}; + +// Sets up buffer utility according to the environment (called in index-minimal) +util._configure = function() { + var Buffer = util.Buffer; + /* istanbul ignore if */ + if (!Buffer) { + util._Buffer_from = util._Buffer_allocUnsafe = null; + return; + } + // because node 4.x buffers are incompatible & immutable + // see: https://github.com/dcodeIO/protobuf.js/pull/665 + util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from || + /* istanbul ignore next */ + function Buffer_from(value, encoding) { + return new Buffer(value, encoding); + }; + util._Buffer_allocUnsafe = Buffer.allocUnsafe || + /* istanbul ignore next */ + function Buffer_allocUnsafe(size) { + return new Buffer(size); + }; +}; + +},{"1":1,"14":14,"2":2,"3":3,"4":4,"5":5,"6":6,"7":7}],16:[function(require,module,exports){ +"use strict"; +module.exports = Writer; + +var util = require(15); + +var BufferWriter; // cyclic + +var LongBits = util.LongBits, + base64 = util.base64, + utf8 = util.utf8; + +/** + * Constructs a new writer operation instance. + * @classdesc Scheduled writer operation. + * @constructor + * @param {function(*, Uint8Array, number)} fn Function to call + * @param {number} len Value byte length + * @param {*} val Value to write + * @ignore + */ +function Op(fn, len, val) { + + /** + * Function to call. + * @type {function(Uint8Array, number, *)} + */ + this.fn = fn; + + /** + * Value byte length. + * @type {number} + */ + this.len = len; + + /** + * Next operation. + * @type {Writer.Op|undefined} + */ + this.next = undefined; + + /** + * Value to write. + * @type {*} + */ + this.val = val; // type varies +} + +/* istanbul ignore next */ +function noop() {} // eslint-disable-line no-empty-function + +/** + * Constructs a new writer state instance. + * @classdesc Copied writer state. + * @memberof Writer + * @constructor + * @param {Writer} writer Writer to copy state from + * @ignore + */ +function State(writer) { + + /** + * Current head. + * @type {Writer.Op} + */ + this.head = writer.head; + + /** + * Current tail. + * @type {Writer.Op} + */ + this.tail = writer.tail; + + /** + * Current buffer length. + * @type {number} + */ + this.len = writer.len; + + /** + * Next state. + * @type {State|null} + */ + this.next = writer.states; +} + +/** + * Constructs a new writer instance. + * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`. + * @constructor + */ +function Writer() { + + /** + * Current length. + * @type {number} + */ + this.len = 0; + + /** + * Operations head. + * @type {Object} + */ + this.head = new Op(noop, 0, 0); + + /** + * Operations tail + * @type {Object} + */ + this.tail = this.head; + + /** + * Linked forked states. + * @type {Object|null} + */ + this.states = null; + + // When a value is written, the writer calculates its byte length and puts it into a linked + // list of operations to perform when finish() is called. This both allows us to allocate + // buffers of the exact required size and reduces the amount of work we have to do compared + // to first calculating over objects and then encoding over objects. In our case, the encoding + // part is just a linked list walk calling operations with already prepared values. +} + +/** + * Creates a new writer. + * @function + * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ +Writer.create = util.Buffer + ? function create_buffer_setup() { + return (Writer.create = function create_buffer() { + return new BufferWriter(); + })(); + } + /* istanbul ignore next */ + : function create_array() { + return new Writer(); + }; + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ +Writer.alloc = function alloc(size) { + return new util.Array(size); +}; + +// Use Uint8Array buffer pool in the browser, just like node does with buffers +/* istanbul ignore else */ +if (util.Array !== Array) + Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray); + +/** + * Pushes a new operation to the queue. + * @param {function(Uint8Array, number, *)} fn Function to call + * @param {number} len Value byte length + * @param {number} val Value to write + * @returns {Writer} `this` + * @private + */ +Writer.prototype._push = function push(fn, len, val) { + this.tail = this.tail.next = new Op(fn, len, val); + this.len += len; + return this; +}; + +function writeByte(val, buf, pos) { + buf[pos] = val & 255; +} + +function writeVarint32(val, buf, pos) { + while (val > 127) { + buf[pos++] = val & 127 | 128; + val >>>= 7; + } + buf[pos] = val; +} + +/** + * Constructs a new varint writer operation instance. + * @classdesc Scheduled varint writer operation. + * @extends Op + * @constructor + * @param {number} len Value byte length + * @param {number} val Value to write + * @ignore + */ +function VarintOp(len, val) { + this.len = len; + this.next = undefined; + this.val = val; +} + +VarintOp.prototype = Object.create(Op.prototype); +VarintOp.prototype.fn = writeVarint32; + +/** + * Writes an unsigned 32 bit value as a varint. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.uint32 = function write_uint32(value) { + // here, the call to this.push has been inlined and a varint specific Op subclass is used. + // uint32 is by far the most frequently used operation and benefits significantly from this. + this.len += (this.tail = this.tail.next = new VarintOp( + (value = value >>> 0) + < 128 ? 1 + : value < 16384 ? 2 + : value < 2097152 ? 3 + : value < 268435456 ? 4 + : 5, + value)).len; + return this; +}; + +/** + * Writes a signed 32 bit value as a varint. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.int32 = function write_int32(value) { + return value < 0 + ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec + : this.uint32(value); +}; + +/** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sint32 = function write_sint32(value) { + return this.uint32((value << 1 ^ value >> 31) >>> 0); +}; + +function writeVarint64(val, buf, pos) { + while (val.hi) { + buf[pos++] = val.lo & 127 | 128; + val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0; + val.hi >>>= 7; + } + while (val.lo > 127) { + buf[pos++] = val.lo & 127 | 128; + val.lo = val.lo >>> 7; + } + buf[pos++] = val.lo; +} + +/** + * Writes an unsigned 64 bit value as a varint. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.uint64 = function write_uint64(value) { + var bits = LongBits.from(value); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a signed 64 bit value as a varint. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.int64 = Writer.prototype.uint64; + +/** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sint64 = function write_sint64(value) { + var bits = LongBits.from(value).zzEncode(); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a boolish value as a varint. + * @param {boolean} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.bool = function write_bool(value) { + return this._push(writeByte, 1, value ? 1 : 0); +}; + +function writeFixed32(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +/** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.fixed32 = function write_fixed32(value) { + return this._push(writeFixed32, 4, value >>> 0); +}; + +/** + * Writes a signed 32 bit value as fixed 32 bits. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sfixed32 = Writer.prototype.fixed32; + +/** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.fixed64 = function write_fixed64(value) { + var bits = LongBits.from(value); + return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi); +}; + +/** + * Writes a signed 64 bit value as fixed 64 bits. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sfixed64 = Writer.prototype.fixed64; + +/** + * Writes a float (32 bit). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.float = function write_float(value) { + return this._push(util.float.writeFloatLE, 4, value); +}; + +/** + * Writes a double (64 bit float). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.double = function write_double(value) { + return this._push(util.float.writeDoubleLE, 8, value); +}; + +var writeBytes = util.Array.prototype.set + ? function writeBytes_set(val, buf, pos) { + buf.set(val, pos); // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytes_for(val, buf, pos) { + for (var i = 0; i < val.length; ++i) + buf[pos + i] = val[i]; + }; + +/** + * Writes a sequence of bytes. + * @param {Uint8Array|string} value Buffer or base64 encoded string to write + * @returns {Writer} `this` + */ +Writer.prototype.bytes = function write_bytes(value) { + var len = value.length >>> 0; + if (!len) + return this._push(writeByte, 1, 0); + if (util.isString(value)) { + var buf = Writer.alloc(len = base64.length(value)); + base64.decode(value, buf, 0); + value = buf; + } + return this.uint32(len)._push(writeBytes, len, value); +}; + +/** + * Writes a string. + * @param {string} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.string = function write_string(value) { + var len = utf8.length(value); + return len + ? this.uint32(len)._push(utf8.write, len, value) + : this._push(writeByte, 1, 0); +}; + +/** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns {Writer} `this` + */ +Writer.prototype.fork = function fork() { + this.states = new State(this); + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + return this; +}; + +/** + * Resets this instance to the last state. + * @returns {Writer} `this` + */ +Writer.prototype.reset = function reset() { + if (this.states) { + this.head = this.states.head; + this.tail = this.states.tail; + this.len = this.states.len; + this.states = this.states.next; + } else { + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + } + return this; +}; + +/** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns {Writer} `this` + */ +Writer.prototype.ldelim = function ldelim() { + var head = this.head, + tail = this.tail, + len = this.len; + this.reset().uint32(len); + if (len) { + this.tail.next = head.next; // skip noop + this.tail = tail; + this.len += len; + } + return this; +}; + +/** + * Finishes the write operation. + * @returns {Uint8Array} Finished buffer + */ +Writer.prototype.finish = function finish() { + var head = this.head.next, // skip noop + buf = this.constructor.alloc(this.len), + pos = 0; + while (head) { + head.fn(head.val, buf, pos); + pos += head.len; + head = head.next; + } + // this.head = this.tail = null; + return buf; +}; + +Writer._configure = function(BufferWriter_) { + BufferWriter = BufferWriter_; +}; + +},{"15":15}],17:[function(require,module,exports){ +"use strict"; +module.exports = BufferWriter; + +// extends Writer +var Writer = require(16); +(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter; + +var util = require(15); + +var Buffer = util.Buffer; + +/** + * Constructs a new buffer writer instance. + * @classdesc Wire format writer using node buffers. + * @extends Writer + * @constructor + */ +function BufferWriter() { + Writer.call(this); +} + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Buffer} Buffer + */ +BufferWriter.alloc = function alloc_buffer(size) { + return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size); +}; + +var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set" + ? function writeBytesBuffer_set(val, buf, pos) { + buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited) + // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytesBuffer_copy(val, buf, pos) { + if (val.copy) // Buffer values + val.copy(buf, pos, 0, val.length); + else for (var i = 0; i < val.length;) // plain array values + buf[pos++] = val[i++]; + }; + +/** + * @override + */ +BufferWriter.prototype.bytes = function write_bytes_buffer(value) { + if (util.isString(value)) + value = util._Buffer_from(value, "base64"); + var len = value.length >>> 0; + this.uint32(len); + if (len) + this._push(writeBytesBuffer, len, value); + return this; +}; + +function writeStringBuffer(val, buf, pos) { + if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions) + util.utf8.write(val, buf, pos); + else + buf.utf8Write(val, pos); +} + +/** + * @override + */ +BufferWriter.prototype.string = function write_string_buffer(value) { + var len = Buffer.byteLength(value); + this.uint32(len); + if (len) + this._push(writeStringBuffer, len, value); + return this; +}; + + +/** + * Finishes the write operation. + * @name BufferWriter#finish + * @function + * @returns {Buffer} Finished buffer + */ + +},{"15":15,"16":16}]},{},[8]) + +})(); +//# sourceMappingURL=protobuf.js.map diff --git a/node_modules/protobufjs/dist/minimal/protobuf.js.map b/node_modules/protobufjs/dist/minimal/protobuf.js.map new file mode 100644 index 0000000..c44c45b --- /dev/null +++ b/node_modules/protobufjs/dist/minimal/protobuf.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/index-minimal","../src/reader.js","../src/reader_buffer.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/util/longbits.js","../src/util/minimal.js","../src/writer.js","../src/writer_buffer.js"],"names":[],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3cA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"protobuf.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(16);\r\nprotobuf.BufferWriter = require(17);\r\nprotobuf.Reader = require(9);\r\nprotobuf.BufferReader = require(10);\r\n\r\n// Utility\r\nprotobuf.util = require(15);\r\nprotobuf.rpc = require(12);\r\nprotobuf.roots = require(11);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(15);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(9);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(15);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(13);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(15);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(15);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(3);\r\n\r\n// float handling accross browsers\r\nutil.float = require(4);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(5);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(7);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(6);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(14);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(15);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(16);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(15);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/dist/minimal/protobuf.min.js b/node_modules/protobufjs/dist/minimal/protobuf.min.js new file mode 100644 index 0000000..517e320 --- /dev/null +++ b/node_modules/protobufjs/dist/minimal/protobuf.min.js @@ -0,0 +1,8 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:26 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +!function(b){"use strict";var r,u,t,n;r={1:[function(t,n){n.exports=function(t,n){var i=Array(arguments.length-1),e=0,r=2,s=!0;for(;r>2],r=(3&f)<<4,h=1;break;case 1:e[s++]=o[r|f>>4],r=(15&f)<<2,h=2;break;case 2:e[s++]=o[r|f>>6],e[s++]=o[63&f],h=0}8191>4,r=h,e=2;break;case 2:n[i++]=(15&r)<<4|(60&h)>>2,r=h,e=3;break;case 3:n[i++]=(3&r)<<6|h,e=0}}if(1===e)throw Error(c);return i-u},r.test=function(t){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(t)}},{}],3:[function(t,n){function i(){this.t={}}(n.exports=i).prototype.on=function(t,n,i){return(this.t[t]||(this.t[t]=[])).push({fn:n,ctx:i||this}),this},i.prototype.off=function(t,n){if(t===b)this.t={};else if(n===b)this.t[t]=[];else for(var i=this.t[t],r=0;r>>0,i,r);else if(n<11754943508222875e-54)t((u<<31|Math.round(n/1401298464324817e-60))>>>0,i,r);else{var e=Math.floor(Math.log(n)/Math.LN2);t((u<<31|e+127<<23|8388607&Math.round(n*Math.pow(2,-e)*8388608))>>>0,i,r)}}function n(t,n,i){var r=t(n,i),u=2*(r>>31)+1,e=r>>>23&255,s=8388607&r;return 255===e?s?NaN:u*(1/0):0===e?1401298464324817e-60*u*s:u*Math.pow(2,e-150)*(s+8388608)}h.writeFloatLE=t.bind(null,r),h.writeFloatBE=t.bind(null,u),h.readFloatLE=n.bind(null,e),h.readFloatBE=n.bind(null,s)}(),"undefined"!=typeof Float64Array?function(){var r=new Float64Array([-0]),u=new Uint8Array(r.buffer),t=128===u[7];function n(t,n,i){r[0]=t,n[i]=u[0],n[i+1]=u[1],n[i+2]=u[2],n[i+3]=u[3],n[i+4]=u[4],n[i+5]=u[5],n[i+6]=u[6],n[i+7]=u[7]}function i(t,n,i){r[0]=t,n[i]=u[7],n[i+1]=u[6],n[i+2]=u[5],n[i+3]=u[4],n[i+4]=u[3],n[i+5]=u[2],n[i+6]=u[1],n[i+7]=u[0]}function e(t,n){return u[0]=t[n],u[1]=t[n+1],u[2]=t[n+2],u[3]=t[n+3],u[4]=t[n+4],u[5]=t[n+5],u[6]=t[n+6],u[7]=t[n+7],r[0]}function s(t,n){return u[7]=t[n],u[6]=t[n+1],u[5]=t[n+2],u[4]=t[n+3],u[3]=t[n+4],u[2]=t[n+5],u[1]=t[n+6],u[0]=t[n+7],r[0]}h.writeDoubleLE=t?n:i,h.writeDoubleBE=t?i:n,h.readDoubleLE=t?e:s,h.readDoubleBE=t?s:e}():function(){function t(t,n,i,r,u,e){var s=r<0?1:0;if(s&&(r=-r),0===r)t(0,u,e+n),t(0<1/r?0:2147483648,u,e+i);else if(isNaN(r))t(0,u,e+n),t(2146959360,u,e+i);else if(17976931348623157e292>>0,u,e+i);else{var h;if(r<22250738585072014e-324)t((h=r/5e-324)>>>0,u,e+n),t((s<<31|h/4294967296)>>>0,u,e+i);else{var f=Math.floor(Math.log(r)/Math.LN2);1024===f&&(f=1023),t(4503599627370496*(h=r*Math.pow(2,-f))>>>0,u,e+n),t((s<<31|f+1023<<20|1048576*h&1048575)>>>0,u,e+i)}}}function n(t,n,i,r,u){var e=t(r,u+n),s=t(r,u+i),h=2*(s>>31)+1,f=s>>>20&2047,o=4294967296*(1048575&s)+e;return 2047===f?o?NaN:h*(1/0):0===f?5e-324*h*o:h*Math.pow(2,f-1075)*(o+4503599627370496)}h.writeDoubleLE=t.bind(null,r,0,4),h.writeDoubleBE=t.bind(null,u,4,0),h.readDoubleLE=n.bind(null,e,0,4),h.readDoubleBE=n.bind(null,s,4,0)}(),h}function r(t,n,i){n[i]=255&t,n[i+1]=t>>>8&255,n[i+2]=t>>>16&255,n[i+3]=t>>>24}function u(t,n,i){n[i]=t>>>24,n[i+1]=t>>>16&255,n[i+2]=t>>>8&255,n[i+3]=255&t}function e(t,n){return(t[n]|t[n+1]<<8|t[n+2]<<16|t[n+3]<<24)>>>0}function s(t,n){return(t[n]<<24|t[n+1]<<16|t[n+2]<<8|t[n+3])>>>0}n.exports=i(i)},{}],5:[function(t,n,i){function r(t){try{var n=eval("require")(t);if(n&&(n.length||Object.keys(n).length))return n}catch(t){}return null}n.exports=r},{}],6:[function(t,n){n.exports=function(i,r,t){var u=t||8192,e=u>>>1,s=null,h=u;return function(t){if(t<1||e>10),e[s++]=56320+(1023&r)):e[s++]=(15&r)<<12|(63&t[n++])<<6|63&t[n++],8191>6|192:(55296==(64512&r)&&56320==(64512&(u=t.charCodeAt(s+1)))?(r=65536+((1023&r)<<10)+(1023&u),++s,n[i++]=r>>18|240,n[i++]=r>>12&63|128):n[i++]=r>>12|224,n[i++]=r>>6&63|128),n[i++]=63&r|128);return i-e}},{}],8:[function(t,n,i){var r=i;function u(){r.Reader.n(r.BufferReader),r.util.n()}r.build="minimal",r.Writer=t(16),r.BufferWriter=t(17),r.Reader=t(9),r.BufferReader=t(10),r.util=t(15),r.rpc=t(12),r.roots=t(11),r.configure=u,r.Writer.n(r.BufferWriter),u()},{10:10,11:11,12:12,15:15,16:16,17:17,9:9}],9:[function(t,n){n.exports=h;var i,r=t(15),u=r.LongBits,e=r.utf8;function s(t,n){return RangeError("index out of range: "+t.pos+" + "+(n||1)+" > "+t.len)}function h(t){this.buf=t,this.pos=0,this.len=t.length}var f,o="undefined"!=typeof Uint8Array?function(t){if(t instanceof Uint8Array||Array.isArray(t))return new h(t);throw Error("illegal buffer")}:function(t){if(Array.isArray(t))return new h(t);throw Error("illegal buffer")};function c(){var t=new u(0,0),n=0;if(!(4=this.len)throw s(this);if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*n)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(127&this.buf[this.pos++])<<7*n)>>>0,t}for(;n<4;++n)if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*n)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(127&this.buf[this.pos])<<28)>>>0,t.hi=(t.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return t;if(n=0,4>>0,this.buf[this.pos++]<128)return t}else for(;n<5;++n){if(this.pos>=this.len)throw s(this);if(t.hi=(t.hi|(127&this.buf[this.pos])<<7*n+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}function a(t,n){return(t[n-4]|t[n-3]<<8|t[n-2]<<16|t[n-1]<<24)>>>0}function l(){if(this.pos+8>this.len)throw s(this,8);return new u(a(this.buf,this.pos+=4),a(this.buf,this.pos+=4))}h.create=r.Buffer?function(t){return(h.create=function(t){return r.Buffer.isBuffer(t)?new i(t):o(t)})(t)}:o,h.prototype.i=r.Array.prototype.subarray||r.Array.prototype.slice,h.prototype.uint32=(f=4294967295,function(){if(f=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return f;if((this.pos+=5)>this.len)throw this.pos=this.len,s(this,10);return f}),h.prototype.int32=function(){return 0|this.uint32()},h.prototype.sint32=function(){var t=this.uint32();return t>>>1^-(1&t)|0},h.prototype.bool=function(){return 0!==this.uint32()},h.prototype.fixed32=function(){if(this.pos+4>this.len)throw s(this,4);return a(this.buf,this.pos+=4)},h.prototype.sfixed32=function(){if(this.pos+4>this.len)throw s(this,4);return 0|a(this.buf,this.pos+=4)},h.prototype.float=function(){if(this.pos+4>this.len)throw s(this,4);var t=r.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t},h.prototype.double=function(){if(this.pos+8>this.len)throw s(this,4);var t=r.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t},h.prototype.bytes=function(){var t=this.uint32(),n=this.pos,i=this.pos+t;if(i>this.len)throw s(this,t);return this.pos+=t,Array.isArray(this.buf)?this.buf.slice(n,i):n===i?new this.buf.constructor(0):this.i.call(this.buf,n,i)},h.prototype.string=function(){var t=this.bytes();return e.read(t,0,t.length)},h.prototype.skip=function(t){if("number"==typeof t){if(this.pos+t>this.len)throw s(this,t);this.pos+=t}else do{if(this.pos>=this.len)throw s(this)}while(128&this.buf[this.pos++]);return this},h.prototype.skipType=function(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(t=7&this.uint32());)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+t+" at offset "+this.pos)}return this},h.n=function(t){i=t;var n=r.Long?"toLong":"toNumber";r.merge(h.prototype,{int64:function(){return c.call(this)[n](!1)},uint64:function(){return c.call(this)[n](!0)},sint64:function(){return c.call(this).zzDecode()[n](!1)},fixed64:function(){return l.call(this)[n](!0)},sfixed64:function(){return l.call(this)[n](!1)}})}},{15:15}],10:[function(t,n){n.exports=u;var i=t(9);(u.prototype=Object.create(i.prototype)).constructor=u;var r=t(15);function u(t){i.call(this,t)}r.Buffer&&(u.prototype.i=r.Buffer.prototype.slice),u.prototype.string=function(){var t=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len))}},{15:15,9:9}],11:[function(t,n){n.exports={}},{}],12:[function(t,n,i){i.Service=t(13)},{13:13}],13:[function(t,n){n.exports=i;var h=t(15);function i(t,n,i){if("function"!=typeof t)throw TypeError("rpcImpl must be a function");h.EventEmitter.call(this),this.rpcImpl=t,this.requestDelimited=!!n,this.responseDelimited=!!i}((i.prototype=Object.create(h.EventEmitter.prototype)).constructor=i).prototype.rpcCall=function t(i,n,r,u,e){if(!u)throw TypeError("request must be specified");var s=this;if(!e)return h.asPromise(t,s,i,n,r,u);if(!s.rpcImpl)return setTimeout(function(){e(Error("already ended"))},0),b;try{return s.rpcImpl(i,n[s.requestDelimited?"encodeDelimited":"encode"](u).finish(),function(t,n){if(t)return s.emit("error",t,i),e(t);if(null===n)return s.end(!0),b;if(!(n instanceof r))try{n=r[s.responseDelimited?"decodeDelimited":"decode"](n)}catch(t){return s.emit("error",t,i),e(t)}return s.emit("data",n,i),e(null,n)})}catch(t){return s.emit("error",t,i),setTimeout(function(){e(t)},0),b}},i.prototype.end=function(t){return this.rpcImpl&&(t||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}},{15:15}],14:[function(t,n){n.exports=u;var i=t(15);function u(t,n){this.lo=t>>>0,this.hi=n>>>0}var e=u.zero=new u(0,0);e.toNumber=function(){return 0},e.zzEncode=e.zzDecode=function(){return this},e.length=function(){return 1};var r=u.zeroHash="\0\0\0\0\0\0\0\0";u.fromNumber=function(t){if(0===t)return e;var n=t<0;n&&(t=-t);var i=t>>>0,r=(t-i)/4294967296>>>0;return n&&(r=~r>>>0,i=~i>>>0,4294967295<++i&&(i=0,4294967295<++r&&(r=0))),new u(i,r)},u.from=function(t){if("number"==typeof t)return u.fromNumber(t);if(i.isString(t)){if(!i.Long)return u.fromNumber(parseInt(t,10));t=i.Long.fromString(t)}return t.low||t.high?new u(t.low>>>0,t.high>>>0):e},u.prototype.toNumber=function(t){if(!t&&this.hi>>>31){var n=1+~this.lo>>>0,i=~this.hi>>>0;return n||(i=i+1>>>0),-(n+4294967296*i)}return this.lo+4294967296*this.hi},u.prototype.toLong=function(t){return i.Long?new i.Long(0|this.lo,0|this.hi,!!t):{low:0|this.lo,high:0|this.hi,unsigned:!!t}};var s=String.prototype.charCodeAt;u.fromHash=function(t){return t===r?e:new u((s.call(t,0)|s.call(t,1)<<8|s.call(t,2)<<16|s.call(t,3)<<24)>>>0,(s.call(t,4)|s.call(t,5)<<8|s.call(t,6)<<16|s.call(t,7)<<24)>>>0)},u.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},u.prototype.zzEncode=function(){var t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this},u.prototype.zzDecode=function(){var t=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this},u.prototype.length=function(){var t=this.lo,n=(this.lo>>>28|this.hi<<4)>>>0,i=this.hi>>>24;return 0===i?0===n?t<16384?t<128?1:2:t<2097152?3:4:n<16384?n<128?5:6:n<2097152?7:8:i<128?9:10}},{15:15}],15:[function(t,n,i){var r=i;function u(t,n,i){for(var r=Object.keys(n),u=0;u>>7|t.hi<<25)>>>0,t.hi>>>=7;for(;127>>7;n[i++]=t.lo}function w(t,n,i){n[i]=255&t,n[i+1]=t>>>8&255,n[i+2]=t>>>16&255,n[i+3]=t>>>24}c.create=r.Buffer?function(){return(c.create=function(){return new i})()}:function(){return new c},c.alloc=function(t){return new r.Array(t)},r.Array!==Array&&(c.alloc=r.pool(c.alloc,r.Array.prototype.subarray)),c.prototype.e=function(t,n,i){return this.tail=this.tail.next=new h(t,n,i),this.len+=n,this},(l.prototype=Object.create(h.prototype)).fn=function(t,n,i){for(;127>>=7;n[i]=t},c.prototype.uint32=function(t){return this.len+=(this.tail=this.tail.next=new l((t>>>=0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this},c.prototype.int32=function(t){return t<0?this.e(v,10,u.fromNumber(t)):this.uint32(t)},c.prototype.sint32=function(t){return this.uint32((t<<1^t>>31)>>>0)},c.prototype.int64=c.prototype.uint64=function(t){var n=u.from(t);return this.e(v,n.length(),n)},c.prototype.sint64=function(t){var n=u.from(t).zzEncode();return this.e(v,n.length(),n)},c.prototype.bool=function(t){return this.e(a,1,t?1:0)},c.prototype.sfixed32=c.prototype.fixed32=function(t){return this.e(w,4,t>>>0)},c.prototype.sfixed64=c.prototype.fixed64=function(t){var n=u.from(t);return this.e(w,4,n.lo).e(w,4,n.hi)},c.prototype.float=function(t){return this.e(r.float.writeFloatLE,4,t)},c.prototype.double=function(t){return this.e(r.float.writeDoubleLE,8,t)};var y=r.Array.prototype.set?function(t,n,i){n.set(t,i)}:function(t,n,i){for(var r=0;r>>0;if(!n)return this.e(a,1,0);if(r.isString(t)){var i=c.alloc(n=e.length(t));e.decode(t,i,0),t=i}return this.uint32(n).e(y,n,t)},c.prototype.string=function(t){var n=s.length(t);return n?this.uint32(n).e(s.write,n,t):this.e(a,1,0)},c.prototype.fork=function(){return this.states=new o(this),this.head=this.tail=new h(f,0,0),this.len=0,this},c.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new h(f,0,0),this.len=0),this},c.prototype.ldelim=function(){var t=this.head,n=this.tail,i=this.len;return this.reset().uint32(i),i&&(this.tail.next=t.next,this.tail=n,this.len+=i),this},c.prototype.finish=function(){for(var t=this.head.next,n=this.constructor.alloc(this.len),i=0;t;)t.fn(t.val,n,i),i+=t.len,t=t.next;return n},c.n=function(t){i=t}},{15:15}],17:[function(t,n){n.exports=e;var i=t(16);(e.prototype=Object.create(i.prototype)).constructor=e;var r=t(15),u=r.Buffer;function e(){i.call(this)}e.alloc=function(t){return(e.alloc=r.u)(t)};var s=u&&u.prototype instanceof Uint8Array&&"set"===u.prototype.set.name?function(t,n,i){n.set(t,i)}:function(t,n,i){if(t.copy)t.copy(n,i,0,t.length);else for(var r=0;r>>0;return this.uint32(n),n&&this.e(s,n,t),this},e.prototype.string=function(t){var n=u.byteLength(t);return this.uint32(n),n&&this.e(h,n,t),this}},{15:15,16:16}]},u={},t=[8],n=function t(n){var i=u[n];return i||r[n][0].call(i=u[n]={exports:{}},t,i,i.exports),i.exports}(t[0]),n.util.global.protobuf=n,"function"==typeof define&&define.amd&&define(["long"],function(t){return t&&t.isLong&&(n.util.Long=t,n.configure()),n}),"object"==typeof module&&module&&module.exports&&(module.exports=n)}(); +//# sourceMappingURL=protobuf.min.js.map diff --git a/node_modules/protobufjs/dist/minimal/protobuf.min.js.map b/node_modules/protobufjs/dist/minimal/protobuf.min.js.map new file mode 100644 index 0000000..b13f243 --- /dev/null +++ b/node_modules/protobufjs/dist/minimal/protobuf.min.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/index-minimal","../src/reader.js","../src/reader_buffer.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/util/longbits.js","../src/util/minimal.js","../src/writer.js","../src/writer_buffer.js"],"names":["undefined","modules","cache","entries","protobuf","1","require","module","exports","fn","ctx","params","Array","arguments","length","offset","index","pending","Promise","resolve","reject","err","apply","base64","string","p","n","charAt","Math","ceil","b64","s64","i","encode","buffer","start","end","t","parts","chunk","j","b","push","String","fromCharCode","slice","join","invalidEncoding","decode","c","charCodeAt","Error","test","EventEmitter","this","_listeners","prototype","on","evt","off","listeners","splice","emit","args","factory","Float32Array","f32","f8b","Uint8Array","le","writeFloat_f32_cpy","val","buf","pos","writeFloat_f32_rev","readFloat_f32_cpy","readFloat_f32_rev","writeFloatLE","writeFloatBE","readFloatLE","readFloatBE","writeFloat_ieee754","writeUint","sign","isNaN","round","exponent","floor","log","LN2","pow","readFloat_ieee754","readUint","uint","mantissa","NaN","Infinity","bind","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","f64","writeDouble_f64_cpy","writeDouble_f64_rev","readDouble_f64_cpy","readDouble_f64_rev","writeDoubleLE","writeDoubleBE","readDoubleLE","readDoubleBE","writeDouble_ieee754","off0","off1","readDouble_ieee754","lo","hi","inquire","moduleName","mod","eval","Object","keys","e","alloc","size","SIZE","MAX","slab","call","utf8","len","read","write","c1","c2","configure","Reader","_configure","BufferReader","util","build","Writer","BufferWriter","rpc","roots","LongBits","indexOutOfRange","reader","writeLength","RangeError","value","create_array","isArray","readLongVarint","bits","readFixed32_end","readFixed64","create","Buffer","isBuffer","_slice","subarray","uint32","int32","sint32","bool","fixed32","sfixed32","float","double","bytes","constructor","skip","skipType","wireType","BufferReader_","Long","merge","int64","uint64","sint64","zzDecode","fixed64","sfixed64","utf8Slice","min","Service","rpcImpl","requestDelimited","responseDelimited","TypeError","rpcCall","method","requestCtor","responseCtor","request","callback","self","asPromise","setTimeout","finish","response","endedByRPC","zero","toNumber","zzEncode","zeroHash","fromNumber","from","isString","parseInt","fromString","low","high","unsigned","toLong","fromHash","hash","toHash","mask","part0","part1","part2","dst","src","ifNotSet","newError","name","CustomError","message","properties","defineProperty","get","captureStackTrace","stack","toString","pool","global","window","emptyArray","freeze","emptyObject","isNode","process","versions","node","isInteger","Number","isFinite","isObject","isset","isSet","obj","prop","hasOwnProperty","utf8Write","_Buffer_from","_Buffer_allocUnsafe","newBuffer","sizeOrArray","dcodeIO","key2Re","key32Re","key64Re","longToHash","longFromHash","fromBits","lcFirst","str","toLowerCase","substring","ProtocolError","oneOfGetter","fieldNames","fieldMap","oneOfSetter","toJSONOptions","longs","enums","json","encoding","allocUnsafe","Op","next","noop","State","writer","head","tail","states","writeByte","VarintOp","writeVarint64","writeFixed32","_push","writeBytes","set","fork","reset","ldelim","BufferWriter_","writeBytesBuffer","copy","writeStringBuffer","byteLength","$require","$module","define","amd","isLong"],"mappings":"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","file":"protobuf.min.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(16);\r\nprotobuf.BufferWriter = require(17);\r\nprotobuf.Reader = require(9);\r\nprotobuf.BufferReader = require(10);\r\n\r\n// Utility\r\nprotobuf.util = require(15);\r\nprotobuf.rpc = require(12);\r\nprotobuf.roots = require(11);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(15);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(9);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(15);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(13);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(15);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(15);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(3);\r\n\r\n// float handling accross browsers\r\nutil.float = require(4);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(5);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(7);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(6);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(14);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(15);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(16);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(15);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/dist/protobuf.js b/node_modules/protobufjs/dist/protobuf.js new file mode 100644 index 0000000..c3e1c02 --- /dev/null +++ b/node_modules/protobufjs/dist/protobuf.js @@ -0,0 +1,8726 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:25 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +(function(undefined){"use strict";(function prelude(modules, cache, entries) { + + // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS + // sources through a conflict-free require shim and is again wrapped within an iife that + // provides a minification-friendly `undefined` var plus a global "use strict" directive + // so that minification can remove the directives of each module. + + function $require(name) { + var $module = cache[name]; + if (!$module) + modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports); + return $module.exports; + } + + var protobuf = $require(entries[0]); + + // Expose globally + protobuf.util.global.protobuf = protobuf; + + // Be nice to AMD + if (typeof define === "function" && define.amd) + define(["long"], function(Long) { + if (Long && Long.isLong) { + protobuf.util.Long = Long; + protobuf.configure(); + } + return protobuf; + }); + + // Be nice to CommonJS + if (typeof module === "object" && module && module.exports) + module.exports = protobuf; + +})/* end of prelude */({1:[function(require,module,exports){ +"use strict"; +module.exports = asPromise; + +/** + * Callback as used by {@link util.asPromise}. + * @typedef asPromiseCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {...*} params Additional arguments + * @returns {undefined} + */ + +/** + * Returns a promise from a node-style callback function. + * @memberof util + * @param {asPromiseCallback} fn Function to call + * @param {*} ctx Function context + * @param {...*} params Function arguments + * @returns {Promise<*>} Promisified function + */ +function asPromise(fn, ctx/*, varargs */) { + var params = new Array(arguments.length - 1), + offset = 0, + index = 2, + pending = true; + while (index < arguments.length) + params[offset++] = arguments[index++]; + return new Promise(function executor(resolve, reject) { + params[offset] = function callback(err/*, varargs */) { + if (pending) { + pending = false; + if (err) + reject(err); + else { + var params = new Array(arguments.length - 1), + offset = 0; + while (offset < params.length) + params[offset++] = arguments[offset]; + resolve.apply(null, params); + } + } + }; + try { + fn.apply(ctx || null, params); + } catch (err) { + if (pending) { + pending = false; + reject(err); + } + } + }); +} + +},{}],2:[function(require,module,exports){ +"use strict"; + +/** + * A minimal base64 implementation for number arrays. + * @memberof util + * @namespace + */ +var base64 = exports; + +/** + * Calculates the byte length of a base64 encoded string. + * @param {string} string Base64 encoded string + * @returns {number} Byte length + */ +base64.length = function length(string) { + var p = string.length; + if (!p) + return 0; + var n = 0; + while (--p % 4 > 1 && string.charAt(p) === "=") + ++n; + return Math.ceil(string.length * 3) / 4 - n; +}; + +// Base64 encoding table +var b64 = new Array(64); + +// Base64 decoding table +var s64 = new Array(123); + +// 65..90, 97..122, 48..57, 43, 47 +for (var i = 0; i < 64;) + s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++; + +/** + * Encodes a buffer to a base64 encoded string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} Base64 encoded string + */ +base64.encode = function encode(buffer, start, end) { + var parts = null, + chunk = []; + var i = 0, // output index + j = 0, // goto index + t; // temporary + while (start < end) { + var b = buffer[start++]; + switch (j) { + case 0: + chunk[i++] = b64[b >> 2]; + t = (b & 3) << 4; + j = 1; + break; + case 1: + chunk[i++] = b64[t | b >> 4]; + t = (b & 15) << 2; + j = 2; + break; + case 2: + chunk[i++] = b64[t | b >> 6]; + chunk[i++] = b64[b & 63]; + j = 0; + break; + } + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (j) { + chunk[i++] = b64[t]; + chunk[i++] = 61; + if (j === 1) + chunk[i++] = 61; + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +var invalidEncoding = "invalid encoding"; + +/** + * Decodes a base64 encoded string to a buffer. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Number of bytes written + * @throws {Error} If encoding is invalid + */ +base64.decode = function decode(string, buffer, offset) { + var start = offset; + var j = 0, // goto index + t; // temporary + for (var i = 0; i < string.length;) { + var c = string.charCodeAt(i++); + if (c === 61 && j > 1) + break; + if ((c = s64[c]) === undefined) + throw Error(invalidEncoding); + switch (j) { + case 0: + t = c; + j = 1; + break; + case 1: + buffer[offset++] = t << 2 | (c & 48) >> 4; + t = c; + j = 2; + break; + case 2: + buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2; + t = c; + j = 3; + break; + case 3: + buffer[offset++] = (t & 3) << 6 | c; + j = 0; + break; + } + } + if (j === 1) + throw Error(invalidEncoding); + return offset - start; +}; + +/** + * Tests if the specified string appears to be base64 encoded. + * @param {string} string String to test + * @returns {boolean} `true` if probably base64 encoded, otherwise false + */ +base64.test = function test(string) { + return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string); +}; + +},{}],3:[function(require,module,exports){ +"use strict"; +module.exports = codegen; + +/** + * Begins generating a function. + * @memberof util + * @param {string[]} functionParams Function parameter names + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + */ +function codegen(functionParams, functionName) { + + /* istanbul ignore if */ + if (typeof functionParams === "string") { + functionName = functionParams; + functionParams = undefined; + } + + var body = []; + + /** + * Appends code to the function's body or finishes generation. + * @typedef Codegen + * @type {function} + * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any + * @param {...*} [formatParams] Format parameters + * @returns {Codegen|Function} Itself or the generated function if finished + * @throws {Error} If format parameter counts do not match + */ + + function Codegen(formatStringOrScope) { + // note that explicit array handling below makes this ~50% faster + + // finish the function + if (typeof formatStringOrScope !== "string") { + var source = toString(); + if (codegen.verbose) + console.log("codegen: " + source); // eslint-disable-line no-console + source = "return " + source; + if (formatStringOrScope) { + var scopeKeys = Object.keys(formatStringOrScope), + scopeParams = new Array(scopeKeys.length + 1), + scopeValues = new Array(scopeKeys.length), + scopeOffset = 0; + while (scopeOffset < scopeKeys.length) { + scopeParams[scopeOffset] = scopeKeys[scopeOffset]; + scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]]; + } + scopeParams[scopeOffset] = source; + return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func + } + return Function(source)(); // eslint-disable-line no-new-func + } + + // otherwise append to body + var formatParams = new Array(arguments.length - 1), + formatOffset = 0; + while (formatOffset < formatParams.length) + formatParams[formatOffset] = arguments[++formatOffset]; + formatOffset = 0; + formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) { + var value = formatParams[formatOffset++]; + switch ($1) { + case "d": case "f": return String(Number(value)); + case "i": return String(Math.floor(value)); + case "j": return JSON.stringify(value); + case "s": return String(value); + } + return "%"; + }); + if (formatOffset !== formatParams.length) + throw Error("parameter count mismatch"); + body.push(formatStringOrScope); + return Codegen; + } + + function toString(functionNameOverride) { + return "function " + (functionNameOverride || functionName || "") + "(" + (functionParams && functionParams.join(",") || "") + "){\n " + body.join("\n ") + "\n}"; + } + + Codegen.toString = toString; + return Codegen; +} + +/** + * Begins generating a function. + * @memberof util + * @function codegen + * @param {string} [functionName] Function name if not anonymous + * @returns {Codegen} Appender that appends code to the function's body + * @variation 2 + */ + +/** + * When set to `true`, codegen will log generated code to console. Useful for debugging. + * @name util.codegen.verbose + * @type {boolean} + */ +codegen.verbose = false; + +},{}],4:[function(require,module,exports){ +"use strict"; +module.exports = EventEmitter; + +/** + * Constructs a new event emitter instance. + * @classdesc A minimal event emitter. + * @memberof util + * @constructor + */ +function EventEmitter() { + + /** + * Registered listeners. + * @type {Object.} + * @private + */ + this._listeners = {}; +} + +/** + * Registers an event listener. + * @param {string} evt Event name + * @param {function} fn Listener + * @param {*} [ctx] Listener context + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.on = function on(evt, fn, ctx) { + (this._listeners[evt] || (this._listeners[evt] = [])).push({ + fn : fn, + ctx : ctx || this + }); + return this; +}; + +/** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param {string} [evt] Event name. Removes all listeners if omitted. + * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.off = function off(evt, fn) { + if (evt === undefined) + this._listeners = {}; + else { + if (fn === undefined) + this._listeners[evt] = []; + else { + var listeners = this._listeners[evt]; + for (var i = 0; i < listeners.length;) + if (listeners[i].fn === fn) + listeners.splice(i, 1); + else + ++i; + } + } + return this; +}; + +/** + * Emits an event by calling its listeners with the specified arguments. + * @param {string} evt Event name + * @param {...*} args Arguments + * @returns {util.EventEmitter} `this` + */ +EventEmitter.prototype.emit = function emit(evt) { + var listeners = this._listeners[evt]; + if (listeners) { + var args = [], + i = 1; + for (; i < arguments.length;) + args.push(arguments[i++]); + for (i = 0; i < listeners.length;) + listeners[i].fn.apply(listeners[i++].ctx, args); + } + return this; +}; + +},{}],5:[function(require,module,exports){ +"use strict"; +module.exports = fetch; + +var asPromise = require(1), + inquire = require(7); + +var fs = inquire("fs"); + +/** + * Node-style callback as used by {@link util.fetch}. + * @typedef FetchCallback + * @type {function} + * @param {?Error} error Error, if any, otherwise `null` + * @param {string} [contents] File contents, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Options as used by {@link util.fetch}. + * @typedef FetchOptions + * @type {Object} + * @property {boolean} [binary=false] Whether expecting a binary response + * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest + */ + +/** + * Fetches the contents of a file. + * @memberof util + * @param {string} filename File path or url + * @param {FetchOptions} options Fetch options + * @param {FetchCallback} callback Callback function + * @returns {undefined} + */ +function fetch(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = {}; + } else if (!options) + options = {}; + + if (!callback) + return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this + + // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found. + if (!options.xhr && fs && fs.readFile) + return fs.readFile(filename, function fetchReadFileCallback(err, contents) { + return err && typeof XMLHttpRequest !== "undefined" + ? fetch.xhr(filename, options, callback) + : err + ? callback(err) + : callback(null, options.binary ? contents : contents.toString("utf8")); + }); + + // use the XHR version otherwise. + return fetch.xhr(filename, options, callback); +} + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ + +/** + * Fetches the contents of a file. + * @name util.fetch + * @function + * @param {string} path File path or url + * @param {FetchOptions} [options] Fetch options + * @returns {Promise} Promise + * @variation 3 + */ + +/**/ +fetch.xhr = function fetch_xhr(filename, options, callback) { + var xhr = new XMLHttpRequest(); + xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() { + + if (xhr.readyState !== 4) + return undefined; + + // local cors security errors return status 0 / empty string, too. afaik this cannot be + // reliably distinguished from an actually empty file for security reasons. feel free + // to send a pull request if you are aware of a solution. + if (xhr.status !== 0 && xhr.status !== 200) + return callback(Error("status " + xhr.status)); + + // if binary data is expected, make sure that some sort of array is returned, even if + // ArrayBuffers are not supported. the binary string fallback, however, is unsafe. + if (options.binary) { + var buffer = xhr.response; + if (!buffer) { + buffer = []; + for (var i = 0; i < xhr.responseText.length; ++i) + buffer.push(xhr.responseText.charCodeAt(i) & 255); + } + return callback(null, typeof Uint8Array !== "undefined" ? new Uint8Array(buffer) : buffer); + } + return callback(null, xhr.responseText); + }; + + if (options.binary) { + // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers + if ("overrideMimeType" in xhr) + xhr.overrideMimeType("text/plain; charset=x-user-defined"); + xhr.responseType = "arraybuffer"; + } + + xhr.open("GET", filename); + xhr.send(); +}; + +},{"1":1,"7":7}],6:[function(require,module,exports){ +"use strict"; + +module.exports = factory(factory); + +/** + * Reads / writes floats / doubles from / to buffers. + * @name util.float + * @namespace + */ + +/** + * Writes a 32 bit float to a buffer using little endian byte order. + * @name util.float.writeFloatLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 32 bit float to a buffer using big endian byte order. + * @name util.float.writeFloatBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 32 bit float from a buffer using little endian byte order. + * @name util.float.readFloatLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 32 bit float from a buffer using big endian byte order. + * @name util.float.readFloatBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Writes a 64 bit double to a buffer using little endian byte order. + * @name util.float.writeDoubleLE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Writes a 64 bit double to a buffer using big endian byte order. + * @name util.float.writeDoubleBE + * @function + * @param {number} val Value to write + * @param {Uint8Array} buf Target buffer + * @param {number} pos Target buffer offset + * @returns {undefined} + */ + +/** + * Reads a 64 bit double from a buffer using little endian byte order. + * @name util.float.readDoubleLE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +/** + * Reads a 64 bit double from a buffer using big endian byte order. + * @name util.float.readDoubleBE + * @function + * @param {Uint8Array} buf Source buffer + * @param {number} pos Source buffer offset + * @returns {number} Value read + */ + +// Factory function for the purpose of node-based testing in modified global environments +function factory(exports) { + + // float: typed array + if (typeof Float32Array !== "undefined") (function() { + + var f32 = new Float32Array([ -0 ]), + f8b = new Uint8Array(f32.buffer), + le = f8b[3] === 128; + + function writeFloat_f32_cpy(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + } + + function writeFloat_f32_rev(val, buf, pos) { + f32[0] = val; + buf[pos ] = f8b[3]; + buf[pos + 1] = f8b[2]; + buf[pos + 2] = f8b[1]; + buf[pos + 3] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev; + /* istanbul ignore next */ + exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy; + + function readFloat_f32_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + return f32[0]; + } + + function readFloat_f32_rev(buf, pos) { + f8b[3] = buf[pos ]; + f8b[2] = buf[pos + 1]; + f8b[1] = buf[pos + 2]; + f8b[0] = buf[pos + 3]; + return f32[0]; + } + + /* istanbul ignore next */ + exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev; + /* istanbul ignore next */ + exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy; + + // float: ieee754 + })(); else (function() { + + function writeFloat_ieee754(writeUint, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos); + else if (isNaN(val)) + writeUint(2143289344, buf, pos); + else if (val > 3.4028234663852886e+38) // +-Infinity + writeUint((sign << 31 | 2139095040) >>> 0, buf, pos); + else if (val < 1.1754943508222875e-38) // denormal + writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos); + else { + var exponent = Math.floor(Math.log(val) / Math.LN2), + mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607; + writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos); + } + } + + exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE); + exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE); + + function readFloat_ieee754(readUint, buf, pos) { + var uint = readUint(buf, pos), + sign = (uint >> 31) * 2 + 1, + exponent = uint >>> 23 & 255, + mantissa = uint & 8388607; + return exponent === 255 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 1.401298464324817e-45 * mantissa + : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608); + } + + exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE); + exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE); + + })(); + + // double: typed array + if (typeof Float64Array !== "undefined") (function() { + + var f64 = new Float64Array([-0]), + f8b = new Uint8Array(f64.buffer), + le = f8b[7] === 128; + + function writeDouble_f64_cpy(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[0]; + buf[pos + 1] = f8b[1]; + buf[pos + 2] = f8b[2]; + buf[pos + 3] = f8b[3]; + buf[pos + 4] = f8b[4]; + buf[pos + 5] = f8b[5]; + buf[pos + 6] = f8b[6]; + buf[pos + 7] = f8b[7]; + } + + function writeDouble_f64_rev(val, buf, pos) { + f64[0] = val; + buf[pos ] = f8b[7]; + buf[pos + 1] = f8b[6]; + buf[pos + 2] = f8b[5]; + buf[pos + 3] = f8b[4]; + buf[pos + 4] = f8b[3]; + buf[pos + 5] = f8b[2]; + buf[pos + 6] = f8b[1]; + buf[pos + 7] = f8b[0]; + } + + /* istanbul ignore next */ + exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev; + /* istanbul ignore next */ + exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy; + + function readDouble_f64_cpy(buf, pos) { + f8b[0] = buf[pos ]; + f8b[1] = buf[pos + 1]; + f8b[2] = buf[pos + 2]; + f8b[3] = buf[pos + 3]; + f8b[4] = buf[pos + 4]; + f8b[5] = buf[pos + 5]; + f8b[6] = buf[pos + 6]; + f8b[7] = buf[pos + 7]; + return f64[0]; + } + + function readDouble_f64_rev(buf, pos) { + f8b[7] = buf[pos ]; + f8b[6] = buf[pos + 1]; + f8b[5] = buf[pos + 2]; + f8b[4] = buf[pos + 3]; + f8b[3] = buf[pos + 4]; + f8b[2] = buf[pos + 5]; + f8b[1] = buf[pos + 6]; + f8b[0] = buf[pos + 7]; + return f64[0]; + } + + /* istanbul ignore next */ + exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev; + /* istanbul ignore next */ + exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy; + + // double: ieee754 + })(); else (function() { + + function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) { + var sign = val < 0 ? 1 : 0; + if (sign) + val = -val; + if (val === 0) { + writeUint(0, buf, pos + off0); + writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1); + } else if (isNaN(val)) { + writeUint(0, buf, pos + off0); + writeUint(2146959360, buf, pos + off1); + } else if (val > 1.7976931348623157e+308) { // +-Infinity + writeUint(0, buf, pos + off0); + writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1); + } else { + var mantissa; + if (val < 2.2250738585072014e-308) { // denormal + mantissa = val / 5e-324; + writeUint(mantissa >>> 0, buf, pos + off0); + writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1); + } else { + var exponent = Math.floor(Math.log(val) / Math.LN2); + if (exponent === 1024) + exponent = 1023; + mantissa = val * Math.pow(2, -exponent); + writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0); + writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1); + } + } + } + + exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4); + exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0); + + function readDouble_ieee754(readUint, off0, off1, buf, pos) { + var lo = readUint(buf, pos + off0), + hi = readUint(buf, pos + off1); + var sign = (hi >> 31) * 2 + 1, + exponent = hi >>> 20 & 2047, + mantissa = 4294967296 * (hi & 1048575) + lo; + return exponent === 2047 + ? mantissa + ? NaN + : sign * Infinity + : exponent === 0 // denormal + ? sign * 5e-324 * mantissa + : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496); + } + + exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4); + exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0); + + })(); + + return exports; +} + +// uint helpers + +function writeUintLE(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +function writeUintBE(val, buf, pos) { + buf[pos ] = val >>> 24; + buf[pos + 1] = val >>> 16 & 255; + buf[pos + 2] = val >>> 8 & 255; + buf[pos + 3] = val & 255; +} + +function readUintLE(buf, pos) { + return (buf[pos ] + | buf[pos + 1] << 8 + | buf[pos + 2] << 16 + | buf[pos + 3] << 24) >>> 0; +} + +function readUintBE(buf, pos) { + return (buf[pos ] << 24 + | buf[pos + 1] << 16 + | buf[pos + 2] << 8 + | buf[pos + 3]) >>> 0; +} + +},{}],7:[function(require,module,exports){ +"use strict"; +module.exports = inquire; + +/** + * Requires a module only if available. + * @memberof util + * @param {string} moduleName Module to require + * @returns {?Object} Required module if available and not empty, otherwise `null` + */ +function inquire(moduleName) { + try { + var mod = eval("quire".replace(/^/,"re"))(moduleName); // eslint-disable-line no-eval + if (mod && (mod.length || Object.keys(mod).length)) + return mod; + } catch (e) {} // eslint-disable-line no-empty + return null; +} + +},{}],8:[function(require,module,exports){ +"use strict"; + +/** + * A minimal path module to resolve Unix, Windows and URL paths alike. + * @memberof util + * @namespace + */ +var path = exports; + +var isAbsolute = +/** + * Tests if the specified path is absolute. + * @param {string} path Path to test + * @returns {boolean} `true` if path is absolute + */ +path.isAbsolute = function isAbsolute(path) { + return /^(?:\/|\w+:)/.test(path); +}; + +var normalize = +/** + * Normalizes the specified path. + * @param {string} path Path to normalize + * @returns {string} Normalized path + */ +path.normalize = function normalize(path) { + path = path.replace(/\\/g, "/") + .replace(/\/{2,}/g, "/"); + var parts = path.split("/"), + absolute = isAbsolute(path), + prefix = ""; + if (absolute) + prefix = parts.shift() + "/"; + for (var i = 0; i < parts.length;) { + if (parts[i] === "..") { + if (i > 0 && parts[i - 1] !== "..") + parts.splice(--i, 2); + else if (absolute) + parts.splice(i, 1); + else + ++i; + } else if (parts[i] === ".") + parts.splice(i, 1); + else + ++i; + } + return prefix + parts.join("/"); +}; + +/** + * Resolves the specified include path against the specified origin path. + * @param {string} originPath Path to the origin file + * @param {string} includePath Include path relative to origin path + * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized + * @returns {string} Path to the include file + */ +path.resolve = function resolve(originPath, includePath, alreadyNormalized) { + if (!alreadyNormalized) + includePath = normalize(includePath); + if (isAbsolute(includePath)) + return includePath; + if (!alreadyNormalized) + originPath = normalize(originPath); + return (originPath = originPath.replace(/(?:\/|^)[^/]+$/, "")).length ? normalize(originPath + "/" + includePath) : includePath; +}; + +},{}],9:[function(require,module,exports){ +"use strict"; +module.exports = pool; + +/** + * An allocator as used by {@link util.pool}. + * @typedef PoolAllocator + * @type {function} + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ + +/** + * A slicer as used by {@link util.pool}. + * @typedef PoolSlicer + * @type {function} + * @param {number} start Start offset + * @param {number} end End offset + * @returns {Uint8Array} Buffer slice + * @this {Uint8Array} + */ + +/** + * A general purpose buffer pool. + * @memberof util + * @function + * @param {PoolAllocator} alloc Allocator + * @param {PoolSlicer} slice Slicer + * @param {number} [size=8192] Slab size + * @returns {PoolAllocator} Pooled allocator + */ +function pool(alloc, slice, size) { + var SIZE = size || 8192; + var MAX = SIZE >>> 1; + var slab = null; + var offset = SIZE; + return function pool_alloc(size) { + if (size < 1 || size > MAX) + return alloc(size); + if (offset + size > SIZE) { + slab = alloc(SIZE); + offset = 0; + } + var buf = slice.call(slab, offset, offset += size); + if (offset & 7) // align to 32 bit + offset = (offset | 7) + 1; + return buf; + }; +} + +},{}],10:[function(require,module,exports){ +"use strict"; + +/** + * A minimal UTF8 implementation for number arrays. + * @memberof util + * @namespace + */ +var utf8 = exports; + +/** + * Calculates the UTF8 byte length of a string. + * @param {string} string String + * @returns {number} Byte length + */ +utf8.length = function utf8_length(string) { + var len = 0, + c = 0; + for (var i = 0; i < string.length; ++i) { + c = string.charCodeAt(i); + if (c < 128) + len += 1; + else if (c < 2048) + len += 2; + else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) { + ++i; + len += 4; + } else + len += 3; + } + return len; +}; + +/** + * Reads UTF8 bytes as a string. + * @param {Uint8Array} buffer Source buffer + * @param {number} start Source start + * @param {number} end Source end + * @returns {string} String read + */ +utf8.read = function utf8_read(buffer, start, end) { + var len = end - start; + if (len < 1) + return ""; + var parts = null, + chunk = [], + i = 0, // char offset + t; // temporary + while (start < end) { + t = buffer[start++]; + if (t < 128) + chunk[i++] = t; + else if (t > 191 && t < 224) + chunk[i++] = (t & 31) << 6 | buffer[start++] & 63; + else if (t > 239 && t < 365) { + t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000; + chunk[i++] = 0xD800 + (t >> 10); + chunk[i++] = 0xDC00 + (t & 1023); + } else + chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63; + if (i > 8191) { + (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk)); + i = 0; + } + } + if (parts) { + if (i) + parts.push(String.fromCharCode.apply(String, chunk.slice(0, i))); + return parts.join(""); + } + return String.fromCharCode.apply(String, chunk.slice(0, i)); +}; + +/** + * Writes a string as UTF8 bytes. + * @param {string} string Source string + * @param {Uint8Array} buffer Destination buffer + * @param {number} offset Destination offset + * @returns {number} Bytes written + */ +utf8.write = function utf8_write(string, buffer, offset) { + var start = offset, + c1, // character 1 + c2; // character 2 + for (var i = 0; i < string.length; ++i) { + c1 = string.charCodeAt(i); + if (c1 < 128) { + buffer[offset++] = c1; + } else if (c1 < 2048) { + buffer[offset++] = c1 >> 6 | 192; + buffer[offset++] = c1 & 63 | 128; + } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) { + c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF); + ++i; + buffer[offset++] = c1 >> 18 | 240; + buffer[offset++] = c1 >> 12 & 63 | 128; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } else { + buffer[offset++] = c1 >> 12 | 224; + buffer[offset++] = c1 >> 6 & 63 | 128; + buffer[offset++] = c1 & 63 | 128; + } + } + return offset - start; +}; + +},{}],11:[function(require,module,exports){ +"use strict"; +module.exports = common; + +var commonRe = /\/|\./; + +/** + * Provides common type definitions. + * Can also be used to provide additional google types or your own custom types. + * @param {string} name Short name as in `google/protobuf/[name].proto` or full file name + * @param {Object.} json JSON definition within `google.protobuf` if a short name, otherwise the file's root definition + * @returns {undefined} + * @property {INamespace} google/protobuf/any.proto Any + * @property {INamespace} google/protobuf/duration.proto Duration + * @property {INamespace} google/protobuf/empty.proto Empty + * @property {INamespace} google/protobuf/field_mask.proto FieldMask + * @property {INamespace} google/protobuf/struct.proto Struct, Value, NullValue and ListValue + * @property {INamespace} google/protobuf/timestamp.proto Timestamp + * @property {INamespace} google/protobuf/wrappers.proto Wrappers + * @example + * // manually provides descriptor.proto (assumes google/protobuf/ namespace and .proto extension) + * protobuf.common("descriptor", descriptorJson); + * + * // manually provides a custom definition (uses my.foo namespace) + * protobuf.common("my/foo/bar.proto", myFooBarJson); + */ +function common(name, json) { + if (!commonRe.test(name)) { + name = "google/protobuf/" + name + ".proto"; + json = { nested: { google: { nested: { protobuf: { nested: json } } } } }; + } + common[name] = json; +} + +// Not provided because of limited use (feel free to discuss or to provide yourself): +// +// google/protobuf/descriptor.proto +// google/protobuf/source_context.proto +// google/protobuf/type.proto +// +// Stripped and pre-parsed versions of these non-bundled files are instead available as part of +// the repository or package within the google/protobuf directory. + +common("any", { + + /** + * Properties of a google.protobuf.Any message. + * @interface IAny + * @type {Object} + * @property {string} [typeUrl] + * @property {Uint8Array} [bytes] + * @memberof common + */ + Any: { + fields: { + type_url: { + type: "string", + id: 1 + }, + value: { + type: "bytes", + id: 2 + } + } + } +}); + +var timeType; + +common("duration", { + + /** + * Properties of a google.protobuf.Duration message. + * @interface IDuration + * @type {Object} + * @property {number|Long} [seconds] + * @property {number} [nanos] + * @memberof common + */ + Duration: timeType = { + fields: { + seconds: { + type: "int64", + id: 1 + }, + nanos: { + type: "int32", + id: 2 + } + } + } +}); + +common("timestamp", { + + /** + * Properties of a google.protobuf.Timestamp message. + * @interface ITimestamp + * @type {Object} + * @property {number|Long} [seconds] + * @property {number} [nanos] + * @memberof common + */ + Timestamp: timeType +}); + +common("empty", { + + /** + * Properties of a google.protobuf.Empty message. + * @interface IEmpty + * @memberof common + */ + Empty: { + fields: {} + } +}); + +common("struct", { + + /** + * Properties of a google.protobuf.Struct message. + * @interface IStruct + * @type {Object} + * @property {Object.} [fields] + * @memberof common + */ + Struct: { + fields: { + fields: { + keyType: "string", + type: "Value", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Value message. + * @interface IValue + * @type {Object} + * @property {string} [kind] + * @property {0} [nullValue] + * @property {number} [numberValue] + * @property {string} [stringValue] + * @property {boolean} [boolValue] + * @property {IStruct} [structValue] + * @property {IListValue} [listValue] + * @memberof common + */ + Value: { + oneofs: { + kind: { + oneof: [ + "nullValue", + "numberValue", + "stringValue", + "boolValue", + "structValue", + "listValue" + ] + } + }, + fields: { + nullValue: { + type: "NullValue", + id: 1 + }, + numberValue: { + type: "double", + id: 2 + }, + stringValue: { + type: "string", + id: 3 + }, + boolValue: { + type: "bool", + id: 4 + }, + structValue: { + type: "Struct", + id: 5 + }, + listValue: { + type: "ListValue", + id: 6 + } + } + }, + + NullValue: { + values: { + NULL_VALUE: 0 + } + }, + + /** + * Properties of a google.protobuf.ListValue message. + * @interface IListValue + * @type {Object} + * @property {Array.} [values] + * @memberof common + */ + ListValue: { + fields: { + values: { + rule: "repeated", + type: "Value", + id: 1 + } + } + } +}); + +common("wrappers", { + + /** + * Properties of a google.protobuf.DoubleValue message. + * @interface IDoubleValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + DoubleValue: { + fields: { + value: { + type: "double", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.FloatValue message. + * @interface IFloatValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + FloatValue: { + fields: { + value: { + type: "float", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Int64Value message. + * @interface IInt64Value + * @type {Object} + * @property {number|Long} [value] + * @memberof common + */ + Int64Value: { + fields: { + value: { + type: "int64", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.UInt64Value message. + * @interface IUInt64Value + * @type {Object} + * @property {number|Long} [value] + * @memberof common + */ + UInt64Value: { + fields: { + value: { + type: "uint64", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Int32Value message. + * @interface IInt32Value + * @type {Object} + * @property {number} [value] + * @memberof common + */ + Int32Value: { + fields: { + value: { + type: "int32", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.UInt32Value message. + * @interface IUInt32Value + * @type {Object} + * @property {number} [value] + * @memberof common + */ + UInt32Value: { + fields: { + value: { + type: "uint32", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.BoolValue message. + * @interface IBoolValue + * @type {Object} + * @property {boolean} [value] + * @memberof common + */ + BoolValue: { + fields: { + value: { + type: "bool", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.StringValue message. + * @interface IStringValue + * @type {Object} + * @property {string} [value] + * @memberof common + */ + StringValue: { + fields: { + value: { + type: "string", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.BytesValue message. + * @interface IBytesValue + * @type {Object} + * @property {Uint8Array} [value] + * @memberof common + */ + BytesValue: { + fields: { + value: { + type: "bytes", + id: 1 + } + } + } +}); + +common("field_mask", { + + /** + * Properties of a google.protobuf.FieldMask message. + * @interface IDoubleValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + FieldMask: { + fields: { + paths: { + rule: "repeated", + type: "string", + id: 1 + } + } + } +}); + +/** + * Gets the root definition of the specified common proto file. + * + * Bundled definitions are: + * - google/protobuf/any.proto + * - google/protobuf/duration.proto + * - google/protobuf/empty.proto + * - google/protobuf/field_mask.proto + * - google/protobuf/struct.proto + * - google/protobuf/timestamp.proto + * - google/protobuf/wrappers.proto + * + * @param {string} file Proto file name + * @returns {INamespace|null} Root definition or `null` if not defined + */ +common.get = function get(file) { + return common[file] || null; +}; + +},{}],12:[function(require,module,exports){ +"use strict"; +/** + * Runtime message from/to plain object converters. + * @namespace + */ +var converter = exports; + +var Enum = require(15), + util = require(37); + +/** + * Generates a partial value fromObject conveter. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} prop Property reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genValuePartial_fromObject(gen, field, fieldIndex, prop) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(d%s){", prop); + for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) { + if (field.repeated && values[keys[i]] === field.typeDefault) gen + ("default:"); + gen + ("case%j:", keys[i]) + ("case %i:", values[keys[i]]) + ("m%s=%j", prop, values[keys[i]]) + ("break"); + } gen + ("}"); + } else gen + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s=types[%i].fromObject(d%s)", prop, fieldIndex, prop); + } else { + var isUnsigned = false; + switch (field.type) { + case "double": + case "float": gen + ("m%s=Number(d%s)", prop, prop); // also catches "NaN", "Infinity" + break; + case "uint32": + case "fixed32": gen + ("m%s=d%s>>>0", prop, prop); + break; + case "int32": + case "sint32": + case "sfixed32": gen + ("m%s=d%s|0", prop, prop); + break; + case "uint64": + isUnsigned = true; + // eslint-disable-line no-fallthrough + case "int64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(util.Long)") + ("(m%s=util.Long.fromValue(d%s)).unsigned=%j", prop, prop, isUnsigned) + ("else if(typeof d%s===\"string\")", prop) + ("m%s=parseInt(d%s,10)", prop, prop) + ("else if(typeof d%s===\"number\")", prop) + ("m%s=d%s", prop, prop) + ("else if(typeof d%s===\"object\")", prop) + ("m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)", prop, prop, prop, isUnsigned ? "true" : ""); + break; + case "bytes": gen + ("if(typeof d%s===\"string\")", prop) + ("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)", prop, prop, prop) + ("else if(d%s.length)", prop) + ("m%s=d%s", prop, prop); + break; + case "string": gen + ("m%s=String(d%s)", prop, prop); + break; + case "bool": gen + ("m%s=Boolean(d%s)", prop, prop); + break; + /* default: gen + ("m%s=d%s", prop, prop); + break; */ + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a plain object to runtime message converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.fromObject = function fromObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray; + var gen = util.codegen(["d"], mtype.name + "$fromObject") + ("if(d instanceof this.ctor)") + ("return d"); + if (!fields.length) return gen + ("return new this.ctor"); + gen + ("var m=new this.ctor"); + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + prop = util.safeProp(field.name); + + // Map fields + if (field.map) { gen + ("if(d%s){", prop) + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s={}", prop) + ("for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s", prop, prop, prop, prop, isUnsigned ? "true": "", prop); + break; + case "bytes": gen + ("d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s", prop, prop, prop, prop, prop); + break; + default: gen + ("d%s=m%s", prop, prop); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a runtime message to plain object converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.toObject = function toObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById); + if (!fields.length) + return util.codegen()("return {}"); + var gen = util.codegen(["m", "o"], mtype.name + "$toObject") + ("if(!o)") + ("o={}") + ("var d={}"); + + var repeatedFields = [], + mapFields = [], + normalFields = [], + i = 0; + for (; i < fields.length; ++i) + if (!fields[i].partOf) + ( fields[i].resolve().repeated ? repeatedFields + : fields[i].map ? mapFields + : normalFields).push(fields[i]); + + if (repeatedFields.length) { gen + ("if(o.arrays||o.defaults){"); + for (i = 0; i < repeatedFields.length; ++i) gen + ("d%s=[]", util.safeProp(repeatedFields[i].name)); + gen + ("}"); + } + + if (mapFields.length) { gen + ("if(o.objects||o.defaults){"); + for (i = 0; i < mapFields.length; ++i) gen + ("d%s={}", util.safeProp(mapFields[i].name)); + gen + ("}"); + } + + if (normalFields.length) { gen + ("if(o.defaults){"); + for (i = 0; i < normalFields.length; ++i) { + var field = normalFields[i], + prop = util.safeProp(field.name); + if (field.resolvedType instanceof Enum) gen + ("d%s=o.enums===String?%j:%j", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault); + else if (field.long) gen + ("if(util.Long){") + ("var n=new util.Long(%i,%i,%j)", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned) + ("d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n", prop) + ("}else") + ("d%s=o.longs===String?%j:%i", prop, field.typeDefault.toString(), field.typeDefault.toNumber()); + else if (field.bytes) { + var arrayDefault = "[" + Array.prototype.slice.call(field.typeDefault).join(",") + "]"; + gen + ("if(o.bytes===String)d%s=%j", prop, String.fromCharCode.apply(String, field.typeDefault)) + ("else{") + ("d%s=%s", prop, arrayDefault) + ("if(o.bytes!==Array)d%s=util.newBuffer(d%s)", prop, prop) + ("}"); + } else gen + ("d%s=%j", prop, field.typeDefault); // also messages (=null) + } gen + ("}"); + } + var hasKs2 = false; + for (i = 0; i < fields.length; ++i) { + var field = fields[i], + index = mtype._fieldsArray.indexOf(field), + prop = util.safeProp(field.name); + if (field.map) { + if (!hasKs2) { hasKs2 = true; gen + ("var ks2"); + } gen + ("if(m%s&&(ks2=Object.keys(m%s)).length){", prop, prop) + ("d%s={}", prop) + ("for(var j=0;j>>3){"); + + var i = 0; + for (; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + ref = "m" + util.safeProp(field.name); gen + ("case %i:", field.id); + + // Map fields + if (field.map) { gen + ("r.skip().pos++") // assumes id 1 + key wireType + ("if(%s===util.emptyObject)", ref) + ("%s={}", ref) + ("k=r.%s()", field.keyType) + ("r.pos++"); // assumes id 2 + value wireType + if (types.long[field.keyType] !== undefined) { + if (types.basic[type] === undefined) gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=r.%s()", ref, type); + } else { + if (types.basic[type] === undefined) gen + ("%s[k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[k]=r.%s()", ref, type); + } + + // Repeated fields + } else if (field.repeated) { gen + + ("if(!(%s&&%s.length))", ref, ref) + ("%s=[]", ref); + + // Packable (always check for forward and backward compatiblity) + if (types.packed[type] !== undefined) gen + ("if((t&7)===2){") + ("var c2=r.uint32()+r.pos") + ("while(r.pos>> 0, (field.id << 3 | 4) >>> 0) + : gen("types[%i].encode(%s,w.uint32(%i).fork()).ldelim()", fieldIndex, ref, (field.id << 3 | 2) >>> 0); +} + +/** + * Generates an encoder specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function encoder(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var gen = util.codegen(["m", "w"], mtype.name + "$encode") + ("if(!w)") + ("w=Writer.create()"); + + var i, ref; + + // "when a message is serialized its known fields should be written sequentially by field number" + var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById); + + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + index = mtype._fieldsArray.indexOf(field), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + wireType = types.basic[type]; + ref = "m" + util.safeProp(field.name); + + // Map fields + if (field.map) { + gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name) // !== undefined && !== null + ("for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType); + if (wireType === undefined) gen + ("types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()", index, ref); // can't be groups + else gen + (".uint32(%i).%s(%s[ks[i]]).ldelim()", 16 | wireType, type, ref); + gen + ("}") + ("}"); + + // Repeated fields + } else if (field.repeated) { gen + ("if(%s!=null&&%s.length){", ref, ref); // !== undefined && !== null + + // Packed repeated + if (field.packed && types.packed[type] !== undefined) { gen + + ("w.uint32(%i).fork()", (field.id << 3 | 2) >>> 0) + ("for(var i=0;i<%s.length;++i)", ref) + ("w.%s(%s[i])", type, ref) + ("w.ldelim()"); + + // Non-packed + } else { gen + + ("for(var i=0;i<%s.length;++i)", ref); + if (wireType === undefined) + genTypePartial(gen, field, index, ref + "[i]"); + else gen + ("w.uint32(%i).%s(%s[i])", (field.id << 3 | wireType) >>> 0, type, ref); + + } gen + ("}"); + + // Non-repeated + } else { + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j))", ref, field.name); // !== undefined && !== null + + if (wireType === undefined) + genTypePartial(gen, field, index, ref); + else gen + ("w.uint32(%i).%s(%s)", (field.id << 3 | wireType) >>> 0, type, ref); + + } + } + + return gen + ("return w"); + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} +},{"15":15,"36":36,"37":37}],15:[function(require,module,exports){ +"use strict"; +module.exports = Enum; + +// extends ReflectionObject +var ReflectionObject = require(24); +((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = "Enum"; + +var Namespace = require(23), + util = require(37); + +/** + * Constructs a new enum instance. + * @classdesc Reflected enum. + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {Object.} [values] Enum values as an object, by name + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this enum + * @param {Object.} [comments] The value comments for this enum + */ +function Enum(name, values, options, comment, comments) { + ReflectionObject.call(this, name, options); + + if (values && typeof values !== "object") + throw TypeError("values must be an object"); + + /** + * Enum values by id. + * @type {Object.} + */ + this.valuesById = {}; + + /** + * Enum values by name. + * @type {Object.} + */ + this.values = Object.create(this.valuesById); // toJSON, marker + + /** + * Enum comment text. + * @type {string|null} + */ + this.comment = comment; + + /** + * Value comment texts, if any. + * @type {Object.} + */ + this.comments = comments || {}; + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + // Note that values inherit valuesById on their prototype which makes them a TypeScript- + // compatible enum. This is used by pbts to write actual enum definitions that work for + // static and reflection code alike instead of emitting generic object definitions. + + if (values) + for (var keys = Object.keys(values), i = 0; i < keys.length; ++i) + if (typeof values[keys[i]] === "number") // use forward entries only + this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i]; +} + +/** + * Enum descriptor. + * @interface IEnum + * @property {Object.} values Enum values + * @property {Object.} [options] Enum options + */ + +/** + * Constructs an enum from an enum descriptor. + * @param {string} name Enum name + * @param {IEnum} json Enum descriptor + * @returns {Enum} Created enum + * @throws {TypeError} If arguments are invalid + */ +Enum.fromJSON = function fromJSON(name, json) { + var enm = new Enum(name, json.values, json.options, json.comment, json.comments); + enm.reserved = json.reserved; + return enm; +}; + +/** + * Converts this enum to an enum descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IEnum} Enum descriptor + */ +Enum.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "values" , this.values, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "comment" , keepComments ? this.comment : undefined, + "comments" , keepComments ? this.comments : undefined + ]); +}; + +/** + * Adds a value to this enum. + * @param {string} name Value name + * @param {number} id Value id + * @param {string} [comment] Comment, if any + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a value with this name or id + */ +Enum.prototype.add = function add(name, id, comment) { + // utilized by the parser but not by .fromJSON + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (!util.isInteger(id)) + throw TypeError("id must be an integer"); + + if (this.values[name] !== undefined) + throw Error("duplicate name '" + name + "' in " + this); + + if (this.isReservedId(id)) + throw Error("id " + id + " is reserved in " + this); + + if (this.isReservedName(name)) + throw Error("name '" + name + "' is reserved in " + this); + + if (this.valuesById[id] !== undefined) { + if (!(this.options && this.options.allow_alias)) + throw Error("duplicate id " + id + " in " + this); + this.values[name] = id; + } else + this.valuesById[this.values[name] = id] = name; + + this.comments[name] = comment || null; + return this; +}; + +/** + * Removes a value from this enum + * @param {string} name Value name + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `name` is not a name of this enum + */ +Enum.prototype.remove = function remove(name) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + var val = this.values[name]; + if (val == null) + throw Error("name '" + name + "' does not exist in " + this); + + delete this.valuesById[val]; + delete this.values[name]; + delete this.comments[name]; + + return this; +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; + +},{"23":23,"24":24,"37":37}],16:[function(require,module,exports){ +"use strict"; +module.exports = Field; + +// extends ReflectionObject +var ReflectionObject = require(24); +((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = "Field"; + +var Enum = require(15), + types = require(36), + util = require(37); + +var Type; // cyclic + +var ruleRe = /^required|optional|repeated$/; + +/** + * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class. + * @name Field + * @classdesc Reflected message field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a field from a field descriptor. + * @param {string} name Field name + * @param {IField} json Field descriptor + * @returns {Field} Created field + * @throws {TypeError} If arguments are invalid + */ +Field.fromJSON = function fromJSON(name, json) { + return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment); +}; + +/** + * Not an actual constructor. Use {@link Field} instead. + * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions. + * @exports FieldBase + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function Field(name, id, type, rule, extend, options, comment) { + + if (util.isObject(rule)) { + comment = extend; + options = rule; + rule = extend = undefined; + } else if (util.isObject(extend)) { + comment = options; + options = extend; + extend = undefined; + } + + ReflectionObject.call(this, name, options); + + if (!util.isInteger(id) || id < 0) + throw TypeError("id must be a non-negative integer"); + + if (!util.isString(type)) + throw TypeError("type must be a string"); + + if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase())) + throw TypeError("rule must be a string rule"); + + if (extend !== undefined && !util.isString(extend)) + throw TypeError("extend must be a string"); + + /** + * Field rule, if any. + * @type {string|undefined} + */ + this.rule = rule && rule !== "optional" ? rule : undefined; // toJSON + + /** + * Field type. + * @type {string} + */ + this.type = type; // toJSON + + /** + * Unique field id. + * @type {number} + */ + this.id = id; // toJSON, marker + + /** + * Extended type if different from parent. + * @type {string|undefined} + */ + this.extend = extend || undefined; // toJSON + + /** + * Whether this field is required. + * @type {boolean} + */ + this.required = rule === "required"; + + /** + * Whether this field is optional. + * @type {boolean} + */ + this.optional = !this.required; + + /** + * Whether this field is repeated. + * @type {boolean} + */ + this.repeated = rule === "repeated"; + + /** + * Whether this field is a map or not. + * @type {boolean} + */ + this.map = false; + + /** + * Message this field belongs to. + * @type {Type|null} + */ + this.message = null; + + /** + * OneOf this field belongs to, if any, + * @type {OneOf|null} + */ + this.partOf = null; + + /** + * The field type's default value. + * @type {*} + */ + this.typeDefault = null; + + /** + * The field's default value on prototypes. + * @type {*} + */ + this.defaultValue = null; + + /** + * Whether this field's value should be treated as a long. + * @type {boolean} + */ + this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false; + + /** + * Whether this field's value is a buffer. + * @type {boolean} + */ + this.bytes = type === "bytes"; + + /** + * Resolved type if not a basic type. + * @type {Type|Enum|null} + */ + this.resolvedType = null; + + /** + * Sister-field within the extended type if a declaring extension field. + * @type {Field|null} + */ + this.extensionField = null; + + /** + * Sister-field within the declaring namespace if an extended field. + * @type {Field|null} + */ + this.declaringField = null; + + /** + * Internally remembers whether this field is packed. + * @type {boolean|null} + * @private + */ + this._packed = null; + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Determines whether this field is packed. Only relevant when repeated and working with proto2. + * @name Field#packed + * @type {boolean} + * @readonly + */ +Object.defineProperty(Field.prototype, "packed", { + get: function() { + // defaults to packed=true if not explicity set to false + if (this._packed === null) + this._packed = this.getOption("packed") !== false; + return this._packed; + } +}); + +/** + * @override + */ +Field.prototype.setOption = function setOption(name, value, ifNotSet) { + if (name === "packed") // clear cached before setting + this._packed = null; + return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet); +}; + +/** + * Field descriptor. + * @interface IField + * @property {string} [rule="optional"] Field rule + * @property {string} type Field type + * @property {number} id Field id + * @property {Object.} [options] Field options + */ + +/** + * Extension field descriptor. + * @interface IExtensionField + * @extends IField + * @property {string} extend Extended type + */ + +/** + * Converts this field to a field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IField} Field descriptor + */ +Field.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "rule" , this.rule !== "optional" && this.rule || undefined, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Resolves this field's type references. + * @returns {Field} `this` + * @throws {Error} If any reference cannot be resolved + */ +Field.prototype.resolve = function resolve() { + + if (this.resolved) + return this; + + if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it + this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type); + if (this.resolvedType instanceof Type) + this.typeDefault = null; + else // instanceof Enum + this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined + } + + // use explicitly set default value if present + if (this.options && this.options["default"] != null) { + this.typeDefault = this.options["default"]; + if (this.resolvedType instanceof Enum && typeof this.typeDefault === "string") + this.typeDefault = this.resolvedType.values[this.typeDefault]; + } + + // remove unnecessary options + if (this.options) { + if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum)) + delete this.options.packed; + if (!Object.keys(this.options).length) + this.options = undefined; + } + + // convert to internal data type if necesssary + if (this.long) { + this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === "u"); + + /* istanbul ignore else */ + if (Object.freeze) + Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it) + + } else if (this.bytes && typeof this.typeDefault === "string") { + var buf; + if (util.base64.test(this.typeDefault)) + util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0); + else + util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0); + this.typeDefault = buf; + } + + // take special care of maps and repeated fields + if (this.map) + this.defaultValue = util.emptyObject; + else if (this.repeated) + this.defaultValue = util.emptyArray; + else + this.defaultValue = this.typeDefault; + + // ensure proper value on prototype + if (this.parent instanceof Type) + this.parent.ctor.prototype[this.name] = this.defaultValue; + + return ReflectionObject.prototype.resolve.call(this); +}; + +/** + * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript). + * @typedef FieldDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} fieldName Field name + * @returns {undefined} + */ + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|Object} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @param {T} [defaultValue] Default value + * @returns {FieldDecorator} Decorator function + * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[] + */ +Field.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) { + + // submessage: decorate the submessage and use its name as the type + if (typeof fieldType === "function") + fieldType = util.decorateType(fieldType).name; + + // enum reference: create a reflected copy of the enum and keep reuseing it + else if (fieldType && typeof fieldType === "object") + fieldType = util.decorateEnum(fieldType).name; + + return function fieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new Field(fieldName, fieldId, fieldType, fieldRule, { "default": defaultValue })); + }; +}; + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {Constructor|string} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @returns {FieldDecorator} Decorator function + * @template T extends Message + * @variation 2 + */ +// like Field.d but without a default value + +// Sets up cyclic dependencies (called in index-light) +Field._configure = function configure(Type_) { + Type = Type_; +}; + +},{"15":15,"24":24,"36":36,"37":37}],17:[function(require,module,exports){ +"use strict"; +var protobuf = module.exports = require(18); + +protobuf.build = "light"; + +/** + * A node-style callback as used by {@link load} and {@link Root#load}. + * @typedef LoadCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Root} [root] Root, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @param {string|string[]} filename One or multiple files to load + * @param {Root} root Root namespace, defaults to create a new one if omitted. + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + */ +function load(filename, root, callback) { + if (typeof root === "function") { + callback = root; + root = new protobuf.Root(); + } else if (!root) + root = new protobuf.Root(); + return root.load(filename, callback); +} + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Promise} Promise + * @see {@link Root#load} + * @variation 3 + */ +// function load(filename:string, [root:Root]):Promise + +protobuf.load = load; + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only). + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + * @see {@link Root#loadSync} + */ +function loadSync(filename, root) { + if (!root) + root = new protobuf.Root(); + return root.loadSync(filename); +} + +protobuf.loadSync = loadSync; + +// Serialization +protobuf.encoder = require(14); +protobuf.decoder = require(13); +protobuf.verifier = require(40); +protobuf.converter = require(12); + +// Reflection +protobuf.ReflectionObject = require(24); +protobuf.Namespace = require(23); +protobuf.Root = require(29); +protobuf.Enum = require(15); +protobuf.Type = require(35); +protobuf.Field = require(16); +protobuf.OneOf = require(25); +protobuf.MapField = require(20); +protobuf.Service = require(33); +protobuf.Method = require(22); + +// Runtime +protobuf.Message = require(21); +protobuf.wrappers = require(41); + +// Utility +protobuf.types = require(36); +protobuf.util = require(37); + +// Set up possibly cyclic reflection dependencies +protobuf.ReflectionObject._configure(protobuf.Root); +protobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum); +protobuf.Root._configure(protobuf.Type); +protobuf.Field._configure(protobuf.Type); + +},{"12":12,"13":13,"14":14,"15":15,"16":16,"18":18,"20":20,"21":21,"22":22,"23":23,"24":24,"25":25,"29":29,"33":33,"35":35,"36":36,"37":37,"40":40,"41":41}],18:[function(require,module,exports){ +"use strict"; +var protobuf = exports; + +/** + * Build type, one of `"full"`, `"light"` or `"minimal"`. + * @name build + * @type {string} + * @const + */ +protobuf.build = "minimal"; + +// Serialization +protobuf.Writer = require(42); +protobuf.BufferWriter = require(43); +protobuf.Reader = require(27); +protobuf.BufferReader = require(28); + +// Utility +protobuf.util = require(39); +protobuf.rpc = require(31); +protobuf.roots = require(30); +protobuf.configure = configure; + +/* istanbul ignore next */ +/** + * Reconfigures the library according to the environment. + * @returns {undefined} + */ +function configure() { + protobuf.Reader._configure(protobuf.BufferReader); + protobuf.util._configure(); +} + +// Set up buffer utility according to the environment +protobuf.Writer._configure(protobuf.BufferWriter); +configure(); + +},{"27":27,"28":28,"30":30,"31":31,"39":39,"42":42,"43":43}],19:[function(require,module,exports){ +"use strict"; +var protobuf = module.exports = require(17); + +protobuf.build = "full"; + +// Parser +protobuf.tokenize = require(34); +protobuf.parse = require(26); +protobuf.common = require(11); + +// Configure parser +protobuf.Root._configure(protobuf.Type, protobuf.parse, protobuf.common); + +},{"11":11,"17":17,"26":26,"34":34}],20:[function(require,module,exports){ +"use strict"; +module.exports = MapField; + +// extends Field +var Field = require(16); +((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = "MapField"; + +var types = require(36), + util = require(37); + +/** + * Constructs a new map field instance. + * @classdesc Reflected map field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} keyType Key type + * @param {string} type Value type + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function MapField(name, id, keyType, type, options, comment) { + Field.call(this, name, id, type, undefined, undefined, options, comment); + + /* istanbul ignore if */ + if (!util.isString(keyType)) + throw TypeError("keyType must be a string"); + + /** + * Key type. + * @type {string} + */ + this.keyType = keyType; // toJSON, marker + + /** + * Resolved key type if not a basic type. + * @type {ReflectionObject|null} + */ + this.resolvedKeyType = null; + + // Overrides Field#map + this.map = true; +} + +/** + * Map field descriptor. + * @interface IMapField + * @extends {IField} + * @property {string} keyType Key type + */ + +/** + * Extension map field descriptor. + * @interface IExtensionMapField + * @extends IMapField + * @property {string} extend Extended type + */ + +/** + * Constructs a map field from a map field descriptor. + * @param {string} name Field name + * @param {IMapField} json Map field descriptor + * @returns {MapField} Created map field + * @throws {TypeError} If arguments are invalid + */ +MapField.fromJSON = function fromJSON(name, json) { + return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment); +}; + +/** + * Converts this map field to a map field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMapField} Map field descriptor + */ +MapField.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "keyType" , this.keyType, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +MapField.prototype.resolve = function resolve() { + if (this.resolved) + return this; + + // Besides a value type, map fields have a key type that may be "any scalar type except for floating point types and bytes" + if (types.mapKey[this.keyType] === undefined) + throw Error("invalid key type: " + this.keyType); + + return Field.prototype.resolve.call(this); +}; + +/** + * Map field decorator (TypeScript). + * @name MapField.d + * @function + * @param {number} fieldId Field id + * @param {"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"} fieldKeyType Field key type + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"|"bytes"|Object|Constructor<{}>} fieldValueType Field value type + * @returns {FieldDecorator} Decorator function + * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> } + */ +MapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) { + + // submessage value: decorate the submessage and use its name as the type + if (typeof fieldValueType === "function") + fieldValueType = util.decorateType(fieldValueType).name; + + // enum reference value: create a reflected copy of the enum and keep reuseing it + else if (fieldValueType && typeof fieldValueType === "object") + fieldValueType = util.decorateEnum(fieldValueType).name; + + return function mapFieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType)); + }; +}; + +},{"16":16,"36":36,"37":37}],21:[function(require,module,exports){ +"use strict"; +module.exports = Message; + +var util = require(39); + +/** + * Constructs a new message instance. + * @classdesc Abstract runtime message. + * @constructor + * @param {Properties} [properties] Properties to set + * @template T extends object = object + */ +function Message(properties) { + // not used internally + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + this[keys[i]] = properties[keys[i]]; +} + +/** + * Reference to the reflected type. + * @name Message.$type + * @type {Type} + * @readonly + */ + +/** + * Reference to the reflected type. + * @name Message#$type + * @type {Type} + * @readonly + */ + +/*eslint-disable valid-jsdoc*/ + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message} Message instance + * @template T extends Message + * @this Constructor + */ +Message.create = function create(properties) { + return this.$type.create(properties); +}; + +/** + * Encodes a message of this type. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encode = function encode(message, writer) { + return this.$type.encode(message, writer); +}; + +/** + * Encodes a message of this type preceeded by its length as a varint. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encodeDelimited = function encodeDelimited(message, writer) { + return this.$type.encodeDelimited(message, writer); +}; + +/** + * Decodes a message of this type. + * @name Message.decode + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decode = function decode(reader) { + return this.$type.decode(reader); +}; + +/** + * Decodes a message of this type preceeded by its length as a varint. + * @name Message.decodeDelimited + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decodeDelimited = function decodeDelimited(reader) { + return this.$type.decodeDelimited(reader); +}; + +/** + * Verifies a message of this type. + * @name Message.verify + * @function + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ +Message.verify = function verify(message) { + return this.$type.verify(message); +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object + * @returns {T} Message instance + * @template T extends Message + * @this Constructor + */ +Message.fromObject = function fromObject(object) { + return this.$type.fromObject(object); +}; + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {T} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @template T extends Message + * @this Constructor + */ +Message.toObject = function toObject(message, options) { + return this.$type.toObject(message, options); +}; + +/** + * Converts this message to JSON. + * @returns {Object.} JSON object + */ +Message.prototype.toJSON = function toJSON() { + return this.$type.toObject(this, util.toJSONOptions); +}; + +/*eslint-enable valid-jsdoc*/ +},{"39":39}],22:[function(require,module,exports){ +"use strict"; +module.exports = Method; + +// extends ReflectionObject +var ReflectionObject = require(24); +((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = "Method"; + +var util = require(37); + +/** + * Constructs a new service method instance. + * @classdesc Reflected service method. + * @extends ReflectionObject + * @constructor + * @param {string} name Method name + * @param {string|undefined} type Method type, usually `"rpc"` + * @param {string} requestType Request message type + * @param {string} responseType Response message type + * @param {boolean|Object.} [requestStream] Whether the request is streamed + * @param {boolean|Object.} [responseStream] Whether the response is streamed + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this method + */ +function Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) { + + /* istanbul ignore next */ + if (util.isObject(requestStream)) { + options = requestStream; + requestStream = responseStream = undefined; + } else if (util.isObject(responseStream)) { + options = responseStream; + responseStream = undefined; + } + + /* istanbul ignore if */ + if (!(type === undefined || util.isString(type))) + throw TypeError("type must be a string"); + + /* istanbul ignore if */ + if (!util.isString(requestType)) + throw TypeError("requestType must be a string"); + + /* istanbul ignore if */ + if (!util.isString(responseType)) + throw TypeError("responseType must be a string"); + + ReflectionObject.call(this, name, options); + + /** + * Method type. + * @type {string} + */ + this.type = type || "rpc"; // toJSON + + /** + * Request type. + * @type {string} + */ + this.requestType = requestType; // toJSON, marker + + /** + * Whether requests are streamed or not. + * @type {boolean|undefined} + */ + this.requestStream = requestStream ? true : undefined; // toJSON + + /** + * Response type. + * @type {string} + */ + this.responseType = responseType; // toJSON + + /** + * Whether responses are streamed or not. + * @type {boolean|undefined} + */ + this.responseStream = responseStream ? true : undefined; // toJSON + + /** + * Resolved request type. + * @type {Type|null} + */ + this.resolvedRequestType = null; + + /** + * Resolved response type. + * @type {Type|null} + */ + this.resolvedResponseType = null; + + /** + * Comment for this method + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Method descriptor. + * @interface IMethod + * @property {string} [type="rpc"] Method type + * @property {string} requestType Request type + * @property {string} responseType Response type + * @property {boolean} [requestStream=false] Whether requests are streamed + * @property {boolean} [responseStream=false] Whether responses are streamed + * @property {Object.} [options] Method options + */ + +/** + * Constructs a method from a method descriptor. + * @param {string} name Method name + * @param {IMethod} json Method descriptor + * @returns {Method} Created method + * @throws {TypeError} If arguments are invalid + */ +Method.fromJSON = function fromJSON(name, json) { + return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment); +}; + +/** + * Converts this method to a method descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMethod} Method descriptor + */ +Method.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "type" , this.type !== "rpc" && /* istanbul ignore next */ this.type || undefined, + "requestType" , this.requestType, + "requestStream" , this.requestStream, + "responseType" , this.responseType, + "responseStream" , this.responseStream, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Method.prototype.resolve = function resolve() { + + /* istanbul ignore if */ + if (this.resolved) + return this; + + this.resolvedRequestType = this.parent.lookupType(this.requestType); + this.resolvedResponseType = this.parent.lookupType(this.responseType); + + return ReflectionObject.prototype.resolve.call(this); +}; + +},{"24":24,"37":37}],23:[function(require,module,exports){ +"use strict"; +module.exports = Namespace; + +// extends ReflectionObject +var ReflectionObject = require(24); +((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = "Namespace"; + +var Field = require(16), + util = require(37); + +var Type, // cyclic + Service, + Enum; + +/** + * Constructs a new namespace instance. + * @name Namespace + * @classdesc Reflected namespace. + * @extends NamespaceBase + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a namespace from JSON. + * @memberof Namespace + * @function + * @param {string} name Namespace name + * @param {Object.} json JSON object + * @returns {Namespace} Created namespace + * @throws {TypeError} If arguments are invalid + */ +Namespace.fromJSON = function fromJSON(name, json) { + return new Namespace(name, json.options).addJSON(json.nested); +}; + +/** + * Converts an array of reflection objects to JSON. + * @memberof Namespace + * @param {ReflectionObject[]} array Object array + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {Object.|undefined} JSON object or `undefined` when array is empty + */ +function arrayToJSON(array, toJSONOptions) { + if (!(array && array.length)) + return undefined; + var obj = {}; + for (var i = 0; i < array.length; ++i) + obj[array[i].name] = array[i].toJSON(toJSONOptions); + return obj; +} + +Namespace.arrayToJSON = arrayToJSON; + +/** + * Tests if the specified id is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedId = function isReservedId(reserved, id) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (typeof reserved[i] !== "string" && reserved[i][0] <= id && reserved[i][1] >= id) + return true; + return false; +}; + +/** + * Tests if the specified name is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedName = function isReservedName(reserved, name) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (reserved[i] === name) + return true; + return false; +}; + +/** + * Not an actual constructor. Use {@link Namespace} instead. + * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions. + * @exports NamespaceBase + * @extends ReflectionObject + * @abstract + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + * @see {@link Namespace} + */ +function Namespace(name, options) { + ReflectionObject.call(this, name, options); + + /** + * Nested objects by name. + * @type {Object.|undefined} + */ + this.nested = undefined; // toJSON + + /** + * Cached nested objects as an array. + * @type {ReflectionObject[]|null} + * @private + */ + this._nestedArray = null; +} + +function clearCache(namespace) { + namespace._nestedArray = null; + return namespace; +} + +/** + * Nested objects of this namespace as an array for iteration. + * @name NamespaceBase#nestedArray + * @type {ReflectionObject[]} + * @readonly + */ +Object.defineProperty(Namespace.prototype, "nestedArray", { + get: function() { + return this._nestedArray || (this._nestedArray = util.toArray(this.nested)); + } +}); + +/** + * Namespace descriptor. + * @interface INamespace + * @property {Object.} [options] Namespace options + * @property {Object.} [nested] Nested object descriptors + */ + +/** + * Any extension field descriptor. + * @typedef AnyExtensionField + * @type {IExtensionField|IExtensionMapField} + */ + +/** + * Any nested object descriptor. + * @typedef AnyNestedObject + * @type {IEnum|IType|IService|AnyExtensionField|INamespace} + */ +// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place) + +/** + * Converts this namespace to a namespace descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {INamespace} Namespace descriptor + */ +Namespace.prototype.toJSON = function toJSON(toJSONOptions) { + return util.toObject([ + "options" , this.options, + "nested" , arrayToJSON(this.nestedArray, toJSONOptions) + ]); +}; + +/** + * Adds nested objects to this namespace from nested object descriptors. + * @param {Object.} nestedJson Any nested object descriptors + * @returns {Namespace} `this` + */ +Namespace.prototype.addJSON = function addJSON(nestedJson) { + var ns = this; + /* istanbul ignore else */ + if (nestedJson) { + for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) { + nested = nestedJson[names[i]]; + ns.add( // most to least likely + ( nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : nested.id !== undefined + ? Field.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + } + return this; +}; + +/** + * Gets the nested object of the specified name. + * @param {string} name Nested object name + * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist + */ +Namespace.prototype.get = function get(name) { + return this.nested && this.nested[name] + || null; +}; + +/** + * Gets the values of the nested {@link Enum|enum} of the specified name. + * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`. + * @param {string} name Nested enum name + * @returns {Object.} Enum values + * @throws {Error} If there is no such enum + */ +Namespace.prototype.getEnum = function getEnum(name) { + if (this.nested && this.nested[name] instanceof Enum) + return this.nested[name].values; + throw Error("no such enum: " + name); +}; + +/** + * Adds a nested object to this namespace. + * @param {ReflectionObject} object Nested object to add + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name + */ +Namespace.prototype.add = function add(object) { + + if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace)) + throw TypeError("object must be a valid nested object"); + + if (!this.nested) + this.nested = {}; + else { + var prev = this.get(object.name); + if (prev) { + if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) { + // replace plain namespace but keep existing nested elements and options + var nested = prev.nestedArray; + for (var i = 0; i < nested.length; ++i) + object.add(nested[i]); + this.remove(prev); + if (!this.nested) + this.nested = {}; + object.setOptions(prev.options, true); + + } else + throw Error("duplicate name '" + object.name + "' in " + this); + } + } + this.nested[object.name] = object; + object.onAdd(this); + return clearCache(this); +}; + +/** + * Removes a nested object from this namespace. + * @param {ReflectionObject} object Nested object to remove + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this namespace + */ +Namespace.prototype.remove = function remove(object) { + + if (!(object instanceof ReflectionObject)) + throw TypeError("object must be a ReflectionObject"); + if (object.parent !== this) + throw Error(object + " is not a member of " + this); + + delete this.nested[object.name]; + if (!Object.keys(this.nested).length) + this.nested = undefined; + + object.onRemove(this); + return clearCache(this); +}; + +/** + * Defines additial namespaces within this one if not yet existing. + * @param {string|string[]} path Path to create + * @param {*} [json] Nested types to create from JSON + * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty + */ +Namespace.prototype.define = function define(path, json) { + + if (util.isString(path)) + path = path.split("."); + else if (!Array.isArray(path)) + throw TypeError("illegal path"); + if (path && path.length && path[0] === "") + throw Error("path must be relative"); + + var ptr = this; + while (path.length > 0) { + var part = path.shift(); + if (ptr.nested && ptr.nested[part]) { + ptr = ptr.nested[part]; + if (!(ptr instanceof Namespace)) + throw Error("path conflicts with non-namespace objects"); + } else + ptr.add(ptr = new Namespace(part)); + } + if (json) + ptr.addJSON(json); + return ptr; +}; + +/** + * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost. + * @returns {Namespace} `this` + */ +Namespace.prototype.resolveAll = function resolveAll() { + var nested = this.nestedArray, i = 0; + while (i < nested.length) + if (nested[i] instanceof Namespace) + nested[i++].resolveAll(); + else + nested[i++].resolve(); + return this.resolve(); +}; + +/** + * Recursively looks up the reflection object matching the specified path in the scope of this namespace. + * @param {string|string[]} path Path to look up + * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc. + * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + */ +Namespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) { + + /* istanbul ignore next */ + if (typeof filterTypes === "boolean") { + parentAlreadyChecked = filterTypes; + filterTypes = undefined; + } else if (filterTypes && !Array.isArray(filterTypes)) + filterTypes = [ filterTypes ]; + + if (util.isString(path) && path.length) { + if (path === ".") + return this.root; + path = path.split("."); + } else if (!path.length) + return this; + + // Start at root if path is absolute + if (path[0] === "") + return this.root.lookup(path.slice(1), filterTypes); + + // Test if the first part matches any nested object, and if so, traverse if path contains more + var found = this.get(path[0]); + if (found) { + if (path.length === 1) { + if (!filterTypes || filterTypes.indexOf(found.constructor) > -1) + return found; + } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true))) + return found; + + // Otherwise try each nested namespace + } else + for (var i = 0; i < this.nestedArray.length; ++i) + if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true))) + return found; + + // If there hasn't been a match, try again at the parent + if (this.parent === null || parentAlreadyChecked) + return null; + return this.parent.lookup(path, filterTypes); +}; + +/** + * Looks up the reflection object at the specified path, relative to this namespace. + * @name NamespaceBase#lookup + * @function + * @param {string|string[]} path Path to look up + * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + * @variation 2 + */ +// lookup(path: string, [parentAlreadyChecked: boolean]) + +/** + * Looks up the {@link Type|type} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type + * @throws {Error} If `path` does not point to a type + */ +Namespace.prototype.lookupType = function lookupType(path) { + var found = this.lookup(path, [ Type ]); + if (!found) + throw Error("no such type: " + path); + return found; +}; + +/** + * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Enum} Looked up enum + * @throws {Error} If `path` does not point to an enum + */ +Namespace.prototype.lookupEnum = function lookupEnum(path) { + var found = this.lookup(path, [ Enum ]); + if (!found) + throw Error("no such Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type or enum + * @throws {Error} If `path` does not point to a type or enum + */ +Namespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) { + var found = this.lookup(path, [ Type, Enum ]); + if (!found) + throw Error("no such Type or Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Service|service} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Service} Looked up service + * @throws {Error} If `path` does not point to a service + */ +Namespace.prototype.lookupService = function lookupService(path) { + var found = this.lookup(path, [ Service ]); + if (!found) + throw Error("no such Service '" + path + "' in " + this); + return found; +}; + +// Sets up cyclic dependencies (called in index-light) +Namespace._configure = function(Type_, Service_, Enum_) { + Type = Type_; + Service = Service_; + Enum = Enum_; +}; + +},{"16":16,"24":24,"37":37}],24:[function(require,module,exports){ +"use strict"; +module.exports = ReflectionObject; + +ReflectionObject.className = "ReflectionObject"; + +var util = require(37); + +var Root; // cyclic + +/** + * Constructs a new reflection object instance. + * @classdesc Base class of all reflection objects. + * @constructor + * @param {string} name Object name + * @param {Object.} [options] Declared options + * @abstract + */ +function ReflectionObject(name, options) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (options && !util.isObject(options)) + throw TypeError("options must be an object"); + + /** + * Options. + * @type {Object.|undefined} + */ + this.options = options; // toJSON + + /** + * Unique name within its namespace. + * @type {string} + */ + this.name = name; + + /** + * Parent namespace. + * @type {Namespace|null} + */ + this.parent = null; + + /** + * Whether already resolved or not. + * @type {boolean} + */ + this.resolved = false; + + /** + * Comment text, if any. + * @type {string|null} + */ + this.comment = null; + + /** + * Defining file name. + * @type {string|null} + */ + this.filename = null; +} + +Object.defineProperties(ReflectionObject.prototype, { + + /** + * Reference to the root namespace. + * @name ReflectionObject#root + * @type {Root} + * @readonly + */ + root: { + get: function() { + var ptr = this; + while (ptr.parent !== null) + ptr = ptr.parent; + return ptr; + } + }, + + /** + * Full name including leading dot. + * @name ReflectionObject#fullName + * @type {string} + * @readonly + */ + fullName: { + get: function() { + var path = [ this.name ], + ptr = this.parent; + while (ptr) { + path.unshift(ptr.name); + ptr = ptr.parent; + } + return path.join("."); + } + } +}); + +/** + * Converts this reflection object to its descriptor representation. + * @returns {Object.} Descriptor + * @abstract + */ +ReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() { + throw Error(); // not implemented, shouldn't happen +}; + +/** + * Called when this object is added to a parent. + * @param {ReflectionObject} parent Parent added to + * @returns {undefined} + */ +ReflectionObject.prototype.onAdd = function onAdd(parent) { + if (this.parent && this.parent !== parent) + this.parent.remove(this); + this.parent = parent; + this.resolved = false; + var root = parent.root; + if (root instanceof Root) + root._handleAdd(this); +}; + +/** + * Called when this object is removed from a parent. + * @param {ReflectionObject} parent Parent removed from + * @returns {undefined} + */ +ReflectionObject.prototype.onRemove = function onRemove(parent) { + var root = parent.root; + if (root instanceof Root) + root._handleRemove(this); + this.parent = null; + this.resolved = false; +}; + +/** + * Resolves this objects type references. + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.resolve = function resolve() { + if (this.resolved) + return this; + if (this.root instanceof Root) + this.resolved = true; // only if part of a root + return this; +}; + +/** + * Gets an option value. + * @param {string} name Option name + * @returns {*} Option value or `undefined` if not set + */ +ReflectionObject.prototype.getOption = function getOption(name) { + if (this.options) + return this.options[name]; + return undefined; +}; + +/** + * Sets an option. + * @param {string} name Option name + * @param {*} value Option value + * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) { + if (!ifNotSet || !this.options || this.options[name] === undefined) + (this.options || (this.options = {}))[name] = value; + return this; +}; + +/** + * Sets multiple options. + * @param {Object.} options Options to set + * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) { + if (options) + for (var keys = Object.keys(options), i = 0; i < keys.length; ++i) + this.setOption(keys[i], options[keys[i]], ifNotSet); + return this; +}; + +/** + * Converts this instance to its string representation. + * @returns {string} Class name[, space, full name] + */ +ReflectionObject.prototype.toString = function toString() { + var className = this.constructor.className, + fullName = this.fullName; + if (fullName.length) + return className + " " + fullName; + return className; +}; + +// Sets up cyclic dependencies (called in index-light) +ReflectionObject._configure = function(Root_) { + Root = Root_; +}; + +},{"37":37}],25:[function(require,module,exports){ +"use strict"; +module.exports = OneOf; + +// extends ReflectionObject +var ReflectionObject = require(24); +((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = "OneOf"; + +var Field = require(16), + util = require(37); + +/** + * Constructs a new oneof instance. + * @classdesc Reflected oneof. + * @extends ReflectionObject + * @constructor + * @param {string} name Oneof name + * @param {string[]|Object.} [fieldNames] Field names + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function OneOf(name, fieldNames, options, comment) { + if (!Array.isArray(fieldNames)) { + options = fieldNames; + fieldNames = undefined; + } + ReflectionObject.call(this, name, options); + + /* istanbul ignore if */ + if (!(fieldNames === undefined || Array.isArray(fieldNames))) + throw TypeError("fieldNames must be an Array"); + + /** + * Field names that belong to this oneof. + * @type {string[]} + */ + this.oneof = fieldNames || []; // toJSON, marker + + /** + * Fields that belong to this oneof as an array for iteration. + * @type {Field[]} + * @readonly + */ + this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Oneof descriptor. + * @interface IOneOf + * @property {Array.} oneof Oneof field names + * @property {Object.} [options] Oneof options + */ + +/** + * Constructs a oneof from a oneof descriptor. + * @param {string} name Oneof name + * @param {IOneOf} json Oneof descriptor + * @returns {OneOf} Created oneof + * @throws {TypeError} If arguments are invalid + */ +OneOf.fromJSON = function fromJSON(name, json) { + return new OneOf(name, json.oneof, json.options, json.comment); +}; + +/** + * Converts this oneof to a oneof descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IOneOf} Oneof descriptor + */ +OneOf.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "oneof" , this.oneof, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Adds the fields of the specified oneof to the parent if not already done so. + * @param {OneOf} oneof The oneof + * @returns {undefined} + * @inner + * @ignore + */ +function addFieldsToParent(oneof) { + if (oneof.parent) + for (var i = 0; i < oneof.fieldsArray.length; ++i) + if (!oneof.fieldsArray[i].parent) + oneof.parent.add(oneof.fieldsArray[i]); +} + +/** + * Adds a field to this oneof and removes it from its current parent, if any. + * @param {Field} field Field to add + * @returns {OneOf} `this` + */ +OneOf.prototype.add = function add(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + if (field.parent && field.parent !== this.parent) + field.parent.remove(field); + this.oneof.push(field.name); + this.fieldsArray.push(field); + field.partOf = this; // field.parent remains null + addFieldsToParent(this); + return this; +}; + +/** + * Removes a field from this oneof and puts it back to the oneof's parent. + * @param {Field} field Field to remove + * @returns {OneOf} `this` + */ +OneOf.prototype.remove = function remove(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + var index = this.fieldsArray.indexOf(field); + + /* istanbul ignore if */ + if (index < 0) + throw Error(field + " is not a member of " + this); + + this.fieldsArray.splice(index, 1); + index = this.oneof.indexOf(field.name); + + /* istanbul ignore else */ + if (index > -1) // theoretical + this.oneof.splice(index, 1); + + field.partOf = null; + return this; +}; + +/** + * @override + */ +OneOf.prototype.onAdd = function onAdd(parent) { + ReflectionObject.prototype.onAdd.call(this, parent); + var self = this; + // Collect present fields + for (var i = 0; i < this.oneof.length; ++i) { + var field = parent.get(this.oneof[i]); + if (field && !field.partOf) { + field.partOf = self; + self.fieldsArray.push(field); + } + } + // Add not yet present fields + addFieldsToParent(this); +}; + +/** + * @override + */ +OneOf.prototype.onRemove = function onRemove(parent) { + for (var i = 0, field; i < this.fieldsArray.length; ++i) + if ((field = this.fieldsArray[i]).parent) + field.parent.remove(field); + ReflectionObject.prototype.onRemove.call(this, parent); +}; + +/** + * Decorator function as returned by {@link OneOf.d} (TypeScript). + * @typedef OneOfDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} oneofName OneOf name + * @returns {undefined} + */ + +/** + * OneOf decorator (TypeScript). + * @function + * @param {...string} fieldNames Field names + * @returns {OneOfDecorator} Decorator function + * @template T extends string + */ +OneOf.d = function decorateOneOf() { + var fieldNames = new Array(arguments.length), + index = 0; + while (index < arguments.length) + fieldNames[index] = arguments[index++]; + return function oneOfDecorator(prototype, oneofName) { + util.decorateType(prototype.constructor) + .add(new OneOf(oneofName, fieldNames)); + Object.defineProperty(prototype, oneofName, { + get: util.oneOfGetter(fieldNames), + set: util.oneOfSetter(fieldNames) + }); + }; +}; + +},{"16":16,"24":24,"37":37}],26:[function(require,module,exports){ +"use strict"; +module.exports = parse; + +parse.filename = null; +parse.defaults = { keepCase: false }; + +var tokenize = require(34), + Root = require(29), + Type = require(35), + Field = require(16), + MapField = require(20), + OneOf = require(25), + Enum = require(15), + Service = require(33), + Method = require(22), + types = require(36), + util = require(37); + +var base10Re = /^[1-9][0-9]*$/, + base10NegRe = /^-?[1-9][0-9]*$/, + base16Re = /^0[x][0-9a-fA-F]+$/, + base16NegRe = /^-?0[x][0-9a-fA-F]+$/, + base8Re = /^0[0-7]+$/, + base8NegRe = /^-?0[0-7]+$/, + numberRe = /^(?![eE])[0-9]*(?:\.[0-9]*)?(?:[eE][+-]?[0-9]+)?$/, + nameRe = /^[a-zA-Z_][a-zA-Z_0-9]*$/, + typeRefRe = /^(?:\.?[a-zA-Z_][a-zA-Z_0-9]*)(?:\.[a-zA-Z_][a-zA-Z_0-9]*)*$/, + fqTypeRefRe = /^(?:\.[a-zA-Z_][a-zA-Z_0-9]*)+$/; + +/** + * Result object returned from {@link parse}. + * @interface IParserResult + * @property {string|undefined} package Package name, if declared + * @property {string[]|undefined} imports Imports, if any + * @property {string[]|undefined} weakImports Weak imports, if any + * @property {string|undefined} syntax Syntax, if specified (either `"proto2"` or `"proto3"`) + * @property {Root} root Populated root instance + */ + +/** + * Options modifying the behavior of {@link parse}. + * @interface IParseOptions + * @property {boolean} [keepCase=false] Keeps field casing instead of converting to camel case + * @property {boolean} [alternateCommentMode=false] Recognize double-slash comments in addition to doc-block comments. + */ + +/** + * Options modifying the behavior of JSON serialization. + * @interface IToJSONOptions + * @property {boolean} [keepComments=false] Serializes comments. + */ + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @param {string} source Source contents + * @param {Root} root Root to populate + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {IParserResult} Parser result + * @property {string} filename=null Currently processing file name for error reporting, if known + * @property {IParseOptions} defaults Default {@link IParseOptions} + */ +function parse(source, root, options) { + /* eslint-disable callback-return */ + if (!(root instanceof Root)) { + options = root; + root = new Root(); + } + if (!options) + options = parse.defaults; + + var tn = tokenize(source, options.alternateCommentMode || false), + next = tn.next, + push = tn.push, + peek = tn.peek, + skip = tn.skip, + cmnt = tn.cmnt; + + var head = true, + pkg, + imports, + weakImports, + syntax, + isProto3 = false; + + var ptr = root; + + var applyCase = options.keepCase ? function(name) { return name; } : util.camelCase; + + /* istanbul ignore next */ + function illegal(token, name, insideTryCatch) { + var filename = parse.filename; + if (!insideTryCatch) + parse.filename = null; + return Error("illegal " + (name || "token") + " '" + token + "' (" + (filename ? filename + ", " : "") + "line " + tn.line + ")"); + } + + function readString() { + var values = [], + token; + do { + /* istanbul ignore if */ + if ((token = next()) !== "\"" && token !== "'") + throw illegal(token); + + values.push(next()); + skip(token); + token = peek(); + } while (token === "\"" || token === "'"); + return values.join(""); + } + + function readValue(acceptTypeRef) { + var token = next(); + switch (token) { + case "'": + case "\"": + push(token); + return readString(); + case "true": case "TRUE": + return true; + case "false": case "FALSE": + return false; + } + try { + return parseNumber(token, /* insideTryCatch */ true); + } catch (e) { + + /* istanbul ignore else */ + if (acceptTypeRef && typeRefRe.test(token)) + return token; + + /* istanbul ignore next */ + throw illegal(token, "value"); + } + } + + function readRanges(target, acceptStrings) { + var token, start; + do { + if (acceptStrings && ((token = peek()) === "\"" || token === "'")) + target.push(readString()); + else + target.push([ start = parseId(next()), skip("to", true) ? parseId(next()) : start ]); + } while (skip(",", true)); + skip(";"); + } + + function parseNumber(token, insideTryCatch) { + var sign = 1; + if (token.charAt(0) === "-") { + sign = -1; + token = token.substring(1); + } + switch (token) { + case "inf": case "INF": case "Inf": + return sign * Infinity; + case "nan": case "NAN": case "Nan": case "NaN": + return NaN; + case "0": + return 0; + } + if (base10Re.test(token)) + return sign * parseInt(token, 10); + if (base16Re.test(token)) + return sign * parseInt(token, 16); + if (base8Re.test(token)) + return sign * parseInt(token, 8); + + /* istanbul ignore else */ + if (numberRe.test(token)) + return sign * parseFloat(token); + + /* istanbul ignore next */ + throw illegal(token, "number", insideTryCatch); + } + + function parseId(token, acceptNegative) { + switch (token) { + case "max": case "MAX": case "Max": + return 536870911; + case "0": + return 0; + } + + /* istanbul ignore if */ + if (!acceptNegative && token.charAt(0) === "-") + throw illegal(token, "id"); + + if (base10NegRe.test(token)) + return parseInt(token, 10); + if (base16NegRe.test(token)) + return parseInt(token, 16); + + /* istanbul ignore else */ + if (base8NegRe.test(token)) + return parseInt(token, 8); + + /* istanbul ignore next */ + throw illegal(token, "id"); + } + + function parsePackage() { + + /* istanbul ignore if */ + if (pkg !== undefined) + throw illegal("package"); + + pkg = next(); + + /* istanbul ignore if */ + if (!typeRefRe.test(pkg)) + throw illegal(pkg, "name"); + + ptr = ptr.define(pkg); + skip(";"); + } + + function parseImport() { + var token = peek(); + var whichImports; + switch (token) { + case "weak": + whichImports = weakImports || (weakImports = []); + next(); + break; + case "public": + next(); + // eslint-disable-line no-fallthrough + default: + whichImports = imports || (imports = []); + break; + } + token = readString(); + skip(";"); + whichImports.push(token); + } + + function parseSyntax() { + skip("="); + syntax = readString(); + isProto3 = syntax === "proto3"; + + /* istanbul ignore if */ + if (!isProto3 && syntax !== "proto2") + throw illegal(syntax, "syntax"); + + skip(";"); + } + + function parseCommon(parent, token) { + switch (token) { + + case "option": + parseOption(parent, token); + skip(";"); + return true; + + case "message": + parseType(parent, token); + return true; + + case "enum": + parseEnum(parent, token); + return true; + + case "service": + parseService(parent, token); + return true; + + case "extend": + parseExtension(parent, token); + return true; + } + return false; + } + + function ifBlock(obj, fnIf, fnElse) { + var trailingLine = tn.line; + if (obj) { + obj.comment = cmnt(); // try block-type comment + obj.filename = parse.filename; + } + if (skip("{", true)) { + var token; + while ((token = next()) !== "}") + fnIf(token); + skip(";", true); + } else { + if (fnElse) + fnElse(); + skip(";"); + if (obj && typeof obj.comment !== "string") + obj.comment = cmnt(trailingLine); // try line-type comment if no block + } + } + + function parseType(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "type name"); + + var type = new Type(token); + ifBlock(type, function parseType_block(token) { + if (parseCommon(type, token)) + return; + + switch (token) { + + case "map": + parseMapField(type, token); + break; + + case "required": + case "optional": + case "repeated": + parseField(type, token); + break; + + case "oneof": + parseOneOf(type, token); + break; + + case "extensions": + readRanges(type.extensions || (type.extensions = [])); + break; + + case "reserved": + readRanges(type.reserved || (type.reserved = []), true); + break; + + default: + /* istanbul ignore if */ + if (!isProto3 || !typeRefRe.test(token)) + throw illegal(token); + + push(token); + parseField(type, "optional"); + break; + } + }); + parent.add(type); + } + + function parseField(parent, rule, extend) { + var type = next(); + if (type === "group") { + parseGroup(parent, rule); + return; + } + + /* istanbul ignore if */ + if (!typeRefRe.test(type)) + throw illegal(type, "type"); + + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + name = applyCase(name); + skip("="); + + var field = new Field(name, parseId(next()), type, rule, extend); + ifBlock(field, function parseField_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(field, token); + skip(";"); + } else + throw illegal(token); + + }, function parseField_line() { + parseInlineOptions(field); + }); + parent.add(field); + + // JSON defaults to packed=true if not set so we have to set packed=false explicity when + // parsing proto2 descriptors without the option, where applicable. This must be done for + // all known packable types and anything that could be an enum (= is not a basic type). + if (!isProto3 && field.repeated && (types.packed[type] !== undefined || types.basic[type] === undefined)) + field.setOption("packed", false, /* ifNotSet */ true); + } + + function parseGroup(parent, rule) { + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + var fieldName = util.lcFirst(name); + if (name === fieldName) + name = util.ucFirst(name); + skip("="); + var id = parseId(next()); + var type = new Type(name); + type.group = true; + var field = new Field(fieldName, id, name, rule); + field.filename = parse.filename; + ifBlock(type, function parseGroup_block(token) { + switch (token) { + + case "option": + parseOption(type, token); + skip(";"); + break; + + case "required": + case "optional": + case "repeated": + parseField(type, token); + break; + + /* istanbul ignore next */ + default: + throw illegal(token); // there are no groups with proto3 semantics + } + }); + parent.add(type) + .add(field); + } + + function parseMapField(parent) { + skip("<"); + var keyType = next(); + + /* istanbul ignore if */ + if (types.mapKey[keyType] === undefined) + throw illegal(keyType, "type"); + + skip(","); + var valueType = next(); + + /* istanbul ignore if */ + if (!typeRefRe.test(valueType)) + throw illegal(valueType, "type"); + + skip(">"); + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + skip("="); + var field = new MapField(applyCase(name), parseId(next()), keyType, valueType); + ifBlock(field, function parseMapField_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(field, token); + skip(";"); + } else + throw illegal(token); + + }, function parseMapField_line() { + parseInlineOptions(field); + }); + parent.add(field); + } + + function parseOneOf(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var oneof = new OneOf(applyCase(token)); + ifBlock(oneof, function parseOneOf_block(token) { + if (token === "option") { + parseOption(oneof, token); + skip(";"); + } else { + push(token); + parseField(oneof, "optional"); + } + }); + parent.add(oneof); + } + + function parseEnum(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var enm = new Enum(token); + ifBlock(enm, function parseEnum_block(token) { + switch(token) { + case "option": + parseOption(enm, token); + skip(";"); + break; + + case "reserved": + readRanges(enm.reserved || (enm.reserved = []), true); + break; + + default: + parseEnumValue(enm, token); + } + }); + parent.add(enm); + } + + function parseEnumValue(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token)) + throw illegal(token, "name"); + + skip("="); + var value = parseId(next(), true), + dummy = {}; + ifBlock(dummy, function parseEnumValue_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(dummy, token); // skip + skip(";"); + } else + throw illegal(token); + + }, function parseEnumValue_line() { + parseInlineOptions(dummy); // skip + }); + parent.add(token, value, dummy.comment); + } + + function parseOption(parent, token) { + var isCustom = skip("(", true); + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token, "name"); + + var name = token; + if (isCustom) { + skip(")"); + name = "(" + name + ")"; + token = peek(); + if (fqTypeRefRe.test(token)) { + name += token; + next(); + } + } + skip("="); + parseOptionValue(parent, name); + } + + function parseOptionValue(parent, name) { + if (skip("{", true)) { // { a: "foo" b { c: "bar" } } + do { + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + if (peek() === "{") + parseOptionValue(parent, name + "." + token); + else { + skip(":"); + if (peek() === "{") + parseOptionValue(parent, name + "." + token); + else + setOption(parent, name + "." + token, readValue(true)); + } + skip(",", true); + } while (!skip("}", true)); + } else + setOption(parent, name, readValue(true)); + // Does not enforce a delimiter to be universal + } + + function setOption(parent, name, value) { + if (parent.setOption) + parent.setOption(name, value); + } + + function parseInlineOptions(parent) { + if (skip("[", true)) { + do { + parseOption(parent, "option"); + } while (skip(",", true)); + skip("]"); + } + return parent; + } + + function parseService(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "service name"); + + var service = new Service(token); + ifBlock(service, function parseService_block(token) { + if (parseCommon(service, token)) + return; + + /* istanbul ignore else */ + if (token === "rpc") + parseMethod(service, token); + else + throw illegal(token); + }); + parent.add(service); + } + + function parseMethod(parent, token) { + var type = token; + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var name = token, + requestType, requestStream, + responseType, responseStream; + + skip("("); + if (skip("stream", true)) + requestStream = true; + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token); + + requestType = token; + skip(")"); skip("returns"); skip("("); + if (skip("stream", true)) + responseStream = true; + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token); + + responseType = token; + skip(")"); + + var method = new Method(name, type, requestType, responseType, requestStream, responseStream); + ifBlock(method, function parseMethod_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(method, token); + skip(";"); + } else + throw illegal(token); + + }); + parent.add(method); + } + + function parseExtension(parent, token) { + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token, "reference"); + + var reference = token; + ifBlock(null, function parseExtension_block(token) { + switch (token) { + + case "required": + case "repeated": + case "optional": + parseField(parent, token, reference); + break; + + default: + /* istanbul ignore if */ + if (!isProto3 || !typeRefRe.test(token)) + throw illegal(token); + push(token); + parseField(parent, "optional", reference); + break; + } + }); + } + + var token; + while ((token = next()) !== null) { + switch (token) { + + case "package": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parsePackage(); + break; + + case "import": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseImport(); + break; + + case "syntax": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseSyntax(); + break; + + case "option": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseOption(ptr, token); + skip(";"); + break; + + default: + + /* istanbul ignore else */ + if (parseCommon(ptr, token)) { + head = false; + continue; + } + + /* istanbul ignore next */ + throw illegal(token); + } + } + + parse.filename = null; + return { + "package" : pkg, + "imports" : imports, + weakImports : weakImports, + syntax : syntax, + root : root + }; +} + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @name parse + * @function + * @param {string} source Source contents + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {IParserResult} Parser result + * @property {string} filename=null Currently processing file name for error reporting, if known + * @property {IParseOptions} defaults Default {@link IParseOptions} + * @variation 2 + */ + +},{"15":15,"16":16,"20":20,"22":22,"25":25,"29":29,"33":33,"34":34,"35":35,"36":36,"37":37}],27:[function(require,module,exports){ +"use strict"; +module.exports = Reader; + +var util = require(39); + +var BufferReader; // cyclic + +var LongBits = util.LongBits, + utf8 = util.utf8; + +/* istanbul ignore next */ +function indexOutOfRange(reader, writeLength) { + return RangeError("index out of range: " + reader.pos + " + " + (writeLength || 1) + " > " + reader.len); +} + +/** + * Constructs a new reader instance using the specified buffer. + * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`. + * @constructor + * @param {Uint8Array} buffer Buffer to read from + */ +function Reader(buffer) { + + /** + * Read buffer. + * @type {Uint8Array} + */ + this.buf = buffer; + + /** + * Read buffer position. + * @type {number} + */ + this.pos = 0; + + /** + * Read buffer length. + * @type {number} + */ + this.len = buffer.length; +} + +var create_array = typeof Uint8Array !== "undefined" + ? function create_typed_array(buffer) { + if (buffer instanceof Uint8Array || Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + } + /* istanbul ignore next */ + : function create_array(buffer) { + if (Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + }; + +/** + * Creates a new reader using the specified buffer. + * @function + * @param {Uint8Array|Buffer} buffer Buffer to read from + * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ +Reader.create = util.Buffer + ? function create_buffer_setup(buffer) { + return (Reader.create = function create_buffer(buffer) { + return util.Buffer.isBuffer(buffer) + ? new BufferReader(buffer) + /* istanbul ignore next */ + : create_array(buffer); + })(buffer); + } + /* istanbul ignore next */ + : create_array; + +Reader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice; + +/** + * Reads a varint as an unsigned 32 bit value. + * @function + * @returns {number} Value read + */ +Reader.prototype.uint32 = (function read_uint32_setup() { + var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!) + return function read_uint32() { + value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value; + + /* istanbul ignore if */ + if ((this.pos += 5) > this.len) { + this.pos = this.len; + throw indexOutOfRange(this, 10); + } + return value; + }; +})(); + +/** + * Reads a varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.int32 = function read_int32() { + return this.uint32() | 0; +}; + +/** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.sint32 = function read_sint32() { + var value = this.uint32(); + return value >>> 1 ^ -(value & 1) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readLongVarint() { + // tends to deopt with local vars for octet etc. + var bits = new LongBits(0, 0); + var i = 0; + if (this.len - this.pos > 4) { // fast route (lo) + for (; i < 4; ++i) { + // 1st..4th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 5th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0; + bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + i = 0; + } else { + for (; i < 3; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 1st..3th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 4th + bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0; + return bits; + } + if (this.len - this.pos > 4) { // fast route (hi) + for (; i < 5; ++i) { + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } else { + for (; i < 5; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } + /* istanbul ignore next */ + throw Error("invalid varint encoding"); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads a varint as a signed 64 bit value. + * @name Reader#int64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as an unsigned 64 bit value. + * @name Reader#uint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @name Reader#sint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as a boolean. + * @returns {boolean} Value read + */ +Reader.prototype.bool = function read_bool() { + return this.uint32() !== 0; +}; + +function readFixed32_end(buf, end) { // note that this uses `end`, not `pos` + return (buf[end - 4] + | buf[end - 3] << 8 + | buf[end - 2] << 16 + | buf[end - 1] << 24) >>> 0; +} + +/** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.fixed32 = function read_fixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4); +}; + +/** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.sfixed32 = function read_sfixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readFixed64(/* this: Reader */) { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 8); + + return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads fixed 64 bits. + * @name Reader#fixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads zig-zag encoded fixed 64 bits. + * @name Reader#sfixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a float (32 bit) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.float = function read_float() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readFloatLE(this.buf, this.pos); + this.pos += 4; + return value; +}; + +/** + * Reads a double (64 bit float) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.double = function read_double() { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readDoubleLE(this.buf, this.pos); + this.pos += 8; + return value; +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns {Uint8Array} Value read + */ +Reader.prototype.bytes = function read_bytes() { + var length = this.uint32(), + start = this.pos, + end = this.pos + length; + + /* istanbul ignore if */ + if (end > this.len) + throw indexOutOfRange(this, length); + + this.pos += length; + if (Array.isArray(this.buf)) // plain array + return this.buf.slice(start, end); + return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1 + ? new this.buf.constructor(0) + : this._slice.call(this.buf, start, end); +}; + +/** + * Reads a string preceeded by its byte length as a varint. + * @returns {string} Value read + */ +Reader.prototype.string = function read_string() { + var bytes = this.bytes(); + return utf8.read(bytes, 0, bytes.length); +}; + +/** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param {number} [length] Length if known, otherwise a varint is assumed + * @returns {Reader} `this` + */ +Reader.prototype.skip = function skip(length) { + if (typeof length === "number") { + /* istanbul ignore if */ + if (this.pos + length > this.len) + throw indexOutOfRange(this, length); + this.pos += length; + } else { + do { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + } while (this.buf[this.pos++] & 128); + } + return this; +}; + +/** + * Skips the next element of the specified wire type. + * @param {number} wireType Wire type received + * @returns {Reader} `this` + */ +Reader.prototype.skipType = function(wireType) { + switch (wireType) { + case 0: + this.skip(); + break; + case 1: + this.skip(8); + break; + case 2: + this.skip(this.uint32()); + break; + case 3: + while ((wireType = this.uint32() & 7) !== 4) { + this.skipType(wireType); + } + break; + case 5: + this.skip(4); + break; + + /* istanbul ignore next */ + default: + throw Error("invalid wire type " + wireType + " at offset " + this.pos); + } + return this; +}; + +Reader._configure = function(BufferReader_) { + BufferReader = BufferReader_; + + var fn = util.Long ? "toLong" : /* istanbul ignore next */ "toNumber"; + util.merge(Reader.prototype, { + + int64: function read_int64() { + return readLongVarint.call(this)[fn](false); + }, + + uint64: function read_uint64() { + return readLongVarint.call(this)[fn](true); + }, + + sint64: function read_sint64() { + return readLongVarint.call(this).zzDecode()[fn](false); + }, + + fixed64: function read_fixed64() { + return readFixed64.call(this)[fn](true); + }, + + sfixed64: function read_sfixed64() { + return readFixed64.call(this)[fn](false); + } + + }); +}; + +},{"39":39}],28:[function(require,module,exports){ +"use strict"; +module.exports = BufferReader; + +// extends Reader +var Reader = require(27); +(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader; + +var util = require(39); + +/** + * Constructs a new buffer reader instance. + * @classdesc Wire format reader using node buffers. + * @extends Reader + * @constructor + * @param {Buffer} buffer Buffer to read from + */ +function BufferReader(buffer) { + Reader.call(this, buffer); + + /** + * Read buffer. + * @name BufferReader#buf + * @type {Buffer} + */ +} + +/* istanbul ignore else */ +if (util.Buffer) + BufferReader.prototype._slice = util.Buffer.prototype.slice; + +/** + * @override + */ +BufferReader.prototype.string = function read_string_buffer() { + var len = this.uint32(); // modifies pos + return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len)); +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @name BufferReader#bytes + * @function + * @returns {Buffer} Value read + */ + +},{"27":27,"39":39}],29:[function(require,module,exports){ +"use strict"; +module.exports = Root; + +// extends Namespace +var Namespace = require(23); +((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = "Root"; + +var Field = require(16), + Enum = require(15), + OneOf = require(25), + util = require(37); + +var Type, // cyclic + parse, // might be excluded + common; // " + +/** + * Constructs a new root namespace instance. + * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together. + * @extends NamespaceBase + * @constructor + * @param {Object.} [options] Top level options + */ +function Root(options) { + Namespace.call(this, "", options); + + /** + * Deferred extension fields. + * @type {Field[]} + */ + this.deferred = []; + + /** + * Resolved file names of loaded files. + * @type {string[]} + */ + this.files = []; +} + +/** + * Loads a namespace descriptor into a root namespace. + * @param {INamespace} json Nameespace descriptor + * @param {Root} [root] Root namespace, defaults to create a new one if omitted + * @returns {Root} Root namespace + */ +Root.fromJSON = function fromJSON(json, root) { + if (!root) + root = new Root(); + if (json.options) + root.setOptions(json.options); + return root.addJSON(json.nested); +}; + +/** + * Resolves the path of an imported file, relative to the importing origin. + * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories. + * @function + * @param {string} origin The file name of the importing file + * @param {string} target The file name being imported + * @returns {string|null} Resolved path to `target` or `null` to skip the file + */ +Root.prototype.resolvePath = util.path.resolve; + +// A symbol-like function to safely signal synchronous loading +/* istanbul ignore next */ +function SYNC() {} // eslint-disable-line no-empty-function + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} options Parse options + * @param {LoadCallback} callback Callback function + * @returns {undefined} + */ +Root.prototype.load = function load(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = undefined; + } + var self = this; + if (!callback) + return util.asPromise(load, self, filename, options); + + var sync = callback === SYNC; // undocumented + + // Finishes loading by calling the callback (exactly once) + function finish(err, root) { + /* istanbul ignore if */ + if (!callback) + return; + var cb = callback; + callback = null; + if (sync) + throw err; + cb(err, root); + } + + // Processes a single file + function process(filename, source) { + try { + if (util.isString(source) && source.charAt(0) === "{") + source = JSON.parse(source); + if (!util.isString(source)) + self.setOptions(source.options).addJSON(source.nested); + else { + parse.filename = filename; + var parsed = parse(source, self, options), + resolved, + i = 0; + if (parsed.imports) + for (; i < parsed.imports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.imports[i])) + fetch(resolved); + if (parsed.weakImports) + for (i = 0; i < parsed.weakImports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.weakImports[i])) + fetch(resolved, true); + } + } catch (err) { + finish(err); + } + if (!sync && !queued) + finish(null, self); // only once anyway + } + + // Fetches a single file + function fetch(filename, weak) { + + // Strip path if this file references a bundled definition + var idx = filename.lastIndexOf("google/protobuf/"); + if (idx > -1) { + var altname = filename.substring(idx); + if (altname in common) + filename = altname; + } + + // Skip if already loaded / attempted + if (self.files.indexOf(filename) > -1) + return; + self.files.push(filename); + + // Shortcut bundled definitions + if (filename in common) { + if (sync) + process(filename, common[filename]); + else { + ++queued; + setTimeout(function() { + --queued; + process(filename, common[filename]); + }); + } + return; + } + + // Otherwise fetch from disk or network + if (sync) { + var source; + try { + source = util.fs.readFileSync(filename).toString("utf8"); + } catch (err) { + if (!weak) + finish(err); + return; + } + process(filename, source); + } else { + ++queued; + util.fetch(filename, function(err, source) { + --queued; + /* istanbul ignore if */ + if (!callback) + return; // terminated meanwhile + if (err) { + /* istanbul ignore else */ + if (!weak) + finish(err); + else if (!queued) // can't be covered reliably + finish(null, self); + return; + } + process(filename, source); + }); + } + } + var queued = 0; + + // Assembling the root namespace doesn't require working type + // references anymore, so we can load everything in parallel + if (util.isString(filename)) + filename = [ filename ]; + for (var i = 0, resolved; i < filename.length; ++i) + if (resolved = self.resolvePath("", filename[i])) + fetch(resolved); + + if (sync) + return self; + if (!queued) + finish(null, self); + return undefined; +}; +// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Promise} Promise + * @variation 3 + */ +// function load(filename:string, [options:IParseOptions]):Promise + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only). + * @function Root#loadSync + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + */ +Root.prototype.loadSync = function loadSync(filename, options) { + if (!util.isNode) + throw Error("not supported"); + return this.load(filename, options, SYNC); +}; + +/** + * @override + */ +Root.prototype.resolveAll = function resolveAll() { + if (this.deferred.length) + throw Error("unresolvable extensions: " + this.deferred.map(function(field) { + return "'extend " + field.extend + "' in " + field.parent.fullName; + }).join(", ")); + return Namespace.prototype.resolveAll.call(this); +}; + +// only uppercased (and thus conflict-free) children are exposed, see below +var exposeRe = /^[A-Z]/; + +/** + * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type. + * @param {Root} root Root instance + * @param {Field} field Declaring extension field witin the declaring type + * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise + * @inner + * @ignore + */ +function tryHandleExtension(root, field) { + var extendedType = field.parent.lookup(field.extend); + if (extendedType) { + var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options); + sisterField.declaringField = field; + field.extensionField = sisterField; + extendedType.add(sisterField); + return true; + } + return false; +} + +/** + * Called when any object is added to this root or its sub-namespaces. + * @param {ReflectionObject} object Object added + * @returns {undefined} + * @private + */ +Root.prototype._handleAdd = function _handleAdd(object) { + if (object instanceof Field) { + + if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField) + if (!tryHandleExtension(this, object)) + this.deferred.push(object); + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + object.parent[object.name] = object.values; // expose enum values as property of its parent + + } else if (!(object instanceof OneOf)) /* everything else is a namespace */ { + + if (object instanceof Type) // Try to handle any deferred extensions + for (var i = 0; i < this.deferred.length;) + if (tryHandleExtension(this, this.deferred[i])) + this.deferred.splice(i, 1); + else + ++i; + for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace + this._handleAdd(object._nestedArray[j]); + if (exposeRe.test(object.name)) + object.parent[object.name] = object; // expose namespace as property of its parent + } + + // The above also adds uppercased (and thus conflict-free) nested types, services and enums as + // properties of namespaces just like static code does. This allows using a .d.ts generated for + // a static module with reflection-based solutions where the condition is met. +}; + +/** + * Called when any object is removed from this root or its sub-namespaces. + * @param {ReflectionObject} object Object removed + * @returns {undefined} + * @private + */ +Root.prototype._handleRemove = function _handleRemove(object) { + if (object instanceof Field) { + + if (/* an extension field */ object.extend !== undefined) { + if (/* already handled */ object.extensionField) { // remove its sister field + object.extensionField.parent.remove(object.extensionField); + object.extensionField = null; + } else { // cancel the extension + var index = this.deferred.indexOf(object); + /* istanbul ignore else */ + if (index > -1) + this.deferred.splice(index, 1); + } + } + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose enum values + + } else if (object instanceof Namespace) { + + for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace + this._handleRemove(object._nestedArray[i]); + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose namespaces + + } +}; + +// Sets up cyclic dependencies (called in index-light) +Root._configure = function(Type_, parse_, common_) { + Type = Type_; + parse = parse_; + common = common_; +}; + +},{"15":15,"16":16,"23":23,"25":25,"37":37}],30:[function(require,module,exports){ +"use strict"; +module.exports = {}; + +/** + * Named roots. + * This is where pbjs stores generated structures (the option `-r, --root` specifies a name). + * Can also be used manually to make roots available accross modules. + * @name roots + * @type {Object.} + * @example + * // pbjs -r myroot -o compiled.js ... + * + * // in another module: + * require("./compiled.js"); + * + * // in any subsequent module: + * var root = protobuf.roots["myroot"]; + */ + +},{}],31:[function(require,module,exports){ +"use strict"; + +/** + * Streaming RPC helpers. + * @namespace + */ +var rpc = exports; + +/** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @typedef RPCImpl + * @type {function} + * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called + * @param {Uint8Array} requestData Request data + * @param {RPCImplCallback} callback Callback function + * @returns {undefined} + * @example + * function rpcImpl(method, requestData, callback) { + * if (protobuf.util.lcFirst(method.name) !== "myMethod") // compatible with static code + * throw Error("no such method"); + * asynchronouslyObtainAResponse(requestData, function(err, responseData) { + * callback(err, responseData); + * }); + * } + */ + +/** + * Node-style callback as used by {@link RPCImpl}. + * @typedef RPCImplCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error + * @returns {undefined} + */ + +rpc.Service = require(32); + +},{"32":32}],32:[function(require,module,exports){ +"use strict"; +module.exports = Service; + +var util = require(39); + +// Extends EventEmitter +(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service; + +/** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @typedef rpc.ServiceMethodCallback + * @template TRes extends Message + * @type {function} + * @param {Error|null} error Error, if any + * @param {TRes} [response] Response message + * @returns {undefined} + */ + +/** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @typedef rpc.ServiceMethod + * @template TReq extends Message + * @template TRes extends Message + * @type {function} + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message + * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined` + */ + +/** + * Constructs a new RPC service instance. + * @classdesc An RPC service as returned by {@link Service#create}. + * @exports rpc.Service + * @extends util.EventEmitter + * @constructor + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ +function Service(rpcImpl, requestDelimited, responseDelimited) { + + if (typeof rpcImpl !== "function") + throw TypeError("rpcImpl must be a function"); + + util.EventEmitter.call(this); + + /** + * RPC implementation. Becomes `null` once the service is ended. + * @type {RPCImpl|null} + */ + this.rpcImpl = rpcImpl; + + /** + * Whether requests are length-delimited. + * @type {boolean} + */ + this.requestDelimited = Boolean(requestDelimited); + + /** + * Whether responses are length-delimited. + * @type {boolean} + */ + this.responseDelimited = Boolean(responseDelimited); +} + +/** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param {Method|rpc.ServiceMethod} method Reflected or static method + * @param {Constructor} requestCtor Request constructor + * @param {Constructor} responseCtor Response constructor + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} callback Service callback + * @returns {undefined} + * @template TReq extends Message + * @template TRes extends Message + */ +Service.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) { + + if (!request) + throw TypeError("request must be specified"); + + var self = this; + if (!callback) + return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request); + + if (!self.rpcImpl) { + setTimeout(function() { callback(Error("already ended")); }, 0); + return undefined; + } + + try { + return self.rpcImpl( + method, + requestCtor[self.requestDelimited ? "encodeDelimited" : "encode"](request).finish(), + function rpcCallback(err, response) { + + if (err) { + self.emit("error", err, method); + return callback(err); + } + + if (response === null) { + self.end(/* endedByRPC */ true); + return undefined; + } + + if (!(response instanceof responseCtor)) { + try { + response = responseCtor[self.responseDelimited ? "decodeDelimited" : "decode"](response); + } catch (err) { + self.emit("error", err, method); + return callback(err); + } + } + + self.emit("data", response, method); + return callback(null, response); + } + ); + } catch (err) { + self.emit("error", err, method); + setTimeout(function() { callback(err); }, 0); + return undefined; + } +}; + +/** + * Ends this service and emits the `end` event. + * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns {rpc.Service} `this` + */ +Service.prototype.end = function end(endedByRPC) { + if (this.rpcImpl) { + if (!endedByRPC) // signal end to rpcImpl + this.rpcImpl(null, null, null); + this.rpcImpl = null; + this.emit("end").off(); + } + return this; +}; + +},{"39":39}],33:[function(require,module,exports){ +"use strict"; +module.exports = Service; + +// extends Namespace +var Namespace = require(23); +((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = "Service"; + +var Method = require(22), + util = require(37), + rpc = require(31); + +/** + * Constructs a new service instance. + * @classdesc Reflected service. + * @extends NamespaceBase + * @constructor + * @param {string} name Service name + * @param {Object.} [options] Service options + * @throws {TypeError} If arguments are invalid + */ +function Service(name, options) { + Namespace.call(this, name, options); + + /** + * Service methods. + * @type {Object.} + */ + this.methods = {}; // toJSON, marker + + /** + * Cached methods as an array. + * @type {Method[]|null} + * @private + */ + this._methodsArray = null; +} + +/** + * Service descriptor. + * @interface IService + * @extends INamespace + * @property {Object.} methods Method descriptors + */ + +/** + * Constructs a service from a service descriptor. + * @param {string} name Service name + * @param {IService} json Service descriptor + * @returns {Service} Created service + * @throws {TypeError} If arguments are invalid + */ +Service.fromJSON = function fromJSON(name, json) { + var service = new Service(name, json.options); + /* istanbul ignore else */ + if (json.methods) + for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i) + service.add(Method.fromJSON(names[i], json.methods[names[i]])); + if (json.nested) + service.addJSON(json.nested); + service.comment = json.comment; + return service; +}; + +/** + * Converts this service to a service descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IService} Service descriptor + */ +Service.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "methods" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {}, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Methods of this service as an array for iteration. + * @name Service#methodsArray + * @type {Method[]} + * @readonly + */ +Object.defineProperty(Service.prototype, "methodsArray", { + get: function() { + return this._methodsArray || (this._methodsArray = util.toArray(this.methods)); + } +}); + +function clearCache(service) { + service._methodsArray = null; + return service; +} + +/** + * @override + */ +Service.prototype.get = function get(name) { + return this.methods[name] + || Namespace.prototype.get.call(this, name); +}; + +/** + * @override + */ +Service.prototype.resolveAll = function resolveAll() { + var methods = this.methodsArray; + for (var i = 0; i < methods.length; ++i) + methods[i].resolve(); + return Namespace.prototype.resolve.call(this); +}; + +/** + * @override + */ +Service.prototype.add = function add(object) { + + /* istanbul ignore if */ + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Method) { + this.methods[object.name] = object; + object.parent = this; + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * @override + */ +Service.prototype.remove = function remove(object) { + if (object instanceof Method) { + + /* istanbul ignore if */ + if (this.methods[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.methods[object.name]; + object.parent = null; + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Creates a runtime service using the specified rpc implementation. + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed. + */ +Service.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) { + var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited); + for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) { + var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\w_]/g, ""); + rpcService[methodName] = util.codegen(["r","c"], util.isReserved(methodName) ? methodName + "_" : methodName)("return this.rpcCall(m,q,s,r,c)")({ + m: method, + q: method.resolvedRequestType.ctor, + s: method.resolvedResponseType.ctor + }); + } + return rpcService; +}; + +},{"22":22,"23":23,"31":31,"37":37}],34:[function(require,module,exports){ +"use strict"; +module.exports = tokenize; + +var delimRe = /[\s{}=;:[\],'"()<>]/g, + stringDoubleRe = /(?:"([^"\\]*(?:\\.[^"\\]*)*)")/g, + stringSingleRe = /(?:'([^'\\]*(?:\\.[^'\\]*)*)')/g; + +var setCommentRe = /^ *[*/]+ */, + setCommentAltRe = /^\s*\*?\/*/, + setCommentSplitRe = /\n/g, + whitespaceRe = /\s/, + unescapeRe = /\\(.?)/g; + +var unescapeMap = { + "0": "\0", + "r": "\r", + "n": "\n", + "t": "\t" +}; + +/** + * Unescapes a string. + * @param {string} str String to unescape + * @returns {string} Unescaped string + * @property {Object.} map Special characters map + * @memberof tokenize + */ +function unescape(str) { + return str.replace(unescapeRe, function($0, $1) { + switch ($1) { + case "\\": + case "": + return $1; + default: + return unescapeMap[$1] || ""; + } + }); +} + +tokenize.unescape = unescape; + +/** + * Gets the next token and advances. + * @typedef TokenizerHandleNext + * @type {function} + * @returns {string|null} Next token or `null` on eof + */ + +/** + * Peeks for the next token. + * @typedef TokenizerHandlePeek + * @type {function} + * @returns {string|null} Next token or `null` on eof + */ + +/** + * Pushes a token back to the stack. + * @typedef TokenizerHandlePush + * @type {function} + * @param {string} token Token + * @returns {undefined} + */ + +/** + * Skips the next token. + * @typedef TokenizerHandleSkip + * @type {function} + * @param {string} expected Expected token + * @param {boolean} [optional=false] If optional + * @returns {boolean} Whether the token matched + * @throws {Error} If the token didn't match and is not optional + */ + +/** + * Gets the comment on the previous line or, alternatively, the line comment on the specified line. + * @typedef TokenizerHandleCmnt + * @type {function} + * @param {number} [line] Line number + * @returns {string|null} Comment text or `null` if none + */ + +/** + * Handle object returned from {@link tokenize}. + * @interface ITokenizerHandle + * @property {TokenizerHandleNext} next Gets the next token and advances (`null` on eof) + * @property {TokenizerHandlePeek} peek Peeks for the next token (`null` on eof) + * @property {TokenizerHandlePush} push Pushes a token back to the stack + * @property {TokenizerHandleSkip} skip Skips a token, returns its presence and advances or, if non-optional and not present, throws + * @property {TokenizerHandleCmnt} cmnt Gets the comment on the previous line or the line comment on the specified line, if any + * @property {number} line Current line number + */ + +/** + * Tokenizes the given .proto source and returns an object with useful utility functions. + * @param {string} source Source contents + * @param {boolean} alternateCommentMode Whether we should activate alternate comment parsing mode. + * @returns {ITokenizerHandle} Tokenizer handle + */ +function tokenize(source, alternateCommentMode) { + /* eslint-disable callback-return */ + source = source.toString(); + + var offset = 0, + length = source.length, + line = 1, + commentType = null, + commentText = null, + commentLine = 0, + commentLineEmpty = false; + + var stack = []; + + var stringDelim = null; + + /* istanbul ignore next */ + /** + * Creates an error for illegal syntax. + * @param {string} subject Subject + * @returns {Error} Error created + * @inner + */ + function illegal(subject) { + return Error("illegal " + subject + " (line " + line + ")"); + } + + /** + * Reads a string till its end. + * @returns {string} String read + * @inner + */ + function readString() { + var re = stringDelim === "'" ? stringSingleRe : stringDoubleRe; + re.lastIndex = offset - 1; + var match = re.exec(source); + if (!match) + throw illegal("string"); + offset = re.lastIndex; + push(stringDelim); + stringDelim = null; + return unescape(match[1]); + } + + /** + * Gets the character at `pos` within the source. + * @param {number} pos Position + * @returns {string} Character + * @inner + */ + function charAt(pos) { + return source.charAt(pos); + } + + /** + * Sets the current comment text. + * @param {number} start Start offset + * @param {number} end End offset + * @returns {undefined} + * @inner + */ + function setComment(start, end) { + commentType = source.charAt(start++); + commentLine = line; + commentLineEmpty = false; + var lookback; + if (alternateCommentMode) { + lookback = 2; // alternate comment parsing: "//" or "/*" + } else { + lookback = 3; // "///" or "/**" + } + var commentOffset = start - lookback, + c; + do { + if (--commentOffset < 0 || + (c = source.charAt(commentOffset)) === "\n") { + commentLineEmpty = true; + break; + } + } while (c === " " || c === "\t"); + var lines = source + .substring(start, end) + .split(setCommentSplitRe); + for (var i = 0; i < lines.length; ++i) + lines[i] = lines[i] + .replace(alternateCommentMode ? setCommentAltRe : setCommentRe, "") + .trim(); + commentText = lines + .join("\n") + .trim(); + } + + function isDoubleSlashCommentLine(startOffset) { + var endOffset = findEndOfLine(startOffset); + + // see if remaining line matches comment pattern + var lineText = source.substring(startOffset, endOffset); + // look for 1 or 2 slashes since startOffset would already point past + // the first slash that started the comment. + var isComment = /^\s*\/{1,2}/.test(lineText); + return isComment; + } + + function findEndOfLine(cursor) { + // find end of cursor's line + var endOffset = cursor; + while (endOffset < length && charAt(endOffset) !== "\n") { + endOffset++; + } + return endOffset; + } + + /** + * Obtains the next token. + * @returns {string|null} Next token or `null` on eof + * @inner + */ + function next() { + if (stack.length > 0) + return stack.shift(); + if (stringDelim) + return readString(); + var repeat, + prev, + curr, + start, + isDoc; + do { + if (offset === length) + return null; + repeat = false; + while (whitespaceRe.test(curr = charAt(offset))) { + if (curr === "\n") + ++line; + if (++offset === length) + return null; + } + + if (charAt(offset) === "/") { + if (++offset === length) { + throw illegal("comment"); + } + if (charAt(offset) === "/") { // Line + if (!alternateCommentMode) { + // check for triple-slash comment + isDoc = charAt(start = offset + 1) === "/"; + + while (charAt(++offset) !== "\n") { + if (offset === length) { + return null; + } + } + ++offset; + if (isDoc) { + setComment(start, offset - 1); + } + ++line; + repeat = true; + } else { + // check for double-slash comments, consolidating consecutive lines + start = offset; + isDoc = false; + if (isDoubleSlashCommentLine(offset)) { + isDoc = true; + do { + offset = findEndOfLine(offset); + if (offset === length) { + break; + } + offset++; + } while (isDoubleSlashCommentLine(offset)); + } else { + offset = Math.min(length, findEndOfLine(offset) + 1); + } + if (isDoc) { + setComment(start, offset); + } + line++; + repeat = true; + } + } else if ((curr = charAt(offset)) === "*") { /* Block */ + // check for /** (regular comment mode) or /* (alternate comment mode) + start = offset + 1; + isDoc = alternateCommentMode || charAt(start) === "*"; + do { + if (curr === "\n") { + ++line; + } + if (++offset === length) { + throw illegal("comment"); + } + prev = curr; + curr = charAt(offset); + } while (prev !== "*" || curr !== "/"); + ++offset; + if (isDoc) { + setComment(start, offset - 2); + } + repeat = true; + } else { + return "/"; + } + } + } while (repeat); + + // offset !== length if we got here + + var end = offset; + delimRe.lastIndex = 0; + var delim = delimRe.test(charAt(end++)); + if (!delim) + while (end < length && !delimRe.test(charAt(end))) + ++end; + var token = source.substring(offset, offset = end); + if (token === "\"" || token === "'") + stringDelim = token; + return token; + } + + /** + * Pushes a token back to the stack. + * @param {string} token Token + * @returns {undefined} + * @inner + */ + function push(token) { + stack.push(token); + } + + /** + * Peeks for the next token. + * @returns {string|null} Token or `null` on eof + * @inner + */ + function peek() { + if (!stack.length) { + var token = next(); + if (token === null) + return null; + push(token); + } + return stack[0]; + } + + /** + * Skips a token. + * @param {string} expected Expected token + * @param {boolean} [optional=false] Whether the token is optional + * @returns {boolean} `true` when skipped, `false` if not + * @throws {Error} When a required token is not present + * @inner + */ + function skip(expected, optional) { + var actual = peek(), + equals = actual === expected; + if (equals) { + next(); + return true; + } + if (!optional) + throw illegal("token '" + actual + "', '" + expected + "' expected"); + return false; + } + + /** + * Gets a comment. + * @param {number} [trailingLine] Line number if looking for a trailing comment + * @returns {string|null} Comment text + * @inner + */ + function cmnt(trailingLine) { + var ret = null; + if (trailingLine === undefined) { + if (commentLine === line - 1 && (alternateCommentMode || commentType === "*" || commentLineEmpty)) { + ret = commentText; + } + } else { + /* istanbul ignore else */ + if (commentLine < trailingLine) { + peek(); + } + if (commentLine === trailingLine && !commentLineEmpty && (alternateCommentMode || commentType === "/")) { + ret = commentText; + } + } + return ret; + } + + return Object.defineProperty({ + next: next, + peek: peek, + push: push, + skip: skip, + cmnt: cmnt + }, "line", { + get: function() { return line; } + }); + /* eslint-enable callback-return */ +} + +},{}],35:[function(require,module,exports){ +"use strict"; +module.exports = Type; + +// extends Namespace +var Namespace = require(23); +((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = "Type"; + +var Enum = require(15), + OneOf = require(25), + Field = require(16), + MapField = require(20), + Service = require(33), + Message = require(21), + Reader = require(27), + Writer = require(42), + util = require(37), + encoder = require(14), + decoder = require(13), + verifier = require(40), + converter = require(12), + wrappers = require(41); + +/** + * Constructs a new reflected message type instance. + * @classdesc Reflected message type. + * @extends NamespaceBase + * @constructor + * @param {string} name Message name + * @param {Object.} [options] Declared options + */ +function Type(name, options) { + Namespace.call(this, name, options); + + /** + * Message fields. + * @type {Object.} + */ + this.fields = {}; // toJSON, marker + + /** + * Oneofs declared within this namespace, if any. + * @type {Object.} + */ + this.oneofs = undefined; // toJSON + + /** + * Extension ranges, if any. + * @type {number[][]} + */ + this.extensions = undefined; // toJSON + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + /*? + * Whether this type is a legacy group. + * @type {boolean|undefined} + */ + this.group = undefined; // toJSON + + /** + * Cached fields by id. + * @type {Object.|null} + * @private + */ + this._fieldsById = null; + + /** + * Cached fields as an array. + * @type {Field[]|null} + * @private + */ + this._fieldsArray = null; + + /** + * Cached oneofs as an array. + * @type {OneOf[]|null} + * @private + */ + this._oneofsArray = null; + + /** + * Cached constructor. + * @type {Constructor<{}>} + * @private + */ + this._ctor = null; +} + +Object.defineProperties(Type.prototype, { + + /** + * Message fields by id. + * @name Type#fieldsById + * @type {Object.} + * @readonly + */ + fieldsById: { + get: function() { + + /* istanbul ignore if */ + if (this._fieldsById) + return this._fieldsById; + + this._fieldsById = {}; + for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) { + var field = this.fields[names[i]], + id = field.id; + + /* istanbul ignore if */ + if (this._fieldsById[id]) + throw Error("duplicate id " + id + " in " + this); + + this._fieldsById[id] = field; + } + return this._fieldsById; + } + }, + + /** + * Fields of this message as an array for iteration. + * @name Type#fieldsArray + * @type {Field[]} + * @readonly + */ + fieldsArray: { + get: function() { + return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields)); + } + }, + + /** + * Oneofs of this message as an array for iteration. + * @name Type#oneofsArray + * @type {OneOf[]} + * @readonly + */ + oneofsArray: { + get: function() { + return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs)); + } + }, + + /** + * The registered constructor, if any registered, otherwise a generic constructor. + * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor. + * @name Type#ctor + * @type {Constructor<{}>} + */ + ctor: { + get: function() { + return this._ctor || (this.ctor = Type.generateConstructor(this)()); + }, + set: function(ctor) { + + // Ensure proper prototype + var prototype = ctor.prototype; + if (!(prototype instanceof Message)) { + (ctor.prototype = new Message()).constructor = ctor; + util.merge(ctor.prototype, prototype); + } + + // Classes and messages reference their reflected type + ctor.$type = ctor.prototype.$type = this; + + // Mix in static methods + util.merge(ctor, Message, true); + + this._ctor = ctor; + + // Messages have non-enumerable default values on their prototype + var i = 0; + for (; i < /* initializes */ this.fieldsArray.length; ++i) + this._fieldsArray[i].resolve(); // ensures a proper value + + // Messages have non-enumerable getters and setters for each virtual oneof field + var ctorProperties = {}; + for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i) + ctorProperties[this._oneofsArray[i].resolve().name] = { + get: util.oneOfGetter(this._oneofsArray[i].oneof), + set: util.oneOfSetter(this._oneofsArray[i].oneof) + }; + if (i) + Object.defineProperties(ctor.prototype, ctorProperties); + } + } +}); + +/** + * Generates a constructor function for the specified type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +Type.generateConstructor = function generateConstructor(mtype) { + /* eslint-disable no-unexpected-multiline */ + var gen = util.codegen(["p"], mtype.name); + // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype + for (var i = 0, field; i < mtype.fieldsArray.length; ++i) + if ((field = mtype._fieldsArray[i]).map) gen + ("this%s={}", util.safeProp(field.name)); + else if (field.repeated) gen + ("this%s=[]", util.safeProp(field.name)); + return gen + ("if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors + * @property {Object.} fields Field descriptors + * @property {number[][]} [extensions] Extension ranges + * @property {number[][]} [reserved] Reserved ranges + * @property {boolean} [group=false] Whether a legacy group or not + */ + +/** + * Creates a message type from a message type descriptor. + * @param {string} name Message name + * @param {IType} json Message type descriptor + * @returns {Type} Created message type + */ +Type.fromJSON = function fromJSON(name, json) { + var type = new Type(name, json.options); + type.extensions = json.extensions; + type.reserved = json.reserved; + var names = Object.keys(json.fields), + i = 0; + for (; i < names.length; ++i) + type.add( + ( typeof json.fields[names[i]].keyType !== "undefined" + ? MapField.fromJSON + : Field.fromJSON )(names[i], json.fields[names[i]]) + ); + if (json.oneofs) + for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i) + type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]])); + if (json.nested) + for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) { + var nested = json.nested[names[i]]; + type.add( // most to least likely + ( nested.id !== undefined + ? Field.fromJSON + : nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + if (json.extensions && json.extensions.length) + type.extensions = json.extensions; + if (json.reserved && json.reserved.length) + type.reserved = json.reserved; + if (json.group) + type.group = true; + if (json.comment) + type.comment = json.comment; + return type; +}; + +/** + * Converts this message type to a message type descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IType} Message type descriptor + */ +Type.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "oneofs" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions), + "fields" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {}, + "extensions" , this.extensions && this.extensions.length ? this.extensions : undefined, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "group" , this.group || undefined, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Type.prototype.resolveAll = function resolveAll() { + var fields = this.fieldsArray, i = 0; + while (i < fields.length) + fields[i++].resolve(); + var oneofs = this.oneofsArray; i = 0; + while (i < oneofs.length) + oneofs[i++].resolve(); + return Namespace.prototype.resolveAll.call(this); +}; + +/** + * @override + */ +Type.prototype.get = function get(name) { + return this.fields[name] + || this.oneofs && this.oneofs[name] + || this.nested && this.nested[name] + || null; +}; + +/** + * Adds a nested object to this type. + * @param {ReflectionObject} object Nested object to add + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id + */ +Type.prototype.add = function add(object) { + + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Field && object.extend === undefined) { + // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects. + // The root object takes care of adding distinct sister-fields to the respective extended + // type instead. + + // avoids calling the getter if not absolutely necessary because it's called quite frequently + if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id]) + throw Error("duplicate id " + object.id + " in " + this); + if (this.isReservedId(object.id)) + throw Error("id " + object.id + " is reserved in " + this); + if (this.isReservedName(object.name)) + throw Error("name '" + object.name + "' is reserved in " + this); + + if (object.parent) + object.parent.remove(object); + this.fields[object.name] = object; + object.message = this; + object.onAdd(this); + return clearCache(this); + } + if (object instanceof OneOf) { + if (!this.oneofs) + this.oneofs = {}; + this.oneofs[object.name] = object; + object.onAdd(this); + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * Removes a nested object from this type. + * @param {ReflectionObject} object Nested object to remove + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this type + */ +Type.prototype.remove = function remove(object) { + if (object instanceof Field && object.extend === undefined) { + // See Type#add for the reason why extension fields are excluded here. + + /* istanbul ignore if */ + if (!this.fields || this.fields[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.fields[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + if (object instanceof OneOf) { + + /* istanbul ignore if */ + if (!this.oneofs || this.oneofs[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.oneofs[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message<{}>} Message instance + */ +Type.prototype.create = function create(properties) { + return new this.ctor(properties); +}; + +/** + * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}. + * @returns {Type} `this` + */ +Type.prototype.setup = function setup() { + // Sets up everything at once so that the prototype chain does not have to be re-evaluated + // multiple times (V8, soft-deopt prototype-check). + + var fullName = this.fullName, + types = []; + for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i) + types.push(this._fieldsArray[i].resolve().resolvedType); + + // Replace setup methods with type-specific generated functions + this.encode = encoder(this)({ + Writer : Writer, + types : types, + util : util + }); + this.decode = decoder(this)({ + Reader : Reader, + types : types, + util : util + }); + this.verify = verifier(this)({ + types : types, + util : util + }); + this.fromObject = converter.fromObject(this)({ + types : types, + util : util + }); + this.toObject = converter.toObject(this)({ + types : types, + util : util + }); + + // Inject custom wrappers for common types + var wrapper = wrappers[fullName]; + if (wrapper) { + var originalThis = Object.create(this); + // if (wrapper.fromObject) { + originalThis.fromObject = this.fromObject; + this.fromObject = wrapper.fromObject.bind(originalThis); + // } + // if (wrapper.toObject) { + originalThis.toObject = this.toObject; + this.toObject = wrapper.toObject.bind(originalThis); + // } + } + + return this; +}; + +/** + * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encode = function encode_setup(message, writer) { + return this.setup().encode(message, writer); // overrides this method +}; + +/** + * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim(); +}; + +/** + * Decodes a message of this type. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Length of the message, if known beforehand + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError<{}>} If required fields are missing + */ +Type.prototype.decode = function decode_setup(reader, length) { + return this.setup().decode(reader, length); // overrides this method +}; + +/** + * Decodes a message of this type preceeded by its byte length as a varint. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError} If required fields are missing + */ +Type.prototype.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof Reader)) + reader = Reader.create(reader); + return this.decode(reader, reader.uint32()); +}; + +/** + * Verifies that field values are valid and that required fields are present. + * @param {Object.} message Plain object to verify + * @returns {null|string} `null` if valid, otherwise the reason why it is not + */ +Type.prototype.verify = function verify_setup(message) { + return this.setup().verify(message); // overrides this method +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object to convert + * @returns {Message<{}>} Message instance + */ +Type.prototype.fromObject = function fromObject(object) { + return this.setup().fromObject(object); +}; + +/** + * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}. + * @interface IConversionOptions + * @property {Function} [longs] Long conversion type. + * Valid values are `String` and `Number` (the global types). + * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library. + * @property {Function} [enums] Enum value conversion type. + * Only valid value is `String` (the global type). + * Defaults to copy the present value, which is the numeric id. + * @property {Function} [bytes] Bytes value conversion type. + * Valid values are `Array` and (a base64 encoded) `String` (the global types). + * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser. + * @property {boolean} [defaults=false] Also sets default values on the resulting object + * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false` + * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false` + * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any + * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings + */ + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ +Type.prototype.toObject = function toObject(message, options) { + return this.setup().toObject(message, options); +}; + +/** + * Decorator function as returned by {@link Type.d} (TypeScript). + * @typedef TypeDecorator + * @type {function} + * @param {Constructor} target Target constructor + * @returns {undefined} + * @template T extends Message + */ + +/** + * Type decorator (TypeScript). + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {TypeDecorator} Decorator function + * @template T extends Message + */ +Type.d = function decorateType(typeName) { + return function typeDecorator(target) { + util.decorateType(target, typeName); + }; +}; + +},{"12":12,"13":13,"14":14,"15":15,"16":16,"20":20,"21":21,"23":23,"25":25,"27":27,"33":33,"37":37,"40":40,"41":41,"42":42}],36:[function(require,module,exports){ +"use strict"; + +/** + * Common type constants. + * @namespace + */ +var types = exports; + +var util = require(37); + +var s = [ + "double", // 0 + "float", // 1 + "int32", // 2 + "uint32", // 3 + "sint32", // 4 + "fixed32", // 5 + "sfixed32", // 6 + "int64", // 7 + "uint64", // 8 + "sint64", // 9 + "fixed64", // 10 + "sfixed64", // 11 + "bool", // 12 + "string", // 13 + "bytes" // 14 +]; + +function bake(values, offset) { + var i = 0, o = {}; + offset |= 0; + while (i < values.length) o[s[i + offset]] = values[i++]; + return o; +} + +/** + * Basic type wire types. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + * @property {number} bytes=2 Ldelim wire type + */ +types.basic = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2, + /* bytes */ 2 +]); + +/** + * Basic type defaults. + * @type {Object.} + * @const + * @property {number} double=0 Double default + * @property {number} float=0 Float default + * @property {number} int32=0 Int32 default + * @property {number} uint32=0 Uint32 default + * @property {number} sint32=0 Sint32 default + * @property {number} fixed32=0 Fixed32 default + * @property {number} sfixed32=0 Sfixed32 default + * @property {number} int64=0 Int64 default + * @property {number} uint64=0 Uint64 default + * @property {number} sint64=0 Sint32 default + * @property {number} fixed64=0 Fixed64 default + * @property {number} sfixed64=0 Sfixed64 default + * @property {boolean} bool=false Bool default + * @property {string} string="" String default + * @property {Array.} bytes=Array(0) Bytes default + * @property {null} message=null Message default + */ +types.defaults = bake([ + /* double */ 0, + /* float */ 0, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 0, + /* sfixed32 */ 0, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 0, + /* sfixed64 */ 0, + /* bool */ false, + /* string */ "", + /* bytes */ util.emptyArray, + /* message */ null +]); + +/** + * Basic long type wire types. + * @type {Object.} + * @const + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + */ +types.long = bake([ + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1 +], 7); + +/** + * Allowed types for map keys with their associated wire type. + * @type {Object.} + * @const + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + */ +types.mapKey = bake([ + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2 +], 2); + +/** + * Allowed types for packed repeated fields with their associated wire type. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + */ +types.packed = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0 +]); + +},{"37":37}],37:[function(require,module,exports){ +"use strict"; + +/** + * Various utility functions. + * @namespace + */ +var util = module.exports = require(39); + +var roots = require(30); + +var Type, // cyclic + Enum; + +util.codegen = require(3); +util.fetch = require(5); +util.path = require(8); + +/** + * Node's fs module if available. + * @type {Object.} + */ +util.fs = util.inquire("fs"); + +/** + * Converts an object's values to an array. + * @param {Object.} object Object to convert + * @returns {Array.<*>} Converted array + */ +util.toArray = function toArray(object) { + if (object) { + var keys = Object.keys(object), + array = new Array(keys.length), + index = 0; + while (index < keys.length) + array[index] = object[keys[index++]]; + return array; + } + return []; +}; + +/** + * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values. + * @param {Array.<*>} array Array to convert + * @returns {Object.} Converted object + */ +util.toObject = function toObject(array) { + var object = {}, + index = 0; + while (index < array.length) { + var key = array[index++], + val = array[index++]; + if (val !== undefined) + object[key] = val; + } + return object; +}; + +var safePropBackslashRe = /\\/g, + safePropQuoteRe = /"/g; + +/** + * Tests whether the specified name is a reserved word in JS. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +util.isReserved = function isReserved(name) { + return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name); +}; + +/** + * Returns a safe property accessor for the specified property name. + * @param {string} prop Property name + * @returns {string} Safe accessor + */ +util.safeProp = function safeProp(prop) { + if (!/^[$\w_]+$/.test(prop) || util.isReserved(prop)) + return "[\"" + prop.replace(safePropBackslashRe, "\\\\").replace(safePropQuoteRe, "\\\"") + "\"]"; + return "." + prop; +}; + +/** + * Converts the first character of a string to upper case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.ucFirst = function ucFirst(str) { + return str.charAt(0).toUpperCase() + str.substring(1); +}; + +var camelCaseRe = /_([a-z])/g; + +/** + * Converts a string to camel case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.camelCase = function camelCase(str) { + return str.substring(0, 1) + + str.substring(1) + .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); }); +}; + +/** + * Compares reflected fields by id. + * @param {Field} a First field + * @param {Field} b Second field + * @returns {number} Comparison value + */ +util.compareFieldsById = function compareFieldsById(a, b) { + return a.id - b.id; +}; + +/** + * Decorator helper for types (TypeScript). + * @param {Constructor} ctor Constructor function + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {Type} Reflected type + * @template T extends Message + * @property {Root} root Decorators root + */ +util.decorateType = function decorateType(ctor, typeName) { + + /* istanbul ignore if */ + if (ctor.$type) { + if (typeName && ctor.$type.name !== typeName) { + util.decorateRoot.remove(ctor.$type); + ctor.$type.name = typeName; + util.decorateRoot.add(ctor.$type); + } + return ctor.$type; + } + + /* istanbul ignore next */ + if (!Type) + Type = require(35); + + var type = new Type(typeName || ctor.name); + util.decorateRoot.add(type); + type.ctor = ctor; // sets up .encode, .decode etc. + Object.defineProperty(ctor, "$type", { value: type, enumerable: false }); + Object.defineProperty(ctor.prototype, "$type", { value: type, enumerable: false }); + return type; +}; + +var decorateEnumIndex = 0; + +/** + * Decorator helper for enums (TypeScript). + * @param {Object} object Enum object + * @returns {Enum} Reflected enum + */ +util.decorateEnum = function decorateEnum(object) { + + /* istanbul ignore if */ + if (object.$type) + return object.$type; + + /* istanbul ignore next */ + if (!Enum) + Enum = require(15); + + var enm = new Enum("Enum" + decorateEnumIndex++, object); + util.decorateRoot.add(enm); + Object.defineProperty(object, "$type", { value: enm, enumerable: false }); + return enm; +}; + +/** + * Decorator root (TypeScript). + * @name util.decorateRoot + * @type {Root} + * @readonly + */ +Object.defineProperty(util, "decorateRoot", { + get: function() { + return roots["decorated"] || (roots["decorated"] = new (require(29))()); + } +}); + +},{"15":15,"29":29,"3":3,"30":30,"35":35,"39":39,"5":5,"8":8}],38:[function(require,module,exports){ +"use strict"; +module.exports = LongBits; + +var util = require(39); + +/** + * Constructs new long bits. + * @classdesc Helper class for working with the low and high bits of a 64 bit value. + * @memberof util + * @constructor + * @param {number} lo Low 32 bits, unsigned + * @param {number} hi High 32 bits, unsigned + */ +function LongBits(lo, hi) { + + // note that the casts below are theoretically unnecessary as of today, but older statically + // generated converter code might still call the ctor with signed 32bits. kept for compat. + + /** + * Low bits. + * @type {number} + */ + this.lo = lo >>> 0; + + /** + * High bits. + * @type {number} + */ + this.hi = hi >>> 0; +} + +/** + * Zero bits. + * @memberof util.LongBits + * @type {util.LongBits} + */ +var zero = LongBits.zero = new LongBits(0, 0); + +zero.toNumber = function() { return 0; }; +zero.zzEncode = zero.zzDecode = function() { return this; }; +zero.length = function() { return 1; }; + +/** + * Zero hash. + * @memberof util.LongBits + * @type {string} + */ +var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0"; + +/** + * Constructs new long bits from the specified number. + * @param {number} value Value + * @returns {util.LongBits} Instance + */ +LongBits.fromNumber = function fromNumber(value) { + if (value === 0) + return zero; + var sign = value < 0; + if (sign) + value = -value; + var lo = value >>> 0, + hi = (value - lo) / 4294967296 >>> 0; + if (sign) { + hi = ~hi >>> 0; + lo = ~lo >>> 0; + if (++lo > 4294967295) { + lo = 0; + if (++hi > 4294967295) + hi = 0; + } + } + return new LongBits(lo, hi); +}; + +/** + * Constructs new long bits from a number, long or string. + * @param {Long|number|string} value Value + * @returns {util.LongBits} Instance + */ +LongBits.from = function from(value) { + if (typeof value === "number") + return LongBits.fromNumber(value); + if (util.isString(value)) { + /* istanbul ignore else */ + if (util.Long) + value = util.Long.fromString(value); + else + return LongBits.fromNumber(parseInt(value, 10)); + } + return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero; +}; + +/** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {number} Possibly unsafe number + */ +LongBits.prototype.toNumber = function toNumber(unsigned) { + if (!unsigned && this.hi >>> 31) { + var lo = ~this.lo + 1 >>> 0, + hi = ~this.hi >>> 0; + if (!lo) + hi = hi + 1 >>> 0; + return -(lo + hi * 4294967296); + } + return this.lo + this.hi * 4294967296; +}; + +/** + * Converts this long bits to a long. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long} Long + */ +LongBits.prototype.toLong = function toLong(unsigned) { + return util.Long + ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned)) + /* istanbul ignore next */ + : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) }; +}; + +var charCodeAt = String.prototype.charCodeAt; + +/** + * Constructs new long bits from the specified 8 characters long hash. + * @param {string} hash Hash + * @returns {util.LongBits} Bits + */ +LongBits.fromHash = function fromHash(hash) { + if (hash === zeroHash) + return zero; + return new LongBits( + ( charCodeAt.call(hash, 0) + | charCodeAt.call(hash, 1) << 8 + | charCodeAt.call(hash, 2) << 16 + | charCodeAt.call(hash, 3) << 24) >>> 0 + , + ( charCodeAt.call(hash, 4) + | charCodeAt.call(hash, 5) << 8 + | charCodeAt.call(hash, 6) << 16 + | charCodeAt.call(hash, 7) << 24) >>> 0 + ); +}; + +/** + * Converts this long bits to a 8 characters long hash. + * @returns {string} Hash + */ +LongBits.prototype.toHash = function toHash() { + return String.fromCharCode( + this.lo & 255, + this.lo >>> 8 & 255, + this.lo >>> 16 & 255, + this.lo >>> 24 , + this.hi & 255, + this.hi >>> 8 & 255, + this.hi >>> 16 & 255, + this.hi >>> 24 + ); +}; + +/** + * Zig-zag encodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzEncode = function zzEncode() { + var mask = this.hi >> 31; + this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0; + this.lo = ( this.lo << 1 ^ mask) >>> 0; + return this; +}; + +/** + * Zig-zag decodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzDecode = function zzDecode() { + var mask = -(this.lo & 1); + this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0; + this.hi = ( this.hi >>> 1 ^ mask) >>> 0; + return this; +}; + +/** + * Calculates the length of this longbits when encoded as a varint. + * @returns {number} Length + */ +LongBits.prototype.length = function length() { + var part0 = this.lo, + part1 = (this.lo >>> 28 | this.hi << 4) >>> 0, + part2 = this.hi >>> 24; + return part2 === 0 + ? part1 === 0 + ? part0 < 16384 + ? part0 < 128 ? 1 : 2 + : part0 < 2097152 ? 3 : 4 + : part1 < 16384 + ? part1 < 128 ? 5 : 6 + : part1 < 2097152 ? 7 : 8 + : part2 < 128 ? 9 : 10; +}; + +},{"39":39}],39:[function(require,module,exports){ +"use strict"; +var util = exports; + +// used to return a Promise where callback is omitted +util.asPromise = require(1); + +// converts to / from base64 encoded strings +util.base64 = require(2); + +// base class of rpc.Service +util.EventEmitter = require(4); + +// float handling accross browsers +util.float = require(6); + +// requires modules optionally and hides the call from bundlers +util.inquire = require(7); + +// converts to / from utf8 encoded strings +util.utf8 = require(10); + +// provides a node-like buffer pool in the browser +util.pool = require(9); + +// utility to work with the low and high bits of a 64 bit value +util.LongBits = require(38); + +// global object reference +util.global = typeof window !== "undefined" && window + || typeof global !== "undefined" && global + || typeof self !== "undefined" && self + || this; // eslint-disable-line no-invalid-this + +/** + * An immuable empty array. + * @memberof util + * @type {Array.<*>} + * @const + */ +util.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes + +/** + * An immutable empty object. + * @type {Object} + * @const + */ +util.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes + +/** + * Whether running within node or not. + * @memberof util + * @type {boolean} + * @const + */ +util.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node); + +/** + * Tests if the specified value is an integer. + * @function + * @param {*} value Value to test + * @returns {boolean} `true` if the value is an integer + */ +util.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) { + return typeof value === "number" && isFinite(value) && Math.floor(value) === value; +}; + +/** + * Tests if the specified value is a string. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a string + */ +util.isString = function isString(value) { + return typeof value === "string" || value instanceof String; +}; + +/** + * Tests if the specified value is a non-null object. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a non-null object + */ +util.isObject = function isObject(value) { + return value && typeof value === "object"; +}; + +/** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @function + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isset = + +/** + * Checks if a property on a message is considered to be present. + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isSet = function isSet(obj, prop) { + var value = obj[prop]; + if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins + return typeof value !== "object" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0; + return false; +}; + +/** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + * @interface Buffer + * @extends Uint8Array + */ + +/** + * Node's Buffer class if available. + * @type {Constructor} + */ +util.Buffer = (function() { + try { + var Buffer = util.inquire("buffer").Buffer; + // refuse to use non-node buffers if not explicitly assigned (perf reasons): + return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null; + } catch (e) { + /* istanbul ignore next */ + return null; + } +})(); + +// Internal alias of or polyfull for Buffer.from. +util._Buffer_from = null; + +// Internal alias of or polyfill for Buffer.allocUnsafe. +util._Buffer_allocUnsafe = null; + +/** + * Creates a new buffer of whatever type supported by the environment. + * @param {number|number[]} [sizeOrArray=0] Buffer size or number array + * @returns {Uint8Array|Buffer} Buffer + */ +util.newBuffer = function newBuffer(sizeOrArray) { + /* istanbul ignore next */ + return typeof sizeOrArray === "number" + ? util.Buffer + ? util._Buffer_allocUnsafe(sizeOrArray) + : new util.Array(sizeOrArray) + : util.Buffer + ? util._Buffer_from(sizeOrArray) + : typeof Uint8Array === "undefined" + ? sizeOrArray + : new Uint8Array(sizeOrArray); +}; + +/** + * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. + * @type {Constructor} + */ +util.Array = typeof Uint8Array !== "undefined" ? Uint8Array /* istanbul ignore next */ : Array; + +/** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + * @interface Long + * @property {number} low Low bits + * @property {number} high High bits + * @property {boolean} unsigned Whether unsigned or not + */ + +/** + * Long.js's Long class if available. + * @type {Constructor} + */ +util.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long + || /* istanbul ignore next */ util.global.Long + || util.inquire("long"); + +/** + * Regular expression used to verify 2 bit (`bool`) map keys. + * @type {RegExp} + * @const + */ +util.key2Re = /^true|false|0|1$/; + +/** + * Regular expression used to verify 32 bit (`int32` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key32Re = /^-?(?:0|[1-9][0-9]*)$/; + +/** + * Regular expression used to verify 64 bit (`int64` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/; + +/** + * Converts a number or long to an 8 characters long hash string. + * @param {Long|number} value Value to convert + * @returns {string} Hash + */ +util.longToHash = function longToHash(value) { + return value + ? util.LongBits.from(value).toHash() + : util.LongBits.zeroHash; +}; + +/** + * Converts an 8 characters long hash string to a long or number. + * @param {string} hash Hash + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long|number} Original value + */ +util.longFromHash = function longFromHash(hash, unsigned) { + var bits = util.LongBits.fromHash(hash); + if (util.Long) + return util.Long.fromBits(bits.lo, bits.hi, unsigned); + return bits.toNumber(Boolean(unsigned)); +}; + +/** + * Merges the properties of the source object into the destination object. + * @memberof util + * @param {Object.} dst Destination object + * @param {Object.} src Source object + * @param {boolean} [ifNotSet=false] Merges only if the key is not already set + * @returns {Object.} Destination object + */ +function merge(dst, src, ifNotSet) { // used by converters + for (var keys = Object.keys(src), i = 0; i < keys.length; ++i) + if (dst[keys[i]] === undefined || !ifNotSet) + dst[keys[i]] = src[keys[i]]; + return dst; +} + +util.merge = merge; + +/** + * Converts the first character of a string to lower case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.lcFirst = function lcFirst(str) { + return str.charAt(0).toLowerCase() + str.substring(1); +}; + +/** + * Creates a custom error constructor. + * @memberof util + * @param {string} name Error name + * @returns {Constructor} Custom error constructor + */ +function newError(name) { + + function CustomError(message, properties) { + + if (!(this instanceof CustomError)) + return new CustomError(message, properties); + + // Error.call(this, message); + // ^ just returns a new error instance because the ctor can be called as a function + + Object.defineProperty(this, "message", { get: function() { return message; } }); + + /* istanbul ignore next */ + if (Error.captureStackTrace) // node + Error.captureStackTrace(this, CustomError); + else + Object.defineProperty(this, "stack", { value: (new Error()).stack || "" }); + + if (properties) + merge(this, properties); + } + + (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError; + + Object.defineProperty(CustomError.prototype, "name", { get: function() { return name; } }); + + CustomError.prototype.toString = function toString() { + return this.name + ": " + this.message; + }; + + return CustomError; +} + +util.newError = newError; + +/** + * Constructs a new protocol error. + * @classdesc Error subclass indicating a protocol specifc error. + * @memberof util + * @extends Error + * @template T extends Message + * @constructor + * @param {string} message Error message + * @param {Object.} [properties] Additional properties + * @example + * try { + * MyMessage.decode(someBuffer); // throws if required fields are missing + * } catch (e) { + * if (e instanceof ProtocolError && e.instance) + * console.log("decoded so far: " + JSON.stringify(e.instance)); + * } + */ +util.ProtocolError = newError("ProtocolError"); + +/** + * So far decoded message instance. + * @name util.ProtocolError#instance + * @type {Message} + */ + +/** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @typedef OneOfGetter + * @type {function} + * @returns {string|undefined} Set field name, if any + */ + +/** + * Builds a getter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfGetter} Unbound getter + */ +util.oneOfGetter = function getOneOf(fieldNames) { + var fieldMap = {}; + for (var i = 0; i < fieldNames.length; ++i) + fieldMap[fieldNames[i]] = 1; + + /** + * @returns {string|undefined} Set field name, if any + * @this Object + * @ignore + */ + return function() { // eslint-disable-line consistent-return + for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i) + if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null) + return keys[i]; + }; +}; + +/** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @typedef OneOfSetter + * @type {function} + * @param {string|undefined} value Field name + * @returns {undefined} + */ + +/** + * Builds a setter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfSetter} Unbound setter + */ +util.oneOfSetter = function setOneOf(fieldNames) { + + /** + * @param {string} name Field name + * @returns {undefined} + * @this Object + * @ignore + */ + return function(name) { + for (var i = 0; i < fieldNames.length; ++i) + if (fieldNames[i] !== name) + delete this[fieldNames[i]]; + }; +}; + +/** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @type {IConversionOptions} + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ +util.toJSONOptions = { + longs: String, + enums: String, + bytes: String, + json: true +}; + +// Sets up buffer utility according to the environment (called in index-minimal) +util._configure = function() { + var Buffer = util.Buffer; + /* istanbul ignore if */ + if (!Buffer) { + util._Buffer_from = util._Buffer_allocUnsafe = null; + return; + } + // because node 4.x buffers are incompatible & immutable + // see: https://github.com/dcodeIO/protobuf.js/pull/665 + util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from || + /* istanbul ignore next */ + function Buffer_from(value, encoding) { + return new Buffer(value, encoding); + }; + util._Buffer_allocUnsafe = Buffer.allocUnsafe || + /* istanbul ignore next */ + function Buffer_allocUnsafe(size) { + return new Buffer(size); + }; +}; + +},{"1":1,"10":10,"2":2,"38":38,"4":4,"6":6,"7":7,"9":9}],40:[function(require,module,exports){ +"use strict"; +module.exports = verifier; + +var Enum = require(15), + util = require(37); + +function invalid(field, expected) { + return field.name + ": " + expected + (field.repeated && expected !== "array" ? "[]" : field.map && expected !== "object" ? "{k:"+field.keyType+"}" : "") + " expected"; +} + +/** + * Generates a partial value verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyValue(gen, field, fieldIndex, ref) { + /* eslint-disable no-unexpected-multiline */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(%s){", ref) + ("default:") + ("return%j", invalid(field, "enum value")); + for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen + ("case %i:", field.resolvedType.values[keys[j]]); + gen + ("break") + ("}"); + } else { + gen + ("{") + ("var e=types[%i].verify(%s);", fieldIndex, ref) + ("if(e)") + ("return%j+e", field.name + ".") + ("}"); + } + } else { + switch (field.type) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.isInteger(%s))", ref) + ("return%j", invalid(field, "integer")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))", ref, ref, ref, ref) + ("return%j", invalid(field, "integer|Long")); + break; + case "float": + case "double": gen + ("if(typeof %s!==\"number\")", ref) + ("return%j", invalid(field, "number")); + break; + case "bool": gen + ("if(typeof %s!==\"boolean\")", ref) + ("return%j", invalid(field, "boolean")); + break; + case "string": gen + ("if(!util.isString(%s))", ref) + ("return%j", invalid(field, "string")); + break; + case "bytes": gen + ("if(!(%s&&typeof %s.length===\"number\"||util.isString(%s)))", ref, ref, ref) + ("return%j", invalid(field, "buffer")); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a partial key verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyKey(gen, field, ref) { + /* eslint-disable no-unexpected-multiline */ + switch (field.keyType) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.key32Re.test(%s))", ref) + ("return%j", invalid(field, "integer key")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.key64Re.test(%s))", ref) // see comment above: x is ok, d is not + ("return%j", invalid(field, "integer|Long key")); + break; + case "bool": gen + ("if(!util.key2Re.test(%s))", ref) + ("return%j", invalid(field, "boolean key")); + break; + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a verifier specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function verifier(mtype) { + /* eslint-disable no-unexpected-multiline */ + + var gen = util.codegen(["m"], mtype.name + "$verify") + ("if(typeof m!==\"object\"||m===null)") + ("return%j", "object expected"); + var oneofs = mtype.oneofsArray, + seenFirstField = {}; + if (oneofs.length) gen + ("var p={}"); + + for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + ref = "m" + util.safeProp(field.name); + + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name); // !== undefined && !== null + + // map fields + if (field.map) { gen + ("if(!util.isObject(%s))", ref) + ("return%j", invalid(field, "object")) + ("var k=Object.keys(%s)", ref) + ("for(var i=0;i} + * @const + */ +var wrappers = exports; + +var Message = require(21); + +/** + * From object converter part of an {@link IWrapper}. + * @typedef WrapperFromObjectConverter + * @type {function} + * @param {Object.} object Plain object + * @returns {Message<{}>} Message instance + * @this Type + */ + +/** + * To object converter part of an {@link IWrapper}. + * @typedef WrapperToObjectConverter + * @type {function} + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @this Type + */ + +/** + * Common type wrapper part of {@link wrappers}. + * @interface IWrapper + * @property {WrapperFromObjectConverter} [fromObject] From object converter + * @property {WrapperToObjectConverter} [toObject] To object converter + */ + +// Custom wrapper for Any +wrappers[".google.protobuf.Any"] = { + + fromObject: function(object) { + + // unwrap value type if mapped + if (object && object["@type"]) { + var type = this.lookup(object["@type"]); + /* istanbul ignore else */ + if (type) { + // type_url does not accept leading "." + var type_url = object["@type"].charAt(0) === "." ? + object["@type"].substr(1) : object["@type"]; + // type_url prefix is optional, but path seperator is required + return this.create({ + type_url: "/" + type_url, + value: type.encode(type.fromObject(object)).finish() + }); + } + } + + return this.fromObject(object); + }, + + toObject: function(message, options) { + + // decode value if requested and unmapped + if (options && options.json && message.type_url && message.value) { + // Only use fully qualified type name after the last '/' + var name = message.type_url.substring(message.type_url.lastIndexOf("/") + 1); + var type = this.lookup(name); + /* istanbul ignore else */ + if (type) + message = type.decode(message.value); + } + + // wrap value if unmapped + if (!(message instanceof this.ctor) && message instanceof Message) { + var object = message.$type.toObject(message, options); + object["@type"] = message.$type.fullName; + return object; + } + + return this.toObject(message, options); + } +}; + +},{"21":21}],42:[function(require,module,exports){ +"use strict"; +module.exports = Writer; + +var util = require(39); + +var BufferWriter; // cyclic + +var LongBits = util.LongBits, + base64 = util.base64, + utf8 = util.utf8; + +/** + * Constructs a new writer operation instance. + * @classdesc Scheduled writer operation. + * @constructor + * @param {function(*, Uint8Array, number)} fn Function to call + * @param {number} len Value byte length + * @param {*} val Value to write + * @ignore + */ +function Op(fn, len, val) { + + /** + * Function to call. + * @type {function(Uint8Array, number, *)} + */ + this.fn = fn; + + /** + * Value byte length. + * @type {number} + */ + this.len = len; + + /** + * Next operation. + * @type {Writer.Op|undefined} + */ + this.next = undefined; + + /** + * Value to write. + * @type {*} + */ + this.val = val; // type varies +} + +/* istanbul ignore next */ +function noop() {} // eslint-disable-line no-empty-function + +/** + * Constructs a new writer state instance. + * @classdesc Copied writer state. + * @memberof Writer + * @constructor + * @param {Writer} writer Writer to copy state from + * @ignore + */ +function State(writer) { + + /** + * Current head. + * @type {Writer.Op} + */ + this.head = writer.head; + + /** + * Current tail. + * @type {Writer.Op} + */ + this.tail = writer.tail; + + /** + * Current buffer length. + * @type {number} + */ + this.len = writer.len; + + /** + * Next state. + * @type {State|null} + */ + this.next = writer.states; +} + +/** + * Constructs a new writer instance. + * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`. + * @constructor + */ +function Writer() { + + /** + * Current length. + * @type {number} + */ + this.len = 0; + + /** + * Operations head. + * @type {Object} + */ + this.head = new Op(noop, 0, 0); + + /** + * Operations tail + * @type {Object} + */ + this.tail = this.head; + + /** + * Linked forked states. + * @type {Object|null} + */ + this.states = null; + + // When a value is written, the writer calculates its byte length and puts it into a linked + // list of operations to perform when finish() is called. This both allows us to allocate + // buffers of the exact required size and reduces the amount of work we have to do compared + // to first calculating over objects and then encoding over objects. In our case, the encoding + // part is just a linked list walk calling operations with already prepared values. +} + +/** + * Creates a new writer. + * @function + * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ +Writer.create = util.Buffer + ? function create_buffer_setup() { + return (Writer.create = function create_buffer() { + return new BufferWriter(); + })(); + } + /* istanbul ignore next */ + : function create_array() { + return new Writer(); + }; + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ +Writer.alloc = function alloc(size) { + return new util.Array(size); +}; + +// Use Uint8Array buffer pool in the browser, just like node does with buffers +/* istanbul ignore else */ +if (util.Array !== Array) + Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray); + +/** + * Pushes a new operation to the queue. + * @param {function(Uint8Array, number, *)} fn Function to call + * @param {number} len Value byte length + * @param {number} val Value to write + * @returns {Writer} `this` + * @private + */ +Writer.prototype._push = function push(fn, len, val) { + this.tail = this.tail.next = new Op(fn, len, val); + this.len += len; + return this; +}; + +function writeByte(val, buf, pos) { + buf[pos] = val & 255; +} + +function writeVarint32(val, buf, pos) { + while (val > 127) { + buf[pos++] = val & 127 | 128; + val >>>= 7; + } + buf[pos] = val; +} + +/** + * Constructs a new varint writer operation instance. + * @classdesc Scheduled varint writer operation. + * @extends Op + * @constructor + * @param {number} len Value byte length + * @param {number} val Value to write + * @ignore + */ +function VarintOp(len, val) { + this.len = len; + this.next = undefined; + this.val = val; +} + +VarintOp.prototype = Object.create(Op.prototype); +VarintOp.prototype.fn = writeVarint32; + +/** + * Writes an unsigned 32 bit value as a varint. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.uint32 = function write_uint32(value) { + // here, the call to this.push has been inlined and a varint specific Op subclass is used. + // uint32 is by far the most frequently used operation and benefits significantly from this. + this.len += (this.tail = this.tail.next = new VarintOp( + (value = value >>> 0) + < 128 ? 1 + : value < 16384 ? 2 + : value < 2097152 ? 3 + : value < 268435456 ? 4 + : 5, + value)).len; + return this; +}; + +/** + * Writes a signed 32 bit value as a varint. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.int32 = function write_int32(value) { + return value < 0 + ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec + : this.uint32(value); +}; + +/** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sint32 = function write_sint32(value) { + return this.uint32((value << 1 ^ value >> 31) >>> 0); +}; + +function writeVarint64(val, buf, pos) { + while (val.hi) { + buf[pos++] = val.lo & 127 | 128; + val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0; + val.hi >>>= 7; + } + while (val.lo > 127) { + buf[pos++] = val.lo & 127 | 128; + val.lo = val.lo >>> 7; + } + buf[pos++] = val.lo; +} + +/** + * Writes an unsigned 64 bit value as a varint. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.uint64 = function write_uint64(value) { + var bits = LongBits.from(value); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a signed 64 bit value as a varint. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.int64 = Writer.prototype.uint64; + +/** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sint64 = function write_sint64(value) { + var bits = LongBits.from(value).zzEncode(); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a boolish value as a varint. + * @param {boolean} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.bool = function write_bool(value) { + return this._push(writeByte, 1, value ? 1 : 0); +}; + +function writeFixed32(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +/** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.fixed32 = function write_fixed32(value) { + return this._push(writeFixed32, 4, value >>> 0); +}; + +/** + * Writes a signed 32 bit value as fixed 32 bits. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sfixed32 = Writer.prototype.fixed32; + +/** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.fixed64 = function write_fixed64(value) { + var bits = LongBits.from(value); + return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi); +}; + +/** + * Writes a signed 64 bit value as fixed 64 bits. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sfixed64 = Writer.prototype.fixed64; + +/** + * Writes a float (32 bit). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.float = function write_float(value) { + return this._push(util.float.writeFloatLE, 4, value); +}; + +/** + * Writes a double (64 bit float). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.double = function write_double(value) { + return this._push(util.float.writeDoubleLE, 8, value); +}; + +var writeBytes = util.Array.prototype.set + ? function writeBytes_set(val, buf, pos) { + buf.set(val, pos); // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytes_for(val, buf, pos) { + for (var i = 0; i < val.length; ++i) + buf[pos + i] = val[i]; + }; + +/** + * Writes a sequence of bytes. + * @param {Uint8Array|string} value Buffer or base64 encoded string to write + * @returns {Writer} `this` + */ +Writer.prototype.bytes = function write_bytes(value) { + var len = value.length >>> 0; + if (!len) + return this._push(writeByte, 1, 0); + if (util.isString(value)) { + var buf = Writer.alloc(len = base64.length(value)); + base64.decode(value, buf, 0); + value = buf; + } + return this.uint32(len)._push(writeBytes, len, value); +}; + +/** + * Writes a string. + * @param {string} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.string = function write_string(value) { + var len = utf8.length(value); + return len + ? this.uint32(len)._push(utf8.write, len, value) + : this._push(writeByte, 1, 0); +}; + +/** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns {Writer} `this` + */ +Writer.prototype.fork = function fork() { + this.states = new State(this); + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + return this; +}; + +/** + * Resets this instance to the last state. + * @returns {Writer} `this` + */ +Writer.prototype.reset = function reset() { + if (this.states) { + this.head = this.states.head; + this.tail = this.states.tail; + this.len = this.states.len; + this.states = this.states.next; + } else { + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + } + return this; +}; + +/** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns {Writer} `this` + */ +Writer.prototype.ldelim = function ldelim() { + var head = this.head, + tail = this.tail, + len = this.len; + this.reset().uint32(len); + if (len) { + this.tail.next = head.next; // skip noop + this.tail = tail; + this.len += len; + } + return this; +}; + +/** + * Finishes the write operation. + * @returns {Uint8Array} Finished buffer + */ +Writer.prototype.finish = function finish() { + var head = this.head.next, // skip noop + buf = this.constructor.alloc(this.len), + pos = 0; + while (head) { + head.fn(head.val, buf, pos); + pos += head.len; + head = head.next; + } + // this.head = this.tail = null; + return buf; +}; + +Writer._configure = function(BufferWriter_) { + BufferWriter = BufferWriter_; +}; + +},{"39":39}],43:[function(require,module,exports){ +"use strict"; +module.exports = BufferWriter; + +// extends Writer +var Writer = require(42); +(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter; + +var util = require(39); + +var Buffer = util.Buffer; + +/** + * Constructs a new buffer writer instance. + * @classdesc Wire format writer using node buffers. + * @extends Writer + * @constructor + */ +function BufferWriter() { + Writer.call(this); +} + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Buffer} Buffer + */ +BufferWriter.alloc = function alloc_buffer(size) { + return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size); +}; + +var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set" + ? function writeBytesBuffer_set(val, buf, pos) { + buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited) + // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytesBuffer_copy(val, buf, pos) { + if (val.copy) // Buffer values + val.copy(buf, pos, 0, val.length); + else for (var i = 0; i < val.length;) // plain array values + buf[pos++] = val[i++]; + }; + +/** + * @override + */ +BufferWriter.prototype.bytes = function write_bytes_buffer(value) { + if (util.isString(value)) + value = util._Buffer_from(value, "base64"); + var len = value.length >>> 0; + this.uint32(len); + if (len) + this._push(writeBytesBuffer, len, value); + return this; +}; + +function writeStringBuffer(val, buf, pos) { + if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions) + util.utf8.write(val, buf, pos); + else + buf.utf8Write(val, pos); +} + +/** + * @override + */ +BufferWriter.prototype.string = function write_string_buffer(value) { + var len = Buffer.byteLength(value); + this.uint32(len); + if (len) + this._push(writeStringBuffer, len, value); + return this; +}; + + +/** + * Finishes the write operation. + * @name BufferWriter#finish + * @function + * @returns {Buffer} Finished buffer + */ + +},{"39":39,"42":42}]},{},[19]) + +})(); +//# sourceMappingURL=protobuf.js.map diff --git a/node_modules/protobufjs/dist/protobuf.js.map b/node_modules/protobufjs/dist/protobuf.js.map new file mode 100644 index 0000000..d00d017 --- /dev/null +++ b/node_modules/protobufjs/dist/protobuf.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/codegen/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/fetch/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/path/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/common.js","../src/converter.js","../src/decoder.js","../src/encoder.js","../src/enum.js","../src/field.js","../src/index-light.js","../src/index-minimal.js","../src/index","../src/mapfield.js","../src/message.js","../src/method.js","../src/namespace.js","../src/object.js","../src/oneof.js","../src/parse.js","../src/reader.js","../src/reader_buffer.js","../src/root.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/service.js","../src/tokenize.js","../src/type.js","../src/types.js","../src/util.js","../src/util/longbits.js","../src/util/minimal.js","../src/verifier.js","../src/wrappers.js","../src/writer.js","../src/writer_buffer.js"],"names":[],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/YA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7YA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3cA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"protobuf.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = codegen;\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @param {string[]} functionParams Function parameter names\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n */\r\nfunction codegen(functionParams, functionName) {\r\n\r\n /* istanbul ignore if */\r\n if (typeof functionParams === \"string\") {\r\n functionName = functionParams;\r\n functionParams = undefined;\r\n }\r\n\r\n var body = [];\r\n\r\n /**\r\n * Appends code to the function's body or finishes generation.\r\n * @typedef Codegen\r\n * @type {function}\r\n * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any\r\n * @param {...*} [formatParams] Format parameters\r\n * @returns {Codegen|Function} Itself or the generated function if finished\r\n * @throws {Error} If format parameter counts do not match\r\n */\r\n\r\n function Codegen(formatStringOrScope) {\r\n // note that explicit array handling below makes this ~50% faster\r\n\r\n // finish the function\r\n if (typeof formatStringOrScope !== \"string\") {\r\n var source = toString();\r\n if (codegen.verbose)\r\n console.log(\"codegen: \" + source); // eslint-disable-line no-console\r\n source = \"return \" + source;\r\n if (formatStringOrScope) {\r\n var scopeKeys = Object.keys(formatStringOrScope),\r\n scopeParams = new Array(scopeKeys.length + 1),\r\n scopeValues = new Array(scopeKeys.length),\r\n scopeOffset = 0;\r\n while (scopeOffset < scopeKeys.length) {\r\n scopeParams[scopeOffset] = scopeKeys[scopeOffset];\r\n scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]];\r\n }\r\n scopeParams[scopeOffset] = source;\r\n return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func\r\n }\r\n return Function(source)(); // eslint-disable-line no-new-func\r\n }\r\n\r\n // otherwise append to body\r\n var formatParams = new Array(arguments.length - 1),\r\n formatOffset = 0;\r\n while (formatOffset < formatParams.length)\r\n formatParams[formatOffset] = arguments[++formatOffset];\r\n formatOffset = 0;\r\n formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) {\r\n var value = formatParams[formatOffset++];\r\n switch ($1) {\r\n case \"d\": case \"f\": return String(Number(value));\r\n case \"i\": return String(Math.floor(value));\r\n case \"j\": return JSON.stringify(value);\r\n case \"s\": return String(value);\r\n }\r\n return \"%\";\r\n });\r\n if (formatOffset !== formatParams.length)\r\n throw Error(\"parameter count mismatch\");\r\n body.push(formatStringOrScope);\r\n return Codegen;\r\n }\r\n\r\n function toString(functionNameOverride) {\r\n return \"function \" + (functionNameOverride || functionName || \"\") + \"(\" + (functionParams && functionParams.join(\",\") || \"\") + \"){\\n \" + body.join(\"\\n \") + \"\\n}\";\r\n }\r\n\r\n Codegen.toString = toString;\r\n return Codegen;\r\n}\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @function codegen\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * When set to `true`, codegen will log generated code to console. Useful for debugging.\r\n * @name util.codegen.verbose\r\n * @type {boolean}\r\n */\r\ncodegen.verbose = false;\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = fetch;\r\n\r\nvar asPromise = require(1),\r\n inquire = require(7);\r\n\r\nvar fs = inquire(\"fs\");\r\n\r\n/**\r\n * Node-style callback as used by {@link util.fetch}.\r\n * @typedef FetchCallback\r\n * @type {function}\r\n * @param {?Error} error Error, if any, otherwise `null`\r\n * @param {string} [contents] File contents, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Options as used by {@link util.fetch}.\r\n * @typedef FetchOptions\r\n * @type {Object}\r\n * @property {boolean} [binary=false] Whether expecting a binary response\r\n * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @memberof util\r\n * @param {string} filename File path or url\r\n * @param {FetchOptions} options Fetch options\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nfunction fetch(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = {};\r\n } else if (!options)\r\n options = {};\r\n\r\n if (!callback)\r\n return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this\r\n\r\n // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found.\r\n if (!options.xhr && fs && fs.readFile)\r\n return fs.readFile(filename, function fetchReadFileCallback(err, contents) {\r\n return err && typeof XMLHttpRequest !== \"undefined\"\r\n ? fetch.xhr(filename, options, callback)\r\n : err\r\n ? callback(err)\r\n : callback(null, options.binary ? contents : contents.toString(\"utf8\"));\r\n });\r\n\r\n // use the XHR version otherwise.\r\n return fetch.xhr(filename, options, callback);\r\n}\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchOptions} [options] Fetch options\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n\r\n/**/\r\nfetch.xhr = function fetch_xhr(filename, options, callback) {\r\n var xhr = new XMLHttpRequest();\r\n xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() {\r\n\r\n if (xhr.readyState !== 4)\r\n return undefined;\r\n\r\n // local cors security errors return status 0 / empty string, too. afaik this cannot be\r\n // reliably distinguished from an actually empty file for security reasons. feel free\r\n // to send a pull request if you are aware of a solution.\r\n if (xhr.status !== 0 && xhr.status !== 200)\r\n return callback(Error(\"status \" + xhr.status));\r\n\r\n // if binary data is expected, make sure that some sort of array is returned, even if\r\n // ArrayBuffers are not supported. the binary string fallback, however, is unsafe.\r\n if (options.binary) {\r\n var buffer = xhr.response;\r\n if (!buffer) {\r\n buffer = [];\r\n for (var i = 0; i < xhr.responseText.length; ++i)\r\n buffer.push(xhr.responseText.charCodeAt(i) & 255);\r\n }\r\n return callback(null, typeof Uint8Array !== \"undefined\" ? new Uint8Array(buffer) : buffer);\r\n }\r\n return callback(null, xhr.responseText);\r\n };\r\n\r\n if (options.binary) {\r\n // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers\r\n if (\"overrideMimeType\" in xhr)\r\n xhr.overrideMimeType(\"text/plain; charset=x-user-defined\");\r\n xhr.responseType = \"arraybuffer\";\r\n }\r\n\r\n xhr.open(\"GET\", filename);\r\n xhr.send();\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal path module to resolve Unix, Windows and URL paths alike.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar path = exports;\r\n\r\nvar isAbsolute =\r\n/**\r\n * Tests if the specified path is absolute.\r\n * @param {string} path Path to test\r\n * @returns {boolean} `true` if path is absolute\r\n */\r\npath.isAbsolute = function isAbsolute(path) {\r\n return /^(?:\\/|\\w+:)/.test(path);\r\n};\r\n\r\nvar normalize =\r\n/**\r\n * Normalizes the specified path.\r\n * @param {string} path Path to normalize\r\n * @returns {string} Normalized path\r\n */\r\npath.normalize = function normalize(path) {\r\n path = path.replace(/\\\\/g, \"/\")\r\n .replace(/\\/{2,}/g, \"/\");\r\n var parts = path.split(\"/\"),\r\n absolute = isAbsolute(path),\r\n prefix = \"\";\r\n if (absolute)\r\n prefix = parts.shift() + \"/\";\r\n for (var i = 0; i < parts.length;) {\r\n if (parts[i] === \"..\") {\r\n if (i > 0 && parts[i - 1] !== \"..\")\r\n parts.splice(--i, 2);\r\n else if (absolute)\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n } else if (parts[i] === \".\")\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n return prefix + parts.join(\"/\");\r\n};\r\n\r\n/**\r\n * Resolves the specified include path against the specified origin path.\r\n * @param {string} originPath Path to the origin file\r\n * @param {string} includePath Include path relative to origin path\r\n * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized\r\n * @returns {string} Path to the include file\r\n */\r\npath.resolve = function resolve(originPath, includePath, alreadyNormalized) {\r\n if (!alreadyNormalized)\r\n includePath = normalize(includePath);\r\n if (isAbsolute(includePath))\r\n return includePath;\r\n if (!alreadyNormalized)\r\n originPath = normalize(originPath);\r\n return (originPath = originPath.replace(/(?:\\/|^)[^/]+$/, \"\")).length ? normalize(originPath + \"/\" + includePath) : includePath;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nmodule.exports = common;\r\n\r\nvar commonRe = /\\/|\\./;\r\n\r\n/**\r\n * Provides common type definitions.\r\n * Can also be used to provide additional google types or your own custom types.\r\n * @param {string} name Short name as in `google/protobuf/[name].proto` or full file name\r\n * @param {Object.} json JSON definition within `google.protobuf` if a short name, otherwise the file's root definition\r\n * @returns {undefined}\r\n * @property {INamespace} google/protobuf/any.proto Any\r\n * @property {INamespace} google/protobuf/duration.proto Duration\r\n * @property {INamespace} google/protobuf/empty.proto Empty\r\n * @property {INamespace} google/protobuf/field_mask.proto FieldMask\r\n * @property {INamespace} google/protobuf/struct.proto Struct, Value, NullValue and ListValue\r\n * @property {INamespace} google/protobuf/timestamp.proto Timestamp\r\n * @property {INamespace} google/protobuf/wrappers.proto Wrappers\r\n * @example\r\n * // manually provides descriptor.proto (assumes google/protobuf/ namespace and .proto extension)\r\n * protobuf.common(\"descriptor\", descriptorJson);\r\n *\r\n * // manually provides a custom definition (uses my.foo namespace)\r\n * protobuf.common(\"my/foo/bar.proto\", myFooBarJson);\r\n */\r\nfunction common(name, json) {\r\n if (!commonRe.test(name)) {\r\n name = \"google/protobuf/\" + name + \".proto\";\r\n json = { nested: { google: { nested: { protobuf: { nested: json } } } } };\r\n }\r\n common[name] = json;\r\n}\r\n\r\n// Not provided because of limited use (feel free to discuss or to provide yourself):\r\n//\r\n// google/protobuf/descriptor.proto\r\n// google/protobuf/source_context.proto\r\n// google/protobuf/type.proto\r\n//\r\n// Stripped and pre-parsed versions of these non-bundled files are instead available as part of\r\n// the repository or package within the google/protobuf directory.\r\n\r\ncommon(\"any\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Any message.\r\n * @interface IAny\r\n * @type {Object}\r\n * @property {string} [typeUrl]\r\n * @property {Uint8Array} [bytes]\r\n * @memberof common\r\n */\r\n Any: {\r\n fields: {\r\n type_url: {\r\n type: \"string\",\r\n id: 1\r\n },\r\n value: {\r\n type: \"bytes\",\r\n id: 2\r\n }\r\n }\r\n }\r\n});\r\n\r\nvar timeType;\r\n\r\ncommon(\"duration\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Duration message.\r\n * @interface IDuration\r\n * @type {Object}\r\n * @property {number|Long} [seconds]\r\n * @property {number} [nanos]\r\n * @memberof common\r\n */\r\n Duration: timeType = {\r\n fields: {\r\n seconds: {\r\n type: \"int64\",\r\n id: 1\r\n },\r\n nanos: {\r\n type: \"int32\",\r\n id: 2\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"timestamp\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Timestamp message.\r\n * @interface ITimestamp\r\n * @type {Object}\r\n * @property {number|Long} [seconds]\r\n * @property {number} [nanos]\r\n * @memberof common\r\n */\r\n Timestamp: timeType\r\n});\r\n\r\ncommon(\"empty\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Empty message.\r\n * @interface IEmpty\r\n * @memberof common\r\n */\r\n Empty: {\r\n fields: {}\r\n }\r\n});\r\n\r\ncommon(\"struct\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Struct message.\r\n * @interface IStruct\r\n * @type {Object}\r\n * @property {Object.} [fields]\r\n * @memberof common\r\n */\r\n Struct: {\r\n fields: {\r\n fields: {\r\n keyType: \"string\",\r\n type: \"Value\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Value message.\r\n * @interface IValue\r\n * @type {Object}\r\n * @property {string} [kind]\r\n * @property {0} [nullValue]\r\n * @property {number} [numberValue]\r\n * @property {string} [stringValue]\r\n * @property {boolean} [boolValue]\r\n * @property {IStruct} [structValue]\r\n * @property {IListValue} [listValue]\r\n * @memberof common\r\n */\r\n Value: {\r\n oneofs: {\r\n kind: {\r\n oneof: [\r\n \"nullValue\",\r\n \"numberValue\",\r\n \"stringValue\",\r\n \"boolValue\",\r\n \"structValue\",\r\n \"listValue\"\r\n ]\r\n }\r\n },\r\n fields: {\r\n nullValue: {\r\n type: \"NullValue\",\r\n id: 1\r\n },\r\n numberValue: {\r\n type: \"double\",\r\n id: 2\r\n },\r\n stringValue: {\r\n type: \"string\",\r\n id: 3\r\n },\r\n boolValue: {\r\n type: \"bool\",\r\n id: 4\r\n },\r\n structValue: {\r\n type: \"Struct\",\r\n id: 5\r\n },\r\n listValue: {\r\n type: \"ListValue\",\r\n id: 6\r\n }\r\n }\r\n },\r\n\r\n NullValue: {\r\n values: {\r\n NULL_VALUE: 0\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.ListValue message.\r\n * @interface IListValue\r\n * @type {Object}\r\n * @property {Array.} [values]\r\n * @memberof common\r\n */\r\n ListValue: {\r\n fields: {\r\n values: {\r\n rule: \"repeated\",\r\n type: \"Value\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"wrappers\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.DoubleValue message.\r\n * @interface IDoubleValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n DoubleValue: {\r\n fields: {\r\n value: {\r\n type: \"double\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.FloatValue message.\r\n * @interface IFloatValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n FloatValue: {\r\n fields: {\r\n value: {\r\n type: \"float\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Int64Value message.\r\n * @interface IInt64Value\r\n * @type {Object}\r\n * @property {number|Long} [value]\r\n * @memberof common\r\n */\r\n Int64Value: {\r\n fields: {\r\n value: {\r\n type: \"int64\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.UInt64Value message.\r\n * @interface IUInt64Value\r\n * @type {Object}\r\n * @property {number|Long} [value]\r\n * @memberof common\r\n */\r\n UInt64Value: {\r\n fields: {\r\n value: {\r\n type: \"uint64\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Int32Value message.\r\n * @interface IInt32Value\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n Int32Value: {\r\n fields: {\r\n value: {\r\n type: \"int32\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.UInt32Value message.\r\n * @interface IUInt32Value\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n UInt32Value: {\r\n fields: {\r\n value: {\r\n type: \"uint32\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.BoolValue message.\r\n * @interface IBoolValue\r\n * @type {Object}\r\n * @property {boolean} [value]\r\n * @memberof common\r\n */\r\n BoolValue: {\r\n fields: {\r\n value: {\r\n type: \"bool\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.StringValue message.\r\n * @interface IStringValue\r\n * @type {Object}\r\n * @property {string} [value]\r\n * @memberof common\r\n */\r\n StringValue: {\r\n fields: {\r\n value: {\r\n type: \"string\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.BytesValue message.\r\n * @interface IBytesValue\r\n * @type {Object}\r\n * @property {Uint8Array} [value]\r\n * @memberof common\r\n */\r\n BytesValue: {\r\n fields: {\r\n value: {\r\n type: \"bytes\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"field_mask\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.FieldMask message.\r\n * @interface IDoubleValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n FieldMask: {\r\n fields: {\r\n paths: {\r\n rule: \"repeated\",\r\n type: \"string\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Gets the root definition of the specified common proto file.\r\n *\r\n * Bundled definitions are:\r\n * - google/protobuf/any.proto\r\n * - google/protobuf/duration.proto\r\n * - google/protobuf/empty.proto\r\n * - google/protobuf/field_mask.proto\r\n * - google/protobuf/struct.proto\r\n * - google/protobuf/timestamp.proto\r\n * - google/protobuf/wrappers.proto\r\n *\r\n * @param {string} file Proto file name\r\n * @returns {INamespace|null} Root definition or `null` if not defined\r\n */\r\ncommon.get = function get(file) {\r\n return common[file] || null;\r\n};\r\n","\"use strict\";\r\n/**\r\n * Runtime message from/to plain object converters.\r\n * @namespace\r\n */\r\nvar converter = exports;\r\n\r\nvar Enum = require(15),\r\n util = require(37);\r\n\r\n/**\r\n * Generates a partial value fromObject conveter.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} prop Property reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genValuePartial_fromObject(gen, field, fieldIndex, prop) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(d%s){\", prop);\r\n for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) {\r\n if (field.repeated && values[keys[i]] === field.typeDefault) gen\r\n (\"default:\");\r\n gen\r\n (\"case%j:\", keys[i])\r\n (\"case %i:\", values[keys[i]])\r\n (\"m%s=%j\", prop, values[keys[i]])\r\n (\"break\");\r\n } gen\r\n (\"}\");\r\n } else gen\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s=types[%i].fromObject(d%s)\", prop, fieldIndex, prop);\r\n } else {\r\n var isUnsigned = false;\r\n switch (field.type) {\r\n case \"double\":\r\n case \"float\": gen\r\n (\"m%s=Number(d%s)\", prop, prop); // also catches \"NaN\", \"Infinity\"\r\n break;\r\n case \"uint32\":\r\n case \"fixed32\": gen\r\n (\"m%s=d%s>>>0\", prop, prop);\r\n break;\r\n case \"int32\":\r\n case \"sint32\":\r\n case \"sfixed32\": gen\r\n (\"m%s=d%s|0\", prop, prop);\r\n break;\r\n case \"uint64\":\r\n isUnsigned = true;\r\n // eslint-disable-line no-fallthrough\r\n case \"int64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(util.Long)\")\r\n (\"(m%s=util.Long.fromValue(d%s)).unsigned=%j\", prop, prop, isUnsigned)\r\n (\"else if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"m%s=parseInt(d%s,10)\", prop, prop)\r\n (\"else if(typeof d%s===\\\"number\\\")\", prop)\r\n (\"m%s=d%s\", prop, prop)\r\n (\"else if(typeof d%s===\\\"object\\\")\", prop)\r\n (\"m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)\", prop, prop, prop, isUnsigned ? \"true\" : \"\");\r\n break;\r\n case \"bytes\": gen\r\n (\"if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)\", prop, prop, prop)\r\n (\"else if(d%s.length)\", prop)\r\n (\"m%s=d%s\", prop, prop);\r\n break;\r\n case \"string\": gen\r\n (\"m%s=String(d%s)\", prop, prop);\r\n break;\r\n case \"bool\": gen\r\n (\"m%s=Boolean(d%s)\", prop, prop);\r\n break;\r\n /* default: gen\r\n (\"m%s=d%s\", prop, prop);\r\n break; */\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a plain object to runtime message converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.fromObject = function fromObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray;\r\n var gen = util.codegen([\"d\"], mtype.name + \"$fromObject\")\r\n (\"if(d instanceof this.ctor)\")\r\n (\"return d\");\r\n if (!fields.length) return gen\r\n (\"return new this.ctor\");\r\n gen\r\n (\"var m=new this.ctor\");\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n prop = util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"if(d%s){\", prop)\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s={}\", prop)\r\n (\"for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s\", prop, prop, prop, prop, isUnsigned ? \"true\": \"\", prop);\r\n break;\r\n case \"bytes\": gen\r\n (\"d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s\", prop, prop, prop, prop, prop);\r\n break;\r\n default: gen\r\n (\"d%s=m%s\", prop, prop);\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a runtime message to plain object converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.toObject = function toObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n if (!fields.length)\r\n return util.codegen()(\"return {}\");\r\n var gen = util.codegen([\"m\", \"o\"], mtype.name + \"$toObject\")\r\n (\"if(!o)\")\r\n (\"o={}\")\r\n (\"var d={}\");\r\n\r\n var repeatedFields = [],\r\n mapFields = [],\r\n normalFields = [],\r\n i = 0;\r\n for (; i < fields.length; ++i)\r\n if (!fields[i].partOf)\r\n ( fields[i].resolve().repeated ? repeatedFields\r\n : fields[i].map ? mapFields\r\n : normalFields).push(fields[i]);\r\n\r\n if (repeatedFields.length) { gen\r\n (\"if(o.arrays||o.defaults){\");\r\n for (i = 0; i < repeatedFields.length; ++i) gen\r\n (\"d%s=[]\", util.safeProp(repeatedFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (mapFields.length) { gen\r\n (\"if(o.objects||o.defaults){\");\r\n for (i = 0; i < mapFields.length; ++i) gen\r\n (\"d%s={}\", util.safeProp(mapFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (normalFields.length) { gen\r\n (\"if(o.defaults){\");\r\n for (i = 0; i < normalFields.length; ++i) {\r\n var field = normalFields[i],\r\n prop = util.safeProp(field.name);\r\n if (field.resolvedType instanceof Enum) gen\r\n (\"d%s=o.enums===String?%j:%j\", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault);\r\n else if (field.long) gen\r\n (\"if(util.Long){\")\r\n (\"var n=new util.Long(%i,%i,%j)\", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned)\r\n (\"d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n\", prop)\r\n (\"}else\")\r\n (\"d%s=o.longs===String?%j:%i\", prop, field.typeDefault.toString(), field.typeDefault.toNumber());\r\n else if (field.bytes) {\r\n var arrayDefault = \"[\" + Array.prototype.slice.call(field.typeDefault).join(\",\") + \"]\";\r\n gen\r\n (\"if(o.bytes===String)d%s=%j\", prop, String.fromCharCode.apply(String, field.typeDefault))\r\n (\"else{\")\r\n (\"d%s=%s\", prop, arrayDefault)\r\n (\"if(o.bytes!==Array)d%s=util.newBuffer(d%s)\", prop, prop)\r\n (\"}\");\r\n } else gen\r\n (\"d%s=%j\", prop, field.typeDefault); // also messages (=null)\r\n } gen\r\n (\"}\");\r\n }\r\n var hasKs2 = false;\r\n for (i = 0; i < fields.length; ++i) {\r\n var field = fields[i],\r\n index = mtype._fieldsArray.indexOf(field),\r\n prop = util.safeProp(field.name);\r\n if (field.map) {\r\n if (!hasKs2) { hasKs2 = true; gen\r\n (\"var ks2\");\r\n } gen\r\n (\"if(m%s&&(ks2=Object.keys(m%s)).length){\", prop, prop)\r\n (\"d%s={}\", prop)\r\n (\"for(var j=0;j>>3){\");\r\n\r\n var i = 0;\r\n for (; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n ref = \"m\" + util.safeProp(field.name); gen\r\n (\"case %i:\", field.id);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"r.skip().pos++\") // assumes id 1 + key wireType\r\n (\"if(%s===util.emptyObject)\", ref)\r\n (\"%s={}\", ref)\r\n (\"k=r.%s()\", field.keyType)\r\n (\"r.pos++\"); // assumes id 2 + value wireType\r\n if (types.long[field.keyType] !== undefined) {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=r.%s()\", ref, type);\r\n } else {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[k]=r.%s()\", ref, type);\r\n }\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n\r\n (\"if(!(%s&&%s.length))\", ref, ref)\r\n (\"%s=[]\", ref);\r\n\r\n // Packable (always check for forward and backward compatiblity)\r\n if (types.packed[type] !== undefined) gen\r\n (\"if((t&7)===2){\")\r\n (\"var c2=r.uint32()+r.pos\")\r\n (\"while(r.pos>> 0, (field.id << 3 | 4) >>> 0)\r\n : gen(\"types[%i].encode(%s,w.uint32(%i).fork()).ldelim()\", fieldIndex, ref, (field.id << 3 | 2) >>> 0);\r\n}\r\n\r\n/**\r\n * Generates an encoder specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction encoder(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var gen = util.codegen([\"m\", \"w\"], mtype.name + \"$encode\")\r\n (\"if(!w)\")\r\n (\"w=Writer.create()\");\r\n\r\n var i, ref;\r\n\r\n // \"when a message is serialized its known fields should be written sequentially by field number\"\r\n var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n index = mtype._fieldsArray.indexOf(field),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n wireType = types.basic[type];\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) {\r\n gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name) // !== undefined && !== null\r\n (\"for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType);\r\n if (wireType === undefined) gen\r\n (\"types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()\", index, ref); // can't be groups\r\n else gen\r\n (\".uint32(%i).%s(%s[ks[i]]).ldelim()\", 16 | wireType, type, ref);\r\n gen\r\n (\"}\")\r\n (\"}\");\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n (\"if(%s!=null&&%s.length){\", ref, ref); // !== undefined && !== null\r\n\r\n // Packed repeated\r\n if (field.packed && types.packed[type] !== undefined) { gen\r\n\r\n (\"w.uint32(%i).fork()\", (field.id << 3 | 2) >>> 0)\r\n (\"for(var i=0;i<%s.length;++i)\", ref)\r\n (\"w.%s(%s[i])\", type, ref)\r\n (\"w.ldelim()\");\r\n\r\n // Non-packed\r\n } else { gen\r\n\r\n (\"for(var i=0;i<%s.length;++i)\", ref);\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref + \"[i]\");\r\n else gen\r\n (\"w.uint32(%i).%s(%s[i])\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n } gen\r\n (\"}\");\r\n\r\n // Non-repeated\r\n } else {\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j))\", ref, field.name); // !== undefined && !== null\r\n\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref);\r\n else gen\r\n (\"w.uint32(%i).%s(%s)\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n }\r\n }\r\n\r\n return gen\r\n (\"return w\");\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}","\"use strict\";\r\nmodule.exports = Enum;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = \"Enum\";\r\n\r\nvar Namespace = require(23),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new enum instance.\r\n * @classdesc Reflected enum.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {Object.} [values] Enum values as an object, by name\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this enum\r\n * @param {Object.} [comments] The value comments for this enum\r\n */\r\nfunction Enum(name, values, options, comment, comments) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (values && typeof values !== \"object\")\r\n throw TypeError(\"values must be an object\");\r\n\r\n /**\r\n * Enum values by id.\r\n * @type {Object.}\r\n */\r\n this.valuesById = {};\r\n\r\n /**\r\n * Enum values by name.\r\n * @type {Object.}\r\n */\r\n this.values = Object.create(this.valuesById); // toJSON, marker\r\n\r\n /**\r\n * Enum comment text.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n\r\n /**\r\n * Value comment texts, if any.\r\n * @type {Object.}\r\n */\r\n this.comments = comments || {};\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n // Note that values inherit valuesById on their prototype which makes them a TypeScript-\r\n // compatible enum. This is used by pbts to write actual enum definitions that work for\r\n // static and reflection code alike instead of emitting generic object definitions.\r\n\r\n if (values)\r\n for (var keys = Object.keys(values), i = 0; i < keys.length; ++i)\r\n if (typeof values[keys[i]] === \"number\") // use forward entries only\r\n this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i];\r\n}\r\n\r\n/**\r\n * Enum descriptor.\r\n * @interface IEnum\r\n * @property {Object.} values Enum values\r\n * @property {Object.} [options] Enum options\r\n */\r\n\r\n/**\r\n * Constructs an enum from an enum descriptor.\r\n * @param {string} name Enum name\r\n * @param {IEnum} json Enum descriptor\r\n * @returns {Enum} Created enum\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nEnum.fromJSON = function fromJSON(name, json) {\r\n var enm = new Enum(name, json.values, json.options, json.comment, json.comments);\r\n enm.reserved = json.reserved;\r\n return enm;\r\n};\r\n\r\n/**\r\n * Converts this enum to an enum descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IEnum} Enum descriptor\r\n */\r\nEnum.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"values\" , this.values,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"comment\" , keepComments ? this.comment : undefined,\r\n \"comments\" , keepComments ? this.comments : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds a value to this enum.\r\n * @param {string} name Value name\r\n * @param {number} id Value id\r\n * @param {string} [comment] Comment, if any\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a value with this name or id\r\n */\r\nEnum.prototype.add = function add(name, id, comment) {\r\n // utilized by the parser but not by .fromJSON\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (!util.isInteger(id))\r\n throw TypeError(\"id must be an integer\");\r\n\r\n if (this.values[name] !== undefined)\r\n throw Error(\"duplicate name '\" + name + \"' in \" + this);\r\n\r\n if (this.isReservedId(id))\r\n throw Error(\"id \" + id + \" is reserved in \" + this);\r\n\r\n if (this.isReservedName(name))\r\n throw Error(\"name '\" + name + \"' is reserved in \" + this);\r\n\r\n if (this.valuesById[id] !== undefined) {\r\n if (!(this.options && this.options.allow_alias))\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n this.values[name] = id;\r\n } else\r\n this.valuesById[this.values[name] = id] = name;\r\n\r\n this.comments[name] = comment || null;\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a value from this enum\r\n * @param {string} name Value name\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `name` is not a name of this enum\r\n */\r\nEnum.prototype.remove = function remove(name) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n var val = this.values[name];\r\n if (val == null)\r\n throw Error(\"name '\" + name + \"' does not exist in \" + this);\r\n\r\n delete this.valuesById[val];\r\n delete this.values[name];\r\n delete this.comments[name];\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Field;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = \"Field\";\r\n\r\nvar Enum = require(15),\r\n types = require(36),\r\n util = require(37);\r\n\r\nvar Type; // cyclic\r\n\r\nvar ruleRe = /^required|optional|repeated$/;\r\n\r\n/**\r\n * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.\r\n * @name Field\r\n * @classdesc Reflected message field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a field from a field descriptor.\r\n * @param {string} name Field name\r\n * @param {IField} json Field descriptor\r\n * @returns {Field} Created field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nField.fromJSON = function fromJSON(name, json) {\r\n return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Field} instead.\r\n * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports FieldBase\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction Field(name, id, type, rule, extend, options, comment) {\r\n\r\n if (util.isObject(rule)) {\r\n comment = extend;\r\n options = rule;\r\n rule = extend = undefined;\r\n } else if (util.isObject(extend)) {\r\n comment = options;\r\n options = extend;\r\n extend = undefined;\r\n }\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (!util.isInteger(id) || id < 0)\r\n throw TypeError(\"id must be a non-negative integer\");\r\n\r\n if (!util.isString(type))\r\n throw TypeError(\"type must be a string\");\r\n\r\n if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))\r\n throw TypeError(\"rule must be a string rule\");\r\n\r\n if (extend !== undefined && !util.isString(extend))\r\n throw TypeError(\"extend must be a string\");\r\n\r\n /**\r\n * Field rule, if any.\r\n * @type {string|undefined}\r\n */\r\n this.rule = rule && rule !== \"optional\" ? rule : undefined; // toJSON\r\n\r\n /**\r\n * Field type.\r\n * @type {string}\r\n */\r\n this.type = type; // toJSON\r\n\r\n /**\r\n * Unique field id.\r\n * @type {number}\r\n */\r\n this.id = id; // toJSON, marker\r\n\r\n /**\r\n * Extended type if different from parent.\r\n * @type {string|undefined}\r\n */\r\n this.extend = extend || undefined; // toJSON\r\n\r\n /**\r\n * Whether this field is required.\r\n * @type {boolean}\r\n */\r\n this.required = rule === \"required\";\r\n\r\n /**\r\n * Whether this field is optional.\r\n * @type {boolean}\r\n */\r\n this.optional = !this.required;\r\n\r\n /**\r\n * Whether this field is repeated.\r\n * @type {boolean}\r\n */\r\n this.repeated = rule === \"repeated\";\r\n\r\n /**\r\n * Whether this field is a map or not.\r\n * @type {boolean}\r\n */\r\n this.map = false;\r\n\r\n /**\r\n * Message this field belongs to.\r\n * @type {Type|null}\r\n */\r\n this.message = null;\r\n\r\n /**\r\n * OneOf this field belongs to, if any,\r\n * @type {OneOf|null}\r\n */\r\n this.partOf = null;\r\n\r\n /**\r\n * The field type's default value.\r\n * @type {*}\r\n */\r\n this.typeDefault = null;\r\n\r\n /**\r\n * The field's default value on prototypes.\r\n * @type {*}\r\n */\r\n this.defaultValue = null;\r\n\r\n /**\r\n * Whether this field's value should be treated as a long.\r\n * @type {boolean}\r\n */\r\n this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;\r\n\r\n /**\r\n * Whether this field's value is a buffer.\r\n * @type {boolean}\r\n */\r\n this.bytes = type === \"bytes\";\r\n\r\n /**\r\n * Resolved type if not a basic type.\r\n * @type {Type|Enum|null}\r\n */\r\n this.resolvedType = null;\r\n\r\n /**\r\n * Sister-field within the extended type if a declaring extension field.\r\n * @type {Field|null}\r\n */\r\n this.extensionField = null;\r\n\r\n /**\r\n * Sister-field within the declaring namespace if an extended field.\r\n * @type {Field|null}\r\n */\r\n this.declaringField = null;\r\n\r\n /**\r\n * Internally remembers whether this field is packed.\r\n * @type {boolean|null}\r\n * @private\r\n */\r\n this._packed = null;\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Determines whether this field is packed. Only relevant when repeated and working with proto2.\r\n * @name Field#packed\r\n * @type {boolean}\r\n * @readonly\r\n */\r\nObject.defineProperty(Field.prototype, \"packed\", {\r\n get: function() {\r\n // defaults to packed=true if not explicity set to false\r\n if (this._packed === null)\r\n this._packed = this.getOption(\"packed\") !== false;\r\n return this._packed;\r\n }\r\n});\r\n\r\n/**\r\n * @override\r\n */\r\nField.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (name === \"packed\") // clear cached before setting\r\n this._packed = null;\r\n return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);\r\n};\r\n\r\n/**\r\n * Field descriptor.\r\n * @interface IField\r\n * @property {string} [rule=\"optional\"] Field rule\r\n * @property {string} type Field type\r\n * @property {number} id Field id\r\n * @property {Object.} [options] Field options\r\n */\r\n\r\n/**\r\n * Extension field descriptor.\r\n * @interface IExtensionField\r\n * @extends IField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Converts this field to a field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IField} Field descriptor\r\n */\r\nField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"rule\" , this.rule !== \"optional\" && this.rule || undefined,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Resolves this field's type references.\r\n * @returns {Field} `this`\r\n * @throws {Error} If any reference cannot be resolved\r\n */\r\nField.prototype.resolve = function resolve() {\r\n\r\n if (this.resolved)\r\n return this;\r\n\r\n if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it\r\n this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);\r\n if (this.resolvedType instanceof Type)\r\n this.typeDefault = null;\r\n else // instanceof Enum\r\n this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined\r\n }\r\n\r\n // use explicitly set default value if present\r\n if (this.options && this.options[\"default\"] != null) {\r\n this.typeDefault = this.options[\"default\"];\r\n if (this.resolvedType instanceof Enum && typeof this.typeDefault === \"string\")\r\n this.typeDefault = this.resolvedType.values[this.typeDefault];\r\n }\r\n\r\n // remove unnecessary options\r\n if (this.options) {\r\n if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))\r\n delete this.options.packed;\r\n if (!Object.keys(this.options).length)\r\n this.options = undefined;\r\n }\r\n\r\n // convert to internal data type if necesssary\r\n if (this.long) {\r\n this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === \"u\");\r\n\r\n /* istanbul ignore else */\r\n if (Object.freeze)\r\n Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)\r\n\r\n } else if (this.bytes && typeof this.typeDefault === \"string\") {\r\n var buf;\r\n if (util.base64.test(this.typeDefault))\r\n util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);\r\n else\r\n util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);\r\n this.typeDefault = buf;\r\n }\r\n\r\n // take special care of maps and repeated fields\r\n if (this.map)\r\n this.defaultValue = util.emptyObject;\r\n else if (this.repeated)\r\n this.defaultValue = util.emptyArray;\r\n else\r\n this.defaultValue = this.typeDefault;\r\n\r\n // ensure proper value on prototype\r\n if (this.parent instanceof Type)\r\n this.parent.ctor.prototype[this.name] = this.defaultValue;\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).\r\n * @typedef FieldDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} fieldName Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"string\"|\"bool\"|\"bytes\"|Object} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @param {T} [defaultValue] Default value\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]\r\n */\r\nField.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {\r\n\r\n // submessage: decorate the submessage and use its name as the type\r\n if (typeof fieldType === \"function\")\r\n fieldType = util.decorateType(fieldType).name;\r\n\r\n // enum reference: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldType && typeof fieldType === \"object\")\r\n fieldType = util.decorateEnum(fieldType).name;\r\n\r\n return function fieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new Field(fieldName, fieldId, fieldType, fieldRule, { \"default\": defaultValue }));\r\n };\r\n};\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {Constructor|string} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends Message\r\n * @variation 2\r\n */\r\n// like Field.d but without a default value\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nField._configure = function configure(Type_) {\r\n Type = Type_;\r\n};\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(18);\r\n\r\nprotobuf.build = \"light\";\r\n\r\n/**\r\n * A node-style callback as used by {@link load} and {@link Root#load}.\r\n * @typedef LoadCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Root} [root] Root, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} root Root namespace, defaults to create a new one if omitted.\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n */\r\nfunction load(filename, root, callback) {\r\n if (typeof root === \"function\") {\r\n callback = root;\r\n root = new protobuf.Root();\r\n } else if (!root)\r\n root = new protobuf.Root();\r\n return root.load(filename, callback);\r\n}\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Promise} Promise\r\n * @see {@link Root#load}\r\n * @variation 3\r\n */\r\n// function load(filename:string, [root:Root]):Promise\r\n\r\nprotobuf.load = load;\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only).\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n * @see {@link Root#loadSync}\r\n */\r\nfunction loadSync(filename, root) {\r\n if (!root)\r\n root = new protobuf.Root();\r\n return root.loadSync(filename);\r\n}\r\n\r\nprotobuf.loadSync = loadSync;\r\n\r\n// Serialization\r\nprotobuf.encoder = require(14);\r\nprotobuf.decoder = require(13);\r\nprotobuf.verifier = require(40);\r\nprotobuf.converter = require(12);\r\n\r\n// Reflection\r\nprotobuf.ReflectionObject = require(24);\r\nprotobuf.Namespace = require(23);\r\nprotobuf.Root = require(29);\r\nprotobuf.Enum = require(15);\r\nprotobuf.Type = require(35);\r\nprotobuf.Field = require(16);\r\nprotobuf.OneOf = require(25);\r\nprotobuf.MapField = require(20);\r\nprotobuf.Service = require(33);\r\nprotobuf.Method = require(22);\r\n\r\n// Runtime\r\nprotobuf.Message = require(21);\r\nprotobuf.wrappers = require(41);\r\n\r\n// Utility\r\nprotobuf.types = require(36);\r\nprotobuf.util = require(37);\r\n\r\n// Set up possibly cyclic reflection dependencies\r\nprotobuf.ReflectionObject._configure(protobuf.Root);\r\nprotobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum);\r\nprotobuf.Root._configure(protobuf.Type);\r\nprotobuf.Field._configure(protobuf.Type);\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(42);\r\nprotobuf.BufferWriter = require(43);\r\nprotobuf.Reader = require(27);\r\nprotobuf.BufferReader = require(28);\r\n\r\n// Utility\r\nprotobuf.util = require(39);\r\nprotobuf.rpc = require(31);\r\nprotobuf.roots = require(30);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(17);\r\n\r\nprotobuf.build = \"full\";\r\n\r\n// Parser\r\nprotobuf.tokenize = require(34);\r\nprotobuf.parse = require(26);\r\nprotobuf.common = require(11);\r\n\r\n// Configure parser\r\nprotobuf.Root._configure(protobuf.Type, protobuf.parse, protobuf.common);\r\n","\"use strict\";\r\nmodule.exports = MapField;\r\n\r\n// extends Field\r\nvar Field = require(16);\r\n((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = \"MapField\";\r\n\r\nvar types = require(36),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new map field instance.\r\n * @classdesc Reflected map field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} keyType Key type\r\n * @param {string} type Value type\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction MapField(name, id, keyType, type, options, comment) {\r\n Field.call(this, name, id, type, undefined, undefined, options, comment);\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(keyType))\r\n throw TypeError(\"keyType must be a string\");\r\n\r\n /**\r\n * Key type.\r\n * @type {string}\r\n */\r\n this.keyType = keyType; // toJSON, marker\r\n\r\n /**\r\n * Resolved key type if not a basic type.\r\n * @type {ReflectionObject|null}\r\n */\r\n this.resolvedKeyType = null;\r\n\r\n // Overrides Field#map\r\n this.map = true;\r\n}\r\n\r\n/**\r\n * Map field descriptor.\r\n * @interface IMapField\r\n * @extends {IField}\r\n * @property {string} keyType Key type\r\n */\r\n\r\n/**\r\n * Extension map field descriptor.\r\n * @interface IExtensionMapField\r\n * @extends IMapField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Constructs a map field from a map field descriptor.\r\n * @param {string} name Field name\r\n * @param {IMapField} json Map field descriptor\r\n * @returns {MapField} Created map field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMapField.fromJSON = function fromJSON(name, json) {\r\n return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this map field to a map field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMapField} Map field descriptor\r\n */\r\nMapField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"keyType\" , this.keyType,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMapField.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n\r\n // Besides a value type, map fields have a key type that may be \"any scalar type except for floating point types and bytes\"\r\n if (types.mapKey[this.keyType] === undefined)\r\n throw Error(\"invalid key type: \" + this.keyType);\r\n\r\n return Field.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Map field decorator (TypeScript).\r\n * @name MapField.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"} fieldKeyType Field key type\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"|\"bytes\"|Object|Constructor<{}>} fieldValueType Field value type\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> }\r\n */\r\nMapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) {\r\n\r\n // submessage value: decorate the submessage and use its name as the type\r\n if (typeof fieldValueType === \"function\")\r\n fieldValueType = util.decorateType(fieldValueType).name;\r\n\r\n // enum reference value: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldValueType && typeof fieldValueType === \"object\")\r\n fieldValueType = util.decorateEnum(fieldValueType).name;\r\n\r\n return function mapFieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType));\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Message;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs a new message instance.\r\n * @classdesc Abstract runtime message.\r\n * @constructor\r\n * @param {Properties} [properties] Properties to set\r\n * @template T extends object = object\r\n */\r\nfunction Message(properties) {\r\n // not used internally\r\n if (properties)\r\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\r\n this[keys[i]] = properties[keys[i]];\r\n}\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message.$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message#$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/*eslint-disable valid-jsdoc*/\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.create = function create(properties) {\r\n return this.$type.create(properties);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encode = function encode(message, writer) {\r\n return this.$type.encode(message, writer);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its length as a varint.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.$type.encodeDelimited(message, writer);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @name Message.decode\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decode = function decode(reader) {\r\n return this.$type.decode(reader);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its length as a varint.\r\n * @name Message.decodeDelimited\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decodeDelimited = function decodeDelimited(reader) {\r\n return this.$type.decodeDelimited(reader);\r\n};\r\n\r\n/**\r\n * Verifies a message of this type.\r\n * @name Message.verify\r\n * @function\r\n * @param {Object.} message Plain object to verify\r\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\r\n */\r\nMessage.verify = function verify(message) {\r\n return this.$type.verify(message);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object\r\n * @returns {T} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.fromObject = function fromObject(object) {\r\n return this.$type.fromObject(object);\r\n};\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {T} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.toObject = function toObject(message, options) {\r\n return this.$type.toObject(message, options);\r\n};\r\n\r\n/**\r\n * Converts this message to JSON.\r\n * @returns {Object.} JSON object\r\n */\r\nMessage.prototype.toJSON = function toJSON() {\r\n return this.$type.toObject(this, util.toJSONOptions);\r\n};\r\n\r\n/*eslint-enable valid-jsdoc*/","\"use strict\";\r\nmodule.exports = Method;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = \"Method\";\r\n\r\nvar util = require(37);\r\n\r\n/**\r\n * Constructs a new service method instance.\r\n * @classdesc Reflected service method.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Method name\r\n * @param {string|undefined} type Method type, usually `\"rpc\"`\r\n * @param {string} requestType Request message type\r\n * @param {string} responseType Response message type\r\n * @param {boolean|Object.} [requestStream] Whether the request is streamed\r\n * @param {boolean|Object.} [responseStream] Whether the response is streamed\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this method\r\n */\r\nfunction Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) {\r\n\r\n /* istanbul ignore next */\r\n if (util.isObject(requestStream)) {\r\n options = requestStream;\r\n requestStream = responseStream = undefined;\r\n } else if (util.isObject(responseStream)) {\r\n options = responseStream;\r\n responseStream = undefined;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!(type === undefined || util.isString(type)))\r\n throw TypeError(\"type must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(requestType))\r\n throw TypeError(\"requestType must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(responseType))\r\n throw TypeError(\"responseType must be a string\");\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Method type.\r\n * @type {string}\r\n */\r\n this.type = type || \"rpc\"; // toJSON\r\n\r\n /**\r\n * Request type.\r\n * @type {string}\r\n */\r\n this.requestType = requestType; // toJSON, marker\r\n\r\n /**\r\n * Whether requests are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.requestStream = requestStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Response type.\r\n * @type {string}\r\n */\r\n this.responseType = responseType; // toJSON\r\n\r\n /**\r\n * Whether responses are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.responseStream = responseStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Resolved request type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedRequestType = null;\r\n\r\n /**\r\n * Resolved response type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedResponseType = null;\r\n\r\n /**\r\n * Comment for this method\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Method descriptor.\r\n * @interface IMethod\r\n * @property {string} [type=\"rpc\"] Method type\r\n * @property {string} requestType Request type\r\n * @property {string} responseType Response type\r\n * @property {boolean} [requestStream=false] Whether requests are streamed\r\n * @property {boolean} [responseStream=false] Whether responses are streamed\r\n * @property {Object.} [options] Method options\r\n */\r\n\r\n/**\r\n * Constructs a method from a method descriptor.\r\n * @param {string} name Method name\r\n * @param {IMethod} json Method descriptor\r\n * @returns {Method} Created method\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMethod.fromJSON = function fromJSON(name, json) {\r\n return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this method to a method descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMethod} Method descriptor\r\n */\r\nMethod.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"type\" , this.type !== \"rpc\" && /* istanbul ignore next */ this.type || undefined,\r\n \"requestType\" , this.requestType,\r\n \"requestStream\" , this.requestStream,\r\n \"responseType\" , this.responseType,\r\n \"responseStream\" , this.responseStream,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMethod.prototype.resolve = function resolve() {\r\n\r\n /* istanbul ignore if */\r\n if (this.resolved)\r\n return this;\r\n\r\n this.resolvedRequestType = this.parent.lookupType(this.requestType);\r\n this.resolvedResponseType = this.parent.lookupType(this.responseType);\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Namespace;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = \"Namespace\";\r\n\r\nvar Field = require(16),\r\n util = require(37);\r\n\r\nvar Type, // cyclic\r\n Service,\r\n Enum;\r\n\r\n/**\r\n * Constructs a new namespace instance.\r\n * @name Namespace\r\n * @classdesc Reflected namespace.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a namespace from JSON.\r\n * @memberof Namespace\r\n * @function\r\n * @param {string} name Namespace name\r\n * @param {Object.} json JSON object\r\n * @returns {Namespace} Created namespace\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nNamespace.fromJSON = function fromJSON(name, json) {\r\n return new Namespace(name, json.options).addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Converts an array of reflection objects to JSON.\r\n * @memberof Namespace\r\n * @param {ReflectionObject[]} array Object array\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {Object.|undefined} JSON object or `undefined` when array is empty\r\n */\r\nfunction arrayToJSON(array, toJSONOptions) {\r\n if (!(array && array.length))\r\n return undefined;\r\n var obj = {};\r\n for (var i = 0; i < array.length; ++i)\r\n obj[array[i].name] = array[i].toJSON(toJSONOptions);\r\n return obj;\r\n}\r\n\r\nNamespace.arrayToJSON = arrayToJSON;\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedId = function isReservedId(reserved, id) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (typeof reserved[i] !== \"string\" && reserved[i][0] <= id && reserved[i][1] >= id)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedName = function isReservedName(reserved, name) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (reserved[i] === name)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Namespace} instead.\r\n * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports NamespaceBase\r\n * @extends ReflectionObject\r\n * @abstract\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n * @see {@link Namespace}\r\n */\r\nfunction Namespace(name, options) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Nested objects by name.\r\n * @type {Object.|undefined}\r\n */\r\n this.nested = undefined; // toJSON\r\n\r\n /**\r\n * Cached nested objects as an array.\r\n * @type {ReflectionObject[]|null}\r\n * @private\r\n */\r\n this._nestedArray = null;\r\n}\r\n\r\nfunction clearCache(namespace) {\r\n namespace._nestedArray = null;\r\n return namespace;\r\n}\r\n\r\n/**\r\n * Nested objects of this namespace as an array for iteration.\r\n * @name NamespaceBase#nestedArray\r\n * @type {ReflectionObject[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Namespace.prototype, \"nestedArray\", {\r\n get: function() {\r\n return this._nestedArray || (this._nestedArray = util.toArray(this.nested));\r\n }\r\n});\r\n\r\n/**\r\n * Namespace descriptor.\r\n * @interface INamespace\r\n * @property {Object.} [options] Namespace options\r\n * @property {Object.} [nested] Nested object descriptors\r\n */\r\n\r\n/**\r\n * Any extension field descriptor.\r\n * @typedef AnyExtensionField\r\n * @type {IExtensionField|IExtensionMapField}\r\n */\r\n\r\n/**\r\n * Any nested object descriptor.\r\n * @typedef AnyNestedObject\r\n * @type {IEnum|IType|IService|AnyExtensionField|INamespace}\r\n */\r\n// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place)\r\n\r\n/**\r\n * Converts this namespace to a namespace descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {INamespace} Namespace descriptor\r\n */\r\nNamespace.prototype.toJSON = function toJSON(toJSONOptions) {\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"nested\" , arrayToJSON(this.nestedArray, toJSONOptions)\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds nested objects to this namespace from nested object descriptors.\r\n * @param {Object.} nestedJson Any nested object descriptors\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.addJSON = function addJSON(nestedJson) {\r\n var ns = this;\r\n /* istanbul ignore else */\r\n if (nestedJson) {\r\n for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) {\r\n nested = nestedJson[names[i]];\r\n ns.add( // most to least likely\r\n ( nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : nested.id !== undefined\r\n ? Field.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets the nested object of the specified name.\r\n * @param {string} name Nested object name\r\n * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist\r\n */\r\nNamespace.prototype.get = function get(name) {\r\n return this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Gets the values of the nested {@link Enum|enum} of the specified name.\r\n * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`.\r\n * @param {string} name Nested enum name\r\n * @returns {Object.} Enum values\r\n * @throws {Error} If there is no such enum\r\n */\r\nNamespace.prototype.getEnum = function getEnum(name) {\r\n if (this.nested && this.nested[name] instanceof Enum)\r\n return this.nested[name].values;\r\n throw Error(\"no such enum: \" + name);\r\n};\r\n\r\n/**\r\n * Adds a nested object to this namespace.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name\r\n */\r\nNamespace.prototype.add = function add(object) {\r\n\r\n if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace))\r\n throw TypeError(\"object must be a valid nested object\");\r\n\r\n if (!this.nested)\r\n this.nested = {};\r\n else {\r\n var prev = this.get(object.name);\r\n if (prev) {\r\n if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) {\r\n // replace plain namespace but keep existing nested elements and options\r\n var nested = prev.nestedArray;\r\n for (var i = 0; i < nested.length; ++i)\r\n object.add(nested[i]);\r\n this.remove(prev);\r\n if (!this.nested)\r\n this.nested = {};\r\n object.setOptions(prev.options, true);\r\n\r\n } else\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n }\r\n }\r\n this.nested[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this namespace.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this namespace\r\n */\r\nNamespace.prototype.remove = function remove(object) {\r\n\r\n if (!(object instanceof ReflectionObject))\r\n throw TypeError(\"object must be a ReflectionObject\");\r\n if (object.parent !== this)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.nested[object.name];\r\n if (!Object.keys(this.nested).length)\r\n this.nested = undefined;\r\n\r\n object.onRemove(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Defines additial namespaces within this one if not yet existing.\r\n * @param {string|string[]} path Path to create\r\n * @param {*} [json] Nested types to create from JSON\r\n * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty\r\n */\r\nNamespace.prototype.define = function define(path, json) {\r\n\r\n if (util.isString(path))\r\n path = path.split(\".\");\r\n else if (!Array.isArray(path))\r\n throw TypeError(\"illegal path\");\r\n if (path && path.length && path[0] === \"\")\r\n throw Error(\"path must be relative\");\r\n\r\n var ptr = this;\r\n while (path.length > 0) {\r\n var part = path.shift();\r\n if (ptr.nested && ptr.nested[part]) {\r\n ptr = ptr.nested[part];\r\n if (!(ptr instanceof Namespace))\r\n throw Error(\"path conflicts with non-namespace objects\");\r\n } else\r\n ptr.add(ptr = new Namespace(part));\r\n }\r\n if (json)\r\n ptr.addJSON(json);\r\n return ptr;\r\n};\r\n\r\n/**\r\n * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost.\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.resolveAll = function resolveAll() {\r\n var nested = this.nestedArray, i = 0;\r\n while (i < nested.length)\r\n if (nested[i] instanceof Namespace)\r\n nested[i++].resolveAll();\r\n else\r\n nested[i++].resolve();\r\n return this.resolve();\r\n};\r\n\r\n/**\r\n * Recursively looks up the reflection object matching the specified path in the scope of this namespace.\r\n * @param {string|string[]} path Path to look up\r\n * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc.\r\n * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n */\r\nNamespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) {\r\n\r\n /* istanbul ignore next */\r\n if (typeof filterTypes === \"boolean\") {\r\n parentAlreadyChecked = filterTypes;\r\n filterTypes = undefined;\r\n } else if (filterTypes && !Array.isArray(filterTypes))\r\n filterTypes = [ filterTypes ];\r\n\r\n if (util.isString(path) && path.length) {\r\n if (path === \".\")\r\n return this.root;\r\n path = path.split(\".\");\r\n } else if (!path.length)\r\n return this;\r\n\r\n // Start at root if path is absolute\r\n if (path[0] === \"\")\r\n return this.root.lookup(path.slice(1), filterTypes);\r\n\r\n // Test if the first part matches any nested object, and if so, traverse if path contains more\r\n var found = this.get(path[0]);\r\n if (found) {\r\n if (path.length === 1) {\r\n if (!filterTypes || filterTypes.indexOf(found.constructor) > -1)\r\n return found;\r\n } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true)))\r\n return found;\r\n\r\n // Otherwise try each nested namespace\r\n } else\r\n for (var i = 0; i < this.nestedArray.length; ++i)\r\n if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true)))\r\n return found;\r\n\r\n // If there hasn't been a match, try again at the parent\r\n if (this.parent === null || parentAlreadyChecked)\r\n return null;\r\n return this.parent.lookup(path, filterTypes);\r\n};\r\n\r\n/**\r\n * Looks up the reflection object at the specified path, relative to this namespace.\r\n * @name NamespaceBase#lookup\r\n * @function\r\n * @param {string|string[]} path Path to look up\r\n * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n * @variation 2\r\n */\r\n// lookup(path: string, [parentAlreadyChecked: boolean])\r\n\r\n/**\r\n * Looks up the {@link Type|type} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type\r\n * @throws {Error} If `path` does not point to a type\r\n */\r\nNamespace.prototype.lookupType = function lookupType(path) {\r\n var found = this.lookup(path, [ Type ]);\r\n if (!found)\r\n throw Error(\"no such type: \" + path);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Enum} Looked up enum\r\n * @throws {Error} If `path` does not point to an enum\r\n */\r\nNamespace.prototype.lookupEnum = function lookupEnum(path) {\r\n var found = this.lookup(path, [ Enum ]);\r\n if (!found)\r\n throw Error(\"no such Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type or enum\r\n * @throws {Error} If `path` does not point to a type or enum\r\n */\r\nNamespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) {\r\n var found = this.lookup(path, [ Type, Enum ]);\r\n if (!found)\r\n throw Error(\"no such Type or Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Service|service} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Service} Looked up service\r\n * @throws {Error} If `path` does not point to a service\r\n */\r\nNamespace.prototype.lookupService = function lookupService(path) {\r\n var found = this.lookup(path, [ Service ]);\r\n if (!found)\r\n throw Error(\"no such Service '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nNamespace._configure = function(Type_, Service_, Enum_) {\r\n Type = Type_;\r\n Service = Service_;\r\n Enum = Enum_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = ReflectionObject;\r\n\r\nReflectionObject.className = \"ReflectionObject\";\r\n\r\nvar util = require(37);\r\n\r\nvar Root; // cyclic\r\n\r\n/**\r\n * Constructs a new reflection object instance.\r\n * @classdesc Base class of all reflection objects.\r\n * @constructor\r\n * @param {string} name Object name\r\n * @param {Object.} [options] Declared options\r\n * @abstract\r\n */\r\nfunction ReflectionObject(name, options) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (options && !util.isObject(options))\r\n throw TypeError(\"options must be an object\");\r\n\r\n /**\r\n * Options.\r\n * @type {Object.|undefined}\r\n */\r\n this.options = options; // toJSON\r\n\r\n /**\r\n * Unique name within its namespace.\r\n * @type {string}\r\n */\r\n this.name = name;\r\n\r\n /**\r\n * Parent namespace.\r\n * @type {Namespace|null}\r\n */\r\n this.parent = null;\r\n\r\n /**\r\n * Whether already resolved or not.\r\n * @type {boolean}\r\n */\r\n this.resolved = false;\r\n\r\n /**\r\n * Comment text, if any.\r\n * @type {string|null}\r\n */\r\n this.comment = null;\r\n\r\n /**\r\n * Defining file name.\r\n * @type {string|null}\r\n */\r\n this.filename = null;\r\n}\r\n\r\nObject.defineProperties(ReflectionObject.prototype, {\r\n\r\n /**\r\n * Reference to the root namespace.\r\n * @name ReflectionObject#root\r\n * @type {Root}\r\n * @readonly\r\n */\r\n root: {\r\n get: function() {\r\n var ptr = this;\r\n while (ptr.parent !== null)\r\n ptr = ptr.parent;\r\n return ptr;\r\n }\r\n },\r\n\r\n /**\r\n * Full name including leading dot.\r\n * @name ReflectionObject#fullName\r\n * @type {string}\r\n * @readonly\r\n */\r\n fullName: {\r\n get: function() {\r\n var path = [ this.name ],\r\n ptr = this.parent;\r\n while (ptr) {\r\n path.unshift(ptr.name);\r\n ptr = ptr.parent;\r\n }\r\n return path.join(\".\");\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Converts this reflection object to its descriptor representation.\r\n * @returns {Object.} Descriptor\r\n * @abstract\r\n */\r\nReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() {\r\n throw Error(); // not implemented, shouldn't happen\r\n};\r\n\r\n/**\r\n * Called when this object is added to a parent.\r\n * @param {ReflectionObject} parent Parent added to\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onAdd = function onAdd(parent) {\r\n if (this.parent && this.parent !== parent)\r\n this.parent.remove(this);\r\n this.parent = parent;\r\n this.resolved = false;\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleAdd(this);\r\n};\r\n\r\n/**\r\n * Called when this object is removed from a parent.\r\n * @param {ReflectionObject} parent Parent removed from\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onRemove = function onRemove(parent) {\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleRemove(this);\r\n this.parent = null;\r\n this.resolved = false;\r\n};\r\n\r\n/**\r\n * Resolves this objects type references.\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n if (this.root instanceof Root)\r\n this.resolved = true; // only if part of a root\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets an option value.\r\n * @param {string} name Option name\r\n * @returns {*} Option value or `undefined` if not set\r\n */\r\nReflectionObject.prototype.getOption = function getOption(name) {\r\n if (this.options)\r\n return this.options[name];\r\n return undefined;\r\n};\r\n\r\n/**\r\n * Sets an option.\r\n * @param {string} name Option name\r\n * @param {*} value Option value\r\n * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (!ifNotSet || !this.options || this.options[name] === undefined)\r\n (this.options || (this.options = {}))[name] = value;\r\n return this;\r\n};\r\n\r\n/**\r\n * Sets multiple options.\r\n * @param {Object.} options Options to set\r\n * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) {\r\n if (options)\r\n for (var keys = Object.keys(options), i = 0; i < keys.length; ++i)\r\n this.setOption(keys[i], options[keys[i]], ifNotSet);\r\n return this;\r\n};\r\n\r\n/**\r\n * Converts this instance to its string representation.\r\n * @returns {string} Class name[, space, full name]\r\n */\r\nReflectionObject.prototype.toString = function toString() {\r\n var className = this.constructor.className,\r\n fullName = this.fullName;\r\n if (fullName.length)\r\n return className + \" \" + fullName;\r\n return className;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nReflectionObject._configure = function(Root_) {\r\n Root = Root_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = OneOf;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = \"OneOf\";\r\n\r\nvar Field = require(16),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new oneof instance.\r\n * @classdesc Reflected oneof.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Oneof name\r\n * @param {string[]|Object.} [fieldNames] Field names\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction OneOf(name, fieldNames, options, comment) {\r\n if (!Array.isArray(fieldNames)) {\r\n options = fieldNames;\r\n fieldNames = undefined;\r\n }\r\n ReflectionObject.call(this, name, options);\r\n\r\n /* istanbul ignore if */\r\n if (!(fieldNames === undefined || Array.isArray(fieldNames)))\r\n throw TypeError(\"fieldNames must be an Array\");\r\n\r\n /**\r\n * Field names that belong to this oneof.\r\n * @type {string[]}\r\n */\r\n this.oneof = fieldNames || []; // toJSON, marker\r\n\r\n /**\r\n * Fields that belong to this oneof as an array for iteration.\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Oneof descriptor.\r\n * @interface IOneOf\r\n * @property {Array.} oneof Oneof field names\r\n * @property {Object.} [options] Oneof options\r\n */\r\n\r\n/**\r\n * Constructs a oneof from a oneof descriptor.\r\n * @param {string} name Oneof name\r\n * @param {IOneOf} json Oneof descriptor\r\n * @returns {OneOf} Created oneof\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nOneOf.fromJSON = function fromJSON(name, json) {\r\n return new OneOf(name, json.oneof, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this oneof to a oneof descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IOneOf} Oneof descriptor\r\n */\r\nOneOf.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"oneof\" , this.oneof,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds the fields of the specified oneof to the parent if not already done so.\r\n * @param {OneOf} oneof The oneof\r\n * @returns {undefined}\r\n * @inner\r\n * @ignore\r\n */\r\nfunction addFieldsToParent(oneof) {\r\n if (oneof.parent)\r\n for (var i = 0; i < oneof.fieldsArray.length; ++i)\r\n if (!oneof.fieldsArray[i].parent)\r\n oneof.parent.add(oneof.fieldsArray[i]);\r\n}\r\n\r\n/**\r\n * Adds a field to this oneof and removes it from its current parent, if any.\r\n * @param {Field} field Field to add\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.add = function add(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n if (field.parent && field.parent !== this.parent)\r\n field.parent.remove(field);\r\n this.oneof.push(field.name);\r\n this.fieldsArray.push(field);\r\n field.partOf = this; // field.parent remains null\r\n addFieldsToParent(this);\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a field from this oneof and puts it back to the oneof's parent.\r\n * @param {Field} field Field to remove\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.remove = function remove(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n var index = this.fieldsArray.indexOf(field);\r\n\r\n /* istanbul ignore if */\r\n if (index < 0)\r\n throw Error(field + \" is not a member of \" + this);\r\n\r\n this.fieldsArray.splice(index, 1);\r\n index = this.oneof.indexOf(field.name);\r\n\r\n /* istanbul ignore else */\r\n if (index > -1) // theoretical\r\n this.oneof.splice(index, 1);\r\n\r\n field.partOf = null;\r\n return this;\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onAdd = function onAdd(parent) {\r\n ReflectionObject.prototype.onAdd.call(this, parent);\r\n var self = this;\r\n // Collect present fields\r\n for (var i = 0; i < this.oneof.length; ++i) {\r\n var field = parent.get(this.oneof[i]);\r\n if (field && !field.partOf) {\r\n field.partOf = self;\r\n self.fieldsArray.push(field);\r\n }\r\n }\r\n // Add not yet present fields\r\n addFieldsToParent(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onRemove = function onRemove(parent) {\r\n for (var i = 0, field; i < this.fieldsArray.length; ++i)\r\n if ((field = this.fieldsArray[i]).parent)\r\n field.parent.remove(field);\r\n ReflectionObject.prototype.onRemove.call(this, parent);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link OneOf.d} (TypeScript).\r\n * @typedef OneOfDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} oneofName OneOf name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * OneOf decorator (TypeScript).\r\n * @function\r\n * @param {...string} fieldNames Field names\r\n * @returns {OneOfDecorator} Decorator function\r\n * @template T extends string\r\n */\r\nOneOf.d = function decorateOneOf() {\r\n var fieldNames = new Array(arguments.length),\r\n index = 0;\r\n while (index < arguments.length)\r\n fieldNames[index] = arguments[index++];\r\n return function oneOfDecorator(prototype, oneofName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new OneOf(oneofName, fieldNames));\r\n Object.defineProperty(prototype, oneofName, {\r\n get: util.oneOfGetter(fieldNames),\r\n set: util.oneOfSetter(fieldNames)\r\n });\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = parse;\r\n\r\nparse.filename = null;\r\nparse.defaults = { keepCase: false };\r\n\r\nvar tokenize = require(34),\r\n Root = require(29),\r\n Type = require(35),\r\n Field = require(16),\r\n MapField = require(20),\r\n OneOf = require(25),\r\n Enum = require(15),\r\n Service = require(33),\r\n Method = require(22),\r\n types = require(36),\r\n util = require(37);\r\n\r\nvar base10Re = /^[1-9][0-9]*$/,\r\n base10NegRe = /^-?[1-9][0-9]*$/,\r\n base16Re = /^0[x][0-9a-fA-F]+$/,\r\n base16NegRe = /^-?0[x][0-9a-fA-F]+$/,\r\n base8Re = /^0[0-7]+$/,\r\n base8NegRe = /^-?0[0-7]+$/,\r\n numberRe = /^(?![eE])[0-9]*(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?$/,\r\n nameRe = /^[a-zA-Z_][a-zA-Z_0-9]*$/,\r\n typeRefRe = /^(?:\\.?[a-zA-Z_][a-zA-Z_0-9]*)(?:\\.[a-zA-Z_][a-zA-Z_0-9]*)*$/,\r\n fqTypeRefRe = /^(?:\\.[a-zA-Z_][a-zA-Z_0-9]*)+$/;\r\n\r\n/**\r\n * Result object returned from {@link parse}.\r\n * @interface IParserResult\r\n * @property {string|undefined} package Package name, if declared\r\n * @property {string[]|undefined} imports Imports, if any\r\n * @property {string[]|undefined} weakImports Weak imports, if any\r\n * @property {string|undefined} syntax Syntax, if specified (either `\"proto2\"` or `\"proto3\"`)\r\n * @property {Root} root Populated root instance\r\n */\r\n\r\n/**\r\n * Options modifying the behavior of {@link parse}.\r\n * @interface IParseOptions\r\n * @property {boolean} [keepCase=false] Keeps field casing instead of converting to camel case\r\n * @property {boolean} [alternateCommentMode=false] Recognize double-slash comments in addition to doc-block comments.\r\n */\r\n\r\n/**\r\n * Options modifying the behavior of JSON serialization.\r\n * @interface IToJSONOptions\r\n * @property {boolean} [keepComments=false] Serializes comments.\r\n */\r\n\r\n/**\r\n * Parses the given .proto source and returns an object with the parsed contents.\r\n * @param {string} source Source contents\r\n * @param {Root} root Root to populate\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {IParserResult} Parser result\r\n * @property {string} filename=null Currently processing file name for error reporting, if known\r\n * @property {IParseOptions} defaults Default {@link IParseOptions}\r\n */\r\nfunction parse(source, root, options) {\r\n /* eslint-disable callback-return */\r\n if (!(root instanceof Root)) {\r\n options = root;\r\n root = new Root();\r\n }\r\n if (!options)\r\n options = parse.defaults;\r\n\r\n var tn = tokenize(source, options.alternateCommentMode || false),\r\n next = tn.next,\r\n push = tn.push,\r\n peek = tn.peek,\r\n skip = tn.skip,\r\n cmnt = tn.cmnt;\r\n\r\n var head = true,\r\n pkg,\r\n imports,\r\n weakImports,\r\n syntax,\r\n isProto3 = false;\r\n\r\n var ptr = root;\r\n\r\n var applyCase = options.keepCase ? function(name) { return name; } : util.camelCase;\r\n\r\n /* istanbul ignore next */\r\n function illegal(token, name, insideTryCatch) {\r\n var filename = parse.filename;\r\n if (!insideTryCatch)\r\n parse.filename = null;\r\n return Error(\"illegal \" + (name || \"token\") + \" '\" + token + \"' (\" + (filename ? filename + \", \" : \"\") + \"line \" + tn.line + \")\");\r\n }\r\n\r\n function readString() {\r\n var values = [],\r\n token;\r\n do {\r\n /* istanbul ignore if */\r\n if ((token = next()) !== \"\\\"\" && token !== \"'\")\r\n throw illegal(token);\r\n\r\n values.push(next());\r\n skip(token);\r\n token = peek();\r\n } while (token === \"\\\"\" || token === \"'\");\r\n return values.join(\"\");\r\n }\r\n\r\n function readValue(acceptTypeRef) {\r\n var token = next();\r\n switch (token) {\r\n case \"'\":\r\n case \"\\\"\":\r\n push(token);\r\n return readString();\r\n case \"true\": case \"TRUE\":\r\n return true;\r\n case \"false\": case \"FALSE\":\r\n return false;\r\n }\r\n try {\r\n return parseNumber(token, /* insideTryCatch */ true);\r\n } catch (e) {\r\n\r\n /* istanbul ignore else */\r\n if (acceptTypeRef && typeRefRe.test(token))\r\n return token;\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"value\");\r\n }\r\n }\r\n\r\n function readRanges(target, acceptStrings) {\r\n var token, start;\r\n do {\r\n if (acceptStrings && ((token = peek()) === \"\\\"\" || token === \"'\"))\r\n target.push(readString());\r\n else\r\n target.push([ start = parseId(next()), skip(\"to\", true) ? parseId(next()) : start ]);\r\n } while (skip(\",\", true));\r\n skip(\";\");\r\n }\r\n\r\n function parseNumber(token, insideTryCatch) {\r\n var sign = 1;\r\n if (token.charAt(0) === \"-\") {\r\n sign = -1;\r\n token = token.substring(1);\r\n }\r\n switch (token) {\r\n case \"inf\": case \"INF\": case \"Inf\":\r\n return sign * Infinity;\r\n case \"nan\": case \"NAN\": case \"Nan\": case \"NaN\":\r\n return NaN;\r\n case \"0\":\r\n return 0;\r\n }\r\n if (base10Re.test(token))\r\n return sign * parseInt(token, 10);\r\n if (base16Re.test(token))\r\n return sign * parseInt(token, 16);\r\n if (base8Re.test(token))\r\n return sign * parseInt(token, 8);\r\n\r\n /* istanbul ignore else */\r\n if (numberRe.test(token))\r\n return sign * parseFloat(token);\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"number\", insideTryCatch);\r\n }\r\n\r\n function parseId(token, acceptNegative) {\r\n switch (token) {\r\n case \"max\": case \"MAX\": case \"Max\":\r\n return 536870911;\r\n case \"0\":\r\n return 0;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!acceptNegative && token.charAt(0) === \"-\")\r\n throw illegal(token, \"id\");\r\n\r\n if (base10NegRe.test(token))\r\n return parseInt(token, 10);\r\n if (base16NegRe.test(token))\r\n return parseInt(token, 16);\r\n\r\n /* istanbul ignore else */\r\n if (base8NegRe.test(token))\r\n return parseInt(token, 8);\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"id\");\r\n }\r\n\r\n function parsePackage() {\r\n\r\n /* istanbul ignore if */\r\n if (pkg !== undefined)\r\n throw illegal(\"package\");\r\n\r\n pkg = next();\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(pkg))\r\n throw illegal(pkg, \"name\");\r\n\r\n ptr = ptr.define(pkg);\r\n skip(\";\");\r\n }\r\n\r\n function parseImport() {\r\n var token = peek();\r\n var whichImports;\r\n switch (token) {\r\n case \"weak\":\r\n whichImports = weakImports || (weakImports = []);\r\n next();\r\n break;\r\n case \"public\":\r\n next();\r\n // eslint-disable-line no-fallthrough\r\n default:\r\n whichImports = imports || (imports = []);\r\n break;\r\n }\r\n token = readString();\r\n skip(\";\");\r\n whichImports.push(token);\r\n }\r\n\r\n function parseSyntax() {\r\n skip(\"=\");\r\n syntax = readString();\r\n isProto3 = syntax === \"proto3\";\r\n\r\n /* istanbul ignore if */\r\n if (!isProto3 && syntax !== \"proto2\")\r\n throw illegal(syntax, \"syntax\");\r\n\r\n skip(\";\");\r\n }\r\n\r\n function parseCommon(parent, token) {\r\n switch (token) {\r\n\r\n case \"option\":\r\n parseOption(parent, token);\r\n skip(\";\");\r\n return true;\r\n\r\n case \"message\":\r\n parseType(parent, token);\r\n return true;\r\n\r\n case \"enum\":\r\n parseEnum(parent, token);\r\n return true;\r\n\r\n case \"service\":\r\n parseService(parent, token);\r\n return true;\r\n\r\n case \"extend\":\r\n parseExtension(parent, token);\r\n return true;\r\n }\r\n return false;\r\n }\r\n\r\n function ifBlock(obj, fnIf, fnElse) {\r\n var trailingLine = tn.line;\r\n if (obj) {\r\n obj.comment = cmnt(); // try block-type comment\r\n obj.filename = parse.filename;\r\n }\r\n if (skip(\"{\", true)) {\r\n var token;\r\n while ((token = next()) !== \"}\")\r\n fnIf(token);\r\n skip(\";\", true);\r\n } else {\r\n if (fnElse)\r\n fnElse();\r\n skip(\";\");\r\n if (obj && typeof obj.comment !== \"string\")\r\n obj.comment = cmnt(trailingLine); // try line-type comment if no block\r\n }\r\n }\r\n\r\n function parseType(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"type name\");\r\n\r\n var type = new Type(token);\r\n ifBlock(type, function parseType_block(token) {\r\n if (parseCommon(type, token))\r\n return;\r\n\r\n switch (token) {\r\n\r\n case \"map\":\r\n parseMapField(type, token);\r\n break;\r\n\r\n case \"required\":\r\n case \"optional\":\r\n case \"repeated\":\r\n parseField(type, token);\r\n break;\r\n\r\n case \"oneof\":\r\n parseOneOf(type, token);\r\n break;\r\n\r\n case \"extensions\":\r\n readRanges(type.extensions || (type.extensions = []));\r\n break;\r\n\r\n case \"reserved\":\r\n readRanges(type.reserved || (type.reserved = []), true);\r\n break;\r\n\r\n default:\r\n /* istanbul ignore if */\r\n if (!isProto3 || !typeRefRe.test(token))\r\n throw illegal(token);\r\n\r\n push(token);\r\n parseField(type, \"optional\");\r\n break;\r\n }\r\n });\r\n parent.add(type);\r\n }\r\n\r\n function parseField(parent, rule, extend) {\r\n var type = next();\r\n if (type === \"group\") {\r\n parseGroup(parent, rule);\r\n return;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(type))\r\n throw illegal(type, \"type\");\r\n\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n name = applyCase(name);\r\n skip(\"=\");\r\n\r\n var field = new Field(name, parseId(next()), type, rule, extend);\r\n ifBlock(field, function parseField_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(field, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseField_line() {\r\n parseInlineOptions(field);\r\n });\r\n parent.add(field);\r\n\r\n // JSON defaults to packed=true if not set so we have to set packed=false explicity when\r\n // parsing proto2 descriptors without the option, where applicable. This must be done for\r\n // all known packable types and anything that could be an enum (= is not a basic type).\r\n if (!isProto3 && field.repeated && (types.packed[type] !== undefined || types.basic[type] === undefined))\r\n field.setOption(\"packed\", false, /* ifNotSet */ true);\r\n }\r\n\r\n function parseGroup(parent, rule) {\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n var fieldName = util.lcFirst(name);\r\n if (name === fieldName)\r\n name = util.ucFirst(name);\r\n skip(\"=\");\r\n var id = parseId(next());\r\n var type = new Type(name);\r\n type.group = true;\r\n var field = new Field(fieldName, id, name, rule);\r\n field.filename = parse.filename;\r\n ifBlock(type, function parseGroup_block(token) {\r\n switch (token) {\r\n\r\n case \"option\":\r\n parseOption(type, token);\r\n skip(\";\");\r\n break;\r\n\r\n case \"required\":\r\n case \"optional\":\r\n case \"repeated\":\r\n parseField(type, token);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw illegal(token); // there are no groups with proto3 semantics\r\n }\r\n });\r\n parent.add(type)\r\n .add(field);\r\n }\r\n\r\n function parseMapField(parent) {\r\n skip(\"<\");\r\n var keyType = next();\r\n\r\n /* istanbul ignore if */\r\n if (types.mapKey[keyType] === undefined)\r\n throw illegal(keyType, \"type\");\r\n\r\n skip(\",\");\r\n var valueType = next();\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(valueType))\r\n throw illegal(valueType, \"type\");\r\n\r\n skip(\">\");\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n skip(\"=\");\r\n var field = new MapField(applyCase(name), parseId(next()), keyType, valueType);\r\n ifBlock(field, function parseMapField_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(field, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseMapField_line() {\r\n parseInlineOptions(field);\r\n });\r\n parent.add(field);\r\n }\r\n\r\n function parseOneOf(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var oneof = new OneOf(applyCase(token));\r\n ifBlock(oneof, function parseOneOf_block(token) {\r\n if (token === \"option\") {\r\n parseOption(oneof, token);\r\n skip(\";\");\r\n } else {\r\n push(token);\r\n parseField(oneof, \"optional\");\r\n }\r\n });\r\n parent.add(oneof);\r\n }\r\n\r\n function parseEnum(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var enm = new Enum(token);\r\n ifBlock(enm, function parseEnum_block(token) {\r\n switch(token) {\r\n case \"option\":\r\n parseOption(enm, token);\r\n skip(\";\");\r\n break;\r\n\r\n case \"reserved\":\r\n readRanges(enm.reserved || (enm.reserved = []), true);\r\n break;\r\n\r\n default:\r\n parseEnumValue(enm, token);\r\n }\r\n });\r\n parent.add(enm);\r\n }\r\n\r\n function parseEnumValue(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token))\r\n throw illegal(token, \"name\");\r\n\r\n skip(\"=\");\r\n var value = parseId(next(), true),\r\n dummy = {};\r\n ifBlock(dummy, function parseEnumValue_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(dummy, token); // skip\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseEnumValue_line() {\r\n parseInlineOptions(dummy); // skip\r\n });\r\n parent.add(token, value, dummy.comment);\r\n }\r\n\r\n function parseOption(parent, token) {\r\n var isCustom = skip(\"(\", true);\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var name = token;\r\n if (isCustom) {\r\n skip(\")\");\r\n name = \"(\" + name + \")\";\r\n token = peek();\r\n if (fqTypeRefRe.test(token)) {\r\n name += token;\r\n next();\r\n }\r\n }\r\n skip(\"=\");\r\n parseOptionValue(parent, name);\r\n }\r\n\r\n function parseOptionValue(parent, name) {\r\n if (skip(\"{\", true)) { // { a: \"foo\" b { c: \"bar\" } }\r\n do {\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n if (peek() === \"{\")\r\n parseOptionValue(parent, name + \".\" + token);\r\n else {\r\n skip(\":\");\r\n if (peek() === \"{\")\r\n parseOptionValue(parent, name + \".\" + token);\r\n else\r\n setOption(parent, name + \".\" + token, readValue(true));\r\n }\r\n skip(\",\", true);\r\n } while (!skip(\"}\", true));\r\n } else\r\n setOption(parent, name, readValue(true));\r\n // Does not enforce a delimiter to be universal\r\n }\r\n\r\n function setOption(parent, name, value) {\r\n if (parent.setOption)\r\n parent.setOption(name, value);\r\n }\r\n\r\n function parseInlineOptions(parent) {\r\n if (skip(\"[\", true)) {\r\n do {\r\n parseOption(parent, \"option\");\r\n } while (skip(\",\", true));\r\n skip(\"]\");\r\n }\r\n return parent;\r\n }\r\n\r\n function parseService(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"service name\");\r\n\r\n var service = new Service(token);\r\n ifBlock(service, function parseService_block(token) {\r\n if (parseCommon(service, token))\r\n return;\r\n\r\n /* istanbul ignore else */\r\n if (token === \"rpc\")\r\n parseMethod(service, token);\r\n else\r\n throw illegal(token);\r\n });\r\n parent.add(service);\r\n }\r\n\r\n function parseMethod(parent, token) {\r\n var type = token;\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var name = token,\r\n requestType, requestStream,\r\n responseType, responseStream;\r\n\r\n skip(\"(\");\r\n if (skip(\"stream\", true))\r\n requestStream = true;\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token);\r\n\r\n requestType = token;\r\n skip(\")\"); skip(\"returns\"); skip(\"(\");\r\n if (skip(\"stream\", true))\r\n responseStream = true;\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token);\r\n\r\n responseType = token;\r\n skip(\")\");\r\n\r\n var method = new Method(name, type, requestType, responseType, requestStream, responseStream);\r\n ifBlock(method, function parseMethod_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(method, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n });\r\n parent.add(method);\r\n }\r\n\r\n function parseExtension(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token, \"reference\");\r\n\r\n var reference = token;\r\n ifBlock(null, function parseExtension_block(token) {\r\n switch (token) {\r\n\r\n case \"required\":\r\n case \"repeated\":\r\n case \"optional\":\r\n parseField(parent, token, reference);\r\n break;\r\n\r\n default:\r\n /* istanbul ignore if */\r\n if (!isProto3 || !typeRefRe.test(token))\r\n throw illegal(token);\r\n push(token);\r\n parseField(parent, \"optional\", reference);\r\n break;\r\n }\r\n });\r\n }\r\n\r\n var token;\r\n while ((token = next()) !== null) {\r\n switch (token) {\r\n\r\n case \"package\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parsePackage();\r\n break;\r\n\r\n case \"import\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseImport();\r\n break;\r\n\r\n case \"syntax\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseSyntax();\r\n break;\r\n\r\n case \"option\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseOption(ptr, token);\r\n skip(\";\");\r\n break;\r\n\r\n default:\r\n\r\n /* istanbul ignore else */\r\n if (parseCommon(ptr, token)) {\r\n head = false;\r\n continue;\r\n }\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token);\r\n }\r\n }\r\n\r\n parse.filename = null;\r\n return {\r\n \"package\" : pkg,\r\n \"imports\" : imports,\r\n weakImports : weakImports,\r\n syntax : syntax,\r\n root : root\r\n };\r\n}\r\n\r\n/**\r\n * Parses the given .proto source and returns an object with the parsed contents.\r\n * @name parse\r\n * @function\r\n * @param {string} source Source contents\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {IParserResult} Parser result\r\n * @property {string} filename=null Currently processing file name for error reporting, if known\r\n * @property {IParseOptions} defaults Default {@link IParseOptions}\r\n * @variation 2\r\n */\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(39);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(27);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = Root;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = \"Root\";\r\n\r\nvar Field = require(16),\r\n Enum = require(15),\r\n OneOf = require(25),\r\n util = require(37);\r\n\r\nvar Type, // cyclic\r\n parse, // might be excluded\r\n common; // \"\r\n\r\n/**\r\n * Constructs a new root namespace instance.\r\n * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {Object.} [options] Top level options\r\n */\r\nfunction Root(options) {\r\n Namespace.call(this, \"\", options);\r\n\r\n /**\r\n * Deferred extension fields.\r\n * @type {Field[]}\r\n */\r\n this.deferred = [];\r\n\r\n /**\r\n * Resolved file names of loaded files.\r\n * @type {string[]}\r\n */\r\n this.files = [];\r\n}\r\n\r\n/**\r\n * Loads a namespace descriptor into a root namespace.\r\n * @param {INamespace} json Nameespace descriptor\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted\r\n * @returns {Root} Root namespace\r\n */\r\nRoot.fromJSON = function fromJSON(json, root) {\r\n if (!root)\r\n root = new Root();\r\n if (json.options)\r\n root.setOptions(json.options);\r\n return root.addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Resolves the path of an imported file, relative to the importing origin.\r\n * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories.\r\n * @function\r\n * @param {string} origin The file name of the importing file\r\n * @param {string} target The file name being imported\r\n * @returns {string|null} Resolved path to `target` or `null` to skip the file\r\n */\r\nRoot.prototype.resolvePath = util.path.resolve;\r\n\r\n// A symbol-like function to safely signal synchronous loading\r\n/* istanbul ignore next */\r\nfunction SYNC() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} options Parse options\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nRoot.prototype.load = function load(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = undefined;\r\n }\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(load, self, filename, options);\r\n\r\n var sync = callback === SYNC; // undocumented\r\n\r\n // Finishes loading by calling the callback (exactly once)\r\n function finish(err, root) {\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return;\r\n var cb = callback;\r\n callback = null;\r\n if (sync)\r\n throw err;\r\n cb(err, root);\r\n }\r\n\r\n // Processes a single file\r\n function process(filename, source) {\r\n try {\r\n if (util.isString(source) && source.charAt(0) === \"{\")\r\n source = JSON.parse(source);\r\n if (!util.isString(source))\r\n self.setOptions(source.options).addJSON(source.nested);\r\n else {\r\n parse.filename = filename;\r\n var parsed = parse(source, self, options),\r\n resolved,\r\n i = 0;\r\n if (parsed.imports)\r\n for (; i < parsed.imports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.imports[i]))\r\n fetch(resolved);\r\n if (parsed.weakImports)\r\n for (i = 0; i < parsed.weakImports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.weakImports[i]))\r\n fetch(resolved, true);\r\n }\r\n } catch (err) {\r\n finish(err);\r\n }\r\n if (!sync && !queued)\r\n finish(null, self); // only once anyway\r\n }\r\n\r\n // Fetches a single file\r\n function fetch(filename, weak) {\r\n\r\n // Strip path if this file references a bundled definition\r\n var idx = filename.lastIndexOf(\"google/protobuf/\");\r\n if (idx > -1) {\r\n var altname = filename.substring(idx);\r\n if (altname in common)\r\n filename = altname;\r\n }\r\n\r\n // Skip if already loaded / attempted\r\n if (self.files.indexOf(filename) > -1)\r\n return;\r\n self.files.push(filename);\r\n\r\n // Shortcut bundled definitions\r\n if (filename in common) {\r\n if (sync)\r\n process(filename, common[filename]);\r\n else {\r\n ++queued;\r\n setTimeout(function() {\r\n --queued;\r\n process(filename, common[filename]);\r\n });\r\n }\r\n return;\r\n }\r\n\r\n // Otherwise fetch from disk or network\r\n if (sync) {\r\n var source;\r\n try {\r\n source = util.fs.readFileSync(filename).toString(\"utf8\");\r\n } catch (err) {\r\n if (!weak)\r\n finish(err);\r\n return;\r\n }\r\n process(filename, source);\r\n } else {\r\n ++queued;\r\n util.fetch(filename, function(err, source) {\r\n --queued;\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return; // terminated meanwhile\r\n if (err) {\r\n /* istanbul ignore else */\r\n if (!weak)\r\n finish(err);\r\n else if (!queued) // can't be covered reliably\r\n finish(null, self);\r\n return;\r\n }\r\n process(filename, source);\r\n });\r\n }\r\n }\r\n var queued = 0;\r\n\r\n // Assembling the root namespace doesn't require working type\r\n // references anymore, so we can load everything in parallel\r\n if (util.isString(filename))\r\n filename = [ filename ];\r\n for (var i = 0, resolved; i < filename.length; ++i)\r\n if (resolved = self.resolvePath(\"\", filename[i]))\r\n fetch(resolved);\r\n\r\n if (sync)\r\n return self;\r\n if (!queued)\r\n finish(null, self);\r\n return undefined;\r\n};\r\n// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n// function load(filename:string, [options:IParseOptions]):Promise\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only).\r\n * @function Root#loadSync\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n */\r\nRoot.prototype.loadSync = function loadSync(filename, options) {\r\n if (!util.isNode)\r\n throw Error(\"not supported\");\r\n return this.load(filename, options, SYNC);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nRoot.prototype.resolveAll = function resolveAll() {\r\n if (this.deferred.length)\r\n throw Error(\"unresolvable extensions: \" + this.deferred.map(function(field) {\r\n return \"'extend \" + field.extend + \"' in \" + field.parent.fullName;\r\n }).join(\", \"));\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n// only uppercased (and thus conflict-free) children are exposed, see below\r\nvar exposeRe = /^[A-Z]/;\r\n\r\n/**\r\n * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type.\r\n * @param {Root} root Root instance\r\n * @param {Field} field Declaring extension field witin the declaring type\r\n * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise\r\n * @inner\r\n * @ignore\r\n */\r\nfunction tryHandleExtension(root, field) {\r\n var extendedType = field.parent.lookup(field.extend);\r\n if (extendedType) {\r\n var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options);\r\n sisterField.declaringField = field;\r\n field.extensionField = sisterField;\r\n extendedType.add(sisterField);\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * Called when any object is added to this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object added\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleAdd = function _handleAdd(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField)\r\n if (!tryHandleExtension(this, object))\r\n this.deferred.push(object);\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object.values; // expose enum values as property of its parent\r\n\r\n } else if (!(object instanceof OneOf)) /* everything else is a namespace */ {\r\n\r\n if (object instanceof Type) // Try to handle any deferred extensions\r\n for (var i = 0; i < this.deferred.length;)\r\n if (tryHandleExtension(this, this.deferred[i]))\r\n this.deferred.splice(i, 1);\r\n else\r\n ++i;\r\n for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace\r\n this._handleAdd(object._nestedArray[j]);\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object; // expose namespace as property of its parent\r\n }\r\n\r\n // The above also adds uppercased (and thus conflict-free) nested types, services and enums as\r\n // properties of namespaces just like static code does. This allows using a .d.ts generated for\r\n // a static module with reflection-based solutions where the condition is met.\r\n};\r\n\r\n/**\r\n * Called when any object is removed from this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object removed\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleRemove = function _handleRemove(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field */ object.extend !== undefined) {\r\n if (/* already handled */ object.extensionField) { // remove its sister field\r\n object.extensionField.parent.remove(object.extensionField);\r\n object.extensionField = null;\r\n } else { // cancel the extension\r\n var index = this.deferred.indexOf(object);\r\n /* istanbul ignore else */\r\n if (index > -1)\r\n this.deferred.splice(index, 1);\r\n }\r\n }\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose enum values\r\n\r\n } else if (object instanceof Namespace) {\r\n\r\n for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace\r\n this._handleRemove(object._nestedArray[i]);\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose namespaces\r\n\r\n }\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nRoot._configure = function(Type_, parse_, common_) {\r\n Type = Type_;\r\n parse = parse_;\r\n common = common_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(32);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(39);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = \"Service\";\r\n\r\nvar Method = require(22),\r\n util = require(37),\r\n rpc = require(31);\r\n\r\n/**\r\n * Constructs a new service instance.\r\n * @classdesc Reflected service.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Service name\r\n * @param {Object.} [options] Service options\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nfunction Service(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Service methods.\r\n * @type {Object.}\r\n */\r\n this.methods = {}; // toJSON, marker\r\n\r\n /**\r\n * Cached methods as an array.\r\n * @type {Method[]|null}\r\n * @private\r\n */\r\n this._methodsArray = null;\r\n}\r\n\r\n/**\r\n * Service descriptor.\r\n * @interface IService\r\n * @extends INamespace\r\n * @property {Object.} methods Method descriptors\r\n */\r\n\r\n/**\r\n * Constructs a service from a service descriptor.\r\n * @param {string} name Service name\r\n * @param {IService} json Service descriptor\r\n * @returns {Service} Created service\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nService.fromJSON = function fromJSON(name, json) {\r\n var service = new Service(name, json.options);\r\n /* istanbul ignore else */\r\n if (json.methods)\r\n for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i)\r\n service.add(Method.fromJSON(names[i], json.methods[names[i]]));\r\n if (json.nested)\r\n service.addJSON(json.nested);\r\n service.comment = json.comment;\r\n return service;\r\n};\r\n\r\n/**\r\n * Converts this service to a service descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IService} Service descriptor\r\n */\r\nService.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"methods\" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {},\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Methods of this service as an array for iteration.\r\n * @name Service#methodsArray\r\n * @type {Method[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Service.prototype, \"methodsArray\", {\r\n get: function() {\r\n return this._methodsArray || (this._methodsArray = util.toArray(this.methods));\r\n }\r\n});\r\n\r\nfunction clearCache(service) {\r\n service._methodsArray = null;\r\n return service;\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.get = function get(name) {\r\n return this.methods[name]\r\n || Namespace.prototype.get.call(this, name);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.resolveAll = function resolveAll() {\r\n var methods = this.methodsArray;\r\n for (var i = 0; i < methods.length; ++i)\r\n methods[i].resolve();\r\n return Namespace.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.add = function add(object) {\r\n\r\n /* istanbul ignore if */\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Method) {\r\n this.methods[object.name] = object;\r\n object.parent = this;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.remove = function remove(object) {\r\n if (object instanceof Method) {\r\n\r\n /* istanbul ignore if */\r\n if (this.methods[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.methods[object.name];\r\n object.parent = null;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Creates a runtime service using the specified rpc implementation.\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed.\r\n */\r\nService.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) {\r\n var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited);\r\n for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) {\r\n var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\\w_]/g, \"\");\r\n rpcService[methodName] = util.codegen([\"r\",\"c\"], util.isReserved(methodName) ? methodName + \"_\" : methodName)(\"return this.rpcCall(m,q,s,r,c)\")({\r\n m: method,\r\n q: method.resolvedRequestType.ctor,\r\n s: method.resolvedResponseType.ctor\r\n });\r\n }\r\n return rpcService;\r\n};\r\n","\"use strict\";\r\nmodule.exports = tokenize;\r\n\r\nvar delimRe = /[\\s{}=;:[\\],'\"()<>]/g,\r\n stringDoubleRe = /(?:\"([^\"\\\\]*(?:\\\\.[^\"\\\\]*)*)\")/g,\r\n stringSingleRe = /(?:'([^'\\\\]*(?:\\\\.[^'\\\\]*)*)')/g;\r\n\r\nvar setCommentRe = /^ *[*/]+ */,\r\n setCommentAltRe = /^\\s*\\*?\\/*/,\r\n setCommentSplitRe = /\\n/g,\r\n whitespaceRe = /\\s/,\r\n unescapeRe = /\\\\(.?)/g;\r\n\r\nvar unescapeMap = {\r\n \"0\": \"\\0\",\r\n \"r\": \"\\r\",\r\n \"n\": \"\\n\",\r\n \"t\": \"\\t\"\r\n};\r\n\r\n/**\r\n * Unescapes a string.\r\n * @param {string} str String to unescape\r\n * @returns {string} Unescaped string\r\n * @property {Object.} map Special characters map\r\n * @memberof tokenize\r\n */\r\nfunction unescape(str) {\r\n return str.replace(unescapeRe, function($0, $1) {\r\n switch ($1) {\r\n case \"\\\\\":\r\n case \"\":\r\n return $1;\r\n default:\r\n return unescapeMap[$1] || \"\";\r\n }\r\n });\r\n}\r\n\r\ntokenize.unescape = unescape;\r\n\r\n/**\r\n * Gets the next token and advances.\r\n * @typedef TokenizerHandleNext\r\n * @type {function}\r\n * @returns {string|null} Next token or `null` on eof\r\n */\r\n\r\n/**\r\n * Peeks for the next token.\r\n * @typedef TokenizerHandlePeek\r\n * @type {function}\r\n * @returns {string|null} Next token or `null` on eof\r\n */\r\n\r\n/**\r\n * Pushes a token back to the stack.\r\n * @typedef TokenizerHandlePush\r\n * @type {function}\r\n * @param {string} token Token\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Skips the next token.\r\n * @typedef TokenizerHandleSkip\r\n * @type {function}\r\n * @param {string} expected Expected token\r\n * @param {boolean} [optional=false] If optional\r\n * @returns {boolean} Whether the token matched\r\n * @throws {Error} If the token didn't match and is not optional\r\n */\r\n\r\n/**\r\n * Gets the comment on the previous line or, alternatively, the line comment on the specified line.\r\n * @typedef TokenizerHandleCmnt\r\n * @type {function}\r\n * @param {number} [line] Line number\r\n * @returns {string|null} Comment text or `null` if none\r\n */\r\n\r\n/**\r\n * Handle object returned from {@link tokenize}.\r\n * @interface ITokenizerHandle\r\n * @property {TokenizerHandleNext} next Gets the next token and advances (`null` on eof)\r\n * @property {TokenizerHandlePeek} peek Peeks for the next token (`null` on eof)\r\n * @property {TokenizerHandlePush} push Pushes a token back to the stack\r\n * @property {TokenizerHandleSkip} skip Skips a token, returns its presence and advances or, if non-optional and not present, throws\r\n * @property {TokenizerHandleCmnt} cmnt Gets the comment on the previous line or the line comment on the specified line, if any\r\n * @property {number} line Current line number\r\n */\r\n\r\n/**\r\n * Tokenizes the given .proto source and returns an object with useful utility functions.\r\n * @param {string} source Source contents\r\n * @param {boolean} alternateCommentMode Whether we should activate alternate comment parsing mode.\r\n * @returns {ITokenizerHandle} Tokenizer handle\r\n */\r\nfunction tokenize(source, alternateCommentMode) {\r\n /* eslint-disable callback-return */\r\n source = source.toString();\r\n\r\n var offset = 0,\r\n length = source.length,\r\n line = 1,\r\n commentType = null,\r\n commentText = null,\r\n commentLine = 0,\r\n commentLineEmpty = false;\r\n\r\n var stack = [];\r\n\r\n var stringDelim = null;\r\n\r\n /* istanbul ignore next */\r\n /**\r\n * Creates an error for illegal syntax.\r\n * @param {string} subject Subject\r\n * @returns {Error} Error created\r\n * @inner\r\n */\r\n function illegal(subject) {\r\n return Error(\"illegal \" + subject + \" (line \" + line + \")\");\r\n }\r\n\r\n /**\r\n * Reads a string till its end.\r\n * @returns {string} String read\r\n * @inner\r\n */\r\n function readString() {\r\n var re = stringDelim === \"'\" ? stringSingleRe : stringDoubleRe;\r\n re.lastIndex = offset - 1;\r\n var match = re.exec(source);\r\n if (!match)\r\n throw illegal(\"string\");\r\n offset = re.lastIndex;\r\n push(stringDelim);\r\n stringDelim = null;\r\n return unescape(match[1]);\r\n }\r\n\r\n /**\r\n * Gets the character at `pos` within the source.\r\n * @param {number} pos Position\r\n * @returns {string} Character\r\n * @inner\r\n */\r\n function charAt(pos) {\r\n return source.charAt(pos);\r\n }\r\n\r\n /**\r\n * Sets the current comment text.\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {undefined}\r\n * @inner\r\n */\r\n function setComment(start, end) {\r\n commentType = source.charAt(start++);\r\n commentLine = line;\r\n commentLineEmpty = false;\r\n var lookback;\r\n if (alternateCommentMode) {\r\n lookback = 2; // alternate comment parsing: \"//\" or \"/*\"\r\n } else {\r\n lookback = 3; // \"///\" or \"/**\"\r\n }\r\n var commentOffset = start - lookback,\r\n c;\r\n do {\r\n if (--commentOffset < 0 ||\r\n (c = source.charAt(commentOffset)) === \"\\n\") {\r\n commentLineEmpty = true;\r\n break;\r\n }\r\n } while (c === \" \" || c === \"\\t\");\r\n var lines = source\r\n .substring(start, end)\r\n .split(setCommentSplitRe);\r\n for (var i = 0; i < lines.length; ++i)\r\n lines[i] = lines[i]\r\n .replace(alternateCommentMode ? setCommentAltRe : setCommentRe, \"\")\r\n .trim();\r\n commentText = lines\r\n .join(\"\\n\")\r\n .trim();\r\n }\r\n\r\n function isDoubleSlashCommentLine(startOffset) {\r\n var endOffset = findEndOfLine(startOffset);\r\n\r\n // see if remaining line matches comment pattern\r\n var lineText = source.substring(startOffset, endOffset);\r\n // look for 1 or 2 slashes since startOffset would already point past\r\n // the first slash that started the comment.\r\n var isComment = /^\\s*\\/{1,2}/.test(lineText);\r\n return isComment;\r\n }\r\n\r\n function findEndOfLine(cursor) {\r\n // find end of cursor's line\r\n var endOffset = cursor;\r\n while (endOffset < length && charAt(endOffset) !== \"\\n\") {\r\n endOffset++;\r\n }\r\n return endOffset;\r\n }\r\n\r\n /**\r\n * Obtains the next token.\r\n * @returns {string|null} Next token or `null` on eof\r\n * @inner\r\n */\r\n function next() {\r\n if (stack.length > 0)\r\n return stack.shift();\r\n if (stringDelim)\r\n return readString();\r\n var repeat,\r\n prev,\r\n curr,\r\n start,\r\n isDoc;\r\n do {\r\n if (offset === length)\r\n return null;\r\n repeat = false;\r\n while (whitespaceRe.test(curr = charAt(offset))) {\r\n if (curr === \"\\n\")\r\n ++line;\r\n if (++offset === length)\r\n return null;\r\n }\r\n\r\n if (charAt(offset) === \"/\") {\r\n if (++offset === length) {\r\n throw illegal(\"comment\");\r\n }\r\n if (charAt(offset) === \"/\") { // Line\r\n if (!alternateCommentMode) {\r\n // check for triple-slash comment\r\n isDoc = charAt(start = offset + 1) === \"/\";\r\n\r\n while (charAt(++offset) !== \"\\n\") {\r\n if (offset === length) {\r\n return null;\r\n }\r\n }\r\n ++offset;\r\n if (isDoc) {\r\n setComment(start, offset - 1);\r\n }\r\n ++line;\r\n repeat = true;\r\n } else {\r\n // check for double-slash comments, consolidating consecutive lines\r\n start = offset;\r\n isDoc = false;\r\n if (isDoubleSlashCommentLine(offset)) {\r\n isDoc = true;\r\n do {\r\n offset = findEndOfLine(offset);\r\n if (offset === length) {\r\n break;\r\n }\r\n offset++;\r\n } while (isDoubleSlashCommentLine(offset));\r\n } else {\r\n offset = Math.min(length, findEndOfLine(offset) + 1);\r\n }\r\n if (isDoc) {\r\n setComment(start, offset);\r\n }\r\n line++;\r\n repeat = true;\r\n }\r\n } else if ((curr = charAt(offset)) === \"*\") { /* Block */\r\n // check for /** (regular comment mode) or /* (alternate comment mode)\r\n start = offset + 1;\r\n isDoc = alternateCommentMode || charAt(start) === \"*\";\r\n do {\r\n if (curr === \"\\n\") {\r\n ++line;\r\n }\r\n if (++offset === length) {\r\n throw illegal(\"comment\");\r\n }\r\n prev = curr;\r\n curr = charAt(offset);\r\n } while (prev !== \"*\" || curr !== \"/\");\r\n ++offset;\r\n if (isDoc) {\r\n setComment(start, offset - 2);\r\n }\r\n repeat = true;\r\n } else {\r\n return \"/\";\r\n }\r\n }\r\n } while (repeat);\r\n\r\n // offset !== length if we got here\r\n\r\n var end = offset;\r\n delimRe.lastIndex = 0;\r\n var delim = delimRe.test(charAt(end++));\r\n if (!delim)\r\n while (end < length && !delimRe.test(charAt(end)))\r\n ++end;\r\n var token = source.substring(offset, offset = end);\r\n if (token === \"\\\"\" || token === \"'\")\r\n stringDelim = token;\r\n return token;\r\n }\r\n\r\n /**\r\n * Pushes a token back to the stack.\r\n * @param {string} token Token\r\n * @returns {undefined}\r\n * @inner\r\n */\r\n function push(token) {\r\n stack.push(token);\r\n }\r\n\r\n /**\r\n * Peeks for the next token.\r\n * @returns {string|null} Token or `null` on eof\r\n * @inner\r\n */\r\n function peek() {\r\n if (!stack.length) {\r\n var token = next();\r\n if (token === null)\r\n return null;\r\n push(token);\r\n }\r\n return stack[0];\r\n }\r\n\r\n /**\r\n * Skips a token.\r\n * @param {string} expected Expected token\r\n * @param {boolean} [optional=false] Whether the token is optional\r\n * @returns {boolean} `true` when skipped, `false` if not\r\n * @throws {Error} When a required token is not present\r\n * @inner\r\n */\r\n function skip(expected, optional) {\r\n var actual = peek(),\r\n equals = actual === expected;\r\n if (equals) {\r\n next();\r\n return true;\r\n }\r\n if (!optional)\r\n throw illegal(\"token '\" + actual + \"', '\" + expected + \"' expected\");\r\n return false;\r\n }\r\n\r\n /**\r\n * Gets a comment.\r\n * @param {number} [trailingLine] Line number if looking for a trailing comment\r\n * @returns {string|null} Comment text\r\n * @inner\r\n */\r\n function cmnt(trailingLine) {\r\n var ret = null;\r\n if (trailingLine === undefined) {\r\n if (commentLine === line - 1 && (alternateCommentMode || commentType === \"*\" || commentLineEmpty)) {\r\n ret = commentText;\r\n }\r\n } else {\r\n /* istanbul ignore else */\r\n if (commentLine < trailingLine) {\r\n peek();\r\n }\r\n if (commentLine === trailingLine && !commentLineEmpty && (alternateCommentMode || commentType === \"/\")) {\r\n ret = commentText;\r\n }\r\n }\r\n return ret;\r\n }\r\n\r\n return Object.defineProperty({\r\n next: next,\r\n peek: peek,\r\n push: push,\r\n skip: skip,\r\n cmnt: cmnt\r\n }, \"line\", {\r\n get: function() { return line; }\r\n });\r\n /* eslint-enable callback-return */\r\n}\r\n","\"use strict\";\r\nmodule.exports = Type;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = \"Type\";\r\n\r\nvar Enum = require(15),\r\n OneOf = require(25),\r\n Field = require(16),\r\n MapField = require(20),\r\n Service = require(33),\r\n Message = require(21),\r\n Reader = require(27),\r\n Writer = require(42),\r\n util = require(37),\r\n encoder = require(14),\r\n decoder = require(13),\r\n verifier = require(40),\r\n converter = require(12),\r\n wrappers = require(41);\r\n\r\n/**\r\n * Constructs a new reflected message type instance.\r\n * @classdesc Reflected message type.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Message name\r\n * @param {Object.} [options] Declared options\r\n */\r\nfunction Type(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Message fields.\r\n * @type {Object.}\r\n */\r\n this.fields = {}; // toJSON, marker\r\n\r\n /**\r\n * Oneofs declared within this namespace, if any.\r\n * @type {Object.}\r\n */\r\n this.oneofs = undefined; // toJSON\r\n\r\n /**\r\n * Extension ranges, if any.\r\n * @type {number[][]}\r\n */\r\n this.extensions = undefined; // toJSON\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n /*?\r\n * Whether this type is a legacy group.\r\n * @type {boolean|undefined}\r\n */\r\n this.group = undefined; // toJSON\r\n\r\n /**\r\n * Cached fields by id.\r\n * @type {Object.|null}\r\n * @private\r\n */\r\n this._fieldsById = null;\r\n\r\n /**\r\n * Cached fields as an array.\r\n * @type {Field[]|null}\r\n * @private\r\n */\r\n this._fieldsArray = null;\r\n\r\n /**\r\n * Cached oneofs as an array.\r\n * @type {OneOf[]|null}\r\n * @private\r\n */\r\n this._oneofsArray = null;\r\n\r\n /**\r\n * Cached constructor.\r\n * @type {Constructor<{}>}\r\n * @private\r\n */\r\n this._ctor = null;\r\n}\r\n\r\nObject.defineProperties(Type.prototype, {\r\n\r\n /**\r\n * Message fields by id.\r\n * @name Type#fieldsById\r\n * @type {Object.}\r\n * @readonly\r\n */\r\n fieldsById: {\r\n get: function() {\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById)\r\n return this._fieldsById;\r\n\r\n this._fieldsById = {};\r\n for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) {\r\n var field = this.fields[names[i]],\r\n id = field.id;\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById[id])\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n\r\n this._fieldsById[id] = field;\r\n }\r\n return this._fieldsById;\r\n }\r\n },\r\n\r\n /**\r\n * Fields of this message as an array for iteration.\r\n * @name Type#fieldsArray\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n fieldsArray: {\r\n get: function() {\r\n return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields));\r\n }\r\n },\r\n\r\n /**\r\n * Oneofs of this message as an array for iteration.\r\n * @name Type#oneofsArray\r\n * @type {OneOf[]}\r\n * @readonly\r\n */\r\n oneofsArray: {\r\n get: function() {\r\n return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs));\r\n }\r\n },\r\n\r\n /**\r\n * The registered constructor, if any registered, otherwise a generic constructor.\r\n * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor.\r\n * @name Type#ctor\r\n * @type {Constructor<{}>}\r\n */\r\n ctor: {\r\n get: function() {\r\n return this._ctor || (this.ctor = Type.generateConstructor(this)());\r\n },\r\n set: function(ctor) {\r\n\r\n // Ensure proper prototype\r\n var prototype = ctor.prototype;\r\n if (!(prototype instanceof Message)) {\r\n (ctor.prototype = new Message()).constructor = ctor;\r\n util.merge(ctor.prototype, prototype);\r\n }\r\n\r\n // Classes and messages reference their reflected type\r\n ctor.$type = ctor.prototype.$type = this;\r\n\r\n // Mix in static methods\r\n util.merge(ctor, Message, true);\r\n\r\n this._ctor = ctor;\r\n\r\n // Messages have non-enumerable default values on their prototype\r\n var i = 0;\r\n for (; i < /* initializes */ this.fieldsArray.length; ++i)\r\n this._fieldsArray[i].resolve(); // ensures a proper value\r\n\r\n // Messages have non-enumerable getters and setters for each virtual oneof field\r\n var ctorProperties = {};\r\n for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i)\r\n ctorProperties[this._oneofsArray[i].resolve().name] = {\r\n get: util.oneOfGetter(this._oneofsArray[i].oneof),\r\n set: util.oneOfSetter(this._oneofsArray[i].oneof)\r\n };\r\n if (i)\r\n Object.defineProperties(ctor.prototype, ctorProperties);\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Generates a constructor function for the specified type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nType.generateConstructor = function generateConstructor(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n var gen = util.codegen([\"p\"], mtype.name);\r\n // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype\r\n for (var i = 0, field; i < mtype.fieldsArray.length; ++i)\r\n if ((field = mtype._fieldsArray[i]).map) gen\r\n (\"this%s={}\", util.safeProp(field.name));\r\n else if (field.repeated) gen\r\n (\"this%s=[]\", util.safeProp(field.name));\r\n return gen\r\n (\"if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors\r\n * @property {Object.} fields Field descriptors\r\n * @property {number[][]} [extensions] Extension ranges\r\n * @property {number[][]} [reserved] Reserved ranges\r\n * @property {boolean} [group=false] Whether a legacy group or not\r\n */\r\n\r\n/**\r\n * Creates a message type from a message type descriptor.\r\n * @param {string} name Message name\r\n * @param {IType} json Message type descriptor\r\n * @returns {Type} Created message type\r\n */\r\nType.fromJSON = function fromJSON(name, json) {\r\n var type = new Type(name, json.options);\r\n type.extensions = json.extensions;\r\n type.reserved = json.reserved;\r\n var names = Object.keys(json.fields),\r\n i = 0;\r\n for (; i < names.length; ++i)\r\n type.add(\r\n ( typeof json.fields[names[i]].keyType !== \"undefined\"\r\n ? MapField.fromJSON\r\n : Field.fromJSON )(names[i], json.fields[names[i]])\r\n );\r\n if (json.oneofs)\r\n for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i)\r\n type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]]));\r\n if (json.nested)\r\n for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) {\r\n var nested = json.nested[names[i]];\r\n type.add( // most to least likely\r\n ( nested.id !== undefined\r\n ? Field.fromJSON\r\n : nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n if (json.extensions && json.extensions.length)\r\n type.extensions = json.extensions;\r\n if (json.reserved && json.reserved.length)\r\n type.reserved = json.reserved;\r\n if (json.group)\r\n type.group = true;\r\n if (json.comment)\r\n type.comment = json.comment;\r\n return type;\r\n};\r\n\r\n/**\r\n * Converts this message type to a message type descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IType} Message type descriptor\r\n */\r\nType.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"oneofs\" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions),\r\n \"fields\" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {},\r\n \"extensions\" , this.extensions && this.extensions.length ? this.extensions : undefined,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"group\" , this.group || undefined,\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.resolveAll = function resolveAll() {\r\n var fields = this.fieldsArray, i = 0;\r\n while (i < fields.length)\r\n fields[i++].resolve();\r\n var oneofs = this.oneofsArray; i = 0;\r\n while (i < oneofs.length)\r\n oneofs[i++].resolve();\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.get = function get(name) {\r\n return this.fields[name]\r\n || this.oneofs && this.oneofs[name]\r\n || this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Adds a nested object to this type.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id\r\n */\r\nType.prototype.add = function add(object) {\r\n\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Field && object.extend === undefined) {\r\n // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects.\r\n // The root object takes care of adding distinct sister-fields to the respective extended\r\n // type instead.\r\n\r\n // avoids calling the getter if not absolutely necessary because it's called quite frequently\r\n if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id])\r\n throw Error(\"duplicate id \" + object.id + \" in \" + this);\r\n if (this.isReservedId(object.id))\r\n throw Error(\"id \" + object.id + \" is reserved in \" + this);\r\n if (this.isReservedName(object.name))\r\n throw Error(\"name '\" + object.name + \"' is reserved in \" + this);\r\n\r\n if (object.parent)\r\n object.parent.remove(object);\r\n this.fields[object.name] = object;\r\n object.message = this;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n if (!this.oneofs)\r\n this.oneofs = {};\r\n this.oneofs[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this type.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this type\r\n */\r\nType.prototype.remove = function remove(object) {\r\n if (object instanceof Field && object.extend === undefined) {\r\n // See Type#add for the reason why extension fields are excluded here.\r\n\r\n /* istanbul ignore if */\r\n if (!this.fields || this.fields[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.fields[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n\r\n /* istanbul ignore if */\r\n if (!this.oneofs || this.oneofs[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.oneofs[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.create = function create(properties) {\r\n return new this.ctor(properties);\r\n};\r\n\r\n/**\r\n * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}.\r\n * @returns {Type} `this`\r\n */\r\nType.prototype.setup = function setup() {\r\n // Sets up everything at once so that the prototype chain does not have to be re-evaluated\r\n // multiple times (V8, soft-deopt prototype-check).\r\n\r\n var fullName = this.fullName,\r\n types = [];\r\n for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i)\r\n types.push(this._fieldsArray[i].resolve().resolvedType);\r\n\r\n // Replace setup methods with type-specific generated functions\r\n this.encode = encoder(this)({\r\n Writer : Writer,\r\n types : types,\r\n util : util\r\n });\r\n this.decode = decoder(this)({\r\n Reader : Reader,\r\n types : types,\r\n util : util\r\n });\r\n this.verify = verifier(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.fromObject = converter.fromObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.toObject = converter.toObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n\r\n // Inject custom wrappers for common types\r\n var wrapper = wrappers[fullName];\r\n if (wrapper) {\r\n var originalThis = Object.create(this);\r\n // if (wrapper.fromObject) {\r\n originalThis.fromObject = this.fromObject;\r\n this.fromObject = wrapper.fromObject.bind(originalThis);\r\n // }\r\n // if (wrapper.toObject) {\r\n originalThis.toObject = this.toObject;\r\n this.toObject = wrapper.toObject.bind(originalThis);\r\n // }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encode = function encode_setup(message, writer) {\r\n return this.setup().encode(message, writer); // overrides this method\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim();\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @param {number} [length] Length of the message, if known beforehand\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError<{}>} If required fields are missing\r\n */\r\nType.prototype.decode = function decode_setup(reader, length) {\r\n return this.setup().decode(reader, length); // overrides this method\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its byte length as a varint.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError} If required fields are missing\r\n */\r\nType.prototype.decodeDelimited = function decodeDelimited(reader) {\r\n if (!(reader instanceof Reader))\r\n reader = Reader.create(reader);\r\n return this.decode(reader, reader.uint32());\r\n};\r\n\r\n/**\r\n * Verifies that field values are valid and that required fields are present.\r\n * @param {Object.} message Plain object to verify\r\n * @returns {null|string} `null` if valid, otherwise the reason why it is not\r\n */\r\nType.prototype.verify = function verify_setup(message) {\r\n return this.setup().verify(message); // overrides this method\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object to convert\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.fromObject = function fromObject(object) {\r\n return this.setup().fromObject(object);\r\n};\r\n\r\n/**\r\n * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}.\r\n * @interface IConversionOptions\r\n * @property {Function} [longs] Long conversion type.\r\n * Valid values are `String` and `Number` (the global types).\r\n * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library.\r\n * @property {Function} [enums] Enum value conversion type.\r\n * Only valid value is `String` (the global type).\r\n * Defaults to copy the present value, which is the numeric id.\r\n * @property {Function} [bytes] Bytes value conversion type.\r\n * Valid values are `Array` and (a base64 encoded) `String` (the global types).\r\n * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser.\r\n * @property {boolean} [defaults=false] Also sets default values on the resulting object\r\n * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false`\r\n * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false`\r\n * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any\r\n * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings\r\n */\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n */\r\nType.prototype.toObject = function toObject(message, options) {\r\n return this.setup().toObject(message, options);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Type.d} (TypeScript).\r\n * @typedef TypeDecorator\r\n * @type {function}\r\n * @param {Constructor} target Target constructor\r\n * @returns {undefined}\r\n * @template T extends Message\r\n */\r\n\r\n/**\r\n * Type decorator (TypeScript).\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {TypeDecorator} Decorator function\r\n * @template T extends Message\r\n */\r\nType.d = function decorateType(typeName) {\r\n return function typeDecorator(target) {\r\n util.decorateType(target, typeName);\r\n };\r\n};\r\n","\"use strict\";\r\n\r\n/**\r\n * Common type constants.\r\n * @namespace\r\n */\r\nvar types = exports;\r\n\r\nvar util = require(37);\r\n\r\nvar s = [\r\n \"double\", // 0\r\n \"float\", // 1\r\n \"int32\", // 2\r\n \"uint32\", // 3\r\n \"sint32\", // 4\r\n \"fixed32\", // 5\r\n \"sfixed32\", // 6\r\n \"int64\", // 7\r\n \"uint64\", // 8\r\n \"sint64\", // 9\r\n \"fixed64\", // 10\r\n \"sfixed64\", // 11\r\n \"bool\", // 12\r\n \"string\", // 13\r\n \"bytes\" // 14\r\n];\r\n\r\nfunction bake(values, offset) {\r\n var i = 0, o = {};\r\n offset |= 0;\r\n while (i < values.length) o[s[i + offset]] = values[i++];\r\n return o;\r\n}\r\n\r\n/**\r\n * Basic type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n * @property {number} bytes=2 Ldelim wire type\r\n */\r\ntypes.basic = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2,\r\n /* bytes */ 2\r\n]);\r\n\r\n/**\r\n * Basic type defaults.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=0 Double default\r\n * @property {number} float=0 Float default\r\n * @property {number} int32=0 Int32 default\r\n * @property {number} uint32=0 Uint32 default\r\n * @property {number} sint32=0 Sint32 default\r\n * @property {number} fixed32=0 Fixed32 default\r\n * @property {number} sfixed32=0 Sfixed32 default\r\n * @property {number} int64=0 Int64 default\r\n * @property {number} uint64=0 Uint64 default\r\n * @property {number} sint64=0 Sint32 default\r\n * @property {number} fixed64=0 Fixed64 default\r\n * @property {number} sfixed64=0 Sfixed64 default\r\n * @property {boolean} bool=false Bool default\r\n * @property {string} string=\"\" String default\r\n * @property {Array.} bytes=Array(0) Bytes default\r\n * @property {null} message=null Message default\r\n */\r\ntypes.defaults = bake([\r\n /* double */ 0,\r\n /* float */ 0,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 0,\r\n /* sfixed32 */ 0,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 0,\r\n /* sfixed64 */ 0,\r\n /* bool */ false,\r\n /* string */ \"\",\r\n /* bytes */ util.emptyArray,\r\n /* message */ null\r\n]);\r\n\r\n/**\r\n * Basic long type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n */\r\ntypes.long = bake([\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1\r\n], 7);\r\n\r\n/**\r\n * Allowed types for map keys with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n */\r\ntypes.mapKey = bake([\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2\r\n], 2);\r\n\r\n/**\r\n * Allowed types for packed repeated fields with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n */\r\ntypes.packed = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0\r\n]);\r\n","\"use strict\";\r\n\r\n/**\r\n * Various utility functions.\r\n * @namespace\r\n */\r\nvar util = module.exports = require(39);\r\n\r\nvar roots = require(30);\r\n\r\nvar Type, // cyclic\r\n Enum;\r\n\r\nutil.codegen = require(3);\r\nutil.fetch = require(5);\r\nutil.path = require(8);\r\n\r\n/**\r\n * Node's fs module if available.\r\n * @type {Object.}\r\n */\r\nutil.fs = util.inquire(\"fs\");\r\n\r\n/**\r\n * Converts an object's values to an array.\r\n * @param {Object.} object Object to convert\r\n * @returns {Array.<*>} Converted array\r\n */\r\nutil.toArray = function toArray(object) {\r\n if (object) {\r\n var keys = Object.keys(object),\r\n array = new Array(keys.length),\r\n index = 0;\r\n while (index < keys.length)\r\n array[index] = object[keys[index++]];\r\n return array;\r\n }\r\n return [];\r\n};\r\n\r\n/**\r\n * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values.\r\n * @param {Array.<*>} array Array to convert\r\n * @returns {Object.} Converted object\r\n */\r\nutil.toObject = function toObject(array) {\r\n var object = {},\r\n index = 0;\r\n while (index < array.length) {\r\n var key = array[index++],\r\n val = array[index++];\r\n if (val !== undefined)\r\n object[key] = val;\r\n }\r\n return object;\r\n};\r\n\r\nvar safePropBackslashRe = /\\\\/g,\r\n safePropQuoteRe = /\"/g;\r\n\r\n/**\r\n * Tests whether the specified name is a reserved word in JS.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nutil.isReserved = function isReserved(name) {\r\n return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name);\r\n};\r\n\r\n/**\r\n * Returns a safe property accessor for the specified property name.\r\n * @param {string} prop Property name\r\n * @returns {string} Safe accessor\r\n */\r\nutil.safeProp = function safeProp(prop) {\r\n if (!/^[$\\w_]+$/.test(prop) || util.isReserved(prop))\r\n return \"[\\\"\" + prop.replace(safePropBackslashRe, \"\\\\\\\\\").replace(safePropQuoteRe, \"\\\\\\\"\") + \"\\\"]\";\r\n return \".\" + prop;\r\n};\r\n\r\n/**\r\n * Converts the first character of a string to upper case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.ucFirst = function ucFirst(str) {\r\n return str.charAt(0).toUpperCase() + str.substring(1);\r\n};\r\n\r\nvar camelCaseRe = /_([a-z])/g;\r\n\r\n/**\r\n * Converts a string to camel case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.camelCase = function camelCase(str) {\r\n return str.substring(0, 1)\r\n + str.substring(1)\r\n .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); });\r\n};\r\n\r\n/**\r\n * Compares reflected fields by id.\r\n * @param {Field} a First field\r\n * @param {Field} b Second field\r\n * @returns {number} Comparison value\r\n */\r\nutil.compareFieldsById = function compareFieldsById(a, b) {\r\n return a.id - b.id;\r\n};\r\n\r\n/**\r\n * Decorator helper for types (TypeScript).\r\n * @param {Constructor} ctor Constructor function\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {Type} Reflected type\r\n * @template T extends Message\r\n * @property {Root} root Decorators root\r\n */\r\nutil.decorateType = function decorateType(ctor, typeName) {\r\n\r\n /* istanbul ignore if */\r\n if (ctor.$type) {\r\n if (typeName && ctor.$type.name !== typeName) {\r\n util.decorateRoot.remove(ctor.$type);\r\n ctor.$type.name = typeName;\r\n util.decorateRoot.add(ctor.$type);\r\n }\r\n return ctor.$type;\r\n }\r\n\r\n /* istanbul ignore next */\r\n if (!Type)\r\n Type = require(35);\r\n\r\n var type = new Type(typeName || ctor.name);\r\n util.decorateRoot.add(type);\r\n type.ctor = ctor; // sets up .encode, .decode etc.\r\n Object.defineProperty(ctor, \"$type\", { value: type, enumerable: false });\r\n Object.defineProperty(ctor.prototype, \"$type\", { value: type, enumerable: false });\r\n return type;\r\n};\r\n\r\nvar decorateEnumIndex = 0;\r\n\r\n/**\r\n * Decorator helper for enums (TypeScript).\r\n * @param {Object} object Enum object\r\n * @returns {Enum} Reflected enum\r\n */\r\nutil.decorateEnum = function decorateEnum(object) {\r\n\r\n /* istanbul ignore if */\r\n if (object.$type)\r\n return object.$type;\r\n\r\n /* istanbul ignore next */\r\n if (!Enum)\r\n Enum = require(15);\r\n\r\n var enm = new Enum(\"Enum\" + decorateEnumIndex++, object);\r\n util.decorateRoot.add(enm);\r\n Object.defineProperty(object, \"$type\", { value: enm, enumerable: false });\r\n return enm;\r\n};\r\n\r\n/**\r\n * Decorator root (TypeScript).\r\n * @name util.decorateRoot\r\n * @type {Root}\r\n * @readonly\r\n */\r\nObject.defineProperty(util, \"decorateRoot\", {\r\n get: function() {\r\n return roots[\"decorated\"] || (roots[\"decorated\"] = new (require(29))());\r\n }\r\n});\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(4);\r\n\r\n// float handling accross browsers\r\nutil.float = require(6);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(7);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(10);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(9);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(38);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = verifier;\r\n\r\nvar Enum = require(15),\r\n util = require(37);\r\n\r\nfunction invalid(field, expected) {\r\n return field.name + \": \" + expected + (field.repeated && expected !== \"array\" ? \"[]\" : field.map && expected !== \"object\" ? \"{k:\"+field.keyType+\"}\" : \"\") + \" expected\";\r\n}\r\n\r\n/**\r\n * Generates a partial value verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyValue(gen, field, fieldIndex, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(%s){\", ref)\r\n (\"default:\")\r\n (\"return%j\", invalid(field, \"enum value\"));\r\n for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen\r\n (\"case %i:\", field.resolvedType.values[keys[j]]);\r\n gen\r\n (\"break\")\r\n (\"}\");\r\n } else {\r\n gen\r\n (\"{\")\r\n (\"var e=types[%i].verify(%s);\", fieldIndex, ref)\r\n (\"if(e)\")\r\n (\"return%j+e\", field.name + \".\")\r\n (\"}\");\r\n }\r\n } else {\r\n switch (field.type) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.isInteger(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))\", ref, ref, ref, ref)\r\n (\"return%j\", invalid(field, \"integer|Long\"));\r\n break;\r\n case \"float\":\r\n case \"double\": gen\r\n (\"if(typeof %s!==\\\"number\\\")\", ref)\r\n (\"return%j\", invalid(field, \"number\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(typeof %s!==\\\"boolean\\\")\", ref)\r\n (\"return%j\", invalid(field, \"boolean\"));\r\n break;\r\n case \"string\": gen\r\n (\"if(!util.isString(%s))\", ref)\r\n (\"return%j\", invalid(field, \"string\"));\r\n break;\r\n case \"bytes\": gen\r\n (\"if(!(%s&&typeof %s.length===\\\"number\\\"||util.isString(%s)))\", ref, ref, ref)\r\n (\"return%j\", invalid(field, \"buffer\"));\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a partial key verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyKey(gen, field, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n switch (field.keyType) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.key32Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer key\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.key64Re.test(%s))\", ref) // see comment above: x is ok, d is not\r\n (\"return%j\", invalid(field, \"integer|Long key\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(!util.key2Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"boolean key\"));\r\n break;\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a verifier specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction verifier(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n\r\n var gen = util.codegen([\"m\"], mtype.name + \"$verify\")\r\n (\"if(typeof m!==\\\"object\\\"||m===null)\")\r\n (\"return%j\", \"object expected\");\r\n var oneofs = mtype.oneofsArray,\r\n seenFirstField = {};\r\n if (oneofs.length) gen\r\n (\"var p={}\");\r\n\r\n for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name); // !== undefined && !== null\r\n\r\n // map fields\r\n if (field.map) { gen\r\n (\"if(!util.isObject(%s))\", ref)\r\n (\"return%j\", invalid(field, \"object\"))\r\n (\"var k=Object.keys(%s)\", ref)\r\n (\"for(var i=0;i}\r\n * @const\r\n */\r\nvar wrappers = exports;\r\n\r\nvar Message = require(21);\r\n\r\n/**\r\n * From object converter part of an {@link IWrapper}.\r\n * @typedef WrapperFromObjectConverter\r\n * @type {function}\r\n * @param {Object.} object Plain object\r\n * @returns {Message<{}>} Message instance\r\n * @this Type\r\n */\r\n\r\n/**\r\n * To object converter part of an {@link IWrapper}.\r\n * @typedef WrapperToObjectConverter\r\n * @type {function}\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @this Type\r\n */\r\n\r\n/**\r\n * Common type wrapper part of {@link wrappers}.\r\n * @interface IWrapper\r\n * @property {WrapperFromObjectConverter} [fromObject] From object converter\r\n * @property {WrapperToObjectConverter} [toObject] To object converter\r\n */\r\n\r\n// Custom wrapper for Any\r\nwrappers[\".google.protobuf.Any\"] = {\r\n\r\n fromObject: function(object) {\r\n\r\n // unwrap value type if mapped\r\n if (object && object[\"@type\"]) {\r\n var type = this.lookup(object[\"@type\"]);\r\n /* istanbul ignore else */\r\n if (type) {\r\n // type_url does not accept leading \".\"\r\n var type_url = object[\"@type\"].charAt(0) === \".\" ?\r\n object[\"@type\"].substr(1) : object[\"@type\"];\r\n // type_url prefix is optional, but path seperator is required\r\n return this.create({\r\n type_url: \"/\" + type_url,\r\n value: type.encode(type.fromObject(object)).finish()\r\n });\r\n }\r\n }\r\n\r\n return this.fromObject(object);\r\n },\r\n\r\n toObject: function(message, options) {\r\n\r\n // decode value if requested and unmapped\r\n if (options && options.json && message.type_url && message.value) {\r\n // Only use fully qualified type name after the last '/'\r\n var name = message.type_url.substring(message.type_url.lastIndexOf(\"/\") + 1);\r\n var type = this.lookup(name);\r\n /* istanbul ignore else */\r\n if (type)\r\n message = type.decode(message.value);\r\n }\r\n\r\n // wrap value if unmapped\r\n if (!(message instanceof this.ctor) && message instanceof Message) {\r\n var object = message.$type.toObject(message, options);\r\n object[\"@type\"] = message.$type.fullName;\r\n return object;\r\n }\r\n\r\n return this.toObject(message, options);\r\n }\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(39);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(42);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(39);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/dist/protobuf.min.js b/node_modules/protobufjs/dist/protobuf.min.js new file mode 100644 index 0000000..9be32b6 --- /dev/null +++ b/node_modules/protobufjs/dist/protobuf.min.js @@ -0,0 +1,8 @@ +/*! + * protobuf.js v6.8.8 (c) 2016, daniel wirtz + * compiled thu, 19 jul 2018 00:33:26 utc + * licensed under the bsd-3-clause license + * see: https://github.com/dcodeio/protobuf.js for details + */ +!function(tt){"use strict";var r,e,t,i;r={1:[function(t,i){i.exports=function(t,i){var n=Array(arguments.length-1),s=0,r=2,u=!0;for(;r>2],r=(3&f)<<4,o=1;break;case 1:s[u++]=h[r|f>>4],r=(15&f)<<2,o=2;break;case 2:s[u++]=h[r|f>>6],s[u++]=h[63&f],o=0}8191>4,r=o,s=2;break;case 2:i[n++]=(15&r)<<4|(60&o)>>2,r=o,s=3;break;case 3:i[n++]=(3&r)<<6|o,s=0}}if(1===s)throw Error(a);return n-e},r.test=function(t){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(t)}},{}],3:[function(t,i){function c(i,n){"string"==typeof i&&(n=i,i=tt);var f=[];function h(t){if("string"!=typeof t){var i=a();if(c.verbose&&console.log("codegen: "+i),i="return "+i,t){for(var n=Object.keys(t),r=Array(n.length+1),e=Array(n.length),s=0;s>>0,n,r);else if(i<11754943508222875e-54)t((e<<31|Math.round(i/1401298464324817e-60))>>>0,n,r);else{var s=Math.floor(Math.log(i)/Math.LN2);t((e<<31|s+127<<23|8388607&Math.round(i*Math.pow(2,-s)*8388608))>>>0,n,r)}}function i(t,i,n){var r=t(i,n),e=2*(r>>31)+1,s=r>>>23&255,u=8388607&r;return 255===s?u?NaN:e*(1/0):0===s?1401298464324817e-60*e*u:e*Math.pow(2,s-150)*(u+8388608)}o.writeFloatLE=t.bind(null,r),o.writeFloatBE=t.bind(null,e),o.readFloatLE=i.bind(null,s),o.readFloatBE=i.bind(null,u)}(),"undefined"!=typeof Float64Array?function(){var r=new Float64Array([-0]),e=new Uint8Array(r.buffer),t=128===e[7];function i(t,i,n){r[0]=t,i[n]=e[0],i[n+1]=e[1],i[n+2]=e[2],i[n+3]=e[3],i[n+4]=e[4],i[n+5]=e[5],i[n+6]=e[6],i[n+7]=e[7]}function n(t,i,n){r[0]=t,i[n]=e[7],i[n+1]=e[6],i[n+2]=e[5],i[n+3]=e[4],i[n+4]=e[3],i[n+5]=e[2],i[n+6]=e[1],i[n+7]=e[0]}function s(t,i){return e[0]=t[i],e[1]=t[i+1],e[2]=t[i+2],e[3]=t[i+3],e[4]=t[i+4],e[5]=t[i+5],e[6]=t[i+6],e[7]=t[i+7],r[0]}function u(t,i){return e[7]=t[i],e[6]=t[i+1],e[5]=t[i+2],e[4]=t[i+3],e[3]=t[i+4],e[2]=t[i+5],e[1]=t[i+6],e[0]=t[i+7],r[0]}o.writeDoubleLE=t?i:n,o.writeDoubleBE=t?n:i,o.readDoubleLE=t?s:u,o.readDoubleBE=t?u:s}():function(){function t(t,i,n,r,e,s){var u=r<0?1:0;if(u&&(r=-r),0===r)t(0,e,s+i),t(0<1/r?0:2147483648,e,s+n);else if(isNaN(r))t(0,e,s+i),t(2146959360,e,s+n);else if(17976931348623157e292>>0,e,s+n);else{var o;if(r<22250738585072014e-324)t((o=r/5e-324)>>>0,e,s+i),t((u<<31|o/4294967296)>>>0,e,s+n);else{var f=Math.floor(Math.log(r)/Math.LN2);1024===f&&(f=1023),t(4503599627370496*(o=r*Math.pow(2,-f))>>>0,e,s+i),t((u<<31|f+1023<<20|1048576*o&1048575)>>>0,e,s+n)}}}function i(t,i,n,r,e){var s=t(r,e+i),u=t(r,e+n),o=2*(u>>31)+1,f=u>>>20&2047,h=4294967296*(1048575&u)+s;return 2047===f?h?NaN:o*(1/0):0===f?5e-324*o*h:o*Math.pow(2,f-1075)*(h+4503599627370496)}o.writeDoubleLE=t.bind(null,r,0,4),o.writeDoubleBE=t.bind(null,e,4,0),o.readDoubleLE=i.bind(null,s,0,4),o.readDoubleBE=i.bind(null,u,4,0)}(),o}function r(t,i,n){i[n]=255&t,i[n+1]=t>>>8&255,i[n+2]=t>>>16&255,i[n+3]=t>>>24}function e(t,i,n){i[n]=t>>>24,i[n+1]=t>>>16&255,i[n+2]=t>>>8&255,i[n+3]=255&t}function s(t,i){return(t[i]|t[i+1]<<8|t[i+2]<<16|t[i+3]<<24)>>>0}function u(t,i){return(t[i]<<24|t[i+1]<<16|t[i+2]<<8|t[i+3])>>>0}i.exports=n(n)},{}],7:[function(t,i,n){function r(t){try{var i=eval("require")(t);if(i&&(i.length||Object.keys(i).length))return i}catch(t){}return null}i.exports=r},{}],8:[function(t,i,n){var r=n,s=r.isAbsolute=function(t){return/^(?:\/|\w+:)/.test(t)},e=r.normalize=function(t){var i=(t=t.replace(/\\/g,"/").replace(/\/{2,}/g,"/")).split("/"),n=s(t),r="";n&&(r=i.shift()+"/");for(var e=0;e>>1,u=null,o=e;return function(t){if(t<1||s>10),s[u++]=56320+(1023&r)):s[u++]=(15&r)<<12|(63&t[i++])<<6|63&t[i++],8191>6|192:(55296==(64512&r)&&56320==(64512&(e=t.charCodeAt(u+1)))?(r=65536+((1023&r)<<10)+(1023&e),++u,i[n++]=r>>18|240,i[n++]=r>>12&63|128):i[n++]=r>>12|224,i[n++]=r>>6&63|128),i[n++]=63&r|128);return n-s}},{}],11:[function(t,i){i.exports=e;var n,r=/\/|\./;function e(t,i){r.test(t)||(t="google/protobuf/"+t+".proto",i={nested:{google:{nested:{protobuf:{nested:i}}}}}),e[t]=i}e("any",{Any:{fields:{type_url:{type:"string",id:1},value:{type:"bytes",id:2}}}}),e("duration",{Duration:n={fields:{seconds:{type:"int64",id:1},nanos:{type:"int32",id:2}}}}),e("timestamp",{Timestamp:n}),e("empty",{Empty:{fields:{}}}),e("struct",{Struct:{fields:{fields:{keyType:"string",type:"Value",id:1}}},Value:{oneofs:{kind:{oneof:["nullValue","numberValue","stringValue","boolValue","structValue","listValue"]}},fields:{nullValue:{type:"NullValue",id:1},numberValue:{type:"double",id:2},stringValue:{type:"string",id:3},boolValue:{type:"bool",id:4},structValue:{type:"Struct",id:5},listValue:{type:"ListValue",id:6}}},NullValue:{values:{NULL_VALUE:0}},ListValue:{fields:{values:{rule:"repeated",type:"Value",id:1}}}}),e("wrappers",{DoubleValue:{fields:{value:{type:"double",id:1}}},FloatValue:{fields:{value:{type:"float",id:1}}},Int64Value:{fields:{value:{type:"int64",id:1}}},UInt64Value:{fields:{value:{type:"uint64",id:1}}},Int32Value:{fields:{value:{type:"int32",id:1}}},UInt32Value:{fields:{value:{type:"uint32",id:1}}},BoolValue:{fields:{value:{type:"bool",id:1}}},StringValue:{fields:{value:{type:"string",id:1}}},BytesValue:{fields:{value:{type:"bytes",id:1}}}}),e("field_mask",{FieldMask:{fields:{paths:{rule:"repeated",type:"string",id:1}}}}),e.get=function(t){return e[t]||null}},{}],12:[function(t,i,n){var r=n,l=t(15),v=t(37);function u(t,i,n,r){if(i.resolvedType)if(i.resolvedType instanceof l){t("switch(d%s){",r);for(var e=i.resolvedType.values,s=Object.keys(e),u=0;u>>0",r,r);break;case"int32":case"sint32":case"sfixed32":t("m%s=d%s|0",r,r);break;case"uint64":o=!0;case"int64":case"sint64":case"fixed64":case"sfixed64":t("if(util.Long)")("(m%s=util.Long.fromValue(d%s)).unsigned=%j",r,r,o)('else if(typeof d%s==="string")',r)("m%s=parseInt(d%s,10)",r,r)('else if(typeof d%s==="number")',r)("m%s=d%s",r,r)('else if(typeof d%s==="object")',r)("m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)",r,r,r,o?"true":"");break;case"bytes":t('if(typeof d%s==="string")',r)("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)",r,r,r)("else if(d%s.length)",r)("m%s=d%s",r,r);break;case"string":t("m%s=String(d%s)",r,r);break;case"bool":t("m%s=Boolean(d%s)",r,r)}}return t}function d(t,i,n,r){if(i.resolvedType)i.resolvedType instanceof l?t("d%s=o.enums===String?types[%i].values[m%s]:m%s",r,n,r,r):t("d%s=types[%i].toObject(m%s,o)",r,n,r);else{var e=!1;switch(i.type){case"double":case"float":t("d%s=o.json&&!isFinite(m%s)?String(m%s):m%s",r,r,r,r);break;case"uint64":e=!0;case"int64":case"sint64":case"fixed64":case"sfixed64":t('if(typeof m%s==="number")',r)("d%s=o.longs===String?String(m%s):m%s",r,r,r)("else")("d%s=o.longs===String?util.Long.prototype.toString.call(m%s):o.longs===Number?new util.LongBits(m%s.low>>>0,m%s.high>>>0).toNumber(%s):m%s",r,r,r,r,e?"true":"",r);break;case"bytes":t("d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s",r,r,r,r,r);break;default:t("d%s=m%s",r,r)}}return t}r.fromObject=function(t){var i=t.fieldsArray,n=v.codegen(["d"],t.name+"$fromObject")("if(d instanceof this.ctor)")("return d");if(!i.length)return n("return new this.ctor");n("var m=new this.ctor");for(var r=0;r>>3){");for(var n=0;n>>0,8|a.mapKey[s.keyType],s.keyType),f===tt?n("types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()",u,i):n(".uint32(%i).%s(%s[ks[i]]).ldelim()",16|f,o,i),n("}")("}")):s.repeated?(n("if(%s!=null&&%s.length){",i,i),s.packed&&a.packed[o]!==tt?n("w.uint32(%i).fork()",(s.id<<3|2)>>>0)("for(var i=0;i<%s.length;++i)",i)("w.%s(%s[i])",o,i)("w.ldelim()"):(n("for(var i=0;i<%s.length;++i)",i),f===tt?l(n,s,u,i+"[i]"):n("w.uint32(%i).%s(%s[i])",(s.id<<3|f)>>>0,o,i)),n("}")):(s.optional&&n("if(%s!=null&&m.hasOwnProperty(%j))",i,s.name),f===tt?l(n,s,u,i):n("w.uint32(%i).%s(%s)",(s.id<<3|f)>>>0,o,i))}return n("return w")};var h=t(15),a=t(36),c=t(37);function l(t,i,n,r){return i.resolvedType.group?t("types[%i].encode(%s,w.uint32(%i)).uint32(%i)",n,r,(i.id<<3|3)>>>0,(i.id<<3|4)>>>0):t("types[%i].encode(%s,w.uint32(%i).fork()).ldelim()",n,r,(i.id<<3|2)>>>0)}},{15:15,36:36,37:37}],15:[function(t,i){i.exports=e;var o=t(24);((e.prototype=Object.create(o.prototype)).constructor=e).className="Enum";var n=t(23),r=t(37);function e(t,i,n,r,e){if(o.call(this,t,n),i&&"object"!=typeof i)throw TypeError("values must be an object");if(this.valuesById={},this.values=Object.create(this.valuesById),this.comment=r,this.comments=e||{},this.reserved=tt,i)for(var s=Object.keys(i),u=0;u=i)return!0;return!1},h.isReservedName=function(t,i){if(t)for(var n=0;n");var r=h();if(!G.test(r))throw b(r,"name");l("=");var e=new U(y(r),k(h()),i,n);S(e,function(t){if("option"!==t)throw b(t);N(e,t),l(";")},function(){$(e)}),t.add(e)}(n);break;case"required":case"optional":case"repeated":T(n,t);break;case"oneof":!function(t,i){if(!G.test(i=h()))throw b(i,"name");var n=new _(y(i));S(n,function(t){"option"===t?(N(n,t),l(";")):(a(t),T(n,"optional"))}),t.add(n)}(n,t);break;case"extensions":j(n.extensions||(n.extensions=[]));break;case"reserved":j(n.reserved||(n.reserved=[]),!0);break;default:if(!p||!K.test(t))throw b(t);a(t),T(n,"optional")}}),t.add(n)}(t,i),!0;case"enum":return function(t,i){if(!G.test(i=h()))throw b(i,"name");var n=new q(i);S(n,function(t){switch(t){case"option":N(n,t),l(";");break;case"reserved":j(n.reserved||(n.reserved=[]),!0);break;default:!function(t,i){if(!G.test(i))throw b(i,"name");l("=");var n=k(h(),!0),r={};S(r,function(t){if("option"!==t)throw b(t);N(r,t),l(";")},function(){$(r)}),t.add(i,n,r.comment)}(n,t)}}),t.add(n)}(t,i),!0;case"service":return function(t,i){if(!G.test(i=h()))throw b(i,"service name");var n=new R(i);S(n,function(t){if(!x(n,t)){if("rpc"!==t)throw b(t);!function(t,i){var n=i;if(!G.test(i=h()))throw b(i,"name");var r,e,s,u,o=i;l("("),l("stream",!0)&&(e=!0);if(!K.test(i=h()))throw b(i);r=i,l(")"),l("returns"),l("("),l("stream",!0)&&(u=!0);if(!K.test(i=h()))throw b(i);s=i,l(")");var f=new z(o,n,r,s,e,u);S(f,function(t){if("option"!==t)throw b(t);N(f,t),l(";")}),t.add(f)}(n,t)}}),t.add(n)}(t,i),!0;case"extend":return function(i,t){if(!K.test(t=h()))throw b(t,"reference");var n=t;S(null,function(t){switch(t){case"required":case"repeated":case"optional":T(i,t,n);break;default:if(!p||!K.test(t))throw b(t);a(t),T(i,"optional",n)}})}(t,i),!0}return!1}function S(t,i,n){var r=f.line;if(t&&(t.comment=v(),t.filename=Y.filename),l("{",!0)){for(var e;"}"!==(e=h());)i(e);l(";",!0)}else n&&n(),l(";"),t&&"string"!=typeof t.comment&&(t.comment=v(r))}function T(t,i,n){var r=h();if("group"!==r){if(!K.test(r))throw b(r,"type");var e=h();if(!G.test(e))throw b(e,"name");e=y(e),l("=");var s=new L(e,k(h()),r,i,n);S(s,function(t){if("option"!==t)throw b(t);N(s,t),l(";")},function(){$(s)}),t.add(s),p||!s.repeated||Z.packed[r]===tt&&Z.basic[r]!==tt||s.setOption("packed",!1,!0)}else!function(t,i){var n=h();if(!G.test(n))throw b(n,"name");var r=B.lcFirst(n);n===r&&(n=B.ucFirst(n));l("=");var e=k(h()),s=new F(n);s.group=!0;var u=new L(r,e,n,i);u.filename=Y.filename,S(s,function(t){switch(t){case"option":N(s,t),l(";");break;case"required":case"optional":case"repeated":T(s,t);break;default:throw b(t)}}),t.add(s).add(u)}(t,i)}function N(t,i){var n=l("(",!0);if(!K.test(i=h()))throw b(i,"name");var r=i;n&&(l(")"),r="("+r+")",i=c(),Q.test(i)&&(r+=i,h())),l("="),function t(i,n){if(l("{",!0))do{if(!G.test(o=h()))throw b(o,"name");"{"===c()?t(i,n+"."+o):(l(":"),"{"===c()?t(i,n+"."+o):V(i,n+"."+o,g(!0))),l(",",!0)}while(!l("}",!0));else V(i,n,g(!0))}(t,r)}function V(t,i,n){t.setOption&&t.setOption(i,n)}function $(t){if(l("[",!0)){for(;N(t,"option"),l(",",!0););l("]")}return t}for(;null!==(o=h());)switch(o){case"package":if(!d)throw b(o);E();break;case"import":if(!d)throw b(o);O();break;case"syntax":if(!d)throw b(o);A();break;case"option":if(!d)throw b(o);N(w,o),l(";");break;default:if(x(w,o)){d=!1;continue}throw b(o)}return Y.filename=null,{package:r,imports:e,weakImports:s,syntax:u,root:i}}},{15:15,16:16,20:20,22:22,25:25,29:29,33:33,34:34,35:35,36:36,37:37}],27:[function(t,i){i.exports=o;var n,r=t(39),e=r.LongBits,s=r.utf8;function u(t,i){return RangeError("index out of range: "+t.pos+" + "+(i||1)+" > "+t.len)}function o(t){this.buf=t,this.pos=0,this.len=t.length}var f,h="undefined"!=typeof Uint8Array?function(t){if(t instanceof Uint8Array||Array.isArray(t))return new o(t);throw Error("illegal buffer")}:function(t){if(Array.isArray(t))return new o(t);throw Error("illegal buffer")};function a(){var t=new e(0,0),i=0;if(!(4=this.len)throw u(this);if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*i)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(127&this.buf[this.pos++])<<7*i)>>>0,t}for(;i<4;++i)if(t.lo=(t.lo|(127&this.buf[this.pos])<<7*i)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(127&this.buf[this.pos])<<28)>>>0,t.hi=(t.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return t;if(i=0,4>>0,this.buf[this.pos++]<128)return t}else for(;i<5;++i){if(this.pos>=this.len)throw u(this);if(t.hi=(t.hi|(127&this.buf[this.pos])<<7*i+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}function c(t,i){return(t[i-4]|t[i-3]<<8|t[i-2]<<16|t[i-1]<<24)>>>0}function l(){if(this.pos+8>this.len)throw u(this,8);return new e(c(this.buf,this.pos+=4),c(this.buf,this.pos+=4))}o.create=r.Buffer?function(t){return(o.create=function(t){return r.Buffer.isBuffer(t)?new n(t):h(t)})(t)}:h,o.prototype.c=r.Array.prototype.subarray||r.Array.prototype.slice,o.prototype.uint32=(f=4294967295,function(){if(f=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return f;if(f=(f|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return f;if((this.pos+=5)>this.len)throw this.pos=this.len,u(this,10);return f}),o.prototype.int32=function(){return 0|this.uint32()},o.prototype.sint32=function(){var t=this.uint32();return t>>>1^-(1&t)|0},o.prototype.bool=function(){return 0!==this.uint32()},o.prototype.fixed32=function(){if(this.pos+4>this.len)throw u(this,4);return c(this.buf,this.pos+=4)},o.prototype.sfixed32=function(){if(this.pos+4>this.len)throw u(this,4);return 0|c(this.buf,this.pos+=4)},o.prototype.float=function(){if(this.pos+4>this.len)throw u(this,4);var t=r.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t},o.prototype.double=function(){if(this.pos+8>this.len)throw u(this,4);var t=r.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t},o.prototype.bytes=function(){var t=this.uint32(),i=this.pos,n=this.pos+t;if(n>this.len)throw u(this,t);return this.pos+=t,Array.isArray(this.buf)?this.buf.slice(i,n):i===n?new this.buf.constructor(0):this.c.call(this.buf,i,n)},o.prototype.string=function(){var t=this.bytes();return s.read(t,0,t.length)},o.prototype.skip=function(t){if("number"==typeof t){if(this.pos+t>this.len)throw u(this,t);this.pos+=t}else do{if(this.pos>=this.len)throw u(this)}while(128&this.buf[this.pos++]);return this},o.prototype.skipType=function(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(t=7&this.uint32());)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+t+" at offset "+this.pos)}return this},o.o=function(t){n=t;var i=r.Long?"toLong":"toNumber";r.merge(o.prototype,{int64:function(){return a.call(this)[i](!1)},uint64:function(){return a.call(this)[i](!0)},sint64:function(){return a.call(this).zzDecode()[i](!1)},fixed64:function(){return l.call(this)[i](!0)},sfixed64:function(){return l.call(this)[i](!1)}})}},{39:39}],28:[function(t,i){i.exports=e;var n=t(27);(e.prototype=Object.create(n.prototype)).constructor=e;var r=t(39);function e(t){n.call(this,t)}r.Buffer&&(e.prototype.c=r.Buffer.prototype.slice),e.prototype.string=function(){var t=this.uint32();return this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len))}},{27:27,39:39}],29:[function(t,i){i.exports=n;var r=t(23);((n.prototype=Object.create(r.prototype)).constructor=n).className="Root";var e,v,d,s=t(16),u=t(15),o=t(25),p=t(37);function n(t){r.call(this,"",t),this.deferred=[],this.files=[]}function w(){}n.fromJSON=function(t,i){return i||(i=new n),t.options&&i.setOptions(t.options),i.addJSON(t.nested)},n.prototype.resolvePath=p.path.resolve,n.prototype.load=function t(i,s,u){"function"==typeof s&&(u=s,s=tt);var o=this;if(!u)return p.asPromise(t,o,i,s);var f=u===w;function h(t,i){if(u){var n=u;if(u=null,f)throw t;n(t,i)}}function a(t,i){try{if(p.isString(i)&&"{"===i.charAt(0)&&(i=JSON.parse(i)),p.isString(i)){v.filename=t;var n,r=v(i,o,s),e=0;if(r.imports)for(;e]/g,O=/(?:"([^"\\]*(?:\\.[^"\\]*)*)")/g,A=/(?:'([^'\\]*(?:\\.[^'\\]*)*)')/g,x=/^ *[*/]+ */,S=/^\s*\*?\/*/,T=/\n/g,N=/\s/,n=/\\(.?)/g,r={0:"\0",r:"\r",n:"\n",t:"\t"};function V(t){return t.replace(n,function(t,i){switch(i){case"\\":case"":return i;default:return r[i]||""}})}function e(o,f){o=o.toString();var h=0,a=o.length,c=1,u=null,l=null,v=0,d=!1,p=[],w=null;function y(t){return Error("illegal "+t+" (line "+c+")")}function b(t){return o.charAt(t)}function m(t,i){u=o.charAt(t++),v=c,d=!1;var n,r=t-(f?2:3);do{if(--r<0||"\n"===(n=o.charAt(r))){d=!0;break}}while(" "===n||"\t"===n);for(var e=o.substring(t,i).split(T),s=0;s>>0,this.hi=i>>>0}var s=e.zero=new e(0,0);s.toNumber=function(){return 0},s.zzEncode=s.zzDecode=function(){return this},s.length=function(){return 1};var r=e.zeroHash="\0\0\0\0\0\0\0\0";e.fromNumber=function(t){if(0===t)return s;var i=t<0;i&&(t=-t);var n=t>>>0,r=(t-n)/4294967296>>>0;return i&&(r=~r>>>0,n=~n>>>0,4294967295<++n&&(n=0,4294967295<++r&&(r=0))),new e(n,r)},e.from=function(t){if("number"==typeof t)return e.fromNumber(t);if(n.isString(t)){if(!n.Long)return e.fromNumber(parseInt(t,10));t=n.Long.fromString(t)}return t.low||t.high?new e(t.low>>>0,t.high>>>0):s},e.prototype.toNumber=function(t){if(!t&&this.hi>>>31){var i=1+~this.lo>>>0,n=~this.hi>>>0;return i||(n=n+1>>>0),-(i+4294967296*n)}return this.lo+4294967296*this.hi},e.prototype.toLong=function(t){return n.Long?new n.Long(0|this.lo,0|this.hi,!!t):{low:0|this.lo,high:0|this.hi,unsigned:!!t}};var u=String.prototype.charCodeAt;e.fromHash=function(t){return t===r?s:new e((u.call(t,0)|u.call(t,1)<<8|u.call(t,2)<<16|u.call(t,3)<<24)>>>0,(u.call(t,4)|u.call(t,5)<<8|u.call(t,6)<<16|u.call(t,7)<<24)>>>0)},e.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},e.prototype.zzEncode=function(){var t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this},e.prototype.zzDecode=function(){var t=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this},e.prototype.length=function(){var t=this.lo,i=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return 0===n?0===i?t<16384?t<128?1:2:t<2097152?3:4:i<16384?i<128?5:6:i<2097152?7:8:n<128?9:10}},{39:39}],39:[function(t,i,n){var r=n;function e(t,i,n){for(var r=Object.keys(i),e=0;e>>7|t.hi<<25)>>>0,t.hi>>>=7;for(;127>>7;i[n++]=t.lo}function d(t,i,n){i[n]=255&t,i[n+1]=t>>>8&255,i[n+2]=t>>>16&255,i[n+3]=t>>>24}a.create=r.Buffer?function(){return(a.create=function(){return new n})()}:function(){return new a},a.alloc=function(t){return new r.Array(t)},r.Array!==Array&&(a.alloc=r.pool(a.alloc,r.Array.prototype.subarray)),a.prototype.g=function(t,i,n){return this.tail=this.tail.next=new o(t,i,n),this.len+=i,this},(l.prototype=Object.create(o.prototype)).fn=function(t,i,n){for(;127>>=7;i[n]=t},a.prototype.uint32=function(t){return this.len+=(this.tail=this.tail.next=new l((t>>>=0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this},a.prototype.int32=function(t){return t<0?this.g(v,10,e.fromNumber(t)):this.uint32(t)},a.prototype.sint32=function(t){return this.uint32((t<<1^t>>31)>>>0)},a.prototype.int64=a.prototype.uint64=function(t){var i=e.from(t);return this.g(v,i.length(),i)},a.prototype.sint64=function(t){var i=e.from(t).zzEncode();return this.g(v,i.length(),i)},a.prototype.bool=function(t){return this.g(c,1,t?1:0)},a.prototype.sfixed32=a.prototype.fixed32=function(t){return this.g(d,4,t>>>0)},a.prototype.sfixed64=a.prototype.fixed64=function(t){var i=e.from(t);return this.g(d,4,i.lo).g(d,4,i.hi)},a.prototype.float=function(t){return this.g(r.float.writeFloatLE,4,t)},a.prototype.double=function(t){return this.g(r.float.writeDoubleLE,8,t)};var p=r.Array.prototype.set?function(t,i,n){i.set(t,n)}:function(t,i,n){for(var r=0;r>>0;if(!i)return this.g(c,1,0);if(r.isString(t)){var n=a.alloc(i=s.length(t));s.decode(t,n,0),t=n}return this.uint32(i).g(p,i,t)},a.prototype.string=function(t){var i=u.length(t);return i?this.uint32(i).g(u.write,i,t):this.g(c,1,0)},a.prototype.fork=function(){return this.states=new h(this),this.head=this.tail=new o(f,0,0),this.len=0,this},a.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new o(f,0,0),this.len=0),this},a.prototype.ldelim=function(){var t=this.head,i=this.tail,n=this.len;return this.reset().uint32(n),n&&(this.tail.next=t.next,this.tail=i,this.len+=n),this},a.prototype.finish=function(){for(var t=this.head.next,i=this.constructor.alloc(this.len),n=0;t;)t.fn(t.val,i,n),n+=t.len,t=t.next;return i},a.o=function(t){n=t}},{39:39}],43:[function(t,i){i.exports=s;var n=t(42);(s.prototype=Object.create(n.prototype)).constructor=s;var r=t(39),e=r.Buffer;function s(){n.call(this)}s.alloc=function(t){return(s.alloc=r.b)(t)};var u=e&&e.prototype instanceof Uint8Array&&"set"===e.prototype.set.name?function(t,i,n){i.set(t,n)}:function(t,i,n){if(t.copy)t.copy(i,n,0,t.length);else for(var r=0;r>>0;return this.uint32(i),i&&this.g(u,i,t),this},s.prototype.string=function(t){var i=e.byteLength(t);return this.uint32(i),i&&this.g(o,i,t),this}},{39:39,42:42}]},e={},t=[19],i=function t(i){var n=e[i];return n||r[i][0].call(n=e[i]={exports:{}},t,n,n.exports),n.exports}(t[0]),i.util.global.protobuf=i,"function"==typeof define&&define.amd&&define(["long"],function(t){return t&&t.isLong&&(i.util.Long=t,i.configure()),i}),"object"==typeof module&&module&&module.exports&&(module.exports=i)}(); +//# sourceMappingURL=protobuf.min.js.map diff --git a/node_modules/protobufjs/dist/protobuf.min.js.map b/node_modules/protobufjs/dist/protobuf.min.js.map new file mode 100644 index 0000000..9bfc346 --- /dev/null +++ b/node_modules/protobufjs/dist/protobuf.min.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["lib/prelude.js","../node_modules/@protobufjs/aspromise/index.js","../node_modules/@protobufjs/base64/index.js","../node_modules/@protobufjs/codegen/index.js","../node_modules/@protobufjs/eventemitter/index.js","../node_modules/@protobufjs/fetch/index.js","../node_modules/@protobufjs/float/index.js","../node_modules/@protobufjs/inquire/index.js","../node_modules/@protobufjs/path/index.js","../node_modules/@protobufjs/pool/index.js","../node_modules/@protobufjs/utf8/index.js","../src/common.js","../src/converter.js","../src/decoder.js","../src/encoder.js","../src/enum.js","../src/field.js","../src/index-light.js","../src/index-minimal.js","../src/index","../src/mapfield.js","../src/message.js","../src/method.js","../src/namespace.js","../src/object.js","../src/oneof.js","../src/parse.js","../src/reader.js","../src/reader_buffer.js","../src/root.js","../src/roots.js","../src/rpc.js","../src/rpc/service.js","../src/service.js","../src/tokenize.js","../src/type.js","../src/types.js","../src/util.js","../src/util/longbits.js","../src/util/minimal.js","../src/verifier.js","../src/wrappers.js","../src/writer.js","../src/writer_buffer.js"],"names":["undefined","modules","cache","entries","protobuf","1","require","module","exports","fn","ctx","params","Array","arguments","length","offset","index","pending","Promise","resolve","reject","err","apply","base64","string","p","n","charAt","Math","ceil","b64","s64","i","encode","buffer","start","end","t","parts","chunk","j","b","push","String","fromCharCode","slice","join","invalidEncoding","decode","c","charCodeAt","Error","test","codegen","functionParams","functionName","body","Codegen","formatStringOrScope","source","toString","verbose","console","log","scopeKeys","Object","keys","scopeParams","scopeValues","scopeOffset","Function","formatParams","formatOffset","replace","$0","$1","value","floor","JSON","stringify","functionNameOverride","EventEmitter","this","_listeners","prototype","on","evt","off","listeners","splice","emit","args","fetch","asPromise","fs","inquire","filename","options","callback","xhr","readFile","contents","XMLHttpRequest","binary","onreadystatechange","readyState","status","response","responseText","Uint8Array","overrideMimeType","responseType","open","send","factory","Float32Array","f32","f8b","le","writeFloat_f32_cpy","val","buf","pos","writeFloat_f32_rev","readFloat_f32_cpy","readFloat_f32_rev","writeFloatLE","writeFloatBE","readFloatLE","readFloatBE","writeFloat_ieee754","writeUint","sign","isNaN","round","exponent","LN2","pow","readFloat_ieee754","readUint","uint","mantissa","NaN","Infinity","bind","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","f64","writeDouble_f64_cpy","writeDouble_f64_rev","readDouble_f64_cpy","readDouble_f64_rev","writeDoubleLE","writeDoubleBE","readDoubleLE","readDoubleBE","writeDouble_ieee754","off0","off1","readDouble_ieee754","lo","hi","moduleName","mod","eval","e","path","isAbsolute","normalize","split","absolute","prefix","shift","originPath","includePath","alreadyNormalized","alloc","size","SIZE","MAX","slab","call","utf8","len","read","write","c1","c2","common","timeType","commonRe","name","json","nested","google","Any","fields","type_url","type","id","Duration","seconds","nanos","Timestamp","Empty","Struct","keyType","Value","oneofs","kind","oneof","nullValue","numberValue","stringValue","boolValue","structValue","listValue","NullValue","values","NULL_VALUE","ListValue","rule","DoubleValue","FloatValue","Int64Value","UInt64Value","Int32Value","UInt32Value","BoolValue","StringValue","BytesValue","FieldMask","paths","get","file","converter","Enum","util","genValuePartial_fromObject","gen","field","fieldIndex","prop","resolvedType","repeated","typeDefault","fullName","isUnsigned","genValuePartial_toObject","fromObject","mtype","fieldsArray","safeProp","map","toObject","sort","compareFieldsById","repeatedFields","mapFields","normalFields","partOf","valuesById","long","low","high","unsigned","toNumber","bytes","arrayDefault","hasKs2","_fieldsArray","indexOf","filter","group","ref","types","basic","packed","rfield","required","wireType","mapKey","genTypePartial","optional","ReflectionObject","create","constructor","className","Namespace","comment","comments","TypeError","reserved","fromJSON","enm","toJSON","toJSONOptions","keepComments","add","isString","isInteger","isReservedId","isReservedName","allow_alias","remove","Field","Type","ruleRe","extend","isObject","toLowerCase","message","defaultValue","Long","extensionField","declaringField","_packed","defineProperty","getOption","setOption","ifNotSet","resolved","defaults","parent","lookupTypeOrEnum","fromNumber","freeze","newBuffer","emptyObject","emptyArray","ctor","d","fieldId","fieldType","fieldRule","decorateType","decorateEnum","fieldName","default","_configure","Type_","build","load","root","Root","loadSync","encoder","decoder","verifier","OneOf","MapField","Service","Method","Message","wrappers","configure","Reader","BufferReader","Writer","BufferWriter","rpc","roots","tokenize","parse","resolvedKeyType","fieldKeyType","fieldValueType","properties","$type","writer","encodeDelimited","reader","decodeDelimited","verify","object","requestType","requestStream","responseStream","resolvedRequestType","resolvedResponseType","lookupType","arrayToJSON","array","obj","_nestedArray","clearCache","namespace","addJSON","toArray","nestedArray","nestedJson","names","methods","getEnum","prev","setOptions","onAdd","onRemove","define","isArray","ptr","part","resolveAll","lookup","filterTypes","parentAlreadyChecked","found","lookupEnum","lookupService","Service_","Enum_","defineProperties","unshift","_handleAdd","_handleRemove","Root_","fieldNames","addFieldsToParent","oneofName","oneOfGetter","set","oneOfSetter","keepCase","base10Re","base10NegRe","base16Re","base16NegRe","base8Re","base8NegRe","numberRe","nameRe","typeRefRe","fqTypeRefRe","pkg","imports","weakImports","syntax","token","tn","alternateCommentMode","next","peek","skip","cmnt","head","isProto3","applyCase","camelCase","illegal","insideTryCatch","line","readString","readValue","acceptTypeRef","substring","parseInt","parseFloat","parseNumber","readRanges","target","acceptStrings","parseId","acceptNegative","parsePackage","parseImport","whichImports","parseSyntax","parseCommon","parseOption","ifBlock","valueType","parseInlineOptions","parseMapField","parseField","parseOneOf","extensions","parseType","dummy","parseEnumValue","parseEnum","service","method","parseMethod","parseService","reference","parseExtension","fnIf","fnElse","trailingLine","lcFirst","ucFirst","parseGroup","isCustom","parseOptionValue","package","LongBits","indexOutOfRange","writeLength","RangeError","create_array","readLongVarint","bits","readFixed32_end","readFixed64","Buffer","isBuffer","_slice","subarray","uint32","int32","sint32","bool","fixed32","sfixed32","float","double","skipType","BufferReader_","merge","int64","uint64","sint64","zzDecode","fixed64","sfixed64","utf8Slice","min","deferred","files","SYNC","resolvePath","self","sync","finish","cb","process","parsed","queued","weak","idx","lastIndexOf","altname","setTimeout","readFileSync","isNode","exposeRe","tryHandleExtension","extendedType","sisterField","parse_","common_","rpcImpl","requestDelimited","responseDelimited","rpcCall","requestCtor","responseCtor","request","endedByRPC","_methodsArray","inherited","methodsArray","rpcService","methodName","isReserved","m","q","s","delimRe","stringDoubleRe","stringSingleRe","setCommentRe","setCommentAltRe","setCommentSplitRe","whitespaceRe","unescapeRe","unescapeMap","0","r","unescape","str","commentType","commentText","commentLine","commentLineEmpty","stack","stringDelim","subject","setComment","commentOffset","lines","trim","isDoubleSlashCommentLine","startOffset","endOffset","findEndOfLine","lineText","cursor","re","lastIndex","match","exec","repeat","curr","isDoc","expected","actual","ret","_fieldsById","_oneofsArray","_ctor","fieldsById","oneofsArray","generateConstructor","ctorProperties","setup","wrapper","originalThis","fork","ldelim","typeName","bake","o","key","safePropBackslashRe","safePropQuoteRe","toUpperCase","camelCaseRe","a","decorateRoot","enumerable","decorateEnumIndex","zero","zzEncode","zeroHash","from","fromString","toLong","fromHash","hash","toHash","mask","part0","part1","part2","dst","src","newError","CustomError","captureStackTrace","pool","global","window","versions","node","Number","isFinite","isset","isSet","hasOwnProperty","utf8Write","_Buffer_from","_Buffer_allocUnsafe","sizeOrArray","dcodeIO","key2Re","key32Re","key64Re","longToHash","longFromHash","fromBits","ProtocolError","fieldMap","longs","enums","encoding","allocUnsafe","seenFirstField","invalid","genVerifyKey","genVerifyValue","oneofProp","substr","Op","noop","State","tail","states","writeByte","VarintOp","writeVarint64","writeFixed32","_push","writeBytes","reset","BufferWriter_","writeBytesBuffer","copy","writeStringBuffer","byteLength","$require","$module","amd","isLong"],"mappings":"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","file":"protobuf.min.js","sourcesContent":["(function prelude(modules, cache, entries) {\r\n\r\n // This is the prelude used to bundle protobuf.js for the browser. Wraps up the CommonJS\r\n // sources through a conflict-free require shim and is again wrapped within an iife that\r\n // provides a minification-friendly `undefined` var plus a global \"use strict\" directive\r\n // so that minification can remove the directives of each module.\r\n\r\n function $require(name) {\r\n var $module = cache[name];\r\n if (!$module)\r\n modules[name][0].call($module = cache[name] = { exports: {} }, $require, $module, $module.exports);\r\n return $module.exports;\r\n }\r\n\r\n var protobuf = $require(entries[0]);\r\n\r\n // Expose globally\r\n protobuf.util.global.protobuf = protobuf;\r\n\r\n // Be nice to AMD\r\n if (typeof define === \"function\" && define.amd)\r\n define([\"long\"], function(Long) {\r\n if (Long && Long.isLong) {\r\n protobuf.util.Long = Long;\r\n protobuf.configure();\r\n }\r\n return protobuf;\r\n });\r\n\r\n // Be nice to CommonJS\r\n if (typeof module === \"object\" && module && module.exports)\r\n module.exports = protobuf;\r\n\r\n})/* end of prelude */","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = codegen;\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @param {string[]} functionParams Function parameter names\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n */\r\nfunction codegen(functionParams, functionName) {\r\n\r\n /* istanbul ignore if */\r\n if (typeof functionParams === \"string\") {\r\n functionName = functionParams;\r\n functionParams = undefined;\r\n }\r\n\r\n var body = [];\r\n\r\n /**\r\n * Appends code to the function's body or finishes generation.\r\n * @typedef Codegen\r\n * @type {function}\r\n * @param {string|Object.} [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any\r\n * @param {...*} [formatParams] Format parameters\r\n * @returns {Codegen|Function} Itself or the generated function if finished\r\n * @throws {Error} If format parameter counts do not match\r\n */\r\n\r\n function Codegen(formatStringOrScope) {\r\n // note that explicit array handling below makes this ~50% faster\r\n\r\n // finish the function\r\n if (typeof formatStringOrScope !== \"string\") {\r\n var source = toString();\r\n if (codegen.verbose)\r\n console.log(\"codegen: \" + source); // eslint-disable-line no-console\r\n source = \"return \" + source;\r\n if (formatStringOrScope) {\r\n var scopeKeys = Object.keys(formatStringOrScope),\r\n scopeParams = new Array(scopeKeys.length + 1),\r\n scopeValues = new Array(scopeKeys.length),\r\n scopeOffset = 0;\r\n while (scopeOffset < scopeKeys.length) {\r\n scopeParams[scopeOffset] = scopeKeys[scopeOffset];\r\n scopeValues[scopeOffset] = formatStringOrScope[scopeKeys[scopeOffset++]];\r\n }\r\n scopeParams[scopeOffset] = source;\r\n return Function.apply(null, scopeParams).apply(null, scopeValues); // eslint-disable-line no-new-func\r\n }\r\n return Function(source)(); // eslint-disable-line no-new-func\r\n }\r\n\r\n // otherwise append to body\r\n var formatParams = new Array(arguments.length - 1),\r\n formatOffset = 0;\r\n while (formatOffset < formatParams.length)\r\n formatParams[formatOffset] = arguments[++formatOffset];\r\n formatOffset = 0;\r\n formatStringOrScope = formatStringOrScope.replace(/%([%dfijs])/g, function replace($0, $1) {\r\n var value = formatParams[formatOffset++];\r\n switch ($1) {\r\n case \"d\": case \"f\": return String(Number(value));\r\n case \"i\": return String(Math.floor(value));\r\n case \"j\": return JSON.stringify(value);\r\n case \"s\": return String(value);\r\n }\r\n return \"%\";\r\n });\r\n if (formatOffset !== formatParams.length)\r\n throw Error(\"parameter count mismatch\");\r\n body.push(formatStringOrScope);\r\n return Codegen;\r\n }\r\n\r\n function toString(functionNameOverride) {\r\n return \"function \" + (functionNameOverride || functionName || \"\") + \"(\" + (functionParams && functionParams.join(\",\") || \"\") + \"){\\n \" + body.join(\"\\n \") + \"\\n}\";\r\n }\r\n\r\n Codegen.toString = toString;\r\n return Codegen;\r\n}\r\n\r\n/**\r\n * Begins generating a function.\r\n * @memberof util\r\n * @function codegen\r\n * @param {string} [functionName] Function name if not anonymous\r\n * @returns {Codegen} Appender that appends code to the function's body\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * When set to `true`, codegen will log generated code to console. Useful for debugging.\r\n * @name util.codegen.verbose\r\n * @type {boolean}\r\n */\r\ncodegen.verbose = false;\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = fetch;\r\n\r\nvar asPromise = require(1),\r\n inquire = require(7);\r\n\r\nvar fs = inquire(\"fs\");\r\n\r\n/**\r\n * Node-style callback as used by {@link util.fetch}.\r\n * @typedef FetchCallback\r\n * @type {function}\r\n * @param {?Error} error Error, if any, otherwise `null`\r\n * @param {string} [contents] File contents, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Options as used by {@link util.fetch}.\r\n * @typedef FetchOptions\r\n * @type {Object}\r\n * @property {boolean} [binary=false] Whether expecting a binary response\r\n * @property {boolean} [xhr=false] If `true`, forces the use of XMLHttpRequest\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @memberof util\r\n * @param {string} filename File path or url\r\n * @param {FetchOptions} options Fetch options\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nfunction fetch(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = {};\r\n } else if (!options)\r\n options = {};\r\n\r\n if (!callback)\r\n return asPromise(fetch, this, filename, options); // eslint-disable-line no-invalid-this\r\n\r\n // if a node-like filesystem is present, try it first but fall back to XHR if nothing is found.\r\n if (!options.xhr && fs && fs.readFile)\r\n return fs.readFile(filename, function fetchReadFileCallback(err, contents) {\r\n return err && typeof XMLHttpRequest !== \"undefined\"\r\n ? fetch.xhr(filename, options, callback)\r\n : err\r\n ? callback(err)\r\n : callback(null, options.binary ? contents : contents.toString(\"utf8\"));\r\n });\r\n\r\n // use the XHR version otherwise.\r\n return fetch.xhr(filename, options, callback);\r\n}\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n\r\n/**\r\n * Fetches the contents of a file.\r\n * @name util.fetch\r\n * @function\r\n * @param {string} path File path or url\r\n * @param {FetchOptions} [options] Fetch options\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n\r\n/**/\r\nfetch.xhr = function fetch_xhr(filename, options, callback) {\r\n var xhr = new XMLHttpRequest();\r\n xhr.onreadystatechange /* works everywhere */ = function fetchOnReadyStateChange() {\r\n\r\n if (xhr.readyState !== 4)\r\n return undefined;\r\n\r\n // local cors security errors return status 0 / empty string, too. afaik this cannot be\r\n // reliably distinguished from an actually empty file for security reasons. feel free\r\n // to send a pull request if you are aware of a solution.\r\n if (xhr.status !== 0 && xhr.status !== 200)\r\n return callback(Error(\"status \" + xhr.status));\r\n\r\n // if binary data is expected, make sure that some sort of array is returned, even if\r\n // ArrayBuffers are not supported. the binary string fallback, however, is unsafe.\r\n if (options.binary) {\r\n var buffer = xhr.response;\r\n if (!buffer) {\r\n buffer = [];\r\n for (var i = 0; i < xhr.responseText.length; ++i)\r\n buffer.push(xhr.responseText.charCodeAt(i) & 255);\r\n }\r\n return callback(null, typeof Uint8Array !== \"undefined\" ? new Uint8Array(buffer) : buffer);\r\n }\r\n return callback(null, xhr.responseText);\r\n };\r\n\r\n if (options.binary) {\r\n // ref: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Sending_and_Receiving_Binary_Data#Receiving_binary_data_in_older_browsers\r\n if (\"overrideMimeType\" in xhr)\r\n xhr.overrideMimeType(\"text/plain; charset=x-user-defined\");\r\n xhr.responseType = \"arraybuffer\";\r\n }\r\n\r\n xhr.open(\"GET\", filename);\r\n xhr.send();\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal path module to resolve Unix, Windows and URL paths alike.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar path = exports;\r\n\r\nvar isAbsolute =\r\n/**\r\n * Tests if the specified path is absolute.\r\n * @param {string} path Path to test\r\n * @returns {boolean} `true` if path is absolute\r\n */\r\npath.isAbsolute = function isAbsolute(path) {\r\n return /^(?:\\/|\\w+:)/.test(path);\r\n};\r\n\r\nvar normalize =\r\n/**\r\n * Normalizes the specified path.\r\n * @param {string} path Path to normalize\r\n * @returns {string} Normalized path\r\n */\r\npath.normalize = function normalize(path) {\r\n path = path.replace(/\\\\/g, \"/\")\r\n .replace(/\\/{2,}/g, \"/\");\r\n var parts = path.split(\"/\"),\r\n absolute = isAbsolute(path),\r\n prefix = \"\";\r\n if (absolute)\r\n prefix = parts.shift() + \"/\";\r\n for (var i = 0; i < parts.length;) {\r\n if (parts[i] === \"..\") {\r\n if (i > 0 && parts[i - 1] !== \"..\")\r\n parts.splice(--i, 2);\r\n else if (absolute)\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n } else if (parts[i] === \".\")\r\n parts.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n return prefix + parts.join(\"/\");\r\n};\r\n\r\n/**\r\n * Resolves the specified include path against the specified origin path.\r\n * @param {string} originPath Path to the origin file\r\n * @param {string} includePath Include path relative to origin path\r\n * @param {boolean} [alreadyNormalized=false] `true` if both paths are already known to be normalized\r\n * @returns {string} Path to the include file\r\n */\r\npath.resolve = function resolve(originPath, includePath, alreadyNormalized) {\r\n if (!alreadyNormalized)\r\n includePath = normalize(includePath);\r\n if (isAbsolute(includePath))\r\n return includePath;\r\n if (!alreadyNormalized)\r\n originPath = normalize(originPath);\r\n return (originPath = originPath.replace(/(?:\\/|^)[^/]+$/, \"\")).length ? normalize(originPath + \"/\" + includePath) : includePath;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nmodule.exports = common;\r\n\r\nvar commonRe = /\\/|\\./;\r\n\r\n/**\r\n * Provides common type definitions.\r\n * Can also be used to provide additional google types or your own custom types.\r\n * @param {string} name Short name as in `google/protobuf/[name].proto` or full file name\r\n * @param {Object.} json JSON definition within `google.protobuf` if a short name, otherwise the file's root definition\r\n * @returns {undefined}\r\n * @property {INamespace} google/protobuf/any.proto Any\r\n * @property {INamespace} google/protobuf/duration.proto Duration\r\n * @property {INamespace} google/protobuf/empty.proto Empty\r\n * @property {INamespace} google/protobuf/field_mask.proto FieldMask\r\n * @property {INamespace} google/protobuf/struct.proto Struct, Value, NullValue and ListValue\r\n * @property {INamespace} google/protobuf/timestamp.proto Timestamp\r\n * @property {INamespace} google/protobuf/wrappers.proto Wrappers\r\n * @example\r\n * // manually provides descriptor.proto (assumes google/protobuf/ namespace and .proto extension)\r\n * protobuf.common(\"descriptor\", descriptorJson);\r\n *\r\n * // manually provides a custom definition (uses my.foo namespace)\r\n * protobuf.common(\"my/foo/bar.proto\", myFooBarJson);\r\n */\r\nfunction common(name, json) {\r\n if (!commonRe.test(name)) {\r\n name = \"google/protobuf/\" + name + \".proto\";\r\n json = { nested: { google: { nested: { protobuf: { nested: json } } } } };\r\n }\r\n common[name] = json;\r\n}\r\n\r\n// Not provided because of limited use (feel free to discuss or to provide yourself):\r\n//\r\n// google/protobuf/descriptor.proto\r\n// google/protobuf/source_context.proto\r\n// google/protobuf/type.proto\r\n//\r\n// Stripped and pre-parsed versions of these non-bundled files are instead available as part of\r\n// the repository or package within the google/protobuf directory.\r\n\r\ncommon(\"any\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Any message.\r\n * @interface IAny\r\n * @type {Object}\r\n * @property {string} [typeUrl]\r\n * @property {Uint8Array} [bytes]\r\n * @memberof common\r\n */\r\n Any: {\r\n fields: {\r\n type_url: {\r\n type: \"string\",\r\n id: 1\r\n },\r\n value: {\r\n type: \"bytes\",\r\n id: 2\r\n }\r\n }\r\n }\r\n});\r\n\r\nvar timeType;\r\n\r\ncommon(\"duration\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Duration message.\r\n * @interface IDuration\r\n * @type {Object}\r\n * @property {number|Long} [seconds]\r\n * @property {number} [nanos]\r\n * @memberof common\r\n */\r\n Duration: timeType = {\r\n fields: {\r\n seconds: {\r\n type: \"int64\",\r\n id: 1\r\n },\r\n nanos: {\r\n type: \"int32\",\r\n id: 2\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"timestamp\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Timestamp message.\r\n * @interface ITimestamp\r\n * @type {Object}\r\n * @property {number|Long} [seconds]\r\n * @property {number} [nanos]\r\n * @memberof common\r\n */\r\n Timestamp: timeType\r\n});\r\n\r\ncommon(\"empty\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Empty message.\r\n * @interface IEmpty\r\n * @memberof common\r\n */\r\n Empty: {\r\n fields: {}\r\n }\r\n});\r\n\r\ncommon(\"struct\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.Struct message.\r\n * @interface IStruct\r\n * @type {Object}\r\n * @property {Object.} [fields]\r\n * @memberof common\r\n */\r\n Struct: {\r\n fields: {\r\n fields: {\r\n keyType: \"string\",\r\n type: \"Value\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Value message.\r\n * @interface IValue\r\n * @type {Object}\r\n * @property {string} [kind]\r\n * @property {0} [nullValue]\r\n * @property {number} [numberValue]\r\n * @property {string} [stringValue]\r\n * @property {boolean} [boolValue]\r\n * @property {IStruct} [structValue]\r\n * @property {IListValue} [listValue]\r\n * @memberof common\r\n */\r\n Value: {\r\n oneofs: {\r\n kind: {\r\n oneof: [\r\n \"nullValue\",\r\n \"numberValue\",\r\n \"stringValue\",\r\n \"boolValue\",\r\n \"structValue\",\r\n \"listValue\"\r\n ]\r\n }\r\n },\r\n fields: {\r\n nullValue: {\r\n type: \"NullValue\",\r\n id: 1\r\n },\r\n numberValue: {\r\n type: \"double\",\r\n id: 2\r\n },\r\n stringValue: {\r\n type: \"string\",\r\n id: 3\r\n },\r\n boolValue: {\r\n type: \"bool\",\r\n id: 4\r\n },\r\n structValue: {\r\n type: \"Struct\",\r\n id: 5\r\n },\r\n listValue: {\r\n type: \"ListValue\",\r\n id: 6\r\n }\r\n }\r\n },\r\n\r\n NullValue: {\r\n values: {\r\n NULL_VALUE: 0\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.ListValue message.\r\n * @interface IListValue\r\n * @type {Object}\r\n * @property {Array.} [values]\r\n * @memberof common\r\n */\r\n ListValue: {\r\n fields: {\r\n values: {\r\n rule: \"repeated\",\r\n type: \"Value\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"wrappers\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.DoubleValue message.\r\n * @interface IDoubleValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n DoubleValue: {\r\n fields: {\r\n value: {\r\n type: \"double\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.FloatValue message.\r\n * @interface IFloatValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n FloatValue: {\r\n fields: {\r\n value: {\r\n type: \"float\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Int64Value message.\r\n * @interface IInt64Value\r\n * @type {Object}\r\n * @property {number|Long} [value]\r\n * @memberof common\r\n */\r\n Int64Value: {\r\n fields: {\r\n value: {\r\n type: \"int64\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.UInt64Value message.\r\n * @interface IUInt64Value\r\n * @type {Object}\r\n * @property {number|Long} [value]\r\n * @memberof common\r\n */\r\n UInt64Value: {\r\n fields: {\r\n value: {\r\n type: \"uint64\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.Int32Value message.\r\n * @interface IInt32Value\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n Int32Value: {\r\n fields: {\r\n value: {\r\n type: \"int32\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.UInt32Value message.\r\n * @interface IUInt32Value\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n UInt32Value: {\r\n fields: {\r\n value: {\r\n type: \"uint32\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.BoolValue message.\r\n * @interface IBoolValue\r\n * @type {Object}\r\n * @property {boolean} [value]\r\n * @memberof common\r\n */\r\n BoolValue: {\r\n fields: {\r\n value: {\r\n type: \"bool\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.StringValue message.\r\n * @interface IStringValue\r\n * @type {Object}\r\n * @property {string} [value]\r\n * @memberof common\r\n */\r\n StringValue: {\r\n fields: {\r\n value: {\r\n type: \"string\",\r\n id: 1\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Properties of a google.protobuf.BytesValue message.\r\n * @interface IBytesValue\r\n * @type {Object}\r\n * @property {Uint8Array} [value]\r\n * @memberof common\r\n */\r\n BytesValue: {\r\n fields: {\r\n value: {\r\n type: \"bytes\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\ncommon(\"field_mask\", {\r\n\r\n /**\r\n * Properties of a google.protobuf.FieldMask message.\r\n * @interface IDoubleValue\r\n * @type {Object}\r\n * @property {number} [value]\r\n * @memberof common\r\n */\r\n FieldMask: {\r\n fields: {\r\n paths: {\r\n rule: \"repeated\",\r\n type: \"string\",\r\n id: 1\r\n }\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Gets the root definition of the specified common proto file.\r\n *\r\n * Bundled definitions are:\r\n * - google/protobuf/any.proto\r\n * - google/protobuf/duration.proto\r\n * - google/protobuf/empty.proto\r\n * - google/protobuf/field_mask.proto\r\n * - google/protobuf/struct.proto\r\n * - google/protobuf/timestamp.proto\r\n * - google/protobuf/wrappers.proto\r\n *\r\n * @param {string} file Proto file name\r\n * @returns {INamespace|null} Root definition or `null` if not defined\r\n */\r\ncommon.get = function get(file) {\r\n return common[file] || null;\r\n};\r\n","\"use strict\";\r\n/**\r\n * Runtime message from/to plain object converters.\r\n * @namespace\r\n */\r\nvar converter = exports;\r\n\r\nvar Enum = require(15),\r\n util = require(37);\r\n\r\n/**\r\n * Generates a partial value fromObject conveter.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} prop Property reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genValuePartial_fromObject(gen, field, fieldIndex, prop) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(d%s){\", prop);\r\n for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) {\r\n if (field.repeated && values[keys[i]] === field.typeDefault) gen\r\n (\"default:\");\r\n gen\r\n (\"case%j:\", keys[i])\r\n (\"case %i:\", values[keys[i]])\r\n (\"m%s=%j\", prop, values[keys[i]])\r\n (\"break\");\r\n } gen\r\n (\"}\");\r\n } else gen\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s=types[%i].fromObject(d%s)\", prop, fieldIndex, prop);\r\n } else {\r\n var isUnsigned = false;\r\n switch (field.type) {\r\n case \"double\":\r\n case \"float\": gen\r\n (\"m%s=Number(d%s)\", prop, prop); // also catches \"NaN\", \"Infinity\"\r\n break;\r\n case \"uint32\":\r\n case \"fixed32\": gen\r\n (\"m%s=d%s>>>0\", prop, prop);\r\n break;\r\n case \"int32\":\r\n case \"sint32\":\r\n case \"sfixed32\": gen\r\n (\"m%s=d%s|0\", prop, prop);\r\n break;\r\n case \"uint64\":\r\n isUnsigned = true;\r\n // eslint-disable-line no-fallthrough\r\n case \"int64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(util.Long)\")\r\n (\"(m%s=util.Long.fromValue(d%s)).unsigned=%j\", prop, prop, isUnsigned)\r\n (\"else if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"m%s=parseInt(d%s,10)\", prop, prop)\r\n (\"else if(typeof d%s===\\\"number\\\")\", prop)\r\n (\"m%s=d%s\", prop, prop)\r\n (\"else if(typeof d%s===\\\"object\\\")\", prop)\r\n (\"m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)\", prop, prop, prop, isUnsigned ? \"true\" : \"\");\r\n break;\r\n case \"bytes\": gen\r\n (\"if(typeof d%s===\\\"string\\\")\", prop)\r\n (\"util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)\", prop, prop, prop)\r\n (\"else if(d%s.length)\", prop)\r\n (\"m%s=d%s\", prop, prop);\r\n break;\r\n case \"string\": gen\r\n (\"m%s=String(d%s)\", prop, prop);\r\n break;\r\n case \"bool\": gen\r\n (\"m%s=Boolean(d%s)\", prop, prop);\r\n break;\r\n /* default: gen\r\n (\"m%s=d%s\", prop, prop);\r\n break; */\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a plain object to runtime message converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.fromObject = function fromObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray;\r\n var gen = util.codegen([\"d\"], mtype.name + \"$fromObject\")\r\n (\"if(d instanceof this.ctor)\")\r\n (\"return d\");\r\n if (!fields.length) return gen\r\n (\"return new this.ctor\");\r\n gen\r\n (\"var m=new this.ctor\");\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n prop = util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"if(d%s){\", prop)\r\n (\"if(typeof d%s!==\\\"object\\\")\", prop)\r\n (\"throw TypeError(%j)\", field.fullName + \": object expected\")\r\n (\"m%s={}\", prop)\r\n (\"for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s\", prop, prop, prop, prop, isUnsigned ? \"true\": \"\", prop);\r\n break;\r\n case \"bytes\": gen\r\n (\"d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s\", prop, prop, prop, prop, prop);\r\n break;\r\n default: gen\r\n (\"d%s=m%s\", prop, prop);\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}\r\n\r\n/**\r\n * Generates a runtime message to plain object converter specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nconverter.toObject = function toObject(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n if (!fields.length)\r\n return util.codegen()(\"return {}\");\r\n var gen = util.codegen([\"m\", \"o\"], mtype.name + \"$toObject\")\r\n (\"if(!o)\")\r\n (\"o={}\")\r\n (\"var d={}\");\r\n\r\n var repeatedFields = [],\r\n mapFields = [],\r\n normalFields = [],\r\n i = 0;\r\n for (; i < fields.length; ++i)\r\n if (!fields[i].partOf)\r\n ( fields[i].resolve().repeated ? repeatedFields\r\n : fields[i].map ? mapFields\r\n : normalFields).push(fields[i]);\r\n\r\n if (repeatedFields.length) { gen\r\n (\"if(o.arrays||o.defaults){\");\r\n for (i = 0; i < repeatedFields.length; ++i) gen\r\n (\"d%s=[]\", util.safeProp(repeatedFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (mapFields.length) { gen\r\n (\"if(o.objects||o.defaults){\");\r\n for (i = 0; i < mapFields.length; ++i) gen\r\n (\"d%s={}\", util.safeProp(mapFields[i].name));\r\n gen\r\n (\"}\");\r\n }\r\n\r\n if (normalFields.length) { gen\r\n (\"if(o.defaults){\");\r\n for (i = 0; i < normalFields.length; ++i) {\r\n var field = normalFields[i],\r\n prop = util.safeProp(field.name);\r\n if (field.resolvedType instanceof Enum) gen\r\n (\"d%s=o.enums===String?%j:%j\", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault);\r\n else if (field.long) gen\r\n (\"if(util.Long){\")\r\n (\"var n=new util.Long(%i,%i,%j)\", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned)\r\n (\"d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n\", prop)\r\n (\"}else\")\r\n (\"d%s=o.longs===String?%j:%i\", prop, field.typeDefault.toString(), field.typeDefault.toNumber());\r\n else if (field.bytes) {\r\n var arrayDefault = \"[\" + Array.prototype.slice.call(field.typeDefault).join(\",\") + \"]\";\r\n gen\r\n (\"if(o.bytes===String)d%s=%j\", prop, String.fromCharCode.apply(String, field.typeDefault))\r\n (\"else{\")\r\n (\"d%s=%s\", prop, arrayDefault)\r\n (\"if(o.bytes!==Array)d%s=util.newBuffer(d%s)\", prop, prop)\r\n (\"}\");\r\n } else gen\r\n (\"d%s=%j\", prop, field.typeDefault); // also messages (=null)\r\n } gen\r\n (\"}\");\r\n }\r\n var hasKs2 = false;\r\n for (i = 0; i < fields.length; ++i) {\r\n var field = fields[i],\r\n index = mtype._fieldsArray.indexOf(field),\r\n prop = util.safeProp(field.name);\r\n if (field.map) {\r\n if (!hasKs2) { hasKs2 = true; gen\r\n (\"var ks2\");\r\n } gen\r\n (\"if(m%s&&(ks2=Object.keys(m%s)).length){\", prop, prop)\r\n (\"d%s={}\", prop)\r\n (\"for(var j=0;j>>3){\");\r\n\r\n var i = 0;\r\n for (; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n ref = \"m\" + util.safeProp(field.name); gen\r\n (\"case %i:\", field.id);\r\n\r\n // Map fields\r\n if (field.map) { gen\r\n (\"r.skip().pos++\") // assumes id 1 + key wireType\r\n (\"if(%s===util.emptyObject)\", ref)\r\n (\"%s={}\", ref)\r\n (\"k=r.%s()\", field.keyType)\r\n (\"r.pos++\"); // assumes id 2 + value wireType\r\n if (types.long[field.keyType] !== undefined) {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[typeof k===\\\"object\\\"?util.longToHash(k):k]=r.%s()\", ref, type);\r\n } else {\r\n if (types.basic[type] === undefined) gen\r\n (\"%s[k]=types[%i].decode(r,r.uint32())\", ref, i); // can't be groups\r\n else gen\r\n (\"%s[k]=r.%s()\", ref, type);\r\n }\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n\r\n (\"if(!(%s&&%s.length))\", ref, ref)\r\n (\"%s=[]\", ref);\r\n\r\n // Packable (always check for forward and backward compatiblity)\r\n if (types.packed[type] !== undefined) gen\r\n (\"if((t&7)===2){\")\r\n (\"var c2=r.uint32()+r.pos\")\r\n (\"while(r.pos>> 0, (field.id << 3 | 4) >>> 0)\r\n : gen(\"types[%i].encode(%s,w.uint32(%i).fork()).ldelim()\", fieldIndex, ref, (field.id << 3 | 2) >>> 0);\r\n}\r\n\r\n/**\r\n * Generates an encoder specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction encoder(mtype) {\r\n /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n var gen = util.codegen([\"m\", \"w\"], mtype.name + \"$encode\")\r\n (\"if(!w)\")\r\n (\"w=Writer.create()\");\r\n\r\n var i, ref;\r\n\r\n // \"when a message is serialized its known fields should be written sequentially by field number\"\r\n var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById);\r\n\r\n for (var i = 0; i < fields.length; ++i) {\r\n var field = fields[i].resolve(),\r\n index = mtype._fieldsArray.indexOf(field),\r\n type = field.resolvedType instanceof Enum ? \"int32\" : field.type,\r\n wireType = types.basic[type];\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n // Map fields\r\n if (field.map) {\r\n gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name) // !== undefined && !== null\r\n (\"for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType);\r\n if (wireType === undefined) gen\r\n (\"types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()\", index, ref); // can't be groups\r\n else gen\r\n (\".uint32(%i).%s(%s[ks[i]]).ldelim()\", 16 | wireType, type, ref);\r\n gen\r\n (\"}\")\r\n (\"}\");\r\n\r\n // Repeated fields\r\n } else if (field.repeated) { gen\r\n (\"if(%s!=null&&%s.length){\", ref, ref); // !== undefined && !== null\r\n\r\n // Packed repeated\r\n if (field.packed && types.packed[type] !== undefined) { gen\r\n\r\n (\"w.uint32(%i).fork()\", (field.id << 3 | 2) >>> 0)\r\n (\"for(var i=0;i<%s.length;++i)\", ref)\r\n (\"w.%s(%s[i])\", type, ref)\r\n (\"w.ldelim()\");\r\n\r\n // Non-packed\r\n } else { gen\r\n\r\n (\"for(var i=0;i<%s.length;++i)\", ref);\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref + \"[i]\");\r\n else gen\r\n (\"w.uint32(%i).%s(%s[i])\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n } gen\r\n (\"}\");\r\n\r\n // Non-repeated\r\n } else {\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j))\", ref, field.name); // !== undefined && !== null\r\n\r\n if (wireType === undefined)\r\n genTypePartial(gen, field, index, ref);\r\n else gen\r\n (\"w.uint32(%i).%s(%s)\", (field.id << 3 | wireType) >>> 0, type, ref);\r\n\r\n }\r\n }\r\n\r\n return gen\r\n (\"return w\");\r\n /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */\r\n}","\"use strict\";\r\nmodule.exports = Enum;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = \"Enum\";\r\n\r\nvar Namespace = require(23),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new enum instance.\r\n * @classdesc Reflected enum.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {Object.} [values] Enum values as an object, by name\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this enum\r\n * @param {Object.} [comments] The value comments for this enum\r\n */\r\nfunction Enum(name, values, options, comment, comments) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (values && typeof values !== \"object\")\r\n throw TypeError(\"values must be an object\");\r\n\r\n /**\r\n * Enum values by id.\r\n * @type {Object.}\r\n */\r\n this.valuesById = {};\r\n\r\n /**\r\n * Enum values by name.\r\n * @type {Object.}\r\n */\r\n this.values = Object.create(this.valuesById); // toJSON, marker\r\n\r\n /**\r\n * Enum comment text.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n\r\n /**\r\n * Value comment texts, if any.\r\n * @type {Object.}\r\n */\r\n this.comments = comments || {};\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n // Note that values inherit valuesById on their prototype which makes them a TypeScript-\r\n // compatible enum. This is used by pbts to write actual enum definitions that work for\r\n // static and reflection code alike instead of emitting generic object definitions.\r\n\r\n if (values)\r\n for (var keys = Object.keys(values), i = 0; i < keys.length; ++i)\r\n if (typeof values[keys[i]] === \"number\") // use forward entries only\r\n this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i];\r\n}\r\n\r\n/**\r\n * Enum descriptor.\r\n * @interface IEnum\r\n * @property {Object.} values Enum values\r\n * @property {Object.} [options] Enum options\r\n */\r\n\r\n/**\r\n * Constructs an enum from an enum descriptor.\r\n * @param {string} name Enum name\r\n * @param {IEnum} json Enum descriptor\r\n * @returns {Enum} Created enum\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nEnum.fromJSON = function fromJSON(name, json) {\r\n var enm = new Enum(name, json.values, json.options, json.comment, json.comments);\r\n enm.reserved = json.reserved;\r\n return enm;\r\n};\r\n\r\n/**\r\n * Converts this enum to an enum descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IEnum} Enum descriptor\r\n */\r\nEnum.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"values\" , this.values,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"comment\" , keepComments ? this.comment : undefined,\r\n \"comments\" , keepComments ? this.comments : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds a value to this enum.\r\n * @param {string} name Value name\r\n * @param {number} id Value id\r\n * @param {string} [comment] Comment, if any\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a value with this name or id\r\n */\r\nEnum.prototype.add = function add(name, id, comment) {\r\n // utilized by the parser but not by .fromJSON\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (!util.isInteger(id))\r\n throw TypeError(\"id must be an integer\");\r\n\r\n if (this.values[name] !== undefined)\r\n throw Error(\"duplicate name '\" + name + \"' in \" + this);\r\n\r\n if (this.isReservedId(id))\r\n throw Error(\"id \" + id + \" is reserved in \" + this);\r\n\r\n if (this.isReservedName(name))\r\n throw Error(\"name '\" + name + \"' is reserved in \" + this);\r\n\r\n if (this.valuesById[id] !== undefined) {\r\n if (!(this.options && this.options.allow_alias))\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n this.values[name] = id;\r\n } else\r\n this.valuesById[this.values[name] = id] = name;\r\n\r\n this.comments[name] = comment || null;\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a value from this enum\r\n * @param {string} name Value name\r\n * @returns {Enum} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `name` is not a name of this enum\r\n */\r\nEnum.prototype.remove = function remove(name) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n var val = this.values[name];\r\n if (val == null)\r\n throw Error(\"name '\" + name + \"' does not exist in \" + this);\r\n\r\n delete this.valuesById[val];\r\n delete this.values[name];\r\n delete this.comments[name];\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nEnum.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Field;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = \"Field\";\r\n\r\nvar Enum = require(15),\r\n types = require(36),\r\n util = require(37);\r\n\r\nvar Type; // cyclic\r\n\r\nvar ruleRe = /^required|optional|repeated$/;\r\n\r\n/**\r\n * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.\r\n * @name Field\r\n * @classdesc Reflected message field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a field from a field descriptor.\r\n * @param {string} name Field name\r\n * @param {IField} json Field descriptor\r\n * @returns {Field} Created field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nField.fromJSON = function fromJSON(name, json) {\r\n return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Field} instead.\r\n * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports FieldBase\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} type Value type\r\n * @param {string|Object.} [rule=\"optional\"] Field rule\r\n * @param {string|Object.} [extend] Extended type if different from parent\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction Field(name, id, type, rule, extend, options, comment) {\r\n\r\n if (util.isObject(rule)) {\r\n comment = extend;\r\n options = rule;\r\n rule = extend = undefined;\r\n } else if (util.isObject(extend)) {\r\n comment = options;\r\n options = extend;\r\n extend = undefined;\r\n }\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n if (!util.isInteger(id) || id < 0)\r\n throw TypeError(\"id must be a non-negative integer\");\r\n\r\n if (!util.isString(type))\r\n throw TypeError(\"type must be a string\");\r\n\r\n if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))\r\n throw TypeError(\"rule must be a string rule\");\r\n\r\n if (extend !== undefined && !util.isString(extend))\r\n throw TypeError(\"extend must be a string\");\r\n\r\n /**\r\n * Field rule, if any.\r\n * @type {string|undefined}\r\n */\r\n this.rule = rule && rule !== \"optional\" ? rule : undefined; // toJSON\r\n\r\n /**\r\n * Field type.\r\n * @type {string}\r\n */\r\n this.type = type; // toJSON\r\n\r\n /**\r\n * Unique field id.\r\n * @type {number}\r\n */\r\n this.id = id; // toJSON, marker\r\n\r\n /**\r\n * Extended type if different from parent.\r\n * @type {string|undefined}\r\n */\r\n this.extend = extend || undefined; // toJSON\r\n\r\n /**\r\n * Whether this field is required.\r\n * @type {boolean}\r\n */\r\n this.required = rule === \"required\";\r\n\r\n /**\r\n * Whether this field is optional.\r\n * @type {boolean}\r\n */\r\n this.optional = !this.required;\r\n\r\n /**\r\n * Whether this field is repeated.\r\n * @type {boolean}\r\n */\r\n this.repeated = rule === \"repeated\";\r\n\r\n /**\r\n * Whether this field is a map or not.\r\n * @type {boolean}\r\n */\r\n this.map = false;\r\n\r\n /**\r\n * Message this field belongs to.\r\n * @type {Type|null}\r\n */\r\n this.message = null;\r\n\r\n /**\r\n * OneOf this field belongs to, if any,\r\n * @type {OneOf|null}\r\n */\r\n this.partOf = null;\r\n\r\n /**\r\n * The field type's default value.\r\n * @type {*}\r\n */\r\n this.typeDefault = null;\r\n\r\n /**\r\n * The field's default value on prototypes.\r\n * @type {*}\r\n */\r\n this.defaultValue = null;\r\n\r\n /**\r\n * Whether this field's value should be treated as a long.\r\n * @type {boolean}\r\n */\r\n this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;\r\n\r\n /**\r\n * Whether this field's value is a buffer.\r\n * @type {boolean}\r\n */\r\n this.bytes = type === \"bytes\";\r\n\r\n /**\r\n * Resolved type if not a basic type.\r\n * @type {Type|Enum|null}\r\n */\r\n this.resolvedType = null;\r\n\r\n /**\r\n * Sister-field within the extended type if a declaring extension field.\r\n * @type {Field|null}\r\n */\r\n this.extensionField = null;\r\n\r\n /**\r\n * Sister-field within the declaring namespace if an extended field.\r\n * @type {Field|null}\r\n */\r\n this.declaringField = null;\r\n\r\n /**\r\n * Internally remembers whether this field is packed.\r\n * @type {boolean|null}\r\n * @private\r\n */\r\n this._packed = null;\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Determines whether this field is packed. Only relevant when repeated and working with proto2.\r\n * @name Field#packed\r\n * @type {boolean}\r\n * @readonly\r\n */\r\nObject.defineProperty(Field.prototype, \"packed\", {\r\n get: function() {\r\n // defaults to packed=true if not explicity set to false\r\n if (this._packed === null)\r\n this._packed = this.getOption(\"packed\") !== false;\r\n return this._packed;\r\n }\r\n});\r\n\r\n/**\r\n * @override\r\n */\r\nField.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (name === \"packed\") // clear cached before setting\r\n this._packed = null;\r\n return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);\r\n};\r\n\r\n/**\r\n * Field descriptor.\r\n * @interface IField\r\n * @property {string} [rule=\"optional\"] Field rule\r\n * @property {string} type Field type\r\n * @property {number} id Field id\r\n * @property {Object.} [options] Field options\r\n */\r\n\r\n/**\r\n * Extension field descriptor.\r\n * @interface IExtensionField\r\n * @extends IField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Converts this field to a field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IField} Field descriptor\r\n */\r\nField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"rule\" , this.rule !== \"optional\" && this.rule || undefined,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Resolves this field's type references.\r\n * @returns {Field} `this`\r\n * @throws {Error} If any reference cannot be resolved\r\n */\r\nField.prototype.resolve = function resolve() {\r\n\r\n if (this.resolved)\r\n return this;\r\n\r\n if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it\r\n this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);\r\n if (this.resolvedType instanceof Type)\r\n this.typeDefault = null;\r\n else // instanceof Enum\r\n this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined\r\n }\r\n\r\n // use explicitly set default value if present\r\n if (this.options && this.options[\"default\"] != null) {\r\n this.typeDefault = this.options[\"default\"];\r\n if (this.resolvedType instanceof Enum && typeof this.typeDefault === \"string\")\r\n this.typeDefault = this.resolvedType.values[this.typeDefault];\r\n }\r\n\r\n // remove unnecessary options\r\n if (this.options) {\r\n if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))\r\n delete this.options.packed;\r\n if (!Object.keys(this.options).length)\r\n this.options = undefined;\r\n }\r\n\r\n // convert to internal data type if necesssary\r\n if (this.long) {\r\n this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === \"u\");\r\n\r\n /* istanbul ignore else */\r\n if (Object.freeze)\r\n Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)\r\n\r\n } else if (this.bytes && typeof this.typeDefault === \"string\") {\r\n var buf;\r\n if (util.base64.test(this.typeDefault))\r\n util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);\r\n else\r\n util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);\r\n this.typeDefault = buf;\r\n }\r\n\r\n // take special care of maps and repeated fields\r\n if (this.map)\r\n this.defaultValue = util.emptyObject;\r\n else if (this.repeated)\r\n this.defaultValue = util.emptyArray;\r\n else\r\n this.defaultValue = this.typeDefault;\r\n\r\n // ensure proper value on prototype\r\n if (this.parent instanceof Type)\r\n this.parent.ctor.prototype[this.name] = this.defaultValue;\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).\r\n * @typedef FieldDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} fieldName Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"string\"|\"bool\"|\"bytes\"|Object} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @param {T} [defaultValue] Default value\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]\r\n */\r\nField.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {\r\n\r\n // submessage: decorate the submessage and use its name as the type\r\n if (typeof fieldType === \"function\")\r\n fieldType = util.decorateType(fieldType).name;\r\n\r\n // enum reference: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldType && typeof fieldType === \"object\")\r\n fieldType = util.decorateEnum(fieldType).name;\r\n\r\n return function fieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new Field(fieldName, fieldId, fieldType, fieldRule, { \"default\": defaultValue }));\r\n };\r\n};\r\n\r\n/**\r\n * Field decorator (TypeScript).\r\n * @name Field.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {Constructor|string} fieldType Field type\r\n * @param {\"optional\"|\"required\"|\"repeated\"} [fieldRule=\"optional\"] Field rule\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends Message\r\n * @variation 2\r\n */\r\n// like Field.d but without a default value\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nField._configure = function configure(Type_) {\r\n Type = Type_;\r\n};\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(18);\r\n\r\nprotobuf.build = \"light\";\r\n\r\n/**\r\n * A node-style callback as used by {@link load} and {@link Root#load}.\r\n * @typedef LoadCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Root} [root] Root, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} root Root namespace, defaults to create a new one if omitted.\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n */\r\nfunction load(filename, root, callback) {\r\n if (typeof root === \"function\") {\r\n callback = root;\r\n root = new protobuf.Root();\r\n } else if (!root)\r\n root = new protobuf.Root();\r\n return root.load(filename, callback);\r\n}\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @see {@link Root#load}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise.\r\n * @name load\r\n * @function\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Promise} Promise\r\n * @see {@link Root#load}\r\n * @variation 3\r\n */\r\n// function load(filename:string, [root:Root]):Promise\r\n\r\nprotobuf.load = load;\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only).\r\n * @param {string|string[]} filename One or multiple files to load\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n * @see {@link Root#loadSync}\r\n */\r\nfunction loadSync(filename, root) {\r\n if (!root)\r\n root = new protobuf.Root();\r\n return root.loadSync(filename);\r\n}\r\n\r\nprotobuf.loadSync = loadSync;\r\n\r\n// Serialization\r\nprotobuf.encoder = require(14);\r\nprotobuf.decoder = require(13);\r\nprotobuf.verifier = require(40);\r\nprotobuf.converter = require(12);\r\n\r\n// Reflection\r\nprotobuf.ReflectionObject = require(24);\r\nprotobuf.Namespace = require(23);\r\nprotobuf.Root = require(29);\r\nprotobuf.Enum = require(15);\r\nprotobuf.Type = require(35);\r\nprotobuf.Field = require(16);\r\nprotobuf.OneOf = require(25);\r\nprotobuf.MapField = require(20);\r\nprotobuf.Service = require(33);\r\nprotobuf.Method = require(22);\r\n\r\n// Runtime\r\nprotobuf.Message = require(21);\r\nprotobuf.wrappers = require(41);\r\n\r\n// Utility\r\nprotobuf.types = require(36);\r\nprotobuf.util = require(37);\r\n\r\n// Set up possibly cyclic reflection dependencies\r\nprotobuf.ReflectionObject._configure(protobuf.Root);\r\nprotobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum);\r\nprotobuf.Root._configure(protobuf.Type);\r\nprotobuf.Field._configure(protobuf.Type);\r\n","\"use strict\";\r\nvar protobuf = exports;\r\n\r\n/**\r\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\r\n * @name build\r\n * @type {string}\r\n * @const\r\n */\r\nprotobuf.build = \"minimal\";\r\n\r\n// Serialization\r\nprotobuf.Writer = require(42);\r\nprotobuf.BufferWriter = require(43);\r\nprotobuf.Reader = require(27);\r\nprotobuf.BufferReader = require(28);\r\n\r\n// Utility\r\nprotobuf.util = require(39);\r\nprotobuf.rpc = require(31);\r\nprotobuf.roots = require(30);\r\nprotobuf.configure = configure;\r\n\r\n/* istanbul ignore next */\r\n/**\r\n * Reconfigures the library according to the environment.\r\n * @returns {undefined}\r\n */\r\nfunction configure() {\r\n protobuf.Reader._configure(protobuf.BufferReader);\r\n protobuf.util._configure();\r\n}\r\n\r\n// Set up buffer utility according to the environment\r\nprotobuf.Writer._configure(protobuf.BufferWriter);\r\nconfigure();\r\n","\"use strict\";\r\nvar protobuf = module.exports = require(17);\r\n\r\nprotobuf.build = \"full\";\r\n\r\n// Parser\r\nprotobuf.tokenize = require(34);\r\nprotobuf.parse = require(26);\r\nprotobuf.common = require(11);\r\n\r\n// Configure parser\r\nprotobuf.Root._configure(protobuf.Type, protobuf.parse, protobuf.common);\r\n","\"use strict\";\r\nmodule.exports = MapField;\r\n\r\n// extends Field\r\nvar Field = require(16);\r\n((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = \"MapField\";\r\n\r\nvar types = require(36),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new map field instance.\r\n * @classdesc Reflected map field.\r\n * @extends FieldBase\r\n * @constructor\r\n * @param {string} name Unique name within its namespace\r\n * @param {number} id Unique id within its namespace\r\n * @param {string} keyType Key type\r\n * @param {string} type Value type\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction MapField(name, id, keyType, type, options, comment) {\r\n Field.call(this, name, id, type, undefined, undefined, options, comment);\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(keyType))\r\n throw TypeError(\"keyType must be a string\");\r\n\r\n /**\r\n * Key type.\r\n * @type {string}\r\n */\r\n this.keyType = keyType; // toJSON, marker\r\n\r\n /**\r\n * Resolved key type if not a basic type.\r\n * @type {ReflectionObject|null}\r\n */\r\n this.resolvedKeyType = null;\r\n\r\n // Overrides Field#map\r\n this.map = true;\r\n}\r\n\r\n/**\r\n * Map field descriptor.\r\n * @interface IMapField\r\n * @extends {IField}\r\n * @property {string} keyType Key type\r\n */\r\n\r\n/**\r\n * Extension map field descriptor.\r\n * @interface IExtensionMapField\r\n * @extends IMapField\r\n * @property {string} extend Extended type\r\n */\r\n\r\n/**\r\n * Constructs a map field from a map field descriptor.\r\n * @param {string} name Field name\r\n * @param {IMapField} json Map field descriptor\r\n * @returns {MapField} Created map field\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMapField.fromJSON = function fromJSON(name, json) {\r\n return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this map field to a map field descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMapField} Map field descriptor\r\n */\r\nMapField.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"keyType\" , this.keyType,\r\n \"type\" , this.type,\r\n \"id\" , this.id,\r\n \"extend\" , this.extend,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMapField.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n\r\n // Besides a value type, map fields have a key type that may be \"any scalar type except for floating point types and bytes\"\r\n if (types.mapKey[this.keyType] === undefined)\r\n throw Error(\"invalid key type: \" + this.keyType);\r\n\r\n return Field.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * Map field decorator (TypeScript).\r\n * @name MapField.d\r\n * @function\r\n * @param {number} fieldId Field id\r\n * @param {\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"} fieldKeyType Field key type\r\n * @param {\"double\"|\"float\"|\"int32\"|\"uint32\"|\"sint32\"|\"fixed32\"|\"sfixed32\"|\"int64\"|\"uint64\"|\"sint64\"|\"fixed64\"|\"sfixed64\"|\"bool\"|\"string\"|\"bytes\"|Object|Constructor<{}>} fieldValueType Field value type\r\n * @returns {FieldDecorator} Decorator function\r\n * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> }\r\n */\r\nMapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) {\r\n\r\n // submessage value: decorate the submessage and use its name as the type\r\n if (typeof fieldValueType === \"function\")\r\n fieldValueType = util.decorateType(fieldValueType).name;\r\n\r\n // enum reference value: create a reflected copy of the enum and keep reuseing it\r\n else if (fieldValueType && typeof fieldValueType === \"object\")\r\n fieldValueType = util.decorateEnum(fieldValueType).name;\r\n\r\n return function mapFieldDecorator(prototype, fieldName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType));\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = Message;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs a new message instance.\r\n * @classdesc Abstract runtime message.\r\n * @constructor\r\n * @param {Properties} [properties] Properties to set\r\n * @template T extends object = object\r\n */\r\nfunction Message(properties) {\r\n // not used internally\r\n if (properties)\r\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\r\n this[keys[i]] = properties[keys[i]];\r\n}\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message.$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/**\r\n * Reference to the reflected type.\r\n * @name Message#$type\r\n * @type {Type}\r\n * @readonly\r\n */\r\n\r\n/*eslint-disable valid-jsdoc*/\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.create = function create(properties) {\r\n return this.$type.create(properties);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encode = function encode(message, writer) {\r\n return this.$type.encode(message, writer);\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its length as a varint.\r\n * @param {T|Object.} message Message to encode\r\n * @param {Writer} [writer] Writer to use\r\n * @returns {Writer} Writer\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.$type.encodeDelimited(message, writer);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @name Message.decode\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decode = function decode(reader) {\r\n return this.$type.decode(reader);\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its length as a varint.\r\n * @name Message.decodeDelimited\r\n * @function\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode\r\n * @returns {T} Decoded message\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.decodeDelimited = function decodeDelimited(reader) {\r\n return this.$type.decodeDelimited(reader);\r\n};\r\n\r\n/**\r\n * Verifies a message of this type.\r\n * @name Message.verify\r\n * @function\r\n * @param {Object.} message Plain object to verify\r\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\r\n */\r\nMessage.verify = function verify(message) {\r\n return this.$type.verify(message);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object\r\n * @returns {T} Message instance\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.fromObject = function fromObject(object) {\r\n return this.$type.fromObject(object);\r\n};\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {T} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @template T extends Message\r\n * @this Constructor\r\n */\r\nMessage.toObject = function toObject(message, options) {\r\n return this.$type.toObject(message, options);\r\n};\r\n\r\n/**\r\n * Converts this message to JSON.\r\n * @returns {Object.} JSON object\r\n */\r\nMessage.prototype.toJSON = function toJSON() {\r\n return this.$type.toObject(this, util.toJSONOptions);\r\n};\r\n\r\n/*eslint-enable valid-jsdoc*/","\"use strict\";\r\nmodule.exports = Method;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = \"Method\";\r\n\r\nvar util = require(37);\r\n\r\n/**\r\n * Constructs a new service method instance.\r\n * @classdesc Reflected service method.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Method name\r\n * @param {string|undefined} type Method type, usually `\"rpc\"`\r\n * @param {string} requestType Request message type\r\n * @param {string} responseType Response message type\r\n * @param {boolean|Object.} [requestStream] Whether the request is streamed\r\n * @param {boolean|Object.} [responseStream] Whether the response is streamed\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] The comment for this method\r\n */\r\nfunction Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) {\r\n\r\n /* istanbul ignore next */\r\n if (util.isObject(requestStream)) {\r\n options = requestStream;\r\n requestStream = responseStream = undefined;\r\n } else if (util.isObject(responseStream)) {\r\n options = responseStream;\r\n responseStream = undefined;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!(type === undefined || util.isString(type)))\r\n throw TypeError(\"type must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(requestType))\r\n throw TypeError(\"requestType must be a string\");\r\n\r\n /* istanbul ignore if */\r\n if (!util.isString(responseType))\r\n throw TypeError(\"responseType must be a string\");\r\n\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Method type.\r\n * @type {string}\r\n */\r\n this.type = type || \"rpc\"; // toJSON\r\n\r\n /**\r\n * Request type.\r\n * @type {string}\r\n */\r\n this.requestType = requestType; // toJSON, marker\r\n\r\n /**\r\n * Whether requests are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.requestStream = requestStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Response type.\r\n * @type {string}\r\n */\r\n this.responseType = responseType; // toJSON\r\n\r\n /**\r\n * Whether responses are streamed or not.\r\n * @type {boolean|undefined}\r\n */\r\n this.responseStream = responseStream ? true : undefined; // toJSON\r\n\r\n /**\r\n * Resolved request type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedRequestType = null;\r\n\r\n /**\r\n * Resolved response type.\r\n * @type {Type|null}\r\n */\r\n this.resolvedResponseType = null;\r\n\r\n /**\r\n * Comment for this method\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Method descriptor.\r\n * @interface IMethod\r\n * @property {string} [type=\"rpc\"] Method type\r\n * @property {string} requestType Request type\r\n * @property {string} responseType Response type\r\n * @property {boolean} [requestStream=false] Whether requests are streamed\r\n * @property {boolean} [responseStream=false] Whether responses are streamed\r\n * @property {Object.} [options] Method options\r\n */\r\n\r\n/**\r\n * Constructs a method from a method descriptor.\r\n * @param {string} name Method name\r\n * @param {IMethod} json Method descriptor\r\n * @returns {Method} Created method\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nMethod.fromJSON = function fromJSON(name, json) {\r\n return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this method to a method descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IMethod} Method descriptor\r\n */\r\nMethod.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"type\" , this.type !== \"rpc\" && /* istanbul ignore next */ this.type || undefined,\r\n \"requestType\" , this.requestType,\r\n \"requestStream\" , this.requestStream,\r\n \"responseType\" , this.responseType,\r\n \"responseStream\" , this.responseStream,\r\n \"options\" , this.options,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nMethod.prototype.resolve = function resolve() {\r\n\r\n /* istanbul ignore if */\r\n if (this.resolved)\r\n return this;\r\n\r\n this.resolvedRequestType = this.parent.lookupType(this.requestType);\r\n this.resolvedResponseType = this.parent.lookupType(this.responseType);\r\n\r\n return ReflectionObject.prototype.resolve.call(this);\r\n};\r\n","\"use strict\";\r\nmodule.exports = Namespace;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = \"Namespace\";\r\n\r\nvar Field = require(16),\r\n util = require(37);\r\n\r\nvar Type, // cyclic\r\n Service,\r\n Enum;\r\n\r\n/**\r\n * Constructs a new namespace instance.\r\n * @name Namespace\r\n * @classdesc Reflected namespace.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n */\r\n\r\n/**\r\n * Constructs a namespace from JSON.\r\n * @memberof Namespace\r\n * @function\r\n * @param {string} name Namespace name\r\n * @param {Object.} json JSON object\r\n * @returns {Namespace} Created namespace\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nNamespace.fromJSON = function fromJSON(name, json) {\r\n return new Namespace(name, json.options).addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Converts an array of reflection objects to JSON.\r\n * @memberof Namespace\r\n * @param {ReflectionObject[]} array Object array\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {Object.|undefined} JSON object or `undefined` when array is empty\r\n */\r\nfunction arrayToJSON(array, toJSONOptions) {\r\n if (!(array && array.length))\r\n return undefined;\r\n var obj = {};\r\n for (var i = 0; i < array.length; ++i)\r\n obj[array[i].name] = array[i].toJSON(toJSONOptions);\r\n return obj;\r\n}\r\n\r\nNamespace.arrayToJSON = arrayToJSON;\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedId = function isReservedId(reserved, id) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (typeof reserved[i] !== \"string\" && reserved[i][0] <= id && reserved[i][1] >= id)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {Array.|undefined} reserved Array of reserved ranges and names\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nNamespace.isReservedName = function isReservedName(reserved, name) {\r\n if (reserved)\r\n for (var i = 0; i < reserved.length; ++i)\r\n if (reserved[i] === name)\r\n return true;\r\n return false;\r\n};\r\n\r\n/**\r\n * Not an actual constructor. Use {@link Namespace} instead.\r\n * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions.\r\n * @exports NamespaceBase\r\n * @extends ReflectionObject\r\n * @abstract\r\n * @constructor\r\n * @param {string} name Namespace name\r\n * @param {Object.} [options] Declared options\r\n * @see {@link Namespace}\r\n */\r\nfunction Namespace(name, options) {\r\n ReflectionObject.call(this, name, options);\r\n\r\n /**\r\n * Nested objects by name.\r\n * @type {Object.|undefined}\r\n */\r\n this.nested = undefined; // toJSON\r\n\r\n /**\r\n * Cached nested objects as an array.\r\n * @type {ReflectionObject[]|null}\r\n * @private\r\n */\r\n this._nestedArray = null;\r\n}\r\n\r\nfunction clearCache(namespace) {\r\n namespace._nestedArray = null;\r\n return namespace;\r\n}\r\n\r\n/**\r\n * Nested objects of this namespace as an array for iteration.\r\n * @name NamespaceBase#nestedArray\r\n * @type {ReflectionObject[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Namespace.prototype, \"nestedArray\", {\r\n get: function() {\r\n return this._nestedArray || (this._nestedArray = util.toArray(this.nested));\r\n }\r\n});\r\n\r\n/**\r\n * Namespace descriptor.\r\n * @interface INamespace\r\n * @property {Object.} [options] Namespace options\r\n * @property {Object.} [nested] Nested object descriptors\r\n */\r\n\r\n/**\r\n * Any extension field descriptor.\r\n * @typedef AnyExtensionField\r\n * @type {IExtensionField|IExtensionMapField}\r\n */\r\n\r\n/**\r\n * Any nested object descriptor.\r\n * @typedef AnyNestedObject\r\n * @type {IEnum|IType|IService|AnyExtensionField|INamespace}\r\n */\r\n// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place)\r\n\r\n/**\r\n * Converts this namespace to a namespace descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {INamespace} Namespace descriptor\r\n */\r\nNamespace.prototype.toJSON = function toJSON(toJSONOptions) {\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"nested\" , arrayToJSON(this.nestedArray, toJSONOptions)\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds nested objects to this namespace from nested object descriptors.\r\n * @param {Object.} nestedJson Any nested object descriptors\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.addJSON = function addJSON(nestedJson) {\r\n var ns = this;\r\n /* istanbul ignore else */\r\n if (nestedJson) {\r\n for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) {\r\n nested = nestedJson[names[i]];\r\n ns.add( // most to least likely\r\n ( nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : nested.id !== undefined\r\n ? Field.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets the nested object of the specified name.\r\n * @param {string} name Nested object name\r\n * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist\r\n */\r\nNamespace.prototype.get = function get(name) {\r\n return this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Gets the values of the nested {@link Enum|enum} of the specified name.\r\n * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`.\r\n * @param {string} name Nested enum name\r\n * @returns {Object.} Enum values\r\n * @throws {Error} If there is no such enum\r\n */\r\nNamespace.prototype.getEnum = function getEnum(name) {\r\n if (this.nested && this.nested[name] instanceof Enum)\r\n return this.nested[name].values;\r\n throw Error(\"no such enum: \" + name);\r\n};\r\n\r\n/**\r\n * Adds a nested object to this namespace.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name\r\n */\r\nNamespace.prototype.add = function add(object) {\r\n\r\n if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace))\r\n throw TypeError(\"object must be a valid nested object\");\r\n\r\n if (!this.nested)\r\n this.nested = {};\r\n else {\r\n var prev = this.get(object.name);\r\n if (prev) {\r\n if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) {\r\n // replace plain namespace but keep existing nested elements and options\r\n var nested = prev.nestedArray;\r\n for (var i = 0; i < nested.length; ++i)\r\n object.add(nested[i]);\r\n this.remove(prev);\r\n if (!this.nested)\r\n this.nested = {};\r\n object.setOptions(prev.options, true);\r\n\r\n } else\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n }\r\n }\r\n this.nested[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this namespace.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Namespace} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this namespace\r\n */\r\nNamespace.prototype.remove = function remove(object) {\r\n\r\n if (!(object instanceof ReflectionObject))\r\n throw TypeError(\"object must be a ReflectionObject\");\r\n if (object.parent !== this)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.nested[object.name];\r\n if (!Object.keys(this.nested).length)\r\n this.nested = undefined;\r\n\r\n object.onRemove(this);\r\n return clearCache(this);\r\n};\r\n\r\n/**\r\n * Defines additial namespaces within this one if not yet existing.\r\n * @param {string|string[]} path Path to create\r\n * @param {*} [json] Nested types to create from JSON\r\n * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty\r\n */\r\nNamespace.prototype.define = function define(path, json) {\r\n\r\n if (util.isString(path))\r\n path = path.split(\".\");\r\n else if (!Array.isArray(path))\r\n throw TypeError(\"illegal path\");\r\n if (path && path.length && path[0] === \"\")\r\n throw Error(\"path must be relative\");\r\n\r\n var ptr = this;\r\n while (path.length > 0) {\r\n var part = path.shift();\r\n if (ptr.nested && ptr.nested[part]) {\r\n ptr = ptr.nested[part];\r\n if (!(ptr instanceof Namespace))\r\n throw Error(\"path conflicts with non-namespace objects\");\r\n } else\r\n ptr.add(ptr = new Namespace(part));\r\n }\r\n if (json)\r\n ptr.addJSON(json);\r\n return ptr;\r\n};\r\n\r\n/**\r\n * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost.\r\n * @returns {Namespace} `this`\r\n */\r\nNamespace.prototype.resolveAll = function resolveAll() {\r\n var nested = this.nestedArray, i = 0;\r\n while (i < nested.length)\r\n if (nested[i] instanceof Namespace)\r\n nested[i++].resolveAll();\r\n else\r\n nested[i++].resolve();\r\n return this.resolve();\r\n};\r\n\r\n/**\r\n * Recursively looks up the reflection object matching the specified path in the scope of this namespace.\r\n * @param {string|string[]} path Path to look up\r\n * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc.\r\n * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n */\r\nNamespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) {\r\n\r\n /* istanbul ignore next */\r\n if (typeof filterTypes === \"boolean\") {\r\n parentAlreadyChecked = filterTypes;\r\n filterTypes = undefined;\r\n } else if (filterTypes && !Array.isArray(filterTypes))\r\n filterTypes = [ filterTypes ];\r\n\r\n if (util.isString(path) && path.length) {\r\n if (path === \".\")\r\n return this.root;\r\n path = path.split(\".\");\r\n } else if (!path.length)\r\n return this;\r\n\r\n // Start at root if path is absolute\r\n if (path[0] === \"\")\r\n return this.root.lookup(path.slice(1), filterTypes);\r\n\r\n // Test if the first part matches any nested object, and if so, traverse if path contains more\r\n var found = this.get(path[0]);\r\n if (found) {\r\n if (path.length === 1) {\r\n if (!filterTypes || filterTypes.indexOf(found.constructor) > -1)\r\n return found;\r\n } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true)))\r\n return found;\r\n\r\n // Otherwise try each nested namespace\r\n } else\r\n for (var i = 0; i < this.nestedArray.length; ++i)\r\n if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true)))\r\n return found;\r\n\r\n // If there hasn't been a match, try again at the parent\r\n if (this.parent === null || parentAlreadyChecked)\r\n return null;\r\n return this.parent.lookup(path, filterTypes);\r\n};\r\n\r\n/**\r\n * Looks up the reflection object at the specified path, relative to this namespace.\r\n * @name NamespaceBase#lookup\r\n * @function\r\n * @param {string|string[]} path Path to look up\r\n * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked\r\n * @returns {ReflectionObject|null} Looked up object or `null` if none could be found\r\n * @variation 2\r\n */\r\n// lookup(path: string, [parentAlreadyChecked: boolean])\r\n\r\n/**\r\n * Looks up the {@link Type|type} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type\r\n * @throws {Error} If `path` does not point to a type\r\n */\r\nNamespace.prototype.lookupType = function lookupType(path) {\r\n var found = this.lookup(path, [ Type ]);\r\n if (!found)\r\n throw Error(\"no such type: \" + path);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Enum} Looked up enum\r\n * @throws {Error} If `path` does not point to an enum\r\n */\r\nNamespace.prototype.lookupEnum = function lookupEnum(path) {\r\n var found = this.lookup(path, [ Enum ]);\r\n if (!found)\r\n throw Error(\"no such Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Type} Looked up type or enum\r\n * @throws {Error} If `path` does not point to a type or enum\r\n */\r\nNamespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) {\r\n var found = this.lookup(path, [ Type, Enum ]);\r\n if (!found)\r\n throw Error(\"no such Type or Enum '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n/**\r\n * Looks up the {@link Service|service} at the specified path, relative to this namespace.\r\n * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`.\r\n * @param {string|string[]} path Path to look up\r\n * @returns {Service} Looked up service\r\n * @throws {Error} If `path` does not point to a service\r\n */\r\nNamespace.prototype.lookupService = function lookupService(path) {\r\n var found = this.lookup(path, [ Service ]);\r\n if (!found)\r\n throw Error(\"no such Service '\" + path + \"' in \" + this);\r\n return found;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nNamespace._configure = function(Type_, Service_, Enum_) {\r\n Type = Type_;\r\n Service = Service_;\r\n Enum = Enum_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = ReflectionObject;\r\n\r\nReflectionObject.className = \"ReflectionObject\";\r\n\r\nvar util = require(37);\r\n\r\nvar Root; // cyclic\r\n\r\n/**\r\n * Constructs a new reflection object instance.\r\n * @classdesc Base class of all reflection objects.\r\n * @constructor\r\n * @param {string} name Object name\r\n * @param {Object.} [options] Declared options\r\n * @abstract\r\n */\r\nfunction ReflectionObject(name, options) {\r\n\r\n if (!util.isString(name))\r\n throw TypeError(\"name must be a string\");\r\n\r\n if (options && !util.isObject(options))\r\n throw TypeError(\"options must be an object\");\r\n\r\n /**\r\n * Options.\r\n * @type {Object.|undefined}\r\n */\r\n this.options = options; // toJSON\r\n\r\n /**\r\n * Unique name within its namespace.\r\n * @type {string}\r\n */\r\n this.name = name;\r\n\r\n /**\r\n * Parent namespace.\r\n * @type {Namespace|null}\r\n */\r\n this.parent = null;\r\n\r\n /**\r\n * Whether already resolved or not.\r\n * @type {boolean}\r\n */\r\n this.resolved = false;\r\n\r\n /**\r\n * Comment text, if any.\r\n * @type {string|null}\r\n */\r\n this.comment = null;\r\n\r\n /**\r\n * Defining file name.\r\n * @type {string|null}\r\n */\r\n this.filename = null;\r\n}\r\n\r\nObject.defineProperties(ReflectionObject.prototype, {\r\n\r\n /**\r\n * Reference to the root namespace.\r\n * @name ReflectionObject#root\r\n * @type {Root}\r\n * @readonly\r\n */\r\n root: {\r\n get: function() {\r\n var ptr = this;\r\n while (ptr.parent !== null)\r\n ptr = ptr.parent;\r\n return ptr;\r\n }\r\n },\r\n\r\n /**\r\n * Full name including leading dot.\r\n * @name ReflectionObject#fullName\r\n * @type {string}\r\n * @readonly\r\n */\r\n fullName: {\r\n get: function() {\r\n var path = [ this.name ],\r\n ptr = this.parent;\r\n while (ptr) {\r\n path.unshift(ptr.name);\r\n ptr = ptr.parent;\r\n }\r\n return path.join(\".\");\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Converts this reflection object to its descriptor representation.\r\n * @returns {Object.} Descriptor\r\n * @abstract\r\n */\r\nReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() {\r\n throw Error(); // not implemented, shouldn't happen\r\n};\r\n\r\n/**\r\n * Called when this object is added to a parent.\r\n * @param {ReflectionObject} parent Parent added to\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onAdd = function onAdd(parent) {\r\n if (this.parent && this.parent !== parent)\r\n this.parent.remove(this);\r\n this.parent = parent;\r\n this.resolved = false;\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleAdd(this);\r\n};\r\n\r\n/**\r\n * Called when this object is removed from a parent.\r\n * @param {ReflectionObject} parent Parent removed from\r\n * @returns {undefined}\r\n */\r\nReflectionObject.prototype.onRemove = function onRemove(parent) {\r\n var root = parent.root;\r\n if (root instanceof Root)\r\n root._handleRemove(this);\r\n this.parent = null;\r\n this.resolved = false;\r\n};\r\n\r\n/**\r\n * Resolves this objects type references.\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.resolve = function resolve() {\r\n if (this.resolved)\r\n return this;\r\n if (this.root instanceof Root)\r\n this.resolved = true; // only if part of a root\r\n return this;\r\n};\r\n\r\n/**\r\n * Gets an option value.\r\n * @param {string} name Option name\r\n * @returns {*} Option value or `undefined` if not set\r\n */\r\nReflectionObject.prototype.getOption = function getOption(name) {\r\n if (this.options)\r\n return this.options[name];\r\n return undefined;\r\n};\r\n\r\n/**\r\n * Sets an option.\r\n * @param {string} name Option name\r\n * @param {*} value Option value\r\n * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) {\r\n if (!ifNotSet || !this.options || this.options[name] === undefined)\r\n (this.options || (this.options = {}))[name] = value;\r\n return this;\r\n};\r\n\r\n/**\r\n * Sets multiple options.\r\n * @param {Object.} options Options to set\r\n * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set\r\n * @returns {ReflectionObject} `this`\r\n */\r\nReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) {\r\n if (options)\r\n for (var keys = Object.keys(options), i = 0; i < keys.length; ++i)\r\n this.setOption(keys[i], options[keys[i]], ifNotSet);\r\n return this;\r\n};\r\n\r\n/**\r\n * Converts this instance to its string representation.\r\n * @returns {string} Class name[, space, full name]\r\n */\r\nReflectionObject.prototype.toString = function toString() {\r\n var className = this.constructor.className,\r\n fullName = this.fullName;\r\n if (fullName.length)\r\n return className + \" \" + fullName;\r\n return className;\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nReflectionObject._configure = function(Root_) {\r\n Root = Root_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = OneOf;\r\n\r\n// extends ReflectionObject\r\nvar ReflectionObject = require(24);\r\n((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = \"OneOf\";\r\n\r\nvar Field = require(16),\r\n util = require(37);\r\n\r\n/**\r\n * Constructs a new oneof instance.\r\n * @classdesc Reflected oneof.\r\n * @extends ReflectionObject\r\n * @constructor\r\n * @param {string} name Oneof name\r\n * @param {string[]|Object.} [fieldNames] Field names\r\n * @param {Object.} [options] Declared options\r\n * @param {string} [comment] Comment associated with this field\r\n */\r\nfunction OneOf(name, fieldNames, options, comment) {\r\n if (!Array.isArray(fieldNames)) {\r\n options = fieldNames;\r\n fieldNames = undefined;\r\n }\r\n ReflectionObject.call(this, name, options);\r\n\r\n /* istanbul ignore if */\r\n if (!(fieldNames === undefined || Array.isArray(fieldNames)))\r\n throw TypeError(\"fieldNames must be an Array\");\r\n\r\n /**\r\n * Field names that belong to this oneof.\r\n * @type {string[]}\r\n */\r\n this.oneof = fieldNames || []; // toJSON, marker\r\n\r\n /**\r\n * Fields that belong to this oneof as an array for iteration.\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent\r\n\r\n /**\r\n * Comment for this field.\r\n * @type {string|null}\r\n */\r\n this.comment = comment;\r\n}\r\n\r\n/**\r\n * Oneof descriptor.\r\n * @interface IOneOf\r\n * @property {Array.} oneof Oneof field names\r\n * @property {Object.} [options] Oneof options\r\n */\r\n\r\n/**\r\n * Constructs a oneof from a oneof descriptor.\r\n * @param {string} name Oneof name\r\n * @param {IOneOf} json Oneof descriptor\r\n * @returns {OneOf} Created oneof\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nOneOf.fromJSON = function fromJSON(name, json) {\r\n return new OneOf(name, json.oneof, json.options, json.comment);\r\n};\r\n\r\n/**\r\n * Converts this oneof to a oneof descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IOneOf} Oneof descriptor\r\n */\r\nOneOf.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , this.options,\r\n \"oneof\" , this.oneof,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Adds the fields of the specified oneof to the parent if not already done so.\r\n * @param {OneOf} oneof The oneof\r\n * @returns {undefined}\r\n * @inner\r\n * @ignore\r\n */\r\nfunction addFieldsToParent(oneof) {\r\n if (oneof.parent)\r\n for (var i = 0; i < oneof.fieldsArray.length; ++i)\r\n if (!oneof.fieldsArray[i].parent)\r\n oneof.parent.add(oneof.fieldsArray[i]);\r\n}\r\n\r\n/**\r\n * Adds a field to this oneof and removes it from its current parent, if any.\r\n * @param {Field} field Field to add\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.add = function add(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n if (field.parent && field.parent !== this.parent)\r\n field.parent.remove(field);\r\n this.oneof.push(field.name);\r\n this.fieldsArray.push(field);\r\n field.partOf = this; // field.parent remains null\r\n addFieldsToParent(this);\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes a field from this oneof and puts it back to the oneof's parent.\r\n * @param {Field} field Field to remove\r\n * @returns {OneOf} `this`\r\n */\r\nOneOf.prototype.remove = function remove(field) {\r\n\r\n /* istanbul ignore if */\r\n if (!(field instanceof Field))\r\n throw TypeError(\"field must be a Field\");\r\n\r\n var index = this.fieldsArray.indexOf(field);\r\n\r\n /* istanbul ignore if */\r\n if (index < 0)\r\n throw Error(field + \" is not a member of \" + this);\r\n\r\n this.fieldsArray.splice(index, 1);\r\n index = this.oneof.indexOf(field.name);\r\n\r\n /* istanbul ignore else */\r\n if (index > -1) // theoretical\r\n this.oneof.splice(index, 1);\r\n\r\n field.partOf = null;\r\n return this;\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onAdd = function onAdd(parent) {\r\n ReflectionObject.prototype.onAdd.call(this, parent);\r\n var self = this;\r\n // Collect present fields\r\n for (var i = 0; i < this.oneof.length; ++i) {\r\n var field = parent.get(this.oneof[i]);\r\n if (field && !field.partOf) {\r\n field.partOf = self;\r\n self.fieldsArray.push(field);\r\n }\r\n }\r\n // Add not yet present fields\r\n addFieldsToParent(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nOneOf.prototype.onRemove = function onRemove(parent) {\r\n for (var i = 0, field; i < this.fieldsArray.length; ++i)\r\n if ((field = this.fieldsArray[i]).parent)\r\n field.parent.remove(field);\r\n ReflectionObject.prototype.onRemove.call(this, parent);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link OneOf.d} (TypeScript).\r\n * @typedef OneOfDecorator\r\n * @type {function}\r\n * @param {Object} prototype Target prototype\r\n * @param {string} oneofName OneOf name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * OneOf decorator (TypeScript).\r\n * @function\r\n * @param {...string} fieldNames Field names\r\n * @returns {OneOfDecorator} Decorator function\r\n * @template T extends string\r\n */\r\nOneOf.d = function decorateOneOf() {\r\n var fieldNames = new Array(arguments.length),\r\n index = 0;\r\n while (index < arguments.length)\r\n fieldNames[index] = arguments[index++];\r\n return function oneOfDecorator(prototype, oneofName) {\r\n util.decorateType(prototype.constructor)\r\n .add(new OneOf(oneofName, fieldNames));\r\n Object.defineProperty(prototype, oneofName, {\r\n get: util.oneOfGetter(fieldNames),\r\n set: util.oneOfSetter(fieldNames)\r\n });\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = parse;\r\n\r\nparse.filename = null;\r\nparse.defaults = { keepCase: false };\r\n\r\nvar tokenize = require(34),\r\n Root = require(29),\r\n Type = require(35),\r\n Field = require(16),\r\n MapField = require(20),\r\n OneOf = require(25),\r\n Enum = require(15),\r\n Service = require(33),\r\n Method = require(22),\r\n types = require(36),\r\n util = require(37);\r\n\r\nvar base10Re = /^[1-9][0-9]*$/,\r\n base10NegRe = /^-?[1-9][0-9]*$/,\r\n base16Re = /^0[x][0-9a-fA-F]+$/,\r\n base16NegRe = /^-?0[x][0-9a-fA-F]+$/,\r\n base8Re = /^0[0-7]+$/,\r\n base8NegRe = /^-?0[0-7]+$/,\r\n numberRe = /^(?![eE])[0-9]*(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?$/,\r\n nameRe = /^[a-zA-Z_][a-zA-Z_0-9]*$/,\r\n typeRefRe = /^(?:\\.?[a-zA-Z_][a-zA-Z_0-9]*)(?:\\.[a-zA-Z_][a-zA-Z_0-9]*)*$/,\r\n fqTypeRefRe = /^(?:\\.[a-zA-Z_][a-zA-Z_0-9]*)+$/;\r\n\r\n/**\r\n * Result object returned from {@link parse}.\r\n * @interface IParserResult\r\n * @property {string|undefined} package Package name, if declared\r\n * @property {string[]|undefined} imports Imports, if any\r\n * @property {string[]|undefined} weakImports Weak imports, if any\r\n * @property {string|undefined} syntax Syntax, if specified (either `\"proto2\"` or `\"proto3\"`)\r\n * @property {Root} root Populated root instance\r\n */\r\n\r\n/**\r\n * Options modifying the behavior of {@link parse}.\r\n * @interface IParseOptions\r\n * @property {boolean} [keepCase=false] Keeps field casing instead of converting to camel case\r\n * @property {boolean} [alternateCommentMode=false] Recognize double-slash comments in addition to doc-block comments.\r\n */\r\n\r\n/**\r\n * Options modifying the behavior of JSON serialization.\r\n * @interface IToJSONOptions\r\n * @property {boolean} [keepComments=false] Serializes comments.\r\n */\r\n\r\n/**\r\n * Parses the given .proto source and returns an object with the parsed contents.\r\n * @param {string} source Source contents\r\n * @param {Root} root Root to populate\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {IParserResult} Parser result\r\n * @property {string} filename=null Currently processing file name for error reporting, if known\r\n * @property {IParseOptions} defaults Default {@link IParseOptions}\r\n */\r\nfunction parse(source, root, options) {\r\n /* eslint-disable callback-return */\r\n if (!(root instanceof Root)) {\r\n options = root;\r\n root = new Root();\r\n }\r\n if (!options)\r\n options = parse.defaults;\r\n\r\n var tn = tokenize(source, options.alternateCommentMode || false),\r\n next = tn.next,\r\n push = tn.push,\r\n peek = tn.peek,\r\n skip = tn.skip,\r\n cmnt = tn.cmnt;\r\n\r\n var head = true,\r\n pkg,\r\n imports,\r\n weakImports,\r\n syntax,\r\n isProto3 = false;\r\n\r\n var ptr = root;\r\n\r\n var applyCase = options.keepCase ? function(name) { return name; } : util.camelCase;\r\n\r\n /* istanbul ignore next */\r\n function illegal(token, name, insideTryCatch) {\r\n var filename = parse.filename;\r\n if (!insideTryCatch)\r\n parse.filename = null;\r\n return Error(\"illegal \" + (name || \"token\") + \" '\" + token + \"' (\" + (filename ? filename + \", \" : \"\") + \"line \" + tn.line + \")\");\r\n }\r\n\r\n function readString() {\r\n var values = [],\r\n token;\r\n do {\r\n /* istanbul ignore if */\r\n if ((token = next()) !== \"\\\"\" && token !== \"'\")\r\n throw illegal(token);\r\n\r\n values.push(next());\r\n skip(token);\r\n token = peek();\r\n } while (token === \"\\\"\" || token === \"'\");\r\n return values.join(\"\");\r\n }\r\n\r\n function readValue(acceptTypeRef) {\r\n var token = next();\r\n switch (token) {\r\n case \"'\":\r\n case \"\\\"\":\r\n push(token);\r\n return readString();\r\n case \"true\": case \"TRUE\":\r\n return true;\r\n case \"false\": case \"FALSE\":\r\n return false;\r\n }\r\n try {\r\n return parseNumber(token, /* insideTryCatch */ true);\r\n } catch (e) {\r\n\r\n /* istanbul ignore else */\r\n if (acceptTypeRef && typeRefRe.test(token))\r\n return token;\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"value\");\r\n }\r\n }\r\n\r\n function readRanges(target, acceptStrings) {\r\n var token, start;\r\n do {\r\n if (acceptStrings && ((token = peek()) === \"\\\"\" || token === \"'\"))\r\n target.push(readString());\r\n else\r\n target.push([ start = parseId(next()), skip(\"to\", true) ? parseId(next()) : start ]);\r\n } while (skip(\",\", true));\r\n skip(\";\");\r\n }\r\n\r\n function parseNumber(token, insideTryCatch) {\r\n var sign = 1;\r\n if (token.charAt(0) === \"-\") {\r\n sign = -1;\r\n token = token.substring(1);\r\n }\r\n switch (token) {\r\n case \"inf\": case \"INF\": case \"Inf\":\r\n return sign * Infinity;\r\n case \"nan\": case \"NAN\": case \"Nan\": case \"NaN\":\r\n return NaN;\r\n case \"0\":\r\n return 0;\r\n }\r\n if (base10Re.test(token))\r\n return sign * parseInt(token, 10);\r\n if (base16Re.test(token))\r\n return sign * parseInt(token, 16);\r\n if (base8Re.test(token))\r\n return sign * parseInt(token, 8);\r\n\r\n /* istanbul ignore else */\r\n if (numberRe.test(token))\r\n return sign * parseFloat(token);\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"number\", insideTryCatch);\r\n }\r\n\r\n function parseId(token, acceptNegative) {\r\n switch (token) {\r\n case \"max\": case \"MAX\": case \"Max\":\r\n return 536870911;\r\n case \"0\":\r\n return 0;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!acceptNegative && token.charAt(0) === \"-\")\r\n throw illegal(token, \"id\");\r\n\r\n if (base10NegRe.test(token))\r\n return parseInt(token, 10);\r\n if (base16NegRe.test(token))\r\n return parseInt(token, 16);\r\n\r\n /* istanbul ignore else */\r\n if (base8NegRe.test(token))\r\n return parseInt(token, 8);\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token, \"id\");\r\n }\r\n\r\n function parsePackage() {\r\n\r\n /* istanbul ignore if */\r\n if (pkg !== undefined)\r\n throw illegal(\"package\");\r\n\r\n pkg = next();\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(pkg))\r\n throw illegal(pkg, \"name\");\r\n\r\n ptr = ptr.define(pkg);\r\n skip(\";\");\r\n }\r\n\r\n function parseImport() {\r\n var token = peek();\r\n var whichImports;\r\n switch (token) {\r\n case \"weak\":\r\n whichImports = weakImports || (weakImports = []);\r\n next();\r\n break;\r\n case \"public\":\r\n next();\r\n // eslint-disable-line no-fallthrough\r\n default:\r\n whichImports = imports || (imports = []);\r\n break;\r\n }\r\n token = readString();\r\n skip(\";\");\r\n whichImports.push(token);\r\n }\r\n\r\n function parseSyntax() {\r\n skip(\"=\");\r\n syntax = readString();\r\n isProto3 = syntax === \"proto3\";\r\n\r\n /* istanbul ignore if */\r\n if (!isProto3 && syntax !== \"proto2\")\r\n throw illegal(syntax, \"syntax\");\r\n\r\n skip(\";\");\r\n }\r\n\r\n function parseCommon(parent, token) {\r\n switch (token) {\r\n\r\n case \"option\":\r\n parseOption(parent, token);\r\n skip(\";\");\r\n return true;\r\n\r\n case \"message\":\r\n parseType(parent, token);\r\n return true;\r\n\r\n case \"enum\":\r\n parseEnum(parent, token);\r\n return true;\r\n\r\n case \"service\":\r\n parseService(parent, token);\r\n return true;\r\n\r\n case \"extend\":\r\n parseExtension(parent, token);\r\n return true;\r\n }\r\n return false;\r\n }\r\n\r\n function ifBlock(obj, fnIf, fnElse) {\r\n var trailingLine = tn.line;\r\n if (obj) {\r\n obj.comment = cmnt(); // try block-type comment\r\n obj.filename = parse.filename;\r\n }\r\n if (skip(\"{\", true)) {\r\n var token;\r\n while ((token = next()) !== \"}\")\r\n fnIf(token);\r\n skip(\";\", true);\r\n } else {\r\n if (fnElse)\r\n fnElse();\r\n skip(\";\");\r\n if (obj && typeof obj.comment !== \"string\")\r\n obj.comment = cmnt(trailingLine); // try line-type comment if no block\r\n }\r\n }\r\n\r\n function parseType(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"type name\");\r\n\r\n var type = new Type(token);\r\n ifBlock(type, function parseType_block(token) {\r\n if (parseCommon(type, token))\r\n return;\r\n\r\n switch (token) {\r\n\r\n case \"map\":\r\n parseMapField(type, token);\r\n break;\r\n\r\n case \"required\":\r\n case \"optional\":\r\n case \"repeated\":\r\n parseField(type, token);\r\n break;\r\n\r\n case \"oneof\":\r\n parseOneOf(type, token);\r\n break;\r\n\r\n case \"extensions\":\r\n readRanges(type.extensions || (type.extensions = []));\r\n break;\r\n\r\n case \"reserved\":\r\n readRanges(type.reserved || (type.reserved = []), true);\r\n break;\r\n\r\n default:\r\n /* istanbul ignore if */\r\n if (!isProto3 || !typeRefRe.test(token))\r\n throw illegal(token);\r\n\r\n push(token);\r\n parseField(type, \"optional\");\r\n break;\r\n }\r\n });\r\n parent.add(type);\r\n }\r\n\r\n function parseField(parent, rule, extend) {\r\n var type = next();\r\n if (type === \"group\") {\r\n parseGroup(parent, rule);\r\n return;\r\n }\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(type))\r\n throw illegal(type, \"type\");\r\n\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n name = applyCase(name);\r\n skip(\"=\");\r\n\r\n var field = new Field(name, parseId(next()), type, rule, extend);\r\n ifBlock(field, function parseField_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(field, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseField_line() {\r\n parseInlineOptions(field);\r\n });\r\n parent.add(field);\r\n\r\n // JSON defaults to packed=true if not set so we have to set packed=false explicity when\r\n // parsing proto2 descriptors without the option, where applicable. This must be done for\r\n // all known packable types and anything that could be an enum (= is not a basic type).\r\n if (!isProto3 && field.repeated && (types.packed[type] !== undefined || types.basic[type] === undefined))\r\n field.setOption(\"packed\", false, /* ifNotSet */ true);\r\n }\r\n\r\n function parseGroup(parent, rule) {\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n var fieldName = util.lcFirst(name);\r\n if (name === fieldName)\r\n name = util.ucFirst(name);\r\n skip(\"=\");\r\n var id = parseId(next());\r\n var type = new Type(name);\r\n type.group = true;\r\n var field = new Field(fieldName, id, name, rule);\r\n field.filename = parse.filename;\r\n ifBlock(type, function parseGroup_block(token) {\r\n switch (token) {\r\n\r\n case \"option\":\r\n parseOption(type, token);\r\n skip(\";\");\r\n break;\r\n\r\n case \"required\":\r\n case \"optional\":\r\n case \"repeated\":\r\n parseField(type, token);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw illegal(token); // there are no groups with proto3 semantics\r\n }\r\n });\r\n parent.add(type)\r\n .add(field);\r\n }\r\n\r\n function parseMapField(parent) {\r\n skip(\"<\");\r\n var keyType = next();\r\n\r\n /* istanbul ignore if */\r\n if (types.mapKey[keyType] === undefined)\r\n throw illegal(keyType, \"type\");\r\n\r\n skip(\",\");\r\n var valueType = next();\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(valueType))\r\n throw illegal(valueType, \"type\");\r\n\r\n skip(\">\");\r\n var name = next();\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(name))\r\n throw illegal(name, \"name\");\r\n\r\n skip(\"=\");\r\n var field = new MapField(applyCase(name), parseId(next()), keyType, valueType);\r\n ifBlock(field, function parseMapField_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(field, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseMapField_line() {\r\n parseInlineOptions(field);\r\n });\r\n parent.add(field);\r\n }\r\n\r\n function parseOneOf(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var oneof = new OneOf(applyCase(token));\r\n ifBlock(oneof, function parseOneOf_block(token) {\r\n if (token === \"option\") {\r\n parseOption(oneof, token);\r\n skip(\";\");\r\n } else {\r\n push(token);\r\n parseField(oneof, \"optional\");\r\n }\r\n });\r\n parent.add(oneof);\r\n }\r\n\r\n function parseEnum(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var enm = new Enum(token);\r\n ifBlock(enm, function parseEnum_block(token) {\r\n switch(token) {\r\n case \"option\":\r\n parseOption(enm, token);\r\n skip(\";\");\r\n break;\r\n\r\n case \"reserved\":\r\n readRanges(enm.reserved || (enm.reserved = []), true);\r\n break;\r\n\r\n default:\r\n parseEnumValue(enm, token);\r\n }\r\n });\r\n parent.add(enm);\r\n }\r\n\r\n function parseEnumValue(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token))\r\n throw illegal(token, \"name\");\r\n\r\n skip(\"=\");\r\n var value = parseId(next(), true),\r\n dummy = {};\r\n ifBlock(dummy, function parseEnumValue_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(dummy, token); // skip\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n }, function parseEnumValue_line() {\r\n parseInlineOptions(dummy); // skip\r\n });\r\n parent.add(token, value, dummy.comment);\r\n }\r\n\r\n function parseOption(parent, token) {\r\n var isCustom = skip(\"(\", true);\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var name = token;\r\n if (isCustom) {\r\n skip(\")\");\r\n name = \"(\" + name + \")\";\r\n token = peek();\r\n if (fqTypeRefRe.test(token)) {\r\n name += token;\r\n next();\r\n }\r\n }\r\n skip(\"=\");\r\n parseOptionValue(parent, name);\r\n }\r\n\r\n function parseOptionValue(parent, name) {\r\n if (skip(\"{\", true)) { // { a: \"foo\" b { c: \"bar\" } }\r\n do {\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n if (peek() === \"{\")\r\n parseOptionValue(parent, name + \".\" + token);\r\n else {\r\n skip(\":\");\r\n if (peek() === \"{\")\r\n parseOptionValue(parent, name + \".\" + token);\r\n else\r\n setOption(parent, name + \".\" + token, readValue(true));\r\n }\r\n skip(\",\", true);\r\n } while (!skip(\"}\", true));\r\n } else\r\n setOption(parent, name, readValue(true));\r\n // Does not enforce a delimiter to be universal\r\n }\r\n\r\n function setOption(parent, name, value) {\r\n if (parent.setOption)\r\n parent.setOption(name, value);\r\n }\r\n\r\n function parseInlineOptions(parent) {\r\n if (skip(\"[\", true)) {\r\n do {\r\n parseOption(parent, \"option\");\r\n } while (skip(\",\", true));\r\n skip(\"]\");\r\n }\r\n return parent;\r\n }\r\n\r\n function parseService(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"service name\");\r\n\r\n var service = new Service(token);\r\n ifBlock(service, function parseService_block(token) {\r\n if (parseCommon(service, token))\r\n return;\r\n\r\n /* istanbul ignore else */\r\n if (token === \"rpc\")\r\n parseMethod(service, token);\r\n else\r\n throw illegal(token);\r\n });\r\n parent.add(service);\r\n }\r\n\r\n function parseMethod(parent, token) {\r\n var type = token;\r\n\r\n /* istanbul ignore if */\r\n if (!nameRe.test(token = next()))\r\n throw illegal(token, \"name\");\r\n\r\n var name = token,\r\n requestType, requestStream,\r\n responseType, responseStream;\r\n\r\n skip(\"(\");\r\n if (skip(\"stream\", true))\r\n requestStream = true;\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token);\r\n\r\n requestType = token;\r\n skip(\")\"); skip(\"returns\"); skip(\"(\");\r\n if (skip(\"stream\", true))\r\n responseStream = true;\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token);\r\n\r\n responseType = token;\r\n skip(\")\");\r\n\r\n var method = new Method(name, type, requestType, responseType, requestStream, responseStream);\r\n ifBlock(method, function parseMethod_block(token) {\r\n\r\n /* istanbul ignore else */\r\n if (token === \"option\") {\r\n parseOption(method, token);\r\n skip(\";\");\r\n } else\r\n throw illegal(token);\r\n\r\n });\r\n parent.add(method);\r\n }\r\n\r\n function parseExtension(parent, token) {\r\n\r\n /* istanbul ignore if */\r\n if (!typeRefRe.test(token = next()))\r\n throw illegal(token, \"reference\");\r\n\r\n var reference = token;\r\n ifBlock(null, function parseExtension_block(token) {\r\n switch (token) {\r\n\r\n case \"required\":\r\n case \"repeated\":\r\n case \"optional\":\r\n parseField(parent, token, reference);\r\n break;\r\n\r\n default:\r\n /* istanbul ignore if */\r\n if (!isProto3 || !typeRefRe.test(token))\r\n throw illegal(token);\r\n push(token);\r\n parseField(parent, \"optional\", reference);\r\n break;\r\n }\r\n });\r\n }\r\n\r\n var token;\r\n while ((token = next()) !== null) {\r\n switch (token) {\r\n\r\n case \"package\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parsePackage();\r\n break;\r\n\r\n case \"import\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseImport();\r\n break;\r\n\r\n case \"syntax\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseSyntax();\r\n break;\r\n\r\n case \"option\":\r\n\r\n /* istanbul ignore if */\r\n if (!head)\r\n throw illegal(token);\r\n\r\n parseOption(ptr, token);\r\n skip(\";\");\r\n break;\r\n\r\n default:\r\n\r\n /* istanbul ignore else */\r\n if (parseCommon(ptr, token)) {\r\n head = false;\r\n continue;\r\n }\r\n\r\n /* istanbul ignore next */\r\n throw illegal(token);\r\n }\r\n }\r\n\r\n parse.filename = null;\r\n return {\r\n \"package\" : pkg,\r\n \"imports\" : imports,\r\n weakImports : weakImports,\r\n syntax : syntax,\r\n root : root\r\n };\r\n}\r\n\r\n/**\r\n * Parses the given .proto source and returns an object with the parsed contents.\r\n * @name parse\r\n * @function\r\n * @param {string} source Source contents\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {IParserResult} Parser result\r\n * @property {string} filename=null Currently processing file name for error reporting, if known\r\n * @property {IParseOptions} defaults Default {@link IParseOptions}\r\n * @variation 2\r\n */\r\n","\"use strict\";\r\nmodule.exports = Reader;\r\n\r\nvar util = require(39);\r\n\r\nvar BufferReader; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n utf8 = util.utf8;\r\n\r\n/* istanbul ignore next */\r\nfunction indexOutOfRange(reader, writeLength) {\r\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\r\n}\r\n\r\n/**\r\n * Constructs a new reader instance using the specified buffer.\r\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n * @param {Uint8Array} buffer Buffer to read from\r\n */\r\nfunction Reader(buffer) {\r\n\r\n /**\r\n * Read buffer.\r\n * @type {Uint8Array}\r\n */\r\n this.buf = buffer;\r\n\r\n /**\r\n * Read buffer position.\r\n * @type {number}\r\n */\r\n this.pos = 0;\r\n\r\n /**\r\n * Read buffer length.\r\n * @type {number}\r\n */\r\n this.len = buffer.length;\r\n}\r\n\r\nvar create_array = typeof Uint8Array !== \"undefined\"\r\n ? function create_typed_array(buffer) {\r\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n }\r\n /* istanbul ignore next */\r\n : function create_array(buffer) {\r\n if (Array.isArray(buffer))\r\n return new Reader(buffer);\r\n throw Error(\"illegal buffer\");\r\n };\r\n\r\n/**\r\n * Creates a new reader using the specified buffer.\r\n * @function\r\n * @param {Uint8Array|Buffer} buffer Buffer to read from\r\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\r\n * @throws {Error} If `buffer` is not a valid buffer\r\n */\r\nReader.create = util.Buffer\r\n ? function create_buffer_setup(buffer) {\r\n return (Reader.create = function create_buffer(buffer) {\r\n return util.Buffer.isBuffer(buffer)\r\n ? new BufferReader(buffer)\r\n /* istanbul ignore next */\r\n : create_array(buffer);\r\n })(buffer);\r\n }\r\n /* istanbul ignore next */\r\n : create_array;\r\n\r\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\r\n\r\n/**\r\n * Reads a varint as an unsigned 32 bit value.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.uint32 = (function read_uint32_setup() {\r\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\r\n return function read_uint32() {\r\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\r\n\r\n /* istanbul ignore if */\r\n if ((this.pos += 5) > this.len) {\r\n this.pos = this.len;\r\n throw indexOutOfRange(this, 10);\r\n }\r\n return value;\r\n };\r\n})();\r\n\r\n/**\r\n * Reads a varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.int32 = function read_int32() {\r\n return this.uint32() | 0;\r\n};\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 32 bit value.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sint32 = function read_sint32() {\r\n var value = this.uint32();\r\n return value >>> 1 ^ -(value & 1) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readLongVarint() {\r\n // tends to deopt with local vars for octet etc.\r\n var bits = new LongBits(0, 0);\r\n var i = 0;\r\n if (this.len - this.pos > 4) { // fast route (lo)\r\n for (; i < 4; ++i) {\r\n // 1st..4th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 5th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n i = 0;\r\n } else {\r\n for (; i < 3; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 1st..3th\r\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n // 4th\r\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\r\n return bits;\r\n }\r\n if (this.len - this.pos > 4) { // fast route (hi)\r\n for (; i < 5; ++i) {\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n } else {\r\n for (; i < 5; ++i) {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n // 6th..10th\r\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\r\n if (this.buf[this.pos++] < 128)\r\n return bits;\r\n }\r\n }\r\n /* istanbul ignore next */\r\n throw Error(\"invalid varint encoding\");\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads a varint as a signed 64 bit value.\r\n * @name Reader#int64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as an unsigned 64 bit value.\r\n * @name Reader#uint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a zig-zag encoded varint as a signed 64 bit value.\r\n * @name Reader#sint64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a varint as a boolean.\r\n * @returns {boolean} Value read\r\n */\r\nReader.prototype.bool = function read_bool() {\r\n return this.uint32() !== 0;\r\n};\r\n\r\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\r\n return (buf[end - 4]\r\n | buf[end - 3] << 8\r\n | buf[end - 2] << 16\r\n | buf[end - 1] << 24) >>> 0;\r\n}\r\n\r\n/**\r\n * Reads fixed 32 bits as an unsigned 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.fixed32 = function read_fixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4);\r\n};\r\n\r\n/**\r\n * Reads fixed 32 bits as a signed 32 bit integer.\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.sfixed32 = function read_sfixed32() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n return readFixed32_end(this.buf, this.pos += 4) | 0;\r\n};\r\n\r\n/* eslint-disable no-invalid-this */\r\n\r\nfunction readFixed64(/* this: Reader */) {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 8);\r\n\r\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\r\n}\r\n\r\n/* eslint-enable no-invalid-this */\r\n\r\n/**\r\n * Reads fixed 64 bits.\r\n * @name Reader#fixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads zig-zag encoded fixed 64 bits.\r\n * @name Reader#sfixed64\r\n * @function\r\n * @returns {Long} Value read\r\n */\r\n\r\n/**\r\n * Reads a float (32 bit) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.float = function read_float() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 4 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readFloatLE(this.buf, this.pos);\r\n this.pos += 4;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a double (64 bit float) as a number.\r\n * @function\r\n * @returns {number} Value read\r\n */\r\nReader.prototype.double = function read_double() {\r\n\r\n /* istanbul ignore if */\r\n if (this.pos + 8 > this.len)\r\n throw indexOutOfRange(this, 4);\r\n\r\n var value = util.float.readDoubleLE(this.buf, this.pos);\r\n this.pos += 8;\r\n return value;\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @returns {Uint8Array} Value read\r\n */\r\nReader.prototype.bytes = function read_bytes() {\r\n var length = this.uint32(),\r\n start = this.pos,\r\n end = this.pos + length;\r\n\r\n /* istanbul ignore if */\r\n if (end > this.len)\r\n throw indexOutOfRange(this, length);\r\n\r\n this.pos += length;\r\n if (Array.isArray(this.buf)) // plain array\r\n return this.buf.slice(start, end);\r\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\r\n ? new this.buf.constructor(0)\r\n : this._slice.call(this.buf, start, end);\r\n};\r\n\r\n/**\r\n * Reads a string preceeded by its byte length as a varint.\r\n * @returns {string} Value read\r\n */\r\nReader.prototype.string = function read_string() {\r\n var bytes = this.bytes();\r\n return utf8.read(bytes, 0, bytes.length);\r\n};\r\n\r\n/**\r\n * Skips the specified number of bytes if specified, otherwise skips a varint.\r\n * @param {number} [length] Length if known, otherwise a varint is assumed\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skip = function skip(length) {\r\n if (typeof length === \"number\") {\r\n /* istanbul ignore if */\r\n if (this.pos + length > this.len)\r\n throw indexOutOfRange(this, length);\r\n this.pos += length;\r\n } else {\r\n do {\r\n /* istanbul ignore if */\r\n if (this.pos >= this.len)\r\n throw indexOutOfRange(this);\r\n } while (this.buf[this.pos++] & 128);\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Skips the next element of the specified wire type.\r\n * @param {number} wireType Wire type received\r\n * @returns {Reader} `this`\r\n */\r\nReader.prototype.skipType = function(wireType) {\r\n switch (wireType) {\r\n case 0:\r\n this.skip();\r\n break;\r\n case 1:\r\n this.skip(8);\r\n break;\r\n case 2:\r\n this.skip(this.uint32());\r\n break;\r\n case 3:\r\n while ((wireType = this.uint32() & 7) !== 4) {\r\n this.skipType(wireType);\r\n }\r\n break;\r\n case 5:\r\n this.skip(4);\r\n break;\r\n\r\n /* istanbul ignore next */\r\n default:\r\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\r\n }\r\n return this;\r\n};\r\n\r\nReader._configure = function(BufferReader_) {\r\n BufferReader = BufferReader_;\r\n\r\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\r\n util.merge(Reader.prototype, {\r\n\r\n int64: function read_int64() {\r\n return readLongVarint.call(this)[fn](false);\r\n },\r\n\r\n uint64: function read_uint64() {\r\n return readLongVarint.call(this)[fn](true);\r\n },\r\n\r\n sint64: function read_sint64() {\r\n return readLongVarint.call(this).zzDecode()[fn](false);\r\n },\r\n\r\n fixed64: function read_fixed64() {\r\n return readFixed64.call(this)[fn](true);\r\n },\r\n\r\n sfixed64: function read_sfixed64() {\r\n return readFixed64.call(this)[fn](false);\r\n }\r\n\r\n });\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferReader;\r\n\r\n// extends Reader\r\nvar Reader = require(27);\r\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs a new buffer reader instance.\r\n * @classdesc Wire format reader using node buffers.\r\n * @extends Reader\r\n * @constructor\r\n * @param {Buffer} buffer Buffer to read from\r\n */\r\nfunction BufferReader(buffer) {\r\n Reader.call(this, buffer);\r\n\r\n /**\r\n * Read buffer.\r\n * @name BufferReader#buf\r\n * @type {Buffer}\r\n */\r\n}\r\n\r\n/* istanbul ignore else */\r\nif (util.Buffer)\r\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\r\n\r\n/**\r\n * @override\r\n */\r\nBufferReader.prototype.string = function read_string_buffer() {\r\n var len = this.uint32(); // modifies pos\r\n return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len));\r\n};\r\n\r\n/**\r\n * Reads a sequence of bytes preceeded by its length as a varint.\r\n * @name BufferReader#bytes\r\n * @function\r\n * @returns {Buffer} Value read\r\n */\r\n","\"use strict\";\r\nmodule.exports = Root;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = \"Root\";\r\n\r\nvar Field = require(16),\r\n Enum = require(15),\r\n OneOf = require(25),\r\n util = require(37);\r\n\r\nvar Type, // cyclic\r\n parse, // might be excluded\r\n common; // \"\r\n\r\n/**\r\n * Constructs a new root namespace instance.\r\n * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {Object.} [options] Top level options\r\n */\r\nfunction Root(options) {\r\n Namespace.call(this, \"\", options);\r\n\r\n /**\r\n * Deferred extension fields.\r\n * @type {Field[]}\r\n */\r\n this.deferred = [];\r\n\r\n /**\r\n * Resolved file names of loaded files.\r\n * @type {string[]}\r\n */\r\n this.files = [];\r\n}\r\n\r\n/**\r\n * Loads a namespace descriptor into a root namespace.\r\n * @param {INamespace} json Nameespace descriptor\r\n * @param {Root} [root] Root namespace, defaults to create a new one if omitted\r\n * @returns {Root} Root namespace\r\n */\r\nRoot.fromJSON = function fromJSON(json, root) {\r\n if (!root)\r\n root = new Root();\r\n if (json.options)\r\n root.setOptions(json.options);\r\n return root.addJSON(json.nested);\r\n};\r\n\r\n/**\r\n * Resolves the path of an imported file, relative to the importing origin.\r\n * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories.\r\n * @function\r\n * @param {string} origin The file name of the importing file\r\n * @param {string} target The file name being imported\r\n * @returns {string|null} Resolved path to `target` or `null` to skip the file\r\n */\r\nRoot.prototype.resolvePath = util.path.resolve;\r\n\r\n// A symbol-like function to safely signal synchronous loading\r\n/* istanbul ignore next */\r\nfunction SYNC() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} options Parse options\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n */\r\nRoot.prototype.load = function load(filename, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = undefined;\r\n }\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(load, self, filename, options);\r\n\r\n var sync = callback === SYNC; // undocumented\r\n\r\n // Finishes loading by calling the callback (exactly once)\r\n function finish(err, root) {\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return;\r\n var cb = callback;\r\n callback = null;\r\n if (sync)\r\n throw err;\r\n cb(err, root);\r\n }\r\n\r\n // Processes a single file\r\n function process(filename, source) {\r\n try {\r\n if (util.isString(source) && source.charAt(0) === \"{\")\r\n source = JSON.parse(source);\r\n if (!util.isString(source))\r\n self.setOptions(source.options).addJSON(source.nested);\r\n else {\r\n parse.filename = filename;\r\n var parsed = parse(source, self, options),\r\n resolved,\r\n i = 0;\r\n if (parsed.imports)\r\n for (; i < parsed.imports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.imports[i]))\r\n fetch(resolved);\r\n if (parsed.weakImports)\r\n for (i = 0; i < parsed.weakImports.length; ++i)\r\n if (resolved = self.resolvePath(filename, parsed.weakImports[i]))\r\n fetch(resolved, true);\r\n }\r\n } catch (err) {\r\n finish(err);\r\n }\r\n if (!sync && !queued)\r\n finish(null, self); // only once anyway\r\n }\r\n\r\n // Fetches a single file\r\n function fetch(filename, weak) {\r\n\r\n // Strip path if this file references a bundled definition\r\n var idx = filename.lastIndexOf(\"google/protobuf/\");\r\n if (idx > -1) {\r\n var altname = filename.substring(idx);\r\n if (altname in common)\r\n filename = altname;\r\n }\r\n\r\n // Skip if already loaded / attempted\r\n if (self.files.indexOf(filename) > -1)\r\n return;\r\n self.files.push(filename);\r\n\r\n // Shortcut bundled definitions\r\n if (filename in common) {\r\n if (sync)\r\n process(filename, common[filename]);\r\n else {\r\n ++queued;\r\n setTimeout(function() {\r\n --queued;\r\n process(filename, common[filename]);\r\n });\r\n }\r\n return;\r\n }\r\n\r\n // Otherwise fetch from disk or network\r\n if (sync) {\r\n var source;\r\n try {\r\n source = util.fs.readFileSync(filename).toString(\"utf8\");\r\n } catch (err) {\r\n if (!weak)\r\n finish(err);\r\n return;\r\n }\r\n process(filename, source);\r\n } else {\r\n ++queued;\r\n util.fetch(filename, function(err, source) {\r\n --queued;\r\n /* istanbul ignore if */\r\n if (!callback)\r\n return; // terminated meanwhile\r\n if (err) {\r\n /* istanbul ignore else */\r\n if (!weak)\r\n finish(err);\r\n else if (!queued) // can't be covered reliably\r\n finish(null, self);\r\n return;\r\n }\r\n process(filename, source);\r\n });\r\n }\r\n }\r\n var queued = 0;\r\n\r\n // Assembling the root namespace doesn't require working type\r\n // references anymore, so we can load everything in parallel\r\n if (util.isString(filename))\r\n filename = [ filename ];\r\n for (var i = 0, resolved; i < filename.length; ++i)\r\n if (resolved = self.resolvePath(\"\", filename[i]))\r\n fetch(resolved);\r\n\r\n if (sync)\r\n return self;\r\n if (!queued)\r\n finish(null, self);\r\n return undefined;\r\n};\r\n// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {LoadCallback} callback Callback function\r\n * @returns {undefined}\r\n * @variation 2\r\n */\r\n// function load(filename:string, callback:LoadCallback):undefined\r\n\r\n/**\r\n * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise.\r\n * @function Root#load\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Promise} Promise\r\n * @variation 3\r\n */\r\n// function load(filename:string, [options:IParseOptions]):Promise\r\n\r\n/**\r\n * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only).\r\n * @function Root#loadSync\r\n * @param {string|string[]} filename Names of one or multiple files to load\r\n * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted.\r\n * @returns {Root} Root namespace\r\n * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid\r\n */\r\nRoot.prototype.loadSync = function loadSync(filename, options) {\r\n if (!util.isNode)\r\n throw Error(\"not supported\");\r\n return this.load(filename, options, SYNC);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nRoot.prototype.resolveAll = function resolveAll() {\r\n if (this.deferred.length)\r\n throw Error(\"unresolvable extensions: \" + this.deferred.map(function(field) {\r\n return \"'extend \" + field.extend + \"' in \" + field.parent.fullName;\r\n }).join(\", \"));\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n// only uppercased (and thus conflict-free) children are exposed, see below\r\nvar exposeRe = /^[A-Z]/;\r\n\r\n/**\r\n * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type.\r\n * @param {Root} root Root instance\r\n * @param {Field} field Declaring extension field witin the declaring type\r\n * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise\r\n * @inner\r\n * @ignore\r\n */\r\nfunction tryHandleExtension(root, field) {\r\n var extendedType = field.parent.lookup(field.extend);\r\n if (extendedType) {\r\n var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options);\r\n sisterField.declaringField = field;\r\n field.extensionField = sisterField;\r\n extendedType.add(sisterField);\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * Called when any object is added to this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object added\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleAdd = function _handleAdd(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField)\r\n if (!tryHandleExtension(this, object))\r\n this.deferred.push(object);\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object.values; // expose enum values as property of its parent\r\n\r\n } else if (!(object instanceof OneOf)) /* everything else is a namespace */ {\r\n\r\n if (object instanceof Type) // Try to handle any deferred extensions\r\n for (var i = 0; i < this.deferred.length;)\r\n if (tryHandleExtension(this, this.deferred[i]))\r\n this.deferred.splice(i, 1);\r\n else\r\n ++i;\r\n for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace\r\n this._handleAdd(object._nestedArray[j]);\r\n if (exposeRe.test(object.name))\r\n object.parent[object.name] = object; // expose namespace as property of its parent\r\n }\r\n\r\n // The above also adds uppercased (and thus conflict-free) nested types, services and enums as\r\n // properties of namespaces just like static code does. This allows using a .d.ts generated for\r\n // a static module with reflection-based solutions where the condition is met.\r\n};\r\n\r\n/**\r\n * Called when any object is removed from this root or its sub-namespaces.\r\n * @param {ReflectionObject} object Object removed\r\n * @returns {undefined}\r\n * @private\r\n */\r\nRoot.prototype._handleRemove = function _handleRemove(object) {\r\n if (object instanceof Field) {\r\n\r\n if (/* an extension field */ object.extend !== undefined) {\r\n if (/* already handled */ object.extensionField) { // remove its sister field\r\n object.extensionField.parent.remove(object.extensionField);\r\n object.extensionField = null;\r\n } else { // cancel the extension\r\n var index = this.deferred.indexOf(object);\r\n /* istanbul ignore else */\r\n if (index > -1)\r\n this.deferred.splice(index, 1);\r\n }\r\n }\r\n\r\n } else if (object instanceof Enum) {\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose enum values\r\n\r\n } else if (object instanceof Namespace) {\r\n\r\n for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace\r\n this._handleRemove(object._nestedArray[i]);\r\n\r\n if (exposeRe.test(object.name))\r\n delete object.parent[object.name]; // unexpose namespaces\r\n\r\n }\r\n};\r\n\r\n// Sets up cyclic dependencies (called in index-light)\r\nRoot._configure = function(Type_, parse_, common_) {\r\n Type = Type_;\r\n parse = parse_;\r\n common = common_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = {};\r\n\r\n/**\r\n * Named roots.\r\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\r\n * Can also be used manually to make roots available accross modules.\r\n * @name roots\r\n * @type {Object.}\r\n * @example\r\n * // pbjs -r myroot -o compiled.js ...\r\n *\r\n * // in another module:\r\n * require(\"./compiled.js\");\r\n *\r\n * // in any subsequent module:\r\n * var root = protobuf.roots[\"myroot\"];\r\n */\r\n","\"use strict\";\r\n\r\n/**\r\n * Streaming RPC helpers.\r\n * @namespace\r\n */\r\nvar rpc = exports;\r\n\r\n/**\r\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\r\n * @typedef RPCImpl\r\n * @type {function}\r\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\r\n * @param {Uint8Array} requestData Request data\r\n * @param {RPCImplCallback} callback Callback function\r\n * @returns {undefined}\r\n * @example\r\n * function rpcImpl(method, requestData, callback) {\r\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\r\n * throw Error(\"no such method\");\r\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\r\n * callback(err, responseData);\r\n * });\r\n * }\r\n */\r\n\r\n/**\r\n * Node-style callback as used by {@link RPCImpl}.\r\n * @typedef RPCImplCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any, otherwise `null`\r\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\r\n * @returns {undefined}\r\n */\r\n\r\nrpc.Service = require(32);\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\nvar util = require(39);\r\n\r\n// Extends EventEmitter\r\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\r\n\r\n/**\r\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\r\n *\r\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\r\n * @typedef rpc.ServiceMethodCallback\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {TRes} [response] Response message\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\r\n * @typedef rpc.ServiceMethod\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n * @type {function}\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\r\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\r\n */\r\n\r\n/**\r\n * Constructs a new RPC service instance.\r\n * @classdesc An RPC service as returned by {@link Service#create}.\r\n * @exports rpc.Service\r\n * @extends util.EventEmitter\r\n * @constructor\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n */\r\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\r\n\r\n if (typeof rpcImpl !== \"function\")\r\n throw TypeError(\"rpcImpl must be a function\");\r\n\r\n util.EventEmitter.call(this);\r\n\r\n /**\r\n * RPC implementation. Becomes `null` once the service is ended.\r\n * @type {RPCImpl|null}\r\n */\r\n this.rpcImpl = rpcImpl;\r\n\r\n /**\r\n * Whether requests are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.requestDelimited = Boolean(requestDelimited);\r\n\r\n /**\r\n * Whether responses are length-delimited.\r\n * @type {boolean}\r\n */\r\n this.responseDelimited = Boolean(responseDelimited);\r\n}\r\n\r\n/**\r\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\r\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\r\n * @param {Constructor} requestCtor Request constructor\r\n * @param {Constructor} responseCtor Response constructor\r\n * @param {TReq|Properties} request Request message or plain object\r\n * @param {rpc.ServiceMethodCallback} callback Service callback\r\n * @returns {undefined}\r\n * @template TReq extends Message\r\n * @template TRes extends Message\r\n */\r\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\r\n\r\n if (!request)\r\n throw TypeError(\"request must be specified\");\r\n\r\n var self = this;\r\n if (!callback)\r\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\r\n\r\n if (!self.rpcImpl) {\r\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\r\n return undefined;\r\n }\r\n\r\n try {\r\n return self.rpcImpl(\r\n method,\r\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\r\n function rpcCallback(err, response) {\r\n\r\n if (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n\r\n if (response === null) {\r\n self.end(/* endedByRPC */ true);\r\n return undefined;\r\n }\r\n\r\n if (!(response instanceof responseCtor)) {\r\n try {\r\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n return callback(err);\r\n }\r\n }\r\n\r\n self.emit(\"data\", response, method);\r\n return callback(null, response);\r\n }\r\n );\r\n } catch (err) {\r\n self.emit(\"error\", err, method);\r\n setTimeout(function() { callback(err); }, 0);\r\n return undefined;\r\n }\r\n};\r\n\r\n/**\r\n * Ends this service and emits the `end` event.\r\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\r\n * @returns {rpc.Service} `this`\r\n */\r\nService.prototype.end = function end(endedByRPC) {\r\n if (this.rpcImpl) {\r\n if (!endedByRPC) // signal end to rpcImpl\r\n this.rpcImpl(null, null, null);\r\n this.rpcImpl = null;\r\n this.emit(\"end\").off();\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\nmodule.exports = Service;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = \"Service\";\r\n\r\nvar Method = require(22),\r\n util = require(37),\r\n rpc = require(31);\r\n\r\n/**\r\n * Constructs a new service instance.\r\n * @classdesc Reflected service.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Service name\r\n * @param {Object.} [options] Service options\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nfunction Service(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Service methods.\r\n * @type {Object.}\r\n */\r\n this.methods = {}; // toJSON, marker\r\n\r\n /**\r\n * Cached methods as an array.\r\n * @type {Method[]|null}\r\n * @private\r\n */\r\n this._methodsArray = null;\r\n}\r\n\r\n/**\r\n * Service descriptor.\r\n * @interface IService\r\n * @extends INamespace\r\n * @property {Object.} methods Method descriptors\r\n */\r\n\r\n/**\r\n * Constructs a service from a service descriptor.\r\n * @param {string} name Service name\r\n * @param {IService} json Service descriptor\r\n * @returns {Service} Created service\r\n * @throws {TypeError} If arguments are invalid\r\n */\r\nService.fromJSON = function fromJSON(name, json) {\r\n var service = new Service(name, json.options);\r\n /* istanbul ignore else */\r\n if (json.methods)\r\n for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i)\r\n service.add(Method.fromJSON(names[i], json.methods[names[i]]));\r\n if (json.nested)\r\n service.addJSON(json.nested);\r\n service.comment = json.comment;\r\n return service;\r\n};\r\n\r\n/**\r\n * Converts this service to a service descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IService} Service descriptor\r\n */\r\nService.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"methods\" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {},\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * Methods of this service as an array for iteration.\r\n * @name Service#methodsArray\r\n * @type {Method[]}\r\n * @readonly\r\n */\r\nObject.defineProperty(Service.prototype, \"methodsArray\", {\r\n get: function() {\r\n return this._methodsArray || (this._methodsArray = util.toArray(this.methods));\r\n }\r\n});\r\n\r\nfunction clearCache(service) {\r\n service._methodsArray = null;\r\n return service;\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.get = function get(name) {\r\n return this.methods[name]\r\n || Namespace.prototype.get.call(this, name);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.resolveAll = function resolveAll() {\r\n var methods = this.methodsArray;\r\n for (var i = 0; i < methods.length; ++i)\r\n methods[i].resolve();\r\n return Namespace.prototype.resolve.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.add = function add(object) {\r\n\r\n /* istanbul ignore if */\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Method) {\r\n this.methods[object.name] = object;\r\n object.parent = this;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nService.prototype.remove = function remove(object) {\r\n if (object instanceof Method) {\r\n\r\n /* istanbul ignore if */\r\n if (this.methods[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.methods[object.name];\r\n object.parent = null;\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Creates a runtime service using the specified rpc implementation.\r\n * @param {RPCImpl} rpcImpl RPC implementation\r\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\r\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\r\n * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed.\r\n */\r\nService.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) {\r\n var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited);\r\n for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) {\r\n var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\\w_]/g, \"\");\r\n rpcService[methodName] = util.codegen([\"r\",\"c\"], util.isReserved(methodName) ? methodName + \"_\" : methodName)(\"return this.rpcCall(m,q,s,r,c)\")({\r\n m: method,\r\n q: method.resolvedRequestType.ctor,\r\n s: method.resolvedResponseType.ctor\r\n });\r\n }\r\n return rpcService;\r\n};\r\n","\"use strict\";\r\nmodule.exports = tokenize;\r\n\r\nvar delimRe = /[\\s{}=;:[\\],'\"()<>]/g,\r\n stringDoubleRe = /(?:\"([^\"\\\\]*(?:\\\\.[^\"\\\\]*)*)\")/g,\r\n stringSingleRe = /(?:'([^'\\\\]*(?:\\\\.[^'\\\\]*)*)')/g;\r\n\r\nvar setCommentRe = /^ *[*/]+ */,\r\n setCommentAltRe = /^\\s*\\*?\\/*/,\r\n setCommentSplitRe = /\\n/g,\r\n whitespaceRe = /\\s/,\r\n unescapeRe = /\\\\(.?)/g;\r\n\r\nvar unescapeMap = {\r\n \"0\": \"\\0\",\r\n \"r\": \"\\r\",\r\n \"n\": \"\\n\",\r\n \"t\": \"\\t\"\r\n};\r\n\r\n/**\r\n * Unescapes a string.\r\n * @param {string} str String to unescape\r\n * @returns {string} Unescaped string\r\n * @property {Object.} map Special characters map\r\n * @memberof tokenize\r\n */\r\nfunction unescape(str) {\r\n return str.replace(unescapeRe, function($0, $1) {\r\n switch ($1) {\r\n case \"\\\\\":\r\n case \"\":\r\n return $1;\r\n default:\r\n return unescapeMap[$1] || \"\";\r\n }\r\n });\r\n}\r\n\r\ntokenize.unescape = unescape;\r\n\r\n/**\r\n * Gets the next token and advances.\r\n * @typedef TokenizerHandleNext\r\n * @type {function}\r\n * @returns {string|null} Next token or `null` on eof\r\n */\r\n\r\n/**\r\n * Peeks for the next token.\r\n * @typedef TokenizerHandlePeek\r\n * @type {function}\r\n * @returns {string|null} Next token or `null` on eof\r\n */\r\n\r\n/**\r\n * Pushes a token back to the stack.\r\n * @typedef TokenizerHandlePush\r\n * @type {function}\r\n * @param {string} token Token\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Skips the next token.\r\n * @typedef TokenizerHandleSkip\r\n * @type {function}\r\n * @param {string} expected Expected token\r\n * @param {boolean} [optional=false] If optional\r\n * @returns {boolean} Whether the token matched\r\n * @throws {Error} If the token didn't match and is not optional\r\n */\r\n\r\n/**\r\n * Gets the comment on the previous line or, alternatively, the line comment on the specified line.\r\n * @typedef TokenizerHandleCmnt\r\n * @type {function}\r\n * @param {number} [line] Line number\r\n * @returns {string|null} Comment text or `null` if none\r\n */\r\n\r\n/**\r\n * Handle object returned from {@link tokenize}.\r\n * @interface ITokenizerHandle\r\n * @property {TokenizerHandleNext} next Gets the next token and advances (`null` on eof)\r\n * @property {TokenizerHandlePeek} peek Peeks for the next token (`null` on eof)\r\n * @property {TokenizerHandlePush} push Pushes a token back to the stack\r\n * @property {TokenizerHandleSkip} skip Skips a token, returns its presence and advances or, if non-optional and not present, throws\r\n * @property {TokenizerHandleCmnt} cmnt Gets the comment on the previous line or the line comment on the specified line, if any\r\n * @property {number} line Current line number\r\n */\r\n\r\n/**\r\n * Tokenizes the given .proto source and returns an object with useful utility functions.\r\n * @param {string} source Source contents\r\n * @param {boolean} alternateCommentMode Whether we should activate alternate comment parsing mode.\r\n * @returns {ITokenizerHandle} Tokenizer handle\r\n */\r\nfunction tokenize(source, alternateCommentMode) {\r\n /* eslint-disable callback-return */\r\n source = source.toString();\r\n\r\n var offset = 0,\r\n length = source.length,\r\n line = 1,\r\n commentType = null,\r\n commentText = null,\r\n commentLine = 0,\r\n commentLineEmpty = false;\r\n\r\n var stack = [];\r\n\r\n var stringDelim = null;\r\n\r\n /* istanbul ignore next */\r\n /**\r\n * Creates an error for illegal syntax.\r\n * @param {string} subject Subject\r\n * @returns {Error} Error created\r\n * @inner\r\n */\r\n function illegal(subject) {\r\n return Error(\"illegal \" + subject + \" (line \" + line + \")\");\r\n }\r\n\r\n /**\r\n * Reads a string till its end.\r\n * @returns {string} String read\r\n * @inner\r\n */\r\n function readString() {\r\n var re = stringDelim === \"'\" ? stringSingleRe : stringDoubleRe;\r\n re.lastIndex = offset - 1;\r\n var match = re.exec(source);\r\n if (!match)\r\n throw illegal(\"string\");\r\n offset = re.lastIndex;\r\n push(stringDelim);\r\n stringDelim = null;\r\n return unescape(match[1]);\r\n }\r\n\r\n /**\r\n * Gets the character at `pos` within the source.\r\n * @param {number} pos Position\r\n * @returns {string} Character\r\n * @inner\r\n */\r\n function charAt(pos) {\r\n return source.charAt(pos);\r\n }\r\n\r\n /**\r\n * Sets the current comment text.\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {undefined}\r\n * @inner\r\n */\r\n function setComment(start, end) {\r\n commentType = source.charAt(start++);\r\n commentLine = line;\r\n commentLineEmpty = false;\r\n var lookback;\r\n if (alternateCommentMode) {\r\n lookback = 2; // alternate comment parsing: \"//\" or \"/*\"\r\n } else {\r\n lookback = 3; // \"///\" or \"/**\"\r\n }\r\n var commentOffset = start - lookback,\r\n c;\r\n do {\r\n if (--commentOffset < 0 ||\r\n (c = source.charAt(commentOffset)) === \"\\n\") {\r\n commentLineEmpty = true;\r\n break;\r\n }\r\n } while (c === \" \" || c === \"\\t\");\r\n var lines = source\r\n .substring(start, end)\r\n .split(setCommentSplitRe);\r\n for (var i = 0; i < lines.length; ++i)\r\n lines[i] = lines[i]\r\n .replace(alternateCommentMode ? setCommentAltRe : setCommentRe, \"\")\r\n .trim();\r\n commentText = lines\r\n .join(\"\\n\")\r\n .trim();\r\n }\r\n\r\n function isDoubleSlashCommentLine(startOffset) {\r\n var endOffset = findEndOfLine(startOffset);\r\n\r\n // see if remaining line matches comment pattern\r\n var lineText = source.substring(startOffset, endOffset);\r\n // look for 1 or 2 slashes since startOffset would already point past\r\n // the first slash that started the comment.\r\n var isComment = /^\\s*\\/{1,2}/.test(lineText);\r\n return isComment;\r\n }\r\n\r\n function findEndOfLine(cursor) {\r\n // find end of cursor's line\r\n var endOffset = cursor;\r\n while (endOffset < length && charAt(endOffset) !== \"\\n\") {\r\n endOffset++;\r\n }\r\n return endOffset;\r\n }\r\n\r\n /**\r\n * Obtains the next token.\r\n * @returns {string|null} Next token or `null` on eof\r\n * @inner\r\n */\r\n function next() {\r\n if (stack.length > 0)\r\n return stack.shift();\r\n if (stringDelim)\r\n return readString();\r\n var repeat,\r\n prev,\r\n curr,\r\n start,\r\n isDoc;\r\n do {\r\n if (offset === length)\r\n return null;\r\n repeat = false;\r\n while (whitespaceRe.test(curr = charAt(offset))) {\r\n if (curr === \"\\n\")\r\n ++line;\r\n if (++offset === length)\r\n return null;\r\n }\r\n\r\n if (charAt(offset) === \"/\") {\r\n if (++offset === length) {\r\n throw illegal(\"comment\");\r\n }\r\n if (charAt(offset) === \"/\") { // Line\r\n if (!alternateCommentMode) {\r\n // check for triple-slash comment\r\n isDoc = charAt(start = offset + 1) === \"/\";\r\n\r\n while (charAt(++offset) !== \"\\n\") {\r\n if (offset === length) {\r\n return null;\r\n }\r\n }\r\n ++offset;\r\n if (isDoc) {\r\n setComment(start, offset - 1);\r\n }\r\n ++line;\r\n repeat = true;\r\n } else {\r\n // check for double-slash comments, consolidating consecutive lines\r\n start = offset;\r\n isDoc = false;\r\n if (isDoubleSlashCommentLine(offset)) {\r\n isDoc = true;\r\n do {\r\n offset = findEndOfLine(offset);\r\n if (offset === length) {\r\n break;\r\n }\r\n offset++;\r\n } while (isDoubleSlashCommentLine(offset));\r\n } else {\r\n offset = Math.min(length, findEndOfLine(offset) + 1);\r\n }\r\n if (isDoc) {\r\n setComment(start, offset);\r\n }\r\n line++;\r\n repeat = true;\r\n }\r\n } else if ((curr = charAt(offset)) === \"*\") { /* Block */\r\n // check for /** (regular comment mode) or /* (alternate comment mode)\r\n start = offset + 1;\r\n isDoc = alternateCommentMode || charAt(start) === \"*\";\r\n do {\r\n if (curr === \"\\n\") {\r\n ++line;\r\n }\r\n if (++offset === length) {\r\n throw illegal(\"comment\");\r\n }\r\n prev = curr;\r\n curr = charAt(offset);\r\n } while (prev !== \"*\" || curr !== \"/\");\r\n ++offset;\r\n if (isDoc) {\r\n setComment(start, offset - 2);\r\n }\r\n repeat = true;\r\n } else {\r\n return \"/\";\r\n }\r\n }\r\n } while (repeat);\r\n\r\n // offset !== length if we got here\r\n\r\n var end = offset;\r\n delimRe.lastIndex = 0;\r\n var delim = delimRe.test(charAt(end++));\r\n if (!delim)\r\n while (end < length && !delimRe.test(charAt(end)))\r\n ++end;\r\n var token = source.substring(offset, offset = end);\r\n if (token === \"\\\"\" || token === \"'\")\r\n stringDelim = token;\r\n return token;\r\n }\r\n\r\n /**\r\n * Pushes a token back to the stack.\r\n * @param {string} token Token\r\n * @returns {undefined}\r\n * @inner\r\n */\r\n function push(token) {\r\n stack.push(token);\r\n }\r\n\r\n /**\r\n * Peeks for the next token.\r\n * @returns {string|null} Token or `null` on eof\r\n * @inner\r\n */\r\n function peek() {\r\n if (!stack.length) {\r\n var token = next();\r\n if (token === null)\r\n return null;\r\n push(token);\r\n }\r\n return stack[0];\r\n }\r\n\r\n /**\r\n * Skips a token.\r\n * @param {string} expected Expected token\r\n * @param {boolean} [optional=false] Whether the token is optional\r\n * @returns {boolean} `true` when skipped, `false` if not\r\n * @throws {Error} When a required token is not present\r\n * @inner\r\n */\r\n function skip(expected, optional) {\r\n var actual = peek(),\r\n equals = actual === expected;\r\n if (equals) {\r\n next();\r\n return true;\r\n }\r\n if (!optional)\r\n throw illegal(\"token '\" + actual + \"', '\" + expected + \"' expected\");\r\n return false;\r\n }\r\n\r\n /**\r\n * Gets a comment.\r\n * @param {number} [trailingLine] Line number if looking for a trailing comment\r\n * @returns {string|null} Comment text\r\n * @inner\r\n */\r\n function cmnt(trailingLine) {\r\n var ret = null;\r\n if (trailingLine === undefined) {\r\n if (commentLine === line - 1 && (alternateCommentMode || commentType === \"*\" || commentLineEmpty)) {\r\n ret = commentText;\r\n }\r\n } else {\r\n /* istanbul ignore else */\r\n if (commentLine < trailingLine) {\r\n peek();\r\n }\r\n if (commentLine === trailingLine && !commentLineEmpty && (alternateCommentMode || commentType === \"/\")) {\r\n ret = commentText;\r\n }\r\n }\r\n return ret;\r\n }\r\n\r\n return Object.defineProperty({\r\n next: next,\r\n peek: peek,\r\n push: push,\r\n skip: skip,\r\n cmnt: cmnt\r\n }, \"line\", {\r\n get: function() { return line; }\r\n });\r\n /* eslint-enable callback-return */\r\n}\r\n","\"use strict\";\r\nmodule.exports = Type;\r\n\r\n// extends Namespace\r\nvar Namespace = require(23);\r\n((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = \"Type\";\r\n\r\nvar Enum = require(15),\r\n OneOf = require(25),\r\n Field = require(16),\r\n MapField = require(20),\r\n Service = require(33),\r\n Message = require(21),\r\n Reader = require(27),\r\n Writer = require(42),\r\n util = require(37),\r\n encoder = require(14),\r\n decoder = require(13),\r\n verifier = require(40),\r\n converter = require(12),\r\n wrappers = require(41);\r\n\r\n/**\r\n * Constructs a new reflected message type instance.\r\n * @classdesc Reflected message type.\r\n * @extends NamespaceBase\r\n * @constructor\r\n * @param {string} name Message name\r\n * @param {Object.} [options] Declared options\r\n */\r\nfunction Type(name, options) {\r\n Namespace.call(this, name, options);\r\n\r\n /**\r\n * Message fields.\r\n * @type {Object.}\r\n */\r\n this.fields = {}; // toJSON, marker\r\n\r\n /**\r\n * Oneofs declared within this namespace, if any.\r\n * @type {Object.}\r\n */\r\n this.oneofs = undefined; // toJSON\r\n\r\n /**\r\n * Extension ranges, if any.\r\n * @type {number[][]}\r\n */\r\n this.extensions = undefined; // toJSON\r\n\r\n /**\r\n * Reserved ranges, if any.\r\n * @type {Array.}\r\n */\r\n this.reserved = undefined; // toJSON\r\n\r\n /*?\r\n * Whether this type is a legacy group.\r\n * @type {boolean|undefined}\r\n */\r\n this.group = undefined; // toJSON\r\n\r\n /**\r\n * Cached fields by id.\r\n * @type {Object.|null}\r\n * @private\r\n */\r\n this._fieldsById = null;\r\n\r\n /**\r\n * Cached fields as an array.\r\n * @type {Field[]|null}\r\n * @private\r\n */\r\n this._fieldsArray = null;\r\n\r\n /**\r\n * Cached oneofs as an array.\r\n * @type {OneOf[]|null}\r\n * @private\r\n */\r\n this._oneofsArray = null;\r\n\r\n /**\r\n * Cached constructor.\r\n * @type {Constructor<{}>}\r\n * @private\r\n */\r\n this._ctor = null;\r\n}\r\n\r\nObject.defineProperties(Type.prototype, {\r\n\r\n /**\r\n * Message fields by id.\r\n * @name Type#fieldsById\r\n * @type {Object.}\r\n * @readonly\r\n */\r\n fieldsById: {\r\n get: function() {\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById)\r\n return this._fieldsById;\r\n\r\n this._fieldsById = {};\r\n for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) {\r\n var field = this.fields[names[i]],\r\n id = field.id;\r\n\r\n /* istanbul ignore if */\r\n if (this._fieldsById[id])\r\n throw Error(\"duplicate id \" + id + \" in \" + this);\r\n\r\n this._fieldsById[id] = field;\r\n }\r\n return this._fieldsById;\r\n }\r\n },\r\n\r\n /**\r\n * Fields of this message as an array for iteration.\r\n * @name Type#fieldsArray\r\n * @type {Field[]}\r\n * @readonly\r\n */\r\n fieldsArray: {\r\n get: function() {\r\n return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields));\r\n }\r\n },\r\n\r\n /**\r\n * Oneofs of this message as an array for iteration.\r\n * @name Type#oneofsArray\r\n * @type {OneOf[]}\r\n * @readonly\r\n */\r\n oneofsArray: {\r\n get: function() {\r\n return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs));\r\n }\r\n },\r\n\r\n /**\r\n * The registered constructor, if any registered, otherwise a generic constructor.\r\n * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor.\r\n * @name Type#ctor\r\n * @type {Constructor<{}>}\r\n */\r\n ctor: {\r\n get: function() {\r\n return this._ctor || (this.ctor = Type.generateConstructor(this)());\r\n },\r\n set: function(ctor) {\r\n\r\n // Ensure proper prototype\r\n var prototype = ctor.prototype;\r\n if (!(prototype instanceof Message)) {\r\n (ctor.prototype = new Message()).constructor = ctor;\r\n util.merge(ctor.prototype, prototype);\r\n }\r\n\r\n // Classes and messages reference their reflected type\r\n ctor.$type = ctor.prototype.$type = this;\r\n\r\n // Mix in static methods\r\n util.merge(ctor, Message, true);\r\n\r\n this._ctor = ctor;\r\n\r\n // Messages have non-enumerable default values on their prototype\r\n var i = 0;\r\n for (; i < /* initializes */ this.fieldsArray.length; ++i)\r\n this._fieldsArray[i].resolve(); // ensures a proper value\r\n\r\n // Messages have non-enumerable getters and setters for each virtual oneof field\r\n var ctorProperties = {};\r\n for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i)\r\n ctorProperties[this._oneofsArray[i].resolve().name] = {\r\n get: util.oneOfGetter(this._oneofsArray[i].oneof),\r\n set: util.oneOfSetter(this._oneofsArray[i].oneof)\r\n };\r\n if (i)\r\n Object.defineProperties(ctor.prototype, ctorProperties);\r\n }\r\n }\r\n});\r\n\r\n/**\r\n * Generates a constructor function for the specified type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nType.generateConstructor = function generateConstructor(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n var gen = util.codegen([\"p\"], mtype.name);\r\n // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype\r\n for (var i = 0, field; i < mtype.fieldsArray.length; ++i)\r\n if ((field = mtype._fieldsArray[i]).map) gen\r\n (\"this%s={}\", util.safeProp(field.name));\r\n else if (field.repeated) gen\r\n (\"this%s=[]\", util.safeProp(field.name));\r\n return gen\r\n (\"if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors\r\n * @property {Object.} fields Field descriptors\r\n * @property {number[][]} [extensions] Extension ranges\r\n * @property {number[][]} [reserved] Reserved ranges\r\n * @property {boolean} [group=false] Whether a legacy group or not\r\n */\r\n\r\n/**\r\n * Creates a message type from a message type descriptor.\r\n * @param {string} name Message name\r\n * @param {IType} json Message type descriptor\r\n * @returns {Type} Created message type\r\n */\r\nType.fromJSON = function fromJSON(name, json) {\r\n var type = new Type(name, json.options);\r\n type.extensions = json.extensions;\r\n type.reserved = json.reserved;\r\n var names = Object.keys(json.fields),\r\n i = 0;\r\n for (; i < names.length; ++i)\r\n type.add(\r\n ( typeof json.fields[names[i]].keyType !== \"undefined\"\r\n ? MapField.fromJSON\r\n : Field.fromJSON )(names[i], json.fields[names[i]])\r\n );\r\n if (json.oneofs)\r\n for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i)\r\n type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]]));\r\n if (json.nested)\r\n for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) {\r\n var nested = json.nested[names[i]];\r\n type.add( // most to least likely\r\n ( nested.id !== undefined\r\n ? Field.fromJSON\r\n : nested.fields !== undefined\r\n ? Type.fromJSON\r\n : nested.values !== undefined\r\n ? Enum.fromJSON\r\n : nested.methods !== undefined\r\n ? Service.fromJSON\r\n : Namespace.fromJSON )(names[i], nested)\r\n );\r\n }\r\n if (json.extensions && json.extensions.length)\r\n type.extensions = json.extensions;\r\n if (json.reserved && json.reserved.length)\r\n type.reserved = json.reserved;\r\n if (json.group)\r\n type.group = true;\r\n if (json.comment)\r\n type.comment = json.comment;\r\n return type;\r\n};\r\n\r\n/**\r\n * Converts this message type to a message type descriptor.\r\n * @param {IToJSONOptions} [toJSONOptions] JSON conversion options\r\n * @returns {IType} Message type descriptor\r\n */\r\nType.prototype.toJSON = function toJSON(toJSONOptions) {\r\n var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions);\r\n var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;\r\n return util.toObject([\r\n \"options\" , inherited && inherited.options || undefined,\r\n \"oneofs\" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions),\r\n \"fields\" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {},\r\n \"extensions\" , this.extensions && this.extensions.length ? this.extensions : undefined,\r\n \"reserved\" , this.reserved && this.reserved.length ? this.reserved : undefined,\r\n \"group\" , this.group || undefined,\r\n \"nested\" , inherited && inherited.nested || undefined,\r\n \"comment\" , keepComments ? this.comment : undefined\r\n ]);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.resolveAll = function resolveAll() {\r\n var fields = this.fieldsArray, i = 0;\r\n while (i < fields.length)\r\n fields[i++].resolve();\r\n var oneofs = this.oneofsArray; i = 0;\r\n while (i < oneofs.length)\r\n oneofs[i++].resolve();\r\n return Namespace.prototype.resolveAll.call(this);\r\n};\r\n\r\n/**\r\n * @override\r\n */\r\nType.prototype.get = function get(name) {\r\n return this.fields[name]\r\n || this.oneofs && this.oneofs[name]\r\n || this.nested && this.nested[name]\r\n || null;\r\n};\r\n\r\n/**\r\n * Adds a nested object to this type.\r\n * @param {ReflectionObject} object Nested object to add\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id\r\n */\r\nType.prototype.add = function add(object) {\r\n\r\n if (this.get(object.name))\r\n throw Error(\"duplicate name '\" + object.name + \"' in \" + this);\r\n\r\n if (object instanceof Field && object.extend === undefined) {\r\n // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects.\r\n // The root object takes care of adding distinct sister-fields to the respective extended\r\n // type instead.\r\n\r\n // avoids calling the getter if not absolutely necessary because it's called quite frequently\r\n if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id])\r\n throw Error(\"duplicate id \" + object.id + \" in \" + this);\r\n if (this.isReservedId(object.id))\r\n throw Error(\"id \" + object.id + \" is reserved in \" + this);\r\n if (this.isReservedName(object.name))\r\n throw Error(\"name '\" + object.name + \"' is reserved in \" + this);\r\n\r\n if (object.parent)\r\n object.parent.remove(object);\r\n this.fields[object.name] = object;\r\n object.message = this;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n if (!this.oneofs)\r\n this.oneofs = {};\r\n this.oneofs[object.name] = object;\r\n object.onAdd(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.add.call(this, object);\r\n};\r\n\r\n/**\r\n * Removes a nested object from this type.\r\n * @param {ReflectionObject} object Nested object to remove\r\n * @returns {Type} `this`\r\n * @throws {TypeError} If arguments are invalid\r\n * @throws {Error} If `object` is not a member of this type\r\n */\r\nType.prototype.remove = function remove(object) {\r\n if (object instanceof Field && object.extend === undefined) {\r\n // See Type#add for the reason why extension fields are excluded here.\r\n\r\n /* istanbul ignore if */\r\n if (!this.fields || this.fields[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.fields[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n if (object instanceof OneOf) {\r\n\r\n /* istanbul ignore if */\r\n if (!this.oneofs || this.oneofs[object.name] !== object)\r\n throw Error(object + \" is not a member of \" + this);\r\n\r\n delete this.oneofs[object.name];\r\n object.parent = null;\r\n object.onRemove(this);\r\n return clearCache(this);\r\n }\r\n return Namespace.prototype.remove.call(this, object);\r\n};\r\n\r\n/**\r\n * Tests if the specified id is reserved.\r\n * @param {number} id Id to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedId = function isReservedId(id) {\r\n return Namespace.isReservedId(this.reserved, id);\r\n};\r\n\r\n/**\r\n * Tests if the specified name is reserved.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nType.prototype.isReservedName = function isReservedName(name) {\r\n return Namespace.isReservedName(this.reserved, name);\r\n};\r\n\r\n/**\r\n * Creates a new message of this type using the specified properties.\r\n * @param {Object.} [properties] Properties to set\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.create = function create(properties) {\r\n return new this.ctor(properties);\r\n};\r\n\r\n/**\r\n * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}.\r\n * @returns {Type} `this`\r\n */\r\nType.prototype.setup = function setup() {\r\n // Sets up everything at once so that the prototype chain does not have to be re-evaluated\r\n // multiple times (V8, soft-deopt prototype-check).\r\n\r\n var fullName = this.fullName,\r\n types = [];\r\n for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i)\r\n types.push(this._fieldsArray[i].resolve().resolvedType);\r\n\r\n // Replace setup methods with type-specific generated functions\r\n this.encode = encoder(this)({\r\n Writer : Writer,\r\n types : types,\r\n util : util\r\n });\r\n this.decode = decoder(this)({\r\n Reader : Reader,\r\n types : types,\r\n util : util\r\n });\r\n this.verify = verifier(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.fromObject = converter.fromObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n this.toObject = converter.toObject(this)({\r\n types : types,\r\n util : util\r\n });\r\n\r\n // Inject custom wrappers for common types\r\n var wrapper = wrappers[fullName];\r\n if (wrapper) {\r\n var originalThis = Object.create(this);\r\n // if (wrapper.fromObject) {\r\n originalThis.fromObject = this.fromObject;\r\n this.fromObject = wrapper.fromObject.bind(originalThis);\r\n // }\r\n // if (wrapper.toObject) {\r\n originalThis.toObject = this.toObject;\r\n this.toObject = wrapper.toObject.bind(originalThis);\r\n // }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encode = function encode_setup(message, writer) {\r\n return this.setup().encode(message, writer); // overrides this method\r\n};\r\n\r\n/**\r\n * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages.\r\n * @param {Message<{}>|Object.} message Message instance or plain object\r\n * @param {Writer} [writer] Writer to encode to\r\n * @returns {Writer} writer\r\n */\r\nType.prototype.encodeDelimited = function encodeDelimited(message, writer) {\r\n return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim();\r\n};\r\n\r\n/**\r\n * Decodes a message of this type.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @param {number} [length] Length of the message, if known beforehand\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError<{}>} If required fields are missing\r\n */\r\nType.prototype.decode = function decode_setup(reader, length) {\r\n return this.setup().decode(reader, length); // overrides this method\r\n};\r\n\r\n/**\r\n * Decodes a message of this type preceeded by its byte length as a varint.\r\n * @param {Reader|Uint8Array} reader Reader or buffer to decode from\r\n * @returns {Message<{}>} Decoded message\r\n * @throws {Error} If the payload is not a reader or valid buffer\r\n * @throws {util.ProtocolError} If required fields are missing\r\n */\r\nType.prototype.decodeDelimited = function decodeDelimited(reader) {\r\n if (!(reader instanceof Reader))\r\n reader = Reader.create(reader);\r\n return this.decode(reader, reader.uint32());\r\n};\r\n\r\n/**\r\n * Verifies that field values are valid and that required fields are present.\r\n * @param {Object.} message Plain object to verify\r\n * @returns {null|string} `null` if valid, otherwise the reason why it is not\r\n */\r\nType.prototype.verify = function verify_setup(message) {\r\n return this.setup().verify(message); // overrides this method\r\n};\r\n\r\n/**\r\n * Creates a new message of this type from a plain object. Also converts values to their respective internal types.\r\n * @param {Object.} object Plain object to convert\r\n * @returns {Message<{}>} Message instance\r\n */\r\nType.prototype.fromObject = function fromObject(object) {\r\n return this.setup().fromObject(object);\r\n};\r\n\r\n/**\r\n * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}.\r\n * @interface IConversionOptions\r\n * @property {Function} [longs] Long conversion type.\r\n * Valid values are `String` and `Number` (the global types).\r\n * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library.\r\n * @property {Function} [enums] Enum value conversion type.\r\n * Only valid value is `String` (the global type).\r\n * Defaults to copy the present value, which is the numeric id.\r\n * @property {Function} [bytes] Bytes value conversion type.\r\n * Valid values are `Array` and (a base64 encoded) `String` (the global types).\r\n * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser.\r\n * @property {boolean} [defaults=false] Also sets default values on the resulting object\r\n * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false`\r\n * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false`\r\n * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any\r\n * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings\r\n */\r\n\r\n/**\r\n * Creates a plain object from a message of this type. Also converts values to other types if specified.\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n */\r\nType.prototype.toObject = function toObject(message, options) {\r\n return this.setup().toObject(message, options);\r\n};\r\n\r\n/**\r\n * Decorator function as returned by {@link Type.d} (TypeScript).\r\n * @typedef TypeDecorator\r\n * @type {function}\r\n * @param {Constructor} target Target constructor\r\n * @returns {undefined}\r\n * @template T extends Message\r\n */\r\n\r\n/**\r\n * Type decorator (TypeScript).\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {TypeDecorator} Decorator function\r\n * @template T extends Message\r\n */\r\nType.d = function decorateType(typeName) {\r\n return function typeDecorator(target) {\r\n util.decorateType(target, typeName);\r\n };\r\n};\r\n","\"use strict\";\r\n\r\n/**\r\n * Common type constants.\r\n * @namespace\r\n */\r\nvar types = exports;\r\n\r\nvar util = require(37);\r\n\r\nvar s = [\r\n \"double\", // 0\r\n \"float\", // 1\r\n \"int32\", // 2\r\n \"uint32\", // 3\r\n \"sint32\", // 4\r\n \"fixed32\", // 5\r\n \"sfixed32\", // 6\r\n \"int64\", // 7\r\n \"uint64\", // 8\r\n \"sint64\", // 9\r\n \"fixed64\", // 10\r\n \"sfixed64\", // 11\r\n \"bool\", // 12\r\n \"string\", // 13\r\n \"bytes\" // 14\r\n];\r\n\r\nfunction bake(values, offset) {\r\n var i = 0, o = {};\r\n offset |= 0;\r\n while (i < values.length) o[s[i + offset]] = values[i++];\r\n return o;\r\n}\r\n\r\n/**\r\n * Basic type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n * @property {number} bytes=2 Ldelim wire type\r\n */\r\ntypes.basic = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2,\r\n /* bytes */ 2\r\n]);\r\n\r\n/**\r\n * Basic type defaults.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=0 Double default\r\n * @property {number} float=0 Float default\r\n * @property {number} int32=0 Int32 default\r\n * @property {number} uint32=0 Uint32 default\r\n * @property {number} sint32=0 Sint32 default\r\n * @property {number} fixed32=0 Fixed32 default\r\n * @property {number} sfixed32=0 Sfixed32 default\r\n * @property {number} int64=0 Int64 default\r\n * @property {number} uint64=0 Uint64 default\r\n * @property {number} sint64=0 Sint32 default\r\n * @property {number} fixed64=0 Fixed64 default\r\n * @property {number} sfixed64=0 Sfixed64 default\r\n * @property {boolean} bool=false Bool default\r\n * @property {string} string=\"\" String default\r\n * @property {Array.} bytes=Array(0) Bytes default\r\n * @property {null} message=null Message default\r\n */\r\ntypes.defaults = bake([\r\n /* double */ 0,\r\n /* float */ 0,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 0,\r\n /* sfixed32 */ 0,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 0,\r\n /* sfixed64 */ 0,\r\n /* bool */ false,\r\n /* string */ \"\",\r\n /* bytes */ util.emptyArray,\r\n /* message */ null\r\n]);\r\n\r\n/**\r\n * Basic long type wire types.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n */\r\ntypes.long = bake([\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1\r\n], 7);\r\n\r\n/**\r\n * Allowed types for map keys with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n * @property {number} string=2 Ldelim wire type\r\n */\r\ntypes.mapKey = bake([\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0,\r\n /* string */ 2\r\n], 2);\r\n\r\n/**\r\n * Allowed types for packed repeated fields with their associated wire type.\r\n * @type {Object.}\r\n * @const\r\n * @property {number} double=1 Fixed64 wire type\r\n * @property {number} float=5 Fixed32 wire type\r\n * @property {number} int32=0 Varint wire type\r\n * @property {number} uint32=0 Varint wire type\r\n * @property {number} sint32=0 Varint wire type\r\n * @property {number} fixed32=5 Fixed32 wire type\r\n * @property {number} sfixed32=5 Fixed32 wire type\r\n * @property {number} int64=0 Varint wire type\r\n * @property {number} uint64=0 Varint wire type\r\n * @property {number} sint64=0 Varint wire type\r\n * @property {number} fixed64=1 Fixed64 wire type\r\n * @property {number} sfixed64=1 Fixed64 wire type\r\n * @property {number} bool=0 Varint wire type\r\n */\r\ntypes.packed = bake([\r\n /* double */ 1,\r\n /* float */ 5,\r\n /* int32 */ 0,\r\n /* uint32 */ 0,\r\n /* sint32 */ 0,\r\n /* fixed32 */ 5,\r\n /* sfixed32 */ 5,\r\n /* int64 */ 0,\r\n /* uint64 */ 0,\r\n /* sint64 */ 0,\r\n /* fixed64 */ 1,\r\n /* sfixed64 */ 1,\r\n /* bool */ 0\r\n]);\r\n","\"use strict\";\r\n\r\n/**\r\n * Various utility functions.\r\n * @namespace\r\n */\r\nvar util = module.exports = require(39);\r\n\r\nvar roots = require(30);\r\n\r\nvar Type, // cyclic\r\n Enum;\r\n\r\nutil.codegen = require(3);\r\nutil.fetch = require(5);\r\nutil.path = require(8);\r\n\r\n/**\r\n * Node's fs module if available.\r\n * @type {Object.}\r\n */\r\nutil.fs = util.inquire(\"fs\");\r\n\r\n/**\r\n * Converts an object's values to an array.\r\n * @param {Object.} object Object to convert\r\n * @returns {Array.<*>} Converted array\r\n */\r\nutil.toArray = function toArray(object) {\r\n if (object) {\r\n var keys = Object.keys(object),\r\n array = new Array(keys.length),\r\n index = 0;\r\n while (index < keys.length)\r\n array[index] = object[keys[index++]];\r\n return array;\r\n }\r\n return [];\r\n};\r\n\r\n/**\r\n * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values.\r\n * @param {Array.<*>} array Array to convert\r\n * @returns {Object.} Converted object\r\n */\r\nutil.toObject = function toObject(array) {\r\n var object = {},\r\n index = 0;\r\n while (index < array.length) {\r\n var key = array[index++],\r\n val = array[index++];\r\n if (val !== undefined)\r\n object[key] = val;\r\n }\r\n return object;\r\n};\r\n\r\nvar safePropBackslashRe = /\\\\/g,\r\n safePropQuoteRe = /\"/g;\r\n\r\n/**\r\n * Tests whether the specified name is a reserved word in JS.\r\n * @param {string} name Name to test\r\n * @returns {boolean} `true` if reserved, otherwise `false`\r\n */\r\nutil.isReserved = function isReserved(name) {\r\n return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name);\r\n};\r\n\r\n/**\r\n * Returns a safe property accessor for the specified property name.\r\n * @param {string} prop Property name\r\n * @returns {string} Safe accessor\r\n */\r\nutil.safeProp = function safeProp(prop) {\r\n if (!/^[$\\w_]+$/.test(prop) || util.isReserved(prop))\r\n return \"[\\\"\" + prop.replace(safePropBackslashRe, \"\\\\\\\\\").replace(safePropQuoteRe, \"\\\\\\\"\") + \"\\\"]\";\r\n return \".\" + prop;\r\n};\r\n\r\n/**\r\n * Converts the first character of a string to upper case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.ucFirst = function ucFirst(str) {\r\n return str.charAt(0).toUpperCase() + str.substring(1);\r\n};\r\n\r\nvar camelCaseRe = /_([a-z])/g;\r\n\r\n/**\r\n * Converts a string to camel case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.camelCase = function camelCase(str) {\r\n return str.substring(0, 1)\r\n + str.substring(1)\r\n .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); });\r\n};\r\n\r\n/**\r\n * Compares reflected fields by id.\r\n * @param {Field} a First field\r\n * @param {Field} b Second field\r\n * @returns {number} Comparison value\r\n */\r\nutil.compareFieldsById = function compareFieldsById(a, b) {\r\n return a.id - b.id;\r\n};\r\n\r\n/**\r\n * Decorator helper for types (TypeScript).\r\n * @param {Constructor} ctor Constructor function\r\n * @param {string} [typeName] Type name, defaults to the constructor's name\r\n * @returns {Type} Reflected type\r\n * @template T extends Message\r\n * @property {Root} root Decorators root\r\n */\r\nutil.decorateType = function decorateType(ctor, typeName) {\r\n\r\n /* istanbul ignore if */\r\n if (ctor.$type) {\r\n if (typeName && ctor.$type.name !== typeName) {\r\n util.decorateRoot.remove(ctor.$type);\r\n ctor.$type.name = typeName;\r\n util.decorateRoot.add(ctor.$type);\r\n }\r\n return ctor.$type;\r\n }\r\n\r\n /* istanbul ignore next */\r\n if (!Type)\r\n Type = require(35);\r\n\r\n var type = new Type(typeName || ctor.name);\r\n util.decorateRoot.add(type);\r\n type.ctor = ctor; // sets up .encode, .decode etc.\r\n Object.defineProperty(ctor, \"$type\", { value: type, enumerable: false });\r\n Object.defineProperty(ctor.prototype, \"$type\", { value: type, enumerable: false });\r\n return type;\r\n};\r\n\r\nvar decorateEnumIndex = 0;\r\n\r\n/**\r\n * Decorator helper for enums (TypeScript).\r\n * @param {Object} object Enum object\r\n * @returns {Enum} Reflected enum\r\n */\r\nutil.decorateEnum = function decorateEnum(object) {\r\n\r\n /* istanbul ignore if */\r\n if (object.$type)\r\n return object.$type;\r\n\r\n /* istanbul ignore next */\r\n if (!Enum)\r\n Enum = require(15);\r\n\r\n var enm = new Enum(\"Enum\" + decorateEnumIndex++, object);\r\n util.decorateRoot.add(enm);\r\n Object.defineProperty(object, \"$type\", { value: enm, enumerable: false });\r\n return enm;\r\n};\r\n\r\n/**\r\n * Decorator root (TypeScript).\r\n * @name util.decorateRoot\r\n * @type {Root}\r\n * @readonly\r\n */\r\nObject.defineProperty(util, \"decorateRoot\", {\r\n get: function() {\r\n return roots[\"decorated\"] || (roots[\"decorated\"] = new (require(29))());\r\n }\r\n});\r\n","\"use strict\";\r\nmodule.exports = LongBits;\r\n\r\nvar util = require(39);\r\n\r\n/**\r\n * Constructs new long bits.\r\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\r\n * @memberof util\r\n * @constructor\r\n * @param {number} lo Low 32 bits, unsigned\r\n * @param {number} hi High 32 bits, unsigned\r\n */\r\nfunction LongBits(lo, hi) {\r\n\r\n // note that the casts below are theoretically unnecessary as of today, but older statically\r\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\r\n\r\n /**\r\n * Low bits.\r\n * @type {number}\r\n */\r\n this.lo = lo >>> 0;\r\n\r\n /**\r\n * High bits.\r\n * @type {number}\r\n */\r\n this.hi = hi >>> 0;\r\n}\r\n\r\n/**\r\n * Zero bits.\r\n * @memberof util.LongBits\r\n * @type {util.LongBits}\r\n */\r\nvar zero = LongBits.zero = new LongBits(0, 0);\r\n\r\nzero.toNumber = function() { return 0; };\r\nzero.zzEncode = zero.zzDecode = function() { return this; };\r\nzero.length = function() { return 1; };\r\n\r\n/**\r\n * Zero hash.\r\n * @memberof util.LongBits\r\n * @type {string}\r\n */\r\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\r\n\r\n/**\r\n * Constructs new long bits from the specified number.\r\n * @param {number} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.fromNumber = function fromNumber(value) {\r\n if (value === 0)\r\n return zero;\r\n var sign = value < 0;\r\n if (sign)\r\n value = -value;\r\n var lo = value >>> 0,\r\n hi = (value - lo) / 4294967296 >>> 0;\r\n if (sign) {\r\n hi = ~hi >>> 0;\r\n lo = ~lo >>> 0;\r\n if (++lo > 4294967295) {\r\n lo = 0;\r\n if (++hi > 4294967295)\r\n hi = 0;\r\n }\r\n }\r\n return new LongBits(lo, hi);\r\n};\r\n\r\n/**\r\n * Constructs new long bits from a number, long or string.\r\n * @param {Long|number|string} value Value\r\n * @returns {util.LongBits} Instance\r\n */\r\nLongBits.from = function from(value) {\r\n if (typeof value === \"number\")\r\n return LongBits.fromNumber(value);\r\n if (util.isString(value)) {\r\n /* istanbul ignore else */\r\n if (util.Long)\r\n value = util.Long.fromString(value);\r\n else\r\n return LongBits.fromNumber(parseInt(value, 10));\r\n }\r\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a possibly unsafe JavaScript number.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {number} Possibly unsafe number\r\n */\r\nLongBits.prototype.toNumber = function toNumber(unsigned) {\r\n if (!unsigned && this.hi >>> 31) {\r\n var lo = ~this.lo + 1 >>> 0,\r\n hi = ~this.hi >>> 0;\r\n if (!lo)\r\n hi = hi + 1 >>> 0;\r\n return -(lo + hi * 4294967296);\r\n }\r\n return this.lo + this.hi * 4294967296;\r\n};\r\n\r\n/**\r\n * Converts this long bits to a long.\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long} Long\r\n */\r\nLongBits.prototype.toLong = function toLong(unsigned) {\r\n return util.Long\r\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\r\n /* istanbul ignore next */\r\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\r\n};\r\n\r\nvar charCodeAt = String.prototype.charCodeAt;\r\n\r\n/**\r\n * Constructs new long bits from the specified 8 characters long hash.\r\n * @param {string} hash Hash\r\n * @returns {util.LongBits} Bits\r\n */\r\nLongBits.fromHash = function fromHash(hash) {\r\n if (hash === zeroHash)\r\n return zero;\r\n return new LongBits(\r\n ( charCodeAt.call(hash, 0)\r\n | charCodeAt.call(hash, 1) << 8\r\n | charCodeAt.call(hash, 2) << 16\r\n | charCodeAt.call(hash, 3) << 24) >>> 0\r\n ,\r\n ( charCodeAt.call(hash, 4)\r\n | charCodeAt.call(hash, 5) << 8\r\n | charCodeAt.call(hash, 6) << 16\r\n | charCodeAt.call(hash, 7) << 24) >>> 0\r\n );\r\n};\r\n\r\n/**\r\n * Converts this long bits to a 8 characters long hash.\r\n * @returns {string} Hash\r\n */\r\nLongBits.prototype.toHash = function toHash() {\r\n return String.fromCharCode(\r\n this.lo & 255,\r\n this.lo >>> 8 & 255,\r\n this.lo >>> 16 & 255,\r\n this.lo >>> 24 ,\r\n this.hi & 255,\r\n this.hi >>> 8 & 255,\r\n this.hi >>> 16 & 255,\r\n this.hi >>> 24\r\n );\r\n};\r\n\r\n/**\r\n * Zig-zag encodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzEncode = function zzEncode() {\r\n var mask = this.hi >> 31;\r\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\r\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Zig-zag decodes this long bits.\r\n * @returns {util.LongBits} `this`\r\n */\r\nLongBits.prototype.zzDecode = function zzDecode() {\r\n var mask = -(this.lo & 1);\r\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\r\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Calculates the length of this longbits when encoded as a varint.\r\n * @returns {number} Length\r\n */\r\nLongBits.prototype.length = function length() {\r\n var part0 = this.lo,\r\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\r\n part2 = this.hi >>> 24;\r\n return part2 === 0\r\n ? part1 === 0\r\n ? part0 < 16384\r\n ? part0 < 128 ? 1 : 2\r\n : part0 < 2097152 ? 3 : 4\r\n : part1 < 16384\r\n ? part1 < 128 ? 5 : 6\r\n : part1 < 2097152 ? 7 : 8\r\n : part2 < 128 ? 9 : 10;\r\n};\r\n","\"use strict\";\r\nvar util = exports;\r\n\r\n// used to return a Promise where callback is omitted\r\nutil.asPromise = require(1);\r\n\r\n// converts to / from base64 encoded strings\r\nutil.base64 = require(2);\r\n\r\n// base class of rpc.Service\r\nutil.EventEmitter = require(4);\r\n\r\n// float handling accross browsers\r\nutil.float = require(6);\r\n\r\n// requires modules optionally and hides the call from bundlers\r\nutil.inquire = require(7);\r\n\r\n// converts to / from utf8 encoded strings\r\nutil.utf8 = require(10);\r\n\r\n// provides a node-like buffer pool in the browser\r\nutil.pool = require(9);\r\n\r\n// utility to work with the low and high bits of a 64 bit value\r\nutil.LongBits = require(38);\r\n\r\n// global object reference\r\nutil.global = typeof window !== \"undefined\" && window\r\n || typeof global !== \"undefined\" && global\r\n || typeof self !== \"undefined\" && self\r\n || this; // eslint-disable-line no-invalid-this\r\n\r\n/**\r\n * An immuable empty array.\r\n * @memberof util\r\n * @type {Array.<*>}\r\n * @const\r\n */\r\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\r\n\r\n/**\r\n * An immutable empty object.\r\n * @type {Object}\r\n * @const\r\n */\r\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\r\n\r\n/**\r\n * Whether running within node or not.\r\n * @memberof util\r\n * @type {boolean}\r\n * @const\r\n */\r\nutil.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node);\r\n\r\n/**\r\n * Tests if the specified value is an integer.\r\n * @function\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is an integer\r\n */\r\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\r\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a string.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a string\r\n */\r\nutil.isString = function isString(value) {\r\n return typeof value === \"string\" || value instanceof String;\r\n};\r\n\r\n/**\r\n * Tests if the specified value is a non-null object.\r\n * @param {*} value Value to test\r\n * @returns {boolean} `true` if the value is a non-null object\r\n */\r\nutil.isObject = function isObject(value) {\r\n return value && typeof value === \"object\";\r\n};\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * This is an alias of {@link util.isSet}.\r\n * @function\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isset =\r\n\r\n/**\r\n * Checks if a property on a message is considered to be present.\r\n * @param {Object} obj Plain object or message instance\r\n * @param {string} prop Property name\r\n * @returns {boolean} `true` if considered to be present, otherwise `false`\r\n */\r\nutil.isSet = function isSet(obj, prop) {\r\n var value = obj[prop];\r\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\r\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\r\n return false;\r\n};\r\n\r\n/**\r\n * Any compatible Buffer instance.\r\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\r\n * @interface Buffer\r\n * @extends Uint8Array\r\n */\r\n\r\n/**\r\n * Node's Buffer class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Buffer = (function() {\r\n try {\r\n var Buffer = util.inquire(\"buffer\").Buffer;\r\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\r\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\r\n } catch (e) {\r\n /* istanbul ignore next */\r\n return null;\r\n }\r\n})();\r\n\r\n// Internal alias of or polyfull for Buffer.from.\r\nutil._Buffer_from = null;\r\n\r\n// Internal alias of or polyfill for Buffer.allocUnsafe.\r\nutil._Buffer_allocUnsafe = null;\r\n\r\n/**\r\n * Creates a new buffer of whatever type supported by the environment.\r\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\r\n * @returns {Uint8Array|Buffer} Buffer\r\n */\r\nutil.newBuffer = function newBuffer(sizeOrArray) {\r\n /* istanbul ignore next */\r\n return typeof sizeOrArray === \"number\"\r\n ? util.Buffer\r\n ? util._Buffer_allocUnsafe(sizeOrArray)\r\n : new util.Array(sizeOrArray)\r\n : util.Buffer\r\n ? util._Buffer_from(sizeOrArray)\r\n : typeof Uint8Array === \"undefined\"\r\n ? sizeOrArray\r\n : new Uint8Array(sizeOrArray);\r\n};\r\n\r\n/**\r\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\r\n * @type {Constructor}\r\n */\r\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\r\n\r\n/**\r\n * Any compatible Long instance.\r\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\r\n * @interface Long\r\n * @property {number} low Low bits\r\n * @property {number} high High bits\r\n * @property {boolean} unsigned Whether unsigned or not\r\n */\r\n\r\n/**\r\n * Long.js's Long class if available.\r\n * @type {Constructor}\r\n */\r\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\r\n || /* istanbul ignore next */ util.global.Long\r\n || util.inquire(\"long\");\r\n\r\n/**\r\n * Regular expression used to verify 2 bit (`bool`) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key2Re = /^true|false|0|1$/;\r\n\r\n/**\r\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\r\n\r\n/**\r\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\r\n * @type {RegExp}\r\n * @const\r\n */\r\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\r\n\r\n/**\r\n * Converts a number or long to an 8 characters long hash string.\r\n * @param {Long|number} value Value to convert\r\n * @returns {string} Hash\r\n */\r\nutil.longToHash = function longToHash(value) {\r\n return value\r\n ? util.LongBits.from(value).toHash()\r\n : util.LongBits.zeroHash;\r\n};\r\n\r\n/**\r\n * Converts an 8 characters long hash string to a long or number.\r\n * @param {string} hash Hash\r\n * @param {boolean} [unsigned=false] Whether unsigned or not\r\n * @returns {Long|number} Original value\r\n */\r\nutil.longFromHash = function longFromHash(hash, unsigned) {\r\n var bits = util.LongBits.fromHash(hash);\r\n if (util.Long)\r\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\r\n return bits.toNumber(Boolean(unsigned));\r\n};\r\n\r\n/**\r\n * Merges the properties of the source object into the destination object.\r\n * @memberof util\r\n * @param {Object.} dst Destination object\r\n * @param {Object.} src Source object\r\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\r\n * @returns {Object.} Destination object\r\n */\r\nfunction merge(dst, src, ifNotSet) { // used by converters\r\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\r\n if (dst[keys[i]] === undefined || !ifNotSet)\r\n dst[keys[i]] = src[keys[i]];\r\n return dst;\r\n}\r\n\r\nutil.merge = merge;\r\n\r\n/**\r\n * Converts the first character of a string to lower case.\r\n * @param {string} str String to convert\r\n * @returns {string} Converted string\r\n */\r\nutil.lcFirst = function lcFirst(str) {\r\n return str.charAt(0).toLowerCase() + str.substring(1);\r\n};\r\n\r\n/**\r\n * Creates a custom error constructor.\r\n * @memberof util\r\n * @param {string} name Error name\r\n * @returns {Constructor} Custom error constructor\r\n */\r\nfunction newError(name) {\r\n\r\n function CustomError(message, properties) {\r\n\r\n if (!(this instanceof CustomError))\r\n return new CustomError(message, properties);\r\n\r\n // Error.call(this, message);\r\n // ^ just returns a new error instance because the ctor can be called as a function\r\n\r\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\r\n\r\n /* istanbul ignore next */\r\n if (Error.captureStackTrace) // node\r\n Error.captureStackTrace(this, CustomError);\r\n else\r\n Object.defineProperty(this, \"stack\", { value: (new Error()).stack || \"\" });\r\n\r\n if (properties)\r\n merge(this, properties);\r\n }\r\n\r\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\r\n\r\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\r\n\r\n CustomError.prototype.toString = function toString() {\r\n return this.name + \": \" + this.message;\r\n };\r\n\r\n return CustomError;\r\n}\r\n\r\nutil.newError = newError;\r\n\r\n/**\r\n * Constructs a new protocol error.\r\n * @classdesc Error subclass indicating a protocol specifc error.\r\n * @memberof util\r\n * @extends Error\r\n * @template T extends Message\r\n * @constructor\r\n * @param {string} message Error message\r\n * @param {Object.} [properties] Additional properties\r\n * @example\r\n * try {\r\n * MyMessage.decode(someBuffer); // throws if required fields are missing\r\n * } catch (e) {\r\n * if (e instanceof ProtocolError && e.instance)\r\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\r\n * }\r\n */\r\nutil.ProtocolError = newError(\"ProtocolError\");\r\n\r\n/**\r\n * So far decoded message instance.\r\n * @name util.ProtocolError#instance\r\n * @type {Message}\r\n */\r\n\r\n/**\r\n * A OneOf getter as returned by {@link util.oneOfGetter}.\r\n * @typedef OneOfGetter\r\n * @type {function}\r\n * @returns {string|undefined} Set field name, if any\r\n */\r\n\r\n/**\r\n * Builds a getter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfGetter} Unbound getter\r\n */\r\nutil.oneOfGetter = function getOneOf(fieldNames) {\r\n var fieldMap = {};\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n fieldMap[fieldNames[i]] = 1;\r\n\r\n /**\r\n * @returns {string|undefined} Set field name, if any\r\n * @this Object\r\n * @ignore\r\n */\r\n return function() { // eslint-disable-line consistent-return\r\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\r\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\r\n return keys[i];\r\n };\r\n};\r\n\r\n/**\r\n * A OneOf setter as returned by {@link util.oneOfSetter}.\r\n * @typedef OneOfSetter\r\n * @type {function}\r\n * @param {string|undefined} value Field name\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Builds a setter for a oneof's present field name.\r\n * @param {string[]} fieldNames Field names\r\n * @returns {OneOfSetter} Unbound setter\r\n */\r\nutil.oneOfSetter = function setOneOf(fieldNames) {\r\n\r\n /**\r\n * @param {string} name Field name\r\n * @returns {undefined}\r\n * @this Object\r\n * @ignore\r\n */\r\n return function(name) {\r\n for (var i = 0; i < fieldNames.length; ++i)\r\n if (fieldNames[i] !== name)\r\n delete this[fieldNames[i]];\r\n };\r\n};\r\n\r\n/**\r\n * Default conversion options used for {@link Message#toJSON} implementations.\r\n *\r\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\r\n *\r\n * - Longs become strings\r\n * - Enums become string keys\r\n * - Bytes become base64 encoded strings\r\n * - (Sub-)Messages become plain objects\r\n * - Maps become plain objects with all string keys\r\n * - Repeated fields become arrays\r\n * - NaN and Infinity for float and double fields become strings\r\n *\r\n * @type {IConversionOptions}\r\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\r\n */\r\nutil.toJSONOptions = {\r\n longs: String,\r\n enums: String,\r\n bytes: String,\r\n json: true\r\n};\r\n\r\n// Sets up buffer utility according to the environment (called in index-minimal)\r\nutil._configure = function() {\r\n var Buffer = util.Buffer;\r\n /* istanbul ignore if */\r\n if (!Buffer) {\r\n util._Buffer_from = util._Buffer_allocUnsafe = null;\r\n return;\r\n }\r\n // because node 4.x buffers are incompatible & immutable\r\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\r\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\r\n /* istanbul ignore next */\r\n function Buffer_from(value, encoding) {\r\n return new Buffer(value, encoding);\r\n };\r\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\r\n /* istanbul ignore next */\r\n function Buffer_allocUnsafe(size) {\r\n return new Buffer(size);\r\n };\r\n};\r\n","\"use strict\";\r\nmodule.exports = verifier;\r\n\r\nvar Enum = require(15),\r\n util = require(37);\r\n\r\nfunction invalid(field, expected) {\r\n return field.name + \": \" + expected + (field.repeated && expected !== \"array\" ? \"[]\" : field.map && expected !== \"object\" ? \"{k:\"+field.keyType+\"}\" : \"\") + \" expected\";\r\n}\r\n\r\n/**\r\n * Generates a partial value verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {number} fieldIndex Field index\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyValue(gen, field, fieldIndex, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n if (field.resolvedType) {\r\n if (field.resolvedType instanceof Enum) { gen\r\n (\"switch(%s){\", ref)\r\n (\"default:\")\r\n (\"return%j\", invalid(field, \"enum value\"));\r\n for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen\r\n (\"case %i:\", field.resolvedType.values[keys[j]]);\r\n gen\r\n (\"break\")\r\n (\"}\");\r\n } else {\r\n gen\r\n (\"{\")\r\n (\"var e=types[%i].verify(%s);\", fieldIndex, ref)\r\n (\"if(e)\")\r\n (\"return%j+e\", field.name + \".\")\r\n (\"}\");\r\n }\r\n } else {\r\n switch (field.type) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.isInteger(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))\", ref, ref, ref, ref)\r\n (\"return%j\", invalid(field, \"integer|Long\"));\r\n break;\r\n case \"float\":\r\n case \"double\": gen\r\n (\"if(typeof %s!==\\\"number\\\")\", ref)\r\n (\"return%j\", invalid(field, \"number\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(typeof %s!==\\\"boolean\\\")\", ref)\r\n (\"return%j\", invalid(field, \"boolean\"));\r\n break;\r\n case \"string\": gen\r\n (\"if(!util.isString(%s))\", ref)\r\n (\"return%j\", invalid(field, \"string\"));\r\n break;\r\n case \"bytes\": gen\r\n (\"if(!(%s&&typeof %s.length===\\\"number\\\"||util.isString(%s)))\", ref, ref, ref)\r\n (\"return%j\", invalid(field, \"buffer\"));\r\n break;\r\n }\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a partial key verifier.\r\n * @param {Codegen} gen Codegen instance\r\n * @param {Field} field Reflected field\r\n * @param {string} ref Variable reference\r\n * @returns {Codegen} Codegen instance\r\n * @ignore\r\n */\r\nfunction genVerifyKey(gen, field, ref) {\r\n /* eslint-disable no-unexpected-multiline */\r\n switch (field.keyType) {\r\n case \"int32\":\r\n case \"uint32\":\r\n case \"sint32\":\r\n case \"fixed32\":\r\n case \"sfixed32\": gen\r\n (\"if(!util.key32Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"integer key\"));\r\n break;\r\n case \"int64\":\r\n case \"uint64\":\r\n case \"sint64\":\r\n case \"fixed64\":\r\n case \"sfixed64\": gen\r\n (\"if(!util.key64Re.test(%s))\", ref) // see comment above: x is ok, d is not\r\n (\"return%j\", invalid(field, \"integer|Long key\"));\r\n break;\r\n case \"bool\": gen\r\n (\"if(!util.key2Re.test(%s))\", ref)\r\n (\"return%j\", invalid(field, \"boolean key\"));\r\n break;\r\n }\r\n return gen;\r\n /* eslint-enable no-unexpected-multiline */\r\n}\r\n\r\n/**\r\n * Generates a verifier specific to the specified message type.\r\n * @param {Type} mtype Message type\r\n * @returns {Codegen} Codegen instance\r\n */\r\nfunction verifier(mtype) {\r\n /* eslint-disable no-unexpected-multiline */\r\n\r\n var gen = util.codegen([\"m\"], mtype.name + \"$verify\")\r\n (\"if(typeof m!==\\\"object\\\"||m===null)\")\r\n (\"return%j\", \"object expected\");\r\n var oneofs = mtype.oneofsArray,\r\n seenFirstField = {};\r\n if (oneofs.length) gen\r\n (\"var p={}\");\r\n\r\n for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) {\r\n var field = mtype._fieldsArray[i].resolve(),\r\n ref = \"m\" + util.safeProp(field.name);\r\n\r\n if (field.optional) gen\r\n (\"if(%s!=null&&m.hasOwnProperty(%j)){\", ref, field.name); // !== undefined && !== null\r\n\r\n // map fields\r\n if (field.map) { gen\r\n (\"if(!util.isObject(%s))\", ref)\r\n (\"return%j\", invalid(field, \"object\"))\r\n (\"var k=Object.keys(%s)\", ref)\r\n (\"for(var i=0;i}\r\n * @const\r\n */\r\nvar wrappers = exports;\r\n\r\nvar Message = require(21);\r\n\r\n/**\r\n * From object converter part of an {@link IWrapper}.\r\n * @typedef WrapperFromObjectConverter\r\n * @type {function}\r\n * @param {Object.} object Plain object\r\n * @returns {Message<{}>} Message instance\r\n * @this Type\r\n */\r\n\r\n/**\r\n * To object converter part of an {@link IWrapper}.\r\n * @typedef WrapperToObjectConverter\r\n * @type {function}\r\n * @param {Message<{}>} message Message instance\r\n * @param {IConversionOptions} [options] Conversion options\r\n * @returns {Object.} Plain object\r\n * @this Type\r\n */\r\n\r\n/**\r\n * Common type wrapper part of {@link wrappers}.\r\n * @interface IWrapper\r\n * @property {WrapperFromObjectConverter} [fromObject] From object converter\r\n * @property {WrapperToObjectConverter} [toObject] To object converter\r\n */\r\n\r\n// Custom wrapper for Any\r\nwrappers[\".google.protobuf.Any\"] = {\r\n\r\n fromObject: function(object) {\r\n\r\n // unwrap value type if mapped\r\n if (object && object[\"@type\"]) {\r\n var type = this.lookup(object[\"@type\"]);\r\n /* istanbul ignore else */\r\n if (type) {\r\n // type_url does not accept leading \".\"\r\n var type_url = object[\"@type\"].charAt(0) === \".\" ?\r\n object[\"@type\"].substr(1) : object[\"@type\"];\r\n // type_url prefix is optional, but path seperator is required\r\n return this.create({\r\n type_url: \"/\" + type_url,\r\n value: type.encode(type.fromObject(object)).finish()\r\n });\r\n }\r\n }\r\n\r\n return this.fromObject(object);\r\n },\r\n\r\n toObject: function(message, options) {\r\n\r\n // decode value if requested and unmapped\r\n if (options && options.json && message.type_url && message.value) {\r\n // Only use fully qualified type name after the last '/'\r\n var name = message.type_url.substring(message.type_url.lastIndexOf(\"/\") + 1);\r\n var type = this.lookup(name);\r\n /* istanbul ignore else */\r\n if (type)\r\n message = type.decode(message.value);\r\n }\r\n\r\n // wrap value if unmapped\r\n if (!(message instanceof this.ctor) && message instanceof Message) {\r\n var object = message.$type.toObject(message, options);\r\n object[\"@type\"] = message.$type.fullName;\r\n return object;\r\n }\r\n\r\n return this.toObject(message, options);\r\n }\r\n};\r\n","\"use strict\";\r\nmodule.exports = Writer;\r\n\r\nvar util = require(39);\r\n\r\nvar BufferWriter; // cyclic\r\n\r\nvar LongBits = util.LongBits,\r\n base64 = util.base64,\r\n utf8 = util.utf8;\r\n\r\n/**\r\n * Constructs a new writer operation instance.\r\n * @classdesc Scheduled writer operation.\r\n * @constructor\r\n * @param {function(*, Uint8Array, number)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {*} val Value to write\r\n * @ignore\r\n */\r\nfunction Op(fn, len, val) {\r\n\r\n /**\r\n * Function to call.\r\n * @type {function(Uint8Array, number, *)}\r\n */\r\n this.fn = fn;\r\n\r\n /**\r\n * Value byte length.\r\n * @type {number}\r\n */\r\n this.len = len;\r\n\r\n /**\r\n * Next operation.\r\n * @type {Writer.Op|undefined}\r\n */\r\n this.next = undefined;\r\n\r\n /**\r\n * Value to write.\r\n * @type {*}\r\n */\r\n this.val = val; // type varies\r\n}\r\n\r\n/* istanbul ignore next */\r\nfunction noop() {} // eslint-disable-line no-empty-function\r\n\r\n/**\r\n * Constructs a new writer state instance.\r\n * @classdesc Copied writer state.\r\n * @memberof Writer\r\n * @constructor\r\n * @param {Writer} writer Writer to copy state from\r\n * @ignore\r\n */\r\nfunction State(writer) {\r\n\r\n /**\r\n * Current head.\r\n * @type {Writer.Op}\r\n */\r\n this.head = writer.head;\r\n\r\n /**\r\n * Current tail.\r\n * @type {Writer.Op}\r\n */\r\n this.tail = writer.tail;\r\n\r\n /**\r\n * Current buffer length.\r\n * @type {number}\r\n */\r\n this.len = writer.len;\r\n\r\n /**\r\n * Next state.\r\n * @type {State|null}\r\n */\r\n this.next = writer.states;\r\n}\r\n\r\n/**\r\n * Constructs a new writer instance.\r\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\r\n * @constructor\r\n */\r\nfunction Writer() {\r\n\r\n /**\r\n * Current length.\r\n * @type {number}\r\n */\r\n this.len = 0;\r\n\r\n /**\r\n * Operations head.\r\n * @type {Object}\r\n */\r\n this.head = new Op(noop, 0, 0);\r\n\r\n /**\r\n * Operations tail\r\n * @type {Object}\r\n */\r\n this.tail = this.head;\r\n\r\n /**\r\n * Linked forked states.\r\n * @type {Object|null}\r\n */\r\n this.states = null;\r\n\r\n // When a value is written, the writer calculates its byte length and puts it into a linked\r\n // list of operations to perform when finish() is called. This both allows us to allocate\r\n // buffers of the exact required size and reduces the amount of work we have to do compared\r\n // to first calculating over objects and then encoding over objects. In our case, the encoding\r\n // part is just a linked list walk calling operations with already prepared values.\r\n}\r\n\r\n/**\r\n * Creates a new writer.\r\n * @function\r\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\r\n */\r\nWriter.create = util.Buffer\r\n ? function create_buffer_setup() {\r\n return (Writer.create = function create_buffer() {\r\n return new BufferWriter();\r\n })();\r\n }\r\n /* istanbul ignore next */\r\n : function create_array() {\r\n return new Writer();\r\n };\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\nWriter.alloc = function alloc(size) {\r\n return new util.Array(size);\r\n};\r\n\r\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\r\n/* istanbul ignore else */\r\nif (util.Array !== Array)\r\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\r\n\r\n/**\r\n * Pushes a new operation to the queue.\r\n * @param {function(Uint8Array, number, *)} fn Function to call\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @returns {Writer} `this`\r\n * @private\r\n */\r\nWriter.prototype._push = function push(fn, len, val) {\r\n this.tail = this.tail.next = new Op(fn, len, val);\r\n this.len += len;\r\n return this;\r\n};\r\n\r\nfunction writeByte(val, buf, pos) {\r\n buf[pos] = val & 255;\r\n}\r\n\r\nfunction writeVarint32(val, buf, pos) {\r\n while (val > 127) {\r\n buf[pos++] = val & 127 | 128;\r\n val >>>= 7;\r\n }\r\n buf[pos] = val;\r\n}\r\n\r\n/**\r\n * Constructs a new varint writer operation instance.\r\n * @classdesc Scheduled varint writer operation.\r\n * @extends Op\r\n * @constructor\r\n * @param {number} len Value byte length\r\n * @param {number} val Value to write\r\n * @ignore\r\n */\r\nfunction VarintOp(len, val) {\r\n this.len = len;\r\n this.next = undefined;\r\n this.val = val;\r\n}\r\n\r\nVarintOp.prototype = Object.create(Op.prototype);\r\nVarintOp.prototype.fn = writeVarint32;\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as a varint.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.uint32 = function write_uint32(value) {\r\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\r\n // uint32 is by far the most frequently used operation and benefits significantly from this.\r\n this.len += (this.tail = this.tail.next = new VarintOp(\r\n (value = value >>> 0)\r\n < 128 ? 1\r\n : value < 16384 ? 2\r\n : value < 2097152 ? 3\r\n : value < 268435456 ? 4\r\n : 5,\r\n value)).len;\r\n return this;\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as a varint.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.int32 = function write_int32(value) {\r\n return value < 0\r\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\r\n : this.uint32(value);\r\n};\r\n\r\n/**\r\n * Writes a 32 bit value as a varint, zig-zag encoded.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sint32 = function write_sint32(value) {\r\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\r\n};\r\n\r\nfunction writeVarint64(val, buf, pos) {\r\n while (val.hi) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\r\n val.hi >>>= 7;\r\n }\r\n while (val.lo > 127) {\r\n buf[pos++] = val.lo & 127 | 128;\r\n val.lo = val.lo >>> 7;\r\n }\r\n buf[pos++] = val.lo;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as a varint.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.uint64 = function write_uint64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.int64 = Writer.prototype.uint64;\r\n\r\n/**\r\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sint64 = function write_sint64(value) {\r\n var bits = LongBits.from(value).zzEncode();\r\n return this._push(writeVarint64, bits.length(), bits);\r\n};\r\n\r\n/**\r\n * Writes a boolish value as a varint.\r\n * @param {boolean} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bool = function write_bool(value) {\r\n return this._push(writeByte, 1, value ? 1 : 0);\r\n};\r\n\r\nfunction writeFixed32(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\n/**\r\n * Writes an unsigned 32 bit value as fixed 32 bits.\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fixed32 = function write_fixed32(value) {\r\n return this._push(writeFixed32, 4, value >>> 0);\r\n};\r\n\r\n/**\r\n * Writes a signed 32 bit value as fixed 32 bits.\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\r\n\r\n/**\r\n * Writes an unsigned 64 bit value as fixed 64 bits.\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.fixed64 = function write_fixed64(value) {\r\n var bits = LongBits.from(value);\r\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\r\n};\r\n\r\n/**\r\n * Writes a signed 64 bit value as fixed 64 bits.\r\n * @function\r\n * @param {Long|number|string} value Value to write\r\n * @returns {Writer} `this`\r\n * @throws {TypeError} If `value` is a string and no long library is present.\r\n */\r\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\r\n\r\n/**\r\n * Writes a float (32 bit).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.float = function write_float(value) {\r\n return this._push(util.float.writeFloatLE, 4, value);\r\n};\r\n\r\n/**\r\n * Writes a double (64 bit float).\r\n * @function\r\n * @param {number} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.double = function write_double(value) {\r\n return this._push(util.float.writeDoubleLE, 8, value);\r\n};\r\n\r\nvar writeBytes = util.Array.prototype.set\r\n ? function writeBytes_set(val, buf, pos) {\r\n buf.set(val, pos); // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytes_for(val, buf, pos) {\r\n for (var i = 0; i < val.length; ++i)\r\n buf[pos + i] = val[i];\r\n };\r\n\r\n/**\r\n * Writes a sequence of bytes.\r\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.bytes = function write_bytes(value) {\r\n var len = value.length >>> 0;\r\n if (!len)\r\n return this._push(writeByte, 1, 0);\r\n if (util.isString(value)) {\r\n var buf = Writer.alloc(len = base64.length(value));\r\n base64.decode(value, buf, 0);\r\n value = buf;\r\n }\r\n return this.uint32(len)._push(writeBytes, len, value);\r\n};\r\n\r\n/**\r\n * Writes a string.\r\n * @param {string} value Value to write\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.string = function write_string(value) {\r\n var len = utf8.length(value);\r\n return len\r\n ? this.uint32(len)._push(utf8.write, len, value)\r\n : this._push(writeByte, 1, 0);\r\n};\r\n\r\n/**\r\n * Forks this writer's state by pushing it to a stack.\r\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.fork = function fork() {\r\n this.states = new State(this);\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets this instance to the last state.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.reset = function reset() {\r\n if (this.states) {\r\n this.head = this.states.head;\r\n this.tail = this.states.tail;\r\n this.len = this.states.len;\r\n this.states = this.states.next;\r\n } else {\r\n this.head = this.tail = new Op(noop, 0, 0);\r\n this.len = 0;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\r\n * @returns {Writer} `this`\r\n */\r\nWriter.prototype.ldelim = function ldelim() {\r\n var head = this.head,\r\n tail = this.tail,\r\n len = this.len;\r\n this.reset().uint32(len);\r\n if (len) {\r\n this.tail.next = head.next; // skip noop\r\n this.tail = tail;\r\n this.len += len;\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @returns {Uint8Array} Finished buffer\r\n */\r\nWriter.prototype.finish = function finish() {\r\n var head = this.head.next, // skip noop\r\n buf = this.constructor.alloc(this.len),\r\n pos = 0;\r\n while (head) {\r\n head.fn(head.val, buf, pos);\r\n pos += head.len;\r\n head = head.next;\r\n }\r\n // this.head = this.tail = null;\r\n return buf;\r\n};\r\n\r\nWriter._configure = function(BufferWriter_) {\r\n BufferWriter = BufferWriter_;\r\n};\r\n","\"use strict\";\r\nmodule.exports = BufferWriter;\r\n\r\n// extends Writer\r\nvar Writer = require(42);\r\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\r\n\r\nvar util = require(39);\r\n\r\nvar Buffer = util.Buffer;\r\n\r\n/**\r\n * Constructs a new buffer writer instance.\r\n * @classdesc Wire format writer using node buffers.\r\n * @extends Writer\r\n * @constructor\r\n */\r\nfunction BufferWriter() {\r\n Writer.call(this);\r\n}\r\n\r\n/**\r\n * Allocates a buffer of the specified size.\r\n * @param {number} size Buffer size\r\n * @returns {Buffer} Buffer\r\n */\r\nBufferWriter.alloc = function alloc_buffer(size) {\r\n return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);\r\n};\r\n\r\nvar writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === \"set\"\r\n ? function writeBytesBuffer_set(val, buf, pos) {\r\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\r\n // also works for plain array values\r\n }\r\n /* istanbul ignore next */\r\n : function writeBytesBuffer_copy(val, buf, pos) {\r\n if (val.copy) // Buffer values\r\n val.copy(buf, pos, 0, val.length);\r\n else for (var i = 0; i < val.length;) // plain array values\r\n buf[pos++] = val[i++];\r\n };\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\r\n if (util.isString(value))\r\n value = util._Buffer_from(value, \"base64\");\r\n var len = value.length >>> 0;\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeBytesBuffer, len, value);\r\n return this;\r\n};\r\n\r\nfunction writeStringBuffer(val, buf, pos) {\r\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\r\n util.utf8.write(val, buf, pos);\r\n else\r\n buf.utf8Write(val, pos);\r\n}\r\n\r\n/**\r\n * @override\r\n */\r\nBufferWriter.prototype.string = function write_string_buffer(value) {\r\n var len = Buffer.byteLength(value);\r\n this.uint32(len);\r\n if (len)\r\n this._push(writeStringBuffer, len, value);\r\n return this;\r\n};\r\n\r\n\r\n/**\r\n * Finishes the write operation.\r\n * @name BufferWriter#finish\r\n * @function\r\n * @returns {Buffer} Finished buffer\r\n */\r\n"],"sourceRoot":"."} \ No newline at end of file diff --git a/node_modules/protobufjs/ext/debug/README.md b/node_modules/protobufjs/ext/debug/README.md new file mode 100644 index 0000000..a48517e --- /dev/null +++ b/node_modules/protobufjs/ext/debug/README.md @@ -0,0 +1,4 @@ +protobufjs/ext/debug +========================= + +Experimental debugging extension. diff --git a/node_modules/protobufjs/ext/debug/index.js b/node_modules/protobufjs/ext/debug/index.js new file mode 100644 index 0000000..2b79766 --- /dev/null +++ b/node_modules/protobufjs/ext/debug/index.js @@ -0,0 +1,71 @@ +"use strict"; +var protobuf = require("../.."); + +/** + * Debugging utility functions. Only present in debug builds. + * @namespace + */ +var debug = protobuf.debug = module.exports = {}; + +var codegen = protobuf.util.codegen; + +var debugFnRe = /function ([^(]+)\(([^)]*)\) {/g; + +// Counts number of calls to any generated function +function codegen_debug() { + codegen_debug.supported = codegen.supported; + codegen_debug.verbose = codegen.verbose; + var gen = codegen.apply(null, Array.prototype.slice.call(arguments)); + gen.str = (function(str) { return function str_debug() { + return str.apply(null, Array.prototype.slice.call(arguments)).replace(debugFnRe, "function $1($2) {\n\t$1.calls=($1.calls|0)+1"); + };})(gen.str); + return gen; +} + +/** + * Returns a list of unused types within the specified root. + * @param {NamespaceBase} ns Namespace to search + * @returns {Type[]} Unused types + */ +debug.unusedTypes = function unusedTypes(ns) { + + /* istanbul ignore if */ + if (!(ns instanceof protobuf.Namespace)) + throw TypeError("ns must be a Namespace"); + + /* istanbul ignore if */ + if (!ns.nested) + return []; + + var unused = []; + for (var names = Object.keys(ns.nested), i = 0; i < names.length; ++i) { + var nested = ns.nested[names[i]]; + if (nested instanceof protobuf.Type) { + var calls = (nested.encode.calls|0) + + (nested.decode.calls|0) + + (nested.verify.calls|0) + + (nested.toObject.calls|0) + + (nested.fromObject.calls|0); + if (!calls) + unused.push(nested); + } else if (nested instanceof protobuf.Namespace) + Array.prototype.push.apply(unused, unusedTypes(nested)); + } + return unused; +}; + +/** + * Enables debugging extensions. + * @returns {undefined} + */ +debug.enable = function enable() { + protobuf.util.codegen = codegen_debug; +}; + +/** + * Disables debugging extensions. + * @returns {undefined} + */ +debug.disable = function disable() { + protobuf.util.codegen = codegen; +}; diff --git a/node_modules/protobufjs/ext/descriptor/README.md b/node_modules/protobufjs/ext/descriptor/README.md new file mode 100644 index 0000000..d78ef79 --- /dev/null +++ b/node_modules/protobufjs/ext/descriptor/README.md @@ -0,0 +1,72 @@ +protobufjs/ext/descriptor +========================= + +Experimental extension for interoperability with [descriptor.proto](https://github.com/google/protobuf/blob/master/src/google/protobuf/descriptor.proto) types. + +Usage +----- + +```js +var protobuf = require("protobufjs"), // requires the full library + descriptor = require("protobufjs/ext/descriptor"); + +var root = ...; + +// convert any existing root instance to the corresponding descriptor type +var descriptor = root.toDescriptor("proto2"); +// ^ returns a FileDescriptorSet message, see table below + +// encode to a descriptor buffer +var buffer = descriptor.FileDescriptorSet.encode(descriptor).finish(); + +// decode from a descriptor buffer +var decodedDescriptor = descriptor.FileDescriptorSet.decode(buffer); + +// convert any existing descriptor to a root instance +root = protobuf.Root.fromDescriptor(decodedDescriptor); +// ^ expects a FileDescriptorSet message or buffer, see table below + +// and start all over again +``` + +API +--- + +The extension adds `.fromDescriptor(descriptor[, syntax])` and `#toDescriptor([syntax])` methods to reflection objects and exports the `.google.protobuf` namespace of the internally used `Root` instance containing the following types present in descriptor.proto: + +| Descriptor type | protobuf.js type | Remarks +|-------------------------------|------------------|--------- +| **FileDescriptorSet** | Root | +| FileDescriptorProto | | dependencies are not supported +| FileOptions | | +| FileOptionsOptimizeMode | | +| SourceCodeInfo | | not supported +| SourceCodeInfoLocation | | +| GeneratedCodeInfo | | not supported +| GeneratedCodeInfoAnnotation | | +| **DescriptorProto** | Type | +| MessageOptions | | +| DescriptorProtoExtensionRange | | +| DescriptorProtoReservedRange | | +| **FieldDescriptorProto** | Field | +| FieldDescriptorProtoLabel | | +| FieldDescriptorProtoType | | +| FieldOptions | | +| FieldOptionsCType | | +| FieldOptionsJSType | | +| **OneofDescriptorProto** | OneOf | +| OneofOptions | | +| **EnumDescriptorProto** | Enum | +| EnumOptions | | +| EnumValueDescriptorProto | | +| EnumValueOptions | | not supported +| **ServiceDescriptorProto** | Service | +| ServiceOptions | | +| **MethodDescriptorProto** | Method | +| MethodOptions | | +| UninterpretedOption | | not supported +| UninterpretedOptionNamePart | | + +Note that not all features of descriptor.proto translate perfectly to a protobuf.js root instance. A root instance has only limited knowlege of packages or individual files for example, which is then compensated by guessing and generating fictional file names. + +When using TypeScript, the respective interface types can be used to reference specific message instances (i.e. `protobuf.Message`). diff --git a/node_modules/protobufjs/ext/descriptor/index.d.ts b/node_modules/protobufjs/ext/descriptor/index.d.ts new file mode 100644 index 0000000..1df2efc --- /dev/null +++ b/node_modules/protobufjs/ext/descriptor/index.d.ts @@ -0,0 +1,191 @@ +import * as $protobuf from "../.."; +export const FileDescriptorSet: $protobuf.Type; + +export const FileDescriptorProto: $protobuf.Type; + +export const DescriptorProto: $protobuf.Type & { + ExtensionRange: $protobuf.Type, + ReservedRange: $protobuf.Type +}; + +export const FieldDescriptorProto: $protobuf.Type & { + Label: $protobuf.Enum, + Type: $protobuf.Enum +}; + +export const OneofDescriptorProto: $protobuf.Type; + +export const EnumDescriptorProto: $protobuf.Type; + +export const ServiceDescriptorProto: $protobuf.Type; + +export const EnumValueDescriptorProto: $protobuf.Type; + +export const MethodDescriptorProto: $protobuf.Type; + +export const FileOptions: $protobuf.Type & { + OptimizeMode: $protobuf.Enum +}; + +export const MessageOptions: $protobuf.Type; + +export const FieldOptions: $protobuf.Type & { + CType: $protobuf.Enum, + JSType: $protobuf.Enum +}; + +export const OneofOptions: $protobuf.Type; + +export const EnumOptions: $protobuf.Type; + +export const EnumValueOptions: $protobuf.Type; + +export const ServiceOptions: $protobuf.Type; + +export const MethodOptions: $protobuf.Type; + +export const UninterpretedOption: $protobuf.Type & { + NamePart: $protobuf.Type +}; + +export const SourceCodeInfo: $protobuf.Type & { + Location: $protobuf.Type +}; + +export const GeneratedCodeInfo: $protobuf.Type & { + Annotation: $protobuf.Type +}; + +export interface IFileDescriptorSet { + file: IFileDescriptorProto[]; +} + +export interface IFileDescriptorProto { + name?: string; + package?: string; + dependency?: any; + publicDependency?: any; + weakDependency?: any; + messageType?: IDescriptorProto[]; + enumType?: IEnumDescriptorProto[]; + service?: IServiceDescriptorProto[]; + extension?: IFieldDescriptorProto[]; + options?: IFileOptions; + sourceCodeInfo?: any; + syntax?: string; +} + +export interface IFileOptions { + javaPackage?: string; + javaOuterClassname?: string; + javaMultipleFiles?: boolean; + javaGenerateEqualsAndHash?: boolean; + javaStringCheckUtf8?: boolean; + optimizeFor?: IFileOptionsOptimizeMode; + goPackage?: string; + ccGenericServices?: boolean; + javaGenericServices?: boolean; + pyGenericServices?: boolean; + deprecated?: boolean; + ccEnableArenas?: boolean; + objcClassPrefix?: string; + csharpNamespace?: string; +} + +type IFileOptionsOptimizeMode = number; + +export interface IDescriptorProto { + name?: string; + field?: IFieldDescriptorProto[]; + extension?: IFieldDescriptorProto[]; + nestedType?: IDescriptorProto[]; + enumType?: IEnumDescriptorProto[]; + extensionRange?: IDescriptorProtoExtensionRange[]; + oneofDecl?: IOneofDescriptorProto[]; + options?: IMessageOptions; + reservedRange?: IDescriptorProtoReservedRange[]; + reservedName?: string[]; +} + +export interface IMessageOptions { + mapEntry?: boolean; +} + +export interface IDescriptorProtoExtensionRange { + start?: number; + end?: number; +} + +export interface IDescriptorProtoReservedRange { + start?: number; + end?: number; +} + +export interface IFieldDescriptorProto { + name?: string; + number?: number; + label?: IFieldDescriptorProtoLabel; + type?: IFieldDescriptorProtoType; + typeName?: string; + extendee?: string; + defaultValue?: string; + oneofIndex?: number; + jsonName?: any; + options?: IFieldOptions; +} + +type IFieldDescriptorProtoLabel = number; + +type IFieldDescriptorProtoType = number; + +export interface IFieldOptions { + packed?: boolean; + jstype?: IFieldOptionsJSType; +} + +type IFieldOptionsJSType = number; + +export interface IEnumDescriptorProto { + name?: string; + value?: IEnumValueDescriptorProto[]; + options?: IEnumOptions; +} + +export interface IEnumValueDescriptorProto { + name?: string; + number?: number; + options?: any; +} + +export interface IEnumOptions { + allowAlias?: boolean; + deprecated?: boolean; +} + +export interface IOneofDescriptorProto { + name?: string; + options?: any; +} + +export interface IServiceDescriptorProto { + name?: string; + method?: IMethodDescriptorProto[]; + options?: IServiceOptions; +} + +export interface IServiceOptions { + deprecated?: boolean; +} + +export interface IMethodDescriptorProto { + name?: string; + inputType?: string; + outputType?: string; + options?: IMethodOptions; + clientStreaming?: boolean; + serverStreaming?: boolean; +} + +export interface IMethodOptions { + deprecated?: boolean; +} diff --git a/node_modules/protobufjs/ext/descriptor/index.js b/node_modules/protobufjs/ext/descriptor/index.js new file mode 100644 index 0000000..0b32d02 --- /dev/null +++ b/node_modules/protobufjs/ext/descriptor/index.js @@ -0,0 +1,1052 @@ +"use strict"; +var $protobuf = require("../.."); +module.exports = exports = $protobuf.descriptor = $protobuf.Root.fromJSON(require("../../google/protobuf/descriptor.json")).lookup(".google.protobuf"); + +var Namespace = $protobuf.Namespace, + Root = $protobuf.Root, + Enum = $protobuf.Enum, + Type = $protobuf.Type, + Field = $protobuf.Field, + MapField = $protobuf.MapField, + OneOf = $protobuf.OneOf, + Service = $protobuf.Service, + Method = $protobuf.Method; + +// --- Root --- + +/** + * Properties of a FileDescriptorSet message. + * @interface IFileDescriptorSet + * @property {IFileDescriptorProto[]} file Files + */ + +/** + * Properties of a FileDescriptorProto message. + * @interface IFileDescriptorProto + * @property {string} [name] File name + * @property {string} [package] Package + * @property {*} [dependency] Not supported + * @property {*} [publicDependency] Not supported + * @property {*} [weakDependency] Not supported + * @property {IDescriptorProto[]} [messageType] Nested message types + * @property {IEnumDescriptorProto[]} [enumType] Nested enums + * @property {IServiceDescriptorProto[]} [service] Nested services + * @property {IFieldDescriptorProto[]} [extension] Nested extension fields + * @property {IFileOptions} [options] Options + * @property {*} [sourceCodeInfo] Not supported + * @property {string} [syntax="proto2"] Syntax + */ + +/** + * Properties of a FileOptions message. + * @interface IFileOptions + * @property {string} [javaPackage] + * @property {string} [javaOuterClassname] + * @property {boolean} [javaMultipleFiles] + * @property {boolean} [javaGenerateEqualsAndHash] + * @property {boolean} [javaStringCheckUtf8] + * @property {IFileOptionsOptimizeMode} [optimizeFor=1] + * @property {string} [goPackage] + * @property {boolean} [ccGenericServices] + * @property {boolean} [javaGenericServices] + * @property {boolean} [pyGenericServices] + * @property {boolean} [deprecated] + * @property {boolean} [ccEnableArenas] + * @property {string} [objcClassPrefix] + * @property {string} [csharpNamespace] + */ + +/** + * Values of he FileOptions.OptimizeMode enum. + * @typedef IFileOptionsOptimizeMode + * @type {number} + * @property {number} SPEED=1 + * @property {number} CODE_SIZE=2 + * @property {number} LITE_RUNTIME=3 + */ + +/** + * Creates a root from a descriptor set. + * @param {IFileDescriptorSet|Reader|Uint8Array} descriptor Descriptor + * @returns {Root} Root instance + */ +Root.fromDescriptor = function fromDescriptor(descriptor) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.FileDescriptorSet.decode(descriptor); + + var root = new Root(); + + if (descriptor.file) { + var fileDescriptor, + filePackage; + for (var j = 0, i; j < descriptor.file.length; ++j) { + filePackage = root; + if ((fileDescriptor = descriptor.file[j])["package"] && fileDescriptor["package"].length) + filePackage = root.define(fileDescriptor["package"]); + if (fileDescriptor.name && fileDescriptor.name.length) + root.files.push(filePackage.filename = fileDescriptor.name); + if (fileDescriptor.messageType) + for (i = 0; i < fileDescriptor.messageType.length; ++i) + filePackage.add(Type.fromDescriptor(fileDescriptor.messageType[i], fileDescriptor.syntax)); + if (fileDescriptor.enumType) + for (i = 0; i < fileDescriptor.enumType.length; ++i) + filePackage.add(Enum.fromDescriptor(fileDescriptor.enumType[i])); + if (fileDescriptor.extension) + for (i = 0; i < fileDescriptor.extension.length; ++i) + filePackage.add(Field.fromDescriptor(fileDescriptor.extension[i])); + if (fileDescriptor.service) + for (i = 0; i < fileDescriptor.service.length; ++i) + filePackage.add(Service.fromDescriptor(fileDescriptor.service[i])); + var opts = fromDescriptorOptions(fileDescriptor.options, exports.FileOptions); + if (opts) { + var ks = Object.keys(opts); + for (i = 0; i < ks.length; ++i) + filePackage.setOption(ks[i], opts[ks[i]]); + } + } + } + + return root; +}; + +/** + * Converts a root to a descriptor set. + * @returns {Message} Descriptor + * @param {string} [syntax="proto2"] Syntax + */ +Root.prototype.toDescriptor = function toDescriptor(syntax) { + var set = exports.FileDescriptorSet.create(); + Root_toDescriptorRecursive(this, set.file, syntax); + return set; +}; + +// Traverses a namespace and assembles the descriptor set +function Root_toDescriptorRecursive(ns, files, syntax) { + + // Create a new file + var file = exports.FileDescriptorProto.create({ name: ns.filename || (ns.fullName.substring(1).replace(/\./g, "_") || "root") + ".proto" }); + if (syntax) + file.syntax = syntax; + if (!(ns instanceof Root)) + file["package"] = ns.fullName.substring(1); + + // Add nested types + for (var i = 0, nested; i < ns.nestedArray.length; ++i) + if ((nested = ns._nestedArray[i]) instanceof Type) + file.messageType.push(nested.toDescriptor(syntax)); + else if (nested instanceof Enum) + file.enumType.push(nested.toDescriptor()); + else if (nested instanceof Field) + file.extension.push(nested.toDescriptor(syntax)); + else if (nested instanceof Service) + file.service.push(nested.toDescriptor()); + else if (nested instanceof /* plain */ Namespace) + Root_toDescriptorRecursive(nested, files, syntax); // requires new file + + // Keep package-level options + file.options = toDescriptorOptions(ns.options, exports.FileOptions); + + // And keep the file only if there is at least one nested object + if (file.messageType.length + file.enumType.length + file.extension.length + file.service.length) + files.push(file); +} + +// --- Type --- + +/** + * Properties of a DescriptorProto message. + * @interface IDescriptorProto + * @property {string} [name] Message type name + * @property {IFieldDescriptorProto[]} [field] Fields + * @property {IFieldDescriptorProto[]} [extension] Extension fields + * @property {IDescriptorProto[]} [nestedType] Nested message types + * @property {IEnumDescriptorProto[]} [enumType] Nested enums + * @property {IDescriptorProtoExtensionRange[]} [extensionRange] Extension ranges + * @property {IOneofDescriptorProto[]} [oneofDecl] Oneofs + * @property {IMessageOptions} [options] Not supported + * @property {IDescriptorProtoReservedRange[]} [reservedRange] Reserved ranges + * @property {string[]} [reservedName] Reserved names + */ + +/** + * Properties of a MessageOptions message. + * @interface IMessageOptions + * @property {boolean} [mapEntry=false] Whether this message is a map entry + */ + +/** + * Properties of an ExtensionRange message. + * @interface IDescriptorProtoExtensionRange + * @property {number} [start] Start field id + * @property {number} [end] End field id + */ + +/** + * Properties of a ReservedRange message. + * @interface IDescriptorProtoReservedRange + * @property {number} [start] Start field id + * @property {number} [end] End field id + */ + +var unnamedMessageIndex = 0; + +/** + * Creates a type from a descriptor. + * @param {IDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @param {string} [syntax="proto2"] Syntax + * @returns {Type} Type instance + */ +Type.fromDescriptor = function fromDescriptor(descriptor, syntax) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.DescriptorProto.decode(descriptor); + + // Create the message type + var type = new Type(descriptor.name.length ? descriptor.name : "Type" + unnamedMessageIndex++, fromDescriptorOptions(descriptor.options, exports.MessageOptions)), + i; + + /* Oneofs */ if (descriptor.oneofDecl) + for (i = 0; i < descriptor.oneofDecl.length; ++i) + type.add(OneOf.fromDescriptor(descriptor.oneofDecl[i])); + /* Fields */ if (descriptor.field) + for (i = 0; i < descriptor.field.length; ++i) { + var field = Field.fromDescriptor(descriptor.field[i], syntax); + type.add(field); + if (descriptor.field[i].hasOwnProperty("oneofIndex")) // eslint-disable-line no-prototype-builtins + type.oneofsArray[descriptor.field[i].oneofIndex].add(field); + } + /* Extension fields */ if (descriptor.extension) + for (i = 0; i < descriptor.extension.length; ++i) + type.add(Field.fromDescriptor(descriptor.extension[i], syntax)); + /* Nested types */ if (descriptor.nestedType) + for (i = 0; i < descriptor.nestedType.length; ++i) { + type.add(Type.fromDescriptor(descriptor.nestedType[i], syntax)); + if (descriptor.nestedType[i].options && descriptor.nestedType[i].options.mapEntry) + type.setOption("map_entry", true); + } + /* Nested enums */ if (descriptor.enumType) + for (i = 0; i < descriptor.enumType.length; ++i) + type.add(Enum.fromDescriptor(descriptor.enumType[i])); + /* Extension ranges */ if (descriptor.extensionRange && descriptor.extensionRange.length) { + type.extensions = []; + for (i = 0; i < descriptor.extensionRange.length; ++i) + type.extensions.push([ descriptor.extensionRange[i].start, descriptor.extensionRange[i].end ]); + } + /* Reserved... */ if (descriptor.reservedRange && descriptor.reservedRange.length || descriptor.reservedName && descriptor.reservedName.length) { + type.reserved = []; + /* Ranges */ if (descriptor.reservedRange) + for (i = 0; i < descriptor.reservedRange.length; ++i) + type.reserved.push([ descriptor.reservedRange[i].start, descriptor.reservedRange[i].end ]); + /* Names */ if (descriptor.reservedName) + for (i = 0; i < descriptor.reservedName.length; ++i) + type.reserved.push(descriptor.reservedName[i]); + } + + return type; +}; + +/** + * Converts a type to a descriptor. + * @returns {Message} Descriptor + * @param {string} [syntax="proto2"] Syntax + */ +Type.prototype.toDescriptor = function toDescriptor(syntax) { + var descriptor = exports.DescriptorProto.create({ name: this.name }), + i; + + /* Fields */ for (i = 0; i < this.fieldsArray.length; ++i) { + var fieldDescriptor; + descriptor.field.push(fieldDescriptor = this._fieldsArray[i].toDescriptor(syntax)); + if (this._fieldsArray[i] instanceof MapField) { // map fields are repeated FieldNameEntry + var keyType = toDescriptorType(this._fieldsArray[i].keyType, this._fieldsArray[i].resolvedKeyType), + valueType = toDescriptorType(this._fieldsArray[i].type, this._fieldsArray[i].resolvedType), + valueTypeName = valueType === /* type */ 11 || valueType === /* enum */ 14 + ? this._fieldsArray[i].resolvedType && shortname(this.parent, this._fieldsArray[i].resolvedType) || this._fieldsArray[i].type + : undefined; + descriptor.nestedType.push(exports.DescriptorProto.create({ + name: fieldDescriptor.typeName, + field: [ + exports.FieldDescriptorProto.create({ name: "key", number: 1, label: 1, type: keyType }), // can't reference a type or enum + exports.FieldDescriptorProto.create({ name: "value", number: 2, label: 1, type: valueType, typeName: valueTypeName }) + ], + options: exports.MessageOptions.create({ mapEntry: true }) + })); + } + } + /* Oneofs */ for (i = 0; i < this.oneofsArray.length; ++i) + descriptor.oneofDecl.push(this._oneofsArray[i].toDescriptor()); + /* Nested... */ for (i = 0; i < this.nestedArray.length; ++i) { + /* Extension fields */ if (this._nestedArray[i] instanceof Field) + descriptor.field.push(this._nestedArray[i].toDescriptor(syntax)); + /* Types */ else if (this._nestedArray[i] instanceof Type) + descriptor.nestedType.push(this._nestedArray[i].toDescriptor(syntax)); + /* Enums */ else if (this._nestedArray[i] instanceof Enum) + descriptor.enumType.push(this._nestedArray[i].toDescriptor()); + // plain nested namespaces become packages instead in Root#toDescriptor + } + /* Extension ranges */ if (this.extensions) + for (i = 0; i < this.extensions.length; ++i) + descriptor.extensionRange.push(exports.DescriptorProto.ExtensionRange.create({ start: this.extensions[i][0], end: this.extensions[i][1] })); + /* Reserved... */ if (this.reserved) + for (i = 0; i < this.reserved.length; ++i) + /* Names */ if (typeof this.reserved[i] === "string") + descriptor.reservedName.push(this.reserved[i]); + /* Ranges */ else + descriptor.reservedRange.push(exports.DescriptorProto.ReservedRange.create({ start: this.reserved[i][0], end: this.reserved[i][1] })); + + descriptor.options = toDescriptorOptions(this.options, exports.MessageOptions); + + return descriptor; +}; + +// --- Field --- + +/** + * Properties of a FieldDescriptorProto message. + * @interface IFieldDescriptorProto + * @property {string} [name] Field name + * @property {number} [number] Field id + * @property {IFieldDescriptorProtoLabel} [label] Field rule + * @property {IFieldDescriptorProtoType} [type] Field basic type + * @property {string} [typeName] Field type name + * @property {string} [extendee] Extended type name + * @property {string} [defaultValue] Literal default value + * @property {number} [oneofIndex] Oneof index if part of a oneof + * @property {*} [jsonName] Not supported + * @property {IFieldOptions} [options] Field options + */ + +/** + * Values of the FieldDescriptorProto.Label enum. + * @typedef IFieldDescriptorProtoLabel + * @type {number} + * @property {number} LABEL_OPTIONAL=1 + * @property {number} LABEL_REQUIRED=2 + * @property {number} LABEL_REPEATED=3 + */ + +/** + * Values of the FieldDescriptorProto.Type enum. + * @typedef IFieldDescriptorProtoType + * @type {number} + * @property {number} TYPE_DOUBLE=1 + * @property {number} TYPE_FLOAT=2 + * @property {number} TYPE_INT64=3 + * @property {number} TYPE_UINT64=4 + * @property {number} TYPE_INT32=5 + * @property {number} TYPE_FIXED64=6 + * @property {number} TYPE_FIXED32=7 + * @property {number} TYPE_BOOL=8 + * @property {number} TYPE_STRING=9 + * @property {number} TYPE_GROUP=10 + * @property {number} TYPE_MESSAGE=11 + * @property {number} TYPE_BYTES=12 + * @property {number} TYPE_UINT32=13 + * @property {number} TYPE_ENUM=14 + * @property {number} TYPE_SFIXED32=15 + * @property {number} TYPE_SFIXED64=16 + * @property {number} TYPE_SINT32=17 + * @property {number} TYPE_SINT64=18 + */ + +/** + * Properties of a FieldOptions message. + * @interface IFieldOptions + * @property {boolean} [packed] Whether packed or not (defaults to `false` for proto2 and `true` for proto3) + * @property {IFieldOptionsJSType} [jstype] JavaScript value type (not used by protobuf.js) + */ + +/** + * Values of the FieldOptions.JSType enum. + * @typedef IFieldOptionsJSType + * @type {number} + * @property {number} JS_NORMAL=0 + * @property {number} JS_STRING=1 + * @property {number} JS_NUMBER=2 + */ + +// copied here from parse.js +var numberRe = /^(?![eE])[0-9]*(?:\.[0-9]*)?(?:[eE][+-]?[0-9]+)?$/; + +/** + * Creates a field from a descriptor. + * @param {IFieldDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @param {string} [syntax="proto2"] Syntax + * @returns {Field} Field instance + */ +Field.fromDescriptor = function fromDescriptor(descriptor, syntax) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.DescriptorProto.decode(descriptor); + + if (typeof descriptor.number !== "number") + throw Error("missing field id"); + + // Rewire field type + var fieldType; + if (descriptor.typeName && descriptor.typeName.length) + fieldType = descriptor.typeName; + else + fieldType = fromDescriptorType(descriptor.type); + + // Rewire field rule + var fieldRule; + switch (descriptor.label) { + // 0 is reserved for errors + case 1: fieldRule = undefined; break; + case 2: fieldRule = "required"; break; + case 3: fieldRule = "repeated"; break; + default: throw Error("illegal label: " + descriptor.label); + } + + var extendee = descriptor.extendee; + if (descriptor.extendee !== undefined) { + extendee = extendee.length ? extendee : undefined; + } + var field = new Field( + descriptor.name.length ? descriptor.name : "field" + descriptor.number, + descriptor.number, + fieldType, + fieldRule, + extendee + ); + + field.options = fromDescriptorOptions(descriptor.options, exports.FieldOptions); + + if (descriptor.defaultValue && descriptor.defaultValue.length) { + var defaultValue = descriptor.defaultValue; + switch (defaultValue) { + case "true": case "TRUE": + defaultValue = true; + break; + case "false": case "FALSE": + defaultValue = false; + break; + default: + var match = numberRe.exec(defaultValue); + if (match) + defaultValue = parseInt(defaultValue); // eslint-disable-line radix + break; + } + field.setOption("default", defaultValue); + } + + if (packableDescriptorType(descriptor.type)) { + if (syntax === "proto3") { // defaults to packed=true (internal preset is packed=true) + if (descriptor.options && !descriptor.options.packed) + field.setOption("packed", false); + } else if (!(descriptor.options && descriptor.options.packed)) // defaults to packed=false + field.setOption("packed", false); + } + + return field; +}; + +/** + * Converts a field to a descriptor. + * @returns {Message} Descriptor + * @param {string} [syntax="proto2"] Syntax + */ +Field.prototype.toDescriptor = function toDescriptor(syntax) { + var descriptor = exports.FieldDescriptorProto.create({ name: this.name, number: this.id }); + + if (this.map) { + + descriptor.type = 11; // message + descriptor.typeName = $protobuf.util.ucFirst(this.name); // fieldName -> FieldNameEntry (built in Type#toDescriptor) + descriptor.label = 3; // repeated + + } else { + + // Rewire field type + switch (descriptor.type = toDescriptorType(this.type, this.resolve().resolvedType)) { + case 10: // group + case 11: // type + case 14: // enum + descriptor.typeName = this.resolvedType ? shortname(this.parent, this.resolvedType) : this.type; + break; + } + + // Rewire field rule + switch (this.rule) { + case "repeated": descriptor.label = 3; break; + case "required": descriptor.label = 2; break; + default: descriptor.label = 1; break; + } + + } + + // Handle extension field + descriptor.extendee = this.extensionField ? this.extensionField.parent.fullName : this.extend; + + // Handle part of oneof + if (this.partOf) + if ((descriptor.oneofIndex = this.parent.oneofsArray.indexOf(this.partOf)) < 0) + throw Error("missing oneof"); + + if (this.options) { + descriptor.options = toDescriptorOptions(this.options, exports.FieldOptions); + if (this.options["default"] != null) + descriptor.defaultValue = String(this.options["default"]); + } + + if (syntax === "proto3") { // defaults to packed=true + if (!this.packed) + (descriptor.options || (descriptor.options = exports.FieldOptions.create())).packed = false; + } else if (this.packed) // defaults to packed=false + (descriptor.options || (descriptor.options = exports.FieldOptions.create())).packed = true; + + return descriptor; +}; + +// --- Enum --- + +/** + * Properties of an EnumDescriptorProto message. + * @interface IEnumDescriptorProto + * @property {string} [name] Enum name + * @property {IEnumValueDescriptorProto[]} [value] Enum values + * @property {IEnumOptions} [options] Enum options + */ + +/** + * Properties of an EnumValueDescriptorProto message. + * @interface IEnumValueDescriptorProto + * @property {string} [name] Name + * @property {number} [number] Value + * @property {*} [options] Not supported + */ + +/** + * Properties of an EnumOptions message. + * @interface IEnumOptions + * @property {boolean} [allowAlias] Whether aliases are allowed + * @property {boolean} [deprecated] + */ + +var unnamedEnumIndex = 0; + +/** + * Creates an enum from a descriptor. + * @param {IEnumDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @returns {Enum} Enum instance + */ +Enum.fromDescriptor = function fromDescriptor(descriptor) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.EnumDescriptorProto.decode(descriptor); + + // Construct values object + var values = {}; + if (descriptor.value) + for (var i = 0; i < descriptor.value.length; ++i) { + var name = descriptor.value[i].name, + value = descriptor.value[i].number || 0; + values[name && name.length ? name : "NAME" + value] = value; + } + + return new Enum( + descriptor.name && descriptor.name.length ? descriptor.name : "Enum" + unnamedEnumIndex++, + values, + fromDescriptorOptions(descriptor.options, exports.EnumOptions) + ); +}; + +/** + * Converts an enum to a descriptor. + * @returns {Message} Descriptor + */ +Enum.prototype.toDescriptor = function toDescriptor() { + + // Values + var values = []; + for (var i = 0, ks = Object.keys(this.values); i < ks.length; ++i) + values.push(exports.EnumValueDescriptorProto.create({ name: ks[i], number: this.values[ks[i]] })); + + return exports.EnumDescriptorProto.create({ + name: this.name, + value: values, + options: toDescriptorOptions(this.options, exports.EnumOptions) + }); +}; + +// --- OneOf --- + +/** + * Properties of a OneofDescriptorProto message. + * @interface IOneofDescriptorProto + * @property {string} [name] Oneof name + * @property {*} [options] Not supported + */ + +var unnamedOneofIndex = 0; + +/** + * Creates a oneof from a descriptor. + * @param {IOneofDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @returns {OneOf} OneOf instance + */ +OneOf.fromDescriptor = function fromDescriptor(descriptor) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.OneofDescriptorProto.decode(descriptor); + + return new OneOf( + // unnamedOneOfIndex is global, not per type, because we have no ref to a type here + descriptor.name && descriptor.name.length ? descriptor.name : "oneof" + unnamedOneofIndex++ + // fromDescriptorOptions(descriptor.options, exports.OneofOptions) - only uninterpreted_option + ); +}; + +/** + * Converts a oneof to a descriptor. + * @returns {Message} Descriptor + */ +OneOf.prototype.toDescriptor = function toDescriptor() { + return exports.OneofDescriptorProto.create({ + name: this.name + // options: toDescriptorOptions(this.options, exports.OneofOptions) - only uninterpreted_option + }); +}; + +// --- Service --- + +/** + * Properties of a ServiceDescriptorProto message. + * @interface IServiceDescriptorProto + * @property {string} [name] Service name + * @property {IMethodDescriptorProto[]} [method] Methods + * @property {IServiceOptions} [options] Options + */ + +/** + * Properties of a ServiceOptions message. + * @interface IServiceOptions + * @property {boolean} [deprecated] + */ + +var unnamedServiceIndex = 0; + +/** + * Creates a service from a descriptor. + * @param {IServiceDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @returns {Service} Service instance + */ +Service.fromDescriptor = function fromDescriptor(descriptor) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.ServiceDescriptorProto.decode(descriptor); + + var service = new Service(descriptor.name && descriptor.name.length ? descriptor.name : "Service" + unnamedServiceIndex++, fromDescriptorOptions(descriptor.options, exports.ServiceOptions)); + if (descriptor.method) + for (var i = 0; i < descriptor.method.length; ++i) + service.add(Method.fromDescriptor(descriptor.method[i])); + + return service; +}; + +/** + * Converts a service to a descriptor. + * @returns {Message} Descriptor + */ +Service.prototype.toDescriptor = function toDescriptor() { + + // Methods + var methods = []; + for (var i = 0; i < this.methodsArray; ++i) + methods.push(this._methodsArray[i].toDescriptor()); + + return exports.ServiceDescriptorProto.create({ + name: this.name, + methods: methods, + options: toDescriptorOptions(this.options, exports.ServiceOptions) + }); +}; + +// --- Method --- + +/** + * Properties of a MethodDescriptorProto message. + * @interface IMethodDescriptorProto + * @property {string} [name] Method name + * @property {string} [inputType] Request type name + * @property {string} [outputType] Response type name + * @property {IMethodOptions} [options] Not supported + * @property {boolean} [clientStreaming=false] Whether requests are streamed + * @property {boolean} [serverStreaming=false] Whether responses are streamed + */ + +/** + * Properties of a MethodOptions message. + * @interface IMethodOptions + * @property {boolean} [deprecated] + */ + +var unnamedMethodIndex = 0; + +/** + * Creates a method from a descriptor. + * @param {IMethodDescriptorProto|Reader|Uint8Array} descriptor Descriptor + * @returns {Method} Reflected method instance + */ +Method.fromDescriptor = function fromDescriptor(descriptor) { + + // Decode the descriptor message if specified as a buffer: + if (typeof descriptor.length === "number") + descriptor = exports.MethodDescriptorProto.decode(descriptor); + + return new Method( + // unnamedMethodIndex is global, not per service, because we have no ref to a service here + descriptor.name && descriptor.name.length ? descriptor.name : "Method" + unnamedMethodIndex++, + "rpc", + descriptor.inputType, + descriptor.outputType, + Boolean(descriptor.clientStreaming), + Boolean(descriptor.serverStreaming), + fromDescriptorOptions(descriptor.options, exports.MethodOptions) + ); +}; + +/** + * Converts a method to a descriptor. + * @returns {Message} Descriptor + */ +Method.prototype.toDescriptor = function toDescriptor() { + return exports.MethodDescriptorProto.create({ + name: this.name, + inputType: this.resolvedRequestType ? this.resolvedRequestType.fullName : this.requestType, + outputType: this.resolvedResponseType ? this.resolvedResponseType.fullName : this.responseType, + clientStreaming: this.requestStream, + serverStreaming: this.responseStream, + options: toDescriptorOptions(this.options, exports.MethodOptions) + }); +}; + +// --- utility --- + +// Converts a descriptor type to a protobuf.js basic type +function fromDescriptorType(type) { + switch (type) { + // 0 is reserved for errors + case 1: return "double"; + case 2: return "float"; + case 3: return "int64"; + case 4: return "uint64"; + case 5: return "int32"; + case 6: return "fixed64"; + case 7: return "fixed32"; + case 8: return "bool"; + case 9: return "string"; + case 12: return "bytes"; + case 13: return "uint32"; + case 15: return "sfixed32"; + case 16: return "sfixed64"; + case 17: return "sint32"; + case 18: return "sint64"; + } + throw Error("illegal type: " + type); +} + +// Tests if a descriptor type is packable +function packableDescriptorType(type) { + switch (type) { + case 1: // double + case 2: // float + case 3: // int64 + case 4: // uint64 + case 5: // int32 + case 6: // fixed64 + case 7: // fixed32 + case 8: // bool + case 13: // uint32 + case 14: // enum (!) + case 15: // sfixed32 + case 16: // sfixed64 + case 17: // sint32 + case 18: // sint64 + return true; + } + return false; +} + +// Converts a protobuf.js basic type to a descriptor type +function toDescriptorType(type, resolvedType) { + switch (type) { + // 0 is reserved for errors + case "double": return 1; + case "float": return 2; + case "int64": return 3; + case "uint64": return 4; + case "int32": return 5; + case "fixed64": return 6; + case "fixed32": return 7; + case "bool": return 8; + case "string": return 9; + case "bytes": return 12; + case "uint32": return 13; + case "sfixed32": return 15; + case "sfixed64": return 16; + case "sint32": return 17; + case "sint64": return 18; + } + if (resolvedType instanceof Enum) + return 14; + if (resolvedType instanceof Type) + return resolvedType.group ? 10 : 11; + throw Error("illegal type: " + type); +} + +// Converts descriptor options to an options object +function fromDescriptorOptions(options, type) { + if (!options) + return undefined; + var out = []; + for (var i = 0, field, key, val; i < type.fieldsArray.length; ++i) + if ((key = (field = type._fieldsArray[i]).name) !== "uninterpretedOption") + if (options.hasOwnProperty(key)) { // eslint-disable-line no-prototype-builtins + val = options[key]; + if (field.resolvedType instanceof Enum && typeof val === "number" && field.resolvedType.valuesById[val] !== undefined) + val = field.resolvedType.valuesById[val]; + out.push(underScore(key), val); + } + return out.length ? $protobuf.util.toObject(out) : undefined; +} + +// Converts an options object to descriptor options +function toDescriptorOptions(options, type) { + if (!options) + return undefined; + var out = []; + for (var i = 0, ks = Object.keys(options), key, val; i < ks.length; ++i) { + val = options[key = ks[i]]; + if (key === "default") + continue; + var field = type.fields[key]; + if (!field && !(field = type.fields[key = $protobuf.util.camelCase(key)])) + continue; + out.push(key, val); + } + return out.length ? type.fromObject($protobuf.util.toObject(out)) : undefined; +} + +// Calculates the shortest relative path from `from` to `to`. +function shortname(from, to) { + var fromPath = from.fullName.split("."), + toPath = to.fullName.split("."), + i = 0, + j = 0, + k = toPath.length - 1; + if (!(from instanceof Root) && to instanceof Namespace) + while (i < fromPath.length && j < k && fromPath[i] === toPath[j]) { + var other = to.lookup(fromPath[i++], true); + if (other !== null && other !== to) + break; + ++j; + } + else + for (; i < fromPath.length && j < k && fromPath[i] === toPath[j]; ++i, ++j); + return toPath.slice(j).join("."); +} + +// copied here from cli/targets/proto.js +function underScore(str) { + return str.substring(0,1) + + str.substring(1) + .replace(/([A-Z])(?=[a-z]|$)/g, function($0, $1) { return "_" + $1.toLowerCase(); }); +} + +// --- exports --- + +/** + * Reflected file descriptor set. + * @name FileDescriptorSet + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected file descriptor proto. + * @name FileDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected descriptor proto. + * @name DescriptorProto + * @type {Type} + * @property {Type} ExtensionRange + * @property {Type} ReservedRange + * @const + * @tstype $protobuf.Type & { + * ExtensionRange: $protobuf.Type, + * ReservedRange: $protobuf.Type + * } + */ + +/** + * Reflected field descriptor proto. + * @name FieldDescriptorProto + * @type {Type} + * @property {Enum} Label + * @property {Enum} Type + * @const + * @tstype $protobuf.Type & { + * Label: $protobuf.Enum, + * Type: $protobuf.Enum + * } + */ + +/** + * Reflected oneof descriptor proto. + * @name OneofDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected enum descriptor proto. + * @name EnumDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected service descriptor proto. + * @name ServiceDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected enum value descriptor proto. + * @name EnumValueDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected method descriptor proto. + * @name MethodDescriptorProto + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected file options. + * @name FileOptions + * @type {Type} + * @property {Enum} OptimizeMode + * @const + * @tstype $protobuf.Type & { + * OptimizeMode: $protobuf.Enum + * } + */ + +/** + * Reflected message options. + * @name MessageOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected field options. + * @name FieldOptions + * @type {Type} + * @property {Enum} CType + * @property {Enum} JSType + * @const + * @tstype $protobuf.Type & { + * CType: $protobuf.Enum, + * JSType: $protobuf.Enum + * } + */ + +/** + * Reflected oneof options. + * @name OneofOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected enum options. + * @name EnumOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected enum value options. + * @name EnumValueOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected service options. + * @name ServiceOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected method options. + * @name MethodOptions + * @type {Type} + * @const + * @tstype $protobuf.Type + */ + +/** + * Reflected uninterpretet option. + * @name UninterpretedOption + * @type {Type} + * @property {Type} NamePart + * @const + * @tstype $protobuf.Type & { + * NamePart: $protobuf.Type + * } + */ + +/** + * Reflected source code info. + * @name SourceCodeInfo + * @type {Type} + * @property {Type} Location + * @const + * @tstype $protobuf.Type & { + * Location: $protobuf.Type + * } + */ + +/** + * Reflected generated code info. + * @name GeneratedCodeInfo + * @type {Type} + * @property {Type} Annotation + * @const + * @tstype $protobuf.Type & { + * Annotation: $protobuf.Type + * } + */ diff --git a/node_modules/protobufjs/ext/descriptor/test.js b/node_modules/protobufjs/ext/descriptor/test.js new file mode 100644 index 0000000..ceb80f8 --- /dev/null +++ b/node_modules/protobufjs/ext/descriptor/test.js @@ -0,0 +1,54 @@ +/*eslint-disable no-console*/ +"use strict"; +var protobuf = require("../../"), + descriptor = require("."); + +/* var proto = { + nested: { + Message: { + fields: { + foo: { + type: "string", + id: 1 + } + }, + nested: { + SubMessage: { + fields: {} + } + } + }, + Enum: { + values: { + ONE: 1, + TWO: 2 + } + } + } +}; */ + +// var root = protobuf.Root.fromJSON(proto).resolveAll(); +var root = protobuf.loadSync("tests/data/google/protobuf/descriptor.proto").resolveAll(); + +// console.log("Original proto", JSON.stringify(root, null, 2)); + +var msg = root.toDescriptor(); + +// console.log("\nDescriptor", JSON.stringify(msg.toObject(), null, 2)); + +var buf = descriptor.FileDescriptorSet.encode(msg).finish(); +var root2 = protobuf.Root.fromDescriptor(buf, "proto2").resolveAll(); + +// console.log("\nDecoded proto", JSON.stringify(root2, null, 2)); + +var diff = require("deep-diff").diff(root.toJSON(), root2.toJSON()); +if (diff) { + diff.forEach(function(diff) { + console.log(diff.kind + " @ " + diff.path.join(".")); + console.log("lhs:", typeof diff.lhs, diff.lhs); + console.log("rhs:", typeof diff.rhs, diff.rhs); + console.log(); + }); + process.exitCode = 1; +} else + console.log("no differences"); diff --git a/node_modules/protobufjs/google/LICENSE b/node_modules/protobufjs/google/LICENSE new file mode 100644 index 0000000..868bd40 --- /dev/null +++ b/node_modules/protobufjs/google/LICENSE @@ -0,0 +1,27 @@ +Copyright 2014, Google Inc. All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + + * Redistributions of source code must retain the above copyright +notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above +copyright notice, this list of conditions and the following disclaimer +in the documentation and/or other materials provided with the +distribution. + * Neither the name of Google Inc. nor the names of its +contributors may be used to endorse or promote products derived from +this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/protobufjs/google/README.md b/node_modules/protobufjs/google/README.md new file mode 100644 index 0000000..09e3f23 --- /dev/null +++ b/node_modules/protobufjs/google/README.md @@ -0,0 +1 @@ +This folder contains stripped and pre-parsed definitions of common Google types. These files are not used by protobuf.js directly but are here so you can use or include them where required. diff --git a/node_modules/protobufjs/google/api/annotations.json b/node_modules/protobufjs/google/api/annotations.json new file mode 100644 index 0000000..3f13a73 --- /dev/null +++ b/node_modules/protobufjs/google/api/annotations.json @@ -0,0 +1,83 @@ +{ + "nested": { + "google": { + "nested": { + "api": { + "nested": { + "http": { + "type": "HttpRule", + "id": 72295728, + "extend": "google.protobuf.MethodOptions" + }, + "HttpRule": { + "oneofs": { + "pattern": { + "oneof": [ + "get", + "put", + "post", + "delete", + "patch", + "custom" + ] + } + }, + "fields": { + "get": { + "type": "string", + "id": 2 + }, + "put": { + "type": "string", + "id": 3 + }, + "post": { + "type": "string", + "id": 4 + }, + "delete": { + "type": "string", + "id": 5 + }, + "patch": { + "type": "string", + "id": 6 + }, + "custom": { + "type": "CustomHttpPattern", + "id": 8 + }, + "selector": { + "type": "string", + "id": 1 + }, + "body": { + "type": "string", + "id": 7 + }, + "additionalBindings": { + "rule": "repeated", + "type": "HttpRule", + "id": 11 + } + } + } + } + }, + "protobuf": { + "nested": { + "MethodOptions": { + "fields": {}, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/api/annotations.proto b/node_modules/protobufjs/google/api/annotations.proto new file mode 100644 index 0000000..63a8eef --- /dev/null +++ b/node_modules/protobufjs/google/api/annotations.proto @@ -0,0 +1,11 @@ +syntax = "proto3"; + +package google.api; + +import "google/api/http.proto"; +import "google/protobuf/descriptor.proto"; + +extend google.protobuf.MethodOptions { + + HttpRule http = 72295728; +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/api/http.json b/node_modules/protobufjs/google/api/http.json new file mode 100644 index 0000000..e3a0f4f --- /dev/null +++ b/node_modules/protobufjs/google/api/http.json @@ -0,0 +1,86 @@ +{ + "nested": { + "google": { + "nested": { + "api": { + "nested": { + "Http": { + "fields": { + "rules": { + "rule": "repeated", + "type": "HttpRule", + "id": 1 + } + } + }, + "HttpRule": { + "oneofs": { + "pattern": { + "oneof": [ + "get", + "put", + "post", + "delete", + "patch", + "custom" + ] + } + }, + "fields": { + "get": { + "type": "string", + "id": 2 + }, + "put": { + "type": "string", + "id": 3 + }, + "post": { + "type": "string", + "id": 4 + }, + "delete": { + "type": "string", + "id": 5 + }, + "patch": { + "type": "string", + "id": 6 + }, + "custom": { + "type": "CustomHttpPattern", + "id": 8 + }, + "selector": { + "type": "string", + "id": 1 + }, + "body": { + "type": "string", + "id": 7 + }, + "additionalBindings": { + "rule": "repeated", + "type": "HttpRule", + "id": 11 + } + } + }, + "CustomHttpPattern": { + "fields": { + "kind": { + "type": "string", + "id": 1 + }, + "path": { + "type": "string", + "id": 2 + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/api/http.proto b/node_modules/protobufjs/google/api/http.proto new file mode 100644 index 0000000..e9a7e9d --- /dev/null +++ b/node_modules/protobufjs/google/api/http.proto @@ -0,0 +1,31 @@ +syntax = "proto3"; + +package google.api; + +message Http { + + repeated HttpRule rules = 1; +} + +message HttpRule { + + oneof pattern { + + string get = 2; + string put = 3; + string post = 4; + string delete = 5; + string patch = 6; + CustomHttpPattern custom = 8; + } + + string selector = 1; + string body = 7; + repeated HttpRule additional_bindings = 11; +} + +message CustomHttpPattern { + + string kind = 1; + string path = 2; +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/api.json b/node_modules/protobufjs/google/protobuf/api.json new file mode 100644 index 0000000..5460612 --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/api.json @@ -0,0 +1,118 @@ +{ + "nested": { + "google": { + "nested": { + "protobuf": { + "nested": { + "Api": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "methods": { + "rule": "repeated", + "type": "Method", + "id": 2 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 3 + }, + "version": { + "type": "string", + "id": 4 + }, + "sourceContext": { + "type": "SourceContext", + "id": 5 + }, + "mixins": { + "rule": "repeated", + "type": "Mixin", + "id": 6 + }, + "syntax": { + "type": "Syntax", + "id": 7 + } + } + }, + "Method": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "requestTypeUrl": { + "type": "string", + "id": 2 + }, + "requestStreaming": { + "type": "bool", + "id": 3 + }, + "responseTypeUrl": { + "type": "string", + "id": 4 + }, + "responseStreaming": { + "type": "bool", + "id": 5 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 6 + }, + "syntax": { + "type": "Syntax", + "id": 7 + } + } + }, + "Mixin": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "root": { + "type": "string", + "id": 2 + } + } + }, + "SourceContext": { + "fields": { + "fileName": { + "type": "string", + "id": 1 + } + } + }, + "Option": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "value": { + "type": "Any", + "id": 2 + } + } + }, + "Syntax": { + "values": { + "SYNTAX_PROTO2": 0, + "SYNTAX_PROTO3": 1 + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/api.proto b/node_modules/protobufjs/google/protobuf/api.proto new file mode 100644 index 0000000..cf6ae3f --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/api.proto @@ -0,0 +1,34 @@ +syntax = "proto3"; + +package google.protobuf; + +import "google/protobuf/source_context.proto"; +import "google/protobuf/type.proto"; + +message Api { + + string name = 1; + repeated Method methods = 2; + repeated Option options = 3; + string version = 4; + SourceContext source_context = 5; + repeated Mixin mixins = 6; + Syntax syntax = 7; +} + +message Method { + + string name = 1; + string request_type_url = 2; + bool request_streaming = 3; + string response_type_url = 4; + bool response_streaming = 5; + repeated Option options = 6; + Syntax syntax = 7; +} + +message Mixin { + + string name = 1; + string root = 2; +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/descriptor.json b/node_modules/protobufjs/google/protobuf/descriptor.json new file mode 100644 index 0000000..f6c5c11 --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/descriptor.json @@ -0,0 +1,739 @@ +{ + "nested": { + "google": { + "nested": { + "protobuf": { + "nested": { + "FileDescriptorSet": { + "fields": { + "file": { + "rule": "repeated", + "type": "FileDescriptorProto", + "id": 1 + } + } + }, + "FileDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "package": { + "type": "string", + "id": 2 + }, + "dependency": { + "rule": "repeated", + "type": "string", + "id": 3 + }, + "publicDependency": { + "rule": "repeated", + "type": "int32", + "id": 10, + "options": { + "packed": false + } + }, + "weakDependency": { + "rule": "repeated", + "type": "int32", + "id": 11, + "options": { + "packed": false + } + }, + "messageType": { + "rule": "repeated", + "type": "DescriptorProto", + "id": 4 + }, + "enumType": { + "rule": "repeated", + "type": "EnumDescriptorProto", + "id": 5 + }, + "service": { + "rule": "repeated", + "type": "ServiceDescriptorProto", + "id": 6 + }, + "extension": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 7 + }, + "options": { + "type": "FileOptions", + "id": 8 + }, + "sourceCodeInfo": { + "type": "SourceCodeInfo", + "id": 9 + }, + "syntax": { + "type": "string", + "id": 12 + } + } + }, + "DescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "field": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 2 + }, + "extension": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 6 + }, + "nestedType": { + "rule": "repeated", + "type": "DescriptorProto", + "id": 3 + }, + "enumType": { + "rule": "repeated", + "type": "EnumDescriptorProto", + "id": 4 + }, + "extensionRange": { + "rule": "repeated", + "type": "ExtensionRange", + "id": 5 + }, + "oneofDecl": { + "rule": "repeated", + "type": "OneofDescriptorProto", + "id": 8 + }, + "options": { + "type": "MessageOptions", + "id": 7 + }, + "reservedRange": { + "rule": "repeated", + "type": "ReservedRange", + "id": 9 + }, + "reservedName": { + "rule": "repeated", + "type": "string", + "id": 10 + } + }, + "nested": { + "ExtensionRange": { + "fields": { + "start": { + "type": "int32", + "id": 1 + }, + "end": { + "type": "int32", + "id": 2 + } + } + }, + "ReservedRange": { + "fields": { + "start": { + "type": "int32", + "id": 1 + }, + "end": { + "type": "int32", + "id": 2 + } + } + } + } + }, + "FieldDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "number": { + "type": "int32", + "id": 3 + }, + "label": { + "type": "Label", + "id": 4 + }, + "type": { + "type": "Type", + "id": 5 + }, + "typeName": { + "type": "string", + "id": 6 + }, + "extendee": { + "type": "string", + "id": 2 + }, + "defaultValue": { + "type": "string", + "id": 7 + }, + "oneofIndex": { + "type": "int32", + "id": 9 + }, + "jsonName": { + "type": "string", + "id": 10 + }, + "options": { + "type": "FieldOptions", + "id": 8 + } + }, + "nested": { + "Type": { + "values": { + "TYPE_DOUBLE": 1, + "TYPE_FLOAT": 2, + "TYPE_INT64": 3, + "TYPE_UINT64": 4, + "TYPE_INT32": 5, + "TYPE_FIXED64": 6, + "TYPE_FIXED32": 7, + "TYPE_BOOL": 8, + "TYPE_STRING": 9, + "TYPE_GROUP": 10, + "TYPE_MESSAGE": 11, + "TYPE_BYTES": 12, + "TYPE_UINT32": 13, + "TYPE_ENUM": 14, + "TYPE_SFIXED32": 15, + "TYPE_SFIXED64": 16, + "TYPE_SINT32": 17, + "TYPE_SINT64": 18 + } + }, + "Label": { + "values": { + "LABEL_OPTIONAL": 1, + "LABEL_REQUIRED": 2, + "LABEL_REPEATED": 3 + } + } + } + }, + "OneofDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "options": { + "type": "OneofOptions", + "id": 2 + } + } + }, + "EnumDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "value": { + "rule": "repeated", + "type": "EnumValueDescriptorProto", + "id": 2 + }, + "options": { + "type": "EnumOptions", + "id": 3 + } + } + }, + "EnumValueDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "number": { + "type": "int32", + "id": 2 + }, + "options": { + "type": "EnumValueOptions", + "id": 3 + } + } + }, + "ServiceDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "method": { + "rule": "repeated", + "type": "MethodDescriptorProto", + "id": 2 + }, + "options": { + "type": "ServiceOptions", + "id": 3 + } + } + }, + "MethodDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "inputType": { + "type": "string", + "id": 2 + }, + "outputType": { + "type": "string", + "id": 3 + }, + "options": { + "type": "MethodOptions", + "id": 4 + }, + "clientStreaming": { + "type": "bool", + "id": 5 + }, + "serverStreaming": { + "type": "bool", + "id": 6 + } + } + }, + "FileOptions": { + "fields": { + "javaPackage": { + "type": "string", + "id": 1 + }, + "javaOuterClassname": { + "type": "string", + "id": 8 + }, + "javaMultipleFiles": { + "type": "bool", + "id": 10 + }, + "javaGenerateEqualsAndHash": { + "type": "bool", + "id": 20, + "options": { + "deprecated": true + } + }, + "javaStringCheckUtf8": { + "type": "bool", + "id": 27 + }, + "optimizeFor": { + "type": "OptimizeMode", + "id": 9, + "options": { + "default": "SPEED" + } + }, + "goPackage": { + "type": "string", + "id": 11 + }, + "ccGenericServices": { + "type": "bool", + "id": 16 + }, + "javaGenericServices": { + "type": "bool", + "id": 17 + }, + "pyGenericServices": { + "type": "bool", + "id": 18 + }, + "deprecated": { + "type": "bool", + "id": 23 + }, + "ccEnableArenas": { + "type": "bool", + "id": 31 + }, + "objcClassPrefix": { + "type": "string", + "id": 36 + }, + "csharpNamespace": { + "type": "string", + "id": 37 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 38, + 38 + ] + ], + "nested": { + "OptimizeMode": { + "values": { + "SPEED": 1, + "CODE_SIZE": 2, + "LITE_RUNTIME": 3 + } + } + } + }, + "MessageOptions": { + "fields": { + "messageSetWireFormat": { + "type": "bool", + "id": 1 + }, + "noStandardDescriptorAccessor": { + "type": "bool", + "id": 2 + }, + "deprecated": { + "type": "bool", + "id": 3 + }, + "mapEntry": { + "type": "bool", + "id": 7 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 8, + 8 + ] + ] + }, + "FieldOptions": { + "fields": { + "ctype": { + "type": "CType", + "id": 1, + "options": { + "default": "STRING" + } + }, + "packed": { + "type": "bool", + "id": 2 + }, + "jstype": { + "type": "JSType", + "id": 6, + "options": { + "default": "JS_NORMAL" + } + }, + "lazy": { + "type": "bool", + "id": 5 + }, + "deprecated": { + "type": "bool", + "id": 3 + }, + "weak": { + "type": "bool", + "id": 10 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 4, + 4 + ] + ], + "nested": { + "CType": { + "values": { + "STRING": 0, + "CORD": 1, + "STRING_PIECE": 2 + } + }, + "JSType": { + "values": { + "JS_NORMAL": 0, + "JS_STRING": 1, + "JS_NUMBER": 2 + } + } + } + }, + "OneofOptions": { + "fields": { + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "EnumOptions": { + "fields": { + "allowAlias": { + "type": "bool", + "id": 2 + }, + "deprecated": { + "type": "bool", + "id": 3 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "EnumValueOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 1 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "ServiceOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 33 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "MethodOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 33 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "UninterpretedOption": { + "fields": { + "name": { + "rule": "repeated", + "type": "NamePart", + "id": 2 + }, + "identifierValue": { + "type": "string", + "id": 3 + }, + "positiveIntValue": { + "type": "uint64", + "id": 4 + }, + "negativeIntValue": { + "type": "int64", + "id": 5 + }, + "doubleValue": { + "type": "double", + "id": 6 + }, + "stringValue": { + "type": "bytes", + "id": 7 + }, + "aggregateValue": { + "type": "string", + "id": 8 + } + }, + "nested": { + "NamePart": { + "fields": { + "namePart": { + "rule": "required", + "type": "string", + "id": 1 + }, + "isExtension": { + "rule": "required", + "type": "bool", + "id": 2 + } + } + } + } + }, + "SourceCodeInfo": { + "fields": { + "location": { + "rule": "repeated", + "type": "Location", + "id": 1 + } + }, + "nested": { + "Location": { + "fields": { + "path": { + "rule": "repeated", + "type": "int32", + "id": 1 + }, + "span": { + "rule": "repeated", + "type": "int32", + "id": 2 + }, + "leadingComments": { + "type": "string", + "id": 3 + }, + "trailingComments": { + "type": "string", + "id": 4 + }, + "leadingDetachedComments": { + "rule": "repeated", + "type": "string", + "id": 6 + } + } + } + } + }, + "GeneratedCodeInfo": { + "fields": { + "annotation": { + "rule": "repeated", + "type": "Annotation", + "id": 1 + } + }, + "nested": { + "Annotation": { + "fields": { + "path": { + "rule": "repeated", + "type": "int32", + "id": 1 + }, + "sourceFile": { + "type": "string", + "id": 2 + }, + "begin": { + "type": "int32", + "id": 3 + }, + "end": { + "type": "int32", + "id": 4 + } + } + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/descriptor.proto b/node_modules/protobufjs/google/protobuf/descriptor.proto new file mode 100644 index 0000000..3279492 --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/descriptor.proto @@ -0,0 +1,286 @@ +syntax = "proto2"; + +package google.protobuf; + +message FileDescriptorSet { + + repeated FileDescriptorProto file = 1; +} + +message FileDescriptorProto { + + optional string name = 1; + optional string package = 2; + repeated string dependency = 3; + repeated int32 public_dependency = 10; + repeated int32 weak_dependency = 11; + repeated DescriptorProto message_type = 4; + repeated EnumDescriptorProto enum_type = 5; + repeated ServiceDescriptorProto service = 6; + repeated FieldDescriptorProto extension = 7; + optional FileOptions options = 8; + optional SourceCodeInfo source_code_info = 9; + optional string syntax = 12; +} + +message DescriptorProto { + + optional string name = 1; + repeated FieldDescriptorProto field = 2; + repeated FieldDescriptorProto extension = 6; + repeated DescriptorProto nested_type = 3; + repeated EnumDescriptorProto enum_type = 4; + repeated ExtensionRange extension_range = 5; + repeated OneofDescriptorProto oneof_decl = 8; + optional MessageOptions options = 7; + repeated ReservedRange reserved_range = 9; + repeated string reserved_name = 10; + + message ExtensionRange { + + optional int32 start = 1; + optional int32 end = 2; + } + + message ReservedRange { + + optional int32 start = 1; + optional int32 end = 2; + } +} + +message FieldDescriptorProto { + + optional string name = 1; + optional int32 number = 3; + optional Label label = 4; + optional Type type = 5; + optional string type_name = 6; + optional string extendee = 2; + optional string default_value = 7; + optional int32 oneof_index = 9; + optional string json_name = 10; + optional FieldOptions options = 8; + + enum Type { + + TYPE_DOUBLE = 1; + TYPE_FLOAT = 2; + TYPE_INT64 = 3; + TYPE_UINT64 = 4; + TYPE_INT32 = 5; + TYPE_FIXED64 = 6; + TYPE_FIXED32 = 7; + TYPE_BOOL = 8; + TYPE_STRING = 9; + TYPE_GROUP = 10; + TYPE_MESSAGE = 11; + TYPE_BYTES = 12; + TYPE_UINT32 = 13; + TYPE_ENUM = 14; + TYPE_SFIXED32 = 15; + TYPE_SFIXED64 = 16; + TYPE_SINT32 = 17; + TYPE_SINT64 = 18; + } + + enum Label { + + LABEL_OPTIONAL = 1; + LABEL_REQUIRED = 2; + LABEL_REPEATED = 3; + } +} + +message OneofDescriptorProto { + + optional string name = 1; + optional OneofOptions options = 2; +} + +message EnumDescriptorProto { + + optional string name = 1; + repeated EnumValueDescriptorProto value = 2; + optional EnumOptions options = 3; +} + +message EnumValueDescriptorProto { + + optional string name = 1; + optional int32 number = 2; + optional EnumValueOptions options = 3; +} + +message ServiceDescriptorProto { + + optional string name = 1; + repeated MethodDescriptorProto method = 2; + optional ServiceOptions options = 3; +} + +message MethodDescriptorProto { + + optional string name = 1; + optional string input_type = 2; + optional string output_type = 3; + optional MethodOptions options = 4; + optional bool client_streaming = 5; + optional bool server_streaming = 6; +} + +message FileOptions { + + optional string java_package = 1; + optional string java_outer_classname = 8; + optional bool java_multiple_files = 10; + optional bool java_generate_equals_and_hash = 20 [deprecated=true]; + optional bool java_string_check_utf8 = 27; + optional OptimizeMode optimize_for = 9 [default=SPEED]; + optional string go_package = 11; + optional bool cc_generic_services = 16; + optional bool java_generic_services = 17; + optional bool py_generic_services = 18; + optional bool deprecated = 23; + optional bool cc_enable_arenas = 31; + optional string objc_class_prefix = 36; + optional string csharp_namespace = 37; + repeated UninterpretedOption uninterpreted_option = 999; + + enum OptimizeMode { + + SPEED = 1; + CODE_SIZE = 2; + LITE_RUNTIME = 3; + } + + extensions 1000 to max; + + reserved 38; +} + +message MessageOptions { + + optional bool message_set_wire_format = 1; + optional bool no_standard_descriptor_accessor = 2; + optional bool deprecated = 3; + optional bool map_entry = 7; + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; + + reserved 8; +} + +message FieldOptions { + + optional CType ctype = 1 [default=STRING]; + optional bool packed = 2; + optional JSType jstype = 6 [default=JS_NORMAL]; + optional bool lazy = 5; + optional bool deprecated = 3; + optional bool weak = 10; + repeated UninterpretedOption uninterpreted_option = 999; + + enum CType { + + STRING = 0; + CORD = 1; + STRING_PIECE = 2; + } + + enum JSType { + + JS_NORMAL = 0; + JS_STRING = 1; + JS_NUMBER = 2; + } + + extensions 1000 to max; + + reserved 4; +} + +message OneofOptions { + + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; +} + +message EnumOptions { + + optional bool allow_alias = 2; + optional bool deprecated = 3; + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; +} + +message EnumValueOptions { + + optional bool deprecated = 1; + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; +} + +message ServiceOptions { + + optional bool deprecated = 33; + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; +} + +message MethodOptions { + + optional bool deprecated = 33; + repeated UninterpretedOption uninterpreted_option = 999; + + extensions 1000 to max; +} + +message UninterpretedOption { + + repeated NamePart name = 2; + optional string identifier_value = 3; + optional uint64 positive_int_value = 4; + optional int64 negative_int_value = 5; + optional double double_value = 6; + optional bytes string_value = 7; + optional string aggregate_value = 8; + + message NamePart { + + required string name_part = 1; + required bool is_extension = 2; + } +} + +message SourceCodeInfo { + + repeated Location location = 1; + + message Location { + + repeated int32 path = 1 [packed=true]; + repeated int32 span = 2 [packed=true]; + optional string leading_comments = 3; + optional string trailing_comments = 4; + repeated string leading_detached_comments = 6; + } +} + +message GeneratedCodeInfo { + + repeated Annotation annotation = 1; + + message Annotation { + + repeated int32 path = 1 [packed=true]; + optional string source_file = 2; + optional int32 begin = 3; + optional int32 end = 4; + } +} diff --git a/node_modules/protobufjs/google/protobuf/source_context.json b/node_modules/protobufjs/google/protobuf/source_context.json new file mode 100644 index 0000000..51adb63 --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/source_context.json @@ -0,0 +1,20 @@ +{ + "nested": { + "google": { + "nested": { + "protobuf": { + "nested": { + "SourceContext": { + "fields": { + "fileName": { + "type": "string", + "id": 1 + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/source_context.proto b/node_modules/protobufjs/google/protobuf/source_context.proto new file mode 100644 index 0000000..584d36c --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/source_context.proto @@ -0,0 +1,7 @@ +syntax = "proto3"; + +package google.protobuf; + +message SourceContext { + string file_name = 1; +} diff --git a/node_modules/protobufjs/google/protobuf/type.json b/node_modules/protobufjs/google/protobuf/type.json new file mode 100644 index 0000000..fffa70d --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/type.json @@ -0,0 +1,202 @@ +{ + "nested": { + "google": { + "nested": { + "protobuf": { + "nested": { + "Type": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "fields": { + "rule": "repeated", + "type": "Field", + "id": 2 + }, + "oneofs": { + "rule": "repeated", + "type": "string", + "id": 3 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 4 + }, + "sourceContext": { + "type": "SourceContext", + "id": 5 + }, + "syntax": { + "type": "Syntax", + "id": 6 + } + } + }, + "Field": { + "fields": { + "kind": { + "type": "Kind", + "id": 1 + }, + "cardinality": { + "type": "Cardinality", + "id": 2 + }, + "number": { + "type": "int32", + "id": 3 + }, + "name": { + "type": "string", + "id": 4 + }, + "typeUrl": { + "type": "string", + "id": 6 + }, + "oneofIndex": { + "type": "int32", + "id": 7 + }, + "packed": { + "type": "bool", + "id": 8 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 9 + }, + "jsonName": { + "type": "string", + "id": 10 + }, + "defaultValue": { + "type": "string", + "id": 11 + } + }, + "nested": { + "Kind": { + "values": { + "TYPE_UNKNOWN": 0, + "TYPE_DOUBLE": 1, + "TYPE_FLOAT": 2, + "TYPE_INT64": 3, + "TYPE_UINT64": 4, + "TYPE_INT32": 5, + "TYPE_FIXED64": 6, + "TYPE_FIXED32": 7, + "TYPE_BOOL": 8, + "TYPE_STRING": 9, + "TYPE_GROUP": 10, + "TYPE_MESSAGE": 11, + "TYPE_BYTES": 12, + "TYPE_UINT32": 13, + "TYPE_ENUM": 14, + "TYPE_SFIXED32": 15, + "TYPE_SFIXED64": 16, + "TYPE_SINT32": 17, + "TYPE_SINT64": 18 + } + }, + "Cardinality": { + "values": { + "CARDINALITY_UNKNOWN": 0, + "CARDINALITY_OPTIONAL": 1, + "CARDINALITY_REQUIRED": 2, + "CARDINALITY_REPEATED": 3 + } + } + } + }, + "Enum": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "enumvalue": { + "rule": "repeated", + "type": "EnumValue", + "id": 2 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 3 + }, + "sourceContext": { + "type": "SourceContext", + "id": 4 + }, + "syntax": { + "type": "Syntax", + "id": 5 + } + } + }, + "EnumValue": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "number": { + "type": "int32", + "id": 2 + }, + "options": { + "rule": "repeated", + "type": "Option", + "id": 3 + } + } + }, + "Option": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "value": { + "type": "Any", + "id": 2 + } + } + }, + "Syntax": { + "values": { + "SYNTAX_PROTO2": 0, + "SYNTAX_PROTO3": 1 + } + }, + "Any": { + "fields": { + "type_url": { + "type": "string", + "id": 1 + }, + "value": { + "type": "bytes", + "id": 2 + } + } + }, + "SourceContext": { + "fields": { + "fileName": { + "type": "string", + "id": 1 + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/node_modules/protobufjs/google/protobuf/type.proto b/node_modules/protobufjs/google/protobuf/type.proto new file mode 100644 index 0000000..8ee445b --- /dev/null +++ b/node_modules/protobufjs/google/protobuf/type.proto @@ -0,0 +1,89 @@ +syntax = "proto3"; + +package google.protobuf; + +import "google/protobuf/any.proto"; +import "google/protobuf/source_context.proto"; + +message Type { + + string name = 1; + repeated Field fields = 2; + repeated string oneofs = 3; + repeated Option options = 4; + SourceContext source_context = 5; + Syntax syntax = 6; +} + +message Field { + + Kind kind = 1; + Cardinality cardinality = 2; + int32 number = 3; + string name = 4; + string type_url = 6; + int32 oneof_index = 7; + bool packed = 8; + repeated Option options = 9; + string json_name = 10; + string default_value = 11; + + enum Kind { + + TYPE_UNKNOWN = 0; + TYPE_DOUBLE = 1; + TYPE_FLOAT = 2; + TYPE_INT64 = 3; + TYPE_UINT64 = 4; + TYPE_INT32 = 5; + TYPE_FIXED64 = 6; + TYPE_FIXED32 = 7; + TYPE_BOOL = 8; + TYPE_STRING = 9; + TYPE_GROUP = 10; + TYPE_MESSAGE = 11; + TYPE_BYTES = 12; + TYPE_UINT32 = 13; + TYPE_ENUM = 14; + TYPE_SFIXED32 = 15; + TYPE_SFIXED64 = 16; + TYPE_SINT32 = 17; + TYPE_SINT64 = 18; + } + + enum Cardinality { + + CARDINALITY_UNKNOWN = 0; + CARDINALITY_OPTIONAL = 1; + CARDINALITY_REQUIRED = 2; + CARDINALITY_REPEATED = 3; + } +} + +message Enum { + + string name = 1; + repeated EnumValue enumvalue = 2; + repeated Option options = 3; + SourceContext source_context = 4; + Syntax syntax = 5; +} + +message EnumValue { + + string name = 1; + int32 number = 2; + repeated Option options = 3; +} + +message Option { + + string name = 1; + Any value = 2; +} + +enum Syntax { + + SYNTAX_PROTO2 = 0; + SYNTAX_PROTO3 = 1; +} diff --git a/node_modules/protobufjs/index.d.ts b/node_modules/protobufjs/index.d.ts new file mode 100644 index 0000000..e65d5ff --- /dev/null +++ b/node_modules/protobufjs/index.d.ts @@ -0,0 +1,2694 @@ +// DO NOT EDIT! This is a generated file. Edit the JSDoc in src/*.js instead and run 'npm run types'. + +export as namespace protobuf; + +/** + * Provides common type definitions. + * Can also be used to provide additional google types or your own custom types. + * @param name Short name as in `google/protobuf/[name].proto` or full file name + * @param json JSON definition within `google.protobuf` if a short name, otherwise the file's root definition + */ +export function common(name: string, json: { [k: string]: any }): void; + +export namespace common { + + /** Properties of a google.protobuf.Any message. */ + interface IAny { + typeUrl?: string; + bytes?: Uint8Array; + } + + /** Properties of a google.protobuf.Duration message. */ + interface IDuration { + seconds?: (number|Long); + nanos?: number; + } + + /** Properties of a google.protobuf.Timestamp message. */ + interface ITimestamp { + seconds?: (number|Long); + nanos?: number; + } + + /** Properties of a google.protobuf.Empty message. */ + interface IEmpty { + } + + /** Properties of a google.protobuf.Struct message. */ + interface IStruct { + fields?: { [k: string]: IValue }; + } + + /** Properties of a google.protobuf.Value message. */ + interface IValue { + kind?: string; + nullValue?: 0; + numberValue?: number; + stringValue?: string; + boolValue?: boolean; + structValue?: IStruct; + listValue?: IListValue; + } + + /** Properties of a google.protobuf.ListValue message. */ + interface IListValue { + values?: IValue[]; + } + + /** Properties of a google.protobuf.DoubleValue message. */ + interface IDoubleValue { + value?: number; + } + + /** Properties of a google.protobuf.FloatValue message. */ + interface IFloatValue { + value?: number; + } + + /** Properties of a google.protobuf.Int64Value message. */ + interface IInt64Value { + value?: (number|Long); + } + + /** Properties of a google.protobuf.UInt64Value message. */ + interface IUInt64Value { + value?: (number|Long); + } + + /** Properties of a google.protobuf.Int32Value message. */ + interface IInt32Value { + value?: number; + } + + /** Properties of a google.protobuf.UInt32Value message. */ + interface IUInt32Value { + value?: number; + } + + /** Properties of a google.protobuf.BoolValue message. */ + interface IBoolValue { + value?: boolean; + } + + /** Properties of a google.protobuf.StringValue message. */ + interface IStringValue { + value?: string; + } + + /** Properties of a google.protobuf.BytesValue message. */ + interface IBytesValue { + value?: Uint8Array; + } + + /** + * Gets the root definition of the specified common proto file. + * + * Bundled definitions are: + * - google/protobuf/any.proto + * - google/protobuf/duration.proto + * - google/protobuf/empty.proto + * - google/protobuf/field_mask.proto + * - google/protobuf/struct.proto + * - google/protobuf/timestamp.proto + * - google/protobuf/wrappers.proto + * + * @param file Proto file name + * @returns Root definition or `null` if not defined + */ + function get(file: string): (INamespace|null); +} + +/** Runtime message from/to plain object converters. */ +export namespace converter { + + /** + * Generates a plain object to runtime message converter specific to the specified message type. + * @param mtype Message type + * @returns Codegen instance + */ + function fromObject(mtype: Type): Codegen; + + /** + * Generates a runtime message to plain object converter specific to the specified message type. + * @param mtype Message type + * @returns Codegen instance + */ + function toObject(mtype: Type): Codegen; +} + +/** + * Generates a decoder specific to the specified message type. + * @param mtype Message type + * @returns Codegen instance + */ +export function decoder(mtype: Type): Codegen; + +/** + * Generates an encoder specific to the specified message type. + * @param mtype Message type + * @returns Codegen instance + */ +export function encoder(mtype: Type): Codegen; + +/** Reflected enum. */ +export class Enum extends ReflectionObject { + + /** + * Constructs a new enum instance. + * @param name Unique name within its namespace + * @param [values] Enum values as an object, by name + * @param [options] Declared options + * @param [comment] The comment for this enum + * @param [comments] The value comments for this enum + */ + constructor(name: string, values?: { [k: string]: number }, options?: { [k: string]: any }, comment?: string, comments?: { [k: string]: string }); + + /** Enum values by id. */ + public valuesById: { [k: number]: string }; + + /** Enum values by name. */ + public values: { [k: string]: number }; + + /** Enum comment text. */ + public comment: (string|null); + + /** Value comment texts, if any. */ + public comments: { [k: string]: string }; + + /** Reserved ranges, if any. */ + public reserved: (number[]|string)[]; + + /** + * Constructs an enum from an enum descriptor. + * @param name Enum name + * @param json Enum descriptor + * @returns Created enum + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IEnum): Enum; + + /** + * Converts this enum to an enum descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Enum descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IEnum; + + /** + * Adds a value to this enum. + * @param name Value name + * @param id Value id + * @param [comment] Comment, if any + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a value with this name or id + */ + public add(name: string, id: number, comment?: string): Enum; + + /** + * Removes a value from this enum + * @param name Value name + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `name` is not a name of this enum + */ + public remove(name: string): Enum; + + /** + * Tests if the specified id is reserved. + * @param id Id to test + * @returns `true` if reserved, otherwise `false` + */ + public isReservedId(id: number): boolean; + + /** + * Tests if the specified name is reserved. + * @param name Name to test + * @returns `true` if reserved, otherwise `false` + */ + public isReservedName(name: string): boolean; +} + +/** Enum descriptor. */ +export interface IEnum { + + /** Enum values */ + values: { [k: string]: number }; + + /** Enum options */ + options?: { [k: string]: any }; +} + +/** Reflected message field. */ +export class Field extends FieldBase { + + /** + * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class. + * @param name Unique name within its namespace + * @param id Unique id within its namespace + * @param type Value type + * @param [rule="optional"] Field rule + * @param [extend] Extended type if different from parent + * @param [options] Declared options + */ + constructor(name: string, id: number, type: string, rule?: (string|{ [k: string]: any }), extend?: (string|{ [k: string]: any }), options?: { [k: string]: any }); + + /** + * Constructs a field from a field descriptor. + * @param name Field name + * @param json Field descriptor + * @returns Created field + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IField): Field; + + /** Determines whether this field is packed. Only relevant when repeated and working with proto2. */ + public readonly packed: boolean; + + /** + * Field decorator (TypeScript). + * @param fieldId Field id + * @param fieldType Field type + * @param [fieldRule="optional"] Field rule + * @param [defaultValue] Default value + * @returns Decorator function + */ + public static d(fieldId: number, fieldType: ("double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|object), fieldRule?: ("optional"|"required"|"repeated"), defaultValue?: T): FieldDecorator; + + /** + * Field decorator (TypeScript). + * @param fieldId Field id + * @param fieldType Field type + * @param [fieldRule="optional"] Field rule + * @returns Decorator function + */ + public static d>(fieldId: number, fieldType: (Constructor|string), fieldRule?: ("optional"|"required"|"repeated")): FieldDecorator; +} + +/** Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions. */ +export class FieldBase extends ReflectionObject { + + /** + * Not an actual constructor. Use {@link Field} instead. + * @param name Unique name within its namespace + * @param id Unique id within its namespace + * @param type Value type + * @param [rule="optional"] Field rule + * @param [extend] Extended type if different from parent + * @param [options] Declared options + * @param [comment] Comment associated with this field + */ + constructor(name: string, id: number, type: string, rule?: (string|{ [k: string]: any }), extend?: (string|{ [k: string]: any }), options?: { [k: string]: any }, comment?: string); + + /** Field rule, if any. */ + public rule?: string; + + /** Field type. */ + public type: string; + + /** Unique field id. */ + public id: number; + + /** Extended type if different from parent. */ + public extend?: string; + + /** Whether this field is required. */ + public required: boolean; + + /** Whether this field is optional. */ + public optional: boolean; + + /** Whether this field is repeated. */ + public repeated: boolean; + + /** Whether this field is a map or not. */ + public map: boolean; + + /** Message this field belongs to. */ + public message: (Type|null); + + /** OneOf this field belongs to, if any, */ + public partOf: (OneOf|null); + + /** The field type's default value. */ + public typeDefault: any; + + /** The field's default value on prototypes. */ + public defaultValue: any; + + /** Whether this field's value should be treated as a long. */ + public long: boolean; + + /** Whether this field's value is a buffer. */ + public bytes: boolean; + + /** Resolved type if not a basic type. */ + public resolvedType: (Type|Enum|null); + + /** Sister-field within the extended type if a declaring extension field. */ + public extensionField: (Field|null); + + /** Sister-field within the declaring namespace if an extended field. */ + public declaringField: (Field|null); + + /** Comment for this field. */ + public comment: (string|null); + + /** + * Converts this field to a field descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Field descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IField; + + /** + * Resolves this field's type references. + * @returns `this` + * @throws {Error} If any reference cannot be resolved + */ + public resolve(): Field; +} + +/** Field descriptor. */ +export interface IField { + + /** Field rule */ + rule?: string; + + /** Field type */ + type: string; + + /** Field id */ + id: number; + + /** Field options */ + options?: { [k: string]: any }; +} + +/** Extension field descriptor. */ +export interface IExtensionField extends IField { + + /** Extended type */ + extend: string; +} + +/** + * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript). + * @param prototype Target prototype + * @param fieldName Field name + */ +type FieldDecorator = (prototype: object, fieldName: string) => void; + +/** + * A node-style callback as used by {@link load} and {@link Root#load}. + * @param error Error, if any, otherwise `null` + * @param [root] Root, if there hasn't been an error + */ +type LoadCallback = (error: (Error|null), root?: Root) => void; + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @param filename One or multiple files to load + * @param root Root namespace, defaults to create a new one if omitted. + * @param callback Callback function + * @see {@link Root#load} + */ +export function load(filename: (string|string[]), root: Root, callback: LoadCallback): void; + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @param filename One or multiple files to load + * @param callback Callback function + * @see {@link Root#load} + */ +export function load(filename: (string|string[]), callback: LoadCallback): void; + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise. + * @param filename One or multiple files to load + * @param [root] Root namespace, defaults to create a new one if omitted. + * @returns Promise + * @see {@link Root#load} + */ +export function load(filename: (string|string[]), root?: Root): Promise; + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only). + * @param filename One or multiple files to load + * @param [root] Root namespace, defaults to create a new one if omitted. + * @returns Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + * @see {@link Root#loadSync} + */ +export function loadSync(filename: (string|string[]), root?: Root): Root; + +/** Build type, one of `"full"`, `"light"` or `"minimal"`. */ +export const build: string; + +/** Reconfigures the library according to the environment. */ +export function configure(): void; + +/** Reflected map field. */ +export class MapField extends FieldBase { + + /** + * Constructs a new map field instance. + * @param name Unique name within its namespace + * @param id Unique id within its namespace + * @param keyType Key type + * @param type Value type + * @param [options] Declared options + * @param [comment] Comment associated with this field + */ + constructor(name: string, id: number, keyType: string, type: string, options?: { [k: string]: any }, comment?: string); + + /** Key type. */ + public keyType: string; + + /** Resolved key type if not a basic type. */ + public resolvedKeyType: (ReflectionObject|null); + + /** + * Constructs a map field from a map field descriptor. + * @param name Field name + * @param json Map field descriptor + * @returns Created map field + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IMapField): MapField; + + /** + * Converts this map field to a map field descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Map field descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IMapField; + + /** + * Map field decorator (TypeScript). + * @param fieldId Field id + * @param fieldKeyType Field key type + * @param fieldValueType Field value type + * @returns Decorator function + */ + public static d }>(fieldId: number, fieldKeyType: ("int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"), fieldValueType: ("double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"|"bytes"|object|Constructor<{}>)): FieldDecorator; +} + +/** Map field descriptor. */ +export interface IMapField extends IField { + + /** Key type */ + keyType: string; +} + +/** Extension map field descriptor. */ +export interface IExtensionMapField extends IMapField { + + /** Extended type */ + extend: string; +} + +/** Abstract runtime message. */ +export class Message { + + /** + * Constructs a new message instance. + * @param [properties] Properties to set + */ + constructor(properties?: Properties); + + /** Reference to the reflected type. */ + public static readonly $type: Type; + + /** Reference to the reflected type. */ + public readonly $type: Type; + + /** + * Creates a new message of this type using the specified properties. + * @param [properties] Properties to set + * @returns Message instance + */ + public static create>(this: Constructor, properties?: { [k: string]: any }): Message; + + /** + * Encodes a message of this type. + * @param message Message to encode + * @param [writer] Writer to use + * @returns Writer + */ + public static encode>(this: Constructor, message: (T|{ [k: string]: any }), writer?: Writer): Writer; + + /** + * Encodes a message of this type preceeded by its length as a varint. + * @param message Message to encode + * @param [writer] Writer to use + * @returns Writer + */ + public static encodeDelimited>(this: Constructor, message: (T|{ [k: string]: any }), writer?: Writer): Writer; + + /** + * Decodes a message of this type. + * @param reader Reader or buffer to decode + * @returns Decoded message + */ + public static decode>(this: Constructor, reader: (Reader|Uint8Array)): T; + + /** + * Decodes a message of this type preceeded by its length as a varint. + * @param reader Reader or buffer to decode + * @returns Decoded message + */ + public static decodeDelimited>(this: Constructor, reader: (Reader|Uint8Array)): T; + + /** + * Verifies a message of this type. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Message instance + */ + public static fromObject>(this: Constructor, object: { [k: string]: any }): T; + + /** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param message Message instance + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject>(this: Constructor, message: T, options?: IConversionOptions): { [k: string]: any }; + + /** + * Converts this message to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; +} + +/** Reflected service method. */ +export class Method extends ReflectionObject { + + /** + * Constructs a new service method instance. + * @param name Method name + * @param type Method type, usually `"rpc"` + * @param requestType Request message type + * @param responseType Response message type + * @param [requestStream] Whether the request is streamed + * @param [responseStream] Whether the response is streamed + * @param [options] Declared options + * @param [comment] The comment for this method + */ + constructor(name: string, type: (string|undefined), requestType: string, responseType: string, requestStream?: (boolean|{ [k: string]: any }), responseStream?: (boolean|{ [k: string]: any }), options?: { [k: string]: any }, comment?: string); + + /** Method type. */ + public type: string; + + /** Request type. */ + public requestType: string; + + /** Whether requests are streamed or not. */ + public requestStream?: boolean; + + /** Response type. */ + public responseType: string; + + /** Whether responses are streamed or not. */ + public responseStream?: boolean; + + /** Resolved request type. */ + public resolvedRequestType: (Type|null); + + /** Resolved response type. */ + public resolvedResponseType: (Type|null); + + /** Comment for this method */ + public comment: (string|null); + + /** + * Constructs a method from a method descriptor. + * @param name Method name + * @param json Method descriptor + * @returns Created method + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IMethod): Method; + + /** + * Converts this method to a method descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Method descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IMethod; +} + +/** Method descriptor. */ +export interface IMethod { + + /** Method type */ + type?: string; + + /** Request type */ + requestType: string; + + /** Response type */ + responseType: string; + + /** Whether requests are streamed */ + requestStream?: boolean; + + /** Whether responses are streamed */ + responseStream?: boolean; + + /** Method options */ + options?: { [k: string]: any }; +} + +/** Reflected namespace. */ +export class Namespace extends NamespaceBase { + + /** + * Constructs a new namespace instance. + * @param name Namespace name + * @param [options] Declared options + */ + constructor(name: string, options?: { [k: string]: any }); + + /** + * Constructs a namespace from JSON. + * @param name Namespace name + * @param json JSON object + * @returns Created namespace + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: { [k: string]: any }): Namespace; + + /** + * Converts an array of reflection objects to JSON. + * @param array Object array + * @param [toJSONOptions] JSON conversion options + * @returns JSON object or `undefined` when array is empty + */ + public static arrayToJSON(array: ReflectionObject[], toJSONOptions?: IToJSONOptions): ({ [k: string]: any }|undefined); + + /** + * Tests if the specified id is reserved. + * @param reserved Array of reserved ranges and names + * @param id Id to test + * @returns `true` if reserved, otherwise `false` + */ + public static isReservedId(reserved: ((number[]|string)[]|undefined), id: number): boolean; + + /** + * Tests if the specified name is reserved. + * @param reserved Array of reserved ranges and names + * @param name Name to test + * @returns `true` if reserved, otherwise `false` + */ + public static isReservedName(reserved: ((number[]|string)[]|undefined), name: string): boolean; +} + +/** Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions. */ +export abstract class NamespaceBase extends ReflectionObject { + + /** Nested objects by name. */ + public nested?: { [k: string]: ReflectionObject }; + + /** Nested objects of this namespace as an array for iteration. */ + public readonly nestedArray: ReflectionObject[]; + + /** + * Converts this namespace to a namespace descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Namespace descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): INamespace; + + /** + * Adds nested objects to this namespace from nested object descriptors. + * @param nestedJson Any nested object descriptors + * @returns `this` + */ + public addJSON(nestedJson: { [k: string]: AnyNestedObject }): Namespace; + + /** + * Gets the nested object of the specified name. + * @param name Nested object name + * @returns The reflection object or `null` if it doesn't exist + */ + public get(name: string): (ReflectionObject|null); + + /** + * Gets the values of the nested {@link Enum|enum} of the specified name. + * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`. + * @param name Nested enum name + * @returns Enum values + * @throws {Error} If there is no such enum + */ + public getEnum(name: string): { [k: string]: number }; + + /** + * Adds a nested object to this namespace. + * @param object Nested object to add + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name + */ + public add(object: ReflectionObject): Namespace; + + /** + * Removes a nested object from this namespace. + * @param object Nested object to remove + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this namespace + */ + public remove(object: ReflectionObject): Namespace; + + /** + * Defines additial namespaces within this one if not yet existing. + * @param path Path to create + * @param [json] Nested types to create from JSON + * @returns Pointer to the last namespace created or `this` if path is empty + */ + public define(path: (string|string[]), json?: any): Namespace; + + /** + * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost. + * @returns `this` + */ + public resolveAll(): Namespace; + + /** + * Recursively looks up the reflection object matching the specified path in the scope of this namespace. + * @param path Path to look up + * @param filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc. + * @param [parentAlreadyChecked=false] If known, whether the parent has already been checked + * @returns Looked up object or `null` if none could be found + */ + public lookup(path: (string|string[]), filterTypes: (any|any[]), parentAlreadyChecked?: boolean): (ReflectionObject|null); + + /** + * Looks up the reflection object at the specified path, relative to this namespace. + * @param path Path to look up + * @param [parentAlreadyChecked=false] Whether the parent has already been checked + * @returns Looked up object or `null` if none could be found + */ + public lookup(path: (string|string[]), parentAlreadyChecked?: boolean): (ReflectionObject|null); + + /** + * Looks up the {@link Type|type} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param path Path to look up + * @returns Looked up type + * @throws {Error} If `path` does not point to a type + */ + public lookupType(path: (string|string[])): Type; + + /** + * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param path Path to look up + * @returns Looked up enum + * @throws {Error} If `path` does not point to an enum + */ + public lookupEnum(path: (string|string[])): Enum; + + /** + * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param path Path to look up + * @returns Looked up type or enum + * @throws {Error} If `path` does not point to a type or enum + */ + public lookupTypeOrEnum(path: (string|string[])): Type; + + /** + * Looks up the {@link Service|service} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param path Path to look up + * @returns Looked up service + * @throws {Error} If `path` does not point to a service + */ + public lookupService(path: (string|string[])): Service; +} + +/** Namespace descriptor. */ +export interface INamespace { + + /** Namespace options */ + options?: { [k: string]: any }; + + /** Nested object descriptors */ + nested?: { [k: string]: AnyNestedObject }; +} + +/** Any extension field descriptor. */ +type AnyExtensionField = (IExtensionField|IExtensionMapField); + +/** Any nested object descriptor. */ +type AnyNestedObject = (IEnum|IType|IService|AnyExtensionField|INamespace); + +/** Base class of all reflection objects. */ +export abstract class ReflectionObject { + + /** Options. */ + public options?: { [k: string]: any }; + + /** Unique name within its namespace. */ + public name: string; + + /** Parent namespace. */ + public parent: (Namespace|null); + + /** Whether already resolved or not. */ + public resolved: boolean; + + /** Comment text, if any. */ + public comment: (string|null); + + /** Defining file name. */ + public filename: (string|null); + + /** Reference to the root namespace. */ + public readonly root: Root; + + /** Full name including leading dot. */ + public readonly fullName: string; + + /** + * Converts this reflection object to its descriptor representation. + * @returns Descriptor + */ + public toJSON(): { [k: string]: any }; + + /** + * Called when this object is added to a parent. + * @param parent Parent added to + */ + public onAdd(parent: ReflectionObject): void; + + /** + * Called when this object is removed from a parent. + * @param parent Parent removed from + */ + public onRemove(parent: ReflectionObject): void; + + /** + * Resolves this objects type references. + * @returns `this` + */ + public resolve(): ReflectionObject; + + /** + * Gets an option value. + * @param name Option name + * @returns Option value or `undefined` if not set + */ + public getOption(name: string): any; + + /** + * Sets an option. + * @param name Option name + * @param value Option value + * @param [ifNotSet] Sets the option only if it isn't currently set + * @returns `this` + */ + public setOption(name: string, value: any, ifNotSet?: boolean): ReflectionObject; + + /** + * Sets multiple options. + * @param options Options to set + * @param [ifNotSet] Sets an option only if it isn't currently set + * @returns `this` + */ + public setOptions(options: { [k: string]: any }, ifNotSet?: boolean): ReflectionObject; + + /** + * Converts this instance to its string representation. + * @returns Class name[, space, full name] + */ + public toString(): string; +} + +/** Reflected oneof. */ +export class OneOf extends ReflectionObject { + + /** + * Constructs a new oneof instance. + * @param name Oneof name + * @param [fieldNames] Field names + * @param [options] Declared options + * @param [comment] Comment associated with this field + */ + constructor(name: string, fieldNames?: (string[]|{ [k: string]: any }), options?: { [k: string]: any }, comment?: string); + + /** Field names that belong to this oneof. */ + public oneof: string[]; + + /** Fields that belong to this oneof as an array for iteration. */ + public readonly fieldsArray: Field[]; + + /** Comment for this field. */ + public comment: (string|null); + + /** + * Constructs a oneof from a oneof descriptor. + * @param name Oneof name + * @param json Oneof descriptor + * @returns Created oneof + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IOneOf): OneOf; + + /** + * Converts this oneof to a oneof descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Oneof descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IOneOf; + + /** + * Adds a field to this oneof and removes it from its current parent, if any. + * @param field Field to add + * @returns `this` + */ + public add(field: Field): OneOf; + + /** + * Removes a field from this oneof and puts it back to the oneof's parent. + * @param field Field to remove + * @returns `this` + */ + public remove(field: Field): OneOf; + + /** + * OneOf decorator (TypeScript). + * @param fieldNames Field names + * @returns Decorator function + */ + public static d(...fieldNames: string[]): OneOfDecorator; +} + +/** Oneof descriptor. */ +export interface IOneOf { + + /** Oneof field names */ + oneof: string[]; + + /** Oneof options */ + options?: { [k: string]: any }; +} + +/** + * Decorator function as returned by {@link OneOf.d} (TypeScript). + * @param prototype Target prototype + * @param oneofName OneOf name + */ +type OneOfDecorator = (prototype: object, oneofName: string) => void; + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @param source Source contents + * @param [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns Parser result + */ +export function parse(source: string, options?: IParseOptions): IParserResult; + +/** Result object returned from {@link parse}. */ +export interface IParserResult { + + /** Package name, if declared */ + package: (string|undefined); + + /** Imports, if any */ + imports: (string[]|undefined); + + /** Weak imports, if any */ + weakImports: (string[]|undefined); + + /** Syntax, if specified (either `"proto2"` or `"proto3"`) */ + syntax: (string|undefined); + + /** Populated root instance */ + root: Root; +} + +/** Options modifying the behavior of {@link parse}. */ +export interface IParseOptions { + + /** Keeps field casing instead of converting to camel case */ + keepCase?: boolean; + + /** Recognize double-slash comments in addition to doc-block comments. */ + alternateCommentMode?: boolean; +} + +/** Options modifying the behavior of JSON serialization. */ +export interface IToJSONOptions { + + /** Serializes comments. */ + keepComments?: boolean; +} + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @param source Source contents + * @param root Root to populate + * @param [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns Parser result + */ +export function parse(source: string, root: Root, options?: IParseOptions): IParserResult; + +/** Wire format reader using `Uint8Array` if available, otherwise `Array`. */ +export class Reader { + + /** + * Constructs a new reader instance using the specified buffer. + * @param buffer Buffer to read from + */ + constructor(buffer: Uint8Array); + + /** Read buffer. */ + public buf: Uint8Array; + + /** Read buffer position. */ + public pos: number; + + /** Read buffer length. */ + public len: number; + + /** + * Creates a new reader using the specified buffer. + * @param buffer Buffer to read from + * @returns A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ + public static create(buffer: (Uint8Array|Buffer)): (Reader|BufferReader); + + /** + * Reads a varint as an unsigned 32 bit value. + * @returns Value read + */ + public uint32(): number; + + /** + * Reads a varint as a signed 32 bit value. + * @returns Value read + */ + public int32(): number; + + /** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns Value read + */ + public sint32(): number; + + /** + * Reads a varint as a signed 64 bit value. + * @returns Value read + */ + public int64(): Long; + + /** + * Reads a varint as an unsigned 64 bit value. + * @returns Value read + */ + public uint64(): Long; + + /** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @returns Value read + */ + public sint64(): Long; + + /** + * Reads a varint as a boolean. + * @returns Value read + */ + public bool(): boolean; + + /** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns Value read + */ + public fixed32(): number; + + /** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns Value read + */ + public sfixed32(): number; + + /** + * Reads fixed 64 bits. + * @returns Value read + */ + public fixed64(): Long; + + /** + * Reads zig-zag encoded fixed 64 bits. + * @returns Value read + */ + public sfixed64(): Long; + + /** + * Reads a float (32 bit) as a number. + * @returns Value read + */ + public float(): number; + + /** + * Reads a double (64 bit float) as a number. + * @returns Value read + */ + public double(): number; + + /** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns Value read + */ + public bytes(): Uint8Array; + + /** + * Reads a string preceeded by its byte length as a varint. + * @returns Value read + */ + public string(): string; + + /** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param [length] Length if known, otherwise a varint is assumed + * @returns `this` + */ + public skip(length?: number): Reader; + + /** + * Skips the next element of the specified wire type. + * @param wireType Wire type received + * @returns `this` + */ + public skipType(wireType: number): Reader; +} + +/** Wire format reader using node buffers. */ +export class BufferReader extends Reader { + + /** + * Constructs a new buffer reader instance. + * @param buffer Buffer to read from + */ + constructor(buffer: Buffer); + + /** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns Value read + */ + public bytes(): Buffer; +} + +/** Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together. */ +export class Root extends NamespaceBase { + + /** + * Constructs a new root namespace instance. + * @param [options] Top level options + */ + constructor(options?: { [k: string]: any }); + + /** Deferred extension fields. */ + public deferred: Field[]; + + /** Resolved file names of loaded files. */ + public files: string[]; + + /** + * Loads a namespace descriptor into a root namespace. + * @param json Nameespace descriptor + * @param [root] Root namespace, defaults to create a new one if omitted + * @returns Root namespace + */ + public static fromJSON(json: INamespace, root?: Root): Root; + + /** + * Resolves the path of an imported file, relative to the importing origin. + * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories. + * @param origin The file name of the importing file + * @param target The file name being imported + * @returns Resolved path to `target` or `null` to skip the file + */ + public resolvePath(origin: string, target: string): (string|null); + + /** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @param filename Names of one or multiple files to load + * @param options Parse options + * @param callback Callback function + */ + public load(filename: (string|string[]), options: IParseOptions, callback: LoadCallback): void; + + /** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @param filename Names of one or multiple files to load + * @param callback Callback function + */ + public load(filename: (string|string[]), callback: LoadCallback): void; + + /** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise. + * @param filename Names of one or multiple files to load + * @param [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns Promise + */ + public load(filename: (string|string[]), options?: IParseOptions): Promise; + + /** + * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only). + * @param filename Names of one or multiple files to load + * @param [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + */ + public loadSync(filename: (string|string[]), options?: IParseOptions): Root; +} + +/** + * Named roots. + * This is where pbjs stores generated structures (the option `-r, --root` specifies a name). + * Can also be used manually to make roots available accross modules. + */ +export let roots: { [k: string]: Root }; + +/** Streaming RPC helpers. */ +export namespace rpc { + + /** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @param error Error, if any + * @param [response] Response message + */ + type ServiceMethodCallback> = (error: (Error|null), response?: TRes) => void; + + /** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @param request Request message or plain object + * @param [callback] Node-style callback called with the error, if any, and the response message + * @returns Promise if `callback` has been omitted, otherwise `undefined` + */ + type ServiceMethod, TRes extends Message> = (request: (TReq|Properties), callback?: rpc.ServiceMethodCallback) => Promise>; + + /** An RPC service as returned by {@link Service#create}. */ + class Service extends util.EventEmitter { + + /** + * Constructs a new RPC service instance. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + */ + constructor(rpcImpl: RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean); + + /** RPC implementation. Becomes `null` once the service is ended. */ + public rpcImpl: (RPCImpl|null); + + /** Whether requests are length-delimited. */ + public requestDelimited: boolean; + + /** Whether responses are length-delimited. */ + public responseDelimited: boolean; + + /** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param method Reflected or static method + * @param requestCtor Request constructor + * @param responseCtor Response constructor + * @param request Request message or plain object + * @param callback Service callback + */ + public rpcCall, TRes extends Message>(method: (Method|rpc.ServiceMethod), requestCtor: Constructor, responseCtor: Constructor, request: (TReq|Properties), callback: rpc.ServiceMethodCallback): void; + + /** + * Ends this service and emits the `end` event. + * @param [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns `this` + */ + public end(endedByRPC?: boolean): rpc.Service; + } +} + +/** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @param method Reflected or static method being called + * @param requestData Request data + * @param callback Callback function + */ +type RPCImpl = (method: (Method|rpc.ServiceMethod, Message<{}>>), requestData: Uint8Array, callback: RPCImplCallback) => void; + +/** + * Node-style callback as used by {@link RPCImpl}. + * @param error Error, if any, otherwise `null` + * @param [response] Response data or `null` to signal end of stream, if there hasn't been an error + */ +type RPCImplCallback = (error: (Error|null), response?: (Uint8Array|null)) => void; + +/** Reflected service. */ +export class Service extends NamespaceBase { + + /** + * Constructs a new service instance. + * @param name Service name + * @param [options] Service options + * @throws {TypeError} If arguments are invalid + */ + constructor(name: string, options?: { [k: string]: any }); + + /** Service methods. */ + public methods: { [k: string]: Method }; + + /** + * Constructs a service from a service descriptor. + * @param name Service name + * @param json Service descriptor + * @returns Created service + * @throws {TypeError} If arguments are invalid + */ + public static fromJSON(name: string, json: IService): Service; + + /** + * Converts this service to a service descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Service descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IService; + + /** Methods of this service as an array for iteration. */ + public readonly methodsArray: Method[]; + + /** + * Creates a runtime service using the specified rpc implementation. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + * @returns RPC service. Useful where requests and/or responses are streamed. + */ + public create(rpcImpl: RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean): rpc.Service; +} + +/** Service descriptor. */ +export interface IService extends INamespace { + + /** Method descriptors */ + methods: { [k: string]: IMethod }; +} + +/** + * Gets the next token and advances. + * @returns Next token or `null` on eof + */ +type TokenizerHandleNext = () => (string|null); + +/** + * Peeks for the next token. + * @returns Next token or `null` on eof + */ +type TokenizerHandlePeek = () => (string|null); + +/** + * Pushes a token back to the stack. + * @param token Token + */ +type TokenizerHandlePush = (token: string) => void; + +/** + * Skips the next token. + * @param expected Expected token + * @param [optional=false] If optional + * @returns Whether the token matched + * @throws {Error} If the token didn't match and is not optional + */ +type TokenizerHandleSkip = (expected: string, optional?: boolean) => boolean; + +/** + * Gets the comment on the previous line or, alternatively, the line comment on the specified line. + * @param [line] Line number + * @returns Comment text or `null` if none + */ +type TokenizerHandleCmnt = (line?: number) => (string|null); + +/** Handle object returned from {@link tokenize}. */ +export interface ITokenizerHandle { + + /** Gets the next token and advances (`null` on eof) */ + next: TokenizerHandleNext; + + /** Peeks for the next token (`null` on eof) */ + peek: TokenizerHandlePeek; + + /** Pushes a token back to the stack */ + push: TokenizerHandlePush; + + /** Skips a token, returns its presence and advances or, if non-optional and not present, throws */ + skip: TokenizerHandleSkip; + + /** Gets the comment on the previous line or the line comment on the specified line, if any */ + cmnt: TokenizerHandleCmnt; + + /** Current line number */ + line: number; +} + +/** + * Tokenizes the given .proto source and returns an object with useful utility functions. + * @param source Source contents + * @param alternateCommentMode Whether we should activate alternate comment parsing mode. + * @returns Tokenizer handle + */ +export function tokenize(source: string, alternateCommentMode: boolean): ITokenizerHandle; + +export namespace tokenize { + + /** + * Unescapes a string. + * @param str String to unescape + * @returns Unescaped string + */ + function unescape(str: string): string; +} + +/** Reflected message type. */ +export class Type extends NamespaceBase { + + /** + * Constructs a new reflected message type instance. + * @param name Message name + * @param [options] Declared options + */ + constructor(name: string, options?: { [k: string]: any }); + + /** Message fields. */ + public fields: { [k: string]: Field }; + + /** Oneofs declared within this namespace, if any. */ + public oneofs: { [k: string]: OneOf }; + + /** Extension ranges, if any. */ + public extensions: number[][]; + + /** Reserved ranges, if any. */ + public reserved: (number[]|string)[]; + + /** Message fields by id. */ + public readonly fieldsById: { [k: number]: Field }; + + /** Fields of this message as an array for iteration. */ + public readonly fieldsArray: Field[]; + + /** Oneofs of this message as an array for iteration. */ + public readonly oneofsArray: OneOf[]; + + /** + * The registered constructor, if any registered, otherwise a generic constructor. + * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor. + */ + public ctor: Constructor<{}>; + + /** + * Generates a constructor function for the specified type. + * @param mtype Message type + * @returns Codegen instance + */ + public static generateConstructor(mtype: Type): Codegen; + + /** + * Creates a message type from a message type descriptor. + * @param name Message name + * @param json Message type descriptor + * @returns Created message type + */ + public static fromJSON(name: string, json: IType): Type; + + /** + * Converts this message type to a message type descriptor. + * @param [toJSONOptions] JSON conversion options + * @returns Message type descriptor + */ + public toJSON(toJSONOptions?: IToJSONOptions): IType; + + /** + * Adds a nested object to this type. + * @param object Nested object to add + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id + */ + public add(object: ReflectionObject): Type; + + /** + * Removes a nested object from this type. + * @param object Nested object to remove + * @returns `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this type + */ + public remove(object: ReflectionObject): Type; + + /** + * Tests if the specified id is reserved. + * @param id Id to test + * @returns `true` if reserved, otherwise `false` + */ + public isReservedId(id: number): boolean; + + /** + * Tests if the specified name is reserved. + * @param name Name to test + * @returns `true` if reserved, otherwise `false` + */ + public isReservedName(name: string): boolean; + + /** + * Creates a new message of this type using the specified properties. + * @param [properties] Properties to set + * @returns Message instance + */ + public create(properties?: { [k: string]: any }): Message<{}>; + + /** + * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}. + * @returns `this` + */ + public setup(): Type; + + /** + * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages. + * @param message Message instance or plain object + * @param [writer] Writer to encode to + * @returns writer + */ + public encode(message: (Message<{}>|{ [k: string]: any }), writer?: Writer): Writer; + + /** + * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages. + * @param message Message instance or plain object + * @param [writer] Writer to encode to + * @returns writer + */ + public encodeDelimited(message: (Message<{}>|{ [k: string]: any }), writer?: Writer): Writer; + + /** + * Decodes a message of this type. + * @param reader Reader or buffer to decode from + * @param [length] Length of the message, if known beforehand + * @returns Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError<{}>} If required fields are missing + */ + public decode(reader: (Reader|Uint8Array), length?: number): Message<{}>; + + /** + * Decodes a message of this type preceeded by its byte length as a varint. + * @param reader Reader or buffer to decode from + * @returns Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError} If required fields are missing + */ + public decodeDelimited(reader: (Reader|Uint8Array)): Message<{}>; + + /** + * Verifies that field values are valid and that required fields are present. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public verify(message: { [k: string]: any }): (null|string); + + /** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param object Plain object to convert + * @returns Message instance + */ + public fromObject(object: { [k: string]: any }): Message<{}>; + + /** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param message Message instance + * @param [options] Conversion options + * @returns Plain object + */ + public toObject(message: Message<{}>, options?: IConversionOptions): { [k: string]: any }; + + /** + * Type decorator (TypeScript). + * @param [typeName] Type name, defaults to the constructor's name + * @returns Decorator function + */ + public static d>(typeName?: string): TypeDecorator; +} + +/** Message type descriptor. */ +export interface IType extends INamespace { + + /** Oneof descriptors */ + oneofs?: { [k: string]: IOneOf }; + + /** Field descriptors */ + fields: { [k: string]: IField }; + + /** Extension ranges */ + extensions?: number[][]; + + /** Reserved ranges */ + reserved?: number[][]; + + /** Whether a legacy group or not */ + group?: boolean; +} + +/** Conversion options as used by {@link Type#toObject} and {@link Message.toObject}. */ +export interface IConversionOptions { + + /** + * Long conversion type. + * Valid values are `String` and `Number` (the global types). + * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library. + */ + longs?: Function; + + /** + * Enum value conversion type. + * Only valid value is `String` (the global type). + * Defaults to copy the present value, which is the numeric id. + */ + enums?: Function; + + /** + * Bytes value conversion type. + * Valid values are `Array` and (a base64 encoded) `String` (the global types). + * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser. + */ + bytes?: Function; + + /** Also sets default values on the resulting object */ + defaults?: boolean; + + /** Sets empty arrays for missing repeated fields even if `defaults=false` */ + arrays?: boolean; + + /** Sets empty objects for missing map fields even if `defaults=false` */ + objects?: boolean; + + /** Includes virtual oneof properties set to the present field's name, if any */ + oneofs?: boolean; + + /** Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings */ + json?: boolean; +} + +/** + * Decorator function as returned by {@link Type.d} (TypeScript). + * @param target Target constructor + */ +type TypeDecorator> = (target: Constructor) => void; + +/** Common type constants. */ +export namespace types { + + /** Basic type wire types. */ + const basic: { + "double": number, + "float": number, + "int32": number, + "uint32": number, + "sint32": number, + "fixed32": number, + "sfixed32": number, + "int64": number, + "uint64": number, + "sint64": number, + "fixed64": number, + "sfixed64": number, + "bool": number, + "string": number, + "bytes": number + }; + + /** Basic type defaults. */ + const defaults: { + "double": number, + "float": number, + "int32": number, + "uint32": number, + "sint32": number, + "fixed32": number, + "sfixed32": number, + "int64": number, + "uint64": number, + "sint64": number, + "fixed64": number, + "sfixed64": number, + "bool": boolean, + "string": string, + "bytes": number[], + "message": null + }; + + /** Basic long type wire types. */ + const long: { + "int64": number, + "uint64": number, + "sint64": number, + "fixed64": number, + "sfixed64": number + }; + + /** Allowed types for map keys with their associated wire type. */ + const mapKey: { + "int32": number, + "uint32": number, + "sint32": number, + "fixed32": number, + "sfixed32": number, + "int64": number, + "uint64": number, + "sint64": number, + "fixed64": number, + "sfixed64": number, + "bool": number, + "string": number + }; + + /** Allowed types for packed repeated fields with their associated wire type. */ + const packed: { + "double": number, + "float": number, + "int32": number, + "uint32": number, + "sint32": number, + "fixed32": number, + "sfixed32": number, + "int64": number, + "uint64": number, + "sint64": number, + "fixed64": number, + "sfixed64": number, + "bool": number + }; +} + +/** Constructor type. */ +export interface Constructor extends Function { + new(...params: any[]): T; prototype: T; +} + +/** Properties type. */ +type Properties = { [P in keyof T]?: T[P] }; + +/** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + */ +export interface Buffer extends Uint8Array { +} + +/** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + */ +export interface Long { + + /** Low bits */ + low: number; + + /** High bits */ + high: number; + + /** Whether unsigned or not */ + unsigned: boolean; +} + +/** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @returns Set field name, if any + */ +type OneOfGetter = () => (string|undefined); + +/** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @param value Field name + */ +type OneOfSetter = (value: (string|undefined)) => void; + +/** Various utility functions. */ +export namespace util { + + /** Helper class for working with the low and high bits of a 64 bit value. */ + class LongBits { + + /** + * Constructs new long bits. + * @param lo Low 32 bits, unsigned + * @param hi High 32 bits, unsigned + */ + constructor(lo: number, hi: number); + + /** Low bits. */ + public lo: number; + + /** High bits. */ + public hi: number; + + /** Zero bits. */ + public static zero: util.LongBits; + + /** Zero hash. */ + public static zeroHash: string; + + /** + * Constructs new long bits from the specified number. + * @param value Value + * @returns Instance + */ + public static fromNumber(value: number): util.LongBits; + + /** + * Constructs new long bits from a number, long or string. + * @param value Value + * @returns Instance + */ + public static from(value: (Long|number|string)): util.LongBits; + + /** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param [unsigned=false] Whether unsigned or not + * @returns Possibly unsafe number + */ + public toNumber(unsigned?: boolean): number; + + /** + * Converts this long bits to a long. + * @param [unsigned=false] Whether unsigned or not + * @returns Long + */ + public toLong(unsigned?: boolean): Long; + + /** + * Constructs new long bits from the specified 8 characters long hash. + * @param hash Hash + * @returns Bits + */ + public static fromHash(hash: string): util.LongBits; + + /** + * Converts this long bits to a 8 characters long hash. + * @returns Hash + */ + public toHash(): string; + + /** + * Zig-zag encodes this long bits. + * @returns `this` + */ + public zzEncode(): util.LongBits; + + /** + * Zig-zag decodes this long bits. + * @returns `this` + */ + public zzDecode(): util.LongBits; + + /** + * Calculates the length of this longbits when encoded as a varint. + * @returns Length + */ + public length(): number; + } + + /** An immuable empty array. */ + const emptyArray: any[]; + + /** An immutable empty object. */ + const emptyObject: object; + + /** Whether running within node or not. */ + const isNode: boolean; + + /** + * Tests if the specified value is an integer. + * @param value Value to test + * @returns `true` if the value is an integer + */ + function isInteger(value: any): boolean; + + /** + * Tests if the specified value is a string. + * @param value Value to test + * @returns `true` if the value is a string + */ + function isString(value: any): boolean; + + /** + * Tests if the specified value is a non-null object. + * @param value Value to test + * @returns `true` if the value is a non-null object + */ + function isObject(value: any): boolean; + + /** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @param obj Plain object or message instance + * @param prop Property name + * @returns `true` if considered to be present, otherwise `false` + */ + function isset(obj: object, prop: string): boolean; + + /** + * Checks if a property on a message is considered to be present. + * @param obj Plain object or message instance + * @param prop Property name + * @returns `true` if considered to be present, otherwise `false` + */ + function isSet(obj: object, prop: string): boolean; + + /** Node's Buffer class if available. */ + let Buffer: Constructor; + + /** + * Creates a new buffer of whatever type supported by the environment. + * @param [sizeOrArray=0] Buffer size or number array + * @returns Buffer + */ + function newBuffer(sizeOrArray?: (number|number[])): (Uint8Array|Buffer); + + /** Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. */ + let Array: Constructor; + + /** Long.js's Long class if available. */ + let Long: Constructor; + + /** Regular expression used to verify 2 bit (`bool`) map keys. */ + const key2Re: RegExp; + + /** Regular expression used to verify 32 bit (`int32` etc.) map keys. */ + const key32Re: RegExp; + + /** Regular expression used to verify 64 bit (`int64` etc.) map keys. */ + const key64Re: RegExp; + + /** + * Converts a number or long to an 8 characters long hash string. + * @param value Value to convert + * @returns Hash + */ + function longToHash(value: (Long|number)): string; + + /** + * Converts an 8 characters long hash string to a long or number. + * @param hash Hash + * @param [unsigned=false] Whether unsigned or not + * @returns Original value + */ + function longFromHash(hash: string, unsigned?: boolean): (Long|number); + + /** + * Merges the properties of the source object into the destination object. + * @param dst Destination object + * @param src Source object + * @param [ifNotSet=false] Merges only if the key is not already set + * @returns Destination object + */ + function merge(dst: { [k: string]: any }, src: { [k: string]: any }, ifNotSet?: boolean): { [k: string]: any }; + + /** + * Converts the first character of a string to lower case. + * @param str String to convert + * @returns Converted string + */ + function lcFirst(str: string): string; + + /** + * Creates a custom error constructor. + * @param name Error name + * @returns Custom error constructor + */ + function newError(name: string): Constructor; + + /** Error subclass indicating a protocol specifc error. */ + class ProtocolError> extends Error { + + /** + * Constructs a new protocol error. + * @param message Error message + * @param [properties] Additional properties + */ + constructor(message: string, properties?: { [k: string]: any }); + + /** So far decoded message instance. */ + public instance: Message; + } + + /** + * Builds a getter for a oneof's present field name. + * @param fieldNames Field names + * @returns Unbound getter + */ + function oneOfGetter(fieldNames: string[]): OneOfGetter; + + /** + * Builds a setter for a oneof's present field name. + * @param fieldNames Field names + * @returns Unbound setter + */ + function oneOfSetter(fieldNames: string[]): OneOfSetter; + + /** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ + let toJSONOptions: IConversionOptions; + + /** Node's fs module if available. */ + let fs: { [k: string]: any }; + + /** + * Converts an object's values to an array. + * @param object Object to convert + * @returns Converted array + */ + function toArray(object: { [k: string]: any }): any[]; + + /** + * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values. + * @param array Array to convert + * @returns Converted object + */ + function toObject(array: any[]): { [k: string]: any }; + + /** + * Tests whether the specified name is a reserved word in JS. + * @param name Name to test + * @returns `true` if reserved, otherwise `false` + */ + function isReserved(name: string): boolean; + + /** + * Returns a safe property accessor for the specified property name. + * @param prop Property name + * @returns Safe accessor + */ + function safeProp(prop: string): string; + + /** + * Converts the first character of a string to upper case. + * @param str String to convert + * @returns Converted string + */ + function ucFirst(str: string): string; + + /** + * Converts a string to camel case. + * @param str String to convert + * @returns Converted string + */ + function camelCase(str: string): string; + + /** + * Compares reflected fields by id. + * @param a First field + * @param b Second field + * @returns Comparison value + */ + function compareFieldsById(a: Field, b: Field): number; + + /** + * Decorator helper for types (TypeScript). + * @param ctor Constructor function + * @param [typeName] Type name, defaults to the constructor's name + * @returns Reflected type + */ + function decorateType>(ctor: Constructor, typeName?: string): Type; + + /** + * Decorator helper for enums (TypeScript). + * @param object Enum object + * @returns Reflected enum + */ + function decorateEnum(object: object): Enum; + + /** Decorator root (TypeScript). */ + let decorateRoot: Root; + + /** + * Returns a promise from a node-style callback function. + * @param fn Function to call + * @param ctx Function context + * @param params Function arguments + * @returns Promisified function + */ + function asPromise(fn: asPromiseCallback, ctx: any, ...params: any[]): Promise; + + /** A minimal base64 implementation for number arrays. */ + namespace base64 { + + /** + * Calculates the byte length of a base64 encoded string. + * @param string Base64 encoded string + * @returns Byte length + */ + function length(string: string): number; + + /** + * Encodes a buffer to a base64 encoded string. + * @param buffer Source buffer + * @param start Source start + * @param end Source end + * @returns Base64 encoded string + */ + function encode(buffer: Uint8Array, start: number, end: number): string; + + /** + * Decodes a base64 encoded string to a buffer. + * @param string Source string + * @param buffer Destination buffer + * @param offset Destination offset + * @returns Number of bytes written + * @throws {Error} If encoding is invalid + */ + function decode(string: string, buffer: Uint8Array, offset: number): number; + + /** + * Tests if the specified string appears to be base64 encoded. + * @param string String to test + * @returns `true` if probably base64 encoded, otherwise false + */ + function test(string: string): boolean; + } + + /** + * Begins generating a function. + * @param functionParams Function parameter names + * @param [functionName] Function name if not anonymous + * @returns Appender that appends code to the function's body + */ + function codegen(functionParams: string[], functionName?: string): Codegen; + + namespace codegen { + + /** When set to `true`, codegen will log generated code to console. Useful for debugging. */ + let verbose: boolean; + } + + /** + * Begins generating a function. + * @param [functionName] Function name if not anonymous + * @returns Appender that appends code to the function's body + */ + function codegen(functionName?: string): Codegen; + + /** A minimal event emitter. */ + class EventEmitter { + + /** Constructs a new event emitter instance. */ + constructor(); + + /** + * Registers an event listener. + * @param evt Event name + * @param fn Listener + * @param [ctx] Listener context + * @returns `this` + */ + public on(evt: string, fn: EventEmitterListener, ctx?: any): this; + + /** + * Removes an event listener or any matching listeners if arguments are omitted. + * @param [evt] Event name. Removes all listeners if omitted. + * @param [fn] Listener to remove. Removes all listeners of `evt` if omitted. + * @returns `this` + */ + public off(evt?: string, fn?: EventEmitterListener): this; + + /** + * Emits an event by calling its listeners with the specified arguments. + * @param evt Event name + * @param args Arguments + * @returns `this` + */ + public emit(evt: string, ...args: any[]): this; + } + + /** Reads / writes floats / doubles from / to buffers. */ + namespace float { + + /** + * Writes a 32 bit float to a buffer using little endian byte order. + * @param val Value to write + * @param buf Target buffer + * @param pos Target buffer offset + */ + function writeFloatLE(val: number, buf: Uint8Array, pos: number): void; + + /** + * Writes a 32 bit float to a buffer using big endian byte order. + * @param val Value to write + * @param buf Target buffer + * @param pos Target buffer offset + */ + function writeFloatBE(val: number, buf: Uint8Array, pos: number): void; + + /** + * Reads a 32 bit float from a buffer using little endian byte order. + * @param buf Source buffer + * @param pos Source buffer offset + * @returns Value read + */ + function readFloatLE(buf: Uint8Array, pos: number): number; + + /** + * Reads a 32 bit float from a buffer using big endian byte order. + * @param buf Source buffer + * @param pos Source buffer offset + * @returns Value read + */ + function readFloatBE(buf: Uint8Array, pos: number): number; + + /** + * Writes a 64 bit double to a buffer using little endian byte order. + * @param val Value to write + * @param buf Target buffer + * @param pos Target buffer offset + */ + function writeDoubleLE(val: number, buf: Uint8Array, pos: number): void; + + /** + * Writes a 64 bit double to a buffer using big endian byte order. + * @param val Value to write + * @param buf Target buffer + * @param pos Target buffer offset + */ + function writeDoubleBE(val: number, buf: Uint8Array, pos: number): void; + + /** + * Reads a 64 bit double from a buffer using little endian byte order. + * @param buf Source buffer + * @param pos Source buffer offset + * @returns Value read + */ + function readDoubleLE(buf: Uint8Array, pos: number): number; + + /** + * Reads a 64 bit double from a buffer using big endian byte order. + * @param buf Source buffer + * @param pos Source buffer offset + * @returns Value read + */ + function readDoubleBE(buf: Uint8Array, pos: number): number; + } + + /** + * Fetches the contents of a file. + * @param filename File path or url + * @param options Fetch options + * @param callback Callback function + */ + function fetch(filename: string, options: IFetchOptions, callback: FetchCallback): void; + + /** + * Fetches the contents of a file. + * @param path File path or url + * @param callback Callback function + */ + function fetch(path: string, callback: FetchCallback): void; + + /** + * Fetches the contents of a file. + * @param path File path or url + * @param [options] Fetch options + * @returns Promise + */ + function fetch(path: string, options?: IFetchOptions): Promise<(string|Uint8Array)>; + + /** + * Requires a module only if available. + * @param moduleName Module to require + * @returns Required module if available and not empty, otherwise `null` + */ + function inquire(moduleName: string): object; + + /** A minimal path module to resolve Unix, Windows and URL paths alike. */ + namespace path { + + /** + * Tests if the specified path is absolute. + * @param path Path to test + * @returns `true` if path is absolute + */ + function isAbsolute(path: string): boolean; + + /** + * Normalizes the specified path. + * @param path Path to normalize + * @returns Normalized path + */ + function normalize(path: string): string; + + /** + * Resolves the specified include path against the specified origin path. + * @param originPath Path to the origin file + * @param includePath Include path relative to origin path + * @param [alreadyNormalized=false] `true` if both paths are already known to be normalized + * @returns Path to the include file + */ + function resolve(originPath: string, includePath: string, alreadyNormalized?: boolean): string; + } + + /** + * A general purpose buffer pool. + * @param alloc Allocator + * @param slice Slicer + * @param [size=8192] Slab size + * @returns Pooled allocator + */ + function pool(alloc: PoolAllocator, slice: PoolSlicer, size?: number): PoolAllocator; + + /** A minimal UTF8 implementation for number arrays. */ + namespace utf8 { + + /** + * Calculates the UTF8 byte length of a string. + * @param string String + * @returns Byte length + */ + function length(string: string): number; + + /** + * Reads UTF8 bytes as a string. + * @param buffer Source buffer + * @param start Source start + * @param end Source end + * @returns String read + */ + function read(buffer: Uint8Array, start: number, end: number): string; + + /** + * Writes a string as UTF8 bytes. + * @param string Source string + * @param buffer Destination buffer + * @param offset Destination offset + * @returns Bytes written + */ + function write(string: string, buffer: Uint8Array, offset: number): number; + } +} + +/** + * Generates a verifier specific to the specified message type. + * @param mtype Message type + * @returns Codegen instance + */ +export function verifier(mtype: Type): Codegen; + +/** Wrappers for common types. */ +export const wrappers: { [k: string]: IWrapper }; + +/** + * From object converter part of an {@link IWrapper}. + * @param object Plain object + * @returns Message instance + */ +type WrapperFromObjectConverter = (this: Type, object: { [k: string]: any }) => Message<{}>; + +/** + * To object converter part of an {@link IWrapper}. + * @param message Message instance + * @param [options] Conversion options + * @returns Plain object + */ +type WrapperToObjectConverter = (this: Type, message: Message<{}>, options?: IConversionOptions) => { [k: string]: any }; + +/** Common type wrapper part of {@link wrappers}. */ +export interface IWrapper { + + /** From object converter */ + fromObject?: WrapperFromObjectConverter; + + /** To object converter */ + toObject?: WrapperToObjectConverter; +} + +/** Wire format writer using `Uint8Array` if available, otherwise `Array`. */ +export class Writer { + + /** Constructs a new writer instance. */ + constructor(); + + /** Current length. */ + public len: number; + + /** Operations head. */ + public head: object; + + /** Operations tail */ + public tail: object; + + /** Linked forked states. */ + public states: (object|null); + + /** + * Creates a new writer. + * @returns A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ + public static create(): (BufferWriter|Writer); + + /** + * Allocates a buffer of the specified size. + * @param size Buffer size + * @returns Buffer + */ + public static alloc(size: number): Uint8Array; + + /** + * Writes an unsigned 32 bit value as a varint. + * @param value Value to write + * @returns `this` + */ + public uint32(value: number): Writer; + + /** + * Writes a signed 32 bit value as a varint. + * @param value Value to write + * @returns `this` + */ + public int32(value: number): Writer; + + /** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param value Value to write + * @returns `this` + */ + public sint32(value: number): Writer; + + /** + * Writes an unsigned 64 bit value as a varint. + * @param value Value to write + * @returns `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + public uint64(value: (Long|number|string)): Writer; + + /** + * Writes a signed 64 bit value as a varint. + * @param value Value to write + * @returns `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + public int64(value: (Long|number|string)): Writer; + + /** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param value Value to write + * @returns `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + public sint64(value: (Long|number|string)): Writer; + + /** + * Writes a boolish value as a varint. + * @param value Value to write + * @returns `this` + */ + public bool(value: boolean): Writer; + + /** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param value Value to write + * @returns `this` + */ + public fixed32(value: number): Writer; + + /** + * Writes a signed 32 bit value as fixed 32 bits. + * @param value Value to write + * @returns `this` + */ + public sfixed32(value: number): Writer; + + /** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param value Value to write + * @returns `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + public fixed64(value: (Long|number|string)): Writer; + + /** + * Writes a signed 64 bit value as fixed 64 bits. + * @param value Value to write + * @returns `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ + public sfixed64(value: (Long|number|string)): Writer; + + /** + * Writes a float (32 bit). + * @param value Value to write + * @returns `this` + */ + public float(value: number): Writer; + + /** + * Writes a double (64 bit float). + * @param value Value to write + * @returns `this` + */ + public double(value: number): Writer; + + /** + * Writes a sequence of bytes. + * @param value Buffer or base64 encoded string to write + * @returns `this` + */ + public bytes(value: (Uint8Array|string)): Writer; + + /** + * Writes a string. + * @param value Value to write + * @returns `this` + */ + public string(value: string): Writer; + + /** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns `this` + */ + public fork(): Writer; + + /** + * Resets this instance to the last state. + * @returns `this` + */ + public reset(): Writer; + + /** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns `this` + */ + public ldelim(): Writer; + + /** + * Finishes the write operation. + * @returns Finished buffer + */ + public finish(): Uint8Array; +} + +/** Wire format writer using node buffers. */ +export class BufferWriter extends Writer { + + /** Constructs a new buffer writer instance. */ + constructor(); + + /** + * Finishes the write operation. + * @returns Finished buffer + */ + public finish(): Buffer; + + /** + * Allocates a buffer of the specified size. + * @param size Buffer size + * @returns Buffer + */ + public static alloc(size: number): Buffer; +} + +/** + * Callback as used by {@link util.asPromise}. + * @param error Error, if any + * @param params Additional arguments + */ +type asPromiseCallback = (error: (Error|null), ...params: any[]) => void; + +/** + * Appends code to the function's body or finishes generation. + * @param [formatStringOrScope] Format string or, to finish the function, an object of additional scope variables, if any + * @param [formatParams] Format parameters + * @returns Itself or the generated function if finished + * @throws {Error} If format parameter counts do not match + */ +type Codegen = (formatStringOrScope?: (string|{ [k: string]: any }), ...formatParams: any[]) => (Codegen|Function); + +/** + * Event listener as used by {@link util.EventEmitter}. + * @param args Arguments + */ +type EventEmitterListener = (...args: any[]) => void; + +/** + * Node-style callback as used by {@link util.fetch}. + * @param error Error, if any, otherwise `null` + * @param [contents] File contents, if there hasn't been an error + */ +type FetchCallback = (error: Error, contents?: string) => void; + +/** Options as used by {@link util.fetch}. */ +export interface IFetchOptions { + + /** Whether expecting a binary response */ + binary?: boolean; + + /** If `true`, forces the use of XMLHttpRequest */ + xhr?: boolean; +} + +/** + * An allocator as used by {@link util.pool}. + * @param size Buffer size + * @returns Buffer + */ +type PoolAllocator = (size: number) => Uint8Array; + +/** + * A slicer as used by {@link util.pool}. + * @param start Start offset + * @param end End offset + * @returns Buffer slice + */ +type PoolSlicer = (this: Uint8Array, start: number, end: number) => Uint8Array; diff --git a/node_modules/protobufjs/index.js b/node_modules/protobufjs/index.js new file mode 100644 index 0000000..042042a --- /dev/null +++ b/node_modules/protobufjs/index.js @@ -0,0 +1,4 @@ +// full library entry point. + +"use strict"; +module.exports = require("./src/index"); diff --git a/node_modules/protobufjs/light.d.ts b/node_modules/protobufjs/light.d.ts new file mode 100644 index 0000000..d83e7f9 --- /dev/null +++ b/node_modules/protobufjs/light.d.ts @@ -0,0 +1,2 @@ +export as namespace protobuf; +export * from "./index"; diff --git a/node_modules/protobufjs/light.js b/node_modules/protobufjs/light.js new file mode 100644 index 0000000..1209e64 --- /dev/null +++ b/node_modules/protobufjs/light.js @@ -0,0 +1,4 @@ +// light library entry point. + +"use strict"; +module.exports = require("./src/index-light"); \ No newline at end of file diff --git a/node_modules/protobufjs/minimal.d.ts b/node_modules/protobufjs/minimal.d.ts new file mode 100644 index 0000000..d83e7f9 --- /dev/null +++ b/node_modules/protobufjs/minimal.d.ts @@ -0,0 +1,2 @@ +export as namespace protobuf; +export * from "./index"; diff --git a/node_modules/protobufjs/minimal.js b/node_modules/protobufjs/minimal.js new file mode 100644 index 0000000..1f35ec9 --- /dev/null +++ b/node_modules/protobufjs/minimal.js @@ -0,0 +1,4 @@ +// minimal library entry point. + +"use strict"; +module.exports = require("./src/index-minimal"); diff --git a/node_modules/protobufjs/node_modules/@types/long/LICENSE b/node_modules/protobufjs/node_modules/@types/long/LICENSE new file mode 100644 index 0000000..2107107 --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/long/LICENSE @@ -0,0 +1,21 @@ + MIT License + + Copyright (c) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE diff --git a/node_modules/protobufjs/node_modules/@types/long/README.md b/node_modules/protobufjs/node_modules/@types/long/README.md new file mode 100644 index 0000000..382951d --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/long/README.md @@ -0,0 +1,16 @@ +# Installation +> `npm install --save @types/long` + +# Summary +This package contains type definitions for long.js (https://github.com/dcodeIO/long.js). + +# Details +Files were exported from https://www.github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/long + +Additional Details + * Last updated: Wed, 25 Apr 2018 00:38:11 GMT + * Dependencies: none + * Global values: Long + +# Credits +These definitions were written by Peter Kooijmans . diff --git a/node_modules/protobufjs/node_modules/@types/long/index.d.ts b/node_modules/protobufjs/node_modules/@types/long/index.d.ts new file mode 100644 index 0000000..7d373ae --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/long/index.d.ts @@ -0,0 +1,385 @@ +// Type definitions for long.js 4.0.0 +// Project: https://github.com/dcodeIO/long.js +// Definitions by: Peter Kooijmans +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped +// Definitions by: Denis Cappellin + +export = Long; +export as namespace Long; + +declare namespace Long {} +declare class Long +{ + /** + * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as signed integers. See the from* functions below for more convenient ways of constructing Longs. + */ + constructor( low: number, high?: number, unsigned?: boolean ); + + /** + * Maximum unsigned value. + */ + static MAX_UNSIGNED_VALUE: Long; + + /** + * Maximum signed value. + */ + static MAX_VALUE: Long; + + /** + * Minimum signed value. + */ + static MIN_VALUE: Long; + + /** + * Signed negative one. + */ + static NEG_ONE: Long; + + /** + * Signed one. + */ + static ONE: Long; + + /** + * Unsigned one. + */ + static UONE: Long; + + /** + * Unsigned zero. + */ + static UZERO: Long; + + /** + * Signed zero + */ + static ZERO: Long; + + /** + * The high 32 bits as a signed value. + */ + high: number; + + /** + * The low 32 bits as a signed value. + */ + low: number; + + /** + * Whether unsigned or not. + */ + unsigned: boolean; + + /** + * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is assumed to use 32 bits. + */ + static fromBits( lowBits:number, highBits:number, unsigned?:boolean ): Long; + + /** + * Returns a Long representing the given 32 bit integer value. + */ + static fromInt( value: number, unsigned?: boolean ): Long; + + /** + * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned. + */ + static fromNumber( value: number, unsigned?: boolean ): Long; + + /** + * Returns a Long representation of the given string, written using the specified radix. + */ + static fromString( str: string, unsigned?: boolean | number, radix?: number ): Long; + + /** + * Creates a Long from its byte representation. + */ + static fromBytes( bytes: number[], unsigned?: boolean, le?: boolean ): Long; + + /** + * Creates a Long from its little endian byte representation. + */ + static fromBytesLE( bytes: number[], unsigned?: boolean ): Long; + + /** + * Creates a Long from its little endian byte representation. + */ + static fromBytesBE( bytes: number[], unsigned?: boolean ): Long; + + /** + * Tests if the specified object is a Long. + */ + static isLong( obj: any ): boolean; + + /** + * Converts the specified value to a Long. + */ + static fromValue( val: Long | number | string | {low: number, high: number, unsigned: boolean} ): Long; + + /** + * Returns the sum of this and the specified Long. + */ + add( addend: number | Long | string ): Long; + + /** + * Returns the bitwise AND of this Long and the specified. + */ + and( other: Long | number | string ): Long; + + /** + * Compares this Long's value with the specified's. + */ + compare( other: Long | number | string ): number; + + /** + * Compares this Long's value with the specified's. + */ + comp( other: Long | number | string ): number; + + /** + * Returns this Long divided by the specified. + */ + divide( divisor: Long | number | string ): Long; + + /** + * Returns this Long divided by the specified. + */ + div( divisor: Long | number | string ): Long; + + /** + * Tests if this Long's value equals the specified's. + */ + equals( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value equals the specified's. + */ + eq( other: Long | number | string ): boolean; + + /** + * Gets the high 32 bits as a signed integer. + */ + getHighBits(): number; + + /** + * Gets the high 32 bits as an unsigned integer. + */ + getHighBitsUnsigned(): number; + + /** + * Gets the low 32 bits as a signed integer. + */ + getLowBits(): number; + + /** + * Gets the low 32 bits as an unsigned integer. + */ + getLowBitsUnsigned(): number; + + /** + * Gets the number of bits needed to represent the absolute value of this Long. + */ + getNumBitsAbs(): number; + + /** + * Tests if this Long's value is greater than the specified's. + */ + greaterThan( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than the specified's. + */ + gt( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than or equal the specified's. + */ + greaterThanOrEqual( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is greater than or equal the specified's. + */ + gte( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is even. + */ + isEven(): boolean; + + /** + * Tests if this Long's value is negative. + */ + isNegative(): boolean; + + /** + * Tests if this Long's value is odd. + */ + isOdd(): boolean; + + /** + * Tests if this Long's value is positive. + */ + isPositive(): boolean; + + /** + * Tests if this Long's value equals zero. + */ + isZero(): boolean; + + /** + * Tests if this Long's value is less than the specified's. + */ + lessThan( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than the specified's. + */ + lt( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than or equal the specified's. + */ + lessThanOrEqual( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value is less than or equal the specified's. + */ + lte( other: Long | number | string ): boolean; + + /** + * Returns this Long modulo the specified. + */ + modulo( other: Long | number | string ): Long; + + /** + * Returns this Long modulo the specified. + */ + mod( other: Long | number | string ): Long; + + /** + * Returns the product of this and the specified Long. + */ + multiply( multiplier: Long | number | string ): Long; + + /** + * Returns the product of this and the specified Long. + */ + mul( multiplier: Long | number | string ): Long; + + /** + * Negates this Long's value. + */ + negate(): Long; + + /** + * Negates this Long's value. + */ + neg(): Long; + + /** + * Returns the bitwise NOT of this Long. + */ + not(): Long; + + /** + * Tests if this Long's value differs from the specified's. + */ + notEquals( other: Long | number | string ): boolean; + + /** + * Tests if this Long's value differs from the specified's. + */ + neq( other: Long | number | string ): boolean; + + /** + * Returns the bitwise OR of this Long and the specified. + */ + or( other: Long | number | string ): Long; + + /** + * Returns this Long with bits shifted to the left by the given amount. + */ + shiftLeft( numBits: number | Long ): Long; + + /** + * Returns this Long with bits shifted to the left by the given amount. + */ + shl( numBits: number | Long ): Long; + + /** + * Returns this Long with bits arithmetically shifted to the right by the given amount. + */ + shiftRight( numBits: number | Long ): Long; + + /** + * Returns this Long with bits arithmetically shifted to the right by the given amount. + */ + shr( numBits: number | Long ): Long; + + /** + * Returns this Long with bits logically shifted to the right by the given amount. + */ + shiftRightUnsigned( numBits: number | Long ): Long; + + /** + * Returns this Long with bits logically shifted to the right by the given amount. + */ + shru( numBits: number | Long ): Long; + + /** + * Returns the difference of this and the specified Long. + */ + subtract( subtrahend: number | Long | string ): Long; + + /** + * Returns the difference of this and the specified Long. + */ + sub( subtrahend: number | Long |string ): Long; + + /** + * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer. + */ + toInt(): number; + + /** + * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa). + */ + toNumber(): number; + + /** + * Converts this Long to its byte representation. + */ + + toBytes( le?: boolean ): number[]; + + /** + * Converts this Long to its little endian byte representation. + */ + + toBytesLE(): number[]; + + /** + * Converts this Long to its big endian byte representation. + */ + + toBytesBE(): number[]; + + /** + * Converts this Long to signed. + */ + toSigned(): Long; + + /** + * Converts the Long to a string written in the specified radix. + */ + toString( radix?: number ): string; + + /** + * Converts this Long to unsigned. + */ + toUnsigned(): Long; + + /** + * Returns the bitwise XOR of this Long and the given one. + */ + xor( other: Long | number | string ): Long; +} diff --git a/node_modules/protobufjs/node_modules/@types/long/package.json b/node_modules/protobufjs/node_modules/@types/long/package.json new file mode 100644 index 0000000..5b46d7d --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/long/package.json @@ -0,0 +1,47 @@ +{ + "_from": "@types/long@^4.0.0", + "_id": "@types/long@4.0.0", + "_inBundle": false, + "_integrity": "sha512-1w52Nyx4Gq47uuu0EVcsHBxZFJgurQ+rTKS3qMHxR1GY2T8c2AJYd6vZoZ9q1rupaDjU0yT+Jc2XTyXkjeMA+Q==", + "_location": "/protobufjs/@types/long", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/long@^4.0.0", + "name": "@types/long", + "escapedName": "@types%2flong", + "scope": "@types", + "rawSpec": "^4.0.0", + "saveSpec": null, + "fetchSpec": "^4.0.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.0.tgz", + "_shasum": "719551d2352d301ac8b81db732acb6bdc28dbdef", + "_spec": "@types/long@^4.0.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "bundleDependencies": false, + "contributors": [ + { + "name": "Peter Kooijmans", + "url": "https://github.com/peterkooijmans" + } + ], + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for long.js", + "license": "MIT", + "main": "", + "name": "@types/long", + "repository": { + "type": "git", + "url": "https://www.github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typeScriptVersion": "2.0", + "typesPublisherContentHash": "cc3246302180c8c161d2e2c0c3f0a419226efa475d2cd5afbe51986d60cd8287", + "version": "4.0.0" +} diff --git a/node_modules/protobufjs/node_modules/@types/node/LICENSE b/node_modules/protobufjs/node_modules/@types/node/LICENSE new file mode 100644 index 0000000..2107107 --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/node/LICENSE @@ -0,0 +1,21 @@ + MIT License + + Copyright (c) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE diff --git a/node_modules/protobufjs/node_modules/@types/node/README.md b/node_modules/protobufjs/node_modules/@types/node/README.md new file mode 100644 index 0000000..e5df9c7 --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/node/README.md @@ -0,0 +1,16 @@ +# Installation +> `npm install --save @types/node` + +# Summary +This package contains type definitions for Node.js (http://nodejs.org/). + +# Details +Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node + +Additional Details + * Last updated: Mon, 06 Aug 2018 21:55:25 GMT + * Dependencies: none + * Global values: Buffer, NodeJS, SlowBuffer, Symbol, __dirname, __filename, clearImmediate, clearInterval, clearTimeout, console, exports, global, module, process, require, setImmediate, setInterval, setTimeout + +# Credits +These definitions were written by Microsoft TypeScript , DefinitelyTyped , Parambir Singh , Christian Vaagland Tellnes , Wilco Bakker , Nicolas Voigt , Chigozirim C. , Flarna , Mariusz Wiktorczyk , wwwy3y3 , Deividas Bakanas , Kelvin Jin , Alvis HT Tang , Sebastian Silbermann , Hannes Magnusson , Alberto Schiabel , Klaus Meinhardt , Huw , Nicolas Even , Bruno Scheufler , Mohsen Azimi , Hoàng Văn Khải , Alexander T. , Lishude , Andrew Makarov , Zane Hannan AU , Eugene Y. Q. Shen . diff --git a/node_modules/protobufjs/node_modules/@types/node/index.d.ts b/node_modules/protobufjs/node_modules/@types/node/index.d.ts new file mode 100644 index 0000000..ed04749 --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/node/index.d.ts @@ -0,0 +1,8026 @@ +// Type definitions for Node.js 10.5.x +// Project: http://nodejs.org/ +// Definitions by: Microsoft TypeScript +// DefinitelyTyped +// Parambir Singh +// Christian Vaagland Tellnes +// Wilco Bakker +// Nicolas Voigt +// Chigozirim C. +// Flarna +// Mariusz Wiktorczyk +// wwwy3y3 +// Deividas Bakanas +// Kelvin Jin +// Alvis HT Tang +// Sebastian Silbermann +// Hannes Magnusson +// Alberto Schiabel +// Klaus Meinhardt +// Huw +// Nicolas Even +// Bruno Scheufler +// Mohsen Azimi +// Hoàng Văn Khải +// Alexander T. +// Lishude +// Andrew Makarov +// Zane Hannan AU +// Eugene Y. Q. Shen +// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped + +/** inspector module types */ +/// + +// This needs to be global to avoid TS2403 in case lib.dom.d.ts is present in the same build +interface Console { + Console: NodeJS.ConsoleConstructor; + /** + * A simple assertion test that verifies whether `value` is truthy. + * If it is not, an `AssertionError` is thrown. + * If provided, the error `message` is formatted using `util.format()` and used as the error message. + */ + assert(value: any, message?: string, ...optionalParams: any[]): void; + /** + * When `stdout` is a TTY, calling `console.clear()` will attempt to clear the TTY. + * When `stdout` is not a TTY, this method does nothing. + */ + clear(): void; + /** + * Maintains an internal counter specific to `label` and outputs to `stdout` the number of times `console.count()` has been called with the given `label`. + */ + count(label?: string): void; + /** + * Resets the internal counter specific to `label`. + */ + countReset(label?: string): void; + /** + * The `console.debug()` function is an alias for {@link console.log()}. + */ + debug(message?: any, ...optionalParams: any[]): void; + /** + * Uses {@link util.inspect()} on `obj` and prints the resulting string to `stdout`. + * This function bypasses any custom `inspect()` function defined on `obj`. + */ + dir(obj: any, options?: NodeJS.InspectOptions): void; + /** + * This method calls {@link console.log()} passing it the arguments received. Please note that this method does not produce any XML formatting + */ + dirxml(...data: any[]): void; + /** + * Prints to `stderr` with newline. + */ + error(message?: any, ...optionalParams: any[]): void; + /** + * Increases indentation of subsequent lines by two spaces. + * If one or more `label`s are provided, those are printed first without the additional indentation. + */ + group(...label: any[]): void; + /** + * The `console.groupCollapsed()` function is an alias for {@link console.group()}. + */ + groupCollapsed(): void; + /** + * Decreases indentation of subsequent lines by two spaces. + */ + groupEnd(): void; + /** + * The {@link console.info()} function is an alias for {@link console.log()}. + */ + info(message?: any, ...optionalParams: any[]): void; + /** + * Prints to `stdout` with newline. + */ + log(message?: any, ...optionalParams: any[]): void; + /** + * This method does not display anything unless used in the inspector. + * Prints to `stdout` the array `array` formatted as a table. + */ + table(tabularData: any, properties?: string[]): void; + /** + * Starts a timer that can be used to compute the duration of an operation. Timers are identified by a unique `label`. + */ + time(label?: string): void; + /** + * Stops a timer that was previously started by calling {@link console.time()} and prints the result to `stdout`. + */ + timeEnd(label?: string): void; + /** + * Prints to `stderr` the string 'Trace :', followed by the {@link util.format()} formatted message and stack trace to the current position in the code. + */ + trace(message?: any, ...optionalParams: any[]): void; + /** + * The {@link console.warn()} function is an alias for {@link console.error()}. + */ + warn(message?: any, ...optionalParams: any[]): void; + + // --- Inspector mode only --- + /** + * This method does not display anything unless used in the inspector. + * Starts a JavaScript CPU profile with an optional label. + */ + profile(label?: string): void; + /** + * This method does not display anything unless used in the inspector. + * Stops the current JavaScript CPU profiling session if one has been started and prints the report to the Profiles panel of the inspector. + */ + profileEnd(): void; + /** + * This method does not display anything unless used in the inspector. + * Adds an event with the label `label` to the Timeline panel of the inspector. + */ + timeStamp(label?: string): void; +} + +interface Error { + stack?: string; +} + +// Declare "static" methods in Error +interface ErrorConstructor { + /** Create .stack property on a target object */ + captureStackTrace(targetObject: Object, constructorOpt?: Function): void; + + /** + * Optional override for formatting stack traces + * + * @see https://github.com/v8/v8/wiki/Stack%20Trace%20API#customizing-stack-traces + */ + prepareStackTrace?: (err: Error, stackTraces: NodeJS.CallSite[]) => any; + + stackTraceLimit: number; +} + +// compat for TypeScript 1.8 +// if you use with --target es3 or --target es5 and use below definitions, +// use the lib.es6.d.ts that is bundled with TypeScript 1.8. +interface MapConstructor { } +interface WeakMapConstructor { } +interface SetConstructor { } +interface WeakSetConstructor { } + +// Forward-declare needed types from lib.es2015.d.ts (in case users are using `--lib es5`) +interface Iterable { } +interface Iterator { + next(value?: any): IteratorResult; +} +interface IteratorResult { } +interface AsyncIterableIterator {} +interface SymbolConstructor { + readonly observable: symbol; + readonly iterator: symbol; + readonly asyncIterator: symbol; +} +declare var Symbol: SymbolConstructor; + +// Node.js ESNEXT support +interface String { + /** Removes whitespace from the left end of a string. */ + trimLeft(): string; + /** Removes whitespace from the right end of a string. */ + trimRight(): string; +} + +/************************************************ +* * +* GLOBAL * +* * +************************************************/ +declare var process: NodeJS.Process; +declare var global: NodeJS.Global; +declare var console: Console; + +declare var __filename: string; +declare var __dirname: string; + +declare function setTimeout(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timer; +declare namespace setTimeout { + export function __promisify__(ms: number): Promise; + export function __promisify__(ms: number, value: T): Promise; +} +declare function clearTimeout(timeoutId: NodeJS.Timer): void; +declare function setInterval(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timer; +declare function clearInterval(intervalId: NodeJS.Timer): void; +declare function setImmediate(callback: (...args: any[]) => void, ...args: any[]): any; +declare namespace setImmediate { + export function __promisify__(): Promise; + export function __promisify__(value: T): Promise; +} +declare function clearImmediate(immediateId: any): void; + +// TODO: change to `type NodeRequireFunction = (id: string) => any;` in next mayor version. +interface NodeRequireFunction { + /* tslint:disable-next-line:callable-types */ + (id: string): any; +} + +interface NodeRequire extends NodeRequireFunction { + resolve: RequireResolve; + cache: any; + extensions: NodeExtensions; + main: NodeModule | undefined; +} + +interface RequireResolve { + (id: string, options?: { paths?: string[]; }): string; + paths(request: string): string[] | null; +} + +interface NodeExtensions { + '.js': (m: NodeModule, filename: string) => any; + '.json': (m: NodeModule, filename: string) => any; + '.node': (m: NodeModule, filename: string) => any; + [ext: string]: (m: NodeModule, filename: string) => any; +} + +declare var require: NodeRequire; + +interface NodeModule { + exports: any; + require: NodeRequireFunction; + id: string; + filename: string; + loaded: boolean; + parent: NodeModule | null; + children: NodeModule[]; + paths: string[]; +} + +declare var module: NodeModule; + +// Same as module.exports +declare var exports: any; +declare var SlowBuffer: { + new(str: string, encoding?: string): Buffer; + new(size: number): Buffer; + new(size: Uint8Array): Buffer; + new(array: any[]): Buffer; + prototype: Buffer; + isBuffer(obj: any): boolean; + byteLength(string: string, encoding?: string): number; + concat(list: Buffer[], totalLength?: number): Buffer; +}; + +// Buffer class +type BufferEncoding = "ascii" | "utf8" | "utf16le" | "ucs2" | "base64" | "latin1" | "binary" | "hex"; +interface Buffer extends Uint8Array { + write(string: string, offset?: number, length?: number, encoding?: string): number; + toString(encoding?: string, start?: number, end?: number): string; + toJSON(): { type: 'Buffer', data: any[] }; + equals(otherBuffer: Uint8Array): boolean; + compare(otherBuffer: Uint8Array, targetStart?: number, targetEnd?: number, sourceStart?: number, sourceEnd?: number): number; + copy(targetBuffer: Uint8Array, targetStart?: number, sourceStart?: number, sourceEnd?: number): number; + slice(start?: number, end?: number): Buffer; + writeUIntLE(value: number, offset: number, byteLength: number, noAssert?: boolean): number; + writeUIntBE(value: number, offset: number, byteLength: number, noAssert?: boolean): number; + writeIntLE(value: number, offset: number, byteLength: number, noAssert?: boolean): number; + writeIntBE(value: number, offset: number, byteLength: number, noAssert?: boolean): number; + readUIntLE(offset: number, byteLength: number, noAssert?: boolean): number; + readUIntBE(offset: number, byteLength: number, noAssert?: boolean): number; + readIntLE(offset: number, byteLength: number, noAssert?: boolean): number; + readIntBE(offset: number, byteLength: number, noAssert?: boolean): number; + readUInt8(offset: number, noAssert?: boolean): number; + readUInt16LE(offset: number, noAssert?: boolean): number; + readUInt16BE(offset: number, noAssert?: boolean): number; + readUInt32LE(offset: number, noAssert?: boolean): number; + readUInt32BE(offset: number, noAssert?: boolean): number; + readInt8(offset: number, noAssert?: boolean): number; + readInt16LE(offset: number, noAssert?: boolean): number; + readInt16BE(offset: number, noAssert?: boolean): number; + readInt32LE(offset: number, noAssert?: boolean): number; + readInt32BE(offset: number, noAssert?: boolean): number; + readFloatLE(offset: number, noAssert?: boolean): number; + readFloatBE(offset: number, noAssert?: boolean): number; + readDoubleLE(offset: number, noAssert?: boolean): number; + readDoubleBE(offset: number, noAssert?: boolean): number; + swap16(): Buffer; + swap32(): Buffer; + swap64(): Buffer; + writeUInt8(value: number, offset: number, noAssert?: boolean): number; + writeUInt16LE(value: number, offset: number, noAssert?: boolean): number; + writeUInt16BE(value: number, offset: number, noAssert?: boolean): number; + writeUInt32LE(value: number, offset: number, noAssert?: boolean): number; + writeUInt32BE(value: number, offset: number, noAssert?: boolean): number; + writeInt8(value: number, offset: number, noAssert?: boolean): number; + writeInt16LE(value: number, offset: number, noAssert?: boolean): number; + writeInt16BE(value: number, offset: number, noAssert?: boolean): number; + writeInt32LE(value: number, offset: number, noAssert?: boolean): number; + writeInt32BE(value: number, offset: number, noAssert?: boolean): number; + writeFloatLE(value: number, offset: number, noAssert?: boolean): number; + writeFloatBE(value: number, offset: number, noAssert?: boolean): number; + writeDoubleLE(value: number, offset: number, noAssert?: boolean): number; + writeDoubleBE(value: number, offset: number, noAssert?: boolean): number; + fill(value: any, offset?: number, end?: number): this; + indexOf(value: string | number | Uint8Array, byteOffset?: number, encoding?: string): number; + lastIndexOf(value: string | number | Uint8Array, byteOffset?: number, encoding?: string): number; + entries(): IterableIterator<[number, number]>; + includes(value: string | number | Buffer, byteOffset?: number, encoding?: string): boolean; + keys(): IterableIterator; + values(): IterableIterator; +} + +/** + * Raw data is stored in instances of the Buffer class. + * A Buffer is similar to an array of integers but corresponds to a raw memory allocation outside the V8 heap. A Buffer cannot be resized. + * Valid string encodings: 'ascii'|'utf8'|'utf16le'|'ucs2'(alias of 'utf16le')|'base64'|'binary'(deprecated)|'hex' + */ +declare var Buffer: { + /** + * Allocates a new buffer containing the given {str}. + * + * @param str String to store in buffer. + * @param encoding encoding to use, optional. Default is 'utf8' + * @deprecated since v10.0.0 - Use `Buffer.from(string[, encoding])` instead. + */ + new(str: string, encoding?: string): Buffer; + /** + * Allocates a new buffer of {size} octets. + * + * @param size count of octets to allocate. + * @deprecated since v10.0.0 - Use `Buffer.alloc()` instead (also see `Buffer.allocUnsafe()`). + */ + new(size: number): Buffer; + /** + * Allocates a new buffer containing the given {array} of octets. + * + * @param array The octets to store. + * @deprecated since v10.0.0 - Use `Buffer.from(array)` instead. + */ + new(array: Uint8Array): Buffer; + /** + * Produces a Buffer backed by the same allocated memory as + * the given {ArrayBuffer}. + * + * + * @param arrayBuffer The ArrayBuffer with which to share memory. + * @deprecated since v10.0.0 - Use `Buffer.from(arrayBuffer[, byteOffset[, length]])` instead. + */ + new(arrayBuffer: ArrayBuffer): Buffer; + /** + * Allocates a new buffer containing the given {array} of octets. + * + * @param array The octets to store. + * @deprecated since v10.0.0 - Use `Buffer.from(array)` instead. + */ + new(array: any[]): Buffer; + /** + * Copies the passed {buffer} data onto a new {Buffer} instance. + * + * @param buffer The buffer to copy. + * @deprecated since v10.0.0 - Use `Buffer.from(buffer)` instead. + */ + new(buffer: Buffer): Buffer; + prototype: Buffer; + /** + * When passed a reference to the .buffer property of a TypedArray instance, + * the newly created Buffer will share the same allocated memory as the TypedArray. + * The optional {byteOffset} and {length} arguments specify a memory range + * within the {arrayBuffer} that will be shared by the Buffer. + * + * @param arrayBuffer The .buffer property of any TypedArray or a new ArrayBuffer() + */ + from(arrayBuffer: ArrayBuffer, byteOffset?: number, length?: number): Buffer; + // from(arrayBuffer: SharedArrayBuffer, byteOffset?: number, length?: number): Buffer; + /** + * Creates a new Buffer using the passed {data} + * @param data data to create a new Buffer + */ + from(data: any[]): Buffer; + from(data: Uint8Array): Buffer; + /** + * Creates a new Buffer containing the given JavaScript string {str}. + * If provided, the {encoding} parameter identifies the character encoding. + * If not provided, {encoding} defaults to 'utf8'. + */ + from(str: string, encoding?: string): Buffer; + /** + * Creates a new Buffer using the passed {data} + * @param values to create a new Buffer + */ + of(...items: number[]): Buffer; + /** + * Returns true if {obj} is a Buffer + * + * @param obj object to test. + */ + isBuffer(obj: any): obj is Buffer; + /** + * Returns true if {encoding} is a valid encoding argument. + * Valid string encodings in Node 0.12: 'ascii'|'utf8'|'utf16le'|'ucs2'(alias of 'utf16le')|'base64'|'binary'(deprecated)|'hex' + * + * @param encoding string to test. + */ + isEncoding(encoding: string): boolean | undefined; + /** + * Gives the actual byte length of a string. encoding defaults to 'utf8'. + * This is not the same as String.prototype.length since that returns the number of characters in a string. + * + * @param string string to test. + * @param encoding encoding used to evaluate (defaults to 'utf8') + */ + byteLength(string: string | NodeJS.TypedArray | DataView | ArrayBuffer /*| SharedArrayBuffer */, encoding?: string): number; + /** + * Returns a buffer which is the result of concatenating all the buffers in the list together. + * + * If the list has no items, or if the totalLength is 0, then it returns a zero-length buffer. + * If the list has exactly one item, then the first item of the list is returned. + * If the list has more than one item, then a new Buffer is created. + * + * @param list An array of Buffer objects to concatenate + * @param totalLength Total length of the buffers when concatenated. + * If totalLength is not provided, it is read from the buffers in the list. However, this adds an additional loop to the function, so it is faster to provide the length explicitly. + */ + concat(list: Uint8Array[], totalLength?: number): Buffer; + /** + * The same as buf1.compare(buf2). + */ + compare(buf1: Uint8Array, buf2: Uint8Array): number; + /** + * Allocates a new buffer of {size} octets. + * + * @param size count of octets to allocate. + * @param fill if specified, buffer will be initialized by calling buf.fill(fill). + * If parameter is omitted, buffer will be filled with zeros. + * @param encoding encoding used for call to buf.fill while initalizing + */ + alloc(size: number, fill?: string | Buffer | number, encoding?: string): Buffer; + /** + * Allocates a new buffer of {size} octets, leaving memory not initialized, so the contents + * of the newly created Buffer are unknown and may contain sensitive data. + * + * @param size count of octets to allocate + */ + allocUnsafe(size: number): Buffer; + /** + * Allocates a new non-pooled buffer of {size} octets, leaving memory not initialized, so the contents + * of the newly created Buffer are unknown and may contain sensitive data. + * + * @param size count of octets to allocate + */ + allocUnsafeSlow(size: number): Buffer; + /** + * This is the number of bytes used to determine the size of pre-allocated, internal Buffer instances used for pooling. This value may be modified. + */ + poolSize: number; +}; + +/************************************************ +* * +* GLOBAL INTERFACES * +* * +************************************************/ +declare namespace NodeJS { + export interface InspectOptions { + showHidden?: boolean; + depth?: number | null; + colors?: boolean; + customInspect?: boolean; + showProxy?: boolean; + maxArrayLength?: number | null; + breakLength?: number; + compact?: boolean; + } + + export interface ConsoleConstructor { + prototype: Console; + new(stdout: WritableStream, stderr?: WritableStream): Console; + } + + export interface CallSite { + /** + * Value of "this" + */ + getThis(): any; + + /** + * Type of "this" as a string. + * This is the name of the function stored in the constructor field of + * "this", if available. Otherwise the object's [[Class]] internal + * property. + */ + getTypeName(): string | null; + + /** + * Current function + */ + getFunction(): Function | undefined; + + /** + * Name of the current function, typically its name property. + * If a name property is not available an attempt will be made to try + * to infer a name from the function's context. + */ + getFunctionName(): string | null; + + /** + * Name of the property [of "this" or one of its prototypes] that holds + * the current function + */ + getMethodName(): string | null; + + /** + * Name of the script [if this function was defined in a script] + */ + getFileName(): string | null; + + /** + * Current line number [if this function was defined in a script] + */ + getLineNumber(): number | null; + + /** + * Current column number [if this function was defined in a script] + */ + getColumnNumber(): number | null; + + /** + * A call site object representing the location where eval was called + * [if this function was created using a call to eval] + */ + getEvalOrigin(): string | undefined; + + /** + * Is this a toplevel invocation, that is, is "this" the global object? + */ + isToplevel(): boolean; + + /** + * Does this call take place in code defined by a call to eval? + */ + isEval(): boolean; + + /** + * Is this call in native V8 code? + */ + isNative(): boolean; + + /** + * Is this a constructor call? + */ + isConstructor(): boolean; + } + + export interface ErrnoException extends Error { + errno?: number; + code?: string; + path?: string; + syscall?: string; + stack?: string; + } + + export class EventEmitter { + addListener(event: string | symbol, listener: (...args: any[]) => void): this; + on(event: string | symbol, listener: (...args: any[]) => void): this; + once(event: string | symbol, listener: (...args: any[]) => void): this; + removeListener(event: string | symbol, listener: (...args: any[]) => void): this; + off(event: string | symbol, listener: (...args: any[]) => void): this; + removeAllListeners(event?: string | symbol): this; + setMaxListeners(n: number): this; + getMaxListeners(): number; + listeners(event: string | symbol): Function[]; + rawListeners(event: string | symbol): Function[]; + emit(event: string | symbol, ...args: any[]): boolean; + listenerCount(type: string | symbol): number; + // Added in Node 6... + prependListener(event: string | symbol, listener: (...args: any[]) => void): this; + prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this; + eventNames(): Array; + } + + export interface ReadableStream extends EventEmitter { + readable: boolean; + read(size?: number): string | Buffer; + setEncoding(encoding: string): this; + pause(): this; + resume(): this; + isPaused(): boolean; + pipe(destination: T, options?: { end?: boolean; }): T; + unpipe(destination?: T): this; + unshift(chunk: string): void; + unshift(chunk: Buffer): void; + wrap(oldStream: ReadableStream): this; + [Symbol.asyncIterator](): AsyncIterableIterator; + } + + export interface WritableStream extends EventEmitter { + writable: boolean; + write(buffer: Buffer | string, cb?: Function): boolean; + write(str: string, encoding?: string, cb?: Function): boolean; + end(cb?: Function): void; + end(buffer: Buffer, cb?: Function): void; + end(str: string, cb?: Function): void; + end(str: string, encoding?: string, cb?: Function): void; + } + + export interface ReadWriteStream extends ReadableStream, WritableStream { } + + export interface Events extends EventEmitter { } + + export interface Domain extends Events { + run(fn: Function): void; + add(emitter: Events): void; + remove(emitter: Events): void; + bind(cb: (err: Error, data: any) => any): any; + intercept(cb: (data: any) => any): any; + + addListener(event: string, listener: (...args: any[]) => void): this; + on(event: string, listener: (...args: any[]) => void): this; + once(event: string, listener: (...args: any[]) => void): this; + removeListener(event: string, listener: (...args: any[]) => void): this; + removeAllListeners(event?: string): this; + } + + export interface MemoryUsage { + rss: number; + heapTotal: number; + heapUsed: number; + external: number; + } + + export interface CpuUsage { + user: number; + system: number; + } + + export interface ProcessVersions { + http_parser: string; + node: string; + v8: string; + ares: string; + uv: string; + zlib: string; + modules: string; + openssl: string; + } + + type Platform = 'aix' + | 'android' + | 'darwin' + | 'freebsd' + | 'linux' + | 'openbsd' + | 'sunos' + | 'win32' + | 'cygwin'; + + type Signals = + "SIGABRT" | "SIGALRM" | "SIGBUS" | "SIGCHLD" | "SIGCONT" | "SIGFPE" | "SIGHUP" | "SIGILL" | "SIGINT" | "SIGIO" | + "SIGIOT" | "SIGKILL" | "SIGPIPE" | "SIGPOLL" | "SIGPROF" | "SIGPWR" | "SIGQUIT" | "SIGSEGV" | "SIGSTKFLT" | + "SIGSTOP" | "SIGSYS" | "SIGTERM" | "SIGTRAP" | "SIGTSTP" | "SIGTTIN" | "SIGTTOU" | "SIGUNUSED" | "SIGURG" | + "SIGUSR1" | "SIGUSR2" | "SIGVTALRM" | "SIGWINCH" | "SIGXCPU" | "SIGXFSZ" | "SIGBREAK" | "SIGLOST" | "SIGINFO"; + + type BeforeExitListener = (code: number) => void; + type DisconnectListener = () => void; + type ExitListener = (code: number) => void; + type RejectionHandledListener = (promise: Promise) => void; + type UncaughtExceptionListener = (error: Error) => void; + type UnhandledRejectionListener = (reason: any, promise: Promise) => void; + type WarningListener = (warning: Error) => void; + type MessageListener = (message: any, sendHandle: any) => void; + type SignalsListener = (signal: Signals) => void; + type NewListenerListener = (type: string | symbol, listener: (...args: any[]) => void) => void; + type RemoveListenerListener = (type: string | symbol, listener: (...args: any[]) => void) => void; + + export interface Socket extends ReadWriteStream { + isTTY?: true; + } + + export interface ProcessEnv { + [key: string]: string | undefined; + } + + export interface WriteStream extends Socket { + readonly writableHighWaterMark: number; + readonly writableLength: number; + columns?: number; + rows?: number; + _write(chunk: any, encoding: string, callback: Function): void; + _destroy(err: Error | null, callback: Function): void; + _final(callback: Function): void; + setDefaultEncoding(encoding: string): this; + cork(): void; + uncork(): void; + destroy(error?: Error): void; + } + export interface ReadStream extends Socket { + readonly readableHighWaterMark: number; + readonly readableLength: number; + isRaw?: boolean; + setRawMode?(mode: boolean): void; + _read(size: number): void; + _destroy(err: Error | null, callback: Function): void; + push(chunk: any, encoding?: string): boolean; + destroy(error?: Error): void; + } + + export interface Process extends EventEmitter { + stdout: WriteStream; + stderr: WriteStream; + stdin: ReadStream; + openStdin(): Socket; + argv: string[]; + argv0: string; + execArgv: string[]; + execPath: string; + abort(): void; + chdir(directory: string): void; + cwd(): string; + debugPort: number; + emitWarning(warning: string | Error, name?: string, ctor?: Function): void; + env: ProcessEnv; + exit(code?: number): never; + exitCode: number; + getgid(): number; + setgid(id: number | string): void; + getuid(): number; + setuid(id: number | string): void; + geteuid(): number; + seteuid(id: number | string): void; + getegid(): number; + setegid(id: number | string): void; + getgroups(): number[]; + setgroups(groups: Array): void; + setUncaughtExceptionCaptureCallback(cb: ((err: Error) => void) | null): void; + hasUncaughtExceptionCaptureCallback(): boolean; + version: string; + versions: ProcessVersions; + config: { + target_defaults: { + cflags: any[]; + default_configuration: string; + defines: string[]; + include_dirs: string[]; + libraries: string[]; + }; + variables: { + clang: number; + host_arch: string; + node_install_npm: boolean; + node_install_waf: boolean; + node_prefix: string; + node_shared_openssl: boolean; + node_shared_v8: boolean; + node_shared_zlib: boolean; + node_use_dtrace: boolean; + node_use_etw: boolean; + node_use_openssl: boolean; + target_arch: string; + v8_no_strict_aliasing: number; + v8_use_snapshot: boolean; + visibility: string; + }; + }; + kill(pid: number, signal?: string | number): void; + pid: number; + ppid: number; + title: string; + arch: string; + platform: Platform; + mainModule?: NodeModule; + memoryUsage(): MemoryUsage; + cpuUsage(previousValue?: CpuUsage): CpuUsage; + nextTick(callback: Function, ...args: any[]): void; + umask(mask?: number): number; + uptime(): number; + hrtime(time?: [number, number]): [number, number]; + domain: Domain; + + // Worker + send?(message: any, sendHandle?: any): void; + disconnect(): void; + connected: boolean; + + /** + * EventEmitter + * 1. beforeExit + * 2. disconnect + * 3. exit + * 4. message + * 5. rejectionHandled + * 6. uncaughtException + * 7. unhandledRejection + * 8. warning + * 9. message + * 10. + * 11. newListener/removeListener inherited from EventEmitter + */ + addListener(event: "beforeExit", listener: BeforeExitListener): this; + addListener(event: "disconnect", listener: DisconnectListener): this; + addListener(event: "exit", listener: ExitListener): this; + addListener(event: "rejectionHandled", listener: RejectionHandledListener): this; + addListener(event: "uncaughtException", listener: UncaughtExceptionListener): this; + addListener(event: "unhandledRejection", listener: UnhandledRejectionListener): this; + addListener(event: "warning", listener: WarningListener): this; + addListener(event: "message", listener: MessageListener): this; + addListener(event: Signals, listener: SignalsListener): this; + addListener(event: "newListener", listener: NewListenerListener): this; + addListener(event: "removeListener", listener: RemoveListenerListener): this; + + emit(event: "beforeExit", code: number): boolean; + emit(event: "disconnect"): boolean; + emit(event: "exit", code: number): boolean; + emit(event: "rejectionHandled", promise: Promise): boolean; + emit(event: "uncaughtException", error: Error): boolean; + emit(event: "unhandledRejection", reason: any, promise: Promise): boolean; + emit(event: "warning", warning: Error): boolean; + emit(event: "message", message: any, sendHandle: any): this; + emit(event: Signals): boolean; + emit(event: "newListener", eventName: string | symbol, listener: (...args: any[]) => void): this; + emit(event: "removeListener", eventName: string, listener: (...args: any[]) => void): this; + + on(event: "beforeExit", listener: BeforeExitListener): this; + on(event: "disconnect", listener: DisconnectListener): this; + on(event: "exit", listener: ExitListener): this; + on(event: "rejectionHandled", listener: RejectionHandledListener): this; + on(event: "uncaughtException", listener: UncaughtExceptionListener): this; + on(event: "unhandledRejection", listener: UnhandledRejectionListener): this; + on(event: "warning", listener: WarningListener): this; + on(event: "message", listener: MessageListener): this; + on(event: Signals, listener: SignalsListener): this; + on(event: "newListener", listener: NewListenerListener): this; + on(event: "removeListener", listener: RemoveListenerListener): this; + + once(event: "beforeExit", listener: BeforeExitListener): this; + once(event: "disconnect", listener: DisconnectListener): this; + once(event: "exit", listener: ExitListener): this; + once(event: "rejectionHandled", listener: RejectionHandledListener): this; + once(event: "uncaughtException", listener: UncaughtExceptionListener): this; + once(event: "unhandledRejection", listener: UnhandledRejectionListener): this; + once(event: "warning", listener: WarningListener): this; + once(event: "message", listener: MessageListener): this; + once(event: Signals, listener: SignalsListener): this; + once(event: "newListener", listener: NewListenerListener): this; + once(event: "removeListener", listener: RemoveListenerListener): this; + + prependListener(event: "beforeExit", listener: BeforeExitListener): this; + prependListener(event: "disconnect", listener: DisconnectListener): this; + prependListener(event: "exit", listener: ExitListener): this; + prependListener(event: "rejectionHandled", listener: RejectionHandledListener): this; + prependListener(event: "uncaughtException", listener: UncaughtExceptionListener): this; + prependListener(event: "unhandledRejection", listener: UnhandledRejectionListener): this; + prependListener(event: "warning", listener: WarningListener): this; + prependListener(event: "message", listener: MessageListener): this; + prependListener(event: Signals, listener: SignalsListener): this; + prependListener(event: "newListener", listener: NewListenerListener): this; + prependListener(event: "removeListener", listener: RemoveListenerListener): this; + + prependOnceListener(event: "beforeExit", listener: BeforeExitListener): this; + prependOnceListener(event: "disconnect", listener: DisconnectListener): this; + prependOnceListener(event: "exit", listener: ExitListener): this; + prependOnceListener(event: "rejectionHandled", listener: RejectionHandledListener): this; + prependOnceListener(event: "uncaughtException", listener: UncaughtExceptionListener): this; + prependOnceListener(event: "unhandledRejection", listener: UnhandledRejectionListener): this; + prependOnceListener(event: "warning", listener: WarningListener): this; + prependOnceListener(event: "message", listener: MessageListener): this; + prependOnceListener(event: Signals, listener: SignalsListener): this; + prependOnceListener(event: "newListener", listener: NewListenerListener): this; + prependOnceListener(event: "removeListener", listener: RemoveListenerListener): this; + + listeners(event: "beforeExit"): BeforeExitListener[]; + listeners(event: "disconnect"): DisconnectListener[]; + listeners(event: "exit"): ExitListener[]; + listeners(event: "rejectionHandled"): RejectionHandledListener[]; + listeners(event: "uncaughtException"): UncaughtExceptionListener[]; + listeners(event: "unhandledRejection"): UnhandledRejectionListener[]; + listeners(event: "warning"): WarningListener[]; + listeners(event: "message"): MessageListener[]; + listeners(event: Signals): SignalsListener[]; + listeners(event: "newListener"): NewListenerListener[]; + listeners(event: "removeListener"): RemoveListenerListener[]; + } + + export interface Global { + Array: typeof Array; + ArrayBuffer: typeof ArrayBuffer; + Boolean: typeof Boolean; + Buffer: typeof Buffer; + DataView: typeof DataView; + Date: typeof Date; + Error: typeof Error; + EvalError: typeof EvalError; + Float32Array: typeof Float32Array; + Float64Array: typeof Float64Array; + Function: typeof Function; + GLOBAL: Global; + Infinity: typeof Infinity; + Int16Array: typeof Int16Array; + Int32Array: typeof Int32Array; + Int8Array: typeof Int8Array; + Intl: typeof Intl; + JSON: typeof JSON; + Map: MapConstructor; + Math: typeof Math; + NaN: typeof NaN; + Number: typeof Number; + Object: typeof Object; + Promise: Function; + RangeError: typeof RangeError; + ReferenceError: typeof ReferenceError; + RegExp: typeof RegExp; + Set: SetConstructor; + String: typeof String; + Symbol: Function; + SyntaxError: typeof SyntaxError; + TypeError: typeof TypeError; + URIError: typeof URIError; + Uint16Array: typeof Uint16Array; + Uint32Array: typeof Uint32Array; + Uint8Array: typeof Uint8Array; + Uint8ClampedArray: Function; + WeakMap: WeakMapConstructor; + WeakSet: WeakSetConstructor; + clearImmediate: (immediateId: any) => void; + clearInterval: (intervalId: NodeJS.Timer) => void; + clearTimeout: (timeoutId: NodeJS.Timer) => void; + console: typeof console; + decodeURI: typeof decodeURI; + decodeURIComponent: typeof decodeURIComponent; + encodeURI: typeof encodeURI; + encodeURIComponent: typeof encodeURIComponent; + escape: (str: string) => string; + eval: typeof eval; + global: Global; + isFinite: typeof isFinite; + isNaN: typeof isNaN; + parseFloat: typeof parseFloat; + parseInt: typeof parseInt; + process: Process; + root: Global; + setImmediate: (callback: (...args: any[]) => void, ...args: any[]) => any; + setInterval: (callback: (...args: any[]) => void, ms: number, ...args: any[]) => NodeJS.Timer; + setTimeout: (callback: (...args: any[]) => void, ms: number, ...args: any[]) => NodeJS.Timer; + undefined: typeof undefined; + unescape: (str: string) => string; + gc: () => void; + v8debug?: any; + } + + export interface Timer { + ref(): void; + unref(): void; + } + + class Module { + static runMain(): void; + static wrap(code: string): string; + static builtinModules: string[]; + + static Module: typeof Module; + + exports: any; + require: NodeRequireFunction; + id: string; + filename: string; + loaded: boolean; + parent: Module | null; + children: Module[]; + paths: string[]; + + constructor(id: string, parent?: Module); + } + + type TypedArray = Uint8Array | Uint8ClampedArray | Uint16Array | Uint32Array | Int8Array | Int16Array | Int32Array | Float32Array | Float64Array; +} + +interface IterableIterator { } + +/************************************************ +* * +* MODULES * +* * +************************************************/ +declare module "buffer" { + export var INSPECT_MAX_BYTES: number; + var BuffType: typeof Buffer; + var SlowBuffType: typeof SlowBuffer; + export { BuffType as Buffer, SlowBuffType as SlowBuffer }; +} + +declare module "querystring" { + export interface StringifyOptions { + encodeURIComponent?: Function; + } + + export interface ParseOptions { + maxKeys?: number; + decodeURIComponent?: Function; + } + + interface ParsedUrlQuery { [key: string]: string | string[] | undefined; } + + export function stringify(obj: T, sep?: string, eq?: string, options?: StringifyOptions): string; + export function parse(str: string, sep?: string, eq?: string, options?: ParseOptions): ParsedUrlQuery; + export function parse(str: string, sep?: string, eq?: string, options?: ParseOptions): T; + export function escape(str: string): string; + export function unescape(str: string): string; +} + +declare module "events" { + class internal extends NodeJS.EventEmitter { } + + namespace internal { + export class EventEmitter extends internal { + /** @deprecated since v4.0.0 */ + static listenerCount(emitter: EventEmitter, event: string | symbol): number; + static defaultMaxListeners: number; + + addListener(event: string | symbol, listener: (...args: any[]) => void): this; + on(event: string | symbol, listener: (...args: any[]) => void): this; + once(event: string | symbol, listener: (...args: any[]) => void): this; + prependListener(event: string | symbol, listener: (...args: any[]) => void): this; + prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this; + removeListener(event: string | symbol, listener: (...args: any[]) => void): this; + off(event: string | symbol, listener: (...args: any[]) => void): this; + removeAllListeners(event?: string | symbol): this; + setMaxListeners(n: number): this; + getMaxListeners(): number; + listeners(event: string | symbol): Function[]; + rawListeners(event: string | symbol): Function[]; + emit(event: string | symbol, ...args: any[]): boolean; + eventNames(): Array; + listenerCount(type: string | symbol): number; + } + } + + export = internal; +} + +declare module "http" { + import * as events from "events"; + import * as net from "net"; + import * as stream from "stream"; + import { URL } from "url"; + + // incoming headers will never contain number + export interface IncomingHttpHeaders { + 'accept'?: string; + 'access-control-allow-origin'?: string; + 'access-control-allow-credentials'?: string; + 'access-control-expose-headers'?: string; + 'access-control-max-age'?: string; + 'access-control-allow-methods'?: string; + 'access-control-allow-headers'?: string; + 'accept-patch'?: string; + 'accept-ranges'?: string; + 'authorization'?: string; + 'age'?: string; + 'allow'?: string; + 'alt-svc'?: string; + 'cache-control'?: string; + 'connection'?: string; + 'content-disposition'?: string; + 'content-encoding'?: string; + 'content-language'?: string; + 'content-length'?: string; + 'content-location'?: string; + 'content-range'?: string; + 'content-type'?: string; + 'date'?: string; + 'expires'?: string; + 'host'?: string; + 'last-modified'?: string; + 'location'?: string; + 'pragma'?: string; + 'proxy-authenticate'?: string; + 'public-key-pins'?: string; + 'retry-after'?: string; + 'set-cookie'?: string[]; + 'strict-transport-security'?: string; + 'trailer'?: string; + 'transfer-encoding'?: string; + 'tk'?: string; + 'upgrade'?: string; + 'vary'?: string; + 'via'?: string; + 'warning'?: string; + 'www-authenticate'?: string; + [header: string]: string | string[] | undefined; + } + + // outgoing headers allows numbers (as they are converted internally to strings) + export interface OutgoingHttpHeaders { + [header: string]: number | string | string[] | undefined; + } + + export interface ClientRequestArgs { + protocol?: string; + host?: string; + hostname?: string; + family?: number; + port?: number | string; + defaultPort?: number | string; + localAddress?: string; + socketPath?: string; + method?: string; + path?: string; + headers?: OutgoingHttpHeaders; + auth?: string; + agent?: Agent | boolean; + _defaultAgent?: Agent; + timeout?: number; + // https://github.com/nodejs/node/blob/master/lib/_http_client.js#L278 + createConnection?: (options: ClientRequestArgs, oncreate: (err: Error, socket: net.Socket) => void) => net.Socket; + } + + export class Server extends net.Server { + constructor(requestListener?: (req: IncomingMessage, res: ServerResponse) => void); + + setTimeout(msecs?: number, callback?: () => void): this; + setTimeout(callback: () => void): this; + maxHeadersCount: number; + timeout: number; + keepAliveTimeout: number; + } + /** + * @deprecated Use IncomingMessage + */ + export class ServerRequest extends IncomingMessage { + connection: net.Socket; + } + + // https://github.com/nodejs/node/blob/master/lib/_http_outgoing.js + export class OutgoingMessage extends stream.Writable { + upgrading: boolean; + chunkedEncoding: boolean; + shouldKeepAlive: boolean; + useChunkedEncodingByDefault: boolean; + sendDate: boolean; + finished: boolean; + headersSent: boolean; + connection: net.Socket; + + constructor(); + + setTimeout(msecs: number, callback?: () => void): this; + setHeader(name: string, value: number | string | string[]): void; + getHeader(name: string): number | string | string[] | undefined; + getHeaders(): OutgoingHttpHeaders; + getHeaderNames(): string[]; + hasHeader(name: string): boolean; + removeHeader(name: string): void; + addTrailers(headers: OutgoingHttpHeaders | Array<[string, string]>): void; + flushHeaders(): void; + } + + // https://github.com/nodejs/node/blob/master/lib/_http_server.js#L108-L256 + export class ServerResponse extends OutgoingMessage { + statusCode: number; + statusMessage: string; + + constructor(req: IncomingMessage); + + assignSocket(socket: net.Socket): void; + detachSocket(socket: net.Socket): void; + // https://github.com/nodejs/node/blob/master/test/parallel/test-http-write-callbacks.js#L53 + // no args in writeContinue callback + writeContinue(callback?: () => void): void; + writeHead(statusCode: number, reasonPhrase?: string, headers?: OutgoingHttpHeaders): void; + writeHead(statusCode: number, headers?: OutgoingHttpHeaders): void; + } + + // https://github.com/nodejs/node/blob/master/lib/_http_client.js#L77 + export class ClientRequest extends OutgoingMessage { + connection: net.Socket; + socket: net.Socket; + aborted: number; + + constructor(url: string | URL | ClientRequestArgs, cb?: (res: IncomingMessage) => void); + + abort(): void; + onSocket(socket: net.Socket): void; + setTimeout(timeout: number, callback?: () => void): this; + setNoDelay(noDelay?: boolean): void; + setSocketKeepAlive(enable?: boolean, initialDelay?: number): void; + } + + export class IncomingMessage extends stream.Readable { + constructor(socket: net.Socket); + + httpVersion: string; + httpVersionMajor: number; + httpVersionMinor: number; + connection: net.Socket; + headers: IncomingHttpHeaders; + rawHeaders: string[]; + trailers: { [key: string]: string | undefined }; + rawTrailers: string[]; + setTimeout(msecs: number, callback: () => void): this; + /** + * Only valid for request obtained from http.Server. + */ + method?: string; + /** + * Only valid for request obtained from http.Server. + */ + url?: string; + /** + * Only valid for response obtained from http.ClientRequest. + */ + statusCode?: number; + /** + * Only valid for response obtained from http.ClientRequest. + */ + statusMessage?: string; + socket: net.Socket; + destroy(error?: Error): void; + } + + /** + * @deprecated Use IncomingMessage + */ + export class ClientResponse extends IncomingMessage { } + + export interface AgentOptions { + /** + * Keep sockets around in a pool to be used by other requests in the future. Default = false + */ + keepAlive?: boolean; + /** + * When using HTTP KeepAlive, how often to send TCP KeepAlive packets over sockets being kept alive. Default = 1000. + * Only relevant if keepAlive is set to true. + */ + keepAliveMsecs?: number; + /** + * Maximum number of sockets to allow per host. Default for Node 0.10 is 5, default for Node 0.12 is Infinity + */ + maxSockets?: number; + /** + * Maximum number of sockets to leave open in a free state. Only relevant if keepAlive is set to true. Default = 256. + */ + maxFreeSockets?: number; + } + + export class Agent { + maxFreeSockets: number; + maxSockets: number; + sockets: any; + requests: any; + + constructor(opts?: AgentOptions); + + /** + * Destroy any sockets that are currently in use by the agent. + * It is usually not necessary to do this. However, if you are using an agent with KeepAlive enabled, + * then it is best to explicitly shut down the agent when you know that it will no longer be used. Otherwise, + * sockets may hang open for quite a long time before the server terminates them. + */ + destroy(): void; + } + + export var METHODS: string[]; + + export var STATUS_CODES: { + [errorCode: number]: string | undefined; + [errorCode: string]: string | undefined; + }; + + export function createServer(requestListener?: (request: IncomingMessage, response: ServerResponse) => void): Server; + export function createClient(port?: number, host?: string): any; + + // although RequestOptions are passed as ClientRequestArgs to ClientRequest directly, + // create interface RequestOptions would make the naming more clear to developers + export interface RequestOptions extends ClientRequestArgs { } + export function request(options: RequestOptions | string | URL, callback?: (res: IncomingMessage) => void): ClientRequest; + export function get(options: RequestOptions | string | URL, callback?: (res: IncomingMessage) => void): ClientRequest; + export var globalAgent: Agent; +} + +declare module "cluster" { + import * as child from "child_process"; + import * as events from "events"; + import * as net from "net"; + + // interfaces + export interface ClusterSettings { + execArgv?: string[]; // default: process.execArgv + exec?: string; + args?: string[]; + silent?: boolean; + stdio?: any[]; + uid?: number; + gid?: number; + inspectPort?: number | (() => number); + } + + export interface Address { + address: string; + port: number; + addressType: number | "udp4" | "udp6"; // 4, 6, -1, "udp4", "udp6" + } + + export class Worker extends events.EventEmitter { + id: number; + process: child.ChildProcess; + suicide: boolean; + send(message: any, sendHandle?: any, callback?: (error: Error) => void): boolean; + kill(signal?: string): void; + destroy(signal?: string): void; + disconnect(): void; + isConnected(): boolean; + isDead(): boolean; + exitedAfterDisconnect: boolean; + + /** + * events.EventEmitter + * 1. disconnect + * 2. error + * 3. exit + * 4. listening + * 5. message + * 6. online + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "disconnect", listener: () => void): this; + addListener(event: "error", listener: (error: Error) => void): this; + addListener(event: "exit", listener: (code: number, signal: string) => void): this; + addListener(event: "listening", listener: (address: Address) => void): this; + addListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + addListener(event: "online", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "disconnect"): boolean; + emit(event: "error", error: Error): boolean; + emit(event: "exit", code: number, signal: string): boolean; + emit(event: "listening", address: Address): boolean; + emit(event: "message", message: any, handle: net.Socket | net.Server): boolean; + emit(event: "online"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "disconnect", listener: () => void): this; + on(event: "error", listener: (error: Error) => void): this; + on(event: "exit", listener: (code: number, signal: string) => void): this; + on(event: "listening", listener: (address: Address) => void): this; + on(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + on(event: "online", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "disconnect", listener: () => void): this; + once(event: "error", listener: (error: Error) => void): this; + once(event: "exit", listener: (code: number, signal: string) => void): this; + once(event: "listening", listener: (address: Address) => void): this; + once(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + once(event: "online", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "disconnect", listener: () => void): this; + prependListener(event: "error", listener: (error: Error) => void): this; + prependListener(event: "exit", listener: (code: number, signal: string) => void): this; + prependListener(event: "listening", listener: (address: Address) => void): this; + prependListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + prependListener(event: "online", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "disconnect", listener: () => void): this; + prependOnceListener(event: "error", listener: (error: Error) => void): this; + prependOnceListener(event: "exit", listener: (code: number, signal: string) => void): this; + prependOnceListener(event: "listening", listener: (address: Address) => void): this; + prependOnceListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + prependOnceListener(event: "online", listener: () => void): this; + } + + export interface Cluster extends events.EventEmitter { + Worker: Worker; + disconnect(callback?: Function): void; + fork(env?: any): Worker; + isMaster: boolean; + isWorker: boolean; + // TODO: cluster.schedulingPolicy + settings: ClusterSettings; + setupMaster(settings?: ClusterSettings): void; + worker?: Worker; + workers?: { + [index: string]: Worker | undefined + }; + + /** + * events.EventEmitter + * 1. disconnect + * 2. exit + * 3. fork + * 4. listening + * 5. message + * 6. online + * 7. setup + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "disconnect", listener: (worker: Worker) => void): this; + addListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this; + addListener(event: "fork", listener: (worker: Worker) => void): this; + addListener(event: "listening", listener: (worker: Worker, address: Address) => void): this; + addListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + addListener(event: "online", listener: (worker: Worker) => void): this; + addListener(event: "setup", listener: (settings: any) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "disconnect", worker: Worker): boolean; + emit(event: "exit", worker: Worker, code: number, signal: string): boolean; + emit(event: "fork", worker: Worker): boolean; + emit(event: "listening", worker: Worker, address: Address): boolean; + emit(event: "message", worker: Worker, message: any, handle: net.Socket | net.Server): boolean; + emit(event: "online", worker: Worker): boolean; + emit(event: "setup", settings: any): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "disconnect", listener: (worker: Worker) => void): this; + on(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this; + on(event: "fork", listener: (worker: Worker) => void): this; + on(event: "listening", listener: (worker: Worker, address: Address) => void): this; + on(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + on(event: "online", listener: (worker: Worker) => void): this; + on(event: "setup", listener: (settings: any) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "disconnect", listener: (worker: Worker) => void): this; + once(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this; + once(event: "fork", listener: (worker: Worker) => void): this; + once(event: "listening", listener: (worker: Worker, address: Address) => void): this; + once(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + once(event: "online", listener: (worker: Worker) => void): this; + once(event: "setup", listener: (settings: any) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "disconnect", listener: (worker: Worker) => void): this; + prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this; + prependListener(event: "fork", listener: (worker: Worker) => void): this; + prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): this; + prependListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + prependListener(event: "online", listener: (worker: Worker) => void): this; + prependListener(event: "setup", listener: (settings: any) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "disconnect", listener: (worker: Worker) => void): this; + prependOnceListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this; + prependOnceListener(event: "fork", listener: (worker: Worker) => void): this; + prependOnceListener(event: "listening", listener: (worker: Worker, address: Address) => void): this; + prependOnceListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined. + prependOnceListener(event: "online", listener: (worker: Worker) => void): this; + prependOnceListener(event: "setup", listener: (settings: any) => void): this; + } + + export function disconnect(callback?: Function): void; + export function fork(env?: any): Worker; + export var isMaster: boolean; + export var isWorker: boolean; + // TODO: cluster.schedulingPolicy + export var settings: ClusterSettings; + export function setupMaster(settings?: ClusterSettings): void; + export var worker: Worker; + export var workers: { + [index: string]: Worker | undefined + }; + + /** + * events.EventEmitter + * 1. disconnect + * 2. exit + * 3. fork + * 4. listening + * 5. message + * 6. online + * 7. setup + */ + export function addListener(event: string, listener: (...args: any[]) => void): Cluster; + export function addListener(event: "disconnect", listener: (worker: Worker) => void): Cluster; + export function addListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster; + export function addListener(event: "fork", listener: (worker: Worker) => void): Cluster; + export function addListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster; + export function addListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined. + export function addListener(event: "online", listener: (worker: Worker) => void): Cluster; + export function addListener(event: "setup", listener: (settings: any) => void): Cluster; + + export function emit(event: string | symbol, ...args: any[]): boolean; + export function emit(event: "disconnect", worker: Worker): boolean; + export function emit(event: "exit", worker: Worker, code: number, signal: string): boolean; + export function emit(event: "fork", worker: Worker): boolean; + export function emit(event: "listening", worker: Worker, address: Address): boolean; + export function emit(event: "message", worker: Worker, message: any, handle: net.Socket | net.Server): boolean; + export function emit(event: "online", worker: Worker): boolean; + export function emit(event: "setup", settings: any): boolean; + + export function on(event: string, listener: (...args: any[]) => void): Cluster; + export function on(event: "disconnect", listener: (worker: Worker) => void): Cluster; + export function on(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster; + export function on(event: "fork", listener: (worker: Worker) => void): Cluster; + export function on(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster; + export function on(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined. + export function on(event: "online", listener: (worker: Worker) => void): Cluster; + export function on(event: "setup", listener: (settings: any) => void): Cluster; + + export function once(event: string, listener: (...args: any[]) => void): Cluster; + export function once(event: "disconnect", listener: (worker: Worker) => void): Cluster; + export function once(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster; + export function once(event: "fork", listener: (worker: Worker) => void): Cluster; + export function once(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster; + export function once(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined. + export function once(event: "online", listener: (worker: Worker) => void): Cluster; + export function once(event: "setup", listener: (settings: any) => void): Cluster; + + export function removeListener(event: string, listener: (...args: any[]) => void): Cluster; + export function removeAllListeners(event?: string): Cluster; + export function setMaxListeners(n: number): Cluster; + export function getMaxListeners(): number; + export function listeners(event: string): Function[]; + export function listenerCount(type: string): number; + + export function prependListener(event: string, listener: (...args: any[]) => void): Cluster; + export function prependListener(event: "disconnect", listener: (worker: Worker) => void): Cluster; + export function prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster; + export function prependListener(event: "fork", listener: (worker: Worker) => void): Cluster; + export function prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster; + export function prependListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined. + export function prependListener(event: "online", listener: (worker: Worker) => void): Cluster; + export function prependListener(event: "setup", listener: (settings: any) => void): Cluster; + + export function prependOnceListener(event: string, listener: (...args: any[]) => void): Cluster; + export function prependOnceListener(event: "disconnect", listener: (worker: Worker) => void): Cluster; + export function prependOnceListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster; + export function prependOnceListener(event: "fork", listener: (worker: Worker) => void): Cluster; + export function prependOnceListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster; + export function prependOnceListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined. + export function prependOnceListener(event: "online", listener: (worker: Worker) => void): Cluster; + export function prependOnceListener(event: "setup", listener: (settings: any) => void): Cluster; + + export function eventNames(): string[]; +} + +declare module "zlib" { + import * as stream from "stream"; + + export interface ZlibOptions { + flush?: number; // default: zlib.constants.Z_NO_FLUSH + finishFlush?: number; // default: zlib.constants.Z_FINISH + chunkSize?: number; // default: 16*1024 + windowBits?: number; + level?: number; // compression only + memLevel?: number; // compression only + strategy?: number; // compression only + dictionary?: Buffer | NodeJS.TypedArray | DataView | ArrayBuffer; // deflate/inflate only, empty dictionary by default + } + + export interface Zlib { + readonly bytesRead: number; + close(callback?: () => void): void; + flush(kind?: number | (() => void), callback?: () => void): void; + } + + export interface ZlibParams { + params(level: number, strategy: number, callback: () => void): void; + } + + export interface ZlibReset { + reset(): void; + } + + export interface Gzip extends stream.Transform, Zlib { } + export interface Gunzip extends stream.Transform, Zlib { } + export interface Deflate extends stream.Transform, Zlib, ZlibReset, ZlibParams { } + export interface Inflate extends stream.Transform, Zlib, ZlibReset { } + export interface DeflateRaw extends stream.Transform, Zlib, ZlibReset, ZlibParams { } + export interface InflateRaw extends stream.Transform, Zlib, ZlibReset { } + export interface Unzip extends stream.Transform, Zlib { } + + export function createGzip(options?: ZlibOptions): Gzip; + export function createGunzip(options?: ZlibOptions): Gunzip; + export function createDeflate(options?: ZlibOptions): Deflate; + export function createInflate(options?: ZlibOptions): Inflate; + export function createDeflateRaw(options?: ZlibOptions): DeflateRaw; + export function createInflateRaw(options?: ZlibOptions): InflateRaw; + export function createUnzip(options?: ZlibOptions): Unzip; + + type InputType = string | Buffer | DataView | ArrayBuffer | NodeJS.TypedArray; + export function deflate(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function deflate(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function deflateSync(buf: InputType, options?: ZlibOptions): Buffer; + export function deflateRaw(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function deflateRaw(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function deflateRawSync(buf: InputType, options?: ZlibOptions): Buffer; + export function gzip(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function gzip(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function gzipSync(buf: InputType, options?: ZlibOptions): Buffer; + export function gunzip(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function gunzip(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function gunzipSync(buf: InputType, options?: ZlibOptions): Buffer; + export function inflate(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function inflate(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function inflateSync(buf: InputType, options?: ZlibOptions): Buffer; + export function inflateRaw(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function inflateRaw(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function inflateRawSync(buf: InputType, options?: ZlibOptions): Buffer; + export function unzip(buf: InputType, callback: (error: Error | null, result: Buffer) => void): void; + export function unzip(buf: InputType, options: ZlibOptions, callback: (error: Error | null, result: Buffer) => void): void; + export function unzipSync(buf: InputType, options?: ZlibOptions): Buffer; + + export namespace constants { + // Allowed flush values. + + export const Z_NO_FLUSH: number; + export const Z_PARTIAL_FLUSH: number; + export const Z_SYNC_FLUSH: number; + export const Z_FULL_FLUSH: number; + export const Z_FINISH: number; + export const Z_BLOCK: number; + export const Z_TREES: number; + + // Return codes for the compression/decompression functions. Negative values are errors, positive values are used for special but normal events. + + export const Z_OK: number; + export const Z_STREAM_END: number; + export const Z_NEED_DICT: number; + export const Z_ERRNO: number; + export const Z_STREAM_ERROR: number; + export const Z_DATA_ERROR: number; + export const Z_MEM_ERROR: number; + export const Z_BUF_ERROR: number; + export const Z_VERSION_ERROR: number; + + // Compression levels. + + export const Z_NO_COMPRESSION: number; + export const Z_BEST_SPEED: number; + export const Z_BEST_COMPRESSION: number; + export const Z_DEFAULT_COMPRESSION: number; + + // Compression strategy. + + export const Z_FILTERED: number; + export const Z_HUFFMAN_ONLY: number; + export const Z_RLE: number; + export const Z_FIXED: number; + export const Z_DEFAULT_STRATEGY: number; + } + + // Constants + export var Z_NO_FLUSH: number; + export var Z_PARTIAL_FLUSH: number; + export var Z_SYNC_FLUSH: number; + export var Z_FULL_FLUSH: number; + export var Z_FINISH: number; + export var Z_BLOCK: number; + export var Z_TREES: number; + export var Z_OK: number; + export var Z_STREAM_END: number; + export var Z_NEED_DICT: number; + export var Z_ERRNO: number; + export var Z_STREAM_ERROR: number; + export var Z_DATA_ERROR: number; + export var Z_MEM_ERROR: number; + export var Z_BUF_ERROR: number; + export var Z_VERSION_ERROR: number; + export var Z_NO_COMPRESSION: number; + export var Z_BEST_SPEED: number; + export var Z_BEST_COMPRESSION: number; + export var Z_DEFAULT_COMPRESSION: number; + export var Z_FILTERED: number; + export var Z_HUFFMAN_ONLY: number; + export var Z_RLE: number; + export var Z_FIXED: number; + export var Z_DEFAULT_STRATEGY: number; + export var Z_BINARY: number; + export var Z_TEXT: number; + export var Z_ASCII: number; + export var Z_UNKNOWN: number; + export var Z_DEFLATED: number; +} + +declare module "os" { + export interface CpuInfo { + model: string; + speed: number; + times: { + user: number; + nice: number; + sys: number; + idle: number; + irq: number; + }; + } + + export interface NetworkInterfaceBase { + address: string; + netmask: string; + mac: string; + internal: boolean; + } + + export interface NetworkInterfaceInfoIPv4 extends NetworkInterfaceBase { + family: "IPv4"; + } + + export interface NetworkInterfaceInfoIPv6 extends NetworkInterfaceBase { + family: "IPv6"; + scopeid: number; + } + + export type NetworkInterfaceInfo = NetworkInterfaceInfoIPv4 | NetworkInterfaceInfoIPv6; + + export function hostname(): string; + export function loadavg(): number[]; + export function uptime(): number; + export function freemem(): number; + export function totalmem(): number; + export function cpus(): CpuInfo[]; + export function type(): string; + export function release(): string; + export function networkInterfaces(): { [index: string]: NetworkInterfaceInfo[] }; + export function homedir(): string; + export function userInfo(options?: { encoding: string }): { username: string, uid: number, gid: number, shell: any, homedir: string }; + export var constants: { + UV_UDP_REUSEADDR: number, + signals: { + SIGHUP: number; + SIGINT: number; + SIGQUIT: number; + SIGILL: number; + SIGTRAP: number; + SIGABRT: number; + SIGIOT: number; + SIGBUS: number; + SIGFPE: number; + SIGKILL: number; + SIGUSR1: number; + SIGSEGV: number; + SIGUSR2: number; + SIGPIPE: number; + SIGALRM: number; + SIGTERM: number; + SIGCHLD: number; + SIGSTKFLT: number; + SIGCONT: number; + SIGSTOP: number; + SIGTSTP: number; + SIGTTIN: number; + SIGTTOU: number; + SIGURG: number; + SIGXCPU: number; + SIGXFSZ: number; + SIGVTALRM: number; + SIGPROF: number; + SIGWINCH: number; + SIGIO: number; + SIGPOLL: number; + SIGPWR: number; + SIGSYS: number; + SIGUNUSED: number; + }, + errno: { + E2BIG: number; + EACCES: number; + EADDRINUSE: number; + EADDRNOTAVAIL: number; + EAFNOSUPPORT: number; + EAGAIN: number; + EALREADY: number; + EBADF: number; + EBADMSG: number; + EBUSY: number; + ECANCELED: number; + ECHILD: number; + ECONNABORTED: number; + ECONNREFUSED: number; + ECONNRESET: number; + EDEADLK: number; + EDESTADDRREQ: number; + EDOM: number; + EDQUOT: number; + EEXIST: number; + EFAULT: number; + EFBIG: number; + EHOSTUNREACH: number; + EIDRM: number; + EILSEQ: number; + EINPROGRESS: number; + EINTR: number; + EINVAL: number; + EIO: number; + EISCONN: number; + EISDIR: number; + ELOOP: number; + EMFILE: number; + EMLINK: number; + EMSGSIZE: number; + EMULTIHOP: number; + ENAMETOOLONG: number; + ENETDOWN: number; + ENETRESET: number; + ENETUNREACH: number; + ENFILE: number; + ENOBUFS: number; + ENODATA: number; + ENODEV: number; + ENOENT: number; + ENOEXEC: number; + ENOLCK: number; + ENOLINK: number; + ENOMEM: number; + ENOMSG: number; + ENOPROTOOPT: number; + ENOSPC: number; + ENOSR: number; + ENOSTR: number; + ENOSYS: number; + ENOTCONN: number; + ENOTDIR: number; + ENOTEMPTY: number; + ENOTSOCK: number; + ENOTSUP: number; + ENOTTY: number; + ENXIO: number; + EOPNOTSUPP: number; + EOVERFLOW: number; + EPERM: number; + EPIPE: number; + EPROTO: number; + EPROTONOSUPPORT: number; + EPROTOTYPE: number; + ERANGE: number; + EROFS: number; + ESPIPE: number; + ESRCH: number; + ESTALE: number; + ETIME: number; + ETIMEDOUT: number; + ETXTBSY: number; + EWOULDBLOCK: number; + EXDEV: number; + }, + }; + export function arch(): string; + export function platform(): NodeJS.Platform; + export function tmpdir(): string; + export const EOL: string; + export function endianness(): "BE" | "LE"; +} + +declare module "https" { + import * as tls from "tls"; + import * as events from "events"; + import * as http from "http"; + import { URL } from "url"; + + export type ServerOptions = tls.SecureContextOptions & tls.TlsOptions; + + export type RequestOptions = http.RequestOptions & tls.SecureContextOptions & { + rejectUnauthorized?: boolean; // Defaults to true + servername?: string; // SNI TLS Extension + }; + + export interface AgentOptions extends http.AgentOptions, tls.ConnectionOptions { + rejectUnauthorized?: boolean; + maxCachedSessions?: number; + } + + export class Agent extends http.Agent { + constructor(options?: AgentOptions); + options: AgentOptions; + } + + export class Server extends tls.Server { + setTimeout(callback: () => void): this; + setTimeout(msecs?: number, callback?: () => void): this; + timeout: number; + keepAliveTimeout: number; + } + + export function createServer(options: ServerOptions, requestListener?: (req: http.IncomingMessage, res: http.ServerResponse) => void): Server; + export function request(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest; + export function get(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest; + export var globalAgent: Agent; +} + +declare module "punycode" { + export function decode(string: string): string; + export function encode(string: string): string; + export function toUnicode(domain: string): string; + export function toASCII(domain: string): string; + export var ucs2: ucs2; + interface ucs2 { + decode(string: string): number[]; + encode(codePoints: number[]): string; + } + export var version: any; +} + +declare module "repl" { + import * as stream from "stream"; + import * as readline from "readline"; + + export interface ReplOptions { + prompt?: string; + input?: NodeJS.ReadableStream; + output?: NodeJS.WritableStream; + terminal?: boolean; + eval?: Function; + useColors?: boolean; + useGlobal?: boolean; + ignoreUndefined?: boolean; + writer?: Function; + completer?: Function; + replMode?: any; + breakEvalOnSigint?: any; + } + + export interface REPLServer extends readline.ReadLine { + context: any; + inputStream: NodeJS.ReadableStream; + outputStream: NodeJS.WritableStream; + + defineCommand(keyword: string, cmd: Function | { help: string, action: Function }): void; + displayPrompt(preserveCursor?: boolean): void; + + /** + * events.EventEmitter + * 1. exit + * 2. reset + */ + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "exit", listener: () => void): this; + addListener(event: "reset", listener: (...args: any[]) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "exit"): boolean; + emit(event: "reset", context: any): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "exit", listener: () => void): this; + on(event: "reset", listener: (...args: any[]) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "exit", listener: () => void): this; + once(event: "reset", listener: (...args: any[]) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "exit", listener: () => void): this; + prependListener(event: "reset", listener: (...args: any[]) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "exit", listener: () => void): this; + prependOnceListener(event: "reset", listener: (...args: any[]) => void): this; + } + + export function start(options?: string | ReplOptions): REPLServer; + + export class Recoverable extends SyntaxError { + err: Error; + + constructor(err: Error); + } +} + +declare module "readline" { + import * as events from "events"; + import * as stream from "stream"; + + export interface Key { + sequence?: string; + name?: string; + ctrl?: boolean; + meta?: boolean; + shift?: boolean; + } + + export interface ReadLine extends events.EventEmitter { + setPrompt(prompt: string): void; + prompt(preserveCursor?: boolean): void; + question(query: string, callback: (answer: string) => void): void; + pause(): ReadLine; + resume(): ReadLine; + close(): void; + write(data: string | Buffer, key?: Key): void; + + /** + * events.EventEmitter + * 1. close + * 2. line + * 3. pause + * 4. resume + * 5. SIGCONT + * 6. SIGINT + * 7. SIGTSTP + */ + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "line", listener: (input: any) => void): this; + addListener(event: "pause", listener: () => void): this; + addListener(event: "resume", listener: () => void): this; + addListener(event: "SIGCONT", listener: () => void): this; + addListener(event: "SIGINT", listener: () => void): this; + addListener(event: "SIGTSTP", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close"): boolean; + emit(event: "line", input: any): boolean; + emit(event: "pause"): boolean; + emit(event: "resume"): boolean; + emit(event: "SIGCONT"): boolean; + emit(event: "SIGINT"): boolean; + emit(event: "SIGTSTP"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: () => void): this; + on(event: "line", listener: (input: any) => void): this; + on(event: "pause", listener: () => void): this; + on(event: "resume", listener: () => void): this; + on(event: "SIGCONT", listener: () => void): this; + on(event: "SIGINT", listener: () => void): this; + on(event: "SIGTSTP", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: () => void): this; + once(event: "line", listener: (input: any) => void): this; + once(event: "pause", listener: () => void): this; + once(event: "resume", listener: () => void): this; + once(event: "SIGCONT", listener: () => void): this; + once(event: "SIGINT", listener: () => void): this; + once(event: "SIGTSTP", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "line", listener: (input: any) => void): this; + prependListener(event: "pause", listener: () => void): this; + prependListener(event: "resume", listener: () => void): this; + prependListener(event: "SIGCONT", listener: () => void): this; + prependListener(event: "SIGINT", listener: () => void): this; + prependListener(event: "SIGTSTP", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "line", listener: (input: any) => void): this; + prependOnceListener(event: "pause", listener: () => void): this; + prependOnceListener(event: "resume", listener: () => void): this; + prependOnceListener(event: "SIGCONT", listener: () => void): this; + prependOnceListener(event: "SIGINT", listener: () => void): this; + prependOnceListener(event: "SIGTSTP", listener: () => void): this; + } + + type Completer = (line: string) => CompleterResult; + type AsyncCompleter = (line: string, callback: (err: any, result: CompleterResult) => void) => any; + + export type CompleterResult = [string[], string]; + + export interface ReadLineOptions { + input: NodeJS.ReadableStream; + output?: NodeJS.WritableStream; + completer?: Completer | AsyncCompleter; + terminal?: boolean; + historySize?: number; + prompt?: string; + crlfDelay?: number; + removeHistoryDuplicates?: boolean; + } + + export function createInterface(input: NodeJS.ReadableStream, output?: NodeJS.WritableStream, completer?: Completer | AsyncCompleter, terminal?: boolean): ReadLine; + export function createInterface(options: ReadLineOptions): ReadLine; + + export function cursorTo(stream: NodeJS.WritableStream, x: number, y?: number): void; + export function emitKeypressEvents(stream: NodeJS.ReadableStream, interface?: ReadLine): void; + export function moveCursor(stream: NodeJS.WritableStream, dx: number | string, dy: number | string): void; + export function clearLine(stream: NodeJS.WritableStream, dir: number): void; + export function clearScreenDown(stream: NodeJS.WritableStream): void; +} + +declare module "vm" { + export interface Context { } + export interface ScriptOptions { + filename?: string; + lineOffset?: number; + columnOffset?: number; + displayErrors?: boolean; + timeout?: number; + cachedData?: Buffer; + produceCachedData?: boolean; + } + export interface RunningScriptOptions { + filename?: string; + lineOffset?: number; + columnOffset?: number; + displayErrors?: boolean; + timeout?: number; + } + export class Script { + constructor(code: string, options?: ScriptOptions); + runInContext(contextifiedSandbox: Context, options?: RunningScriptOptions): any; + runInNewContext(sandbox?: Context, options?: RunningScriptOptions): any; + runInThisContext(options?: RunningScriptOptions): any; + } + export function createContext(sandbox?: Context): Context; + export function isContext(sandbox: Context): boolean; + export function runInContext(code: string, contextifiedSandbox: Context, options?: RunningScriptOptions | string): any; + /** @deprecated */ + export function runInDebugContext(code: string): any; + export function runInNewContext(code: string, sandbox?: Context, options?: RunningScriptOptions | string): any; + export function runInThisContext(code: string, options?: RunningScriptOptions | string): any; +} + +declare module "child_process" { + import * as events from "events"; + import * as stream from "stream"; + import * as net from "net"; + + export interface ChildProcess extends events.EventEmitter { + stdin: stream.Writable; + stdout: stream.Readable; + stderr: stream.Readable; + stdio: [stream.Writable, stream.Readable, stream.Readable]; + killed: boolean; + pid: number; + kill(signal?: string): void; + send(message: any, callback?: (error: Error) => void): boolean; + send(message: any, sendHandle?: net.Socket | net.Server, callback?: (error: Error) => void): boolean; + send(message: any, sendHandle?: net.Socket | net.Server, options?: MessageOptions, callback?: (error: Error) => void): boolean; + connected: boolean; + disconnect(): void; + unref(): void; + ref(): void; + + /** + * events.EventEmitter + * 1. close + * 2. disconnect + * 3. error + * 4. exit + * 5. message + */ + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: (code: number, signal: string) => void): this; + addListener(event: "disconnect", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "exit", listener: (code: number, signal: string) => void): this; + addListener(event: "message", listener: (message: any, sendHandle: net.Socket | net.Server) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close", code: number, signal: string): boolean; + emit(event: "disconnect"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "exit", code: number, signal: string): boolean; + emit(event: "message", message: any, sendHandle: net.Socket | net.Server): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: (code: number, signal: string) => void): this; + on(event: "disconnect", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "exit", listener: (code: number, signal: string) => void): this; + on(event: "message", listener: (message: any, sendHandle: net.Socket | net.Server) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: (code: number, signal: string) => void): this; + once(event: "disconnect", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "exit", listener: (code: number, signal: string) => void): this; + once(event: "message", listener: (message: any, sendHandle: net.Socket | net.Server) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: (code: number, signal: string) => void): this; + prependListener(event: "disconnect", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "exit", listener: (code: number, signal: string) => void): this; + prependListener(event: "message", listener: (message: any, sendHandle: net.Socket | net.Server) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: (code: number, signal: string) => void): this; + prependOnceListener(event: "disconnect", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "exit", listener: (code: number, signal: string) => void): this; + prependOnceListener(event: "message", listener: (message: any, sendHandle: net.Socket | net.Server) => void): this; + } + + export interface MessageOptions { + keepOpen?: boolean; + } + + export interface SpawnOptions { + argv0?: string; + cwd?: string; + env?: any; + stdio?: any; + detached?: boolean; + uid?: number; + gid?: number; + shell?: boolean | string; + windowsVerbatimArguments?: boolean; + windowsHide?: boolean; + } + + export function spawn(command: string, args?: ReadonlyArray, options?: SpawnOptions): ChildProcess; + + export interface ExecOptions { + cwd?: string; + env?: any; + shell?: string; + timeout?: number; + maxBuffer?: number; + killSignal?: string; + uid?: number; + gid?: number; + windowsHide?: boolean; + } + + export interface ExecOptionsWithStringEncoding extends ExecOptions { + encoding: BufferEncoding; + } + + export interface ExecOptionsWithBufferEncoding extends ExecOptions { + encoding: string | null; // specify `null`. + } + + export interface ExecException extends Error { + cmd?: string; + killed?: boolean; + code?: number; + signal?: string; + } + + // no `options` definitely means stdout/stderr are `string`. + export function exec(command: string, callback?: (error: ExecException | null, stdout: string, stderr: string) => void): ChildProcess; + + // `options` with `"buffer"` or `null` for `encoding` means stdout/stderr are definitely `Buffer`. + export function exec(command: string, options: { encoding: "buffer" | null } & ExecOptions, callback?: (error: ExecException | null, stdout: Buffer, stderr: Buffer) => void): ChildProcess; + + // `options` with well known `encoding` means stdout/stderr are definitely `string`. + export function exec(command: string, options: { encoding: BufferEncoding } & ExecOptions, callback?: (error: ExecException | null, stdout: string, stderr: string) => void): ChildProcess; + + // `options` with an `encoding` whose type is `string` means stdout/stderr could either be `Buffer` or `string`. + // There is no guarantee the `encoding` is unknown as `string` is a superset of `BufferEncoding`. + export function exec(command: string, options: { encoding: string } & ExecOptions, callback?: (error: ExecException | null, stdout: string | Buffer, stderr: string | Buffer) => void): ChildProcess; + + // `options` without an `encoding` means stdout/stderr are definitely `string`. + export function exec(command: string, options: ExecOptions, callback?: (error: ExecException | null, stdout: string, stderr: string) => void): ChildProcess; + + // fallback if nothing else matches. Worst case is always `string | Buffer`. + export function exec(command: string, options: ({ encoding?: string | null } & ExecOptions) | undefined | null, callback?: (error: ExecException | null, stdout: string | Buffer, stderr: string | Buffer) => void): ChildProcess; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace exec { + export function __promisify__(command: string): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(command: string, options: { encoding: "buffer" | null } & ExecOptions): Promise<{ stdout: Buffer, stderr: Buffer }>; + export function __promisify__(command: string, options: { encoding: BufferEncoding } & ExecOptions): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(command: string, options: ExecOptions): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(command: string, options?: ({ encoding?: string | null } & ExecOptions) | null): Promise<{ stdout: string | Buffer, stderr: string | Buffer }>; + } + + export interface ExecFileOptions { + cwd?: string; + env?: any; + timeout?: number; + maxBuffer?: number; + killSignal?: string; + uid?: number; + gid?: number; + windowsHide?: boolean; + windowsVerbatimArguments?: boolean; + } + export interface ExecFileOptionsWithStringEncoding extends ExecFileOptions { + encoding: BufferEncoding; + } + export interface ExecFileOptionsWithBufferEncoding extends ExecFileOptions { + encoding: 'buffer' | null; + } + export interface ExecFileOptionsWithOtherEncoding extends ExecFileOptions { + encoding: string; + } + + export function execFile(file: string): ChildProcess; + export function execFile(file: string, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null): ChildProcess; + export function execFile(file: string, args?: ReadonlyArray | null): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null): ChildProcess; + + // no `options` definitely means stdout/stderr are `string`. + export function execFile(file: string, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + + // `options` with `"buffer"` or `null` for `encoding` means stdout/stderr are definitely `Buffer`. + export function execFile(file: string, options: ExecFileOptionsWithBufferEncoding, callback: (error: Error | null, stdout: Buffer, stderr: Buffer) => void): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ExecFileOptionsWithBufferEncoding, callback: (error: Error | null, stdout: Buffer, stderr: Buffer) => void): ChildProcess; + + // `options` with well known `encoding` means stdout/stderr are definitely `string`. + export function execFile(file: string, options: ExecFileOptionsWithStringEncoding, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ExecFileOptionsWithStringEncoding, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + + // `options` with an `encoding` whose type is `string` means stdout/stderr could either be `Buffer` or `string`. + // There is no guarantee the `encoding` is unknown as `string` is a superset of `BufferEncoding`. + export function execFile(file: string, options: ExecFileOptionsWithOtherEncoding, callback: (error: Error | null, stdout: string | Buffer, stderr: string | Buffer) => void): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ExecFileOptionsWithOtherEncoding, callback: (error: Error | null, stdout: string | Buffer, stderr: string | Buffer) => void): ChildProcess; + + // `options` without an `encoding` means stdout/stderr are definitely `string`. + export function execFile(file: string, options: ExecFileOptions, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ExecFileOptions, callback: (error: Error | null, stdout: string, stderr: string) => void): ChildProcess; + + // fallback if nothing else matches. Worst case is always `string | Buffer`. + export function execFile(file: string, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null, callback: ((error: Error | null, stdout: string | Buffer, stderr: string | Buffer) => void) | undefined | null): ChildProcess; + export function execFile(file: string, args: ReadonlyArray | undefined | null, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null, callback: ((error: Error | null, stdout: string | Buffer, stderr: string | Buffer) => void) | undefined | null): ChildProcess; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace execFile { + export function __promisify__(file: string): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, args: string[] | undefined | null): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, options: ExecFileOptionsWithBufferEncoding): Promise<{ stdout: Buffer, stderr: Buffer }>; + export function __promisify__(file: string, args: string[] | undefined | null, options: ExecFileOptionsWithBufferEncoding): Promise<{ stdout: Buffer, stderr: Buffer }>; + export function __promisify__(file: string, options: ExecFileOptionsWithStringEncoding): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, args: string[] | undefined | null, options: ExecFileOptionsWithStringEncoding): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, options: ExecFileOptionsWithOtherEncoding): Promise<{ stdout: string | Buffer, stderr: string | Buffer }>; + export function __promisify__(file: string, args: string[] | undefined | null, options: ExecFileOptionsWithOtherEncoding): Promise<{ stdout: string | Buffer, stderr: string | Buffer }>; + export function __promisify__(file: string, options: ExecFileOptions): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, args: string[] | undefined | null, options: ExecFileOptions): Promise<{ stdout: string, stderr: string }>; + export function __promisify__(file: string, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null): Promise<{ stdout: string | Buffer, stderr: string | Buffer }>; + export function __promisify__(file: string, args: string[] | undefined | null, options: ({ encoding?: string | null } & ExecFileOptions) | undefined | null): Promise<{ stdout: string | Buffer, stderr: string | Buffer }>; + } + + export interface ForkOptions { + cwd?: string; + env?: any; + execPath?: string; + execArgv?: string[]; + silent?: boolean; + stdio?: any[]; + uid?: number; + gid?: number; + windowsVerbatimArguments?: boolean; + } + export function fork(modulePath: string, args?: ReadonlyArray, options?: ForkOptions): ChildProcess; + + export interface SpawnSyncOptions { + argv0?: string; + cwd?: string; + input?: string | Buffer; + stdio?: any; + env?: any; + uid?: number; + gid?: number; + timeout?: number; + killSignal?: string; + maxBuffer?: number; + encoding?: string; + shell?: boolean | string; + windowsHide?: boolean; + windowsVerbatimArguments?: boolean; + } + export interface SpawnSyncOptionsWithStringEncoding extends SpawnSyncOptions { + encoding: BufferEncoding; + } + export interface SpawnSyncOptionsWithBufferEncoding extends SpawnSyncOptions { + encoding: string; // specify `null`. + } + export interface SpawnSyncReturns { + pid: number; + output: string[]; + stdout: T; + stderr: T; + status: number; + signal: string; + error: Error; + } + export function spawnSync(command: string): SpawnSyncReturns; + export function spawnSync(command: string, options?: SpawnSyncOptionsWithStringEncoding): SpawnSyncReturns; + export function spawnSync(command: string, options?: SpawnSyncOptionsWithBufferEncoding): SpawnSyncReturns; + export function spawnSync(command: string, options?: SpawnSyncOptions): SpawnSyncReturns; + export function spawnSync(command: string, args?: ReadonlyArray, options?: SpawnSyncOptionsWithStringEncoding): SpawnSyncReturns; + export function spawnSync(command: string, args?: ReadonlyArray, options?: SpawnSyncOptionsWithBufferEncoding): SpawnSyncReturns; + export function spawnSync(command: string, args?: ReadonlyArray, options?: SpawnSyncOptions): SpawnSyncReturns; + + export interface ExecSyncOptions { + cwd?: string; + input?: string | Buffer; + stdio?: any; + env?: any; + shell?: string; + uid?: number; + gid?: number; + timeout?: number; + killSignal?: string; + maxBuffer?: number; + encoding?: string; + windowsHide?: boolean; + } + export interface ExecSyncOptionsWithStringEncoding extends ExecSyncOptions { + encoding: BufferEncoding; + } + export interface ExecSyncOptionsWithBufferEncoding extends ExecSyncOptions { + encoding: string; // specify `null`. + } + export function execSync(command: string): Buffer; + export function execSync(command: string, options?: ExecSyncOptionsWithStringEncoding): string; + export function execSync(command: string, options?: ExecSyncOptionsWithBufferEncoding): Buffer; + export function execSync(command: string, options?: ExecSyncOptions): Buffer; + + export interface ExecFileSyncOptions { + cwd?: string; + input?: string | Buffer; + stdio?: any; + env?: any; + uid?: number; + gid?: number; + timeout?: number; + killSignal?: string; + maxBuffer?: number; + encoding?: string; + windowsHide?: boolean; + } + export interface ExecFileSyncOptionsWithStringEncoding extends ExecFileSyncOptions { + encoding: BufferEncoding; + } + export interface ExecFileSyncOptionsWithBufferEncoding extends ExecFileSyncOptions { + encoding: string; // specify `null`. + } + export function execFileSync(command: string): Buffer; + export function execFileSync(command: string, options?: ExecFileSyncOptionsWithStringEncoding): string; + export function execFileSync(command: string, options?: ExecFileSyncOptionsWithBufferEncoding): Buffer; + export function execFileSync(command: string, options?: ExecFileSyncOptions): Buffer; + export function execFileSync(command: string, args?: ReadonlyArray, options?: ExecFileSyncOptionsWithStringEncoding): string; + export function execFileSync(command: string, args?: ReadonlyArray, options?: ExecFileSyncOptionsWithBufferEncoding): Buffer; + export function execFileSync(command: string, args?: ReadonlyArray, options?: ExecFileSyncOptions): Buffer; +} + +declare module "url" { + import { ParsedUrlQuery } from 'querystring'; + + export interface UrlObjectCommon { + auth?: string; + hash?: string; + host?: string; + hostname?: string; + href?: string; + path?: string; + pathname?: string; + protocol?: string; + search?: string; + slashes?: boolean; + } + + // Input to `url.format` + export interface UrlObject extends UrlObjectCommon { + port?: string | number; + query?: string | null | { [key: string]: any }; + } + + // Output of `url.parse` + export interface Url extends UrlObjectCommon { + port?: string; + query?: string | null | ParsedUrlQuery; + } + + export interface UrlWithParsedQuery extends Url { + query: ParsedUrlQuery; + } + + export interface UrlWithStringQuery extends Url { + query: string | null; + } + + export function parse(urlStr: string): UrlWithStringQuery; + export function parse(urlStr: string, parseQueryString: false | undefined, slashesDenoteHost?: boolean): UrlWithStringQuery; + export function parse(urlStr: string, parseQueryString: true, slashesDenoteHost?: boolean): UrlWithParsedQuery; + export function parse(urlStr: string, parseQueryString: boolean, slashesDenoteHost?: boolean): Url; + + export function format(URL: URL, options?: URLFormatOptions): string; + export function format(urlObject: UrlObject | string): string; + export function resolve(from: string, to: string): string; + + export function domainToASCII(domain: string): string; + export function domainToUnicode(domain: string): string; + + export interface URLFormatOptions { + auth?: boolean; + fragment?: boolean; + search?: boolean; + unicode?: boolean; + } + + export class URL { + constructor(input: string, base?: string | URL); + hash: string; + host: string; + hostname: string; + href: string; + readonly origin: string; + password: string; + pathname: string; + port: string; + protocol: string; + search: string; + readonly searchParams: URLSearchParams; + username: string; + toString(): string; + toJSON(): string; + } + + export class URLSearchParams implements Iterable<[string, string]> { + constructor(init?: URLSearchParams | string | { [key: string]: string | string[] | undefined } | Iterable<[string, string]> | Array<[string, string]>); + append(name: string, value: string): void; + delete(name: string): void; + entries(): IterableIterator<[string, string]>; + forEach(callback: (value: string, name: string, searchParams: this) => void): void; + get(name: string): string | null; + getAll(name: string): string[]; + has(name: string): boolean; + keys(): IterableIterator; + set(name: string, value: string): void; + sort(): void; + toString(): string; + values(): IterableIterator; + [Symbol.iterator](): IterableIterator<[string, string]>; + } +} + +declare module "dns" { + // Supported getaddrinfo flags. + export const ADDRCONFIG: number; + export const V4MAPPED: number; + + export interface LookupOptions { + family?: number; + hints?: number; + all?: boolean; + } + + export interface LookupOneOptions extends LookupOptions { + all?: false; + } + + export interface LookupAllOptions extends LookupOptions { + all: true; + } + + export interface LookupAddress { + address: string; + family: number; + } + + export function lookup(hostname: string, family: number, callback: (err: NodeJS.ErrnoException, address: string, family: number) => void): void; + export function lookup(hostname: string, options: LookupOneOptions, callback: (err: NodeJS.ErrnoException, address: string, family: number) => void): void; + export function lookup(hostname: string, options: LookupAllOptions, callback: (err: NodeJS.ErrnoException, addresses: LookupAddress[]) => void): void; + export function lookup(hostname: string, options: LookupOptions, callback: (err: NodeJS.ErrnoException, address: string | LookupAddress[], family: number) => void): void; + export function lookup(hostname: string, callback: (err: NodeJS.ErrnoException, address: string, family: number) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace lookup { + export function __promisify__(hostname: string, options: LookupAllOptions): Promise<{ address: LookupAddress[] }>; + export function __promisify__(hostname: string, options?: LookupOneOptions | number): Promise<{ address: string, family: number }>; + export function __promisify__(hostname: string, options?: LookupOptions | number): Promise<{ address: string | LookupAddress[], family?: number }>; + } + + export function lookupService(address: string, port: number, callback: (err: NodeJS.ErrnoException, hostname: string, service: string) => void): void; + + export namespace lookupService { + export function __promisify__(address: string, port: number): Promise<{ hostname: string, service: string }>; + } + + export interface ResolveOptions { + ttl: boolean; + } + + export interface ResolveWithTtlOptions extends ResolveOptions { + ttl: true; + } + + export interface RecordWithTtl { + address: string; + ttl: number; + } + + export interface AnyRecordWithTtl extends RecordWithTtl { + type: "A" | "AAAA"; + } + + export interface MxRecord { + priority: number; + exchange: string; + } + + export interface AnyMxRecord extends MxRecord { + type: "MX"; + } + + export interface NaptrRecord { + flags: string; + service: string; + regexp: string; + replacement: string; + order: number; + preference: number; + } + + export interface AnyNaptrRecord extends NaptrRecord { + type: "NAPTR"; + } + + export interface SoaRecord { + nsname: string; + hostmaster: string; + serial: number; + refresh: number; + retry: number; + expire: number; + minttl: number; + } + + export interface AnySoaRecord extends SoaRecord { + type: "SOA"; + } + + export interface SrvRecord { + priority: number; + weight: number; + port: number; + name: string; + } + + export interface AnySrvRecord extends SrvRecord { + type: "SRV"; + } + + export interface AnyTxtRecord { + type: "TXT"; + entries: string[]; + } + + export function resolve(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "A", callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "AAAA", callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "ANY", callback: (err: NodeJS.ErrnoException, addresses: ReadonlyArray) => void): void; + export function resolve(hostname: string, rrtype: "CNAME", callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "MX", callback: (err: NodeJS.ErrnoException, addresses: MxRecord[]) => void): void; + export function resolve(hostname: string, rrtype: "NAPTR", callback: (err: NodeJS.ErrnoException, addresses: NaptrRecord[]) => void): void; + export function resolve(hostname: string, rrtype: "NS", callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "PTR", callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve(hostname: string, rrtype: "SOA", callback: (err: NodeJS.ErrnoException, addresses: SoaRecord) => void): void; + export function resolve(hostname: string, rrtype: "SRV", callback: (err: NodeJS.ErrnoException, addresses: SrvRecord[]) => void): void; + export function resolve(hostname: string, rrtype: "TXT", callback: (err: NodeJS.ErrnoException, addresses: string[][]) => void): void; + export function resolve(hostname: string, rrtype: string, callback: (err: NodeJS.ErrnoException, addresses: string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][]) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace resolve { + export function __promisify__(hostname: string, rrtype?: "A" | "AAAA" | "CNAME" | "NS" | "PTR"): Promise; + export function __promisify__(hostname: string, rrtype: "ANY"): Promise>; + export function __promisify__(hostname: string, rrtype: "MX"): Promise; + export function __promisify__(hostname: string, rrtype: "NAPTR"): Promise; + export function __promisify__(hostname: string, rrtype: "SOA"): Promise; + export function __promisify__(hostname: string, rrtype: "SRV"): Promise; + export function __promisify__(hostname: string, rrtype: "TXT"): Promise; + export function __promisify__(hostname: string, rrtype?: string): Promise; + } + + export function resolve4(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve4(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException, addresses: RecordWithTtl[]) => void): void; + export function resolve4(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException, addresses: string[] | RecordWithTtl[]) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace resolve4 { + export function __promisify__(hostname: string): Promise; + export function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise; + export function __promisify__(hostname: string, options?: ResolveOptions): Promise; + } + + export function resolve6(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolve6(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException, addresses: RecordWithTtl[]) => void): void; + export function resolve6(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException, addresses: string[] | RecordWithTtl[]) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace resolve6 { + export function __promisify__(hostname: string): Promise; + export function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise; + export function __promisify__(hostname: string, options?: ResolveOptions): Promise; + } + + export function resolveAny(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: ReadonlyArray) => void): void; + export function resolveCname(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolveMx(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: MxRecord[]) => void): void; + export function resolveNaptr(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: NaptrRecord[]) => void): void; + export function resolveNs(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolvePtr(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[]) => void): void; + export function resolveSoa(hostname: string, callback: (err: NodeJS.ErrnoException, address: SoaRecord) => void): void; + export function resolveSrv(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: SrvRecord[]) => void): void; + export function resolveTxt(hostname: string, callback: (err: NodeJS.ErrnoException, addresses: string[][]) => void): void; + + export function reverse(ip: string, callback: (err: NodeJS.ErrnoException, hostnames: string[]) => void): void; + export function setServers(servers: string[]): void; + + // Error codes + export var NODATA: string; + export var FORMERR: string; + export var SERVFAIL: string; + export var NOTFOUND: string; + export var NOTIMP: string; + export var REFUSED: string; + export var BADQUERY: string; + export var BADNAME: string; + export var BADFAMILY: string; + export var BADRESP: string; + export var CONNREFUSED: string; + export var TIMEOUT: string; + export var EOF: string; + export var FILE: string; + export var NOMEM: string; + export var DESTRUCTION: string; + export var BADSTR: string; + export var BADFLAGS: string; + export var NONAME: string; + export var BADHINTS: string; + export var NOTINITIALIZED: string; + export var LOADIPHLPAPI: string; + export var ADDRGETNETWORKPARAMS: string; + export var CANCELLED: string; +} + +declare module "net" { + import * as stream from "stream"; + import * as events from "events"; + import * as dns from "dns"; + + type LookupFunction = (hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void) => void; + + export interface AddressInfo { + address: string; + family: string; + port: number; + } + + export interface SocketConstructorOpts { + fd?: number; + allowHalfOpen?: boolean; + readable?: boolean; + writable?: boolean; + } + + export interface TcpSocketConnectOpts { + port: number; + host?: string; + localAddress?: string; + localPort?: number; + hints?: number; + family?: number; + lookup?: LookupFunction; + } + + export interface IpcSocketConnectOpts { + path: string; + } + + export type SocketConnectOpts = TcpSocketConnectOpts | IpcSocketConnectOpts; + + export class Socket extends stream.Duplex { + constructor(options?: SocketConstructorOpts); + + // Extended base methods + write(buffer: Buffer): boolean; + write(buffer: Buffer, cb?: Function): boolean; + write(str: string, cb?: Function): boolean; + write(str: string, encoding?: string, cb?: Function): boolean; + write(str: string, encoding?: string, fd?: string): boolean; + write(data: any, encoding?: string, callback?: Function): void; + + connect(options: SocketConnectOpts, connectionListener?: Function): this; + connect(port: number, host: string, connectionListener?: Function): this; + connect(port: number, connectionListener?: Function): this; + connect(path: string, connectionListener?: Function): this; + + bufferSize: number; + setEncoding(encoding?: string): this; + pause(): this; + resume(): this; + setTimeout(timeout: number, callback?: Function): this; + setNoDelay(noDelay?: boolean): this; + setKeepAlive(enable?: boolean, initialDelay?: number): this; + address(): AddressInfo | string; + unref(): void; + ref(): void; + + remoteAddress?: string; + remoteFamily?: string; + remotePort?: number; + localAddress: string; + localPort: number; + bytesRead: number; + bytesWritten: number; + connecting: boolean; + destroyed: boolean; + + // Extended base methods + end(): void; + end(buffer: Buffer, cb?: Function): void; + end(str: string, cb?: Function): void; + end(str: string, encoding?: string, cb?: Function): void; + end(data?: any, encoding?: string): void; + + /** + * events.EventEmitter + * 1. close + * 2. connect + * 3. data + * 4. drain + * 5. end + * 6. error + * 7. lookup + * 8. timeout + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: (had_error: boolean) => void): this; + addListener(event: "connect", listener: () => void): this; + addListener(event: "data", listener: (data: Buffer) => void): this; + addListener(event: "drain", listener: () => void): this; + addListener(event: "end", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this; + addListener(event: "timeout", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close", had_error: boolean): boolean; + emit(event: "connect"): boolean; + emit(event: "data", data: Buffer): boolean; + emit(event: "drain"): boolean; + emit(event: "end"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "lookup", err: Error, address: string, family: string | number, host: string): boolean; + emit(event: "timeout"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: (had_error: boolean) => void): this; + on(event: "connect", listener: () => void): this; + on(event: "data", listener: (data: Buffer) => void): this; + on(event: "drain", listener: () => void): this; + on(event: "end", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this; + on(event: "timeout", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: (had_error: boolean) => void): this; + once(event: "connect", listener: () => void): this; + once(event: "data", listener: (data: Buffer) => void): this; + once(event: "drain", listener: () => void): this; + once(event: "end", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this; + once(event: "timeout", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: (had_error: boolean) => void): this; + prependListener(event: "connect", listener: () => void): this; + prependListener(event: "data", listener: (data: Buffer) => void): this; + prependListener(event: "drain", listener: () => void): this; + prependListener(event: "end", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this; + prependListener(event: "timeout", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: (had_error: boolean) => void): this; + prependOnceListener(event: "connect", listener: () => void): this; + prependOnceListener(event: "data", listener: (data: Buffer) => void): this; + prependOnceListener(event: "drain", listener: () => void): this; + prependOnceListener(event: "end", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this; + prependOnceListener(event: "timeout", listener: () => void): this; + } + + export interface ListenOptions { + port?: number; + host?: string; + backlog?: number; + path?: string; + exclusive?: boolean; + readableAll?: boolean; + writableAll?: boolean; + } + + // https://github.com/nodejs/node/blob/master/lib/net.js + export class Server extends events.EventEmitter { + constructor(connectionListener?: (socket: Socket) => void); + constructor(options?: { allowHalfOpen?: boolean, pauseOnConnect?: boolean }, connectionListener?: (socket: Socket) => void); + + listen(port?: number, hostname?: string, backlog?: number, listeningListener?: Function): this; + listen(port?: number, hostname?: string, listeningListener?: Function): this; + listen(port?: number, backlog?: number, listeningListener?: Function): this; + listen(port?: number, listeningListener?: Function): this; + listen(path: string, backlog?: number, listeningListener?: Function): this; + listen(path: string, listeningListener?: Function): this; + listen(options: ListenOptions, listeningListener?: Function): this; + listen(handle: any, backlog?: number, listeningListener?: Function): this; + listen(handle: any, listeningListener?: Function): this; + close(callback?: Function): this; + address(): AddressInfo | string; + getConnections(cb: (error: Error | null, count: number) => void): void; + ref(): this; + unref(): this; + maxConnections: number; + connections: number; + listening: boolean; + + /** + * events.EventEmitter + * 1. close + * 2. connection + * 3. error + * 4. listening + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "connection", listener: (socket: Socket) => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "listening", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close"): boolean; + emit(event: "connection", socket: Socket): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "listening"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: () => void): this; + on(event: "connection", listener: (socket: Socket) => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "listening", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: () => void): this; + once(event: "connection", listener: (socket: Socket) => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "listening", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "connection", listener: (socket: Socket) => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "listening", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "connection", listener: (socket: Socket) => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "listening", listener: () => void): this; + } + + export interface TcpNetConnectOpts extends TcpSocketConnectOpts, SocketConstructorOpts { + timeout?: number; + } + + export interface IpcNetConnectOpts extends IpcSocketConnectOpts, SocketConstructorOpts { + timeout?: number; + } + + export type NetConnectOpts = TcpNetConnectOpts | IpcNetConnectOpts; + + export function createServer(connectionListener?: (socket: Socket) => void): Server; + export function createServer(options?: { allowHalfOpen?: boolean, pauseOnConnect?: boolean }, connectionListener?: (socket: Socket) => void): Server; + export function connect(options: NetConnectOpts, connectionListener?: Function): Socket; + export function connect(port: number, host?: string, connectionListener?: Function): Socket; + export function connect(path: string, connectionListener?: Function): Socket; + export function createConnection(options: NetConnectOpts, connectionListener?: Function): Socket; + export function createConnection(port: number, host?: string, connectionListener?: Function): Socket; + export function createConnection(path: string, connectionListener?: Function): Socket; + export function isIP(input: string): number; + export function isIPv4(input: string): boolean; + export function isIPv6(input: string): boolean; +} + +declare module "dgram" { + import { AddressInfo } from "net"; + import * as dns from "dns"; + import * as events from "events"; + + export interface RemoteInfo { + address: string; + family: string; + port: number; + } + + export interface BindOptions { + port: number; + address?: string; + exclusive?: boolean; + } + + type SocketType = "udp4" | "udp6"; + + export interface SocketOptions { + type: SocketType; + reuseAddr?: boolean; + recvBufferSize?: number; + sendBufferSize?: number; + lookup?: (hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException, address: string, family: number) => void) => void; + } + + export function createSocket(type: SocketType, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket; + export function createSocket(options: SocketOptions, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket; + + export class Socket extends events.EventEmitter { + send(msg: Buffer | string | Uint8Array | any[], port: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void; + send(msg: Buffer | string | Uint8Array, offset: number, length: number, port: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void; + bind(port?: number, address?: string, callback?: () => void): void; + bind(port?: number, callback?: () => void): void; + bind(callback?: () => void): void; + bind(options: BindOptions, callback?: Function): void; + close(callback?: () => void): void; + address(): AddressInfo | string; + setBroadcast(flag: boolean): void; + setTTL(ttl: number): void; + setMulticastTTL(ttl: number): void; + setMulticastInterface(multicastInterface: string): void; + setMulticastLoopback(flag: boolean): void; + addMembership(multicastAddress: string, multicastInterface?: string): void; + dropMembership(multicastAddress: string, multicastInterface?: string): void; + ref(): this; + unref(): this; + setRecvBufferSize(size: number): void; + setSendBufferSize(size: number): void; + getRecvBufferSize(): number; + getSendBufferSize(): number; + + /** + * events.EventEmitter + * 1. close + * 2. error + * 3. listening + * 4. message + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "listening", listener: () => void): this; + addListener(event: "message", listener: (msg: Buffer, rinfo: AddressInfo) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "listening"): boolean; + emit(event: "message", msg: Buffer, rinfo: AddressInfo): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "listening", listener: () => void): this; + on(event: "message", listener: (msg: Buffer, rinfo: AddressInfo) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "listening", listener: () => void): this; + once(event: "message", listener: (msg: Buffer, rinfo: AddressInfo) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "listening", listener: () => void): this; + prependListener(event: "message", listener: (msg: Buffer, rinfo: AddressInfo) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "listening", listener: () => void): this; + prependOnceListener(event: "message", listener: (msg: Buffer, rinfo: AddressInfo) => void): this; + } +} + +declare module "fs" { + import * as stream from "stream"; + import * as events from "events"; + import { URL } from "url"; + + /** + * Valid types for path values in "fs". + */ + export type PathLike = string | Buffer | URL; + + export class Stats { + isFile(): boolean; + isDirectory(): boolean; + isBlockDevice(): boolean; + isCharacterDevice(): boolean; + isSymbolicLink(): boolean; + isFIFO(): boolean; + isSocket(): boolean; + dev: number; + ino: number; + mode: number; + nlink: number; + uid: number; + gid: number; + rdev: number; + size: number; + blksize: number; + blocks: number; + atimeMs: number; + mtimeMs: number; + ctimeMs: number; + birthtimeMs: number; + atime: Date; + mtime: Date; + ctime: Date; + birthtime: Date; + } + + export interface FSWatcher extends events.EventEmitter { + close(): void; + + /** + * events.EventEmitter + * 1. change + * 2. error + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "change", listener: (eventType: string, filename: string | Buffer) => void): this; + addListener(event: "error", listener: (error: Error) => void): this; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "change", listener: (eventType: string, filename: string | Buffer) => void): this; + on(event: "error", listener: (error: Error) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "change", listener: (eventType: string, filename: string | Buffer) => void): this; + once(event: "error", listener: (error: Error) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "change", listener: (eventType: string, filename: string | Buffer) => void): this; + prependListener(event: "error", listener: (error: Error) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "change", listener: (eventType: string, filename: string | Buffer) => void): this; + prependOnceListener(event: "error", listener: (error: Error) => void): this; + } + + export class ReadStream extends stream.Readable { + close(): void; + bytesRead: number; + path: string | Buffer; + + /** + * events.EventEmitter + * 1. open + * 2. close + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "open", listener: (fd: number) => void): this; + addListener(event: "close", listener: () => void): this; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "open", listener: (fd: number) => void): this; + on(event: "close", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "open", listener: (fd: number) => void): this; + once(event: "close", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "open", listener: (fd: number) => void): this; + prependListener(event: "close", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "open", listener: (fd: number) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + } + + export class WriteStream extends stream.Writable { + close(): void; + bytesWritten: number; + path: string | Buffer; + + /** + * events.EventEmitter + * 1. open + * 2. close + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "open", listener: (fd: number) => void): this; + addListener(event: "close", listener: () => void): this; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "open", listener: (fd: number) => void): this; + on(event: "close", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "open", listener: (fd: number) => void): this; + once(event: "close", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "open", listener: (fd: number) => void): this; + prependListener(event: "close", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "open", listener: (fd: number) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + } + + /** + * Asynchronous rename(2) - Change the name or location of a file or directory. + * @param oldPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function rename(oldPath: PathLike, newPath: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace rename { + /** + * Asynchronous rename(2) - Change the name or location of a file or directory. + * @param oldPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function __promisify__(oldPath: PathLike, newPath: PathLike): Promise; + } + + /** + * Synchronous rename(2) - Change the name or location of a file or directory. + * @param oldPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function renameSync(oldPath: PathLike, newPath: PathLike): void; + + /** + * Asynchronous truncate(2) - Truncate a file to a specified length. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param len If not specified, defaults to `0`. + */ + export function truncate(path: PathLike, len: number | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronous truncate(2) - Truncate a file to a specified length. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function truncate(path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace truncate { + /** + * Asynchronous truncate(2) - Truncate a file to a specified length. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param len If not specified, defaults to `0`. + */ + export function __promisify__(path: PathLike, len?: number | null): Promise; + } + + /** + * Synchronous truncate(2) - Truncate a file to a specified length. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param len If not specified, defaults to `0`. + */ + export function truncateSync(path: PathLike, len?: number | null): void; + + /** + * Asynchronous ftruncate(2) - Truncate a file to a specified length. + * @param fd A file descriptor. + * @param len If not specified, defaults to `0`. + */ + export function ftruncate(fd: number, len: number | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronous ftruncate(2) - Truncate a file to a specified length. + * @param fd A file descriptor. + */ + export function ftruncate(fd: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace ftruncate { + /** + * Asynchronous ftruncate(2) - Truncate a file to a specified length. + * @param fd A file descriptor. + * @param len If not specified, defaults to `0`. + */ + export function __promisify__(fd: number, len?: number | null): Promise; + } + + /** + * Synchronous ftruncate(2) - Truncate a file to a specified length. + * @param fd A file descriptor. + * @param len If not specified, defaults to `0`. + */ + export function ftruncateSync(fd: number, len?: number | null): void; + + /** + * Asynchronous chown(2) - Change ownership of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function chown(path: PathLike, uid: number, gid: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace chown { + /** + * Asynchronous chown(2) - Change ownership of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike, uid: number, gid: number): Promise; + } + + /** + * Synchronous chown(2) - Change ownership of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function chownSync(path: PathLike, uid: number, gid: number): void; + + /** + * Asynchronous fchown(2) - Change ownership of a file. + * @param fd A file descriptor. + */ + export function fchown(fd: number, uid: number, gid: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace fchown { + /** + * Asynchronous fchown(2) - Change ownership of a file. + * @param fd A file descriptor. + */ + export function __promisify__(fd: number, uid: number, gid: number): Promise; + } + + /** + * Synchronous fchown(2) - Change ownership of a file. + * @param fd A file descriptor. + */ + export function fchownSync(fd: number, uid: number, gid: number): void; + + /** + * Asynchronous lchown(2) - Change ownership of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function lchown(path: PathLike, uid: number, gid: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace lchown { + /** + * Asynchronous lchown(2) - Change ownership of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike, uid: number, gid: number): Promise; + } + + /** + * Synchronous lchown(2) - Change ownership of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function lchownSync(path: PathLike, uid: number, gid: number): void; + + /** + * Asynchronous chmod(2) - Change permissions of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function chmod(path: PathLike, mode: string | number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace chmod { + /** + * Asynchronous chmod(2) - Change permissions of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function __promisify__(path: PathLike, mode: string | number): Promise; + } + + /** + * Synchronous chmod(2) - Change permissions of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function chmodSync(path: PathLike, mode: string | number): void; + + /** + * Asynchronous fchmod(2) - Change permissions of a file. + * @param fd A file descriptor. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function fchmod(fd: number, mode: string | number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace fchmod { + /** + * Asynchronous fchmod(2) - Change permissions of a file. + * @param fd A file descriptor. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function __promisify__(fd: number, mode: string | number): Promise; + } + + /** + * Synchronous fchmod(2) - Change permissions of a file. + * @param fd A file descriptor. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function fchmodSync(fd: number, mode: string | number): void; + + /** + * Asynchronous lchmod(2) - Change permissions of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function lchmod(path: PathLike, mode: string | number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace lchmod { + /** + * Asynchronous lchmod(2) - Change permissions of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function __promisify__(path: PathLike, mode: string | number): Promise; + } + + /** + * Synchronous lchmod(2) - Change permissions of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + export function lchmodSync(path: PathLike, mode: string | number): void; + + /** + * Asynchronous stat(2) - Get file status. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function stat(path: PathLike, callback: (err: NodeJS.ErrnoException, stats: Stats) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace stat { + /** + * Asynchronous stat(2) - Get file status. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike): Promise; + } + + /** + * Synchronous stat(2) - Get file status. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function statSync(path: PathLike): Stats; + + /** + * Asynchronous fstat(2) - Get file status. + * @param fd A file descriptor. + */ + export function fstat(fd: number, callback: (err: NodeJS.ErrnoException, stats: Stats) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace fstat { + /** + * Asynchronous fstat(2) - Get file status. + * @param fd A file descriptor. + */ + export function __promisify__(fd: number): Promise; + } + + /** + * Synchronous fstat(2) - Get file status. + * @param fd A file descriptor. + */ + export function fstatSync(fd: number): Stats; + + /** + * Asynchronous lstat(2) - Get file status. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function lstat(path: PathLike, callback: (err: NodeJS.ErrnoException, stats: Stats) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace lstat { + /** + * Asynchronous lstat(2) - Get file status. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike): Promise; + } + + /** + * Synchronous lstat(2) - Get file status. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function lstatSync(path: PathLike): Stats; + + /** + * Asynchronous link(2) - Create a new link (also known as a hard link) to an existing file. + * @param existingPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function link(existingPath: PathLike, newPath: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace link { + /** + * Asynchronous link(2) - Create a new link (also known as a hard link) to an existing file. + * @param existingPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function link(existingPath: PathLike, newPath: PathLike): Promise; + } + + /** + * Synchronous link(2) - Create a new link (also known as a hard link) to an existing file. + * @param existingPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function linkSync(existingPath: PathLike, newPath: PathLike): void; + + /** + * Asynchronous symlink(2) - Create a new symbolic link to an existing file. + * @param target A path to an existing file. If a URL is provided, it must use the `file:` protocol. + * @param path A path to the new symlink. If a URL is provided, it must use the `file:` protocol. + * @param type May be set to `'dir'`, `'file'`, or `'junction'` (default is `'file'`) and is only available on Windows (ignored on other platforms). + * When using `'junction'`, the `target` argument will automatically be normalized to an absolute path. + */ + export function symlink(target: PathLike, path: PathLike, type: symlink.Type | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronous symlink(2) - Create a new symbolic link to an existing file. + * @param target A path to an existing file. If a URL is provided, it must use the `file:` protocol. + * @param path A path to the new symlink. If a URL is provided, it must use the `file:` protocol. + */ + export function symlink(target: PathLike, path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace symlink { + /** + * Asynchronous symlink(2) - Create a new symbolic link to an existing file. + * @param target A path to an existing file. If a URL is provided, it must use the `file:` protocol. + * @param path A path to the new symlink. If a URL is provided, it must use the `file:` protocol. + * @param type May be set to `'dir'`, `'file'`, or `'junction'` (default is `'file'`) and is only available on Windows (ignored on other platforms). + * When using `'junction'`, the `target` argument will automatically be normalized to an absolute path. + */ + export function __promisify__(target: PathLike, path: PathLike, type?: string | null): Promise; + + export type Type = "dir" | "file" | "junction"; + } + + /** + * Synchronous symlink(2) - Create a new symbolic link to an existing file. + * @param target A path to an existing file. If a URL is provided, it must use the `file:` protocol. + * @param path A path to the new symlink. If a URL is provided, it must use the `file:` protocol. + * @param type May be set to `'dir'`, `'file'`, or `'junction'` (default is `'file'`) and is only available on Windows (ignored on other platforms). + * When using `'junction'`, the `target` argument will automatically be normalized to an absolute path. + */ + export function symlinkSync(target: PathLike, path: PathLike, type?: symlink.Type | null): void; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlink(path: PathLike, options: { encoding?: BufferEncoding | null } | BufferEncoding | undefined | null, callback: (err: NodeJS.ErrnoException, linkString: string) => void): void; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlink(path: PathLike, options: { encoding: "buffer" } | "buffer", callback: (err: NodeJS.ErrnoException, linkString: Buffer) => void): void; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlink(path: PathLike, options: { encoding?: string | null } | string | undefined | null, callback: (err: NodeJS.ErrnoException, linkString: string | Buffer) => void): void; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function readlink(path: PathLike, callback: (err: NodeJS.ErrnoException, linkString: string) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace readlink { + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + } + + /** + * Synchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlinkSync(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): string; + + /** + * Synchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlinkSync(path: PathLike, options: { encoding: "buffer" } | "buffer"): Buffer; + + /** + * Synchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readlinkSync(path: PathLike, options?: { encoding?: string | null } | string | null): string | Buffer; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpath(path: PathLike, options: { encoding?: BufferEncoding | null } | BufferEncoding | undefined | null, callback: (err: NodeJS.ErrnoException, resolvedPath: string) => void): void; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpath(path: PathLike, options: { encoding: "buffer" } | "buffer", callback: (err: NodeJS.ErrnoException, resolvedPath: Buffer) => void): void; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpath(path: PathLike, options: { encoding?: string | null } | string | undefined | null, callback: (err: NodeJS.ErrnoException, resolvedPath: string | Buffer) => void): void; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function realpath(path: PathLike, callback: (err: NodeJS.ErrnoException, resolvedPath: string) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace realpath { + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + + export function native(path: PathLike, options: { encoding?: BufferEncoding | null } | BufferEncoding | undefined | null, callback: (err: NodeJS.ErrnoException, resolvedPath: string) => void): void; + export function native(path: PathLike, options: { encoding: "buffer" } | "buffer", callback: (err: NodeJS.ErrnoException, resolvedPath: Buffer) => void): void; + export function native(path: PathLike, options: { encoding?: string | null } | string | undefined | null, callback: (err: NodeJS.ErrnoException, resolvedPath: string | Buffer) => void): void; + export function native(path: PathLike, callback: (err: NodeJS.ErrnoException, resolvedPath: string) => void): void; + } + + /** + * Synchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpathSync(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): string; + + /** + * Synchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpathSync(path: PathLike, options: { encoding: "buffer" } | "buffer"): Buffer; + + /** + * Synchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function realpathSync(path: PathLike, options?: { encoding?: string | null } | string | null): string | Buffer; + + export namespace realpathSync { + export function native(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): string; + export function native(path: PathLike, options: { encoding: "buffer" } | "buffer"): Buffer; + export function native(path: PathLike, options?: { encoding?: string | null } | string | null): string | Buffer; + } + + /** + * Asynchronous unlink(2) - delete a name and possibly the file it refers to. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function unlink(path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace unlink { + /** + * Asynchronous unlink(2) - delete a name and possibly the file it refers to. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike): Promise; + } + + /** + * Synchronous unlink(2) - delete a name and possibly the file it refers to. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function unlinkSync(path: PathLike): void; + + /** + * Asynchronous rmdir(2) - delete a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function rmdir(path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace rmdir { + /** + * Asynchronous rmdir(2) - delete a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function __promisify__(path: PathLike): Promise; + } + + /** + * Synchronous rmdir(2) - delete a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function rmdirSync(path: PathLike): void; + + /** + * Asynchronous mkdir(2) - create a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not specified, defaults to `0o777`. + */ + export function mkdir(path: PathLike, mode: number | string | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronous mkdir(2) - create a directory with a mode of `0o777`. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function mkdir(path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace mkdir { + /** + * Asynchronous mkdir(2) - create a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not specified, defaults to `0o777`. + */ + export function __promisify__(path: PathLike, mode?: number | string | null): Promise; + } + + /** + * Synchronous mkdir(2) - create a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not specified, defaults to `0o777`. + */ + export function mkdirSync(path: PathLike, mode?: number | string | null): void; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtemp(prefix: string, options: { encoding?: BufferEncoding | null } | BufferEncoding | undefined | null, callback: (err: NodeJS.ErrnoException, folder: string) => void): void; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtemp(prefix: string, options: "buffer" | { encoding: "buffer" }, callback: (err: NodeJS.ErrnoException, folder: Buffer) => void): void; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtemp(prefix: string, options: { encoding?: string | null } | string | undefined | null, callback: (err: NodeJS.ErrnoException, folder: string | Buffer) => void): void; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + */ + export function mkdtemp(prefix: string, callback: (err: NodeJS.ErrnoException, folder: string) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace mkdtemp { + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(prefix: string, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(prefix: string, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(prefix: string, options?: { encoding?: string | null } | string | null): Promise; + } + + /** + * Synchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtempSync(prefix: string, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): string; + + /** + * Synchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtempSync(prefix: string, options: { encoding: "buffer" } | "buffer"): Buffer; + + /** + * Synchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required prefix to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function mkdtempSync(prefix: string, options?: { encoding?: string | null } | string | null): string | Buffer; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdir(path: PathLike, options: { encoding: BufferEncoding | null } | BufferEncoding | undefined | null, callback: (err: NodeJS.ErrnoException, files: string[]) => void): void; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdir(path: PathLike, options: { encoding: "buffer" } | "buffer", callback: (err: NodeJS.ErrnoException, files: Buffer[]) => void): void; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdir(path: PathLike, options: { encoding?: string | null } | string | undefined | null, callback: (err: NodeJS.ErrnoException, files: string[] | Buffer[]) => void): void; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function readdir(path: PathLike, callback: (err: NodeJS.ErrnoException, files: string[]) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace readdir { + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options: "buffer" | { encoding: "buffer" }): Promise; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function __promisify__(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + } + + /** + * Synchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdirSync(path: PathLike, options?: { encoding: BufferEncoding | null } | BufferEncoding | null): string[]; + + /** + * Synchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdirSync(path: PathLike, options: { encoding: "buffer" } | "buffer"): Buffer[]; + + /** + * Synchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + export function readdirSync(path: PathLike, options?: { encoding?: string | null } | string | null): string[] | Buffer[]; + + /** + * Asynchronous close(2) - close a file descriptor. + * @param fd A file descriptor. + */ + export function close(fd: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace close { + /** + * Asynchronous close(2) - close a file descriptor. + * @param fd A file descriptor. + */ + export function __promisify__(fd: number): Promise; + } + + /** + * Synchronous close(2) - close a file descriptor. + * @param fd A file descriptor. + */ + export function closeSync(fd: number): void; + + /** + * Asynchronous open(2) - open and possibly create a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not supplied, defaults to `0o666`. + */ + export function open(path: PathLike, flags: string | number, mode: string | number | undefined | null, callback: (err: NodeJS.ErrnoException, fd: number) => void): void; + + /** + * Asynchronous open(2) - open and possibly create a file. If the file is created, its mode will be `0o666`. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + export function open(path: PathLike, flags: string | number, callback: (err: NodeJS.ErrnoException, fd: number) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace open { + /** + * Asynchronous open(2) - open and possibly create a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not supplied, defaults to `0o666`. + */ + export function __promisify__(path: PathLike, flags: string | number, mode?: string | number | null): Promise; + } + + /** + * Synchronous open(2) - open and possibly create a file, returning a file descriptor.. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not supplied, defaults to `0o666`. + */ + export function openSync(path: PathLike, flags: string | number, mode?: string | number | null): number; + + /** + * Asynchronously change file timestamps of the file referenced by the supplied path. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function utimes(path: PathLike, atime: string | number | Date, mtime: string | number | Date, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace utimes { + /** + * Asynchronously change file timestamps of the file referenced by the supplied path. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function __promisify__(path: PathLike, atime: string | number | Date, mtime: string | number | Date): Promise; + } + + /** + * Synchronously change file timestamps of the file referenced by the supplied path. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function utimesSync(path: PathLike, atime: string | number | Date, mtime: string | number | Date): void; + + /** + * Asynchronously change file timestamps of the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function futimes(fd: number, atime: string | number | Date, mtime: string | number | Date, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace futimes { + /** + * Asynchronously change file timestamps of the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function __promisify__(fd: number, atime: string | number | Date, mtime: string | number | Date): Promise; + } + + /** + * Synchronously change file timestamps of the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + export function futimesSync(fd: number, atime: string | number | Date, mtime: string | number | Date): void; + + /** + * Asynchronous fsync(2) - synchronize a file's in-core state with the underlying storage device. + * @param fd A file descriptor. + */ + export function fsync(fd: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace fsync { + /** + * Asynchronous fsync(2) - synchronize a file's in-core state with the underlying storage device. + * @param fd A file descriptor. + */ + export function __promisify__(fd: number): Promise; + } + + /** + * Synchronous fsync(2) - synchronize a file's in-core state with the underlying storage device. + * @param fd A file descriptor. + */ + export function fsyncSync(fd: number): void; + + /** + * Asynchronously writes `buffer` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + export function write(fd: number, buffer: TBuffer, offset: number | undefined | null, length: number | undefined | null, position: number | undefined | null, callback: (err: NodeJS.ErrnoException, written: number, buffer: TBuffer) => void): void; + + /** + * Asynchronously writes `buffer` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + */ + export function write(fd: number, buffer: TBuffer, offset: number | undefined | null, length: number | undefined | null, callback: (err: NodeJS.ErrnoException, written: number, buffer: TBuffer) => void): void; + + /** + * Asynchronously writes `buffer` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + */ + export function write(fd: number, buffer: TBuffer, offset: number | undefined | null, callback: (err: NodeJS.ErrnoException, written: number, buffer: TBuffer) => void): void; + + /** + * Asynchronously writes `buffer` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + */ + export function write(fd: number, buffer: TBuffer, callback: (err: NodeJS.ErrnoException, written: number, buffer: TBuffer) => void): void; + + /** + * Asynchronously writes `string` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + * @param encoding The expected string encoding. + */ + export function write(fd: number, string: any, position: number | undefined | null, encoding: string | undefined | null, callback: (err: NodeJS.ErrnoException, written: number, str: string) => void): void; + + /** + * Asynchronously writes `string` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + export function write(fd: number, string: any, position: number | undefined | null, callback: (err: NodeJS.ErrnoException, written: number, str: string) => void): void; + + /** + * Asynchronously writes `string` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + */ + export function write(fd: number, string: any, callback: (err: NodeJS.ErrnoException, written: number, str: string) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace write { + /** + * Asynchronously writes `buffer` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + export function __promisify__(fd: number, buffer?: TBuffer, offset?: number, length?: number, position?: number | null): Promise<{ bytesWritten: number, buffer: TBuffer }>; + + /** + * Asynchronously writes `string` to the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + * @param encoding The expected string encoding. + */ + export function __promisify__(fd: number, string: any, position?: number | null, encoding?: string | null): Promise<{ bytesWritten: number, buffer: string }>; + } + + /** + * Synchronously writes `buffer` to the file referenced by the supplied file descriptor, returning the number of bytes written. + * @param fd A file descriptor. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + export function writeSync(fd: number, buffer: Buffer | Uint8Array, offset?: number | null, length?: number | null, position?: number | null): number; + + /** + * Synchronously writes `string` to the file referenced by the supplied file descriptor, returning the number of bytes written. + * @param fd A file descriptor. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + * @param encoding The expected string encoding. + */ + export function writeSync(fd: number, string: any, position?: number | null, encoding?: string | null): number; + + /** + * Asynchronously reads data from the file referenced by the supplied file descriptor. + * @param fd A file descriptor. + * @param buffer The buffer that the data will be written to. + * @param offset The offset in the buffer at which to start writing. + * @param length The number of bytes to read. + * @param position The offset from the beginning of the file from which data should be read. If `null`, data will be read from the current position. + */ + export function read(fd: number, buffer: TBuffer, offset: number, length: number, position: number | null, callback?: (err: NodeJS.ErrnoException, bytesRead: number, buffer: TBuffer) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace read { + /** + * @param fd A file descriptor. + * @param buffer The buffer that the data will be written to. + * @param offset The offset in the buffer at which to start writing. + * @param length The number of bytes to read. + * @param position The offset from the beginning of the file from which data should be read. If `null`, data will be read from the current position. + */ + export function __promisify__(fd: number, buffer: TBuffer, offset: number, length: number, position: number | null): Promise<{ bytesRead: number, buffer: TBuffer }>; + } + + /** + * Synchronously reads data from the file referenced by the supplied file descriptor, returning the number of bytes read. + * @param fd A file descriptor. + * @param buffer The buffer that the data will be written to. + * @param offset The offset in the buffer at which to start writing. + * @param length The number of bytes to read. + * @param position The offset from the beginning of the file from which data should be read. If `null`, data will be read from the current position. + */ + export function readSync(fd: number, buffer: Buffer | Uint8Array, offset: number, length: number, position: number | null): number; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function readFile(path: PathLike | number, options: { encoding?: null; flag?: string; } | undefined | null, callback: (err: NodeJS.ErrnoException, data: Buffer) => void): void; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function readFile(path: PathLike | number, options: { encoding: string; flag?: string; } | string, callback: (err: NodeJS.ErrnoException, data: string) => void): void; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function readFile(path: PathLike | number, options: { encoding?: string | null; flag?: string; } | string | undefined | null, callback: (err: NodeJS.ErrnoException, data: string | Buffer) => void): void; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + */ + export function readFile(path: PathLike | number, callback: (err: NodeJS.ErrnoException, data: Buffer) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace readFile { + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function __promisify__(path: PathLike | number, options?: { encoding?: null; flag?: string; } | null): Promise; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function __promisify__(path: PathLike | number, options: { encoding: string; flag?: string; } | string): Promise; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function __promisify__(path: PathLike | number, options?: { encoding?: string | null; flag?: string; } | string | null): Promise; + } + + /** + * Synchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. If a flag is not provided, it defaults to `'r'`. + */ + export function readFileSync(path: PathLike | number, options?: { encoding?: null; flag?: string; } | null): Buffer; + + /** + * Synchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function readFileSync(path: PathLike | number, options: { encoding: string; flag?: string; } | string): string; + + /** + * Synchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param options Either the encoding for the result, or an object that contains the encoding and an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + export function readFileSync(path: PathLike | number, options?: { encoding?: string | null; flag?: string; } | string | null): string | Buffer; + + /** + * Asynchronously writes data to a file, replacing the file if it already exists. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'w'` is used. + */ + export function writeFile(path: PathLike | number, data: any, options: { encoding?: string | null; mode?: number | string; flag?: string; } | string | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronously writes data to a file, replacing the file if it already exists. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + */ + export function writeFile(path: PathLike | number, data: any, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace writeFile { + /** + * Asynchronously writes data to a file, replacing the file if it already exists. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'w'` is used. + */ + export function __promisify__(path: PathLike | number, data: any, options?: { encoding?: string | null; mode?: number | string; flag?: string; } | string | null): Promise; + } + + /** + * Synchronously writes data to a file, replacing the file if it already exists. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'w'` is used. + */ + export function writeFileSync(path: PathLike | number, data: any, options?: { encoding?: string | null; mode?: number | string; flag?: string; } | string | null): void; + + /** + * Asynchronously append data to a file, creating the file if it does not exist. + * @param file A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'a'` is used. + */ + export function appendFile(file: PathLike | number, data: any, options: { encoding?: string | null, mode?: string | number, flag?: string } | string | undefined | null, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronously append data to a file, creating the file if it does not exist. + * @param file A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + */ + export function appendFile(file: PathLike | number, data: any, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace appendFile { + /** + * Asynchronously append data to a file, creating the file if it does not exist. + * @param file A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'a'` is used. + */ + export function __promisify__(file: PathLike | number, data: any, options?: { encoding?: string | null, mode?: string | number, flag?: string } | string | null): Promise; + } + + /** + * Synchronously append data to a file, creating the file if it does not exist. + * @param file A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a file descriptor is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a Buffer or Uint8Array is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'a'` is used. + */ + export function appendFileSync(file: PathLike | number, data: any, options?: { encoding?: string | null; mode?: number | string; flag?: string; } | string | null): void; + + /** + * Watch for changes on `filename`. The callback `listener` will be called each time the file is accessed. + */ + export function watchFile(filename: PathLike, options: { persistent?: boolean; interval?: number; } | undefined, listener: (curr: Stats, prev: Stats) => void): void; + + /** + * Watch for changes on `filename`. The callback `listener` will be called each time the file is accessed. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function watchFile(filename: PathLike, listener: (curr: Stats, prev: Stats) => void): void; + + /** + * Stop watching for changes on `filename`. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function unwatchFile(filename: PathLike, listener?: (curr: Stats, prev: Stats) => void): void; + + /** + * Watch for changes on `filename`, where `filename` is either a file or a directory, returning an `FSWatcher`. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param options Either the encoding for the filename provided to the listener, or an object optionally specifying encoding, persistent, and recursive options. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `persistent` is not supplied, the default of `true` is used. + * If `recursive` is not supplied, the default of `false` is used. + */ + export function watch(filename: PathLike, options: { encoding?: BufferEncoding | null, persistent?: boolean, recursive?: boolean } | BufferEncoding | undefined | null, listener?: (event: string, filename: string) => void): FSWatcher; + + /** + * Watch for changes on `filename`, where `filename` is either a file or a directory, returning an `FSWatcher`. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param options Either the encoding for the filename provided to the listener, or an object optionally specifying encoding, persistent, and recursive options. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `persistent` is not supplied, the default of `true` is used. + * If `recursive` is not supplied, the default of `false` is used. + */ + export function watch(filename: PathLike, options: { encoding: "buffer", persistent?: boolean, recursive?: boolean } | "buffer", listener?: (event: string, filename: Buffer) => void): FSWatcher; + + /** + * Watch for changes on `filename`, where `filename` is either a file or a directory, returning an `FSWatcher`. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param options Either the encoding for the filename provided to the listener, or an object optionally specifying encoding, persistent, and recursive options. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `persistent` is not supplied, the default of `true` is used. + * If `recursive` is not supplied, the default of `false` is used. + */ + export function watch(filename: PathLike, options: { encoding?: string | null, persistent?: boolean, recursive?: boolean } | string | null, listener?: (event: string, filename: string | Buffer) => void): FSWatcher; + + /** + * Watch for changes on `filename`, where `filename` is either a file or a directory, returning an `FSWatcher`. + * @param filename A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function watch(filename: PathLike, listener?: (event: string, filename: string) => any): FSWatcher; + + /** + * Asynchronously tests whether or not the given path exists by checking with the file system. + * @deprecated + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function exists(path: PathLike, callback: (exists: boolean) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace exists { + /** + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + function __promisify__(path: PathLike): Promise; + } + + /** + * Synchronously tests whether or not the given path exists by checking with the file system. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function existsSync(path: PathLike): boolean; + + export namespace constants { + // File Access Constants + + /** Constant for fs.access(). File is visible to the calling process. */ + export const F_OK: number; + + /** Constant for fs.access(). File can be read by the calling process. */ + export const R_OK: number; + + /** Constant for fs.access(). File can be written by the calling process. */ + export const W_OK: number; + + /** Constant for fs.access(). File can be executed by the calling process. */ + export const X_OK: number; + + // File Copy Constants + + /** Constant for fs.copyFile. Flag indicating the destination file should not be overwritten if it already exists. */ + export const COPYFILE_EXCL: number; + + /** Constant for fs.copyFile. copy operation will attempt to create a copy-on-write reflink. If the underlying platform does not support copy-on-write, then a fallback copy mechanism is used. */ + export const COPYFILE_FICLONE: number; + + /** Constant for fs.copyFile. Copy operation will attempt to create a copy-on-write reflink. If the underlying platform does not support copy-on-write, then the operation will fail with an error. */ + export const COPYFILE_FICLONE_FORCE: number; + + // File Open Constants + + /** Constant for fs.open(). Flag indicating to open a file for read-only access. */ + export const O_RDONLY: number; + + /** Constant for fs.open(). Flag indicating to open a file for write-only access. */ + export const O_WRONLY: number; + + /** Constant for fs.open(). Flag indicating to open a file for read-write access. */ + export const O_RDWR: number; + + /** Constant for fs.open(). Flag indicating to create the file if it does not already exist. */ + export const O_CREAT: number; + + /** Constant for fs.open(). Flag indicating that opening a file should fail if the O_CREAT flag is set and the file already exists. */ + export const O_EXCL: number; + + /** Constant for fs.open(). Flag indicating that if path identifies a terminal device, opening the path shall not cause that terminal to become the controlling terminal for the process (if the process does not already have one). */ + export const O_NOCTTY: number; + + /** Constant for fs.open(). Flag indicating that if the file exists and is a regular file, and the file is opened successfully for write access, its length shall be truncated to zero. */ + export const O_TRUNC: number; + + /** Constant for fs.open(). Flag indicating that data will be appended to the end of the file. */ + export const O_APPEND: number; + + /** Constant for fs.open(). Flag indicating that the open should fail if the path is not a directory. */ + export const O_DIRECTORY: number; + + /** Constant for fs.open(). Flag indicating reading accesses to the file system will no longer result in an update to the atime information associated with the file. This flag is available on Linux operating systems only. */ + export const O_NOATIME: number; + + /** Constant for fs.open(). Flag indicating that the open should fail if the path is a symbolic link. */ + export const O_NOFOLLOW: number; + + /** Constant for fs.open(). Flag indicating that the file is opened for synchronous I/O. */ + export const O_SYNC: number; + + /** Constant for fs.open(). Flag indicating that the file is opened for synchronous I/O with write operations waiting for data integrity. */ + export const O_DSYNC: number; + + /** Constant for fs.open(). Flag indicating to open the symbolic link itself rather than the resource it is pointing to. */ + export const O_SYMLINK: number; + + /** Constant for fs.open(). When set, an attempt will be made to minimize caching effects of file I/O. */ + export const O_DIRECT: number; + + /** Constant for fs.open(). Flag indicating to open the file in nonblocking mode when possible. */ + export const O_NONBLOCK: number; + + // File Type Constants + + /** Constant for fs.Stats mode property for determining a file's type. Bit mask used to extract the file type code. */ + export const S_IFMT: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a regular file. */ + export const S_IFREG: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a directory. */ + export const S_IFDIR: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a character-oriented device file. */ + export const S_IFCHR: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a block-oriented device file. */ + export const S_IFBLK: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a FIFO/pipe. */ + export const S_IFIFO: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a symbolic link. */ + export const S_IFLNK: number; + + /** Constant for fs.Stats mode property for determining a file's type. File type constant for a socket. */ + export const S_IFSOCK: number; + + // File Mode Constants + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable, writable and executable by owner. */ + export const S_IRWXU: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable by owner. */ + export const S_IRUSR: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating writable by owner. */ + export const S_IWUSR: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating executable by owner. */ + export const S_IXUSR: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable, writable and executable by group. */ + export const S_IRWXG: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable by group. */ + export const S_IRGRP: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating writable by group. */ + export const S_IWGRP: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating executable by group. */ + export const S_IXGRP: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable, writable and executable by others. */ + export const S_IRWXO: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating readable by others. */ + export const S_IROTH: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating writable by others. */ + export const S_IWOTH: number; + + /** Constant for fs.Stats mode property for determining access permissions for a file. File mode indicating executable by others. */ + export const S_IXOTH: number; + } + + /** + * Asynchronously tests a user's permissions for the file specified by path. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function access(path: PathLike, mode: number | undefined, callback: (err: NodeJS.ErrnoException) => void): void; + + /** + * Asynchronously tests a user's permissions for the file specified by path. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function access(path: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace access { + /** + * Asynchronously tests a user's permissions for the file specified by path. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function __promisify__(path: PathLike, mode?: number): Promise; + } + + /** + * Synchronously tests a user's permissions for the file specified by path. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function accessSync(path: PathLike, mode?: number): void; + + /** + * Returns a new `ReadStream` object. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function createReadStream(path: PathLike, options?: string | { + flags?: string; + encoding?: string; + fd?: number; + mode?: number; + autoClose?: boolean; + start?: number; + end?: number; + highWaterMark?: number; + }): ReadStream; + + /** + * Returns a new `WriteStream` object. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + export function createWriteStream(path: PathLike, options?: string | { + flags?: string; + encoding?: string; + fd?: number; + mode?: number; + autoClose?: boolean; + start?: number; + }): WriteStream; + + /** + * Asynchronous fdatasync(2) - synchronize a file's in-core state with storage device. + * @param fd A file descriptor. + */ + export function fdatasync(fd: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace fdatasync { + /** + * Asynchronous fdatasync(2) - synchronize a file's in-core state with storage device. + * @param fd A file descriptor. + */ + export function __promisify__(fd: number): Promise; + } + + /** + * Synchronous fdatasync(2) - synchronize a file's in-core state with storage device. + * @param fd A file descriptor. + */ + export function fdatasyncSync(fd: number): void; + + /** + * Asynchronously copies src to dest. By default, dest is overwritten if it already exists. + * No arguments other than a possible exception are given to the callback function. + * Node.js makes no guarantees about the atomicity of the copy operation. + * If an error occurs after the destination file has been opened for writing, Node.js will attempt + * to remove the destination. + * @param src A path to the source file. + * @param dest A path to the destination file. + */ + export function copyFile(src: PathLike, dest: PathLike, callback: (err: NodeJS.ErrnoException) => void): void; + /** + * Asynchronously copies src to dest. By default, dest is overwritten if it already exists. + * No arguments other than a possible exception are given to the callback function. + * Node.js makes no guarantees about the atomicity of the copy operation. + * If an error occurs after the destination file has been opened for writing, Node.js will attempt + * to remove the destination. + * @param src A path to the source file. + * @param dest A path to the destination file. + * @param flags An integer that specifies the behavior of the copy operation. The only supported flag is fs.constants.COPYFILE_EXCL, which causes the copy operation to fail if dest already exists. + */ + export function copyFile(src: PathLike, dest: PathLike, flags: number, callback: (err: NodeJS.ErrnoException) => void): void; + + // NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime. + export namespace copyFile { + /** + * Asynchronously copies src to dest. By default, dest is overwritten if it already exists. + * No arguments other than a possible exception are given to the callback function. + * Node.js makes no guarantees about the atomicity of the copy operation. + * If an error occurs after the destination file has been opened for writing, Node.js will attempt + * to remove the destination. + * @param src A path to the source file. + * @param dest A path to the destination file. + * @param flags An optional integer that specifies the behavior of the copy operation. The only supported flag is fs.constants.COPYFILE_EXCL, which causes the copy operation to fail if dest already exists. + */ + export function __promisify__(src: PathLike, dst: PathLike, flags?: number): Promise; + } + + /** + * Synchronously copies src to dest. By default, dest is overwritten if it already exists. + * Node.js makes no guarantees about the atomicity of the copy operation. + * If an error occurs after the destination file has been opened for writing, Node.js will attempt + * to remove the destination. + * @param src A path to the source file. + * @param dest A path to the destination file. + * @param flags An optional integer that specifies the behavior of the copy operation. The only supported flag is fs.constants.COPYFILE_EXCL, which causes the copy operation to fail if dest already exists. + */ + export function copyFileSync(src: PathLike, dest: PathLike, flags?: number): void; + + export namespace promises { + interface FileHandle { + /** + * Gets the file descriptor for this file handle. + */ + readonly fd: number; + + /** + * Asynchronously append data to a file, creating the file if it does not exist. The underlying file will _not_ be closed automatically. + * The `FileHandle` must have been opened for appending. + * @param data The data to write. If something other than a `Buffer` or `Uint8Array` is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'a'` is used. + */ + appendFile(data: any, options?: { encoding?: string | null, mode?: string | number, flag?: string | number } | string | null): Promise; + + /** + * Asynchronous fchown(2) - Change ownership of a file. + */ + chown(uid: number, gid: number): Promise; + + /** + * Asynchronous fchmod(2) - Change permissions of a file. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + chmod(mode: string | number): Promise; + + /** + * Asynchronous fdatasync(2) - synchronize a file's in-core state with storage device. + */ + datasync(): Promise; + + /** + * Asynchronous fsync(2) - synchronize a file's in-core state with the underlying storage device. + */ + sync(): Promise; + + /** + * Asynchronously reads data from the file. + * The `FileHandle` must have been opened for reading. + * @param buffer The buffer that the data will be written to. + * @param offset The offset in the buffer at which to start writing. + * @param length The number of bytes to read. + * @param position The offset from the beginning of the file from which data should be read. If `null`, data will be read from the current position. + */ + read(buffer: TBuffer, offset?: number | null, length?: number | null, position?: number | null): Promise<{ bytesRead: number, buffer: TBuffer }>; + + /** + * Asynchronously reads the entire contents of a file. The underlying file will _not_ be closed automatically. + * The `FileHandle` must have been opened for reading. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + readFile(options?: { encoding?: null, flag?: string | number } | null): Promise; + + /** + * Asynchronously reads the entire contents of a file. The underlying file will _not_ be closed automatically. + * The `FileHandle` must have been opened for reading. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + readFile(options: { encoding: BufferEncoding, flag?: string | number } | BufferEncoding): Promise; + + /** + * Asynchronously reads the entire contents of a file. The underlying file will _not_ be closed automatically. + * The `FileHandle` must have been opened for reading. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + readFile(options?: { encoding?: string | null, flag?: string | number } | string | null): Promise; + + /** + * Asynchronous fstat(2) - Get file status. + */ + stat(): Promise; + + /** + * Asynchronous ftruncate(2) - Truncate a file to a specified length. + * @param len If not specified, defaults to `0`. + */ + truncate(len?: number): Promise; + + /** + * Asynchronously change file timestamps of the file. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + utimes(atime: string | number | Date, mtime: string | number | Date): Promise; + + /** + * Asynchronously writes `buffer` to the file. + * The `FileHandle` must have been opened for writing. + * @param buffer The buffer that the data will be written to. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + write(buffer: TBuffer, offset?: number | null, length?: number | null, position?: number | null): Promise<{ bytesWritten: number, buffer: TBuffer }>; + + /** + * Asynchronously writes `string` to the file. + * The `FileHandle` must have been opened for writing. + * It is unsafe to call `write()` multiple times on the same file without waiting for the `Promise` to be resolved (or rejected). For this scenario, `fs.createWriteStream` is strongly recommended. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + * @param encoding The expected string encoding. + */ + write(data: any, position?: number | null, encoding?: string | null): Promise<{ bytesWritten: number, buffer: string }>; + + /** + * Asynchronously writes data to a file, replacing the file if it already exists. The underlying file will _not_ be closed automatically. + * The `FileHandle` must have been opened for writing. + * It is unsafe to call `writeFile()` multiple times on the same file without waiting for the `Promise` to be resolved (or rejected). + * @param data The data to write. If something other than a `Buffer` or `Uint8Array` is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'w'` is used. + */ + writeFile(data: any, options?: { encoding?: string | null, mode?: string | number, flag?: string | number } | string | null): Promise; + + /** + * Asynchronous close(2) - close a `FileHandle`. + */ + close(): Promise; + } + + /** + * Asynchronously tests a user's permissions for the file specified by path. + * @param path A path to a file or directory. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + function access(path: PathLike, mode?: number): Promise; + + /** + * Asynchronously copies `src` to `dest`. By default, `dest` is overwritten if it already exists. + * Node.js makes no guarantees about the atomicity of the copy operation. + * If an error occurs after the destination file has been opened for writing, Node.js will attempt + * to remove the destination. + * @param src A path to the source file. + * @param dest A path to the destination file. + * @param flags An optional integer that specifies the behavior of the copy operation. The only + * supported flag is `fs.constants.COPYFILE_EXCL`, which causes the copy operation to fail if + * `dest` already exists. + */ + function copyFile(src: PathLike, dest: PathLike, flags?: number): Promise; + + /** + * Asynchronous open(2) - open and possibly create a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not + * supplied, defaults to `0o666`. + */ + function open(path: PathLike, flags: string | number, mode?: string | number): Promise; + + /** + * Asynchronously reads data from the file referenced by the supplied `FileHandle`. + * @param handle A `FileHandle`. + * @param buffer The buffer that the data will be written to. + * @param offset The offset in the buffer at which to start writing. + * @param length The number of bytes to read. + * @param position The offset from the beginning of the file from which data should be read. If + * `null`, data will be read from the current position. + */ + function read(handle: FileHandle, buffer: TBuffer, offset?: number | null, length?: number | null, position?: number | null): Promise<{ bytesRead: number, buffer: TBuffer }>; + + /** + * Asynchronously writes `buffer` to the file referenced by the supplied `FileHandle`. + * It is unsafe to call `fsPromises.write()` multiple times on the same file without waiting for the `Promise` to be resolved (or rejected). For this scenario, `fs.createWriteStream` is strongly recommended. + * @param handle A `FileHandle`. + * @param buffer The buffer that the data will be written to. + * @param offset The part of the buffer to be written. If not supplied, defaults to `0`. + * @param length The number of bytes to write. If not supplied, defaults to `buffer.length - offset`. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + */ + function write(handle: FileHandle, buffer: TBuffer, offset?: number | null, length?: number | null, position?: number | null): Promise<{ bytesWritten: number, buffer: TBuffer }>; + + /** + * Asynchronously writes `string` to the file referenced by the supplied `FileHandle`. + * It is unsafe to call `fsPromises.write()` multiple times on the same file without waiting for the `Promise` to be resolved (or rejected). For this scenario, `fs.createWriteStream` is strongly recommended. + * @param handle A `FileHandle`. + * @param string A string to write. If something other than a string is supplied it will be coerced to a string. + * @param position The offset from the beginning of the file where this data should be written. If not supplied, defaults to the current position. + * @param encoding The expected string encoding. + */ + function write(handle: FileHandle, string: any, position?: number | null, encoding?: string | null): Promise<{ bytesWritten: number, buffer: string }>; + + /** + * Asynchronous rename(2) - Change the name or location of a file or directory. + * @param oldPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + */ + function rename(oldPath: PathLike, newPath: PathLike): Promise; + + /** + * Asynchronous truncate(2) - Truncate a file to a specified length. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param len If not specified, defaults to `0`. + */ + function truncate(path: PathLike, len?: number): Promise; + + /** + * Asynchronous ftruncate(2) - Truncate a file to a specified length. + * @param handle A `FileHandle`. + * @param len If not specified, defaults to `0`. + */ + function ftruncate(handle: FileHandle, len?: number): Promise; + + /** + * Asynchronous rmdir(2) - delete a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function rmdir(path: PathLike): Promise; + + /** + * Asynchronous fdatasync(2) - synchronize a file's in-core state with storage device. + * @param handle A `FileHandle`. + */ + function fdatasync(handle: FileHandle): Promise; + + /** + * Asynchronous fsync(2) - synchronize a file's in-core state with the underlying storage device. + * @param handle A `FileHandle`. + */ + function fsync(handle: FileHandle): Promise; + + /** + * Asynchronous mkdir(2) - create a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. If not specified, defaults to `0o777`. + */ + function mkdir(path: PathLike, mode?: string | number): Promise; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readdir(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readdir(path: PathLike, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronous readdir(3) - read a directory. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readdir(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readlink(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readlink(path: PathLike, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronous readlink(2) - read value of a symbolic link. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function readlink(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + + /** + * Asynchronous symlink(2) - Create a new symbolic link to an existing file. + * @param target A path to an existing file. If a URL is provided, it must use the `file:` protocol. + * @param path A path to the new symlink. If a URL is provided, it must use the `file:` protocol. + * @param type May be set to `'dir'`, `'file'`, or `'junction'` (default is `'file'`) and is only available on Windows (ignored on other platforms). + * When using `'junction'`, the `target` argument will automatically be normalized to an absolute path. + */ + function symlink(target: PathLike, path: PathLike, type?: string | null): Promise; + + /** + * Asynchronous fstat(2) - Get file status. + * @param handle A `FileHandle`. + */ + function fstat(handle: FileHandle): Promise; + + /** + * Asynchronous lstat(2) - Get file status. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function lstat(path: PathLike): Promise; + + /** + * Asynchronous stat(2) - Get file status. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function stat(path: PathLike): Promise; + + /** + * Asynchronous link(2) - Create a new link (also known as a hard link) to an existing file. + * @param existingPath A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param newPath A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function link(existingPath: PathLike, newPath: PathLike): Promise; + + /** + * Asynchronous unlink(2) - delete a name and possibly the file it refers to. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function unlink(path: PathLike): Promise; + + /** + * Asynchronous fchmod(2) - Change permissions of a file. + * @param handle A `FileHandle`. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + function fchmod(handle: FileHandle, mode: string | number): Promise; + + /** + * Asynchronous chmod(2) - Change permissions of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + function chmod(path: PathLike, mode: string | number): Promise; + + /** + * Asynchronous lchmod(2) - Change permissions of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param mode A file mode. If a string is passed, it is parsed as an octal integer. + */ + function lchmod(path: PathLike, mode: string | number): Promise; + + /** + * Asynchronous lchown(2) - Change ownership of a file. Does not dereference symbolic links. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function lchown(path: PathLike, uid: number, gid: number): Promise; + + /** + * Asynchronous fchown(2) - Change ownership of a file. + * @param handle A `FileHandle`. + */ + function fchown(handle: FileHandle, uid: number, gid: number): Promise; + + /** + * Asynchronous chown(2) - Change ownership of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + */ + function chown(path: PathLike, uid: number, gid: number): Promise; + + /** + * Asynchronously change file timestamps of the file referenced by the supplied path. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + function utimes(path: PathLike, atime: string | number | Date, mtime: string | number | Date): Promise; + + /** + * Asynchronously change file timestamps of the file referenced by the supplied `FileHandle`. + * @param handle A `FileHandle`. + * @param atime The last access time. If a string is provided, it will be coerced to number. + * @param mtime The last modified time. If a string is provided, it will be coerced to number. + */ + function futimes(handle: FileHandle, atime: string | number | Date, mtime: string | number | Date): Promise; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function realpath(path: PathLike, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function realpath(path: PathLike, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronous realpath(3) - return the canonicalized absolute pathname. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function realpath(path: PathLike, options?: { encoding?: string | null } | string | null): Promise; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required `prefix` to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function mkdtemp(prefix: string, options?: { encoding?: BufferEncoding | null } | BufferEncoding | null): Promise; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required `prefix` to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function mkdtemp(prefix: string, options: { encoding: "buffer" } | "buffer"): Promise; + + /** + * Asynchronously creates a unique temporary directory. + * Generates six random characters to be appended behind a required `prefix` to create a unique temporary directory. + * @param options The encoding (or an object specifying the encoding), used as the encoding of the result. If not provided, `'utf8'` is used. + */ + function mkdtemp(prefix: string, options?: { encoding?: string | null } | string | null): Promise; + + /** + * Asynchronously writes data to a file, replacing the file if it already exists. + * It is unsafe to call `fsPromises.writeFile()` multiple times on the same file without waiting for the `Promise` to be resolved (or rejected). + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a `FileHandle` is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a `Buffer` or `Uint8Array` is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'w'` is used. + */ + function writeFile(path: PathLike | FileHandle, data: any, options?: { encoding?: string | null, mode?: string | number, flag?: string | number } | string | null): Promise; + + /** + * Asynchronously append data to a file, creating the file if it does not exist. + * @param file A path to a file. If a URL is provided, it must use the `file:` protocol. + * URL support is _experimental_. + * If a `FileHandle` is provided, the underlying file will _not_ be closed automatically. + * @param data The data to write. If something other than a `Buffer` or `Uint8Array` is provided, the value is coerced to a string. + * @param options Either the encoding for the file, or an object optionally specifying the encoding, file mode, and flag. + * If `encoding` is not supplied, the default of `'utf8'` is used. + * If `mode` is not supplied, the default of `0o666` is used. + * If `mode` is a string, it is parsed as an octal integer. + * If `flag` is not supplied, the default of `'a'` is used. + */ + function appendFile(path: PathLike | FileHandle, data: any, options?: { encoding?: string | null, mode?: string | number, flag?: string | number } | string | null): Promise; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a `FileHandle` is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + function readFile(path: PathLike | FileHandle, options?: { encoding?: null, flag?: string | number } | null): Promise; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a `FileHandle` is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + function readFile(path: PathLike | FileHandle, options: { encoding: BufferEncoding, flag?: string | number } | BufferEncoding): Promise; + + /** + * Asynchronously reads the entire contents of a file. + * @param path A path to a file. If a URL is provided, it must use the `file:` protocol. + * If a `FileHandle` is provided, the underlying file will _not_ be closed automatically. + * @param options An object that may contain an optional flag. + * If a flag is not provided, it defaults to `'r'`. + */ + function readFile(path: PathLike | FileHandle, options?: { encoding?: string | null, flag?: string | number } | string | null): Promise; + } +} + +declare module "path" { + /** + * A parsed path object generated by path.parse() or consumed by path.format(). + */ + export interface ParsedPath { + /** + * The root of the path such as '/' or 'c:\' + */ + root: string; + /** + * The full directory path such as '/home/user/dir' or 'c:\path\dir' + */ + dir: string; + /** + * The file name including extension (if any) such as 'index.html' + */ + base: string; + /** + * The file extension (if any) such as '.html' + */ + ext: string; + /** + * The file name without extension (if any) such as 'index' + */ + name: string; + } + export interface FormatInputPathObject { + /** + * The root of the path such as '/' or 'c:\' + */ + root?: string; + /** + * The full directory path such as '/home/user/dir' or 'c:\path\dir' + */ + dir?: string; + /** + * The file name including extension (if any) such as 'index.html' + */ + base?: string; + /** + * The file extension (if any) such as '.html' + */ + ext?: string; + /** + * The file name without extension (if any) such as 'index' + */ + name?: string; + } + + /** + * Normalize a string path, reducing '..' and '.' parts. + * When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used. + * + * @param p string path to normalize. + */ + export function normalize(p: string): string; + /** + * Join all arguments together and normalize the resulting path. + * Arguments must be strings. In v0.8, non-string arguments were silently ignored. In v0.10 and up, an exception is thrown. + * + * @param paths paths to join. + */ + export function join(...paths: string[]): string; + /** + * The right-most parameter is considered {to}. Other parameters are considered an array of {from}. + * + * Starting from leftmost {from} paramter, resolves {to} to an absolute path. + * + * If {to} isn't already absolute, {from} arguments are prepended in right to left order, until an absolute path is found. If after using all {from} paths still no absolute path is found, the current working directory is used as well. The resulting path is normalized, and trailing slashes are removed unless the path gets resolved to the root directory. + * + * @param pathSegments string paths to join. Non-string arguments are ignored. + */ + export function resolve(...pathSegments: string[]): string; + /** + * Determines whether {path} is an absolute path. An absolute path will always resolve to the same location, regardless of the working directory. + * + * @param path path to test. + */ + export function isAbsolute(path: string): boolean; + /** + * Solve the relative path from {from} to {to}. + * At times we have two absolute paths, and we need to derive the relative path from one to the other. This is actually the reverse transform of path.resolve. + */ + export function relative(from: string, to: string): string; + /** + * Return the directory name of a path. Similar to the Unix dirname command. + * + * @param p the path to evaluate. + */ + export function dirname(p: string): string; + /** + * Return the last portion of a path. Similar to the Unix basename command. + * Often used to extract the file name from a fully qualified path. + * + * @param p the path to evaluate. + * @param ext optionally, an extension to remove from the result. + */ + export function basename(p: string, ext?: string): string; + /** + * Return the extension of the path, from the last '.' to end of string in the last portion of the path. + * If there is no '.' in the last portion of the path or the first character of it is '.', then it returns an empty string + * + * @param p the path to evaluate. + */ + export function extname(p: string): string; + /** + * The platform-specific file separator. '\\' or '/'. + */ + export var sep: '\\' | '/'; + /** + * The platform-specific file delimiter. ';' or ':'. + */ + export var delimiter: ';' | ':'; + /** + * Returns an object from a path string - the opposite of format(). + * + * @param pathString path to evaluate. + */ + export function parse(pathString: string): ParsedPath; + /** + * Returns a path string from an object - the opposite of parse(). + * + * @param pathString path to evaluate. + */ + export function format(pathObject: FormatInputPathObject): string; + + export module posix { + export function normalize(p: string): string; + export function join(...paths: any[]): string; + export function resolve(...pathSegments: any[]): string; + export function isAbsolute(p: string): boolean; + export function relative(from: string, to: string): string; + export function dirname(p: string): string; + export function basename(p: string, ext?: string): string; + export function extname(p: string): string; + export var sep: string; + export var delimiter: string; + export function parse(p: string): ParsedPath; + export function format(pP: FormatInputPathObject): string; + } + + export module win32 { + export function normalize(p: string): string; + export function join(...paths: any[]): string; + export function resolve(...pathSegments: any[]): string; + export function isAbsolute(p: string): boolean; + export function relative(from: string, to: string): string; + export function dirname(p: string): string; + export function basename(p: string, ext?: string): string; + export function extname(p: string): string; + export var sep: string; + export var delimiter: string; + export function parse(p: string): ParsedPath; + export function format(pP: FormatInputPathObject): string; + } +} + +declare module "string_decoder" { + export interface NodeStringDecoder { + write(buffer: Buffer): string; + end(buffer?: Buffer): string; + } + export var StringDecoder: { + new(encoding?: string): NodeStringDecoder; + }; +} + +declare module "tls" { + import * as crypto from "crypto"; + import * as dns from "dns"; + import * as net from "net"; + import * as stream from "stream"; + + var CLIENT_RENEG_LIMIT: number; + var CLIENT_RENEG_WINDOW: number; + + export interface Certificate { + /** + * Country code. + */ + C: string; + /** + * Street. + */ + ST: string; + /** + * Locality. + */ + L: string; + /** + * Organization. + */ + O: string; + /** + * Organizational unit. + */ + OU: string; + /** + * Common name. + */ + CN: string; + } + + export interface PeerCertificate { + subject: Certificate; + issuer: Certificate; + subjectaltname: string; + infoAccess: { [index: string]: string[] | undefined }; + modulus: string; + exponent: string; + valid_from: string; + valid_to: string; + fingerprint: string; + ext_key_usage: string[]; + serialNumber: string; + raw: Buffer; + } + + export interface DetailedPeerCertificate extends PeerCertificate { + issuerCertificate: DetailedPeerCertificate; + } + + export interface CipherNameAndProtocol { + /** + * The cipher name. + */ + name: string; + /** + * SSL/TLS protocol version. + */ + version: string; + } + + export class TLSSocket extends net.Socket { + /** + * Construct a new tls.TLSSocket object from an existing TCP socket. + */ + constructor(socket: net.Socket, options?: { + /** + * An optional TLS context object from tls.createSecureContext() + */ + secureContext?: SecureContext, + /** + * If true the TLS socket will be instantiated in server-mode. + * Defaults to false. + */ + isServer?: boolean, + /** + * An optional net.Server instance. + */ + server?: net.Server, + /** + * If true the server will request a certificate from clients that + * connect and attempt to verify that certificate. Defaults to + * false. + */ + requestCert?: boolean, + /** + * If true the server will reject any connection which is not + * authorized with the list of supplied CAs. This option only has an + * effect if requestCert is true. Defaults to false. + */ + rejectUnauthorized?: boolean, + /** + * An array of strings or a Buffer naming possible NPN protocols. + * (Protocols should be ordered by their priority.) + */ + NPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array, + /** + * An array of strings or a Buffer naming possible ALPN protocols. + * (Protocols should be ordered by their priority.) When the server + * receives both NPN and ALPN extensions from the client, ALPN takes + * precedence over NPN and the server does not send an NPN extension + * to the client. + */ + ALPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array, + /** + * SNICallback(servername, cb) A function that will be + * called if the client supports SNI TLS extension. Two arguments + * will be passed when called: servername and cb. SNICallback should + * invoke cb(null, ctx), where ctx is a SecureContext instance. + * (tls.createSecureContext(...) can be used to get a proper + * SecureContext.) If SNICallback wasn't provided the default callback + * with high-level API will be used (see below). + */ + SNICallback?: (servername: string, cb: (err: Error | null, ctx: SecureContext) => void) => void, + /** + * An optional Buffer instance containing a TLS session. + */ + session?: Buffer, + /** + * If true, specifies that the OCSP status request extension will be + * added to the client hello and an 'OCSPResponse' event will be + * emitted on the socket before establishing a secure communication + */ + requestOCSP?: boolean + }); + + /** + * A boolean that is true if the peer certificate was signed by one of the specified CAs, otherwise false. + */ + authorized: boolean; + /** + * The reason why the peer's certificate has not been verified. + * This property becomes available only when tlsSocket.authorized === false. + */ + authorizationError: Error; + /** + * Static boolean value, always true. + * May be used to distinguish TLS sockets from regular ones. + */ + encrypted: boolean; + /** + * Returns an object representing the cipher name and the SSL/TLS protocol version of the current connection. + * @returns Returns an object representing the cipher name + * and the SSL/TLS protocol version of the current connection. + */ + getCipher(): CipherNameAndProtocol; + /** + * Returns an object representing the peer's certificate. + * The returned object has some properties corresponding to the field of the certificate. + * If detailed argument is true the full chain with issuer property will be returned, + * if false only the top certificate without issuer property. + * If the peer does not provide a certificate, it returns null or an empty object. + * @param detailed - If true; the full chain with issuer property will be returned. + * @returns An object representing the peer's certificate. + */ + getPeerCertificate(detailed: true): DetailedPeerCertificate; + getPeerCertificate(detailed?: false): PeerCertificate; + getPeerCertificate(detailed?: boolean): PeerCertificate | DetailedPeerCertificate; + /** + * Returns a string containing the negotiated SSL/TLS protocol version of the current connection. + * The value `'unknown'` will be returned for connected sockets that have not completed the handshaking process. + * The value `null` will be returned for server sockets or disconnected client sockets. + * See https://www.openssl.org/docs/man1.0.2/ssl/SSL_get_version.html for more information. + * @returns negotiated SSL/TLS protocol version of the current connection + */ + getProtocol(): string | null; + /** + * Could be used to speed up handshake establishment when reconnecting to the server. + * @returns ASN.1 encoded TLS session or undefined if none was negotiated. + */ + getSession(): any; + /** + * NOTE: Works only with client TLS sockets. + * Useful only for debugging, for session reuse provide session option to tls.connect(). + * @returns TLS session ticket or undefined if none was negotiated. + */ + getTLSTicket(): any; + /** + * Initiate TLS renegotiation process. + * + * NOTE: Can be used to request peer's certificate after the secure connection has been established. + * ANOTHER NOTE: When running as the server, socket will be destroyed with an error after handshakeTimeout timeout. + * @param options - The options may contain the following fields: rejectUnauthorized, + * requestCert (See tls.createServer() for details). + * @param callback - callback(err) will be executed with null as err, once the renegotiation + * is successfully completed. + */ + renegotiate(options: { rejectUnauthorized?: boolean, requestCert?: boolean }, callback: (err: Error | null) => void): any; + /** + * Set maximum TLS fragment size (default and maximum value is: 16384, minimum is: 512). + * Smaller fragment size decreases buffering latency on the client: large fragments are buffered by + * the TLS layer until the entire fragment is received and its integrity is verified; + * large fragments can span multiple roundtrips, and their processing can be delayed due to packet + * loss or reordering. However, smaller fragments add extra TLS framing bytes and CPU overhead, + * which may decrease overall server throughput. + * @param size - TLS fragment size (default and maximum value is: 16384, minimum is: 512). + * @returns Returns true on success, false otherwise. + */ + setMaxSendFragment(size: number): boolean; + + /** + * events.EventEmitter + * 1. OCSPResponse + * 2. secureConnect + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "OCSPResponse", listener: (response: Buffer) => void): this; + addListener(event: "secureConnect", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "OCSPResponse", response: Buffer): boolean; + emit(event: "secureConnect"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "OCSPResponse", listener: (response: Buffer) => void): this; + on(event: "secureConnect", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "OCSPResponse", listener: (response: Buffer) => void): this; + once(event: "secureConnect", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "OCSPResponse", listener: (response: Buffer) => void): this; + prependListener(event: "secureConnect", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "OCSPResponse", listener: (response: Buffer) => void): this; + prependOnceListener(event: "secureConnect", listener: () => void): this; + } + + export interface TlsOptions extends SecureContextOptions { + handshakeTimeout?: number; + requestCert?: boolean; + rejectUnauthorized?: boolean; + NPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array; + ALPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array; + SNICallback?: (servername: string, cb: (err: Error | null, ctx: SecureContext) => void) => void; + sessionTimeout?: number; + ticketKeys?: Buffer; + } + + export interface ConnectionOptions extends SecureContextOptions { + host?: string; + port?: number; + path?: string; // Creates unix socket connection to path. If this option is specified, `host` and `port` are ignored. + socket?: net.Socket; // Establish secure connection on a given socket rather than creating a new socket + rejectUnauthorized?: boolean; // Defaults to true + NPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array; + ALPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array; + checkServerIdentity?: typeof checkServerIdentity; + servername?: string; // SNI TLS Extension + session?: Buffer; + minDHSize?: number; + secureContext?: SecureContext; // If not provided, the entire ConnectionOptions object will be passed to tls.createSecureContext() + lookup?: net.LookupFunction; + } + + export class Server extends net.Server { + addContext(hostName: string, credentials: { + key: string; + cert: string; + ca: string; + }): void; + + /** + * events.EventEmitter + * 1. tlsClientError + * 2. newSession + * 3. OCSPRequest + * 4. resumeSession + * 5. secureConnection + */ + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "tlsClientError", listener: (err: Error, tlsSocket: TLSSocket) => void): this; + addListener(event: "newSession", listener: (sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void) => void): this; + addListener(event: "OCSPRequest", listener: (certificate: Buffer, issuer: Buffer, callback: Function) => void): this; + addListener(event: "resumeSession", listener: (sessionId: any, callback: (err: Error, sessionData: any) => void) => void): this; + addListener(event: "secureConnection", listener: (tlsSocket: TLSSocket) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "tlsClientError", err: Error, tlsSocket: TLSSocket): boolean; + emit(event: "newSession", sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void): boolean; + emit(event: "OCSPRequest", certificate: Buffer, issuer: Buffer, callback: Function): boolean; + emit(event: "resumeSession", sessionId: any, callback: (err: Error, sessionData: any) => void): boolean; + emit(event: "secureConnection", tlsSocket: TLSSocket): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "tlsClientError", listener: (err: Error, tlsSocket: TLSSocket) => void): this; + on(event: "newSession", listener: (sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void) => void): this; + on(event: "OCSPRequest", listener: (certificate: Buffer, issuer: Buffer, callback: Function) => void): this; + on(event: "resumeSession", listener: (sessionId: any, callback: (err: Error, sessionData: any) => void) => void): this; + on(event: "secureConnection", listener: (tlsSocket: TLSSocket) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "tlsClientError", listener: (err: Error, tlsSocket: TLSSocket) => void): this; + once(event: "newSession", listener: (sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void) => void): this; + once(event: "OCSPRequest", listener: (certificate: Buffer, issuer: Buffer, callback: Function) => void): this; + once(event: "resumeSession", listener: (sessionId: any, callback: (err: Error, sessionData: any) => void) => void): this; + once(event: "secureConnection", listener: (tlsSocket: TLSSocket) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "tlsClientError", listener: (err: Error, tlsSocket: TLSSocket) => void): this; + prependListener(event: "newSession", listener: (sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void) => void): this; + prependListener(event: "OCSPRequest", listener: (certificate: Buffer, issuer: Buffer, callback: Function) => void): this; + prependListener(event: "resumeSession", listener: (sessionId: any, callback: (err: Error, sessionData: any) => void) => void): this; + prependListener(event: "secureConnection", listener: (tlsSocket: TLSSocket) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "tlsClientError", listener: (err: Error, tlsSocket: TLSSocket) => void): this; + prependOnceListener(event: "newSession", listener: (sessionId: any, sessionData: any, callback: (err: Error, resp: Buffer) => void) => void): this; + prependOnceListener(event: "OCSPRequest", listener: (certificate: Buffer, issuer: Buffer, callback: Function) => void): this; + prependOnceListener(event: "resumeSession", listener: (sessionId: any, callback: (err: Error, sessionData: any) => void) => void): this; + prependOnceListener(event: "secureConnection", listener: (tlsSocket: TLSSocket) => void): this; + } + + export interface SecurePair { + encrypted: any; + cleartext: any; + } + + export interface SecureContextOptions { + pfx?: string | Buffer | Array; + key?: string | Buffer | Array; + passphrase?: string; + cert?: string | Buffer | Array; + ca?: string | Buffer | Array; + ciphers?: string; + honorCipherOrder?: boolean; + ecdhCurve?: string; + clientCertEngine?: string; + crl?: string | Buffer | Array; + dhparam?: string | Buffer; + secureOptions?: number; // Value is a numeric bitmask of the `SSL_OP_*` options + secureProtocol?: string; // SSL Method, e.g. SSLv23_method + sessionIdContext?: string; + } + + export interface SecureContext { + context: any; + } + + /* + * Verifies the certificate `cert` is issued to host `host`. + * @host The hostname to verify the certificate against + * @cert PeerCertificate representing the peer's certificate + * + * Returns Error object, populating it with the reason, host and cert on failure. On success, returns undefined. + */ + export function checkServerIdentity(host: string, cert: PeerCertificate): Error | undefined; + export function createServer(options: TlsOptions, secureConnectionListener?: (socket: TLSSocket) => void): Server; + export function connect(options: ConnectionOptions, secureConnectionListener?: () => void): TLSSocket; + export function connect(port: number, host?: string, options?: ConnectionOptions, secureConnectListener?: () => void): TLSSocket; + export function connect(port: number, options?: ConnectionOptions, secureConnectListener?: () => void): TLSSocket; + export function createSecurePair(credentials?: crypto.Credentials, isServer?: boolean, requestCert?: boolean, rejectUnauthorized?: boolean): SecurePair; + export function createSecureContext(details: SecureContextOptions): SecureContext; + export function getCiphers(): string[]; + + export var DEFAULT_ECDH_CURVE: string; +} + +declare module "crypto" { + import * as stream from "stream"; + + export interface Certificate { + exportChallenge(spkac: string | Buffer | NodeJS.TypedArray | DataView): Buffer; + exportPublicKey(spkac: string | Buffer | NodeJS.TypedArray | DataView): Buffer; + verifySpkac(spkac: Buffer | NodeJS.TypedArray | DataView): boolean; + } + export var Certificate: { + new(): Certificate; + (): Certificate; + }; + + /** @deprecated since v10.0.0 */ + export var fips: boolean; + + export interface CredentialDetails { + pfx: string; + key: string; + passphrase: string; + cert: string; + ca: string | string[]; + crl: string | string[]; + ciphers: string; + } + export interface Credentials { context?: any; } + export function createCredentials(details: CredentialDetails): Credentials; + export function createHash(algorithm: string, options?: stream.TransformOptions): Hash; + export function createHmac(algorithm: string, key: string | Buffer | NodeJS.TypedArray | DataView, options?: stream.TransformOptions): Hmac; + + type Utf8AsciiLatin1Encoding = "utf8" | "ascii" | "latin1"; + type HexBase64Latin1Encoding = "latin1" | "hex" | "base64"; + type Utf8AsciiBinaryEncoding = "utf8" | "ascii" | "binary"; + type HexBase64BinaryEncoding = "binary" | "base64" | "hex"; + type ECDHKeyFormat = "compressed" | "uncompressed" | "hybrid"; + + export interface Hash extends NodeJS.ReadWriteStream { + update(data: string | Buffer | NodeJS.TypedArray | DataView): Hash; + update(data: string, input_encoding: Utf8AsciiLatin1Encoding): Hash; + digest(): Buffer; + digest(encoding: HexBase64Latin1Encoding): string; + } + export interface Hmac extends NodeJS.ReadWriteStream { + update(data: string | Buffer | NodeJS.TypedArray | DataView): Hmac; + update(data: string, input_encoding: Utf8AsciiLatin1Encoding): Hmac; + digest(): Buffer; + digest(encoding: HexBase64Latin1Encoding): string; + } + export type CipherCCMTypes = 'aes-128-ccm' | 'aes-192-ccm' | 'aes-256-ccm'; + export type CipherGCMTypes = 'aes-128-gcm' | 'aes-192-gcm' | 'aes-256-gcm'; + export interface CipherCCMOptions extends stream.TransformOptions { + authTagLength: number; + } + export interface CipherGCMOptions extends stream.TransformOptions { + authTagLength?: number; + } + /** @deprecated since v10.0.0 use createCipheriv() */ + export function createCipher(algorithm: string, password: string | Buffer | NodeJS.TypedArray | DataView, options?: stream.TransformOptions): Cipher; + export function createCipher(algorithm: CipherCCMTypes, password: string | Buffer | NodeJS.TypedArray | DataView, options: CipherCCMOptions): CipherCCM; + export function createCipher(algorithm: CipherGCMTypes, password: string | Buffer | NodeJS.TypedArray | DataView, options: CipherGCMOptions): CipherGCM; + + export function createCipheriv(algorithm: string, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options?: stream.TransformOptions): Cipher; + export function createCipheriv(algorithm: CipherGCMTypes, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options: CipherCCMOptions): CipherCCM; + export function createCipheriv(algorithm: CipherGCMTypes, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options: CipherGCMOptions): CipherGCM; + + export interface Cipher extends NodeJS.ReadWriteStream { + update(data: string | Buffer | NodeJS.TypedArray | DataView): Buffer; + update(data: string, input_encoding: Utf8AsciiBinaryEncoding): Buffer; + update(data: Buffer | NodeJS.TypedArray | DataView, output_encoding: HexBase64BinaryEncoding): string; + update(data: Buffer | NodeJS.TypedArray | DataView, input_encoding: any, output_encoding: HexBase64BinaryEncoding): string; + // second arg ignored + update(data: string, input_encoding: Utf8AsciiBinaryEncoding, output_encoding: HexBase64BinaryEncoding): string; + final(): Buffer; + final(output_encoding: string): string; + setAutoPadding(auto_padding?: boolean): this; + // getAuthTag(): Buffer; + // setAAD(buffer: Buffer): this; // docs only say buffer + } + export interface CipherCCM extends Cipher { + setAAD(buffer: Buffer, options: { plainTextLength: number }): this; + getAuthTag(): Buffer; + } + export interface CipherGCM extends Cipher { + setAAD(buffer: Buffer, options?: { plainTextLength: number }): this; + getAuthTag(): Buffer; + } + /** @deprecated since v10.0.0 use createCipheriv() */ + export function createDecipher(algorithm: string, password: string | Buffer | NodeJS.TypedArray | DataView, options?: stream.TransformOptions): Decipher; + export function createDecipher(algorithm: CipherCCMTypes, password: string | Buffer | NodeJS.TypedArray | DataView, options: CipherCCMOptions): DecipherCCM; + export function createDecipher(algorithm: CipherGCMTypes, password: string | Buffer | NodeJS.TypedArray | DataView, options: CipherGCMOptions): DecipherGCM; + + export function createDecipheriv(algorithm: string, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options?: stream.TransformOptions): Decipher; + export function createDecipheriv(algorithm: CipherCCMTypes, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options: CipherCCMOptions): DecipherCCM; + export function createDecipheriv(algorithm: CipherGCMTypes, key: string | Buffer | NodeJS.TypedArray | DataView, iv: string | Buffer | NodeJS.TypedArray | DataView, options: CipherGCMOptions): DecipherGCM; + + export interface Decipher extends NodeJS.ReadWriteStream { + update(data: Buffer | NodeJS.TypedArray | DataView): Buffer; + update(data: string, input_encoding: HexBase64BinaryEncoding): Buffer; + update(data: Buffer | NodeJS.TypedArray | DataView, input_encoding: any, output_encoding: Utf8AsciiBinaryEncoding): string; + // second arg is ignored + update(data: string, input_encoding: HexBase64BinaryEncoding, output_encoding: Utf8AsciiBinaryEncoding): string; + final(): Buffer; + final(output_encoding: string): string; + setAutoPadding(auto_padding?: boolean): this; + // setAuthTag(tag: Buffer | NodeJS.TypedArray | DataView): this; + // setAAD(buffer: Buffer | NodeJS.TypedArray | DataView): this; + } + export interface DecipherCCM extends Decipher { + setAuthTag(buffer: Buffer | NodeJS.TypedArray | DataView, options: { plainTextLength: number }): this; + setAAD(buffer: Buffer | NodeJS.TypedArray | DataView): this; + } + export interface DecipherGCM extends Decipher { + setAuthTag(buffer: Buffer | NodeJS.TypedArray | DataView, options?: { plainTextLength: number }): this; + setAAD(buffer: Buffer | NodeJS.TypedArray | DataView): this; + } + + export function createSign(algorithm: string, options?: stream.WritableOptions): Signer; + export interface Signer extends NodeJS.WritableStream { + update(data: string | Buffer | NodeJS.TypedArray | DataView): Signer; + update(data: string, input_encoding: Utf8AsciiLatin1Encoding): Signer; + sign(private_key: string | { key: string; passphrase: string, padding?: number, saltLength?: number }): Buffer; + sign(private_key: string | { key: string; passphrase: string, padding?: number, saltLength?: number }, output_format: HexBase64Latin1Encoding): string; + } + export function createVerify(algorith: string, options?: stream.WritableOptions): Verify; + export interface Verify extends NodeJS.WritableStream { + update(data: string | Buffer | NodeJS.TypedArray | DataView): Verify; + update(data: string, input_encoding: Utf8AsciiLatin1Encoding): Verify; + verify(object: string | Object, signature: Buffer | NodeJS.TypedArray | DataView): boolean; + verify(object: string | Object, signature: string, signature_format: HexBase64Latin1Encoding): boolean; + // https://nodejs.org/api/crypto.html#crypto_verifier_verify_object_signature_signature_format + // The signature field accepts a TypedArray type, but it is only available starting ES2017 + } + export function createDiffieHellman(prime_length: number, generator?: number | Buffer | NodeJS.TypedArray | DataView): DiffieHellman; + export function createDiffieHellman(prime: Buffer | NodeJS.TypedArray | DataView): DiffieHellman; + export function createDiffieHellman(prime: string, prime_encoding: HexBase64Latin1Encoding): DiffieHellman; + export function createDiffieHellman(prime: string, prime_encoding: HexBase64Latin1Encoding, generator: number | Buffer | NodeJS.TypedArray | DataView): DiffieHellman; + export function createDiffieHellman(prime: string, prime_encoding: HexBase64Latin1Encoding, generator: string, generator_encoding: HexBase64Latin1Encoding): DiffieHellman; + export interface DiffieHellman { + generateKeys(): Buffer; + generateKeys(encoding: HexBase64Latin1Encoding): string; + computeSecret(other_public_key: Buffer | NodeJS.TypedArray | DataView): Buffer; + computeSecret(other_public_key: string, input_encoding: HexBase64Latin1Encoding): Buffer; + computeSecret(other_public_key: Buffer | NodeJS.TypedArray | DataView, output_encoding: HexBase64Latin1Encoding): string; + computeSecret(other_public_key: string, input_encoding: HexBase64Latin1Encoding, output_encoding: HexBase64Latin1Encoding): string; + getPrime(): Buffer; + getPrime(encoding: HexBase64Latin1Encoding): string; + getGenerator(): Buffer; + getGenerator(encoding: HexBase64Latin1Encoding): string; + getPublicKey(): Buffer; + getPublicKey(encoding: HexBase64Latin1Encoding): string; + getPrivateKey(): Buffer; + getPrivateKey(encoding: HexBase64Latin1Encoding): string; + setPublicKey(public_key: Buffer | NodeJS.TypedArray | DataView): void; + setPublicKey(public_key: string, encoding: string): void; + setPrivateKey(private_key: Buffer | NodeJS.TypedArray | DataView): void; + setPrivateKey(private_key: string, encoding: string): void; + verifyError: number; + } + export function getDiffieHellman(group_name: string): DiffieHellman; + export function pbkdf2(password: string | Buffer | NodeJS.TypedArray | DataView, salt: string | Buffer | NodeJS.TypedArray | DataView, iterations: number, keylen: number, digest: string, callback: (err: Error | null, derivedKey: Buffer) => any): void; + export function pbkdf2Sync(password: string | Buffer | NodeJS.TypedArray | DataView, salt: string | Buffer | NodeJS.TypedArray | DataView, iterations: number, keylen: number, digest: string): Buffer; + + export function randomBytes(size: number): Buffer; + export function randomBytes(size: number, callback: (err: Error | null, buf: Buffer) => void): void; + export function pseudoRandomBytes(size: number): Buffer; + export function pseudoRandomBytes(size: number, callback: (err: Error | null, buf: Buffer) => void): void; + + export function randomFillSync(buffer: T, offset?: number, size?: number): T; + export function randomFill(buffer: T, callback: (err: Error | null, buf: T) => void): void; + export function randomFill(buffer: T, offset: number, callback: (err: Error | null, buf: T) => void): void; + export function randomFill(buffer: T, offset: number, size: number, callback: (err: Error | null, buf: T) => void): void; + + export interface ScryptOptions { + N?: number; + r?: number; + p?: number; + maxmem?: number; + } + export function scrypt(password: string | Buffer | NodeJS.TypedArray | DataView, salt: string | Buffer | NodeJS.TypedArray | DataView, keylen: number, callback: (err: Error | null, derivedKey: Buffer) => void): void; + export function scrypt(password: string | Buffer | NodeJS.TypedArray | DataView, salt: string | Buffer | NodeJS.TypedArray | DataView, keylen: number, options: ScryptOptions, callback: (err: Error | null, derivedKey: Buffer) => void): void; + export function scryptSync(password: string | Buffer | NodeJS.TypedArray | DataView, salt: string | Buffer | NodeJS.TypedArray | DataView, keylen: number, options?: ScryptOptions): Buffer; + + export interface RsaPublicKey { + key: string; + padding?: number; + } + export interface RsaPrivateKey { + key: string; + passphrase?: string; + padding?: number; + } + export function publicEncrypt(public_key: string | RsaPublicKey, buffer: Buffer | NodeJS.TypedArray | DataView): Buffer; + export function privateDecrypt(private_key: string | RsaPrivateKey, buffer: Buffer | NodeJS.TypedArray | DataView): Buffer; + export function privateEncrypt(private_key: string | RsaPrivateKey, buffer: Buffer | NodeJS.TypedArray | DataView): Buffer; + export function publicDecrypt(public_key: string | RsaPublicKey, buffer: Buffer | NodeJS.TypedArray | DataView): Buffer; + export function getCiphers(): string[]; + export function getCurves(): string[]; + export function getHashes(): string[]; + export class ECDH { + static convertKey(key: string | Buffer | NodeJS.TypedArray | DataView, curve: string, inputEncoding?: HexBase64Latin1Encoding, outputEncoding?: "latin1" | "hex" | "base64", format?: "uncompressed" | "compressed" | "hybrid"): Buffer | string; + generateKeys(): Buffer; + generateKeys(encoding: HexBase64Latin1Encoding, format?: ECDHKeyFormat): string; + computeSecret(other_public_key: Buffer | NodeJS.TypedArray | DataView): Buffer; + computeSecret(other_public_key: string, input_encoding: HexBase64Latin1Encoding): Buffer; + computeSecret(other_public_key: Buffer | NodeJS.TypedArray | DataView, output_encoding: HexBase64Latin1Encoding): string; + computeSecret(other_public_key: string, input_encoding: HexBase64Latin1Encoding, output_encoding: HexBase64Latin1Encoding): string; + getPrivateKey(): Buffer; + getPrivateKey(encoding: HexBase64Latin1Encoding): string; + getPublicKey(): Buffer; + getPublicKey(encoding: HexBase64Latin1Encoding, format?: ECDHKeyFormat): string; + setPrivateKey(private_key: Buffer | NodeJS.TypedArray | DataView): void; + setPrivateKey(private_key: string, encoding: HexBase64Latin1Encoding): void; + } + export function createECDH(curve_name: string): ECDH; + export function timingSafeEqual(a: Buffer | NodeJS.TypedArray | DataView, b: Buffer | NodeJS.TypedArray | DataView): boolean; + /** @deprecated since v10.0.0 */ + export var DEFAULT_ENCODING: string; +} + +declare module "stream" { + import * as events from "events"; + + class internal extends events.EventEmitter { + pipe(destination: T, options?: { end?: boolean; }): T; + } + + namespace internal { + export class Stream extends internal { } + + export interface ReadableOptions { + highWaterMark?: number; + encoding?: string; + objectMode?: boolean; + read?(this: Readable, size: number): void; + destroy?(this: Readable, error: Error | null, callback: (error: Error | null) => void): void; + } + + export class Readable extends Stream implements NodeJS.ReadableStream { + readable: boolean; + readonly readableHighWaterMark: number; + readonly readableLength: number; + constructor(opts?: ReadableOptions); + _read(size: number): void; + read(size?: number): any; + setEncoding(encoding: string): this; + pause(): this; + resume(): this; + isPaused(): boolean; + unpipe(destination?: T): this; + unshift(chunk: any): void; + wrap(oldStream: NodeJS.ReadableStream): this; + push(chunk: any, encoding?: string): boolean; + _destroy(error: Error | null, callback: (error: Error | null) => void): void; + destroy(error?: Error): void; + + /** + * Event emitter + * The defined events on documents including: + * 1. close + * 2. data + * 3. end + * 4. readable + * 5. error + */ + addListener(event: "close", listener: () => void): this; + addListener(event: "data", listener: (chunk: any) => void): this; + addListener(event: "end", listener: () => void): this; + addListener(event: "readable", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: string | symbol, listener: (...args: any[]) => void): this; + + emit(event: "close"): boolean; + emit(event: "data", chunk: any): boolean; + emit(event: "end"): boolean; + emit(event: "readable"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: string | symbol, ...args: any[]): boolean; + + on(event: "close", listener: () => void): this; + on(event: "data", listener: (chunk: any) => void): this; + on(event: "end", listener: () => void): this; + on(event: "readable", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: string | symbol, listener: (...args: any[]) => void): this; + + once(event: "close", listener: () => void): this; + once(event: "data", listener: (chunk: any) => void): this; + once(event: "end", listener: () => void): this; + once(event: "readable", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: string | symbol, listener: (...args: any[]) => void): this; + + prependListener(event: "close", listener: () => void): this; + prependListener(event: "data", listener: (chunk: any) => void): this; + prependListener(event: "end", listener: () => void): this; + prependListener(event: "readable", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: string | symbol, listener: (...args: any[]) => void): this; + + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "data", listener: (chunk: any) => void): this; + prependOnceListener(event: "end", listener: () => void): this; + prependOnceListener(event: "readable", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this; + + removeListener(event: "close", listener: () => void): this; + removeListener(event: "data", listener: (chunk: any) => void): this; + removeListener(event: "end", listener: () => void): this; + removeListener(event: "readable", listener: () => void): this; + removeListener(event: "error", listener: (err: Error) => void): this; + removeListener(event: string | symbol, listener: (...args: any[]) => void): this; + + [Symbol.asyncIterator](): AsyncIterableIterator; + } + + export interface WritableOptions { + highWaterMark?: number; + decodeStrings?: boolean; + objectMode?: boolean; + write?(this: Writable, chunk: any, encoding: string, callback: (error?: Error | null) => void): void; + writev?(this: Writable, chunks: Array<{ chunk: any, encoding: string }>, callback: (error?: Error | null) => void): void; + destroy?(this: Writable, error: Error | null, callback: (error: Error | null) => void): void; + final?(this: Writable, callback: (error?: Error | null) => void): void; + } + + export class Writable extends Stream implements NodeJS.WritableStream { + writable: boolean; + readonly writableHighWaterMark: number; + readonly writableLength: number; + constructor(opts?: WritableOptions); + _write(chunk: any, encoding: string, callback: (error?: Error | null) => void): void; + _writev?(chunks: Array<{ chunk: any, encoding: string }>, callback: (error?: Error | null) => void): void; + _destroy(error: Error | null, callback: (error: Error | null) => void): void; + _final(callback: (error?: Error | null) => void): void; + write(chunk: any, cb?: (error: Error | null | undefined) => void): boolean; + write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): boolean; + setDefaultEncoding(encoding: string): this; + end(cb?: () => void): void; + end(chunk: any, cb?: () => void): void; + end(chunk: any, encoding?: string, cb?: () => void): void; + cork(): void; + uncork(): void; + destroy(error?: Error): void; + + /** + * Event emitter + * The defined events on documents including: + * 1. close + * 2. drain + * 3. error + * 4. finish + * 5. pipe + * 6. unpipe + */ + addListener(event: "close", listener: () => void): this; + addListener(event: "drain", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "finish", listener: () => void): this; + addListener(event: "pipe", listener: (src: Readable) => void): this; + addListener(event: "unpipe", listener: (src: Readable) => void): this; + addListener(event: string | symbol, listener: (...args: any[]) => void): this; + + emit(event: "close"): boolean; + emit(event: "drain"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "finish"): boolean; + emit(event: "pipe", src: Readable): boolean; + emit(event: "unpipe", src: Readable): boolean; + emit(event: string | symbol, ...args: any[]): boolean; + + on(event: "close", listener: () => void): this; + on(event: "drain", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "finish", listener: () => void): this; + on(event: "pipe", listener: (src: Readable) => void): this; + on(event: "unpipe", listener: (src: Readable) => void): this; + on(event: string | symbol, listener: (...args: any[]) => void): this; + + once(event: "close", listener: () => void): this; + once(event: "drain", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "finish", listener: () => void): this; + once(event: "pipe", listener: (src: Readable) => void): this; + once(event: "unpipe", listener: (src: Readable) => void): this; + once(event: string | symbol, listener: (...args: any[]) => void): this; + + prependListener(event: "close", listener: () => void): this; + prependListener(event: "drain", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "finish", listener: () => void): this; + prependListener(event: "pipe", listener: (src: Readable) => void): this; + prependListener(event: "unpipe", listener: (src: Readable) => void): this; + prependListener(event: string | symbol, listener: (...args: any[]) => void): this; + + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "drain", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "finish", listener: () => void): this; + prependOnceListener(event: "pipe", listener: (src: Readable) => void): this; + prependOnceListener(event: "unpipe", listener: (src: Readable) => void): this; + prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this; + + removeListener(event: "close", listener: () => void): this; + removeListener(event: "drain", listener: () => void): this; + removeListener(event: "error", listener: (err: Error) => void): this; + removeListener(event: "finish", listener: () => void): this; + removeListener(event: "pipe", listener: (src: Readable) => void): this; + removeListener(event: "unpipe", listener: (src: Readable) => void): this; + removeListener(event: string | symbol, listener: (...args: any[]) => void): this; + } + + export interface DuplexOptions extends ReadableOptions, WritableOptions { + allowHalfOpen?: boolean; + readableObjectMode?: boolean; + writableObjectMode?: boolean; + read?(this: Duplex, size: number): void; + write?(this: Duplex, chunk: any, encoding: string, callback: (error?: Error | null) => void): void; + writev?(this: Duplex, chunks: Array<{ chunk: any, encoding: string }>, callback: (error?: Error | null) => void): void; + final?(this: Duplex, callback: (error?: Error | null) => void): void; + destroy?(this: Duplex, error: Error | null, callback: (error: Error | null) => void): void; + } + + // Note: Duplex extends both Readable and Writable. + export class Duplex extends Readable implements Writable { + writable: boolean; + readonly writableHighWaterMark: number; + readonly writableLength: number; + constructor(opts?: DuplexOptions); + _write(chunk: any, encoding: string, callback: (error?: Error | null) => void): void; + _writev?(chunks: Array<{ chunk: any, encoding: string }>, callback: (error?: Error | null) => void): void; + _destroy(error: Error | null, callback: (error: Error | null) => void): void; + _final(callback: (error?: Error | null) => void): void; + write(chunk: any, cb?: (error: Error | null | undefined) => void): boolean; + write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): boolean; + setDefaultEncoding(encoding: string): this; + end(cb?: () => void): void; + end(chunk: any, cb?: () => void): void; + end(chunk: any, encoding?: string, cb?: () => void): void; + cork(): void; + uncork(): void; + } + + type TransformCallback = (error?: Error, data?: any) => void; + + export interface TransformOptions extends DuplexOptions { + read?(this: Transform, size: number): void; + write?(this: Transform, chunk: any, encoding: string, callback: (error?: Error | null) => void): void; + writev?(this: Transform, chunks: Array<{ chunk: any, encoding: string }>, callback: (error?: Error | null) => void): void; + final?(this: Transform, callback: (error?: Error | null) => void): void; + destroy?(this: Transform, error: Error | null, callback: (error: Error | null) => void): void; + transform?(this: Transform, chunk: any, encoding: string, callback: TransformCallback): void; + flush?(this: Transform, callback: TransformCallback): void; + } + + export class Transform extends Duplex { + constructor(opts?: TransformOptions); + _transform(chunk: any, encoding: string, callback: TransformCallback): void; + _flush(callback: TransformCallback): void; + } + + export class PassThrough extends Transform { } + + export function pipeline(stream1: NodeJS.ReadableStream, stream2: T, callback?: (err: NodeJS.ErrnoException) => void): T; + export function pipeline(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: T, callback?: (err: NodeJS.ErrnoException) => void): T; + export function pipeline(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: NodeJS.ReadWriteStream, stream4: T, callback?: (err: NodeJS.ErrnoException) => void): T; + export function pipeline(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: NodeJS.ReadWriteStream, stream4: NodeJS.ReadWriteStream, stream5: T, callback?: (err: NodeJS.ErrnoException) => void): T; + export function pipeline(streams: Array, callback?: (err: NodeJS.ErrnoException) => void): NodeJS.WritableStream; + export function pipeline(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream | NodeJS.WritableStream, ...streams: Array void)>): NodeJS.WritableStream; + export namespace pipeline { + export function __promisify__(stream1: NodeJS.ReadableStream, stream2: T): Promise; + export function __promisify__(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: T): Promise; + export function __promisify__(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: NodeJS.ReadWriteStream, stream4: T): Promise; + export function __promisify__(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream, stream3: NodeJS.ReadWriteStream, stream4: NodeJS.ReadWriteStream, stream5: T): Promise; + export function __promisify__(streams: Array): Promise; + export function __promisify__(stream1: NodeJS.ReadableStream, stream2: NodeJS.ReadWriteStream | NodeJS.WritableStream, ...streams: Array): Promise; + } + } + + export = internal; +} + +declare module "util" { + export interface InspectOptions extends NodeJS.InspectOptions { } + export function format(format: any, ...param: any[]): string; + /** @deprecated since v0.11.3 - use `console.error()` instead. */ + export function debug(string: string): void; + /** @deprecated since v0.11.3 - use `console.error()` instead. */ + export function error(...param: any[]): void; + /** @deprecated since v0.11.3 - use `console.log()` instead. */ + export function puts(...param: any[]): void; + /** @deprecated since v0.11.3 - use `console.log()` instead. */ + export function print(...param: any[]): void; + /** @deprecated since v0.11.3 - use a third party module instead. */ + export function log(string: string): void; + export var inspect: { + (object: any, showHidden?: boolean, depth?: number | null, color?: boolean): string; + (object: any, options: InspectOptions): string; + colors: { + [color: string]: [number, number] | undefined + } + styles: { + [style: string]: string | undefined + } + defaultOptions: InspectOptions; + custom: symbol; + }; + /** @deprecated since v4.0.0 - use `Array.isArray()` instead. */ + export function isArray(object: any): object is any[]; + /** @deprecated since v4.0.0 - use `util.types.isRegExp()` instead. */ + export function isRegExp(object: any): object is RegExp; + /** @deprecated since v4.0.0 - use `util.types.isDate()` instead. */ + export function isDate(object: any): object is Date; + /** @deprecated since v4.0.0 - use `util.types.isNativeError()` instead. */ + export function isError(object: any): object is Error; + export function inherits(constructor: any, superConstructor: any): void; + export function debuglog(key: string): (msg: string, ...param: any[]) => void; + /** @deprecated since v4.0.0 - use `typeof value === 'boolean'` instead. */ + export function isBoolean(object: any): object is boolean; + /** @deprecated since v4.0.0 - use `Buffer.isBuffer()` instead. */ + export function isBuffer(object: any): object is Buffer; + /** @deprecated since v4.0.0 - use `typeof value === 'function'` instead. */ + export function isFunction(object: any): boolean; + /** @deprecated since v4.0.0 - use `value === null` instead. */ + export function isNull(object: any): object is null; + /** @deprecated since v4.0.0 - use `value === null || value === undefined` instead. */ + export function isNullOrUndefined(object: any): object is null | undefined; + /** @deprecated since v4.0.0 - use `typeof value === 'number'` instead. */ + export function isNumber(object: any): object is number; + /** @deprecated since v4.0.0 - use `value !== null && typeof value === 'object'` instead. */ + export function isObject(object: any): boolean; + /** @deprecated since v4.0.0 - use `(typeof value !== 'object' && typeof value !== 'function') || value === null` instead. */ + export function isPrimitive(object: any): boolean; + /** @deprecated since v4.0.0 - use `typeof value === 'string'` instead. */ + export function isString(object: any): object is string; + /** @deprecated since v4.0.0 - use `typeof value === 'symbol'` instead. */ + export function isSymbol(object: any): object is symbol; + /** @deprecated since v4.0.0 - use `value === undefined` instead. */ + export function isUndefined(object: any): object is undefined; + export function deprecate(fn: T, message: string): T; + export function isDeepStrictEqual(val1: any, val2: any): boolean; + + export interface CustomPromisify extends Function { + __promisify__: TCustom; + } + + export function callbackify(fn: () => Promise): (callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: () => Promise): (callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1) => Promise): (arg1: T1, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1) => Promise): (arg1: T1, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2) => Promise): (arg1: T1, arg2: T2, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2) => Promise): (arg1: T1, arg2: T2, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3) => Promise): (arg1: T1, arg2: T2, arg3: T3, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3) => Promise): (arg1: T1, arg2: T2, arg3: T3, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, arg6: T6) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, arg6: T6, callback: (err: NodeJS.ErrnoException) => void) => void; + export function callbackify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, arg6: T6) => Promise): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, arg6: T6, callback: (err: NodeJS.ErrnoException, result: TResult) => void) => void; + + export function promisify(fn: CustomPromisify): TCustom; + export function promisify(fn: (callback: (err: Error | null, result: TResult) => void) => void): () => Promise; + export function promisify(fn: (callback: (err: Error | null) => void) => void): () => Promise; + export function promisify(fn: (arg1: T1, callback: (err: Error | null, result: TResult) => void) => void): (arg1: T1) => Promise; + export function promisify(fn: (arg1: T1, callback: (err: Error | null) => void) => void): (arg1: T1) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, callback: (err: Error | null, result: TResult) => void) => void): (arg1: T1, arg2: T2) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, callback: (err: Error | null) => void) => void): (arg1: T1, arg2: T2) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, callback: (err: Error | null, result: TResult) => void) => void): (arg1: T1, arg2: T2, arg3: T3) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, callback: (err: Error | null) => void) => void): (arg1: T1, arg2: T2, arg3: T3) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, callback: (err: Error | null, result: TResult) => void) => void): (arg1: T1, arg2: T2, arg3: T3, arg4: T4) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, callback: (err: Error | null) => void) => void): (arg1: T1, arg2: T2, arg3: T3, arg4: T4) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, callback: (err: Error | null, result: TResult) => void) => void): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5) => Promise; + export function promisify(fn: (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5, callback: (err: Error | null) => void) => void): (arg1: T1, arg2: T2, arg3: T3, arg4: T4, arg5: T5) => Promise; + export function promisify(fn: Function): Function; + export namespace promisify { + const custom: symbol; + } + + export namespace types { + export function isAnyArrayBuffer(object: any): boolean; + export function isArgumentsObject(object: any): object is IArguments; + export function isArrayBuffer(object: any): object is ArrayBuffer; + export function isAsyncFunction(object: any): boolean; + export function isBooleanObject(object: any): object is Boolean; + export function isDataView(object: any): object is DataView; + export function isDate(object: any): object is Date; + export function isExternal(object: any): boolean; + export function isFloat32Array(object: any): object is Float32Array; + export function isFloat64Array(object: any): object is Float64Array; + export function isGeneratorFunction(object: any): boolean; + export function isGeneratorObject(object: any): boolean; + export function isInt8Array(object: any): object is Int8Array; + export function isInt16Array(object: any): object is Int16Array; + export function isInt32Array(object: any): object is Int32Array; + export function isMap(object: any): boolean; + export function isMapIterator(object: any): boolean; + export function isNativeError(object: any): object is Error; + export function isNumberObject(object: any): object is Number; + export function isPromise(object: any): boolean; + export function isProxy(object: any): boolean; + export function isRegExp(object: any): object is RegExp; + export function isSet(object: any): boolean; + export function isSetIterator(object: any): boolean; + export function isSharedArrayBuffer(object: any): boolean; + export function isStringObject(object: any): boolean; + export function isSymbolObject(object: any): boolean; + export function isTypedArray(object: any): object is NodeJS.TypedArray; + export function isUint8Array(object: any): object is Uint8Array; + export function isUint8ClampedArray(object: any): object is Uint8ClampedArray; + export function isUint16Array(object: any): object is Uint16Array; + export function isUint32Array(object: any): object is Uint32Array; + export function isWeakMap(object: any): boolean; + export function isWeakSet(object: any): boolean; + export function isWebAssemblyCompiledModule(object: any): boolean; + } + + export class TextDecoder { + readonly encoding: string; + readonly fatal: boolean; + readonly ignoreBOM: boolean; + constructor( + encoding?: string, + options?: { fatal?: boolean; ignoreBOM?: boolean } + ); + decode( + input?: NodeJS.TypedArray | DataView | ArrayBuffer | null, + options?: { stream?: boolean } + ): string; + } + + export class TextEncoder { + readonly encoding: string; + constructor(); + encode(input?: string): Uint8Array; + } +} + +declare module "assert" { + function internal(value: any, message?: string | Error): void; + namespace internal { + export class AssertionError implements Error { + name: string; + message: string; + actual: any; + expected: any; + operator: string; + generatedMessage: boolean; + code: 'ERR_ASSERTION'; + + constructor(options?: { + message?: string; actual?: any; expected?: any; + operator?: string; stackStartFn?: Function + }); + } + + export function fail(message?: string | Error): never; + /** @deprecated since v10.0.0 - use fail([message]) or other assert functions instead. */ + export function fail(actual: any, expected: any, message?: string | Error, operator?: string, stackStartFn?: Function): never; + export function ok(value: any, message?: string | Error): void; + /** @deprecated since v9.9.0 - use strictEqual() instead. */ + export function equal(actual: any, expected: any, message?: string | Error): void; + /** @deprecated since v9.9.0 - use notStrictEqual() instead. */ + export function notEqual(actual: any, expected: any, message?: string | Error): void; + /** @deprecated since v9.9.0 - use deepStrictEqual() instead. */ + export function deepEqual(actual: any, expected: any, message?: string | Error): void; + /** @deprecated since v9.9.0 - use notDeepStrictEqual() instead. */ + export function notDeepEqual(actual: any, expected: any, message?: string | Error): void; + export function strictEqual(actual: any, expected: any, message?: string | Error): void; + export function notStrictEqual(actual: any, expected: any, message?: string | Error): void; + export function deepStrictEqual(actual: any, expected: any, message?: string | Error): void; + export function notDeepStrictEqual(actual: any, expected: any, message?: string | Error): void; + + export function throws(block: Function, message?: string | Error): void; + export function throws(block: Function, error: RegExp | Function | Object | Error, message?: string | Error): void; + export function doesNotThrow(block: Function, message?: string | Error): void; + export function doesNotThrow(block: Function, error: RegExp | Function, message?: string | Error): void; + + export function ifError(value: any): void; + + export function rejects(block: Function | Promise, message?: string | Error): Promise; + export function rejects(block: Function | Promise, error: RegExp | Function | Object | Error, message?: string | Error): Promise; + export function doesNotReject(block: Function | Promise, message?: string | Error): Promise; + export function doesNotReject(block: Function | Promise, error: RegExp | Function, message?: string | Error): Promise; + + export var strict: typeof internal; + } + + export = internal; +} + +declare module "tty" { + import * as net from "net"; + + export function isatty(fd: number): boolean; + export class ReadStream extends net.Socket { + isRaw: boolean; + setRawMode(mode: boolean): void; + isTTY: boolean; + } + export class WriteStream extends net.Socket { + columns: number; + rows: number; + isTTY: boolean; + } +} + +declare module "domain" { + import * as events from "events"; + + export class Domain extends events.EventEmitter implements NodeJS.Domain { + run(fn: Function): void; + add(emitter: events.EventEmitter): void; + remove(emitter: events.EventEmitter): void; + bind(cb: (err: Error, data: any) => any): any; + intercept(cb: (data: any) => any): any; + members: any[]; + enter(): void; + exit(): void; + } + + export function create(): Domain; +} + +declare module "constants" { + export var E2BIG: number; + export var EACCES: number; + export var EADDRINUSE: number; + export var EADDRNOTAVAIL: number; + export var EAFNOSUPPORT: number; + export var EAGAIN: number; + export var EALREADY: number; + export var EBADF: number; + export var EBADMSG: number; + export var EBUSY: number; + export var ECANCELED: number; + export var ECHILD: number; + export var ECONNABORTED: number; + export var ECONNREFUSED: number; + export var ECONNRESET: number; + export var EDEADLK: number; + export var EDESTADDRREQ: number; + export var EDOM: number; + export var EEXIST: number; + export var EFAULT: number; + export var EFBIG: number; + export var EHOSTUNREACH: number; + export var EIDRM: number; + export var EILSEQ: number; + export var EINPROGRESS: number; + export var EINTR: number; + export var EINVAL: number; + export var EIO: number; + export var EISCONN: number; + export var EISDIR: number; + export var ELOOP: number; + export var EMFILE: number; + export var EMLINK: number; + export var EMSGSIZE: number; + export var ENAMETOOLONG: number; + export var ENETDOWN: number; + export var ENETRESET: number; + export var ENETUNREACH: number; + export var ENFILE: number; + export var ENOBUFS: number; + export var ENODATA: number; + export var ENODEV: number; + export var ENOENT: number; + export var ENOEXEC: number; + export var ENOLCK: number; + export var ENOLINK: number; + export var ENOMEM: number; + export var ENOMSG: number; + export var ENOPROTOOPT: number; + export var ENOSPC: number; + export var ENOSR: number; + export var ENOSTR: number; + export var ENOSYS: number; + export var ENOTCONN: number; + export var ENOTDIR: number; + export var ENOTEMPTY: number; + export var ENOTSOCK: number; + export var ENOTSUP: number; + export var ENOTTY: number; + export var ENXIO: number; + export var EOPNOTSUPP: number; + export var EOVERFLOW: number; + export var EPERM: number; + export var EPIPE: number; + export var EPROTO: number; + export var EPROTONOSUPPORT: number; + export var EPROTOTYPE: number; + export var ERANGE: number; + export var EROFS: number; + export var ESPIPE: number; + export var ESRCH: number; + export var ETIME: number; + export var ETIMEDOUT: number; + export var ETXTBSY: number; + export var EWOULDBLOCK: number; + export var EXDEV: number; + export var WSAEINTR: number; + export var WSAEBADF: number; + export var WSAEACCES: number; + export var WSAEFAULT: number; + export var WSAEINVAL: number; + export var WSAEMFILE: number; + export var WSAEWOULDBLOCK: number; + export var WSAEINPROGRESS: number; + export var WSAEALREADY: number; + export var WSAENOTSOCK: number; + export var WSAEDESTADDRREQ: number; + export var WSAEMSGSIZE: number; + export var WSAEPROTOTYPE: number; + export var WSAENOPROTOOPT: number; + export var WSAEPROTONOSUPPORT: number; + export var WSAESOCKTNOSUPPORT: number; + export var WSAEOPNOTSUPP: number; + export var WSAEPFNOSUPPORT: number; + export var WSAEAFNOSUPPORT: number; + export var WSAEADDRINUSE: number; + export var WSAEADDRNOTAVAIL: number; + export var WSAENETDOWN: number; + export var WSAENETUNREACH: number; + export var WSAENETRESET: number; + export var WSAECONNABORTED: number; + export var WSAECONNRESET: number; + export var WSAENOBUFS: number; + export var WSAEISCONN: number; + export var WSAENOTCONN: number; + export var WSAESHUTDOWN: number; + export var WSAETOOMANYREFS: number; + export var WSAETIMEDOUT: number; + export var WSAECONNREFUSED: number; + export var WSAELOOP: number; + export var WSAENAMETOOLONG: number; + export var WSAEHOSTDOWN: number; + export var WSAEHOSTUNREACH: number; + export var WSAENOTEMPTY: number; + export var WSAEPROCLIM: number; + export var WSAEUSERS: number; + export var WSAEDQUOT: number; + export var WSAESTALE: number; + export var WSAEREMOTE: number; + export var WSASYSNOTREADY: number; + export var WSAVERNOTSUPPORTED: number; + export var WSANOTINITIALISED: number; + export var WSAEDISCON: number; + export var WSAENOMORE: number; + export var WSAECANCELLED: number; + export var WSAEINVALIDPROCTABLE: number; + export var WSAEINVALIDPROVIDER: number; + export var WSAEPROVIDERFAILEDINIT: number; + export var WSASYSCALLFAILURE: number; + export var WSASERVICE_NOT_FOUND: number; + export var WSATYPE_NOT_FOUND: number; + export var WSA_E_NO_MORE: number; + export var WSA_E_CANCELLED: number; + export var WSAEREFUSED: number; + export var SIGHUP: number; + export var SIGINT: number; + export var SIGILL: number; + export var SIGABRT: number; + export var SIGFPE: number; + export var SIGKILL: number; + export var SIGSEGV: number; + export var SIGTERM: number; + export var SIGBREAK: number; + export var SIGWINCH: number; + export var SSL_OP_ALL: number; + export var SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION: number; + export var SSL_OP_CIPHER_SERVER_PREFERENCE: number; + export var SSL_OP_CISCO_ANYCONNECT: number; + export var SSL_OP_COOKIE_EXCHANGE: number; + export var SSL_OP_CRYPTOPRO_TLSEXT_BUG: number; + export var SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS: number; + export var SSL_OP_EPHEMERAL_RSA: number; + export var SSL_OP_LEGACY_SERVER_CONNECT: number; + export var SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER: number; + export var SSL_OP_MICROSOFT_SESS_ID_BUG: number; + export var SSL_OP_MSIE_SSLV2_RSA_PADDING: number; + export var SSL_OP_NETSCAPE_CA_DN_BUG: number; + export var SSL_OP_NETSCAPE_CHALLENGE_BUG: number; + export var SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG: number; + export var SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG: number; + export var SSL_OP_NO_COMPRESSION: number; + export var SSL_OP_NO_QUERY_MTU: number; + export var SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION: number; + export var SSL_OP_NO_SSLv2: number; + export var SSL_OP_NO_SSLv3: number; + export var SSL_OP_NO_TICKET: number; + export var SSL_OP_NO_TLSv1: number; + export var SSL_OP_NO_TLSv1_1: number; + export var SSL_OP_NO_TLSv1_2: number; + export var SSL_OP_PKCS1_CHECK_1: number; + export var SSL_OP_PKCS1_CHECK_2: number; + export var SSL_OP_SINGLE_DH_USE: number; + export var SSL_OP_SINGLE_ECDH_USE: number; + export var SSL_OP_SSLEAY_080_CLIENT_DH_BUG: number; + export var SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG: number; + export var SSL_OP_TLS_BLOCK_PADDING_BUG: number; + export var SSL_OP_TLS_D5_BUG: number; + export var SSL_OP_TLS_ROLLBACK_BUG: number; + export var ENGINE_METHOD_DSA: number; + export var ENGINE_METHOD_DH: number; + export var ENGINE_METHOD_RAND: number; + export var ENGINE_METHOD_ECDH: number; + export var ENGINE_METHOD_ECDSA: number; + export var ENGINE_METHOD_CIPHERS: number; + export var ENGINE_METHOD_DIGESTS: number; + export var ENGINE_METHOD_STORE: number; + export var ENGINE_METHOD_PKEY_METHS: number; + export var ENGINE_METHOD_PKEY_ASN1_METHS: number; + export var ENGINE_METHOD_ALL: number; + export var ENGINE_METHOD_NONE: number; + export var DH_CHECK_P_NOT_SAFE_PRIME: number; + export var DH_CHECK_P_NOT_PRIME: number; + export var DH_UNABLE_TO_CHECK_GENERATOR: number; + export var DH_NOT_SUITABLE_GENERATOR: number; + export var NPN_ENABLED: number; + export var RSA_PKCS1_PADDING: number; + export var RSA_SSLV23_PADDING: number; + export var RSA_NO_PADDING: number; + export var RSA_PKCS1_OAEP_PADDING: number; + export var RSA_X931_PADDING: number; + export var RSA_PKCS1_PSS_PADDING: number; + export var POINT_CONVERSION_COMPRESSED: number; + export var POINT_CONVERSION_UNCOMPRESSED: number; + export var POINT_CONVERSION_HYBRID: number; + export var O_RDONLY: number; + export var O_WRONLY: number; + export var O_RDWR: number; + export var S_IFMT: number; + export var S_IFREG: number; + export var S_IFDIR: number; + export var S_IFCHR: number; + export var S_IFBLK: number; + export var S_IFIFO: number; + export var S_IFSOCK: number; + export var S_IRWXU: number; + export var S_IRUSR: number; + export var S_IWUSR: number; + export var S_IXUSR: number; + export var S_IRWXG: number; + export var S_IRGRP: number; + export var S_IWGRP: number; + export var S_IXGRP: number; + export var S_IRWXO: number; + export var S_IROTH: number; + export var S_IWOTH: number; + export var S_IXOTH: number; + export var S_IFLNK: number; + export var O_CREAT: number; + export var O_EXCL: number; + export var O_NOCTTY: number; + export var O_DIRECTORY: number; + export var O_NOATIME: number; + export var O_NOFOLLOW: number; + export var O_SYNC: number; + export var O_DSYNC: number; + export var O_SYMLINK: number; + export var O_DIRECT: number; + export var O_NONBLOCK: number; + export var O_TRUNC: number; + export var O_APPEND: number; + export var F_OK: number; + export var R_OK: number; + export var W_OK: number; + export var X_OK: number; + export var COPYFILE_EXCL: number; + export var COPYFILE_FICLONE: number; + export var COPYFILE_FICLONE_FORCE: number; + export var UV_UDP_REUSEADDR: number; + export var SIGQUIT: number; + export var SIGTRAP: number; + export var SIGIOT: number; + export var SIGBUS: number; + export var SIGUSR1: number; + export var SIGUSR2: number; + export var SIGPIPE: number; + export var SIGALRM: number; + export var SIGCHLD: number; + export var SIGSTKFLT: number; + export var SIGCONT: number; + export var SIGSTOP: number; + export var SIGTSTP: number; + export var SIGTTIN: number; + export var SIGTTOU: number; + export var SIGURG: number; + export var SIGXCPU: number; + export var SIGXFSZ: number; + export var SIGVTALRM: number; + export var SIGPROF: number; + export var SIGIO: number; + export var SIGPOLL: number; + export var SIGPWR: number; + export var SIGSYS: number; + export var SIGUNUSED: number; + export var defaultCoreCipherList: string; + export var defaultCipherList: string; + export var ENGINE_METHOD_RSA: number; + export var ALPN_ENABLED: number; +} + +declare module "module" { + export = NodeJS.Module; +} + +declare module "process" { + export = process; +} + +declare module "v8" { + interface HeapSpaceInfo { + space_name: string; + space_size: number; + space_used_size: number; + space_available_size: number; + physical_space_size: number; + } + + // ** Signifies if the --zap_code_space option is enabled or not. 1 == enabled, 0 == disabled. */ + type DoesZapCodeSpaceFlag = 0 | 1; + + interface HeapInfo { + total_heap_size: number; + total_heap_size_executable: number; + total_physical_size: number; + total_available_size: number; + used_heap_size: number; + heap_size_limit: number; + malloced_memory: number; + peak_malloced_memory: number; + does_zap_garbage: DoesZapCodeSpaceFlag; + } + + export function getHeapStatistics(): HeapInfo; + export function getHeapSpaceStatistics(): HeapSpaceInfo[]; + export function setFlagsFromString(flags: string): void; +} + +declare module "timers" { + export function setTimeout(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timer; + export namespace setTimeout { + export function __promisify__(ms: number): Promise; + export function __promisify__(ms: number, value: T): Promise; + } + export function clearTimeout(timeoutId: NodeJS.Timer): void; + export function setInterval(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timer; + export function clearInterval(intervalId: NodeJS.Timer): void; + export function setImmediate(callback: (...args: any[]) => void, ...args: any[]): any; + export namespace setImmediate { + export function __promisify__(): Promise; + export function __promisify__(value: T): Promise; + } + export function clearImmediate(immediateId: any): void; +} + +declare module "console" { + export = console; +} + +/** + * Async Hooks module: https://nodejs.org/api/async_hooks.html + */ +declare module "async_hooks" { + /** + * Returns the asyncId of the current execution context. + */ + export function executionAsyncId(): number; + + /** + * Returns the ID of the resource responsible for calling the callback that is currently being executed. + */ + export function triggerAsyncId(): number; + + export interface HookCallbacks { + /** + * Called when a class is constructed that has the possibility to emit an asynchronous event. + * @param asyncId a unique ID for the async resource + * @param type the type of the async resource + * @param triggerAsyncId the unique ID of the async resource in whose execution context this async resource was created + * @param resource reference to the resource representing the async operation, needs to be released during destroy + */ + init?(asyncId: number, type: string, triggerAsyncId: number, resource: Object): void; + + /** + * When an asynchronous operation is initiated or completes a callback is called to notify the user. + * The before callback is called just before said callback is executed. + * @param asyncId the unique identifier assigned to the resource about to execute the callback. + */ + before?(asyncId: number): void; + + /** + * Called immediately after the callback specified in before is completed. + * @param asyncId the unique identifier assigned to the resource which has executed the callback. + */ + after?(asyncId: number): void; + + /** + * Called when a promise has resolve() called. This may not be in the same execution id + * as the promise itself. + * @param asyncId the unique id for the promise that was resolve()d. + */ + promiseResolve?(asyncId: number): void; + + /** + * Called after the resource corresponding to asyncId is destroyed + * @param asyncId a unique ID for the async resource + */ + destroy?(asyncId: number): void; + } + + export interface AsyncHook { + /** + * Enable the callbacks for a given AsyncHook instance. If no callbacks are provided enabling is a noop. + */ + enable(): this; + + /** + * Disable the callbacks for a given AsyncHook instance from the global pool of AsyncHook callbacks to be executed. Once a hook has been disabled it will not be called again until enabled. + */ + disable(): this; + } + + /** + * Registers functions to be called for different lifetime events of each async operation. + * @param options the callbacks to register + * @return an AsyncHooks instance used for disabling and enabling hooks + */ + export function createHook(options: HookCallbacks): AsyncHook; + + export interface AsyncResourceOptions { + /** + * The ID of the execution context that created this async event. + * Default: `executionAsyncId()` + */ + triggerAsyncId?: number; + + /** + * Disables automatic `emitDestroy` when the object is garbage collected. + * This usually does not need to be set (even if `emitDestroy` is called + * manually), unless the resource's `asyncId` is retrieved and the + * sensitive API's `emitDestroy` is called with it. + * Default: `false` + */ + requireManualDestroy?: boolean; + } + + /** + * The class AsyncResource was designed to be extended by the embedder's async resources. + * Using this users can easily trigger the lifetime events of their own resources. + */ + export class AsyncResource { + /** + * AsyncResource() is meant to be extended. Instantiating a + * new AsyncResource() also triggers init. If triggerAsyncId is omitted then + * async_hook.executionAsyncId() is used. + * @param type The type of async event. + * @param triggerAsyncId The ID of the execution context that created + * this async event (default: `executionAsyncId()`), or an + * AsyncResourceOptions object (since 9.3) + */ + constructor(type: string, triggerAsyncId?: number|AsyncResourceOptions); + + /** + * Call AsyncHooks before callbacks. + * @deprecated since 9.6 - Use asyncResource.runInAsyncScope() instead. + */ + emitBefore(): void; + + /** + * Call AsyncHooks after callbacks. + * @deprecated since 9.6 - Use asyncResource.runInAsyncScope() instead. + */ + emitAfter(): void; + + /** + * Call the provided function with the provided arguments in the + * execution context of the async resource. This will establish the + * context, trigger the AsyncHooks before callbacks, call the function, + * trigger the AsyncHooks after callbacks, and then restore the original + * execution context. + * @param fn The function to call in the execution context of this + * async resource. + * @param thisArg The receiver to be used for the function call. + * @param args Optional arguments to pass to the function. + */ + runInAsyncScope(fn: (this: This, ...args: any[]) => Result, thisArg?: This, ...args: any[]): Result; + + /** + * Call AsyncHooks destroy callbacks. + */ + emitDestroy(): void; + + /** + * @return the unique ID assigned to this AsyncResource instance. + */ + asyncId(): number; + + /** + * @return the trigger ID for this AsyncResource instance. + */ + triggerAsyncId(): number; + } +} + +declare module "http2" { + import * as events from "events"; + import * as fs from "fs"; + import * as net from "net"; + import * as stream from "stream"; + import * as tls from "tls"; + import * as url from "url"; + + import { IncomingHttpHeaders as Http1IncomingHttpHeaders, OutgoingHttpHeaders } from "http"; + export { OutgoingHttpHeaders } from "http"; + + export interface IncomingHttpStatusHeader { + ":status"?: number; + } + + export interface IncomingHttpHeaders extends Http1IncomingHttpHeaders { + ":path"?: string; + ":method"?: string; + ":authority"?: string; + ":scheme"?: string; + } + + // Http2Stream + + export interface StreamPriorityOptions { + exclusive?: boolean; + parent?: number; + weight?: number; + silent?: boolean; + } + + export interface StreamState { + localWindowSize?: number; + state?: number; + streamLocalClose?: number; + streamRemoteClose?: number; + sumDependencyWeight?: number; + weight?: number; + } + + export interface ServerStreamResponseOptions { + endStream?: boolean; + getTrailers?: (trailers: OutgoingHttpHeaders) => void; + } + + export interface StatOptions { + offset: number; + length: number; + } + + export interface ServerStreamFileResponseOptions { + statCheck?: (stats: fs.Stats, headers: OutgoingHttpHeaders, statOptions: StatOptions) => void | boolean; + getTrailers?: (trailers: OutgoingHttpHeaders) => void; + offset?: number; + length?: number; + } + + export interface ServerStreamFileResponseOptionsWithError extends ServerStreamFileResponseOptions { + onError?: (err: NodeJS.ErrnoException) => void; + } + + export interface Http2Stream extends stream.Duplex { + readonly aborted: boolean; + close(code?: number, callback?: () => void): void; + readonly closed: boolean; + readonly destroyed: boolean; + readonly pending: boolean; + priority(options: StreamPriorityOptions): void; + readonly rstCode: number; + readonly session: Http2Session; + setTimeout(msecs: number, callback?: () => void): void; + readonly state: StreamState; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "aborted", listener: () => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "data", listener: (chunk: Buffer | string) => void): this; + addListener(event: "drain", listener: () => void): this; + addListener(event: "end", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "finish", listener: () => void): this; + addListener(event: "frameError", listener: (frameType: number, errorCode: number) => void): this; + addListener(event: "pipe", listener: (src: stream.Readable) => void): this; + addListener(event: "unpipe", listener: (src: stream.Readable) => void): this; + addListener(event: "streamClosed", listener: (code: number) => void): this; + addListener(event: "timeout", listener: () => void): this; + addListener(event: "trailers", listener: (trailers: IncomingHttpHeaders, flags: number) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "aborted"): boolean; + emit(event: "close"): boolean; + emit(event: "data", chunk: Buffer | string): boolean; + emit(event: "drain"): boolean; + emit(event: "end"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "finish"): boolean; + emit(event: "frameError", frameType: number, errorCode: number): boolean; + emit(event: "pipe", src: stream.Readable): boolean; + emit(event: "unpipe", src: stream.Readable): boolean; + emit(event: "streamClosed", code: number): boolean; + emit(event: "timeout"): boolean; + emit(event: "trailers", trailers: IncomingHttpHeaders, flags: number): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "aborted", listener: () => void): this; + on(event: "close", listener: () => void): this; + on(event: "data", listener: (chunk: Buffer | string) => void): this; + on(event: "drain", listener: () => void): this; + on(event: "end", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "finish", listener: () => void): this; + on(event: "frameError", listener: (frameType: number, errorCode: number) => void): this; + on(event: "pipe", listener: (src: stream.Readable) => void): this; + on(event: "unpipe", listener: (src: stream.Readable) => void): this; + on(event: "streamClosed", listener: (code: number) => void): this; + on(event: "timeout", listener: () => void): this; + on(event: "trailers", listener: (trailers: IncomingHttpHeaders, flags: number) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "aborted", listener: () => void): this; + once(event: "close", listener: () => void): this; + once(event: "data", listener: (chunk: Buffer | string) => void): this; + once(event: "drain", listener: () => void): this; + once(event: "end", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "finish", listener: () => void): this; + once(event: "frameError", listener: (frameType: number, errorCode: number) => void): this; + once(event: "pipe", listener: (src: stream.Readable) => void): this; + once(event: "unpipe", listener: (src: stream.Readable) => void): this; + once(event: "streamClosed", listener: (code: number) => void): this; + once(event: "timeout", listener: () => void): this; + once(event: "trailers", listener: (trailers: IncomingHttpHeaders, flags: number) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "aborted", listener: () => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "data", listener: (chunk: Buffer | string) => void): this; + prependListener(event: "drain", listener: () => void): this; + prependListener(event: "end", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "finish", listener: () => void): this; + prependListener(event: "frameError", listener: (frameType: number, errorCode: number) => void): this; + prependListener(event: "pipe", listener: (src: stream.Readable) => void): this; + prependListener(event: "unpipe", listener: (src: stream.Readable) => void): this; + prependListener(event: "streamClosed", listener: (code: number) => void): this; + prependListener(event: "timeout", listener: () => void): this; + prependListener(event: "trailers", listener: (trailers: IncomingHttpHeaders, flags: number) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "aborted", listener: () => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "data", listener: (chunk: Buffer | string) => void): this; + prependOnceListener(event: "drain", listener: () => void): this; + prependOnceListener(event: "end", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "finish", listener: () => void): this; + prependOnceListener(event: "frameError", listener: (frameType: number, errorCode: number) => void): this; + prependOnceListener(event: "pipe", listener: (src: stream.Readable) => void): this; + prependOnceListener(event: "unpipe", listener: (src: stream.Readable) => void): this; + prependOnceListener(event: "streamClosed", listener: (code: number) => void): this; + prependOnceListener(event: "timeout", listener: () => void): this; + prependOnceListener(event: "trailers", listener: (trailers: IncomingHttpHeaders, flags: number) => void): this; + } + + export interface ClientHttp2Stream extends Http2Stream { + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "headers", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + addListener(event: "push", listener: (headers: IncomingHttpHeaders, flags: number) => void): this; + addListener(event: "response", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "headers", headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number): boolean; + emit(event: "push", headers: IncomingHttpHeaders, flags: number): boolean; + emit(event: "response", headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "headers", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + on(event: "push", listener: (headers: IncomingHttpHeaders, flags: number) => void): this; + on(event: "response", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "headers", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + once(event: "push", listener: (headers: IncomingHttpHeaders, flags: number) => void): this; + once(event: "response", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "headers", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + prependListener(event: "push", listener: (headers: IncomingHttpHeaders, flags: number) => void): this; + prependListener(event: "response", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "headers", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + prependOnceListener(event: "push", listener: (headers: IncomingHttpHeaders, flags: number) => void): this; + prependOnceListener(event: "response", listener: (headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + } + + export interface ServerHttp2Stream extends Http2Stream { + additionalHeaders(headers: OutgoingHttpHeaders): void; + readonly headersSent: boolean; + readonly pushAllowed: boolean; + pushStream(headers: OutgoingHttpHeaders, callback?: (err: Error | null, pushStream: ServerHttp2Stream, headers: OutgoingHttpHeaders) => void): void; + pushStream(headers: OutgoingHttpHeaders, options?: StreamPriorityOptions, callback?: (err: Error | null, pushStream: ServerHttp2Stream, headers: OutgoingHttpHeaders) => void): void; + respond(headers?: OutgoingHttpHeaders, options?: ServerStreamResponseOptions): void; + respondWithFD(fd: number, headers?: OutgoingHttpHeaders, options?: ServerStreamFileResponseOptions): void; + respondWithFile(path: string, headers?: OutgoingHttpHeaders, options?: ServerStreamFileResponseOptionsWithError): void; + } + + // Http2Session + + export interface Settings { + headerTableSize?: number; + enablePush?: boolean; + initialWindowSize?: number; + maxFrameSize?: number; + maxConcurrentStreams?: number; + maxHeaderListSize?: number; + } + + export interface ClientSessionRequestOptions { + endStream?: boolean; + exclusive?: boolean; + parent?: number; + weight?: number; + getTrailers?: (trailers: OutgoingHttpHeaders, flags: number) => void; + } + + export interface SessionState { + effectiveLocalWindowSize?: number; + effectiveRecvDataLength?: number; + nextStreamID?: number; + localWindowSize?: number; + lastProcStreamID?: number; + remoteWindowSize?: number; + outboundQueueSize?: number; + deflateDynamicTableSize?: number; + inflateDynamicTableSize?: number; + } + + export interface Http2Session extends events.EventEmitter { + readonly alpnProtocol?: string; + close(callback?: () => void): void; + readonly closed: boolean; + readonly connecting: boolean; + destroy(error?: Error, code?: number): void; + readonly destroyed: boolean; + readonly encrypted?: boolean; + goaway(code?: number, lastStreamID?: number, opaqueData?: Buffer | DataView | NodeJS.TypedArray): void; + readonly localSettings: Settings; + readonly originSet?: string[]; + readonly pendingSettingsAck: boolean; + ping(callback: (err: Error | null, duration: number, payload: Buffer) => void): boolean; + ping(payload: Buffer | DataView | NodeJS.TypedArray , callback: (err: Error | null, duration: number, payload: Buffer) => void): boolean; + ref(): void; + readonly remoteSettings: Settings; + rstStream(stream: Http2Stream, code?: number): void; + setTimeout(msecs: number, callback?: () => void): void; + readonly socket: net.Socket | tls.TLSSocket; + readonly state: SessionState; + priority(stream: Http2Stream, options: StreamPriorityOptions): void; + settings(settings: Settings): void; + readonly type: number; + unref(): void; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "error", listener: (err: Error) => void): this; + addListener(event: "frameError", listener: (frameType: number, errorCode: number, streamID: number) => void): this; + addListener(event: "goaway", listener: (errorCode: number, lastStreamID: number, opaqueData: Buffer) => void): this; + addListener(event: "localSettings", listener: (settings: Settings) => void): this; + addListener(event: "remoteSettings", listener: (settings: Settings) => void): this; + addListener(event: "timeout", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "close"): boolean; + emit(event: "error", err: Error): boolean; + emit(event: "frameError", frameType: number, errorCode: number, streamID: number): boolean; + emit(event: "goaway", errorCode: number, lastStreamID: number, opaqueData: Buffer): boolean; + emit(event: "localSettings", settings: Settings): boolean; + emit(event: "remoteSettings", settings: Settings): boolean; + emit(event: "timeout"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "close", listener: () => void): this; + on(event: "error", listener: (err: Error) => void): this; + on(event: "frameError", listener: (frameType: number, errorCode: number, streamID: number) => void): this; + on(event: "goaway", listener: (errorCode: number, lastStreamID: number, opaqueData: Buffer) => void): this; + on(event: "localSettings", listener: (settings: Settings) => void): this; + on(event: "remoteSettings", listener: (settings: Settings) => void): this; + on(event: "timeout", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "close", listener: () => void): this; + once(event: "error", listener: (err: Error) => void): this; + once(event: "frameError", listener: (frameType: number, errorCode: number, streamID: number) => void): this; + once(event: "goaway", listener: (errorCode: number, lastStreamID: number, opaqueData: Buffer) => void): this; + once(event: "localSettings", listener: (settings: Settings) => void): this; + once(event: "remoteSettings", listener: (settings: Settings) => void): this; + once(event: "timeout", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "error", listener: (err: Error) => void): this; + prependListener(event: "frameError", listener: (frameType: number, errorCode: number, streamID: number) => void): this; + prependListener(event: "goaway", listener: (errorCode: number, lastStreamID: number, opaqueData: Buffer) => void): this; + prependListener(event: "localSettings", listener: (settings: Settings) => void): this; + prependListener(event: "remoteSettings", listener: (settings: Settings) => void): this; + prependListener(event: "timeout", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "error", listener: (err: Error) => void): this; + prependOnceListener(event: "frameError", listener: (frameType: number, errorCode: number, streamID: number) => void): this; + prependOnceListener(event: "goaway", listener: (errorCode: number, lastStreamID: number, opaqueData: Buffer) => void): this; + prependOnceListener(event: "localSettings", listener: (settings: Settings) => void): this; + prependOnceListener(event: "remoteSettings", listener: (settings: Settings) => void): this; + prependOnceListener(event: "timeout", listener: () => void): this; + } + + export interface ClientHttp2Session extends Http2Session { + request(headers?: OutgoingHttpHeaders, options?: ClientSessionRequestOptions): ClientHttp2Stream; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "altsvc", listener: (alt: string, origin: string, stream: number) => void): this; + addListener(event: "connect", listener: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + addListener(event: "stream", listener: (stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "altsvc", alt: string, origin: string, stream: number): boolean; + emit(event: "connect", session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket): boolean; + emit(event: "stream", stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "altsvc", listener: (alt: string, origin: string, stream: number) => void): this; + on(event: "connect", listener: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + on(event: "stream", listener: (stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "altsvc", listener: (alt: string, origin: string, stream: number) => void): this; + once(event: "connect", listener: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + once(event: "stream", listener: (stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "altsvc", listener: (alt: string, origin: string, stream: number) => void): this; + prependListener(event: "connect", listener: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + prependListener(event: "stream", listener: (stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "altsvc", listener: (alt: string, origin: string, stream: number) => void): this; + prependOnceListener(event: "connect", listener: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + prependOnceListener(event: "stream", listener: (stream: ClientHttp2Stream, headers: IncomingHttpHeaders & IncomingHttpStatusHeader, flags: number) => void): this; + } + + export interface AlternativeServiceOptions { + origin: number | string | url.URL; + } + + export interface ServerHttp2Session extends Http2Session { + altsvc(alt: string, originOrStream: number | string | url.URL | AlternativeServiceOptions): void; + readonly server: Http2Server | Http2SecureServer; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "connect", listener: (session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + addListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "connect", session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket): boolean; + emit(event: "stream", stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "connect", listener: (session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + on(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "connect", listener: (session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + once(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "connect", listener: (session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + prependListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "connect", listener: (session: ServerHttp2Session, socket: net.Socket | tls.TLSSocket) => void): this; + prependOnceListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + } + + // Http2Server + + export interface SessionOptions { + maxDeflateDynamicTableSize?: number; + maxReservedRemoteStreams?: number; + maxSendHeaderBlockLength?: number; + paddingStrategy?: number; + peerMaxConcurrentStreams?: number; + selectPadding?: (frameLen: number, maxFrameLen: number) => number; + settings?: Settings; + } + + export type ClientSessionOptions = SessionOptions; + export type ServerSessionOptions = SessionOptions; + + export interface SecureClientSessionOptions extends ClientSessionOptions, tls.ConnectionOptions { } + export interface SecureServerSessionOptions extends ServerSessionOptions, tls.TlsOptions { } + + export interface ServerOptions extends ServerSessionOptions { + allowHTTP1?: boolean; + } + + export interface SecureServerOptions extends SecureServerSessionOptions { + allowHTTP1?: boolean; + } + + export interface Http2Server extends net.Server { + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + addListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + addListener(event: "sessionError", listener: (err: Error) => void): this; + addListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + addListener(event: "timeout", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "checkContinue", request: Http2ServerRequest, response: Http2ServerResponse): boolean; + emit(event: "request", request: Http2ServerRequest, response: Http2ServerResponse): boolean; + emit(event: "sessionError", err: Error): boolean; + emit(event: "stream", stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number): boolean; + emit(event: "timeout"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + on(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + on(event: "sessionError", listener: (err: Error) => void): this; + on(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + on(event: "timeout", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + once(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + once(event: "sessionError", listener: (err: Error) => void): this; + once(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + once(event: "timeout", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependListener(event: "sessionError", listener: (err: Error) => void): this; + prependListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + prependListener(event: "timeout", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependOnceListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependOnceListener(event: "sessionError", listener: (err: Error) => void): this; + prependOnceListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + prependOnceListener(event: "timeout", listener: () => void): this; + } + + export interface Http2SecureServer extends tls.Server { + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + addListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + addListener(event: "sessionError", listener: (err: Error) => void): this; + addListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + addListener(event: "timeout", listener: () => void): this; + addListener(event: "unknownProtocol", listener: (socket: tls.TLSSocket) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "checkContinue", request: Http2ServerRequest, response: Http2ServerResponse): boolean; + emit(event: "request", request: Http2ServerRequest, response: Http2ServerResponse): boolean; + emit(event: "sessionError", err: Error): boolean; + emit(event: "stream", stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number): boolean; + emit(event: "timeout"): boolean; + emit(event: "unknownProtocol", socket: tls.TLSSocket): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + on(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + on(event: "sessionError", listener: (err: Error) => void): this; + on(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + on(event: "timeout", listener: () => void): this; + on(event: "unknownProtocol", listener: (socket: tls.TLSSocket) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + once(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + once(event: "sessionError", listener: (err: Error) => void): this; + once(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + once(event: "timeout", listener: () => void): this; + once(event: "unknownProtocol", listener: (socket: tls.TLSSocket) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependListener(event: "sessionError", listener: (err: Error) => void): this; + prependListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + prependListener(event: "timeout", listener: () => void): this; + prependListener(event: "unknownProtocol", listener: (socket: tls.TLSSocket) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "checkContinue", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependOnceListener(event: "request", listener: (request: Http2ServerRequest, response: Http2ServerResponse) => void): this; + prependOnceListener(event: "sessionError", listener: (err: Error) => void): this; + prependOnceListener(event: "stream", listener: (stream: ServerHttp2Stream, headers: IncomingHttpHeaders, flags: number) => void): this; + prependOnceListener(event: "timeout", listener: () => void): this; + prependOnceListener(event: "unknownProtocol", listener: (socket: tls.TLSSocket) => void): this; + } + + export interface Http2ServerRequest extends stream.Readable { + headers: IncomingHttpHeaders; + httpVersion: string; + method: string; + rawHeaders: string[]; + rawTrailers: string[]; + setTimeout(msecs: number, callback?: () => void): void; + socket: net.Socket | tls.TLSSocket; + stream: ServerHttp2Stream; + trailers: IncomingHttpHeaders; + url: string; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "aborted", hadError: boolean, code: number): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + } + + export interface Http2ServerResponse extends events.EventEmitter { + addTrailers(trailers: OutgoingHttpHeaders): void; + connection: net.Socket | tls.TLSSocket; + end(callback?: () => void): void; + end(data?: string | Buffer, callback?: () => void): void; + end(data?: string | Buffer, encoding?: string, callback?: () => void): void; + readonly finished: boolean; + getHeader(name: string): string; + getHeaderNames(): string[]; + getHeaders(): OutgoingHttpHeaders; + hasHeader(name: string): boolean; + readonly headersSent: boolean; + removeHeader(name: string): void; + sendDate: boolean; + setHeader(name: string, value: number | string | string[]): void; + setTimeout(msecs: number, callback?: () => void): void; + socket: net.Socket | tls.TLSSocket; + statusCode: number; + statusMessage: ''; + stream: ServerHttp2Stream; + write(chunk: string | Buffer, callback?: (err: Error) => void): boolean; + write(chunk: string | Buffer, encoding?: string, callback?: (err: Error) => void): boolean; + writeContinue(): void; + writeHead(statusCode: number, headers?: OutgoingHttpHeaders): void; + writeHead(statusCode: number, statusMessage?: string, headers?: OutgoingHttpHeaders): void; + createPushResponse(headers: OutgoingHttpHeaders, callback: (err: Error | null, res: Http2ServerResponse) => void): void; + + addListener(event: string, listener: (...args: any[]) => void): this; + addListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + addListener(event: "close", listener: () => void): this; + addListener(event: "drain", listener: () => void): this; + addListener(event: "error", listener: (error: Error) => void): this; + addListener(event: "finish", listener: () => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "aborted", hadError: boolean, code: number): boolean; + emit(event: "close"): boolean; + emit(event: "drain"): boolean; + emit(event: "error", error: Error): boolean; + emit(event: "finish"): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + on(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + on(event: "close", listener: () => void): this; + on(event: "drain", listener: () => void): this; + on(event: "error", listener: (error: Error) => void): this; + on(event: "finish", listener: () => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + once(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + once(event: "close", listener: () => void): this; + once(event: "drain", listener: () => void): this; + once(event: "error", listener: (error: Error) => void): this; + once(event: "finish", listener: () => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + prependListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + prependListener(event: "close", listener: () => void): this; + prependListener(event: "drain", listener: () => void): this; + prependListener(event: "error", listener: (error: Error) => void): this; + prependListener(event: "finish", listener: () => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + prependOnceListener(event: "aborted", listener: (hadError: boolean, code: number) => void): this; + prependOnceListener(event: "close", listener: () => void): this; + prependOnceListener(event: "drain", listener: () => void): this; + prependOnceListener(event: "error", listener: (error: Error) => void): this; + prependOnceListener(event: "finish", listener: () => void): this; + } + + // Public API + + export namespace constants { + export const NGHTTP2_SESSION_SERVER: number; + export const NGHTTP2_SESSION_CLIENT: number; + export const NGHTTP2_STREAM_STATE_IDLE: number; + export const NGHTTP2_STREAM_STATE_OPEN: number; + export const NGHTTP2_STREAM_STATE_RESERVED_LOCAL: number; + export const NGHTTP2_STREAM_STATE_RESERVED_REMOTE: number; + export const NGHTTP2_STREAM_STATE_HALF_CLOSED_LOCAL: number; + export const NGHTTP2_STREAM_STATE_HALF_CLOSED_REMOTE: number; + export const NGHTTP2_STREAM_STATE_CLOSED: number; + export const NGHTTP2_NO_ERROR: number; + export const NGHTTP2_PROTOCOL_ERROR: number; + export const NGHTTP2_INTERNAL_ERROR: number; + export const NGHTTP2_FLOW_CONTROL_ERROR: number; + export const NGHTTP2_SETTINGS_TIMEOUT: number; + export const NGHTTP2_STREAM_CLOSED: number; + export const NGHTTP2_FRAME_SIZE_ERROR: number; + export const NGHTTP2_REFUSED_STREAM: number; + export const NGHTTP2_CANCEL: number; + export const NGHTTP2_COMPRESSION_ERROR: number; + export const NGHTTP2_CONNECT_ERROR: number; + export const NGHTTP2_ENHANCE_YOUR_CALM: number; + export const NGHTTP2_INADEQUATE_SECURITY: number; + export const NGHTTP2_HTTP_1_1_REQUIRED: number; + export const NGHTTP2_ERR_FRAME_SIZE_ERROR: number; + export const NGHTTP2_FLAG_NONE: number; + export const NGHTTP2_FLAG_END_STREAM: number; + export const NGHTTP2_FLAG_END_HEADERS: number; + export const NGHTTP2_FLAG_ACK: number; + export const NGHTTP2_FLAG_PADDED: number; + export const NGHTTP2_FLAG_PRIORITY: number; + export const DEFAULT_SETTINGS_HEADER_TABLE_SIZE: number; + export const DEFAULT_SETTINGS_ENABLE_PUSH: number; + export const DEFAULT_SETTINGS_INITIAL_WINDOW_SIZE: number; + export const DEFAULT_SETTINGS_MAX_FRAME_SIZE: number; + export const MAX_MAX_FRAME_SIZE: number; + export const MIN_MAX_FRAME_SIZE: number; + export const MAX_INITIAL_WINDOW_SIZE: number; + export const NGHTTP2_DEFAULT_WEIGHT: number; + export const NGHTTP2_SETTINGS_HEADER_TABLE_SIZE: number; + export const NGHTTP2_SETTINGS_ENABLE_PUSH: number; + export const NGHTTP2_SETTINGS_MAX_CONCURRENT_STREAMS: number; + export const NGHTTP2_SETTINGS_INITIAL_WINDOW_SIZE: number; + export const NGHTTP2_SETTINGS_MAX_FRAME_SIZE: number; + export const NGHTTP2_SETTINGS_MAX_HEADER_LIST_SIZE: number; + export const PADDING_STRATEGY_NONE: number; + export const PADDING_STRATEGY_MAX: number; + export const PADDING_STRATEGY_CALLBACK: number; + export const HTTP2_HEADER_STATUS: string; + export const HTTP2_HEADER_METHOD: string; + export const HTTP2_HEADER_AUTHORITY: string; + export const HTTP2_HEADER_SCHEME: string; + export const HTTP2_HEADER_PATH: string; + export const HTTP2_HEADER_ACCEPT_CHARSET: string; + export const HTTP2_HEADER_ACCEPT_ENCODING: string; + export const HTTP2_HEADER_ACCEPT_LANGUAGE: string; + export const HTTP2_HEADER_ACCEPT_RANGES: string; + export const HTTP2_HEADER_ACCEPT: string; + export const HTTP2_HEADER_ACCESS_CONTROL_ALLOW_ORIGIN: string; + export const HTTP2_HEADER_AGE: string; + export const HTTP2_HEADER_ALLOW: string; + export const HTTP2_HEADER_AUTHORIZATION: string; + export const HTTP2_HEADER_CACHE_CONTROL: string; + export const HTTP2_HEADER_CONNECTION: string; + export const HTTP2_HEADER_CONTENT_DISPOSITION: string; + export const HTTP2_HEADER_CONTENT_ENCODING: string; + export const HTTP2_HEADER_CONTENT_LANGUAGE: string; + export const HTTP2_HEADER_CONTENT_LENGTH: string; + export const HTTP2_HEADER_CONTENT_LOCATION: string; + export const HTTP2_HEADER_CONTENT_MD5: string; + export const HTTP2_HEADER_CONTENT_RANGE: string; + export const HTTP2_HEADER_CONTENT_TYPE: string; + export const HTTP2_HEADER_COOKIE: string; + export const HTTP2_HEADER_DATE: string; + export const HTTP2_HEADER_ETAG: string; + export const HTTP2_HEADER_EXPECT: string; + export const HTTP2_HEADER_EXPIRES: string; + export const HTTP2_HEADER_FROM: string; + export const HTTP2_HEADER_HOST: string; + export const HTTP2_HEADER_IF_MATCH: string; + export const HTTP2_HEADER_IF_MODIFIED_SINCE: string; + export const HTTP2_HEADER_IF_NONE_MATCH: string; + export const HTTP2_HEADER_IF_RANGE: string; + export const HTTP2_HEADER_IF_UNMODIFIED_SINCE: string; + export const HTTP2_HEADER_LAST_MODIFIED: string; + export const HTTP2_HEADER_LINK: string; + export const HTTP2_HEADER_LOCATION: string; + export const HTTP2_HEADER_MAX_FORWARDS: string; + export const HTTP2_HEADER_PREFER: string; + export const HTTP2_HEADER_PROXY_AUTHENTICATE: string; + export const HTTP2_HEADER_PROXY_AUTHORIZATION: string; + export const HTTP2_HEADER_RANGE: string; + export const HTTP2_HEADER_REFERER: string; + export const HTTP2_HEADER_REFRESH: string; + export const HTTP2_HEADER_RETRY_AFTER: string; + export const HTTP2_HEADER_SERVER: string; + export const HTTP2_HEADER_SET_COOKIE: string; + export const HTTP2_HEADER_STRICT_TRANSPORT_SECURITY: string; + export const HTTP2_HEADER_TRANSFER_ENCODING: string; + export const HTTP2_HEADER_TE: string; + export const HTTP2_HEADER_UPGRADE: string; + export const HTTP2_HEADER_USER_AGENT: string; + export const HTTP2_HEADER_VARY: string; + export const HTTP2_HEADER_VIA: string; + export const HTTP2_HEADER_WWW_AUTHENTICATE: string; + export const HTTP2_HEADER_HTTP2_SETTINGS: string; + export const HTTP2_HEADER_KEEP_ALIVE: string; + export const HTTP2_HEADER_PROXY_CONNECTION: string; + export const HTTP2_METHOD_ACL: string; + export const HTTP2_METHOD_BASELINE_CONTROL: string; + export const HTTP2_METHOD_BIND: string; + export const HTTP2_METHOD_CHECKIN: string; + export const HTTP2_METHOD_CHECKOUT: string; + export const HTTP2_METHOD_CONNECT: string; + export const HTTP2_METHOD_COPY: string; + export const HTTP2_METHOD_DELETE: string; + export const HTTP2_METHOD_GET: string; + export const HTTP2_METHOD_HEAD: string; + export const HTTP2_METHOD_LABEL: string; + export const HTTP2_METHOD_LINK: string; + export const HTTP2_METHOD_LOCK: string; + export const HTTP2_METHOD_MERGE: string; + export const HTTP2_METHOD_MKACTIVITY: string; + export const HTTP2_METHOD_MKCALENDAR: string; + export const HTTP2_METHOD_MKCOL: string; + export const HTTP2_METHOD_MKREDIRECTREF: string; + export const HTTP2_METHOD_MKWORKSPACE: string; + export const HTTP2_METHOD_MOVE: string; + export const HTTP2_METHOD_OPTIONS: string; + export const HTTP2_METHOD_ORDERPATCH: string; + export const HTTP2_METHOD_PATCH: string; + export const HTTP2_METHOD_POST: string; + export const HTTP2_METHOD_PRI: string; + export const HTTP2_METHOD_PROPFIND: string; + export const HTTP2_METHOD_PROPPATCH: string; + export const HTTP2_METHOD_PUT: string; + export const HTTP2_METHOD_REBIND: string; + export const HTTP2_METHOD_REPORT: string; + export const HTTP2_METHOD_SEARCH: string; + export const HTTP2_METHOD_TRACE: string; + export const HTTP2_METHOD_UNBIND: string; + export const HTTP2_METHOD_UNCHECKOUT: string; + export const HTTP2_METHOD_UNLINK: string; + export const HTTP2_METHOD_UNLOCK: string; + export const HTTP2_METHOD_UPDATE: string; + export const HTTP2_METHOD_UPDATEREDIRECTREF: string; + export const HTTP2_METHOD_VERSION_CONTROL: string; + export const HTTP_STATUS_CONTINUE: number; + export const HTTP_STATUS_SWITCHING_PROTOCOLS: number; + export const HTTP_STATUS_PROCESSING: number; + export const HTTP_STATUS_OK: number; + export const HTTP_STATUS_CREATED: number; + export const HTTP_STATUS_ACCEPTED: number; + export const HTTP_STATUS_NON_AUTHORITATIVE_INFORMATION: number; + export const HTTP_STATUS_NO_CONTENT: number; + export const HTTP_STATUS_RESET_CONTENT: number; + export const HTTP_STATUS_PARTIAL_CONTENT: number; + export const HTTP_STATUS_MULTI_STATUS: number; + export const HTTP_STATUS_ALREADY_REPORTED: number; + export const HTTP_STATUS_IM_USED: number; + export const HTTP_STATUS_MULTIPLE_CHOICES: number; + export const HTTP_STATUS_MOVED_PERMANENTLY: number; + export const HTTP_STATUS_FOUND: number; + export const HTTP_STATUS_SEE_OTHER: number; + export const HTTP_STATUS_NOT_MODIFIED: number; + export const HTTP_STATUS_USE_PROXY: number; + export const HTTP_STATUS_TEMPORARY_REDIRECT: number; + export const HTTP_STATUS_PERMANENT_REDIRECT: number; + export const HTTP_STATUS_BAD_REQUEST: number; + export const HTTP_STATUS_UNAUTHORIZED: number; + export const HTTP_STATUS_PAYMENT_REQUIRED: number; + export const HTTP_STATUS_FORBIDDEN: number; + export const HTTP_STATUS_NOT_FOUND: number; + export const HTTP_STATUS_METHOD_NOT_ALLOWED: number; + export const HTTP_STATUS_NOT_ACCEPTABLE: number; + export const HTTP_STATUS_PROXY_AUTHENTICATION_REQUIRED: number; + export const HTTP_STATUS_REQUEST_TIMEOUT: number; + export const HTTP_STATUS_CONFLICT: number; + export const HTTP_STATUS_GONE: number; + export const HTTP_STATUS_LENGTH_REQUIRED: number; + export const HTTP_STATUS_PRECONDITION_FAILED: number; + export const HTTP_STATUS_PAYLOAD_TOO_LARGE: number; + export const HTTP_STATUS_URI_TOO_LONG: number; + export const HTTP_STATUS_UNSUPPORTED_MEDIA_TYPE: number; + export const HTTP_STATUS_RANGE_NOT_SATISFIABLE: number; + export const HTTP_STATUS_EXPECTATION_FAILED: number; + export const HTTP_STATUS_TEAPOT: number; + export const HTTP_STATUS_MISDIRECTED_REQUEST: number; + export const HTTP_STATUS_UNPROCESSABLE_ENTITY: number; + export const HTTP_STATUS_LOCKED: number; + export const HTTP_STATUS_FAILED_DEPENDENCY: number; + export const HTTP_STATUS_UNORDERED_COLLECTION: number; + export const HTTP_STATUS_UPGRADE_REQUIRED: number; + export const HTTP_STATUS_PRECONDITION_REQUIRED: number; + export const HTTP_STATUS_TOO_MANY_REQUESTS: number; + export const HTTP_STATUS_REQUEST_HEADER_FIELDS_TOO_LARGE: number; + export const HTTP_STATUS_UNAVAILABLE_FOR_LEGAL_REASONS: number; + export const HTTP_STATUS_INTERNAL_SERVER_ERROR: number; + export const HTTP_STATUS_NOT_IMPLEMENTED: number; + export const HTTP_STATUS_BAD_GATEWAY: number; + export const HTTP_STATUS_SERVICE_UNAVAILABLE: number; + export const HTTP_STATUS_GATEWAY_TIMEOUT: number; + export const HTTP_STATUS_HTTP_VERSION_NOT_SUPPORTED: number; + export const HTTP_STATUS_VARIANT_ALSO_NEGOTIATES: number; + export const HTTP_STATUS_INSUFFICIENT_STORAGE: number; + export const HTTP_STATUS_LOOP_DETECTED: number; + export const HTTP_STATUS_BANDWIDTH_LIMIT_EXCEEDED: number; + export const HTTP_STATUS_NOT_EXTENDED: number; + export const HTTP_STATUS_NETWORK_AUTHENTICATION_REQUIRED: number; + } + + export function getDefaultSettings(): Settings; + export function getPackedSettings(settings: Settings): Settings; + export function getUnpackedSettings(buf: Buffer | Uint8Array): Settings; + + export function createServer(onRequestHandler?: (request: Http2ServerRequest, response: Http2ServerResponse) => void): Http2Server; + export function createServer(options: ServerOptions, onRequestHandler?: (request: Http2ServerRequest, response: Http2ServerResponse) => void): Http2Server; + + export function createSecureServer(onRequestHandler?: (request: Http2ServerRequest, response: Http2ServerResponse) => void): Http2SecureServer; + export function createSecureServer(options: SecureServerOptions, onRequestHandler?: (request: Http2ServerRequest, response: Http2ServerResponse) => void): Http2SecureServer; + + export function connect(authority: string | url.URL, listener?: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): ClientHttp2Session; + export function connect(authority: string | url.URL, options?: ClientSessionOptions | SecureClientSessionOptions, listener?: (session: ClientHttp2Session, socket: net.Socket | tls.TLSSocket) => void): ClientHttp2Session; +} + +declare module "perf_hooks" { + import { AsyncResource } from "async_hooks"; + + export interface PerformanceEntry { + /** + * The total number of milliseconds elapsed for this entry. + * This value will not be meaningful for all Performance Entry types. + */ + readonly duration: number; + + /** + * The name of the performance entry. + */ + readonly name: string; + + /** + * The high resolution millisecond timestamp marking the starting time of the Performance Entry. + */ + readonly startTime: number; + + /** + * The type of the performance entry. + * Currently it may be one of: 'node', 'mark', 'measure', 'gc', or 'function'. + */ + readonly entryType: string; + + /** + * When performanceEntry.entryType is equal to 'gc', the performance.kind property identifies + * the type of garbage collection operation that occurred. + * The value may be one of perf_hooks.constants. + */ + readonly kind?: number; + } + + export interface PerformanceNodeTiming extends PerformanceEntry { + /** + * The high resolution millisecond timestamp at which the Node.js process completed bootstrap. + */ + readonly bootstrapComplete: number; + + /** + * The high resolution millisecond timestamp at which cluster processing ended. + */ + readonly clusterSetupEnd: number; + + /** + * The high resolution millisecond timestamp at which cluster processing started. + */ + readonly clusterSetupStart: number; + + /** + * The high resolution millisecond timestamp at which the Node.js event loop exited. + */ + readonly loopExit: number; + + /** + * The high resolution millisecond timestamp at which the Node.js event loop started. + */ + readonly loopStart: number; + + /** + * The high resolution millisecond timestamp at which main module load ended. + */ + readonly moduleLoadEnd: number; + + /** + * The high resolution millisecond timestamp at which main module load started. + */ + readonly moduleLoadStart: number; + + /** + * The high resolution millisecond timestamp at which the Node.js process was initialized. + */ + readonly nodeStart: number; + + /** + * The high resolution millisecond timestamp at which preload module load ended. + */ + readonly preloadModuleLoadEnd: number; + + /** + * The high resolution millisecond timestamp at which preload module load started. + */ + readonly preloadModuleLoadStart: number; + + /** + * The high resolution millisecond timestamp at which third_party_main processing ended. + */ + readonly thirdPartyMainEnd: number; + + /** + * The high resolution millisecond timestamp at which third_party_main processing started. + */ + readonly thirdPartyMainStart: number; + + /** + * The high resolution millisecond timestamp at which the V8 platform was initialized. + */ + readonly v8Start: number; + } + + export interface Performance { + /** + * If name is not provided, removes all PerformanceFunction objects from the Performance Timeline. + * If name is provided, removes entries with name. + * @param name + */ + clearFunctions(name?: string): void; + + /** + * If name is not provided, removes all PerformanceMark objects from the Performance Timeline. + * If name is provided, removes only the named mark. + * @param name + */ + clearMarks(name?: string): void; + + /** + * If name is not provided, removes all PerformanceMeasure objects from the Performance Timeline. + * If name is provided, removes only objects whose performanceEntry.name matches name. + */ + clearMeasures(name?: string): void; + + /** + * Returns a list of all PerformanceEntry objects in chronological order with respect to performanceEntry.startTime. + * @return list of all PerformanceEntry objects + */ + getEntries(): PerformanceEntry[]; + + /** + * Returns a list of all PerformanceEntry objects in chronological order with respect to performanceEntry.startTime + * whose performanceEntry.name is equal to name, and optionally, whose performanceEntry.entryType is equal to type. + * @param name + * @param type + * @return list of all PerformanceEntry objects + */ + getEntriesByName(name: string, type?: string): PerformanceEntry[]; + + /** + * Returns a list of all PerformanceEntry objects in chronological order with respect to performanceEntry.startTime + * whose performanceEntry.entryType is equal to type. + * @param type + * @return list of all PerformanceEntry objects + */ + getEntriesByType(type: string): PerformanceEntry[]; + + /** + * Creates a new PerformanceMark entry in the Performance Timeline. + * A PerformanceMark is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'mark', + * and whose performanceEntry.duration is always 0. + * Performance marks are used to mark specific significant moments in the Performance Timeline. + * @param name + */ + mark(name?: string): void; + + /** + * Creates a new PerformanceMeasure entry in the Performance Timeline. + * A PerformanceMeasure is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'measure', + * and whose performanceEntry.duration measures the number of milliseconds elapsed since startMark and endMark. + * + * The startMark argument may identify any existing PerformanceMark in the the Performance Timeline, or may identify + * any of the timestamp properties provided by the PerformanceNodeTiming class. If the named startMark does not exist, + * then startMark is set to timeOrigin by default. + * + * The endMark argument must identify any existing PerformanceMark in the the Performance Timeline or any of the timestamp + * properties provided by the PerformanceNodeTiming class. If the named endMark does not exist, an error will be thrown. + * @param name + * @param startMark + * @param endMark + */ + measure(name: string, startMark: string, endMark: string): void; + + /** + * An instance of the PerformanceNodeTiming class that provides performance metrics for specific Node.js operational milestones. + */ + readonly nodeTiming: PerformanceNodeTiming; + + /** + * @return the current high resolution millisecond timestamp + */ + now(): number; + + /** + * The timeOrigin specifies the high resolution millisecond timestamp from which all performance metric durations are measured. + */ + readonly timeOrigin: number; + + /** + * Wraps a function within a new function that measures the running time of the wrapped function. + * A PerformanceObserver must be subscribed to the 'function' event type in order for the timing details to be accessed. + * @param fn + */ + timerify any>(fn: T): T; + } + + export interface PerformanceObserverEntryList { + /** + * @return a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime. + */ + getEntries(): PerformanceEntry[]; + + /** + * @return a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime + * whose performanceEntry.name is equal to name, and optionally, whose performanceEntry.entryType is equal to type. + */ + getEntriesByName(name: string, type?: string): PerformanceEntry[]; + + /** + * @return Returns a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime + * whose performanceEntry.entryType is equal to type. + */ + getEntriesByType(type: string): PerformanceEntry[]; + } + + export type PerformanceObserverCallback = (list: PerformanceObserverEntryList, observer: PerformanceObserver) => void; + + export class PerformanceObserver extends AsyncResource { + constructor(callback: PerformanceObserverCallback); + + /** + * Disconnects the PerformanceObserver instance from all notifications. + */ + disconnect(): void; + + /** + * Subscribes the PerformanceObserver instance to notifications of new PerformanceEntry instances identified by options.entryTypes. + * When options.buffered is false, the callback will be invoked once for every PerformanceEntry instance. + * Property buffered defaults to false. + * @param options + */ + observe(options: { entryTypes: string[], buffered?: boolean }): void; + } + + export namespace constants { + export const NODE_PERFORMANCE_GC_MAJOR: number; + export const NODE_PERFORMANCE_GC_MINOR: number; + export const NODE_PERFORMANCE_GC_INCREMENTAL: number; + export const NODE_PERFORMANCE_GC_WEAKCB: number; + } + + const performance: Performance; +} diff --git a/node_modules/protobufjs/node_modules/@types/node/inspector.d.ts b/node_modules/protobufjs/node_modules/@types/node/inspector.d.ts new file mode 100644 index 0000000..955239b --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/node/inspector.d.ts @@ -0,0 +1,2488 @@ +// Type definitions for inspector + +// These definitions are auto-generated. +// Please see https://github.com/DefinitelyTyped/DefinitelyTyped/pull/19330 +// for more information. + +/** + * The inspector module provides an API for interacting with the V8 inspector. + */ +declare module "inspector" { + import { EventEmitter } from 'events'; + + export interface InspectorNotification { + method: string; + params: T; + } + + export namespace Schema { + /** + * Description of the protocol domain. + */ + export interface Domain { + /** + * Domain name. + */ + name: string; + /** + * Domain version. + */ + version: string; + } + + export interface GetDomainsReturnType { + /** + * List of supported domains. + */ + domains: Schema.Domain[]; + } + } + + export namespace Runtime { + /** + * Unique script identifier. + */ + export type ScriptId = string; + + /** + * Unique object identifier. + */ + export type RemoteObjectId = string; + + /** + * Primitive value which cannot be JSON-stringified. + */ + export type UnserializableValue = string; + + /** + * Mirror object referencing original JavaScript object. + */ + export interface RemoteObject { + /** + * Object type. + */ + type: string; + /** + * Object subtype hint. Specified for object type values only. + */ + subtype?: string; + /** + * Object class (constructor) name. Specified for object type values only. + */ + className?: string; + /** + * Remote object value in case of primitive values or JSON values (if it was requested). + */ + value?: any; + /** + * Primitive value which can not be JSON-stringified does not have value, but gets this property. + */ + unserializableValue?: Runtime.UnserializableValue; + /** + * String representation of the object. + */ + description?: string; + /** + * Unique object identifier (for non-primitive values). + */ + objectId?: Runtime.RemoteObjectId; + /** + * Preview containing abbreviated property values. Specified for object type values only. + * @experimental + */ + preview?: Runtime.ObjectPreview; + /** + * @experimental + */ + customPreview?: Runtime.CustomPreview; + } + + /** + * @experimental + */ + export interface CustomPreview { + header: string; + hasBody: boolean; + formatterObjectId: Runtime.RemoteObjectId; + bindRemoteObjectFunctionId: Runtime.RemoteObjectId; + configObjectId?: Runtime.RemoteObjectId; + } + + /** + * Object containing abbreviated remote object value. + * @experimental + */ + export interface ObjectPreview { + /** + * Object type. + */ + type: string; + /** + * Object subtype hint. Specified for object type values only. + */ + subtype?: string; + /** + * String representation of the object. + */ + description?: string; + /** + * True iff some of the properties or entries of the original object did not fit. + */ + overflow: boolean; + /** + * List of the properties. + */ + properties: Runtime.PropertyPreview[]; + /** + * List of the entries. Specified for map and set subtype values only. + */ + entries?: Runtime.EntryPreview[]; + } + + /** + * @experimental + */ + export interface PropertyPreview { + /** + * Property name. + */ + name: string; + /** + * Object type. Accessor means that the property itself is an accessor property. + */ + type: string; + /** + * User-friendly property value string. + */ + value?: string; + /** + * Nested value preview. + */ + valuePreview?: Runtime.ObjectPreview; + /** + * Object subtype hint. Specified for object type values only. + */ + subtype?: string; + } + + /** + * @experimental + */ + export interface EntryPreview { + /** + * Preview of the key. Specified for map-like collection entries. + */ + key?: Runtime.ObjectPreview; + /** + * Preview of the value. + */ + value: Runtime.ObjectPreview; + } + + /** + * Object property descriptor. + */ + export interface PropertyDescriptor { + /** + * Property name or symbol description. + */ + name: string; + /** + * The value associated with the property. + */ + value?: Runtime.RemoteObject; + /** + * True if the value associated with the property may be changed (data descriptors only). + */ + writable?: boolean; + /** + * A function which serves as a getter for the property, or undefined if there is no getter (accessor descriptors only). + */ + get?: Runtime.RemoteObject; + /** + * A function which serves as a setter for the property, or undefined if there is no setter (accessor descriptors only). + */ + set?: Runtime.RemoteObject; + /** + * True if the type of this property descriptor may be changed and if the property may be deleted from the corresponding object. + */ + configurable: boolean; + /** + * True if this property shows up during enumeration of the properties on the corresponding object. + */ + enumerable: boolean; + /** + * True if the result was thrown during the evaluation. + */ + wasThrown?: boolean; + /** + * True if the property is owned for the object. + */ + isOwn?: boolean; + /** + * Property symbol object, if the property is of the symbol type. + */ + symbol?: Runtime.RemoteObject; + } + + /** + * Object internal property descriptor. This property isn't normally visible in JavaScript code. + */ + export interface InternalPropertyDescriptor { + /** + * Conventional property name. + */ + name: string; + /** + * The value associated with the property. + */ + value?: Runtime.RemoteObject; + } + + /** + * Represents function call argument. Either remote object id objectId, primitive value, unserializable primitive value or neither of (for undefined) them should be specified. + */ + export interface CallArgument { + /** + * Primitive value. + */ + value?: any; + /** + * Primitive value which can not be JSON-stringified. + */ + unserializableValue?: Runtime.UnserializableValue; + /** + * Remote object handle. + */ + objectId?: Runtime.RemoteObjectId; + } + + /** + * Id of an execution context. + */ + export type ExecutionContextId = number; + + /** + * Description of an isolated world. + */ + export interface ExecutionContextDescription { + /** + * Unique id of the execution context. It can be used to specify in which execution context script evaluation should be performed. + */ + id: Runtime.ExecutionContextId; + /** + * Execution context origin. + */ + origin: string; + /** + * Human readable name describing given context. + */ + name: string; + /** + * Embedder-specific auxiliary data. + */ + auxData?: {}; + } + + /** + * Detailed information about exception (or error) that was thrown during script compilation or execution. + */ + export interface ExceptionDetails { + /** + * Exception id. + */ + exceptionId: number; + /** + * Exception text, which should be used together with exception object when available. + */ + text: string; + /** + * Line number of the exception location (0-based). + */ + lineNumber: number; + /** + * Column number of the exception location (0-based). + */ + columnNumber: number; + /** + * Script ID of the exception location. + */ + scriptId?: Runtime.ScriptId; + /** + * URL of the exception location, to be used when the script was not reported. + */ + url?: string; + /** + * JavaScript stack trace if available. + */ + stackTrace?: Runtime.StackTrace; + /** + * Exception object if available. + */ + exception?: Runtime.RemoteObject; + /** + * Identifier of the context where exception happened. + */ + executionContextId?: Runtime.ExecutionContextId; + } + + /** + * Number of milliseconds since epoch. + */ + export type Timestamp = number; + + /** + * Stack entry for runtime errors and assertions. + */ + export interface CallFrame { + /** + * JavaScript function name. + */ + functionName: string; + /** + * JavaScript script id. + */ + scriptId: Runtime.ScriptId; + /** + * JavaScript script name or url. + */ + url: string; + /** + * JavaScript script line number (0-based). + */ + lineNumber: number; + /** + * JavaScript script column number (0-based). + */ + columnNumber: number; + } + + /** + * Call frames for assertions or error messages. + */ + export interface StackTrace { + /** + * String label of this stack trace. For async traces this may be a name of the function that initiated the async call. + */ + description?: string; + /** + * JavaScript function name. + */ + callFrames: Runtime.CallFrame[]; + /** + * Asynchronous JavaScript stack trace that preceded this stack, if available. + */ + parent?: Runtime.StackTrace; + /** + * Creation frame of the Promise which produced the next synchronous trace when resolved, if available. + * @experimental + */ + promiseCreationFrame?: Runtime.CallFrame; + } + + export interface EvaluateParameterType { + /** + * Expression to evaluate. + */ + expression: string; + /** + * Symbolic group name that can be used to release multiple objects. + */ + objectGroup?: string; + /** + * Determines whether Command Line API should be available during the evaluation. + */ + includeCommandLineAPI?: boolean; + /** + * In silent mode exceptions thrown during evaluation are not reported and do not pause execution. Overrides setPauseOnException state. + */ + silent?: boolean; + /** + * Specifies in which execution context to perform evaluation. If the parameter is omitted the evaluation will be performed in the context of the inspected page. + */ + contextId?: Runtime.ExecutionContextId; + /** + * Whether the result is expected to be a JSON object that should be sent by value. + */ + returnByValue?: boolean; + /** + * Whether preview should be generated for the result. + * @experimental + */ + generatePreview?: boolean; + /** + * Whether execution should be treated as initiated by user in the UI. + * @experimental + */ + userGesture?: boolean; + /** + * Whether execution should wait for promise to be resolved. If the result of evaluation is not a Promise, it's considered to be an error. + */ + awaitPromise?: boolean; + } + + export interface AwaitPromiseParameterType { + /** + * Identifier of the promise. + */ + promiseObjectId: Runtime.RemoteObjectId; + /** + * Whether the result is expected to be a JSON object that should be sent by value. + */ + returnByValue?: boolean; + /** + * Whether preview should be generated for the result. + */ + generatePreview?: boolean; + } + + export interface CallFunctionOnParameterType { + /** + * Identifier of the object to call function on. + */ + objectId: Runtime.RemoteObjectId; + /** + * Declaration of the function to call. + */ + functionDeclaration: string; + /** + * Call arguments. All call arguments must belong to the same JavaScript world as the target object. + */ + arguments?: Runtime.CallArgument[]; + /** + * In silent mode exceptions thrown during evaluation are not reported and do not pause execution. Overrides setPauseOnException state. + */ + silent?: boolean; + /** + * Whether the result is expected to be a JSON object which should be sent by value. + */ + returnByValue?: boolean; + /** + * Whether preview should be generated for the result. + * @experimental + */ + generatePreview?: boolean; + /** + * Whether execution should be treated as initiated by user in the UI. + * @experimental + */ + userGesture?: boolean; + /** + * Whether execution should wait for promise to be resolved. If the result of evaluation is not a Promise, it's considered to be an error. + */ + awaitPromise?: boolean; + } + + export interface GetPropertiesParameterType { + /** + * Identifier of the object to return properties for. + */ + objectId: Runtime.RemoteObjectId; + /** + * If true, returns properties belonging only to the element itself, not to its prototype chain. + */ + ownProperties?: boolean; + /** + * If true, returns accessor properties (with getter/setter) only; internal properties are not returned either. + * @experimental + */ + accessorPropertiesOnly?: boolean; + /** + * Whether preview should be generated for the results. + * @experimental + */ + generatePreview?: boolean; + } + + export interface ReleaseObjectParameterType { + /** + * Identifier of the object to release. + */ + objectId: Runtime.RemoteObjectId; + } + + export interface ReleaseObjectGroupParameterType { + /** + * Symbolic object group name. + */ + objectGroup: string; + } + + export interface SetCustomObjectFormatterEnabledParameterType { + enabled: boolean; + } + + export interface CompileScriptParameterType { + /** + * Expression to compile. + */ + expression: string; + /** + * Source url to be set for the script. + */ + sourceURL: string; + /** + * Specifies whether the compiled script should be persisted. + */ + persistScript: boolean; + /** + * Specifies in which execution context to perform script run. If the parameter is omitted the evaluation will be performed in the context of the inspected page. + */ + executionContextId?: Runtime.ExecutionContextId; + } + + export interface RunScriptParameterType { + /** + * Id of the script to run. + */ + scriptId: Runtime.ScriptId; + /** + * Specifies in which execution context to perform script run. If the parameter is omitted the evaluation will be performed in the context of the inspected page. + */ + executionContextId?: Runtime.ExecutionContextId; + /** + * Symbolic group name that can be used to release multiple objects. + */ + objectGroup?: string; + /** + * In silent mode exceptions thrown during evaluation are not reported and do not pause execution. Overrides setPauseOnException state. + */ + silent?: boolean; + /** + * Determines whether Command Line API should be available during the evaluation. + */ + includeCommandLineAPI?: boolean; + /** + * Whether the result is expected to be a JSON object which should be sent by value. + */ + returnByValue?: boolean; + /** + * Whether preview should be generated for the result. + */ + generatePreview?: boolean; + /** + * Whether execution should wait for promise to be resolved. If the result of evaluation is not a Promise, it's considered to be an error. + */ + awaitPromise?: boolean; + } + + export interface EvaluateReturnType { + /** + * Evaluation result. + */ + result: Runtime.RemoteObject; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface AwaitPromiseReturnType { + /** + * Promise result. Will contain rejected value if promise was rejected. + */ + result: Runtime.RemoteObject; + /** + * Exception details if stack strace is available. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface CallFunctionOnReturnType { + /** + * Call result. + */ + result: Runtime.RemoteObject; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface GetPropertiesReturnType { + /** + * Object properties. + */ + result: Runtime.PropertyDescriptor[]; + /** + * Internal object properties (only of the element itself). + */ + internalProperties?: Runtime.InternalPropertyDescriptor[]; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface CompileScriptReturnType { + /** + * Id of the script. + */ + scriptId?: Runtime.ScriptId; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface RunScriptReturnType { + /** + * Run result. + */ + result: Runtime.RemoteObject; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface ExecutionContextCreatedEventDataType { + /** + * A newly created execution context. + */ + context: Runtime.ExecutionContextDescription; + } + + export interface ExecutionContextDestroyedEventDataType { + /** + * Id of the destroyed context + */ + executionContextId: Runtime.ExecutionContextId; + } + + export interface ExceptionThrownEventDataType { + /** + * Timestamp of the exception. + */ + timestamp: Runtime.Timestamp; + exceptionDetails: Runtime.ExceptionDetails; + } + + export interface ExceptionRevokedEventDataType { + /** + * Reason describing why exception was revoked. + */ + reason: string; + /** + * The id of revoked exception, as reported in exceptionUnhandled. + */ + exceptionId: number; + } + + export interface ConsoleAPICalledEventDataType { + /** + * Type of the call. + */ + type: string; + /** + * Call arguments. + */ + args: Runtime.RemoteObject[]; + /** + * Identifier of the context where the call was made. + */ + executionContextId: Runtime.ExecutionContextId; + /** + * Call timestamp. + */ + timestamp: Runtime.Timestamp; + /** + * Stack trace captured when the call was made. + */ + stackTrace?: Runtime.StackTrace; + /** + * Console context descriptor for calls on non-default console context (not console.*): 'anonymous#unique-logger-id' for call on unnamed context, 'name#unique-logger-id' for call on named context. + * @experimental + */ + context?: string; + } + + export interface InspectRequestedEventDataType { + object: Runtime.RemoteObject; + hints: {}; + } + } + + export namespace Debugger { + /** + * Breakpoint identifier. + */ + export type BreakpointId = string; + + /** + * Call frame identifier. + */ + export type CallFrameId = string; + + /** + * Location in the source code. + */ + export interface Location { + /** + * Script identifier as reported in the Debugger.scriptParsed. + */ + scriptId: Runtime.ScriptId; + /** + * Line number in the script (0-based). + */ + lineNumber: number; + /** + * Column number in the script (0-based). + */ + columnNumber?: number; + } + + /** + * Location in the source code. + * @experimental + */ + export interface ScriptPosition { + lineNumber: number; + columnNumber: number; + } + + /** + * JavaScript call frame. Array of call frames form the call stack. + */ + export interface CallFrame { + /** + * Call frame identifier. This identifier is only valid while the virtual machine is paused. + */ + callFrameId: Debugger.CallFrameId; + /** + * Name of the JavaScript function called on this call frame. + */ + functionName: string; + /** + * Location in the source code. + * @experimental + */ + functionLocation?: Debugger.Location; + /** + * Location in the source code. + */ + location: Debugger.Location; + /** + * Scope chain for this call frame. + */ + scopeChain: Debugger.Scope[]; + /** + * this object for this call frame. + */ + this: Runtime.RemoteObject; + /** + * The value being returned, if the function is at return point. + */ + returnValue?: Runtime.RemoteObject; + } + + /** + * Scope description. + */ + export interface Scope { + /** + * Scope type. + */ + type: string; + /** + * Object representing the scope. For global and with scopes it represents the actual object; for the rest of the scopes, it is artificial transient object enumerating scope variables as its properties. + */ + object: Runtime.RemoteObject; + name?: string; + /** + * Location in the source code where scope starts + */ + startLocation?: Debugger.Location; + /** + * Location in the source code where scope ends + */ + endLocation?: Debugger.Location; + } + + /** + * Search match for resource. + * @experimental + */ + export interface SearchMatch { + /** + * Line number in resource content. + */ + lineNumber: number; + /** + * Line with match content. + */ + lineContent: string; + } + + /** + * @experimental + */ + export interface BreakLocation { + /** + * Script identifier as reported in the Debugger.scriptParsed. + */ + scriptId: Runtime.ScriptId; + /** + * Line number in the script (0-based). + */ + lineNumber: number; + /** + * Column number in the script (0-based). + */ + columnNumber?: number; + type?: string; + } + + export interface SetBreakpointsActiveParameterType { + /** + * New value for breakpoints active state. + */ + active: boolean; + } + + export interface SetSkipAllPausesParameterType { + /** + * New value for skip pauses state. + */ + skip: boolean; + } + + export interface SetBreakpointByUrlParameterType { + /** + * Line number to set breakpoint at. + */ + lineNumber: number; + /** + * URL of the resources to set breakpoint on. + */ + url?: string; + /** + * Regex pattern for the URLs of the resources to set breakpoints on. Either url or urlRegex must be specified. + */ + urlRegex?: string; + /** + * Offset in the line to set breakpoint at. + */ + columnNumber?: number; + /** + * Expression to use as a breakpoint condition. When specified, debugger will only stop on the breakpoint if this expression evaluates to true. + */ + condition?: string; + } + + export interface SetBreakpointParameterType { + /** + * Location to set breakpoint in. + */ + location: Debugger.Location; + /** + * Expression to use as a breakpoint condition. When specified, debugger will only stop on the breakpoint if this expression evaluates to true. + */ + condition?: string; + } + + export interface RemoveBreakpointParameterType { + breakpointId: Debugger.BreakpointId; + } + + export interface GetPossibleBreakpointsParameterType { + /** + * Start of range to search possible breakpoint locations in. + */ + start: Debugger.Location; + /** + * End of range to search possible breakpoint locations in (excluding). When not specified, end of scripts is used as end of range. + */ + end?: Debugger.Location; + /** + * Only consider locations which are in the same (non-nested) function as start. + */ + restrictToFunction?: boolean; + } + + export interface ContinueToLocationParameterType { + /** + * Location to continue to. + */ + location: Debugger.Location; + /** + * @experimental + */ + targetCallFrames?: string; + } + + export interface SearchInContentParameterType { + /** + * Id of the script to search in. + */ + scriptId: Runtime.ScriptId; + /** + * String to search for. + */ + query: string; + /** + * If true, search is case sensitive. + */ + caseSensitive?: boolean; + /** + * If true, treats string parameter as regex. + */ + isRegex?: boolean; + } + + export interface SetScriptSourceParameterType { + /** + * Id of the script to edit. + */ + scriptId: Runtime.ScriptId; + /** + * New content of the script. + */ + scriptSource: string; + /** + * If true the change will not actually be applied. Dry run may be used to get result description without actually modifying the code. + */ + dryRun?: boolean; + } + + export interface RestartFrameParameterType { + /** + * Call frame identifier to evaluate on. + */ + callFrameId: Debugger.CallFrameId; + } + + export interface GetScriptSourceParameterType { + /** + * Id of the script to get source for. + */ + scriptId: Runtime.ScriptId; + } + + export interface SetPauseOnExceptionsParameterType { + /** + * Pause on exceptions mode. + */ + state: string; + } + + export interface EvaluateOnCallFrameParameterType { + /** + * Call frame identifier to evaluate on. + */ + callFrameId: Debugger.CallFrameId; + /** + * Expression to evaluate. + */ + expression: string; + /** + * String object group name to put result into (allows rapid releasing resulting object handles using releaseObjectGroup). + */ + objectGroup?: string; + /** + * Specifies whether command line API should be available to the evaluated expression, defaults to false. + */ + includeCommandLineAPI?: boolean; + /** + * In silent mode exceptions thrown during evaluation are not reported and do not pause execution. Overrides setPauseOnException state. + */ + silent?: boolean; + /** + * Whether the result is expected to be a JSON object that should be sent by value. + */ + returnByValue?: boolean; + /** + * Whether preview should be generated for the result. + * @experimental + */ + generatePreview?: boolean; + /** + * Whether to throw an exception if side effect cannot be ruled out during evaluation. + * @experimental + */ + throwOnSideEffect?: boolean; + } + + export interface SetVariableValueParameterType { + /** + * 0-based number of scope as was listed in scope chain. Only 'local', 'closure' and 'catch' scope types are allowed. Other scopes could be manipulated manually. + */ + scopeNumber: number; + /** + * Variable name. + */ + variableName: string; + /** + * New variable value. + */ + newValue: Runtime.CallArgument; + /** + * Id of callframe that holds variable. + */ + callFrameId: Debugger.CallFrameId; + } + + export interface SetAsyncCallStackDepthParameterType { + /** + * Maximum depth of async call stacks. Setting to 0 will effectively disable collecting async call stacks (default). + */ + maxDepth: number; + } + + export interface SetBlackboxPatternsParameterType { + /** + * Array of regexps that will be used to check script url for blackbox state. + */ + patterns: string[]; + } + + export interface SetBlackboxedRangesParameterType { + /** + * Id of the script. + */ + scriptId: Runtime.ScriptId; + positions: Debugger.ScriptPosition[]; + } + + export interface SetBreakpointByUrlReturnType { + /** + * Id of the created breakpoint for further reference. + */ + breakpointId: Debugger.BreakpointId; + /** + * List of the locations this breakpoint resolved into upon addition. + */ + locations: Debugger.Location[]; + } + + export interface SetBreakpointReturnType { + /** + * Id of the created breakpoint for further reference. + */ + breakpointId: Debugger.BreakpointId; + /** + * Location this breakpoint resolved into. + */ + actualLocation: Debugger.Location; + } + + export interface GetPossibleBreakpointsReturnType { + /** + * List of the possible breakpoint locations. + */ + locations: Debugger.BreakLocation[]; + } + + export interface SearchInContentReturnType { + /** + * List of search matches. + */ + result: Debugger.SearchMatch[]; + } + + export interface SetScriptSourceReturnType { + /** + * New stack trace in case editing has happened while VM was stopped. + */ + callFrames?: Debugger.CallFrame[]; + /** + * Whether current call stack was modified after applying the changes. + */ + stackChanged?: boolean; + /** + * Async stack trace, if any. + */ + asyncStackTrace?: Runtime.StackTrace; + /** + * Exception details if any. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface RestartFrameReturnType { + /** + * New stack trace. + */ + callFrames: Debugger.CallFrame[]; + /** + * Async stack trace, if any. + */ + asyncStackTrace?: Runtime.StackTrace; + } + + export interface GetScriptSourceReturnType { + /** + * Script source. + */ + scriptSource: string; + } + + export interface EvaluateOnCallFrameReturnType { + /** + * Object wrapper for the evaluation result. + */ + result: Runtime.RemoteObject; + /** + * Exception details. + */ + exceptionDetails?: Runtime.ExceptionDetails; + } + + export interface ScriptParsedEventDataType { + /** + * Identifier of the script parsed. + */ + scriptId: Runtime.ScriptId; + /** + * URL or name of the script parsed (if any). + */ + url: string; + /** + * Line offset of the script within the resource with given URL (for script tags). + */ + startLine: number; + /** + * Column offset of the script within the resource with given URL. + */ + startColumn: number; + /** + * Last line of the script. + */ + endLine: number; + /** + * Length of the last line of the script. + */ + endColumn: number; + /** + * Specifies script creation context. + */ + executionContextId: Runtime.ExecutionContextId; + /** + * Content hash of the script. + */ + hash: string; + /** + * Embedder-specific auxiliary data. + */ + executionContextAuxData?: {}; + /** + * True, if this script is generated as a result of the live edit operation. + * @experimental + */ + isLiveEdit?: boolean; + /** + * URL of source map associated with script (if any). + */ + sourceMapURL?: string; + /** + * True, if this script has sourceURL. + * @experimental + */ + hasSourceURL?: boolean; + /** + * True, if this script is ES6 module. + * @experimental + */ + isModule?: boolean; + /** + * This script length. + * @experimental + */ + length?: number; + /** + * JavaScript top stack frame of where the script parsed event was triggered if available. + * @experimental + */ + stackTrace?: Runtime.StackTrace; + } + + export interface ScriptFailedToParseEventDataType { + /** + * Identifier of the script parsed. + */ + scriptId: Runtime.ScriptId; + /** + * URL or name of the script parsed (if any). + */ + url: string; + /** + * Line offset of the script within the resource with given URL (for script tags). + */ + startLine: number; + /** + * Column offset of the script within the resource with given URL. + */ + startColumn: number; + /** + * Last line of the script. + */ + endLine: number; + /** + * Length of the last line of the script. + */ + endColumn: number; + /** + * Specifies script creation context. + */ + executionContextId: Runtime.ExecutionContextId; + /** + * Content hash of the script. + */ + hash: string; + /** + * Embedder-specific auxiliary data. + */ + executionContextAuxData?: {}; + /** + * URL of source map associated with script (if any). + */ + sourceMapURL?: string; + /** + * True, if this script has sourceURL. + * @experimental + */ + hasSourceURL?: boolean; + /** + * True, if this script is ES6 module. + * @experimental + */ + isModule?: boolean; + /** + * This script length. + * @experimental + */ + length?: number; + /** + * JavaScript top stack frame of where the script parsed event was triggered if available. + * @experimental + */ + stackTrace?: Runtime.StackTrace; + } + + export interface BreakpointResolvedEventDataType { + /** + * Breakpoint unique identifier. + */ + breakpointId: Debugger.BreakpointId; + /** + * Actual breakpoint location. + */ + location: Debugger.Location; + } + + export interface PausedEventDataType { + /** + * Call stack the virtual machine stopped on. + */ + callFrames: Debugger.CallFrame[]; + /** + * Pause reason. + */ + reason: string; + /** + * Object containing break-specific auxiliary properties. + */ + data?: {}; + /** + * Hit breakpoints IDs + */ + hitBreakpoints?: string[]; + /** + * Async stack trace, if any. + */ + asyncStackTrace?: Runtime.StackTrace; + } + } + + export namespace Console { + /** + * Console message. + */ + export interface ConsoleMessage { + /** + * Message source. + */ + source: string; + /** + * Message severity. + */ + level: string; + /** + * Message text. + */ + text: string; + /** + * URL of the message origin. + */ + url?: string; + /** + * Line number in the resource that generated this message (1-based). + */ + line?: number; + /** + * Column number in the resource that generated this message (1-based). + */ + column?: number; + } + + export interface MessageAddedEventDataType { + /** + * Console message that has been added. + */ + message: Console.ConsoleMessage; + } + } + + export namespace Profiler { + /** + * Profile node. Holds callsite information, execution statistics and child nodes. + */ + export interface ProfileNode { + /** + * Unique id of the node. + */ + id: number; + /** + * Function location. + */ + callFrame: Runtime.CallFrame; + /** + * Number of samples where this node was on top of the call stack. + * @experimental + */ + hitCount?: number; + /** + * Child node ids. + */ + children?: number[]; + /** + * The reason of being not optimized. The function may be deoptimized or marked as don't optimize. + */ + deoptReason?: string; + /** + * An array of source position ticks. + * @experimental + */ + positionTicks?: Profiler.PositionTickInfo[]; + } + + /** + * Profile. + */ + export interface Profile { + /** + * The list of profile nodes. First item is the root node. + */ + nodes: Profiler.ProfileNode[]; + /** + * Profiling start timestamp in microseconds. + */ + startTime: number; + /** + * Profiling end timestamp in microseconds. + */ + endTime: number; + /** + * Ids of samples top nodes. + */ + samples?: number[]; + /** + * Time intervals between adjacent samples in microseconds. The first delta is relative to the profile startTime. + */ + timeDeltas?: number[]; + } + + /** + * Specifies a number of samples attributed to a certain source position. + * @experimental + */ + export interface PositionTickInfo { + /** + * Source line number (1-based). + */ + line: number; + /** + * Number of samples attributed to the source line. + */ + ticks: number; + } + + /** + * Coverage data for a source range. + * @experimental + */ + export interface CoverageRange { + /** + * JavaScript script source offset for the range start. + */ + startOffset: number; + /** + * JavaScript script source offset for the range end. + */ + endOffset: number; + /** + * Collected execution count of the source range. + */ + count: number; + } + + /** + * Coverage data for a JavaScript function. + * @experimental + */ + export interface FunctionCoverage { + /** + * JavaScript function name. + */ + functionName: string; + /** + * Source ranges inside the function with coverage data. + */ + ranges: Profiler.CoverageRange[]; + /** + * Whether coverage data for this function has block granularity. + */ + isBlockCoverage: boolean; + } + + /** + * Coverage data for a JavaScript script. + * @experimental + */ + export interface ScriptCoverage { + /** + * JavaScript script id. + */ + scriptId: Runtime.ScriptId; + /** + * JavaScript script name or url. + */ + url: string; + /** + * Functions contained in the script that has coverage data. + */ + functions: Profiler.FunctionCoverage[]; + } + + export interface SetSamplingIntervalParameterType { + /** + * New sampling interval in microseconds. + */ + interval: number; + } + + export interface StartPreciseCoverageParameterType { + /** + * Collect accurate call counts beyond simple 'covered' or 'not covered'. + */ + callCount?: boolean; + } + + export interface StopReturnType { + /** + * Recorded profile. + */ + profile: Profiler.Profile; + } + + export interface TakePreciseCoverageReturnType { + /** + * Coverage data for the current isolate. + */ + result: Profiler.ScriptCoverage[]; + } + + export interface GetBestEffortCoverageReturnType { + /** + * Coverage data for the current isolate. + */ + result: Profiler.ScriptCoverage[]; + } + + export interface ConsoleProfileStartedEventDataType { + id: string; + /** + * Location of console.profile(). + */ + location: Debugger.Location; + /** + * Profile title passed as an argument to console.profile(). + */ + title?: string; + } + + export interface ConsoleProfileFinishedEventDataType { + id: string; + /** + * Location of console.profileEnd(). + */ + location: Debugger.Location; + profile: Profiler.Profile; + /** + * Profile title passed as an argument to console.profile(). + */ + title?: string; + } + } + + export namespace HeapProfiler { + /** + * Heap snapshot object id. + */ + export type HeapSnapshotObjectId = string; + + /** + * Sampling Heap Profile node. Holds callsite information, allocation statistics and child nodes. + */ + export interface SamplingHeapProfileNode { + /** + * Function location. + */ + callFrame: Runtime.CallFrame; + /** + * Allocations size in bytes for the node excluding children. + */ + selfSize: number; + /** + * Child nodes. + */ + children: HeapProfiler.SamplingHeapProfileNode[]; + } + + /** + * Profile. + */ + export interface SamplingHeapProfile { + head: HeapProfiler.SamplingHeapProfileNode; + } + + export interface StartTrackingHeapObjectsParameterType { + trackAllocations?: boolean; + } + + export interface StopTrackingHeapObjectsParameterType { + /** + * If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being taken when the tracking is stopped. + */ + reportProgress?: boolean; + } + + export interface TakeHeapSnapshotParameterType { + /** + * If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being taken. + */ + reportProgress?: boolean; + } + + export interface GetObjectByHeapObjectIdParameterType { + objectId: HeapProfiler.HeapSnapshotObjectId; + /** + * Symbolic group name that can be used to release multiple objects. + */ + objectGroup?: string; + } + + export interface AddInspectedHeapObjectParameterType { + /** + * Heap snapshot object id to be accessible by means of $x command line API. + */ + heapObjectId: HeapProfiler.HeapSnapshotObjectId; + } + + export interface GetHeapObjectIdParameterType { + /** + * Identifier of the object to get heap object id for. + */ + objectId: Runtime.RemoteObjectId; + } + + export interface StartSamplingParameterType { + /** + * Average sample interval in bytes. Poisson distribution is used for the intervals. The default value is 32768 bytes. + */ + samplingInterval?: number; + } + + export interface GetObjectByHeapObjectIdReturnType { + /** + * Evaluation result. + */ + result: Runtime.RemoteObject; + } + + export interface GetHeapObjectIdReturnType { + /** + * Id of the heap snapshot object corresponding to the passed remote object id. + */ + heapSnapshotObjectId: HeapProfiler.HeapSnapshotObjectId; + } + + export interface StopSamplingReturnType { + /** + * Recorded sampling heap profile. + */ + profile: HeapProfiler.SamplingHeapProfile; + } + + export interface AddHeapSnapshotChunkEventDataType { + chunk: string; + } + + export interface ReportHeapSnapshotProgressEventDataType { + done: number; + total: number; + finished?: boolean; + } + + export interface LastSeenObjectIdEventDataType { + lastSeenObjectId: number; + timestamp: number; + } + + export interface HeapStatsUpdateEventDataType { + /** + * An array of triplets. Each triplet describes a fragment. The first integer is the fragment index, the second integer is a total count of objects for the fragment, the third integer is a total size of the objects for the fragment. + */ + statsUpdate: number[]; + } + } + + /** + * The inspector.Session is used for dispatching messages to the V8 inspector back-end and receiving message responses and notifications. + */ + export class Session extends EventEmitter { + /** + * Create a new instance of the inspector.Session class. The inspector session needs to be connected through session.connect() before the messages can be dispatched to the inspector backend. + */ + constructor(); + + /** + * Connects a session to the inspector back-end. An exception will be thrown if there is already a connected session established either through the API or by a front-end connected to the Inspector WebSocket port. + */ + connect(): void; + + /** + * Immediately close the session. All pending message callbacks will be called with an error. session.connect() will need to be called to be able to send messages again. Reconnected session will lose all inspector state, such as enabled agents or configured breakpoints. + */ + disconnect(): void; + + /** + * Posts a message to the inspector back-end. callback will be notified when a response is received. callback is a function that accepts two optional arguments - error and message-specific result. + */ + post(method: string, params?: {}, callback?: (err: Error | null, params?: {}) => void): void; + post(method: string, callback?: (err: Error | null, params?: {}) => void): void; + + /** + * Returns supported domains. + */ + post(method: "Schema.getDomains", callback?: (err: Error | null, params: Schema.GetDomainsReturnType) => void): void; + /** + * Evaluates expression on global object. + */ + post(method: "Runtime.evaluate", params?: Runtime.EvaluateParameterType, callback?: (err: Error | null, params: Runtime.EvaluateReturnType) => void): void; + post(method: "Runtime.evaluate", callback?: (err: Error | null, params: Runtime.EvaluateReturnType) => void): void; + + /** + * Add handler to promise with given promise object id. + */ + post(method: "Runtime.awaitPromise", params?: Runtime.AwaitPromiseParameterType, callback?: (err: Error | null, params: Runtime.AwaitPromiseReturnType) => void): void; + post(method: "Runtime.awaitPromise", callback?: (err: Error | null, params: Runtime.AwaitPromiseReturnType) => void): void; + + /** + * Calls function with given declaration on the given object. Object group of the result is inherited from the target object. + */ + post(method: "Runtime.callFunctionOn", params?: Runtime.CallFunctionOnParameterType, callback?: (err: Error | null, params: Runtime.CallFunctionOnReturnType) => void): void; + post(method: "Runtime.callFunctionOn", callback?: (err: Error | null, params: Runtime.CallFunctionOnReturnType) => void): void; + + /** + * Returns properties of a given object. Object group of the result is inherited from the target object. + */ + post(method: "Runtime.getProperties", params?: Runtime.GetPropertiesParameterType, callback?: (err: Error | null, params: Runtime.GetPropertiesReturnType) => void): void; + post(method: "Runtime.getProperties", callback?: (err: Error | null, params: Runtime.GetPropertiesReturnType) => void): void; + + /** + * Releases remote object with given id. + */ + post(method: "Runtime.releaseObject", params?: Runtime.ReleaseObjectParameterType, callback?: (err: Error | null) => void): void; + post(method: "Runtime.releaseObject", callback?: (err: Error | null) => void): void; + + /** + * Releases all remote objects that belong to a given group. + */ + post(method: "Runtime.releaseObjectGroup", params?: Runtime.ReleaseObjectGroupParameterType, callback?: (err: Error | null) => void): void; + post(method: "Runtime.releaseObjectGroup", callback?: (err: Error | null) => void): void; + + /** + * Tells inspected instance to run if it was waiting for debugger to attach. + */ + post(method: "Runtime.runIfWaitingForDebugger", callback?: (err: Error | null) => void): void; + + /** + * Enables reporting of execution contexts creation by means of executionContextCreated event. When the reporting gets enabled the event will be sent immediately for each existing execution context. + */ + post(method: "Runtime.enable", callback?: (err: Error | null) => void): void; + + /** + * Disables reporting of execution contexts creation. + */ + post(method: "Runtime.disable", callback?: (err: Error | null) => void): void; + + /** + * Discards collected exceptions and console API calls. + */ + post(method: "Runtime.discardConsoleEntries", callback?: (err: Error | null) => void): void; + + /** + * @experimental + */ + post(method: "Runtime.setCustomObjectFormatterEnabled", params?: Runtime.SetCustomObjectFormatterEnabledParameterType, callback?: (err: Error | null) => void): void; + post(method: "Runtime.setCustomObjectFormatterEnabled", callback?: (err: Error | null) => void): void; + + /** + * Compiles expression. + */ + post(method: "Runtime.compileScript", params?: Runtime.CompileScriptParameterType, callback?: (err: Error | null, params: Runtime.CompileScriptReturnType) => void): void; + post(method: "Runtime.compileScript", callback?: (err: Error | null, params: Runtime.CompileScriptReturnType) => void): void; + + /** + * Runs script with given id in a given context. + */ + post(method: "Runtime.runScript", params?: Runtime.RunScriptParameterType, callback?: (err: Error | null, params: Runtime.RunScriptReturnType) => void): void; + post(method: "Runtime.runScript", callback?: (err: Error | null, params: Runtime.RunScriptReturnType) => void): void; + /** + * Enables debugger for the given page. Clients should not assume that the debugging has been enabled until the result for this command is received. + */ + post(method: "Debugger.enable", callback?: (err: Error | null) => void): void; + + /** + * Disables debugger for given page. + */ + post(method: "Debugger.disable", callback?: (err: Error | null) => void): void; + + /** + * Activates / deactivates all breakpoints on the page. + */ + post(method: "Debugger.setBreakpointsActive", params?: Debugger.SetBreakpointsActiveParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setBreakpointsActive", callback?: (err: Error | null) => void): void; + + /** + * Makes page not interrupt on any pauses (breakpoint, exception, dom exception etc). + */ + post(method: "Debugger.setSkipAllPauses", params?: Debugger.SetSkipAllPausesParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setSkipAllPauses", callback?: (err: Error | null) => void): void; + + /** + * Sets JavaScript breakpoint at given location specified either by URL or URL regex. Once this command is issued, all existing parsed scripts will have breakpoints resolved and returned in locations property. Further matching script parsing will result in subsequent breakpointResolved events issued. This logical breakpoint will survive page reloads. + */ + post(method: "Debugger.setBreakpointByUrl", params?: Debugger.SetBreakpointByUrlParameterType, callback?: (err: Error | null, params: Debugger.SetBreakpointByUrlReturnType) => void): void; + post(method: "Debugger.setBreakpointByUrl", callback?: (err: Error | null, params: Debugger.SetBreakpointByUrlReturnType) => void): void; + + /** + * Sets JavaScript breakpoint at a given location. + */ + post(method: "Debugger.setBreakpoint", params?: Debugger.SetBreakpointParameterType, callback?: (err: Error | null, params: Debugger.SetBreakpointReturnType) => void): void; + post(method: "Debugger.setBreakpoint", callback?: (err: Error | null, params: Debugger.SetBreakpointReturnType) => void): void; + + /** + * Removes JavaScript breakpoint. + */ + post(method: "Debugger.removeBreakpoint", params?: Debugger.RemoveBreakpointParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.removeBreakpoint", callback?: (err: Error | null) => void): void; + + /** + * Returns possible locations for breakpoint. scriptId in start and end range locations should be the same. + * @experimental + */ + post(method: "Debugger.getPossibleBreakpoints", params?: Debugger.GetPossibleBreakpointsParameterType, callback?: (err: Error | null, params: Debugger.GetPossibleBreakpointsReturnType) => void): void; + post(method: "Debugger.getPossibleBreakpoints", callback?: (err: Error | null, params: Debugger.GetPossibleBreakpointsReturnType) => void): void; + + /** + * Continues execution until specific location is reached. + */ + post(method: "Debugger.continueToLocation", params?: Debugger.ContinueToLocationParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.continueToLocation", callback?: (err: Error | null) => void): void; + + /** + * Steps over the statement. + */ + post(method: "Debugger.stepOver", callback?: (err: Error | null) => void): void; + + /** + * Steps into the function call. + */ + post(method: "Debugger.stepInto", callback?: (err: Error | null) => void): void; + + /** + * Steps out of the function call. + */ + post(method: "Debugger.stepOut", callback?: (err: Error | null) => void): void; + + /** + * Stops on the next JavaScript statement. + */ + post(method: "Debugger.pause", callback?: (err: Error | null) => void): void; + + /** + * Steps into next scheduled async task if any is scheduled before next pause. Returns success when async task is actually scheduled, returns error if no task were scheduled or another scheduleStepIntoAsync was called. + * @experimental + */ + post(method: "Debugger.scheduleStepIntoAsync", callback?: (err: Error | null) => void): void; + + /** + * Resumes JavaScript execution. + */ + post(method: "Debugger.resume", callback?: (err: Error | null) => void): void; + + /** + * Searches for given string in script content. + * @experimental + */ + post(method: "Debugger.searchInContent", params?: Debugger.SearchInContentParameterType, callback?: (err: Error | null, params: Debugger.SearchInContentReturnType) => void): void; + post(method: "Debugger.searchInContent", callback?: (err: Error | null, params: Debugger.SearchInContentReturnType) => void): void; + + /** + * Edits JavaScript source live. + */ + post(method: "Debugger.setScriptSource", params?: Debugger.SetScriptSourceParameterType, callback?: (err: Error | null, params: Debugger.SetScriptSourceReturnType) => void): void; + post(method: "Debugger.setScriptSource", callback?: (err: Error | null, params: Debugger.SetScriptSourceReturnType) => void): void; + + /** + * Restarts particular call frame from the beginning. + */ + post(method: "Debugger.restartFrame", params?: Debugger.RestartFrameParameterType, callback?: (err: Error | null, params: Debugger.RestartFrameReturnType) => void): void; + post(method: "Debugger.restartFrame", callback?: (err: Error | null, params: Debugger.RestartFrameReturnType) => void): void; + + /** + * Returns source for the script with given id. + */ + post(method: "Debugger.getScriptSource", params?: Debugger.GetScriptSourceParameterType, callback?: (err: Error | null, params: Debugger.GetScriptSourceReturnType) => void): void; + post(method: "Debugger.getScriptSource", callback?: (err: Error | null, params: Debugger.GetScriptSourceReturnType) => void): void; + + /** + * Defines pause on exceptions state. Can be set to stop on all exceptions, uncaught exceptions or no exceptions. Initial pause on exceptions state is none. + */ + post(method: "Debugger.setPauseOnExceptions", params?: Debugger.SetPauseOnExceptionsParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setPauseOnExceptions", callback?: (err: Error | null) => void): void; + + /** + * Evaluates expression on a given call frame. + */ + post(method: "Debugger.evaluateOnCallFrame", params?: Debugger.EvaluateOnCallFrameParameterType, callback?: (err: Error | null, params: Debugger.EvaluateOnCallFrameReturnType) => void): void; + post(method: "Debugger.evaluateOnCallFrame", callback?: (err: Error | null, params: Debugger.EvaluateOnCallFrameReturnType) => void): void; + + /** + * Changes value of variable in a callframe. Object-based scopes are not supported and must be mutated manually. + */ + post(method: "Debugger.setVariableValue", params?: Debugger.SetVariableValueParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setVariableValue", callback?: (err: Error | null) => void): void; + + /** + * Enables or disables async call stacks tracking. + */ + post(method: "Debugger.setAsyncCallStackDepth", params?: Debugger.SetAsyncCallStackDepthParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setAsyncCallStackDepth", callback?: (err: Error | null) => void): void; + + /** + * Replace previous blackbox patterns with passed ones. Forces backend to skip stepping/pausing in scripts with url matching one of the patterns. VM will try to leave blackboxed script by performing 'step in' several times, finally resorting to 'step out' if unsuccessful. + * @experimental + */ + post(method: "Debugger.setBlackboxPatterns", params?: Debugger.SetBlackboxPatternsParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setBlackboxPatterns", callback?: (err: Error | null) => void): void; + + /** + * Makes backend skip steps in the script in blackboxed ranges. VM will try leave blacklisted scripts by performing 'step in' several times, finally resorting to 'step out' if unsuccessful. Positions array contains positions where blackbox state is changed. First interval isn't blackboxed. Array should be sorted. + * @experimental + */ + post(method: "Debugger.setBlackboxedRanges", params?: Debugger.SetBlackboxedRangesParameterType, callback?: (err: Error | null) => void): void; + post(method: "Debugger.setBlackboxedRanges", callback?: (err: Error | null) => void): void; + /** + * Enables console domain, sends the messages collected so far to the client by means of the messageAdded notification. + */ + post(method: "Console.enable", callback?: (err: Error | null) => void): void; + + /** + * Disables console domain, prevents further console messages from being reported to the client. + */ + post(method: "Console.disable", callback?: (err: Error | null) => void): void; + + /** + * Does nothing. + */ + post(method: "Console.clearMessages", callback?: (err: Error | null) => void): void; + post(method: "Profiler.enable", callback?: (err: Error | null) => void): void; + + post(method: "Profiler.disable", callback?: (err: Error | null) => void): void; + + /** + * Changes CPU profiler sampling interval. Must be called before CPU profiles recording started. + */ + post(method: "Profiler.setSamplingInterval", params?: Profiler.SetSamplingIntervalParameterType, callback?: (err: Error | null) => void): void; + post(method: "Profiler.setSamplingInterval", callback?: (err: Error | null) => void): void; + + post(method: "Profiler.start", callback?: (err: Error | null) => void): void; + + post(method: "Profiler.stop", callback?: (err: Error | null, params: Profiler.StopReturnType) => void): void; + + /** + * Enable precise code coverage. Coverage data for JavaScript executed before enabling precise code coverage may be incomplete. Enabling prevents running optimized code and resets execution counters. + * @experimental + */ + post(method: "Profiler.startPreciseCoverage", params?: Profiler.StartPreciseCoverageParameterType, callback?: (err: Error | null) => void): void; + post(method: "Profiler.startPreciseCoverage", callback?: (err: Error | null) => void): void; + + /** + * Disable precise code coverage. Disabling releases unnecessary execution count records and allows executing optimized code. + * @experimental + */ + post(method: "Profiler.stopPreciseCoverage", callback?: (err: Error | null) => void): void; + + /** + * Collect coverage data for the current isolate, and resets execution counters. Precise code coverage needs to have started. + * @experimental + */ + post(method: "Profiler.takePreciseCoverage", callback?: (err: Error | null, params: Profiler.TakePreciseCoverageReturnType) => void): void; + + /** + * Collect coverage data for the current isolate. The coverage data may be incomplete due to garbage collection. + * @experimental + */ + post(method: "Profiler.getBestEffortCoverage", callback?: (err: Error | null, params: Profiler.GetBestEffortCoverageReturnType) => void): void; + post(method: "HeapProfiler.enable", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.disable", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.startTrackingHeapObjects", params?: HeapProfiler.StartTrackingHeapObjectsParameterType, callback?: (err: Error | null) => void): void; + post(method: "HeapProfiler.startTrackingHeapObjects", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.stopTrackingHeapObjects", params?: HeapProfiler.StopTrackingHeapObjectsParameterType, callback?: (err: Error | null) => void): void; + post(method: "HeapProfiler.stopTrackingHeapObjects", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.takeHeapSnapshot", params?: HeapProfiler.TakeHeapSnapshotParameterType, callback?: (err: Error | null) => void): void; + post(method: "HeapProfiler.takeHeapSnapshot", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.collectGarbage", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.getObjectByHeapObjectId", params?: HeapProfiler.GetObjectByHeapObjectIdParameterType, callback?: (err: Error | null, params: HeapProfiler.GetObjectByHeapObjectIdReturnType) => void): void; + post(method: "HeapProfiler.getObjectByHeapObjectId", callback?: (err: Error | null, params: HeapProfiler.GetObjectByHeapObjectIdReturnType) => void): void; + + /** + * Enables console to refer to the node with given id via $x (see Command Line API for more details $x functions). + */ + post(method: "HeapProfiler.addInspectedHeapObject", params?: HeapProfiler.AddInspectedHeapObjectParameterType, callback?: (err: Error | null) => void): void; + post(method: "HeapProfiler.addInspectedHeapObject", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.getHeapObjectId", params?: HeapProfiler.GetHeapObjectIdParameterType, callback?: (err: Error | null, params: HeapProfiler.GetHeapObjectIdReturnType) => void): void; + post(method: "HeapProfiler.getHeapObjectId", callback?: (err: Error | null, params: HeapProfiler.GetHeapObjectIdReturnType) => void): void; + + post(method: "HeapProfiler.startSampling", params?: HeapProfiler.StartSamplingParameterType, callback?: (err: Error | null) => void): void; + post(method: "HeapProfiler.startSampling", callback?: (err: Error | null) => void): void; + + post(method: "HeapProfiler.stopSampling", callback?: (err: Error | null, params: HeapProfiler.StopSamplingReturnType) => void): void; + + // Events + + addListener(event: string, listener: (...args: any[]) => void): this; + + /** + * Emitted when any notification from the V8 Inspector is received. + */ + addListener(event: "inspectorNotification", listener: (message: InspectorNotification<{}>) => void): this; + + /** + * Issued when new execution context is created. + */ + addListener(event: "Runtime.executionContextCreated", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when execution context is destroyed. + */ + addListener(event: "Runtime.executionContextDestroyed", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when all executionContexts were cleared in browser + */ + addListener(event: "Runtime.executionContextsCleared", listener: () => void): this; + + /** + * Issued when exception was thrown and unhandled. + */ + addListener(event: "Runtime.exceptionThrown", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when unhandled exception was revoked. + */ + addListener(event: "Runtime.exceptionRevoked", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when console API was called. + */ + addListener(event: "Runtime.consoleAPICalled", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when object should be inspected (for example, as a result of inspect() command line API call). + */ + addListener(event: "Runtime.inspectRequested", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine parses script. This event is also fired for all known and uncollected scripts upon enabling debugger. + */ + addListener(event: "Debugger.scriptParsed", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine fails to parse the script. + */ + addListener(event: "Debugger.scriptFailedToParse", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when breakpoint is resolved to an actual script and location. + */ + addListener(event: "Debugger.breakpointResolved", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + */ + addListener(event: "Debugger.paused", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine resumed execution. + */ + addListener(event: "Debugger.resumed", listener: () => void): this; + + /** + * Issued when new console message is added. + */ + addListener(event: "Console.messageAdded", listener: (message: InspectorNotification) => void): this; + + /** + * Sent when new profile recording is started using console.profile() call. + */ + addListener(event: "Profiler.consoleProfileStarted", listener: (message: InspectorNotification) => void): this; + + addListener(event: "Profiler.consoleProfileFinished", listener: (message: InspectorNotification) => void): this; + addListener(event: "HeapProfiler.addHeapSnapshotChunk", listener: (message: InspectorNotification) => void): this; + addListener(event: "HeapProfiler.resetProfiles", listener: () => void): this; + addListener(event: "HeapProfiler.reportHeapSnapshotProgress", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + */ + addListener(event: "HeapProfiler.lastSeenObjectId", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend may send update for one or more fragments + */ + addListener(event: "HeapProfiler.heapStatsUpdate", listener: (message: InspectorNotification) => void): this; + + emit(event: string | symbol, ...args: any[]): boolean; + emit(event: "inspectorNotification", message: InspectorNotification<{}>): boolean; + emit(event: "Runtime.executionContextCreated", message: InspectorNotification): boolean; + emit(event: "Runtime.executionContextDestroyed", message: InspectorNotification): boolean; + emit(event: "Runtime.executionContextsCleared"): boolean; + emit(event: "Runtime.exceptionThrown", message: InspectorNotification): boolean; + emit(event: "Runtime.exceptionRevoked", message: InspectorNotification): boolean; + emit(event: "Runtime.consoleAPICalled", message: InspectorNotification): boolean; + emit(event: "Runtime.inspectRequested", message: InspectorNotification): boolean; + emit(event: "Debugger.scriptParsed", message: InspectorNotification): boolean; + emit(event: "Debugger.scriptFailedToParse", message: InspectorNotification): boolean; + emit(event: "Debugger.breakpointResolved", message: InspectorNotification): boolean; + emit(event: "Debugger.paused", message: InspectorNotification): boolean; + emit(event: "Debugger.resumed"): boolean; + emit(event: "Console.messageAdded", message: InspectorNotification): boolean; + emit(event: "Profiler.consoleProfileStarted", message: InspectorNotification): boolean; + emit(event: "Profiler.consoleProfileFinished", message: InspectorNotification): boolean; + emit(event: "HeapProfiler.addHeapSnapshotChunk", message: InspectorNotification): boolean; + emit(event: "HeapProfiler.resetProfiles"): boolean; + emit(event: "HeapProfiler.reportHeapSnapshotProgress", message: InspectorNotification): boolean; + emit(event: "HeapProfiler.lastSeenObjectId", message: InspectorNotification): boolean; + emit(event: "HeapProfiler.heapStatsUpdate", message: InspectorNotification): boolean; + + on(event: string, listener: (...args: any[]) => void): this; + + /** + * Emitted when any notification from the V8 Inspector is received. + */ + on(event: "inspectorNotification", listener: (message: InspectorNotification<{}>) => void): this; + + /** + * Issued when new execution context is created. + */ + on(event: "Runtime.executionContextCreated", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when execution context is destroyed. + */ + on(event: "Runtime.executionContextDestroyed", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when all executionContexts were cleared in browser + */ + on(event: "Runtime.executionContextsCleared", listener: () => void): this; + + /** + * Issued when exception was thrown and unhandled. + */ + on(event: "Runtime.exceptionThrown", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when unhandled exception was revoked. + */ + on(event: "Runtime.exceptionRevoked", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when console API was called. + */ + on(event: "Runtime.consoleAPICalled", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when object should be inspected (for example, as a result of inspect() command line API call). + */ + on(event: "Runtime.inspectRequested", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine parses script. This event is also fired for all known and uncollected scripts upon enabling debugger. + */ + on(event: "Debugger.scriptParsed", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine fails to parse the script. + */ + on(event: "Debugger.scriptFailedToParse", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when breakpoint is resolved to an actual script and location. + */ + on(event: "Debugger.breakpointResolved", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + */ + on(event: "Debugger.paused", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine resumed execution. + */ + on(event: "Debugger.resumed", listener: () => void): this; + + /** + * Issued when new console message is added. + */ + on(event: "Console.messageAdded", listener: (message: InspectorNotification) => void): this; + + /** + * Sent when new profile recording is started using console.profile() call. + */ + on(event: "Profiler.consoleProfileStarted", listener: (message: InspectorNotification) => void): this; + + on(event: "Profiler.consoleProfileFinished", listener: (message: InspectorNotification) => void): this; + on(event: "HeapProfiler.addHeapSnapshotChunk", listener: (message: InspectorNotification) => void): this; + on(event: "HeapProfiler.resetProfiles", listener: () => void): this; + on(event: "HeapProfiler.reportHeapSnapshotProgress", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + */ + on(event: "HeapProfiler.lastSeenObjectId", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend may send update for one or more fragments + */ + on(event: "HeapProfiler.heapStatsUpdate", listener: (message: InspectorNotification) => void): this; + + once(event: string, listener: (...args: any[]) => void): this; + + /** + * Emitted when any notification from the V8 Inspector is received. + */ + once(event: "inspectorNotification", listener: (message: InspectorNotification<{}>) => void): this; + + /** + * Issued when new execution context is created. + */ + once(event: "Runtime.executionContextCreated", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when execution context is destroyed. + */ + once(event: "Runtime.executionContextDestroyed", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when all executionContexts were cleared in browser + */ + once(event: "Runtime.executionContextsCleared", listener: () => void): this; + + /** + * Issued when exception was thrown and unhandled. + */ + once(event: "Runtime.exceptionThrown", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when unhandled exception was revoked. + */ + once(event: "Runtime.exceptionRevoked", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when console API was called. + */ + once(event: "Runtime.consoleAPICalled", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when object should be inspected (for example, as a result of inspect() command line API call). + */ + once(event: "Runtime.inspectRequested", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine parses script. This event is also fired for all known and uncollected scripts upon enabling debugger. + */ + once(event: "Debugger.scriptParsed", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine fails to parse the script. + */ + once(event: "Debugger.scriptFailedToParse", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when breakpoint is resolved to an actual script and location. + */ + once(event: "Debugger.breakpointResolved", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + */ + once(event: "Debugger.paused", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine resumed execution. + */ + once(event: "Debugger.resumed", listener: () => void): this; + + /** + * Issued when new console message is added. + */ + once(event: "Console.messageAdded", listener: (message: InspectorNotification) => void): this; + + /** + * Sent when new profile recording is started using console.profile() call. + */ + once(event: "Profiler.consoleProfileStarted", listener: (message: InspectorNotification) => void): this; + + once(event: "Profiler.consoleProfileFinished", listener: (message: InspectorNotification) => void): this; + once(event: "HeapProfiler.addHeapSnapshotChunk", listener: (message: InspectorNotification) => void): this; + once(event: "HeapProfiler.resetProfiles", listener: () => void): this; + once(event: "HeapProfiler.reportHeapSnapshotProgress", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + */ + once(event: "HeapProfiler.lastSeenObjectId", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend may send update for one or more fragments + */ + once(event: "HeapProfiler.heapStatsUpdate", listener: (message: InspectorNotification) => void): this; + + prependListener(event: string, listener: (...args: any[]) => void): this; + + /** + * Emitted when any notification from the V8 Inspector is received. + */ + prependListener(event: "inspectorNotification", listener: (message: InspectorNotification<{}>) => void): this; + + /** + * Issued when new execution context is created. + */ + prependListener(event: "Runtime.executionContextCreated", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when execution context is destroyed. + */ + prependListener(event: "Runtime.executionContextDestroyed", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when all executionContexts were cleared in browser + */ + prependListener(event: "Runtime.executionContextsCleared", listener: () => void): this; + + /** + * Issued when exception was thrown and unhandled. + */ + prependListener(event: "Runtime.exceptionThrown", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when unhandled exception was revoked. + */ + prependListener(event: "Runtime.exceptionRevoked", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when console API was called. + */ + prependListener(event: "Runtime.consoleAPICalled", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when object should be inspected (for example, as a result of inspect() command line API call). + */ + prependListener(event: "Runtime.inspectRequested", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine parses script. This event is also fired for all known and uncollected scripts upon enabling debugger. + */ + prependListener(event: "Debugger.scriptParsed", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine fails to parse the script. + */ + prependListener(event: "Debugger.scriptFailedToParse", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when breakpoint is resolved to an actual script and location. + */ + prependListener(event: "Debugger.breakpointResolved", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + */ + prependListener(event: "Debugger.paused", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine resumed execution. + */ + prependListener(event: "Debugger.resumed", listener: () => void): this; + + /** + * Issued when new console message is added. + */ + prependListener(event: "Console.messageAdded", listener: (message: InspectorNotification) => void): this; + + /** + * Sent when new profile recording is started using console.profile() call. + */ + prependListener(event: "Profiler.consoleProfileStarted", listener: (message: InspectorNotification) => void): this; + + prependListener(event: "Profiler.consoleProfileFinished", listener: (message: InspectorNotification) => void): this; + prependListener(event: "HeapProfiler.addHeapSnapshotChunk", listener: (message: InspectorNotification) => void): this; + prependListener(event: "HeapProfiler.resetProfiles", listener: () => void): this; + prependListener(event: "HeapProfiler.reportHeapSnapshotProgress", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + */ + prependListener(event: "HeapProfiler.lastSeenObjectId", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend may send update for one or more fragments + */ + prependListener(event: "HeapProfiler.heapStatsUpdate", listener: (message: InspectorNotification) => void): this; + + prependOnceListener(event: string, listener: (...args: any[]) => void): this; + + /** + * Emitted when any notification from the V8 Inspector is received. + */ + prependOnceListener(event: "inspectorNotification", listener: (message: InspectorNotification<{}>) => void): this; + + /** + * Issued when new execution context is created. + */ + prependOnceListener(event: "Runtime.executionContextCreated", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when execution context is destroyed. + */ + prependOnceListener(event: "Runtime.executionContextDestroyed", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when all executionContexts were cleared in browser + */ + prependOnceListener(event: "Runtime.executionContextsCleared", listener: () => void): this; + + /** + * Issued when exception was thrown and unhandled. + */ + prependOnceListener(event: "Runtime.exceptionThrown", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when unhandled exception was revoked. + */ + prependOnceListener(event: "Runtime.exceptionRevoked", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when console API was called. + */ + prependOnceListener(event: "Runtime.consoleAPICalled", listener: (message: InspectorNotification) => void): this; + + /** + * Issued when object should be inspected (for example, as a result of inspect() command line API call). + */ + prependOnceListener(event: "Runtime.inspectRequested", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine parses script. This event is also fired for all known and uncollected scripts upon enabling debugger. + */ + prependOnceListener(event: "Debugger.scriptParsed", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when virtual machine fails to parse the script. + */ + prependOnceListener(event: "Debugger.scriptFailedToParse", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when breakpoint is resolved to an actual script and location. + */ + prependOnceListener(event: "Debugger.breakpointResolved", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + */ + prependOnceListener(event: "Debugger.paused", listener: (message: InspectorNotification) => void): this; + + /** + * Fired when the virtual machine resumed execution. + */ + prependOnceListener(event: "Debugger.resumed", listener: () => void): this; + + /** + * Issued when new console message is added. + */ + prependOnceListener(event: "Console.messageAdded", listener: (message: InspectorNotification) => void): this; + + /** + * Sent when new profile recording is started using console.profile() call. + */ + prependOnceListener(event: "Profiler.consoleProfileStarted", listener: (message: InspectorNotification) => void): this; + + prependOnceListener(event: "Profiler.consoleProfileFinished", listener: (message: InspectorNotification) => void): this; + prependOnceListener(event: "HeapProfiler.addHeapSnapshotChunk", listener: (message: InspectorNotification) => void): this; + prependOnceListener(event: "HeapProfiler.resetProfiles", listener: () => void): this; + prependOnceListener(event: "HeapProfiler.reportHeapSnapshotProgress", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + */ + prependOnceListener(event: "HeapProfiler.lastSeenObjectId", listener: (message: InspectorNotification) => void): this; + + /** + * If heap objects tracking has been started then backend may send update for one or more fragments + */ + prependOnceListener(event: "HeapProfiler.heapStatsUpdate", listener: (message: InspectorNotification) => void): this; + } + + // Top Level API + + /** + * Activate inspector on host and port. Equivalent to node --inspect=[[host:]port], but can be done programatically after node has started. + * If wait is true, will block until a client has connected to the inspect port and flow control has been passed to the debugger client. + * @param port Port to listen on for inspector connections. Optional, defaults to what was specified on the CLI. + * @param host Host to listen on for inspector connections. Optional, defaults to what was specified on the CLI. + * @param wait Block until a client has connected. Optional, defaults to false. + */ + export function open(port?: number, host?: string, wait?: boolean): void; + + /** + * Deactivate the inspector. Blocks until there are no active connections. + */ + export function close(): void; + + /** + * Return the URL of the active inspector, or undefined if there is none. + */ + export function url(): string; +} diff --git a/node_modules/protobufjs/node_modules/@types/node/package.json b/node_modules/protobufjs/node_modules/@types/node/package.json new file mode 100644 index 0000000..5a55dcd --- /dev/null +++ b/node_modules/protobufjs/node_modules/@types/node/package.json @@ -0,0 +1,155 @@ +{ + "_from": "@types/node@^10.1.0", + "_id": "@types/node@10.5.7", + "_inBundle": false, + "_integrity": "sha512-VkKcfuitP+Nc/TaTFH0B8qNmn+6NbI6crLkQonbedViVz7O2w8QV/GERPlkJ4bg42VGHiEWa31CoTOPs1q6z1w==", + "_location": "/protobufjs/@types/node", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "@types/node@^10.1.0", + "name": "@types/node", + "escapedName": "@types%2fnode", + "scope": "@types", + "rawSpec": "^10.1.0", + "saveSpec": null, + "fetchSpec": "^10.1.0" + }, + "_requiredBy": [ + "/protobufjs" + ], + "_resolved": "https://registry.npmjs.org/@types/node/-/node-10.5.7.tgz", + "_shasum": "960d9feb3ade2233bcc9843c918d740b4f78a7cf", + "_spec": "@types/node@^10.1.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\protobufjs", + "bugs": { + "url": "https://github.com/DefinitelyTyped/DefinitelyTyped/issues" + }, + "bundleDependencies": false, + "contributors": [ + { + "name": "Microsoft TypeScript", + "url": "http://typescriptlang.org" + }, + { + "name": "DefinitelyTyped", + "url": "https://github.com/DefinitelyTyped/DefinitelyTyped" + }, + { + "name": "Parambir Singh", + "url": "https://github.com/parambirs" + }, + { + "name": "Christian Vaagland Tellnes", + "url": "https://github.com/tellnes" + }, + { + "name": "Wilco Bakker", + "url": "https://github.com/WilcoBakker" + }, + { + "name": "Nicolas Voigt", + "url": "https://github.com/octo-sniffle" + }, + { + "name": "Chigozirim C.", + "url": "https://github.com/smac89" + }, + { + "name": "Flarna", + "url": "https://github.com/Flarna" + }, + { + "name": "Mariusz Wiktorczyk", + "url": "https://github.com/mwiktorczyk" + }, + { + "name": "wwwy3y3", + "url": "https://github.com/wwwy3y3" + }, + { + "name": "Deividas Bakanas", + "url": "https://github.com/DeividasBakanas" + }, + { + "name": "Kelvin Jin", + "url": "https://github.com/kjin" + }, + { + "name": "Alvis HT Tang", + "url": "https://github.com/alvis" + }, + { + "name": "Sebastian Silbermann", + "url": "https://github.com/eps1lon" + }, + { + "name": "Hannes Magnusson", + "url": "https://github.com/Hannes-Magnusson-CK" + }, + { + "name": "Alberto Schiabel", + "url": "https://github.com/jkomyno" + }, + { + "name": "Klaus Meinhardt", + "url": "https://github.com/ajafff" + }, + { + "name": "Huw", + "url": "https://github.com/hoo29" + }, + { + "name": "Nicolas Even", + "url": "https://github.com/n-e" + }, + { + "name": "Bruno Scheufler", + "url": "https://github.com/brunoscheufler" + }, + { + "name": "Mohsen Azimi", + "url": "https://github.com/mohsen1" + }, + { + "name": "Hoàng Văn Khải", + "url": "https://github.com/KSXGitHub" + }, + { + "name": "Alexander T.", + "url": "https://github.com/a-tarasyuk" + }, + { + "name": "Lishude", + "url": "https://github.com/islishude" + }, + { + "name": "Andrew Makarov", + "url": "https://github.com/r3nya" + }, + { + "name": "Zane Hannan AU", + "url": "https://github.com/ZaneHannanAU" + }, + { + "name": "Eugene Y. Q. Shen", + "url": "https://github.com/eyqs" + } + ], + "dependencies": {}, + "deprecated": false, + "description": "TypeScript definitions for Node.js", + "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped#readme", + "license": "MIT", + "main": "", + "name": "@types/node", + "repository": { + "type": "git", + "url": "git+https://github.com/DefinitelyTyped/DefinitelyTyped.git" + }, + "scripts": {}, + "typeScriptVersion": "2.0", + "typesPublisherContentHash": "ff6a9da38f7afe6c2a421ae121c99dabed96f1aca57674b6f7bf87b20f8dc62b", + "version": "10.5.7" +} diff --git a/node_modules/protobufjs/package-lock.json b/node_modules/protobufjs/package-lock.json new file mode 100644 index 0000000..c685e3e --- /dev/null +++ b/node_modules/protobufjs/package-lock.json @@ -0,0 +1,7307 @@ +{ + "name": "protobufjs", + "version": "6.8.7", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@gulp-sourcemaps/identity-map": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@gulp-sourcemaps/identity-map/-/identity-map-1.0.1.tgz", + "integrity": "sha1-z6I7xYQPkQTOMqZedNt+epdLvuE=", + "dev": true, + "requires": { + "acorn": "^5.0.3", + "css": "^2.2.1", + "normalize-path": "^2.1.1", + "source-map": "^0.5.6", + "through2": "^2.0.3" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + } + } + }, + "@gulp-sourcemaps/map-sources": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@gulp-sourcemaps/map-sources/-/map-sources-1.0.0.tgz", + "integrity": "sha1-iQrnxdjId/bThIYCFazp1+yUW9o=", + "dev": true, + "requires": { + "normalize-path": "^2.0.1", + "through2": "^2.0.3" + } + }, + "@protobufjs/aspromise": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", + "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" + }, + "@protobufjs/base64": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", + "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" + }, + "@protobufjs/codegen": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", + "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" + }, + "@protobufjs/eventemitter": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", + "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" + }, + "@protobufjs/fetch": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", + "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", + "requires": { + "@protobufjs/aspromise": "^1.1.1", + "@protobufjs/inquire": "^1.1.0" + } + }, + "@protobufjs/float": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", + "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" + }, + "@protobufjs/inquire": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", + "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" + }, + "@protobufjs/path": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", + "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" + }, + "@protobufjs/pool": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", + "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" + }, + "@protobufjs/utf8": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", + "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" + }, + "@types/long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.0.tgz", + "integrity": "sha512-1w52Nyx4Gq47uuu0EVcsHBxZFJgurQ+rTKS3qMHxR1GY2T8c2AJYd6vZoZ9q1rupaDjU0yT+Jc2XTyXkjeMA+Q==" + }, + "@types/node": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.1.0.tgz", + "integrity": "sha512-sELcX/cJHwRp8kn4hYSvBxKGJ+ubl3MvS8VJQe5gz/sp7CifYxsiCxIJ35wMIYyGVMgfO2AzRa8UcVReAcJRlw==" + }, + "JSONStream": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.2.tgz", + "integrity": "sha1-wQI3G27Dp887hHygDCC7D85Mbeo=", + "dev": true, + "requires": { + "jsonparse": "^1.2.0", + "through": ">=2.2.7 <3" + } + }, + "abbrev": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", + "integrity": "sha1-kbR5JYinc4wl813W9jdSovh3YTU=", + "dev": true + }, + "acorn": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", + "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=", + "dev": true + }, + "acorn-jsx": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", + "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", + "dev": true, + "requires": { + "acorn": "^3.0.4" + }, + "dependencies": { + "acorn": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", + "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", + "dev": true + } + } + }, + "acorn-node": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.3.0.tgz", + "integrity": "sha512-efP54n3d1aLfjL2UMdaXa6DsswwzJeI5rqhbFvXMrKiJ6eJFpf+7R0zN7t8IC+XKn2YOAFAv6xbBNgHUkoHWLw==", + "dev": true, + "requires": { + "acorn": "^5.4.1", + "xtend": "^4.0.1" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + } + } + }, + "ajv": { + "version": "5.5.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", + "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", + "dev": true, + "requires": { + "co": "^4.6.0", + "fast-deep-equal": "^1.0.0", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.3.0" + } + }, + "ajv-keywords": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-2.1.1.tgz", + "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", + "dev": true + }, + "align-text": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", + "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", + "dev": true, + "requires": { + "kind-of": "^3.0.2", + "longest": "^1.0.1", + "repeat-string": "^1.5.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "amdefine": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", + "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", + "dev": true + }, + "ansi-colors": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-1.1.0.tgz", + "integrity": "sha512-SFKX67auSNoVR38N3L+nvsPjOE0bybKTYbkf5tRvushrAPQ9V75huw0ZxBkKVeRU9kqH3d6HA4xTckbwZ4ixmA==", + "dev": true, + "requires": { + "ansi-wrap": "^0.1.0" + } + }, + "ansi-escapes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", + "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", + "dev": true + }, + "ansi-gray": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/ansi-gray/-/ansi-gray-0.1.1.tgz", + "integrity": "sha1-KWLPVOyXksSFEKPetSRDaGHvclE=", + "dev": true, + "requires": { + "ansi-wrap": "0.1.0" + } + }, + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "ansi-wrap": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/ansi-wrap/-/ansi-wrap-0.1.0.tgz", + "integrity": "sha1-qCJQ3bABXponyoLoLqYDu/pF768=", + "dev": true + }, + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + } + }, + "append-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/append-buffer/-/append-buffer-1.0.2.tgz", + "integrity": "sha1-2CIM9GYIFSXv6lBhTz3mUU36WPE=", + "dev": true, + "requires": { + "buffer-equal": "^1.0.0" + } + }, + "archy": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", + "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", + "dev": true + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true + }, + "arr-filter": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/arr-filter/-/arr-filter-1.1.2.tgz", + "integrity": "sha1-Q/3d0JHo7xGqTEXZzcGOLf8XEe4=", + "dev": true, + "requires": { + "make-iterator": "^1.0.0" + } + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true + }, + "arr-map": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/arr-map/-/arr-map-2.0.2.tgz", + "integrity": "sha1-Onc0X/wc814qkYJWAfnljy4kysQ=", + "dev": true, + "requires": { + "make-iterator": "^1.0.0" + } + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true + }, + "array-each": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", + "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=", + "dev": true + }, + "array-filter": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz", + "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=", + "dev": true + }, + "array-find-index": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", + "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=", + "dev": true + }, + "array-initial": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/array-initial/-/array-initial-1.1.0.tgz", + "integrity": "sha1-L6dLJnOTccOUe9enrcc74zSz15U=", + "dev": true, + "requires": { + "array-slice": "^1.0.0", + "is-number": "^4.0.0" + }, + "dependencies": { + "is-number": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", + "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", + "dev": true + } + } + }, + "array-last": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/array-last/-/array-last-1.3.0.tgz", + "integrity": "sha512-eOCut5rXlI6aCOS7Z7kCplKRKyiFQ6dHFBem4PwlwKeNFk2/XxTrhRh5T9PyaEWGy/NHTZWbY+nsZlNFJu9rYg==", + "dev": true, + "requires": { + "is-number": "^4.0.0" + }, + "dependencies": { + "is-number": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", + "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", + "dev": true + } + } + }, + "array-map": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz", + "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=", + "dev": true + }, + "array-reduce": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz", + "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=", + "dev": true + }, + "array-slice": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-1.1.0.tgz", + "integrity": "sha512-B1qMD3RBP7O8o0H2KbrXDyB0IccejMF15+87Lvlor12ONPRHP6gTjXMNkt/d3ZuOGbAe66hFmaCfECI24Ufp6w==", + "dev": true + }, + "array-sort": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-sort/-/array-sort-1.0.0.tgz", + "integrity": "sha512-ihLeJkonmdiAsD7vpgN3CRcx2J2S0TiYW+IS/5zHBI7mKUq3ySvBdzzBfD236ubDBQFiiyG3SWCPc+msQ9KoYg==", + "dev": true, + "requires": { + "default-compare": "^1.0.0", + "get-value": "^2.0.6", + "kind-of": "^5.0.2" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "dev": true, + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", + "dev": true + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", + "dev": true + }, + "asn1.js": { + "version": "4.10.1", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.10.1.tgz", + "integrity": "sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw==", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "assert": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", + "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "dev": true, + "requires": { + "util": "0.10.3" + } + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true + }, + "astw": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/astw/-/astw-2.2.0.tgz", + "integrity": "sha1-e9QXhNMkk5h66yOba04cV6hzuRc=", + "dev": true, + "requires": { + "acorn": "^4.0.3" + } + }, + "async": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", + "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", + "dev": true + }, + "async-done": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/async-done/-/async-done-1.3.1.tgz", + "integrity": "sha512-R1BaUeJ4PMoLNJuk+0tLJgjmEqVsdN118+Z8O+alhnQDQgy0kmD5Mqi0DNEmMx2LM0Ed5yekKu+ZXYvIHceicg==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.2", + "process-nextick-args": "^1.0.7", + "stream-exhaust": "^1.0.1" + }, + "dependencies": { + "process-nextick-args": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", + "dev": true + } + } + }, + "async-each": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", + "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", + "dev": true + }, + "async-settle": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/async-settle/-/async-settle-1.0.0.tgz", + "integrity": "sha1-HQqRS7Aldb7IqPOnTlCA9yssDGs=", + "dev": true, + "requires": { + "async-done": "^1.2.2" + } + }, + "atob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.1.tgz", + "integrity": "sha1-ri1acpR38onWDdf5amMUoi3Wwio=", + "dev": true + }, + "babel-code-frame": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", + "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", + "dev": true, + "requires": { + "chalk": "^1.1.3", + "esutils": "^2.0.2", + "js-tokens": "^3.0.2" + }, + "dependencies": { + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", + "dev": true + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "dev": true, + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", + "dev": true + } + } + }, + "babylon": { + "version": "7.0.0-beta.19", + "resolved": "https://registry.npmjs.org/babylon/-/babylon-7.0.0-beta.19.tgz", + "integrity": "sha512-Vg0C9s/REX6/WIXN37UKpv5ZhRi6A4pjHlpkE34+8/a6c2W1Q692n3hmc+SZG5lKRnaExLUbxtJ1SVT+KaCQ/A==", + "dev": true + }, + "bach": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/bach/-/bach-1.2.0.tgz", + "integrity": "sha1-Szzpa/JxNPeaG0FKUcFONMO9mIA=", + "dev": true, + "requires": { + "arr-filter": "^1.1.1", + "arr-flatten": "^1.0.1", + "arr-map": "^2.0.0", + "array-each": "^1.0.0", + "array-initial": "^1.0.0", + "array-last": "^1.1.1", + "async-done": "^1.2.2", + "async-settle": "^1.0.0", + "now-and-later": "^2.0.0" + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "base64-js": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.0.tgz", + "integrity": "sha512-ccav/yGvoa80BQDljCxsmmQ3Xvx60/UpBIij5QN21W3wBi/hhIC9OoO+KLpu9IJTS9j4DRVJ3aDDF9cMSoa2lw==", + "dev": true + }, + "base64url": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", + "integrity": "sha1-6sFuA+oUOO/5Qj1puqNiYu0fcLs=", + "dev": true + }, + "benchmark": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/benchmark/-/benchmark-2.1.4.tgz", + "integrity": "sha1-CfPeMckWQl1JjMLuVloOvzwqVik=", + "dev": true, + "requires": { + "lodash": "^4.17.4", + "platform": "^1.3.3" + } + }, + "binary-extensions": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", + "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=", + "dev": true + }, + "bl": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/bl/-/bl-1.2.2.tgz", + "integrity": "sha512-e8tQYnZodmebYDWGH7KMRvtzKXaJHx3BbilrgZCfvyLUYdKpK1t5PSPmpkny/SgiTSCnjfLW7v5rlONXVFkQEA==", + "dev": true, + "requires": { + "readable-stream": "^2.3.5", + "safe-buffer": "^5.1.1" + } + }, + "bluebird": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", + "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==", + "dev": true + }, + "bn.js": { + "version": "4.11.8", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", + "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=", + "dev": true + }, + "browser-pack": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-6.1.0.tgz", + "integrity": "sha512-erYug8XoqzU3IfcU8fUgyHqyOXqIE4tUTTQ+7mqUjQlvnXkOO6OlT9c/ZoJVHYoAaqGxr09CN53G7XIsO4KtWA==", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "combine-source-map": "~0.8.0", + "defined": "^1.0.0", + "safe-buffer": "^5.1.1", + "through2": "^2.0.0", + "umd": "^3.0.0" + } + }, + "browser-resolve": { + "version": "1.11.2", + "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz", + "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=", + "dev": true, + "requires": { + "resolve": "1.1.7" + }, + "dependencies": { + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", + "dev": true + } + } + }, + "browser-unpack": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browser-unpack/-/browser-unpack-1.2.0.tgz", + "integrity": "sha1-NXruMfxGeDFoTQY+Q1XgcKeClw0=", + "dev": true, + "requires": { + "acorn": "^4.0.3", + "browser-pack": "^5.0.1", + "concat-stream": "^1.5.0", + "minimist": "^1.1.1" + }, + "dependencies": { + "browser-pack": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-5.0.1.tgz", + "integrity": "sha1-QZdxmyDG4KqglFHFER5T77b7wY0=", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "combine-source-map": "~0.6.1", + "defined": "^1.0.0", + "through2": "^1.0.0", + "umd": "^3.0.0" + } + }, + "combine-source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.6.1.tgz", + "integrity": "sha1-m0oJwxYDPXaODxHgKfonMOB5rZY=", + "dev": true, + "requires": { + "convert-source-map": "~1.1.0", + "inline-source-map": "~0.5.0", + "lodash.memoize": "~3.0.3", + "source-map": "~0.4.2" + } + }, + "inline-source-map": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.5.0.tgz", + "integrity": "sha1-Skxd2OT7Xps82mDIIt+tyu5m4K8=", + "dev": true, + "requires": { + "source-map": "~0.4.0" + } + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true + }, + "readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "0.0.1", + "string_decoder": "~0.10.x" + } + }, + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, + "requires": { + "amdefine": ">=0.0.4" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + }, + "through2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/through2/-/through2-1.1.1.tgz", + "integrity": "sha1-CEfLxESfNAVXTb3M2buEG4OsNUU=", + "dev": true, + "requires": { + "readable-stream": ">=1.1.13-1 <1.2.0-0", + "xtend": ">=4.0.0 <4.1.0-0" + } + } + } + }, + "browserify": { + "version": "16.2.2", + "resolved": "https://registry.npmjs.org/browserify/-/browserify-16.2.2.tgz", + "integrity": "sha512-fMES05wq1Oukts6ksGUU2TMVHHp06LyQt0SIwbXIHm7waSrQmNBZePsU0iM/4f94zbvb/wHma+D1YrdzWYnF/A==", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "assert": "^1.4.0", + "browser-pack": "^6.0.1", + "browser-resolve": "^1.11.0", + "browserify-zlib": "~0.2.0", + "buffer": "^5.0.2", + "cached-path-relative": "^1.0.0", + "concat-stream": "^1.6.0", + "console-browserify": "^1.1.0", + "constants-browserify": "~1.0.0", + "crypto-browserify": "^3.0.0", + "defined": "^1.0.0", + "deps-sort": "^2.0.0", + "domain-browser": "^1.2.0", + "duplexer2": "~0.1.2", + "events": "^2.0.0", + "glob": "^7.1.0", + "has": "^1.0.0", + "htmlescape": "^1.1.0", + "https-browserify": "^1.0.0", + "inherits": "~2.0.1", + "insert-module-globals": "^7.0.0", + "labeled-stream-splicer": "^2.0.0", + "mkdirp": "^0.5.0", + "module-deps": "^6.0.0", + "os-browserify": "~0.3.0", + "parents": "^1.0.1", + "path-browserify": "~0.0.0", + "process": "~0.11.0", + "punycode": "^1.3.2", + "querystring-es3": "~0.2.0", + "read-only-stream": "^2.0.0", + "readable-stream": "^2.0.2", + "resolve": "^1.1.4", + "shasum": "^1.0.0", + "shell-quote": "^1.6.1", + "stream-browserify": "^2.0.0", + "stream-http": "^2.0.0", + "string_decoder": "^1.1.1", + "subarg": "^1.0.0", + "syntax-error": "^1.1.1", + "through2": "^2.0.0", + "timers-browserify": "^1.0.1", + "tty-browserify": "0.0.1", + "url": "~0.11.0", + "util": "~0.10.1", + "vm-browserify": "^1.0.0", + "xtend": "^4.0.0" + }, + "dependencies": { + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + } + } + }, + "browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", + "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", + "dev": true, + "requires": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", + "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", + "dev": true, + "requires": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "browserify-des": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.1.tgz", + "integrity": "sha512-zy0Cobe3hhgpiOM32Tj7KQ3Vl91m0njwsjzZQK1L+JDf11dzP9qIvjreVinsvXrgfjhStXwUWAEpB9D7Gwmayw==", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1" + } + }, + "browserify-rsa": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", + "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "randombytes": "^2.0.1" + } + }, + "browserify-sign": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz", + "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", + "dev": true, + "requires": { + "bn.js": "^4.1.1", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.2", + "elliptic": "^6.0.0", + "inherits": "^2.0.1", + "parse-asn1": "^5.0.0" + } + }, + "browserify-wrap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/browserify-wrap/-/browserify-wrap-1.0.2.tgz", + "integrity": "sha1-DvJ3xnxplAkVnt8hraPchQF/lqo=", + "dev": true + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "dev": true, + "requires": { + "pako": "~1.0.5" + } + }, + "buffer": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.1.0.tgz", + "integrity": "sha512-YkIRgwsZwJWTnyQrsBTWefizHh+8GYj3kbL1BTiAQ/9pwpino0G7B2gp5tx/FUBqUlvtxV85KNR3mwfAtv15Yw==", + "dev": true, + "requires": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4" + } + }, + "buffer-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-1.0.0.tgz", + "integrity": "sha1-WWFrSYME1Var1GaWayLu2j7KX74=", + "dev": true + }, + "buffer-from": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.0.0.tgz", + "integrity": "sha512-83apNb8KK0Se60UE1+4Ukbe3HbfELJ6UlI4ldtOGs7So4KD26orJM8hIY9lxdzP+UpItH1Yh/Y8GUvNFWFFRxA==", + "dev": true + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", + "dev": true + }, + "builtin-modules": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", + "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", + "dev": true + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=", + "dev": true + }, + "bundle-collapser": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/bundle-collapser/-/bundle-collapser-1.3.0.tgz", + "integrity": "sha1-9LT/WLLyLudwGyD6djBuI/U6P7Y=", + "dev": true, + "requires": { + "browser-pack": "^5.0.1", + "browser-unpack": "^1.1.0", + "concat-stream": "^1.5.0", + "falafel": "^2.1.0", + "minimist": "^1.1.1", + "through2": "^2.0.0" + }, + "dependencies": { + "browser-pack": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-5.0.1.tgz", + "integrity": "sha1-QZdxmyDG4KqglFHFER5T77b7wY0=", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "combine-source-map": "~0.6.1", + "defined": "^1.0.0", + "through2": "^1.0.0", + "umd": "^3.0.0" + }, + "dependencies": { + "through2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/through2/-/through2-1.1.1.tgz", + "integrity": "sha1-CEfLxESfNAVXTb3M2buEG4OsNUU=", + "dev": true, + "requires": { + "readable-stream": ">=1.1.13-1 <1.2.0-0", + "xtend": ">=4.0.0 <4.1.0-0" + } + } + } + }, + "combine-source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.6.1.tgz", + "integrity": "sha1-m0oJwxYDPXaODxHgKfonMOB5rZY=", + "dev": true, + "requires": { + "convert-source-map": "~1.1.0", + "inline-source-map": "~0.5.0", + "lodash.memoize": "~3.0.3", + "source-map": "~0.4.2" + } + }, + "inline-source-map": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.5.0.tgz", + "integrity": "sha1-Skxd2OT7Xps82mDIIt+tyu5m4K8=", + "dev": true, + "requires": { + "source-map": "~0.4.0" + } + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true + }, + "readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "0.0.1", + "string_decoder": "~0.10.x" + } + }, + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, + "requires": { + "amdefine": ">=0.0.4" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + } + } + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "cached-path-relative": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cached-path-relative/-/cached-path-relative-1.0.1.tgz", + "integrity": "sha1-0JxLUoAKpMB44t2BqGmqyQ0uVOc=", + "dev": true + }, + "caller-path": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", + "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", + "dev": true, + "requires": { + "callsites": "^0.2.0" + } + }, + "callsites": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", + "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", + "dev": true + }, + "camelcase": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", + "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "dev": true + }, + "camelcase-keys": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-4.2.0.tgz", + "integrity": "sha1-oqpfsa9oh1glnDLBQUJteJI7m3c=", + "dev": true, + "requires": { + "camelcase": "^4.1.0", + "map-obj": "^2.0.0", + "quick-lru": "^1.0.0" + } + }, + "catharsis": { + "version": "0.8.9", + "resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.8.9.tgz", + "integrity": "sha1-mMyJDKZS3S7w5ws3klMQ/56Q/Is=", + "dev": true, + "requires": { + "underscore-contrib": "~0.3.0" + } + }, + "center-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", + "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", + "dev": true, + "optional": true, + "requires": { + "align-text": "^0.1.3", + "lazy-cache": "^1.0.3" + } + }, + "chalk": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", + "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "chardet": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", + "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", + "dev": true + }, + "chokidar": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.3.tgz", + "integrity": "sha512-zW8iXYZtXMx4kux/nuZVXjkLP+CyIK5Al5FHnj1OgTKGZfp4Oy6/ymtMSKFv3GD8DviEmUPmJg9eFdJ/JzudMg==", + "dev": true, + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.0", + "braces": "^2.3.0", + "fsevents": "^1.1.2", + "glob-parent": "^3.1.0", + "inherits": "^2.0.1", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^2.1.1", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.0.0", + "upath": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", + "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + } + } + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "circular-json": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", + "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", + "dev": true + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", + "dev": true + }, + "cliui": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", + "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", + "dev": true, + "optional": true, + "requires": { + "center-align": "^0.1.1", + "right-align": "^0.1.1", + "wordwrap": "0.0.2" + }, + "dependencies": { + "wordwrap": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", + "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=", + "dev": true, + "optional": true + } + } + }, + "clone-buffer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/clone-buffer/-/clone-buffer-1.0.0.tgz", + "integrity": "sha1-4+JbIHrE5wGvch4staFnksrD3Fg=", + "dev": true + }, + "cloneable-readable": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/cloneable-readable/-/cloneable-readable-1.1.2.tgz", + "integrity": "sha512-Bq6+4t+lbM8vhTs/Bef5c5AdEMtapp/iFb6+s4/Hh9MVTt8OLKH7ZOOZSCT+Ys7hsHvqv0GuMPJ1lnQJVHvxpg==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "process-nextick-args": "^2.0.0", + "readable-stream": "^2.3.5" + } + }, + "co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "dev": true + }, + "collection-map": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-map/-/collection-map-1.0.0.tgz", + "integrity": "sha1-rqDwb40mx4DCt1SUOFVEsiVa8Yw=", + "dev": true, + "requires": { + "arr-map": "^2.0.2", + "for-own": "^1.0.0", + "make-iterator": "^1.0.0" + } + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color-convert": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.1.tgz", + "integrity": "sha512-mjGanIiwQJskCC18rPR6OmrZ6fm2Lc7PeGFYwCmy5J34wC6F1PzdGL6xeMfmgicfYcNLGuVFA3WzXtIDCQSZxQ==", + "dev": true, + "requires": { + "color-name": "^1.1.1" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "color-support": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", + "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", + "dev": true + }, + "combine-source-map": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.8.0.tgz", + "integrity": "sha1-pY0N8ELBhvz4IqjoAV9UUNLXmos=", + "dev": true, + "requires": { + "convert-source-map": "~1.1.0", + "inline-source-map": "~0.6.0", + "lodash.memoize": "~3.0.3", + "source-map": "~0.5.3" + } + }, + "component-emitter": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", + "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "concat-stream": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.5.2.tgz", + "integrity": "sha1-cIl4Yk2FavQaWnQd790mHadSwmY=", + "dev": true, + "requires": { + "inherits": "~2.0.1", + "readable-stream": "~2.0.0", + "typedarray": "~0.0.5" + }, + "dependencies": { + "process-nextick-args": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", + "dev": true + }, + "readable-stream": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.0.6.tgz", + "integrity": "sha1-j5A0HmilPMySh4jaz80Rs265t44=", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "~1.0.0", + "process-nextick-args": "~1.0.6", + "string_decoder": "~0.10.x", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + } + } + }, + "concat-with-sourcemaps": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/concat-with-sourcemaps/-/concat-with-sourcemaps-1.1.0.tgz", + "integrity": "sha512-4gEjHJFT9e+2W/77h/DS5SGUgwDaOwprX8L/gl5+3ixnzkVJJsZWDSelmN3Oilw3LNDZjZV0yqH1hLG3k6nghg==", + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "console-browserify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", + "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "dev": true, + "requires": { + "date-now": "^0.1.4" + } + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", + "dev": true + }, + "convert-source-map": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.1.3.tgz", + "integrity": "sha1-SCnId+n+SbMWHzvzZziI4gRpmGA=", + "dev": true + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true + }, + "copy-props": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/copy-props/-/copy-props-2.0.4.tgz", + "integrity": "sha512-7cjuUME+p+S3HZlbllgsn2CDwS+5eCCX16qBgNC4jgSTf49qR1VKy/Zhl400m0IQXl/bPGEVqncgUUMjrr4s8A==", + "dev": true, + "requires": { + "each-props": "^1.3.0", + "is-plain-object": "^2.0.1" + } + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true + }, + "create-ecdh": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz", + "integrity": "sha512-GbEHQPMOswGpKXM9kCWVrremUcBmjteUaQ01T9rkKCPDXfUHX0IoP9LpHYo2NPFampa4e+/pFDc3jQdxrxQLaw==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "elliptic": "^6.0.0" + } + }, + "create-hash": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", + "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", + "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", + "dev": true, + "requires": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "dev": true, + "requires": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + } + }, + "css": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/css/-/css-2.2.3.tgz", + "integrity": "sha512-0W171WccAjQGGTKLhw4m2nnl0zPHUlTO/I8td4XzJgIB8Hg3ZZx71qT4G4eX8OVsSiaAKiUMy73E3nsbPlg2DQ==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "source-map": "^0.1.38", + "source-map-resolve": "^0.5.1", + "urix": "^0.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.1.43", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", + "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", + "dev": true, + "requires": { + "amdefine": ">=0.0.4" + } + } + } + }, + "currently-unhandled": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", + "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", + "dev": true, + "requires": { + "array-find-index": "^1.0.1" + } + }, + "d": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/d/-/d-1.0.0.tgz", + "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", + "dev": true, + "requires": { + "es5-ext": "^0.10.9" + } + }, + "dargs": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/dargs/-/dargs-4.1.0.tgz", + "integrity": "sha1-A6nbtLXC8Tm/FK5T8LiipqhvThc=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "date-now": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", + "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", + "dev": true + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "debug-fabulous": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/debug-fabulous/-/debug-fabulous-1.1.0.tgz", + "integrity": "sha512-GZqvGIgKNlUnHUPQhepnUZFIMoi3dgZKQBzKDeL2g7oJF9SNAji/AAu36dusFUas0O+pae74lNeoIPHqXWDkLg==", + "dev": true, + "requires": { + "debug": "3.X", + "memoizee": "0.4.X", + "object-assign": "4.X" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "decamelize-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.0.tgz", + "integrity": "sha1-0XGoeTMlKAfrPLYdwcFEXQeN8tk=", + "dev": true, + "requires": { + "decamelize": "^1.1.0", + "map-obj": "^1.0.0" + }, + "dependencies": { + "map-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", + "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=", + "dev": true + } + } + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "dev": true + }, + "deep-equal": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", + "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU=", + "dev": true + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", + "dev": true + }, + "default-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/default-compare/-/default-compare-1.0.0.tgz", + "integrity": "sha512-QWfXlM0EkAbqOCbD/6HjdwT19j7WCkMyiRhWilc4H9/5h/RzTF9gv5LYh1+CmDV5d1rki6KAWLtQale0xt20eQ==", + "dev": true, + "requires": { + "kind-of": "^5.0.2" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "default-resolution": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/default-resolution/-/default-resolution-2.0.0.tgz", + "integrity": "sha1-vLgrqnKtebQmp2cy8aga1t8m1oQ=", + "dev": true + }, + "define-properties": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", + "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", + "dev": true, + "requires": { + "foreach": "^2.0.5", + "object-keys": "^1.0.8" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "defined": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", + "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", + "dev": true + }, + "del": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", + "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", + "dev": true, + "requires": { + "globby": "^5.0.0", + "is-path-cwd": "^1.0.0", + "is-path-in-cwd": "^1.0.0", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0", + "rimraf": "^2.2.8" + } + }, + "deps-sort": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/deps-sort/-/deps-sort-2.0.0.tgz", + "integrity": "sha1-CRckkC6EZYJg65EHSMzNGvbiH7U=", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "shasum": "^1.0.0", + "subarg": "^1.0.0", + "through2": "^2.0.0" + } + }, + "des.js": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.0.tgz", + "integrity": "sha1-wHTS4qpqipoH29YfmhXCzYPsjsw=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "detect-file": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", + "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=", + "dev": true + }, + "detect-newline": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-2.1.0.tgz", + "integrity": "sha1-9B8cEL5LAOh7XxPaaAdZ8sW/0+I=", + "dev": true + }, + "detective": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/detective/-/detective-5.1.0.tgz", + "integrity": "sha512-TFHMqfOvxlgrfVzTEkNBSh9SvSNX/HfF4OFI2QFGCyPm02EsyILqnUeb5P6q7JZ3SFNTBL5t2sePRgrN4epUWQ==", + "dev": true, + "requires": { + "acorn-node": "^1.3.0", + "defined": "^1.0.0", + "minimist": "^1.1.1" + } + }, + "diff": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", + "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", + "dev": true + }, + "diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", + "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + } + }, + "doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", + "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==", + "dev": true + }, + "duplexer2": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", + "integrity": "sha1-ixLauHjA1p4+eJEFFmKjL8a93ME=", + "dev": true, + "requires": { + "readable-stream": "^2.0.2" + } + }, + "duplexify": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.6.0.tgz", + "integrity": "sha512-fO3Di4tBKJpYTFHAxTU00BcfWMY9w24r/x21a6rZRbsD/ToUgGxsMbiGRmB7uVAXeGKXD9MwiLZa5E97EVgIRQ==", + "dev": true, + "requires": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + }, + "dependencies": { + "end-of-stream": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", + "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", + "dev": true, + "requires": { + "once": "^1.4.0" + } + } + } + }, + "each-props": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/each-props/-/each-props-1.3.2.tgz", + "integrity": "sha512-vV0Hem3zAGkJAyU7JSjixeU66rwdynTAa1vofCrSA5fEln+m67Az9CcnkVD776/fsN/UjIWmBDoNRS6t6G9RfA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.1", + "object.defaults": "^1.1.0" + } + }, + "elliptic": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.0.tgz", + "integrity": "sha1-ysmvh2LIWDYYcAPI3+GT5eLq5d8=", + "dev": true, + "requires": { + "bn.js": "^4.4.0", + "brorand": "^1.0.1", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.0" + } + }, + "end-of-stream": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", + "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", + "dev": true, + "requires": { + "once": "^1.4.0" + } + }, + "error-ex": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", + "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.11.0.tgz", + "integrity": "sha512-ZnQrE/lXTTQ39ulXZ+J1DTFazV9qBy61x2bY071B+qGco8Z8q1QddsLdt/EF8Ai9hcWH72dWS0kFqXLxOxqslA==", + "dev": true, + "requires": { + "es-to-primitive": "^1.1.1", + "function-bind": "^1.1.1", + "has": "^1.0.1", + "is-callable": "^1.1.3", + "is-regex": "^1.0.4" + } + }, + "es-to-primitive": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz", + "integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=", + "dev": true, + "requires": { + "is-callable": "^1.1.1", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.1" + } + }, + "es5-ext": { + "version": "0.10.42", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.42.tgz", + "integrity": "sha512-AJxO1rmPe1bDEfSR6TJ/FgMFYuTBhR5R57KW58iCkYACMyFbrkqVyzXSurYoScDGvgyMpk7uRF/lPUPPTmsRSA==", + "dev": true, + "requires": { + "es6-iterator": "~2.0.3", + "es6-symbol": "~3.1.1", + "next-tick": "1" + } + }, + "es6-iterator": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", + "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", + "dev": true, + "requires": { + "d": "1", + "es5-ext": "^0.10.35", + "es6-symbol": "^3.1.1" + } + }, + "es6-symbol": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.1.tgz", + "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", + "dev": true, + "requires": { + "d": "1", + "es5-ext": "~0.10.14" + } + }, + "es6-weak-map": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.2.tgz", + "integrity": "sha1-XjqzIlH/0VOKH45f+hNXdy+S2W8=", + "dev": true, + "requires": { + "d": "1", + "es5-ext": "^0.10.14", + "es6-iterator": "^2.0.1", + "es6-symbol": "^3.1.1" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "escodegen": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.9.1.tgz", + "integrity": "sha512-6hTjO1NAWkHnDk3OqQ4YrCuwwmGHL9S3nPlzBOUG/R44rda3wLNrfvQ5fkSGjyhHFKM7ALPKcKGrwvCLe0lC7Q==", + "dev": true, + "requires": { + "esprima": "^3.1.3", + "estraverse": "^4.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true + } + } + }, + "eslint": { + "version": "4.19.1", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-4.19.1.tgz", + "integrity": "sha512-bT3/1x1EbZB7phzYu7vCr1v3ONuzDtX8WjuM9c0iYxe+cq+pwcKEoQjl7zd3RpC6YOLgnSy3cTN58M2jcoPDIQ==", + "dev": true, + "requires": { + "ajv": "^5.3.0", + "babel-code-frame": "^6.22.0", + "chalk": "^2.1.0", + "concat-stream": "^1.6.0", + "cross-spawn": "^5.1.0", + "debug": "^3.1.0", + "doctrine": "^2.1.0", + "eslint-scope": "^3.7.1", + "eslint-visitor-keys": "^1.0.0", + "espree": "^3.5.4", + "esquery": "^1.0.0", + "esutils": "^2.0.2", + "file-entry-cache": "^2.0.0", + "functional-red-black-tree": "^1.0.1", + "glob": "^7.1.2", + "globals": "^11.0.1", + "ignore": "^3.3.3", + "imurmurhash": "^0.1.4", + "inquirer": "^3.0.6", + "is-resolvable": "^1.0.0", + "js-yaml": "^3.9.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.3.0", + "lodash": "^4.17.4", + "minimatch": "^3.0.2", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "optionator": "^0.8.2", + "path-is-inside": "^1.0.2", + "pluralize": "^7.0.0", + "progress": "^2.0.0", + "regexpp": "^1.0.1", + "require-uncached": "^1.0.3", + "semver": "^5.3.0", + "strip-ansi": "^4.0.0", + "strip-json-comments": "~2.0.1", + "table": "4.0.2", + "text-table": "~0.2.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "eslint-scope": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", + "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", + "dev": true, + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "eslint-visitor-keys": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", + "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", + "dev": true + }, + "espree": { + "version": "3.5.4", + "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.4.tgz", + "integrity": "sha512-yAcIQxtmMiB/jL32dzEp2enBeidsB7xWPLNiw3IIkpVds1P+h7qF9YwJq1yUNzp2OKXgAprs4F61ih66UsoD1A==", + "dev": true, + "requires": { + "acorn": "^5.5.0", + "acorn-jsx": "^3.0.0" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + } + } + }, + "esprima": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", + "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", + "dev": true + }, + "esquery": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", + "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", + "dev": true, + "requires": { + "estraverse": "^4.0.0" + } + }, + "esrecurse": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", + "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "dev": true, + "requires": { + "estraverse": "^4.1.0" + } + }, + "estraverse": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", + "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", + "dev": true + }, + "esutils": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", + "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", + "dev": true + }, + "event-emitter": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", + "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", + "dev": true, + "requires": { + "d": "1", + "es5-ext": "~0.10.14" + } + }, + "events": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/events/-/events-2.0.0.tgz", + "integrity": "sha512-r/M5YkNg9zwI8QbSf7tsDWWJvO3PGwZXyG7GpFAxtMASnHL2eblFd7iHiGPtyGKKFPZ59S63NeX10Ws6WqGDcg==", + "dev": true + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "dev": true, + "requires": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "expand-tilde": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", + "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", + "dev": true, + "requires": { + "homedir-polyfill": "^1.0.1" + } + }, + "extend": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", + "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", + "dev": true + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.2.0.tgz", + "integrity": "sha512-bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A==", + "dev": true, + "requires": { + "chardet": "^0.4.0", + "iconv-lite": "^0.4.17", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "falafel": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/falafel/-/falafel-2.1.0.tgz", + "integrity": "sha1-lrsXdh2rqU9G0AFzizzt86Z/4Gw=", + "dev": true, + "requires": { + "acorn": "^5.0.0", + "foreach": "^2.0.5", + "isarray": "0.0.1", + "object-keys": "^1.0.6" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true + } + } + }, + "fancy-log": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/fancy-log/-/fancy-log-1.3.2.tgz", + "integrity": "sha1-9BEl49hPLn2JpD0G2VjI94vha+E=", + "dev": true, + "requires": { + "ansi-gray": "^0.1.1", + "color-support": "^1.1.3", + "time-stamp": "^1.0.0" + } + }, + "fast-deep-equal": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", + "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", + "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "file-entry-cache": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", + "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", + "dev": true, + "requires": { + "flat-cache": "^1.2.1", + "object-assign": "^4.0.1" + } + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "findup-sync": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-2.0.0.tgz", + "integrity": "sha1-kyaxSIwi0aYIhlCoaQGy2akKLLw=", + "dev": true, + "requires": { + "detect-file": "^1.0.0", + "is-glob": "^3.1.0", + "micromatch": "^3.0.4", + "resolve-dir": "^1.0.1" + } + }, + "fined": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fined/-/fined-1.1.0.tgz", + "integrity": "sha1-s33IRLdqL15wgeiE98CuNE8VNHY=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.2", + "is-plain-object": "^2.0.3", + "object.defaults": "^1.1.0", + "object.pick": "^1.2.0", + "parse-filepath": "^1.0.1" + } + }, + "flagged-respawn": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.0.tgz", + "integrity": "sha1-Tnmumy6zi/hrO7Vr8+ClaqX8q9c=", + "dev": true + }, + "flat-cache": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", + "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", + "dev": true, + "requires": { + "circular-json": "^0.3.1", + "del": "^2.0.2", + "graceful-fs": "^4.1.2", + "write": "^0.2.1" + } + }, + "flush-write-stream": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.0.3.tgz", + "integrity": "sha512-calZMC10u0FMUqoiunI2AiGIIUtUIvifNwkHhNupZH4cbNnW1Itkoh/Nf5HFYmDrwWPjrUxpkZT0KhuCq0jmGw==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.4" + } + }, + "for-each": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.2.tgz", + "integrity": "sha1-LEBFC5NI6X8oEyJZO6lnBLmr1NQ=", + "dev": true, + "requires": { + "is-function": "~1.0.0" + } + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true + }, + "for-own": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", + "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", + "dev": true, + "requires": { + "for-in": "^1.0.1" + } + }, + "foreach": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", + "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", + "dev": true + }, + "fork-stream": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/fork-stream/-/fork-stream-0.0.4.tgz", + "integrity": "sha1-24Sfznf2cIpfjzhq5TOgkHtUrnA=", + "dev": true + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, + "requires": { + "map-cache": "^0.2.2" + } + }, + "fs-extra": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.3.tgz", + "integrity": "sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-mkdirp-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs-mkdirp-stream/-/fs-mkdirp-stream-1.0.0.tgz", + "integrity": "sha1-C3gV/DIBxqaeFNuYzgmMFpNSWes=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "through2": "^2.0.3" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "fsevents": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", + "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", + "dev": true, + "optional": true, + "requires": { + "nan": "^2.9.2", + "node-pre-gyp": "^0.10.0" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "debug": { + "version": "2.6.9", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ms": "2.0.0" + } + }, + "deep-extend": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "dev": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "^2.2.1" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.21", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safer-buffer": "^2.1.0" + } + }, + "ignore-walk": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "dev": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + }, + "minipass": { + "version": "2.2.4", + "bundled": true, + "dev": true, + "requires": { + "safe-buffer": "^5.1.1", + "yallist": "^3.0.0" + } + }, + "minizlib": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "^2.2.1" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "needle": { + "version": "2.2.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "debug": "^2.1.2", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.10.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.0", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.1.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "npm-bundled": { + "version": "1.0.3", + "bundled": true, + "dev": true, + "optional": true + }, + "npm-packlist": { + "version": "1.1.10", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "rc": { + "version": "1.2.7", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "deep-extend": "^0.5.1", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rimraf": { + "version": "2.6.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "glob": "^7.0.5" + } + }, + "safe-buffer": { + "version": "5.1.1", + "bundled": true, + "dev": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "dev": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "dev": true, + "optional": true + }, + "semver": { + "version": "5.5.0", + "bundled": true, + "dev": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "tar": { + "version": "4.4.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "chownr": "^1.0.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.2.4", + "minizlib": "^1.1.0", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.1", + "yallist": "^3.0.2" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "string-width": "^1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "yallist": { + "version": "3.0.2", + "bundled": true, + "dev": true + } + } + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", + "dev": true + }, + "get-caller-file": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.2.tgz", + "integrity": "sha1-9wLmMSfn4jHBYKgMFVSstw1QR+U=", + "dev": true + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true + }, + "gh-pages": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/gh-pages/-/gh-pages-1.1.0.tgz", + "integrity": "sha512-ZpDkeOVmIrN5mz+sBWDz5zmTqcbNJzI/updCwEv/7rrSdpTNlj1B5GhBqG7f4Q8p5sJOdnBV0SIqxJrxtZQ9FA==", + "dev": true, + "requires": { + "async": "2.6.0", + "base64url": "^2.0.0", + "commander": "2.11.0", + "fs-extra": "^4.0.2", + "globby": "^6.1.0", + "graceful-fs": "4.1.11", + "rimraf": "^2.6.2" + }, + "dependencies": { + "async": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.0.tgz", + "integrity": "sha512-xAfGg1/NTLBBKlHFmnd7PlmUW9KhVQIUuSrYem9xzFUZy13ScvtyGGejaae9iAVRiRq9+Cx7DPFaAAhCpyxyPw==", + "dev": true, + "requires": { + "lodash": "^4.14.0" + } + }, + "commander": { + "version": "2.11.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", + "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", + "dev": true + }, + "globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + } + } + }, + "git-raw-commits": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/git-raw-commits/-/git-raw-commits-1.3.6.tgz", + "integrity": "sha512-svsK26tQ8vEKnMshTDatSIQSMDdz8CxIIqKsvPqbtV23Etmw6VNaFAitu8zwZ0VrOne7FztwPyRLxK7/DIUTQg==", + "dev": true, + "requires": { + "dargs": "^4.0.1", + "lodash.template": "^4.0.2", + "meow": "^4.0.0", + "split2": "^2.0.0", + "through2": "^2.0.0" + } + }, + "git-semver-tags": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/git-semver-tags/-/git-semver-tags-1.3.6.tgz", + "integrity": "sha512-2jHlJnln4D/ECk9FxGEBh3k44wgYdWjWDtMmJPaecjoRmxKo3Y1Lh8GMYuOPu04CHw86NTAODchYjC5pnpMQig==", + "dev": true, + "requires": { + "meow": "^4.0.0", + "semver": "^5.5.0" + } + }, + "glob": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", + "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + } + }, + "glob-stream": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/glob-stream/-/glob-stream-6.1.0.tgz", + "integrity": "sha1-cEXJlBOz65SIjYOrRtC0BMx73eQ=", + "dev": true, + "requires": { + "extend": "^3.0.0", + "glob": "^7.1.1", + "glob-parent": "^3.1.0", + "is-negated-glob": "^1.0.0", + "ordered-read-streams": "^1.0.0", + "pumpify": "^1.3.5", + "readable-stream": "^2.1.5", + "remove-trailing-separator": "^1.0.1", + "to-absolute-glob": "^2.0.0", + "unique-stream": "^2.0.2" + }, + "dependencies": { + "to-absolute-glob": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/to-absolute-glob/-/to-absolute-glob-2.0.2.tgz", + "integrity": "sha1-GGX0PZ50sIItufFFt4z/fQ98hJs=", + "dev": true, + "requires": { + "is-absolute": "^1.0.0", + "is-negated-glob": "^1.0.0" + } + } + } + }, + "glob-watcher": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/glob-watcher/-/glob-watcher-5.0.1.tgz", + "integrity": "sha512-fK92r2COMC199WCyGUblrZKhjra3cyVMDiypDdqg1vsSDmexnbYivK1kNR4QItiNXLKmGlqan469ks67RtNa2g==", + "dev": true, + "requires": { + "async-done": "^1.2.0", + "chokidar": "^2.0.0", + "just-debounce": "^1.0.0", + "object.defaults": "^1.1.0" + } + }, + "global-modules": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", + "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", + "dev": true, + "requires": { + "global-prefix": "^1.0.1", + "is-windows": "^1.0.1", + "resolve-dir": "^1.0.0" + } + }, + "global-prefix": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", + "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.2", + "homedir-polyfill": "^1.0.1", + "ini": "^1.3.4", + "is-windows": "^1.0.1", + "which": "^1.2.14" + } + }, + "globals": { + "version": "11.5.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.5.0.tgz", + "integrity": "sha512-hYyf+kI8dm3nORsiiXUQigOU62hDLfJ9G01uyGMxhc6BKsircrUhC4uJPQPUSuq2GrTmiiEt7ewxlMdBewfmKQ==", + "dev": true + }, + "globby": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", + "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "arrify": "^1.0.0", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "glogg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/glogg/-/glogg-1.0.1.tgz", + "integrity": "sha512-ynYqXLoluBKf9XGR1gA59yEJisIL7YHEH4xr3ZziHB5/yl4qWfaK8Js9jGe6gBGCSCKVqiyO30WnRZADvemUNw==", + "dev": true, + "requires": { + "sparkles": "^1.0.0" + } + }, + "google-protobuf": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/google-protobuf/-/google-protobuf-3.5.0.tgz", + "integrity": "sha1-uMxjx02DRXvYqakEUDyO+ya8ozk=", + "dev": true + }, + "graceful-fs": { + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true + }, + "gulp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/gulp/-/gulp-4.0.0.tgz", + "integrity": "sha1-lXZsYB2t5Kd+0+eyttwDiBtZY2Y=", + "dev": true, + "requires": { + "glob-watcher": "^5.0.0", + "gulp-cli": "^2.0.0", + "undertaker": "^1.0.0", + "vinyl-fs": "^3.0.0" + }, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", + "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", + "dev": true + }, + "cliui": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", + "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", + "dev": true, + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wrap-ansi": "^2.0.0" + } + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "dev": true, + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "gulp-cli": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/gulp-cli/-/gulp-cli-2.0.1.tgz", + "integrity": "sha512-RxujJJdN8/O6IW2nPugl7YazhmrIEjmiVfPKrWt68r71UCaLKS71Hp0gpKT+F6qOUFtr7KqtifDKaAJPRVvMYQ==", + "dev": true, + "requires": { + "ansi-colors": "^1.0.1", + "archy": "^1.0.0", + "array-sort": "^1.0.0", + "color-support": "^1.1.3", + "concat-stream": "^1.6.0", + "copy-props": "^2.0.1", + "fancy-log": "^1.3.2", + "gulplog": "^1.0.0", + "interpret": "^1.1.0", + "isobject": "^3.0.1", + "liftoff": "^2.5.0", + "matchdep": "^2.0.0", + "mute-stdout": "^1.0.0", + "pretty-hrtime": "^1.0.0", + "replace-homedir": "^1.0.0", + "semver-greatest-satisfied-range": "^1.1.0", + "v8flags": "^3.0.1", + "yargs": "^7.1.0" + } + }, + "is-valid-glob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-1.0.0.tgz", + "integrity": "sha1-Kb8+/3Ab4tTTFdusw5vDn+j2Aao=", + "dev": true + }, + "load-json-file": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", + "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^2.2.0", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0", + "strip-bom": "^2.0.0" + } + }, + "parse-json": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", + "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "dev": true, + "requires": { + "error-ex": "^1.2.0" + } + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "dev": true, + "requires": { + "pinkie-promise": "^2.0.0" + } + }, + "path-type": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", + "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "read-pkg": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", + "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", + "dev": true, + "requires": { + "load-json-file": "^1.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^1.0.0" + } + }, + "read-pkg-up": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", + "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", + "dev": true, + "requires": { + "find-up": "^1.0.0", + "read-pkg": "^1.0.0" + } + }, + "strip-bom": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", + "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", + "dev": true, + "requires": { + "is-utf8": "^0.2.0" + } + }, + "vinyl-fs": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-3.0.3.tgz", + "integrity": "sha512-vIu34EkyNyJxmP0jscNzWBSygh7VWhqun6RmqVfXePrOwi9lhvRs//dOaGOTRUQr4tx7/zd26Tk5WeSVZitgng==", + "dev": true, + "requires": { + "fs-mkdirp-stream": "^1.0.0", + "glob-stream": "^6.1.0", + "graceful-fs": "^4.0.0", + "is-valid-glob": "^1.0.0", + "lazystream": "^1.0.0", + "lead": "^1.0.0", + "object.assign": "^4.0.4", + "pumpify": "^1.3.5", + "readable-stream": "^2.3.3", + "remove-bom-buffer": "^3.0.0", + "remove-bom-stream": "^1.2.0", + "resolve-options": "^1.1.0", + "through2": "^2.0.0", + "to-through": "^2.0.0", + "value-or-function": "^3.0.0", + "vinyl": "^2.0.0", + "vinyl-sourcemap": "^1.1.0" + } + }, + "yargs": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-7.1.0.tgz", + "integrity": "sha1-a6MY6xaWFyf10oT46gA+jWFU0Mg=", + "dev": true, + "requires": { + "camelcase": "^3.0.0", + "cliui": "^3.2.0", + "decamelize": "^1.1.1", + "get-caller-file": "^1.0.1", + "os-locale": "^1.4.0", + "read-pkg-up": "^1.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^1.0.1", + "set-blocking": "^2.0.0", + "string-width": "^1.0.2", + "which-module": "^1.0.0", + "y18n": "^3.2.1", + "yargs-parser": "^5.0.0" + } + } + } + }, + "gulp-header": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/gulp-header/-/gulp-header-2.0.5.tgz", + "integrity": "sha512-7bOIiHvM1GUHIG3LRH+UIanOxyjSys0FbzzgUBlV2cZIIZihEW+KKKKm0ejUBNGvRdhISEFFr6HlptXoa28gtQ==", + "dev": true, + "requires": { + "concat-with-sourcemaps": "*", + "lodash.template": "^4.4.0", + "through2": "^2.0.0" + } + }, + "gulp-if": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/gulp-if/-/gulp-if-2.0.2.tgz", + "integrity": "sha1-pJe351cwBQQcqivIt92jyARE1ik=", + "dev": true, + "requires": { + "gulp-match": "^1.0.3", + "ternary-stream": "^2.0.1", + "through2": "^2.0.1" + } + }, + "gulp-match": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/gulp-match/-/gulp-match-1.0.3.tgz", + "integrity": "sha1-kcfA1/Kb7NZgbVfYCn+Hdqh6uo4=", + "dev": true, + "requires": { + "minimatch": "^3.0.3" + } + }, + "gulp-sourcemaps": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/gulp-sourcemaps/-/gulp-sourcemaps-2.6.4.tgz", + "integrity": "sha1-y7IAhFCxvM5s0jv5gze+dRv24wo=", + "dev": true, + "requires": { + "@gulp-sourcemaps/identity-map": "1.X", + "@gulp-sourcemaps/map-sources": "1.X", + "acorn": "5.X", + "convert-source-map": "1.X", + "css": "2.X", + "debug-fabulous": "1.X", + "detect-newline": "2.X", + "graceful-fs": "4.X", + "source-map": "~0.6.0", + "strip-bom-string": "1.X", + "through2": "2.X" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "gulp-uglify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/gulp-uglify/-/gulp-uglify-3.0.0.tgz", + "integrity": "sha1-DfAzHXKg0wLj434QlIXd3zPG0co=", + "dev": true, + "requires": { + "gulplog": "^1.0.0", + "has-gulplog": "^0.1.0", + "lodash": "^4.13.1", + "make-error-cause": "^1.1.1", + "through2": "^2.0.0", + "uglify-js": "^3.0.5", + "vinyl-sourcemaps-apply": "^0.2.0" + } + }, + "gulplog": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/gulplog/-/gulplog-1.0.0.tgz", + "integrity": "sha1-4oxNRdBey77YGDY86PnFkmIp/+U=", + "dev": true, + "requires": { + "glogg": "^1.0.0" + } + }, + "handlebars": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.0.11.tgz", + "integrity": "sha1-Ywo13+ApS8KB7a5v/F0yn8eYLcw=", + "dev": true, + "requires": { + "async": "^1.4.0", + "optimist": "^0.6.1", + "source-map": "^0.4.4", + "uglify-js": "^2.6" + }, + "dependencies": { + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, + "requires": { + "amdefine": ">=0.0.4" + } + }, + "uglify-js": { + "version": "2.8.29", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", + "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", + "dev": true, + "optional": true, + "requires": { + "source-map": "~0.5.1", + "uglify-to-browserify": "~1.0.0", + "yargs": "~3.10.0" + }, + "dependencies": { + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true, + "optional": true + } + } + } + } + }, + "has": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", + "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", + "dev": true, + "requires": { + "function-bind": "^1.0.2" + } + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "has-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", + "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", + "dev": true + }, + "has-gulplog": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/has-gulplog/-/has-gulplog-0.1.0.tgz", + "integrity": "sha1-ZBTIKRNpfaUVkDl9r7EvIpZ4Ec4=", + "dev": true, + "requires": { + "sparkles": "^1.0.0" + } + }, + "has-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", + "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", + "dev": true + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "hash-base": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", + "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "hash.js": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.3.tgz", + "integrity": "sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.0" + } + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "dev": true, + "requires": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "homedir-polyfill": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.1.tgz", + "integrity": "sha1-TCu8inWJmP7r9e1oWA921GdotLw=", + "dev": true, + "requires": { + "parse-passwd": "^1.0.0" + } + }, + "hosted-git-info": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.6.0.tgz", + "integrity": "sha512-lIbgIIQA3lz5XaB6vxakj6sDHADJiZadYEJB+FgA+C4nubM1NwcuvUr9EJPmnH1skZqpqUzWborWo8EIUi0Sdw==", + "dev": true + }, + "htmlescape": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/htmlescape/-/htmlescape-1.1.1.tgz", + "integrity": "sha1-OgPtwiFLyjtmQko+eVk0lQnLA1E=", + "dev": true + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=", + "dev": true + }, + "iconv-lite": { + "version": "0.4.23", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", + "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "ieee754": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.11.tgz", + "integrity": "sha512-VhDzCKN7K8ufStx/CLj5/PDTMgph+qwN5Pkd5i0sGnVwk56zJ0lkT8Qzi1xqWLS0Wp29DgDtNeS7v8/wMoZeHg==", + "dev": true + }, + "ignore": { + "version": "3.3.8", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.8.tgz", + "integrity": "sha512-pUh+xUQQhQzevjRHHFqqcTy0/dP/kS9I8HSrUydhihjuD09W6ldVWFtIrwhXdUJHis3i2rZNqEHpZH/cbinFbg==", + "dev": true + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, + "indent-string": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", + "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + }, + "ini": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", + "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", + "dev": true + }, + "inline-source-map": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.6.2.tgz", + "integrity": "sha1-+Tk0ccGKedFyT4Y/o4tYY3Ct4qU=", + "dev": true, + "requires": { + "source-map": "~0.5.3" + } + }, + "inquirer": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.3.0.tgz", + "integrity": "sha512-h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ==", + "dev": true, + "requires": { + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.0", + "cli-cursor": "^2.1.0", + "cli-width": "^2.0.0", + "external-editor": "^2.0.4", + "figures": "^2.0.0", + "lodash": "^4.3.0", + "mute-stream": "0.0.7", + "run-async": "^2.2.0", + "rx-lite": "^4.0.8", + "rx-lite-aggregates": "^4.0.8", + "string-width": "^2.1.0", + "strip-ansi": "^4.0.0", + "through": "^2.3.6" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "figures": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", + "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "insert-module-globals": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/insert-module-globals/-/insert-module-globals-7.1.0.tgz", + "integrity": "sha512-LbYZdybvKjbbcKLp03lB323Cgc8f0iL0Rjh8U6JZ7K1gZSf7MxQH191iCNUcLX4qIQ6/yWe4Q4ZsQ+opcReNFg==", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "combine-source-map": "^0.8.0", + "concat-stream": "^1.6.1", + "is-buffer": "^1.1.0", + "lexical-scope": "^1.2.0", + "path-is-absolute": "^1.0.1", + "process": "~0.11.0", + "through2": "^2.0.0", + "xtend": "^4.0.0" + }, + "dependencies": { + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + } + } + }, + "interpret": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", + "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=", + "dev": true + }, + "invert-kv": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", + "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=", + "dev": true + }, + "is-absolute": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-absolute/-/is-absolute-1.0.0.tgz", + "integrity": "sha512-dOWoqflvcydARa360Gvv18DZ/gRuHKi2NU/wU5X1ZFzdYfH29nkiNZsF3mp4OJ3H4yo9Mx8A/uAGNzpzPN3yBA==", + "dev": true, + "requires": { + "is-relative": "^1.0.0", + "is-windows": "^1.0.1" + } + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "is-builtin-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", + "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", + "dev": true, + "requires": { + "builtin-modules": "^1.0.0" + } + }, + "is-callable": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", + "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-date-object": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", + "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", + "dev": true + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "is-function": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-function/-/is-function-1.0.1.tgz", + "integrity": "sha1-Es+5i2W1fdPRk6MSH19uL0N2ArU=", + "dev": true + }, + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + }, + "is-negated-glob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-negated-glob/-/is-negated-glob-1.0.0.tgz", + "integrity": "sha1-aRC8pdqMleeEtXUbl2z1oQ/uNtI=", + "dev": true + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-odd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-odd/-/is-odd-2.0.0.tgz", + "integrity": "sha512-OTiixgpZAT1M4NHgS5IguFp/Vz2VI3U7Goh4/HA1adtwyLtSBrxYlcSYkhpAE07s4fKEcjrFxyvtQBND4vFQyQ==", + "dev": true, + "requires": { + "is-number": "^4.0.0" + }, + "dependencies": { + "is-number": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", + "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", + "dev": true + } + } + }, + "is-path-cwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", + "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", + "dev": true + }, + "is-path-in-cwd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", + "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", + "dev": true, + "requires": { + "is-path-inside": "^1.0.0" + } + }, + "is-path-inside": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", + "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", + "dev": true, + "requires": { + "path-is-inside": "^1.0.1" + } + }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", + "dev": true + }, + "is-regex": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", + "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", + "dev": true, + "requires": { + "has": "^1.0.1" + } + }, + "is-relative": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-relative/-/is-relative-1.0.0.tgz", + "integrity": "sha512-Kw/ReK0iqwKeu0MITLFuj0jbPAmEiOsIwyIXvvbfa6QfmN9pkD1M+8pdk7Rl/dTKbH34/XBFMbgD4iMJhLQbGA==", + "dev": true, + "requires": { + "is-unc-path": "^1.0.0" + } + }, + "is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", + "dev": true + }, + "is-symbol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz", + "integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI=", + "dev": true + }, + "is-unc-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-unc-path/-/is-unc-path-1.0.0.tgz", + "integrity": "sha512-mrGpVd0fs7WWLfVsStvgF6iEJnbjDFZh9/emhRDcGWTduTfNHd9CHeUwH3gYIjdbwo4On6hunkztwOaAw0yllQ==", + "dev": true, + "requires": { + "unc-path-regex": "^0.1.2" + } + }, + "is-utf8": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", + "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", + "dev": true + }, + "is-valid-glob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-1.0.0.tgz", + "integrity": "sha1-Kb8+/3Ab4tTTFdusw5vDn+j2Aao=", + "dev": true + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true + }, + "istanbul": { + "version": "0.4.5", + "resolved": "https://registry.npmjs.org/istanbul/-/istanbul-0.4.5.tgz", + "integrity": "sha1-ZcfXPUxNqE1POsMQuRj7C4Azczs=", + "dev": true, + "requires": { + "abbrev": "1.0.x", + "async": "1.x", + "escodegen": "1.8.x", + "esprima": "2.7.x", + "glob": "^5.0.15", + "handlebars": "^4.0.1", + "js-yaml": "3.x", + "mkdirp": "0.5.x", + "nopt": "3.x", + "once": "1.x", + "resolve": "1.1.x", + "supports-color": "^3.1.0", + "which": "^1.1.1", + "wordwrap": "^1.0.0" + }, + "dependencies": { + "escodegen": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", + "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", + "dev": true, + "requires": { + "esprima": "^2.7.1", + "estraverse": "^1.9.1", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.2.0" + } + }, + "esprima": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", + "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", + "dev": true + }, + "estraverse": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", + "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=", + "dev": true + }, + "glob": { + "version": "5.0.15", + "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", + "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", + "dev": true, + "requires": { + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "2 || 3", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", + "dev": true + }, + "source-map": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", + "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", + "dev": true, + "optional": true, + "requires": { + "amdefine": ">=0.0.4" + } + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true, + "requires": { + "has-flag": "^1.0.0" + } + } + } + }, + "jaguarjs-jsdoc": { + "version": "github:dcodeIO/jaguarjs-jsdoc#ade85ac841f5ca8be40c60d506102039a036a8fa", + "from": "github:dcodeIO/jaguarjs-jsdoc", + "dev": true + }, + "js-tokens": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", + "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", + "dev": true + }, + "js-yaml": { + "version": "3.11.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.11.0.tgz", + "integrity": "sha512-saJstZWv7oNeOyBh3+Dx1qWzhW0+e6/8eDzo7p5rDFqxntSztloLtuKu+Ejhtq82jsilwOIZYsCz+lIjthg1Hw==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "dependencies": { + "esprima": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", + "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", + "dev": true + } + } + }, + "js2xmlparser": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-3.0.0.tgz", + "integrity": "sha1-P7YOqgicVED5MZ9RdgzNB+JJlzM=", + "dev": true, + "requires": { + "xmlcreate": "^1.0.1" + } + }, + "jsdoc": { + "version": "3.5.5", + "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.5.5.tgz", + "integrity": "sha512-6PxB65TAU4WO0Wzyr/4/YhlGovXl0EVYfpKbpSroSj0qBxT4/xod/l40Opkm38dRHRdQgdeY836M0uVnJQG7kg==", + "dev": true, + "requires": { + "babylon": "7.0.0-beta.19", + "bluebird": "~3.5.0", + "catharsis": "~0.8.9", + "escape-string-regexp": "~1.0.5", + "js2xmlparser": "~3.0.0", + "klaw": "~2.0.0", + "marked": "~0.3.6", + "mkdirp": "~0.5.1", + "requizzle": "~0.2.1", + "strip-json-comments": "~2.0.1", + "taffydb": "2.6.2", + "underscore": "~1.8.3" + } + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "json-schema-traverse": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", + "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", + "dev": true + }, + "json-stable-stringify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-0.0.1.tgz", + "integrity": "sha1-YRwj6BTbN1Un34URk9tZ3Sryf0U=", + "dev": true, + "requires": { + "jsonify": "~0.0.0" + } + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", + "dev": true + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsonify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", + "dev": true + }, + "jsonparse": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz", + "integrity": "sha1-P02uSpH6wxX3EGL4UhzCOfE2YoA=", + "dev": true + }, + "just-debounce": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/just-debounce/-/just-debounce-1.0.0.tgz", + "integrity": "sha1-h/zPrv/AtozRnVX2cilD+SnqNeo=", + "dev": true + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true + }, + "klaw": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/klaw/-/klaw-2.0.0.tgz", + "integrity": "sha1-WcEo4Nxc5BAgEVEZTuucv4WGUPY=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.9" + } + }, + "labeled-stream-splicer": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/labeled-stream-splicer/-/labeled-stream-splicer-2.0.1.tgz", + "integrity": "sha512-MC94mHZRvJ3LfykJlTUipBqenZz1pacOZEMhhQ8dMGcDHs0SBE5GbsavUXV7YtP3icBW17W0Zy1I0lfASmo9Pg==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "isarray": "^2.0.4", + "stream-splicer": "^2.0.0" + }, + "dependencies": { + "isarray": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.4.tgz", + "integrity": "sha512-GMxXOiUirWg1xTKRipM0Ek07rX+ubx4nNVElTJdNLYmNO/2YrDkgJGw9CljXn+r4EWiDQg/8lsRdHyg2PJuUaA==", + "dev": true + } + } + }, + "last-run": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/last-run/-/last-run-1.1.1.tgz", + "integrity": "sha1-RblpQsF7HHnHchmCWbqUO+v4yls=", + "dev": true, + "requires": { + "default-resolution": "^2.0.0", + "es6-weak-map": "^2.0.1" + } + }, + "lazy-cache": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", + "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=", + "dev": true, + "optional": true + }, + "lazystream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.0.tgz", + "integrity": "sha1-9plf4PggOS9hOWvolGJAe7dxaOQ=", + "dev": true, + "requires": { + "readable-stream": "^2.0.5" + } + }, + "lcid": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", + "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", + "dev": true, + "requires": { + "invert-kv": "^1.0.0" + } + }, + "lead": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lead/-/lead-1.0.0.tgz", + "integrity": "sha1-bxT5mje+Op3XhPVJVpDlkDRm7kI=", + "dev": true, + "requires": { + "flush-write-stream": "^1.0.2" + } + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "dev": true, + "requires": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + } + }, + "lexical-scope": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/lexical-scope/-/lexical-scope-1.2.0.tgz", + "integrity": "sha1-/Ope3HBKSzqHls3KQZw6CvryLfQ=", + "dev": true, + "requires": { + "astw": "^2.0.0" + } + }, + "liftoff": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/liftoff/-/liftoff-2.5.0.tgz", + "integrity": "sha1-IAkpG7Mc6oYbvxCnwVooyvdcMew=", + "dev": true, + "requires": { + "extend": "^3.0.0", + "findup-sync": "^2.0.0", + "fined": "^1.0.1", + "flagged-respawn": "^1.0.0", + "is-plain-object": "^2.0.4", + "object.map": "^1.0.0", + "rechoir": "^0.6.2", + "resolve": "^1.1.7" + } + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.10", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.10.tgz", + "integrity": "sha512-UejweD1pDoXu+AD825lWwp4ZGtSwgnpZxb3JDViD7StjQz+Nb/6l093lx4OQ0foGWNRoc19mWy7BzL+UAK2iVg==", + "dev": true + }, + "lodash._reinterpolate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", + "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=", + "dev": true + }, + "lodash.memoize": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-3.0.4.tgz", + "integrity": "sha1-LcvSwofLwKVcxCMovQxzYVDVPj8=", + "dev": true + }, + "lodash.template": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-4.4.0.tgz", + "integrity": "sha1-5zoDhcg1VZF0bgILmWecaQ5o+6A=", + "dev": true, + "requires": { + "lodash._reinterpolate": "~3.0.0", + "lodash.templatesettings": "^4.0.0" + } + }, + "lodash.templatesettings": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-4.1.0.tgz", + "integrity": "sha1-K01OlbpEDZFf8IvImeRVNmZxMxY=", + "dev": true, + "requires": { + "lodash._reinterpolate": "~3.0.0" + } + }, + "long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", + "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" + }, + "longest": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", + "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", + "dev": true + }, + "loud-rejection": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", + "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=", + "dev": true, + "requires": { + "currently-unhandled": "^0.4.1", + "signal-exit": "^3.0.0" + } + }, + "lru-cache": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", + "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "lru-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", + "integrity": "sha1-Jzi9nw089PhEkMVzbEhpmsYyzaM=", + "dev": true, + "requires": { + "es5-ext": "~0.10.2" + } + }, + "make-error": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.4.tgz", + "integrity": "sha512-0Dab5btKVPhibSalc9QGXb559ED7G7iLjFXBaj9Wq8O3vorueR5K5jaE3hkG6ZQINyhA/JgG6Qk4qdFQjsYV6g==", + "dev": true + }, + "make-error-cause": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/make-error-cause/-/make-error-cause-1.2.2.tgz", + "integrity": "sha1-3wOI/NCzeBbf8KX7gQiTl3fcvJ0=", + "dev": true, + "requires": { + "make-error": "^1.2.0" + } + }, + "make-iterator": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/make-iterator/-/make-iterator-1.0.1.tgz", + "integrity": "sha512-pxiuXh0iVEq7VM7KMIhs5gxsfxCux2URptUQaXo4iZZJxBAzTPOLE2BumO5dbfVYq/hBJFBR/a1mFDmOx5AGmw==", + "dev": true, + "requires": { + "kind-of": "^6.0.2" + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true + }, + "map-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-2.0.0.tgz", + "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", + "dev": true + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, + "requires": { + "object-visit": "^1.0.0" + } + }, + "marked": { + "version": "0.3.19", + "resolved": "https://registry.npmjs.org/marked/-/marked-0.3.19.tgz", + "integrity": "sha512-ea2eGWOqNxPcXv8dyERdSr/6FmzvWwzjMxpfGB/sbMccXoct+xY+YukPD+QTUZwyvK7BZwcr4m21WBOW41pAkg==", + "dev": true + }, + "matchdep": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/matchdep/-/matchdep-2.0.0.tgz", + "integrity": "sha1-xvNINKDY28OzfCfui7yyfHd1WC4=", + "dev": true, + "requires": { + "findup-sync": "^2.0.0", + "micromatch": "^3.0.4", + "resolve": "^1.4.0", + "stack-trace": "0.0.10" + } + }, + "md5.js": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.4.tgz", + "integrity": "sha1-6b296UogpawYsENA/Fdk1bCdkB0=", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "memoizee": { + "version": "0.4.12", + "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.12.tgz", + "integrity": "sha512-sprBu6nwxBWBvBOh5v2jcsGqiGLlL2xr2dLub3vR8dnE8YB17omwtm/0NSHl8jjNbcsJd5GMWJAnTSVe/O0Wfg==", + "dev": true, + "requires": { + "d": "1", + "es5-ext": "^0.10.30", + "es6-weak-map": "^2.0.2", + "event-emitter": "^0.3.5", + "is-promise": "^2.1", + "lru-queue": "0.1", + "next-tick": "1", + "timers-ext": "^0.1.2" + } + }, + "meow": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/meow/-/meow-4.0.1.tgz", + "integrity": "sha512-xcSBHD5Z86zaOc+781KrupuHAzeGXSLtiAOmBsiLDiPSaYSB6hdew2ng9EBAnZ62jagG9MHAOdxpDi/lWBFJ/A==", + "dev": true, + "requires": { + "camelcase-keys": "^4.0.0", + "decamelize-keys": "^1.0.0", + "loud-rejection": "^1.0.0", + "minimist": "^1.1.3", + "minimist-options": "^3.0.1", + "normalize-package-data": "^2.3.4", + "read-pkg-up": "^3.0.0", + "redent": "^2.0.0", + "trim-newlines": "^2.0.0" + } + }, + "merge-stream": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-1.0.1.tgz", + "integrity": "sha1-QEEgLVCKNCugAXQAjfDCUbjBNeE=", + "dev": true, + "requires": { + "readable-stream": "^2.0.1" + } + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + } + }, + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", + "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", + "dev": true + }, + "minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", + "dev": true + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=", + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true + }, + "minimist-options": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-3.0.2.tgz", + "integrity": "sha512-FyBrT/d0d4+uiZRbqznPXqw3IpZZG3gl3wKWiX784FycUKVwBt0uLBFkQrtE4tZOrgo78nZp2jnKz3L65T5LdQ==", + "dev": true, + "requires": { + "arrify": "^1.0.1", + "is-plain-obj": "^1.1.0" + } + }, + "mixin-deep": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", + "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", + "dev": true, + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true, + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true + } + } + }, + "module-deps": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/module-deps/-/module-deps-6.0.2.tgz", + "integrity": "sha512-KWBI3009iRnHjRlxRhe8nJ6kdeBTg4sMi5N6AZgg5f1/v5S7EBCRBOY854I4P5Anl4kx6AJH+4bBBC2Gi3nkvg==", + "dev": true, + "requires": { + "JSONStream": "^1.0.3", + "browser-resolve": "^1.7.0", + "cached-path-relative": "^1.0.0", + "concat-stream": "~1.6.0", + "defined": "^1.0.0", + "detective": "^5.0.2", + "duplexer2": "^0.1.2", + "inherits": "^2.0.1", + "parents": "^1.0.0", + "readable-stream": "^2.0.2", + "resolve": "^1.4.0", + "stream-combiner2": "^1.1.1", + "subarg": "^1.0.0", + "through2": "^2.0.0", + "xtend": "^4.0.0" + }, + "dependencies": { + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + } + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "mute-stdout": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/mute-stdout/-/mute-stdout-1.0.0.tgz", + "integrity": "sha1-WzLqB+tDyd7WEwQ0z5JvRrKn/U0=", + "dev": true + }, + "mute-stream": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", + "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", + "dev": true + }, + "nan": { + "version": "2.10.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", + "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", + "dev": true, + "optional": true + }, + "nanomatch": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.9.tgz", + "integrity": "sha512-n8R9bS8yQ6eSXaV6jHUpKzD8gLsin02w1HSFiegwrs9E098Ylhw5jdyKPaYqvHknHaSCKTPp7C8dGCQ0q9koXA==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-odd": "^2.0.0", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + } + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "next-tick": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", + "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=", + "dev": true + }, + "nopt": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", + "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", + "dev": true, + "requires": { + "abbrev": "1" + } + }, + "normalize-package-data": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", + "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "is-builtin-module": "^1.0.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + }, + "now-and-later": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.0.tgz", + "integrity": "sha1-vGHLtFbXnLMiB85HygUTb/Ln1u4=", + "dev": true, + "requires": { + "once": "^1.3.2" + } + }, + "number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "object-inspect": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.5.0.tgz", + "integrity": "sha512-UmOFbHbwvv+XHj7BerrhVq+knjceBdkvU5AriwLMvhv2qi+e7DJzxfBeFpILEjVzCp+xA+W/pIf06RGPWlZNfw==", + "dev": true + }, + "object-keys": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", + "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=", + "dev": true + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, + "requires": { + "isobject": "^3.0.0" + } + }, + "object.assign": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", + "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "function-bind": "^1.1.1", + "has-symbols": "^1.0.0", + "object-keys": "^1.0.11" + } + }, + "object.defaults": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/object.defaults/-/object.defaults-1.1.0.tgz", + "integrity": "sha1-On+GgzS0B96gbaFtiNXNKeQ1/s8=", + "dev": true, + "requires": { + "array-each": "^1.0.1", + "array-slice": "^1.0.0", + "for-own": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "object.map": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object.map/-/object.map-1.0.1.tgz", + "integrity": "sha1-z4Plncj8wK1fQlDh94s7gb2AHTc=", + "dev": true, + "requires": { + "for-own": "^1.0.0", + "make-iterator": "^1.0.0" + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "object.reduce": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object.reduce/-/object.reduce-1.0.1.tgz", + "integrity": "sha1-b+NI8qx/oPlcpiEiZZkJaCW7A60=", + "dev": true, + "requires": { + "for-own": "^1.0.0", + "make-iterator": "^1.0.0" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "optimist": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", + "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", + "dev": true, + "requires": { + "minimist": "~0.0.1", + "wordwrap": "~0.0.2" + }, + "dependencies": { + "minimist": { + "version": "0.0.10", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", + "integrity": "sha1-3j+YVD2/lggr5IrRoMfNqDYwHc8=", + "dev": true + }, + "wordwrap": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", + "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", + "dev": true + } + } + }, + "optionator": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", + "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", + "dev": true, + "requires": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.4", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "wordwrap": "~1.0.0" + } + }, + "ordered-read-streams": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ordered-read-streams/-/ordered-read-streams-1.0.1.tgz", + "integrity": "sha1-d8DLN8QVJdZBZtmQ/61+xqDhNj4=", + "dev": true, + "requires": { + "readable-stream": "^2.0.1" + } + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=", + "dev": true + }, + "os-locale": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", + "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", + "dev": true, + "requires": { + "lcid": "^1.0.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true + }, + "p-limit": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.2.0.tgz", + "integrity": "sha512-Y/OtIaXtUPr4/YpMv1pCL5L5ed0rumAaAeBSj12F+bSlMdys7i8oQF/GUJmfpTS/QoaRrS/k6pma29haJpsMng==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "pako": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz", + "integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg==", + "dev": true + }, + "parents": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parents/-/parents-1.0.1.tgz", + "integrity": "sha1-/t1NK/GTp3dF/nHjcdc8MwfZx1E=", + "dev": true, + "requires": { + "path-platform": "~0.11.15" + } + }, + "parse-asn1": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.1.tgz", + "integrity": "sha512-KPx7flKXg775zZpnp9SxJlz00gTd4BmJ2yJufSc44gMCRrRQ7NSzAcSJQfifuOLgW6bEi+ftrALtsgALeB2Adw==", + "dev": true, + "requires": { + "asn1.js": "^4.0.0", + "browserify-aes": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3" + } + }, + "parse-filepath": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/parse-filepath/-/parse-filepath-1.0.2.tgz", + "integrity": "sha1-pjISf1Oq89FYdvWHLz/6x2PWyJE=", + "dev": true, + "requires": { + "is-absolute": "^1.0.0", + "map-cache": "^0.2.0", + "path-root": "^0.1.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "parse-passwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", + "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=", + "dev": true + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true + }, + "path-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.0.tgz", + "integrity": "sha1-oLhwcpquIUAFt9UDLsLLuw+0RRo=", + "dev": true + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", + "dev": true + }, + "path-parse": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", + "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", + "dev": true + }, + "path-platform": { + "version": "0.11.15", + "resolved": "https://registry.npmjs.org/path-platform/-/path-platform-0.11.15.tgz", + "integrity": "sha1-6GQhf3TDaFDwhSt43Hv31KVyG/I=", + "dev": true + }, + "path-root": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/path-root/-/path-root-0.1.1.tgz", + "integrity": "sha1-mkpoFMrBwM1zNgqV8yCDyOpHRbc=", + "dev": true, + "requires": { + "path-root-regex": "^0.1.0" + } + }, + "path-root-regex": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/path-root-regex/-/path-root-regex-0.1.2.tgz", + "integrity": "sha1-v8zcjfWxLcUsi0PsONGNcsBLqW0=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "pbkdf2": { + "version": "3.0.16", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.16.tgz", + "integrity": "sha512-y4CXP3thSxqf7c0qmOF+9UeOTrifiVTIM+u7NWlq+PRsHbr7r7dpCmvzrZxa96JJUNi0Y5w9VqG5ZNeCVMoDcA==", + "dev": true, + "requires": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true, + "requires": { + "pinkie": "^2.0.0" + } + }, + "platform": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/platform/-/platform-1.3.5.tgz", + "integrity": "sha512-TuvHS8AOIZNAlE77WUDiR4rySV/VMptyMfcfeoMgs4P8apaZM3JrnbzBiixKUv+XR6i+BXrQh8WAnjaSPFO65Q==", + "dev": true + }, + "pluralize": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", + "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", + "dev": true + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true + }, + "pretty-hrtime": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/pretty-hrtime/-/pretty-hrtime-1.0.3.tgz", + "integrity": "sha1-t+PqQkNaTJsnWdmeDyAesZWALuE=", + "dev": true + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", + "dev": true + }, + "process-nextick-args": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", + "dev": true + }, + "progress": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.0.tgz", + "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "public-encrypt": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.2.tgz", + "integrity": "sha512-4kJ5Esocg8X3h8YgJsKAuoesBgB7mqH3eowiDzMUPKiRDDE7E/BqqZD1hnTByIaAFiwAw246YEltSq7tdrOH0Q==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1" + } + }, + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "pumpify": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.0.tgz", + "integrity": "sha512-UWi0klDoq8xtVzlMRgENV9F7iCTZExaJQSQL187UXsxpk9NnrKGqTqqUNYAKGOzucSOxs2+jUnRNI+rLviPhJg==", + "dev": true, + "requires": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + } + }, + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", + "dev": true + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", + "dev": true + }, + "quick-lru": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-1.1.0.tgz", + "integrity": "sha1-Q2CxfGETatOAeDl/8RQW4Ybc+7g=", + "dev": true + }, + "randombytes": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.6.tgz", + "integrity": "sha512-CIQ5OFxf4Jou6uOKe9t1AOgqpeU5fd70A8NPdHSGeYXqXsPe6peOwI0cUl88RWZ6sP1vPMV3avd/R6cZ5/sP1A==", + "dev": true, + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", + "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", + "dev": true, + "requires": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "read-only-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-only-stream/-/read-only-stream-2.0.0.tgz", + "integrity": "sha1-JyT9aoET1zdkrCiNQ4YnDB2/F/A=", + "dev": true, + "requires": { + "readable-stream": "^2.0.2" + } + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-3.0.0.tgz", + "integrity": "sha1-PtSWaF26D4/hGNBpHcUfSh/5bwc=", + "dev": true, + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^3.0.0" + } + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "readdirp": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", + "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "minimatch": "^3.0.2", + "readable-stream": "^2.0.2", + "set-immediate-shim": "^1.0.1" + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", + "dev": true, + "requires": { + "resolve": "^1.1.6" + } + }, + "redent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-2.0.0.tgz", + "integrity": "sha1-wbIAe0LVfrE4kHmzyDM2OdXhzKo=", + "dev": true, + "requires": { + "indent-string": "^3.0.0", + "strip-indent": "^2.0.0" + } + }, + "reflect-metadata": { + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.12.tgz", + "integrity": "sha512-n+IyV+nGz3+0q3/Yf1ra12KpCyi001bi4XFxSjbiWWjfqb52iTTtpGXmCCAOWWIAn9KEuFZKGqBERHmrtScZ3A==", + "dev": true + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "regexpp": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-1.1.0.tgz", + "integrity": "sha512-LOPw8FpgdQF9etWMaAfG/WRthIdXJGYp4mJ2Jgn/2lpkbod9jPn0t9UqN7AxBOKNfzRbYyVfgc7Vk4t/MpnXgw==", + "dev": true + }, + "remove-bom-buffer": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/remove-bom-buffer/-/remove-bom-buffer-3.0.0.tgz", + "integrity": "sha512-8v2rWhaakv18qcvNeli2mZ/TMTL2nEyAKRvzo1WtnZBl15SHyEhrCu2/xKlJyUFKHiHgfXIyuY6g2dObJJycXQ==", + "dev": true, + "requires": { + "is-buffer": "^1.1.5", + "is-utf8": "^0.2.1" + } + }, + "remove-bom-stream": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/remove-bom-stream/-/remove-bom-stream-1.2.0.tgz", + "integrity": "sha1-BfGlk/FuQuH7kOv1nejlaVJflSM=", + "dev": true, + "requires": { + "remove-bom-buffer": "^3.0.0", + "safe-buffer": "^5.1.0", + "through2": "^2.0.3" + } + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", + "dev": true + }, + "repeat-element": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", + "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true + }, + "replace-homedir": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/replace-homedir/-/replace-homedir-1.0.0.tgz", + "integrity": "sha1-6H9tUTuSjd6AgmDBK+f+xv9ueYw=", + "dev": true, + "requires": { + "homedir-polyfill": "^1.0.1", + "is-absolute": "^1.0.0", + "remove-trailing-separator": "^1.1.0" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "require-main-filename": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", + "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", + "dev": true + }, + "require-uncached": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", + "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", + "dev": true, + "requires": { + "caller-path": "^0.1.0", + "resolve-from": "^1.0.0" + } + }, + "requizzle": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.1.tgz", + "integrity": "sha1-aUPDUwxNmn5G8c3dUcFY/GcM294=", + "dev": true, + "requires": { + "underscore": "~1.6.0" + }, + "dependencies": { + "underscore": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.6.0.tgz", + "integrity": "sha1-izixDKze9jM3uLJOT/htRa6lKag=", + "dev": true + } + } + }, + "resolve": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.7.1.tgz", + "integrity": "sha512-c7rwLofp8g1U+h1KNyHL/jicrKg1Ek4q+Lr33AL65uZTinUZHe30D5HlyN5V9NW0JX1D5dXQ4jqW5l7Sy/kGfw==", + "dev": true, + "requires": { + "path-parse": "^1.0.5" + } + }, + "resolve-dir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", + "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.0", + "global-modules": "^1.0.0" + } + }, + "resolve-from": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", + "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", + "dev": true + }, + "resolve-options": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/resolve-options/-/resolve-options-1.1.0.tgz", + "integrity": "sha1-MrueOcBtZzONyTeMDW1gdFZq0TE=", + "dev": true, + "requires": { + "value-or-function": "^3.0.0" + } + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "resumer": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/resumer/-/resumer-0.0.0.tgz", + "integrity": "sha1-8ej0YeQGS6Oegq883CqMiT0HZ1k=", + "dev": true, + "requires": { + "through": "~2.3.4" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true + }, + "right-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", + "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", + "dev": true, + "optional": true, + "requires": { + "align-text": "^0.1.1" + } + }, + "rimraf": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", + "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", + "dev": true, + "requires": { + "glob": "^7.0.5" + } + }, + "ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", + "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "dev": true, + "requires": { + "is-promise": "^2.1.0" + } + }, + "rx-lite": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", + "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", + "dev": true + }, + "rx-lite-aggregates": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", + "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", + "dev": true, + "requires": { + "rx-lite": "*" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "semver": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", + "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", + "dev": true + }, + "semver-greatest-satisfied-range": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/semver-greatest-satisfied-range/-/semver-greatest-satisfied-range-1.1.0.tgz", + "integrity": "sha1-E+jCZYq5aRywzXEJMkAoDTb3els=", + "dev": true, + "requires": { + "sver-compat": "^1.5.0" + } + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "set-immediate-shim": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", + "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", + "dev": true + }, + "set-value": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", + "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", + "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "shasum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/shasum/-/shasum-1.0.2.tgz", + "integrity": "sha1-5wEjENj0F/TetXEhUOVni4euVl8=", + "dev": true, + "requires": { + "json-stable-stringify": "~0.0.0", + "sha.js": "~2.4.4" + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "shell-quote": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz", + "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=", + "dev": true, + "requires": { + "array-filter": "~0.0.0", + "array-map": "~0.0.0", + "array-reduce": "~0.0.0", + "jsonify": "~0.0.0" + } + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "slice-ansi": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", + "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + } + } + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, + "requires": { + "kind-of": "^3.2.0" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true + }, + "source-map-resolve": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", + "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", + "dev": true, + "requires": { + "atob": "^2.1.1", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", + "dev": true + }, + "sparkles": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/sparkles/-/sparkles-1.0.1.tgz", + "integrity": "sha512-dSO0DDYUahUt/0/pD/Is3VIm5TGJjludZ0HVymmhYF6eNA53PVLhnUk0znSYbH8IYBuJdCE+1luR22jNLMaQdw==", + "dev": true + }, + "spdx-correct": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.0.0.tgz", + "integrity": "sha512-N19o9z5cEyc8yQQPukRCZ9EUmb4HUpnrmaL/fxS2pBo2jbfcFRVuFZ/oFC+vZz0MNNk0h80iMn5/S6qGZOL5+g==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.1.0.tgz", + "integrity": "sha512-4K1NsmrlCU1JJgUrtgEeTVyfx8VaYea9J9LvARxhbHtVtohPs/gFGG5yy49beySjlIMhhXZ4QqujIZEfS4l6Cg==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", + "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.0.tgz", + "integrity": "sha512-2+EPwgbnmOIl8HjGBXXMd9NAu02vLjOO1nWw4kmeRDFyHn+M/ETfHxQUK0oXg8ctgVnl9t3rosNVsZ1jG61nDA==", + "dev": true + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "split2": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/split2/-/split2-2.2.0.tgz", + "integrity": "sha512-RAb22TG39LhI31MbreBgIuKiIKhVsawfTgEGqKHTK87aG+ul/PB8Sqoi3I7kVdRWiCfrKxK3uo4/YUkpNvhPbw==", + "dev": true, + "requires": { + "through2": "^2.0.2" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "stack-trace": { + "version": "0.0.10", + "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", + "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=", + "dev": true + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "stream-browserify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz", + "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=", + "dev": true, + "requires": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + } + }, + "stream-combiner2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/stream-combiner2/-/stream-combiner2-1.1.1.tgz", + "integrity": "sha1-+02KFCDqNidk4hrUeAOXvry0HL4=", + "dev": true, + "requires": { + "duplexer2": "~0.1.0", + "readable-stream": "^2.0.2" + } + }, + "stream-exhaust": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/stream-exhaust/-/stream-exhaust-1.0.2.tgz", + "integrity": "sha512-b/qaq/GlBK5xaq1yrK9/zFcyRSTNxmcZwFLGSTG0mXgZl/4Z6GgiyYOXOvY7N3eEvFRAG1bkDRz5EPGSvPYQlw==", + "dev": true + }, + "stream-http": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.2.tgz", + "integrity": "sha512-QllfrBhqF1DPcz46WxKTs6Mz1Bpc+8Qm6vbqOpVav5odAXwbyzwnEczoWqtxrsmlO+cJqtPrp/8gWKWjaKLLlA==", + "dev": true, + "requires": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + } + }, + "stream-shift": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.0.tgz", + "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=", + "dev": true + }, + "stream-splicer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/stream-splicer/-/stream-splicer-2.0.0.tgz", + "integrity": "sha1-G2O+Q4oTPktnHMGTUZdgAXWRDYM=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.2" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string.prototype.trim": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.1.2.tgz", + "integrity": "sha1-0E3iyJ4Tf019IG8Ia17S+ua+jOo=", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "es-abstract": "^1.5.0", + "function-bind": "^1.0.2" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-bom-string": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-bom-string/-/strip-bom-string-1.0.0.tgz", + "integrity": "sha1-5SEekiQ2n7uB1jOi8ABE3IztrZI=", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, + "subarg": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/subarg/-/subarg-1.0.0.tgz", + "integrity": "sha1-9izxdYHplrSPyWVpn1TAauJouNI=", + "dev": true, + "requires": { + "minimist": "^1.1.0" + } + }, + "supports-color": { + "version": "5.4.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", + "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + }, + "dependencies": { + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + } + } + }, + "sver-compat": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/sver-compat/-/sver-compat-1.5.0.tgz", + "integrity": "sha1-PPh9/rTQe0o/FIJ7wYaz/QxkXNg=", + "dev": true, + "requires": { + "es6-iterator": "^2.0.1", + "es6-symbol": "^3.1.1" + } + }, + "syntax-error": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.4.0.tgz", + "integrity": "sha512-YPPlu67mdnHGTup2A8ff7BC2Pjq0e0Yp/IyTFN03zWO0RcK07uLcbi7C2KpGR2FvWbaB0+bfE27a+sBKebSo7w==", + "dev": true, + "requires": { + "acorn-node": "^1.2.0" + } + }, + "table": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/table/-/table-4.0.2.tgz", + "integrity": "sha512-UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA==", + "dev": true, + "requires": { + "ajv": "^5.2.3", + "ajv-keywords": "^2.1.0", + "chalk": "^2.1.0", + "lodash": "^4.17.4", + "slice-ansi": "1.0.0", + "string-width": "^2.1.1" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "taffydb": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", + "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", + "dev": true + }, + "tape": { + "version": "4.9.0", + "resolved": "https://registry.npmjs.org/tape/-/tape-4.9.0.tgz", + "integrity": "sha512-j0jO9BiScfqtPBb9QmPLL0qvxXMz98xjkMb7x8lKipFlJZwNJkqkWPou+NU4V6T9RnVh1kuSthLE8gLrN8bBfw==", + "dev": true, + "requires": { + "deep-equal": "~1.0.1", + "defined": "~1.0.0", + "for-each": "~0.3.2", + "function-bind": "~1.1.1", + "glob": "~7.1.2", + "has": "~1.0.1", + "inherits": "~2.0.3", + "minimist": "~1.2.0", + "object-inspect": "~1.5.0", + "resolve": "~1.5.0", + "resumer": "~0.0.0", + "string.prototype.trim": "~1.1.2", + "through": "~2.3.8" + }, + "dependencies": { + "resolve": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", + "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", + "dev": true, + "requires": { + "path-parse": "^1.0.5" + } + } + } + }, + "ternary-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/ternary-stream/-/ternary-stream-2.0.1.tgz", + "integrity": "sha1-Bk5Im0tb9gumpre8fy9cJ07Pgmk=", + "dev": true, + "requires": { + "duplexify": "^3.5.0", + "fork-stream": "^0.0.4", + "merge-stream": "^1.0.0", + "through2": "^2.0.1" + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", + "dev": true + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "through2": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", + "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", + "dev": true, + "requires": { + "readable-stream": "^2.1.5", + "xtend": "~4.0.1" + } + }, + "through2-filter": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/through2-filter/-/through2-filter-2.0.0.tgz", + "integrity": "sha1-YLxVoNrLdghdsfna6Zq0P4PWIuw=", + "dev": true, + "requires": { + "through2": "~2.0.0", + "xtend": "~4.0.0" + } + }, + "time-stamp": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/time-stamp/-/time-stamp-1.1.0.tgz", + "integrity": "sha1-dkpaEa9QVhkhsTPztE5hhofg9cM=", + "dev": true + }, + "timers-browserify": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-1.4.2.tgz", + "integrity": "sha1-ycWLV1voQHN1y14kYtrO50NZ9B0=", + "dev": true, + "requires": { + "process": "~0.11.0" + } + }, + "timers-ext": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.5.tgz", + "integrity": "sha512-tsEStd7kmACHENhsUPaxb8Jf8/+GZZxyNFQbZD07HQOyooOa6At1rQqjffgvg7n+dxscQa9cjjMdWhJtsP2sxg==", + "dev": true, + "requires": { + "es5-ext": "~0.10.14", + "next-tick": "1" + } + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", + "dev": true + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "to-through": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-through/-/to-through-2.0.0.tgz", + "integrity": "sha1-/JKtq6ByZHvAtn1rA2ZKoZUJOvY=", + "dev": true, + "requires": { + "through2": "^2.0.3" + } + }, + "trim-newlines": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", + "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", + "dev": true + }, + "tslib": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.1.tgz", + "integrity": "sha512-avfPS28HmGLLc2o4elcc2EIq2FcH++Yo5YxpBZi9Yw93BCTGFthI4HPE4Rpep6vSYQaK8e69PelM44tPj+RaQg==", + "dev": true + }, + "tslint": { + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/tslint/-/tslint-5.10.0.tgz", + "integrity": "sha1-EeJrzLiK+gLdDZlWyuPUVAtfVMM=", + "dev": true, + "requires": { + "babel-code-frame": "^6.22.0", + "builtin-modules": "^1.1.1", + "chalk": "^2.3.0", + "commander": "^2.12.1", + "diff": "^3.2.0", + "glob": "^7.1.1", + "js-yaml": "^3.7.0", + "minimatch": "^3.0.4", + "resolve": "^1.3.2", + "semver": "^5.3.0", + "tslib": "^1.8.0", + "tsutils": "^2.12.1" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", + "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "commander": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz", + "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "supports-color": { + "version": "5.4.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", + "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "tsutils": { + "version": "2.27.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.27.0.tgz", + "integrity": "sha512-JcyX25oM9pFcb3zh60OqG1St8p/uSqC5Bgipdo3ieacB/Ao4dPhm7hAtKT9NrEu23CyYrrgJPV3CqYfo+/+T4w==", + "dev": true, + "requires": { + "tslib": "^1.8.1" + } + }, + "tty-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.1.tgz", + "integrity": "sha512-C3TaO7K81YvjCgQH9Q1S3R3P3BtN3RIM8n+OvX4il1K1zgE8ZhI0op7kClgkxtutIE8hQrcrHBXvIheqKUUCxw==", + "dev": true + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true, + "requires": { + "prelude-ls": "~1.1.2" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", + "dev": true + }, + "typescript": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-2.8.3.tgz", + "integrity": "sha512-K7g15Bb6Ra4lKf7Iq2l/I5/En+hLIHmxWZGq3D4DIRNFxMNV6j2SHSvDOqs2tGd4UvD/fJvrwopzQXjLrT7Itw==", + "dev": true + }, + "uglify-js": { + "version": "3.3.25", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.3.25.tgz", + "integrity": "sha512-hobogryjDV36VrLK3Y69ou4REyrTApzUblVFmdQOYRe8cYaSmFJXMb4dR9McdvYDSbeNdzUgYr2YVukJaErJcA==", + "dev": true, + "requires": { + "commander": "~2.15.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "commander": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz", + "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "uglify-to-browserify": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", + "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", + "dev": true, + "optional": true + }, + "umd": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/umd/-/umd-3.0.3.tgz", + "integrity": "sha512-4IcGSufhFshvLNcMCV80UnQVlZ5pMOC8mvNPForqwA4+lzYQuetTESLDQkeLmihq8bRcnpbQa48Wb8Lh16/xow==", + "dev": true + }, + "unc-path-regex": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/unc-path-regex/-/unc-path-regex-0.1.2.tgz", + "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=", + "dev": true + }, + "underscore": { + "version": "1.8.3", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.8.3.tgz", + "integrity": "sha1-Tz+1OxBuYJf8+ctBCfKl6b36UCI=", + "dev": true + }, + "underscore-contrib": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/underscore-contrib/-/underscore-contrib-0.3.0.tgz", + "integrity": "sha1-ZltmwkeD+PorGMn4y7Dix9SMJsc=", + "dev": true, + "requires": { + "underscore": "1.6.0" + }, + "dependencies": { + "underscore": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.6.0.tgz", + "integrity": "sha1-izixDKze9jM3uLJOT/htRa6lKag=", + "dev": true + } + } + }, + "undertaker": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/undertaker/-/undertaker-1.2.0.tgz", + "integrity": "sha1-M52kZGJS0ILcN45wgGcpl1DhG0k=", + "dev": true, + "requires": { + "arr-flatten": "^1.0.1", + "arr-map": "^2.0.0", + "bach": "^1.0.0", + "collection-map": "^1.0.0", + "es6-weak-map": "^2.0.1", + "last-run": "^1.1.0", + "object.defaults": "^1.0.0", + "object.reduce": "^1.0.0", + "undertaker-registry": "^1.0.0" + } + }, + "undertaker-registry": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/undertaker-registry/-/undertaker-registry-1.0.1.tgz", + "integrity": "sha1-XkvaMI5KiirlhPm5pDWaSZglzFA=", + "dev": true + }, + "union-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", + "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^0.4.3" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "set-value": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", + "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.1", + "to-object-path": "^0.3.0" + } + } + } + }, + "unique-stream": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/unique-stream/-/unique-stream-2.2.1.tgz", + "integrity": "sha1-WqADz76Uxf+GbE59ZouxxNuts2k=", + "dev": true, + "requires": { + "json-stable-stringify": "^1.0.0", + "through2-filter": "^2.0.0" + }, + "dependencies": { + "json-stable-stringify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", + "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", + "dev": true, + "requires": { + "jsonify": "~0.0.0" + } + } + } + }, + "universalify": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.1.tgz", + "integrity": "sha1-+nG63UQ3r0wUiEHjs7Fl+enlkLc=", + "dev": true + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true + } + } + }, + "upath": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz", + "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", + "dev": true + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "dev": true, + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", + "dev": true + } + } + }, + "use": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.0.tgz", + "integrity": "sha512-6UJEQM/L+mzC3ZJNM56Q4DFGLX/evKGRg15UJHGB9X5j5Z3AFbgZvjUh2yq/UJUY4U5dh7Fal++XbNg1uzpRAw==", + "dev": true, + "requires": { + "kind-of": "^6.0.2" + } + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "dev": true, + "requires": { + "inherits": "2.0.1" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", + "dev": true + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true + }, + "v8flags": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.0.tgz", + "integrity": "sha512-0m69VIK2dudEf2Ub0xwLQhZkDZu85OmiOpTw+UGDt56ibviYICHziM/3aE+oVg7IjGPp0c83w3eSVqa+lYZ9UQ==", + "dev": true, + "requires": { + "homedir-polyfill": "^1.0.1" + } + }, + "validate-npm-package-license": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.3.tgz", + "integrity": "sha512-63ZOUnL4SIXj4L0NixR3L1lcjO38crAbgrTpl28t8jjrfuiOBL5Iygm+60qPs/KsZGzPNg6Smnc/oY16QTjF0g==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "value-or-function": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/value-or-function/-/value-or-function-3.0.0.tgz", + "integrity": "sha1-HCQ6ULWVwb5Up1S/7OhWO5/42BM=", + "dev": true + }, + "vinyl": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.1.0.tgz", + "integrity": "sha1-Ah+cLPlR1rk5lDyJ617lrdT9kkw=", + "dev": true, + "requires": { + "clone": "^2.1.1", + "clone-buffer": "^1.0.0", + "clone-stats": "^1.0.0", + "cloneable-readable": "^1.0.0", + "remove-trailing-separator": "^1.0.1", + "replace-ext": "^1.0.0" + }, + "dependencies": { + "clone": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.1.tgz", + "integrity": "sha1-0hfR6WERjjrJpLi7oyhVU79kfNs=", + "dev": true + }, + "clone-stats": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", + "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", + "dev": true + }, + "replace-ext": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-1.0.0.tgz", + "integrity": "sha1-3mMSg3P8v3w8z6TeWkgMRaZ5WOs=", + "dev": true + } + } + }, + "vinyl-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/vinyl-buffer/-/vinyl-buffer-1.0.1.tgz", + "integrity": "sha1-lsGjR5uMU5JULGEgKQE7Wyf4i78=", + "dev": true, + "requires": { + "bl": "^1.2.1", + "through2": "^2.0.3" + } + }, + "vinyl-fs": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-3.0.3.tgz", + "integrity": "sha512-vIu34EkyNyJxmP0jscNzWBSygh7VWhqun6RmqVfXePrOwi9lhvRs//dOaGOTRUQr4tx7/zd26Tk5WeSVZitgng==", + "dev": true, + "requires": { + "fs-mkdirp-stream": "^1.0.0", + "glob-stream": "^6.1.0", + "graceful-fs": "^4.0.0", + "is-valid-glob": "^1.0.0", + "lazystream": "^1.0.0", + "lead": "^1.0.0", + "object.assign": "^4.0.4", + "pumpify": "^1.3.5", + "readable-stream": "^2.3.3", + "remove-bom-buffer": "^3.0.0", + "remove-bom-stream": "^1.2.0", + "resolve-options": "^1.1.0", + "through2": "^2.0.0", + "to-through": "^2.0.0", + "value-or-function": "^3.0.0", + "vinyl": "^2.0.0", + "vinyl-sourcemap": "^1.1.0" + } + }, + "vinyl-source-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/vinyl-source-stream/-/vinyl-source-stream-2.0.0.tgz", + "integrity": "sha1-84pa+53R6Ttl1VBGmsYYKsT1S44=", + "dev": true, + "requires": { + "through2": "^2.0.3", + "vinyl": "^2.1.0" + } + }, + "vinyl-sourcemap": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/vinyl-sourcemap/-/vinyl-sourcemap-1.1.0.tgz", + "integrity": "sha1-kqgAWTo4cDqM2xHYswCtS+Y7PhY=", + "dev": true, + "requires": { + "append-buffer": "^1.0.2", + "convert-source-map": "^1.5.0", + "graceful-fs": "^4.1.6", + "normalize-path": "^2.1.1", + "now-and-later": "^2.0.0", + "remove-bom-buffer": "^3.0.0", + "vinyl": "^2.0.0" + }, + "dependencies": { + "convert-source-map": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", + "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", + "dev": true + } + } + }, + "vinyl-sourcemaps-apply": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/vinyl-sourcemaps-apply/-/vinyl-sourcemaps-apply-0.2.1.tgz", + "integrity": "sha1-q2VJ1h0XLCsbh75cUI0jnI74dwU=", + "dev": true, + "requires": { + "source-map": "^0.5.1" + } + }, + "vm-browserify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.0.1.tgz", + "integrity": "sha512-EqzLchIMYLBjRPoqVsEkZOa/4Vr2RfOWbd58F+I/Gj79AYTrsseMunxbbSkbYfrqZaXSuPBBXNSOhtJgg0PpmA==", + "dev": true + }, + "which": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", + "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", + "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=", + "dev": true + }, + "window-size": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", + "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=", + "dev": true, + "optional": true + }, + "wordwrap": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", + "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "dev": true, + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "write": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", + "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", + "dev": true, + "requires": { + "mkdirp": "^0.5.1" + } + }, + "xmlcreate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-1.0.2.tgz", + "integrity": "sha1-+mv3YqYKQT+z3Y9LA8WyaSONMI8=", + "dev": true + }, + "xtend": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", + "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", + "dev": true + }, + "y18n": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", + "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + }, + "yargs": { + "version": "3.10.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", + "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", + "dev": true, + "optional": true, + "requires": { + "camelcase": "^1.0.2", + "cliui": "^2.1.0", + "decamelize": "^1.0.0", + "window-size": "0.1.0" + }, + "dependencies": { + "camelcase": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", + "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=", + "dev": true, + "optional": true + } + } + }, + "yargs-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-5.0.0.tgz", + "integrity": "sha1-J17PDX/+Bcd+ZOfIbkzZS/DhIoo=", + "dev": true, + "requires": { + "camelcase": "^3.0.0" + }, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", + "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", + "dev": true + } + } + } + } +} diff --git a/node_modules/protobufjs/package.json b/node_modules/protobufjs/package.json new file mode 100644 index 0000000..2ab99c7 --- /dev/null +++ b/node_modules/protobufjs/package.json @@ -0,0 +1,152 @@ +{ + "_from": "protobufjs@~6.8.6", + "_id": "protobufjs@6.8.8", + "_inBundle": false, + "_integrity": "sha512-AAmHtD5pXgZfi7GMpllpO3q1Xw1OYldr+dMUlAnffGTAhqkg72WdmSY71uKBF/JuyiKs8psYbtKrhi0ASCD8qw==", + "_location": "/protobufjs", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "protobufjs@~6.8.6", + "name": "protobufjs", + "escapedName": "protobufjs", + "rawSpec": "~6.8.6", + "saveSpec": null, + "fetchSpec": "~6.8.6" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-converter" + ], + "_resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.8.tgz", + "_shasum": "c8b4f1282fd7a90e6f5b109ed11c84af82908e7c", + "_spec": "protobufjs@~6.8.6", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-converter", + "author": { + "name": "Daniel Wirtz", + "email": "dcode+protobufjs@dcode.io" + }, + "bin": { + "pbjs": "bin/pbjs", + "pbts": "bin/pbts" + }, + "bugs": { + "url": "https://github.com/dcodeIO/protobuf.js/issues" + }, + "bundleDependencies": false, + "cliDependencies": [ + "semver", + "chalk", + "glob", + "jsdoc", + "minimist", + "tmp", + "uglify-js", + "espree", + "escodegen", + "estraverse" + ], + "dependencies": { + "@protobufjs/aspromise": "^1.1.2", + "@protobufjs/base64": "^1.1.2", + "@protobufjs/codegen": "^2.0.4", + "@protobufjs/eventemitter": "^1.1.0", + "@protobufjs/fetch": "^1.1.0", + "@protobufjs/float": "^1.0.2", + "@protobufjs/inquire": "^1.1.0", + "@protobufjs/path": "^1.1.2", + "@protobufjs/pool": "^1.1.0", + "@protobufjs/utf8": "^1.1.0", + "@types/long": "^4.0.0", + "@types/node": "^10.1.0", + "long": "^4.0.0" + }, + "deprecated": false, + "description": "Protocol Buffers for JavaScript (& TypeScript).", + "devDependencies": { + "benchmark": "^2.1.4", + "browserify": "^16.2.2", + "browserify-wrap": "^1.0.2", + "bundle-collapser": "^1.3.0", + "chalk": "^2.4.1", + "escodegen": "^1.9.1", + "eslint": "^4.19.1", + "espree": "^3.5.4", + "estraverse": "^4.2.0", + "gh-pages": "^1.1.0", + "git-raw-commits": "^1.3.6", + "git-semver-tags": "^1.3.6", + "glob": "^7.1.2", + "google-protobuf": "^3.5.0", + "gulp": "^4.0.0", + "gulp-header": "^2.0.5", + "gulp-if": "^2.0.1", + "gulp-sourcemaps": "^2.6.4", + "gulp-uglify": "^3.0.0", + "istanbul": "^0.4.5", + "jaguarjs-jsdoc": "github:dcodeIO/jaguarjs-jsdoc", + "jsdoc": "^3.5.5", + "minimist": "^1.2.0", + "reflect-metadata": "^0.1.12", + "semver": "^5.5.0", + "tape": "^4.9.0", + "tmp": "0.0.33", + "tslint": "^5.10.0", + "typescript": "^2.8.3", + "uglify-js": "^3.3.25", + "vinyl-buffer": "^1.0.1", + "vinyl-fs": "^3.0.3", + "vinyl-source-stream": "^2.0.0" + }, + "files": [ + "index.js", + "index.d.ts", + "light.d.ts", + "light.js", + "minimal.d.ts", + "minimal.js", + "package-lock.json", + "tsconfig.json", + "scripts/postinstall.js", + "bin/**", + "cli/**", + "dist/**", + "ext/**", + "google/**", + "src/**" + ], + "homepage": "http://dcode.io/protobuf.js", + "keywords": [ + "protobuf", + "protocol-buffers", + "serialization", + "typescript" + ], + "license": "BSD-3-Clause", + "main": "index.js", + "name": "protobufjs", + "repository": { + "type": "git", + "url": "git+https://github.com/dcodeIO/protobuf.js.git" + }, + "scripts": { + "bench": "node bench", + "build": "gulp --gulpfile scripts/gulpfile.js", + "changelog": "node scripts/changelog -w", + "coverage": "istanbul --config=config/istanbul.json cover node_modules/tape/bin/tape tests/*.js tests/node/*.js", + "docs": "jsdoc -c config/jsdoc.json -R README.md --verbose --pedantic", + "lint": "eslint **/*.js -c config/eslint.json && tslint **/*.d.ts -e **/node_modules/** -t stylish -c config/tslint.json", + "make": "npm run test && npm run types && npm run build && npm run lint", + "pages": "node scripts/pages", + "postinstall": "node scripts/postinstall", + "prepublish": "node scripts/prepublish", + "prof": "node bench/prof", + "release": "npm run make && npm run changelog", + "test": "tape -r ./lib/tape-adapter tests/*.js tests/node/*.js", + "test-types": "tsc tests/comp_typescript.ts --lib es2015 --strictNullChecks --experimentalDecorators --emitDecoratorMetadata && tsc tests/data/test.js.ts --lib es2015 --noEmit --strictNullChecks && tsc tests/data/rpc.ts --lib es2015 --noEmit --strictNullChecks", + "types": "node bin/pbts --main --global protobuf --out index.d.ts src/ lib/aspromise/index.js lib/base64/index.js lib/codegen/index.js lib/eventemitter/index.js lib/float/index.js lib/fetch/index.js lib/inquire/index.js lib/path/index.js lib/pool/index.js lib/utf8/index.js && npm run test-types" + }, + "types": "index.d.ts", + "version": "6.8.8", + "versionScheme": "~" +} diff --git a/node_modules/protobufjs/scripts/changelog.js b/node_modules/protobufjs/scripts/changelog.js new file mode 100644 index 0000000..d806b6b --- /dev/null +++ b/node_modules/protobufjs/scripts/changelog.js @@ -0,0 +1,150 @@ +"use strict"; + +var path = require("path"), + fs = require("fs"); + +var gitSemverTags = require("git-semver-tags"), + gitRawCommits = require("git-raw-commits"), + minimist = require("minimist"); + +var basedir = path.join(__dirname, ".."); +var pkg = require(basedir + "/package.json"); + +var argv = minimist(process.argv, { + alias: { + tag : "t", + write : "w" + }, + string: [ "tag" ], + boolean: [ "write" ], + default: { + tag: null, + write: false + } +}); + +// categories to be used in the future and regexes for lazy / older subjects +var validCategories = { + "Breaking": null, + "Fixed": /fix|properly|prevent|correctly/i, + "New": /added|initial/i, + "CLI": /pbjs|pbts|CLI/, + "Docs": /README/i, + "Other": null +}; +var breakingFallback = /removed|stripped|dropped/i; + +var repo = "https://github.com/dcodeIO/protobuf.js"; + +gitSemverTags(function(err, tags) { + if (err) + throw err; + + var categories = {}; + Object.keys(validCategories).forEach(function(category) { + categories[category] = []; + }); + var output = []; + + var from = tags[0]; + var to = "HEAD"; + var tag; + if (argv.tag) { + var idx = tags.indexOf(argv.tag); + if (idx < 0) + throw Error("no such tag: " + argv.tag); + from = tags[idx + 1]; + tag = to = tags[idx]; + } else + tag = pkg.version; + + var commits = gitRawCommits({ + from: from, + to: to, + merges: false, + format: "%B%n#%H" + }); + + commits.on("error", function(err) { + throw err; + }); + + commits.on("data", function(chunk) { + var message = chunk.toString("utf8").trim(); + var match = /#([0-9a-f]{40})$/.exec(message); + var hash; + if (match) { + message = message.substring(0, message.length - match[1].length).trim(); + hash = match[1]; + } + message.split(";").forEach(function(message) { + if (/^(Merge pull request |Post-merge)/.test(message)) + return; + var match = /^(\w+):/i.exec(message = message.trim()); + var category; + if (match && match[1] in validCategories) { + category = match[1]; + message = message.substring(match[1].length + 1).trim(); + } else { + var keys = Object.keys(validCategories); + for (var i = 0; i < keys.length; ++i) { + var re = validCategories[keys[i]]; + if (re && re.test(message)) { + category = keys[i]; + break; + } + } + message = message.replace(/^(\w+):/i, "").trim(); + } + if (!category) { + if (breakingFallback.test(message)) + category = "Breaking"; + else + category = "Other"; + } + var nl = message.indexOf("\n"); + if (nl > -1) + message = message.substring(0, nl).trim(); + if (!hash || message.length < 12) + return; + message = message.replace(/\[ci skip\]/, "").trim(); + categories[category].push({ + text: message, + hash: hash + }); + }); + }); + + commits.on("end", function() { + output.push("# [" + tag + "](" + repo + "/releases/tag/" + tag + ")\n"); + Object.keys(categories).forEach(function(category) { + var messages = categories[category]; + if (!messages.length) + return; + output.push("\n## " + category + "\n"); + messages.forEach(function(message) { + var text = message.text.replace(/#(\d+)/g, "[#$1](" + repo + "/issues/$1)"); + output.push("[:hash:](" + repo + "/commit/" + message.hash + ") " + text + "
\n"); + }); + }); + var current; + try { + current = fs.readFileSync(basedir + "/CHANGELOG.md").toString("utf8"); + } catch (e) { + current = ""; + } + var re = new RegExp("^# \\[" + tag + "\\]"); + if (re.test(current)) { // regenerated, replace + var pos = current.indexOf("# [", 1); + if (pos > -1) + current = current.substring(pos).trim(); + else + current = ""; + } + var contents = output.join("") + "\n" + current; + if (argv.write) + fs.writeFileSync(basedir + "/CHANGELOG.md", contents, "utf8"); + else + process.stdout.write(contents); + }); +}); diff --git a/node_modules/protobufjs/scripts/postinstall.js b/node_modules/protobufjs/scripts/postinstall.js new file mode 100644 index 0000000..37898b6 --- /dev/null +++ b/node_modules/protobufjs/scripts/postinstall.js @@ -0,0 +1,35 @@ +"use strict"; + +var path = require("path"), + fs = require("fs"), + pkg = require(path.join(__dirname, "..", "package.json")); + +// ensure that there is a node_modules folder for cli dependencies +try { fs.mkdirSync(path.join(__dirname, "..", "cli", "node_modules")); } catch (e) {/**/} + +// check version scheme used by dependents +if (!pkg.versionScheme) + return; + +var warn = process.stderr.isTTY + ? "\x1b[30m\x1b[43mWARN\x1b[0m \x1b[35m" + path.basename(process.argv[1], ".js") + "\x1b[0m" + : "WARN " + path.basename(process.argv[1], ".js"); + +var basePkg; +try { + basePkg = JSON.parse(fs.readFileSync(path.join(__dirname, "..", "..", "package.json"))); +} catch (e) { + return; +} + +[ + "dependencies", + "devDependencies", + "optionalDependencies", + "peerDependencies" +] +.forEach(function(check) { + var version = basePkg && basePkg[check] && basePkg[check][pkg.name]; + if (typeof version === "string" && version.charAt(0) !== pkg.versionScheme) + process.stderr.write(pkg.name + " " + warn + " " + pkg.name + "@" + version + " is configured as a dependency of " + basePkg.name + ". use " + pkg.name + "@" + pkg.versionScheme + version.substring(1) + " instead for API compatibility.\n"); +}); diff --git a/node_modules/protobufjs/src/common.js b/node_modules/protobufjs/src/common.js new file mode 100644 index 0000000..489ee1c --- /dev/null +++ b/node_modules/protobufjs/src/common.js @@ -0,0 +1,399 @@ +"use strict"; +module.exports = common; + +var commonRe = /\/|\./; + +/** + * Provides common type definitions. + * Can also be used to provide additional google types or your own custom types. + * @param {string} name Short name as in `google/protobuf/[name].proto` or full file name + * @param {Object.} json JSON definition within `google.protobuf` if a short name, otherwise the file's root definition + * @returns {undefined} + * @property {INamespace} google/protobuf/any.proto Any + * @property {INamespace} google/protobuf/duration.proto Duration + * @property {INamespace} google/protobuf/empty.proto Empty + * @property {INamespace} google/protobuf/field_mask.proto FieldMask + * @property {INamespace} google/protobuf/struct.proto Struct, Value, NullValue and ListValue + * @property {INamespace} google/protobuf/timestamp.proto Timestamp + * @property {INamespace} google/protobuf/wrappers.proto Wrappers + * @example + * // manually provides descriptor.proto (assumes google/protobuf/ namespace and .proto extension) + * protobuf.common("descriptor", descriptorJson); + * + * // manually provides a custom definition (uses my.foo namespace) + * protobuf.common("my/foo/bar.proto", myFooBarJson); + */ +function common(name, json) { + if (!commonRe.test(name)) { + name = "google/protobuf/" + name + ".proto"; + json = { nested: { google: { nested: { protobuf: { nested: json } } } } }; + } + common[name] = json; +} + +// Not provided because of limited use (feel free to discuss or to provide yourself): +// +// google/protobuf/descriptor.proto +// google/protobuf/source_context.proto +// google/protobuf/type.proto +// +// Stripped and pre-parsed versions of these non-bundled files are instead available as part of +// the repository or package within the google/protobuf directory. + +common("any", { + + /** + * Properties of a google.protobuf.Any message. + * @interface IAny + * @type {Object} + * @property {string} [typeUrl] + * @property {Uint8Array} [bytes] + * @memberof common + */ + Any: { + fields: { + type_url: { + type: "string", + id: 1 + }, + value: { + type: "bytes", + id: 2 + } + } + } +}); + +var timeType; + +common("duration", { + + /** + * Properties of a google.protobuf.Duration message. + * @interface IDuration + * @type {Object} + * @property {number|Long} [seconds] + * @property {number} [nanos] + * @memberof common + */ + Duration: timeType = { + fields: { + seconds: { + type: "int64", + id: 1 + }, + nanos: { + type: "int32", + id: 2 + } + } + } +}); + +common("timestamp", { + + /** + * Properties of a google.protobuf.Timestamp message. + * @interface ITimestamp + * @type {Object} + * @property {number|Long} [seconds] + * @property {number} [nanos] + * @memberof common + */ + Timestamp: timeType +}); + +common("empty", { + + /** + * Properties of a google.protobuf.Empty message. + * @interface IEmpty + * @memberof common + */ + Empty: { + fields: {} + } +}); + +common("struct", { + + /** + * Properties of a google.protobuf.Struct message. + * @interface IStruct + * @type {Object} + * @property {Object.} [fields] + * @memberof common + */ + Struct: { + fields: { + fields: { + keyType: "string", + type: "Value", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Value message. + * @interface IValue + * @type {Object} + * @property {string} [kind] + * @property {0} [nullValue] + * @property {number} [numberValue] + * @property {string} [stringValue] + * @property {boolean} [boolValue] + * @property {IStruct} [structValue] + * @property {IListValue} [listValue] + * @memberof common + */ + Value: { + oneofs: { + kind: { + oneof: [ + "nullValue", + "numberValue", + "stringValue", + "boolValue", + "structValue", + "listValue" + ] + } + }, + fields: { + nullValue: { + type: "NullValue", + id: 1 + }, + numberValue: { + type: "double", + id: 2 + }, + stringValue: { + type: "string", + id: 3 + }, + boolValue: { + type: "bool", + id: 4 + }, + structValue: { + type: "Struct", + id: 5 + }, + listValue: { + type: "ListValue", + id: 6 + } + } + }, + + NullValue: { + values: { + NULL_VALUE: 0 + } + }, + + /** + * Properties of a google.protobuf.ListValue message. + * @interface IListValue + * @type {Object} + * @property {Array.} [values] + * @memberof common + */ + ListValue: { + fields: { + values: { + rule: "repeated", + type: "Value", + id: 1 + } + } + } +}); + +common("wrappers", { + + /** + * Properties of a google.protobuf.DoubleValue message. + * @interface IDoubleValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + DoubleValue: { + fields: { + value: { + type: "double", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.FloatValue message. + * @interface IFloatValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + FloatValue: { + fields: { + value: { + type: "float", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Int64Value message. + * @interface IInt64Value + * @type {Object} + * @property {number|Long} [value] + * @memberof common + */ + Int64Value: { + fields: { + value: { + type: "int64", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.UInt64Value message. + * @interface IUInt64Value + * @type {Object} + * @property {number|Long} [value] + * @memberof common + */ + UInt64Value: { + fields: { + value: { + type: "uint64", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.Int32Value message. + * @interface IInt32Value + * @type {Object} + * @property {number} [value] + * @memberof common + */ + Int32Value: { + fields: { + value: { + type: "int32", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.UInt32Value message. + * @interface IUInt32Value + * @type {Object} + * @property {number} [value] + * @memberof common + */ + UInt32Value: { + fields: { + value: { + type: "uint32", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.BoolValue message. + * @interface IBoolValue + * @type {Object} + * @property {boolean} [value] + * @memberof common + */ + BoolValue: { + fields: { + value: { + type: "bool", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.StringValue message. + * @interface IStringValue + * @type {Object} + * @property {string} [value] + * @memberof common + */ + StringValue: { + fields: { + value: { + type: "string", + id: 1 + } + } + }, + + /** + * Properties of a google.protobuf.BytesValue message. + * @interface IBytesValue + * @type {Object} + * @property {Uint8Array} [value] + * @memberof common + */ + BytesValue: { + fields: { + value: { + type: "bytes", + id: 1 + } + } + } +}); + +common("field_mask", { + + /** + * Properties of a google.protobuf.FieldMask message. + * @interface IDoubleValue + * @type {Object} + * @property {number} [value] + * @memberof common + */ + FieldMask: { + fields: { + paths: { + rule: "repeated", + type: "string", + id: 1 + } + } + } +}); + +/** + * Gets the root definition of the specified common proto file. + * + * Bundled definitions are: + * - google/protobuf/any.proto + * - google/protobuf/duration.proto + * - google/protobuf/empty.proto + * - google/protobuf/field_mask.proto + * - google/protobuf/struct.proto + * - google/protobuf/timestamp.proto + * - google/protobuf/wrappers.proto + * + * @param {string} file Proto file name + * @returns {INamespace|null} Root definition or `null` if not defined + */ +common.get = function get(file) { + return common[file] || null; +}; diff --git a/node_modules/protobufjs/src/converter.js b/node_modules/protobufjs/src/converter.js new file mode 100644 index 0000000..44d952e --- /dev/null +++ b/node_modules/protobufjs/src/converter.js @@ -0,0 +1,293 @@ +"use strict"; +/** + * Runtime message from/to plain object converters. + * @namespace + */ +var converter = exports; + +var Enum = require("./enum"), + util = require("./util"); + +/** + * Generates a partial value fromObject conveter. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} prop Property reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genValuePartial_fromObject(gen, field, fieldIndex, prop) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(d%s){", prop); + for (var values = field.resolvedType.values, keys = Object.keys(values), i = 0; i < keys.length; ++i) { + if (field.repeated && values[keys[i]] === field.typeDefault) gen + ("default:"); + gen + ("case%j:", keys[i]) + ("case %i:", values[keys[i]]) + ("m%s=%j", prop, values[keys[i]]) + ("break"); + } gen + ("}"); + } else gen + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s=types[%i].fromObject(d%s)", prop, fieldIndex, prop); + } else { + var isUnsigned = false; + switch (field.type) { + case "double": + case "float": gen + ("m%s=Number(d%s)", prop, prop); // also catches "NaN", "Infinity" + break; + case "uint32": + case "fixed32": gen + ("m%s=d%s>>>0", prop, prop); + break; + case "int32": + case "sint32": + case "sfixed32": gen + ("m%s=d%s|0", prop, prop); + break; + case "uint64": + isUnsigned = true; + // eslint-disable-line no-fallthrough + case "int64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(util.Long)") + ("(m%s=util.Long.fromValue(d%s)).unsigned=%j", prop, prop, isUnsigned) + ("else if(typeof d%s===\"string\")", prop) + ("m%s=parseInt(d%s,10)", prop, prop) + ("else if(typeof d%s===\"number\")", prop) + ("m%s=d%s", prop, prop) + ("else if(typeof d%s===\"object\")", prop) + ("m%s=new util.LongBits(d%s.low>>>0,d%s.high>>>0).toNumber(%s)", prop, prop, prop, isUnsigned ? "true" : ""); + break; + case "bytes": gen + ("if(typeof d%s===\"string\")", prop) + ("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)", prop, prop, prop) + ("else if(d%s.length)", prop) + ("m%s=d%s", prop, prop); + break; + case "string": gen + ("m%s=String(d%s)", prop, prop); + break; + case "bool": gen + ("m%s=Boolean(d%s)", prop, prop); + break; + /* default: gen + ("m%s=d%s", prop, prop); + break; */ + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a plain object to runtime message converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.fromObject = function fromObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray; + var gen = util.codegen(["d"], mtype.name + "$fromObject") + ("if(d instanceof this.ctor)") + ("return d"); + if (!fields.length) return gen + ("return new this.ctor"); + gen + ("var m=new this.ctor"); + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + prop = util.safeProp(field.name); + + // Map fields + if (field.map) { gen + ("if(d%s){", prop) + ("if(typeof d%s!==\"object\")", prop) + ("throw TypeError(%j)", field.fullName + ": object expected") + ("m%s={}", prop) + ("for(var ks=Object.keys(d%s),i=0;i>>0,m%s.high>>>0).toNumber(%s):m%s", prop, prop, prop, prop, isUnsigned ? "true": "", prop); + break; + case "bytes": gen + ("d%s=o.bytes===String?util.base64.encode(m%s,0,m%s.length):o.bytes===Array?Array.prototype.slice.call(m%s):m%s", prop, prop, prop, prop, prop); + break; + default: gen + ("d%s=m%s", prop, prop); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} + +/** + * Generates a runtime message to plain object converter specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +converter.toObject = function toObject(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var fields = mtype.fieldsArray.slice().sort(util.compareFieldsById); + if (!fields.length) + return util.codegen()("return {}"); + var gen = util.codegen(["m", "o"], mtype.name + "$toObject") + ("if(!o)") + ("o={}") + ("var d={}"); + + var repeatedFields = [], + mapFields = [], + normalFields = [], + i = 0; + for (; i < fields.length; ++i) + if (!fields[i].partOf) + ( fields[i].resolve().repeated ? repeatedFields + : fields[i].map ? mapFields + : normalFields).push(fields[i]); + + if (repeatedFields.length) { gen + ("if(o.arrays||o.defaults){"); + for (i = 0; i < repeatedFields.length; ++i) gen + ("d%s=[]", util.safeProp(repeatedFields[i].name)); + gen + ("}"); + } + + if (mapFields.length) { gen + ("if(o.objects||o.defaults){"); + for (i = 0; i < mapFields.length; ++i) gen + ("d%s={}", util.safeProp(mapFields[i].name)); + gen + ("}"); + } + + if (normalFields.length) { gen + ("if(o.defaults){"); + for (i = 0; i < normalFields.length; ++i) { + var field = normalFields[i], + prop = util.safeProp(field.name); + if (field.resolvedType instanceof Enum) gen + ("d%s=o.enums===String?%j:%j", prop, field.resolvedType.valuesById[field.typeDefault], field.typeDefault); + else if (field.long) gen + ("if(util.Long){") + ("var n=new util.Long(%i,%i,%j)", field.typeDefault.low, field.typeDefault.high, field.typeDefault.unsigned) + ("d%s=o.longs===String?n.toString():o.longs===Number?n.toNumber():n", prop) + ("}else") + ("d%s=o.longs===String?%j:%i", prop, field.typeDefault.toString(), field.typeDefault.toNumber()); + else if (field.bytes) { + var arrayDefault = "[" + Array.prototype.slice.call(field.typeDefault).join(",") + "]"; + gen + ("if(o.bytes===String)d%s=%j", prop, String.fromCharCode.apply(String, field.typeDefault)) + ("else{") + ("d%s=%s", prop, arrayDefault) + ("if(o.bytes!==Array)d%s=util.newBuffer(d%s)", prop, prop) + ("}"); + } else gen + ("d%s=%j", prop, field.typeDefault); // also messages (=null) + } gen + ("}"); + } + var hasKs2 = false; + for (i = 0; i < fields.length; ++i) { + var field = fields[i], + index = mtype._fieldsArray.indexOf(field), + prop = util.safeProp(field.name); + if (field.map) { + if (!hasKs2) { hasKs2 = true; gen + ("var ks2"); + } gen + ("if(m%s&&(ks2=Object.keys(m%s)).length){", prop, prop) + ("d%s={}", prop) + ("for(var j=0;j>>3){"); + + var i = 0; + for (; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + ref = "m" + util.safeProp(field.name); gen + ("case %i:", field.id); + + // Map fields + if (field.map) { gen + ("r.skip().pos++") // assumes id 1 + key wireType + ("if(%s===util.emptyObject)", ref) + ("%s={}", ref) + ("k=r.%s()", field.keyType) + ("r.pos++"); // assumes id 2 + value wireType + if (types.long[field.keyType] !== undefined) { + if (types.basic[type] === undefined) gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[typeof k===\"object\"?util.longToHash(k):k]=r.%s()", ref, type); + } else { + if (types.basic[type] === undefined) gen + ("%s[k]=types[%i].decode(r,r.uint32())", ref, i); // can't be groups + else gen + ("%s[k]=r.%s()", ref, type); + } + + // Repeated fields + } else if (field.repeated) { gen + + ("if(!(%s&&%s.length))", ref, ref) + ("%s=[]", ref); + + // Packable (always check for forward and backward compatiblity) + if (types.packed[type] !== undefined) gen + ("if((t&7)===2){") + ("var c2=r.uint32()+r.pos") + ("while(r.pos>> 0, (field.id << 3 | 4) >>> 0) + : gen("types[%i].encode(%s,w.uint32(%i).fork()).ldelim()", fieldIndex, ref, (field.id << 3 | 2) >>> 0); +} + +/** + * Generates an encoder specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function encoder(mtype) { + /* eslint-disable no-unexpected-multiline, block-scoped-var, no-redeclare */ + var gen = util.codegen(["m", "w"], mtype.name + "$encode") + ("if(!w)") + ("w=Writer.create()"); + + var i, ref; + + // "when a message is serialized its known fields should be written sequentially by field number" + var fields = /* initializes */ mtype.fieldsArray.slice().sort(util.compareFieldsById); + + for (var i = 0; i < fields.length; ++i) { + var field = fields[i].resolve(), + index = mtype._fieldsArray.indexOf(field), + type = field.resolvedType instanceof Enum ? "int32" : field.type, + wireType = types.basic[type]; + ref = "m" + util.safeProp(field.name); + + // Map fields + if (field.map) { + gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name) // !== undefined && !== null + ("for(var ks=Object.keys(%s),i=0;i>> 0, 8 | types.mapKey[field.keyType], field.keyType); + if (wireType === undefined) gen + ("types[%i].encode(%s[ks[i]],w.uint32(18).fork()).ldelim().ldelim()", index, ref); // can't be groups + else gen + (".uint32(%i).%s(%s[ks[i]]).ldelim()", 16 | wireType, type, ref); + gen + ("}") + ("}"); + + // Repeated fields + } else if (field.repeated) { gen + ("if(%s!=null&&%s.length){", ref, ref); // !== undefined && !== null + + // Packed repeated + if (field.packed && types.packed[type] !== undefined) { gen + + ("w.uint32(%i).fork()", (field.id << 3 | 2) >>> 0) + ("for(var i=0;i<%s.length;++i)", ref) + ("w.%s(%s[i])", type, ref) + ("w.ldelim()"); + + // Non-packed + } else { gen + + ("for(var i=0;i<%s.length;++i)", ref); + if (wireType === undefined) + genTypePartial(gen, field, index, ref + "[i]"); + else gen + ("w.uint32(%i).%s(%s[i])", (field.id << 3 | wireType) >>> 0, type, ref); + + } gen + ("}"); + + // Non-repeated + } else { + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j))", ref, field.name); // !== undefined && !== null + + if (wireType === undefined) + genTypePartial(gen, field, index, ref); + else gen + ("w.uint32(%i).%s(%s)", (field.id << 3 | wireType) >>> 0, type, ref); + + } + } + + return gen + ("return w"); + /* eslint-enable no-unexpected-multiline, block-scoped-var, no-redeclare */ +} \ No newline at end of file diff --git a/node_modules/protobufjs/src/enum.js b/node_modules/protobufjs/src/enum.js new file mode 100644 index 0000000..b11014b --- /dev/null +++ b/node_modules/protobufjs/src/enum.js @@ -0,0 +1,181 @@ +"use strict"; +module.exports = Enum; + +// extends ReflectionObject +var ReflectionObject = require("./object"); +((Enum.prototype = Object.create(ReflectionObject.prototype)).constructor = Enum).className = "Enum"; + +var Namespace = require("./namespace"), + util = require("./util"); + +/** + * Constructs a new enum instance. + * @classdesc Reflected enum. + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {Object.} [values] Enum values as an object, by name + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this enum + * @param {Object.} [comments] The value comments for this enum + */ +function Enum(name, values, options, comment, comments) { + ReflectionObject.call(this, name, options); + + if (values && typeof values !== "object") + throw TypeError("values must be an object"); + + /** + * Enum values by id. + * @type {Object.} + */ + this.valuesById = {}; + + /** + * Enum values by name. + * @type {Object.} + */ + this.values = Object.create(this.valuesById); // toJSON, marker + + /** + * Enum comment text. + * @type {string|null} + */ + this.comment = comment; + + /** + * Value comment texts, if any. + * @type {Object.} + */ + this.comments = comments || {}; + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + // Note that values inherit valuesById on their prototype which makes them a TypeScript- + // compatible enum. This is used by pbts to write actual enum definitions that work for + // static and reflection code alike instead of emitting generic object definitions. + + if (values) + for (var keys = Object.keys(values), i = 0; i < keys.length; ++i) + if (typeof values[keys[i]] === "number") // use forward entries only + this.valuesById[ this.values[keys[i]] = values[keys[i]] ] = keys[i]; +} + +/** + * Enum descriptor. + * @interface IEnum + * @property {Object.} values Enum values + * @property {Object.} [options] Enum options + */ + +/** + * Constructs an enum from an enum descriptor. + * @param {string} name Enum name + * @param {IEnum} json Enum descriptor + * @returns {Enum} Created enum + * @throws {TypeError} If arguments are invalid + */ +Enum.fromJSON = function fromJSON(name, json) { + var enm = new Enum(name, json.values, json.options, json.comment, json.comments); + enm.reserved = json.reserved; + return enm; +}; + +/** + * Converts this enum to an enum descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IEnum} Enum descriptor + */ +Enum.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "values" , this.values, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "comment" , keepComments ? this.comment : undefined, + "comments" , keepComments ? this.comments : undefined + ]); +}; + +/** + * Adds a value to this enum. + * @param {string} name Value name + * @param {number} id Value id + * @param {string} [comment] Comment, if any + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a value with this name or id + */ +Enum.prototype.add = function add(name, id, comment) { + // utilized by the parser but not by .fromJSON + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (!util.isInteger(id)) + throw TypeError("id must be an integer"); + + if (this.values[name] !== undefined) + throw Error("duplicate name '" + name + "' in " + this); + + if (this.isReservedId(id)) + throw Error("id " + id + " is reserved in " + this); + + if (this.isReservedName(name)) + throw Error("name '" + name + "' is reserved in " + this); + + if (this.valuesById[id] !== undefined) { + if (!(this.options && this.options.allow_alias)) + throw Error("duplicate id " + id + " in " + this); + this.values[name] = id; + } else + this.valuesById[this.values[name] = id] = name; + + this.comments[name] = comment || null; + return this; +}; + +/** + * Removes a value from this enum + * @param {string} name Value name + * @returns {Enum} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `name` is not a name of this enum + */ +Enum.prototype.remove = function remove(name) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + var val = this.values[name]; + if (val == null) + throw Error("name '" + name + "' does not exist in " + this); + + delete this.valuesById[val]; + delete this.values[name]; + delete this.comments[name]; + + return this; +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Enum.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; diff --git a/node_modules/protobufjs/src/field.js b/node_modules/protobufjs/src/field.js new file mode 100644 index 0000000..788c773 --- /dev/null +++ b/node_modules/protobufjs/src/field.js @@ -0,0 +1,371 @@ +"use strict"; +module.exports = Field; + +// extends ReflectionObject +var ReflectionObject = require("./object"); +((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = "Field"; + +var Enum = require("./enum"), + types = require("./types"), + util = require("./util"); + +var Type; // cyclic + +var ruleRe = /^required|optional|repeated$/; + +/** + * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class. + * @name Field + * @classdesc Reflected message field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a field from a field descriptor. + * @param {string} name Field name + * @param {IField} json Field descriptor + * @returns {Field} Created field + * @throws {TypeError} If arguments are invalid + */ +Field.fromJSON = function fromJSON(name, json) { + return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment); +}; + +/** + * Not an actual constructor. Use {@link Field} instead. + * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions. + * @exports FieldBase + * @extends ReflectionObject + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} type Value type + * @param {string|Object.} [rule="optional"] Field rule + * @param {string|Object.} [extend] Extended type if different from parent + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function Field(name, id, type, rule, extend, options, comment) { + + if (util.isObject(rule)) { + comment = extend; + options = rule; + rule = extend = undefined; + } else if (util.isObject(extend)) { + comment = options; + options = extend; + extend = undefined; + } + + ReflectionObject.call(this, name, options); + + if (!util.isInteger(id) || id < 0) + throw TypeError("id must be a non-negative integer"); + + if (!util.isString(type)) + throw TypeError("type must be a string"); + + if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase())) + throw TypeError("rule must be a string rule"); + + if (extend !== undefined && !util.isString(extend)) + throw TypeError("extend must be a string"); + + /** + * Field rule, if any. + * @type {string|undefined} + */ + this.rule = rule && rule !== "optional" ? rule : undefined; // toJSON + + /** + * Field type. + * @type {string} + */ + this.type = type; // toJSON + + /** + * Unique field id. + * @type {number} + */ + this.id = id; // toJSON, marker + + /** + * Extended type if different from parent. + * @type {string|undefined} + */ + this.extend = extend || undefined; // toJSON + + /** + * Whether this field is required. + * @type {boolean} + */ + this.required = rule === "required"; + + /** + * Whether this field is optional. + * @type {boolean} + */ + this.optional = !this.required; + + /** + * Whether this field is repeated. + * @type {boolean} + */ + this.repeated = rule === "repeated"; + + /** + * Whether this field is a map or not. + * @type {boolean} + */ + this.map = false; + + /** + * Message this field belongs to. + * @type {Type|null} + */ + this.message = null; + + /** + * OneOf this field belongs to, if any, + * @type {OneOf|null} + */ + this.partOf = null; + + /** + * The field type's default value. + * @type {*} + */ + this.typeDefault = null; + + /** + * The field's default value on prototypes. + * @type {*} + */ + this.defaultValue = null; + + /** + * Whether this field's value should be treated as a long. + * @type {boolean} + */ + this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false; + + /** + * Whether this field's value is a buffer. + * @type {boolean} + */ + this.bytes = type === "bytes"; + + /** + * Resolved type if not a basic type. + * @type {Type|Enum|null} + */ + this.resolvedType = null; + + /** + * Sister-field within the extended type if a declaring extension field. + * @type {Field|null} + */ + this.extensionField = null; + + /** + * Sister-field within the declaring namespace if an extended field. + * @type {Field|null} + */ + this.declaringField = null; + + /** + * Internally remembers whether this field is packed. + * @type {boolean|null} + * @private + */ + this._packed = null; + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Determines whether this field is packed. Only relevant when repeated and working with proto2. + * @name Field#packed + * @type {boolean} + * @readonly + */ +Object.defineProperty(Field.prototype, "packed", { + get: function() { + // defaults to packed=true if not explicity set to false + if (this._packed === null) + this._packed = this.getOption("packed") !== false; + return this._packed; + } +}); + +/** + * @override + */ +Field.prototype.setOption = function setOption(name, value, ifNotSet) { + if (name === "packed") // clear cached before setting + this._packed = null; + return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet); +}; + +/** + * Field descriptor. + * @interface IField + * @property {string} [rule="optional"] Field rule + * @property {string} type Field type + * @property {number} id Field id + * @property {Object.} [options] Field options + */ + +/** + * Extension field descriptor. + * @interface IExtensionField + * @extends IField + * @property {string} extend Extended type + */ + +/** + * Converts this field to a field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IField} Field descriptor + */ +Field.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "rule" , this.rule !== "optional" && this.rule || undefined, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Resolves this field's type references. + * @returns {Field} `this` + * @throws {Error} If any reference cannot be resolved + */ +Field.prototype.resolve = function resolve() { + + if (this.resolved) + return this; + + if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it + this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type); + if (this.resolvedType instanceof Type) + this.typeDefault = null; + else // instanceof Enum + this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined + } + + // use explicitly set default value if present + if (this.options && this.options["default"] != null) { + this.typeDefault = this.options["default"]; + if (this.resolvedType instanceof Enum && typeof this.typeDefault === "string") + this.typeDefault = this.resolvedType.values[this.typeDefault]; + } + + // remove unnecessary options + if (this.options) { + if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum)) + delete this.options.packed; + if (!Object.keys(this.options).length) + this.options = undefined; + } + + // convert to internal data type if necesssary + if (this.long) { + this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === "u"); + + /* istanbul ignore else */ + if (Object.freeze) + Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it) + + } else if (this.bytes && typeof this.typeDefault === "string") { + var buf; + if (util.base64.test(this.typeDefault)) + util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0); + else + util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0); + this.typeDefault = buf; + } + + // take special care of maps and repeated fields + if (this.map) + this.defaultValue = util.emptyObject; + else if (this.repeated) + this.defaultValue = util.emptyArray; + else + this.defaultValue = this.typeDefault; + + // ensure proper value on prototype + if (this.parent instanceof Type) + this.parent.ctor.prototype[this.name] = this.defaultValue; + + return ReflectionObject.prototype.resolve.call(this); +}; + +/** + * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript). + * @typedef FieldDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} fieldName Field name + * @returns {undefined} + */ + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|Object} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @param {T} [defaultValue] Default value + * @returns {FieldDecorator} Decorator function + * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[] + */ +Field.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) { + + // submessage: decorate the submessage and use its name as the type + if (typeof fieldType === "function") + fieldType = util.decorateType(fieldType).name; + + // enum reference: create a reflected copy of the enum and keep reuseing it + else if (fieldType && typeof fieldType === "object") + fieldType = util.decorateEnum(fieldType).name; + + return function fieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new Field(fieldName, fieldId, fieldType, fieldRule, { "default": defaultValue })); + }; +}; + +/** + * Field decorator (TypeScript). + * @name Field.d + * @function + * @param {number} fieldId Field id + * @param {Constructor|string} fieldType Field type + * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule + * @returns {FieldDecorator} Decorator function + * @template T extends Message + * @variation 2 + */ +// like Field.d but without a default value + +// Sets up cyclic dependencies (called in index-light) +Field._configure = function configure(Type_) { + Type = Type_; +}; diff --git a/node_modules/protobufjs/src/index-light.js b/node_modules/protobufjs/src/index-light.js new file mode 100644 index 0000000..32c6a05 --- /dev/null +++ b/node_modules/protobufjs/src/index-light.js @@ -0,0 +1,104 @@ +"use strict"; +var protobuf = module.exports = require("./index-minimal"); + +protobuf.build = "light"; + +/** + * A node-style callback as used by {@link load} and {@link Root#load}. + * @typedef LoadCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Root} [root] Root, if there hasn't been an error + * @returns {undefined} + */ + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @param {string|string[]} filename One or multiple files to load + * @param {Root} root Root namespace, defaults to create a new one if omitted. + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + */ +function load(filename, root, callback) { + if (typeof root === "function") { + callback = root; + root = new protobuf.Root(); + } else if (!root) + root = new protobuf.Root(); + return root.load(filename, callback); +} + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and calls the callback. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @see {@link Root#load} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into a common root namespace and returns a promise. + * @name load + * @function + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Promise} Promise + * @see {@link Root#load} + * @variation 3 + */ +// function load(filename:string, [root:Root]):Promise + +protobuf.load = load; + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into a common root namespace (node only). + * @param {string|string[]} filename One or multiple files to load + * @param {Root} [root] Root namespace, defaults to create a new one if omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + * @see {@link Root#loadSync} + */ +function loadSync(filename, root) { + if (!root) + root = new protobuf.Root(); + return root.loadSync(filename); +} + +protobuf.loadSync = loadSync; + +// Serialization +protobuf.encoder = require("./encoder"); +protobuf.decoder = require("./decoder"); +protobuf.verifier = require("./verifier"); +protobuf.converter = require("./converter"); + +// Reflection +protobuf.ReflectionObject = require("./object"); +protobuf.Namespace = require("./namespace"); +protobuf.Root = require("./root"); +protobuf.Enum = require("./enum"); +protobuf.Type = require("./type"); +protobuf.Field = require("./field"); +protobuf.OneOf = require("./oneof"); +protobuf.MapField = require("./mapfield"); +protobuf.Service = require("./service"); +protobuf.Method = require("./method"); + +// Runtime +protobuf.Message = require("./message"); +protobuf.wrappers = require("./wrappers"); + +// Utility +protobuf.types = require("./types"); +protobuf.util = require("./util"); + +// Set up possibly cyclic reflection dependencies +protobuf.ReflectionObject._configure(protobuf.Root); +protobuf.Namespace._configure(protobuf.Type, protobuf.Service, protobuf.Enum); +protobuf.Root._configure(protobuf.Type); +protobuf.Field._configure(protobuf.Type); diff --git a/node_modules/protobufjs/src/index-minimal.js b/node_modules/protobufjs/src/index-minimal.js new file mode 100644 index 0000000..9bc051b --- /dev/null +++ b/node_modules/protobufjs/src/index-minimal.js @@ -0,0 +1,36 @@ +"use strict"; +var protobuf = exports; + +/** + * Build type, one of `"full"`, `"light"` or `"minimal"`. + * @name build + * @type {string} + * @const + */ +protobuf.build = "minimal"; + +// Serialization +protobuf.Writer = require("./writer"); +protobuf.BufferWriter = require("./writer_buffer"); +protobuf.Reader = require("./reader"); +protobuf.BufferReader = require("./reader_buffer"); + +// Utility +protobuf.util = require("./util/minimal"); +protobuf.rpc = require("./rpc"); +protobuf.roots = require("./roots"); +protobuf.configure = configure; + +/* istanbul ignore next */ +/** + * Reconfigures the library according to the environment. + * @returns {undefined} + */ +function configure() { + protobuf.Reader._configure(protobuf.BufferReader); + protobuf.util._configure(); +} + +// Set up buffer utility according to the environment +protobuf.Writer._configure(protobuf.BufferWriter); +configure(); diff --git a/node_modules/protobufjs/src/index.js b/node_modules/protobufjs/src/index.js new file mode 100644 index 0000000..56bd3d5 --- /dev/null +++ b/node_modules/protobufjs/src/index.js @@ -0,0 +1,12 @@ +"use strict"; +var protobuf = module.exports = require("./index-light"); + +protobuf.build = "full"; + +// Parser +protobuf.tokenize = require("./tokenize"); +protobuf.parse = require("./parse"); +protobuf.common = require("./common"); + +// Configure parser +protobuf.Root._configure(protobuf.Type, protobuf.parse, protobuf.common); diff --git a/node_modules/protobufjs/src/mapfield.js b/node_modules/protobufjs/src/mapfield.js new file mode 100644 index 0000000..67c7097 --- /dev/null +++ b/node_modules/protobufjs/src/mapfield.js @@ -0,0 +1,126 @@ +"use strict"; +module.exports = MapField; + +// extends Field +var Field = require("./field"); +((MapField.prototype = Object.create(Field.prototype)).constructor = MapField).className = "MapField"; + +var types = require("./types"), + util = require("./util"); + +/** + * Constructs a new map field instance. + * @classdesc Reflected map field. + * @extends FieldBase + * @constructor + * @param {string} name Unique name within its namespace + * @param {number} id Unique id within its namespace + * @param {string} keyType Key type + * @param {string} type Value type + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function MapField(name, id, keyType, type, options, comment) { + Field.call(this, name, id, type, undefined, undefined, options, comment); + + /* istanbul ignore if */ + if (!util.isString(keyType)) + throw TypeError("keyType must be a string"); + + /** + * Key type. + * @type {string} + */ + this.keyType = keyType; // toJSON, marker + + /** + * Resolved key type if not a basic type. + * @type {ReflectionObject|null} + */ + this.resolvedKeyType = null; + + // Overrides Field#map + this.map = true; +} + +/** + * Map field descriptor. + * @interface IMapField + * @extends {IField} + * @property {string} keyType Key type + */ + +/** + * Extension map field descriptor. + * @interface IExtensionMapField + * @extends IMapField + * @property {string} extend Extended type + */ + +/** + * Constructs a map field from a map field descriptor. + * @param {string} name Field name + * @param {IMapField} json Map field descriptor + * @returns {MapField} Created map field + * @throws {TypeError} If arguments are invalid + */ +MapField.fromJSON = function fromJSON(name, json) { + return new MapField(name, json.id, json.keyType, json.type, json.options, json.comment); +}; + +/** + * Converts this map field to a map field descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMapField} Map field descriptor + */ +MapField.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "keyType" , this.keyType, + "type" , this.type, + "id" , this.id, + "extend" , this.extend, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +MapField.prototype.resolve = function resolve() { + if (this.resolved) + return this; + + // Besides a value type, map fields have a key type that may be "any scalar type except for floating point types and bytes" + if (types.mapKey[this.keyType] === undefined) + throw Error("invalid key type: " + this.keyType); + + return Field.prototype.resolve.call(this); +}; + +/** + * Map field decorator (TypeScript). + * @name MapField.d + * @function + * @param {number} fieldId Field id + * @param {"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"} fieldKeyType Field key type + * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"bool"|"string"|"bytes"|Object|Constructor<{}>} fieldValueType Field value type + * @returns {FieldDecorator} Decorator function + * @template T extends { [key: string]: number | Long | string | boolean | Uint8Array | Buffer | number[] | Message<{}> } + */ +MapField.d = function decorateMapField(fieldId, fieldKeyType, fieldValueType) { + + // submessage value: decorate the submessage and use its name as the type + if (typeof fieldValueType === "function") + fieldValueType = util.decorateType(fieldValueType).name; + + // enum reference value: create a reflected copy of the enum and keep reuseing it + else if (fieldValueType && typeof fieldValueType === "object") + fieldValueType = util.decorateEnum(fieldValueType).name; + + return function mapFieldDecorator(prototype, fieldName) { + util.decorateType(prototype.constructor) + .add(new MapField(fieldName, fieldId, fieldKeyType, fieldValueType)); + }; +}; diff --git a/node_modules/protobufjs/src/message.js b/node_modules/protobufjs/src/message.js new file mode 100644 index 0000000..3f94bf6 --- /dev/null +++ b/node_modules/protobufjs/src/message.js @@ -0,0 +1,139 @@ +"use strict"; +module.exports = Message; + +var util = require("./util/minimal"); + +/** + * Constructs a new message instance. + * @classdesc Abstract runtime message. + * @constructor + * @param {Properties} [properties] Properties to set + * @template T extends object = object + */ +function Message(properties) { + // not used internally + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + this[keys[i]] = properties[keys[i]]; +} + +/** + * Reference to the reflected type. + * @name Message.$type + * @type {Type} + * @readonly + */ + +/** + * Reference to the reflected type. + * @name Message#$type + * @type {Type} + * @readonly + */ + +/*eslint-disable valid-jsdoc*/ + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message} Message instance + * @template T extends Message + * @this Constructor + */ +Message.create = function create(properties) { + return this.$type.create(properties); +}; + +/** + * Encodes a message of this type. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encode = function encode(message, writer) { + return this.$type.encode(message, writer); +}; + +/** + * Encodes a message of this type preceeded by its length as a varint. + * @param {T|Object.} message Message to encode + * @param {Writer} [writer] Writer to use + * @returns {Writer} Writer + * @template T extends Message + * @this Constructor + */ +Message.encodeDelimited = function encodeDelimited(message, writer) { + return this.$type.encodeDelimited(message, writer); +}; + +/** + * Decodes a message of this type. + * @name Message.decode + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decode = function decode(reader) { + return this.$type.decode(reader); +}; + +/** + * Decodes a message of this type preceeded by its length as a varint. + * @name Message.decodeDelimited + * @function + * @param {Reader|Uint8Array} reader Reader or buffer to decode + * @returns {T} Decoded message + * @template T extends Message + * @this Constructor + */ +Message.decodeDelimited = function decodeDelimited(reader) { + return this.$type.decodeDelimited(reader); +}; + +/** + * Verifies a message of this type. + * @name Message.verify + * @function + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ +Message.verify = function verify(message) { + return this.$type.verify(message); +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object + * @returns {T} Message instance + * @template T extends Message + * @this Constructor + */ +Message.fromObject = function fromObject(object) { + return this.$type.fromObject(object); +}; + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {T} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @template T extends Message + * @this Constructor + */ +Message.toObject = function toObject(message, options) { + return this.$type.toObject(message, options); +}; + +/** + * Converts this message to JSON. + * @returns {Object.} JSON object + */ +Message.prototype.toJSON = function toJSON() { + return this.$type.toObject(this, util.toJSONOptions); +}; + +/*eslint-enable valid-jsdoc*/ \ No newline at end of file diff --git a/node_modules/protobufjs/src/method.js b/node_modules/protobufjs/src/method.js new file mode 100644 index 0000000..f515922 --- /dev/null +++ b/node_modules/protobufjs/src/method.js @@ -0,0 +1,151 @@ +"use strict"; +module.exports = Method; + +// extends ReflectionObject +var ReflectionObject = require("./object"); +((Method.prototype = Object.create(ReflectionObject.prototype)).constructor = Method).className = "Method"; + +var util = require("./util"); + +/** + * Constructs a new service method instance. + * @classdesc Reflected service method. + * @extends ReflectionObject + * @constructor + * @param {string} name Method name + * @param {string|undefined} type Method type, usually `"rpc"` + * @param {string} requestType Request message type + * @param {string} responseType Response message type + * @param {boolean|Object.} [requestStream] Whether the request is streamed + * @param {boolean|Object.} [responseStream] Whether the response is streamed + * @param {Object.} [options] Declared options + * @param {string} [comment] The comment for this method + */ +function Method(name, type, requestType, responseType, requestStream, responseStream, options, comment) { + + /* istanbul ignore next */ + if (util.isObject(requestStream)) { + options = requestStream; + requestStream = responseStream = undefined; + } else if (util.isObject(responseStream)) { + options = responseStream; + responseStream = undefined; + } + + /* istanbul ignore if */ + if (!(type === undefined || util.isString(type))) + throw TypeError("type must be a string"); + + /* istanbul ignore if */ + if (!util.isString(requestType)) + throw TypeError("requestType must be a string"); + + /* istanbul ignore if */ + if (!util.isString(responseType)) + throw TypeError("responseType must be a string"); + + ReflectionObject.call(this, name, options); + + /** + * Method type. + * @type {string} + */ + this.type = type || "rpc"; // toJSON + + /** + * Request type. + * @type {string} + */ + this.requestType = requestType; // toJSON, marker + + /** + * Whether requests are streamed or not. + * @type {boolean|undefined} + */ + this.requestStream = requestStream ? true : undefined; // toJSON + + /** + * Response type. + * @type {string} + */ + this.responseType = responseType; // toJSON + + /** + * Whether responses are streamed or not. + * @type {boolean|undefined} + */ + this.responseStream = responseStream ? true : undefined; // toJSON + + /** + * Resolved request type. + * @type {Type|null} + */ + this.resolvedRequestType = null; + + /** + * Resolved response type. + * @type {Type|null} + */ + this.resolvedResponseType = null; + + /** + * Comment for this method + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Method descriptor. + * @interface IMethod + * @property {string} [type="rpc"] Method type + * @property {string} requestType Request type + * @property {string} responseType Response type + * @property {boolean} [requestStream=false] Whether requests are streamed + * @property {boolean} [responseStream=false] Whether responses are streamed + * @property {Object.} [options] Method options + */ + +/** + * Constructs a method from a method descriptor. + * @param {string} name Method name + * @param {IMethod} json Method descriptor + * @returns {Method} Created method + * @throws {TypeError} If arguments are invalid + */ +Method.fromJSON = function fromJSON(name, json) { + return new Method(name, json.type, json.requestType, json.responseType, json.requestStream, json.responseStream, json.options, json.comment); +}; + +/** + * Converts this method to a method descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IMethod} Method descriptor + */ +Method.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "type" , this.type !== "rpc" && /* istanbul ignore next */ this.type || undefined, + "requestType" , this.requestType, + "requestStream" , this.requestStream, + "responseType" , this.responseType, + "responseStream" , this.responseStream, + "options" , this.options, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Method.prototype.resolve = function resolve() { + + /* istanbul ignore if */ + if (this.resolved) + return this; + + this.resolvedRequestType = this.parent.lookupType(this.requestType); + this.resolvedResponseType = this.parent.lookupType(this.responseType); + + return ReflectionObject.prototype.resolve.call(this); +}; diff --git a/node_modules/protobufjs/src/namespace.js b/node_modules/protobufjs/src/namespace.js new file mode 100644 index 0000000..cb5f355 --- /dev/null +++ b/node_modules/protobufjs/src/namespace.js @@ -0,0 +1,433 @@ +"use strict"; +module.exports = Namespace; + +// extends ReflectionObject +var ReflectionObject = require("./object"); +((Namespace.prototype = Object.create(ReflectionObject.prototype)).constructor = Namespace).className = "Namespace"; + +var Field = require("./field"), + util = require("./util"); + +var Type, // cyclic + Service, + Enum; + +/** + * Constructs a new namespace instance. + * @name Namespace + * @classdesc Reflected namespace. + * @extends NamespaceBase + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + */ + +/** + * Constructs a namespace from JSON. + * @memberof Namespace + * @function + * @param {string} name Namespace name + * @param {Object.} json JSON object + * @returns {Namespace} Created namespace + * @throws {TypeError} If arguments are invalid + */ +Namespace.fromJSON = function fromJSON(name, json) { + return new Namespace(name, json.options).addJSON(json.nested); +}; + +/** + * Converts an array of reflection objects to JSON. + * @memberof Namespace + * @param {ReflectionObject[]} array Object array + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {Object.|undefined} JSON object or `undefined` when array is empty + */ +function arrayToJSON(array, toJSONOptions) { + if (!(array && array.length)) + return undefined; + var obj = {}; + for (var i = 0; i < array.length; ++i) + obj[array[i].name] = array[i].toJSON(toJSONOptions); + return obj; +} + +Namespace.arrayToJSON = arrayToJSON; + +/** + * Tests if the specified id is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedId = function isReservedId(reserved, id) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (typeof reserved[i] !== "string" && reserved[i][0] <= id && reserved[i][1] >= id) + return true; + return false; +}; + +/** + * Tests if the specified name is reserved. + * @param {Array.|undefined} reserved Array of reserved ranges and names + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Namespace.isReservedName = function isReservedName(reserved, name) { + if (reserved) + for (var i = 0; i < reserved.length; ++i) + if (reserved[i] === name) + return true; + return false; +}; + +/** + * Not an actual constructor. Use {@link Namespace} instead. + * @classdesc Base class of all reflection objects containing nested objects. This is not an actual class but here for the sake of having consistent type definitions. + * @exports NamespaceBase + * @extends ReflectionObject + * @abstract + * @constructor + * @param {string} name Namespace name + * @param {Object.} [options] Declared options + * @see {@link Namespace} + */ +function Namespace(name, options) { + ReflectionObject.call(this, name, options); + + /** + * Nested objects by name. + * @type {Object.|undefined} + */ + this.nested = undefined; // toJSON + + /** + * Cached nested objects as an array. + * @type {ReflectionObject[]|null} + * @private + */ + this._nestedArray = null; +} + +function clearCache(namespace) { + namespace._nestedArray = null; + return namespace; +} + +/** + * Nested objects of this namespace as an array for iteration. + * @name NamespaceBase#nestedArray + * @type {ReflectionObject[]} + * @readonly + */ +Object.defineProperty(Namespace.prototype, "nestedArray", { + get: function() { + return this._nestedArray || (this._nestedArray = util.toArray(this.nested)); + } +}); + +/** + * Namespace descriptor. + * @interface INamespace + * @property {Object.} [options] Namespace options + * @property {Object.} [nested] Nested object descriptors + */ + +/** + * Any extension field descriptor. + * @typedef AnyExtensionField + * @type {IExtensionField|IExtensionMapField} + */ + +/** + * Any nested object descriptor. + * @typedef AnyNestedObject + * @type {IEnum|IType|IService|AnyExtensionField|INamespace} + */ +// ^ BEWARE: VSCode hangs forever when using more than 5 types (that's why AnyExtensionField exists in the first place) + +/** + * Converts this namespace to a namespace descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {INamespace} Namespace descriptor + */ +Namespace.prototype.toJSON = function toJSON(toJSONOptions) { + return util.toObject([ + "options" , this.options, + "nested" , arrayToJSON(this.nestedArray, toJSONOptions) + ]); +}; + +/** + * Adds nested objects to this namespace from nested object descriptors. + * @param {Object.} nestedJson Any nested object descriptors + * @returns {Namespace} `this` + */ +Namespace.prototype.addJSON = function addJSON(nestedJson) { + var ns = this; + /* istanbul ignore else */ + if (nestedJson) { + for (var names = Object.keys(nestedJson), i = 0, nested; i < names.length; ++i) { + nested = nestedJson[names[i]]; + ns.add( // most to least likely + ( nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : nested.id !== undefined + ? Field.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + } + return this; +}; + +/** + * Gets the nested object of the specified name. + * @param {string} name Nested object name + * @returns {ReflectionObject|null} The reflection object or `null` if it doesn't exist + */ +Namespace.prototype.get = function get(name) { + return this.nested && this.nested[name] + || null; +}; + +/** + * Gets the values of the nested {@link Enum|enum} of the specified name. + * This methods differs from {@link Namespace#get|get} in that it returns an enum's values directly and throws instead of returning `null`. + * @param {string} name Nested enum name + * @returns {Object.} Enum values + * @throws {Error} If there is no such enum + */ +Namespace.prototype.getEnum = function getEnum(name) { + if (this.nested && this.nested[name] instanceof Enum) + return this.nested[name].values; + throw Error("no such enum: " + name); +}; + +/** + * Adds a nested object to this namespace. + * @param {ReflectionObject} object Nested object to add + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name + */ +Namespace.prototype.add = function add(object) { + + if (!(object instanceof Field && object.extend !== undefined || object instanceof Type || object instanceof Enum || object instanceof Service || object instanceof Namespace)) + throw TypeError("object must be a valid nested object"); + + if (!this.nested) + this.nested = {}; + else { + var prev = this.get(object.name); + if (prev) { + if (prev instanceof Namespace && object instanceof Namespace && !(prev instanceof Type || prev instanceof Service)) { + // replace plain namespace but keep existing nested elements and options + var nested = prev.nestedArray; + for (var i = 0; i < nested.length; ++i) + object.add(nested[i]); + this.remove(prev); + if (!this.nested) + this.nested = {}; + object.setOptions(prev.options, true); + + } else + throw Error("duplicate name '" + object.name + "' in " + this); + } + } + this.nested[object.name] = object; + object.onAdd(this); + return clearCache(this); +}; + +/** + * Removes a nested object from this namespace. + * @param {ReflectionObject} object Nested object to remove + * @returns {Namespace} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this namespace + */ +Namespace.prototype.remove = function remove(object) { + + if (!(object instanceof ReflectionObject)) + throw TypeError("object must be a ReflectionObject"); + if (object.parent !== this) + throw Error(object + " is not a member of " + this); + + delete this.nested[object.name]; + if (!Object.keys(this.nested).length) + this.nested = undefined; + + object.onRemove(this); + return clearCache(this); +}; + +/** + * Defines additial namespaces within this one if not yet existing. + * @param {string|string[]} path Path to create + * @param {*} [json] Nested types to create from JSON + * @returns {Namespace} Pointer to the last namespace created or `this` if path is empty + */ +Namespace.prototype.define = function define(path, json) { + + if (util.isString(path)) + path = path.split("."); + else if (!Array.isArray(path)) + throw TypeError("illegal path"); + if (path && path.length && path[0] === "") + throw Error("path must be relative"); + + var ptr = this; + while (path.length > 0) { + var part = path.shift(); + if (ptr.nested && ptr.nested[part]) { + ptr = ptr.nested[part]; + if (!(ptr instanceof Namespace)) + throw Error("path conflicts with non-namespace objects"); + } else + ptr.add(ptr = new Namespace(part)); + } + if (json) + ptr.addJSON(json); + return ptr; +}; + +/** + * Resolves this namespace's and all its nested objects' type references. Useful to validate a reflection tree, but comes at a cost. + * @returns {Namespace} `this` + */ +Namespace.prototype.resolveAll = function resolveAll() { + var nested = this.nestedArray, i = 0; + while (i < nested.length) + if (nested[i] instanceof Namespace) + nested[i++].resolveAll(); + else + nested[i++].resolve(); + return this.resolve(); +}; + +/** + * Recursively looks up the reflection object matching the specified path in the scope of this namespace. + * @param {string|string[]} path Path to look up + * @param {*|Array.<*>} filterTypes Filter types, any combination of the constructors of `protobuf.Type`, `protobuf.Enum`, `protobuf.Service` etc. + * @param {boolean} [parentAlreadyChecked=false] If known, whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + */ +Namespace.prototype.lookup = function lookup(path, filterTypes, parentAlreadyChecked) { + + /* istanbul ignore next */ + if (typeof filterTypes === "boolean") { + parentAlreadyChecked = filterTypes; + filterTypes = undefined; + } else if (filterTypes && !Array.isArray(filterTypes)) + filterTypes = [ filterTypes ]; + + if (util.isString(path) && path.length) { + if (path === ".") + return this.root; + path = path.split("."); + } else if (!path.length) + return this; + + // Start at root if path is absolute + if (path[0] === "") + return this.root.lookup(path.slice(1), filterTypes); + + // Test if the first part matches any nested object, and if so, traverse if path contains more + var found = this.get(path[0]); + if (found) { + if (path.length === 1) { + if (!filterTypes || filterTypes.indexOf(found.constructor) > -1) + return found; + } else if (found instanceof Namespace && (found = found.lookup(path.slice(1), filterTypes, true))) + return found; + + // Otherwise try each nested namespace + } else + for (var i = 0; i < this.nestedArray.length; ++i) + if (this._nestedArray[i] instanceof Namespace && (found = this._nestedArray[i].lookup(path, filterTypes, true))) + return found; + + // If there hasn't been a match, try again at the parent + if (this.parent === null || parentAlreadyChecked) + return null; + return this.parent.lookup(path, filterTypes); +}; + +/** + * Looks up the reflection object at the specified path, relative to this namespace. + * @name NamespaceBase#lookup + * @function + * @param {string|string[]} path Path to look up + * @param {boolean} [parentAlreadyChecked=false] Whether the parent has already been checked + * @returns {ReflectionObject|null} Looked up object or `null` if none could be found + * @variation 2 + */ +// lookup(path: string, [parentAlreadyChecked: boolean]) + +/** + * Looks up the {@link Type|type} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type + * @throws {Error} If `path` does not point to a type + */ +Namespace.prototype.lookupType = function lookupType(path) { + var found = this.lookup(path, [ Type ]); + if (!found) + throw Error("no such type: " + path); + return found; +}; + +/** + * Looks up the values of the {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Enum} Looked up enum + * @throws {Error} If `path` does not point to an enum + */ +Namespace.prototype.lookupEnum = function lookupEnum(path) { + var found = this.lookup(path, [ Enum ]); + if (!found) + throw Error("no such Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Type|type} or {@link Enum|enum} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Type} Looked up type or enum + * @throws {Error} If `path` does not point to a type or enum + */ +Namespace.prototype.lookupTypeOrEnum = function lookupTypeOrEnum(path) { + var found = this.lookup(path, [ Type, Enum ]); + if (!found) + throw Error("no such Type or Enum '" + path + "' in " + this); + return found; +}; + +/** + * Looks up the {@link Service|service} at the specified path, relative to this namespace. + * Besides its signature, this methods differs from {@link Namespace#lookup|lookup} in that it throws instead of returning `null`. + * @param {string|string[]} path Path to look up + * @returns {Service} Looked up service + * @throws {Error} If `path` does not point to a service + */ +Namespace.prototype.lookupService = function lookupService(path) { + var found = this.lookup(path, [ Service ]); + if (!found) + throw Error("no such Service '" + path + "' in " + this); + return found; +}; + +// Sets up cyclic dependencies (called in index-light) +Namespace._configure = function(Type_, Service_, Enum_) { + Type = Type_; + Service = Service_; + Enum = Enum_; +}; diff --git a/node_modules/protobufjs/src/object.js b/node_modules/protobufjs/src/object.js new file mode 100644 index 0000000..b6a5e56 --- /dev/null +++ b/node_modules/protobufjs/src/object.js @@ -0,0 +1,200 @@ +"use strict"; +module.exports = ReflectionObject; + +ReflectionObject.className = "ReflectionObject"; + +var util = require("./util"); + +var Root; // cyclic + +/** + * Constructs a new reflection object instance. + * @classdesc Base class of all reflection objects. + * @constructor + * @param {string} name Object name + * @param {Object.} [options] Declared options + * @abstract + */ +function ReflectionObject(name, options) { + + if (!util.isString(name)) + throw TypeError("name must be a string"); + + if (options && !util.isObject(options)) + throw TypeError("options must be an object"); + + /** + * Options. + * @type {Object.|undefined} + */ + this.options = options; // toJSON + + /** + * Unique name within its namespace. + * @type {string} + */ + this.name = name; + + /** + * Parent namespace. + * @type {Namespace|null} + */ + this.parent = null; + + /** + * Whether already resolved or not. + * @type {boolean} + */ + this.resolved = false; + + /** + * Comment text, if any. + * @type {string|null} + */ + this.comment = null; + + /** + * Defining file name. + * @type {string|null} + */ + this.filename = null; +} + +Object.defineProperties(ReflectionObject.prototype, { + + /** + * Reference to the root namespace. + * @name ReflectionObject#root + * @type {Root} + * @readonly + */ + root: { + get: function() { + var ptr = this; + while (ptr.parent !== null) + ptr = ptr.parent; + return ptr; + } + }, + + /** + * Full name including leading dot. + * @name ReflectionObject#fullName + * @type {string} + * @readonly + */ + fullName: { + get: function() { + var path = [ this.name ], + ptr = this.parent; + while (ptr) { + path.unshift(ptr.name); + ptr = ptr.parent; + } + return path.join("."); + } + } +}); + +/** + * Converts this reflection object to its descriptor representation. + * @returns {Object.} Descriptor + * @abstract + */ +ReflectionObject.prototype.toJSON = /* istanbul ignore next */ function toJSON() { + throw Error(); // not implemented, shouldn't happen +}; + +/** + * Called when this object is added to a parent. + * @param {ReflectionObject} parent Parent added to + * @returns {undefined} + */ +ReflectionObject.prototype.onAdd = function onAdd(parent) { + if (this.parent && this.parent !== parent) + this.parent.remove(this); + this.parent = parent; + this.resolved = false; + var root = parent.root; + if (root instanceof Root) + root._handleAdd(this); +}; + +/** + * Called when this object is removed from a parent. + * @param {ReflectionObject} parent Parent removed from + * @returns {undefined} + */ +ReflectionObject.prototype.onRemove = function onRemove(parent) { + var root = parent.root; + if (root instanceof Root) + root._handleRemove(this); + this.parent = null; + this.resolved = false; +}; + +/** + * Resolves this objects type references. + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.resolve = function resolve() { + if (this.resolved) + return this; + if (this.root instanceof Root) + this.resolved = true; // only if part of a root + return this; +}; + +/** + * Gets an option value. + * @param {string} name Option name + * @returns {*} Option value or `undefined` if not set + */ +ReflectionObject.prototype.getOption = function getOption(name) { + if (this.options) + return this.options[name]; + return undefined; +}; + +/** + * Sets an option. + * @param {string} name Option name + * @param {*} value Option value + * @param {boolean} [ifNotSet] Sets the option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOption = function setOption(name, value, ifNotSet) { + if (!ifNotSet || !this.options || this.options[name] === undefined) + (this.options || (this.options = {}))[name] = value; + return this; +}; + +/** + * Sets multiple options. + * @param {Object.} options Options to set + * @param {boolean} [ifNotSet] Sets an option only if it isn't currently set + * @returns {ReflectionObject} `this` + */ +ReflectionObject.prototype.setOptions = function setOptions(options, ifNotSet) { + if (options) + for (var keys = Object.keys(options), i = 0; i < keys.length; ++i) + this.setOption(keys[i], options[keys[i]], ifNotSet); + return this; +}; + +/** + * Converts this instance to its string representation. + * @returns {string} Class name[, space, full name] + */ +ReflectionObject.prototype.toString = function toString() { + var className = this.constructor.className, + fullName = this.fullName; + if (fullName.length) + return className + " " + fullName; + return className; +}; + +// Sets up cyclic dependencies (called in index-light) +ReflectionObject._configure = function(Root_) { + Root = Root_; +}; diff --git a/node_modules/protobufjs/src/oneof.js b/node_modules/protobufjs/src/oneof.js new file mode 100644 index 0000000..ba0e902 --- /dev/null +++ b/node_modules/protobufjs/src/oneof.js @@ -0,0 +1,203 @@ +"use strict"; +module.exports = OneOf; + +// extends ReflectionObject +var ReflectionObject = require("./object"); +((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = "OneOf"; + +var Field = require("./field"), + util = require("./util"); + +/** + * Constructs a new oneof instance. + * @classdesc Reflected oneof. + * @extends ReflectionObject + * @constructor + * @param {string} name Oneof name + * @param {string[]|Object.} [fieldNames] Field names + * @param {Object.} [options] Declared options + * @param {string} [comment] Comment associated with this field + */ +function OneOf(name, fieldNames, options, comment) { + if (!Array.isArray(fieldNames)) { + options = fieldNames; + fieldNames = undefined; + } + ReflectionObject.call(this, name, options); + + /* istanbul ignore if */ + if (!(fieldNames === undefined || Array.isArray(fieldNames))) + throw TypeError("fieldNames must be an Array"); + + /** + * Field names that belong to this oneof. + * @type {string[]} + */ + this.oneof = fieldNames || []; // toJSON, marker + + /** + * Fields that belong to this oneof as an array for iteration. + * @type {Field[]} + * @readonly + */ + this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent + + /** + * Comment for this field. + * @type {string|null} + */ + this.comment = comment; +} + +/** + * Oneof descriptor. + * @interface IOneOf + * @property {Array.} oneof Oneof field names + * @property {Object.} [options] Oneof options + */ + +/** + * Constructs a oneof from a oneof descriptor. + * @param {string} name Oneof name + * @param {IOneOf} json Oneof descriptor + * @returns {OneOf} Created oneof + * @throws {TypeError} If arguments are invalid + */ +OneOf.fromJSON = function fromJSON(name, json) { + return new OneOf(name, json.oneof, json.options, json.comment); +}; + +/** + * Converts this oneof to a oneof descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IOneOf} Oneof descriptor + */ +OneOf.prototype.toJSON = function toJSON(toJSONOptions) { + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , this.options, + "oneof" , this.oneof, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Adds the fields of the specified oneof to the parent if not already done so. + * @param {OneOf} oneof The oneof + * @returns {undefined} + * @inner + * @ignore + */ +function addFieldsToParent(oneof) { + if (oneof.parent) + for (var i = 0; i < oneof.fieldsArray.length; ++i) + if (!oneof.fieldsArray[i].parent) + oneof.parent.add(oneof.fieldsArray[i]); +} + +/** + * Adds a field to this oneof and removes it from its current parent, if any. + * @param {Field} field Field to add + * @returns {OneOf} `this` + */ +OneOf.prototype.add = function add(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + if (field.parent && field.parent !== this.parent) + field.parent.remove(field); + this.oneof.push(field.name); + this.fieldsArray.push(field); + field.partOf = this; // field.parent remains null + addFieldsToParent(this); + return this; +}; + +/** + * Removes a field from this oneof and puts it back to the oneof's parent. + * @param {Field} field Field to remove + * @returns {OneOf} `this` + */ +OneOf.prototype.remove = function remove(field) { + + /* istanbul ignore if */ + if (!(field instanceof Field)) + throw TypeError("field must be a Field"); + + var index = this.fieldsArray.indexOf(field); + + /* istanbul ignore if */ + if (index < 0) + throw Error(field + " is not a member of " + this); + + this.fieldsArray.splice(index, 1); + index = this.oneof.indexOf(field.name); + + /* istanbul ignore else */ + if (index > -1) // theoretical + this.oneof.splice(index, 1); + + field.partOf = null; + return this; +}; + +/** + * @override + */ +OneOf.prototype.onAdd = function onAdd(parent) { + ReflectionObject.prototype.onAdd.call(this, parent); + var self = this; + // Collect present fields + for (var i = 0; i < this.oneof.length; ++i) { + var field = parent.get(this.oneof[i]); + if (field && !field.partOf) { + field.partOf = self; + self.fieldsArray.push(field); + } + } + // Add not yet present fields + addFieldsToParent(this); +}; + +/** + * @override + */ +OneOf.prototype.onRemove = function onRemove(parent) { + for (var i = 0, field; i < this.fieldsArray.length; ++i) + if ((field = this.fieldsArray[i]).parent) + field.parent.remove(field); + ReflectionObject.prototype.onRemove.call(this, parent); +}; + +/** + * Decorator function as returned by {@link OneOf.d} (TypeScript). + * @typedef OneOfDecorator + * @type {function} + * @param {Object} prototype Target prototype + * @param {string} oneofName OneOf name + * @returns {undefined} + */ + +/** + * OneOf decorator (TypeScript). + * @function + * @param {...string} fieldNames Field names + * @returns {OneOfDecorator} Decorator function + * @template T extends string + */ +OneOf.d = function decorateOneOf() { + var fieldNames = new Array(arguments.length), + index = 0; + while (index < arguments.length) + fieldNames[index] = arguments[index++]; + return function oneOfDecorator(prototype, oneofName) { + util.decorateType(prototype.constructor) + .add(new OneOf(oneofName, fieldNames)); + Object.defineProperty(prototype, oneofName, { + get: util.oneOfGetter(fieldNames), + set: util.oneOfSetter(fieldNames) + }); + }; +}; diff --git a/node_modules/protobufjs/src/parse.js b/node_modules/protobufjs/src/parse.js new file mode 100644 index 0000000..c0059ef --- /dev/null +++ b/node_modules/protobufjs/src/parse.js @@ -0,0 +1,758 @@ +"use strict"; +module.exports = parse; + +parse.filename = null; +parse.defaults = { keepCase: false }; + +var tokenize = require("./tokenize"), + Root = require("./root"), + Type = require("./type"), + Field = require("./field"), + MapField = require("./mapfield"), + OneOf = require("./oneof"), + Enum = require("./enum"), + Service = require("./service"), + Method = require("./method"), + types = require("./types"), + util = require("./util"); + +var base10Re = /^[1-9][0-9]*$/, + base10NegRe = /^-?[1-9][0-9]*$/, + base16Re = /^0[x][0-9a-fA-F]+$/, + base16NegRe = /^-?0[x][0-9a-fA-F]+$/, + base8Re = /^0[0-7]+$/, + base8NegRe = /^-?0[0-7]+$/, + numberRe = /^(?![eE])[0-9]*(?:\.[0-9]*)?(?:[eE][+-]?[0-9]+)?$/, + nameRe = /^[a-zA-Z_][a-zA-Z_0-9]*$/, + typeRefRe = /^(?:\.?[a-zA-Z_][a-zA-Z_0-9]*)(?:\.[a-zA-Z_][a-zA-Z_0-9]*)*$/, + fqTypeRefRe = /^(?:\.[a-zA-Z_][a-zA-Z_0-9]*)+$/; + +/** + * Result object returned from {@link parse}. + * @interface IParserResult + * @property {string|undefined} package Package name, if declared + * @property {string[]|undefined} imports Imports, if any + * @property {string[]|undefined} weakImports Weak imports, if any + * @property {string|undefined} syntax Syntax, if specified (either `"proto2"` or `"proto3"`) + * @property {Root} root Populated root instance + */ + +/** + * Options modifying the behavior of {@link parse}. + * @interface IParseOptions + * @property {boolean} [keepCase=false] Keeps field casing instead of converting to camel case + * @property {boolean} [alternateCommentMode=false] Recognize double-slash comments in addition to doc-block comments. + */ + +/** + * Options modifying the behavior of JSON serialization. + * @interface IToJSONOptions + * @property {boolean} [keepComments=false] Serializes comments. + */ + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @param {string} source Source contents + * @param {Root} root Root to populate + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {IParserResult} Parser result + * @property {string} filename=null Currently processing file name for error reporting, if known + * @property {IParseOptions} defaults Default {@link IParseOptions} + */ +function parse(source, root, options) { + /* eslint-disable callback-return */ + if (!(root instanceof Root)) { + options = root; + root = new Root(); + } + if (!options) + options = parse.defaults; + + var tn = tokenize(source, options.alternateCommentMode || false), + next = tn.next, + push = tn.push, + peek = tn.peek, + skip = tn.skip, + cmnt = tn.cmnt; + + var head = true, + pkg, + imports, + weakImports, + syntax, + isProto3 = false; + + var ptr = root; + + var applyCase = options.keepCase ? function(name) { return name; } : util.camelCase; + + /* istanbul ignore next */ + function illegal(token, name, insideTryCatch) { + var filename = parse.filename; + if (!insideTryCatch) + parse.filename = null; + return Error("illegal " + (name || "token") + " '" + token + "' (" + (filename ? filename + ", " : "") + "line " + tn.line + ")"); + } + + function readString() { + var values = [], + token; + do { + /* istanbul ignore if */ + if ((token = next()) !== "\"" && token !== "'") + throw illegal(token); + + values.push(next()); + skip(token); + token = peek(); + } while (token === "\"" || token === "'"); + return values.join(""); + } + + function readValue(acceptTypeRef) { + var token = next(); + switch (token) { + case "'": + case "\"": + push(token); + return readString(); + case "true": case "TRUE": + return true; + case "false": case "FALSE": + return false; + } + try { + return parseNumber(token, /* insideTryCatch */ true); + } catch (e) { + + /* istanbul ignore else */ + if (acceptTypeRef && typeRefRe.test(token)) + return token; + + /* istanbul ignore next */ + throw illegal(token, "value"); + } + } + + function readRanges(target, acceptStrings) { + var token, start; + do { + if (acceptStrings && ((token = peek()) === "\"" || token === "'")) + target.push(readString()); + else + target.push([ start = parseId(next()), skip("to", true) ? parseId(next()) : start ]); + } while (skip(",", true)); + skip(";"); + } + + function parseNumber(token, insideTryCatch) { + var sign = 1; + if (token.charAt(0) === "-") { + sign = -1; + token = token.substring(1); + } + switch (token) { + case "inf": case "INF": case "Inf": + return sign * Infinity; + case "nan": case "NAN": case "Nan": case "NaN": + return NaN; + case "0": + return 0; + } + if (base10Re.test(token)) + return sign * parseInt(token, 10); + if (base16Re.test(token)) + return sign * parseInt(token, 16); + if (base8Re.test(token)) + return sign * parseInt(token, 8); + + /* istanbul ignore else */ + if (numberRe.test(token)) + return sign * parseFloat(token); + + /* istanbul ignore next */ + throw illegal(token, "number", insideTryCatch); + } + + function parseId(token, acceptNegative) { + switch (token) { + case "max": case "MAX": case "Max": + return 536870911; + case "0": + return 0; + } + + /* istanbul ignore if */ + if (!acceptNegative && token.charAt(0) === "-") + throw illegal(token, "id"); + + if (base10NegRe.test(token)) + return parseInt(token, 10); + if (base16NegRe.test(token)) + return parseInt(token, 16); + + /* istanbul ignore else */ + if (base8NegRe.test(token)) + return parseInt(token, 8); + + /* istanbul ignore next */ + throw illegal(token, "id"); + } + + function parsePackage() { + + /* istanbul ignore if */ + if (pkg !== undefined) + throw illegal("package"); + + pkg = next(); + + /* istanbul ignore if */ + if (!typeRefRe.test(pkg)) + throw illegal(pkg, "name"); + + ptr = ptr.define(pkg); + skip(";"); + } + + function parseImport() { + var token = peek(); + var whichImports; + switch (token) { + case "weak": + whichImports = weakImports || (weakImports = []); + next(); + break; + case "public": + next(); + // eslint-disable-line no-fallthrough + default: + whichImports = imports || (imports = []); + break; + } + token = readString(); + skip(";"); + whichImports.push(token); + } + + function parseSyntax() { + skip("="); + syntax = readString(); + isProto3 = syntax === "proto3"; + + /* istanbul ignore if */ + if (!isProto3 && syntax !== "proto2") + throw illegal(syntax, "syntax"); + + skip(";"); + } + + function parseCommon(parent, token) { + switch (token) { + + case "option": + parseOption(parent, token); + skip(";"); + return true; + + case "message": + parseType(parent, token); + return true; + + case "enum": + parseEnum(parent, token); + return true; + + case "service": + parseService(parent, token); + return true; + + case "extend": + parseExtension(parent, token); + return true; + } + return false; + } + + function ifBlock(obj, fnIf, fnElse) { + var trailingLine = tn.line; + if (obj) { + obj.comment = cmnt(); // try block-type comment + obj.filename = parse.filename; + } + if (skip("{", true)) { + var token; + while ((token = next()) !== "}") + fnIf(token); + skip(";", true); + } else { + if (fnElse) + fnElse(); + skip(";"); + if (obj && typeof obj.comment !== "string") + obj.comment = cmnt(trailingLine); // try line-type comment if no block + } + } + + function parseType(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "type name"); + + var type = new Type(token); + ifBlock(type, function parseType_block(token) { + if (parseCommon(type, token)) + return; + + switch (token) { + + case "map": + parseMapField(type, token); + break; + + case "required": + case "optional": + case "repeated": + parseField(type, token); + break; + + case "oneof": + parseOneOf(type, token); + break; + + case "extensions": + readRanges(type.extensions || (type.extensions = [])); + break; + + case "reserved": + readRanges(type.reserved || (type.reserved = []), true); + break; + + default: + /* istanbul ignore if */ + if (!isProto3 || !typeRefRe.test(token)) + throw illegal(token); + + push(token); + parseField(type, "optional"); + break; + } + }); + parent.add(type); + } + + function parseField(parent, rule, extend) { + var type = next(); + if (type === "group") { + parseGroup(parent, rule); + return; + } + + /* istanbul ignore if */ + if (!typeRefRe.test(type)) + throw illegal(type, "type"); + + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + name = applyCase(name); + skip("="); + + var field = new Field(name, parseId(next()), type, rule, extend); + ifBlock(field, function parseField_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(field, token); + skip(";"); + } else + throw illegal(token); + + }, function parseField_line() { + parseInlineOptions(field); + }); + parent.add(field); + + // JSON defaults to packed=true if not set so we have to set packed=false explicity when + // parsing proto2 descriptors without the option, where applicable. This must be done for + // all known packable types and anything that could be an enum (= is not a basic type). + if (!isProto3 && field.repeated && (types.packed[type] !== undefined || types.basic[type] === undefined)) + field.setOption("packed", false, /* ifNotSet */ true); + } + + function parseGroup(parent, rule) { + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + var fieldName = util.lcFirst(name); + if (name === fieldName) + name = util.ucFirst(name); + skip("="); + var id = parseId(next()); + var type = new Type(name); + type.group = true; + var field = new Field(fieldName, id, name, rule); + field.filename = parse.filename; + ifBlock(type, function parseGroup_block(token) { + switch (token) { + + case "option": + parseOption(type, token); + skip(";"); + break; + + case "required": + case "optional": + case "repeated": + parseField(type, token); + break; + + /* istanbul ignore next */ + default: + throw illegal(token); // there are no groups with proto3 semantics + } + }); + parent.add(type) + .add(field); + } + + function parseMapField(parent) { + skip("<"); + var keyType = next(); + + /* istanbul ignore if */ + if (types.mapKey[keyType] === undefined) + throw illegal(keyType, "type"); + + skip(","); + var valueType = next(); + + /* istanbul ignore if */ + if (!typeRefRe.test(valueType)) + throw illegal(valueType, "type"); + + skip(">"); + var name = next(); + + /* istanbul ignore if */ + if (!nameRe.test(name)) + throw illegal(name, "name"); + + skip("="); + var field = new MapField(applyCase(name), parseId(next()), keyType, valueType); + ifBlock(field, function parseMapField_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(field, token); + skip(";"); + } else + throw illegal(token); + + }, function parseMapField_line() { + parseInlineOptions(field); + }); + parent.add(field); + } + + function parseOneOf(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var oneof = new OneOf(applyCase(token)); + ifBlock(oneof, function parseOneOf_block(token) { + if (token === "option") { + parseOption(oneof, token); + skip(";"); + } else { + push(token); + parseField(oneof, "optional"); + } + }); + parent.add(oneof); + } + + function parseEnum(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var enm = new Enum(token); + ifBlock(enm, function parseEnum_block(token) { + switch(token) { + case "option": + parseOption(enm, token); + skip(";"); + break; + + case "reserved": + readRanges(enm.reserved || (enm.reserved = []), true); + break; + + default: + parseEnumValue(enm, token); + } + }); + parent.add(enm); + } + + function parseEnumValue(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token)) + throw illegal(token, "name"); + + skip("="); + var value = parseId(next(), true), + dummy = {}; + ifBlock(dummy, function parseEnumValue_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(dummy, token); // skip + skip(";"); + } else + throw illegal(token); + + }, function parseEnumValue_line() { + parseInlineOptions(dummy); // skip + }); + parent.add(token, value, dummy.comment); + } + + function parseOption(parent, token) { + var isCustom = skip("(", true); + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token, "name"); + + var name = token; + if (isCustom) { + skip(")"); + name = "(" + name + ")"; + token = peek(); + if (fqTypeRefRe.test(token)) { + name += token; + next(); + } + } + skip("="); + parseOptionValue(parent, name); + } + + function parseOptionValue(parent, name) { + if (skip("{", true)) { // { a: "foo" b { c: "bar" } } + do { + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + if (peek() === "{") + parseOptionValue(parent, name + "." + token); + else { + skip(":"); + if (peek() === "{") + parseOptionValue(parent, name + "." + token); + else + setOption(parent, name + "." + token, readValue(true)); + } + skip(",", true); + } while (!skip("}", true)); + } else + setOption(parent, name, readValue(true)); + // Does not enforce a delimiter to be universal + } + + function setOption(parent, name, value) { + if (parent.setOption) + parent.setOption(name, value); + } + + function parseInlineOptions(parent) { + if (skip("[", true)) { + do { + parseOption(parent, "option"); + } while (skip(",", true)); + skip("]"); + } + return parent; + } + + function parseService(parent, token) { + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "service name"); + + var service = new Service(token); + ifBlock(service, function parseService_block(token) { + if (parseCommon(service, token)) + return; + + /* istanbul ignore else */ + if (token === "rpc") + parseMethod(service, token); + else + throw illegal(token); + }); + parent.add(service); + } + + function parseMethod(parent, token) { + var type = token; + + /* istanbul ignore if */ + if (!nameRe.test(token = next())) + throw illegal(token, "name"); + + var name = token, + requestType, requestStream, + responseType, responseStream; + + skip("("); + if (skip("stream", true)) + requestStream = true; + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token); + + requestType = token; + skip(")"); skip("returns"); skip("("); + if (skip("stream", true)) + responseStream = true; + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token); + + responseType = token; + skip(")"); + + var method = new Method(name, type, requestType, responseType, requestStream, responseStream); + ifBlock(method, function parseMethod_block(token) { + + /* istanbul ignore else */ + if (token === "option") { + parseOption(method, token); + skip(";"); + } else + throw illegal(token); + + }); + parent.add(method); + } + + function parseExtension(parent, token) { + + /* istanbul ignore if */ + if (!typeRefRe.test(token = next())) + throw illegal(token, "reference"); + + var reference = token; + ifBlock(null, function parseExtension_block(token) { + switch (token) { + + case "required": + case "repeated": + case "optional": + parseField(parent, token, reference); + break; + + default: + /* istanbul ignore if */ + if (!isProto3 || !typeRefRe.test(token)) + throw illegal(token); + push(token); + parseField(parent, "optional", reference); + break; + } + }); + } + + var token; + while ((token = next()) !== null) { + switch (token) { + + case "package": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parsePackage(); + break; + + case "import": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseImport(); + break; + + case "syntax": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseSyntax(); + break; + + case "option": + + /* istanbul ignore if */ + if (!head) + throw illegal(token); + + parseOption(ptr, token); + skip(";"); + break; + + default: + + /* istanbul ignore else */ + if (parseCommon(ptr, token)) { + head = false; + continue; + } + + /* istanbul ignore next */ + throw illegal(token); + } + } + + parse.filename = null; + return { + "package" : pkg, + "imports" : imports, + weakImports : weakImports, + syntax : syntax, + root : root + }; +} + +/** + * Parses the given .proto source and returns an object with the parsed contents. + * @name parse + * @function + * @param {string} source Source contents + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {IParserResult} Parser result + * @property {string} filename=null Currently processing file name for error reporting, if known + * @property {IParseOptions} defaults Default {@link IParseOptions} + * @variation 2 + */ diff --git a/node_modules/protobufjs/src/reader.js b/node_modules/protobufjs/src/reader.js new file mode 100644 index 0000000..110cd71 --- /dev/null +++ b/node_modules/protobufjs/src/reader.js @@ -0,0 +1,405 @@ +"use strict"; +module.exports = Reader; + +var util = require("./util/minimal"); + +var BufferReader; // cyclic + +var LongBits = util.LongBits, + utf8 = util.utf8; + +/* istanbul ignore next */ +function indexOutOfRange(reader, writeLength) { + return RangeError("index out of range: " + reader.pos + " + " + (writeLength || 1) + " > " + reader.len); +} + +/** + * Constructs a new reader instance using the specified buffer. + * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`. + * @constructor + * @param {Uint8Array} buffer Buffer to read from + */ +function Reader(buffer) { + + /** + * Read buffer. + * @type {Uint8Array} + */ + this.buf = buffer; + + /** + * Read buffer position. + * @type {number} + */ + this.pos = 0; + + /** + * Read buffer length. + * @type {number} + */ + this.len = buffer.length; +} + +var create_array = typeof Uint8Array !== "undefined" + ? function create_typed_array(buffer) { + if (buffer instanceof Uint8Array || Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + } + /* istanbul ignore next */ + : function create_array(buffer) { + if (Array.isArray(buffer)) + return new Reader(buffer); + throw Error("illegal buffer"); + }; + +/** + * Creates a new reader using the specified buffer. + * @function + * @param {Uint8Array|Buffer} buffer Buffer to read from + * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader} + * @throws {Error} If `buffer` is not a valid buffer + */ +Reader.create = util.Buffer + ? function create_buffer_setup(buffer) { + return (Reader.create = function create_buffer(buffer) { + return util.Buffer.isBuffer(buffer) + ? new BufferReader(buffer) + /* istanbul ignore next */ + : create_array(buffer); + })(buffer); + } + /* istanbul ignore next */ + : create_array; + +Reader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice; + +/** + * Reads a varint as an unsigned 32 bit value. + * @function + * @returns {number} Value read + */ +Reader.prototype.uint32 = (function read_uint32_setup() { + var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!) + return function read_uint32() { + value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value; + value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value; + + /* istanbul ignore if */ + if ((this.pos += 5) > this.len) { + this.pos = this.len; + throw indexOutOfRange(this, 10); + } + return value; + }; +})(); + +/** + * Reads a varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.int32 = function read_int32() { + return this.uint32() | 0; +}; + +/** + * Reads a zig-zag encoded varint as a signed 32 bit value. + * @returns {number} Value read + */ +Reader.prototype.sint32 = function read_sint32() { + var value = this.uint32(); + return value >>> 1 ^ -(value & 1) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readLongVarint() { + // tends to deopt with local vars for octet etc. + var bits = new LongBits(0, 0); + var i = 0; + if (this.len - this.pos > 4) { // fast route (lo) + for (; i < 4; ++i) { + // 1st..4th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 5th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0; + bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + i = 0; + } else { + for (; i < 3; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 1st..3th + bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + // 4th + bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0; + return bits; + } + if (this.len - this.pos > 4) { // fast route (hi) + for (; i < 5; ++i) { + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } else { + for (; i < 5; ++i) { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + // 6th..10th + bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0; + if (this.buf[this.pos++] < 128) + return bits; + } + } + /* istanbul ignore next */ + throw Error("invalid varint encoding"); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads a varint as a signed 64 bit value. + * @name Reader#int64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as an unsigned 64 bit value. + * @name Reader#uint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a zig-zag encoded varint as a signed 64 bit value. + * @name Reader#sint64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a varint as a boolean. + * @returns {boolean} Value read + */ +Reader.prototype.bool = function read_bool() { + return this.uint32() !== 0; +}; + +function readFixed32_end(buf, end) { // note that this uses `end`, not `pos` + return (buf[end - 4] + | buf[end - 3] << 8 + | buf[end - 2] << 16 + | buf[end - 1] << 24) >>> 0; +} + +/** + * Reads fixed 32 bits as an unsigned 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.fixed32 = function read_fixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4); +}; + +/** + * Reads fixed 32 bits as a signed 32 bit integer. + * @returns {number} Value read + */ +Reader.prototype.sfixed32 = function read_sfixed32() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + return readFixed32_end(this.buf, this.pos += 4) | 0; +}; + +/* eslint-disable no-invalid-this */ + +function readFixed64(/* this: Reader */) { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 8); + + return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4)); +} + +/* eslint-enable no-invalid-this */ + +/** + * Reads fixed 64 bits. + * @name Reader#fixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads zig-zag encoded fixed 64 bits. + * @name Reader#sfixed64 + * @function + * @returns {Long} Value read + */ + +/** + * Reads a float (32 bit) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.float = function read_float() { + + /* istanbul ignore if */ + if (this.pos + 4 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readFloatLE(this.buf, this.pos); + this.pos += 4; + return value; +}; + +/** + * Reads a double (64 bit float) as a number. + * @function + * @returns {number} Value read + */ +Reader.prototype.double = function read_double() { + + /* istanbul ignore if */ + if (this.pos + 8 > this.len) + throw indexOutOfRange(this, 4); + + var value = util.float.readDoubleLE(this.buf, this.pos); + this.pos += 8; + return value; +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @returns {Uint8Array} Value read + */ +Reader.prototype.bytes = function read_bytes() { + var length = this.uint32(), + start = this.pos, + end = this.pos + length; + + /* istanbul ignore if */ + if (end > this.len) + throw indexOutOfRange(this, length); + + this.pos += length; + if (Array.isArray(this.buf)) // plain array + return this.buf.slice(start, end); + return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1 + ? new this.buf.constructor(0) + : this._slice.call(this.buf, start, end); +}; + +/** + * Reads a string preceeded by its byte length as a varint. + * @returns {string} Value read + */ +Reader.prototype.string = function read_string() { + var bytes = this.bytes(); + return utf8.read(bytes, 0, bytes.length); +}; + +/** + * Skips the specified number of bytes if specified, otherwise skips a varint. + * @param {number} [length] Length if known, otherwise a varint is assumed + * @returns {Reader} `this` + */ +Reader.prototype.skip = function skip(length) { + if (typeof length === "number") { + /* istanbul ignore if */ + if (this.pos + length > this.len) + throw indexOutOfRange(this, length); + this.pos += length; + } else { + do { + /* istanbul ignore if */ + if (this.pos >= this.len) + throw indexOutOfRange(this); + } while (this.buf[this.pos++] & 128); + } + return this; +}; + +/** + * Skips the next element of the specified wire type. + * @param {number} wireType Wire type received + * @returns {Reader} `this` + */ +Reader.prototype.skipType = function(wireType) { + switch (wireType) { + case 0: + this.skip(); + break; + case 1: + this.skip(8); + break; + case 2: + this.skip(this.uint32()); + break; + case 3: + while ((wireType = this.uint32() & 7) !== 4) { + this.skipType(wireType); + } + break; + case 5: + this.skip(4); + break; + + /* istanbul ignore next */ + default: + throw Error("invalid wire type " + wireType + " at offset " + this.pos); + } + return this; +}; + +Reader._configure = function(BufferReader_) { + BufferReader = BufferReader_; + + var fn = util.Long ? "toLong" : /* istanbul ignore next */ "toNumber"; + util.merge(Reader.prototype, { + + int64: function read_int64() { + return readLongVarint.call(this)[fn](false); + }, + + uint64: function read_uint64() { + return readLongVarint.call(this)[fn](true); + }, + + sint64: function read_sint64() { + return readLongVarint.call(this).zzDecode()[fn](false); + }, + + fixed64: function read_fixed64() { + return readFixed64.call(this)[fn](true); + }, + + sfixed64: function read_sfixed64() { + return readFixed64.call(this)[fn](false); + } + + }); +}; diff --git a/node_modules/protobufjs/src/reader_buffer.js b/node_modules/protobufjs/src/reader_buffer.js new file mode 100644 index 0000000..9518901 --- /dev/null +++ b/node_modules/protobufjs/src/reader_buffer.js @@ -0,0 +1,44 @@ +"use strict"; +module.exports = BufferReader; + +// extends Reader +var Reader = require("./reader"); +(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader; + +var util = require("./util/minimal"); + +/** + * Constructs a new buffer reader instance. + * @classdesc Wire format reader using node buffers. + * @extends Reader + * @constructor + * @param {Buffer} buffer Buffer to read from + */ +function BufferReader(buffer) { + Reader.call(this, buffer); + + /** + * Read buffer. + * @name BufferReader#buf + * @type {Buffer} + */ +} + +/* istanbul ignore else */ +if (util.Buffer) + BufferReader.prototype._slice = util.Buffer.prototype.slice; + +/** + * @override + */ +BufferReader.prototype.string = function read_string_buffer() { + var len = this.uint32(); // modifies pos + return this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len)); +}; + +/** + * Reads a sequence of bytes preceeded by its length as a varint. + * @name BufferReader#bytes + * @function + * @returns {Buffer} Value read + */ diff --git a/node_modules/protobufjs/src/root.js b/node_modules/protobufjs/src/root.js new file mode 100644 index 0000000..13be39d --- /dev/null +++ b/node_modules/protobufjs/src/root.js @@ -0,0 +1,351 @@ +"use strict"; +module.exports = Root; + +// extends Namespace +var Namespace = require("./namespace"); +((Root.prototype = Object.create(Namespace.prototype)).constructor = Root).className = "Root"; + +var Field = require("./field"), + Enum = require("./enum"), + OneOf = require("./oneof"), + util = require("./util"); + +var Type, // cyclic + parse, // might be excluded + common; // " + +/** + * Constructs a new root namespace instance. + * @classdesc Root namespace wrapping all types, enums, services, sub-namespaces etc. that belong together. + * @extends NamespaceBase + * @constructor + * @param {Object.} [options] Top level options + */ +function Root(options) { + Namespace.call(this, "", options); + + /** + * Deferred extension fields. + * @type {Field[]} + */ + this.deferred = []; + + /** + * Resolved file names of loaded files. + * @type {string[]} + */ + this.files = []; +} + +/** + * Loads a namespace descriptor into a root namespace. + * @param {INamespace} json Nameespace descriptor + * @param {Root} [root] Root namespace, defaults to create a new one if omitted + * @returns {Root} Root namespace + */ +Root.fromJSON = function fromJSON(json, root) { + if (!root) + root = new Root(); + if (json.options) + root.setOptions(json.options); + return root.addJSON(json.nested); +}; + +/** + * Resolves the path of an imported file, relative to the importing origin. + * This method exists so you can override it with your own logic in case your imports are scattered over multiple directories. + * @function + * @param {string} origin The file name of the importing file + * @param {string} target The file name being imported + * @returns {string|null} Resolved path to `target` or `null` to skip the file + */ +Root.prototype.resolvePath = util.path.resolve; + +// A symbol-like function to safely signal synchronous loading +/* istanbul ignore next */ +function SYNC() {} // eslint-disable-line no-empty-function + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} options Parse options + * @param {LoadCallback} callback Callback function + * @returns {undefined} + */ +Root.prototype.load = function load(filename, options, callback) { + if (typeof options === "function") { + callback = options; + options = undefined; + } + var self = this; + if (!callback) + return util.asPromise(load, self, filename, options); + + var sync = callback === SYNC; // undocumented + + // Finishes loading by calling the callback (exactly once) + function finish(err, root) { + /* istanbul ignore if */ + if (!callback) + return; + var cb = callback; + callback = null; + if (sync) + throw err; + cb(err, root); + } + + // Processes a single file + function process(filename, source) { + try { + if (util.isString(source) && source.charAt(0) === "{") + source = JSON.parse(source); + if (!util.isString(source)) + self.setOptions(source.options).addJSON(source.nested); + else { + parse.filename = filename; + var parsed = parse(source, self, options), + resolved, + i = 0; + if (parsed.imports) + for (; i < parsed.imports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.imports[i])) + fetch(resolved); + if (parsed.weakImports) + for (i = 0; i < parsed.weakImports.length; ++i) + if (resolved = self.resolvePath(filename, parsed.weakImports[i])) + fetch(resolved, true); + } + } catch (err) { + finish(err); + } + if (!sync && !queued) + finish(null, self); // only once anyway + } + + // Fetches a single file + function fetch(filename, weak) { + + // Strip path if this file references a bundled definition + var idx = filename.lastIndexOf("google/protobuf/"); + if (idx > -1) { + var altname = filename.substring(idx); + if (altname in common) + filename = altname; + } + + // Skip if already loaded / attempted + if (self.files.indexOf(filename) > -1) + return; + self.files.push(filename); + + // Shortcut bundled definitions + if (filename in common) { + if (sync) + process(filename, common[filename]); + else { + ++queued; + setTimeout(function() { + --queued; + process(filename, common[filename]); + }); + } + return; + } + + // Otherwise fetch from disk or network + if (sync) { + var source; + try { + source = util.fs.readFileSync(filename).toString("utf8"); + } catch (err) { + if (!weak) + finish(err); + return; + } + process(filename, source); + } else { + ++queued; + util.fetch(filename, function(err, source) { + --queued; + /* istanbul ignore if */ + if (!callback) + return; // terminated meanwhile + if (err) { + /* istanbul ignore else */ + if (!weak) + finish(err); + else if (!queued) // can't be covered reliably + finish(null, self); + return; + } + process(filename, source); + }); + } + } + var queued = 0; + + // Assembling the root namespace doesn't require working type + // references anymore, so we can load everything in parallel + if (util.isString(filename)) + filename = [ filename ]; + for (var i = 0, resolved; i < filename.length; ++i) + if (resolved = self.resolvePath("", filename[i])) + fetch(resolved); + + if (sync) + return self; + if (!queued) + finish(null, self); + return undefined; +}; +// function load(filename:string, options:IParseOptions, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and calls the callback. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {LoadCallback} callback Callback function + * @returns {undefined} + * @variation 2 + */ +// function load(filename:string, callback:LoadCallback):undefined + +/** + * Loads one or multiple .proto or preprocessed .json files into this root namespace and returns a promise. + * @function Root#load + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Promise} Promise + * @variation 3 + */ +// function load(filename:string, [options:IParseOptions]):Promise + +/** + * Synchronously loads one or multiple .proto or preprocessed .json files into this root namespace (node only). + * @function Root#loadSync + * @param {string|string[]} filename Names of one or multiple files to load + * @param {IParseOptions} [options] Parse options. Defaults to {@link parse.defaults} when omitted. + * @returns {Root} Root namespace + * @throws {Error} If synchronous fetching is not supported (i.e. in browsers) or if a file's syntax is invalid + */ +Root.prototype.loadSync = function loadSync(filename, options) { + if (!util.isNode) + throw Error("not supported"); + return this.load(filename, options, SYNC); +}; + +/** + * @override + */ +Root.prototype.resolveAll = function resolveAll() { + if (this.deferred.length) + throw Error("unresolvable extensions: " + this.deferred.map(function(field) { + return "'extend " + field.extend + "' in " + field.parent.fullName; + }).join(", ")); + return Namespace.prototype.resolveAll.call(this); +}; + +// only uppercased (and thus conflict-free) children are exposed, see below +var exposeRe = /^[A-Z]/; + +/** + * Handles a deferred declaring extension field by creating a sister field to represent it within its extended type. + * @param {Root} root Root instance + * @param {Field} field Declaring extension field witin the declaring type + * @returns {boolean} `true` if successfully added to the extended type, `false` otherwise + * @inner + * @ignore + */ +function tryHandleExtension(root, field) { + var extendedType = field.parent.lookup(field.extend); + if (extendedType) { + var sisterField = new Field(field.fullName, field.id, field.type, field.rule, undefined, field.options); + sisterField.declaringField = field; + field.extensionField = sisterField; + extendedType.add(sisterField); + return true; + } + return false; +} + +/** + * Called when any object is added to this root or its sub-namespaces. + * @param {ReflectionObject} object Object added + * @returns {undefined} + * @private + */ +Root.prototype._handleAdd = function _handleAdd(object) { + if (object instanceof Field) { + + if (/* an extension field (implies not part of a oneof) */ object.extend !== undefined && /* not already handled */ !object.extensionField) + if (!tryHandleExtension(this, object)) + this.deferred.push(object); + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + object.parent[object.name] = object.values; // expose enum values as property of its parent + + } else if (!(object instanceof OneOf)) /* everything else is a namespace */ { + + if (object instanceof Type) // Try to handle any deferred extensions + for (var i = 0; i < this.deferred.length;) + if (tryHandleExtension(this, this.deferred[i])) + this.deferred.splice(i, 1); + else + ++i; + for (var j = 0; j < /* initializes */ object.nestedArray.length; ++j) // recurse into the namespace + this._handleAdd(object._nestedArray[j]); + if (exposeRe.test(object.name)) + object.parent[object.name] = object; // expose namespace as property of its parent + } + + // The above also adds uppercased (and thus conflict-free) nested types, services and enums as + // properties of namespaces just like static code does. This allows using a .d.ts generated for + // a static module with reflection-based solutions where the condition is met. +}; + +/** + * Called when any object is removed from this root or its sub-namespaces. + * @param {ReflectionObject} object Object removed + * @returns {undefined} + * @private + */ +Root.prototype._handleRemove = function _handleRemove(object) { + if (object instanceof Field) { + + if (/* an extension field */ object.extend !== undefined) { + if (/* already handled */ object.extensionField) { // remove its sister field + object.extensionField.parent.remove(object.extensionField); + object.extensionField = null; + } else { // cancel the extension + var index = this.deferred.indexOf(object); + /* istanbul ignore else */ + if (index > -1) + this.deferred.splice(index, 1); + } + } + + } else if (object instanceof Enum) { + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose enum values + + } else if (object instanceof Namespace) { + + for (var i = 0; i < /* initializes */ object.nestedArray.length; ++i) // recurse into the namespace + this._handleRemove(object._nestedArray[i]); + + if (exposeRe.test(object.name)) + delete object.parent[object.name]; // unexpose namespaces + + } +}; + +// Sets up cyclic dependencies (called in index-light) +Root._configure = function(Type_, parse_, common_) { + Type = Type_; + parse = parse_; + common = common_; +}; diff --git a/node_modules/protobufjs/src/roots.js b/node_modules/protobufjs/src/roots.js new file mode 100644 index 0000000..1921211 --- /dev/null +++ b/node_modules/protobufjs/src/roots.js @@ -0,0 +1,18 @@ +"use strict"; +module.exports = {}; + +/** + * Named roots. + * This is where pbjs stores generated structures (the option `-r, --root` specifies a name). + * Can also be used manually to make roots available accross modules. + * @name roots + * @type {Object.} + * @example + * // pbjs -r myroot -o compiled.js ... + * + * // in another module: + * require("./compiled.js"); + * + * // in any subsequent module: + * var root = protobuf.roots["myroot"]; + */ diff --git a/node_modules/protobufjs/src/rpc.js b/node_modules/protobufjs/src/rpc.js new file mode 100644 index 0000000..894e5c7 --- /dev/null +++ b/node_modules/protobufjs/src/rpc.js @@ -0,0 +1,36 @@ +"use strict"; + +/** + * Streaming RPC helpers. + * @namespace + */ +var rpc = exports; + +/** + * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets. + * @typedef RPCImpl + * @type {function} + * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called + * @param {Uint8Array} requestData Request data + * @param {RPCImplCallback} callback Callback function + * @returns {undefined} + * @example + * function rpcImpl(method, requestData, callback) { + * if (protobuf.util.lcFirst(method.name) !== "myMethod") // compatible with static code + * throw Error("no such method"); + * asynchronouslyObtainAResponse(requestData, function(err, responseData) { + * callback(err, responseData); + * }); + * } + */ + +/** + * Node-style callback as used by {@link RPCImpl}. + * @typedef RPCImplCallback + * @type {function} + * @param {Error|null} error Error, if any, otherwise `null` + * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error + * @returns {undefined} + */ + +rpc.Service = require("./rpc/service"); diff --git a/node_modules/protobufjs/src/rpc/service.js b/node_modules/protobufjs/src/rpc/service.js new file mode 100644 index 0000000..757f382 --- /dev/null +++ b/node_modules/protobufjs/src/rpc/service.js @@ -0,0 +1,142 @@ +"use strict"; +module.exports = Service; + +var util = require("../util/minimal"); + +// Extends EventEmitter +(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service; + +/** + * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}. + * + * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`. + * @typedef rpc.ServiceMethodCallback + * @template TRes extends Message + * @type {function} + * @param {Error|null} error Error, if any + * @param {TRes} [response] Response message + * @returns {undefined} + */ + +/** + * A service method part of a {@link rpc.Service} as created by {@link Service.create}. + * @typedef rpc.ServiceMethod + * @template TReq extends Message + * @template TRes extends Message + * @type {function} + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message + * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined` + */ + +/** + * Constructs a new RPC service instance. + * @classdesc An RPC service as returned by {@link Service#create}. + * @exports rpc.Service + * @extends util.EventEmitter + * @constructor + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ +function Service(rpcImpl, requestDelimited, responseDelimited) { + + if (typeof rpcImpl !== "function") + throw TypeError("rpcImpl must be a function"); + + util.EventEmitter.call(this); + + /** + * RPC implementation. Becomes `null` once the service is ended. + * @type {RPCImpl|null} + */ + this.rpcImpl = rpcImpl; + + /** + * Whether requests are length-delimited. + * @type {boolean} + */ + this.requestDelimited = Boolean(requestDelimited); + + /** + * Whether responses are length-delimited. + * @type {boolean} + */ + this.responseDelimited = Boolean(responseDelimited); +} + +/** + * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}. + * @param {Method|rpc.ServiceMethod} method Reflected or static method + * @param {Constructor} requestCtor Request constructor + * @param {Constructor} responseCtor Response constructor + * @param {TReq|Properties} request Request message or plain object + * @param {rpc.ServiceMethodCallback} callback Service callback + * @returns {undefined} + * @template TReq extends Message + * @template TRes extends Message + */ +Service.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) { + + if (!request) + throw TypeError("request must be specified"); + + var self = this; + if (!callback) + return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request); + + if (!self.rpcImpl) { + setTimeout(function() { callback(Error("already ended")); }, 0); + return undefined; + } + + try { + return self.rpcImpl( + method, + requestCtor[self.requestDelimited ? "encodeDelimited" : "encode"](request).finish(), + function rpcCallback(err, response) { + + if (err) { + self.emit("error", err, method); + return callback(err); + } + + if (response === null) { + self.end(/* endedByRPC */ true); + return undefined; + } + + if (!(response instanceof responseCtor)) { + try { + response = responseCtor[self.responseDelimited ? "decodeDelimited" : "decode"](response); + } catch (err) { + self.emit("error", err, method); + return callback(err); + } + } + + self.emit("data", response, method); + return callback(null, response); + } + ); + } catch (err) { + self.emit("error", err, method); + setTimeout(function() { callback(err); }, 0); + return undefined; + } +}; + +/** + * Ends this service and emits the `end` event. + * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation. + * @returns {rpc.Service} `this` + */ +Service.prototype.end = function end(endedByRPC) { + if (this.rpcImpl) { + if (!endedByRPC) // signal end to rpcImpl + this.rpcImpl(null, null, null); + this.rpcImpl = null; + this.emit("end").off(); + } + return this; +}; diff --git a/node_modules/protobufjs/src/service.js b/node_modules/protobufjs/src/service.js new file mode 100644 index 0000000..bc2c308 --- /dev/null +++ b/node_modules/protobufjs/src/service.js @@ -0,0 +1,167 @@ +"use strict"; +module.exports = Service; + +// extends Namespace +var Namespace = require("./namespace"); +((Service.prototype = Object.create(Namespace.prototype)).constructor = Service).className = "Service"; + +var Method = require("./method"), + util = require("./util"), + rpc = require("./rpc"); + +/** + * Constructs a new service instance. + * @classdesc Reflected service. + * @extends NamespaceBase + * @constructor + * @param {string} name Service name + * @param {Object.} [options] Service options + * @throws {TypeError} If arguments are invalid + */ +function Service(name, options) { + Namespace.call(this, name, options); + + /** + * Service methods. + * @type {Object.} + */ + this.methods = {}; // toJSON, marker + + /** + * Cached methods as an array. + * @type {Method[]|null} + * @private + */ + this._methodsArray = null; +} + +/** + * Service descriptor. + * @interface IService + * @extends INamespace + * @property {Object.} methods Method descriptors + */ + +/** + * Constructs a service from a service descriptor. + * @param {string} name Service name + * @param {IService} json Service descriptor + * @returns {Service} Created service + * @throws {TypeError} If arguments are invalid + */ +Service.fromJSON = function fromJSON(name, json) { + var service = new Service(name, json.options); + /* istanbul ignore else */ + if (json.methods) + for (var names = Object.keys(json.methods), i = 0; i < names.length; ++i) + service.add(Method.fromJSON(names[i], json.methods[names[i]])); + if (json.nested) + service.addJSON(json.nested); + service.comment = json.comment; + return service; +}; + +/** + * Converts this service to a service descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IService} Service descriptor + */ +Service.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "methods" , Namespace.arrayToJSON(this.methodsArray, toJSONOptions) || /* istanbul ignore next */ {}, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * Methods of this service as an array for iteration. + * @name Service#methodsArray + * @type {Method[]} + * @readonly + */ +Object.defineProperty(Service.prototype, "methodsArray", { + get: function() { + return this._methodsArray || (this._methodsArray = util.toArray(this.methods)); + } +}); + +function clearCache(service) { + service._methodsArray = null; + return service; +} + +/** + * @override + */ +Service.prototype.get = function get(name) { + return this.methods[name] + || Namespace.prototype.get.call(this, name); +}; + +/** + * @override + */ +Service.prototype.resolveAll = function resolveAll() { + var methods = this.methodsArray; + for (var i = 0; i < methods.length; ++i) + methods[i].resolve(); + return Namespace.prototype.resolve.call(this); +}; + +/** + * @override + */ +Service.prototype.add = function add(object) { + + /* istanbul ignore if */ + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Method) { + this.methods[object.name] = object; + object.parent = this; + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * @override + */ +Service.prototype.remove = function remove(object) { + if (object instanceof Method) { + + /* istanbul ignore if */ + if (this.methods[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.methods[object.name]; + object.parent = null; + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Creates a runtime service using the specified rpc implementation. + * @param {RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {rpc.Service} RPC service. Useful where requests and/or responses are streamed. + */ +Service.prototype.create = function create(rpcImpl, requestDelimited, responseDelimited) { + var rpcService = new rpc.Service(rpcImpl, requestDelimited, responseDelimited); + for (var i = 0, method; i < /* initializes */ this.methodsArray.length; ++i) { + var methodName = util.lcFirst((method = this._methodsArray[i]).resolve().name).replace(/[^$\w_]/g, ""); + rpcService[methodName] = util.codegen(["r","c"], util.isReserved(methodName) ? methodName + "_" : methodName)("return this.rpcCall(m,q,s,r,c)")({ + m: method, + q: method.resolvedRequestType.ctor, + s: method.resolvedResponseType.ctor + }); + } + return rpcService; +}; diff --git a/node_modules/protobufjs/src/tokenize.js b/node_modules/protobufjs/src/tokenize.js new file mode 100644 index 0000000..b939ef2 --- /dev/null +++ b/node_modules/protobufjs/src/tokenize.js @@ -0,0 +1,397 @@ +"use strict"; +module.exports = tokenize; + +var delimRe = /[\s{}=;:[\],'"()<>]/g, + stringDoubleRe = /(?:"([^"\\]*(?:\\.[^"\\]*)*)")/g, + stringSingleRe = /(?:'([^'\\]*(?:\\.[^'\\]*)*)')/g; + +var setCommentRe = /^ *[*/]+ */, + setCommentAltRe = /^\s*\*?\/*/, + setCommentSplitRe = /\n/g, + whitespaceRe = /\s/, + unescapeRe = /\\(.?)/g; + +var unescapeMap = { + "0": "\0", + "r": "\r", + "n": "\n", + "t": "\t" +}; + +/** + * Unescapes a string. + * @param {string} str String to unescape + * @returns {string} Unescaped string + * @property {Object.} map Special characters map + * @memberof tokenize + */ +function unescape(str) { + return str.replace(unescapeRe, function($0, $1) { + switch ($1) { + case "\\": + case "": + return $1; + default: + return unescapeMap[$1] || ""; + } + }); +} + +tokenize.unescape = unescape; + +/** + * Gets the next token and advances. + * @typedef TokenizerHandleNext + * @type {function} + * @returns {string|null} Next token or `null` on eof + */ + +/** + * Peeks for the next token. + * @typedef TokenizerHandlePeek + * @type {function} + * @returns {string|null} Next token or `null` on eof + */ + +/** + * Pushes a token back to the stack. + * @typedef TokenizerHandlePush + * @type {function} + * @param {string} token Token + * @returns {undefined} + */ + +/** + * Skips the next token. + * @typedef TokenizerHandleSkip + * @type {function} + * @param {string} expected Expected token + * @param {boolean} [optional=false] If optional + * @returns {boolean} Whether the token matched + * @throws {Error} If the token didn't match and is not optional + */ + +/** + * Gets the comment on the previous line or, alternatively, the line comment on the specified line. + * @typedef TokenizerHandleCmnt + * @type {function} + * @param {number} [line] Line number + * @returns {string|null} Comment text or `null` if none + */ + +/** + * Handle object returned from {@link tokenize}. + * @interface ITokenizerHandle + * @property {TokenizerHandleNext} next Gets the next token and advances (`null` on eof) + * @property {TokenizerHandlePeek} peek Peeks for the next token (`null` on eof) + * @property {TokenizerHandlePush} push Pushes a token back to the stack + * @property {TokenizerHandleSkip} skip Skips a token, returns its presence and advances or, if non-optional and not present, throws + * @property {TokenizerHandleCmnt} cmnt Gets the comment on the previous line or the line comment on the specified line, if any + * @property {number} line Current line number + */ + +/** + * Tokenizes the given .proto source and returns an object with useful utility functions. + * @param {string} source Source contents + * @param {boolean} alternateCommentMode Whether we should activate alternate comment parsing mode. + * @returns {ITokenizerHandle} Tokenizer handle + */ +function tokenize(source, alternateCommentMode) { + /* eslint-disable callback-return */ + source = source.toString(); + + var offset = 0, + length = source.length, + line = 1, + commentType = null, + commentText = null, + commentLine = 0, + commentLineEmpty = false; + + var stack = []; + + var stringDelim = null; + + /* istanbul ignore next */ + /** + * Creates an error for illegal syntax. + * @param {string} subject Subject + * @returns {Error} Error created + * @inner + */ + function illegal(subject) { + return Error("illegal " + subject + " (line " + line + ")"); + } + + /** + * Reads a string till its end. + * @returns {string} String read + * @inner + */ + function readString() { + var re = stringDelim === "'" ? stringSingleRe : stringDoubleRe; + re.lastIndex = offset - 1; + var match = re.exec(source); + if (!match) + throw illegal("string"); + offset = re.lastIndex; + push(stringDelim); + stringDelim = null; + return unescape(match[1]); + } + + /** + * Gets the character at `pos` within the source. + * @param {number} pos Position + * @returns {string} Character + * @inner + */ + function charAt(pos) { + return source.charAt(pos); + } + + /** + * Sets the current comment text. + * @param {number} start Start offset + * @param {number} end End offset + * @returns {undefined} + * @inner + */ + function setComment(start, end) { + commentType = source.charAt(start++); + commentLine = line; + commentLineEmpty = false; + var lookback; + if (alternateCommentMode) { + lookback = 2; // alternate comment parsing: "//" or "/*" + } else { + lookback = 3; // "///" or "/**" + } + var commentOffset = start - lookback, + c; + do { + if (--commentOffset < 0 || + (c = source.charAt(commentOffset)) === "\n") { + commentLineEmpty = true; + break; + } + } while (c === " " || c === "\t"); + var lines = source + .substring(start, end) + .split(setCommentSplitRe); + for (var i = 0; i < lines.length; ++i) + lines[i] = lines[i] + .replace(alternateCommentMode ? setCommentAltRe : setCommentRe, "") + .trim(); + commentText = lines + .join("\n") + .trim(); + } + + function isDoubleSlashCommentLine(startOffset) { + var endOffset = findEndOfLine(startOffset); + + // see if remaining line matches comment pattern + var lineText = source.substring(startOffset, endOffset); + // look for 1 or 2 slashes since startOffset would already point past + // the first slash that started the comment. + var isComment = /^\s*\/{1,2}/.test(lineText); + return isComment; + } + + function findEndOfLine(cursor) { + // find end of cursor's line + var endOffset = cursor; + while (endOffset < length && charAt(endOffset) !== "\n") { + endOffset++; + } + return endOffset; + } + + /** + * Obtains the next token. + * @returns {string|null} Next token or `null` on eof + * @inner + */ + function next() { + if (stack.length > 0) + return stack.shift(); + if (stringDelim) + return readString(); + var repeat, + prev, + curr, + start, + isDoc; + do { + if (offset === length) + return null; + repeat = false; + while (whitespaceRe.test(curr = charAt(offset))) { + if (curr === "\n") + ++line; + if (++offset === length) + return null; + } + + if (charAt(offset) === "/") { + if (++offset === length) { + throw illegal("comment"); + } + if (charAt(offset) === "/") { // Line + if (!alternateCommentMode) { + // check for triple-slash comment + isDoc = charAt(start = offset + 1) === "/"; + + while (charAt(++offset) !== "\n") { + if (offset === length) { + return null; + } + } + ++offset; + if (isDoc) { + setComment(start, offset - 1); + } + ++line; + repeat = true; + } else { + // check for double-slash comments, consolidating consecutive lines + start = offset; + isDoc = false; + if (isDoubleSlashCommentLine(offset)) { + isDoc = true; + do { + offset = findEndOfLine(offset); + if (offset === length) { + break; + } + offset++; + } while (isDoubleSlashCommentLine(offset)); + } else { + offset = Math.min(length, findEndOfLine(offset) + 1); + } + if (isDoc) { + setComment(start, offset); + } + line++; + repeat = true; + } + } else if ((curr = charAt(offset)) === "*") { /* Block */ + // check for /** (regular comment mode) or /* (alternate comment mode) + start = offset + 1; + isDoc = alternateCommentMode || charAt(start) === "*"; + do { + if (curr === "\n") { + ++line; + } + if (++offset === length) { + throw illegal("comment"); + } + prev = curr; + curr = charAt(offset); + } while (prev !== "*" || curr !== "/"); + ++offset; + if (isDoc) { + setComment(start, offset - 2); + } + repeat = true; + } else { + return "/"; + } + } + } while (repeat); + + // offset !== length if we got here + + var end = offset; + delimRe.lastIndex = 0; + var delim = delimRe.test(charAt(end++)); + if (!delim) + while (end < length && !delimRe.test(charAt(end))) + ++end; + var token = source.substring(offset, offset = end); + if (token === "\"" || token === "'") + stringDelim = token; + return token; + } + + /** + * Pushes a token back to the stack. + * @param {string} token Token + * @returns {undefined} + * @inner + */ + function push(token) { + stack.push(token); + } + + /** + * Peeks for the next token. + * @returns {string|null} Token or `null` on eof + * @inner + */ + function peek() { + if (!stack.length) { + var token = next(); + if (token === null) + return null; + push(token); + } + return stack[0]; + } + + /** + * Skips a token. + * @param {string} expected Expected token + * @param {boolean} [optional=false] Whether the token is optional + * @returns {boolean} `true` when skipped, `false` if not + * @throws {Error} When a required token is not present + * @inner + */ + function skip(expected, optional) { + var actual = peek(), + equals = actual === expected; + if (equals) { + next(); + return true; + } + if (!optional) + throw illegal("token '" + actual + "', '" + expected + "' expected"); + return false; + } + + /** + * Gets a comment. + * @param {number} [trailingLine] Line number if looking for a trailing comment + * @returns {string|null} Comment text + * @inner + */ + function cmnt(trailingLine) { + var ret = null; + if (trailingLine === undefined) { + if (commentLine === line - 1 && (alternateCommentMode || commentType === "*" || commentLineEmpty)) { + ret = commentText; + } + } else { + /* istanbul ignore else */ + if (commentLine < trailingLine) { + peek(); + } + if (commentLine === trailingLine && !commentLineEmpty && (alternateCommentMode || commentType === "/")) { + ret = commentText; + } + } + return ret; + } + + return Object.defineProperty({ + next: next, + peek: peek, + push: push, + skip: skip, + cmnt: cmnt + }, "line", { + get: function() { return line; } + }); + /* eslint-enable callback-return */ +} diff --git a/node_modules/protobufjs/src/type.js b/node_modules/protobufjs/src/type.js new file mode 100644 index 0000000..2e7bda4 --- /dev/null +++ b/node_modules/protobufjs/src/type.js @@ -0,0 +1,589 @@ +"use strict"; +module.exports = Type; + +// extends Namespace +var Namespace = require("./namespace"); +((Type.prototype = Object.create(Namespace.prototype)).constructor = Type).className = "Type"; + +var Enum = require("./enum"), + OneOf = require("./oneof"), + Field = require("./field"), + MapField = require("./mapfield"), + Service = require("./service"), + Message = require("./message"), + Reader = require("./reader"), + Writer = require("./writer"), + util = require("./util"), + encoder = require("./encoder"), + decoder = require("./decoder"), + verifier = require("./verifier"), + converter = require("./converter"), + wrappers = require("./wrappers"); + +/** + * Constructs a new reflected message type instance. + * @classdesc Reflected message type. + * @extends NamespaceBase + * @constructor + * @param {string} name Message name + * @param {Object.} [options] Declared options + */ +function Type(name, options) { + Namespace.call(this, name, options); + + /** + * Message fields. + * @type {Object.} + */ + this.fields = {}; // toJSON, marker + + /** + * Oneofs declared within this namespace, if any. + * @type {Object.} + */ + this.oneofs = undefined; // toJSON + + /** + * Extension ranges, if any. + * @type {number[][]} + */ + this.extensions = undefined; // toJSON + + /** + * Reserved ranges, if any. + * @type {Array.} + */ + this.reserved = undefined; // toJSON + + /*? + * Whether this type is a legacy group. + * @type {boolean|undefined} + */ + this.group = undefined; // toJSON + + /** + * Cached fields by id. + * @type {Object.|null} + * @private + */ + this._fieldsById = null; + + /** + * Cached fields as an array. + * @type {Field[]|null} + * @private + */ + this._fieldsArray = null; + + /** + * Cached oneofs as an array. + * @type {OneOf[]|null} + * @private + */ + this._oneofsArray = null; + + /** + * Cached constructor. + * @type {Constructor<{}>} + * @private + */ + this._ctor = null; +} + +Object.defineProperties(Type.prototype, { + + /** + * Message fields by id. + * @name Type#fieldsById + * @type {Object.} + * @readonly + */ + fieldsById: { + get: function() { + + /* istanbul ignore if */ + if (this._fieldsById) + return this._fieldsById; + + this._fieldsById = {}; + for (var names = Object.keys(this.fields), i = 0; i < names.length; ++i) { + var field = this.fields[names[i]], + id = field.id; + + /* istanbul ignore if */ + if (this._fieldsById[id]) + throw Error("duplicate id " + id + " in " + this); + + this._fieldsById[id] = field; + } + return this._fieldsById; + } + }, + + /** + * Fields of this message as an array for iteration. + * @name Type#fieldsArray + * @type {Field[]} + * @readonly + */ + fieldsArray: { + get: function() { + return this._fieldsArray || (this._fieldsArray = util.toArray(this.fields)); + } + }, + + /** + * Oneofs of this message as an array for iteration. + * @name Type#oneofsArray + * @type {OneOf[]} + * @readonly + */ + oneofsArray: { + get: function() { + return this._oneofsArray || (this._oneofsArray = util.toArray(this.oneofs)); + } + }, + + /** + * The registered constructor, if any registered, otherwise a generic constructor. + * Assigning a function replaces the internal constructor. If the function does not extend {@link Message} yet, its prototype will be setup accordingly and static methods will be populated. If it already extends {@link Message}, it will just replace the internal constructor. + * @name Type#ctor + * @type {Constructor<{}>} + */ + ctor: { + get: function() { + return this._ctor || (this.ctor = Type.generateConstructor(this)()); + }, + set: function(ctor) { + + // Ensure proper prototype + var prototype = ctor.prototype; + if (!(prototype instanceof Message)) { + (ctor.prototype = new Message()).constructor = ctor; + util.merge(ctor.prototype, prototype); + } + + // Classes and messages reference their reflected type + ctor.$type = ctor.prototype.$type = this; + + // Mix in static methods + util.merge(ctor, Message, true); + + this._ctor = ctor; + + // Messages have non-enumerable default values on their prototype + var i = 0; + for (; i < /* initializes */ this.fieldsArray.length; ++i) + this._fieldsArray[i].resolve(); // ensures a proper value + + // Messages have non-enumerable getters and setters for each virtual oneof field + var ctorProperties = {}; + for (i = 0; i < /* initializes */ this.oneofsArray.length; ++i) + ctorProperties[this._oneofsArray[i].resolve().name] = { + get: util.oneOfGetter(this._oneofsArray[i].oneof), + set: util.oneOfSetter(this._oneofsArray[i].oneof) + }; + if (i) + Object.defineProperties(ctor.prototype, ctorProperties); + } + } +}); + +/** + * Generates a constructor function for the specified type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +Type.generateConstructor = function generateConstructor(mtype) { + /* eslint-disable no-unexpected-multiline */ + var gen = util.codegen(["p"], mtype.name); + // explicitly initialize mutable object/array fields so that these aren't just inherited from the prototype + for (var i = 0, field; i < mtype.fieldsArray.length; ++i) + if ((field = mtype._fieldsArray[i]).map) gen + ("this%s={}", util.safeProp(field.name)); + else if (field.repeated) gen + ("this%s=[]", util.safeProp(field.name)); + return gen + ("if(p)for(var ks=Object.keys(p),i=0;i} [oneofs] Oneof descriptors + * @property {Object.} fields Field descriptors + * @property {number[][]} [extensions] Extension ranges + * @property {number[][]} [reserved] Reserved ranges + * @property {boolean} [group=false] Whether a legacy group or not + */ + +/** + * Creates a message type from a message type descriptor. + * @param {string} name Message name + * @param {IType} json Message type descriptor + * @returns {Type} Created message type + */ +Type.fromJSON = function fromJSON(name, json) { + var type = new Type(name, json.options); + type.extensions = json.extensions; + type.reserved = json.reserved; + var names = Object.keys(json.fields), + i = 0; + for (; i < names.length; ++i) + type.add( + ( typeof json.fields[names[i]].keyType !== "undefined" + ? MapField.fromJSON + : Field.fromJSON )(names[i], json.fields[names[i]]) + ); + if (json.oneofs) + for (names = Object.keys(json.oneofs), i = 0; i < names.length; ++i) + type.add(OneOf.fromJSON(names[i], json.oneofs[names[i]])); + if (json.nested) + for (names = Object.keys(json.nested), i = 0; i < names.length; ++i) { + var nested = json.nested[names[i]]; + type.add( // most to least likely + ( nested.id !== undefined + ? Field.fromJSON + : nested.fields !== undefined + ? Type.fromJSON + : nested.values !== undefined + ? Enum.fromJSON + : nested.methods !== undefined + ? Service.fromJSON + : Namespace.fromJSON )(names[i], nested) + ); + } + if (json.extensions && json.extensions.length) + type.extensions = json.extensions; + if (json.reserved && json.reserved.length) + type.reserved = json.reserved; + if (json.group) + type.group = true; + if (json.comment) + type.comment = json.comment; + return type; +}; + +/** + * Converts this message type to a message type descriptor. + * @param {IToJSONOptions} [toJSONOptions] JSON conversion options + * @returns {IType} Message type descriptor + */ +Type.prototype.toJSON = function toJSON(toJSONOptions) { + var inherited = Namespace.prototype.toJSON.call(this, toJSONOptions); + var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false; + return util.toObject([ + "options" , inherited && inherited.options || undefined, + "oneofs" , Namespace.arrayToJSON(this.oneofsArray, toJSONOptions), + "fields" , Namespace.arrayToJSON(this.fieldsArray.filter(function(obj) { return !obj.declaringField; }), toJSONOptions) || {}, + "extensions" , this.extensions && this.extensions.length ? this.extensions : undefined, + "reserved" , this.reserved && this.reserved.length ? this.reserved : undefined, + "group" , this.group || undefined, + "nested" , inherited && inherited.nested || undefined, + "comment" , keepComments ? this.comment : undefined + ]); +}; + +/** + * @override + */ +Type.prototype.resolveAll = function resolveAll() { + var fields = this.fieldsArray, i = 0; + while (i < fields.length) + fields[i++].resolve(); + var oneofs = this.oneofsArray; i = 0; + while (i < oneofs.length) + oneofs[i++].resolve(); + return Namespace.prototype.resolveAll.call(this); +}; + +/** + * @override + */ +Type.prototype.get = function get(name) { + return this.fields[name] + || this.oneofs && this.oneofs[name] + || this.nested && this.nested[name] + || null; +}; + +/** + * Adds a nested object to this type. + * @param {ReflectionObject} object Nested object to add + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If there is already a nested object with this name or, if a field, when there is already a field with this id + */ +Type.prototype.add = function add(object) { + + if (this.get(object.name)) + throw Error("duplicate name '" + object.name + "' in " + this); + + if (object instanceof Field && object.extend === undefined) { + // NOTE: Extension fields aren't actual fields on the declaring type, but nested objects. + // The root object takes care of adding distinct sister-fields to the respective extended + // type instead. + + // avoids calling the getter if not absolutely necessary because it's called quite frequently + if (this._fieldsById ? /* istanbul ignore next */ this._fieldsById[object.id] : this.fieldsById[object.id]) + throw Error("duplicate id " + object.id + " in " + this); + if (this.isReservedId(object.id)) + throw Error("id " + object.id + " is reserved in " + this); + if (this.isReservedName(object.name)) + throw Error("name '" + object.name + "' is reserved in " + this); + + if (object.parent) + object.parent.remove(object); + this.fields[object.name] = object; + object.message = this; + object.onAdd(this); + return clearCache(this); + } + if (object instanceof OneOf) { + if (!this.oneofs) + this.oneofs = {}; + this.oneofs[object.name] = object; + object.onAdd(this); + return clearCache(this); + } + return Namespace.prototype.add.call(this, object); +}; + +/** + * Removes a nested object from this type. + * @param {ReflectionObject} object Nested object to remove + * @returns {Type} `this` + * @throws {TypeError} If arguments are invalid + * @throws {Error} If `object` is not a member of this type + */ +Type.prototype.remove = function remove(object) { + if (object instanceof Field && object.extend === undefined) { + // See Type#add for the reason why extension fields are excluded here. + + /* istanbul ignore if */ + if (!this.fields || this.fields[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.fields[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + if (object instanceof OneOf) { + + /* istanbul ignore if */ + if (!this.oneofs || this.oneofs[object.name] !== object) + throw Error(object + " is not a member of " + this); + + delete this.oneofs[object.name]; + object.parent = null; + object.onRemove(this); + return clearCache(this); + } + return Namespace.prototype.remove.call(this, object); +}; + +/** + * Tests if the specified id is reserved. + * @param {number} id Id to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedId = function isReservedId(id) { + return Namespace.isReservedId(this.reserved, id); +}; + +/** + * Tests if the specified name is reserved. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +Type.prototype.isReservedName = function isReservedName(name) { + return Namespace.isReservedName(this.reserved, name); +}; + +/** + * Creates a new message of this type using the specified properties. + * @param {Object.} [properties] Properties to set + * @returns {Message<{}>} Message instance + */ +Type.prototype.create = function create(properties) { + return new this.ctor(properties); +}; + +/** + * Sets up {@link Type#encode|encode}, {@link Type#decode|decode} and {@link Type#verify|verify}. + * @returns {Type} `this` + */ +Type.prototype.setup = function setup() { + // Sets up everything at once so that the prototype chain does not have to be re-evaluated + // multiple times (V8, soft-deopt prototype-check). + + var fullName = this.fullName, + types = []; + for (var i = 0; i < /* initializes */ this.fieldsArray.length; ++i) + types.push(this._fieldsArray[i].resolve().resolvedType); + + // Replace setup methods with type-specific generated functions + this.encode = encoder(this)({ + Writer : Writer, + types : types, + util : util + }); + this.decode = decoder(this)({ + Reader : Reader, + types : types, + util : util + }); + this.verify = verifier(this)({ + types : types, + util : util + }); + this.fromObject = converter.fromObject(this)({ + types : types, + util : util + }); + this.toObject = converter.toObject(this)({ + types : types, + util : util + }); + + // Inject custom wrappers for common types + var wrapper = wrappers[fullName]; + if (wrapper) { + var originalThis = Object.create(this); + // if (wrapper.fromObject) { + originalThis.fromObject = this.fromObject; + this.fromObject = wrapper.fromObject.bind(originalThis); + // } + // if (wrapper.toObject) { + originalThis.toObject = this.toObject; + this.toObject = wrapper.toObject.bind(originalThis); + // } + } + + return this; +}; + +/** + * Encodes a message of this type. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encode = function encode_setup(message, writer) { + return this.setup().encode(message, writer); // overrides this method +}; + +/** + * Encodes a message of this type preceeded by its byte length as a varint. Does not implicitly {@link Type#verify|verify} messages. + * @param {Message<{}>|Object.} message Message instance or plain object + * @param {Writer} [writer] Writer to encode to + * @returns {Writer} writer + */ +Type.prototype.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer && writer.len ? writer.fork() : writer).ldelim(); +}; + +/** + * Decodes a message of this type. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Length of the message, if known beforehand + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError<{}>} If required fields are missing + */ +Type.prototype.decode = function decode_setup(reader, length) { + return this.setup().decode(reader, length); // overrides this method +}; + +/** + * Decodes a message of this type preceeded by its byte length as a varint. + * @param {Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {Message<{}>} Decoded message + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {util.ProtocolError} If required fields are missing + */ +Type.prototype.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof Reader)) + reader = Reader.create(reader); + return this.decode(reader, reader.uint32()); +}; + +/** + * Verifies that field values are valid and that required fields are present. + * @param {Object.} message Plain object to verify + * @returns {null|string} `null` if valid, otherwise the reason why it is not + */ +Type.prototype.verify = function verify_setup(message) { + return this.setup().verify(message); // overrides this method +}; + +/** + * Creates a new message of this type from a plain object. Also converts values to their respective internal types. + * @param {Object.} object Plain object to convert + * @returns {Message<{}>} Message instance + */ +Type.prototype.fromObject = function fromObject(object) { + return this.setup().fromObject(object); +}; + +/** + * Conversion options as used by {@link Type#toObject} and {@link Message.toObject}. + * @interface IConversionOptions + * @property {Function} [longs] Long conversion type. + * Valid values are `String` and `Number` (the global types). + * Defaults to copy the present value, which is a possibly unsafe number without and a {@link Long} with a long library. + * @property {Function} [enums] Enum value conversion type. + * Only valid value is `String` (the global type). + * Defaults to copy the present value, which is the numeric id. + * @property {Function} [bytes] Bytes value conversion type. + * Valid values are `Array` and (a base64 encoded) `String` (the global types). + * Defaults to copy the present value, which usually is a Buffer under node and an Uint8Array in the browser. + * @property {boolean} [defaults=false] Also sets default values on the resulting object + * @property {boolean} [arrays=false] Sets empty arrays for missing repeated fields even if `defaults=false` + * @property {boolean} [objects=false] Sets empty objects for missing map fields even if `defaults=false` + * @property {boolean} [oneofs=false] Includes virtual oneof properties set to the present field's name, if any + * @property {boolean} [json=false] Performs additional JSON compatibility conversions, i.e. NaN and Infinity to strings + */ + +/** + * Creates a plain object from a message of this type. Also converts values to other types if specified. + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ +Type.prototype.toObject = function toObject(message, options) { + return this.setup().toObject(message, options); +}; + +/** + * Decorator function as returned by {@link Type.d} (TypeScript). + * @typedef TypeDecorator + * @type {function} + * @param {Constructor} target Target constructor + * @returns {undefined} + * @template T extends Message + */ + +/** + * Type decorator (TypeScript). + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {TypeDecorator} Decorator function + * @template T extends Message + */ +Type.d = function decorateType(typeName) { + return function typeDecorator(target) { + util.decorateType(target, typeName); + }; +}; diff --git a/node_modules/protobufjs/src/types.js b/node_modules/protobufjs/src/types.js new file mode 100644 index 0000000..5fda19a --- /dev/null +++ b/node_modules/protobufjs/src/types.js @@ -0,0 +1,196 @@ +"use strict"; + +/** + * Common type constants. + * @namespace + */ +var types = exports; + +var util = require("./util"); + +var s = [ + "double", // 0 + "float", // 1 + "int32", // 2 + "uint32", // 3 + "sint32", // 4 + "fixed32", // 5 + "sfixed32", // 6 + "int64", // 7 + "uint64", // 8 + "sint64", // 9 + "fixed64", // 10 + "sfixed64", // 11 + "bool", // 12 + "string", // 13 + "bytes" // 14 +]; + +function bake(values, offset) { + var i = 0, o = {}; + offset |= 0; + while (i < values.length) o[s[i + offset]] = values[i++]; + return o; +} + +/** + * Basic type wire types. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + * @property {number} bytes=2 Ldelim wire type + */ +types.basic = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2, + /* bytes */ 2 +]); + +/** + * Basic type defaults. + * @type {Object.} + * @const + * @property {number} double=0 Double default + * @property {number} float=0 Float default + * @property {number} int32=0 Int32 default + * @property {number} uint32=0 Uint32 default + * @property {number} sint32=0 Sint32 default + * @property {number} fixed32=0 Fixed32 default + * @property {number} sfixed32=0 Sfixed32 default + * @property {number} int64=0 Int64 default + * @property {number} uint64=0 Uint64 default + * @property {number} sint64=0 Sint32 default + * @property {number} fixed64=0 Fixed64 default + * @property {number} sfixed64=0 Sfixed64 default + * @property {boolean} bool=false Bool default + * @property {string} string="" String default + * @property {Array.} bytes=Array(0) Bytes default + * @property {null} message=null Message default + */ +types.defaults = bake([ + /* double */ 0, + /* float */ 0, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 0, + /* sfixed32 */ 0, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 0, + /* sfixed64 */ 0, + /* bool */ false, + /* string */ "", + /* bytes */ util.emptyArray, + /* message */ null +]); + +/** + * Basic long type wire types. + * @type {Object.} + * @const + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + */ +types.long = bake([ + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1 +], 7); + +/** + * Allowed types for map keys with their associated wire type. + * @type {Object.} + * @const + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + * @property {number} string=2 Ldelim wire type + */ +types.mapKey = bake([ + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0, + /* string */ 2 +], 2); + +/** + * Allowed types for packed repeated fields with their associated wire type. + * @type {Object.} + * @const + * @property {number} double=1 Fixed64 wire type + * @property {number} float=5 Fixed32 wire type + * @property {number} int32=0 Varint wire type + * @property {number} uint32=0 Varint wire type + * @property {number} sint32=0 Varint wire type + * @property {number} fixed32=5 Fixed32 wire type + * @property {number} sfixed32=5 Fixed32 wire type + * @property {number} int64=0 Varint wire type + * @property {number} uint64=0 Varint wire type + * @property {number} sint64=0 Varint wire type + * @property {number} fixed64=1 Fixed64 wire type + * @property {number} sfixed64=1 Fixed64 wire type + * @property {number} bool=0 Varint wire type + */ +types.packed = bake([ + /* double */ 1, + /* float */ 5, + /* int32 */ 0, + /* uint32 */ 0, + /* sint32 */ 0, + /* fixed32 */ 5, + /* sfixed32 */ 5, + /* int64 */ 0, + /* uint64 */ 0, + /* sint64 */ 0, + /* fixed64 */ 1, + /* sfixed64 */ 1, + /* bool */ 0 +]); diff --git a/node_modules/protobufjs/src/typescript.jsdoc b/node_modules/protobufjs/src/typescript.jsdoc new file mode 100644 index 0000000..9a67101 --- /dev/null +++ b/node_modules/protobufjs/src/typescript.jsdoc @@ -0,0 +1,15 @@ +/** + * Constructor type. + * @interface Constructor + * @extends Function + * @template T + * @tstype new(...params: any[]): T; prototype: T; + */ + +/** + * Properties type. + * @typedef Properties + * @template T + * @type {Object.} + * @tstype { [P in keyof T]?: T[P] } + */ diff --git a/node_modules/protobufjs/src/util.js b/node_modules/protobufjs/src/util.js new file mode 100644 index 0000000..a5a9a83 --- /dev/null +++ b/node_modules/protobufjs/src/util.js @@ -0,0 +1,178 @@ +"use strict"; + +/** + * Various utility functions. + * @namespace + */ +var util = module.exports = require("./util/minimal"); + +var roots = require("./roots"); + +var Type, // cyclic + Enum; + +util.codegen = require("@protobufjs/codegen"); +util.fetch = require("@protobufjs/fetch"); +util.path = require("@protobufjs/path"); + +/** + * Node's fs module if available. + * @type {Object.} + */ +util.fs = util.inquire("fs"); + +/** + * Converts an object's values to an array. + * @param {Object.} object Object to convert + * @returns {Array.<*>} Converted array + */ +util.toArray = function toArray(object) { + if (object) { + var keys = Object.keys(object), + array = new Array(keys.length), + index = 0; + while (index < keys.length) + array[index] = object[keys[index++]]; + return array; + } + return []; +}; + +/** + * Converts an array of keys immediately followed by their respective value to an object, omitting undefined values. + * @param {Array.<*>} array Array to convert + * @returns {Object.} Converted object + */ +util.toObject = function toObject(array) { + var object = {}, + index = 0; + while (index < array.length) { + var key = array[index++], + val = array[index++]; + if (val !== undefined) + object[key] = val; + } + return object; +}; + +var safePropBackslashRe = /\\/g, + safePropQuoteRe = /"/g; + +/** + * Tests whether the specified name is a reserved word in JS. + * @param {string} name Name to test + * @returns {boolean} `true` if reserved, otherwise `false` + */ +util.isReserved = function isReserved(name) { + return /^(?:do|if|in|for|let|new|try|var|case|else|enum|eval|false|null|this|true|void|with|break|catch|class|const|super|throw|while|yield|delete|export|import|public|return|static|switch|typeof|default|extends|finally|package|private|continue|debugger|function|arguments|interface|protected|implements|instanceof)$/.test(name); +}; + +/** + * Returns a safe property accessor for the specified property name. + * @param {string} prop Property name + * @returns {string} Safe accessor + */ +util.safeProp = function safeProp(prop) { + if (!/^[$\w_]+$/.test(prop) || util.isReserved(prop)) + return "[\"" + prop.replace(safePropBackslashRe, "\\\\").replace(safePropQuoteRe, "\\\"") + "\"]"; + return "." + prop; +}; + +/** + * Converts the first character of a string to upper case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.ucFirst = function ucFirst(str) { + return str.charAt(0).toUpperCase() + str.substring(1); +}; + +var camelCaseRe = /_([a-z])/g; + +/** + * Converts a string to camel case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.camelCase = function camelCase(str) { + return str.substring(0, 1) + + str.substring(1) + .replace(camelCaseRe, function($0, $1) { return $1.toUpperCase(); }); +}; + +/** + * Compares reflected fields by id. + * @param {Field} a First field + * @param {Field} b Second field + * @returns {number} Comparison value + */ +util.compareFieldsById = function compareFieldsById(a, b) { + return a.id - b.id; +}; + +/** + * Decorator helper for types (TypeScript). + * @param {Constructor} ctor Constructor function + * @param {string} [typeName] Type name, defaults to the constructor's name + * @returns {Type} Reflected type + * @template T extends Message + * @property {Root} root Decorators root + */ +util.decorateType = function decorateType(ctor, typeName) { + + /* istanbul ignore if */ + if (ctor.$type) { + if (typeName && ctor.$type.name !== typeName) { + util.decorateRoot.remove(ctor.$type); + ctor.$type.name = typeName; + util.decorateRoot.add(ctor.$type); + } + return ctor.$type; + } + + /* istanbul ignore next */ + if (!Type) + Type = require("./type"); + + var type = new Type(typeName || ctor.name); + util.decorateRoot.add(type); + type.ctor = ctor; // sets up .encode, .decode etc. + Object.defineProperty(ctor, "$type", { value: type, enumerable: false }); + Object.defineProperty(ctor.prototype, "$type", { value: type, enumerable: false }); + return type; +}; + +var decorateEnumIndex = 0; + +/** + * Decorator helper for enums (TypeScript). + * @param {Object} object Enum object + * @returns {Enum} Reflected enum + */ +util.decorateEnum = function decorateEnum(object) { + + /* istanbul ignore if */ + if (object.$type) + return object.$type; + + /* istanbul ignore next */ + if (!Enum) + Enum = require("./enum"); + + var enm = new Enum("Enum" + decorateEnumIndex++, object); + util.decorateRoot.add(enm); + Object.defineProperty(object, "$type", { value: enm, enumerable: false }); + return enm; +}; + +/** + * Decorator root (TypeScript). + * @name util.decorateRoot + * @type {Root} + * @readonly + */ +Object.defineProperty(util, "decorateRoot", { + get: function() { + return roots["decorated"] || (roots["decorated"] = new (require("./root"))()); + } +}); diff --git a/node_modules/protobufjs/src/util/longbits.js b/node_modules/protobufjs/src/util/longbits.js new file mode 100644 index 0000000..11bfb1c --- /dev/null +++ b/node_modules/protobufjs/src/util/longbits.js @@ -0,0 +1,200 @@ +"use strict"; +module.exports = LongBits; + +var util = require("../util/minimal"); + +/** + * Constructs new long bits. + * @classdesc Helper class for working with the low and high bits of a 64 bit value. + * @memberof util + * @constructor + * @param {number} lo Low 32 bits, unsigned + * @param {number} hi High 32 bits, unsigned + */ +function LongBits(lo, hi) { + + // note that the casts below are theoretically unnecessary as of today, but older statically + // generated converter code might still call the ctor with signed 32bits. kept for compat. + + /** + * Low bits. + * @type {number} + */ + this.lo = lo >>> 0; + + /** + * High bits. + * @type {number} + */ + this.hi = hi >>> 0; +} + +/** + * Zero bits. + * @memberof util.LongBits + * @type {util.LongBits} + */ +var zero = LongBits.zero = new LongBits(0, 0); + +zero.toNumber = function() { return 0; }; +zero.zzEncode = zero.zzDecode = function() { return this; }; +zero.length = function() { return 1; }; + +/** + * Zero hash. + * @memberof util.LongBits + * @type {string} + */ +var zeroHash = LongBits.zeroHash = "\0\0\0\0\0\0\0\0"; + +/** + * Constructs new long bits from the specified number. + * @param {number} value Value + * @returns {util.LongBits} Instance + */ +LongBits.fromNumber = function fromNumber(value) { + if (value === 0) + return zero; + var sign = value < 0; + if (sign) + value = -value; + var lo = value >>> 0, + hi = (value - lo) / 4294967296 >>> 0; + if (sign) { + hi = ~hi >>> 0; + lo = ~lo >>> 0; + if (++lo > 4294967295) { + lo = 0; + if (++hi > 4294967295) + hi = 0; + } + } + return new LongBits(lo, hi); +}; + +/** + * Constructs new long bits from a number, long or string. + * @param {Long|number|string} value Value + * @returns {util.LongBits} Instance + */ +LongBits.from = function from(value) { + if (typeof value === "number") + return LongBits.fromNumber(value); + if (util.isString(value)) { + /* istanbul ignore else */ + if (util.Long) + value = util.Long.fromString(value); + else + return LongBits.fromNumber(parseInt(value, 10)); + } + return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero; +}; + +/** + * Converts this long bits to a possibly unsafe JavaScript number. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {number} Possibly unsafe number + */ +LongBits.prototype.toNumber = function toNumber(unsigned) { + if (!unsigned && this.hi >>> 31) { + var lo = ~this.lo + 1 >>> 0, + hi = ~this.hi >>> 0; + if (!lo) + hi = hi + 1 >>> 0; + return -(lo + hi * 4294967296); + } + return this.lo + this.hi * 4294967296; +}; + +/** + * Converts this long bits to a long. + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long} Long + */ +LongBits.prototype.toLong = function toLong(unsigned) { + return util.Long + ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned)) + /* istanbul ignore next */ + : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) }; +}; + +var charCodeAt = String.prototype.charCodeAt; + +/** + * Constructs new long bits from the specified 8 characters long hash. + * @param {string} hash Hash + * @returns {util.LongBits} Bits + */ +LongBits.fromHash = function fromHash(hash) { + if (hash === zeroHash) + return zero; + return new LongBits( + ( charCodeAt.call(hash, 0) + | charCodeAt.call(hash, 1) << 8 + | charCodeAt.call(hash, 2) << 16 + | charCodeAt.call(hash, 3) << 24) >>> 0 + , + ( charCodeAt.call(hash, 4) + | charCodeAt.call(hash, 5) << 8 + | charCodeAt.call(hash, 6) << 16 + | charCodeAt.call(hash, 7) << 24) >>> 0 + ); +}; + +/** + * Converts this long bits to a 8 characters long hash. + * @returns {string} Hash + */ +LongBits.prototype.toHash = function toHash() { + return String.fromCharCode( + this.lo & 255, + this.lo >>> 8 & 255, + this.lo >>> 16 & 255, + this.lo >>> 24 , + this.hi & 255, + this.hi >>> 8 & 255, + this.hi >>> 16 & 255, + this.hi >>> 24 + ); +}; + +/** + * Zig-zag encodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzEncode = function zzEncode() { + var mask = this.hi >> 31; + this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0; + this.lo = ( this.lo << 1 ^ mask) >>> 0; + return this; +}; + +/** + * Zig-zag decodes this long bits. + * @returns {util.LongBits} `this` + */ +LongBits.prototype.zzDecode = function zzDecode() { + var mask = -(this.lo & 1); + this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0; + this.hi = ( this.hi >>> 1 ^ mask) >>> 0; + return this; +}; + +/** + * Calculates the length of this longbits when encoded as a varint. + * @returns {number} Length + */ +LongBits.prototype.length = function length() { + var part0 = this.lo, + part1 = (this.lo >>> 28 | this.hi << 4) >>> 0, + part2 = this.hi >>> 24; + return part2 === 0 + ? part1 === 0 + ? part0 < 16384 + ? part0 < 128 ? 1 : 2 + : part0 < 2097152 ? 3 : 4 + : part1 < 16384 + ? part1 < 128 ? 5 : 6 + : part1 < 2097152 ? 7 : 8 + : part2 < 128 ? 9 : 10; +}; diff --git a/node_modules/protobufjs/src/util/minimal.js b/node_modules/protobufjs/src/util/minimal.js new file mode 100644 index 0000000..48b62bf --- /dev/null +++ b/node_modules/protobufjs/src/util/minimal.js @@ -0,0 +1,414 @@ +"use strict"; +var util = exports; + +// used to return a Promise where callback is omitted +util.asPromise = require("@protobufjs/aspromise"); + +// converts to / from base64 encoded strings +util.base64 = require("@protobufjs/base64"); + +// base class of rpc.Service +util.EventEmitter = require("@protobufjs/eventemitter"); + +// float handling accross browsers +util.float = require("@protobufjs/float"); + +// requires modules optionally and hides the call from bundlers +util.inquire = require("@protobufjs/inquire"); + +// converts to / from utf8 encoded strings +util.utf8 = require("@protobufjs/utf8"); + +// provides a node-like buffer pool in the browser +util.pool = require("@protobufjs/pool"); + +// utility to work with the low and high bits of a 64 bit value +util.LongBits = require("./longbits"); + +// global object reference +util.global = typeof window !== "undefined" && window + || typeof global !== "undefined" && global + || typeof self !== "undefined" && self + || this; // eslint-disable-line no-invalid-this + +/** + * An immuable empty array. + * @memberof util + * @type {Array.<*>} + * @const + */ +util.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes + +/** + * An immutable empty object. + * @type {Object} + * @const + */ +util.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes + +/** + * Whether running within node or not. + * @memberof util + * @type {boolean} + * @const + */ +util.isNode = Boolean(util.global.process && util.global.process.versions && util.global.process.versions.node); + +/** + * Tests if the specified value is an integer. + * @function + * @param {*} value Value to test + * @returns {boolean} `true` if the value is an integer + */ +util.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) { + return typeof value === "number" && isFinite(value) && Math.floor(value) === value; +}; + +/** + * Tests if the specified value is a string. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a string + */ +util.isString = function isString(value) { + return typeof value === "string" || value instanceof String; +}; + +/** + * Tests if the specified value is a non-null object. + * @param {*} value Value to test + * @returns {boolean} `true` if the value is a non-null object + */ +util.isObject = function isObject(value) { + return value && typeof value === "object"; +}; + +/** + * Checks if a property on a message is considered to be present. + * This is an alias of {@link util.isSet}. + * @function + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isset = + +/** + * Checks if a property on a message is considered to be present. + * @param {Object} obj Plain object or message instance + * @param {string} prop Property name + * @returns {boolean} `true` if considered to be present, otherwise `false` + */ +util.isSet = function isSet(obj, prop) { + var value = obj[prop]; + if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins + return typeof value !== "object" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0; + return false; +}; + +/** + * Any compatible Buffer instance. + * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings. + * @interface Buffer + * @extends Uint8Array + */ + +/** + * Node's Buffer class if available. + * @type {Constructor} + */ +util.Buffer = (function() { + try { + var Buffer = util.inquire("buffer").Buffer; + // refuse to use non-node buffers if not explicitly assigned (perf reasons): + return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null; + } catch (e) { + /* istanbul ignore next */ + return null; + } +})(); + +// Internal alias of or polyfull for Buffer.from. +util._Buffer_from = null; + +// Internal alias of or polyfill for Buffer.allocUnsafe. +util._Buffer_allocUnsafe = null; + +/** + * Creates a new buffer of whatever type supported by the environment. + * @param {number|number[]} [sizeOrArray=0] Buffer size or number array + * @returns {Uint8Array|Buffer} Buffer + */ +util.newBuffer = function newBuffer(sizeOrArray) { + /* istanbul ignore next */ + return typeof sizeOrArray === "number" + ? util.Buffer + ? util._Buffer_allocUnsafe(sizeOrArray) + : new util.Array(sizeOrArray) + : util.Buffer + ? util._Buffer_from(sizeOrArray) + : typeof Uint8Array === "undefined" + ? sizeOrArray + : new Uint8Array(sizeOrArray); +}; + +/** + * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`. + * @type {Constructor} + */ +util.Array = typeof Uint8Array !== "undefined" ? Uint8Array /* istanbul ignore next */ : Array; + +/** + * Any compatible Long instance. + * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js. + * @interface Long + * @property {number} low Low bits + * @property {number} high High bits + * @property {boolean} unsigned Whether unsigned or not + */ + +/** + * Long.js's Long class if available. + * @type {Constructor} + */ +util.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long + || /* istanbul ignore next */ util.global.Long + || util.inquire("long"); + +/** + * Regular expression used to verify 2 bit (`bool`) map keys. + * @type {RegExp} + * @const + */ +util.key2Re = /^true|false|0|1$/; + +/** + * Regular expression used to verify 32 bit (`int32` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key32Re = /^-?(?:0|[1-9][0-9]*)$/; + +/** + * Regular expression used to verify 64 bit (`int64` etc.) map keys. + * @type {RegExp} + * @const + */ +util.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/; + +/** + * Converts a number or long to an 8 characters long hash string. + * @param {Long|number} value Value to convert + * @returns {string} Hash + */ +util.longToHash = function longToHash(value) { + return value + ? util.LongBits.from(value).toHash() + : util.LongBits.zeroHash; +}; + +/** + * Converts an 8 characters long hash string to a long or number. + * @param {string} hash Hash + * @param {boolean} [unsigned=false] Whether unsigned or not + * @returns {Long|number} Original value + */ +util.longFromHash = function longFromHash(hash, unsigned) { + var bits = util.LongBits.fromHash(hash); + if (util.Long) + return util.Long.fromBits(bits.lo, bits.hi, unsigned); + return bits.toNumber(Boolean(unsigned)); +}; + +/** + * Merges the properties of the source object into the destination object. + * @memberof util + * @param {Object.} dst Destination object + * @param {Object.} src Source object + * @param {boolean} [ifNotSet=false] Merges only if the key is not already set + * @returns {Object.} Destination object + */ +function merge(dst, src, ifNotSet) { // used by converters + for (var keys = Object.keys(src), i = 0; i < keys.length; ++i) + if (dst[keys[i]] === undefined || !ifNotSet) + dst[keys[i]] = src[keys[i]]; + return dst; +} + +util.merge = merge; + +/** + * Converts the first character of a string to lower case. + * @param {string} str String to convert + * @returns {string} Converted string + */ +util.lcFirst = function lcFirst(str) { + return str.charAt(0).toLowerCase() + str.substring(1); +}; + +/** + * Creates a custom error constructor. + * @memberof util + * @param {string} name Error name + * @returns {Constructor} Custom error constructor + */ +function newError(name) { + + function CustomError(message, properties) { + + if (!(this instanceof CustomError)) + return new CustomError(message, properties); + + // Error.call(this, message); + // ^ just returns a new error instance because the ctor can be called as a function + + Object.defineProperty(this, "message", { get: function() { return message; } }); + + /* istanbul ignore next */ + if (Error.captureStackTrace) // node + Error.captureStackTrace(this, CustomError); + else + Object.defineProperty(this, "stack", { value: (new Error()).stack || "" }); + + if (properties) + merge(this, properties); + } + + (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError; + + Object.defineProperty(CustomError.prototype, "name", { get: function() { return name; } }); + + CustomError.prototype.toString = function toString() { + return this.name + ": " + this.message; + }; + + return CustomError; +} + +util.newError = newError; + +/** + * Constructs a new protocol error. + * @classdesc Error subclass indicating a protocol specifc error. + * @memberof util + * @extends Error + * @template T extends Message + * @constructor + * @param {string} message Error message + * @param {Object.} [properties] Additional properties + * @example + * try { + * MyMessage.decode(someBuffer); // throws if required fields are missing + * } catch (e) { + * if (e instanceof ProtocolError && e.instance) + * console.log("decoded so far: " + JSON.stringify(e.instance)); + * } + */ +util.ProtocolError = newError("ProtocolError"); + +/** + * So far decoded message instance. + * @name util.ProtocolError#instance + * @type {Message} + */ + +/** + * A OneOf getter as returned by {@link util.oneOfGetter}. + * @typedef OneOfGetter + * @type {function} + * @returns {string|undefined} Set field name, if any + */ + +/** + * Builds a getter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfGetter} Unbound getter + */ +util.oneOfGetter = function getOneOf(fieldNames) { + var fieldMap = {}; + for (var i = 0; i < fieldNames.length; ++i) + fieldMap[fieldNames[i]] = 1; + + /** + * @returns {string|undefined} Set field name, if any + * @this Object + * @ignore + */ + return function() { // eslint-disable-line consistent-return + for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i) + if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null) + return keys[i]; + }; +}; + +/** + * A OneOf setter as returned by {@link util.oneOfSetter}. + * @typedef OneOfSetter + * @type {function} + * @param {string|undefined} value Field name + * @returns {undefined} + */ + +/** + * Builds a setter for a oneof's present field name. + * @param {string[]} fieldNames Field names + * @returns {OneOfSetter} Unbound setter + */ +util.oneOfSetter = function setOneOf(fieldNames) { + + /** + * @param {string} name Field name + * @returns {undefined} + * @this Object + * @ignore + */ + return function(name) { + for (var i = 0; i < fieldNames.length; ++i) + if (fieldNames[i] !== name) + delete this[fieldNames[i]]; + }; +}; + +/** + * Default conversion options used for {@link Message#toJSON} implementations. + * + * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely: + * + * - Longs become strings + * - Enums become string keys + * - Bytes become base64 encoded strings + * - (Sub-)Messages become plain objects + * - Maps become plain objects with all string keys + * - Repeated fields become arrays + * - NaN and Infinity for float and double fields become strings + * + * @type {IConversionOptions} + * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json + */ +util.toJSONOptions = { + longs: String, + enums: String, + bytes: String, + json: true +}; + +// Sets up buffer utility according to the environment (called in index-minimal) +util._configure = function() { + var Buffer = util.Buffer; + /* istanbul ignore if */ + if (!Buffer) { + util._Buffer_from = util._Buffer_allocUnsafe = null; + return; + } + // because node 4.x buffers are incompatible & immutable + // see: https://github.com/dcodeIO/protobuf.js/pull/665 + util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from || + /* istanbul ignore next */ + function Buffer_from(value, encoding) { + return new Buffer(value, encoding); + }; + util._Buffer_allocUnsafe = Buffer.allocUnsafe || + /* istanbul ignore next */ + function Buffer_allocUnsafe(size) { + return new Buffer(size); + }; +}; diff --git a/node_modules/protobufjs/src/verifier.js b/node_modules/protobufjs/src/verifier.js new file mode 100644 index 0000000..d58e27a --- /dev/null +++ b/node_modules/protobufjs/src/verifier.js @@ -0,0 +1,177 @@ +"use strict"; +module.exports = verifier; + +var Enum = require("./enum"), + util = require("./util"); + +function invalid(field, expected) { + return field.name + ": " + expected + (field.repeated && expected !== "array" ? "[]" : field.map && expected !== "object" ? "{k:"+field.keyType+"}" : "") + " expected"; +} + +/** + * Generates a partial value verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {number} fieldIndex Field index + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyValue(gen, field, fieldIndex, ref) { + /* eslint-disable no-unexpected-multiline */ + if (field.resolvedType) { + if (field.resolvedType instanceof Enum) { gen + ("switch(%s){", ref) + ("default:") + ("return%j", invalid(field, "enum value")); + for (var keys = Object.keys(field.resolvedType.values), j = 0; j < keys.length; ++j) gen + ("case %i:", field.resolvedType.values[keys[j]]); + gen + ("break") + ("}"); + } else { + gen + ("{") + ("var e=types[%i].verify(%s);", fieldIndex, ref) + ("if(e)") + ("return%j+e", field.name + ".") + ("}"); + } + } else { + switch (field.type) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.isInteger(%s))", ref) + ("return%j", invalid(field, "integer")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.isInteger(%s)&&!(%s&&util.isInteger(%s.low)&&util.isInteger(%s.high)))", ref, ref, ref, ref) + ("return%j", invalid(field, "integer|Long")); + break; + case "float": + case "double": gen + ("if(typeof %s!==\"number\")", ref) + ("return%j", invalid(field, "number")); + break; + case "bool": gen + ("if(typeof %s!==\"boolean\")", ref) + ("return%j", invalid(field, "boolean")); + break; + case "string": gen + ("if(!util.isString(%s))", ref) + ("return%j", invalid(field, "string")); + break; + case "bytes": gen + ("if(!(%s&&typeof %s.length===\"number\"||util.isString(%s)))", ref, ref, ref) + ("return%j", invalid(field, "buffer")); + break; + } + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a partial key verifier. + * @param {Codegen} gen Codegen instance + * @param {Field} field Reflected field + * @param {string} ref Variable reference + * @returns {Codegen} Codegen instance + * @ignore + */ +function genVerifyKey(gen, field, ref) { + /* eslint-disable no-unexpected-multiline */ + switch (field.keyType) { + case "int32": + case "uint32": + case "sint32": + case "fixed32": + case "sfixed32": gen + ("if(!util.key32Re.test(%s))", ref) + ("return%j", invalid(field, "integer key")); + break; + case "int64": + case "uint64": + case "sint64": + case "fixed64": + case "sfixed64": gen + ("if(!util.key64Re.test(%s))", ref) // see comment above: x is ok, d is not + ("return%j", invalid(field, "integer|Long key")); + break; + case "bool": gen + ("if(!util.key2Re.test(%s))", ref) + ("return%j", invalid(field, "boolean key")); + break; + } + return gen; + /* eslint-enable no-unexpected-multiline */ +} + +/** + * Generates a verifier specific to the specified message type. + * @param {Type} mtype Message type + * @returns {Codegen} Codegen instance + */ +function verifier(mtype) { + /* eslint-disable no-unexpected-multiline */ + + var gen = util.codegen(["m"], mtype.name + "$verify") + ("if(typeof m!==\"object\"||m===null)") + ("return%j", "object expected"); + var oneofs = mtype.oneofsArray, + seenFirstField = {}; + if (oneofs.length) gen + ("var p={}"); + + for (var i = 0; i < /* initializes */ mtype.fieldsArray.length; ++i) { + var field = mtype._fieldsArray[i].resolve(), + ref = "m" + util.safeProp(field.name); + + if (field.optional) gen + ("if(%s!=null&&m.hasOwnProperty(%j)){", ref, field.name); // !== undefined && !== null + + // map fields + if (field.map) { gen + ("if(!util.isObject(%s))", ref) + ("return%j", invalid(field, "object")) + ("var k=Object.keys(%s)", ref) + ("for(var i=0;i} + * @const + */ +var wrappers = exports; + +var Message = require("./message"); + +/** + * From object converter part of an {@link IWrapper}. + * @typedef WrapperFromObjectConverter + * @type {function} + * @param {Object.} object Plain object + * @returns {Message<{}>} Message instance + * @this Type + */ + +/** + * To object converter part of an {@link IWrapper}. + * @typedef WrapperToObjectConverter + * @type {function} + * @param {Message<{}>} message Message instance + * @param {IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + * @this Type + */ + +/** + * Common type wrapper part of {@link wrappers}. + * @interface IWrapper + * @property {WrapperFromObjectConverter} [fromObject] From object converter + * @property {WrapperToObjectConverter} [toObject] To object converter + */ + +// Custom wrapper for Any +wrappers[".google.protobuf.Any"] = { + + fromObject: function(object) { + + // unwrap value type if mapped + if (object && object["@type"]) { + var type = this.lookup(object["@type"]); + /* istanbul ignore else */ + if (type) { + // type_url does not accept leading "." + var type_url = object["@type"].charAt(0) === "." ? + object["@type"].substr(1) : object["@type"]; + // type_url prefix is optional, but path seperator is required + return this.create({ + type_url: "/" + type_url, + value: type.encode(type.fromObject(object)).finish() + }); + } + } + + return this.fromObject(object); + }, + + toObject: function(message, options) { + + // decode value if requested and unmapped + if (options && options.json && message.type_url && message.value) { + // Only use fully qualified type name after the last '/' + var name = message.type_url.substring(message.type_url.lastIndexOf("/") + 1); + var type = this.lookup(name); + /* istanbul ignore else */ + if (type) + message = type.decode(message.value); + } + + // wrap value if unmapped + if (!(message instanceof this.ctor) && message instanceof Message) { + var object = message.$type.toObject(message, options); + object["@type"] = message.$type.fullName; + return object; + } + + return this.toObject(message, options); + } +}; diff --git a/node_modules/protobufjs/src/writer.js b/node_modules/protobufjs/src/writer.js new file mode 100644 index 0000000..f77d83c --- /dev/null +++ b/node_modules/protobufjs/src/writer.js @@ -0,0 +1,459 @@ +"use strict"; +module.exports = Writer; + +var util = require("./util/minimal"); + +var BufferWriter; // cyclic + +var LongBits = util.LongBits, + base64 = util.base64, + utf8 = util.utf8; + +/** + * Constructs a new writer operation instance. + * @classdesc Scheduled writer operation. + * @constructor + * @param {function(*, Uint8Array, number)} fn Function to call + * @param {number} len Value byte length + * @param {*} val Value to write + * @ignore + */ +function Op(fn, len, val) { + + /** + * Function to call. + * @type {function(Uint8Array, number, *)} + */ + this.fn = fn; + + /** + * Value byte length. + * @type {number} + */ + this.len = len; + + /** + * Next operation. + * @type {Writer.Op|undefined} + */ + this.next = undefined; + + /** + * Value to write. + * @type {*} + */ + this.val = val; // type varies +} + +/* istanbul ignore next */ +function noop() {} // eslint-disable-line no-empty-function + +/** + * Constructs a new writer state instance. + * @classdesc Copied writer state. + * @memberof Writer + * @constructor + * @param {Writer} writer Writer to copy state from + * @ignore + */ +function State(writer) { + + /** + * Current head. + * @type {Writer.Op} + */ + this.head = writer.head; + + /** + * Current tail. + * @type {Writer.Op} + */ + this.tail = writer.tail; + + /** + * Current buffer length. + * @type {number} + */ + this.len = writer.len; + + /** + * Next state. + * @type {State|null} + */ + this.next = writer.states; +} + +/** + * Constructs a new writer instance. + * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`. + * @constructor + */ +function Writer() { + + /** + * Current length. + * @type {number} + */ + this.len = 0; + + /** + * Operations head. + * @type {Object} + */ + this.head = new Op(noop, 0, 0); + + /** + * Operations tail + * @type {Object} + */ + this.tail = this.head; + + /** + * Linked forked states. + * @type {Object|null} + */ + this.states = null; + + // When a value is written, the writer calculates its byte length and puts it into a linked + // list of operations to perform when finish() is called. This both allows us to allocate + // buffers of the exact required size and reduces the amount of work we have to do compared + // to first calculating over objects and then encoding over objects. In our case, the encoding + // part is just a linked list walk calling operations with already prepared values. +} + +/** + * Creates a new writer. + * @function + * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer} + */ +Writer.create = util.Buffer + ? function create_buffer_setup() { + return (Writer.create = function create_buffer() { + return new BufferWriter(); + })(); + } + /* istanbul ignore next */ + : function create_array() { + return new Writer(); + }; + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Uint8Array} Buffer + */ +Writer.alloc = function alloc(size) { + return new util.Array(size); +}; + +// Use Uint8Array buffer pool in the browser, just like node does with buffers +/* istanbul ignore else */ +if (util.Array !== Array) + Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray); + +/** + * Pushes a new operation to the queue. + * @param {function(Uint8Array, number, *)} fn Function to call + * @param {number} len Value byte length + * @param {number} val Value to write + * @returns {Writer} `this` + * @private + */ +Writer.prototype._push = function push(fn, len, val) { + this.tail = this.tail.next = new Op(fn, len, val); + this.len += len; + return this; +}; + +function writeByte(val, buf, pos) { + buf[pos] = val & 255; +} + +function writeVarint32(val, buf, pos) { + while (val > 127) { + buf[pos++] = val & 127 | 128; + val >>>= 7; + } + buf[pos] = val; +} + +/** + * Constructs a new varint writer operation instance. + * @classdesc Scheduled varint writer operation. + * @extends Op + * @constructor + * @param {number} len Value byte length + * @param {number} val Value to write + * @ignore + */ +function VarintOp(len, val) { + this.len = len; + this.next = undefined; + this.val = val; +} + +VarintOp.prototype = Object.create(Op.prototype); +VarintOp.prototype.fn = writeVarint32; + +/** + * Writes an unsigned 32 bit value as a varint. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.uint32 = function write_uint32(value) { + // here, the call to this.push has been inlined and a varint specific Op subclass is used. + // uint32 is by far the most frequently used operation and benefits significantly from this. + this.len += (this.tail = this.tail.next = new VarintOp( + (value = value >>> 0) + < 128 ? 1 + : value < 16384 ? 2 + : value < 2097152 ? 3 + : value < 268435456 ? 4 + : 5, + value)).len; + return this; +}; + +/** + * Writes a signed 32 bit value as a varint. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.int32 = function write_int32(value) { + return value < 0 + ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec + : this.uint32(value); +}; + +/** + * Writes a 32 bit value as a varint, zig-zag encoded. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sint32 = function write_sint32(value) { + return this.uint32((value << 1 ^ value >> 31) >>> 0); +}; + +function writeVarint64(val, buf, pos) { + while (val.hi) { + buf[pos++] = val.lo & 127 | 128; + val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0; + val.hi >>>= 7; + } + while (val.lo > 127) { + buf[pos++] = val.lo & 127 | 128; + val.lo = val.lo >>> 7; + } + buf[pos++] = val.lo; +} + +/** + * Writes an unsigned 64 bit value as a varint. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.uint64 = function write_uint64(value) { + var bits = LongBits.from(value); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a signed 64 bit value as a varint. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.int64 = Writer.prototype.uint64; + +/** + * Writes a signed 64 bit value as a varint, zig-zag encoded. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sint64 = function write_sint64(value) { + var bits = LongBits.from(value).zzEncode(); + return this._push(writeVarint64, bits.length(), bits); +}; + +/** + * Writes a boolish value as a varint. + * @param {boolean} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.bool = function write_bool(value) { + return this._push(writeByte, 1, value ? 1 : 0); +}; + +function writeFixed32(val, buf, pos) { + buf[pos ] = val & 255; + buf[pos + 1] = val >>> 8 & 255; + buf[pos + 2] = val >>> 16 & 255; + buf[pos + 3] = val >>> 24; +} + +/** + * Writes an unsigned 32 bit value as fixed 32 bits. + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.fixed32 = function write_fixed32(value) { + return this._push(writeFixed32, 4, value >>> 0); +}; + +/** + * Writes a signed 32 bit value as fixed 32 bits. + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.sfixed32 = Writer.prototype.fixed32; + +/** + * Writes an unsigned 64 bit value as fixed 64 bits. + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.fixed64 = function write_fixed64(value) { + var bits = LongBits.from(value); + return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi); +}; + +/** + * Writes a signed 64 bit value as fixed 64 bits. + * @function + * @param {Long|number|string} value Value to write + * @returns {Writer} `this` + * @throws {TypeError} If `value` is a string and no long library is present. + */ +Writer.prototype.sfixed64 = Writer.prototype.fixed64; + +/** + * Writes a float (32 bit). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.float = function write_float(value) { + return this._push(util.float.writeFloatLE, 4, value); +}; + +/** + * Writes a double (64 bit float). + * @function + * @param {number} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.double = function write_double(value) { + return this._push(util.float.writeDoubleLE, 8, value); +}; + +var writeBytes = util.Array.prototype.set + ? function writeBytes_set(val, buf, pos) { + buf.set(val, pos); // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytes_for(val, buf, pos) { + for (var i = 0; i < val.length; ++i) + buf[pos + i] = val[i]; + }; + +/** + * Writes a sequence of bytes. + * @param {Uint8Array|string} value Buffer or base64 encoded string to write + * @returns {Writer} `this` + */ +Writer.prototype.bytes = function write_bytes(value) { + var len = value.length >>> 0; + if (!len) + return this._push(writeByte, 1, 0); + if (util.isString(value)) { + var buf = Writer.alloc(len = base64.length(value)); + base64.decode(value, buf, 0); + value = buf; + } + return this.uint32(len)._push(writeBytes, len, value); +}; + +/** + * Writes a string. + * @param {string} value Value to write + * @returns {Writer} `this` + */ +Writer.prototype.string = function write_string(value) { + var len = utf8.length(value); + return len + ? this.uint32(len)._push(utf8.write, len, value) + : this._push(writeByte, 1, 0); +}; + +/** + * Forks this writer's state by pushing it to a stack. + * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state. + * @returns {Writer} `this` + */ +Writer.prototype.fork = function fork() { + this.states = new State(this); + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + return this; +}; + +/** + * Resets this instance to the last state. + * @returns {Writer} `this` + */ +Writer.prototype.reset = function reset() { + if (this.states) { + this.head = this.states.head; + this.tail = this.states.tail; + this.len = this.states.len; + this.states = this.states.next; + } else { + this.head = this.tail = new Op(noop, 0, 0); + this.len = 0; + } + return this; +}; + +/** + * Resets to the last state and appends the fork state's current write length as a varint followed by its operations. + * @returns {Writer} `this` + */ +Writer.prototype.ldelim = function ldelim() { + var head = this.head, + tail = this.tail, + len = this.len; + this.reset().uint32(len); + if (len) { + this.tail.next = head.next; // skip noop + this.tail = tail; + this.len += len; + } + return this; +}; + +/** + * Finishes the write operation. + * @returns {Uint8Array} Finished buffer + */ +Writer.prototype.finish = function finish() { + var head = this.head.next, // skip noop + buf = this.constructor.alloc(this.len), + pos = 0; + while (head) { + head.fn(head.val, buf, pos); + pos += head.len; + head = head.next; + } + // this.head = this.tail = null; + return buf; +}; + +Writer._configure = function(BufferWriter_) { + BufferWriter = BufferWriter_; +}; diff --git a/node_modules/protobufjs/src/writer_buffer.js b/node_modules/protobufjs/src/writer_buffer.js new file mode 100644 index 0000000..55c479c --- /dev/null +++ b/node_modules/protobufjs/src/writer_buffer.js @@ -0,0 +1,81 @@ +"use strict"; +module.exports = BufferWriter; + +// extends Writer +var Writer = require("./writer"); +(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter; + +var util = require("./util/minimal"); + +var Buffer = util.Buffer; + +/** + * Constructs a new buffer writer instance. + * @classdesc Wire format writer using node buffers. + * @extends Writer + * @constructor + */ +function BufferWriter() { + Writer.call(this); +} + +/** + * Allocates a buffer of the specified size. + * @param {number} size Buffer size + * @returns {Buffer} Buffer + */ +BufferWriter.alloc = function alloc_buffer(size) { + return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size); +}; + +var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set" + ? function writeBytesBuffer_set(val, buf, pos) { + buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited) + // also works for plain array values + } + /* istanbul ignore next */ + : function writeBytesBuffer_copy(val, buf, pos) { + if (val.copy) // Buffer values + val.copy(buf, pos, 0, val.length); + else for (var i = 0; i < val.length;) // plain array values + buf[pos++] = val[i++]; + }; + +/** + * @override + */ +BufferWriter.prototype.bytes = function write_bytes_buffer(value) { + if (util.isString(value)) + value = util._Buffer_from(value, "base64"); + var len = value.length >>> 0; + this.uint32(len); + if (len) + this._push(writeBytesBuffer, len, value); + return this; +}; + +function writeStringBuffer(val, buf, pos) { + if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions) + util.utf8.write(val, buf, pos); + else + buf.utf8Write(val, pos); +} + +/** + * @override + */ +BufferWriter.prototype.string = function write_string_buffer(value) { + var len = Buffer.byteLength(value); + this.uint32(len); + if (len) + this._push(writeStringBuffer, len, value); + return this; +}; + + +/** + * Finishes the write operation. + * @name BufferWriter#finish + * @function + * @returns {Buffer} Finished buffer + */ diff --git a/node_modules/protobufjs/tsconfig.json b/node_modules/protobufjs/tsconfig.json new file mode 100644 index 0000000..22852fa --- /dev/null +++ b/node_modules/protobufjs/tsconfig.json @@ -0,0 +1,7 @@ +{ + "compilerOptions": { + "target": "ES5", + "experimentalDecorators": true, + "emitDecoratorMetadata": true + } +} \ No newline at end of file diff --git a/node_modules/querystring/.History.md.un~ b/node_modules/querystring/.History.md.un~ new file mode 100644 index 0000000000000000000000000000000000000000..c96a7dd8c8c86e2e4b6af0478b1bc122b929528d GIT binary patch literal 7960 zcmeI1O>0v@6ozk__}SL4mLj+rD1;VG%uP&mDblr2L05iY+Y|yOx0H0*MfHaW;zHes zKR`F`T=@gs`hk0K;X==IGN(>L?aJBB3n!DAdy@?3;XU`)S!)7yiU;&V2&^z8MM z_O~xGQz3{XCeC6fM$1j%OzWXru>3x=E^Ac0e$!mpo5+#Xq5{S_vTkUMz zuW+=IJ^08`5g#ydh*13&{hirr8vkDgRy%8%;>fZe=l$2h@R$S`78YHj-l(_SW!G%v zd987!mUrA@dr#qUMp?pSNJ_l70&gjVNBWOSOu%a%Tp;ai+aKUqn`0q4k1WKLz+3(o zyv!FzkZ`p#0hgesNr*^7R0*PsAtG=bmpCcGHEe#=fQ9Dmz#6q#%RwOxR6L$U>@xmX=tfkh&gPir=9Y8Y%7Y^LoR2jl5aQTOJ*#w5#Al zqW${GB%vb7^QPhnO@ ZFiAa69(m~N+kCx4vvqx5-`@NB>JPML-n9S# literal 0 HcmV?d00001 diff --git a/node_modules/querystring/.Readme.md.un~ b/node_modules/querystring/.Readme.md.un~ new file mode 100644 index 0000000000000000000000000000000000000000..71613b59ba1b551647a6ba1b47180a44ac70212b GIT binary patch literal 3225 zcmeHJyGjE=6dhxHHnxHY5fx2g(wK;m2tL4CM2U#VlB~&Ul8rO75g(v-*8YIKrG>3O zV4?PwVrgY5de3Y|*AUQ%YqbYXhTNHb%sprCofWHezFeNSA6e+|G>1{HPna%a9q zp?4>dB~Fx_m_f}bEc`<0w6uAF!lBtZI=41*ERw;dU*sfHzCq6QQM z(+C8rAq#$jR2#4V2qA}7&H7al*JZhx3SRRAv~Tn57%zhgoI^2MwfumpG2qeK*kR#H{5#i5Mo3~;7 L>#09+@^tYI$G;b9 literal 0 HcmV?d00001 diff --git a/node_modules/querystring/.package.json.un~ b/node_modules/querystring/.package.json.un~ new file mode 100644 index 0000000000000000000000000000000000000000..d86fe314c5aaeffce89d94a968668c5dc133ba5b GIT binary patch literal 5710 zcmeHLOKTKC5T3-u_&`k*#kb>v5n;0rb>mwIL_}{n=tV>}yR&9w=i$t5j7Sb%Jt!(3 z#j~D7Px=RZ9K@@FM-@en9!0;erhB)O4H6P_n}%advIf~Yu2>IpEI{p6-nwZjxRQ_iVj17;! z7CJ2J*JjwJ>o);g0aDRz+b#V7{%--S(oLa`NW0+oTY(hIAm$NE$+IKoH;x2dTe_-tEeJ1%Z=M1ZOox*jx?OI z;BL#4u&_;g6>?JdLDdHdv+jf{mN*-jUEZjtZacu}T8rR|E0G&EBxgdCoe_|JP<3oZ zXPoEn(AB0BU5^`)>tD`Yi8Hi<9^r$q^VYWWHHj*1MG`eAH4Fdhb|Wvc+)NN4N9X%K3+ zEKs&QiS=YhP9l&-zN|bI3e_tiYvT!kL8pQ(EANE5Xp-L@KxffBJhNzqo*gxPshdMm zK?etI-&BrA!L`_lYweI$<0LH0a(RkNUQlh;oj4y(l>J8FxwY&0ao5jRyeew2 zos-I(uLPbK_$!kb(xC? zt2)(Y$kTvqZ^(7(P+!ME0h4Y(wM`b+Ts#Sv$$c2M2V_`zKp#dnPzh76GZof@h|h5W zrq(2C3>?Ad7${aGii>=7F@&MYL=<>>1t?2eW`Ch`$$B+bb0en~OsT8j8I-=rHMHF} zQ!I6w(N~VkwQ}StEA1tvTv3d)?|!(`M!&jb5IRx0!$fg^vZ61UbrHAJ%kDHfW@cd~ z(O;#|l`L}{QeLLg%tDteqM4b6{W(rzm1mM!mM6vG7$z~Zi~!6m;A}dp-<-?}fHC2X k7WsA2O1YvJ7SZOxmG@1!>PxuN-yAeobAJIY-TeCGFNStew*UYD literal 0 HcmV?d00001 diff --git a/node_modules/querystring/.travis.yml b/node_modules/querystring/.travis.yml new file mode 100644 index 0000000..895dbd3 --- /dev/null +++ b/node_modules/querystring/.travis.yml @@ -0,0 +1,4 @@ +language: node_js +node_js: + - 0.6 + - 0.8 diff --git a/node_modules/querystring/History.md b/node_modules/querystring/History.md new file mode 100644 index 0000000..4fddbaf --- /dev/null +++ b/node_modules/querystring/History.md @@ -0,0 +1,20 @@ +# 0.2.0 / 2013-02-21 + + - Refactor into function per-module idiomatic style. + - Improved test coverage. + +# 0.1.0 / 2011-12-13 + + - Minor project reorganization + +# 0.0.3 / 2011-04-16 + - Support for AMD module loaders + +# 0.0.2 / 2011-04-16 + + - Ported unit tests + - Removed functionality that depended on Buffers + +# 0.0.1 / 2011-04-15 + + - Initial release diff --git a/node_modules/querystring/License.md b/node_modules/querystring/License.md new file mode 100644 index 0000000..fc80e85 --- /dev/null +++ b/node_modules/querystring/License.md @@ -0,0 +1,19 @@ + +Copyright 2012 Irakli Gozalishvili. All rights reserved. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to +deal in the Software without restriction, including without limitation the +rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +sell copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +IN THE SOFTWARE. diff --git a/node_modules/querystring/Readme.md b/node_modules/querystring/Readme.md new file mode 100644 index 0000000..a4fe252 --- /dev/null +++ b/node_modules/querystring/Readme.md @@ -0,0 +1,15 @@ +# querystring + +[![Build Status](https://secure.travis-ci.org/Gozala/querystring.png)](http://travis-ci.org/Gozala/querystring) + + +[![Browser support](http://ci.testling.com/Gozala/querystring.png)](http://ci.testling.com/Gozala/querystring) + + + +Node's querystring module for all engines. + +## Install ## + + npm install querystring + diff --git a/node_modules/querystring/decode.js b/node_modules/querystring/decode.js new file mode 100644 index 0000000..a6518b8 --- /dev/null +++ b/node_modules/querystring/decode.js @@ -0,0 +1,80 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +'use strict'; + +// If obj.hasOwnProperty has been overridden, then calling +// obj.hasOwnProperty(prop) will break. +// See: https://github.com/joyent/node/issues/1707 +function hasOwnProperty(obj, prop) { + return Object.prototype.hasOwnProperty.call(obj, prop); +} + +module.exports = function(qs, sep, eq, options) { + sep = sep || '&'; + eq = eq || '='; + var obj = {}; + + if (typeof qs !== 'string' || qs.length === 0) { + return obj; + } + + var regexp = /\+/g; + qs = qs.split(sep); + + var maxKeys = 1000; + if (options && typeof options.maxKeys === 'number') { + maxKeys = options.maxKeys; + } + + var len = qs.length; + // maxKeys <= 0 means that we should not limit keys count + if (maxKeys > 0 && len > maxKeys) { + len = maxKeys; + } + + for (var i = 0; i < len; ++i) { + var x = qs[i].replace(regexp, '%20'), + idx = x.indexOf(eq), + kstr, vstr, k, v; + + if (idx >= 0) { + kstr = x.substr(0, idx); + vstr = x.substr(idx + 1); + } else { + kstr = x; + vstr = ''; + } + + k = decodeURIComponent(kstr); + v = decodeURIComponent(vstr); + + if (!hasOwnProperty(obj, k)) { + obj[k] = v; + } else if (Array.isArray(obj[k])) { + obj[k].push(v); + } else { + obj[k] = [obj[k], v]; + } + } + + return obj; +}; diff --git a/node_modules/querystring/encode.js b/node_modules/querystring/encode.js new file mode 100644 index 0000000..4f2b561 --- /dev/null +++ b/node_modules/querystring/encode.js @@ -0,0 +1,64 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +'use strict'; + +var stringifyPrimitive = function(v) { + switch (typeof v) { + case 'string': + return v; + + case 'boolean': + return v ? 'true' : 'false'; + + case 'number': + return isFinite(v) ? v : ''; + + default: + return ''; + } +}; + +module.exports = function(obj, sep, eq, name) { + sep = sep || '&'; + eq = eq || '='; + if (obj === null) { + obj = undefined; + } + + if (typeof obj === 'object') { + return Object.keys(obj).map(function(k) { + var ks = encodeURIComponent(stringifyPrimitive(k)) + eq; + if (Array.isArray(obj[k])) { + return obj[k].map(function(v) { + return ks + encodeURIComponent(stringifyPrimitive(v)); + }).join(sep); + } else { + return ks + encodeURIComponent(stringifyPrimitive(obj[k])); + } + }).join(sep); + + } + + if (!name) return ''; + return encodeURIComponent(stringifyPrimitive(name)) + eq + + encodeURIComponent(stringifyPrimitive(obj)); +}; diff --git a/node_modules/querystring/index.js b/node_modules/querystring/index.js new file mode 100644 index 0000000..99826ea --- /dev/null +++ b/node_modules/querystring/index.js @@ -0,0 +1,4 @@ +'use strict'; + +exports.decode = exports.parse = require('./decode'); +exports.encode = exports.stringify = require('./encode'); diff --git a/node_modules/querystring/package.json b/node_modules/querystring/package.json new file mode 100644 index 0000000..0775083 --- /dev/null +++ b/node_modules/querystring/package.json @@ -0,0 +1,100 @@ +{ + "_from": "querystring@0.2.0", + "_id": "querystring@0.2.0", + "_inBundle": false, + "_integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", + "_location": "/querystring", + "_phantomChildren": {}, + "_requested": { + "type": "version", + "registry": true, + "raw": "querystring@0.2.0", + "name": "querystring", + "escapedName": "querystring", + "rawSpec": "0.2.0", + "saveSpec": null, + "fetchSpec": "0.2.0" + }, + "_requiredBy": [ + "/url" + ], + "_resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "_shasum": "b209849203bb25df820da756e747005878521620", + "_spec": "querystring@0.2.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\url", + "author": { + "name": "Irakli Gozalishvili", + "email": "rfobic@gmail.com" + }, + "bugs": { + "url": "http://github.com/Gozala/querystring/issues/" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "Node's querystring module for all engines.", + "devDependencies": { + "phantomify": "~0.x.0", + "retape": "~0.x.0", + "tape": "~0.1.5", + "test": "~0.x.0" + }, + "engines": { + "node": ">=0.4.x" + }, + "homepage": "https://github.com/Gozala/querystring#readme", + "id": "querystring", + "keywords": [ + "commonjs", + "query", + "querystring" + ], + "licenses": [ + { + "type": "MIT", + "url": "https://github.com/Gozala/enchain/License.md" + } + ], + "name": "querystring", + "repository": { + "type": "git", + "url": "git://github.com/Gozala/querystring.git", + "web": "https://github.com/Gozala/querystring" + }, + "scripts": { + "test": "npm run test-node && npm run test-browser && npm run test-tap", + "test-browser": "node ./node_modules/phantomify/bin/cmd.js ./test/common-index.js", + "test-node": "node ./test/common-index.js", + "test-tap": "node ./test/tap-index.js" + }, + "testling": { + "files": "test/tap-index.js", + "browsers": { + "iexplore": [ + 9, + 10 + ], + "chrome": [ + 16, + 20, + 25, + "canary" + ], + "firefox": [ + 10, + 15, + 16, + 17, + 18, + "nightly" + ], + "safari": [ + 5, + 6 + ], + "opera": [ + 12 + ] + } + }, + "version": "0.2.0" +} diff --git a/node_modules/querystring/test/.index.js.un~ b/node_modules/querystring/test/.index.js.un~ new file mode 100644 index 0000000000000000000000000000000000000000..898eceddc9e485e85275e41f9b8b98294bb3fe08 GIT binary patch literal 975 zcmWH`%$*;a=aT=Ffr(>^0h6blXhl42hkT^^Cju)3aORMz^9E7#J=A zF*0BTa+sh3AR2}l0?m@ovVde68R9P>DS$G8!VCjM7vN0bq2T0Y?V| z!&eEQ*`RoY1wSY%7)%?%(FA6L_)q|fPnbG}(P)AN3$18)G%;e2CfTCY!qUv5R1Kw) b)Z!8)O}(PhJdM ; :'); + }); +}; + +exports['test the weird objects, that they get parsed properly'] = function(assert) { + qsWeirdObjects.forEach(function(testCase) { + assert.deepEqual(testCase[2], qs.parse(testCase[1]), + 'parse ' + testCase[1]); + }); +}; + +exports['test non munge test cases'] = function(assert) { + qsNoMungeTestCases.forEach(function(testCase) { + assert.deepEqual(testCase[0], qs.stringify(testCase[1], '&', '=', false), + 'stringify ' + JSON.stringify(testCase[1]) + ' -> & ='); + }); +}; + +exports['test the nested qs-in-qs case'] = function(assert) { + var f = qs.parse('a=b&q=x%3Dy%26y%3Dz'); + f.q = qs.parse(f.q); + assert.deepEqual(f, { a: 'b', q: { x: 'y', y: 'z' } }, + 'parse a=b&q=x%3Dy%26y%3Dz'); +}; + +exports['test nested in colon'] = function(assert) { + var f = qs.parse('a:b;q:x%3Ay%3By%3Az', ';', ':'); + f.q = qs.parse(f.q, ';', ':'); + assert.deepEqual(f, { a: 'b', q: { x: 'y', y: 'z' } }, + 'parse a:b;q:x%3Ay%3By%3Az -> ; :'); +}; + +exports['test stringifying'] = function(assert) { + qsTestCases.forEach(function(testCase) { + assert.equal(testCase[1], qs.stringify(testCase[2]), + 'stringify ' + JSON.stringify(testCase[2])); + }); + + qsColonTestCases.forEach(function(testCase) { + assert.equal(testCase[1], qs.stringify(testCase[2], ';', ':'), + 'stringify ' + JSON.stringify(testCase[2]) + ' -> ; :'); + }); + + qsWeirdObjects.forEach(function(testCase) { + assert.equal(testCase[1], qs.stringify(testCase[0]), + 'stringify ' + JSON.stringify(testCase[0])); + }); +}; + +exports['test stringifying nested'] = function(assert) { + var f = qs.stringify({ + a: 'b', + q: qs.stringify({ + x: 'y', + y: 'z' + }) + }); + assert.equal(f, 'a=b&q=x%3Dy%26y%3Dz', + JSON.stringify({ + a: 'b', + 'qs.stringify -> q': { + x: 'y', + y: 'z' + } + })); + + var threw = false; + try { qs.parse(undefined); } catch(error) { threw = true; } + assert.ok(!threw, "does not throws on undefined"); +}; + +exports['test nested in colon'] = function(assert) { + var f = qs.stringify({ + a: 'b', + q: qs.stringify({ + x: 'y', + y: 'z' + }, ';', ':') + }, ';', ':'); + assert.equal(f, 'a:b;q:x%3Ay%3By%3Az', + 'stringify ' + JSON.stringify({ + a: 'b', + 'qs.stringify -> q': { + x: 'y', + y: 'z' + } + }) + ' -> ; : '); + + + assert.deepEqual({}, qs.parse(), 'parse undefined'); +}; diff --git a/node_modules/querystring/test/tap-index.js b/node_modules/querystring/test/tap-index.js new file mode 100644 index 0000000..70679b3 --- /dev/null +++ b/node_modules/querystring/test/tap-index.js @@ -0,0 +1,3 @@ +"use strict"; + +require("retape")(require("./index")) \ No newline at end of file diff --git a/node_modules/seedrandom/.coveralls.yml b/node_modules/seedrandom/.coveralls.yml new file mode 100644 index 0000000..9160059 --- /dev/null +++ b/node_modules/seedrandom/.coveralls.yml @@ -0,0 +1 @@ +service_name: travis-ci diff --git a/node_modules/seedrandom/.npmignore b/node_modules/seedrandom/.npmignore new file mode 100644 index 0000000..a088b6f --- /dev/null +++ b/node_modules/seedrandom/.npmignore @@ -0,0 +1,2 @@ +node_modules +bower_components diff --git a/node_modules/seedrandom/.nvmrc b/node_modules/seedrandom/.nvmrc new file mode 100644 index 0000000..1e8b314 --- /dev/null +++ b/node_modules/seedrandom/.nvmrc @@ -0,0 +1 @@ +6 diff --git a/node_modules/seedrandom/.travis.yml b/node_modules/seedrandom/.travis.yml new file mode 100644 index 0000000..205850f --- /dev/null +++ b/node_modules/seedrandom/.travis.yml @@ -0,0 +1,9 @@ +language: node_js +sudo: false +node_js: +- '0.10' +- '0.12' +- '4' +- '5' +- '6' +- '7' diff --git a/node_modules/seedrandom/Gruntfile.js b/node_modules/seedrandom/Gruntfile.js new file mode 100644 index 0000000..c24df6e --- /dev/null +++ b/node_modules/seedrandom/Gruntfile.js @@ -0,0 +1,108 @@ +module.exports = function(grunt) { + "use strict"; + + grunt.initConfig({ + pkg: grunt.file.readJSON("package.json"), + bowercopy: { + options: { + clean: true + }, + test: { + options: { + destPrefix: "test/lib" + }, + files: { + "qunit.js" : "qunit/qunit/qunit.js", + "qunit.css" : "qunit/qunit/qunit.css", + "require.js" : "requirejs/require.js" + } + } + }, + uglify: { + all: { + files: { + "<%= pkg.name %>.min.js": [ "<%= pkg.name %>.js" ], + "lib/alea.min.js": [ "lib/alea.js" ], + "lib/tychei.min.js": [ "lib/tychei.js" ], + "lib/xor4096.min.js": [ "lib/xor4096.js" ], + "lib/xorshift7.min.js": [ "lib/xorshift7.js" ], + "lib/xorwow.min.js": [ "lib/xorwow.js" ], + "lib/xor128.min.js": [ "lib/xor128.js" ] + }, + options: { + preserveComments: false, + report: "min", + beautify: { + ascii_only: true + } + } + } + }, + qunit: { + options: { + noGlobals: true, + httpBase: 'http://localhost:8192' + }, + all: ["test/*.html"] + }, + connect: { + server: { + options: { + port: 8192, + base: '.' + } + } + }, + browserify: { + test: { + files: { + 'test/browserified.js': ['test/nodetest.js'], + }, + options: { + ignore: ['requirejs', 'process'], + alias: { + 'assert': './test/qunitassert.js' + } + } + } + }, + mochacov: { + options: { + files: [ + 'test/cryptotest.js', + 'test/nodetest.js', + 'test/prngtest.js' + ] + }, + coverage: { + options: { + coveralls: true + } + }, + test: { + options: { + reporter: 'dot' + } + } + }, + release: { + options: { + bump: false + } + } + }); + + grunt.loadNpmTasks('grunt-bowercopy'); + grunt.loadNpmTasks('grunt-contrib-connect'); + grunt.loadNpmTasks('grunt-contrib-qunit'); + grunt.loadNpmTasks('grunt-contrib-uglify'); + grunt.loadNpmTasks('grunt-mocha-cov'); + grunt.loadNpmTasks('grunt-release'); + grunt.loadNpmTasks('grunt-browserify'); + + grunt.registerTask("test", + ["browserify", "connect", "qunit", "mochacov:test"]); + grunt.registerTask("default", ["uglify", "test"]); + grunt.registerTask("travis", ["default", "mochacov:coverage"]); +}; + diff --git a/node_modules/seedrandom/README.md b/node_modules/seedrandom/README.md new file mode 100644 index 0000000..3645bcc --- /dev/null +++ b/node_modules/seedrandom/README.md @@ -0,0 +1,298 @@ +seedrandom.js +============= +[![Build Status](https://travis-ci.org/davidbau/seedrandom.svg?branch=master)](https://travis-ci.org/davidbau/seedrandom) +[![NPM version](https://badge.fury.io/js/seedrandom.svg)](http://badge.fury.io/js/seedrandom) +[![Bower version](https://badge.fury.io/bo/seedrandom.svg)](http://badge.fury.io/bo/seedrandom) + +Seeded random number generator for JavaScript. + +Version 2.4.3 + +Author: David Bau + +Date: 2015-07-04 + +Can be used as a plain script, a Node.js module or an AMD module. + + +Script tag usage +---------------- + +```html + +``` + +```js +// Sets Math.random to a PRNG initialized using the given explicit seed. +Math.seedrandom('hello.'); +console.log(Math.random()); // Always 0.9282578795792454 +console.log(Math.random()); // Always 0.3752569768646784 + +// Sets Math.random to an ARC4-based PRNG that is autoseeded using the +// current time, dom state, and other accumulated local entropy. +// The generated seed string is returned. +Math.seedrandom(); +console.log(Math.random()); // Reasonably unpredictable. + +// Seeds using the given explicit seed mixed with accumulated entropy. +Math.seedrandom('added entropy.', { entropy: true }); +console.log(Math.random()); // As unpredictable as added entropy. + +// Use "new" to create a local prng without altering Math.random. +var myrng = new Math.seedrandom('hello.'); +console.log(myrng()); // Always 0.9282578795792454 + +// Use "quick" to get only 32 bits of randomness in a float. +console.log(myrng.quick()); // Always 0.3752569768112153 + +// Use "int32" to get a 32 bit (signed) integer +console.log(myrng.int32()); // Always 986220731 + +``` + +Other Fast PRNG Algorithms +-------------------------- + +The package includes some other fast PRNGs. To use Johannes Baagøe's +extremely fast Alea PRNG: + + +```html + +``` + +```js +// Use xor4096 for Richard Brent's xorgens-4096 algorithm. +var xorgen = new xor4096('hello.'); + +// By default provides 32 bits of randomness in a float. +console.log(xorgen()); // Always 0.9798525865189731 + +// Use "double" to get 56 bits of randomness. +console.log(xorgen.double()); // Always 0.03583478477375346 + +// Use "int32" to get a 32 bit (signed) integer. +console.log(xorgen.int32()); // Always 1341429986 +```` + +Besides xor4096, there are several other faster PRNGs available. + +|PRNG name | Time vs native | Period | Author | +|-----------|----------------|-------------|----------------------| +|`alea` | 1.95 ns, 0.9x | ~2^116 | Baagøe | +|`xor128` | 2.04 ns, 0.9x | 2^128-1 | Marsaglia | +|`tychei` | 2.32 ns, 1.1x | ~2^127 | Neves/Araujo (ChaCha)| +|`xorwow` | 2.40 ns, 1.1x | 2^192-2^32 | Marsaglia | +|`xor4096` | 2.40 ns, 1.1x | 2^4096-2^32 | Brent (xorgens) | +|`xorshift7`| 2.64 ns, 1.3x | 2^256-1 | Panneton/L'ecuyer | +|`quick` | 3.80 ns, 1.8x | ~2^1600 | Bau (ARC4) | + +(Timings were done on node v0.12.2 on a single-core Google Compute Engine +instance. `quick` is just the 32-bit version of the RC4-based PRNG +originally packaged with seedrandom.) + + +Node.js usage +------------- + +``` +npm install seedrandom +``` + +```js +// Local PRNG: does not affect Math.random. +var seedrandom = require('seedrandom'); +var rng = seedrandom('hello.'); +console.log(rng()); // Always 0.9282578795792454 + +// Global PRNG: set Math.random. +seedrandom('hello.', { global: true }); +console.log(Math.random()); // Always 0.9282578795792454 + +// Autoseeded ARC4-based PRNG. +rng = seedrandom(); +console.log(rng()); // Reasonably unpredictable. + +// Mixing accumulated entropy. +rng = seedrandom('added entropy.', { entropy: true }); +console.log(rng()); // As unpredictable as added entropy. + +// Using alternate algorithms, as listed above. +var rng2 = seedrandom.xor4096('hello.') +console.log(rng2()); +``` + + +Require.js usage +---------------- + +Similar to Node.js usage: + +``` +bower install seedrandom +``` + +``` +require(['seedrandom'], function(seedrandom) { + var rng = seedrandom('hello.'); + console.log(rng()); // Always 0.9282578795792454 +}); +``` + + +Network seeding +--------------- + +```html + + + + + + +``` + +Reseeding using user input +-------------------------- + +```js +var seed = Math.seedrandom(); // Use prng with an automatic seed. +document.write(Math.random()); // Pretty much unpredictable x. + +var rng = new Math.seedrandom(seed); // A new prng with the same seed. +document.write(rng()); // Repeat the 'unpredictable' x. + +function reseed(event, count) { // Define a custom entropy collector. + var t = []; + function w(e) { + t.push([e.pageX, e.pageY, +new Date]); + if (t.length < count) { return; } + document.removeEventListener(event, w); + Math.seedrandom(t, { entropy: true }); + } + document.addEventListener(event, w); +} +reseed('mousemove', 100); // Reseed after 100 mouse moves. +``` + +The "pass" option can be used to get both the prng and the seed. +The following returns both an autoseeded prng and the seed as an object, +without mutating Math.random: + +```js +var obj = Math.seedrandom(null, { pass: function(prng, seed) { + return { random: prng, seed: seed }; +}}); +``` + + +Saving and Restoring PRNG state +------------------------------- + +```js +var seedrandom = Math.seedrandom; +var saveable = seedrandom("secret-seed", {state: true}); +for (var j = 0; j < 1e5; ++j) saveable(); +var saved = saveable.state(); +var replica = seedrandom("", {state: saved}); +assert(replica() == saveable()); +``` + +In normal use the prng is opaque and its internal state cannot be accessed. +However, if the "state" option is specified, the prng gets a state() method +that returns a plain object the can be used to reconstruct a prng later in +the same state (by passing that saved object back as the state option). + + +Version notes +------------- + +The random number sequence is the same as version 1.0 for string seeds. + +* Version 2.0 changed the sequence for non-string seeds. +* Version 2.1 speeds seeding and uses window.crypto to autoseed if present. +* Version 2.2 alters non-crypto autoseeding to sweep up entropy from plugins. +* Version 2.3 adds support for "new", module loading, and a null seed arg. +* Version 2.3.1 adds a build environment, module packaging, and tests. +* Version 2.3.4 fixes bugs on IE8, and switches to MIT license. +* Version 2.3.6 adds a readable options object argument. +* Version 2.3.10 adds support for node.js crypto (contributed by ctd1500). +* Version 2.3.11 adds an option to load and save internal state. +* Version 2.4.0 adds implementations of several other fast PRNGs. +* Version 2.4.2 adds an implementation of Baagoe's very fast Alea PRNG. +* Version 2.4.3 ignores nodejs crypto when under browserify. + +The standard ARC4 key scheduler cycles short keys, which means that +seedrandom('ab') is equivalent to seedrandom('abab') and 'ababab'. +Therefore it is a good idea to add a terminator to avoid trivial +equivalences on short string seeds, e.g., Math.seedrandom(str + '\0'). +Starting with version 2.0, a terminator is added automatically for +non-string seeds, so seeding with the number 111 is the same as seeding +with '111\0'. + +When seedrandom() is called with zero args or a null seed, it uses a +seed drawn from the browser crypto object if present. If there is no +crypto support, seedrandom() uses the current time, the native rng, +and a walk of several DOM objects to collect a few bits of entropy. + +Each time the one- or two-argument forms of seedrandom are called, +entropy from the passed seed is accumulated in a pool to help generate +future seeds for the zero- and two-argument forms of seedrandom. + +On speed - This javascript implementation of Math.random() is several +times slower than the built-in Math.random() because it is not native +code, but that is typically fast enough. Some details (timings on +Chrome 25 on a 2010 vintage macbook): + +* seeded Math.random() - avg less than 0.0002 milliseconds per call +* seedrandom('explicit.') - avg less than 0.2 milliseconds per call +* seedrandom('explicit.', true) - avg less than 0.2 milliseconds per call +* seedrandom() with crypto - avg less than 0.2 milliseconds per call + +Autoseeding without crypto is somewhat slow, about 20-30 milliseconds on +a 2012 windows 7 1.5ghz i5 laptop, as seen on Firefox 19, IE 10, and Opera. +Seeded rng calls themselves are fast across these browsers, with slowest +numbers on Opera at about 0.0005 ms per seeded Math.random(). + + +LICENSE (MIT) +------------- + +Copyright 2015 David Bau. + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/seedrandom/bower.json b/node_modules/seedrandom/bower.json new file mode 100644 index 0000000..8e62b3a --- /dev/null +++ b/node_modules/seedrandom/bower.json @@ -0,0 +1,16 @@ +{ + "name": "seedrandom", + "description": "Seeded random number generator for Javascript.", + "main": "seedrandom.js", + "license": "MIT", + "keywords": [ + "random", + "seed", + "crypto" + ], + "ignore": [], + "devDependencies": { + "qunit": "latest", + "requirejs": "latest" + } +} diff --git a/node_modules/seedrandom/component.json b/node_modules/seedrandom/component.json new file mode 100644 index 0000000..fe1aa60 --- /dev/null +++ b/node_modules/seedrandom/component.json @@ -0,0 +1,10 @@ +{ + "name": "seedrandom", + "version": "2.4.0", + "description": "Seeded random number generator for Javascript", + "repository": "davidbau/seedrandom", + "main": "seedrandom.js", + "scripts": [ "seedrandom.js" ], + "keywords": [ "random", "seed", "crypto" ], + "license": "MIT" +} diff --git a/node_modules/seedrandom/index.js b/node_modules/seedrandom/index.js new file mode 100644 index 0000000..513669a --- /dev/null +++ b/node_modules/seedrandom/index.js @@ -0,0 +1,60 @@ +// A library of seedable RNGs implemented in Javascript. +// +// Usage: +// +// var seedrandom = require('seedrandom'); +// var random = seedrandom(1); // or any seed. +// var x = random(); // 0 <= x < 1. Every bit is random. +// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness. + +// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe. +// Period: ~2^116 +// Reported to pass all BigCrush tests. +var alea = require('./lib/alea'); + +// xor128, a pure xor-shift generator by George Marsaglia. +// Period: 2^128-1. +// Reported to fail: MatrixRank and LinearComp. +var xor128 = require('./lib/xor128'); + +// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl. +// Period: 2^192-2^32 +// Reported to fail: CollisionOver, SimpPoker, and LinearComp. +var xorwow = require('./lib/xorwow'); + +// xorshift7, by François Panneton and Pierre L'ecuyer, takes +// a different approach: it adds robustness by allowing more shifts +// than Marsaglia's original three. It is a 7-shift generator +// with 256 bits, that passes BigCrush with no systmatic failures. +// Period 2^256-1. +// No systematic BigCrush failures reported. +var xorshift7 = require('./lib/xorshift7'); + +// xor4096, by Richard Brent, is a 4096-bit xor-shift with a +// very long period that also adds a Weyl generator. It also passes +// BigCrush with no systematic failures. Its long period may +// be useful if you have many generators and need to avoid +// collisions. +// Period: 2^4128-2^32. +// No systematic BigCrush failures reported. +var xor4096 = require('./lib/xor4096'); + +// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random +// number generator derived from ChaCha, a modern stream cipher. +// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf +// Period: ~2^127 +// No systematic BigCrush failures reported. +var tychei = require('./lib/tychei'); + +// The original ARC4-based prng included in this library. +// Period: ~2^1600 +var sr = require('./seedrandom'); + +sr.alea = alea; +sr.xor128 = xor128; +sr.xorwow = xorwow; +sr.xorshift7 = xorshift7; +sr.xor4096 = xor4096; +sr.tychei = tychei; + +module.exports = sr; diff --git a/node_modules/seedrandom/lib/alea.js b/node_modules/seedrandom/lib/alea.js new file mode 100644 index 0000000..f912ffd --- /dev/null +++ b/node_modules/seedrandom/lib/alea.js @@ -0,0 +1,114 @@ +// A port of an algorithm by Johannes Baagøe , 2010 +// http://baagoe.com/en/RandomMusings/javascript/ +// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror +// Original work is under MIT license - + +// Copyright (C) 2010 by Johannes Baagøe +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +// THE SOFTWARE. + + + +(function(global, module, define) { + +function Alea(seed) { + var me = this, mash = Mash(); + + me.next = function() { + var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32 + me.s0 = me.s1; + me.s1 = me.s2; + return me.s2 = t - (me.c = t | 0); + }; + + // Apply the seeding algorithm from Baagoe. + me.c = 1; + me.s0 = mash(' '); + me.s1 = mash(' '); + me.s2 = mash(' '); + me.s0 -= mash(seed); + if (me.s0 < 0) { me.s0 += 1; } + me.s1 -= mash(seed); + if (me.s1 < 0) { me.s1 += 1; } + me.s2 -= mash(seed); + if (me.s2 < 0) { me.s2 += 1; } + mash = null; +} + +function copy(f, t) { + t.c = f.c; + t.s0 = f.s0; + t.s1 = f.s1; + t.s2 = f.s2; + return t; +} + +function impl(seed, opts) { + var xg = new Alea(seed), + state = opts && opts.state, + prng = xg.next; + prng.int32 = function() { return (xg.next() * 0x100000000) | 0; } + prng.double = function() { + return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53 + }; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +function Mash() { + var n = 0xefc8249d; + + var mash = function(data) { + data = data.toString(); + for (var i = 0; i < data.length; i++) { + n += data.charCodeAt(i); + var h = 0.02519603282416938 * n; + n = h >>> 0; + h -= n; + h *= n; + n = h >>> 0; + h -= n; + n += h * 0x100000000; // 2^32 + } + return (n >>> 0) * 2.3283064365386963e-10; // 2^-32 + }; + + return mash; +} + + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.alea = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/node_modules/seedrandom/lib/alea.min.js b/node_modules/seedrandom/lib/alea.min.js new file mode 100644 index 0000000..51b0219 --- /dev/null +++ b/node_modules/seedrandom/lib/alea.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){var b=this,c=g();b.next=function(){var a=2091639*b.s0+2.3283064365386963e-10*b.c;return b.s0=b.s1,b.s1=b.s2,b.s2=a-(b.c=0|a)},b.c=1,b.s0=c(" "),b.s1=c(" "),b.s2=c(" "),b.s0-=c(a),b.s0<0&&(b.s0+=1),b.s1-=c(a),b.s1<0&&(b.s1+=1),b.s2-=c(a),b.s2<0&&(b.s2+=1),c=null}function e(a,b){return b.c=a.c,b.s0=a.s0,b.s1=a.s1,b.s2=a.s2,b}function f(a,b){var c=new d(a),f=b&&b.state,g=c.next;return g.int32=function(){return 4294967296*c.next()|0},g.double=function(){return g()+1.1102230246251565e-16*(2097152*g()|0)},g.quick=g,f&&("object"==typeof f&&e(f,c),g.state=function(){return e(c,{})}),g}function g(){var a=4022871197,b=function(b){b=b.toString();for(var c=0;c>>0,d-=a,d*=a,a=d>>>0,d-=a,a+=4294967296*d}return 2.3283064365386963e-10*(a>>>0)};return b}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.alea=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/lib/crypto.js b/node_modules/seedrandom/lib/crypto.js new file mode 100644 index 0000000..18ee91f --- /dev/null +++ b/node_modules/seedrandom/lib/crypto.js @@ -0,0 +1,11 @@ +// mimic a subset of node's crypto API for the browser + +function randomBytes(width) { + var out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + return out; +} + +module.exports = { + randomBytes: randomBytes +} diff --git a/node_modules/seedrandom/lib/tychei.js b/node_modules/seedrandom/lib/tychei.js new file mode 100644 index 0000000..3d0ddd4 --- /dev/null +++ b/node_modules/seedrandom/lib/tychei.js @@ -0,0 +1,103 @@ +// A Javascript implementaion of the "Tyche-i" prng algorithm by +// Samuel Neves and Filipe Araujo. +// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var b = me.b, c = me.c, d = me.d, a = me.a; + b = (b << 25) ^ (b >>> 7) ^ c; + c = (c - d) | 0; + d = (d << 24) ^ (d >>> 8) ^ a; + a = (a - b) | 0; + me.b = b = (b << 20) ^ (b >>> 12) ^ c; + me.c = c = (c - d) | 0; + me.d = (d << 16) ^ (c >>> 16) ^ a; + return me.a = (a - b) | 0; + }; + + /* The following is non-inverted tyche, which has better internal + * bit diffusion, but which is about 25% slower than tyche-i in JS. + me.next = function() { + var a = me.a, b = me.b, c = me.c, d = me.d; + a = (me.a + me.b | 0) >>> 0; + d = me.d ^ a; d = d << 16 ^ d >>> 16; + c = me.c + d | 0; + b = me.b ^ c; b = b << 12 ^ d >>> 20; + me.a = a = a + b | 0; + d = d ^ a; me.d = d = d << 8 ^ d >>> 24; + me.c = c = c + d | 0; + b = b ^ c; + return me.b = (b << 7 ^ b >>> 25); + } + */ + + me.a = 0; + me.b = 0; + me.c = 2654435769 | 0; + me.d = 1367130551; + + if (seed === Math.floor(seed)) { + // Integer seed. + me.a = (seed / 0x100000000) | 0; + me.b = seed | 0; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 20; k++) { + me.b ^= strseed.charCodeAt(k) | 0; + me.next(); + } +} + +function copy(f, t) { + t.a = f.a; + t.b = f.b; + t.c = f.c; + t.d = f.d; + return t; +}; + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.tychei = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/node_modules/seedrandom/lib/tychei.min.js b/node_modules/seedrandom/lib/tychei.min.js new file mode 100644 index 0000000..12849dc --- /dev/null +++ b/node_modules/seedrandom/lib/tychei.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){var b=this,c="";b.next=function(){var a=b.b,c=b.c,d=b.d,e=b.a;return a=a<<25^a>>>7^c,c=c-d|0,d=d<<24^d>>>8^e,e=e-a|0,b.b=a=a<<20^a>>>12^c,b.c=c=c-d|0,b.d=d<<16^c>>>16^e,b.a=e-a|0},b.a=0,b.b=0,b.c=-1640531527,b.d=1367130551,a===Math.floor(a)?(b.a=a/4294967296|0,b.b=0|a):c+=a;for(var d=0;d>>0)/4294967296};return g.double=function(){do var a=c.next()>>>11,b=(c.next()>>>0)/4294967296,d=(a+b)/(1<<21);while(0===d);return d},g.int32=c.next,g.quick=g,f&&("object"==typeof f&&e(f,c),g.state=function(){return e(c,{})}),g}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.tychei=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/lib/xor128.js b/node_modules/seedrandom/lib/xor128.js new file mode 100644 index 0000000..c461934 --- /dev/null +++ b/node_modules/seedrandom/lib/xor128.js @@ -0,0 +1,81 @@ +// A Javascript implementaion of the "xor128" prng algorithm by +// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + + // Set up generator function. + me.next = function() { + var t = me.x ^ (me.x << 11); + me.x = me.y; + me.y = me.z; + me.z = me.w; + return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8); + }; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + me.next(); + } +} + +function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + return t; +} + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xor128 = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/node_modules/seedrandom/lib/xor128.min.js b/node_modules/seedrandom/lib/xor128.min.js new file mode 100644 index 0000000..dbd1cba --- /dev/null +++ b/node_modules/seedrandom/lib/xor128.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){var b=this,c="";b.x=0,b.y=0,b.z=0,b.w=0,b.next=function(){var a=b.x^b.x<<11;return b.x=b.y,b.y=b.z,b.z=b.w,b.w^=b.w>>>19^a^a>>>8},a===(0|a)?b.x=a:c+=a;for(var d=0;d>>0)/4294967296};return g.double=function(){do var a=c.next()>>>11,b=(c.next()>>>0)/4294967296,d=(a+b)/(1<<21);while(0===d);return d},g.int32=c.next,g.quick=g,f&&("object"==typeof f&&e(f,c),g.state=function(){return e(c,{})}),g}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.xor128=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/lib/xor4096.js b/node_modules/seedrandom/lib/xor4096.js new file mode 100644 index 0000000..6adf19f --- /dev/null +++ b/node_modules/seedrandom/lib/xor4096.js @@ -0,0 +1,146 @@ +// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm. +// +// This fast non-cryptographic random number generator is designed for +// use in Monte-Carlo algorithms. It combines a long-period xorshift +// generator with a Weyl generator, and it passes all common batteries +// of stasticial tests for randomness while consuming only a few nanoseconds +// for each prng generated. For background on the generator, see Brent's +// paper: "Some long-period random number generators using shifts and xors." +// http://arxiv.org/pdf/1004.3115v1.pdf +// +// Usage: +// +// var xor4096 = require('xor4096'); +// random = xor4096(1); // Seed with int32 or string. +// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits. +// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits. +// +// For nonzero numeric keys, this impelementation provides a sequence +// identical to that by Brent's xorgens 3 implementaion in C. This +// implementation also provides for initalizing the generator with +// string seeds, or for saving and restoring the state of the generator. +// +// On Chrome, this prng benchmarks about 2.1 times slower than +// Javascript's built-in Math.random(). + +(function(global, module, define) { + +function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + var w = me.w, + X = me.X, i = me.i, t, v; + // Update Weyl generator. + me.w = w = (w + 0x61c88647) | 0; + // Update xor generator. + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + // Update Xor generator array state. + v = X[i] = v ^ t; + me.i = i; + // Result is the combination. + return (v + (w ^ (w >>> 16))) | 0; + }; + + function init(me, seed) { + var t, v, i, j, w, X = [], limit = 128; + if (seed === (seed | 0)) { + // Numeric seeds initialize v, which is used to generates X. + v = seed; + seed = null; + } else { + // String seeds are mixed into v and X one character at a time. + seed = seed + '\0'; + v = 0; + limit = Math.max(limit, seed.length); + } + // Initialize circular array and weyl value. + for (i = 0, j = -32; j < limit; ++j) { + // Put the unicode characters into the array, and shuffle them. + if (seed) v ^= seed.charCodeAt((j + 32) % seed.length); + // After 32 shuffles, take v as the starting w value. + if (j === 0) w = v; + v ^= v << 10; + v ^= v >>> 15; + v ^= v << 4; + v ^= v >>> 13; + if (j >= 0) { + w = (w + 0x61c88647) | 0; // Weyl. + t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array. + i = (0 == t) ? i + 1 : 0; // Count zeroes. + } + } + // We have detected all zeroes; make the key nonzero. + if (i >= 128) { + X[(seed && seed.length || 0) & 127] = -1; + } + // Run the generator 512 times to further mix the state before using it. + // Factoring this as a function slows the main generator, so it is just + // unrolled here. The weyl generator is not advanced while warming up. + i = 127; + for (j = 4 * 128; j > 0; --j) { + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + X[i] = v ^ t; + } + // Storing state as object members is faster than using closure variables. + me.w = w; + me.X = X; + me.i = i; + } + + init(me, seed); +} + +function copy(f, t) { + t.i = f.i; + t.w = f.w; + t.X = f.X.slice(); + return t; +}; + +function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.X) copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xor4096 = impl; +} + +})( + this, // window object or global + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); diff --git a/node_modules/seedrandom/lib/xor4096.min.js b/node_modules/seedrandom/lib/xor4096.min.js new file mode 100644 index 0000000..a7d37c5 --- /dev/null +++ b/node_modules/seedrandom/lib/xor4096.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){function b(a,b){var c,d,e,f,g,h=[],i=128;for(b===(0|b)?(d=b,b=null):(b+="\0",d=0,i=Math.max(i,b.length)),e=0,f=-32;f>>15,d^=d<<4,d^=d>>>13,f>=0&&(g=g+1640531527|0,c=h[127&f]^=d+g,e=0==c?e+1:0);for(e>=128&&(h[127&(b&&b.length||0)]=-1),e=127,f=512;f>0;--f)d=h[e+34&127],c=h[e=e+1&127],d^=d<<13,c^=c<<17,d^=d>>>15,c^=c>>>12,h[e]=d^c;a.w=g,a.X=h,a.i=e}var c=this;c.next=function(){var a,b,d=c.w,e=c.X,f=c.i;return c.w=d=d+1640531527|0,b=e[f+34&127],a=e[f=f+1&127],b^=b<<13,a^=a<<17,b^=b>>>15,a^=a>>>12,b=e[f]=b^a,c.i=f,b+(d^d>>>16)|0},b(c,a)}function e(a,b){return b.i=a.i,b.w=a.w,b.X=a.X.slice(),b}function f(a,b){null==a&&(a=+new Date);var c=new d(a),f=b&&b.state,g=function(){return(c.next()>>>0)/4294967296};return g.double=function(){do var a=c.next()>>>11,b=(c.next()>>>0)/4294967296,d=(a+b)/(1<<21);while(0===d);return d},g.int32=c.next,g.quick=g,f&&(f.X&&e(f,c),g.state=function(){return e(c,{})}),g}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.xor4096=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/lib/xorshift7.js b/node_modules/seedrandom/lib/xorshift7.js new file mode 100644 index 0000000..b7e5151 --- /dev/null +++ b/node_modules/seedrandom/lib/xorshift7.js @@ -0,0 +1,97 @@ +// A Javascript implementaion of the "xorshift7" algorithm by +// François Panneton and Pierre L'ecuyer: +// "On the Xorgshift Random Number Generators" +// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf + +(function(global, module, define) { + +function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + // Update xor generator. + var X = me.x, i = me.i, t, v, w; + t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24); + t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10); + t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3); + t = X[(i + 4) & 7]; v ^= t ^ (t << 7); + t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9); + X[i] = v; + me.i = (i + 1) & 7; + return v; + }; + + function init(me, seed) { + var j, w, X = []; + + if (seed === (seed | 0)) { + // Seed state array using a 32-bit integer. + w = X[0] = seed; + } else { + // Seed state using a string. + seed = '' + seed; + for (j = 0; j < seed.length; ++j) { + X[j & 7] = (X[j & 7] << 15) ^ + (seed.charCodeAt(j) + X[(j + 1) & 7] << 13); + } + } + // Enforce an array length of 8, not all zeroes. + while (X.length < 8) X.push(0); + for (j = 0; j < 8 && X[j] === 0; ++j); + if (j == 8) w = X[7] = -1; else w = X[j]; + + me.x = X; + me.i = 0; + + // Discard an initial 256 values. + for (j = 256; j > 0; --j) { + me.next(); + } + } + + init(me, seed); +} + +function copy(f, t) { + t.x = f.x.slice(); + t.i = f.i; + return t; +} + +function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.x) copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xorshift7 = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + diff --git a/node_modules/seedrandom/lib/xorshift7.min.js b/node_modules/seedrandom/lib/xorshift7.min.js new file mode 100644 index 0000000..cf534d4 --- /dev/null +++ b/node_modules/seedrandom/lib/xorshift7.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){function b(a,b){var c,d,e=[];if(b===(0|b))d=e[0]=b;else for(b=""+b,c=0;c0;--c)a.next()}var c=this;c.next=function(){var a,b,d=c.x,e=c.i;return a=d[e],a^=a>>>7,b=a^a<<24,a=d[e+1&7],b^=a^a>>>10,a=d[e+3&7],b^=a^a>>>3,a=d[e+4&7],b^=a^a<<7,a=d[e+7&7],a^=a<<13,b^=a^a<<9,d[e]=b,c.i=e+1&7,b},b(c,a)}function e(a,b){return b.x=a.x.slice(),b.i=a.i,b}function f(a,b){null==a&&(a=+new Date);var c=new d(a),f=b&&b.state,g=function(){return(c.next()>>>0)/4294967296};return g.double=function(){do var a=c.next()>>>11,b=(c.next()>>>0)/4294967296,d=(a+b)/(1<<21);while(0===d);return d},g.int32=c.next,g.quick=g,f&&(f.x&&e(f,c),g.state=function(){return e(c,{})}),g}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.xorshift7=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/lib/xorwow.js b/node_modules/seedrandom/lib/xorwow.js new file mode 100644 index 0000000..79d5e44 --- /dev/null +++ b/node_modules/seedrandom/lib/xorwow.js @@ -0,0 +1,86 @@ +// A Javascript implementaion of the "xorwow" prng algorithm by +// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var t = (me.x ^ (me.x >>> 2)); + me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v; + return (me.d = (me.d + 362437 | 0)) + + (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0; + }; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + me.v = 0; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + if (k == strseed.length) { + me.d = me.x << 10 ^ me.x >>> 4; + } + me.next(); + } +} + +function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + t.v = f.v; + t.d = f.d; + return t; +} + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xorwow = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/node_modules/seedrandom/lib/xorwow.min.js b/node_modules/seedrandom/lib/xorwow.min.js new file mode 100644 index 0000000..877a481 --- /dev/null +++ b/node_modules/seedrandom/lib/xorwow.min.js @@ -0,0 +1 @@ +!function(a,b,c){function d(a){var b=this,c="";b.next=function(){var a=b.x^b.x>>>2;return b.x=b.y,b.y=b.z,b.z=b.w,b.w=b.v,(b.d=b.d+362437|0)+(b.v=b.v^b.v<<4^(a^a<<1))|0},b.x=0,b.y=0,b.z=0,b.w=0,b.v=0,a===(0|a)?b.x=a:c+=a;for(var d=0;d>>4),b.next()}function e(a,b){return b.x=a.x,b.y=a.y,b.z=a.z,b.w=a.w,b.v=a.v,b.d=a.d,b}function f(a,b){var c=new d(a),f=b&&b.state,g=function(){return(c.next()>>>0)/4294967296};return g.double=function(){do var a=c.next()>>>11,b=(c.next()>>>0)/4294967296,d=(a+b)/(1<<21);while(0===d);return d},g.int32=c.next,g.quick=g,f&&("object"==typeof f&&e(f,c),g.state=function(){return e(c,{})}),g}b&&b.exports?b.exports=f:c&&c.amd?c(function(){return f}):this.xorwow=f}(this,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/node_modules/seedrandom/package.json b/node_modules/seedrandom/package.json new file mode 100644 index 0000000..75dae3e --- /dev/null +++ b/node_modules/seedrandom/package.json @@ -0,0 +1,82 @@ +{ + "_from": "seedrandom@~2.4.3", + "_id": "seedrandom@2.4.3", + "_inBundle": false, + "_integrity": "sha1-JDhQTa0zkXMUv/GKxNeU8W1qrsw=", + "_location": "/seedrandom", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "seedrandom@~2.4.3", + "name": "seedrandom", + "escapedName": "seedrandom", + "rawSpec": "~2.4.3", + "saveSpec": null, + "fetchSpec": "~2.4.3" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-core" + ], + "_resolved": "https://registry.npmjs.org/seedrandom/-/seedrandom-2.4.3.tgz", + "_shasum": "2438504dad33917314bff18ac4d794f16d6aaecc", + "_spec": "seedrandom@~2.4.3", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-core", + "author": { + "name": "David Bau" + }, + "browser": { + "crypto": false + }, + "bugs": { + "url": "https://github.com/davidbau/seedrandom/issues" + }, + "bundleDependencies": false, + "config": { + "blanket": { + "pattern": [ + "seedrandom.js", + "lib/alea.js", + "lib/xor128.js", + "lib/xorwow.js", + "lib/xorshift7.js", + "lib/tychei.js", + "lib/xor4096.js" + ] + } + }, + "deprecated": false, + "description": "Seeded random number generator for Javascript.", + "devDependencies": { + "blanket": "latest", + "grunt": "latest", + "grunt-bowercopy": "latest", + "grunt-browserify": "latest", + "grunt-cli": "latest", + "grunt-contrib-connect": "latest", + "grunt-contrib-qunit": "latest", + "grunt-contrib-uglify": "latest", + "grunt-mocha-cov": "latest", + "grunt-release": "latest", + "phantomjs-prebuilt": "latest", + "proxyquire": "latest", + "requirejs": "latest" + }, + "homepage": "http://davidbau.com/archives/2010/01/30/random_seeds_coded_hints_and_quintillions.html", + "keywords": [ + "seed", + "random", + "crypto" + ], + "license": "MIT", + "main": "index.js", + "name": "seedrandom", + "repository": { + "type": "git", + "url": "git://github.com/davidbau/seedrandom.git" + }, + "scripts": { + "test": "grunt travis" + }, + "version": "2.4.3" +} diff --git a/node_modules/seedrandom/seedrandom.js b/node_modules/seedrandom/seedrandom.js new file mode 100644 index 0000000..83ea6e8 --- /dev/null +++ b/node_modules/seedrandom/seedrandom.js @@ -0,0 +1,247 @@ +/* +Copyright 2014 David Bau. + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +*/ + +(function (pool, math) { +// +// The following constants are related to IEEE 754 limits. +// +var global = this, + width = 256, // each RC4 output is 0 <= x < 256 + chunks = 6, // at least six RC4 outputs for each double + digits = 52, // there are 52 significant digits in a double + rngname = 'random', // rngname: name for Math.random and Math.seedrandom + startdenom = math.pow(width, chunks), + significance = math.pow(2, digits), + overflow = significance * 2, + mask = width - 1, + nodecrypto; // node.js crypto module, initialized at the bottom. + +// +// seedrandom() +// This is the seedrandom function described above. +// +function seedrandom(seed, options, callback) { + var key = []; + options = (options == true) ? { entropy: true } : (options || {}); + + // Flatten the seed string or build one from local entropy if needed. + var shortseed = mixkey(flatten( + options.entropy ? [seed, tostring(pool)] : + (seed == null) ? autoseed() : seed, 3), key); + + // Use the seed to initialize an ARC4 generator. + var arc4 = new ARC4(key); + + // This function returns a random double in [0, 1) that contains + // randomness in every bit of the mantissa of the IEEE 754 value. + var prng = function() { + var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48 + d = startdenom, // and denominator d = 2 ^ 48. + x = 0; // and no 'extra last byte'. + while (n < significance) { // Fill up all significant digits by + n = (n + x) * width; // shifting numerator and + d *= width; // denominator and generating a + x = arc4.g(1); // new least-significant-byte. + } + while (n >= overflow) { // To avoid rounding up, before adding + n /= 2; // last byte, shift everything + d /= 2; // right using integer math until + x >>>= 1; // we have exactly the desired bits. + } + return (n + x) / d; // Form the number within [0, 1). + }; + + prng.int32 = function() { return arc4.g(4) | 0; } + prng.quick = function() { return arc4.g(4) / 0x100000000; } + prng.double = prng; + + // Mix the randomness into accumulated entropy. + mixkey(tostring(arc4.S), pool); + + // Calling convention: what to return as a function of prng, seed, is_math. + return (options.pass || callback || + function(prng, seed, is_math_call, state) { + if (state) { + // Load the arc4 state from the given state if it has an S array. + if (state.S) { copy(state, arc4); } + // Only provide the .state method if requested via options.state. + prng.state = function() { return copy(arc4, {}); } + } + + // If called as a method of Math (Math.seedrandom()), mutate + // Math.random because that is how seedrandom.js has worked since v1.0. + if (is_math_call) { math[rngname] = prng; return seed; } + + // Otherwise, it is a newer calling convention, so return the + // prng directly. + else return prng; + })( + prng, + shortseed, + 'global' in options ? options.global : (this == math), + options.state); +} +math['seed' + rngname] = seedrandom; + +// +// ARC4 +// +// An ARC4 implementation. The constructor takes a key in the form of +// an array of at most (width) integers that should be 0 <= x < (width). +// +// The g(count) method returns a pseudorandom integer that concatenates +// the next (count) outputs from ARC4. Its return value is a number x +// that is in the range 0 <= x < (width ^ count). +// +function ARC4(key) { + var t, keylen = key.length, + me = this, i = 0, j = me.i = me.j = 0, s = me.S = []; + + // The empty key [] is treated as [0]. + if (!keylen) { key = [keylen++]; } + + // Set up S using the standard key scheduling algorithm. + while (i < width) { + s[i] = i++; + } + for (i = 0; i < width; i++) { + s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))]; + s[j] = t; + } + + // The "g" method returns the next (count) outputs as one number. + (me.g = function(count) { + // Using instance members instead of closure state nearly doubles speed. + var t, r = 0, + i = me.i, j = me.j, s = me.S; + while (count--) { + t = s[i = mask & (i + 1)]; + r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))]; + } + me.i = i; me.j = j; + return r; + // For robust unpredictability, the function call below automatically + // discards an initial batch of values. This is called RC4-drop[256]. + // See http://google.com/search?q=rsa+fluhrer+response&btnI + })(width); +} + +// +// copy() +// Copies internal state of ARC4 to or from a plain object. +// +function copy(f, t) { + t.i = f.i; + t.j = f.j; + t.S = f.S.slice(); + return t; +}; + +// +// flatten() +// Converts an object tree to nested arrays of strings. +// +function flatten(obj, depth) { + var result = [], typ = (typeof obj), prop; + if (depth && typ == 'object') { + for (prop in obj) { + try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {} + } + } + return (result.length ? result : typ == 'string' ? obj : obj + '\0'); +} + +// +// mixkey() +// Mixes a string seed into a key that is an array of integers, and +// returns a shortened string seed that is equivalent to the result key. +// +function mixkey(seed, key) { + var stringseed = seed + '', smear, j = 0; + while (j < stringseed.length) { + key[mask & j] = + mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++)); + } + return tostring(key); +} + +// +// autoseed() +// Returns an object for autoseeding, using window.crypto and Node crypto +// module if available. +// +function autoseed() { + try { + var out; + if (nodecrypto && (out = nodecrypto.randomBytes)) { + // The use of 'out' to remember randomBytes makes tight minified code. + out = out(width); + } else { + out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + } + return tostring(out); + } catch (e) { + var browser = global.navigator, + plugins = browser && browser.plugins; + return [+new Date, global, plugins, global.screen, tostring(pool)]; + } +} + +// +// tostring() +// Converts an array of charcodes to a string +// +function tostring(a) { + return String.fromCharCode.apply(0, a); +} + +// +// When seedrandom.js is loaded, we immediately mix a few bits +// from the built-in RNG into the entropy pool. Because we do +// not want to interfere with deterministic PRNG state later, +// seedrandom will not call math.random on its own again after +// initialization. +// +mixkey(math.random(), pool); + +// +// Nodejs and AMD support: export the implementation as a module using +// either convention. +// +if ((typeof module) == 'object' && module.exports) { + module.exports = seedrandom; + // When in node.js, try using crypto package for autoseeding. + try { + nodecrypto = require('crypto'); + } catch (ex) {} +} else if ((typeof define) == 'function' && define.amd) { + define(function() { return seedrandom; }); +} + +// End anonymous scope, and pass initial values. +})( + [], // pool: entropy pool starts empty + Math // math: package containing random, pow, and seedrandom +); diff --git a/node_modules/seedrandom/seedrandom.min.js b/node_modules/seedrandom/seedrandom.min.js new file mode 100644 index 0000000..401b4bf --- /dev/null +++ b/node_modules/seedrandom/seedrandom.min.js @@ -0,0 +1 @@ +!function(a,b){function c(c,j,k){var n=[];j=1==j?{entropy:!0}:j||{};var s=g(f(j.entropy?[c,i(a)]:null==c?h():c,3),n),t=new d(n),u=function(){for(var a=t.g(m),b=p,c=0;a=r;)a/=2,b/=2,c>>>=1;return(a+c)/b};return u.int32=function(){return 0|t.g(4)},u.quick=function(){return t.g(4)/4294967296},u.double=u,g(i(t.S),a),(j.pass||k||function(a,c,d,f){return f&&(f.S&&e(f,t),a.state=function(){return e(t,{})}),d?(b[o]=a,c):a})(u,s,"global"in j?j.global:this==b,j.state)}function d(a){var b,c=a.length,d=this,e=0,f=d.i=d.j=0,g=d.S=[];for(c||(a=[c++]);e + + + + +
+
+ + + + + + diff --git a/node_modules/seedrandom/test/autoseed.html b/node_modules/seedrandom/test/autoseed.html new file mode 100644 index 0000000..2738f24 --- /dev/null +++ b/node_modules/seedrandom/test/autoseed.html @@ -0,0 +1,46 @@ + + + + + +
+
+ + + + + diff --git a/node_modules/seedrandom/test/bitgen.js b/node_modules/seedrandom/test/bitgen.js new file mode 100644 index 0000000..c3563d5 --- /dev/null +++ b/node_modules/seedrandom/test/bitgen.js @@ -0,0 +1,45 @@ +#!/usr/bin/env node +var seedrandom = require('../seedrandom'); + +// process.on('SIGPIPE', process.exit); +function epipeBomb(stream, callback) { + if (stream == null) stream = process.stdout; + if (callback == null) callback = process.exit; + + function epipeFilter(err) { + if (err.code === 'EPIPE') return callback(); + + // If there's more than one error handler (ie, us), + // then the error won't be bubbled up anyway + if (stream.listeners('error').length <= 1) { + stream.removeAllListeners(); // Pretend we were never here + stream.emit('error', err); // Then emit as if we were never here + stream.on('error', epipeFilter);// Reattach, ready for the next error! + } + } + + stream.on('error', epipeFilter); +} + +epipeBomb(); + +var bufsize = 1024 * 256, + buf = new Buffer(bufsize * 4), + prng = seedrandom(0), + count = parseInt(process.argv[2]) || Infinity; +function dowrite() { + while (count > 0) { + for (var j = 0; j < bufsize; ++j) { + buf.writeUInt32BE(Math.floor( + prng() * 256 * 256 * 256 * 256 + ), j * 4); + } + count -= bufsize * 32; + if (!process.stdout.write(buf)) { + process.stdout.once('drain', function() { setTimeout(dowrite, 0) }); + return; + } + } +} + +dowrite(); diff --git a/node_modules/seedrandom/test/browserified.html b/node_modules/seedrandom/test/browserified.html new file mode 100644 index 0000000..724654e --- /dev/null +++ b/node_modules/seedrandom/test/browserified.html @@ -0,0 +1,23 @@ + + + + + +
+
+ + + + + diff --git a/node_modules/seedrandom/test/browserified.js b/node_modules/seedrandom/test/browserified.js new file mode 100644 index 0000000..518be87 --- /dev/null +++ b/node_modules/seedrandom/test/browserified.js @@ -0,0 +1,489 @@ +require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o= overflow) { // To avoid rounding up, before adding + n /= 2; // last byte, shift everything + d /= 2; // right using integer math until + x >>>= 1; // we have exactly the desired bits. + } + return (n + x) / d; // Form the number within [0, 1). + }; + + prng.int32 = function() { return arc4.g(4) | 0; } + prng.quick = function() { return arc4.g(4) / 0x100000000; } + prng.double = prng; + + // Mix the randomness into accumulated entropy. + mixkey(tostring(arc4.S), pool); + + // Calling convention: what to return as a function of prng, seed, is_math. + return (options.pass || callback || + function(prng, seed, is_math_call, state) { + if (state) { + // Load the arc4 state from the given state if it has an S array. + if (state.S) { copy(state, arc4); } + // Only provide the .state method if requested via options.state. + prng.state = function() { return copy(arc4, {}); } + } + + // If called as a method of Math (Math.seedrandom()), mutate + // Math.random because that is how seedrandom.js has worked since v1.0. + if (is_math_call) { math[rngname] = prng; return seed; } + + // Otherwise, it is a newer calling convention, so return the + // prng directly. + else return prng; + })( + prng, + shortseed, + 'global' in options ? options.global : (this == math), + options.state); +} +math['seed' + rngname] = seedrandom; + +// +// ARC4 +// +// An ARC4 implementation. The constructor takes a key in the form of +// an array of at most (width) integers that should be 0 <= x < (width). +// +// The g(count) method returns a pseudorandom integer that concatenates +// the next (count) outputs from ARC4. Its return value is a number x +// that is in the range 0 <= x < (width ^ count). +// +function ARC4(key) { + var t, keylen = key.length, + me = this, i = 0, j = me.i = me.j = 0, s = me.S = []; + + // The empty key [] is treated as [0]. + if (!keylen) { key = [keylen++]; } + + // Set up S using the standard key scheduling algorithm. + while (i < width) { + s[i] = i++; + } + for (i = 0; i < width; i++) { + s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))]; + s[j] = t; + } + + // The "g" method returns the next (count) outputs as one number. + (me.g = function(count) { + // Using instance members instead of closure state nearly doubles speed. + var t, r = 0, + i = me.i, j = me.j, s = me.S; + while (count--) { + t = s[i = mask & (i + 1)]; + r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))]; + } + me.i = i; me.j = j; + return r; + // For robust unpredictability, the function call below automatically + // discards an initial batch of values. This is called RC4-drop[256]. + // See http://google.com/search?q=rsa+fluhrer+response&btnI + })(width); +} + +// +// copy() +// Copies internal state of ARC4 to or from a plain object. +// +function copy(f, t) { + t.i = f.i; + t.j = f.j; + t.S = f.S.slice(); + return t; +}; + +// +// flatten() +// Converts an object tree to nested arrays of strings. +// +function flatten(obj, depth) { + var result = [], typ = (typeof obj), prop; + if (depth && typ == 'object') { + for (prop in obj) { + try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {} + } + } + return (result.length ? result : typ == 'string' ? obj : obj + '\0'); +} + +// +// mixkey() +// Mixes a string seed into a key that is an array of integers, and +// returns a shortened string seed that is equivalent to the result key. +// +function mixkey(seed, key) { + var stringseed = seed + '', smear, j = 0; + while (j < stringseed.length) { + key[mask & j] = + mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++)); + } + return tostring(key); +} + +// +// autoseed() +// Returns an object for autoseeding, using window.crypto and Node crypto +// module if available. +// +function autoseed() { + try { + var out; + if (nodecrypto && (out = nodecrypto.randomBytes)) { + // The use of 'out' to remember randomBytes makes tight minified code. + out = out(width); + } else { + out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + } + return tostring(out); + } catch (e) { + var browser = global.navigator, + plugins = browser && browser.plugins; + return [+new Date, global, plugins, global.screen, tostring(pool)]; + } +} + +// +// tostring() +// Converts an array of charcodes to a string +// +function tostring(a) { + return String.fromCharCode.apply(0, a); +} + +// +// When seedrandom.js is loaded, we immediately mix a few bits +// from the built-in RNG into the entropy pool. Because we do +// not want to interfere with deterministic PRNG state later, +// seedrandom will not call math.random on its own again after +// initialization. +// +mixkey(math.random(), pool); + +// +// Nodejs and AMD support: export the implementation as a module using +// either convention. +// +if ((typeof module) == 'object' && module.exports) { + module.exports = seedrandom; + // When in node.js, try using crypto package for autoseeding. + try { + nodecrypto = require('crypto'); + } catch (ex) {} +} else if ((typeof define) == 'function' && define.amd) { + define(function() { return seedrandom; }); +} + +// End anonymous scope, and pass initial values. +})( + [], // pool: entropy pool starts empty + Math // math: package containing random, pow, and seedrandom +); + +},{"crypto":1}],4:[function(require,module,exports){ +(function (__dirname){ +var assert = require("assert"); +var seedrandom = require("../seedrandom"); +var requirejs = require("requirejs"); + +// Stub out requirejs if in the browser via browserify. +if (!requirejs.config) { + requirejs = require; +} else { + requirejs.config({ + baseUrl: __dirname + }); +} + +describe("Nodejs API Test", function() { + +it('should pass basic tests.', function() { + var original = Math.random, + result, r, xprng, obj, as2, as3, autoseed1, myrng, + firstprng, secondprng, thirdprng, rng; + + result = Math.seedrandom('hello.'); + firstprng = Math.random; + assert.ok(original !== firstprng, "Should change Math.random."); + assert.equal(result, "hello.", "Should return short seed."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + r = Math.random(); + assert.equal(r, 0.3752569768646784, "Should be 'hello.'#2"); + + // should be able to autoseed + result = Math.seedrandom(); + secondprng = Math.random; + assert.ok(original !== secondprng, "Should change Math.random."); + assert.ok(firstprng !== secondprng, "Should change Math.random."); + assert.equal(result.length, 256, "Should return short seed."); + r = Math.random(); + assert.ok(r > 0, "Should be posititive."); + assert.ok(r < 1, "Should be less than 1."); + assert.ok(r != 0.9282578795792454, "Should not be 'hello.'#1"); + assert.ok(r != 0.3752569768646784, "Should not be 'hello.'#2"); + assert.ok(r != 0.7316977468919549, "Should not be 'hello.'#3"); + autoseed1 = r; + + // should be able to add entropy. + result = Math.seedrandom('added entropy.', { entropy:true }); + assert.equal(result.length, 256, "Should return short seed."); + thirdprng = Math.random; + assert.ok(thirdprng !== secondprng, "Should change Math.random."); + r = Math.random(); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // Reset to original Math.random. + Math.random = original; + // should be able to use new Math.seedrandom('hello.') + myrng = new Math.seedrandom('hello.'); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== myrng, "PRNG should not be Math.random."); + r = myrng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // should be able to use seedrandom('hello.')" + rng = seedrandom('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); + + // Global PRNG: set Math.random. + // should be able to use seedrandom('hello.', { global: true }) + result = seedrandom('hello.', { global: true }); + assert.equal(result, 'hello.', "Should return short seed."); + assert.ok(original != Math.random, "Should change Math.random."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // Autoseeded non-global + Math.random = original; + // should be able to use seedrandom() + result = seedrandom(); + assert.equal(typeof(result), 'function', "Should return function."); + assert.ok(original === Math.random, "Should not change Math.random."); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.9282578795792454, "Should not be 'hello.'#1"); + assert.ok(r != 0.7316977468919549, "Should not be 'hello.'#3"); + + // Mixing accumulated entropy. + // should be able to use seedrandom('added entropy.', { entropy: true }) + rng = seedrandom('added entropy.', { entropy: true }); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // Legacy calling convention for mixing accumulated entropy. + // should be able to use seedrandom('added entropy.', true) + rng = seedrandom('added entropy.', true); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // The pass option + // should be able to use Math.seedrandom(null, { pass: ... + obj = Math.seedrandom(null, { pass: function(prng, seed) { + return { random: prng, seed: seed }; + }}); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== obj.random, "Should be different from Math.random."); + assert.equal(typeof(obj.random), 'function', "Should return a PRNG function."); + assert.equal(typeof(obj.seed), 'string', "Should return a seed."); + as2 = obj.random(); + assert.ok(as2 != 0.9282578795792454, "Should not be 'hello.'#1"); + rng = seedrandom(obj.seed); + as3 = rng(); + assert.equal(as2, as3, "Should be reproducible when using the seed."); + + // Exercise pass again, with explicit seed and global + // should be able to use Math.seedrandom('hello.', { pass: ... + result = Math.seedrandom('hello.', { + global: 'abc', + pass: function(prng, seed, global) { + assert.equal(typeof(prng), 'function', "Callback arg #1 assert"); + assert.equal(seed, 'hello.', "Callback arg #2 assert"); + assert.equal(global, 'abc', "Callback arg #3 passed through."); + assert.equal(prng(), 0.9282578795792454, "Should be 'hello.'#1"); + return 'def'; + }}); + assert.equal(result, 'def', "Should return value from callback."); + assert.ok(original === Math.random, "Should not change Math.random."); + + // Legacy third argument callback argument: + // should be able to use Math.seedrandom('hello.', { global: 50 }, callback) + result = Math.seedrandom('hello.', { global: 50 }, + function(prng, seed, global) { + assert.equal(typeof(prng), 'function', "Callback arg #1 assert"); + assert.equal(seed, 'hello.', "Callback arg #2 assert"); + assert.equal(global, 50, "Callback arg #3 assert"); + assert.equal(prng(), 0.9282578795792454, "Should be 'hello.'#1"); + return 'zzz'; + }); + assert.equal(result, 'zzz', "Should return value from callback."); + assert.ok(original === Math.random, "Should not change Math.random."); + + // Global: false. + // should be able to use new Math.seedrandom('hello.', {global: false}) + myrng = new Math.seedrandom('hello.', {global:false}); + assert.equal(typeof(myrng), 'function', "Should return a PRNG funciton."); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== myrng, "PRNG should not be Math.random."); + r = myrng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // options = {} when a method of Math. + // should be able to use Math.seedrandom('hello.', {}) + result = Math.seedrandom('hello.'); + xprng = Math.random; + assert.ok(original !== xprng, "Should change Math.random."); + assert.equal(result, "hello.", "Should return short seed."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + r = Math.random(); + assert.equal(r, 0.3752569768646784, "Should be 'hello.'#2"); + Math.random = original; + + // options = {} when not a method of Math + // should be able to use seedrandom('hello.', {}) + rng = seedrandom('hello.', {}); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); +}); + +it('should support state api.', function() { + // Verify that there is no state method + var dummy = seedrandom('hello'); + var unexpected = -1; + var expected = -1; + try { + unexpected = dummy.state(); + } catch(e) { + expected = 1; + } + assert.equal(unexpected, -1); + assert.equal(expected, 1); + var count = 0; + for (var x in dummy) { + if (x == 'state') count += 1; + } + assert.equal(count, 0); + + // Verify that a state method can be added + var saveable = seedrandom("secret-seed", {state: true}); + var ordinary = seedrandom("secret-seed"); + for (var j = 0; j < 1e2; ++j) { + assert.equal(ordinary(), saveable()); + } + var virgin = seedrandom("secret-seed"); + var saved = saveable.state(); + var replica = seedrandom("", {state: saved}); + for (var j = 0; j < 1e2; ++j) { + var r = replica(); + assert.equal(r, saveable()); + assert.equal(r, ordinary()); + assert.ok(r != virgin()); + } +}); + +it('should support requirejs in node.', function() { + var original = Math.random; + var rsr = requirejs('../seedrandom'); + var rng = rsr('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + var r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); +}); + +// End of test. + +}); + +}).call(this,"/test") +},{"../seedrandom":3,"assert":"assert","requirejs":2}],"assert":[function(require,module,exports){ +// Use QUnit.assert to mimic node.assert. + +module.exports = QUnit.assert; + +},{}]},{},[4]); diff --git a/node_modules/seedrandom/test/cryptotest.js b/node_modules/seedrandom/test/cryptotest.js new file mode 100644 index 0000000..1686e59 --- /dev/null +++ b/node_modules/seedrandom/test/cryptotest.js @@ -0,0 +1,57 @@ +var proxyquire = require('proxyquire'); +var assert = require("assert"); +var Module = require("module"); + +describe("Crypto API Test", function() { + +var crypto_stub = {}; +var original = Math.random; +var rng, r; + +// Load seedrandom in absence of any crypto package. +it("should be able to seed without crypto", function() { + var noncrypto_sr = proxyquire('../seedrandom', { crypto: null }); + rng = noncrypto_sr('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert(original === Math.random, "Should not change Math.random."); + assert(original !== rng, "PRNG should not be Math.random."); + var noncrypto_sr = proxyquire('../seedrandom', { crypto: null }); + result = noncrypto_sr(); + assert.equal(typeof(result), 'function', "Should return function."); + assert(original === Math.random, "Should not change Math.random."); + r = result(); + assert(r != 0.9282578795792454, "Should not be 'hello.'#1"); + assert(r != 0.7316977468919549, "Should not be 'hello.'#3"); + assert(r != 0.23144008215179881, "Should not be '\\0'#1"); + assert(r != 0.7220382488550928, "Should not be '\\1'#1"); + // Recache original seedrandom. + proxyquire('../seedrandom', {}); +}); + +// Load seedrandom with zeroed-out crypto package. +it("should be able to seed ('hello.') with zero crypto", function() { + var zerocrypto_sr = proxyquire('../seedrandom', { + crypto: { randomBytes: function(n) { + result = []; while (n-- > 0) { result.push(1); } return result; } } + }); + rng = zerocrypto_sr('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454 , "Should be 'hello.'#1"); + assert(original === Math.random, "Should not change Math.random."); + assert(original !== rng, "PRNG should not be Math.random."); + rng = zerocrypto_sr(); + assert.equal(typeof(rng), 'function', "Should return function."); + assert(original === Math.random, "Should not change Math.random."); + r = rng(); + assert.equal(r, 0.7220382488550928, "Should be '\\1'#1"); + r = rng(); + assert.equal(r, 0.0259971860493045, "Should be '\\1'#2"); + // Recache original seedrandom. + proxyquire('../seedrandom', {}); +}); + + +}); diff --git a/node_modules/seedrandom/test/lib/qunit.css b/node_modules/seedrandom/test/lib/qunit.css new file mode 100644 index 0000000..593a65f --- /dev/null +++ b/node_modules/seedrandom/test/lib/qunit.css @@ -0,0 +1,415 @@ +/*! + * QUnit 2.1.0 + * https://qunitjs.com/ + * + * Copyright jQuery Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2016-12-06T04:45Z + */ + +/** Font Family and Sizes */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-filteredTest, #qunit-userAgent, #qunit-testresult { + font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif; +} + +#qunit-testrunner-toolbar, #qunit-filteredTest, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; } +#qunit-tests { font-size: smaller; } + + +/** Resets */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-filteredTest, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter { + margin: 0; + padding: 0; +} + + +/** Header (excluding toolbar) */ + +#qunit-header { + padding: 0.5em 0 0.5em 1em; + + color: #8699A4; + background-color: #0D3349; + + font-size: 1.5em; + line-height: 1em; + font-weight: 400; + + border-radius: 5px 5px 0 0; +} + +#qunit-header a { + text-decoration: none; + color: #C2CCD1; +} + +#qunit-header a:hover, +#qunit-header a:focus { + color: #FFF; +} + +#qunit-banner { + height: 5px; +} + +#qunit-filteredTest { + padding: 0.5em 1em 0.5em 1em; + color: #366097; + background-color: #F4FF77; +} + +#qunit-userAgent { + padding: 0.5em 1em 0.5em 1em; + color: #FFF; + background-color: #2B81AF; + text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px; +} + + +/** Toolbar */ + +#qunit-testrunner-toolbar { + padding: 0.5em 1em 0.5em 1em; + color: #5E740B; + background-color: #EEE; +} + +#qunit-testrunner-toolbar .clearfix { + height: 0; + clear: both; +} + +#qunit-testrunner-toolbar label { + display: inline-block; +} + +#qunit-testrunner-toolbar input[type=checkbox], +#qunit-testrunner-toolbar input[type=radio] { + margin: 3px; + vertical-align: -2px; +} + +#qunit-testrunner-toolbar input[type=text] { + box-sizing: border-box; + height: 1.6em; +} + +.qunit-url-config, +.qunit-filter, +#qunit-modulefilter { + display: inline-block; + line-height: 2.1em; +} + +.qunit-filter, +#qunit-modulefilter { + float: right; + position: relative; + margin-left: 1em; +} + +.qunit-url-config label { + margin-right: 0.5em; +} + +#qunit-modulefilter-search { + box-sizing: border-box; + width: 400px; +} + +#qunit-modulefilter-search-container:after { + position: absolute; + right: 0.3em; + content: "\25bc"; + color: black; +} + +#qunit-modulefilter-dropdown { + /* align with #qunit-modulefilter-search */ + box-sizing: border-box; + width: 400px; + position: absolute; + right: 0; + top: 50%; + margin-top: 0.8em; + + border: 1px solid #D3D3D3; + border-top: none; + border-radius: 0 0 .25em .25em; + color: #000; + background-color: #F5F5F5; + z-index: 99; +} + +#qunit-modulefilter-dropdown a { + color: inherit; + text-decoration: none; +} + +#qunit-modulefilter-dropdown .clickable.checked { + font-weight: bold; + color: #000; + background-color: #D2E0E6; +} + +#qunit-modulefilter-dropdown .clickable:hover { + color: #FFF; + background-color: #0D3349; +} + +#qunit-modulefilter-actions { + display: block; + overflow: auto; + + /* align with #qunit-modulefilter-dropdown-list */ + font: smaller/1.5em sans-serif; +} + +#qunit-modulefilter-dropdown #qunit-modulefilter-actions > * { + box-sizing: border-box; + max-height: 2.8em; + display: block; + padding: 0.4em; +} + +#qunit-modulefilter-dropdown #qunit-modulefilter-actions > button { + float: right; + font: inherit; +} + +#qunit-modulefilter-dropdown #qunit-modulefilter-actions > :last-child { + /* insert padding to align with checkbox margins */ + padding-left: 3px; +} + +#qunit-modulefilter-dropdown-list { + max-height: 200px; + overflow-y: auto; + margin: 0; + border-top: 2px groove threedhighlight; + padding: 0.4em 0 0; + font: smaller/1.5em sans-serif; +} + +#qunit-modulefilter-dropdown-list li { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} + +#qunit-modulefilter-dropdown-list .clickable { + display: block; + padding-left: 0.15em; +} + + +/** Tests: Pass/Fail */ + +#qunit-tests { + list-style-position: inside; +} + +#qunit-tests li { + padding: 0.4em 1em 0.4em 1em; + border-bottom: 1px solid #FFF; + list-style-position: inside; +} + +#qunit-tests > li { + display: none; +} + +#qunit-tests li.running, +#qunit-tests li.pass, +#qunit-tests li.fail, +#qunit-tests li.skipped { + display: list-item; +} + +#qunit-tests.hidepass { + position: relative; +} + +#qunit-tests.hidepass li.running, +#qunit-tests.hidepass li.pass { + visibility: hidden; + position: absolute; + width: 0; + height: 0; + padding: 0; + border: 0; + margin: 0; +} + +#qunit-tests li strong { + cursor: pointer; +} + +#qunit-tests li.skipped strong { + cursor: default; +} + +#qunit-tests li a { + padding: 0.5em; + color: #C2CCD1; + text-decoration: none; +} + +#qunit-tests li p a { + padding: 0.25em; + color: #6B6464; +} +#qunit-tests li a:hover, +#qunit-tests li a:focus { + color: #000; +} + +#qunit-tests li .runtime { + float: right; + font-size: smaller; +} + +.qunit-assert-list { + margin-top: 0.5em; + padding: 0.5em; + + background-color: #FFF; + + border-radius: 5px; +} + +.qunit-source { + margin: 0.6em 0 0.3em; +} + +.qunit-collapsed { + display: none; +} + +#qunit-tests table { + border-collapse: collapse; + margin-top: 0.2em; +} + +#qunit-tests th { + text-align: right; + vertical-align: top; + padding: 0 0.5em 0 0; +} + +#qunit-tests td { + vertical-align: top; +} + +#qunit-tests pre { + margin: 0; + white-space: pre-wrap; + word-wrap: break-word; +} + +#qunit-tests del { + color: #374E0C; + background-color: #E0F2BE; + text-decoration: none; +} + +#qunit-tests ins { + color: #500; + background-color: #FFCACA; + text-decoration: none; +} + +/*** Test Counts */ + +#qunit-tests b.counts { color: #000; } +#qunit-tests b.passed { color: #5E740B; } +#qunit-tests b.failed { color: #710909; } + +#qunit-tests li li { + padding: 5px; + background-color: #FFF; + border-bottom: none; + list-style-position: inside; +} + +/*** Passing Styles */ + +#qunit-tests li li.pass { + color: #3C510C; + background-color: #FFF; + border-left: 10px solid #C6E746; +} + +#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; } +#qunit-tests .pass .test-name { color: #366097; } + +#qunit-tests .pass .test-actual, +#qunit-tests .pass .test-expected { color: #999; } + +#qunit-banner.qunit-pass { background-color: #C6E746; } + +/*** Failing Styles */ + +#qunit-tests li li.fail { + color: #710909; + background-color: #FFF; + border-left: 10px solid #EE5757; + white-space: pre; +} + +#qunit-tests > li:last-child { + border-radius: 0 0 5px 5px; +} + +#qunit-tests .fail { color: #000; background-color: #EE5757; } +#qunit-tests .fail .test-name, +#qunit-tests .fail .module-name { color: #000; } + +#qunit-tests .fail .test-actual { color: #EE5757; } +#qunit-tests .fail .test-expected { color: #008000; } + +#qunit-banner.qunit-fail { background-color: #EE5757; } + +/*** Skipped tests */ + +#qunit-tests .skipped { + background-color: #EBECE9; +} + +#qunit-tests .qunit-skipped-label { + background-color: #F4FF77; + display: inline-block; + font-style: normal; + color: #366097; + line-height: 1.8em; + padding: 0 0.5em; + margin: -0.4em 0.4em -0.4em 0; +} + +/** Result */ + +#qunit-testresult { + padding: 0.5em 1em 0.5em 1em; + + color: #2B81AF; + background-color: #D2E0E6; + + border-bottom: 1px solid #FFF; +} +#qunit-testresult .module-name { + font-weight: 700; +} + +/** Fixture */ + +#qunit-fixture { + position: absolute; + top: -10000px; + left: -10000px; + width: 1000px; + height: 1000px; +} diff --git a/node_modules/seedrandom/test/lib/qunit.js b/node_modules/seedrandom/test/lib/qunit.js new file mode 100644 index 0000000..8b5e69e --- /dev/null +++ b/node_modules/seedrandom/test/lib/qunit.js @@ -0,0 +1,4349 @@ +/*! + * QUnit 2.1.0 + * https://qunitjs.com/ + * + * Copyright jQuery Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2016-12-06T04:45Z + */ +(function (global$1) { + 'use strict'; + + global$1 = 'default' in global$1 ? global$1['default'] : global$1; + + var window = global$1.window; + var console = global$1.console; + var setTimeout = global$1.setTimeout; + var clearTimeout = global$1.clearTimeout; + + var document = window && window.document; + var navigator = window && window.navigator; + var sessionStorage = window && window.sessionStorage; + + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { + return typeof obj; + } : function (obj) { + return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; + }; + + + + + + + + + + + + + + + + + + + + + + var get$1 = function get$1(object, property, receiver) { + if (object === null) object = Function.prototype; + var desc = Object.getOwnPropertyDescriptor(object, property); + + if (desc === undefined) { + var parent = Object.getPrototypeOf(object); + + if (parent === null) { + return undefined; + } else { + return get$1(parent, property, receiver); + } + } else if ("value" in desc) { + return desc.value; + } else { + var getter = desc.get; + + if (getter === undefined) { + return undefined; + } + + return getter.call(receiver); + } + }; + + + + + + + + + + + + + + + + + + var set$1 = function set$1(object, property, value, receiver) { + var desc = Object.getOwnPropertyDescriptor(object, property); + + if (desc === undefined) { + var parent = Object.getPrototypeOf(object); + + if (parent !== null) { + set$1(parent, property, value, receiver); + } + } else if ("value" in desc && desc.writable) { + desc.value = value; + } else { + var setter = desc.set; + + if (setter !== undefined) { + setter.call(receiver, value); + } + } + + return value; + }; + + + + + + + + + + + + + + + + var toConsumableArray = function (arr) { + if (Array.isArray(arr)) { + for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i]; + + return arr2; + } else { + return Array.from(arr); + } + }; + + var toString = Object.prototype.toString; + var hasOwn = Object.prototype.hasOwnProperty; + var now = Date.now || function () { + return new Date().getTime(); + }; + + var defined = { + document: window && window.document !== undefined, + setTimeout: setTimeout !== undefined + }; + + // Returns a new Array with the elements that are in a but not in b + function diff(a, b) { + var i, + j, + result = a.slice(); + + for (i = 0; i < result.length; i++) { + for (j = 0; j < b.length; j++) { + if (result[i] === b[j]) { + result.splice(i, 1); + i--; + break; + } + } + } + return result; + } + + // From jquery.js + function inArray(elem, array) { + if (array.indexOf) { + return array.indexOf(elem); + } + + for (var i = 0, length = array.length; i < length; i++) { + if (array[i] === elem) { + return i; + } + } + + return -1; + } + + /** + * Makes a clone of an object using only Array or Object as base, + * and copies over the own enumerable properties. + * + * @param {Object} obj + * @return {Object} New object with only the own properties (recursively). + */ + function objectValues(obj) { + var key, + val, + vals = is("array", obj) ? [] : {}; + for (key in obj) { + if (hasOwn.call(obj, key)) { + val = obj[key]; + vals[key] = val === Object(val) ? objectValues(val) : val; + } + } + return vals; + } + + function extend(a, b, undefOnly) { + for (var prop in b) { + if (hasOwn.call(b, prop)) { + if (b[prop] === undefined) { + delete a[prop]; + } else if (!(undefOnly && typeof a[prop] !== "undefined")) { + a[prop] = b[prop]; + } + } + } + + return a; + } + + function objectType(obj) { + if (typeof obj === "undefined") { + return "undefined"; + } + + // Consider: typeof null === object + if (obj === null) { + return "null"; + } + + var match = toString.call(obj).match(/^\[object\s(.*)\]$/), + type = match && match[1]; + + switch (type) { + case "Number": + if (isNaN(obj)) { + return "nan"; + } + return "number"; + case "String": + case "Boolean": + case "Array": + case "Set": + case "Map": + case "Date": + case "RegExp": + case "Function": + case "Symbol": + return type.toLowerCase(); + } + + if ((typeof obj === "undefined" ? "undefined" : _typeof(obj)) === "object") { + return "object"; + } + } + + // Safe object type checking + function is(type, obj) { + return objectType(obj) === type; + } + + // Test for equality any JavaScript type. + // Author: Philippe Rathé + var equiv = (function () { + + // Stack to decide between skip/abort functions + var callers = []; + + // Stack to avoiding loops from circular referencing + var parents = []; + var parentsB = []; + + var getProto = Object.getPrototypeOf || function (obj) { + return obj.__proto__; + }; + + function useStrictEquality(b, a) { + + // To catch short annotation VS 'new' annotation of a declaration. e.g.: + // `var i = 1;` + // `var j = new Number(1);` + if ((typeof a === "undefined" ? "undefined" : _typeof(a)) === "object") { + a = a.valueOf(); + } + if ((typeof b === "undefined" ? "undefined" : _typeof(b)) === "object") { + b = b.valueOf(); + } + + return a === b; + } + + function compareConstructors(a, b) { + var protoA = getProto(a); + var protoB = getProto(b); + + // Comparing constructors is more strict than using `instanceof` + if (a.constructor === b.constructor) { + return true; + } + + // Ref #851 + // If the obj prototype descends from a null constructor, treat it + // as a null prototype. + if (protoA && protoA.constructor === null) { + protoA = null; + } + if (protoB && protoB.constructor === null) { + protoB = null; + } + + // Allow objects with no prototype to be equivalent to + // objects with Object as their constructor. + if (protoA === null && protoB === Object.prototype || protoB === null && protoA === Object.prototype) { + return true; + } + + return false; + } + + function getRegExpFlags(regexp) { + return "flags" in regexp ? regexp.flags : regexp.toString().match(/[gimuy]*$/)[0]; + } + + var callbacks = { + "string": useStrictEquality, + "boolean": useStrictEquality, + "number": useStrictEquality, + "null": useStrictEquality, + "undefined": useStrictEquality, + "symbol": useStrictEquality, + "date": useStrictEquality, + + "nan": function nan() { + return true; + }, + + "regexp": function regexp(b, a) { + return a.source === b.source && + + // Include flags in the comparison + getRegExpFlags(a) === getRegExpFlags(b); + }, + + // - skip when the property is a method of an instance (OOP) + // - abort otherwise, + // initial === would have catch identical references anyway + "function": function _function(b, a) { + + var caller = callers[callers.length - 1]; + return caller !== Object && typeof caller !== "undefined" && a.toString() === b.toString(); + }, + + "array": function array(b, a) { + var i, j, len, loop, aCircular, bCircular; + + len = a.length; + if (len !== b.length) { + + // Safe and faster + return false; + } + + // Track reference to avoid circular references + parents.push(a); + parentsB.push(b); + for (i = 0; i < len; i++) { + loop = false; + for (j = 0; j < parents.length; j++) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if (aCircular || bCircular) { + if (a[i] === b[i] || aCircular && bCircular) { + loop = true; + } else { + parents.pop(); + parentsB.pop(); + return false; + } + } + } + if (!loop && !innerEquiv(a[i], b[i])) { + parents.pop(); + parentsB.pop(); + return false; + } + } + parents.pop(); + parentsB.pop(); + return true; + }, + + "set": function set(b, a) { + var innerEq, + outerEq = true; + + if (a.size !== b.size) { + return false; + } + + a.forEach(function (aVal) { + innerEq = false; + + b.forEach(function (bVal) { + if (innerEquiv(bVal, aVal)) { + innerEq = true; + } + }); + + if (!innerEq) { + outerEq = false; + } + }); + + return outerEq; + }, + + "map": function map(b, a) { + var innerEq, + outerEq = true; + + if (a.size !== b.size) { + return false; + } + + a.forEach(function (aVal, aKey) { + innerEq = false; + + b.forEach(function (bVal, bKey) { + if (innerEquiv([bVal, bKey], [aVal, aKey])) { + innerEq = true; + } + }); + + if (!innerEq) { + outerEq = false; + } + }); + + return outerEq; + }, + + "object": function object(b, a) { + var i, j, loop, aCircular, bCircular; + + // Default to true + var eq = true; + var aProperties = []; + var bProperties = []; + + if (compareConstructors(a, b) === false) { + return false; + } + + // Stack constructor before traversing properties + callers.push(a.constructor); + + // Track reference to avoid circular references + parents.push(a); + parentsB.push(b); + + // Be strict: don't ensure hasOwnProperty and go deep + for (i in a) { + loop = false; + for (j = 0; j < parents.length; j++) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if (aCircular || bCircular) { + if (a[i] === b[i] || aCircular && bCircular) { + loop = true; + } else { + eq = false; + break; + } + } + } + aProperties.push(i); + if (!loop && !innerEquiv(a[i], b[i])) { + eq = false; + break; + } + } + + parents.pop(); + parentsB.pop(); + + // Unstack, we are done + callers.pop(); + + for (i in b) { + + // Collect b's properties + bProperties.push(i); + } + + // Ensures identical properties name + return eq && innerEquiv(aProperties.sort(), bProperties.sort()); + } + }; + + function typeEquiv(a, b) { + var type = objectType(a); + return objectType(b) === type && callbacks[type](b, a); + } + + // The real equiv function + function innerEquiv(a, b) { + + // We're done when there's nothing more to compare + if (arguments.length < 2) { + return true; + } + + // Require type-specific equality + return (a === b || typeEquiv(a, b)) && ( + + // ...across all consecutive argument pairs + arguments.length === 2 || innerEquiv.apply(this, [].slice.call(arguments, 1))); + } + + return innerEquiv; + })(); + + /** + * Config object: Maintain internal state + * Later exposed as QUnit.config + * `config` initialized at top of scope + */ + var config = { + + // The queue of tests to run + queue: [], + + // Block until document ready + blocking: true, + + // By default, run previously failed tests first + // very useful in combination with "Hide passed tests" checked + reorder: true, + + // By default, modify document.title when suite is done + altertitle: true, + + // HTML Reporter: collapse every test except the first failing test + // If false, all failing tests will be expanded + collapse: true, + + // By default, scroll to top of the page when suite is done + scrolltop: true, + + // Depth up-to which object will be dumped + maxDepth: 5, + + // When enabled, all tests must call expect() + requireExpects: false, + + // Placeholder for user-configurable form-exposed URL parameters + urlConfig: [], + + // Set of all modules. + modules: [], + + // Stack of nested modules + moduleStack: [], + + // The first unnamed module + currentModule: { + name: "", + tests: [], + childModules: [], + testsRun: 0 + }, + + callbacks: {}, + + // The storage module to use for reordering tests + storage: sessionStorage + }; + + // take a predefined QUnit.config and extend the defaults + var globalConfig = window && window.QUnit && window.QUnit.config; + + // only extend the global config if there is no QUnit overload + if (window && window.QUnit && !window.QUnit.version) { + extend(config, globalConfig); + } + + // Push a loose unnamed module to the modules collection + config.modules.push(config.currentModule); + + // Based on jsDump by Ariel Flesler + // http://flesler.blogspot.com/2008/05/jsdump-pretty-dump-of-any-javascript.html + var dump = (function () { + function quote(str) { + return "\"" + str.toString().replace(/\\/g, "\\\\").replace(/"/g, "\\\"") + "\""; + } + function literal(o) { + return o + ""; + } + function join(pre, arr, post) { + var s = dump.separator(), + base = dump.indent(), + inner = dump.indent(1); + if (arr.join) { + arr = arr.join("," + s + inner); + } + if (!arr) { + return pre + post; + } + return [pre, inner + arr, base + post].join(s); + } + function array(arr, stack) { + var i = arr.length, + ret = new Array(i); + + if (dump.maxDepth && dump.depth > dump.maxDepth) { + return "[object Array]"; + } + + this.up(); + while (i--) { + ret[i] = this.parse(arr[i], undefined, stack); + } + this.down(); + return join("[", ret, "]"); + } + + function isArray(obj) { + return ( + + //Native Arrays + toString.call(obj) === "[object Array]" || + + // NodeList objects + typeof obj.length === "number" && obj.item !== undefined && (obj.length ? obj.item(0) === obj[0] : obj.item(0) === null && obj[0] === undefined) + ); + } + + var reName = /^function (\w+)/, + dump = { + + // The objType is used mostly internally, you can fix a (custom) type in advance + parse: function parse(obj, objType, stack) { + stack = stack || []; + var res, + parser, + parserType, + inStack = inArray(obj, stack); + + if (inStack !== -1) { + return "recursion(" + (inStack - stack.length) + ")"; + } + + objType = objType || this.typeOf(obj); + parser = this.parsers[objType]; + parserType = typeof parser === "undefined" ? "undefined" : _typeof(parser); + + if (parserType === "function") { + stack.push(obj); + res = parser.call(this, obj, stack); + stack.pop(); + return res; + } + return parserType === "string" ? parser : this.parsers.error; + }, + typeOf: function typeOf(obj) { + var type; + + if (obj === null) { + type = "null"; + } else if (typeof obj === "undefined") { + type = "undefined"; + } else if (is("regexp", obj)) { + type = "regexp"; + } else if (is("date", obj)) { + type = "date"; + } else if (is("function", obj)) { + type = "function"; + } else if (obj.setInterval !== undefined && obj.document !== undefined && obj.nodeType === undefined) { + type = "window"; + } else if (obj.nodeType === 9) { + type = "document"; + } else if (obj.nodeType) { + type = "node"; + } else if (isArray(obj)) { + type = "array"; + } else if (obj.constructor === Error.prototype.constructor) { + type = "error"; + } else { + type = typeof obj === "undefined" ? "undefined" : _typeof(obj); + } + return type; + }, + + separator: function separator() { + if (this.multiline) { + return this.HTML ? "
" : "\n"; + } else { + return this.HTML ? " " : " "; + } + }, + + // Extra can be a number, shortcut for increasing-calling-decreasing + indent: function indent(extra) { + if (!this.multiline) { + return ""; + } + var chr = this.indentChar; + if (this.HTML) { + chr = chr.replace(/\t/g, " ").replace(/ /g, " "); + } + return new Array(this.depth + (extra || 0)).join(chr); + }, + up: function up(a) { + this.depth += a || 1; + }, + down: function down(a) { + this.depth -= a || 1; + }, + setParser: function setParser(name, parser) { + this.parsers[name] = parser; + }, + + // The next 3 are exposed so you can use them + quote: quote, + literal: literal, + join: join, + depth: 1, + maxDepth: config.maxDepth, + + // This is the list of parsers, to modify them, use dump.setParser + parsers: { + window: "[Window]", + document: "[Document]", + error: function error(_error) { + return "Error(\"" + _error.message + "\")"; + }, + unknown: "[Unknown]", + "null": "null", + "undefined": "undefined", + "function": function _function(fn) { + var ret = "function", + + + // Functions never have name in IE + name = "name" in fn ? fn.name : (reName.exec(fn) || [])[1]; + + if (name) { + ret += " " + name; + } + ret += "("; + + ret = [ret, dump.parse(fn, "functionArgs"), "){"].join(""); + return join(ret, dump.parse(fn, "functionCode"), "}"); + }, + array: array, + nodelist: array, + "arguments": array, + object: function object(map, stack) { + var keys, + key, + val, + i, + nonEnumerableProperties, + ret = []; + + if (dump.maxDepth && dump.depth > dump.maxDepth) { + return "[object Object]"; + } + + dump.up(); + keys = []; + for (key in map) { + keys.push(key); + } + + // Some properties are not always enumerable on Error objects. + nonEnumerableProperties = ["message", "name"]; + for (i in nonEnumerableProperties) { + key = nonEnumerableProperties[i]; + if (key in map && inArray(key, keys) < 0) { + keys.push(key); + } + } + keys.sort(); + for (i = 0; i < keys.length; i++) { + key = keys[i]; + val = map[key]; + ret.push(dump.parse(key, "key") + ": " + dump.parse(val, undefined, stack)); + } + dump.down(); + return join("{", ret, "}"); + }, + node: function node(_node) { + var len, + i, + val, + open = dump.HTML ? "<" : "<", + close = dump.HTML ? ">" : ">", + tag = _node.nodeName.toLowerCase(), + ret = open + tag, + attrs = _node.attributes; + + if (attrs) { + for (i = 0, len = attrs.length; i < len; i++) { + val = attrs[i].nodeValue; + + // IE6 includes all attributes in .attributes, even ones not explicitly + // set. Those have values like undefined, null, 0, false, "" or + // "inherit". + if (val && val !== "inherit") { + ret += " " + attrs[i].nodeName + "=" + dump.parse(val, "attribute"); + } + } + } + ret += close; + + // Show content of TextNode or CDATASection + if (_node.nodeType === 3 || _node.nodeType === 4) { + ret += _node.nodeValue; + } + + return ret + open + "/" + tag + close; + }, + + // Function calls it internally, it's the arguments part of the function + functionArgs: function functionArgs(fn) { + var args, + l = fn.length; + + if (!l) { + return ""; + } + + args = new Array(l); + while (l--) { + + // 97 is 'a' + args[l] = String.fromCharCode(97 + l); + } + return " " + args.join(", ") + " "; + }, + + // Object calls it internally, the key part of an item in a map + key: quote, + + // Function calls it internally, it's the content of the function + functionCode: "[code]", + + // Node calls it internally, it's a html attribute value + attribute: quote, + string: quote, + date: quote, + regexp: literal, + number: literal, + "boolean": literal, + symbol: function symbol(sym) { + return sym.toString(); + } + }, + + // If true, entities are escaped ( <, >, \t, space and \n ) + HTML: false, + + // Indentation unit + indentChar: " ", + + // If true, items in a collection, are separated by a \n, else just a space. + multiline: true + }; + + return dump; + })(); + + // Register logging callbacks + function registerLoggingCallbacks(obj) { + var i, + l, + key, + callbackNames = ["begin", "done", "log", "testStart", "testDone", "moduleStart", "moduleDone"]; + + function registerLoggingCallback(key) { + var loggingCallback = function loggingCallback(callback) { + if (objectType(callback) !== "function") { + throw new Error("QUnit logging methods require a callback function as their first parameters."); + } + + config.callbacks[key].push(callback); + }; + + return loggingCallback; + } + + for (i = 0, l = callbackNames.length; i < l; i++) { + key = callbackNames[i]; + + // Initialize key collection of logging callback + if (objectType(config.callbacks[key]) === "undefined") { + config.callbacks[key] = []; + } + + obj[key] = registerLoggingCallback(key); + } + } + + function runLoggingCallbacks(key, args) { + var i, l, callbacks; + + callbacks = config.callbacks[key]; + for (i = 0, l = callbacks.length; i < l; i++) { + callbacks[i](args); + } + } + + // Doesn't support IE9, it will return undefined on these browsers + // See also https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error/Stack + var fileName = (sourceFromStacktrace(0) || "").replace(/(:\d+)+\)?/, "").replace(/.+\//, ""); + + function extractStacktrace(e, offset) { + offset = offset === undefined ? 4 : offset; + + var stack, include, i; + + if (e && e.stack) { + stack = e.stack.split("\n"); + if (/^error$/i.test(stack[0])) { + stack.shift(); + } + if (fileName) { + include = []; + for (i = offset; i < stack.length; i++) { + if (stack[i].indexOf(fileName) !== -1) { + break; + } + include.push(stack[i]); + } + if (include.length) { + return include.join("\n"); + } + } + return stack[offset]; + } + } + + function sourceFromStacktrace(offset) { + var error = new Error(); + + // Support: Safari <=7 only, IE <=10 - 11 only + // Not all browsers generate the `stack` property for `new Error()`, see also #636 + if (!error.stack) { + try { + throw error; + } catch (err) { + error = err; + } + } + + return extractStacktrace(error, offset); + } + + var unitSampler; + var focused = false; + var priorityCount = 0; + + function Test(settings) { + var i, l; + + ++Test.count; + + this.expected = null; + extend(this, settings); + this.assertions = []; + this.semaphore = 0; + this.usedAsync = false; + this.module = config.currentModule; + this.stack = sourceFromStacktrace(3); + + // Register unique strings + for (i = 0, l = this.module.tests; i < l.length; i++) { + if (this.module.tests[i].name === this.testName) { + this.testName += " "; + } + } + + this.testId = generateHash(this.module.name, this.testName); + + this.module.tests.push({ + name: this.testName, + testId: this.testId + }); + + if (settings.skip) { + + // Skipped tests will fully ignore any sent callback + this.callback = function () {}; + this.async = false; + this.expected = 0; + } else { + this.assert = new Assert(this); + } + } + + Test.count = 0; + + function getNotStartedModules(startModule) { + var module = startModule, + modules = []; + + while (module && module.testsRun === 0) { + modules.push(module); + module = module.parentModule; + } + + return modules; + } + + Test.prototype = { + before: function before() { + var i, + startModule, + module = this.module, + notStartedModules = getNotStartedModules(module); + + for (i = notStartedModules.length - 1; i >= 0; i--) { + startModule = notStartedModules[i]; + startModule.stats = { all: 0, bad: 0, started: now() }; + runLoggingCallbacks("moduleStart", { + name: startModule.name, + tests: startModule.tests + }); + } + + config.current = this; + + if (module.testEnvironment) { + delete module.testEnvironment.before; + delete module.testEnvironment.beforeEach; + delete module.testEnvironment.afterEach; + delete module.testEnvironment.after; + } + this.testEnvironment = extend({}, module.testEnvironment); + + this.started = now(); + runLoggingCallbacks("testStart", { + name: this.testName, + module: module.name, + testId: this.testId, + previousFailure: this.previousFailure + }); + + if (!config.pollution) { + saveGlobal(); + } + }, + + run: function run() { + var promise; + + config.current = this; + + this.callbackStarted = now(); + + if (config.notrycatch) { + runTest(this); + return; + } + + try { + runTest(this); + } catch (e) { + this.pushFailure("Died on test #" + (this.assertions.length + 1) + " " + this.stack + ": " + (e.message || e), extractStacktrace(e, 0)); + + // Else next test will carry the responsibility + saveGlobal(); + + // Restart the tests if they're blocking + if (config.blocking) { + internalRecover(this); + } + } + + function runTest(test) { + promise = test.callback.call(test.testEnvironment, test.assert); + test.resolvePromise(promise); + } + }, + + after: function after() { + checkPollution(); + }, + + queueHook: function queueHook(hook, hookName, hookOwner) { + var promise, + test = this; + return function runHook() { + if (hookName === "before") { + if (hookOwner.testsRun !== 0) { + return; + } + + test.preserveEnvironment = true; + } + + if (hookName === "after" && hookOwner.testsRun !== numberOfTests(hookOwner) - 1) { + return; + } + + config.current = test; + if (config.notrycatch) { + callHook(); + return; + } + try { + callHook(); + } catch (error) { + test.pushFailure(hookName + " failed on " + test.testName + ": " + (error.message || error), extractStacktrace(error, 0)); + } + + function callHook() { + promise = hook.call(test.testEnvironment, test.assert); + test.resolvePromise(promise, hookName); + } + }; + }, + + // Currently only used for module level hooks, can be used to add global level ones + hooks: function hooks(handler) { + var hooks = []; + + function processHooks(test, module) { + if (module.parentModule) { + processHooks(test, module.parentModule); + } + if (module.testEnvironment && objectType(module.testEnvironment[handler]) === "function") { + hooks.push(test.queueHook(module.testEnvironment[handler], handler, module)); + } + } + + // Hooks are ignored on skipped tests + if (!this.skip) { + processHooks(this, this.module); + } + return hooks; + }, + + finish: function finish() { + config.current = this; + if (config.requireExpects && this.expected === null) { + this.pushFailure("Expected number of assertions to be defined, but expect() was " + "not called.", this.stack); + } else if (this.expected !== null && this.expected !== this.assertions.length) { + this.pushFailure("Expected " + this.expected + " assertions, but " + this.assertions.length + " were run", this.stack); + } else if (this.expected === null && !this.assertions.length) { + this.pushFailure("Expected at least one assertion, but none were run - call " + "expect(0) to accept zero assertions.", this.stack); + } + + var i, + module = this.module, + moduleName = module.name, + testName = this.testName, + skipped = !!this.skip, + bad = 0, + storage = config.storage; + + this.runtime = now() - this.started; + + config.stats.all += this.assertions.length; + module.stats.all += this.assertions.length; + + for (i = 0; i < this.assertions.length; i++) { + if (!this.assertions[i].result) { + bad++; + config.stats.bad++; + module.stats.bad++; + } + } + + notifyTestsRan(module); + + // Store result when possible + if (storage) { + if (bad) { + storage.setItem("qunit-test-" + moduleName + "-" + testName, bad); + } else { + storage.removeItem("qunit-test-" + moduleName + "-" + testName); + } + } + + runLoggingCallbacks("testDone", { + name: testName, + module: moduleName, + skipped: skipped, + failed: bad, + passed: this.assertions.length - bad, + total: this.assertions.length, + runtime: skipped ? 0 : this.runtime, + + // HTML Reporter use + assertions: this.assertions, + testId: this.testId, + + // Source of Test + source: this.stack + }); + + if (module.testsRun === numberOfTests(module)) { + runLoggingCallbacks("moduleDone", { + name: module.name, + tests: module.tests, + failed: module.stats.bad, + passed: module.stats.all - module.stats.bad, + total: module.stats.all, + runtime: now() - module.stats.started + }); + } + + config.current = undefined; + }, + + preserveTestEnvironment: function preserveTestEnvironment() { + if (this.preserveEnvironment) { + this.module.testEnvironment = this.testEnvironment; + this.testEnvironment = extend({}, this.module.testEnvironment); + } + }, + + queue: function queue() { + var priority, + previousFailCount, + test = this; + + if (!this.valid()) { + return; + } + + function run() { + + // Each of these can by async + synchronize([function () { + test.before(); + }, test.hooks("before"), function () { + test.preserveTestEnvironment(); + }, test.hooks("beforeEach"), function () { + test.run(); + }, test.hooks("afterEach").reverse(), test.hooks("after").reverse(), function () { + test.after(); + }, function () { + test.finish(); + }]); + } + + previousFailCount = config.storage && +config.storage.getItem("qunit-test-" + this.module.name + "-" + this.testName); + + // Prioritize previously failed tests, detected from storage + priority = config.reorder && previousFailCount; + + this.previousFailure = !!previousFailCount; + + return synchronize(run, priority, config.seed); + }, + + pushResult: function pushResult(resultInfo) { + + // Destructure of resultInfo = { result, actual, expected, message, negative } + var source, + details = { + module: this.module.name, + name: this.testName, + result: resultInfo.result, + message: resultInfo.message, + actual: resultInfo.actual, + expected: resultInfo.expected, + testId: this.testId, + negative: resultInfo.negative || false, + runtime: now() - this.started + }; + + if (!resultInfo.result) { + source = sourceFromStacktrace(); + + if (source) { + details.source = source; + } + } + + runLoggingCallbacks("log", details); + + this.assertions.push({ + result: !!resultInfo.result, + message: resultInfo.message + }); + }, + + pushFailure: function pushFailure(message, source, actual) { + if (!(this instanceof Test)) { + throw new Error("pushFailure() assertion outside test context, was " + sourceFromStacktrace(2)); + } + + var details = { + module: this.module.name, + name: this.testName, + result: false, + message: message || "error", + actual: actual || null, + testId: this.testId, + runtime: now() - this.started + }; + + if (source) { + details.source = source; + } + + runLoggingCallbacks("log", details); + + this.assertions.push({ + result: false, + message: message + }); + }, + + resolvePromise: function resolvePromise(promise, phase) { + var then, + resume, + message, + test = this; + if (promise != null) { + then = promise.then; + if (objectType(then) === "function") { + resume = internalStop(test); + then.call(promise, function () { + resume(); + }, function (error) { + message = "Promise rejected " + (!phase ? "during" : phase.replace(/Each$/, "")) + " \"" + test.testName + "\": " + (error && error.message || error); + test.pushFailure(message, extractStacktrace(error, 0)); + + // Else next test will carry the responsibility + saveGlobal(); + + // Unblock + resume(); + }); + } + } + }, + + valid: function valid() { + var filter = config.filter, + regexFilter = /^(!?)\/([\w\W]*)\/(i?$)/.exec(filter), + module = config.module && config.module.toLowerCase(), + fullName = this.module.name + ": " + this.testName; + + function moduleChainNameMatch(testModule) { + var testModuleName = testModule.name ? testModule.name.toLowerCase() : null; + if (testModuleName === module) { + return true; + } else if (testModule.parentModule) { + return moduleChainNameMatch(testModule.parentModule); + } else { + return false; + } + } + + function moduleChainIdMatch(testModule) { + return inArray(testModule.moduleId, config.moduleId) > -1 || testModule.parentModule && moduleChainIdMatch(testModule.parentModule); + } + + // Internally-generated tests are always valid + if (this.callback && this.callback.validTest) { + return true; + } + + if (config.moduleId && config.moduleId.length > 0 && !moduleChainIdMatch(this.module)) { + + return false; + } + + if (config.testId && config.testId.length > 0 && inArray(this.testId, config.testId) < 0) { + + return false; + } + + if (module && !moduleChainNameMatch(this.module)) { + return false; + } + + if (!filter) { + return true; + } + + return regexFilter ? this.regexFilter(!!regexFilter[1], regexFilter[2], regexFilter[3], fullName) : this.stringFilter(filter, fullName); + }, + + regexFilter: function regexFilter(exclude, pattern, flags, fullName) { + var regex = new RegExp(pattern, flags); + var match = regex.test(fullName); + + return match !== exclude; + }, + + stringFilter: function stringFilter(filter, fullName) { + filter = filter.toLowerCase(); + fullName = fullName.toLowerCase(); + + var include = filter.charAt(0) !== "!"; + if (!include) { + filter = filter.slice(1); + } + + // If the filter matches, we need to honour include + if (fullName.indexOf(filter) !== -1) { + return include; + } + + // Otherwise, do the opposite + return !include; + } + }; + + function pushFailure() { + if (!config.current) { + throw new Error("pushFailure() assertion outside test context, in " + sourceFromStacktrace(2)); + } + + // Gets current test obj + var currentTest = config.current; + + return currentTest.pushFailure.apply(currentTest, arguments); + } + + // Based on Java's String.hashCode, a simple but not + // rigorously collision resistant hashing function + function generateHash(module, testName) { + var hex, + i = 0, + hash = 0, + str = module + "\x1C" + testName, + len = str.length; + + for (; i < len; i++) { + hash = (hash << 5) - hash + str.charCodeAt(i); + hash |= 0; + } + + // Convert the possibly negative integer hash code into an 8 character hex string, which isn't + // strictly necessary but increases user understanding that the id is a SHA-like hash + hex = (0x100000000 + hash).toString(16); + if (hex.length < 8) { + hex = "0000000" + hex; + } + + return hex.slice(-8); + } + + function synchronize(callback, priority, seed) { + var last = !priority, + index; + + if (objectType(callback) === "array") { + while (callback.length) { + synchronize(callback.shift()); + } + return; + } + + if (priority) { + config.queue.splice(priorityCount++, 0, callback); + } else if (seed) { + if (!unitSampler) { + unitSampler = unitSamplerGenerator(seed); + } + + // Insert into a random position after all priority items + index = Math.floor(unitSampler() * (config.queue.length - priorityCount + 1)); + config.queue.splice(priorityCount + index, 0, callback); + } else { + config.queue.push(callback); + } + + if (internalState.autorun && !config.blocking) { + process(last); + } + } + + function unitSamplerGenerator(seed) { + + // 32-bit xorshift, requires only a nonzero seed + // http://excamera.com/sphinx/article-xorshift.html + var sample = parseInt(generateHash(seed), 16) || -1; + return function () { + sample ^= sample << 13; + sample ^= sample >>> 17; + sample ^= sample << 5; + + // ECMAScript has no unsigned number type + if (sample < 0) { + sample += 0x100000000; + } + + return sample / 0x100000000; + }; + } + + function saveGlobal() { + config.pollution = []; + + if (config.noglobals) { + for (var key in global$1) { + if (hasOwn.call(global$1, key)) { + + // In Opera sometimes DOM element ids show up here, ignore them + if (/^qunit-test-output/.test(key)) { + continue; + } + config.pollution.push(key); + } + } + } + } + + function checkPollution() { + var newGlobals, + deletedGlobals, + old = config.pollution; + + saveGlobal(); + + newGlobals = diff(config.pollution, old); + if (newGlobals.length > 0) { + pushFailure("Introduced global variable(s): " + newGlobals.join(", ")); + } + + deletedGlobals = diff(old, config.pollution); + if (deletedGlobals.length > 0) { + pushFailure("Deleted global variable(s): " + deletedGlobals.join(", ")); + } + } + + // Will be exposed as QUnit.test + function test(testName, callback) { + if (focused) { + return; + } + + var newTest; + + newTest = new Test({ + testName: testName, + callback: callback + }); + + newTest.queue(); + } + + // Will be exposed as QUnit.skip + function skip(testName) { + if (focused) { + return; + } + + var test = new Test({ + testName: testName, + skip: true + }); + + test.queue(); + } + + // Will be exposed as QUnit.only + function only(testName, callback) { + var newTest; + + if (focused) { + return; + } + + config.queue.length = 0; + focused = true; + + newTest = new Test({ + testName: testName, + callback: callback + }); + + newTest.queue(); + } + + // Put a hold on processing and return a function that will release it. + function internalStop(test) { + var released = false; + + test.semaphore += 1; + config.blocking = true; + + // Set a recovery timeout, if so configured. + if (config.testTimeout && defined.setTimeout) { + clearTimeout(config.timeout); + config.timeout = setTimeout(function () { + pushFailure("Test timed out", sourceFromStacktrace(2)); + internalRecover(test); + }, config.testTimeout); + } + + return function resume() { + if (released) { + return; + } + + released = true; + test.semaphore -= 1; + internalStart(test); + }; + } + + // Forcefully release all processing holds. + function internalRecover(test) { + test.semaphore = 0; + internalStart(test); + } + + // Release a processing hold, scheduling a resumption attempt if no holds remain. + function internalStart(test) { + + // If semaphore is non-numeric, throw error + if (isNaN(test.semaphore)) { + test.semaphore = 0; + + pushFailure("Invalid value on test.semaphore", sourceFromStacktrace(2)); + return; + } + + // Don't start until equal number of stop-calls + if (test.semaphore > 0) { + return; + } + + // Throw an Error if start is called more often than stop + if (test.semaphore < 0) { + test.semaphore = 0; + + pushFailure("Tried to restart test while already started (test's semaphore was 0 already)", sourceFromStacktrace(2)); + return; + } + + // Add a slight delay to allow more assertions etc. + if (defined.setTimeout) { + if (config.timeout) { + clearTimeout(config.timeout); + } + config.timeout = setTimeout(function () { + if (test.semaphore > 0) { + return; + } + + if (config.timeout) { + clearTimeout(config.timeout); + } + + begin(); + }, 13); + } else { + begin(); + } + } + + function numberOfTests(module) { + var count = module.tests.length, + modules = [].concat(toConsumableArray(module.childModules)); + + // Do a breadth-first traversal of the child modules + while (modules.length) { + var nextModule = modules.shift(); + count += nextModule.tests.length; + modules.push.apply(modules, toConsumableArray(nextModule.childModules)); + } + + return count; + } + + function notifyTestsRan(module) { + module.testsRun++; + while (module = module.parentModule) { + module.testsRun++; + } + } + + function Assert(testContext) { + this.test = testContext; + } + + // Assert helpers + Assert.prototype = { + + // Specify the number of expected assertions to guarantee that failed test + // (no assertions are run at all) don't slip through. + expect: function expect(asserts) { + if (arguments.length === 1) { + this.test.expected = asserts; + } else { + return this.test.expected; + } + }, + + // Put a hold on processing and return a function that will release it a maximum of once. + async: function async(count) { + var resume, + test$$1 = this.test, + popped = false, + acceptCallCount = count; + + if (typeof acceptCallCount === "undefined") { + acceptCallCount = 1; + } + + test$$1.usedAsync = true; + resume = internalStop(test$$1); + + return function done() { + + if (popped) { + test$$1.pushFailure("Too many calls to the `assert.async` callback", sourceFromStacktrace(2)); + return; + } + acceptCallCount -= 1; + if (acceptCallCount > 0) { + return; + } + + popped = true; + resume(); + }; + }, + + // Exports test.push() to the user API + // Alias of pushResult. + push: function push(result, actual, expected, message, negative) { + var currentAssert = this instanceof Assert ? this : config.current.assert; + return currentAssert.pushResult({ + result: result, + actual: actual, + expected: expected, + message: message, + negative: negative + }); + }, + + pushResult: function pushResult(resultInfo) { + + // Destructure of resultInfo = { result, actual, expected, message, negative } + var assert = this, + currentTest = assert instanceof Assert && assert.test || config.current; + + // Backwards compatibility fix. + // Allows the direct use of global exported assertions and QUnit.assert.* + // Although, it's use is not recommended as it can leak assertions + // to other tests from async tests, because we only get a reference to the current test, + // not exactly the test where assertion were intended to be called. + if (!currentTest) { + throw new Error("assertion outside test context, in " + sourceFromStacktrace(2)); + } + + if (currentTest.usedAsync === true && currentTest.semaphore === 0) { + currentTest.pushFailure("Assertion after the final `assert.async` was resolved", sourceFromStacktrace(2)); + + // Allow this assertion to continue running anyway... + } + + if (!(assert instanceof Assert)) { + assert = currentTest.assert; + } + + return assert.test.pushResult(resultInfo); + }, + + ok: function ok(result, message) { + message = message || (result ? "okay" : "failed, expected argument to be truthy, was: " + dump.parse(result)); + this.pushResult({ + result: !!result, + actual: result, + expected: true, + message: message + }); + }, + + notOk: function notOk(result, message) { + message = message || (!result ? "okay" : "failed, expected argument to be falsy, was: " + dump.parse(result)); + this.pushResult({ + result: !result, + actual: result, + expected: false, + message: message + }); + }, + + equal: function equal(actual, expected, message) { + + // eslint-disable-next-line eqeqeq + var result = expected == actual; + + this.pushResult({ + result: result, + actual: actual, + expected: expected, + message: message + }); + }, + + notEqual: function notEqual(actual, expected, message) { + + // eslint-disable-next-line eqeqeq + var result = expected != actual; + + this.pushResult({ + result: result, + actual: actual, + expected: expected, + message: message, + negative: true + }); + }, + + propEqual: function propEqual(actual, expected, message) { + actual = objectValues(actual); + expected = objectValues(expected); + this.pushResult({ + result: equiv(actual, expected), + actual: actual, + expected: expected, + message: message + }); + }, + + notPropEqual: function notPropEqual(actual, expected, message) { + actual = objectValues(actual); + expected = objectValues(expected); + this.pushResult({ + result: !equiv(actual, expected), + actual: actual, + expected: expected, + message: message, + negative: true + }); + }, + + deepEqual: function deepEqual(actual, expected, message) { + this.pushResult({ + result: equiv(actual, expected), + actual: actual, + expected: expected, + message: message + }); + }, + + notDeepEqual: function notDeepEqual(actual, expected, message) { + this.pushResult({ + result: !equiv(actual, expected), + actual: actual, + expected: expected, + message: message, + negative: true + }); + }, + + strictEqual: function strictEqual(actual, expected, message) { + this.pushResult({ + result: expected === actual, + actual: actual, + expected: expected, + message: message + }); + }, + + notStrictEqual: function notStrictEqual(actual, expected, message) { + this.pushResult({ + result: expected !== actual, + actual: actual, + expected: expected, + message: message, + negative: true + }); + }, + + "throws": function throws(block, expected, message) { + var actual, + expectedType, + expectedOutput = expected, + ok = false, + currentTest = this instanceof Assert && this.test || config.current; + + // 'expected' is optional unless doing string comparison + if (objectType(expected) === "string") { + if (message == null) { + message = expected; + expected = null; + } else { + throw new Error("throws/raises does not accept a string value for the expected argument.\n" + "Use a non-string object value (e.g. regExp) instead if it's necessary." + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + } + } + + currentTest.ignoreGlobalErrors = true; + try { + block.call(currentTest.testEnvironment); + } catch (e) { + actual = e; + } + currentTest.ignoreGlobalErrors = false; + + if (actual) { + expectedType = objectType(expected); + + // We don't want to validate thrown error + if (!expected) { + ok = true; + expectedOutput = null; + + // Expected is a regexp + } else if (expectedType === "regexp") { + ok = expected.test(errorString(actual)); + + // Expected is a constructor, maybe an Error constructor + } else if (expectedType === "function" && actual instanceof expected) { + ok = true; + + // Expected is an Error object + } else if (expectedType === "object") { + ok = actual instanceof expected.constructor && actual.name === expected.name && actual.message === expected.message; + + // Expected is a validation function which returns true if validation passed + } else if (expectedType === "function" && expected.call({}, actual) === true) { + expectedOutput = null; + ok = true; + } + } + + currentTest.assert.pushResult({ + result: ok, + actual: actual, + expected: expectedOutput, + message: message + }); + } + }; + + // Provide an alternative to assert.throws(), for environments that consider throws a reserved word + // Known to us are: Closure Compiler, Narwhal + (function () { + + // eslint-disable-next-line dot-notation + Assert.prototype.raises = Assert.prototype["throws"]; + })(); + + function errorString(error) { + var name, + message, + resultErrorString = error.toString(); + if (resultErrorString.substring(0, 7) === "[object") { + name = error.name ? error.name.toString() : "Error"; + message = error.message ? error.message.toString() : ""; + if (name && message) { + return name + ": " + message; + } else if (name) { + return name; + } else if (message) { + return message; + } else { + return "Error"; + } + } else { + return resultErrorString; + } + } + + /* global module, exports, define */ + function applyDeprecated(name) { + return function () { + throw new Error(name + " is removed in QUnit 2.0.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + }; + } + + function exportQUnit(QUnit) { + + Object.keys(Assert.prototype).forEach(function (key) { + QUnit[key] = applyDeprecated("`QUnit." + key + "`"); + }); + + QUnit.asyncTest = function () { + throw new Error("asyncTest is removed in QUnit 2.0, use QUnit.test() with assert.async() instead.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + }; + + QUnit.stop = function () { + throw new Error("QUnit.stop is removed in QUnit 2.0, use QUnit.test() with assert.async() instead.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + }; + + function resetThrower() { + throw new Error("QUnit.reset is removed in QUnit 2.0 without replacement.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + } + + Object.defineProperty(QUnit, "reset", { + get: function get() { + return resetThrower; + }, + set: resetThrower + }); + + if (defined.document) { + + // QUnit may be defined when it is preconfigured but then only QUnit and QUnit.config may be defined. + if (window.QUnit && window.QUnit.version) { + throw new Error("QUnit has already been defined."); + } + + ["test", "module", "expect", "start", "ok", "notOk", "equal", "notEqual", "propEqual", "notPropEqual", "deepEqual", "notDeepEqual", "strictEqual", "notStrictEqual", "throws", "raises"].forEach(function (key) { + window[key] = applyDeprecated("The global `" + key + "`"); + }); + + window.QUnit = QUnit; + } + + // For nodejs + if (typeof module !== "undefined" && module && module.exports) { + module.exports = QUnit; + + // For consistency with CommonJS environments' exports + module.exports.QUnit = QUnit; + } + + // For CommonJS with exports, but without module.exports, like Rhino + if (typeof exports !== "undefined" && exports) { + exports.QUnit = QUnit; + } + + if (typeof define === "function" && define.amd) { + define(function () { + return QUnit; + }); + QUnit.config.autostart = false; + } + } + + (function () { + if (!defined.document) { + return; + } + + // `onErrorFnPrev` initialized at top of scope + // Preserve other handlers + var onErrorFnPrev = window.onerror; + + // Cover uncaught exceptions + // Returning true will suppress the default browser handler, + // returning false will let it run. + window.onerror = function (error, filePath, linerNr) { + var ret = false; + if (onErrorFnPrev) { + ret = onErrorFnPrev(error, filePath, linerNr); + } + + // Treat return value as window.onerror itself does, + // Only do our handling if not suppressed. + if (ret !== true) { + if (config.current) { + if (config.current.ignoreGlobalErrors) { + return true; + } + pushFailure(error, filePath + ":" + linerNr); + } else { + test("global failure", extend(function () { + pushFailure(error, filePath + ":" + linerNr); + }, { validTest: true })); + } + return false; + } + + return ret; + }; + })(); + + var QUnit = {}; + + var globalStartCalled = false; + var runStarted = false; + + var internalState = { + autorun: false + }; + + // Figure out if we're running the tests from a server or not + QUnit.isLocal = !(defined.document && window.location.protocol !== "file:"); + + // Expose the current QUnit version + QUnit.version = "2.1.0"; + + extend(QUnit, { + + // Call on start of module test to prepend name to all tests + module: function module(name, testEnvironment, executeNow) { + var module, moduleFns; + var currentModule = config.currentModule; + + if (arguments.length === 2) { + if (objectType(testEnvironment) === "function") { + executeNow = testEnvironment; + testEnvironment = undefined; + } + } + + module = createModule(); + + if (testEnvironment && (testEnvironment.setup || testEnvironment.teardown)) { + console.warn("Module's `setup` and `teardown` are not hooks anymore on QUnit 2.0, use " + "`beforeEach` and `afterEach` instead\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + } + + moduleFns = { + before: setHook(module, "before"), + beforeEach: setHook(module, "beforeEach"), + afterEach: setHook(module, "afterEach"), + after: setHook(module, "after") + }; + + if (objectType(executeNow) === "function") { + config.moduleStack.push(module); + setCurrentModule(module); + executeNow.call(module.testEnvironment, moduleFns); + config.moduleStack.pop(); + module = module.parentModule || currentModule; + } + + setCurrentModule(module); + + function createModule() { + var parentModule = config.moduleStack.length ? config.moduleStack.slice(-1)[0] : null; + var moduleName = parentModule !== null ? [parentModule.name, name].join(" > ") : name; + var module = { + name: moduleName, + parentModule: parentModule, + tests: [], + moduleId: generateHash(moduleName), + testsRun: 0, + childModules: [] + }; + + var env = {}; + if (parentModule) { + parentModule.childModules.push(module); + extend(env, parentModule.testEnvironment); + delete env.beforeEach; + delete env.afterEach; + } + extend(env, testEnvironment); + module.testEnvironment = env; + + config.modules.push(module); + return module; + } + + function setCurrentModule(module) { + config.currentModule = module; + } + }, + + test: test, + + skip: skip, + + only: only, + + start: function start(count) { + var globalStartAlreadyCalled = globalStartCalled; + + if (!config.current) { + globalStartCalled = true; + + if (runStarted) { + throw new Error("Called start() while test already started running"); + } else if (globalStartAlreadyCalled || count > 1) { + throw new Error("Called start() outside of a test context too many times"); + } else if (config.autostart) { + throw new Error("Called start() outside of a test context when " + "QUnit.config.autostart was true"); + } else if (!config.pageLoaded) { + + // The page isn't completely loaded yet, so bail out and let `QUnit.load` handle it + config.autostart = true; + return; + } + } else { + throw new Error("QUnit.start cannot be called inside a test context. This feature is removed in " + "QUnit 2.0. For async tests, use QUnit.test() with assert.async() instead.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + } + + scheduleBegin(); + }, + + config: config, + + is: is, + + objectType: objectType, + + extend: extend, + + load: function load() { + config.pageLoaded = true; + + // Initialize the configuration options + extend(config, { + stats: { all: 0, bad: 0 }, + started: 0, + updateRate: 1000, + autostart: true, + filter: "" + }, true); + + if (!runStarted) { + config.blocking = false; + + if (config.autostart) { + scheduleBegin(); + } + } + }, + + stack: function stack(offset) { + offset = (offset || 0) + 2; + return sourceFromStacktrace(offset); + } + }); + + QUnit.pushFailure = pushFailure; + QUnit.assert = Assert.prototype; + QUnit.equiv = equiv; + QUnit.dump = dump; + + // 3.0 TODO: Remove + function jsDumpThrower() { + throw new Error("QUnit.jsDump is removed in QUnit 2.0, use QUnit.dump instead.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + } + + Object.defineProperty(QUnit, "jsDump", { + get: jsDumpThrower, + set: jsDumpThrower + }); + + registerLoggingCallbacks(QUnit); + + function scheduleBegin() { + + runStarted = true; + + // Add a slight delay to allow definition of more modules and tests. + if (defined.setTimeout) { + setTimeout(function () { + begin(); + }, 13); + } else { + begin(); + } + } + + function begin() { + var i, + l, + modulesLog = []; + + // If the test run hasn't officially begun yet + if (!config.started) { + + // Record the time of the test run's beginning + config.started = now(); + + // Delete the loose unnamed module if unused. + if (config.modules[0].name === "" && config.modules[0].tests.length === 0) { + config.modules.shift(); + } + + // Avoid unnecessary information by not logging modules' test environments + for (i = 0, l = config.modules.length; i < l; i++) { + modulesLog.push({ + name: config.modules[i].name, + tests: config.modules[i].tests + }); + } + + // The test run is officially beginning now + runLoggingCallbacks("begin", { + totalTests: Test.count, + modules: modulesLog + }); + } + + config.blocking = false; + process(true); + } + + function process(last) { + function next() { + process(last); + } + var start = now(); + config.depth = (config.depth || 0) + 1; + + while (config.queue.length && !config.blocking) { + if (!defined.setTimeout || config.updateRate <= 0 || now() - start < config.updateRate) { + if (config.current) { + + // Reset async tracking for each phase of the Test lifecycle + config.current.usedAsync = false; + } + config.queue.shift()(); + } else { + setTimeout(next, 13); + break; + } + } + config.depth--; + if (last && !config.blocking && !config.queue.length && config.depth === 0) { + done$1(); + } + } + + function done$1() { + var runtime, + passed, + i, + key, + storage = config.storage; + + internalState.autorun = true; + + runtime = now() - config.started; + passed = config.stats.all - config.stats.bad; + + runLoggingCallbacks("done", { + failed: config.stats.bad, + passed: passed, + total: config.stats.all, + runtime: runtime + }); + + // Clear own storage items if all tests passed + if (storage && config.stats.bad === 0) { + for (i = storage.length - 1; i >= 0; i--) { + key = storage.key(i); + if (key.indexOf("qunit-test-") === 0) { + storage.removeItem(key); + } + } + } + } + + function setHook(module, hookName) { + if (module.testEnvironment === undefined) { + module.testEnvironment = {}; + } + + return function (callback) { + module.testEnvironment[hookName] = callback; + }; + } + + exportQUnit(QUnit); + + (function () { + + if (typeof window === "undefined" || typeof document === "undefined") { + return; + } + + var config = QUnit.config, + hasOwn = Object.prototype.hasOwnProperty; + + // Stores fixture HTML for resetting later + function storeFixture() { + + // Avoid overwriting user-defined values + if (hasOwn.call(config, "fixture")) { + return; + } + + var fixture = document.getElementById("qunit-fixture"); + if (fixture) { + config.fixture = fixture.innerHTML; + } + } + + QUnit.begin(storeFixture); + + // Resets the fixture DOM element if available. + function resetFixture() { + if (config.fixture == null) { + return; + } + + var fixture = document.getElementById("qunit-fixture"); + if (fixture) { + fixture.innerHTML = config.fixture; + } + } + + QUnit.testStart(resetFixture); + })(); + + // Escape text for attribute or text content. + function escapeText(s) { + if (!s) { + return ""; + } + s = s + ""; + + // Both single quotes and double quotes (for attributes) + return s.replace(/['"<>&]/g, function (s) { + switch (s) { + case "'": + return "'"; + case "\"": + return """; + case "<": + return "<"; + case ">": + return ">"; + case "&": + return "&"; + } + }); + } + + (function () { + + // Don't load the HTML Reporter on non-browser environments + if (typeof window === "undefined" || !window.document) { + return; + } + + QUnit.init = function () { + throw new Error("QUnit.init is removed in QUnit 2.0, use QUnit.test() with assert.async() instead.\n" + "Details in our upgrade guide at https://qunitjs.com/upgrade-guide-2.x/"); + }; + + var config = QUnit.config, + document$$1 = window.document, + collapseNext = false, + hasOwn = Object.prototype.hasOwnProperty, + unfilteredUrl = setUrl({ filter: undefined, module: undefined, + moduleId: undefined, testId: undefined }), + modulesList = []; + + function addEvent(elem, type, fn) { + elem.addEventListener(type, fn, false); + } + + function removeEvent(elem, type, fn) { + elem.removeEventListener(type, fn, false); + } + + function addEvents(elems, type, fn) { + var i = elems.length; + while (i--) { + addEvent(elems[i], type, fn); + } + } + + function hasClass(elem, name) { + return (" " + elem.className + " ").indexOf(" " + name + " ") >= 0; + } + + function addClass(elem, name) { + if (!hasClass(elem, name)) { + elem.className += (elem.className ? " " : "") + name; + } + } + + function toggleClass(elem, name, force) { + if (force || typeof force === "undefined" && !hasClass(elem, name)) { + addClass(elem, name); + } else { + removeClass(elem, name); + } + } + + function removeClass(elem, name) { + var set = " " + elem.className + " "; + + // Class name may appear multiple times + while (set.indexOf(" " + name + " ") >= 0) { + set = set.replace(" " + name + " ", " "); + } + + // Trim for prettiness + elem.className = typeof set.trim === "function" ? set.trim() : set.replace(/^\s+|\s+$/g, ""); + } + + function id(name) { + return document$$1.getElementById && document$$1.getElementById(name); + } + + function interceptNavigation(ev) { + applyUrlParams(); + + if (ev && ev.preventDefault) { + ev.preventDefault(); + } + + return false; + } + + function getUrlConfigHtml() { + var i, + j, + val, + escaped, + escapedTooltip, + selection = false, + urlConfig = config.urlConfig, + urlConfigHtml = ""; + + for (i = 0; i < urlConfig.length; i++) { + + // Options can be either strings or objects with nonempty "id" properties + val = config.urlConfig[i]; + if (typeof val === "string") { + val = { + id: val, + label: val + }; + } + + escaped = escapeText(val.id); + escapedTooltip = escapeText(val.tooltip); + + if (!val.value || typeof val.value === "string") { + urlConfigHtml += ""; + } else { + urlConfigHtml += ""; + } + } + + return urlConfigHtml; + } + + // Handle "click" events on toolbar checkboxes and "change" for select menus. + // Updates the URL with the new state of `config.urlConfig` values. + function toolbarChanged() { + var updatedUrl, + value, + tests, + field = this, + params = {}; + + // Detect if field is a select menu or a checkbox + if ("selectedIndex" in field) { + value = field.options[field.selectedIndex].value || undefined; + } else { + value = field.checked ? field.defaultValue || true : undefined; + } + + params[field.name] = value; + updatedUrl = setUrl(params); + + // Check if we can apply the change without a page refresh + if ("hidepassed" === field.name && "replaceState" in window.history) { + QUnit.urlParams[field.name] = value; + config[field.name] = value || false; + tests = id("qunit-tests"); + if (tests) { + toggleClass(tests, "hidepass", value || false); + } + window.history.replaceState(null, "", updatedUrl); + } else { + window.location = updatedUrl; + } + } + + function setUrl(params) { + var key, + arrValue, + i, + querystring = "?", + location = window.location; + + params = QUnit.extend(QUnit.extend({}, QUnit.urlParams), params); + + for (key in params) { + + // Skip inherited or undefined properties + if (hasOwn.call(params, key) && params[key] !== undefined) { + + // Output a parameter for each value of this key (but usually just one) + arrValue = [].concat(params[key]); + for (i = 0; i < arrValue.length; i++) { + querystring += encodeURIComponent(key); + if (arrValue[i] !== true) { + querystring += "=" + encodeURIComponent(arrValue[i]); + } + querystring += "&"; + } + } + } + return location.protocol + "//" + location.host + location.pathname + querystring.slice(0, -1); + } + + function applyUrlParams() { + var i, + selectedModules = [], + modulesList = id("qunit-modulefilter-dropdown-list").getElementsByTagName("input"), + filter = id("qunit-filter-input").value; + + for (i = 0; i < modulesList.length; i++) { + if (modulesList[i].checked) { + selectedModules.push(modulesList[i].value); + } + } + + window.location = setUrl({ + filter: filter === "" ? undefined : filter, + moduleId: selectedModules.length === 0 ? undefined : selectedModules, + + // Remove module and testId filter + module: undefined, + testId: undefined + }); + } + + function toolbarUrlConfigContainer() { + var urlConfigContainer = document$$1.createElement("span"); + + urlConfigContainer.innerHTML = getUrlConfigHtml(); + addClass(urlConfigContainer, "qunit-url-config"); + + addEvents(urlConfigContainer.getElementsByTagName("input"), "change", toolbarChanged); + addEvents(urlConfigContainer.getElementsByTagName("select"), "change", toolbarChanged); + + return urlConfigContainer; + } + + function toolbarLooseFilter() { + var filter = document$$1.createElement("form"), + label = document$$1.createElement("label"), + input = document$$1.createElement("input"), + button = document$$1.createElement("button"); + + addClass(filter, "qunit-filter"); + + label.innerHTML = "Filter: "; + + input.type = "text"; + input.value = config.filter || ""; + input.name = "filter"; + input.id = "qunit-filter-input"; + + button.innerHTML = "Go"; + + label.appendChild(input); + + filter.appendChild(label); + filter.appendChild(document$$1.createTextNode(" ")); + filter.appendChild(button); + addEvent(filter, "submit", interceptNavigation); + + return filter; + } + + function moduleListHtml() { + var i, + checked, + html = ""; + + for (i = 0; i < config.modules.length; i++) { + if (config.modules[i].name !== "") { + checked = config.moduleId.indexOf(config.modules[i].moduleId) > -1; + html += "
  • "; + } + } + + return html; + } + + function toolbarModuleFilter() { + var allCheckbox, + commit, + reset, + moduleFilter = document$$1.createElement("form"), + label = document$$1.createElement("label"), + moduleSearch = document$$1.createElement("input"), + dropDown = document$$1.createElement("div"), + actions = document$$1.createElement("span"), + dropDownList = document$$1.createElement("ul"), + dirty = false; + + moduleSearch.id = "qunit-modulefilter-search"; + addEvent(moduleSearch, "input", searchInput); + addEvent(moduleSearch, "input", searchFocus); + addEvent(moduleSearch, "focus", searchFocus); + addEvent(moduleSearch, "click", searchFocus); + + label.id = "qunit-modulefilter-search-container"; + label.innerHTML = "Module: "; + label.appendChild(moduleSearch); + + actions.id = "qunit-modulefilter-actions"; + actions.innerHTML = "" + "" + ""; + allCheckbox = actions.lastChild.firstChild; + commit = actions.firstChild; + reset = commit.nextSibling; + addEvent(commit, "click", applyUrlParams); + + dropDownList.id = "qunit-modulefilter-dropdown-list"; + dropDownList.innerHTML = moduleListHtml(); + + dropDown.id = "qunit-modulefilter-dropdown"; + dropDown.style.display = "none"; + dropDown.appendChild(actions); + dropDown.appendChild(dropDownList); + addEvent(dropDown, "change", selectionChange); + selectionChange(); + + moduleFilter.id = "qunit-modulefilter"; + moduleFilter.appendChild(label); + moduleFilter.appendChild(dropDown); + addEvent(moduleFilter, "submit", interceptNavigation); + addEvent(moduleFilter, "reset", function () { + + // Let the reset happen, then update styles + window.setTimeout(selectionChange); + }); + + // Enables show/hide for the dropdown + function searchFocus() { + if (dropDown.style.display !== "none") { + return; + } + + dropDown.style.display = "block"; + addEvent(document$$1, "click", hideHandler); + addEvent(document$$1, "keydown", hideHandler); + + // Hide on Escape keydown or outside-container click + function hideHandler(e) { + var inContainer = moduleFilter.contains(e.target); + + if (e.keyCode === 27 || !inContainer) { + if (e.keyCode === 27 && inContainer) { + moduleSearch.focus(); + } + dropDown.style.display = "none"; + removeEvent(document$$1, "click", hideHandler); + removeEvent(document$$1, "keydown", hideHandler); + moduleSearch.value = ""; + searchInput(); + } + } + } + + // Processes module search box input + function searchInput() { + var i, + item, + searchText = moduleSearch.value.toLowerCase(), + listItems = dropDownList.children; + + for (i = 0; i < listItems.length; i++) { + item = listItems[i]; + if (!searchText || item.textContent.toLowerCase().indexOf(searchText) > -1) { + item.style.display = ""; + } else { + item.style.display = "none"; + } + } + } + + // Processes selection changes + function selectionChange(evt) { + var i, + item, + checkbox = evt && evt.target || allCheckbox, + modulesList = dropDownList.getElementsByTagName("input"), + selectedNames = []; + + toggleClass(checkbox.parentNode, "checked", checkbox.checked); + + dirty = false; + if (checkbox.checked && checkbox !== allCheckbox) { + allCheckbox.checked = false; + removeClass(allCheckbox.parentNode, "checked"); + } + for (i = 0; i < modulesList.length; i++) { + item = modulesList[i]; + if (!evt) { + toggleClass(item.parentNode, "checked", item.checked); + } else if (checkbox === allCheckbox && checkbox.checked) { + item.checked = false; + removeClass(item.parentNode, "checked"); + } + dirty = dirty || item.checked !== item.defaultChecked; + if (item.checked) { + selectedNames.push(item.parentNode.textContent); + } + } + + commit.style.display = reset.style.display = dirty ? "" : "none"; + moduleSearch.placeholder = selectedNames.join(", ") || allCheckbox.parentNode.textContent; + moduleSearch.title = "Type to filter list. Current selection:\n" + (selectedNames.join("\n") || allCheckbox.parentNode.textContent); + } + + return moduleFilter; + } + + function appendToolbar() { + var toolbar = id("qunit-testrunner-toolbar"); + + if (toolbar) { + toolbar.appendChild(toolbarUrlConfigContainer()); + toolbar.appendChild(toolbarModuleFilter()); + toolbar.appendChild(toolbarLooseFilter()); + toolbar.appendChild(document$$1.createElement("div")).className = "clearfix"; + } + } + + function appendHeader() { + var header = id("qunit-header"); + + if (header) { + header.innerHTML = "" + header.innerHTML + " "; + } + } + + function appendBanner() { + var banner = id("qunit-banner"); + + if (banner) { + banner.className = ""; + } + } + + function appendTestResults() { + var tests = id("qunit-tests"), + result = id("qunit-testresult"); + + if (result) { + result.parentNode.removeChild(result); + } + + if (tests) { + tests.innerHTML = ""; + result = document$$1.createElement("p"); + result.id = "qunit-testresult"; + result.className = "result"; + tests.parentNode.insertBefore(result, tests); + result.innerHTML = "Running...
     "; + } + } + + function appendFilteredTest() { + var testId = QUnit.config.testId; + if (!testId || testId.length <= 0) { + return ""; + } + return "
    Rerunning selected tests: " + escapeText(testId.join(", ")) + " Run all tests
    "; + } + + function appendUserAgent() { + var userAgent = id("qunit-userAgent"); + + if (userAgent) { + userAgent.innerHTML = ""; + userAgent.appendChild(document$$1.createTextNode("QUnit " + QUnit.version + "; " + navigator.userAgent)); + } + } + + function appendInterface() { + var qunit = id("qunit"); + + if (qunit) { + qunit.innerHTML = "

    " + escapeText(document$$1.title) + "

    " + "

    " + "
    " + appendFilteredTest() + "

    " + "
      "; + } + + appendHeader(); + appendBanner(); + appendTestResults(); + appendUserAgent(); + appendToolbar(); + } + + function appendTestsList(modules) { + var i, l, x, z, test, moduleObj; + + for (i = 0, l = modules.length; i < l; i++) { + moduleObj = modules[i]; + + for (x = 0, z = moduleObj.tests.length; x < z; x++) { + test = moduleObj.tests[x]; + + appendTest(test.name, test.testId, moduleObj.name); + } + } + } + + function appendTest(name, testId, moduleName) { + var title, + rerunTrigger, + testBlock, + assertList, + tests = id("qunit-tests"); + + if (!tests) { + return; + } + + title = document$$1.createElement("strong"); + title.innerHTML = getNameHtml(name, moduleName); + + rerunTrigger = document$$1.createElement("a"); + rerunTrigger.innerHTML = "Rerun"; + rerunTrigger.href = setUrl({ testId: testId }); + + testBlock = document$$1.createElement("li"); + testBlock.appendChild(title); + testBlock.appendChild(rerunTrigger); + testBlock.id = "qunit-test-output-" + testId; + + assertList = document$$1.createElement("ol"); + assertList.className = "qunit-assert-list"; + + testBlock.appendChild(assertList); + + tests.appendChild(testBlock); + } + + // HTML Reporter initialization and load + QUnit.begin(function (details) { + var i, moduleObj, tests; + + // Sort modules by name for the picker + for (i = 0; i < details.modules.length; i++) { + moduleObj = details.modules[i]; + if (moduleObj.name) { + modulesList.push(moduleObj.name); + } + } + modulesList.sort(function (a, b) { + return a.localeCompare(b); + }); + + // Initialize QUnit elements + appendInterface(); + appendTestsList(details.modules); + tests = id("qunit-tests"); + if (tests && config.hidepassed) { + addClass(tests, "hidepass"); + } + }); + + QUnit.done(function (details) { + var banner = id("qunit-banner"), + tests = id("qunit-tests"), + html = ["Tests completed in ", details.runtime, " milliseconds.
      ", "", details.passed, " assertions of ", details.total, " passed, ", details.failed, " failed."].join(""); + + if (banner) { + banner.className = details.failed ? "qunit-fail" : "qunit-pass"; + } + + if (tests) { + id("qunit-testresult").innerHTML = html; + } + + if (config.altertitle && document$$1.title) { + + // Show ✖ for good, ✔ for bad suite result in title + // use escape sequences in case file gets loaded with non-utf-8-charset + document$$1.title = [details.failed ? "\u2716" : "\u2714", document$$1.title.replace(/^[\u2714\u2716] /i, "")].join(" "); + } + + // Scroll back to top to show results + if (config.scrolltop && window.scrollTo) { + window.scrollTo(0, 0); + } + }); + + function getNameHtml(name, module) { + var nameHtml = ""; + + if (module) { + nameHtml = "" + escapeText(module) + ": "; + } + + nameHtml += "" + escapeText(name) + ""; + + return nameHtml; + } + + QUnit.testStart(function (details) { + var running, testBlock, bad; + + testBlock = id("qunit-test-output-" + details.testId); + if (testBlock) { + testBlock.className = "running"; + } else { + + // Report later registered tests + appendTest(details.name, details.testId, details.module); + } + + running = id("qunit-testresult"); + if (running) { + bad = QUnit.config.reorder && details.previousFailure; + + running.innerHTML = (bad ? "Rerunning previously failed test:
      " : "Running:
      ") + getNameHtml(details.name, details.module); + } + }); + + function stripHtml(string) { + + // Strip tags, html entity and whitespaces + return string.replace(/<\/?[^>]+(>|$)/g, "").replace(/\"/g, "").replace(/\s+/g, ""); + } + + QUnit.log(function (details) { + var assertList, + assertLi, + message, + expected, + actual, + diff, + showDiff = false, + testItem = id("qunit-test-output-" + details.testId); + + if (!testItem) { + return; + } + + message = escapeText(details.message) || (details.result ? "okay" : "failed"); + message = "" + message + ""; + message += "@ " + details.runtime + " ms"; + + // The pushFailure doesn't provide details.expected + // when it calls, it's implicit to also not show expected and diff stuff + // Also, we need to check details.expected existence, as it can exist and be undefined + if (!details.result && hasOwn.call(details, "expected")) { + if (details.negative) { + expected = "NOT " + QUnit.dump.parse(details.expected); + } else { + expected = QUnit.dump.parse(details.expected); + } + + actual = QUnit.dump.parse(details.actual); + message += ""; + + if (actual !== expected) { + + message += ""; + + // Don't show diff if actual or expected are booleans + if (!/^(true|false)$/.test(actual) && !/^(true|false)$/.test(expected)) { + diff = QUnit.diff(expected, actual); + showDiff = stripHtml(diff).length !== stripHtml(expected).length + stripHtml(actual).length; + } + + // Don't show diff if expected and actual are totally different + if (showDiff) { + message += ""; + } + } else if (expected.indexOf("[object Array]") !== -1 || expected.indexOf("[object Object]") !== -1) { + message += ""; + } else { + message += ""; + } + + if (details.source) { + message += ""; + } + + message += "
      Expected:
      " + escapeText(expected) + "
      Result:
      " + escapeText(actual) + "
      Diff:
      " + diff + "
      Message: " + "Diff suppressed as the depth of object is more than current max depth (" + QUnit.config.maxDepth + ").

      Hint: Use QUnit.dump.maxDepth to " + " run with a higher max depth or " + "Rerun without max depth.

      Message: " + "Diff suppressed as the expected and actual results have an equivalent" + " serialization
      Source:
      " + escapeText(details.source) + "
      "; + + // This occurs when pushFailure is set and we have an extracted stack trace + } else if (!details.result && details.source) { + message += "" + "" + "
      Source:
      " + escapeText(details.source) + "
      "; + } + + assertList = testItem.getElementsByTagName("ol")[0]; + + assertLi = document$$1.createElement("li"); + assertLi.className = details.result ? "pass" : "fail"; + assertLi.innerHTML = message; + assertList.appendChild(assertLi); + }); + + QUnit.testDone(function (details) { + var testTitle, + time, + testItem, + assertList, + good, + bad, + testCounts, + skipped, + sourceName, + tests = id("qunit-tests"); + + if (!tests) { + return; + } + + testItem = id("qunit-test-output-" + details.testId); + + assertList = testItem.getElementsByTagName("ol")[0]; + + good = details.passed; + bad = details.failed; + + if (bad === 0) { + + // Collapse the passing tests + addClass(assertList, "qunit-collapsed"); + } else if (config.collapse) { + if (!collapseNext) { + + // Skip collapsing the first failing test + collapseNext = true; + } else { + + // Collapse remaining tests + addClass(assertList, "qunit-collapsed"); + } + } + + // The testItem.firstChild is the test name + testTitle = testItem.firstChild; + + testCounts = bad ? "" + bad + ", " + "" + good + ", " : ""; + + testTitle.innerHTML += " (" + testCounts + details.assertions.length + ")"; + + if (details.skipped) { + testItem.className = "skipped"; + skipped = document$$1.createElement("em"); + skipped.className = "qunit-skipped-label"; + skipped.innerHTML = "skipped"; + testItem.insertBefore(skipped, testTitle); + } else { + addEvent(testTitle, "click", function () { + toggleClass(assertList, "qunit-collapsed"); + }); + + testItem.className = bad ? "fail" : "pass"; + + time = document$$1.createElement("span"); + time.className = "runtime"; + time.innerHTML = details.runtime + " ms"; + testItem.insertBefore(time, assertList); + } + + // Show the source of the test when showing assertions + if (details.source) { + sourceName = document$$1.createElement("p"); + sourceName.innerHTML = "Source: " + details.source; + addClass(sourceName, "qunit-source"); + if (bad === 0) { + addClass(sourceName, "qunit-collapsed"); + } + addEvent(testTitle, "click", function () { + toggleClass(sourceName, "qunit-collapsed"); + }); + testItem.appendChild(sourceName); + } + }); + + // Avoid readyState issue with phantomjs + // Ref: #818 + var notPhantom = function (p) { + return !(p && p.version && p.version.major > 0); + }(window.phantom); + + if (notPhantom && document$$1.readyState === "complete") { + QUnit.load(); + } else { + addEvent(window, "load", QUnit.load); + } + })(); + + /* + * This file is a modified version of google-diff-match-patch's JavaScript implementation + * (https://code.google.com/p/google-diff-match-patch/source/browse/trunk/javascript/diff_match_patch_uncompressed.js), + * modifications are licensed as more fully set forth in LICENSE.txt. + * + * The original source of google-diff-match-patch is attributable and licensed as follows: + * + * Copyright 2006 Google Inc. + * https://code.google.com/p/google-diff-match-patch/ + * + * 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 + * + * https://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. + * + * More Info: + * https://code.google.com/p/google-diff-match-patch/ + * + * Usage: QUnit.diff(expected, actual) + * + */ + QUnit.diff = function () { + function DiffMatchPatch() {} + + // DIFF FUNCTIONS + + /** + * The data structure representing a diff is an array of tuples: + * [[DIFF_DELETE, 'Hello'], [DIFF_INSERT, 'Goodbye'], [DIFF_EQUAL, ' world.']] + * which means: delete 'Hello', add 'Goodbye' and keep ' world.' + */ + var DIFF_DELETE = -1, + DIFF_INSERT = 1, + DIFF_EQUAL = 0; + + /** + * Find the differences between two texts. Simplifies the problem by stripping + * any common prefix or suffix off the texts before diffing. + * @param {string} text1 Old string to be diffed. + * @param {string} text2 New string to be diffed. + * @param {boolean=} optChecklines Optional speedup flag. If present and false, + * then don't run a line-level diff first to identify the changed areas. + * Defaults to true, which does a faster, slightly less optimal diff. + * @return {!Array.} Array of diff tuples. + */ + DiffMatchPatch.prototype.DiffMain = function (text1, text2, optChecklines) { + var deadline, checklines, commonlength, commonprefix, commonsuffix, diffs; + + // The diff must be complete in up to 1 second. + deadline = new Date().getTime() + 1000; + + // Check for null inputs. + if (text1 === null || text2 === null) { + throw new Error("Null input. (DiffMain)"); + } + + // Check for equality (speedup). + if (text1 === text2) { + if (text1) { + return [[DIFF_EQUAL, text1]]; + } + return []; + } + + if (typeof optChecklines === "undefined") { + optChecklines = true; + } + + checklines = optChecklines; + + // Trim off common prefix (speedup). + commonlength = this.diffCommonPrefix(text1, text2); + commonprefix = text1.substring(0, commonlength); + text1 = text1.substring(commonlength); + text2 = text2.substring(commonlength); + + // Trim off common suffix (speedup). + commonlength = this.diffCommonSuffix(text1, text2); + commonsuffix = text1.substring(text1.length - commonlength); + text1 = text1.substring(0, text1.length - commonlength); + text2 = text2.substring(0, text2.length - commonlength); + + // Compute the diff on the middle block. + diffs = this.diffCompute(text1, text2, checklines, deadline); + + // Restore the prefix and suffix. + if (commonprefix) { + diffs.unshift([DIFF_EQUAL, commonprefix]); + } + if (commonsuffix) { + diffs.push([DIFF_EQUAL, commonsuffix]); + } + this.diffCleanupMerge(diffs); + return diffs; + }; + + /** + * Reduce the number of edits by eliminating operationally trivial equalities. + * @param {!Array.} diffs Array of diff tuples. + */ + DiffMatchPatch.prototype.diffCleanupEfficiency = function (diffs) { + var changes, equalities, equalitiesLength, lastequality, pointer, preIns, preDel, postIns, postDel; + changes = false; + equalities = []; // Stack of indices where equalities are found. + equalitiesLength = 0; // Keeping our own length var is faster in JS. + /** @type {?string} */ + lastequality = null; + + // Always equal to diffs[equalities[equalitiesLength - 1]][1] + pointer = 0; // Index of current position. + + // Is there an insertion operation before the last equality. + preIns = false; + + // Is there a deletion operation before the last equality. + preDel = false; + + // Is there an insertion operation after the last equality. + postIns = false; + + // Is there a deletion operation after the last equality. + postDel = false; + while (pointer < diffs.length) { + + // Equality found. + if (diffs[pointer][0] === DIFF_EQUAL) { + if (diffs[pointer][1].length < 4 && (postIns || postDel)) { + + // Candidate found. + equalities[equalitiesLength++] = pointer; + preIns = postIns; + preDel = postDel; + lastequality = diffs[pointer][1]; + } else { + + // Not a candidate, and can never become one. + equalitiesLength = 0; + lastequality = null; + } + postIns = postDel = false; + + // An insertion or deletion. + } else { + + if (diffs[pointer][0] === DIFF_DELETE) { + postDel = true; + } else { + postIns = true; + } + + /* + * Five types to be split: + * ABXYCD + * AXCD + * ABXC + * AXCD + * ABXC + */ + if (lastequality && (preIns && preDel && postIns && postDel || lastequality.length < 2 && preIns + preDel + postIns + postDel === 3)) { + + // Duplicate record. + diffs.splice(equalities[equalitiesLength - 1], 0, [DIFF_DELETE, lastequality]); + + // Change second copy to insert. + diffs[equalities[equalitiesLength - 1] + 1][0] = DIFF_INSERT; + equalitiesLength--; // Throw away the equality we just deleted; + lastequality = null; + if (preIns && preDel) { + + // No changes made which could affect previous entry, keep going. + postIns = postDel = true; + equalitiesLength = 0; + } else { + equalitiesLength--; // Throw away the previous equality. + pointer = equalitiesLength > 0 ? equalities[equalitiesLength - 1] : -1; + postIns = postDel = false; + } + changes = true; + } + } + pointer++; + } + + if (changes) { + this.diffCleanupMerge(diffs); + } + }; + + /** + * Convert a diff array into a pretty HTML report. + * @param {!Array.} diffs Array of diff tuples. + * @param {integer} string to be beautified. + * @return {string} HTML representation. + */ + DiffMatchPatch.prototype.diffPrettyHtml = function (diffs) { + var op, + data, + x, + html = []; + for (x = 0; x < diffs.length; x++) { + op = diffs[x][0]; // Operation (insert, delete, equal) + data = diffs[x][1]; // Text of change. + switch (op) { + case DIFF_INSERT: + html[x] = "" + escapeText(data) + ""; + break; + case DIFF_DELETE: + html[x] = "" + escapeText(data) + ""; + break; + case DIFF_EQUAL: + html[x] = "" + escapeText(data) + ""; + break; + } + } + return html.join(""); + }; + + /** + * Determine the common prefix of two strings. + * @param {string} text1 First string. + * @param {string} text2 Second string. + * @return {number} The number of characters common to the start of each + * string. + */ + DiffMatchPatch.prototype.diffCommonPrefix = function (text1, text2) { + var pointermid, pointermax, pointermin, pointerstart; + + // Quick check for common null cases. + if (!text1 || !text2 || text1.charAt(0) !== text2.charAt(0)) { + return 0; + } + + // Binary search. + // Performance analysis: https://neil.fraser.name/news/2007/10/09/ + pointermin = 0; + pointermax = Math.min(text1.length, text2.length); + pointermid = pointermax; + pointerstart = 0; + while (pointermin < pointermid) { + if (text1.substring(pointerstart, pointermid) === text2.substring(pointerstart, pointermid)) { + pointermin = pointermid; + pointerstart = pointermin; + } else { + pointermax = pointermid; + } + pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin); + } + return pointermid; + }; + + /** + * Determine the common suffix of two strings. + * @param {string} text1 First string. + * @param {string} text2 Second string. + * @return {number} The number of characters common to the end of each string. + */ + DiffMatchPatch.prototype.diffCommonSuffix = function (text1, text2) { + var pointermid, pointermax, pointermin, pointerend; + + // Quick check for common null cases. + if (!text1 || !text2 || text1.charAt(text1.length - 1) !== text2.charAt(text2.length - 1)) { + return 0; + } + + // Binary search. + // Performance analysis: https://neil.fraser.name/news/2007/10/09/ + pointermin = 0; + pointermax = Math.min(text1.length, text2.length); + pointermid = pointermax; + pointerend = 0; + while (pointermin < pointermid) { + if (text1.substring(text1.length - pointermid, text1.length - pointerend) === text2.substring(text2.length - pointermid, text2.length - pointerend)) { + pointermin = pointermid; + pointerend = pointermin; + } else { + pointermax = pointermid; + } + pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin); + } + return pointermid; + }; + + /** + * Find the differences between two texts. Assumes that the texts do not + * have any common prefix or suffix. + * @param {string} text1 Old string to be diffed. + * @param {string} text2 New string to be diffed. + * @param {boolean} checklines Speedup flag. If false, then don't run a + * line-level diff first to identify the changed areas. + * If true, then run a faster, slightly less optimal diff. + * @param {number} deadline Time when the diff should be complete by. + * @return {!Array.} Array of diff tuples. + * @private + */ + DiffMatchPatch.prototype.diffCompute = function (text1, text2, checklines, deadline) { + var diffs, longtext, shorttext, i, hm, text1A, text2A, text1B, text2B, midCommon, diffsA, diffsB; + + if (!text1) { + + // Just add some text (speedup). + return [[DIFF_INSERT, text2]]; + } + + if (!text2) { + + // Just delete some text (speedup). + return [[DIFF_DELETE, text1]]; + } + + longtext = text1.length > text2.length ? text1 : text2; + shorttext = text1.length > text2.length ? text2 : text1; + i = longtext.indexOf(shorttext); + if (i !== -1) { + + // Shorter text is inside the longer text (speedup). + diffs = [[DIFF_INSERT, longtext.substring(0, i)], [DIFF_EQUAL, shorttext], [DIFF_INSERT, longtext.substring(i + shorttext.length)]]; + + // Swap insertions for deletions if diff is reversed. + if (text1.length > text2.length) { + diffs[0][0] = diffs[2][0] = DIFF_DELETE; + } + return diffs; + } + + if (shorttext.length === 1) { + + // Single character string. + // After the previous speedup, the character can't be an equality. + return [[DIFF_DELETE, text1], [DIFF_INSERT, text2]]; + } + + // Check to see if the problem can be split in two. + hm = this.diffHalfMatch(text1, text2); + if (hm) { + + // A half-match was found, sort out the return data. + text1A = hm[0]; + text1B = hm[1]; + text2A = hm[2]; + text2B = hm[3]; + midCommon = hm[4]; + + // Send both pairs off for separate processing. + diffsA = this.DiffMain(text1A, text2A, checklines, deadline); + diffsB = this.DiffMain(text1B, text2B, checklines, deadline); + + // Merge the results. + return diffsA.concat([[DIFF_EQUAL, midCommon]], diffsB); + } + + if (checklines && text1.length > 100 && text2.length > 100) { + return this.diffLineMode(text1, text2, deadline); + } + + return this.diffBisect(text1, text2, deadline); + }; + + /** + * Do the two texts share a substring which is at least half the length of the + * longer text? + * This speedup can produce non-minimal diffs. + * @param {string} text1 First string. + * @param {string} text2 Second string. + * @return {Array.} Five element Array, containing the prefix of + * text1, the suffix of text1, the prefix of text2, the suffix of + * text2 and the common middle. Or null if there was no match. + * @private + */ + DiffMatchPatch.prototype.diffHalfMatch = function (text1, text2) { + var longtext, shorttext, dmp, text1A, text2B, text2A, text1B, midCommon, hm1, hm2, hm; + + longtext = text1.length > text2.length ? text1 : text2; + shorttext = text1.length > text2.length ? text2 : text1; + if (longtext.length < 4 || shorttext.length * 2 < longtext.length) { + return null; // Pointless. + } + dmp = this; // 'this' becomes 'window' in a closure. + + /** + * Does a substring of shorttext exist within longtext such that the substring + * is at least half the length of longtext? + * Closure, but does not reference any external variables. + * @param {string} longtext Longer string. + * @param {string} shorttext Shorter string. + * @param {number} i Start index of quarter length substring within longtext. + * @return {Array.} Five element Array, containing the prefix of + * longtext, the suffix of longtext, the prefix of shorttext, the suffix + * of shorttext and the common middle. Or null if there was no match. + * @private + */ + function diffHalfMatchI(longtext, shorttext, i) { + var seed, j, bestCommon, prefixLength, suffixLength, bestLongtextA, bestLongtextB, bestShorttextA, bestShorttextB; + + // Start with a 1/4 length substring at position i as a seed. + seed = longtext.substring(i, i + Math.floor(longtext.length / 4)); + j = -1; + bestCommon = ""; + while ((j = shorttext.indexOf(seed, j + 1)) !== -1) { + prefixLength = dmp.diffCommonPrefix(longtext.substring(i), shorttext.substring(j)); + suffixLength = dmp.diffCommonSuffix(longtext.substring(0, i), shorttext.substring(0, j)); + if (bestCommon.length < suffixLength + prefixLength) { + bestCommon = shorttext.substring(j - suffixLength, j) + shorttext.substring(j, j + prefixLength); + bestLongtextA = longtext.substring(0, i - suffixLength); + bestLongtextB = longtext.substring(i + prefixLength); + bestShorttextA = shorttext.substring(0, j - suffixLength); + bestShorttextB = shorttext.substring(j + prefixLength); + } + } + if (bestCommon.length * 2 >= longtext.length) { + return [bestLongtextA, bestLongtextB, bestShorttextA, bestShorttextB, bestCommon]; + } else { + return null; + } + } + + // First check if the second quarter is the seed for a half-match. + hm1 = diffHalfMatchI(longtext, shorttext, Math.ceil(longtext.length / 4)); + + // Check again based on the third quarter. + hm2 = diffHalfMatchI(longtext, shorttext, Math.ceil(longtext.length / 2)); + if (!hm1 && !hm2) { + return null; + } else if (!hm2) { + hm = hm1; + } else if (!hm1) { + hm = hm2; + } else { + + // Both matched. Select the longest. + hm = hm1[4].length > hm2[4].length ? hm1 : hm2; + } + + // A half-match was found, sort out the return data. + if (text1.length > text2.length) { + text1A = hm[0]; + text1B = hm[1]; + text2A = hm[2]; + text2B = hm[3]; + } else { + text2A = hm[0]; + text2B = hm[1]; + text1A = hm[2]; + text1B = hm[3]; + } + midCommon = hm[4]; + return [text1A, text1B, text2A, text2B, midCommon]; + }; + + /** + * Do a quick line-level diff on both strings, then rediff the parts for + * greater accuracy. + * This speedup can produce non-minimal diffs. + * @param {string} text1 Old string to be diffed. + * @param {string} text2 New string to be diffed. + * @param {number} deadline Time when the diff should be complete by. + * @return {!Array.} Array of diff tuples. + * @private + */ + DiffMatchPatch.prototype.diffLineMode = function (text1, text2, deadline) { + var a, diffs, linearray, pointer, countInsert, countDelete, textInsert, textDelete, j; + + // Scan the text on a line-by-line basis first. + a = this.diffLinesToChars(text1, text2); + text1 = a.chars1; + text2 = a.chars2; + linearray = a.lineArray; + + diffs = this.DiffMain(text1, text2, false, deadline); + + // Convert the diff back to original text. + this.diffCharsToLines(diffs, linearray); + + // Eliminate freak matches (e.g. blank lines) + this.diffCleanupSemantic(diffs); + + // Rediff any replacement blocks, this time character-by-character. + // Add a dummy entry at the end. + diffs.push([DIFF_EQUAL, ""]); + pointer = 0; + countDelete = 0; + countInsert = 0; + textDelete = ""; + textInsert = ""; + while (pointer < diffs.length) { + switch (diffs[pointer][0]) { + case DIFF_INSERT: + countInsert++; + textInsert += diffs[pointer][1]; + break; + case DIFF_DELETE: + countDelete++; + textDelete += diffs[pointer][1]; + break; + case DIFF_EQUAL: + + // Upon reaching an equality, check for prior redundancies. + if (countDelete >= 1 && countInsert >= 1) { + + // Delete the offending records and add the merged ones. + diffs.splice(pointer - countDelete - countInsert, countDelete + countInsert); + pointer = pointer - countDelete - countInsert; + a = this.DiffMain(textDelete, textInsert, false, deadline); + for (j = a.length - 1; j >= 0; j--) { + diffs.splice(pointer, 0, a[j]); + } + pointer = pointer + a.length; + } + countInsert = 0; + countDelete = 0; + textDelete = ""; + textInsert = ""; + break; + } + pointer++; + } + diffs.pop(); // Remove the dummy entry at the end. + + return diffs; + }; + + /** + * Find the 'middle snake' of a diff, split the problem in two + * and return the recursively constructed diff. + * See Myers 1986 paper: An O(ND) Difference Algorithm and Its Variations. + * @param {string} text1 Old string to be diffed. + * @param {string} text2 New string to be diffed. + * @param {number} deadline Time at which to bail if not yet complete. + * @return {!Array.} Array of diff tuples. + * @private + */ + DiffMatchPatch.prototype.diffBisect = function (text1, text2, deadline) { + var text1Length, text2Length, maxD, vOffset, vLength, v1, v2, x, delta, front, k1start, k1end, k2start, k2end, k2Offset, k1Offset, x1, x2, y1, y2, d, k1, k2; + + // Cache the text lengths to prevent multiple calls. + text1Length = text1.length; + text2Length = text2.length; + maxD = Math.ceil((text1Length + text2Length) / 2); + vOffset = maxD; + vLength = 2 * maxD; + v1 = new Array(vLength); + v2 = new Array(vLength); + + // Setting all elements to -1 is faster in Chrome & Firefox than mixing + // integers and undefined. + for (x = 0; x < vLength; x++) { + v1[x] = -1; + v2[x] = -1; + } + v1[vOffset + 1] = 0; + v2[vOffset + 1] = 0; + delta = text1Length - text2Length; + + // If the total number of characters is odd, then the front path will collide + // with the reverse path. + front = delta % 2 !== 0; + + // Offsets for start and end of k loop. + // Prevents mapping of space beyond the grid. + k1start = 0; + k1end = 0; + k2start = 0; + k2end = 0; + for (d = 0; d < maxD; d++) { + + // Bail out if deadline is reached. + if (new Date().getTime() > deadline) { + break; + } + + // Walk the front path one step. + for (k1 = -d + k1start; k1 <= d - k1end; k1 += 2) { + k1Offset = vOffset + k1; + if (k1 === -d || k1 !== d && v1[k1Offset - 1] < v1[k1Offset + 1]) { + x1 = v1[k1Offset + 1]; + } else { + x1 = v1[k1Offset - 1] + 1; + } + y1 = x1 - k1; + while (x1 < text1Length && y1 < text2Length && text1.charAt(x1) === text2.charAt(y1)) { + x1++; + y1++; + } + v1[k1Offset] = x1; + if (x1 > text1Length) { + + // Ran off the right of the graph. + k1end += 2; + } else if (y1 > text2Length) { + + // Ran off the bottom of the graph. + k1start += 2; + } else if (front) { + k2Offset = vOffset + delta - k1; + if (k2Offset >= 0 && k2Offset < vLength && v2[k2Offset] !== -1) { + + // Mirror x2 onto top-left coordinate system. + x2 = text1Length - v2[k2Offset]; + if (x1 >= x2) { + + // Overlap detected. + return this.diffBisectSplit(text1, text2, x1, y1, deadline); + } + } + } + } + + // Walk the reverse path one step. + for (k2 = -d + k2start; k2 <= d - k2end; k2 += 2) { + k2Offset = vOffset + k2; + if (k2 === -d || k2 !== d && v2[k2Offset - 1] < v2[k2Offset + 1]) { + x2 = v2[k2Offset + 1]; + } else { + x2 = v2[k2Offset - 1] + 1; + } + y2 = x2 - k2; + while (x2 < text1Length && y2 < text2Length && text1.charAt(text1Length - x2 - 1) === text2.charAt(text2Length - y2 - 1)) { + x2++; + y2++; + } + v2[k2Offset] = x2; + if (x2 > text1Length) { + + // Ran off the left of the graph. + k2end += 2; + } else if (y2 > text2Length) { + + // Ran off the top of the graph. + k2start += 2; + } else if (!front) { + k1Offset = vOffset + delta - k2; + if (k1Offset >= 0 && k1Offset < vLength && v1[k1Offset] !== -1) { + x1 = v1[k1Offset]; + y1 = vOffset + x1 - k1Offset; + + // Mirror x2 onto top-left coordinate system. + x2 = text1Length - x2; + if (x1 >= x2) { + + // Overlap detected. + return this.diffBisectSplit(text1, text2, x1, y1, deadline); + } + } + } + } + } + + // Diff took too long and hit the deadline or + // number of diffs equals number of characters, no commonality at all. + return [[DIFF_DELETE, text1], [DIFF_INSERT, text2]]; + }; + + /** + * Given the location of the 'middle snake', split the diff in two parts + * and recurse. + * @param {string} text1 Old string to be diffed. + * @param {string} text2 New string to be diffed. + * @param {number} x Index of split point in text1. + * @param {number} y Index of split point in text2. + * @param {number} deadline Time at which to bail if not yet complete. + * @return {!Array.} Array of diff tuples. + * @private + */ + DiffMatchPatch.prototype.diffBisectSplit = function (text1, text2, x, y, deadline) { + var text1a, text1b, text2a, text2b, diffs, diffsb; + text1a = text1.substring(0, x); + text2a = text2.substring(0, y); + text1b = text1.substring(x); + text2b = text2.substring(y); + + // Compute both diffs serially. + diffs = this.DiffMain(text1a, text2a, false, deadline); + diffsb = this.DiffMain(text1b, text2b, false, deadline); + + return diffs.concat(diffsb); + }; + + /** + * Reduce the number of edits by eliminating semantically trivial equalities. + * @param {!Array.} diffs Array of diff tuples. + */ + DiffMatchPatch.prototype.diffCleanupSemantic = function (diffs) { + var changes, equalities, equalitiesLength, lastequality, pointer, lengthInsertions2, lengthDeletions2, lengthInsertions1, lengthDeletions1, deletion, insertion, overlapLength1, overlapLength2; + changes = false; + equalities = []; // Stack of indices where equalities are found. + equalitiesLength = 0; // Keeping our own length var is faster in JS. + /** @type {?string} */ + lastequality = null; + + // Always equal to diffs[equalities[equalitiesLength - 1]][1] + pointer = 0; // Index of current position. + + // Number of characters that changed prior to the equality. + lengthInsertions1 = 0; + lengthDeletions1 = 0; + + // Number of characters that changed after the equality. + lengthInsertions2 = 0; + lengthDeletions2 = 0; + while (pointer < diffs.length) { + if (diffs[pointer][0] === DIFF_EQUAL) { + // Equality found. + equalities[equalitiesLength++] = pointer; + lengthInsertions1 = lengthInsertions2; + lengthDeletions1 = lengthDeletions2; + lengthInsertions2 = 0; + lengthDeletions2 = 0; + lastequality = diffs[pointer][1]; + } else { + // An insertion or deletion. + if (diffs[pointer][0] === DIFF_INSERT) { + lengthInsertions2 += diffs[pointer][1].length; + } else { + lengthDeletions2 += diffs[pointer][1].length; + } + + // Eliminate an equality that is smaller or equal to the edits on both + // sides of it. + if (lastequality && lastequality.length <= Math.max(lengthInsertions1, lengthDeletions1) && lastequality.length <= Math.max(lengthInsertions2, lengthDeletions2)) { + + // Duplicate record. + diffs.splice(equalities[equalitiesLength - 1], 0, [DIFF_DELETE, lastequality]); + + // Change second copy to insert. + diffs[equalities[equalitiesLength - 1] + 1][0] = DIFF_INSERT; + + // Throw away the equality we just deleted. + equalitiesLength--; + + // Throw away the previous equality (it needs to be reevaluated). + equalitiesLength--; + pointer = equalitiesLength > 0 ? equalities[equalitiesLength - 1] : -1; + + // Reset the counters. + lengthInsertions1 = 0; + lengthDeletions1 = 0; + lengthInsertions2 = 0; + lengthDeletions2 = 0; + lastequality = null; + changes = true; + } + } + pointer++; + } + + // Normalize the diff. + if (changes) { + this.diffCleanupMerge(diffs); + } + + // Find any overlaps between deletions and insertions. + // e.g: abcxxxxxxdef + // -> abcxxxdef + // e.g: xxxabcdefxxx + // -> defxxxabc + // Only extract an overlap if it is as big as the edit ahead or behind it. + pointer = 1; + while (pointer < diffs.length) { + if (diffs[pointer - 1][0] === DIFF_DELETE && diffs[pointer][0] === DIFF_INSERT) { + deletion = diffs[pointer - 1][1]; + insertion = diffs[pointer][1]; + overlapLength1 = this.diffCommonOverlap(deletion, insertion); + overlapLength2 = this.diffCommonOverlap(insertion, deletion); + if (overlapLength1 >= overlapLength2) { + if (overlapLength1 >= deletion.length / 2 || overlapLength1 >= insertion.length / 2) { + + // Overlap found. Insert an equality and trim the surrounding edits. + diffs.splice(pointer, 0, [DIFF_EQUAL, insertion.substring(0, overlapLength1)]); + diffs[pointer - 1][1] = deletion.substring(0, deletion.length - overlapLength1); + diffs[pointer + 1][1] = insertion.substring(overlapLength1); + pointer++; + } + } else { + if (overlapLength2 >= deletion.length / 2 || overlapLength2 >= insertion.length / 2) { + + // Reverse overlap found. + // Insert an equality and swap and trim the surrounding edits. + diffs.splice(pointer, 0, [DIFF_EQUAL, deletion.substring(0, overlapLength2)]); + + diffs[pointer - 1][0] = DIFF_INSERT; + diffs[pointer - 1][1] = insertion.substring(0, insertion.length - overlapLength2); + diffs[pointer + 1][0] = DIFF_DELETE; + diffs[pointer + 1][1] = deletion.substring(overlapLength2); + pointer++; + } + } + pointer++; + } + pointer++; + } + }; + + /** + * Determine if the suffix of one string is the prefix of another. + * @param {string} text1 First string. + * @param {string} text2 Second string. + * @return {number} The number of characters common to the end of the first + * string and the start of the second string. + * @private + */ + DiffMatchPatch.prototype.diffCommonOverlap = function (text1, text2) { + var text1Length, text2Length, textLength, best, length, pattern, found; + + // Cache the text lengths to prevent multiple calls. + text1Length = text1.length; + text2Length = text2.length; + + // Eliminate the null case. + if (text1Length === 0 || text2Length === 0) { + return 0; + } + + // Truncate the longer string. + if (text1Length > text2Length) { + text1 = text1.substring(text1Length - text2Length); + } else if (text1Length < text2Length) { + text2 = text2.substring(0, text1Length); + } + textLength = Math.min(text1Length, text2Length); + + // Quick check for the worst case. + if (text1 === text2) { + return textLength; + } + + // Start by looking for a single character match + // and increase length until no match is found. + // Performance analysis: https://neil.fraser.name/news/2010/11/04/ + best = 0; + length = 1; + while (true) { + pattern = text1.substring(textLength - length); + found = text2.indexOf(pattern); + if (found === -1) { + return best; + } + length += found; + if (found === 0 || text1.substring(textLength - length) === text2.substring(0, length)) { + best = length; + length++; + } + } + }; + + /** + * Split two texts into an array of strings. Reduce the texts to a string of + * hashes where each Unicode character represents one line. + * @param {string} text1 First string. + * @param {string} text2 Second string. + * @return {{chars1: string, chars2: string, lineArray: !Array.}} + * An object containing the encoded text1, the encoded text2 and + * the array of unique strings. + * The zeroth element of the array of unique strings is intentionally blank. + * @private + */ + DiffMatchPatch.prototype.diffLinesToChars = function (text1, text2) { + var lineArray, lineHash, chars1, chars2; + lineArray = []; // E.g. lineArray[4] === 'Hello\n' + lineHash = {}; // E.g. lineHash['Hello\n'] === 4 + + // '\x00' is a valid character, but various debuggers don't like it. + // So we'll insert a junk entry to avoid generating a null character. + lineArray[0] = ""; + + /** + * Split a text into an array of strings. Reduce the texts to a string of + * hashes where each Unicode character represents one line. + * Modifies linearray and linehash through being a closure. + * @param {string} text String to encode. + * @return {string} Encoded string. + * @private + */ + function diffLinesToCharsMunge(text) { + var chars, lineStart, lineEnd, lineArrayLength, line; + chars = ""; + + // Walk the text, pulling out a substring for each line. + // text.split('\n') would would temporarily double our memory footprint. + // Modifying text would create many large strings to garbage collect. + lineStart = 0; + lineEnd = -1; + + // Keeping our own length variable is faster than looking it up. + lineArrayLength = lineArray.length; + while (lineEnd < text.length - 1) { + lineEnd = text.indexOf("\n", lineStart); + if (lineEnd === -1) { + lineEnd = text.length - 1; + } + line = text.substring(lineStart, lineEnd + 1); + lineStart = lineEnd + 1; + + if (lineHash.hasOwnProperty ? lineHash.hasOwnProperty(line) : lineHash[line] !== undefined) { + chars += String.fromCharCode(lineHash[line]); + } else { + chars += String.fromCharCode(lineArrayLength); + lineHash[line] = lineArrayLength; + lineArray[lineArrayLength++] = line; + } + } + return chars; + } + + chars1 = diffLinesToCharsMunge(text1); + chars2 = diffLinesToCharsMunge(text2); + return { + chars1: chars1, + chars2: chars2, + lineArray: lineArray + }; + }; + + /** + * Rehydrate the text in a diff from a string of line hashes to real lines of + * text. + * @param {!Array.} diffs Array of diff tuples. + * @param {!Array.} lineArray Array of unique strings. + * @private + */ + DiffMatchPatch.prototype.diffCharsToLines = function (diffs, lineArray) { + var x, chars, text, y; + for (x = 0; x < diffs.length; x++) { + chars = diffs[x][1]; + text = []; + for (y = 0; y < chars.length; y++) { + text[y] = lineArray[chars.charCodeAt(y)]; + } + diffs[x][1] = text.join(""); + } + }; + + /** + * Reorder and merge like edit sections. Merge equalities. + * Any edit section can move as long as it doesn't cross an equality. + * @param {!Array.} diffs Array of diff tuples. + */ + DiffMatchPatch.prototype.diffCleanupMerge = function (diffs) { + var pointer, countDelete, countInsert, textInsert, textDelete, commonlength, changes, diffPointer, position; + diffs.push([DIFF_EQUAL, ""]); // Add a dummy entry at the end. + pointer = 0; + countDelete = 0; + countInsert = 0; + textDelete = ""; + textInsert = ""; + + while (pointer < diffs.length) { + switch (diffs[pointer][0]) { + case DIFF_INSERT: + countInsert++; + textInsert += diffs[pointer][1]; + pointer++; + break; + case DIFF_DELETE: + countDelete++; + textDelete += diffs[pointer][1]; + pointer++; + break; + case DIFF_EQUAL: + + // Upon reaching an equality, check for prior redundancies. + if (countDelete + countInsert > 1) { + if (countDelete !== 0 && countInsert !== 0) { + + // Factor out any common prefixes. + commonlength = this.diffCommonPrefix(textInsert, textDelete); + if (commonlength !== 0) { + if (pointer - countDelete - countInsert > 0 && diffs[pointer - countDelete - countInsert - 1][0] === DIFF_EQUAL) { + diffs[pointer - countDelete - countInsert - 1][1] += textInsert.substring(0, commonlength); + } else { + diffs.splice(0, 0, [DIFF_EQUAL, textInsert.substring(0, commonlength)]); + pointer++; + } + textInsert = textInsert.substring(commonlength); + textDelete = textDelete.substring(commonlength); + } + + // Factor out any common suffixies. + commonlength = this.diffCommonSuffix(textInsert, textDelete); + if (commonlength !== 0) { + diffs[pointer][1] = textInsert.substring(textInsert.length - commonlength) + diffs[pointer][1]; + textInsert = textInsert.substring(0, textInsert.length - commonlength); + textDelete = textDelete.substring(0, textDelete.length - commonlength); + } + } + + // Delete the offending records and add the merged ones. + if (countDelete === 0) { + diffs.splice(pointer - countInsert, countDelete + countInsert, [DIFF_INSERT, textInsert]); + } else if (countInsert === 0) { + diffs.splice(pointer - countDelete, countDelete + countInsert, [DIFF_DELETE, textDelete]); + } else { + diffs.splice(pointer - countDelete - countInsert, countDelete + countInsert, [DIFF_DELETE, textDelete], [DIFF_INSERT, textInsert]); + } + pointer = pointer - countDelete - countInsert + (countDelete ? 1 : 0) + (countInsert ? 1 : 0) + 1; + } else if (pointer !== 0 && diffs[pointer - 1][0] === DIFF_EQUAL) { + + // Merge this equality with the previous one. + diffs[pointer - 1][1] += diffs[pointer][1]; + diffs.splice(pointer, 1); + } else { + pointer++; + } + countInsert = 0; + countDelete = 0; + textDelete = ""; + textInsert = ""; + break; + } + } + if (diffs[diffs.length - 1][1] === "") { + diffs.pop(); // Remove the dummy entry at the end. + } + + // Second pass: look for single edits surrounded on both sides by equalities + // which can be shifted sideways to eliminate an equality. + // e.g: ABAC -> ABAC + changes = false; + pointer = 1; + + // Intentionally ignore the first and last element (don't need checking). + while (pointer < diffs.length - 1) { + if (diffs[pointer - 1][0] === DIFF_EQUAL && diffs[pointer + 1][0] === DIFF_EQUAL) { + + diffPointer = diffs[pointer][1]; + position = diffPointer.substring(diffPointer.length - diffs[pointer - 1][1].length); + + // This is a single edit surrounded by equalities. + if (position === diffs[pointer - 1][1]) { + + // Shift the edit over the previous equality. + diffs[pointer][1] = diffs[pointer - 1][1] + diffs[pointer][1].substring(0, diffs[pointer][1].length - diffs[pointer - 1][1].length); + diffs[pointer + 1][1] = diffs[pointer - 1][1] + diffs[pointer + 1][1]; + diffs.splice(pointer - 1, 1); + changes = true; + } else if (diffPointer.substring(0, diffs[pointer + 1][1].length) === diffs[pointer + 1][1]) { + + // Shift the edit over the next equality. + diffs[pointer - 1][1] += diffs[pointer + 1][1]; + diffs[pointer][1] = diffs[pointer][1].substring(diffs[pointer + 1][1].length) + diffs[pointer + 1][1]; + diffs.splice(pointer + 1, 1); + changes = true; + } + } + pointer++; + } + + // If shifts were made, the diff needs reordering and another shift sweep. + if (changes) { + this.diffCleanupMerge(diffs); + } + }; + + return function (o, n) { + var diff, output, text; + diff = new DiffMatchPatch(); + output = diff.DiffMain(o, n); + diff.diffCleanupEfficiency(output); + text = diff.diffPrettyHtml(output); + + return text; + }; + }(); + + (function () { + + // Only interact with URLs via window.location + var location = typeof window !== "undefined" && window.location; + if (!location) { + return; + } + + var urlParams = getUrlParams(); + + QUnit.urlParams = urlParams; + + // Match module/test by inclusion in an array + QUnit.config.moduleId = [].concat(urlParams.moduleId || []); + QUnit.config.testId = [].concat(urlParams.testId || []); + + // Exact case-insensitive match of the module name + QUnit.config.module = urlParams.module; + + // Regular expression or case-insenstive substring match against "moduleName: testName" + QUnit.config.filter = urlParams.filter; + + // Test order randomization + if (urlParams.seed === true) { + + // Generate a random seed if the option is specified without a value + QUnit.config.seed = Math.random().toString(36).slice(2); + } else if (urlParams.seed) { + QUnit.config.seed = urlParams.seed; + } + + // Add URL-parameter-mapped config values with UI form rendering data + QUnit.config.urlConfig.push({ + id: "hidepassed", + label: "Hide passed tests", + tooltip: "Only show tests and assertions that fail. Stored as query-strings." + }, { + id: "noglobals", + label: "Check for Globals", + tooltip: "Enabling this will test if any test introduces new properties on the " + "global object (`window` in Browsers). Stored as query-strings." + }, { + id: "notrycatch", + label: "No try-catch", + tooltip: "Enabling this will run tests outside of a try-catch block. Makes debugging " + "exceptions in IE reasonable. Stored as query-strings." + }); + + QUnit.begin(function () { + var i, + option, + urlConfig = QUnit.config.urlConfig; + + for (i = 0; i < urlConfig.length; i++) { + + // Options can be either strings or objects with nonempty "id" properties + option = QUnit.config.urlConfig[i]; + if (typeof option !== "string") { + option = option.id; + } + + if (QUnit.config[option] === undefined) { + QUnit.config[option] = urlParams[option]; + } + } + }); + + function getUrlParams() { + var i, param, name, value; + var urlParams = Object.create(null); + var params = location.search.slice(1).split("&"); + var length = params.length; + + for (i = 0; i < length; i++) { + if (params[i]) { + param = params[i].split("="); + name = decodeQueryParam(param[0]); + + // Allow just a key to turn on a flag, e.g., test.html?noglobals + value = param.length === 1 || decodeQueryParam(param.slice(1).join("=")); + if (name in urlParams) { + urlParams[name] = [].concat(urlParams[name], value); + } else { + urlParams[name] = value; + } + } + } + + return urlParams; + } + + function decodeQueryParam(param) { + return decodeURIComponent(param.replace(/\+/g, "%20")); + } + })(); + +}((function() { return this; }()))); diff --git a/node_modules/seedrandom/test/lib/require.js b/node_modules/seedrandom/test/lib/require.js new file mode 100644 index 0000000..4db1424 --- /dev/null +++ b/node_modules/seedrandom/test/lib/require.js @@ -0,0 +1,2142 @@ +/** vim: et:ts=4:sw=4:sts=4 + * @license RequireJS 2.3.2 Copyright jQuery Foundation and other contributors. + * Released under MIT license, https://github.com/requirejs/requirejs/blob/master/LICENSE + */ +//Not using strict: uneven strict support in browsers, #392, and causes +//problems with requirejs.exec()/transpiler plugins that may not be strict. +/*jslint regexp: true, nomen: true, sloppy: true */ +/*global window, navigator, document, importScripts, setTimeout, opera */ + +var requirejs, require, define; +(function (global, setTimeout) { + var req, s, head, baseElement, dataMain, src, + interactiveScript, currentlyAddingScript, mainScript, subPath, + version = '2.3.2', + commentRegExp = /\/\*[\s\S]*?\*\/|([^:"'=]|^)\/\/.*$/mg, + cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g, + jsSuffixRegExp = /\.js$/, + currDirRegExp = /^\.\//, + op = Object.prototype, + ostring = op.toString, + hasOwn = op.hasOwnProperty, + isBrowser = !!(typeof window !== 'undefined' && typeof navigator !== 'undefined' && window.document), + isWebWorker = !isBrowser && typeof importScripts !== 'undefined', + //PS3 indicates loaded and complete, but need to wait for complete + //specifically. Sequence is 'loading', 'loaded', execution, + // then 'complete'. The UA check is unfortunate, but not sure how + //to feature test w/o causing perf issues. + readyRegExp = isBrowser && navigator.platform === 'PLAYSTATION 3' ? + /^complete$/ : /^(complete|loaded)$/, + defContextName = '_', + //Oh the tragedy, detecting opera. See the usage of isOpera for reason. + isOpera = typeof opera !== 'undefined' && opera.toString() === '[object Opera]', + contexts = {}, + cfg = {}, + globalDefQueue = [], + useInteractive = false; + + //Could match something like ')//comment', do not lose the prefix to comment. + function commentReplace(match, singlePrefix) { + return singlePrefix || ''; + } + + function isFunction(it) { + return ostring.call(it) === '[object Function]'; + } + + function isArray(it) { + return ostring.call(it) === '[object Array]'; + } + + /** + * Helper function for iterating over an array. If the func returns + * a true value, it will break out of the loop. + */ + function each(ary, func) { + if (ary) { + var i; + for (i = 0; i < ary.length; i += 1) { + if (ary[i] && func(ary[i], i, ary)) { + break; + } + } + } + } + + /** + * Helper function for iterating over an array backwards. If the func + * returns a true value, it will break out of the loop. + */ + function eachReverse(ary, func) { + if (ary) { + var i; + for (i = ary.length - 1; i > -1; i -= 1) { + if (ary[i] && func(ary[i], i, ary)) { + break; + } + } + } + } + + function hasProp(obj, prop) { + return hasOwn.call(obj, prop); + } + + function getOwn(obj, prop) { + return hasProp(obj, prop) && obj[prop]; + } + + /** + * Cycles over properties in an object and calls a function for each + * property value. If the function returns a truthy value, then the + * iteration is stopped. + */ + function eachProp(obj, func) { + var prop; + for (prop in obj) { + if (hasProp(obj, prop)) { + if (func(obj[prop], prop)) { + break; + } + } + } + } + + /** + * Simple function to mix in properties from source into target, + * but only if target does not already have a property of the same name. + */ + function mixin(target, source, force, deepStringMixin) { + if (source) { + eachProp(source, function (value, prop) { + if (force || !hasProp(target, prop)) { + if (deepStringMixin && typeof value === 'object' && value && + !isArray(value) && !isFunction(value) && + !(value instanceof RegExp)) { + + if (!target[prop]) { + target[prop] = {}; + } + mixin(target[prop], value, force, deepStringMixin); + } else { + target[prop] = value; + } + } + }); + } + return target; + } + + //Similar to Function.prototype.bind, but the 'this' object is specified + //first, since it is easier to read/figure out what 'this' will be. + function bind(obj, fn) { + return function () { + return fn.apply(obj, arguments); + }; + } + + function scripts() { + return document.getElementsByTagName('script'); + } + + function defaultOnError(err) { + throw err; + } + + //Allow getting a global that is expressed in + //dot notation, like 'a.b.c'. + function getGlobal(value) { + if (!value) { + return value; + } + var g = global; + each(value.split('.'), function (part) { + g = g[part]; + }); + return g; + } + + /** + * Constructs an error with a pointer to an URL with more information. + * @param {String} id the error ID that maps to an ID on a web page. + * @param {String} message human readable error. + * @param {Error} [err] the original error, if there is one. + * + * @returns {Error} + */ + function makeError(id, msg, err, requireModules) { + var e = new Error(msg + '\nhttp://requirejs.org/docs/errors.html#' + id); + e.requireType = id; + e.requireModules = requireModules; + if (err) { + e.originalError = err; + } + return e; + } + + if (typeof define !== 'undefined') { + //If a define is already in play via another AMD loader, + //do not overwrite. + return; + } + + if (typeof requirejs !== 'undefined') { + if (isFunction(requirejs)) { + //Do not overwrite an existing requirejs instance. + return; + } + cfg = requirejs; + requirejs = undefined; + } + + //Allow for a require config object + if (typeof require !== 'undefined' && !isFunction(require)) { + //assume it is a config object. + cfg = require; + require = undefined; + } + + function newContext(contextName) { + var inCheckLoaded, Module, context, handlers, + checkLoadedTimeoutId, + config = { + //Defaults. Do not set a default for map + //config to speed up normalize(), which + //will run faster if there is no default. + waitSeconds: 7, + baseUrl: './', + paths: {}, + bundles: {}, + pkgs: {}, + shim: {}, + config: {} + }, + registry = {}, + //registry of just enabled modules, to speed + //cycle breaking code when lots of modules + //are registered, but not activated. + enabledRegistry = {}, + undefEvents = {}, + defQueue = [], + defined = {}, + urlFetched = {}, + bundlesMap = {}, + requireCounter = 1, + unnormalizedCounter = 1; + + /** + * Trims the . and .. from an array of path segments. + * It will keep a leading path segment if a .. will become + * the first path segment, to help with module name lookups, + * which act like paths, but can be remapped. But the end result, + * all paths that use this function should look normalized. + * NOTE: this method MODIFIES the input array. + * @param {Array} ary the array of path segments. + */ + function trimDots(ary) { + var i, part; + for (i = 0; i < ary.length; i++) { + part = ary[i]; + if (part === '.') { + ary.splice(i, 1); + i -= 1; + } else if (part === '..') { + // If at the start, or previous value is still .., + // keep them so that when converted to a path it may + // still work when converted to a path, even though + // as an ID it is less than ideal. In larger point + // releases, may be better to just kick out an error. + if (i === 0 || (i === 1 && ary[2] === '..') || ary[i - 1] === '..') { + continue; + } else if (i > 0) { + ary.splice(i - 1, 2); + i -= 2; + } + } + } + } + + /** + * Given a relative module name, like ./something, normalize it to + * a real name that can be mapped to a path. + * @param {String} name the relative name + * @param {String} baseName a real name that the name arg is relative + * to. + * @param {Boolean} applyMap apply the map config to the value. Should + * only be done if this normalization is for a dependency ID. + * @returns {String} normalized name + */ + function normalize(name, baseName, applyMap) { + var pkgMain, mapValue, nameParts, i, j, nameSegment, lastIndex, + foundMap, foundI, foundStarMap, starI, normalizedBaseParts, + baseParts = (baseName && baseName.split('/')), + map = config.map, + starMap = map && map['*']; + + //Adjust any relative paths. + if (name) { + name = name.split('/'); + lastIndex = name.length - 1; + + // If wanting node ID compatibility, strip .js from end + // of IDs. Have to do this here, and not in nameToUrl + // because node allows either .js or non .js to map + // to same file. + if (config.nodeIdCompat && jsSuffixRegExp.test(name[lastIndex])) { + name[lastIndex] = name[lastIndex].replace(jsSuffixRegExp, ''); + } + + // Starts with a '.' so need the baseName + if (name[0].charAt(0) === '.' && baseParts) { + //Convert baseName to array, and lop off the last part, + //so that . matches that 'directory' and not name of the baseName's + //module. For instance, baseName of 'one/two/three', maps to + //'one/two/three.js', but we want the directory, 'one/two' for + //this normalization. + normalizedBaseParts = baseParts.slice(0, baseParts.length - 1); + name = normalizedBaseParts.concat(name); + } + + trimDots(name); + name = name.join('/'); + } + + //Apply map config if available. + if (applyMap && map && (baseParts || starMap)) { + nameParts = name.split('/'); + + outerLoop: for (i = nameParts.length; i > 0; i -= 1) { + nameSegment = nameParts.slice(0, i).join('/'); + + if (baseParts) { + //Find the longest baseName segment match in the config. + //So, do joins on the biggest to smallest lengths of baseParts. + for (j = baseParts.length; j > 0; j -= 1) { + mapValue = getOwn(map, baseParts.slice(0, j).join('/')); + + //baseName segment has config, find if it has one for + //this name. + if (mapValue) { + mapValue = getOwn(mapValue, nameSegment); + if (mapValue) { + //Match, update name to the new value. + foundMap = mapValue; + foundI = i; + break outerLoop; + } + } + } + } + + //Check for a star map match, but just hold on to it, + //if there is a shorter segment match later in a matching + //config, then favor over this star map. + if (!foundStarMap && starMap && getOwn(starMap, nameSegment)) { + foundStarMap = getOwn(starMap, nameSegment); + starI = i; + } + } + + if (!foundMap && foundStarMap) { + foundMap = foundStarMap; + foundI = starI; + } + + if (foundMap) { + nameParts.splice(0, foundI, foundMap); + name = nameParts.join('/'); + } + } + + // If the name points to a package's name, use + // the package main instead. + pkgMain = getOwn(config.pkgs, name); + + return pkgMain ? pkgMain : name; + } + + function removeScript(name) { + if (isBrowser) { + each(scripts(), function (scriptNode) { + if (scriptNode.getAttribute('data-requiremodule') === name && + scriptNode.getAttribute('data-requirecontext') === context.contextName) { + scriptNode.parentNode.removeChild(scriptNode); + return true; + } + }); + } + } + + function hasPathFallback(id) { + var pathConfig = getOwn(config.paths, id); + if (pathConfig && isArray(pathConfig) && pathConfig.length > 1) { + //Pop off the first array value, since it failed, and + //retry + pathConfig.shift(); + context.require.undef(id); + + //Custom require that does not do map translation, since + //ID is "absolute", already mapped/resolved. + context.makeRequire(null, { + skipMap: true + })([id]); + + return true; + } + } + + //Turns a plugin!resource to [plugin, resource] + //with the plugin being undefined if the name + //did not have a plugin prefix. + function splitPrefix(name) { + var prefix, + index = name ? name.indexOf('!') : -1; + if (index > -1) { + prefix = name.substring(0, index); + name = name.substring(index + 1, name.length); + } + return [prefix, name]; + } + + /** + * Creates a module mapping that includes plugin prefix, module + * name, and path. If parentModuleMap is provided it will + * also normalize the name via require.normalize() + * + * @param {String} name the module name + * @param {String} [parentModuleMap] parent module map + * for the module name, used to resolve relative names. + * @param {Boolean} isNormalized: is the ID already normalized. + * This is true if this call is done for a define() module ID. + * @param {Boolean} applyMap: apply the map config to the ID. + * Should only be true if this map is for a dependency. + * + * @returns {Object} + */ + function makeModuleMap(name, parentModuleMap, isNormalized, applyMap) { + var url, pluginModule, suffix, nameParts, + prefix = null, + parentName = parentModuleMap ? parentModuleMap.name : null, + originalName = name, + isDefine = true, + normalizedName = ''; + + //If no name, then it means it is a require call, generate an + //internal name. + if (!name) { + isDefine = false; + name = '_@r' + (requireCounter += 1); + } + + nameParts = splitPrefix(name); + prefix = nameParts[0]; + name = nameParts[1]; + + if (prefix) { + prefix = normalize(prefix, parentName, applyMap); + pluginModule = getOwn(defined, prefix); + } + + //Account for relative paths if there is a base name. + if (name) { + if (prefix) { + if (pluginModule && pluginModule.normalize) { + //Plugin is loaded, use its normalize method. + normalizedName = pluginModule.normalize(name, function (name) { + return normalize(name, parentName, applyMap); + }); + } else { + // If nested plugin references, then do not try to + // normalize, as it will not normalize correctly. This + // places a restriction on resourceIds, and the longer + // term solution is not to normalize until plugins are + // loaded and all normalizations to allow for async + // loading of a loader plugin. But for now, fixes the + // common uses. Details in #1131 + normalizedName = name.indexOf('!') === -1 ? + normalize(name, parentName, applyMap) : + name; + } + } else { + //A regular module. + normalizedName = normalize(name, parentName, applyMap); + + //Normalized name may be a plugin ID due to map config + //application in normalize. The map config values must + //already be normalized, so do not need to redo that part. + nameParts = splitPrefix(normalizedName); + prefix = nameParts[0]; + normalizedName = nameParts[1]; + isNormalized = true; + + url = context.nameToUrl(normalizedName); + } + } + + //If the id is a plugin id that cannot be determined if it needs + //normalization, stamp it with a unique ID so two matching relative + //ids that may conflict can be separate. + suffix = prefix && !pluginModule && !isNormalized ? + '_unnormalized' + (unnormalizedCounter += 1) : + ''; + + return { + prefix: prefix, + name: normalizedName, + parentMap: parentModuleMap, + unnormalized: !!suffix, + url: url, + originalName: originalName, + isDefine: isDefine, + id: (prefix ? + prefix + '!' + normalizedName : + normalizedName) + suffix + }; + } + + function getModule(depMap) { + var id = depMap.id, + mod = getOwn(registry, id); + + if (!mod) { + mod = registry[id] = new context.Module(depMap); + } + + return mod; + } + + function on(depMap, name, fn) { + var id = depMap.id, + mod = getOwn(registry, id); + + if (hasProp(defined, id) && + (!mod || mod.defineEmitComplete)) { + if (name === 'defined') { + fn(defined[id]); + } + } else { + mod = getModule(depMap); + if (mod.error && name === 'error') { + fn(mod.error); + } else { + mod.on(name, fn); + } + } + } + + function onError(err, errback) { + var ids = err.requireModules, + notified = false; + + if (errback) { + errback(err); + } else { + each(ids, function (id) { + var mod = getOwn(registry, id); + if (mod) { + //Set error on module, so it skips timeout checks. + mod.error = err; + if (mod.events.error) { + notified = true; + mod.emit('error', err); + } + } + }); + + if (!notified) { + req.onError(err); + } + } + } + + /** + * Internal method to transfer globalQueue items to this context's + * defQueue. + */ + function takeGlobalQueue() { + //Push all the globalDefQueue items into the context's defQueue + if (globalDefQueue.length) { + each(globalDefQueue, function(queueItem) { + var id = queueItem[0]; + if (typeof id === 'string') { + context.defQueueMap[id] = true; + } + defQueue.push(queueItem); + }); + globalDefQueue = []; + } + } + + handlers = { + 'require': function (mod) { + if (mod.require) { + return mod.require; + } else { + return (mod.require = context.makeRequire(mod.map)); + } + }, + 'exports': function (mod) { + mod.usingExports = true; + if (mod.map.isDefine) { + if (mod.exports) { + return (defined[mod.map.id] = mod.exports); + } else { + return (mod.exports = defined[mod.map.id] = {}); + } + } + }, + 'module': function (mod) { + if (mod.module) { + return mod.module; + } else { + return (mod.module = { + id: mod.map.id, + uri: mod.map.url, + config: function () { + return getOwn(config.config, mod.map.id) || {}; + }, + exports: mod.exports || (mod.exports = {}) + }); + } + } + }; + + function cleanRegistry(id) { + //Clean up machinery used for waiting modules. + delete registry[id]; + delete enabledRegistry[id]; + } + + function breakCycle(mod, traced, processed) { + var id = mod.map.id; + + if (mod.error) { + mod.emit('error', mod.error); + } else { + traced[id] = true; + each(mod.depMaps, function (depMap, i) { + var depId = depMap.id, + dep = getOwn(registry, depId); + + //Only force things that have not completed + //being defined, so still in the registry, + //and only if it has not been matched up + //in the module already. + if (dep && !mod.depMatched[i] && !processed[depId]) { + if (getOwn(traced, depId)) { + mod.defineDep(i, defined[depId]); + mod.check(); //pass false? + } else { + breakCycle(dep, traced, processed); + } + } + }); + processed[id] = true; + } + } + + function checkLoaded() { + var err, usingPathFallback, + waitInterval = config.waitSeconds * 1000, + //It is possible to disable the wait interval by using waitSeconds of 0. + expired = waitInterval && (context.startTime + waitInterval) < new Date().getTime(), + noLoads = [], + reqCalls = [], + stillLoading = false, + needCycleCheck = true; + + //Do not bother if this call was a result of a cycle break. + if (inCheckLoaded) { + return; + } + + inCheckLoaded = true; + + //Figure out the state of all the modules. + eachProp(enabledRegistry, function (mod) { + var map = mod.map, + modId = map.id; + + //Skip things that are not enabled or in error state. + if (!mod.enabled) { + return; + } + + if (!map.isDefine) { + reqCalls.push(mod); + } + + if (!mod.error) { + //If the module should be executed, and it has not + //been inited and time is up, remember it. + if (!mod.inited && expired) { + if (hasPathFallback(modId)) { + usingPathFallback = true; + stillLoading = true; + } else { + noLoads.push(modId); + removeScript(modId); + } + } else if (!mod.inited && mod.fetched && map.isDefine) { + stillLoading = true; + if (!map.prefix) { + //No reason to keep looking for unfinished + //loading. If the only stillLoading is a + //plugin resource though, keep going, + //because it may be that a plugin resource + //is waiting on a non-plugin cycle. + return (needCycleCheck = false); + } + } + } + }); + + if (expired && noLoads.length) { + //If wait time expired, throw error of unloaded modules. + err = makeError('timeout', 'Load timeout for modules: ' + noLoads, null, noLoads); + err.contextName = context.contextName; + return onError(err); + } + + //Not expired, check for a cycle. + if (needCycleCheck) { + each(reqCalls, function (mod) { + breakCycle(mod, {}, {}); + }); + } + + //If still waiting on loads, and the waiting load is something + //other than a plugin resource, or there are still outstanding + //scripts, then just try back later. + if ((!expired || usingPathFallback) && stillLoading) { + //Something is still waiting to load. Wait for it, but only + //if a timeout is not already in effect. + if ((isBrowser || isWebWorker) && !checkLoadedTimeoutId) { + checkLoadedTimeoutId = setTimeout(function () { + checkLoadedTimeoutId = 0; + checkLoaded(); + }, 50); + } + } + + inCheckLoaded = false; + } + + Module = function (map) { + this.events = getOwn(undefEvents, map.id) || {}; + this.map = map; + this.shim = getOwn(config.shim, map.id); + this.depExports = []; + this.depMaps = []; + this.depMatched = []; + this.pluginMaps = {}; + this.depCount = 0; + + /* this.exports this.factory + this.depMaps = [], + this.enabled, this.fetched + */ + }; + + Module.prototype = { + init: function (depMaps, factory, errback, options) { + options = options || {}; + + //Do not do more inits if already done. Can happen if there + //are multiple define calls for the same module. That is not + //a normal, common case, but it is also not unexpected. + if (this.inited) { + return; + } + + this.factory = factory; + + if (errback) { + //Register for errors on this module. + this.on('error', errback); + } else if (this.events.error) { + //If no errback already, but there are error listeners + //on this module, set up an errback to pass to the deps. + errback = bind(this, function (err) { + this.emit('error', err); + }); + } + + //Do a copy of the dependency array, so that + //source inputs are not modified. For example + //"shim" deps are passed in here directly, and + //doing a direct modification of the depMaps array + //would affect that config. + this.depMaps = depMaps && depMaps.slice(0); + + this.errback = errback; + + //Indicate this module has be initialized + this.inited = true; + + this.ignore = options.ignore; + + //Could have option to init this module in enabled mode, + //or could have been previously marked as enabled. However, + //the dependencies are not known until init is called. So + //if enabled previously, now trigger dependencies as enabled. + if (options.enabled || this.enabled) { + //Enable this module and dependencies. + //Will call this.check() + this.enable(); + } else { + this.check(); + } + }, + + defineDep: function (i, depExports) { + //Because of cycles, defined callback for a given + //export can be called more than once. + if (!this.depMatched[i]) { + this.depMatched[i] = true; + this.depCount -= 1; + this.depExports[i] = depExports; + } + }, + + fetch: function () { + if (this.fetched) { + return; + } + this.fetched = true; + + context.startTime = (new Date()).getTime(); + + var map = this.map; + + //If the manager is for a plugin managed resource, + //ask the plugin to load it now. + if (this.shim) { + context.makeRequire(this.map, { + enableBuildCallback: true + })(this.shim.deps || [], bind(this, function () { + return map.prefix ? this.callPlugin() : this.load(); + })); + } else { + //Regular dependency. + return map.prefix ? this.callPlugin() : this.load(); + } + }, + + load: function () { + var url = this.map.url; + + //Regular dependency. + if (!urlFetched[url]) { + urlFetched[url] = true; + context.load(this.map.id, url); + } + }, + + /** + * Checks if the module is ready to define itself, and if so, + * define it. + */ + check: function () { + if (!this.enabled || this.enabling) { + return; + } + + var err, cjsModule, + id = this.map.id, + depExports = this.depExports, + exports = this.exports, + factory = this.factory; + + if (!this.inited) { + // Only fetch if not already in the defQueue. + if (!hasProp(context.defQueueMap, id)) { + this.fetch(); + } + } else if (this.error) { + this.emit('error', this.error); + } else if (!this.defining) { + //The factory could trigger another require call + //that would result in checking this module to + //define itself again. If already in the process + //of doing that, skip this work. + this.defining = true; + + if (this.depCount < 1 && !this.defined) { + if (isFunction(factory)) { + //If there is an error listener, favor passing + //to that instead of throwing an error. However, + //only do it for define()'d modules. require + //errbacks should not be called for failures in + //their callbacks (#699). However if a global + //onError is set, use that. + if ((this.events.error && this.map.isDefine) || + req.onError !== defaultOnError) { + try { + exports = context.execCb(id, factory, depExports, exports); + } catch (e) { + err = e; + } + } else { + exports = context.execCb(id, factory, depExports, exports); + } + + // Favor return value over exports. If node/cjs in play, + // then will not have a return value anyway. Favor + // module.exports assignment over exports object. + if (this.map.isDefine && exports === undefined) { + cjsModule = this.module; + if (cjsModule) { + exports = cjsModule.exports; + } else if (this.usingExports) { + //exports already set the defined value. + exports = this.exports; + } + } + + if (err) { + err.requireMap = this.map; + err.requireModules = this.map.isDefine ? [this.map.id] : null; + err.requireType = this.map.isDefine ? 'define' : 'require'; + return onError((this.error = err)); + } + + } else { + //Just a literal value + exports = factory; + } + + this.exports = exports; + + if (this.map.isDefine && !this.ignore) { + defined[id] = exports; + + if (req.onResourceLoad) { + var resLoadMaps = []; + each(this.depMaps, function (depMap) { + resLoadMaps.push(depMap.normalizedMap || depMap); + }); + req.onResourceLoad(context, this.map, resLoadMaps); + } + } + + //Clean up + cleanRegistry(id); + + this.defined = true; + } + + //Finished the define stage. Allow calling check again + //to allow define notifications below in the case of a + //cycle. + this.defining = false; + + if (this.defined && !this.defineEmitted) { + this.defineEmitted = true; + this.emit('defined', this.exports); + this.defineEmitComplete = true; + } + + } + }, + + callPlugin: function () { + var map = this.map, + id = map.id, + //Map already normalized the prefix. + pluginMap = makeModuleMap(map.prefix); + + //Mark this as a dependency for this plugin, so it + //can be traced for cycles. + this.depMaps.push(pluginMap); + + on(pluginMap, 'defined', bind(this, function (plugin) { + var load, normalizedMap, normalizedMod, + bundleId = getOwn(bundlesMap, this.map.id), + name = this.map.name, + parentName = this.map.parentMap ? this.map.parentMap.name : null, + localRequire = context.makeRequire(map.parentMap, { + enableBuildCallback: true + }); + + //If current map is not normalized, wait for that + //normalized name to load instead of continuing. + if (this.map.unnormalized) { + //Normalize the ID if the plugin allows it. + if (plugin.normalize) { + name = plugin.normalize(name, function (name) { + return normalize(name, parentName, true); + }) || ''; + } + + //prefix and name should already be normalized, no need + //for applying map config again either. + normalizedMap = makeModuleMap(map.prefix + '!' + name, + this.map.parentMap); + on(normalizedMap, + 'defined', bind(this, function (value) { + this.map.normalizedMap = normalizedMap; + this.init([], function () { return value; }, null, { + enabled: true, + ignore: true + }); + })); + + normalizedMod = getOwn(registry, normalizedMap.id); + if (normalizedMod) { + //Mark this as a dependency for this plugin, so it + //can be traced for cycles. + this.depMaps.push(normalizedMap); + + if (this.events.error) { + normalizedMod.on('error', bind(this, function (err) { + this.emit('error', err); + })); + } + normalizedMod.enable(); + } + + return; + } + + //If a paths config, then just load that file instead to + //resolve the plugin, as it is built into that paths layer. + if (bundleId) { + this.map.url = context.nameToUrl(bundleId); + this.load(); + return; + } + + load = bind(this, function (value) { + this.init([], function () { return value; }, null, { + enabled: true + }); + }); + + load.error = bind(this, function (err) { + this.inited = true; + this.error = err; + err.requireModules = [id]; + + //Remove temp unnormalized modules for this module, + //since they will never be resolved otherwise now. + eachProp(registry, function (mod) { + if (mod.map.id.indexOf(id + '_unnormalized') === 0) { + cleanRegistry(mod.map.id); + } + }); + + onError(err); + }); + + //Allow plugins to load other code without having to know the + //context or how to 'complete' the load. + load.fromText = bind(this, function (text, textAlt) { + /*jslint evil: true */ + var moduleName = map.name, + moduleMap = makeModuleMap(moduleName), + hasInteractive = useInteractive; + + //As of 2.1.0, support just passing the text, to reinforce + //fromText only being called once per resource. Still + //support old style of passing moduleName but discard + //that moduleName in favor of the internal ref. + if (textAlt) { + text = textAlt; + } + + //Turn off interactive script matching for IE for any define + //calls in the text, then turn it back on at the end. + if (hasInteractive) { + useInteractive = false; + } + + //Prime the system by creating a module instance for + //it. + getModule(moduleMap); + + //Transfer any config to this other module. + if (hasProp(config.config, id)) { + config.config[moduleName] = config.config[id]; + } + + try { + req.exec(text); + } catch (e) { + return onError(makeError('fromtexteval', + 'fromText eval for ' + id + + ' failed: ' + e, + e, + [id])); + } + + if (hasInteractive) { + useInteractive = true; + } + + //Mark this as a dependency for the plugin + //resource + this.depMaps.push(moduleMap); + + //Support anonymous modules. + context.completeLoad(moduleName); + + //Bind the value of that module to the value for this + //resource ID. + localRequire([moduleName], load); + }); + + //Use parentName here since the plugin's name is not reliable, + //could be some weird string with no path that actually wants to + //reference the parentName's path. + plugin.load(map.name, localRequire, load, config); + })); + + context.enable(pluginMap, this); + this.pluginMaps[pluginMap.id] = pluginMap; + }, + + enable: function () { + enabledRegistry[this.map.id] = this; + this.enabled = true; + + //Set flag mentioning that the module is enabling, + //so that immediate calls to the defined callbacks + //for dependencies do not trigger inadvertent load + //with the depCount still being zero. + this.enabling = true; + + //Enable each dependency + each(this.depMaps, bind(this, function (depMap, i) { + var id, mod, handler; + + if (typeof depMap === 'string') { + //Dependency needs to be converted to a depMap + //and wired up to this module. + depMap = makeModuleMap(depMap, + (this.map.isDefine ? this.map : this.map.parentMap), + false, + !this.skipMap); + this.depMaps[i] = depMap; + + handler = getOwn(handlers, depMap.id); + + if (handler) { + this.depExports[i] = handler(this); + return; + } + + this.depCount += 1; + + on(depMap, 'defined', bind(this, function (depExports) { + if (this.undefed) { + return; + } + this.defineDep(i, depExports); + this.check(); + })); + + if (this.errback) { + on(depMap, 'error', bind(this, this.errback)); + } else if (this.events.error) { + // No direct errback on this module, but something + // else is listening for errors, so be sure to + // propagate the error correctly. + on(depMap, 'error', bind(this, function(err) { + this.emit('error', err); + })); + } + } + + id = depMap.id; + mod = registry[id]; + + //Skip special modules like 'require', 'exports', 'module' + //Also, don't call enable if it is already enabled, + //important in circular dependency cases. + if (!hasProp(handlers, id) && mod && !mod.enabled) { + context.enable(depMap, this); + } + })); + + //Enable each plugin that is used in + //a dependency + eachProp(this.pluginMaps, bind(this, function (pluginMap) { + var mod = getOwn(registry, pluginMap.id); + if (mod && !mod.enabled) { + context.enable(pluginMap, this); + } + })); + + this.enabling = false; + + this.check(); + }, + + on: function (name, cb) { + var cbs = this.events[name]; + if (!cbs) { + cbs = this.events[name] = []; + } + cbs.push(cb); + }, + + emit: function (name, evt) { + each(this.events[name], function (cb) { + cb(evt); + }); + if (name === 'error') { + //Now that the error handler was triggered, remove + //the listeners, since this broken Module instance + //can stay around for a while in the registry. + delete this.events[name]; + } + } + }; + + function callGetModule(args) { + //Skip modules already defined. + if (!hasProp(defined, args[0])) { + getModule(makeModuleMap(args[0], null, true)).init(args[1], args[2]); + } + } + + function removeListener(node, func, name, ieName) { + //Favor detachEvent because of IE9 + //issue, see attachEvent/addEventListener comment elsewhere + //in this file. + if (node.detachEvent && !isOpera) { + //Probably IE. If not it will throw an error, which will be + //useful to know. + if (ieName) { + node.detachEvent(ieName, func); + } + } else { + node.removeEventListener(name, func, false); + } + } + + /** + * Given an event from a script node, get the requirejs info from it, + * and then removes the event listeners on the node. + * @param {Event} evt + * @returns {Object} + */ + function getScriptData(evt) { + //Using currentTarget instead of target for Firefox 2.0's sake. Not + //all old browsers will be supported, but this one was easy enough + //to support and still makes sense. + var node = evt.currentTarget || evt.srcElement; + + //Remove the listeners once here. + removeListener(node, context.onScriptLoad, 'load', 'onreadystatechange'); + removeListener(node, context.onScriptError, 'error'); + + return { + node: node, + id: node && node.getAttribute('data-requiremodule') + }; + } + + function intakeDefines() { + var args; + + //Any defined modules in the global queue, intake them now. + takeGlobalQueue(); + + //Make sure any remaining defQueue items get properly processed. + while (defQueue.length) { + args = defQueue.shift(); + if (args[0] === null) { + return onError(makeError('mismatch', 'Mismatched anonymous define() module: ' + + args[args.length - 1])); + } else { + //args are id, deps, factory. Should be normalized by the + //define() function. + callGetModule(args); + } + } + context.defQueueMap = {}; + } + + context = { + config: config, + contextName: contextName, + registry: registry, + defined: defined, + urlFetched: urlFetched, + defQueue: defQueue, + defQueueMap: {}, + Module: Module, + makeModuleMap: makeModuleMap, + nextTick: req.nextTick, + onError: onError, + + /** + * Set a configuration for the context. + * @param {Object} cfg config object to integrate. + */ + configure: function (cfg) { + //Make sure the baseUrl ends in a slash. + if (cfg.baseUrl) { + if (cfg.baseUrl.charAt(cfg.baseUrl.length - 1) !== '/') { + cfg.baseUrl += '/'; + } + } + + // Convert old style urlArgs string to a function. + if (typeof cfg.urlArgs === 'string') { + var urlArgs = cfg.urlArgs; + cfg.urlArgs = function(id, url) { + return (url.indexOf('?') === -1 ? '?' : '&') + urlArgs; + }; + } + + //Save off the paths since they require special processing, + //they are additive. + var shim = config.shim, + objs = { + paths: true, + bundles: true, + config: true, + map: true + }; + + eachProp(cfg, function (value, prop) { + if (objs[prop]) { + if (!config[prop]) { + config[prop] = {}; + } + mixin(config[prop], value, true, true); + } else { + config[prop] = value; + } + }); + + //Reverse map the bundles + if (cfg.bundles) { + eachProp(cfg.bundles, function (value, prop) { + each(value, function (v) { + if (v !== prop) { + bundlesMap[v] = prop; + } + }); + }); + } + + //Merge shim + if (cfg.shim) { + eachProp(cfg.shim, function (value, id) { + //Normalize the structure + if (isArray(value)) { + value = { + deps: value + }; + } + if ((value.exports || value.init) && !value.exportsFn) { + value.exportsFn = context.makeShimExports(value); + } + shim[id] = value; + }); + config.shim = shim; + } + + //Adjust packages if necessary. + if (cfg.packages) { + each(cfg.packages, function (pkgObj) { + var location, name; + + pkgObj = typeof pkgObj === 'string' ? {name: pkgObj} : pkgObj; + + name = pkgObj.name; + location = pkgObj.location; + if (location) { + config.paths[name] = pkgObj.location; + } + + //Save pointer to main module ID for pkg name. + //Remove leading dot in main, so main paths are normalized, + //and remove any trailing .js, since different package + //envs have different conventions: some use a module name, + //some use a file name. + config.pkgs[name] = pkgObj.name + '/' + (pkgObj.main || 'main') + .replace(currDirRegExp, '') + .replace(jsSuffixRegExp, ''); + }); + } + + //If there are any "waiting to execute" modules in the registry, + //update the maps for them, since their info, like URLs to load, + //may have changed. + eachProp(registry, function (mod, id) { + //If module already has init called, since it is too + //late to modify them, and ignore unnormalized ones + //since they are transient. + if (!mod.inited && !mod.map.unnormalized) { + mod.map = makeModuleMap(id, null, true); + } + }); + + //If a deps array or a config callback is specified, then call + //require with those args. This is useful when require is defined as a + //config object before require.js is loaded. + if (cfg.deps || cfg.callback) { + context.require(cfg.deps || [], cfg.callback); + } + }, + + makeShimExports: function (value) { + function fn() { + var ret; + if (value.init) { + ret = value.init.apply(global, arguments); + } + return ret || (value.exports && getGlobal(value.exports)); + } + return fn; + }, + + makeRequire: function (relMap, options) { + options = options || {}; + + function localRequire(deps, callback, errback) { + var id, map, requireMod; + + if (options.enableBuildCallback && callback && isFunction(callback)) { + callback.__requireJsBuild = true; + } + + if (typeof deps === 'string') { + if (isFunction(callback)) { + //Invalid call + return onError(makeError('requireargs', 'Invalid require call'), errback); + } + + //If require|exports|module are requested, get the + //value for them from the special handlers. Caveat: + //this only works while module is being defined. + if (relMap && hasProp(handlers, deps)) { + return handlers[deps](registry[relMap.id]); + } + + //Synchronous access to one module. If require.get is + //available (as in the Node adapter), prefer that. + if (req.get) { + return req.get(context, deps, relMap, localRequire); + } + + //Normalize module name, if it contains . or .. + map = makeModuleMap(deps, relMap, false, true); + id = map.id; + + if (!hasProp(defined, id)) { + return onError(makeError('notloaded', 'Module name "' + + id + + '" has not been loaded yet for context: ' + + contextName + + (relMap ? '' : '. Use require([])'))); + } + return defined[id]; + } + + //Grab defines waiting in the global queue. + intakeDefines(); + + //Mark all the dependencies as needing to be loaded. + context.nextTick(function () { + //Some defines could have been added since the + //require call, collect them. + intakeDefines(); + + requireMod = getModule(makeModuleMap(null, relMap)); + + //Store if map config should be applied to this require + //call for dependencies. + requireMod.skipMap = options.skipMap; + + requireMod.init(deps, callback, errback, { + enabled: true + }); + + checkLoaded(); + }); + + return localRequire; + } + + mixin(localRequire, { + isBrowser: isBrowser, + + /** + * Converts a module name + .extension into an URL path. + * *Requires* the use of a module name. It does not support using + * plain URLs like nameToUrl. + */ + toUrl: function (moduleNamePlusExt) { + var ext, + index = moduleNamePlusExt.lastIndexOf('.'), + segment = moduleNamePlusExt.split('/')[0], + isRelative = segment === '.' || segment === '..'; + + //Have a file extension alias, and it is not the + //dots from a relative path. + if (index !== -1 && (!isRelative || index > 1)) { + ext = moduleNamePlusExt.substring(index, moduleNamePlusExt.length); + moduleNamePlusExt = moduleNamePlusExt.substring(0, index); + } + + return context.nameToUrl(normalize(moduleNamePlusExt, + relMap && relMap.id, true), ext, true); + }, + + defined: function (id) { + return hasProp(defined, makeModuleMap(id, relMap, false, true).id); + }, + + specified: function (id) { + id = makeModuleMap(id, relMap, false, true).id; + return hasProp(defined, id) || hasProp(registry, id); + } + }); + + //Only allow undef on top level require calls + if (!relMap) { + localRequire.undef = function (id) { + //Bind any waiting define() calls to this context, + //fix for #408 + takeGlobalQueue(); + + var map = makeModuleMap(id, relMap, true), + mod = getOwn(registry, id); + + mod.undefed = true; + removeScript(id); + + delete defined[id]; + delete urlFetched[map.url]; + delete undefEvents[id]; + + //Clean queued defines too. Go backwards + //in array so that the splices do not + //mess up the iteration. + eachReverse(defQueue, function(args, i) { + if (args[0] === id) { + defQueue.splice(i, 1); + } + }); + delete context.defQueueMap[id]; + + if (mod) { + //Hold on to listeners in case the + //module will be attempted to be reloaded + //using a different config. + if (mod.events.defined) { + undefEvents[id] = mod.events; + } + + cleanRegistry(id); + } + }; + } + + return localRequire; + }, + + /** + * Called to enable a module if it is still in the registry + * awaiting enablement. A second arg, parent, the parent module, + * is passed in for context, when this method is overridden by + * the optimizer. Not shown here to keep code compact. + */ + enable: function (depMap) { + var mod = getOwn(registry, depMap.id); + if (mod) { + getModule(depMap).enable(); + } + }, + + /** + * Internal method used by environment adapters to complete a load event. + * A load event could be a script load or just a load pass from a synchronous + * load call. + * @param {String} moduleName the name of the module to potentially complete. + */ + completeLoad: function (moduleName) { + var found, args, mod, + shim = getOwn(config.shim, moduleName) || {}, + shExports = shim.exports; + + takeGlobalQueue(); + + while (defQueue.length) { + args = defQueue.shift(); + if (args[0] === null) { + args[0] = moduleName; + //If already found an anonymous module and bound it + //to this name, then this is some other anon module + //waiting for its completeLoad to fire. + if (found) { + break; + } + found = true; + } else if (args[0] === moduleName) { + //Found matching define call for this script! + found = true; + } + + callGetModule(args); + } + context.defQueueMap = {}; + + //Do this after the cycle of callGetModule in case the result + //of those calls/init calls changes the registry. + mod = getOwn(registry, moduleName); + + if (!found && !hasProp(defined, moduleName) && mod && !mod.inited) { + if (config.enforceDefine && (!shExports || !getGlobal(shExports))) { + if (hasPathFallback(moduleName)) { + return; + } else { + return onError(makeError('nodefine', + 'No define call for ' + moduleName, + null, + [moduleName])); + } + } else { + //A script that does not call define(), so just simulate + //the call for it. + callGetModule([moduleName, (shim.deps || []), shim.exportsFn]); + } + } + + checkLoaded(); + }, + + /** + * Converts a module name to a file path. Supports cases where + * moduleName may actually be just an URL. + * Note that it **does not** call normalize on the moduleName, + * it is assumed to have already been normalized. This is an + * internal API, not a public one. Use toUrl for the public API. + */ + nameToUrl: function (moduleName, ext, skipExt) { + var paths, syms, i, parentModule, url, + parentPath, bundleId, + pkgMain = getOwn(config.pkgs, moduleName); + + if (pkgMain) { + moduleName = pkgMain; + } + + bundleId = getOwn(bundlesMap, moduleName); + + if (bundleId) { + return context.nameToUrl(bundleId, ext, skipExt); + } + + //If a colon is in the URL, it indicates a protocol is used and it is just + //an URL to a file, or if it starts with a slash, contains a query arg (i.e. ?) + //or ends with .js, then assume the user meant to use an url and not a module id. + //The slash is important for protocol-less URLs as well as full paths. + if (req.jsExtRegExp.test(moduleName)) { + //Just a plain path, not module name lookup, so just return it. + //Add extension if it is included. This is a bit wonky, only non-.js things pass + //an extension, this method probably needs to be reworked. + url = moduleName + (ext || ''); + } else { + //A module that needs to be converted to a path. + paths = config.paths; + + syms = moduleName.split('/'); + //For each module name segment, see if there is a path + //registered for it. Start with most specific name + //and work up from it. + for (i = syms.length; i > 0; i -= 1) { + parentModule = syms.slice(0, i).join('/'); + + parentPath = getOwn(paths, parentModule); + if (parentPath) { + //If an array, it means there are a few choices, + //Choose the one that is desired + if (isArray(parentPath)) { + parentPath = parentPath[0]; + } + syms.splice(0, i, parentPath); + break; + } + } + + //Join the path parts together, then figure out if baseUrl is needed. + url = syms.join('/'); + url += (ext || (/^data\:|^blob\:|\?/.test(url) || skipExt ? '' : '.js')); + url = (url.charAt(0) === '/' || url.match(/^[\w\+\.\-]+:/) ? '' : config.baseUrl) + url; + } + + return config.urlArgs && !/^blob\:/.test(url) ? + url + config.urlArgs(moduleName, url) : url; + }, + + //Delegates to req.load. Broken out as a separate function to + //allow overriding in the optimizer. + load: function (id, url) { + req.load(context, id, url); + }, + + /** + * Executes a module callback function. Broken out as a separate function + * solely to allow the build system to sequence the files in the built + * layer in the right sequence. + * + * @private + */ + execCb: function (name, callback, args, exports) { + return callback.apply(exports, args); + }, + + /** + * callback for script loads, used to check status of loading. + * + * @param {Event} evt the event from the browser for the script + * that was loaded. + */ + onScriptLoad: function (evt) { + //Using currentTarget instead of target for Firefox 2.0's sake. Not + //all old browsers will be supported, but this one was easy enough + //to support and still makes sense. + if (evt.type === 'load' || + (readyRegExp.test((evt.currentTarget || evt.srcElement).readyState))) { + //Reset interactive script so a script node is not held onto for + //to long. + interactiveScript = null; + + //Pull out the name of the module and the context. + var data = getScriptData(evt); + context.completeLoad(data.id); + } + }, + + /** + * Callback for script errors. + */ + onScriptError: function (evt) { + var data = getScriptData(evt); + if (!hasPathFallback(data.id)) { + var parents = []; + eachProp(registry, function(value, key) { + if (key.indexOf('_@r') !== 0) { + each(value.depMaps, function(depMap) { + if (depMap.id === data.id) { + parents.push(key); + return true; + } + }); + } + }); + return onError(makeError('scripterror', 'Script error for "' + data.id + + (parents.length ? + '", needed by: ' + parents.join(', ') : + '"'), evt, [data.id])); + } + } + }; + + context.require = context.makeRequire(); + return context; + } + + /** + * Main entry point. + * + * If the only argument to require is a string, then the module that + * is represented by that string is fetched for the appropriate context. + * + * If the first argument is an array, then it will be treated as an array + * of dependency string names to fetch. An optional function callback can + * be specified to execute when all of those dependencies are available. + * + * Make a local req variable to help Caja compliance (it assumes things + * on a require that are not standardized), and to give a short + * name for minification/local scope use. + */ + req = requirejs = function (deps, callback, errback, optional) { + + //Find the right context, use default + var context, config, + contextName = defContextName; + + // Determine if have config object in the call. + if (!isArray(deps) && typeof deps !== 'string') { + // deps is a config object + config = deps; + if (isArray(callback)) { + // Adjust args if there are dependencies + deps = callback; + callback = errback; + errback = optional; + } else { + deps = []; + } + } + + if (config && config.context) { + contextName = config.context; + } + + context = getOwn(contexts, contextName); + if (!context) { + context = contexts[contextName] = req.s.newContext(contextName); + } + + if (config) { + context.configure(config); + } + + return context.require(deps, callback, errback); + }; + + /** + * Support require.config() to make it easier to cooperate with other + * AMD loaders on globally agreed names. + */ + req.config = function (config) { + return req(config); + }; + + /** + * Execute something after the current tick + * of the event loop. Override for other envs + * that have a better solution than setTimeout. + * @param {Function} fn function to execute later. + */ + req.nextTick = typeof setTimeout !== 'undefined' ? function (fn) { + setTimeout(fn, 4); + } : function (fn) { fn(); }; + + /** + * Export require as a global, but only if it does not already exist. + */ + if (!require) { + require = req; + } + + req.version = version; + + //Used to filter out dependencies that are already paths. + req.jsExtRegExp = /^\/|:|\?|\.js$/; + req.isBrowser = isBrowser; + s = req.s = { + contexts: contexts, + newContext: newContext + }; + + //Create default context. + req({}); + + //Exports some context-sensitive methods on global require. + each([ + 'toUrl', + 'undef', + 'defined', + 'specified' + ], function (prop) { + //Reference from contexts instead of early binding to default context, + //so that during builds, the latest instance of the default context + //with its config gets used. + req[prop] = function () { + var ctx = contexts[defContextName]; + return ctx.require[prop].apply(ctx, arguments); + }; + }); + + if (isBrowser) { + head = s.head = document.getElementsByTagName('head')[0]; + //If BASE tag is in play, using appendChild is a problem for IE6. + //When that browser dies, this can be removed. Details in this jQuery bug: + //http://dev.jquery.com/ticket/2709 + baseElement = document.getElementsByTagName('base')[0]; + if (baseElement) { + head = s.head = baseElement.parentNode; + } + } + + /** + * Any errors that require explicitly generates will be passed to this + * function. Intercept/override it if you want custom error handling. + * @param {Error} err the error object. + */ + req.onError = defaultOnError; + + /** + * Creates the node for the load command. Only used in browser envs. + */ + req.createNode = function (config, moduleName, url) { + var node = config.xhtml ? + document.createElementNS('http://www.w3.org/1999/xhtml', 'html:script') : + document.createElement('script'); + node.type = config.scriptType || 'text/javascript'; + node.charset = 'utf-8'; + node.async = true; + return node; + }; + + /** + * Does the request to load a module for the browser case. + * Make this a separate function to allow other environments + * to override it. + * + * @param {Object} context the require context to find state. + * @param {String} moduleName the name of the module. + * @param {Object} url the URL to the module. + */ + req.load = function (context, moduleName, url) { + var config = (context && context.config) || {}, + node; + if (isBrowser) { + //In the browser so use a script tag + node = req.createNode(config, moduleName, url); + + node.setAttribute('data-requirecontext', context.contextName); + node.setAttribute('data-requiremodule', moduleName); + + //Set up load listener. Test attachEvent first because IE9 has + //a subtle issue in its addEventListener and script onload firings + //that do not match the behavior of all other browsers with + //addEventListener support, which fire the onload event for a + //script right after the script execution. See: + //https://connect.microsoft.com/IE/feedback/details/648057/script-onload-event-is-not-fired-immediately-after-script-execution + //UNFORTUNATELY Opera implements attachEvent but does not follow the script + //script execution mode. + if (node.attachEvent && + //Check if node.attachEvent is artificially added by custom script or + //natively supported by browser + //read https://github.com/requirejs/requirejs/issues/187 + //if we can NOT find [native code] then it must NOT natively supported. + //in IE8, node.attachEvent does not have toString() + //Note the test for "[native code" with no closing brace, see: + //https://github.com/requirejs/requirejs/issues/273 + !(node.attachEvent.toString && node.attachEvent.toString().indexOf('[native code') < 0) && + !isOpera) { + //Probably IE. IE (at least 6-8) do not fire + //script onload right after executing the script, so + //we cannot tie the anonymous define call to a name. + //However, IE reports the script as being in 'interactive' + //readyState at the time of the define call. + useInteractive = true; + + node.attachEvent('onreadystatechange', context.onScriptLoad); + //It would be great to add an error handler here to catch + //404s in IE9+. However, onreadystatechange will fire before + //the error handler, so that does not help. If addEventListener + //is used, then IE will fire error before load, but we cannot + //use that pathway given the connect.microsoft.com issue + //mentioned above about not doing the 'script execute, + //then fire the script load event listener before execute + //next script' that other browsers do. + //Best hope: IE10 fixes the issues, + //and then destroys all installs of IE 6-9. + //node.attachEvent('onerror', context.onScriptError); + } else { + node.addEventListener('load', context.onScriptLoad, false); + node.addEventListener('error', context.onScriptError, false); + } + node.src = url; + + //Calling onNodeCreated after all properties on the node have been + //set, but before it is placed in the DOM. + if (config.onNodeCreated) { + config.onNodeCreated(node, config, moduleName, url); + } + + //For some cache cases in IE 6-8, the script executes before the end + //of the appendChild execution, so to tie an anonymous define + //call to the module name (which is stored on the node), hold on + //to a reference to this node, but clear after the DOM insertion. + currentlyAddingScript = node; + if (baseElement) { + head.insertBefore(node, baseElement); + } else { + head.appendChild(node); + } + currentlyAddingScript = null; + + return node; + } else if (isWebWorker) { + try { + //In a web worker, use importScripts. This is not a very + //efficient use of importScripts, importScripts will block until + //its script is downloaded and evaluated. However, if web workers + //are in play, the expectation is that a build has been done so + //that only one script needs to be loaded anyway. This may need + //to be reevaluated if other use cases become common. + + // Post a task to the event loop to work around a bug in WebKit + // where the worker gets garbage-collected after calling + // importScripts(): https://webkit.org/b/153317 + setTimeout(function() {}, 0); + importScripts(url); + + //Account for anonymous modules + context.completeLoad(moduleName); + } catch (e) { + context.onError(makeError('importscripts', + 'importScripts failed for ' + + moduleName + ' at ' + url, + e, + [moduleName])); + } + } + }; + + function getInteractiveScript() { + if (interactiveScript && interactiveScript.readyState === 'interactive') { + return interactiveScript; + } + + eachReverse(scripts(), function (script) { + if (script.readyState === 'interactive') { + return (interactiveScript = script); + } + }); + return interactiveScript; + } + + //Look for a data-main script attribute, which could also adjust the baseUrl. + if (isBrowser && !cfg.skipDataMain) { + //Figure out baseUrl. Get it from the script tag with require.js in it. + eachReverse(scripts(), function (script) { + //Set the 'head' where we can append children by + //using the script's parent. + if (!head) { + head = script.parentNode; + } + + //Look for a data-main attribute to set main script for the page + //to load. If it is there, the path to data main becomes the + //baseUrl, if it is not already set. + dataMain = script.getAttribute('data-main'); + if (dataMain) { + //Preserve dataMain in case it is a path (i.e. contains '?') + mainScript = dataMain; + + //Set final baseUrl if there is not already an explicit one, + //but only do so if the data-main value is not a loader plugin + //module ID. + if (!cfg.baseUrl && mainScript.indexOf('!') === -1) { + //Pull off the directory of data-main for use as the + //baseUrl. + src = mainScript.split('/'); + mainScript = src.pop(); + subPath = src.length ? src.join('/') + '/' : './'; + + cfg.baseUrl = subPath; + } + + //Strip off any trailing .js since mainScript is now + //like a module name. + mainScript = mainScript.replace(jsSuffixRegExp, ''); + + //If mainScript is still a path, fall back to dataMain + if (req.jsExtRegExp.test(mainScript)) { + mainScript = dataMain; + } + + //Put the data-main script in the files to load. + cfg.deps = cfg.deps ? cfg.deps.concat(mainScript) : [mainScript]; + + return true; + } + }); + } + + /** + * The function that handles definitions of modules. Differs from + * require() in that a string for the module should be the first argument, + * and the function to execute after dependencies are loaded should + * return a value to define the module corresponding to the first argument's + * name. + */ + define = function (name, deps, callback) { + var node, context; + + //Allow for anonymous modules + if (typeof name !== 'string') { + //Adjust args appropriately + callback = deps; + deps = name; + name = null; + } + + //This module may not have dependencies + if (!isArray(deps)) { + callback = deps; + deps = null; + } + + //If no name, and callback is a function, then figure out if it a + //CommonJS thing with dependencies. + if (!deps && isFunction(callback)) { + deps = []; + //Remove comments from the callback string, + //look for require calls, and pull them into the dependencies, + //but only if there are function args. + if (callback.length) { + callback + .toString() + .replace(commentRegExp, commentReplace) + .replace(cjsRequireRegExp, function (match, dep) { + deps.push(dep); + }); + + //May be a CommonJS thing even without require calls, but still + //could use exports, and module. Avoid doing exports and module + //work though if it just needs require. + //REQUIRES the function to expect the CommonJS variables in the + //order listed below. + deps = (callback.length === 1 ? ['require'] : ['require', 'exports', 'module']).concat(deps); + } + } + + //If in IE 6-8 and hit an anonymous define() call, do the interactive + //work. + if (useInteractive) { + node = currentlyAddingScript || getInteractiveScript(); + if (node) { + if (!name) { + name = node.getAttribute('data-requiremodule'); + } + context = contexts[node.getAttribute('data-requirecontext')]; + } + } + + //Always save off evaluating the def call until the script onload handler. + //This allows multiple modules to be in a file without prematurely + //tracing dependencies, and allows for anonymous module support, + //where the module name is not known until the script onload event + //occurs. If no context, use the global queue, and get it processed + //in the onscript load callback. + if (context) { + context.defQueue.push([name, deps, callback]); + context.defQueueMap[name] = true; + } else { + globalDefQueue.push([name, deps, callback]); + } + }; + + define.amd = { + jQuery: true + }; + + /** + * Executes the text. Normally just uses eval, but can be modified + * to use a better, environment-specific call. Only used for transpiling + * loader plugins, not for plain JS modules. + * @param {String} text the text to execute/evaluate. + */ + req.exec = function (text) { + /*jslint evil: true */ + return eval(text); + }; + + //Set up with config info. + req(cfg); +}(this, (typeof setTimeout === 'undefined' ? undefined : setTimeout))); diff --git a/node_modules/seedrandom/test/newapi.html b/node_modules/seedrandom/test/newapi.html new file mode 100644 index 0000000..0767be1 --- /dev/null +++ b/node_modules/seedrandom/test/newapi.html @@ -0,0 +1,44 @@ + + + + + +
      +
      + + + + + diff --git a/node_modules/seedrandom/test/nodetest.js b/node_modules/seedrandom/test/nodetest.js new file mode 100644 index 0000000..ab90184 --- /dev/null +++ b/node_modules/seedrandom/test/nodetest.js @@ -0,0 +1,226 @@ +var assert = require("assert"); +var seedrandom = require("../seedrandom"); +var requirejs = require("requirejs"); + +// Stub out requirejs if in the browser via browserify. +if (!requirejs.config) { + requirejs = require; +} else { + requirejs.config({ + baseUrl: __dirname + }); +} + +describe("Nodejs API Test", function() { + +it('should pass basic tests.', function() { + var original = Math.random, + result, r, xprng, obj, as2, as3, autoseed1, myrng, + firstprng, secondprng, thirdprng, rng; + + result = Math.seedrandom('hello.'); + firstprng = Math.random; + assert.ok(original !== firstprng, "Should change Math.random."); + assert.equal(result, "hello.", "Should return short seed."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + r = Math.random(); + assert.equal(r, 0.3752569768646784, "Should be 'hello.'#2"); + + // should be able to autoseed + result = Math.seedrandom(); + secondprng = Math.random; + assert.ok(original !== secondprng, "Should change Math.random."); + assert.ok(firstprng !== secondprng, "Should change Math.random."); + assert.equal(result.length, 256, "Should return short seed."); + r = Math.random(); + assert.ok(r > 0, "Should be posititive."); + assert.ok(r < 1, "Should be less than 1."); + assert.ok(r != 0.9282578795792454, "Should not be 'hello.'#1"); + assert.ok(r != 0.3752569768646784, "Should not be 'hello.'#2"); + assert.ok(r != 0.7316977468919549, "Should not be 'hello.'#3"); + autoseed1 = r; + + // should be able to add entropy. + result = Math.seedrandom('added entropy.', { entropy:true }); + assert.equal(result.length, 256, "Should return short seed."); + thirdprng = Math.random; + assert.ok(thirdprng !== secondprng, "Should change Math.random."); + r = Math.random(); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // Reset to original Math.random. + Math.random = original; + // should be able to use new Math.seedrandom('hello.') + myrng = new Math.seedrandom('hello.'); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== myrng, "PRNG should not be Math.random."); + r = myrng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // should be able to use seedrandom('hello.')" + rng = seedrandom('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); + + // Global PRNG: set Math.random. + // should be able to use seedrandom('hello.', { global: true }) + result = seedrandom('hello.', { global: true }); + assert.equal(result, 'hello.', "Should return short seed."); + assert.ok(original != Math.random, "Should change Math.random."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // Autoseeded non-global + Math.random = original; + // should be able to use seedrandom() + result = seedrandom(); + assert.equal(typeof(result), 'function', "Should return function."); + assert.ok(original === Math.random, "Should not change Math.random."); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.9282578795792454, "Should not be 'hello.'#1"); + assert.ok(r != 0.7316977468919549, "Should not be 'hello.'#3"); + + // Mixing accumulated entropy. + // should be able to use seedrandom('added entropy.', { entropy: true }) + rng = seedrandom('added entropy.', { entropy: true }); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // Legacy calling convention for mixing accumulated entropy. + // should be able to use seedrandom('added entropy.', true) + rng = seedrandom('added entropy.', true); + r = result(); + // got " + r); + assert.ok(r != autoseed1, "Should not repeat previous autoseed."); + assert.ok(r != 0.597067214994467, "Should not be 'added entropy.'#1"); + + // The pass option + // should be able to use Math.seedrandom(null, { pass: ... + obj = Math.seedrandom(null, { pass: function(prng, seed) { + return { random: prng, seed: seed }; + }}); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== obj.random, "Should be different from Math.random."); + assert.equal(typeof(obj.random), 'function', "Should return a PRNG function."); + assert.equal(typeof(obj.seed), 'string', "Should return a seed."); + as2 = obj.random(); + assert.ok(as2 != 0.9282578795792454, "Should not be 'hello.'#1"); + rng = seedrandom(obj.seed); + as3 = rng(); + assert.equal(as2, as3, "Should be reproducible when using the seed."); + + // Exercise pass again, with explicit seed and global + // should be able to use Math.seedrandom('hello.', { pass: ... + result = Math.seedrandom('hello.', { + global: 'abc', + pass: function(prng, seed, global) { + assert.equal(typeof(prng), 'function', "Callback arg #1 assert"); + assert.equal(seed, 'hello.', "Callback arg #2 assert"); + assert.equal(global, 'abc', "Callback arg #3 passed through."); + assert.equal(prng(), 0.9282578795792454, "Should be 'hello.'#1"); + return 'def'; + }}); + assert.equal(result, 'def', "Should return value from callback."); + assert.ok(original === Math.random, "Should not change Math.random."); + + // Legacy third argument callback argument: + // should be able to use Math.seedrandom('hello.', { global: 50 }, callback) + result = Math.seedrandom('hello.', { global: 50 }, + function(prng, seed, global) { + assert.equal(typeof(prng), 'function', "Callback arg #1 assert"); + assert.equal(seed, 'hello.', "Callback arg #2 assert"); + assert.equal(global, 50, "Callback arg #3 assert"); + assert.equal(prng(), 0.9282578795792454, "Should be 'hello.'#1"); + return 'zzz'; + }); + assert.equal(result, 'zzz', "Should return value from callback."); + assert.ok(original === Math.random, "Should not change Math.random."); + + // Global: false. + // should be able to use new Math.seedrandom('hello.', {global: false}) + myrng = new Math.seedrandom('hello.', {global:false}); + assert.equal(typeof(myrng), 'function', "Should return a PRNG funciton."); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== myrng, "PRNG should not be Math.random."); + r = myrng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + + // options = {} when a method of Math. + // should be able to use Math.seedrandom('hello.', {}) + result = Math.seedrandom('hello.'); + xprng = Math.random; + assert.ok(original !== xprng, "Should change Math.random."); + assert.equal(result, "hello.", "Should return short seed."); + r = Math.random(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + r = Math.random(); + assert.equal(r, 0.3752569768646784, "Should be 'hello.'#2"); + Math.random = original; + + // options = {} when not a method of Math + // should be able to use seedrandom('hello.', {}) + rng = seedrandom('hello.', {}); + assert.equal(typeof(rng), 'function', "Should return a function."); + r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); +}); + +it('should support state api.', function() { + // Verify that there is no state method + var dummy = seedrandom('hello'); + var unexpected = -1; + var expected = -1; + try { + unexpected = dummy.state(); + } catch(e) { + expected = 1; + } + assert.equal(unexpected, -1); + assert.equal(expected, 1); + var count = 0; + for (var x in dummy) { + if (x == 'state') count += 1; + } + assert.equal(count, 0); + + // Verify that a state method can be added + var saveable = seedrandom("secret-seed", {state: true}); + var ordinary = seedrandom("secret-seed"); + for (var j = 0; j < 1e2; ++j) { + assert.equal(ordinary(), saveable()); + } + var virgin = seedrandom("secret-seed"); + var saved = saveable.state(); + var replica = seedrandom("", {state: saved}); + for (var j = 0; j < 1e2; ++j) { + var r = replica(); + assert.equal(r, saveable()); + assert.equal(r, ordinary()); + assert.ok(r != virgin()); + } +}); + +it('should support requirejs in node.', function() { + var original = Math.random; + var rsr = requirejs('../seedrandom'); + var rng = rsr('hello.'); + assert.equal(typeof(rng), 'function', "Should return a function."); + var r = rng(); + assert.equal(r, 0.9282578795792454, "Should be 'hello.'#1"); + assert.ok(original === Math.random, "Should not change Math.random."); + assert.ok(original !== rng, "PRNG should not be Math.random."); +}); + +// End of test. + +}); diff --git a/node_modules/seedrandom/test/options.html b/node_modules/seedrandom/test/options.html new file mode 100644 index 0000000..d8ca26b --- /dev/null +++ b/node_modules/seedrandom/test/options.html @@ -0,0 +1,195 @@ + + + + + +
      +
      + + + + + diff --git a/node_modules/seedrandom/test/out/dieharder-report.txt b/node_modules/seedrandom/test/out/dieharder-report.txt new file mode 100644 index 0000000..9e94668 --- /dev/null +++ b/node_modules/seedrandom/test/out/dieharder-report.txt @@ -0,0 +1,125 @@ +#=============================================================================# +# dieharder version 3.31.1 Copyright 2003 Robert G. Brown # +#=============================================================================# + rng_name |rands/second| Seed | +stdin_input_raw| 8.07e+05 | 254212981| +#=============================================================================# + test_name |ntup| tsamples |psamples| p-value |Assessment +#=============================================================================# + diehard_birthdays| 0| 100| 100|0.55960061| PASSED + diehard_operm5| 0| 1000000| 100|0.10062010| PASSED + diehard_rank_32x32| 0| 40000| 100|0.70957907| PASSED + diehard_rank_6x8| 0| 100000| 100|0.55953143| PASSED + diehard_bitstream| 0| 2097152| 100|0.22843857| PASSED + diehard_opso| 0| 2097152| 100|0.72251086| PASSED + diehard_oqso| 0| 2097152| 100|0.30642074| PASSED + diehard_dna| 0| 2097152| 100|0.30448899| PASSED +diehard_count_1s_str| 0| 256000| 100|0.23557064| PASSED +diehard_count_1s_byt| 0| 256000| 100|0.71300874| PASSED + diehard_parking_lot| 0| 12000| 100|0.88217430| PASSED + diehard_2dsphere| 2| 8000| 100|0.32366362| PASSED + diehard_3dsphere| 3| 4000| 100|0.30804215| PASSED + diehard_squeeze| 0| 100000| 100|0.97856588| PASSED + diehard_sums| 0| 100| 100|0.01512286| PASSED + diehard_runs| 0| 100000| 100|0.39065054| PASSED + diehard_runs| 0| 100000| 100|0.10369088| PASSED + diehard_craps| 0| 200000| 100|0.57875078| PASSED + diehard_craps| 0| 200000| 100|0.96945165| PASSED + marsaglia_tsang_gcd| 0| 10000000| 100|0.58793715| PASSED + marsaglia_tsang_gcd| 0| 10000000| 100|0.59724594| PASSED + sts_monobit| 1| 100000| 100|0.49155110| PASSED + sts_runs| 2| 100000| 100|0.01880740| PASSED + sts_serial| 1| 100000| 100|0.79060354| PASSED + sts_serial| 2| 100000| 100|0.91055644| PASSED + sts_serial| 3| 100000| 100|0.15984346| PASSED + sts_serial| 3| 100000| 100|0.04426690| PASSED + sts_serial| 4| 100000| 100|0.31589675| PASSED + sts_serial| 4| 100000| 100|0.65789943| PASSED + sts_serial| 5| 100000| 100|0.84228003| PASSED + sts_serial| 5| 100000| 100|0.28748169| PASSED + sts_serial| 6| 100000| 100|0.00092985| WEAK + sts_serial| 6| 100000| 100|0.06074248| PASSED + sts_serial| 7| 100000| 100|0.54740122| PASSED + sts_serial| 7| 100000| 100|0.30286638| PASSED + sts_serial| 8| 100000| 100|0.56593073| PASSED + sts_serial| 8| 100000| 100|0.48256390| PASSED + sts_serial| 9| 100000| 100|0.70850963| PASSED + sts_serial| 9| 100000| 100|0.63732762| PASSED + sts_serial| 10| 100000| 100|0.70209276| PASSED + sts_serial| 10| 100000| 100|0.99576606| WEAK + sts_serial| 11| 100000| 100|0.96272563| PASSED + sts_serial| 11| 100000| 100|0.76682898| PASSED + sts_serial| 12| 100000| 100|0.51522677| PASSED + sts_serial| 12| 100000| 100|0.49381681| PASSED + sts_serial| 13| 100000| 100|0.24260261| PASSED + sts_serial| 13| 100000| 100|0.41953338| PASSED + sts_serial| 14| 100000| 100|0.34770045| PASSED + sts_serial| 14| 100000| 100|0.16117277| PASSED + sts_serial| 15| 100000| 100|0.27319992| PASSED + sts_serial| 15| 100000| 100|0.61170864| PASSED + sts_serial| 16| 100000| 100|0.90638742| PASSED + sts_serial| 16| 100000| 100|0.60186602| PASSED + rgb_bitdist| 1| 100000| 100|0.72630216| PASSED + rgb_bitdist| 2| 100000| 100|0.61396597| PASSED + rgb_bitdist| 3| 100000| 100|0.40711729| PASSED + rgb_bitdist| 4| 100000| 100|0.94730365| PASSED + rgb_bitdist| 5| 100000| 100|0.95781972| PASSED + rgb_bitdist| 6| 100000| 100|0.15054771| PASSED + rgb_bitdist| 7| 100000| 100|0.25022202| PASSED + rgb_bitdist| 8| 100000| 100|0.66027754| PASSED + rgb_bitdist| 9| 100000| 100|0.86566842| PASSED + rgb_bitdist| 10| 100000| 100|0.55219204| PASSED + rgb_bitdist| 11| 100000| 100|0.73446935| PASSED + rgb_bitdist| 12| 100000| 100|0.99761332| WEAK +rgb_minimum_distance| 2| 10000| 1000|0.42222311| PASSED +rgb_minimum_distance| 3| 10000| 1000|0.81566417| PASSED +rgb_minimum_distance| 4| 10000| 1000|0.84024874| PASSED +rgb_minimum_distance| 5| 10000| 1000|0.37732026| PASSED + rgb_permutations| 2| 100000| 100|0.10996142| PASSED + rgb_permutations| 3| 100000| 100|0.64682554| PASSED + rgb_permutations| 4| 100000| 100|0.75843859| PASSED + rgb_permutations| 5| 100000| 100|0.95248930| PASSED + rgb_lagged_sum| 0| 1000000| 100|0.57812648| PASSED + rgb_lagged_sum| 1| 1000000| 100|0.67863162| PASSED + rgb_lagged_sum| 2| 1000000| 100|0.70003210| PASSED + rgb_lagged_sum| 3| 1000000| 100|0.50312943| PASSED + rgb_lagged_sum| 4| 1000000| 100|0.80009739| PASSED + rgb_lagged_sum| 5| 1000000| 100|0.66383600| PASSED + rgb_lagged_sum| 6| 1000000| 100|0.65640392| PASSED + rgb_lagged_sum| 7| 1000000| 100|0.10710511| PASSED + rgb_lagged_sum| 8| 1000000| 100|0.70414014| PASSED + rgb_lagged_sum| 9| 1000000| 100|0.63857571| PASSED + rgb_lagged_sum| 10| 1000000| 100|0.25221229| PASSED + rgb_lagged_sum| 11| 1000000| 100|0.04199433| PASSED + rgb_lagged_sum| 12| 1000000| 100|0.82738115| PASSED + rgb_lagged_sum| 13| 1000000| 100|0.28316509| PASSED + rgb_lagged_sum| 14| 1000000| 100|0.21184422| PASSED + rgb_lagged_sum| 15| 1000000| 100|0.35537687| PASSED + rgb_lagged_sum| 16| 1000000| 100|0.40157319| PASSED + rgb_lagged_sum| 17| 1000000| 100|0.98108259| PASSED + rgb_lagged_sum| 18| 1000000| 100|0.65892868| PASSED + rgb_lagged_sum| 19| 1000000| 100|0.61659671| PASSED + rgb_lagged_sum| 20| 1000000| 100|0.21462018| PASSED + rgb_lagged_sum| 21| 1000000| 100|0.94489214| PASSED + rgb_lagged_sum| 22| 1000000| 100|0.76019491| PASSED + rgb_lagged_sum| 23| 1000000| 100|0.21024028| PASSED + rgb_lagged_sum| 24| 1000000| 100|0.25249456| PASSED + rgb_lagged_sum| 25| 1000000| 100|0.87385459| PASSED + rgb_lagged_sum| 26| 1000000| 100|0.81553540| PASSED + rgb_lagged_sum| 27| 1000000| 100|0.94450657| PASSED + rgb_lagged_sum| 28| 1000000| 100|0.82470366| PASSED + rgb_lagged_sum| 29| 1000000| 100|0.93993722| PASSED + rgb_lagged_sum| 30| 1000000| 100|0.52675692| PASSED + rgb_lagged_sum| 31| 1000000| 100|0.59975558| PASSED + rgb_lagged_sum| 32| 1000000| 100|0.27951088| PASSED + rgb_kstest_test| 0| 10000| 1000|0.49707175| PASSED + dab_bytedistrib| 0| 51200000| 1|0.73019918| PASSED + dab_dct| 256| 50000| 1|0.33856081| PASSED +Preparing to run test 207. ntuple = 0 + dab_filltree| 32| 15000000| 1|0.92953640| PASSED + dab_filltree| 32| 15000000| 1|0.10970674| PASSED +Preparing to run test 208. ntuple = 0 + dab_filltree2| 0| 5000000| 1|0.88411850| PASSED + dab_filltree2| 1| 5000000| 1|0.56835378| PASSED +Preparing to run test 209. ntuple = 0 + dab_monobit2| 12| 65000000| 1|0.07987839| PASSED diff --git a/node_modules/seedrandom/test/prngtest.js b/node_modules/seedrandom/test/prngtest.js new file mode 100644 index 0000000..c5ae03a --- /dev/null +++ b/node_modules/seedrandom/test/prngtest.js @@ -0,0 +1,122 @@ +// A simple smoke test and benchmark for the generators. + +var assert = require('assert'); +var xor128 = require('../lib/xor128'); +var xorwow = require('../lib/xorwow'); +var xs7 = require('../lib/xorshift7'); +var xor4096 = require('../lib/xor4096'); +var tychei = require('../lib/tychei'); +var alea = require('../lib/alea'); +var sr = require('../seedrandom'); + +describe("XOR-Shift generator test", function() { + +var benchmarks = { native: { rand: Math.random, times: [] } }; + +function test(label, alg, double1, float3, int4, hc, qc, ec, e2c) { + var fn = alg(1); + var fn2 = alg('hello.', { state: true }); + benchmarks[label] = {rand: fn.quick, times: []}; + it("should use " + label + " correctly", function() { + if (double1 != null) assert.equal(fn.double(), double1); + if (float3 != null) assert.equal(fn.quick(), float3); + if (int4 != null) assert.equal(fn.int32(), int4); + assert(fn() > 0); + assert(fn() < 1); + assert(fn2() > 0); + // Internal state is visible only if requested. + assert(!('state' in fn)); + assert('state' in fn2); + var ss = fn2.state(); + var rs = fn2(); + assert(rs < 1); + var j, h = 0, q = 0, e = 0, r, p, e2 = 0; + for (j = 0; j < 1024; ++j) { + r = fn(); + if (r < 0.5) h += 1; + if (r < 0.25) q += 1; + if (r < 0.125) e += 1; + r2 = fn2(); + if (r2 < 0.125) e2 += 1; + } + if (hc != null) { + assert.equal(h, hc); + assert.equal(q, qc); + assert.equal(e, ec); + assert.equal(e2, e2c); + h = q = e = p = 0; + for (j = 0; j < 1024; ++j) { + r = fn.double(); + if (r < 0.5) h += 1; + if (r < 0.25) q += 1; + if (r < 0.125) e += 1; + if (fn.int32() >= 0) p += 1; + } + // Sanity-check double() and int32. + assert(h >= 480 && h <= 543, h); + assert(q >= 226 && q <= 286, q); + assert(e >= 100 && e <= 156, e); + assert(e2 >= 100 && e2 <= 156, e2); + assert(p >= 482 && p <= 543, p); + } + var fn3 = alg(0, { state: ss }); + assert.equal(fn3(), rs); + }); +} + +test("xor128", xor128, + 0.7963797148975774, 0.22171171731315553, 317177041, 498, 236, 110, 115); +test("xorwow", xorwow, + 0.8178000247146859, 0.8407576507888734, 533150816, 519, 228, 121, 123); +test("xorshift7", xs7, + 0.21241471533241418, 0.9957620368804783, -1678071207, 510, 261, 143, 124); +test("tychei", tychei, + 0.42331440041340196, 0.9365617581643164, -884984569, 521, 242, 116, 126); +test("seedrandom", sr, + 0.1776348083296759, 0.2160690303426236, 1397712774, 526, 282, 131, 137); +test("xor4096", xor4096, + 0.1520436450538547, 0.4206166828516871, 1312695376, 496, 241, 113, 142); +test("alea", alea, + 0.5260470956849501, 0.47771977609954774, -1625913352, 494, 246, 125, 122); + +it("runs benchmarks", function() { + var n = 4; + var trials = 10; + var top = 4; + this.timeout(200 * n * trials); + this.slow(30 * n * trials); + var fn, k, start, end, j, t; + for (k in benchmarks) { + fn = benchmarks[k].rand; + // warmup. + for (j = 0; j < 1e5; ++j) fn(); + } + for (t = 0; t < trials; ++t) { + for (k in benchmarks) { + fn = benchmarks[k].rand; + start = +new Date; + // benchmark. + for (j = 0; j < n * 1e5; ++j) fn(); + end = +new Date; + benchmarks[k].times.push(end - start); + } + } + for (k in benchmarks) { + benchmarks[k].times.sort(); + } + function fastest(array) { + var sum = 0; + for (var j = 0; j < top; ++j) { + sum += array[j]; + } + return sum / top; + } + var nativetime = fastest(benchmarks.native.times); + for (k in benchmarks) { + var time = fastest(benchmarks[k].times); + console.log(k+ ': ' + time / n + ' nanoseconds per call, ' + + (time / nativetime).toFixed(1) + 'x native random.'); + } +}); + +}); diff --git a/node_modules/seedrandom/test/qunitassert.js b/node_modules/seedrandom/test/qunitassert.js new file mode 100644 index 0000000..9b72d6e --- /dev/null +++ b/node_modules/seedrandom/test/qunitassert.js @@ -0,0 +1,3 @@ +// Use QUnit.assert to mimic node.assert. + +module.exports = QUnit.assert; diff --git a/node_modules/seedrandom/test/require.html b/node_modules/seedrandom/test/require.html new file mode 100644 index 0000000..b8aac32 --- /dev/null +++ b/node_modules/seedrandom/test/require.html @@ -0,0 +1,57 @@ + + + + + + +
      +
      + + + + + diff --git a/node_modules/seedrandom/test/run_dieharder.sh b/node_modules/seedrandom/test/run_dieharder.sh new file mode 100644 index 0000000..89fb5e1 --- /dev/null +++ b/node_modules/seedrandom/test/run_dieharder.sh @@ -0,0 +1,5 @@ +#!/bin/sh +# http://www.phy.duke.edu/~rgb/General/dieharder.php +# How to run dieharder against seedrandom: + +node bitgen.js | dieharder -g 200 -a | tee out/dieharder-report.txt diff --git a/node_modules/seedrandom/test/state.html b/node_modules/seedrandom/test/state.html new file mode 100644 index 0000000..609b4f0 --- /dev/null +++ b/node_modules/seedrandom/test/state.html @@ -0,0 +1,56 @@ + + + + + +
      +
      + + + + + diff --git a/node_modules/url/.npmignore b/node_modules/url/.npmignore new file mode 100644 index 0000000..ba11471 --- /dev/null +++ b/node_modules/url/.npmignore @@ -0,0 +1 @@ +test-url.js diff --git a/node_modules/url/.travis.yml b/node_modules/url/.travis.yml new file mode 100644 index 0000000..16ed301 --- /dev/null +++ b/node_modules/url/.travis.yml @@ -0,0 +1,7 @@ +language: node_js +node_js: + - "0.10" +env: + global: + - secure: OgPRLCzHFh5WbjHEKlghHFW1oOreSF2JVUr3CMaFDi03ngTS2WONSw8mRn8SA6FTldiGGBx1n8orDzUw6cdkB7+tkU3G5B0M0V3vl823NaUFKgxsCM3UGDYfJb3yfAG5cj72rVZoX/ABd1fVuG4vBIlDLxsSlKQFMzUCFoyttr8= + - secure: AiZP8GHbyx83ZBhOvOxxtpNcgNHoP+vo5G1a1OYU78EHCgHg8NRyHKyCdrBnPvw6mV2BI/8frZaXAEicsHMtHMofBYn7nibNlaajBPI8AkHtYfNSc+zO+71Kwv7VOTOKKnkMEIkqhHlc6njFoH3QaBNHsgNlzzplPxaIt8vdUVk= diff --git a/node_modules/url/.zuul.yml b/node_modules/url/.zuul.yml new file mode 100644 index 0000000..feea8b6 --- /dev/null +++ b/node_modules/url/.zuul.yml @@ -0,0 +1,16 @@ +ui: mocha-tdd +browsers: + - name: chrome + version: latest + - name: firefox + version: 24..latest + - name: safari + version: latest + - name: ie + version: 9..latest + - name: iphone + version: oldest..latest + - name: ipad + version: oldest..latest + - name: android + version: oldest..latest diff --git a/node_modules/url/LICENSE b/node_modules/url/LICENSE new file mode 100644 index 0000000..f45bc11 --- /dev/null +++ b/node_modules/url/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright Joyent, Inc. and other Node contributors. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/url/README.md b/node_modules/url/README.md new file mode 100644 index 0000000..8b35460 --- /dev/null +++ b/node_modules/url/README.md @@ -0,0 +1,108 @@ +# node-url + +[![Build Status](https://travis-ci.org/defunctzombie/node-url.svg?branch=master)](https://travis-ci.org/defunctzombie/node-url) + +This module has utilities for URL resolution and parsing meant to have feature parity with node.js core [url](http://nodejs.org/api/url.html) module. + +```js +var url = require('url'); +``` + +## api + +Parsed URL objects have some or all of the following fields, depending on +whether or not they exist in the URL string. Any parts that are not in the URL +string will not be in the parsed object. Examples are shown for the URL + +`'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'` + +* `href`: The full URL that was originally parsed. Both the protocol and host are lowercased. + + Example: `'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'` + +* `protocol`: The request protocol, lowercased. + + Example: `'http:'` + +* `host`: The full lowercased host portion of the URL, including port + information. + + Example: `'host.com:8080'` + +* `auth`: The authentication information portion of a URL. + + Example: `'user:pass'` + +* `hostname`: Just the lowercased hostname portion of the host. + + Example: `'host.com'` + +* `port`: The port number portion of the host. + + Example: `'8080'` + +* `pathname`: The path section of the URL, that comes after the host and + before the query, including the initial slash if present. + + Example: `'/p/a/t/h'` + +* `search`: The 'query string' portion of the URL, including the leading + question mark. + + Example: `'?query=string'` + +* `path`: Concatenation of `pathname` and `search`. + + Example: `'/p/a/t/h?query=string'` + +* `query`: Either the 'params' portion of the query string, or a + querystring-parsed object. + + Example: `'query=string'` or `{'query':'string'}` + +* `hash`: The 'fragment' portion of the URL including the pound-sign. + + Example: `'#hash'` + +The following methods are provided by the URL module: + +### url.parse(urlStr, [parseQueryString], [slashesDenoteHost]) + +Take a URL string, and return an object. + +Pass `true` as the second argument to also parse +the query string using the `querystring` module. +Defaults to `false`. + +Pass `true` as the third argument to treat `//foo/bar` as +`{ host: 'foo', pathname: '/bar' }` rather than +`{ pathname: '//foo/bar' }`. Defaults to `false`. + +### url.format(urlObj) + +Take a parsed URL object, and return a formatted URL string. + +* `href` will be ignored. +* `protocol` is treated the same with or without the trailing `:` (colon). + * The protocols `http`, `https`, `ftp`, `gopher`, `file` will be + postfixed with `://` (colon-slash-slash). + * All other protocols `mailto`, `xmpp`, `aim`, `sftp`, `foo`, etc will + be postfixed with `:` (colon) +* `auth` will be used if present. +* `hostname` will only be used if `host` is absent. +* `port` will only be used if `host` is absent. +* `host` will be used in place of `hostname` and `port` +* `pathname` is treated the same with or without the leading `/` (slash) +* `search` will be used in place of `query` +* `query` (object; see `querystring`) will only be used if `search` is absent. +* `search` is treated the same with or without the leading `?` (question mark) +* `hash` is treated the same with or without the leading `#` (pound sign, anchor) + +### url.resolve(from, to) + +Take a base URL, and a href URL, and resolve them as a browser would for +an anchor tag. Examples: + + url.resolve('/one/two/three', 'four') // '/one/two/four' + url.resolve('http://example.com/', '/one') // 'http://example.com/one' + url.resolve('http://example.com/one', '/two') // 'http://example.com/two' diff --git a/node_modules/url/node_modules/punycode/LICENSE-MIT.txt b/node_modules/url/node_modules/punycode/LICENSE-MIT.txt new file mode 100644 index 0000000..a41e0a7 --- /dev/null +++ b/node_modules/url/node_modules/punycode/LICENSE-MIT.txt @@ -0,0 +1,20 @@ +Copyright Mathias Bynens + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/url/node_modules/punycode/README.md b/node_modules/url/node_modules/punycode/README.md new file mode 100644 index 0000000..831e637 --- /dev/null +++ b/node_modules/url/node_modules/punycode/README.md @@ -0,0 +1,176 @@ +# Punycode.js [![Build status](https://travis-ci.org/bestiejs/punycode.js.svg?branch=master)](https://travis-ci.org/bestiejs/punycode.js) [![Code coverage status](http://img.shields.io/coveralls/bestiejs/punycode.js/master.svg)](https://coveralls.io/r/bestiejs/punycode.js) [![Dependency status](https://gemnasium.com/bestiejs/punycode.js.svg)](https://gemnasium.com/bestiejs/punycode.js) + +A robust Punycode converter that fully complies to [RFC 3492](http://tools.ietf.org/html/rfc3492) and [RFC 5891](http://tools.ietf.org/html/rfc5891), and works on nearly all JavaScript platforms. + +This JavaScript library is the result of comparing, optimizing and documenting different open-source implementations of the Punycode algorithm: + +* [The C example code from RFC 3492](http://tools.ietf.org/html/rfc3492#appendix-C) +* [`punycode.c` by _Markus W. Scherer_ (IBM)](http://opensource.apple.com/source/ICU/ICU-400.42/icuSources/common/punycode.c) +* [`punycode.c` by _Ben Noordhuis_](https://github.com/bnoordhuis/punycode/blob/master/punycode.c) +* [JavaScript implementation by _some_](http://stackoverflow.com/questions/183485/can-anyone-recommend-a-good-free-javascript-for-punycode-to-unicode-conversion/301287#301287) +* [`punycode.js` by _Ben Noordhuis_](https://github.com/joyent/node/blob/426298c8c1c0d5b5224ac3658c41e7c2a3fe9377/lib/punycode.js) (note: [not fully compliant](https://github.com/joyent/node/issues/2072)) + +This project is [bundled](https://github.com/joyent/node/blob/master/lib/punycode.js) with [Node.js v0.6.2+](https://github.com/joyent/node/compare/975f1930b1...61e796decc). + +## Installation + +Via [npm](http://npmjs.org/) (only required for Node.js releases older than v0.6.2): + +```bash +npm install punycode +``` + +Via [Bower](http://bower.io/): + +```bash +bower install punycode +``` + +Via [Component](https://github.com/component/component): + +```bash +component install bestiejs/punycode.js +``` + +In a browser: + +```html + +``` + +In [Narwhal](http://narwhaljs.org/), [Node.js](http://nodejs.org/), and [RingoJS](http://ringojs.org/): + +```js +var punycode = require('punycode'); +``` + +In [Rhino](http://www.mozilla.org/rhino/): + +```js +load('punycode.js'); +``` + +Using an AMD loader like [RequireJS](http://requirejs.org/): + +```js +require( + { + 'paths': { + 'punycode': 'path/to/punycode' + } + }, + ['punycode'], + function(punycode) { + console.log(punycode); + } +); +``` + +## API + +### `punycode.decode(string)` + +Converts a Punycode string of ASCII symbols to a string of Unicode symbols. + +```js +// decode domain name parts +punycode.decode('maana-pta'); // 'mañana' +punycode.decode('--dqo34k'); // '☃-⌘' +``` + +### `punycode.encode(string)` + +Converts a string of Unicode symbols to a Punycode string of ASCII symbols. + +```js +// encode domain name parts +punycode.encode('mañana'); // 'maana-pta' +punycode.encode('☃-⌘'); // '--dqo34k' +``` + +### `punycode.toUnicode(input)` + +Converts a Punycode string representing a domain name or an email address to Unicode. Only the Punycoded parts of the input will be converted, i.e. it doesn’t matter if you call it on a string that has already been converted to Unicode. + +```js +// decode domain names +punycode.toUnicode('xn--maana-pta.com'); +// → 'mañana.com' +punycode.toUnicode('xn----dqo34k.com'); +// → '☃-⌘.com' + +// decode email addresses +punycode.toUnicode('джумла@xn--p-8sbkgc5ag7bhce.xn--ba-lmcq'); +// → 'джумла@джpумлатест.bрфa' +``` + +### `punycode.toASCII(input)` + +Converts a Unicode string representing a domain name or an email address to Punycode. Only the non-ASCII parts of the input will be converted, i.e. it doesn’t matter if you call it with a domain that's already in ASCII. + +```js +// encode domain names +punycode.toASCII('mañana.com'); +// → 'xn--maana-pta.com' +punycode.toASCII('☃-⌘.com'); +// → 'xn----dqo34k.com' + +// encode email addresses +punycode.toASCII('джумла@джpумлатест.bрфa'); +// → 'джумла@xn--p-8sbkgc5ag7bhce.xn--ba-lmcq' +``` + +### `punycode.ucs2` + +#### `punycode.ucs2.decode(string)` + +Creates an array containing the numeric code point values of each Unicode symbol in the string. While [JavaScript uses UCS-2 internally](https://mathiasbynens.be/notes/javascript-encoding), this function will convert a pair of surrogate halves (each of which UCS-2 exposes as separate characters) into a single code point, matching UTF-16. + +```js +punycode.ucs2.decode('abc'); +// → [0x61, 0x62, 0x63] +// surrogate pair for U+1D306 TETRAGRAM FOR CENTRE: +punycode.ucs2.decode('\uD834\uDF06'); +// → [0x1D306] +``` + +#### `punycode.ucs2.encode(codePoints)` + +Creates a string based on an array of numeric code point values. + +```js +punycode.ucs2.encode([0x61, 0x62, 0x63]); +// → 'abc' +punycode.ucs2.encode([0x1D306]); +// → '\uD834\uDF06' +``` + +### `punycode.version` + +A string representing the current Punycode.js version number. + +## Unit tests & code coverage + +After cloning this repository, run `npm install --dev` to install the dependencies needed for Punycode.js development and testing. You may want to install Istanbul _globally_ using `npm install istanbul -g`. + +Once that’s done, you can run the unit tests in Node using `npm test` or `node tests/tests.js`. To run the tests in Rhino, Ringo, Narwhal, PhantomJS, and web browsers as well, use `grunt test`. + +To generate the code coverage report, use `grunt cover`. + +Feel free to fork if you see possible improvements! + +## Author + +| [![twitter/mathias](https://gravatar.com/avatar/24e08a9ea84deb17ae121074d0f17125?s=70)](https://twitter.com/mathias "Follow @mathias on Twitter") | +|---| +| [Mathias Bynens](https://mathiasbynens.be/) | + +## Contributors + +| [![twitter/jdalton](https://gravatar.com/avatar/299a3d891ff1920b69c364d061007043?s=70)](https://twitter.com/jdalton "Follow @jdalton on Twitter") | +|---| +| [John-David Dalton](http://allyoucanleet.com/) | + +## License + +Punycode.js is available under the [MIT](https://mths.be/mit) license. diff --git a/node_modules/url/node_modules/punycode/package.json b/node_modules/url/node_modules/punycode/package.json new file mode 100644 index 0000000..c9272d9 --- /dev/null +++ b/node_modules/url/node_modules/punycode/package.json @@ -0,0 +1,80 @@ +{ + "_from": "punycode@1.3.2", + "_id": "punycode@1.3.2", + "_inBundle": false, + "_integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", + "_location": "/url/punycode", + "_phantomChildren": {}, + "_requested": { + "type": "version", + "registry": true, + "raw": "punycode@1.3.2", + "name": "punycode", + "escapedName": "punycode", + "rawSpec": "1.3.2", + "saveSpec": null, + "fetchSpec": "1.3.2" + }, + "_requiredBy": [ + "/url" + ], + "_resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "_shasum": "9653a036fb7c1ee42342f2325cceefea3926c48d", + "_spec": "punycode@1.3.2", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\url", + "author": { + "name": "Mathias Bynens", + "url": "https://mathiasbynens.be/" + }, + "bugs": { + "url": "https://github.com/bestiejs/punycode.js/issues" + }, + "bundleDependencies": false, + "contributors": [ + { + "name": "Mathias Bynens", + "url": "https://mathiasbynens.be/" + }, + { + "name": "John-David Dalton", + "url": "http://allyoucanleet.com/" + } + ], + "deprecated": false, + "description": "A robust Punycode converter that fully complies to RFC 3492 and RFC 5891, and works on nearly all JavaScript platforms.", + "devDependencies": { + "coveralls": "^2.10.1", + "grunt": "^0.4.5", + "grunt-contrib-uglify": "^0.5.0", + "grunt-shell": "^0.7.0", + "istanbul": "^0.2.13", + "qunit-extras": "^1.2.0", + "qunitjs": "~1.11.0", + "requirejs": "^2.1.14" + }, + "files": [ + "LICENSE-MIT.txt", + "punycode.js" + ], + "homepage": "https://mths.be/punycode", + "keywords": [ + "punycode", + "unicode", + "idn", + "idna", + "dns", + "url", + "domain" + ], + "license": "MIT", + "main": "punycode.js", + "name": "punycode", + "repository": { + "type": "git", + "url": "git+https://github.com/bestiejs/punycode.js.git" + }, + "scripts": { + "test": "node tests/tests.js" + }, + "version": "1.3.2" +} diff --git a/node_modules/url/node_modules/punycode/punycode.js b/node_modules/url/node_modules/punycode/punycode.js new file mode 100644 index 0000000..ac68597 --- /dev/null +++ b/node_modules/url/node_modules/punycode/punycode.js @@ -0,0 +1,530 @@ +/*! https://mths.be/punycode v1.3.2 by @mathias */ +;(function(root) { + + /** Detect free variables */ + var freeExports = typeof exports == 'object' && exports && + !exports.nodeType && exports; + var freeModule = typeof module == 'object' && module && + !module.nodeType && module; + var freeGlobal = typeof global == 'object' && global; + if ( + freeGlobal.global === freeGlobal || + freeGlobal.window === freeGlobal || + freeGlobal.self === freeGlobal + ) { + root = freeGlobal; + } + + /** + * The `punycode` object. + * @name punycode + * @type Object + */ + var punycode, + + /** Highest positive signed 32-bit float value */ + maxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1 + + /** Bootstring parameters */ + base = 36, + tMin = 1, + tMax = 26, + skew = 38, + damp = 700, + initialBias = 72, + initialN = 128, // 0x80 + delimiter = '-', // '\x2D' + + /** Regular expressions */ + regexPunycode = /^xn--/, + regexNonASCII = /[^\x20-\x7E]/, // unprintable ASCII chars + non-ASCII chars + regexSeparators = /[\x2E\u3002\uFF0E\uFF61]/g, // RFC 3490 separators + + /** Error messages */ + errors = { + 'overflow': 'Overflow: input needs wider integers to process', + 'not-basic': 'Illegal input >= 0x80 (not a basic code point)', + 'invalid-input': 'Invalid input' + }, + + /** Convenience shortcuts */ + baseMinusTMin = base - tMin, + floor = Math.floor, + stringFromCharCode = String.fromCharCode, + + /** Temporary variable */ + key; + + /*--------------------------------------------------------------------------*/ + + /** + * A generic error utility function. + * @private + * @param {String} type The error type. + * @returns {Error} Throws a `RangeError` with the applicable error message. + */ + function error(type) { + throw RangeError(errors[type]); + } + + /** + * A generic `Array#map` utility function. + * @private + * @param {Array} array The array to iterate over. + * @param {Function} callback The function that gets called for every array + * item. + * @returns {Array} A new array of values returned by the callback function. + */ + function map(array, fn) { + var length = array.length; + var result = []; + while (length--) { + result[length] = fn(array[length]); + } + return result; + } + + /** + * A simple `Array#map`-like wrapper to work with domain name strings or email + * addresses. + * @private + * @param {String} domain The domain name or email address. + * @param {Function} callback The function that gets called for every + * character. + * @returns {Array} A new string of characters returned by the callback + * function. + */ + function mapDomain(string, fn) { + var parts = string.split('@'); + var result = ''; + if (parts.length > 1) { + // In email addresses, only the domain name should be punycoded. Leave + // the local part (i.e. everything up to `@`) intact. + result = parts[0] + '@'; + string = parts[1]; + } + // Avoid `split(regex)` for IE8 compatibility. See #17. + string = string.replace(regexSeparators, '\x2E'); + var labels = string.split('.'); + var encoded = map(labels, fn).join('.'); + return result + encoded; + } + + /** + * Creates an array containing the numeric code points of each Unicode + * character in the string. While JavaScript uses UCS-2 internally, + * this function will convert a pair of surrogate halves (each of which + * UCS-2 exposes as separate characters) into a single code point, + * matching UTF-16. + * @see `punycode.ucs2.encode` + * @see + * @memberOf punycode.ucs2 + * @name decode + * @param {String} string The Unicode input string (UCS-2). + * @returns {Array} The new array of code points. + */ + function ucs2decode(string) { + var output = [], + counter = 0, + length = string.length, + value, + extra; + while (counter < length) { + value = string.charCodeAt(counter++); + if (value >= 0xD800 && value <= 0xDBFF && counter < length) { + // high surrogate, and there is a next character + extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { // low surrogate + output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); + } else { + // unmatched surrogate; only append this code unit, in case the next + // code unit is the high surrogate of a surrogate pair + output.push(value); + counter--; + } + } else { + output.push(value); + } + } + return output; + } + + /** + * Creates a string based on an array of numeric code points. + * @see `punycode.ucs2.decode` + * @memberOf punycode.ucs2 + * @name encode + * @param {Array} codePoints The array of numeric code points. + * @returns {String} The new Unicode string (UCS-2). + */ + function ucs2encode(array) { + return map(array, function(value) { + var output = ''; + if (value > 0xFFFF) { + value -= 0x10000; + output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800); + value = 0xDC00 | value & 0x3FF; + } + output += stringFromCharCode(value); + return output; + }).join(''); + } + + /** + * Converts a basic code point into a digit/integer. + * @see `digitToBasic()` + * @private + * @param {Number} codePoint The basic numeric code point value. + * @returns {Number} The numeric value of a basic code point (for use in + * representing integers) in the range `0` to `base - 1`, or `base` if + * the code point does not represent a value. + */ + function basicToDigit(codePoint) { + if (codePoint - 48 < 10) { + return codePoint - 22; + } + if (codePoint - 65 < 26) { + return codePoint - 65; + } + if (codePoint - 97 < 26) { + return codePoint - 97; + } + return base; + } + + /** + * Converts a digit/integer into a basic code point. + * @see `basicToDigit()` + * @private + * @param {Number} digit The numeric value of a basic code point. + * @returns {Number} The basic code point whose value (when used for + * representing integers) is `digit`, which needs to be in the range + * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is + * used; else, the lowercase form is used. The behavior is undefined + * if `flag` is non-zero and `digit` has no uppercase form. + */ + function digitToBasic(digit, flag) { + // 0..25 map to ASCII a..z or A..Z + // 26..35 map to ASCII 0..9 + return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5); + } + + /** + * Bias adaptation function as per section 3.4 of RFC 3492. + * http://tools.ietf.org/html/rfc3492#section-3.4 + * @private + */ + function adapt(delta, numPoints, firstTime) { + var k = 0; + delta = firstTime ? floor(delta / damp) : delta >> 1; + delta += floor(delta / numPoints); + for (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) { + delta = floor(delta / baseMinusTMin); + } + return floor(k + (baseMinusTMin + 1) * delta / (delta + skew)); + } + + /** + * Converts a Punycode string of ASCII-only symbols to a string of Unicode + * symbols. + * @memberOf punycode + * @param {String} input The Punycode string of ASCII-only symbols. + * @returns {String} The resulting string of Unicode symbols. + */ + function decode(input) { + // Don't use UCS-2 + var output = [], + inputLength = input.length, + out, + i = 0, + n = initialN, + bias = initialBias, + basic, + j, + index, + oldi, + w, + k, + digit, + t, + /** Cached calculation results */ + baseMinusT; + + // Handle the basic code points: let `basic` be the number of input code + // points before the last delimiter, or `0` if there is none, then copy + // the first basic code points to the output. + + basic = input.lastIndexOf(delimiter); + if (basic < 0) { + basic = 0; + } + + for (j = 0; j < basic; ++j) { + // if it's not a basic code point + if (input.charCodeAt(j) >= 0x80) { + error('not-basic'); + } + output.push(input.charCodeAt(j)); + } + + // Main decoding loop: start just after the last delimiter if any basic code + // points were copied; start at the beginning otherwise. + + for (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) { + + // `index` is the index of the next character to be consumed. + // Decode a generalized variable-length integer into `delta`, + // which gets added to `i`. The overflow checking is easier + // if we increase `i` as we go, then subtract off its starting + // value at the end to obtain `delta`. + for (oldi = i, w = 1, k = base; /* no condition */; k += base) { + + if (index >= inputLength) { + error('invalid-input'); + } + + digit = basicToDigit(input.charCodeAt(index++)); + + if (digit >= base || digit > floor((maxInt - i) / w)) { + error('overflow'); + } + + i += digit * w; + t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); + + if (digit < t) { + break; + } + + baseMinusT = base - t; + if (w > floor(maxInt / baseMinusT)) { + error('overflow'); + } + + w *= baseMinusT; + + } + + out = output.length + 1; + bias = adapt(i - oldi, out, oldi == 0); + + // `i` was supposed to wrap around from `out` to `0`, + // incrementing `n` each time, so we'll fix that now: + if (floor(i / out) > maxInt - n) { + error('overflow'); + } + + n += floor(i / out); + i %= out; + + // Insert `n` at position `i` of the output + output.splice(i++, 0, n); + + } + + return ucs2encode(output); + } + + /** + * Converts a string of Unicode symbols (e.g. a domain name label) to a + * Punycode string of ASCII-only symbols. + * @memberOf punycode + * @param {String} input The string of Unicode symbols. + * @returns {String} The resulting Punycode string of ASCII-only symbols. + */ + function encode(input) { + var n, + delta, + handledCPCount, + basicLength, + bias, + j, + m, + q, + k, + t, + currentValue, + output = [], + /** `inputLength` will hold the number of code points in `input`. */ + inputLength, + /** Cached calculation results */ + handledCPCountPlusOne, + baseMinusT, + qMinusT; + + // Convert the input in UCS-2 to Unicode + input = ucs2decode(input); + + // Cache the length + inputLength = input.length; + + // Initialize the state + n = initialN; + delta = 0; + bias = initialBias; + + // Handle the basic code points + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue < 0x80) { + output.push(stringFromCharCode(currentValue)); + } + } + + handledCPCount = basicLength = output.length; + + // `handledCPCount` is the number of code points that have been handled; + // `basicLength` is the number of basic code points. + + // Finish the basic string - if it is not empty - with a delimiter + if (basicLength) { + output.push(delimiter); + } + + // Main encoding loop: + while (handledCPCount < inputLength) { + + // All non-basic code points < n have been handled already. Find the next + // larger one: + for (m = maxInt, j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue >= n && currentValue < m) { + m = currentValue; + } + } + + // Increase `delta` enough to advance the decoder's state to , + // but guard against overflow + handledCPCountPlusOne = handledCPCount + 1; + if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) { + error('overflow'); + } + + delta += (m - n) * handledCPCountPlusOne; + n = m; + + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + + if (currentValue < n && ++delta > maxInt) { + error('overflow'); + } + + if (currentValue == n) { + // Represent delta as a generalized variable-length integer + for (q = delta, k = base; /* no condition */; k += base) { + t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); + if (q < t) { + break; + } + qMinusT = q - t; + baseMinusT = base - t; + output.push( + stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)) + ); + q = floor(qMinusT / baseMinusT); + } + + output.push(stringFromCharCode(digitToBasic(q, 0))); + bias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength); + delta = 0; + ++handledCPCount; + } + } + + ++delta; + ++n; + + } + return output.join(''); + } + + /** + * Converts a Punycode string representing a domain name or an email address + * to Unicode. Only the Punycoded parts of the input will be converted, i.e. + * it doesn't matter if you call it on a string that has already been + * converted to Unicode. + * @memberOf punycode + * @param {String} input The Punycoded domain name or email address to + * convert to Unicode. + * @returns {String} The Unicode representation of the given Punycode + * string. + */ + function toUnicode(input) { + return mapDomain(input, function(string) { + return regexPunycode.test(string) + ? decode(string.slice(4).toLowerCase()) + : string; + }); + } + + /** + * Converts a Unicode string representing a domain name or an email address to + * Punycode. Only the non-ASCII parts of the domain name will be converted, + * i.e. it doesn't matter if you call it with a domain that's already in + * ASCII. + * @memberOf punycode + * @param {String} input The domain name or email address to convert, as a + * Unicode string. + * @returns {String} The Punycode representation of the given domain name or + * email address. + */ + function toASCII(input) { + return mapDomain(input, function(string) { + return regexNonASCII.test(string) + ? 'xn--' + encode(string) + : string; + }); + } + + /*--------------------------------------------------------------------------*/ + + /** Define the public API */ + punycode = { + /** + * A string representing the current Punycode.js version number. + * @memberOf punycode + * @type String + */ + 'version': '1.3.2', + /** + * An object of methods to convert from JavaScript's internal character + * representation (UCS-2) to Unicode code points, and back. + * @see + * @memberOf punycode + * @type Object + */ + 'ucs2': { + 'decode': ucs2decode, + 'encode': ucs2encode + }, + 'decode': decode, + 'encode': encode, + 'toASCII': toASCII, + 'toUnicode': toUnicode + }; + + /** Expose `punycode` */ + // Some AMD build optimizers, like r.js, check for specific condition patterns + // like the following: + if ( + typeof define == 'function' && + typeof define.amd == 'object' && + define.amd + ) { + define('punycode', function() { + return punycode; + }); + } else if (freeExports && freeModule) { + if (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+ + freeModule.exports = punycode; + } else { // in Narwhal or RingoJS v0.7.0- + for (key in punycode) { + punycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]); + } + } + } else { // in Rhino or a web browser + root.punycode = punycode; + } + +}(this)); diff --git a/node_modules/url/package.json b/node_modules/url/package.json new file mode 100644 index 0000000..acd6687 --- /dev/null +++ b/node_modules/url/package.json @@ -0,0 +1,53 @@ +{ + "_from": "url@~0.11.0", + "_id": "url@0.11.0", + "_inBundle": false, + "_integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "_location": "/url", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "url@~0.11.0", + "name": "url", + "escapedName": "url", + "rawSpec": "~0.11.0", + "saveSpec": null, + "fetchSpec": "~0.11.0" + }, + "_requiredBy": [ + "/@tensorflow/tfjs-converter" + ], + "_resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "_shasum": "3838e97cfc60521eb73c525a8e55bfdd9e2e28f1", + "_spec": "url@~0.11.0", + "_where": "C:\\Users\\Gavin\\Desktop\\opensource\\ratzbot\\node_modules\\@tensorflow\\tfjs-converter", + "bugs": { + "url": "https://github.com/defunctzombie/node-url/issues" + }, + "bundleDependencies": false, + "dependencies": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "deprecated": false, + "description": "The core `url` packaged standalone for use with Browserify.", + "devDependencies": { + "assert": "1.1.1", + "mocha": "1.18.2", + "zuul": "3.3.0" + }, + "homepage": "https://github.com/defunctzombie/node-url#readme", + "license": "MIT", + "main": "./url.js", + "name": "url", + "repository": { + "type": "git", + "url": "git+https://github.com/defunctzombie/node-url.git" + }, + "scripts": { + "test": "mocha --ui qunit test.js && zuul -- test.js", + "test-local": "zuul --local -- test.js" + }, + "version": "0.11.0" +} diff --git a/node_modules/url/test.js b/node_modules/url/test.js new file mode 100644 index 0000000..3b7d335 --- /dev/null +++ b/node_modules/url/test.js @@ -0,0 +1,1599 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +var assert = require('assert'); + +var url = require('./url'); + +// URLs to parse, and expected data +// { url : parsed } +var parseTests = { + '//some_path' : { + 'href': '//some_path', + 'pathname': '//some_path', + 'path': '//some_path' + }, + + 'http:\\\\evil-phisher\\foo.html#h\\a\\s\\h': { + protocol: 'http:', + slashes: true, + host: 'evil-phisher', + hostname: 'evil-phisher', + pathname: '/foo.html', + path: '/foo.html', + hash: '#h%5Ca%5Cs%5Ch', + href: 'http://evil-phisher/foo.html#h%5Ca%5Cs%5Ch' + }, + + 'http:\\\\evil-phisher\\foo.html?json="\\"foo\\""#h\\a\\s\\h': { + protocol: 'http:', + slashes: true, + host: 'evil-phisher', + hostname: 'evil-phisher', + pathname: '/foo.html', + search: '?json=%22%5C%22foo%5C%22%22', + query: 'json=%22%5C%22foo%5C%22%22', + path: '/foo.html?json=%22%5C%22foo%5C%22%22', + hash: '#h%5Ca%5Cs%5Ch', + href: 'http://evil-phisher/foo.html?json=%22%5C%22foo%5C%22%22#h%5Ca%5Cs%5Ch' + }, + + 'http:\\\\evil-phisher\\foo.html#h\\a\\s\\h?blarg': { + protocol: 'http:', + slashes: true, + host: 'evil-phisher', + hostname: 'evil-phisher', + pathname: '/foo.html', + path: '/foo.html', + hash: '#h%5Ca%5Cs%5Ch?blarg', + href: 'http://evil-phisher/foo.html#h%5Ca%5Cs%5Ch?blarg' + }, + + + 'http:\\\\evil-phisher\\foo.html': { + protocol: 'http:', + slashes: true, + host: 'evil-phisher', + hostname: 'evil-phisher', + pathname: '/foo.html', + path: '/foo.html', + href: 'http://evil-phisher/foo.html' + }, + + 'HTTP://www.example.com/' : { + 'href': 'http://www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'HTTP://www.example.com' : { + 'href': 'http://www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://www.ExAmPlE.com/' : { + 'href': 'http://www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://user:pw@www.ExAmPlE.com/' : { + 'href': 'http://user:pw@www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pw', + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://USER:PW@www.ExAmPlE.com/' : { + 'href': 'http://USER:PW@www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'auth': 'USER:PW', + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://user@www.example.com/' : { + 'href': 'http://user@www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user', + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://user%3Apw@www.example.com/' : { + 'href': 'http://user:pw@www.example.com/', + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pw', + 'host': 'www.example.com', + 'hostname': 'www.example.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://x.com/path?that\'s#all, folks' : { + 'href': 'http://x.com/path?that%27s#all,%20folks', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x.com', + 'hostname': 'x.com', + 'search': '?that%27s', + 'query': 'that%27s', + 'pathname': '/path', + 'hash': '#all,%20folks', + 'path': '/path?that%27s' + }, + + 'HTTP://X.COM/Y' : { + 'href': 'http://x.com/Y', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x.com', + 'hostname': 'x.com', + 'pathname': '/Y', + 'path': '/Y' + }, + + // + not an invalid host character + // per https://url.spec.whatwg.org/#host-parsing + 'http://x.y.com+a/b/c' : { + 'href': 'http://x.y.com+a/b/c', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x.y.com+a', + 'hostname': 'x.y.com+a', + 'pathname': '/b/c', + 'path': '/b/c' + }, + + // an unexpected invalid char in the hostname. + 'HtTp://x.y.cOm;a/b/c?d=e#f gi' : { + 'href': 'http://x.y.com/;a/b/c?d=e#f%20g%3Ch%3Ei', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x.y.com', + 'hostname': 'x.y.com', + 'pathname': ';a/b/c', + 'search': '?d=e', + 'query': 'd=e', + 'hash': '#f%20g%3Ch%3Ei', + 'path': ';a/b/c?d=e' + }, + + // make sure that we don't accidentally lcast the path parts. + 'HtTp://x.y.cOm;A/b/c?d=e#f gi' : { + 'href': 'http://x.y.com/;A/b/c?d=e#f%20g%3Ch%3Ei', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x.y.com', + 'hostname': 'x.y.com', + 'pathname': ';A/b/c', + 'search': '?d=e', + 'query': 'd=e', + 'hash': '#f%20g%3Ch%3Ei', + 'path': ';A/b/c?d=e' + }, + + 'http://x...y...#p': { + 'href': 'http://x...y.../#p', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x...y...', + 'hostname': 'x...y...', + 'hash': '#p', + 'pathname': '/', + 'path': '/' + }, + + 'http://x/p/"quoted"': { + 'href': 'http://x/p/%22quoted%22', + 'protocol': 'http:', + 'slashes': true, + 'host': 'x', + 'hostname': 'x', + 'pathname': '/p/%22quoted%22', + 'path': '/p/%22quoted%22' + }, + + ' Is a URL!': { + 'href': '%3Chttp://goo.corn/bread%3E%20Is%20a%20URL!', + 'pathname': '%3Chttp://goo.corn/bread%3E%20Is%20a%20URL!', + 'path': '%3Chttp://goo.corn/bread%3E%20Is%20a%20URL!' + }, + + 'http://www.narwhaljs.org/blog/categories?id=news' : { + 'href': 'http://www.narwhaljs.org/blog/categories?id=news', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.narwhaljs.org', + 'hostname': 'www.narwhaljs.org', + 'search': '?id=news', + 'query': 'id=news', + 'pathname': '/blog/categories', + 'path': '/blog/categories?id=news' + }, + + 'http://mt0.google.com/vt/lyrs=m@114&hl=en&src=api&x=2&y=2&z=3&s=' : { + 'href': 'http://mt0.google.com/vt/lyrs=m@114&hl=en&src=api&x=2&y=2&z=3&s=', + 'protocol': 'http:', + 'slashes': true, + 'host': 'mt0.google.com', + 'hostname': 'mt0.google.com', + 'pathname': '/vt/lyrs=m@114&hl=en&src=api&x=2&y=2&z=3&s=', + 'path': '/vt/lyrs=m@114&hl=en&src=api&x=2&y=2&z=3&s=' + }, + + 'http://mt0.google.com/vt/lyrs=m@114???&hl=en&src=api&x=2&y=2&z=3&s=' : { + 'href': 'http://mt0.google.com/vt/lyrs=m@114???&hl=en&src=api' + + '&x=2&y=2&z=3&s=', + 'protocol': 'http:', + 'slashes': true, + 'host': 'mt0.google.com', + 'hostname': 'mt0.google.com', + 'search': '???&hl=en&src=api&x=2&y=2&z=3&s=', + 'query': '??&hl=en&src=api&x=2&y=2&z=3&s=', + 'pathname': '/vt/lyrs=m@114', + 'path': '/vt/lyrs=m@114???&hl=en&src=api&x=2&y=2&z=3&s=' + }, + + 'http://user:pass@mt0.google.com/vt/lyrs=m@114???&hl=en&src=api&x=2&y=2&z=3&s=': + { + 'href': 'http://user:pass@mt0.google.com/vt/lyrs=m@114???' + + '&hl=en&src=api&x=2&y=2&z=3&s=', + 'protocol': 'http:', + 'slashes': true, + 'host': 'mt0.google.com', + 'auth': 'user:pass', + 'hostname': 'mt0.google.com', + 'search': '???&hl=en&src=api&x=2&y=2&z=3&s=', + 'query': '??&hl=en&src=api&x=2&y=2&z=3&s=', + 'pathname': '/vt/lyrs=m@114', + 'path': '/vt/lyrs=m@114???&hl=en&src=api&x=2&y=2&z=3&s=' + }, + + 'file:///etc/passwd' : { + 'href': 'file:///etc/passwd', + 'slashes': true, + 'protocol': 'file:', + 'pathname': '/etc/passwd', + 'hostname': '', + 'host': '', + 'path': '/etc/passwd' + }, + + 'file://localhost/etc/passwd' : { + 'href': 'file://localhost/etc/passwd', + 'protocol': 'file:', + 'slashes': true, + 'pathname': '/etc/passwd', + 'hostname': 'localhost', + 'host': 'localhost', + 'path': '/etc/passwd' + }, + + 'file://foo/etc/passwd' : { + 'href': 'file://foo/etc/passwd', + 'protocol': 'file:', + 'slashes': true, + 'pathname': '/etc/passwd', + 'hostname': 'foo', + 'host': 'foo', + 'path': '/etc/passwd' + }, + + 'file:///etc/node/' : { + 'href': 'file:///etc/node/', + 'slashes': true, + 'protocol': 'file:', + 'pathname': '/etc/node/', + 'hostname': '', + 'host': '', + 'path': '/etc/node/' + }, + + 'file://localhost/etc/node/' : { + 'href': 'file://localhost/etc/node/', + 'protocol': 'file:', + 'slashes': true, + 'pathname': '/etc/node/', + 'hostname': 'localhost', + 'host': 'localhost', + 'path': '/etc/node/' + }, + + 'file://foo/etc/node/' : { + 'href': 'file://foo/etc/node/', + 'protocol': 'file:', + 'slashes': true, + 'pathname': '/etc/node/', + 'hostname': 'foo', + 'host': 'foo', + 'path': '/etc/node/' + }, + + 'http:/baz/../foo/bar' : { + 'href': 'http:/baz/../foo/bar', + 'protocol': 'http:', + 'pathname': '/baz/../foo/bar', + 'path': '/baz/../foo/bar' + }, + + 'http://user:pass@example.com:8000/foo/bar?baz=quux#frag' : { + 'href': 'http://user:pass@example.com:8000/foo/bar?baz=quux#frag', + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com:8000', + 'auth': 'user:pass', + 'port': '8000', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?baz=quux', + 'query': 'baz=quux', + 'pathname': '/foo/bar', + 'path': '/foo/bar?baz=quux' + }, + + '//user:pass@example.com:8000/foo/bar?baz=quux#frag' : { + 'href': '//user:pass@example.com:8000/foo/bar?baz=quux#frag', + 'slashes': true, + 'host': 'example.com:8000', + 'auth': 'user:pass', + 'port': '8000', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?baz=quux', + 'query': 'baz=quux', + 'pathname': '/foo/bar', + 'path': '/foo/bar?baz=quux' + }, + + '/foo/bar?baz=quux#frag' : { + 'href': '/foo/bar?baz=quux#frag', + 'hash': '#frag', + 'search': '?baz=quux', + 'query': 'baz=quux', + 'pathname': '/foo/bar', + 'path': '/foo/bar?baz=quux' + }, + + 'http:/foo/bar?baz=quux#frag' : { + 'href': 'http:/foo/bar?baz=quux#frag', + 'protocol': 'http:', + 'hash': '#frag', + 'search': '?baz=quux', + 'query': 'baz=quux', + 'pathname': '/foo/bar', + 'path': '/foo/bar?baz=quux' + }, + + 'mailto:foo@bar.com?subject=hello' : { + 'href': 'mailto:foo@bar.com?subject=hello', + 'protocol': 'mailto:', + 'host': 'bar.com', + 'auth' : 'foo', + 'hostname' : 'bar.com', + 'search': '?subject=hello', + 'query': 'subject=hello', + 'path': '?subject=hello' + }, + + 'javascript:alert(\'hello\');' : { + 'href': 'javascript:alert(\'hello\');', + 'protocol': 'javascript:', + 'pathname': 'alert(\'hello\');', + 'path': 'alert(\'hello\');' + }, + + 'xmpp:isaacschlueter@jabber.org' : { + 'href': 'xmpp:isaacschlueter@jabber.org', + 'protocol': 'xmpp:', + 'host': 'jabber.org', + 'auth': 'isaacschlueter', + 'hostname': 'jabber.org' + }, + + 'http://atpass:foo%40bar@127.0.0.1:8080/path?search=foo#bar' : { + 'href' : 'http://atpass:foo%40bar@127.0.0.1:8080/path?search=foo#bar', + 'protocol' : 'http:', + 'slashes': true, + 'host' : '127.0.0.1:8080', + 'auth' : 'atpass:foo@bar', + 'hostname' : '127.0.0.1', + 'port' : '8080', + 'pathname': '/path', + 'search' : '?search=foo', + 'query' : 'search=foo', + 'hash' : '#bar', + 'path': '/path?search=foo' + }, + + 'svn+ssh://foo/bar': { + 'href': 'svn+ssh://foo/bar', + 'host': 'foo', + 'hostname': 'foo', + 'protocol': 'svn+ssh:', + 'pathname': '/bar', + 'path': '/bar', + 'slashes': true + }, + + 'dash-test://foo/bar': { + 'href': 'dash-test://foo/bar', + 'host': 'foo', + 'hostname': 'foo', + 'protocol': 'dash-test:', + 'pathname': '/bar', + 'path': '/bar', + 'slashes': true + }, + + 'dash-test:foo/bar': { + 'href': 'dash-test:foo/bar', + 'host': 'foo', + 'hostname': 'foo', + 'protocol': 'dash-test:', + 'pathname': '/bar', + 'path': '/bar' + }, + + 'dot.test://foo/bar': { + 'href': 'dot.test://foo/bar', + 'host': 'foo', + 'hostname': 'foo', + 'protocol': 'dot.test:', + 'pathname': '/bar', + 'path': '/bar', + 'slashes': true + }, + + 'dot.test:foo/bar': { + 'href': 'dot.test:foo/bar', + 'host': 'foo', + 'hostname': 'foo', + 'protocol': 'dot.test:', + 'pathname': '/bar', + 'path': '/bar' + }, + + // IDNA tests + 'http://www.日本語.com/' : { + 'href': 'http://www.xn--wgv71a119e.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.xn--wgv71a119e.com', + 'hostname': 'www.xn--wgv71a119e.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://example.Bücher.com/' : { + 'href': 'http://example.xn--bcher-kva.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.xn--bcher-kva.com', + 'hostname': 'example.xn--bcher-kva.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://www.Äffchen.com/' : { + 'href': 'http://www.xn--ffchen-9ta.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.xn--ffchen-9ta.com', + 'hostname': 'www.xn--ffchen-9ta.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://www.Äffchen.cOm;A/b/c?d=e#f gi' : { + 'href': 'http://www.xn--ffchen-9ta.com/;A/b/c?d=e#f%20g%3Ch%3Ei', + 'protocol': 'http:', + 'slashes': true, + 'host': 'www.xn--ffchen-9ta.com', + 'hostname': 'www.xn--ffchen-9ta.com', + 'pathname': ';A/b/c', + 'search': '?d=e', + 'query': 'd=e', + 'hash': '#f%20g%3Ch%3Ei', + 'path': ';A/b/c?d=e' + }, + + 'http://SÉLIER.COM/' : { + 'href': 'http://xn--slier-bsa.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'xn--slier-bsa.com', + 'hostname': 'xn--slier-bsa.com', + 'pathname': '/', + 'path': '/' + }, + + 'http://ليهمابتكلموشعربي؟.ي؟/' : { + 'href': 'http://xn--egbpdaj6bu4bxfgehfvwxn.xn--egb9f/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'xn--egbpdaj6bu4bxfgehfvwxn.xn--egb9f', + 'hostname': 'xn--egbpdaj6bu4bxfgehfvwxn.xn--egb9f', + 'pathname': '/', + 'path': '/' + }, + + 'http://➡.ws/➡' : { + 'href': 'http://xn--hgi.ws/➡', + 'protocol': 'http:', + 'slashes': true, + 'host': 'xn--hgi.ws', + 'hostname': 'xn--hgi.ws', + 'pathname': '/➡', + 'path': '/➡' + }, + + 'http://bucket_name.s3.amazonaws.com/image.jpg': { + protocol: 'http:', + 'slashes': true, + slashes: true, + host: 'bucket_name.s3.amazonaws.com', + hostname: 'bucket_name.s3.amazonaws.com', + pathname: '/image.jpg', + href: 'http://bucket_name.s3.amazonaws.com/image.jpg', + 'path': '/image.jpg' + }, + + 'git+http://github.com/joyent/node.git': { + protocol: 'git+http:', + slashes: true, + host: 'github.com', + hostname: 'github.com', + pathname: '/joyent/node.git', + path: '/joyent/node.git', + href: 'git+http://github.com/joyent/node.git' + }, + + //if local1@domain1 is uses as a relative URL it may + //be parse into auth@hostname, but here there is no + //way to make it work in url.parse, I add the test to be explicit + 'local1@domain1': { + 'pathname': 'local1@domain1', + 'path': 'local1@domain1', + 'href': 'local1@domain1' + }, + + //While this may seem counter-intuitive, a browser will parse + // as a path. + 'www.example.com' : { + 'href': 'www.example.com', + 'pathname': 'www.example.com', + 'path': 'www.example.com' + }, + + // ipv6 support + '[fe80::1]': { + 'href': '[fe80::1]', + 'pathname': '[fe80::1]', + 'path': '[fe80::1]' + }, + + 'coap://[FEDC:BA98:7654:3210:FEDC:BA98:7654:3210]': { + 'protocol': 'coap:', + 'slashes': true, + 'host': '[fedc:ba98:7654:3210:fedc:ba98:7654:3210]', + 'hostname': 'fedc:ba98:7654:3210:fedc:ba98:7654:3210', + 'href': 'coap://[fedc:ba98:7654:3210:fedc:ba98:7654:3210]/', + 'pathname': '/', + 'path': '/' + }, + + 'coap://[1080:0:0:0:8:800:200C:417A]:61616/': { + 'protocol': 'coap:', + 'slashes': true, + 'host': '[1080:0:0:0:8:800:200c:417a]:61616', + 'port': '61616', + 'hostname': '1080:0:0:0:8:800:200c:417a', + 'href': 'coap://[1080:0:0:0:8:800:200c:417a]:61616/', + 'pathname': '/', + 'path': '/' + }, + + 'http://user:password@[3ffe:2a00:100:7031::1]:8080': { + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:password', + 'host': '[3ffe:2a00:100:7031::1]:8080', + 'port': '8080', + 'hostname': '3ffe:2a00:100:7031::1', + 'href': 'http://user:password@[3ffe:2a00:100:7031::1]:8080/', + 'pathname': '/', + 'path': '/' + }, + + 'coap://u:p@[::192.9.5.5]:61616/.well-known/r?n=Temperature': { + 'protocol': 'coap:', + 'slashes': true, + 'auth': 'u:p', + 'host': '[::192.9.5.5]:61616', + 'port': '61616', + 'hostname': '::192.9.5.5', + 'href': 'coap://u:p@[::192.9.5.5]:61616/.well-known/r?n=Temperature', + 'search': '?n=Temperature', + 'query': 'n=Temperature', + 'pathname': '/.well-known/r', + 'path': '/.well-known/r?n=Temperature' + }, + + // empty port + 'http://example.com:': { + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'href': 'http://example.com/', + 'pathname': '/', + 'path': '/' + }, + + 'http://example.com:/a/b.html': { + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'href': 'http://example.com/a/b.html', + 'pathname': '/a/b.html', + 'path': '/a/b.html' + }, + + 'http://example.com:?a=b': { + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'href': 'http://example.com/?a=b', + 'search': '?a=b', + 'query': 'a=b', + 'pathname': '/', + 'path': '/?a=b' + }, + + 'http://example.com:#abc': { + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'href': 'http://example.com/#abc', + 'hash': '#abc', + 'pathname': '/', + 'path': '/' + }, + + 'http://[fe80::1]:/a/b?a=b#abc': { + 'protocol': 'http:', + 'slashes': true, + 'host': '[fe80::1]', + 'hostname': 'fe80::1', + 'href': 'http://[fe80::1]/a/b?a=b#abc', + 'search': '?a=b', + 'query': 'a=b', + 'hash': '#abc', + 'pathname': '/a/b', + 'path': '/a/b?a=b' + }, + + 'http://-lovemonsterz.tumblr.com/rss': { + 'protocol': 'http:', + 'slashes': true, + 'host': '-lovemonsterz.tumblr.com', + 'hostname': '-lovemonsterz.tumblr.com', + 'href': 'http://-lovemonsterz.tumblr.com/rss', + 'pathname': '/rss', + 'path': '/rss', + }, + + 'http://-lovemonsterz.tumblr.com:80/rss': { + 'protocol': 'http:', + 'slashes': true, + 'port': '80', + 'host': '-lovemonsterz.tumblr.com:80', + 'hostname': '-lovemonsterz.tumblr.com', + 'href': 'http://-lovemonsterz.tumblr.com:80/rss', + 'pathname': '/rss', + 'path': '/rss', + }, + + 'http://user:pass@-lovemonsterz.tumblr.com/rss': { + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pass', + 'host': '-lovemonsterz.tumblr.com', + 'hostname': '-lovemonsterz.tumblr.com', + 'href': 'http://user:pass@-lovemonsterz.tumblr.com/rss', + 'pathname': '/rss', + 'path': '/rss', + }, + + 'http://user:pass@-lovemonsterz.tumblr.com:80/rss': { + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pass', + 'port': '80', + 'host': '-lovemonsterz.tumblr.com:80', + 'hostname': '-lovemonsterz.tumblr.com', + 'href': 'http://user:pass@-lovemonsterz.tumblr.com:80/rss', + 'pathname': '/rss', + 'path': '/rss', + }, + + 'http://_jabber._tcp.google.com/test': { + 'protocol': 'http:', + 'slashes': true, + 'host': '_jabber._tcp.google.com', + 'hostname': '_jabber._tcp.google.com', + 'href': 'http://_jabber._tcp.google.com/test', + 'pathname': '/test', + 'path': '/test', + }, + + 'http://user:pass@_jabber._tcp.google.com/test': { + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pass', + 'host': '_jabber._tcp.google.com', + 'hostname': '_jabber._tcp.google.com', + 'href': 'http://user:pass@_jabber._tcp.google.com/test', + 'pathname': '/test', + 'path': '/test', + }, + + 'http://_jabber._tcp.google.com:80/test': { + 'protocol': 'http:', + 'slashes': true, + 'port': '80', + 'host': '_jabber._tcp.google.com:80', + 'hostname': '_jabber._tcp.google.com', + 'href': 'http://_jabber._tcp.google.com:80/test', + 'pathname': '/test', + 'path': '/test', + }, + + 'http://user:pass@_jabber._tcp.google.com:80/test': { + 'protocol': 'http:', + 'slashes': true, + 'auth': 'user:pass', + 'port': '80', + 'host': '_jabber._tcp.google.com:80', + 'hostname': '_jabber._tcp.google.com', + 'href': 'http://user:pass@_jabber._tcp.google.com:80/test', + 'pathname': '/test', + 'path': '/test', + }, + + 'http://x:1/\' <>"`/{}|\\^~`/': { + protocol: 'http:', + slashes: true, + host: 'x:1', + port: '1', + hostname: 'x', + pathname: '/%27%20%3C%3E%22%60/%7B%7D%7C/%5E~%60/', + path: '/%27%20%3C%3E%22%60/%7B%7D%7C/%5E~%60/', + href: 'http://x:1/%27%20%3C%3E%22%60/%7B%7D%7C/%5E~%60/' + }, + + 'http://a@b@c/': { + protocol: 'http:', + slashes: true, + auth: 'a@b', + host: 'c', + hostname: 'c', + href: 'http://a%40b@c/', + path: '/', + pathname: '/' + }, + + 'http://a@b?@c': { + protocol: 'http:', + slashes: true, + auth: 'a', + host: 'b', + hostname: 'b', + href: 'http://a@b/?@c', + path: '/?@c', + pathname: '/', + search: '?@c', + query: '@c' + }, + + 'http://a\r" \t\n<\'b:b@c\r\nd/e?f':{ + protocol: 'http:', + slashes: true, + auth: 'a\r" \t\n<\'b:b', + host: 'c', + port: null, + hostname: 'c', + hash: null, + search: '?f', + query: 'f', + pathname: '%0D%0Ad/e', + path: '%0D%0Ad/e?f', + href: 'http://a%0D%22%20%09%0A%3C\'b:b@c/%0D%0Ad/e?f' + }, + + // git urls used by npm + 'git+ssh://git@github.com:npm/npm': { + protocol: 'git+ssh:', + slashes: true, + auth: 'git', + host: 'github.com', + port: null, + hostname: 'github.com', + hash: null, + search: null, + query: null, + pathname: '/:npm/npm', + path: '/:npm/npm', + href: 'git+ssh://git@github.com/:npm/npm' + } + +}; + +Object.keys(parseTests).forEach(function(u) { + test('parse(' + u + ')', function() { + var actual = url.parse(u), + spaced = url.parse(' \t ' + u + '\n\t'); + expected = parseTests[u]; + + Object.keys(actual).forEach(function (i) { + if (expected[i] === undefined && actual[i] === null) { + expected[i] = null; + } + }); + + assert.deepEqual(actual, expected); + assert.deepEqual(spaced, expected); + + var expected = parseTests[u].href, + actual = url.format(parseTests[u]); + + assert.equal(actual, expected, + 'format(' + u + ') == ' + u + '\nactual:' + actual); + }); +}); + +var parseTestsWithQueryString = { + '/foo/bar?baz=quux#frag' : { + 'href': '/foo/bar?baz=quux#frag', + 'hash': '#frag', + 'search': '?baz=quux', + 'query': { + 'baz': 'quux' + }, + 'pathname': '/foo/bar', + 'path': '/foo/bar?baz=quux' + }, + 'http://example.com' : { + 'href': 'http://example.com/', + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'query': {}, + 'search': '', + 'pathname': '/', + 'path': '/' + }, + '/example': { + protocol: null, + slashes: null, + auth: null, + host: null, + port: null, + hostname: null, + hash: null, + search: '', + query: {}, + pathname: '/example', + path: '/example', + href: '/example' + }, + '/example?query=value':{ + protocol: null, + slashes: null, + auth: null, + host: null, + port: null, + hostname: null, + hash: null, + search: '?query=value', + query: { query: 'value' }, + pathname: '/example', + path: '/example?query=value', + href: '/example?query=value' + } +}; + +Object.keys(parseTestsWithQueryString).forEach(function(u) { + test('parse(' + u + ')', function() { + var actual = url.parse(u, true); + var expected = parseTestsWithQueryString[u]; + for (var i in actual) { + if (actual[i] === null && expected[i] === undefined) { + expected[i] = null; + } + } + + assert.deepEqual(actual, expected); + }); +}); + +// some extra formatting tests, just to verify +// that it'll format slightly wonky content to a valid url. +var formatTests = { + 'http://example.com?' : { + 'href': 'http://example.com/?', + 'protocol': 'http:', + 'slashes': true, + 'host': 'example.com', + 'hostname': 'example.com', + 'search': '?', + 'query': {}, + 'pathname': '/' + }, + 'http://example.com?foo=bar#frag' : { + 'href': 'http://example.com/?foo=bar#frag', + 'protocol': 'http:', + 'host': 'example.com', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?foo=bar', + 'query': 'foo=bar', + 'pathname': '/' + }, + 'http://example.com?foo=@bar#frag' : { + 'href': 'http://example.com/?foo=@bar#frag', + 'protocol': 'http:', + 'host': 'example.com', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?foo=@bar', + 'query': 'foo=@bar', + 'pathname': '/' + }, + 'http://example.com?foo=/bar/#frag' : { + 'href': 'http://example.com/?foo=/bar/#frag', + 'protocol': 'http:', + 'host': 'example.com', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?foo=/bar/', + 'query': 'foo=/bar/', + 'pathname': '/' + }, + 'http://example.com?foo=?bar/#frag' : { + 'href': 'http://example.com/?foo=?bar/#frag', + 'protocol': 'http:', + 'host': 'example.com', + 'hostname': 'example.com', + 'hash': '#frag', + 'search': '?foo=?bar/', + 'query': 'foo=?bar/', + 'pathname': '/' + }, + 'http://example.com#frag=?bar/#frag' : { + 'href': 'http://example.com/#frag=?bar/#frag', + 'protocol': 'http:', + 'host': 'example.com', + 'hostname': 'example.com', + 'hash': '#frag=?bar/#frag', + 'pathname': '/' + }, + 'http://google.com" onload="alert(42)/' : { + 'href': 'http://google.com/%22%20onload=%22alert(42)/', + 'protocol': 'http:', + 'host': 'google.com', + 'pathname': '/%22%20onload=%22alert(42)/' + }, + 'http://a.com/a/b/c?s#h' : { + 'href': 'http://a.com/a/b/c?s#h', + 'protocol': 'http', + 'host': 'a.com', + 'pathname': 'a/b/c', + 'hash': 'h', + 'search': 's' + }, + 'xmpp:isaacschlueter@jabber.org' : { + 'href': 'xmpp:isaacschlueter@jabber.org', + 'protocol': 'xmpp:', + 'host': 'jabber.org', + 'auth': 'isaacschlueter', + 'hostname': 'jabber.org' + }, + 'http://atpass:foo%40bar@127.0.0.1/' : { + 'href': 'http://atpass:foo%40bar@127.0.0.1/', + 'auth': 'atpass:foo@bar', + 'hostname': '127.0.0.1', + 'protocol': 'http:', + 'pathname': '/' + }, + 'http://atslash%2F%40:%2F%40@foo/' : { + 'href': 'http://atslash%2F%40:%2F%40@foo/', + 'auth': 'atslash/@:/@', + 'hostname': 'foo', + 'protocol': 'http:', + 'pathname': '/' + }, + 'svn+ssh://foo/bar': { + 'href': 'svn+ssh://foo/bar', + 'hostname': 'foo', + 'protocol': 'svn+ssh:', + 'pathname': '/bar', + 'slashes': true + }, + 'dash-test://foo/bar': { + 'href': 'dash-test://foo/bar', + 'hostname': 'foo', + 'protocol': 'dash-test:', + 'pathname': '/bar', + 'slashes': true + }, + 'dash-test:foo/bar': { + 'href': 'dash-test:foo/bar', + 'hostname': 'foo', + 'protocol': 'dash-test:', + 'pathname': '/bar' + }, + 'dot.test://foo/bar': { + 'href': 'dot.test://foo/bar', + 'hostname': 'foo', + 'protocol': 'dot.test:', + 'pathname': '/bar', + 'slashes': true + }, + 'dot.test:foo/bar': { + 'href': 'dot.test:foo/bar', + 'hostname': 'foo', + 'protocol': 'dot.test:', + 'pathname': '/bar' + }, + // ipv6 support + 'coap:u:p@[::1]:61616/.well-known/r?n=Temperature': { + 'href': 'coap:u:p@[::1]:61616/.well-known/r?n=Temperature', + 'protocol': 'coap:', + 'auth': 'u:p', + 'hostname': '::1', + 'port': '61616', + 'pathname': '/.well-known/r', + 'search': 'n=Temperature' + }, + 'coap:[fedc:ba98:7654:3210:fedc:ba98:7654:3210]:61616/s/stopButton': { + 'href': 'coap:[fedc:ba98:7654:3210:fedc:ba98:7654:3210]:61616/s/stopButton', + 'protocol': 'coap', + 'host': '[fedc:ba98:7654:3210:fedc:ba98:7654:3210]:61616', + 'pathname': '/s/stopButton' + }, + + // encode context-specific delimiters in path and query, but do not touch + // other non-delimiter chars like `%`. + // + + // `#`,`?` in path + '/path/to/%%23%3F+=&.txt?foo=theA1#bar' : { + href : '/path/to/%%23%3F+=&.txt?foo=theA1#bar', + pathname: '/path/to/%#?+=&.txt', + query: { + foo: 'theA1' + }, + hash: "#bar" + }, + + // `#`,`?` in path + `#` in query + '/path/to/%%23%3F+=&.txt?foo=the%231#bar' : { + href : '/path/to/%%23%3F+=&.txt?foo=the%231#bar', + pathname: '/path/to/%#?+=&.txt', + query: { + foo: 'the#1' + }, + hash: "#bar" + }, + + // `?` and `#` in path and search + 'http://ex.com/foo%3F100%m%23r?abc=the%231?&foo=bar#frag': { + href: 'http://ex.com/foo%3F100%m%23r?abc=the%231?&foo=bar#frag', + protocol: 'http:', + hostname: 'ex.com', + hash: '#frag', + search: '?abc=the#1?&foo=bar', + pathname: '/foo?100%m#r', + }, + + // `?` and `#` in search only + 'http://ex.com/fooA100%mBr?abc=the%231?&foo=bar#frag': { + href: 'http://ex.com/fooA100%mBr?abc=the%231?&foo=bar#frag', + protocol: 'http:', + hostname: 'ex.com', + hash: '#frag', + search: '?abc=the#1?&foo=bar', + pathname: '/fooA100%mBr', + } +}; + +Object.keys(formatTests).forEach(function(u) { + test('format(' + u + ')', function() { + var expect = formatTests[u].href; + delete formatTests[u].href; + var actual = url.format(u); + var actualObj = url.format(formatTests[u]); + assert.equal(actual, expect, + 'wonky format(' + u + ') == ' + expect + + '\nactual:' + actual); + assert.equal(actualObj, expect, + 'wonky format(' + JSON.stringify(formatTests[u]) + + ') == ' + expect + + '\nactual: ' + actualObj); + }); +}); + +/* + [from, path, expected] +*/ +var relativeTests = [ + ['/foo/bar/baz', 'quux', '/foo/bar/quux'], + ['/foo/bar/baz', 'quux/asdf', '/foo/bar/quux/asdf'], + ['/foo/bar/baz', 'quux/baz', '/foo/bar/quux/baz'], + ['/foo/bar/baz', '../quux/baz', '/foo/quux/baz'], + ['/foo/bar/baz', '/bar', '/bar'], + ['/foo/bar/baz/', 'quux', '/foo/bar/baz/quux'], + ['/foo/bar/baz/', 'quux/baz', '/foo/bar/baz/quux/baz'], + ['/foo/bar/baz', '../../../../../../../../quux/baz', '/quux/baz'], + ['/foo/bar/baz', '../../../../../../../quux/baz', '/quux/baz'], + ['/foo', '.', '/'], + ['/foo', '..', '/'], + ['/foo/', '.', '/foo/'], + ['/foo/', '..', '/'], + ['/foo/bar', '.', '/foo/'], + ['/foo/bar', '..', '/'], + ['/foo/bar/', '.', '/foo/bar/'], + ['/foo/bar/', '..', '/foo/'], + ['foo/bar', '../../../baz', '../../baz'], + ['foo/bar/', '../../../baz', '../baz'], + ['http://example.com/b//c//d;p?q#blarg', 'https:#hash2', 'https:///#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'https:/p/a/t/h?s#hash2', + 'https://p/a/t/h?s#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'https://u:p@h.com/p/a/t/h?s#hash2', + 'https://u:p@h.com/p/a/t/h?s#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'https:/a/b/c/d', + 'https://a/b/c/d'], + ['http://example.com/b//c//d;p?q#blarg', + 'http:#hash2', + 'http://example.com/b//c//d;p?q#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'http:/p/a/t/h?s#hash2', + 'http://example.com/p/a/t/h?s#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'http://u:p@h.com/p/a/t/h?s#hash2', + 'http://u:p@h.com/p/a/t/h?s#hash2'], + ['http://example.com/b//c//d;p?q#blarg', + 'http:/a/b/c/d', + 'http://example.com/a/b/c/d'], + ['/foo/bar/baz', '/../etc/passwd', '/etc/passwd'] +]; + +relativeTests.forEach(function(relativeTest) { + test('resolve(' + [relativeTest[0], relativeTest[1]] + ')', function() { + var a = url.resolve(relativeTest[0], relativeTest[1]), + e = relativeTest[2]; + assert.equal(a, e, + 'resolve(' + [relativeTest[0], relativeTest[1]] + ') == ' + e + + '\n actual=' + a); + }); +}); + + +// https://github.com/joyent/node/issues/568 +[ + undefined, + null, + true, + false, + 0.0, + 0, + [], + {} +].forEach(function(val) { + test('parse(' + val + ')', function() { + assert.throws(function() { url.parse(val); }, TypeError); + }); +}); + + +// +// Tests below taken from Chiron +// http://code.google.com/p/chironjs/source/browse/trunk/src/test/http/url.js +// +// Copyright (c) 2002-2008 Kris Kowal +// used with permission under MIT License +// +// Changes marked with @isaacs + +var bases = [ + 'http://a/b/c/d;p?q', + 'http://a/b/c/d;p?q=1/2', + 'http://a/b/c/d;p=1/2?q', + 'fred:///s//a/b/c', + 'http:///s//a/b/c' +]; + +//[to, from, result] +var relativeTests2 = [ + // http://lists.w3.org/Archives/Public/uri/2004Feb/0114.html + ['../c', 'foo:a/b', 'foo:c'], + ['foo:.', 'foo:a', 'foo:'], + ['/foo/../../../bar', 'zz:abc', 'zz:/bar'], + ['/foo/../bar', 'zz:abc', 'zz:/bar'], + // @isaacs Disagree. Not how web browsers resolve this. + ['foo/../../../bar', 'zz:abc', 'zz:bar'], + // ['foo/../../../bar', 'zz:abc', 'zz:../../bar'], // @isaacs Added + ['foo/../bar', 'zz:abc', 'zz:bar'], + ['zz:.', 'zz:abc', 'zz:'], + ['/.', bases[0], 'http://a/'], + ['/.foo', bases[0], 'http://a/.foo'], + ['.foo', bases[0], 'http://a/b/c/.foo'], + + // http://gbiv.com/protocols/uri/test/rel_examples1.html + // examples from RFC 2396 + ['g:h', bases[0], 'g:h'], + ['g', bases[0], 'http://a/b/c/g'], + ['./g', bases[0], 'http://a/b/c/g'], + ['g/', bases[0], 'http://a/b/c/g/'], + ['/g', bases[0], 'http://a/g'], + ['//g', bases[0], 'http://g/'], + // changed with RFC 2396bis + //('?y', bases[0], 'http://a/b/c/d;p?y'], + ['?y', bases[0], 'http://a/b/c/d;p?y'], + ['g?y', bases[0], 'http://a/b/c/g?y'], + // changed with RFC 2396bis + //('#s', bases[0], CURRENT_DOC_URI + '#s'], + ['#s', bases[0], 'http://a/b/c/d;p?q#s'], + ['g#s', bases[0], 'http://a/b/c/g#s'], + ['g?y#s', bases[0], 'http://a/b/c/g?y#s'], + [';x', bases[0], 'http://a/b/c/;x'], + ['g;x', bases[0], 'http://a/b/c/g;x'], + ['g;x?y#s' , bases[0], 'http://a/b/c/g;x?y#s'], + // changed with RFC 2396bis + //('', bases[0], CURRENT_DOC_URI], + ['', bases[0], 'http://a/b/c/d;p?q'], + ['.', bases[0], 'http://a/b/c/'], + ['./', bases[0], 'http://a/b/c/'], + ['..', bases[0], 'http://a/b/'], + ['../', bases[0], 'http://a/b/'], + ['../g', bases[0], 'http://a/b/g'], + ['../..', bases[0], 'http://a/'], + ['../../', bases[0], 'http://a/'], + ['../../g' , bases[0], 'http://a/g'], + ['../../../g', bases[0], ('http://a/../g', 'http://a/g')], + ['../../../../g', bases[0], ('http://a/../../g', 'http://a/g')], + // changed with RFC 2396bis + //('/./g', bases[0], 'http://a/./g'], + ['/./g', bases[0], 'http://a/g'], + // changed with RFC 2396bis + //('/../g', bases[0], 'http://a/../g'], + ['/../g', bases[0], 'http://a/g'], + ['g.', bases[0], 'http://a/b/c/g.'], + ['.g', bases[0], 'http://a/b/c/.g'], + ['g..', bases[0], 'http://a/b/c/g..'], + ['..g', bases[0], 'http://a/b/c/..g'], + ['./../g', bases[0], 'http://a/b/g'], + ['./g/.', bases[0], 'http://a/b/c/g/'], + ['g/./h', bases[0], 'http://a/b/c/g/h'], + ['g/../h', bases[0], 'http://a/b/c/h'], + ['g;x=1/./y', bases[0], 'http://a/b/c/g;x=1/y'], + ['g;x=1/../y', bases[0], 'http://a/b/c/y'], + ['g?y/./x', bases[0], 'http://a/b/c/g?y/./x'], + ['g?y/../x', bases[0], 'http://a/b/c/g?y/../x'], + ['g#s/./x', bases[0], 'http://a/b/c/g#s/./x'], + ['g#s/../x', bases[0], 'http://a/b/c/g#s/../x'], + ['http:g', bases[0], ('http:g', 'http://a/b/c/g')], + ['http:', bases[0], ('http:', bases[0])], + // not sure where this one originated + ['/a/b/c/./../../g', bases[0], 'http://a/a/g'], + + // http://gbiv.com/protocols/uri/test/rel_examples2.html + // slashes in base URI's query args + ['g', bases[1], 'http://a/b/c/g'], + ['./g', bases[1], 'http://a/b/c/g'], + ['g/', bases[1], 'http://a/b/c/g/'], + ['/g', bases[1], 'http://a/g'], + ['//g', bases[1], 'http://g/'], + // changed in RFC 2396bis + //('?y', bases[1], 'http://a/b/c/?y'], + ['?y', bases[1], 'http://a/b/c/d;p?y'], + ['g?y', bases[1], 'http://a/b/c/g?y'], + ['g?y/./x' , bases[1], 'http://a/b/c/g?y/./x'], + ['g?y/../x', bases[1], 'http://a/b/c/g?y/../x'], + ['g#s', bases[1], 'http://a/b/c/g#s'], + ['g#s/./x' , bases[1], 'http://a/b/c/g#s/./x'], + ['g#s/../x', bases[1], 'http://a/b/c/g#s/../x'], + ['./', bases[1], 'http://a/b/c/'], + ['../', bases[1], 'http://a/b/'], + ['../g', bases[1], 'http://a/b/g'], + ['../../', bases[1], 'http://a/'], + ['../../g' , bases[1], 'http://a/g'], + + // http://gbiv.com/protocols/uri/test/rel_examples3.html + // slashes in path params + // all of these changed in RFC 2396bis + ['g', bases[2], 'http://a/b/c/d;p=1/g'], + ['./g', bases[2], 'http://a/b/c/d;p=1/g'], + ['g/', bases[2], 'http://a/b/c/d;p=1/g/'], + ['g?y', bases[2], 'http://a/b/c/d;p=1/g?y'], + [';x', bases[2], 'http://a/b/c/d;p=1/;x'], + ['g;x', bases[2], 'http://a/b/c/d;p=1/g;x'], + ['g;x=1/./y', bases[2], 'http://a/b/c/d;p=1/g;x=1/y'], + ['g;x=1/../y', bases[2], 'http://a/b/c/d;p=1/y'], + ['./', bases[2], 'http://a/b/c/d;p=1/'], + ['../', bases[2], 'http://a/b/c/'], + ['../g', bases[2], 'http://a/b/c/g'], + ['../../', bases[2], 'http://a/b/'], + ['../../g' , bases[2], 'http://a/b/g'], + + // http://gbiv.com/protocols/uri/test/rel_examples4.html + // double and triple slash, unknown scheme + ['g:h', bases[3], 'g:h'], + ['g', bases[3], 'fred:///s//a/b/g'], + ['./g', bases[3], 'fred:///s//a/b/g'], + ['g/', bases[3], 'fred:///s//a/b/g/'], + ['/g', bases[3], 'fred:///g'], // may change to fred:///s//a/g + ['//g', bases[3], 'fred://g'], // may change to fred:///s//g + ['//g/x', bases[3], 'fred://g/x'], // may change to fred:///s//g/x + ['///g', bases[3], 'fred:///g'], + ['./', bases[3], 'fred:///s//a/b/'], + ['../', bases[3], 'fred:///s//a/'], + ['../g', bases[3], 'fred:///s//a/g'], + + ['../../', bases[3], 'fred:///s//'], + ['../../g' , bases[3], 'fred:///s//g'], + ['../../../g', bases[3], 'fred:///s/g'], + // may change to fred:///s//a/../../../g + ['../../../../g', bases[3], 'fred:///g'], + + // http://gbiv.com/protocols/uri/test/rel_examples5.html + // double and triple slash, well-known scheme + ['g:h', bases[4], 'g:h'], + ['g', bases[4], 'http:///s//a/b/g'], + ['./g', bases[4], 'http:///s//a/b/g'], + ['g/', bases[4], 'http:///s//a/b/g/'], + ['/g', bases[4], 'http:///g'], // may change to http:///s//a/g + ['//g', bases[4], 'http://g/'], // may change to http:///s//g + ['//g/x', bases[4], 'http://g/x'], // may change to http:///s//g/x + ['///g', bases[4], 'http:///g'], + ['./', bases[4], 'http:///s//a/b/'], + ['../', bases[4], 'http:///s//a/'], + ['../g', bases[4], 'http:///s//a/g'], + ['../../', bases[4], 'http:///s//'], + ['../../g' , bases[4], 'http:///s//g'], + // may change to http:///s//a/../../g + ['../../../g', bases[4], 'http:///s/g'], + // may change to http:///s//a/../../../g + ['../../../../g', bases[4], 'http:///g'], + + // from Dan Connelly's tests in http://www.w3.org/2000/10/swap/uripath.py + ['bar:abc', 'foo:xyz', 'bar:abc'], + ['../abc', 'http://example/x/y/z', 'http://example/x/abc'], + ['http://example/x/abc', 'http://example2/x/y/z', 'http://example/x/abc'], + ['../r', 'http://ex/x/y/z', 'http://ex/x/r'], + ['q/r', 'http://ex/x/y', 'http://ex/x/q/r'], + ['q/r#s', 'http://ex/x/y', 'http://ex/x/q/r#s'], + ['q/r#s/t', 'http://ex/x/y', 'http://ex/x/q/r#s/t'], + ['ftp://ex/x/q/r', 'http://ex/x/y', 'ftp://ex/x/q/r'], + ['', 'http://ex/x/y', 'http://ex/x/y'], + ['', 'http://ex/x/y/', 'http://ex/x/y/'], + ['', 'http://ex/x/y/pdq', 'http://ex/x/y/pdq'], + ['z/', 'http://ex/x/y/', 'http://ex/x/y/z/'], + ['#Animal', + 'file:/swap/test/animal.rdf', + 'file:/swap/test/animal.rdf#Animal'], + ['../abc', 'file:/e/x/y/z', 'file:/e/x/abc'], + ['/example/x/abc', 'file:/example2/x/y/z', 'file:/example/x/abc'], + ['../r', 'file:/ex/x/y/z', 'file:/ex/x/r'], + ['/r', 'file:/ex/x/y/z', 'file:/r'], + ['q/r', 'file:/ex/x/y', 'file:/ex/x/q/r'], + ['q/r#s', 'file:/ex/x/y', 'file:/ex/x/q/r#s'], + ['q/r#', 'file:/ex/x/y', 'file:/ex/x/q/r#'], + ['q/r#s/t', 'file:/ex/x/y', 'file:/ex/x/q/r#s/t'], + ['ftp://ex/x/q/r', 'file:/ex/x/y', 'ftp://ex/x/q/r'], + ['', 'file:/ex/x/y', 'file:/ex/x/y'], + ['', 'file:/ex/x/y/', 'file:/ex/x/y/'], + ['', 'file:/ex/x/y/pdq', 'file:/ex/x/y/pdq'], + ['z/', 'file:/ex/x/y/', 'file:/ex/x/y/z/'], + ['file://meetings.example.com/cal#m1', + 'file:/devel/WWW/2000/10/swap/test/reluri-1.n3', + 'file://meetings.example.com/cal#m1'], + ['file://meetings.example.com/cal#m1', + 'file:/home/connolly/w3ccvs/WWW/2000/10/swap/test/reluri-1.n3', + 'file://meetings.example.com/cal#m1'], + ['./#blort', 'file:/some/dir/foo', 'file:/some/dir/#blort'], + ['./#', 'file:/some/dir/foo', 'file:/some/dir/#'], + // Ryan Lee + ['./', 'http://example/x/abc.efg', 'http://example/x/'], + + + // Graham Klyne's tests + // http://www.ninebynine.org/Software/HaskellUtils/Network/UriTest.xls + // 01-31 are from Connelly's cases + + // 32-49 + ['./q:r', 'http://ex/x/y', 'http://ex/x/q:r'], + ['./p=q:r', 'http://ex/x/y', 'http://ex/x/p=q:r'], + ['?pp/rr', 'http://ex/x/y?pp/qq', 'http://ex/x/y?pp/rr'], + ['y/z', 'http://ex/x/y?pp/qq', 'http://ex/x/y/z'], + ['local/qual@domain.org#frag', + 'mailto:local', + 'mailto:local/qual@domain.org#frag'], + ['more/qual2@domain2.org#frag', + 'mailto:local/qual1@domain1.org', + 'mailto:local/more/qual2@domain2.org#frag'], + ['y?q', 'http://ex/x/y?q', 'http://ex/x/y?q'], + ['/x/y?q', 'http://ex?p', 'http://ex/x/y?q'], + ['c/d', 'foo:a/b', 'foo:a/c/d'], + ['/c/d', 'foo:a/b', 'foo:/c/d'], + ['', 'foo:a/b?c#d', 'foo:a/b?c'], + ['b/c', 'foo:a', 'foo:b/c'], + ['../b/c', 'foo:/a/y/z', 'foo:/a/b/c'], + ['./b/c', 'foo:a', 'foo:b/c'], + ['/./b/c', 'foo:a', 'foo:/b/c'], + ['../../d', 'foo://a//b/c', 'foo://a/d'], + ['.', 'foo:a', 'foo:'], + ['..', 'foo:a', 'foo:'], + + // 50-57[cf. TimBL comments -- + // http://lists.w3.org/Archives/Public/uri/2003Feb/0028.html, + // http://lists.w3.org/Archives/Public/uri/2003Jan/0008.html) + ['abc', 'http://example/x/y%2Fz', 'http://example/x/abc'], + ['../../x%2Fabc', 'http://example/a/x/y/z', 'http://example/a/x%2Fabc'], + ['../x%2Fabc', 'http://example/a/x/y%2Fz', 'http://example/a/x%2Fabc'], + ['abc', 'http://example/x%2Fy/z', 'http://example/x%2Fy/abc'], + ['q%3Ar', 'http://ex/x/y', 'http://ex/x/q%3Ar'], + ['/x%2Fabc', 'http://example/x/y%2Fz', 'http://example/x%2Fabc'], + ['/x%2Fabc', 'http://example/x/y/z', 'http://example/x%2Fabc'], + ['/x%2Fabc', 'http://example/x/y%2Fz', 'http://example/x%2Fabc'], + + // 70-77 + ['local2@domain2', 'mailto:local1@domain1?query1', 'mailto:local2@domain2'], + ['local2@domain2?query2', + 'mailto:local1@domain1', + 'mailto:local2@domain2?query2'], + ['local2@domain2?query2', + 'mailto:local1@domain1?query1', + 'mailto:local2@domain2?query2'], + ['?query2', 'mailto:local@domain?query1', 'mailto:local@domain?query2'], + ['local@domain?query2', 'mailto:?query1', 'mailto:local@domain?query2'], + ['?query2', 'mailto:local@domain?query1', 'mailto:local@domain?query2'], + ['http://example/a/b?c/../d', 'foo:bar', 'http://example/a/b?c/../d'], + ['http://example/a/b#c/../d', 'foo:bar', 'http://example/a/b#c/../d'], + + // 82-88 + // @isaacs Disagree. Not how browsers do it. + // ['http:this', 'http://example.org/base/uri', 'http:this'], + // @isaacs Added + ['http:this', 'http://example.org/base/uri', 'http://example.org/base/this'], + ['http:this', 'http:base', 'http:this'], + ['.//g', 'f:/a', 'f://g'], + ['b/c//d/e', 'f://example.org/base/a', 'f://example.org/base/b/c//d/e'], + ['m2@example.ord/c2@example.org', + 'mid:m@example.ord/c@example.org', + 'mid:m@example.ord/m2@example.ord/c2@example.org'], + ['mini1.xml', + 'file:///C:/DEV/Haskell/lib/HXmlToolbox-3.01/examples/', + 'file:///C:/DEV/Haskell/lib/HXmlToolbox-3.01/examples/mini1.xml'], + ['../b/c', 'foo:a/y/z', 'foo:a/b/c'], + + //changeing auth + ['http://diff:auth@www.example.com', + 'http://asdf:qwer@www.example.com', + 'http://diff:auth@www.example.com/'] +]; + +relativeTests2.forEach(function(relativeTest) { + test('resolve(' + [relativeTest[1], relativeTest[0]] + ')', function() { + var a = url.resolve(relativeTest[1], relativeTest[0]), + e = relativeTest[2]; + assert.equal(a, e, + 'resolve(' + [relativeTest[1], relativeTest[0]] + ') == ' + e + + '\n actual=' + a); + }); +}); + +//if format and parse are inverse operations then +//resolveObject(parse(x), y) == parse(resolve(x, y)) + +//host and hostname are special, in this case a '' value is important +var emptyIsImportant = {'host': true, 'hostname': ''}; + +//format: [from, path, expected] +relativeTests.forEach(function(relativeTest) { +test('resolveObject(' + [relativeTest[0], relativeTest[1]] + ')', function() { + var actual = url.resolveObject(url.parse(relativeTest[0]), relativeTest[1]), + expected = url.parse(relativeTest[2]); + + + assert.deepEqual(actual, expected); + + expected = relativeTest[2]; + actual = url.format(actual); + + assert.equal(actual, expected, + 'format(' + actual + ') == ' + expected + '\nactual:' + actual); + }); +}); + +//format: [to, from, result] +// the test: ['.//g', 'f:/a', 'f://g'] is a fundamental problem +// url.parse('f:/a') does not have a host +// url.resolve('f:/a', './/g') does not have a host because you have moved +// down to the g directory. i.e. f: //g, however when this url is parsed +// f:// will indicate that the host is g which is not the case. +// it is unclear to me how to keep this information from being lost +// it may be that a pathname of ////g should collapse to /g but this seems +// to be a lot of work for an edge case. Right now I remove the test +if (relativeTests2[181][0] === './/g' && + relativeTests2[181][1] === 'f:/a' && + relativeTests2[181][2] === 'f://g') { + relativeTests2.splice(181, 1); +} + +relativeTests2.forEach(function(relativeTest) { + test('resolveObject(' + [relativeTest[1], relativeTest[0]] + ')', function() { + var actual = url.resolveObject(url.parse(relativeTest[1]), relativeTest[0]), + expected = url.parse(relativeTest[2]); + + assert.deepEqual(actual, expected); + + var expected = relativeTest[2], + actual = url.format(actual); + + assert.equal(actual, expected, + 'format(' + relativeTest[1] + ') == ' + expected + + '\nactual:' + actual); + }); +}); diff --git a/node_modules/url/url.js b/node_modules/url/url.js new file mode 100644 index 0000000..23ac6f5 --- /dev/null +++ b/node_modules/url/url.js @@ -0,0 +1,732 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +'use strict'; + +var punycode = require('punycode'); +var util = require('./util'); + +exports.parse = urlParse; +exports.resolve = urlResolve; +exports.resolveObject = urlResolveObject; +exports.format = urlFormat; + +exports.Url = Url; + +function Url() { + this.protocol = null; + this.slashes = null; + this.auth = null; + this.host = null; + this.port = null; + this.hostname = null; + this.hash = null; + this.search = null; + this.query = null; + this.pathname = null; + this.path = null; + this.href = null; +} + +// Reference: RFC 3986, RFC 1808, RFC 2396 + +// define these here so at least they only have to be +// compiled once on the first module load. +var protocolPattern = /^([a-z0-9.+-]+:)/i, + portPattern = /:[0-9]*$/, + + // Special case for a simple path URL + simplePathPattern = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/, + + // RFC 2396: characters reserved for delimiting URLs. + // We actually just auto-escape these. + delims = ['<', '>', '"', '`', ' ', '\r', '\n', '\t'], + + // RFC 2396: characters not allowed for various reasons. + unwise = ['{', '}', '|', '\\', '^', '`'].concat(delims), + + // Allowed by RFCs, but cause of XSS attacks. Always escape these. + autoEscape = ['\''].concat(unwise), + // Characters that are never ever allowed in a hostname. + // Note that any invalid chars are also handled, but these + // are the ones that are *expected* to be seen, so we fast-path + // them. + nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape), + hostEndingChars = ['/', '?', '#'], + hostnameMaxLen = 255, + hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/, + hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/, + // protocols that can allow "unsafe" and "unwise" chars. + unsafeProtocol = { + 'javascript': true, + 'javascript:': true + }, + // protocols that never have a hostname. + hostlessProtocol = { + 'javascript': true, + 'javascript:': true + }, + // protocols that always contain a // bit. + slashedProtocol = { + 'http': true, + 'https': true, + 'ftp': true, + 'gopher': true, + 'file': true, + 'http:': true, + 'https:': true, + 'ftp:': true, + 'gopher:': true, + 'file:': true + }, + querystring = require('querystring'); + +function urlParse(url, parseQueryString, slashesDenoteHost) { + if (url && util.isObject(url) && url instanceof Url) return url; + + var u = new Url; + u.parse(url, parseQueryString, slashesDenoteHost); + return u; +} + +Url.prototype.parse = function(url, parseQueryString, slashesDenoteHost) { + if (!util.isString(url)) { + throw new TypeError("Parameter 'url' must be a string, not " + typeof url); + } + + // Copy chrome, IE, opera backslash-handling behavior. + // Back slashes before the query string get converted to forward slashes + // See: https://code.google.com/p/chromium/issues/detail?id=25916 + var queryIndex = url.indexOf('?'), + splitter = + (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#', + uSplit = url.split(splitter), + slashRegex = /\\/g; + uSplit[0] = uSplit[0].replace(slashRegex, '/'); + url = uSplit.join(splitter); + + var rest = url; + + // trim before proceeding. + // This is to support parse stuff like " http://foo.com \n" + rest = rest.trim(); + + if (!slashesDenoteHost && url.split('#').length === 1) { + // Try fast path regexp + var simplePath = simplePathPattern.exec(rest); + if (simplePath) { + this.path = rest; + this.href = rest; + this.pathname = simplePath[1]; + if (simplePath[2]) { + this.search = simplePath[2]; + if (parseQueryString) { + this.query = querystring.parse(this.search.substr(1)); + } else { + this.query = this.search.substr(1); + } + } else if (parseQueryString) { + this.search = ''; + this.query = {}; + } + return this; + } + } + + var proto = protocolPattern.exec(rest); + if (proto) { + proto = proto[0]; + var lowerProto = proto.toLowerCase(); + this.protocol = lowerProto; + rest = rest.substr(proto.length); + } + + // figure out if it's got a host + // user@server is *always* interpreted as a hostname, and url + // resolution will treat //foo/bar as host=foo,path=bar because that's + // how the browser resolves relative URLs. + if (slashesDenoteHost || proto || rest.match(/^\/\/[^@\/]+@[^@\/]+/)) { + var slashes = rest.substr(0, 2) === '//'; + if (slashes && !(proto && hostlessProtocol[proto])) { + rest = rest.substr(2); + this.slashes = true; + } + } + + if (!hostlessProtocol[proto] && + (slashes || (proto && !slashedProtocol[proto]))) { + + // there's a hostname. + // the first instance of /, ?, ;, or # ends the host. + // + // If there is an @ in the hostname, then non-host chars *are* allowed + // to the left of the last @ sign, unless some host-ending character + // comes *before* the @-sign. + // URLs are obnoxious. + // + // ex: + // http://a@b@c/ => user:a@b host:c + // http://a@b?@c => user:a host:c path:/?@c + + // v0.12 TODO(isaacs): This is not quite how Chrome does things. + // Review our test case against browsers more comprehensively. + + // find the first instance of any hostEndingChars + var hostEnd = -1; + for (var i = 0; i < hostEndingChars.length; i++) { + var hec = rest.indexOf(hostEndingChars[i]); + if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) + hostEnd = hec; + } + + // at this point, either we have an explicit point where the + // auth portion cannot go past, or the last @ char is the decider. + var auth, atSign; + if (hostEnd === -1) { + // atSign can be anywhere. + atSign = rest.lastIndexOf('@'); + } else { + // atSign must be in auth portion. + // http://a@b/c@d => host:b auth:a path:/c@d + atSign = rest.lastIndexOf('@', hostEnd); + } + + // Now we have a portion which is definitely the auth. + // Pull that off. + if (atSign !== -1) { + auth = rest.slice(0, atSign); + rest = rest.slice(atSign + 1); + this.auth = decodeURIComponent(auth); + } + + // the host is the remaining to the left of the first non-host char + hostEnd = -1; + for (var i = 0; i < nonHostChars.length; i++) { + var hec = rest.indexOf(nonHostChars[i]); + if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) + hostEnd = hec; + } + // if we still have not hit it, then the entire thing is a host. + if (hostEnd === -1) + hostEnd = rest.length; + + this.host = rest.slice(0, hostEnd); + rest = rest.slice(hostEnd); + + // pull out port. + this.parseHost(); + + // we've indicated that there is a hostname, + // so even if it's empty, it has to be present. + this.hostname = this.hostname || ''; + + // if hostname begins with [ and ends with ] + // assume that it's an IPv6 address. + var ipv6Hostname = this.hostname[0] === '[' && + this.hostname[this.hostname.length - 1] === ']'; + + // validate a little. + if (!ipv6Hostname) { + var hostparts = this.hostname.split(/\./); + for (var i = 0, l = hostparts.length; i < l; i++) { + var part = hostparts[i]; + if (!part) continue; + if (!part.match(hostnamePartPattern)) { + var newpart = ''; + for (var j = 0, k = part.length; j < k; j++) { + if (part.charCodeAt(j) > 127) { + // we replace non-ASCII char with a temporary placeholder + // we need this to make sure size of hostname is not + // broken by replacing non-ASCII by nothing + newpart += 'x'; + } else { + newpart += part[j]; + } + } + // we test again with ASCII char only + if (!newpart.match(hostnamePartPattern)) { + var validParts = hostparts.slice(0, i); + var notHost = hostparts.slice(i + 1); + var bit = part.match(hostnamePartStart); + if (bit) { + validParts.push(bit[1]); + notHost.unshift(bit[2]); + } + if (notHost.length) { + rest = '/' + notHost.join('.') + rest; + } + this.hostname = validParts.join('.'); + break; + } + } + } + } + + if (this.hostname.length > hostnameMaxLen) { + this.hostname = ''; + } else { + // hostnames are always lower case. + this.hostname = this.hostname.toLowerCase(); + } + + if (!ipv6Hostname) { + // IDNA Support: Returns a punycoded representation of "domain". + // It only converts parts of the domain name that + // have non-ASCII characters, i.e. it doesn't matter if + // you call it with a domain that already is ASCII-only. + this.hostname = punycode.toASCII(this.hostname); + } + + var p = this.port ? ':' + this.port : ''; + var h = this.hostname || ''; + this.host = h + p; + this.href += this.host; + + // strip [ and ] from the hostname + // the host field still retains them, though + if (ipv6Hostname) { + this.hostname = this.hostname.substr(1, this.hostname.length - 2); + if (rest[0] !== '/') { + rest = '/' + rest; + } + } + } + + // now rest is set to the post-host stuff. + // chop off any delim chars. + if (!unsafeProtocol[lowerProto]) { + + // First, make 100% sure that any "autoEscape" chars get + // escaped, even if encodeURIComponent doesn't think they + // need to be. + for (var i = 0, l = autoEscape.length; i < l; i++) { + var ae = autoEscape[i]; + if (rest.indexOf(ae) === -1) + continue; + var esc = encodeURIComponent(ae); + if (esc === ae) { + esc = escape(ae); + } + rest = rest.split(ae).join(esc); + } + } + + + // chop off from the tail first. + var hash = rest.indexOf('#'); + if (hash !== -1) { + // got a fragment string. + this.hash = rest.substr(hash); + rest = rest.slice(0, hash); + } + var qm = rest.indexOf('?'); + if (qm !== -1) { + this.search = rest.substr(qm); + this.query = rest.substr(qm + 1); + if (parseQueryString) { + this.query = querystring.parse(this.query); + } + rest = rest.slice(0, qm); + } else if (parseQueryString) { + // no query string, but parseQueryString still requested + this.search = ''; + this.query = {}; + } + if (rest) this.pathname = rest; + if (slashedProtocol[lowerProto] && + this.hostname && !this.pathname) { + this.pathname = '/'; + } + + //to support http.request + if (this.pathname || this.search) { + var p = this.pathname || ''; + var s = this.search || ''; + this.path = p + s; + } + + // finally, reconstruct the href based on what has been validated. + this.href = this.format(); + return this; +}; + +// format a parsed object into a url string +function urlFormat(obj) { + // ensure it's an object, and not a string url. + // If it's an obj, this is a no-op. + // this way, you can call url_format() on strings + // to clean up potentially wonky urls. + if (util.isString(obj)) obj = urlParse(obj); + if (!(obj instanceof Url)) return Url.prototype.format.call(obj); + return obj.format(); +} + +Url.prototype.format = function() { + var auth = this.auth || ''; + if (auth) { + auth = encodeURIComponent(auth); + auth = auth.replace(/%3A/i, ':'); + auth += '@'; + } + + var protocol = this.protocol || '', + pathname = this.pathname || '', + hash = this.hash || '', + host = false, + query = ''; + + if (this.host) { + host = auth + this.host; + } else if (this.hostname) { + host = auth + (this.hostname.indexOf(':') === -1 ? + this.hostname : + '[' + this.hostname + ']'); + if (this.port) { + host += ':' + this.port; + } + } + + if (this.query && + util.isObject(this.query) && + Object.keys(this.query).length) { + query = querystring.stringify(this.query); + } + + var search = this.search || (query && ('?' + query)) || ''; + + if (protocol && protocol.substr(-1) !== ':') protocol += ':'; + + // only the slashedProtocols get the //. Not mailto:, xmpp:, etc. + // unless they had them to begin with. + if (this.slashes || + (!protocol || slashedProtocol[protocol]) && host !== false) { + host = '//' + (host || ''); + if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname; + } else if (!host) { + host = ''; + } + + if (hash && hash.charAt(0) !== '#') hash = '#' + hash; + if (search && search.charAt(0) !== '?') search = '?' + search; + + pathname = pathname.replace(/[?#]/g, function(match) { + return encodeURIComponent(match); + }); + search = search.replace('#', '%23'); + + return protocol + host + pathname + search + hash; +}; + +function urlResolve(source, relative) { + return urlParse(source, false, true).resolve(relative); +} + +Url.prototype.resolve = function(relative) { + return this.resolveObject(urlParse(relative, false, true)).format(); +}; + +function urlResolveObject(source, relative) { + if (!source) return relative; + return urlParse(source, false, true).resolveObject(relative); +} + +Url.prototype.resolveObject = function(relative) { + if (util.isString(relative)) { + var rel = new Url(); + rel.parse(relative, false, true); + relative = rel; + } + + var result = new Url(); + var tkeys = Object.keys(this); + for (var tk = 0; tk < tkeys.length; tk++) { + var tkey = tkeys[tk]; + result[tkey] = this[tkey]; + } + + // hash is always overridden, no matter what. + // even href="" will remove it. + result.hash = relative.hash; + + // if the relative url is empty, then there's nothing left to do here. + if (relative.href === '') { + result.href = result.format(); + return result; + } + + // hrefs like //foo/bar always cut to the protocol. + if (relative.slashes && !relative.protocol) { + // take everything except the protocol from relative + var rkeys = Object.keys(relative); + for (var rk = 0; rk < rkeys.length; rk++) { + var rkey = rkeys[rk]; + if (rkey !== 'protocol') + result[rkey] = relative[rkey]; + } + + //urlParse appends trailing / to urls like http://www.example.com + if (slashedProtocol[result.protocol] && + result.hostname && !result.pathname) { + result.path = result.pathname = '/'; + } + + result.href = result.format(); + return result; + } + + if (relative.protocol && relative.protocol !== result.protocol) { + // if it's a known url protocol, then changing + // the protocol does weird things + // first, if it's not file:, then we MUST have a host, + // and if there was a path + // to begin with, then we MUST have a path. + // if it is file:, then the host is dropped, + // because that's known to be hostless. + // anything else is assumed to be absolute. + if (!slashedProtocol[relative.protocol]) { + var keys = Object.keys(relative); + for (var v = 0; v < keys.length; v++) { + var k = keys[v]; + result[k] = relative[k]; + } + result.href = result.format(); + return result; + } + + result.protocol = relative.protocol; + if (!relative.host && !hostlessProtocol[relative.protocol]) { + var relPath = (relative.pathname || '').split('/'); + while (relPath.length && !(relative.host = relPath.shift())); + if (!relative.host) relative.host = ''; + if (!relative.hostname) relative.hostname = ''; + if (relPath[0] !== '') relPath.unshift(''); + if (relPath.length < 2) relPath.unshift(''); + result.pathname = relPath.join('/'); + } else { + result.pathname = relative.pathname; + } + result.search = relative.search; + result.query = relative.query; + result.host = relative.host || ''; + result.auth = relative.auth; + result.hostname = relative.hostname || relative.host; + result.port = relative.port; + // to support http.request + if (result.pathname || result.search) { + var p = result.pathname || ''; + var s = result.search || ''; + result.path = p + s; + } + result.slashes = result.slashes || relative.slashes; + result.href = result.format(); + return result; + } + + var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'), + isRelAbs = ( + relative.host || + relative.pathname && relative.pathname.charAt(0) === '/' + ), + mustEndAbs = (isRelAbs || isSourceAbs || + (result.host && relative.pathname)), + removeAllDots = mustEndAbs, + srcPath = result.pathname && result.pathname.split('/') || [], + relPath = relative.pathname && relative.pathname.split('/') || [], + psychotic = result.protocol && !slashedProtocol[result.protocol]; + + // if the url is a non-slashed url, then relative + // links like ../.. should be able + // to crawl up to the hostname, as well. This is strange. + // result.protocol has already been set by now. + // Later on, put the first path part into the host field. + if (psychotic) { + result.hostname = ''; + result.port = null; + if (result.host) { + if (srcPath[0] === '') srcPath[0] = result.host; + else srcPath.unshift(result.host); + } + result.host = ''; + if (relative.protocol) { + relative.hostname = null; + relative.port = null; + if (relative.host) { + if (relPath[0] === '') relPath[0] = relative.host; + else relPath.unshift(relative.host); + } + relative.host = null; + } + mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === ''); + } + + if (isRelAbs) { + // it's absolute. + result.host = (relative.host || relative.host === '') ? + relative.host : result.host; + result.hostname = (relative.hostname || relative.hostname === '') ? + relative.hostname : result.hostname; + result.search = relative.search; + result.query = relative.query; + srcPath = relPath; + // fall through to the dot-handling below. + } else if (relPath.length) { + // it's relative + // throw away the existing file, and take the new path instead. + if (!srcPath) srcPath = []; + srcPath.pop(); + srcPath = srcPath.concat(relPath); + result.search = relative.search; + result.query = relative.query; + } else if (!util.isNullOrUndefined(relative.search)) { + // just pull out the search. + // like href='?foo'. + // Put this after the other two cases because it simplifies the booleans + if (psychotic) { + result.hostname = result.host = srcPath.shift(); + //occationaly the auth can get stuck only in host + //this especially happens in cases like + //url.resolveObject('mailto:local1@domain1', 'local2@domain2') + var authInHost = result.host && result.host.indexOf('@') > 0 ? + result.host.split('@') : false; + if (authInHost) { + result.auth = authInHost.shift(); + result.host = result.hostname = authInHost.shift(); + } + } + result.search = relative.search; + result.query = relative.query; + //to support http.request + if (!util.isNull(result.pathname) || !util.isNull(result.search)) { + result.path = (result.pathname ? result.pathname : '') + + (result.search ? result.search : ''); + } + result.href = result.format(); + return result; + } + + if (!srcPath.length) { + // no path at all. easy. + // we've already handled the other stuff above. + result.pathname = null; + //to support http.request + if (result.search) { + result.path = '/' + result.search; + } else { + result.path = null; + } + result.href = result.format(); + return result; + } + + // if a url ENDs in . or .., then it must get a trailing slash. + // however, if it ends in anything else non-slashy, + // then it must NOT get a trailing slash. + var last = srcPath.slice(-1)[0]; + var hasTrailingSlash = ( + (result.host || relative.host || srcPath.length > 1) && + (last === '.' || last === '..') || last === ''); + + // strip single dots, resolve double dots to parent dir + // if the path tries to go above the root, `up` ends up > 0 + var up = 0; + for (var i = srcPath.length; i >= 0; i--) { + last = srcPath[i]; + if (last === '.') { + srcPath.splice(i, 1); + } else if (last === '..') { + srcPath.splice(i, 1); + up++; + } else if (up) { + srcPath.splice(i, 1); + up--; + } + } + + // if the path is allowed to go above the root, restore leading ..s + if (!mustEndAbs && !removeAllDots) { + for (; up--; up) { + srcPath.unshift('..'); + } + } + + if (mustEndAbs && srcPath[0] !== '' && + (!srcPath[0] || srcPath[0].charAt(0) !== '/')) { + srcPath.unshift(''); + } + + if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) { + srcPath.push(''); + } + + var isAbsolute = srcPath[0] === '' || + (srcPath[0] && srcPath[0].charAt(0) === '/'); + + // put the host back + if (psychotic) { + result.hostname = result.host = isAbsolute ? '' : + srcPath.length ? srcPath.shift() : ''; + //occationaly the auth can get stuck only in host + //this especially happens in cases like + //url.resolveObject('mailto:local1@domain1', 'local2@domain2') + var authInHost = result.host && result.host.indexOf('@') > 0 ? + result.host.split('@') : false; + if (authInHost) { + result.auth = authInHost.shift(); + result.host = result.hostname = authInHost.shift(); + } + } + + mustEndAbs = mustEndAbs || (result.host && srcPath.length); + + if (mustEndAbs && !isAbsolute) { + srcPath.unshift(''); + } + + if (!srcPath.length) { + result.pathname = null; + result.path = null; + } else { + result.pathname = srcPath.join('/'); + } + + //to support request.http + if (!util.isNull(result.pathname) || !util.isNull(result.search)) { + result.path = (result.pathname ? result.pathname : '') + + (result.search ? result.search : ''); + } + result.auth = relative.auth || result.auth; + result.slashes = result.slashes || relative.slashes; + result.href = result.format(); + return result; +}; + +Url.prototype.parseHost = function() { + var host = this.host; + var port = portPattern.exec(host); + if (port) { + port = port[0]; + if (port !== ':') { + this.port = port.substr(1); + } + host = host.substr(0, host.length - port.length); + } + if (host) this.hostname = host; +}; diff --git a/node_modules/url/util.js b/node_modules/url/util.js new file mode 100644 index 0000000..97dcf31 --- /dev/null +++ b/node_modules/url/util.js @@ -0,0 +1,16 @@ +'use strict'; + +module.exports = { + isString: function(arg) { + return typeof(arg) === 'string'; + }, + isObject: function(arg) { + return typeof(arg) === 'object' && arg !== null; + }, + isNull: function(arg) { + return arg === null; + }, + isNullOrUndefined: function(arg) { + return arg == null; + } +}; diff --git a/package-lock.json b/package-lock.json index 9b5d4cd..388b44c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,15 +1,125 @@ { "name": "ratzbot", - "version": "3.0.0", + "version": "3.1.0", "lockfileVersion": 1, "requires": true, "dependencies": { + "@protobufjs/aspromise": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", + "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" + }, + "@protobufjs/base64": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", + "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" + }, + "@protobufjs/codegen": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", + "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" + }, + "@protobufjs/eventemitter": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", + "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" + }, + "@protobufjs/fetch": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", + "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", + "requires": { + "@protobufjs/aspromise": "^1.1.1", + "@protobufjs/inquire": "^1.1.0" + } + }, + "@protobufjs/float": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", + "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" + }, + "@protobufjs/inquire": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", + "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" + }, + "@protobufjs/path": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", + "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" + }, + "@protobufjs/pool": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", + "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" + }, + "@protobufjs/utf8": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", + "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" + }, + "@tensorflow/tfjs": { + "version": "0.12.4", + "resolved": "https://registry.npmjs.org/@tensorflow/tfjs/-/tfjs-0.12.4.tgz", + "integrity": "sha512-K/UZ0QyRqs36HWJcrddYz0AGpFtTJgWoIwUjG5041CixoEb3uyKS4ejEjECRdPy6TPFpjnIyYuO4hZMc3ny/Vg==", + "requires": { + "@tensorflow/tfjs-converter": "0.5.5", + "@tensorflow/tfjs-core": "0.12.8", + "@tensorflow/tfjs-layers": "0.7.2" + } + }, + "@tensorflow/tfjs-converter": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/@tensorflow/tfjs-converter/-/tfjs-converter-0.5.5.tgz", + "integrity": "sha512-tLIv4u0+BtE61oarjQWJUsL0Ro54YmiDx8XVCbN9QY34V6zZrNFr/VJYZEIZnKcepCQ0MxZ09mggnfBD3EvMrQ==", + "requires": { + "@types/long": "~3.0.32", + "protobufjs": "~6.8.6", + "url": "~0.11.0" + } + }, + "@tensorflow/tfjs-core": { + "version": "0.12.8", + "resolved": "https://registry.npmjs.org/@tensorflow/tfjs-core/-/tfjs-core-0.12.8.tgz", + "integrity": "sha512-Rm3HgjZ0hMbWz8Vj/s9wLtP4ddp+1mi7SyrAbcQ9dU/jnjGupiXBWnAUjiSsID5FtBpVYvvlIxSegmWQxcXorg==", + "requires": { + "@types/seedrandom": "~2.4.27", + "@types/webgl-ext": "~0.0.29", + "@types/webgl2": "~0.0.4", + "seedrandom": "~2.4.3" + } + }, + "@tensorflow/tfjs-layers": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/@tensorflow/tfjs-layers/-/tfjs-layers-0.7.2.tgz", + "integrity": "sha512-NwGmyYCrzV8cYycqA9fVfBWaz1zS1hqHP5MsRwU1m92TX/5lEhRClRmVCHJ4K8/GR+tYMl1PR/qCkeRjttwk7A==" + }, + "@types/long": { + "version": "3.0.32", + "resolved": "https://registry.npmjs.org/@types/long/-/long-3.0.32.tgz", + "integrity": "sha512-ZXyOOm83p7X8p3s0IYM3VeueNmHpkk/yMlP8CLeOnEcu6hIwPH7YjZBvhQkR0ZFS2DqZAxKtJ/M5fcuv3OU5BA==" + }, "@types/node": { "version": "8.10.20", "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.20.tgz", "integrity": "sha512-M7x8+5D1k/CuA6jhiwuSCmE8sbUWJF0wYsjcig9WrXvwUI5ArEoUBdOXpV4JcEMrLp02/QbDjw+kI+vQeKyQgg==", "dev": true }, + "@types/seedrandom": { + "version": "2.4.27", + "resolved": "https://registry.npmjs.org/@types/seedrandom/-/seedrandom-2.4.27.tgz", + "integrity": "sha1-nbVjk33YaRX2kJK8QyWdL0hXjkE=" + }, + "@types/webgl-ext": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/webgl-ext/-/webgl-ext-0.0.29.tgz", + "integrity": "sha512-ZlVjDQU5Vlc9hF4LGdDldujZUf0amwlwGv1RI2bfvdrEHIl6X/7MZVpemJUjS7NxD9XaKfE8SlFrxsfXpUkt/A==" + }, + "@types/webgl2": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/@types/webgl2/-/webgl2-0.0.4.tgz", + "integrity": "sha512-PACt1xdErJbMUOUweSrbVM7gSIYm1vTncW2hF6Os/EeWi6TXYAYMPp+8v6rzHmypE5gHrxaxZNXgMkJVIdZpHw==" + }, "ajv": { "version": "5.5.2", "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", @@ -216,6 +326,12 @@ "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", "dev": true }, + "coffeescript": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/coffeescript/-/coffeescript-2.3.1.tgz", + "integrity": "sha512-DNJmSPMyiz+OjWYyuDXNBcFutDjP2TS2owsZ8YvT65hA8c5IdHWIBqdA3Yf/XHoK23d/f1HqLjQbEJJZJoeV1w==", + "dev": true + }, "combined-stream": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.6.tgz", @@ -1906,6 +2022,38 @@ "through2": "~0.2.3" } }, + "protobufjs": { + "version": "6.8.8", + "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.8.tgz", + "integrity": "sha512-AAmHtD5pXgZfi7GMpllpO3q1Xw1OYldr+dMUlAnffGTAhqkg72WdmSY71uKBF/JuyiKs8psYbtKrhi0ASCD8qw==", + "requires": { + "@protobufjs/aspromise": "^1.1.2", + "@protobufjs/base64": "^1.1.2", + "@protobufjs/codegen": "^2.0.4", + "@protobufjs/eventemitter": "^1.1.0", + "@protobufjs/fetch": "^1.1.0", + "@protobufjs/float": "^1.0.2", + "@protobufjs/inquire": "^1.1.0", + "@protobufjs/path": "^1.1.2", + "@protobufjs/pool": "^1.1.0", + "@protobufjs/utf8": "^1.1.0", + "@types/long": "^4.0.0", + "@types/node": "^10.1.0", + "long": "^4.0.0" + }, + "dependencies": { + "@types/long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.0.tgz", + "integrity": "sha512-1w52Nyx4Gq47uuu0EVcsHBxZFJgurQ+rTKS3qMHxR1GY2T8c2AJYd6vZoZ9q1rupaDjU0yT+Jc2XTyXkjeMA+Q==" + }, + "@types/node": { + "version": "10.5.7", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.5.7.tgz", + "integrity": "sha512-VkKcfuitP+Nc/TaTFH0B8qNmn+6NbI6crLkQonbedViVz7O2w8QV/GERPlkJ4bg42VGHiEWa31CoTOPs1q6z1w==" + } + } + }, "punycode": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", @@ -1916,6 +2064,11 @@ "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" + }, "rc": { "version": "1.2.8", "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", @@ -2031,6 +2184,11 @@ "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" }, + "seedrandom": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/seedrandom/-/seedrandom-2.4.3.tgz", + "integrity": "sha1-JDhQTa0zkXMUv/GKxNeU8W1qrsw=" + }, "seek-bzip": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/seek-bzip/-/seek-bzip-1.0.5.tgz", @@ -2304,6 +2462,22 @@ "through": "^2.3.6" } }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" + } + } + }, "util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", diff --git a/package.json b/package.json index b228de2..896c9c0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "ratzbot", - "version": "3.0.0", + "version": "3.1.0", "description": "Discord bot for Twitch streamer ratzDoll", "main": "main.js", "scripts": { @@ -10,6 +10,7 @@ "author": "Gavin Isgar", "license": "GPL-3.0-or-later", "dependencies": { + "@tensorflow/tfjs": "^0.12.4", "discord-rpc": "^3.0.0-beta.11", "discord.js": "^11.3.2", "ffmpeg-binaries": "^4.0.0", @@ -18,6 +19,7 @@ "ytdl-core": "^0.20.4" }, "devDependencies": { + "coffeescript": "^2.3.1", "electron": "^2.0.2" } }